@openreplay/tracker 16.0.2-beta.1 → 16.0.3-beta-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 (39) hide show
  1. package/dist/cjs/common/interaction.d.ts +2 -2
  2. package/dist/cjs/common/messages.gen.d.ts +1 -44
  3. package/dist/cjs/entry.js +9828 -0
  4. package/dist/cjs/entry.js.map +1 -0
  5. package/dist/cjs/index.js +88 -116
  6. package/dist/cjs/index.js.map +1 -1
  7. package/dist/cjs/main/app/index.d.ts +0 -5
  8. package/dist/cjs/main/app/messages.gen.d.ts +0 -5
  9. package/dist/cjs/main/app/observer/observer.d.ts +5 -1
  10. package/dist/cjs/main/app/observer/top_observer.d.ts +1 -0
  11. package/dist/cjs/main/app/ticker.d.ts +0 -4
  12. package/dist/cjs/main/entry.d.ts +5 -0
  13. package/dist/cjs/main/index.d.ts +3 -3
  14. package/dist/cjs/main/singleton.d.ts +108 -0
  15. package/dist/lib/common/interaction.d.ts +2 -2
  16. package/dist/lib/common/messages.gen.d.ts +1 -44
  17. package/dist/lib/entry.js +9821 -0
  18. package/dist/lib/entry.js.map +1 -0
  19. package/dist/lib/index.js +88 -116
  20. package/dist/lib/index.js.map +1 -1
  21. package/dist/lib/main/app/index.d.ts +0 -5
  22. package/dist/lib/main/app/messages.gen.d.ts +0 -5
  23. package/dist/lib/main/app/observer/observer.d.ts +5 -1
  24. package/dist/lib/main/app/observer/top_observer.d.ts +1 -0
  25. package/dist/lib/main/app/ticker.d.ts +0 -4
  26. package/dist/lib/main/entry.d.ts +5 -0
  27. package/dist/lib/main/index.d.ts +3 -3
  28. package/dist/lib/main/singleton.d.ts +108 -0
  29. package/dist/types/common/interaction.d.ts +2 -2
  30. package/dist/types/common/messages.gen.d.ts +1 -44
  31. package/dist/types/main/app/index.d.ts +0 -5
  32. package/dist/types/main/app/messages.gen.d.ts +0 -5
  33. package/dist/types/main/app/observer/observer.d.ts +5 -1
  34. package/dist/types/main/app/observer/top_observer.d.ts +1 -0
  35. package/dist/types/main/app/ticker.d.ts +0 -4
  36. package/dist/types/main/entry.d.ts +5 -0
  37. package/dist/types/main/index.d.ts +3 -3
  38. package/dist/types/main/singleton.d.ts +108 -0
  39. package/package.json +11 -6
package/dist/lib/index.js CHANGED
@@ -721,7 +721,9 @@ class StringDictionary {
721
721
  this.backDict = {};
722
722
  this.getKey = (str) => {
723
723
  let isNew = false;
724
- if (!this.backDict[str]) {
724
+ // avoiding potential native object properties
725
+ const safeKey = `__${str}`;
726
+ if (!this.backDict[safeKey]) {
725
727
  isNew = true;
726
728
  // shaving the first 2 digits of the timestamp (since they are irrelevant for next millennia)
727
729
  const shavedTs = Date.now() % 10 ** (13 - 2);
@@ -733,10 +735,10 @@ class StringDictionary {
733
735
  else {
734
736
  this.lastSuffix = 1;
735
737
  }
736
- this.backDict[str] = id;
738
+ this.backDict[safeKey] = id;
737
739
  this.lastTs = shavedTs;
738
740
  }
739
- return [this.backDict[str], isNew];
741
+ return [this.backDict[safeKey], isNew];
740
742
  };
741
743
  }
742
744
  }
@@ -1673,33 +1675,6 @@ function SetNodeAttributeDictGlobal(id, name, value) {
1673
1675
  value,
1674
1676
  ];
1675
1677
  }
1676
- function CSSInsertRule(id, rule, index) {
1677
- return [
1678
- 37 /* Messages.Type.CSSInsertRule */,
1679
- id,
1680
- rule,
1681
- index,
1682
- ];
1683
- }
1684
- function CSSDeleteRule(id, index) {
1685
- return [
1686
- 38 /* Messages.Type.CSSDeleteRule */,
1687
- id,
1688
- index,
1689
- ];
1690
- }
1691
- function Fetch(method, url, request, response, status, timestamp, duration) {
1692
- return [
1693
- 39 /* Messages.Type.Fetch */,
1694
- method,
1695
- url,
1696
- request,
1697
- response,
1698
- status,
1699
- timestamp,
1700
- duration,
1701
- ];
1702
- }
1703
1678
  function Profiler(name, duration, args, result) {
1704
1679
  return [
1705
1680
  40 /* Messages.Type.Profiler */,
@@ -1842,18 +1817,6 @@ function SetNodeFocus(id) {
1842
1817
  id,
1843
1818
  ];
1844
1819
  }
1845
- function LongTask(timestamp, duration, context, containerType, containerSrc, containerId, containerName) {
1846
- return [
1847
- 59 /* Messages.Type.LongTask */,
1848
- timestamp,
1849
- duration,
1850
- context,
1851
- containerType,
1852
- containerSrc,
1853
- containerId,
1854
- containerName,
1855
- ];
1856
- }
1857
1820
  function SetNodeAttributeURLBased(id, name, value, baseURL) {
1858
1821
  return [
1859
1822
  60 /* Messages.Type.SetNodeAttributeURLBased */,
@@ -1885,15 +1848,6 @@ function CustomIssue(name, payload) {
1885
1848
  payload,
1886
1849
  ];
1887
1850
  }
1888
- function CSSInsertRuleURLBased(id, rule, index, baseURL) {
1889
- return [
1890
- 67 /* Messages.Type.CSSInsertRuleURLBased */,
1891
- id,
1892
- rule,
1893
- index,
1894
- baseURL,
1895
- ];
1896
- }
1897
1851
  function MouseClick(id, hesitationTime, label, selector, normalizedX, normalizedY) {
1898
1852
  return [
1899
1853
  68 /* Messages.Type.MouseClick */,
@@ -2132,9 +2086,6 @@ var _Messages = /*#__PURE__*/Object.freeze({
2132
2086
  AdoptedSSRemoveOwner: AdoptedSSRemoveOwner,
2133
2087
  AdoptedSSReplaceURLBased: AdoptedSSReplaceURLBased,
2134
2088
  BatchMetadata: BatchMetadata,
2135
- CSSDeleteRule: CSSDeleteRule,
2136
- CSSInsertRule: CSSInsertRule,
2137
- CSSInsertRuleURLBased: CSSInsertRuleURLBased,
2138
2089
  CanvasNode: CanvasNode,
2139
2090
  ConnectionInformation: ConnectionInformation,
2140
2091
  ConsoleLog: ConsoleLog,
@@ -2144,13 +2095,11 @@ var _Messages = /*#__PURE__*/Object.freeze({
2144
2095
  CreateTextNode: CreateTextNode,
2145
2096
  CustomEvent: CustomEvent,
2146
2097
  CustomIssue: CustomIssue,
2147
- Fetch: Fetch,
2148
2098
  GraphQL: GraphQL,
2149
2099
  GraphQLDeprecated: GraphQLDeprecated,
2150
2100
  InputChange: InputChange,
2151
2101
  JSException: JSException,
2152
2102
  LoadFontFace: LoadFontFace,
2153
- LongTask: LongTask,
2154
2103
  Metadata: Metadata,
2155
2104
  MobX: MobX,
2156
2105
  MouseClick: MouseClick,
@@ -2588,9 +2537,7 @@ const spinnerStyles = {
2588
2537
  };
2589
2538
 
2590
2539
  const Quality = {
2591
- Standard: { width: 1280, height: 720 },
2592
- High: { width: 1920, height: 1080 },
2593
- };
2540
+ Standard: { width: 1280, height: 720 }};
2594
2541
  class Recorder {
2595
2542
  constructor(app) {
2596
2543
  this.app = app;
@@ -3752,29 +3699,76 @@ class Nodes {
3752
3699
  }
3753
3700
 
3754
3701
  const iconCache = {};
3755
- const domParser = new DOMParser();
3756
- async function parseUseEl(useElement, mode) {
3702
+ const svgUrlCache = {};
3703
+ async function parseUseEl(useElement, mode, domParser) {
3757
3704
  try {
3758
3705
  const href = useElement.getAttribute('xlink:href') || useElement.getAttribute('href');
3759
3706
  if (!href) {
3760
3707
  console.debug('Openreplay: xlink:href or href not found on <use>.');
3761
3708
  return;
3762
3709
  }
3763
- const [url, symbolId] = href.split('#');
3764
- if (!url || !symbolId) {
3765
- console.debug('Openreplay: Invalid xlink:href or href found on <use>.');
3710
+ let [url, symbolId] = href.split('#');
3711
+ // happens if svg spritemap is local, fastest case for us
3712
+ if (!url && symbolId) {
3713
+ const symbol = document.querySelector(href);
3714
+ if (symbol) {
3715
+ const inlineSvg = `
3716
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="${symbol.getAttribute('viewBox') || '0 0 24 24'}">
3717
+ ${symbol.innerHTML}
3718
+ </svg>
3719
+ `.trim();
3720
+ iconCache[symbolId] = inlineSvg;
3721
+ return inlineSvg;
3722
+ }
3723
+ else {
3724
+ console.warn('Openreplay: Sprite symbol not found in the document.');
3725
+ return;
3726
+ }
3727
+ }
3728
+ if (!url && !symbolId) {
3729
+ console.warn('Openreplay: Invalid xlink:href or href found on <use>.');
3766
3730
  return;
3767
3731
  }
3768
3732
  if (iconCache[symbolId]) {
3769
3733
  return iconCache[symbolId];
3770
3734
  }
3771
- const response = await fetch(url);
3772
- const svgText = await response.text();
3773
- const svgDoc = domParser.parseFromString(svgText, 'image/svg+xml');
3735
+ let svgDoc;
3736
+ if (svgUrlCache[url]) {
3737
+ if (svgUrlCache[url] === 1) {
3738
+ await new Promise((resolve) => {
3739
+ let tries = 0;
3740
+ const interval = setInterval(() => {
3741
+ if (tries > 100) {
3742
+ clearInterval(interval);
3743
+ resolve(false);
3744
+ }
3745
+ if (svgUrlCache[url] !== 1) {
3746
+ svgDoc = svgUrlCache[url];
3747
+ clearInterval(interval);
3748
+ resolve(true);
3749
+ }
3750
+ else {
3751
+ tries++;
3752
+ }
3753
+ }, 100);
3754
+ });
3755
+ }
3756
+ else {
3757
+ svgDoc = svgUrlCache[url] ?? `<svg xmlns="http://www.w3.org/2000/svg"></svg>`;
3758
+ }
3759
+ }
3760
+ else {
3761
+ svgUrlCache[url] = 1;
3762
+ const response = await fetch(url);
3763
+ const svgText = await response.text();
3764
+ svgDoc = domParser.parseFromString(svgText, 'image/svg+xml');
3765
+ svgUrlCache[url] = svgDoc;
3766
+ }
3767
+ // @ts-ignore
3774
3768
  const symbol = svgDoc.getElementById(symbolId);
3775
3769
  if (!symbol) {
3776
3770
  console.debug('Openreplay: Symbol not found in SVG.');
3777
- return;
3771
+ return '';
3778
3772
  }
3779
3773
  if (mode === 'inline') ;
3780
3774
  if (mode === 'svgtext') {
@@ -3829,7 +3823,7 @@ var RecentsType;
3829
3823
  RecentsType[RecentsType["Changed"] = 2] = "Changed";
3830
3824
  })(RecentsType || (RecentsType = {}));
3831
3825
  class Observer {
3832
- constructor(app, isTopContext = false) {
3826
+ constructor(app, isTopContext = false, options = { disableSprites: false }) {
3833
3827
  this.app = app;
3834
3828
  this.isTopContext = isTopContext;
3835
3829
  this.commited = [];
@@ -3837,6 +3831,9 @@ class Observer {
3837
3831
  this.indexes = [];
3838
3832
  this.attributesMap = new Map();
3839
3833
  this.textSet = new Set();
3834
+ this.disableSprites = false;
3835
+ this.domParser = new DOMParser();
3836
+ this.disableSprites = options.disableSprites;
3840
3837
  this.observer = createMutationObserver(this.app.safe((mutations) => {
3841
3838
  for (const mutation of mutations) {
3842
3839
  // mutations order is sequential
@@ -3931,8 +3928,8 @@ class Observer {
3931
3928
  if (value === null) {
3932
3929
  this.app.send(RemoveNodeAttribute(id, name));
3933
3930
  }
3934
- if (isUseElement(node) && name === 'href') {
3935
- parseUseEl(node, 'svgtext')
3931
+ if (isUseElement(node) && name === 'href' && !this.disableSprites) {
3932
+ parseUseEl(node, 'svgtext', this.domParser)
3936
3933
  .then((svgData) => {
3937
3934
  if (svgData) {
3938
3935
  this.app.send(SetNodeAttribute(id, name, `_$OPENREPLAY_SPRITE$_${svgData}`));
@@ -4285,7 +4282,11 @@ class IFrameOffsets {
4285
4282
  const attachShadowNativeFn = IN_BROWSER ? Element.prototype.attachShadow : () => new ShadowRoot();
4286
4283
  class TopObserver extends Observer {
4287
4284
  constructor(params) {
4288
- super(params.app, true);
4285
+ const opts = Object.assign({
4286
+ captureIFrames: true,
4287
+ disableSprites: false,
4288
+ }, params.options);
4289
+ super(params.app, true, opts);
4289
4290
  this.iframeOffsets = new IFrameOffsets();
4290
4291
  this.contextCallbacks = [];
4291
4292
  // Attached once per Tracker instance
@@ -4295,9 +4296,7 @@ class TopObserver extends Observer {
4295
4296
  this.docObservers = new WeakMap();
4296
4297
  this.shadowRootObservers = new WeakMap();
4297
4298
  this.app = params.app;
4298
- this.options = Object.assign({
4299
- captureIFrames: true,
4300
- }, params.options);
4299
+ this.options = opts;
4301
4300
  // IFrames
4302
4301
  this.app.nodes.attachNodeCallback((node) => {
4303
4302
  if (hasTag(node, 'iframe') &&
@@ -4631,10 +4630,6 @@ function wrap(callback, n) {
4631
4630
  }
4632
4631
  };
4633
4632
  }
4634
- /**
4635
- * Takes a callback and n as number of turn skips
4636
- * Every tick is 30ms, so attach(cb, 3) will call cb every 90ms
4637
- * */
4638
4633
  class Ticker {
4639
4634
  constructor(app) {
4640
4635
  this.app = app;
@@ -4676,7 +4671,7 @@ class Ticker {
4676
4671
  * this value is injected during build time via rollup
4677
4672
  * */
4678
4673
  // @ts-ignore
4679
- const workerBodyFn = "!function(){\"use strict\";class t{constructor(t,s,i,e=10,n=250,h,r){this.onUnauthorised=s,this.onFailure=i,this.MAX_ATTEMPTS_COUNT=e,this.ATTEMPT_TIMEOUT=n,this.onCompress=h,this.pageNo=r,this.attemptsCount=0,this.busy=!1,this.queue=[],this.token=null,this.lastBatchNum=0,this.ingestURL=t+\"/v1/web/i\",this.isCompressing=void 0!==h}getQueueStatus(){return 0===this.queue.length&&!this.busy}authorise(t){this.token=t,this.busy||this.sendNext()}push(t){if(this.busy||!this.token)this.queue.push(t);else if(this.busy=!0,this.isCompressing&&this.onCompress)this.onCompress(t);else{const s=++this.lastBatchNum;this.sendBatch(t,!1,s)}}sendNext(){const t=this.queue.shift();if(t)if(this.busy=!0,this.isCompressing&&this.onCompress)this.onCompress(t);else{const s=++this.lastBatchNum;this.sendBatch(t,!1,s)}else this.busy=!1}retry(t,s,i){this.attemptsCount>=this.MAX_ATTEMPTS_COUNT?this.onFailure(`Failed to send batch after ${this.attemptsCount} attempts.`):(this.attemptsCount++,setTimeout((()=>this.sendBatch(t,s,i)),this.ATTEMPT_TIMEOUT*this.attemptsCount))}sendBatch(t,s,i){var e;const n=null==i?void 0:i.toString().replace(/^([^_]+)_([^_]+).*/,\"$1_$2_$3\");this.busy=!0;const h={Authorization:`Bearer ${this.token}`};if(s&&(h[\"Content-Encoding\"]=\"gzip\"),null===this.token)return void setTimeout((()=>{this.sendBatch(t,s,`${null!=i?i:\"noBatchNum\"}_newToken`)}),500);const r=new AbortController,a=setTimeout((()=>{r.abort()}),3e4);fetch(`${this.ingestURL}?batch=${null!==(e=this.pageNo)&&void 0!==e?e:\"noPageNum\"}_${null!=n?n:\"noBatchNum\"}`,{body:t,method:\"POST\",headers:h,keepalive:t.length<65536,signal:r.signal}).then((e=>{if(clearTimeout(a),401===e.status)return this.busy=!1,void this.onUnauthorised();e.status>=400?this.retry(t,s,`${null!=i?i:\"noBatchNum\"}_network:${e.status}`):(this.attemptsCount=0,this.sendNext())})).catch((e=>{clearTimeout(a),console.warn(\"OpenReplay:\",e),this.retry(t,s,`${null!=i?i:\"noBatchNum\"}_reject:${e.message}`)}))}sendCompressed(t){const s=++this.lastBatchNum;this.sendBatch(t,!0,s)}sendUncompressed(t){const s=++this.lastBatchNum;this.sendBatch(t,!1,s)}clean(){this.sendNext(),setTimeout((()=>{this.token=null,this.queue.length=0}),10)}}const s=\"function\"==typeof TextEncoder?new TextEncoder:{encode(t){const s=t.length,i=new Uint8Array(3*s);let e=-1;for(let n=0,h=0,r=0;r!==s;){if(n=t.charCodeAt(r),r+=1,n>=55296&&n<=56319){if(r===s){i[e+=1]=239,i[e+=1]=191,i[e+=1]=189;break}if(h=t.charCodeAt(r),!(h>=56320&&h<=57343)){i[e+=1]=239,i[e+=1]=191,i[e+=1]=189;continue}if(n=1024*(n-55296)+h-56320+65536,r+=1,n>65535){i[e+=1]=240|n>>>18,i[e+=1]=128|n>>>12&63,i[e+=1]=128|n>>>6&63,i[e+=1]=128|63&n;continue}}n<=127?i[e+=1]=0|n:n<=2047?(i[e+=1]=192|n>>>6,i[e+=1]=128|63&n):(i[e+=1]=224|n>>>12,i[e+=1]=128|n>>>6&63,i[e+=1]=128|63&n)}return i.subarray(0,e+1)}};class i{constructor(t){this.size=t,this.offset=0,this.checkpointOffset=0,this.data=new Uint8Array(t)}getCurrentOffset(){return this.offset}checkpoint(){this.checkpointOffset=this.offset}get isEmpty(){return 0===this.offset}skip(t){return this.offset+=t,this.offset<=this.size}set(t,s){this.data.set(t,s)}boolean(t){return this.data[this.offset++]=+t,this.offset<=this.size}uint(t){for((t<0||t>Number.MAX_SAFE_INTEGER)&&(t=0);t>=128;)this.data[this.offset++]=t%256|128,t=Math.floor(t/128);return this.data[this.offset++]=t,this.offset<=this.size}int(t){return t=Math.round(t),this.uint(t>=0?2*t:-2*t-1)}string(t){const i=s.encode(t),e=i.byteLength;return!(!this.uint(e)||this.offset+e>this.size)&&(this.data.set(i,this.offset),this.offset+=e,!0)}reset(){this.offset=0,this.checkpointOffset=0}flush(){const t=this.data.slice(0,this.checkpointOffset);return this.reset(),t}}class e extends i{encode(t){switch(t[0]){case 0:case 11:case 114:case 115:return this.uint(t[1]);case 4:case 44:case 47:return this.string(t[1])&&this.string(t[2])&&this.uint(t[3]);case 5:case 20:case 38:case 70:case 75:case 76:case 77:case 82:return this.uint(t[1])&&this.uint(t[2]);case 6:return this.int(t[1])&&this.int(t[2]);case 7:return!0;case 8:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3])&&this.string(t[4])&&this.boolean(t[5]);case 9:case 10:case 24:case 35:case 51:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3]);case 12:case 52:case 61:case 71:return this.uint(t[1])&&this.string(t[2])&&this.string(t[3]);case 13:case 14:case 17:case 34:case 50:case 54:return this.uint(t[1])&&this.string(t[2]);case 16:return this.uint(t[1])&&this.int(t[2])&&this.int(t[3]);case 18:return this.uint(t[1])&&this.string(t[2])&&this.int(t[3]);case 19:return this.uint(t[1])&&this.boolean(t[2]);case 21:return this.string(t[1])&&this.string(t[2])&&this.string(t[3])&&this.string(t[4])&&this.string(t[5])&&this.uint(t[6])&&this.uint(t[7])&&this.uint(t[8]);case 22:case 27:case 30:case 41:case 45:case 46:case 43:case 63:case 64:case 79:case 124:return this.string(t[1])&&this.string(t[2]);case 23:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3])&&this.uint(t[4])&&this.uint(t[5])&&this.uint(t[6])&&this.uint(t[7])&&this.uint(t[8])&&this.uint(t[9]);case 28:case 29:case 42:case 117:case 118:return this.string(t[1]);case 37:return this.uint(t[1])&&this.string(t[2])&&this.uint(t[3]);case 39:return this.string(t[1])&&this.string(t[2])&&this.string(t[3])&&this.string(t[4])&&this.uint(t[5])&&this.uint(t[6])&&this.uint(t[7]);case 40:return this.string(t[1])&&this.uint(t[2])&&this.string(t[3])&&this.string(t[4]);case 48:return this.string(t[1])&&this.string(t[2])&&this.string(t[3])&&this.string(t[4])&&this.int(t[5]);case 49:return this.int(t[1])&&this.int(t[2])&&this.uint(t[3])&&this.uint(t[4]);case 53:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3])&&this.uint(t[4])&&this.uint(t[5])&&this.uint(t[6])&&this.string(t[7])&&this.string(t[8]);case 55:return this.boolean(t[1]);case 57:case 60:return this.uint(t[1])&&this.string(t[2])&&this.string(t[3])&&this.string(t[4]);case 58:case 120:return this.int(t[1]);case 59:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3])&&this.uint(t[4])&&this.string(t[5])&&this.string(t[6])&&this.string(t[7]);case 67:case 73:return this.uint(t[1])&&this.string(t[2])&&this.uint(t[3])&&this.string(t[4]);case 68:return this.uint(t[1])&&this.uint(t[2])&&this.string(t[3])&&this.string(t[4])&&this.uint(t[5])&&this.uint(t[6]);case 69:return this.uint(t[1])&&this.uint(t[2])&&this.string(t[3])&&this.string(t[4]);case 78:return this.string(t[1])&&this.string(t[2])&&this.string(t[3])&&this.string(t[4]);case 81:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3])&&this.int(t[4])&&this.string(t[5]);case 83:return this.string(t[1])&&this.string(t[2])&&this.string(t[3])&&this.string(t[4])&&this.string(t[5])&&this.uint(t[6])&&this.uint(t[7])&&this.uint(t[8])&&this.uint(t[9]);case 84:return this.string(t[1])&&this.string(t[2])&&this.string(t[3])&&this.uint(t[4])&&this.string(t[5])&&this.string(t[6]);case 112:return this.uint(t[1])&&this.string(t[2])&&this.boolean(t[3])&&this.string(t[4])&&this.int(t[5])&&this.int(t[6]);case 113:return this.uint(t[1])&&this.uint(t[2])&&this.string(t[3]);case 116:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3])&&this.uint(t[4])&&this.uint(t[5])&&this.uint(t[6])&&this.string(t[7])&&this.string(t[8])&&this.uint(t[9])&&this.boolean(t[10]);case 119:return this.string(t[1])&&this.uint(t[2]);case 121:return this.string(t[1])&&this.string(t[2])&&this.uint(t[3])&&this.uint(t[4]);case 122:return this.string(t[1])&&this.string(t[2])&&this.uint(t[3])&&this.string(t[4]);case 123:return this.string(t[1])&&this.string(t[2])&&this.string(t[3])&&this.string(t[4])&&this.uint(t[5])}}}class n{constructor(t,s,i,n,h,r){this.pageNo=t,this.timestamp=s,this.url=i,this.onBatch=n,this.tabId=h,this.onOfflineEnd=r,this.nextIndex=0,this.beaconSize=2e5,this.encoder=new e(this.beaconSize),this.sizeBuffer=new Uint8Array(3),this.isEmpty=!0,this.beaconSizeLimit=1e6,this.prepare()}writeType(t){return this.encoder.uint(t[0])}writeFields(t){return this.encoder.encode(t)}writeSizeAt(t,s){for(let s=0;s<3;s++)this.sizeBuffer[s]=t>>8*s;this.encoder.set(this.sizeBuffer,s)}prepare(){if(!this.encoder.isEmpty)return;const t=[81,1,this.pageNo,this.nextIndex,this.timestamp,this.url],s=[118,this.tabId];this.writeType(t),this.writeFields(t),this.writeWithSize(s),this.isEmpty=!0}writeWithSize(t){const s=this.encoder;if(!this.writeType(t)||!s.skip(3))return!1;const i=s.getCurrentOffset(),e=this.writeFields(t);if(e){const e=s.getCurrentOffset()-i;if(e>16777215)return console.warn(\"OpenReplay: max message size overflow.\"),!1;this.writeSizeAt(e,i-3),s.checkpoint(),this.isEmpty=this.isEmpty&&0===t[0],this.nextIndex++}return e}setBeaconSizeLimit(t){this.beaconSizeLimit=t}writeMessage(t){if(\"q_end\"===t[0])return this.finaliseBatch(),this.onOfflineEnd();0===t[0]&&(this.timestamp=t[1]),122===t[0]&&(this.url=t[1]),this.writeWithSize(t)||(this.finaliseBatch(),this.writeWithSize(t)||(this.encoder=new e(this.beaconSizeLimit),this.prepare(),this.writeWithSize(t)?this.finaliseBatch():console.warn(\"OpenReplay: beacon size overflow. Skipping large message.\",t,this),this.encoder=new e(this.beaconSize),this.prepare()))}finaliseBatch(){if(this.isEmpty)return;const t=this.encoder.flush();this.onBatch(t),this.prepare()}clean(){this.encoder.reset()}}var h;!function(t){t[t.NotActive=0]=\"NotActive\",t[t.Starting=1]=\"Starting\",t[t.Stopping=2]=\"Stopping\",t[t.Active=3]=\"Active\",t[t.Stopped=4]=\"Stopped\"}(h||(h={}));let r=null,a=null,u=h.NotActive;function o(){a&&a.finaliseBatch()}function c(){return new Promise((t=>{u=h.Stopping,null!==p&&(clearInterval(p),p=null),a&&(a.clean(),a=null),r&&(r.clean(),setTimeout((()=>{r=null}),20)),setTimeout((()=>{u=h.NotActive,t(null)}),100)}))}function l(){[h.Stopped,h.Stopping].includes(u)||(postMessage(\"a_stop\"),c().then((()=>{postMessage(\"a_start\")})))}let g,p=null;self.onmessage=({data:s})=>{if(null!=s)if(\"heartbeat_q\"!==s){if(\"stop\"===s)return o(),void c().then((()=>{u=h.Stopped}));if(\"forceFlushBatch\"!==s){if(!Array.isArray(s)){if(\"compressed\"===s.type){if(!r)return console.debug(\"OR WebWorker: sender not initialised. Compressed batch.\"),void l();s.batch&&r.sendCompressed(s.batch)}if(\"uncompressed\"===s.type){if(!r)return console.debug(\"OR WebWorker: sender not initialised. Uncompressed batch.\"),void l();s.batch&&r.sendUncompressed(s.batch)}return\"start\"===s.type?(u=h.Starting,r=new t(s.ingestPoint,(()=>{l()}),(t=>{!function(t){postMessage({type:\"failure\",reason:t}),c()}(t)}),s.connAttemptCount,s.connAttemptGap,(t=>{postMessage({type:\"compress\",batch:t},[t.buffer])}),s.pageNo),a=new n(s.pageNo,s.timestamp,s.url,(t=>{r&&r.push(t)}),s.tabId,(()=>postMessage({type:\"queue_empty\"}))),null===p&&(p=setInterval(o,1e4)),u=h.Active):\"auth\"===s.type?r?a?(r.authorise(s.token),void(s.beaconSizeLimit&&a.setBeaconSizeLimit(s.beaconSizeLimit))):(console.debug(\"OR WebWorker: writer not initialised. Received auth.\"),void l()):(console.debug(\"OR WebWorker: sender not initialised. Received auth.\"),void l()):void 0}if(a){const t=a;s.forEach((s=>{55===s[0]&&(s[1]?g=setTimeout((()=>l()),18e5):clearTimeout(g)),t.writeMessage(s)}))}else postMessage(\"not_init\"),l()}else o()}else setTimeout((()=>{postMessage(\"heartbeat_a\")}),50);else o()}}();\n";
4674
+ const workerBodyFn = "!function(){\"use strict\";class t{constructor(t,s,i,e=10,n=250,h,r){this.onUnauthorised=s,this.onFailure=i,this.MAX_ATTEMPTS_COUNT=e,this.ATTEMPT_TIMEOUT=n,this.onCompress=h,this.pageNo=r,this.attemptsCount=0,this.busy=!1,this.queue=[],this.token=null,this.lastBatchNum=0,this.ingestURL=t+\"/v1/web/i\",this.isCompressing=void 0!==h}getQueueStatus(){return 0===this.queue.length&&!this.busy}authorise(t){this.token=t,this.busy||this.sendNext()}push(t){if(this.busy||!this.token)this.queue.push(t);else if(this.busy=!0,this.isCompressing&&this.onCompress)this.onCompress(t);else{const s=++this.lastBatchNum;this.sendBatch(t,!1,s)}}sendNext(){const t=this.queue.shift();if(t)if(this.busy=!0,this.isCompressing&&this.onCompress)this.onCompress(t);else{const s=++this.lastBatchNum;this.sendBatch(t,!1,s)}else this.busy=!1}retry(t,s,i){this.attemptsCount>=this.MAX_ATTEMPTS_COUNT?this.onFailure(`Failed to send batch after ${this.attemptsCount} attempts.`):(this.attemptsCount++,setTimeout((()=>this.sendBatch(t,s,i)),this.ATTEMPT_TIMEOUT*this.attemptsCount))}sendBatch(t,s,i){var e;const n=null==i?void 0:i.toString().replace(/^([^_]+)_([^_]+).*/,\"$1_$2_$3\");this.busy=!0;const h={Authorization:`Bearer ${this.token}`};s&&(h[\"Content-Encoding\"]=\"gzip\"),null!==this.token?fetch(`${this.ingestURL}?batch=${null!==(e=this.pageNo)&&void 0!==e?e:\"noPageNum\"}_${null!=n?n:\"noBatchNum\"}`,{body:t,method:\"POST\",headers:h,keepalive:t.length<65536}).then((e=>{if(401===e.status)return this.busy=!1,void this.onUnauthorised();e.status>=400?this.retry(t,s,`${null!=i?i:\"noBatchNum\"}_network:${e.status}`):(this.attemptsCount=0,this.sendNext())})).catch((e=>{console.warn(\"OpenReplay:\",e),this.retry(t,s,`${null!=i?i:\"noBatchNum\"}_reject:${e.message}`)})):setTimeout((()=>{this.sendBatch(t,s,`${null!=i?i:\"noBatchNum\"}_newToken`)}),500)}sendCompressed(t){const s=++this.lastBatchNum;this.sendBatch(t,!0,s)}sendUncompressed(t){const s=++this.lastBatchNum;this.sendBatch(t,!1,s)}clean(){this.sendNext(),setTimeout((()=>{this.token=null,this.queue.length=0}),10)}}const s=\"function\"==typeof TextEncoder?new TextEncoder:{encode(t){const s=t.length,i=new Uint8Array(3*s);let e=-1;for(let n=0,h=0,r=0;r!==s;){if(n=t.charCodeAt(r),r+=1,n>=55296&&n<=56319){if(r===s){i[e+=1]=239,i[e+=1]=191,i[e+=1]=189;break}if(h=t.charCodeAt(r),!(h>=56320&&h<=57343)){i[e+=1]=239,i[e+=1]=191,i[e+=1]=189;continue}if(n=1024*(n-55296)+h-56320+65536,r+=1,n>65535){i[e+=1]=240|n>>>18,i[e+=1]=128|n>>>12&63,i[e+=1]=128|n>>>6&63,i[e+=1]=128|63&n;continue}}n<=127?i[e+=1]=0|n:n<=2047?(i[e+=1]=192|n>>>6,i[e+=1]=128|63&n):(i[e+=1]=224|n>>>12,i[e+=1]=128|n>>>6&63,i[e+=1]=128|63&n)}return i.subarray(0,e+1)}};class i{constructor(t){this.size=t,this.offset=0,this.checkpointOffset=0,this.data=new Uint8Array(t)}getCurrentOffset(){return this.offset}checkpoint(){this.checkpointOffset=this.offset}get isEmpty(){return 0===this.offset}skip(t){return this.offset+=t,this.offset<=this.size}set(t,s){this.data.set(t,s)}boolean(t){return this.data[this.offset++]=+t,this.offset<=this.size}uint(t){for((t<0||t>Number.MAX_SAFE_INTEGER)&&(t=0);t>=128;)this.data[this.offset++]=t%256|128,t=Math.floor(t/128);return this.data[this.offset++]=t,this.offset<=this.size}int(t){return t=Math.round(t),this.uint(t>=0?2*t:-2*t-1)}string(t){const i=s.encode(t),e=i.byteLength;return!(!this.uint(e)||this.offset+e>this.size)&&(this.data.set(i,this.offset),this.offset+=e,!0)}reset(){this.offset=0,this.checkpointOffset=0}flush(){const t=this.data.slice(0,this.checkpointOffset);return this.reset(),t}}class e extends i{encode(t){switch(t[0]){case 0:case 11:case 114:case 115:return this.uint(t[1]);case 4:case 44:case 47:return this.string(t[1])&&this.string(t[2])&&this.uint(t[3]);case 5:case 20:case 70:case 75:case 76:case 77:case 82:return this.uint(t[1])&&this.uint(t[2]);case 6:return this.int(t[1])&&this.int(t[2]);case 7:return!0;case 8:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3])&&this.string(t[4])&&this.boolean(t[5]);case 9:case 10:case 24:case 35:case 51:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3]);case 12:case 52:case 61:case 71:return this.uint(t[1])&&this.string(t[2])&&this.string(t[3]);case 13:case 14:case 17:case 34:case 50:case 54:return this.uint(t[1])&&this.string(t[2]);case 16:return this.uint(t[1])&&this.int(t[2])&&this.int(t[3]);case 18:return this.uint(t[1])&&this.string(t[2])&&this.int(t[3]);case 19:return this.uint(t[1])&&this.boolean(t[2]);case 21:return this.string(t[1])&&this.string(t[2])&&this.string(t[3])&&this.string(t[4])&&this.string(t[5])&&this.uint(t[6])&&this.uint(t[7])&&this.uint(t[8]);case 22:case 27:case 30:case 41:case 45:case 46:case 43:case 63:case 64:case 79:case 124:return this.string(t[1])&&this.string(t[2]);case 23:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3])&&this.uint(t[4])&&this.uint(t[5])&&this.uint(t[6])&&this.uint(t[7])&&this.uint(t[8])&&this.uint(t[9]);case 28:case 29:case 42:case 117:case 118:return this.string(t[1]);case 40:return this.string(t[1])&&this.uint(t[2])&&this.string(t[3])&&this.string(t[4]);case 48:return this.string(t[1])&&this.string(t[2])&&this.string(t[3])&&this.string(t[4])&&this.int(t[5]);case 49:return this.int(t[1])&&this.int(t[2])&&this.uint(t[3])&&this.uint(t[4]);case 53:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3])&&this.uint(t[4])&&this.uint(t[5])&&this.uint(t[6])&&this.string(t[7])&&this.string(t[8]);case 55:return this.boolean(t[1]);case 57:case 60:return this.uint(t[1])&&this.string(t[2])&&this.string(t[3])&&this.string(t[4]);case 58:case 120:return this.int(t[1]);case 68:return this.uint(t[1])&&this.uint(t[2])&&this.string(t[3])&&this.string(t[4])&&this.uint(t[5])&&this.uint(t[6]);case 69:return this.uint(t[1])&&this.uint(t[2])&&this.string(t[3])&&this.string(t[4]);case 73:return this.uint(t[1])&&this.string(t[2])&&this.uint(t[3])&&this.string(t[4]);case 78:return this.string(t[1])&&this.string(t[2])&&this.string(t[3])&&this.string(t[4]);case 81:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3])&&this.int(t[4])&&this.string(t[5]);case 83:return this.string(t[1])&&this.string(t[2])&&this.string(t[3])&&this.string(t[4])&&this.string(t[5])&&this.uint(t[6])&&this.uint(t[7])&&this.uint(t[8])&&this.uint(t[9]);case 84:return this.string(t[1])&&this.string(t[2])&&this.string(t[3])&&this.uint(t[4])&&this.string(t[5])&&this.string(t[6]);case 112:return this.uint(t[1])&&this.string(t[2])&&this.boolean(t[3])&&this.string(t[4])&&this.int(t[5])&&this.int(t[6]);case 113:return this.uint(t[1])&&this.uint(t[2])&&this.string(t[3]);case 116:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3])&&this.uint(t[4])&&this.uint(t[5])&&this.uint(t[6])&&this.string(t[7])&&this.string(t[8])&&this.uint(t[9])&&this.boolean(t[10]);case 119:return this.string(t[1])&&this.uint(t[2]);case 121:return this.string(t[1])&&this.string(t[2])&&this.uint(t[3])&&this.uint(t[4]);case 122:return this.string(t[1])&&this.string(t[2])&&this.uint(t[3])&&this.string(t[4]);case 123:return this.string(t[1])&&this.string(t[2])&&this.string(t[3])&&this.string(t[4])&&this.uint(t[5])}}}class n{constructor(t,s,i,n,h,r){this.pageNo=t,this.timestamp=s,this.url=i,this.onBatch=n,this.tabId=h,this.onOfflineEnd=r,this.nextIndex=0,this.beaconSize=2e5,this.encoder=new e(this.beaconSize),this.sizeBuffer=new Uint8Array(3),this.isEmpty=!0,this.beaconSizeLimit=1e6,this.prepare()}writeType(t){return this.encoder.uint(t[0])}writeFields(t){return this.encoder.encode(t)}writeSizeAt(t,s){for(let s=0;s<3;s++)this.sizeBuffer[s]=t>>8*s;this.encoder.set(this.sizeBuffer,s)}prepare(){if(!this.encoder.isEmpty)return;const t=[81,1,this.pageNo,this.nextIndex,this.timestamp,this.url],s=[118,this.tabId];this.writeType(t),this.writeFields(t),this.writeWithSize(s),this.isEmpty=!0}writeWithSize(t){const s=this.encoder;if(!this.writeType(t)||!s.skip(3))return!1;const i=s.getCurrentOffset(),e=this.writeFields(t);if(e){const e=s.getCurrentOffset()-i;if(e>16777215)return console.warn(\"OpenReplay: max message size overflow.\"),!1;this.writeSizeAt(e,i-3),s.checkpoint(),this.isEmpty=this.isEmpty&&0===t[0],this.nextIndex++}return e}setBeaconSizeLimit(t){this.beaconSizeLimit=t}writeMessage(t){if(\"q_end\"===t[0])return this.finaliseBatch(),this.onOfflineEnd();0===t[0]&&(this.timestamp=t[1]),122===t[0]&&(this.url=t[1]),this.writeWithSize(t)||(this.finaliseBatch(),this.writeWithSize(t)||(this.encoder=new e(this.beaconSizeLimit),this.prepare(),this.writeWithSize(t)?this.finaliseBatch():console.warn(\"OpenReplay: beacon size overflow. Skipping large message.\",t,this),this.encoder=new e(this.beaconSize),this.prepare()))}finaliseBatch(){if(this.isEmpty)return;const t=this.encoder.flush();this.onBatch(t),this.prepare()}clean(){this.encoder.reset()}}var h;!function(t){t[t.NotActive=0]=\"NotActive\",t[t.Starting=1]=\"Starting\",t[t.Stopping=2]=\"Stopping\",t[t.Active=3]=\"Active\",t[t.Stopped=4]=\"Stopped\"}(h||(h={}));let r=null,a=null,u=h.NotActive;function o(){a&&a.finaliseBatch()}function c(){return new Promise((t=>{u=h.Stopping,null!==p&&(clearInterval(p),p=null),a&&(a.clean(),a=null),r&&(r.clean(),setTimeout((()=>{r=null}),20)),setTimeout((()=>{u=h.NotActive,t(null)}),100)}))}function l(){[h.Stopped,h.Stopping].includes(u)||(postMessage(\"a_stop\"),c().then((()=>{postMessage(\"a_start\")})))}let g,p=null;self.onmessage=({data:s})=>{if(null!=s){if(\"stop\"===s)return o(),void c().then((()=>{u=h.Stopped}));if(\"forceFlushBatch\"!==s){if(!Array.isArray(s)){if(\"compressed\"===s.type){if(!r)return console.debug(\"OR WebWorker: sender not initialised. Compressed batch.\"),void l();s.batch&&r.sendCompressed(s.batch)}if(\"uncompressed\"===s.type){if(!r)return console.debug(\"OR WebWorker: sender not initialised. Uncompressed batch.\"),void l();s.batch&&r.sendUncompressed(s.batch)}return\"start\"===s.type?(u=h.Starting,r=new t(s.ingestPoint,(()=>{l()}),(t=>{!function(t){postMessage({type:\"failure\",reason:t}),c()}(t)}),s.connAttemptCount,s.connAttemptGap,(t=>{postMessage({type:\"compress\",batch:t},[t.buffer])}),s.pageNo),a=new n(s.pageNo,s.timestamp,s.url,(t=>{r&&r.push(t)}),s.tabId,(()=>postMessage({type:\"queue_empty\"}))),null===p&&(p=setInterval(o,1e4)),u=h.Active):\"auth\"===s.type?r?a?(r.authorise(s.token),void(s.beaconSizeLimit&&a.setBeaconSizeLimit(s.beaconSizeLimit))):(console.debug(\"OR WebWorker: writer not initialised. Received auth.\"),void l()):(console.debug(\"OR WebWorker: sender not initialised. Received auth.\"),void l()):void 0}if(a){const t=a;s.forEach((s=>{55===s[0]&&(s[1]?g=setTimeout((()=>l()),18e5):clearTimeout(g)),t.writeMessage(s)}))}else postMessage(\"not_init\"),l()}else o()}else o()}}();\n";
4680
4675
  const CANCELED = 'canceled';
4681
4676
  const uxtStorageKey = 'or_uxt_active';
4682
4677
  const bufferStorageKey = 'or_buffer_1';
@@ -4730,7 +4725,7 @@ class App {
4730
4725
  this.stopCallbacks = [];
4731
4726
  this.commitCallbacks = [];
4732
4727
  this.activityState = ActivityState.NotActive;
4733
- this.version = '16.0.2-beta.1'; // TODO: version compatability check inside each plugin.
4728
+ this.version = '16.0.3-beta-1'; // TODO: version compatability check inside each plugin.
4734
4729
  this.socketMode = false;
4735
4730
  this.compressionThreshold = 24 * 1000;
4736
4731
  this.bc = null;
@@ -4962,8 +4957,6 @@ class App {
4962
4957
  }
4963
4958
  };
4964
4959
  this.startTimeout = null;
4965
- this.heartbeatInterval = null;
4966
- this.restartTimeout = null;
4967
4960
  this.coldStartCommitN = 0;
4968
4961
  this.delay = 0;
4969
4962
  this.attachStartCallback = (cb, useSafe = false) => {
@@ -5065,6 +5058,7 @@ class App {
5065
5058
  fixedCanvasScaling: false,
5066
5059
  disableCanvas: false,
5067
5060
  captureIFrames: true,
5061
+ disableSprites: false,
5068
5062
  obscureTextEmails: true,
5069
5063
  obscureTextNumbers: false,
5070
5064
  crossdomain: {
@@ -5243,17 +5237,6 @@ class App {
5243
5237
  this.worker.postMessage(null);
5244
5238
  }
5245
5239
  };
5246
- this.heartbeatInterval = setInterval(() => {
5247
- if (this.worker) {
5248
- this.restartTimeout = setTimeout(() => {
5249
- this.stop();
5250
- this.waitStatus(ActivityState.NotActive).then(() => {
5251
- void this.start(this.prevOpts);
5252
- });
5253
- }, 10000);
5254
- this.worker.postMessage('heartbeat_q');
5255
- }
5256
- }, 20000);
5257
5240
  // keep better tactics, discard others?
5258
5241
  this.attachEventListener(window, 'beforeunload', alertWorker, false);
5259
5242
  this.attachEventListener(document.body, 'mouseleave', alertWorker, false, false);
@@ -5284,12 +5267,6 @@ class App {
5284
5267
  else if (data === 'not_init') {
5285
5268
  this.debug.warn('OR WebWorker: writer not initialised. Restarting tracker');
5286
5269
  }
5287
- else if (data === 'heartbeat_a') {
5288
- if (this.restartTimeout) {
5289
- clearTimeout(this.restartTimeout);
5290
- this.restartTimeout = null;
5291
- }
5292
- }
5293
5270
  else if (data.type === 'failure') {
5294
5271
  this.stop(false);
5295
5272
  this.debug.error('worker_failed', data.reason);
@@ -5361,8 +5338,7 @@ class App {
5361
5338
  * */
5362
5339
  _nCommit() {
5363
5340
  if (this.socketMode) {
5364
- this.messages.unshift(TabData(this.session.getTabId()));
5365
- this.messages.unshift(Timestamp(this.timestamp()));
5341
+ this.messages.unshift(Timestamp(this.timestamp()), TabData(this.session.getTabId()));
5366
5342
  this.commitCallbacks.forEach((cb) => cb(this.messages));
5367
5343
  this.messages.length = 0;
5368
5344
  return;
@@ -5381,8 +5357,7 @@ class App {
5381
5357
  }
5382
5358
  try {
5383
5359
  requestIdleCb(() => {
5384
- this.messages.unshift(TabData(this.session.getTabId()));
5385
- this.messages.unshift(Timestamp(this.timestamp()));
5360
+ this.messages.unshift(Timestamp(this.timestamp()), TabData(this.session.getTabId()));
5386
5361
  this.worker?.postMessage(this.messages);
5387
5362
  this.commitCallbacks.forEach((cb) => cb(this.messages));
5388
5363
  this.messages.length = 0;
@@ -5405,20 +5380,13 @@ class App {
5405
5380
  _cStartCommit() {
5406
5381
  this.coldStartCommitN += 1;
5407
5382
  if (this.coldStartCommitN === 2) {
5408
- this.bufferedMessages1.push(Timestamp(this.timestamp()));
5409
- this.bufferedMessages1.push(TabData(this.session.getTabId()));
5410
- this.bufferedMessages2.push(Timestamp(this.timestamp()));
5411
- this.bufferedMessages2.push(TabData(this.session.getTabId()));
5383
+ const payload = [Timestamp(this.timestamp()), TabData(this.session.getTabId())];
5384
+ this.bufferedMessages1.push(...payload);
5385
+ this.bufferedMessages2.push(...payload);
5412
5386
  this.coldStartCommitN = 0;
5413
5387
  }
5414
5388
  }
5415
- /**
5416
- * called every 30ms via this.ticker
5417
- * */
5418
5389
  commit() {
5419
- if (this.activityState === ActivityState.NotActive) {
5420
- return;
5421
- }
5422
5390
  if (this.activityState === ActivityState.ColdStart) {
5423
5391
  this._cStartCommit();
5424
5392
  }
@@ -5441,6 +5409,10 @@ class App {
5441
5409
  }
5442
5410
  catch (e) {
5443
5411
  app._debug('safe_fn_call', e);
5412
+ // time: this.timestamp(),
5413
+ // name: e.name,
5414
+ // message: e.message,
5415
+ // stack: e.stack
5444
5416
  }
5445
5417
  }; // TODO: correct typing
5446
5418
  }
@@ -7269,7 +7241,7 @@ function roundNumber(num) {
7269
7241
  return Math.round(num * 1e4);
7270
7242
  }
7271
7243
 
7272
- var e,o=-1,a=function(e){addEventListener("pageshow",(function(n){n.persisted&&(o=n.timeStamp,e(n));}),!0);},c=function(){var e=self.performance&&performance.getEntriesByType&&performance.getEntriesByType("navigation")[0];if(e&&e.responseStart>0&&e.responseStart<performance.now())return e},u=function(){var e=c();return e&&e.activationStart||0},f=function(e,n){var t=c(),r="navigate";o>=0?r="back-forward-cache":t&&(document.prerendering||u()>0?r="prerender":document.wasDiscarded?r="restore":t.type&&(r=t.type.replace(/_/g,"-")));return {name:e,value:void 0===n?-1:n,rating:"good",delta:0,entries:[],id:"v4-".concat(Date.now(),"-").concat(Math.floor(8999999999999*Math.random())+1e12),navigationType:r}},s=function(e,n,t){try{if(PerformanceObserver.supportedEntryTypes.includes(e)){var r=new PerformanceObserver((function(e){Promise.resolve().then((function(){n(e.getEntries());}));}));return r.observe(Object.assign({type:e,buffered:!0},t||{})),r}}catch(e){}},d=function(e,n,t,r){var i,o;return function(a){n.value>=0&&(a||r)&&((o=n.value-(i||0))||void 0===i)&&(i=n.value,n.delta=o,n.rating=function(e,n){return e>n[1]?"poor":e>n[0]?"needs-improvement":"good"}(n.value,t),e(n));}},l=function(e){requestAnimationFrame((function(){return requestAnimationFrame((function(){return e()}))}));},p=function(e){document.addEventListener("visibilitychange",(function(){"hidden"===document.visibilityState&&e();}));},v=function(e){var n=!1;return function(){n||(e(),n=!0);}},m=-1,h=function(){return "hidden"!==document.visibilityState||document.prerendering?1/0:0},g=function(e){"hidden"===document.visibilityState&&m>-1&&(m="visibilitychange"===e.type?e.timeStamp:0,T());},y=function(){addEventListener("visibilitychange",g,!0),addEventListener("prerenderingchange",g,!0);},T=function(){removeEventListener("visibilitychange",g,!0),removeEventListener("prerenderingchange",g,!0);},E=function(){return m<0&&(m=h(),y(),a((function(){setTimeout((function(){m=h(),y();}),0);}))),{get firstHiddenTime(){return m}}},C=function(e){document.prerendering?addEventListener("prerenderingchange",(function(){return e()}),!0):e();},b=[1800,3e3],S=function(e,n){n=n||{},C((function(){var t,r=E(),i=f("FCP"),o=s("paint",(function(e){e.forEach((function(e){"first-contentful-paint"===e.name&&(o.disconnect(),e.startTime<r.firstHiddenTime&&(i.value=Math.max(e.startTime-u(),0),i.entries.push(e),t(!0)));}));}));o&&(t=d(e,i,b,n.reportAllChanges),a((function(r){i=f("FCP"),t=d(e,i,b,n.reportAllChanges),l((function(){i.value=performance.now()-r.timeStamp,t(!0);}));})));}));},L=[.1,.25],w=function(e,n){n=n||{},S(v((function(){var t,r=f("CLS",0),i=0,o=[],c=function(e){e.forEach((function(e){if(!e.hadRecentInput){var n=o[0],t=o[o.length-1];i&&e.startTime-t.startTime<1e3&&e.startTime-n.startTime<5e3?(i+=e.value,o.push(e)):(i=e.value,o=[e]);}})),i>r.value&&(r.value=i,r.entries=o,t());},u=s("layout-shift",c);u&&(t=d(e,r,L,n.reportAllChanges),p((function(){c(u.takeRecords()),t(!0);})),a((function(){i=0,r=f("CLS",0),t=d(e,r,L,n.reportAllChanges),l((function(){return t()}));})),setTimeout(t,0));})));},A=0,I=1/0,P=0,M=function(e){e.forEach((function(e){e.interactionId&&(I=Math.min(I,e.interactionId),P=Math.max(P,e.interactionId),A=P?(P-I)/7+1:0);}));},k=function(){return e?A:performance.interactionCount||0},F=function(){"interactionCount"in performance||e||(e=s("event",M,{type:"event",buffered:!0,durationThreshold:0}));},D=[],x=new Map,R=0,B=function(){var e=Math.min(D.length-1,Math.floor((k()-R)/50));return D[e]},H=[],q=function(e){if(H.forEach((function(n){return n(e)})),e.interactionId||"first-input"===e.entryType){var n=D[D.length-1],t=x.get(e.interactionId);if(t||D.length<10||e.duration>n.latency){if(t)e.duration>t.latency?(t.entries=[e],t.latency=e.duration):e.duration===t.latency&&e.startTime===t.entries[0].startTime&&t.entries.push(e);else {var r={id:e.interactionId,latency:e.duration,entries:[e]};x.set(r.id,r),D.push(r);}D.sort((function(e,n){return n.latency-e.latency})),D.length>10&&D.splice(10).forEach((function(e){return x.delete(e.id)}));}}},O=function(e){var n=self.requestIdleCallback||self.setTimeout,t=-1;return e=v(e),"hidden"===document.visibilityState?e():(t=n(e),p(e)),t},N=[200,500],j=function(e,n){"PerformanceEventTiming"in self&&"interactionId"in PerformanceEventTiming.prototype&&(n=n||{},C((function(){var t;F();var r,i=f("INP"),o=function(e){O((function(){e.forEach(q);var n=B();n&&n.latency!==i.value&&(i.value=n.latency,i.entries=n.entries,r());}));},c=s("event",o,{durationThreshold:null!==(t=n.durationThreshold)&&void 0!==t?t:40});r=d(e,i,N,n.reportAllChanges),c&&(c.observe({type:"first-input",buffered:!0}),p((function(){o(c.takeRecords()),r(!0);})),a((function(){R=k(),D.length=0,x.clear(),i=f("INP"),r=d(e,i,N,n.reportAllChanges);})));})));},_=[2500,4e3],z={},G=function(e,n){n=n||{},C((function(){var t,r=E(),i=f("LCP"),o=function(e){n.reportAllChanges||(e=e.slice(-1)),e.forEach((function(e){e.startTime<r.firstHiddenTime&&(i.value=Math.max(e.startTime-u(),0),i.entries=[e],t());}));},c=s("largest-contentful-paint",o);if(c){t=d(e,i,_,n.reportAllChanges);var m=v((function(){z[i.id]||(o(c.takeRecords()),c.disconnect(),z[i.id]=!0,t(!0));}));["keydown","click"].forEach((function(e){addEventListener(e,(function(){return O(m)}),{once:!0,capture:!0});})),p(m),a((function(r){i=f("LCP"),t=d(e,i,_,n.reportAllChanges),l((function(){i.value=performance.now()-r.timeStamp,z[i.id]=!0,t(!0);}));}));}}));},J=[800,1800],K=function e(n){document.prerendering?C((function(){return e(n)})):"complete"!==document.readyState?addEventListener("load",(function(){return e(n)}),!0):setTimeout(n,0);},Q=function(e,n){n=n||{};var t=f("TTFB"),r=d(e,t,J,n.reportAllChanges);K((function(){var i=c();i&&(t.value=Math.max(i.responseStart-u(),0),t.entries=[i],r(!0),a((function(){t=f("TTFB",0),(r=d(e,t,J,n.reportAllChanges))(!0);})));}));};
7244
+ var e,o=-1,a=function(e){addEventListener("pageshow",(function(n){n.persisted&&(o=n.timeStamp,e(n));}),true);},c=function(){var e=self.performance&&performance.getEntriesByType&&performance.getEntriesByType("navigation")[0];if(e&&e.responseStart>0&&e.responseStart<performance.now())return e},u=function(){var e=c();return e&&e.activationStart||0},f=function(e,n){var t=c(),r="navigate";o>=0?r="back-forward-cache":t&&(document.prerendering||u()>0?r="prerender":document.wasDiscarded?r="restore":t.type&&(r=t.type.replace(/_/g,"-")));return {name:e,value:void 0===n?-1:n,rating:"good",delta:0,entries:[],id:"v4-".concat(Date.now(),"-").concat(Math.floor(8999999999999*Math.random())+1e12),navigationType:r}},s=function(e,n,t){try{if(PerformanceObserver.supportedEntryTypes.includes(e)){var r=new PerformanceObserver((function(e){Promise.resolve().then((function(){n(e.getEntries());}));}));return r.observe(Object.assign({type:e,buffered:!0},t||{})),r}}catch(e){}},d=function(e,n,t,r){var i,o;return function(a){n.value>=0&&(a||r)&&((o=n.value-(i||0))||void 0===i)&&(i=n.value,n.delta=o,n.rating=function(e,n){return e>n[1]?"poor":e>n[0]?"needs-improvement":"good"}(n.value,t),e(n));}},l=function(e){requestAnimationFrame((function(){return requestAnimationFrame((function(){return e()}))}));},p=function(e){document.addEventListener("visibilitychange",(function(){"hidden"===document.visibilityState&&e();}));},v=function(e){var n=false;return function(){n||(e(),n=true);}},m=-1,h=function(){return "hidden"!==document.visibilityState||document.prerendering?1/0:0},g=function(e){"hidden"===document.visibilityState&&m>-1&&(m="visibilitychange"===e.type?e.timeStamp:0,T());},y=function(){addEventListener("visibilitychange",g,true),addEventListener("prerenderingchange",g,true);},T=function(){removeEventListener("visibilitychange",g,true),removeEventListener("prerenderingchange",g,true);},E=function(){return m<0&&(m=h(),y(),a((function(){setTimeout((function(){m=h(),y();}),0);}))),{get firstHiddenTime(){return m}}},C=function(e){document.prerendering?addEventListener("prerenderingchange",(function(){return e()}),true):e();},b=[1800,3e3],S=function(e,n){n=n||{},C((function(){var t,r=E(),i=f("FCP"),o=s("paint",(function(e){e.forEach((function(e){"first-contentful-paint"===e.name&&(o.disconnect(),e.startTime<r.firstHiddenTime&&(i.value=Math.max(e.startTime-u(),0),i.entries.push(e),t(true)));}));}));o&&(t=d(e,i,b,n.reportAllChanges),a((function(r){i=f("FCP"),t=d(e,i,b,n.reportAllChanges),l((function(){i.value=performance.now()-r.timeStamp,t(true);}));})));}));},L=[.1,.25],w=function(e,n){n=n||{},S(v((function(){var t,r=f("CLS",0),i=0,o=[],c=function(e){e.forEach((function(e){if(!e.hadRecentInput){var n=o[0],t=o[o.length-1];i&&e.startTime-t.startTime<1e3&&e.startTime-n.startTime<5e3?(i+=e.value,o.push(e)):(i=e.value,o=[e]);}})),i>r.value&&(r.value=i,r.entries=o,t());},u=s("layout-shift",c);u&&(t=d(e,r,L,n.reportAllChanges),p((function(){c(u.takeRecords()),t(true);})),a((function(){i=0,r=f("CLS",0),t=d(e,r,L,n.reportAllChanges),l((function(){return t()}));})),setTimeout(t,0));})));},A=0,I=1/0,P=0,M=function(e){e.forEach((function(e){e.interactionId&&(I=Math.min(I,e.interactionId),P=Math.max(P,e.interactionId),A=P?(P-I)/7+1:0);}));},k=function(){return e?A:performance.interactionCount||0},F=function(){"interactionCount"in performance||e||(e=s("event",M,{type:"event",buffered:true,durationThreshold:0}));},D=[],x=new Map,R=0,B=function(){var e=Math.min(D.length-1,Math.floor((k()-R)/50));return D[e]},H=[],q=function(e){if(H.forEach((function(n){return n(e)})),e.interactionId||"first-input"===e.entryType){var n=D[D.length-1],t=x.get(e.interactionId);if(t||D.length<10||e.duration>n.latency){if(t)e.duration>t.latency?(t.entries=[e],t.latency=e.duration):e.duration===t.latency&&e.startTime===t.entries[0].startTime&&t.entries.push(e);else {var r={id:e.interactionId,latency:e.duration,entries:[e]};x.set(r.id,r),D.push(r);}D.sort((function(e,n){return n.latency-e.latency})),D.length>10&&D.splice(10).forEach((function(e){return x.delete(e.id)}));}}},O=function(e){var n=self.requestIdleCallback||self.setTimeout,t=-1;return e=v(e),"hidden"===document.visibilityState?e():(t=n(e),p(e)),t},N=[200,500],j=function(e,n){"PerformanceEventTiming"in self&&"interactionId"in PerformanceEventTiming.prototype&&(n=n||{},C((function(){var t;F();var r,i=f("INP"),o=function(e){O((function(){e.forEach(q);var n=B();n&&n.latency!==i.value&&(i.value=n.latency,i.entries=n.entries,r());}));},c=s("event",o,{durationThreshold:null!==(t=n.durationThreshold)&&void 0!==t?t:40});r=d(e,i,N,n.reportAllChanges),c&&(c.observe({type:"first-input",buffered:true}),p((function(){o(c.takeRecords()),r(true);})),a((function(){R=k(),D.length=0,x.clear(),i=f("INP"),r=d(e,i,N,n.reportAllChanges);})));})));},_=[2500,4e3],z={},G=function(e,n){n=n||{},C((function(){var t,r=E(),i=f("LCP"),o=function(e){n.reportAllChanges||(e=e.slice(-1)),e.forEach((function(e){e.startTime<r.firstHiddenTime&&(i.value=Math.max(e.startTime-u(),0),i.entries=[e],t());}));},c=s("largest-contentful-paint",o);if(c){t=d(e,i,_,n.reportAllChanges);var m=v((function(){z[i.id]||(o(c.takeRecords()),c.disconnect(),z[i.id]=true,t(true));}));["keydown","click"].forEach((function(e){addEventListener(e,(function(){return O(m)}),{once:true,capture:true});})),p(m),a((function(r){i=f("LCP"),t=d(e,i,_,n.reportAllChanges),l((function(){i.value=performance.now()-r.timeStamp,z[i.id]=true,t(true);}));}));}}));},J=[800,1800],K=function e(n){document.prerendering?C((function(){return e(n)})):"complete"!==document.readyState?addEventListener("load",(function(){return e(n)}),true):setTimeout(n,0);},Q=function(e,n){n=n||{};var t=f("TTFB"),r=d(e,t,J,n.reportAllChanges);K((function(){var i=c();i&&(t.value=Math.max(i.responseStart-u(),0),t.entries=[i],r(true),a((function(){t=f("TTFB",0),(r=d(e,t,J,n.reportAllChanges))(true);})));}));};
7273
7245
 
7274
7246
  function getPaintBlocks(resources) {
7275
7247
  const paintBlocks = [];
@@ -9213,7 +9185,7 @@ class API {
9213
9185
  this.signalStartIssue = (reason, missingApi) => {
9214
9186
  const doNotTrack = this.checkDoNotTrack();
9215
9187
  console.log("Tracker couldn't start due to:", JSON.stringify({
9216
- trackerVersion: '16.0.2-beta.1',
9188
+ trackerVersion: '16.0.3-beta-1',
9217
9189
  projectKey: this.options.projectKey,
9218
9190
  doNotTrack,
9219
9191
  reason: missingApi.length ? `missing api: ${missingApi.join(',')}` : reason,