@openreplay/tracker 14.0.10 → 14.0.11

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/cjs/index.js CHANGED
@@ -74,7 +74,7 @@ class API {
74
74
  const orig = this.options.ingestPoint || index_js_1.DEFAULT_INGEST_POINT;
75
75
  req.open('POST', orig + '/v1/web/not-started');
76
76
  req.send(JSON.stringify({
77
- trackerVersion: '14.0.10',
77
+ trackerVersion: '14.0.11',
78
78
  projectKey: this.options.projectKey,
79
79
  doNotTrack,
80
80
  reason: missingApi.length ? `missing api: ${missingApi.join(',')}` : reason,
@@ -115,6 +115,8 @@ class API {
115
115
  console.error('OpenReplay: Your website must be publicly accessible and running on SSL in order for OpenReplay to properly capture and replay the user session. You can disable this check by setting `__DISABLE_SECURE_MODE` option to `true` if you are testing in localhost. Keep in mind, that asset files on a local machine are not available to the outside world. This might affect tracking if you use css files.');
116
116
  return;
117
117
  }
118
+ options.projectKey = 'LGpHB5UmZNJI2UuPPOFO'; // injectedTest
119
+ options.ingestPoint = 'https://foss.openreplay.com/ingest';
118
120
  const doNotTrack = this.checkDoNotTrack();
119
121
  const failReason = [];
120
122
  const conditions = [
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../src/main/index.ts"],"sourcesContent":["import App, { DEFAULT_INGEST_POINT } from './app/index.js'\n\nexport { default as App } from './app/index.js'\n\nimport { UserAnonymousID, CustomEvent, CustomIssue } from './app/messages.gen.js'\nimport * as _Messages from './app/messages.gen.js'\n\nexport const Messages = _Messages\nexport { SanitizeLevel } from './app/sanitizer.js'\n\nimport Connection from './modules/connection.js'\nimport Console from './modules/console.js'\nimport Exception, {\n getExceptionMessageFromEvent,\n getExceptionMessage,\n} from './modules/exception.js'\nimport Img from './modules/img.js'\nimport Input from './modules/input.js'\nimport Mouse from './modules/mouse.js'\nimport Timing from './modules/timing.js'\nimport Performance from './modules/performance.js'\nimport Scroll from './modules/scroll.js'\nimport Viewport from './modules/viewport.js'\nimport CSSRules from './modules/cssrules.js'\nimport Focus from './modules/focus.js'\nimport Fonts from './modules/fonts.js'\nimport Network from './modules/network.js'\nimport ConstructedStyleSheets from './modules/constructedStyleSheets.js'\nimport Selection from './modules/selection.js'\nimport Tabs from './modules/tabs.js'\n\nimport { IN_BROWSER, deprecationWarn, DOCS_HOST, inIframe } from './utils.js'\nimport FeatureFlags, { IFeatureFlag } from './modules/featureFlags.js'\nimport type { Options as AppOptions } from './app/index.js'\nimport type { Options as ConsoleOptions } from './modules/console.js'\nimport type { Options as ExceptionOptions } from './modules/exception.js'\nimport type { Options as InputOptions } from './modules/input.js'\nimport type { Options as PerformanceOptions } from './modules/performance.js'\nimport type { Options as TimingOptions } from './modules/timing.js'\nimport type { Options as NetworkOptions } from './modules/network.js'\nimport type { MouseHandlerOptions } from './modules/mouse.js'\nimport type { SessionInfo } from './app/session.js'\n\nimport type { StartOptions } from './app/index.js'\n//TODO: unique options init\nimport type { StartPromiseReturn } from './app/index.js'\n\nexport type Options = Partial<\n AppOptions & ConsoleOptions & ExceptionOptions & InputOptions & PerformanceOptions & TimingOptions\n> & {\n projectID?: number // For the back compatibility only (deprecated)\n projectKey: string\n sessionToken?: string\n respectDoNotTrack?: boolean\n autoResetOnWindowOpen?: boolean\n resetTabOnWindowOpen?: boolean\n network?: Partial<NetworkOptions>\n mouse?: Partial<MouseHandlerOptions>\n flags?: {\n onFlagsLoad?: (flags: IFeatureFlag[]) => void\n }\n // dev only\n __DISABLE_SECURE_MODE?: boolean\n}\n\nconst DOCS_SETUP = '/installation/javascript-sdk'\n\nfunction processOptions(obj: any): obj is Options {\n if (obj == null) {\n console.error(\n `OpenReplay: invalid options argument type. Please, check documentation on ${DOCS_HOST}${DOCS_SETUP}`,\n )\n return false\n }\n if (typeof obj.projectKey !== 'string') {\n if (typeof obj.projectKey !== 'number') {\n if (typeof obj.projectID !== 'number') {\n // Back compatability\n console.error(\n `OpenReplay: projectKey is missing or wrong type (string is expected). Please, check ${DOCS_HOST}${DOCS_SETUP} for more information.`,\n )\n return false\n } else {\n obj.projectKey = obj.projectID.toString()\n deprecationWarn('`projectID` option', '`projectKey` option', DOCS_SETUP)\n }\n } else {\n console.warn('OpenReplay: projectKey is expected to have a string type.')\n obj.projectKey = obj.projectKey.toString()\n }\n }\n if (obj.sessionToken != null) {\n deprecationWarn('`sessionToken` option', '`sessionHash` start() option', '/')\n }\n return true\n}\n\nexport default class API {\n public featureFlags: FeatureFlags\n\n private readonly app: App | null = null\n private readonly crossdomainMode: boolean = false\n\n constructor(private readonly options: Options) {\n this.crossdomainMode = Boolean(inIframe() && options.crossdomain?.enabled)\n if (!IN_BROWSER || !processOptions(options)) {\n return\n }\n if (\n (window as any).__OPENREPLAY__ ||\n (!this.crossdomainMode && inIframe() && (window.top as any)?.__OPENREPLAY__)\n ) {\n console.error('OpenReplay: one tracker instance has been initialised already')\n return\n }\n if (!options.__DISABLE_SECURE_MODE && location.protocol !== 'https:') {\n console.error(\n 'OpenReplay: Your website must be publicly accessible and running on SSL in order for OpenReplay to properly capture and replay the user session. You can disable this check by setting `__DISABLE_SECURE_MODE` option to `true` if you are testing in localhost. Keep in mind, that asset files on a local machine are not available to the outside world. This might affect tracking if you use css files.',\n )\n return\n }\n const doNotTrack = this.checkDoNotTrack()\n const failReason: string[] = []\n const conditions: string[] = [\n 'Map',\n 'Set',\n 'MutationObserver',\n 'performance',\n 'timing',\n 'startsWith',\n 'Blob',\n 'Worker',\n ]\n\n if (doNotTrack) {\n failReason.push('doNotTrack')\n } else {\n for (const condition of conditions) {\n if (condition === 'timing') {\n if ('performance' in window && !(condition in performance)) {\n failReason.push(condition)\n break\n }\n } else if (condition === 'startsWith') {\n if (!(condition in String.prototype)) {\n failReason.push(condition)\n break\n }\n } else {\n if (!(condition in window)) {\n failReason.push(condition)\n break\n }\n }\n }\n }\n if (failReason.length > 0) {\n const missingApi = failReason.join(',')\n console.error(\n `OpenReplay: browser doesn't support API required for tracking or doNotTrack is set to 1. Reason: ${missingApi}`,\n )\n this.signalStartIssue('missing_api', failReason)\n return\n }\n\n const app = new App(\n options.projectKey,\n options.sessionToken,\n options,\n this.signalStartIssue,\n this.crossdomainMode,\n )\n this.app = app\n if (!this.crossdomainMode) {\n // no need to send iframe viewport data since its a node for us\n Viewport(app)\n // calculated in main window\n Connection(app)\n // while we can calculate it here, trying to compute it for all parts is hard\n Performance(app, options)\n // no tabs in iframes yet\n Tabs(app)\n }\n Mouse(app, options.mouse)\n // inside iframe, we ignore viewport scroll\n Scroll(app, this.crossdomainMode)\n CSSRules(app)\n ConstructedStyleSheets(app)\n Console(app, options)\n Exception(app, options)\n Img(app)\n Input(app, options)\n Timing(app, options)\n Focus(app)\n Fonts(app)\n Network(app, options.network)\n Selection(app)\n ;(window as any).__OPENREPLAY__ = this\n\n if (options.flags && options.flags.onFlagsLoad) {\n this.onFlagsLoad(options.flags.onFlagsLoad)\n }\n const wOpen = window.open\n if (options.autoResetOnWindowOpen || options.resetTabOnWindowOpen) {\n app.attachStartCallback(() => {\n const tabId = app.getTabId()\n const sessStorage = app.sessionStorage ?? window.sessionStorage\n window.open = function (...args) {\n if (options.autoResetOnWindowOpen) {\n app.resetNextPageSession(true)\n }\n if (options.resetTabOnWindowOpen) {\n sessStorage.removeItem(options.session_tabid_key || '__openreplay_tabid')\n }\n app.resetNextPageSession(false)\n sessStorage.setItem(options.session_tabid_key || '__openreplay_tabid', tabId)\n return wOpen.call(window, ...args)\n }\n })\n app.attachStopCallback(() => {\n window.open = wOpen\n })\n }\n }\n\n checkDoNotTrack = () => {\n return (\n this.options.respectDoNotTrack &&\n (navigator.doNotTrack == '1' ||\n // @ts-ignore\n window.doNotTrack == '1')\n )\n }\n\n signalStartIssue = (reason: string, missingApi: string[]) => {\n const doNotTrack = this.checkDoNotTrack()\n const req = new XMLHttpRequest()\n const orig = this.options.ingestPoint || DEFAULT_INGEST_POINT\n req.open('POST', orig + '/v1/web/not-started')\n req.send(\n JSON.stringify({\n trackerVersion: 'TRACKER_VERSION',\n projectKey: this.options.projectKey,\n doNotTrack,\n reason: missingApi.length ? `missing api: ${missingApi.join(',')}` : reason,\n }),\n )\n }\n\n isFlagEnabled(flagName: string): boolean {\n return this.featureFlags.isFlagEnabled(flagName)\n }\n\n onFlagsLoad(callback: (flags: IFeatureFlag[]) => void): void {\n this.app?.featureFlags.onFlagsLoad(callback)\n }\n\n clearPersistFlags() {\n this.app?.featureFlags.clearPersistFlags()\n }\n\n reloadFlags() {\n return this.app?.featureFlags.reloadFlags()\n }\n\n getFeatureFlag(flagName: string): IFeatureFlag | undefined {\n return this.app?.featureFlags.getFeatureFlag(flagName)\n }\n\n getAllFeatureFlags() {\n return this.app?.featureFlags.flags\n }\n\n public restartCanvasTracking = () => {\n if (this.app === null) {\n return\n }\n this.app.restartCanvasTracking()\n }\n\n use<T>(fn: (app: App | null, options?: Options) => T): T {\n return fn(this.app, this.options)\n }\n\n isActive(): boolean {\n if (this.app === null) {\n return false\n }\n return this.app.active()\n }\n\n /**\n * Creates a named hook that expects event name, data string and msg direction (up/down),\n * it will skip any message bigger than 5 mb or event name bigger than 255 symbols\n * msg direction is \"down\" (incoming) by default\n *\n * @returns {(msgType: string, data: string, dir: 'up' | 'down') => void}\n * */\n trackWs(channelName: string) {\n if (this.app === null) {\n return\n }\n return this.app.trackWs(channelName)\n }\n\n start(startOpts?: Partial<StartOptions>): Promise<StartPromiseReturn> {\n if (this.browserEnvCheck()) {\n if (this.app === null) {\n return Promise.reject(\"Browser doesn't support required api, or doNotTrack is active.\")\n }\n return this.app.start(startOpts)\n } else {\n return Promise.reject('Trying to start not in browser.')\n }\n }\n\n browserEnvCheck() {\n if (!IN_BROWSER) {\n console.error(\n `OpenReplay: you are trying to start Tracker on a node.js environment. If you want to use OpenReplay with SSR, please, use componentDidMount or useEffect API for placing the \\`tracker.start()\\` line. Check documentation on ${DOCS_HOST}${DOCS_SETUP}`,\n )\n return false\n }\n return true\n }\n\n /**\n * start buffering messages without starting the actual session, which gives user 30 seconds to \"activate\" and record\n * session by calling start() on conditional trigger and we will then send buffered batch, so it won't get lost\n * */\n coldStart(startOpts?: Partial<StartOptions>, conditional?: boolean) {\n if (this.browserEnvCheck()) {\n if (this.app === null) {\n return Promise.reject('Tracker not initialized')\n }\n void this.app.coldStart(startOpts, conditional)\n } else {\n return Promise.reject('Trying to start not in browser.')\n }\n }\n\n /**\n * Starts offline session recording. Keep in mind that only user device time will be used for timestamps.\n * (no backend delay sync)\n *\n * @param {Object} startOpts - options for session start, same as .start()\n * @param {Function} onSessionSent - callback that will be called once session is fully sent\n * @returns methods to manipulate buffer:\n *\n * saveBuffer - to save it in localStorage\n *\n * getBuffer - returns current buffer\n *\n * setBuffer - replaces current buffer with given\n * */\n startOfflineRecording(startOpts: Partial<StartOptions>, onSessionSent: () => void) {\n if (this.browserEnvCheck()) {\n if (this.app === null) {\n return Promise.reject('Tracker not initialized')\n }\n return this.app.offlineRecording(startOpts, onSessionSent)\n } else {\n return Promise.reject('Trying to start not in browser.')\n }\n }\n\n /**\n * Uploads the stored session buffer to backend\n * @returns promise that resolves once messages are loaded, it has to be awaited\n * so the session can be uploaded properly\n * @resolve - if messages were loaded into service worker successfully\n * @reject {string} - error message\n * */\n uploadOfflineRecording() {\n if (this.app === null) {\n return\n }\n return this.app.uploadOfflineRecording()\n }\n\n stop(): string | undefined {\n if (this.app === null) {\n return\n }\n this.app.stop()\n return this.app.session.getSessionHash()\n }\n\n forceFlushBatch() {\n if (this.app === null) {\n return\n }\n this.app.forceFlushBatch()\n }\n\n getSessionToken(): string | null | undefined {\n if (this.app === null) {\n return null\n }\n return this.app.getSessionToken()\n }\n\n getSessionInfo(): SessionInfo | null {\n if (this.app === null) {\n return null\n }\n return this.app.session.getInfo()\n }\n\n getSessionID(): string | null | undefined {\n if (this.app === null) {\n return null\n }\n return this.app.getSessionID()\n }\n\n getTabId() {\n if (this.app === null) {\n return null\n }\n return this.app.getTabId()\n }\n\n getUxId() {\n if (this.app === null) {\n return null\n }\n return this.app.getUxtId()\n }\n\n sessionID(): string | null | undefined {\n deprecationWarn(\"'sessionID' method\", \"'getSessionID' method\", '/')\n return this.getSessionID()\n }\n\n getSessionURL(options?: { withCurrentTime?: boolean }): string | undefined {\n if (this.app === null) {\n return undefined\n }\n return this.app.getSessionURL(options)\n }\n\n setUserID(id: string): void {\n if (typeof id === 'string' && this.app !== null) {\n this.app.session.setUserID(id)\n }\n }\n\n userID(id: string): void {\n deprecationWarn(\"'userID' method\", \"'setUserID' method\", '/')\n this.setUserID(id)\n }\n\n setUserAnonymousID(id: string): void {\n if (typeof id === 'string' && this.app !== null) {\n this.app.send(UserAnonymousID(id))\n }\n }\n\n userAnonymousID(id: string): void {\n deprecationWarn(\"'userAnonymousID' method\", \"'setUserAnonymousID' method\", '/')\n this.setUserAnonymousID(id)\n }\n\n setMetadata(key: string, value: string): void {\n if (typeof key === 'string' && typeof value === 'string' && this.app !== null) {\n this.app.session.setMetadata(key, value)\n }\n }\n\n metadata(key: string, value: string): void {\n deprecationWarn(\"'metadata' method\", \"'setMetadata' method\", '/')\n this.setMetadata(key, value)\n }\n\n event(key: string, payload: any = null, issue = false): void {\n if (typeof key === 'string' && this.app !== null) {\n if (issue) {\n return this.issue(key, payload)\n } else {\n try {\n payload = JSON.stringify(payload)\n } catch (e) {\n return\n }\n this.app.send(CustomEvent(key, payload))\n }\n }\n }\n\n issue(key: string, payload: any = null): void {\n if (typeof key === 'string' && this.app !== null) {\n try {\n payload = JSON.stringify(payload)\n } catch (e) {\n return\n }\n this.app.send(CustomIssue(key, payload))\n }\n }\n\n handleError = (\n e: Error | ErrorEvent | PromiseRejectionEvent,\n metadata: Record<string, any> = {},\n ) => {\n if (this.app === null) {\n return\n }\n if (e instanceof Error) {\n const msg = getExceptionMessage(e, [], metadata)\n this.app.send(msg)\n } else if (\n e instanceof ErrorEvent ||\n ('PromiseRejectionEvent' in window && e instanceof PromiseRejectionEvent)\n ) {\n const msg = getExceptionMessageFromEvent(e, undefined, metadata)\n if (msg != null) {\n this.app.send(msg)\n }\n }\n }\n}\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":["../../src/main/index.ts"],"sourcesContent":["import App, { DEFAULT_INGEST_POINT } from './app/index.js'\n\nexport { default as App } from './app/index.js'\n\nimport { UserAnonymousID, CustomEvent, CustomIssue } from './app/messages.gen.js'\nimport * as _Messages from './app/messages.gen.js'\n\nexport const Messages = _Messages\nexport { SanitizeLevel } from './app/sanitizer.js'\n\nimport Connection from './modules/connection.js'\nimport Console from './modules/console.js'\nimport Exception, {\n getExceptionMessageFromEvent,\n getExceptionMessage,\n} from './modules/exception.js'\nimport Img from './modules/img.js'\nimport Input from './modules/input.js'\nimport Mouse from './modules/mouse.js'\nimport Timing from './modules/timing.js'\nimport Performance from './modules/performance.js'\nimport Scroll from './modules/scroll.js'\nimport Viewport from './modules/viewport.js'\nimport CSSRules from './modules/cssrules.js'\nimport Focus from './modules/focus.js'\nimport Fonts from './modules/fonts.js'\nimport Network from './modules/network.js'\nimport ConstructedStyleSheets from './modules/constructedStyleSheets.js'\nimport Selection from './modules/selection.js'\nimport Tabs from './modules/tabs.js'\n\nimport { IN_BROWSER, deprecationWarn, DOCS_HOST, inIframe } from './utils.js'\nimport FeatureFlags, { IFeatureFlag } from './modules/featureFlags.js'\nimport type { Options as AppOptions } from './app/index.js'\nimport type { Options as ConsoleOptions } from './modules/console.js'\nimport type { Options as ExceptionOptions } from './modules/exception.js'\nimport type { Options as InputOptions } from './modules/input.js'\nimport type { Options as PerformanceOptions } from './modules/performance.js'\nimport type { Options as TimingOptions } from './modules/timing.js'\nimport type { Options as NetworkOptions } from './modules/network.js'\nimport type { MouseHandlerOptions } from './modules/mouse.js'\nimport type { SessionInfo } from './app/session.js'\n\nimport type { StartOptions } from './app/index.js'\n//TODO: unique options init\nimport type { StartPromiseReturn } from './app/index.js'\n\nexport type Options = Partial<\n AppOptions & ConsoleOptions & ExceptionOptions & InputOptions & PerformanceOptions & TimingOptions\n> & {\n projectID?: number // For the back compatibility only (deprecated)\n projectKey: string\n sessionToken?: string\n respectDoNotTrack?: boolean\n autoResetOnWindowOpen?: boolean\n resetTabOnWindowOpen?: boolean\n network?: Partial<NetworkOptions>\n mouse?: Partial<MouseHandlerOptions>\n flags?: {\n onFlagsLoad?: (flags: IFeatureFlag[]) => void\n }\n // dev only\n __DISABLE_SECURE_MODE?: boolean\n}\n\nconst DOCS_SETUP = '/installation/javascript-sdk'\n\nfunction processOptions(obj: any): obj is Options {\n if (obj == null) {\n console.error(\n `OpenReplay: invalid options argument type. Please, check documentation on ${DOCS_HOST}${DOCS_SETUP}`,\n )\n return false\n }\n if (typeof obj.projectKey !== 'string') {\n if (typeof obj.projectKey !== 'number') {\n if (typeof obj.projectID !== 'number') {\n // Back compatability\n console.error(\n `OpenReplay: projectKey is missing or wrong type (string is expected). Please, check ${DOCS_HOST}${DOCS_SETUP} for more information.`,\n )\n return false\n } else {\n obj.projectKey = obj.projectID.toString()\n deprecationWarn('`projectID` option', '`projectKey` option', DOCS_SETUP)\n }\n } else {\n console.warn('OpenReplay: projectKey is expected to have a string type.')\n obj.projectKey = obj.projectKey.toString()\n }\n }\n if (obj.sessionToken != null) {\n deprecationWarn('`sessionToken` option', '`sessionHash` start() option', '/')\n }\n return true\n}\n\nexport default class API {\n public featureFlags: FeatureFlags\n\n private readonly app: App | null = null\n private readonly crossdomainMode: boolean = false\n\n constructor(private readonly options: Options) {\n this.crossdomainMode = Boolean(inIframe() && options.crossdomain?.enabled)\n if (!IN_BROWSER || !processOptions(options)) {\n return\n }\n if (\n (window as any).__OPENREPLAY__ ||\n (!this.crossdomainMode && inIframe() && (window.top as any)?.__OPENREPLAY__)\n ) {\n console.error('OpenReplay: one tracker instance has been initialised already')\n return\n }\n if (!options.__DISABLE_SECURE_MODE && location.protocol !== 'https:') {\n console.error(\n 'OpenReplay: Your website must be publicly accessible and running on SSL in order for OpenReplay to properly capture and replay the user session. You can disable this check by setting `__DISABLE_SECURE_MODE` option to `true` if you are testing in localhost. Keep in mind, that asset files on a local machine are not available to the outside world. This might affect tracking if you use css files.',\n )\n return\n }\n options.projectKey = 'LGpHB5UmZNJI2UuPPOFO' // injectedTest\n options.ingestPoint = 'https://foss.openreplay.com/ingest'\n const doNotTrack = this.checkDoNotTrack()\n const failReason: string[] = []\n const conditions: string[] = [\n 'Map',\n 'Set',\n 'MutationObserver',\n 'performance',\n 'timing',\n 'startsWith',\n 'Blob',\n 'Worker',\n ]\n\n if (doNotTrack) {\n failReason.push('doNotTrack')\n } else {\n for (const condition of conditions) {\n if (condition === 'timing') {\n if ('performance' in window && !(condition in performance)) {\n failReason.push(condition)\n break\n }\n } else if (condition === 'startsWith') {\n if (!(condition in String.prototype)) {\n failReason.push(condition)\n break\n }\n } else {\n if (!(condition in window)) {\n failReason.push(condition)\n break\n }\n }\n }\n }\n if (failReason.length > 0) {\n const missingApi = failReason.join(',')\n console.error(\n `OpenReplay: browser doesn't support API required for tracking or doNotTrack is set to 1. Reason: ${missingApi}`,\n )\n this.signalStartIssue('missing_api', failReason)\n return\n }\n\n const app = new App(\n options.projectKey,\n options.sessionToken,\n options,\n this.signalStartIssue,\n this.crossdomainMode,\n )\n this.app = app\n if (!this.crossdomainMode) {\n // no need to send iframe viewport data since its a node for us\n Viewport(app)\n // calculated in main window\n Connection(app)\n // while we can calculate it here, trying to compute it for all parts is hard\n Performance(app, options)\n // no tabs in iframes yet\n Tabs(app)\n }\n Mouse(app, options.mouse)\n // inside iframe, we ignore viewport scroll\n Scroll(app, this.crossdomainMode)\n CSSRules(app)\n ConstructedStyleSheets(app)\n Console(app, options)\n Exception(app, options)\n Img(app)\n Input(app, options)\n Timing(app, options)\n Focus(app)\n Fonts(app)\n Network(app, options.network)\n Selection(app)\n ;(window as any).__OPENREPLAY__ = this\n\n if (options.flags && options.flags.onFlagsLoad) {\n this.onFlagsLoad(options.flags.onFlagsLoad)\n }\n const wOpen = window.open\n if (options.autoResetOnWindowOpen || options.resetTabOnWindowOpen) {\n app.attachStartCallback(() => {\n const tabId = app.getTabId()\n const sessStorage = app.sessionStorage ?? window.sessionStorage\n window.open = function (...args) {\n if (options.autoResetOnWindowOpen) {\n app.resetNextPageSession(true)\n }\n if (options.resetTabOnWindowOpen) {\n sessStorage.removeItem(options.session_tabid_key || '__openreplay_tabid')\n }\n app.resetNextPageSession(false)\n sessStorage.setItem(options.session_tabid_key || '__openreplay_tabid', tabId)\n return wOpen.call(window, ...args)\n }\n })\n app.attachStopCallback(() => {\n window.open = wOpen\n })\n }\n }\n\n checkDoNotTrack = () => {\n return (\n this.options.respectDoNotTrack &&\n (navigator.doNotTrack == '1' ||\n // @ts-ignore\n window.doNotTrack == '1')\n )\n }\n\n signalStartIssue = (reason: string, missingApi: string[]) => {\n const doNotTrack = this.checkDoNotTrack()\n const req = new XMLHttpRequest()\n const orig = this.options.ingestPoint || DEFAULT_INGEST_POINT\n req.open('POST', orig + '/v1/web/not-started')\n req.send(\n JSON.stringify({\n trackerVersion: 'TRACKER_VERSION',\n projectKey: this.options.projectKey,\n doNotTrack,\n reason: missingApi.length ? `missing api: ${missingApi.join(',')}` : reason,\n }),\n )\n }\n\n isFlagEnabled(flagName: string): boolean {\n return this.featureFlags.isFlagEnabled(flagName)\n }\n\n onFlagsLoad(callback: (flags: IFeatureFlag[]) => void): void {\n this.app?.featureFlags.onFlagsLoad(callback)\n }\n\n clearPersistFlags() {\n this.app?.featureFlags.clearPersistFlags()\n }\n\n reloadFlags() {\n return this.app?.featureFlags.reloadFlags()\n }\n\n getFeatureFlag(flagName: string): IFeatureFlag | undefined {\n return this.app?.featureFlags.getFeatureFlag(flagName)\n }\n\n getAllFeatureFlags() {\n return this.app?.featureFlags.flags\n }\n\n public restartCanvasTracking = () => {\n if (this.app === null) {\n return\n }\n this.app.restartCanvasTracking()\n }\n\n use<T>(fn: (app: App | null, options?: Options) => T): T {\n return fn(this.app, this.options)\n }\n\n isActive(): boolean {\n if (this.app === null) {\n return false\n }\n return this.app.active()\n }\n\n /**\n * Creates a named hook that expects event name, data string and msg direction (up/down),\n * it will skip any message bigger than 5 mb or event name bigger than 255 symbols\n * msg direction is \"down\" (incoming) by default\n *\n * @returns {(msgType: string, data: string, dir: 'up' | 'down') => void}\n * */\n trackWs(channelName: string) {\n if (this.app === null) {\n return\n }\n return this.app.trackWs(channelName)\n }\n\n start(startOpts?: Partial<StartOptions>): Promise<StartPromiseReturn> {\n if (this.browserEnvCheck()) {\n if (this.app === null) {\n return Promise.reject(\"Browser doesn't support required api, or doNotTrack is active.\")\n }\n return this.app.start(startOpts)\n } else {\n return Promise.reject('Trying to start not in browser.')\n }\n }\n\n browserEnvCheck() {\n if (!IN_BROWSER) {\n console.error(\n `OpenReplay: you are trying to start Tracker on a node.js environment. If you want to use OpenReplay with SSR, please, use componentDidMount or useEffect API for placing the \\`tracker.start()\\` line. Check documentation on ${DOCS_HOST}${DOCS_SETUP}`,\n )\n return false\n }\n return true\n }\n\n /**\n * start buffering messages without starting the actual session, which gives user 30 seconds to \"activate\" and record\n * session by calling start() on conditional trigger and we will then send buffered batch, so it won't get lost\n * */\n coldStart(startOpts?: Partial<StartOptions>, conditional?: boolean) {\n if (this.browserEnvCheck()) {\n if (this.app === null) {\n return Promise.reject('Tracker not initialized')\n }\n void this.app.coldStart(startOpts, conditional)\n } else {\n return Promise.reject('Trying to start not in browser.')\n }\n }\n\n /**\n * Starts offline session recording. Keep in mind that only user device time will be used for timestamps.\n * (no backend delay sync)\n *\n * @param {Object} startOpts - options for session start, same as .start()\n * @param {Function} onSessionSent - callback that will be called once session is fully sent\n * @returns methods to manipulate buffer:\n *\n * saveBuffer - to save it in localStorage\n *\n * getBuffer - returns current buffer\n *\n * setBuffer - replaces current buffer with given\n * */\n startOfflineRecording(startOpts: Partial<StartOptions>, onSessionSent: () => void) {\n if (this.browserEnvCheck()) {\n if (this.app === null) {\n return Promise.reject('Tracker not initialized')\n }\n return this.app.offlineRecording(startOpts, onSessionSent)\n } else {\n return Promise.reject('Trying to start not in browser.')\n }\n }\n\n /**\n * Uploads the stored session buffer to backend\n * @returns promise that resolves once messages are loaded, it has to be awaited\n * so the session can be uploaded properly\n * @resolve - if messages were loaded into service worker successfully\n * @reject {string} - error message\n * */\n uploadOfflineRecording() {\n if (this.app === null) {\n return\n }\n return this.app.uploadOfflineRecording()\n }\n\n stop(): string | undefined {\n if (this.app === null) {\n return\n }\n this.app.stop()\n return this.app.session.getSessionHash()\n }\n\n forceFlushBatch() {\n if (this.app === null) {\n return\n }\n this.app.forceFlushBatch()\n }\n\n getSessionToken(): string | null | undefined {\n if (this.app === null) {\n return null\n }\n return this.app.getSessionToken()\n }\n\n getSessionInfo(): SessionInfo | null {\n if (this.app === null) {\n return null\n }\n return this.app.session.getInfo()\n }\n\n getSessionID(): string | null | undefined {\n if (this.app === null) {\n return null\n }\n return this.app.getSessionID()\n }\n\n getTabId() {\n if (this.app === null) {\n return null\n }\n return this.app.getTabId()\n }\n\n getUxId() {\n if (this.app === null) {\n return null\n }\n return this.app.getUxtId()\n }\n\n sessionID(): string | null | undefined {\n deprecationWarn(\"'sessionID' method\", \"'getSessionID' method\", '/')\n return this.getSessionID()\n }\n\n getSessionURL(options?: { withCurrentTime?: boolean }): string | undefined {\n if (this.app === null) {\n return undefined\n }\n return this.app.getSessionURL(options)\n }\n\n setUserID(id: string): void {\n if (typeof id === 'string' && this.app !== null) {\n this.app.session.setUserID(id)\n }\n }\n\n userID(id: string): void {\n deprecationWarn(\"'userID' method\", \"'setUserID' method\", '/')\n this.setUserID(id)\n }\n\n setUserAnonymousID(id: string): void {\n if (typeof id === 'string' && this.app !== null) {\n this.app.send(UserAnonymousID(id))\n }\n }\n\n userAnonymousID(id: string): void {\n deprecationWarn(\"'userAnonymousID' method\", \"'setUserAnonymousID' method\", '/')\n this.setUserAnonymousID(id)\n }\n\n setMetadata(key: string, value: string): void {\n if (typeof key === 'string' && typeof value === 'string' && this.app !== null) {\n this.app.session.setMetadata(key, value)\n }\n }\n\n metadata(key: string, value: string): void {\n deprecationWarn(\"'metadata' method\", \"'setMetadata' method\", '/')\n this.setMetadata(key, value)\n }\n\n event(key: string, payload: any = null, issue = false): void {\n if (typeof key === 'string' && this.app !== null) {\n if (issue) {\n return this.issue(key, payload)\n } else {\n try {\n payload = JSON.stringify(payload)\n } catch (e) {\n return\n }\n this.app.send(CustomEvent(key, payload))\n }\n }\n }\n\n issue(key: string, payload: any = null): void {\n if (typeof key === 'string' && this.app !== null) {\n try {\n payload = JSON.stringify(payload)\n } catch (e) {\n return\n }\n this.app.send(CustomIssue(key, payload))\n }\n }\n\n handleError = (\n e: Error | ErrorEvent | PromiseRejectionEvent,\n metadata: Record<string, any> = {},\n ) => {\n if (this.app === null) {\n return\n }\n if (e instanceof Error) {\n const msg = getExceptionMessage(e, [], metadata)\n this.app.send(msg)\n } else if (\n e instanceof ErrorEvent ||\n ('PromiseRejectionEvent' in window && e instanceof PromiseRejectionEvent)\n ) {\n const msg = getExceptionMessageFromEvent(e, undefined, metadata)\n if (msg != null) {\n this.app.send(msg)\n }\n }\n }\n}\n"],"names":[],"mappings":";;;;;AAAA,MAA0D,UAAA,GAAA,OAAA,CAAA,YAAA,CAAA,OAAA,CAAA,gBAAA,CAAA,CAAA,CAAA;AAE1D,IAA+C,UAAA,GAAA,OAAA,CAAA,gBAAA,CAAA,CAAA;AAAtC,MAAA,CAAA,cAAA,CAAA,OAAA,EAAA,KAAA,EAAA,EAAA,UAAA,EAAA,IAAA,EAAA,GAAA,EAAA,YAAA,EAAA,OAAA,OAAA,CAAA,eAAA,CAAA,UAAA,CAAA,CAAA,OAAO,CAAO,EAAA,EAAA,CAAA,CAAA;AAEvB,MAAiF,iBAAA,GAAA,OAAA,CAAA,uBAAA,CAAA,CAAA;AACjF,MAAkD,SAAA,GAAA,OAAA,CAAA,YAAA,CAAA,OAAA,CAAA,uBAAA,CAAA,CAAA,CAAA;AAErC,OAAA,CAAA,QAAQ,GAAG,SAAS,CAAA;AACjC,IAAkD,cAAA,GAAA,OAAA,CAAA,oBAAA,CAAA,CAAA;AAAzC,MAAA,CAAA,cAAA,CAAA,OAAA,EAAA,eAAA,EAAA,EAAA,UAAA,EAAA,IAAA,EAAA,GAAA,EAAA,YAAA,EAAA,OAAA,cAAA,CAAA,aAAa,CAAA,EAAA,EAAA,CAAA,CAAA;AAEtB,MAAgD,eAAA,GAAA,OAAA,CAAA,eAAA,CAAA,OAAA,CAAA,yBAAA,CAAA,CAAA,CAAA;AAChD,MAA0C,YAAA,GAAA,OAAA,CAAA,eAAA,CAAA,OAAA,CAAA,sBAAA,CAAA,CAAA,CAAA;AAC1C,MAG+B,cAAA,GAAA,OAAA,CAAA,YAAA,CAAA,OAAA,CAAA,wBAAA,CAAA,CAAA,CAAA;AAC/B,MAAkC,QAAA,GAAA,OAAA,CAAA,eAAA,CAAA,OAAA,CAAA,kBAAA,CAAA,CAAA,CAAA;AAClC,MAAsC,UAAA,GAAA,OAAA,CAAA,eAAA,CAAA,OAAA,CAAA,oBAAA,CAAA,CAAA,CAAA;AACtC,MAAsC,UAAA,GAAA,OAAA,CAAA,eAAA,CAAA,OAAA,CAAA,oBAAA,CAAA,CAAA,CAAA;AACtC,MAAwC,WAAA,GAAA,OAAA,CAAA,eAAA,CAAA,OAAA,CAAA,qBAAA,CAAA,CAAA,CAAA;AACxC,MAAkD,gBAAA,GAAA,OAAA,CAAA,eAAA,CAAA,OAAA,CAAA,0BAAA,CAAA,CAAA,CAAA;AAClD,MAAwC,WAAA,GAAA,OAAA,CAAA,eAAA,CAAA,OAAA,CAAA,qBAAA,CAAA,CAAA,CAAA;AACxC,MAA4C,aAAA,GAAA,OAAA,CAAA,eAAA,CAAA,OAAA,CAAA,uBAAA,CAAA,CAAA,CAAA;AAC5C,MAA4C,aAAA,GAAA,OAAA,CAAA,eAAA,CAAA,OAAA,CAAA,uBAAA,CAAA,CAAA,CAAA;AAC5C,MAAsC,UAAA,GAAA,OAAA,CAAA,eAAA,CAAA,OAAA,CAAA,oBAAA,CAAA,CAAA,CAAA;AACtC,MAAsC,UAAA,GAAA,OAAA,CAAA,eAAA,CAAA,OAAA,CAAA,oBAAA,CAAA,CAAA,CAAA;AACtC,MAA0C,YAAA,GAAA,OAAA,CAAA,eAAA,CAAA,OAAA,CAAA,sBAAA,CAAA,CAAA,CAAA;AAC1C,MAAwE,2BAAA,GAAA,OAAA,CAAA,eAAA,CAAA,OAAA,CAAA,qCAAA,CAAA,CAAA,CAAA;AACxE,MAA8C,cAAA,GAAA,OAAA,CAAA,eAAA,CAAA,OAAA,CAAA,wBAAA,CAAA,CAAA,CAAA;AAC9C,MAAoC,SAAA,GAAA,OAAA,CAAA,eAAA,CAAA,OAAA,CAAA,mBAAA,CAAA,CAAA,CAAA;AAEpC,MAA6E,UAAA,GAAA,OAAA,CAAA,YAAA,CAAA,CAAA;AAkC7E,MAAM,UAAU,GAAG,8BAA8B,CAAA;AAEjD,SAAS,cAAc,CAAC,GAAQ,EAAA;AAC9B,IAAA,IAAI,GAAG,IAAI,IAAI,EAAE;QACf,OAAO,CAAC,KAAK,CACX,CAAA,0EAAA,EAA6E,oBAAS,CAAG,EAAA,UAAU,CAAE,CAAA,CACtG,CAAA;AACD,QAAA,OAAO,KAAK,CAAA;KACd;AACA,IAAA,IAAI,OAAO,GAAG,CAAC,UAAU,KAAK,QAAQ,EAAE;AACtC,QAAA,IAAI,OAAO,GAAG,CAAC,UAAU,KAAK,QAAQ,EAAE;AACtC,YAAA,IAAI,OAAO,GAAG,CAAC,SAAS,KAAK,QAAQ,EAAE;;gBAErC,OAAO,CAAC,KAAK,CACX,CAAA,oFAAA,EAAuF,oBAAS,CAAG,EAAA,UAAU,CAAwB,sBAAA,CAAA,CACtI,CAAA;AACD,gBAAA,OAAO,KAAK,CAAA;aACd;iBAAO;gBACL,GAAG,CAAC,UAAU,GAAG,GAAG,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAA;gBACzC,IAAA,UAAA,CAAA,eAAe,EAAC,oBAAoB,EAAE,qBAAqB,EAAE,UAAU,CAAC,CAAA;aAC1E;SACF;aAAO;AACL,YAAA,OAAO,CAAC,IAAI,CAAC,2DAA2D,CAAC,CAAA;YACzE,GAAG,CAAC,UAAU,GAAG,GAAG,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAA;SAC5C;KACF;AACA,IAAA,IAAI,GAAG,CAAC,YAAY,IAAI,IAAI,EAAE;QAC5B,IAAA,UAAA,CAAA,eAAe,EAAC,uBAAuB,EAAE,8BAA8B,EAAE,GAAG,CAAC,CAAA;KAC/E;AACA,IAAA,OAAO,IAAI,CAAA;AACb,CAAA;AAEA,MAAqB,GAAG,CAAA;AAMtB,IAAA,WAAA,CAA6B,OAAgB,EAAA;QAAhB,IAAO,CAAA,OAAA,GAAP,OAAO,CAAA;QAHnB,IAAG,CAAA,GAAA,GAAe,IAAI,CAAA;QACtB,IAAe,CAAA,eAAA,GAAY,KAAK,CAAA;QA8HjD,IAAe,CAAA,eAAA,GAAG,MAAK;AACrB,YAAA,QACE,IAAI,CAAC,OAAO,CAAC,iBAAiB;AAC9B,iBAAC,SAAS,CAAC,UAAU,IAAI,GAAG;;AAE1B,oBAAA,MAAM,CAAC,UAAU,IAAI,GAAG,CAAC,EAC5B;AACH,SAAC,CAAA;AAED,QAAA,IAAA,CAAA,gBAAgB,GAAG,CAAC,MAAc,EAAE,UAAoB,KAAI;AAC1D,YAAA,MAAM,UAAU,GAAG,IAAI,CAAC,eAAe,EAAE,CAAA;AACzC,YAAA,MAAM,GAAG,GAAG,IAAI,cAAc,EAAE,CAAA;YAChC,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,IAAI,UAAA,CAAA,oBAAoB,CAAA;YAC7D,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,GAAG,qBAAqB,CAAC,CAAA;AAC9C,YAAA,GAAG,CAAC,IAAI,CACN,IAAI,CAAC,SAAS,CAAC;AACb,gBAAA,cAAc,EAAE,SAAiB;AACjC,gBAAA,UAAU,EAAE,IAAI,CAAC,OAAO,CAAC,UAAU;gBACnC,UAAU;AACV,gBAAA,MAAM,EAAE,UAAU,CAAC,MAAM,GAAG,CAAgB,aAAA,EAAA,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,MAAM;AAC5E,aAAA,CAAC,CACH,CAAA;AACH,SAAC,CAAA;QA0BM,IAAqB,CAAA,qBAAA,GAAG,MAAK;AAClC,YAAA,IAAI,IAAI,CAAC,GAAG,KAAK,IAAI,EAAE;gBACrB,OAAM;aACR;AACA,YAAA,IAAI,CAAC,GAAG,CAAC,qBAAqB,EAAE,CAAA;AAClC,SAAC,CAAA;AA+ND,QAAA,IAAA,CAAA,WAAW,GAAG,CACZ,CAA6C,EAC7C,QAAgC,GAAA,EAAE,KAChC;AACF,YAAA,IAAI,IAAI,CAAC,GAAG,KAAK,IAAI,EAAE;gBACrB,OAAM;aACR;AACA,YAAA,IAAI,CAAC,YAAY,KAAK,EAAE;gBACtB,MAAM,GAAG,GAAG,IAAA,cAAmB,CAAA,mBAAA,EAAC,CAAC,EAAE,EAAE,EAAE,QAAQ,CAAC,CAAA;AAChD,gBAAA,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;aACpB;iBAAO,IACL,CAAC,YAAY,UAAU;iBACtB,uBAAuB,IAAI,MAAM,IAAI,CAAC,YAAY,qBAAqB,CAAC,EACzE;gBACA,MAAM,GAAG,GAAG,IAAA,cAA4B,CAAA,4BAAA,EAAC,CAAC,EAAE,SAAS,EAAE,QAAQ,CAAC,CAAA;AAChE,gBAAA,IAAI,GAAG,IAAI,IAAI,EAAE;AACf,oBAAA,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;iBACpB;aACF;AACF,SAAC,CAAA;AAlaC,QAAA,IAAI,CAAC,eAAe,GAAG,OAAO,CAAC,IAAA,UAAA,CAAA,QAAQ,GAAE,IAAI,OAAO,CAAC,WAAW,EAAE,OAAO,CAAC,CAAA;QAC1E,IAAI,CAAC,qBAAU,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE;YAC3C,OAAM;SACR;QACA,IACG,MAAc,CAAC,cAAc;AAC9B,aAAC,CAAC,IAAI,CAAC,eAAe,IAAI,IAAA,UAAQ,CAAA,QAAA,GAAE,IAAK,MAAM,CAAC,GAAW,EAAE,cAAc,CAAC,EAC5E;AACA,YAAA,OAAO,CAAC,KAAK,CAAC,+DAA+D,CAAC,CAAA;YAC9E,OAAM;SACR;QACA,IAAI,CAAC,OAAO,CAAC,qBAAqB,IAAI,QAAQ,CAAC,QAAQ,KAAK,QAAQ,EAAE;AACpE,YAAA,OAAO,CAAC,KAAK,CACX,6YAA6Y,CAC9Y,CAAA;YACD,OAAM;SACR;AACA,QAAA,OAAO,CAAC,UAAU,GAAG,sBAAsB,CAAA;AAC3C,QAAA,OAAO,CAAC,WAAW,GAAG,oCAAoC,CAAA;AAC1D,QAAA,MAAM,UAAU,GAAG,IAAI,CAAC,eAAe,EAAE,CAAA;QACzC,MAAM,UAAU,GAAa,EAAE,CAAA;AAC/B,QAAA,MAAM,UAAU,GAAa;YAC3B,KAAK;YACL,KAAK;YACL,kBAAkB;YAClB,aAAa;YACb,QAAQ;YACR,YAAY;YACZ,MAAM;YACN,QAAQ;SACT,CAAA;QAED,IAAI,UAAU,EAAE;AACd,YAAA,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,CAAA;SAC/B;aAAO;AACL,YAAA,KAAK,MAAM,SAAS,IAAI,UAAU,EAAE;AAClC,gBAAA,IAAI,SAAS,KAAK,QAAQ,EAAE;oBAC1B,IAAI,aAAa,IAAI,MAAM,IAAI,EAAE,SAAS,IAAI,WAAW,CAAC,EAAE;AAC1D,wBAAA,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;wBAC1B,MAAK;qBACP;iBACF;AAAO,qBAAA,IAAI,SAAS,KAAK,YAAY,EAAE;oBACrC,IAAI,EAAE,SAAS,IAAI,MAAM,CAAC,SAAS,CAAC,EAAE;AACpC,wBAAA,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;wBAC1B,MAAK;qBACP;iBACF;qBAAO;AACL,oBAAA,IAAI,EAAE,SAAS,IAAI,MAAM,CAAC,EAAE;AAC1B,wBAAA,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;wBAC1B,MAAK;qBACP;iBACF;aACF;SACF;AACA,QAAA,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE;YACzB,MAAM,UAAU,GAAG,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;AACvC,YAAA,OAAO,CAAC,KAAK,CACX,oGAAoG,UAAU,CAAA,CAAE,CACjH,CAAA;AACD,YAAA,IAAI,CAAC,gBAAgB,CAAC,aAAa,EAAE,UAAU,CAAC,CAAA;YAChD,OAAM;SACR;QAEA,MAAM,GAAG,GAAG,IAAI,UAAA,CAAA,OAAG,CACjB,OAAO,CAAC,UAAU,EAClB,OAAO,CAAC,YAAY,EACpB,OAAO,EACP,IAAI,CAAC,gBAAgB,EACrB,IAAI,CAAC,eAAe,CACrB,CAAA;AACD,QAAA,IAAI,CAAC,GAAG,GAAG,GAAG,CAAA;AACd,QAAA,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE;;AAEzB,YAAA,IAAA,aAAQ,CAAA,OAAA,EAAC,GAAG,CAAC,CAAA;;AAEb,YAAA,IAAA,eAAU,CAAA,OAAA,EAAC,GAAG,CAAC,CAAA;;AAEf,YAAA,IAAA,wBAAW,EAAC,GAAG,EAAE,OAAO,CAAC,CAAA;;AAEzB,YAAA,IAAA,SAAI,CAAA,OAAA,EAAC,GAAG,CAAC,CAAA;SACX;QACA,IAAA,UAAA,CAAA,OAAK,EAAC,GAAG,EAAE,OAAO,CAAC,KAAK,CAAC,CAAA;;QAEzB,IAAA,WAAA,CAAA,OAAM,EAAC,GAAG,EAAE,IAAI,CAAC,eAAe,CAAC,CAAA;AACjC,QAAA,IAAA,aAAQ,CAAA,OAAA,EAAC,GAAG,CAAC,CAAA;AACb,QAAA,IAAA,2BAAsB,CAAA,OAAA,EAAC,GAAG,CAAC,CAAA;AAC3B,QAAA,IAAA,oBAAO,EAAC,GAAG,EAAE,OAAO,CAAC,CAAA;AACrB,QAAA,IAAA,sBAAS,EAAC,GAAG,EAAE,OAAO,CAAC,CAAA;AACvB,QAAA,IAAA,QAAG,CAAA,OAAA,EAAC,GAAG,CAAC,CAAA;AACR,QAAA,IAAA,kBAAK,EAAC,GAAG,EAAE,OAAO,CAAC,CAAA;AACnB,QAAA,IAAA,mBAAM,EAAC,GAAG,EAAE,OAAO,CAAC,CAAA;AACpB,QAAA,IAAA,UAAK,CAAA,OAAA,EAAC,GAAG,CAAC,CAAA;AACV,QAAA,IAAA,UAAK,CAAA,OAAA,EAAC,GAAG,CAAC,CAAA;QACV,IAAA,YAAA,CAAA,OAAO,EAAC,GAAG,EAAE,OAAO,CAAC,OAAO,CAAC,CAAA;AAC7B,QAAA,IAAA,cAAS,CAAA,OAAA,EAAC,GAAG,CAAC,CAAA;AACZ,QAAA,MAAc,CAAC,cAAc,GAAG,IAAI,CAAA;QAEtC,IAAI,OAAO,CAAC,KAAK,IAAI,OAAO,CAAC,KAAK,CAAC,WAAW,EAAE;YAC9C,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,CAAA;SAC7C;AACA,QAAA,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAA;QACzB,IAAI,OAAO,CAAC,qBAAqB,IAAI,OAAO,CAAC,oBAAoB,EAAE;AACjE,YAAA,GAAG,CAAC,mBAAmB,CAAC,MAAK;AAC3B,gBAAA,MAAM,KAAK,GAAG,GAAG,CAAC,QAAQ,EAAE,CAAA;gBAC5B,MAAM,WAAW,GAAG,GAAG,CAAC,cAAc,IAAI,MAAM,CAAC,cAAc,CAAA;AAC/D,gBAAA,MAAM,CAAC,IAAI,GAAG,UAAU,GAAG,IAAI,EAAA;AAC7B,oBAAA,IAAI,OAAO,CAAC,qBAAqB,EAAE;AACjC,wBAAA,GAAG,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAA;qBAChC;AACA,oBAAA,IAAI,OAAO,CAAC,oBAAoB,EAAE;wBAChC,WAAW,CAAC,UAAU,CAAC,OAAO,CAAC,iBAAiB,IAAI,oBAAoB,CAAC,CAAA;qBAC3E;AACA,oBAAA,GAAG,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAA;oBAC/B,WAAW,CAAC,OAAO,CAAC,OAAO,CAAC,iBAAiB,IAAI,oBAAoB,EAAE,KAAK,CAAC,CAAA;oBAC7E,OAAO,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,CAAA;AACpC,iBAAC,CAAA;AACH,aAAC,CAAC,CAAA;AACF,YAAA,GAAG,CAAC,kBAAkB,CAAC,MAAK;AAC1B,gBAAA,MAAM,CAAC,IAAI,GAAG,KAAK,CAAA;AACrB,aAAC,CAAC,CAAA;SACJ;KACF;AA0BA,IAAA,aAAa,CAAC,QAAgB,EAAA;QAC5B,OAAO,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAA;KAClD;AAEA,IAAA,WAAW,CAAC,QAAyC,EAAA;QACnD,IAAI,CAAC,GAAG,EAAE,YAAY,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAA;KAC9C;IAEA,iBAAiB,GAAA;AACf,QAAA,IAAI,CAAC,GAAG,EAAE,YAAY,CAAC,iBAAiB,EAAE,CAAA;KAC5C;IAEA,WAAW,GAAA;QACT,OAAO,IAAI,CAAC,GAAG,EAAE,YAAY,CAAC,WAAW,EAAE,CAAA;KAC7C;AAEA,IAAA,cAAc,CAAC,QAAgB,EAAA;QAC7B,OAAO,IAAI,CAAC,GAAG,EAAE,YAAY,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAA;KACxD;IAEA,kBAAkB,GAAA;AAChB,QAAA,OAAO,IAAI,CAAC,GAAG,EAAE,YAAY,CAAC,KAAK,CAAA;KACrC;AASA,IAAA,GAAG,CAAI,EAA6C,EAAA;QAClD,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,CAAA;KACnC;IAEA,QAAQ,GAAA;AACN,QAAA,IAAI,IAAI,CAAC,GAAG,KAAK,IAAI,EAAE;AACrB,YAAA,OAAO,KAAK,CAAA;SACd;AACA,QAAA,OAAO,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,CAAA;KAC1B;AAEA;;;;;;AAMK;AACL,IAAA,OAAO,CAAC,WAAmB,EAAA;AACzB,QAAA,IAAI,IAAI,CAAC,GAAG,KAAK,IAAI,EAAE;YACrB,OAAM;SACR;QACA,OAAO,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,WAAW,CAAC,CAAA;KACtC;AAEA,IAAA,KAAK,CAAC,SAAiC,EAAA;AACrC,QAAA,IAAI,IAAI,CAAC,eAAe,EAAE,EAAE;AAC1B,YAAA,IAAI,IAAI,CAAC,GAAG,KAAK,IAAI,EAAE;AACrB,gBAAA,OAAO,OAAO,CAAC,MAAM,CAAC,gEAAgE,CAAC,CAAA;aACzF;YACA,OAAO,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,SAAS,CAAC,CAAA;SAClC;aAAO;AACL,YAAA,OAAO,OAAO,CAAC,MAAM,CAAC,iCAAiC,CAAC,CAAA;SAC1D;KACF;IAEA,eAAe,GAAA;QACb,IAAI,CAAC,UAAU,CAAA,UAAA,EAAE;YACf,OAAO,CAAC,KAAK,CACX,CAAA,8NAAA,EAAiO,oBAAS,CAAG,EAAA,UAAU,CAAE,CAAA,CAC1P,CAAA;AACD,YAAA,OAAO,KAAK,CAAA;SACd;AACA,QAAA,OAAO,IAAI,CAAA;KACb;AAEA;;;AAGK;IACL,SAAS,CAAC,SAAiC,EAAE,WAAqB,EAAA;AAChE,QAAA,IAAI,IAAI,CAAC,eAAe,EAAE,EAAE;AAC1B,YAAA,IAAI,IAAI,CAAC,GAAG,KAAK,IAAI,EAAE;AACrB,gBAAA,OAAO,OAAO,CAAC,MAAM,CAAC,yBAAyB,CAAC,CAAA;aAClD;YACA,KAAK,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,SAAS,EAAE,WAAW,CAAC,CAAA;SACjD;aAAO;AACL,YAAA,OAAO,OAAO,CAAC,MAAM,CAAC,iCAAiC,CAAC,CAAA;SAC1D;KACF;AAEA;;;;;;;;;;;;;AAaK;IACL,qBAAqB,CAAC,SAAgC,EAAE,aAAyB,EAAA;AAC/E,QAAA,IAAI,IAAI,CAAC,eAAe,EAAE,EAAE;AAC1B,YAAA,IAAI,IAAI,CAAC,GAAG,KAAK,IAAI,EAAE;AACrB,gBAAA,OAAO,OAAO,CAAC,MAAM,CAAC,yBAAyB,CAAC,CAAA;aAClD;YACA,OAAO,IAAI,CAAC,GAAG,CAAC,gBAAgB,CAAC,SAAS,EAAE,aAAa,CAAC,CAAA;SAC5D;aAAO;AACL,YAAA,OAAO,OAAO,CAAC,MAAM,CAAC,iCAAiC,CAAC,CAAA;SAC1D;KACF;AAEA;;;;;;AAMK;IACL,sBAAsB,GAAA;AACpB,QAAA,IAAI,IAAI,CAAC,GAAG,KAAK,IAAI,EAAE;YACrB,OAAM;SACR;AACA,QAAA,OAAO,IAAI,CAAC,GAAG,CAAC,sBAAsB,EAAE,CAAA;KAC1C;IAEA,IAAI,GAAA;AACF,QAAA,IAAI,IAAI,CAAC,GAAG,KAAK,IAAI,EAAE;YACrB,OAAM;SACR;AACA,QAAA,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,CAAA;QACf,OAAO,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,cAAc,EAAE,CAAA;KAC1C;IAEA,eAAe,GAAA;AACb,QAAA,IAAI,IAAI,CAAC,GAAG,KAAK,IAAI,EAAE;YACrB,OAAM;SACR;AACA,QAAA,IAAI,CAAC,GAAG,CAAC,eAAe,EAAE,CAAA;KAC5B;IAEA,eAAe,GAAA;AACb,QAAA,IAAI,IAAI,CAAC,GAAG,KAAK,IAAI,EAAE;AACrB,YAAA,OAAO,IAAI,CAAA;SACb;AACA,QAAA,OAAO,IAAI,CAAC,GAAG,CAAC,eAAe,EAAE,CAAA;KACnC;IAEA,cAAc,GAAA;AACZ,QAAA,IAAI,IAAI,CAAC,GAAG,KAAK,IAAI,EAAE;AACrB,YAAA,OAAO,IAAI,CAAA;SACb;QACA,OAAO,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,OAAO,EAAE,CAAA;KACnC;IAEA,YAAY,GAAA;AACV,QAAA,IAAI,IAAI,CAAC,GAAG,KAAK,IAAI,EAAE;AACrB,YAAA,OAAO,IAAI,CAAA;SACb;AACA,QAAA,OAAO,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAA;KAChC;IAEA,QAAQ,GAAA;AACN,QAAA,IAAI,IAAI,CAAC,GAAG,KAAK,IAAI,EAAE;AACrB,YAAA,OAAO,IAAI,CAAA;SACb;AACA,QAAA,OAAO,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAA;KAC5B;IAEA,OAAO,GAAA;AACL,QAAA,IAAI,IAAI,CAAC,GAAG,KAAK,IAAI,EAAE;AACrB,YAAA,OAAO,IAAI,CAAA;SACb;AACA,QAAA,OAAO,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAA;KAC5B;IAEA,SAAS,GAAA;QACP,IAAA,UAAA,CAAA,eAAe,EAAC,oBAAoB,EAAE,uBAAuB,EAAE,GAAG,CAAC,CAAA;AACnE,QAAA,OAAO,IAAI,CAAC,YAAY,EAAE,CAAA;KAC5B;AAEA,IAAA,aAAa,CAAC,OAAuC,EAAA;AACnD,QAAA,IAAI,IAAI,CAAC,GAAG,KAAK,IAAI,EAAE;AACrB,YAAA,OAAO,SAAS,CAAA;SAClB;QACA,OAAO,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,OAAO,CAAC,CAAA;KACxC;AAEA,IAAA,SAAS,CAAC,EAAU,EAAA;QAClB,IAAI,OAAO,EAAE,KAAK,QAAQ,IAAI,IAAI,CAAC,GAAG,KAAK,IAAI,EAAE;YAC/C,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC,CAAA;SAChC;KACF;AAEA,IAAA,MAAM,CAAC,EAAU,EAAA;QACf,IAAA,UAAA,CAAA,eAAe,EAAC,iBAAiB,EAAE,oBAAoB,EAAE,GAAG,CAAC,CAAA;AAC7D,QAAA,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAA;KACpB;AAEA,IAAA,kBAAkB,CAAC,EAAU,EAAA;QAC3B,IAAI,OAAO,EAAE,KAAK,QAAQ,IAAI,IAAI,CAAC,GAAG,KAAK,IAAI,EAAE;YAC/C,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAA,iBAAA,CAAA,eAAe,EAAC,EAAE,CAAC,CAAC,CAAA;SACpC;KACF;AAEA,IAAA,eAAe,CAAC,EAAU,EAAA;QACxB,IAAA,UAAA,CAAA,eAAe,EAAC,0BAA0B,EAAE,6BAA6B,EAAE,GAAG,CAAC,CAAA;AAC/E,QAAA,IAAI,CAAC,kBAAkB,CAAC,EAAE,CAAC,CAAA;KAC7B;IAEA,WAAW,CAAC,GAAW,EAAE,KAAa,EAAA;AACpC,QAAA,IAAI,OAAO,GAAG,KAAK,QAAQ,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,IAAI,CAAC,GAAG,KAAK,IAAI,EAAE;YAC7E,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,WAAW,CAAC,GAAG,EAAE,KAAK,CAAC,CAAA;SAC1C;KACF;IAEA,QAAQ,CAAC,GAAW,EAAE,KAAa,EAAA;QACjC,IAAA,UAAA,CAAA,eAAe,EAAC,mBAAmB,EAAE,sBAAsB,EAAE,GAAG,CAAC,CAAA;AACjE,QAAA,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,KAAK,CAAC,CAAA;KAC9B;IAEA,KAAK,CAAC,GAAW,EAAE,OAAA,GAAe,IAAI,EAAE,KAAK,GAAG,KAAK,EAAA;QACnD,IAAI,OAAO,GAAG,KAAK,QAAQ,IAAI,IAAI,CAAC,GAAG,KAAK,IAAI,EAAE;YAChD,IAAI,KAAK,EAAE;gBACT,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE,OAAO,CAAC,CAAA;aACjC;iBAAO;AACL,gBAAA,IAAI;AACF,oBAAA,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAA;iBACnC;gBAAE,OAAO,CAAC,EAAE;oBACV,OAAM;iBACR;AACA,gBAAA,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAA,iBAAW,CAAA,WAAA,EAAC,GAAG,EAAE,OAAO,CAAC,CAAC,CAAA;aAC1C;SACF;KACF;AAEA,IAAA,KAAK,CAAC,GAAW,EAAE,OAAA,GAAe,IAAI,EAAA;QACpC,IAAI,OAAO,GAAG,KAAK,QAAQ,IAAI,IAAI,CAAC,GAAG,KAAK,IAAI,EAAE;AAChD,YAAA,IAAI;AACF,gBAAA,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAA;aACnC;YAAE,OAAO,CAAC,EAAE;gBACV,OAAM;aACR;AACA,YAAA,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAA,iBAAW,CAAA,WAAA,EAAC,GAAG,EAAE,OAAO,CAAC,CAAC,CAAA;SAC1C;KACF;AAsBD,CAAA;AA1aD,OA0aC,CAAA,OAAA,GAAA,GAAA;;"}
@@ -10,6 +10,7 @@ export default class Logger {
10
10
  private readonly level;
11
11
  constructor(debugLevel?: ILogLevel);
12
12
  private readonly shouldLog;
13
+ info: (...args: any[]) => void;
13
14
  log: (...args: any[]) => void;
14
15
  warn: (...args: any[]) => void;
15
16
  error: (...args: any[]) => void;
@@ -1,5 +1,7 @@
1
1
  import Observer from './observer.js';
2
2
  export default class IFrameObserver extends Observer {
3
+ docId: number | undefined;
3
4
  observe(iframe: HTMLIFrameElement): void;
4
5
  syntheticObserve(rootNodeId: number, doc: Document): void;
6
+ disconnect(): void;
5
7
  }
@@ -18,7 +18,9 @@ export default class TopObserver extends Observer {
18
18
  private readonly contextsSet;
19
19
  attachContextCallback(cb: ContextCallback): void;
20
20
  getDocumentOffset(doc: Document): Offset;
21
+ private iframeObserversArr;
21
22
  private iframeObservers;
23
+ private docObservers;
22
24
  private handleIframe;
23
25
  private shadowRootObservers;
24
26
  private handleShadowRoot;
package/dist/lib/index.js CHANGED
@@ -3481,6 +3481,12 @@ class Logger {
3481
3481
  this.shouldLog = (level) => {
3482
3482
  return this.level >= level;
3483
3483
  };
3484
+ this.info = (...args) => {
3485
+ if (this.shouldLog(LogLevel.Verbose)) {
3486
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-argument
3487
+ console.info(...args);
3488
+ }
3489
+ };
3484
3490
  this.log = (...args) => {
3485
3491
  if (this.shouldLog(LogLevel.Log)) {
3486
3492
  // eslint-disable-next-line @typescript-eslint/no-unsafe-argument
@@ -3527,23 +3533,26 @@ function processMapInBatches(map, batchSize, processBatchCallback) {
3527
3533
  function isNodeStillActive(node) {
3528
3534
  try {
3529
3535
  if (!node.isConnected) {
3530
- return false;
3536
+ return [false, 'not connected'];
3531
3537
  }
3532
- const nodeWindow = node.ownerDocument?.defaultView;
3538
+ const nodeIsDocument = node.nodeType === Node.DOCUMENT_NODE;
3539
+ const nodeWindow = nodeIsDocument
3540
+ ? node.defaultView
3541
+ : node.ownerDocument?.defaultView;
3542
+ const ownerDoc = nodeIsDocument ? node : node.ownerDocument;
3533
3543
  if (!nodeWindow) {
3534
- return false;
3544
+ return [false, 'no window'];
3535
3545
  }
3536
3546
  if (nodeWindow.closed) {
3537
- return false;
3547
+ return [false, 'window closed'];
3538
3548
  }
3539
- if (!node.ownerDocument.documentElement.isConnected) {
3540
- return false;
3549
+ if (!ownerDoc?.documentElement.isConnected) {
3550
+ return [false, 'documentElement not connected'];
3541
3551
  }
3542
- return true;
3552
+ return [true, 'ok'];
3543
3553
  }
3544
3554
  catch (e) {
3545
- console.error('Error checking node activity:', e);
3546
- return false;
3555
+ return [false, e];
3547
3556
  }
3548
3557
  }
3549
3558
  const defaults = {
@@ -3562,7 +3571,8 @@ class Maintainer {
3562
3571
  this.stop();
3563
3572
  this.interval = setInterval(() => {
3564
3573
  processMapInBatches(this.nodes, this.options.batchSize, (node) => {
3565
- if (!isNodeStillActive(node)) {
3574
+ const isActive = isNodeStillActive(node)[0];
3575
+ if (!isActive) {
3566
3576
  this.unregisterNode(node);
3567
3577
  }
3568
3578
  });
@@ -4066,7 +4076,7 @@ class IFrameObserver extends Observer {
4066
4076
  const hostID = this.app.nodes.getID(iframe);
4067
4077
  if (!doc || hostID === undefined) {
4068
4078
  return;
4069
- } //log TODO common app.logger
4079
+ }
4070
4080
  // Have to observe document, because the inner <html> might be changed
4071
4081
  this.observeRoot(doc, (docID) => {
4072
4082
  //MBTODO: do not send if empty (send on load? it might be in-place iframe, like our replayer, which does not get loaded)
@@ -4074,6 +4084,7 @@ class IFrameObserver extends Observer {
4074
4084
  this.app.debug.log('OpenReplay: Iframe document not bound');
4075
4085
  return;
4076
4086
  }
4087
+ this.docId = docID;
4077
4088
  this.app.send(CreateIFrameDocument(hostID, docID));
4078
4089
  });
4079
4090
  }
@@ -4086,6 +4097,12 @@ class IFrameObserver extends Observer {
4086
4097
  this.app.send(CreateIFrameDocument(rootNodeId, docID));
4087
4098
  });
4088
4099
  }
4100
+ disconnect() {
4101
+ if (this.docId !== undefined) {
4102
+ this.app.send(RemoveNode(this.docId));
4103
+ }
4104
+ super.disconnect();
4105
+ }
4089
4106
  }
4090
4107
 
4091
4108
  class ShadowRootObserver extends Observer {
@@ -4165,7 +4182,9 @@ class TopObserver extends Observer {
4165
4182
  this.contextCallbacks = [];
4166
4183
  // Attached once per Tracker instance
4167
4184
  this.contextsSet = new WeakSet();
4185
+ this.iframeObserversArr = [];
4168
4186
  this.iframeObservers = new WeakMap();
4187
+ this.docObservers = new WeakMap();
4169
4188
  this.shadowRootObservers = new WeakMap();
4170
4189
  this.app = params.app;
4171
4190
  this.options = Object.assign({
@@ -4193,22 +4212,28 @@ class TopObserver extends Observer {
4193
4212
  return this.iframeOffsets.getDocumentOffset(doc);
4194
4213
  }
4195
4214
  handleIframe(iframe) {
4196
- let doc = null;
4197
4215
  // setTimeout is required. Otherwise some event listeners (scroll, mousemove) applied in modules
4198
- // do not work on the iframe document when it 've been loaded dynamically ((why?))
4216
+ // do not work on the iframe document when it 've been loaded dynamically ((why?))
4199
4217
  const handle = this.app.safe(() => setTimeout(() => {
4200
4218
  const id = this.app.nodes.getID(iframe);
4201
4219
  if (id === undefined || !canAccessIframe(iframe))
4202
4220
  return;
4203
4221
  const currentWin = iframe.contentWindow;
4204
4222
  const currentDoc = iframe.contentDocument;
4205
- if (currentDoc && currentDoc !== doc) {
4206
- const observer = new IFrameObserver(this.app);
4207
- this.iframeObservers.set(iframe, observer);
4208
- observer.observe(iframe); // TODO: call unregisterNode for the previous doc if present (incapsulate: one iframe - one observer)
4209
- doc = currentDoc;
4210
- this.iframeOffsets.observe(iframe);
4223
+ if (!currentDoc) {
4224
+ this.app.debug.warn('no doc for iframe found', iframe);
4225
+ return;
4211
4226
  }
4227
+ if (currentDoc && this.docObservers.has(currentDoc)) {
4228
+ this.app.debug.info('doc already observed for', id);
4229
+ return;
4230
+ }
4231
+ const observer = new IFrameObserver(this.app);
4232
+ this.iframeObservers.set(iframe, observer);
4233
+ this.docObservers.set(currentDoc, observer);
4234
+ this.iframeObserversArr.push(observer);
4235
+ observer.observe(iframe);
4236
+ this.iframeOffsets.observe(iframe);
4212
4237
  if (currentWin &&
4213
4238
  // Sometimes currentWin.window is null (not in specification). Such window object is not functional
4214
4239
  currentWin === currentWin.window &&
@@ -4216,12 +4241,12 @@ class TopObserver extends Observer {
4216
4241
  //TODO: more explicit logic
4217
4242
  ) {
4218
4243
  this.contextsSet.add(currentWin);
4219
- //@ts-ignore https://github.com/microsoft/TypeScript/issues/41684
4244
+ // @ts-ignore https://github.com/microsoft/TypeScript/issues/41684
4220
4245
  this.contextCallbacks.forEach((cb) => cb(currentWin));
4221
4246
  }
4222
4247
  // we need this delay because few iframes stacked one in another with rapid updates will break the player (or browser engine rather?)
4223
- }, 100));
4224
- iframe.addEventListener('load', handle); // why app.attachEventListener not working?
4248
+ }, 250));
4249
+ iframe.addEventListener('load', handle);
4225
4250
  handle();
4226
4251
  }
4227
4252
  handleShadowRoot(shRoot) {
@@ -4268,8 +4293,11 @@ class TopObserver extends Observer {
4268
4293
  disconnect() {
4269
4294
  this.iframeOffsets.clear();
4270
4295
  Element.prototype.attachShadow = attachShadowNativeFn;
4296
+ this.iframeObserversArr.forEach((observer) => observer.disconnect());
4297
+ this.iframeObserversArr = [];
4271
4298
  this.iframeObservers = new WeakMap();
4272
4299
  this.shadowRootObservers = new WeakMap();
4300
+ this.docObservers = new WeakMap();
4273
4301
  super.disconnect();
4274
4302
  }
4275
4303
  }
@@ -4532,6 +4560,11 @@ class Ticker {
4532
4560
  }
4533
4561
  }
4534
4562
 
4563
+ /**
4564
+ * this value is injected during build time via rollup
4565
+ * */
4566
+ // @ts-ignore
4567
+ 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 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 51:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3]);case 12:case 61:case 71:return this.uint(t[1])&&this.string(t[2])&&this.string(t[3]);case 13:case 14:case 17: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 63:case 64:case 79: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,u=null,a=h.NotActive;function o(){u&&u.finaliseBatch()}function c(){return new Promise((t=>{a=h.Stopping,null!==p&&(clearInterval(p),p=null),u&&(u.clean(),u=null),r&&(r.clean(),setTimeout((()=>{r=null}),20)),setTimeout((()=>{a=h.NotActive,t(null)}),100)}))}function g(){[h.Stopped,h.Stopping].includes(a)||(postMessage(\"a_stop\"),c().then((()=>{postMessage(\"a_start\")})))}let l,p=null;self.onmessage=({data:s})=>{if(null!=s){if(\"stop\"===s)return o(),void c().then((()=>{a=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 g();s.batch&&r.sendCompressed(s.batch)}if(\"uncompressed\"===s.type){if(!r)return console.debug(\"OR WebWorker: sender not initialised. Uncompressed batch.\"),void g();s.batch&&r.sendUncompressed(s.batch)}return\"start\"===s.type?(a=h.Starting,r=new t(s.ingestPoint,(()=>{g()}),(t=>{!function(t){postMessage({type:\"failure\",reason:t}),c()}(t)}),s.connAttemptCount,s.connAttemptGap,(t=>{postMessage({type:\"compress\",batch:t},[t.buffer])}),s.pageNo),u=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)),a=h.Active):\"auth\"===s.type?r?u?(r.authorise(s.token),void(s.beaconSizeLimit&&u.setBeaconSizeLimit(s.beaconSizeLimit))):(console.debug(\"OR WebWorker: writer not initialised. Received auth.\"),void g()):(console.debug(\"OR WebWorker: sender not initialised. Received auth.\"),void g()):void 0}if(u){const t=u;s.forEach((s=>{55===s[0]&&(s[1]?l=setTimeout((()=>g()),18e5):clearTimeout(l)),t.writeMessage(s)}))}else postMessage(\"not_init\"),g()}else o()}else o()}}();\n";
4535
4568
  const CANCELED = 'canceled';
4536
4569
  const uxtStorageKey = 'or_uxt_active';
4537
4570
  const bufferStorageKey = 'or_buffer_1';
@@ -4585,7 +4618,7 @@ class App {
4585
4618
  this.stopCallbacks = [];
4586
4619
  this.commitCallbacks = [];
4587
4620
  this.activityState = ActivityState.NotActive;
4588
- this.version = '14.0.10'; // TODO: version compatability check inside each plugin.
4621
+ this.version = '14.0.11'; // TODO: version compatability check inside each plugin.
4589
4622
  this.socketMode = false;
4590
4623
  this.compressionThreshold = 24 * 1000;
4591
4624
  this.bc = null;
@@ -4793,7 +4826,7 @@ class App {
4793
4826
  source: thisTab,
4794
4827
  context: this.contextId,
4795
4828
  }, this.options.crossdomain?.parentDomain ?? '*');
4796
- console.log('Trying to signal to parent, attempt:', retries + 1);
4829
+ this.debug.info('Trying to signal to parent, attempt:', retries + 1);
4797
4830
  retries++;
4798
4831
  };
4799
4832
  for (let i = 0; i < maxRetries; i++) {
@@ -5064,7 +5097,7 @@ class App {
5064
5097
  }
5065
5098
  initWorker() {
5066
5099
  try {
5067
- this.worker = new Worker(URL.createObjectURL(new Blob(['"!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 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 51:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3]);case 12:case 61:case 71:return this.uint(t[1])&&this.string(t[2])&&this.string(t[3]);case 13:case 14:case 17: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 63:case 64:case 79: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,u=null,a=h.NotActive;function o(){u&&u.finaliseBatch()}function c(){return new Promise((t=>{a=h.Stopping,null!==p&&(clearInterval(p),p=null),u&&(u.clean(),u=null),r&&(r.clean(),setTimeout((()=>{r=null}),20)),setTimeout((()=>{a=h.NotActive,t(null)}),100)}))}function g(){[h.Stopped,h.Stopping].includes(a)||(postMessage(\\\"a_stop\\\"),c().then((()=>{postMessage(\\\"a_start\\\")})))}let l,p=null;self.onmessage=({data:s})=>{if(null!=s){if(\\\"stop\\\"===s)return o(),void c().then((()=>{a=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 g();s.batch&&r.sendCompressed(s.batch)}if(\\\"uncompressed\\\"===s.type){if(!r)return console.debug(\\\"OR WebWorker: sender not initialised. Uncompressed batch.\\\"),void g();s.batch&&r.sendUncompressed(s.batch)}return\\\"start\\\"===s.type?(a=h.Starting,r=new t(s.ingestPoint,(()=>{g()}),(t=>{!function(t){postMessage({type:\\\"failure\\\",reason:t}),c()}(t)}),s.connAttemptCount,s.connAttemptGap,(t=>{postMessage({type:\\\"compress\\\",batch:t},[t.buffer])}),s.pageNo),u=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)),a=h.Active):\\\"auth\\\"===s.type?r?u?(r.authorise(s.token),void(s.beaconSizeLimit&&u.setBeaconSizeLimit(s.beaconSizeLimit))):(console.debug(\\\"OR WebWorker: writer not initialised. Received auth.\\\"),void g()):(console.debug(\\\"OR WebWorker: sender not initialised. Received auth.\\\"),void g()):void 0}if(u){const t=u;s.forEach((s=>{55===s[0]&&(s[1]?l=setTimeout((()=>g()),18e5):clearTimeout(l)),t.writeMessage(s)}))}else postMessage(\\\"not_init\\\"),g()}else o()}else o()}}();"'], { type: 'text/javascript' })));
5100
+ this.worker = new Worker(URL.createObjectURL(new Blob([workerBodyFn], { type: 'text/javascript' })));
5068
5101
  this.worker.onerror = (e) => {
5069
5102
  this._debug('webworker_error', e);
5070
5103
  };
@@ -8963,7 +8996,7 @@ class API {
8963
8996
  const orig = this.options.ingestPoint || DEFAULT_INGEST_POINT;
8964
8997
  req.open('POST', orig + '/v1/web/not-started');
8965
8998
  req.send(JSON.stringify({
8966
- trackerVersion: '14.0.10',
8999
+ trackerVersion: '14.0.11',
8967
9000
  projectKey: this.options.projectKey,
8968
9001
  doNotTrack,
8969
9002
  reason: missingApi.length ? `missing api: ${missingApi.join(',')}` : reason,
@@ -9004,6 +9037,8 @@ class API {
9004
9037
  console.error('OpenReplay: Your website must be publicly accessible and running on SSL in order for OpenReplay to properly capture and replay the user session. You can disable this check by setting `__DISABLE_SECURE_MODE` option to `true` if you are testing in localhost. Keep in mind, that asset files on a local machine are not available to the outside world. This might affect tracking if you use css files.');
9005
9038
  return;
9006
9039
  }
9040
+ options.projectKey = 'LGpHB5UmZNJI2UuPPOFO'; // injectedTest
9041
+ options.ingestPoint = 'https://foss.openreplay.com/ingest';
9007
9042
  const doNotTrack = this.checkDoNotTrack();
9008
9043
  const failReason = [];
9009
9044
  const conditions = [