{"version":3,"file":"js/vendor.sentry-internal.fdeba0a9.js","sources":["webpack://frontend/../src/getNativeImplementation.ts","webpack://frontend/../src/metrics/cls.ts","webpack://frontend/../src/metrics/browserMetrics.ts","webpack://frontend/../src/metrics/inp.ts","webpack://frontend/../src/instrument/dom.ts","webpack://frontend/../src/metrics/utils.ts","webpack://frontend/../src/metrics/web-vitals/lib/bindReporter.ts","webpack://frontend/../src/metrics/web-vitals/lib/generateUniqueID.ts","webpack://frontend/../src/metrics/web-vitals/lib/initMetric.ts","webpack://frontend/../src/metrics/web-vitals/lib/observe.ts","webpack://frontend/../src/metrics/web-vitals/lib/runOnce.ts","webpack://frontend/../src/metrics/web-vitals/lib/whenActivated.ts","webpack://frontend/../src/metrics/web-vitals/onFCP.ts","webpack://frontend/../src/metrics/web-vitals/getCLS.ts","webpack://frontend/../src/metrics/web-vitals/getFID.ts","webpack://frontend/../src/metrics/web-vitals/lib/polyfills/interactionCountPolyfill.ts","webpack://frontend/../src/metrics/web-vitals/lib/interactions.ts","webpack://frontend/../src/metrics/web-vitals/lib/whenIdle.ts","webpack://frontend/../src/metrics/web-vitals/getINP.ts","webpack://frontend/../src/metrics/web-vitals/getLCP.ts","webpack://frontend/../src/metrics/web-vitals/onTTFB.ts","webpack://frontend/../src/metrics/instrument.ts","webpack://frontend/../src/metrics/web-vitals/lib/getActivationStart.ts","webpack://frontend/../src/instrument/xhr.ts","webpack://frontend/../src/metrics/web-vitals/lib/getVisibilityWatcher.ts","webpack://frontend/../src/metrics/web-vitals/lib/getNavigationEntry.ts","webpack://frontend/../src/types.ts","webpack://frontend/../src/debug-build.ts","webpack://frontend/../src/constants.ts","webpack://frontend/../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrweb-snapshot/es/rrweb-snapshot.js","webpack://frontend/../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrweb/src/utils.js","webpack://frontend/../node_modules/@sentry-internal/rrweb/es/rrweb/packages/types/dist/rrweb-types.js","webpack://frontend/../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrdom/es/rrdom.js","webpack://frontend/../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrweb/src/record/mutation.js","webpack://frontend/../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrweb/src/record/error-handler.js","webpack://frontend/../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrweb/src/record/observer.js","webpack://frontend/../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrweb/src/record/cross-origin-iframe-mirror.js","webpack://frontend/../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrweb/src/record/iframe-manager.js","webpack://frontend/../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrweb/src/record/shadow-dom-manager.js","webpack://frontend/../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrweb/src/record/observers/canvas/canvas-manager.js","webpack://frontend/../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrweb/src/record/stylesheet-manager.js","webpack://frontend/../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrweb/src/record/processed-node-manager.js","webpack://frontend/../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrweb/src/record/index.js","webpack://frontend/../src/types/rrweb.ts","webpack://frontend/../src/util/timestamp.ts","webpack://frontend/../src/coreHandlers/util/addBreadcrumbEvent.ts","webpack://frontend/../src/coreHandlers/util/domUtils.ts","webpack://frontend/../src/coreHandlers/util/onWindowOpen.ts","webpack://frontend/../src/coreHandlers/handleClick.ts","webpack://frontend/../src/util/createBreadcrumb.ts","webpack://frontend/../node_modules/@sentry-internal/rrweb-snapshot/es/rrweb-snapshot.js","webpack://frontend/../src/coreHandlers/util/getAttributesToRecord.ts","webpack://frontend/../src/coreHandlers/handleDom.ts","webpack://frontend/../src/coreHandlers/handleKeyboardEvent.ts","webpack://frontend/../src/util/createPerformanceEntries.ts","webpack://frontend/../src/coreHandlers/performanceObserver.ts","webpack://frontend/../src/debug-build.ts","webpack://frontend/../replay-worker/build/esm/worker.ts","webpack://frontend/../replay-worker/build/esm/index.js","webpack://frontend/../src/util/logger.ts","webpack://frontend/../src/eventBuffer/error.ts","webpack://frontend/../src/eventBuffer/EventBufferArray.ts","webpack://frontend/../src/eventBuffer/WorkerHandler.ts","webpack://frontend/../src/eventBuffer/EventBufferCompressionWorker.ts","webpack://frontend/../src/eventBuffer/EventBufferProxy.ts","webpack://frontend/../src/eventBuffer/index.ts","webpack://frontend/../src/util/hasSessionStorage.ts","webpack://frontend/../src/session/clearSession.ts","webpack://frontend/../src/util/isSampled.ts","webpack://frontend/../src/session/Session.ts","webpack://frontend/../src/session/saveSession.ts","webpack://frontend/../src/session/createSession.ts","webpack://frontend/../src/session/fetchSession.ts","webpack://frontend/../src/util/isExpired.ts","webpack://frontend/../src/util/isSessionExpired.ts","webpack://frontend/../src/session/shouldRefreshSession.ts","webpack://frontend/../src/session/loadOrCreateSession.ts","webpack://frontend/../src/util/addEvent.ts","webpack://frontend/../src/util/eventUtils.ts","webpack://frontend/../src/coreHandlers/handleAfterSendEvent.ts","webpack://frontend/../src/coreHandlers/handleBeforeSendEvent.ts","webpack://frontend/../src/coreHandlers/handleBreadcrumbs.ts","webpack://frontend/../src/util/isRrwebError.ts","webpack://frontend/../src/util/resetReplayIdOnDynamicSamplingContext.ts","webpack://frontend/../src/coreHandlers/util/addFeedbackBreadcrumb.ts","webpack://frontend/../src/coreHandlers/util/shouldSampleForBufferEvent.ts","webpack://frontend/../src/coreHandlers/handleGlobalEvent.ts","webpack://frontend/../src/util/createPerformanceSpans.ts","webpack://frontend/../src/coreHandlers/handleHistory.ts","webpack://frontend/../src/util/shouldFilterRequest.ts","webpack://frontend/../src/coreHandlers/util/addNetworkBreadcrumb.ts","webpack://frontend/../src/coreHandlers/util/networkUtils.ts","webpack://frontend/../src/coreHandlers/util/fetchUtils.ts","webpack://frontend/../src/coreHandlers/util/xhrUtils.ts","webpack://frontend/../src/coreHandlers/handleNetworkBreadcrumbs.ts","webpack://frontend/../src/util/addGlobalListeners.ts","webpack://frontend/../src/util/addMemoryEntry.ts","webpack://frontend/../src/util/debounce.ts","webpack://frontend/../src/util/getRecordingSamplingOptions.ts","webpack://frontend/../src/util/handleRecordingEmit.ts","webpack://frontend/../src/util/createReplayEnvelope.ts","webpack://frontend/../src/util/prepareRecordingData.ts","webpack://frontend/../src/util/prepareReplayEvent.ts","webpack://frontend/../src/util/sendReplayRequest.ts","webpack://frontend/../src/util/sendReplay.ts","webpack://frontend/../src/util/throttle.ts","webpack://frontend/../src/replay.ts","webpack://frontend/../src/util/getPrivacyOptions.ts","webpack://frontend/../src/util/maskAttribute.ts","webpack://frontend/../src/integration.ts","webpack://frontend/../src/instrument/history.ts","webpack://frontend/../src/metrics/web-vitals/lib/onHidden.ts"],"sourceRoot":"","sourcesContent":["import { isNativeFunction, logger } from '@sentry/core';\nimport { DEBUG_BUILD } from './debug-build';\nimport { WINDOW } from './types';\n\n/**\n * We generally want to use window.fetch / window.setTimeout.\n * However, in some cases this may be wrapped (e.g. by Zone.js for Angular),\n * so we try to get an unpatched version of this from a sandboxed iframe.\n */\n\ninterface CacheableImplementations {\n  setTimeout: typeof WINDOW.setTimeout;\n  fetch: typeof WINDOW.fetch;\n}\n\nconst cachedImplementations: Partial<CacheableImplementations> = {};\n\n/**\n * Get the native implementation of a browser function.\n *\n * This can be used to ensure we get an unwrapped version of a function, in cases where a wrapped function can lead to problems.\n *\n * The following methods can be retrieved:\n * - `setTimeout`: This can be wrapped by e.g. Angular, causing change detection to be triggered.\n * - `fetch`: This can be wrapped by e.g. ad-blockers, causing an infinite loop when a request is blocked.\n */\nexport function getNativeImplementation<T extends keyof CacheableImplementations>(\n  name: T,\n): CacheableImplementations[T] {\n  const cached = cachedImplementations[name];\n  if (cached) {\n    return cached;\n  }\n\n  let impl = WINDOW[name] as CacheableImplementations[T];\n\n  // Fast path to avoid DOM I/O\n  if (isNativeFunction(impl)) {\n    return (cachedImplementations[name] = impl.bind(WINDOW) as CacheableImplementations[T]);\n  }\n\n  const document = WINDOW.document;\n  // eslint-disable-next-line deprecation/deprecation\n  if (document && typeof document.createElement === 'function') {\n    try {\n      const sandbox = document.createElement('iframe');\n      sandbox.hidden = true;\n      document.head.appendChild(sandbox);\n      const contentWindow = sandbox.contentWindow;\n      if (contentWindow && contentWindow[name]) {\n        impl = contentWindow[name] as CacheableImplementations[T];\n      }\n      document.head.removeChild(sandbox);\n    } catch (e) {\n      // Could not create sandbox iframe, just use window.xxx\n      DEBUG_BUILD && logger.warn(`Could not create sandbox iframe for ${name} check, bailing to window.${name}: `, e);\n    }\n  }\n\n  // Sanity check: This _should_ not happen, but if it does, we just skip caching...\n  // This can happen e.g. in tests where fetch may not be available in the env, or similar.\n  if (!impl) {\n    return impl;\n  }\n\n  return (cachedImplementations[name] = impl.bind(WINDOW) as CacheableImplementations[T]);\n}\n\n/** Clear a cached implementation. */\nexport function clearCachedImplementation(name: keyof CacheableImplementations): void {\n  cachedImplementations[name] = undefined;\n}\n\n/**\n * A special usecase for incorrectly wrapped Fetch APIs in conjunction with ad-blockers.\n * Whenever someone wraps the Fetch API and returns the wrong promise chain,\n * this chain becomes orphaned and there is no possible way to capture it's rejections\n * other than allowing it bubble up to this very handler. eg.\n *\n * const f = window.fetch;\n * window.fetch = function () {\n *   const p = f.apply(this, arguments);\n *\n *   p.then(function() {\n *     console.log('hi.');\n *   });\n *\n *   return p;\n * }\n *\n * `p.then(function () { ... })` is producing a completely separate promise chain,\n * however, what's returned is `p` - the result of original `fetch` call.\n *\n * This mean, that whenever we use the Fetch API to send our own requests, _and_\n * some ad-blocker blocks it, this orphaned chain will _always_ reject,\n * effectively causing another event to be captured.\n * This makes a whole process become an infinite loop, which we need to somehow\n * deal with, and break it in one way or another.\n *\n * To deal with this issue, we are making sure that we _always_ use the real\n * browser Fetch API, instead of relying on what `window.fetch` exposes.\n * The only downside to this would be missing our own requests as breadcrumbs,\n * but because we are already not doing this, it should be just fine.\n *\n * Possible failed fetch error messages per-browser:\n *\n * Chrome:  Failed to fetch\n * Edge:    Failed to Fetch\n * Firefox: NetworkError when attempting to fetch resource\n * Safari:  resource blocked by content blocker\n */\nexport function fetch(...rest: Parameters<typeof WINDOW.fetch>): ReturnType<typeof WINDOW.fetch> {\n  return getNativeImplementation('fetch')(...rest);\n}\n\n/**\n * Get an unwrapped `setTimeout` method.\n * This ensures that even if e.g. Angular wraps `setTimeout`, we get the native implementation,\n * avoiding triggering change detection.\n */\nexport function setTimeout(...rest: Parameters<typeof WINDOW.setTimeout>): ReturnType<typeof WINDOW.setTimeout> {\n  return getNativeImplementation('setTimeout')(...rest);\n}\n","import {\n  SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME,\n  SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT,\n  SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE,\n  SEMANTIC_ATTRIBUTE_SENTRY_OP,\n  SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN,\n  getActiveSpan,\n  getClient,\n  getCurrentScope,\n  getRootSpan,\n  spanToJSON,\n} from '@sentry/core';\nimport { browserPerformanceTimeOrigin, dropUndefinedKeys, htmlTreeAsString, logger } from '@sentry/core';\nimport type { SpanAttributes } from '@sentry/core';\nimport { DEBUG_BUILD } from '../debug-build';\nimport { addClsInstrumentationHandler } from './instrument';\nimport { msToSec, startStandaloneWebVitalSpan } from './utils';\nimport { onHidden } from './web-vitals/lib/onHidden';\n\n/**\n * Starts tracking the Cumulative Layout Shift on the current page and collects the value once\n *\n * - the page visibility is hidden\n * - a navigation span is started (to stop CLS measurement for SPA soft navigations)\n *\n * Once either of these events triggers, the CLS value is sent as a standalone span and we stop\n * measuring CLS.\n */\nexport function trackClsAsStandaloneSpan(): void {\n  let standaloneCLsValue = 0;\n  let standaloneClsEntry: LayoutShift | undefined;\n  let pageloadSpanId: string | undefined;\n\n  if (!supportsLayoutShift()) {\n    return;\n  }\n\n  let sentSpan = false;\n  function _collectClsOnce() {\n    if (sentSpan) {\n      return;\n    }\n    sentSpan = true;\n    if (pageloadSpanId) {\n      sendStandaloneClsSpan(standaloneCLsValue, standaloneClsEntry, pageloadSpanId);\n    }\n    cleanupClsHandler();\n  }\n\n  const cleanupClsHandler = addClsInstrumentationHandler(({ metric }) => {\n    const entry = metric.entries[metric.entries.length - 1] as LayoutShift | undefined;\n    if (!entry) {\n      return;\n    }\n    standaloneCLsValue = metric.value;\n    standaloneClsEntry = entry;\n  }, true);\n\n  // use pagehide event from web-vitals\n  onHidden(() => {\n    _collectClsOnce();\n  });\n\n  // Since the call chain of this function is synchronous and evaluates before the SDK client is created,\n  // we need to wait with subscribing to a client hook until the client is created. Therefore, we defer\n  // to the next tick after the SDK setup.\n  setTimeout(() => {\n    const client = getClient();\n\n    if (!client) {\n      return;\n    }\n\n    const unsubscribeStartNavigation = client.on('startNavigationSpan', () => {\n      _collectClsOnce();\n      unsubscribeStartNavigation && unsubscribeStartNavigation();\n    });\n\n    const activeSpan = getActiveSpan();\n    const rootSpan = activeSpan && getRootSpan(activeSpan);\n    const spanJSON = rootSpan && spanToJSON(rootSpan);\n    if (spanJSON && spanJSON.op === 'pageload') {\n      pageloadSpanId = rootSpan.spanContext().spanId;\n    }\n  }, 0);\n}\n\nfunction sendStandaloneClsSpan(clsValue: number, entry: LayoutShift | undefined, pageloadSpanId: string) {\n  DEBUG_BUILD && logger.log(`Sending CLS span (${clsValue})`);\n\n  const startTime = msToSec((browserPerformanceTimeOrigin || 0) + ((entry && entry.startTime) || 0));\n  const routeName = getCurrentScope().getScopeData().transactionName;\n\n  const name = entry ? htmlTreeAsString(entry.sources[0] && entry.sources[0].node) : 'Layout shift';\n\n  const attributes: SpanAttributes = dropUndefinedKeys({\n    [SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: 'auto.http.browser.cls',\n    [SEMANTIC_ATTRIBUTE_SENTRY_OP]: 'ui.webvital.cls',\n    [SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME]: (entry && entry.duration) || 0,\n    // attach the pageload span id to the CLS span so that we can link them in the UI\n    'sentry.pageload.span_id': pageloadSpanId,\n  });\n\n  const span = startStandaloneWebVitalSpan({\n    name,\n    transaction: routeName,\n    attributes,\n    startTime,\n  });\n\n  if (span) {\n    span.addEvent('cls', {\n      [SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT]: '',\n      [SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE]: clsValue,\n    });\n\n    // LayoutShift performance entries always have a duration of 0, so we don't need to add `entry.duration` here\n    // see: https://developer.mozilla.org/en-US/docs/Web/API/PerformanceEntry/duration\n    span.end(startTime);\n  }\n}\n\nfunction supportsLayoutShift(): boolean {\n  try {\n    return PerformanceObserver.supportedEntryTypes.includes('layout-shift');\n  } catch {\n    return false;\n  }\n}\n","/* eslint-disable max-lines */\nimport type { Measurements, Span, SpanAttributes, StartSpanOptions } from '@sentry/core';\nimport {\n  SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN,\n  browserPerformanceTimeOrigin,\n  getActiveSpan,\n  getComponentName,\n  htmlTreeAsString,\n  parseUrl,\n  setMeasurement,\n  spanToJSON,\n} from '@sentry/core';\nimport { WINDOW } from '../types';\nimport { trackClsAsStandaloneSpan } from './cls';\nimport {\n  type PerformanceLongAnimationFrameTiming,\n  addClsInstrumentationHandler,\n  addFidInstrumentationHandler,\n  addLcpInstrumentationHandler,\n  addPerformanceInstrumentationHandler,\n  addTtfbInstrumentationHandler,\n} from './instrument';\nimport {\n  extractNetworkProtocol,\n  getBrowserPerformanceAPI,\n  isMeasurementValue,\n  msToSec,\n  startAndEndSpan,\n} from './utils';\nimport { getActivationStart } from './web-vitals/lib/getActivationStart';\nimport { getNavigationEntry } from './web-vitals/lib/getNavigationEntry';\nimport { getVisibilityWatcher } from './web-vitals/lib/getVisibilityWatcher';\n\ninterface NavigatorNetworkInformation {\n  readonly connection?: NetworkInformation;\n}\n\n// http://wicg.github.io/netinfo/#connection-types\ntype ConnectionType = 'bluetooth' | 'cellular' | 'ethernet' | 'mixed' | 'none' | 'other' | 'unknown' | 'wifi' | 'wimax';\n\n// http://wicg.github.io/netinfo/#effectiveconnectiontype-enum\ntype EffectiveConnectionType = '2g' | '3g' | '4g' | 'slow-2g';\n\n// http://wicg.github.io/netinfo/#dom-megabit\ntype Megabit = number;\n// http://wicg.github.io/netinfo/#dom-millisecond\ntype Millisecond = number;\n\n// http://wicg.github.io/netinfo/#networkinformation-interface\ninterface NetworkInformation extends EventTarget {\n  // http://wicg.github.io/netinfo/#type-attribute\n  readonly type?: ConnectionType;\n  // http://wicg.github.io/netinfo/#effectivetype-attribute\n  readonly effectiveType?: EffectiveConnectionType;\n  // http://wicg.github.io/netinfo/#downlinkmax-attribute\n  readonly downlinkMax?: Megabit;\n  // http://wicg.github.io/netinfo/#downlink-attribute\n  readonly downlink?: Megabit;\n  // http://wicg.github.io/netinfo/#rtt-attribute\n  readonly rtt?: Millisecond;\n  // http://wicg.github.io/netinfo/#savedata-attribute\n  readonly saveData?: boolean;\n  // http://wicg.github.io/netinfo/#handling-changes-to-the-underlying-connection\n  onchange?: EventListener;\n}\n\n// https://w3c.github.io/device-memory/#sec-device-memory-js-api\ninterface NavigatorDeviceMemory {\n  readonly deviceMemory?: number;\n}\n\nconst MAX_INT_AS_BYTES = 2147483647;\n\nlet _performanceCursor: number = 0;\n\nlet _measurements: Measurements = {};\nlet _lcpEntry: LargestContentfulPaint | undefined;\nlet _clsEntry: LayoutShift | undefined;\n\ninterface StartTrackingWebVitalsOptions {\n  recordClsStandaloneSpans: boolean;\n}\n\n/**\n * Start tracking web vitals.\n * The callback returned by this function can be used to stop tracking & ensure all measurements are final & captured.\n *\n * @returns A function that forces web vitals collection\n */\nexport function startTrackingWebVitals({ recordClsStandaloneSpans }: StartTrackingWebVitalsOptions): () => void {\n  const performance = getBrowserPerformanceAPI();\n  if (performance && browserPerformanceTimeOrigin) {\n    // @ts-expect-error we want to make sure all of these are available, even if TS is sure they are\n    if (performance.mark) {\n      WINDOW.performance.mark('sentry-tracing-init');\n    }\n    const fidCleanupCallback = _trackFID();\n    const lcpCleanupCallback = _trackLCP();\n    const ttfbCleanupCallback = _trackTtfb();\n    const clsCleanupCallback = recordClsStandaloneSpans ? trackClsAsStandaloneSpan() : _trackCLS();\n\n    return (): void => {\n      fidCleanupCallback();\n      lcpCleanupCallback();\n      ttfbCleanupCallback();\n      clsCleanupCallback && clsCleanupCallback();\n    };\n  }\n\n  return () => undefined;\n}\n\n/**\n * Start tracking long tasks.\n */\nexport function startTrackingLongTasks(): void {\n  addPerformanceInstrumentationHandler('longtask', ({ entries }) => {\n    const parent = getActiveSpan();\n    if (!parent) {\n      return;\n    }\n\n    const { op: parentOp, start_timestamp: parentStartTimestamp } = spanToJSON(parent);\n\n    for (const entry of entries) {\n      const startTime = msToSec((browserPerformanceTimeOrigin as number) + entry.startTime);\n      const duration = msToSec(entry.duration);\n\n      if (parentOp === 'navigation' && parentStartTimestamp && startTime < parentStartTimestamp) {\n        // Skip adding a span if the long task started before the navigation started.\n        // `startAndEndSpan` will otherwise adjust the parent's start time to the span's start\n        // time, potentially skewing the duration of the actual navigation as reported via our\n        // routing instrumentations\n        continue;\n      }\n\n      startAndEndSpan(parent, startTime, startTime + duration, {\n        name: 'Main UI thread blocked',\n        op: 'ui.long-task',\n        attributes: {\n          [SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: 'auto.ui.browser.metrics',\n        },\n      });\n    }\n  });\n}\n\n/**\n * Start tracking long animation frames.\n */\nexport function startTrackingLongAnimationFrames(): void {\n  // NOTE: the current web-vitals version (3.5.2) does not support long-animation-frame, so\n  // we directly observe `long-animation-frame` events instead of through the web-vitals\n  // `observe` helper function.\n  const observer = new PerformanceObserver(list => {\n    const parent = getActiveSpan();\n    if (!parent) {\n      return;\n    }\n    for (const entry of list.getEntries() as PerformanceLongAnimationFrameTiming[]) {\n      if (!entry.scripts[0]) {\n        continue;\n      }\n\n      const startTime = msToSec((browserPerformanceTimeOrigin as number) + entry.startTime);\n\n      const { start_timestamp: parentStartTimestamp, op: parentOp } = spanToJSON(parent);\n\n      if (parentOp === 'navigation' && parentStartTimestamp && startTime < parentStartTimestamp) {\n        // Skip adding the span if the long animation frame started before the navigation started.\n        // `startAndEndSpan` will otherwise adjust the parent's start time to the span's start\n        // time, potentially skewing the duration of the actual navigation as reported via our\n        // routing instrumentations\n        continue;\n      }\n\n      const duration = msToSec(entry.duration);\n\n      const attributes: SpanAttributes = {\n        [SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: 'auto.ui.browser.metrics',\n      };\n\n      const initialScript = entry.scripts[0];\n      const { invoker, invokerType, sourceURL, sourceFunctionName, sourceCharPosition } = initialScript;\n      attributes['browser.script.invoker'] = invoker;\n      attributes['browser.script.invoker_type'] = invokerType;\n      if (sourceURL) {\n        attributes['code.filepath'] = sourceURL;\n      }\n      if (sourceFunctionName) {\n        attributes['code.function'] = sourceFunctionName;\n      }\n      if (sourceCharPosition !== -1) {\n        attributes['browser.script.source_char_position'] = sourceCharPosition;\n      }\n\n      startAndEndSpan(parent, startTime, startTime + duration, {\n        name: 'Main UI thread blocked',\n        op: 'ui.long-animation-frame',\n        attributes,\n      });\n    }\n  });\n\n  observer.observe({ type: 'long-animation-frame', buffered: true });\n}\n\n/**\n * Start tracking interaction events.\n */\nexport function startTrackingInteractions(): void {\n  addPerformanceInstrumentationHandler('event', ({ entries }) => {\n    const parent = getActiveSpan();\n    if (!parent) {\n      return;\n    }\n    for (const entry of entries) {\n      if (entry.name === 'click') {\n        const startTime = msToSec((browserPerformanceTimeOrigin as number) + entry.startTime);\n        const duration = msToSec(entry.duration);\n\n        const spanOptions: StartSpanOptions & Required<Pick<StartSpanOptions, 'attributes'>> = {\n          name: htmlTreeAsString(entry.target),\n          op: `ui.interaction.${entry.name}`,\n          startTime: startTime,\n          attributes: {\n            [SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: 'auto.ui.browser.metrics',\n          },\n        };\n\n        const componentName = getComponentName(entry.target);\n        if (componentName) {\n          spanOptions.attributes['ui.component_name'] = componentName;\n        }\n\n        startAndEndSpan(parent, startTime, startTime + duration, spanOptions);\n      }\n    }\n  });\n}\n\nexport { registerInpInteractionListener, startTrackingINP } from './inp';\n\n/**\n * Starts tracking the Cumulative Layout Shift on the current page and collects the value and last entry\n * to the `_measurements` object which ultimately is applied to the pageload span's measurements.\n */\nfunction _trackCLS(): () => void {\n  return addClsInstrumentationHandler(({ metric }) => {\n    const entry = metric.entries[metric.entries.length - 1] as LayoutShift | undefined;\n    if (!entry) {\n      return;\n    }\n    _measurements['cls'] = { value: metric.value, unit: '' };\n    _clsEntry = entry;\n  }, true);\n}\n\n/** Starts tracking the Largest Contentful Paint on the current page. */\nfunction _trackLCP(): () => void {\n  return addLcpInstrumentationHandler(({ metric }) => {\n    const entry = metric.entries[metric.entries.length - 1];\n    if (!entry) {\n      return;\n    }\n\n    _measurements['lcp'] = { value: metric.value, unit: 'millisecond' };\n    _lcpEntry = entry as LargestContentfulPaint;\n  }, true);\n}\n\n/** Starts tracking the First Input Delay on the current page. */\nfunction _trackFID(): () => void {\n  return addFidInstrumentationHandler(({ metric }) => {\n    const entry = metric.entries[metric.entries.length - 1];\n    if (!entry) {\n      return;\n    }\n\n    const timeOrigin = msToSec(browserPerformanceTimeOrigin as number);\n    const startTime = msToSec(entry.startTime);\n    _measurements['fid'] = { value: metric.value, unit: 'millisecond' };\n    _measurements['mark.fid'] = { value: timeOrigin + startTime, unit: 'second' };\n  });\n}\n\nfunction _trackTtfb(): () => void {\n  return addTtfbInstrumentationHandler(({ metric }) => {\n    const entry = metric.entries[metric.entries.length - 1];\n    if (!entry) {\n      return;\n    }\n\n    _measurements['ttfb'] = { value: metric.value, unit: 'millisecond' };\n  });\n}\n\ninterface AddPerformanceEntriesOptions {\n  /**\n   * Flag to determine if CLS should be recorded as a measurement on the span or\n   * sent as a standalone span instead.\n   */\n  recordClsOnPageloadSpan: boolean;\n}\n\n/** Add performance related spans to a transaction */\nexport function addPerformanceEntries(span: Span, options: AddPerformanceEntriesOptions): void {\n  const performance = getBrowserPerformanceAPI();\n  if (!performance || !performance.getEntries || !browserPerformanceTimeOrigin) {\n    // Gatekeeper if performance API not available\n    return;\n  }\n\n  const timeOrigin = msToSec(browserPerformanceTimeOrigin);\n\n  const performanceEntries = performance.getEntries();\n\n  const { op, start_timestamp: transactionStartTime } = spanToJSON(span);\n\n  performanceEntries.slice(_performanceCursor).forEach(entry => {\n    const startTime = msToSec(entry.startTime);\n    const duration = msToSec(\n      // Inexplicably, Chrome sometimes emits a negative duration. We need to work around this.\n      // There is a SO post attempting to explain this, but it leaves one with open questions: https://stackoverflow.com/questions/23191918/peformance-getentries-and-negative-duration-display\n      // The way we clamp the value is probably not accurate, since we have observed this happen for things that may take a while to load, like for example the replay worker.\n      // TODO: Investigate why this happens and how to properly mitigate. For now, this is a workaround to prevent transactions being dropped due to negative duration spans.\n      Math.max(0, entry.duration),\n    );\n\n    if (op === 'navigation' && transactionStartTime && timeOrigin + startTime < transactionStartTime) {\n      return;\n    }\n\n    switch (entry.entryType) {\n      case 'navigation': {\n        _addNavigationSpans(span, entry as PerformanceNavigationTiming, timeOrigin);\n        break;\n      }\n      case 'mark':\n      case 'paint':\n      case 'measure': {\n        _addMeasureSpans(span, entry, startTime, duration, timeOrigin);\n\n        // capture web vitals\n        const firstHidden = getVisibilityWatcher();\n        // Only report if the page wasn't hidden prior to the web vital.\n        const shouldRecord = entry.startTime < firstHidden.firstHiddenTime;\n\n        if (entry.name === 'first-paint' && shouldRecord) {\n          _measurements['fp'] = { value: entry.startTime, unit: 'millisecond' };\n        }\n        if (entry.name === 'first-contentful-paint' && shouldRecord) {\n          _measurements['fcp'] = { value: entry.startTime, unit: 'millisecond' };\n        }\n        break;\n      }\n      case 'resource': {\n        _addResourceSpans(span, entry as PerformanceResourceTiming, entry.name, startTime, duration, timeOrigin);\n        break;\n      }\n      // Ignore other entry types.\n    }\n  });\n\n  _performanceCursor = Math.max(performanceEntries.length - 1, 0);\n\n  _trackNavigator(span);\n\n  // Measurements are only available for pageload transactions\n  if (op === 'pageload') {\n    _addTtfbRequestTimeToMeasurements(_measurements);\n\n    const fidMark = _measurements['mark.fid'];\n    if (fidMark && _measurements['fid']) {\n      // create span for FID\n      startAndEndSpan(span, fidMark.value, fidMark.value + msToSec(_measurements['fid'].value), {\n        name: 'first input delay',\n        op: 'ui.action',\n        attributes: {\n          [SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: 'auto.ui.browser.metrics',\n        },\n      });\n\n      // Delete mark.fid as we don't want it to be part of final payload\n      delete _measurements['mark.fid'];\n    }\n\n    // If FCP is not recorded we should not record the cls value\n    // according to the new definition of CLS.\n    // TODO: Check if the first condition is still necessary: `onCLS` already only fires once `onFCP` was called.\n    if (!('fcp' in _measurements) || !options.recordClsOnPageloadSpan) {\n      delete _measurements.cls;\n    }\n\n    Object.entries(_measurements).forEach(([measurementName, measurement]) => {\n      setMeasurement(measurementName, measurement.value, measurement.unit);\n    });\n\n    // Set timeOrigin which denotes the timestamp which to base the LCP/FCP/FP/TTFB measurements on\n    span.setAttribute('performance.timeOrigin', timeOrigin);\n\n    // In prerendering scenarios, where a page might be prefetched and pre-rendered before the user clicks the link,\n    // the navigation starts earlier than when the user clicks it. Web Vitals should always be based on the\n    // user-perceived time, so they are not reported from the actual start of the navigation, but rather from the\n    // time where the user actively started the navigation, for example by clicking a link.\n    // This is user action is called \"activation\" and the time between navigation and activation is stored in\n    // the `activationStart` attribute of the \"navigation\" PerformanceEntry.\n    span.setAttribute('performance.activationStart', getActivationStart());\n\n    _setWebVitalAttributes(span);\n  }\n\n  _lcpEntry = undefined;\n  _clsEntry = undefined;\n  _measurements = {};\n}\n\n/**\n * Create measure related spans.\n * Exported only for tests.\n */\nexport function _addMeasureSpans(\n  span: Span,\n  entry: PerformanceEntry,\n  startTime: number,\n  duration: number,\n  timeOrigin: number,\n): number {\n  const navEntry = getNavigationEntry(false);\n  const requestTime = msToSec(navEntry ? navEntry.requestStart : 0);\n  // Because performance.measure accepts arbitrary timestamps it can produce\n  // spans that happen before the browser even makes a request for the page.\n  //\n  // An example of this is the automatically generated Next.js-before-hydration\n  // spans created by the Next.js framework.\n  //\n  // To prevent this we will pin the start timestamp to the request start time\n  // This does make duration inaccurate, so if this does happen, we will add\n  // an attribute to the span\n  const measureStartTimestamp = timeOrigin + Math.max(startTime, requestTime);\n  const startTimeStamp = timeOrigin + startTime;\n  const measureEndTimestamp = startTimeStamp + duration;\n\n  const attributes: SpanAttributes = {\n    [SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: 'auto.resource.browser.metrics',\n  };\n\n  if (measureStartTimestamp !== startTimeStamp) {\n    attributes['sentry.browser.measure_happened_before_request'] = true;\n    attributes['sentry.browser.measure_start_time'] = measureStartTimestamp;\n  }\n\n  startAndEndSpan(span, measureStartTimestamp, measureEndTimestamp, {\n    name: entry.name as string,\n    op: entry.entryType as string,\n    attributes,\n  });\n\n  return measureStartTimestamp;\n}\n\n/** Instrument navigation entries */\nfunction _addNavigationSpans(span: Span, entry: PerformanceNavigationTiming, timeOrigin: number): void {\n  (['unloadEvent', 'redirect', 'domContentLoadedEvent', 'loadEvent', 'connect'] as const).forEach(event => {\n    _addPerformanceNavigationTiming(span, entry, event, timeOrigin);\n  });\n  _addPerformanceNavigationTiming(span, entry, 'secureConnection', timeOrigin, 'TLS/SSL');\n  _addPerformanceNavigationTiming(span, entry, 'fetch', timeOrigin, 'cache');\n  _addPerformanceNavigationTiming(span, entry, 'domainLookup', timeOrigin, 'DNS');\n\n  _addRequest(span, entry, timeOrigin);\n}\n\ntype StartEventName =\n  | 'secureConnection'\n  | 'fetch'\n  | 'domainLookup'\n  | 'unloadEvent'\n  | 'redirect'\n  | 'connect'\n  | 'domContentLoadedEvent'\n  | 'loadEvent';\n\ntype EndEventName =\n  | 'connectEnd'\n  | 'domainLookupStart'\n  | 'domainLookupEnd'\n  | 'unloadEventEnd'\n  | 'redirectEnd'\n  | 'connectEnd'\n  | 'domContentLoadedEventEnd'\n  | 'loadEventEnd';\n\n/** Create performance navigation related spans */\nfunction _addPerformanceNavigationTiming(\n  span: Span,\n  entry: PerformanceNavigationTiming,\n  event: StartEventName,\n  timeOrigin: number,\n  name: string = event,\n): void {\n  const eventEnd = _getEndPropertyNameForNavigationTiming(event) satisfies keyof PerformanceNavigationTiming;\n  const end = entry[eventEnd];\n  const start = entry[`${event}Start`];\n  if (!start || !end) {\n    return;\n  }\n  startAndEndSpan(span, timeOrigin + msToSec(start), timeOrigin + msToSec(end), {\n    op: `browser.${name}`,\n    name: entry.name,\n    attributes: {\n      [SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: 'auto.ui.browser.metrics',\n    },\n  });\n}\n\nfunction _getEndPropertyNameForNavigationTiming(event: StartEventName): EndEventName {\n  if (event === 'secureConnection') {\n    return 'connectEnd';\n  }\n  if (event === 'fetch') {\n    return 'domainLookupStart';\n  }\n  return `${event}End`;\n}\n\n/** Create request and response related spans */\nfunction _addRequest(span: Span, entry: PerformanceNavigationTiming, timeOrigin: number): void {\n  const requestStartTimestamp = timeOrigin + msToSec(entry.requestStart as number);\n  const responseEndTimestamp = timeOrigin + msToSec(entry.responseEnd as number);\n  const responseStartTimestamp = timeOrigin + msToSec(entry.responseStart as number);\n  if (entry.responseEnd) {\n    // It is possible that we are collecting these metrics when the page hasn't finished loading yet, for example when the HTML slowly streams in.\n    // In this case, ie. when the document request hasn't finished yet, `entry.responseEnd` will be 0.\n    // In order not to produce faulty spans, where the end timestamp is before the start timestamp, we will only collect\n    // these spans when the responseEnd value is available. The backend (Relay) would drop the entire span if it contained faulty spans.\n    startAndEndSpan(span, requestStartTimestamp, responseEndTimestamp, {\n      op: 'browser.request',\n      name: entry.name,\n      attributes: {\n        [SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: 'auto.ui.browser.metrics',\n      },\n    });\n\n    startAndEndSpan(span, responseStartTimestamp, responseEndTimestamp, {\n      op: 'browser.response',\n      name: entry.name,\n      attributes: {\n        [SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: 'auto.ui.browser.metrics',\n      },\n    });\n  }\n}\n\n/**\n * Create resource-related spans.\n * Exported only for tests.\n */\nexport function _addResourceSpans(\n  span: Span,\n  entry: PerformanceResourceTiming,\n  resourceUrl: string,\n  startTime: number,\n  duration: number,\n  timeOrigin: number,\n): void {\n  // we already instrument based on fetch and xhr, so we don't need to\n  // duplicate spans here.\n  if (entry.initiatorType === 'xmlhttprequest' || entry.initiatorType === 'fetch') {\n    return;\n  }\n\n  const parsedUrl = parseUrl(resourceUrl);\n\n  const attributes: SpanAttributes = {\n    [SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: 'auto.resource.browser.metrics',\n  };\n  setResourceEntrySizeData(attributes, entry, 'transferSize', 'http.response_transfer_size');\n  setResourceEntrySizeData(attributes, entry, 'encodedBodySize', 'http.response_content_length');\n  setResourceEntrySizeData(attributes, entry, 'decodedBodySize', 'http.decoded_response_content_length');\n\n  // `deliveryType` is experimental and does not exist everywhere\n  const deliveryType = (entry as { deliveryType?: 'cache' | 'navigational-prefetch' | '' }).deliveryType;\n  if (deliveryType != null) {\n    attributes['http.response_delivery_type'] = deliveryType;\n  }\n\n  // Types do not reflect this property yet\n  const renderBlockingStatus = (entry as { renderBlockingStatus?: 'render-blocking' | 'non-render-blocking' })\n    .renderBlockingStatus;\n  if (renderBlockingStatus) {\n    attributes['resource.render_blocking_status'] = renderBlockingStatus;\n  }\n\n  if (parsedUrl.protocol) {\n    attributes['url.scheme'] = parsedUrl.protocol.split(':').pop(); // the protocol returned by parseUrl includes a :, but OTEL spec does not, so we remove it.\n  }\n\n  if (parsedUrl.host) {\n    attributes['server.address'] = parsedUrl.host;\n  }\n\n  attributes['url.same_origin'] = resourceUrl.includes(WINDOW.location.origin);\n\n  const { name, version } = extractNetworkProtocol(entry.nextHopProtocol);\n  attributes['network.protocol.name'] = name;\n  attributes['network.protocol.version'] = version;\n\n  const startTimestamp = timeOrigin + startTime;\n  const endTimestamp = startTimestamp + duration;\n\n  startAndEndSpan(span, startTimestamp, endTimestamp, {\n    name: resourceUrl.replace(WINDOW.location.origin, ''),\n    op: entry.initiatorType ? `resource.${entry.initiatorType}` : 'resource.other',\n    attributes,\n  });\n}\n\n/**\n * Capture the information of the user agent.\n */\nfunction _trackNavigator(span: Span): void {\n  const navigator = WINDOW.navigator as null | (Navigator & NavigatorNetworkInformation & NavigatorDeviceMemory);\n  if (!navigator) {\n    return;\n  }\n\n  // track network connectivity\n  const connection = navigator.connection;\n  if (connection) {\n    if (connection.effectiveType) {\n      span.setAttribute('effectiveConnectionType', connection.effectiveType);\n    }\n\n    if (connection.type) {\n      span.setAttribute('connectionType', connection.type);\n    }\n\n    if (isMeasurementValue(connection.rtt)) {\n      _measurements['connection.rtt'] = { value: connection.rtt, unit: 'millisecond' };\n    }\n  }\n\n  if (isMeasurementValue(navigator.deviceMemory)) {\n    span.setAttribute('deviceMemory', `${navigator.deviceMemory} GB`);\n  }\n\n  if (isMeasurementValue(navigator.hardwareConcurrency)) {\n    span.setAttribute('hardwareConcurrency', String(navigator.hardwareConcurrency));\n  }\n}\n\n/** Add LCP / CLS data to span to allow debugging */\nfunction _setWebVitalAttributes(span: Span): void {\n  if (_lcpEntry) {\n    // Capture Properties of the LCP element that contributes to the LCP.\n\n    if (_lcpEntry.element) {\n      span.setAttribute('lcp.element', htmlTreeAsString(_lcpEntry.element));\n    }\n\n    if (_lcpEntry.id) {\n      span.setAttribute('lcp.id', _lcpEntry.id);\n    }\n\n    if (_lcpEntry.url) {\n      // Trim URL to the first 200 characters.\n      span.setAttribute('lcp.url', _lcpEntry.url.trim().slice(0, 200));\n    }\n\n    if (_lcpEntry.loadTime != null) {\n      // loadTime is the time of LCP that's related to receiving the LCP element response..\n      span.setAttribute('lcp.loadTime', _lcpEntry.loadTime);\n    }\n\n    if (_lcpEntry.renderTime != null) {\n      // renderTime is loadTime + rendering time\n      // it's 0 if the LCP element is loaded from a 3rd party origin that doesn't send the\n      // `Timing-Allow-Origin` header.\n      span.setAttribute('lcp.renderTime', _lcpEntry.renderTime);\n    }\n\n    span.setAttribute('lcp.size', _lcpEntry.size);\n  }\n\n  // See: https://developer.mozilla.org/en-US/docs/Web/API/LayoutShift\n  if (_clsEntry && _clsEntry.sources) {\n    _clsEntry.sources.forEach((source, index) =>\n      span.setAttribute(`cls.source.${index + 1}`, htmlTreeAsString(source.node)),\n    );\n  }\n}\n\nfunction setResourceEntrySizeData(\n  attributes: SpanAttributes,\n  entry: PerformanceResourceTiming,\n  key: keyof Pick<PerformanceResourceTiming, 'transferSize' | 'encodedBodySize' | 'decodedBodySize'>,\n  dataKey: 'http.response_transfer_size' | 'http.response_content_length' | 'http.decoded_response_content_length',\n): void {\n  const entryVal = entry[key];\n  if (entryVal != null && entryVal < MAX_INT_AS_BYTES) {\n    attributes[dataKey] = entryVal;\n  }\n}\n\n/**\n * Add ttfb request time information to measurements.\n *\n * ttfb information is added via vendored web vitals library.\n */\nfunction _addTtfbRequestTimeToMeasurements(_measurements: Measurements): void {\n  const navEntry = getNavigationEntry(false);\n  if (!navEntry) {\n    return;\n  }\n\n  const { responseStart, requestStart } = navEntry;\n\n  if (requestStart <= responseStart) {\n    _measurements['ttfb.requestTime'] = {\n      value: responseStart - requestStart,\n      unit: 'millisecond',\n    };\n  }\n}\n","import type { Span, SpanAttributes } from '@sentry/core';\nimport {\n  SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME,\n  SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT,\n  SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE,\n  SEMANTIC_ATTRIBUTE_SENTRY_OP,\n  SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN,\n  browserPerformanceTimeOrigin,\n  dropUndefinedKeys,\n  getActiveSpan,\n  getCurrentScope,\n  getRootSpan,\n  htmlTreeAsString,\n  spanToJSON,\n} from '@sentry/core';\nimport {\n  addInpInstrumentationHandler,\n  addPerformanceInstrumentationHandler,\n  isPerformanceEventTiming,\n} from './instrument';\nimport { getBrowserPerformanceAPI, msToSec, startStandaloneWebVitalSpan } from './utils';\n\nconst LAST_INTERACTIONS: number[] = [];\nconst INTERACTIONS_SPAN_MAP = new Map<number, Span>();\n\n/**\n * Start tracking INP webvital events.\n */\nexport function startTrackingINP(): () => void {\n  const performance = getBrowserPerformanceAPI();\n  if (performance && browserPerformanceTimeOrigin) {\n    const inpCallback = _trackINP();\n\n    return (): void => {\n      inpCallback();\n    };\n  }\n\n  return () => undefined;\n}\n\nconst INP_ENTRY_MAP: Record<string, 'click' | 'hover' | 'drag' | 'press'> = {\n  click: 'click',\n  pointerdown: 'click',\n  pointerup: 'click',\n  mousedown: 'click',\n  mouseup: 'click',\n  touchstart: 'click',\n  touchend: 'click',\n  mouseover: 'hover',\n  mouseout: 'hover',\n  mouseenter: 'hover',\n  mouseleave: 'hover',\n  pointerover: 'hover',\n  pointerout: 'hover',\n  pointerenter: 'hover',\n  pointerleave: 'hover',\n  dragstart: 'drag',\n  dragend: 'drag',\n  drag: 'drag',\n  dragenter: 'drag',\n  dragleave: 'drag',\n  dragover: 'drag',\n  drop: 'drag',\n  keydown: 'press',\n  keyup: 'press',\n  keypress: 'press',\n  input: 'press',\n};\n\n/** Starts tracking the Interaction to Next Paint on the current page. */\nfunction _trackINP(): () => void {\n  return addInpInstrumentationHandler(({ metric }) => {\n    if (metric.value == undefined) {\n      return;\n    }\n\n    const entry = metric.entries.find(entry => entry.duration === metric.value && INP_ENTRY_MAP[entry.name]);\n\n    if (!entry) {\n      return;\n    }\n\n    const { interactionId } = entry;\n    const interactionType = INP_ENTRY_MAP[entry.name];\n\n    /** Build the INP span, create an envelope from the span, and then send the envelope */\n    const startTime = msToSec((browserPerformanceTimeOrigin as number) + entry.startTime);\n    const duration = msToSec(metric.value);\n    const activeSpan = getActiveSpan();\n    const rootSpan = activeSpan ? getRootSpan(activeSpan) : undefined;\n\n    // We first try to lookup the span from our INTERACTIONS_SPAN_MAP,\n    // where we cache the route per interactionId\n    const cachedSpan = interactionId != null ? INTERACTIONS_SPAN_MAP.get(interactionId) : undefined;\n\n    const spanToUse = cachedSpan || rootSpan;\n\n    // Else, we try to use the active span.\n    // Finally, we fall back to look at the transactionName on the scope\n    const routeName = spanToUse ? spanToJSON(spanToUse).description : getCurrentScope().getScopeData().transactionName;\n\n    const name = htmlTreeAsString(entry.target);\n    const attributes: SpanAttributes = dropUndefinedKeys({\n      [SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: 'auto.http.browser.inp',\n      [SEMANTIC_ATTRIBUTE_SENTRY_OP]: `ui.interaction.${interactionType}`,\n      [SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME]: entry.duration,\n    });\n\n    const span = startStandaloneWebVitalSpan({\n      name,\n      transaction: routeName,\n      attributes,\n      startTime,\n    });\n\n    if (span) {\n      span.addEvent('inp', {\n        [SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT]: 'millisecond',\n        [SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE]: metric.value,\n      });\n\n      span.end(startTime + duration);\n    }\n  });\n}\n\n/**\n * Register a listener to cache route information for INP interactions.\n * TODO(v9): `latestRoute` no longer needs to be passed in and will be removed in v9.\n */\nexport function registerInpInteractionListener(_latestRoute?: unknown): void {\n  const handleEntries = ({ entries }: { entries: PerformanceEntry[] }): void => {\n    const activeSpan = getActiveSpan();\n    const activeRootSpan = activeSpan && getRootSpan(activeSpan);\n\n    entries.forEach(entry => {\n      if (!isPerformanceEventTiming(entry) || !activeRootSpan) {\n        return;\n      }\n\n      const interactionId = entry.interactionId;\n      if (interactionId == null) {\n        return;\n      }\n\n      // If the interaction was already recorded before, nothing more to do\n      if (INTERACTIONS_SPAN_MAP.has(interactionId)) {\n        return;\n      }\n\n      // We keep max. 10 interactions in the list, then remove the oldest one & clean up\n      if (LAST_INTERACTIONS.length > 10) {\n        const last = LAST_INTERACTIONS.shift() as number;\n        INTERACTIONS_SPAN_MAP.delete(last);\n      }\n\n      // We add the interaction to the list of recorded interactions\n      // and store the span for this interaction\n      LAST_INTERACTIONS.push(interactionId);\n      INTERACTIONS_SPAN_MAP.set(interactionId, activeRootSpan);\n    });\n  };\n\n  addPerformanceInstrumentationHandler('event', handleEntries);\n  addPerformanceInstrumentationHandler('first-input', handleEntries);\n}\n","import type { HandlerDataDom } from '@sentry/core';\nimport { addHandler, addNonEnumerableProperty, fill, maybeInstrument, triggerHandlers, uuid4 } from '@sentry/core';\nimport { WINDOW } from '../types';\n\ntype SentryWrappedTarget = HTMLElement & { _sentryId?: string };\n\ntype AddEventListener = (\n  type: string,\n  listener: EventListenerOrEventListenerObject,\n  options?: boolean | AddEventListenerOptions,\n) => void;\ntype RemoveEventListener = (\n  type: string,\n  listener: EventListenerOrEventListenerObject,\n  options?: boolean | EventListenerOptions,\n) => void;\n\ntype InstrumentedElement = Element & {\n  __sentry_instrumentation_handlers__?: {\n    [key in 'click' | 'keypress']?: {\n      handler?: unknown;\n      /** The number of custom listeners attached to this element */\n      refCount: number;\n    };\n  };\n};\n\nconst DEBOUNCE_DURATION = 1000;\n\nlet debounceTimerID: number | undefined;\nlet lastCapturedEventType: string | undefined;\nlet lastCapturedEventTargetId: string | undefined;\n\n/**\n * Add an instrumentation handler for when a click or a keypress happens.\n *\n * Use at your own risk, this might break without changelog notice, only used internally.\n * @hidden\n */\nexport function addClickKeypressInstrumentationHandler(handler: (data: HandlerDataDom) => void): void {\n  const type = 'dom';\n  addHandler(type, handler);\n  maybeInstrument(type, instrumentDOM);\n}\n\n/** Exported for tests only. */\nexport function instrumentDOM(): void {\n  if (!WINDOW.document) {\n    return;\n  }\n\n  // Make it so that any click or keypress that is unhandled / bubbled up all the way to the document triggers our dom\n  // handlers. (Normally we have only one, which captures a breadcrumb for each click or keypress.) Do this before\n  // we instrument `addEventListener` so that we don't end up attaching this handler twice.\n  const triggerDOMHandler = triggerHandlers.bind(null, 'dom');\n  const globalDOMEventHandler = makeDOMEventHandler(triggerDOMHandler, true);\n  WINDOW.document.addEventListener('click', globalDOMEventHandler, false);\n  WINDOW.document.addEventListener('keypress', globalDOMEventHandler, false);\n\n  // After hooking into click and keypress events bubbled up to `document`, we also hook into user-handled\n  // clicks & keypresses, by adding an event listener of our own to any element to which they add a listener. That\n  // way, whenever one of their handlers is triggered, ours will be, too. (This is needed because their handler\n  // could potentially prevent the event from bubbling up to our global listeners. This way, our handler are still\n  // guaranteed to fire at least once.)\n  ['EventTarget', 'Node'].forEach((target: string) => {\n    const globalObject = WINDOW as unknown as Record<string, { prototype?: object }>;\n    const targetObj = globalObject[target];\n    const proto = targetObj && targetObj.prototype;\n\n    // eslint-disable-next-line no-prototype-builtins\n    if (!proto || !proto.hasOwnProperty || !proto.hasOwnProperty('addEventListener')) {\n      return;\n    }\n\n    fill(proto, 'addEventListener', function (originalAddEventListener: AddEventListener): AddEventListener {\n      return function (this: InstrumentedElement, type, listener, options): AddEventListener {\n        if (type === 'click' || type == 'keypress') {\n          try {\n            const handlers = (this.__sentry_instrumentation_handlers__ =\n              this.__sentry_instrumentation_handlers__ || {});\n            const handlerForType = (handlers[type] = handlers[type] || { refCount: 0 });\n\n            if (!handlerForType.handler) {\n              const handler = makeDOMEventHandler(triggerDOMHandler);\n              handlerForType.handler = handler;\n              originalAddEventListener.call(this, type, handler, options);\n            }\n\n            handlerForType.refCount++;\n          } catch (e) {\n            // Accessing dom properties is always fragile.\n            // Also allows us to skip `addEventListeners` calls with no proper `this` context.\n          }\n        }\n\n        return originalAddEventListener.call(this, type, listener, options);\n      };\n    });\n\n    fill(\n      proto,\n      'removeEventListener',\n      function (originalRemoveEventListener: RemoveEventListener): RemoveEventListener {\n        return function (this: InstrumentedElement, type, listener, options): () => void {\n          if (type === 'click' || type == 'keypress') {\n            try {\n              const handlers = this.__sentry_instrumentation_handlers__ || {};\n              const handlerForType = handlers[type];\n\n              if (handlerForType) {\n                handlerForType.refCount--;\n                // If there are no longer any custom handlers of the current type on this element, we can remove ours, too.\n                if (handlerForType.refCount <= 0) {\n                  originalRemoveEventListener.call(this, type, handlerForType.handler, options);\n                  handlerForType.handler = undefined;\n                  delete handlers[type]; // eslint-disable-line @typescript-eslint/no-dynamic-delete\n                }\n\n                // If there are no longer any custom handlers of any type on this element, cleanup everything.\n                if (Object.keys(handlers).length === 0) {\n                  delete this.__sentry_instrumentation_handlers__;\n                }\n              }\n            } catch (e) {\n              // Accessing dom properties is always fragile.\n              // Also allows us to skip `addEventListeners` calls with no proper `this` context.\n            }\n          }\n\n          return originalRemoveEventListener.call(this, type, listener, options);\n        };\n      },\n    );\n  });\n}\n\n/**\n * Check whether the event is similar to the last captured one. For example, two click events on the same button.\n */\nfunction isSimilarToLastCapturedEvent(event: Event): boolean {\n  // If both events have different type, then user definitely performed two separate actions. e.g. click + keypress.\n  if (event.type !== lastCapturedEventType) {\n    return false;\n  }\n\n  try {\n    // If both events have the same type, it's still possible that actions were performed on different targets.\n    // e.g. 2 clicks on different buttons.\n    if (!event.target || (event.target as SentryWrappedTarget)._sentryId !== lastCapturedEventTargetId) {\n      return false;\n    }\n  } catch (e) {\n    // just accessing `target` property can throw an exception in some rare circumstances\n    // see: https://github.com/getsentry/sentry-javascript/issues/838\n  }\n\n  // If both events have the same type _and_ same `target` (an element which triggered an event, _not necessarily_\n  // to which an event listener was attached), we treat them as the same action, as we want to capture\n  // only one breadcrumb. e.g. multiple clicks on the same button, or typing inside a user input box.\n  return true;\n}\n\n/**\n * Decide whether an event should be captured.\n * @param event event to be captured\n */\nfunction shouldSkipDOMEvent(eventType: string, target: SentryWrappedTarget | null): boolean {\n  // We are only interested in filtering `keypress` events for now.\n  if (eventType !== 'keypress') {\n    return false;\n  }\n\n  if (!target || !target.tagName) {\n    return true;\n  }\n\n  // Only consider keypress events on actual input elements. This will disregard keypresses targeting body\n  // e.g.tabbing through elements, hotkeys, etc.\n  if (target.tagName === 'INPUT' || target.tagName === 'TEXTAREA' || target.isContentEditable) {\n    return false;\n  }\n\n  return true;\n}\n\n/**\n * Wraps addEventListener to capture UI breadcrumbs\n */\nfunction makeDOMEventHandler(\n  handler: (data: HandlerDataDom) => void,\n  globalListener: boolean = false,\n): (event: Event) => void {\n  return (event: Event & { _sentryCaptured?: true }): void => {\n    // It's possible this handler might trigger multiple times for the same\n    // event (e.g. event propagation through node ancestors).\n    // Ignore if we've already captured that event.\n    if (!event || event['_sentryCaptured']) {\n      return;\n    }\n\n    const target = getEventTarget(event);\n\n    // We always want to skip _some_ events.\n    if (shouldSkipDOMEvent(event.type, target)) {\n      return;\n    }\n\n    // Mark event as \"seen\"\n    addNonEnumerableProperty(event, '_sentryCaptured', true);\n\n    if (target && !target._sentryId) {\n      // Add UUID to event target so we can identify if\n      addNonEnumerableProperty(target, '_sentryId', uuid4());\n    }\n\n    const name = event.type === 'keypress' ? 'input' : event.type;\n\n    // If there is no last captured event, it means that we can safely capture the new event and store it for future comparisons.\n    // If there is a last captured event, see if the new event is different enough to treat it as a unique one.\n    // If that's the case, emit the previous event and store locally the newly-captured DOM event.\n    if (!isSimilarToLastCapturedEvent(event)) {\n      const handlerData: HandlerDataDom = { event, name, global: globalListener };\n      handler(handlerData);\n      lastCapturedEventType = event.type;\n      lastCapturedEventTargetId = target ? target._sentryId : undefined;\n    }\n\n    // Start a new debounce timer that will prevent us from capturing multiple events that should be grouped together.\n    clearTimeout(debounceTimerID);\n    debounceTimerID = WINDOW.setTimeout(() => {\n      lastCapturedEventTargetId = undefined;\n      lastCapturedEventType = undefined;\n    }, DEBOUNCE_DURATION);\n  };\n}\n\nfunction getEventTarget(event: Event): SentryWrappedTarget | null {\n  try {\n    return event.target as SentryWrappedTarget | null;\n  } catch (e) {\n    // just accessing `target` property can throw an exception in some rare circumstances\n    // see: https://github.com/getsentry/sentry-javascript/issues/838\n    return null;\n  }\n}\n","import type { Integration, SentrySpan, Span, SpanAttributes, SpanTimeInput, StartSpanOptions } from '@sentry/core';\nimport { getClient, getCurrentScope, spanToJSON, startInactiveSpan, withActiveSpan } from '@sentry/core';\nimport { WINDOW } from '../types';\n\n/**\n * Checks if a given value is a valid measurement value.\n */\nexport function isMeasurementValue(value: unknown): value is number {\n  return typeof value === 'number' && isFinite(value);\n}\n\n/**\n * Helper function to start child on transactions. This function will make sure that the transaction will\n * use the start timestamp of the created child span if it is earlier than the transactions actual\n * start timestamp.\n */\nexport function startAndEndSpan(\n  parentSpan: Span,\n  startTimeInSeconds: number,\n  endTime: SpanTimeInput,\n  { ...ctx }: StartSpanOptions,\n): Span | undefined {\n  const parentStartTime = spanToJSON(parentSpan).start_timestamp;\n  if (parentStartTime && parentStartTime > startTimeInSeconds) {\n    // We can only do this for SentrySpans...\n    if (typeof (parentSpan as Partial<SentrySpan>).updateStartTime === 'function') {\n      (parentSpan as SentrySpan).updateStartTime(startTimeInSeconds);\n    }\n  }\n\n  // The return value only exists for tests\n  return withActiveSpan(parentSpan, () => {\n    const span = startInactiveSpan({\n      startTime: startTimeInSeconds,\n      ...ctx,\n    });\n\n    if (span) {\n      span.end(endTime);\n    }\n\n    return span;\n  });\n}\n\ninterface StandaloneWebVitalSpanOptions {\n  name: string;\n  transaction?: string;\n  attributes: SpanAttributes;\n  startTime: number;\n}\n\n/**\n * Starts an inactive, standalone span used to send web vital values to Sentry.\n * DO NOT use this for arbitrary spans, as these spans require special handling\n * during ingestion to extract metrics.\n *\n * This function adds a bunch of attributes and data to the span that's shared\n * by all web vital standalone spans. However, you need to take care of adding\n * the actual web vital value as an event to the span. Also, you need to assign\n * a transaction name and some other values that are specific to the web vital.\n *\n * Ultimately, you also need to take care of ending the span to send it off.\n *\n * @param options\n *\n * @returns an inactive, standalone and NOT YET ended span\n */\nexport function startStandaloneWebVitalSpan(options: StandaloneWebVitalSpanOptions): Span | undefined {\n  const client = getClient();\n  if (!client) {\n    return;\n  }\n\n  const { name, transaction, attributes: passedAttributes, startTime } = options;\n\n  const { release, environment } = client.getOptions();\n  // We need to get the replay, user, and activeTransaction from the current scope\n  // so that we can associate replay id, profile id, and a user display to the span\n  const replay = client.getIntegrationByName<Integration & { getReplayId: () => string }>('Replay');\n  const replayId = replay && replay.getReplayId();\n\n  const scope = getCurrentScope();\n\n  const user = scope.getUser();\n  const userDisplay = user !== undefined ? user.email || user.id || user.ip_address : undefined;\n\n  let profileId: string | undefined;\n  try {\n    // @ts-expect-error skip optional chaining to save bundle size with try catch\n    profileId = scope.getScopeData().contexts.profile.profile_id;\n  } catch {\n    // do nothing\n  }\n\n  const attributes: SpanAttributes = {\n    release,\n    environment,\n\n    user: userDisplay || undefined,\n    profile_id: profileId || undefined,\n    replay_id: replayId || undefined,\n\n    transaction,\n\n    // Web vital score calculation relies on the user agent to account for different\n    // browsers setting different thresholds for what is considered a good/meh/bad value.\n    // For example: Chrome vs. Chrome Mobile\n    'user_agent.original': WINDOW.navigator && WINDOW.navigator.userAgent,\n\n    ...passedAttributes,\n  };\n\n  return startInactiveSpan({\n    name,\n    attributes,\n    startTime,\n    experimental: {\n      standalone: true,\n    },\n  });\n}\n\n/** Get the browser performance API. */\nexport function getBrowserPerformanceAPI(): Performance | undefined {\n  // @ts-expect-error we want to make sure all of these are available, even if TS is sure they are\n  return WINDOW && WINDOW.addEventListener && WINDOW.performance;\n}\n\n/**\n * Converts from milliseconds to seconds\n * @param time time in ms\n */\nexport function msToSec(time: number): number {\n  return time / 1000;\n}\n\n/**\n * Converts ALPN protocol ids to name and version.\n *\n * (https://www.iana.org/assignments/tls-extensiontype-values/tls-extensiontype-values.xhtml#alpn-protocol-ids)\n * @param nextHopProtocol PerformanceResourceTiming.nextHopProtocol\n */\nexport function extractNetworkProtocol(nextHopProtocol: string): { name: string; version: string } {\n  let name = 'unknown';\n  let version = 'unknown';\n  let _name = '';\n  for (const char of nextHopProtocol) {\n    // http/1.1 etc.\n    if (char === '/') {\n      [name, version] = nextHopProtocol.split('/') as [string, string];\n      break;\n    }\n    // h2, h3 etc.\n    if (!isNaN(Number(char))) {\n      name = _name === 'h' ? 'http' : _name;\n      version = nextHopProtocol.split(_name)[1] as string;\n      break;\n    }\n    _name += char;\n  }\n  if (_name === nextHopProtocol) {\n    // webrtc, ftp, etc.\n    name = _name;\n  }\n  return { name, version };\n}\n","/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { MetricRatingThresholds, MetricType } from '../types';\n\nconst getRating = (value: number, thresholds: MetricRatingThresholds): MetricType['rating'] => {\n  if (value > thresholds[1]) {\n    return 'poor';\n  }\n  if (value > thresholds[0]) {\n    return 'needs-improvement';\n  }\n  return 'good';\n};\n\nexport const bindReporter = <MetricName extends MetricType['name']>(\n  callback: (metric: Extract<MetricType, { name: MetricName }>) => void,\n  metric: Extract<MetricType, { name: MetricName }>,\n  thresholds: MetricRatingThresholds,\n  reportAllChanges?: boolean,\n) => {\n  let prevValue: number;\n  let delta: number;\n  return (forceReport?: boolean) => {\n    if (metric.value >= 0) {\n      if (forceReport || reportAllChanges) {\n        delta = metric.value - (prevValue || 0);\n\n        // Report the metric if there's a non-zero delta or if no previous\n        // value exists (which can happen in the case of the document becoming\n        // hidden when the metric value is 0).\n        // See: https://github.com/GoogleChrome/web-vitals/issues/14\n        if (delta || prevValue === undefined) {\n          prevValue = metric.value;\n          metric.delta = delta;\n          metric.rating = getRating(metric.value, thresholds);\n          callback(metric);\n        }\n      }\n    }\n  };\n};\n","/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * Performantly generate a unique, 30-char string by combining a version\n * number, the current timestamp with a 13-digit number integer.\n * @return {string}\n */\nexport const generateUniqueID = () => {\n  return `v4-${Date.now()}-${Math.floor(Math.random() * (9e12 - 1)) + 1e12}`;\n};\n","/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { WINDOW } from '../../../types';\nimport type { MetricType } from '../types';\nimport { generateUniqueID } from './generateUniqueID';\nimport { getActivationStart } from './getActivationStart';\nimport { getNavigationEntry } from './getNavigationEntry';\n\nexport const initMetric = <MetricName extends MetricType['name']>(name: MetricName, value?: number) => {\n  const navEntry = getNavigationEntry();\n  let navigationType: MetricType['navigationType'] = 'navigate';\n\n  if (navEntry) {\n    if ((WINDOW.document && WINDOW.document.prerendering) || getActivationStart() > 0) {\n      navigationType = 'prerender';\n    } else if (WINDOW.document && WINDOW.document.wasDiscarded) {\n      navigationType = 'restore';\n    } else if (navEntry.type) {\n      navigationType = navEntry.type.replace(/_/g, '-') as MetricType['navigationType'];\n    }\n  }\n\n  // Use `entries` type specific for the metric.\n  const entries: Extract<MetricType, { name: MetricName }>['entries'] = [];\n\n  return {\n    name,\n    value: typeof value === 'undefined' ? -1 : value,\n    rating: 'good' as const, // If needed, will be updated when reported. `const` to keep the type from widening to `string`.\n    delta: 0,\n    entries,\n    id: generateUniqueID(),\n    navigationType,\n  };\n};\n","/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\ninterface PerformanceEntryMap {\n  event: PerformanceEventTiming[];\n  'first-input': PerformanceEventTiming[];\n  'layout-shift': LayoutShift[];\n  'largest-contentful-paint': LargestContentfulPaint[];\n  'long-animation-frame': PerformanceLongAnimationFrameTiming[];\n  paint: PerformancePaintTiming[];\n  navigation: PerformanceNavigationTiming[];\n  resource: PerformanceResourceTiming[];\n  // Sentry-specific change:\n  // We add longtask as a supported entry type as we use this in\n  // our `instrumentPerformanceObserver` function also observes 'longtask'\n  // entries.\n  longtask: PerformanceEntry[];\n}\n\n/**\n * Takes a performance entry type and a callback function, and creates a\n * `PerformanceObserver` instance that will observe the specified entry type\n * with buffering enabled and call the callback _for each entry_.\n *\n * This function also feature-detects entry support and wraps the logic in a\n * try/catch to avoid errors in unsupporting browsers.\n */\nexport const observe = <K extends keyof PerformanceEntryMap>(\n  type: K,\n  callback: (entries: PerformanceEntryMap[K]) => void,\n  opts?: PerformanceObserverInit,\n): PerformanceObserver | undefined => {\n  try {\n    if (PerformanceObserver.supportedEntryTypes.includes(type)) {\n      const po = new PerformanceObserver(list => {\n        // Delay by a microtask to workaround a bug in Safari where the\n        // callback is invoked immediately, rather than in a separate task.\n        // See: https://github.com/GoogleChrome/web-vitals/issues/277\n        // eslint-disable-next-line @typescript-eslint/no-floating-promises\n        Promise.resolve().then(() => {\n          callback(list.getEntries() as PerformanceEntryMap[K]);\n        });\n      });\n      po.observe(\n        Object.assign(\n          {\n            type,\n            buffered: true,\n          },\n          opts || {},\n        ) as PerformanceObserverInit,\n      );\n      return po;\n    }\n  } catch (e) {\n    // Do nothing.\n  }\n  return;\n};\n","/*\n * Copyright 2022 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nexport const runOnce = (cb: () => void) => {\n  let called = false;\n  return () => {\n    if (!called) {\n      cb();\n      called = true;\n    }\n  };\n};\n","/*\n * Copyright 2022 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { WINDOW } from '../../../types';\n\nexport const whenActivated = (callback: () => void) => {\n  if (WINDOW.document && WINDOW.document.prerendering) {\n    addEventListener('prerenderingchange', () => callback(), true);\n  } else {\n    callback();\n  }\n};\n","/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { bindReporter } from './lib/bindReporter';\nimport { getActivationStart } from './lib/getActivationStart';\nimport { getVisibilityWatcher } from './lib/getVisibilityWatcher';\nimport { initMetric } from './lib/initMetric';\nimport { observe } from './lib/observe';\nimport { whenActivated } from './lib/whenActivated';\nimport type { FCPMetric, MetricRatingThresholds, ReportOpts } from './types';\n\n/** Thresholds for FCP. See https://web.dev/articles/fcp#what_is_a_good_fcp_score */\nexport const FCPThresholds: MetricRatingThresholds = [1800, 3000];\n\n/**\n * Calculates the [FCP](https://web.dev/articles/fcp) value for the current page and\n * calls the `callback` function once the value is ready, along with the\n * relevant `paint` performance entry used to determine the value. The reported\n * value is a `DOMHighResTimeStamp`.\n */\nexport const onFCP = (onReport: (metric: FCPMetric) => void, opts: ReportOpts = {}) => {\n  whenActivated(() => {\n    const visibilityWatcher = getVisibilityWatcher();\n    const metric = initMetric('FCP');\n    let report: ReturnType<typeof bindReporter>;\n\n    const handleEntries = (entries: FCPMetric['entries']) => {\n      entries.forEach(entry => {\n        if (entry.name === 'first-contentful-paint') {\n          po!.disconnect();\n\n          // Only report if the page wasn't hidden prior to the first paint.\n          if (entry.startTime < visibilityWatcher.firstHiddenTime) {\n            // The activationStart reference is used because FCP should be\n            // relative to page activation rather than navigation start if the\n            // page was prerendered. But in cases where `activationStart` occurs\n            // after the FCP, this time should be clamped at 0.\n            metric.value = Math.max(entry.startTime - getActivationStart(), 0);\n            metric.entries.push(entry);\n            report(true);\n          }\n        }\n      });\n    };\n\n    const po = observe('paint', handleEntries);\n\n    if (po) {\n      report = bindReporter(onReport, metric, FCPThresholds, opts.reportAllChanges);\n    }\n  });\n};\n","/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { bindReporter } from './lib/bindReporter';\nimport { initMetric } from './lib/initMetric';\nimport { observe } from './lib/observe';\nimport { onHidden } from './lib/onHidden';\nimport { runOnce } from './lib/runOnce';\nimport { onFCP } from './onFCP';\nimport type { CLSMetric, MetricRatingThresholds, ReportOpts } from './types';\n\n/** Thresholds for CLS. See https://web.dev/articles/cls#what_is_a_good_cls_score */\nexport const CLSThresholds: MetricRatingThresholds = [0.1, 0.25];\n\n/**\n * Calculates the [CLS](https://web.dev/articles/cls) value for the current page and\n * calls the `callback` function once the value is ready to be reported, along\n * with all `layout-shift` performance entries that were used in the metric\n * value calculation. The reported value is a `double` (corresponding to a\n * [layout shift score](https://web.dev/articles/cls#layout_shift_score)).\n *\n * If the `reportAllChanges` configuration option is set to `true`, the\n * `callback` function will be called as soon as the value is initially\n * determined as well as any time the value changes throughout the page\n * lifespan.\n *\n * _**Important:** CLS should be continually monitored for changes throughout\n * the entire lifespan of a page—including if the user returns to the page after\n * it's been hidden/backgrounded. However, since browsers often [will not fire\n * additional callbacks once the user has backgrounded a\n * page](https://developer.chrome.com/blog/page-lifecycle-api/#advice-hidden),\n * `callback` is always called when the page's visibility state changes to\n * hidden. As a result, the `callback` function might be called multiple times\n * during the same page load._\n */\nexport const onCLS = (onReport: (metric: CLSMetric) => void, opts: ReportOpts = {}) => {\n  // Start monitoring FCP so we can only report CLS if FCP is also reported.\n  // Note: this is done to match the current behavior of CrUX.\n  onFCP(\n    runOnce(() => {\n      const metric = initMetric('CLS', 0);\n      let report: ReturnType<typeof bindReporter>;\n\n      let sessionValue = 0;\n      let sessionEntries: LayoutShift[] = [];\n\n      const handleEntries = (entries: LayoutShift[]) => {\n        entries.forEach(entry => {\n          // Only count layout shifts without recent user input.\n          if (!entry.hadRecentInput) {\n            const firstSessionEntry = sessionEntries[0];\n            const lastSessionEntry = sessionEntries[sessionEntries.length - 1];\n\n            // If the entry occurred less than 1 second after the previous entry\n            // and less than 5 seconds after the first entry in the session,\n            // include the entry in the current session. Otherwise, start a new\n            // session.\n            if (\n              sessionValue &&\n              firstSessionEntry &&\n              lastSessionEntry &&\n              entry.startTime - lastSessionEntry.startTime < 1000 &&\n              entry.startTime - firstSessionEntry.startTime < 5000\n            ) {\n              sessionValue += entry.value;\n              sessionEntries.push(entry);\n            } else {\n              sessionValue = entry.value;\n              sessionEntries = [entry];\n            }\n          }\n        });\n\n        // If the current session value is larger than the current CLS value,\n        // update CLS and the entries contributing to it.\n        if (sessionValue > metric.value) {\n          metric.value = sessionValue;\n          metric.entries = sessionEntries;\n          report();\n        }\n      };\n\n      const po = observe('layout-shift', handleEntries);\n      if (po) {\n        report = bindReporter(onReport, metric, CLSThresholds, opts.reportAllChanges);\n\n        onHidden(() => {\n          handleEntries(po.takeRecords() as CLSMetric['entries']);\n          report(true);\n        });\n\n        // Queue a task to report (if nothing else triggers a report first).\n        // This allows CLS to be reported as soon as FCP fires when\n        // `reportAllChanges` is true.\n        setTimeout(report, 0);\n      }\n    }),\n  );\n};\n","/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { bindReporter } from './lib/bindReporter';\nimport { getVisibilityWatcher } from './lib/getVisibilityWatcher';\nimport { initMetric } from './lib/initMetric';\nimport { observe } from './lib/observe';\nimport { onHidden } from './lib/onHidden';\nimport { runOnce } from './lib/runOnce';\nimport { whenActivated } from './lib/whenActivated';\nimport type { FIDMetric, MetricRatingThresholds, ReportOpts } from './types';\n\n/** Thresholds for FID. See https://web.dev/articles/fid#what_is_a_good_fid_score */\nexport const FIDThresholds: MetricRatingThresholds = [100, 300];\n\n/**\n * Calculates the [FID](https://web.dev/articles/fid) value for the current page and\n * calls the `callback` function once the value is ready, along with the\n * relevant `first-input` performance entry used to determine the value. The\n * reported value is a `DOMHighResTimeStamp`.\n *\n * _**Important:** since FID is only reported after the user interacts with the\n * page, it's possible that it will not be reported for some page loads._\n */\nexport const onFID = (onReport: (metric: FIDMetric) => void, opts: ReportOpts = {}) => {\n  whenActivated(() => {\n    const visibilityWatcher = getVisibilityWatcher();\n    const metric = initMetric('FID');\n    // eslint-disable-next-line prefer-const\n    let report: ReturnType<typeof bindReporter>;\n\n    const handleEntry = (entry: PerformanceEventTiming): void => {\n      // Only report if the page wasn't hidden prior to the first input.\n      if (entry.startTime < visibilityWatcher.firstHiddenTime) {\n        metric.value = entry.processingStart - entry.startTime;\n        metric.entries.push(entry);\n        report(true);\n      }\n    };\n\n    const handleEntries = (entries: FIDMetric['entries']) => {\n      (entries as PerformanceEventTiming[]).forEach(handleEntry);\n    };\n\n    const po = observe('first-input', handleEntries);\n\n    report = bindReporter(onReport, metric, FIDThresholds, opts.reportAllChanges);\n\n    if (po) {\n      onHidden(\n        runOnce(() => {\n          handleEntries(po.takeRecords() as FIDMetric['entries']);\n          po.disconnect();\n        }),\n      );\n    }\n  });\n};\n","/*\n * Copyright 2022 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { observe } from '../observe';\n\ndeclare global {\n  interface Performance {\n    interactionCount: number;\n  }\n}\n\nlet interactionCountEstimate = 0;\nlet minKnownInteractionId = Infinity;\nlet maxKnownInteractionId = 0;\n\nconst updateEstimate = (entries: PerformanceEventTiming[]) => {\n  entries.forEach(e => {\n    if (e.interactionId) {\n      minKnownInteractionId = Math.min(minKnownInteractionId, e.interactionId);\n      maxKnownInteractionId = Math.max(maxKnownInteractionId, e.interactionId);\n\n      interactionCountEstimate = maxKnownInteractionId ? (maxKnownInteractionId - minKnownInteractionId) / 7 + 1 : 0;\n    }\n  });\n};\n\nlet po: PerformanceObserver | undefined;\n\n/**\n * Returns the `interactionCount` value using the native API (if available)\n * or the polyfill estimate in this module.\n */\nexport const getInteractionCount = (): number => {\n  return po ? interactionCountEstimate : performance.interactionCount || 0;\n};\n\n/**\n * Feature detects native support or initializes the polyfill if needed.\n */\nexport const initInteractionCountPolyfill = (): void => {\n  if ('interactionCount' in performance || po) return;\n\n  po = observe('event', updateEstimate, {\n    type: 'event',\n    buffered: true,\n    durationThreshold: 0,\n  } as PerformanceObserverInit);\n};\n","/*\n * Copyright 2024 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { getInteractionCount } from './polyfills/interactionCountPolyfill';\n\ninterface Interaction {\n  id: number;\n  latency: number;\n  entries: PerformanceEventTiming[];\n}\n\ninterface EntryPreProcessingHook {\n  (entry: PerformanceEventTiming): void;\n}\n\n// A list of longest interactions on the page (by latency) sorted so the\n// longest one is first. The list is at most MAX_INTERACTIONS_TO_CONSIDER long.\nexport const longestInteractionList: Interaction[] = [];\n\n// A mapping of longest interactions by their interaction ID.\n// This is used for faster lookup.\nexport const longestInteractionMap: Map<number, Interaction> = new Map();\n\n// The default `durationThreshold` used across this library for observing\n// `event` entries via PerformanceObserver.\nexport const DEFAULT_DURATION_THRESHOLD = 40;\n\n// Used to store the interaction count after a bfcache restore, since p98\n// interaction latencies should only consider the current navigation.\nlet prevInteractionCount = 0;\n\n/**\n * Returns the interaction count since the last bfcache restore (or for the\n * full page lifecycle if there were no bfcache restores).\n */\nconst getInteractionCountForNavigation = () => {\n  return getInteractionCount() - prevInteractionCount;\n};\n\nexport const resetInteractions = () => {\n  prevInteractionCount = getInteractionCount();\n  longestInteractionList.length = 0;\n  longestInteractionMap.clear();\n};\n\n/**\n * Returns the estimated p98 longest interaction based on the stored\n * interaction candidates and the interaction count for the current page.\n */\nexport const estimateP98LongestInteraction = () => {\n  const candidateInteractionIndex = Math.min(\n    longestInteractionList.length - 1,\n    Math.floor(getInteractionCountForNavigation() / 50),\n  );\n\n  return longestInteractionList[candidateInteractionIndex];\n};\n\n// To prevent unnecessary memory usage on pages with lots of interactions,\n// store at most 10 of the longest interactions to consider as INP candidates.\nconst MAX_INTERACTIONS_TO_CONSIDER = 10;\n\n/**\n * A list of callback functions to run before each entry is processed.\n * Exposing this list allows the attribution build to hook into the\n * entry processing pipeline.\n */\nexport const entryPreProcessingCallbacks: EntryPreProcessingHook[] = [];\n\n/**\n * Takes a performance entry and adds it to the list of worst interactions\n * if its duration is long enough to make it among the worst. If the\n * entry is part of an existing interaction, it is merged and the latency\n * and entries list is updated as needed.\n */\nexport const processInteractionEntry = (entry: PerformanceEventTiming) => {\n  entryPreProcessingCallbacks.forEach(cb => cb(entry));\n\n  // Skip further processing for entries that cannot be INP candidates.\n  if (!(entry.interactionId || entry.entryType === 'first-input')) return;\n\n  // The least-long of the 10 longest interactions.\n  const minLongestInteraction = longestInteractionList[longestInteractionList.length - 1];\n\n  const existingInteraction = longestInteractionMap.get(entry.interactionId!);\n\n  // Only process the entry if it's possibly one of the ten longest,\n  // or if it's part of an existing interaction.\n  if (\n    existingInteraction ||\n    longestInteractionList.length < MAX_INTERACTIONS_TO_CONSIDER ||\n    (minLongestInteraction && entry.duration > minLongestInteraction.latency)\n  ) {\n    // If the interaction already exists, update it. Otherwise create one.\n    if (existingInteraction) {\n      // If the new entry has a longer duration, replace the old entries,\n      // otherwise add to the array.\n      if (entry.duration > existingInteraction.latency) {\n        existingInteraction.entries = [entry];\n        existingInteraction.latency = entry.duration;\n      } else if (\n        entry.duration === existingInteraction.latency &&\n        entry.startTime === (existingInteraction.entries[0] && existingInteraction.entries[0].startTime)\n      ) {\n        existingInteraction.entries.push(entry);\n      }\n    } else {\n      const interaction = {\n        id: entry.interactionId!,\n        latency: entry.duration,\n        entries: [entry],\n      };\n      longestInteractionMap.set(interaction.id, interaction);\n      longestInteractionList.push(interaction);\n    }\n\n    // Sort the entries by latency (descending) and keep only the top ten.\n    longestInteractionList.sort((a, b) => b.latency - a.latency);\n    if (longestInteractionList.length > MAX_INTERACTIONS_TO_CONSIDER) {\n      longestInteractionList.splice(MAX_INTERACTIONS_TO_CONSIDER).forEach(i => longestInteractionMap.delete(i.id));\n    }\n  }\n};\n","/*\n * Copyright 2024 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { WINDOW } from '../../../types';\nimport { onHidden } from './onHidden';\nimport { runOnce } from './runOnce';\n\n/**\n * Runs the passed callback during the next idle period, or immediately\n * if the browser's visibility state is (or becomes) hidden.\n */\nexport const whenIdle = (cb: () => void): number => {\n  const rIC = WINDOW.requestIdleCallback || WINDOW.setTimeout;\n\n  let handle = -1;\n  // eslint-disable-next-line no-param-reassign\n  cb = runOnce(cb) as () => void;\n  // If the document is hidden, run the callback immediately, otherwise\n  // race an idle callback with the next `visibilitychange` event.\n  if (WINDOW.document && WINDOW.document.visibilityState === 'hidden') {\n    cb();\n  } else {\n    handle = rIC(cb);\n    onHidden(cb);\n  }\n  return handle;\n};\n","/*\n * Copyright 2022 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { WINDOW } from '../../types';\nimport { bindReporter } from './lib/bindReporter';\nimport { initMetric } from './lib/initMetric';\nimport { DEFAULT_DURATION_THRESHOLD, estimateP98LongestInteraction, processInteractionEntry } from './lib/interactions';\nimport { observe } from './lib/observe';\nimport { onHidden } from './lib/onHidden';\nimport { initInteractionCountPolyfill } from './lib/polyfills/interactionCountPolyfill';\nimport { whenActivated } from './lib/whenActivated';\nimport { whenIdle } from './lib/whenIdle';\n\nimport type { INPMetric, MetricRatingThresholds, ReportOpts } from './types';\n\n/** Thresholds for INP. See https://web.dev/articles/inp#what_is_a_good_inp_score */\nexport const INPThresholds: MetricRatingThresholds = [200, 500];\n\n/**\n * Calculates the [INP](https://web.dev/articles/inp) value for the current\n * page and calls the `callback` function once the value is ready, along with\n * the `event` performance entries reported for that interaction. The reported\n * value is a `DOMHighResTimeStamp`.\n *\n * A custom `durationThreshold` configuration option can optionally be passed to\n * control what `event-timing` entries are considered for INP reporting. The\n * default threshold is `40`, which means INP scores of less than 40 are\n * reported as 0. Note that this will not affect your 75th percentile INP value\n * unless that value is also less than 40 (well below the recommended\n * [good](https://web.dev/articles/inp#what_is_a_good_inp_score) threshold).\n *\n * If the `reportAllChanges` configuration option is set to `true`, the\n * `callback` function will be called as soon as the value is initially\n * determined as well as any time the value changes throughout the page\n * lifespan.\n *\n * _**Important:** INP should be continually monitored for changes throughout\n * the entire lifespan of a page—including if the user returns to the page after\n * it's been hidden/backgrounded. However, since browsers often [will not fire\n * additional callbacks once the user has backgrounded a\n * page](https://developer.chrome.com/blog/page-lifecycle-api/#advice-hidden),\n * `callback` is always called when the page's visibility state changes to\n * hidden. As a result, the `callback` function might be called multiple times\n * during the same page load._\n */\nexport const onINP = (onReport: (metric: INPMetric) => void, opts: ReportOpts = {}) => {\n  // Return if the browser doesn't support all APIs needed to measure INP.\n  if (!('PerformanceEventTiming' in WINDOW && 'interactionId' in PerformanceEventTiming.prototype)) {\n    return;\n  }\n\n  whenActivated(() => {\n    // TODO(philipwalton): remove once the polyfill is no longer needed.\n    initInteractionCountPolyfill();\n\n    const metric = initMetric('INP');\n    // eslint-disable-next-line prefer-const\n    let report: ReturnType<typeof bindReporter>;\n\n    const handleEntries = (entries: INPMetric['entries']) => {\n      // Queue the `handleEntries()` callback in the next idle task.\n      // This is needed to increase the chances that all event entries that\n      // occurred between the user interaction and the next paint\n      // have been dispatched. Note: there is currently an experiment\n      // running in Chrome (EventTimingKeypressAndCompositionInteractionId)\n      // 123+ that if rolled out fully may make this no longer necessary.\n      whenIdle(() => {\n        entries.forEach(processInteractionEntry);\n\n        const inp = estimateP98LongestInteraction();\n\n        if (inp && inp.latency !== metric.value) {\n          metric.value = inp.latency;\n          metric.entries = inp.entries;\n          report();\n        }\n      });\n    };\n\n    const po = observe('event', handleEntries, {\n      // Event Timing entries have their durations rounded to the nearest 8ms,\n      // so a duration of 40ms would be any event that spans 2.5 or more frames\n      // at 60Hz. This threshold is chosen to strike a balance between usefulness\n      // and performance. Running this callback for any interaction that spans\n      // just one or two frames is likely not worth the insight that could be\n      // gained.\n      durationThreshold: opts.durationThreshold != null ? opts.durationThreshold : DEFAULT_DURATION_THRESHOLD,\n    });\n\n    report = bindReporter(onReport, metric, INPThresholds, opts.reportAllChanges);\n\n    if (po) {\n      // Also observe entries of type `first-input`. This is useful in cases\n      // where the first interaction is less than the `durationThreshold`.\n      po.observe({ type: 'first-input', buffered: true });\n\n      onHidden(() => {\n        handleEntries(po.takeRecords() as INPMetric['entries']);\n        report(true);\n      });\n    }\n  });\n};\n","/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { WINDOW } from '../../types';\nimport { bindReporter } from './lib/bindReporter';\nimport { getActivationStart } from './lib/getActivationStart';\nimport { getVisibilityWatcher } from './lib/getVisibilityWatcher';\nimport { initMetric } from './lib/initMetric';\nimport { observe } from './lib/observe';\nimport { onHidden } from './lib/onHidden';\nimport { runOnce } from './lib/runOnce';\nimport { whenActivated } from './lib/whenActivated';\nimport { whenIdle } from './lib/whenIdle';\nimport type { LCPMetric, MetricRatingThresholds, ReportOpts } from './types';\n\n/** Thresholds for LCP. See https://web.dev/articles/lcp#what_is_a_good_lcp_score */\nexport const LCPThresholds: MetricRatingThresholds = [2500, 4000];\n\nconst reportedMetricIDs: Record<string, boolean> = {};\n\n/**\n * Calculates the [LCP](https://web.dev/articles/lcp) value for the current page and\n * calls the `callback` function once the value is ready (along with the\n * relevant `largest-contentful-paint` performance entry used to determine the\n * value). The reported value is a `DOMHighResTimeStamp`.\n *\n * If the `reportAllChanges` configuration option is set to `true`, the\n * `callback` function will be called any time a new `largest-contentful-paint`\n * performance entry is dispatched, or once the final value of the metric has\n * been determined.\n */\nexport const onLCP = (onReport: (metric: LCPMetric) => void, opts: ReportOpts = {}) => {\n  whenActivated(() => {\n    const visibilityWatcher = getVisibilityWatcher();\n    const metric = initMetric('LCP');\n    let report: ReturnType<typeof bindReporter>;\n\n    const handleEntries = (entries: LCPMetric['entries']) => {\n      // If reportAllChanges is set then call this function for each entry,\n      // otherwise only consider the last one.\n      if (!opts.reportAllChanges) {\n        // eslint-disable-next-line no-param-reassign\n        entries = entries.slice(-1);\n      }\n\n      entries.forEach(entry => {\n        // Only report if the page wasn't hidden prior to LCP.\n        if (entry.startTime < visibilityWatcher.firstHiddenTime) {\n          // The startTime attribute returns the value of the renderTime if it is\n          // not 0, and the value of the loadTime otherwise. The activationStart\n          // reference is used because LCP should be relative to page activation\n          // rather than navigation start if the page was pre-rendered. But in cases\n          // where `activationStart` occurs after the LCP, this time should be\n          // clamped at 0.\n          metric.value = Math.max(entry.startTime - getActivationStart(), 0);\n          metric.entries = [entry];\n          report();\n        }\n      });\n    };\n\n    const po = observe('largest-contentful-paint', handleEntries);\n\n    if (po) {\n      report = bindReporter(onReport, metric, LCPThresholds, opts.reportAllChanges);\n\n      const stopListening = runOnce(() => {\n        if (!reportedMetricIDs[metric.id]) {\n          handleEntries(po.takeRecords() as LCPMetric['entries']);\n          po.disconnect();\n          reportedMetricIDs[metric.id] = true;\n          report(true);\n        }\n      });\n\n      // Stop listening after input. Note: while scrolling is an input that\n      // stops LCP observation, it's unreliable since it can be programmatically\n      // generated. See: https://github.com/GoogleChrome/web-vitals/issues/75\n      ['keydown', 'click'].forEach(type => {\n        // Wrap in a setTimeout so the callback is run in a separate task\n        // to avoid extending the keyboard/click handler to reduce INP impact\n        // https://github.com/GoogleChrome/web-vitals/issues/383\n        if (WINDOW.document) {\n          addEventListener(type, () => whenIdle(stopListening as () => void), {\n            once: true,\n            capture: true,\n          });\n        }\n      });\n\n      onHidden(stopListening);\n    }\n  });\n};\n","/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { WINDOW } from '../../types';\nimport { bindReporter } from './lib/bindReporter';\nimport { getActivationStart } from './lib/getActivationStart';\nimport { getNavigationEntry } from './lib/getNavigationEntry';\nimport { initMetric } from './lib/initMetric';\nimport { whenActivated } from './lib/whenActivated';\nimport type { MetricRatingThresholds, ReportOpts, TTFBMetric } from './types';\n\n/** Thresholds for TTFB. See https://web.dev/articles/ttfb#what_is_a_good_ttfb_score */\nexport const TTFBThresholds: MetricRatingThresholds = [800, 1800];\n\n/**\n * Runs in the next task after the page is done loading and/or prerendering.\n * @param callback\n */\nconst whenReady = (callback: () => void) => {\n  if (WINDOW.document && WINDOW.document.prerendering) {\n    whenActivated(() => whenReady(callback));\n  } else if (WINDOW.document && WINDOW.document.readyState !== 'complete') {\n    addEventListener('load', () => whenReady(callback), true);\n  } else {\n    // Queue a task so the callback runs after `loadEventEnd`.\n    setTimeout(callback, 0);\n  }\n};\n\n/**\n * Calculates the [TTFB](https://web.dev/articles/ttfb) value for the\n * current page and calls the `callback` function once the page has loaded,\n * along with the relevant `navigation` performance entry used to determine the\n * value. The reported value is a `DOMHighResTimeStamp`.\n *\n * Note, this function waits until after the page is loaded to call `callback`\n * in order to ensure all properties of the `navigation` entry are populated.\n * This is useful if you want to report on other metrics exposed by the\n * [Navigation Timing API](https://w3c.github.io/navigation-timing/). For\n * example, the TTFB metric starts from the page's [time\n * origin](https://www.w3.org/TR/hr-time-2/#sec-time-origin), which means it\n * includes time spent on DNS lookup, connection negotiation, network latency,\n * and server processing time.\n */\nexport const onTTFB = (onReport: (metric: TTFBMetric) => void, opts: ReportOpts = {}) => {\n  const metric = initMetric('TTFB');\n  const report = bindReporter(onReport, metric, TTFBThresholds, opts.reportAllChanges);\n\n  whenReady(() => {\n    const navigationEntry = getNavigationEntry();\n\n    if (navigationEntry) {\n      // The activationStart reference is used because TTFB should be\n      // relative to page activation rather than navigation start if the\n      // page was prerendered. But in cases where `activationStart` occurs\n      // after the first byte is received, this time should be clamped at 0.\n      metric.value = Math.max(navigationEntry.responseStart - getActivationStart(), 0);\n\n      metric.entries = [navigationEntry];\n      report(true);\n    }\n  });\n};\n","import { getFunctionName, logger } from '@sentry/core';\n\nimport { DEBUG_BUILD } from '../debug-build';\nimport { onCLS } from './web-vitals/getCLS';\nimport { onFID } from './web-vitals/getFID';\nimport { onINP } from './web-vitals/getINP';\nimport { onLCP } from './web-vitals/getLCP';\nimport { observe } from './web-vitals/lib/observe';\nimport { onTTFB } from './web-vitals/onTTFB';\n\ntype InstrumentHandlerTypePerformanceObserver =\n  | 'longtask'\n  | 'event'\n  | 'navigation'\n  | 'paint'\n  | 'resource'\n  | 'first-input';\n\ntype InstrumentHandlerTypeMetric = 'cls' | 'lcp' | 'fid' | 'ttfb' | 'inp';\n\n// We provide this here manually instead of relying on a global, as this is not available in non-browser environements\n// And we do not want to expose such types\ninterface PerformanceEntry {\n  readonly duration: number;\n  readonly entryType: string;\n  readonly name: string;\n  readonly startTime: number;\n  toJSON(): Record<string, unknown>;\n}\ninterface PerformanceEventTiming extends PerformanceEntry {\n  processingStart: number;\n  processingEnd: number;\n  duration: number;\n  cancelable?: boolean;\n  target?: unknown | null;\n  interactionId?: number;\n}\n\ninterface PerformanceScriptTiming extends PerformanceEntry {\n  sourceURL: string;\n  sourceFunctionName: string;\n  sourceCharPosition: number;\n  invoker: string;\n  invokerType: string;\n}\nexport interface PerformanceLongAnimationFrameTiming extends PerformanceEntry {\n  scripts: PerformanceScriptTiming[];\n}\n\ninterface Metric {\n  /**\n   * The name of the metric (in acronym form).\n   */\n  name: 'CLS' | 'FCP' | 'FID' | 'INP' | 'LCP' | 'TTFB';\n\n  /**\n   * The current value of the metric.\n   */\n  value: number;\n\n  /**\n   * The rating as to whether the metric value is within the \"good\",\n   * \"needs improvement\", or \"poor\" thresholds of the metric.\n   */\n  rating: 'good' | 'needs-improvement' | 'poor';\n\n  /**\n   * The delta between the current value and the last-reported value.\n   * On the first report, `delta` and `value` will always be the same.\n   */\n  delta: number;\n\n  /**\n   * A unique ID representing this particular metric instance. This ID can\n   * be used by an analytics tool to dedupe multiple values sent for the same\n   * metric instance, or to group multiple deltas together and calculate a\n   * total. It can also be used to differentiate multiple different metric\n   * instances sent from the same page, which can happen if the page is\n   * restored from the back/forward cache (in that case new metrics object\n   * get created).\n   */\n  id: string;\n\n  /**\n   * Any performance entries relevant to the metric value calculation.\n   * The array may also be empty if the metric value was not based on any\n   * entries (e.g. a CLS value of 0 given no layout shifts).\n   */\n  entries: PerformanceEntry[];\n\n  /**\n   * The type of navigation\n   *\n   * Navigation Timing API (or `undefined` if the browser doesn't\n   * support that API). For pages that are restored from the bfcache, this\n   * value will be 'back-forward-cache'.\n   */\n  navigationType: 'navigate' | 'reload' | 'back-forward' | 'back-forward-cache' | 'prerender' | 'restore';\n}\n\ntype InstrumentHandlerType = InstrumentHandlerTypeMetric | InstrumentHandlerTypePerformanceObserver;\n\ntype StopListening = undefined | void | (() => void);\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype InstrumentHandlerCallback = (data: any) => void;\n\ntype CleanupHandlerCallback = () => void;\n\nconst handlers: { [key in InstrumentHandlerType]?: InstrumentHandlerCallback[] } = {};\nconst instrumented: { [key in InstrumentHandlerType]?: boolean } = {};\n\nlet _previousCls: Metric | undefined;\nlet _previousFid: Metric | undefined;\nlet _previousLcp: Metric | undefined;\nlet _previousTtfb: Metric | undefined;\nlet _previousInp: Metric | undefined;\n\n/**\n * Add a callback that will be triggered when a CLS metric is available.\n * Returns a cleanup callback which can be called to remove the instrumentation handler.\n *\n * Pass `stopOnCallback = true` to stop listening for CLS when the cleanup callback is called.\n * This will lead to the CLS being finalized and frozen.\n */\nexport function addClsInstrumentationHandler(\n  callback: (data: { metric: Metric }) => void,\n  stopOnCallback = false,\n): CleanupHandlerCallback {\n  return addMetricObserver('cls', callback, instrumentCls, _previousCls, stopOnCallback);\n}\n\n/**\n * Add a callback that will be triggered when a LCP metric is available.\n * Returns a cleanup callback which can be called to remove the instrumentation handler.\n *\n * Pass `stopOnCallback = true` to stop listening for LCP when the cleanup callback is called.\n * This will lead to the LCP being finalized and frozen.\n */\nexport function addLcpInstrumentationHandler(\n  callback: (data: { metric: Metric }) => void,\n  stopOnCallback = false,\n): CleanupHandlerCallback {\n  return addMetricObserver('lcp', callback, instrumentLcp, _previousLcp, stopOnCallback);\n}\n\n/**\n * Add a callback that will be triggered when a FID metric is available.\n * Returns a cleanup callback which can be called to remove the instrumentation handler.\n */\nexport function addFidInstrumentationHandler(callback: (data: { metric: Metric }) => void): CleanupHandlerCallback {\n  return addMetricObserver('fid', callback, instrumentFid, _previousFid);\n}\n\n/**\n * Add a callback that will be triggered when a FID metric is available.\n */\nexport function addTtfbInstrumentationHandler(callback: (data: { metric: Metric }) => void): CleanupHandlerCallback {\n  return addMetricObserver('ttfb', callback, instrumentTtfb, _previousTtfb);\n}\n\n/**\n * Add a callback that will be triggered when a INP metric is available.\n * Returns a cleanup callback which can be called to remove the instrumentation handler.\n */\nexport function addInpInstrumentationHandler(\n  callback: (data: { metric: Omit<Metric, 'entries'> & { entries: PerformanceEventTiming[] } }) => void,\n): CleanupHandlerCallback {\n  return addMetricObserver('inp', callback, instrumentInp, _previousInp);\n}\n\nexport function addPerformanceInstrumentationHandler(\n  type: 'event',\n  callback: (data: { entries: ((PerformanceEntry & { target?: unknown | null }) | PerformanceEventTiming)[] }) => void,\n): CleanupHandlerCallback;\nexport function addPerformanceInstrumentationHandler(\n  type: InstrumentHandlerTypePerformanceObserver,\n  callback: (data: { entries: PerformanceEntry[] }) => void,\n): CleanupHandlerCallback;\n\n/**\n * Add a callback that will be triggered when a performance observer is triggered,\n * and receives the entries of the observer.\n * Returns a cleanup callback which can be called to remove the instrumentation handler.\n */\nexport function addPerformanceInstrumentationHandler(\n  type: InstrumentHandlerTypePerformanceObserver,\n  callback: (data: { entries: PerformanceEntry[] }) => void,\n): CleanupHandlerCallback {\n  addHandler(type, callback);\n\n  if (!instrumented[type]) {\n    instrumentPerformanceObserver(type);\n    instrumented[type] = true;\n  }\n\n  return getCleanupCallback(type, callback);\n}\n\n/** Trigger all handlers of a given type. */\nfunction triggerHandlers(type: InstrumentHandlerType, data: unknown): void {\n  const typeHandlers = handlers[type];\n\n  if (!typeHandlers || !typeHandlers.length) {\n    return;\n  }\n\n  for (const handler of typeHandlers) {\n    try {\n      handler(data);\n    } catch (e) {\n      DEBUG_BUILD &&\n        logger.error(\n          `Error while triggering instrumentation handler.\\nType: ${type}\\nName: ${getFunctionName(handler)}\\nError:`,\n          e,\n        );\n    }\n  }\n}\n\nfunction instrumentCls(): StopListening {\n  return onCLS(\n    metric => {\n      triggerHandlers('cls', {\n        metric,\n      });\n      _previousCls = metric;\n    },\n    // We want the callback to be called whenever the CLS value updates.\n    // By default, the callback is only called when the tab goes to the background.\n    { reportAllChanges: true },\n  );\n}\n\nfunction instrumentFid(): void {\n  return onFID(metric => {\n    triggerHandlers('fid', {\n      metric,\n    });\n    _previousFid = metric;\n  });\n}\n\nfunction instrumentLcp(): StopListening {\n  return onLCP(\n    metric => {\n      triggerHandlers('lcp', {\n        metric,\n      });\n      _previousLcp = metric;\n    },\n    // We want the callback to be called whenever the LCP value updates.\n    // By default, the callback is only called when the tab goes to the background.\n    { reportAllChanges: true },\n  );\n}\n\nfunction instrumentTtfb(): StopListening {\n  return onTTFB(metric => {\n    triggerHandlers('ttfb', {\n      metric,\n    });\n    _previousTtfb = metric;\n  });\n}\n\nfunction instrumentInp(): void {\n  return onINP(metric => {\n    triggerHandlers('inp', {\n      metric,\n    });\n    _previousInp = metric;\n  });\n}\n\nfunction addMetricObserver(\n  type: InstrumentHandlerTypeMetric,\n  callback: InstrumentHandlerCallback,\n  instrumentFn: () => StopListening,\n  previousValue: Metric | undefined,\n  stopOnCallback = false,\n): CleanupHandlerCallback {\n  addHandler(type, callback);\n\n  let stopListening: StopListening | undefined;\n\n  if (!instrumented[type]) {\n    stopListening = instrumentFn();\n    instrumented[type] = true;\n  }\n\n  if (previousValue) {\n    callback({ metric: previousValue });\n  }\n\n  return getCleanupCallback(type, callback, stopOnCallback ? stopListening : undefined);\n}\n\nfunction instrumentPerformanceObserver(type: InstrumentHandlerTypePerformanceObserver): void {\n  const options: PerformanceObserverInit = {};\n\n  // Special per-type options we want to use\n  if (type === 'event') {\n    options.durationThreshold = 0;\n  }\n\n  observe(\n    type,\n    entries => {\n      triggerHandlers(type, { entries });\n    },\n    options,\n  );\n}\n\nfunction addHandler(type: InstrumentHandlerType, handler: InstrumentHandlerCallback): void {\n  handlers[type] = handlers[type] || [];\n  (handlers[type] as InstrumentHandlerCallback[]).push(handler);\n}\n\n// Get a callback which can be called to remove the instrumentation handler\nfunction getCleanupCallback(\n  type: InstrumentHandlerType,\n  callback: InstrumentHandlerCallback,\n  stopListening: StopListening,\n): CleanupHandlerCallback {\n  return () => {\n    if (stopListening) {\n      stopListening();\n    }\n\n    const typeHandlers = handlers[type];\n\n    if (!typeHandlers) {\n      return;\n    }\n\n    const index = typeHandlers.indexOf(callback);\n    if (index !== -1) {\n      typeHandlers.splice(index, 1);\n    }\n  };\n}\n\n/**\n * Check if a PerformanceEntry is a PerformanceEventTiming by checking for the `duration` property.\n */\nexport function isPerformanceEventTiming(entry: PerformanceEntry): entry is PerformanceEventTiming {\n  return 'duration' in entry;\n}\n","/*\n * Copyright 2022 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { getNavigationEntry } from './getNavigationEntry';\n\nexport const getActivationStart = (): number => {\n  const navEntry = getNavigationEntry();\n  return (navEntry && navEntry.activationStart) || 0;\n};\n","import type { HandlerDataXhr, SentryWrappedXMLHttpRequest } from '@sentry/core';\nimport { addHandler, isString, maybeInstrument, timestampInSeconds, triggerHandlers } from '@sentry/core';\nimport { WINDOW } from '../types';\n\nexport const SENTRY_XHR_DATA_KEY = '__sentry_xhr_v3__';\n\ntype WindowWithXhr = Window & { XMLHttpRequest?: typeof XMLHttpRequest };\n\n/**\n * Add an instrumentation handler for when an XHR request happens.\n * The handler function is called once when the request starts and once when it ends,\n * which can be identified by checking if it has an `endTimestamp`.\n *\n * Use at your own risk, this might break without changelog notice, only used internally.\n * @hidden\n */\nexport function addXhrInstrumentationHandler(handler: (data: HandlerDataXhr) => void): void {\n  const type = 'xhr';\n  addHandler(type, handler);\n  maybeInstrument(type, instrumentXHR);\n}\n\n/** Exported only for tests. */\nexport function instrumentXHR(): void {\n  if (!(WINDOW as WindowWithXhr).XMLHttpRequest) {\n    return;\n  }\n\n  const xhrproto = XMLHttpRequest.prototype;\n\n  // eslint-disable-next-line @typescript-eslint/unbound-method\n  xhrproto.open = new Proxy(xhrproto.open, {\n    apply(originalOpen, xhrOpenThisArg: XMLHttpRequest & SentryWrappedXMLHttpRequest, xhrOpenArgArray) {\n      // NOTE: If you are a Sentry user, and you are seeing this stack frame,\n      //       it means the error, that was caused by your XHR call did not\n      //       have a stack trace. If you are using HttpClient integration,\n      //       this is the expected behavior, as we are using this virtual error to capture\n      //       the location of your XHR call, and group your HttpClient events accordingly.\n      const virtualError = new Error();\n\n      const startTimestamp = timestampInSeconds() * 1000;\n\n      // open() should always be called with two or more arguments\n      // But to be on the safe side, we actually validate this and bail out if we don't have a method & url\n      const method = isString(xhrOpenArgArray[0]) ? xhrOpenArgArray[0].toUpperCase() : undefined;\n      const url = parseUrl(xhrOpenArgArray[1]);\n\n      if (!method || !url) {\n        return originalOpen.apply(xhrOpenThisArg, xhrOpenArgArray);\n      }\n\n      xhrOpenThisArg[SENTRY_XHR_DATA_KEY] = {\n        method,\n        url,\n        request_headers: {},\n      };\n\n      // if Sentry key appears in URL, don't capture it as a request\n      if (method === 'POST' && url.match(/sentry_key/)) {\n        xhrOpenThisArg.__sentry_own_request__ = true;\n      }\n\n      const onreadystatechangeHandler: () => void = () => {\n        // For whatever reason, this is not the same instance here as from the outer method\n        const xhrInfo = xhrOpenThisArg[SENTRY_XHR_DATA_KEY];\n\n        if (!xhrInfo) {\n          return;\n        }\n\n        if (xhrOpenThisArg.readyState === 4) {\n          try {\n            // touching statusCode in some platforms throws\n            // an exception\n            xhrInfo.status_code = xhrOpenThisArg.status;\n          } catch (e) {\n            /* do nothing */\n          }\n\n          const handlerData: HandlerDataXhr = {\n            endTimestamp: timestampInSeconds() * 1000,\n            startTimestamp,\n            xhr: xhrOpenThisArg,\n            virtualError,\n          };\n          triggerHandlers('xhr', handlerData);\n        }\n      };\n\n      if ('onreadystatechange' in xhrOpenThisArg && typeof xhrOpenThisArg.onreadystatechange === 'function') {\n        xhrOpenThisArg.onreadystatechange = new Proxy(xhrOpenThisArg.onreadystatechange, {\n          apply(originalOnreadystatechange, onreadystatechangeThisArg, onreadystatechangeArgArray: unknown[]) {\n            onreadystatechangeHandler();\n            return originalOnreadystatechange.apply(onreadystatechangeThisArg, onreadystatechangeArgArray);\n          },\n        });\n      } else {\n        xhrOpenThisArg.addEventListener('readystatechange', onreadystatechangeHandler);\n      }\n\n      // Intercepting `setRequestHeader` to access the request headers of XHR instance.\n      // This will only work for user/library defined headers, not for the default/browser-assigned headers.\n      // Request cookies are also unavailable for XHR, as `Cookie` header can't be defined by `setRequestHeader`.\n      xhrOpenThisArg.setRequestHeader = new Proxy(xhrOpenThisArg.setRequestHeader, {\n        apply(\n          originalSetRequestHeader,\n          setRequestHeaderThisArg: SentryWrappedXMLHttpRequest,\n          setRequestHeaderArgArray: unknown[],\n        ) {\n          const [header, value] = setRequestHeaderArgArray;\n\n          const xhrInfo = setRequestHeaderThisArg[SENTRY_XHR_DATA_KEY];\n\n          if (xhrInfo && isString(header) && isString(value)) {\n            xhrInfo.request_headers[header.toLowerCase()] = value;\n          }\n\n          return originalSetRequestHeader.apply(setRequestHeaderThisArg, setRequestHeaderArgArray);\n        },\n      });\n\n      return originalOpen.apply(xhrOpenThisArg, xhrOpenArgArray);\n    },\n  });\n\n  // eslint-disable-next-line @typescript-eslint/unbound-method\n  xhrproto.send = new Proxy(xhrproto.send, {\n    apply(originalSend, sendThisArg: XMLHttpRequest & SentryWrappedXMLHttpRequest, sendArgArray: unknown[]) {\n      const sentryXhrData = sendThisArg[SENTRY_XHR_DATA_KEY];\n\n      if (!sentryXhrData) {\n        return originalSend.apply(sendThisArg, sendArgArray);\n      }\n\n      if (sendArgArray[0] !== undefined) {\n        sentryXhrData.body = sendArgArray[0];\n      }\n\n      const handlerData: HandlerDataXhr = {\n        startTimestamp: timestampInSeconds() * 1000,\n        xhr: sendThisArg,\n      };\n      triggerHandlers('xhr', handlerData);\n\n      return originalSend.apply(sendThisArg, sendArgArray);\n    },\n  });\n}\n\nfunction parseUrl(url: string | unknown): string | undefined {\n  if (isString(url)) {\n    return url;\n  }\n\n  try {\n    // url can be a string or URL\n    // but since URL is not available in IE11, we do not check for it,\n    // but simply assume it is an URL and return `toString()` from it (which returns the full URL)\n    // If that fails, we just return undefined\n    return (url as URL).toString();\n  } catch {} // eslint-disable-line no-empty\n\n  return undefined;\n}\n","/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { WINDOW } from '../../../types';\n\nlet firstHiddenTime = -1;\n\nconst initHiddenTime = () => {\n  // If the document is hidden when this code runs, assume it was always\n  // hidden and the page was loaded in the background, with the one exception\n  // that visibility state is always 'hidden' during prerendering, so we have\n  // to ignore that case until prerendering finishes (see: `prerenderingchange`\n  // event logic below).\n  return WINDOW.document!.visibilityState === 'hidden' && !WINDOW.document!.prerendering ? 0 : Infinity;\n};\n\nconst onVisibilityUpdate = (event: Event) => {\n  // If the document is 'hidden' and no previous hidden timestamp has been\n  // set, update it based on the current event data.\n  if (WINDOW.document!.visibilityState === 'hidden' && firstHiddenTime > -1) {\n    // If the event is a 'visibilitychange' event, it means the page was\n    // visible prior to this change, so the event timestamp is the first\n    // hidden time.\n    // However, if the event is not a 'visibilitychange' event, then it must\n    // be a 'prerenderingchange' event, and the fact that the document is\n    // still 'hidden' from the above check means the tab was activated\n    // in a background state and so has always been hidden.\n    firstHiddenTime = event.type === 'visibilitychange' ? event.timeStamp : 0;\n\n    // Remove all listeners now that a `firstHiddenTime` value has been set.\n    removeChangeListeners();\n  }\n};\n\nconst addChangeListeners = () => {\n  addEventListener('visibilitychange', onVisibilityUpdate, true);\n  // IMPORTANT: when a page is prerendering, its `visibilityState` is\n  // 'hidden', so in order to account for cases where this module checks for\n  // visibility during prerendering, an additional check after prerendering\n  // completes is also required.\n  addEventListener('prerenderingchange', onVisibilityUpdate, true);\n};\n\nconst removeChangeListeners = () => {\n  removeEventListener('visibilitychange', onVisibilityUpdate, true);\n  removeEventListener('prerenderingchange', onVisibilityUpdate, true);\n};\n\nexport const getVisibilityWatcher = () => {\n  if (WINDOW.document && firstHiddenTime < 0) {\n    // If the document is hidden when this code runs, assume it was hidden\n    // since navigation start. This isn't a perfect heuristic, but it's the\n    // best we can do until an API is available to support querying past\n    // visibilityState.\n    firstHiddenTime = initHiddenTime();\n    addChangeListeners();\n  }\n  return {\n    get firstHiddenTime() {\n      return firstHiddenTime;\n    },\n  };\n};\n","/*\n * Copyright 2022 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { WINDOW } from '../../../types';\n\n// sentry-specific change:\n// add optional param to not check for responseStart (see comment below)\nexport const getNavigationEntry = (checkResponseStart = true): PerformanceNavigationTiming | void => {\n  const navigationEntry =\n    WINDOW.performance && WINDOW.performance.getEntriesByType && WINDOW.performance.getEntriesByType('navigation')[0];\n  // Check to ensure the `responseStart` property is present and valid.\n  // In some cases no value is reported by the browser (for\n  // privacy/security reasons), and in other cases (bugs) the value is\n  // negative or is larger than the current page time. Ignore these cases:\n  // https://github.com/GoogleChrome/web-vitals/issues/137\n  // https://github.com/GoogleChrome/web-vitals/issues/162\n  // https://github.com/GoogleChrome/web-vitals/issues/275\n  if (\n    // sentry-specific change:\n    // We don't want to check for responseStart for our own use of `getNavigationEntry`\n    !checkResponseStart ||\n    (navigationEntry && navigationEntry.responseStart > 0 && navigationEntry.responseStart < performance.now())\n  ) {\n    return navigationEntry;\n  }\n};\n","import { GLOBAL_OBJ } from '@sentry/core';\n\nexport const WINDOW = GLOBAL_OBJ as typeof GLOBAL_OBJ &\n  // document is not available in all browser environments (webworkers). We make it optional so you have to explicitly check for it\n  Omit<Window, 'document'> &\n  Partial<Pick<Window, 'document'>>;\n","declare const __DEBUG_BUILD__: boolean;\n\n/**\n * This serves as a build time flag that will be true by default, but false in non-debug builds or if users replace `__SENTRY_DEBUG__` in their generated code.\n *\n * ATTENTION: This constant must never cross package boundaries (i.e. be exported) to guarantee that it can be used for tree shaking.\n */\nexport const DEBUG_BUILD = __DEBUG_BUILD__;\n","import { GLOBAL_OBJ } from '@sentry/core';\n\n// exporting a separate copy of `WINDOW` rather than exporting the one from `@sentry/browser`\n// prevents the browser package from being bundled in the CDN bundle, and avoids a\n// circular dependency between the browser and replay packages should `@sentry/browser` import\n// from `@sentry/replay` in the future\nexport const WINDOW = GLOBAL_OBJ as typeof GLOBAL_OBJ & Window;\n\nexport const REPLAY_SESSION_KEY = 'sentryReplaySession';\nexport const REPLAY_EVENT_NAME = 'replay_event';\nexport const RECORDING_EVENT_NAME = 'replay_recording';\nexport const UNABLE_TO_SEND_REPLAY = 'Unable to send Replay';\n\n// The idle limit for a session after which recording is paused.\nexport const SESSION_IDLE_PAUSE_DURATION = 300_000; // 5 minutes in ms\n\n// The idle limit for a session after which the session expires.\nexport const SESSION_IDLE_EXPIRE_DURATION = 900_000; // 15 minutes in ms\n\n/** Default flush delays */\nexport const DEFAULT_FLUSH_MIN_DELAY = 5_000;\n// XXX: Temp fix for our debounce logic where `maxWait` would never occur if it\n// was the same as `wait`\nexport const DEFAULT_FLUSH_MAX_DELAY = 5_500;\n\n/* How long to wait for error checkouts */\nexport const BUFFER_CHECKOUT_TIME = 60_000;\n\nexport const RETRY_BASE_INTERVAL = 5000;\nexport const RETRY_MAX_COUNT = 3;\n\n/* The max (uncompressed) size in bytes of a network body. Any body larger than this will be truncated. */\nexport const NETWORK_BODY_MAX_SIZE = 150_000;\n\n/* The max size of a single console arg that is captured. Any arg larger than this will be truncated. */\nexport const CONSOLE_ARG_MAX_SIZE = 5_000;\n\n/* Min. time to wait before we consider something a slow click. */\nexport const SLOW_CLICK_THRESHOLD = 3_000;\n/* For scroll actions after a click, we only look for a very short time period to detect programmatic scrolling. */\nexport const SLOW_CLICK_SCROLL_TIMEOUT = 300;\n\n/** When encountering a total segment size exceeding this size, stop the replay (as we cannot properly ingest it). */\nexport const REPLAY_MAX_EVENT_BUFFER_SIZE = 20_000_000; // ~20MB\n\n/** Replays must be min. 5s long before we send them. */\nexport const MIN_REPLAY_DURATION = 4_999;\n/* The max. allowed value that the minReplayDuration can be set to. */\nexport const MIN_REPLAY_DURATION_LIMIT = 15_000;\n\n/** The max. length of a replay. */\nexport const MAX_REPLAY_DURATION = 3_600_000; // 60 minutes in ms;\n\n/** Default attributes to be ignored when `maskAllText` is enabled */\nexport const DEFAULT_IGNORED_ATTRIBUTES = ['title', 'placeholder'];\n","var NodeType;\r\n(function (NodeType) {\r\n    NodeType[NodeType[\"Document\"] = 0] = \"Document\";\r\n    NodeType[NodeType[\"DocumentType\"] = 1] = \"DocumentType\";\r\n    NodeType[NodeType[\"Element\"] = 2] = \"Element\";\r\n    NodeType[NodeType[\"Text\"] = 3] = \"Text\";\r\n    NodeType[NodeType[\"CDATA\"] = 4] = \"CDATA\";\r\n    NodeType[NodeType[\"Comment\"] = 5] = \"Comment\";\r\n})(NodeType || (NodeType = {}));\n\nfunction isElement(n) {\r\n    return n.nodeType === n.ELEMENT_NODE;\r\n}\r\nfunction isShadowRoot(n) {\r\n    const host = n?.host;\r\n    return Boolean(host?.shadowRoot === n);\r\n}\r\nfunction isNativeShadowDom(shadowRoot) {\r\n    return Object.prototype.toString.call(shadowRoot) === '[object ShadowRoot]';\r\n}\r\nfunction fixBrowserCompatibilityIssuesInCSS(cssText) {\r\n    if (cssText.includes(' background-clip: text;') &&\r\n        !cssText.includes(' -webkit-background-clip: text;')) {\r\n        cssText = cssText.replace(/\\sbackground-clip:\\s*text;/g, ' -webkit-background-clip: text; background-clip: text;');\r\n    }\r\n    return cssText;\r\n}\r\nfunction escapeImportStatement(rule) {\r\n    const { cssText } = rule;\r\n    if (cssText.split('\"').length < 3)\r\n        return cssText;\r\n    const statement = ['@import', `url(${JSON.stringify(rule.href)})`];\r\n    if (rule.layerName === '') {\r\n        statement.push(`layer`);\r\n    }\r\n    else if (rule.layerName) {\r\n        statement.push(`layer(${rule.layerName})`);\r\n    }\r\n    if (rule.supportsText) {\r\n        statement.push(`supports(${rule.supportsText})`);\r\n    }\r\n    if (rule.media.length) {\r\n        statement.push(rule.media.mediaText);\r\n    }\r\n    return statement.join(' ') + ';';\r\n}\r\nfunction stringifyStylesheet(s) {\r\n    try {\r\n        const rules = s.rules || s.cssRules;\r\n        return rules\r\n            ? fixBrowserCompatibilityIssuesInCSS(Array.from(rules, stringifyRule).join(''))\r\n            : null;\r\n    }\r\n    catch (error) {\r\n        return null;\r\n    }\r\n}\r\nfunction fixAllCssProperty(rule) {\r\n    let styles = '';\r\n    for (let i = 0; i < rule.style.length; i++) {\r\n        const styleDeclaration = rule.style;\r\n        const attribute = styleDeclaration[i];\r\n        const isImportant = styleDeclaration.getPropertyPriority(attribute);\r\n        styles += `${attribute}:${styleDeclaration.getPropertyValue(attribute)}${isImportant ? ` !important` : ''};`;\r\n    }\r\n    return `${rule.selectorText} { ${styles} }`;\r\n}\r\nfunction stringifyRule(rule) {\r\n    let importStringified;\r\n    if (isCSSImportRule(rule)) {\r\n        try {\r\n            importStringified =\r\n                stringifyStylesheet(rule.styleSheet) ||\r\n                    escapeImportStatement(rule);\r\n        }\r\n        catch (error) {\r\n        }\r\n    }\r\n    else if (isCSSStyleRule(rule)) {\r\n        let cssText = rule.cssText;\r\n        const needsSafariColonFix = rule.selectorText.includes(':');\r\n        const needsAllFix = typeof rule.style['all'] === 'string' && rule.style['all'];\r\n        if (needsAllFix) {\r\n            cssText = fixAllCssProperty(rule);\r\n        }\r\n        if (needsSafariColonFix) {\r\n            cssText = fixSafariColons(cssText);\r\n        }\r\n        if (needsSafariColonFix || needsAllFix) {\r\n            return cssText;\r\n        }\r\n    }\r\n    return importStringified || rule.cssText;\r\n}\r\nfunction fixSafariColons(cssStringified) {\r\n    const regex = /(\\[(?:[\\w-]+)[^\\\\])(:(?:[\\w-]+)\\])/gm;\r\n    return cssStringified.replace(regex, '$1\\\\$2');\r\n}\r\nfunction isCSSImportRule(rule) {\r\n    return 'styleSheet' in rule;\r\n}\r\nfunction isCSSStyleRule(rule) {\r\n    return 'selectorText' in rule;\r\n}\r\nclass Mirror {\r\n    constructor() {\r\n        this.idNodeMap = new Map();\r\n        this.nodeMetaMap = new WeakMap();\r\n    }\r\n    getId(n) {\r\n        if (!n)\r\n            return -1;\r\n        const id = this.getMeta(n)?.id;\r\n        return id ?? -1;\r\n    }\r\n    getNode(id) {\r\n        return this.idNodeMap.get(id) || null;\r\n    }\r\n    getIds() {\r\n        return Array.from(this.idNodeMap.keys());\r\n    }\r\n    getMeta(n) {\r\n        return this.nodeMetaMap.get(n) || null;\r\n    }\r\n    removeNodeFromMap(n) {\r\n        const id = this.getId(n);\r\n        this.idNodeMap.delete(id);\r\n        if (n.childNodes) {\r\n            n.childNodes.forEach((childNode) => this.removeNodeFromMap(childNode));\r\n        }\r\n    }\r\n    has(id) {\r\n        return this.idNodeMap.has(id);\r\n    }\r\n    hasNode(node) {\r\n        return this.nodeMetaMap.has(node);\r\n    }\r\n    add(n, meta) {\r\n        const id = meta.id;\r\n        this.idNodeMap.set(id, n);\r\n        this.nodeMetaMap.set(n, meta);\r\n    }\r\n    replace(id, n) {\r\n        const oldNode = this.getNode(id);\r\n        if (oldNode) {\r\n            const meta = this.nodeMetaMap.get(oldNode);\r\n            if (meta)\r\n                this.nodeMetaMap.set(n, meta);\r\n        }\r\n        this.idNodeMap.set(id, n);\r\n    }\r\n    reset() {\r\n        this.idNodeMap = new Map();\r\n        this.nodeMetaMap = new WeakMap();\r\n    }\r\n}\r\nfunction createMirror() {\r\n    return new Mirror();\r\n}\r\nfunction shouldMaskInput({ maskInputOptions, tagName, type, }) {\r\n    if (tagName === 'OPTION') {\r\n        tagName = 'SELECT';\r\n    }\r\n    return Boolean(maskInputOptions[tagName.toLowerCase()] ||\r\n        (type && maskInputOptions[type]) ||\r\n        type === 'password' ||\r\n        (tagName === 'INPUT' && !type && maskInputOptions['text']));\r\n}\r\nfunction maskInputValue({ isMasked, element, value, maskInputFn, }) {\r\n    let text = value || '';\r\n    if (!isMasked) {\r\n        return text;\r\n    }\r\n    if (maskInputFn) {\r\n        text = maskInputFn(text, element);\r\n    }\r\n    return '*'.repeat(text.length);\r\n}\r\nfunction toLowerCase(str) {\r\n    return str.toLowerCase();\r\n}\r\nfunction toUpperCase(str) {\r\n    return str.toUpperCase();\r\n}\r\nconst ORIGINAL_ATTRIBUTE_NAME = '__rrweb_original__';\r\nfunction is2DCanvasBlank(canvas) {\r\n    const ctx = canvas.getContext('2d');\r\n    if (!ctx)\r\n        return true;\r\n    const chunkSize = 50;\r\n    for (let x = 0; x < canvas.width; x += chunkSize) {\r\n        for (let y = 0; y < canvas.height; y += chunkSize) {\r\n            const getImageData = ctx.getImageData;\r\n            const originalGetImageData = ORIGINAL_ATTRIBUTE_NAME in getImageData\r\n                ? getImageData[ORIGINAL_ATTRIBUTE_NAME]\r\n                : getImageData;\r\n            const pixelBuffer = new Uint32Array(originalGetImageData.call(ctx, x, y, Math.min(chunkSize, canvas.width - x), Math.min(chunkSize, canvas.height - y)).data.buffer);\r\n            if (pixelBuffer.some((pixel) => pixel !== 0))\r\n                return false;\r\n        }\r\n    }\r\n    return true;\r\n}\r\nfunction isNodeMetaEqual(a, b) {\r\n    if (!a || !b || a.type !== b.type)\r\n        return false;\r\n    if (a.type === NodeType.Document)\r\n        return a.compatMode === b.compatMode;\r\n    else if (a.type === NodeType.DocumentType)\r\n        return (a.name === b.name &&\r\n            a.publicId === b.publicId &&\r\n            a.systemId === b.systemId);\r\n    else if (a.type === NodeType.Comment ||\r\n        a.type === NodeType.Text ||\r\n        a.type === NodeType.CDATA)\r\n        return a.textContent === b.textContent;\r\n    else if (a.type === NodeType.Element)\r\n        return (a.tagName === b.tagName &&\r\n            JSON.stringify(a.attributes) ===\r\n                JSON.stringify(b.attributes) &&\r\n            a.isSVG === b.isSVG &&\r\n            a.needBlock === b.needBlock);\r\n    return false;\r\n}\r\nfunction getInputType(element) {\r\n    const type = element.type;\r\n    return element.hasAttribute('data-rr-is-password')\r\n        ? 'password'\r\n        : type\r\n            ?\r\n                toLowerCase(type)\r\n            : null;\r\n}\r\nfunction getInputValue(el, tagName, type) {\r\n    if (tagName === 'INPUT' && (type === 'radio' || type === 'checkbox')) {\r\n        return el.getAttribute('value') || '';\r\n    }\r\n    return el.value;\r\n}\r\nfunction extractFileExtension(path, baseURL) {\r\n    let url;\r\n    try {\r\n        url = new URL(path, baseURL ?? window.location.href);\r\n    }\r\n    catch (err) {\r\n        return null;\r\n    }\r\n    const regex = /\\.([0-9a-z]+)(?:$)/i;\r\n    const match = url.pathname.match(regex);\r\n    return match?.[1] ?? null;\r\n}\r\nconst cachedImplementations = {};\r\nfunction getImplementation(name) {\r\n    const cached = cachedImplementations[name];\r\n    if (cached) {\r\n        return cached;\r\n    }\r\n    const document = window.document;\r\n    let impl = window[name];\r\n    if (document && typeof document.createElement === 'function') {\r\n        try {\r\n            const sandbox = document.createElement('iframe');\r\n            sandbox.hidden = true;\r\n            document.head.appendChild(sandbox);\r\n            const contentWindow = sandbox.contentWindow;\r\n            if (contentWindow && contentWindow[name]) {\r\n                impl =\r\n                    contentWindow[name];\r\n            }\r\n            document.head.removeChild(sandbox);\r\n        }\r\n        catch (e) {\r\n        }\r\n    }\r\n    return (cachedImplementations[name] = impl.bind(window));\r\n}\r\nfunction setTimeout(...rest) {\r\n    return getImplementation('setTimeout')(...rest);\r\n}\r\nfunction clearTimeout(...rest) {\r\n    return getImplementation('clearTimeout')(...rest);\r\n}\r\nfunction getIframeContentDocument(iframe) {\r\n    try {\r\n        return iframe.contentDocument;\r\n    }\r\n    catch (e) {\r\n    }\r\n}\n\nlet _id = 1;\r\nconst tagNameRegex = new RegExp('[^a-z0-9-_:]');\r\nconst IGNORED_NODE = -2;\r\nfunction genId() {\r\n    return _id++;\r\n}\r\nfunction getValidTagName(element) {\r\n    if (element instanceof HTMLFormElement) {\r\n        return 'form';\r\n    }\r\n    const processedTagName = toLowerCase(element.tagName);\r\n    if (tagNameRegex.test(processedTagName)) {\r\n        return 'div';\r\n    }\r\n    return processedTagName;\r\n}\r\nfunction extractOrigin(url) {\r\n    let origin = '';\r\n    if (url.indexOf('//') > -1) {\r\n        origin = url.split('/').slice(0, 3).join('/');\r\n    }\r\n    else {\r\n        origin = url.split('/')[0];\r\n    }\r\n    origin = origin.split('?')[0];\r\n    return origin;\r\n}\r\nlet canvasService;\r\nlet canvasCtx;\r\nconst URL_IN_CSS_REF = /url\\((?:(')([^']*)'|(\")(.*?)\"|([^)]*))\\)/gm;\r\nconst URL_PROTOCOL_MATCH = /^(?:[a-z+]+:)?\\/\\//i;\r\nconst URL_WWW_MATCH = /^www\\..*/i;\r\nconst DATA_URI = /^(data:)([^,]*),(.*)/i;\r\nfunction absoluteToStylesheet(cssText, href) {\r\n    return (cssText || '').replace(URL_IN_CSS_REF, (origin, quote1, path1, quote2, path2, path3) => {\r\n        const filePath = path1 || path2 || path3;\r\n        const maybeQuote = quote1 || quote2 || '';\r\n        if (!filePath) {\r\n            return origin;\r\n        }\r\n        if (URL_PROTOCOL_MATCH.test(filePath) || URL_WWW_MATCH.test(filePath)) {\r\n            return `url(${maybeQuote}${filePath}${maybeQuote})`;\r\n        }\r\n        if (DATA_URI.test(filePath)) {\r\n            return `url(${maybeQuote}${filePath}${maybeQuote})`;\r\n        }\r\n        if (filePath[0] === '/') {\r\n            return `url(${maybeQuote}${extractOrigin(href) + filePath}${maybeQuote})`;\r\n        }\r\n        const stack = href.split('/');\r\n        const parts = filePath.split('/');\r\n        stack.pop();\r\n        for (const part of parts) {\r\n            if (part === '.') {\r\n                continue;\r\n            }\r\n            else if (part === '..') {\r\n                stack.pop();\r\n            }\r\n            else {\r\n                stack.push(part);\r\n            }\r\n        }\r\n        return `url(${maybeQuote}${stack.join('/')}${maybeQuote})`;\r\n    });\r\n}\r\nconst SRCSET_NOT_SPACES = /^[^ \\t\\n\\r\\u000c]+/;\r\nconst SRCSET_COMMAS_OR_SPACES = /^[, \\t\\n\\r\\u000c]+/;\r\nfunction getAbsoluteSrcsetString(doc, attributeValue) {\r\n    if (attributeValue.trim() === '') {\r\n        return attributeValue;\r\n    }\r\n    let pos = 0;\r\n    function collectCharacters(regEx) {\r\n        let chars;\r\n        const match = regEx.exec(attributeValue.substring(pos));\r\n        if (match) {\r\n            chars = match[0];\r\n            pos += chars.length;\r\n            return chars;\r\n        }\r\n        return '';\r\n    }\r\n    const output = [];\r\n    while (true) {\r\n        collectCharacters(SRCSET_COMMAS_OR_SPACES);\r\n        if (pos >= attributeValue.length) {\r\n            break;\r\n        }\r\n        let url = collectCharacters(SRCSET_NOT_SPACES);\r\n        if (url.slice(-1) === ',') {\r\n            url = absoluteToDoc(doc, url.substring(0, url.length - 1));\r\n            output.push(url);\r\n        }\r\n        else {\r\n            let descriptorsStr = '';\r\n            url = absoluteToDoc(doc, url);\r\n            let inParens = false;\r\n            while (true) {\r\n                const c = attributeValue.charAt(pos);\r\n                if (c === '') {\r\n                    output.push((url + descriptorsStr).trim());\r\n                    break;\r\n                }\r\n                else if (!inParens) {\r\n                    if (c === ',') {\r\n                        pos += 1;\r\n                        output.push((url + descriptorsStr).trim());\r\n                        break;\r\n                    }\r\n                    else if (c === '(') {\r\n                        inParens = true;\r\n                    }\r\n                }\r\n                else {\r\n                    if (c === ')') {\r\n                        inParens = false;\r\n                    }\r\n                }\r\n                descriptorsStr += c;\r\n                pos += 1;\r\n            }\r\n        }\r\n    }\r\n    return output.join(', ');\r\n}\r\nconst cachedDocument = new WeakMap();\r\nfunction absoluteToDoc(doc, attributeValue) {\r\n    if (!attributeValue || attributeValue.trim() === '') {\r\n        return attributeValue;\r\n    }\r\n    return getHref(doc, attributeValue);\r\n}\r\nfunction isSVGElement(el) {\r\n    return Boolean(el.tagName === 'svg' || el.ownerSVGElement);\r\n}\r\nfunction getHref(doc, customHref) {\r\n    let a = cachedDocument.get(doc);\r\n    if (!a) {\r\n        a = doc.createElement('a');\r\n        cachedDocument.set(doc, a);\r\n    }\r\n    if (!customHref) {\r\n        customHref = '';\r\n    }\r\n    else if (customHref.startsWith('blob:') || customHref.startsWith('data:')) {\r\n        return customHref;\r\n    }\r\n    a.setAttribute('href', customHref);\r\n    return a.href;\r\n}\r\nfunction transformAttribute(doc, tagName, name, value, element, maskAttributeFn) {\r\n    if (!value) {\r\n        return value;\r\n    }\r\n    if (name === 'src' ||\r\n        (name === 'href' && !(tagName === 'use' && value[0] === '#'))) {\r\n        return absoluteToDoc(doc, value);\r\n    }\r\n    else if (name === 'xlink:href' && value[0] !== '#') {\r\n        return absoluteToDoc(doc, value);\r\n    }\r\n    else if (name === 'background' &&\r\n        (tagName === 'table' || tagName === 'td' || tagName === 'th')) {\r\n        return absoluteToDoc(doc, value);\r\n    }\r\n    else if (name === 'srcset') {\r\n        return getAbsoluteSrcsetString(doc, value);\r\n    }\r\n    else if (name === 'style') {\r\n        return absoluteToStylesheet(value, getHref(doc));\r\n    }\r\n    else if (tagName === 'object' && name === 'data') {\r\n        return absoluteToDoc(doc, value);\r\n    }\r\n    if (typeof maskAttributeFn === 'function') {\r\n        return maskAttributeFn(name, value, element);\r\n    }\r\n    return value;\r\n}\r\nfunction ignoreAttribute(tagName, name, _value) {\r\n    return (tagName === 'video' || tagName === 'audio') && name === 'autoplay';\r\n}\r\nfunction _isBlockedElement(element, blockClass, blockSelector, unblockSelector) {\r\n    try {\r\n        if (unblockSelector && element.matches(unblockSelector)) {\r\n            return false;\r\n        }\r\n        if (typeof blockClass === 'string') {\r\n            if (element.classList.contains(blockClass)) {\r\n                return true;\r\n            }\r\n        }\r\n        else {\r\n            for (let eIndex = element.classList.length; eIndex--;) {\r\n                const className = element.classList[eIndex];\r\n                if (blockClass.test(className)) {\r\n                    return true;\r\n                }\r\n            }\r\n        }\r\n        if (blockSelector) {\r\n            return element.matches(blockSelector);\r\n        }\r\n    }\r\n    catch (e) {\r\n    }\r\n    return false;\r\n}\r\nfunction elementClassMatchesRegex(el, regex) {\r\n    for (let eIndex = el.classList.length; eIndex--;) {\r\n        const className = el.classList[eIndex];\r\n        if (regex.test(className)) {\r\n            return true;\r\n        }\r\n    }\r\n    return false;\r\n}\r\nfunction distanceToMatch(node, matchPredicate, limit = Infinity, distance = 0) {\r\n    if (!node)\r\n        return -1;\r\n    if (node.nodeType !== node.ELEMENT_NODE)\r\n        return -1;\r\n    if (distance > limit)\r\n        return -1;\r\n    if (matchPredicate(node))\r\n        return distance;\r\n    return distanceToMatch(node.parentNode, matchPredicate, limit, distance + 1);\r\n}\r\nfunction createMatchPredicate(className, selector) {\r\n    return (node) => {\r\n        const el = node;\r\n        if (el === null)\r\n            return false;\r\n        try {\r\n            if (className) {\r\n                if (typeof className === 'string') {\r\n                    if (el.matches(`.${className}`))\r\n                        return true;\r\n                }\r\n                else if (elementClassMatchesRegex(el, className)) {\r\n                    return true;\r\n                }\r\n            }\r\n            if (selector && el.matches(selector))\r\n                return true;\r\n            return false;\r\n        }\r\n        catch {\r\n            return false;\r\n        }\r\n    };\r\n}\r\nfunction needMaskingText(node, maskTextClass, maskTextSelector, unmaskTextClass, unmaskTextSelector, maskAllText) {\r\n    try {\r\n        const el = node.nodeType === node.ELEMENT_NODE\r\n            ? node\r\n            : node.parentElement;\r\n        if (el === null)\r\n            return false;\r\n        if (el.tagName === 'INPUT') {\r\n            const autocomplete = el.getAttribute('autocomplete');\r\n            const disallowedAutocompleteValues = [\r\n                'current-password',\r\n                'new-password',\r\n                'cc-number',\r\n                'cc-exp',\r\n                'cc-exp-month',\r\n                'cc-exp-year',\r\n                'cc-csc',\r\n            ];\r\n            if (disallowedAutocompleteValues.includes(autocomplete)) {\r\n                return true;\r\n            }\r\n        }\r\n        let maskDistance = -1;\r\n        let unmaskDistance = -1;\r\n        if (maskAllText) {\r\n            unmaskDistance = distanceToMatch(el, createMatchPredicate(unmaskTextClass, unmaskTextSelector));\r\n            if (unmaskDistance < 0) {\r\n                return true;\r\n            }\r\n            maskDistance = distanceToMatch(el, createMatchPredicate(maskTextClass, maskTextSelector), unmaskDistance >= 0 ? unmaskDistance : Infinity);\r\n        }\r\n        else {\r\n            maskDistance = distanceToMatch(el, createMatchPredicate(maskTextClass, maskTextSelector));\r\n            if (maskDistance < 0) {\r\n                return false;\r\n            }\r\n            unmaskDistance = distanceToMatch(el, createMatchPredicate(unmaskTextClass, unmaskTextSelector), maskDistance >= 0 ? maskDistance : Infinity);\r\n        }\r\n        return maskDistance >= 0\r\n            ? unmaskDistance >= 0\r\n                ? maskDistance <= unmaskDistance\r\n                : true\r\n            : unmaskDistance >= 0\r\n                ? false\r\n                : !!maskAllText;\r\n    }\r\n    catch (e) {\r\n    }\r\n    return !!maskAllText;\r\n}\r\nfunction onceIframeLoaded(iframeEl, listener, iframeLoadTimeout) {\r\n    const win = iframeEl.contentWindow;\r\n    if (!win) {\r\n        return;\r\n    }\r\n    let fired = false;\r\n    let readyState;\r\n    try {\r\n        readyState = win.document.readyState;\r\n    }\r\n    catch (error) {\r\n        return;\r\n    }\r\n    if (readyState !== 'complete') {\r\n        const timer = setTimeout(() => {\r\n            if (!fired) {\r\n                listener();\r\n                fired = true;\r\n            }\r\n        }, iframeLoadTimeout);\r\n        iframeEl.addEventListener('load', () => {\r\n            clearTimeout(timer);\r\n            fired = true;\r\n            listener();\r\n        });\r\n        return;\r\n    }\r\n    const blankUrl = 'about:blank';\r\n    if (win.location.href !== blankUrl ||\r\n        iframeEl.src === blankUrl ||\r\n        iframeEl.src === '') {\r\n        setTimeout(listener, 0);\r\n        return iframeEl.addEventListener('load', listener);\r\n    }\r\n    iframeEl.addEventListener('load', listener);\r\n}\r\nfunction onceStylesheetLoaded(link, listener, styleSheetLoadTimeout) {\r\n    let fired = false;\r\n    let styleSheetLoaded;\r\n    try {\r\n        styleSheetLoaded = link.sheet;\r\n    }\r\n    catch (error) {\r\n        return;\r\n    }\r\n    if (styleSheetLoaded)\r\n        return;\r\n    const timer = setTimeout(() => {\r\n        if (!fired) {\r\n            listener();\r\n            fired = true;\r\n        }\r\n    }, styleSheetLoadTimeout);\r\n    link.addEventListener('load', () => {\r\n        clearTimeout(timer);\r\n        fired = true;\r\n        listener();\r\n    });\r\n}\r\nfunction serializeNode(n, options) {\r\n    const { doc, mirror, blockClass, blockSelector, unblockSelector, maskAllText, maskAttributeFn, maskTextClass, unmaskTextClass, maskTextSelector, unmaskTextSelector, inlineStylesheet, maskInputOptions = {}, maskTextFn, maskInputFn, dataURLOptions = {}, inlineImages, recordCanvas, keepIframeSrcFn, newlyAddedElement = false, } = options;\r\n    const rootId = getRootId(doc, mirror);\r\n    switch (n.nodeType) {\r\n        case n.DOCUMENT_NODE:\r\n            if (n.compatMode !== 'CSS1Compat') {\r\n                return {\r\n                    type: NodeType.Document,\r\n                    childNodes: [],\r\n                    compatMode: n.compatMode,\r\n                };\r\n            }\r\n            else {\r\n                return {\r\n                    type: NodeType.Document,\r\n                    childNodes: [],\r\n                };\r\n            }\r\n        case n.DOCUMENT_TYPE_NODE:\r\n            return {\r\n                type: NodeType.DocumentType,\r\n                name: n.name,\r\n                publicId: n.publicId,\r\n                systemId: n.systemId,\r\n                rootId,\r\n            };\r\n        case n.ELEMENT_NODE:\r\n            return serializeElementNode(n, {\r\n                doc,\r\n                blockClass,\r\n                blockSelector,\r\n                unblockSelector,\r\n                inlineStylesheet,\r\n                maskAttributeFn,\r\n                maskInputOptions,\r\n                maskInputFn,\r\n                dataURLOptions,\r\n                inlineImages,\r\n                recordCanvas,\r\n                keepIframeSrcFn,\r\n                newlyAddedElement,\r\n                rootId,\r\n                maskAllText,\r\n                maskTextClass,\r\n                unmaskTextClass,\r\n                maskTextSelector,\r\n                unmaskTextSelector,\r\n            });\r\n        case n.TEXT_NODE:\r\n            return serializeTextNode(n, {\r\n                doc,\r\n                maskAllText,\r\n                maskTextClass,\r\n                unmaskTextClass,\r\n                maskTextSelector,\r\n                unmaskTextSelector,\r\n                maskTextFn,\r\n                maskInputOptions,\r\n                maskInputFn,\r\n                rootId,\r\n            });\r\n        case n.CDATA_SECTION_NODE:\r\n            return {\r\n                type: NodeType.CDATA,\r\n                textContent: '',\r\n                rootId,\r\n            };\r\n        case n.COMMENT_NODE:\r\n            return {\r\n                type: NodeType.Comment,\r\n                textContent: n.textContent || '',\r\n                rootId,\r\n            };\r\n        default:\r\n            return false;\r\n    }\r\n}\r\nfunction getRootId(doc, mirror) {\r\n    if (!mirror.hasNode(doc))\r\n        return undefined;\r\n    const docId = mirror.getId(doc);\r\n    return docId === 1 ? undefined : docId;\r\n}\r\nfunction serializeTextNode(n, options) {\r\n    const { maskAllText, maskTextClass, unmaskTextClass, maskTextSelector, unmaskTextSelector, maskTextFn, maskInputOptions, maskInputFn, rootId, } = options;\r\n    const parentTagName = n.parentNode && n.parentNode.tagName;\r\n    let textContent = n.textContent;\r\n    const isStyle = parentTagName === 'STYLE' ? true : undefined;\r\n    const isScript = parentTagName === 'SCRIPT' ? true : undefined;\r\n    const isTextarea = parentTagName === 'TEXTAREA' ? true : undefined;\r\n    if (isStyle && textContent) {\r\n        try {\r\n            if (n.nextSibling || n.previousSibling) {\r\n            }\r\n            else if (n.parentNode.sheet?.cssRules) {\r\n                textContent = stringifyStylesheet(n.parentNode.sheet);\r\n            }\r\n        }\r\n        catch (err) {\r\n            console.warn(`Cannot get CSS styles from text's parentNode. Error: ${err}`, n);\r\n        }\r\n        textContent = absoluteToStylesheet(textContent, getHref(options.doc));\r\n    }\r\n    if (isScript) {\r\n        textContent = 'SCRIPT_PLACEHOLDER';\r\n    }\r\n    const forceMask = needMaskingText(n, maskTextClass, maskTextSelector, unmaskTextClass, unmaskTextSelector, maskAllText);\r\n    if (!isStyle && !isScript && !isTextarea && textContent && forceMask) {\r\n        textContent = maskTextFn\r\n            ? maskTextFn(textContent, n.parentElement)\r\n            : textContent.replace(/[\\S]/g, '*');\r\n    }\r\n    if (isTextarea && textContent && (maskInputOptions.textarea || forceMask)) {\r\n        textContent = maskInputFn\r\n            ? maskInputFn(textContent, n.parentNode)\r\n            : textContent.replace(/[\\S]/g, '*');\r\n    }\r\n    if (parentTagName === 'OPTION' && textContent) {\r\n        const isInputMasked = shouldMaskInput({\r\n            type: null,\r\n            tagName: parentTagName,\r\n            maskInputOptions,\r\n        });\r\n        textContent = maskInputValue({\r\n            isMasked: needMaskingText(n, maskTextClass, maskTextSelector, unmaskTextClass, unmaskTextSelector, isInputMasked),\r\n            element: n,\r\n            value: textContent,\r\n            maskInputFn,\r\n        });\r\n    }\r\n    return {\r\n        type: NodeType.Text,\r\n        textContent: textContent || '',\r\n        isStyle,\r\n        rootId,\r\n    };\r\n}\r\nfunction serializeElementNode(n, options) {\r\n    const { doc, blockClass, blockSelector, unblockSelector, inlineStylesheet, maskInputOptions = {}, maskAttributeFn, maskInputFn, dataURLOptions = {}, inlineImages, recordCanvas, keepIframeSrcFn, newlyAddedElement = false, rootId, maskAllText, maskTextClass, unmaskTextClass, maskTextSelector, unmaskTextSelector, } = options;\r\n    const needBlock = _isBlockedElement(n, blockClass, blockSelector, unblockSelector);\r\n    const tagName = getValidTagName(n);\r\n    let attributes = {};\r\n    const len = n.attributes.length;\r\n    for (let i = 0; i < len; i++) {\r\n        const attr = n.attributes[i];\r\n        if (attr.name && !ignoreAttribute(tagName, attr.name, attr.value)) {\r\n            attributes[attr.name] = transformAttribute(doc, tagName, toLowerCase(attr.name), attr.value, n, maskAttributeFn);\r\n        }\r\n    }\r\n    if (tagName === 'link' && inlineStylesheet) {\r\n        const stylesheet = Array.from(doc.styleSheets).find((s) => {\r\n            return s.href === n.href;\r\n        });\r\n        let cssText = null;\r\n        if (stylesheet) {\r\n            cssText = stringifyStylesheet(stylesheet);\r\n        }\r\n        if (cssText) {\r\n            attributes.rel = null;\r\n            attributes.href = null;\r\n            attributes.crossorigin = null;\r\n            attributes._cssText = absoluteToStylesheet(cssText, stylesheet.href);\r\n        }\r\n    }\r\n    if (tagName === 'style' &&\r\n        n.sheet &&\r\n        !(n.innerText || n.textContent || '').trim().length) {\r\n        const cssText = stringifyStylesheet(n.sheet);\r\n        if (cssText) {\r\n            attributes._cssText = absoluteToStylesheet(cssText, getHref(doc));\r\n        }\r\n    }\r\n    if (tagName === 'input' ||\r\n        tagName === 'textarea' ||\r\n        tagName === 'select' ||\r\n        tagName === 'option') {\r\n        const el = n;\r\n        const type = getInputType(el);\r\n        const value = getInputValue(el, toUpperCase(tagName), type);\r\n        const checked = el.checked;\r\n        if (type !== 'submit' && type !== 'button' && value) {\r\n            const forceMask = needMaskingText(el, maskTextClass, maskTextSelector, unmaskTextClass, unmaskTextSelector, shouldMaskInput({\r\n                type,\r\n                tagName: toUpperCase(tagName),\r\n                maskInputOptions,\r\n            }));\r\n            attributes.value = maskInputValue({\r\n                isMasked: forceMask,\r\n                element: el,\r\n                value,\r\n                maskInputFn,\r\n            });\r\n        }\r\n        if (checked) {\r\n            attributes.checked = checked;\r\n        }\r\n    }\r\n    if (tagName === 'option') {\r\n        if (n.selected && !maskInputOptions['select']) {\r\n            attributes.selected = true;\r\n        }\r\n        else {\r\n            delete attributes.selected;\r\n        }\r\n    }\r\n    if (tagName === 'canvas' && recordCanvas) {\r\n        if (n.__context === '2d') {\r\n            if (!is2DCanvasBlank(n)) {\r\n                attributes.rr_dataURL = n.toDataURL(dataURLOptions.type, dataURLOptions.quality);\r\n            }\r\n        }\r\n        else if (!('__context' in n)) {\r\n            const canvasDataURL = n.toDataURL(dataURLOptions.type, dataURLOptions.quality);\r\n            const blankCanvas = doc.createElement('canvas');\r\n            blankCanvas.width = n.width;\r\n            blankCanvas.height = n.height;\r\n            const blankCanvasDataURL = blankCanvas.toDataURL(dataURLOptions.type, dataURLOptions.quality);\r\n            if (canvasDataURL !== blankCanvasDataURL) {\r\n                attributes.rr_dataURL = canvasDataURL;\r\n            }\r\n        }\r\n    }\r\n    if (tagName === 'img' && inlineImages) {\r\n        if (!canvasService) {\r\n            canvasService = doc.createElement('canvas');\r\n            canvasCtx = canvasService.getContext('2d');\r\n        }\r\n        const image = n;\r\n        const imageSrc = image.currentSrc || image.getAttribute('src') || '<unknown-src>';\r\n        const priorCrossOrigin = image.crossOrigin;\r\n        const recordInlineImage = () => {\r\n            image.removeEventListener('load', recordInlineImage);\r\n            try {\r\n                canvasService.width = image.naturalWidth;\r\n                canvasService.height = image.naturalHeight;\r\n                canvasCtx.drawImage(image, 0, 0);\r\n                attributes.rr_dataURL = canvasService.toDataURL(dataURLOptions.type, dataURLOptions.quality);\r\n            }\r\n            catch (err) {\r\n                if (image.crossOrigin !== 'anonymous') {\r\n                    image.crossOrigin = 'anonymous';\r\n                    if (image.complete && image.naturalWidth !== 0)\r\n                        recordInlineImage();\r\n                    else\r\n                        image.addEventListener('load', recordInlineImage);\r\n                    return;\r\n                }\r\n                else {\r\n                    console.warn(`Cannot inline img src=${imageSrc}! Error: ${err}`);\r\n                }\r\n            }\r\n            if (image.crossOrigin === 'anonymous') {\r\n                priorCrossOrigin\r\n                    ? (attributes.crossOrigin = priorCrossOrigin)\r\n                    : image.removeAttribute('crossorigin');\r\n            }\r\n        };\r\n        if (image.complete && image.naturalWidth !== 0)\r\n            recordInlineImage();\r\n        else\r\n            image.addEventListener('load', recordInlineImage);\r\n    }\r\n    if (tagName === 'audio' || tagName === 'video') {\r\n        attributes.rr_mediaState = n.paused\r\n            ? 'paused'\r\n            : 'played';\r\n        attributes.rr_mediaCurrentTime = n.currentTime;\r\n    }\r\n    if (!newlyAddedElement) {\r\n        if (n.scrollLeft) {\r\n            attributes.rr_scrollLeft = n.scrollLeft;\r\n        }\r\n        if (n.scrollTop) {\r\n            attributes.rr_scrollTop = n.scrollTop;\r\n        }\r\n    }\r\n    if (needBlock) {\r\n        const { width, height } = n.getBoundingClientRect();\r\n        attributes = {\r\n            class: attributes.class,\r\n            rr_width: `${width}px`,\r\n            rr_height: `${height}px`,\r\n        };\r\n    }\r\n    if (tagName === 'iframe' && !keepIframeSrcFn(attributes.src)) {\r\n        if (!needBlock && !getIframeContentDocument(n)) {\r\n            attributes.rr_src = attributes.src;\r\n        }\r\n        delete attributes.src;\r\n    }\r\n    let isCustomElement;\r\n    try {\r\n        if (customElements.get(tagName))\r\n            isCustomElement = true;\r\n    }\r\n    catch (e) {\r\n    }\r\n    return {\r\n        type: NodeType.Element,\r\n        tagName,\r\n        attributes,\r\n        childNodes: [],\r\n        isSVG: isSVGElement(n) || undefined,\r\n        needBlock,\r\n        rootId,\r\n        isCustom: isCustomElement,\r\n    };\r\n}\r\nfunction lowerIfExists(maybeAttr) {\r\n    if (maybeAttr === undefined || maybeAttr === null) {\r\n        return '';\r\n    }\r\n    else {\r\n        return maybeAttr.toLowerCase();\r\n    }\r\n}\r\nfunction slimDOMExcluded(sn, slimDOMOptions) {\r\n    if (slimDOMOptions.comment && sn.type === NodeType.Comment) {\r\n        return true;\r\n    }\r\n    else if (sn.type === NodeType.Element) {\r\n        if (slimDOMOptions.script &&\r\n            (sn.tagName === 'script' ||\r\n                (sn.tagName === 'link' &&\r\n                    (sn.attributes.rel === 'preload' ||\r\n                        sn.attributes.rel === 'modulepreload')) ||\r\n                (sn.tagName === 'link' &&\r\n                    sn.attributes.rel === 'prefetch' &&\r\n                    typeof sn.attributes.href === 'string' &&\r\n                    extractFileExtension(sn.attributes.href) === 'js'))) {\r\n            return true;\r\n        }\r\n        else if (slimDOMOptions.headFavicon &&\r\n            ((sn.tagName === 'link' && sn.attributes.rel === 'shortcut icon') ||\r\n                (sn.tagName === 'meta' &&\r\n                    (lowerIfExists(sn.attributes.name).match(/^msapplication-tile(image|color)$/) ||\r\n                        lowerIfExists(sn.attributes.name) === 'application-name' ||\r\n                        lowerIfExists(sn.attributes.rel) === 'icon' ||\r\n                        lowerIfExists(sn.attributes.rel) === 'apple-touch-icon' ||\r\n                        lowerIfExists(sn.attributes.rel) === 'shortcut icon')))) {\r\n            return true;\r\n        }\r\n        else if (sn.tagName === 'meta') {\r\n            if (slimDOMOptions.headMetaDescKeywords &&\r\n                lowerIfExists(sn.attributes.name).match(/^description|keywords$/)) {\r\n                return true;\r\n            }\r\n            else if (slimDOMOptions.headMetaSocial &&\r\n                (lowerIfExists(sn.attributes.property).match(/^(og|twitter|fb):/) ||\r\n                    lowerIfExists(sn.attributes.name).match(/^(og|twitter):/) ||\r\n                    lowerIfExists(sn.attributes.name) === 'pinterest')) {\r\n                return true;\r\n            }\r\n            else if (slimDOMOptions.headMetaRobots &&\r\n                (lowerIfExists(sn.attributes.name) === 'robots' ||\r\n                    lowerIfExists(sn.attributes.name) === 'googlebot' ||\r\n                    lowerIfExists(sn.attributes.name) === 'bingbot')) {\r\n                return true;\r\n            }\r\n            else if (slimDOMOptions.headMetaHttpEquiv &&\r\n                sn.attributes['http-equiv'] !== undefined) {\r\n                return true;\r\n            }\r\n            else if (slimDOMOptions.headMetaAuthorship &&\r\n                (lowerIfExists(sn.attributes.name) === 'author' ||\r\n                    lowerIfExists(sn.attributes.name) === 'generator' ||\r\n                    lowerIfExists(sn.attributes.name) === 'framework' ||\r\n                    lowerIfExists(sn.attributes.name) === 'publisher' ||\r\n                    lowerIfExists(sn.attributes.name) === 'progid' ||\r\n                    lowerIfExists(sn.attributes.property).match(/^article:/) ||\r\n                    lowerIfExists(sn.attributes.property).match(/^product:/))) {\r\n                return true;\r\n            }\r\n            else if (slimDOMOptions.headMetaVerification &&\r\n                (lowerIfExists(sn.attributes.name) === 'google-site-verification' ||\r\n                    lowerIfExists(sn.attributes.name) === 'yandex-verification' ||\r\n                    lowerIfExists(sn.attributes.name) === 'csrf-token' ||\r\n                    lowerIfExists(sn.attributes.name) === 'p:domain_verify' ||\r\n                    lowerIfExists(sn.attributes.name) === 'verify-v1' ||\r\n                    lowerIfExists(sn.attributes.name) === 'verification' ||\r\n                    lowerIfExists(sn.attributes.name) === 'shopify-checkout-api-token')) {\r\n                return true;\r\n            }\r\n        }\r\n    }\r\n    return false;\r\n}\r\nfunction serializeNodeWithId(n, options) {\r\n    const { doc, mirror, blockClass, blockSelector, unblockSelector, maskAllText, maskTextClass, unmaskTextClass, maskTextSelector, unmaskTextSelector, skipChild = false, inlineStylesheet = true, maskInputOptions = {}, maskAttributeFn, maskTextFn, maskInputFn, slimDOMOptions, dataURLOptions = {}, inlineImages = false, recordCanvas = false, onSerialize, onIframeLoad, iframeLoadTimeout = 5000, onStylesheetLoad, stylesheetLoadTimeout = 5000, keepIframeSrcFn = () => false, newlyAddedElement = false, } = options;\r\n    let { preserveWhiteSpace = true } = options;\r\n    const _serializedNode = serializeNode(n, {\r\n        doc,\r\n        mirror,\r\n        blockClass,\r\n        blockSelector,\r\n        maskAllText,\r\n        unblockSelector,\r\n        maskTextClass,\r\n        unmaskTextClass,\r\n        maskTextSelector,\r\n        unmaskTextSelector,\r\n        inlineStylesheet,\r\n        maskInputOptions,\r\n        maskAttributeFn,\r\n        maskTextFn,\r\n        maskInputFn,\r\n        dataURLOptions,\r\n        inlineImages,\r\n        recordCanvas,\r\n        keepIframeSrcFn,\r\n        newlyAddedElement,\r\n    });\r\n    if (!_serializedNode) {\r\n        console.warn(n, 'not serialized');\r\n        return null;\r\n    }\r\n    let id;\r\n    if (mirror.hasNode(n)) {\r\n        id = mirror.getId(n);\r\n    }\r\n    else if (slimDOMExcluded(_serializedNode, slimDOMOptions) ||\r\n        (!preserveWhiteSpace &&\r\n            _serializedNode.type === NodeType.Text &&\r\n            !_serializedNode.isStyle &&\r\n            !_serializedNode.textContent.replace(/^\\s+|\\s+$/gm, '').length)) {\r\n        id = IGNORED_NODE;\r\n    }\r\n    else {\r\n        id = genId();\r\n    }\r\n    const serializedNode = Object.assign(_serializedNode, { id });\r\n    mirror.add(n, serializedNode);\r\n    if (id === IGNORED_NODE) {\r\n        return null;\r\n    }\r\n    if (onSerialize) {\r\n        onSerialize(n);\r\n    }\r\n    let recordChild = !skipChild;\r\n    if (serializedNode.type === NodeType.Element) {\r\n        recordChild = recordChild && !serializedNode.needBlock;\r\n        delete serializedNode.needBlock;\r\n        const shadowRoot = n.shadowRoot;\r\n        if (shadowRoot && isNativeShadowDom(shadowRoot))\r\n            serializedNode.isShadowHost = true;\r\n    }\r\n    if ((serializedNode.type === NodeType.Document ||\r\n        serializedNode.type === NodeType.Element) &&\r\n        recordChild) {\r\n        if (slimDOMOptions.headWhitespace &&\r\n            serializedNode.type === NodeType.Element &&\r\n            serializedNode.tagName === 'head') {\r\n            preserveWhiteSpace = false;\r\n        }\r\n        const bypassOptions = {\r\n            doc,\r\n            mirror,\r\n            blockClass,\r\n            blockSelector,\r\n            maskAllText,\r\n            unblockSelector,\r\n            maskTextClass,\r\n            unmaskTextClass,\r\n            maskTextSelector,\r\n            unmaskTextSelector,\r\n            skipChild,\r\n            inlineStylesheet,\r\n            maskInputOptions,\r\n            maskAttributeFn,\r\n            maskTextFn,\r\n            maskInputFn,\r\n            slimDOMOptions,\r\n            dataURLOptions,\r\n            inlineImages,\r\n            recordCanvas,\r\n            preserveWhiteSpace,\r\n            onSerialize,\r\n            onIframeLoad,\r\n            iframeLoadTimeout,\r\n            onStylesheetLoad,\r\n            stylesheetLoadTimeout,\r\n            keepIframeSrcFn,\r\n        };\r\n        for (const childN of Array.from(n.childNodes)) {\r\n            const serializedChildNode = serializeNodeWithId(childN, bypassOptions);\r\n            if (serializedChildNode) {\r\n                serializedNode.childNodes.push(serializedChildNode);\r\n            }\r\n        }\r\n        if (isElement(n) && n.shadowRoot) {\r\n            for (const childN of Array.from(n.shadowRoot.childNodes)) {\r\n                const serializedChildNode = serializeNodeWithId(childN, bypassOptions);\r\n                if (serializedChildNode) {\r\n                    isNativeShadowDom(n.shadowRoot) &&\r\n                        (serializedChildNode.isShadow = true);\r\n                    serializedNode.childNodes.push(serializedChildNode);\r\n                }\r\n            }\r\n        }\r\n    }\r\n    if (n.parentNode &&\r\n        isShadowRoot(n.parentNode) &&\r\n        isNativeShadowDom(n.parentNode)) {\r\n        serializedNode.isShadow = true;\r\n    }\r\n    if (serializedNode.type === NodeType.Element &&\r\n        serializedNode.tagName === 'iframe') {\r\n        onceIframeLoaded(n, () => {\r\n            const iframeDoc = getIframeContentDocument(n);\r\n            if (iframeDoc && onIframeLoad) {\r\n                const serializedIframeNode = serializeNodeWithId(iframeDoc, {\r\n                    doc: iframeDoc,\r\n                    mirror,\r\n                    blockClass,\r\n                    blockSelector,\r\n                    unblockSelector,\r\n                    maskAllText,\r\n                    maskTextClass,\r\n                    unmaskTextClass,\r\n                    maskTextSelector,\r\n                    unmaskTextSelector,\r\n                    skipChild: false,\r\n                    inlineStylesheet,\r\n                    maskInputOptions,\r\n                    maskAttributeFn,\r\n                    maskTextFn,\r\n                    maskInputFn,\r\n                    slimDOMOptions,\r\n                    dataURLOptions,\r\n                    inlineImages,\r\n                    recordCanvas,\r\n                    preserveWhiteSpace,\r\n                    onSerialize,\r\n                    onIframeLoad,\r\n                    iframeLoadTimeout,\r\n                    onStylesheetLoad,\r\n                    stylesheetLoadTimeout,\r\n                    keepIframeSrcFn,\r\n                });\r\n                if (serializedIframeNode) {\r\n                    onIframeLoad(n, serializedIframeNode);\r\n                }\r\n            }\r\n        }, iframeLoadTimeout);\r\n    }\r\n    if (serializedNode.type === NodeType.Element &&\r\n        serializedNode.tagName === 'link' &&\r\n        typeof serializedNode.attributes.rel === 'string' &&\r\n        (serializedNode.attributes.rel === 'stylesheet' ||\r\n            (serializedNode.attributes.rel === 'preload' &&\r\n                typeof serializedNode.attributes.href === 'string' &&\r\n                extractFileExtension(serializedNode.attributes.href) === 'css'))) {\r\n        onceStylesheetLoaded(n, () => {\r\n            if (onStylesheetLoad) {\r\n                const serializedLinkNode = serializeNodeWithId(n, {\r\n                    doc,\r\n                    mirror,\r\n                    blockClass,\r\n                    blockSelector,\r\n                    unblockSelector,\r\n                    maskAllText,\r\n                    maskTextClass,\r\n                    unmaskTextClass,\r\n                    maskTextSelector,\r\n                    unmaskTextSelector,\r\n                    skipChild: false,\r\n                    inlineStylesheet,\r\n                    maskInputOptions,\r\n                    maskAttributeFn,\r\n                    maskTextFn,\r\n                    maskInputFn,\r\n                    slimDOMOptions,\r\n                    dataURLOptions,\r\n                    inlineImages,\r\n                    recordCanvas,\r\n                    preserveWhiteSpace,\r\n                    onSerialize,\r\n                    onIframeLoad,\r\n                    iframeLoadTimeout,\r\n                    onStylesheetLoad,\r\n                    stylesheetLoadTimeout,\r\n                    keepIframeSrcFn,\r\n                });\r\n                if (serializedLinkNode) {\r\n                    onStylesheetLoad(n, serializedLinkNode);\r\n                }\r\n            }\r\n        }, stylesheetLoadTimeout);\r\n    }\r\n    return serializedNode;\r\n}\r\nfunction snapshot(n, options) {\r\n    const { mirror = new Mirror(), blockClass = 'rr-block', blockSelector = null, unblockSelector = null, maskAllText = false, maskTextClass = 'rr-mask', unmaskTextClass = null, maskTextSelector = null, unmaskTextSelector = null, inlineStylesheet = true, inlineImages = false, recordCanvas = false, maskAllInputs = false, maskAttributeFn, maskTextFn, maskInputFn, slimDOM = false, dataURLOptions, preserveWhiteSpace, onSerialize, onIframeLoad, iframeLoadTimeout, onStylesheetLoad, stylesheetLoadTimeout, keepIframeSrcFn = () => false, } = options || {};\r\n    const maskInputOptions = maskAllInputs === true\r\n        ? {\r\n            color: true,\r\n            date: true,\r\n            'datetime-local': true,\r\n            email: true,\r\n            month: true,\r\n            number: true,\r\n            range: true,\r\n            search: true,\r\n            tel: true,\r\n            text: true,\r\n            time: true,\r\n            url: true,\r\n            week: true,\r\n            textarea: true,\r\n            select: true,\r\n        }\r\n        : maskAllInputs === false\r\n            ? {}\r\n            : maskAllInputs;\r\n    const slimDOMOptions = slimDOM === true || slimDOM === 'all'\r\n        ?\r\n            {\r\n                script: true,\r\n                comment: true,\r\n                headFavicon: true,\r\n                headWhitespace: true,\r\n                headMetaDescKeywords: slimDOM === 'all',\r\n                headMetaSocial: true,\r\n                headMetaRobots: true,\r\n                headMetaHttpEquiv: true,\r\n                headMetaAuthorship: true,\r\n                headMetaVerification: true,\r\n            }\r\n        : slimDOM === false\r\n            ? {}\r\n            : slimDOM;\r\n    return serializeNodeWithId(n, {\r\n        doc: n,\r\n        mirror,\r\n        blockClass,\r\n        blockSelector,\r\n        unblockSelector,\r\n        maskAllText,\r\n        maskTextClass,\r\n        unmaskTextClass,\r\n        maskTextSelector,\r\n        unmaskTextSelector,\r\n        skipChild: false,\r\n        inlineStylesheet,\r\n        maskInputOptions,\r\n        maskAttributeFn,\r\n        maskTextFn,\r\n        maskInputFn,\r\n        slimDOMOptions,\r\n        dataURLOptions,\r\n        inlineImages,\r\n        recordCanvas,\r\n        preserveWhiteSpace,\r\n        onSerialize,\r\n        onIframeLoad,\r\n        iframeLoadTimeout,\r\n        onStylesheetLoad,\r\n        stylesheetLoadTimeout,\r\n        keepIframeSrcFn,\r\n        newlyAddedElement: false,\r\n    });\r\n}\r\n\nconst commentre = /\\/\\*[^*]*\\*+([^/*][^*]*\\*+)*\\//g;\r\nfunction parse(css, options = {}) {\r\n    let lineno = 1;\r\n    let column = 1;\r\n    function updatePosition(str) {\r\n        const lines = str.match(/\\n/g);\r\n        if (lines) {\r\n            lineno += lines.length;\r\n        }\r\n        const i = str.lastIndexOf('\\n');\r\n        column = i === -1 ? column + str.length : str.length - i;\r\n    }\r\n    function position() {\r\n        const start = { line: lineno, column };\r\n        return (node) => {\r\n            node.position = new Position(start);\r\n            whitespace();\r\n            return node;\r\n        };\r\n    }\r\n    class Position {\r\n        constructor(start) {\r\n            this.start = start;\r\n            this.end = { line: lineno, column };\r\n            this.source = options.source;\r\n        }\r\n    }\r\n    Position.prototype.content = css;\r\n    const errorsList = [];\r\n    function error(msg) {\r\n        const err = new Error(`${options.source || ''}:${lineno}:${column}: ${msg}`);\r\n        err.reason = msg;\r\n        err.filename = options.source;\r\n        err.line = lineno;\r\n        err.column = column;\r\n        err.source = css;\r\n        if (options.silent) {\r\n            errorsList.push(err);\r\n        }\r\n        else {\r\n            throw err;\r\n        }\r\n    }\r\n    function stylesheet() {\r\n        const rulesList = rules();\r\n        return {\r\n            type: 'stylesheet',\r\n            stylesheet: {\r\n                source: options.source,\r\n                rules: rulesList,\r\n                parsingErrors: errorsList,\r\n            },\r\n        };\r\n    }\r\n    function open() {\r\n        return match(/^{\\s*/);\r\n    }\r\n    function close() {\r\n        return match(/^}/);\r\n    }\r\n    function rules() {\r\n        let node;\r\n        const rules = [];\r\n        whitespace();\r\n        comments(rules);\r\n        while (css.length && css.charAt(0) !== '}' && (node = atrule() || rule())) {\r\n            if (node) {\r\n                rules.push(node);\r\n                comments(rules);\r\n            }\r\n        }\r\n        return rules;\r\n    }\r\n    function match(re) {\r\n        const m = re.exec(css);\r\n        if (!m) {\r\n            return;\r\n        }\r\n        const str = m[0];\r\n        updatePosition(str);\r\n        css = css.slice(str.length);\r\n        return m;\r\n    }\r\n    function whitespace() {\r\n        match(/^\\s*/);\r\n    }\r\n    function comments(rules = []) {\r\n        let c;\r\n        while ((c = comment())) {\r\n            if (c) {\r\n                rules.push(c);\r\n            }\r\n            c = comment();\r\n        }\r\n        return rules;\r\n    }\r\n    function comment() {\r\n        const pos = position();\r\n        if ('/' !== css.charAt(0) || '*' !== css.charAt(1)) {\r\n            return;\r\n        }\r\n        let i = 2;\r\n        while ('' !== css.charAt(i) &&\r\n            ('*' !== css.charAt(i) || '/' !== css.charAt(i + 1))) {\r\n            ++i;\r\n        }\r\n        i += 2;\r\n        if ('' === css.charAt(i - 1)) {\r\n            return error('End of comment missing');\r\n        }\r\n        const str = css.slice(2, i - 2);\r\n        column += 2;\r\n        updatePosition(str);\r\n        css = css.slice(i);\r\n        column += 2;\r\n        return pos({\r\n            type: 'comment',\r\n            comment: str,\r\n        });\r\n    }\r\n    function selector() {\r\n        const m = match(/^([^{]+)/);\r\n        if (!m) {\r\n            return;\r\n        }\r\n        const splitSelectors = trim(m[0])\r\n            .replace(/\\/\\*([^*]|[\\r\\n]|(\\*+([^*/]|[\\r\\n])))*\\*\\/+/g, '')\r\n            .replace(/\"(?:\\\\\"|[^\"])*\"|'(?:\\\\'|[^'])*'/g, (m) => {\r\n            return m.replace(/,/g, '\\u200C');\r\n        })\r\n            .split(/\\s*(?![^(]*\\)),\\s*/);\r\n        if (splitSelectors.length <= 1) {\r\n            return splitSelectors.map((s) => {\r\n                return s.replace(/\\u200C/g, ',');\r\n            });\r\n        }\r\n        let i = 0;\r\n        let j = 0;\r\n        const len = splitSelectors.length;\r\n        const finalSelectors = [];\r\n        while (i < len) {\r\n            const openingParensCount = (splitSelectors[i].match(/\\(/g) || []).length;\r\n            const closingParensCount = (splitSelectors[i].match(/\\)/g) || []).length;\r\n            let unbalancedParens = openingParensCount - closingParensCount;\r\n            if (unbalancedParens >= 1) {\r\n                let foundClosingSelector = false;\r\n                j = i + 1;\r\n                while (j < len) {\r\n                    const nextOpeningParensCount = (splitSelectors[j].match(/\\(/g) || [])\r\n                        .length;\r\n                    const nextClosingParensCount = (splitSelectors[j].match(/\\)/g) || [])\r\n                        .length;\r\n                    const nextUnbalancedParens = nextClosingParensCount - nextOpeningParensCount;\r\n                    if (nextUnbalancedParens === unbalancedParens) {\r\n                        finalSelectors.push(splitSelectors.slice(i, j + 1).join(','));\r\n                        i = j + 1;\r\n                        foundClosingSelector = true;\r\n                        break;\r\n                    }\r\n                    j++;\r\n                    unbalancedParens -= nextUnbalancedParens;\r\n                }\r\n                if (foundClosingSelector) {\r\n                    continue;\r\n                }\r\n                splitSelectors\r\n                    .slice(i, len)\r\n                    .forEach((selector) => selector && finalSelectors.push(selector));\r\n                break;\r\n            }\r\n            splitSelectors[i] && finalSelectors.push(splitSelectors[i]);\r\n            i++;\r\n        }\r\n        return finalSelectors.map((s) => {\r\n            return s.replace(/\\u200C/g, ',');\r\n        });\r\n    }\r\n    function declaration() {\r\n        const pos = position();\r\n        const propMatch = match(/^(\\*?[-#\\/\\*\\\\\\w]+(\\[[0-9a-z_-]+\\])?)\\s*/);\r\n        if (!propMatch) {\r\n            return;\r\n        }\r\n        const prop = trim(propMatch[0]);\r\n        if (!match(/^:\\s*/)) {\r\n            return error(`property missing ':'`);\r\n        }\r\n        const val = match(/^((?:'(?:\\\\'|.)*?'|\"(?:\\\\\"|.)*?\"|\\([^\\)]*?\\)|[^};])+)/);\r\n        const ret = pos({\r\n            type: 'declaration',\r\n            property: prop.replace(commentre, ''),\r\n            value: val ? trim(val[0]).replace(commentre, '') : '',\r\n        });\r\n        match(/^[;\\s]*/);\r\n        return ret;\r\n    }\r\n    function declarations() {\r\n        const decls = [];\r\n        if (!open()) {\r\n            return error(`missing '{'`);\r\n        }\r\n        comments(decls);\r\n        let decl;\r\n        while ((decl = declaration())) {\r\n            if (decl !== false) {\r\n                decls.push(decl);\r\n                comments(decls);\r\n            }\r\n            decl = declaration();\r\n        }\r\n        if (!close()) {\r\n            return error(`missing '}'`);\r\n        }\r\n        return decls;\r\n    }\r\n    function keyframe() {\r\n        let m;\r\n        const vals = [];\r\n        const pos = position();\r\n        while ((m = match(/^((\\d+\\.\\d+|\\.\\d+|\\d+)%?|[a-z]+)\\s*/))) {\r\n            vals.push(m[1]);\r\n            match(/^,\\s*/);\r\n        }\r\n        if (!vals.length) {\r\n            return;\r\n        }\r\n        return pos({\r\n            type: 'keyframe',\r\n            values: vals,\r\n            declarations: declarations(),\r\n        });\r\n    }\r\n    function atkeyframes() {\r\n        const pos = position();\r\n        let m = match(/^@([-\\w]+)?keyframes\\s*/);\r\n        if (!m) {\r\n            return;\r\n        }\r\n        const vendor = m[1];\r\n        m = match(/^([-\\w]+)\\s*/);\r\n        if (!m) {\r\n            return error('@keyframes missing name');\r\n        }\r\n        const name = m[1];\r\n        if (!open()) {\r\n            return error(`@keyframes missing '{'`);\r\n        }\r\n        let frame;\r\n        let frames = comments();\r\n        while ((frame = keyframe())) {\r\n            frames.push(frame);\r\n            frames = frames.concat(comments());\r\n        }\r\n        if (!close()) {\r\n            return error(`@keyframes missing '}'`);\r\n        }\r\n        return pos({\r\n            type: 'keyframes',\r\n            name,\r\n            vendor,\r\n            keyframes: frames,\r\n        });\r\n    }\r\n    function atsupports() {\r\n        const pos = position();\r\n        const m = match(/^@supports *([^{]+)/);\r\n        if (!m) {\r\n            return;\r\n        }\r\n        const supports = trim(m[1]);\r\n        if (!open()) {\r\n            return error(`@supports missing '{'`);\r\n        }\r\n        const style = comments().concat(rules());\r\n        if (!close()) {\r\n            return error(`@supports missing '}'`);\r\n        }\r\n        return pos({\r\n            type: 'supports',\r\n            supports,\r\n            rules: style,\r\n        });\r\n    }\r\n    function athost() {\r\n        const pos = position();\r\n        const m = match(/^@host\\s*/);\r\n        if (!m) {\r\n            return;\r\n        }\r\n        if (!open()) {\r\n            return error(`@host missing '{'`);\r\n        }\r\n        const style = comments().concat(rules());\r\n        if (!close()) {\r\n            return error(`@host missing '}'`);\r\n        }\r\n        return pos({\r\n            type: 'host',\r\n            rules: style,\r\n        });\r\n    }\r\n    function atmedia() {\r\n        const pos = position();\r\n        const m = match(/^@media *([^{]+)/);\r\n        if (!m) {\r\n            return;\r\n        }\r\n        const media = trim(m[1]);\r\n        if (!open()) {\r\n            return error(`@media missing '{'`);\r\n        }\r\n        const style = comments().concat(rules());\r\n        if (!close()) {\r\n            return error(`@media missing '}'`);\r\n        }\r\n        return pos({\r\n            type: 'media',\r\n            media,\r\n            rules: style,\r\n        });\r\n    }\r\n    function atcustommedia() {\r\n        const pos = position();\r\n        const m = match(/^@custom-media\\s+(--[^\\s]+)\\s*([^{;]+);/);\r\n        if (!m) {\r\n            return;\r\n        }\r\n        return pos({\r\n            type: 'custom-media',\r\n            name: trim(m[1]),\r\n            media: trim(m[2]),\r\n        });\r\n    }\r\n    function atpage() {\r\n        const pos = position();\r\n        const m = match(/^@page */);\r\n        if (!m) {\r\n            return;\r\n        }\r\n        const sel = selector() || [];\r\n        if (!open()) {\r\n            return error(`@page missing '{'`);\r\n        }\r\n        let decls = comments();\r\n        let decl;\r\n        while ((decl = declaration())) {\r\n            decls.push(decl);\r\n            decls = decls.concat(comments());\r\n        }\r\n        if (!close()) {\r\n            return error(`@page missing '}'`);\r\n        }\r\n        return pos({\r\n            type: 'page',\r\n            selectors: sel,\r\n            declarations: decls,\r\n        });\r\n    }\r\n    function atdocument() {\r\n        const pos = position();\r\n        const m = match(/^@([-\\w]+)?document *([^{]+)/);\r\n        if (!m) {\r\n            return;\r\n        }\r\n        const vendor = trim(m[1]);\r\n        const doc = trim(m[2]);\r\n        if (!open()) {\r\n            return error(`@document missing '{'`);\r\n        }\r\n        const style = comments().concat(rules());\r\n        if (!close()) {\r\n            return error(`@document missing '}'`);\r\n        }\r\n        return pos({\r\n            type: 'document',\r\n            document: doc,\r\n            vendor,\r\n            rules: style,\r\n        });\r\n    }\r\n    function atfontface() {\r\n        const pos = position();\r\n        const m = match(/^@font-face\\s*/);\r\n        if (!m) {\r\n            return;\r\n        }\r\n        if (!open()) {\r\n            return error(`@font-face missing '{'`);\r\n        }\r\n        let decls = comments();\r\n        let decl;\r\n        while ((decl = declaration())) {\r\n            decls.push(decl);\r\n            decls = decls.concat(comments());\r\n        }\r\n        if (!close()) {\r\n            return error(`@font-face missing '}'`);\r\n        }\r\n        return pos({\r\n            type: 'font-face',\r\n            declarations: decls,\r\n        });\r\n    }\r\n    const atimport = _compileAtrule('import');\r\n    const atcharset = _compileAtrule('charset');\r\n    const atnamespace = _compileAtrule('namespace');\r\n    function _compileAtrule(name) {\r\n        const re = new RegExp('^@' +\r\n            name +\r\n            '\\\\s*((?:' +\r\n            [\r\n                /[^\\\\]\"(?:\\\\\"|[^\"])*\"/.source,\r\n                /[^\\\\]'(?:\\\\'|[^'])*'/.source,\r\n                '[^;]',\r\n            ].join('|') +\r\n            ')+);');\r\n        return () => {\r\n            const pos = position();\r\n            const m = match(re);\r\n            if (!m) {\r\n                return;\r\n            }\r\n            const ret = { type: name };\r\n            ret[name] = m[1].trim();\r\n            return pos(ret);\r\n        };\r\n    }\r\n    function atrule() {\r\n        if (css[0] !== '@') {\r\n            return;\r\n        }\r\n        return (atkeyframes() ||\r\n            atmedia() ||\r\n            atcustommedia() ||\r\n            atsupports() ||\r\n            atimport() ||\r\n            atcharset() ||\r\n            atnamespace() ||\r\n            atdocument() ||\r\n            atpage() ||\r\n            athost() ||\r\n            atfontface());\r\n    }\r\n    function rule() {\r\n        const pos = position();\r\n        const sel = selector();\r\n        if (!sel) {\r\n            return error('selector missing');\r\n        }\r\n        comments();\r\n        return pos({\r\n            type: 'rule',\r\n            selectors: sel,\r\n            declarations: declarations(),\r\n        });\r\n    }\r\n    return addParent(stylesheet());\r\n}\r\nfunction trim(str) {\r\n    return str ? str.replace(/^\\s+|\\s+$/g, '') : '';\r\n}\r\nfunction addParent(obj, parent) {\r\n    const isNode = obj && typeof obj.type === 'string';\r\n    const childParent = isNode ? obj : parent;\r\n    for (const k of Object.keys(obj)) {\r\n        const value = obj[k];\r\n        if (Array.isArray(value)) {\r\n            value.forEach((v) => {\r\n                addParent(v, childParent);\r\n            });\r\n        }\r\n        else if (value && typeof value === 'object') {\r\n            addParent(value, childParent);\r\n        }\r\n    }\r\n    if (isNode) {\r\n        Object.defineProperty(obj, 'parent', {\r\n            configurable: true,\r\n            writable: true,\r\n            enumerable: false,\r\n            value: parent || null,\r\n        });\r\n    }\r\n    return obj;\r\n}\n\nconst tagMap = {\r\n    script: 'noscript',\r\n    altglyph: 'altGlyph',\r\n    altglyphdef: 'altGlyphDef',\r\n    altglyphitem: 'altGlyphItem',\r\n    animatecolor: 'animateColor',\r\n    animatemotion: 'animateMotion',\r\n    animatetransform: 'animateTransform',\r\n    clippath: 'clipPath',\r\n    feblend: 'feBlend',\r\n    fecolormatrix: 'feColorMatrix',\r\n    fecomponenttransfer: 'feComponentTransfer',\r\n    fecomposite: 'feComposite',\r\n    feconvolvematrix: 'feConvolveMatrix',\r\n    fediffuselighting: 'feDiffuseLighting',\r\n    fedisplacementmap: 'feDisplacementMap',\r\n    fedistantlight: 'feDistantLight',\r\n    fedropshadow: 'feDropShadow',\r\n    feflood: 'feFlood',\r\n    fefunca: 'feFuncA',\r\n    fefuncb: 'feFuncB',\r\n    fefuncg: 'feFuncG',\r\n    fefuncr: 'feFuncR',\r\n    fegaussianblur: 'feGaussianBlur',\r\n    feimage: 'feImage',\r\n    femerge: 'feMerge',\r\n    femergenode: 'feMergeNode',\r\n    femorphology: 'feMorphology',\r\n    feoffset: 'feOffset',\r\n    fepointlight: 'fePointLight',\r\n    fespecularlighting: 'feSpecularLighting',\r\n    fespotlight: 'feSpotLight',\r\n    fetile: 'feTile',\r\n    feturbulence: 'feTurbulence',\r\n    foreignobject: 'foreignObject',\r\n    glyphref: 'glyphRef',\r\n    lineargradient: 'linearGradient',\r\n    radialgradient: 'radialGradient',\r\n};\r\nfunction getTagName(n) {\r\n    let tagName = tagMap[n.tagName] ? tagMap[n.tagName] : n.tagName;\r\n    if (tagName === 'link' && n.attributes._cssText) {\r\n        tagName = 'style';\r\n    }\r\n    return tagName;\r\n}\r\nfunction escapeRegExp(str) {\r\n    return str.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&');\r\n}\r\nconst HOVER_SELECTOR = /([^\\\\]):hover/;\r\nconst HOVER_SELECTOR_GLOBAL = new RegExp(HOVER_SELECTOR.source, 'g');\r\nfunction addHoverClass(cssText, cache) {\r\n    const cachedStyle = cache?.stylesWithHoverClass.get(cssText);\r\n    if (cachedStyle)\r\n        return cachedStyle;\r\n    if (cssText.length >= 1000000) {\r\n        return cssText;\r\n    }\r\n    const ast = parse(cssText, {\r\n        silent: true,\r\n    });\r\n    if (!ast.stylesheet) {\r\n        return cssText;\r\n    }\r\n    const selectors = [];\r\n    ast.stylesheet.rules.forEach((rule) => {\r\n        if ('selectors' in rule) {\r\n            (rule.selectors || []).forEach((selector) => {\r\n                if (HOVER_SELECTOR.test(selector)) {\r\n                    selectors.push(selector);\r\n                }\r\n            });\r\n        }\r\n    });\r\n    if (selectors.length === 0) {\r\n        return cssText;\r\n    }\r\n    const selectorMatcher = new RegExp(selectors\r\n        .filter((selector, index) => selectors.indexOf(selector) === index)\r\n        .sort((a, b) => b.length - a.length)\r\n        .map((selector) => {\r\n        return escapeRegExp(selector);\r\n    })\r\n        .join('|'), 'g');\r\n    const result = cssText.replace(selectorMatcher, (selector) => {\r\n        const newSelector = selector.replace(HOVER_SELECTOR_GLOBAL, '$1.\\\\:hover');\r\n        return `${selector}, ${newSelector}`;\r\n    });\r\n    cache?.stylesWithHoverClass.set(cssText, result);\r\n    return result;\r\n}\r\nfunction createCache() {\r\n    const stylesWithHoverClass = new Map();\r\n    return {\r\n        stylesWithHoverClass,\r\n    };\r\n}\r\nfunction buildNode(n, options) {\r\n    const { doc, hackCss, cache } = options;\r\n    switch (n.type) {\r\n        case NodeType.Document:\r\n            return doc.implementation.createDocument(null, '', null);\r\n        case NodeType.DocumentType:\r\n            return doc.implementation.createDocumentType(n.name || 'html', n.publicId, n.systemId);\r\n        case NodeType.Element: {\r\n            const tagName = getTagName(n);\r\n            let node;\r\n            if (n.isSVG) {\r\n                node = doc.createElementNS('http://www.w3.org/2000/svg', tagName);\r\n            }\r\n            else {\r\n                if (n.isCustom &&\r\n                    doc.defaultView?.customElements &&\r\n                    !doc.defaultView.customElements.get(n.tagName))\r\n                    doc.defaultView.customElements.define(n.tagName, class extends doc.defaultView.HTMLElement {\r\n                    });\r\n                node = doc.createElement(tagName);\r\n            }\r\n            const specialAttributes = {};\r\n            for (const name in n.attributes) {\r\n                if (!Object.prototype.hasOwnProperty.call(n.attributes, name)) {\r\n                    continue;\r\n                }\r\n                let value = n.attributes[name];\r\n                if (tagName === 'option' &&\r\n                    name === 'selected' &&\r\n                    value === false) {\r\n                    continue;\r\n                }\r\n                if (value === null) {\r\n                    continue;\r\n                }\r\n                if (value === true)\r\n                    value = '';\r\n                if (name.startsWith('rr_')) {\r\n                    specialAttributes[name] = value;\r\n                    continue;\r\n                }\r\n                const isTextarea = tagName === 'textarea' && name === 'value';\r\n                const isRemoteOrDynamicCss = tagName === 'style' && name === '_cssText';\r\n                if (isRemoteOrDynamicCss && hackCss && typeof value === 'string') {\r\n                    value = addHoverClass(value, cache);\r\n                }\r\n                if ((isTextarea || isRemoteOrDynamicCss) && typeof value === 'string') {\r\n                    const child = doc.createTextNode(value);\r\n                    for (const c of Array.from(node.childNodes)) {\r\n                        if (c.nodeType === node.TEXT_NODE) {\r\n                            node.removeChild(c);\r\n                        }\r\n                    }\r\n                    node.appendChild(child);\r\n                    continue;\r\n                }\r\n                try {\r\n                    if (n.isSVG && name === 'xlink:href') {\r\n                        node.setAttributeNS('http://www.w3.org/1999/xlink', name, value.toString());\r\n                    }\r\n                    else if (name === 'onload' ||\r\n                        name === 'onclick' ||\r\n                        name.substring(0, 7) === 'onmouse') {\r\n                        node.setAttribute('_' + name, value.toString());\r\n                    }\r\n                    else if (tagName === 'meta' &&\r\n                        n.attributes['http-equiv'] === 'Content-Security-Policy' &&\r\n                        name === 'content') {\r\n                        node.setAttribute('csp-content', value.toString());\r\n                        continue;\r\n                    }\r\n                    else if (tagName === 'link' &&\r\n                        (n.attributes.rel === 'preload' ||\r\n                            n.attributes.rel === 'modulepreload')) {\r\n                    }\r\n                    else if (tagName === 'link' &&\r\n                        n.attributes.rel === 'prefetch' &&\r\n                        typeof n.attributes.href === 'string' &&\r\n                        extractFileExtension(n.attributes.href) === 'js') {\r\n                    }\r\n                    else if (tagName === 'img' &&\r\n                        n.attributes.srcset &&\r\n                        n.attributes.rr_dataURL) {\r\n                        node.setAttribute('rrweb-original-srcset', n.attributes.srcset);\r\n                    }\r\n                    else {\r\n                        node.setAttribute(name, value.toString());\r\n                    }\r\n                }\r\n                catch (error) {\r\n                }\r\n            }\r\n            for (const name in specialAttributes) {\r\n                const value = specialAttributes[name];\r\n                if (tagName === 'canvas' && name === 'rr_dataURL') {\r\n                    const image = doc.createElement('img');\r\n                    image.onload = () => {\r\n                        const ctx = node.getContext('2d');\r\n                        if (ctx) {\r\n                            ctx.drawImage(image, 0, 0, image.width, image.height);\r\n                        }\r\n                    };\r\n                    image.src = value.toString();\r\n                    if (node.RRNodeType)\r\n                        node.rr_dataURL = value.toString();\r\n                }\r\n                else if (tagName === 'img' && name === 'rr_dataURL') {\r\n                    const image = node;\r\n                    if (!image.currentSrc.startsWith('data:')) {\r\n                        image.setAttribute('rrweb-original-src', n.attributes.src);\r\n                        image.src = value.toString();\r\n                    }\r\n                }\r\n                if (name === 'rr_width') {\r\n                    node.style.setProperty('width', value.toString());\r\n                }\r\n                else if (name === 'rr_height') {\r\n                    node.style.setProperty('height', value.toString());\r\n                }\r\n                else if (name === 'rr_mediaCurrentTime' &&\r\n                    typeof value === 'number') {\r\n                    node.currentTime = value;\r\n                }\r\n                else if (name === 'rr_mediaState') {\r\n                    switch (value) {\r\n                        case 'played':\r\n                            node\r\n                                .play()\r\n                                .catch((e) => console.warn('media playback error', e));\r\n                            break;\r\n                        case 'paused':\r\n                            node.pause();\r\n                            break;\r\n                    }\r\n                }\r\n            }\r\n            if (n.isShadowHost) {\r\n                if (!node.shadowRoot) {\r\n                    node.attachShadow({ mode: 'open' });\r\n                }\r\n                else {\r\n                    while (node.shadowRoot.firstChild) {\r\n                        node.shadowRoot.removeChild(node.shadowRoot.firstChild);\r\n                    }\r\n                }\r\n            }\r\n            return node;\r\n        }\r\n        case NodeType.Text:\r\n            return doc.createTextNode(n.isStyle && hackCss\r\n                ? addHoverClass(n.textContent, cache)\r\n                : n.textContent);\r\n        case NodeType.CDATA:\r\n            return doc.createCDATASection(n.textContent);\r\n        case NodeType.Comment:\r\n            return doc.createComment(n.textContent);\r\n        default:\r\n            return null;\r\n    }\r\n}\r\nfunction buildNodeWithSN(n, options) {\r\n    const { doc, mirror, skipChild = false, hackCss = true, afterAppend, cache, } = options;\r\n    if (mirror.has(n.id)) {\r\n        const nodeInMirror = mirror.getNode(n.id);\r\n        const meta = mirror.getMeta(nodeInMirror);\r\n        if (isNodeMetaEqual(meta, n))\r\n            return mirror.getNode(n.id);\r\n    }\r\n    let node = buildNode(n, { doc, hackCss, cache });\r\n    if (!node) {\r\n        return null;\r\n    }\r\n    if (n.rootId && mirror.getNode(n.rootId) !== doc) {\r\n        mirror.replace(n.rootId, doc);\r\n    }\r\n    if (n.type === NodeType.Document) {\r\n        doc.close();\r\n        doc.open();\r\n        if (n.compatMode === 'BackCompat' &&\r\n            n.childNodes &&\r\n            n.childNodes[0].type !== NodeType.DocumentType) {\r\n            if (n.childNodes[0].type === NodeType.Element &&\r\n                'xmlns' in n.childNodes[0].attributes &&\r\n                n.childNodes[0].attributes.xmlns === 'http://www.w3.org/1999/xhtml') {\r\n                doc.write('<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"\">');\r\n            }\r\n            else {\r\n                doc.write('<!DOCTYPE html PUBLIC \"-//W3C//DTD HTML 4.0 Transitional//EN\" \"\">');\r\n            }\r\n        }\r\n        node = doc;\r\n    }\r\n    mirror.add(node, n);\r\n    if ((n.type === NodeType.Document || n.type === NodeType.Element) &&\r\n        !skipChild) {\r\n        for (const childN of n.childNodes) {\r\n            const childNode = buildNodeWithSN(childN, {\r\n                doc,\r\n                mirror,\r\n                skipChild: false,\r\n                hackCss,\r\n                afterAppend,\r\n                cache,\r\n            });\r\n            if (!childNode) {\r\n                console.warn('Failed to rebuild', childN);\r\n                continue;\r\n            }\r\n            if (childN.isShadow && isElement(node) && node.shadowRoot) {\r\n                node.shadowRoot.appendChild(childNode);\r\n            }\r\n            else if (n.type === NodeType.Document &&\r\n                childN.type == NodeType.Element) {\r\n                const htmlElement = childNode;\r\n                let body = null;\r\n                htmlElement.childNodes.forEach((child) => {\r\n                    if (child.nodeName === 'BODY')\r\n                        body = child;\r\n                });\r\n                if (body) {\r\n                    htmlElement.removeChild(body);\r\n                    node.appendChild(childNode);\r\n                    htmlElement.appendChild(body);\r\n                }\r\n                else {\r\n                    node.appendChild(childNode);\r\n                }\r\n            }\r\n            else {\r\n                node.appendChild(childNode);\r\n            }\r\n            if (afterAppend) {\r\n                afterAppend(childNode, childN.id);\r\n            }\r\n        }\r\n    }\r\n    return node;\r\n}\r\nfunction visit(mirror, onVisit) {\r\n    function walk(node) {\r\n        onVisit(node);\r\n    }\r\n    for (const id of mirror.getIds()) {\r\n        if (mirror.has(id)) {\r\n            walk(mirror.getNode(id));\r\n        }\r\n    }\r\n}\r\nfunction handleScroll(node, mirror) {\r\n    const n = mirror.getMeta(node);\r\n    if (n?.type !== NodeType.Element) {\r\n        return;\r\n    }\r\n    const el = node;\r\n    for (const name in n.attributes) {\r\n        if (!(Object.prototype.hasOwnProperty.call(n.attributes, name) &&\r\n            name.startsWith('rr_'))) {\r\n            continue;\r\n        }\r\n        const value = n.attributes[name];\r\n        if (name === 'rr_scrollLeft') {\r\n            el.scrollLeft = value;\r\n        }\r\n        if (name === 'rr_scrollTop') {\r\n            el.scrollTop = value;\r\n        }\r\n    }\r\n}\r\nfunction rebuild(n, options) {\r\n    const { doc, onVisit, hackCss = true, afterAppend, cache, mirror = new Mirror(), } = options;\r\n    const node = buildNodeWithSN(n, {\r\n        doc,\r\n        mirror,\r\n        skipChild: false,\r\n        hackCss,\r\n        afterAppend,\r\n        cache,\r\n    });\r\n    visit(mirror, (visitedNode) => {\r\n        if (onVisit) {\r\n            onVisit(visitedNode);\r\n        }\r\n        handleScroll(visitedNode, mirror);\r\n    });\r\n    return node;\r\n}\n\nexport { IGNORED_NODE, Mirror, NodeType, addHoverClass, buildNodeWithSN, clearTimeout, createCache, createMatchPredicate, createMirror, distanceToMatch, escapeImportStatement, extractFileExtension, fixAllCssProperty, fixSafariColons, genId, getIframeContentDocument, getInputType, getInputValue, ignoreAttribute, is2DCanvasBlank, isCSSImportRule, isCSSStyleRule, isElement, isNativeShadowDom, isNodeMetaEqual, isShadowRoot, maskInputValue, needMaskingText, rebuild, serializeNodeWithId, setTimeout, shouldMaskInput, snapshot, stringifyRule, stringifyStylesheet, toLowerCase, toUpperCase, transformAttribute };\n","import { distanceToMatch, IGNORED_NODE, isShadowRoot, createMatchPredicate } from '../../rrweb-snapshot/es/rrweb-snapshot.js';\n\nfunction on(type, fn, target = document) {\r\n    const options = { capture: true, passive: true };\r\n    target.addEventListener(type, fn, options);\r\n    return () => target.removeEventListener(type, fn, options);\r\n}\r\nconst DEPARTED_MIRROR_ACCESS_WARNING = 'Please stop import mirror directly. Instead of that,' +\r\n    '\\r\\n' +\r\n    'now you can use replayer.getMirror() to access the mirror instance of a replayer,' +\r\n    '\\r\\n' +\r\n    'or you can use record.mirror to access the mirror instance during recording.';\r\nlet _mirror = {\r\n    map: {},\r\n    getId() {\r\n        console.error(DEPARTED_MIRROR_ACCESS_WARNING);\r\n        return -1;\r\n    },\r\n    getNode() {\r\n        console.error(DEPARTED_MIRROR_ACCESS_WARNING);\r\n        return null;\r\n    },\r\n    removeNodeFromMap() {\r\n        console.error(DEPARTED_MIRROR_ACCESS_WARNING);\r\n    },\r\n    has() {\r\n        console.error(DEPARTED_MIRROR_ACCESS_WARNING);\r\n        return false;\r\n    },\r\n    reset() {\r\n        console.error(DEPARTED_MIRROR_ACCESS_WARNING);\r\n    },\r\n};\r\nif (typeof window !== 'undefined' && window.Proxy && window.Reflect) {\r\n    _mirror = new Proxy(_mirror, {\r\n        get(target, prop, receiver) {\r\n            if (prop === 'map') {\r\n                console.error(DEPARTED_MIRROR_ACCESS_WARNING);\r\n            }\r\n            return Reflect.get(target, prop, receiver);\r\n        },\r\n    });\r\n}\r\nfunction throttle(func, wait, options = {}) {\r\n    let timeout = null;\r\n    let previous = 0;\r\n    return function (...args) {\r\n        const now = Date.now();\r\n        if (!previous && options.leading === false) {\r\n            previous = now;\r\n        }\r\n        const remaining = wait - (now - previous);\r\n        const context = this;\r\n        if (remaining <= 0 || remaining > wait) {\r\n            if (timeout) {\r\n                clearTimeout(timeout);\r\n                timeout = null;\r\n            }\r\n            previous = now;\r\n            func.apply(context, args);\r\n        }\r\n        else if (!timeout && options.trailing !== false) {\r\n            timeout = setTimeout(() => {\r\n                previous = options.leading === false ? 0 : Date.now();\r\n                timeout = null;\r\n                func.apply(context, args);\r\n            }, remaining);\r\n        }\r\n    };\r\n}\r\nfunction hookSetter(target, key, d, isRevoked, win = window) {\r\n    const original = win.Object.getOwnPropertyDescriptor(target, key);\r\n    win.Object.defineProperty(target, key, isRevoked\r\n        ? d\r\n        : {\r\n            set(value) {\r\n                setTimeout(() => {\r\n                    d.set.call(this, value);\r\n                }, 0);\r\n                if (original && original.set) {\r\n                    original.set.call(this, value);\r\n                }\r\n            },\r\n        });\r\n    return () => hookSetter(target, key, original || {}, true);\r\n}\r\nfunction patch(source, name, replacement) {\r\n    try {\r\n        if (!(name in source)) {\r\n            return () => {\r\n            };\r\n        }\r\n        const original = source[name];\r\n        const wrapped = replacement(original);\r\n        if (typeof wrapped === 'function') {\r\n            wrapped.prototype = wrapped.prototype || {};\r\n            Object.defineProperties(wrapped, {\r\n                __rrweb_original__: {\r\n                    enumerable: false,\r\n                    value: original,\r\n                },\r\n            });\r\n        }\r\n        source[name] = wrapped;\r\n        return () => {\r\n            source[name] = original;\r\n        };\r\n    }\r\n    catch {\r\n        return () => {\r\n        };\r\n    }\r\n}\r\nlet nowTimestamp = Date.now;\r\nif (!(/[1-9][0-9]{12}/.test(Date.now().toString()))) {\r\n    nowTimestamp = () => new Date().getTime();\r\n}\r\nfunction getWindowScroll(win) {\r\n    const doc = win.document;\r\n    return {\r\n        left: doc.scrollingElement\r\n            ? doc.scrollingElement.scrollLeft\r\n            : win.pageXOffset !== undefined\r\n                ? win.pageXOffset\r\n                : doc?.documentElement.scrollLeft ||\r\n                    doc?.body?.parentElement?.scrollLeft ||\r\n                    doc?.body?.scrollLeft ||\r\n                    0,\r\n        top: doc.scrollingElement\r\n            ? doc.scrollingElement.scrollTop\r\n            : win.pageYOffset !== undefined\r\n                ? win.pageYOffset\r\n                : doc?.documentElement.scrollTop ||\r\n                    doc?.body?.parentElement?.scrollTop ||\r\n                    doc?.body?.scrollTop ||\r\n                    0,\r\n    };\r\n}\r\nfunction getWindowHeight() {\r\n    return (window.innerHeight ||\r\n        (document.documentElement && document.documentElement.clientHeight) ||\r\n        (document.body && document.body.clientHeight));\r\n}\r\nfunction getWindowWidth() {\r\n    return (window.innerWidth ||\r\n        (document.documentElement && document.documentElement.clientWidth) ||\r\n        (document.body && document.body.clientWidth));\r\n}\r\nfunction closestElementOfNode(node) {\r\n    if (!node) {\r\n        return null;\r\n    }\r\n    const el = node.nodeType === node.ELEMENT_NODE\r\n        ? node\r\n        : node.parentElement;\r\n    return el;\r\n}\r\nfunction isBlocked(node, blockClass, blockSelector, unblockSelector, checkAncestors) {\r\n    if (!node) {\r\n        return false;\r\n    }\r\n    const el = closestElementOfNode(node);\r\n    if (!el) {\r\n        return false;\r\n    }\r\n    const blockedPredicate = createMatchPredicate(blockClass, blockSelector);\r\n    if (!checkAncestors) {\r\n        const isUnblocked = unblockSelector && el.matches(unblockSelector);\r\n        return blockedPredicate(el) && !isUnblocked;\r\n    }\r\n    const blockDistance = distanceToMatch(el, blockedPredicate);\r\n    let unblockDistance = -1;\r\n    if (blockDistance < 0) {\r\n        return false;\r\n    }\r\n    if (unblockSelector) {\r\n        unblockDistance = distanceToMatch(el, createMatchPredicate(null, unblockSelector));\r\n    }\r\n    if (blockDistance > -1 && unblockDistance < 0) {\r\n        return true;\r\n    }\r\n    return blockDistance < unblockDistance;\r\n}\r\nfunction isSerialized(n, mirror) {\r\n    return mirror.getId(n) !== -1;\r\n}\r\nfunction isIgnored(n, mirror) {\r\n    return mirror.getId(n) === IGNORED_NODE;\r\n}\r\nfunction isAncestorRemoved(target, mirror) {\r\n    if (isShadowRoot(target)) {\r\n        return false;\r\n    }\r\n    const id = mirror.getId(target);\r\n    if (!mirror.has(id)) {\r\n        return true;\r\n    }\r\n    if (target.parentNode &&\r\n        target.parentNode.nodeType === target.DOCUMENT_NODE) {\r\n        return false;\r\n    }\r\n    if (!target.parentNode) {\r\n        return true;\r\n    }\r\n    return isAncestorRemoved(target.parentNode, mirror);\r\n}\r\nfunction legacy_isTouchEvent(event) {\r\n    return Boolean(event.changedTouches);\r\n}\r\nfunction polyfill(win = window) {\r\n    if ('NodeList' in win && !win.NodeList.prototype.forEach) {\r\n        win.NodeList.prototype.forEach = Array.prototype\r\n            .forEach;\r\n    }\r\n    if ('DOMTokenList' in win && !win.DOMTokenList.prototype.forEach) {\r\n        win.DOMTokenList.prototype.forEach = Array.prototype\r\n            .forEach;\r\n    }\r\n    if (!Node.prototype.contains) {\r\n        Node.prototype.contains = (...args) => {\r\n            let node = args[0];\r\n            if (!(0 in args)) {\r\n                throw new TypeError('1 argument is required');\r\n            }\r\n            do {\r\n                if (this === node) {\r\n                    return true;\r\n                }\r\n            } while ((node = node && node.parentNode));\r\n            return false;\r\n        };\r\n    }\r\n}\r\nfunction queueToResolveTrees(queue) {\r\n    const queueNodeMap = {};\r\n    const putIntoMap = (m, parent) => {\r\n        const nodeInTree = {\r\n            value: m,\r\n            parent,\r\n            children: [],\r\n        };\r\n        queueNodeMap[m.node.id] = nodeInTree;\r\n        return nodeInTree;\r\n    };\r\n    const queueNodeTrees = [];\r\n    for (const mutation of queue) {\r\n        const { nextId, parentId } = mutation;\r\n        if (nextId && nextId in queueNodeMap) {\r\n            const nextInTree = queueNodeMap[nextId];\r\n            if (nextInTree.parent) {\r\n                const idx = nextInTree.parent.children.indexOf(nextInTree);\r\n                nextInTree.parent.children.splice(idx, 0, putIntoMap(mutation, nextInTree.parent));\r\n            }\r\n            else {\r\n                const idx = queueNodeTrees.indexOf(nextInTree);\r\n                queueNodeTrees.splice(idx, 0, putIntoMap(mutation, null));\r\n            }\r\n            continue;\r\n        }\r\n        if (parentId in queueNodeMap) {\r\n            const parentInTree = queueNodeMap[parentId];\r\n            parentInTree.children.push(putIntoMap(mutation, parentInTree));\r\n            continue;\r\n        }\r\n        queueNodeTrees.push(putIntoMap(mutation, null));\r\n    }\r\n    return queueNodeTrees;\r\n}\r\nfunction iterateResolveTree(tree, cb) {\r\n    cb(tree.value);\r\n    for (let i = tree.children.length - 1; i >= 0; i--) {\r\n        iterateResolveTree(tree.children[i], cb);\r\n    }\r\n}\r\nfunction isSerializedIframe(n, mirror) {\r\n    return Boolean(n.nodeName === 'IFRAME' && mirror.getMeta(n));\r\n}\r\nfunction isSerializedStylesheet(n, mirror) {\r\n    return Boolean(n.nodeName === 'LINK' &&\r\n        n.nodeType === n.ELEMENT_NODE &&\r\n        n.getAttribute &&\r\n        n.getAttribute('rel') === 'stylesheet' &&\r\n        mirror.getMeta(n));\r\n}\r\nfunction getBaseDimension(node, rootIframe) {\r\n    const frameElement = node.ownerDocument?.defaultView?.frameElement;\r\n    if (!frameElement || frameElement === rootIframe) {\r\n        return {\r\n            x: 0,\r\n            y: 0,\r\n            relativeScale: 1,\r\n            absoluteScale: 1,\r\n        };\r\n    }\r\n    const frameDimension = frameElement.getBoundingClientRect();\r\n    const frameBaseDimension = getBaseDimension(frameElement, rootIframe);\r\n    const relativeScale = frameDimension.height / frameElement.clientHeight;\r\n    return {\r\n        x: frameDimension.x * frameBaseDimension.relativeScale +\r\n            frameBaseDimension.x,\r\n        y: frameDimension.y * frameBaseDimension.relativeScale +\r\n            frameBaseDimension.y,\r\n        relativeScale,\r\n        absoluteScale: frameBaseDimension.absoluteScale * relativeScale,\r\n    };\r\n}\r\nfunction hasShadowRoot(n) {\r\n    return Boolean(n?.shadowRoot);\r\n}\r\nfunction getNestedRule(rules, position) {\r\n    const rule = rules[position[0]];\r\n    if (position.length === 1) {\r\n        return rule;\r\n    }\r\n    else {\r\n        return getNestedRule(rule.cssRules[position[1]].cssRules, position.slice(2));\r\n    }\r\n}\r\nfunction getPositionsAndIndex(nestedIndex) {\r\n    const positions = [...nestedIndex];\r\n    const index = positions.pop();\r\n    return { positions, index };\r\n}\r\nfunction uniqueTextMutations(mutations) {\r\n    const idSet = new Set();\r\n    const uniqueMutations = [];\r\n    for (let i = mutations.length; i--;) {\r\n        const mutation = mutations[i];\r\n        if (!idSet.has(mutation.id)) {\r\n            uniqueMutations.push(mutation);\r\n            idSet.add(mutation.id);\r\n        }\r\n    }\r\n    return uniqueMutations;\r\n}\r\nclass StyleSheetMirror {\r\n    constructor() {\r\n        this.id = 1;\r\n        this.styleIDMap = new WeakMap();\r\n        this.idStyleMap = new Map();\r\n    }\r\n    getId(stylesheet) {\r\n        return this.styleIDMap.get(stylesheet) ?? -1;\r\n    }\r\n    has(stylesheet) {\r\n        return this.styleIDMap.has(stylesheet);\r\n    }\r\n    add(stylesheet, id) {\r\n        if (this.has(stylesheet))\r\n            return this.getId(stylesheet);\r\n        let newId;\r\n        if (id === undefined) {\r\n            newId = this.id++;\r\n        }\r\n        else\r\n            newId = id;\r\n        this.styleIDMap.set(stylesheet, newId);\r\n        this.idStyleMap.set(newId, stylesheet);\r\n        return newId;\r\n    }\r\n    getStyle(id) {\r\n        return this.idStyleMap.get(id) || null;\r\n    }\r\n    reset() {\r\n        this.styleIDMap = new WeakMap();\r\n        this.idStyleMap = new Map();\r\n        this.id = 1;\r\n    }\r\n    generateId() {\r\n        return this.id++;\r\n    }\r\n}\r\nfunction getShadowHost(n) {\r\n    let shadowHost = null;\r\n    if (n.getRootNode?.()?.nodeType === Node.DOCUMENT_FRAGMENT_NODE &&\r\n        n.getRootNode().host)\r\n        shadowHost = n.getRootNode().host;\r\n    return shadowHost;\r\n}\r\nfunction getRootShadowHost(n) {\r\n    let rootShadowHost = n;\r\n    let shadowHost;\r\n    while ((shadowHost = getShadowHost(rootShadowHost)))\r\n        rootShadowHost = shadowHost;\r\n    return rootShadowHost;\r\n}\r\nfunction shadowHostInDom(n) {\r\n    const doc = n.ownerDocument;\r\n    if (!doc)\r\n        return false;\r\n    const shadowHost = getRootShadowHost(n);\r\n    return doc.contains(shadowHost);\r\n}\r\nfunction inDom(n) {\r\n    const doc = n.ownerDocument;\r\n    if (!doc)\r\n        return false;\r\n    return doc.contains(n) || shadowHostInDom(n);\r\n}\r\nconst cachedImplementations = {};\r\nfunction getImplementation(name) {\r\n    const cached = cachedImplementations[name];\r\n    if (cached) {\r\n        return cached;\r\n    }\r\n    const document = window.document;\r\n    let impl = window[name];\r\n    if (document && typeof document.createElement === 'function') {\r\n        try {\r\n            const sandbox = document.createElement('iframe');\r\n            sandbox.hidden = true;\r\n            document.head.appendChild(sandbox);\r\n            const contentWindow = sandbox.contentWindow;\r\n            if (contentWindow && contentWindow[name]) {\r\n                impl =\r\n                    contentWindow[name];\r\n            }\r\n            document.head.removeChild(sandbox);\r\n        }\r\n        catch (e) {\r\n        }\r\n    }\r\n    return (cachedImplementations[name] = impl.bind(window));\r\n}\r\nfunction onRequestAnimationFrame(...rest) {\r\n    return getImplementation('requestAnimationFrame')(...rest);\r\n}\r\nfunction setTimeout(...rest) {\r\n    return getImplementation('setTimeout')(...rest);\r\n}\r\nfunction clearTimeout(...rest) {\r\n    return getImplementation('clearTimeout')(...rest);\r\n}\n\nexport { StyleSheetMirror, _mirror, clearTimeout, closestElementOfNode, getBaseDimension, getNestedRule, getPositionsAndIndex, getRootShadowHost, getShadowHost, getWindowHeight, getWindowScroll, getWindowWidth, hasShadowRoot, hookSetter, inDom, isAncestorRemoved, isBlocked, isIgnored, isSerialized, isSerializedIframe, isSerializedStylesheet, iterateResolveTree, legacy_isTouchEvent, nowTimestamp, on, onRequestAnimationFrame, patch, polyfill, queueToResolveTrees, setTimeout, shadowHostInDom, throttle, uniqueTextMutations };\n","var EventType = /* @__PURE__ */ ((EventType2) => {\n  EventType2[EventType2[\"DomContentLoaded\"] = 0] = \"DomContentLoaded\";\n  EventType2[EventType2[\"Load\"] = 1] = \"Load\";\n  EventType2[EventType2[\"FullSnapshot\"] = 2] = \"FullSnapshot\";\n  EventType2[EventType2[\"IncrementalSnapshot\"] = 3] = \"IncrementalSnapshot\";\n  EventType2[EventType2[\"Meta\"] = 4] = \"Meta\";\n  EventType2[EventType2[\"Custom\"] = 5] = \"Custom\";\n  EventType2[EventType2[\"Plugin\"] = 6] = \"Plugin\";\n  return EventType2;\n})(EventType || {});\nvar IncrementalSource = /* @__PURE__ */ ((IncrementalSource2) => {\n  IncrementalSource2[IncrementalSource2[\"Mutation\"] = 0] = \"Mutation\";\n  IncrementalSource2[IncrementalSource2[\"MouseMove\"] = 1] = \"MouseMove\";\n  IncrementalSource2[IncrementalSource2[\"MouseInteraction\"] = 2] = \"MouseInteraction\";\n  IncrementalSource2[IncrementalSource2[\"Scroll\"] = 3] = \"Scroll\";\n  IncrementalSource2[IncrementalSource2[\"ViewportResize\"] = 4] = \"ViewportResize\";\n  IncrementalSource2[IncrementalSource2[\"Input\"] = 5] = \"Input\";\n  IncrementalSource2[IncrementalSource2[\"TouchMove\"] = 6] = \"TouchMove\";\n  IncrementalSource2[IncrementalSource2[\"MediaInteraction\"] = 7] = \"MediaInteraction\";\n  IncrementalSource2[IncrementalSource2[\"StyleSheetRule\"] = 8] = \"StyleSheetRule\";\n  IncrementalSource2[IncrementalSource2[\"CanvasMutation\"] = 9] = \"CanvasMutation\";\n  IncrementalSource2[IncrementalSource2[\"Font\"] = 10] = \"Font\";\n  IncrementalSource2[IncrementalSource2[\"Log\"] = 11] = \"Log\";\n  IncrementalSource2[IncrementalSource2[\"Drag\"] = 12] = \"Drag\";\n  IncrementalSource2[IncrementalSource2[\"StyleDeclaration\"] = 13] = \"StyleDeclaration\";\n  IncrementalSource2[IncrementalSource2[\"Selection\"] = 14] = \"Selection\";\n  IncrementalSource2[IncrementalSource2[\"AdoptedStyleSheet\"] = 15] = \"AdoptedStyleSheet\";\n  IncrementalSource2[IncrementalSource2[\"CustomElement\"] = 16] = \"CustomElement\";\n  return IncrementalSource2;\n})(IncrementalSource || {});\nvar MouseInteractions = /* @__PURE__ */ ((MouseInteractions2) => {\n  MouseInteractions2[MouseInteractions2[\"MouseUp\"] = 0] = \"MouseUp\";\n  MouseInteractions2[MouseInteractions2[\"MouseDown\"] = 1] = \"MouseDown\";\n  MouseInteractions2[MouseInteractions2[\"Click\"] = 2] = \"Click\";\n  MouseInteractions2[MouseInteractions2[\"ContextMenu\"] = 3] = \"ContextMenu\";\n  MouseInteractions2[MouseInteractions2[\"DblClick\"] = 4] = \"DblClick\";\n  MouseInteractions2[MouseInteractions2[\"Focus\"] = 5] = \"Focus\";\n  MouseInteractions2[MouseInteractions2[\"Blur\"] = 6] = \"Blur\";\n  MouseInteractions2[MouseInteractions2[\"TouchStart\"] = 7] = \"TouchStart\";\n  MouseInteractions2[MouseInteractions2[\"TouchMove_Departed\"] = 8] = \"TouchMove_Departed\";\n  MouseInteractions2[MouseInteractions2[\"TouchEnd\"] = 9] = \"TouchEnd\";\n  MouseInteractions2[MouseInteractions2[\"TouchCancel\"] = 10] = \"TouchCancel\";\n  return MouseInteractions2;\n})(MouseInteractions || {});\nvar PointerTypes = /* @__PURE__ */ ((PointerTypes2) => {\n  PointerTypes2[PointerTypes2[\"Mouse\"] = 0] = \"Mouse\";\n  PointerTypes2[PointerTypes2[\"Pen\"] = 1] = \"Pen\";\n  PointerTypes2[PointerTypes2[\"Touch\"] = 2] = \"Touch\";\n  return PointerTypes2;\n})(PointerTypes || {});\nvar CanvasContext = /* @__PURE__ */ ((CanvasContext2) => {\n  CanvasContext2[CanvasContext2[\"2D\"] = 0] = \"2D\";\n  CanvasContext2[CanvasContext2[\"WebGL\"] = 1] = \"WebGL\";\n  CanvasContext2[CanvasContext2[\"WebGL2\"] = 2] = \"WebGL2\";\n  return CanvasContext2;\n})(CanvasContext || {});\nvar ReplayerEvents = /* @__PURE__ */ ((ReplayerEvents2) => {\n  ReplayerEvents2[\"Start\"] = \"start\";\n  ReplayerEvents2[\"Pause\"] = \"pause\";\n  ReplayerEvents2[\"Resume\"] = \"resume\";\n  ReplayerEvents2[\"Resize\"] = \"resize\";\n  ReplayerEvents2[\"Finish\"] = \"finish\";\n  ReplayerEvents2[\"FullsnapshotRebuilded\"] = \"fullsnapshot-rebuilded\";\n  ReplayerEvents2[\"LoadStylesheetStart\"] = \"load-stylesheet-start\";\n  ReplayerEvents2[\"LoadStylesheetEnd\"] = \"load-stylesheet-end\";\n  ReplayerEvents2[\"SkipStart\"] = \"skip-start\";\n  ReplayerEvents2[\"SkipEnd\"] = \"skip-end\";\n  ReplayerEvents2[\"MouseInteraction\"] = \"mouse-interaction\";\n  ReplayerEvents2[\"EventCast\"] = \"event-cast\";\n  ReplayerEvents2[\"CustomEvent\"] = \"custom-event\";\n  ReplayerEvents2[\"Flush\"] = \"flush\";\n  ReplayerEvents2[\"StateChange\"] = \"state-change\";\n  ReplayerEvents2[\"PlayBack\"] = \"play-back\";\n  ReplayerEvents2[\"Destroy\"] = \"destroy\";\n  return ReplayerEvents2;\n})(ReplayerEvents || {});\n\nexport { CanvasContext, EventType, IncrementalSource, MouseInteractions, PointerTypes, ReplayerEvents };\n","var NodeType$1;\r\n(function (NodeType) {\r\n    NodeType[NodeType[\"Document\"] = 0] = \"Document\";\r\n    NodeType[NodeType[\"DocumentType\"] = 1] = \"DocumentType\";\r\n    NodeType[NodeType[\"Element\"] = 2] = \"Element\";\r\n    NodeType[NodeType[\"Text\"] = 3] = \"Text\";\r\n    NodeType[NodeType[\"CDATA\"] = 4] = \"CDATA\";\r\n    NodeType[NodeType[\"Comment\"] = 5] = \"Comment\";\r\n})(NodeType$1 || (NodeType$1 = {}));\nclass Mirror$1 {\r\n    constructor() {\r\n        this.idNodeMap = new Map();\r\n        this.nodeMetaMap = new WeakMap();\r\n    }\r\n    getId(n) {\r\n        if (!n)\r\n            return -1;\r\n        const id = this.getMeta(n)?.id;\r\n        return id ?? -1;\r\n    }\r\n    getNode(id) {\r\n        return this.idNodeMap.get(id) || null;\r\n    }\r\n    getIds() {\r\n        return Array.from(this.idNodeMap.keys());\r\n    }\r\n    getMeta(n) {\r\n        return this.nodeMetaMap.get(n) || null;\r\n    }\r\n    removeNodeFromMap(n) {\r\n        const id = this.getId(n);\r\n        this.idNodeMap.delete(id);\r\n        if (n.childNodes) {\r\n            n.childNodes.forEach((childNode) => this.removeNodeFromMap(childNode));\r\n        }\r\n    }\r\n    has(id) {\r\n        return this.idNodeMap.has(id);\r\n    }\r\n    hasNode(node) {\r\n        return this.nodeMetaMap.has(node);\r\n    }\r\n    add(n, meta) {\r\n        const id = meta.id;\r\n        this.idNodeMap.set(id, n);\r\n        this.nodeMetaMap.set(n, meta);\r\n    }\r\n    replace(id, n) {\r\n        const oldNode = this.getNode(id);\r\n        if (oldNode) {\r\n            const meta = this.nodeMetaMap.get(oldNode);\r\n            if (meta)\r\n                this.nodeMetaMap.set(n, meta);\r\n        }\r\n        this.idNodeMap.set(id, n);\r\n    }\r\n    reset() {\r\n        this.idNodeMap = new Map();\r\n        this.nodeMetaMap = new WeakMap();\r\n    }\r\n}\r\nfunction createMirror$1() {\r\n    return new Mirror$1();\r\n}\n\nfunction parseCSSText(cssText) {\r\n    const res = {};\r\n    const listDelimiter = /;(?![^(]*\\))/g;\r\n    const propertyDelimiter = /:(.+)/;\r\n    const comment = /\\/\\*.*?\\*\\//g;\r\n    cssText\r\n        .replace(comment, '')\r\n        .split(listDelimiter)\r\n        .forEach(function (item) {\r\n        if (item) {\r\n            const tmp = item.split(propertyDelimiter);\r\n            tmp.length > 1 && (res[camelize(tmp[0].trim())] = tmp[1].trim());\r\n        }\r\n    });\r\n    return res;\r\n}\r\nfunction toCSSText(style) {\r\n    const properties = [];\r\n    for (const name in style) {\r\n        const value = style[name];\r\n        if (typeof value !== 'string')\r\n            continue;\r\n        const normalizedName = hyphenate(name);\r\n        properties.push(`${normalizedName}: ${value};`);\r\n    }\r\n    return properties.join(' ');\r\n}\r\nconst camelizeRE = /-([a-z])/g;\r\nconst CUSTOM_PROPERTY_REGEX = /^--[a-zA-Z0-9-]+$/;\r\nconst camelize = (str) => {\r\n    if (CUSTOM_PROPERTY_REGEX.test(str))\r\n        return str;\r\n    return str.replace(camelizeRE, (_, c) => (c ? c.toUpperCase() : ''));\r\n};\r\nconst hyphenateRE = /\\B([A-Z])/g;\r\nconst hyphenate = (str) => {\r\n    return str.replace(hyphenateRE, '-$1').toLowerCase();\r\n};\n\nclass BaseRRNode {\r\n    constructor(..._args) {\r\n        this.parentElement = null;\r\n        this.parentNode = null;\r\n        this.firstChild = null;\r\n        this.lastChild = null;\r\n        this.previousSibling = null;\r\n        this.nextSibling = null;\r\n        this.ELEMENT_NODE = NodeType.ELEMENT_NODE;\r\n        this.TEXT_NODE = NodeType.TEXT_NODE;\r\n    }\r\n    get childNodes() {\r\n        const childNodes = [];\r\n        let childIterator = this.firstChild;\r\n        while (childIterator) {\r\n            childNodes.push(childIterator);\r\n            childIterator = childIterator.nextSibling;\r\n        }\r\n        return childNodes;\r\n    }\r\n    contains(node) {\r\n        if (!(node instanceof BaseRRNode))\r\n            return false;\r\n        else if (node.ownerDocument !== this.ownerDocument)\r\n            return false;\r\n        else if (node === this)\r\n            return true;\r\n        while (node.parentNode) {\r\n            if (node.parentNode === this)\r\n                return true;\r\n            node = node.parentNode;\r\n        }\r\n        return false;\r\n    }\r\n    appendChild(_newChild) {\r\n        throw new Error(`RRDomException: Failed to execute 'appendChild' on 'RRNode': This RRNode type does not support this method.`);\r\n    }\r\n    insertBefore(_newChild, _refChild) {\r\n        throw new Error(`RRDomException: Failed to execute 'insertBefore' on 'RRNode': This RRNode type does not support this method.`);\r\n    }\r\n    removeChild(_node) {\r\n        throw new Error(`RRDomException: Failed to execute 'removeChild' on 'RRNode': This RRNode type does not support this method.`);\r\n    }\r\n    toString() {\r\n        return 'RRNode';\r\n    }\r\n}\r\nfunction BaseRRDocumentImpl(RRNodeClass) {\r\n    return class BaseRRDocument extends RRNodeClass {\r\n        constructor(...args) {\r\n            super(args);\r\n            this.nodeType = NodeType.DOCUMENT_NODE;\r\n            this.nodeName = '#document';\r\n            this.compatMode = 'CSS1Compat';\r\n            this.RRNodeType = NodeType$1.Document;\r\n            this.textContent = null;\r\n            this.ownerDocument = this;\r\n        }\r\n        get documentElement() {\r\n            return (this.childNodes.find((node) => node.RRNodeType === NodeType$1.Element &&\r\n                node.tagName === 'HTML') || null);\r\n        }\r\n        get body() {\r\n            return (this.documentElement?.childNodes.find((node) => node.RRNodeType === NodeType$1.Element &&\r\n                node.tagName === 'BODY') || null);\r\n        }\r\n        get head() {\r\n            return (this.documentElement?.childNodes.find((node) => node.RRNodeType === NodeType$1.Element &&\r\n                node.tagName === 'HEAD') || null);\r\n        }\r\n        get implementation() {\r\n            return this;\r\n        }\r\n        get firstElementChild() {\r\n            return this.documentElement;\r\n        }\r\n        appendChild(newChild) {\r\n            const nodeType = newChild.RRNodeType;\r\n            if (nodeType === NodeType$1.Element ||\r\n                nodeType === NodeType$1.DocumentType) {\r\n                if (this.childNodes.some((s) => s.RRNodeType === nodeType)) {\r\n                    throw new Error(`RRDomException: Failed to execute 'appendChild' on 'RRNode': Only one ${nodeType === NodeType$1.Element ? 'RRElement' : 'RRDoctype'} on RRDocument allowed.`);\r\n                }\r\n            }\r\n            const child = appendChild(this, newChild);\r\n            child.parentElement = null;\r\n            return child;\r\n        }\r\n        insertBefore(newChild, refChild) {\r\n            const nodeType = newChild.RRNodeType;\r\n            if (nodeType === NodeType$1.Element ||\r\n                nodeType === NodeType$1.DocumentType) {\r\n                if (this.childNodes.some((s) => s.RRNodeType === nodeType)) {\r\n                    throw new Error(`RRDomException: Failed to execute 'insertBefore' on 'RRNode': Only one ${nodeType === NodeType$1.Element ? 'RRElement' : 'RRDoctype'} on RRDocument allowed.`);\r\n                }\r\n            }\r\n            const child = insertBefore(this, newChild, refChild);\r\n            child.parentElement = null;\r\n            return child;\r\n        }\r\n        removeChild(node) {\r\n            return removeChild(this, node);\r\n        }\r\n        open() {\r\n            this.firstChild = null;\r\n            this.lastChild = null;\r\n        }\r\n        close() {\r\n        }\r\n        write(content) {\r\n            let publicId;\r\n            if (content ===\r\n                '<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"\">')\r\n                publicId = '-//W3C//DTD XHTML 1.0 Transitional//EN';\r\n            else if (content ===\r\n                '<!DOCTYPE html PUBLIC \"-//W3C//DTD HTML 4.0 Transitional//EN\" \"\">')\r\n                publicId = '-//W3C//DTD HTML 4.0 Transitional//EN';\r\n            if (publicId) {\r\n                const doctype = this.createDocumentType('html', publicId, '');\r\n                this.open();\r\n                this.appendChild(doctype);\r\n            }\r\n        }\r\n        createDocument(_namespace, _qualifiedName, _doctype) {\r\n            return new BaseRRDocument();\r\n        }\r\n        createDocumentType(qualifiedName, publicId, systemId) {\r\n            const doctype = new (BaseRRDocumentTypeImpl(BaseRRNode))(qualifiedName, publicId, systemId);\r\n            doctype.ownerDocument = this;\r\n            return doctype;\r\n        }\r\n        createElement(tagName) {\r\n            const element = new (BaseRRElementImpl(BaseRRNode))(tagName);\r\n            element.ownerDocument = this;\r\n            return element;\r\n        }\r\n        createElementNS(_namespaceURI, qualifiedName) {\r\n            return this.createElement(qualifiedName);\r\n        }\r\n        createTextNode(data) {\r\n            const text = new (BaseRRTextImpl(BaseRRNode))(data);\r\n            text.ownerDocument = this;\r\n            return text;\r\n        }\r\n        createComment(data) {\r\n            const comment = new (BaseRRCommentImpl(BaseRRNode))(data);\r\n            comment.ownerDocument = this;\r\n            return comment;\r\n        }\r\n        createCDATASection(data) {\r\n            const CDATASection = new (BaseRRCDATASectionImpl(BaseRRNode))(data);\r\n            CDATASection.ownerDocument = this;\r\n            return CDATASection;\r\n        }\r\n        toString() {\r\n            return 'RRDocument';\r\n        }\r\n    };\r\n}\r\nfunction BaseRRDocumentTypeImpl(RRNodeClass) {\r\n    return class BaseRRDocumentType extends RRNodeClass {\r\n        constructor(qualifiedName, publicId, systemId) {\r\n            super();\r\n            this.nodeType = NodeType.DOCUMENT_TYPE_NODE;\r\n            this.RRNodeType = NodeType$1.DocumentType;\r\n            this.name = qualifiedName;\r\n            this.publicId = publicId;\r\n            this.systemId = systemId;\r\n            this.nodeName = qualifiedName;\r\n            this.textContent = null;\r\n        }\r\n        toString() {\r\n            return 'RRDocumentType';\r\n        }\r\n    };\r\n}\r\nfunction BaseRRElementImpl(RRNodeClass) {\r\n    return class BaseRRElement extends RRNodeClass {\r\n        constructor(tagName) {\r\n            super();\r\n            this.nodeType = NodeType.ELEMENT_NODE;\r\n            this.RRNodeType = NodeType$1.Element;\r\n            this.attributes = {};\r\n            this.shadowRoot = null;\r\n            this.tagName = tagName.toUpperCase();\r\n            this.nodeName = tagName.toUpperCase();\r\n        }\r\n        get textContent() {\r\n            let result = '';\r\n            this.childNodes.forEach((node) => (result += node.textContent));\r\n            return result;\r\n        }\r\n        set textContent(textContent) {\r\n            this.firstChild = null;\r\n            this.lastChild = null;\r\n            this.appendChild(this.ownerDocument.createTextNode(textContent));\r\n        }\r\n        get classList() {\r\n            return new ClassList(this.attributes.class, (newClassName) => {\r\n                this.attributes.class = newClassName;\r\n            });\r\n        }\r\n        get id() {\r\n            return this.attributes.id || '';\r\n        }\r\n        get className() {\r\n            return this.attributes.class || '';\r\n        }\r\n        get style() {\r\n            const style = (this.attributes.style ? parseCSSText(this.attributes.style) : {});\r\n            const hyphenateRE = /\\B([A-Z])/g;\r\n            style.setProperty = (name, value, priority) => {\r\n                if (hyphenateRE.test(name))\r\n                    return;\r\n                const normalizedName = camelize(name);\r\n                if (!value)\r\n                    delete style[normalizedName];\r\n                else\r\n                    style[normalizedName] = value;\r\n                if (priority === 'important')\r\n                    style[normalizedName] += ' !important';\r\n                this.attributes.style = toCSSText(style);\r\n            };\r\n            style.removeProperty = (name) => {\r\n                if (hyphenateRE.test(name))\r\n                    return '';\r\n                const normalizedName = camelize(name);\r\n                const value = style[normalizedName] || '';\r\n                delete style[normalizedName];\r\n                this.attributes.style = toCSSText(style);\r\n                return value;\r\n            };\r\n            return style;\r\n        }\r\n        getAttribute(name) {\r\n            return this.attributes[name] || null;\r\n        }\r\n        setAttribute(name, attribute) {\r\n            this.attributes[name] = attribute;\r\n        }\r\n        setAttributeNS(_namespace, qualifiedName, value) {\r\n            this.setAttribute(qualifiedName, value);\r\n        }\r\n        removeAttribute(name) {\r\n            delete this.attributes[name];\r\n        }\r\n        appendChild(newChild) {\r\n            return appendChild(this, newChild);\r\n        }\r\n        insertBefore(newChild, refChild) {\r\n            return insertBefore(this, newChild, refChild);\r\n        }\r\n        removeChild(node) {\r\n            return removeChild(this, node);\r\n        }\r\n        attachShadow(_init) {\r\n            const shadowRoot = this.ownerDocument.createElement('SHADOWROOT');\r\n            this.shadowRoot = shadowRoot;\r\n            return shadowRoot;\r\n        }\r\n        dispatchEvent(_event) {\r\n            return true;\r\n        }\r\n        toString() {\r\n            let attributeString = '';\r\n            for (const attribute in this.attributes) {\r\n                attributeString += `${attribute}=\"${this.attributes[attribute]}\" `;\r\n            }\r\n            return `${this.tagName} ${attributeString}`;\r\n        }\r\n    };\r\n}\r\nfunction BaseRRMediaElementImpl(RRElementClass) {\r\n    return class BaseRRMediaElement extends RRElementClass {\r\n        attachShadow(_init) {\r\n            throw new Error(`RRDomException: Failed to execute 'attachShadow' on 'RRElement': This RRElement does not support attachShadow`);\r\n        }\r\n        play() {\r\n            this.paused = false;\r\n        }\r\n        pause() {\r\n            this.paused = true;\r\n        }\r\n    };\r\n}\r\nfunction BaseRRTextImpl(RRNodeClass) {\r\n    return class BaseRRText extends RRNodeClass {\r\n        constructor(data) {\r\n            super();\r\n            this.nodeType = NodeType.TEXT_NODE;\r\n            this.nodeName = '#text';\r\n            this.RRNodeType = NodeType$1.Text;\r\n            this.data = data;\r\n        }\r\n        get textContent() {\r\n            return this.data;\r\n        }\r\n        set textContent(textContent) {\r\n            this.data = textContent;\r\n        }\r\n        toString() {\r\n            return `RRText text=${JSON.stringify(this.data)}`;\r\n        }\r\n    };\r\n}\r\nfunction BaseRRCommentImpl(RRNodeClass) {\r\n    return class BaseRRComment extends RRNodeClass {\r\n        constructor(data) {\r\n            super();\r\n            this.nodeType = NodeType.COMMENT_NODE;\r\n            this.nodeName = '#comment';\r\n            this.RRNodeType = NodeType$1.Comment;\r\n            this.data = data;\r\n        }\r\n        get textContent() {\r\n            return this.data;\r\n        }\r\n        set textContent(textContent) {\r\n            this.data = textContent;\r\n        }\r\n        toString() {\r\n            return `RRComment text=${JSON.stringify(this.data)}`;\r\n        }\r\n    };\r\n}\r\nfunction BaseRRCDATASectionImpl(RRNodeClass) {\r\n    return class BaseRRCDATASection extends RRNodeClass {\r\n        constructor(data) {\r\n            super();\r\n            this.nodeName = '#cdata-section';\r\n            this.nodeType = NodeType.CDATA_SECTION_NODE;\r\n            this.RRNodeType = NodeType$1.CDATA;\r\n            this.data = data;\r\n        }\r\n        get textContent() {\r\n            return this.data;\r\n        }\r\n        set textContent(textContent) {\r\n            this.data = textContent;\r\n        }\r\n        toString() {\r\n            return `RRCDATASection data=${JSON.stringify(this.data)}`;\r\n        }\r\n    };\r\n}\r\nclass ClassList {\r\n    constructor(classText, onChange) {\r\n        this.classes = [];\r\n        this.add = (...classNames) => {\r\n            for (const item of classNames) {\r\n                const className = String(item);\r\n                if (this.classes.indexOf(className) >= 0)\r\n                    continue;\r\n                this.classes.push(className);\r\n            }\r\n            this.onChange && this.onChange(this.classes.join(' '));\r\n        };\r\n        this.remove = (...classNames) => {\r\n            this.classes = this.classes.filter((item) => classNames.indexOf(item) === -1);\r\n            this.onChange && this.onChange(this.classes.join(' '));\r\n        };\r\n        if (classText) {\r\n            const classes = classText.trim().split(/\\s+/);\r\n            this.classes.push(...classes);\r\n        }\r\n        this.onChange = onChange;\r\n    }\r\n}\r\nfunction appendChild(parent, newChild) {\r\n    if (newChild.parentNode)\r\n        newChild.parentNode.removeChild(newChild);\r\n    if (parent.lastChild) {\r\n        parent.lastChild.nextSibling = newChild;\r\n        newChild.previousSibling = parent.lastChild;\r\n    }\r\n    else {\r\n        parent.firstChild = newChild;\r\n        newChild.previousSibling = null;\r\n    }\r\n    parent.lastChild = newChild;\r\n    newChild.nextSibling = null;\r\n    newChild.parentNode = parent;\r\n    newChild.parentElement = parent;\r\n    newChild.ownerDocument = parent.ownerDocument;\r\n    return newChild;\r\n}\r\nfunction insertBefore(parent, newChild, refChild) {\r\n    if (!refChild)\r\n        return appendChild(parent, newChild);\r\n    if (refChild.parentNode !== parent)\r\n        throw new Error(\"Failed to execute 'insertBefore' on 'RRNode': The RRNode before which the new node is to be inserted is not a child of this RRNode.\");\r\n    if (newChild === refChild)\r\n        return newChild;\r\n    if (newChild.parentNode)\r\n        newChild.parentNode.removeChild(newChild);\r\n    newChild.previousSibling = refChild.previousSibling;\r\n    refChild.previousSibling = newChild;\r\n    newChild.nextSibling = refChild;\r\n    if (newChild.previousSibling)\r\n        newChild.previousSibling.nextSibling = newChild;\r\n    else\r\n        parent.firstChild = newChild;\r\n    newChild.parentElement = parent;\r\n    newChild.parentNode = parent;\r\n    newChild.ownerDocument = parent.ownerDocument;\r\n    return newChild;\r\n}\r\nfunction removeChild(parent, child) {\r\n    if (child.parentNode !== parent)\r\n        throw new Error(\"Failed to execute 'removeChild' on 'RRNode': The RRNode to be removed is not a child of this RRNode.\");\r\n    if (child.previousSibling)\r\n        child.previousSibling.nextSibling = child.nextSibling;\r\n    else\r\n        parent.firstChild = child.nextSibling;\r\n    if (child.nextSibling)\r\n        child.nextSibling.previousSibling = child.previousSibling;\r\n    else\r\n        parent.lastChild = child.previousSibling;\r\n    child.previousSibling = null;\r\n    child.nextSibling = null;\r\n    child.parentElement = null;\r\n    child.parentNode = null;\r\n    return child;\r\n}\r\nvar NodeType;\r\n(function (NodeType) {\r\n    NodeType[NodeType[\"PLACEHOLDER\"] = 0] = \"PLACEHOLDER\";\r\n    NodeType[NodeType[\"ELEMENT_NODE\"] = 1] = \"ELEMENT_NODE\";\r\n    NodeType[NodeType[\"ATTRIBUTE_NODE\"] = 2] = \"ATTRIBUTE_NODE\";\r\n    NodeType[NodeType[\"TEXT_NODE\"] = 3] = \"TEXT_NODE\";\r\n    NodeType[NodeType[\"CDATA_SECTION_NODE\"] = 4] = \"CDATA_SECTION_NODE\";\r\n    NodeType[NodeType[\"ENTITY_REFERENCE_NODE\"] = 5] = \"ENTITY_REFERENCE_NODE\";\r\n    NodeType[NodeType[\"ENTITY_NODE\"] = 6] = \"ENTITY_NODE\";\r\n    NodeType[NodeType[\"PROCESSING_INSTRUCTION_NODE\"] = 7] = \"PROCESSING_INSTRUCTION_NODE\";\r\n    NodeType[NodeType[\"COMMENT_NODE\"] = 8] = \"COMMENT_NODE\";\r\n    NodeType[NodeType[\"DOCUMENT_NODE\"] = 9] = \"DOCUMENT_NODE\";\r\n    NodeType[NodeType[\"DOCUMENT_TYPE_NODE\"] = 10] = \"DOCUMENT_TYPE_NODE\";\r\n    NodeType[NodeType[\"DOCUMENT_FRAGMENT_NODE\"] = 11] = \"DOCUMENT_FRAGMENT_NODE\";\r\n})(NodeType || (NodeType = {}));\n\nfunction getIFrameContentDocument(iframe) {\r\n    try {\r\n        return iframe.contentDocument;\r\n    }\r\n    catch (e) {\r\n    }\r\n}\r\nfunction getIFrameContentWindow(iframe) {\r\n    try {\r\n        return iframe.contentWindow;\r\n    }\r\n    catch (e) {\r\n    }\r\n}\n\nconst NAMESPACES = {\r\n    svg: 'http://www.w3.org/2000/svg',\r\n    'xlink:href': 'http://www.w3.org/1999/xlink',\r\n    xmlns: 'http://www.w3.org/2000/xmlns/',\r\n};\r\nconst SVGTagMap = {\r\n    altglyph: 'altGlyph',\r\n    altglyphdef: 'altGlyphDef',\r\n    altglyphitem: 'altGlyphItem',\r\n    animatecolor: 'animateColor',\r\n    animatemotion: 'animateMotion',\r\n    animatetransform: 'animateTransform',\r\n    clippath: 'clipPath',\r\n    feblend: 'feBlend',\r\n    fecolormatrix: 'feColorMatrix',\r\n    fecomponenttransfer: 'feComponentTransfer',\r\n    fecomposite: 'feComposite',\r\n    feconvolvematrix: 'feConvolveMatrix',\r\n    fediffuselighting: 'feDiffuseLighting',\r\n    fedisplacementmap: 'feDisplacementMap',\r\n    fedistantlight: 'feDistantLight',\r\n    fedropshadow: 'feDropShadow',\r\n    feflood: 'feFlood',\r\n    fefunca: 'feFuncA',\r\n    fefuncb: 'feFuncB',\r\n    fefuncg: 'feFuncG',\r\n    fefuncr: 'feFuncR',\r\n    fegaussianblur: 'feGaussianBlur',\r\n    feimage: 'feImage',\r\n    femerge: 'feMerge',\r\n    femergenode: 'feMergeNode',\r\n    femorphology: 'feMorphology',\r\n    feoffset: 'feOffset',\r\n    fepointlight: 'fePointLight',\r\n    fespecularlighting: 'feSpecularLighting',\r\n    fespotlight: 'feSpotLight',\r\n    fetile: 'feTile',\r\n    feturbulence: 'feTurbulence',\r\n    foreignobject: 'foreignObject',\r\n    glyphref: 'glyphRef',\r\n    lineargradient: 'linearGradient',\r\n    radialgradient: 'radialGradient',\r\n};\r\nlet createdNodeSet = null;\r\nfunction diff(oldTree, newTree, replayer, rrnodeMirror = newTree.mirror ||\r\n    newTree.ownerDocument.mirror) {\r\n    oldTree = diffBeforeUpdatingChildren(oldTree, newTree, replayer, rrnodeMirror);\r\n    diffChildren(oldTree, newTree, replayer, rrnodeMirror);\r\n    diffAfterUpdatingChildren(oldTree, newTree, replayer);\r\n}\r\nfunction diffBeforeUpdatingChildren(oldTree, newTree, replayer, rrnodeMirror) {\r\n    if (replayer.afterAppend && !createdNodeSet) {\r\n        createdNodeSet = new WeakSet();\r\n        setTimeout(() => {\r\n            createdNodeSet = null;\r\n        }, 0);\r\n    }\r\n    if (!sameNodeType(oldTree, newTree)) {\r\n        const calibratedOldTree = createOrGetNode(newTree, replayer.mirror, rrnodeMirror);\r\n        oldTree.parentNode?.replaceChild(calibratedOldTree, oldTree);\r\n        oldTree = calibratedOldTree;\r\n    }\r\n    switch (newTree.RRNodeType) {\r\n        case NodeType$1.Document: {\r\n            if (!nodeMatching(oldTree, newTree, replayer.mirror, rrnodeMirror)) {\r\n                const newMeta = rrnodeMirror.getMeta(newTree);\r\n                if (newMeta) {\r\n                    replayer.mirror.removeNodeFromMap(oldTree);\r\n                    oldTree.close();\r\n                    oldTree.open();\r\n                    replayer.mirror.add(oldTree, newMeta);\r\n                    createdNodeSet?.add(oldTree);\r\n                }\r\n            }\r\n            break;\r\n        }\r\n        case NodeType$1.Element: {\r\n            const oldElement = oldTree;\r\n            const newRRElement = newTree;\r\n            switch (newRRElement.tagName) {\r\n                case 'IFRAME': {\r\n                    const oldContentDocument = getIFrameContentDocument(oldTree);\r\n                    if (!oldContentDocument)\r\n                        break;\r\n                    diff(oldContentDocument, newTree.contentDocument, replayer, rrnodeMirror);\r\n                    break;\r\n                }\r\n            }\r\n            if (newRRElement.shadowRoot) {\r\n                if (!oldElement.shadowRoot)\r\n                    oldElement.attachShadow({ mode: 'open' });\r\n                diffChildren(oldElement.shadowRoot, newRRElement.shadowRoot, replayer, rrnodeMirror);\r\n            }\r\n            diffProps(oldElement, newRRElement, rrnodeMirror);\r\n            break;\r\n        }\r\n    }\r\n    return oldTree;\r\n}\r\nfunction diffAfterUpdatingChildren(oldTree, newTree, replayer) {\r\n    switch (newTree.RRNodeType) {\r\n        case NodeType$1.Document: {\r\n            const scrollData = newTree.scrollData;\r\n            scrollData && replayer.applyScroll(scrollData, true);\r\n            break;\r\n        }\r\n        case NodeType$1.Element: {\r\n            const oldElement = oldTree;\r\n            const newRRElement = newTree;\r\n            newRRElement.scrollData &&\r\n                replayer.applyScroll(newRRElement.scrollData, true);\r\n            newRRElement.inputData && replayer.applyInput(newRRElement.inputData);\r\n            switch (newRRElement.tagName) {\r\n                case 'AUDIO':\r\n                case 'VIDEO': {\r\n                    const oldMediaElement = oldTree;\r\n                    const newMediaRRElement = newRRElement;\r\n                    if (newMediaRRElement.paused !== undefined)\r\n                        newMediaRRElement.paused\r\n                            ? void oldMediaElement.pause()\r\n                            : void oldMediaElement.play();\r\n                    if (newMediaRRElement.muted !== undefined)\r\n                        oldMediaElement.muted = newMediaRRElement.muted;\r\n                    if (newMediaRRElement.volume !== undefined)\r\n                        oldMediaElement.volume = newMediaRRElement.volume;\r\n                    if (newMediaRRElement.currentTime !== undefined)\r\n                        oldMediaElement.currentTime = newMediaRRElement.currentTime;\r\n                    if (newMediaRRElement.playbackRate !== undefined)\r\n                        oldMediaElement.playbackRate = newMediaRRElement.playbackRate;\r\n                    break;\r\n                }\r\n                case 'CANVAS': {\r\n                    const rrCanvasElement = newTree;\r\n                    if (rrCanvasElement.rr_dataURL !== null) {\r\n                        const image = document.createElement('img');\r\n                        image.onload = () => {\r\n                            const ctx = oldElement.getContext('2d');\r\n                            if (ctx) {\r\n                                ctx.drawImage(image, 0, 0, image.width, image.height);\r\n                            }\r\n                        };\r\n                        image.src = rrCanvasElement.rr_dataURL;\r\n                    }\r\n                    rrCanvasElement.canvasMutations.forEach((canvasMutation) => replayer.applyCanvas(canvasMutation.event, canvasMutation.mutation, oldTree));\r\n                    break;\r\n                }\r\n                case 'STYLE': {\r\n                    const styleSheet = oldElement.sheet;\r\n                    styleSheet &&\r\n                        newTree.rules.forEach((data) => replayer.applyStyleSheetMutation(data, styleSheet));\r\n                    break;\r\n                }\r\n            }\r\n            break;\r\n        }\r\n        case NodeType$1.Text:\r\n        case NodeType$1.Comment:\r\n        case NodeType$1.CDATA: {\r\n            if (oldTree.textContent !==\r\n                newTree.data)\r\n                oldTree.textContent = newTree.data;\r\n            break;\r\n        }\r\n    }\r\n    if (createdNodeSet?.has(oldTree)) {\r\n        createdNodeSet.delete(oldTree);\r\n        replayer.afterAppend?.(oldTree, replayer.mirror.getId(oldTree));\r\n    }\r\n}\r\nfunction diffProps(oldTree, newTree, rrnodeMirror) {\r\n    const oldAttributes = oldTree.attributes;\r\n    const newAttributes = newTree.attributes;\r\n    for (const name in newAttributes) {\r\n        const newValue = newAttributes[name];\r\n        const sn = rrnodeMirror.getMeta(newTree);\r\n        if (sn?.isSVG && NAMESPACES[name])\r\n            oldTree.setAttributeNS(NAMESPACES[name], name, newValue);\r\n        else if (newTree.tagName === 'CANVAS' && name === 'rr_dataURL') {\r\n            const image = document.createElement('img');\r\n            image.src = newValue;\r\n            image.onload = () => {\r\n                const ctx = oldTree.getContext('2d');\r\n                if (ctx) {\r\n                    ctx.drawImage(image, 0, 0, image.width, image.height);\r\n                }\r\n            };\r\n        }\r\n        else if (newTree.tagName === 'IFRAME' && name === 'srcdoc')\r\n            continue;\r\n        else {\r\n            try {\r\n                oldTree.setAttribute(name, newValue);\r\n            }\r\n            catch (err) {\r\n                console.warn(err);\r\n            }\r\n        }\r\n    }\r\n    for (const { name } of Array.from(oldAttributes))\r\n        if (!(name in newAttributes))\r\n            oldTree.removeAttribute(name);\r\n    newTree.scrollLeft && (oldTree.scrollLeft = newTree.scrollLeft);\r\n    newTree.scrollTop && (oldTree.scrollTop = newTree.scrollTop);\r\n}\r\nfunction diffChildren(oldTree, newTree, replayer, rrnodeMirror) {\r\n    const oldChildren = Array.from(oldTree.childNodes);\r\n    const newChildren = newTree.childNodes;\r\n    if (oldChildren.length === 0 && newChildren.length === 0)\r\n        return;\r\n    let oldStartIndex = 0, oldEndIndex = oldChildren.length - 1, newStartIndex = 0, newEndIndex = newChildren.length - 1;\r\n    let oldStartNode = oldChildren[oldStartIndex], oldEndNode = oldChildren[oldEndIndex], newStartNode = newChildren[newStartIndex], newEndNode = newChildren[newEndIndex];\r\n    let oldIdToIndex = undefined, indexInOld = undefined;\r\n    while (oldStartIndex <= oldEndIndex && newStartIndex <= newEndIndex) {\r\n        if (oldStartNode === undefined) {\r\n            oldStartNode = oldChildren[++oldStartIndex];\r\n        }\r\n        else if (oldEndNode === undefined) {\r\n            oldEndNode = oldChildren[--oldEndIndex];\r\n        }\r\n        else if (nodeMatching(oldStartNode, newStartNode, replayer.mirror, rrnodeMirror)) {\r\n            oldStartNode = oldChildren[++oldStartIndex];\r\n            newStartNode = newChildren[++newStartIndex];\r\n        }\r\n        else if (nodeMatching(oldEndNode, newEndNode, replayer.mirror, rrnodeMirror)) {\r\n            oldEndNode = oldChildren[--oldEndIndex];\r\n            newEndNode = newChildren[--newEndIndex];\r\n        }\r\n        else if (nodeMatching(oldStartNode, newEndNode, replayer.mirror, rrnodeMirror)) {\r\n            try {\r\n                oldTree.insertBefore(oldStartNode, oldEndNode.nextSibling);\r\n            }\r\n            catch (e) {\r\n                console.warn(e);\r\n            }\r\n            oldStartNode = oldChildren[++oldStartIndex];\r\n            newEndNode = newChildren[--newEndIndex];\r\n        }\r\n        else if (nodeMatching(oldEndNode, newStartNode, replayer.mirror, rrnodeMirror)) {\r\n            try {\r\n                oldTree.insertBefore(oldEndNode, oldStartNode);\r\n            }\r\n            catch (e) {\r\n                console.warn(e);\r\n            }\r\n            oldEndNode = oldChildren[--oldEndIndex];\r\n            newStartNode = newChildren[++newStartIndex];\r\n        }\r\n        else {\r\n            if (!oldIdToIndex) {\r\n                oldIdToIndex = {};\r\n                for (let i = oldStartIndex; i <= oldEndIndex; i++) {\r\n                    const oldChild = oldChildren[i];\r\n                    if (oldChild && replayer.mirror.hasNode(oldChild))\r\n                        oldIdToIndex[replayer.mirror.getId(oldChild)] = i;\r\n                }\r\n            }\r\n            indexInOld = oldIdToIndex[rrnodeMirror.getId(newStartNode)];\r\n            const nodeToMove = oldChildren[indexInOld];\r\n            if (indexInOld !== undefined &&\r\n                nodeToMove &&\r\n                nodeMatching(nodeToMove, newStartNode, replayer.mirror, rrnodeMirror)) {\r\n                try {\r\n                    oldTree.insertBefore(nodeToMove, oldStartNode);\r\n                }\r\n                catch (e) {\r\n                    console.warn(e);\r\n                }\r\n                oldChildren[indexInOld] = undefined;\r\n            }\r\n            else {\r\n                const newNode = createOrGetNode(newStartNode, replayer.mirror, rrnodeMirror);\r\n                if (oldTree.nodeName === '#document' &&\r\n                    oldStartNode &&\r\n                    ((newNode.nodeType === newNode.DOCUMENT_TYPE_NODE &&\r\n                        oldStartNode.nodeType === oldStartNode.DOCUMENT_TYPE_NODE) ||\r\n                        (newNode.nodeType === newNode.ELEMENT_NODE &&\r\n                            oldStartNode.nodeType === oldStartNode.ELEMENT_NODE))) {\r\n                    oldTree.removeChild(oldStartNode);\r\n                    replayer.mirror.removeNodeFromMap(oldStartNode);\r\n                    oldStartNode = oldChildren[++oldStartIndex];\r\n                }\r\n                try {\r\n                    oldTree.insertBefore(newNode, oldStartNode || null);\r\n                }\r\n                catch (e) {\r\n                    console.warn(e);\r\n                }\r\n            }\r\n            newStartNode = newChildren[++newStartIndex];\r\n        }\r\n    }\r\n    if (oldStartIndex > oldEndIndex) {\r\n        const referenceRRNode = newChildren[newEndIndex + 1];\r\n        let referenceNode = null;\r\n        if (referenceRRNode)\r\n            referenceNode = replayer.mirror.getNode(rrnodeMirror.getId(referenceRRNode));\r\n        for (; newStartIndex <= newEndIndex; ++newStartIndex) {\r\n            const newNode = createOrGetNode(newChildren[newStartIndex], replayer.mirror, rrnodeMirror);\r\n            try {\r\n                oldTree.insertBefore(newNode, referenceNode);\r\n            }\r\n            catch (e) {\r\n                console.warn(e);\r\n            }\r\n        }\r\n    }\r\n    else if (newStartIndex > newEndIndex) {\r\n        for (; oldStartIndex <= oldEndIndex; oldStartIndex++) {\r\n            const node = oldChildren[oldStartIndex];\r\n            if (!node || node.parentNode !== oldTree)\r\n                continue;\r\n            try {\r\n                oldTree.removeChild(node);\r\n                replayer.mirror.removeNodeFromMap(node);\r\n            }\r\n            catch (e) {\r\n                console.warn(e);\r\n            }\r\n        }\r\n    }\r\n    let oldChild = oldTree.firstChild;\r\n    let newChild = newTree.firstChild;\r\n    while (oldChild !== null && newChild !== null) {\r\n        diff(oldChild, newChild, replayer, rrnodeMirror);\r\n        oldChild = oldChild.nextSibling;\r\n        newChild = newChild.nextSibling;\r\n    }\r\n}\r\nfunction createOrGetNode(rrNode, domMirror, rrnodeMirror) {\r\n    const nodeId = rrnodeMirror.getId(rrNode);\r\n    const sn = rrnodeMirror.getMeta(rrNode);\r\n    let node = null;\r\n    if (nodeId > -1)\r\n        node = domMirror.getNode(nodeId);\r\n    if (node !== null && sameNodeType(node, rrNode))\r\n        return node;\r\n    switch (rrNode.RRNodeType) {\r\n        case NodeType$1.Document:\r\n            node = new Document();\r\n            break;\r\n        case NodeType$1.DocumentType:\r\n            node = document.implementation.createDocumentType(rrNode.name, rrNode.publicId, rrNode.systemId);\r\n            break;\r\n        case NodeType$1.Element: {\r\n            let tagName = rrNode.tagName.toLowerCase();\r\n            tagName = SVGTagMap[tagName] || tagName;\r\n            if (sn && 'isSVG' in sn && sn?.isSVG) {\r\n                node = document.createElementNS(NAMESPACES['svg'], tagName);\r\n            }\r\n            else\r\n                node = document.createElement(rrNode.tagName);\r\n            break;\r\n        }\r\n        case NodeType$1.Text:\r\n            node = document.createTextNode(rrNode.data);\r\n            break;\r\n        case NodeType$1.Comment:\r\n            node = document.createComment(rrNode.data);\r\n            break;\r\n        case NodeType$1.CDATA:\r\n            node = document.createCDATASection(rrNode.data);\r\n            break;\r\n    }\r\n    if (sn)\r\n        domMirror.add(node, { ...sn });\r\n    try {\r\n        createdNodeSet?.add(node);\r\n    }\r\n    catch (e) {\r\n    }\r\n    return node;\r\n}\r\nfunction sameNodeType(node1, node2) {\r\n    if (node1.nodeType !== node2.nodeType)\r\n        return false;\r\n    return (node1.nodeType !== node1.ELEMENT_NODE ||\r\n        node1.tagName.toUpperCase() ===\r\n            node2.tagName);\r\n}\r\nfunction nodeMatching(node1, node2, domMirror, rrdomMirror) {\r\n    const node1Id = domMirror.getId(node1);\r\n    const node2Id = rrdomMirror.getId(node2);\r\n    if (node1Id === -1 || node1Id !== node2Id)\r\n        return false;\r\n    return sameNodeType(node1, node2);\r\n}\n\nclass RRDocument extends BaseRRDocumentImpl(BaseRRNode) {\r\n    get unserializedId() {\r\n        return this._unserializedId--;\r\n    }\r\n    constructor(mirror) {\r\n        super();\r\n        this.UNSERIALIZED_STARTING_ID = -2;\r\n        this._unserializedId = this.UNSERIALIZED_STARTING_ID;\r\n        this.mirror = createMirror();\r\n        this.scrollData = null;\r\n        if (mirror) {\r\n            this.mirror = mirror;\r\n        }\r\n    }\r\n    createDocument(_namespace, _qualifiedName, _doctype) {\r\n        return new RRDocument();\r\n    }\r\n    createDocumentType(qualifiedName, publicId, systemId) {\r\n        const documentTypeNode = new RRDocumentType(qualifiedName, publicId, systemId);\r\n        documentTypeNode.ownerDocument = this;\r\n        return documentTypeNode;\r\n    }\r\n    createElement(tagName) {\r\n        const upperTagName = tagName.toUpperCase();\r\n        let element;\r\n        switch (upperTagName) {\r\n            case 'AUDIO':\r\n            case 'VIDEO':\r\n                element = new RRMediaElement(upperTagName);\r\n                break;\r\n            case 'IFRAME':\r\n                element = new RRIFrameElement(upperTagName, this.mirror);\r\n                break;\r\n            case 'CANVAS':\r\n                element = new RRCanvasElement(upperTagName);\r\n                break;\r\n            case 'STYLE':\r\n                element = new RRStyleElement(upperTagName);\r\n                break;\r\n            default:\r\n                element = new RRElement(upperTagName);\r\n                break;\r\n        }\r\n        element.ownerDocument = this;\r\n        return element;\r\n    }\r\n    createComment(data) {\r\n        const commentNode = new RRComment(data);\r\n        commentNode.ownerDocument = this;\r\n        return commentNode;\r\n    }\r\n    createCDATASection(data) {\r\n        const sectionNode = new RRCDATASection(data);\r\n        sectionNode.ownerDocument = this;\r\n        return sectionNode;\r\n    }\r\n    createTextNode(data) {\r\n        const textNode = new RRText(data);\r\n        textNode.ownerDocument = this;\r\n        return textNode;\r\n    }\r\n    destroyTree() {\r\n        this.firstChild = null;\r\n        this.lastChild = null;\r\n        this.mirror.reset();\r\n    }\r\n    open() {\r\n        super.open();\r\n        this._unserializedId = this.UNSERIALIZED_STARTING_ID;\r\n    }\r\n}\r\nconst RRDocumentType = BaseRRDocumentTypeImpl(BaseRRNode);\r\nclass RRElement extends BaseRRElementImpl(BaseRRNode) {\r\n    constructor() {\r\n        super(...arguments);\r\n        this.inputData = null;\r\n        this.scrollData = null;\r\n    }\r\n}\r\nclass RRMediaElement extends BaseRRMediaElementImpl(RRElement) {\r\n}\r\nclass RRCanvasElement extends RRElement {\r\n    constructor() {\r\n        super(...arguments);\r\n        this.rr_dataURL = null;\r\n        this.canvasMutations = [];\r\n    }\r\n    getContext() {\r\n        return null;\r\n    }\r\n}\r\nclass RRStyleElement extends RRElement {\r\n    constructor() {\r\n        super(...arguments);\r\n        this.rules = [];\r\n    }\r\n}\r\nclass RRIFrameElement extends RRElement {\r\n    constructor(upperTagName, mirror) {\r\n        super(upperTagName);\r\n        this.contentDocument = new RRDocument();\r\n        this.contentDocument.mirror = mirror;\r\n    }\r\n}\r\nconst RRText = BaseRRTextImpl(BaseRRNode);\r\nconst RRComment = BaseRRCommentImpl(BaseRRNode);\r\nconst RRCDATASection = BaseRRCDATASectionImpl(BaseRRNode);\r\nfunction getValidTagName(element) {\r\n    if (element instanceof HTMLFormElement) {\r\n        return 'FORM';\r\n    }\r\n    return element.tagName.toUpperCase();\r\n}\r\nfunction buildFromNode(node, rrdom, domMirror, parentRRNode) {\r\n    let rrNode;\r\n    switch (node.nodeType) {\r\n        case NodeType.DOCUMENT_NODE:\r\n            if (parentRRNode && parentRRNode.nodeName === 'IFRAME')\r\n                rrNode = parentRRNode.contentDocument;\r\n            else {\r\n                rrNode = rrdom;\r\n                rrNode.compatMode = node.compatMode;\r\n            }\r\n            break;\r\n        case NodeType.DOCUMENT_TYPE_NODE: {\r\n            const documentType = node;\r\n            rrNode = rrdom.createDocumentType(documentType.name, documentType.publicId, documentType.systemId);\r\n            break;\r\n        }\r\n        case NodeType.ELEMENT_NODE: {\r\n            const elementNode = node;\r\n            const tagName = getValidTagName(elementNode);\r\n            rrNode = rrdom.createElement(tagName);\r\n            const rrElement = rrNode;\r\n            for (const { name, value } of Array.from(elementNode.attributes)) {\r\n                rrElement.attributes[name] = value;\r\n            }\r\n            elementNode.scrollLeft && (rrElement.scrollLeft = elementNode.scrollLeft);\r\n            elementNode.scrollTop && (rrElement.scrollTop = elementNode.scrollTop);\r\n            break;\r\n        }\r\n        case NodeType.TEXT_NODE:\r\n            rrNode = rrdom.createTextNode(node.textContent || '');\r\n            break;\r\n        case NodeType.CDATA_SECTION_NODE:\r\n            rrNode = rrdom.createCDATASection(node.data);\r\n            break;\r\n        case NodeType.COMMENT_NODE:\r\n            rrNode = rrdom.createComment(node.textContent || '');\r\n            break;\r\n        case NodeType.DOCUMENT_FRAGMENT_NODE:\r\n            rrNode = parentRRNode.attachShadow({ mode: 'open' });\r\n            break;\r\n        default:\r\n            return null;\r\n    }\r\n    let sn = domMirror.getMeta(node);\r\n    if (rrdom instanceof RRDocument) {\r\n        if (!sn) {\r\n            sn = getDefaultSN(rrNode, rrdom.unserializedId);\r\n            domMirror.add(node, sn);\r\n        }\r\n        rrdom.mirror.add(rrNode, { ...sn });\r\n    }\r\n    return rrNode;\r\n}\r\nfunction buildFromDom(dom, domMirror = createMirror$1(), rrdom = new RRDocument()) {\r\n    function walk(node, parentRRNode) {\r\n        const rrNode = buildFromNode(node, rrdom, domMirror, parentRRNode);\r\n        if (rrNode === null)\r\n            return;\r\n        if (parentRRNode?.nodeName !== 'IFRAME' &&\r\n            node.nodeType !== NodeType.DOCUMENT_FRAGMENT_NODE) {\r\n            parentRRNode?.appendChild(rrNode);\r\n            rrNode.parentNode = parentRRNode;\r\n            rrNode.parentElement = parentRRNode;\r\n        }\r\n        if (node.nodeName === 'IFRAME') {\r\n            const iframeDoc = getIFrameContentDocument(node);\r\n            iframeDoc && walk(iframeDoc, rrNode);\r\n        }\r\n        else if (node.nodeType === NodeType.DOCUMENT_NODE ||\r\n            node.nodeType === NodeType.ELEMENT_NODE ||\r\n            node.nodeType === NodeType.DOCUMENT_FRAGMENT_NODE) {\r\n            if (node.nodeType === NodeType.ELEMENT_NODE &&\r\n                node.shadowRoot)\r\n                walk(node.shadowRoot, rrNode);\r\n            node.childNodes.forEach((childNode) => walk(childNode, rrNode));\r\n        }\r\n    }\r\n    walk(dom, null);\r\n    return rrdom;\r\n}\r\nfunction createMirror() {\r\n    return new Mirror();\r\n}\r\nclass Mirror {\r\n    constructor() {\r\n        this.idNodeMap = new Map();\r\n        this.nodeMetaMap = new WeakMap();\r\n    }\r\n    getId(n) {\r\n        if (!n)\r\n            return -1;\r\n        const id = this.getMeta(n)?.id;\r\n        return id ?? -1;\r\n    }\r\n    getNode(id) {\r\n        return this.idNodeMap.get(id) || null;\r\n    }\r\n    getIds() {\r\n        return Array.from(this.idNodeMap.keys());\r\n    }\r\n    getMeta(n) {\r\n        return this.nodeMetaMap.get(n) || null;\r\n    }\r\n    removeNodeFromMap(n) {\r\n        const id = this.getId(n);\r\n        this.idNodeMap.delete(id);\r\n        if (n.childNodes) {\r\n            n.childNodes.forEach((childNode) => this.removeNodeFromMap(childNode));\r\n        }\r\n    }\r\n    has(id) {\r\n        return this.idNodeMap.has(id);\r\n    }\r\n    hasNode(node) {\r\n        return this.nodeMetaMap.has(node);\r\n    }\r\n    add(n, meta) {\r\n        const id = meta.id;\r\n        this.idNodeMap.set(id, n);\r\n        this.nodeMetaMap.set(n, meta);\r\n    }\r\n    replace(id, n) {\r\n        const oldNode = this.getNode(id);\r\n        if (oldNode) {\r\n            const meta = this.nodeMetaMap.get(oldNode);\r\n            if (meta)\r\n                this.nodeMetaMap.set(n, meta);\r\n        }\r\n        this.idNodeMap.set(id, n);\r\n    }\r\n    reset() {\r\n        this.idNodeMap = new Map();\r\n        this.nodeMetaMap = new WeakMap();\r\n    }\r\n}\r\nfunction getDefaultSN(node, id) {\r\n    switch (node.RRNodeType) {\r\n        case NodeType$1.Document:\r\n            return {\r\n                id,\r\n                type: node.RRNodeType,\r\n                childNodes: [],\r\n            };\r\n        case NodeType$1.DocumentType: {\r\n            const doctype = node;\r\n            return {\r\n                id,\r\n                type: node.RRNodeType,\r\n                name: doctype.name,\r\n                publicId: doctype.publicId,\r\n                systemId: doctype.systemId,\r\n            };\r\n        }\r\n        case NodeType$1.Element:\r\n            return {\r\n                id,\r\n                type: node.RRNodeType,\r\n                tagName: node.tagName.toLowerCase(),\r\n                attributes: {},\r\n                childNodes: [],\r\n            };\r\n        case NodeType$1.Text:\r\n            return {\r\n                id,\r\n                type: node.RRNodeType,\r\n                textContent: node.textContent || '',\r\n            };\r\n        case NodeType$1.Comment:\r\n            return {\r\n                id,\r\n                type: node.RRNodeType,\r\n                textContent: node.textContent || '',\r\n            };\r\n        case NodeType$1.CDATA:\r\n            return {\r\n                id,\r\n                type: node.RRNodeType,\r\n                textContent: '',\r\n            };\r\n    }\r\n}\n\nexport { BaseRRCDATASectionImpl, BaseRRCommentImpl, BaseRRDocumentImpl, BaseRRDocumentTypeImpl, BaseRRElementImpl, BaseRRMediaElementImpl, BaseRRNode, BaseRRTextImpl, ClassList, Mirror, NodeType, RRCDATASection, RRCanvasElement, RRComment, RRDocument, RRDocumentType, RRElement, RRIFrameElement, RRMediaElement, BaseRRNode as RRNode, RRStyleElement, RRText, buildFromDom, buildFromNode, createMirror, createOrGetNode, diff, getDefaultSN, getIFrameContentDocument, getIFrameContentWindow };\n","import { isShadowRoot, isNativeShadowDom, getInputType, getInputValue, shouldMaskInput, needMaskingText, maskInputValue, ignoreAttribute, transformAttribute, toLowerCase, IGNORED_NODE, serializeNodeWithId } from '../../../rrweb-snapshot/es/rrweb-snapshot.js';\nimport { isIgnored, isBlocked, isSerialized, isAncestorRemoved, closestElementOfNode, hasShadowRoot, inDom, getShadowHost, isSerializedIframe, isSerializedStylesheet } from '../utils.js';\nimport { getIFrameContentDocument } from '../../../rrdom/es/rrdom.js';\n\nfunction isNodeInLinkedList(n) {\r\n    return '__ln' in n;\r\n}\r\nclass DoubleLinkedList {\r\n    constructor() {\r\n        this.length = 0;\r\n        this.head = null;\r\n        this.tail = null;\r\n    }\r\n    get(position) {\r\n        if (position >= this.length) {\r\n            throw new Error('Position outside of list range');\r\n        }\r\n        let current = this.head;\r\n        for (let index = 0; index < position; index++) {\r\n            current = current?.next || null;\r\n        }\r\n        return current;\r\n    }\r\n    addNode(n) {\r\n        const node = {\r\n            value: n,\r\n            previous: null,\r\n            next: null,\r\n        };\r\n        n.__ln = node;\r\n        if (n.previousSibling && isNodeInLinkedList(n.previousSibling)) {\r\n            const current = n.previousSibling.__ln.next;\r\n            node.next = current;\r\n            node.previous = n.previousSibling.__ln;\r\n            n.previousSibling.__ln.next = node;\r\n            if (current) {\r\n                current.previous = node;\r\n            }\r\n        }\r\n        else if (n.nextSibling &&\r\n            isNodeInLinkedList(n.nextSibling) &&\r\n            n.nextSibling.__ln.previous) {\r\n            const current = n.nextSibling.__ln.previous;\r\n            node.previous = current;\r\n            node.next = n.nextSibling.__ln;\r\n            n.nextSibling.__ln.previous = node;\r\n            if (current) {\r\n                current.next = node;\r\n            }\r\n        }\r\n        else {\r\n            if (this.head) {\r\n                this.head.previous = node;\r\n            }\r\n            node.next = this.head;\r\n            this.head = node;\r\n        }\r\n        if (node.next === null) {\r\n            this.tail = node;\r\n        }\r\n        this.length++;\r\n    }\r\n    removeNode(n) {\r\n        const current = n.__ln;\r\n        if (!this.head) {\r\n            return;\r\n        }\r\n        if (!current.previous) {\r\n            this.head = current.next;\r\n            if (this.head) {\r\n                this.head.previous = null;\r\n            }\r\n            else {\r\n                this.tail = null;\r\n            }\r\n        }\r\n        else {\r\n            current.previous.next = current.next;\r\n            if (current.next) {\r\n                current.next.previous = current.previous;\r\n            }\r\n            else {\r\n                this.tail = current.previous;\r\n            }\r\n        }\r\n        if (n.__ln) {\r\n            delete n.__ln;\r\n        }\r\n        this.length--;\r\n    }\r\n}\r\nconst moveKey = (id, parentId) => `${id}@${parentId}`;\r\nclass MutationBuffer {\r\n    constructor() {\r\n        this.frozen = false;\r\n        this.locked = false;\r\n        this.texts = [];\r\n        this.attributes = [];\r\n        this.attributeMap = new WeakMap();\r\n        this.removes = [];\r\n        this.mapRemoves = [];\r\n        this.movedMap = {};\r\n        this.addedSet = new Set();\r\n        this.movedSet = new Set();\r\n        this.droppedSet = new Set();\r\n        this.processMutations = (mutations) => {\r\n            mutations.forEach(this.processMutation);\r\n            this.emit();\r\n        };\r\n        this.emit = () => {\r\n            if (this.frozen || this.locked) {\r\n                return;\r\n            }\r\n            const adds = [];\r\n            const addedIds = new Set();\r\n            const addList = new DoubleLinkedList();\r\n            const getNextId = (n) => {\r\n                let ns = n;\r\n                let nextId = IGNORED_NODE;\r\n                while (nextId === IGNORED_NODE) {\r\n                    ns = ns && ns.nextSibling;\r\n                    nextId = ns && this.mirror.getId(ns);\r\n                }\r\n                return nextId;\r\n            };\r\n            const pushAdd = (n) => {\r\n                if (!n.parentNode || !inDom(n)) {\r\n                    return;\r\n                }\r\n                const parentId = isShadowRoot(n.parentNode)\r\n                    ? this.mirror.getId(getShadowHost(n))\r\n                    : this.mirror.getId(n.parentNode);\r\n                const nextId = getNextId(n);\r\n                if (parentId === -1 || nextId === -1) {\r\n                    return addList.addNode(n);\r\n                }\r\n                const sn = serializeNodeWithId(n, {\r\n                    doc: this.doc,\r\n                    mirror: this.mirror,\r\n                    blockClass: this.blockClass,\r\n                    blockSelector: this.blockSelector,\r\n                    maskAllText: this.maskAllText,\r\n                    unblockSelector: this.unblockSelector,\r\n                    maskTextClass: this.maskTextClass,\r\n                    unmaskTextClass: this.unmaskTextClass,\r\n                    maskTextSelector: this.maskTextSelector,\r\n                    unmaskTextSelector: this.unmaskTextSelector,\r\n                    skipChild: true,\r\n                    newlyAddedElement: true,\r\n                    inlineStylesheet: this.inlineStylesheet,\r\n                    maskInputOptions: this.maskInputOptions,\r\n                    maskAttributeFn: this.maskAttributeFn,\r\n                    maskTextFn: this.maskTextFn,\r\n                    maskInputFn: this.maskInputFn,\r\n                    slimDOMOptions: this.slimDOMOptions,\r\n                    dataURLOptions: this.dataURLOptions,\r\n                    recordCanvas: this.recordCanvas,\r\n                    inlineImages: this.inlineImages,\r\n                    onSerialize: (currentN) => {\r\n                        if (isSerializedIframe(currentN, this.mirror) &&\r\n                            !isBlocked(currentN, this.blockClass, this.blockSelector, this.unblockSelector, false)) {\r\n                            this.iframeManager.addIframe(currentN);\r\n                        }\r\n                        if (isSerializedStylesheet(currentN, this.mirror)) {\r\n                            this.stylesheetManager.trackLinkElement(currentN);\r\n                        }\r\n                        if (hasShadowRoot(n)) {\r\n                            this.shadowDomManager.addShadowRoot(n.shadowRoot, this.doc);\r\n                        }\r\n                    },\r\n                    onIframeLoad: (iframe, childSn) => {\r\n                        if (isBlocked(iframe, this.blockClass, this.blockSelector, this.unblockSelector, false)) {\r\n                            return;\r\n                        }\r\n                        this.iframeManager.attachIframe(iframe, childSn);\r\n                        if (iframe.contentWindow) {\r\n                            this.canvasManager.addWindow(iframe.contentWindow);\r\n                        }\r\n                        this.shadowDomManager.observeAttachShadow(iframe);\r\n                    },\r\n                    onStylesheetLoad: (link, childSn) => {\r\n                        this.stylesheetManager.attachLinkElement(link, childSn);\r\n                    },\r\n                });\r\n                if (sn) {\r\n                    adds.push({\r\n                        parentId,\r\n                        nextId,\r\n                        node: sn,\r\n                    });\r\n                    addedIds.add(sn.id);\r\n                }\r\n            };\r\n            while (this.mapRemoves.length) {\r\n                this.mirror.removeNodeFromMap(this.mapRemoves.shift());\r\n            }\r\n            for (const n of this.movedSet) {\r\n                if (isParentRemoved(this.removes, n, this.mirror) &&\r\n                    !this.movedSet.has(n.parentNode)) {\r\n                    continue;\r\n                }\r\n                pushAdd(n);\r\n            }\r\n            for (const n of this.addedSet) {\r\n                if (!isAncestorInSet(this.droppedSet, n) &&\r\n                    !isParentRemoved(this.removes, n, this.mirror)) {\r\n                    pushAdd(n);\r\n                }\r\n                else if (isAncestorInSet(this.movedSet, n)) {\r\n                    pushAdd(n);\r\n                }\r\n                else {\r\n                    this.droppedSet.add(n);\r\n                }\r\n            }\r\n            let candidate = null;\r\n            while (addList.length) {\r\n                let node = null;\r\n                if (candidate) {\r\n                    const parentId = this.mirror.getId(candidate.value.parentNode);\r\n                    const nextId = getNextId(candidate.value);\r\n                    if (parentId !== -1 && nextId !== -1) {\r\n                        node = candidate;\r\n                    }\r\n                }\r\n                if (!node) {\r\n                    let tailNode = addList.tail;\r\n                    while (tailNode) {\r\n                        const _node = tailNode;\r\n                        tailNode = tailNode.previous;\r\n                        if (_node) {\r\n                            const parentId = this.mirror.getId(_node.value.parentNode);\r\n                            const nextId = getNextId(_node.value);\r\n                            if (nextId === -1)\r\n                                continue;\r\n                            else if (parentId !== -1) {\r\n                                node = _node;\r\n                                break;\r\n                            }\r\n                            else {\r\n                                const unhandledNode = _node.value;\r\n                                if (unhandledNode.parentNode &&\r\n                                    unhandledNode.parentNode.nodeType ===\r\n                                        Node.DOCUMENT_FRAGMENT_NODE) {\r\n                                    const shadowHost = unhandledNode.parentNode\r\n                                        .host;\r\n                                    const parentId = this.mirror.getId(shadowHost);\r\n                                    if (parentId !== -1) {\r\n                                        node = _node;\r\n                                        break;\r\n                                    }\r\n                                }\r\n                            }\r\n                        }\r\n                    }\r\n                }\r\n                if (!node) {\r\n                    while (addList.head) {\r\n                        addList.removeNode(addList.head.value);\r\n                    }\r\n                    break;\r\n                }\r\n                candidate = node.previous;\r\n                addList.removeNode(node.value);\r\n                pushAdd(node.value);\r\n            }\r\n            const payload = {\r\n                texts: this.texts\r\n                    .map((text) => ({\r\n                    id: this.mirror.getId(text.node),\r\n                    value: text.value,\r\n                }))\r\n                    .filter((text) => !addedIds.has(text.id))\r\n                    .filter((text) => this.mirror.has(text.id)),\r\n                attributes: this.attributes\r\n                    .map((attribute) => {\r\n                    const { attributes } = attribute;\r\n                    if (typeof attributes.style === 'string') {\r\n                        const diffAsStr = JSON.stringify(attribute.styleDiff);\r\n                        const unchangedAsStr = JSON.stringify(attribute._unchangedStyles);\r\n                        if (diffAsStr.length < attributes.style.length) {\r\n                            if ((diffAsStr + unchangedAsStr).split('var(').length ===\r\n                                attributes.style.split('var(').length) {\r\n                                attributes.style = attribute.styleDiff;\r\n                            }\r\n                        }\r\n                    }\r\n                    return {\r\n                        id: this.mirror.getId(attribute.node),\r\n                        attributes: attributes,\r\n                    };\r\n                })\r\n                    .filter((attribute) => !addedIds.has(attribute.id))\r\n                    .filter((attribute) => this.mirror.has(attribute.id)),\r\n                removes: this.removes,\r\n                adds,\r\n            };\r\n            if (!payload.texts.length &&\r\n                !payload.attributes.length &&\r\n                !payload.removes.length &&\r\n                !payload.adds.length) {\r\n                return;\r\n            }\r\n            this.texts = [];\r\n            this.attributes = [];\r\n            this.attributeMap = new WeakMap();\r\n            this.removes = [];\r\n            this.addedSet = new Set();\r\n            this.movedSet = new Set();\r\n            this.droppedSet = new Set();\r\n            this.movedMap = {};\r\n            this.mutationCb(payload);\r\n        };\r\n        this.processMutation = (m) => {\r\n            if (isIgnored(m.target, this.mirror)) {\r\n                return;\r\n            }\r\n            switch (m.type) {\r\n                case 'characterData': {\r\n                    const value = m.target.textContent;\r\n                    if (!isBlocked(m.target, this.blockClass, this.blockSelector, this.unblockSelector, false) &&\r\n                        value !== m.oldValue) {\r\n                        this.texts.push({\r\n                            value: needMaskingText(m.target, this.maskTextClass, this.maskTextSelector, this.unmaskTextClass, this.unmaskTextSelector, this.maskAllText) && value\r\n                                ? this.maskTextFn\r\n                                    ? this.maskTextFn(value, closestElementOfNode(m.target))\r\n                                    : value.replace(/[\\S]/g, '*')\r\n                                : value,\r\n                            node: m.target,\r\n                        });\r\n                    }\r\n                    break;\r\n                }\r\n                case 'attributes': {\r\n                    const target = m.target;\r\n                    let attributeName = m.attributeName;\r\n                    let value = m.target.getAttribute(attributeName);\r\n                    if (attributeName === 'value') {\r\n                        const type = getInputType(target);\r\n                        const tagName = target.tagName;\r\n                        value = getInputValue(target, tagName, type);\r\n                        const isInputMasked = shouldMaskInput({\r\n                            maskInputOptions: this.maskInputOptions,\r\n                            tagName,\r\n                            type,\r\n                        });\r\n                        const forceMask = needMaskingText(m.target, this.maskTextClass, this.maskTextSelector, this.unmaskTextClass, this.unmaskTextSelector, isInputMasked);\r\n                        value = maskInputValue({\r\n                            isMasked: forceMask,\r\n                            element: target,\r\n                            value,\r\n                            maskInputFn: this.maskInputFn,\r\n                        });\r\n                    }\r\n                    if (isBlocked(m.target, this.blockClass, this.blockSelector, this.unblockSelector, false) ||\r\n                        value === m.oldValue) {\r\n                        return;\r\n                    }\r\n                    let item = this.attributeMap.get(m.target);\r\n                    if (target.tagName === 'IFRAME' &&\r\n                        attributeName === 'src' &&\r\n                        !this.keepIframeSrcFn(value)) {\r\n                        const iframeDoc = getIFrameContentDocument(target);\r\n                        if (!iframeDoc) {\r\n                            attributeName = 'rr_src';\r\n                        }\r\n                        else {\r\n                            return;\r\n                        }\r\n                    }\r\n                    if (!item) {\r\n                        item = {\r\n                            node: m.target,\r\n                            attributes: {},\r\n                            styleDiff: {},\r\n                            _unchangedStyles: {},\r\n                        };\r\n                        this.attributes.push(item);\r\n                        this.attributeMap.set(m.target, item);\r\n                    }\r\n                    if (attributeName === 'type' &&\r\n                        target.tagName === 'INPUT' &&\r\n                        (m.oldValue || '').toLowerCase() === 'password') {\r\n                        target.setAttribute('data-rr-is-password', 'true');\r\n                    }\r\n                    if (!ignoreAttribute(target.tagName, attributeName)) {\r\n                        item.attributes[attributeName] = transformAttribute(this.doc, toLowerCase(target.tagName), toLowerCase(attributeName), value, target, this.maskAttributeFn);\r\n                        if (attributeName === 'style') {\r\n                            if (!this.unattachedDoc) {\r\n                                try {\r\n                                    this.unattachedDoc =\r\n                                        document.implementation.createHTMLDocument();\r\n                                }\r\n                                catch (e) {\r\n                                    this.unattachedDoc = this.doc;\r\n                                }\r\n                            }\r\n                            const old = this.unattachedDoc.createElement('span');\r\n                            if (m.oldValue) {\r\n                                old.setAttribute('style', m.oldValue);\r\n                            }\r\n                            for (const pname of Array.from(target.style)) {\r\n                                const newValue = target.style.getPropertyValue(pname);\r\n                                const newPriority = target.style.getPropertyPriority(pname);\r\n                                if (newValue !== old.style.getPropertyValue(pname) ||\r\n                                    newPriority !== old.style.getPropertyPriority(pname)) {\r\n                                    if (newPriority === '') {\r\n                                        item.styleDiff[pname] = newValue;\r\n                                    }\r\n                                    else {\r\n                                        item.styleDiff[pname] = [newValue, newPriority];\r\n                                    }\r\n                                }\r\n                                else {\r\n                                    item._unchangedStyles[pname] = [newValue, newPriority];\r\n                                }\r\n                            }\r\n                            for (const pname of Array.from(old.style)) {\r\n                                if (target.style.getPropertyValue(pname) === '') {\r\n                                    item.styleDiff[pname] = false;\r\n                                }\r\n                            }\r\n                        }\r\n                    }\r\n                    break;\r\n                }\r\n                case 'childList': {\r\n                    if (isBlocked(m.target, this.blockClass, this.blockSelector, this.unblockSelector, true)) {\r\n                        return;\r\n                    }\r\n                    m.addedNodes.forEach((n) => this.genAdds(n, m.target));\r\n                    m.removedNodes.forEach((n) => {\r\n                        const nodeId = this.mirror.getId(n);\r\n                        const parentId = isShadowRoot(m.target)\r\n                            ? this.mirror.getId(m.target.host)\r\n                            : this.mirror.getId(m.target);\r\n                        if (isBlocked(m.target, this.blockClass, this.blockSelector, this.unblockSelector, false) ||\r\n                            isIgnored(n, this.mirror) ||\r\n                            !isSerialized(n, this.mirror)) {\r\n                            return;\r\n                        }\r\n                        if (this.addedSet.has(n)) {\r\n                            deepDelete(this.addedSet, n);\r\n                            this.droppedSet.add(n);\r\n                        }\r\n                        else if (this.addedSet.has(m.target) && nodeId === -1) ;\r\n                        else if (isAncestorRemoved(m.target, this.mirror)) ;\r\n                        else if (this.movedSet.has(n) &&\r\n                            this.movedMap[moveKey(nodeId, parentId)]) {\r\n                            deepDelete(this.movedSet, n);\r\n                        }\r\n                        else {\r\n                            this.removes.push({\r\n                                parentId,\r\n                                id: nodeId,\r\n                                isShadow: isShadowRoot(m.target) && isNativeShadowDom(m.target)\r\n                                    ? true\r\n                                    : undefined,\r\n                            });\r\n                        }\r\n                        this.mapRemoves.push(n);\r\n                    });\r\n                    break;\r\n                }\r\n            }\r\n        };\r\n        this.genAdds = (n, target) => {\r\n            if (this.processedNodeManager.inOtherBuffer(n, this))\r\n                return;\r\n            if (this.addedSet.has(n) || this.movedSet.has(n))\r\n                return;\r\n            if (this.mirror.hasNode(n)) {\r\n                if (isIgnored(n, this.mirror)) {\r\n                    return;\r\n                }\r\n                this.movedSet.add(n);\r\n                let targetId = null;\r\n                if (target && this.mirror.hasNode(target)) {\r\n                    targetId = this.mirror.getId(target);\r\n                }\r\n                if (targetId && targetId !== -1) {\r\n                    this.movedMap[moveKey(this.mirror.getId(n), targetId)] = true;\r\n                }\r\n            }\r\n            else {\r\n                this.addedSet.add(n);\r\n                this.droppedSet.delete(n);\r\n            }\r\n            if (!isBlocked(n, this.blockClass, this.blockSelector, this.unblockSelector, false)) {\r\n                n.childNodes.forEach((childN) => this.genAdds(childN));\r\n                if (hasShadowRoot(n)) {\r\n                    n.shadowRoot.childNodes.forEach((childN) => {\r\n                        this.processedNodeManager.add(childN, this);\r\n                        this.genAdds(childN, n);\r\n                    });\r\n                }\r\n            }\r\n        };\r\n    }\r\n    init(options) {\r\n        [\r\n            'mutationCb',\r\n            'blockClass',\r\n            'blockSelector',\r\n            'unblockSelector',\r\n            'maskAllText',\r\n            'maskTextClass',\r\n            'unmaskTextClass',\r\n            'maskTextSelector',\r\n            'unmaskTextSelector',\r\n            'inlineStylesheet',\r\n            'maskInputOptions',\r\n            'maskAttributeFn',\r\n            'maskTextFn',\r\n            'maskInputFn',\r\n            'keepIframeSrcFn',\r\n            'recordCanvas',\r\n            'inlineImages',\r\n            'slimDOMOptions',\r\n            'dataURLOptions',\r\n            'doc',\r\n            'mirror',\r\n            'iframeManager',\r\n            'stylesheetManager',\r\n            'shadowDomManager',\r\n            'canvasManager',\r\n            'processedNodeManager',\r\n        ].forEach((key) => {\r\n            this[key] = options[key];\r\n        });\r\n    }\r\n    freeze() {\r\n        this.frozen = true;\r\n        this.canvasManager.freeze();\r\n    }\r\n    unfreeze() {\r\n        this.frozen = false;\r\n        this.canvasManager.unfreeze();\r\n        this.emit();\r\n    }\r\n    isFrozen() {\r\n        return this.frozen;\r\n    }\r\n    lock() {\r\n        this.locked = true;\r\n        this.canvasManager.lock();\r\n    }\r\n    unlock() {\r\n        this.locked = false;\r\n        this.canvasManager.unlock();\r\n        this.emit();\r\n    }\r\n    reset() {\r\n        this.shadowDomManager.reset();\r\n        this.canvasManager.reset();\r\n    }\r\n}\r\nfunction deepDelete(addsSet, n) {\r\n    addsSet.delete(n);\r\n    n.childNodes.forEach((childN) => deepDelete(addsSet, childN));\r\n}\r\nfunction isParentRemoved(removes, n, mirror) {\r\n    if (removes.length === 0)\r\n        return false;\r\n    return _isParentRemoved(removes, n, mirror);\r\n}\r\nfunction _isParentRemoved(removes, n, mirror) {\r\n    let node = n.parentNode;\r\n    while (node) {\r\n        const parentId = mirror.getId(node);\r\n        if (removes.some((r) => r.id === parentId)) {\r\n            return true;\r\n        }\r\n        node = node.parentNode;\r\n    }\r\n    return false;\r\n}\r\nfunction isAncestorInSet(set, n) {\r\n    if (set.size === 0)\r\n        return false;\r\n    return _isAncestorInSet(set, n);\r\n}\r\nfunction _isAncestorInSet(set, n) {\r\n    const { parentNode } = n;\r\n    if (!parentNode) {\r\n        return false;\r\n    }\r\n    if (set.has(parentNode)) {\r\n        return true;\r\n    }\r\n    return _isAncestorInSet(set, parentNode);\r\n}\n\nexport { MutationBuffer as default };\n","let errorHandler;\r\nfunction registerErrorHandler(handler) {\r\n    errorHandler = handler;\r\n}\r\nfunction unregisterErrorHandler() {\r\n    errorHandler = undefined;\r\n}\r\nconst callbackWrapper = (cb) => {\r\n    if (!errorHandler) {\r\n        return cb;\r\n    }\r\n    const rrwebWrapped = ((...rest) => {\r\n        try {\r\n            return cb(...rest);\r\n        }\r\n        catch (error) {\r\n            if (errorHandler && errorHandler(error) === true) {\r\n                return () => {\r\n                };\r\n            }\r\n            throw error;\r\n        }\r\n    });\r\n    return rrwebWrapped;\r\n};\n\nexport { callbackWrapper, registerErrorHandler, unregisterErrorHandler };\n","import { toLowerCase, toUpperCase, getInputType, getInputValue, shouldMaskInput, needMaskingText, maskInputValue } from '../../../rrweb-snapshot/es/rrweb-snapshot.js';\nimport { on, throttle, isBlocked, getWindowScroll, hookSetter, patch, setTimeout, legacy_isTouchEvent, nowTimestamp, getWindowHeight, getWindowWidth } from '../utils.js';\nimport { MouseInteractions, IncrementalSource, PointerTypes } from '../../../types/dist/rrweb-types.js';\nimport MutationBuffer from './mutation.js';\nimport { callbackWrapper } from './error-handler.js';\n\nconst mutationBuffers = [];\r\nfunction getEventTarget(event) {\r\n    try {\r\n        if ('composedPath' in event) {\r\n            const path = event.composedPath();\r\n            if (path.length) {\r\n                return path[0];\r\n            }\r\n        }\r\n        else if ('path' in event && event.path.length) {\r\n            return event.path[0];\r\n        }\r\n    }\r\n    catch {\r\n    }\r\n    return event && event.target;\r\n}\r\nfunction initMutationObserver(options, rootEl) {\r\n    const mutationBuffer = new MutationBuffer();\r\n    mutationBuffers.push(mutationBuffer);\r\n    mutationBuffer.init(options);\r\n    let mutationObserverCtor = window.MutationObserver ||\r\n        window.__rrMutationObserver;\r\n    const angularZoneSymbol = window?.Zone?.__symbol__?.('MutationObserver');\r\n    if (angularZoneSymbol &&\r\n        window[angularZoneSymbol]) {\r\n        mutationObserverCtor = window[angularZoneSymbol];\r\n    }\r\n    const observer = new mutationObserverCtor(callbackWrapper((mutations) => {\r\n        if (options.onMutation && options.onMutation(mutations) === false) {\r\n            return;\r\n        }\r\n        mutationBuffer.processMutations.bind(mutationBuffer)(mutations);\r\n    }));\r\n    observer.observe(rootEl, {\r\n        attributes: true,\r\n        attributeOldValue: true,\r\n        characterData: true,\r\n        characterDataOldValue: true,\r\n        childList: true,\r\n        subtree: true,\r\n    });\r\n    return observer;\r\n}\r\nfunction initMoveObserver({ mousemoveCb, sampling, doc, mirror, }) {\r\n    if (sampling.mousemove === false) {\r\n        return () => {\r\n        };\r\n    }\r\n    const threshold = typeof sampling.mousemove === 'number' ? sampling.mousemove : 50;\r\n    const callbackThreshold = typeof sampling.mousemoveCallback === 'number'\r\n        ? sampling.mousemoveCallback\r\n        : 500;\r\n    let positions = [];\r\n    let timeBaseline;\r\n    const wrappedCb = throttle(callbackWrapper((source) => {\r\n        const totalOffset = Date.now() - timeBaseline;\r\n        mousemoveCb(positions.map((p) => {\r\n            p.timeOffset -= totalOffset;\r\n            return p;\r\n        }), source);\r\n        positions = [];\r\n        timeBaseline = null;\r\n    }), callbackThreshold);\r\n    const updatePosition = callbackWrapper(throttle(callbackWrapper((evt) => {\r\n        const target = getEventTarget(evt);\r\n        const { clientX, clientY } = legacy_isTouchEvent(evt)\r\n            ? evt.changedTouches[0]\r\n            : evt;\r\n        if (!timeBaseline) {\r\n            timeBaseline = nowTimestamp();\r\n        }\r\n        positions.push({\r\n            x: clientX,\r\n            y: clientY,\r\n            id: mirror.getId(target),\r\n            timeOffset: nowTimestamp() - timeBaseline,\r\n        });\r\n        wrappedCb(typeof DragEvent !== 'undefined' && evt instanceof DragEvent\r\n            ? IncrementalSource.Drag\r\n            : evt instanceof MouseEvent\r\n                ? IncrementalSource.MouseMove\r\n                : IncrementalSource.TouchMove);\r\n    }), threshold, {\r\n        trailing: false,\r\n    }));\r\n    const handlers = [\r\n        on('mousemove', updatePosition, doc),\r\n        on('touchmove', updatePosition, doc),\r\n        on('drag', updatePosition, doc),\r\n    ];\r\n    return callbackWrapper(() => {\r\n        handlers.forEach((h) => h());\r\n    });\r\n}\r\nfunction initMouseInteractionObserver({ mouseInteractionCb, doc, mirror, blockClass, blockSelector, unblockSelector, sampling, }) {\r\n    if (sampling.mouseInteraction === false) {\r\n        return () => {\r\n        };\r\n    }\r\n    const disableMap = sampling.mouseInteraction === true ||\r\n        sampling.mouseInteraction === undefined\r\n        ? {}\r\n        : sampling.mouseInteraction;\r\n    const handlers = [];\r\n    let currentPointerType = null;\r\n    const getHandler = (eventKey) => {\r\n        return (event) => {\r\n            const target = getEventTarget(event);\r\n            if (isBlocked(target, blockClass, blockSelector, unblockSelector, true)) {\r\n                return;\r\n            }\r\n            let pointerType = null;\r\n            let thisEventKey = eventKey;\r\n            if ('pointerType' in event) {\r\n                switch (event.pointerType) {\r\n                    case 'mouse':\r\n                        pointerType = PointerTypes.Mouse;\r\n                        break;\r\n                    case 'touch':\r\n                        pointerType = PointerTypes.Touch;\r\n                        break;\r\n                    case 'pen':\r\n                        pointerType = PointerTypes.Pen;\r\n                        break;\r\n                }\r\n                if (pointerType === PointerTypes.Touch) {\r\n                    if (MouseInteractions[eventKey] === MouseInteractions.MouseDown) {\r\n                        thisEventKey = 'TouchStart';\r\n                    }\r\n                    else if (MouseInteractions[eventKey] === MouseInteractions.MouseUp) {\r\n                        thisEventKey = 'TouchEnd';\r\n                    }\r\n                }\r\n                else if (pointerType === PointerTypes.Pen) ;\r\n            }\r\n            else if (legacy_isTouchEvent(event)) {\r\n                pointerType = PointerTypes.Touch;\r\n            }\r\n            if (pointerType !== null) {\r\n                currentPointerType = pointerType;\r\n                if ((thisEventKey.startsWith('Touch') &&\r\n                    pointerType === PointerTypes.Touch) ||\r\n                    (thisEventKey.startsWith('Mouse') &&\r\n                        pointerType === PointerTypes.Mouse)) {\r\n                    pointerType = null;\r\n                }\r\n            }\r\n            else if (MouseInteractions[eventKey] === MouseInteractions.Click) {\r\n                pointerType = currentPointerType;\r\n                currentPointerType = null;\r\n            }\r\n            const e = legacy_isTouchEvent(event) ? event.changedTouches[0] : event;\r\n            if (!e) {\r\n                return;\r\n            }\r\n            const id = mirror.getId(target);\r\n            const { clientX, clientY } = e;\r\n            callbackWrapper(mouseInteractionCb)({\r\n                type: MouseInteractions[thisEventKey],\r\n                id,\r\n                x: clientX,\r\n                y: clientY,\r\n                ...(pointerType !== null && { pointerType }),\r\n            });\r\n        };\r\n    };\r\n    Object.keys(MouseInteractions)\r\n        .filter((key) => Number.isNaN(Number(key)) &&\r\n        !key.endsWith('_Departed') &&\r\n        disableMap[key] !== false)\r\n        .forEach((eventKey) => {\r\n        let eventName = toLowerCase(eventKey);\r\n        const handler = getHandler(eventKey);\r\n        if (window.PointerEvent) {\r\n            switch (MouseInteractions[eventKey]) {\r\n                case MouseInteractions.MouseDown:\r\n                case MouseInteractions.MouseUp:\r\n                    eventName = eventName.replace('mouse', 'pointer');\r\n                    break;\r\n                case MouseInteractions.TouchStart:\r\n                case MouseInteractions.TouchEnd:\r\n                    return;\r\n            }\r\n        }\r\n        handlers.push(on(eventName, handler, doc));\r\n    });\r\n    return callbackWrapper(() => {\r\n        handlers.forEach((h) => h());\r\n    });\r\n}\r\nfunction initScrollObserver({ scrollCb, doc, mirror, blockClass, blockSelector, unblockSelector, sampling, }) {\r\n    const updatePosition = callbackWrapper(throttle(callbackWrapper((evt) => {\r\n        const target = getEventTarget(evt);\r\n        if (!target ||\r\n            isBlocked(target, blockClass, blockSelector, unblockSelector, true)) {\r\n            return;\r\n        }\r\n        const id = mirror.getId(target);\r\n        if (target === doc && doc.defaultView) {\r\n            const scrollLeftTop = getWindowScroll(doc.defaultView);\r\n            scrollCb({\r\n                id,\r\n                x: scrollLeftTop.left,\r\n                y: scrollLeftTop.top,\r\n            });\r\n        }\r\n        else {\r\n            scrollCb({\r\n                id,\r\n                x: target.scrollLeft,\r\n                y: target.scrollTop,\r\n            });\r\n        }\r\n    }), sampling.scroll || 100));\r\n    return on('scroll', updatePosition, doc);\r\n}\r\nfunction initViewportResizeObserver({ viewportResizeCb }, { win }) {\r\n    let lastH = -1;\r\n    let lastW = -1;\r\n    const updateDimension = callbackWrapper(throttle(callbackWrapper(() => {\r\n        const height = getWindowHeight();\r\n        const width = getWindowWidth();\r\n        if (lastH !== height || lastW !== width) {\r\n            viewportResizeCb({\r\n                width: Number(width),\r\n                height: Number(height),\r\n            });\r\n            lastH = height;\r\n            lastW = width;\r\n        }\r\n    }), 200));\r\n    return on('resize', updateDimension, win);\r\n}\r\nconst INPUT_TAGS = ['INPUT', 'TEXTAREA', 'SELECT'];\r\nconst lastInputValueMap = new WeakMap();\r\nfunction initInputObserver({ inputCb, doc, mirror, blockClass, blockSelector, unblockSelector, ignoreClass, ignoreSelector, maskInputOptions, maskInputFn, sampling, userTriggeredOnInput, maskTextClass, unmaskTextClass, maskTextSelector, unmaskTextSelector, }) {\r\n    function eventHandler(event) {\r\n        let target = getEventTarget(event);\r\n        const userTriggered = event.isTrusted;\r\n        const tagName = target && toUpperCase(target.tagName);\r\n        if (tagName === 'OPTION')\r\n            target = target.parentElement;\r\n        if (!target ||\r\n            !tagName ||\r\n            INPUT_TAGS.indexOf(tagName) < 0 ||\r\n            isBlocked(target, blockClass, blockSelector, unblockSelector, true)) {\r\n            return;\r\n        }\r\n        const el = target;\r\n        if (el.classList.contains(ignoreClass) ||\r\n            (ignoreSelector && el.matches(ignoreSelector))) {\r\n            return;\r\n        }\r\n        const type = getInputType(target);\r\n        let text = getInputValue(el, tagName, type);\r\n        let isChecked = false;\r\n        const isInputMasked = shouldMaskInput({\r\n            maskInputOptions,\r\n            tagName,\r\n            type,\r\n        });\r\n        const forceMask = needMaskingText(target, maskTextClass, maskTextSelector, unmaskTextClass, unmaskTextSelector, isInputMasked);\r\n        if (type === 'radio' || type === 'checkbox') {\r\n            isChecked = target.checked;\r\n        }\r\n        text = maskInputValue({\r\n            isMasked: forceMask,\r\n            element: target,\r\n            value: text,\r\n            maskInputFn,\r\n        });\r\n        cbWithDedup(target, userTriggeredOnInput\r\n            ? { text, isChecked, userTriggered }\r\n            : { text, isChecked });\r\n        const name = target.name;\r\n        if (type === 'radio' && name && isChecked) {\r\n            doc\r\n                .querySelectorAll(`input[type=\"radio\"][name=\"${name}\"]`)\r\n                .forEach((el) => {\r\n                if (el !== target) {\r\n                    const text = maskInputValue({\r\n                        isMasked: forceMask,\r\n                        element: el,\r\n                        value: getInputValue(el, tagName, type),\r\n                        maskInputFn,\r\n                    });\r\n                    cbWithDedup(el, userTriggeredOnInput\r\n                        ? { text, isChecked: !isChecked, userTriggered: false }\r\n                        : { text, isChecked: !isChecked });\r\n                }\r\n            });\r\n        }\r\n    }\r\n    function cbWithDedup(target, v) {\r\n        const lastInputValue = lastInputValueMap.get(target);\r\n        if (!lastInputValue ||\r\n            lastInputValue.text !== v.text ||\r\n            lastInputValue.isChecked !== v.isChecked) {\r\n            lastInputValueMap.set(target, v);\r\n            const id = mirror.getId(target);\r\n            callbackWrapper(inputCb)({\r\n                ...v,\r\n                id,\r\n            });\r\n        }\r\n    }\r\n    const events = sampling.input === 'last' ? ['change'] : ['input', 'change'];\r\n    const handlers = events.map((eventName) => on(eventName, callbackWrapper(eventHandler), doc));\r\n    const currentWindow = doc.defaultView;\r\n    if (!currentWindow) {\r\n        return () => {\r\n            handlers.forEach((h) => h());\r\n        };\r\n    }\r\n    const propertyDescriptor = currentWindow.Object.getOwnPropertyDescriptor(currentWindow.HTMLInputElement.prototype, 'value');\r\n    const hookProperties = [\r\n        [currentWindow.HTMLInputElement.prototype, 'value'],\r\n        [currentWindow.HTMLInputElement.prototype, 'checked'],\r\n        [currentWindow.HTMLSelectElement.prototype, 'value'],\r\n        [currentWindow.HTMLTextAreaElement.prototype, 'value'],\r\n        [currentWindow.HTMLSelectElement.prototype, 'selectedIndex'],\r\n        [currentWindow.HTMLOptionElement.prototype, 'selected'],\r\n    ];\r\n    if (propertyDescriptor && propertyDescriptor.set) {\r\n        handlers.push(...hookProperties.map((p) => hookSetter(p[0], p[1], {\r\n            set() {\r\n                callbackWrapper(eventHandler)({\r\n                    target: this,\r\n                    isTrusted: false,\r\n                });\r\n            },\r\n        }, false, currentWindow)));\r\n    }\r\n    return callbackWrapper(() => {\r\n        handlers.forEach((h) => h());\r\n    });\r\n}\r\nfunction getNestedCSSRulePositions(rule) {\r\n    const positions = [];\r\n    function recurse(childRule, pos) {\r\n        if ((hasNestedCSSRule('CSSGroupingRule') &&\r\n            childRule.parentRule instanceof CSSGroupingRule) ||\r\n            (hasNestedCSSRule('CSSMediaRule') &&\r\n                childRule.parentRule instanceof CSSMediaRule) ||\r\n            (hasNestedCSSRule('CSSSupportsRule') &&\r\n                childRule.parentRule instanceof CSSSupportsRule) ||\r\n            (hasNestedCSSRule('CSSConditionRule') &&\r\n                childRule.parentRule instanceof CSSConditionRule)) {\r\n            const rules = Array.from(childRule.parentRule.cssRules);\r\n            const index = rules.indexOf(childRule);\r\n            pos.unshift(index);\r\n        }\r\n        else if (childRule.parentStyleSheet) {\r\n            const rules = Array.from(childRule.parentStyleSheet.cssRules);\r\n            const index = rules.indexOf(childRule);\r\n            pos.unshift(index);\r\n        }\r\n        return pos;\r\n    }\r\n    return recurse(rule, positions);\r\n}\r\nfunction getIdAndStyleId(sheet, mirror, styleMirror) {\r\n    let id, styleId;\r\n    if (!sheet)\r\n        return {};\r\n    if (sheet.ownerNode)\r\n        id = mirror.getId(sheet.ownerNode);\r\n    else\r\n        styleId = styleMirror.getId(sheet);\r\n    return {\r\n        styleId,\r\n        id,\r\n    };\r\n}\r\nfunction initStyleSheetObserver({ styleSheetRuleCb, mirror, stylesheetManager }, { win }) {\r\n    if (!win.CSSStyleSheet || !win.CSSStyleSheet.prototype) {\r\n        return () => {\r\n        };\r\n    }\r\n    const insertRule = win.CSSStyleSheet.prototype.insertRule;\r\n    win.CSSStyleSheet.prototype.insertRule = new Proxy(insertRule, {\r\n        apply: callbackWrapper((target, thisArg, argumentsList) => {\r\n            const [rule, index] = argumentsList;\r\n            const { id, styleId } = getIdAndStyleId(thisArg, mirror, stylesheetManager.styleMirror);\r\n            if ((id && id !== -1) || (styleId && styleId !== -1)) {\r\n                styleSheetRuleCb({\r\n                    id,\r\n                    styleId,\r\n                    adds: [{ rule, index }],\r\n                });\r\n            }\r\n            return target.apply(thisArg, argumentsList);\r\n        }),\r\n    });\r\n    const deleteRule = win.CSSStyleSheet.prototype.deleteRule;\r\n    win.CSSStyleSheet.prototype.deleteRule = new Proxy(deleteRule, {\r\n        apply: callbackWrapper((target, thisArg, argumentsList) => {\r\n            const [index] = argumentsList;\r\n            const { id, styleId } = getIdAndStyleId(thisArg, mirror, stylesheetManager.styleMirror);\r\n            if ((id && id !== -1) || (styleId && styleId !== -1)) {\r\n                styleSheetRuleCb({\r\n                    id,\r\n                    styleId,\r\n                    removes: [{ index }],\r\n                });\r\n            }\r\n            return target.apply(thisArg, argumentsList);\r\n        }),\r\n    });\r\n    let replace;\r\n    if (win.CSSStyleSheet.prototype.replace) {\r\n        replace = win.CSSStyleSheet.prototype.replace;\r\n        win.CSSStyleSheet.prototype.replace = new Proxy(replace, {\r\n            apply: callbackWrapper((target, thisArg, argumentsList) => {\r\n                const [text] = argumentsList;\r\n                const { id, styleId } = getIdAndStyleId(thisArg, mirror, stylesheetManager.styleMirror);\r\n                if ((id && id !== -1) || (styleId && styleId !== -1)) {\r\n                    styleSheetRuleCb({\r\n                        id,\r\n                        styleId,\r\n                        replace: text,\r\n                    });\r\n                }\r\n                return target.apply(thisArg, argumentsList);\r\n            }),\r\n        });\r\n    }\r\n    let replaceSync;\r\n    if (win.CSSStyleSheet.prototype.replaceSync) {\r\n        replaceSync = win.CSSStyleSheet.prototype.replaceSync;\r\n        win.CSSStyleSheet.prototype.replaceSync = new Proxy(replaceSync, {\r\n            apply: callbackWrapper((target, thisArg, argumentsList) => {\r\n                const [text] = argumentsList;\r\n                const { id, styleId } = getIdAndStyleId(thisArg, mirror, stylesheetManager.styleMirror);\r\n                if ((id && id !== -1) || (styleId && styleId !== -1)) {\r\n                    styleSheetRuleCb({\r\n                        id,\r\n                        styleId,\r\n                        replaceSync: text,\r\n                    });\r\n                }\r\n                return target.apply(thisArg, argumentsList);\r\n            }),\r\n        });\r\n    }\r\n    const supportedNestedCSSRuleTypes = {};\r\n    if (canMonkeyPatchNestedCSSRule('CSSGroupingRule')) {\r\n        supportedNestedCSSRuleTypes.CSSGroupingRule = win.CSSGroupingRule;\r\n    }\r\n    else {\r\n        if (canMonkeyPatchNestedCSSRule('CSSMediaRule')) {\r\n            supportedNestedCSSRuleTypes.CSSMediaRule = win.CSSMediaRule;\r\n        }\r\n        if (canMonkeyPatchNestedCSSRule('CSSConditionRule')) {\r\n            supportedNestedCSSRuleTypes.CSSConditionRule = win.CSSConditionRule;\r\n        }\r\n        if (canMonkeyPatchNestedCSSRule('CSSSupportsRule')) {\r\n            supportedNestedCSSRuleTypes.CSSSupportsRule = win.CSSSupportsRule;\r\n        }\r\n    }\r\n    const unmodifiedFunctions = {};\r\n    Object.entries(supportedNestedCSSRuleTypes).forEach(([typeKey, type]) => {\r\n        unmodifiedFunctions[typeKey] = {\r\n            insertRule: type.prototype.insertRule,\r\n            deleteRule: type.prototype.deleteRule,\r\n        };\r\n        type.prototype.insertRule = new Proxy(unmodifiedFunctions[typeKey].insertRule, {\r\n            apply: callbackWrapper((target, thisArg, argumentsList) => {\r\n                const [rule, index] = argumentsList;\r\n                const { id, styleId } = getIdAndStyleId(thisArg.parentStyleSheet, mirror, stylesheetManager.styleMirror);\r\n                if ((id && id !== -1) || (styleId && styleId !== -1)) {\r\n                    styleSheetRuleCb({\r\n                        id,\r\n                        styleId,\r\n                        adds: [\r\n                            {\r\n                                rule,\r\n                                index: [\r\n                                    ...getNestedCSSRulePositions(thisArg),\r\n                                    index || 0,\r\n                                ],\r\n                            },\r\n                        ],\r\n                    });\r\n                }\r\n                return target.apply(thisArg, argumentsList);\r\n            }),\r\n        });\r\n        type.prototype.deleteRule = new Proxy(unmodifiedFunctions[typeKey].deleteRule, {\r\n            apply: callbackWrapper((target, thisArg, argumentsList) => {\r\n                const [index] = argumentsList;\r\n                const { id, styleId } = getIdAndStyleId(thisArg.parentStyleSheet, mirror, stylesheetManager.styleMirror);\r\n                if ((id && id !== -1) || (styleId && styleId !== -1)) {\r\n                    styleSheetRuleCb({\r\n                        id,\r\n                        styleId,\r\n                        removes: [\r\n                            { index: [...getNestedCSSRulePositions(thisArg), index] },\r\n                        ],\r\n                    });\r\n                }\r\n                return target.apply(thisArg, argumentsList);\r\n            }),\r\n        });\r\n    });\r\n    return callbackWrapper(() => {\r\n        win.CSSStyleSheet.prototype.insertRule = insertRule;\r\n        win.CSSStyleSheet.prototype.deleteRule = deleteRule;\r\n        replace && (win.CSSStyleSheet.prototype.replace = replace);\r\n        replaceSync && (win.CSSStyleSheet.prototype.replaceSync = replaceSync);\r\n        Object.entries(supportedNestedCSSRuleTypes).forEach(([typeKey, type]) => {\r\n            type.prototype.insertRule = unmodifiedFunctions[typeKey].insertRule;\r\n            type.prototype.deleteRule = unmodifiedFunctions[typeKey].deleteRule;\r\n        });\r\n    });\r\n}\r\nfunction initAdoptedStyleSheetObserver({ mirror, stylesheetManager, }, host) {\r\n    let hostId = null;\r\n    if (host.nodeName === '#document')\r\n        hostId = mirror.getId(host);\r\n    else\r\n        hostId = mirror.getId(host.host);\r\n    const patchTarget = host.nodeName === '#document'\r\n        ? host.defaultView?.Document\r\n        : host.ownerDocument?.defaultView?.ShadowRoot;\r\n    const originalPropertyDescriptor = patchTarget?.prototype\r\n        ? Object.getOwnPropertyDescriptor(patchTarget?.prototype, 'adoptedStyleSheets')\r\n        : undefined;\r\n    if (hostId === null ||\r\n        hostId === -1 ||\r\n        !patchTarget ||\r\n        !originalPropertyDescriptor)\r\n        return () => {\r\n        };\r\n    Object.defineProperty(host, 'adoptedStyleSheets', {\r\n        configurable: originalPropertyDescriptor.configurable,\r\n        enumerable: originalPropertyDescriptor.enumerable,\r\n        get() {\r\n            return originalPropertyDescriptor.get?.call(this);\r\n        },\r\n        set(sheets) {\r\n            const result = originalPropertyDescriptor.set?.call(this, sheets);\r\n            if (hostId !== null && hostId !== -1) {\r\n                try {\r\n                    stylesheetManager.adoptStyleSheets(sheets, hostId);\r\n                }\r\n                catch (e) {\r\n                }\r\n            }\r\n            return result;\r\n        },\r\n    });\r\n    return callbackWrapper(() => {\r\n        Object.defineProperty(host, 'adoptedStyleSheets', {\r\n            configurable: originalPropertyDescriptor.configurable,\r\n            enumerable: originalPropertyDescriptor.enumerable,\r\n            get: originalPropertyDescriptor.get,\r\n            set: originalPropertyDescriptor.set,\r\n        });\r\n    });\r\n}\r\nfunction initStyleDeclarationObserver({ styleDeclarationCb, mirror, ignoreCSSAttributes, stylesheetManager, }, { win }) {\r\n    const setProperty = win.CSSStyleDeclaration.prototype.setProperty;\r\n    win.CSSStyleDeclaration.prototype.setProperty = new Proxy(setProperty, {\r\n        apply: callbackWrapper((target, thisArg, argumentsList) => {\r\n            const [property, value, priority] = argumentsList;\r\n            if (ignoreCSSAttributes.has(property)) {\r\n                return setProperty.apply(thisArg, [property, value, priority]);\r\n            }\r\n            const { id, styleId } = getIdAndStyleId(thisArg.parentRule?.parentStyleSheet, mirror, stylesheetManager.styleMirror);\r\n            if ((id && id !== -1) || (styleId && styleId !== -1)) {\r\n                styleDeclarationCb({\r\n                    id,\r\n                    styleId,\r\n                    set: {\r\n                        property,\r\n                        value,\r\n                        priority,\r\n                    },\r\n                    index: getNestedCSSRulePositions(thisArg.parentRule),\r\n                });\r\n            }\r\n            return target.apply(thisArg, argumentsList);\r\n        }),\r\n    });\r\n    const removeProperty = win.CSSStyleDeclaration.prototype.removeProperty;\r\n    win.CSSStyleDeclaration.prototype.removeProperty = new Proxy(removeProperty, {\r\n        apply: callbackWrapper((target, thisArg, argumentsList) => {\r\n            const [property] = argumentsList;\r\n            if (ignoreCSSAttributes.has(property)) {\r\n                return removeProperty.apply(thisArg, [property]);\r\n            }\r\n            const { id, styleId } = getIdAndStyleId(thisArg.parentRule?.parentStyleSheet, mirror, stylesheetManager.styleMirror);\r\n            if ((id && id !== -1) || (styleId && styleId !== -1)) {\r\n                styleDeclarationCb({\r\n                    id,\r\n                    styleId,\r\n                    remove: {\r\n                        property,\r\n                    },\r\n                    index: getNestedCSSRulePositions(thisArg.parentRule),\r\n                });\r\n            }\r\n            return target.apply(thisArg, argumentsList);\r\n        }),\r\n    });\r\n    return callbackWrapper(() => {\r\n        win.CSSStyleDeclaration.prototype.setProperty = setProperty;\r\n        win.CSSStyleDeclaration.prototype.removeProperty = removeProperty;\r\n    });\r\n}\r\nfunction initMediaInteractionObserver({ mediaInteractionCb, blockClass, blockSelector, unblockSelector, mirror, sampling, doc, }) {\r\n    const handler = callbackWrapper((type) => throttle(callbackWrapper((event) => {\r\n        const target = getEventTarget(event);\r\n        if (!target ||\r\n            isBlocked(target, blockClass, blockSelector, unblockSelector, true)) {\r\n            return;\r\n        }\r\n        const { currentTime, volume, muted, playbackRate } = target;\r\n        mediaInteractionCb({\r\n            type,\r\n            id: mirror.getId(target),\r\n            currentTime,\r\n            volume,\r\n            muted,\r\n            playbackRate,\r\n        });\r\n    }), sampling.media || 500));\r\n    const handlers = [\r\n        on('play', handler(0), doc),\r\n        on('pause', handler(1), doc),\r\n        on('seeked', handler(2), doc),\r\n        on('volumechange', handler(3), doc),\r\n        on('ratechange', handler(4), doc),\r\n    ];\r\n    return callbackWrapper(() => {\r\n        handlers.forEach((h) => h());\r\n    });\r\n}\r\nfunction initFontObserver({ fontCb, doc }) {\r\n    const win = doc.defaultView;\r\n    if (!win) {\r\n        return () => {\r\n        };\r\n    }\r\n    const handlers = [];\r\n    const fontMap = new WeakMap();\r\n    const originalFontFace = win.FontFace;\r\n    win.FontFace = function FontFace(family, source, descriptors) {\r\n        const fontFace = new originalFontFace(family, source, descriptors);\r\n        fontMap.set(fontFace, {\r\n            family,\r\n            buffer: typeof source !== 'string',\r\n            descriptors,\r\n            fontSource: typeof source === 'string'\r\n                ? source\r\n                : JSON.stringify(Array.from(new Uint8Array(source))),\r\n        });\r\n        return fontFace;\r\n    };\r\n    const restoreHandler = patch(doc.fonts, 'add', function (original) {\r\n        return function (fontFace) {\r\n            setTimeout(callbackWrapper(() => {\r\n                const p = fontMap.get(fontFace);\r\n                if (p) {\r\n                    fontCb(p);\r\n                    fontMap.delete(fontFace);\r\n                }\r\n            }), 0);\r\n            return original.apply(this, [fontFace]);\r\n        };\r\n    });\r\n    handlers.push(() => {\r\n        win.FontFace = originalFontFace;\r\n    });\r\n    handlers.push(restoreHandler);\r\n    return callbackWrapper(() => {\r\n        handlers.forEach((h) => h());\r\n    });\r\n}\r\nfunction initSelectionObserver(param) {\r\n    const { doc, mirror, blockClass, blockSelector, unblockSelector, selectionCb, } = param;\r\n    let collapsed = true;\r\n    const updateSelection = callbackWrapper(() => {\r\n        const selection = doc.getSelection();\r\n        if (!selection || (collapsed && selection?.isCollapsed))\r\n            return;\r\n        collapsed = selection.isCollapsed || false;\r\n        const ranges = [];\r\n        const count = selection.rangeCount || 0;\r\n        for (let i = 0; i < count; i++) {\r\n            const range = selection.getRangeAt(i);\r\n            const { startContainer, startOffset, endContainer, endOffset } = range;\r\n            const blocked = isBlocked(startContainer, blockClass, blockSelector, unblockSelector, true) ||\r\n                isBlocked(endContainer, blockClass, blockSelector, unblockSelector, true);\r\n            if (blocked)\r\n                continue;\r\n            ranges.push({\r\n                start: mirror.getId(startContainer),\r\n                startOffset,\r\n                end: mirror.getId(endContainer),\r\n                endOffset,\r\n            });\r\n        }\r\n        selectionCb({ ranges });\r\n    });\r\n    updateSelection();\r\n    return on('selectionchange', updateSelection);\r\n}\r\nfunction initCustomElementObserver({ doc, customElementCb, }) {\r\n    const win = doc.defaultView;\r\n    if (!win || !win.customElements)\r\n        return () => { };\r\n    const restoreHandler = patch(win.customElements, 'define', function (original) {\r\n        return function (name, constructor, options) {\r\n            try {\r\n                customElementCb({\r\n                    define: {\r\n                        name,\r\n                    },\r\n                });\r\n            }\r\n            catch (e) {\r\n            }\r\n            return original.apply(this, [name, constructor, options]);\r\n        };\r\n    });\r\n    return restoreHandler;\r\n}\r\nfunction initObservers(o, _hooks = {}) {\r\n    const currentWindow = o.doc.defaultView;\r\n    if (!currentWindow) {\r\n        return () => {\r\n        };\r\n    }\r\n    let mutationObserver;\r\n    if (o.recordDOM) {\r\n        mutationObserver = initMutationObserver(o, o.doc);\r\n    }\r\n    const mousemoveHandler = initMoveObserver(o);\r\n    const mouseInteractionHandler = initMouseInteractionObserver(o);\r\n    const scrollHandler = initScrollObserver(o);\r\n    const viewportResizeHandler = initViewportResizeObserver(o, {\r\n        win: currentWindow,\r\n    });\r\n    const inputHandler = initInputObserver(o);\r\n    const mediaInteractionHandler = initMediaInteractionObserver(o);\r\n    let styleSheetObserver = () => { };\r\n    let adoptedStyleSheetObserver = () => { };\r\n    let styleDeclarationObserver = () => { };\r\n    let fontObserver = () => { };\r\n    if (o.recordDOM) {\r\n        styleSheetObserver = initStyleSheetObserver(o, { win: currentWindow });\r\n        adoptedStyleSheetObserver = initAdoptedStyleSheetObserver(o, o.doc);\r\n        styleDeclarationObserver = initStyleDeclarationObserver(o, {\r\n            win: currentWindow,\r\n        });\r\n        if (o.collectFonts) {\r\n            fontObserver = initFontObserver(o);\r\n        }\r\n    }\r\n    const selectionObserver = initSelectionObserver(o);\r\n    const customElementObserver = initCustomElementObserver(o);\r\n    const pluginHandlers = [];\r\n    for (const plugin of o.plugins) {\r\n        pluginHandlers.push(plugin.observer(plugin.callback, currentWindow, plugin.options));\r\n    }\r\n    return callbackWrapper(() => {\r\n        mutationBuffers.forEach((b) => b.reset());\r\n        mutationObserver?.disconnect();\r\n        mousemoveHandler();\r\n        mouseInteractionHandler();\r\n        scrollHandler();\r\n        viewportResizeHandler();\r\n        inputHandler();\r\n        mediaInteractionHandler();\r\n        styleSheetObserver();\r\n        adoptedStyleSheetObserver();\r\n        styleDeclarationObserver();\r\n        fontObserver();\r\n        selectionObserver();\r\n        customElementObserver();\r\n        pluginHandlers.forEach((h) => h());\r\n    });\r\n}\r\nfunction hasNestedCSSRule(prop) {\r\n    return typeof window[prop] !== 'undefined';\r\n}\r\nfunction canMonkeyPatchNestedCSSRule(prop) {\r\n    return Boolean(typeof window[prop] !== 'undefined' &&\r\n        window[prop].prototype &&\r\n        'insertRule' in window[prop].prototype &&\r\n        'deleteRule' in window[prop].prototype);\r\n}\n\nexport { INPUT_TAGS, initAdoptedStyleSheetObserver, initMutationObserver, initObservers, initScrollObserver, mutationBuffers };\n","class CrossOriginIframeMirror {\r\n    constructor(generateIdFn) {\r\n        this.generateIdFn = generateIdFn;\r\n        this.iframeIdToRemoteIdMap = new WeakMap();\r\n        this.iframeRemoteIdToIdMap = new WeakMap();\r\n    }\r\n    getId(iframe, remoteId, idToRemoteMap, remoteToIdMap) {\r\n        const idToRemoteIdMap = idToRemoteMap || this.getIdToRemoteIdMap(iframe);\r\n        const remoteIdToIdMap = remoteToIdMap || this.getRemoteIdToIdMap(iframe);\r\n        let id = idToRemoteIdMap.get(remoteId);\r\n        if (!id) {\r\n            id = this.generateIdFn();\r\n            idToRemoteIdMap.set(remoteId, id);\r\n            remoteIdToIdMap.set(id, remoteId);\r\n        }\r\n        return id;\r\n    }\r\n    getIds(iframe, remoteId) {\r\n        const idToRemoteIdMap = this.getIdToRemoteIdMap(iframe);\r\n        const remoteIdToIdMap = this.getRemoteIdToIdMap(iframe);\r\n        return remoteId.map((id) => this.getId(iframe, id, idToRemoteIdMap, remoteIdToIdMap));\r\n    }\r\n    getRemoteId(iframe, id, map) {\r\n        const remoteIdToIdMap = map || this.getRemoteIdToIdMap(iframe);\r\n        if (typeof id !== 'number')\r\n            return id;\r\n        const remoteId = remoteIdToIdMap.get(id);\r\n        if (!remoteId)\r\n            return -1;\r\n        return remoteId;\r\n    }\r\n    getRemoteIds(iframe, ids) {\r\n        const remoteIdToIdMap = this.getRemoteIdToIdMap(iframe);\r\n        return ids.map((id) => this.getRemoteId(iframe, id, remoteIdToIdMap));\r\n    }\r\n    reset(iframe) {\r\n        if (!iframe) {\r\n            this.iframeIdToRemoteIdMap = new WeakMap();\r\n            this.iframeRemoteIdToIdMap = new WeakMap();\r\n            return;\r\n        }\r\n        this.iframeIdToRemoteIdMap.delete(iframe);\r\n        this.iframeRemoteIdToIdMap.delete(iframe);\r\n    }\r\n    getIdToRemoteIdMap(iframe) {\r\n        let idToRemoteIdMap = this.iframeIdToRemoteIdMap.get(iframe);\r\n        if (!idToRemoteIdMap) {\r\n            idToRemoteIdMap = new Map();\r\n            this.iframeIdToRemoteIdMap.set(iframe, idToRemoteIdMap);\r\n        }\r\n        return idToRemoteIdMap;\r\n    }\r\n    getRemoteIdToIdMap(iframe) {\r\n        let remoteIdToIdMap = this.iframeRemoteIdToIdMap.get(iframe);\r\n        if (!remoteIdToIdMap) {\r\n            remoteIdToIdMap = new Map();\r\n            this.iframeRemoteIdToIdMap.set(iframe, remoteIdToIdMap);\r\n        }\r\n        return remoteIdToIdMap;\r\n    }\r\n}\n\nexport { CrossOriginIframeMirror as default };\n","import { genId, NodeType } from '../../../rrweb-snapshot/es/rrweb-snapshot.js';\nimport CrossOriginIframeMirror from './cross-origin-iframe-mirror.js';\nimport { EventType, IncrementalSource } from '../../../types/dist/rrweb-types.js';\nimport { getIFrameContentDocument } from '../../../rrdom/es/rrdom.js';\n\nclass IframeManagerNoop {\r\n    constructor() {\r\n        this.crossOriginIframeMirror = new CrossOriginIframeMirror(genId);\r\n        this.crossOriginIframeRootIdMap = new WeakMap();\r\n    }\r\n    addIframe() {\r\n    }\r\n    addLoadListener() {\r\n    }\r\n    attachIframe() {\r\n    }\r\n}\r\nclass IframeManager {\r\n    constructor(options) {\r\n        this.iframes = new WeakMap();\r\n        this.crossOriginIframeMap = new WeakMap();\r\n        this.crossOriginIframeMirror = new CrossOriginIframeMirror(genId);\r\n        this.crossOriginIframeRootIdMap = new WeakMap();\r\n        this.mutationCb = options.mutationCb;\r\n        this.wrappedEmit = options.wrappedEmit;\r\n        this.stylesheetManager = options.stylesheetManager;\r\n        this.recordCrossOriginIframes = options.recordCrossOriginIframes;\r\n        this.crossOriginIframeStyleMirror = new CrossOriginIframeMirror(this.stylesheetManager.styleMirror.generateId.bind(this.stylesheetManager.styleMirror));\r\n        this.mirror = options.mirror;\r\n        if (this.recordCrossOriginIframes) {\r\n            window.addEventListener('message', this.handleMessage.bind(this));\r\n        }\r\n    }\r\n    addIframe(iframeEl) {\r\n        this.iframes.set(iframeEl, true);\r\n        if (iframeEl.contentWindow)\r\n            this.crossOriginIframeMap.set(iframeEl.contentWindow, iframeEl);\r\n    }\r\n    addLoadListener(cb) {\r\n        this.loadListener = cb;\r\n    }\r\n    attachIframe(iframeEl, childSn) {\r\n        this.mutationCb({\r\n            adds: [\r\n                {\r\n                    parentId: this.mirror.getId(iframeEl),\r\n                    nextId: null,\r\n                    node: childSn,\r\n                },\r\n            ],\r\n            removes: [],\r\n            texts: [],\r\n            attributes: [],\r\n            isAttachIframe: true,\r\n        });\r\n        this.loadListener?.(iframeEl);\r\n        const iframeDoc = getIFrameContentDocument(iframeEl);\r\n        if (iframeDoc &&\r\n            iframeDoc.adoptedStyleSheets &&\r\n            iframeDoc.adoptedStyleSheets.length > 0)\r\n            this.stylesheetManager.adoptStyleSheets(iframeDoc.adoptedStyleSheets, this.mirror.getId(iframeDoc));\r\n    }\r\n    handleMessage(message) {\r\n        const crossOriginMessageEvent = message;\r\n        if (crossOriginMessageEvent.data.type !== 'rrweb' ||\r\n            crossOriginMessageEvent.origin !== crossOriginMessageEvent.data.origin)\r\n            return;\r\n        const iframeSourceWindow = message.source;\r\n        if (!iframeSourceWindow)\r\n            return;\r\n        const iframeEl = this.crossOriginIframeMap.get(message.source);\r\n        if (!iframeEl)\r\n            return;\r\n        const transformedEvent = this.transformCrossOriginEvent(iframeEl, crossOriginMessageEvent.data.event);\r\n        if (transformedEvent)\r\n            this.wrappedEmit(transformedEvent, crossOriginMessageEvent.data.isCheckout);\r\n    }\r\n    transformCrossOriginEvent(iframeEl, e) {\r\n        switch (e.type) {\r\n            case EventType.FullSnapshot: {\r\n                this.crossOriginIframeMirror.reset(iframeEl);\r\n                this.crossOriginIframeStyleMirror.reset(iframeEl);\r\n                this.replaceIdOnNode(e.data.node, iframeEl);\r\n                const rootId = e.data.node.id;\r\n                this.crossOriginIframeRootIdMap.set(iframeEl, rootId);\r\n                this.patchRootIdOnNode(e.data.node, rootId);\r\n                return {\r\n                    timestamp: e.timestamp,\r\n                    type: EventType.IncrementalSnapshot,\r\n                    data: {\r\n                        source: IncrementalSource.Mutation,\r\n                        adds: [\r\n                            {\r\n                                parentId: this.mirror.getId(iframeEl),\r\n                                nextId: null,\r\n                                node: e.data.node,\r\n                            },\r\n                        ],\r\n                        removes: [],\r\n                        texts: [],\r\n                        attributes: [],\r\n                        isAttachIframe: true,\r\n                    },\r\n                };\r\n            }\r\n            case EventType.Meta:\r\n            case EventType.Load:\r\n            case EventType.DomContentLoaded: {\r\n                return false;\r\n            }\r\n            case EventType.Plugin: {\r\n                return e;\r\n            }\r\n            case EventType.Custom: {\r\n                this.replaceIds(e.data.payload, iframeEl, ['id', 'parentId', 'previousId', 'nextId']);\r\n                return e;\r\n            }\r\n            case EventType.IncrementalSnapshot: {\r\n                switch (e.data.source) {\r\n                    case IncrementalSource.Mutation: {\r\n                        e.data.adds.forEach((n) => {\r\n                            this.replaceIds(n, iframeEl, [\r\n                                'parentId',\r\n                                'nextId',\r\n                                'previousId',\r\n                            ]);\r\n                            this.replaceIdOnNode(n.node, iframeEl);\r\n                            const rootId = this.crossOriginIframeRootIdMap.get(iframeEl);\r\n                            rootId && this.patchRootIdOnNode(n.node, rootId);\r\n                        });\r\n                        e.data.removes.forEach((n) => {\r\n                            this.replaceIds(n, iframeEl, ['parentId', 'id']);\r\n                        });\r\n                        e.data.attributes.forEach((n) => {\r\n                            this.replaceIds(n, iframeEl, ['id']);\r\n                        });\r\n                        e.data.texts.forEach((n) => {\r\n                            this.replaceIds(n, iframeEl, ['id']);\r\n                        });\r\n                        return e;\r\n                    }\r\n                    case IncrementalSource.Drag:\r\n                    case IncrementalSource.TouchMove:\r\n                    case IncrementalSource.MouseMove: {\r\n                        e.data.positions.forEach((p) => {\r\n                            this.replaceIds(p, iframeEl, ['id']);\r\n                        });\r\n                        return e;\r\n                    }\r\n                    case IncrementalSource.ViewportResize: {\r\n                        return false;\r\n                    }\r\n                    case IncrementalSource.MediaInteraction:\r\n                    case IncrementalSource.MouseInteraction:\r\n                    case IncrementalSource.Scroll:\r\n                    case IncrementalSource.CanvasMutation:\r\n                    case IncrementalSource.Input: {\r\n                        this.replaceIds(e.data, iframeEl, ['id']);\r\n                        return e;\r\n                    }\r\n                    case IncrementalSource.StyleSheetRule:\r\n                    case IncrementalSource.StyleDeclaration: {\r\n                        this.replaceIds(e.data, iframeEl, ['id']);\r\n                        this.replaceStyleIds(e.data, iframeEl, ['styleId']);\r\n                        return e;\r\n                    }\r\n                    case IncrementalSource.Font: {\r\n                        return e;\r\n                    }\r\n                    case IncrementalSource.Selection: {\r\n                        e.data.ranges.forEach((range) => {\r\n                            this.replaceIds(range, iframeEl, ['start', 'end']);\r\n                        });\r\n                        return e;\r\n                    }\r\n                    case IncrementalSource.AdoptedStyleSheet: {\r\n                        this.replaceIds(e.data, iframeEl, ['id']);\r\n                        this.replaceStyleIds(e.data, iframeEl, ['styleIds']);\r\n                        e.data.styles?.forEach((style) => {\r\n                            this.replaceStyleIds(style, iframeEl, ['styleId']);\r\n                        });\r\n                        return e;\r\n                    }\r\n                }\r\n            }\r\n        }\r\n        return false;\r\n    }\r\n    replace(iframeMirror, obj, iframeEl, keys) {\r\n        for (const key of keys) {\r\n            if (!Array.isArray(obj[key]) && typeof obj[key] !== 'number')\r\n                continue;\r\n            if (Array.isArray(obj[key])) {\r\n                obj[key] = iframeMirror.getIds(iframeEl, obj[key]);\r\n            }\r\n            else {\r\n                obj[key] = iframeMirror.getId(iframeEl, obj[key]);\r\n            }\r\n        }\r\n        return obj;\r\n    }\r\n    replaceIds(obj, iframeEl, keys) {\r\n        return this.replace(this.crossOriginIframeMirror, obj, iframeEl, keys);\r\n    }\r\n    replaceStyleIds(obj, iframeEl, keys) {\r\n        return this.replace(this.crossOriginIframeStyleMirror, obj, iframeEl, keys);\r\n    }\r\n    replaceIdOnNode(node, iframeEl) {\r\n        this.replaceIds(node, iframeEl, ['id', 'rootId']);\r\n        if ('childNodes' in node) {\r\n            node.childNodes.forEach((child) => {\r\n                this.replaceIdOnNode(child, iframeEl);\r\n            });\r\n        }\r\n    }\r\n    patchRootIdOnNode(node, rootId) {\r\n        if (node.type !== NodeType.Document && !node.rootId)\r\n            node.rootId = rootId;\r\n        if ('childNodes' in node) {\r\n            node.childNodes.forEach((child) => {\r\n                this.patchRootIdOnNode(child, rootId);\r\n            });\r\n        }\r\n    }\r\n}\n\nexport { IframeManager, IframeManagerNoop };\n","import { initMutationObserver, initScrollObserver, initAdoptedStyleSheetObserver } from './observer.js';\nimport { setTimeout, patch, inDom } from '../utils.js';\nimport { isNativeShadowDom } from '../../../rrweb-snapshot/es/rrweb-snapshot.js';\nimport { getIFrameContentDocument, getIFrameContentWindow } from '../../../rrdom/es/rrdom.js';\n\nclass ShadowDomManagerNoop {\r\n    init() {\r\n    }\r\n    addShadowRoot() {\r\n    }\r\n    observeAttachShadow() {\r\n    }\r\n    reset() {\r\n    }\r\n}\r\nclass ShadowDomManager {\r\n    constructor(options) {\r\n        this.shadowDoms = new WeakSet();\r\n        this.restoreHandlers = [];\r\n        this.mutationCb = options.mutationCb;\r\n        this.scrollCb = options.scrollCb;\r\n        this.bypassOptions = options.bypassOptions;\r\n        this.mirror = options.mirror;\r\n        this.init();\r\n    }\r\n    init() {\r\n        this.reset();\r\n        this.patchAttachShadow(Element, document);\r\n    }\r\n    addShadowRoot(shadowRoot, doc) {\r\n        if (!isNativeShadowDom(shadowRoot))\r\n            return;\r\n        if (this.shadowDoms.has(shadowRoot))\r\n            return;\r\n        this.shadowDoms.add(shadowRoot);\r\n        this.bypassOptions.canvasManager.addShadowRoot(shadowRoot);\r\n        const observer = initMutationObserver({\r\n            ...this.bypassOptions,\r\n            doc,\r\n            mutationCb: this.mutationCb,\r\n            mirror: this.mirror,\r\n            shadowDomManager: this,\r\n        }, shadowRoot);\r\n        this.restoreHandlers.push(() => observer.disconnect());\r\n        this.restoreHandlers.push(initScrollObserver({\r\n            ...this.bypassOptions,\r\n            scrollCb: this.scrollCb,\r\n            doc: shadowRoot,\r\n            mirror: this.mirror,\r\n        }));\r\n        setTimeout(() => {\r\n            if (shadowRoot.adoptedStyleSheets &&\r\n                shadowRoot.adoptedStyleSheets.length > 0)\r\n                this.bypassOptions.stylesheetManager.adoptStyleSheets(shadowRoot.adoptedStyleSheets, this.mirror.getId(shadowRoot.host));\r\n            this.restoreHandlers.push(initAdoptedStyleSheetObserver({\r\n                mirror: this.mirror,\r\n                stylesheetManager: this.bypassOptions.stylesheetManager,\r\n            }, shadowRoot));\r\n        }, 0);\r\n    }\r\n    observeAttachShadow(iframeElement) {\r\n        const iframeDoc = getIFrameContentDocument(iframeElement);\r\n        const iframeWindow = getIFrameContentWindow(iframeElement);\r\n        if (!iframeDoc || !iframeWindow)\r\n            return;\r\n        this.patchAttachShadow(iframeWindow.Element, iframeDoc);\r\n    }\r\n    patchAttachShadow(element, doc) {\r\n        const manager = this;\r\n        this.restoreHandlers.push(patch(element.prototype, 'attachShadow', function (original) {\r\n            return function (option) {\r\n                const shadowRoot = original.call(this, option);\r\n                if (this.shadowRoot && inDom(this))\r\n                    manager.addShadowRoot(this.shadowRoot, doc);\r\n                return shadowRoot;\r\n            };\r\n        }));\r\n    }\r\n    reset() {\r\n        this.restoreHandlers.forEach((handler) => {\r\n            try {\r\n                handler();\r\n            }\r\n            catch (e) {\r\n            }\r\n        });\r\n        this.restoreHandlers = [];\r\n        this.shadowDoms = new WeakSet();\r\n        this.bypassOptions.canvasManager.resetShadowRoots();\r\n    }\r\n}\n\nexport { ShadowDomManager, ShadowDomManagerNoop };\n","import { onRequestAnimationFrame, isBlocked } from '../../../utils.js';\nimport { CanvasContext } from '../../../../../types/dist/rrweb-types.js';\nimport initCanvas2DMutationObserver from './2d.js';\nimport initCanvasContextObserver from './canvas.js';\nimport initCanvasWebGLMutationObserver from './webgl.js';\nimport { getImageBitmapDataUrlWorkerURL as t } from '../../../../../rrweb-worker/es/rrweb-worker/index.js';\nimport { callbackWrapper, registerErrorHandler } from '../../error-handler.js';\n\nclass CanvasManagerNoop {\r\n    reset() {\r\n    }\r\n    freeze() {\r\n    }\r\n    unfreeze() {\r\n    }\r\n    lock() {\r\n    }\r\n    unlock() {\r\n    }\r\n    snapshot() {\r\n    }\r\n    addWindow() {\r\n    }\r\n    addShadowRoot() {\r\n    }\r\n    resetShadowRoots() {\r\n    }\r\n}\r\nclass CanvasManager {\r\n    reset() {\r\n        this.pendingCanvasMutations.clear();\r\n        this.restoreHandlers.forEach((handler) => {\r\n            try {\r\n                handler();\r\n            }\r\n            catch (e) {\r\n            }\r\n        });\r\n        this.restoreHandlers = [];\r\n        this.windowsSet = new WeakSet();\r\n        this.windows = [];\r\n        this.shadowDoms = new Set();\r\n        this.worker?.terminate();\r\n        this.worker = null;\r\n        this.snapshotInProgressMap = new Map();\r\n    }\r\n    freeze() {\r\n        this.frozen = true;\r\n    }\r\n    unfreeze() {\r\n        this.frozen = false;\r\n    }\r\n    lock() {\r\n        this.locked = true;\r\n    }\r\n    unlock() {\r\n        this.locked = false;\r\n    }\r\n    constructor(options) {\r\n        this.pendingCanvasMutations = new Map();\r\n        this.rafStamps = { latestId: 0, invokeId: null };\r\n        this.shadowDoms = new Set();\r\n        this.windowsSet = new WeakSet();\r\n        this.windows = [];\r\n        this.restoreHandlers = [];\r\n        this.frozen = false;\r\n        this.locked = false;\r\n        this.snapshotInProgressMap = new Map();\r\n        this.worker = null;\r\n        this.processMutation = (target, mutation) => {\r\n            const newFrame = this.rafStamps.invokeId &&\r\n                this.rafStamps.latestId !== this.rafStamps.invokeId;\r\n            if (newFrame || !this.rafStamps.invokeId)\r\n                this.rafStamps.invokeId = this.rafStamps.latestId;\r\n            if (!this.pendingCanvasMutations.has(target)) {\r\n                this.pendingCanvasMutations.set(target, []);\r\n            }\r\n            this.pendingCanvasMutations.get(target).push(mutation);\r\n        };\r\n        const { sampling = 'all', win, blockClass, blockSelector, unblockSelector, maxCanvasSize, recordCanvas, dataURLOptions, errorHandler, } = options;\r\n        this.mutationCb = options.mutationCb;\r\n        this.mirror = options.mirror;\r\n        this.options = options;\r\n        if (errorHandler) {\r\n            registerErrorHandler(errorHandler);\r\n        }\r\n        if ((recordCanvas && typeof sampling === 'number') ||\r\n            options.enableManualSnapshot) {\r\n            this.worker = this.initFPSWorker();\r\n        }\r\n        this.addWindow(win);\r\n        if (options.enableManualSnapshot) {\r\n            return;\r\n        }\r\n        callbackWrapper(() => {\r\n            if (recordCanvas && sampling === 'all') {\r\n                this.startRAFTimestamping();\r\n                this.startPendingCanvasMutationFlusher();\r\n            }\r\n            if (recordCanvas && typeof sampling === 'number') {\r\n                this.initCanvasFPSObserver(sampling, blockClass, blockSelector, unblockSelector, maxCanvasSize, {\r\n                    dataURLOptions,\r\n                });\r\n            }\r\n        })();\r\n    }\r\n    addWindow(win) {\r\n        const { sampling = 'all', blockClass, blockSelector, unblockSelector, recordCanvas, enableManualSnapshot, } = this.options;\r\n        if (this.windowsSet.has(win))\r\n            return;\r\n        if (enableManualSnapshot) {\r\n            this.windowsSet.add(win);\r\n            this.windows.push(new WeakRef(win));\r\n            return;\r\n        }\r\n        callbackWrapper(() => {\r\n            if (recordCanvas && sampling === 'all') {\r\n                this.initCanvasMutationObserver(win, blockClass, blockSelector, unblockSelector);\r\n            }\r\n            if (recordCanvas && typeof sampling === 'number') {\r\n                const canvasContextReset = initCanvasContextObserver(win, blockClass, blockSelector, unblockSelector, true);\r\n                this.restoreHandlers.push(() => {\r\n                    canvasContextReset();\r\n                });\r\n            }\r\n        })();\r\n        this.windowsSet.add(win);\r\n        this.windows.push(new WeakRef(win));\r\n    }\r\n    addShadowRoot(shadowRoot) {\r\n        this.shadowDoms.add(new WeakRef(shadowRoot));\r\n    }\r\n    resetShadowRoots() {\r\n        this.shadowDoms = new Set();\r\n    }\r\n    initFPSWorker() {\r\n        const worker = new Worker(t());\r\n        worker.onmessage = (e) => {\r\n            const data = e.data;\r\n            const { id } = data;\r\n            this.snapshotInProgressMap.set(id, false);\r\n            if (!('base64' in data))\r\n                return;\r\n            const { base64, type, width, height } = data;\r\n            this.mutationCb({\r\n                id,\r\n                type: CanvasContext['2D'],\r\n                commands: [\r\n                    {\r\n                        property: 'clearRect',\r\n                        args: [0, 0, width, height],\r\n                    },\r\n                    {\r\n                        property: 'drawImage',\r\n                        args: [\r\n                            {\r\n                                rr_type: 'ImageBitmap',\r\n                                args: [\r\n                                    {\r\n                                        rr_type: 'Blob',\r\n                                        data: [{ rr_type: 'ArrayBuffer', base64 }],\r\n                                        type,\r\n                                    },\r\n                                ],\r\n                            },\r\n                            0,\r\n                            0,\r\n                            width,\r\n                            height,\r\n                        ],\r\n                    },\r\n                ],\r\n            });\r\n        };\r\n        return worker;\r\n    }\r\n    initCanvasFPSObserver(fps, blockClass, blockSelector, unblockSelector, maxCanvasSize, options) {\r\n        const rafId = this.takeSnapshot(false, fps, blockClass, blockSelector, unblockSelector, maxCanvasSize, options.dataURLOptions);\r\n        this.restoreHandlers.push(() => {\r\n            cancelAnimationFrame(rafId);\r\n        });\r\n    }\r\n    initCanvasMutationObserver(win, blockClass, blockSelector, unblockSelector) {\r\n        const canvasContextReset = initCanvasContextObserver(win, blockClass, blockSelector, unblockSelector, false);\r\n        const canvas2DReset = initCanvas2DMutationObserver(this.processMutation.bind(this), win, blockClass, blockSelector, unblockSelector);\r\n        const canvasWebGL1and2Reset = initCanvasWebGLMutationObserver(this.processMutation.bind(this), win, blockClass, blockSelector, unblockSelector, this.mirror);\r\n        this.restoreHandlers.push(() => {\r\n            canvasContextReset();\r\n            canvas2DReset();\r\n            canvasWebGL1and2Reset();\r\n        });\r\n    }\r\n    snapshot(canvasElement) {\r\n        const { options } = this;\r\n        const rafId = this.takeSnapshot(true, options.sampling === 'all' ? 2 : options.sampling || 2, options.blockClass, options.blockSelector, options.unblockSelector, options.maxCanvasSize, options.dataURLOptions, canvasElement);\r\n        this.restoreHandlers.push(() => {\r\n            cancelAnimationFrame(rafId);\r\n        });\r\n    }\r\n    takeSnapshot(isManualSnapshot, fps, blockClass, blockSelector, unblockSelector, maxCanvasSize, dataURLOptions, canvasElement) {\r\n        const timeBetweenSnapshots = 1000 / fps;\r\n        let lastSnapshotTime = 0;\r\n        let rafId;\r\n        const getCanvas = (canvasElement) => {\r\n            if (canvasElement) {\r\n                return [canvasElement];\r\n            }\r\n            const matchedCanvas = [];\r\n            const searchCanvas = (root) => {\r\n                root.querySelectorAll('canvas').forEach((canvas) => {\r\n                    if (!isBlocked(canvas, blockClass, blockSelector, unblockSelector, true)) {\r\n                        matchedCanvas.push(canvas);\r\n                    }\r\n                });\r\n            };\r\n            for (const item of this.windows) {\r\n                const window = item.deref();\r\n                if (window) {\r\n                    searchCanvas(window.document);\r\n                }\r\n            }\r\n            for (const item of this.shadowDoms) {\r\n                const shadowRoot = item.deref();\r\n                if (shadowRoot) {\r\n                    searchCanvas(shadowRoot);\r\n                }\r\n            }\r\n            return matchedCanvas;\r\n        };\r\n        const takeCanvasSnapshots = (timestamp) => {\r\n            if (!this.windows.length) {\r\n                return;\r\n            }\r\n            if (lastSnapshotTime &&\r\n                timestamp - lastSnapshotTime < timeBetweenSnapshots) {\r\n                rafId = onRequestAnimationFrame(takeCanvasSnapshots);\r\n                return;\r\n            }\r\n            lastSnapshotTime = timestamp;\r\n            getCanvas(canvasElement).forEach((canvas) => {\r\n                if (!this.mirror.hasNode(canvas)) {\r\n                    return;\r\n                }\r\n                const id = this.mirror.getId(canvas);\r\n                if (this.snapshotInProgressMap.get(id))\r\n                    return;\r\n                if (!canvas.width || !canvas.height)\r\n                    return;\r\n                this.snapshotInProgressMap.set(id, true);\r\n                if (!isManualSnapshot &&\r\n                    ['webgl', 'webgl2'].includes(canvas.__context)) {\r\n                    const context = canvas.getContext(canvas.__context);\r\n                    if (context?.getContextAttributes()?.preserveDrawingBuffer === false) {\r\n                        context.clear(context.COLOR_BUFFER_BIT);\r\n                    }\r\n                }\r\n                createImageBitmap(canvas)\r\n                    .then((bitmap) => {\r\n                    this.worker?.postMessage({\r\n                        id,\r\n                        bitmap,\r\n                        width: canvas.width,\r\n                        height: canvas.height,\r\n                        dataURLOptions,\r\n                        maxCanvasSize,\r\n                    }, [bitmap]);\r\n                })\r\n                    .catch((error) => {\r\n                    callbackWrapper(() => {\r\n                        throw error;\r\n                    })();\r\n                });\r\n            });\r\n            if (!isManualSnapshot) {\r\n                rafId = onRequestAnimationFrame(takeCanvasSnapshots);\r\n            }\r\n        };\r\n        rafId = onRequestAnimationFrame(takeCanvasSnapshots);\r\n        return rafId;\r\n    }\r\n    startPendingCanvasMutationFlusher() {\r\n        onRequestAnimationFrame(() => this.flushPendingCanvasMutations());\r\n    }\r\n    startRAFTimestamping() {\r\n        const setLatestRAFTimestamp = (timestamp) => {\r\n            this.rafStamps.latestId = timestamp;\r\n            onRequestAnimationFrame(setLatestRAFTimestamp);\r\n        };\r\n        onRequestAnimationFrame(setLatestRAFTimestamp);\r\n    }\r\n    flushPendingCanvasMutations() {\r\n        this.pendingCanvasMutations.forEach((values, canvas) => {\r\n            const id = this.mirror.getId(canvas);\r\n            this.flushPendingCanvasMutationFor(canvas, id);\r\n        });\r\n        onRequestAnimationFrame(() => this.flushPendingCanvasMutations());\r\n    }\r\n    flushPendingCanvasMutationFor(canvas, id) {\r\n        if (this.frozen || this.locked) {\r\n            return;\r\n        }\r\n        const valuesWithType = this.pendingCanvasMutations.get(canvas);\r\n        if (!valuesWithType || id === -1)\r\n            return;\r\n        const values = valuesWithType.map((value) => {\r\n            const { type, ...rest } = value;\r\n            return rest;\r\n        });\r\n        const { type } = valuesWithType[0];\r\n        this.mutationCb({ id, type, commands: values });\r\n        this.pendingCanvasMutations.delete(canvas);\r\n    }\r\n}\n\nexport { CanvasManager, CanvasManagerNoop };\n","import { stringifyRule } from '../../../rrweb-snapshot/es/rrweb-snapshot.js';\nimport { StyleSheetMirror } from '../utils.js';\n\nclass StylesheetManager {\r\n    constructor(options) {\r\n        this.trackedLinkElements = new WeakSet();\r\n        this.styleMirror = new StyleSheetMirror();\r\n        this.mutationCb = options.mutationCb;\r\n        this.adoptedStyleSheetCb = options.adoptedStyleSheetCb;\r\n    }\r\n    attachLinkElement(linkEl, childSn) {\r\n        if ('_cssText' in childSn.attributes)\r\n            this.mutationCb({\r\n                adds: [],\r\n                removes: [],\r\n                texts: [],\r\n                attributes: [\r\n                    {\r\n                        id: childSn.id,\r\n                        attributes: childSn\r\n                            .attributes,\r\n                    },\r\n                ],\r\n            });\r\n        this.trackLinkElement(linkEl);\r\n    }\r\n    trackLinkElement(linkEl) {\r\n        if (this.trackedLinkElements.has(linkEl))\r\n            return;\r\n        this.trackedLinkElements.add(linkEl);\r\n        this.trackStylesheetInLinkElement(linkEl);\r\n    }\r\n    adoptStyleSheets(sheets, hostId) {\r\n        if (sheets.length === 0)\r\n            return;\r\n        const adoptedStyleSheetData = {\r\n            id: hostId,\r\n            styleIds: [],\r\n        };\r\n        const styles = [];\r\n        for (const sheet of sheets) {\r\n            let styleId;\r\n            if (!this.styleMirror.has(sheet)) {\r\n                styleId = this.styleMirror.add(sheet);\r\n                styles.push({\r\n                    styleId,\r\n                    rules: Array.from(sheet.rules || CSSRule, (r, index) => ({\r\n                        rule: stringifyRule(r),\r\n                        index,\r\n                    })),\r\n                });\r\n            }\r\n            else\r\n                styleId = this.styleMirror.getId(sheet);\r\n            adoptedStyleSheetData.styleIds.push(styleId);\r\n        }\r\n        if (styles.length > 0)\r\n            adoptedStyleSheetData.styles = styles;\r\n        this.adoptedStyleSheetCb(adoptedStyleSheetData);\r\n    }\r\n    reset() {\r\n        this.styleMirror.reset();\r\n        this.trackedLinkElements = new WeakSet();\r\n    }\r\n    trackStylesheetInLinkElement(linkEl) {\r\n    }\r\n}\n\nexport { StylesheetManager };\n","import { onRequestAnimationFrame } from '../utils.js';\n\nclass ProcessedNodeManager {\r\n    constructor() {\r\n        this.nodeMap = new WeakMap();\r\n        this.active = false;\r\n    }\r\n    inOtherBuffer(node, thisBuffer) {\r\n        const buffers = this.nodeMap.get(node);\r\n        return (buffers && Array.from(buffers).some((buffer) => buffer !== thisBuffer));\r\n    }\r\n    add(node, buffer) {\r\n        if (!this.active) {\r\n            this.active = true;\r\n            onRequestAnimationFrame(() => {\r\n                this.nodeMap = new WeakMap();\r\n                this.active = false;\r\n            });\r\n        }\r\n        this.nodeMap.set(node, (this.nodeMap.get(node) || new Set()).add(buffer));\r\n    }\r\n    destroy() {\r\n    }\r\n}\n\nexport { ProcessedNodeManager as default };\n","import { createMirror, snapshot } from '../../../rrweb-snapshot/es/rrweb-snapshot.js';\nimport { initObservers, mutationBuffers } from './observer.js';\nimport { polyfill, on, nowTimestamp, getWindowWidth, getWindowHeight, getWindowScroll, isSerializedIframe, isSerializedStylesheet, hasShadowRoot } from '../utils.js';\nimport { EventType, IncrementalSource } from '../../../types/dist/rrweb-types.js';\nimport { IframeManagerNoop, IframeManager } from './iframe-manager.js';\nimport { ShadowDomManagerNoop, ShadowDomManager } from './shadow-dom-manager.js';\nimport { CanvasManagerNoop } from './observers/canvas/canvas-manager.js';\nexport { CanvasManager } from './observers/canvas/canvas-manager.js';\nimport { StylesheetManager } from './stylesheet-manager.js';\nimport ProcessedNodeManager from './processed-node-manager.js';\nimport { callbackWrapper, unregisterErrorHandler, registerErrorHandler } from './error-handler.js';\n\nlet wrappedEmit;\r\nlet _wrappedEmit;\r\nlet _takeFullSnapshot;\r\ntry {\r\n    if (Array.from([1], (x) => x * 2)[0] !== 2) {\r\n        const cleanFrame = document.createElement('iframe');\r\n        document.body.appendChild(cleanFrame);\r\n        Array.from = cleanFrame.contentWindow?.Array.from || Array.from;\r\n        document.body.removeChild(cleanFrame);\r\n    }\r\n}\r\ncatch (err) {\r\n    console.debug('Unable to override Array.from', err);\r\n}\r\nconst mirror = createMirror();\r\nfunction record(options = {}) {\r\n    const { emit, checkoutEveryNms, checkoutEveryNth, blockClass = 'rr-block', blockSelector = null, unblockSelector = null, ignoreClass = 'rr-ignore', ignoreSelector = null, maskAllText = false, maskTextClass = 'rr-mask', unmaskTextClass = null, maskTextSelector = null, unmaskTextSelector = null, inlineStylesheet = true, maskAllInputs, maskInputOptions: _maskInputOptions, slimDOMOptions: _slimDOMOptions, maskAttributeFn, maskInputFn, maskTextFn, maxCanvasSize = null, packFn, sampling = {}, dataURLOptions = {}, mousemoveWait, recordDOM = true, recordCanvas = false, recordCrossOriginIframes = false, recordAfter = options.recordAfter === 'DOMContentLoaded'\r\n        ? options.recordAfter\r\n        : 'load', userTriggeredOnInput = false, collectFonts = false, inlineImages = false, plugins, keepIframeSrcFn = () => false, ignoreCSSAttributes = new Set([]), errorHandler, onMutation, getCanvasManager, } = options;\r\n    registerErrorHandler(errorHandler);\r\n    const inEmittingFrame = recordCrossOriginIframes\r\n        ? window.parent === window\r\n        : true;\r\n    let passEmitsToParent = false;\r\n    if (!inEmittingFrame) {\r\n        try {\r\n            if (window.parent.document) {\r\n                passEmitsToParent = false;\r\n            }\r\n        }\r\n        catch (e) {\r\n            passEmitsToParent = true;\r\n        }\r\n    }\r\n    if (inEmittingFrame && !emit) {\r\n        throw new Error('emit function is required');\r\n    }\r\n    if (!inEmittingFrame && !passEmitsToParent) {\r\n        return () => {\r\n        };\r\n    }\r\n    if (mousemoveWait !== undefined && sampling.mousemove === undefined) {\r\n        sampling.mousemove = mousemoveWait;\r\n    }\r\n    mirror.reset();\r\n    const maskInputOptions = maskAllInputs === true\r\n        ? {\r\n            color: true,\r\n            date: true,\r\n            'datetime-local': true,\r\n            email: true,\r\n            month: true,\r\n            number: true,\r\n            range: true,\r\n            search: true,\r\n            tel: true,\r\n            text: true,\r\n            time: true,\r\n            url: true,\r\n            week: true,\r\n            textarea: true,\r\n            select: true,\r\n            radio: true,\r\n            checkbox: true,\r\n        }\r\n        : _maskInputOptions !== undefined\r\n            ? _maskInputOptions\r\n            : {};\r\n    const slimDOMOptions = _slimDOMOptions === true || _slimDOMOptions === 'all'\r\n        ? {\r\n            script: true,\r\n            comment: true,\r\n            headFavicon: true,\r\n            headWhitespace: true,\r\n            headMetaSocial: true,\r\n            headMetaRobots: true,\r\n            headMetaHttpEquiv: true,\r\n            headMetaVerification: true,\r\n            headMetaAuthorship: _slimDOMOptions === 'all',\r\n            headMetaDescKeywords: _slimDOMOptions === 'all',\r\n        }\r\n        : _slimDOMOptions\r\n            ? _slimDOMOptions\r\n            : {};\r\n    polyfill();\r\n    let lastFullSnapshotEvent;\r\n    let incrementalSnapshotCount = 0;\r\n    const eventProcessor = (e) => {\r\n        for (const plugin of plugins || []) {\r\n            if (plugin.eventProcessor) {\r\n                e = plugin.eventProcessor(e);\r\n            }\r\n        }\r\n        if (packFn &&\r\n            !passEmitsToParent) {\r\n            e = packFn(e);\r\n        }\r\n        return e;\r\n    };\r\n    wrappedEmit = (r, isCheckout) => {\r\n        const e = r;\r\n        e.timestamp = nowTimestamp();\r\n        if (mutationBuffers[0]?.isFrozen() &&\r\n            e.type !== EventType.FullSnapshot &&\r\n            !(e.type === EventType.IncrementalSnapshot &&\r\n                e.data.source === IncrementalSource.Mutation)) {\r\n            mutationBuffers.forEach((buf) => buf.unfreeze());\r\n        }\r\n        if (inEmittingFrame) {\r\n            emit?.(eventProcessor(e), isCheckout);\r\n        }\r\n        else if (passEmitsToParent) {\r\n            const message = {\r\n                type: 'rrweb',\r\n                event: eventProcessor(e),\r\n                origin: window.location.origin,\r\n                isCheckout,\r\n            };\r\n            window.parent.postMessage(message, '*');\r\n        }\r\n        if (e.type === EventType.FullSnapshot) {\r\n            lastFullSnapshotEvent = e;\r\n            incrementalSnapshotCount = 0;\r\n        }\r\n        else if (e.type === EventType.IncrementalSnapshot) {\r\n            if (e.data.source === IncrementalSource.Mutation &&\r\n                e.data.isAttachIframe) {\r\n                return;\r\n            }\r\n            incrementalSnapshotCount++;\r\n            const exceedCount = checkoutEveryNth && incrementalSnapshotCount >= checkoutEveryNth;\r\n            const exceedTime = checkoutEveryNms &&\r\n                lastFullSnapshotEvent &&\r\n                e.timestamp - lastFullSnapshotEvent.timestamp > checkoutEveryNms;\r\n            if (exceedCount || exceedTime) {\r\n                takeFullSnapshot(true);\r\n            }\r\n        }\r\n    };\r\n    _wrappedEmit = wrappedEmit;\r\n    const wrappedMutationEmit = (m) => {\r\n        wrappedEmit({\r\n            type: EventType.IncrementalSnapshot,\r\n            data: {\r\n                source: IncrementalSource.Mutation,\r\n                ...m,\r\n            },\r\n        });\r\n    };\r\n    const wrappedScrollEmit = (p) => wrappedEmit({\r\n        type: EventType.IncrementalSnapshot,\r\n        data: {\r\n            source: IncrementalSource.Scroll,\r\n            ...p,\r\n        },\r\n    });\r\n    const wrappedCanvasMutationEmit = (p) => wrappedEmit({\r\n        type: EventType.IncrementalSnapshot,\r\n        data: {\r\n            source: IncrementalSource.CanvasMutation,\r\n            ...p,\r\n        },\r\n    });\r\n    const wrappedAdoptedStyleSheetEmit = (a) => wrappedEmit({\r\n        type: EventType.IncrementalSnapshot,\r\n        data: {\r\n            source: IncrementalSource.AdoptedStyleSheet,\r\n            ...a,\r\n        },\r\n    });\r\n    const stylesheetManager = new StylesheetManager({\r\n        mutationCb: wrappedMutationEmit,\r\n        adoptedStyleSheetCb: wrappedAdoptedStyleSheetEmit,\r\n    });\r\n    const iframeManager = typeof __RRWEB_EXCLUDE_IFRAME__ === 'boolean' && __RRWEB_EXCLUDE_IFRAME__\r\n        ? new IframeManagerNoop()\r\n        : new IframeManager({\r\n            mirror,\r\n            mutationCb: wrappedMutationEmit,\r\n            stylesheetManager: stylesheetManager,\r\n            recordCrossOriginIframes,\r\n            wrappedEmit,\r\n        });\r\n    for (const plugin of plugins || []) {\r\n        if (plugin.getMirror)\r\n            plugin.getMirror({\r\n                nodeMirror: mirror,\r\n                crossOriginIframeMirror: iframeManager.crossOriginIframeMirror,\r\n                crossOriginIframeStyleMirror: iframeManager.crossOriginIframeStyleMirror,\r\n            });\r\n    }\r\n    const processedNodeManager = new ProcessedNodeManager();\r\n    const canvasManager = _getCanvasManager(getCanvasManager, {\r\n        mirror,\r\n        win: window,\r\n        mutationCb: (p) => wrappedEmit({\r\n            type: EventType.IncrementalSnapshot,\r\n            data: {\r\n                source: IncrementalSource.CanvasMutation,\r\n                ...p,\r\n            },\r\n        }),\r\n        recordCanvas,\r\n        blockClass,\r\n        blockSelector,\r\n        unblockSelector,\r\n        maxCanvasSize,\r\n        sampling: sampling['canvas'],\r\n        dataURLOptions,\r\n        errorHandler,\r\n    });\r\n    const shadowDomManager = typeof __RRWEB_EXCLUDE_SHADOW_DOM__ === 'boolean' &&\r\n        __RRWEB_EXCLUDE_SHADOW_DOM__\r\n        ? new ShadowDomManagerNoop()\r\n        : new ShadowDomManager({\r\n            mutationCb: wrappedMutationEmit,\r\n            scrollCb: wrappedScrollEmit,\r\n            bypassOptions: {\r\n                onMutation,\r\n                blockClass,\r\n                blockSelector,\r\n                unblockSelector,\r\n                maskAllText,\r\n                maskTextClass,\r\n                unmaskTextClass,\r\n                maskTextSelector,\r\n                unmaskTextSelector,\r\n                inlineStylesheet,\r\n                maskInputOptions,\r\n                dataURLOptions,\r\n                maskAttributeFn,\r\n                maskTextFn,\r\n                maskInputFn,\r\n                recordCanvas,\r\n                inlineImages,\r\n                sampling,\r\n                slimDOMOptions,\r\n                iframeManager,\r\n                stylesheetManager,\r\n                canvasManager,\r\n                keepIframeSrcFn,\r\n                processedNodeManager,\r\n            },\r\n            mirror,\r\n        });\r\n    const takeFullSnapshot = (isCheckout = false) => {\r\n        if (!recordDOM) {\r\n            return;\r\n        }\r\n        wrappedEmit({\r\n            type: EventType.Meta,\r\n            data: {\r\n                href: window.location.href,\r\n                width: getWindowWidth(),\r\n                height: getWindowHeight(),\r\n            },\r\n        }, isCheckout);\r\n        stylesheetManager.reset();\r\n        shadowDomManager.init();\r\n        mutationBuffers.forEach((buf) => buf.lock());\r\n        const node = snapshot(document, {\r\n            mirror,\r\n            blockClass,\r\n            blockSelector,\r\n            unblockSelector,\r\n            maskAllText,\r\n            maskTextClass,\r\n            unmaskTextClass,\r\n            maskTextSelector,\r\n            unmaskTextSelector,\r\n            inlineStylesheet,\r\n            maskAllInputs: maskInputOptions,\r\n            maskAttributeFn,\r\n            maskInputFn,\r\n            maskTextFn,\r\n            slimDOM: slimDOMOptions,\r\n            dataURLOptions,\r\n            recordCanvas,\r\n            inlineImages,\r\n            onSerialize: (n) => {\r\n                if (isSerializedIframe(n, mirror)) {\r\n                    iframeManager.addIframe(n);\r\n                }\r\n                if (isSerializedStylesheet(n, mirror)) {\r\n                    stylesheetManager.trackLinkElement(n);\r\n                }\r\n                if (hasShadowRoot(n)) {\r\n                    shadowDomManager.addShadowRoot(n.shadowRoot, document);\r\n                }\r\n            },\r\n            onIframeLoad: (iframe, childSn) => {\r\n                iframeManager.attachIframe(iframe, childSn);\r\n                if (iframe.contentWindow) {\r\n                    canvasManager.addWindow(iframe.contentWindow);\r\n                }\r\n                shadowDomManager.observeAttachShadow(iframe);\r\n            },\r\n            onStylesheetLoad: (linkEl, childSn) => {\r\n                stylesheetManager.attachLinkElement(linkEl, childSn);\r\n            },\r\n            keepIframeSrcFn,\r\n        });\r\n        if (!node) {\r\n            return console.warn('Failed to snapshot the document');\r\n        }\r\n        wrappedEmit({\r\n            type: EventType.FullSnapshot,\r\n            data: {\r\n                node,\r\n                initialOffset: getWindowScroll(window),\r\n            },\r\n        });\r\n        mutationBuffers.forEach((buf) => buf.unlock());\r\n        if (document.adoptedStyleSheets && document.adoptedStyleSheets.length > 0)\r\n            stylesheetManager.adoptStyleSheets(document.adoptedStyleSheets, mirror.getId(document));\r\n    };\r\n    _takeFullSnapshot = takeFullSnapshot;\r\n    try {\r\n        const handlers = [];\r\n        const observe = (doc) => {\r\n            return callbackWrapper(initObservers)({\r\n                onMutation,\r\n                mutationCb: wrappedMutationEmit,\r\n                mousemoveCb: (positions, source) => wrappedEmit({\r\n                    type: EventType.IncrementalSnapshot,\r\n                    data: {\r\n                        source,\r\n                        positions,\r\n                    },\r\n                }),\r\n                mouseInteractionCb: (d) => wrappedEmit({\r\n                    type: EventType.IncrementalSnapshot,\r\n                    data: {\r\n                        source: IncrementalSource.MouseInteraction,\r\n                        ...d,\r\n                    },\r\n                }),\r\n                scrollCb: wrappedScrollEmit,\r\n                viewportResizeCb: (d) => wrappedEmit({\r\n                    type: EventType.IncrementalSnapshot,\r\n                    data: {\r\n                        source: IncrementalSource.ViewportResize,\r\n                        ...d,\r\n                    },\r\n                }),\r\n                inputCb: (v) => wrappedEmit({\r\n                    type: EventType.IncrementalSnapshot,\r\n                    data: {\r\n                        source: IncrementalSource.Input,\r\n                        ...v,\r\n                    },\r\n                }),\r\n                mediaInteractionCb: (p) => wrappedEmit({\r\n                    type: EventType.IncrementalSnapshot,\r\n                    data: {\r\n                        source: IncrementalSource.MediaInteraction,\r\n                        ...p,\r\n                    },\r\n                }),\r\n                styleSheetRuleCb: (r) => wrappedEmit({\r\n                    type: EventType.IncrementalSnapshot,\r\n                    data: {\r\n                        source: IncrementalSource.StyleSheetRule,\r\n                        ...r,\r\n                    },\r\n                }),\r\n                styleDeclarationCb: (r) => wrappedEmit({\r\n                    type: EventType.IncrementalSnapshot,\r\n                    data: {\r\n                        source: IncrementalSource.StyleDeclaration,\r\n                        ...r,\r\n                    },\r\n                }),\r\n                canvasMutationCb: wrappedCanvasMutationEmit,\r\n                fontCb: (p) => wrappedEmit({\r\n                    type: EventType.IncrementalSnapshot,\r\n                    data: {\r\n                        source: IncrementalSource.Font,\r\n                        ...p,\r\n                    },\r\n                }),\r\n                selectionCb: (p) => {\r\n                    wrappedEmit({\r\n                        type: EventType.IncrementalSnapshot,\r\n                        data: {\r\n                            source: IncrementalSource.Selection,\r\n                            ...p,\r\n                        },\r\n                    });\r\n                },\r\n                customElementCb: (c) => {\r\n                    wrappedEmit({\r\n                        type: EventType.IncrementalSnapshot,\r\n                        data: {\r\n                            source: IncrementalSource.CustomElement,\r\n                            ...c,\r\n                        },\r\n                    });\r\n                },\r\n                blockClass,\r\n                ignoreClass,\r\n                ignoreSelector,\r\n                maskAllText,\r\n                maskTextClass,\r\n                unmaskTextClass,\r\n                maskTextSelector,\r\n                unmaskTextSelector,\r\n                maskInputOptions,\r\n                inlineStylesheet,\r\n                sampling,\r\n                recordDOM,\r\n                recordCanvas,\r\n                inlineImages,\r\n                userTriggeredOnInput,\r\n                collectFonts,\r\n                doc,\r\n                maskAttributeFn,\r\n                maskInputFn,\r\n                maskTextFn,\r\n                keepIframeSrcFn,\r\n                blockSelector,\r\n                unblockSelector,\r\n                slimDOMOptions,\r\n                dataURLOptions,\r\n                mirror,\r\n                iframeManager,\r\n                stylesheetManager,\r\n                shadowDomManager,\r\n                processedNodeManager,\r\n                canvasManager,\r\n                ignoreCSSAttributes,\r\n                plugins: plugins\r\n                    ?.filter((p) => p.observer)\r\n                    ?.map((p) => ({\r\n                    observer: p.observer,\r\n                    options: p.options,\r\n                    callback: (payload) => wrappedEmit({\r\n                        type: EventType.Plugin,\r\n                        data: {\r\n                            plugin: p.name,\r\n                            payload,\r\n                        },\r\n                    }),\r\n                })) || [],\r\n            }, {});\r\n        };\r\n        iframeManager.addLoadListener((iframeEl) => {\r\n            try {\r\n                handlers.push(observe(iframeEl.contentDocument));\r\n            }\r\n            catch (error) {\r\n                console.warn(error);\r\n            }\r\n        });\r\n        const init = () => {\r\n            takeFullSnapshot();\r\n            handlers.push(observe(document));\r\n        };\r\n        if (document.readyState === 'interactive' ||\r\n            document.readyState === 'complete') {\r\n            init();\r\n        }\r\n        else {\r\n            handlers.push(on('DOMContentLoaded', () => {\r\n                wrappedEmit({\r\n                    type: EventType.DomContentLoaded,\r\n                    data: {},\r\n                });\r\n                if (recordAfter === 'DOMContentLoaded')\r\n                    init();\r\n            }));\r\n            handlers.push(on('load', () => {\r\n                wrappedEmit({\r\n                    type: EventType.Load,\r\n                    data: {},\r\n                });\r\n                if (recordAfter === 'load')\r\n                    init();\r\n            }, window));\r\n        }\r\n        return () => {\r\n            handlers.forEach((h) => h());\r\n            processedNodeManager.destroy();\r\n            _takeFullSnapshot = undefined;\r\n            unregisterErrorHandler();\r\n        };\r\n    }\r\n    catch (error) {\r\n        console.warn(error);\r\n    }\r\n}\r\nfunction addCustomEvent(tag, payload) {\r\n    if (!_wrappedEmit) {\r\n        throw new Error('please add custom event after start recording');\r\n    }\r\n    wrappedEmit({\r\n        type: EventType.Custom,\r\n        data: {\r\n            tag,\r\n            payload,\r\n        },\r\n    });\r\n}\r\nfunction freezePage() {\r\n    mutationBuffers.forEach((buf) => buf.freeze());\r\n}\r\nfunction takeFullSnapshot(isCheckout) {\r\n    if (!_takeFullSnapshot) {\r\n        throw new Error('please take full snapshot after start recording');\r\n    }\r\n    _takeFullSnapshot(isCheckout);\r\n}\r\nrecord.mirror = mirror;\r\nrecord.takeFullSnapshot = takeFullSnapshot;\r\nfunction _getCanvasManager(getCanvasManagerFn, options) {\r\n    try {\r\n        return getCanvasManagerFn\r\n            ? getCanvasManagerFn(options)\r\n            : new CanvasManagerNoop();\r\n    }\r\n    catch {\r\n        console.warn('Unable to initialize CanvasManager');\r\n        return new CanvasManagerNoop();\r\n    }\r\n}\n\nexport { addCustomEvent, record as default, freezePage, takeFullSnapshot };\n","type ClassOption = string | RegExp;\n\n/** Duplicate this from @sentry-internal/rrweb so we can export this as well. */\nexport const ReplayEventTypeDomContentLoaded = 0;\nexport const ReplayEventTypeLoad = 1;\nexport const ReplayEventTypeFullSnapshot = 2;\nexport const ReplayEventTypeIncrementalSnapshot = 3;\nexport const ReplayEventTypeMeta = 4;\nexport const ReplayEventTypeCustom = 5;\nexport const ReplayEventTypePlugin = 6;\n\nexport type ReplayEventType =\n  | typeof ReplayEventTypeDomContentLoaded\n  | typeof ReplayEventTypeLoad\n  | typeof ReplayEventTypeFullSnapshot\n  | typeof ReplayEventTypeIncrementalSnapshot\n  | typeof ReplayEventTypeMeta\n  | typeof ReplayEventTypeCustom\n  | typeof ReplayEventTypePlugin;\n\n/**\n * This is a partial copy of rrweb's eventWithTime type which only contains the properties\n * we specifically need in the SDK.\n */\nexport type ReplayEventWithTime = {\n  type: ReplayEventType;\n  data: unknown;\n  timestamp: number;\n  delay?: number;\n};\n\n/**\n * This is a partial copy of rrweb's recording options which only contains the properties\n * we specifically use in the SDK. Users can specify additional properties, hence we add the\n * Record<string, unknown> union type.\n */\nexport type RrwebRecordOptions = {\n  maskAllText?: boolean;\n  maskAllInputs?: boolean;\n  blockClass?: ClassOption;\n  ignoreClass?: string;\n  maskTextClass?: ClassOption;\n  maskTextSelector?: string;\n  blockSelector?: string;\n  maskInputOptions?: Record<string, boolean>;\n} & Record<string, unknown>;\n\nexport interface CanvasManagerInterface {\n  reset(): void;\n  freeze(): void;\n  unfreeze(): void;\n  lock(): void;\n  unlock(): void;\n  snapshot(): void;\n  addWindow(win: typeof globalThis & Window): void;\n  addShadowRoot(shadowRoot: ShadowRoot): void;\n  resetShadowRoots(): void;\n}\n\nexport interface CanvasManagerOptions {\n  recordCanvas: boolean;\n  enableManualSnapshot?: boolean;\n  blockClass: string | RegExp;\n  blockSelector: string | null;\n  unblockSelector: string | null;\n  sampling?: 'all' | number;\n  dataURLOptions: Partial<{\n    type: string;\n    quality: number;\n  }>;\n  mutationCb: (p: any) => void;\n  win: typeof globalThis & Window;\n  mirror: any;\n}\n","/**\n * Converts a timestamp to ms, if it was in s, or keeps it as ms.\n */\nexport function timestampToMs(timestamp: number): number {\n  const isMs = timestamp > 9999999999;\n  return isMs ? timestamp : timestamp * 1000;\n}\n\n/**\n * Converts a timestamp to s, if it was in ms, or keeps it as s.\n */\nexport function timestampToS(timestamp: number): number {\n  const isMs = timestamp > 9999999999;\n  return isMs ? timestamp / 1000 : timestamp;\n}\n","import { EventType } from '@sentry-internal/rrweb';\nimport { normalize } from '@sentry/core';\nimport type { Breadcrumb } from '@sentry/core';\n\nimport type { ReplayContainer } from '../../types';\n\n/**\n * Add a breadcrumb event to replay.\n */\nexport function addBreadcrumbEvent(replay: ReplayContainer, breadcrumb: Breadcrumb): void {\n  if (breadcrumb.category === 'sentry.transaction') {\n    return;\n  }\n\n  if (['ui.click', 'ui.input'].includes(breadcrumb.category as string)) {\n    replay.triggerUserActivity();\n  } else {\n    replay.checkAndHandleExpiredSession();\n  }\n\n  replay.addUpdate(() => {\n    // This should never reject\n    // eslint-disable-next-line @typescript-eslint/no-floating-promises\n    replay.throttledAddEvent({\n      type: EventType.Custom,\n      // TODO: We were converting from ms to seconds for breadcrumbs, spans,\n      // but maybe we should just keep them as milliseconds\n      timestamp: (breadcrumb.timestamp || 0) * 1000,\n      data: {\n        tag: 'breadcrumb',\n        // normalize to max. 10 depth and 1_000 properties per object\n        payload: normalize(breadcrumb, 10, 1_000),\n      },\n    });\n\n    // Do not flush after console log messages\n    return breadcrumb.category === 'console';\n  });\n}\n","import type { INode } from '@sentry-internal/rrweb-snapshot';\n\nconst INTERACTIVE_SELECTOR = 'button,a';\n\n/** Get the closest interactive parent element, or else return the given element. */\nexport function getClosestInteractive(element: Element): Element {\n  const closestInteractive = element.closest(INTERACTIVE_SELECTOR);\n  return closestInteractive || element;\n}\n\n/**\n * For clicks, we check if the target is inside of a button or link\n * If so, we use this as the target instead\n * This is useful because if you click on the image in <button><img></button>,\n * The target will be the image, not the button, which we don't want here\n */\nexport function getClickTargetNode(event: Event | MouseEvent | Node): Node | INode | null {\n  const target = getTargetNode(event);\n\n  if (!target || !(target instanceof Element)) {\n    return target;\n  }\n\n  return getClosestInteractive(target);\n}\n\n/** Get the event target node. */\nexport function getTargetNode(event: Node | { target: EventTarget | null }): Node | INode | null {\n  if (isEventWithTarget(event)) {\n    return event.target as Node | null;\n  }\n\n  return event;\n}\n\nfunction isEventWithTarget(event: unknown): event is { target: EventTarget | null } {\n  return typeof event === 'object' && !!event && 'target' in event;\n}\n","import { fill } from '@sentry/core';\n\nimport { WINDOW } from '../../constants';\n\ntype WindowOpenHandler = () => void;\n\nlet handlers: undefined | WindowOpenHandler[];\n\n/**\n * Register a handler to be called when `window.open()` is called.\n * Returns a cleanup function.\n */\nexport function onWindowOpen(cb: WindowOpenHandler): () => void {\n  // Ensure to only register this once\n  if (!handlers) {\n    handlers = [];\n    monkeyPatchWindowOpen();\n  }\n\n  handlers.push(cb);\n\n  return () => {\n    const pos = handlers ? handlers.indexOf(cb) : -1;\n    if (pos > -1) {\n      (handlers as WindowOpenHandler[]).splice(pos, 1);\n    }\n  };\n}\n\nfunction monkeyPatchWindowOpen(): void {\n  fill(WINDOW, 'open', function (originalWindowOpen: () => void): () => void {\n    return function (...args: unknown[]): void {\n      if (handlers) {\n        try {\n          handlers.forEach(handler => handler());\n        } catch (e) {\n          // ignore errors in here\n        }\n      }\n\n      return originalWindowOpen.apply(WINDOW, args);\n    };\n  });\n}\n","import { setTimeout } from '@sentry-internal/browser-utils';\nimport { IncrementalSource, MouseInteractions, record } from '@sentry-internal/rrweb';\nimport type { Breadcrumb } from '@sentry/core';\n\nimport { WINDOW } from '../constants';\nimport type {\n  RecordingEvent,\n  ReplayClickDetector,\n  ReplayContainer,\n  ReplayMultiClickFrame,\n  ReplaySlowClickFrame,\n  SlowClickConfig,\n} from '../types';\nimport { ReplayEventTypeIncrementalSnapshot } from '../types';\nimport { timestampToS } from '../util/timestamp';\nimport { addBreadcrumbEvent } from './util/addBreadcrumbEvent';\nimport { getClosestInteractive } from './util/domUtils';\nimport { onWindowOpen } from './util/onWindowOpen';\n\ntype ClickBreadcrumb = Breadcrumb & {\n  timestamp: number;\n};\n\ninterface Click {\n  timestamp: number;\n  mutationAfter?: number;\n  scrollAfter?: number;\n  clickBreadcrumb: ClickBreadcrumb;\n  clickCount: number;\n  node: HTMLElement;\n}\n\ntype IncrementalRecordingEvent = RecordingEvent & {\n  type: typeof ReplayEventTypeIncrementalSnapshot;\n  data: { source: IncrementalSource };\n};\n\ntype IncrementalMouseInteractionRecordingEvent = IncrementalRecordingEvent & {\n  type: typeof ReplayEventTypeIncrementalSnapshot;\n  data: { type: MouseInteractions; id: number };\n};\n\n/** Any IncrementalSource for rrweb that we interpret as a kind of mutation. */\nconst IncrementalMutationSources = new Set([\n  IncrementalSource.Mutation,\n  IncrementalSource.StyleSheetRule,\n  IncrementalSource.StyleDeclaration,\n  IncrementalSource.AdoptedStyleSheet,\n  IncrementalSource.CanvasMutation,\n  IncrementalSource.Selection,\n  IncrementalSource.MediaInteraction,\n]);\n\n/** Handle a click. */\nexport function handleClick(clickDetector: ReplayClickDetector, clickBreadcrumb: Breadcrumb, node: HTMLElement): void {\n  clickDetector.handleClick(clickBreadcrumb, node);\n}\n\n/** A click detector class that can be used to detect slow or rage clicks on elements. */\nexport class ClickDetector implements ReplayClickDetector {\n  // protected for testing\n  protected _lastMutation: number;\n  protected _lastScroll: number;\n\n  private _clicks: Click[];\n  private _teardown: undefined | (() => void);\n\n  private _threshold: number;\n  private _scrollTimeout: number;\n  private _timeout: number;\n  private _ignoreSelector: string;\n\n  private _replay: ReplayContainer;\n  private _checkClickTimeout?: ReturnType<typeof setTimeout>;\n  private _addBreadcrumbEvent: typeof addBreadcrumbEvent;\n\n  public constructor(\n    replay: ReplayContainer,\n    slowClickConfig: SlowClickConfig,\n    // Just for easier testing\n    _addBreadcrumbEvent = addBreadcrumbEvent,\n  ) {\n    this._lastMutation = 0;\n    this._lastScroll = 0;\n    this._clicks = [];\n\n    // We want everything in s, but options are in ms\n    this._timeout = slowClickConfig.timeout / 1000;\n    this._threshold = slowClickConfig.threshold / 1000;\n    this._scrollTimeout = slowClickConfig.scrollTimeout / 1000;\n    this._replay = replay;\n    this._ignoreSelector = slowClickConfig.ignoreSelector;\n    this._addBreadcrumbEvent = _addBreadcrumbEvent;\n  }\n\n  /** Register click detection handlers on mutation or scroll. */\n  public addListeners(): void {\n    const cleanupWindowOpen = onWindowOpen(() => {\n      // Treat window.open as mutation\n      this._lastMutation = nowInSeconds();\n    });\n\n    this._teardown = () => {\n      cleanupWindowOpen();\n\n      this._clicks = [];\n      this._lastMutation = 0;\n      this._lastScroll = 0;\n    };\n  }\n\n  /** Clean up listeners. */\n  public removeListeners(): void {\n    if (this._teardown) {\n      this._teardown();\n    }\n\n    if (this._checkClickTimeout) {\n      clearTimeout(this._checkClickTimeout);\n    }\n  }\n\n  /** @inheritDoc */\n  public handleClick(breadcrumb: Breadcrumb, node: HTMLElement): void {\n    if (ignoreElement(node, this._ignoreSelector) || !isClickBreadcrumb(breadcrumb)) {\n      return;\n    }\n\n    const newClick: Click = {\n      timestamp: timestampToS(breadcrumb.timestamp),\n      clickBreadcrumb: breadcrumb,\n      // Set this to 0 so we know it originates from the click breadcrumb\n      clickCount: 0,\n      node,\n    };\n\n    // If there was a click in the last 1s on the same element, ignore it - only keep a single reference per second\n    if (\n      this._clicks.some(click => click.node === newClick.node && Math.abs(click.timestamp - newClick.timestamp) < 1)\n    ) {\n      return;\n    }\n\n    this._clicks.push(newClick);\n\n    // If this is the first new click, set a timeout to check for multi clicks\n    if (this._clicks.length === 1) {\n      this._scheduleCheckClicks();\n    }\n  }\n\n  /** @inheritDoc */\n  public registerMutation(timestamp = Date.now()): void {\n    this._lastMutation = timestampToS(timestamp);\n  }\n\n  /** @inheritDoc */\n  public registerScroll(timestamp = Date.now()): void {\n    this._lastScroll = timestampToS(timestamp);\n  }\n\n  /** @inheritDoc */\n  public registerClick(element: HTMLElement): void {\n    const node = getClosestInteractive(element);\n    this._handleMultiClick(node as HTMLElement);\n  }\n\n  /** Count multiple clicks on elements. */\n  private _handleMultiClick(node: HTMLElement): void {\n    this._getClicks(node).forEach(click => {\n      click.clickCount++;\n    });\n  }\n\n  /** Get all pending clicks for a given node. */\n  private _getClicks(node: HTMLElement): Click[] {\n    return this._clicks.filter(click => click.node === node);\n  }\n\n  /** Check the clicks that happened. */\n  private _checkClicks(): void {\n    const timedOutClicks: Click[] = [];\n\n    const now = nowInSeconds();\n\n    this._clicks.forEach(click => {\n      if (!click.mutationAfter && this._lastMutation) {\n        click.mutationAfter = click.timestamp <= this._lastMutation ? this._lastMutation - click.timestamp : undefined;\n      }\n      if (!click.scrollAfter && this._lastScroll) {\n        click.scrollAfter = click.timestamp <= this._lastScroll ? this._lastScroll - click.timestamp : undefined;\n      }\n\n      // All of these are in seconds!\n      if (click.timestamp + this._timeout <= now) {\n        timedOutClicks.push(click);\n      }\n    });\n\n    // Remove \"old\" clicks\n    for (const click of timedOutClicks) {\n      const pos = this._clicks.indexOf(click);\n\n      if (pos > -1) {\n        this._generateBreadcrumbs(click);\n        this._clicks.splice(pos, 1);\n      }\n    }\n\n    // Trigger new check, unless no clicks left\n    if (this._clicks.length) {\n      this._scheduleCheckClicks();\n    }\n  }\n\n  /** Generate matching breadcrumb(s) for the click. */\n  private _generateBreadcrumbs(click: Click): void {\n    const replay = this._replay;\n    const hadScroll = click.scrollAfter && click.scrollAfter <= this._scrollTimeout;\n    const hadMutation = click.mutationAfter && click.mutationAfter <= this._threshold;\n\n    const isSlowClick = !hadScroll && !hadMutation;\n    const { clickCount, clickBreadcrumb } = click;\n\n    // Slow click\n    if (isSlowClick) {\n      // If `mutationAfter` is set, it means a mutation happened after the threshold, but before the timeout\n      // If not, it means we just timed out without scroll & mutation\n      const timeAfterClickMs = Math.min(click.mutationAfter || this._timeout, this._timeout) * 1000;\n      const endReason = timeAfterClickMs < this._timeout * 1000 ? 'mutation' : 'timeout';\n\n      const breadcrumb: ReplaySlowClickFrame = {\n        type: 'default',\n        message: clickBreadcrumb.message,\n        timestamp: clickBreadcrumb.timestamp,\n        category: 'ui.slowClickDetected',\n        data: {\n          ...clickBreadcrumb.data,\n          url: WINDOW.location.href,\n          route: replay.getCurrentRoute(),\n          timeAfterClickMs,\n          endReason,\n          // If clickCount === 0, it means multiClick was not correctly captured here\n          // - we still want to send 1 in this case\n          clickCount: clickCount || 1,\n        },\n      };\n\n      this._addBreadcrumbEvent(replay, breadcrumb);\n      return;\n    }\n\n    // Multi click\n    if (clickCount > 1) {\n      const breadcrumb: ReplayMultiClickFrame = {\n        type: 'default',\n        message: clickBreadcrumb.message,\n        timestamp: clickBreadcrumb.timestamp,\n        category: 'ui.multiClick',\n        data: {\n          ...clickBreadcrumb.data,\n          url: WINDOW.location.href,\n          route: replay.getCurrentRoute(),\n          clickCount,\n          metric: true,\n        },\n      };\n\n      this._addBreadcrumbEvent(replay, breadcrumb);\n    }\n  }\n\n  /** Schedule to check current clicks. */\n  private _scheduleCheckClicks(): void {\n    if (this._checkClickTimeout) {\n      clearTimeout(this._checkClickTimeout);\n    }\n\n    this._checkClickTimeout = setTimeout(() => this._checkClicks(), 1000);\n  }\n}\n\nconst SLOW_CLICK_TAGS = ['A', 'BUTTON', 'INPUT'];\n\n/** exported for tests only */\nexport function ignoreElement(node: HTMLElement, ignoreSelector: string): boolean {\n  if (!SLOW_CLICK_TAGS.includes(node.tagName)) {\n    return true;\n  }\n\n  // If <input> tag, we only want to consider input[type='submit'] & input[type='button']\n  if (node.tagName === 'INPUT' && !['submit', 'button'].includes(node.getAttribute('type') || '')) {\n    return true;\n  }\n\n  // If <a> tag, detect special variants that may not lead to an action\n  // If target !== _self, we may open the link somewhere else, which would lead to no action\n  // Also, when downloading a file, we may not leave the page, but still not trigger an action\n  if (\n    node.tagName === 'A' &&\n    (node.hasAttribute('download') || (node.hasAttribute('target') && node.getAttribute('target') !== '_self'))\n  ) {\n    return true;\n  }\n\n  if (ignoreSelector && node.matches(ignoreSelector)) {\n    return true;\n  }\n\n  return false;\n}\n\nfunction isClickBreadcrumb(breadcrumb: Breadcrumb): breadcrumb is ClickBreadcrumb {\n  return !!(breadcrumb.data && typeof breadcrumb.data.nodeId === 'number' && breadcrumb.timestamp);\n}\n\n// This is good enough for us, and is easier to test/mock than `timestampInSeconds`\nfunction nowInSeconds(): number {\n  return Date.now() / 1000;\n}\n\n/** Update the click detector based on a recording event of rrweb. */\nexport function updateClickDetectorForRecordingEvent(clickDetector: ReplayClickDetector, event: RecordingEvent): void {\n  try {\n    // note: We only consider incremental snapshots here\n    // This means that any full snapshot is ignored for mutation detection - the reason is that we simply cannot know if a mutation happened here.\n    // E.g. think that we are buffering, an error happens and we take a full snapshot because we switched to session mode -\n    // in this scenario, we would not know if a dead click happened because of the error, which is a key dead click scenario.\n    // Instead, by ignoring full snapshots, we have the risk that we generate a false positive\n    // (if a mutation _did_ happen but was \"swallowed\" by the full snapshot)\n    // But this should be more unlikely as we'd generally capture the incremental snapshot right away\n\n    if (!isIncrementalEvent(event)) {\n      return;\n    }\n\n    const { source } = event.data;\n    if (IncrementalMutationSources.has(source)) {\n      clickDetector.registerMutation(event.timestamp);\n    }\n\n    if (source === IncrementalSource.Scroll) {\n      clickDetector.registerScroll(event.timestamp);\n    }\n\n    if (isIncrementalMouseInteraction(event)) {\n      const { type, id } = event.data;\n      const node = record.mirror.getNode(id);\n\n      if (node instanceof HTMLElement && type === MouseInteractions.Click) {\n        clickDetector.registerClick(node);\n      }\n    }\n  } catch {\n    // ignore errors here, e.g. if accessing something that does not exist\n  }\n}\n\nfunction isIncrementalEvent(event: RecordingEvent): event is IncrementalRecordingEvent {\n  return event.type === ReplayEventTypeIncrementalSnapshot;\n}\n\nfunction isIncrementalMouseInteraction(\n  event: IncrementalRecordingEvent,\n): event is IncrementalMouseInteractionRecordingEvent {\n  return event.data.source === IncrementalSource.MouseInteraction;\n}\n","import type { ReplayBreadcrumbFrame } from '../types/replayFrame';\n\n/**\n * Create a breadcrumb for a replay.\n */\nexport function createBreadcrumb(\n  breadcrumb: Omit<ReplayBreadcrumbFrame, 'timestamp' | 'type'> & Partial<Pick<ReplayBreadcrumbFrame, 'timestamp'>>,\n): ReplayBreadcrumbFrame {\n  return {\n    timestamp: Date.now() / 1000,\n    type: 'default',\n    ...breadcrumb,\n  };\n}\n","var NodeType;\r\n(function (NodeType) {\r\n    NodeType[NodeType[\"Document\"] = 0] = \"Document\";\r\n    NodeType[NodeType[\"DocumentType\"] = 1] = \"DocumentType\";\r\n    NodeType[NodeType[\"Element\"] = 2] = \"Element\";\r\n    NodeType[NodeType[\"Text\"] = 3] = \"Text\";\r\n    NodeType[NodeType[\"CDATA\"] = 4] = \"CDATA\";\r\n    NodeType[NodeType[\"Comment\"] = 5] = \"Comment\";\r\n})(NodeType || (NodeType = {}));\n\nfunction isElement(n) {\r\n    return n.nodeType === n.ELEMENT_NODE;\r\n}\r\nfunction isShadowRoot(n) {\r\n    const host = n?.host;\r\n    return Boolean(host?.shadowRoot === n);\r\n}\r\nfunction isNativeShadowDom(shadowRoot) {\r\n    return Object.prototype.toString.call(shadowRoot) === '[object ShadowRoot]';\r\n}\r\nfunction fixBrowserCompatibilityIssuesInCSS(cssText) {\r\n    if (cssText.includes(' background-clip: text;') &&\r\n        !cssText.includes(' -webkit-background-clip: text;')) {\r\n        cssText = cssText.replace(/\\sbackground-clip:\\s*text;/g, ' -webkit-background-clip: text; background-clip: text;');\r\n    }\r\n    return cssText;\r\n}\r\nfunction escapeImportStatement(rule) {\r\n    const { cssText } = rule;\r\n    if (cssText.split('\"').length < 3)\r\n        return cssText;\r\n    const statement = ['@import', `url(${JSON.stringify(rule.href)})`];\r\n    if (rule.layerName === '') {\r\n        statement.push(`layer`);\r\n    }\r\n    else if (rule.layerName) {\r\n        statement.push(`layer(${rule.layerName})`);\r\n    }\r\n    if (rule.supportsText) {\r\n        statement.push(`supports(${rule.supportsText})`);\r\n    }\r\n    if (rule.media.length) {\r\n        statement.push(rule.media.mediaText);\r\n    }\r\n    return statement.join(' ') + ';';\r\n}\r\nfunction stringifyStylesheet(s) {\r\n    try {\r\n        const rules = s.rules || s.cssRules;\r\n        return rules\r\n            ? fixBrowserCompatibilityIssuesInCSS(Array.from(rules, stringifyRule).join(''))\r\n            : null;\r\n    }\r\n    catch (error) {\r\n        return null;\r\n    }\r\n}\r\nfunction fixAllCssProperty(rule) {\r\n    let styles = '';\r\n    for (let i = 0; i < rule.style.length; i++) {\r\n        const styleDeclaration = rule.style;\r\n        const attribute = styleDeclaration[i];\r\n        const isImportant = styleDeclaration.getPropertyPriority(attribute);\r\n        styles += `${attribute}:${styleDeclaration.getPropertyValue(attribute)}${isImportant ? ` !important` : ''};`;\r\n    }\r\n    return `${rule.selectorText} { ${styles} }`;\r\n}\r\nfunction stringifyRule(rule) {\r\n    let importStringified;\r\n    if (isCSSImportRule(rule)) {\r\n        try {\r\n            importStringified =\r\n                stringifyStylesheet(rule.styleSheet) ||\r\n                    escapeImportStatement(rule);\r\n        }\r\n        catch (error) {\r\n        }\r\n    }\r\n    else if (isCSSStyleRule(rule)) {\r\n        let cssText = rule.cssText;\r\n        const needsSafariColonFix = rule.selectorText.includes(':');\r\n        const needsAllFix = typeof rule.style['all'] === 'string' && rule.style['all'];\r\n        if (needsAllFix) {\r\n            cssText = fixAllCssProperty(rule);\r\n        }\r\n        if (needsSafariColonFix) {\r\n            cssText = fixSafariColons(cssText);\r\n        }\r\n        if (needsSafariColonFix || needsAllFix) {\r\n            return cssText;\r\n        }\r\n    }\r\n    return importStringified || rule.cssText;\r\n}\r\nfunction fixSafariColons(cssStringified) {\r\n    const regex = /(\\[(?:[\\w-]+)[^\\\\])(:(?:[\\w-]+)\\])/gm;\r\n    return cssStringified.replace(regex, '$1\\\\$2');\r\n}\r\nfunction isCSSImportRule(rule) {\r\n    return 'styleSheet' in rule;\r\n}\r\nfunction isCSSStyleRule(rule) {\r\n    return 'selectorText' in rule;\r\n}\r\nclass Mirror {\r\n    constructor() {\r\n        this.idNodeMap = new Map();\r\n        this.nodeMetaMap = new WeakMap();\r\n    }\r\n    getId(n) {\r\n        if (!n)\r\n            return -1;\r\n        const id = this.getMeta(n)?.id;\r\n        return id ?? -1;\r\n    }\r\n    getNode(id) {\r\n        return this.idNodeMap.get(id) || null;\r\n    }\r\n    getIds() {\r\n        return Array.from(this.idNodeMap.keys());\r\n    }\r\n    getMeta(n) {\r\n        return this.nodeMetaMap.get(n) || null;\r\n    }\r\n    removeNodeFromMap(n) {\r\n        const id = this.getId(n);\r\n        this.idNodeMap.delete(id);\r\n        if (n.childNodes) {\r\n            n.childNodes.forEach((childNode) => this.removeNodeFromMap(childNode));\r\n        }\r\n    }\r\n    has(id) {\r\n        return this.idNodeMap.has(id);\r\n    }\r\n    hasNode(node) {\r\n        return this.nodeMetaMap.has(node);\r\n    }\r\n    add(n, meta) {\r\n        const id = meta.id;\r\n        this.idNodeMap.set(id, n);\r\n        this.nodeMetaMap.set(n, meta);\r\n    }\r\n    replace(id, n) {\r\n        const oldNode = this.getNode(id);\r\n        if (oldNode) {\r\n            const meta = this.nodeMetaMap.get(oldNode);\r\n            if (meta)\r\n                this.nodeMetaMap.set(n, meta);\r\n        }\r\n        this.idNodeMap.set(id, n);\r\n    }\r\n    reset() {\r\n        this.idNodeMap = new Map();\r\n        this.nodeMetaMap = new WeakMap();\r\n    }\r\n}\r\nfunction createMirror() {\r\n    return new Mirror();\r\n}\r\nfunction shouldMaskInput({ maskInputOptions, tagName, type, }) {\r\n    if (tagName === 'OPTION') {\r\n        tagName = 'SELECT';\r\n    }\r\n    return Boolean(maskInputOptions[tagName.toLowerCase()] ||\r\n        (type && maskInputOptions[type]) ||\r\n        type === 'password' ||\r\n        (tagName === 'INPUT' && !type && maskInputOptions['text']));\r\n}\r\nfunction maskInputValue({ isMasked, element, value, maskInputFn, }) {\r\n    let text = value || '';\r\n    if (!isMasked) {\r\n        return text;\r\n    }\r\n    if (maskInputFn) {\r\n        text = maskInputFn(text, element);\r\n    }\r\n    return '*'.repeat(text.length);\r\n}\r\nfunction toLowerCase(str) {\r\n    return str.toLowerCase();\r\n}\r\nfunction toUpperCase(str) {\r\n    return str.toUpperCase();\r\n}\r\nconst ORIGINAL_ATTRIBUTE_NAME = '__rrweb_original__';\r\nfunction is2DCanvasBlank(canvas) {\r\n    const ctx = canvas.getContext('2d');\r\n    if (!ctx)\r\n        return true;\r\n    const chunkSize = 50;\r\n    for (let x = 0; x < canvas.width; x += chunkSize) {\r\n        for (let y = 0; y < canvas.height; y += chunkSize) {\r\n            const getImageData = ctx.getImageData;\r\n            const originalGetImageData = ORIGINAL_ATTRIBUTE_NAME in getImageData\r\n                ? getImageData[ORIGINAL_ATTRIBUTE_NAME]\r\n                : getImageData;\r\n            const pixelBuffer = new Uint32Array(originalGetImageData.call(ctx, x, y, Math.min(chunkSize, canvas.width - x), Math.min(chunkSize, canvas.height - y)).data.buffer);\r\n            if (pixelBuffer.some((pixel) => pixel !== 0))\r\n                return false;\r\n        }\r\n    }\r\n    return true;\r\n}\r\nfunction isNodeMetaEqual(a, b) {\r\n    if (!a || !b || a.type !== b.type)\r\n        return false;\r\n    if (a.type === NodeType.Document)\r\n        return a.compatMode === b.compatMode;\r\n    else if (a.type === NodeType.DocumentType)\r\n        return (a.name === b.name &&\r\n            a.publicId === b.publicId &&\r\n            a.systemId === b.systemId);\r\n    else if (a.type === NodeType.Comment ||\r\n        a.type === NodeType.Text ||\r\n        a.type === NodeType.CDATA)\r\n        return a.textContent === b.textContent;\r\n    else if (a.type === NodeType.Element)\r\n        return (a.tagName === b.tagName &&\r\n            JSON.stringify(a.attributes) ===\r\n                JSON.stringify(b.attributes) &&\r\n            a.isSVG === b.isSVG &&\r\n            a.needBlock === b.needBlock);\r\n    return false;\r\n}\r\nfunction getInputType(element) {\r\n    const type = element.type;\r\n    return element.hasAttribute('data-rr-is-password')\r\n        ? 'password'\r\n        : type\r\n            ?\r\n                toLowerCase(type)\r\n            : null;\r\n}\r\nfunction getInputValue(el, tagName, type) {\r\n    if (tagName === 'INPUT' && (type === 'radio' || type === 'checkbox')) {\r\n        return el.getAttribute('value') || '';\r\n    }\r\n    return el.value;\r\n}\r\nfunction extractFileExtension(path, baseURL) {\r\n    let url;\r\n    try {\r\n        url = new URL(path, baseURL ?? window.location.href);\r\n    }\r\n    catch (err) {\r\n        return null;\r\n    }\r\n    const regex = /\\.([0-9a-z]+)(?:$)/i;\r\n    const match = url.pathname.match(regex);\r\n    return match?.[1] ?? null;\r\n}\r\nconst cachedImplementations = {};\r\nfunction getImplementation(name) {\r\n    const cached = cachedImplementations[name];\r\n    if (cached) {\r\n        return cached;\r\n    }\r\n    const document = window.document;\r\n    let impl = window[name];\r\n    if (document && typeof document.createElement === 'function') {\r\n        try {\r\n            const sandbox = document.createElement('iframe');\r\n            sandbox.hidden = true;\r\n            document.head.appendChild(sandbox);\r\n            const contentWindow = sandbox.contentWindow;\r\n            if (contentWindow && contentWindow[name]) {\r\n                impl =\r\n                    contentWindow[name];\r\n            }\r\n            document.head.removeChild(sandbox);\r\n        }\r\n        catch (e) {\r\n        }\r\n    }\r\n    return (cachedImplementations[name] = impl.bind(window));\r\n}\r\nfunction onRequestAnimationFrame(...rest) {\r\n    return getImplementation('requestAnimationFrame')(...rest);\r\n}\r\nfunction setTimeout(...rest) {\r\n    return getImplementation('setTimeout')(...rest);\r\n}\r\nfunction clearTimeout(...rest) {\r\n    return getImplementation('clearTimeout')(...rest);\r\n}\r\nfunction getIframeContentDocument(iframe) {\r\n    try {\r\n        return iframe.contentDocument;\r\n    }\r\n    catch (e) {\r\n    }\r\n}\n\nlet _id = 1;\r\nconst tagNameRegex = new RegExp('[^a-z0-9-_:]');\r\nconst IGNORED_NODE = -2;\r\nfunction genId() {\r\n    return _id++;\r\n}\r\nfunction getValidTagName(element) {\r\n    if (element instanceof HTMLFormElement) {\r\n        return 'form';\r\n    }\r\n    const processedTagName = toLowerCase(element.tagName);\r\n    if (tagNameRegex.test(processedTagName)) {\r\n        return 'div';\r\n    }\r\n    return processedTagName;\r\n}\r\nfunction extractOrigin(url) {\r\n    let origin = '';\r\n    if (url.indexOf('//') > -1) {\r\n        origin = url.split('/').slice(0, 3).join('/');\r\n    }\r\n    else {\r\n        origin = url.split('/')[0];\r\n    }\r\n    origin = origin.split('?')[0];\r\n    return origin;\r\n}\r\nlet canvasService;\r\nlet canvasCtx;\r\nconst URL_IN_CSS_REF = /url\\((?:(')([^']*)'|(\")(.*?)\"|([^)]*))\\)/gm;\r\nconst URL_PROTOCOL_MATCH = /^(?:[a-z+]+:)?\\/\\//i;\r\nconst URL_WWW_MATCH = /^www\\..*/i;\r\nconst DATA_URI = /^(data:)([^,]*),(.*)/i;\r\nfunction absoluteToStylesheet(cssText, href) {\r\n    return (cssText || '').replace(URL_IN_CSS_REF, (origin, quote1, path1, quote2, path2, path3) => {\r\n        const filePath = path1 || path2 || path3;\r\n        const maybeQuote = quote1 || quote2 || '';\r\n        if (!filePath) {\r\n            return origin;\r\n        }\r\n        if (URL_PROTOCOL_MATCH.test(filePath) || URL_WWW_MATCH.test(filePath)) {\r\n            return `url(${maybeQuote}${filePath}${maybeQuote})`;\r\n        }\r\n        if (DATA_URI.test(filePath)) {\r\n            return `url(${maybeQuote}${filePath}${maybeQuote})`;\r\n        }\r\n        if (filePath[0] === '/') {\r\n            return `url(${maybeQuote}${extractOrigin(href) + filePath}${maybeQuote})`;\r\n        }\r\n        const stack = href.split('/');\r\n        const parts = filePath.split('/');\r\n        stack.pop();\r\n        for (const part of parts) {\r\n            if (part === '.') {\r\n                continue;\r\n            }\r\n            else if (part === '..') {\r\n                stack.pop();\r\n            }\r\n            else {\r\n                stack.push(part);\r\n            }\r\n        }\r\n        return `url(${maybeQuote}${stack.join('/')}${maybeQuote})`;\r\n    });\r\n}\r\nconst SRCSET_NOT_SPACES = /^[^ \\t\\n\\r\\u000c]+/;\r\nconst SRCSET_COMMAS_OR_SPACES = /^[, \\t\\n\\r\\u000c]+/;\r\nfunction getAbsoluteSrcsetString(doc, attributeValue) {\r\n    if (attributeValue.trim() === '') {\r\n        return attributeValue;\r\n    }\r\n    let pos = 0;\r\n    function collectCharacters(regEx) {\r\n        let chars;\r\n        const match = regEx.exec(attributeValue.substring(pos));\r\n        if (match) {\r\n            chars = match[0];\r\n            pos += chars.length;\r\n            return chars;\r\n        }\r\n        return '';\r\n    }\r\n    const output = [];\r\n    while (true) {\r\n        collectCharacters(SRCSET_COMMAS_OR_SPACES);\r\n        if (pos >= attributeValue.length) {\r\n            break;\r\n        }\r\n        let url = collectCharacters(SRCSET_NOT_SPACES);\r\n        if (url.slice(-1) === ',') {\r\n            url = absoluteToDoc(doc, url.substring(0, url.length - 1));\r\n            output.push(url);\r\n        }\r\n        else {\r\n            let descriptorsStr = '';\r\n            url = absoluteToDoc(doc, url);\r\n            let inParens = false;\r\n            while (true) {\r\n                const c = attributeValue.charAt(pos);\r\n                if (c === '') {\r\n                    output.push((url + descriptorsStr).trim());\r\n                    break;\r\n                }\r\n                else if (!inParens) {\r\n                    if (c === ',') {\r\n                        pos += 1;\r\n                        output.push((url + descriptorsStr).trim());\r\n                        break;\r\n                    }\r\n                    else if (c === '(') {\r\n                        inParens = true;\r\n                    }\r\n                }\r\n                else {\r\n                    if (c === ')') {\r\n                        inParens = false;\r\n                    }\r\n                }\r\n                descriptorsStr += c;\r\n                pos += 1;\r\n            }\r\n        }\r\n    }\r\n    return output.join(', ');\r\n}\r\nconst cachedDocument = new WeakMap();\r\nfunction absoluteToDoc(doc, attributeValue) {\r\n    if (!attributeValue || attributeValue.trim() === '') {\r\n        return attributeValue;\r\n    }\r\n    return getHref(doc, attributeValue);\r\n}\r\nfunction isSVGElement(el) {\r\n    return Boolean(el.tagName === 'svg' || el.ownerSVGElement);\r\n}\r\nfunction getHref(doc, customHref) {\r\n    let a = cachedDocument.get(doc);\r\n    if (!a) {\r\n        a = doc.createElement('a');\r\n        cachedDocument.set(doc, a);\r\n    }\r\n    if (!customHref) {\r\n        customHref = '';\r\n    }\r\n    else if (customHref.startsWith('blob:') || customHref.startsWith('data:')) {\r\n        return customHref;\r\n    }\r\n    a.setAttribute('href', customHref);\r\n    return a.href;\r\n}\r\nfunction transformAttribute(doc, tagName, name, value, element, maskAttributeFn) {\r\n    if (!value) {\r\n        return value;\r\n    }\r\n    if (name === 'src' ||\r\n        (name === 'href' && !(tagName === 'use' && value[0] === '#'))) {\r\n        return absoluteToDoc(doc, value);\r\n    }\r\n    else if (name === 'xlink:href' && value[0] !== '#') {\r\n        return absoluteToDoc(doc, value);\r\n    }\r\n    else if (name === 'background' &&\r\n        (tagName === 'table' || tagName === 'td' || tagName === 'th')) {\r\n        return absoluteToDoc(doc, value);\r\n    }\r\n    else if (name === 'srcset') {\r\n        return getAbsoluteSrcsetString(doc, value);\r\n    }\r\n    else if (name === 'style') {\r\n        return absoluteToStylesheet(value, getHref(doc));\r\n    }\r\n    else if (tagName === 'object' && name === 'data') {\r\n        return absoluteToDoc(doc, value);\r\n    }\r\n    if (typeof maskAttributeFn === 'function') {\r\n        return maskAttributeFn(name, value, element);\r\n    }\r\n    return value;\r\n}\r\nfunction ignoreAttribute(tagName, name, _value) {\r\n    return (tagName === 'video' || tagName === 'audio') && name === 'autoplay';\r\n}\r\nfunction _isBlockedElement(element, blockClass, blockSelector, unblockSelector) {\r\n    try {\r\n        if (unblockSelector && element.matches(unblockSelector)) {\r\n            return false;\r\n        }\r\n        if (typeof blockClass === 'string') {\r\n            if (element.classList.contains(blockClass)) {\r\n                return true;\r\n            }\r\n        }\r\n        else {\r\n            for (let eIndex = element.classList.length; eIndex--;) {\r\n                const className = element.classList[eIndex];\r\n                if (blockClass.test(className)) {\r\n                    return true;\r\n                }\r\n            }\r\n        }\r\n        if (blockSelector) {\r\n            return element.matches(blockSelector);\r\n        }\r\n    }\r\n    catch (e) {\r\n    }\r\n    return false;\r\n}\r\nfunction elementClassMatchesRegex(el, regex) {\r\n    for (let eIndex = el.classList.length; eIndex--;) {\r\n        const className = el.classList[eIndex];\r\n        if (regex.test(className)) {\r\n            return true;\r\n        }\r\n    }\r\n    return false;\r\n}\r\nfunction classMatchesRegex(node, regex, checkAncestors) {\r\n    if (!node)\r\n        return false;\r\n    if (checkAncestors) {\r\n        return (distanceToMatch(node, (node) => elementClassMatchesRegex(node, regex)) >= 0);\r\n    }\r\n    else if (node.nodeType === node.ELEMENT_NODE) {\r\n        return elementClassMatchesRegex(node, regex);\r\n    }\r\n    return false;\r\n}\r\nfunction distanceToMatch(node, matchPredicate, limit = Infinity, distance = 0) {\r\n    if (!node)\r\n        return -1;\r\n    if (node.nodeType !== node.ELEMENT_NODE)\r\n        return -1;\r\n    if (distance > limit)\r\n        return -1;\r\n    if (matchPredicate(node))\r\n        return distance;\r\n    return distanceToMatch(node.parentNode, matchPredicate, limit, distance + 1);\r\n}\r\nfunction createMatchPredicate(className, selector) {\r\n    return (node) => {\r\n        const el = node;\r\n        if (el === null)\r\n            return false;\r\n        try {\r\n            if (className) {\r\n                if (typeof className === 'string') {\r\n                    if (el.matches(`.${className}`))\r\n                        return true;\r\n                }\r\n                else if (elementClassMatchesRegex(el, className)) {\r\n                    return true;\r\n                }\r\n            }\r\n            if (selector && el.matches(selector))\r\n                return true;\r\n            return false;\r\n        }\r\n        catch {\r\n            return false;\r\n        }\r\n    };\r\n}\r\nfunction needMaskingText(node, maskTextClass, maskTextSelector, unmaskTextClass, unmaskTextSelector, maskAllText) {\r\n    try {\r\n        const el = node.nodeType === node.ELEMENT_NODE\r\n            ? node\r\n            : node.parentElement;\r\n        if (el === null)\r\n            return false;\r\n        if (el.tagName === 'INPUT') {\r\n            const autocomplete = el.getAttribute('autocomplete');\r\n            const disallowedAutocompleteValues = [\r\n                'current-password',\r\n                'new-password',\r\n                'cc-number',\r\n                'cc-exp',\r\n                'cc-exp-month',\r\n                'cc-exp-year',\r\n                'cc-csc',\r\n            ];\r\n            if (disallowedAutocompleteValues.includes(autocomplete)) {\r\n                return true;\r\n            }\r\n        }\r\n        let maskDistance = -1;\r\n        let unmaskDistance = -1;\r\n        if (maskAllText) {\r\n            unmaskDistance = distanceToMatch(el, createMatchPredicate(unmaskTextClass, unmaskTextSelector));\r\n            if (unmaskDistance < 0) {\r\n                return true;\r\n            }\r\n            maskDistance = distanceToMatch(el, createMatchPredicate(maskTextClass, maskTextSelector), unmaskDistance >= 0 ? unmaskDistance : Infinity);\r\n        }\r\n        else {\r\n            maskDistance = distanceToMatch(el, createMatchPredicate(maskTextClass, maskTextSelector));\r\n            if (maskDistance < 0) {\r\n                return false;\r\n            }\r\n            unmaskDistance = distanceToMatch(el, createMatchPredicate(unmaskTextClass, unmaskTextSelector), maskDistance >= 0 ? maskDistance : Infinity);\r\n        }\r\n        return maskDistance >= 0\r\n            ? unmaskDistance >= 0\r\n                ? maskDistance <= unmaskDistance\r\n                : true\r\n            : unmaskDistance >= 0\r\n                ? false\r\n                : !!maskAllText;\r\n    }\r\n    catch (e) {\r\n    }\r\n    return !!maskAllText;\r\n}\r\nfunction onceIframeLoaded(iframeEl, listener, iframeLoadTimeout) {\r\n    const win = iframeEl.contentWindow;\r\n    if (!win) {\r\n        return;\r\n    }\r\n    let fired = false;\r\n    let readyState;\r\n    try {\r\n        readyState = win.document.readyState;\r\n    }\r\n    catch (error) {\r\n        return;\r\n    }\r\n    if (readyState !== 'complete') {\r\n        const timer = setTimeout(() => {\r\n            if (!fired) {\r\n                listener();\r\n                fired = true;\r\n            }\r\n        }, iframeLoadTimeout);\r\n        iframeEl.addEventListener('load', () => {\r\n            clearTimeout(timer);\r\n            fired = true;\r\n            listener();\r\n        });\r\n        return;\r\n    }\r\n    const blankUrl = 'about:blank';\r\n    if (win.location.href !== blankUrl ||\r\n        iframeEl.src === blankUrl ||\r\n        iframeEl.src === '') {\r\n        setTimeout(listener, 0);\r\n        return iframeEl.addEventListener('load', listener);\r\n    }\r\n    iframeEl.addEventListener('load', listener);\r\n}\r\nfunction onceStylesheetLoaded(link, listener, styleSheetLoadTimeout) {\r\n    let fired = false;\r\n    let styleSheetLoaded;\r\n    try {\r\n        styleSheetLoaded = link.sheet;\r\n    }\r\n    catch (error) {\r\n        return;\r\n    }\r\n    if (styleSheetLoaded)\r\n        return;\r\n    const timer = setTimeout(() => {\r\n        if (!fired) {\r\n            listener();\r\n            fired = true;\r\n        }\r\n    }, styleSheetLoadTimeout);\r\n    link.addEventListener('load', () => {\r\n        clearTimeout(timer);\r\n        fired = true;\r\n        listener();\r\n    });\r\n}\r\nfunction serializeNode(n, options) {\r\n    const { doc, mirror, blockClass, blockSelector, unblockSelector, maskAllText, maskAttributeFn, maskTextClass, unmaskTextClass, maskTextSelector, unmaskTextSelector, inlineStylesheet, maskInputOptions = {}, maskTextFn, maskInputFn, dataURLOptions = {}, inlineImages, recordCanvas, keepIframeSrcFn, newlyAddedElement = false, } = options;\r\n    const rootId = getRootId(doc, mirror);\r\n    switch (n.nodeType) {\r\n        case n.DOCUMENT_NODE:\r\n            if (n.compatMode !== 'CSS1Compat') {\r\n                return {\r\n                    type: NodeType.Document,\r\n                    childNodes: [],\r\n                    compatMode: n.compatMode,\r\n                };\r\n            }\r\n            else {\r\n                return {\r\n                    type: NodeType.Document,\r\n                    childNodes: [],\r\n                };\r\n            }\r\n        case n.DOCUMENT_TYPE_NODE:\r\n            return {\r\n                type: NodeType.DocumentType,\r\n                name: n.name,\r\n                publicId: n.publicId,\r\n                systemId: n.systemId,\r\n                rootId,\r\n            };\r\n        case n.ELEMENT_NODE:\r\n            return serializeElementNode(n, {\r\n                doc,\r\n                blockClass,\r\n                blockSelector,\r\n                unblockSelector,\r\n                inlineStylesheet,\r\n                maskAttributeFn,\r\n                maskInputOptions,\r\n                maskInputFn,\r\n                dataURLOptions,\r\n                inlineImages,\r\n                recordCanvas,\r\n                keepIframeSrcFn,\r\n                newlyAddedElement,\r\n                rootId,\r\n                maskAllText,\r\n                maskTextClass,\r\n                unmaskTextClass,\r\n                maskTextSelector,\r\n                unmaskTextSelector,\r\n            });\r\n        case n.TEXT_NODE:\r\n            return serializeTextNode(n, {\r\n                doc,\r\n                maskAllText,\r\n                maskTextClass,\r\n                unmaskTextClass,\r\n                maskTextSelector,\r\n                unmaskTextSelector,\r\n                maskTextFn,\r\n                maskInputOptions,\r\n                maskInputFn,\r\n                rootId,\r\n            });\r\n        case n.CDATA_SECTION_NODE:\r\n            return {\r\n                type: NodeType.CDATA,\r\n                textContent: '',\r\n                rootId,\r\n            };\r\n        case n.COMMENT_NODE:\r\n            return {\r\n                type: NodeType.Comment,\r\n                textContent: n.textContent || '',\r\n                rootId,\r\n            };\r\n        default:\r\n            return false;\r\n    }\r\n}\r\nfunction getRootId(doc, mirror) {\r\n    if (!mirror.hasNode(doc))\r\n        return undefined;\r\n    const docId = mirror.getId(doc);\r\n    return docId === 1 ? undefined : docId;\r\n}\r\nfunction serializeTextNode(n, options) {\r\n    const { maskAllText, maskTextClass, unmaskTextClass, maskTextSelector, unmaskTextSelector, maskTextFn, maskInputOptions, maskInputFn, rootId, } = options;\r\n    const parentTagName = n.parentNode && n.parentNode.tagName;\r\n    let textContent = n.textContent;\r\n    const isStyle = parentTagName === 'STYLE' ? true : undefined;\r\n    const isScript = parentTagName === 'SCRIPT' ? true : undefined;\r\n    const isTextarea = parentTagName === 'TEXTAREA' ? true : undefined;\r\n    if (isStyle && textContent) {\r\n        try {\r\n            if (n.nextSibling || n.previousSibling) {\r\n            }\r\n            else if (n.parentNode.sheet?.cssRules) {\r\n                textContent = stringifyStylesheet(n.parentNode.sheet);\r\n            }\r\n        }\r\n        catch (err) {\r\n            console.warn(`Cannot get CSS styles from text's parentNode. Error: ${err}`, n);\r\n        }\r\n        textContent = absoluteToStylesheet(textContent, getHref(options.doc));\r\n    }\r\n    if (isScript) {\r\n        textContent = 'SCRIPT_PLACEHOLDER';\r\n    }\r\n    const forceMask = needMaskingText(n, maskTextClass, maskTextSelector, unmaskTextClass, unmaskTextSelector, maskAllText);\r\n    if (!isStyle && !isScript && !isTextarea && textContent && forceMask) {\r\n        textContent = maskTextFn\r\n            ? maskTextFn(textContent, n.parentElement)\r\n            : textContent.replace(/[\\S]/g, '*');\r\n    }\r\n    if (isTextarea && textContent && (maskInputOptions.textarea || forceMask)) {\r\n        textContent = maskInputFn\r\n            ? maskInputFn(textContent, n.parentNode)\r\n            : textContent.replace(/[\\S]/g, '*');\r\n    }\r\n    if (parentTagName === 'OPTION' && textContent) {\r\n        const isInputMasked = shouldMaskInput({\r\n            type: null,\r\n            tagName: parentTagName,\r\n            maskInputOptions,\r\n        });\r\n        textContent = maskInputValue({\r\n            isMasked: needMaskingText(n, maskTextClass, maskTextSelector, unmaskTextClass, unmaskTextSelector, isInputMasked),\r\n            element: n,\r\n            value: textContent,\r\n            maskInputFn,\r\n        });\r\n    }\r\n    return {\r\n        type: NodeType.Text,\r\n        textContent: textContent || '',\r\n        isStyle,\r\n        rootId,\r\n    };\r\n}\r\nfunction serializeElementNode(n, options) {\r\n    const { doc, blockClass, blockSelector, unblockSelector, inlineStylesheet, maskInputOptions = {}, maskAttributeFn, maskInputFn, dataURLOptions = {}, inlineImages, recordCanvas, keepIframeSrcFn, newlyAddedElement = false, rootId, maskAllText, maskTextClass, unmaskTextClass, maskTextSelector, unmaskTextSelector, } = options;\r\n    const needBlock = _isBlockedElement(n, blockClass, blockSelector, unblockSelector);\r\n    const tagName = getValidTagName(n);\r\n    let attributes = {};\r\n    const len = n.attributes.length;\r\n    for (let i = 0; i < len; i++) {\r\n        const attr = n.attributes[i];\r\n        if (attr.name && !ignoreAttribute(tagName, attr.name, attr.value)) {\r\n            attributes[attr.name] = transformAttribute(doc, tagName, toLowerCase(attr.name), attr.value, n, maskAttributeFn);\r\n        }\r\n    }\r\n    if (tagName === 'link' && inlineStylesheet) {\r\n        const stylesheet = Array.from(doc.styleSheets).find((s) => {\r\n            return s.href === n.href;\r\n        });\r\n        let cssText = null;\r\n        if (stylesheet) {\r\n            cssText = stringifyStylesheet(stylesheet);\r\n        }\r\n        if (cssText) {\r\n            attributes.rel = null;\r\n            attributes.href = null;\r\n            attributes.crossorigin = null;\r\n            attributes._cssText = absoluteToStylesheet(cssText, stylesheet.href);\r\n        }\r\n    }\r\n    if (tagName === 'style' &&\r\n        n.sheet &&\r\n        !(n.innerText || n.textContent || '').trim().length) {\r\n        const cssText = stringifyStylesheet(n.sheet);\r\n        if (cssText) {\r\n            attributes._cssText = absoluteToStylesheet(cssText, getHref(doc));\r\n        }\r\n    }\r\n    if (tagName === 'input' ||\r\n        tagName === 'textarea' ||\r\n        tagName === 'select' ||\r\n        tagName === 'option') {\r\n        const el = n;\r\n        const type = getInputType(el);\r\n        const value = getInputValue(el, toUpperCase(tagName), type);\r\n        const checked = el.checked;\r\n        if (type !== 'submit' && type !== 'button' && value) {\r\n            const forceMask = needMaskingText(el, maskTextClass, maskTextSelector, unmaskTextClass, unmaskTextSelector, shouldMaskInput({\r\n                type,\r\n                tagName: toUpperCase(tagName),\r\n                maskInputOptions,\r\n            }));\r\n            attributes.value = maskInputValue({\r\n                isMasked: forceMask,\r\n                element: el,\r\n                value,\r\n                maskInputFn,\r\n            });\r\n        }\r\n        if (checked) {\r\n            attributes.checked = checked;\r\n        }\r\n    }\r\n    if (tagName === 'option') {\r\n        if (n.selected && !maskInputOptions['select']) {\r\n            attributes.selected = true;\r\n        }\r\n        else {\r\n            delete attributes.selected;\r\n        }\r\n    }\r\n    if (tagName === 'canvas' && recordCanvas) {\r\n        if (n.__context === '2d') {\r\n            if (!is2DCanvasBlank(n)) {\r\n                attributes.rr_dataURL = n.toDataURL(dataURLOptions.type, dataURLOptions.quality);\r\n            }\r\n        }\r\n        else if (!('__context' in n)) {\r\n            const canvasDataURL = n.toDataURL(dataURLOptions.type, dataURLOptions.quality);\r\n            const blankCanvas = doc.createElement('canvas');\r\n            blankCanvas.width = n.width;\r\n            blankCanvas.height = n.height;\r\n            const blankCanvasDataURL = blankCanvas.toDataURL(dataURLOptions.type, dataURLOptions.quality);\r\n            if (canvasDataURL !== blankCanvasDataURL) {\r\n                attributes.rr_dataURL = canvasDataURL;\r\n            }\r\n        }\r\n    }\r\n    if (tagName === 'img' && inlineImages) {\r\n        if (!canvasService) {\r\n            canvasService = doc.createElement('canvas');\r\n            canvasCtx = canvasService.getContext('2d');\r\n        }\r\n        const image = n;\r\n        const imageSrc = image.currentSrc || image.getAttribute('src') || '<unknown-src>';\r\n        const priorCrossOrigin = image.crossOrigin;\r\n        const recordInlineImage = () => {\r\n            image.removeEventListener('load', recordInlineImage);\r\n            try {\r\n                canvasService.width = image.naturalWidth;\r\n                canvasService.height = image.naturalHeight;\r\n                canvasCtx.drawImage(image, 0, 0);\r\n                attributes.rr_dataURL = canvasService.toDataURL(dataURLOptions.type, dataURLOptions.quality);\r\n            }\r\n            catch (err) {\r\n                if (image.crossOrigin !== 'anonymous') {\r\n                    image.crossOrigin = 'anonymous';\r\n                    if (image.complete && image.naturalWidth !== 0)\r\n                        recordInlineImage();\r\n                    else\r\n                        image.addEventListener('load', recordInlineImage);\r\n                    return;\r\n                }\r\n                else {\r\n                    console.warn(`Cannot inline img src=${imageSrc}! Error: ${err}`);\r\n                }\r\n            }\r\n            if (image.crossOrigin === 'anonymous') {\r\n                priorCrossOrigin\r\n                    ? (attributes.crossOrigin = priorCrossOrigin)\r\n                    : image.removeAttribute('crossorigin');\r\n            }\r\n        };\r\n        if (image.complete && image.naturalWidth !== 0)\r\n            recordInlineImage();\r\n        else\r\n            image.addEventListener('load', recordInlineImage);\r\n    }\r\n    if (tagName === 'audio' || tagName === 'video') {\r\n        attributes.rr_mediaState = n.paused\r\n            ? 'paused'\r\n            : 'played';\r\n        attributes.rr_mediaCurrentTime = n.currentTime;\r\n    }\r\n    if (!newlyAddedElement) {\r\n        if (n.scrollLeft) {\r\n            attributes.rr_scrollLeft = n.scrollLeft;\r\n        }\r\n        if (n.scrollTop) {\r\n            attributes.rr_scrollTop = n.scrollTop;\r\n        }\r\n    }\r\n    if (needBlock) {\r\n        const { width, height } = n.getBoundingClientRect();\r\n        attributes = {\r\n            class: attributes.class,\r\n            rr_width: `${width}px`,\r\n            rr_height: `${height}px`,\r\n        };\r\n    }\r\n    if (tagName === 'iframe' && !keepIframeSrcFn(attributes.src)) {\r\n        if (!needBlock && !getIframeContentDocument(n)) {\r\n            attributes.rr_src = attributes.src;\r\n        }\r\n        delete attributes.src;\r\n    }\r\n    let isCustomElement;\r\n    try {\r\n        if (customElements.get(tagName))\r\n            isCustomElement = true;\r\n    }\r\n    catch (e) {\r\n    }\r\n    return {\r\n        type: NodeType.Element,\r\n        tagName,\r\n        attributes,\r\n        childNodes: [],\r\n        isSVG: isSVGElement(n) || undefined,\r\n        needBlock,\r\n        rootId,\r\n        isCustom: isCustomElement,\r\n    };\r\n}\r\nfunction lowerIfExists(maybeAttr) {\r\n    if (maybeAttr === undefined || maybeAttr === null) {\r\n        return '';\r\n    }\r\n    else {\r\n        return maybeAttr.toLowerCase();\r\n    }\r\n}\r\nfunction slimDOMExcluded(sn, slimDOMOptions) {\r\n    if (slimDOMOptions.comment && sn.type === NodeType.Comment) {\r\n        return true;\r\n    }\r\n    else if (sn.type === NodeType.Element) {\r\n        if (slimDOMOptions.script &&\r\n            (sn.tagName === 'script' ||\r\n                (sn.tagName === 'link' &&\r\n                    (sn.attributes.rel === 'preload' ||\r\n                        sn.attributes.rel === 'modulepreload')) ||\r\n                (sn.tagName === 'link' &&\r\n                    sn.attributes.rel === 'prefetch' &&\r\n                    typeof sn.attributes.href === 'string' &&\r\n                    extractFileExtension(sn.attributes.href) === 'js'))) {\r\n            return true;\r\n        }\r\n        else if (slimDOMOptions.headFavicon &&\r\n            ((sn.tagName === 'link' && sn.attributes.rel === 'shortcut icon') ||\r\n                (sn.tagName === 'meta' &&\r\n                    (lowerIfExists(sn.attributes.name).match(/^msapplication-tile(image|color)$/) ||\r\n                        lowerIfExists(sn.attributes.name) === 'application-name' ||\r\n                        lowerIfExists(sn.attributes.rel) === 'icon' ||\r\n                        lowerIfExists(sn.attributes.rel) === 'apple-touch-icon' ||\r\n                        lowerIfExists(sn.attributes.rel) === 'shortcut icon')))) {\r\n            return true;\r\n        }\r\n        else if (sn.tagName === 'meta') {\r\n            if (slimDOMOptions.headMetaDescKeywords &&\r\n                lowerIfExists(sn.attributes.name).match(/^description|keywords$/)) {\r\n                return true;\r\n            }\r\n            else if (slimDOMOptions.headMetaSocial &&\r\n                (lowerIfExists(sn.attributes.property).match(/^(og|twitter|fb):/) ||\r\n                    lowerIfExists(sn.attributes.name).match(/^(og|twitter):/) ||\r\n                    lowerIfExists(sn.attributes.name) === 'pinterest')) {\r\n                return true;\r\n            }\r\n            else if (slimDOMOptions.headMetaRobots &&\r\n                (lowerIfExists(sn.attributes.name) === 'robots' ||\r\n                    lowerIfExists(sn.attributes.name) === 'googlebot' ||\r\n                    lowerIfExists(sn.attributes.name) === 'bingbot')) {\r\n                return true;\r\n            }\r\n            else if (slimDOMOptions.headMetaHttpEquiv &&\r\n                sn.attributes['http-equiv'] !== undefined) {\r\n                return true;\r\n            }\r\n            else if (slimDOMOptions.headMetaAuthorship &&\r\n                (lowerIfExists(sn.attributes.name) === 'author' ||\r\n                    lowerIfExists(sn.attributes.name) === 'generator' ||\r\n                    lowerIfExists(sn.attributes.name) === 'framework' ||\r\n                    lowerIfExists(sn.attributes.name) === 'publisher' ||\r\n                    lowerIfExists(sn.attributes.name) === 'progid' ||\r\n                    lowerIfExists(sn.attributes.property).match(/^article:/) ||\r\n                    lowerIfExists(sn.attributes.property).match(/^product:/))) {\r\n                return true;\r\n            }\r\n            else if (slimDOMOptions.headMetaVerification &&\r\n                (lowerIfExists(sn.attributes.name) === 'google-site-verification' ||\r\n                    lowerIfExists(sn.attributes.name) === 'yandex-verification' ||\r\n                    lowerIfExists(sn.attributes.name) === 'csrf-token' ||\r\n                    lowerIfExists(sn.attributes.name) === 'p:domain_verify' ||\r\n                    lowerIfExists(sn.attributes.name) === 'verify-v1' ||\r\n                    lowerIfExists(sn.attributes.name) === 'verification' ||\r\n                    lowerIfExists(sn.attributes.name) === 'shopify-checkout-api-token')) {\r\n                return true;\r\n            }\r\n        }\r\n    }\r\n    return false;\r\n}\r\nfunction serializeNodeWithId(n, options) {\r\n    const { doc, mirror, blockClass, blockSelector, unblockSelector, maskAllText, maskTextClass, unmaskTextClass, maskTextSelector, unmaskTextSelector, skipChild = false, inlineStylesheet = true, maskInputOptions = {}, maskAttributeFn, maskTextFn, maskInputFn, slimDOMOptions, dataURLOptions = {}, inlineImages = false, recordCanvas = false, onSerialize, onIframeLoad, iframeLoadTimeout = 5000, onStylesheetLoad, stylesheetLoadTimeout = 5000, keepIframeSrcFn = () => false, newlyAddedElement = false, } = options;\r\n    let { preserveWhiteSpace = true } = options;\r\n    const _serializedNode = serializeNode(n, {\r\n        doc,\r\n        mirror,\r\n        blockClass,\r\n        blockSelector,\r\n        maskAllText,\r\n        unblockSelector,\r\n        maskTextClass,\r\n        unmaskTextClass,\r\n        maskTextSelector,\r\n        unmaskTextSelector,\r\n        inlineStylesheet,\r\n        maskInputOptions,\r\n        maskAttributeFn,\r\n        maskTextFn,\r\n        maskInputFn,\r\n        dataURLOptions,\r\n        inlineImages,\r\n        recordCanvas,\r\n        keepIframeSrcFn,\r\n        newlyAddedElement,\r\n    });\r\n    if (!_serializedNode) {\r\n        console.warn(n, 'not serialized');\r\n        return null;\r\n    }\r\n    let id;\r\n    if (mirror.hasNode(n)) {\r\n        id = mirror.getId(n);\r\n    }\r\n    else if (slimDOMExcluded(_serializedNode, slimDOMOptions) ||\r\n        (!preserveWhiteSpace &&\r\n            _serializedNode.type === NodeType.Text &&\r\n            !_serializedNode.isStyle &&\r\n            !_serializedNode.textContent.replace(/^\\s+|\\s+$/gm, '').length)) {\r\n        id = IGNORED_NODE;\r\n    }\r\n    else {\r\n        id = genId();\r\n    }\r\n    const serializedNode = Object.assign(_serializedNode, { id });\r\n    mirror.add(n, serializedNode);\r\n    if (id === IGNORED_NODE) {\r\n        return null;\r\n    }\r\n    if (onSerialize) {\r\n        onSerialize(n);\r\n    }\r\n    let recordChild = !skipChild;\r\n    if (serializedNode.type === NodeType.Element) {\r\n        recordChild = recordChild && !serializedNode.needBlock;\r\n        delete serializedNode.needBlock;\r\n        const shadowRoot = n.shadowRoot;\r\n        if (shadowRoot && isNativeShadowDom(shadowRoot))\r\n            serializedNode.isShadowHost = true;\r\n    }\r\n    if ((serializedNode.type === NodeType.Document ||\r\n        serializedNode.type === NodeType.Element) &&\r\n        recordChild) {\r\n        if (slimDOMOptions.headWhitespace &&\r\n            serializedNode.type === NodeType.Element &&\r\n            serializedNode.tagName === 'head') {\r\n            preserveWhiteSpace = false;\r\n        }\r\n        const bypassOptions = {\r\n            doc,\r\n            mirror,\r\n            blockClass,\r\n            blockSelector,\r\n            maskAllText,\r\n            unblockSelector,\r\n            maskTextClass,\r\n            unmaskTextClass,\r\n            maskTextSelector,\r\n            unmaskTextSelector,\r\n            skipChild,\r\n            inlineStylesheet,\r\n            maskInputOptions,\r\n            maskAttributeFn,\r\n            maskTextFn,\r\n            maskInputFn,\r\n            slimDOMOptions,\r\n            dataURLOptions,\r\n            inlineImages,\r\n            recordCanvas,\r\n            preserveWhiteSpace,\r\n            onSerialize,\r\n            onIframeLoad,\r\n            iframeLoadTimeout,\r\n            onStylesheetLoad,\r\n            stylesheetLoadTimeout,\r\n            keepIframeSrcFn,\r\n        };\r\n        for (const childN of Array.from(n.childNodes)) {\r\n            const serializedChildNode = serializeNodeWithId(childN, bypassOptions);\r\n            if (serializedChildNode) {\r\n                serializedNode.childNodes.push(serializedChildNode);\r\n            }\r\n        }\r\n        if (isElement(n) && n.shadowRoot) {\r\n            for (const childN of Array.from(n.shadowRoot.childNodes)) {\r\n                const serializedChildNode = serializeNodeWithId(childN, bypassOptions);\r\n                if (serializedChildNode) {\r\n                    isNativeShadowDom(n.shadowRoot) &&\r\n                        (serializedChildNode.isShadow = true);\r\n                    serializedNode.childNodes.push(serializedChildNode);\r\n                }\r\n            }\r\n        }\r\n    }\r\n    if (n.parentNode &&\r\n        isShadowRoot(n.parentNode) &&\r\n        isNativeShadowDom(n.parentNode)) {\r\n        serializedNode.isShadow = true;\r\n    }\r\n    if (serializedNode.type === NodeType.Element &&\r\n        serializedNode.tagName === 'iframe') {\r\n        onceIframeLoaded(n, () => {\r\n            const iframeDoc = getIframeContentDocument(n);\r\n            if (iframeDoc && onIframeLoad) {\r\n                const serializedIframeNode = serializeNodeWithId(iframeDoc, {\r\n                    doc: iframeDoc,\r\n                    mirror,\r\n                    blockClass,\r\n                    blockSelector,\r\n                    unblockSelector,\r\n                    maskAllText,\r\n                    maskTextClass,\r\n                    unmaskTextClass,\r\n                    maskTextSelector,\r\n                    unmaskTextSelector,\r\n                    skipChild: false,\r\n                    inlineStylesheet,\r\n                    maskInputOptions,\r\n                    maskAttributeFn,\r\n                    maskTextFn,\r\n                    maskInputFn,\r\n                    slimDOMOptions,\r\n                    dataURLOptions,\r\n                    inlineImages,\r\n                    recordCanvas,\r\n                    preserveWhiteSpace,\r\n                    onSerialize,\r\n                    onIframeLoad,\r\n                    iframeLoadTimeout,\r\n                    onStylesheetLoad,\r\n                    stylesheetLoadTimeout,\r\n                    keepIframeSrcFn,\r\n                });\r\n                if (serializedIframeNode) {\r\n                    onIframeLoad(n, serializedIframeNode);\r\n                }\r\n            }\r\n        }, iframeLoadTimeout);\r\n    }\r\n    if (serializedNode.type === NodeType.Element &&\r\n        serializedNode.tagName === 'link' &&\r\n        typeof serializedNode.attributes.rel === 'string' &&\r\n        (serializedNode.attributes.rel === 'stylesheet' ||\r\n            (serializedNode.attributes.rel === 'preload' &&\r\n                typeof serializedNode.attributes.href === 'string' &&\r\n                extractFileExtension(serializedNode.attributes.href) === 'css'))) {\r\n        onceStylesheetLoaded(n, () => {\r\n            if (onStylesheetLoad) {\r\n                const serializedLinkNode = serializeNodeWithId(n, {\r\n                    doc,\r\n                    mirror,\r\n                    blockClass,\r\n                    blockSelector,\r\n                    unblockSelector,\r\n                    maskAllText,\r\n                    maskTextClass,\r\n                    unmaskTextClass,\r\n                    maskTextSelector,\r\n                    unmaskTextSelector,\r\n                    skipChild: false,\r\n                    inlineStylesheet,\r\n                    maskInputOptions,\r\n                    maskAttributeFn,\r\n                    maskTextFn,\r\n                    maskInputFn,\r\n                    slimDOMOptions,\r\n                    dataURLOptions,\r\n                    inlineImages,\r\n                    recordCanvas,\r\n                    preserveWhiteSpace,\r\n                    onSerialize,\r\n                    onIframeLoad,\r\n                    iframeLoadTimeout,\r\n                    onStylesheetLoad,\r\n                    stylesheetLoadTimeout,\r\n                    keepIframeSrcFn,\r\n                });\r\n                if (serializedLinkNode) {\r\n                    onStylesheetLoad(n, serializedLinkNode);\r\n                }\r\n            }\r\n        }, stylesheetLoadTimeout);\r\n    }\r\n    return serializedNode;\r\n}\r\nfunction snapshot(n, options) {\r\n    const { mirror = new Mirror(), blockClass = 'rr-block', blockSelector = null, unblockSelector = null, maskAllText = false, maskTextClass = 'rr-mask', unmaskTextClass = null, maskTextSelector = null, unmaskTextSelector = null, inlineStylesheet = true, inlineImages = false, recordCanvas = false, maskAllInputs = false, maskAttributeFn, maskTextFn, maskInputFn, slimDOM = false, dataURLOptions, preserveWhiteSpace, onSerialize, onIframeLoad, iframeLoadTimeout, onStylesheetLoad, stylesheetLoadTimeout, keepIframeSrcFn = () => false, } = options || {};\r\n    const maskInputOptions = maskAllInputs === true\r\n        ? {\r\n            color: true,\r\n            date: true,\r\n            'datetime-local': true,\r\n            email: true,\r\n            month: true,\r\n            number: true,\r\n            range: true,\r\n            search: true,\r\n            tel: true,\r\n            text: true,\r\n            time: true,\r\n            url: true,\r\n            week: true,\r\n            textarea: true,\r\n            select: true,\r\n        }\r\n        : maskAllInputs === false\r\n            ? {}\r\n            : maskAllInputs;\r\n    const slimDOMOptions = slimDOM === true || slimDOM === 'all'\r\n        ?\r\n            {\r\n                script: true,\r\n                comment: true,\r\n                headFavicon: true,\r\n                headWhitespace: true,\r\n                headMetaDescKeywords: slimDOM === 'all',\r\n                headMetaSocial: true,\r\n                headMetaRobots: true,\r\n                headMetaHttpEquiv: true,\r\n                headMetaAuthorship: true,\r\n                headMetaVerification: true,\r\n            }\r\n        : slimDOM === false\r\n            ? {}\r\n            : slimDOM;\r\n    return serializeNodeWithId(n, {\r\n        doc: n,\r\n        mirror,\r\n        blockClass,\r\n        blockSelector,\r\n        unblockSelector,\r\n        maskAllText,\r\n        maskTextClass,\r\n        unmaskTextClass,\r\n        maskTextSelector,\r\n        unmaskTextSelector,\r\n        skipChild: false,\r\n        inlineStylesheet,\r\n        maskInputOptions,\r\n        maskAttributeFn,\r\n        maskTextFn,\r\n        maskInputFn,\r\n        slimDOMOptions,\r\n        dataURLOptions,\r\n        inlineImages,\r\n        recordCanvas,\r\n        preserveWhiteSpace,\r\n        onSerialize,\r\n        onIframeLoad,\r\n        iframeLoadTimeout,\r\n        onStylesheetLoad,\r\n        stylesheetLoadTimeout,\r\n        keepIframeSrcFn,\r\n        newlyAddedElement: false,\r\n    });\r\n}\r\nfunction visitSnapshot(node, onVisit) {\r\n    function walk(current) {\r\n        onVisit(current);\r\n        if (current.type === NodeType.Document ||\r\n            current.type === NodeType.Element) {\r\n            current.childNodes.forEach(walk);\r\n        }\r\n    }\r\n    walk(node);\r\n}\r\nfunction cleanupSnapshot() {\r\n    _id = 1;\r\n}\n\nconst commentre = /\\/\\*[^*]*\\*+([^/*][^*]*\\*+)*\\//g;\r\nfunction parse(css, options = {}) {\r\n    let lineno = 1;\r\n    let column = 1;\r\n    function updatePosition(str) {\r\n        const lines = str.match(/\\n/g);\r\n        if (lines) {\r\n            lineno += lines.length;\r\n        }\r\n        const i = str.lastIndexOf('\\n');\r\n        column = i === -1 ? column + str.length : str.length - i;\r\n    }\r\n    function position() {\r\n        const start = { line: lineno, column };\r\n        return (node) => {\r\n            node.position = new Position(start);\r\n            whitespace();\r\n            return node;\r\n        };\r\n    }\r\n    class Position {\r\n        constructor(start) {\r\n            this.start = start;\r\n            this.end = { line: lineno, column };\r\n            this.source = options.source;\r\n        }\r\n    }\r\n    Position.prototype.content = css;\r\n    const errorsList = [];\r\n    function error(msg) {\r\n        const err = new Error(`${options.source || ''}:${lineno}:${column}: ${msg}`);\r\n        err.reason = msg;\r\n        err.filename = options.source;\r\n        err.line = lineno;\r\n        err.column = column;\r\n        err.source = css;\r\n        if (options.silent) {\r\n            errorsList.push(err);\r\n        }\r\n        else {\r\n            throw err;\r\n        }\r\n    }\r\n    function stylesheet() {\r\n        const rulesList = rules();\r\n        return {\r\n            type: 'stylesheet',\r\n            stylesheet: {\r\n                source: options.source,\r\n                rules: rulesList,\r\n                parsingErrors: errorsList,\r\n            },\r\n        };\r\n    }\r\n    function open() {\r\n        return match(/^{\\s*/);\r\n    }\r\n    function close() {\r\n        return match(/^}/);\r\n    }\r\n    function rules() {\r\n        let node;\r\n        const rules = [];\r\n        whitespace();\r\n        comments(rules);\r\n        while (css.length && css.charAt(0) !== '}' && (node = atrule() || rule())) {\r\n            if (node) {\r\n                rules.push(node);\r\n                comments(rules);\r\n            }\r\n        }\r\n        return rules;\r\n    }\r\n    function match(re) {\r\n        const m = re.exec(css);\r\n        if (!m) {\r\n            return;\r\n        }\r\n        const str = m[0];\r\n        updatePosition(str);\r\n        css = css.slice(str.length);\r\n        return m;\r\n    }\r\n    function whitespace() {\r\n        match(/^\\s*/);\r\n    }\r\n    function comments(rules = []) {\r\n        let c;\r\n        while ((c = comment())) {\r\n            if (c) {\r\n                rules.push(c);\r\n            }\r\n            c = comment();\r\n        }\r\n        return rules;\r\n    }\r\n    function comment() {\r\n        const pos = position();\r\n        if ('/' !== css.charAt(0) || '*' !== css.charAt(1)) {\r\n            return;\r\n        }\r\n        let i = 2;\r\n        while ('' !== css.charAt(i) &&\r\n            ('*' !== css.charAt(i) || '/' !== css.charAt(i + 1))) {\r\n            ++i;\r\n        }\r\n        i += 2;\r\n        if ('' === css.charAt(i - 1)) {\r\n            return error('End of comment missing');\r\n        }\r\n        const str = css.slice(2, i - 2);\r\n        column += 2;\r\n        updatePosition(str);\r\n        css = css.slice(i);\r\n        column += 2;\r\n        return pos({\r\n            type: 'comment',\r\n            comment: str,\r\n        });\r\n    }\r\n    function selector() {\r\n        const m = match(/^([^{]+)/);\r\n        if (!m) {\r\n            return;\r\n        }\r\n        const splitSelectors = trim(m[0])\r\n            .replace(/\\/\\*([^*]|[\\r\\n]|(\\*+([^*/]|[\\r\\n])))*\\*\\/+/g, '')\r\n            .replace(/\"(?:\\\\\"|[^\"])*\"|'(?:\\\\'|[^'])*'/g, (m) => {\r\n            return m.replace(/,/g, '\\u200C');\r\n        })\r\n            .split(/\\s*(?![^(]*\\)),\\s*/);\r\n        if (splitSelectors.length <= 1) {\r\n            return splitSelectors.map((s) => {\r\n                return s.replace(/\\u200C/g, ',');\r\n            });\r\n        }\r\n        let i = 0;\r\n        let j = 0;\r\n        const len = splitSelectors.length;\r\n        const finalSelectors = [];\r\n        while (i < len) {\r\n            const openingParensCount = (splitSelectors[i].match(/\\(/g) || []).length;\r\n            const closingParensCount = (splitSelectors[i].match(/\\)/g) || []).length;\r\n            let unbalancedParens = openingParensCount - closingParensCount;\r\n            if (unbalancedParens >= 1) {\r\n                let foundClosingSelector = false;\r\n                j = i + 1;\r\n                while (j < len) {\r\n                    const nextOpeningParensCount = (splitSelectors[j].match(/\\(/g) || [])\r\n                        .length;\r\n                    const nextClosingParensCount = (splitSelectors[j].match(/\\)/g) || [])\r\n                        .length;\r\n                    const nextUnbalancedParens = nextClosingParensCount - nextOpeningParensCount;\r\n                    if (nextUnbalancedParens === unbalancedParens) {\r\n                        finalSelectors.push(splitSelectors.slice(i, j + 1).join(','));\r\n                        i = j + 1;\r\n                        foundClosingSelector = true;\r\n                        break;\r\n                    }\r\n                    j++;\r\n                    unbalancedParens -= nextUnbalancedParens;\r\n                }\r\n                if (foundClosingSelector) {\r\n                    continue;\r\n                }\r\n                splitSelectors\r\n                    .slice(i, len)\r\n                    .forEach((selector) => selector && finalSelectors.push(selector));\r\n                break;\r\n            }\r\n            splitSelectors[i] && finalSelectors.push(splitSelectors[i]);\r\n            i++;\r\n        }\r\n        return finalSelectors.map((s) => {\r\n            return s.replace(/\\u200C/g, ',');\r\n        });\r\n    }\r\n    function declaration() {\r\n        const pos = position();\r\n        const propMatch = match(/^(\\*?[-#\\/\\*\\\\\\w]+(\\[[0-9a-z_-]+\\])?)\\s*/);\r\n        if (!propMatch) {\r\n            return;\r\n        }\r\n        const prop = trim(propMatch[0]);\r\n        if (!match(/^:\\s*/)) {\r\n            return error(`property missing ':'`);\r\n        }\r\n        const val = match(/^((?:'(?:\\\\'|.)*?'|\"(?:\\\\\"|.)*?\"|\\([^\\)]*?\\)|[^};])+)/);\r\n        const ret = pos({\r\n            type: 'declaration',\r\n            property: prop.replace(commentre, ''),\r\n            value: val ? trim(val[0]).replace(commentre, '') : '',\r\n        });\r\n        match(/^[;\\s]*/);\r\n        return ret;\r\n    }\r\n    function declarations() {\r\n        const decls = [];\r\n        if (!open()) {\r\n            return error(`missing '{'`);\r\n        }\r\n        comments(decls);\r\n        let decl;\r\n        while ((decl = declaration())) {\r\n            if (decl !== false) {\r\n                decls.push(decl);\r\n                comments(decls);\r\n            }\r\n            decl = declaration();\r\n        }\r\n        if (!close()) {\r\n            return error(`missing '}'`);\r\n        }\r\n        return decls;\r\n    }\r\n    function keyframe() {\r\n        let m;\r\n        const vals = [];\r\n        const pos = position();\r\n        while ((m = match(/^((\\d+\\.\\d+|\\.\\d+|\\d+)%?|[a-z]+)\\s*/))) {\r\n            vals.push(m[1]);\r\n            match(/^,\\s*/);\r\n        }\r\n        if (!vals.length) {\r\n            return;\r\n        }\r\n        return pos({\r\n            type: 'keyframe',\r\n            values: vals,\r\n            declarations: declarations(),\r\n        });\r\n    }\r\n    function atkeyframes() {\r\n        const pos = position();\r\n        let m = match(/^@([-\\w]+)?keyframes\\s*/);\r\n        if (!m) {\r\n            return;\r\n        }\r\n        const vendor = m[1];\r\n        m = match(/^([-\\w]+)\\s*/);\r\n        if (!m) {\r\n            return error('@keyframes missing name');\r\n        }\r\n        const name = m[1];\r\n        if (!open()) {\r\n            return error(`@keyframes missing '{'`);\r\n        }\r\n        let frame;\r\n        let frames = comments();\r\n        while ((frame = keyframe())) {\r\n            frames.push(frame);\r\n            frames = frames.concat(comments());\r\n        }\r\n        if (!close()) {\r\n            return error(`@keyframes missing '}'`);\r\n        }\r\n        return pos({\r\n            type: 'keyframes',\r\n            name,\r\n            vendor,\r\n            keyframes: frames,\r\n        });\r\n    }\r\n    function atsupports() {\r\n        const pos = position();\r\n        const m = match(/^@supports *([^{]+)/);\r\n        if (!m) {\r\n            return;\r\n        }\r\n        const supports = trim(m[1]);\r\n        if (!open()) {\r\n            return error(`@supports missing '{'`);\r\n        }\r\n        const style = comments().concat(rules());\r\n        if (!close()) {\r\n            return error(`@supports missing '}'`);\r\n        }\r\n        return pos({\r\n            type: 'supports',\r\n            supports,\r\n            rules: style,\r\n        });\r\n    }\r\n    function athost() {\r\n        const pos = position();\r\n        const m = match(/^@host\\s*/);\r\n        if (!m) {\r\n            return;\r\n        }\r\n        if (!open()) {\r\n            return error(`@host missing '{'`);\r\n        }\r\n        const style = comments().concat(rules());\r\n        if (!close()) {\r\n            return error(`@host missing '}'`);\r\n        }\r\n        return pos({\r\n            type: 'host',\r\n            rules: style,\r\n        });\r\n    }\r\n    function atmedia() {\r\n        const pos = position();\r\n        const m = match(/^@media *([^{]+)/);\r\n        if (!m) {\r\n            return;\r\n        }\r\n        const media = trim(m[1]);\r\n        if (!open()) {\r\n            return error(`@media missing '{'`);\r\n        }\r\n        const style = comments().concat(rules());\r\n        if (!close()) {\r\n            return error(`@media missing '}'`);\r\n        }\r\n        return pos({\r\n            type: 'media',\r\n            media,\r\n            rules: style,\r\n        });\r\n    }\r\n    function atcustommedia() {\r\n        const pos = position();\r\n        const m = match(/^@custom-media\\s+(--[^\\s]+)\\s*([^{;]+);/);\r\n        if (!m) {\r\n            return;\r\n        }\r\n        return pos({\r\n            type: 'custom-media',\r\n            name: trim(m[1]),\r\n            media: trim(m[2]),\r\n        });\r\n    }\r\n    function atpage() {\r\n        const pos = position();\r\n        const m = match(/^@page */);\r\n        if (!m) {\r\n            return;\r\n        }\r\n        const sel = selector() || [];\r\n        if (!open()) {\r\n            return error(`@page missing '{'`);\r\n        }\r\n        let decls = comments();\r\n        let decl;\r\n        while ((decl = declaration())) {\r\n            decls.push(decl);\r\n            decls = decls.concat(comments());\r\n        }\r\n        if (!close()) {\r\n            return error(`@page missing '}'`);\r\n        }\r\n        return pos({\r\n            type: 'page',\r\n            selectors: sel,\r\n            declarations: decls,\r\n        });\r\n    }\r\n    function atdocument() {\r\n        const pos = position();\r\n        const m = match(/^@([-\\w]+)?document *([^{]+)/);\r\n        if (!m) {\r\n            return;\r\n        }\r\n        const vendor = trim(m[1]);\r\n        const doc = trim(m[2]);\r\n        if (!open()) {\r\n            return error(`@document missing '{'`);\r\n        }\r\n        const style = comments().concat(rules());\r\n        if (!close()) {\r\n            return error(`@document missing '}'`);\r\n        }\r\n        return pos({\r\n            type: 'document',\r\n            document: doc,\r\n            vendor,\r\n            rules: style,\r\n        });\r\n    }\r\n    function atfontface() {\r\n        const pos = position();\r\n        const m = match(/^@font-face\\s*/);\r\n        if (!m) {\r\n            return;\r\n        }\r\n        if (!open()) {\r\n            return error(`@font-face missing '{'`);\r\n        }\r\n        let decls = comments();\r\n        let decl;\r\n        while ((decl = declaration())) {\r\n            decls.push(decl);\r\n            decls = decls.concat(comments());\r\n        }\r\n        if (!close()) {\r\n            return error(`@font-face missing '}'`);\r\n        }\r\n        return pos({\r\n            type: 'font-face',\r\n            declarations: decls,\r\n        });\r\n    }\r\n    const atimport = _compileAtrule('import');\r\n    const atcharset = _compileAtrule('charset');\r\n    const atnamespace = _compileAtrule('namespace');\r\n    function _compileAtrule(name) {\r\n        const re = new RegExp('^@' +\r\n            name +\r\n            '\\\\s*((?:' +\r\n            [\r\n                /[^\\\\]\"(?:\\\\\"|[^\"])*\"/.source,\r\n                /[^\\\\]'(?:\\\\'|[^'])*'/.source,\r\n                '[^;]',\r\n            ].join('|') +\r\n            ')+);');\r\n        return () => {\r\n            const pos = position();\r\n            const m = match(re);\r\n            if (!m) {\r\n                return;\r\n            }\r\n            const ret = { type: name };\r\n            ret[name] = m[1].trim();\r\n            return pos(ret);\r\n        };\r\n    }\r\n    function atrule() {\r\n        if (css[0] !== '@') {\r\n            return;\r\n        }\r\n        return (atkeyframes() ||\r\n            atmedia() ||\r\n            atcustommedia() ||\r\n            atsupports() ||\r\n            atimport() ||\r\n            atcharset() ||\r\n            atnamespace() ||\r\n            atdocument() ||\r\n            atpage() ||\r\n            athost() ||\r\n            atfontface());\r\n    }\r\n    function rule() {\r\n        const pos = position();\r\n        const sel = selector();\r\n        if (!sel) {\r\n            return error('selector missing');\r\n        }\r\n        comments();\r\n        return pos({\r\n            type: 'rule',\r\n            selectors: sel,\r\n            declarations: declarations(),\r\n        });\r\n    }\r\n    return addParent(stylesheet());\r\n}\r\nfunction trim(str) {\r\n    return str ? str.replace(/^\\s+|\\s+$/g, '') : '';\r\n}\r\nfunction addParent(obj, parent) {\r\n    const isNode = obj && typeof obj.type === 'string';\r\n    const childParent = isNode ? obj : parent;\r\n    for (const k of Object.keys(obj)) {\r\n        const value = obj[k];\r\n        if (Array.isArray(value)) {\r\n            value.forEach((v) => {\r\n                addParent(v, childParent);\r\n            });\r\n        }\r\n        else if (value && typeof value === 'object') {\r\n            addParent(value, childParent);\r\n        }\r\n    }\r\n    if (isNode) {\r\n        Object.defineProperty(obj, 'parent', {\r\n            configurable: true,\r\n            writable: true,\r\n            enumerable: false,\r\n            value: parent || null,\r\n        });\r\n    }\r\n    return obj;\r\n}\n\nconst tagMap = {\r\n    script: 'noscript',\r\n    altglyph: 'altGlyph',\r\n    altglyphdef: 'altGlyphDef',\r\n    altglyphitem: 'altGlyphItem',\r\n    animatecolor: 'animateColor',\r\n    animatemotion: 'animateMotion',\r\n    animatetransform: 'animateTransform',\r\n    clippath: 'clipPath',\r\n    feblend: 'feBlend',\r\n    fecolormatrix: 'feColorMatrix',\r\n    fecomponenttransfer: 'feComponentTransfer',\r\n    fecomposite: 'feComposite',\r\n    feconvolvematrix: 'feConvolveMatrix',\r\n    fediffuselighting: 'feDiffuseLighting',\r\n    fedisplacementmap: 'feDisplacementMap',\r\n    fedistantlight: 'feDistantLight',\r\n    fedropshadow: 'feDropShadow',\r\n    feflood: 'feFlood',\r\n    fefunca: 'feFuncA',\r\n    fefuncb: 'feFuncB',\r\n    fefuncg: 'feFuncG',\r\n    fefuncr: 'feFuncR',\r\n    fegaussianblur: 'feGaussianBlur',\r\n    feimage: 'feImage',\r\n    femerge: 'feMerge',\r\n    femergenode: 'feMergeNode',\r\n    femorphology: 'feMorphology',\r\n    feoffset: 'feOffset',\r\n    fepointlight: 'fePointLight',\r\n    fespecularlighting: 'feSpecularLighting',\r\n    fespotlight: 'feSpotLight',\r\n    fetile: 'feTile',\r\n    feturbulence: 'feTurbulence',\r\n    foreignobject: 'foreignObject',\r\n    glyphref: 'glyphRef',\r\n    lineargradient: 'linearGradient',\r\n    radialgradient: 'radialGradient',\r\n};\r\nfunction getTagName(n) {\r\n    let tagName = tagMap[n.tagName] ? tagMap[n.tagName] : n.tagName;\r\n    if (tagName === 'link' && n.attributes._cssText) {\r\n        tagName = 'style';\r\n    }\r\n    return tagName;\r\n}\r\nfunction escapeRegExp(str) {\r\n    return str.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&');\r\n}\r\nconst HOVER_SELECTOR = /([^\\\\]):hover/;\r\nconst HOVER_SELECTOR_GLOBAL = new RegExp(HOVER_SELECTOR.source, 'g');\r\nfunction addHoverClass(cssText, cache) {\r\n    const cachedStyle = cache?.stylesWithHoverClass.get(cssText);\r\n    if (cachedStyle)\r\n        return cachedStyle;\r\n    if (cssText.length >= 1000000) {\r\n        return cssText;\r\n    }\r\n    const ast = parse(cssText, {\r\n        silent: true,\r\n    });\r\n    if (!ast.stylesheet) {\r\n        return cssText;\r\n    }\r\n    const selectors = [];\r\n    ast.stylesheet.rules.forEach((rule) => {\r\n        if ('selectors' in rule) {\r\n            (rule.selectors || []).forEach((selector) => {\r\n                if (HOVER_SELECTOR.test(selector)) {\r\n                    selectors.push(selector);\r\n                }\r\n            });\r\n        }\r\n    });\r\n    if (selectors.length === 0) {\r\n        return cssText;\r\n    }\r\n    const selectorMatcher = new RegExp(selectors\r\n        .filter((selector, index) => selectors.indexOf(selector) === index)\r\n        .sort((a, b) => b.length - a.length)\r\n        .map((selector) => {\r\n        return escapeRegExp(selector);\r\n    })\r\n        .join('|'), 'g');\r\n    const result = cssText.replace(selectorMatcher, (selector) => {\r\n        const newSelector = selector.replace(HOVER_SELECTOR_GLOBAL, '$1.\\\\:hover');\r\n        return `${selector}, ${newSelector}`;\r\n    });\r\n    cache?.stylesWithHoverClass.set(cssText, result);\r\n    return result;\r\n}\r\nfunction createCache() {\r\n    const stylesWithHoverClass = new Map();\r\n    return {\r\n        stylesWithHoverClass,\r\n    };\r\n}\r\nfunction buildNode(n, options) {\r\n    const { doc, hackCss, cache } = options;\r\n    switch (n.type) {\r\n        case NodeType.Document:\r\n            return doc.implementation.createDocument(null, '', null);\r\n        case NodeType.DocumentType:\r\n            return doc.implementation.createDocumentType(n.name || 'html', n.publicId, n.systemId);\r\n        case NodeType.Element: {\r\n            const tagName = getTagName(n);\r\n            let node;\r\n            if (n.isSVG) {\r\n                node = doc.createElementNS('http://www.w3.org/2000/svg', tagName);\r\n            }\r\n            else {\r\n                if (n.isCustom &&\r\n                    doc.defaultView?.customElements &&\r\n                    !doc.defaultView.customElements.get(n.tagName))\r\n                    doc.defaultView.customElements.define(n.tagName, class extends doc.defaultView.HTMLElement {\r\n                    });\r\n                node = doc.createElement(tagName);\r\n            }\r\n            const specialAttributes = {};\r\n            for (const name in n.attributes) {\r\n                if (!Object.prototype.hasOwnProperty.call(n.attributes, name)) {\r\n                    continue;\r\n                }\r\n                let value = n.attributes[name];\r\n                if (tagName === 'option' &&\r\n                    name === 'selected' &&\r\n                    value === false) {\r\n                    continue;\r\n                }\r\n                if (value === null) {\r\n                    continue;\r\n                }\r\n                if (value === true)\r\n                    value = '';\r\n                if (name.startsWith('rr_')) {\r\n                    specialAttributes[name] = value;\r\n                    continue;\r\n                }\r\n                const isTextarea = tagName === 'textarea' && name === 'value';\r\n                const isRemoteOrDynamicCss = tagName === 'style' && name === '_cssText';\r\n                if (isRemoteOrDynamicCss && hackCss && typeof value === 'string') {\r\n                    value = addHoverClass(value, cache);\r\n                }\r\n                if ((isTextarea || isRemoteOrDynamicCss) && typeof value === 'string') {\r\n                    const child = doc.createTextNode(value);\r\n                    for (const c of Array.from(node.childNodes)) {\r\n                        if (c.nodeType === node.TEXT_NODE) {\r\n                            node.removeChild(c);\r\n                        }\r\n                    }\r\n                    node.appendChild(child);\r\n                    continue;\r\n                }\r\n                try {\r\n                    if (n.isSVG && name === 'xlink:href') {\r\n                        node.setAttributeNS('http://www.w3.org/1999/xlink', name, value.toString());\r\n                    }\r\n                    else if (name === 'onload' ||\r\n                        name === 'onclick' ||\r\n                        name.substring(0, 7) === 'onmouse') {\r\n                        node.setAttribute('_' + name, value.toString());\r\n                    }\r\n                    else if (tagName === 'meta' &&\r\n                        n.attributes['http-equiv'] === 'Content-Security-Policy' &&\r\n                        name === 'content') {\r\n                        node.setAttribute('csp-content', value.toString());\r\n                        continue;\r\n                    }\r\n                    else if (tagName === 'link' &&\r\n                        (n.attributes.rel === 'preload' ||\r\n                            n.attributes.rel === 'modulepreload')) {\r\n                    }\r\n                    else if (tagName === 'link' &&\r\n                        n.attributes.rel === 'prefetch' &&\r\n                        typeof n.attributes.href === 'string' &&\r\n                        extractFileExtension(n.attributes.href) === 'js') {\r\n                    }\r\n                    else if (tagName === 'img' &&\r\n                        n.attributes.srcset &&\r\n                        n.attributes.rr_dataURL) {\r\n                        node.setAttribute('rrweb-original-srcset', n.attributes.srcset);\r\n                    }\r\n                    else {\r\n                        node.setAttribute(name, value.toString());\r\n                    }\r\n                }\r\n                catch (error) {\r\n                }\r\n            }\r\n            for (const name in specialAttributes) {\r\n                const value = specialAttributes[name];\r\n                if (tagName === 'canvas' && name === 'rr_dataURL') {\r\n                    const image = doc.createElement('img');\r\n                    image.onload = () => {\r\n                        const ctx = node.getContext('2d');\r\n                        if (ctx) {\r\n                            ctx.drawImage(image, 0, 0, image.width, image.height);\r\n                        }\r\n                    };\r\n                    image.src = value.toString();\r\n                    if (node.RRNodeType)\r\n                        node.rr_dataURL = value.toString();\r\n                }\r\n                else if (tagName === 'img' && name === 'rr_dataURL') {\r\n                    const image = node;\r\n                    if (!image.currentSrc.startsWith('data:')) {\r\n                        image.setAttribute('rrweb-original-src', n.attributes.src);\r\n                        image.src = value.toString();\r\n                    }\r\n                }\r\n                if (name === 'rr_width') {\r\n                    node.style.setProperty('width', value.toString());\r\n                }\r\n                else if (name === 'rr_height') {\r\n                    node.style.setProperty('height', value.toString());\r\n                }\r\n                else if (name === 'rr_mediaCurrentTime' &&\r\n                    typeof value === 'number') {\r\n                    node.currentTime = value;\r\n                }\r\n                else if (name === 'rr_mediaState') {\r\n                    switch (value) {\r\n                        case 'played':\r\n                            node\r\n                                .play()\r\n                                .catch((e) => console.warn('media playback error', e));\r\n                            break;\r\n                        case 'paused':\r\n                            node.pause();\r\n                            break;\r\n                    }\r\n                }\r\n            }\r\n            if (n.isShadowHost) {\r\n                if (!node.shadowRoot) {\r\n                    node.attachShadow({ mode: 'open' });\r\n                }\r\n                else {\r\n                    while (node.shadowRoot.firstChild) {\r\n                        node.shadowRoot.removeChild(node.shadowRoot.firstChild);\r\n                    }\r\n                }\r\n            }\r\n            return node;\r\n        }\r\n        case NodeType.Text:\r\n            return doc.createTextNode(n.isStyle && hackCss\r\n                ? addHoverClass(n.textContent, cache)\r\n                : n.textContent);\r\n        case NodeType.CDATA:\r\n            return doc.createCDATASection(n.textContent);\r\n        case NodeType.Comment:\r\n            return doc.createComment(n.textContent);\r\n        default:\r\n            return null;\r\n    }\r\n}\r\nfunction buildNodeWithSN(n, options) {\r\n    const { doc, mirror, skipChild = false, hackCss = true, afterAppend, cache, } = options;\r\n    if (mirror.has(n.id)) {\r\n        const nodeInMirror = mirror.getNode(n.id);\r\n        const meta = mirror.getMeta(nodeInMirror);\r\n        if (isNodeMetaEqual(meta, n))\r\n            return mirror.getNode(n.id);\r\n    }\r\n    let node = buildNode(n, { doc, hackCss, cache });\r\n    if (!node) {\r\n        return null;\r\n    }\r\n    if (n.rootId && mirror.getNode(n.rootId) !== doc) {\r\n        mirror.replace(n.rootId, doc);\r\n    }\r\n    if (n.type === NodeType.Document) {\r\n        doc.close();\r\n        doc.open();\r\n        if (n.compatMode === 'BackCompat' &&\r\n            n.childNodes &&\r\n            n.childNodes[0].type !== NodeType.DocumentType) {\r\n            if (n.childNodes[0].type === NodeType.Element &&\r\n                'xmlns' in n.childNodes[0].attributes &&\r\n                n.childNodes[0].attributes.xmlns === 'http://www.w3.org/1999/xhtml') {\r\n                doc.write('<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"\">');\r\n            }\r\n            else {\r\n                doc.write('<!DOCTYPE html PUBLIC \"-//W3C//DTD HTML 4.0 Transitional//EN\" \"\">');\r\n            }\r\n        }\r\n        node = doc;\r\n    }\r\n    mirror.add(node, n);\r\n    if ((n.type === NodeType.Document || n.type === NodeType.Element) &&\r\n        !skipChild) {\r\n        for (const childN of n.childNodes) {\r\n            const childNode = buildNodeWithSN(childN, {\r\n                doc,\r\n                mirror,\r\n                skipChild: false,\r\n                hackCss,\r\n                afterAppend,\r\n                cache,\r\n            });\r\n            if (!childNode) {\r\n                console.warn('Failed to rebuild', childN);\r\n                continue;\r\n            }\r\n            if (childN.isShadow && isElement(node) && node.shadowRoot) {\r\n                node.shadowRoot.appendChild(childNode);\r\n            }\r\n            else if (n.type === NodeType.Document &&\r\n                childN.type == NodeType.Element) {\r\n                const htmlElement = childNode;\r\n                let body = null;\r\n                htmlElement.childNodes.forEach((child) => {\r\n                    if (child.nodeName === 'BODY')\r\n                        body = child;\r\n                });\r\n                if (body) {\r\n                    htmlElement.removeChild(body);\r\n                    node.appendChild(childNode);\r\n                    htmlElement.appendChild(body);\r\n                }\r\n                else {\r\n                    node.appendChild(childNode);\r\n                }\r\n            }\r\n            else {\r\n                node.appendChild(childNode);\r\n            }\r\n            if (afterAppend) {\r\n                afterAppend(childNode, childN.id);\r\n            }\r\n        }\r\n    }\r\n    return node;\r\n}\r\nfunction visit(mirror, onVisit) {\r\n    function walk(node) {\r\n        onVisit(node);\r\n    }\r\n    for (const id of mirror.getIds()) {\r\n        if (mirror.has(id)) {\r\n            walk(mirror.getNode(id));\r\n        }\r\n    }\r\n}\r\nfunction handleScroll(node, mirror) {\r\n    const n = mirror.getMeta(node);\r\n    if (n?.type !== NodeType.Element) {\r\n        return;\r\n    }\r\n    const el = node;\r\n    for (const name in n.attributes) {\r\n        if (!(Object.prototype.hasOwnProperty.call(n.attributes, name) &&\r\n            name.startsWith('rr_'))) {\r\n            continue;\r\n        }\r\n        const value = n.attributes[name];\r\n        if (name === 'rr_scrollLeft') {\r\n            el.scrollLeft = value;\r\n        }\r\n        if (name === 'rr_scrollTop') {\r\n            el.scrollTop = value;\r\n        }\r\n    }\r\n}\r\nfunction rebuild(n, options) {\r\n    const { doc, onVisit, hackCss = true, afterAppend, cache, mirror = new Mirror(), } = options;\r\n    const node = buildNodeWithSN(n, {\r\n        doc,\r\n        mirror,\r\n        skipChild: false,\r\n        hackCss,\r\n        afterAppend,\r\n        cache,\r\n    });\r\n    visit(mirror, (visitedNode) => {\r\n        if (onVisit) {\r\n            onVisit(visitedNode);\r\n        }\r\n        handleScroll(visitedNode, mirror);\r\n    });\r\n    return node;\r\n}\n\nexport { IGNORED_NODE, Mirror, NodeType, addHoverClass, buildNodeWithSN, classMatchesRegex, cleanupSnapshot, clearTimeout, createCache, createMatchPredicate, createMirror, distanceToMatch, escapeImportStatement, extractFileExtension, fixAllCssProperty, fixSafariColons, genId, getIframeContentDocument, getInputType, getInputValue, ignoreAttribute, is2DCanvasBlank, isCSSImportRule, isCSSStyleRule, isElement, isNativeShadowDom, isNodeMetaEqual, isShadowRoot, maskInputValue, needMaskingText, onRequestAnimationFrame, rebuild, serializeNodeWithId, setTimeout, shouldMaskInput, snapshot, stringifyRule, stringifyStylesheet, toLowerCase, toUpperCase, transformAttribute, visitSnapshot };\n","// Note that these are the serialized attributes and not attributes directly on\n// the DOM Node. Attributes we are interested in:\nconst ATTRIBUTES_TO_RECORD = new Set([\n  'id',\n  'class',\n  'aria-label',\n  'role',\n  'name',\n  'alt',\n  'title',\n  'data-test-id',\n  'data-testid',\n  'disabled',\n  'aria-disabled',\n  'data-sentry-component',\n]);\n\n/**\n * Inclusion list of attributes that we want to record from the DOM element\n */\nexport function getAttributesToRecord(attributes: Record<string, unknown>): Record<string, unknown> {\n  const obj: Record<string, unknown> = {};\n  if (!attributes['data-sentry-component'] && attributes['data-sentry-element']) {\n    attributes['data-sentry-component'] = attributes['data-sentry-element'];\n  }\n  for (const key in attributes) {\n    if (ATTRIBUTES_TO_RECORD.has(key)) {\n      let normalizedKey = key;\n\n      if (key === 'data-testid' || key === 'data-test-id') {\n        normalizedKey = 'testId';\n      }\n\n      obj[normalizedKey] = attributes[key];\n    }\n  }\n\n  return obj;\n}\n","import { record } from '@sentry-internal/rrweb';\nimport type { serializedElementNodeWithId, serializedNodeWithId } from '@sentry-internal/rrweb-snapshot';\nimport { NodeType } from '@sentry-internal/rrweb-snapshot';\nimport { htmlTreeAsString } from '@sentry/core';\nimport type { Breadcrumb, HandlerDataDom } from '@sentry/core';\n\nimport type { ReplayContainer } from '../types';\nimport { createBreadcrumb } from '../util/createBreadcrumb';\nimport { handleClick } from './handleClick';\nimport { addBreadcrumbEvent } from './util/addBreadcrumbEvent';\nimport { getClickTargetNode, getTargetNode } from './util/domUtils';\nimport { getAttributesToRecord } from './util/getAttributesToRecord';\n\nexport const handleDomListener: (replay: ReplayContainer) => (handlerData: HandlerDataDom) => void = (\n  replay: ReplayContainer,\n) => {\n  return (handlerData: HandlerDataDom): void => {\n    if (!replay.isEnabled()) {\n      return;\n    }\n\n    const result = handleDom(handlerData);\n\n    if (!result) {\n      return;\n    }\n\n    const isClick = handlerData.name === 'click';\n    const event = isClick ? (handlerData.event as PointerEvent) : undefined;\n    // Ignore clicks if ctrl/alt/meta/shift keys are held down as they alter behavior of clicks (e.g. open in new tab)\n    if (\n      isClick &&\n      replay.clickDetector &&\n      event &&\n      event.target &&\n      !event.altKey &&\n      !event.metaKey &&\n      !event.ctrlKey &&\n      !event.shiftKey\n    ) {\n      handleClick(\n        replay.clickDetector,\n        result as Breadcrumb & { timestamp: number; data: { nodeId: number } },\n        getClickTargetNode(handlerData.event as Event) as HTMLElement,\n      );\n    }\n\n    addBreadcrumbEvent(replay, result);\n  };\n};\n\n/** Get the base DOM breadcrumb. */\nexport function getBaseDomBreadcrumb(target: Node | null, message: string): Breadcrumb {\n  const nodeId = record.mirror.getId(target);\n  const node = nodeId && record.mirror.getNode(nodeId);\n  const meta = node && record.mirror.getMeta(node);\n  const element = meta && isElement(meta) ? meta : null;\n\n  return {\n    message,\n    data: element\n      ? {\n          nodeId,\n          node: {\n            id: nodeId,\n            tagName: element.tagName,\n            textContent: Array.from(element.childNodes)\n              .map((node: serializedNodeWithId) => node.type === NodeType.Text && node.textContent)\n              .filter(Boolean) // filter out empty values\n              .map(text => (text as string).trim())\n              .join(''),\n            attributes: getAttributesToRecord(element.attributes),\n          },\n        }\n      : {},\n  };\n}\n\n/**\n * An event handler to react to DOM events.\n * Exported for tests.\n */\nexport function handleDom(handlerData: HandlerDataDom): Breadcrumb | null {\n  const { target, message } = getDomTarget(handlerData);\n\n  return createBreadcrumb({\n    category: `ui.${handlerData.name}`,\n    ...getBaseDomBreadcrumb(target, message),\n  });\n}\n\nfunction getDomTarget(handlerData: HandlerDataDom): { target: Node | null; message: string } {\n  const isClick = handlerData.name === 'click';\n\n  let message: string | undefined;\n  let target: Node | null = null;\n\n  // Accessing event.target can throw (see getsentry/raven-js#838, #768)\n  try {\n    target = isClick ? getClickTargetNode(handlerData.event as Event) : getTargetNode(handlerData.event as Event);\n    message = htmlTreeAsString(target, { maxStringLength: 200 }) || '<unknown>';\n  } catch (e) {\n    message = '<unknown>';\n  }\n\n  return { target, message };\n}\n\nfunction isElement(node: serializedNodeWithId): node is serializedElementNodeWithId {\n  return node.type === NodeType.Element;\n}\n","import { htmlTreeAsString } from '@sentry/core';\nimport type { Breadcrumb } from '@sentry/core';\n\nimport type { ReplayContainer } from '../types';\nimport { createBreadcrumb } from '../util/createBreadcrumb';\nimport { getBaseDomBreadcrumb } from './handleDom';\nimport { addBreadcrumbEvent } from './util/addBreadcrumbEvent';\n\n/** Handle keyboard events & create breadcrumbs. */\nexport function handleKeyboardEvent(replay: ReplayContainer, event: KeyboardEvent): void {\n  if (!replay.isEnabled()) {\n    return;\n  }\n\n  // Update user activity, but do not restart recording as it can create\n  // noisy/low-value replays (e.g. user comes back from idle, hits alt-tab, new\n  // session with a single \"keydown\" breadcrumb is created)\n  replay.updateUserActivity();\n\n  const breadcrumb = getKeyboardBreadcrumb(event);\n\n  if (!breadcrumb) {\n    return;\n  }\n\n  addBreadcrumbEvent(replay, breadcrumb);\n}\n\n/** exported only for tests */\nexport function getKeyboardBreadcrumb(event: KeyboardEvent): Breadcrumb | null {\n  const { metaKey, shiftKey, ctrlKey, altKey, key, target } = event;\n\n  // never capture for input fields\n  if (!target || isInputElement(target as HTMLElement) || !key) {\n    return null;\n  }\n\n  // Note: We do not consider shift here, as that means \"uppercase\"\n  const hasModifierKey = metaKey || ctrlKey || altKey;\n  const isCharacterKey = key.length === 1; // other keys like Escape, Tab, etc have a longer length\n\n  // Do not capture breadcrumb if only a word key is pressed\n  // This could leak e.g. user input\n  if (!hasModifierKey && isCharacterKey) {\n    return null;\n  }\n\n  const message = htmlTreeAsString(target, { maxStringLength: 200 }) || '<unknown>';\n  const baseBreadcrumb = getBaseDomBreadcrumb(target as Node, message);\n\n  return createBreadcrumb({\n    category: 'ui.keyDown',\n    message,\n    data: {\n      ...baseBreadcrumb.data,\n      metaKey,\n      shiftKey,\n      ctrlKey,\n      altKey,\n      key,\n    },\n  });\n}\n\nfunction isInputElement(target: HTMLElement): boolean {\n  return target.tagName === 'INPUT' || target.tagName === 'TEXTAREA' || target.isContentEditable;\n}\n","import { record } from '@sentry-internal/rrweb';\nimport { browserPerformanceTimeOrigin } from '@sentry/core';\n\nimport { WINDOW } from '../constants';\nimport type {\n  AllPerformanceEntry,\n  AllPerformanceEntryData,\n  ExperimentalPerformanceResourceTiming,\n  NavigationData,\n  PaintData,\n  ReplayContainer,\n  ReplayPerformanceEntry,\n  ResourceData,\n  WebVitalData,\n} from '../types';\n\n// Map entryType -> function to normalize data for event\nconst ENTRY_TYPES: Record<\n  string,\n  (entry: AllPerformanceEntry) => null | ReplayPerformanceEntry<AllPerformanceEntryData>\n> = {\n  // @ts-expect-error TODO: entry type does not fit the create* functions entry type\n  resource: createResourceEntry,\n  paint: createPaintEntry,\n  // @ts-expect-error TODO: entry type does not fit the create* functions entry type\n  navigation: createNavigationEntry,\n};\n\nexport interface Metric {\n  /**\n   * The current value of the metric.\n   */\n  value: number;\n\n  /**\n   * The rating as to whether the metric value is within the \"good\",\n   * \"needs improvement\", or \"poor\" thresholds of the metric.\n   */\n  rating: 'good' | 'needs-improvement' | 'poor';\n\n  /**\n   * Any performance entries relevant to the metric value calculation.\n   * The array may also be empty if the metric value was not based on any\n   * entries (e.g. a CLS value of 0 given no layout shifts).\n   */\n  entries: PerformanceEntry[] | LayoutShift[];\n}\n\ninterface LayoutShift extends PerformanceEntry {\n  value: number;\n  sources: LayoutShiftAttribution[];\n  hadRecentInput: boolean;\n}\n\ninterface LayoutShiftAttribution {\n  node?: Node;\n  previousRect: DOMRectReadOnly;\n  currentRect: DOMRectReadOnly;\n}\n\n/**\n * Handler creater for web vitals\n */\nexport function webVitalHandler(\n  getter: (metric: Metric) => ReplayPerformanceEntry<AllPerformanceEntryData>,\n  replay: ReplayContainer,\n): (data: { metric: Metric }) => void {\n  return ({ metric }) => void replay.replayPerformanceEntries.push(getter(metric));\n}\n\n/**\n * Create replay performance entries from the browser performance entries.\n */\nexport function createPerformanceEntries(\n  entries: AllPerformanceEntry[],\n): ReplayPerformanceEntry<AllPerformanceEntryData>[] {\n  return entries.map(createPerformanceEntry).filter(Boolean) as ReplayPerformanceEntry<AllPerformanceEntryData>[];\n}\n\nfunction createPerformanceEntry(entry: AllPerformanceEntry): ReplayPerformanceEntry<AllPerformanceEntryData> | null {\n  const entryType = ENTRY_TYPES[entry.entryType];\n  if (!entryType) {\n    return null;\n  }\n\n  return entryType(entry);\n}\n\nfunction getAbsoluteTime(time: number): number {\n  // browserPerformanceTimeOrigin can be undefined if `performance` or\n  // `performance.now` doesn't exist, but this is already checked by this integration\n  return ((browserPerformanceTimeOrigin || WINDOW.performance.timeOrigin) + time) / 1000;\n}\n\nfunction createPaintEntry(entry: PerformancePaintTiming): ReplayPerformanceEntry<PaintData> {\n  const { duration, entryType, name, startTime } = entry;\n\n  const start = getAbsoluteTime(startTime);\n  return {\n    type: entryType,\n    name,\n    start,\n    end: start + duration,\n    data: undefined,\n  };\n}\n\nfunction createNavigationEntry(entry: PerformanceNavigationTiming): ReplayPerformanceEntry<NavigationData> | null {\n  const {\n    entryType,\n    name,\n    decodedBodySize,\n    duration,\n    domComplete,\n    encodedBodySize,\n    domContentLoadedEventStart,\n    domContentLoadedEventEnd,\n    domInteractive,\n    loadEventStart,\n    loadEventEnd,\n    redirectCount,\n    startTime,\n    transferSize,\n    type,\n  } = entry;\n\n  // Ignore entries with no duration, they do not seem to be useful and cause dupes\n  if (duration === 0) {\n    return null;\n  }\n\n  return {\n    type: `${entryType}.${type}`,\n    start: getAbsoluteTime(startTime),\n    end: getAbsoluteTime(domComplete),\n    name,\n    data: {\n      size: transferSize,\n      decodedBodySize,\n      encodedBodySize,\n      duration,\n      domInteractive,\n      domContentLoadedEventStart,\n      domContentLoadedEventEnd,\n      loadEventStart,\n      loadEventEnd,\n      domComplete,\n      redirectCount,\n    },\n  };\n}\n\nfunction createResourceEntry(\n  entry: ExperimentalPerformanceResourceTiming,\n): ReplayPerformanceEntry<ResourceData> | null {\n  const {\n    entryType,\n    initiatorType,\n    name,\n    responseEnd,\n    startTime,\n    decodedBodySize,\n    encodedBodySize,\n    responseStatus,\n    transferSize,\n  } = entry;\n\n  // Core SDK handles these\n  if (['fetch', 'xmlhttprequest'].includes(initiatorType)) {\n    return null;\n  }\n\n  return {\n    type: `${entryType}.${initiatorType}`,\n    start: getAbsoluteTime(startTime),\n    end: getAbsoluteTime(responseEnd),\n    name,\n    data: {\n      size: transferSize,\n      statusCode: responseStatus,\n      decodedBodySize,\n      encodedBodySize,\n    },\n  };\n}\n\n/**\n * Add a LCP event to the replay based on a LCP metric.\n */\nexport function getLargestContentfulPaint(metric: Metric): ReplayPerformanceEntry<WebVitalData> {\n  const lastEntry = metric.entries[metric.entries.length - 1] as (PerformanceEntry & { element?: Node }) | undefined;\n  const node = lastEntry && lastEntry.element ? [lastEntry.element] : undefined;\n  return getWebVital(metric, 'largest-contentful-paint', node);\n}\n\nfunction isLayoutShift(entry: PerformanceEntry): entry is LayoutShift {\n  return (entry as LayoutShift).sources !== undefined;\n}\n\n/**\n * Add a CLS event to the replay based on a CLS metric.\n */\nexport function getCumulativeLayoutShift(metric: Metric): ReplayPerformanceEntry<WebVitalData> {\n  const layoutShifts: WebVitalData['attributions'] = [];\n  const nodes: Node[] = [];\n  for (const entry of metric.entries) {\n    if (isLayoutShift(entry)) {\n      const nodeIds = [];\n      for (const source of entry.sources) {\n        if (source.node) {\n          nodes.push(source.node);\n          const nodeId = record.mirror.getId(source.node);\n          if (nodeId) {\n            nodeIds.push(nodeId);\n          }\n        }\n      }\n      layoutShifts.push({ value: entry.value, nodeIds: nodeIds.length ? nodeIds : undefined });\n    }\n  }\n\n  return getWebVital(metric, 'cumulative-layout-shift', nodes, layoutShifts);\n}\n\n/**\n * Add a FID event to the replay based on a FID metric.\n */\nexport function getFirstInputDelay(metric: Metric): ReplayPerformanceEntry<WebVitalData> {\n  const lastEntry = metric.entries[metric.entries.length - 1] as (PerformanceEntry & { target?: Node }) | undefined;\n  const node = lastEntry && lastEntry.target ? [lastEntry.target] : undefined;\n  return getWebVital(metric, 'first-input-delay', node);\n}\n\n/**\n * Add an INP event to the replay based on an INP metric.\n */\nexport function getInteractionToNextPaint(metric: Metric): ReplayPerformanceEntry<WebVitalData> {\n  const lastEntry = metric.entries[metric.entries.length - 1] as (PerformanceEntry & { target?: Node }) | undefined;\n  const node = lastEntry && lastEntry.target ? [lastEntry.target] : undefined;\n  return getWebVital(metric, 'interaction-to-next-paint', node);\n}\n\n/**\n * Add an web vital event to the replay based on the web vital metric.\n */\nfunction getWebVital(\n  metric: Metric,\n  name: string,\n  nodes: Node[] | undefined,\n  attributions?: WebVitalData['attributions'],\n): ReplayPerformanceEntry<WebVitalData> {\n  const value = metric.value;\n  const rating = metric.rating;\n\n  const end = getAbsoluteTime(value);\n\n  return {\n    type: 'web-vital',\n    name,\n    start: end,\n    end,\n    data: {\n      value,\n      size: value,\n      rating,\n      nodeIds: nodes ? nodes.map(node => record.mirror.getId(node)) : undefined,\n      attributions,\n    },\n  };\n}\n","import {\n  addClsInstrumentationHandler,\n  addFidInstrumentationHandler,\n  addInpInstrumentationHandler,\n  addLcpInstrumentationHandler,\n  addPerformanceInstrumentationHandler,\n} from '@sentry-internal/browser-utils';\nimport type { ReplayContainer } from '../types';\nimport {\n  getCumulativeLayoutShift,\n  getFirstInputDelay,\n  getInteractionToNextPaint,\n  getLargestContentfulPaint,\n  webVitalHandler,\n} from '../util/createPerformanceEntries';\n\n/**\n * Sets up a PerformanceObserver to listen to all performance entry types.\n * Returns a callback to stop observing.\n */\nexport function setupPerformanceObserver(replay: ReplayContainer): () => void {\n  function addPerformanceEntry(entry: PerformanceEntry): void {\n    // It is possible for entries to come up multiple times\n    if (!replay.performanceEntries.includes(entry)) {\n      replay.performanceEntries.push(entry);\n    }\n  }\n\n  function onEntries({ entries }: { entries: PerformanceEntry[] }): void {\n    entries.forEach(addPerformanceEntry);\n  }\n\n  const clearCallbacks: (() => void)[] = [];\n\n  (['navigation', 'paint', 'resource'] as const).forEach(type => {\n    clearCallbacks.push(addPerformanceInstrumentationHandler(type, onEntries));\n  });\n\n  clearCallbacks.push(\n    addLcpInstrumentationHandler(webVitalHandler(getLargestContentfulPaint, replay)),\n    addClsInstrumentationHandler(webVitalHandler(getCumulativeLayoutShift, replay)),\n    addFidInstrumentationHandler(webVitalHandler(getFirstInputDelay, replay)),\n    addInpInstrumentationHandler(webVitalHandler(getInteractionToNextPaint, replay)),\n  );\n\n  // A callback to cleanup all handlers\n  return () => {\n    clearCallbacks.forEach(clearCallback => clearCallback());\n  };\n}\n","declare const __DEBUG_BUILD__: boolean;\n\n/**\n * This serves as a build time flag that will be true by default, but false in non-debug builds or if users replace `__SENTRY_DEBUG__` in their generated code.\n *\n * ATTENTION: This constant must never cross package boundaries (i.e. be exported) to guarantee that it can be used for tree shaking.\n */\nexport const DEBUG_BUILD = __DEBUG_BUILD__;\n","export default `var t=Uint8Array,n=Uint16Array,r=Int32Array,e=new t([0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0,0,0,0]),i=new t([0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13,0,0]),a=new t([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),s=function(t,e){for(var i=new n(31),a=0;a<31;++a)i[a]=e+=1<<t[a-1];var s=new r(i[30]);for(a=1;a<30;++a)for(var o=i[a];o<i[a+1];++o)s[o]=o-i[a]<<5|a;return{b:i,r:s}},o=s(e,2),f=o.b,h=o.r;f[28]=258,h[258]=28;for(var l=s(i,0).r,u=new n(32768),c=0;c<32768;++c){var v=(43690&c)>>1|(21845&c)<<1;v=(61680&(v=(52428&v)>>2|(13107&v)<<2))>>4|(3855&v)<<4,u[c]=((65280&v)>>8|(255&v)<<8)>>1}var d=function(t,r,e){for(var i=t.length,a=0,s=new n(r);a<i;++a)t[a]&&++s[t[a]-1];var o,f=new n(r);for(a=1;a<r;++a)f[a]=f[a-1]+s[a-1]<<1;if(e){o=new n(1<<r);var h=15-r;for(a=0;a<i;++a)if(t[a])for(var l=a<<4|t[a],c=r-t[a],v=f[t[a]-1]++<<c,d=v|(1<<c)-1;v<=d;++v)o[u[v]>>h]=l}else for(o=new n(i),a=0;a<i;++a)t[a]&&(o[a]=u[f[t[a]-1]++]>>15-t[a]);return o},g=new t(288);for(c=0;c<144;++c)g[c]=8;for(c=144;c<256;++c)g[c]=9;for(c=256;c<280;++c)g[c]=7;for(c=280;c<288;++c)g[c]=8;var w=new t(32);for(c=0;c<32;++c)w[c]=5;var p=d(g,9,0),y=d(w,5,0),m=function(t){return(t+7)/8|0},b=function(n,r,e){return(null==e||e>n.length)&&(e=n.length),new t(n.subarray(r,e))},M=[\"unexpected EOF\",\"invalid block type\",\"invalid length/literal\",\"invalid distance\",\"stream finished\",\"no stream handler\",,\"no callback\",\"invalid UTF-8 data\",\"extra field too long\",\"date not in range 1980-2099\",\"filename too long\",\"stream finishing\",\"invalid zip data\"],E=function(t,n,r){var e=new Error(n||M[t]);if(e.code=t,Error.captureStackTrace&&Error.captureStackTrace(e,E),!r)throw e;return e},z=function(t,n,r){r<<=7&n;var e=n/8|0;t[e]|=r,t[e+1]|=r>>8},_=function(t,n,r){r<<=7&n;var e=n/8|0;t[e]|=r,t[e+1]|=r>>8,t[e+2]|=r>>16},x=function(r,e){for(var i=[],a=0;a<r.length;++a)r[a]&&i.push({s:a,f:r[a]});var s=i.length,o=i.slice();if(!s)return{t:F,l:0};if(1==s){var f=new t(i[0].s+1);return f[i[0].s]=1,{t:f,l:1}}i.sort((function(t,n){return t.f-n.f})),i.push({s:-1,f:25001});var h=i[0],l=i[1],u=0,c=1,v=2;for(i[0]={s:-1,f:h.f+l.f,l:h,r:l};c!=s-1;)h=i[i[u].f<i[v].f?u++:v++],l=i[u!=c&&i[u].f<i[v].f?u++:v++],i[c++]={s:-1,f:h.f+l.f,l:h,r:l};var d=o[0].s;for(a=1;a<s;++a)o[a].s>d&&(d=o[a].s);var g=new n(d+1),w=A(i[c-1],g,0);if(w>e){a=0;var p=0,y=w-e,m=1<<y;for(o.sort((function(t,n){return g[n.s]-g[t.s]||t.f-n.f}));a<s;++a){var b=o[a].s;if(!(g[b]>e))break;p+=m-(1<<w-g[b]),g[b]=e}for(p>>=y;p>0;){var M=o[a].s;g[M]<e?p-=1<<e-g[M]++-1:++a}for(;a>=0&&p;--a){var E=o[a].s;g[E]==e&&(--g[E],++p)}w=e}return{t:new t(g),l:w}},A=function(t,n,r){return-1==t.s?Math.max(A(t.l,n,r+1),A(t.r,n,r+1)):n[t.s]=r},D=function(t){for(var r=t.length;r&&!t[--r];);for(var e=new n(++r),i=0,a=t[0],s=1,o=function(t){e[i++]=t},f=1;f<=r;++f)if(t[f]==a&&f!=r)++s;else{if(!a&&s>2){for(;s>138;s-=138)o(32754);s>2&&(o(s>10?s-11<<5|28690:s-3<<5|12305),s=0)}else if(s>3){for(o(a),--s;s>6;s-=6)o(8304);s>2&&(o(s-3<<5|8208),s=0)}for(;s--;)o(a);s=1,a=t[f]}return{c:e.subarray(0,i),n:r}},T=function(t,n){for(var r=0,e=0;e<n.length;++e)r+=t[e]*n[e];return r},k=function(t,n,r){var e=r.length,i=m(n+2);t[i]=255&e,t[i+1]=e>>8,t[i+2]=255^t[i],t[i+3]=255^t[i+1];for(var a=0;a<e;++a)t[i+a+4]=r[a];return 8*(i+4+e)},U=function(t,r,s,o,f,h,l,u,c,v,m){z(r,m++,s),++f[256];for(var b=x(f,15),M=b.t,E=b.l,A=x(h,15),U=A.t,C=A.l,F=D(M),I=F.c,S=F.n,L=D(U),O=L.c,j=L.n,q=new n(19),B=0;B<I.length;++B)++q[31&I[B]];for(B=0;B<O.length;++B)++q[31&O[B]];for(var G=x(q,7),H=G.t,J=G.l,K=19;K>4&&!H[a[K-1]];--K);var N,P,Q,R,V=v+5<<3,W=T(f,g)+T(h,w)+l,X=T(f,M)+T(h,U)+l+14+3*K+T(q,H)+2*q[16]+3*q[17]+7*q[18];if(c>=0&&V<=W&&V<=X)return k(r,m,t.subarray(c,c+v));if(z(r,m,1+(X<W)),m+=2,X<W){N=d(M,E,0),P=M,Q=d(U,C,0),R=U;var Y=d(H,J,0);z(r,m,S-257),z(r,m+5,j-1),z(r,m+10,K-4),m+=14;for(B=0;B<K;++B)z(r,m+3*B,H[a[B]]);m+=3*K;for(var Z=[I,O],$=0;$<2;++$){var tt=Z[$];for(B=0;B<tt.length;++B){var nt=31&tt[B];z(r,m,Y[nt]),m+=H[nt],nt>15&&(z(r,m,tt[B]>>5&127),m+=tt[B]>>12)}}}else N=p,P=g,Q=y,R=w;for(B=0;B<u;++B){var rt=o[B];if(rt>255){_(r,m,N[(nt=rt>>18&31)+257]),m+=P[nt+257],nt>7&&(z(r,m,rt>>23&31),m+=e[nt]);var et=31&rt;_(r,m,Q[et]),m+=R[et],et>3&&(_(r,m,rt>>5&8191),m+=i[et])}else _(r,m,N[rt]),m+=P[rt]}return _(r,m,N[256]),m+P[256]},C=new r([65540,131080,131088,131104,262176,1048704,1048832,2114560,2117632]),F=new t(0),I=function(){for(var t=new Int32Array(256),n=0;n<256;++n){for(var r=n,e=9;--e;)r=(1&r&&-306674912)^r>>>1;t[n]=r}return t}(),S=function(){var t=-1;return{p:function(n){for(var r=t,e=0;e<n.length;++e)r=I[255&r^n[e]]^r>>>8;t=r},d:function(){return~t}}},L=function(){var t=1,n=0;return{p:function(r){for(var e=t,i=n,a=0|r.length,s=0;s!=a;){for(var o=Math.min(s+2655,a);s<o;++s)i+=e+=r[s];e=(65535&e)+15*(e>>16),i=(65535&i)+15*(i>>16)}t=e,n=i},d:function(){return(255&(t%=65521))<<24|(65280&t)<<8|(255&(n%=65521))<<8|n>>8}}},O=function(a,s,o,f,u){if(!u&&(u={l:1},s.dictionary)){var c=s.dictionary.subarray(-32768),v=new t(c.length+a.length);v.set(c),v.set(a,c.length),a=v,u.w=c.length}return function(a,s,o,f,u,c){var v=c.z||a.length,d=new t(f+v+5*(1+Math.ceil(v/7e3))+u),g=d.subarray(f,d.length-u),w=c.l,p=7&(c.r||0);if(s){p&&(g[0]=c.r>>3);for(var y=C[s-1],M=y>>13,E=8191&y,z=(1<<o)-1,_=c.p||new n(32768),x=c.h||new n(z+1),A=Math.ceil(o/3),D=2*A,T=function(t){return(a[t]^a[t+1]<<A^a[t+2]<<D)&z},F=new r(25e3),I=new n(288),S=new n(32),L=0,O=0,j=c.i||0,q=0,B=c.w||0,G=0;j+2<v;++j){var H=T(j),J=32767&j,K=x[H];if(_[J]=K,x[H]=J,B<=j){var N=v-j;if((L>7e3||q>24576)&&(N>423||!w)){p=U(a,g,0,F,I,S,O,q,G,j-G,p),q=L=O=0,G=j;for(var P=0;P<286;++P)I[P]=0;for(P=0;P<30;++P)S[P]=0}var Q=2,R=0,V=E,W=J-K&32767;if(N>2&&H==T(j-W))for(var X=Math.min(M,N)-1,Y=Math.min(32767,j),Z=Math.min(258,N);W<=Y&&--V&&J!=K;){if(a[j+Q]==a[j+Q-W]){for(var $=0;$<Z&&a[j+$]==a[j+$-W];++$);if($>Q){if(Q=$,R=W,$>X)break;var tt=Math.min(W,$-2),nt=0;for(P=0;P<tt;++P){var rt=j-W+P&32767,et=rt-_[rt]&32767;et>nt&&(nt=et,K=rt)}}}W+=(J=K)-(K=_[J])&32767}if(R){F[q++]=268435456|h[Q]<<18|l[R];var it=31&h[Q],at=31&l[R];O+=e[it]+i[at],++I[257+it],++S[at],B=j+Q,++L}else F[q++]=a[j],++I[a[j]]}}for(j=Math.max(j,B);j<v;++j)F[q++]=a[j],++I[a[j]];p=U(a,g,w,F,I,S,O,q,G,j-G,p),w||(c.r=7&p|g[p/8|0]<<3,p-=7,c.h=x,c.p=_,c.i=j,c.w=B)}else{for(j=c.w||0;j<v+w;j+=65535){var st=j+65535;st>=v&&(g[p/8|0]=w,st=v),p=k(g,p+1,a.subarray(j,st))}c.i=v}return b(d,0,f+m(p)+u)}(a,null==s.level?6:s.level,null==s.mem?Math.ceil(1.5*Math.max(8,Math.min(13,Math.log(a.length)))):12+s.mem,o,f,u)},j=function(t,n,r){for(;r;++n)t[n]=r,r>>>=8},q=function(t,n){var r=n.filename;if(t[0]=31,t[1]=139,t[2]=8,t[8]=n.level<2?4:9==n.level?2:0,t[9]=3,0!=n.mtime&&j(t,4,Math.floor(new Date(n.mtime||Date.now())/1e3)),r){t[3]=8;for(var e=0;e<=r.length;++e)t[e+10]=r.charCodeAt(e)}},B=function(t){return 10+(t.filename?t.filename.length+1:0)},G=function(){function n(n,r){if(\"function\"==typeof n&&(r=n,n={}),this.ondata=r,this.o=n||{},this.s={l:0,i:32768,w:32768,z:32768},this.b=new t(98304),this.o.dictionary){var e=this.o.dictionary.subarray(-32768);this.b.set(e,32768-e.length),this.s.i=32768-e.length}}return n.prototype.p=function(t,n){this.ondata(O(t,this.o,0,0,this.s),n)},n.prototype.push=function(n,r){this.ondata||E(5),this.s.l&&E(4);var e=n.length+this.s.z;if(e>this.b.length){if(e>2*this.b.length-32768){var i=new t(-32768&e);i.set(this.b.subarray(0,this.s.z)),this.b=i}var a=this.b.length-this.s.z;a&&(this.b.set(n.subarray(0,a),this.s.z),this.s.z=this.b.length,this.p(this.b,!1)),this.b.set(this.b.subarray(-32768)),this.b.set(n.subarray(a),32768),this.s.z=n.length-a+32768,this.s.i=32766,this.s.w=32768}else this.b.set(n,this.s.z),this.s.z+=n.length;this.s.l=1&r,(this.s.z>this.s.w+8191||r)&&(this.p(this.b,r||!1),this.s.w=this.s.i,this.s.i-=2)},n}();var H=function(){function t(t,n){this.c=L(),this.v=1,G.call(this,t,n)}return t.prototype.push=function(t,n){this.c.p(t),G.prototype.push.call(this,t,n)},t.prototype.p=function(t,n){var r=O(t,this.o,this.v&&(this.o.dictionary?6:2),n&&4,this.s);this.v&&(function(t,n){var r=n.level,e=0==r?0:r<6?1:9==r?3:2;if(t[0]=120,t[1]=e<<6|(n.dictionary&&32),t[1]|=31-(t[0]<<8|t[1])%31,n.dictionary){var i=L();i.p(n.dictionary),j(t,2,i.d())}}(r,this.o),this.v=0),n&&j(r,r.length-4,this.c.d()),this.ondata(r,n)},t}(),J=\"undefined\"!=typeof TextEncoder&&new TextEncoder,K=\"undefined\"!=typeof TextDecoder&&new TextDecoder;try{K.decode(F,{stream:!0})}catch(t){}var N=function(){function t(t){this.ondata=t}return t.prototype.push=function(t,n){this.ondata||E(5),this.d&&E(4),this.ondata(P(t),this.d=n||!1)},t}();function P(n,r){if(J)return J.encode(n);for(var e=n.length,i=new t(n.length+(n.length>>1)),a=0,s=function(t){i[a++]=t},o=0;o<e;++o){if(a+5>i.length){var f=new t(a+8+(e-o<<1));f.set(i),i=f}var h=n.charCodeAt(o);h<128||r?s(h):h<2048?(s(192|h>>6),s(128|63&h)):h>55295&&h<57344?(s(240|(h=65536+(1047552&h)|1023&n.charCodeAt(++o))>>18),s(128|h>>12&63),s(128|h>>6&63),s(128|63&h)):(s(224|h>>12),s(128|h>>6&63),s(128|63&h))}return b(i,0,a)}function Q(t){return function(t,n){n||(n={});var r=S(),e=t.length;r.p(t);var i=O(t,n,B(n),8),a=i.length;return q(i,n),j(i,a-8,r.d()),j(i,a-4,e),i}(P(t))}const R=new class{constructor(){this._init()}clear(){this._init()}addEvent(t){if(!t)throw new Error(\"Adding invalid event\");const n=this._hasEvents?\",\":\"\";this.stream.push(n+t),this._hasEvents=!0}finish(){this.stream.push(\"]\",!0);const t=function(t){let n=0;for(const r of t)n+=r.length;const r=new Uint8Array(n);for(let n=0,e=0,i=t.length;n<i;n++){const i=t[n];r.set(i,e),e+=i.length}return r}(this._deflatedData);return this._init(),t}_init(){this._hasEvents=!1,this._deflatedData=[],this.deflate=new H,this.deflate.ondata=(t,n)=>{this._deflatedData.push(t)},this.stream=new N(((t,n)=>{this.deflate.push(t,n)})),this.stream.push(\"[\")}},V={clear:()=>{R.clear()},addEvent:t=>R.addEvent(t),finish:()=>R.finish(),compress:t=>Q(t)};addEventListener(\"message\",(function(t){const n=t.data.method,r=t.data.id,e=t.data.arg;if(n in V&&\"function\"==typeof V[n])try{const t=V[n](e);postMessage({id:r,method:n,success:!0,response:t})}catch(t){postMessage({id:r,method:n,success:!1,response:t.message}),console.error(t)}})),postMessage({id:void 0,method:\"init\",success:!0,response:void 0});`;\n","import r from\"./worker\";function e(){const e=new Blob([r]);return URL.createObjectURL(e)}export{e as getWorkerURL};\n","import type { ConsoleLevel, SeverityLevel } from '@sentry/core';\nimport { addBreadcrumb, captureException, logger as coreLogger, severityLevelFromString } from '@sentry/core';\nimport { DEBUG_BUILD } from '../debug-build';\n\ntype ReplayConsoleLevels = Extract<ConsoleLevel, 'info' | 'warn' | 'error' | 'log'>;\nconst CONSOLE_LEVELS: readonly ReplayConsoleLevels[] = ['info', 'warn', 'error', 'log'] as const;\nconst PREFIX = '[Replay] ';\n\ntype LoggerMethod = (...args: unknown[]) => void;\ntype LoggerConsoleMethods = Record<ReplayConsoleLevels, LoggerMethod>;\n\ninterface LoggerConfig {\n  captureExceptions: boolean;\n  traceInternals: boolean;\n}\n\ninterface ReplayLogger extends LoggerConsoleMethods {\n  /**\n   * Calls `logger.info` but saves breadcrumb in the next tick due to race\n   * conditions before replay is initialized.\n   */\n  infoTick: LoggerMethod;\n  /**\n   * Captures exceptions (`Error`) if \"capture internal exceptions\" is enabled\n   */\n  exception: LoggerMethod;\n  /**\n   * Configures the logger with additional debugging behavior\n   */\n  setConfig(config: LoggerConfig): void;\n}\n\nfunction _addBreadcrumb(message: unknown, level: SeverityLevel = 'info'): void {\n  addBreadcrumb(\n    {\n      category: 'console',\n      data: {\n        logger: 'replay',\n      },\n      level,\n      message: `${PREFIX}${message}`,\n    },\n    { level },\n  );\n}\n\nfunction makeReplayLogger(): ReplayLogger {\n  let _capture = false;\n  let _trace = false;\n\n  const _logger: Partial<ReplayLogger> = {\n    exception: () => undefined,\n    infoTick: () => undefined,\n    setConfig: (opts: LoggerConfig) => {\n      _capture = opts.captureExceptions;\n      _trace = opts.traceInternals;\n    },\n  };\n\n  if (DEBUG_BUILD) {\n    CONSOLE_LEVELS.forEach(name => {\n      _logger[name] = (...args: unknown[]) => {\n        coreLogger[name](PREFIX, ...args);\n        if (_trace) {\n          _addBreadcrumb(args.join(''), severityLevelFromString(name));\n        }\n      };\n    });\n\n    _logger.exception = (error: unknown, ...message: unknown[]) => {\n      if (message.length && _logger.error) {\n        _logger.error(...message);\n      }\n\n      coreLogger.error(PREFIX, error);\n\n      if (_capture) {\n        captureException(error);\n      } else if (_trace) {\n        // No need for a breadcrumb if `_capture` is enabled since it should be\n        // captured as an exception\n        _addBreadcrumb(error, 'error');\n      }\n    };\n\n    _logger.infoTick = (...args: unknown[]) => {\n      coreLogger.info(PREFIX, ...args);\n      if (_trace) {\n        // Wait a tick here to avoid race conditions for some initial logs\n        // which may be added before replay is initialized\n        setTimeout(() => _addBreadcrumb(args[0]), 0);\n      }\n    };\n  } else {\n    CONSOLE_LEVELS.forEach(name => {\n      _logger[name] = () => undefined;\n    });\n  }\n\n  return _logger as ReplayLogger;\n}\n\nexport const logger = makeReplayLogger();\n","import { REPLAY_MAX_EVENT_BUFFER_SIZE } from '../constants';\n\n/** This error indicates that the event buffer size exceeded the limit.. */\nexport class EventBufferSizeExceededError extends Error {\n  public constructor() {\n    super(`Event buffer exceeded maximum size of ${REPLAY_MAX_EVENT_BUFFER_SIZE}.`);\n  }\n}\n","import { REPLAY_MAX_EVENT_BUFFER_SIZE } from '../constants';\nimport type { AddEventResult, EventBuffer, EventBufferType, RecordingEvent } from '../types';\nimport { timestampToMs } from '../util/timestamp';\nimport { EventBufferSizeExceededError } from './error';\n\n/**\n * A basic event buffer that does not do any compression.\n * Used as fallback if the compression worker cannot be loaded or is disabled.\n */\nexport class EventBufferArray implements EventBuffer {\n  /** All the events that are buffered to be sent. */\n  public events: RecordingEvent[];\n\n  /** @inheritdoc */\n  public hasCheckout: boolean;\n\n  /** @inheritdoc */\n  public waitForCheckout: boolean;\n\n  private _totalSize: number;\n\n  public constructor() {\n    this.events = [];\n    this._totalSize = 0;\n    this.hasCheckout = false;\n    this.waitForCheckout = false;\n  }\n\n  /** @inheritdoc */\n  public get hasEvents(): boolean {\n    return this.events.length > 0;\n  }\n\n  /** @inheritdoc */\n  public get type(): EventBufferType {\n    return 'sync';\n  }\n\n  /** @inheritdoc */\n  public destroy(): void {\n    this.events = [];\n  }\n\n  /** @inheritdoc */\n  public async addEvent(event: RecordingEvent): Promise<AddEventResult> {\n    const eventSize = JSON.stringify(event).length;\n    this._totalSize += eventSize;\n    if (this._totalSize > REPLAY_MAX_EVENT_BUFFER_SIZE) {\n      throw new EventBufferSizeExceededError();\n    }\n\n    this.events.push(event);\n  }\n\n  /** @inheritdoc */\n  public finish(): Promise<string> {\n    return new Promise<string>(resolve => {\n      // Make a copy of the events array reference and immediately clear the\n      // events member so that we do not lose new events while uploading\n      // attachment.\n      const eventsRet = this.events;\n      this.clear();\n      resolve(JSON.stringify(eventsRet));\n    });\n  }\n\n  /** @inheritdoc */\n  public clear(): void {\n    this.events = [];\n    this._totalSize = 0;\n    this.hasCheckout = false;\n  }\n\n  /** @inheritdoc */\n  public getEarliestTimestamp(): number | null {\n    const timestamp = this.events.map(event => event.timestamp).sort()[0];\n\n    if (!timestamp) {\n      return null;\n    }\n\n    return timestampToMs(timestamp);\n  }\n}\n","import { DEBUG_BUILD } from '../debug-build';\nimport type { WorkerRequest, WorkerResponse } from '../types';\nimport { logger } from '../util/logger';\n\n/**\n * Event buffer that uses a web worker to compress events.\n * Exported only for testing.\n */\nexport class WorkerHandler {\n  private _worker: Worker;\n  private _id: number;\n  private _ensureReadyPromise?: Promise<void>;\n\n  public constructor(worker: Worker) {\n    this._worker = worker;\n    this._id = 0;\n  }\n\n  /**\n   * Ensure the worker is ready (or not).\n   * This will either resolve when the worker is ready, or reject if an error occurred.\n   */\n  public ensureReady(): Promise<void> {\n    // Ensure we only check once\n    if (this._ensureReadyPromise) {\n      return this._ensureReadyPromise;\n    }\n\n    this._ensureReadyPromise = new Promise((resolve, reject) => {\n      this._worker.addEventListener(\n        'message',\n        ({ data }: MessageEvent) => {\n          if ((data as WorkerResponse).success) {\n            resolve();\n          } else {\n            reject();\n          }\n        },\n        { once: true },\n      );\n\n      this._worker.addEventListener(\n        'error',\n        error => {\n          reject(error);\n        },\n        { once: true },\n      );\n    });\n\n    return this._ensureReadyPromise;\n  }\n\n  /**\n   * Destroy the worker.\n   */\n  public destroy(): void {\n    DEBUG_BUILD && logger.info('Destroying compression worker');\n    this._worker.terminate();\n  }\n\n  /**\n   * Post message to worker and wait for response before resolving promise.\n   */\n  public postMessage<T>(method: WorkerRequest['method'], arg?: WorkerRequest['arg']): Promise<T> {\n    const id = this._getAndIncrementId();\n\n    return new Promise((resolve, reject) => {\n      const listener = ({ data }: MessageEvent): void => {\n        const response = data as WorkerResponse;\n        if (response.method !== method) {\n          return;\n        }\n\n        // There can be multiple listeners for a single method, the id ensures\n        // that the response matches the caller.\n        if (response.id !== id) {\n          return;\n        }\n\n        // At this point, we'll always want to remove listener regardless of result status\n        this._worker.removeEventListener('message', listener);\n\n        if (!response.success) {\n          // TODO: Do some error handling, not sure what\n          DEBUG_BUILD && logger.error('Error in compression worker: ', response.response);\n\n          reject(new Error('Error in compression worker'));\n          return;\n        }\n\n        resolve(response.response as T);\n      };\n\n      // Note: we can't use `once` option because it's possible it needs to\n      // listen to multiple messages\n      this._worker.addEventListener('message', listener);\n      this._worker.postMessage({ id, method, arg });\n    });\n  }\n\n  /** Get the current ID and increment it for the next call. */\n  private _getAndIncrementId(): number {\n    return this._id++;\n  }\n}\n","import type { ReplayRecordingData } from '@sentry/core';\n\nimport { REPLAY_MAX_EVENT_BUFFER_SIZE } from '../constants';\nimport { DEBUG_BUILD } from '../debug-build';\nimport type { AddEventResult, EventBuffer, EventBufferType, RecordingEvent } from '../types';\nimport { logger } from '../util/logger';\nimport { timestampToMs } from '../util/timestamp';\nimport { WorkerHandler } from './WorkerHandler';\nimport { EventBufferSizeExceededError } from './error';\n\n/**\n * Event buffer that uses a web worker to compress events.\n * Exported only for testing.\n */\nexport class EventBufferCompressionWorker implements EventBuffer {\n  /** @inheritdoc */\n  public hasCheckout: boolean;\n\n  /** @inheritdoc */\n  public waitForCheckout: boolean;\n\n  private _worker: WorkerHandler;\n  private _earliestTimestamp: number | null;\n  private _totalSize;\n\n  public constructor(worker: Worker) {\n    this._worker = new WorkerHandler(worker);\n    this._earliestTimestamp = null;\n    this._totalSize = 0;\n    this.hasCheckout = false;\n    this.waitForCheckout = false;\n  }\n\n  /** @inheritdoc */\n  public get hasEvents(): boolean {\n    return !!this._earliestTimestamp;\n  }\n\n  /** @inheritdoc */\n  public get type(): EventBufferType {\n    return 'worker';\n  }\n\n  /**\n   * Ensure the worker is ready (or not).\n   * This will either resolve when the worker is ready, or reject if an error occurred.\n   */\n  public ensureReady(): Promise<void> {\n    return this._worker.ensureReady();\n  }\n\n  /**\n   * Destroy the event buffer.\n   */\n  public destroy(): void {\n    this._worker.destroy();\n  }\n\n  /**\n   * Add an event to the event buffer.\n   *\n   * Returns true if event was successfully received and processed by worker.\n   */\n  public addEvent(event: RecordingEvent): Promise<AddEventResult> {\n    const timestamp = timestampToMs(event.timestamp);\n    if (!this._earliestTimestamp || timestamp < this._earliestTimestamp) {\n      this._earliestTimestamp = timestamp;\n    }\n\n    const data = JSON.stringify(event);\n    this._totalSize += data.length;\n\n    if (this._totalSize > REPLAY_MAX_EVENT_BUFFER_SIZE) {\n      return Promise.reject(new EventBufferSizeExceededError());\n    }\n\n    return this._sendEventToWorker(data);\n  }\n\n  /**\n   * Finish the event buffer and return the compressed data.\n   */\n  public finish(): Promise<ReplayRecordingData> {\n    return this._finishRequest();\n  }\n\n  /** @inheritdoc */\n  public clear(): void {\n    this._earliestTimestamp = null;\n    this._totalSize = 0;\n    this.hasCheckout = false;\n\n    // We do not wait on this, as we assume the order of messages is consistent for the worker\n    this._worker.postMessage('clear').then(null, e => {\n      DEBUG_BUILD && logger.exception(e, 'Sending \"clear\" message to worker failed', e);\n    });\n  }\n\n  /** @inheritdoc */\n  public getEarliestTimestamp(): number | null {\n    return this._earliestTimestamp;\n  }\n\n  /**\n   * Send the event to the worker.\n   */\n  private _sendEventToWorker(data: string): Promise<AddEventResult> {\n    return this._worker.postMessage<void>('addEvent', data);\n  }\n\n  /**\n   * Finish the request and return the compressed data from the worker.\n   */\n  private async _finishRequest(): Promise<Uint8Array> {\n    const response = await this._worker.postMessage<Uint8Array>('finish');\n\n    this._earliestTimestamp = null;\n    this._totalSize = 0;\n\n    return response;\n  }\n}\n","import type { ReplayRecordingData } from '@sentry/core';\n\nimport { DEBUG_BUILD } from '../debug-build';\nimport type { AddEventResult, EventBuffer, EventBufferType, RecordingEvent } from '../types';\nimport { logger } from '../util/logger';\nimport { EventBufferArray } from './EventBufferArray';\nimport { EventBufferCompressionWorker } from './EventBufferCompressionWorker';\n\n/**\n * This proxy will try to use the compression worker, and fall back to use the simple buffer if an error occurs there.\n * This can happen e.g. if the worker cannot be loaded.\n * Exported only for testing.\n */\nexport class EventBufferProxy implements EventBuffer {\n  private _fallback: EventBufferArray;\n  private _compression: EventBufferCompressionWorker;\n  private _used: EventBuffer;\n  private _ensureWorkerIsLoadedPromise: Promise<void>;\n\n  public constructor(worker: Worker) {\n    this._fallback = new EventBufferArray();\n    this._compression = new EventBufferCompressionWorker(worker);\n    this._used = this._fallback;\n\n    this._ensureWorkerIsLoadedPromise = this._ensureWorkerIsLoaded();\n  }\n\n  /** @inheritdoc */\n  public get waitForCheckout(): boolean {\n    return this._used.waitForCheckout;\n  }\n\n  /** @inheritdoc */\n  public get type(): EventBufferType {\n    return this._used.type;\n  }\n\n  /** @inheritDoc */\n  public get hasEvents(): boolean {\n    return this._used.hasEvents;\n  }\n\n  /** @inheritdoc */\n  public get hasCheckout(): boolean {\n    return this._used.hasCheckout;\n  }\n  /** @inheritdoc */\n  public set hasCheckout(value: boolean) {\n    this._used.hasCheckout = value;\n  }\n\n  /** @inheritdoc */\n  // eslint-disable-next-line @typescript-eslint/adjacent-overload-signatures\n  public set waitForCheckout(value: boolean) {\n    this._used.waitForCheckout = value;\n  }\n\n  /** @inheritDoc */\n  public destroy(): void {\n    this._fallback.destroy();\n    this._compression.destroy();\n  }\n\n  /** @inheritdoc */\n  public clear(): void {\n    return this._used.clear();\n  }\n\n  /** @inheritdoc */\n  public getEarliestTimestamp(): number | null {\n    return this._used.getEarliestTimestamp();\n  }\n\n  /**\n   * Add an event to the event buffer.\n   *\n   * Returns true if event was successfully added.\n   */\n  public addEvent(event: RecordingEvent): Promise<AddEventResult> {\n    return this._used.addEvent(event);\n  }\n\n  /** @inheritDoc */\n  public async finish(): Promise<ReplayRecordingData> {\n    // Ensure the worker is loaded, so the sent event is compressed\n    await this.ensureWorkerIsLoaded();\n\n    return this._used.finish();\n  }\n\n  /** Ensure the worker has loaded. */\n  public ensureWorkerIsLoaded(): Promise<void> {\n    return this._ensureWorkerIsLoadedPromise;\n  }\n\n  /** Actually check if the worker has been loaded. */\n  private async _ensureWorkerIsLoaded(): Promise<void> {\n    try {\n      await this._compression.ensureReady();\n    } catch (error) {\n      // If the worker fails to load, we fall back to the simple buffer.\n      // Nothing more to do from our side here\n      DEBUG_BUILD && logger.exception(error, 'Failed to load the compression worker, falling back to simple buffer');\n      return;\n    }\n\n    // Now we need to switch over the array buffer to the compression worker\n    await this._switchToCompressionWorker();\n  }\n\n  /** Switch the used buffer to the compression worker. */\n  private async _switchToCompressionWorker(): Promise<void> {\n    const { events, hasCheckout, waitForCheckout } = this._fallback;\n\n    const addEventPromises: Promise<void>[] = [];\n    for (const event of events) {\n      addEventPromises.push(this._compression.addEvent(event));\n    }\n\n    this._compression.hasCheckout = hasCheckout;\n    this._compression.waitForCheckout = waitForCheckout;\n\n    // We switch over to the new buffer immediately - any further events will be added\n    // after the previously buffered ones\n    this._used = this._compression;\n\n    // Wait for original events to be re-added before resolving\n    try {\n      await Promise.all(addEventPromises);\n\n      // Can now clear fallback buffer as it's no longer necessary\n      this._fallback.clear();\n    } catch (error) {\n      DEBUG_BUILD && logger.exception(error, 'Failed to add events when switching buffers.');\n    }\n  }\n}\n","import { getWorkerURL } from '@sentry-internal/replay-worker';\n\nimport { DEBUG_BUILD } from '../debug-build';\nimport type { EventBuffer } from '../types';\nimport { logger } from '../util/logger';\nimport { EventBufferArray } from './EventBufferArray';\nimport { EventBufferProxy } from './EventBufferProxy';\n\ninterface CreateEventBufferParams {\n  useCompression: boolean;\n  workerUrl?: string;\n}\n\n// Treeshakable guard to remove the code of the included compression worker\ndeclare const __SENTRY_EXCLUDE_REPLAY_WORKER__: boolean;\n\n/**\n * Create an event buffer for replays.\n */\nexport function createEventBuffer({\n  useCompression,\n  workerUrl: customWorkerUrl,\n}: CreateEventBufferParams): EventBuffer {\n  if (\n    useCompression &&\n    // eslint-disable-next-line no-restricted-globals\n    window.Worker\n  ) {\n    const worker = _loadWorker(customWorkerUrl);\n\n    if (worker) {\n      return worker;\n    }\n  }\n\n  DEBUG_BUILD && logger.info('Using simple buffer');\n  return new EventBufferArray();\n}\n\nfunction _loadWorker(customWorkerUrl?: string): EventBufferProxy | void {\n  try {\n    const workerUrl = customWorkerUrl || _getWorkerUrl();\n\n    if (!workerUrl) {\n      return;\n    }\n\n    DEBUG_BUILD && logger.info(`Using compression worker${customWorkerUrl ? ` from ${customWorkerUrl}` : ''}`);\n    const worker = new Worker(workerUrl);\n    return new EventBufferProxy(worker);\n  } catch (error) {\n    DEBUG_BUILD && logger.exception(error, 'Failed to create compression worker');\n    // Fall back to use simple event buffer array\n  }\n}\n\nfunction _getWorkerUrl(): string {\n  if (typeof __SENTRY_EXCLUDE_REPLAY_WORKER__ === 'undefined' || !__SENTRY_EXCLUDE_REPLAY_WORKER__) {\n    return getWorkerURL();\n  }\n\n  return '';\n}\n","import { WINDOW } from '../constants';\n\n/** If sessionStorage is available. */\nexport function hasSessionStorage(): boolean {\n  try {\n    // This can throw, e.g. when being accessed in a sandboxed iframe\n    return 'sessionStorage' in WINDOW && !!WINDOW.sessionStorage;\n  } catch {\n    return false;\n  }\n}\n","import { REPLAY_SESSION_KEY, WINDOW } from '../../src/constants';\nimport type { ReplayContainer } from '../../src/types';\nimport { hasSessionStorage } from '../util/hasSessionStorage';\n\n/**\n * Removes the session from Session Storage and unsets session in replay instance\n */\nexport function clearSession(replay: ReplayContainer): void {\n  deleteSession();\n  replay.session = undefined;\n}\n\n/**\n * Deletes a session from storage\n */\nfunction deleteSession(): void {\n  if (!hasSessionStorage()) {\n    return;\n  }\n\n  try {\n    WINDOW.sessionStorage.removeItem(REPLAY_SESSION_KEY);\n  } catch {\n    // Ignore potential SecurityError exceptions\n  }\n}\n","/**\n * Given a sample rate, returns true if replay should be sampled.\n *\n * 1.0 = 100% sampling\n * 0.0 = 0% sampling\n */\nexport function isSampled(sampleRate?: number): boolean {\n  if (sampleRate === undefined) {\n    return false;\n  }\n\n  // Math.random() returns a number in range of 0 to 1 (inclusive of 0, but not 1)\n  return Math.random() < sampleRate;\n}\n","import { uuid4 } from '@sentry/core';\n\nimport type { Sampled, Session } from '../types';\n\n/**\n * Get a session with defaults & applied sampling.\n */\nexport function makeSession(session: Partial<Session> & { sampled: Sampled }): Session {\n  const now = Date.now();\n  const id = session.id || uuid4();\n  // Note that this means we cannot set a started/lastActivity of `0`, but this should not be relevant outside of tests.\n  const started = session.started || now;\n  const lastActivity = session.lastActivity || now;\n  const segmentId = session.segmentId || 0;\n  const sampled = session.sampled;\n  const previousSessionId = session.previousSessionId;\n\n  return {\n    id,\n    started,\n    lastActivity,\n    segmentId,\n    sampled,\n    previousSessionId,\n  };\n}\n","import { REPLAY_SESSION_KEY, WINDOW } from '../constants';\nimport type { Session } from '../types';\nimport { hasSessionStorage } from '../util/hasSessionStorage';\n\n/**\n * Save a session to session storage.\n */\nexport function saveSession(session: Session): void {\n  if (!hasSessionStorage()) {\n    return;\n  }\n\n  try {\n    WINDOW.sessionStorage.setItem(REPLAY_SESSION_KEY, JSON.stringify(session));\n  } catch {\n    // Ignore potential SecurityError exceptions\n  }\n}\n","import type { Sampled, Session, SessionOptions } from '../types';\nimport { isSampled } from '../util/isSampled';\nimport { makeSession } from './Session';\nimport { saveSession } from './saveSession';\n\n/**\n * Get the sampled status for a session based on sample rates & current sampled status.\n */\nexport function getSessionSampleType(sessionSampleRate: number, allowBuffering: boolean): Sampled {\n  return isSampled(sessionSampleRate) ? 'session' : allowBuffering ? 'buffer' : false;\n}\n\n/**\n * Create a new session, which in its current implementation is a Sentry event\n * that all replays will be saved to as attachments. Currently, we only expect\n * one of these Sentry events per \"replay session\".\n */\nexport function createSession(\n  { sessionSampleRate, allowBuffering, stickySession = false }: SessionOptions,\n  { previousSessionId }: { previousSessionId?: string } = {},\n): Session {\n  const sampled = getSessionSampleType(sessionSampleRate, allowBuffering);\n  const session = makeSession({\n    sampled,\n    previousSessionId,\n  });\n\n  if (stickySession) {\n    saveSession(session);\n  }\n\n  return session;\n}\n","import { REPLAY_SESSION_KEY, WINDOW } from '../constants';\nimport { DEBUG_BUILD } from '../debug-build';\nimport type { Session } from '../types';\nimport { hasSessionStorage } from '../util/hasSessionStorage';\nimport { logger } from '../util/logger';\nimport { makeSession } from './Session';\n\n/**\n * Fetches a session from storage\n */\nexport function fetchSession(): Session | null {\n  if (!hasSessionStorage()) {\n    return null;\n  }\n\n  try {\n    // This can throw if cookies are disabled\n    const sessionStringFromStorage = WINDOW.sessionStorage.getItem(REPLAY_SESSION_KEY);\n\n    if (!sessionStringFromStorage) {\n      return null;\n    }\n\n    const sessionObj = JSON.parse(sessionStringFromStorage) as Session;\n\n    DEBUG_BUILD && logger.infoTick('Loading existing session');\n\n    return makeSession(sessionObj);\n  } catch {\n    return null;\n  }\n}\n","/**\n * Given an initial timestamp and an expiry duration, checks to see if current\n * time should be considered as expired.\n */\nexport function isExpired(\n  initialTime: null | number,\n  expiry: undefined | number,\n  targetTime: number = +new Date(),\n): boolean {\n  // Always expired if < 0\n  if (initialTime === null || expiry === undefined || expiry < 0) {\n    return true;\n  }\n\n  // Never expires if == 0\n  if (expiry === 0) {\n    return false;\n  }\n\n  return initialTime + expiry <= targetTime;\n}\n","import type { Session } from '../types';\nimport { isExpired } from './isExpired';\n\n/**\n * Checks to see if session is expired\n */\nexport function isSessionExpired(\n  session: Session,\n  {\n    maxReplayDuration,\n    sessionIdleExpire,\n    targetTime = Date.now(),\n  }: { maxReplayDuration: number; sessionIdleExpire: number; targetTime?: number },\n): boolean {\n  return (\n    // First, check that maximum session length has not been exceeded\n    isExpired(session.started, maxReplayDuration, targetTime) ||\n    // check that the idle timeout has not been exceeded (i.e. user has\n    // performed an action within the last `sessionIdleExpire` ms)\n    isExpired(session.lastActivity, sessionIdleExpire, targetTime)\n  );\n}\n","import type { Session } from '../types';\nimport { isSessionExpired } from '../util/isSessionExpired';\n\n/** If the session should be refreshed or not. */\nexport function shouldRefreshSession(\n  session: Session,\n  { sessionIdleExpire, maxReplayDuration }: { sessionIdleExpire: number; maxReplayDuration: number },\n): boolean {\n  // If not expired, all good, just keep the session\n  if (!isSessionExpired(session, { sessionIdleExpire, maxReplayDuration })) {\n    return false;\n  }\n\n  // If we are buffering & haven't ever flushed yet, always continue\n  if (session.sampled === 'buffer' && session.segmentId === 0) {\n    return false;\n  }\n\n  return true;\n}\n","import { DEBUG_BUILD } from '../debug-build';\nimport type { Session, SessionOptions } from '../types';\nimport { logger } from '../util/logger';\nimport { createSession } from './createSession';\nimport { fetchSession } from './fetchSession';\nimport { shouldRefreshSession } from './shouldRefreshSession';\n\n/**\n * Get or create a session, when initializing the replay.\n * Returns a session that may be unsampled.\n */\nexport function loadOrCreateSession(\n  {\n    sessionIdleExpire,\n    maxReplayDuration,\n    previousSessionId,\n  }: {\n    sessionIdleExpire: number;\n    maxReplayDuration: number;\n    previousSessionId?: string;\n  },\n  sessionOptions: SessionOptions,\n): Session {\n  const existingSession = sessionOptions.stickySession && fetchSession();\n\n  // No session exists yet, just create a new one\n  if (!existingSession) {\n    DEBUG_BUILD && logger.infoTick('Creating new session');\n    return createSession(sessionOptions, { previousSessionId });\n  }\n\n  if (!shouldRefreshSession(existingSession, { sessionIdleExpire, maxReplayDuration })) {\n    return existingSession;\n  }\n\n  DEBUG_BUILD && logger.infoTick('Session in sessionStorage is expired, creating new one...');\n  return createSession(sessionOptions, { previousSessionId: existingSession.id });\n}\n","import { EventType } from '@sentry-internal/rrweb';\nimport { getClient } from '@sentry/core';\n\nimport { DEBUG_BUILD } from '../debug-build';\nimport { EventBufferSizeExceededError } from '../eventBuffer/error';\nimport type { AddEventResult, RecordingEvent, ReplayContainer, ReplayFrameEvent, ReplayPluginOptions } from '../types';\nimport { logger } from './logger';\nimport { timestampToMs } from './timestamp';\n\nfunction isCustomEvent(event: RecordingEvent): event is ReplayFrameEvent {\n  return event.type === EventType.Custom;\n}\n\n/**\n * Add an event to the event buffer.\n * In contrast to `addEvent`, this does not return a promise & does not wait for the adding of the event to succeed/fail.\n * Instead this returns `true` if we tried to add the event, else false.\n * It returns `false` e.g. if we are paused, disabled, or out of the max replay duration.\n *\n * `isCheckout` is true if this is either the very first event, or an event triggered by `checkoutEveryNms`.\n */\nexport function addEventSync(replay: ReplayContainer, event: RecordingEvent, isCheckout?: boolean): boolean {\n  if (!shouldAddEvent(replay, event)) {\n    return false;\n  }\n\n  // This should never reject\n  // eslint-disable-next-line @typescript-eslint/no-floating-promises\n  _addEvent(replay, event, isCheckout);\n\n  return true;\n}\n\n/**\n * Add an event to the event buffer.\n * Resolves to `null` if no event was added, else to `void`.\n *\n * `isCheckout` is true if this is either the very first event, or an event triggered by `checkoutEveryNms`.\n */\nexport function addEvent(\n  replay: ReplayContainer,\n  event: RecordingEvent,\n  isCheckout?: boolean,\n): Promise<AddEventResult | null> {\n  if (!shouldAddEvent(replay, event)) {\n    return Promise.resolve(null);\n  }\n\n  return _addEvent(replay, event, isCheckout);\n}\n\nasync function _addEvent(\n  replay: ReplayContainer,\n  event: RecordingEvent,\n  isCheckout?: boolean,\n): Promise<AddEventResult | null> {\n  const { eventBuffer } = replay;\n\n  if (!eventBuffer || (eventBuffer.waitForCheckout && !isCheckout)) {\n    return null;\n  }\n\n  const isBufferMode = replay.recordingMode === 'buffer';\n\n  try {\n    if (isCheckout && isBufferMode) {\n      eventBuffer.clear();\n    }\n\n    if (isCheckout) {\n      eventBuffer.hasCheckout = true;\n      eventBuffer.waitForCheckout = false;\n    }\n\n    const replayOptions = replay.getOptions();\n\n    const eventAfterPossibleCallback = maybeApplyCallback(event, replayOptions.beforeAddRecordingEvent);\n\n    if (!eventAfterPossibleCallback) {\n      return;\n    }\n\n    return await eventBuffer.addEvent(eventAfterPossibleCallback);\n  } catch (error) {\n    const isExceeded = error && error instanceof EventBufferSizeExceededError;\n    const reason = isExceeded ? 'addEventSizeExceeded' : 'addEvent';\n\n    if (isExceeded && isBufferMode) {\n      // Clear buffer and wait for next checkout\n      eventBuffer.clear();\n      eventBuffer.waitForCheckout = true;\n\n      return null;\n    }\n\n    replay.handleException(error);\n\n    await replay.stop({ reason });\n\n    const client = getClient();\n\n    if (client) {\n      client.recordDroppedEvent('internal_sdk_error', 'replay');\n    }\n  }\n}\n\n/** Exported only for tests. */\nexport function shouldAddEvent(replay: ReplayContainer, event: RecordingEvent): boolean {\n  if (!replay.eventBuffer || replay.isPaused() || !replay.isEnabled()) {\n    return false;\n  }\n\n  const timestampInMs = timestampToMs(event.timestamp);\n\n  // Throw out events that happen more than 5 minutes ago. This can happen if\n  // page has been left open and idle for a long period of time and user\n  // comes back to trigger a new session. The performance entries rely on\n  // `performance.timeOrigin`, which is when the page first opened.\n  if (timestampInMs + replay.timeouts.sessionIdlePause < Date.now()) {\n    return false;\n  }\n\n  // Throw out events that are +60min from the initial timestamp\n  if (timestampInMs > replay.getContext().initialTimestamp + replay.getOptions().maxReplayDuration) {\n    DEBUG_BUILD &&\n      logger.infoTick(`Skipping event with timestamp ${timestampInMs} because it is after maxReplayDuration`);\n    return false;\n  }\n\n  return true;\n}\n\nfunction maybeApplyCallback(\n  event: RecordingEvent,\n  callback: ReplayPluginOptions['beforeAddRecordingEvent'],\n): RecordingEvent | null | undefined {\n  try {\n    if (typeof callback === 'function' && isCustomEvent(event)) {\n      return callback(event);\n    }\n  } catch (error) {\n    DEBUG_BUILD &&\n      logger.exception(error, 'An error occurred in the `beforeAddRecordingEvent` callback, skipping the event...');\n    return null;\n  }\n\n  return event;\n}\n","import type { ErrorEvent, Event, FeedbackEvent, ReplayEvent, TransactionEvent } from '@sentry/core';\n\n/** If the event is an error event */\nexport function isErrorEvent(event: Event): event is ErrorEvent {\n  return !event.type;\n}\n\n/** If the event is a transaction event */\nexport function isTransactionEvent(event: Event): event is TransactionEvent {\n  return event.type === 'transaction';\n}\n\n/** If the event is an replay event */\nexport function isReplayEvent(event: Event): event is ReplayEvent {\n  return event.type === 'replay_event';\n}\n\n/** If the event is a feedback event */\nexport function isFeedbackEvent(event: Event): event is FeedbackEvent {\n  return event.type === 'feedback';\n}\n","import { setTimeout } from '@sentry-internal/browser-utils';\nimport type { ErrorEvent, Event, TransactionEvent, TransportMakeRequestResponse } from '@sentry/core';\n\nimport type { ReplayContainer } from '../types';\nimport { isErrorEvent, isTransactionEvent } from '../util/eventUtils';\n\ntype AfterSendEventCallback = (event: Event, sendResponse: TransportMakeRequestResponse) => void;\n\n/**\n * Returns a listener to be added to `client.on('afterSendErrorEvent, listener)`.\n */\nexport function handleAfterSendEvent(replay: ReplayContainer): AfterSendEventCallback {\n  return (event: Event, sendResponse: TransportMakeRequestResponse) => {\n    if (!replay.isEnabled() || (!isErrorEvent(event) && !isTransactionEvent(event))) {\n      return;\n    }\n\n    const statusCode = sendResponse && sendResponse.statusCode;\n\n    // We only want to do stuff on successful error sending, otherwise you get error replays without errors attached\n    // If not using the base transport, we allow `undefined` response (as a custom transport may not implement this correctly yet)\n    // If we do use the base transport, we skip if we encountered an non-OK status code\n    if (!statusCode || statusCode < 200 || statusCode >= 300) {\n      return;\n    }\n\n    if (isTransactionEvent(event)) {\n      handleTransactionEvent(replay, event);\n      return;\n    }\n\n    handleErrorEvent(replay, event);\n  };\n}\n\nfunction handleTransactionEvent(replay: ReplayContainer, event: TransactionEvent): void {\n  const replayContext = replay.getContext();\n\n  // Collect traceIds in _context regardless of `recordingMode`\n  // In error mode, _context gets cleared on every checkout\n  // We limit to max. 100 transactions linked\n  if (event.contexts && event.contexts.trace && event.contexts.trace.trace_id && replayContext.traceIds.size < 100) {\n    replayContext.traceIds.add(event.contexts.trace.trace_id as string);\n  }\n}\n\nfunction handleErrorEvent(replay: ReplayContainer, event: ErrorEvent): void {\n  const replayContext = replay.getContext();\n\n  // Add error to list of errorIds of replay. This is ok to do even if not\n  // sampled because context will get reset at next checkout.\n  // XXX: There is also a race condition where it's possible to capture an\n  // error to Sentry before Replay SDK has loaded, but response returns after\n  // it was loaded, and this gets called.\n  // We limit to max. 100 errors linked\n  if (event.event_id && replayContext.errorIds.size < 100) {\n    replayContext.errorIds.add(event.event_id);\n  }\n\n  // If error event is tagged with replay id it means it was sampled (when in buffer mode)\n  // Need to be very careful that this does not cause an infinite loop\n  if (replay.recordingMode !== 'buffer' || !event.tags || !event.tags.replayId) {\n    return;\n  }\n\n  const { beforeErrorSampling } = replay.getOptions();\n  if (typeof beforeErrorSampling === 'function' && !beforeErrorSampling(event)) {\n    return;\n  }\n\n  setTimeout(async () => {\n    try {\n      // Capture current event buffer as new replay\n      await replay.sendBufferedReplayOrFlush();\n    } catch (err) {\n      replay.handleException(err);\n    }\n  });\n}\n","import { getLocationHref } from '@sentry/core';\nimport type { ErrorEvent, Event } from '@sentry/core';\n\nimport type { ReplayContainer } from '../types';\nimport { createBreadcrumb } from '../util/createBreadcrumb';\nimport { isErrorEvent } from '../util/eventUtils';\nimport { addBreadcrumbEvent } from './util/addBreadcrumbEvent';\n\ntype BeforeSendEventCallback = (event: Event) => void;\n\n/**\n * Returns a listener to be added to `client.on('afterSendErrorEvent, listener)`.\n */\nexport function handleBeforeSendEvent(replay: ReplayContainer): BeforeSendEventCallback {\n  return (event: Event) => {\n    if (!replay.isEnabled() || !isErrorEvent(event)) {\n      return;\n    }\n\n    handleHydrationError(replay, event);\n  };\n}\n\nfunction handleHydrationError(replay: ReplayContainer, event: ErrorEvent): void {\n  const exceptionValue =\n    event.exception && event.exception.values && event.exception.values[0] && event.exception.values[0].value;\n  if (typeof exceptionValue !== 'string') {\n    return;\n  }\n\n  if (\n    // Only matches errors in production builds of react-dom\n    // Example https://reactjs.org/docs/error-decoder.html?invariant=423\n    // With newer React versions, the messages changed to a different website https://react.dev/errors/418\n    exceptionValue.match(\n      /(reactjs\\.org\\/docs\\/error-decoder\\.html\\?invariant=|react\\.dev\\/errors\\/)(418|419|422|423|425)/,\n    ) ||\n    // Development builds of react-dom\n    // Error 1: Hydration failed because the initial UI does not match what was rendered on the server.\n    // Error 2: Text content does not match server-rendered HTML. Warning: Text content did not match.\n    exceptionValue.match(/(does not match server-rendered HTML|Hydration failed because)/i)\n  ) {\n    const breadcrumb = createBreadcrumb({\n      category: 'replay.hydrate-error',\n      data: {\n        url: getLocationHref(),\n      },\n    });\n    addBreadcrumbEvent(replay, breadcrumb);\n  }\n}\n","import type { Breadcrumb } from '@sentry/core';\nimport { getClient, normalize } from '@sentry/core';\nimport { CONSOLE_ARG_MAX_SIZE } from '../constants';\nimport type { ReplayContainer } from '../types';\nimport type { ReplayFrame } from '../types/replayFrame';\nimport { createBreadcrumb } from '../util/createBreadcrumb';\nimport { addBreadcrumbEvent } from './util/addBreadcrumbEvent';\n\ntype BreadcrumbWithCategory = Required<Pick<Breadcrumb, 'category'>>;\n\n/**\n * Handle breadcrumbs that Sentry captures, and make sure to capture relevant breadcrumbs to Replay as well.\n */\nexport function handleBreadcrumbs(replay: ReplayContainer): void {\n  const client = getClient();\n\n  if (!client) {\n    return;\n  }\n\n  client.on('beforeAddBreadcrumb', breadcrumb => beforeAddBreadcrumb(replay, breadcrumb));\n}\n\nfunction beforeAddBreadcrumb(replay: ReplayContainer, breadcrumb: Breadcrumb): void {\n  if (!replay.isEnabled() || !isBreadcrumbWithCategory(breadcrumb)) {\n    return;\n  }\n\n  const result = normalizeBreadcrumb(breadcrumb);\n  if (result) {\n    addBreadcrumbEvent(replay, result);\n  }\n}\n\n/** Exported only for tests. */\nexport function normalizeBreadcrumb(breadcrumb: Breadcrumb): Breadcrumb | null {\n  if (\n    !isBreadcrumbWithCategory(breadcrumb) ||\n    [\n      // fetch & xhr are handled separately,in handleNetworkBreadcrumbs\n      'fetch',\n      'xhr',\n      // These two are breadcrumbs for emitted sentry events, we don't care about them\n      'sentry.event',\n      'sentry.transaction',\n    ].includes(breadcrumb.category) ||\n    // We capture UI breadcrumbs separately\n    breadcrumb.category.startsWith('ui.')\n  ) {\n    return null;\n  }\n\n  if (breadcrumb.category === 'console') {\n    return normalizeConsoleBreadcrumb(breadcrumb);\n  }\n\n  return createBreadcrumb(breadcrumb);\n}\n\n/** exported for tests only */\nexport function normalizeConsoleBreadcrumb(\n  breadcrumb: Omit<Breadcrumb, 'category'> & BreadcrumbWithCategory,\n): ReplayFrame {\n  const args = breadcrumb.data && breadcrumb.data.arguments;\n\n  if (!Array.isArray(args) || args.length === 0) {\n    return createBreadcrumb(breadcrumb);\n  }\n\n  let isTruncated = false;\n\n  // Avoid giant args captures\n  const normalizedArgs = args.map(arg => {\n    if (!arg) {\n      return arg;\n    }\n    if (typeof arg === 'string') {\n      if (arg.length > CONSOLE_ARG_MAX_SIZE) {\n        isTruncated = true;\n        return `${arg.slice(0, CONSOLE_ARG_MAX_SIZE)}…`;\n      }\n\n      return arg;\n    }\n    if (typeof arg === 'object') {\n      try {\n        const normalizedArg = normalize(arg, 7);\n        const stringified = JSON.stringify(normalizedArg);\n        if (stringified.length > CONSOLE_ARG_MAX_SIZE) {\n          isTruncated = true;\n          // We use the pretty printed JSON string here as a base\n          return `${JSON.stringify(normalizedArg, null, 2).slice(0, CONSOLE_ARG_MAX_SIZE)}…`;\n        }\n        return normalizedArg;\n      } catch {\n        // fall back to default\n      }\n    }\n\n    return arg;\n  });\n\n  return createBreadcrumb({\n    ...breadcrumb,\n    data: {\n      ...breadcrumb.data,\n      arguments: normalizedArgs,\n      ...(isTruncated ? { _meta: { warnings: ['CONSOLE_ARG_TRUNCATED'] } } : {}),\n    },\n  });\n}\n\nfunction isBreadcrumbWithCategory(breadcrumb: Breadcrumb): breadcrumb is BreadcrumbWithCategory {\n  return !!breadcrumb.category;\n}\n","import type { Event, EventHint } from '@sentry/core';\n\n/**\n * Returns true if we think the given event is an error originating inside of rrweb.\n */\nexport function isRrwebError(event: Event, hint: EventHint): boolean {\n  if (event.type || !event.exception || !event.exception.values || !event.exception.values.length) {\n    return false;\n  }\n\n  // @ts-expect-error this may be set by rrweb when it finds errors\n  if (hint.originalException && hint.originalException.__rrweb__) {\n    return true;\n  }\n\n  return false;\n}\n","import { getActiveSpan, getCurrentScope, getDynamicSamplingContextFromSpan } from '@sentry/core';\nimport type { DynamicSamplingContext } from '@sentry/core';\n\n/**\n * Reset the `replay_id` field on the DSC.\n */\nexport function resetReplayIdOnDynamicSamplingContext(): void {\n  // Reset DSC on the current scope, if there is one\n  const dsc = getCurrentScope().getPropagationContext().dsc;\n  if (dsc) {\n    delete dsc.replay_id;\n  }\n\n  // Clear it from frozen DSC on the active span\n  const activeSpan = getActiveSpan();\n  if (activeSpan) {\n    const dsc = getDynamicSamplingContextFromSpan(activeSpan);\n    delete (dsc as Partial<DynamicSamplingContext>).replay_id;\n  }\n}\n","import { EventType } from '@sentry-internal/rrweb';\nimport type { FeedbackEvent } from '@sentry/core';\n\nimport type { ReplayBreadcrumbFrameEvent, ReplayContainer } from '../../types';\n\n/**\n * Add a feedback breadcrumb event to replay.\n */\nexport function addFeedbackBreadcrumb(replay: ReplayContainer, event: FeedbackEvent): void {\n  replay.triggerUserActivity();\n  replay.addUpdate(() => {\n    if (!event.timestamp) {\n      // Ignore events that don't have timestamps (this shouldn't happen, more of a typing issue)\n      // Return true here so that we don't flush\n      return true;\n    }\n\n    // This should never reject\n    // eslint-disable-next-line @typescript-eslint/no-floating-promises\n    replay.throttledAddEvent({\n      type: EventType.Custom,\n      timestamp: event.timestamp * 1000,\n      data: {\n        tag: 'breadcrumb',\n        payload: {\n          timestamp: event.timestamp,\n          type: 'default',\n          category: 'sentry.feedback',\n          data: {\n            feedbackId: event.event_id,\n          },\n        },\n      },\n    } as ReplayBreadcrumbFrameEvent);\n\n    return false;\n  });\n}\n","import type { Event } from '@sentry/core';\n\nimport { UNABLE_TO_SEND_REPLAY } from '../../constants';\nimport type { ReplayContainer } from '../../types';\nimport { isSampled } from '../../util/isSampled';\n\n/**\n * Determine if event should be sampled (only applies in buffer mode).\n * When an event is captured by `handleGlobalEvent`, when in buffer mode\n * we determine if we want to sample the error or not.\n */\nexport function shouldSampleForBufferEvent(replay: ReplayContainer, event: Event): boolean {\n  if (replay.recordingMode !== 'buffer') {\n    return false;\n  }\n\n  // ignore this error because otherwise we could loop indefinitely with\n  // trying to capture replay and failing\n  if (event.message === UNABLE_TO_SEND_REPLAY) {\n    return false;\n  }\n\n  // Require the event to be an error event & to have an exception\n  if (!event.exception || event.type) {\n    return false;\n  }\n\n  return isSampled(replay.getOptions().errorSampleRate);\n}\n","import type { Event, EventHint } from '@sentry/core';\n\nimport { DEBUG_BUILD } from '../debug-build';\nimport type { ReplayContainer } from '../types';\nimport { isErrorEvent, isFeedbackEvent, isReplayEvent, isTransactionEvent } from '../util/eventUtils';\nimport { isRrwebError } from '../util/isRrwebError';\nimport { logger } from '../util/logger';\nimport { resetReplayIdOnDynamicSamplingContext } from '../util/resetReplayIdOnDynamicSamplingContext';\nimport { addFeedbackBreadcrumb } from './util/addFeedbackBreadcrumb';\nimport { shouldSampleForBufferEvent } from './util/shouldSampleForBufferEvent';\n\n/**\n * Returns a listener to be added to `addEventProcessor(listener)`.\n */\nexport function handleGlobalEventListener(replay: ReplayContainer): (event: Event, hint: EventHint) => Event | null {\n  return Object.assign(\n    (event: Event, hint: EventHint) => {\n      // Do nothing if replay has been disabled or paused\n      if (!replay.isEnabled() || replay.isPaused()) {\n        return event;\n      }\n\n      if (isReplayEvent(event)) {\n        // Replays have separate set of breadcrumbs, do not include breadcrumbs\n        // from core SDK\n        delete event.breadcrumbs;\n        return event;\n      }\n\n      // We only want to handle errors, transactions, and feedbacks, nothing else\n      if (!isErrorEvent(event) && !isTransactionEvent(event) && !isFeedbackEvent(event)) {\n        return event;\n      }\n\n      // Ensure we do not add replay_id if the session is expired\n      const isSessionActive = replay.checkAndHandleExpiredSession();\n      if (!isSessionActive) {\n        // prevent exceeding replay durations by removing the expired replayId from the DSC\n        resetReplayIdOnDynamicSamplingContext();\n        return event;\n      }\n\n      if (isFeedbackEvent(event)) {\n        // This should never reject\n        // eslint-disable-next-line @typescript-eslint/no-floating-promises\n        replay.flush();\n        event.contexts.feedback.replay_id = replay.getSessionId();\n        // Add a replay breadcrumb for this piece of feedback\n        addFeedbackBreadcrumb(replay, event);\n        return event;\n      }\n\n      // Unless `captureExceptions` is enabled, we want to ignore errors coming from rrweb\n      // As there can be a bunch of stuff going wrong in internals there, that we don't want to bubble up to users\n      if (isRrwebError(event, hint) && !replay.getOptions()._experiments.captureExceptions) {\n        DEBUG_BUILD && logger.log('Ignoring error from rrweb internals', event);\n        return null;\n      }\n\n      // When in buffer mode, we decide to sample here.\n      // Later, in `handleAfterSendEvent`, if the replayId is set, we know that we sampled\n      // And convert the buffer session to a full session\n      const isErrorEventSampled = shouldSampleForBufferEvent(replay, event);\n\n      // Tag errors if it has been sampled in buffer mode, or if it is session mode\n      // Only tag transactions if in session mode\n      const shouldTagReplayId = isErrorEventSampled || replay.recordingMode === 'session';\n\n      if (shouldTagReplayId) {\n        event.tags = { ...event.tags, replayId: replay.getSessionId() };\n      }\n\n      return event;\n    },\n    { id: 'Replay' },\n  );\n}\n","import { EventType } from '@sentry-internal/rrweb';\n\nimport type { AddEventResult, AllEntryData, ReplayContainer, ReplayPerformanceEntry } from '../types';\n\n/**\n * Create a \"span\" for each performance entry.\n */\nexport function createPerformanceSpans(\n  replay: ReplayContainer,\n  entries: ReplayPerformanceEntry<AllEntryData>[],\n): Promise<AddEventResult | null>[] {\n  return entries.map(({ type, start, end, name, data }) => {\n    const response = replay.throttledAddEvent({\n      type: EventType.Custom,\n      timestamp: start,\n      data: {\n        tag: 'performanceSpan',\n        payload: {\n          op: type,\n          description: name,\n          startTimestamp: start,\n          endTimestamp: end,\n          data,\n        },\n      },\n    });\n\n    // If response is a string, it means its either THROTTLED or SKIPPED\n    return typeof response === 'string' ? Promise.resolve(null) : response;\n  });\n}\n","import type { HandlerDataHistory } from '@sentry/core';\n\nimport type { HistoryData, ReplayContainer, ReplayPerformanceEntry } from '../types';\nimport { createPerformanceSpans } from '../util/createPerformanceSpans';\n\nfunction handleHistory(handlerData: HandlerDataHistory): ReplayPerformanceEntry<HistoryData> {\n  const { from, to } = handlerData;\n\n  const now = Date.now() / 1000;\n\n  return {\n    type: 'navigation.push',\n    start: now,\n    end: now,\n    name: to,\n    data: {\n      previous: from,\n    },\n  };\n}\n\n/**\n * Returns a listener to be added to `addHistoryInstrumentationHandler(listener)`.\n */\nexport function handleHistorySpanListener(replay: ReplayContainer): (handlerData: HandlerDataHistory) => void {\n  return (handlerData: HandlerDataHistory) => {\n    if (!replay.isEnabled()) {\n      return;\n    }\n\n    const result = handleHistory(handlerData);\n\n    if (result === null) {\n      return;\n    }\n\n    // Need to collect visited URLs\n    replay.getContext().urls.push(result.name);\n    replay.triggerUserActivity();\n\n    replay.addUpdate(() => {\n      createPerformanceSpans(replay, [result]);\n      // Returning false to flush\n      return false;\n    });\n  };\n}\n","import { getClient, isSentryRequestUrl } from '@sentry/core';\n\nimport { DEBUG_BUILD } from '../debug-build';\nimport type { ReplayContainer } from '../types';\n\n/**\n * Check whether a given request URL should be filtered out. This is so we\n * don't log Sentry ingest requests.\n */\nexport function shouldFilterRequest(replay: ReplayContainer, url: string): boolean {\n  // If we enabled the `traceInternals` experiment, we want to trace everything\n  if (DEBUG_BUILD && replay.getOptions()._experiments.traceInternals) {\n    return false;\n  }\n\n  return isSentryRequestUrl(url, getClient());\n}\n","import type { NetworkRequestData, ReplayContainer, ReplayPerformanceEntry } from '../../types';\nimport { createPerformanceSpans } from '../../util/createPerformanceSpans';\nimport { shouldFilterRequest } from '../../util/shouldFilterRequest';\n\n/** Add a performance entry breadcrumb */\nexport function addNetworkBreadcrumb(\n  replay: ReplayContainer,\n  result: ReplayPerformanceEntry<NetworkRequestData> | null,\n): void {\n  if (!replay.isEnabled()) {\n    return;\n  }\n\n  if (result === null) {\n    return;\n  }\n\n  if (shouldFilterRequest(replay, result.name)) {\n    return;\n  }\n\n  replay.addUpdate(() => {\n    createPerformanceSpans(replay, [result]);\n    // Returning true will cause `addUpdate` to not flush\n    // We do not want network requests to cause a flush. This will prevent\n    // recurring/polling requests from keeping the replay session alive.\n    return true;\n  });\n}\n","import { dropUndefinedKeys, stringMatchesSomePattern } from '@sentry/core';\n\nimport { NETWORK_BODY_MAX_SIZE, WINDOW } from '../../constants';\nimport { DEBUG_BUILD } from '../../debug-build';\nimport type {\n  NetworkBody,\n  NetworkMetaWarning,\n  NetworkRequestData,\n  ReplayNetworkRequestData,\n  ReplayNetworkRequestOrResponse,\n  ReplayPerformanceEntry,\n} from '../../types';\nimport { logger } from '../../util/logger';\n\n/** Get the size of a body. */\nexport function getBodySize(body: RequestInit['body']): number | undefined {\n  if (!body) {\n    return undefined;\n  }\n\n  const textEncoder = new TextEncoder();\n\n  try {\n    if (typeof body === 'string') {\n      return textEncoder.encode(body).length;\n    }\n\n    if (body instanceof URLSearchParams) {\n      return textEncoder.encode(body.toString()).length;\n    }\n\n    if (body instanceof FormData) {\n      const formDataStr = _serializeFormData(body);\n      return textEncoder.encode(formDataStr).length;\n    }\n\n    if (body instanceof Blob) {\n      return body.size;\n    }\n\n    if (body instanceof ArrayBuffer) {\n      return body.byteLength;\n    }\n\n    // Currently unhandled types: ArrayBufferView, ReadableStream\n  } catch {\n    // just return undefined\n  }\n\n  return undefined;\n}\n\n/** Convert a Content-Length header to number/undefined.  */\nexport function parseContentLengthHeader(header: string | null | undefined): number | undefined {\n  if (!header) {\n    return undefined;\n  }\n\n  const size = parseInt(header, 10);\n  return isNaN(size) ? undefined : size;\n}\n\n/** Get the string representation of a body. */\nexport function getBodyString(body: unknown): [string | undefined, NetworkMetaWarning?] {\n  try {\n    if (typeof body === 'string') {\n      return [body];\n    }\n\n    if (body instanceof URLSearchParams) {\n      return [body.toString()];\n    }\n\n    if (body instanceof FormData) {\n      return [_serializeFormData(body)];\n    }\n\n    if (!body) {\n      return [undefined];\n    }\n  } catch (error) {\n    DEBUG_BUILD && logger.exception(error, 'Failed to serialize body', body);\n    return [undefined, 'BODY_PARSE_ERROR'];\n  }\n\n  DEBUG_BUILD && logger.info('Skipping network body because of body type', body);\n\n  return [undefined, 'UNPARSEABLE_BODY_TYPE'];\n}\n\n/** Merge a warning into an existing network request/response. */\nexport function mergeWarning(\n  info: ReplayNetworkRequestOrResponse | undefined,\n  warning: NetworkMetaWarning,\n): ReplayNetworkRequestOrResponse {\n  if (!info) {\n    return {\n      headers: {},\n      size: undefined,\n      _meta: {\n        warnings: [warning],\n      },\n    };\n  }\n\n  const newMeta = { ...info._meta };\n  const existingWarnings = newMeta.warnings || [];\n  newMeta.warnings = [...existingWarnings, warning];\n\n  info._meta = newMeta;\n  return info;\n}\n\n/** Convert ReplayNetworkRequestData to a PerformanceEntry. */\nexport function makeNetworkReplayBreadcrumb(\n  type: string,\n  data: ReplayNetworkRequestData | null,\n): ReplayPerformanceEntry<NetworkRequestData> | null {\n  if (!data) {\n    return null;\n  }\n\n  const { startTimestamp, endTimestamp, url, method, statusCode, request, response } = data;\n\n  const result: ReplayPerformanceEntry<NetworkRequestData> = {\n    type,\n    start: startTimestamp / 1000,\n    end: endTimestamp / 1000,\n    name: url,\n    data: dropUndefinedKeys({\n      method,\n      statusCode,\n      request,\n      response,\n    }),\n  };\n\n  return result;\n}\n\n/** Build the request or response part of a replay network breadcrumb that was skipped. */\nexport function buildSkippedNetworkRequestOrResponse(bodySize: number | undefined): ReplayNetworkRequestOrResponse {\n  return {\n    headers: {},\n    size: bodySize,\n    _meta: {\n      warnings: ['URL_SKIPPED'],\n    },\n  };\n}\n\n/** Build the request or response part of a replay network breadcrumb. */\nexport function buildNetworkRequestOrResponse(\n  headers: Record<string, string>,\n  bodySize: number | undefined,\n  body: string | undefined,\n): ReplayNetworkRequestOrResponse | undefined {\n  if (!bodySize && Object.keys(headers).length === 0) {\n    return undefined;\n  }\n\n  if (!bodySize) {\n    return {\n      headers,\n    };\n  }\n\n  if (!body) {\n    return {\n      headers,\n      size: bodySize,\n    };\n  }\n\n  const info: ReplayNetworkRequestOrResponse = {\n    headers,\n    size: bodySize,\n  };\n\n  const { body: normalizedBody, warnings } = normalizeNetworkBody(body);\n  info.body = normalizedBody;\n  if (warnings && warnings.length > 0) {\n    info._meta = {\n      warnings,\n    };\n  }\n\n  return info;\n}\n\n/** Filter a set of headers */\nexport function getAllowedHeaders(headers: Record<string, string>, allowedHeaders: string[]): Record<string, string> {\n  return Object.entries(headers).reduce((filteredHeaders: Record<string, string>, [key, value]) => {\n    const normalizedKey = key.toLowerCase();\n    // Avoid putting empty strings into the headers\n    if (allowedHeaders.includes(normalizedKey) && headers[key]) {\n      filteredHeaders[normalizedKey] = value;\n    }\n    return filteredHeaders;\n  }, {});\n}\n\nfunction _serializeFormData(formData: FormData): string {\n  // This is a bit simplified, but gives us a decent estimate\n  // This converts e.g. { name: 'Anne Smith', age: 13 } to 'name=Anne+Smith&age=13'\n  // @ts-expect-error passing FormData to URLSearchParams actually works\n  return new URLSearchParams(formData).toString();\n}\n\nfunction normalizeNetworkBody(body: string | undefined): {\n  body: NetworkBody | undefined;\n  warnings?: NetworkMetaWarning[];\n} {\n  if (!body || typeof body !== 'string') {\n    return {\n      body,\n    };\n  }\n\n  const exceedsSizeLimit = body.length > NETWORK_BODY_MAX_SIZE;\n  const isProbablyJson = _strIsProbablyJson(body);\n\n  if (exceedsSizeLimit) {\n    const truncatedBody = body.slice(0, NETWORK_BODY_MAX_SIZE);\n\n    if (isProbablyJson) {\n      return {\n        body: truncatedBody,\n        warnings: ['MAYBE_JSON_TRUNCATED'],\n      };\n    }\n\n    return {\n      body: `${truncatedBody}…`,\n      warnings: ['TEXT_TRUNCATED'],\n    };\n  }\n\n  if (isProbablyJson) {\n    try {\n      const jsonBody = JSON.parse(body);\n      return {\n        body: jsonBody,\n      };\n    } catch {\n      // fall back to just send the body as string\n    }\n  }\n\n  return {\n    body,\n  };\n}\n\nfunction _strIsProbablyJson(str: string): boolean {\n  const first = str[0];\n  const last = str[str.length - 1];\n\n  // Simple check: If this does not start & end with {} or [], it's not JSON\n  return (first === '[' && last === ']') || (first === '{' && last === '}');\n}\n\n/** Match an URL against a list of strings/Regex. */\nexport function urlMatches(url: string, urls: (string | RegExp)[]): boolean {\n  const fullUrl = getFullUrl(url);\n\n  return stringMatchesSomePattern(fullUrl, urls);\n}\n\n/** exported for tests */\nexport function getFullUrl(url: string, baseURI = WINDOW.document.baseURI): string {\n  // Short circuit for common cases:\n  if (url.startsWith('http://') || url.startsWith('https://') || url.startsWith(WINDOW.location.origin)) {\n    return url;\n  }\n  const fixedUrl = new URL(url, baseURI);\n\n  // If these do not match, we are not dealing with a relative URL, so just return it\n  if (fixedUrl.origin !== new URL(baseURI).origin) {\n    return url;\n  }\n\n  const fullUrl = fixedUrl.href;\n\n  // Remove trailing slashes, if they don't match the original URL\n  if (!url.endsWith('/') && fullUrl.endsWith('/')) {\n    return fullUrl.slice(0, -1);\n  }\n\n  return fullUrl;\n}\n","import { setTimeout } from '@sentry-internal/browser-utils';\nimport type { Breadcrumb, FetchBreadcrumbData } from '@sentry/core';\n\nimport { DEBUG_BUILD } from '../../debug-build';\nimport type {\n  FetchHint,\n  NetworkMetaWarning,\n  ReplayContainer,\n  ReplayNetworkOptions,\n  ReplayNetworkRequestData,\n  ReplayNetworkRequestOrResponse,\n} from '../../types';\nimport { logger } from '../../util/logger';\nimport { addNetworkBreadcrumb } from './addNetworkBreadcrumb';\nimport {\n  buildNetworkRequestOrResponse,\n  buildSkippedNetworkRequestOrResponse,\n  getAllowedHeaders,\n  getBodySize,\n  getBodyString,\n  makeNetworkReplayBreadcrumb,\n  mergeWarning,\n  parseContentLengthHeader,\n  urlMatches,\n} from './networkUtils';\n\n/**\n * Capture a fetch breadcrumb to a replay.\n * This adds additional data (where appropriate).\n */\nexport async function captureFetchBreadcrumbToReplay(\n  breadcrumb: Breadcrumb & { data: FetchBreadcrumbData },\n  hint: Partial<FetchHint>,\n  options: ReplayNetworkOptions & {\n    replay: ReplayContainer;\n  },\n): Promise<void> {\n  try {\n    const data = await _prepareFetchData(breadcrumb, hint, options);\n\n    // Create a replay performance entry from this breadcrumb\n    const result = makeNetworkReplayBreadcrumb('resource.fetch', data);\n    addNetworkBreadcrumb(options.replay, result);\n  } catch (error) {\n    DEBUG_BUILD && logger.exception(error, 'Failed to capture fetch breadcrumb');\n  }\n}\n\n/**\n * Enrich a breadcrumb with additional data.\n * This has to be sync & mutate the given breadcrumb,\n * as the breadcrumb is afterwards consumed by other handlers.\n */\nexport function enrichFetchBreadcrumb(\n  breadcrumb: Breadcrumb & { data: FetchBreadcrumbData },\n  hint: Partial<FetchHint>,\n): void {\n  const { input, response } = hint;\n\n  const body = input ? _getFetchRequestArgBody(input) : undefined;\n  const reqSize = getBodySize(body);\n\n  const resSize = response ? parseContentLengthHeader(response.headers.get('content-length')) : undefined;\n\n  if (reqSize !== undefined) {\n    breadcrumb.data.request_body_size = reqSize;\n  }\n  if (resSize !== undefined) {\n    breadcrumb.data.response_body_size = resSize;\n  }\n}\n\nasync function _prepareFetchData(\n  breadcrumb: Breadcrumb & { data: FetchBreadcrumbData },\n  hint: Partial<FetchHint>,\n  options: ReplayNetworkOptions,\n): Promise<ReplayNetworkRequestData> {\n  const now = Date.now();\n  const { startTimestamp = now, endTimestamp = now } = hint;\n\n  const {\n    url,\n    method,\n    status_code: statusCode = 0,\n    request_body_size: requestBodySize,\n    response_body_size: responseBodySize,\n  } = breadcrumb.data;\n\n  const captureDetails =\n    urlMatches(url, options.networkDetailAllowUrls) && !urlMatches(url, options.networkDetailDenyUrls);\n\n  const request = captureDetails\n    ? _getRequestInfo(options, hint.input, requestBodySize)\n    : buildSkippedNetworkRequestOrResponse(requestBodySize);\n  const response = await _getResponseInfo(captureDetails, options, hint.response, responseBodySize);\n\n  return {\n    startTimestamp,\n    endTimestamp,\n    url,\n    method,\n    statusCode,\n    request,\n    response,\n  };\n}\n\nfunction _getRequestInfo(\n  { networkCaptureBodies, networkRequestHeaders }: ReplayNetworkOptions,\n  input: FetchHint['input'] | undefined,\n  requestBodySize?: number,\n): ReplayNetworkRequestOrResponse | undefined {\n  const headers = input ? getRequestHeaders(input, networkRequestHeaders) : {};\n\n  if (!networkCaptureBodies) {\n    return buildNetworkRequestOrResponse(headers, requestBodySize, undefined);\n  }\n\n  // We only want to transmit string or string-like bodies\n  const requestBody = _getFetchRequestArgBody(input);\n  const [bodyStr, warning] = getBodyString(requestBody);\n  const data = buildNetworkRequestOrResponse(headers, requestBodySize, bodyStr);\n\n  if (warning) {\n    return mergeWarning(data, warning);\n  }\n\n  return data;\n}\n\n/** Exported only for tests. */\nexport async function _getResponseInfo(\n  captureDetails: boolean,\n  {\n    networkCaptureBodies,\n    networkResponseHeaders,\n  }: Pick<ReplayNetworkOptions, 'networkCaptureBodies' | 'networkResponseHeaders'>,\n  response: Response | undefined,\n  responseBodySize?: number,\n): Promise<ReplayNetworkRequestOrResponse | undefined> {\n  if (!captureDetails && responseBodySize !== undefined) {\n    return buildSkippedNetworkRequestOrResponse(responseBodySize);\n  }\n\n  const headers = response ? getAllHeaders(response.headers, networkResponseHeaders) : {};\n\n  if (!response || (!networkCaptureBodies && responseBodySize !== undefined)) {\n    return buildNetworkRequestOrResponse(headers, responseBodySize, undefined);\n  }\n\n  const [bodyText, warning] = await _parseFetchResponseBody(response);\n  const result = getResponseData(bodyText, {\n    networkCaptureBodies,\n\n    responseBodySize,\n    captureDetails,\n    headers,\n  });\n\n  if (warning) {\n    return mergeWarning(result, warning);\n  }\n\n  return result;\n}\n\nfunction getResponseData(\n  bodyText: string | undefined,\n  {\n    networkCaptureBodies,\n    responseBodySize,\n    captureDetails,\n    headers,\n  }: {\n    captureDetails: boolean;\n    networkCaptureBodies: boolean;\n    responseBodySize: number | undefined;\n    headers: Record<string, string>;\n  },\n): ReplayNetworkRequestOrResponse | undefined {\n  try {\n    const size =\n      bodyText && bodyText.length && responseBodySize === undefined ? getBodySize(bodyText) : responseBodySize;\n\n    if (!captureDetails) {\n      return buildSkippedNetworkRequestOrResponse(size);\n    }\n\n    if (networkCaptureBodies) {\n      return buildNetworkRequestOrResponse(headers, size, bodyText);\n    }\n\n    return buildNetworkRequestOrResponse(headers, size, undefined);\n  } catch (error) {\n    DEBUG_BUILD && logger.exception(error, 'Failed to serialize response body');\n    // fallback\n    return buildNetworkRequestOrResponse(headers, responseBodySize, undefined);\n  }\n}\n\nasync function _parseFetchResponseBody(response: Response): Promise<[string | undefined, NetworkMetaWarning?]> {\n  const res = _tryCloneResponse(response);\n\n  if (!res) {\n    return [undefined, 'BODY_PARSE_ERROR'];\n  }\n\n  try {\n    const text = await _tryGetResponseText(res);\n    return [text];\n  } catch (error) {\n    if (error instanceof Error && error.message.indexOf('Timeout') > -1) {\n      DEBUG_BUILD && logger.warn('Parsing text body from response timed out');\n      return [undefined, 'BODY_PARSE_TIMEOUT'];\n    }\n\n    DEBUG_BUILD && logger.exception(error, 'Failed to get text body from response');\n    return [undefined, 'BODY_PARSE_ERROR'];\n  }\n}\n\nfunction _getFetchRequestArgBody(fetchArgs: unknown[] = []): RequestInit['body'] | undefined {\n  // We only support getting the body from the fetch options\n  if (fetchArgs.length !== 2 || typeof fetchArgs[1] !== 'object') {\n    return undefined;\n  }\n\n  return (fetchArgs[1] as RequestInit).body;\n}\n\nfunction getAllHeaders(headers: Headers, allowedHeaders: string[]): Record<string, string> {\n  const allHeaders: Record<string, string> = {};\n\n  allowedHeaders.forEach(header => {\n    if (headers.get(header)) {\n      allHeaders[header] = headers.get(header) as string;\n    }\n  });\n\n  return allHeaders;\n}\n\nfunction getRequestHeaders(fetchArgs: unknown[], allowedHeaders: string[]): Record<string, string> {\n  if (fetchArgs.length === 1 && typeof fetchArgs[0] !== 'string') {\n    return getHeadersFromOptions(fetchArgs[0] as Request | RequestInit, allowedHeaders);\n  }\n\n  if (fetchArgs.length === 2) {\n    return getHeadersFromOptions(fetchArgs[1] as Request | RequestInit, allowedHeaders);\n  }\n\n  return {};\n}\n\nfunction getHeadersFromOptions(\n  input: Request | RequestInit | undefined,\n  allowedHeaders: string[],\n): Record<string, string> {\n  if (!input) {\n    return {};\n  }\n\n  const headers = input.headers;\n\n  if (!headers) {\n    return {};\n  }\n\n  if (headers instanceof Headers) {\n    return getAllHeaders(headers, allowedHeaders);\n  }\n\n  // We do not support this, as it is not really documented (anymore?)\n  if (Array.isArray(headers)) {\n    return {};\n  }\n\n  return getAllowedHeaders(headers, allowedHeaders);\n}\n\nfunction _tryCloneResponse(response: Response): Response | void {\n  try {\n    // We have to clone this, as the body can only be read once\n    return response.clone();\n  } catch (error) {\n    // this can throw if the response was already consumed before\n    DEBUG_BUILD && logger.exception(error, 'Failed to clone response body');\n  }\n}\n\n/**\n * Get the response body of a fetch request, or timeout after 500ms.\n * Fetch can return a streaming body, that may not resolve (or not for a long time).\n * If that happens, we rather abort after a short time than keep waiting for this.\n */\nfunction _tryGetResponseText(response: Response): Promise<string | undefined> {\n  return new Promise((resolve, reject) => {\n    const timeout = setTimeout(() => reject(new Error('Timeout while trying to read response body')), 500);\n\n    _getResponseText(response)\n      .then(\n        txt => resolve(txt),\n        reason => reject(reason),\n      )\n      .finally(() => clearTimeout(timeout));\n  });\n}\n\nasync function _getResponseText(response: Response): Promise<string> {\n  // Force this to be a promise, just to be safe\n  // eslint-disable-next-line no-return-await\n  return await response.text();\n}\n","import { SENTRY_XHR_DATA_KEY } from '@sentry-internal/browser-utils';\nimport type { Breadcrumb, XhrBreadcrumbData } from '@sentry/core';\n\nimport { DEBUG_BUILD } from '../../debug-build';\nimport type {\n  NetworkMetaWarning,\n  ReplayContainer,\n  ReplayNetworkOptions,\n  ReplayNetworkRequestData,\n  XhrHint,\n} from '../../types';\nimport { logger } from '../../util/logger';\nimport { addNetworkBreadcrumb } from './addNetworkBreadcrumb';\nimport {\n  buildNetworkRequestOrResponse,\n  buildSkippedNetworkRequestOrResponse,\n  getAllowedHeaders,\n  getBodySize,\n  getBodyString,\n  makeNetworkReplayBreadcrumb,\n  mergeWarning,\n  parseContentLengthHeader,\n  urlMatches,\n} from './networkUtils';\n\n/**\n * Capture an XHR breadcrumb to a replay.\n * This adds additional data (where appropriate).\n */\nexport async function captureXhrBreadcrumbToReplay(\n  breadcrumb: Breadcrumb & { data: XhrBreadcrumbData },\n  hint: Partial<XhrHint>,\n  options: ReplayNetworkOptions & { replay: ReplayContainer },\n): Promise<void> {\n  try {\n    const data = _prepareXhrData(breadcrumb, hint, options);\n\n    // Create a replay performance entry from this breadcrumb\n    const result = makeNetworkReplayBreadcrumb('resource.xhr', data);\n    addNetworkBreadcrumb(options.replay, result);\n  } catch (error) {\n    DEBUG_BUILD && logger.exception(error, 'Failed to capture xhr breadcrumb');\n  }\n}\n\n/**\n * Enrich a breadcrumb with additional data.\n * This has to be sync & mutate the given breadcrumb,\n * as the breadcrumb is afterwards consumed by other handlers.\n */\nexport function enrichXhrBreadcrumb(\n  breadcrumb: Breadcrumb & { data: XhrBreadcrumbData },\n  hint: Partial<XhrHint>,\n): void {\n  const { xhr, input } = hint;\n\n  if (!xhr) {\n    return;\n  }\n\n  const reqSize = getBodySize(input);\n  const resSize = xhr.getResponseHeader('content-length')\n    ? parseContentLengthHeader(xhr.getResponseHeader('content-length'))\n    : _getBodySize(xhr.response, xhr.responseType);\n\n  if (reqSize !== undefined) {\n    breadcrumb.data.request_body_size = reqSize;\n  }\n  if (resSize !== undefined) {\n    breadcrumb.data.response_body_size = resSize;\n  }\n}\n\nfunction _prepareXhrData(\n  breadcrumb: Breadcrumb & { data: XhrBreadcrumbData },\n  hint: Partial<XhrHint>,\n  options: ReplayNetworkOptions,\n): ReplayNetworkRequestData | null {\n  const now = Date.now();\n  const { startTimestamp = now, endTimestamp = now, input, xhr } = hint;\n\n  const {\n    url,\n    method,\n    status_code: statusCode = 0,\n    request_body_size: requestBodySize,\n    response_body_size: responseBodySize,\n  } = breadcrumb.data;\n\n  if (!url) {\n    return null;\n  }\n\n  if (!xhr || !urlMatches(url, options.networkDetailAllowUrls) || urlMatches(url, options.networkDetailDenyUrls)) {\n    const request = buildSkippedNetworkRequestOrResponse(requestBodySize);\n    const response = buildSkippedNetworkRequestOrResponse(responseBodySize);\n    return {\n      startTimestamp,\n      endTimestamp,\n      url,\n      method,\n      statusCode,\n      request,\n      response,\n    };\n  }\n\n  const xhrInfo = xhr[SENTRY_XHR_DATA_KEY];\n  const networkRequestHeaders = xhrInfo\n    ? getAllowedHeaders(xhrInfo.request_headers, options.networkRequestHeaders)\n    : {};\n  const networkResponseHeaders = getAllowedHeaders(getResponseHeaders(xhr), options.networkResponseHeaders);\n\n  const [requestBody, requestWarning] = options.networkCaptureBodies ? getBodyString(input) : [undefined];\n  const [responseBody, responseWarning] = options.networkCaptureBodies ? _getXhrResponseBody(xhr) : [undefined];\n\n  const request = buildNetworkRequestOrResponse(networkRequestHeaders, requestBodySize, requestBody);\n  const response = buildNetworkRequestOrResponse(networkResponseHeaders, responseBodySize, responseBody);\n\n  return {\n    startTimestamp,\n    endTimestamp,\n    url,\n    method,\n    statusCode,\n    request: requestWarning ? mergeWarning(request, requestWarning) : request,\n    response: responseWarning ? mergeWarning(response, responseWarning) : response,\n  };\n}\n\nfunction getResponseHeaders(xhr: XMLHttpRequest): Record<string, string> {\n  const headers = xhr.getAllResponseHeaders();\n\n  if (!headers) {\n    return {};\n  }\n\n  return headers.split('\\r\\n').reduce((acc: Record<string, string>, line: string) => {\n    const [key, value] = line.split(': ') as [string, string | undefined];\n    if (value) {\n      acc[key.toLowerCase()] = value;\n    }\n    return acc;\n  }, {});\n}\n\nfunction _getXhrResponseBody(xhr: XMLHttpRequest): [string | undefined, NetworkMetaWarning?] {\n  // We collect errors that happen, but only log them if we can't get any response body\n  const errors: unknown[] = [];\n\n  try {\n    return [xhr.responseText];\n  } catch (e) {\n    errors.push(e);\n  }\n\n  // Try to manually parse the response body, if responseText fails\n  try {\n    return _parseXhrResponse(xhr.response, xhr.responseType);\n  } catch (e) {\n    errors.push(e);\n  }\n\n  DEBUG_BUILD && logger.warn('Failed to get xhr response body', ...errors);\n\n  return [undefined];\n}\n\n/**\n * Get the string representation of the XHR response.\n * Based on MDN, these are the possible types of the response:\n * string\n * ArrayBuffer\n * Blob\n * Document\n * POJO\n *\n * Exported only for tests.\n */\nexport function _parseXhrResponse(\n  body: XMLHttpRequest['response'],\n  responseType: XMLHttpRequest['responseType'],\n): [string | undefined, NetworkMetaWarning?] {\n  try {\n    if (typeof body === 'string') {\n      return [body];\n    }\n\n    if (body instanceof Document) {\n      return [body.body.outerHTML];\n    }\n\n    if (responseType === 'json' && body && typeof body === 'object') {\n      return [JSON.stringify(body)];\n    }\n\n    if (!body) {\n      return [undefined];\n    }\n  } catch (error) {\n    DEBUG_BUILD && logger.exception(error, 'Failed to serialize body', body);\n    return [undefined, 'BODY_PARSE_ERROR'];\n  }\n\n  DEBUG_BUILD && logger.info('Skipping network body because of body type', body);\n\n  return [undefined, 'UNPARSEABLE_BODY_TYPE'];\n}\n\nfunction _getBodySize(\n  body: XMLHttpRequest['response'],\n  responseType: XMLHttpRequest['responseType'],\n): number | undefined {\n  try {\n    const bodyStr = responseType === 'json' && body && typeof body === 'object' ? JSON.stringify(body) : body;\n    return getBodySize(bodyStr);\n  } catch {\n    return undefined;\n  }\n}\n","import { getClient } from '@sentry/core';\nimport type { Breadcrumb, BreadcrumbHint, FetchBreadcrumbData, XhrBreadcrumbData } from '@sentry/core';\n\nimport { DEBUG_BUILD } from '../debug-build';\nimport type { FetchHint, ReplayContainer, ReplayNetworkOptions, XhrHint } from '../types';\nimport { logger } from '../util/logger';\nimport { captureFetchBreadcrumbToReplay, enrichFetchBreadcrumb } from './util/fetchUtils';\nimport { captureXhrBreadcrumbToReplay, enrichXhrBreadcrumb } from './util/xhrUtils';\n\ninterface ExtendedNetworkBreadcrumbsOptions extends ReplayNetworkOptions {\n  replay: ReplayContainer;\n}\n\n/**\n * This method does two things:\n * - It enriches the regular XHR/fetch breadcrumbs with request/response size data\n * - It captures the XHR/fetch breadcrumbs to the replay\n *   (enriching it with further data that is _not_ added to the regular breadcrumbs)\n */\nexport function handleNetworkBreadcrumbs(replay: ReplayContainer): void {\n  const client = getClient();\n\n  try {\n    const {\n      networkDetailAllowUrls,\n      networkDetailDenyUrls,\n      networkCaptureBodies,\n      networkRequestHeaders,\n      networkResponseHeaders,\n    } = replay.getOptions();\n\n    const options: ExtendedNetworkBreadcrumbsOptions = {\n      replay,\n      networkDetailAllowUrls,\n      networkDetailDenyUrls,\n      networkCaptureBodies,\n      networkRequestHeaders,\n      networkResponseHeaders,\n    };\n\n    if (client) {\n      client.on('beforeAddBreadcrumb', (breadcrumb, hint) => beforeAddNetworkBreadcrumb(options, breadcrumb, hint));\n    }\n  } catch {\n    // Do nothing\n  }\n}\n\n/** just exported for tests */\nexport function beforeAddNetworkBreadcrumb(\n  options: ExtendedNetworkBreadcrumbsOptions,\n  breadcrumb: Breadcrumb,\n  hint?: BreadcrumbHint,\n): void {\n  if (!breadcrumb.data) {\n    return;\n  }\n\n  try {\n    if (_isXhrBreadcrumb(breadcrumb) && _isXhrHint(hint)) {\n      // This has to be sync, as we need to ensure the breadcrumb is enriched in the same tick\n      // Because the hook runs synchronously, and the breadcrumb is afterwards passed on\n      // So any async mutations to it will not be reflected in the final breadcrumb\n      enrichXhrBreadcrumb(breadcrumb, hint);\n\n      // This call should not reject\n      // eslint-disable-next-line @typescript-eslint/no-floating-promises\n      captureXhrBreadcrumbToReplay(breadcrumb, hint, options);\n    }\n\n    if (_isFetchBreadcrumb(breadcrumb) && _isFetchHint(hint)) {\n      // This has to be sync, as we need to ensure the breadcrumb is enriched in the same tick\n      // Because the hook runs synchronously, and the breadcrumb is afterwards passed on\n      // So any async mutations to it will not be reflected in the final breadcrumb\n      enrichFetchBreadcrumb(breadcrumb, hint);\n\n      // This call should not reject\n      // eslint-disable-next-line @typescript-eslint/no-floating-promises\n      captureFetchBreadcrumbToReplay(breadcrumb, hint, options);\n    }\n  } catch (e) {\n    DEBUG_BUILD && logger.exception(e, 'Error when enriching network breadcrumb');\n  }\n}\n\nfunction _isXhrBreadcrumb(breadcrumb: Breadcrumb): breadcrumb is Breadcrumb & { data: XhrBreadcrumbData } {\n  return breadcrumb.category === 'xhr';\n}\n\nfunction _isFetchBreadcrumb(breadcrumb: Breadcrumb): breadcrumb is Breadcrumb & { data: FetchBreadcrumbData } {\n  return breadcrumb.category === 'fetch';\n}\n\nfunction _isXhrHint(hint?: BreadcrumbHint): hint is XhrHint {\n  return hint && hint.xhr;\n}\n\nfunction _isFetchHint(hint?: BreadcrumbHint): hint is FetchHint {\n  return hint && hint.response;\n}\n","import {\n  addClickKeypressInstrumentationHandler,\n  addHistoryInstrumentationHandler,\n} from '@sentry-internal/browser-utils';\nimport { addEventProcessor, getClient } from '@sentry/core';\nimport type { DynamicSamplingContext } from '@sentry/core';\n\nimport { handleAfterSendEvent } from '../coreHandlers/handleAfterSendEvent';\nimport { handleBeforeSendEvent } from '../coreHandlers/handleBeforeSendEvent';\nimport { handleBreadcrumbs } from '../coreHandlers/handleBreadcrumbs';\nimport { handleDomListener } from '../coreHandlers/handleDom';\nimport { handleGlobalEventListener } from '../coreHandlers/handleGlobalEvent';\nimport { handleHistorySpanListener } from '../coreHandlers/handleHistory';\nimport { handleNetworkBreadcrumbs } from '../coreHandlers/handleNetworkBreadcrumbs';\nimport type { ReplayContainer } from '../types';\n\n/**\n * Add global listeners that cannot be removed.\n */\nexport function addGlobalListeners(replay: ReplayContainer): void {\n  // Listeners from core SDK //\n  const client = getClient();\n\n  addClickKeypressInstrumentationHandler(handleDomListener(replay));\n  addHistoryInstrumentationHandler(handleHistorySpanListener(replay));\n  handleBreadcrumbs(replay);\n  handleNetworkBreadcrumbs(replay);\n\n  // Tag all (non replay) events that get sent to Sentry with the current\n  // replay ID so that we can reference them later in the UI\n  const eventProcessor = handleGlobalEventListener(replay);\n  addEventProcessor(eventProcessor);\n\n  // If a custom client has no hooks yet, we continue to use the \"old\" implementation\n  if (client) {\n    client.on('beforeSendEvent', handleBeforeSendEvent(replay));\n    client.on('afterSendEvent', handleAfterSendEvent(replay));\n    client.on('createDsc', (dsc: DynamicSamplingContext) => {\n      const replayId = replay.getSessionId();\n      // We do not want to set the DSC when in buffer mode, as that means the replay has not been sent (yet)\n      if (replayId && replay.isEnabled() && replay.recordingMode === 'session') {\n        // Ensure to check that the session is still active - it could have expired in the meanwhile\n        const isSessionActive = replay.checkAndHandleExpiredSession();\n        if (isSessionActive) {\n          dsc.replay_id = replayId;\n        }\n      }\n    });\n\n    client.on('spanStart', span => {\n      replay.lastActiveSpan = span;\n    });\n\n    // We may be missing the initial spanStart due to timing issues,\n    // so we capture it on finish again.\n    client.on('spanEnd', span => {\n      replay.lastActiveSpan = span;\n    });\n\n    // We want to flush replay\n    client.on('beforeSendFeedback', (feedbackEvent, options) => {\n      const replayId = replay.getSessionId();\n      if (options && options.includeReplay && replay.isEnabled() && replayId) {\n        // This should never reject\n        if (feedbackEvent.contexts && feedbackEvent.contexts.feedback) {\n          feedbackEvent.contexts.feedback.replay_id = replayId;\n        }\n      }\n    });\n  }\n}\n","import { WINDOW } from '../constants';\nimport type { AddEventResult, MemoryData, ReplayContainer, ReplayPerformanceEntry } from '../types';\nimport { createPerformanceSpans } from './createPerformanceSpans';\n\ntype ReplayMemoryEntry = ReplayPerformanceEntry<MemoryData> & { data: { memory: MemoryInfo } };\n\ninterface MemoryInfo {\n  jsHeapSizeLimit: number;\n  totalJSHeapSize: number;\n  usedJSHeapSize: number;\n}\n\n/**\n * Create a \"span\" for the total amount of memory being used by JS objects\n * (including v8 internal objects).\n */\nexport async function addMemoryEntry(replay: ReplayContainer): Promise<Array<AddEventResult | null>> {\n  // window.performance.memory is a non-standard API and doesn't work on all browsers, so we try-catch this\n  try {\n    return Promise.all(\n      createPerformanceSpans(replay, [\n        // @ts-expect-error memory doesn't exist on type Performance as the API is non-standard (we check that it exists above)\n        createMemoryEntry(WINDOW.performance.memory),\n      ]),\n    );\n  } catch (error) {\n    // Do nothing\n    return [];\n  }\n}\n\nfunction createMemoryEntry(memoryEntry: MemoryInfo): ReplayMemoryEntry {\n  const { jsHeapSizeLimit, totalJSHeapSize, usedJSHeapSize } = memoryEntry;\n  // we don't want to use `getAbsoluteTime` because it adds the event time to the\n  // time origin, so we get the current timestamp instead\n  const time = Date.now() / 1000;\n  return {\n    type: 'memory',\n    name: 'memory',\n    start: time,\n    end: time,\n    data: {\n      memory: {\n        jsHeapSizeLimit,\n        totalJSHeapSize,\n        usedJSHeapSize,\n      },\n    },\n  };\n}\n","import { setTimeout } from '@sentry-internal/browser-utils';\n\ntype DebouncedCallback = {\n  (): void | unknown;\n  flush: () => void | unknown;\n  cancel: () => void;\n};\ntype CallbackFunction = () => unknown;\ntype DebounceOptions = { maxWait?: number };\n\n/**\n * Heavily simplified debounce function based on lodash.debounce.\n *\n * This function takes a callback function (@param fun) and delays its invocation\n * by @param wait milliseconds. Optionally, a maxWait can be specified in @param options,\n * which ensures that the callback is invoked at least once after the specified max. wait time.\n *\n * @param func the function whose invocation is to be debounced\n * @param wait the minimum time until the function is invoked after it was called once\n * @param options the options object, which can contain the `maxWait` property\n *\n * @returns the debounced version of the function, which needs to be called at least once to start the\n *          debouncing process. Subsequent calls will reset the debouncing timer and, in case @paramfunc\n *          was already invoked in the meantime, return @param func's return value.\n *          The debounced function has two additional properties:\n *          - `flush`: Invokes the debounced function immediately and returns its return value\n *          - `cancel`: Cancels the debouncing process and resets the debouncing timer\n */\nexport function debounce(func: CallbackFunction, wait: number, options?: DebounceOptions): DebouncedCallback {\n  let callbackReturnValue: unknown;\n\n  let timerId: ReturnType<typeof setTimeout> | undefined;\n  let maxTimerId: ReturnType<typeof setTimeout> | undefined;\n\n  const maxWait = options && options.maxWait ? Math.max(options.maxWait, wait) : 0;\n\n  function invokeFunc(): unknown {\n    cancelTimers();\n    callbackReturnValue = func();\n    return callbackReturnValue;\n  }\n\n  function cancelTimers(): void {\n    timerId !== undefined && clearTimeout(timerId);\n    maxTimerId !== undefined && clearTimeout(maxTimerId);\n    timerId = maxTimerId = undefined;\n  }\n\n  function flush(): unknown {\n    if (timerId !== undefined || maxTimerId !== undefined) {\n      return invokeFunc();\n    }\n    return callbackReturnValue;\n  }\n\n  function debounced(): unknown {\n    if (timerId) {\n      clearTimeout(timerId);\n    }\n    timerId = setTimeout(invokeFunc, wait);\n\n    if (maxWait && maxTimerId === undefined) {\n      maxTimerId = setTimeout(invokeFunc, maxWait);\n    }\n\n    return callbackReturnValue;\n  }\n\n  debounced.cancel = cancelTimers;\n  debounced.flush = flush;\n  return debounced;\n}\n","import { GLOBAL_OBJ } from '@sentry/core';\n\nconst NAVIGATOR = GLOBAL_OBJ.navigator;\n\n/**\n *  Disable sampling mousemove events on iOS browsers as this can cause blocking the main thread\n *  https://github.com/getsentry/sentry-javascript/issues/14534\n */\nexport function getRecordingSamplingOptions(): Partial<{ sampling: { mousemove: boolean } }> {\n  if (\n    /iPhone|iPad|iPod/i.test((NAVIGATOR && NAVIGATOR.userAgent) || '') ||\n    (/Macintosh/i.test((NAVIGATOR && NAVIGATOR.userAgent) || '') &&\n      NAVIGATOR &&\n      NAVIGATOR.maxTouchPoints &&\n      NAVIGATOR.maxTouchPoints > 1)\n  ) {\n    return {\n      sampling: {\n        mousemove: false,\n      },\n    };\n  }\n\n  return {};\n}\n","import { EventType } from '@sentry-internal/rrweb';\n\nimport { updateClickDetectorForRecordingEvent } from '../coreHandlers/handleClick';\nimport { DEBUG_BUILD } from '../debug-build';\nimport { saveSession } from '../session/saveSession';\nimport type { RecordingEvent, ReplayContainer, ReplayOptionFrameEvent } from '../types';\nimport { addEventSync } from './addEvent';\nimport { logger } from './logger';\n\ntype RecordingEmitCallback = (event: RecordingEvent, isCheckout?: boolean) => void;\n\n/**\n * Handler for recording events.\n *\n * Adds to event buffer, and has varying flushing behaviors if the event was a checkout.\n */\nexport function getHandleRecordingEmit(replay: ReplayContainer): RecordingEmitCallback {\n  let hadFirstEvent = false;\n\n  return (event: RecordingEvent, _isCheckout?: boolean) => {\n    // If this is false, it means session is expired, create and a new session and wait for checkout\n    if (!replay.checkAndHandleExpiredSession()) {\n      DEBUG_BUILD && logger.warn('Received replay event after session expired.');\n\n      return;\n    }\n\n    // `_isCheckout` is only set when the checkout is due to `checkoutEveryNms`\n    // We also want to treat the first event as a checkout, so we handle this specifically here\n    const isCheckout = _isCheckout || !hadFirstEvent;\n    hadFirstEvent = true;\n\n    if (replay.clickDetector) {\n      updateClickDetectorForRecordingEvent(replay.clickDetector, event);\n    }\n\n    // The handler returns `true` if we do not want to trigger debounced flush, `false` if we want to debounce flush.\n    replay.addUpdate(() => {\n      // The session is always started immediately on pageload/init, but for\n      // error-only replays, it should reflect the most recent checkout\n      // when an error occurs. Clear any state that happens before this current\n      // checkout. This needs to happen before `addEvent()` which updates state\n      // dependent on this reset.\n      if (replay.recordingMode === 'buffer' && isCheckout) {\n        replay.setInitialState();\n      }\n\n      // If the event is not added (e.g. due to being paused, disabled, or out of the max replay duration),\n      // Skip all further steps\n      if (!addEventSync(replay, event, isCheckout)) {\n        // Return true to skip scheduling a debounced flush\n        return true;\n      }\n\n      // Different behavior for full snapshots (type=2), ignore other event types\n      // See https://github.com/rrweb-io/rrweb/blob/d8f9290ca496712aa1e7d472549480c4e7876594/packages/rrweb/src/types.ts#L16\n      if (!isCheckout) {\n        return false;\n      }\n\n      const session = replay.session;\n\n      // Additionally, create a meta event that will capture certain SDK settings.\n      // In order to handle buffer mode, this needs to either be done when we\n      // receive checkout events or at flush time. We have an experimental mode\n      // to perform multiple checkouts a session (the idea is to improve\n      // seeking during playback), so also only include if segmentId is 0\n      // (handled in `addSettingsEvent`).\n      //\n      // `isCheckout` is always true, but want to be explicit that it should\n      // only be added for checkouts\n      addSettingsEvent(replay, isCheckout);\n\n      // When in buffer mode, make sure we adjust the session started date to the current earliest event of the buffer\n      // this should usually be the timestamp of the checkout event, but to be safe...\n      if (replay.recordingMode === 'buffer' && session && replay.eventBuffer) {\n        const earliestEvent = replay.eventBuffer.getEarliestTimestamp();\n        if (earliestEvent) {\n          DEBUG_BUILD &&\n            logger.info(`Updating session start time to earliest event in buffer to ${new Date(earliestEvent)}`);\n\n          session.started = earliestEvent;\n\n          if (replay.getOptions().stickySession) {\n            saveSession(session);\n          }\n        }\n      }\n\n      // If there is a previousSessionId after a full snapshot occurs, then\n      // the replay session was started due to session expiration. The new session\n      // is started before triggering a new checkout and contains the id\n      // of the previous session. Do not immediately flush in this case\n      // to avoid capturing only the checkout and instead the replay will\n      // be captured if they perform any follow-up actions.\n      if (session && session.previousSessionId) {\n        return true;\n      }\n\n      if (replay.recordingMode === 'session') {\n        // If the full snapshot is due to an initial load, we will not have\n        // a previous session ID. In this case, we want to buffer events\n        // for a set amount of time before flushing. This can help avoid\n        // capturing replays of users that immediately close the window.\n\n        // This should never reject\n        // eslint-disable-next-line @typescript-eslint/no-floating-promises\n        void replay.flush();\n      }\n\n      return true;\n    });\n  };\n}\n\n/**\n * Exported for tests\n */\nexport function createOptionsEvent(replay: ReplayContainer): ReplayOptionFrameEvent {\n  const options = replay.getOptions();\n  return {\n    type: EventType.Custom,\n    timestamp: Date.now(),\n    data: {\n      tag: 'options',\n      payload: {\n        shouldRecordCanvas: replay.isRecordingCanvas(),\n        sessionSampleRate: options.sessionSampleRate,\n        errorSampleRate: options.errorSampleRate,\n        useCompressionOption: options.useCompression,\n        blockAllMedia: options.blockAllMedia,\n        maskAllText: options.maskAllText,\n        maskAllInputs: options.maskAllInputs,\n        useCompression: replay.eventBuffer ? replay.eventBuffer.type === 'worker' : false,\n        networkDetailHasUrls: options.networkDetailAllowUrls.length > 0,\n        networkCaptureBodies: options.networkCaptureBodies,\n        networkRequestHasHeaders: options.networkRequestHeaders.length > 0,\n        networkResponseHasHeaders: options.networkResponseHeaders.length > 0,\n      },\n    },\n  };\n}\n\n/**\n * Add a \"meta\" event that contains a simplified view on current configuration\n * options. This should only be included on the first segment of a recording.\n */\nfunction addSettingsEvent(replay: ReplayContainer, isCheckout?: boolean): void {\n  // Only need to add this event when sending the first segment\n  if (!isCheckout || !replay.session || replay.session.segmentId !== 0) {\n    return;\n  }\n\n  addEventSync(replay, createOptionsEvent(replay), false);\n}\n","import { createEnvelope, createEventEnvelopeHeaders, getSdkMetadataForEnvelopeHeader } from '@sentry/core';\nimport type { DsnComponents, ReplayEnvelope, ReplayEvent, ReplayRecordingData } from '@sentry/core';\n\n/**\n * Create a replay envelope ready to be sent.\n * This includes both the replay event, as well as the recording data.\n */\nexport function createReplayEnvelope(\n  replayEvent: ReplayEvent,\n  recordingData: ReplayRecordingData,\n  dsn: DsnComponents,\n  tunnel?: string,\n): ReplayEnvelope {\n  return createEnvelope<ReplayEnvelope>(\n    createEventEnvelopeHeaders(replayEvent, getSdkMetadataForEnvelopeHeader(replayEvent), tunnel, dsn),\n    [\n      [{ type: 'replay_event' }, replayEvent],\n      [\n        {\n          type: 'replay_recording',\n          // If string then we need to encode to UTF8, otherwise will have\n          // wrong size. TextEncoder has similar browser support to\n          // MutationObserver, although it does not accept IE11.\n          length:\n            typeof recordingData === 'string' ? new TextEncoder().encode(recordingData).length : recordingData.length,\n        },\n        recordingData,\n      ],\n    ],\n  );\n}\n","import type { ReplayRecordingData } from '@sentry/core';\n\n/**\n * Prepare the recording data ready to be sent.\n */\nexport function prepareRecordingData({\n  recordingData,\n  headers,\n}: {\n  recordingData: ReplayRecordingData;\n  headers: Record<string, unknown>;\n}): ReplayRecordingData {\n  let payloadWithSequence;\n\n  // XXX: newline is needed to separate sequence id from events\n  const replayHeaders = `${JSON.stringify(headers)}\n`;\n\n  if (typeof recordingData === 'string') {\n    payloadWithSequence = `${replayHeaders}${recordingData}`;\n  } else {\n    const enc = new TextEncoder();\n    // XXX: newline is needed to separate sequence id from events\n    const sequence = enc.encode(replayHeaders);\n    // Merge the two Uint8Arrays\n    payloadWithSequence = new Uint8Array(sequence.length + recordingData.length);\n    payloadWithSequence.set(sequence);\n    payloadWithSequence.set(recordingData, sequence.length);\n  }\n\n  return payloadWithSequence;\n}\n","import type { IntegrationIndex } from '@sentry/core';\nimport { getIsolationScope, prepareEvent } from '@sentry/core';\nimport type { Client, EventHint, ReplayEvent, Scope } from '@sentry/core';\n\n/**\n * Prepare a replay event & enrich it with the SDK metadata.\n */\nexport async function prepareReplayEvent({\n  client,\n  scope,\n  replayId: event_id,\n  event,\n}: {\n  client: Client & { _integrations?: IntegrationIndex };\n  scope: Scope;\n  replayId: string;\n  event: ReplayEvent;\n}): Promise<ReplayEvent | null> {\n  const integrations =\n    typeof client._integrations === 'object' && client._integrations !== null && !Array.isArray(client._integrations)\n      ? Object.keys(client._integrations)\n      : undefined;\n\n  const eventHint: EventHint = { event_id, integrations };\n\n  client.emit('preprocessEvent', event, eventHint);\n\n  const preparedEvent = (await prepareEvent(\n    client.getOptions(),\n    event,\n    eventHint,\n    scope,\n    client,\n    getIsolationScope(),\n  )) as ReplayEvent | null;\n\n  // If e.g. a global event processor returned null\n  if (!preparedEvent) {\n    return null;\n  }\n\n  // This normally happens in browser client \"_prepareEvent\"\n  // but since we do not use this private method from the client, but rather the plain import\n  // we need to do this manually.\n  preparedEvent.platform = preparedEvent.platform || 'javascript';\n\n  // extract the SDK name because `client._prepareEvent` doesn't add it to the event\n  const metadata = client.getSdkMetadata();\n  const { name, version } = (metadata && metadata.sdk) || {};\n\n  preparedEvent.sdk = {\n    ...preparedEvent.sdk,\n    name: name || 'sentry.javascript.unknown',\n    version: version || '0.0.0',\n  };\n\n  return preparedEvent;\n}\n","import type { RateLimits, ReplayEvent, TransportMakeRequestResponse } from '@sentry/core';\nimport { getClient, getCurrentScope, isRateLimited, resolvedSyncPromise, updateRateLimits } from '@sentry/core';\nimport { REPLAY_EVENT_NAME, UNABLE_TO_SEND_REPLAY } from '../constants';\nimport { DEBUG_BUILD } from '../debug-build';\nimport type { SendReplayData } from '../types';\nimport { createReplayEnvelope } from './createReplayEnvelope';\nimport { logger } from './logger';\nimport { prepareRecordingData } from './prepareRecordingData';\nimport { prepareReplayEvent } from './prepareReplayEvent';\n\n/**\n * Send replay attachment using `fetch()`\n */\nexport async function sendReplayRequest({\n  recordingData,\n  replayId,\n  segmentId: segment_id,\n  eventContext,\n  timestamp,\n  session,\n}: SendReplayData): Promise<TransportMakeRequestResponse> {\n  const preparedRecordingData = prepareRecordingData({\n    recordingData,\n    headers: {\n      segment_id,\n    },\n  });\n\n  const { urls, errorIds, traceIds, initialTimestamp } = eventContext;\n\n  const client = getClient();\n  const scope = getCurrentScope();\n  const transport = client && client.getTransport();\n  const dsn = client && client.getDsn();\n\n  if (!client || !transport || !dsn || !session.sampled) {\n    return resolvedSyncPromise({});\n  }\n\n  const baseEvent: ReplayEvent = {\n    type: REPLAY_EVENT_NAME,\n    replay_start_timestamp: initialTimestamp / 1000,\n    timestamp: timestamp / 1000,\n    error_ids: errorIds,\n    trace_ids: traceIds,\n    urls,\n    replay_id: replayId,\n    segment_id,\n    replay_type: session.sampled,\n  };\n\n  const replayEvent = await prepareReplayEvent({ scope, client, replayId, event: baseEvent });\n\n  if (!replayEvent) {\n    // Taken from baseclient's `_processEvent` method, where this is handled for errors/transactions\n    client.recordDroppedEvent('event_processor', 'replay', baseEvent);\n    DEBUG_BUILD && logger.info('An event processor returned `null`, will not send event.');\n    return resolvedSyncPromise({});\n  }\n\n  /*\n  For reference, the fully built event looks something like this:\n  {\n      \"type\": \"replay_event\",\n      \"timestamp\": 1670837008.634,\n      \"error_ids\": [\n          \"errorId\"\n      ],\n      \"trace_ids\": [\n          \"traceId\"\n      ],\n      \"urls\": [\n          \"https://example.com\"\n      ],\n      \"replay_id\": \"eventId\",\n      \"segment_id\": 3,\n      \"replay_type\": \"error\",\n      \"platform\": \"javascript\",\n      \"event_id\": \"eventId\",\n      \"environment\": \"production\",\n      \"sdk\": {\n          \"integrations\": [\n              \"BrowserTracing\",\n              \"Replay\"\n          ],\n          \"name\": \"sentry.javascript.browser\",\n          \"version\": \"7.25.0\"\n      },\n      \"sdkProcessingMetadata\": {},\n      \"contexts\": {\n      },\n  }\n  */\n\n  // Prevent this data (which, if it exists, was used in earlier steps in the processing pipeline) from being sent to\n  // sentry. (Note: Our use of this property comes and goes with whatever we might be debugging, whatever hacks we may\n  // have temporarily added, etc. Even if we don't happen to be using it at some point in the future, let's not get rid\n  // of this `delete`, lest we miss putting it back in the next time the property is in use.)\n  delete replayEvent.sdkProcessingMetadata;\n\n  const envelope = createReplayEnvelope(replayEvent, preparedRecordingData, dsn, client.getOptions().tunnel);\n\n  let response: TransportMakeRequestResponse;\n\n  try {\n    response = await transport.send(envelope);\n  } catch (err) {\n    const error = new Error(UNABLE_TO_SEND_REPLAY);\n\n    try {\n      // In case browsers don't allow this property to be writable\n      // @ts-expect-error This needs lib es2022 and newer\n      error.cause = err;\n    } catch {\n      // nothing to do\n    }\n    throw error;\n  }\n\n  // If the status code is invalid, we want to immediately stop & not retry\n  if (typeof response.statusCode === 'number' && (response.statusCode < 200 || response.statusCode >= 300)) {\n    throw new TransportStatusCodeError(response.statusCode);\n  }\n\n  const rateLimits = updateRateLimits({}, response);\n  if (isRateLimited(rateLimits, 'replay')) {\n    throw new RateLimitError(rateLimits);\n  }\n\n  return response;\n}\n\n/**\n * This error indicates that the transport returned an invalid status code.\n */\nexport class TransportStatusCodeError extends Error {\n  public constructor(statusCode: number) {\n    super(`Transport returned status code ${statusCode}`);\n  }\n}\n\n/**\n * This error indicates that we hit a rate limit API error.\n */\nexport class RateLimitError extends Error {\n  public rateLimits: RateLimits;\n\n  public constructor(rateLimits: RateLimits) {\n    super('Rate limit hit');\n    this.rateLimits = rateLimits;\n  }\n}\n","import { setTimeout } from '@sentry-internal/browser-utils';\nimport { setContext } from '@sentry/core';\n\nimport { RETRY_BASE_INTERVAL, RETRY_MAX_COUNT, UNABLE_TO_SEND_REPLAY } from '../constants';\nimport type { SendReplayData } from '../types';\nimport { RateLimitError, TransportStatusCodeError, sendReplayRequest } from './sendReplayRequest';\n\n/**\n * Finalize and send the current replay event to Sentry\n */\nexport async function sendReplay(\n  replayData: SendReplayData,\n  retryConfig = {\n    count: 0,\n    interval: RETRY_BASE_INTERVAL,\n  },\n): Promise<unknown> {\n  const { recordingData, onError } = replayData;\n\n  // short circuit if there's no events to upload (this shouldn't happen as _runFlush makes this check)\n  if (!recordingData.length) {\n    return;\n  }\n\n  try {\n    await sendReplayRequest(replayData);\n    return true;\n  } catch (err) {\n    if (err instanceof TransportStatusCodeError || err instanceof RateLimitError) {\n      throw err;\n    }\n\n    // Capture error for every failed replay\n    setContext('Replays', {\n      _retryCount: retryConfig.count,\n    });\n\n    if (onError) {\n      onError(err);\n    }\n\n    // If an error happened here, it's likely that uploading the attachment\n    // failed, we'll can retry with the same events payload\n    if (retryConfig.count >= RETRY_MAX_COUNT) {\n      const error = new Error(`${UNABLE_TO_SEND_REPLAY} - max retries exceeded`);\n\n      try {\n        // In case browsers don't allow this property to be writable\n        // @ts-expect-error This needs lib es2022 and newer\n        error.cause = err;\n      } catch {\n        // nothing to do\n      }\n\n      throw error;\n    }\n\n    // will retry in intervals of 5, 10, 30\n    retryConfig.interval *= ++retryConfig.count;\n\n    return new Promise((resolve, reject) => {\n      setTimeout(async () => {\n        try {\n          await sendReplay(replayData, retryConfig);\n          resolve(true);\n        } catch (err) {\n          reject(err);\n        }\n      }, retryConfig.interval);\n    });\n  }\n}\n","export const THROTTLED = '__THROTTLED';\nexport const SKIPPED = '__SKIPPED';\n\n/**\n * Create a throttled function off a given function.\n * When calling the throttled function, it will call the original function only\n * if it hasn't been called more than `maxCount` times in the last `durationSeconds`.\n *\n * Returns `THROTTLED` if throttled for the first time, after that `SKIPPED`,\n * or else the return value of the original function.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function throttle<T extends (...rest: any[]) => any>(\n  fn: T,\n  maxCount: number,\n  durationSeconds: number,\n): (...rest: Parameters<T>) => ReturnType<T> | typeof THROTTLED | typeof SKIPPED {\n  const counter = new Map<number, number>();\n\n  const _cleanup = (now: number): void => {\n    const threshold = now - durationSeconds;\n    counter.forEach((_value, key) => {\n      if (key < threshold) {\n        counter.delete(key);\n      }\n    });\n  };\n\n  const _getTotalCount = (): number => {\n    return [...counter.values()].reduce((a, b) => a + b, 0);\n  };\n\n  let isThrottled = false;\n\n  return (...rest: Parameters<T>): ReturnType<T> | typeof THROTTLED | typeof SKIPPED => {\n    // Date in second-precision, which we use as basis for the throttling\n    const now = Math.floor(Date.now() / 1000);\n\n    // First, make sure to delete any old entries\n    _cleanup(now);\n\n    // If already over limit, do nothing\n    if (_getTotalCount() >= maxCount) {\n      const wasThrottled = isThrottled;\n      isThrottled = true;\n      return wasThrottled ? SKIPPED : THROTTLED;\n    }\n\n    isThrottled = false;\n    const count = counter.get(now) || 0;\n    counter.set(now, count + 1);\n\n    return fn(...rest);\n  };\n}\n","/* eslint-disable max-lines */ // TODO: We might want to split this file up\nimport { EventType, record } from '@sentry-internal/rrweb';\nimport type { ReplayRecordingMode, Span } from '@sentry/core';\nimport { SEMANTIC_ATTRIBUTE_SENTRY_SOURCE, getActiveSpan, getClient, getRootSpan, spanToJSON } from '@sentry/core';\nimport {\n  BUFFER_CHECKOUT_TIME,\n  SESSION_IDLE_EXPIRE_DURATION,\n  SESSION_IDLE_PAUSE_DURATION,\n  SLOW_CLICK_SCROLL_TIMEOUT,\n  SLOW_CLICK_THRESHOLD,\n  WINDOW,\n} from './constants';\nimport { ClickDetector } from './coreHandlers/handleClick';\nimport { handleKeyboardEvent } from './coreHandlers/handleKeyboardEvent';\nimport { setupPerformanceObserver } from './coreHandlers/performanceObserver';\nimport { DEBUG_BUILD } from './debug-build';\nimport { createEventBuffer } from './eventBuffer';\nimport { clearSession } from './session/clearSession';\nimport { loadOrCreateSession } from './session/loadOrCreateSession';\nimport { saveSession } from './session/saveSession';\nimport { shouldRefreshSession } from './session/shouldRefreshSession';\nimport type {\n  AddEventResult,\n  AddUpdateCallback,\n  AllPerformanceEntry,\n  AllPerformanceEntryData,\n  EventBuffer,\n  InternalEventContext,\n  PopEventContext,\n  RecordingEvent,\n  RecordingOptions,\n  ReplayBreadcrumbFrame,\n  ReplayCanvasIntegrationOptions,\n  ReplayContainer as ReplayContainerInterface,\n  ReplayPerformanceEntry,\n  ReplayPluginOptions,\n  SendBufferedReplayOptions,\n  Session,\n  SlowClickConfig,\n  Timeouts,\n} from './types';\nimport { ReplayEventTypeCustom } from './types';\nimport { addEvent, addEventSync } from './util/addEvent';\nimport { addGlobalListeners } from './util/addGlobalListeners';\nimport { addMemoryEntry } from './util/addMemoryEntry';\nimport { createBreadcrumb } from './util/createBreadcrumb';\nimport { createPerformanceEntries } from './util/createPerformanceEntries';\nimport { createPerformanceSpans } from './util/createPerformanceSpans';\nimport { debounce } from './util/debounce';\nimport { getRecordingSamplingOptions } from './util/getRecordingSamplingOptions';\nimport { getHandleRecordingEmit } from './util/handleRecordingEmit';\nimport { isExpired } from './util/isExpired';\nimport { isSessionExpired } from './util/isSessionExpired';\nimport { logger } from './util/logger';\nimport { resetReplayIdOnDynamicSamplingContext } from './util/resetReplayIdOnDynamicSamplingContext';\nimport { sendReplay } from './util/sendReplay';\nimport { RateLimitError } from './util/sendReplayRequest';\nimport type { SKIPPED } from './util/throttle';\nimport { THROTTLED, throttle } from './util/throttle';\n\n/**\n * The main replay container class, which holds all the state and methods for recording and sending replays.\n */\nexport class ReplayContainer implements ReplayContainerInterface {\n  public eventBuffer: EventBuffer | null;\n\n  public performanceEntries: AllPerformanceEntry[];\n\n  public replayPerformanceEntries: ReplayPerformanceEntry<AllPerformanceEntryData>[];\n\n  public session: Session | undefined;\n\n  public clickDetector: ClickDetector | undefined;\n\n  /**\n   * Recording can happen in one of two modes:\n   *   - session: Record the whole session, sending it continuously\n   *   - buffer: Always keep the last 60s of recording, requires:\n   *     - having replaysOnErrorSampleRate > 0 to capture replay when an error occurs\n   *     - or calling `flush()` to send the replay\n   */\n  public recordingMode: ReplayRecordingMode;\n\n  /**\n   * The current or last active span.\n   * This is only available when performance is enabled.\n   */\n  public lastActiveSpan?: Span;\n\n  /**\n   * These are here so we can overwrite them in tests etc.\n   * @hidden\n   */\n  public readonly timeouts: Timeouts;\n\n  /** The replay has to be manually started, because no sample rate (neither session or error) was provided. */\n  private _requiresManualStart: boolean;\n\n  private _throttledAddEvent: (\n    event: RecordingEvent,\n    isCheckout?: boolean,\n  ) => typeof THROTTLED | typeof SKIPPED | Promise<AddEventResult | null>;\n\n  /**\n   * Options to pass to `rrweb.record()`\n   */\n  private readonly _recordingOptions: RecordingOptions;\n\n  private readonly _options: ReplayPluginOptions;\n\n  private _performanceCleanupCallback?: () => void;\n\n  private _debouncedFlush: ReturnType<typeof debounce>;\n  private _flushLock: Promise<unknown> | undefined;\n\n  /**\n   * Timestamp of the last user activity. This lives across sessions.\n   */\n  private _lastActivity: number;\n\n  /**\n   * Is the integration currently active?\n   */\n  private _isEnabled: boolean;\n\n  /**\n   * Paused is a state where:\n   * - DOM Recording is not listening at all\n   * - Nothing will be added to event buffer (e.g. core SDK events)\n   */\n  private _isPaused: boolean;\n\n  /**\n   * Have we attached listeners to the core SDK?\n   * Note we have to track this as there is no way to remove instrumentation handlers.\n   */\n  private _hasInitializedCoreListeners: boolean;\n\n  /**\n   * Function to stop recording\n   */\n  private _stopRecording: ReturnType<typeof record> | undefined;\n\n  private _context: InternalEventContext;\n\n  /**\n   * Internal use for canvas recording options\n   */\n  private _canvas: ReplayCanvasIntegrationOptions | undefined;\n\n  public constructor({\n    options,\n    recordingOptions,\n  }: {\n    options: ReplayPluginOptions;\n    recordingOptions: RecordingOptions;\n  }) {\n    this.eventBuffer = null;\n    this.performanceEntries = [];\n    this.replayPerformanceEntries = [];\n    this.recordingMode = 'session';\n    this.timeouts = {\n      sessionIdlePause: SESSION_IDLE_PAUSE_DURATION,\n      sessionIdleExpire: SESSION_IDLE_EXPIRE_DURATION,\n    } as const;\n    this._lastActivity = Date.now();\n    this._isEnabled = false;\n    this._isPaused = false;\n    this._requiresManualStart = false;\n    this._hasInitializedCoreListeners = false;\n    this._context = {\n      errorIds: new Set(),\n      traceIds: new Set(),\n      urls: [],\n      initialTimestamp: Date.now(),\n      initialUrl: '',\n    };\n\n    this._recordingOptions = recordingOptions;\n    this._options = options;\n\n    this._debouncedFlush = debounce(() => this._flush(), this._options.flushMinDelay, {\n      maxWait: this._options.flushMaxDelay,\n    });\n\n    this._throttledAddEvent = throttle(\n      (event: RecordingEvent, isCheckout?: boolean) => addEvent(this, event, isCheckout),\n      // Max 300 events...\n      300,\n      // ... per 5s\n      5,\n    );\n\n    const { slowClickTimeout, slowClickIgnoreSelectors } = this.getOptions();\n\n    const slowClickConfig: SlowClickConfig | undefined = slowClickTimeout\n      ? {\n          threshold: Math.min(SLOW_CLICK_THRESHOLD, slowClickTimeout),\n          timeout: slowClickTimeout,\n          scrollTimeout: SLOW_CLICK_SCROLL_TIMEOUT,\n          ignoreSelector: slowClickIgnoreSelectors ? slowClickIgnoreSelectors.join(',') : '',\n        }\n      : undefined;\n\n    if (slowClickConfig) {\n      this.clickDetector = new ClickDetector(this, slowClickConfig);\n    }\n\n    // Configure replay logger w/ experimental options\n    if (DEBUG_BUILD) {\n      const experiments = options._experiments;\n      logger.setConfig({\n        captureExceptions: !!experiments.captureExceptions,\n        traceInternals: !!experiments.traceInternals,\n      });\n    }\n  }\n\n  /** Get the event context. */\n  public getContext(): InternalEventContext {\n    return this._context;\n  }\n\n  /** If recording is currently enabled. */\n  public isEnabled(): boolean {\n    return this._isEnabled;\n  }\n\n  /** If recording is currently paused. */\n  public isPaused(): boolean {\n    return this._isPaused;\n  }\n\n  /**\n   * Determine if canvas recording is enabled\n   */\n  public isRecordingCanvas(): boolean {\n    return Boolean(this._canvas);\n  }\n\n  /** Get the replay integration options. */\n  public getOptions(): ReplayPluginOptions {\n    return this._options;\n  }\n\n  /** A wrapper to conditionally capture exceptions. */\n  public handleException(error: unknown): void {\n    DEBUG_BUILD && logger.exception(error);\n    if (this._options.onError) {\n      this._options.onError(error);\n    }\n  }\n\n  /**\n   * Initializes the plugin based on sampling configuration. Should not be\n   * called outside of constructor.\n   */\n  public initializeSampling(previousSessionId?: string): void {\n    const { errorSampleRate, sessionSampleRate } = this._options;\n\n    // If neither sample rate is > 0, then do nothing - user will need to call one of\n    // `start()` or `startBuffering` themselves.\n    const requiresManualStart = errorSampleRate <= 0 && sessionSampleRate <= 0;\n\n    this._requiresManualStart = requiresManualStart;\n\n    if (requiresManualStart) {\n      return;\n    }\n\n    // Otherwise if there is _any_ sample rate set, try to load an existing\n    // session, or create a new one.\n    this._initializeSessionForSampling(previousSessionId);\n\n    if (!this.session) {\n      // This should not happen, something wrong has occurred\n      DEBUG_BUILD && logger.exception(new Error('Unable to initialize and create session'));\n      return;\n    }\n\n    if (this.session.sampled === false) {\n      // This should only occur if `errorSampleRate` is 0 and was unsampled for\n      // session-based replay. In this case there is nothing to do.\n      return;\n    }\n\n    // If segmentId > 0, it means we've previously already captured this session\n    // In this case, we still want to continue in `session` recording mode\n    this.recordingMode = this.session.sampled === 'buffer' && this.session.segmentId === 0 ? 'buffer' : 'session';\n\n    DEBUG_BUILD && logger.infoTick(`Starting replay in ${this.recordingMode} mode`);\n\n    this._initializeRecording();\n  }\n\n  /**\n   * Start a replay regardless of sampling rate. Calling this will always\n   * create a new session. Will log a message if replay is already in progress.\n   *\n   * Creates or loads a session, attaches listeners to varying events (DOM,\n   * _performanceObserver, Recording, Sentry SDK, etc)\n   */\n  public start(): void {\n    if (this._isEnabled && this.recordingMode === 'session') {\n      DEBUG_BUILD && logger.info('Recording is already in progress');\n      return;\n    }\n\n    if (this._isEnabled && this.recordingMode === 'buffer') {\n      DEBUG_BUILD && logger.info('Buffering is in progress, call `flush()` to save the replay');\n      return;\n    }\n\n    DEBUG_BUILD && logger.infoTick('Starting replay in session mode');\n\n    // Required as user activity is initially set in\n    // constructor, so if `start()` is called after\n    // session idle expiration, a replay will not be\n    // created due to an idle timeout.\n    this._updateUserActivity();\n\n    const session = loadOrCreateSession(\n      {\n        maxReplayDuration: this._options.maxReplayDuration,\n        sessionIdleExpire: this.timeouts.sessionIdleExpire,\n      },\n      {\n        stickySession: this._options.stickySession,\n        // This is intentional: create a new session-based replay when calling `start()`\n        sessionSampleRate: 1,\n        allowBuffering: false,\n      },\n    );\n\n    this.session = session;\n\n    this._initializeRecording();\n  }\n\n  /**\n   * Start replay buffering. Buffers until `flush()` is called or, if\n   * `replaysOnErrorSampleRate` > 0, an error occurs.\n   */\n  public startBuffering(): void {\n    if (this._isEnabled) {\n      DEBUG_BUILD && logger.info('Buffering is in progress, call `flush()` to save the replay');\n      return;\n    }\n\n    DEBUG_BUILD && logger.infoTick('Starting replay in buffer mode');\n\n    const session = loadOrCreateSession(\n      {\n        sessionIdleExpire: this.timeouts.sessionIdleExpire,\n        maxReplayDuration: this._options.maxReplayDuration,\n      },\n      {\n        stickySession: this._options.stickySession,\n        sessionSampleRate: 0,\n        allowBuffering: true,\n      },\n    );\n\n    this.session = session;\n\n    this.recordingMode = 'buffer';\n    this._initializeRecording();\n  }\n\n  /**\n   * Start recording.\n   *\n   * Note that this will cause a new DOM checkout\n   */\n  public startRecording(): void {\n    try {\n      const canvasOptions = this._canvas;\n\n      this._stopRecording = record({\n        ...this._recordingOptions,\n        // When running in error sampling mode, we need to overwrite `checkoutEveryNms`\n        // Without this, it would record forever, until an error happens, which we don't want\n        // instead, we'll always keep the last 60 seconds of replay before an error happened\n        ...(this.recordingMode === 'buffer'\n          ? { checkoutEveryNms: BUFFER_CHECKOUT_TIME }\n          : // Otherwise, use experimental option w/ min checkout time of 6 minutes\n            // This is to improve playback seeking as there could potentially be\n            // less mutations to process in the worse cases.\n            //\n            // checkout by \"N\" events is probably ideal, but means we have less\n            // control about the number of checkouts we make (which generally\n            // increases replay size)\n            this._options._experiments.continuousCheckout && {\n              // Minimum checkout time is 6 minutes\n              checkoutEveryNms: Math.max(360_000, this._options._experiments.continuousCheckout),\n            }),\n        emit: getHandleRecordingEmit(this),\n        ...getRecordingSamplingOptions(),\n        onMutation: this._onMutationHandler,\n        ...(canvasOptions\n          ? {\n              recordCanvas: canvasOptions.recordCanvas,\n              getCanvasManager: canvasOptions.getCanvasManager,\n              sampling: canvasOptions.sampling,\n              dataURLOptions: canvasOptions.dataURLOptions,\n            }\n          : {}),\n      });\n    } catch (err) {\n      this.handleException(err);\n    }\n  }\n\n  /**\n   * Stops the recording, if it was running.\n   *\n   * Returns true if it was previously stopped, or is now stopped,\n   * otherwise false.\n   */\n  public stopRecording(): boolean {\n    try {\n      if (this._stopRecording) {\n        this._stopRecording();\n        this._stopRecording = undefined;\n      }\n\n      return true;\n    } catch (err) {\n      this.handleException(err);\n      return false;\n    }\n  }\n\n  /**\n   * Currently, this needs to be manually called (e.g. for tests). Sentry SDK\n   * does not support a teardown\n   */\n  public async stop({ forceFlush = false, reason }: { forceFlush?: boolean; reason?: string } = {}): Promise<void> {\n    if (!this._isEnabled) {\n      return;\n    }\n\n    // We can't move `_isEnabled` after awaiting a flush, otherwise we can\n    // enter into an infinite loop when `stop()` is called while flushing.\n    this._isEnabled = false;\n\n    try {\n      DEBUG_BUILD && logger.info(`Stopping Replay${reason ? ` triggered by ${reason}` : ''}`);\n\n      resetReplayIdOnDynamicSamplingContext();\n\n      this._removeListeners();\n      this.stopRecording();\n\n      this._debouncedFlush.cancel();\n      // See comment above re: `_isEnabled`, we \"force\" a flush, ignoring the\n      // `_isEnabled` state of the plugin since it was disabled above.\n      if (forceFlush) {\n        await this._flush({ force: true });\n      }\n\n      // After flush, destroy event buffer\n      this.eventBuffer && this.eventBuffer.destroy();\n      this.eventBuffer = null;\n\n      // Clear session from session storage, note this means if a new session\n      // is started after, it will not have `previousSessionId`\n      clearSession(this);\n    } catch (err) {\n      this.handleException(err);\n    }\n  }\n\n  /**\n   * Pause some replay functionality. See comments for `_isPaused`.\n   * This differs from stop as this only stops DOM recording, it is\n   * not as thorough of a shutdown as `stop()`.\n   */\n  public pause(): void {\n    if (this._isPaused) {\n      return;\n    }\n\n    this._isPaused = true;\n    this.stopRecording();\n\n    DEBUG_BUILD && logger.info('Pausing replay');\n  }\n\n  /**\n   * Resumes recording, see notes for `pause().\n   *\n   * Note that calling `startRecording()` here will cause a\n   * new DOM checkout.`\n   */\n  public resume(): void {\n    if (!this._isPaused || !this._checkSession()) {\n      return;\n    }\n\n    this._isPaused = false;\n    this.startRecording();\n\n    DEBUG_BUILD && logger.info('Resuming replay');\n  }\n\n  /**\n   * If not in \"session\" recording mode, flush event buffer which will create a new replay.\n   * Unless `continueRecording` is false, the replay will continue to record and\n   * behave as a \"session\"-based replay.\n   *\n   * Otherwise, queue up a flush.\n   */\n  public async sendBufferedReplayOrFlush({ continueRecording = true }: SendBufferedReplayOptions = {}): Promise<void> {\n    if (this.recordingMode === 'session') {\n      return this.flushImmediate();\n    }\n\n    const activityTime = Date.now();\n\n    DEBUG_BUILD && logger.info('Converting buffer to session');\n\n    // Allow flush to complete before resuming as a session recording, otherwise\n    // the checkout from `startRecording` may be included in the payload.\n    // Prefer to keep the error replay as a separate (and smaller) segment\n    // than the session replay.\n    await this.flushImmediate();\n\n    const hasStoppedRecording = this.stopRecording();\n\n    if (!continueRecording || !hasStoppedRecording) {\n      return;\n    }\n\n    // To avoid race conditions where this is called multiple times, we check here again that we are still buffering\n    if ((this.recordingMode as ReplayRecordingMode) === 'session') {\n      return;\n    }\n\n    // Re-start recording in session-mode\n    this.recordingMode = 'session';\n\n    // Once this session ends, we do not want to refresh it\n    if (this.session) {\n      this._updateUserActivity(activityTime);\n      this._updateSessionActivity(activityTime);\n      this._maybeSaveSession();\n    }\n\n    this.startRecording();\n  }\n\n  /**\n   * We want to batch uploads of replay events. Save events only if\n   * `<flushMinDelay>` milliseconds have elapsed since the last event\n   * *OR* if `<flushMaxDelay>` milliseconds have elapsed.\n   *\n   * Accepts a callback to perform side-effects and returns true to stop batch\n   * processing and hand back control to caller.\n   */\n  public addUpdate(cb: AddUpdateCallback): void {\n    // We need to always run `cb` (e.g. in the case of `this.recordingMode == 'buffer'`)\n    const cbResult = cb();\n\n    // If this option is turned on then we will only want to call `flush`\n    // explicitly\n    if (this.recordingMode === 'buffer') {\n      return;\n    }\n\n    // If callback is true, we do not want to continue with flushing -- the\n    // caller will need to handle it.\n    if (cbResult === true) {\n      return;\n    }\n\n    // addUpdate is called quite frequently - use _debouncedFlush so that it\n    // respects the flush delays and does not flush immediately\n    this._debouncedFlush();\n  }\n\n  /**\n   * Updates the user activity timestamp and resumes recording. This should be\n   * called in an event handler for a user action that we consider as the user\n   * being \"active\" (e.g. a mouse click).\n   */\n  public triggerUserActivity(): void {\n    this._updateUserActivity();\n\n    // This case means that recording was once stopped due to inactivity.\n    // Ensure that recording is resumed.\n    if (!this._stopRecording) {\n      // Create a new session, otherwise when the user action is flushed, it\n      // will get rejected due to an expired session.\n      if (!this._checkSession()) {\n        return;\n      }\n\n      // Note: This will cause a new DOM checkout\n      this.resume();\n      return;\n    }\n\n    // Otherwise... recording was never suspended, continue as normalish\n    this.checkAndHandleExpiredSession();\n\n    this._updateSessionActivity();\n  }\n\n  /**\n   * Updates the user activity timestamp *without* resuming\n   * recording. Some user events (e.g. keydown) can be create\n   * low-value replays that only contain the keypress as a\n   * breadcrumb. Instead this would require other events to\n   * create a new replay after a session has expired.\n   */\n  public updateUserActivity(): void {\n    this._updateUserActivity();\n    this._updateSessionActivity();\n  }\n\n  /**\n   * Only flush if `this.recordingMode === 'session'`\n   */\n  public conditionalFlush(): Promise<void> {\n    if (this.recordingMode === 'buffer') {\n      return Promise.resolve();\n    }\n\n    return this.flushImmediate();\n  }\n\n  /**\n   * Flush using debounce flush\n   */\n  public flush(): Promise<void> {\n    return this._debouncedFlush() as Promise<void>;\n  }\n\n  /**\n   * Always flush via `_debouncedFlush` so that we do not have flushes triggered\n   * from calling both `flush` and `_debouncedFlush`. Otherwise, there could be\n   * cases of multiple flushes happening closely together.\n   */\n  public flushImmediate(): Promise<void> {\n    this._debouncedFlush();\n    // `.flush` is provided by the debounced function, analogously to lodash.debounce\n    return this._debouncedFlush.flush() as Promise<void>;\n  }\n\n  /**\n   * Cancels queued up flushes.\n   */\n  public cancelFlush(): void {\n    this._debouncedFlush.cancel();\n  }\n\n  /** Get the current session (=replay) ID */\n  public getSessionId(): string | undefined {\n    return this.session && this.session.id;\n  }\n\n  /**\n   * Checks if recording should be stopped due to user inactivity. Otherwise\n   * check if session is expired and create a new session if so. Triggers a new\n   * full snapshot on new session.\n   *\n   * Returns true if session is not expired, false otherwise.\n   * @hidden\n   */\n  public checkAndHandleExpiredSession(): boolean | void {\n    // Prevent starting a new session if the last user activity is older than\n    // SESSION_IDLE_PAUSE_DURATION. Otherwise non-user activity can trigger a new\n    // session+recording. This creates noisy replays that do not have much\n    // content in them.\n    if (\n      this._lastActivity &&\n      isExpired(this._lastActivity, this.timeouts.sessionIdlePause) &&\n      this.session &&\n      this.session.sampled === 'session'\n    ) {\n      // Pause recording only for session-based replays. Otherwise, resuming\n      // will create a new replay and will conflict with users who only choose\n      // to record error-based replays only. (e.g. the resumed replay will not\n      // contain a reference to an error)\n      this.pause();\n      return;\n    }\n\n    // --- There is recent user activity --- //\n    // This will create a new session if expired, based on expiry length\n    if (!this._checkSession()) {\n      // Check session handles the refreshing itself\n      return false;\n    }\n\n    return true;\n  }\n\n  /**\n   * Capture some initial state that can change throughout the lifespan of the\n   * replay. This is required because otherwise they would be captured at the\n   * first flush.\n   */\n  public setInitialState(): void {\n    const urlPath = `${WINDOW.location.pathname}${WINDOW.location.hash}${WINDOW.location.search}`;\n    const url = `${WINDOW.location.origin}${urlPath}`;\n\n    this.performanceEntries = [];\n    this.replayPerformanceEntries = [];\n\n    // Reset _context as well\n    this._clearContext();\n\n    this._context.initialUrl = url;\n    this._context.initialTimestamp = Date.now();\n    this._context.urls.push(url);\n  }\n\n  /**\n   * Add a breadcrumb event, that may be throttled.\n   * If it was throttled, we add a custom breadcrumb to indicate that.\n   */\n  public throttledAddEvent(\n    event: RecordingEvent,\n    isCheckout?: boolean,\n  ): typeof THROTTLED | typeof SKIPPED | Promise<AddEventResult | null> {\n    const res = this._throttledAddEvent(event, isCheckout);\n\n    // If this is THROTTLED, it means we have throttled the event for the first time\n    // In this case, we want to add a breadcrumb indicating that something was skipped\n    if (res === THROTTLED) {\n      const breadcrumb = createBreadcrumb({\n        category: 'replay.throttled',\n      });\n\n      this.addUpdate(() => {\n        // Return `false` if the event _was_ added, as that means we schedule a flush\n        return !addEventSync(this, {\n          type: ReplayEventTypeCustom,\n          timestamp: breadcrumb.timestamp || 0,\n          data: {\n            tag: 'breadcrumb',\n            payload: breadcrumb,\n            metric: true,\n          },\n        });\n      });\n    }\n\n    return res;\n  }\n\n  /**\n   * This will get the parametrized route name of the current page.\n   * This is only available if performance is enabled, and if an instrumented router is used.\n   */\n  public getCurrentRoute(): string | undefined {\n    const lastActiveSpan = this.lastActiveSpan || getActiveSpan();\n    const lastRootSpan = lastActiveSpan && getRootSpan(lastActiveSpan);\n\n    const attributes = (lastRootSpan && spanToJSON(lastRootSpan).data) || {};\n    const source = attributes[SEMANTIC_ATTRIBUTE_SENTRY_SOURCE];\n    if (!lastRootSpan || !source || !['route', 'custom'].includes(source)) {\n      return undefined;\n    }\n\n    return spanToJSON(lastRootSpan).description;\n  }\n\n  /**\n   * Initialize and start all listeners to varying events (DOM,\n   * Performance Observer, Recording, Sentry SDK, etc)\n   */\n  private _initializeRecording(): void {\n    this.setInitialState();\n\n    // this method is generally called on page load or manually - in both cases\n    // we should treat it as an activity\n    this._updateSessionActivity();\n\n    this.eventBuffer = createEventBuffer({\n      useCompression: this._options.useCompression,\n      workerUrl: this._options.workerUrl,\n    });\n\n    this._removeListeners();\n    this._addListeners();\n\n    // Need to set as enabled before we start recording, as `record()` can trigger a flush with a new checkout\n    this._isEnabled = true;\n    this._isPaused = false;\n\n    this.startRecording();\n  }\n\n  /**\n   * Loads (or refreshes) the current session.\n   */\n  private _initializeSessionForSampling(previousSessionId?: string): void {\n    // Whenever there is _any_ error sample rate, we always allow buffering\n    // Because we decide on sampling when an error occurs, we need to buffer at all times if sampling for errors\n    const allowBuffering = this._options.errorSampleRate > 0;\n\n    const session = loadOrCreateSession(\n      {\n        sessionIdleExpire: this.timeouts.sessionIdleExpire,\n        maxReplayDuration: this._options.maxReplayDuration,\n        previousSessionId,\n      },\n      {\n        stickySession: this._options.stickySession,\n        sessionSampleRate: this._options.sessionSampleRate,\n        allowBuffering,\n      },\n    );\n\n    this.session = session;\n  }\n\n  /**\n   * Checks and potentially refreshes the current session.\n   * Returns false if session is not recorded.\n   */\n  private _checkSession(): boolean {\n    // If there is no session yet, we do not want to refresh anything\n    // This should generally not happen, but to be safe....\n    if (!this.session) {\n      return false;\n    }\n\n    const currentSession = this.session;\n\n    if (\n      shouldRefreshSession(currentSession, {\n        sessionIdleExpire: this.timeouts.sessionIdleExpire,\n        maxReplayDuration: this._options.maxReplayDuration,\n      })\n    ) {\n      // This should never reject\n      // eslint-disable-next-line @typescript-eslint/no-floating-promises\n      this._refreshSession(currentSession);\n      return false;\n    }\n\n    return true;\n  }\n\n  /**\n   * Refresh a session with a new one.\n   * This stops the current session (without forcing a flush, as that would never work since we are expired),\n   * and then does a new sampling based on the refreshed session.\n   */\n  private async _refreshSession(session: Session): Promise<void> {\n    if (!this._isEnabled) {\n      return;\n    }\n    await this.stop({ reason: 'refresh session' });\n    this.initializeSampling(session.id);\n  }\n\n  /**\n   * Adds listeners to record events for the replay\n   */\n  private _addListeners(): void {\n    try {\n      WINDOW.document.addEventListener('visibilitychange', this._handleVisibilityChange);\n      WINDOW.addEventListener('blur', this._handleWindowBlur);\n      WINDOW.addEventListener('focus', this._handleWindowFocus);\n      WINDOW.addEventListener('keydown', this._handleKeyboardEvent);\n\n      if (this.clickDetector) {\n        this.clickDetector.addListeners();\n      }\n\n      // There is no way to remove these listeners, so ensure they are only added once\n      if (!this._hasInitializedCoreListeners) {\n        addGlobalListeners(this);\n\n        this._hasInitializedCoreListeners = true;\n      }\n    } catch (err) {\n      this.handleException(err);\n    }\n\n    this._performanceCleanupCallback = setupPerformanceObserver(this);\n  }\n\n  /**\n   * Cleans up listeners that were created in `_addListeners`\n   */\n  private _removeListeners(): void {\n    try {\n      WINDOW.document.removeEventListener('visibilitychange', this._handleVisibilityChange);\n\n      WINDOW.removeEventListener('blur', this._handleWindowBlur);\n      WINDOW.removeEventListener('focus', this._handleWindowFocus);\n      WINDOW.removeEventListener('keydown', this._handleKeyboardEvent);\n\n      if (this.clickDetector) {\n        this.clickDetector.removeListeners();\n      }\n\n      if (this._performanceCleanupCallback) {\n        this._performanceCleanupCallback();\n      }\n    } catch (err) {\n      this.handleException(err);\n    }\n  }\n\n  /**\n   * Handle when visibility of the page content changes. Opening a new tab will\n   * cause the state to change to hidden because of content of current page will\n   * be hidden. Likewise, moving a different window to cover the contents of the\n   * page will also trigger a change to a hidden state.\n   */\n  private _handleVisibilityChange: () => void = () => {\n    if (WINDOW.document.visibilityState === 'visible') {\n      this._doChangeToForegroundTasks();\n    } else {\n      this._doChangeToBackgroundTasks();\n    }\n  };\n\n  /**\n   * Handle when page is blurred\n   */\n  private _handleWindowBlur: () => void = () => {\n    const breadcrumb = createBreadcrumb({\n      category: 'ui.blur',\n    });\n\n    // Do not count blur as a user action -- it's part of the process of them\n    // leaving the page\n    this._doChangeToBackgroundTasks(breadcrumb);\n  };\n\n  /**\n   * Handle when page is focused\n   */\n  private _handleWindowFocus: () => void = () => {\n    const breadcrumb = createBreadcrumb({\n      category: 'ui.focus',\n    });\n\n    // Do not count focus as a user action -- instead wait until they focus and\n    // interactive with page\n    this._doChangeToForegroundTasks(breadcrumb);\n  };\n\n  /** Ensure page remains active when a key is pressed. */\n  private _handleKeyboardEvent: (event: KeyboardEvent) => void = (event: KeyboardEvent) => {\n    handleKeyboardEvent(this, event);\n  };\n\n  /**\n   * Tasks to run when we consider a page to be hidden (via blurring and/or visibility)\n   */\n  private _doChangeToBackgroundTasks(breadcrumb?: ReplayBreadcrumbFrame): void {\n    if (!this.session) {\n      return;\n    }\n\n    const expired = isSessionExpired(this.session, {\n      maxReplayDuration: this._options.maxReplayDuration,\n      sessionIdleExpire: this.timeouts.sessionIdleExpire,\n    });\n\n    if (expired) {\n      return;\n    }\n\n    if (breadcrumb) {\n      this._createCustomBreadcrumb(breadcrumb);\n    }\n\n    // Send replay when the page/tab becomes hidden. There is no reason to send\n    // replay if it becomes visible, since no actions we care about were done\n    // while it was hidden\n    // This should never reject\n    // eslint-disable-next-line @typescript-eslint/no-floating-promises\n    void this.conditionalFlush();\n  }\n\n  /**\n   * Tasks to run when we consider a page to be visible (via focus and/or visibility)\n   */\n  private _doChangeToForegroundTasks(breadcrumb?: ReplayBreadcrumbFrame): void {\n    if (!this.session) {\n      return;\n    }\n\n    const isSessionActive = this.checkAndHandleExpiredSession();\n\n    if (!isSessionActive) {\n      // If the user has come back to the page within SESSION_IDLE_PAUSE_DURATION\n      // ms, we will re-use the existing session, otherwise create a new\n      // session\n      DEBUG_BUILD && logger.info('Document has become active, but session has expired');\n      return;\n    }\n\n    if (breadcrumb) {\n      this._createCustomBreadcrumb(breadcrumb);\n    }\n  }\n\n  /**\n   * Update user activity (across session lifespans)\n   */\n  private _updateUserActivity(_lastActivity: number = Date.now()): void {\n    this._lastActivity = _lastActivity;\n  }\n\n  /**\n   * Updates the session's last activity timestamp\n   */\n  private _updateSessionActivity(_lastActivity: number = Date.now()): void {\n    if (this.session) {\n      this.session.lastActivity = _lastActivity;\n      this._maybeSaveSession();\n    }\n  }\n\n  /**\n   * Helper to create (and buffer) a replay breadcrumb from a core SDK breadcrumb\n   */\n  private _createCustomBreadcrumb(breadcrumb: ReplayBreadcrumbFrame): void {\n    this.addUpdate(() => {\n      // This should never reject\n      // eslint-disable-next-line @typescript-eslint/no-floating-promises\n      this.throttledAddEvent({\n        type: EventType.Custom,\n        timestamp: breadcrumb.timestamp || 0,\n        data: {\n          tag: 'breadcrumb',\n          payload: breadcrumb,\n        },\n      });\n    });\n  }\n\n  /**\n   * Observed performance events are added to `this.performanceEntries`. These\n   * are included in the replay event before it is finished and sent to Sentry.\n   */\n  private _addPerformanceEntries(): Promise<Array<AddEventResult | null>> {\n    let performanceEntries = createPerformanceEntries(this.performanceEntries).concat(this.replayPerformanceEntries);\n\n    this.performanceEntries = [];\n    this.replayPerformanceEntries = [];\n\n    // If we are manually starting, we want to ensure we only include performance entries\n    // that are after the initial timestamp\n    // The reason for this is that we may have performance entries from the page load, but may decide to start\n    // the replay later on, in which case we do not want to include these entries.\n    // without this, manually started replays can have events long before the actual replay recording starts,\n    // which messes with the timeline etc.\n    if (this._requiresManualStart) {\n      const initialTimestampInSeconds = this._context.initialTimestamp / 1000;\n      performanceEntries = performanceEntries.filter(entry => entry.start >= initialTimestampInSeconds);\n    }\n\n    return Promise.all(createPerformanceSpans(this, performanceEntries));\n  }\n\n  /**\n   * Clear _context\n   */\n  private _clearContext(): void {\n    // XXX: `initialTimestamp` and `initialUrl` do not get cleared\n    this._context.errorIds.clear();\n    this._context.traceIds.clear();\n    this._context.urls = [];\n  }\n\n  /** Update the initial timestamp based on the buffer content. */\n  private _updateInitialTimestampFromEventBuffer(): void {\n    const { session, eventBuffer } = this;\n    // If replay was started manually (=no sample rate was given),\n    // We do not want to back-port the initial timestamp\n    if (!session || !eventBuffer || this._requiresManualStart) {\n      return;\n    }\n\n    // we only ever update this on the initial segment\n    if (session.segmentId) {\n      return;\n    }\n\n    const earliestEvent = eventBuffer.getEarliestTimestamp();\n    if (earliestEvent && earliestEvent < this._context.initialTimestamp) {\n      this._context.initialTimestamp = earliestEvent;\n    }\n  }\n\n  /**\n   * Return and clear _context\n   */\n  private _popEventContext(): PopEventContext {\n    const _context = {\n      initialTimestamp: this._context.initialTimestamp,\n      initialUrl: this._context.initialUrl,\n      errorIds: Array.from(this._context.errorIds),\n      traceIds: Array.from(this._context.traceIds),\n      urls: this._context.urls,\n    };\n\n    this._clearContext();\n\n    return _context;\n  }\n\n  /**\n   * Flushes replay event buffer to Sentry.\n   *\n   * Performance events are only added right before flushing - this is\n   * due to the buffered performance observer events.\n   *\n   * Should never be called directly, only by `flush`\n   */\n  private async _runFlush(): Promise<void> {\n    const replayId = this.getSessionId();\n\n    if (!this.session || !this.eventBuffer || !replayId) {\n      DEBUG_BUILD && logger.error('No session or eventBuffer found to flush.');\n      return;\n    }\n\n    await this._addPerformanceEntries();\n\n    // Check eventBuffer again, as it could have been stopped in the meanwhile\n    if (!this.eventBuffer || !this.eventBuffer.hasEvents) {\n      return;\n    }\n\n    // Only attach memory event if eventBuffer is not empty\n    await addMemoryEntry(this);\n\n    // Check eventBuffer again, as it could have been stopped in the meanwhile\n    if (!this.eventBuffer) {\n      return;\n    }\n\n    // if this changed in the meanwhile, e.g. because the session was refreshed or similar, we abort here\n    if (replayId !== this.getSessionId()) {\n      return;\n    }\n\n    try {\n      // This uses the data from the eventBuffer, so we need to call this before `finish()\n      this._updateInitialTimestampFromEventBuffer();\n\n      const timestamp = Date.now();\n\n      // Check total duration again, to avoid sending outdated stuff\n      // We leave 30s wiggle room to accommodate late flushing etc.\n      // This _could_ happen when the browser is suspended during flushing, in which case we just want to stop\n      if (timestamp - this._context.initialTimestamp > this._options.maxReplayDuration + 30_000) {\n        throw new Error('Session is too long, not sending replay');\n      }\n\n      const eventContext = this._popEventContext();\n      // Always increment segmentId regardless of outcome of sending replay\n      const segmentId = this.session.segmentId++;\n      this._maybeSaveSession();\n\n      // Note this empties the event buffer regardless of outcome of sending replay\n      const recordingData = await this.eventBuffer.finish();\n\n      await sendReplay({\n        replayId,\n        recordingData,\n        segmentId,\n        eventContext,\n        session: this.session,\n        timestamp,\n        onError: err => this.handleException(err),\n      });\n    } catch (err) {\n      this.handleException(err);\n\n      // This means we retried 3 times and all of them failed,\n      // or we ran into a problem we don't want to retry, like rate limiting.\n      // In this case, we want to completely stop the replay - otherwise, we may get inconsistent segments\n      // This should never reject\n      // eslint-disable-next-line @typescript-eslint/no-floating-promises\n      this.stop({ reason: 'sendReplay' });\n\n      const client = getClient();\n\n      if (client) {\n        const dropReason = err instanceof RateLimitError ? 'ratelimit_backoff' : 'send_error';\n        client.recordDroppedEvent(dropReason, 'replay');\n      }\n    }\n  }\n\n  /**\n   * Flush recording data to Sentry. Creates a lock so that only a single flush\n   * can be active at a time. Do not call this directly.\n   */\n  private _flush = async ({\n    force = false,\n  }: {\n    /**\n     * If true, flush while ignoring the `_isEnabled` state of\n     * Replay integration. (By default, flush is noop if integration\n     * is stopped).\n     */\n    force?: boolean;\n  } = {}): Promise<void> => {\n    if (!this._isEnabled && !force) {\n      // This can happen if e.g. the replay was stopped because of exceeding the retry limit\n      return;\n    }\n\n    if (!this.checkAndHandleExpiredSession()) {\n      DEBUG_BUILD && logger.error('Attempting to finish replay event after session expired.');\n      return;\n    }\n\n    if (!this.session) {\n      // should never happen, as we would have bailed out before\n      return;\n    }\n\n    const start = this.session.started;\n    const now = Date.now();\n    const duration = now - start;\n\n    // A flush is about to happen, cancel any queued flushes\n    this._debouncedFlush.cancel();\n\n    // If session is too short, or too long (allow some wiggle room over maxReplayDuration), do not send it\n    // This _should_ not happen, but it may happen if flush is triggered due to a page activity change or similar\n    const tooShort = duration < this._options.minReplayDuration;\n    const tooLong = duration > this._options.maxReplayDuration + 5_000;\n    if (tooShort || tooLong) {\n      DEBUG_BUILD &&\n        logger.info(\n          `Session duration (${Math.floor(duration / 1000)}s) is too ${\n            tooShort ? 'short' : 'long'\n          }, not sending replay.`,\n        );\n\n      if (tooShort) {\n        this._debouncedFlush();\n      }\n      return;\n    }\n\n    const eventBuffer = this.eventBuffer;\n    if (eventBuffer && this.session.segmentId === 0 && !eventBuffer.hasCheckout) {\n      DEBUG_BUILD && logger.info('Flushing initial segment without checkout.');\n      // TODO FN: Evaluate if we want to stop here, or remove this again?\n    }\n\n    const _flushInProgress = !!this._flushLock;\n\n    // this._flushLock acts as a lock so that future calls to `_flush()` will\n    // be blocked until current flush is finished (i.e. this promise resolves)\n    if (!this._flushLock) {\n      this._flushLock = this._runFlush();\n    }\n\n    try {\n      await this._flushLock;\n    } catch (err) {\n      this.handleException(err);\n    } finally {\n      this._flushLock = undefined;\n\n      if (_flushInProgress) {\n        // Wait for previous flush to finish, then call the debounced\n        // `_flush()`. It's possible there are other flush requests queued and\n        // waiting for it to resolve. We want to reduce all outstanding\n        // requests (as well as any new flush requests that occur within a\n        // second of the locked flush completing) into a single flush.\n        this._debouncedFlush();\n      }\n    }\n  };\n\n  /** Save the session, if it is sticky */\n  private _maybeSaveSession(): void {\n    if (this.session && this._options.stickySession) {\n      saveSession(this.session);\n    }\n  }\n\n  /** Handler for rrweb.record.onMutation */\n  private _onMutationHandler = (mutations: unknown[]): boolean => {\n    const count = mutations.length;\n\n    const mutationLimit = this._options.mutationLimit;\n    const mutationBreadcrumbLimit = this._options.mutationBreadcrumbLimit;\n    const overMutationLimit = mutationLimit && count > mutationLimit;\n\n    // Create a breadcrumb if a lot of mutations happen at the same time\n    // We can show this in the UI as an information with potential performance improvements\n    if (count > mutationBreadcrumbLimit || overMutationLimit) {\n      const breadcrumb = createBreadcrumb({\n        category: 'replay.mutations',\n        data: {\n          count,\n          limit: overMutationLimit,\n        },\n      });\n      this._createCustomBreadcrumb(breadcrumb);\n    }\n\n    // Stop replay if over the mutation limit\n    if (overMutationLimit) {\n      // This should never reject\n      // eslint-disable-next-line @typescript-eslint/no-floating-promises\n      this.stop({ reason: 'mutationLimit', forceFlush: this.recordingMode === 'session' });\n      return false;\n    }\n\n    // `true` means we use the regular mutation handling by rrweb\n    return true;\n  };\n}\n","import type { ReplayIntegrationPrivacyOptions } from '../types';\n\ntype GetPrivacyOptions = Required<Omit<ReplayIntegrationPrivacyOptions, 'maskFn'>>;\n\ninterface GetPrivacyReturn {\n  maskTextSelector: string;\n  unmaskTextSelector: string;\n  blockSelector: string;\n  unblockSelector: string;\n  ignoreSelector: string;\n\n  blockClass?: RegExp;\n  maskTextClass?: RegExp;\n}\n\nfunction getOption(selectors: string[], defaultSelectors: string[]): string {\n  return [\n    ...selectors,\n    // sentry defaults\n    ...defaultSelectors,\n  ].join(',');\n}\n\n/**\n * Returns privacy related configuration for use in rrweb\n */\nexport function getPrivacyOptions({ mask, unmask, block, unblock, ignore }: GetPrivacyOptions): GetPrivacyReturn {\n  const defaultBlockedElements = ['base', 'iframe[srcdoc]:not([src])'];\n\n  const maskSelector = getOption(mask, ['.sentry-mask', '[data-sentry-mask]']);\n  const unmaskSelector = getOption(unmask, []);\n\n  const options: GetPrivacyReturn = {\n    // We are making the decision to make text and input selectors the same\n    maskTextSelector: maskSelector,\n    unmaskTextSelector: unmaskSelector,\n\n    blockSelector: getOption(block, ['.sentry-block', '[data-sentry-block]', ...defaultBlockedElements]),\n    unblockSelector: getOption(unblock, []),\n    ignoreSelector: getOption(ignore, ['.sentry-ignore', '[data-sentry-ignore]', 'input[type=\"file\"]']),\n  };\n\n  return options;\n}\n","import type { getPrivacyOptions } from './getPrivacyOptions';\n\ninterface MaskAttributeParams {\n  maskAttributes: string[];\n  maskAllText: boolean;\n  privacyOptions: ReturnType<typeof getPrivacyOptions>;\n  key: string;\n  value: string;\n  el: HTMLElement;\n}\n\n/**\n * Masks an attribute if necessary, otherwise return attribute value as-is.\n */\nexport function maskAttribute({\n  el,\n  key,\n  maskAttributes,\n  maskAllText,\n  privacyOptions,\n  value,\n}: MaskAttributeParams): string {\n  // We only mask attributes if `maskAllText` is true\n  if (!maskAllText) {\n    return value;\n  }\n\n  // unmaskTextSelector takes precedence\n  if (privacyOptions.unmaskTextSelector && el.matches(privacyOptions.unmaskTextSelector)) {\n    return value;\n  }\n\n  if (\n    maskAttributes.includes(key) ||\n    // Need to mask `value` attribute for `<input>` if it's a button-like\n    // type\n    (key === 'value' && el.tagName === 'INPUT' && ['submit', 'button'].includes(el.getAttribute('type') || ''))\n  ) {\n    return value.replace(/[\\S]/g, '*');\n  }\n\n  return value;\n}\n","import type { BrowserClientReplayOptions, Client, Integration, IntegrationFn, ReplayRecordingMode } from '@sentry/core';\nimport { consoleSandbox, dropUndefinedKeys, isBrowser, parseSampleRate } from '@sentry/core';\nimport {\n  DEFAULT_FLUSH_MAX_DELAY,\n  DEFAULT_FLUSH_MIN_DELAY,\n  MAX_REPLAY_DURATION,\n  MIN_REPLAY_DURATION,\n  MIN_REPLAY_DURATION_LIMIT,\n} from './constants';\nimport { ReplayContainer } from './replay';\nimport type {\n  InitialReplayPluginOptions,\n  RecordingOptions,\n  ReplayCanvasIntegrationOptions,\n  ReplayConfiguration,\n  ReplayPluginOptions,\n  SendBufferedReplayOptions,\n} from './types';\nimport { getPrivacyOptions } from './util/getPrivacyOptions';\nimport { maskAttribute } from './util/maskAttribute';\n\nconst MEDIA_SELECTORS =\n  'img,image,svg,video,object,picture,embed,map,audio,link[rel=\"icon\"],link[rel=\"apple-touch-icon\"]';\n\nconst DEFAULT_NETWORK_HEADERS = ['content-length', 'content-type', 'accept'];\n\nlet _initialized = false;\n\n/**\n * Sentry integration for [Session Replay](https://sentry.io/for/session-replay/).\n *\n * See the [Replay documentation](https://docs.sentry.io/platforms/javascript/guides/session-replay/) for more information.\n *\n * @example\n *\n * ```\n * Sentry.init({\n *   dsn: '__DSN__',\n *   integrations: [Sentry.replayIntegration()],\n * });\n * ```\n */\nexport const replayIntegration = ((options?: ReplayConfiguration) => {\n  return new Replay(options);\n}) satisfies IntegrationFn;\n\n/**\n * Replay integration\n *\n * TODO: Rewrite this to be functional integration\n * Exported for tests.\n */\nexport class Replay implements Integration {\n  /**\n   * @inheritDoc\n   */\n  public static id: string = 'Replay';\n\n  /**\n   * @inheritDoc\n   */\n  public name: string;\n\n  /**\n   * Options to pass to `rrweb.record()`\n   */\n  private readonly _recordingOptions: RecordingOptions;\n\n  /**\n   * Initial options passed to the replay integration, merged with default values.\n   * Note: `sessionSampleRate` and `errorSampleRate` are not required here, as they\n   * can only be finally set when setupOnce() is called.\n   *\n   * @private\n   */\n  private readonly _initialOptions: InitialReplayPluginOptions;\n\n  private _replay?: ReplayContainer;\n\n  public constructor({\n    flushMinDelay = DEFAULT_FLUSH_MIN_DELAY,\n    flushMaxDelay = DEFAULT_FLUSH_MAX_DELAY,\n    minReplayDuration = MIN_REPLAY_DURATION,\n    maxReplayDuration = MAX_REPLAY_DURATION,\n    stickySession = true,\n    useCompression = true,\n    workerUrl,\n    _experiments = {},\n    maskAllText = true,\n    maskAllInputs = true,\n    blockAllMedia = true,\n\n    mutationBreadcrumbLimit = 750,\n    mutationLimit = 10_000,\n\n    slowClickTimeout = 7_000,\n    slowClickIgnoreSelectors = [],\n\n    networkDetailAllowUrls = [],\n    networkDetailDenyUrls = [],\n    networkCaptureBodies = true,\n    networkRequestHeaders = [],\n    networkResponseHeaders = [],\n\n    mask = [],\n    maskAttributes = ['title', 'placeholder'],\n    unmask = [],\n    block = [],\n    unblock = [],\n    ignore = [],\n    maskFn,\n\n    beforeAddRecordingEvent,\n    beforeErrorSampling,\n    onError,\n  }: ReplayConfiguration = {}) {\n    this.name = Replay.id;\n\n    const privacyOptions = getPrivacyOptions({\n      mask,\n      unmask,\n      block,\n      unblock,\n      ignore,\n    });\n\n    this._recordingOptions = {\n      maskAllInputs,\n      maskAllText,\n      maskInputOptions: { password: true },\n      maskTextFn: maskFn,\n      maskInputFn: maskFn,\n      maskAttributeFn: (key: string, value: string, el: HTMLElement): string =>\n        maskAttribute({\n          maskAttributes,\n          maskAllText,\n          privacyOptions,\n          key,\n          value,\n          el,\n        }),\n\n      ...privacyOptions,\n\n      // Our defaults\n      slimDOMOptions: 'all',\n      inlineStylesheet: true,\n      // Disable inline images as it will increase segment/replay size\n      inlineImages: false,\n      // collect fonts, but be aware that `sentry.io` needs to be an allowed\n      // origin for playback\n      collectFonts: true,\n      errorHandler: (err: Error & { __rrweb__?: boolean }) => {\n        try {\n          err.__rrweb__ = true;\n        } catch (error) {\n          // ignore errors here\n          // this can happen if the error is frozen or does not allow mutation for other reasons\n        }\n      },\n    };\n\n    this._initialOptions = {\n      flushMinDelay,\n      flushMaxDelay,\n      minReplayDuration: Math.min(minReplayDuration, MIN_REPLAY_DURATION_LIMIT),\n      maxReplayDuration: Math.min(maxReplayDuration, MAX_REPLAY_DURATION),\n      stickySession,\n      useCompression,\n      workerUrl,\n      blockAllMedia,\n      maskAllInputs,\n      maskAllText,\n      mutationBreadcrumbLimit,\n      mutationLimit,\n      slowClickTimeout,\n      slowClickIgnoreSelectors,\n      networkDetailAllowUrls,\n      networkDetailDenyUrls,\n      networkCaptureBodies,\n      networkRequestHeaders: _getMergedNetworkHeaders(networkRequestHeaders),\n      networkResponseHeaders: _getMergedNetworkHeaders(networkResponseHeaders),\n      beforeAddRecordingEvent,\n      beforeErrorSampling,\n      onError,\n\n      _experiments,\n    };\n\n    if (this._initialOptions.blockAllMedia) {\n      // `blockAllMedia` is a more user friendly option to configure blocking\n      // embedded media elements\n      this._recordingOptions.blockSelector = !this._recordingOptions.blockSelector\n        ? MEDIA_SELECTORS\n        : `${this._recordingOptions.blockSelector},${MEDIA_SELECTORS}`;\n    }\n\n    if (this._isInitialized && isBrowser()) {\n      throw new Error('Multiple Sentry Session Replay instances are not supported');\n    }\n\n    this._isInitialized = true;\n  }\n\n  /** If replay has already been initialized */\n  protected get _isInitialized(): boolean {\n    return _initialized;\n  }\n\n  /** Update _isInitialized */\n  protected set _isInitialized(value: boolean) {\n    _initialized = value;\n  }\n\n  /**\n   * Setup and initialize replay container\n   */\n  public afterAllSetup(client: Client): void {\n    if (!isBrowser() || this._replay) {\n      return;\n    }\n\n    this._setup(client);\n    this._initialize(client);\n  }\n\n  /**\n   * Start a replay regardless of sampling rate. Calling this will always\n   * create a new session. Will log a message if replay is already in progress.\n   *\n   * Creates or loads a session, attaches listeners to varying events (DOM,\n   * PerformanceObserver, Recording, Sentry SDK, etc)\n   */\n  public start(): void {\n    if (!this._replay) {\n      return;\n    }\n    this._replay.start();\n  }\n\n  /**\n   * Start replay buffering. Buffers until `flush()` is called or, if\n   * `replaysOnErrorSampleRate` > 0, until an error occurs.\n   */\n  public startBuffering(): void {\n    if (!this._replay) {\n      return;\n    }\n\n    this._replay.startBuffering();\n  }\n\n  /**\n   * Currently, this needs to be manually called (e.g. for tests). Sentry SDK\n   * does not support a teardown\n   */\n  public stop(): Promise<void> {\n    if (!this._replay) {\n      return Promise.resolve();\n    }\n\n    return this._replay.stop({ forceFlush: this._replay.recordingMode === 'session' });\n  }\n\n  /**\n   * If not in \"session\" recording mode, flush event buffer which will create a new replay.\n   * If replay is not enabled, a new session replay is started.\n   * Unless `continueRecording` is false, the replay will continue to record and\n   * behave as a \"session\"-based replay.\n   *\n   * Otherwise, queue up a flush.\n   */\n  public flush(options?: SendBufferedReplayOptions): Promise<void> {\n    if (!this._replay) {\n      return Promise.resolve();\n    }\n\n    // assuming a session should be recorded in this case\n    if (!this._replay.isEnabled()) {\n      this._replay.start();\n      return Promise.resolve();\n    }\n\n    return this._replay.sendBufferedReplayOrFlush(options);\n  }\n\n  /**\n   * Get the current session ID.\n   */\n  public getReplayId(): string | undefined {\n    if (!this._replay || !this._replay.isEnabled()) {\n      return;\n    }\n\n    return this._replay.getSessionId();\n  }\n\n  /**\n   * Get the current recording mode. This can be either `session` or `buffer`.\n   *\n   * `session`: Recording the whole session, sending it continuously\n   * `buffer`: Always keeping the last 60s of recording, requires:\n   *   - having replaysOnErrorSampleRate > 0 to capture replay when an error occurs\n   *   - or calling `flush()` to send the replay\n   */\n  public getRecordingMode(): ReplayRecordingMode | undefined {\n    if (!this._replay || !this._replay.isEnabled()) {\n      return;\n    }\n\n    return this._replay.recordingMode;\n  }\n\n  /**\n   * Initializes replay.\n   */\n  protected _initialize(client: Client): void {\n    if (!this._replay) {\n      return;\n    }\n\n    this._maybeLoadFromReplayCanvasIntegration(client);\n    this._replay.initializeSampling();\n  }\n\n  /** Setup the integration. */\n  private _setup(client: Client): void {\n    // Client is not available in constructor, so we need to wait until setupOnce\n    const finalOptions = loadReplayOptionsFromClient(this._initialOptions, client);\n\n    this._replay = new ReplayContainer({\n      options: finalOptions,\n      recordingOptions: this._recordingOptions,\n    });\n  }\n\n  /** Get canvas options from ReplayCanvas integration, if it is also added. */\n  private _maybeLoadFromReplayCanvasIntegration(client: Client): void {\n    // To save bundle size, we skip checking for stuff here\n    // and instead just try-catch everything - as generally this should all be defined\n    /* eslint-disable @typescript-eslint/no-non-null-assertion */\n    try {\n      const canvasIntegration = client.getIntegrationByName('ReplayCanvas') as Integration & {\n        getOptions(): ReplayCanvasIntegrationOptions;\n      };\n      if (!canvasIntegration) {\n        return;\n      }\n\n      this._replay!['_canvas'] = canvasIntegration.getOptions();\n    } catch {\n      // ignore errors here\n    }\n    /* eslint-enable @typescript-eslint/no-non-null-assertion */\n  }\n}\n\n/** Parse Replay-related options from SDK options */\nfunction loadReplayOptionsFromClient(initialOptions: InitialReplayPluginOptions, client: Client): ReplayPluginOptions {\n  const opt = client.getOptions() as BrowserClientReplayOptions;\n\n  const finalOptions: ReplayPluginOptions = {\n    sessionSampleRate: 0,\n    errorSampleRate: 0,\n    ...dropUndefinedKeys(initialOptions),\n  };\n\n  const replaysSessionSampleRate = parseSampleRate(opt.replaysSessionSampleRate);\n  const replaysOnErrorSampleRate = parseSampleRate(opt.replaysOnErrorSampleRate);\n\n  if (replaysSessionSampleRate == null && replaysOnErrorSampleRate == null) {\n    consoleSandbox(() => {\n      // eslint-disable-next-line no-console\n      console.warn(\n        'Replay is disabled because neither `replaysSessionSampleRate` nor `replaysOnErrorSampleRate` are set.',\n      );\n    });\n  }\n\n  if (replaysSessionSampleRate != null) {\n    finalOptions.sessionSampleRate = replaysSessionSampleRate;\n  }\n\n  if (replaysOnErrorSampleRate != null) {\n    finalOptions.errorSampleRate = replaysOnErrorSampleRate;\n  }\n\n  return finalOptions;\n}\n\nfunction _getMergedNetworkHeaders(headers: string[]): string[] {\n  return [...DEFAULT_NETWORK_HEADERS, ...headers.map(header => header.toLowerCase())];\n}\n","import { addHandler, fill, maybeInstrument, supportsHistory, triggerHandlers } from '@sentry/core';\nimport type { HandlerDataHistory } from '@sentry/core';\nimport { WINDOW } from '../types';\n\nlet lastHref: string | undefined;\n\n/**\n * Add an instrumentation handler for when a fetch request happens.\n * The handler function is called once when the request starts and once when it ends,\n * which can be identified by checking if it has an `endTimestamp`.\n *\n * Use at your own risk, this might break without changelog notice, only used internally.\n * @hidden\n */\nexport function addHistoryInstrumentationHandler(handler: (data: HandlerDataHistory) => void): void {\n  const type = 'history';\n  addHandler(type, handler);\n  maybeInstrument(type, instrumentHistory);\n}\n\nfunction instrumentHistory(): void {\n  if (!supportsHistory()) {\n    return;\n  }\n\n  const oldOnPopState = WINDOW.onpopstate;\n  WINDOW.onpopstate = function (this: WindowEventHandlers, ...args: unknown[]) {\n    const to = WINDOW.location.href;\n    // keep track of the current URL state, as we always receive only the updated state\n    const from = lastHref;\n    lastHref = to;\n    const handlerData: HandlerDataHistory = { from, to };\n    triggerHandlers('history', handlerData);\n    if (oldOnPopState) {\n      // Apparently this can throw in Firefox when incorrectly implemented plugin is installed.\n      // https://github.com/getsentry/sentry-javascript/issues/3344\n      // https://github.com/bugsnag/bugsnag-js/issues/469\n      try {\n        return oldOnPopState.apply(this, args);\n      } catch (_oO) {\n        // no-empty\n      }\n    }\n  };\n\n  function historyReplacementFunction(originalHistoryFunction: () => void): () => void {\n    return function (this: History, ...args: unknown[]): void {\n      const url = args.length > 2 ? args[2] : undefined;\n      if (url) {\n        // coerce to string (this is what pushState does)\n        const from = lastHref;\n        const to = String(url);\n        // keep track of the current URL state, as we always receive only the updated state\n        lastHref = to;\n        const handlerData: HandlerDataHistory = { from, to };\n        triggerHandlers('history', handlerData);\n      }\n      return originalHistoryFunction.apply(this, args);\n    };\n  }\n\n  fill(WINDOW.history, 'pushState', historyReplacementFunction);\n  fill(WINDOW.history, 'replaceState', historyReplacementFunction);\n}\n","/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { WINDOW } from '../../../types';\n\nexport interface OnHiddenCallback {\n  (event: Event): void;\n}\n\n// Sentry-specific change:\n// This function's logic was NOT updated to web-vitals 4.2.4 but we continue\n// to use the web-vitals 3.5.2 due to us having stricter browser support.\n// PR with context that made the changes: https://github.com/GoogleChrome/web-vitals/pull/442/files#r1530492402\n// The PR removed listening to the `pagehide` event, in favour of only listening to `visibilitychange` event.\n// This is \"more correct\" but some browsers we still support (Safari 12.1-14.0) don't fully support `visibilitychange`\n// or have known bugs w.r.t the `visibilitychange` event.\n// TODO (v9): If we decide to drop support for Safari 12.1-14.0, we can use the logic from web-vitals 4.2.4\n// In this case, we also need to update the integration tests that currently trigger the `pagehide` event to\n// simulate the page being hidden.\nexport const onHidden = (cb: OnHiddenCallback) => {\n  const onHiddenOrPageHide = (event: Event) => {\n    if (event.type === 'pagehide' || (WINDOW.document && WINDOW.document.visibilityState === 'hidden')) {\n      cb(event);\n    }\n  };\n\n  if (WINDOW.document) {\n    addEventListener('visibilitychange', onHiddenOrPageHide, true);\n    // Some browsers have buggy implementations of visibilitychange,\n    // so we use pagehide in addition, just to be safe.\n    addEventListener('pagehide', onHiddenOrPageHide, true);\n  }\n};\n"],"names":["cachedImplementations","getNativeImplementation","name","cached","impl","WINDOW","isNativeFunction","bind","document","createElement","sandbox","hidden","head","appendChild","contentWindow","removeChild","e","DEBUG_BUILD","logger","warn","clearCachedImplementation","undefined","setTimeout","rest","trackClsAsStandaloneSpan","standaloneClsEntry","pageloadSpanId","standaloneCLsValue","supportsLayoutShift","sentSpan","_collectClsOnce","sendStandaloneClsSpan","cleanupClsHandler","addClsInstrumentationHandler","metric","entry","entries","length","value","onHidden","client","getClient","unsubscribeStartNavigation","on","activeSpan","getActiveSpan","rootSpan","getRootSpan","spanJSON","spanToJSON","op","spanContext","spanId","clsValue","log","startTime","msToSec","browserPerformanceTimeOrigin","routeName","getCurrentScope","getScopeData","transactionName","htmlTreeAsString","sources","node","attributes","dropUndefinedKeys","SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN","SEMANTIC_ATTRIBUTE_SENTRY_OP","SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME","duration","span","startStandaloneWebVitalSpan","transaction","addEvent","SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT","SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE","end","PerformanceObserver","supportedEntryTypes","includes","MAX_INT_AS_BYTES","_lcpEntry","_clsEntry","_performanceCursor","_measurements","startTrackingWebVitals","recordClsStandaloneSpans","performance","getBrowserPerformanceAPI","mark","fidCleanupCallback","_trackFID","lcpCleanupCallback","_trackLCP","ttfbCleanupCallback","_trackTtfb","clsCleanupCallback","_trackCLS","startTrackingLongTasks","addPerformanceInstrumentationHandler","parent","parentOp","start_timestamp","parentStartTimestamp","startAndEndSpan","startTrackingLongAnimationFrames","observer","list","getEntries","scripts","initialScript","invoker","invokerType","sourceURL","sourceFunctionName","sourceCharPosition","observe","type","buffered","startTrackingInteractions","spanOptions","target","componentName","getComponentName","unit","addLcpInstrumentationHandler","addFidInstrumentationHandler","timeOrigin","addTtfbInstrumentationHandler","addPerformanceEntries","options","performanceEntries","transactionStartTime","slice","forEach","Math","max","entryType","_addNavigationSpans","_addMeasureSpans","firstHidden","getVisibilityWatcher","shouldRecord","firstHiddenTime","_addResourceSpans","_trackNavigator","_addTtfbRequestTimeToMeasurements","fidMark","recordClsOnPageloadSpan","cls","Object","measurementName","measurement","setMeasurement","setAttribute","getActivationStart","_setWebVitalAttributes","navEntry","getNavigationEntry","requestTime","requestStart","measureStartTimestamp","startTimeStamp","measureEndTimestamp","event","_addPerformanceNavigationTiming","_addRequest","eventEnd","_getEndPropertyNameForNavigationTiming","start","requestStartTimestamp","responseEndTimestamp","responseEnd","responseStartTimestamp","responseStart","resourceUrl","initiatorType","parsedUrl","parseUrl","setResourceEntrySizeData","deliveryType","renderBlockingStatus","protocol","split","pop","host","location","origin","version","extractNetworkProtocol","nextHopProtocol","startTimestamp","endTimestamp","replace","navigator","connection","effectiveType","isMeasurementValue","rtt","deviceMemory","hardwareConcurrency","String","element","id","url","trim","loadTime","renderTime","size","source","index","key","dataKey","entryVal","LAST_INTERACTIONS","INTERACTIONS_SPAN_MAP","Map","startTrackingINP","inpCallback","_trackINP","INP_ENTRY_MAP","click","pointerdown","pointerup","mousedown","mouseup","touchstart","touchend","mouseover","mouseout","mouseenter","mouseleave","pointerover","pointerout","pointerenter","pointerleave","dragstart","dragend","drag","dragenter","dragleave","dragover","drop","keydown","keyup","keypress","input","addInpInstrumentationHandler","find","interactionId","interactionType","cachedSpan","get","spanToUse","description","registerInpInteractionListener","_latestRoute","handleEntries","activeRootSpan","isPerformanceEventTiming","has","last","shift","delete","push","set","DEBOUNCE_DURATION","debounceTimerID","lastCapturedEventType","lastCapturedEventTargetId","addClickKeypressInstrumentationHandler","handler","addHandler","maybeInstrument","instrumentDOM","triggerDOMHandler","triggerHandlers","globalDOMEventHandler","makeDOMEventHandler","addEventListener","globalObject","targetObj","proto","prototype","hasOwnProperty","fill","originalAddEventListener","listener","handlers","this","__sentry_instrumentation_handlers__","handlerForType","refCount","call","originalRemoveEventListener","keys","isSimilarToLastCapturedEvent","_sentryId","shouldSkipDOMEvent","eventType","tagName","isContentEditable","globalListener","getEventTarget","addNonEnumerableProperty","uuid4","handlerData","global","clearTimeout","isFinite","parentSpan","startTimeInSeconds","endTime","ctx","parentStartTime","updateStartTime","withActiveSpan","startInactiveSpan","passedAttributes","release","environment","getOptions","replay","getIntegrationByName","replayId","getReplayId","scope","user","getUser","userDisplay","email","ip_address","profileId","contexts","profile","profile_id","replay_id","userAgent","experimental","standalone","time","_name","char","isNaN","Number","getRating","thresholds","bindReporter","callback","reportAllChanges","prevValue","delta","forceReport","rating","generateUniqueID","Date","now","floor","random","initMetric","navigationType","prerendering","wasDiscarded","opts","po","Promise","resolve","then","assign","runOnce","cb","called","whenActivated","FCPThresholds","onFCP","onReport","visibilityWatcher","report","disconnect","CLSThresholds","onCLS","sessionValue","sessionEntries","hadRecentInput","firstSessionEntry","lastSessionEntry","takeRecords","FIDThresholds","onFID","handleEntry","processingStart","interactionCountEstimate","minKnownInteractionId","Infinity","maxKnownInteractionId","updateEstimate","min","getInteractionCount","interactionCount","initInteractionCountPolyfill","durationThreshold","longestInteractionList","longestInteractionMap","DEFAULT_DURATION_THRESHOLD","prevInteractionCount","getInteractionCountForNavigation","estimateP98LongestInteraction","candidateInteractionIndex","MAX_INTERACTIONS_TO_CONSIDER","entryPreProcessingCallbacks","processInteractionEntry","minLongestInteraction","existingInteraction","latency","interaction","sort","a","b","splice","i","whenIdle","rIC","requestIdleCallback","handle","visibilityState","INPThresholds","onINP","PerformanceEventTiming","inp","LCPThresholds","reportedMetricIDs","onLCP","stopListening","once","capture","TTFBThresholds","whenReady","readyState","onTTFB","navigationEntry","instrumented","_previousCls","_previousFid","_previousLcp","_previousTtfb","_previousInp","stopOnCallback","addMetricObserver","instrumentCls","instrumentLcp","instrumentFid","instrumentTtfb","instrumentInp","instrumentPerformanceObserver","getCleanupCallback","data","typeHandlers","error","getFunctionName","instrumentFn","previousValue","indexOf","activationStart","SENTRY_XHR_DATA_KEY","addXhrInstrumentationHandler","instrumentXHR","XMLHttpRequest","xhrproto","open","Proxy","apply","originalOpen","xhrOpenThisArg","xhrOpenArgArray","virtualError","Error","timestampInSeconds","method","isString","toUpperCase","request_headers","match","__sentry_own_request__","onreadystatechangeHandler","xhrInfo","status_code","status","xhr","onreadystatechange","originalOnreadystatechange","onreadystatechangeThisArg","onreadystatechangeArgArray","setRequestHeader","originalSetRequestHeader","setRequestHeaderThisArg","setRequestHeaderArgArray","header","toLowerCase","send","originalSend","sendThisArg","sendArgArray","sentryXhrData","body","toString","e2","initHiddenTime","onVisibilityUpdate","timeStamp","removeChangeListeners","addChangeListeners","removeEventListener","checkResponseStart","getEntriesByType","GLOBAL_OBJ","__SENTRY_DEBUG__","REPLAY_SESSION_KEY","REPLAY_EVENT_NAME","UNABLE_TO_SEND_REPLAY","SESSION_IDLE_PAUSE_DURATION","SESSION_IDLE_EXPIRE_DURATION","DEFAULT_FLUSH_MIN_DELAY","DEFAULT_FLUSH_MAX_DELAY","BUFFER_CHECKOUT_TIME","RETRY_BASE_INTERVAL","RETRY_MAX_COUNT","NETWORK_BODY_MAX_SIZE","CONSOLE_ARG_MAX_SIZE","SLOW_CLICK_THRESHOLD","SLOW_CLICK_SCROLL_TIMEOUT","REPLAY_MAX_EVENT_BUFFER_SIZE","MIN_REPLAY_DURATION","MIN_REPLAY_DURATION_LIMIT","MAX_REPLAY_DURATION","_nullishCoalesce$1","lhs","rhsFn","_optionalChain$5","ops","lastAccessLHS","fn","args","NodeType$3","isElement$1","n","nodeType","ELEMENT_NODE","isShadowRoot","_","Boolean","_2","shadowRoot","isNativeShadowDom","fixBrowserCompatibilityIssuesInCSS","cssText","escapeImportStatement","rule","statement","JSON","stringify","href","layerName","supportsText","media","mediaText","join","stringifyStylesheet","s","rules","cssRules","Array","from","stringifyRule","fixAllCssProperty","styles","style","styleDeclaration","attribute","isImportant","getPropertyPriority","getPropertyValue","selectorText","importStringified","isCSSImportRule","styleSheet","isCSSStyleRule","needsSafariColonFix","needsAllFix","fixSafariColons","cssStringified","regex","NodeType","Mirror","constructor","idNodeMap","nodeMetaMap","WeakMap","getId","_3","getMeta","_4","_5","getNode","getIds","removeNodeFromMap","childNodes","childNode","hasNode","add","meta","oldNode","reset","createMirror","shouldMaskInput","maskInputOptions","maskInputValue","isMasked","maskInputFn","text","repeat","str","ORIGINAL_ATTRIBUTE_NAME","is2DCanvasBlank","canvas","getContext","chunkSize","x","width","y","height","getImageData","originalGetImageData","pixelBuffer","Uint32Array","buffer","some","pixel","getInputType","hasAttribute","getInputValue","el","getAttribute","extractFileExtension","path","baseURL","URL","window","err","pathname","_6","cachedImplementations$1","getImplementation$1","setTimeout$2","clearTimeout$2","getIframeContentDocument","iframe","contentDocument","_id","tagNameRegex","RegExp","IGNORED_NODE","genId","getValidTagName","HTMLFormElement","processedTagName","test","extractOrigin","canvasService","canvasCtx","URL_IN_CSS_REF","URL_PROTOCOL_MATCH","URL_WWW_MATCH","DATA_URI","absoluteToStylesheet","quote1","path1","quote2","path2","path3","filePath","maybeQuote","stack","parts","part","SRCSET_NOT_SPACES","SRCSET_COMMAS_OR_SPACES","getAbsoluteSrcsetString","doc","attributeValue","pos","collectCharacters","regEx","chars","exec","substring","output","absoluteToDoc","descriptorsStr","inParens","c","charAt","cachedDocument","getHref","isSVGElement","ownerSVGElement","customHref","startsWith","transformAttribute","maskAttributeFn","ignoreAttribute","_value","_isBlockedElement","blockClass","blockSelector","unblockSelector","matches","classList","contains","eIndex","className","elementClassMatchesRegex","distanceToMatch","matchPredicate","limit","distance","parentNode","createMatchPredicate","selector","needMaskingText","maskTextClass","maskTextSelector","unmaskTextClass","unmaskTextSelector","maskAllText","parentElement","autocomplete","disallowedAutocompleteValues","maskDistance","unmaskDistance","onceIframeLoaded","iframeEl","iframeLoadTimeout","win","fired","timer","blankUrl","src","onceStylesheetLoaded","link","styleSheetLoadTimeout","styleSheetLoaded","sheet","serializeNode","mirror","inlineStylesheet","maskTextFn","dataURLOptions","inlineImages","recordCanvas","keepIframeSrcFn","newlyAddedElement","rootId","getRootId","DOCUMENT_NODE","compatMode","Document","DOCUMENT_TYPE_NODE","DocumentType","publicId","systemId","serializeElementNode","TEXT_NODE","serializeTextNode","CDATA_SECTION_NODE","CDATA","textContent","COMMENT_NODE","Comment","docId","parentTagName","isStyle","isScript","isTextarea","nextSibling","previousSibling","_7","_8","_9","console","forceMask","textarea","isInputMasked","Text","needBlock","len","attr","stylesheet","styleSheets","rel","crossorigin","_cssText","innerText","checked","selected","__context","rr_dataURL","toDataURL","quality","canvasDataURL","blankCanvas","blankCanvasDataURL","image","imageSrc","currentSrc","priorCrossOrigin","crossOrigin","recordInlineImage","naturalWidth","naturalHeight","drawImage","complete","removeAttribute","rr_mediaState","paused","rr_mediaCurrentTime","currentTime","scrollLeft","rr_scrollLeft","scrollTop","rr_scrollTop","getBoundingClientRect","class","rr_width","rr_height","isCustomElement","rr_src","customElements","Element","isSVG","isCustom","lowerIfExists","maybeAttr","slimDOMExcluded","sn","slimDOMOptions","comment","script","headFavicon","headMetaDescKeywords","headMetaSocial","property","headMetaRobots","headMetaHttpEquiv","headMetaAuthorship","headMetaVerification","serializeNodeWithId","skipChild","onSerialize","onIframeLoad","onStylesheetLoad","stylesheetLoadTimeout","preserveWhiteSpace","_serializedNode","serializedNode","recordChild","isShadowHost","headWhitespace","bypassOptions","childN","serializedChildNode","isShadow","iframeDoc","serializedIframeNode","serializedLinkNode","snapshot","maskAllInputs","slimDOM","color","date","month","number","range","search","tel","week","select","_optionalChain$4","passive","DEPARTED_MIRROR_ACCESS_WARNING","_mirror","map","throttle$1","func","wait","timeout","previous","leading","remaining","context","clearTimeout$1","trailing","setTimeout$1","hookSetter","d","isRevoked","original","getOwnPropertyDescriptor","defineProperty","patch","replacement","wrapped","defineProperties","__rrweb_original__","enumerable","Reflect","prop","receiver","nowTimestamp","getWindowScroll","left","scrollingElement","pageXOffset","documentElement","top","pageYOffset","_10","_11","_12","_13","_14","getWindowHeight","innerHeight","clientHeight","getWindowWidth","innerWidth","clientWidth","closestElementOfNode","isBlocked","checkAncestors","blockedPredicate","isUnblocked","blockDistance","unblockDistance","isSerialized","isIgnored","isAncestorRemoved","legacy_isTouchEvent","changedTouches","polyfill","NodeList","DOMTokenList","Node","TypeError","isSerializedIframe","nodeName","isSerializedStylesheet","hasShadowRoot","_18","getTime","StyleSheetMirror","styleIDMap","idStyleMap","_nullishCoalesce","newId","getStyle","generateId","getShadowHost","shadowHost","_19","getRootNode","_20","_21","DOCUMENT_FRAGMENT_NODE","getRootShadowHost","rootShadowHost","shadowHostInDom","ownerDocument","inDom","getImplementation","onRequestAnimationFrame","NodeType$1","NodeType$2","EventType","EventType2","IncrementalSource","IncrementalSource2","MouseInteractions","MouseInteractions2","PointerTypes","PointerTypes2","getIFrameContentDocument","getIFrameContentWindow","_optionalChain$3","isNodeInLinkedList","DoubleLinkedList","tail","position","current","next","addNode","__ln","removeNode","moveKey","parentId","MutationBuffer","frozen","locked","texts","attributeMap","removes","mapRemoves","movedMap","addedSet","Set","movedSet","droppedSet","processMutations","mutations","processMutation","emit","adds","addedIds","addList","getNextId","ns","nextId","pushAdd","currentN","iframeManager","addIframe","stylesheetManager","trackLinkElement","shadowDomManager","addShadowRoot","childSn","attachIframe","canvasManager","addWindow","observeAttachShadow","attachLinkElement","isParentRemoved","isAncestorInSet","candidate","tailNode","_node","unhandledNode","payload","filter","diffAsStr","styleDiff","unchangedAsStr","_unchangedStyles","mutationCb","m","oldValue","attributeName","item","unattachedDoc","implementation","createHTMLDocument","old","pname","newValue","newPriority","addedNodes","genAdds","removedNodes","nodeId","deepDelete","processedNodeManager","inOtherBuffer","targetId","init","freeze","unfreeze","isFrozen","lock","unlock","addsSet","_isParentRemoved","r","_isAncestorInSet","errorHandler","registerErrorHandler","unregisterErrorHandler","callbackWrapper","rrwebWrapped","_optionalChain$2","mutationBuffers","composedPath","initMutationObserver","rootEl","mutationBuffer","mutationObserverCtor","MutationObserver","__rrMutationObserver","angularZoneSymbol","Zone","__symbol__","onMutation","attributeOldValue","characterData","characterDataOldValue","childList","subtree","initMoveObserver","mousemoveCb","sampling","mousemove","threshold","callbackThreshold","mousemoveCallback","timeBaseline","positions","wrappedCb","totalOffset","p","timeOffset","updatePosition","evt","clientX","clientY","DragEvent","Drag","MouseEvent","MouseMove","TouchMove","h","initMouseInteractionObserver","mouseInteractionCb","mouseInteraction","disableMap","currentPointerType","getHandler","eventKey","pointerType","thisEventKey","Mouse","Touch","Pen","MouseDown","MouseUp","Click","endsWith","eventName","PointerEvent","TouchStart","TouchEnd","initScrollObserver","scrollCb","defaultView","scrollLeftTop","scroll","initViewportResizeObserver","viewportResizeCb","lastH","lastW","updateDimension","INPUT_TAGS","lastInputValueMap","initInputObserver","inputCb","ignoreClass","ignoreSelector","userTriggeredOnInput","eventHandler","userTriggered","isTrusted","isChecked","cbWithDedup","querySelectorAll","v","lastInputValue","events","currentWindow","propertyDescriptor","HTMLInputElement","hookProperties","HTMLSelectElement","HTMLTextAreaElement","HTMLOptionElement","getNestedCSSRulePositions","recurse","childRule","hasNestedCSSRule","parentRule","CSSGroupingRule","CSSMediaRule","CSSSupportsRule","CSSConditionRule","unshift","parentStyleSheet","getIdAndStyleId","styleMirror","styleId","ownerNode","initStyleSheetObserver","styleSheetRuleCb","CSSStyleSheet","insertRule","thisArg","argumentsList","deleteRule","replaceSync","supportedNestedCSSRuleTypes","canMonkeyPatchNestedCSSRule","unmodifiedFunctions","typeKey","initAdoptedStyleSheetObserver","hostId","patchTarget","ShadowRoot","originalPropertyDescriptor","configurable","sheets","result","_15","_16","adoptStyleSheets","initStyleDeclarationObserver","styleDeclarationCb","ignoreCSSAttributes","setProperty","CSSStyleDeclaration","priority","_17","removeProperty","remove","initMediaInteractionObserver","mediaInteractionCb","volume","muted","playbackRate","initFontObserver","fontCb","fontMap","originalFontFace","FontFace","family","descriptors","fontFace","fontSource","Uint8Array","restoreHandler","fonts","initSelectionObserver","param","selectionCb","collapsed","updateSelection","selection","getSelection","isCollapsed","ranges","count","rangeCount","getRangeAt","startContainer","startOffset","endContainer","endOffset","blocked","initCustomElementObserver","customElementCb","define","initObservers","o","_hooks","mutationObserver","recordDOM","mousemoveHandler","mouseInteractionHandler","scrollHandler","viewportResizeHandler","inputHandler","mediaInteractionHandler","styleSheetObserver","adoptedStyleSheetObserver","styleDeclarationObserver","fontObserver","collectFonts","selectionObserver","customElementObserver","pluginHandlers","plugin","plugins","_22","_23","CrossOriginIframeMirror","generateIdFn","iframeIdToRemoteIdMap","iframeRemoteIdToIdMap","remoteId","idToRemoteMap","remoteToIdMap","idToRemoteIdMap","getIdToRemoteIdMap","remoteIdToIdMap","getRemoteIdToIdMap","getRemoteId","getRemoteIds","ids","_optionalChain$1","IframeManagerNoop","crossOriginIframeMirror","crossOriginIframeRootIdMap","addLoadListener","IframeManager","iframes","crossOriginIframeMap","wrappedEmit","recordCrossOriginIframes","crossOriginIframeStyleMirror","handleMessage","loadListener","isAttachIframe","adoptedStyleSheets","message","crossOriginMessageEvent","iframeSourceWindow","transformedEvent","transformCrossOriginEvent","isCheckout","FullSnapshot","replaceIdOnNode","patchRootIdOnNode","timestamp","IncrementalSnapshot","Mutation","Meta","Load","DomContentLoaded","Plugin","Custom","replaceIds","ViewportResize","MediaInteraction","MouseInteraction","Scroll","CanvasMutation","Input","StyleSheetRule","StyleDeclaration","replaceStyleIds","Font","Selection","AdoptedStyleSheet","iframeMirror","obj","isArray","child","ShadowDomManagerNoop","ShadowDomManager","shadowDoms","WeakSet","restoreHandlers","patchAttachShadow","iframeElement","iframeWindow","manager","option","resetShadowRoots","CanvasManagerNoop","StylesheetManager","trackedLinkElements","adoptedStyleSheetCb","linkEl","trackStylesheetInLinkElement","adoptedStyleSheetData","styleIds","CSSRule","ProcessedNodeManager","nodeMap","active","thisBuffer","buffers","destroy","_takeFullSnapshot","cleanFrame","_optionalChain","debug","record","checkoutEveryNms","checkoutEveryNth","_maskInputOptions","_slimDOMOptions","maxCanvasSize","packFn","mousemoveWait","recordAfter","getCanvasManager","inEmittingFrame","passEmitsToParent","radio","checkbox","lastFullSnapshotEvent","incrementalSnapshotCount","eventProcessor","buf","postMessage","exceedCount","exceedTime","takeFullSnapshot","wrappedMutationEmit","wrappedScrollEmit","wrappedCanvasMutationEmit","wrappedAdoptedStyleSheetEmit","__RRWEB_EXCLUDE_IFRAME__","getMirror","nodeMirror","_getCanvasManager","__RRWEB_EXCLUDE_SHADOW_DOM__","initialOffset","canvasMutationCb","CustomElement","getCanvasManagerFn","ReplayEventTypeIncrementalSnapshot","ReplayEventTypeCustom","timestampToMs","isMs","timestampToS","addBreadcrumbEvent","breadcrumb","category","triggerUserActivity","checkAndHandleExpiredSession","addUpdate","throttledAddEvent","tag","normalize","INTERACTIVE_SELECTOR","getClosestInteractive","closestInteractive","closest","getClickTargetNode","getTargetNode","isEventWithTarget","onWindowOpen","monkeyPatchWindowOpen","originalWindowOpen","IncrementalMutationSources","handleClick","clickDetector","clickBreadcrumb","ClickDetector","slowClickConfig","_addBreadcrumbEvent","_lastMutation","_lastScroll","_clicks","_timeout","_threshold","_scrollTimeout","scrollTimeout","_replay","_ignoreSelector","addListeners","cleanupWindowOpen","nowInSeconds","_teardown","removeListeners","_checkClickTimeout","ignoreElement","isClickBreadcrumb","newClick","clickCount","abs","_scheduleCheckClicks","registerMutation","registerScroll","registerClick","_handleMultiClick","_getClicks","_checkClicks","timedOutClicks","mutationAfter","scrollAfter","_generateBreadcrumbs","hadScroll","hadMutation","isSlowClick","timeAfterClickMs","endReason","route","getCurrentRoute","setTimeout$3","SLOW_CLICK_TAGS","updateClickDetectorForRecordingEvent","isIncrementalEvent","isIncrementalMouseInteraction","HTMLElement","createBreadcrumb","ATTRIBUTES_TO_RECORD","getAttributesToRecord","normalizedKey","handleDomListener","isEnabled","handleDom","isClick","altKey","metaKey","ctrlKey","shiftKey","getBaseDomBreadcrumb","isElement","getDomTarget","maxStringLength","handleKeyboardEvent","updateUserActivity","getKeyboardBreadcrumb","isInputElement","hasModifierKey","isCharacterKey","baseBreadcrumb","ENTRY_TYPES","resource","createResourceEntry","paint","createPaintEntry","navigation","createNavigationEntry","webVitalHandler","getter","replayPerformanceEntries","createPerformanceEntries","createPerformanceEntry","getAbsoluteTime","decodedBodySize","domComplete","encodedBodySize","domContentLoadedEventStart","domContentLoadedEventEnd","domInteractive","loadEventStart","loadEventEnd","redirectCount","transferSize","responseStatus","statusCode","getLargestContentfulPaint","lastEntry","getWebVital","isLayoutShift","getCumulativeLayoutShift","layoutShifts","nodes","nodeIds","getFirstInputDelay","getInteractionToNextPaint","attributions","setupPerformanceObserver","addPerformanceEntry","onEntries","clearCallbacks","clearCallback","Blob","createObjectURL","CONSOLE_LEVELS","PREFIX","_addBreadcrumb","level","addBreadcrumb","makeReplayLogger","_capture","_trace","_logger","exception","infoTick","setConfig","captureExceptions","traceInternals","logger$1","severityLevelFromString","captureException","info","EventBufferSizeExceededError","super","EventBufferArray","_totalSize","hasCheckout","waitForCheckout","hasEvents","eventSize","finish","eventsRet","clear","getEarliestTimestamp","WorkerHandler","worker","_worker","ensureReady","_ensureReadyPromise","reject","success","terminate","arg","_getAndIncrementId","response","EventBufferCompressionWorker","_earliestTimestamp","_sendEventToWorker","_finishRequest","EventBufferProxy","_fallback","_compression","_used","_ensureWorkerIsLoadedPromise","_ensureWorkerIsLoaded","ensureWorkerIsLoaded","_switchToCompressionWorker","addEventPromises","all","createEventBuffer","useCompression","workerUrl","customWorkerUrl","Worker","_loadWorker","_getWorkerUrl","__SENTRY_EXCLUDE_REPLAY_WORKER__","hasSessionStorage","sessionStorage","clearSession","deleteSession","session","removeItem","isSampled","sampleRate","makeSession","started","lastActivity","segmentId","sampled","previousSessionId","saveSession","setItem","getSessionSampleType","sessionSampleRate","allowBuffering","createSession","stickySession","fetchSession","sessionStringFromStorage","getItem","sessionObj","parse","isExpired","initialTime","expiry","targetTime","isSessionExpired","maxReplayDuration","sessionIdleExpire","shouldRefreshSession","loadOrCreateSession","sessionOptions","existingSession","isCustomEvent","addEventSync","shouldAddEvent","_addEvent","async","eventBuffer","isBufferMode","recordingMode","replayOptions","eventAfterPossibleCallback","maybeApplyCallback","beforeAddRecordingEvent","isExceeded","reason","handleException","stop","recordDroppedEvent","isPaused","timestampInMs","timeouts","sessionIdlePause","initialTimestamp","isErrorEvent","isTransactionEvent","isReplayEvent","isFeedbackEvent","handleAfterSendEvent","sendResponse","handleTransactionEvent","handleErrorEvent","replayContext","trace","trace_id","traceIds","event_id","errorIds","tags","beforeErrorSampling","sendBufferedReplayOrFlush","handleBeforeSendEvent","handleHydrationError","exceptionValue","values","getLocationHref","handleBreadcrumbs","beforeAddBreadcrumb","isBreadcrumbWithCategory","normalizeBreadcrumb","normalizeConsoleBreadcrumb","arguments","isTruncated","normalizedArgs","normalizedArg","stringified","_meta","warnings","isRrwebError","hint","originalException","__rrweb__","resetReplayIdOnDynamicSamplingContext","dsc","getPropagationContext","getDynamicSamplingContextFromSpan","addFeedbackBreadcrumb","feedbackId","shouldSampleForBufferEvent","errorSampleRate","handleGlobalEventListener","breadcrumbs","isSessionActive","flush","feedback","getSessionId","_experiments","isErrorEventSampled","shouldTagReplayId","createPerformanceSpans","handleHistory","to","handleHistorySpanListener","urls","shouldFilterRequest","isSentryRequestUrl","addNetworkBreadcrumb","getBodySize","textEncoder","TextEncoder","encode","URLSearchParams","FormData","formDataStr","_serializeFormData","ArrayBuffer","byteLength","parseContentLengthHeader","parseInt","getBodyString","mergeWarning","warning","headers","newMeta","existingWarnings","makeNetworkReplayBreadcrumb","request","buildSkippedNetworkRequestOrResponse","bodySize","buildNetworkRequestOrResponse","normalizedBody","normalizeNetworkBody","getAllowedHeaders","allowedHeaders","reduce","filteredHeaders","formData","exceedsSizeLimit","isProbablyJson","_strIsProbablyJson","truncatedBody","jsonBody","first","urlMatches","fullUrl","getFullUrl","stringMatchesSomePattern","baseURI","fixedUrl","captureFetchBreadcrumbToReplay","_prepareFetchData","enrichFetchBreadcrumb","_getFetchRequestArgBody","reqSize","resSize","request_body_size","response_body_size","requestBodySize","responseBodySize","captureDetails","networkDetailAllowUrls","networkDetailDenyUrls","_getRequestInfo","_getResponseInfo","networkCaptureBodies","networkRequestHeaders","getRequestHeaders","requestBody","bodyStr","networkResponseHeaders","getAllHeaders","bodyText","_parseFetchResponseBody","getResponseData","res","_tryCloneResponse","_tryGetResponseText","fetchArgs","allHeaders","getHeadersFromOptions","Headers","clone","_getResponseText","txt","finally","captureXhrBreadcrumbToReplay","_prepareXhrData","enrichXhrBreadcrumb","getResponseHeader","_getBodySize","responseType","getResponseHeaders","requestWarning","responseBody","responseWarning","_getXhrResponseBody","getAllResponseHeaders","acc","line","errors","responseText","_parseXhrResponse","outerHTML","handleNetworkBreadcrumbs","beforeAddNetworkBreadcrumb","_isXhrBreadcrumb","_isXhrHint","_isFetchBreadcrumb","_isFetchHint","addGlobalListeners","addHistoryInstrumentationHandler","addEventProcessor","lastActiveSpan","feedbackEvent","includeReplay","addMemoryEntry","createMemoryEntry","memory","memoryEntry","jsHeapSizeLimit","totalJSHeapSize","usedJSHeapSize","debounce","callbackReturnValue","timerId","maxTimerId","maxWait","invokeFunc","cancelTimers","debounced","cancel","NAVIGATOR","getRecordingSamplingOptions","maxTouchPoints","getHandleRecordingEmit","hadFirstEvent","_isCheckout","setInitialState","addSettingsEvent","earliestEvent","createOptionsEvent","shouldRecordCanvas","isRecordingCanvas","useCompressionOption","blockAllMedia","networkDetailHasUrls","networkRequestHasHeaders","networkResponseHasHeaders","createReplayEnvelope","replayEvent","recordingData","dsn","tunnel","createEnvelope","createEventEnvelopeHeaders","getSdkMetadataForEnvelopeHeader","prepareRecordingData","payloadWithSequence","replayHeaders","enc","sequence","prepareReplayEvent","integrations","_integrations","eventHint","preparedEvent","prepareEvent","getIsolationScope","platform","metadata","getSdkMetadata","sdk","sendReplayRequest","segment_id","eventContext","preparedRecordingData","transport","getTransport","getDsn","resolvedSyncPromise","baseEvent","replay_start_timestamp","error_ids","trace_ids","replay_type","sdkProcessingMetadata","envelope","cause","TransportStatusCodeError","rateLimits","updateRateLimits","isRateLimited","RateLimitError","sendReplay","replayData","retryConfig","interval","onError","setContext","_retryCount","THROTTLED","SKIPPED","throttle","maxCount","durationSeconds","counter","_cleanup","_getTotalCount","isThrottled","wasThrottled","ReplayContainer","recordingOptions","__init","__init2","__init3","__init4","__init5","__init6","_lastActivity","_isEnabled","_isPaused","_requiresManualStart","_hasInitializedCoreListeners","_context","initialUrl","_recordingOptions","_options","_debouncedFlush","_flush","flushMinDelay","flushMaxDelay","_throttledAddEvent","slowClickTimeout","slowClickIgnoreSelectors","experiments","_canvas","initializeSampling","requiresManualStart","_initializeSessionForSampling","_initializeRecording","_updateUserActivity","startBuffering","startRecording","canvasOptions","_stopRecording","continuousCheckout","_onMutationHandler","stopRecording","forceFlush","_removeListeners","force","pause","resume","_checkSession","continueRecording","flushImmediate","activityTime","hasStoppedRecording","_updateSessionActivity","_maybeSaveSession","cbResult","conditionalFlush","cancelFlush","urlPath","hash","_clearContext","lastRootSpan","SEMANTIC_ATTRIBUTE_SENTRY_SOURCE","_addListeners","currentSession","_refreshSession","_handleVisibilityChange","_handleWindowBlur","_handleWindowFocus","_handleKeyboardEvent","_performanceCleanupCallback","_doChangeToForegroundTasks","_doChangeToBackgroundTasks","expired","_createCustomBreadcrumb","_addPerformanceEntries","concat","initialTimestampInSeconds","_updateInitialTimestampFromEventBuffer","_popEventContext","_runFlush","dropReason","tooShort","minReplayDuration","tooLong","_flushInProgress","_flushLock","mutationLimit","mutationBreadcrumbLimit","overMutationLimit","getOption","selectors","defaultSelectors","getPrivacyOptions","mask","unmask","block","unblock","ignore","defaultBlockedElements","maskSelector","unmaskSelector","maskAttribute","maskAttributes","privacyOptions","MEDIA_SELECTORS","DEFAULT_NETWORK_HEADERS","_initialized","replayIntegration","Replay","__initStatic","maskFn","password","_initialOptions","_getMergedNetworkHeaders","_isInitialized","isBrowser","afterAllSetup","_setup","_initialize","getRecordingMode","_maybeLoadFromReplayCanvasIntegration","finalOptions","loadReplayOptionsFromClient","canvasIntegration","initialOptions","opt","replaysSessionSampleRate","parseSampleRate","replaysOnErrorSampleRate","consoleSandbox","lastHref","instrumentHistory","supportsHistory","oldOnPopState","onpopstate","historyReplacementFunction","originalHistoryFunction","_oO","history","onHiddenOrPageHide"],"mappings":"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","debug_id":"6e6cfaf2-8dd5-59a8-af82-9d45647ec608"}