@whnz/frontend-experience-core 1.0.1 → 1.0.3

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.js CHANGED
@@ -31,7 +31,13 @@ function shouldSample() {
31
31
  // src/reporter.ts
32
32
  var reporterFn = null;
33
33
  function initReporter(fn) {
34
- reporterFn = fn;
34
+ if (typeof fn === "string") {
35
+ reporterFn = (event) => {
36
+ navigator.sendBeacon(fn, JSON.stringify(event));
37
+ };
38
+ } else {
39
+ reporterFn = fn;
40
+ }
35
41
  }
36
42
  function report(event) {
37
43
  if (!reporterFn) return;
@@ -42,10 +48,32 @@ function report(event) {
42
48
  timestamp: event.timestamp || Date.now()
43
49
  };
44
50
  try {
45
- reporterFn(payload);
51
+ enqueue(payload);
46
52
  } catch (e) {
47
53
  }
48
54
  }
55
+ var queue = [];
56
+ var flushing = false;
57
+ function enqueue(payload) {
58
+ queue.push(payload);
59
+ scheduleFlush();
60
+ }
61
+ function scheduleFlush() {
62
+ if (flushing) return;
63
+ flushing = true;
64
+ requestIdleCallback(
65
+ () => {
66
+ flush();
67
+ flushing = false;
68
+ },
69
+ { timeout: 2e3 }
70
+ );
71
+ }
72
+ function flush() {
73
+ if (!queue.length) return;
74
+ const batch = queue.splice(0, 20);
75
+ reporterFn == null ? void 0 : reporterFn(batch.length === 1 ? batch[0] : batch);
76
+ }
49
77
 
50
78
  // src/init.ts
51
79
  var inited = false;
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/context.ts","../src/sampler.ts","../src/reporter.ts","../src/init.ts"],"names":[],"mappings":";AACA,IAAM,OAAA,GAA6B;AAAA,EACjC,GAAA,EAAK,EAAA;AAAA,EACL,OAAA,EAAS,EAAA;AAAA,EACT,GAAA,EAAK,MAAA;AAAA,EACL,KAAA,EAAO;AACT,CAAA;AACO,SAAS,YAAY,OAAA,EAAqC;AAC/D,EAAA,MAAA,CAAO,MAAA,CAAO,SAAS,OAAO,CAAA;AAChC;AACO,SAAS,SAAS,KAAA,EAAe;AACtC,EAAA,OAAA,CAAQ,KAAA,GAAQ,KAAA;AAClB;AACO,SAAS,UAAU,MAAA,EAAgB;AACxC,EAAA,OAAA,CAAQ,MAAA,GAAS,MAAA;AACnB;AACO,SAAS,UAAA,GAAgC;AAC9C,EAAA,OAAO,EAAE,GAAG,OAAA,EAAQ;AACtB;;;AClBA,IAAI,UAAA,GAAa,CAAA;AACV,SAAS,WAAA,CAAY,OAAO,CAAA,EAAG;AACpC,EAAA,UAAA,GAAa,IAAA;AACf;AACO,SAAS,YAAA,GAAwB;AACtC,EAAA,IAAI,UAAA,IAAc,GAAG,OAAO,IAAA;AAC5B,EAAA,OAAO,IAAA,CAAK,QAAO,GAAI,UAAA;AACzB;;;ACJA,IAAI,UAAA,GAA4C,IAAA;AACzC,SAAS,aAAa,EAAA,EAA0B;AACrD,EAAA,UAAA,GAAa,EAAA;AACf;AACO,SAAS,OAAO,KAAA,EAAwB;AAC7C,EAAA,IAAI,CAAC,UAAA,EAAY;AACjB,EAAA,IAAI,CAAC,cAAa,EAAG;AACrB,EAAA,MAAM,OAAA,GAAU;AAAA,IACd,GAAG,KAAA;AAAA,IACH,GAAG,UAAA,EAAW;AAAA,IACd,SAAA,EAAW,KAAA,CAAM,SAAA,IAAa,IAAA,CAAK,GAAA;AAAI,GACzC;AACA,EAAA,IAAI;AACF,IAAA,UAAA,CAAW,OAAO,CAAA;AAAA,EACpB,SAAS,CAAA,EAAG;AAAA,EAEZ;AACF;;;AChBA,IAAI,MAAA,GAAS,KAAA;AACN,SAAS,SAAS,OAAA,EAA0B;AALnD,EAAA,IAAA,EAAA;AAME,EAAA,IAAI,MAAA,EAAQ;AACZ,EAAA,MAAA,GAAS,IAAA;AACT,EAAA,WAAA,CAAY;AAAA,IACV,KAAK,OAAA,CAAQ,GAAA;AAAA,IACb,SAAS,OAAA,CAAQ,OAAA;AAAA,IACjB,KAAK,OAAA,CAAQ,GAAA;AAAA,IACb,OAAO,QAAA,CAAS;AAAA,GACjB,CAAA;AACD,EAAA,YAAA,CAAa,QAAQ,QAAQ,CAAA;AAC7B,EAAA,WAAA,CAAA,CAAY,EAAA,GAAA,OAAA,CAAQ,UAAA,KAAR,IAAA,GAAA,EAAA,GAAsB,CAAC,CAAA;AACrC","file":"index.js","sourcesContent":["import { ExperienceContext } from './types';\nconst context: ExperienceContext = {\n app: '',\n version: '',\n env: 'prod',\n route: '/',\n};\nexport function initContext(partial: Partial<ExperienceContext>) {\n Object.assign(context, partial);\n}\nexport function setRoute(route: string) {\n context.route = route;\n}\nexport function setUserId(userId: string) {\n context.userId = userId;\n}\nexport function getContext(): ExperienceContext {\n return { ...context };\n}\n","let sampleRate = 1;\nexport function initSampler(rate = 1) {\n sampleRate = rate;\n}\nexport function shouldSample(): boolean {\n if (sampleRate >= 1) return true;\n return Math.random() < sampleRate;\n}\n","import { ExperienceEvent } from './types';\nimport { getContext } from './context';\nimport { shouldSample } from './sampler';\nlet reporterFn: ((event: any) => void) | null = null;\nexport function initReporter(fn: (event: any) => void) {\n reporterFn = fn;\n}\nexport function report(event: ExperienceEvent) {\n if (!reporterFn) return;\n if (!shouldSample()) return;\n const payload = {\n ...event,\n ...getContext(),\n timestamp: event.timestamp || Date.now(),\n };\n try {\n reporterFn(payload);\n } catch (e) {\n // core 永远不能抛异常\n }\n}\n","import { InitCoreOptions } from './types';\nimport { initContext } from './context';\nimport { initReporter } from './reporter';\nimport { initSampler } from './sampler';\nlet inited = false;\nexport function initCore(options: InitCoreOptions) {\n if (inited) return;\n inited = true;\n initContext({\n app: options.app,\n version: options.version,\n env: options.env,\n route: location.pathname,\n });\n initReporter(options.reporter);\n initSampler(options.sampleRate ?? 1);\n}\n"]}
1
+ {"version":3,"sources":["../src/context.ts","../src/sampler.ts","../src/reporter.ts","../src/init.ts"],"names":[],"mappings":"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","file":"index.js","sourcesContent":["import { ExperienceContext } from './types';\nconst context: ExperienceContext = {\n app: '',\n version: '',\n env: 'prod',\n route: '/',\n};\nexport function initContext(partial: Partial<ExperienceContext>) {\n Object.assign(context, partial);\n}\nexport function setRoute(route: string) {\n context.route = route;\n}\nexport function setUserId(userId: string) {\n context.userId = userId;\n}\nexport function getContext(): ExperienceContext {\n return { ...context };\n}\n","let sampleRate = 1;\nexport function initSampler(rate = 1) {\n sampleRate = rate;\n}\nexport function shouldSample(): boolean {\n if (sampleRate >= 1) return true;\n return Math.random() < sampleRate;\n}\n","import { ExperienceEvent } from './types';\nimport { getContext } from './context';\nimport { shouldSample } from './sampler';\nlet reporterFn: ((event: any) => void) | null = null;\nexport function initReporter(fn: string | ((event: any) => void)) {\n if (typeof fn === 'string') {\n reporterFn = (event) => {\n navigator.sendBeacon(fn, JSON.stringify(event));\n };\n } else {\n reporterFn = fn;\n }\n}\nexport function report(event: ExperienceEvent) {\n if (!reporterFn) return;\n if (!shouldSample()) return;\n const payload = {\n ...event,\n ...getContext(),\n timestamp: event.timestamp || Date.now(),\n };\n try {\n enqueue(payload);\n } catch (e) {\n // core 永远不能抛异常\n }\n}\nconst queue: any[] = [];\nlet flushing = false;\n\nfunction enqueue(payload: any) {\n queue.push(payload);\n scheduleFlush();\n}\n\nfunction scheduleFlush() {\n if (flushing) return;\n flushing = true;\n\n requestIdleCallback(\n () => {\n flush();\n flushing = false;\n },\n { timeout: 2000 },\n );\n}\n\nfunction flush() {\n if (!queue.length) return;\n const batch = queue.splice(0, 20);\n reporterFn?.(batch.length === 1 ? batch[0] : batch);\n}\n","import { InitCoreOptions } from './types';\nimport { initContext } from './context';\nimport { initReporter } from './reporter';\nimport { initSampler } from './sampler';\n\nlet inited = false;\nexport function initCore(options: InitCoreOptions) {\n if (inited) return;\n inited = true;\n initContext({\n app: options.app,\n version: options.version,\n env: options.env,\n route: location.pathname,\n });\n initReporter(options.reporter);\n initSampler(options.sampleRate ?? 1);\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@whnz/frontend-experience-core",
3
- "version": "1.0.1",
3
+ "version": "1.0.3",
4
4
  "main": "dist/index.js",
5
5
  "type": "module",
6
6
  "types": "dist/index.d.ts",