@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.
- package/dist/index.cjs +827 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.mts +489 -0
- package/dist/index.d.ts +474 -21
- package/dist/index.js +771 -33
- package/dist/index.js.map +1 -0
- package/package.json +23 -36
- package/dist/autoTrack/click.d.ts +0 -2
- package/dist/autoTrack/click.d.ts.map +0 -1
- package/dist/autoTrack/click.js +0 -80
- package/dist/autoTrack/index.d.ts +0 -2
- package/dist/autoTrack/index.d.ts.map +0 -1
- package/dist/autoTrack/index.js +0 -47
- package/dist/autoTrack/pv.d.ts +0 -2
- package/dist/autoTrack/pv.d.ts.map +0 -1
- package/dist/autoTrack/pv.js +0 -57
- package/dist/autoTrack/trackByTags.d.ts +0 -17
- package/dist/autoTrack/trackByTags.d.ts.map +0 -1
- package/dist/autoTrack/trackByTags.js +0 -141
- package/dist/constants/index.d.ts +0 -2
- package/dist/constants/index.d.ts.map +0 -1
- package/dist/constants/index.js +0 -1
- package/dist/constants/tagsMap.d.ts +0 -9
- package/dist/constants/tagsMap.d.ts.map +0 -1
- package/dist/constants/tagsMap.js +0 -8
- package/dist/core/adapters/gtag.d.ts +0 -37
- package/dist/core/adapters/gtag.d.ts.map +0 -1
- package/dist/core/adapters/gtag.js +0 -55
- package/dist/core/adapters/index.d.ts +0 -6
- package/dist/core/adapters/index.d.ts.map +0 -1
- package/dist/core/adapters/index.js +0 -5
- package/dist/core/adapters/meta.d.ts +0 -20
- package/dist/core/adapters/meta.d.ts.map +0 -1
- package/dist/core/adapters/meta.js +0 -41
- package/dist/core/helpers/function-utils.d.ts +0 -17
- package/dist/core/helpers/function-utils.d.ts.map +0 -1
- package/dist/core/helpers/function-utils.js +0 -43
- package/dist/core/helpers/index.d.ts +0 -8
- package/dist/core/helpers/index.d.ts.map +0 -1
- package/dist/core/helpers/index.js +0 -7
- package/dist/core/helpers/logger.d.ts +0 -20
- package/dist/core/helpers/logger.d.ts.map +0 -1
- package/dist/core/helpers/logger.js +0 -32
- package/dist/core/helpers/platform-detector.d.ts +0 -14
- package/dist/core/helpers/platform-detector.d.ts.map +0 -1
- package/dist/core/helpers/platform-detector.js +0 -28
- package/dist/core/helpers/script-loader.d.ts +0 -39
- package/dist/core/helpers/script-loader.d.ts.map +0 -1
- package/dist/core/helpers/script-loader.js +0 -107
- package/dist/core/index.d.ts +0 -7
- package/dist/core/index.d.ts.map +0 -1
- package/dist/core/index.js +0 -9
- package/dist/core/track/gtagTrack.d.ts +0 -2
- package/dist/core/track/gtagTrack.d.ts.map +0 -1
- package/dist/core/track/gtagTrack.js +0 -12
- package/dist/core/track/index.d.ts +0 -4
- package/dist/core/track/index.d.ts.map +0 -1
- package/dist/core/track/index.js +0 -3
- package/dist/core/track/metaTrack.d.ts +0 -2
- package/dist/core/track/metaTrack.d.ts.map +0 -1
- package/dist/core/track/metaTrack.js +0 -18
- package/dist/core/track/track.d.ts +0 -6
- package/dist/core/track/track.d.ts.map +0 -1
- package/dist/core/track/track.js +0 -128
- package/dist/core/tracking/dispatcher.d.ts +0 -10
- package/dist/core/tracking/dispatcher.d.ts.map +0 -1
- package/dist/core/tracking/dispatcher.js +0 -67
- package/dist/core/tracking/index.d.ts +0 -6
- package/dist/core/tracking/index.d.ts.map +0 -1
- package/dist/core/tracking/index.js +0 -5
- package/dist/core/tracking/with-tracking.d.ts +0 -33
- package/dist/core/tracking/with-tracking.d.ts.map +0 -1
- package/dist/core/tracking/with-tracking.js +0 -137
- package/dist/core/utils.d.ts +0 -64
- package/dist/core/utils.d.ts.map +0 -1
- package/dist/core/utils.js +0 -182
- package/dist/index.d.ts.map +0 -1
- package/dist/pixels/GtagPixel.d.ts +0 -7
- package/dist/pixels/GtagPixel.d.ts.map +0 -1
- package/dist/pixels/GtagPixel.js +0 -73
- package/dist/pixels/MetaPixel.d.ts +0 -7
- package/dist/pixels/MetaPixel.d.ts.map +0 -1
- package/dist/pixels/MetaPixel.js +0 -61
- package/dist/pixels/PixelsManager.d.ts +0 -5
- package/dist/pixels/PixelsManager.d.ts.map +0 -1
- package/dist/pixels/PixelsManager.js +0 -17
- package/dist/pixels/index.d.ts +0 -4
- package/dist/pixels/index.d.ts.map +0 -1
- package/dist/pixels/index.js +0 -3
- package/dist/types/common.d.ts +0 -66
- package/dist/types/common.d.ts.map +0 -1
- package/dist/types/common.js +0 -1
- package/dist/types/gtag.d.ts +0 -34
- package/dist/types/gtag.d.ts.map +0 -1
- package/dist/types/gtag.js +0 -1
- package/dist/types/index.d.ts +0 -91
- package/dist/types/index.d.ts.map +0 -1
- package/dist/types/index.js +0 -1
- package/dist/types/meta.d.ts +0 -8
- package/dist/types/meta.d.ts.map +0 -1
- package/dist/types/meta.js +0 -4
- package/dist/types/trackByTags.d.ts +0 -26
- package/dist/types/trackByTags.d.ts.map +0 -1
- package/dist/types/trackByTags.js +0 -4
package/dist/index.js
CHANGED
|
@@ -1,34 +1,772 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
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
|