@anker-in/analysis 0.1.0 → 0.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (104) hide show
  1. package/dist/index.cjs +827 -0
  2. package/dist/index.cjs.map +1 -0
  3. package/dist/index.d.mts +489 -0
  4. package/dist/index.d.ts +474 -21
  5. package/dist/index.js +771 -33
  6. package/dist/index.js.map +1 -0
  7. package/package.json +23 -36
  8. package/dist/autoTrack/click.d.ts +0 -2
  9. package/dist/autoTrack/click.d.ts.map +0 -1
  10. package/dist/autoTrack/click.js +0 -80
  11. package/dist/autoTrack/index.d.ts +0 -2
  12. package/dist/autoTrack/index.d.ts.map +0 -1
  13. package/dist/autoTrack/index.js +0 -47
  14. package/dist/autoTrack/pv.d.ts +0 -2
  15. package/dist/autoTrack/pv.d.ts.map +0 -1
  16. package/dist/autoTrack/pv.js +0 -57
  17. package/dist/autoTrack/trackByTags.d.ts +0 -17
  18. package/dist/autoTrack/trackByTags.d.ts.map +0 -1
  19. package/dist/autoTrack/trackByTags.js +0 -141
  20. package/dist/constants/index.d.ts +0 -2
  21. package/dist/constants/index.d.ts.map +0 -1
  22. package/dist/constants/index.js +0 -1
  23. package/dist/constants/tagsMap.d.ts +0 -9
  24. package/dist/constants/tagsMap.d.ts.map +0 -1
  25. package/dist/constants/tagsMap.js +0 -8
  26. package/dist/core/adapters/gtag.d.ts +0 -37
  27. package/dist/core/adapters/gtag.d.ts.map +0 -1
  28. package/dist/core/adapters/gtag.js +0 -55
  29. package/dist/core/adapters/index.d.ts +0 -6
  30. package/dist/core/adapters/index.d.ts.map +0 -1
  31. package/dist/core/adapters/index.js +0 -5
  32. package/dist/core/adapters/meta.d.ts +0 -20
  33. package/dist/core/adapters/meta.d.ts.map +0 -1
  34. package/dist/core/adapters/meta.js +0 -41
  35. package/dist/core/helpers/function-utils.d.ts +0 -17
  36. package/dist/core/helpers/function-utils.d.ts.map +0 -1
  37. package/dist/core/helpers/function-utils.js +0 -43
  38. package/dist/core/helpers/index.d.ts +0 -8
  39. package/dist/core/helpers/index.d.ts.map +0 -1
  40. package/dist/core/helpers/index.js +0 -7
  41. package/dist/core/helpers/logger.d.ts +0 -20
  42. package/dist/core/helpers/logger.d.ts.map +0 -1
  43. package/dist/core/helpers/logger.js +0 -32
  44. package/dist/core/helpers/platform-detector.d.ts +0 -14
  45. package/dist/core/helpers/platform-detector.d.ts.map +0 -1
  46. package/dist/core/helpers/platform-detector.js +0 -28
  47. package/dist/core/helpers/script-loader.d.ts +0 -39
  48. package/dist/core/helpers/script-loader.d.ts.map +0 -1
  49. package/dist/core/helpers/script-loader.js +0 -107
  50. package/dist/core/index.d.ts +0 -7
  51. package/dist/core/index.d.ts.map +0 -1
  52. package/dist/core/index.js +0 -9
  53. package/dist/core/track/gtagTrack.d.ts +0 -2
  54. package/dist/core/track/gtagTrack.d.ts.map +0 -1
  55. package/dist/core/track/gtagTrack.js +0 -12
  56. package/dist/core/track/index.d.ts +0 -4
  57. package/dist/core/track/index.d.ts.map +0 -1
  58. package/dist/core/track/index.js +0 -3
  59. package/dist/core/track/metaTrack.d.ts +0 -2
  60. package/dist/core/track/metaTrack.d.ts.map +0 -1
  61. package/dist/core/track/metaTrack.js +0 -18
  62. package/dist/core/track/track.d.ts +0 -6
  63. package/dist/core/track/track.d.ts.map +0 -1
  64. package/dist/core/track/track.js +0 -128
  65. package/dist/core/tracking/dispatcher.d.ts +0 -10
  66. package/dist/core/tracking/dispatcher.d.ts.map +0 -1
  67. package/dist/core/tracking/dispatcher.js +0 -67
  68. package/dist/core/tracking/index.d.ts +0 -6
  69. package/dist/core/tracking/index.d.ts.map +0 -1
  70. package/dist/core/tracking/index.js +0 -5
  71. package/dist/core/tracking/with-tracking.d.ts +0 -33
  72. package/dist/core/tracking/with-tracking.d.ts.map +0 -1
  73. package/dist/core/tracking/with-tracking.js +0 -137
  74. package/dist/core/utils.d.ts +0 -64
  75. package/dist/core/utils.d.ts.map +0 -1
  76. package/dist/core/utils.js +0 -182
  77. package/dist/index.d.ts.map +0 -1
  78. package/dist/pixels/GtagPixel.d.ts +0 -7
  79. package/dist/pixels/GtagPixel.d.ts.map +0 -1
  80. package/dist/pixels/GtagPixel.js +0 -73
  81. package/dist/pixels/MetaPixel.d.ts +0 -7
  82. package/dist/pixels/MetaPixel.d.ts.map +0 -1
  83. package/dist/pixels/MetaPixel.js +0 -61
  84. package/dist/pixels/PixelsManager.d.ts +0 -5
  85. package/dist/pixels/PixelsManager.d.ts.map +0 -1
  86. package/dist/pixels/PixelsManager.js +0 -17
  87. package/dist/pixels/index.d.ts +0 -4
  88. package/dist/pixels/index.d.ts.map +0 -1
  89. package/dist/pixels/index.js +0 -3
  90. package/dist/types/common.d.ts +0 -66
  91. package/dist/types/common.d.ts.map +0 -1
  92. package/dist/types/common.js +0 -1
  93. package/dist/types/gtag.d.ts +0 -34
  94. package/dist/types/gtag.d.ts.map +0 -1
  95. package/dist/types/gtag.js +0 -1
  96. package/dist/types/index.d.ts +0 -91
  97. package/dist/types/index.d.ts.map +0 -1
  98. package/dist/types/index.js +0 -1
  99. package/dist/types/meta.d.ts +0 -8
  100. package/dist/types/meta.d.ts.map +0 -1
  101. package/dist/types/meta.js +0 -4
  102. package/dist/types/trackByTags.d.ts +0 -26
  103. package/dist/types/trackByTags.d.ts.map +0 -1
  104. package/dist/types/trackByTags.js +0 -4
package/dist/index.js CHANGED
@@ -1,34 +1,772 @@
1
- /**
2
- * Analysis SDK - 埋点 SDK 主入口
3
- *
4
- * 提供统一的埋点接口,支持多平台埋点上报
5
- */
6
- // ============= 核心功能 =============
7
- export { track } from "./core/tracking";
8
- export { gtagTrack } from "./core/adapters";
9
- export { metaTrack } from "./core/adapters";
10
- // ============= 高阶函数 - 无侵入式埋点 =============
11
- export { withTracking, useTracking } from "./core/tracking";
12
- // ============= TrackByTags 功能 =============
13
- export { trackByTags } from "./autoTrack/trackByTags";
14
- // ============= 工具函数 =============
15
- export { logger, isPlatformAvailable, updateScriptType, updateScriptsType, } from "./core/helpers";
16
- // ============= Pixels 组件 =============
17
- export { GtagPixel, MetaPixel, PixelsManager } from "./pixels";
18
- // ============= 常量 =============
19
- export { TrackTagsVersionMap } from "./constants";
20
- // ============= 默认导出 =============
21
- import { track } from "./core/tracking";
22
- import { trackByTags } from "./autoTrack/trackByTags";
23
- import { logger, isPlatformAvailable, updateScriptType, updateScriptsType, } from "./core/helpers";
24
- import { withTracking, useTracking } from "./core/tracking";
25
- export default {
26
- track,
27
- trackByTags,
28
- withTracking,
29
- useTracking,
30
- logger,
31
- isPlatformAvailable,
32
- updateScriptType,
33
- updateScriptsType,
1
+ var __defProp = Object.defineProperty;
2
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
+
4
+ // src/core/helpers/logger.ts
5
+ function createLogger(initialEnabled = false) {
6
+ let enabled = initialEnabled;
7
+ return {
8
+ setEnabled(value) {
9
+ enabled = value;
10
+ },
11
+ log(...args) {
12
+ if (enabled) {
13
+ console.log("[Analysis SDK]", ...args);
14
+ }
15
+ },
16
+ warn(...args) {
17
+ if (enabled) {
18
+ console.warn("[Analysis SDK]", ...args);
19
+ }
20
+ },
21
+ error(...args) {
22
+ if (enabled) {
23
+ console.error("[Analysis SDK]", ...args);
24
+ }
25
+ }
26
+ };
27
+ }
28
+ __name(createLogger, "createLogger");
29
+ var logger = createLogger();
30
+
31
+ // src/core/helpers/script-loader.ts
32
+ function updateScriptType(options) {
33
+ const { id, enabled, executeOnEnable = true, onError } = options;
34
+ if (typeof window === "undefined") {
35
+ return false;
36
+ }
37
+ const scriptElement = document.getElementById(id);
38
+ if (!scriptElement) {
39
+ logger.warn(`Script element with id "${id}" not found`);
40
+ return false;
41
+ }
42
+ const newType = enabled ? "text/javascript" : "text/plain";
43
+ const currentType = scriptElement.getAttribute("type");
44
+ if (executeOnEnable && currentType === "text/plain" && newType === "text/javascript") {
45
+ scriptElement.setAttribute("type", newType);
46
+ const scriptContent = scriptElement.innerHTML;
47
+ if (scriptContent && typeof window.eval === "function") {
48
+ try {
49
+ window.eval(scriptContent);
50
+ logger.log(`Script "${id}" executed successfully`);
51
+ } catch (e) {
52
+ const error = e instanceof Error ? e : new Error(String(e));
53
+ logger.error(`Script "${id}" execution error:`, error);
54
+ if (onError) {
55
+ onError(error);
56
+ }
57
+ }
58
+ }
59
+ } else {
60
+ scriptElement.setAttribute("type", newType);
61
+ }
62
+ return true;
63
+ }
64
+ __name(updateScriptType, "updateScriptType");
65
+ function updateScriptsType(scriptIds, enabled, executeOnEnable = true) {
66
+ if (typeof window === "undefined") {
67
+ return 0;
68
+ }
69
+ let successCount = 0;
70
+ const ids = Array.isArray(scriptIds) ? scriptIds : Array.from({ length: 100 }, (_, i) => scriptIds(i)).filter(
71
+ (id) => document.getElementById(id)
72
+ );
73
+ ids.forEach((id) => {
74
+ const success = updateScriptType({
75
+ id,
76
+ enabled,
77
+ executeOnEnable
78
+ });
79
+ if (success) {
80
+ successCount++;
81
+ }
82
+ });
83
+ logger.log(`Updated ${successCount}/${ids.length} scripts`);
84
+ return successCount;
85
+ }
86
+ __name(updateScriptsType, "updateScriptsType");
87
+
88
+ // src/core/helpers/function-utils.ts
89
+ function debounce(fn, delay) {
90
+ let timer = null;
91
+ return function(...args) {
92
+ if (timer) clearTimeout(timer);
93
+ timer = setTimeout(() => {
94
+ fn.apply(this, args);
95
+ }, delay);
96
+ };
97
+ }
98
+ __name(debounce, "debounce");
99
+ function throttle(fn, delay) {
100
+ let lastTime = 0;
101
+ return function(...args) {
102
+ const now = Date.now();
103
+ if (now - lastTime >= delay) {
104
+ lastTime = now;
105
+ fn.apply(this, args);
106
+ }
107
+ };
108
+ }
109
+ __name(throttle, "throttle");
110
+
111
+ // src/core/helpers/platform-detector.ts
112
+ var isPlatformAvailable = /* @__PURE__ */ __name((platform) => {
113
+ if (typeof window === "undefined") {
114
+ return false;
115
+ }
116
+ switch (platform) {
117
+ case "gtag":
118
+ return typeof window.gtag !== "undefined" || typeof window.dataLayer !== "undefined";
119
+ case "meta":
120
+ return typeof window.fbq !== "undefined";
121
+ default:
122
+ return false;
123
+ }
124
+ }, "isPlatformAvailable");
125
+
126
+ // src/constants/tagsMap.ts
127
+ var TrackTagsVersionMap = {
128
+ "fbq:act": "fbq:atc",
129
+ "gtag:conversion": "gtag:atc"
34
130
  };
131
+
132
+ // src/autoTrack/trackByTags.ts
133
+ function parseTag(tag) {
134
+ const parts = tag.split(":");
135
+ if (parts.length < 2) {
136
+ return null;
137
+ }
138
+ return {
139
+ media: parts[0]?.toLowerCase() || "",
140
+ event: parts[1]?.toLowerCase() || "",
141
+ target: parts[2] || null
142
+ };
143
+ }
144
+ __name(parseTag, "parseTag");
145
+ function adaptEventName(tags) {
146
+ for (let i = 0; i < tags.length; i++) {
147
+ if (!tags[i]) {
148
+ continue;
149
+ }
150
+ for (const [oldEvent, newEvent] of Object.entries(TrackTagsVersionMap)) {
151
+ if (tags[i]?.includes(oldEvent)) {
152
+ tags[i] = tags[i]?.replace(oldEvent, newEvent) ?? "";
153
+ break;
154
+ }
155
+ }
156
+ }
157
+ }
158
+ __name(adaptEventName, "adaptEventName");
159
+ function handleTagTracking(parsedTag, eventData) {
160
+ const { media, event, target } = parsedTag;
161
+ if (!target) {
162
+ logger.warn(`Tag missing target: ${media}:${event}`);
163
+ return;
164
+ }
165
+ try {
166
+ switch (media) {
167
+ case "fbq":
168
+ case "meta": {
169
+ const config = {
170
+ platform: "meta",
171
+ event: target,
172
+ // target 作为事件名
173
+ data: eventData
174
+ };
175
+ track(config);
176
+ break;
177
+ }
178
+ case "gtag": {
179
+ const config = {
180
+ platform: "gtag",
181
+ eventName: "conversion",
182
+ send_to: target,
183
+ // target 作为转化目标ID
184
+ value: eventData?.value ?? 1,
185
+ currency: eventData?.currency,
186
+ transactionId: eventData?.transactionId
187
+ };
188
+ track(config);
189
+ break;
190
+ }
191
+ default:
192
+ logger.warn(`Unsupported media platform: ${media}`);
193
+ }
194
+ } catch (error) {
195
+ logger.error(`Failed to track tag ${media}:${event}:${target}:`, error);
196
+ }
197
+ }
198
+ __name(handleTagTracking, "handleTagTracking");
199
+ function trackByTags({ tags, data }) {
200
+ if (!tags || tags.length === 0) {
201
+ logger.warn("trackByTags: tags array is empty");
202
+ return;
203
+ }
204
+ const adaptedTags = [...tags];
205
+ adaptEventName(adaptedTags);
206
+ const firstData = data && data.length > 0 ? data[0] : void 0;
207
+ const { event, ...trackingData } = firstData || {};
208
+ adaptedTags.forEach((tag) => {
209
+ const parsed = parseTag(tag);
210
+ if (!parsed) {
211
+ logger.warn(`trackByTags: Invalid tag format: ${tag}`);
212
+ return;
213
+ }
214
+ handleTagTracking(parsed, trackingData);
215
+ });
216
+ }
217
+ __name(trackByTags, "trackByTags");
218
+
219
+ // src/core/helpers/triggerTrack.ts
220
+ function getTrackTagsFromStorage(storageKey) {
221
+ if (typeof window === "undefined" || !window.sessionStorage) {
222
+ logger.warn("sessionStorage is not available");
223
+ return null;
224
+ }
225
+ try {
226
+ const trackTagsRaw = sessionStorage.getItem(storageKey);
227
+ if (!trackTagsRaw) {
228
+ return null;
229
+ }
230
+ const trackTags = JSON.parse(trackTagsRaw);
231
+ if (!trackTags || typeof trackTags !== "object") {
232
+ logger.warn(
233
+ `Invalid trackTags format in sessionStorage key: ${storageKey}`
234
+ );
235
+ return null;
236
+ }
237
+ return trackTags;
238
+ } catch (error) {
239
+ logger.error(`Failed to parse trackTags from sessionStorage:`, error);
240
+ return null;
241
+ }
242
+ }
243
+ __name(getTrackTagsFromStorage, "getTrackTagsFromStorage");
244
+ function triggerTrack(trackPoint, options = {}) {
245
+ const {
246
+ tags,
247
+ eventData = {},
248
+ storageKey = "trackTags",
249
+ silent = false
250
+ } = options;
251
+ if (!trackPoint || typeof trackPoint !== "string") {
252
+ if (!silent) {
253
+ logger.warn("triggerTrack: trackPoint is required and must be a string");
254
+ }
255
+ return;
256
+ }
257
+ const trackTagsRow = getTrackTagsFromStorage(storageKey);
258
+ if (!trackTagsRow) {
259
+ if (!silent) {
260
+ logger.warn(
261
+ `triggerTrack: trackTags not found in sessionStorage (key: ${storageKey})`
262
+ );
263
+ }
264
+ return;
265
+ }
266
+ const trackTags = tags || trackTagsRow[trackPoint];
267
+ if (!trackTags) {
268
+ if (!silent) {
269
+ logger.warn(`triggerTrack: No tags found for trackPoint: ${trackPoint}`);
270
+ }
271
+ return;
272
+ }
273
+ if (!Array.isArray(trackTags)) {
274
+ if (!silent) {
275
+ logger.warn(
276
+ `triggerTrack: Tags for trackPoint "${trackPoint}" is not an array`
277
+ );
278
+ }
279
+ return;
280
+ }
281
+ if (trackTags.length === 0) {
282
+ if (!silent) {
283
+ logger.log(
284
+ `triggerTrack: Tags array is empty for trackPoint: ${trackPoint}`
285
+ );
286
+ }
287
+ return;
288
+ }
289
+ try {
290
+ trackByTags({
291
+ tags: trackTags,
292
+ data: [{ event: "custom", ...eventData }]
293
+ });
294
+ logger.log(
295
+ `triggerTrack: Successfully triggered for trackPoint: ${trackPoint}`,
296
+ {
297
+ tagsCount: trackTags.length,
298
+ trackTags
299
+ }
300
+ );
301
+ } catch (error) {
302
+ logger.error(
303
+ `triggerTrack: Failed to track for trackPoint: ${trackPoint}`,
304
+ error
305
+ );
306
+ }
307
+ }
308
+ __name(triggerTrack, "triggerTrack");
309
+ function triggerTrackBatch(trackPoints, options = {}) {
310
+ if (!Array.isArray(trackPoints)) {
311
+ logger.warn("triggerTrackBatch: trackPoints must be an array");
312
+ return;
313
+ }
314
+ trackPoints.forEach((trackPoint) => {
315
+ triggerTrack(trackPoint, options);
316
+ });
317
+ }
318
+ __name(triggerTrackBatch, "triggerTrackBatch");
319
+ function setTrackTags(trackTags, storageKey = "trackTags") {
320
+ if (typeof window === "undefined" || !window.sessionStorage) {
321
+ logger.warn("sessionStorage is not available");
322
+ return;
323
+ }
324
+ try {
325
+ const trackTagsJson = JSON.stringify(trackTags);
326
+ sessionStorage.setItem(storageKey, trackTagsJson);
327
+ logger.log(
328
+ `setTrackTags: Successfully saved to sessionStorage (key: ${storageKey})`
329
+ );
330
+ } catch (error) {
331
+ logger.error("setTrackTags: Failed to save to sessionStorage", error);
332
+ }
333
+ }
334
+ __name(setTrackTags, "setTrackTags");
335
+ function clearTrackTags(storageKey = "trackTags") {
336
+ if (typeof window === "undefined" || !window.sessionStorage) {
337
+ return;
338
+ }
339
+ try {
340
+ sessionStorage.removeItem(storageKey);
341
+ logger.log(
342
+ `clearTrackTags: Successfully removed from sessionStorage (key: ${storageKey})`
343
+ );
344
+ } catch (error) {
345
+ logger.error("clearTrackTags: Failed to remove from sessionStorage", error);
346
+ }
347
+ }
348
+ __name(clearTrackTags, "clearTrackTags");
349
+ function hasTrackPoint(trackPoint, storageKey = "trackTags") {
350
+ const trackTags = getTrackTagsFromStorage(storageKey);
351
+ if (!trackTags) {
352
+ return false;
353
+ }
354
+ const tags = trackTags[trackPoint];
355
+ return Array.isArray(tags) && tags.length > 0;
356
+ }
357
+ __name(hasTrackPoint, "hasTrackPoint");
358
+
359
+ // src/core/adapters/gtag.ts
360
+ var gtagTrack = /* @__PURE__ */ __name((command, targetOrEventName, params) => {
361
+ if (typeof window === "undefined") {
362
+ return;
363
+ }
364
+ if (typeof window.gtag !== "function") {
365
+ console.warn("gtag is not available. Please load gtag.js first.");
366
+ return;
367
+ }
368
+ try {
369
+ window.gtag(command, targetOrEventName, params);
370
+ } catch (error) {
371
+ console.error("gtagTrack error:", error);
372
+ }
373
+ }, "gtagTrack");
374
+ var gtagEvent = /* @__PURE__ */ __name((eventName, eventParams) => {
375
+ gtagTrack("event", eventName, eventParams);
376
+ }, "gtagEvent");
377
+ var gtagConfig = /* @__PURE__ */ __name((measurementId, configParams) => {
378
+ gtagTrack("config", measurementId, configParams);
379
+ }, "gtagConfig");
380
+
381
+ // src/core/adapters/meta.ts
382
+ var metaTrack = /* @__PURE__ */ __name((event, data) => {
383
+ if (typeof window === "undefined") {
384
+ return;
385
+ }
386
+ if (typeof window.fbq !== "undefined") {
387
+ try {
388
+ if (data) {
389
+ window.fbq("track", event, data);
390
+ } else {
391
+ window.fbq("track", event);
392
+ }
393
+ } catch (error) {
394
+ console.log("fbqTrack error", error);
395
+ }
396
+ }
397
+ }, "metaTrack");
398
+
399
+ // src/core/tracking/dispatcher.ts
400
+ function track(config) {
401
+ const { platform, ...params } = config;
402
+ if (!isPlatformAvailable(platform)) {
403
+ logger.warn(`Platform ${platform} is not available`);
404
+ return;
405
+ }
406
+ try {
407
+ switch (platform) {
408
+ case "gtag": {
409
+ const gtagParams = params;
410
+ handleGtagTrack(gtagParams);
411
+ break;
412
+ }
413
+ case "meta": {
414
+ const metaParams = params;
415
+ handleMetaTrack(metaParams);
416
+ break;
417
+ }
418
+ default:
419
+ logger.warn(`Unsupported platform: ${platform}`);
420
+ }
421
+ } catch (error) {
422
+ logger.error(`Failed to track on platform ${platform}:`, error);
423
+ }
424
+ }
425
+ __name(track, "track");
426
+ function handleGtagTrack(params) {
427
+ const { eventName, measurementId, ...restParams } = params;
428
+ if (measurementId) {
429
+ gtagConfig(measurementId, {});
430
+ }
431
+ const eventParams = { ...restParams };
432
+ if (eventParams.transactionId && !eventParams.transaction_id) {
433
+ eventParams.transaction_id = eventParams.transactionId;
434
+ delete eventParams.transactionId;
435
+ }
436
+ gtagEvent(eventName, eventParams);
437
+ logger.log(`Gtag conversion tracked: ${eventName}`, eventParams);
438
+ }
439
+ __name(handleGtagTrack, "handleGtagTrack");
440
+ function handleMetaTrack(params) {
441
+ const { event, data } = params;
442
+ if (!event) {
443
+ logger.warn("Meta Pixel event name is required");
444
+ return;
445
+ }
446
+ metaTrack(event, data);
447
+ logger.log(`Meta Pixel event tracked: ${event}`, data);
448
+ }
449
+ __name(handleMetaTrack, "handleMetaTrack");
450
+
451
+ // src/core/tracking/with-tracking.ts
452
+ function executeTracking(trackPoint, trackConfig) {
453
+ const configs = Array.isArray(trackConfig) ? trackConfig : [trackConfig ?? {}];
454
+ configs.forEach((config) => {
455
+ try {
456
+ track(config);
457
+ } catch (error) {
458
+ logger.error("withTracking: \u57CB\u70B9\u6267\u884C\u5931\u8D25", error);
459
+ }
460
+ });
461
+ if (typeof window !== "undefined" && !!trackPoint && window.__FUN_TRACK_TAGS__?.[trackPoint ?? ""]?.length > 0) {
462
+ trackByTags({
463
+ tags: window.__FUN_TRACK_TAGS__?.[trackPoint ?? ""] ?? [],
464
+ data: [{ event: "custom" }]
465
+ });
466
+ }
467
+ }
468
+ __name(executeTracking, "executeTracking");
469
+ function withTracking(fn, config) {
470
+ const {
471
+ trackConfig,
472
+ timing = "after",
473
+ condition,
474
+ trackOnError = false,
475
+ errorTrackConfig,
476
+ debounce: debounceTime,
477
+ throttle: throttleTime,
478
+ trackPoint
479
+ } = config;
480
+ function wrappedFunction(...args) {
481
+ if (condition && !condition(args)) {
482
+ return fn(...args);
483
+ }
484
+ const getTrackConfig = /* @__PURE__ */ __name((result) => {
485
+ return typeof trackConfig === "function" ? trackConfig(args, result) : trackConfig;
486
+ }, "getTrackConfig");
487
+ if (timing === "before" || timing === "both") {
488
+ const config2 = getTrackConfig();
489
+ executeTracking(trackPoint, config2);
490
+ }
491
+ try {
492
+ const result = fn(...args);
493
+ if (result instanceof Promise) {
494
+ return result.then((resolvedResult) => {
495
+ if (timing === "after" || timing === "both") {
496
+ const config2 = getTrackConfig(resolvedResult);
497
+ executeTracking(trackPoint, config2);
498
+ }
499
+ return resolvedResult;
500
+ }).catch((error) => {
501
+ if (trackOnError && errorTrackConfig) {
502
+ executeTracking(trackPoint, errorTrackConfig(error, args));
503
+ }
504
+ throw error;
505
+ });
506
+ }
507
+ if (timing === "after" || timing === "both") {
508
+ const config2 = getTrackConfig(result);
509
+ executeTracking(trackPoint, config2);
510
+ }
511
+ return result;
512
+ } catch (error) {
513
+ if (trackOnError && errorTrackConfig) {
514
+ executeTracking(trackPoint, errorTrackConfig(error, args));
515
+ }
516
+ throw error;
517
+ }
518
+ }
519
+ __name(wrappedFunction, "wrappedFunction");
520
+ if (typeof window !== "undefined" && !!trackPoint) {
521
+ const urlParams = new URLSearchParams(window.location.search);
522
+ if (urlParams.has("TRACK_DEV")) {
523
+ return ((...args) => {
524
+ window.open(
525
+ `http://localhost:3002/tracking?trackPoint=${trackPoint}`,
526
+ "_blank"
527
+ );
528
+ });
529
+ }
530
+ }
531
+ if (debounceTime) {
532
+ return debounce(wrappedFunction, debounceTime);
533
+ }
534
+ if (throttleTime) {
535
+ return throttle(wrappedFunction, throttleTime);
536
+ }
537
+ return wrappedFunction;
538
+ }
539
+ __name(withTracking, "withTracking");
540
+ function useTracking(config) {
541
+ return (fn) => {
542
+ return withTracking(fn, config);
543
+ };
544
+ }
545
+ __name(useTracking, "useTracking");
546
+
547
+ // src/pixels/GtagPixel.tsx
548
+ import { useEffect, useRef, useMemo } from "react";
549
+ import Script from "next/script";
550
+ import { Fragment, jsx } from "react/jsx-runtime";
551
+ var GtagPixel = /* @__PURE__ */ __name((props) => {
552
+ const {
553
+ cookieConsentEnabled,
554
+ pixelIds,
555
+ strategy,
556
+ onPixelLoaded,
557
+ ...scriptProps
558
+ } = props;
559
+ const pixelIdsKey = useMemo(() => JSON.stringify(pixelIds), [pixelIds]);
560
+ const pixelIdsArray = useMemo(
561
+ () => Array.isArray(pixelIds) ? pixelIds : [pixelIds],
562
+ [pixelIdsKey]
563
+ );
564
+ const onLoadRef = useRef(onPixelLoaded);
565
+ useEffect(() => {
566
+ onLoadRef.current = onPixelLoaded;
567
+ }, [onPixelLoaded]);
568
+ const initializeGtag = /* @__PURE__ */ __name((pixelId) => {
569
+ try {
570
+ window.dataLayer = window.dataLayer || [];
571
+ if (typeof window.gtag !== "function") {
572
+ window.gtag = /* @__PURE__ */ __name(function gtag() {
573
+ window.dataLayer.push(arguments);
574
+ }, "gtag");
575
+ }
576
+ window.gtag("js", /* @__PURE__ */ new Date());
577
+ window.gtag("config", pixelId, {
578
+ allow_enhanced_conversions: true
579
+ });
580
+ console.log(`\u2705 GtagPixel ${pixelId} initialized`);
581
+ } catch (error) {
582
+ console.error(`Failed to initialize GtagPixel ${pixelId}:`, error);
583
+ }
584
+ }, "initializeGtag");
585
+ useEffect(() => {
586
+ if (!cookieConsentEnabled || typeof window === "undefined") return;
587
+ if (typeof window.gtag !== "undefined" || typeof window.dataLayer !== "undefined") {
588
+ console.log("\u2705 Gtag already available");
589
+ pixelIdsArray.forEach((pixelId) => initializeGtag(pixelId));
590
+ onLoadRef.current?.();
591
+ return;
592
+ }
593
+ const checkScriptLoaded = setInterval(() => {
594
+ if (typeof window.gtag !== "undefined" || typeof window.dataLayer !== "undefined") {
595
+ console.log("\u2705 Gtag became available!");
596
+ clearInterval(checkScriptLoaded);
597
+ pixelIdsArray.forEach((pixelId) => initializeGtag(pixelId));
598
+ onLoadRef.current?.();
599
+ }
600
+ }, 100);
601
+ const timeout = setTimeout(() => {
602
+ clearInterval(checkScriptLoaded);
603
+ console.warn("\u26A0\uFE0F Timeout waiting for gtag");
604
+ }, 5e3);
605
+ return () => {
606
+ clearInterval(checkScriptLoaded);
607
+ clearTimeout(timeout);
608
+ };
609
+ }, [cookieConsentEnabled, pixelIdsArray]);
610
+ return /* @__PURE__ */ jsx(Fragment, { children: pixelIdsArray.length > 0 && pixelIdsArray.map((pixelId, index) => /* @__PURE__ */ jsx(
611
+ Script,
612
+ {
613
+ id: `GtagPixel_${pixelId}_${index}`,
614
+ type: cookieConsentEnabled ? "text/plain" : "text/javascript",
615
+ "data-category": "targeting",
616
+ strategy,
617
+ src: `https://www.googletagmanager.com/gtag/js?id=${pixelId}`,
618
+ onLoad: () => {
619
+ console.log(`\u2705 GtagPixel ${pixelId} loaded from network`);
620
+ initializeGtag(pixelId);
621
+ },
622
+ onError: () => {
623
+ console.error(`\u274C GtagPixel ${pixelId} script load error`);
624
+ },
625
+ ...scriptProps
626
+ },
627
+ pixelId
628
+ )) });
629
+ }, "GtagPixel");
630
+ var GtagPixel_default = GtagPixel;
631
+
632
+ // src/pixels/MetaPixel.tsx
633
+ import { useEffect as useEffect2, useRef as useRef2, useMemo as useMemo2 } from "react";
634
+ import Script2 from "next/script";
635
+ import { Fragment as Fragment2, jsx as jsx2, jsxs } from "react/jsx-runtime";
636
+ var MetaPixel = /* @__PURE__ */ __name((props) => {
637
+ const {
638
+ cookieConsentEnabled,
639
+ pixelIds,
640
+ strategy,
641
+ onPixelLoaded,
642
+ ...scriptProps
643
+ } = props;
644
+ const pixelIdsKey = useMemo2(() => JSON.stringify(pixelIds), [pixelIds]);
645
+ const pixelIdsArray = useMemo2(
646
+ () => Array.isArray(pixelIds) ? pixelIds : [pixelIds],
647
+ [pixelIdsKey]
648
+ );
649
+ const onLoadRef = useRef2(onPixelLoaded);
650
+ useEffect2(() => {
651
+ onLoadRef.current = onPixelLoaded;
652
+ }, [onPixelLoaded]);
653
+ useEffect2(() => {
654
+ if (!cookieConsentEnabled || typeof window === "undefined") return;
655
+ if (typeof window.fbq !== "undefined") {
656
+ console.log("\u2705 window.fbq already available");
657
+ onLoadRef.current?.();
658
+ return;
659
+ }
660
+ const checkScriptLoaded = setInterval(() => {
661
+ if (typeof window.fbq !== "undefined") {
662
+ console.log("\u2705 window.fbq became available!");
663
+ clearInterval(checkScriptLoaded);
664
+ onLoadRef.current?.();
665
+ }
666
+ }, 100);
667
+ const timeout = setTimeout(() => {
668
+ clearInterval(checkScriptLoaded);
669
+ console.warn("\u26A0\uFE0F Timeout waiting for window.fbq");
670
+ }, 5e3);
671
+ return () => {
672
+ clearInterval(checkScriptLoaded);
673
+ clearTimeout(timeout);
674
+ };
675
+ }, [cookieConsentEnabled]);
676
+ return /* @__PURE__ */ jsx2(Fragment2, { children: pixelIdsArray?.length > 0 && // 添加 cookieConsentEnabled 条件
677
+ /* @__PURE__ */ jsxs(Fragment2, { children: [
678
+ /* @__PURE__ */ jsx2(
679
+ Script2,
680
+ {
681
+ id: "MetaPixel",
682
+ strategy,
683
+ type: cookieConsentEnabled ? "text/plain" : "text/javascript",
684
+ "data-category": "targeting",
685
+ src: `https://connect.facebook.net/en_US/fbevents.js`,
686
+ onLoad: () => {
687
+ console.log("\u2705 MetaPixel main script loaded from network");
688
+ },
689
+ onError: () => {
690
+ console.error("\u274C MetaPixel main script load error");
691
+ }
692
+ },
693
+ "MetaPixel"
694
+ ),
695
+ pixelIdsArray.map((pixelId, index) => /* @__PURE__ */ jsx2(
696
+ Script2,
697
+ {
698
+ id: `MetaPixel_${pixelId}_${index}`,
699
+ strategy,
700
+ type: "text/javascript",
701
+ dangerouslySetInnerHTML: {
702
+ __html: `
703
+ !function(f,b,n)
704
+ {if(f.fbq)return;n=f.fbq=function(){n.callMethod?
705
+ n.callMethod.apply(n,arguments):n.queue.push(arguments)};
706
+ if(!f._fbq)f._fbq=n;n.push=n;n.loaded=!0;n.version='2.0';
707
+ n.queue=[];}(window, document);
708
+ fbq('init', '${pixelId}');
709
+ fbq('track', 'PageView');
710
+ `
711
+ },
712
+ onError: () => {
713
+ console.error(`\u274C MetaPixel ${pixelId} script error`);
714
+ },
715
+ ...scriptProps
716
+ },
717
+ pixelId
718
+ ))
719
+ ] }) });
720
+ }, "MetaPixel");
721
+ var MetaPixel_default = MetaPixel;
722
+
723
+ // src/pixels/PixelsManager.tsx
724
+ import { jsx as jsx3 } from "react/jsx-runtime";
725
+ var PIXEL_COMPONENTS = {
726
+ gtag: GtagPixel_default,
727
+ meta: MetaPixel_default
728
+ };
729
+ var PixelsManager = /* @__PURE__ */ __name((config) => {
730
+ const { type, ...pixelProps } = config;
731
+ const PixelComponent = PIXEL_COMPONENTS[type];
732
+ if (!PixelComponent) {
733
+ return null;
734
+ }
735
+ return /* @__PURE__ */ jsx3(PixelComponent, { ...pixelProps });
736
+ }, "PixelsManager");
737
+ var PixelsManager_default = PixelsManager;
738
+
739
+ // src/index.ts
740
+ var index_default = {
741
+ track,
742
+ trackByTags,
743
+ withTracking,
744
+ useTracking,
745
+ logger,
746
+ isPlatformAvailable,
747
+ updateScriptType,
748
+ updateScriptsType
749
+ };
750
+ export {
751
+ GtagPixel_default as GtagPixel,
752
+ MetaPixel_default as MetaPixel,
753
+ PixelsManager_default as PixelsManager,
754
+ TrackTagsVersionMap,
755
+ clearTrackTags,
756
+ index_default as default,
757
+ gtagTrack,
758
+ hasTrackPoint,
759
+ isPlatformAvailable,
760
+ logger,
761
+ metaTrack,
762
+ setTrackTags,
763
+ track,
764
+ trackByTags,
765
+ triggerTrack,
766
+ triggerTrackBatch,
767
+ updateScriptType,
768
+ updateScriptsType,
769
+ useTracking,
770
+ withTracking
771
+ };
772
+ //# sourceMappingURL=index.js.map