posthog-js 1.174.2 → 1.174.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/all-external-dependencies.js +1 -15
- package/dist/all-external-dependencies.js.map +1 -1
- package/dist/array.full.es5.js +1 -1
- package/dist/array.full.es5.js.map +1 -1
- package/dist/array.full.js +2 -16
- package/dist/array.full.js.map +1 -1
- package/dist/array.full.no-external.js +2 -16
- package/dist/array.full.no-external.js.map +1 -1
- package/dist/array.js +2 -2
- package/dist/array.js.map +1 -1
- package/dist/array.no-external.js +2 -2
- package/dist/array.no-external.js.map +1 -1
- package/dist/main.js +2 -2
- package/dist/main.js.map +1 -1
- package/dist/module.d.ts +1 -0
- package/dist/module.full.d.ts +1 -0
- package/dist/module.full.js +2 -16
- package/dist/module.full.js.map +1 -1
- package/dist/module.full.no-external.d.ts +1 -0
- package/dist/module.full.no-external.js +2 -16
- package/dist/module.full.no-external.js.map +1 -1
- package/dist/module.js +2 -2
- package/dist/module.js.map +1 -1
- package/dist/module.no-external.d.ts +1 -0
- package/dist/module.no-external.js +2 -2
- package/dist/module.no-external.js.map +1 -1
- package/dist/recorder-v2.js +1 -15
- package/dist/recorder-v2.js.map +1 -1
- package/dist/recorder.js +1 -15
- package/dist/recorder.js.map +1 -1
- package/dist/src/entrypoints/recorder.d.ts +2 -2
- package/dist/src/sessionid.d.ts +1 -0
- package/lib/package.json +6 -5
- package/lib/src/entrypoints/recorder.d.ts +2 -2
- package/lib/src/entrypoints/recorder.js +6 -5
- package/lib/src/entrypoints/recorder.js.map +1 -1
- package/lib/src/sessionid.d.ts +1 -0
- package/lib/src/sessionid.js +1 -0
- package/lib/src/sessionid.js.map +1 -1
- package/package.json +6 -5
package/dist/recorder-v2.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"recorder-v2.js","sources":["../node_modules/.pnpm/rrweb@2.0.0-alpha.13_patch_hash=es276qklpcauxli22h726xp7fe/node_modules/rrweb/es/rrweb/packages/rrweb-snapshot/es/rrweb-snapshot.js","../node_modules/.pnpm/rrweb@2.0.0-alpha.13_patch_hash=es276qklpcauxli22h726xp7fe/node_modules/rrweb/es/rrweb/packages/rrweb/src/utils.js","../node_modules/.pnpm/rrweb@2.0.0-alpha.13_patch_hash=es276qklpcauxli22h726xp7fe/node_modules/rrweb/es/rrweb/packages/types/dist/types.js","../node_modules/.pnpm/rrweb@2.0.0-alpha.13_patch_hash=es276qklpcauxli22h726xp7fe/node_modules/rrweb/es/rrweb/packages/rrweb/src/record/mutation.js","../node_modules/.pnpm/rrweb@2.0.0-alpha.13_patch_hash=es276qklpcauxli22h726xp7fe/node_modules/rrweb/es/rrweb/packages/rrweb/src/record/error-handler.js","../node_modules/.pnpm/rrweb@2.0.0-alpha.13_patch_hash=es276qklpcauxli22h726xp7fe/node_modules/rrweb/es/rrweb/packages/rrweb/src/record/observer.js","../node_modules/.pnpm/rrweb@2.0.0-alpha.13_patch_hash=es276qklpcauxli22h726xp7fe/node_modules/rrweb/es/rrweb/packages/rrweb/src/record/cross-origin-iframe-mirror.js","../node_modules/.pnpm/rrweb@2.0.0-alpha.13_patch_hash=es276qklpcauxli22h726xp7fe/node_modules/rrweb/es/rrweb/packages/rrweb/src/record/iframe-manager.js","../node_modules/.pnpm/rrweb@2.0.0-alpha.13_patch_hash=es276qklpcauxli22h726xp7fe/node_modules/rrweb/es/rrweb/packages/rrweb/src/record/shadow-dom-manager.js","../node_modules/.pnpm/rrweb@2.0.0-alpha.13_patch_hash=es276qklpcauxli22h726xp7fe/node_modules/rrweb/es/rrweb/ext/tslib/tslib.es6.js","../node_modules/.pnpm/rrweb@2.0.0-alpha.13_patch_hash=es276qklpcauxli22h726xp7fe/node_modules/rrweb/es/rrweb/ext/base64-arraybuffer/dist/base64-arraybuffer.es5.js","../node_modules/.pnpm/rrweb@2.0.0-alpha.13_patch_hash=es276qklpcauxli22h726xp7fe/node_modules/rrweb/es/rrweb/packages/rrweb/src/record/observers/canvas/serialize-args.js","../node_modules/.pnpm/rrweb@2.0.0-alpha.13_patch_hash=es276qklpcauxli22h726xp7fe/node_modules/rrweb/es/rrweb/packages/rrweb/src/record/observers/canvas/canvas.js","../node_modules/.pnpm/rrweb@2.0.0-alpha.13_patch_hash=es276qklpcauxli22h726xp7fe/node_modules/rrweb/es/rrweb/packages/rrweb/src/record/observers/canvas/webgl.js","../node_modules/.pnpm/rrweb@2.0.0-alpha.13_patch_hash=es276qklpcauxli22h726xp7fe/node_modules/rrweb/es/rrweb/_virtual/_rollup-plugin-web-worker-loader__helper__browser__createBase64WorkerFactory.js","../node_modules/.pnpm/rrweb@2.0.0-alpha.13_patch_hash=es276qklpcauxli22h726xp7fe/node_modules/rrweb/es/rrweb/_virtual/image-bitmap-data-url-worker.js","../node_modules/.pnpm/rrweb@2.0.0-alpha.13_patch_hash=es276qklpcauxli22h726xp7fe/node_modules/rrweb/es/rrweb/packages/rrweb/src/record/observers/canvas/canvas-manager.js","../node_modules/.pnpm/rrweb@2.0.0-alpha.13_patch_hash=es276qklpcauxli22h726xp7fe/node_modules/rrweb/es/rrweb/packages/rrweb/src/record/observers/canvas/2d.js","../node_modules/.pnpm/rrweb@2.0.0-alpha.13_patch_hash=es276qklpcauxli22h726xp7fe/node_modules/rrweb/es/rrweb/packages/rrweb/src/record/stylesheet-manager.js","../node_modules/.pnpm/rrweb@2.0.0-alpha.13_patch_hash=es276qklpcauxli22h726xp7fe/node_modules/rrweb/es/rrweb/packages/rrweb/src/record/processed-node-manager.js","../node_modules/.pnpm/rrweb@2.0.0-alpha.13_patch_hash=es276qklpcauxli22h726xp7fe/node_modules/rrweb/es/rrweb/packages/rrweb/src/record/index.js","../node_modules/.pnpm/rrweb@2.0.0-alpha.13_patch_hash=es276qklpcauxli22h726xp7fe/node_modules/rrweb/es/rrweb/packages/rrweb/src/plugins/console/record/error-stack-parser.js","../node_modules/.pnpm/rrweb@2.0.0-alpha.13_patch_hash=es276qklpcauxli22h726xp7fe/node_modules/rrweb/es/rrweb/packages/rrweb/src/plugins/console/record/stringify.js","../node_modules/.pnpm/rrweb@2.0.0-alpha.13_patch_hash=es276qklpcauxli22h726xp7fe/node_modules/rrweb/es/rrweb/packages/rrweb/src/plugins/console/record/index.js","../src/utils/type-utils.ts","../src/utils/globals.ts","../src/utils/logger.ts","../src/utils/index.ts","../src/utils/request-utils.ts","../src/extensions/replay/config.ts","../src/extensions/replay/rrweb-plugins/patch.ts","../src/extensions/replay/external/denylist.ts","../src/entrypoints/recorder.ts"],"sourcesContent":["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 === null || n === void 0 ? void 0 : n.host;\r\n return Boolean((host === null || host === void 0 ? void 0 : 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(' background-clip: text;', ' -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).map(stringifyRule).join(''))\r\n : null;\r\n }\r\n catch (error) {\r\n return null;\r\n }\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) && rule.selectorText.includes(':')) {\r\n return fixSafariColons(rule.cssText);\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 var _a;\r\n if (!n)\r\n return -1;\r\n const id = (_a = this.getMeta(n)) === null || _a === void 0 ? void 0 : _a.id;\r\n return id !== null && id !== void 0 ? 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 maskInputValue({ element, maskInputOptions, tagName, type, value, maskInputFn, }) {\r\n let text = value || '';\r\n const actualType = type && toLowerCase(type);\r\n if (maskInputOptions[tagName.toLowerCase()] ||\r\n (actualType && maskInputOptions[actualType])) {\r\n if (maskInputFn) {\r\n text = maskInputFn(text, element);\r\n }\r\n else {\r\n text = '*'.repeat(text.length);\r\n }\r\n }\r\n return text;\r\n}\r\nfunction toLowerCase(str) {\r\n return str.toLowerCase();\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 extractFileExtension(path, baseURL) {\r\n var _a;\r\n let url;\r\n try {\r\n url = new URL(path, baseURL !== null && baseURL !== void 0 ? 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 (_a = match === null || match === void 0 ? void 0 : match[1]) !== null && _a !== void 0 ? _a : null;\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\nfunction absoluteToDoc(doc, attributeValue) {\r\n if (!attributeValue || attributeValue.trim() === '') {\r\n return attributeValue;\r\n }\r\n const a = doc.createElement('a');\r\n a.href = attributeValue;\r\n return a.href;\r\n}\r\nfunction isSVGElement(el) {\r\n return Boolean(el.tagName === 'svg' || el.ownerSVGElement);\r\n}\r\nfunction getHref() {\r\n const a = document.createElement('a');\r\n a.href = '';\r\n return a.href;\r\n}\r\nfunction transformAttribute(doc, tagName, name, value) {\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());\r\n }\r\n else if (tagName === 'object' && name === 'data') {\r\n return absoluteToDoc(doc, value);\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 (tagName === 'video' && name === 'src' && value && value.startsWith('blob:http')));\r\n}\r\nfunction _isBlockedElement(element, blockClass, blockSelector) {\r\n try {\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 classMatchesRegex(node, regex, checkAncestors) {\r\n if (!node)\r\n return false;\r\n if (node.nodeType !== node.ELEMENT_NODE) {\r\n if (!checkAncestors)\r\n return false;\r\n return classMatchesRegex(node.parentNode, regex, checkAncestors);\r\n }\r\n for (let eIndex = node.classList.length; eIndex--;) {\r\n const className = node.classList[eIndex];\r\n if (regex.test(className)) {\r\n return true;\r\n }\r\n }\r\n if (!checkAncestors)\r\n return false;\r\n return classMatchesRegex(node.parentNode, regex, checkAncestors);\r\n}\r\nfunction needMaskingText(node, maskTextClass, maskTextSelector, checkAncestors) {\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 (typeof maskTextClass === 'string') {\r\n if (checkAncestors) {\r\n if (el.closest(`.${maskTextClass}`))\r\n return true;\r\n }\r\n else {\r\n if (el.classList.contains(maskTextClass))\r\n return true;\r\n }\r\n }\r\n else {\r\n if (classMatchesRegex(el, maskTextClass, checkAncestors))\r\n return true;\r\n }\r\n if (maskTextSelector) {\r\n if (checkAncestors) {\r\n if (el.closest(maskTextSelector))\r\n return true;\r\n }\r\n else {\r\n if (el.matches(maskTextSelector))\r\n return true;\r\n }\r\n }\r\n }\r\n catch (e) {\r\n }\r\n return false;\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, needsMask, 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 inlineStylesheet,\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 });\r\n case n.TEXT_NODE:\r\n return serializeTextNode(n, {\r\n needsMask,\r\n maskTextFn,\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 var _a;\r\n const { needsMask, maskTextFn, 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 if (isStyle && textContent) {\r\n try {\r\n if (n.nextSibling || n.previousSibling) {\r\n }\r\n else if ((_a = n.parentNode.sheet) === null || _a === void 0 ? void 0 : _a.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());\r\n }\r\n if (isScript) {\r\n textContent = 'SCRIPT_PLACEHOLDER';\r\n }\r\n if (!isStyle && !isScript && textContent && needsMask) {\r\n textContent = maskTextFn\r\n ? maskTextFn(textContent, n.parentElement)\r\n : textContent.replace(/[\\S]/g, '*');\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, inlineStylesheet, maskInputOptions = {}, maskInputFn, dataURLOptions = {}, inlineImages, recordCanvas, keepIframeSrcFn, newlyAddedElement = false, rootId, } = options;\r\n const needBlock = _isBlockedElement(n, blockClass, blockSelector);\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 (!ignoreAttribute(tagName, attr.name, attr.value)) {\r\n attributes[attr.name] = transformAttribute(doc, tagName, toLowerCase(attr.name), attr.value);\r\n }\r\n }\r\n if (tagName === 'link' && inlineStylesheet) {\r\n const href = n.href\r\n let stylesheet = Array.from(doc.styleSheets).find((s) => {\r\n return s.href === href;\r\n });\r\n if (!stylesheet && href.includes('.css')) {\r\n const rootDomain = window.location.origin\r\n const stylesheetPath = href.replace(window.location.href, '')\r\n const potentialStylesheetHref = rootDomain + '/' + stylesheetPath\r\n stylesheet = Array.from(doc.styleSheets).find((s) => {\r\n return s.href === potentialStylesheetHref;\r\n });\r\n }\r\n let cssText = null;\r\n if (stylesheet) {\r\n cssText = stringifyStylesheet(stylesheet);\r\n }\r\n if (cssText) {\r\n delete attributes.rel;\r\n delete attributes.href;\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());\r\n }\r\n }\r\n if (tagName === 'input' || tagName === 'textarea' || tagName === 'select') {\r\n const value = n.value;\r\n const checked = n.checked;\r\n if (attributes.type !== 'radio' &&\r\n attributes.type !== 'checkbox' &&\r\n attributes.type !== 'submit' &&\r\n attributes.type !== 'button' &&\r\n value) {\r\n attributes.value = maskInputValue({\r\n element: n,\r\n type: getInputType(n),\r\n tagName,\r\n value,\r\n maskInputOptions,\r\n maskInputFn,\r\n });\r\n }\r\n else 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 = document.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 oldValue = image.crossOrigin;\r\n image.crossOrigin = 'anonymous';\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 console.warn(`Cannot inline img src=${image.currentSrc}! Error: ${err}`);\r\n }\r\n oldValue\r\n ? (attributes.crossOrigin = oldValue)\r\n : image.removeAttribute('crossorigin');\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 const mediaAttributes = attributes;\r\n mediaAttributes.rr_mediaState = n.paused\r\n ? 'paused'\r\n : 'played';\r\n mediaAttributes.rr_mediaCurrentTime = n.currentTime;\r\n mediaAttributes.rr_mediaPlaybackRate = n.playbackRate;\r\n mediaAttributes.rr_mediaMuted = n.muted;\r\n mediaAttributes.rr_mediaLoop = n.loop;\r\n mediaAttributes.rr_mediaVolume = n.volume;\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 (!n.contentDocument) {\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.attributes.as === 'script') ||\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, maskTextClass, maskTextSelector, skipChild = false, inlineStylesheet = true, maskInputOptions = {}, maskTextFn, maskInputFn, slimDOMOptions, dataURLOptions = {}, inlineImages = false, recordCanvas = false, onSerialize, onIframeLoad, iframeLoadTimeout = 5000, onStylesheetLoad, stylesheetLoadTimeout = 5000, keepIframeSrcFn = () => false, newlyAddedElement = false, } = options;\r\n let { needsMask } = options;\r\n let { preserveWhiteSpace = true } = options;\r\n if (!needsMask &&\r\n n.childNodes) {\r\n const checkAncestors = needsMask === undefined;\r\n needsMask = needMaskingText(n, maskTextClass, maskTextSelector, checkAncestors);\r\n }\r\n const _serializedNode = serializeNode(n, {\r\n doc,\r\n mirror,\r\n blockClass,\r\n blockSelector,\r\n needsMask,\r\n inlineStylesheet,\r\n maskInputOptions,\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 needsMask,\r\n maskTextClass,\r\n maskTextSelector,\r\n skipChild,\r\n inlineStylesheet,\r\n maskInputOptions,\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 (serializedNode.type === NodeType.Element &&\r\n serializedNode.tagName === 'textarea' &&\r\n serializedNode.attributes.value !== undefined) ;\r\n else {\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 }\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 = n.contentDocument;\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 needsMask,\r\n maskTextClass,\r\n maskTextSelector,\r\n skipChild: false,\r\n inlineStylesheet,\r\n maskInputOptions,\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 needsMask,\r\n maskTextClass,\r\n maskTextSelector,\r\n skipChild: false,\r\n inlineStylesheet,\r\n maskInputOptions,\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, maskTextClass = 'rr-mask', maskTextSelector = null, inlineStylesheet = true, inlineImages = false, recordCanvas = false, maskAllInputs = false, 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 password: true,\r\n }\r\n : maskAllInputs === false\r\n ? {\r\n password: true,\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 maskTextClass,\r\n maskTextSelector,\r\n skipChild: false,\r\n inlineStylesheet,\r\n maskInputOptions,\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 whitespace();\r\n while (css[0] == '}') {\r\n error('extra closing bracket');\r\n css = css.slice(1);\r\n whitespace();\r\n }\r\n const m = match(/^((\"(?:\\\\\"|[^\"])*\"|'(?:\\\\'|[^'])*'|[^{])+)/);\r\n if (!m) {\r\n return;\r\n }\r\n const cleanedInput = m[0]\r\n .trim()\r\n .replace(/\\/\\*([^*]|[\\r\\n]|(\\*+([^*/]|[\\r\\n])))*\\*\\/+/g, '')\r\n .replace(/\"(?:\\\\\"|[^\"])*\"|'(?:\\\\'|[^'])*'/g, (m) => {\r\n return m.replace(/,/g, '\\u200C');\r\n });\r\n return customSplit(cleanedInput).map((s) => s.replace(/\\u200C/g, ',').trim());\r\n }\r\n function customSplit(input) {\r\n const result = [];\r\n let currentSegment = '';\r\n let depthParentheses = 0;\r\n let depthBrackets = 0;\r\n for (const char of input) {\r\n if (char === '(') {\r\n depthParentheses++;\r\n }\r\n else if (char === ')') {\r\n depthParentheses--;\r\n }\r\n else if (char === '[') {\r\n depthBrackets++;\r\n }\r\n else if (char === ']') {\r\n depthBrackets--;\r\n }\r\n if (char === ',' && depthParentheses === 0 && depthBrackets === 0) {\r\n result.push(currentSegment);\r\n currentSegment = '';\r\n }\r\n else {\r\n currentSegment += char;\r\n }\r\n }\r\n if (currentSegment) {\r\n result.push(currentSegment);\r\n }\r\n return result;\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('^@' + name + '\\\\s*([^;]+);');\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 MEDIA_SELECTOR = /(max|min)-device-(width|height)/;\r\nconst MEDIA_SELECTOR_GLOBAL = new RegExp(MEDIA_SELECTOR.source, 'g');\r\nconst HOVER_SELECTOR = /([^\\\\]):hover/;\r\nconst HOVER_SELECTOR_GLOBAL = new RegExp(HOVER_SELECTOR.source, 'g');\r\nfunction adaptCssForReplay(cssText, cache) {\r\n const cachedStyle = cache === null || cache === void 0 ? void 0 : cache.stylesWithHoverClass.get(cssText);\r\n if (cachedStyle)\r\n return cachedStyle;\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 const medias = [];\r\n function getSelectors(rule) {\r\n if ('selectors' in rule && rule.selectors) {\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 if ('media' in rule && rule.media && MEDIA_SELECTOR.test(rule.media)) {\r\n medias.push(rule.media);\r\n }\r\n if ('rules' in rule && rule.rules) {\r\n rule.rules.forEach(getSelectors);\r\n }\r\n }\r\n getSelectors(ast.stylesheet);\r\n let result = cssText;\r\n if (selectors.length > 0) {\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 result = result.replace(selectorMatcher, (selector) => {\r\n const newSelector = selector.replace(HOVER_SELECTOR_GLOBAL, '$1.\\\\:hover');\r\n return `${selector}, ${newSelector}`;\r\n });\r\n }\r\n if (medias.length > 0) {\r\n const mediaMatcher = new RegExp(medias\r\n .filter((media, index) => medias.indexOf(media) === index)\r\n .sort((a, b) => b.length - a.length)\r\n .map((media) => {\r\n return escapeRegExp(media);\r\n })\r\n .join('|'), 'g');\r\n result = result.replace(mediaMatcher, (media) => {\r\n return media.replace(MEDIA_SELECTOR_GLOBAL, '$1-$2');\r\n });\r\n }\r\n cache === null || cache === void 0 ? void 0 : 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 var _a;\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 ((_a = doc.defaultView) === null || _a === void 0 ? void 0 : _a.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 = adaptCssForReplay(value, cache);\r\n }\r\n if ((isTextarea || isRemoteOrDynamicCss) && typeof value === 'string') {\r\n node.appendChild(doc.createTextNode(value));\r\n n.childNodes = [];\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 n.attributes.as === 'script') {\r\n }\r\n else if (tagName === 'link' &&\r\n n.attributes.rel === 'prefetch' &&\r\n typeof n.attributes.href === 'string' &&\r\n n.attributes.href.endsWith('.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 = document.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.width = value.toString();\r\n }\r\n else if (name === 'rr_height') {\r\n node.style.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 else if (name === 'rr_mediaPlaybackRate' &&\r\n typeof value === 'number') {\r\n node.playbackRate = value;\r\n }\r\n else if (name === 'rr_mediaMuted' && typeof value === 'boolean') {\r\n node.muted = value;\r\n }\r\n else if (name === 'rr_mediaLoop' && typeof value === 'boolean') {\r\n node.loop = value;\r\n }\r\n else if (name === 'rr_mediaVolume' && typeof value === 'number') {\r\n node.volume = value;\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 ? adaptCssForReplay(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 === null || n === void 0 ? void 0 : 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, adaptCssForReplay, buildNodeWithSN, classMatchesRegex, createCache, createMirror, escapeImportStatement, extractFileExtension, fixSafariColons, genId, getInputType, ignoreAttribute, is2DCanvasBlank, isCSSImportRule, isCSSStyleRule, isElement, isNativeShadowDom, isNodeMetaEqual, isShadowRoot, maskInputValue, needMaskingText, rebuild, serializeNodeWithId, snapshot, stringifyRule, stringifyStylesheet, toLowerCase, transformAttribute };\n","import { classMatchesRegex, IGNORED_NODE, isShadowRoot } 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 (_a) {\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 var _a, _b, _c, _d, _e, _f;\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 === null || doc === void 0 ? void 0 : doc.documentElement.scrollLeft) ||\r\n ((_b = (_a = doc === null || doc === void 0 ? void 0 : doc.body) === null || _a === void 0 ? void 0 : _a.parentElement) === null || _b === void 0 ? void 0 : _b.scrollLeft) ||\r\n ((_c = doc === null || doc === void 0 ? void 0 : doc.body) === null || _c === void 0 ? void 0 : _c.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 === null || doc === void 0 ? void 0 : doc.documentElement.scrollTop) ||\r\n ((_e = (_d = doc === null || doc === void 0 ? void 0 : doc.body) === null || _d === void 0 ? void 0 : _d.parentElement) === null || _e === void 0 ? void 0 : _e.scrollTop) ||\r\n ((_f = doc === null || doc === void 0 ? void 0 : doc.body) === null || _f === void 0 ? void 0 : _f.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, 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 try {\r\n if (typeof blockClass === 'string') {\r\n if (el.classList.contains(blockClass))\r\n return true;\r\n if (checkAncestors && el.closest('.' + blockClass) !== null)\r\n return true;\r\n }\r\n else {\r\n if (classMatchesRegex(el, blockClass, checkAncestors))\r\n return true;\r\n }\r\n }\r\n catch (e) {\r\n }\r\n if (blockSelector) {\r\n if (el.matches(blockSelector))\r\n return true;\r\n if (checkAncestors && el.closest(blockSelector) !== null)\r\n return true;\r\n }\r\n return false;\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 var _a, _b;\r\n const frameElement = (_b = (_a = node.ownerDocument) === null || _a === void 0 ? void 0 : _a.defaultView) === null || _b === void 0 ? void 0 : _b.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 === null || n === void 0 ? void 0 : 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 var _a;\r\n return (_a = this.styleIDMap.get(stylesheet)) !== null && _a !== void 0 ? _a : -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 var _a, _b;\r\n let shadowHost = null;\r\n if (((_b = (_a = n.getRootNode) === null || _a === void 0 ? void 0 : _a.call(n)) === null || _b === void 0 ? void 0 : _b.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}\n\nexport { StyleSheetMirror, _mirror, closestElementOfNode, getBaseDimension, getNestedRule, getPositionsAndIndex, getRootShadowHost, getShadowHost, getWindowHeight, getWindowScroll, getWindowWidth, hasShadowRoot, hookSetter, inDom, isAncestorRemoved, isBlocked, isIgnored, isSerialized, isSerializedIframe, isSerializedStylesheet, iterateResolveTree, legacy_isTouchEvent, nowTimestamp, on, patch, polyfill, queueToResolveTrees, 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","import { isShadowRoot, isNativeShadowDom, getInputType, maskInputValue, ignoreAttribute, transformAttribute, toLowerCase, needMaskingText, IGNORED_NODE, serializeNodeWithId } from '../../../rrweb-snapshot/es/rrweb-snapshot.js';\nimport { isIgnored, isBlocked, isSerialized, isAncestorRemoved, closestElementOfNode, hasShadowRoot, inDom, getShadowHost, isSerializedIframe, isSerializedStylesheet } from '../utils.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 === null || current === void 0 ? void 0 : 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 ||\r\n !inDom(n) ||\r\n n.parentNode.tagName === 'TEXTAREA') {\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 maskTextClass: this.maskTextClass,\r\n maskTextSelector: this.maskTextSelector,\r\n skipChild: true,\r\n newlyAddedElement: true,\r\n inlineStylesheet: this.inlineStylesheet,\r\n maskInputOptions: this.maskInputOptions,\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 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 this.iframeManager.attachIframe(iframe, childSn);\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 const n = text.node;\r\n if (n.parentNode &&\r\n n.parentNode.tagName === 'TEXTAREA') {\r\n this.genTextAreaValueMutation(n.parentNode);\r\n }\r\n return {\r\n id: this.mirror.getId(n),\r\n value: text.value,\r\n };\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.genTextAreaValueMutation = (textarea) => {\r\n let item = this.attributeMap.get(textarea);\r\n if (!item) {\r\n item = {\r\n node: textarea,\r\n attributes: {},\r\n styleDiff: {},\r\n _unchangedStyles: {},\r\n };\r\n this.attributes.push(item);\r\n this.attributeMap.set(textarea, item);\r\n }\r\n item.attributes.value = Array.from(textarea.childNodes, (cn) => cn.textContent || '').join('');\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, false) &&\r\n value !== m.oldValue) {\r\n this.texts.push({\r\n value: needMaskingText(m.target, this.maskTextClass, this.maskTextSelector, true) && 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 value = maskInputValue({\r\n element: target,\r\n maskInputOptions: this.maskInputOptions,\r\n tagName: target.tagName,\r\n type,\r\n value,\r\n maskInputFn: this.maskInputFn,\r\n });\r\n }\r\n if (isBlocked(m.target, this.blockClass, this.blockSelector, 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 if (!target.contentDocument) {\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, value)) {\r\n item.attributes[attributeName] = transformAttribute(this.doc, toLowerCase(target.tagName), toLowerCase(attributeName), value);\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, true))\r\n return;\r\n if (m.target.tagName === 'TEXTAREA') {\r\n this.genTextAreaValueMutation(m.target);\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, 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, 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 'maskTextClass',\r\n 'maskTextSelector',\r\n 'inlineStylesheet',\r\n 'maskInputOptions',\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 const { parentNode } = n;\r\n if (!parentNode) {\r\n return false;\r\n }\r\n const parentId = mirror.getId(parentNode);\r\n if (removes.some((r) => r.id === parentId)) {\r\n return true;\r\n }\r\n return _isParentRemoved(removes, parentNode, mirror);\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 throw error;\r\n }\r\n });\r\n return rrwebWrapped;\r\n};\n\nexport { callbackWrapper, registerErrorHandler, unregisterErrorHandler };\n","import { toLowerCase, getInputType, maskInputValue } from '../../../rrweb-snapshot/es/rrweb-snapshot.js';\nimport { on, throttle, isBlocked, getWindowScroll, getWindowHeight, getWindowWidth, hookSetter, patch, legacy_isTouchEvent, nowTimestamp } from '../utils.js';\nimport { MouseInteractions, IncrementalSource, PointerTypes } from '../../../types/dist/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 (_a) {\r\n }\r\n return event && event.target;\r\n}\r\nfunction initMutationObserver(options, rootEl) {\r\n var _a, _b;\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 = (_b = (_a = window === null || window === void 0 ? void 0 : window.Zone) === null || _a === void 0 ? void 0 : _a.__symbol__) === null || _b === void 0 ? void 0 : _b.call(_a, 'MutationObserver');\r\n if (angularZoneSymbol &&\r\n window[angularZoneSymbol]) {\r\n mutationObserverCtor = window[angularZoneSymbol];\r\n }\r\n const observer = new mutationObserverCtor(callbackWrapper(mutationBuffer.processMutations.bind(mutationBuffer)));\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, 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, 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)(Object.assign({ type: MouseInteractions[thisEventKey], id, x: clientX, y: clientY }, (pointerType !== null && { pointerType })));\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, 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, 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, ignoreClass, ignoreSelector, maskInputOptions, maskInputFn, sampling, userTriggeredOnInput, }) {\r\n function eventHandler(event) {\r\n let target = getEventTarget(event);\r\n const userTriggered = event.isTrusted;\r\n const tagName = target && target.tagName;\r\n if (target && tagName === 'OPTION') {\r\n target = target.parentElement;\r\n }\r\n if (!target ||\r\n !tagName ||\r\n INPUT_TAGS.indexOf(tagName) < 0 ||\r\n isBlocked(target, blockClass, blockSelector, true)) {\r\n return;\r\n }\r\n if (target.classList.contains(ignoreClass) ||\r\n (ignoreSelector && target.matches(ignoreSelector))) {\r\n return;\r\n }\r\n let text = target.value;\r\n let isChecked = false;\r\n const type = getInputType(target) || '';\r\n if (type === 'radio' || type === 'checkbox') {\r\n isChecked = target.checked;\r\n }\r\n else if (maskInputOptions[tagName.toLowerCase()] ||\r\n maskInputOptions[type]) {\r\n text = maskInputValue({\r\n element: target,\r\n maskInputOptions,\r\n tagName,\r\n type,\r\n value: text,\r\n maskInputFn,\r\n });\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 = el.value;\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)(Object.assign(Object.assign({}, v), { id }));\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 var _a, _b, _c;\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 ? (_a = host.defaultView) === null || _a === void 0 ? void 0 : _a.Document\r\n : (_c = (_b = host.ownerDocument) === null || _b === void 0 ? void 0 : _b.defaultView) === null || _c === void 0 ? void 0 : _c.ShadowRoot;\r\n const originalPropertyDescriptor = (patchTarget === null || patchTarget === void 0 ? void 0 : patchTarget.prototype)\r\n ? Object.getOwnPropertyDescriptor(patchTarget === null || patchTarget === void 0 ? void 0 : 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 var _a;\r\n return (_a = originalPropertyDescriptor.get) === null || _a === void 0 ? void 0 : _a.call(this);\r\n },\r\n set(sheets) {\r\n var _a;\r\n const result = (_a = originalPropertyDescriptor.set) === null || _a === void 0 ? void 0 : _a.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 var _a;\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((_a = thisArg.parentRule) === null || _a === void 0 ? void 0 : _a.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 var _a;\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((_a = thisArg.parentRule) === null || _a === void 0 ? void 0 : _a.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, 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, true)) {\r\n return;\r\n }\r\n const { currentTime, volume, muted, playbackRate, loop } = 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 loop,\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, selectionCb } = param;\r\n let collapsed = true;\r\n const updateSelection = callbackWrapper(() => {\r\n const selection = doc.getSelection();\r\n if (!selection || (collapsed && (selection === null || selection === void 0 ? void 0 : 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, true) ||\r\n isBlocked(endContainer, blockClass, blockSelector, 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 console.warn(`Custom element callback failed for ${name}`);\r\n }\r\n return original.apply(this, [name, constructor, options]);\r\n };\r\n });\r\n return restoreHandler;\r\n}\r\nfunction mergeHooks(o, hooks) {\r\n const { mutationCb, mousemoveCb, mouseInteractionCb, scrollCb, viewportResizeCb, inputCb, mediaInteractionCb, styleSheetRuleCb, styleDeclarationCb, canvasMutationCb, fontCb, selectionCb, customElementCb, } = o;\r\n o.mutationCb = (...p) => {\r\n if (hooks.mutation) {\r\n hooks.mutation(...p);\r\n }\r\n mutationCb(...p);\r\n };\r\n o.mousemoveCb = (...p) => {\r\n if (hooks.mousemove) {\r\n hooks.mousemove(...p);\r\n }\r\n mousemoveCb(...p);\r\n };\r\n o.mouseInteractionCb = (...p) => {\r\n if (hooks.mouseInteraction) {\r\n hooks.mouseInteraction(...p);\r\n }\r\n mouseInteractionCb(...p);\r\n };\r\n o.scrollCb = (...p) => {\r\n if (hooks.scroll) {\r\n hooks.scroll(...p);\r\n }\r\n scrollCb(...p);\r\n };\r\n o.viewportResizeCb = (...p) => {\r\n if (hooks.viewportResize) {\r\n hooks.viewportResize(...p);\r\n }\r\n viewportResizeCb(...p);\r\n };\r\n o.inputCb = (...p) => {\r\n if (hooks.input) {\r\n hooks.input(...p);\r\n }\r\n inputCb(...p);\r\n };\r\n o.mediaInteractionCb = (...p) => {\r\n if (hooks.mediaInteaction) {\r\n hooks.mediaInteaction(...p);\r\n }\r\n mediaInteractionCb(...p);\r\n };\r\n o.styleSheetRuleCb = (...p) => {\r\n if (hooks.styleSheetRule) {\r\n hooks.styleSheetRule(...p);\r\n }\r\n styleSheetRuleCb(...p);\r\n };\r\n o.styleDeclarationCb = (...p) => {\r\n if (hooks.styleDeclaration) {\r\n hooks.styleDeclaration(...p);\r\n }\r\n styleDeclarationCb(...p);\r\n };\r\n o.canvasMutationCb = (...p) => {\r\n if (hooks.canvasMutation) {\r\n hooks.canvasMutation(...p);\r\n }\r\n canvasMutationCb(...p);\r\n };\r\n o.fontCb = (...p) => {\r\n if (hooks.font) {\r\n hooks.font(...p);\r\n }\r\n fontCb(...p);\r\n };\r\n o.selectionCb = (...p) => {\r\n if (hooks.selection) {\r\n hooks.selection(...p);\r\n }\r\n selectionCb(...p);\r\n };\r\n o.customElementCb = (...c) => {\r\n if (hooks.customElement) {\r\n hooks.customElement(...c);\r\n }\r\n customElementCb(...c);\r\n };\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 mergeHooks(o, hooks);\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 === null || mutationObserver === void 0 ? void 0 : 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/types.js';\n\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 var _a;\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 (_a = this.loadListener) === null || _a === void 0 ? void 0 : _a.call(this, iframeEl);\r\n if (iframeEl.contentDocument &&\r\n iframeEl.contentDocument.adoptedStyleSheets &&\r\n iframeEl.contentDocument.adoptedStyleSheets.length > 0)\r\n this.stylesheetManager.adoptStyleSheets(iframeEl.contentDocument.adoptedStyleSheets, this.mirror.getId(iframeEl.contentDocument));\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 var _a;\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 (_a = e.data.styles) === null || _a === void 0 ? void 0 : _a.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 };\n","import { initMutationObserver, initScrollObserver, initAdoptedStyleSheetObserver } from './observer.js';\nimport { patch, inDom } from '../utils.js';\nimport { isNativeShadowDom } from '../../../rrweb-snapshot/es/rrweb-snapshot.js';\n\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 const observer = initMutationObserver(Object.assign(Object.assign({}, this.bypassOptions), { doc, mutationCb: this.mutationCb, mirror: this.mirror, shadowDomManager: this }), shadowRoot);\r\n this.restoreHandlers.push(() => observer.disconnect());\r\n this.restoreHandlers.push(initScrollObserver(Object.assign(Object.assign({}, this.bypassOptions), { scrollCb: this.scrollCb, doc: shadowRoot, mirror: this.mirror })));\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 if (!iframeElement.contentWindow || !iframeElement.contentDocument)\r\n return;\r\n this.patchAttachShadow(iframeElement.contentWindow.Element, iframeElement.contentDocument);\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 }\r\n}\n\nexport { ShadowDomManager };\n","/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n\r\nfunction __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nfunction __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\n\nexport { __awaiter, __rest };\n","/*\n * base64-arraybuffer 1.0.1 <https://github.com/niklasvh/base64-arraybuffer>\n * Copyright (c) 2021 Niklas von Hertzen <https://hertzen.com>\n * Released under MIT License\n */\nvar chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';\n// Use a lookup table to find the index.\nvar lookup = typeof Uint8Array === 'undefined' ? [] : new Uint8Array(256);\nfor (var i = 0; i < chars.length; i++) {\n lookup[chars.charCodeAt(i)] = i;\n}\nvar encode = function (arraybuffer) {\n var bytes = new Uint8Array(arraybuffer), i, len = bytes.length, base64 = '';\n for (i = 0; i < len; i += 3) {\n base64 += chars[bytes[i] >> 2];\n base64 += chars[((bytes[i] & 3) << 4) | (bytes[i + 1] >> 4)];\n base64 += chars[((bytes[i + 1] & 15) << 2) | (bytes[i + 2] >> 6)];\n base64 += chars[bytes[i + 2] & 63];\n }\n if (len % 3 === 2) {\n base64 = base64.substring(0, base64.length - 1) + '=';\n }\n else if (len % 3 === 1) {\n base64 = base64.substring(0, base64.length - 2) + '==';\n }\n return base64;\n};\nvar decode = function (base64) {\n var bufferLength = base64.length * 0.75, len = base64.length, i, p = 0, encoded1, encoded2, encoded3, encoded4;\n if (base64[base64.length - 1] === '=') {\n bufferLength--;\n if (base64[base64.length - 2] === '=') {\n bufferLength--;\n }\n }\n var arraybuffer = new ArrayBuffer(bufferLength), bytes = new Uint8Array(arraybuffer);\n for (i = 0; i < len; i += 4) {\n encoded1 = lookup[base64.charCodeAt(i)];\n encoded2 = lookup[base64.charCodeAt(i + 1)];\n encoded3 = lookup[base64.charCodeAt(i + 2)];\n encoded4 = lookup[base64.charCodeAt(i + 3)];\n bytes[p++] = (encoded1 << 2) | (encoded2 >> 4);\n bytes[p++] = ((encoded2 & 15) << 4) | (encoded3 >> 2);\n bytes[p++] = ((encoded3 & 3) << 6) | (encoded4 & 63);\n }\n return arraybuffer;\n};\n\nexport { decode, encode };\n","import { encode } from './../../../../../../ext/base64-arraybuffer/dist/base64-arraybuffer.es5.js';\n\nconst canvasVarMap = new Map();\r\nfunction variableListFor(ctx, ctor) {\r\n let contextMap = canvasVarMap.get(ctx);\r\n if (!contextMap) {\r\n contextMap = new Map();\r\n canvasVarMap.set(ctx, contextMap);\r\n }\r\n if (!contextMap.has(ctor)) {\r\n contextMap.set(ctor, []);\r\n }\r\n return contextMap.get(ctor);\r\n}\r\nconst saveWebGLVar = (value, win, ctx) => {\r\n if (!value ||\r\n !(isInstanceOfWebGLObject(value, win) || typeof value === 'object'))\r\n return;\r\n const name = value.constructor.name;\r\n const list = variableListFor(ctx, name);\r\n let index = list.indexOf(value);\r\n if (index === -1) {\r\n index = list.length;\r\n list.push(value);\r\n }\r\n return index;\r\n};\r\nfunction serializeArg(value, win, ctx) {\r\n if (value instanceof Array) {\r\n return value.map((arg) => serializeArg(arg, win, ctx));\r\n }\r\n else if (value === null) {\r\n return value;\r\n }\r\n else if (value instanceof Float32Array ||\r\n value instanceof Float64Array ||\r\n value instanceof Int32Array ||\r\n value instanceof Uint32Array ||\r\n value instanceof Uint8Array ||\r\n value instanceof Uint16Array ||\r\n value instanceof Int16Array ||\r\n value instanceof Int8Array ||\r\n value instanceof Uint8ClampedArray) {\r\n const name = value.constructor.name;\r\n return {\r\n rr_type: name,\r\n args: [Object.values(value)],\r\n };\r\n }\r\n else if (value instanceof ArrayBuffer) {\r\n const name = value.constructor.name;\r\n const base64 = encode(value);\r\n return {\r\n rr_type: name,\r\n base64,\r\n };\r\n }\r\n else if (value instanceof DataView) {\r\n const name = value.constructor.name;\r\n return {\r\n rr_type: name,\r\n args: [\r\n serializeArg(value.buffer, win, ctx),\r\n value.byteOffset,\r\n value.byteLength,\r\n ],\r\n };\r\n }\r\n else if (value instanceof HTMLImageElement) {\r\n const name = value.constructor.name;\r\n const { src } = value;\r\n return {\r\n rr_type: name,\r\n src,\r\n };\r\n }\r\n else if (value instanceof HTMLCanvasElement) {\r\n const name = 'HTMLImageElement';\r\n const src = value.toDataURL();\r\n return {\r\n rr_type: name,\r\n src,\r\n };\r\n }\r\n else if (value instanceof ImageData) {\r\n const name = value.constructor.name;\r\n return {\r\n rr_type: name,\r\n args: [serializeArg(value.data, win, ctx), value.width, value.height],\r\n };\r\n }\r\n else if (isInstanceOfWebGLObject(value, win) || typeof value === 'object') {\r\n const name = value.constructor.name;\r\n const index = saveWebGLVar(value, win, ctx);\r\n return {\r\n rr_type: name,\r\n index: index,\r\n };\r\n }\r\n return value;\r\n}\r\nconst serializeArgs = (args, win, ctx) => {\r\n return args.map((arg) => serializeArg(arg, win, ctx));\r\n};\r\nconst isInstanceOfWebGLObject = (value, win) => {\r\n const webGLConstructorNames = [\r\n 'WebGLActiveInfo',\r\n 'WebGLBuffer',\r\n 'WebGLFramebuffer',\r\n 'WebGLProgram',\r\n 'WebGLRenderbuffer',\r\n 'WebGLShader',\r\n 'WebGLShaderPrecisionFormat',\r\n 'WebGLTexture',\r\n 'WebGLUniformLocation',\r\n 'WebGLVertexArrayObject',\r\n 'WebGLVertexArrayObjectOES',\r\n ];\r\n const supportedWebGLConstructorNames = webGLConstructorNames.filter((name) => typeof win[name] === 'function');\r\n return Boolean(supportedWebGLConstructorNames.find((name) => value instanceof win[name]));\r\n};\n\nexport { isInstanceOfWebGLObject, saveWebGLVar, serializeArg, serializeArgs, variableListFor };\n","import { patch, isBlocked } from '../../../utils.js';\n\nfunction getNormalizedContextName(contextType) {\r\n return contextType === 'experimental-webgl' ? 'webgl' : contextType;\r\n}\r\nfunction initCanvasContextObserver(win, blockClass, blockSelector, setPreserveDrawingBufferToTrue) {\r\n const handlers = [];\r\n try {\r\n const restoreHandler = patch(win.HTMLCanvasElement.prototype, 'getContext', function (original) {\r\n return function (contextType, ...args) {\r\n if (!isBlocked(this, blockClass, blockSelector, true)) {\r\n const ctxName = getNormalizedContextName(contextType);\r\n if (!('__context' in this))\r\n this.__context = ctxName;\r\n if (setPreserveDrawingBufferToTrue &&\r\n ['webgl', 'webgl2'].includes(ctxName)) {\r\n if (args[0] && typeof args[0] === 'object') {\r\n const contextAttributes = args[0];\r\n if (!contextAttributes.preserveDrawingBuffer) {\r\n contextAttributes.preserveDrawingBuffer = true;\r\n }\r\n }\r\n else {\r\n args.splice(0, 1, {\r\n preserveDrawingBuffer: true,\r\n });\r\n }\r\n }\r\n }\r\n return original.apply(this, [contextType, ...args]);\r\n };\r\n });\r\n handlers.push(restoreHandler);\r\n }\r\n catch (_a) {\r\n console.error('failed to patch HTMLCanvasElement.prototype.getContext');\r\n }\r\n return () => {\r\n handlers.forEach((h) => h());\r\n };\r\n}\n\nexport { initCanvasContextObserver as default };\n","import { CanvasContext } from '../../../../../types/dist/types.js';\nimport { patch, isBlocked, hookSetter } from '../../../utils.js';\nimport { saveWebGLVar, serializeArgs } from './serialize-args.js';\n\nfunction patchGLPrototype(prototype, type, cb, blockClass, blockSelector, mirror, win) {\r\n const handlers = [];\r\n const props = Object.getOwnPropertyNames(prototype);\r\n for (const prop of props) {\r\n if ([\r\n 'isContextLost',\r\n 'canvas',\r\n 'drawingBufferWidth',\r\n 'drawingBufferHeight',\r\n ].includes(prop)) {\r\n continue;\r\n }\r\n try {\r\n if (typeof prototype[prop] !== 'function') {\r\n continue;\r\n }\r\n const restoreHandler = patch(prototype, prop, function (original) {\r\n return function (...args) {\r\n const result = original.apply(this, args);\r\n saveWebGLVar(result, win, this);\r\n if ('tagName' in this.canvas &&\r\n !isBlocked(this.canvas, blockClass, blockSelector, true)) {\r\n const recordArgs = serializeArgs(args, win, this);\r\n const mutation = {\r\n type,\r\n property: prop,\r\n args: recordArgs,\r\n };\r\n cb(this.canvas, mutation);\r\n }\r\n return result;\r\n };\r\n });\r\n handlers.push(restoreHandler);\r\n }\r\n catch (_a) {\r\n const hookHandler = hookSetter(prototype, prop, {\r\n set(v) {\r\n cb(this.canvas, {\r\n type,\r\n property: prop,\r\n args: [v],\r\n setter: true,\r\n });\r\n },\r\n });\r\n handlers.push(hookHandler);\r\n }\r\n }\r\n return handlers;\r\n}\r\nfunction initCanvasWebGLMutationObserver(cb, win, blockClass, blockSelector, mirror) {\r\n const handlers = [];\r\n handlers.push(...patchGLPrototype(win.WebGLRenderingContext.prototype, CanvasContext.WebGL, cb, blockClass, blockSelector, mirror, win));\r\n if (typeof win.WebGL2RenderingContext !== 'undefined') {\r\n handlers.push(...patchGLPrototype(win.WebGL2RenderingContext.prototype, CanvasContext.WebGL2, cb, blockClass, blockSelector, mirror, win));\r\n }\r\n return () => {\r\n handlers.forEach((h) => h());\r\n };\r\n}\n\nexport { initCanvasWebGLMutationObserver as default };\n","function decodeBase64(base64, enableUnicode) {\n var binaryString = atob(base64);\n if (enableUnicode) {\n var binaryView = new Uint8Array(binaryString.length);\n for (var i = 0, n = binaryString.length; i < n; ++i) {\n binaryView[i] = binaryString.charCodeAt(i);\n }\n return String.fromCharCode.apply(null, new Uint16Array(binaryView.buffer));\n }\n return binaryString;\n}\n\nfunction createURL(base64, sourcemapArg, enableUnicodeArg) {\n var sourcemap = sourcemapArg === undefined ? null : sourcemapArg;\n var enableUnicode = enableUnicodeArg === undefined ? false : enableUnicodeArg;\n var source = decodeBase64(base64, enableUnicode);\n var start = source.indexOf('\\n', 10) + 1;\n var body = source.substring(start) + (sourcemap ? '\\/\\/# sourceMappingURL=' + sourcemap : '');\n var blob = new Blob([body], { type: 'application/javascript' });\n return URL.createObjectURL(blob);\n}\n\nfunction createBase64WorkerFactory(base64, sourcemapArg, enableUnicodeArg) {\n var url;\n return function WorkerFactory(options) {\n url = url || createURL(base64, sourcemapArg, enableUnicodeArg);\n return new Worker(url, options);\n };\n}\n\nexport { createBase64WorkerFactory };","import { createBase64WorkerFactory } from './_rollup-plugin-web-worker-loader__helper__browser__createBase64WorkerFactory.js';\n\nvar WorkerFactory = createBase64WorkerFactory('Lyogcm9sbHVwLXBsdWdpbi13ZWItd29ya2VyLWxvYWRlciAqLwooZnVuY3Rpb24gKCkgewogICAgJ3VzZSBzdHJpY3QnOwoKICAgIC8qISAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKg0KICAgIENvcHlyaWdodCAoYykgTWljcm9zb2Z0IENvcnBvcmF0aW9uLg0KDQogICAgUGVybWlzc2lvbiB0byB1c2UsIGNvcHksIG1vZGlmeSwgYW5kL29yIGRpc3RyaWJ1dGUgdGhpcyBzb2Z0d2FyZSBmb3IgYW55DQogICAgcHVycG9zZSB3aXRoIG9yIHdpdGhvdXQgZmVlIGlzIGhlcmVieSBncmFudGVkLg0KDQogICAgVEhFIFNPRlRXQVJFIElTIFBST1ZJREVEICJBUyBJUyIgQU5EIFRIRSBBVVRIT1IgRElTQ0xBSU1TIEFMTCBXQVJSQU5USUVTIFdJVEgNCiAgICBSRUdBUkQgVE8gVEhJUyBTT0ZUV0FSRSBJTkNMVURJTkcgQUxMIElNUExJRUQgV0FSUkFOVElFUyBPRiBNRVJDSEFOVEFCSUxJVFkNCiAgICBBTkQgRklUTkVTUy4gSU4gTk8gRVZFTlQgU0hBTEwgVEhFIEFVVEhPUiBCRSBMSUFCTEUgRk9SIEFOWSBTUEVDSUFMLCBESVJFQ1QsDQogICAgSU5ESVJFQ1QsIE9SIENPTlNFUVVFTlRJQUwgREFNQUdFUyBPUiBBTlkgREFNQUdFUyBXSEFUU09FVkVSIFJFU1VMVElORyBGUk9NDQogICAgTE9TUyBPRiBVU0UsIERBVEEgT1IgUFJPRklUUywgV0hFVEhFUiBJTiBBTiBBQ1RJT04gT0YgQ09OVFJBQ1QsIE5FR0xJR0VOQ0UgT1INCiAgICBPVEhFUiBUT1JUSU9VUyBBQ1RJT04sIEFSSVNJTkcgT1VUIE9GIE9SIElOIENPTk5FQ1RJT04gV0lUSCBUSEUgVVNFIE9SDQogICAgUEVSRk9STUFOQ0UgT0YgVEhJUyBTT0ZUV0FSRS4NCiAgICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiAqLw0KDQogICAgZnVuY3Rpb24gX19hd2FpdGVyKHRoaXNBcmcsIF9hcmd1bWVudHMsIFAsIGdlbmVyYXRvcikgew0KICAgICAgICBmdW5jdGlvbiBhZG9wdCh2YWx1ZSkgeyByZXR1cm4gdmFsdWUgaW5zdGFuY2VvZiBQID8gdmFsdWUgOiBuZXcgUChmdW5jdGlvbiAocmVzb2x2ZSkgeyByZXNvbHZlKHZhbHVlKTsgfSk7IH0NCiAgICAgICAgcmV0dXJuIG5ldyAoUCB8fCAoUCA9IFByb21pc2UpKShmdW5jdGlvbiAocmVzb2x2ZSwgcmVqZWN0KSB7DQogICAgICAgICAgICBmdW5jdGlvbiBmdWxmaWxsZWQodmFsdWUpIHsgdHJ5IHsgc3RlcChnZW5lcmF0b3IubmV4dCh2YWx1ZSkpOyB9IGNhdGNoIChlKSB7IHJlamVjdChlKTsgfSB9DQogICAgICAgICAgICBmdW5jdGlvbiByZWplY3RlZCh2YWx1ZSkgeyB0cnkgeyBzdGVwKGdlbmVyYXRvclsidGhyb3ciXSh2YWx1ZSkpOyB9IGNhdGNoIChlKSB7IHJlamVjdChlKTsgfSB9DQogICAgICAgICAgICBmdW5jdGlvbiBzdGVwKHJlc3VsdCkgeyByZXN1bHQuZG9uZSA/IHJlc29sdmUocmVzdWx0LnZhbHVlKSA6IGFkb3B0KHJlc3VsdC52YWx1ZSkudGhlbihmdWxmaWxsZWQsIHJlamVjdGVkKTsgfQ0KICAgICAgICAgICAgc3RlcCgoZ2VuZXJhdG9yID0gZ2VuZXJhdG9yLmFwcGx5KHRoaXNBcmcsIF9hcmd1bWVudHMgfHwgW10pKS5uZXh0KCkpOw0KICAgICAgICB9KTsNCiAgICB9CgogICAgLyoKICAgICAqIGJhc2U2NC1hcnJheWJ1ZmZlciAxLjAuMSA8aHR0cHM6Ly9naXRodWIuY29tL25pa2xhc3ZoL2Jhc2U2NC1hcnJheWJ1ZmZlcj4KICAgICAqIENvcHlyaWdodCAoYykgMjAyMSBOaWtsYXMgdm9uIEhlcnR6ZW4gPGh0dHBzOi8vaGVydHplbi5jb20+CiAgICAgKiBSZWxlYXNlZCB1bmRlciBNSVQgTGljZW5zZQogICAgICovCiAgICB2YXIgY2hhcnMgPSAnQUJDREVGR0hJSktMTU5PUFFSU1RVVldYWVphYmNkZWZnaGlqa2xtbm9wcXJzdHV2d3h5ejAxMjM0NTY3ODkrLyc7CiAgICAvLyBVc2UgYSBsb29rdXAgdGFibGUgdG8gZmluZCB0aGUgaW5kZXguCiAgICB2YXIgbG9va3VwID0gdHlwZW9mIFVpbnQ4QXJyYXkgPT09ICd1bmRlZmluZWQnID8gW10gOiBuZXcgVWludDhBcnJheSgyNTYpOwogICAgZm9yICh2YXIgaSA9IDA7IGkgPCBjaGFycy5sZW5ndGg7IGkrKykgewogICAgICAgIGxvb2t1cFtjaGFycy5jaGFyQ29kZUF0KGkpXSA9IGk7CiAgICB9CiAgICB2YXIgZW5jb2RlID0gZnVuY3Rpb24gKGFycmF5YnVmZmVyKSB7CiAgICAgICAgdmFyIGJ5dGVzID0gbmV3IFVpbnQ4QXJyYXkoYXJyYXlidWZmZXIpLCBpLCBsZW4gPSBieXRlcy5sZW5ndGgsIGJhc2U2NCA9ICcnOwogICAgICAgIGZvciAoaSA9IDA7IGkgPCBsZW47IGkgKz0gMykgewogICAgICAgICAgICBiYXNlNjQgKz0gY2hhcnNbYnl0ZXNbaV0gPj4gMl07CiAgICAgICAgICAgIGJhc2U2NCArPSBjaGFyc1soKGJ5dGVzW2ldICYgMykgPDwgNCkgfCAoYnl0ZXNbaSArIDFdID4+IDQpXTsKICAgICAgICAgICAgYmFzZTY0ICs9IGNoYXJzWygoYnl0ZXNbaSArIDFdICYgMTUpIDw8IDIpIHwgKGJ5dGVzW2kgKyAyXSA+PiA2KV07CiAgICAgICAgICAgIGJhc2U2NCArPSBjaGFyc1tieXRlc1tpICsgMl0gJiA2M107CiAgICAgICAgfQogICAgICAgIGlmIChsZW4gJSAzID09PSAyKSB7CiAgICAgICAgICAgIGJhc2U2NCA9IGJhc2U2NC5zdWJzdHJpbmcoMCwgYmFzZTY0Lmxlbmd0aCAtIDEpICsgJz0nOwogICAgICAgIH0KICAgICAgICBlbHNlIGlmIChsZW4gJSAzID09PSAxKSB7CiAgICAgICAgICAgIGJhc2U2NCA9IGJhc2U2NC5zdWJzdHJpbmcoMCwgYmFzZTY0Lmxlbmd0aCAtIDIpICsgJz09JzsKICAgICAgICB9CiAgICAgICAgcmV0dXJuIGJhc2U2NDsKICAgIH07CgogICAgY29uc3QgbGFzdEJsb2JNYXAgPSBuZXcgTWFwKCk7DQogICAgY29uc3QgdHJhbnNwYXJlbnRCbG9iTWFwID0gbmV3IE1hcCgpOw0KICAgIGZ1bmN0aW9uIGdldFRyYW5zcGFyZW50QmxvYkZvcih3aWR0aCwgaGVpZ2h0LCBkYXRhVVJMT3B0aW9ucykgew0KICAgICAgICByZXR1cm4gX19hd2FpdGVyKHRoaXMsIHZvaWQgMCwgdm9pZCAwLCBmdW5jdGlvbiogKCkgew0KICAgICAgICAgICAgY29uc3QgaWQgPSBgJHt3aWR0aH0tJHtoZWlnaHR9YDsNCiAgICAgICAgICAgIGlmICgnT2Zmc2NyZWVuQ2FudmFzJyBpbiBnbG9iYWxUaGlzKSB7DQogICAgICAgICAgICAgICAgaWYgKHRyYW5zcGFyZW50QmxvYk1hcC5oYXMoaWQpKQ0KICAgICAgICAgICAgICAgICAgICByZXR1cm4gdHJhbnNwYXJlbnRCbG9iTWFwLmdldChpZCk7DQogICAgICAgICAgICAgICAgY29uc3Qgb2Zmc2NyZWVuID0gbmV3IE9mZnNjcmVlbkNhbnZhcyh3aWR0aCwgaGVpZ2h0KTsNCiAgICAgICAgICAgICAgICBvZmZzY3JlZW4uZ2V0Q29udGV4dCgnMmQnKTsNCiAgICAgICAgICAgICAgICBjb25zdCBibG9iID0geWllbGQgb2Zmc2NyZWVuLmNvbnZlcnRUb0Jsb2IoZGF0YVVSTE9wdGlvbnMpOw0KICAgICAgICAgICAgICAgIGNvbnN0IGFycmF5QnVmZmVyID0geWllbGQgYmxvYi5hcnJheUJ1ZmZlcigpOw0KICAgICAgICAgICAgICAgIGNvbnN0IGJhc2U2NCA9IGVuY29kZShhcnJheUJ1ZmZlcik7DQogICAgICAgICAgICAgICAgdHJhbnNwYXJlbnRCbG9iTWFwLnNldChpZCwgYmFzZTY0KTsNCiAgICAgICAgICAgICAgICByZXR1cm4gYmFzZTY0Ow0KICAgICAgICAgICAgfQ0KICAgICAgICAgICAgZWxzZSB7DQogICAgICAgICAgICAgICAgcmV0dXJuICcnOw0KICAgICAgICAgICAgfQ0KICAgICAgICB9KTsNCiAgICB9DQogICAgY29uc3Qgd29ya2VyID0gc2VsZjsNCiAgICB3b3JrZXIub25tZXNzYWdlID0gZnVuY3Rpb24gKGUpIHsNCiAgICAgICAgcmV0dXJuIF9fYXdhaXRlcih0aGlzLCB2b2lkIDAsIHZvaWQgMCwgZnVuY3Rpb24qICgpIHsNCiAgICAgICAgICAgIGlmICgnT2Zmc2NyZWVuQ2FudmFzJyBpbiBnbG9iYWxUaGlzKSB7DQogICAgICAgICAgICAgICAgY29uc3QgeyBpZCwgYml0bWFwLCB3aWR0aCwgaGVpZ2h0LCBkYXRhVVJMT3B0aW9ucyB9ID0gZS5kYXRhOw0KICAgICAgICAgICAgICAgIGNvbnN0IHRyYW5zcGFyZW50QmFzZTY0ID0gZ2V0VHJhbnNwYXJlbnRCbG9iRm9yKHdpZHRoLCBoZWlnaHQsIGRhdGFVUkxPcHRpb25zKTsNCiAgICAgICAgICAgICAgICBjb25zdCBvZmZzY3JlZW4gPSBuZXcgT2Zmc2NyZWVuQ2FudmFzKHdpZHRoLCBoZWlnaHQpOw0KICAgICAgICAgICAgICAgIGNvbnN0IGN0eCA9IG9mZnNjcmVlbi5nZXRDb250ZXh0KCcyZCcpOw0KICAgICAgICAgICAgICAgIGN0eC5kcmF3SW1hZ2UoYml0bWFwLCAwLCAwKTsNCiAgICAgICAgICAgICAgICBiaXRtYXAuY2xvc2UoKTsNCiAgICAgICAgICAgICAgICBjb25zdCBibG9iID0geWllbGQgb2Zmc2NyZWVuLmNvbnZlcnRUb0Jsb2IoZGF0YVVSTE9wdGlvbnMpOw0KICAgICAgICAgICAgICAgIGNvbnN0IHR5cGUgPSBibG9iLnR5cGU7DQogICAgICAgICAgICAgICAgY29uc3QgYXJyYXlCdWZmZXIgPSB5aWVsZCBibG9iLmFycmF5QnVmZmVyKCk7DQogICAgICAgICAgICAgICAgY29uc3QgYmFzZTY0ID0gZW5jb2RlKGFycmF5QnVmZmVyKTsNCiAgICAgICAgICAgICAgICBpZiAoIWxhc3RCbG9iTWFwLmhhcyhpZCkgJiYgKHlpZWxkIHRyYW5zcGFyZW50QmFzZTY0KSA9PT0gYmFzZTY0KSB7DQogICAgICAgICAgICAgICAgICAgIGxhc3RCbG9iTWFwLnNldChpZCwgYmFzZTY0KTsNCiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIHdvcmtlci5wb3N0TWVzc2FnZSh7IGlkIH0pOw0KICAgICAgICAgICAgICAgIH0NCiAgICAgICAgICAgICAgICBpZiAobGFzdEJsb2JNYXAuZ2V0KGlkKSA9PT0gYmFzZTY0KQ0KICAgICAgICAgICAgICAgICAgICByZXR1cm4gd29ya2VyLnBvc3RNZXNzYWdlKHsgaWQgfSk7DQogICAgICAgICAgICAgICAgd29ya2VyLnBvc3RNZXNzYWdlKHsNCiAgICAgICAgICAgICAgICAgICAgaWQsDQogICAgICAgICAgICAgICAgICAgIHR5cGUsDQogICAgICAgICAgICAgICAgICAgIGJhc2U2NCwNCiAgICAgICAgICAgICAgICAgICAgd2lkdGgsDQogICAgICAgICAgICAgICAgICAgIGhlaWdodCwNCiAgICAgICAgICAgICAgICB9KTsNCiAgICAgICAgICAgICAgICBsYXN0QmxvYk1hcC5zZXQoaWQsIGJhc2U2NCk7DQogICAgICAgICAgICB9DQogICAgICAgICAgICBlbHNlIHsNCiAgICAgICAgICAgICAgICByZXR1cm4gd29ya2VyLnBvc3RNZXNzYWdlKHsgaWQ6IGUuZGF0YS5pZCB9KTsNCiAgICAgICAgICAgIH0NCiAgICAgICAgfSk7DQogICAgfTsKCn0pKCk7Cgo=', null, false);\n/* eslint-enable */\n\nexport { WorkerFactory as default };\n","import { __rest, __awaiter } from './../../../../../../ext/tslib/tslib.es6.js';\nimport { isBlocked } from '../../../utils.js';\nimport { CanvasContext } from '../../../../../types/dist/types.js';\nimport initCanvas2DMutationObserver from './2d.js';\nimport initCanvasContextObserver from './canvas.js';\nimport initCanvasWebGLMutationObserver from './webgl.js';\nimport WorkerFactory from '../../../../../../_virtual/image-bitmap-data-url-worker.js';\n\nclass CanvasManager {\r\n reset() {\r\n this.pendingCanvasMutations.clear();\r\n this.resetObservers && this.resetObservers();\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.frozen = false;\r\n this.locked = false;\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, recordCanvas, dataURLOptions, } = options;\r\n this.mutationCb = options.mutationCb;\r\n this.mirror = options.mirror;\r\n if (recordCanvas && sampling === 'all')\r\n this.initCanvasMutationObserver(win, blockClass, blockSelector);\r\n if (recordCanvas && typeof sampling === 'number')\r\n this.initCanvasFPSObserver(sampling, win, blockClass, blockSelector, {\r\n dataURLOptions,\r\n });\r\n }\r\n initCanvasFPSObserver(fps, win, blockClass, blockSelector, options) {\r\n const canvasContextReset = initCanvasContextObserver(win, blockClass, blockSelector, true);\r\n const snapshotInProgressMap = new Map();\r\n const worker = new WorkerFactory();\r\n worker.onmessage = (e) => {\r\n const { id } = e.data;\r\n snapshotInProgressMap.set(id, false);\r\n if (!('base64' in e.data))\r\n return;\r\n const { base64, type, width, height } = e.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 ],\r\n },\r\n ],\r\n });\r\n };\r\n const timeBetweenSnapshots = 1000 / fps;\r\n let lastSnapshotTime = 0;\r\n let rafId;\r\n const getCanvas = () => {\r\n const matchedCanvas = [];\r\n\r\n const searchCanvas = (root) => {\r\n root.querySelectorAll('canvas').forEach((canvas) => {\r\n if (!isBlocked(canvas, blockClass, blockSelector, true)) {\r\n matchedCanvas.push(canvas);\r\n }\r\n });\r\n root.querySelectorAll('*').forEach((elem) => {\r\n if (elem.shadowRoot) {\r\n searchCanvas(elem.shadowRoot);\r\n }\r\n });\r\n };\r\n \r\n searchCanvas(win.document);\r\n return matchedCanvas;\r\n };\r\n const takeCanvasSnapshots = (timestamp) => {\r\n if (lastSnapshotTime &&\r\n timestamp - lastSnapshotTime < timeBetweenSnapshots) {\r\n rafId = requestAnimationFrame(takeCanvasSnapshots);\r\n return;\r\n }\r\n lastSnapshotTime = timestamp;\r\n getCanvas()\r\n .forEach((canvas) => __awaiter(this, void 0, void 0, function* () {\r\n var _a;\r\n const id = this.mirror.getId(canvas);\r\n if (snapshotInProgressMap.get(id))\r\n return;\r\n if (canvas.width === 0 || canvas.height === 0)\r\n return;\r\n snapshotInProgressMap.set(id, true);\r\n if (['webgl', 'webgl2'].includes(canvas.__context)) {\r\n const context = canvas.getContext(canvas.__context);\r\n if (((_a = context === null || context === void 0 ? void 0 : context.getContextAttributes()) === null || _a === void 0 ? void 0 : _a.preserveDrawingBuffer) === false) {\r\n context.clear(context.COLOR_BUFFER_BIT);\r\n }\r\n }\r\n\r\n // createImageBitmap throws if resizing to 0\r\n // Fallback to intrinsic size if canvas has not yet rendered\r\n const width = canvas.clientWidth || canvas.width;\r\n const height = canvas.clientHeight || canvas.height;\r\n\r\n const bitmap = yield createImageBitmap(canvas, {\r\n resizeWidth: width,\r\n resizeHeight: height\r\n })\r\n\r\n worker.postMessage({\r\n id,\r\n bitmap,\r\n width: width,\r\n height: height,\r\n dataURLOptions: options.dataURLOptions,\r\n }, [bitmap]);\r\n }));\r\n rafId = requestAnimationFrame(takeCanvasSnapshots);\r\n };\r\n rafId = requestAnimationFrame(takeCanvasSnapshots);\r\n this.resetObservers = () => {\r\n canvasContextReset();\r\n cancelAnimationFrame(rafId);\r\n };\r\n }\r\n initCanvasMutationObserver(win, blockClass, blockSelector) {\r\n this.startRAFTimestamping();\r\n this.startPendingCanvasMutationFlusher();\r\n const canvasContextReset = initCanvasContextObserver(win, blockClass, blockSelector, false);\r\n const canvas2DReset = initCanvas2DMutationObserver(this.processMutation.bind(this), win, blockClass, blockSelector);\r\n const canvasWebGL1and2Reset = initCanvasWebGLMutationObserver(this.processMutation.bind(this), win, blockClass, blockSelector, this.mirror);\r\n this.resetObservers = () => {\r\n canvasContextReset();\r\n canvas2DReset();\r\n canvasWebGL1and2Reset();\r\n };\r\n }\r\n startPendingCanvasMutationFlusher() {\r\n requestAnimationFrame(() => this.flushPendingCanvasMutations());\r\n }\r\n startRAFTimestamping() {\r\n const setLatestRAFTimestamp = (timestamp) => {\r\n this.rafStamps.latestId = timestamp;\r\n requestAnimationFrame(setLatestRAFTimestamp);\r\n };\r\n requestAnimationFrame(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 requestAnimationFrame(() => 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 rest = __rest(value, [\"type\"]);\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 };\n","import { CanvasContext } from '../../../../../types/dist/types.js';\nimport { patch, isBlocked, hookSetter } from '../../../utils.js';\nimport { serializeArgs } from './serialize-args.js';\n\nfunction initCanvas2DMutationObserver(cb, win, blockClass, blockSelector) {\r\n const handlers = [];\r\n const props2D = Object.getOwnPropertyNames(win.CanvasRenderingContext2D.prototype);\r\n for (const prop of props2D) {\r\n try {\r\n if (typeof win.CanvasRenderingContext2D.prototype[prop] !== 'function') {\r\n continue;\r\n }\r\n const restoreHandler = patch(win.CanvasRenderingContext2D.prototype, prop, function (original) {\r\n return function (...args) {\r\n if (!isBlocked(this.canvas, blockClass, blockSelector, true)) {\r\n setTimeout(() => {\r\n const recordArgs = serializeArgs(args, win, this);\r\n cb(this.canvas, {\r\n type: CanvasContext['2D'],\r\n property: prop,\r\n args: recordArgs,\r\n });\r\n }, 0);\r\n }\r\n return original.apply(this, args);\r\n };\r\n });\r\n handlers.push(restoreHandler);\r\n }\r\n catch (_a) {\r\n const hookHandler = hookSetter(win.CanvasRenderingContext2D.prototype, prop, {\r\n set(v) {\r\n cb(this.canvas, {\r\n type: CanvasContext['2D'],\r\n property: prop,\r\n args: [v],\r\n setter: true,\r\n });\r\n },\r\n });\r\n handlers.push(hookHandler);\r\n }\r\n }\r\n return () => {\r\n handlers.forEach((h) => h());\r\n };\r\n}\n\nexport { initCanvas2DMutationObserver as default };\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","class ProcessedNodeManager {\r\n constructor() {\r\n this.nodeMap = new WeakMap();\r\n this.loop = true;\r\n this.periodicallyClear();\r\n }\r\n periodicallyClear() {\r\n requestAnimationFrame(() => {\r\n this.clear();\r\n if (this.loop)\r\n this.periodicallyClear();\r\n });\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 this.nodeMap.set(node, (this.nodeMap.get(node) || new Set()).add(buffer));\r\n }\r\n clear() {\r\n this.nodeMap = new WeakMap();\r\n }\r\n destroy() {\r\n this.loop = false;\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, nowTimestamp, on, getWindowWidth, getWindowHeight, getWindowScroll, isSerializedIframe, isSerializedStylesheet, hasShadowRoot } from '../utils.js';\nimport { EventType, IncrementalSource } from '../../../types/dist/types.js';\nimport { IframeManager } from './iframe-manager.js';\nimport { ShadowDomManager } from './shadow-dom-manager.js';\nimport { 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\nfunction wrapEvent(e) {\r\n return Object.assign(Object.assign({}, e), { timestamp: nowTimestamp() });\r\n}\r\nlet wrappedEmit;\r\nlet takeFullSnapshot;\r\nlet canvasManager;\r\nlet recording = false;\r\nconst mirror = createMirror();\r\nfunction record(options = {}) {\r\n const { emit, checkoutEveryNms, checkoutEveryNth, blockClass = 'rr-block', blockSelector = null, ignoreClass = 'rr-ignore', ignoreSelector = null, maskTextClass = 'rr-mask', maskTextSelector = null, inlineStylesheet = true, maskAllInputs, maskInputOptions: _maskInputOptions, slimDOMOptions: _slimDOMOptions, maskInputFn, maskTextFn, hooks, 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, } = 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 (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 password: true,\r\n }\r\n : _maskInputOptions !== undefined\r\n ? _maskInputOptions\r\n : { password: true };\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 = (e, isCheckout) => {\r\n var _a;\r\n if (((_a = mutationBuffers[0]) === null || _a === void 0 ? void 0 : _a.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 === null || emit === void 0 ? void 0 : 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 e.timestamp - lastFullSnapshotEvent.timestamp > checkoutEveryNms;\r\n if (exceedCount || exceedTime) {\r\n takeFullSnapshot(true);\r\n }\r\n }\r\n };\r\n const wrappedMutationEmit = (m) => {\r\n wrappedEmit(wrapEvent({\r\n type: EventType.IncrementalSnapshot,\r\n data: Object.assign({ source: IncrementalSource.Mutation }, m),\r\n }));\r\n };\r\n const wrappedScrollEmit = (p) => wrappedEmit(wrapEvent({\r\n type: EventType.IncrementalSnapshot,\r\n data: Object.assign({ source: IncrementalSource.Scroll }, p),\r\n }));\r\n const wrappedCanvasMutationEmit = (p) => wrappedEmit(wrapEvent({\r\n type: EventType.IncrementalSnapshot,\r\n data: Object.assign({ source: IncrementalSource.CanvasMutation }, p),\r\n }));\r\n const wrappedAdoptedStyleSheetEmit = (a) => wrappedEmit(wrapEvent({\r\n type: EventType.IncrementalSnapshot,\r\n data: Object.assign({ source: IncrementalSource.AdoptedStyleSheet }, a),\r\n }));\r\n const stylesheetManager = new StylesheetManager({\r\n mutationCb: wrappedMutationEmit,\r\n adoptedStyleSheetCb: wrappedAdoptedStyleSheetEmit,\r\n });\r\n const iframeManager = 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 canvasManager = new CanvasManager({\r\n recordCanvas,\r\n mutationCb: wrappedCanvasMutationEmit,\r\n win: window,\r\n blockClass,\r\n blockSelector,\r\n mirror,\r\n sampling: sampling.canvas,\r\n dataURLOptions,\r\n });\r\n const shadowDomManager = new ShadowDomManager({\r\n mutationCb: wrappedMutationEmit,\r\n scrollCb: wrappedScrollEmit,\r\n bypassOptions: {\r\n blockClass,\r\n blockSelector,\r\n maskTextClass,\r\n maskTextSelector,\r\n inlineStylesheet,\r\n maskInputOptions,\r\n dataURLOptions,\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 takeFullSnapshot = (isCheckout = false) => {\r\n if (!recordDOM) {\r\n return;\r\n }\r\n wrappedEmit(wrapEvent({\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 maskTextClass,\r\n maskTextSelector,\r\n inlineStylesheet,\r\n maskAllInputs: maskInputOptions,\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 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(wrapEvent({\r\n type: EventType.FullSnapshot,\r\n data: {\r\n node,\r\n initialOffset: getWindowScroll(window),\r\n },\r\n }), isCheckout);\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 try {\r\n const handlers = [];\r\n const observe = (doc) => {\r\n var _a;\r\n return callbackWrapper(initObservers)({\r\n mutationCb: wrappedMutationEmit,\r\n mousemoveCb: (positions, source) => wrappedEmit(wrapEvent({\r\n type: EventType.IncrementalSnapshot,\r\n data: {\r\n source,\r\n positions,\r\n },\r\n })),\r\n mouseInteractionCb: (d) => wrappedEmit(wrapEvent({\r\n type: EventType.IncrementalSnapshot,\r\n data: Object.assign({ source: IncrementalSource.MouseInteraction }, d),\r\n })),\r\n scrollCb: wrappedScrollEmit,\r\n viewportResizeCb: (d) => wrappedEmit(wrapEvent({\r\n type: EventType.IncrementalSnapshot,\r\n data: Object.assign({ source: IncrementalSource.ViewportResize }, d),\r\n })),\r\n inputCb: (v) => wrappedEmit(wrapEvent({\r\n type: EventType.IncrementalSnapshot,\r\n data: Object.assign({ source: IncrementalSource.Input }, v),\r\n })),\r\n mediaInteractionCb: (p) => wrappedEmit(wrapEvent({\r\n type: EventType.IncrementalSnapshot,\r\n data: Object.assign({ source: IncrementalSource.MediaInteraction }, p),\r\n })),\r\n styleSheetRuleCb: (r) => wrappedEmit(wrapEvent({\r\n type: EventType.IncrementalSnapshot,\r\n data: Object.assign({ source: IncrementalSource.StyleSheetRule }, r),\r\n })),\r\n styleDeclarationCb: (r) => wrappedEmit(wrapEvent({\r\n type: EventType.IncrementalSnapshot,\r\n data: Object.assign({ source: IncrementalSource.StyleDeclaration }, r),\r\n })),\r\n canvasMutationCb: wrappedCanvasMutationEmit,\r\n fontCb: (p) => wrappedEmit(wrapEvent({\r\n type: EventType.IncrementalSnapshot,\r\n data: Object.assign({ source: IncrementalSource.Font }, p),\r\n })),\r\n selectionCb: (p) => {\r\n wrappedEmit(wrapEvent({\r\n type: EventType.IncrementalSnapshot,\r\n data: Object.assign({ source: IncrementalSource.Selection }, p),\r\n }));\r\n },\r\n customElementCb: (c) => {\r\n wrappedEmit(wrapEvent({\r\n type: EventType.IncrementalSnapshot,\r\n data: Object.assign({ source: IncrementalSource.CustomElement }, c),\r\n }));\r\n },\r\n blockClass,\r\n ignoreClass,\r\n ignoreSelector,\r\n maskTextClass,\r\n maskTextSelector,\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 maskInputFn,\r\n maskTextFn,\r\n keepIframeSrcFn,\r\n blockSelector,\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: ((_a = plugins === null || plugins === void 0 ? void 0 : plugins.filter((p) => p.observer)) === null || _a === void 0 ? void 0 : _a.map((p) => ({\r\n observer: p.observer,\r\n options: p.options,\r\n callback: (payload) => wrappedEmit(wrapEvent({\r\n type: EventType.Plugin,\r\n data: {\r\n plugin: p.name,\r\n payload,\r\n },\r\n })),\r\n }))) || [],\r\n }, hooks);\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 recording = true;\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(wrapEvent({\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(wrapEvent({\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 recording = false;\r\n unregisterErrorHandler();\r\n };\r\n }\r\n catch (error) {\r\n console.warn(error);\r\n }\r\n}\r\nrecord.addCustomEvent = (tag, payload) => {\r\n if (!recording) {\r\n throw new Error('please add custom event after start recording');\r\n }\r\n wrappedEmit(wrapEvent({\r\n type: EventType.Custom,\r\n data: {\r\n tag,\r\n payload,\r\n },\r\n }));\r\n};\r\nrecord.freezePage = () => {\r\n mutationBuffers.forEach((buf) => buf.freeze());\r\n};\r\nrecord.takeFullSnapshot = (isCheckout) => {\r\n if (!recording) {\r\n throw new Error('please take full snapshot after start recording');\r\n }\r\n takeFullSnapshot(isCheckout);\r\n};\r\nrecord.mirror = mirror;\n\nexport { record as default };\n","class StackFrame {\r\n constructor(obj) {\r\n this.fileName = obj.fileName || '';\r\n this.functionName = obj.functionName || '';\r\n this.lineNumber = obj.lineNumber;\r\n this.columnNumber = obj.columnNumber;\r\n }\r\n toString() {\r\n const lineNumber = this.lineNumber || '';\r\n const columnNumber = this.columnNumber || '';\r\n if (this.functionName)\r\n return `${this.functionName} (${this.fileName}:${lineNumber}:${columnNumber})`;\r\n return `${this.fileName}:${lineNumber}:${columnNumber}`;\r\n }\r\n}\r\nconst FIREFOX_SAFARI_STACK_REGEXP = /(^|@)\\S+:\\d+/;\r\nconst CHROME_IE_STACK_REGEXP = /^\\s*at .*(\\S+:\\d+|\\(native\\))/m;\r\nconst SAFARI_NATIVE_CODE_REGEXP = /^(eval@)?(\\[native code])?$/;\r\nconst ErrorStackParser = {\r\n parse: function (error) {\r\n if (!error) {\r\n return [];\r\n }\r\n if (typeof error.stacktrace !== 'undefined' ||\r\n typeof error['opera#sourceloc'] !== 'undefined') {\r\n return this.parseOpera(error);\r\n }\r\n else if (error.stack && error.stack.match(CHROME_IE_STACK_REGEXP)) {\r\n return this.parseV8OrIE(error);\r\n }\r\n else if (error.stack) {\r\n return this.parseFFOrSafari(error);\r\n }\r\n else {\r\n console.warn('[console-record-plugin]: Failed to parse error object:', error);\r\n return [];\r\n }\r\n },\r\n extractLocation: function (urlLike) {\r\n if (urlLike.indexOf(':') === -1) {\r\n return [urlLike];\r\n }\r\n const regExp = /(.+?)(?::(\\d+))?(?::(\\d+))?$/;\r\n const parts = regExp.exec(urlLike.replace(/[()]/g, ''));\r\n if (!parts)\r\n throw new Error(`Cannot parse given url: ${urlLike}`);\r\n return [parts[1], parts[2] || undefined, parts[3] || undefined];\r\n },\r\n parseV8OrIE: function (error) {\r\n const filtered = error.stack.split('\\n').filter(function (line) {\r\n return !!line.match(CHROME_IE_STACK_REGEXP);\r\n }, this);\r\n return filtered.map(function (line) {\r\n if (line.indexOf('(eval ') > -1) {\r\n line = line\r\n .replace(/eval code/g, 'eval')\r\n .replace(/(\\(eval at [^()]*)|(\\),.*$)/g, '');\r\n }\r\n let sanitizedLine = line.replace(/^\\s+/, '').replace(/\\(eval code/g, '(');\r\n const location = sanitizedLine.match(/ (\\((.+):(\\d+):(\\d+)\\)$)/);\r\n sanitizedLine = location\r\n ? sanitizedLine.replace(location[0], '')\r\n : sanitizedLine;\r\n const tokens = sanitizedLine.split(/\\s+/).slice(1);\r\n const locationParts = this.extractLocation(location ? location[1] : tokens.pop());\r\n const functionName = tokens.join(' ') || undefined;\r\n const fileName = ['eval', '<anonymous>'].indexOf(locationParts[0]) > -1\r\n ? undefined\r\n : locationParts[0];\r\n return new StackFrame({\r\n functionName,\r\n fileName,\r\n lineNumber: locationParts[1],\r\n columnNumber: locationParts[2],\r\n });\r\n }, this);\r\n },\r\n parseFFOrSafari: function (error) {\r\n const filtered = error.stack.split('\\n').filter(function (line) {\r\n return !line.match(SAFARI_NATIVE_CODE_REGEXP);\r\n }, this);\r\n return filtered.map(function (line) {\r\n if (line.indexOf(' > eval') > -1) {\r\n line = line.replace(/ line (\\d+)(?: > eval line \\d+)* > eval:\\d+:\\d+/g, ':$1');\r\n }\r\n if (line.indexOf('@') === -1 && line.indexOf(':') === -1) {\r\n return new StackFrame({\r\n functionName: line,\r\n });\r\n }\r\n else {\r\n const functionNameRegex = /((.*\".+\"[^@]*)?[^@]*)(?:@)/;\r\n const matches = line.match(functionNameRegex);\r\n const functionName = matches && matches[1] ? matches[1] : undefined;\r\n const locationParts = this.extractLocation(line.replace(functionNameRegex, ''));\r\n return new StackFrame({\r\n functionName,\r\n fileName: locationParts[0],\r\n lineNumber: locationParts[1],\r\n columnNumber: locationParts[2],\r\n });\r\n }\r\n }, this);\r\n },\r\n parseOpera: function (e) {\r\n if (!e.stacktrace ||\r\n (e.message.indexOf('\\n') > -1 &&\r\n e.message.split('\\n').length > e.stacktrace.split('\\n').length)) {\r\n return this.parseOpera9(e);\r\n }\r\n else if (!e.stack) {\r\n return this.parseOpera10(e);\r\n }\r\n else {\r\n return this.parseOpera11(e);\r\n }\r\n },\r\n parseOpera9: function (e) {\r\n const lineRE = /Line (\\d+).*script (?:in )?(\\S+)/i;\r\n const lines = e.message.split('\\n');\r\n const result = [];\r\n for (let i = 2, len = lines.length; i < len; i += 2) {\r\n const match = lineRE.exec(lines[i]);\r\n if (match) {\r\n result.push(new StackFrame({\r\n fileName: match[2],\r\n lineNumber: parseFloat(match[1]),\r\n }));\r\n }\r\n }\r\n return result;\r\n },\r\n parseOpera10: function (e) {\r\n const lineRE = /Line (\\d+).*script (?:in )?(\\S+)(?:: In function (\\S+))?$/i;\r\n const lines = e.stacktrace.split('\\n');\r\n const result = [];\r\n for (let i = 0, len = lines.length; i < len; i += 2) {\r\n const match = lineRE.exec(lines[i]);\r\n if (match) {\r\n result.push(new StackFrame({\r\n functionName: match[3] || undefined,\r\n fileName: match[2],\r\n lineNumber: parseFloat(match[1]),\r\n }));\r\n }\r\n }\r\n return result;\r\n },\r\n parseOpera11: function (error) {\r\n const filtered = error.stack.split('\\n').filter(function (line) {\r\n return (!!line.match(FIREFOX_SAFARI_STACK_REGEXP) &&\r\n !line.match(/^Error created at/));\r\n }, this);\r\n return filtered.map(function (line) {\r\n const tokens = line.split('@');\r\n const locationParts = this.extractLocation(tokens.pop());\r\n const functionCall = tokens.shift() || '';\r\n const functionName = functionCall\r\n .replace(/<anonymous function(: (\\w+))?>/, '$2')\r\n .replace(/\\([^)]*\\)/g, '') || undefined;\r\n return new StackFrame({\r\n functionName,\r\n fileName: locationParts[0],\r\n lineNumber: locationParts[1],\r\n columnNumber: locationParts[2],\r\n });\r\n }, this);\r\n },\r\n};\n\nexport { ErrorStackParser, StackFrame };\n","function pathToSelector(node) {\r\n if (!node || !node.outerHTML) {\r\n return '';\r\n }\r\n let path = '';\r\n while (node.parentElement) {\r\n let name = node.localName;\r\n if (!name) {\r\n break;\r\n }\r\n name = name.toLowerCase();\r\n const parent = node.parentElement;\r\n const domSiblings = [];\r\n if (parent.children && parent.children.length > 0) {\r\n for (let i = 0; i < parent.children.length; i++) {\r\n const sibling = parent.children[i];\r\n if (sibling.localName && sibling.localName.toLowerCase) {\r\n if (sibling.localName.toLowerCase() === name) {\r\n domSiblings.push(sibling);\r\n }\r\n }\r\n }\r\n }\r\n if (domSiblings.length > 1) {\r\n name += `:eq(${domSiblings.indexOf(node)})`;\r\n }\r\n path = name + (path ? '>' + path : '');\r\n node = parent;\r\n }\r\n return path;\r\n}\r\nfunction isObject(obj) {\r\n return Object.prototype.toString.call(obj) === '[object Object]';\r\n}\r\nfunction isObjTooDeep(obj, limit) {\r\n if (limit === 0) {\r\n return true;\r\n }\r\n const keys = Object.keys(obj);\r\n for (const key of keys) {\r\n if (isObject(obj[key]) &&\r\n isObjTooDeep(obj[key], limit - 1)) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n}\r\nfunction stringify(obj, stringifyOptions) {\r\n const options = {\r\n numOfKeysLimit: 50,\r\n depthOfLimit: 4,\r\n };\r\n Object.assign(options, stringifyOptions);\r\n const stack = [];\r\n const keys = [];\r\n return JSON.stringify(obj, function (key, value) {\r\n if (stack.length > 0) {\r\n const thisPos = stack.indexOf(this);\r\n ~thisPos ? stack.splice(thisPos + 1) : stack.push(this);\r\n ~thisPos ? keys.splice(thisPos, Infinity, key) : keys.push(key);\r\n if (~stack.indexOf(value)) {\r\n if (stack[0] === value) {\r\n value = '[Circular ~]';\r\n }\r\n else {\r\n value =\r\n '[Circular ~.' +\r\n keys.slice(0, stack.indexOf(value)).join('.') +\r\n ']';\r\n }\r\n }\r\n }\r\n else {\r\n stack.push(value);\r\n }\r\n if (value === null)\r\n return value;\r\n if (value === undefined)\r\n return 'undefined';\r\n if (shouldIgnore(value)) {\r\n return toString(value);\r\n }\r\n if (typeof value === 'bigint') {\r\n return value.toString() + 'n';\r\n }\r\n if (value instanceof Event) {\r\n const eventResult = {};\r\n for (const eventKey in value) {\r\n const eventValue = value[eventKey];\r\n if (Array.isArray(eventValue)) {\r\n eventResult[eventKey] = pathToSelector((eventValue.length ? eventValue[0] : null));\r\n }\r\n else {\r\n eventResult[eventKey] = eventValue;\r\n }\r\n }\r\n return eventResult;\r\n }\r\n else if (value instanceof Node) {\r\n if (value instanceof HTMLElement) {\r\n return value ? value.outerHTML : '';\r\n }\r\n return value.nodeName;\r\n }\r\n else if (value instanceof Error) {\r\n return value.stack\r\n ? value.stack + '\\nEnd of stack for Error object'\r\n : value.name + ': ' + value.message;\r\n }\r\n return value;\r\n });\r\n function shouldIgnore(_obj) {\r\n if (isObject(_obj) && Object.keys(_obj).length > options.numOfKeysLimit) {\r\n return true;\r\n }\r\n if (typeof _obj === 'function') {\r\n return true;\r\n }\r\n if (isObject(_obj) &&\r\n isObjTooDeep(_obj, options.depthOfLimit)) {\r\n return true;\r\n }\r\n return false;\r\n }\r\n function toString(_obj) {\r\n let str = _obj.toString();\r\n if (options.stringLengthLimit && str.length > options.stringLengthLimit) {\r\n str = `${str.slice(0, options.stringLengthLimit)}...`;\r\n }\r\n return str;\r\n }\r\n}\n\nexport { stringify };\n","import { patch } from '../../../utils.js';\nimport { ErrorStackParser } from './error-stack-parser.js';\nimport { stringify } from './stringify.js';\n\nconst defaultLogOptions = {\r\n level: [\r\n 'assert',\r\n 'clear',\r\n 'count',\r\n 'countReset',\r\n 'debug',\r\n 'dir',\r\n 'dirxml',\r\n 'error',\r\n 'group',\r\n 'groupCollapsed',\r\n 'groupEnd',\r\n 'info',\r\n 'log',\r\n 'table',\r\n 'time',\r\n 'timeEnd',\r\n 'timeLog',\r\n 'trace',\r\n 'warn',\r\n ],\r\n lengthThreshold: 1000,\r\n logger: 'console',\r\n};\r\nfunction initLogObserver(cb, win, options) {\r\n const logOptions = (options ? Object.assign({}, defaultLogOptions, options) : defaultLogOptions);\r\n const loggerType = logOptions.logger;\r\n if (!loggerType) {\r\n return () => {\r\n };\r\n }\r\n let logger;\r\n if (typeof loggerType === 'string') {\r\n logger = win[loggerType];\r\n }\r\n else {\r\n logger = loggerType;\r\n }\r\n let logCount = 0;\r\n let inStack = false;\r\n const cancelHandlers = [];\r\n if (logOptions.level.includes('error')) {\r\n const errorHandler = (event) => {\r\n const message = event.message, error = event.error;\r\n const trace = ErrorStackParser.parse(error).map((stackFrame) => stackFrame.toString());\r\n const payload = [stringify(message, logOptions.stringifyOptions)];\r\n cb({\r\n level: 'error',\r\n trace,\r\n payload,\r\n });\r\n };\r\n win.addEventListener('error', errorHandler);\r\n cancelHandlers.push(() => {\r\n win.removeEventListener('error', errorHandler);\r\n });\r\n const unhandledrejectionHandler = (event) => {\r\n let error;\r\n let payload;\r\n if (event.reason instanceof Error) {\r\n error = event.reason;\r\n payload = [\r\n stringify(`Uncaught (in promise) ${error.name}: ${error.message}`, logOptions.stringifyOptions),\r\n ];\r\n }\r\n else {\r\n error = new Error();\r\n payload = [\r\n stringify('Uncaught (in promise)', logOptions.stringifyOptions),\r\n stringify(event.reason, logOptions.stringifyOptions),\r\n ];\r\n }\r\n const trace = ErrorStackParser.parse(error).map((stackFrame) => stackFrame.toString());\r\n cb({\r\n level: 'error',\r\n trace,\r\n payload,\r\n });\r\n };\r\n win.addEventListener('unhandledrejection', unhandledrejectionHandler);\r\n cancelHandlers.push(() => {\r\n win.removeEventListener('unhandledrejection', unhandledrejectionHandler);\r\n });\r\n }\r\n for (const levelType of logOptions.level) {\r\n cancelHandlers.push(replace(logger, levelType));\r\n }\r\n return () => {\r\n cancelHandlers.forEach((h) => h());\r\n };\r\n function replace(_logger, level) {\r\n if (!_logger[level]) {\r\n return () => {\r\n };\r\n }\r\n return patch(_logger, level, (original) => {\r\n return (...args) => {\r\n original.apply(this, args);\r\n if (inStack) {\r\n return;\r\n }\r\n inStack = true;\r\n try {\r\n const trace = ErrorStackParser.parse(new Error())\r\n .map((stackFrame) => stackFrame.toString())\r\n .splice(1);\r\n const payload = args.map((s) => stringify(s, logOptions.stringifyOptions));\r\n logCount++;\r\n if (logCount < logOptions.lengthThreshold) {\r\n cb({\r\n level,\r\n trace,\r\n payload,\r\n });\r\n }\r\n else if (logCount === logOptions.lengthThreshold) {\r\n cb({\r\n level: 'warn',\r\n trace: [],\r\n payload: [\r\n stringify('The number of log records reached the threshold.'),\r\n ],\r\n });\r\n }\r\n }\r\n catch (error) {\r\n original('rrweb logger error:', error, ...args);\r\n }\r\n finally {\r\n inStack = false;\r\n }\r\n };\r\n });\r\n }\r\n}\r\nconst PLUGIN_NAME = 'rrweb/console@1';\r\nconst getRecordConsolePlugin = (options) => ({\r\n name: PLUGIN_NAME,\r\n observer: initLogObserver,\r\n options: options,\r\n});\n\nexport { PLUGIN_NAME, getRecordConsolePlugin };\n","// eslint-disable-next-line posthog-js/no-direct-array-check\nconst nativeIsArray = Array.isArray\nconst ObjProto = Object.prototype\nexport const hasOwnProperty = ObjProto.hasOwnProperty\nconst toString = ObjProto.toString\n\nexport const isArray =\n nativeIsArray ||\n function (obj: any): obj is any[] {\n return toString.call(obj) === '[object Array]'\n }\nexport const isUint8Array = function (x: unknown): x is Uint8Array {\n return toString.call(x) === '[object Uint8Array]'\n}\n// from a comment on http://dbj.org/dbj/?p=286\n// fails on only one very rare and deliberate custom object:\n// let bomb = { toString : undefined, valueOf: function(o) { return \"function BOMBA!\"; }};\nexport const isFunction = function (f: any): f is (...args: any[]) => any {\n // eslint-disable-next-line posthog-js/no-direct-function-check\n return typeof f === 'function'\n}\n// Underscore Addons\nexport const isObject = function (x: unknown): x is Record<string, any> {\n // eslint-disable-next-line posthog-js/no-direct-object-check\n return x === Object(x) && !isArray(x)\n}\nexport const isEmptyObject = function (x: unknown): x is Record<string, any> {\n if (isObject(x)) {\n for (const key in x) {\n if (hasOwnProperty.call(x, key)) {\n return false\n }\n }\n return true\n }\n return false\n}\nexport const isUndefined = function (x: unknown): x is undefined {\n return x === void 0\n}\n\nexport const isString = function (x: unknown): x is string {\n // eslint-disable-next-line posthog-js/no-direct-string-check\n return toString.call(x) == '[object String]'\n}\n\nexport const isEmptyString = function (x: unknown): boolean {\n return isString(x) && x.trim().length === 0\n}\n\nexport const isNull = function (x: unknown): x is null {\n // eslint-disable-next-line posthog-js/no-direct-null-check\n return x === null\n}\n\n/*\n sometimes you want to check if something is null or undefined\n that's what this is for\n */\nexport const isNullish = function (x: unknown): x is null | undefined {\n return isUndefined(x) || isNull(x)\n}\n\nexport const isDate = function (x: unknown): x is Date {\n // eslint-disable-next-line posthog-js/no-direct-date-check\n return toString.call(x) == '[object Date]'\n}\nexport const isNumber = function (x: unknown): x is number {\n // eslint-disable-next-line posthog-js/no-direct-number-check\n return toString.call(x) == '[object Number]'\n}\nexport const isBoolean = function (x: unknown): x is boolean {\n // eslint-disable-next-line posthog-js/no-direct-boolean-check\n return toString.call(x) === '[object Boolean]'\n}\n\nexport const isDocument = (x: unknown): x is Document => {\n // eslint-disable-next-line posthog-js/no-direct-document-check\n return x instanceof Document\n}\n\nexport const isFormData = (x: unknown): x is FormData => {\n // eslint-disable-next-line posthog-js/no-direct-form-data-check\n return x instanceof FormData\n}\n\nexport const isFile = (x: unknown): x is File => {\n // eslint-disable-next-line posthog-js/no-direct-file-check\n return x instanceof File\n}\n","import { ErrorProperties } from '../extensions/exception-autocapture/error-conversion'\nimport type { PostHog } from '../posthog-core'\nimport { SessionIdManager } from '../sessionid'\nimport { ErrorEventArgs, ErrorMetadata, Properties } from '../types'\n\n/*\n * Global helpers to protect access to browser globals in a way that is safer for different targets\n * like DOM, SSR, Web workers etc.\n *\n * NOTE: Typically we want the \"window\" but globalThis works for both the typical browser context as\n * well as other contexts such as the web worker context. Window is still exported for any bits that explicitly require it.\n * If in doubt - export the global you need from this file and use that as an optional value. This way the code path is forced\n * to handle the case where the global is not available.\n */\n\n// eslint-disable-next-line no-restricted-globals\nconst win: (Window & typeof globalThis) | undefined = typeof window !== 'undefined' ? window : undefined\n\n/**\n * This is our contract between (potentially) lazily loaded extensions and the SDK\n * changes to this interface can be breaking changes for users of the SDK\n */\n\nexport type PostHogExtensionKind =\n | 'toolbar'\n | 'exception-autocapture'\n | 'web-vitals'\n | 'recorder'\n | 'tracing-headers'\n | 'surveys'\n\ninterface PostHogExtensions {\n loadExternalDependency?: (\n posthog: PostHog,\n kind: PostHogExtensionKind,\n callback: (error?: string | Event, event?: Event) => void\n ) => void\n\n loadSiteApp?: (posthog: PostHog, appUrl: string, callback: (error?: string | Event, event?: Event) => void) => void\n\n parseErrorAsProperties?: (\n [event, source, lineno, colno, error]: ErrorEventArgs,\n metadata?: ErrorMetadata\n ) => ErrorProperties\n errorWrappingFunctions?: {\n wrapOnError: (captureFn: (props: Properties) => void) => () => void\n wrapUnhandledRejection: (captureFn: (props: Properties) => void) => () => void\n }\n rrweb?: { record: any; version: string; rrwebVersion: string }\n rrwebPlugins?: { getRecordConsolePlugin: any; getRecordNetworkPlugin?: any }\n canActivateRepeatedly?: (survey: any) => boolean\n generateSurveys?: (posthog: PostHog) => any | undefined\n postHogWebVitalsCallbacks?: {\n onLCP: (metric: any) => void\n onCLS: (metric: any) => void\n onFCP: (metric: any) => void\n onINP: (metric: any) => void\n }\n tracingHeadersPatchFns?: {\n _patchFetch: (sessionManager: SessionIdManager) => () => void\n _patchXHR: (sessionManager: any) => () => void\n }\n}\n\nconst global: typeof globalThis | undefined = typeof globalThis !== 'undefined' ? globalThis : win\n\nexport const ArrayProto = Array.prototype\nexport const nativeForEach = ArrayProto.forEach\nexport const nativeIndexOf = ArrayProto.indexOf\n\nexport const navigator = global?.navigator\nexport const document = global?.document\nexport const location = global?.location\nexport const fetch = global?.fetch\nexport const XMLHttpRequest =\n global?.XMLHttpRequest && 'withCredentials' in new global.XMLHttpRequest() ? global.XMLHttpRequest : undefined\nexport const AbortController = global?.AbortController\nexport const userAgent = navigator?.userAgent\nexport const assignableWindow: Window &\n typeof globalThis &\n Record<string, any> & {\n __PosthogExtensions__?: PostHogExtensions\n } = win ?? ({} as any)\n\nexport { win as window }\n","import Config from '../config'\nimport { isUndefined } from './type-utils'\nimport { assignableWindow, window } from './globals'\n\nconst LOGGER_PREFIX = '[PostHog.js]'\nexport const logger = {\n _log: (level: 'log' | 'warn' | 'error', ...args: any[]) => {\n if (\n window &&\n (Config.DEBUG || assignableWindow.POSTHOG_DEBUG) &&\n !isUndefined(window.console) &&\n window.console\n ) {\n const consoleLog =\n '__rrweb_original__' in window.console[level]\n ? (window.console[level] as any)['__rrweb_original__']\n : window.console[level]\n\n // eslint-disable-next-line no-console\n consoleLog(LOGGER_PREFIX, ...args)\n }\n },\n\n info: (...args: any[]) => {\n logger._log('log', ...args)\n },\n\n warn: (...args: any[]) => {\n logger._log('warn', ...args)\n },\n\n error: (...args: any[]) => {\n logger._log('error', ...args)\n },\n\n critical: (...args: any[]) => {\n // Critical errors are always logged to the console\n // eslint-disable-next-line no-console\n console.error(LOGGER_PREFIX, ...args)\n },\n\n uninitializedWarning: (methodName: string) => {\n logger.error(`You must initialize PostHog before calling ${methodName}`)\n },\n}\n","import { Breaker, EventHandler, Properties } from '../types'\nimport { isArray, isFormData, isFunction, isNull, isNullish, isString, hasOwnProperty } from './type-utils'\nimport { logger } from './logger'\nimport { window, nativeForEach, nativeIndexOf } from './globals'\n\nconst breaker: Breaker = {}\n\n// UNDERSCORE\n// Embed part of the Underscore Library\nexport const trim = function (str: string): string {\n return str.replace(/^[\\s\\uFEFF\\xA0]+|[\\s\\uFEFF\\xA0]+$/g, '')\n}\n\nexport function eachArray<E = any>(\n obj: E[] | null | undefined,\n iterator: (value: E, key: number) => void | Breaker,\n thisArg?: any\n): void {\n if (isArray(obj)) {\n if (nativeForEach && obj.forEach === nativeForEach) {\n obj.forEach(iterator, thisArg)\n } else if ('length' in obj && obj.length === +obj.length) {\n for (let i = 0, l = obj.length; i < l; i++) {\n if (i in obj && iterator.call(thisArg, obj[i], i) === breaker) {\n return\n }\n }\n }\n }\n}\n\n/**\n * @param {*=} obj\n * @param {function(...*)=} iterator\n * @param {Object=} thisArg\n */\nexport function each(obj: any, iterator: (value: any, key: any) => void | Breaker, thisArg?: any): void {\n if (isNullish(obj)) {\n return\n }\n if (isArray(obj)) {\n return eachArray(obj, iterator, thisArg)\n }\n if (isFormData(obj)) {\n for (const pair of obj.entries()) {\n if (iterator.call(thisArg, pair[1], pair[0]) === breaker) {\n return\n }\n }\n return\n }\n for (const key in obj) {\n if (hasOwnProperty.call(obj, key)) {\n if (iterator.call(thisArg, obj[key], key) === breaker) {\n return\n }\n }\n }\n}\n\nexport const extend = function (obj: Record<string, any>, ...args: Record<string, any>[]): Record<string, any> {\n eachArray(args, function (source) {\n for (const prop in source) {\n if (source[prop] !== void 0) {\n obj[prop] = source[prop]\n }\n }\n })\n return obj\n}\n\nexport const include = function (\n obj: null | string | Array<any> | Record<string, any>,\n target: any\n): boolean | Breaker {\n let found = false\n if (isNull(obj)) {\n return found\n }\n if (nativeIndexOf && obj.indexOf === nativeIndexOf) {\n return obj.indexOf(target) != -1\n }\n each(obj, function (value) {\n if (found || (found = value === target)) {\n return breaker\n }\n return\n })\n return found\n}\n\nexport function includes<T = any>(str: T[] | string, needle: T): boolean {\n return (str as any).indexOf(needle) !== -1\n}\n\n/**\n * Object.entries() polyfill\n * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/entries\n */\nexport function entries<T = any>(obj: Record<string, T>): [string, T][] {\n const ownProps = Object.keys(obj)\n let i = ownProps.length\n const resArray = new Array(i) // preallocate the Array\n\n while (i--) {\n resArray[i] = [ownProps[i], obj[ownProps[i]]]\n }\n return resArray\n}\n\nexport const isValidRegex = function (str: string): boolean {\n try {\n new RegExp(str)\n } catch {\n return false\n }\n return true\n}\n\nexport const trySafe = function <T>(fn: () => T): T | undefined {\n try {\n return fn()\n } catch {\n return undefined\n }\n}\n\nexport const safewrap = function <F extends (...args: any[]) => any = (...args: any[]) => any>(f: F): F {\n return function (...args) {\n try {\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n return f.apply(this, args)\n } catch (e) {\n logger.critical(\n 'Implementation error. Please turn on debug mode and open a ticket on https://app.posthog.com/home#panel=support%3Asupport%3A.'\n )\n logger.critical(e)\n }\n } as F\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unsafe-function-type\nexport const safewrapClass = function (klass: Function, functions: string[]): void {\n for (let i = 0; i < functions.length; i++) {\n klass.prototype[functions[i]] = safewrap(klass.prototype[functions[i]])\n }\n}\n\nexport const stripEmptyProperties = function (p: Properties): Properties {\n const ret: Properties = {}\n each(p, function (v, k) {\n if (isString(v) && v.length > 0) {\n ret[k] = v\n }\n })\n return ret\n}\n\nexport const stripLeadingDollar = function (s: string): string {\n return s.replace(/^\\$/, '')\n}\n\n/**\n * Deep copies an object.\n * It handles cycles by replacing all references to them with `undefined`\n * Also supports customizing native values\n *\n * @param value\n * @param customizer\n * @returns {{}|undefined|*}\n */\nfunction deepCircularCopy<T extends Record<string, any> = Record<string, any>>(\n value: T,\n customizer?: <K extends keyof T = keyof T>(value: T[K], key?: K) => T[K]\n): T | undefined {\n const COPY_IN_PROGRESS_SET = new Set()\n\n function internalDeepCircularCopy(value: T, key?: string): T | undefined {\n if (value !== Object(value)) return customizer ? customizer(value as any, key) : value // primitive value\n\n if (COPY_IN_PROGRESS_SET.has(value)) return undefined\n COPY_IN_PROGRESS_SET.add(value)\n let result: T\n\n if (isArray(value)) {\n result = [] as any as T\n eachArray(value, (it) => {\n result.push(internalDeepCircularCopy(it))\n })\n } else {\n result = {} as T\n each(value, (val, key) => {\n if (!COPY_IN_PROGRESS_SET.has(val)) {\n ;(result as any)[key] = internalDeepCircularCopy(val, key)\n }\n })\n }\n return result\n }\n return internalDeepCircularCopy(value)\n}\n\nexport function _copyAndTruncateStrings<T extends Record<string, any> = Record<string, any>>(\n object: T,\n maxStringLength: number | null\n): T {\n return deepCircularCopy(object, (value: any) => {\n if (isString(value) && !isNull(maxStringLength)) {\n return (value as string).slice(0, maxStringLength)\n }\n return value\n }) as T\n}\n\nexport function _base64Encode(data: null): null\nexport function _base64Encode(data: undefined): undefined\nexport function _base64Encode(data: string): string\nexport function _base64Encode(data: string | null | undefined): string | null | undefined {\n const b64 = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/='\n let o1,\n o2,\n o3,\n h1,\n h2,\n h3,\n h4,\n bits,\n i = 0,\n ac = 0,\n enc = ''\n const tmp_arr: string[] = []\n\n if (!data) {\n return data\n }\n\n data = utf8Encode(data)\n\n do {\n // pack three octets into four hexets\n o1 = data.charCodeAt(i++)\n o2 = data.charCodeAt(i++)\n o3 = data.charCodeAt(i++)\n\n bits = (o1 << 16) | (o2 << 8) | o3\n\n h1 = (bits >> 18) & 0x3f\n h2 = (bits >> 12) & 0x3f\n h3 = (bits >> 6) & 0x3f\n h4 = bits & 0x3f\n\n // use hexets to index into b64, and append result to encoded string\n tmp_arr[ac++] = b64.charAt(h1) + b64.charAt(h2) + b64.charAt(h3) + b64.charAt(h4)\n } while (i < data.length)\n\n enc = tmp_arr.join('')\n\n switch (data.length % 3) {\n case 1:\n enc = enc.slice(0, -2) + '=='\n break\n case 2:\n enc = enc.slice(0, -1) + '='\n break\n }\n\n return enc\n}\n\nexport const utf8Encode = function (string: string): string {\n string = (string + '').replace(/\\r\\n/g, '\\n').replace(/\\r/g, '\\n')\n\n let utftext = '',\n start,\n end\n let stringl = 0,\n n\n\n start = end = 0\n stringl = string.length\n\n for (n = 0; n < stringl; n++) {\n const c1 = string.charCodeAt(n)\n let enc = null\n\n if (c1 < 128) {\n end++\n } else if (c1 > 127 && c1 < 2048) {\n enc = String.fromCharCode((c1 >> 6) | 192, (c1 & 63) | 128)\n } else {\n enc = String.fromCharCode((c1 >> 12) | 224, ((c1 >> 6) & 63) | 128, (c1 & 63) | 128)\n }\n if (!isNull(enc)) {\n if (end > start) {\n utftext += string.substring(start, end)\n }\n utftext += enc\n start = end = n + 1\n }\n }\n\n if (end > start) {\n utftext += string.substring(start, string.length)\n }\n\n return utftext\n}\n\nexport const registerEvent = (function () {\n // written by Dean Edwards, 2005\n // with input from Tino Zijdel - crisp@xs4all.nl\n // with input from Carl Sverre - mail@carlsverre.com\n // with input from PostHog\n // http://dean.edwards.name/weblog/2005/10/add-event/\n // https://gist.github.com/1930440\n\n /**\n * @param {Object} element\n * @param {string} type\n * @param {function(...*)} handler\n * @param {boolean=} oldSchool\n * @param {boolean=} useCapture\n */\n const register_event = function (\n element: Element | Window | Document | Node,\n type: string,\n handler: EventHandler,\n oldSchool?: boolean,\n useCapture?: boolean\n ) {\n if (!element) {\n logger.error('No valid element provided to register_event')\n return\n }\n\n if (element.addEventListener && !oldSchool) {\n element.addEventListener(type, handler, !!useCapture)\n } else {\n const ontype = 'on' + type\n const old_handler = (element as any)[ontype] // can be undefined\n ;(element as any)[ontype] = makeHandler(element, handler, old_handler)\n }\n }\n\n function makeHandler(\n element: Element | Window | Document | Node,\n new_handler: EventHandler,\n old_handlers: EventHandler\n ) {\n return function (event: Event): boolean | void {\n event = event || fixEvent(window?.event)\n\n // this basically happens in firefox whenever another script\n // overwrites the onload callback and doesn't pass the event\n // object to previously defined callbacks. All the browsers\n // that don't define window.event implement addEventListener\n // so the dom_loaded handler will still be fired as usual.\n if (!event) {\n return undefined\n }\n\n let ret = true\n let old_result: any\n\n if (isFunction(old_handlers)) {\n old_result = old_handlers(event)\n }\n const new_result = new_handler.call(element, event)\n\n if (false === old_result || false === new_result) {\n ret = false\n }\n\n return ret\n }\n }\n\n function fixEvent(event: Event | undefined): Event | undefined {\n if (event) {\n event.preventDefault = fixEvent.preventDefault\n event.stopPropagation = fixEvent.stopPropagation\n }\n return event\n }\n fixEvent.preventDefault = function () {\n ;(this as any as Event).returnValue = false\n }\n fixEvent.stopPropagation = function () {\n ;(this as any as Event).cancelBubble = true\n }\n\n return register_event\n})()\n\nexport function isCrossDomainCookie(documentLocation: Location | undefined) {\n const hostname = documentLocation?.hostname\n\n if (!isString(hostname)) {\n return false\n }\n // split and slice isn't a great way to match arbitrary domains,\n // but it's good enough for ensuring we only match herokuapp.com when it is the TLD\n // for the hostname\n return hostname.split('.').slice(-2).join('.') !== 'herokuapp.com'\n}\n\nexport function isDistinctIdStringLike(value: string): boolean {\n return ['distinct_id', 'distinctid'].includes(value.toLowerCase())\n}\n\nexport function find<T>(value: T[], predicate: (value: T) => boolean): T | undefined {\n for (let i = 0; i < value.length; i++) {\n if (predicate(value[i])) {\n return value[i]\n }\n }\n return undefined\n}\n","import { each, isValidRegex } from './'\n\nimport { isArray, isFile, isUndefined } from './type-utils'\nimport { logger } from './logger'\nimport { document } from './globals'\n\nconst localDomains = ['localhost', '127.0.0.1']\n\n/**\n * IE11 doesn't support `new URL`\n * so we can create an anchor element and use that to parse the URL\n * there's a lot of overlap between HTMLHyperlinkElementUtils and URL\n * meaning useful properties like `pathname` are available on both\n */\nexport const convertToURL = (url: string): HTMLAnchorElement | null => {\n const location = document?.createElement('a')\n if (isUndefined(location)) {\n return null\n }\n\n location.href = url\n return location\n}\n\nexport const isUrlMatchingRegex = function (url: string, pattern: string): boolean {\n if (!isValidRegex(pattern)) return false\n return new RegExp(pattern).test(url)\n}\n\nexport const formDataToQuery = function (formdata: Record<string, any> | FormData, arg_separator = '&'): string {\n let use_val: string\n let use_key: string\n const tph_arr: string[] = []\n\n each(formdata, function (val: File | string | undefined, key: string | undefined) {\n // the key might be literally the string undefined for e.g. if {undefined: 'something'}\n if (isUndefined(val) || isUndefined(key) || key === 'undefined') {\n return\n }\n\n use_val = encodeURIComponent(isFile(val) ? val.name : val.toString())\n use_key = encodeURIComponent(key)\n tph_arr[tph_arr.length] = use_key + '=' + use_val\n })\n\n return tph_arr.join(arg_separator)\n}\n\nexport const getQueryParam = function (url: string, param: string): string {\n const withoutHash: string = url.split('#')[0] || ''\n const queryParams: string = withoutHash.split('?')[1] || ''\n\n const queryParts = queryParams.split('&')\n let keyValuePair\n\n for (let i = 0; i < queryParts.length; i++) {\n const parts = queryParts[i].split('=')\n if (parts[0] === param) {\n keyValuePair = parts\n break\n }\n }\n\n if (!isArray(keyValuePair) || keyValuePair.length < 2) {\n return ''\n } else {\n let result = keyValuePair[1]\n try {\n result = decodeURIComponent(result)\n } catch {\n logger.error('Skipping decoding for malformed query param: ' + result)\n }\n return result.replace(/\\+/g, ' ')\n }\n}\n\nexport const _getHashParam = function (hash: string, param: string): string | null {\n const matches = hash.match(new RegExp(param + '=([^&]*)'))\n return matches ? matches[1] : null\n}\n\nexport const isLocalhost = (): boolean => {\n return localDomains.includes(location.hostname)\n}\n","import { CapturedNetworkRequest, NetworkRecordOptions, PostHogConfig } from '../../types'\nimport { isFunction, isNullish, isString, isUndefined } from '../../utils/type-utils'\nimport { convertToURL } from '../../utils/request-utils'\nimport { logger } from '../../utils/logger'\nimport { shouldCaptureValue } from '../../autocapture-utils'\nimport { each } from '../../utils'\n\nconst LOGGER_PREFIX = '[SessionRecording]'\nconst REDACTED = 'redacted'\n\nexport const defaultNetworkOptions: Required<NetworkRecordOptions> = {\n initiatorTypes: [\n 'audio',\n 'beacon',\n 'body',\n 'css',\n 'early-hint',\n 'embed',\n 'fetch',\n 'frame',\n 'iframe',\n 'icon',\n 'image',\n 'img',\n 'input',\n 'link',\n 'navigation',\n 'object',\n 'ping',\n 'script',\n 'track',\n 'video',\n 'xmlhttprequest',\n ],\n maskRequestFn: (data: CapturedNetworkRequest) => data,\n recordHeaders: false,\n recordBody: false,\n recordInitialRequests: false,\n recordPerformance: false,\n performanceEntryTypeToObserve: [\n // 'event', // This is too noisy as it covers all browser events\n 'first-input',\n // 'mark', // Mark is used too liberally. We would need to filter for specific marks\n // 'measure', // Measure is used too liberally. We would need to filter for specific measures\n 'navigation',\n 'paint',\n 'resource',\n ],\n payloadSizeLimitBytes: 1000000,\n payloadHostDenyList: ['.lr-ingest.io', '.ingest.sentry.io'],\n}\n\nconst HEADER_DENY_LIST = [\n 'authorization',\n 'x-forwarded-for',\n 'authorization',\n 'cookie',\n 'set-cookie',\n 'x-api-key',\n 'x-real-ip',\n 'remote-addr',\n 'forwarded',\n 'proxy-authorization',\n 'x-csrf-token',\n 'x-csrftoken',\n 'x-xsrf-token',\n]\n\nconst PAYLOAD_CONTENT_DENY_LIST = [\n 'password',\n 'secret',\n 'passwd',\n 'api_key',\n 'apikey',\n 'auth',\n 'credentials',\n 'mysql_pwd',\n 'privatekey',\n 'private_key',\n 'token',\n]\n\n// we always remove headers on the deny list because we never want to capture this sensitive data\nconst removeAuthorizationHeader = (data: CapturedNetworkRequest): CapturedNetworkRequest => {\n const headers = data.requestHeaders\n if (!isNullish(headers)) {\n each(Object.keys(headers ?? {}), (header) => {\n if (HEADER_DENY_LIST.includes(header.toLowerCase())) {\n headers[header] = REDACTED\n }\n })\n }\n return data\n}\n\nconst POSTHOG_PATHS_TO_IGNORE = ['/s/', '/e/', '/i/']\n// want to ignore posthog paths when capturing requests, or we can get trapped in a loop\n// because calls to PostHog would be reported using a call to PostHog which would be reported....\nconst ignorePostHogPaths = (data: CapturedNetworkRequest): CapturedNetworkRequest | undefined => {\n const url = convertToURL(data.name)\n if (url && url.pathname && POSTHOG_PATHS_TO_IGNORE.some((path) => url.pathname.indexOf(path) === 0)) {\n return undefined\n }\n return data\n}\n\nfunction estimateBytes(payload: string): number {\n return new Blob([payload]).size\n}\n\nfunction enforcePayloadSizeLimit(\n payload: string | null | undefined,\n headers: Record<string, any> | undefined,\n limit: number,\n description: string\n): string | null | undefined {\n if (isNullish(payload)) {\n return payload\n }\n\n let requestContentLength: string | number = headers?.['content-length'] || estimateBytes(payload)\n if (isString(requestContentLength)) {\n requestContentLength = parseInt(requestContentLength)\n }\n\n if (requestContentLength > limit) {\n return LOGGER_PREFIX + ` ${description} body too large to record (${requestContentLength} bytes)`\n }\n\n return payload\n}\n\n// people can have arbitrarily large payloads on their site, but we don't want to ingest them\nconst limitPayloadSize = (\n options: NetworkRecordOptions\n): ((data: CapturedNetworkRequest | undefined) => CapturedNetworkRequest | undefined) => {\n // the smallest of 1MB or the specified limit if there is one\n const limit = Math.min(1000000, options.payloadSizeLimitBytes ?? 1000000)\n\n return (data) => {\n if (data?.requestBody) {\n data.requestBody = enforcePayloadSizeLimit(data.requestBody, data.requestHeaders, limit, 'Request')\n }\n\n if (data?.responseBody) {\n data.responseBody = enforcePayloadSizeLimit(data.responseBody, data.responseHeaders, limit, 'Response')\n }\n\n return data\n }\n}\n\nfunction scrubPayload(payload: string | null | undefined, label: 'Request' | 'Response'): string | null | undefined {\n if (isNullish(payload)) {\n return payload\n }\n let scrubbed = payload\n\n if (!shouldCaptureValue(scrubbed, false)) {\n scrubbed = LOGGER_PREFIX + ' ' + label + ' body ' + REDACTED\n }\n each(PAYLOAD_CONTENT_DENY_LIST, (text) => {\n if (scrubbed?.length && scrubbed?.indexOf(text) !== -1) {\n scrubbed = LOGGER_PREFIX + ' ' + label + ' body ' + REDACTED + ' as might contain: ' + text\n }\n })\n\n return scrubbed\n}\n\nfunction scrubPayloads(capturedRequest: CapturedNetworkRequest | undefined): CapturedNetworkRequest | undefined {\n if (isUndefined(capturedRequest)) {\n return undefined\n }\n\n capturedRequest.requestBody = scrubPayload(capturedRequest.requestBody, 'Request')\n capturedRequest.responseBody = scrubPayload(capturedRequest.responseBody, 'Response')\n\n return capturedRequest\n}\n\n/**\n * whether a maskRequestFn is provided or not,\n * we ensure that we remove the denied header from requests\n * we _never_ want to record that header by accident\n * if someone complains then we'll add an opt-in to let them override it\n */\nexport const buildNetworkRequestOptions = (\n instanceConfig: PostHogConfig,\n remoteNetworkOptions: Pick<\n NetworkRecordOptions,\n 'recordHeaders' | 'recordBody' | 'recordPerformance' | 'payloadHostDenyList'\n >\n): NetworkRecordOptions => {\n const config: NetworkRecordOptions = {\n payloadSizeLimitBytes: defaultNetworkOptions.payloadSizeLimitBytes,\n performanceEntryTypeToObserve: [...defaultNetworkOptions.performanceEntryTypeToObserve],\n payloadHostDenyList: [\n ...(remoteNetworkOptions.payloadHostDenyList || []),\n ...defaultNetworkOptions.payloadHostDenyList,\n ],\n }\n // client can always disable despite remote options\n const canRecordHeaders =\n instanceConfig.session_recording.recordHeaders === false ? false : remoteNetworkOptions.recordHeaders\n const canRecordBody =\n instanceConfig.session_recording.recordBody === false ? false : remoteNetworkOptions.recordBody\n const canRecordPerformance =\n instanceConfig.capture_performance === false ? false : remoteNetworkOptions.recordPerformance\n\n const payloadLimiter = limitPayloadSize(config)\n\n const enforcedCleaningFn: NetworkRecordOptions['maskRequestFn'] = (d: CapturedNetworkRequest) =>\n payloadLimiter(ignorePostHogPaths(removeAuthorizationHeader(d)))\n\n const hasDeprecatedMaskFunction = isFunction(instanceConfig.session_recording.maskNetworkRequestFn)\n\n if (hasDeprecatedMaskFunction && isFunction(instanceConfig.session_recording.maskCapturedNetworkRequestFn)) {\n logger.warn(\n 'Both `maskNetworkRequestFn` and `maskCapturedNetworkRequestFn` are defined. `maskNetworkRequestFn` will be ignored.'\n )\n }\n\n if (hasDeprecatedMaskFunction) {\n instanceConfig.session_recording.maskCapturedNetworkRequestFn = (data: CapturedNetworkRequest) => {\n const cleanedURL = instanceConfig.session_recording.maskNetworkRequestFn!({ url: data.name })\n return {\n ...data,\n name: cleanedURL?.url,\n } as CapturedNetworkRequest\n }\n }\n\n config.maskRequestFn = isFunction(instanceConfig.session_recording.maskCapturedNetworkRequestFn)\n ? (data) => {\n const cleanedRequest = enforcedCleaningFn(data)\n return cleanedRequest\n ? instanceConfig.session_recording.maskCapturedNetworkRequestFn?.(cleanedRequest) ?? undefined\n : undefined\n }\n : (data) => scrubPayloads(enforcedCleaningFn(data))\n\n return {\n ...defaultNetworkOptions,\n ...config,\n recordHeaders: canRecordHeaders,\n recordBody: canRecordBody,\n recordPerformance: canRecordPerformance,\n recordInitialRequests: canRecordPerformance,\n }\n}\n","// import { patch } from 'rrweb/typings/utils'\n// copied from https://github.com/rrweb-io/rrweb/blob/8aea5b00a4dfe5a6f59bd2ae72bb624f45e51e81/packages/rrweb/src/utils.ts#L129\n// which was copied from https://github.com/getsentry/sentry-javascript/blob/b2109071975af8bf0316d3b5b38f519bdaf5dc15/packages/utils/src/object.ts\nimport { isFunction } from '../../../utils/type-utils'\n\nexport function patch(\n source: { [key: string]: any },\n name: string,\n replacement: (...args: unknown[]) => unknown\n): () => void {\n try {\n if (!(name in source)) {\n return () => {\n //\n }\n }\n\n const original = source[name] as () => unknown\n const wrapped = replacement(original)\n\n // Make sure it's a function first, as we need to attach an empty prototype for `defineProperties` to work\n // otherwise it'll throw \"TypeError: Object.defineProperties called on non-object\"\n if (isFunction(wrapped)) {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n wrapped.prototype = wrapped.prototype || {}\n Object.defineProperties(wrapped, {\n __posthog_wrapped__: {\n enumerable: false,\n value: true,\n },\n })\n }\n\n source[name] = wrapped\n\n return () => {\n source[name] = original\n }\n } catch {\n return () => {\n //\n }\n // This can throw if multiple fill happens on a global object like XMLHttpRequest\n // Fixes https://github.com/getsentry/sentry-javascript/issues/2043\n }\n}\n","import { NetworkRecordOptions } from '../../../types'\n\nfunction hostnameFromURL(url: string | URL | RequestInfo): string | null {\n try {\n if (typeof url === 'string') {\n return new URL(url).hostname\n }\n if ('url' in url) {\n return new URL(url.url).hostname\n }\n return url.hostname\n } catch {\n return null\n }\n}\n\nexport function isHostOnDenyList(url: string | URL | Request, options: NetworkRecordOptions) {\n const hostname = hostnameFromURL(url)\n const defaultNotDenied = { hostname, isHostDenied: false }\n\n if (!options.payloadHostDenyList?.length || !hostname?.trim().length) {\n return defaultNotDenied\n }\n\n for (const deny of options.payloadHostDenyList) {\n if (hostname.endsWith(deny)) {\n return { hostname, isHostDenied: true }\n }\n }\n\n return defaultNotDenied\n}\n","import { version } from 'rrweb/package.json'\nimport { getRecordConsolePlugin, record } from 'rrweb'\n\n// rrweb/network@1 code starts\n// most of what is below here will be removed when rrweb release their code for this\n// see https://github.com/rrweb-io/rrweb/pull/1105\n/// <reference lib=\"dom\" />\n// NB adopted from https://github.com/rrweb-io/rrweb/pull/1105 which looks like it will be accepted into rrweb\n// however, in the PR, it throws when the performance observer data is not available\n// and assumes it is running in a browser with the Request API (i.e. not IE11)\n// copying here so that we can use it before rrweb adopt it\nimport type { IWindow, listenerHandler, RecordPlugin } from '@rrweb/types'\nimport { CapturedNetworkRequest, Headers, InitiatorType, NetworkRecordOptions } from '../types'\nimport {\n isArray,\n isBoolean,\n isDocument,\n isFormData,\n isNull,\n isNullish,\n isObject,\n isString,\n isUndefined,\n} from '../utils/type-utils'\nimport { logger } from '../utils/logger'\nimport { assignableWindow } from '../utils/globals'\nimport { defaultNetworkOptions } from '../extensions/replay/config'\nimport { formDataToQuery } from '../utils/request-utils'\nimport { patch } from '../extensions/replay/rrweb-plugins/patch'\nimport { isHostOnDenyList } from '../extensions/replay/external/denylist'\n\nexport type NetworkData = {\n requests: CapturedNetworkRequest[]\n isInitial?: boolean\n}\n\ntype networkCallback = (data: NetworkData) => void\n\nconst isNavigationTiming = (entry: PerformanceEntry): entry is PerformanceNavigationTiming =>\n entry.entryType === 'navigation'\nconst isResourceTiming = (entry: PerformanceEntry): entry is PerformanceResourceTiming => entry.entryType === 'resource'\n\ntype ObservedPerformanceEntry = (PerformanceNavigationTiming | PerformanceResourceTiming) & {\n responseStatus?: number\n}\n\nexport function findLast<T>(array: Array<T>, predicate: (value: T) => boolean): T | undefined {\n const length = array.length\n for (let i = length - 1; i >= 0; i -= 1) {\n if (predicate(array[i])) {\n return array[i]\n }\n }\n return undefined\n}\n\nfunction initPerformanceObserver(cb: networkCallback, win: IWindow, options: Required<NetworkRecordOptions>) {\n // if we are only observing timings then we could have a single observer for all types, with buffer true,\n // but we are going to filter by initiatorType _if we are wrapping fetch and xhr as the wrapped functions\n // will deal with those.\n // so we have a block which captures requests from before fetch/xhr is wrapped\n // these are marked `isInitial` so playback can display them differently if needed\n // they will never have method/status/headers/body because they are pre-wrapping that provides that\n if (options.recordInitialRequests) {\n const initialPerformanceEntries = win.performance\n .getEntries()\n .filter(\n (entry): entry is ObservedPerformanceEntry =>\n isNavigationTiming(entry) ||\n (isResourceTiming(entry) && options.initiatorTypes.includes(entry.initiatorType as InitiatorType))\n )\n cb({\n requests: initialPerformanceEntries.flatMap((entry) =>\n prepareRequest({ entry, method: undefined, status: undefined, networkRequest: {}, isInitial: true })\n ),\n isInitial: true,\n })\n }\n const observer = new win.PerformanceObserver((entries) => {\n // if recordBody or recordHeaders is true then we don't want to record fetch or xhr here\n // as the wrapped functions will do that. Otherwise, this filter becomes a noop\n // because we do want to record them here\n const wrappedInitiatorFilter = (entry: ObservedPerformanceEntry) =>\n options.recordBody || options.recordHeaders\n ? entry.initiatorType !== 'xmlhttprequest' && entry.initiatorType !== 'fetch'\n : true\n\n const performanceEntries = entries.getEntries().filter(\n (entry): entry is ObservedPerformanceEntry =>\n isNavigationTiming(entry) ||\n (isResourceTiming(entry) &&\n options.initiatorTypes.includes(entry.initiatorType as InitiatorType) &&\n // TODO if we are _only_ capturing timing we don't want to filter initiator here\n wrappedInitiatorFilter(entry))\n )\n\n cb({\n requests: performanceEntries.flatMap((entry) =>\n prepareRequest({ entry, method: undefined, status: undefined, networkRequest: {} })\n ),\n })\n })\n // compat checked earlier\n // eslint-disable-next-line compat/compat\n const entryTypes = PerformanceObserver.supportedEntryTypes.filter((x) =>\n options.performanceEntryTypeToObserve.includes(x)\n )\n // initial records are gathered above, so we don't need to observe and buffer each type separately\n observer.observe({ entryTypes })\n return () => {\n observer.disconnect()\n }\n}\n\nfunction shouldRecordHeaders(type: 'request' | 'response', recordHeaders: NetworkRecordOptions['recordHeaders']) {\n return !!recordHeaders && (isBoolean(recordHeaders) || recordHeaders[type])\n}\n\nfunction shouldRecordBody({\n type,\n recordBody,\n headers,\n}: {\n type: 'request' | 'response'\n recordBody: NetworkRecordOptions['recordBody']\n headers: Headers\n url: string | URL | RequestInfo\n}) {\n function matchesContentType(contentTypes: string[]) {\n const contentTypeHeader = Object.keys(headers).find((key) => key.toLowerCase() === 'content-type')\n const contentType = contentTypeHeader && headers[contentTypeHeader]\n return contentTypes.some((ct) => contentType?.includes(ct))\n }\n\n if (!recordBody) return false\n if (isBoolean(recordBody)) return true\n if (isArray(recordBody)) return matchesContentType(recordBody)\n const recordBodyType = recordBody[type]\n if (isBoolean(recordBodyType)) return recordBodyType\n return matchesContentType(recordBodyType)\n}\n\nasync function getRequestPerformanceEntry(\n win: IWindow,\n initiatorType: string,\n url: string,\n start?: number,\n end?: number,\n attempt = 0\n): Promise<PerformanceResourceTiming | null> {\n if (attempt > 10) {\n logger.warn('Failed to get performance entry for request', { url, initiatorType })\n return null\n }\n const urlPerformanceEntries = win.performance.getEntriesByName(url) as PerformanceResourceTiming[]\n const performanceEntry = findLast(\n urlPerformanceEntries,\n (entry) =>\n isResourceTiming(entry) &&\n entry.initiatorType === initiatorType &&\n (isUndefined(start) || entry.startTime >= start) &&\n (isUndefined(end) || entry.startTime <= end)\n )\n if (!performanceEntry) {\n await new Promise((resolve) => setTimeout(resolve, 50 * attempt))\n return getRequestPerformanceEntry(win, initiatorType, url, start, end, attempt + 1)\n }\n return performanceEntry\n}\n\n/**\n * According to MDN https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest/response\n * xhr response is typed as any but can be an ArrayBuffer, a Blob, a Document, a JavaScript object,\n * or a string, depending on the value of XMLHttpRequest.responseType, that contains the response entity body.\n *\n * XHR request body is Document | XMLHttpRequestBodyInit | null | undefined\n */\nfunction _tryReadXHRBody({\n body,\n options,\n url,\n}: {\n body: Document | XMLHttpRequestBodyInit | any | null | undefined\n options: NetworkRecordOptions\n url: string | URL | RequestInfo\n}): string | null {\n if (isNullish(body)) {\n return null\n }\n\n const { hostname, isHostDenied } = isHostOnDenyList(url, options)\n if (isHostDenied) {\n return hostname + ' is in deny list'\n }\n\n if (isString(body)) {\n return body\n }\n\n if (isDocument(body)) {\n return body.textContent\n }\n\n if (isFormData(body)) {\n return formDataToQuery(body)\n }\n\n if (isObject(body)) {\n try {\n return JSON.stringify(body)\n } catch {\n return '[SessionReplay] Failed to stringify response object'\n }\n }\n\n return '[SessionReplay] Cannot read body of type ' + toString.call(body)\n}\n\nfunction initXhrObserver(cb: networkCallback, win: IWindow, options: Required<NetworkRecordOptions>): listenerHandler {\n if (!options.initiatorTypes.includes('xmlhttprequest')) {\n return () => {\n //\n }\n }\n const recordRequestHeaders = shouldRecordHeaders('request', options.recordHeaders)\n const recordResponseHeaders = shouldRecordHeaders('response', options.recordHeaders)\n\n const restorePatch = patch(\n win.XMLHttpRequest.prototype,\n 'open',\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n (originalOpen: typeof XMLHttpRequest.prototype.open) => {\n return function (\n method: string,\n url: string | URL,\n async = true,\n username?: string | null,\n password?: string | null\n ) {\n // because this function is returned in its actual context `this` _is_ an XMLHttpRequest\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n const xhr = this as XMLHttpRequest\n\n // check IE earlier than this, we only initialize if Request is present\n // eslint-disable-next-line compat/compat\n const req = new Request(url)\n const networkRequest: Partial<CapturedNetworkRequest> = {}\n let start: number | undefined\n let end: number | undefined\n\n const requestHeaders: Headers = {}\n const originalSetRequestHeader = xhr.setRequestHeader.bind(xhr)\n xhr.setRequestHeader = (header: string, value: string) => {\n requestHeaders[header] = value\n return originalSetRequestHeader(header, value)\n }\n if (recordRequestHeaders) {\n networkRequest.requestHeaders = requestHeaders\n }\n\n const originalSend = xhr.send.bind(xhr)\n xhr.send = (body) => {\n if (\n shouldRecordBody({\n type: 'request',\n headers: requestHeaders,\n url,\n recordBody: options.recordBody,\n })\n ) {\n networkRequest.requestBody = _tryReadXHRBody({ body, options, url })\n }\n start = win.performance.now()\n return originalSend(body)\n }\n\n xhr.addEventListener('readystatechange', () => {\n if (xhr.readyState !== xhr.DONE) {\n return\n }\n end = win.performance.now()\n const responseHeaders: Headers = {}\n const rawHeaders = xhr.getAllResponseHeaders()\n const headers = rawHeaders.trim().split(/[\\r\\n]+/)\n headers.forEach((line) => {\n const parts = line.split(': ')\n const header = parts.shift()\n const value = parts.join(': ')\n if (header) {\n responseHeaders[header] = value\n }\n })\n if (recordResponseHeaders) {\n networkRequest.responseHeaders = responseHeaders\n }\n if (\n shouldRecordBody({\n type: 'response',\n headers: responseHeaders,\n url,\n recordBody: options.recordBody,\n })\n ) {\n networkRequest.responseBody = _tryReadXHRBody({ body: xhr.response, options, url })\n }\n getRequestPerformanceEntry(win, 'xmlhttprequest', req.url, start, end)\n .then((entry) => {\n const requests = prepareRequest({\n entry,\n method: req.method,\n status: xhr?.status,\n networkRequest,\n start,\n end,\n url: url.toString(),\n initiatorType: 'xmlhttprequest',\n })\n cb({ requests })\n })\n .catch(() => {\n //\n })\n })\n originalOpen.call(xhr, method, url, async, username, password)\n }\n }\n )\n return () => {\n restorePatch()\n }\n}\n\n/**\n * Check if this PerformanceEntry is either a PerformanceResourceTiming or a PerformanceNavigationTiming\n * NB PerformanceNavigationTiming extends PerformanceResourceTiming\n * Here we don't care which interface it implements as both expose `serverTimings`\n */\nconst exposesServerTiming = (event: PerformanceEntry | null): event is PerformanceResourceTiming =>\n !isNull(event) && (event.entryType === 'navigation' || event.entryType === 'resource')\n\nfunction prepareRequest({\n entry,\n method,\n status,\n networkRequest,\n isInitial,\n start,\n end,\n url,\n initiatorType,\n}: {\n entry: PerformanceResourceTiming | null\n method: string | undefined\n status: number | undefined\n networkRequest: Partial<CapturedNetworkRequest>\n isInitial?: boolean\n start?: number\n end?: number\n // if there is no performance observer entry, we still need to know the url\n url?: string\n // if there is no performance observer entry, we can provide the initiatorType\n initiatorType?: string\n}): CapturedNetworkRequest[] {\n start = entry ? entry.startTime : start\n end = entry ? entry.responseEnd : end\n\n // kudos to sentry javascript sdk for excellent background on why to use Date.now() here\n // https://github.com/getsentry/sentry-javascript/blob/e856e40b6e71a73252e788cd42b5260f81c9c88e/packages/utils/src/time.ts#L70\n // can't start observer if performance.now() is not available\n // eslint-disable-next-line compat/compat\n const timeOrigin = Math.floor(Date.now() - performance.now())\n // clickhouse can't ingest timestamps that are floats\n // (in this case representing fractions of a millisecond we don't care about anyway)\n // use timeOrigin if we really can't gather a start time\n const timestamp = Math.floor(timeOrigin + (start || 0))\n\n const entryJSON = entry ? entry.toJSON() : { name: url }\n\n const requests: CapturedNetworkRequest[] = [\n {\n ...entryJSON,\n startTime: isUndefined(start) ? undefined : Math.round(start),\n endTime: isUndefined(end) ? undefined : Math.round(end),\n timeOrigin,\n timestamp,\n method: method,\n initiatorType: entry ? (entry.initiatorType as InitiatorType) : initiatorType,\n status,\n requestHeaders: networkRequest.requestHeaders,\n requestBody: networkRequest.requestBody,\n responseHeaders: networkRequest.responseHeaders,\n responseBody: networkRequest.responseBody,\n isInitial,\n },\n ]\n\n if (exposesServerTiming(entry)) {\n for (const timing of entry.serverTiming || []) {\n requests.push({\n timeOrigin,\n timestamp,\n startTime: Math.round(entry.startTime),\n name: timing.name,\n duration: timing.duration,\n // the spec has a closed list of possible types\n // https://developer.mozilla.org/en-US/docs/Web/API/PerformanceEntry/entryType\n // but, we need to know this was a server timing so that we know to\n // match it to the appropriate navigation or resource timing\n // that matching will have to be on timestamp and $current_url\n entryType: 'serverTiming',\n })\n }\n }\n\n return requests\n}\n\nconst contentTypePrefixDenyList = ['video/', 'audio/']\n\nfunction _checkForCannotReadResponseBody({\n r,\n options,\n url,\n}: {\n r: Response\n options: NetworkRecordOptions\n url: string | URL | RequestInfo\n}): string | null {\n if (r.headers.get('Transfer-Encoding') === 'chunked') {\n return 'Chunked Transfer-Encoding is not supported'\n }\n\n // `get` and `has` are case-insensitive\n // but return the header value with the casing that was supplied\n const contentType = r.headers.get('Content-Type')?.toLowerCase()\n const contentTypeIsDenied = contentTypePrefixDenyList.some((prefix) => contentType?.startsWith(prefix))\n if (contentType && contentTypeIsDenied) {\n return `Content-Type ${contentType} is not supported`\n }\n\n const { hostname, isHostDenied } = isHostOnDenyList(url, options)\n if (isHostDenied) {\n return hostname + ' is in deny list'\n }\n\n return null\n}\n\nfunction _tryReadBody(r: Request | Response): Promise<string> {\n // there are now already multiple places where we're using Promise...\n // eslint-disable-next-line compat/compat\n return new Promise((resolve, reject) => {\n const timeout = setTimeout(() => resolve('[SessionReplay] Timeout while trying to read body'), 500)\n try {\n r.clone()\n .text()\n .then(\n (txt) => resolve(txt),\n (reason) => reject(reason)\n )\n .finally(() => clearTimeout(timeout))\n } catch {\n clearTimeout(timeout)\n resolve('[SessionReplay] Failed to read body')\n }\n })\n}\n\nasync function _tryReadRequestBody({\n r,\n options,\n url,\n}: {\n r: Request\n options: NetworkRecordOptions\n url: string | URL | RequestInfo\n}): Promise<string> {\n const { hostname, isHostDenied } = isHostOnDenyList(url, options)\n if (isHostDenied) {\n return Promise.resolve(hostname + ' is in deny list')\n }\n\n return _tryReadBody(r)\n}\n\nasync function _tryReadResponseBody({\n r,\n options,\n url,\n}: {\n r: Response\n options: NetworkRecordOptions\n url: string | URL | RequestInfo\n}): Promise<string> {\n const cannotReadBodyReason: string | null = _checkForCannotReadResponseBody({ r, options, url })\n if (!isNull(cannotReadBodyReason)) {\n return Promise.resolve(cannotReadBodyReason)\n }\n\n return _tryReadBody(r)\n}\n\nfunction initFetchObserver(\n cb: networkCallback,\n win: IWindow,\n options: Required<NetworkRecordOptions>\n): listenerHandler {\n if (!options.initiatorTypes.includes('fetch')) {\n return () => {\n //\n }\n }\n const recordRequestHeaders = shouldRecordHeaders('request', options.recordHeaders)\n const recordResponseHeaders = shouldRecordHeaders('response', options.recordHeaders)\n\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n const restorePatch = patch(win, 'fetch', (originalFetch: typeof fetch) => {\n return async function (url: URL | RequestInfo, init?: RequestInit | undefined) {\n // check IE earlier than this, we only initialize if Request is present\n // eslint-disable-next-line compat/compat\n const req = new Request(url, init)\n let res: Response | undefined\n const networkRequest: Partial<CapturedNetworkRequest> = {}\n let start: number | undefined\n let end: number | undefined\n\n try {\n const requestHeaders: Headers = {}\n req.headers.forEach((value, header) => {\n requestHeaders[header] = value\n })\n if (recordRequestHeaders) {\n networkRequest.requestHeaders = requestHeaders\n }\n if (\n shouldRecordBody({\n type: 'request',\n headers: requestHeaders,\n url,\n recordBody: options.recordBody,\n })\n ) {\n networkRequest.requestBody = await _tryReadRequestBody({ r: req, options, url })\n }\n\n start = win.performance.now()\n res = await originalFetch(req)\n end = win.performance.now()\n\n const responseHeaders: Headers = {}\n res.headers.forEach((value, header) => {\n responseHeaders[header] = value\n })\n if (recordResponseHeaders) {\n networkRequest.responseHeaders = responseHeaders\n }\n if (\n shouldRecordBody({\n type: 'response',\n headers: responseHeaders,\n url,\n recordBody: options.recordBody,\n })\n ) {\n networkRequest.responseBody = await _tryReadResponseBody({ r: res, options, url })\n }\n\n return res\n } finally {\n getRequestPerformanceEntry(win, 'fetch', req.url, start, end)\n .then((entry) => {\n const requests = prepareRequest({\n entry,\n method: req.method,\n status: res?.status,\n networkRequest,\n start,\n end,\n url: req.url,\n initiatorType: 'fetch',\n })\n cb({ requests })\n })\n .catch(() => {\n //\n })\n }\n }\n })\n return () => {\n restorePatch()\n }\n}\n\nlet initialisedHandler: listenerHandler | null = null\n\nfunction initNetworkObserver(\n callback: networkCallback,\n win: IWindow, // top window or in an iframe\n options: NetworkRecordOptions\n): listenerHandler {\n if (!('performance' in win)) {\n return () => {\n //\n }\n }\n\n if (initialisedHandler) {\n logger.warn('Network observer already initialised, doing nothing')\n return () => {\n // the first caller should already have this handler and will be responsible for teardown\n }\n }\n\n const networkOptions = (\n options ? Object.assign({}, defaultNetworkOptions, options) : defaultNetworkOptions\n ) as Required<NetworkRecordOptions>\n\n const cb: networkCallback = (data) => {\n const requests: CapturedNetworkRequest[] = []\n data.requests.forEach((request) => {\n const maskedRequest = networkOptions.maskRequestFn(request)\n if (maskedRequest) {\n requests.push(maskedRequest)\n }\n })\n\n if (requests.length > 0) {\n callback({ ...data, requests })\n }\n }\n const performanceObserver = initPerformanceObserver(cb, win, networkOptions)\n\n // only wrap fetch and xhr if headers or body are being recorded\n let xhrObserver: listenerHandler = () => {}\n let fetchObserver: listenerHandler = () => {}\n if (networkOptions.recordHeaders || networkOptions.recordBody) {\n xhrObserver = initXhrObserver(cb, win, networkOptions)\n fetchObserver = initFetchObserver(cb, win, networkOptions)\n }\n\n initialisedHandler = () => {\n performanceObserver()\n xhrObserver()\n fetchObserver()\n }\n return initialisedHandler\n}\n\n// use the plugin name so that when this functionality is adopted into rrweb\n// we can remove this plugin and use the core functionality with the same data\nexport const NETWORK_PLUGIN_NAME = 'rrweb/network@1'\n\n// TODO how should this be typed?\n// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-ignore\nexport const getRecordNetworkPlugin: (options?: NetworkRecordOptions) => RecordPlugin = (options) => {\n return {\n name: NETWORK_PLUGIN_NAME,\n observer: initNetworkObserver,\n options: options,\n }\n}\n\n// rrweb/networ@1 ends\n\nassignableWindow.__PosthogExtensions__ = assignableWindow.__PosthogExtensions__ || {}\nassignableWindow.__PosthogExtensions__.rrwebPlugins = { getRecordConsolePlugin, getRecordNetworkPlugin }\nassignableWindow.__PosthogExtensions__.rrweb = { record: record, version: 'v2', rrwebVersion: version }\n\n// we used to put all of these items directly on window, and now we put it on __PosthogExtensions__\n// but that means that old clients which lazily load this extension are looking in the wrong place\n// yuck,\n// so we also put them directly on the window\n// when 1.161.1 is the oldest version seen in production we can remove this\nassignableWindow.rrweb = { record: record, version: 'v2', rrwebVersion: version }\nassignableWindow.rrwebConsoleRecord = { getRecordConsolePlugin }\nassignableWindow.getRecordNetworkPlugin = getRecordNetworkPlugin\n\nexport default record\n"],"names":["NodeType","isShadowRoot","n","host","Boolean","shadowRoot","isNativeShadowDom","Object","prototype","toString","call","stringifyStylesheet","s","rules","cssRules","cssText","Array","from","map","stringifyRule","join","includes","replace","error","rule","importStringified","isCSSImportRule","styleSheet","split","length","statement","JSON","stringify","href","layerName","push","supportsText","media","mediaText","escapeImportStatement","isCSSStyleRule","selectorText","cssStringified","regex","fixSafariColons","Mirror","constructor","this","idNodeMap","Map","nodeMetaMap","WeakMap","getId","_a","id","getMeta","getNode","get","getIds","keys","removeNodeFromMap","delete","childNodes","forEach","childNode","has","hasNode","node","add","meta","set","oldNode","reset","maskInputValue","_ref","element","maskInputOptions","tagName","type","value","maskInputFn","text","actualType","toLowerCase","repeat","str","ORIGINAL_ATTRIBUTE_NAME","getInputType","hasAttribute","extractFileExtension","path","baseURL","url","URL","window","location","err","match","pathname","_id","tagNameRegex","RegExp","IGNORED_NODE","genId","canvasService","canvasCtx","URL_IN_CSS_REF","URL_PROTOCOL_MATCH","URL_WWW_MATCH","DATA_URI","absoluteToStylesheet","origin","quote1","path1","quote2","path2","path3","filePath","maybeQuote","test","indexOf","slice","extractOrigin","stack","parts","pop","part","SRCSET_NOT_SPACES","SRCSET_COMMAS_OR_SPACES","absoluteToDoc","doc","attributeValue","trim","a","createElement","isSVGElement","el","ownerSVGElement","getHref","document","transformAttribute","name","pos","collectCharacters","regEx","chars","exec","substring","output","descriptorsStr","inParens","c","charAt","getAbsoluteSrcsetString","ignoreAttribute","startsWith","classMatchesRegex","checkAncestors","nodeType","ELEMENT_NODE","parentNode","eIndex","classList","className","needMaskingText","maskTextClass","maskTextSelector","parentElement","closest","contains","matches","e","serializeNode","options","mirror","blockClass","blockSelector","needsMask","inlineStylesheet","maskTextFn","dataURLOptions","inlineImages","recordCanvas","keepIframeSrcFn","newlyAddedElement","rootId","docId","undefined","getRootId","DOCUMENT_NODE","compatMode","Document","DOCUMENT_TYPE_NODE","DocumentType","publicId","systemId","needBlock","_isBlockedElement","HTMLFormElement","processedTagName","getValidTagName","attributes","len","i","attr","stylesheet","styleSheets","find","potentialStylesheetHref","rel","_cssText","sheet","innerText","textContent","checked","selected","__context","canvas","ctx","getContext","x","width","y","height","getImageData","originalGetImageData","Uint32Array","Math","min","data","buffer","some","pixel","is2DCanvasBlank","rr_dataURL","toDataURL","quality","canvasDataURL","blankCanvas","image","oldValue","crossOrigin","recordInlineImage","removeEventListener","naturalWidth","naturalHeight","drawImage","console","warn","currentSrc","removeAttribute","complete","addEventListener","mediaAttributes","rr_mediaState","paused","rr_mediaCurrentTime","currentTime","rr_mediaPlaybackRate","playbackRate","rr_mediaMuted","muted","rr_mediaLoop","loop","rr_mediaVolume","volume","scrollLeft","rr_scrollLeft","scrollTop","rr_scrollTop","getBoundingClientRect","class","rr_width","rr_height","src","contentDocument","rr_src","isCustomElement","customElements","Element","isSVG","isCustom","serializeElementNode","TEXT_NODE","parentTagName","isStyle","isScript","nextSibling","previousSibling","Text","serializeTextNode","CDATA_SECTION_NODE","CDATA","COMMENT_NODE","Comment","lowerIfExists","maybeAttr","serializeNodeWithId","skipChild","slimDOMOptions","onSerialize","onIframeLoad","iframeLoadTimeout","onStylesheetLoad","stylesheetLoadTimeout","preserveWhiteSpace","_serializedNode","sn","comment","script","as","headFavicon","headMetaDescKeywords","headMetaSocial","property","headMetaRobots","headMetaHttpEquiv","headMetaAuthorship","headMetaVerification","slimDOMExcluded","serializedNode","assign","recordChild","isShadowHost","headWhitespace","bypassOptions","childN","serializedChildNode","isElement","isShadow","iframeEl","listener","win","contentWindow","readyState","fired","timer","setTimeout","clearTimeout","blankUrl","onceIframeLoaded","iframeDoc","serializedIframeNode","link","styleSheetLoadTimeout","styleSheetLoaded","onceStylesheetLoaded","serializedLinkNode","on","fn","target","arguments","capture","passive","DEPARTED_MIRROR_ACCESS_WARNING","_mirror","throttle","func","wait","timeout","previous","_len","args","_key","now","Date","leading","remaining","context","apply","trailing","hookSetter","key","d","isRevoked","original","getOwnPropertyDescriptor","defineProperty","patch","source","replacement","wrapped","defineProperties","__rrweb_original__","enumerable","Proxy","Reflect","prop","receiver","nowTimestamp","getWindowScroll","_b","_c","_d","_e","_f","left","scrollingElement","pageXOffset","documentElement","body","top","pageYOffset","getWindowHeight","innerHeight","clientHeight","getWindowWidth","innerWidth","clientWidth","closestElementOfNode","isBlocked","isIgnored","isAncestorRemoved","legacy_isTouchEvent","event","changedTouches","isSerializedIframe","nodeName","isSerializedStylesheet","getAttribute","hasShadowRoot","getTime","StyleSheetMirror","styleIDMap","idStyleMap","newId","getStyle","generateId","getShadowHost","shadowHost","getRootNode","Node","DOCUMENT_FRAGMENT_NODE","shadowHostInDom","ownerDocument","rootShadowHost","getRootShadowHost","inDom","EventType","EventType2","IncrementalSource","IncrementalSource2","MouseInteractions","MouseInteractions2","PointerTypes","PointerTypes2","CanvasContext","CanvasContext2","isNodeInLinkedList","DoubleLinkedList","head","tail","position","Error","current","index","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","iframe","childSn","attachIframe","observeAttachShadow","attachLinkElement","shift","isParentRemoved","isAncestorInSet","candidate","tailNode","_node","unhandledNode","payload","genTextAreaValueMutation","filter","attribute","style","diffAsStr","styleDiff","unchangedAsStr","_unchangedStyles","mutationCb","textarea","item","cn","m","attributeName","setAttribute","unattachedDoc","implementation","createHTMLDocument","old","pname","newValue","getPropertyValue","newPriority","getPropertyPriority","addedNodes","genAdds","removedNodes","nodeId","isSerialized","deepDelete","processedNodeManager","inOtherBuffer","targetId","init","freeze","canvasManager","unfreeze","isFrozen","lock","unlock","addsSet","_isParentRemoved","r","size","_isAncestorInSet","errorHandler","registerErrorHandler","handler","unregisterErrorHandler","callbackWrapper","cb","mutationBuffers","getEventTarget","composedPath","initMutationObserver","rootEl","mutationBuffer","mutationObserverCtor","MutationObserver","__rrMutationObserver","angularZoneSymbol","Zone","__symbol__","observer","bind","observe","attributeOldValue","characterData","characterDataOldValue","childList","subtree","initMouseInteractionObserver","_ref2","mouseInteractionCb","sampling","mouseInteraction","disableMap","handlers","currentPointerType","Number","isNaN","endsWith","eventKey","eventName","pointerType","thisEventKey","Mouse","Touch","Pen","MouseDown","MouseUp","Click","clientX","clientY","getHandler","PointerEvent","TouchStart","TouchEnd","h","initScrollObserver","_ref3","scrollCb","evt","defaultView","scrollLeftTop","scroll","INPUT_TAGS","lastInputValueMap","getNestedCSSRulePositions","childRule","hasNestedCSSRule","parentRule","CSSGroupingRule","CSSMediaRule","CSSSupportsRule","CSSConditionRule","unshift","parentStyleSheet","recurse","getIdAndStyleId","styleMirror","styleId","ownerNode","initAdoptedStyleSheetObserver","_ref11","hostId","patchTarget","ShadowRoot","originalPropertyDescriptor","configurable","sheets","result","adoptStyleSheets","initObservers","o","hooks","currentWindow","mutationObserver","mousemoveCb","viewportResizeCb","inputCb","mediaInteractionCb","styleSheetRuleCb","styleDeclarationCb","canvasMutationCb","fontCb","selectionCb","customElementCb","mutation","mousemove","viewportResize","input","mediaInteaction","styleSheetRule","styleDeclaration","canvasMutation","font","selection","customElement","mergeHooks","recordDOM","mousemoveHandler","threshold","callbackThreshold","mousemoveCallback","timeBaseline","positions","wrappedCb","totalOffset","p","timeOffset","updatePosition","DragEvent","Drag","MouseEvent","MouseMove","TouchMove","initMoveObserver","mouseInteractionHandler","scrollHandler","viewportResizeHandler","_ref4","_ref5","lastH","lastW","initViewportResizeObserver","inputHandler","_ref6","ignoreClass","ignoreSelector","userTriggeredOnInput","eventHandler","userTriggered","isTrusted","isChecked","cbWithDedup","querySelectorAll","v","lastInputValue","propertyDescriptor","HTMLInputElement","hookProperties","HTMLSelectElement","HTMLTextAreaElement","HTMLOptionElement","initInputObserver","mediaInteractionHandler","_ref14","initMediaInteractionObserver","styleSheetObserver","adoptedStyleSheetObserver","styleDeclarationObserver","fontObserver","_ref7","_ref8","CSSStyleSheet","insertRule","thisArg","argumentsList","deleteRule","replaceSync","supportedNestedCSSRuleTypes","canMonkeyPatchNestedCSSRule","unmodifiedFunctions","entries","_ref9","typeKey","_ref10","initStyleSheetObserver","_ref12","_ref13","ignoreCSSAttributes","setProperty","CSSStyleDeclaration","priority","removeProperty","remove","initStyleDeclarationObserver","collectFonts","_ref15","fontMap","originalFontFace","FontFace","family","descriptors","fontFace","fontSource","Uint8Array","restoreHandler","fonts","initFontObserver","selectionObserver","param","collapsed","updateSelection","getSelection","isCollapsed","ranges","count","rangeCount","range","getRangeAt","startContainer","startOffset","endContainer","endOffset","start","end","initSelectionObserver","customElementObserver","_ref16","define","initCustomElementObserver","pluginHandlers","plugin","plugins","callback","b","disconnect","CrossOriginIframeMirror","generateIdFn","iframeIdToRemoteIdMap","iframeRemoteIdToIdMap","remoteId","idToRemoteMap","remoteToIdMap","idToRemoteIdMap","getIdToRemoteIdMap","remoteIdToIdMap","getRemoteIdToIdMap","getRemoteId","getRemoteIds","ids","IframeManager","iframes","crossOriginIframeMap","crossOriginIframeMirror","crossOriginIframeRootIdMap","wrappedEmit","recordCrossOriginIframes","crossOriginIframeStyleMirror","handleMessage","addLoadListener","loadListener","isAttachIframe","adoptedStyleSheets","message","crossOriginMessageEvent","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","styles","iframeMirror","obj","isArray","child","ShadowDomManager","shadowDoms","WeakSet","restoreHandlers","patchAttachShadow","iframeElement","manager","option","__awaiter","_arguments","P","generator","Promise","resolve","reject","fulfilled","step","rejected","done","then","lookup","charCodeAt","canvasVarMap","saveWebGLVar","isInstanceOfWebGLObject","list","ctor","contextMap","variableListFor","serializeArg","arg","Float32Array","Float64Array","Int32Array","Uint16Array","Int16Array","Int8Array","Uint8ClampedArray","rr_type","values","ArrayBuffer","base64","arraybuffer","bytes","encode","DataView","byteOffset","byteLength","HTMLImageElement","HTMLCanvasElement","ImageData","serializeArgs","supportedWebGLConstructorNames","initCanvasContextObserver","setPreserveDrawingBufferToTrue","contextType","ctxName","getNormalizedContextName","contextAttributes","preserveDrawingBuffer","splice","patchGLPrototype","props","getOwnPropertyNames","recordArgs","hookHandler","setter","createURL","sourcemapArg","enableUnicodeArg","sourcemap","enableUnicode","binaryString","atob","binaryView","String","fromCharCode","decodeBase64","blob","Blob","createObjectURL","WorkerFactory","Worker","CanvasManager","pendingCanvasMutations","clear","resetObservers","rafStamps","latestId","invokeId","initCanvasMutationObserver","initCanvasFPSObserver","fps","canvasContextReset","snapshotInProgressMap","worker","onmessage","commands","timeBetweenSnapshots","rafId","lastSnapshotTime","takeCanvasSnapshots","getCanvas","matchedCanvas","searchCanvas","root","elem","getContextAttributes","COLOR_BUFFER_BIT","bitmap","createImageBitmap","resizeWidth","resizeHeight","postMessage","requestAnimationFrame","cancelAnimationFrame","startRAFTimestamping","startPendingCanvasMutationFlusher","canvas2DReset","props2D","CanvasRenderingContext2D","initCanvas2DMutationObserver","canvasWebGL1and2Reset","WebGLRenderingContext","WebGL","WebGL2RenderingContext","WebGL2","initCanvasWebGLMutationObserver","flushPendingCanvasMutations","setLatestRAFTimestamp","flushPendingCanvasMutationFor","valuesWithType","rest","t","hasOwnProperty","getOwnPropertySymbols","propertyIsEnumerable","__rest","StylesheetManager","trackedLinkElements","adoptedStyleSheetCb","linkEl","trackStylesheetInLinkElement","adoptedStyleSheetData","styleIds","CSSRule","ProcessedNodeManager","nodeMap","periodicallyClear","thisBuffer","buffers","destroy","wrapEvent","takeFullSnapshot","recording","record","checkoutEveryNms","checkoutEveryNth","maskAllInputs","_maskInputOptions","_slimDOMOptions","packFn","mousemoveWait","recordAfter","inEmittingFrame","parent","passEmitsToParent","color","date","email","month","number","search","tel","time","week","select","password","lastFullSnapshotEvent","_this","NodeList","DOMTokenList","_len2","_key2","TypeError","polyfill","incrementalSnapshotCount","eventProcessor","buf","exceedCount","exceedTime","wrappedMutationEmit","wrappedScrollEmit","wrappedCanvasMutationEmit","getMirror","nodeMirror","slimDOM","snapshot","initialOffset","CustomElement","addCustomEvent","tag","freezePage","StackFrame","fileName","functionName","lineNumber","columnNumber","FIREFOX_SAFARI_STACK_REGEXP","CHROME_IE_STACK_REGEXP","SAFARI_NATIVE_CODE_REGEXP","ErrorStackParser","parse","stacktrace","parseOpera","parseV8OrIE","parseFFOrSafari","extractLocation","urlLike","line","sanitizedLine","tokens","locationParts","functionNameRegex","parseOpera9","parseOpera11","parseOpera10","lineRE","lines","parseFloat","pathToSelector","outerHTML","localName","domSiblings","children","sibling","isObject","isObjTooDeep","limit","stringifyOptions","numOfKeysLimit","depthOfLimit","thisPos","Infinity","_obj","shouldIgnore","stringLengthLimit","Event","eventResult","eventValue","HTMLElement","defaultLogOptions","level","lengthThreshold","logger","initLogObserver","logOptions","loggerType","logCount","inStack","cancelHandlers","trace","stackFrame","unhandledrejectionHandler","reason","levelType","_logger","getRecordConsolePlugin","nativeIsArray","ObjProto","isFunction","f","isUndefined","isString","isNull","isNullish","isBoolean","isDocument","isFormData","FormData","global","globalThis","nativeForEach","navigator","fetch","XMLHttpRequest","AbortController","userAgent","assignableWindow","LOGGER_PREFIX","_log","consoleLog","info","_len3","_key3","_len4","_key4","critical","_len5","_key5","uninitializedWarning","methodName","breaker","each","iterator","l","eachArray","pair","formDataToQuery","formdata","use_val","use_key","arg_separator","tph_arr","val","encodeURIComponent","File","defaultNetworkOptions","initiatorTypes","maskRequestFn","recordHeaders","recordBody","recordInitialRequests","recordPerformance","performanceEntryTypeToObserve","payloadSizeLimitBytes","payloadHostDenyList","__posthog_wrapped__","isHostOnDenyList","_options$payloadHostD","hostname","hostnameFromURL","defaultNotDenied","isHostDenied","deny","isNavigationTiming","entry","entryType","isResourceTiming","findLast","array","predicate","initPerformanceObserver","initialPerformanceEntries","performance","getEntries","initiatorType","requests","flatMap","prepareRequest","method","status","networkRequest","isInitial","PerformanceObserver","performanceEntries","wrappedInitiatorFilter","entryTypes","supportedEntryTypes","shouldRecordHeaders","shouldRecordBody","headers","matchesContentType","contentTypes","contentTypeHeader","contentType","ct","recordBodyType","async","getRequestPerformanceEntry","attempt","performanceEntry","getEntriesByName","startTime","_tryReadXHRBody","exposesServerTiming","responseEnd","timeOrigin","floor","toJSON","round","endTime","requestHeaders","requestBody","responseHeaders","responseBody","timing","serverTiming","duration","contentTypePrefixDenyList","_tryReadBody","clone","txt","finally","_tryReadResponseBody","cannotReadBodyReason","_r$headers$get","contentTypeIsDenied","prefix","_checkForCannotReadResponseBody","initFetchObserver","recordRequestHeaders","recordResponseHeaders","restorePatch","originalFetch","req","Request","res","header","_tryReadRequestBody","_res","catch","initialisedHandler","initNetworkObserver","networkOptions","request","maskedRequest","performanceObserver","xhrObserver","fetchObserver","originalOpen","username","xhr","originalSetRequestHeader","setRequestHeader","originalSend","send","DONE","getAllResponseHeaders","response","initXhrObserver","NETWORK_PLUGIN_NAME","getRecordNetworkPlugin","__PosthogExtensions__","rrwebPlugins","rrweb","version","rrwebVersion","rrwebConsoleRecord"],"mappings":"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","x_google_ignoreList":[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23]}
|
|
1
|
+
{"version":3,"file":"recorder-v2.js","sources":["../node_modules/.pnpm/rrweb@2.0.0-alpha.16_patch_hash=x52pllmg6k5suqkcoa7bdybazq/node_modules/rrweb/dist/rrweb.js","../node_modules/.pnpm/@rrweb+rrweb-plugin-console-record@2.0.0-alpha.15_rrweb@2.0.0-alpha.16/node_modules/@rrweb/rrweb-plugin-console-record/dist/rrweb-plugin-console-record.js","../src/utils/type-utils.ts","../src/utils/globals.ts","../src/utils/logger.ts","../src/utils/index.ts","../src/utils/request-utils.ts","../src/extensions/replay/config.ts","../src/extensions/replay/rrweb-plugins/patch.ts","../src/extensions/replay/external/denylist.ts","../src/entrypoints/recorder.ts"],"sourcesContent":["var __defProp = Object.defineProperty;\nvar __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== \"symbol\" ? key + \"\" : key, value);\nvar _a;\nvar __defProp$1 = Object.defineProperty;\nvar __defNormalProp$1 = (obj, key, value) => key in obj ? __defProp$1(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __publicField$1 = (obj, key, value) => __defNormalProp$1(obj, typeof key !== \"symbol\" ? key + \"\" : key, value);\nvar NodeType$2 = /* @__PURE__ */ ((NodeType2) => {\n NodeType2[NodeType2[\"Document\"] = 0] = \"Document\";\n NodeType2[NodeType2[\"DocumentType\"] = 1] = \"DocumentType\";\n NodeType2[NodeType2[\"Element\"] = 2] = \"Element\";\n NodeType2[NodeType2[\"Text\"] = 3] = \"Text\";\n NodeType2[NodeType2[\"CDATA\"] = 4] = \"CDATA\";\n NodeType2[NodeType2[\"Comment\"] = 5] = \"Comment\";\n return NodeType2;\n})(NodeType$2 || {});\nfunction isElement(n2) {\n return n2.nodeType === n2.ELEMENT_NODE;\n}\nfunction isShadowRoot(n2) {\n const host = n2 == null ? void 0 : n2.host;\n return Boolean((host == null ? void 0 : host.shadowRoot) === n2);\n}\nfunction isNativeShadowDom(shadowRoot) {\n return Object.prototype.toString.call(shadowRoot) === \"[object ShadowRoot]\";\n}\nfunction fixBrowserCompatibilityIssuesInCSS(cssText) {\n if (cssText.includes(\" background-clip: text;\") && !cssText.includes(\" -webkit-background-clip: text;\")) {\n cssText = cssText.replace(\n /\\sbackground-clip:\\s*text;/g,\n \" -webkit-background-clip: text; background-clip: text;\"\n );\n }\n return cssText;\n}\nfunction escapeImportStatement(rule) {\n const { cssText } = rule;\n if (cssText.split('\"').length < 3) return cssText;\n const statement = [\"@import\", `url(${JSON.stringify(rule.href)})`];\n if (rule.layerName === \"\") {\n statement.push(`layer`);\n } else if (rule.layerName) {\n statement.push(`layer(${rule.layerName})`);\n }\n if (rule.supportsText) {\n statement.push(`supports(${rule.supportsText})`);\n }\n if (rule.media.length) {\n statement.push(rule.media.mediaText);\n }\n return statement.join(\" \") + \";\";\n}\nfunction stringifyStylesheet(s2) {\n try {\n const rules2 = s2.rules || s2.cssRules;\n return rules2 ? fixBrowserCompatibilityIssuesInCSS(\n Array.from(rules2, stringifyRule).join(\"\")\n ) : null;\n } catch (error) {\n return null;\n }\n}\nfunction stringifyRule(rule) {\n let importStringified;\n if (isCSSImportRule(rule)) {\n try {\n importStringified = // for same-origin stylesheets,\n // we can access the imported stylesheet rules directly\n stringifyStylesheet(rule.styleSheet) || // work around browser issues with the raw string `@import url(...)` statement\n escapeImportStatement(rule);\n } catch (error) {\n }\n } else if (isCSSStyleRule(rule) && rule.selectorText.includes(\":\")) {\n return fixSafariColons(rule.cssText);\n }\n return importStringified || rule.cssText;\n}\nfunction fixSafariColons(cssStringified) {\n const regex = /(\\[(?:[\\w-]+)[^\\\\])(:(?:[\\w-]+)\\])/gm;\n return cssStringified.replace(regex, \"$1\\\\$2\");\n}\nfunction isCSSImportRule(rule) {\n return \"styleSheet\" in rule;\n}\nfunction isCSSStyleRule(rule) {\n return \"selectorText\" in rule;\n}\nfunction findStylesheet(doc, href) {\n return Array.from(doc.styleSheets).find((s) => s.href === href);\n}\nclass Mirror {\n constructor() {\n __publicField$1(this, \"idNodeMap\", /* @__PURE__ */ new Map());\n __publicField$1(this, \"nodeMetaMap\", /* @__PURE__ */ new WeakMap());\n }\n getId(n2) {\n var _a2;\n if (!n2) return -1;\n const id = (_a2 = this.getMeta(n2)) == null ? void 0 : _a2.id;\n return id ?? -1;\n }\n getNode(id) {\n return this.idNodeMap.get(id) || null;\n }\n getIds() {\n return Array.from(this.idNodeMap.keys());\n }\n getMeta(n2) {\n return this.nodeMetaMap.get(n2) || null;\n }\n // removes the node from idNodeMap\n // doesn't remove the node from nodeMetaMap\n removeNodeFromMap(n2) {\n const id = this.getId(n2);\n this.idNodeMap.delete(id);\n if (n2.childNodes) {\n n2.childNodes.forEach(\n (childNode) => this.removeNodeFromMap(childNode)\n );\n }\n }\n has(id) {\n return this.idNodeMap.has(id);\n }\n hasNode(node) {\n return this.nodeMetaMap.has(node);\n }\n add(n2, meta) {\n const id = meta.id;\n this.idNodeMap.set(id, n2);\n this.nodeMetaMap.set(n2, meta);\n }\n replace(id, n2) {\n const oldNode = this.getNode(id);\n if (oldNode) {\n const meta = this.nodeMetaMap.get(oldNode);\n if (meta) this.nodeMetaMap.set(n2, meta);\n }\n this.idNodeMap.set(id, n2);\n }\n reset() {\n this.idNodeMap = /* @__PURE__ */ new Map();\n this.nodeMetaMap = /* @__PURE__ */ new WeakMap();\n }\n}\nfunction createMirror$2() {\n return new Mirror();\n}\nfunction maskInputValue({\n element,\n maskInputOptions,\n tagName,\n type,\n value,\n maskInputFn\n}) {\n let text = value || \"\";\n const actualType = type && toLowerCase(type);\n if (maskInputOptions[tagName.toLowerCase()] || actualType && maskInputOptions[actualType]) {\n if (maskInputFn) {\n text = maskInputFn(text, element);\n } else {\n text = \"*\".repeat(text.length);\n }\n }\n return text;\n}\nfunction toLowerCase(str) {\n return str.toLowerCase();\n}\nconst ORIGINAL_ATTRIBUTE_NAME = \"__rrweb_original__\";\nfunction is2DCanvasBlank(canvas) {\n const ctx = canvas.getContext(\"2d\");\n if (!ctx) return true;\n const chunkSize = 50;\n for (let x = 0; x < canvas.width; x += chunkSize) {\n for (let y = 0; y < canvas.height; y += chunkSize) {\n const getImageData = ctx.getImageData;\n const originalGetImageData = ORIGINAL_ATTRIBUTE_NAME in getImageData ? getImageData[ORIGINAL_ATTRIBUTE_NAME] : getImageData;\n const pixelBuffer = new Uint32Array(\n // eslint-disable-next-line @typescript-eslint/no-unsafe-argument, @typescript-eslint/no-unsafe-member-access\n originalGetImageData.call(\n ctx,\n x,\n y,\n Math.min(chunkSize, canvas.width - x),\n Math.min(chunkSize, canvas.height - y)\n ).data.buffer\n );\n if (pixelBuffer.some((pixel) => pixel !== 0)) return false;\n }\n }\n return true;\n}\nfunction isNodeMetaEqual(a2, b) {\n if (!a2 || !b || a2.type !== b.type) return false;\n if (a2.type === NodeType$2.Document)\n return a2.compatMode === b.compatMode;\n else if (a2.type === NodeType$2.DocumentType)\n return a2.name === b.name && a2.publicId === b.publicId && a2.systemId === b.systemId;\n else if (a2.type === NodeType$2.Comment || a2.type === NodeType$2.Text || a2.type === NodeType$2.CDATA)\n return a2.textContent === b.textContent;\n else if (a2.type === NodeType$2.Element)\n return a2.tagName === b.tagName && JSON.stringify(a2.attributes) === JSON.stringify(b.attributes) && a2.isSVG === b.isSVG && a2.needBlock === b.needBlock;\n return false;\n}\nfunction getInputType(element) {\n const type = element.type;\n return element.hasAttribute(\"data-rr-is-password\") ? \"password\" : type ? (\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion\n toLowerCase(type)\n ) : null;\n}\nfunction extractFileExtension(path, baseURL) {\n let url;\n try {\n url = new URL(path, baseURL ?? window.location.href);\n } catch (err) {\n return null;\n }\n const regex = /\\.([0-9a-z]+)(?:$)/i;\n const match = url.pathname.match(regex);\n return (match == null ? void 0 : match[1]) ?? null;\n}\nlet _id = 1;\nconst tagNameRegex = new RegExp(\"[^a-z0-9-_:]\");\nconst IGNORED_NODE = -2;\nfunction genId() {\n return _id++;\n}\nfunction getValidTagName$1(element) {\n if (element instanceof HTMLFormElement) {\n return \"form\";\n }\n const processedTagName = toLowerCase(element.tagName);\n if (tagNameRegex.test(processedTagName)) {\n return \"div\";\n }\n return processedTagName;\n}\nfunction extractOrigin(url) {\n let origin = \"\";\n if (url.indexOf(\"//\") > -1) {\n origin = url.split(\"/\").slice(0, 3).join(\"/\");\n } else {\n origin = url.split(\"/\")[0];\n }\n origin = origin.split(\"?\")[0];\n return origin;\n}\nlet canvasService;\nlet canvasCtx;\nconst URL_IN_CSS_REF = /url\\((?:(')([^']*)'|(\")(.*?)\"|([^)]*))\\)/gm;\nconst URL_PROTOCOL_MATCH = /^(?:[a-z+]+:)?\\/\\//i;\nconst URL_WWW_MATCH = /^www\\..*/i;\nconst DATA_URI = /^(data:)([^,]*),(.*)/i;\nfunction absoluteToStylesheet(cssText, href) {\n return (cssText || \"\").replace(\n URL_IN_CSS_REF,\n (origin, quote1, path1, quote2, path2, path3) => {\n const filePath = path1 || path2 || path3;\n const maybeQuote = quote1 || quote2 || \"\";\n if (!filePath) {\n return origin;\n }\n if (URL_PROTOCOL_MATCH.test(filePath) || URL_WWW_MATCH.test(filePath)) {\n return `url(${maybeQuote}${filePath}${maybeQuote})`;\n }\n if (DATA_URI.test(filePath)) {\n return `url(${maybeQuote}${filePath}${maybeQuote})`;\n }\n if (filePath[0] === \"/\") {\n return `url(${maybeQuote}${extractOrigin(href) + filePath}${maybeQuote})`;\n }\n const stack = href.split(\"/\");\n const parts = filePath.split(\"/\");\n stack.pop();\n for (const part of parts) {\n if (part === \".\") {\n continue;\n } else if (part === \"..\") {\n stack.pop();\n } else {\n stack.push(part);\n }\n }\n return `url(${maybeQuote}${stack.join(\"/\")}${maybeQuote})`;\n }\n );\n}\nconst SRCSET_NOT_SPACES = /^[^ \\t\\n\\r\\u000c]+/;\nconst SRCSET_COMMAS_OR_SPACES = /^[, \\t\\n\\r\\u000c]+/;\nfunction getAbsoluteSrcsetString(doc, attributeValue) {\n if (attributeValue.trim() === \"\") {\n return attributeValue;\n }\n let pos = 0;\n function collectCharacters(regEx) {\n let chars2;\n const match = regEx.exec(attributeValue.substring(pos));\n if (match) {\n chars2 = match[0];\n pos += chars2.length;\n return chars2;\n }\n return \"\";\n }\n const output = [];\n while (true) {\n collectCharacters(SRCSET_COMMAS_OR_SPACES);\n if (pos >= attributeValue.length) {\n break;\n }\n let url = collectCharacters(SRCSET_NOT_SPACES);\n if (url.slice(-1) === \",\") {\n url = absoluteToDoc(doc, url.substring(0, url.length - 1));\n output.push(url);\n } else {\n let descriptorsStr = \"\";\n url = absoluteToDoc(doc, url);\n let inParens = false;\n while (true) {\n const c2 = attributeValue.charAt(pos);\n if (c2 === \"\") {\n output.push((url + descriptorsStr).trim());\n break;\n } else if (!inParens) {\n if (c2 === \",\") {\n pos += 1;\n output.push((url + descriptorsStr).trim());\n break;\n } else if (c2 === \"(\") {\n inParens = true;\n }\n } else {\n if (c2 === \")\") {\n inParens = false;\n }\n }\n descriptorsStr += c2;\n pos += 1;\n }\n }\n }\n return output.join(\", \");\n}\nconst cachedDocument = /* @__PURE__ */ new WeakMap();\nfunction absoluteToDoc(doc, attributeValue) {\n if (!attributeValue || attributeValue.trim() === \"\") {\n return attributeValue;\n }\n return getHref(doc, attributeValue);\n}\nfunction isSVGElement(el) {\n return Boolean(el.tagName === \"svg\" || el.ownerSVGElement);\n}\nfunction getHref(doc, customHref) {\n let a2 = cachedDocument.get(doc);\n if (!a2) {\n a2 = doc.createElement(\"a\");\n cachedDocument.set(doc, a2);\n }\n if (!customHref) {\n customHref = \"\";\n } else if (customHref.startsWith(\"blob:\") || customHref.startsWith(\"data:\")) {\n return customHref;\n }\n a2.setAttribute(\"href\", customHref);\n return a2.href;\n}\nfunction transformAttribute(doc, tagName, name, value) {\n if (!value) {\n return value;\n }\n if (name === \"src\" || name === \"href\" && !(tagName === \"use\" && value[0] === \"#\")) {\n return absoluteToDoc(doc, value);\n } else if (name === \"xlink:href\" && value[0] !== \"#\") {\n return absoluteToDoc(doc, value);\n } else if (name === \"background\" && (tagName === \"table\" || tagName === \"td\" || tagName === \"th\")) {\n return absoluteToDoc(doc, value);\n } else if (name === \"srcset\") {\n return getAbsoluteSrcsetString(doc, value);\n } else if (name === \"style\") {\n return absoluteToStylesheet(value, getHref(doc));\n } else if (tagName === \"object\" && name === \"data\") {\n return absoluteToDoc(doc, value);\n }\n return value;\n}\nfunction ignoreAttribute(tagName, name, _value) {\n return (tagName === \"video\" || tagName === \"audio\") && name === \"autoplay\";\n}\nfunction _isBlockedElement(element, blockClass, blockSelector) {\n try {\n if (typeof blockClass === \"string\") {\n if (element.classList.contains(blockClass)) {\n return true;\n }\n } else {\n for (let eIndex = element.classList.length; eIndex--; ) {\n const className = element.classList[eIndex];\n if (blockClass.test(className)) {\n return true;\n }\n }\n }\n if (blockSelector) {\n return element.matches(blockSelector);\n }\n } catch (e2) {\n }\n return false;\n}\nfunction classMatchesRegex(node, regex, checkAncestors) {\n if (!node) return false;\n if (node.nodeType !== node.ELEMENT_NODE) {\n if (!checkAncestors) return false;\n return classMatchesRegex(node.parentNode, regex, checkAncestors);\n }\n for (let eIndex = node.classList.length; eIndex--; ) {\n const className = node.classList[eIndex];\n if (regex.test(className)) {\n return true;\n }\n }\n if (!checkAncestors) return false;\n return classMatchesRegex(node.parentNode, regex, checkAncestors);\n}\nfunction needMaskingText(node, maskTextClass, maskTextSelector, checkAncestors) {\n let el;\n if (isElement(node)) {\n el = node;\n if (!el.childNodes.length) {\n return false;\n }\n } else if (node.parentElement === null) {\n return false;\n } else {\n el = node.parentElement;\n }\n try {\n if (typeof maskTextClass === \"string\") {\n if (checkAncestors) {\n if (el.closest(`.${maskTextClass}`)) return true;\n } else {\n if (el.classList.contains(maskTextClass)) return true;\n }\n } else {\n if (classMatchesRegex(el, maskTextClass, checkAncestors)) return true;\n }\n if (maskTextSelector) {\n if (checkAncestors) {\n if (el.closest(maskTextSelector)) return true;\n } else {\n if (el.matches(maskTextSelector)) return true;\n }\n }\n } catch (e2) {\n }\n return false;\n}\nfunction onceIframeLoaded(iframeEl, listener, iframeLoadTimeout) {\n const win = iframeEl.contentWindow;\n if (!win) {\n return;\n }\n let fired = false;\n let readyState;\n try {\n readyState = win.document.readyState;\n } catch (error) {\n return;\n }\n if (readyState !== \"complete\") {\n const timer = setTimeout(() => {\n if (!fired) {\n listener();\n fired = true;\n }\n }, iframeLoadTimeout);\n iframeEl.addEventListener(\"load\", () => {\n clearTimeout(timer);\n fired = true;\n listener();\n });\n return;\n }\n const blankUrl = \"about:blank\";\n if (win.location.href !== blankUrl || iframeEl.src === blankUrl || iframeEl.src === \"\") {\n setTimeout(listener, 0);\n return iframeEl.addEventListener(\"load\", listener);\n }\n iframeEl.addEventListener(\"load\", listener);\n}\nfunction onceStylesheetLoaded(link, listener, styleSheetLoadTimeout) {\n let fired = false;\n let styleSheetLoaded;\n try {\n styleSheetLoaded = link.sheet;\n } catch (error) {\n return;\n }\n if (styleSheetLoaded) return;\n const timer = setTimeout(() => {\n if (!fired) {\n listener();\n fired = true;\n }\n }, styleSheetLoadTimeout);\n link.addEventListener(\"load\", () => {\n clearTimeout(timer);\n fired = true;\n listener();\n });\n}\nfunction serializeNode(n2, options) {\n const {\n doc,\n mirror: mirror2,\n blockClass,\n blockSelector,\n needsMask,\n inlineStylesheet,\n maskInputOptions = {},\n maskTextFn,\n maskInputFn,\n dataURLOptions = {},\n inlineImages,\n recordCanvas,\n keepIframeSrcFn,\n newlyAddedElement = false\n } = options;\n const rootId = getRootId(doc, mirror2);\n switch (n2.nodeType) {\n case n2.DOCUMENT_NODE:\n if (n2.compatMode !== \"CSS1Compat\") {\n return {\n type: NodeType$2.Document,\n childNodes: [],\n compatMode: n2.compatMode\n // probably \"BackCompat\"\n };\n } else {\n return {\n type: NodeType$2.Document,\n childNodes: []\n };\n }\n case n2.DOCUMENT_TYPE_NODE:\n return {\n type: NodeType$2.DocumentType,\n name: n2.name,\n publicId: n2.publicId,\n systemId: n2.systemId,\n rootId\n };\n case n2.ELEMENT_NODE:\n return serializeElementNode(n2, {\n doc,\n blockClass,\n blockSelector,\n inlineStylesheet,\n maskInputOptions,\n maskInputFn,\n dataURLOptions,\n inlineImages,\n recordCanvas,\n keepIframeSrcFn,\n newlyAddedElement,\n rootId\n });\n case n2.TEXT_NODE:\n return serializeTextNode(n2, {\n doc,\n needsMask,\n maskTextFn,\n rootId\n });\n case n2.CDATA_SECTION_NODE:\n return {\n type: NodeType$2.CDATA,\n textContent: \"\",\n rootId\n };\n case n2.COMMENT_NODE:\n return {\n type: NodeType$2.Comment,\n textContent: n2.textContent || \"\",\n rootId\n };\n default:\n return false;\n }\n}\nfunction getRootId(doc, mirror2) {\n if (!mirror2.hasNode(doc)) return void 0;\n const docId = mirror2.getId(doc);\n return docId === 1 ? void 0 : docId;\n}\nfunction serializeTextNode(n2, options) {\n var _a2;\n const { needsMask, maskTextFn, rootId } = options;\n const parentTagName = n2.parentNode && n2.parentNode.tagName;\n let textContent = n2.textContent;\n const isStyle = parentTagName === \"STYLE\" ? true : void 0;\n const isScript = parentTagName === \"SCRIPT\" ? true : void 0;\n if (isStyle && textContent) {\n try {\n if (n2.nextSibling || n2.previousSibling) {\n } else if ((_a2 = n2.parentNode.sheet) == null ? void 0 : _a2.cssRules) {\n textContent = stringifyStylesheet(\n n2.parentNode.sheet\n );\n }\n } catch (err) {\n console.warn(\n `Cannot get CSS styles from text's parentNode. Error: ${err}`,\n n2\n );\n }\n textContent = absoluteToStylesheet(textContent, getHref(options.doc));\n }\n if (isScript) {\n textContent = \"SCRIPT_PLACEHOLDER\";\n }\n if (!isStyle && !isScript && textContent && needsMask) {\n textContent = maskTextFn ? maskTextFn(textContent, n2.parentElement) : textContent.replace(/[\\S]/g, \"*\");\n }\n return {\n type: NodeType$2.Text,\n textContent: textContent || \"\",\n isStyle,\n rootId\n };\n}\nfunction serializeElementNode(n2, options) {\n const {\n doc,\n blockClass,\n blockSelector,\n inlineStylesheet,\n maskInputOptions = {},\n maskInputFn,\n dataURLOptions = {},\n inlineImages,\n recordCanvas,\n keepIframeSrcFn,\n newlyAddedElement = false,\n rootId\n } = options;\n const needBlock = _isBlockedElement(n2, blockClass, blockSelector);\n const tagName = getValidTagName$1(n2);\n let attributes = {};\n const len = n2.attributes.length;\n for (let i2 = 0; i2 < len; i2++) {\n const attr = n2.attributes[i2];\n if (!ignoreAttribute(tagName, attr.name, attr.value)) {\n attributes[attr.name] = transformAttribute(\n doc,\n tagName,\n toLowerCase(attr.name),\n attr.value\n );\n }\n }\n if (tagName === \"link\" && inlineStylesheet) {\n const href = n2.href;\n let stylesheet = findStylesheet(doc, href);\n if (!stylesheet && href.includes('.css')) {\n const rootDomain = window.location.origin\n const stylesheetPath = href.replace(window.location.href, '')\n const potentialStylesheetHref = rootDomain + '/' + stylesheetPath\n stylesheet = findStylesheet(doc, potentialStylesheetHref);\n }\n let cssText = null;\n if (stylesheet) {\n cssText = stringifyStylesheet(stylesheet);\n }\n if (cssText) {\n delete attributes.rel;\n delete attributes.href;\n attributes._cssText = absoluteToStylesheet(cssText, stylesheet.href);\n }\n }\n if (tagName === \"style\" && n2.sheet && // TODO: Currently we only try to get dynamic stylesheet when it is an empty style element\n !(n2.innerText || n2.textContent || \"\").trim().length) {\n const cssText = stringifyStylesheet(\n n2.sheet\n );\n if (cssText) {\n attributes._cssText = absoluteToStylesheet(cssText, getHref(doc));\n }\n }\n if (tagName === \"input\" || tagName === \"textarea\" || tagName === \"select\") {\n const value = n2.value;\n const checked = n2.checked;\n if (attributes.type !== \"radio\" && attributes.type !== \"checkbox\" && attributes.type !== \"submit\" && attributes.type !== \"button\" && value) {\n attributes.value = maskInputValue({\n element: n2,\n type: getInputType(n2),\n tagName,\n value,\n maskInputOptions,\n maskInputFn\n });\n } else if (checked) {\n attributes.checked = checked;\n }\n }\n if (tagName === \"option\") {\n if (n2.selected && !maskInputOptions[\"select\"]) {\n attributes.selected = true;\n } else {\n delete attributes.selected;\n }\n }\n if (tagName === \"canvas\" && recordCanvas) {\n if (n2.__context === \"2d\") {\n if (!is2DCanvasBlank(n2)) {\n attributes.rr_dataURL = n2.toDataURL(\n dataURLOptions.type,\n dataURLOptions.quality\n );\n }\n } else if (!(\"__context\" in n2)) {\n const canvasDataURL = n2.toDataURL(\n dataURLOptions.type,\n dataURLOptions.quality\n );\n const blankCanvas = doc.createElement(\"canvas\");\n blankCanvas.width = n2.width;\n blankCanvas.height = n2.height;\n const blankCanvasDataURL = blankCanvas.toDataURL(\n dataURLOptions.type,\n dataURLOptions.quality\n );\n if (canvasDataURL !== blankCanvasDataURL) {\n attributes.rr_dataURL = canvasDataURL;\n }\n }\n }\n if (tagName === \"img\" && inlineImages) {\n if (!canvasService) {\n canvasService = doc.createElement(\"canvas\");\n canvasCtx = canvasService.getContext(\"2d\");\n }\n const image = n2;\n const imageSrc = image.currentSrc || image.getAttribute(\"src\") || \"<unknown-src>\";\n const priorCrossOrigin = image.crossOrigin;\n const recordInlineImage = () => {\n image.removeEventListener(\"load\", recordInlineImage);\n try {\n canvasService.width = image.naturalWidth;\n canvasService.height = image.naturalHeight;\n canvasCtx.drawImage(image, 0, 0);\n attributes.rr_dataURL = canvasService.toDataURL(\n dataURLOptions.type,\n dataURLOptions.quality\n );\n } catch (err) {\n if (image.crossOrigin !== \"anonymous\") {\n image.crossOrigin = \"anonymous\";\n if (image.complete && image.naturalWidth !== 0)\n recordInlineImage();\n else image.addEventListener(\"load\", recordInlineImage);\n return;\n } else {\n console.warn(\n `Cannot inline img src=${imageSrc}! Error: ${err}`\n );\n }\n }\n if (image.crossOrigin === \"anonymous\") {\n priorCrossOrigin ? attributes.crossOrigin = priorCrossOrigin : image.removeAttribute(\"crossorigin\");\n }\n };\n if (image.complete && image.naturalWidth !== 0) recordInlineImage();\n else image.addEventListener(\"load\", recordInlineImage);\n }\n if (tagName === \"audio\" || tagName === \"video\") {\n const mediaAttributes = attributes;\n mediaAttributes.rr_mediaState = n2.paused ? \"paused\" : \"played\";\n mediaAttributes.rr_mediaCurrentTime = n2.currentTime;\n mediaAttributes.rr_mediaPlaybackRate = n2.playbackRate;\n mediaAttributes.rr_mediaMuted = n2.muted;\n mediaAttributes.rr_mediaLoop = n2.loop;\n mediaAttributes.rr_mediaVolume = n2.volume;\n }\n if (!newlyAddedElement) {\n if (n2.scrollLeft) {\n attributes.rr_scrollLeft = n2.scrollLeft;\n }\n if (n2.scrollTop) {\n attributes.rr_scrollTop = n2.scrollTop;\n }\n }\n if (needBlock) {\n const { width, height } = n2.getBoundingClientRect();\n attributes = {\n class: attributes.class,\n rr_width: `${width}px`,\n rr_height: `${height}px`\n };\n }\n if (tagName === \"iframe\" && !keepIframeSrcFn(attributes.src)) {\n if (!n2.contentDocument) {\n attributes.rr_src = attributes.src;\n }\n delete attributes.src;\n }\n let isCustomElement;\n try {\n if (customElements.get(tagName)) isCustomElement = true;\n } catch (e2) {\n }\n return {\n type: NodeType$2.Element,\n tagName,\n attributes,\n childNodes: [],\n isSVG: isSVGElement(n2) || void 0,\n needBlock,\n rootId,\n isCustom: isCustomElement\n };\n}\nfunction lowerIfExists(maybeAttr) {\n if (maybeAttr === void 0 || maybeAttr === null) {\n return \"\";\n } else {\n return maybeAttr.toLowerCase();\n }\n}\nfunction slimDOMExcluded(sn, slimDOMOptions) {\n if (slimDOMOptions.comment && sn.type === NodeType$2.Comment) {\n return true;\n } else if (sn.type === NodeType$2.Element) {\n if (slimDOMOptions.script && // script tag\n (sn.tagName === \"script\" || // (module)preload link\n sn.tagName === \"link\" && (sn.attributes.rel === \"preload\" || sn.attributes.rel === \"modulepreload\") && sn.attributes.as === \"script\" || // prefetch link\n sn.tagName === \"link\" && sn.attributes.rel === \"prefetch\" && typeof sn.attributes.href === \"string\" && extractFileExtension(sn.attributes.href) === \"js\")) {\n return true;\n } else if (slimDOMOptions.headFavicon && (sn.tagName === \"link\" && sn.attributes.rel === \"shortcut icon\" || sn.tagName === \"meta\" && (lowerIfExists(sn.attributes.name).match(\n /^msapplication-tile(image|color)$/\n ) || lowerIfExists(sn.attributes.name) === \"application-name\" || lowerIfExists(sn.attributes.rel) === \"icon\" || lowerIfExists(sn.attributes.rel) === \"apple-touch-icon\" || lowerIfExists(sn.attributes.rel) === \"shortcut icon\"))) {\n return true;\n } else if (sn.tagName === \"meta\") {\n if (slimDOMOptions.headMetaDescKeywords && lowerIfExists(sn.attributes.name).match(/^description|keywords$/)) {\n return true;\n } else if (slimDOMOptions.headMetaSocial && (lowerIfExists(sn.attributes.property).match(/^(og|twitter|fb):/) || // og = opengraph (facebook)\n lowerIfExists(sn.attributes.name).match(/^(og|twitter):/) || lowerIfExists(sn.attributes.name) === \"pinterest\")) {\n return true;\n } else if (slimDOMOptions.headMetaRobots && (lowerIfExists(sn.attributes.name) === \"robots\" || lowerIfExists(sn.attributes.name) === \"googlebot\" || lowerIfExists(sn.attributes.name) === \"bingbot\")) {\n return true;\n } else if (slimDOMOptions.headMetaHttpEquiv && sn.attributes[\"http-equiv\"] !== void 0) {\n return true;\n } else if (slimDOMOptions.headMetaAuthorship && (lowerIfExists(sn.attributes.name) === \"author\" || lowerIfExists(sn.attributes.name) === \"generator\" || lowerIfExists(sn.attributes.name) === \"framework\" || lowerIfExists(sn.attributes.name) === \"publisher\" || lowerIfExists(sn.attributes.name) === \"progid\" || lowerIfExists(sn.attributes.property).match(/^article:/) || lowerIfExists(sn.attributes.property).match(/^product:/))) {\n return true;\n } else if (slimDOMOptions.headMetaVerification && (lowerIfExists(sn.attributes.name) === \"google-site-verification\" || lowerIfExists(sn.attributes.name) === \"yandex-verification\" || lowerIfExists(sn.attributes.name) === \"csrf-token\" || lowerIfExists(sn.attributes.name) === \"p:domain_verify\" || lowerIfExists(sn.attributes.name) === \"verify-v1\" || lowerIfExists(sn.attributes.name) === \"verification\" || lowerIfExists(sn.attributes.name) === \"shopify-checkout-api-token\")) {\n return true;\n }\n }\n }\n return false;\n}\nfunction serializeNodeWithId(n2, options) {\n const {\n doc,\n mirror: mirror2,\n blockClass,\n blockSelector,\n maskTextClass,\n maskTextSelector,\n skipChild = false,\n inlineStylesheet = true,\n maskInputOptions = {},\n maskTextFn,\n maskInputFn,\n slimDOMOptions,\n dataURLOptions = {},\n inlineImages = false,\n recordCanvas = false,\n onSerialize,\n onIframeLoad,\n iframeLoadTimeout = 5e3,\n onStylesheetLoad,\n stylesheetLoadTimeout = 5e3,\n keepIframeSrcFn = () => false,\n newlyAddedElement = false\n } = options;\n let { needsMask } = options;\n let { preserveWhiteSpace = true } = options;\n if (!needsMask) {\n const checkAncestors = needsMask === void 0;\n needsMask = needMaskingText(\n n2,\n maskTextClass,\n maskTextSelector,\n checkAncestors\n );\n }\n const _serializedNode = serializeNode(n2, {\n doc,\n mirror: mirror2,\n blockClass,\n blockSelector,\n needsMask,\n inlineStylesheet,\n maskInputOptions,\n maskTextFn,\n maskInputFn,\n dataURLOptions,\n inlineImages,\n recordCanvas,\n keepIframeSrcFn,\n newlyAddedElement\n });\n if (!_serializedNode) {\n console.warn(n2, \"not serialized\");\n return null;\n }\n let id;\n if (mirror2.hasNode(n2)) {\n id = mirror2.getId(n2);\n } else if (slimDOMExcluded(_serializedNode, slimDOMOptions) || !preserveWhiteSpace && _serializedNode.type === NodeType$2.Text && !_serializedNode.isStyle && !_serializedNode.textContent.replace(/^\\s+|\\s+$/gm, \"\").length) {\n id = IGNORED_NODE;\n } else {\n id = genId();\n }\n const serializedNode = Object.assign(_serializedNode, { id });\n mirror2.add(n2, serializedNode);\n if (id === IGNORED_NODE) {\n return null;\n }\n if (onSerialize) {\n onSerialize(n2);\n }\n let recordChild = !skipChild;\n if (serializedNode.type === NodeType$2.Element) {\n recordChild = recordChild && !serializedNode.needBlock;\n delete serializedNode.needBlock;\n const shadowRoot = n2.shadowRoot;\n if (shadowRoot && isNativeShadowDom(shadowRoot))\n serializedNode.isShadowHost = true;\n }\n if ((serializedNode.type === NodeType$2.Document || serializedNode.type === NodeType$2.Element) && recordChild) {\n if (slimDOMOptions.headWhitespace && serializedNode.type === NodeType$2.Element && serializedNode.tagName === \"head\") {\n preserveWhiteSpace = false;\n }\n const bypassOptions = {\n doc,\n mirror: mirror2,\n blockClass,\n blockSelector,\n needsMask,\n maskTextClass,\n maskTextSelector,\n skipChild,\n inlineStylesheet,\n maskInputOptions,\n maskTextFn,\n maskInputFn,\n slimDOMOptions,\n dataURLOptions,\n inlineImages,\n recordCanvas,\n preserveWhiteSpace,\n onSerialize,\n onIframeLoad,\n iframeLoadTimeout,\n onStylesheetLoad,\n stylesheetLoadTimeout,\n keepIframeSrcFn\n };\n if (serializedNode.type === NodeType$2.Element && serializedNode.tagName === \"textarea\" && serializedNode.attributes.value !== void 0) ;\n else {\n for (const childN of Array.from(n2.childNodes)) {\n const serializedChildNode = serializeNodeWithId(childN, bypassOptions);\n if (serializedChildNode) {\n serializedNode.childNodes.push(serializedChildNode);\n }\n }\n }\n if (isElement(n2) && n2.shadowRoot) {\n for (const childN of Array.from(n2.shadowRoot.childNodes)) {\n const serializedChildNode = serializeNodeWithId(childN, bypassOptions);\n if (serializedChildNode) {\n isNativeShadowDom(n2.shadowRoot) && (serializedChildNode.isShadow = true);\n serializedNode.childNodes.push(serializedChildNode);\n }\n }\n }\n }\n if (n2.parentNode && isShadowRoot(n2.parentNode) && isNativeShadowDom(n2.parentNode)) {\n serializedNode.isShadow = true;\n }\n if (serializedNode.type === NodeType$2.Element && serializedNode.tagName === \"iframe\") {\n onceIframeLoaded(\n n2,\n () => {\n const iframeDoc = n2.contentDocument;\n if (iframeDoc && onIframeLoad) {\n const serializedIframeNode = serializeNodeWithId(iframeDoc, {\n doc: iframeDoc,\n mirror: mirror2,\n blockClass,\n blockSelector,\n needsMask,\n maskTextClass,\n maskTextSelector,\n skipChild: false,\n inlineStylesheet,\n maskInputOptions,\n maskTextFn,\n maskInputFn,\n slimDOMOptions,\n dataURLOptions,\n inlineImages,\n recordCanvas,\n preserveWhiteSpace,\n onSerialize,\n onIframeLoad,\n iframeLoadTimeout,\n onStylesheetLoad,\n stylesheetLoadTimeout,\n keepIframeSrcFn\n });\n if (serializedIframeNode) {\n onIframeLoad(\n n2,\n serializedIframeNode\n );\n }\n }\n },\n iframeLoadTimeout\n );\n }\n if (serializedNode.type === NodeType$2.Element && serializedNode.tagName === \"link\" && typeof serializedNode.attributes.rel === \"string\" && (serializedNode.attributes.rel === \"stylesheet\" || serializedNode.attributes.rel === \"preload\" && typeof serializedNode.attributes.href === \"string\" && extractFileExtension(serializedNode.attributes.href) === \"css\")) {\n onceStylesheetLoaded(\n n2,\n () => {\n if (onStylesheetLoad) {\n const serializedLinkNode = serializeNodeWithId(n2, {\n doc,\n mirror: mirror2,\n blockClass,\n blockSelector,\n needsMask,\n maskTextClass,\n maskTextSelector,\n skipChild: false,\n inlineStylesheet,\n maskInputOptions,\n maskTextFn,\n maskInputFn,\n slimDOMOptions,\n dataURLOptions,\n inlineImages,\n recordCanvas,\n preserveWhiteSpace,\n onSerialize,\n onIframeLoad,\n iframeLoadTimeout,\n onStylesheetLoad,\n stylesheetLoadTimeout,\n keepIframeSrcFn\n });\n if (serializedLinkNode) {\n onStylesheetLoad(\n n2,\n serializedLinkNode\n );\n }\n }\n },\n stylesheetLoadTimeout\n );\n }\n return serializedNode;\n}\nfunction snapshot(n2, options) {\n const {\n mirror: mirror2 = new Mirror(),\n blockClass = \"rr-block\",\n blockSelector = null,\n maskTextClass = \"rr-mask\",\n maskTextSelector = null,\n inlineStylesheet = true,\n inlineImages = false,\n recordCanvas = false,\n maskAllInputs = false,\n maskTextFn,\n maskInputFn,\n slimDOM = false,\n dataURLOptions,\n preserveWhiteSpace,\n onSerialize,\n onIframeLoad,\n iframeLoadTimeout,\n onStylesheetLoad,\n stylesheetLoadTimeout,\n keepIframeSrcFn = () => false\n } = options || {};\n const maskInputOptions = maskAllInputs === true ? {\n color: true,\n date: true,\n \"datetime-local\": true,\n email: true,\n month: true,\n number: true,\n range: true,\n search: true,\n tel: true,\n text: true,\n time: true,\n url: true,\n week: true,\n textarea: true,\n select: true,\n password: true\n } : maskAllInputs === false ? {\n password: true\n } : maskAllInputs;\n const slimDOMOptions = slimDOM === true || slimDOM === \"all\" ? (\n // if true: set of sensible options that should not throw away any information\n {\n script: true,\n comment: true,\n headFavicon: true,\n headWhitespace: true,\n headMetaDescKeywords: slimDOM === \"all\",\n // destructive\n headMetaSocial: true,\n headMetaRobots: true,\n headMetaHttpEquiv: true,\n headMetaAuthorship: true,\n headMetaVerification: true\n }\n ) : slimDOM === false ? {} : slimDOM;\n return serializeNodeWithId(n2, {\n doc: n2,\n mirror: mirror2,\n blockClass,\n blockSelector,\n maskTextClass,\n maskTextSelector,\n skipChild: false,\n inlineStylesheet,\n maskInputOptions,\n maskTextFn,\n maskInputFn,\n slimDOMOptions,\n dataURLOptions,\n inlineImages,\n recordCanvas,\n preserveWhiteSpace,\n onSerialize,\n onIframeLoad,\n iframeLoadTimeout,\n onStylesheetLoad,\n stylesheetLoadTimeout,\n keepIframeSrcFn,\n newlyAddedElement: false\n });\n}\nconst commentre = /\\/\\*[^*]*\\*+([^/*][^*]*\\*+)*\\//g;\nfunction parse(css, options = {}) {\n let lineno = 1;\n let column = 1;\n function updatePosition(str) {\n const lines = str.match(/\\n/g);\n if (lines) {\n lineno += lines.length;\n }\n const i2 = str.lastIndexOf(\"\\n\");\n column = i2 === -1 ? column + str.length : str.length - i2;\n }\n function position() {\n const start = { line: lineno, column };\n return (node) => {\n node.position = new Position(start);\n whitespace();\n return node;\n };\n }\n const _Position = class _Position2 {\n constructor(start) {\n __publicField$1(this, \"content\");\n __publicField$1(this, \"start\");\n __publicField$1(this, \"end\");\n __publicField$1(this, \"source\");\n this.start = start;\n this.end = { line: lineno, column };\n this.source = options.source;\n this.content = _Position2.content;\n }\n };\n __publicField$1(_Position, \"content\");\n let Position = _Position;\n Position.content = css;\n const errorsList = [];\n function error(msg) {\n const err = new Error(\n `${options.source || \"\"}:${lineno}:${column}: ${msg}`\n );\n err.reason = msg;\n err.filename = options.source;\n err.line = lineno;\n err.column = column;\n err.source = css;\n if (options.silent) {\n errorsList.push(err);\n } else {\n throw err;\n }\n }\n function stylesheet() {\n const rulesList = rules2();\n return {\n type: \"stylesheet\",\n stylesheet: {\n source: options.source,\n rules: rulesList,\n parsingErrors: errorsList\n }\n };\n }\n function open() {\n return match(/^{\\s*/);\n }\n function close() {\n return match(/^}/);\n }\n function rules2() {\n let node;\n const rules22 = [];\n whitespace();\n comments(rules22);\n while (css.length && css.charAt(0) !== \"}\" && (node = atrule() || rule())) {\n if (node) {\n rules22.push(node);\n comments(rules22);\n }\n }\n return rules22;\n }\n function match(re) {\n const m = re.exec(css);\n if (!m) {\n return;\n }\n const str = m[0];\n updatePosition(str);\n css = css.slice(str.length);\n return m;\n }\n function whitespace() {\n match(/^\\s*/);\n }\n function comments(rules22 = []) {\n let c2;\n while (c2 = comment()) {\n if (c2) {\n rules22.push(c2);\n }\n c2 = comment();\n }\n return rules22;\n }\n function comment() {\n const pos = position();\n if (\"/\" !== css.charAt(0) || \"*\" !== css.charAt(1)) {\n return;\n }\n let i2 = 2;\n while (\"\" !== css.charAt(i2) && (\"*\" !== css.charAt(i2) || \"/\" !== css.charAt(i2 + 1))) {\n ++i2;\n }\n i2 += 2;\n if (\"\" === css.charAt(i2 - 1)) {\n return error(\"End of comment missing\");\n }\n const str = css.slice(2, i2 - 2);\n column += 2;\n updatePosition(str);\n css = css.slice(i2);\n column += 2;\n return pos({\n type: \"comment\",\n comment: str\n });\n }\n const selectorMatcher = new RegExp(\n \"^((\" + [\n /[^\\\\]\"(?:\\\\\"|[^\"])*\"/.source,\n // consume any quoted parts (checking that the double quote isn't itself escaped)\n /[^\\\\]'(?:\\\\'|[^'])*'/.source,\n // same but for single quotes\n \"[^{]\"\n ].join(\"|\") + \")+)\"\n );\n function selector() {\n whitespace();\n while (css[0] == \"}\") {\n error(\"extra closing bracket\");\n css = css.slice(1);\n whitespace();\n }\n const m = match(selectorMatcher);\n if (!m) {\n return;\n }\n const cleanedInput = m[0].trim().replace(/\\/\\*([^*]|[\\r\\n]|(\\*+([^*/]|[\\r\\n])))*\\*\\/+/g, \"\").replace(/\"(?:\\\\\"|[^\"])*\"|'(?:\\\\'|[^'])*'/g, (m2) => {\n return m2.replace(/,/g, \"\");\n });\n return customSplit(cleanedInput).map(\n (s2) => s2.replace(/\\u200C/g, \",\").trim()\n );\n }\n function customSplit(input) {\n const result = [];\n let currentSegment = \"\";\n let depthParentheses = 0;\n let depthBrackets = 0;\n let currentStringChar = null;\n for (const char of input) {\n const hasStringEscape = currentSegment.endsWith(\"\\\\\");\n if (currentStringChar) {\n if (currentStringChar === char && !hasStringEscape) {\n currentStringChar = null;\n }\n } else if (char === \"(\") {\n depthParentheses++;\n } else if (char === \")\") {\n depthParentheses--;\n } else if (char === \"[\") {\n depthBrackets++;\n } else if (char === \"]\") {\n depthBrackets--;\n } else if (`'\"`.includes(char)) {\n currentStringChar = char;\n }\n if (char === \",\" && depthParentheses === 0 && depthBrackets === 0) {\n result.push(currentSegment);\n currentSegment = \"\";\n } else {\n currentSegment += char;\n }\n }\n if (currentSegment) {\n result.push(currentSegment);\n }\n return result;\n }\n function declaration() {\n const pos = position();\n const propMatch = match(/^(\\*?[-#\\/\\*\\\\\\w]+(\\[[0-9a-z_-]+\\])?)\\s*/);\n if (!propMatch) {\n return;\n }\n const prop = trim(propMatch[0]);\n if (!match(/^:\\s*/)) {\n return error(`property missing ':'`);\n }\n const val = match(/^((?:'(?:\\\\'|.)*?'|\"(?:\\\\\"|.)*?\"|\\([^\\)]*?\\)|[^};])+)/);\n const ret = pos({\n type: \"declaration\",\n property: prop.replace(commentre, \"\"),\n value: val ? trim(val[0]).replace(commentre, \"\") : \"\"\n });\n match(/^[;\\s]*/);\n return ret;\n }\n function declarations() {\n const decls = [];\n if (!open()) {\n return error(`missing '{'`);\n }\n comments(decls);\n let decl;\n while (decl = declaration()) {\n if (decl !== false) {\n decls.push(decl);\n comments(decls);\n }\n decl = declaration();\n }\n if (!close()) {\n return error(`missing '}'`);\n }\n return decls;\n }\n function keyframe() {\n let m;\n const vals = [];\n const pos = position();\n while (m = match(/^((\\d+\\.\\d+|\\.\\d+|\\d+)%?|[a-z]+)\\s*/)) {\n vals.push(m[1]);\n match(/^,\\s*/);\n }\n if (!vals.length) {\n return;\n }\n return pos({\n type: \"keyframe\",\n values: vals,\n declarations: declarations()\n });\n }\n function atkeyframes() {\n const pos = position();\n let m = match(/^@([-\\w]+)?keyframes\\s*/);\n if (!m) {\n return;\n }\n const vendor = m[1];\n m = match(/^([-\\w]+)\\s*/);\n if (!m) {\n return error(\"@keyframes missing name\");\n }\n const name = m[1];\n if (!open()) {\n return error(`@keyframes missing '{'`);\n }\n let frame;\n let frames = comments();\n while (frame = keyframe()) {\n frames.push(frame);\n frames = frames.concat(comments());\n }\n if (!close()) {\n return error(`@keyframes missing '}'`);\n }\n return pos({\n type: \"keyframes\",\n name,\n vendor,\n keyframes: frames\n });\n }\n function atsupports() {\n const pos = position();\n const m = match(/^@supports *([^{]+)/);\n if (!m) {\n return;\n }\n const supports = trim(m[1]);\n if (!open()) {\n return error(`@supports missing '{'`);\n }\n const style = comments().concat(rules2());\n if (!close()) {\n return error(`@supports missing '}'`);\n }\n return pos({\n type: \"supports\",\n supports,\n rules: style\n });\n }\n function athost() {\n const pos = position();\n const m = match(/^@host\\s*/);\n if (!m) {\n return;\n }\n if (!open()) {\n return error(`@host missing '{'`);\n }\n const style = comments().concat(rules2());\n if (!close()) {\n return error(`@host missing '}'`);\n }\n return pos({\n type: \"host\",\n rules: style\n });\n }\n function atmedia() {\n const pos = position();\n const m = match(/^@media *([^{]+)/);\n if (!m) {\n return;\n }\n const media = trim(m[1]);\n if (!open()) {\n return error(`@media missing '{'`);\n }\n const style = comments().concat(rules2());\n if (!close()) {\n return error(`@media missing '}'`);\n }\n return pos({\n type: \"media\",\n media,\n rules: style\n });\n }\n function atcustommedia() {\n const pos = position();\n const m = match(/^@custom-media\\s+(--[^\\s]+)\\s*([^{;]+);/);\n if (!m) {\n return;\n }\n return pos({\n type: \"custom-media\",\n name: trim(m[1]),\n media: trim(m[2])\n });\n }\n function atpage() {\n const pos = position();\n const m = match(/^@page */);\n if (!m) {\n return;\n }\n const sel = selector() || [];\n if (!open()) {\n return error(`@page missing '{'`);\n }\n let decls = comments();\n let decl;\n while (decl = declaration()) {\n decls.push(decl);\n decls = decls.concat(comments());\n }\n if (!close()) {\n return error(`@page missing '}'`);\n }\n return pos({\n type: \"page\",\n selectors: sel,\n declarations: decls\n });\n }\n function atdocument() {\n const pos = position();\n const m = match(/^@([-\\w]+)?document *([^{]+)/);\n if (!m) {\n return;\n }\n const vendor = trim(m[1]);\n const doc = trim(m[2]);\n if (!open()) {\n return error(`@document missing '{'`);\n }\n const style = comments().concat(rules2());\n if (!close()) {\n return error(`@document missing '}'`);\n }\n return pos({\n type: \"document\",\n document: doc,\n vendor,\n rules: style\n });\n }\n function atfontface() {\n const pos = position();\n const m = match(/^@font-face\\s*/);\n if (!m) {\n return;\n }\n if (!open()) {\n return error(`@font-face missing '{'`);\n }\n let decls = comments();\n let decl;\n while (decl = declaration()) {\n decls.push(decl);\n decls = decls.concat(comments());\n }\n if (!close()) {\n return error(`@font-face missing '}'`);\n }\n return pos({\n type: \"font-face\",\n declarations: decls\n });\n }\n const atimport = _compileAtrule(\"import\");\n const atcharset = _compileAtrule(\"charset\");\n const atnamespace = _compileAtrule(\"namespace\");\n function _compileAtrule(name) {\n const re = new RegExp(\n \"^@\" + name + \"\\\\s*((?:\" + [\n /[^\\\\]\"(?:\\\\\"|[^\"])*\"/.source,\n // consume any quoted parts (checking that the double quote isn't itself escaped)\n /[^\\\\]'(?:\\\\'|[^'])*'/.source,\n // same but for single quotes\n \"[^;]\"\n ].join(\"|\") + \")+);\"\n );\n return () => {\n const pos = position();\n const m = match(re);\n if (!m) {\n return;\n }\n const ret = { type: name };\n ret[name] = m[1].trim();\n return pos(ret);\n };\n }\n function atrule() {\n if (css[0] !== \"@\") {\n return;\n }\n return atkeyframes() || atmedia() || atcustommedia() || atsupports() || atimport() || atcharset() || atnamespace() || atdocument() || atpage() || athost() || atfontface();\n }\n function rule() {\n const pos = position();\n const sel = selector();\n if (!sel) {\n return error(\"selector missing\");\n }\n comments();\n return pos({\n type: \"rule\",\n selectors: sel,\n declarations: declarations()\n });\n }\n return addParent(stylesheet());\n}\nfunction trim(str) {\n return str ? str.replace(/^\\s+|\\s+$/g, \"\") : \"\";\n}\nfunction addParent(obj, parent) {\n const isNode = obj && typeof obj.type === \"string\";\n const childParent = isNode ? obj : parent;\n for (const k of Object.keys(obj)) {\n const value = obj[k];\n if (Array.isArray(value)) {\n value.forEach((v2) => {\n addParent(v2, childParent);\n });\n } else if (value && typeof value === \"object\") {\n addParent(value, childParent);\n }\n }\n if (isNode) {\n Object.defineProperty(obj, \"parent\", {\n configurable: true,\n writable: true,\n enumerable: false,\n value: parent || null\n });\n }\n return obj;\n}\nconst tagMap = {\n script: \"noscript\",\n // camel case svg element tag names\n altglyph: \"altGlyph\",\n altglyphdef: \"altGlyphDef\",\n altglyphitem: \"altGlyphItem\",\n animatecolor: \"animateColor\",\n animatemotion: \"animateMotion\",\n animatetransform: \"animateTransform\",\n clippath: \"clipPath\",\n feblend: \"feBlend\",\n fecolormatrix: \"feColorMatrix\",\n fecomponenttransfer: \"feComponentTransfer\",\n fecomposite: \"feComposite\",\n feconvolvematrix: \"feConvolveMatrix\",\n fediffuselighting: \"feDiffuseLighting\",\n fedisplacementmap: \"feDisplacementMap\",\n fedistantlight: \"feDistantLight\",\n fedropshadow: \"feDropShadow\",\n feflood: \"feFlood\",\n fefunca: \"feFuncA\",\n fefuncb: \"feFuncB\",\n fefuncg: \"feFuncG\",\n fefuncr: \"feFuncR\",\n fegaussianblur: \"feGaussianBlur\",\n feimage: \"feImage\",\n femerge: \"feMerge\",\n femergenode: \"feMergeNode\",\n femorphology: \"feMorphology\",\n feoffset: \"feOffset\",\n fepointlight: \"fePointLight\",\n fespecularlighting: \"feSpecularLighting\",\n fespotlight: \"feSpotLight\",\n fetile: \"feTile\",\n feturbulence: \"feTurbulence\",\n foreignobject: \"foreignObject\",\n glyphref: \"glyphRef\",\n lineargradient: \"linearGradient\",\n radialgradient: \"radialGradient\"\n};\nfunction getTagName(n2) {\n let tagName = tagMap[n2.tagName] ? tagMap[n2.tagName] : n2.tagName;\n if (tagName === \"link\" && n2.attributes._cssText) {\n tagName = \"style\";\n }\n return tagName;\n}\nfunction escapeRegExp(str) {\n return str.replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\");\n}\nconst MEDIA_SELECTOR = /(max|min)-device-(width|height)/;\nconst MEDIA_SELECTOR_GLOBAL = new RegExp(MEDIA_SELECTOR.source, \"g\");\nconst HOVER_SELECTOR = /([^\\\\]):hover/;\nconst HOVER_SELECTOR_GLOBAL = new RegExp(HOVER_SELECTOR.source, \"g\");\nfunction adaptCssForReplay(cssText, cache) {\n const cachedStyle = cache == null ? void 0 : cache.stylesWithHoverClass.get(cssText);\n if (cachedStyle) return cachedStyle;\n const ast = parse(cssText, {\n silent: true\n });\n if (!ast.stylesheet) {\n return cssText;\n }\n const selectors = [];\n const medias = [];\n function getSelectors(rule) {\n if (\"selectors\" in rule && rule.selectors) {\n rule.selectors.forEach((selector) => {\n if (HOVER_SELECTOR.test(selector)) {\n selectors.push(selector);\n }\n });\n }\n if (\"media\" in rule && rule.media && MEDIA_SELECTOR.test(rule.media)) {\n medias.push(rule.media);\n }\n if (\"rules\" in rule && rule.rules) {\n rule.rules.forEach(getSelectors);\n }\n }\n getSelectors(ast.stylesheet);\n let result = cssText;\n if (selectors.length > 0) {\n const selectorMatcher = new RegExp(\n selectors.filter((selector, index) => selectors.indexOf(selector) === index).sort((a2, b) => b.length - a2.length).map((selector) => {\n return escapeRegExp(selector);\n }).join(\"|\"),\n \"g\"\n );\n result = result.replace(selectorMatcher, (selector) => {\n const newSelector = selector.replace(\n HOVER_SELECTOR_GLOBAL,\n \"$1.\\\\:hover\"\n );\n return `${selector}, ${newSelector}`;\n });\n }\n if (medias.length > 0) {\n const mediaMatcher = new RegExp(\n medias.filter((media, index) => medias.indexOf(media) === index).sort((a2, b) => b.length - a2.length).map((media) => {\n return escapeRegExp(media);\n }).join(\"|\"),\n \"g\"\n );\n result = result.replace(mediaMatcher, (media) => {\n return media.replace(MEDIA_SELECTOR_GLOBAL, \"$1-$2\");\n });\n }\n cache == null ? void 0 : cache.stylesWithHoverClass.set(cssText, result);\n return result;\n}\nfunction createCache() {\n const stylesWithHoverClass = /* @__PURE__ */ new Map();\n return {\n stylesWithHoverClass\n };\n}\nfunction buildNode(n2, options) {\n var _a2;\n const { doc, hackCss, cache } = options;\n switch (n2.type) {\n case NodeType$2.Document:\n return doc.implementation.createDocument(null, \"\", null);\n case NodeType$2.DocumentType:\n return doc.implementation.createDocumentType(\n n2.name || \"html\",\n n2.publicId,\n n2.systemId\n );\n case NodeType$2.Element: {\n const tagName = getTagName(n2);\n let node;\n if (n2.isSVG) {\n node = doc.createElementNS(\"http://www.w3.org/2000/svg\", tagName);\n } else {\n if (\n // If the tag name is a custom element name\n n2.isCustom && // If the browser supports custom elements\n ((_a2 = doc.defaultView) == null ? void 0 : _a2.customElements) && // If the custom element hasn't been defined yet\n !doc.defaultView.customElements.get(n2.tagName)\n )\n doc.defaultView.customElements.define(\n n2.tagName,\n class extends doc.defaultView.HTMLElement {\n }\n );\n node = doc.createElement(tagName);\n }\n const specialAttributes = {};\n for (const name in n2.attributes) {\n if (!Object.prototype.hasOwnProperty.call(n2.attributes, name)) {\n continue;\n }\n let value = n2.attributes[name];\n if (tagName === \"option\" && name === \"selected\" && value === false) {\n continue;\n }\n if (value === null) {\n continue;\n }\n if (value === true) value = \"\";\n if (name.startsWith(\"rr_\")) {\n specialAttributes[name] = value;\n continue;\n }\n const isTextarea = tagName === \"textarea\" && name === \"value\";\n const isRemoteOrDynamicCss = tagName === \"style\" && name === \"_cssText\";\n if (isRemoteOrDynamicCss && hackCss && typeof value === \"string\") {\n value = adaptCssForReplay(value, cache);\n }\n if ((isTextarea || isRemoteOrDynamicCss) && typeof value === \"string\") {\n node.appendChild(doc.createTextNode(value));\n n2.childNodes = [];\n continue;\n }\n try {\n if (n2.isSVG && name === \"xlink:href\") {\n node.setAttributeNS(\n \"http://www.w3.org/1999/xlink\",\n name,\n value.toString()\n );\n } else if (name === \"onload\" || name === \"onclick\" || name.substring(0, 7) === \"onmouse\") {\n node.setAttribute(\"_\" + name, value.toString());\n } else if (tagName === \"meta\" && n2.attributes[\"http-equiv\"] === \"Content-Security-Policy\" && name === \"content\") {\n node.setAttribute(\"csp-content\", value.toString());\n continue;\n } else if (tagName === \"link\" && (n2.attributes.rel === \"preload\" || n2.attributes.rel === \"modulepreload\") && n2.attributes.as === \"script\") {\n } else if (tagName === \"link\" && n2.attributes.rel === \"prefetch\" && typeof n2.attributes.href === \"string\" && n2.attributes.href.endsWith(\".js\")) {\n } else if (tagName === \"img\" && n2.attributes.srcset && n2.attributes.rr_dataURL) {\n node.setAttribute(\n \"rrweb-original-srcset\",\n n2.attributes.srcset\n );\n } else {\n node.setAttribute(name, value.toString());\n }\n } catch (error) {\n }\n }\n for (const name in specialAttributes) {\n const value = specialAttributes[name];\n if (tagName === \"canvas\" && name === \"rr_dataURL\") {\n const image = doc.createElement(\"img\");\n image.onload = () => {\n const ctx = node.getContext(\"2d\");\n if (ctx) {\n ctx.drawImage(image, 0, 0, image.width, image.height);\n }\n };\n image.src = value.toString();\n if (node.RRNodeType)\n node.rr_dataURL = value.toString();\n } else if (tagName === \"img\" && name === \"rr_dataURL\") {\n const image = node;\n if (!image.currentSrc.startsWith(\"data:\")) {\n image.setAttribute(\n \"rrweb-original-src\",\n n2.attributes.src\n );\n image.src = value.toString();\n }\n }\n if (name === \"rr_width\") {\n node.style.width = value.toString();\n } else if (name === \"rr_height\") {\n node.style.height = value.toString();\n } else if (name === \"rr_mediaCurrentTime\" && typeof value === \"number\") {\n node.currentTime = value;\n } else if (name === \"rr_mediaState\") {\n switch (value) {\n case \"played\":\n node.play().catch((e2) => console.warn(\"media playback error\", e2));\n break;\n case \"paused\":\n node.pause();\n break;\n }\n } else if (name === \"rr_mediaPlaybackRate\" && typeof value === \"number\") {\n node.playbackRate = value;\n } else if (name === \"rr_mediaMuted\" && typeof value === \"boolean\") {\n node.muted = value;\n } else if (name === \"rr_mediaLoop\" && typeof value === \"boolean\") {\n node.loop = value;\n } else if (name === \"rr_mediaVolume\" && typeof value === \"number\") {\n node.volume = value;\n }\n }\n if (n2.isShadowHost) {\n if (!node.shadowRoot) {\n node.attachShadow({ mode: \"open\" });\n } else {\n while (node.shadowRoot.firstChild) {\n node.shadowRoot.removeChild(node.shadowRoot.firstChild);\n }\n }\n }\n return node;\n }\n case NodeType$2.Text:\n return doc.createTextNode(\n n2.isStyle && hackCss ? adaptCssForReplay(n2.textContent, cache) : n2.textContent\n );\n case NodeType$2.CDATA:\n return doc.createCDATASection(n2.textContent);\n case NodeType$2.Comment:\n return doc.createComment(n2.textContent);\n default:\n return null;\n }\n}\nfunction buildNodeWithSN(n2, options) {\n const {\n doc,\n mirror: mirror2,\n skipChild = false,\n hackCss = true,\n afterAppend,\n cache\n } = options;\n if (mirror2.has(n2.id)) {\n const nodeInMirror = mirror2.getNode(n2.id);\n const meta = mirror2.getMeta(nodeInMirror);\n if (isNodeMetaEqual(meta, n2)) return mirror2.getNode(n2.id);\n }\n let node = buildNode(n2, { doc, hackCss, cache });\n if (!node) {\n return null;\n }\n if (n2.rootId && mirror2.getNode(n2.rootId) !== doc) {\n mirror2.replace(n2.rootId, doc);\n }\n if (n2.type === NodeType$2.Document) {\n doc.close();\n doc.open();\n if (n2.compatMode === \"BackCompat\" && n2.childNodes && n2.childNodes[0].type !== NodeType$2.DocumentType) {\n if (n2.childNodes[0].type === NodeType$2.Element && \"xmlns\" in n2.childNodes[0].attributes && n2.childNodes[0].attributes.xmlns === \"http://www.w3.org/1999/xhtml\") {\n doc.write(\n '<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"\">'\n );\n } else {\n doc.write(\n '<!DOCTYPE html PUBLIC \"-//W3C//DTD HTML 4.0 Transitional//EN\" \"\">'\n );\n }\n }\n node = doc;\n }\n mirror2.add(node, n2);\n if ((n2.type === NodeType$2.Document || n2.type === NodeType$2.Element) && !skipChild) {\n for (const childN of n2.childNodes) {\n const childNode = buildNodeWithSN(childN, {\n doc,\n mirror: mirror2,\n skipChild: false,\n hackCss,\n afterAppend,\n cache\n });\n if (!childNode) {\n console.warn(\"Failed to rebuild\", childN);\n continue;\n }\n if (childN.isShadow && isElement(node) && node.shadowRoot) {\n node.shadowRoot.appendChild(childNode);\n } else if (n2.type === NodeType$2.Document && childN.type == NodeType$2.Element) {\n const htmlElement = childNode;\n let body = null;\n htmlElement.childNodes.forEach((child) => {\n if (child.nodeName === \"BODY\") body = child;\n });\n if (body) {\n htmlElement.removeChild(body);\n node.appendChild(childNode);\n htmlElement.appendChild(body);\n } else {\n node.appendChild(childNode);\n }\n } else {\n node.appendChild(childNode);\n }\n if (afterAppend) {\n afterAppend(childNode, childN.id);\n }\n }\n }\n return node;\n}\nfunction visit(mirror2, onVisit) {\n function walk(node) {\n onVisit(node);\n }\n for (const id of mirror2.getIds()) {\n if (mirror2.has(id)) {\n walk(mirror2.getNode(id));\n }\n }\n}\nfunction handleScroll(node, mirror2) {\n const n2 = mirror2.getMeta(node);\n if ((n2 == null ? void 0 : n2.type) !== NodeType$2.Element) {\n return;\n }\n const el = node;\n for (const name in n2.attributes) {\n if (!(Object.prototype.hasOwnProperty.call(n2.attributes, name) && name.startsWith(\"rr_\"))) {\n continue;\n }\n const value = n2.attributes[name];\n if (name === \"rr_scrollLeft\") {\n el.scrollLeft = value;\n }\n if (name === \"rr_scrollTop\") {\n el.scrollTop = value;\n }\n }\n}\nfunction rebuild(n2, options) {\n const {\n doc,\n onVisit,\n hackCss = true,\n afterAppend,\n cache,\n mirror: mirror2 = new Mirror()\n } = options;\n const node = buildNodeWithSN(n2, {\n doc,\n mirror: mirror2,\n skipChild: false,\n hackCss,\n afterAppend,\n cache\n });\n visit(mirror2, (visitedNode) => {\n if (onVisit) {\n onVisit(visitedNode);\n }\n handleScroll(visitedNode, mirror2);\n });\n return node;\n}\nfunction on(type, fn, target = document) {\n const options = { capture: true, passive: true };\n target.addEventListener(type, fn, options);\n return () => target.removeEventListener(type, fn, options);\n}\nconst DEPARTED_MIRROR_ACCESS_WARNING = \"Please stop import mirror directly. Instead of that,\\r\\nnow you can use replayer.getMirror() to access the mirror instance of a replayer,\\r\\nor you can use record.mirror to access the mirror instance during recording.\";\nlet _mirror = {\n map: {},\n getId() {\n console.error(DEPARTED_MIRROR_ACCESS_WARNING);\n return -1;\n },\n getNode() {\n console.error(DEPARTED_MIRROR_ACCESS_WARNING);\n return null;\n },\n removeNodeFromMap() {\n console.error(DEPARTED_MIRROR_ACCESS_WARNING);\n },\n has() {\n console.error(DEPARTED_MIRROR_ACCESS_WARNING);\n return false;\n },\n reset() {\n console.error(DEPARTED_MIRROR_ACCESS_WARNING);\n }\n};\nif (typeof window !== \"undefined\" && window.Proxy && window.Reflect) {\n _mirror = new Proxy(_mirror, {\n get(target, prop, receiver) {\n if (prop === \"map\") {\n console.error(DEPARTED_MIRROR_ACCESS_WARNING);\n }\n return Reflect.get(target, prop, receiver);\n }\n });\n}\nfunction throttle(func, wait, options = {}) {\n let timeout = null;\n let previous = 0;\n return function(...args) {\n const now = Date.now();\n if (!previous && options.leading === false) {\n previous = now;\n }\n const remaining = wait - (now - previous);\n const context = this;\n if (remaining <= 0 || remaining > wait) {\n if (timeout) {\n clearTimeout(timeout);\n timeout = null;\n }\n previous = now;\n func.apply(context, args);\n } else if (!timeout && options.trailing !== false) {\n timeout = setTimeout(() => {\n previous = options.leading === false ? 0 : Date.now();\n timeout = null;\n func.apply(context, args);\n }, remaining);\n }\n };\n}\nfunction hookSetter(target, key, d, isRevoked, win = window) {\n const original = win.Object.getOwnPropertyDescriptor(target, key);\n win.Object.defineProperty(\n target,\n key,\n isRevoked ? d : {\n set(value) {\n setTimeout(() => {\n d.set.call(this, value);\n }, 0);\n if (original && original.set) {\n original.set.call(this, value);\n }\n }\n }\n );\n return () => hookSetter(target, key, original || {}, true);\n}\nfunction patch(source, name, replacement) {\n try {\n if (!(name in source)) {\n return () => {\n };\n }\n const original = source[name];\n const wrapped = replacement(original);\n if (typeof wrapped === \"function\") {\n wrapped.prototype = wrapped.prototype || {};\n Object.defineProperties(wrapped, {\n __rrweb_original__: {\n enumerable: false,\n value: original\n }\n });\n }\n source[name] = wrapped;\n return () => {\n source[name] = original;\n };\n } catch {\n return () => {\n };\n }\n}\nlet nowTimestamp = Date.now;\nif (!/* @__PURE__ */ /[1-9][0-9]{12}/.test(Date.now().toString())) {\n nowTimestamp = () => (/* @__PURE__ */ new Date()).getTime();\n}\nfunction getWindowScroll(win) {\n var _a2, _b, _c, _d, _e, _f;\n const doc = win.document;\n return {\n left: doc.scrollingElement ? doc.scrollingElement.scrollLeft : win.pageXOffset !== void 0 ? win.pageXOffset : (doc == null ? void 0 : doc.documentElement.scrollLeft) || ((_b = (_a2 = doc == null ? void 0 : doc.body) == null ? void 0 : _a2.parentElement) == null ? void 0 : _b.scrollLeft) || ((_c = doc == null ? void 0 : doc.body) == null ? void 0 : _c.scrollLeft) || 0,\n top: doc.scrollingElement ? doc.scrollingElement.scrollTop : win.pageYOffset !== void 0 ? win.pageYOffset : (doc == null ? void 0 : doc.documentElement.scrollTop) || ((_e = (_d = doc == null ? void 0 : doc.body) == null ? void 0 : _d.parentElement) == null ? void 0 : _e.scrollTop) || ((_f = doc == null ? void 0 : doc.body) == null ? void 0 : _f.scrollTop) || 0\n };\n}\nfunction getWindowHeight() {\n return window.innerHeight || document.documentElement && document.documentElement.clientHeight || document.body && document.body.clientHeight;\n}\nfunction getWindowWidth() {\n return window.innerWidth || document.documentElement && document.documentElement.clientWidth || document.body && document.body.clientWidth;\n}\nfunction closestElementOfNode(node) {\n if (!node) {\n return null;\n }\n const el = node.nodeType === node.ELEMENT_NODE ? node : node.parentElement;\n return el;\n}\nfunction isBlocked(node, blockClass, blockSelector, checkAncestors) {\n if (!node) {\n return false;\n }\n const el = closestElementOfNode(node);\n if (!el) {\n return false;\n }\n try {\n if (typeof blockClass === \"string\") {\n if (el.classList.contains(blockClass)) return true;\n if (checkAncestors && el.closest(\".\" + blockClass) !== null) return true;\n } else {\n if (classMatchesRegex(el, blockClass, checkAncestors)) return true;\n }\n } catch (e2) {\n }\n if (blockSelector) {\n if (el.matches(blockSelector)) return true;\n if (checkAncestors && el.closest(blockSelector) !== null) return true;\n }\n return false;\n}\nfunction isSerialized(n2, mirror2) {\n return mirror2.getId(n2) !== -1;\n}\nfunction isIgnored(n2, mirror2, slimDOMOptions) {\n if (n2.tagName === \"TITLE\" && slimDOMOptions.headTitleMutations) {\n return true;\n }\n return mirror2.getId(n2) === IGNORED_NODE;\n}\nfunction isAncestorRemoved(target, mirror2) {\n if (isShadowRoot(target)) {\n return false;\n }\n const id = mirror2.getId(target);\n if (!mirror2.has(id)) {\n return true;\n }\n if (target.parentNode && target.parentNode.nodeType === target.DOCUMENT_NODE) {\n return false;\n }\n if (!target.parentNode) {\n return true;\n }\n return isAncestorRemoved(target.parentNode, mirror2);\n}\nfunction legacy_isTouchEvent(event) {\n return Boolean(event.changedTouches);\n}\nfunction polyfill$1(win = window) {\n if (\"NodeList\" in win && !win.NodeList.prototype.forEach) {\n win.NodeList.prototype.forEach = Array.prototype.forEach;\n }\n if (\"DOMTokenList\" in win && !win.DOMTokenList.prototype.forEach) {\n win.DOMTokenList.prototype.forEach = Array.prototype.forEach;\n }\n if (!Node.prototype.contains) {\n Node.prototype.contains = (...args) => {\n let node = args[0];\n if (!(0 in args)) {\n throw new TypeError(\"1 argument is required\");\n }\n do {\n if (this === node) {\n return true;\n }\n } while (node = node && node.parentNode);\n return false;\n };\n }\n}\nfunction queueToResolveTrees(queue) {\n const queueNodeMap = {};\n const putIntoMap = (m, parent) => {\n const nodeInTree = {\n value: m,\n parent,\n children: []\n };\n queueNodeMap[m.node.id] = nodeInTree;\n return nodeInTree;\n };\n const queueNodeTrees = [];\n for (const mutation of queue) {\n const { nextId, parentId } = mutation;\n if (nextId && nextId in queueNodeMap) {\n const nextInTree = queueNodeMap[nextId];\n if (nextInTree.parent) {\n const idx = nextInTree.parent.children.indexOf(nextInTree);\n nextInTree.parent.children.splice(\n idx,\n 0,\n putIntoMap(mutation, nextInTree.parent)\n );\n } else {\n const idx = queueNodeTrees.indexOf(nextInTree);\n queueNodeTrees.splice(idx, 0, putIntoMap(mutation, null));\n }\n continue;\n }\n if (parentId in queueNodeMap) {\n const parentInTree = queueNodeMap[parentId];\n parentInTree.children.push(putIntoMap(mutation, parentInTree));\n continue;\n }\n queueNodeTrees.push(putIntoMap(mutation, null));\n }\n return queueNodeTrees;\n}\nfunction iterateResolveTree(tree, cb) {\n cb(tree.value);\n for (let i2 = tree.children.length - 1; i2 >= 0; i2--) {\n iterateResolveTree(tree.children[i2], cb);\n }\n}\nfunction isSerializedIframe(n2, mirror2) {\n return Boolean(n2.nodeName === \"IFRAME\" && mirror2.getMeta(n2));\n}\nfunction isSerializedStylesheet(n2, mirror2) {\n return Boolean(\n n2.nodeName === \"LINK\" && n2.nodeType === n2.ELEMENT_NODE && n2.getAttribute && n2.getAttribute(\"rel\") === \"stylesheet\" && mirror2.getMeta(n2)\n );\n}\nfunction getBaseDimension(node, rootIframe) {\n var _a2, _b;\n const frameElement = (_b = (_a2 = node.ownerDocument) == null ? void 0 : _a2.defaultView) == null ? void 0 : _b.frameElement;\n if (!frameElement || frameElement === rootIframe) {\n return {\n x: 0,\n y: 0,\n relativeScale: 1,\n absoluteScale: 1\n };\n }\n const frameDimension = frameElement.getBoundingClientRect();\n const frameBaseDimension = getBaseDimension(frameElement, rootIframe);\n const relativeScale = frameDimension.height / frameElement.clientHeight;\n return {\n x: frameDimension.x * frameBaseDimension.relativeScale + frameBaseDimension.x,\n y: frameDimension.y * frameBaseDimension.relativeScale + frameBaseDimension.y,\n relativeScale,\n absoluteScale: frameBaseDimension.absoluteScale * relativeScale\n };\n}\nfunction hasShadowRoot(n2) {\n return Boolean(n2 == null ? void 0 : n2.shadowRoot);\n}\nfunction getNestedRule(rules2, position) {\n const rule = rules2[position[0]];\n if (position.length === 1) {\n return rule;\n } else {\n return getNestedRule(\n rule.cssRules[position[1]].cssRules,\n position.slice(2)\n );\n }\n}\nfunction getPositionsAndIndex(nestedIndex) {\n const positions = [...nestedIndex];\n const index = positions.pop();\n return { positions, index };\n}\nfunction uniqueTextMutations(mutations) {\n const idSet = /* @__PURE__ */ new Set();\n const uniqueMutations = [];\n for (let i2 = mutations.length; i2--; ) {\n const mutation = mutations[i2];\n if (!idSet.has(mutation.id)) {\n uniqueMutations.push(mutation);\n idSet.add(mutation.id);\n }\n }\n return uniqueMutations;\n}\nclass StyleSheetMirror {\n constructor() {\n __publicField(this, \"id\", 1);\n __publicField(this, \"styleIDMap\", /* @__PURE__ */ new WeakMap());\n __publicField(this, \"idStyleMap\", /* @__PURE__ */ new Map());\n }\n getId(stylesheet) {\n return this.styleIDMap.get(stylesheet) ?? -1;\n }\n has(stylesheet) {\n return this.styleIDMap.has(stylesheet);\n }\n /**\n * @returns If the stylesheet is in the mirror, returns the id of the stylesheet. If not, return the new assigned id.\n */\n add(stylesheet, id) {\n if (this.has(stylesheet)) return this.getId(stylesheet);\n let newId;\n if (id === void 0) {\n newId = this.id++;\n } else newId = id;\n this.styleIDMap.set(stylesheet, newId);\n this.idStyleMap.set(newId, stylesheet);\n return newId;\n }\n getStyle(id) {\n return this.idStyleMap.get(id) || null;\n }\n reset() {\n this.styleIDMap = /* @__PURE__ */ new WeakMap();\n this.idStyleMap = /* @__PURE__ */ new Map();\n this.id = 1;\n }\n generateId() {\n return this.id++;\n }\n}\nfunction getShadowHost(n2) {\n var _a2, _b;\n let shadowHost = null;\n if (((_b = (_a2 = n2.getRootNode) == null ? void 0 : _a2.call(n2)) == null ? void 0 : _b.nodeType) === Node.DOCUMENT_FRAGMENT_NODE && n2.getRootNode().host)\n shadowHost = n2.getRootNode().host;\n return shadowHost;\n}\nfunction getRootShadowHost(n2) {\n let rootShadowHost = n2;\n let shadowHost;\n while (shadowHost = getShadowHost(rootShadowHost))\n rootShadowHost = shadowHost;\n return rootShadowHost;\n}\nfunction shadowHostInDom(n2) {\n const doc = n2.ownerDocument;\n if (!doc) return false;\n const shadowHost = getRootShadowHost(n2);\n return doc.contains(shadowHost);\n}\nfunction inDom(n2) {\n const doc = n2.ownerDocument;\n if (!doc) return false;\n return doc.contains(n2) || shadowHostInDom(n2);\n}\nconst utils = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({\n __proto__: null,\n StyleSheetMirror,\n get _mirror() {\n return _mirror;\n },\n closestElementOfNode,\n getBaseDimension,\n getNestedRule,\n getPositionsAndIndex,\n getRootShadowHost,\n getShadowHost,\n getWindowHeight,\n getWindowScroll,\n getWindowWidth,\n hasShadowRoot,\n hookSetter,\n inDom,\n isAncestorRemoved,\n isBlocked,\n isIgnored,\n isSerialized,\n isSerializedIframe,\n isSerializedStylesheet,\n iterateResolveTree,\n legacy_isTouchEvent,\n get nowTimestamp() {\n return nowTimestamp;\n },\n on,\n patch,\n polyfill: polyfill$1,\n queueToResolveTrees,\n shadowHostInDom,\n throttle,\n uniqueTextMutations\n}, Symbol.toStringTag, { value: \"Module\" }));\nvar 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 MediaInteractions = /* @__PURE__ */ ((MediaInteractions2) => {\n MediaInteractions2[MediaInteractions2[\"Play\"] = 0] = \"Play\";\n MediaInteractions2[MediaInteractions2[\"Pause\"] = 1] = \"Pause\";\n MediaInteractions2[MediaInteractions2[\"Seeked\"] = 2] = \"Seeked\";\n MediaInteractions2[MediaInteractions2[\"VolumeChange\"] = 3] = \"VolumeChange\";\n MediaInteractions2[MediaInteractions2[\"RateChange\"] = 4] = \"RateChange\";\n return MediaInteractions2;\n})(MediaInteractions || {});\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 || {});\nfunction isNodeInLinkedList(n2) {\n return \"__ln\" in n2;\n}\nclass DoubleLinkedList {\n constructor() {\n __publicField(this, \"length\", 0);\n __publicField(this, \"head\", null);\n __publicField(this, \"tail\", null);\n }\n get(position) {\n if (position >= this.length) {\n throw new Error(\"Position outside of list range\");\n }\n let current = this.head;\n for (let index = 0; index < position; index++) {\n current = (current == null ? void 0 : current.next) || null;\n }\n return current;\n }\n addNode(n2) {\n const node = {\n value: n2,\n previous: null,\n next: null\n };\n n2.__ln = node;\n if (n2.previousSibling && isNodeInLinkedList(n2.previousSibling)) {\n const current = n2.previousSibling.__ln.next;\n node.next = current;\n node.previous = n2.previousSibling.__ln;\n n2.previousSibling.__ln.next = node;\n if (current) {\n current.previous = node;\n }\n } else if (n2.nextSibling && isNodeInLinkedList(n2.nextSibling) && n2.nextSibling.__ln.previous) {\n const current = n2.nextSibling.__ln.previous;\n node.previous = current;\n node.next = n2.nextSibling.__ln;\n n2.nextSibling.__ln.previous = node;\n if (current) {\n current.next = node;\n }\n } else {\n if (this.head) {\n this.head.previous = node;\n }\n node.next = this.head;\n this.head = node;\n }\n if (node.next === null) {\n this.tail = node;\n }\n this.length++;\n }\n removeNode(n2) {\n const current = n2.__ln;\n if (!this.head) {\n return;\n }\n if (!current.previous) {\n this.head = current.next;\n if (this.head) {\n this.head.previous = null;\n } else {\n this.tail = null;\n }\n } else {\n current.previous.next = current.next;\n if (current.next) {\n current.next.previous = current.previous;\n } else {\n this.tail = current.previous;\n }\n }\n if (n2.__ln) {\n delete n2.__ln;\n }\n this.length--;\n }\n}\nconst moveKey = (id, parentId) => `${id}@${parentId}`;\nclass MutationBuffer {\n constructor() {\n __publicField(this, \"frozen\", false);\n __publicField(this, \"locked\", false);\n __publicField(this, \"texts\", []);\n __publicField(this, \"attributes\", []);\n __publicField(this, \"attributeMap\", /* @__PURE__ */ new WeakMap());\n __publicField(this, \"removes\", []);\n __publicField(this, \"mapRemoves\", []);\n __publicField(this, \"movedMap\", {});\n /**\n * the browser MutationObserver emits multiple mutations after\n * a delay for performance reasons, making tracing added nodes hard\n * in our `processMutations` callback function.\n * For example, if we append an element el_1 into body, and then append\n * another element el_2 into el_1, these two mutations may be passed to the\n * callback function together when the two operations were done.\n * Generally we need to trace child nodes of newly added nodes, but in this\n * case if we count el_2 as el_1's child node in the first mutation record,\n * then we will count el_2 again in the second mutation record which was\n * duplicated.\n * To avoid of duplicate counting added nodes, we use a Set to store\n * added nodes and its child nodes during iterate mutation records. Then\n * collect added nodes from the Set which have no duplicate copy. But\n * this also causes newly added nodes will not be serialized with id ASAP,\n * which means all the id related calculation should be lazy too.\n */\n __publicField(this, \"addedSet\", /* @__PURE__ */ new Set());\n __publicField(this, \"movedSet\", /* @__PURE__ */ new Set());\n __publicField(this, \"droppedSet\", /* @__PURE__ */ new Set());\n __publicField(this, \"mutationCb\");\n __publicField(this, \"blockClass\");\n __publicField(this, \"blockSelector\");\n __publicField(this, \"maskTextClass\");\n __publicField(this, \"maskTextSelector\");\n __publicField(this, \"inlineStylesheet\");\n __publicField(this, \"maskInputOptions\");\n __publicField(this, \"maskTextFn\");\n __publicField(this, \"maskInputFn\");\n __publicField(this, \"keepIframeSrcFn\");\n __publicField(this, \"recordCanvas\");\n __publicField(this, \"inlineImages\");\n __publicField(this, \"slimDOMOptions\");\n __publicField(this, \"dataURLOptions\");\n __publicField(this, \"doc\");\n __publicField(this, \"mirror\");\n __publicField(this, \"iframeManager\");\n __publicField(this, \"stylesheetManager\");\n __publicField(this, \"shadowDomManager\");\n __publicField(this, \"canvasManager\");\n __publicField(this, \"processedNodeManager\");\n __publicField(this, \"unattachedDoc\");\n __publicField(this, \"processMutations\", (mutations) => {\n mutations.forEach(this.processMutation);\n this.emit();\n });\n __publicField(this, \"emit\", () => {\n if (this.frozen || this.locked) {\n return;\n }\n const adds = [];\n const addedIds = /* @__PURE__ */ new Set();\n const addList = new DoubleLinkedList();\n const getNextId = (n2) => {\n let ns = n2;\n let nextId = IGNORED_NODE;\n while (nextId === IGNORED_NODE) {\n ns = ns && ns.nextSibling;\n nextId = ns && this.mirror.getId(ns);\n }\n return nextId;\n };\n const pushAdd = (n2) => {\n if (!n2.parentNode || !inDom(n2) || n2.parentNode.tagName === \"TEXTAREA\") {\n return;\n }\n const parentId = isShadowRoot(n2.parentNode) ? this.mirror.getId(getShadowHost(n2)) : this.mirror.getId(n2.parentNode);\n const nextId = getNextId(n2);\n if (parentId === -1 || nextId === -1) {\n return addList.addNode(n2);\n }\n const sn = serializeNodeWithId(n2, {\n doc: this.doc,\n mirror: this.mirror,\n blockClass: this.blockClass,\n blockSelector: this.blockSelector,\n maskTextClass: this.maskTextClass,\n maskTextSelector: this.maskTextSelector,\n skipChild: true,\n newlyAddedElement: true,\n inlineStylesheet: this.inlineStylesheet,\n maskInputOptions: this.maskInputOptions,\n maskTextFn: this.maskTextFn,\n maskInputFn: this.maskInputFn,\n slimDOMOptions: this.slimDOMOptions,\n dataURLOptions: this.dataURLOptions,\n recordCanvas: this.recordCanvas,\n inlineImages: this.inlineImages,\n onSerialize: (currentN) => {\n if (isSerializedIframe(currentN, this.mirror)) {\n this.iframeManager.addIframe(currentN);\n }\n if (isSerializedStylesheet(currentN, this.mirror)) {\n this.stylesheetManager.trackLinkElement(\n currentN\n );\n }\n if (hasShadowRoot(n2)) {\n this.shadowDomManager.addShadowRoot(n2.shadowRoot, this.doc);\n }\n },\n onIframeLoad: (iframe, childSn) => {\n this.iframeManager.attachIframe(iframe, childSn);\n this.shadowDomManager.observeAttachShadow(iframe);\n },\n onStylesheetLoad: (link, childSn) => {\n this.stylesheetManager.attachLinkElement(link, childSn);\n }\n });\n if (sn) {\n adds.push({\n parentId,\n nextId,\n node: sn\n });\n addedIds.add(sn.id);\n }\n };\n while (this.mapRemoves.length) {\n this.mirror.removeNodeFromMap(this.mapRemoves.shift());\n }\n for (const n2 of this.movedSet) {\n if (isParentRemoved(this.removes, n2, this.mirror) && !this.movedSet.has(n2.parentNode)) {\n continue;\n }\n pushAdd(n2);\n }\n for (const n2 of this.addedSet) {\n if (!isAncestorInSet(this.droppedSet, n2) && !isParentRemoved(this.removes, n2, this.mirror)) {\n pushAdd(n2);\n } else if (isAncestorInSet(this.movedSet, n2)) {\n pushAdd(n2);\n } else {\n this.droppedSet.add(n2);\n }\n }\n let candidate = null;\n while (addList.length) {\n let node = null;\n if (candidate) {\n const parentId = this.mirror.getId(candidate.value.parentNode);\n const nextId = getNextId(candidate.value);\n if (parentId !== -1 && nextId !== -1) {\n node = candidate;\n }\n }\n if (!node) {\n let tailNode = addList.tail;\n while (tailNode) {\n const _node = tailNode;\n tailNode = tailNode.previous;\n if (_node) {\n const parentId = this.mirror.getId(_node.value.parentNode);\n const nextId = getNextId(_node.value);\n if (nextId === -1) continue;\n else if (parentId !== -1) {\n node = _node;\n break;\n } else {\n const unhandledNode = _node.value;\n if (unhandledNode.parentNode && unhandledNode.parentNode.nodeType === Node.DOCUMENT_FRAGMENT_NODE) {\n const shadowHost = unhandledNode.parentNode.host;\n const parentId2 = this.mirror.getId(shadowHost);\n if (parentId2 !== -1) {\n node = _node;\n break;\n }\n }\n }\n }\n }\n }\n if (!node) {\n while (addList.head) {\n addList.removeNode(addList.head.value);\n }\n break;\n }\n candidate = node.previous;\n addList.removeNode(node.value);\n pushAdd(node.value);\n }\n const payload = {\n texts: this.texts.map((text) => {\n const n2 = text.node;\n if (n2.parentNode && n2.parentNode.tagName === \"TEXTAREA\") {\n this.genTextAreaValueMutation(n2.parentNode);\n }\n return {\n id: this.mirror.getId(n2),\n value: text.value\n };\n }).filter((text) => !addedIds.has(text.id)).filter((text) => this.mirror.has(text.id)),\n attributes: this.attributes.map((attribute) => {\n const { attributes } = attribute;\n if (typeof attributes.style === \"string\") {\n const diffAsStr = JSON.stringify(attribute.styleDiff);\n const unchangedAsStr = JSON.stringify(attribute._unchangedStyles);\n if (diffAsStr.length < attributes.style.length) {\n if ((diffAsStr + unchangedAsStr).split(\"var(\").length === attributes.style.split(\"var(\").length) {\n attributes.style = attribute.styleDiff;\n }\n }\n }\n return {\n id: this.mirror.getId(attribute.node),\n attributes\n };\n }).filter((attribute) => !addedIds.has(attribute.id)).filter((attribute) => this.mirror.has(attribute.id)),\n removes: this.removes,\n adds\n };\n if (!payload.texts.length && !payload.attributes.length && !payload.removes.length && !payload.adds.length) {\n return;\n }\n this.texts = [];\n this.attributes = [];\n this.attributeMap = /* @__PURE__ */ new WeakMap();\n this.removes = [];\n this.addedSet = /* @__PURE__ */ new Set();\n this.movedSet = /* @__PURE__ */ new Set();\n this.droppedSet = /* @__PURE__ */ new Set();\n this.movedMap = {};\n this.mutationCb(payload);\n });\n __publicField(this, \"genTextAreaValueMutation\", (textarea) => {\n let item = this.attributeMap.get(textarea);\n if (!item) {\n item = {\n node: textarea,\n attributes: {},\n styleDiff: {},\n _unchangedStyles: {}\n };\n this.attributes.push(item);\n this.attributeMap.set(textarea, item);\n }\n item.attributes.value = Array.from(\n textarea.childNodes,\n (cn) => cn.textContent || \"\"\n ).join(\"\");\n });\n __publicField(this, \"processMutation\", (m) => {\n if (isIgnored(m.target, this.mirror, this.slimDOMOptions)) {\n return;\n }\n switch (m.type) {\n case \"characterData\": {\n const value = m.target.textContent;\n if (!isBlocked(m.target, this.blockClass, this.blockSelector, false) && value !== m.oldValue) {\n this.texts.push({\n value: needMaskingText(\n m.target,\n this.maskTextClass,\n this.maskTextSelector,\n true\n // checkAncestors\n ) && value ? this.maskTextFn ? this.maskTextFn(value, closestElementOfNode(m.target)) : value.replace(/[\\S]/g, \"*\") : value,\n node: m.target\n });\n }\n break;\n }\n case \"attributes\": {\n const target = m.target;\n let attributeName = m.attributeName;\n let value = m.target.getAttribute(attributeName);\n if (attributeName === \"value\") {\n const type = getInputType(target);\n value = maskInputValue({\n element: target,\n maskInputOptions: this.maskInputOptions,\n tagName: target.tagName,\n type,\n value,\n maskInputFn: this.maskInputFn\n });\n }\n if (isBlocked(m.target, this.blockClass, this.blockSelector, false) || value === m.oldValue) {\n return;\n }\n let item = this.attributeMap.get(m.target);\n if (target.tagName === \"IFRAME\" && attributeName === \"src\" && !this.keepIframeSrcFn(value)) {\n if (!target.contentDocument) {\n attributeName = \"rr_src\";\n } else {\n return;\n }\n }\n if (!item) {\n item = {\n node: m.target,\n attributes: {},\n styleDiff: {},\n _unchangedStyles: {}\n };\n this.attributes.push(item);\n this.attributeMap.set(m.target, item);\n }\n if (attributeName === \"type\" && target.tagName === \"INPUT\" && (m.oldValue || \"\").toLowerCase() === \"password\") {\n target.setAttribute(\"data-rr-is-password\", \"true\");\n }\n if (!ignoreAttribute(target.tagName, attributeName)) {\n item.attributes[attributeName] = transformAttribute(\n this.doc,\n toLowerCase(target.tagName),\n toLowerCase(attributeName),\n value\n );\n if (attributeName === \"style\") {\n if (!this.unattachedDoc) {\n try {\n this.unattachedDoc = document.implementation.createHTMLDocument();\n } catch (e2) {\n this.unattachedDoc = this.doc;\n }\n }\n const old = this.unattachedDoc.createElement(\"span\");\n if (m.oldValue) {\n old.setAttribute(\"style\", m.oldValue);\n }\n for (const pname of Array.from(target.style)) {\n const newValue = target.style.getPropertyValue(pname);\n const newPriority = target.style.getPropertyPriority(pname);\n if (newValue !== old.style.getPropertyValue(pname) || newPriority !== old.style.getPropertyPriority(pname)) {\n if (newPriority === \"\") {\n item.styleDiff[pname] = newValue;\n } else {\n item.styleDiff[pname] = [newValue, newPriority];\n }\n } else {\n item._unchangedStyles[pname] = [newValue, newPriority];\n }\n }\n for (const pname of Array.from(old.style)) {\n if (target.style.getPropertyValue(pname) === \"\") {\n item.styleDiff[pname] = false;\n }\n }\n }\n }\n break;\n }\n case \"childList\": {\n if (isBlocked(m.target, this.blockClass, this.blockSelector, true))\n return;\n if (m.target.tagName === \"TEXTAREA\") {\n this.genTextAreaValueMutation(m.target);\n return;\n }\n m.addedNodes.forEach((n2) => this.genAdds(n2, m.target));\n m.removedNodes.forEach((n2) => {\n const nodeId = this.mirror.getId(n2);\n const parentId = isShadowRoot(m.target) ? this.mirror.getId(m.target.host) : this.mirror.getId(m.target);\n if (isBlocked(m.target, this.blockClass, this.blockSelector, false) || isIgnored(n2, this.mirror, this.slimDOMOptions) || !isSerialized(n2, this.mirror)) {\n return;\n }\n if (this.addedSet.has(n2)) {\n deepDelete(this.addedSet, n2);\n this.droppedSet.add(n2);\n } else if (this.addedSet.has(m.target) && nodeId === -1) ;\n else if (isAncestorRemoved(m.target, this.mirror)) ;\n else if (this.movedSet.has(n2) && this.movedMap[moveKey(nodeId, parentId)]) {\n deepDelete(this.movedSet, n2);\n } else {\n this.removes.push({\n parentId,\n id: nodeId,\n isShadow: isShadowRoot(m.target) && isNativeShadowDom(m.target) ? true : void 0\n });\n }\n this.mapRemoves.push(n2);\n });\n break;\n }\n }\n });\n /**\n * Make sure you check if `n`'s parent is blocked before calling this function\n * */\n __publicField(this, \"genAdds\", (n2, target) => {\n if (this.processedNodeManager.inOtherBuffer(n2, this)) return;\n if (this.addedSet.has(n2) || this.movedSet.has(n2)) return;\n if (this.mirror.hasNode(n2)) {\n if (isIgnored(n2, this.mirror, this.slimDOMOptions)) {\n return;\n }\n this.movedSet.add(n2);\n let targetId = null;\n if (target && this.mirror.hasNode(target)) {\n targetId = this.mirror.getId(target);\n }\n if (targetId && targetId !== -1) {\n this.movedMap[moveKey(this.mirror.getId(n2), targetId)] = true;\n }\n } else {\n this.addedSet.add(n2);\n this.droppedSet.delete(n2);\n }\n if (!isBlocked(n2, this.blockClass, this.blockSelector, false)) {\n n2.childNodes.forEach((childN) => this.genAdds(childN));\n if (hasShadowRoot(n2)) {\n n2.shadowRoot.childNodes.forEach((childN) => {\n this.processedNodeManager.add(childN, this);\n this.genAdds(childN, n2);\n });\n }\n }\n });\n }\n init(options) {\n [\n \"mutationCb\",\n \"blockClass\",\n \"blockSelector\",\n \"maskTextClass\",\n \"maskTextSelector\",\n \"inlineStylesheet\",\n \"maskInputOptions\",\n \"maskTextFn\",\n \"maskInputFn\",\n \"keepIframeSrcFn\",\n \"recordCanvas\",\n \"inlineImages\",\n \"slimDOMOptions\",\n \"dataURLOptions\",\n \"doc\",\n \"mirror\",\n \"iframeManager\",\n \"stylesheetManager\",\n \"shadowDomManager\",\n \"canvasManager\",\n \"processedNodeManager\"\n ].forEach((key) => {\n this[key] = options[key];\n });\n }\n freeze() {\n this.frozen = true;\n this.canvasManager.freeze();\n }\n unfreeze() {\n this.frozen = false;\n this.canvasManager.unfreeze();\n this.emit();\n }\n isFrozen() {\n return this.frozen;\n }\n lock() {\n this.locked = true;\n this.canvasManager.lock();\n }\n unlock() {\n this.locked = false;\n this.canvasManager.unlock();\n this.emit();\n }\n reset() {\n this.shadowDomManager.reset();\n this.canvasManager.reset();\n }\n}\nfunction deepDelete(addsSet, n2) {\n addsSet.delete(n2);\n n2.childNodes.forEach((childN) => deepDelete(addsSet, childN));\n}\nfunction isParentRemoved(removes, n2, mirror2) {\n if (removes.length === 0) return false;\n return _isParentRemoved(removes, n2, mirror2);\n}\nfunction _isParentRemoved(removes, n2, mirror2) {\n let node = n2.parentNode;\n while (node) {\n const parentId = mirror2.getId(node);\n if (removes.some((r2) => r2.id === parentId)) {\n return true;\n }\n node = node.parentNode;\n }\n return false;\n}\nfunction isAncestorInSet(set, n2) {\n if (set.size === 0) return false;\n return _isAncestorInSet(set, n2);\n}\nfunction _isAncestorInSet(set, n2) {\n const { parentNode } = n2;\n if (!parentNode) {\n return false;\n }\n if (set.has(parentNode)) {\n return true;\n }\n return _isAncestorInSet(set, parentNode);\n}\nlet errorHandler;\nfunction registerErrorHandler(handler) {\n errorHandler = handler;\n}\nfunction unregisterErrorHandler() {\n errorHandler = void 0;\n}\nconst callbackWrapper = (cb) => {\n if (!errorHandler) {\n return cb;\n }\n const rrwebWrapped = (...rest) => {\n try {\n return cb(...rest);\n } catch (error) {\n if (errorHandler && errorHandler(error) === true) {\n return;\n }\n throw error;\n }\n };\n return rrwebWrapped;\n};\nconst mutationBuffers = [];\nfunction getEventTarget(event) {\n try {\n if (\"composedPath\" in event) {\n const path = event.composedPath();\n if (path.length) {\n return path[0];\n }\n } else if (\"path\" in event && event.path.length) {\n return event.path[0];\n }\n } catch {\n }\n return event && event.target;\n}\nfunction initMutationObserver(options, rootEl) {\n var _a2, _b;\n const mutationBuffer = new MutationBuffer();\n mutationBuffers.push(mutationBuffer);\n mutationBuffer.init(options);\n let mutationObserverCtor = window.MutationObserver || /**\n * Some websites may disable MutationObserver by removing it from the window object.\n * If someone is using rrweb to build a browser extention or things like it, they\n * could not change the website's code but can have an opportunity to inject some\n * code before the website executing its JS logic.\n * Then they can do this to store the native MutationObserver:\n * window.__rrMutationObserver = MutationObserver\n */\n window.__rrMutationObserver;\n const angularZoneSymbol = (_b = (_a2 = window == null ? void 0 : window.Zone) == null ? void 0 : _a2.__symbol__) == null ? void 0 : _b.call(_a2, \"MutationObserver\");\n if (angularZoneSymbol && window[angularZoneSymbol]) {\n mutationObserverCtor = window[angularZoneSymbol];\n }\n const observer = new mutationObserverCtor(\n callbackWrapper(mutationBuffer.processMutations.bind(mutationBuffer))\n );\n observer.observe(rootEl, {\n attributes: true,\n attributeOldValue: true,\n characterData: true,\n characterDataOldValue: true,\n childList: true,\n subtree: true\n });\n return observer;\n}\nfunction initMoveObserver({\n mousemoveCb,\n sampling,\n doc,\n mirror: mirror2\n}) {\n if (sampling.mousemove === false) {\n return () => {\n };\n }\n const threshold = typeof sampling.mousemove === \"number\" ? sampling.mousemove : 50;\n const callbackThreshold = typeof sampling.mousemoveCallback === \"number\" ? sampling.mousemoveCallback : 500;\n let positions = [];\n let timeBaseline;\n const wrappedCb = throttle(\n callbackWrapper(\n (source) => {\n const totalOffset = Date.now() - timeBaseline;\n mousemoveCb(\n positions.map((p) => {\n p.timeOffset -= totalOffset;\n return p;\n }),\n source\n );\n positions = [];\n timeBaseline = null;\n }\n ),\n callbackThreshold\n );\n const updatePosition = callbackWrapper(\n throttle(\n callbackWrapper((evt) => {\n const target = getEventTarget(evt);\n const { clientX, clientY } = legacy_isTouchEvent(evt) ? evt.changedTouches[0] : evt;\n if (!timeBaseline) {\n timeBaseline = nowTimestamp();\n }\n positions.push({\n x: clientX,\n y: clientY,\n id: mirror2.getId(target),\n timeOffset: nowTimestamp() - timeBaseline\n });\n wrappedCb(\n typeof DragEvent !== \"undefined\" && evt instanceof DragEvent ? IncrementalSource.Drag : evt instanceof MouseEvent ? IncrementalSource.MouseMove : IncrementalSource.TouchMove\n );\n }),\n threshold,\n {\n trailing: false\n }\n )\n );\n const handlers = [\n on(\"mousemove\", updatePosition, doc),\n on(\"touchmove\", updatePosition, doc),\n on(\"drag\", updatePosition, doc)\n ];\n return callbackWrapper(() => {\n handlers.forEach((h) => h());\n });\n}\nfunction initMouseInteractionObserver({\n mouseInteractionCb,\n doc,\n mirror: mirror2,\n blockClass,\n blockSelector,\n sampling\n}) {\n if (sampling.mouseInteraction === false) {\n return () => {\n };\n }\n const disableMap = sampling.mouseInteraction === true || sampling.mouseInteraction === void 0 ? {} : sampling.mouseInteraction;\n const handlers = [];\n let currentPointerType = null;\n const getHandler = (eventKey) => {\n return (event) => {\n const target = getEventTarget(event);\n if (isBlocked(target, blockClass, blockSelector, true)) {\n return;\n }\n let pointerType = null;\n let thisEventKey = eventKey;\n if (\"pointerType\" in event) {\n switch (event.pointerType) {\n case \"mouse\":\n pointerType = PointerTypes.Mouse;\n break;\n case \"touch\":\n pointerType = PointerTypes.Touch;\n break;\n case \"pen\":\n pointerType = PointerTypes.Pen;\n break;\n }\n if (pointerType === PointerTypes.Touch) {\n if (MouseInteractions[eventKey] === MouseInteractions.MouseDown) {\n thisEventKey = \"TouchStart\";\n } else if (MouseInteractions[eventKey] === MouseInteractions.MouseUp) {\n thisEventKey = \"TouchEnd\";\n }\n } else if (pointerType === PointerTypes.Pen) ;\n } else if (legacy_isTouchEvent(event)) {\n pointerType = PointerTypes.Touch;\n }\n if (pointerType !== null) {\n currentPointerType = pointerType;\n if (thisEventKey.startsWith(\"Touch\") && pointerType === PointerTypes.Touch || thisEventKey.startsWith(\"Mouse\") && pointerType === PointerTypes.Mouse) {\n pointerType = null;\n }\n } else if (MouseInteractions[eventKey] === MouseInteractions.Click) {\n pointerType = currentPointerType;\n currentPointerType = null;\n }\n const e2 = legacy_isTouchEvent(event) ? event.changedTouches[0] : event;\n if (!e2) {\n return;\n }\n const id = mirror2.getId(target);\n const { clientX, clientY } = e2;\n callbackWrapper(mouseInteractionCb)({\n type: MouseInteractions[thisEventKey],\n id,\n x: clientX,\n y: clientY,\n ...pointerType !== null && { pointerType }\n });\n };\n };\n Object.keys(MouseInteractions).filter(\n (key) => Number.isNaN(Number(key)) && !key.endsWith(\"_Departed\") && disableMap[key] !== false\n ).forEach((eventKey) => {\n let eventName = toLowerCase(eventKey);\n const handler = getHandler(eventKey);\n if (window.PointerEvent) {\n switch (MouseInteractions[eventKey]) {\n case MouseInteractions.MouseDown:\n case MouseInteractions.MouseUp:\n eventName = eventName.replace(\n \"mouse\",\n \"pointer\"\n );\n break;\n case MouseInteractions.TouchStart:\n case MouseInteractions.TouchEnd:\n return;\n }\n }\n handlers.push(on(eventName, handler, doc));\n });\n return callbackWrapper(() => {\n handlers.forEach((h) => h());\n });\n}\nfunction initScrollObserver({\n scrollCb,\n doc,\n mirror: mirror2,\n blockClass,\n blockSelector,\n sampling\n}) {\n const updatePosition = callbackWrapper(\n throttle(\n callbackWrapper((evt) => {\n const target = getEventTarget(evt);\n if (!target || isBlocked(target, blockClass, blockSelector, true)) {\n return;\n }\n const id = mirror2.getId(target);\n if (target === doc && doc.defaultView) {\n const scrollLeftTop = getWindowScroll(doc.defaultView);\n scrollCb({\n id,\n x: scrollLeftTop.left,\n y: scrollLeftTop.top\n });\n } else {\n scrollCb({\n id,\n x: target.scrollLeft,\n y: target.scrollTop\n });\n }\n }),\n sampling.scroll || 100\n )\n );\n return on(\"scroll\", updatePosition, doc);\n}\nfunction initViewportResizeObserver({ viewportResizeCb }, { win }) {\n let lastH = -1;\n let lastW = -1;\n const updateDimension = callbackWrapper(\n throttle(\n callbackWrapper(() => {\n const height = getWindowHeight();\n const width = getWindowWidth();\n if (lastH !== height || lastW !== width) {\n viewportResizeCb({\n width: Number(width),\n height: Number(height)\n });\n lastH = height;\n lastW = width;\n }\n }),\n 200\n )\n );\n return on(\"resize\", updateDimension, win);\n}\nconst INPUT_TAGS = [\"INPUT\", \"TEXTAREA\", \"SELECT\"];\nconst lastInputValueMap = /* @__PURE__ */ new WeakMap();\nfunction initInputObserver({\n inputCb,\n doc,\n mirror: mirror2,\n blockClass,\n blockSelector,\n ignoreClass,\n ignoreSelector,\n maskInputOptions,\n maskInputFn,\n sampling,\n userTriggeredOnInput\n}) {\n function eventHandler(event) {\n let target = getEventTarget(event);\n const userTriggered = event.isTrusted;\n const tagName = target && target.tagName;\n if (target && tagName === \"OPTION\") {\n target = target.parentElement;\n }\n if (!target || !tagName || INPUT_TAGS.indexOf(tagName) < 0 || isBlocked(target, blockClass, blockSelector, true)) {\n return;\n }\n if (target.classList.contains(ignoreClass) || ignoreSelector && target.matches(ignoreSelector)) {\n return;\n }\n let text = target.value;\n let isChecked = false;\n const type = getInputType(target) || \"\";\n if (type === \"radio\" || type === \"checkbox\") {\n isChecked = target.checked;\n } else if (maskInputOptions[tagName.toLowerCase()] || maskInputOptions[type]) {\n text = maskInputValue({\n element: target,\n maskInputOptions,\n tagName,\n type,\n value: text,\n maskInputFn\n });\n }\n cbWithDedup(\n target,\n userTriggeredOnInput ? { text, isChecked, userTriggered } : { text, isChecked }\n );\n const name = target.name;\n if (type === \"radio\" && name && isChecked) {\n doc.querySelectorAll(`input[type=\"radio\"][name=\"${name}\"]`).forEach((el) => {\n if (el !== target) {\n const text2 = el.value;\n cbWithDedup(\n el,\n userTriggeredOnInput ? { text: text2, isChecked: !isChecked, userTriggered: false } : { text: text2, isChecked: !isChecked }\n );\n }\n });\n }\n }\n function cbWithDedup(target, v2) {\n const lastInputValue = lastInputValueMap.get(target);\n if (!lastInputValue || lastInputValue.text !== v2.text || lastInputValue.isChecked !== v2.isChecked) {\n lastInputValueMap.set(target, v2);\n const id = mirror2.getId(target);\n callbackWrapper(inputCb)({\n ...v2,\n id\n });\n }\n }\n const events = sampling.input === \"last\" ? [\"change\"] : [\"input\", \"change\"];\n const handlers = events.map(\n (eventName) => on(eventName, callbackWrapper(eventHandler), doc)\n );\n const currentWindow = doc.defaultView;\n if (!currentWindow) {\n return () => {\n handlers.forEach((h) => h());\n };\n }\n const propertyDescriptor = currentWindow.Object.getOwnPropertyDescriptor(\n currentWindow.HTMLInputElement.prototype,\n \"value\"\n );\n const hookProperties = [\n [currentWindow.HTMLInputElement.prototype, \"value\"],\n [currentWindow.HTMLInputElement.prototype, \"checked\"],\n [currentWindow.HTMLSelectElement.prototype, \"value\"],\n [currentWindow.HTMLTextAreaElement.prototype, \"value\"],\n // Some UI library use selectedIndex to set select value\n [currentWindow.HTMLSelectElement.prototype, \"selectedIndex\"],\n [currentWindow.HTMLOptionElement.prototype, \"selected\"]\n ];\n if (propertyDescriptor && propertyDescriptor.set) {\n handlers.push(\n ...hookProperties.map(\n (p) => hookSetter(\n p[0],\n p[1],\n {\n set() {\n callbackWrapper(eventHandler)({\n target: this,\n isTrusted: false\n // userTriggered to false as this could well be programmatic\n });\n }\n },\n false,\n currentWindow\n )\n )\n );\n }\n return callbackWrapper(() => {\n handlers.forEach((h) => h());\n });\n}\nfunction getNestedCSSRulePositions(rule) {\n const positions = [];\n function recurse(childRule, pos) {\n if (hasNestedCSSRule(\"CSSGroupingRule\") && childRule.parentRule instanceof CSSGroupingRule || hasNestedCSSRule(\"CSSMediaRule\") && childRule.parentRule instanceof CSSMediaRule || hasNestedCSSRule(\"CSSSupportsRule\") && childRule.parentRule instanceof CSSSupportsRule || hasNestedCSSRule(\"CSSConditionRule\") && childRule.parentRule instanceof CSSConditionRule) {\n const rules2 = Array.from(\n childRule.parentRule.cssRules\n );\n const index = rules2.indexOf(childRule);\n pos.unshift(index);\n } else if (childRule.parentStyleSheet) {\n const rules2 = Array.from(childRule.parentStyleSheet.cssRules);\n const index = rules2.indexOf(childRule);\n pos.unshift(index);\n }\n return pos;\n }\n return recurse(rule, positions);\n}\nfunction getIdAndStyleId(sheet, mirror2, styleMirror) {\n let id, styleId;\n if (!sheet) return {};\n if (sheet.ownerNode) id = mirror2.getId(sheet.ownerNode);\n else styleId = styleMirror.getId(sheet);\n return {\n styleId,\n id\n };\n}\nfunction initStyleSheetObserver({ styleSheetRuleCb, mirror: mirror2, stylesheetManager }, { win }) {\n if (!win.CSSStyleSheet || !win.CSSStyleSheet.prototype) {\n return () => {\n };\n }\n const insertRule = win.CSSStyleSheet.prototype.insertRule;\n win.CSSStyleSheet.prototype.insertRule = new Proxy(insertRule, {\n apply: callbackWrapper(\n (target, thisArg, argumentsList) => {\n const [rule, index] = argumentsList;\n const { id, styleId } = getIdAndStyleId(\n thisArg,\n mirror2,\n stylesheetManager.styleMirror\n );\n if (id && id !== -1 || styleId && styleId !== -1) {\n styleSheetRuleCb({\n id,\n styleId,\n adds: [{ rule, index }]\n });\n }\n return target.apply(thisArg, argumentsList);\n }\n )\n });\n const deleteRule = win.CSSStyleSheet.prototype.deleteRule;\n win.CSSStyleSheet.prototype.deleteRule = new Proxy(deleteRule, {\n apply: callbackWrapper(\n (target, thisArg, argumentsList) => {\n const [index] = argumentsList;\n const { id, styleId } = getIdAndStyleId(\n thisArg,\n mirror2,\n stylesheetManager.styleMirror\n );\n if (id && id !== -1 || styleId && styleId !== -1) {\n styleSheetRuleCb({\n id,\n styleId,\n removes: [{ index }]\n });\n }\n return target.apply(thisArg, argumentsList);\n }\n )\n });\n let replace;\n if (win.CSSStyleSheet.prototype.replace) {\n replace = win.CSSStyleSheet.prototype.replace;\n win.CSSStyleSheet.prototype.replace = new Proxy(replace, {\n apply: callbackWrapper(\n (target, thisArg, argumentsList) => {\n const [text] = argumentsList;\n const { id, styleId } = getIdAndStyleId(\n thisArg,\n mirror2,\n stylesheetManager.styleMirror\n );\n if (id && id !== -1 || styleId && styleId !== -1) {\n styleSheetRuleCb({\n id,\n styleId,\n replace: text\n });\n }\n return target.apply(thisArg, argumentsList);\n }\n )\n });\n }\n let replaceSync;\n if (win.CSSStyleSheet.prototype.replaceSync) {\n replaceSync = win.CSSStyleSheet.prototype.replaceSync;\n win.CSSStyleSheet.prototype.replaceSync = new Proxy(replaceSync, {\n apply: callbackWrapper(\n (target, thisArg, argumentsList) => {\n const [text] = argumentsList;\n const { id, styleId } = getIdAndStyleId(\n thisArg,\n mirror2,\n stylesheetManager.styleMirror\n );\n if (id && id !== -1 || styleId && styleId !== -1) {\n styleSheetRuleCb({\n id,\n styleId,\n replaceSync: text\n });\n }\n return target.apply(thisArg, argumentsList);\n }\n )\n });\n }\n const supportedNestedCSSRuleTypes = {};\n if (canMonkeyPatchNestedCSSRule(\"CSSGroupingRule\")) {\n supportedNestedCSSRuleTypes.CSSGroupingRule = win.CSSGroupingRule;\n } else {\n if (canMonkeyPatchNestedCSSRule(\"CSSMediaRule\")) {\n supportedNestedCSSRuleTypes.CSSMediaRule = win.CSSMediaRule;\n }\n if (canMonkeyPatchNestedCSSRule(\"CSSConditionRule\")) {\n supportedNestedCSSRuleTypes.CSSConditionRule = win.CSSConditionRule;\n }\n if (canMonkeyPatchNestedCSSRule(\"CSSSupportsRule\")) {\n supportedNestedCSSRuleTypes.CSSSupportsRule = win.CSSSupportsRule;\n }\n }\n const unmodifiedFunctions = {};\n Object.entries(supportedNestedCSSRuleTypes).forEach(([typeKey, type]) => {\n unmodifiedFunctions[typeKey] = {\n // eslint-disable-next-line @typescript-eslint/unbound-method\n insertRule: type.prototype.insertRule,\n // eslint-disable-next-line @typescript-eslint/unbound-method\n deleteRule: type.prototype.deleteRule\n };\n type.prototype.insertRule = new Proxy(\n unmodifiedFunctions[typeKey].insertRule,\n {\n apply: callbackWrapper(\n (target, thisArg, argumentsList) => {\n const [rule, index] = argumentsList;\n const { id, styleId } = getIdAndStyleId(\n thisArg.parentStyleSheet,\n mirror2,\n stylesheetManager.styleMirror\n );\n if (id && id !== -1 || styleId && styleId !== -1) {\n styleSheetRuleCb({\n id,\n styleId,\n adds: [\n {\n rule,\n index: [\n ...getNestedCSSRulePositions(thisArg),\n index || 0\n // defaults to 0\n ]\n }\n ]\n });\n }\n return target.apply(thisArg, argumentsList);\n }\n )\n }\n );\n type.prototype.deleteRule = new Proxy(\n unmodifiedFunctions[typeKey].deleteRule,\n {\n apply: callbackWrapper(\n (target, thisArg, argumentsList) => {\n const [index] = argumentsList;\n const { id, styleId } = getIdAndStyleId(\n thisArg.parentStyleSheet,\n mirror2,\n stylesheetManager.styleMirror\n );\n if (id && id !== -1 || styleId && styleId !== -1) {\n styleSheetRuleCb({\n id,\n styleId,\n removes: [\n { index: [...getNestedCSSRulePositions(thisArg), index] }\n ]\n });\n }\n return target.apply(thisArg, argumentsList);\n }\n )\n }\n );\n });\n return callbackWrapper(() => {\n win.CSSStyleSheet.prototype.insertRule = insertRule;\n win.CSSStyleSheet.prototype.deleteRule = deleteRule;\n replace && (win.CSSStyleSheet.prototype.replace = replace);\n replaceSync && (win.CSSStyleSheet.prototype.replaceSync = replaceSync);\n Object.entries(supportedNestedCSSRuleTypes).forEach(([typeKey, type]) => {\n type.prototype.insertRule = unmodifiedFunctions[typeKey].insertRule;\n type.prototype.deleteRule = unmodifiedFunctions[typeKey].deleteRule;\n });\n });\n}\nfunction initAdoptedStyleSheetObserver({\n mirror: mirror2,\n stylesheetManager\n}, host) {\n var _a2, _b, _c;\n let hostId = null;\n if (host.nodeName === \"#document\") hostId = mirror2.getId(host);\n else hostId = mirror2.getId(host.host);\n const patchTarget = host.nodeName === \"#document\" ? (_a2 = host.defaultView) == null ? void 0 : _a2.Document : (_c = (_b = host.ownerDocument) == null ? void 0 : _b.defaultView) == null ? void 0 : _c.ShadowRoot;\n const originalPropertyDescriptor = (patchTarget == null ? void 0 : patchTarget.prototype) ? Object.getOwnPropertyDescriptor(\n patchTarget == null ? void 0 : patchTarget.prototype,\n \"adoptedStyleSheets\"\n ) : void 0;\n if (hostId === null || hostId === -1 || !patchTarget || !originalPropertyDescriptor)\n return () => {\n };\n Object.defineProperty(host, \"adoptedStyleSheets\", {\n configurable: originalPropertyDescriptor.configurable,\n enumerable: originalPropertyDescriptor.enumerable,\n get() {\n var _a3;\n return (_a3 = originalPropertyDescriptor.get) == null ? void 0 : _a3.call(this);\n },\n set(sheets) {\n var _a3;\n const result = (_a3 = originalPropertyDescriptor.set) == null ? void 0 : _a3.call(this, sheets);\n if (hostId !== null && hostId !== -1) {\n try {\n stylesheetManager.adoptStyleSheets(sheets, hostId);\n } catch (e2) {\n }\n }\n return result;\n }\n });\n return callbackWrapper(() => {\n Object.defineProperty(host, \"adoptedStyleSheets\", {\n configurable: originalPropertyDescriptor.configurable,\n enumerable: originalPropertyDescriptor.enumerable,\n // eslint-disable-next-line @typescript-eslint/unbound-method\n get: originalPropertyDescriptor.get,\n // eslint-disable-next-line @typescript-eslint/unbound-method\n set: originalPropertyDescriptor.set\n });\n });\n}\nfunction initStyleDeclarationObserver({\n styleDeclarationCb,\n mirror: mirror2,\n ignoreCSSAttributes,\n stylesheetManager\n}, { win }) {\n const setProperty = win.CSSStyleDeclaration.prototype.setProperty;\n win.CSSStyleDeclaration.prototype.setProperty = new Proxy(setProperty, {\n apply: callbackWrapper(\n (target, thisArg, argumentsList) => {\n var _a2;\n const [property, value, priority] = argumentsList;\n if (ignoreCSSAttributes.has(property)) {\n return setProperty.apply(thisArg, [property, value, priority]);\n }\n const { id, styleId } = getIdAndStyleId(\n (_a2 = thisArg.parentRule) == null ? void 0 : _a2.parentStyleSheet,\n mirror2,\n stylesheetManager.styleMirror\n );\n if (id && id !== -1 || styleId && styleId !== -1) {\n styleDeclarationCb({\n id,\n styleId,\n set: {\n property,\n value,\n priority\n },\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n index: getNestedCSSRulePositions(thisArg.parentRule)\n });\n }\n return target.apply(thisArg, argumentsList);\n }\n )\n });\n const removeProperty = win.CSSStyleDeclaration.prototype.removeProperty;\n win.CSSStyleDeclaration.prototype.removeProperty = new Proxy(removeProperty, {\n apply: callbackWrapper(\n (target, thisArg, argumentsList) => {\n var _a2;\n const [property] = argumentsList;\n if (ignoreCSSAttributes.has(property)) {\n return removeProperty.apply(thisArg, [property]);\n }\n const { id, styleId } = getIdAndStyleId(\n (_a2 = thisArg.parentRule) == null ? void 0 : _a2.parentStyleSheet,\n mirror2,\n stylesheetManager.styleMirror\n );\n if (id && id !== -1 || styleId && styleId !== -1) {\n styleDeclarationCb({\n id,\n styleId,\n remove: {\n property\n },\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n index: getNestedCSSRulePositions(thisArg.parentRule)\n });\n }\n return target.apply(thisArg, argumentsList);\n }\n )\n });\n return callbackWrapper(() => {\n win.CSSStyleDeclaration.prototype.setProperty = setProperty;\n win.CSSStyleDeclaration.prototype.removeProperty = removeProperty;\n });\n}\nfunction initMediaInteractionObserver({\n mediaInteractionCb,\n blockClass,\n blockSelector,\n mirror: mirror2,\n sampling,\n doc\n}) {\n const handler = callbackWrapper(\n (type) => throttle(\n callbackWrapper((event) => {\n const target = getEventTarget(event);\n if (!target || isBlocked(target, blockClass, blockSelector, true)) {\n return;\n }\n const { currentTime, volume, muted, playbackRate, loop } = target;\n mediaInteractionCb({\n type,\n id: mirror2.getId(target),\n currentTime,\n volume,\n muted,\n playbackRate,\n loop\n });\n }),\n sampling.media || 500\n )\n );\n const handlers = [\n on(\"play\", handler(MediaInteractions.Play), doc),\n on(\"pause\", handler(MediaInteractions.Pause), doc),\n on(\"seeked\", handler(MediaInteractions.Seeked), doc),\n on(\"volumechange\", handler(MediaInteractions.VolumeChange), doc),\n on(\"ratechange\", handler(MediaInteractions.RateChange), doc)\n ];\n return callbackWrapper(() => {\n handlers.forEach((h) => h());\n });\n}\nfunction initFontObserver({ fontCb, doc }) {\n const win = doc.defaultView;\n if (!win) {\n return () => {\n };\n }\n const handlers = [];\n const fontMap = /* @__PURE__ */ new WeakMap();\n const originalFontFace = win.FontFace;\n win.FontFace = function FontFace2(family, source, descriptors) {\n const fontFace = new originalFontFace(family, source, descriptors);\n fontMap.set(fontFace, {\n family,\n buffer: typeof source !== \"string\",\n descriptors,\n fontSource: typeof source === \"string\" ? source : JSON.stringify(Array.from(new Uint8Array(source)))\n });\n return fontFace;\n };\n const restoreHandler = patch(\n doc.fonts,\n \"add\",\n function(original) {\n return function(fontFace) {\n setTimeout(\n callbackWrapper(() => {\n const p = fontMap.get(fontFace);\n if (p) {\n fontCb(p);\n fontMap.delete(fontFace);\n }\n }),\n 0\n );\n return original.apply(this, [fontFace]);\n };\n }\n );\n handlers.push(() => {\n win.FontFace = originalFontFace;\n });\n handlers.push(restoreHandler);\n return callbackWrapper(() => {\n handlers.forEach((h) => h());\n });\n}\nfunction initSelectionObserver(param) {\n const { doc, mirror: mirror2, blockClass, blockSelector, selectionCb } = param;\n let collapsed = true;\n const updateSelection = callbackWrapper(() => {\n const selection = doc.getSelection();\n if (!selection || collapsed && (selection == null ? void 0 : selection.isCollapsed)) return;\n collapsed = selection.isCollapsed || false;\n const ranges = [];\n const count = selection.rangeCount || 0;\n for (let i2 = 0; i2 < count; i2++) {\n const range = selection.getRangeAt(i2);\n const { startContainer, startOffset, endContainer, endOffset } = range;\n const blocked = isBlocked(startContainer, blockClass, blockSelector, true) || isBlocked(endContainer, blockClass, blockSelector, true);\n if (blocked) continue;\n ranges.push({\n start: mirror2.getId(startContainer),\n startOffset,\n end: mirror2.getId(endContainer),\n endOffset\n });\n }\n selectionCb({ ranges });\n });\n updateSelection();\n return on(\"selectionchange\", updateSelection);\n}\nfunction initCustomElementObserver({\n doc,\n customElementCb\n}) {\n const win = doc.defaultView;\n if (!win || !win.customElements) return () => {\n };\n const restoreHandler = patch(\n win.customElements,\n \"define\",\n function(original) {\n return function(name, constructor, options) {\n try {\n customElementCb({\n define: {\n name\n }\n });\n } catch (e2) {\n console.warn(`Custom element callback failed for ${name}`);\n }\n return original.apply(this, [name, constructor, options]);\n };\n }\n );\n return restoreHandler;\n}\nfunction mergeHooks(o2, hooks) {\n const {\n mutationCb,\n mousemoveCb,\n mouseInteractionCb,\n scrollCb,\n viewportResizeCb,\n inputCb,\n mediaInteractionCb,\n styleSheetRuleCb,\n styleDeclarationCb,\n canvasMutationCb,\n fontCb,\n selectionCb,\n customElementCb\n } = o2;\n o2.mutationCb = (...p) => {\n if (hooks.mutation) {\n hooks.mutation(...p);\n }\n mutationCb(...p);\n };\n o2.mousemoveCb = (...p) => {\n if (hooks.mousemove) {\n hooks.mousemove(...p);\n }\n mousemoveCb(...p);\n };\n o2.mouseInteractionCb = (...p) => {\n if (hooks.mouseInteraction) {\n hooks.mouseInteraction(...p);\n }\n mouseInteractionCb(...p);\n };\n o2.scrollCb = (...p) => {\n if (hooks.scroll) {\n hooks.scroll(...p);\n }\n scrollCb(...p);\n };\n o2.viewportResizeCb = (...p) => {\n if (hooks.viewportResize) {\n hooks.viewportResize(...p);\n }\n viewportResizeCb(...p);\n };\n o2.inputCb = (...p) => {\n if (hooks.input) {\n hooks.input(...p);\n }\n inputCb(...p);\n };\n o2.mediaInteractionCb = (...p) => {\n if (hooks.mediaInteaction) {\n hooks.mediaInteaction(...p);\n }\n mediaInteractionCb(...p);\n };\n o2.styleSheetRuleCb = (...p) => {\n if (hooks.styleSheetRule) {\n hooks.styleSheetRule(...p);\n }\n styleSheetRuleCb(...p);\n };\n o2.styleDeclarationCb = (...p) => {\n if (hooks.styleDeclaration) {\n hooks.styleDeclaration(...p);\n }\n styleDeclarationCb(...p);\n };\n o2.canvasMutationCb = (...p) => {\n if (hooks.canvasMutation) {\n hooks.canvasMutation(...p);\n }\n canvasMutationCb(...p);\n };\n o2.fontCb = (...p) => {\n if (hooks.font) {\n hooks.font(...p);\n }\n fontCb(...p);\n };\n o2.selectionCb = (...p) => {\n if (hooks.selection) {\n hooks.selection(...p);\n }\n selectionCb(...p);\n };\n o2.customElementCb = (...c2) => {\n if (hooks.customElement) {\n hooks.customElement(...c2);\n }\n customElementCb(...c2);\n };\n}\nfunction initObservers(o2, hooks = {}) {\n const currentWindow = o2.doc.defaultView;\n if (!currentWindow) {\n return () => {\n };\n }\n mergeHooks(o2, hooks);\n let mutationObserver;\n if (o2.recordDOM) {\n mutationObserver = initMutationObserver(o2, o2.doc);\n }\n const mousemoveHandler = initMoveObserver(o2);\n const mouseInteractionHandler = initMouseInteractionObserver(o2);\n const scrollHandler = initScrollObserver(o2);\n const viewportResizeHandler = initViewportResizeObserver(o2, {\n win: currentWindow\n });\n const inputHandler = initInputObserver(o2);\n const mediaInteractionHandler = initMediaInteractionObserver(o2);\n let styleSheetObserver = () => {\n };\n let adoptedStyleSheetObserver = () => {\n };\n let styleDeclarationObserver = () => {\n };\n let fontObserver = () => {\n };\n if (o2.recordDOM) {\n styleSheetObserver = initStyleSheetObserver(o2, { win: currentWindow });\n adoptedStyleSheetObserver = initAdoptedStyleSheetObserver(o2, o2.doc);\n styleDeclarationObserver = initStyleDeclarationObserver(o2, {\n win: currentWindow\n });\n if (o2.collectFonts) {\n fontObserver = initFontObserver(o2);\n }\n }\n const selectionObserver = initSelectionObserver(o2);\n const customElementObserver = initCustomElementObserver(o2);\n const pluginHandlers = [];\n for (const plugin of o2.plugins) {\n pluginHandlers.push(\n plugin.observer(plugin.callback, currentWindow, plugin.options)\n );\n }\n return callbackWrapper(() => {\n mutationBuffers.forEach((b) => b.reset());\n mutationObserver == null ? void 0 : mutationObserver.disconnect();\n mousemoveHandler();\n mouseInteractionHandler();\n scrollHandler();\n viewportResizeHandler();\n inputHandler();\n mediaInteractionHandler();\n styleSheetObserver();\n adoptedStyleSheetObserver();\n styleDeclarationObserver();\n fontObserver();\n selectionObserver();\n customElementObserver();\n pluginHandlers.forEach((h) => h());\n });\n}\nfunction hasNestedCSSRule(prop) {\n return typeof window[prop] !== \"undefined\";\n}\nfunction canMonkeyPatchNestedCSSRule(prop) {\n return Boolean(\n typeof window[prop] !== \"undefined\" && // Note: Generally, this check _shouldn't_ be necessary\n // However, in some scenarios (e.g. jsdom) this can sometimes fail, so we check for it here\n window[prop].prototype && \"insertRule\" in window[prop].prototype && \"deleteRule\" in window[prop].prototype\n );\n}\nclass CrossOriginIframeMirror {\n constructor(generateIdFn) {\n __publicField(this, \"iframeIdToRemoteIdMap\", /* @__PURE__ */ new WeakMap());\n __publicField(this, \"iframeRemoteIdToIdMap\", /* @__PURE__ */ new WeakMap());\n this.generateIdFn = generateIdFn;\n }\n getId(iframe, remoteId, idToRemoteMap, remoteToIdMap) {\n const idToRemoteIdMap = idToRemoteMap || this.getIdToRemoteIdMap(iframe);\n const remoteIdToIdMap = remoteToIdMap || this.getRemoteIdToIdMap(iframe);\n let id = idToRemoteIdMap.get(remoteId);\n if (!id) {\n id = this.generateIdFn();\n idToRemoteIdMap.set(remoteId, id);\n remoteIdToIdMap.set(id, remoteId);\n }\n return id;\n }\n getIds(iframe, remoteId) {\n const idToRemoteIdMap = this.getIdToRemoteIdMap(iframe);\n const remoteIdToIdMap = this.getRemoteIdToIdMap(iframe);\n return remoteId.map(\n (id) => this.getId(iframe, id, idToRemoteIdMap, remoteIdToIdMap)\n );\n }\n getRemoteId(iframe, id, map) {\n const remoteIdToIdMap = map || this.getRemoteIdToIdMap(iframe);\n if (typeof id !== \"number\") return id;\n const remoteId = remoteIdToIdMap.get(id);\n if (!remoteId) return -1;\n return remoteId;\n }\n getRemoteIds(iframe, ids) {\n const remoteIdToIdMap = this.getRemoteIdToIdMap(iframe);\n return ids.map((id) => this.getRemoteId(iframe, id, remoteIdToIdMap));\n }\n reset(iframe) {\n if (!iframe) {\n this.iframeIdToRemoteIdMap = /* @__PURE__ */ new WeakMap();\n this.iframeRemoteIdToIdMap = /* @__PURE__ */ new WeakMap();\n return;\n }\n this.iframeIdToRemoteIdMap.delete(iframe);\n this.iframeRemoteIdToIdMap.delete(iframe);\n }\n getIdToRemoteIdMap(iframe) {\n let idToRemoteIdMap = this.iframeIdToRemoteIdMap.get(iframe);\n if (!idToRemoteIdMap) {\n idToRemoteIdMap = /* @__PURE__ */ new Map();\n this.iframeIdToRemoteIdMap.set(iframe, idToRemoteIdMap);\n }\n return idToRemoteIdMap;\n }\n getRemoteIdToIdMap(iframe) {\n let remoteIdToIdMap = this.iframeRemoteIdToIdMap.get(iframe);\n if (!remoteIdToIdMap) {\n remoteIdToIdMap = /* @__PURE__ */ new Map();\n this.iframeRemoteIdToIdMap.set(iframe, remoteIdToIdMap);\n }\n return remoteIdToIdMap;\n }\n}\nclass IframeManager {\n constructor(options) {\n __publicField(this, \"iframes\", /* @__PURE__ */ new WeakMap());\n __publicField(this, \"crossOriginIframeMap\", /* @__PURE__ */ new WeakMap());\n __publicField(this, \"crossOriginIframeMirror\", new CrossOriginIframeMirror(genId));\n __publicField(this, \"crossOriginIframeStyleMirror\");\n __publicField(this, \"crossOriginIframeRootIdMap\", /* @__PURE__ */ new WeakMap());\n __publicField(this, \"mirror\");\n __publicField(this, \"mutationCb\");\n __publicField(this, \"wrappedEmit\");\n __publicField(this, \"loadListener\");\n __publicField(this, \"stylesheetManager\");\n __publicField(this, \"recordCrossOriginIframes\");\n this.mutationCb = options.mutationCb;\n this.wrappedEmit = options.wrappedEmit;\n this.stylesheetManager = options.stylesheetManager;\n this.recordCrossOriginIframes = options.recordCrossOriginIframes;\n this.crossOriginIframeStyleMirror = new CrossOriginIframeMirror(\n this.stylesheetManager.styleMirror.generateId.bind(\n this.stylesheetManager.styleMirror\n )\n );\n this.mirror = options.mirror;\n if (this.recordCrossOriginIframes) {\n window.addEventListener(\"message\", this.handleMessage.bind(this));\n }\n }\n addIframe(iframeEl) {\n this.iframes.set(iframeEl, true);\n if (iframeEl.contentWindow)\n this.crossOriginIframeMap.set(iframeEl.contentWindow, iframeEl);\n }\n addLoadListener(cb) {\n this.loadListener = cb;\n }\n attachIframe(iframeEl, childSn) {\n var _a2, _b;\n this.mutationCb({\n adds: [\n {\n parentId: this.mirror.getId(iframeEl),\n nextId: null,\n node: childSn\n }\n ],\n removes: [],\n texts: [],\n attributes: [],\n isAttachIframe: true\n });\n if (this.recordCrossOriginIframes)\n (_a2 = iframeEl.contentWindow) == null ? void 0 : _a2.addEventListener(\n \"message\",\n this.handleMessage.bind(this)\n );\n (_b = this.loadListener) == null ? void 0 : _b.call(this, iframeEl);\n if (iframeEl.contentDocument && iframeEl.contentDocument.adoptedStyleSheets && iframeEl.contentDocument.adoptedStyleSheets.length > 0)\n this.stylesheetManager.adoptStyleSheets(\n iframeEl.contentDocument.adoptedStyleSheets,\n this.mirror.getId(iframeEl.contentDocument)\n );\n }\n handleMessage(message) {\n const crossOriginMessageEvent = message;\n if (crossOriginMessageEvent.data.type !== \"rrweb\" || // To filter out the rrweb messages which are forwarded by some sites.\n crossOriginMessageEvent.origin !== crossOriginMessageEvent.data.origin)\n return;\n const iframeSourceWindow = message.source;\n if (!iframeSourceWindow) return;\n const iframeEl = this.crossOriginIframeMap.get(message.source);\n if (!iframeEl) return;\n const transformedEvent = this.transformCrossOriginEvent(\n iframeEl,\n crossOriginMessageEvent.data.event\n );\n if (transformedEvent)\n this.wrappedEmit(\n transformedEvent,\n crossOriginMessageEvent.data.isCheckout\n );\n }\n transformCrossOriginEvent(iframeEl, e2) {\n var _a2;\n switch (e2.type) {\n case EventType.FullSnapshot: {\n this.crossOriginIframeMirror.reset(iframeEl);\n this.crossOriginIframeStyleMirror.reset(iframeEl);\n this.replaceIdOnNode(e2.data.node, iframeEl);\n const rootId = e2.data.node.id;\n this.crossOriginIframeRootIdMap.set(iframeEl, rootId);\n this.patchRootIdOnNode(e2.data.node, rootId);\n return {\n timestamp: e2.timestamp,\n type: EventType.IncrementalSnapshot,\n data: {\n source: IncrementalSource.Mutation,\n adds: [\n {\n parentId: this.mirror.getId(iframeEl),\n nextId: null,\n node: e2.data.node\n }\n ],\n removes: [],\n texts: [],\n attributes: [],\n isAttachIframe: true\n }\n };\n }\n case EventType.Meta:\n case EventType.Load:\n case EventType.DomContentLoaded: {\n return false;\n }\n case EventType.Plugin: {\n return e2;\n }\n case EventType.Custom: {\n this.replaceIds(\n e2.data.payload,\n iframeEl,\n [\"id\", \"parentId\", \"previousId\", \"nextId\"]\n );\n return e2;\n }\n case EventType.IncrementalSnapshot: {\n switch (e2.data.source) {\n case IncrementalSource.Mutation: {\n e2.data.adds.forEach((n2) => {\n this.replaceIds(n2, iframeEl, [\n \"parentId\",\n \"nextId\",\n \"previousId\"\n ]);\n this.replaceIdOnNode(n2.node, iframeEl);\n const rootId = this.crossOriginIframeRootIdMap.get(iframeEl);\n rootId && this.patchRootIdOnNode(n2.node, rootId);\n });\n e2.data.removes.forEach((n2) => {\n this.replaceIds(n2, iframeEl, [\"parentId\", \"id\"]);\n });\n e2.data.attributes.forEach((n2) => {\n this.replaceIds(n2, iframeEl, [\"id\"]);\n });\n e2.data.texts.forEach((n2) => {\n this.replaceIds(n2, iframeEl, [\"id\"]);\n });\n return e2;\n }\n case IncrementalSource.Drag:\n case IncrementalSource.TouchMove:\n case IncrementalSource.MouseMove: {\n e2.data.positions.forEach((p) => {\n this.replaceIds(p, iframeEl, [\"id\"]);\n });\n return e2;\n }\n case IncrementalSource.ViewportResize: {\n return false;\n }\n case IncrementalSource.MediaInteraction:\n case IncrementalSource.MouseInteraction:\n case IncrementalSource.Scroll:\n case IncrementalSource.CanvasMutation:\n case IncrementalSource.Input: {\n this.replaceIds(e2.data, iframeEl, [\"id\"]);\n return e2;\n }\n case IncrementalSource.StyleSheetRule:\n case IncrementalSource.StyleDeclaration: {\n this.replaceIds(e2.data, iframeEl, [\"id\"]);\n this.replaceStyleIds(e2.data, iframeEl, [\"styleId\"]);\n return e2;\n }\n case IncrementalSource.Font: {\n return e2;\n }\n case IncrementalSource.Selection: {\n e2.data.ranges.forEach((range) => {\n this.replaceIds(range, iframeEl, [\"start\", \"end\"]);\n });\n return e2;\n }\n case IncrementalSource.AdoptedStyleSheet: {\n this.replaceIds(e2.data, iframeEl, [\"id\"]);\n this.replaceStyleIds(e2.data, iframeEl, [\"styleIds\"]);\n (_a2 = e2.data.styles) == null ? void 0 : _a2.forEach((style) => {\n this.replaceStyleIds(style, iframeEl, [\"styleId\"]);\n });\n return e2;\n }\n }\n }\n }\n return false;\n }\n replace(iframeMirror, obj, iframeEl, keys) {\n for (const key of keys) {\n if (!Array.isArray(obj[key]) && typeof obj[key] !== \"number\") continue;\n if (Array.isArray(obj[key])) {\n obj[key] = iframeMirror.getIds(\n iframeEl,\n obj[key]\n );\n } else {\n obj[key] = iframeMirror.getId(iframeEl, obj[key]);\n }\n }\n return obj;\n }\n replaceIds(obj, iframeEl, keys) {\n return this.replace(this.crossOriginIframeMirror, obj, iframeEl, keys);\n }\n replaceStyleIds(obj, iframeEl, keys) {\n return this.replace(this.crossOriginIframeStyleMirror, obj, iframeEl, keys);\n }\n replaceIdOnNode(node, iframeEl) {\n this.replaceIds(node, iframeEl, [\"id\", \"rootId\"]);\n if (\"childNodes\" in node) {\n node.childNodes.forEach((child) => {\n this.replaceIdOnNode(child, iframeEl);\n });\n }\n }\n patchRootIdOnNode(node, rootId) {\n if (node.type !== NodeType$2.Document && !node.rootId) node.rootId = rootId;\n if (\"childNodes\" in node) {\n node.childNodes.forEach((child) => {\n this.patchRootIdOnNode(child, rootId);\n });\n }\n }\n}\nclass ShadowDomManager {\n constructor(options) {\n __publicField(this, \"shadowDoms\", /* @__PURE__ */ new WeakSet());\n __publicField(this, \"mutationCb\");\n __publicField(this, \"scrollCb\");\n __publicField(this, \"bypassOptions\");\n __publicField(this, \"mirror\");\n __publicField(this, \"restoreHandlers\", []);\n this.mutationCb = options.mutationCb;\n this.scrollCb = options.scrollCb;\n this.bypassOptions = options.bypassOptions;\n this.mirror = options.mirror;\n this.init();\n }\n init() {\n this.reset();\n this.patchAttachShadow(Element, document);\n }\n addShadowRoot(shadowRoot, doc) {\n if (!isNativeShadowDom(shadowRoot)) return;\n if (this.shadowDoms.has(shadowRoot)) return;\n this.shadowDoms.add(shadowRoot);\n const observer = initMutationObserver(\n {\n ...this.bypassOptions,\n doc,\n mutationCb: this.mutationCb,\n mirror: this.mirror,\n shadowDomManager: this\n },\n shadowRoot\n );\n this.restoreHandlers.push(() => observer.disconnect());\n this.restoreHandlers.push(\n initScrollObserver({\n ...this.bypassOptions,\n scrollCb: this.scrollCb,\n // https://gist.github.com/praveenpuglia/0832da687ed5a5d7a0907046c9ef1813\n // scroll is not allowed to pass the boundary, so we need to listen the shadow document\n doc: shadowRoot,\n mirror: this.mirror\n })\n );\n setTimeout(() => {\n if (shadowRoot.adoptedStyleSheets && shadowRoot.adoptedStyleSheets.length > 0)\n this.bypassOptions.stylesheetManager.adoptStyleSheets(\n shadowRoot.adoptedStyleSheets,\n this.mirror.getId(shadowRoot.host)\n );\n this.restoreHandlers.push(\n initAdoptedStyleSheetObserver(\n {\n mirror: this.mirror,\n stylesheetManager: this.bypassOptions.stylesheetManager\n },\n shadowRoot\n )\n );\n }, 0);\n }\n /**\n * Monkey patch 'attachShadow' of an IFrameElement to observe newly added shadow doms.\n */\n observeAttachShadow(iframeElement) {\n if (!iframeElement.contentWindow || !iframeElement.contentDocument) return;\n this.patchAttachShadow(\n iframeElement.contentWindow.Element,\n iframeElement.contentDocument\n );\n }\n /**\n * Patch 'attachShadow' to observe newly added shadow doms.\n */\n patchAttachShadow(element, doc) {\n const manager = this;\n this.restoreHandlers.push(\n patch(\n element.prototype,\n \"attachShadow\",\n function(original) {\n return function(option) {\n const shadowRoot = original.call(this, option);\n if (this.shadowRoot && inDom(this))\n manager.addShadowRoot(this.shadowRoot, doc);\n return shadowRoot;\n };\n }\n )\n );\n }\n reset() {\n this.restoreHandlers.forEach((handler) => {\n try {\n handler();\n } catch (e2) {\n }\n });\n this.restoreHandlers = [];\n this.shadowDoms = /* @__PURE__ */ new WeakSet();\n }\n}\nvar chars = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\";\nvar lookup = typeof Uint8Array === \"undefined\" ? [] : new Uint8Array(256);\nfor (var i$1 = 0; i$1 < chars.length; i$1++) {\n lookup[chars.charCodeAt(i$1)] = i$1;\n}\nvar encode = function(arraybuffer) {\n var bytes = new Uint8Array(arraybuffer), i2, len = bytes.length, base64 = \"\";\n for (i2 = 0; i2 < len; i2 += 3) {\n base64 += chars[bytes[i2] >> 2];\n base64 += chars[(bytes[i2] & 3) << 4 | bytes[i2 + 1] >> 4];\n base64 += chars[(bytes[i2 + 1] & 15) << 2 | bytes[i2 + 2] >> 6];\n base64 += chars[bytes[i2 + 2] & 63];\n }\n if (len % 3 === 2) {\n base64 = base64.substring(0, base64.length - 1) + \"=\";\n } else if (len % 3 === 1) {\n base64 = base64.substring(0, base64.length - 2) + \"==\";\n }\n return base64;\n};\nvar decode = function(base64) {\n var bufferLength = base64.length * 0.75, len = base64.length, i2, p = 0, encoded1, encoded2, encoded3, encoded4;\n if (base64[base64.length - 1] === \"=\") {\n bufferLength--;\n if (base64[base64.length - 2] === \"=\") {\n bufferLength--;\n }\n }\n var arraybuffer = new ArrayBuffer(bufferLength), bytes = new Uint8Array(arraybuffer);\n for (i2 = 0; i2 < len; i2 += 4) {\n encoded1 = lookup[base64.charCodeAt(i2)];\n encoded2 = lookup[base64.charCodeAt(i2 + 1)];\n encoded3 = lookup[base64.charCodeAt(i2 + 2)];\n encoded4 = lookup[base64.charCodeAt(i2 + 3)];\n bytes[p++] = encoded1 << 2 | encoded2 >> 4;\n bytes[p++] = (encoded2 & 15) << 4 | encoded3 >> 2;\n bytes[p++] = (encoded3 & 3) << 6 | encoded4 & 63;\n }\n return arraybuffer;\n};\nconst canvasVarMap = /* @__PURE__ */ new Map();\nfunction variableListFor$1(ctx, ctor) {\n let contextMap = canvasVarMap.get(ctx);\n if (!contextMap) {\n contextMap = /* @__PURE__ */ new Map();\n canvasVarMap.set(ctx, contextMap);\n }\n if (!contextMap.has(ctor)) {\n contextMap.set(ctor, []);\n }\n return contextMap.get(ctor);\n}\nconst saveWebGLVar = (value, win, ctx) => {\n if (!value || !(isInstanceOfWebGLObject(value, win) || typeof value === \"object\"))\n return;\n const name = value.constructor.name;\n const list = variableListFor$1(ctx, name);\n let index = list.indexOf(value);\n if (index === -1) {\n index = list.length;\n list.push(value);\n }\n return index;\n};\nfunction serializeArg(value, win, ctx) {\n if (value instanceof Array) {\n return value.map((arg) => serializeArg(arg, win, ctx));\n } else if (value === null) {\n return value;\n } else if (value instanceof Float32Array || value instanceof Float64Array || value instanceof Int32Array || value instanceof Uint32Array || value instanceof Uint8Array || value instanceof Uint16Array || value instanceof Int16Array || value instanceof Int8Array || value instanceof Uint8ClampedArray) {\n const name = value.constructor.name;\n return {\n rr_type: name,\n args: [Object.values(value)]\n };\n } else if (\n // SharedArrayBuffer disabled on most browsers due to spectre.\n // More info: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/SharedArrayBuffer/SharedArrayBuffer\n // value instanceof SharedArrayBuffer ||\n value instanceof ArrayBuffer\n ) {\n const name = value.constructor.name;\n const base64 = encode(value);\n return {\n rr_type: name,\n base64\n };\n } else if (value instanceof DataView) {\n const name = value.constructor.name;\n return {\n rr_type: name,\n args: [\n serializeArg(value.buffer, win, ctx),\n value.byteOffset,\n value.byteLength\n ]\n };\n } else if (value instanceof HTMLImageElement) {\n const name = value.constructor.name;\n const { src } = value;\n return {\n rr_type: name,\n src\n };\n } else if (value instanceof HTMLCanvasElement) {\n const name = \"HTMLImageElement\";\n const src = value.toDataURL();\n return {\n rr_type: name,\n src\n };\n } else if (value instanceof ImageData) {\n const name = value.constructor.name;\n return {\n rr_type: name,\n args: [serializeArg(value.data, win, ctx), value.width, value.height]\n };\n } else if (isInstanceOfWebGLObject(value, win) || typeof value === \"object\") {\n const name = value.constructor.name;\n const index = saveWebGLVar(value, win, ctx);\n return {\n rr_type: name,\n index\n };\n }\n return value;\n}\nconst serializeArgs = (args, win, ctx) => {\n return args.map((arg) => serializeArg(arg, win, ctx));\n};\nconst isInstanceOfWebGLObject = (value, win) => {\n const webGLConstructorNames = [\n \"WebGLActiveInfo\",\n \"WebGLBuffer\",\n \"WebGLFramebuffer\",\n \"WebGLProgram\",\n \"WebGLRenderbuffer\",\n \"WebGLShader\",\n \"WebGLShaderPrecisionFormat\",\n \"WebGLTexture\",\n \"WebGLUniformLocation\",\n \"WebGLVertexArrayObject\",\n // In old Chrome versions, value won't be an instanceof WebGLVertexArrayObject.\n \"WebGLVertexArrayObjectOES\"\n ];\n const supportedWebGLConstructorNames = webGLConstructorNames.filter(\n (name) => typeof win[name] === \"function\"\n );\n return Boolean(\n supportedWebGLConstructorNames.find(\n (name) => value instanceof win[name]\n )\n );\n};\nfunction initCanvas2DMutationObserver(cb, win, blockClass, blockSelector) {\n const handlers = [];\n const props2D = Object.getOwnPropertyNames(\n win.CanvasRenderingContext2D.prototype\n );\n for (const prop of props2D) {\n try {\n if (typeof win.CanvasRenderingContext2D.prototype[prop] !== \"function\") {\n continue;\n }\n const restoreHandler = patch(\n win.CanvasRenderingContext2D.prototype,\n prop,\n function(original) {\n return function(...args) {\n if (!isBlocked(this.canvas, blockClass, blockSelector, true)) {\n setTimeout(() => {\n const recordArgs = serializeArgs(args, win, this);\n cb(this.canvas, {\n type: CanvasContext[\"2D\"],\n property: prop,\n args: recordArgs\n });\n }, 0);\n }\n return original.apply(this, args);\n };\n }\n );\n handlers.push(restoreHandler);\n } catch {\n const hookHandler = hookSetter(\n win.CanvasRenderingContext2D.prototype,\n prop,\n {\n set(v2) {\n cb(this.canvas, {\n type: CanvasContext[\"2D\"],\n property: prop,\n args: [v2],\n setter: true\n });\n }\n }\n );\n handlers.push(hookHandler);\n }\n }\n return () => {\n handlers.forEach((h) => h());\n };\n}\nfunction getNormalizedContextName(contextType) {\n return contextType === \"experimental-webgl\" ? \"webgl\" : contextType;\n}\nfunction initCanvasContextObserver(win, blockClass, blockSelector, setPreserveDrawingBufferToTrue) {\n const handlers = [];\n try {\n const restoreHandler = patch(\n win.HTMLCanvasElement.prototype,\n \"getContext\",\n function(original) {\n return function(contextType, ...args) {\n if (!isBlocked(this, blockClass, blockSelector, true)) {\n const ctxName = getNormalizedContextName(contextType);\n if (!(\"__context\" in this)) this.__context = ctxName;\n if (setPreserveDrawingBufferToTrue && [\"webgl\", \"webgl2\"].includes(ctxName)) {\n if (args[0] && typeof args[0] === \"object\") {\n const contextAttributes = args[0];\n if (!contextAttributes.preserveDrawingBuffer) {\n contextAttributes.preserveDrawingBuffer = true;\n }\n } else {\n args.splice(0, 1, {\n preserveDrawingBuffer: true\n });\n }\n }\n }\n return original.apply(this, [contextType, ...args]);\n };\n }\n );\n handlers.push(restoreHandler);\n } catch {\n console.error(\"failed to patch HTMLCanvasElement.prototype.getContext\");\n }\n return () => {\n handlers.forEach((h) => h());\n };\n}\nfunction patchGLPrototype(prototype, type, cb, blockClass, blockSelector, win) {\n const handlers = [];\n const props = Object.getOwnPropertyNames(prototype);\n for (const prop of props) {\n if (\n //prop.startsWith('get') || // e.g. getProgramParameter, but too risky\n [\n \"isContextLost\",\n \"canvas\",\n \"drawingBufferWidth\",\n \"drawingBufferHeight\"\n ].includes(prop)\n ) {\n continue;\n }\n try {\n if (typeof prototype[prop] !== \"function\") {\n continue;\n }\n const restoreHandler = patch(\n prototype,\n prop,\n function(original) {\n return function(...args) {\n const result = original.apply(this, args);\n saveWebGLVar(result, win, this);\n if (\"tagName\" in this.canvas && !isBlocked(this.canvas, blockClass, blockSelector, true)) {\n const recordArgs = serializeArgs(args, win, this);\n const mutation = {\n type,\n property: prop,\n args: recordArgs\n };\n cb(this.canvas, mutation);\n }\n return result;\n };\n }\n );\n handlers.push(restoreHandler);\n } catch {\n const hookHandler = hookSetter(prototype, prop, {\n set(v2) {\n cb(this.canvas, {\n type,\n property: prop,\n args: [v2],\n setter: true\n });\n }\n });\n handlers.push(hookHandler);\n }\n }\n return handlers;\n}\nfunction initCanvasWebGLMutationObserver(cb, win, blockClass, blockSelector) {\n const handlers = [];\n handlers.push(\n ...patchGLPrototype(\n win.WebGLRenderingContext.prototype,\n CanvasContext.WebGL,\n cb,\n blockClass,\n blockSelector,\n win\n )\n );\n if (typeof win.WebGL2RenderingContext !== \"undefined\") {\n handlers.push(\n ...patchGLPrototype(\n win.WebGL2RenderingContext.prototype,\n CanvasContext.WebGL2,\n cb,\n blockClass,\n blockSelector,\n win\n )\n );\n }\n return () => {\n handlers.forEach((h) => h());\n };\n}\nconst encodedJs = \"KGZ1bmN0aW9uKCkgewogICJ1c2Ugc3RyaWN0IjsKICB2YXIgY2hhcnMgPSAiQUJDREVGR0hJSktMTU5PUFFSU1RVVldYWVphYmNkZWZnaGlqa2xtbm9wcXJzdHV2d3h5ejAxMjM0NTY3ODkrLyI7CiAgdmFyIGxvb2t1cCA9IHR5cGVvZiBVaW50OEFycmF5ID09PSAidW5kZWZpbmVkIiA/IFtdIDogbmV3IFVpbnQ4QXJyYXkoMjU2KTsKICBmb3IgKHZhciBpID0gMDsgaSA8IGNoYXJzLmxlbmd0aDsgaSsrKSB7CiAgICBsb29rdXBbY2hhcnMuY2hhckNvZGVBdChpKV0gPSBpOwogIH0KICB2YXIgZW5jb2RlID0gZnVuY3Rpb24oYXJyYXlidWZmZXIpIHsKICAgIHZhciBieXRlcyA9IG5ldyBVaW50OEFycmF5KGFycmF5YnVmZmVyKSwgaTIsIGxlbiA9IGJ5dGVzLmxlbmd0aCwgYmFzZTY0ID0gIiI7CiAgICBmb3IgKGkyID0gMDsgaTIgPCBsZW47IGkyICs9IDMpIHsKICAgICAgYmFzZTY0ICs9IGNoYXJzW2J5dGVzW2kyXSA+PiAyXTsKICAgICAgYmFzZTY0ICs9IGNoYXJzWyhieXRlc1tpMl0gJiAzKSA8PCA0IHwgYnl0ZXNbaTIgKyAxXSA+PiA0XTsKICAgICAgYmFzZTY0ICs9IGNoYXJzWyhieXRlc1tpMiArIDFdICYgMTUpIDw8IDIgfCBieXRlc1tpMiArIDJdID4+IDZdOwogICAgICBiYXNlNjQgKz0gY2hhcnNbYnl0ZXNbaTIgKyAyXSAmIDYzXTsKICAgIH0KICAgIGlmIChsZW4gJSAzID09PSAyKSB7CiAgICAgIGJhc2U2NCA9IGJhc2U2NC5zdWJzdHJpbmcoMCwgYmFzZTY0Lmxlbmd0aCAtIDEpICsgIj0iOwogICAgfSBlbHNlIGlmIChsZW4gJSAzID09PSAxKSB7CiAgICAgIGJhc2U2NCA9IGJhc2U2NC5zdWJzdHJpbmcoMCwgYmFzZTY0Lmxlbmd0aCAtIDIpICsgIj09IjsKICAgIH0KICAgIHJldHVybiBiYXNlNjQ7CiAgfTsKICBjb25zdCBsYXN0QmxvYk1hcCA9IC8qIEBfX1BVUkVfXyAqLyBuZXcgTWFwKCk7CiAgY29uc3QgdHJhbnNwYXJlbnRCbG9iTWFwID0gLyogQF9fUFVSRV9fICovIG5ldyBNYXAoKTsKICBhc3luYyBmdW5jdGlvbiBnZXRUcmFuc3BhcmVudEJsb2JGb3Iod2lkdGgsIGhlaWdodCwgZGF0YVVSTE9wdGlvbnMpIHsKICAgIGNvbnN0IGlkID0gYCR7d2lkdGh9LSR7aGVpZ2h0fWA7CiAgICBpZiAoIk9mZnNjcmVlbkNhbnZhcyIgaW4gZ2xvYmFsVGhpcykgewogICAgICBpZiAodHJhbnNwYXJlbnRCbG9iTWFwLmhhcyhpZCkpIHJldHVybiB0cmFuc3BhcmVudEJsb2JNYXAuZ2V0KGlkKTsKICAgICAgY29uc3Qgb2Zmc2NyZWVuID0gbmV3IE9mZnNjcmVlbkNhbnZhcyh3aWR0aCwgaGVpZ2h0KTsKICAgICAgb2Zmc2NyZWVuLmdldENvbnRleHQoIjJkIik7CiAgICAgIGNvbnN0IGJsb2IgPSBhd2FpdCBvZmZzY3JlZW4uY29udmVydFRvQmxvYihkYXRhVVJMT3B0aW9ucyk7CiAgICAgIGNvbnN0IGFycmF5QnVmZmVyID0gYXdhaXQgYmxvYi5hcnJheUJ1ZmZlcigpOwogICAgICBjb25zdCBiYXNlNjQgPSBlbmNvZGUoYXJyYXlCdWZmZXIpOwogICAgICB0cmFuc3BhcmVudEJsb2JNYXAuc2V0KGlkLCBiYXNlNjQpOwogICAgICByZXR1cm4gYmFzZTY0OwogICAgfSBlbHNlIHsKICAgICAgcmV0dXJuICIiOwogICAgfQogIH0KICBjb25zdCB3b3JrZXIgPSBzZWxmOwogIHdvcmtlci5vbm1lc3NhZ2UgPSBhc3luYyBmdW5jdGlvbihlKSB7CiAgICBpZiAoIk9mZnNjcmVlbkNhbnZhcyIgaW4gZ2xvYmFsVGhpcykgewogICAgICBjb25zdCB7IGlkLCBiaXRtYXAsIHdpZHRoLCBoZWlnaHQsIGRhdGFVUkxPcHRpb25zIH0gPSBlLmRhdGE7CiAgICAgIGNvbnN0IHRyYW5zcGFyZW50QmFzZTY0ID0gZ2V0VHJhbnNwYXJlbnRCbG9iRm9yKAogICAgICAgIHdpZHRoLAogICAgICAgIGhlaWdodCwKICAgICAgICBkYXRhVVJMT3B0aW9ucwogICAgICApOwogICAgICBjb25zdCBvZmZzY3JlZW4gPSBuZXcgT2Zmc2NyZWVuQ2FudmFzKHdpZHRoLCBoZWlnaHQpOwogICAgICBjb25zdCBjdHggPSBvZmZzY3JlZW4uZ2V0Q29udGV4dCgiMmQiKTsKICAgICAgY3R4LmRyYXdJbWFnZShiaXRtYXAsIDAsIDApOwogICAgICBiaXRtYXAuY2xvc2UoKTsKICAgICAgY29uc3QgYmxvYiA9IGF3YWl0IG9mZnNjcmVlbi5jb252ZXJ0VG9CbG9iKGRhdGFVUkxPcHRpb25zKTsKICAgICAgY29uc3QgdHlwZSA9IGJsb2IudHlwZTsKICAgICAgY29uc3QgYXJyYXlCdWZmZXIgPSBhd2FpdCBibG9iLmFycmF5QnVmZmVyKCk7CiAgICAgIGNvbnN0IGJhc2U2NCA9IGVuY29kZShhcnJheUJ1ZmZlcik7CiAgICAgIGlmICghbGFzdEJsb2JNYXAuaGFzKGlkKSAmJiBhd2FpdCB0cmFuc3BhcmVudEJhc2U2NCA9PT0gYmFzZTY0KSB7CiAgICAgICAgbGFzdEJsb2JNYXAuc2V0KGlkLCBiYXNlNjQpOwogICAgICAgIHJldHVybiB3b3JrZXIucG9zdE1lc3NhZ2UoeyBpZCB9KTsKICAgICAgfQogICAgICBpZiAobGFzdEJsb2JNYXAuZ2V0KGlkKSA9PT0gYmFzZTY0KSByZXR1cm4gd29ya2VyLnBvc3RNZXNzYWdlKHsgaWQgfSk7CiAgICAgIHdvcmtlci5wb3N0TWVzc2FnZSh7CiAgICAgICAgaWQsCiAgICAgICAgdHlwZSwKICAgICAgICBiYXNlNjQsCiAgICAgICAgd2lkdGgsCiAgICAgICAgaGVpZ2h0CiAgICAgIH0pOwogICAgICBsYXN0QmxvYk1hcC5zZXQoaWQsIGJhc2U2NCk7CiAgICB9IGVsc2UgewogICAgICByZXR1cm4gd29ya2VyLnBvc3RNZXNzYWdlKHsgaWQ6IGUuZGF0YS5pZCB9KTsKICAgIH0KICB9Owp9KSgpOwovLyMgc291cmNlTWFwcGluZ1VSTD1pbWFnZS1iaXRtYXAtZGF0YS11cmwtd29ya2VyLUlKcEM3Z19iLmpzLm1hcAo=\";\nconst decodeBase64 = (base64) => Uint8Array.from(atob(base64), (c2) => c2.charCodeAt(0));\nconst blob = typeof window !== \"undefined\" && window.Blob && new Blob([decodeBase64(encodedJs)], { type: \"text/javascript;charset=utf-8\" });\nfunction WorkerWrapper(options) {\n let objURL;\n try {\n objURL = blob && (window.URL || window.webkitURL).createObjectURL(blob);\n if (!objURL) throw \"\";\n const worker = new Worker(objURL, {\n name: options == null ? void 0 : options.name\n });\n worker.addEventListener(\"error\", () => {\n (window.URL || window.webkitURL).revokeObjectURL(objURL);\n });\n return worker;\n } catch (e2) {\n return new Worker(\n \"data:text/javascript;base64,\" + encodedJs,\n {\n name: options == null ? void 0 : options.name\n }\n );\n } finally {\n objURL && (window.URL || window.webkitURL).revokeObjectURL(objURL);\n }\n}\nclass CanvasManager {\n constructor(options) {\n __publicField(this, \"pendingCanvasMutations\", /* @__PURE__ */ new Map());\n __publicField(this, \"rafStamps\", { latestId: 0, invokeId: null });\n __publicField(this, \"mirror\");\n __publicField(this, \"mutationCb\");\n __publicField(this, \"resetObservers\");\n __publicField(this, \"frozen\", false);\n __publicField(this, \"locked\", false);\n __publicField(this, \"processMutation\", (target, mutation) => {\n const newFrame = this.rafStamps.invokeId && this.rafStamps.latestId !== this.rafStamps.invokeId;\n if (newFrame || !this.rafStamps.invokeId)\n this.rafStamps.invokeId = this.rafStamps.latestId;\n if (!this.pendingCanvasMutations.has(target)) {\n this.pendingCanvasMutations.set(target, []);\n }\n this.pendingCanvasMutations.get(target).push(mutation);\n });\n const {\n sampling = \"all\",\n win,\n blockClass,\n blockSelector,\n recordCanvas,\n dataURLOptions\n } = options;\n this.mutationCb = options.mutationCb;\n this.mirror = options.mirror;\n if (recordCanvas && sampling === \"all\")\n this.initCanvasMutationObserver(win, blockClass, blockSelector);\n if (recordCanvas && typeof sampling === \"number\")\n this.initCanvasFPSObserver(sampling, win, blockClass, blockSelector, {\n dataURLOptions\n });\n }\n reset() {\n this.pendingCanvasMutations.clear();\n this.resetObservers && this.resetObservers();\n }\n freeze() {\n this.frozen = true;\n }\n unfreeze() {\n this.frozen = false;\n }\n lock() {\n this.locked = true;\n }\n unlock() {\n this.locked = false;\n }\n initCanvasFPSObserver(fps, win, blockClass, blockSelector, options) {\n const canvasContextReset = initCanvasContextObserver(\n win,\n blockClass,\n blockSelector,\n true\n );\n const snapshotInProgressMap = /* @__PURE__ */ new Map();\n const worker = new WorkerWrapper();\n worker.onmessage = (e2) => {\n const { id } = e2.data;\n snapshotInProgressMap.set(id, false);\n if (!(\"base64\" in e2.data)) return;\n const { base64, type, width, height } = e2.data;\n this.mutationCb({\n id,\n type: CanvasContext[\"2D\"],\n commands: [\n {\n property: \"clearRect\",\n // wipe canvas\n args: [0, 0, width, height]\n },\n {\n property: \"drawImage\",\n // draws (semi-transparent) image\n args: [\n {\n rr_type: \"ImageBitmap\",\n args: [\n {\n rr_type: \"Blob\",\n data: [{ rr_type: \"ArrayBuffer\", base64 }],\n type\n }\n ]\n },\n 0,\n 0\n ]\n }\n ]\n });\n };\n const timeBetweenSnapshots = 1e3 / fps;\n let lastSnapshotTime = 0;\n let rafId;\n const getCanvas = () => {\n const matchedCanvas = [];\n const searchCanvas = (root) => {\n root.querySelectorAll(\"canvas\").forEach((canvas) => {\n if (!isBlocked(canvas, blockClass, blockSelector, true)) {\n matchedCanvas.push(canvas);\n }\n });\n root.querySelectorAll(\"*\").forEach((elem) => {\n if (elem.shadowRoot) {\n searchCanvas(elem.shadowRoot);\n }\n });\n };\n searchCanvas(win.document);\n return matchedCanvas;\n };\n const takeCanvasSnapshots = (timestamp) => {\n if (lastSnapshotTime && timestamp - lastSnapshotTime < timeBetweenSnapshots) {\n rafId = requestAnimationFrame(takeCanvasSnapshots);\n return;\n }\n lastSnapshotTime = timestamp;\n getCanvas().forEach(async (canvas) => {\n var _a2;\n const id = this.mirror.getId(canvas);\n if (snapshotInProgressMap.get(id)) return;\n if (canvas.width === 0 || canvas.height === 0) return;\n snapshotInProgressMap.set(id, true);\n if ([\"webgl\", \"webgl2\"].includes(canvas.__context)) {\n const context = canvas.getContext(canvas.__context);\n if (((_a2 = context == null ? void 0 : context.getContextAttributes()) == null ? void 0 : _a2.preserveDrawingBuffer) === false) {\n context.clear(context.COLOR_BUFFER_BIT);\n }\n }\n // createImageBitmap throws if resizing to 0\n // Fallback to intrinsic size if canvas has not yet rendered\n const width = canvas.clientWidth || canvas.width;\n const height = canvas.clientHeight || canvas.height;\n const bitmap = await createImageBitmap(canvas, {\n resizeWidth: width,\n resizeHeight: height\n });\n worker.postMessage(\n {\n id,\n bitmap,\n width: width,\n height: height,\n dataURLOptions: options.dataURLOptions\n },\n [bitmap]\n );\n });\n rafId = requestAnimationFrame(takeCanvasSnapshots);\n };\n rafId = requestAnimationFrame(takeCanvasSnapshots);\n this.resetObservers = () => {\n canvasContextReset();\n cancelAnimationFrame(rafId);\n };\n }\n initCanvasMutationObserver(win, blockClass, blockSelector) {\n this.startRAFTimestamping();\n this.startPendingCanvasMutationFlusher();\n const canvasContextReset = initCanvasContextObserver(\n win,\n blockClass,\n blockSelector,\n false\n );\n const canvas2DReset = initCanvas2DMutationObserver(\n this.processMutation.bind(this),\n win,\n blockClass,\n blockSelector\n );\n const canvasWebGL1and2Reset = initCanvasWebGLMutationObserver(\n this.processMutation.bind(this),\n win,\n blockClass,\n blockSelector\n );\n this.resetObservers = () => {\n canvasContextReset();\n canvas2DReset();\n canvasWebGL1and2Reset();\n };\n }\n startPendingCanvasMutationFlusher() {\n requestAnimationFrame(() => this.flushPendingCanvasMutations());\n }\n startRAFTimestamping() {\n const setLatestRAFTimestamp = (timestamp) => {\n this.rafStamps.latestId = timestamp;\n requestAnimationFrame(setLatestRAFTimestamp);\n };\n requestAnimationFrame(setLatestRAFTimestamp);\n }\n flushPendingCanvasMutations() {\n this.pendingCanvasMutations.forEach(\n (_values, canvas) => {\n const id = this.mirror.getId(canvas);\n this.flushPendingCanvasMutationFor(canvas, id);\n }\n );\n requestAnimationFrame(() => this.flushPendingCanvasMutations());\n }\n flushPendingCanvasMutationFor(canvas, id) {\n if (this.frozen || this.locked) {\n return;\n }\n const valuesWithType = this.pendingCanvasMutations.get(canvas);\n if (!valuesWithType || id === -1) return;\n const values = valuesWithType.map((value) => {\n const { type: type2, ...rest } = value;\n return rest;\n });\n const { type } = valuesWithType[0];\n this.mutationCb({ id, type, commands: values });\n this.pendingCanvasMutations.delete(canvas);\n }\n}\nclass StylesheetManager {\n constructor(options) {\n __publicField(this, \"trackedLinkElements\", /* @__PURE__ */ new WeakSet());\n __publicField(this, \"mutationCb\");\n __publicField(this, \"adoptedStyleSheetCb\");\n __publicField(this, \"styleMirror\", new StyleSheetMirror());\n this.mutationCb = options.mutationCb;\n this.adoptedStyleSheetCb = options.adoptedStyleSheetCb;\n }\n attachLinkElement(linkEl, childSn) {\n if (\"_cssText\" in childSn.attributes)\n this.mutationCb({\n adds: [],\n removes: [],\n texts: [],\n attributes: [\n {\n id: childSn.id,\n attributes: childSn.attributes\n }\n ]\n });\n this.trackLinkElement(linkEl);\n }\n trackLinkElement(linkEl) {\n if (this.trackedLinkElements.has(linkEl)) return;\n this.trackedLinkElements.add(linkEl);\n this.trackStylesheetInLinkElement(linkEl);\n }\n adoptStyleSheets(sheets, hostId) {\n if (sheets.length === 0) return;\n const adoptedStyleSheetData = {\n id: hostId,\n styleIds: []\n };\n const styles = [];\n for (const sheet of sheets) {\n let styleId;\n if (!this.styleMirror.has(sheet)) {\n styleId = this.styleMirror.add(sheet);\n styles.push({\n styleId,\n rules: Array.from(sheet.rules || CSSRule, (r2, index) => ({\n rule: stringifyRule(r2),\n index\n }))\n });\n } else styleId = this.styleMirror.getId(sheet);\n adoptedStyleSheetData.styleIds.push(styleId);\n }\n if (styles.length > 0) adoptedStyleSheetData.styles = styles;\n this.adoptedStyleSheetCb(adoptedStyleSheetData);\n }\n reset() {\n this.styleMirror.reset();\n this.trackedLinkElements = /* @__PURE__ */ new WeakSet();\n }\n // TODO: take snapshot on stylesheet reload by applying event listener\n trackStylesheetInLinkElement(_linkEl) {\n }\n}\nclass ProcessedNodeManager {\n constructor() {\n __publicField(this, \"nodeMap\", /* @__PURE__ */ new WeakMap());\n __publicField(this, \"active\", false);\n }\n inOtherBuffer(node, thisBuffer) {\n const buffers = this.nodeMap.get(node);\n return buffers && Array.from(buffers).some((buffer) => buffer !== thisBuffer);\n }\n add(node, buffer) {\n if (!this.active) {\n this.active = true;\n requestAnimationFrame(() => {\n this.nodeMap = /* @__PURE__ */ new WeakMap();\n this.active = false;\n });\n }\n this.nodeMap.set(node, (this.nodeMap.get(node) || /* @__PURE__ */ new Set()).add(buffer));\n }\n destroy() {\n }\n}\nlet wrappedEmit;\nlet takeFullSnapshot;\nlet canvasManager;\nlet recording = false;\ntry {\n if (Array.from([1], (x) => x * 2)[0] !== 2) {\n const cleanFrame = document.createElement(\"iframe\");\n document.body.appendChild(cleanFrame);\n Array.from = ((_a = cleanFrame.contentWindow) == null ? void 0 : _a.Array.from) || Array.from;\n document.body.removeChild(cleanFrame);\n }\n} catch (err) {\n console.debug(\"Unable to override Array.from\", err);\n}\nconst mirror = createMirror$2();\nfunction record(options = {}) {\n const {\n emit,\n checkoutEveryNms,\n checkoutEveryNth,\n blockClass = \"rr-block\",\n blockSelector = null,\n ignoreClass = \"rr-ignore\",\n ignoreSelector = null,\n maskTextClass = \"rr-mask\",\n maskTextSelector = null,\n inlineStylesheet = true,\n maskAllInputs,\n maskInputOptions: _maskInputOptions,\n slimDOMOptions: _slimDOMOptions,\n maskInputFn,\n maskTextFn,\n hooks,\n packFn,\n sampling = {},\n dataURLOptions = {},\n mousemoveWait,\n recordDOM = true,\n recordCanvas = false,\n recordCrossOriginIframes = false,\n recordAfter = options.recordAfter === \"DOMContentLoaded\" ? options.recordAfter : \"load\",\n userTriggeredOnInput = false,\n collectFonts = false,\n inlineImages = false,\n plugins,\n keepIframeSrcFn = () => false,\n ignoreCSSAttributes = /* @__PURE__ */ new Set([]),\n errorHandler: errorHandler2\n } = options;\n registerErrorHandler(errorHandler2);\n const inEmittingFrame = recordCrossOriginIframes ? window.parent === window : true;\n let passEmitsToParent = false;\n if (!inEmittingFrame) {\n try {\n if (window.parent.document) {\n passEmitsToParent = false;\n }\n } catch (e2) {\n passEmitsToParent = true;\n }\n }\n if (inEmittingFrame && !emit) {\n throw new Error(\"emit function is required\");\n }\n if (!inEmittingFrame && !passEmitsToParent) {\n return () => {\n };\n }\n if (mousemoveWait !== void 0 && sampling.mousemove === void 0) {\n sampling.mousemove = mousemoveWait;\n }\n mirror.reset();\n const maskInputOptions = maskAllInputs === true ? {\n color: true,\n date: true,\n \"datetime-local\": true,\n email: true,\n month: true,\n number: true,\n range: true,\n search: true,\n tel: true,\n text: true,\n time: true,\n url: true,\n week: true,\n textarea: true,\n select: true,\n password: true\n } : _maskInputOptions !== void 0 ? _maskInputOptions : { password: true };\n const slimDOMOptions = _slimDOMOptions === true || _slimDOMOptions === \"all\" ? {\n script: true,\n comment: true,\n headFavicon: true,\n headWhitespace: true,\n headMetaSocial: true,\n headMetaRobots: true,\n headMetaHttpEquiv: true,\n headMetaVerification: true,\n // the following are off for slimDOMOptions === true,\n // as they destroy some (hidden) info:\n headMetaAuthorship: _slimDOMOptions === \"all\",\n headMetaDescKeywords: _slimDOMOptions === \"all\",\n headTitleMutations: _slimDOMOptions === \"all\"\n } : _slimDOMOptions ? _slimDOMOptions : {};\n polyfill$1();\n let lastFullSnapshotEvent;\n let incrementalSnapshotCount = 0;\n const eventProcessor = (e2) => {\n for (const plugin of plugins || []) {\n if (plugin.eventProcessor) {\n e2 = plugin.eventProcessor(e2);\n }\n }\n if (packFn && // Disable packing events which will be emitted to parent frames.\n !passEmitsToParent) {\n e2 = packFn(e2);\n }\n return e2;\n };\n wrappedEmit = (r2, isCheckout) => {\n var _a2;\n const e2 = r2;\n e2.timestamp = nowTimestamp();\n if (((_a2 = mutationBuffers[0]) == null ? void 0 : _a2.isFrozen()) && e2.type !== EventType.FullSnapshot && !(e2.type === EventType.IncrementalSnapshot && e2.data.source === IncrementalSource.Mutation)) {\n mutationBuffers.forEach((buf) => buf.unfreeze());\n }\n if (inEmittingFrame) {\n emit == null ? void 0 : emit(eventProcessor(e2), isCheckout);\n } else if (passEmitsToParent) {\n const message = {\n type: \"rrweb\",\n event: eventProcessor(e2),\n origin: window.location.origin,\n isCheckout\n };\n window.parent.postMessage(message, \"*\");\n }\n if (e2.type === EventType.FullSnapshot) {\n lastFullSnapshotEvent = e2;\n incrementalSnapshotCount = 0;\n } else if (e2.type === EventType.IncrementalSnapshot) {\n if (e2.data.source === IncrementalSource.Mutation && e2.data.isAttachIframe) {\n return;\n }\n incrementalSnapshotCount++;\n const exceedCount = checkoutEveryNth && incrementalSnapshotCount >= checkoutEveryNth;\n const exceedTime = checkoutEveryNms && e2.timestamp - lastFullSnapshotEvent.timestamp > checkoutEveryNms;\n if (exceedCount || exceedTime) {\n takeFullSnapshot(true);\n }\n }\n };\n const wrappedMutationEmit = (m) => {\n wrappedEmit({\n type: EventType.IncrementalSnapshot,\n data: {\n source: IncrementalSource.Mutation,\n ...m\n }\n });\n };\n const wrappedScrollEmit = (p) => wrappedEmit({\n type: EventType.IncrementalSnapshot,\n data: {\n source: IncrementalSource.Scroll,\n ...p\n }\n });\n const wrappedCanvasMutationEmit = (p) => wrappedEmit({\n type: EventType.IncrementalSnapshot,\n data: {\n source: IncrementalSource.CanvasMutation,\n ...p\n }\n });\n const wrappedAdoptedStyleSheetEmit = (a2) => wrappedEmit({\n type: EventType.IncrementalSnapshot,\n data: {\n source: IncrementalSource.AdoptedStyleSheet,\n ...a2\n }\n });\n const stylesheetManager = new StylesheetManager({\n mutationCb: wrappedMutationEmit,\n adoptedStyleSheetCb: wrappedAdoptedStyleSheetEmit\n });\n const iframeManager = new IframeManager({\n mirror,\n mutationCb: wrappedMutationEmit,\n stylesheetManager,\n recordCrossOriginIframes,\n wrappedEmit\n });\n for (const plugin of plugins || []) {\n if (plugin.getMirror)\n plugin.getMirror({\n nodeMirror: mirror,\n crossOriginIframeMirror: iframeManager.crossOriginIframeMirror,\n crossOriginIframeStyleMirror: iframeManager.crossOriginIframeStyleMirror\n });\n }\n const processedNodeManager = new ProcessedNodeManager();\n canvasManager = new CanvasManager({\n recordCanvas,\n mutationCb: wrappedCanvasMutationEmit,\n win: window,\n blockClass,\n blockSelector,\n mirror,\n sampling: sampling.canvas,\n dataURLOptions\n });\n const shadowDomManager = new ShadowDomManager({\n mutationCb: wrappedMutationEmit,\n scrollCb: wrappedScrollEmit,\n bypassOptions: {\n blockClass,\n blockSelector,\n maskTextClass,\n maskTextSelector,\n inlineStylesheet,\n maskInputOptions,\n dataURLOptions,\n maskTextFn,\n maskInputFn,\n recordCanvas,\n inlineImages,\n sampling,\n slimDOMOptions,\n iframeManager,\n stylesheetManager,\n canvasManager,\n keepIframeSrcFn,\n processedNodeManager\n },\n mirror\n });\n takeFullSnapshot = (isCheckout = false) => {\n if (!recordDOM) {\n return;\n }\n wrappedEmit(\n {\n type: EventType.Meta,\n data: {\n href: window.location.href,\n width: getWindowWidth(),\n height: getWindowHeight()\n }\n },\n isCheckout\n );\n stylesheetManager.reset();\n shadowDomManager.init();\n mutationBuffers.forEach((buf) => buf.lock());\n const node = snapshot(document, {\n mirror,\n blockClass,\n blockSelector,\n maskTextClass,\n maskTextSelector,\n inlineStylesheet,\n maskAllInputs: maskInputOptions,\n maskTextFn,\n maskInputFn,\n slimDOM: slimDOMOptions,\n dataURLOptions,\n recordCanvas,\n inlineImages,\n onSerialize: (n2) => {\n if (isSerializedIframe(n2, mirror)) {\n iframeManager.addIframe(n2);\n }\n if (isSerializedStylesheet(n2, mirror)) {\n stylesheetManager.trackLinkElement(n2);\n }\n if (hasShadowRoot(n2)) {\n shadowDomManager.addShadowRoot(n2.shadowRoot, document);\n }\n },\n onIframeLoad: (iframe, childSn) => {\n iframeManager.attachIframe(iframe, childSn);\n shadowDomManager.observeAttachShadow(iframe);\n },\n onStylesheetLoad: (linkEl, childSn) => {\n stylesheetManager.attachLinkElement(linkEl, childSn);\n },\n keepIframeSrcFn\n });\n if (!node) {\n return console.warn(\"Failed to snapshot the document\");\n }\n wrappedEmit(\n {\n type: EventType.FullSnapshot,\n data: {\n node,\n initialOffset: getWindowScroll(window)\n }\n },\n isCheckout\n );\n mutationBuffers.forEach((buf) => buf.unlock());\n if (document.adoptedStyleSheets && document.adoptedStyleSheets.length > 0)\n stylesheetManager.adoptStyleSheets(\n document.adoptedStyleSheets,\n mirror.getId(document)\n );\n };\n try {\n const handlers = [];\n const observe = (doc) => {\n var _a2;\n return callbackWrapper(initObservers)(\n {\n mutationCb: wrappedMutationEmit,\n mousemoveCb: (positions, source) => wrappedEmit({\n type: EventType.IncrementalSnapshot,\n data: {\n source,\n positions\n }\n }),\n mouseInteractionCb: (d) => wrappedEmit({\n type: EventType.IncrementalSnapshot,\n data: {\n source: IncrementalSource.MouseInteraction,\n ...d\n }\n }),\n scrollCb: wrappedScrollEmit,\n viewportResizeCb: (d) => wrappedEmit({\n type: EventType.IncrementalSnapshot,\n data: {\n source: IncrementalSource.ViewportResize,\n ...d\n }\n }),\n inputCb: (v2) => wrappedEmit({\n type: EventType.IncrementalSnapshot,\n data: {\n source: IncrementalSource.Input,\n ...v2\n }\n }),\n mediaInteractionCb: (p) => wrappedEmit({\n type: EventType.IncrementalSnapshot,\n data: {\n source: IncrementalSource.MediaInteraction,\n ...p\n }\n }),\n styleSheetRuleCb: (r2) => wrappedEmit({\n type: EventType.IncrementalSnapshot,\n data: {\n source: IncrementalSource.StyleSheetRule,\n ...r2\n }\n }),\n styleDeclarationCb: (r2) => wrappedEmit({\n type: EventType.IncrementalSnapshot,\n data: {\n source: IncrementalSource.StyleDeclaration,\n ...r2\n }\n }),\n canvasMutationCb: wrappedCanvasMutationEmit,\n fontCb: (p) => wrappedEmit({\n type: EventType.IncrementalSnapshot,\n data: {\n source: IncrementalSource.Font,\n ...p\n }\n }),\n selectionCb: (p) => {\n wrappedEmit({\n type: EventType.IncrementalSnapshot,\n data: {\n source: IncrementalSource.Selection,\n ...p\n }\n });\n },\n customElementCb: (c2) => {\n wrappedEmit({\n type: EventType.IncrementalSnapshot,\n data: {\n source: IncrementalSource.CustomElement,\n ...c2\n }\n });\n },\n blockClass,\n ignoreClass,\n ignoreSelector,\n maskTextClass,\n maskTextSelector,\n maskInputOptions,\n inlineStylesheet,\n sampling,\n recordDOM,\n recordCanvas,\n inlineImages,\n userTriggeredOnInput,\n collectFonts,\n doc,\n maskInputFn,\n maskTextFn,\n keepIframeSrcFn,\n blockSelector,\n slimDOMOptions,\n dataURLOptions,\n mirror,\n iframeManager,\n stylesheetManager,\n shadowDomManager,\n processedNodeManager,\n canvasManager,\n ignoreCSSAttributes,\n plugins: ((_a2 = plugins == null ? void 0 : plugins.filter((p) => p.observer)) == null ? void 0 : _a2.map((p) => ({\n observer: p.observer,\n options: p.options,\n callback: (payload) => wrappedEmit({\n type: EventType.Plugin,\n data: {\n plugin: p.name,\n payload\n }\n })\n }))) || []\n },\n hooks\n );\n };\n iframeManager.addLoadListener((iframeEl) => {\n try {\n handlers.push(observe(iframeEl.contentDocument));\n } catch (error) {\n console.warn(error);\n }\n });\n const init = () => {\n takeFullSnapshot();\n handlers.push(observe(document));\n recording = true;\n };\n if (document.readyState === \"interactive\" || document.readyState === \"complete\") {\n init();\n } else {\n handlers.push(\n on(\"DOMContentLoaded\", () => {\n wrappedEmit({\n type: EventType.DomContentLoaded,\n data: {}\n });\n if (recordAfter === \"DOMContentLoaded\") init();\n })\n );\n handlers.push(\n on(\n \"load\",\n () => {\n wrappedEmit({\n type: EventType.Load,\n data: {}\n });\n if (recordAfter === \"load\") init();\n },\n window\n )\n );\n }\n return () => {\n handlers.forEach((h) => h());\n processedNodeManager.destroy();\n recording = false;\n unregisterErrorHandler();\n };\n } catch (error) {\n console.warn(error);\n }\n}\nrecord.addCustomEvent = (tag, payload) => {\n if (!recording) {\n throw new Error(\"please add custom event after start recording\");\n }\n wrappedEmit({\n type: EventType.Custom,\n data: {\n tag,\n payload\n }\n });\n};\nrecord.freezePage = () => {\n mutationBuffers.forEach((buf) => buf.freeze());\n};\nrecord.takeFullSnapshot = (isCheckout) => {\n if (!recording) {\n throw new Error(\"please take full snapshot after start recording\");\n }\n takeFullSnapshot(isCheckout);\n};\nrecord.mirror = mirror;\nvar __defProp2 = Object.defineProperty;\nvar __defNormalProp2 = (obj, key, value) => key in obj ? __defProp2(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __publicField2 = (obj, key, value) => __defNormalProp2(obj, typeof key !== \"symbol\" ? key + \"\" : key, value);\nvar __defProp22 = Object.defineProperty;\nvar __defNormalProp22 = (obj, key, value) => key in obj ? __defProp22(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __publicField22 = (obj, key, value) => __defNormalProp22(obj, typeof key !== \"symbol\" ? key + \"\" : key, value);\nvar NodeType$1 = /* @__PURE__ */ ((NodeType2) => {\n NodeType2[NodeType2[\"Document\"] = 0] = \"Document\";\n NodeType2[NodeType2[\"DocumentType\"] = 1] = \"DocumentType\";\n NodeType2[NodeType2[\"Element\"] = 2] = \"Element\";\n NodeType2[NodeType2[\"Text\"] = 3] = \"Text\";\n NodeType2[NodeType2[\"CDATA\"] = 4] = \"CDATA\";\n NodeType2[NodeType2[\"Comment\"] = 5] = \"Comment\";\n return NodeType2;\n})(NodeType$1 || {});\nlet Mirror$1 = class Mirror2 {\n constructor() {\n __publicField22(this, \"idNodeMap\", /* @__PURE__ */ new Map());\n __publicField22(this, \"nodeMetaMap\", /* @__PURE__ */ new WeakMap());\n }\n getId(n2) {\n var _a2;\n if (!n2) return -1;\n const id = (_a2 = this.getMeta(n2)) == null ? void 0 : _a2.id;\n return id ?? -1;\n }\n getNode(id) {\n return this.idNodeMap.get(id) || null;\n }\n getIds() {\n return Array.from(this.idNodeMap.keys());\n }\n getMeta(n2) {\n return this.nodeMetaMap.get(n2) || null;\n }\n // removes the node from idNodeMap\n // doesn't remove the node from nodeMetaMap\n removeNodeFromMap(n2) {\n const id = this.getId(n2);\n this.idNodeMap.delete(id);\n if (n2.childNodes) {\n n2.childNodes.forEach(\n (childNode) => this.removeNodeFromMap(childNode)\n );\n }\n }\n has(id) {\n return this.idNodeMap.has(id);\n }\n hasNode(node) {\n return this.nodeMetaMap.has(node);\n }\n add(n2, meta) {\n const id = meta.id;\n this.idNodeMap.set(id, n2);\n this.nodeMetaMap.set(n2, meta);\n }\n replace(id, n2) {\n const oldNode = this.getNode(id);\n if (oldNode) {\n const meta = this.nodeMetaMap.get(oldNode);\n if (meta) this.nodeMetaMap.set(n2, meta);\n }\n this.idNodeMap.set(id, n2);\n }\n reset() {\n this.idNodeMap = /* @__PURE__ */ new Map();\n this.nodeMetaMap = /* @__PURE__ */ new WeakMap();\n }\n};\nfunction createMirror$1() {\n return new Mirror$1();\n}\nfunction parseCSSText(cssText) {\n const res = {};\n const listDelimiter = /;(?![^(]*\\))/g;\n const propertyDelimiter = /:(.+)/;\n const comment = /\\/\\*.*?\\*\\//g;\n cssText.replace(comment, \"\").split(listDelimiter).forEach(function(item) {\n if (item) {\n const tmp = item.split(propertyDelimiter);\n tmp.length > 1 && (res[camelize(tmp[0].trim())] = tmp[1].trim());\n }\n });\n return res;\n}\nfunction toCSSText(style) {\n const properties = [];\n for (const name in style) {\n const value = style[name];\n if (typeof value !== \"string\") continue;\n const normalizedName = hyphenate(name);\n properties.push(`${normalizedName}: ${value};`);\n }\n return properties.join(\" \");\n}\nconst camelizeRE = /-([a-z])/g;\nconst CUSTOM_PROPERTY_REGEX = /^--[a-zA-Z0-9-]+$/;\nconst camelize = (str) => {\n if (CUSTOM_PROPERTY_REGEX.test(str)) return str;\n return str.replace(camelizeRE, (_, c2) => c2 ? c2.toUpperCase() : \"\");\n};\nconst hyphenateRE = /\\B([A-Z])/g;\nconst hyphenate = (str) => {\n return str.replace(hyphenateRE, \"-$1\").toLowerCase();\n};\nclass BaseRRNode {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/no-explicit-any\n constructor(..._args) {\n __publicField2(this, \"parentElement\", null);\n __publicField2(this, \"parentNode\", null);\n __publicField2(this, \"ownerDocument\");\n __publicField2(this, \"firstChild\", null);\n __publicField2(this, \"lastChild\", null);\n __publicField2(this, \"previousSibling\", null);\n __publicField2(this, \"nextSibling\", null);\n __publicField2(this, \"ELEMENT_NODE\", 1);\n __publicField2(this, \"TEXT_NODE\", 3);\n __publicField2(this, \"nodeType\");\n __publicField2(this, \"nodeName\");\n __publicField2(this, \"RRNodeType\");\n }\n get childNodes() {\n const childNodes = [];\n let childIterator = this.firstChild;\n while (childIterator) {\n childNodes.push(childIterator);\n childIterator = childIterator.nextSibling;\n }\n return childNodes;\n }\n contains(node) {\n if (!(node instanceof BaseRRNode)) return false;\n else if (node.ownerDocument !== this.ownerDocument) return false;\n else if (node === this) return true;\n while (node.parentNode) {\n if (node.parentNode === this) return true;\n node = node.parentNode;\n }\n return false;\n }\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n appendChild(_newChild) {\n throw new Error(\n `RRDomException: Failed to execute 'appendChild' on 'RRNode': This RRNode type does not support this method.`\n );\n }\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n insertBefore(_newChild, _refChild) {\n throw new Error(\n `RRDomException: Failed to execute 'insertBefore' on 'RRNode': This RRNode type does not support this method.`\n );\n }\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n removeChild(_node) {\n throw new Error(\n `RRDomException: Failed to execute 'removeChild' on 'RRNode': This RRNode type does not support this method.`\n );\n }\n toString() {\n return \"RRNode\";\n }\n}\nclass BaseRRDocument extends BaseRRNode {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n constructor(...args) {\n super(args);\n __publicField2(this, \"nodeType\", 9);\n __publicField2(this, \"nodeName\", \"#document\");\n __publicField2(this, \"compatMode\", \"CSS1Compat\");\n __publicField2(this, \"RRNodeType\", NodeType$1.Document);\n __publicField2(this, \"textContent\", null);\n this.ownerDocument = this;\n }\n get documentElement() {\n return this.childNodes.find(\n (node) => node.RRNodeType === NodeType$1.Element && node.tagName === \"HTML\"\n ) || null;\n }\n get body() {\n var _a2;\n return ((_a2 = this.documentElement) == null ? void 0 : _a2.childNodes.find(\n (node) => node.RRNodeType === NodeType$1.Element && node.tagName === \"BODY\"\n )) || null;\n }\n get head() {\n var _a2;\n return ((_a2 = this.documentElement) == null ? void 0 : _a2.childNodes.find(\n (node) => node.RRNodeType === NodeType$1.Element && node.tagName === \"HEAD\"\n )) || null;\n }\n get implementation() {\n return this;\n }\n get firstElementChild() {\n return this.documentElement;\n }\n appendChild(newChild) {\n const nodeType = newChild.RRNodeType;\n if (nodeType === NodeType$1.Element || nodeType === NodeType$1.DocumentType) {\n if (this.childNodes.some((s2) => s2.RRNodeType === nodeType)) {\n throw new Error(\n `RRDomException: Failed to execute 'appendChild' on 'RRNode': Only one ${nodeType === NodeType$1.Element ? \"RRElement\" : \"RRDoctype\"} on RRDocument allowed.`\n );\n }\n }\n const child = appendChild(this, newChild);\n child.parentElement = null;\n return child;\n }\n insertBefore(newChild, refChild) {\n const nodeType = newChild.RRNodeType;\n if (nodeType === NodeType$1.Element || nodeType === NodeType$1.DocumentType) {\n if (this.childNodes.some((s2) => s2.RRNodeType === nodeType)) {\n throw new Error(\n `RRDomException: Failed to execute 'insertBefore' on 'RRNode': Only one ${nodeType === NodeType$1.Element ? \"RRElement\" : \"RRDoctype\"} on RRDocument allowed.`\n );\n }\n }\n const child = insertBefore(this, newChild, refChild);\n child.parentElement = null;\n return child;\n }\n removeChild(node) {\n return removeChild(this, node);\n }\n open() {\n this.firstChild = null;\n this.lastChild = null;\n }\n close() {\n }\n /**\n * Adhoc implementation for setting xhtml namespace in rebuilt.ts (rrweb-snapshot).\n * There are two lines used this function:\n * 1. doc.write('\\<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"\"\\>')\n * 2. doc.write('\\<!DOCTYPE html PUBLIC \"-//W3C//DTD HTML 4.0 Transitional//EN\" \"\"\\>')\n */\n write(content) {\n let publicId;\n if (content === '<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"\">')\n publicId = \"-//W3C//DTD XHTML 1.0 Transitional//EN\";\n else if (content === '<!DOCTYPE html PUBLIC \"-//W3C//DTD HTML 4.0 Transitional//EN\" \"\">')\n publicId = \"-//W3C//DTD HTML 4.0 Transitional//EN\";\n if (publicId) {\n const doctype = this.createDocumentType(\"html\", publicId, \"\");\n this.open();\n this.appendChild(doctype);\n }\n }\n createDocument(_namespace, _qualifiedName, _doctype) {\n return new BaseRRDocument();\n }\n createDocumentType(qualifiedName, publicId, systemId) {\n const doctype = new BaseRRDocumentType(qualifiedName, publicId, systemId);\n doctype.ownerDocument = this;\n return doctype;\n }\n createElement(tagName) {\n const element = new BaseRRElement(tagName);\n element.ownerDocument = this;\n return element;\n }\n createElementNS(_namespaceURI, qualifiedName) {\n return this.createElement(qualifiedName);\n }\n createTextNode(data) {\n const text = new BaseRRText(data);\n text.ownerDocument = this;\n return text;\n }\n createComment(data) {\n const comment = new BaseRRComment(data);\n comment.ownerDocument = this;\n return comment;\n }\n createCDATASection(data) {\n const CDATASection = new BaseRRCDATASection(data);\n CDATASection.ownerDocument = this;\n return CDATASection;\n }\n toString() {\n return \"RRDocument\";\n }\n}\nclass BaseRRDocumentType extends BaseRRNode {\n constructor(qualifiedName, publicId, systemId) {\n super();\n __publicField2(this, \"nodeType\", 10);\n __publicField2(this, \"RRNodeType\", NodeType$1.DocumentType);\n __publicField2(this, \"name\");\n __publicField2(this, \"publicId\");\n __publicField2(this, \"systemId\");\n __publicField2(this, \"textContent\", null);\n this.name = qualifiedName;\n this.publicId = publicId;\n this.systemId = systemId;\n this.nodeName = qualifiedName;\n }\n toString() {\n return \"RRDocumentType\";\n }\n}\nclass BaseRRElement extends BaseRRNode {\n constructor(tagName) {\n super();\n __publicField2(this, \"nodeType\", 1);\n __publicField2(this, \"RRNodeType\", NodeType$1.Element);\n __publicField2(this, \"tagName\");\n __publicField2(this, \"attributes\", {});\n __publicField2(this, \"shadowRoot\", null);\n __publicField2(this, \"scrollLeft\");\n __publicField2(this, \"scrollTop\");\n this.tagName = tagName.toUpperCase();\n this.nodeName = tagName.toUpperCase();\n }\n get textContent() {\n let result = \"\";\n this.childNodes.forEach((node) => result += node.textContent);\n return result;\n }\n set textContent(textContent) {\n this.firstChild = null;\n this.lastChild = null;\n this.appendChild(this.ownerDocument.createTextNode(textContent));\n }\n get classList() {\n return new ClassList(\n this.attributes.class,\n (newClassName) => {\n this.attributes.class = newClassName;\n }\n );\n }\n get id() {\n return this.attributes.id || \"\";\n }\n get className() {\n return this.attributes.class || \"\";\n }\n get style() {\n const style = this.attributes.style ? parseCSSText(this.attributes.style) : {};\n const hyphenateRE2 = /\\B([A-Z])/g;\n style.setProperty = (name, value, priority) => {\n if (hyphenateRE2.test(name)) return;\n const normalizedName = camelize(name);\n if (!value) delete style[normalizedName];\n else style[normalizedName] = value;\n if (priority === \"important\") style[normalizedName] += \" !important\";\n this.attributes.style = toCSSText(style);\n };\n style.removeProperty = (name) => {\n if (hyphenateRE2.test(name)) return \"\";\n const normalizedName = camelize(name);\n const value = style[normalizedName] || \"\";\n delete style[normalizedName];\n this.attributes.style = toCSSText(style);\n return value;\n };\n return style;\n }\n getAttribute(name) {\n return this.attributes[name] || null;\n }\n setAttribute(name, attribute) {\n this.attributes[name] = attribute;\n }\n setAttributeNS(_namespace, qualifiedName, value) {\n this.setAttribute(qualifiedName, value);\n }\n removeAttribute(name) {\n delete this.attributes[name];\n }\n appendChild(newChild) {\n return appendChild(this, newChild);\n }\n insertBefore(newChild, refChild) {\n return insertBefore(this, newChild, refChild);\n }\n removeChild(node) {\n return removeChild(this, node);\n }\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n attachShadow(_init) {\n const shadowRoot = this.ownerDocument.createElement(\"SHADOWROOT\");\n this.shadowRoot = shadowRoot;\n return shadowRoot;\n }\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n dispatchEvent(_event) {\n return true;\n }\n toString() {\n let attributeString = \"\";\n for (const attribute in this.attributes) {\n attributeString += `${attribute}=\"${this.attributes[attribute]}\" `;\n }\n return `${this.tagName} ${attributeString}`;\n }\n}\nclass BaseRRMediaElement extends BaseRRElement {\n constructor() {\n super(...arguments);\n __publicField2(this, \"currentTime\");\n __publicField2(this, \"volume\");\n __publicField2(this, \"paused\");\n __publicField2(this, \"muted\");\n __publicField2(this, \"playbackRate\");\n __publicField2(this, \"loop\");\n }\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n attachShadow(_init) {\n throw new Error(\n `RRDomException: Failed to execute 'attachShadow' on 'RRElement': This RRElement does not support attachShadow`\n );\n }\n play() {\n this.paused = false;\n }\n pause() {\n this.paused = true;\n }\n}\nclass BaseRRText extends BaseRRNode {\n constructor(data) {\n super();\n __publicField2(this, \"nodeType\", 3);\n __publicField2(this, \"nodeName\", \"#text\");\n __publicField2(this, \"RRNodeType\", NodeType$1.Text);\n __publicField2(this, \"data\");\n this.data = data;\n }\n get textContent() {\n return this.data;\n }\n set textContent(textContent) {\n this.data = textContent;\n }\n toString() {\n return `RRText text=${JSON.stringify(this.data)}`;\n }\n}\nclass BaseRRComment extends BaseRRNode {\n constructor(data) {\n super();\n __publicField2(this, \"nodeType\", 8);\n __publicField2(this, \"nodeName\", \"#comment\");\n __publicField2(this, \"RRNodeType\", NodeType$1.Comment);\n __publicField2(this, \"data\");\n this.data = data;\n }\n get textContent() {\n return this.data;\n }\n set textContent(textContent) {\n this.data = textContent;\n }\n toString() {\n return `RRComment text=${JSON.stringify(this.data)}`;\n }\n}\nclass BaseRRCDATASection extends BaseRRNode {\n constructor(data) {\n super();\n __publicField2(this, \"nodeName\", \"#cdata-section\");\n __publicField2(this, \"nodeType\", 4);\n __publicField2(this, \"RRNodeType\", NodeType$1.CDATA);\n __publicField2(this, \"data\");\n this.data = data;\n }\n get textContent() {\n return this.data;\n }\n set textContent(textContent) {\n this.data = textContent;\n }\n toString() {\n return `RRCDATASection data=${JSON.stringify(this.data)}`;\n }\n}\nclass ClassList {\n constructor(classText, onChange) {\n __publicField2(this, \"onChange\");\n __publicField2(this, \"classes\", []);\n __publicField2(this, \"add\", (...classNames) => {\n for (const item of classNames) {\n const className = String(item);\n if (this.classes.indexOf(className) >= 0) continue;\n this.classes.push(className);\n }\n this.onChange && this.onChange(this.classes.join(\" \"));\n });\n __publicField2(this, \"remove\", (...classNames) => {\n this.classes = this.classes.filter(\n (item) => classNames.indexOf(item) === -1\n );\n this.onChange && this.onChange(this.classes.join(\" \"));\n });\n if (classText) {\n const classes = classText.trim().split(/\\s+/);\n this.classes.push(...classes);\n }\n this.onChange = onChange;\n }\n}\nfunction appendChild(parent, newChild) {\n if (newChild.parentNode) newChild.parentNode.removeChild(newChild);\n if (parent.lastChild) {\n parent.lastChild.nextSibling = newChild;\n newChild.previousSibling = parent.lastChild;\n } else {\n parent.firstChild = newChild;\n newChild.previousSibling = null;\n }\n parent.lastChild = newChild;\n newChild.nextSibling = null;\n newChild.parentNode = parent;\n newChild.parentElement = parent;\n newChild.ownerDocument = parent.ownerDocument;\n return newChild;\n}\nfunction insertBefore(parent, newChild, refChild) {\n if (!refChild) return appendChild(parent, newChild);\n if (refChild.parentNode !== parent)\n throw new Error(\n \"Failed to execute 'insertBefore' on 'RRNode': The RRNode before which the new node is to be inserted is not a child of this RRNode.\"\n );\n if (newChild === refChild) return newChild;\n if (newChild.parentNode) newChild.parentNode.removeChild(newChild);\n newChild.previousSibling = refChild.previousSibling;\n refChild.previousSibling = newChild;\n newChild.nextSibling = refChild;\n if (newChild.previousSibling) newChild.previousSibling.nextSibling = newChild;\n else parent.firstChild = newChild;\n newChild.parentElement = parent;\n newChild.parentNode = parent;\n newChild.ownerDocument = parent.ownerDocument;\n return newChild;\n}\nfunction removeChild(parent, child) {\n if (child.parentNode !== parent)\n throw new Error(\n \"Failed to execute 'removeChild' on 'RRNode': The RRNode to be removed is not a child of this RRNode.\"\n );\n if (child.previousSibling)\n child.previousSibling.nextSibling = child.nextSibling;\n else parent.firstChild = child.nextSibling;\n if (child.nextSibling)\n child.nextSibling.previousSibling = child.previousSibling;\n else parent.lastChild = child.previousSibling;\n child.previousSibling = null;\n child.nextSibling = null;\n child.parentElement = null;\n child.parentNode = null;\n return child;\n}\nvar NodeType = /* @__PURE__ */ ((NodeType2) => {\n NodeType2[NodeType2[\"PLACEHOLDER\"] = 0] = \"PLACEHOLDER\";\n NodeType2[NodeType2[\"ELEMENT_NODE\"] = 1] = \"ELEMENT_NODE\";\n NodeType2[NodeType2[\"ATTRIBUTE_NODE\"] = 2] = \"ATTRIBUTE_NODE\";\n NodeType2[NodeType2[\"TEXT_NODE\"] = 3] = \"TEXT_NODE\";\n NodeType2[NodeType2[\"CDATA_SECTION_NODE\"] = 4] = \"CDATA_SECTION_NODE\";\n NodeType2[NodeType2[\"ENTITY_REFERENCE_NODE\"] = 5] = \"ENTITY_REFERENCE_NODE\";\n NodeType2[NodeType2[\"ENTITY_NODE\"] = 6] = \"ENTITY_NODE\";\n NodeType2[NodeType2[\"PROCESSING_INSTRUCTION_NODE\"] = 7] = \"PROCESSING_INSTRUCTION_NODE\";\n NodeType2[NodeType2[\"COMMENT_NODE\"] = 8] = \"COMMENT_NODE\";\n NodeType2[NodeType2[\"DOCUMENT_NODE\"] = 9] = \"DOCUMENT_NODE\";\n NodeType2[NodeType2[\"DOCUMENT_TYPE_NODE\"] = 10] = \"DOCUMENT_TYPE_NODE\";\n NodeType2[NodeType2[\"DOCUMENT_FRAGMENT_NODE\"] = 11] = \"DOCUMENT_FRAGMENT_NODE\";\n return NodeType2;\n})(NodeType || {});\nconst NAMESPACES = {\n svg: \"http://www.w3.org/2000/svg\",\n \"xlink:href\": \"http://www.w3.org/1999/xlink\",\n xmlns: \"http://www.w3.org/2000/xmlns/\"\n};\nconst SVGTagMap = {\n altglyph: \"altGlyph\",\n altglyphdef: \"altGlyphDef\",\n altglyphitem: \"altGlyphItem\",\n animatecolor: \"animateColor\",\n animatemotion: \"animateMotion\",\n animatetransform: \"animateTransform\",\n clippath: \"clipPath\",\n feblend: \"feBlend\",\n fecolormatrix: \"feColorMatrix\",\n fecomponenttransfer: \"feComponentTransfer\",\n fecomposite: \"feComposite\",\n feconvolvematrix: \"feConvolveMatrix\",\n fediffuselighting: \"feDiffuseLighting\",\n fedisplacementmap: \"feDisplacementMap\",\n fedistantlight: \"feDistantLight\",\n fedropshadow: \"feDropShadow\",\n feflood: \"feFlood\",\n fefunca: \"feFuncA\",\n fefuncb: \"feFuncB\",\n fefuncg: \"feFuncG\",\n fefuncr: \"feFuncR\",\n fegaussianblur: \"feGaussianBlur\",\n feimage: \"feImage\",\n femerge: \"feMerge\",\n femergenode: \"feMergeNode\",\n femorphology: \"feMorphology\",\n feoffset: \"feOffset\",\n fepointlight: \"fePointLight\",\n fespecularlighting: \"feSpecularLighting\",\n fespotlight: \"feSpotLight\",\n fetile: \"feTile\",\n feturbulence: \"feTurbulence\",\n foreignobject: \"foreignObject\",\n glyphref: \"glyphRef\",\n lineargradient: \"linearGradient\",\n radialgradient: \"radialGradient\"\n};\nlet createdNodeSet = null;\nfunction diff(oldTree, newTree, replayer, rrnodeMirror = newTree.mirror || newTree.ownerDocument.mirror) {\n oldTree = diffBeforeUpdatingChildren(\n oldTree,\n newTree,\n replayer,\n rrnodeMirror\n );\n diffChildren(oldTree, newTree, replayer, rrnodeMirror);\n diffAfterUpdatingChildren(oldTree, newTree, replayer);\n}\nfunction diffBeforeUpdatingChildren(oldTree, newTree, replayer, rrnodeMirror) {\n var _a2;\n if (replayer.afterAppend && !createdNodeSet) {\n createdNodeSet = /* @__PURE__ */ new WeakSet();\n setTimeout(() => {\n createdNodeSet = null;\n }, 0);\n }\n if (!sameNodeType(oldTree, newTree)) {\n const calibratedOldTree = createOrGetNode(\n newTree,\n replayer.mirror,\n rrnodeMirror\n );\n (_a2 = oldTree.parentNode) == null ? void 0 : _a2.replaceChild(calibratedOldTree, oldTree);\n oldTree = calibratedOldTree;\n }\n switch (newTree.RRNodeType) {\n case NodeType$1.Document: {\n if (!nodeMatching(oldTree, newTree, replayer.mirror, rrnodeMirror)) {\n const newMeta = rrnodeMirror.getMeta(newTree);\n if (newMeta) {\n replayer.mirror.removeNodeFromMap(oldTree);\n oldTree.close();\n oldTree.open();\n replayer.mirror.add(oldTree, newMeta);\n createdNodeSet == null ? void 0 : createdNodeSet.add(oldTree);\n }\n }\n break;\n }\n case NodeType$1.Element: {\n const oldElement = oldTree;\n const newRRElement = newTree;\n switch (newRRElement.tagName) {\n case \"IFRAME\": {\n const oldContentDocument = oldTree.contentDocument;\n if (!oldContentDocument) break;\n diff(\n oldContentDocument,\n newTree.contentDocument,\n replayer,\n rrnodeMirror\n );\n break;\n }\n }\n if (newRRElement.shadowRoot) {\n if (!oldElement.shadowRoot) oldElement.attachShadow({ mode: \"open\" });\n diffChildren(\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n oldElement.shadowRoot,\n newRRElement.shadowRoot,\n replayer,\n rrnodeMirror\n );\n }\n diffProps(oldElement, newRRElement, rrnodeMirror);\n break;\n }\n }\n return oldTree;\n}\nfunction diffAfterUpdatingChildren(oldTree, newTree, replayer) {\n var _a2;\n switch (newTree.RRNodeType) {\n case NodeType$1.Document: {\n const scrollData = newTree.scrollData;\n scrollData && replayer.applyScroll(scrollData, true);\n break;\n }\n case NodeType$1.Element: {\n const oldElement = oldTree;\n const newRRElement = newTree;\n newRRElement.scrollData && replayer.applyScroll(newRRElement.scrollData, true);\n newRRElement.inputData && replayer.applyInput(newRRElement.inputData);\n switch (newRRElement.tagName) {\n case \"AUDIO\":\n case \"VIDEO\": {\n const oldMediaElement = oldTree;\n const newMediaRRElement = newRRElement;\n if (newMediaRRElement.paused !== void 0)\n newMediaRRElement.paused ? void oldMediaElement.pause() : void oldMediaElement.play();\n if (newMediaRRElement.muted !== void 0)\n oldMediaElement.muted = newMediaRRElement.muted;\n if (newMediaRRElement.volume !== void 0)\n oldMediaElement.volume = newMediaRRElement.volume;\n if (newMediaRRElement.currentTime !== void 0)\n oldMediaElement.currentTime = newMediaRRElement.currentTime;\n if (newMediaRRElement.playbackRate !== void 0)\n oldMediaElement.playbackRate = newMediaRRElement.playbackRate;\n if (newMediaRRElement.loop !== void 0)\n oldMediaElement.loop = newMediaRRElement.loop;\n break;\n }\n case \"CANVAS\": {\n const rrCanvasElement = newTree;\n if (rrCanvasElement.rr_dataURL !== null) {\n const image = document.createElement(\"img\");\n image.onload = () => {\n const ctx = oldElement.getContext(\"2d\");\n if (ctx) {\n ctx.drawImage(image, 0, 0, image.width, image.height);\n }\n };\n image.src = rrCanvasElement.rr_dataURL;\n }\n rrCanvasElement.canvasMutations.forEach(\n (canvasMutation2) => replayer.applyCanvas(\n canvasMutation2.event,\n canvasMutation2.mutation,\n oldTree\n )\n );\n break;\n }\n case \"STYLE\": {\n const styleSheet = oldElement.sheet;\n styleSheet && newTree.rules.forEach(\n (data) => replayer.applyStyleSheetMutation(data, styleSheet)\n );\n break;\n }\n }\n break;\n }\n case NodeType$1.Text:\n case NodeType$1.Comment:\n case NodeType$1.CDATA: {\n if (oldTree.textContent !== newTree.data)\n oldTree.textContent = newTree.data;\n break;\n }\n }\n if (createdNodeSet == null ? void 0 : createdNodeSet.has(oldTree)) {\n createdNodeSet.delete(oldTree);\n (_a2 = replayer.afterAppend) == null ? void 0 : _a2.call(replayer, oldTree, replayer.mirror.getId(oldTree));\n }\n}\nfunction diffProps(oldTree, newTree, rrnodeMirror) {\n const oldAttributes = oldTree.attributes;\n const newAttributes = newTree.attributes;\n for (const name in newAttributes) {\n const newValue = newAttributes[name];\n const sn = rrnodeMirror.getMeta(newTree);\n if ((sn == null ? void 0 : sn.isSVG) && NAMESPACES[name])\n oldTree.setAttributeNS(NAMESPACES[name], name, newValue);\n else if (newTree.tagName === \"CANVAS\" && name === \"rr_dataURL\") {\n const image = document.createElement(\"img\");\n image.src = newValue;\n image.onload = () => {\n const ctx = oldTree.getContext(\"2d\");\n if (ctx) {\n ctx.drawImage(image, 0, 0, image.width, image.height);\n }\n };\n } else if (newTree.tagName === \"IFRAME\" && name === \"srcdoc\") continue;\n else oldTree.setAttribute(name, newValue);\n }\n for (const { name } of Array.from(oldAttributes))\n if (!(name in newAttributes)) oldTree.removeAttribute(name);\n newTree.scrollLeft && (oldTree.scrollLeft = newTree.scrollLeft);\n newTree.scrollTop && (oldTree.scrollTop = newTree.scrollTop);\n}\nfunction diffChildren(oldTree, newTree, replayer, rrnodeMirror) {\n const oldChildren = Array.from(oldTree.childNodes);\n const newChildren = newTree.childNodes;\n if (oldChildren.length === 0 && newChildren.length === 0) return;\n let oldStartIndex = 0, oldEndIndex = oldChildren.length - 1, newStartIndex = 0, newEndIndex = newChildren.length - 1;\n let oldStartNode = oldChildren[oldStartIndex], oldEndNode = oldChildren[oldEndIndex], newStartNode = newChildren[newStartIndex], newEndNode = newChildren[newEndIndex];\n let oldIdToIndex = void 0, indexInOld = void 0;\n while (oldStartIndex <= oldEndIndex && newStartIndex <= newEndIndex) {\n if (oldStartNode === void 0) {\n oldStartNode = oldChildren[++oldStartIndex];\n } else if (oldEndNode === void 0) {\n oldEndNode = oldChildren[--oldEndIndex];\n } else if (\n // same first node?\n nodeMatching(oldStartNode, newStartNode, replayer.mirror, rrnodeMirror)\n ) {\n oldStartNode = oldChildren[++oldStartIndex];\n newStartNode = newChildren[++newStartIndex];\n } else if (\n // same last node?\n nodeMatching(oldEndNode, newEndNode, replayer.mirror, rrnodeMirror)\n ) {\n oldEndNode = oldChildren[--oldEndIndex];\n newEndNode = newChildren[--newEndIndex];\n } else if (\n // is the first old node the same as the last new node?\n nodeMatching(oldStartNode, newEndNode, replayer.mirror, rrnodeMirror)\n ) {\n try {\n oldTree.insertBefore(oldStartNode, oldEndNode.nextSibling);\n } catch (e2) {\n console.warn(e2);\n }\n oldStartNode = oldChildren[++oldStartIndex];\n newEndNode = newChildren[--newEndIndex];\n } else if (\n // is the last old node the same as the first new node?\n nodeMatching(oldEndNode, newStartNode, replayer.mirror, rrnodeMirror)\n ) {\n try {\n oldTree.insertBefore(oldEndNode, oldStartNode);\n } catch (e2) {\n console.warn(e2);\n }\n oldEndNode = oldChildren[--oldEndIndex];\n newStartNode = newChildren[++newStartIndex];\n } else {\n if (!oldIdToIndex) {\n oldIdToIndex = {};\n for (let i2 = oldStartIndex; i2 <= oldEndIndex; i2++) {\n const oldChild2 = oldChildren[i2];\n if (oldChild2 && replayer.mirror.hasNode(oldChild2))\n oldIdToIndex[replayer.mirror.getId(oldChild2)] = i2;\n }\n }\n indexInOld = oldIdToIndex[rrnodeMirror.getId(newStartNode)];\n const nodeToMove = oldChildren[indexInOld];\n if (indexInOld !== void 0 && nodeToMove && nodeMatching(nodeToMove, newStartNode, replayer.mirror, rrnodeMirror)) {\n try {\n oldTree.insertBefore(nodeToMove, oldStartNode);\n } catch (e2) {\n console.warn(e2);\n }\n oldChildren[indexInOld] = void 0;\n } else {\n const newNode = createOrGetNode(\n newStartNode,\n replayer.mirror,\n rrnodeMirror\n );\n if (oldTree.nodeName === \"#document\" && oldStartNode && /**\n * Special case 1: one document isn't allowed to have two doctype nodes at the same time, so we need to remove the old one first before inserting the new one.\n * How this case happens: A parent document in the old tree already has a doctype node with an id e.g. #1. A new full snapshot rebuilds the replayer with a new doctype node with another id #2. According to the algorithm, the new doctype node will be inserted before the old one, which is not allowed by the Document standard.\n */\n (newNode.nodeType === newNode.DOCUMENT_TYPE_NODE && oldStartNode.nodeType === oldStartNode.DOCUMENT_TYPE_NODE || /**\n * Special case 2: one document isn't allowed to have two HTMLElements at the same time, so we need to remove the old one first before inserting the new one.\n * How this case happens: A mounted iframe element has an automatically created HTML element. We should delete it before inserting a serialized one. Otherwise, an error 'Only one element on document allowed' will be thrown.\n */\n newNode.nodeType === newNode.ELEMENT_NODE && oldStartNode.nodeType === oldStartNode.ELEMENT_NODE)) {\n oldTree.removeChild(oldStartNode);\n replayer.mirror.removeNodeFromMap(oldStartNode);\n oldStartNode = oldChildren[++oldStartIndex];\n }\n try {\n oldTree.insertBefore(newNode, oldStartNode || null);\n } catch (e2) {\n console.warn(e2);\n }\n }\n newStartNode = newChildren[++newStartIndex];\n }\n }\n if (oldStartIndex > oldEndIndex) {\n const referenceRRNode = newChildren[newEndIndex + 1];\n let referenceNode = null;\n if (referenceRRNode)\n referenceNode = replayer.mirror.getNode(\n rrnodeMirror.getId(referenceRRNode)\n );\n for (; newStartIndex <= newEndIndex; ++newStartIndex) {\n const newNode = createOrGetNode(\n newChildren[newStartIndex],\n replayer.mirror,\n rrnodeMirror\n );\n try {\n oldTree.insertBefore(newNode, referenceNode);\n } catch (e2) {\n console.warn(e2);\n }\n }\n } else if (newStartIndex > newEndIndex) {\n for (; oldStartIndex <= oldEndIndex; oldStartIndex++) {\n const node = oldChildren[oldStartIndex];\n if (!node || node.parentNode !== oldTree) continue;\n try {\n oldTree.removeChild(node);\n replayer.mirror.removeNodeFromMap(node);\n } catch (e2) {\n console.warn(e2);\n }\n }\n }\n let oldChild = oldTree.firstChild;\n let newChild = newTree.firstChild;\n while (oldChild !== null && newChild !== null) {\n diff(oldChild, newChild, replayer, rrnodeMirror);\n oldChild = oldChild.nextSibling;\n newChild = newChild.nextSibling;\n }\n}\nfunction createOrGetNode(rrNode, domMirror, rrnodeMirror) {\n const nodeId = rrnodeMirror.getId(rrNode);\n const sn = rrnodeMirror.getMeta(rrNode);\n let node = null;\n if (nodeId > -1) node = domMirror.getNode(nodeId);\n if (node !== null && sameNodeType(node, rrNode)) return node;\n switch (rrNode.RRNodeType) {\n case NodeType$1.Document:\n node = new Document();\n break;\n case NodeType$1.DocumentType:\n node = document.implementation.createDocumentType(\n rrNode.name,\n rrNode.publicId,\n rrNode.systemId\n );\n break;\n case NodeType$1.Element: {\n let tagName = rrNode.tagName.toLowerCase();\n tagName = SVGTagMap[tagName] || tagName;\n if (sn && \"isSVG\" in sn && (sn == null ? void 0 : sn.isSVG)) {\n node = document.createElementNS(NAMESPACES[\"svg\"], tagName);\n } else node = document.createElement(rrNode.tagName);\n break;\n }\n case NodeType$1.Text:\n node = document.createTextNode(rrNode.data);\n break;\n case NodeType$1.Comment:\n node = document.createComment(rrNode.data);\n break;\n case NodeType$1.CDATA:\n node = document.createCDATASection(rrNode.data);\n break;\n }\n if (sn) domMirror.add(node, { ...sn });\n try {\n createdNodeSet == null ? void 0 : createdNodeSet.add(node);\n } catch (e2) {\n }\n return node;\n}\nfunction sameNodeType(node1, node2) {\n if (node1.nodeType !== node2.nodeType) return false;\n return node1.nodeType !== node1.ELEMENT_NODE || node1.tagName.toUpperCase() === node2.tagName;\n}\nfunction nodeMatching(node1, node2, domMirror, rrdomMirror) {\n const node1Id = domMirror.getId(node1);\n const node2Id = rrdomMirror.getId(node2);\n if (node1Id === -1 || node1Id !== node2Id) return false;\n return sameNodeType(node1, node2);\n}\nclass RRDocument extends BaseRRDocument {\n constructor(mirror2) {\n super();\n __publicField2(this, \"UNSERIALIZED_STARTING_ID\", -2);\n __publicField2(this, \"_unserializedId\", this.UNSERIALIZED_STARTING_ID);\n __publicField2(this, \"mirror\", createMirror());\n __publicField2(this, \"scrollData\", null);\n if (mirror2) {\n this.mirror = mirror2;\n }\n }\n /**\n * Every time the id is used, it will minus 1 automatically to avoid collisions.\n */\n get unserializedId() {\n return this._unserializedId--;\n }\n createDocument(_namespace, _qualifiedName, _doctype) {\n return new RRDocument();\n }\n createDocumentType(qualifiedName, publicId, systemId) {\n const documentTypeNode = new RRDocumentType(\n qualifiedName,\n publicId,\n systemId\n );\n documentTypeNode.ownerDocument = this;\n return documentTypeNode;\n }\n createElement(tagName) {\n const upperTagName = tagName.toUpperCase();\n let element;\n switch (upperTagName) {\n case \"AUDIO\":\n case \"VIDEO\":\n element = new RRMediaElement(upperTagName);\n break;\n case \"IFRAME\":\n element = new RRIFrameElement(upperTagName, this.mirror);\n break;\n case \"CANVAS\":\n element = new RRCanvasElement(upperTagName);\n break;\n case \"STYLE\":\n element = new RRStyleElement(upperTagName);\n break;\n default:\n element = new RRElement(upperTagName);\n break;\n }\n element.ownerDocument = this;\n return element;\n }\n createComment(data) {\n const commentNode = new RRComment(data);\n commentNode.ownerDocument = this;\n return commentNode;\n }\n createCDATASection(data) {\n const sectionNode = new RRCDATASection(data);\n sectionNode.ownerDocument = this;\n return sectionNode;\n }\n createTextNode(data) {\n const textNode = new RRText(data);\n textNode.ownerDocument = this;\n return textNode;\n }\n destroyTree() {\n this.firstChild = null;\n this.lastChild = null;\n this.mirror.reset();\n }\n open() {\n super.open();\n this._unserializedId = this.UNSERIALIZED_STARTING_ID;\n }\n}\nconst RRDocumentType = BaseRRDocumentType;\nclass RRElement extends BaseRRElement {\n constructor() {\n super(...arguments);\n __publicField2(this, \"inputData\", null);\n __publicField2(this, \"scrollData\", null);\n }\n}\nclass RRMediaElement extends BaseRRMediaElement {\n}\nclass RRCanvasElement extends RRElement {\n constructor() {\n super(...arguments);\n __publicField2(this, \"rr_dataURL\", null);\n __publicField2(this, \"canvasMutations\", []);\n }\n /**\n * This is a dummy implementation to distinguish RRCanvasElement from real HTMLCanvasElement.\n */\n getContext() {\n return null;\n }\n}\nclass RRStyleElement extends RRElement {\n constructor() {\n super(...arguments);\n __publicField2(this, \"rules\", []);\n }\n}\nclass RRIFrameElement extends RRElement {\n constructor(upperTagName, mirror2) {\n super(upperTagName);\n __publicField2(this, \"contentDocument\", new RRDocument());\n this.contentDocument.mirror = mirror2;\n }\n}\nconst RRText = BaseRRText;\nconst RRComment = BaseRRComment;\nconst RRCDATASection = BaseRRCDATASection;\nfunction getValidTagName(element) {\n if (element instanceof HTMLFormElement) {\n return \"FORM\";\n }\n return element.tagName.toUpperCase();\n}\nfunction buildFromNode(node, rrdom, domMirror, parentRRNode) {\n let rrNode;\n switch (node.nodeType) {\n case NodeType.DOCUMENT_NODE:\n if (parentRRNode && parentRRNode.nodeName === \"IFRAME\")\n rrNode = parentRRNode.contentDocument;\n else {\n rrNode = rrdom;\n rrNode.compatMode = node.compatMode;\n }\n break;\n case NodeType.DOCUMENT_TYPE_NODE: {\n const documentType = node;\n rrNode = rrdom.createDocumentType(\n documentType.name,\n documentType.publicId,\n documentType.systemId\n );\n break;\n }\n case NodeType.ELEMENT_NODE: {\n const elementNode = node;\n const tagName = getValidTagName(elementNode);\n rrNode = rrdom.createElement(tagName);\n const rrElement = rrNode;\n for (const { name, value } of Array.from(elementNode.attributes)) {\n rrElement.attributes[name] = value;\n }\n elementNode.scrollLeft && (rrElement.scrollLeft = elementNode.scrollLeft);\n elementNode.scrollTop && (rrElement.scrollTop = elementNode.scrollTop);\n break;\n }\n case NodeType.TEXT_NODE:\n rrNode = rrdom.createTextNode(node.textContent || \"\");\n break;\n case NodeType.CDATA_SECTION_NODE:\n rrNode = rrdom.createCDATASection(node.data);\n break;\n case NodeType.COMMENT_NODE:\n rrNode = rrdom.createComment(node.textContent || \"\");\n break;\n case NodeType.DOCUMENT_FRAGMENT_NODE:\n rrNode = parentRRNode.attachShadow({ mode: \"open\" });\n break;\n default:\n return null;\n }\n let sn = domMirror.getMeta(node);\n if (rrdom instanceof RRDocument) {\n if (!sn) {\n sn = getDefaultSN(rrNode, rrdom.unserializedId);\n domMirror.add(node, sn);\n }\n rrdom.mirror.add(rrNode, { ...sn });\n }\n return rrNode;\n}\nfunction buildFromDom(dom, domMirror = createMirror$1(), rrdom = new RRDocument()) {\n function walk2(node, parentRRNode) {\n const rrNode = buildFromNode(node, rrdom, domMirror, parentRRNode);\n if (rrNode === null) return;\n if (\n // if the parentRRNode isn't a RRIFrameElement\n (parentRRNode == null ? void 0 : parentRRNode.nodeName) !== \"IFRAME\" && // if node isn't a shadow root\n node.nodeType !== NodeType.DOCUMENT_FRAGMENT_NODE\n ) {\n parentRRNode == null ? void 0 : parentRRNode.appendChild(rrNode);\n rrNode.parentNode = parentRRNode;\n rrNode.parentElement = parentRRNode;\n }\n if (node.nodeName === \"IFRAME\") {\n const iframeDoc = node.contentDocument;\n iframeDoc && walk2(iframeDoc, rrNode);\n } else if (node.nodeType === NodeType.DOCUMENT_NODE || node.nodeType === NodeType.ELEMENT_NODE || node.nodeType === NodeType.DOCUMENT_FRAGMENT_NODE) {\n if (node.nodeType === NodeType.ELEMENT_NODE && node.shadowRoot)\n walk2(node.shadowRoot, rrNode);\n node.childNodes.forEach((childNode) => walk2(childNode, rrNode));\n }\n }\n walk2(dom, null);\n return rrdom;\n}\nfunction createMirror() {\n return new Mirror22();\n}\nclass Mirror22 {\n constructor() {\n __publicField2(this, \"idNodeMap\", /* @__PURE__ */ new Map());\n __publicField2(this, \"nodeMetaMap\", /* @__PURE__ */ new WeakMap());\n }\n getId(n2) {\n var _a2;\n if (!n2) return -1;\n const id = (_a2 = this.getMeta(n2)) == null ? void 0 : _a2.id;\n return id ?? -1;\n }\n getNode(id) {\n return this.idNodeMap.get(id) || null;\n }\n getIds() {\n return Array.from(this.idNodeMap.keys());\n }\n getMeta(n2) {\n return this.nodeMetaMap.get(n2) || null;\n }\n // removes the node from idNodeMap\n // doesn't remove the node from nodeMetaMap\n removeNodeFromMap(n2) {\n const id = this.getId(n2);\n this.idNodeMap.delete(id);\n if (n2.childNodes) {\n n2.childNodes.forEach((childNode) => this.removeNodeFromMap(childNode));\n }\n }\n has(id) {\n return this.idNodeMap.has(id);\n }\n hasNode(node) {\n return this.nodeMetaMap.has(node);\n }\n add(n2, meta) {\n const id = meta.id;\n this.idNodeMap.set(id, n2);\n this.nodeMetaMap.set(n2, meta);\n }\n replace(id, n2) {\n const oldNode = this.getNode(id);\n if (oldNode) {\n const meta = this.nodeMetaMap.get(oldNode);\n if (meta) this.nodeMetaMap.set(n2, meta);\n }\n this.idNodeMap.set(id, n2);\n }\n reset() {\n this.idNodeMap = /* @__PURE__ */ new Map();\n this.nodeMetaMap = /* @__PURE__ */ new WeakMap();\n }\n}\nfunction getDefaultSN(node, id) {\n switch (node.RRNodeType) {\n case NodeType$1.Document:\n return {\n id,\n type: node.RRNodeType,\n childNodes: []\n };\n case NodeType$1.DocumentType: {\n const doctype = node;\n return {\n id,\n type: node.RRNodeType,\n name: doctype.name,\n publicId: doctype.publicId,\n systemId: doctype.systemId\n };\n }\n case NodeType$1.Element:\n return {\n id,\n type: node.RRNodeType,\n tagName: node.tagName.toLowerCase(),\n // In rrweb data, all tagNames are lowercase.\n attributes: {},\n childNodes: []\n };\n case NodeType$1.Text:\n return {\n id,\n type: node.RRNodeType,\n textContent: node.textContent || \"\"\n };\n case NodeType$1.Comment:\n return {\n id,\n type: node.RRNodeType,\n textContent: node.textContent || \"\"\n };\n case NodeType$1.CDATA:\n return {\n id,\n type: node.RRNodeType,\n textContent: \"\"\n };\n }\n}\nfunction mitt$1(n2) {\n return { all: n2 = n2 || /* @__PURE__ */ new Map(), on: function(t2, e2) {\n var i2 = n2.get(t2);\n i2 ? i2.push(e2) : n2.set(t2, [e2]);\n }, off: function(t2, e2) {\n var i2 = n2.get(t2);\n i2 && (e2 ? i2.splice(i2.indexOf(e2) >>> 0, 1) : n2.set(t2, []));\n }, emit: function(t2, e2) {\n var i2 = n2.get(t2);\n i2 && i2.slice().map(function(n3) {\n n3(e2);\n }), (i2 = n2.get(\"*\")) && i2.slice().map(function(n3) {\n n3(t2, e2);\n });\n } };\n}\nconst mittProxy = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({\n __proto__: null,\n default: mitt$1\n}, Symbol.toStringTag, { value: \"Module\" }));\nfunction polyfill(w = window, d = document) {\n if (\"scrollBehavior\" in d.documentElement.style && w.__forceSmoothScrollPolyfill__ !== true) {\n return;\n }\n const Element2 = w.HTMLElement || w.Element;\n const SCROLL_TIME = 468;\n const original = {\n scroll: w.scroll || w.scrollTo,\n scrollBy: w.scrollBy,\n elementScroll: Element2.prototype.scroll || scrollElement,\n scrollIntoView: Element2.prototype.scrollIntoView\n };\n const now = w.performance && w.performance.now ? w.performance.now.bind(w.performance) : Date.now;\n function isMicrosoftBrowser(userAgent) {\n const userAgentPatterns = [\"MSIE \", \"Trident/\", \"Edge/\"];\n return new RegExp(userAgentPatterns.join(\"|\")).test(userAgent);\n }\n const ROUNDING_TOLERANCE = isMicrosoftBrowser(w.navigator.userAgent) ? 1 : 0;\n function scrollElement(x, y) {\n this.scrollLeft = x;\n this.scrollTop = y;\n }\n function ease(k) {\n return 0.5 * (1 - Math.cos(Math.PI * k));\n }\n function shouldBailOut(firstArg) {\n if (firstArg === null || typeof firstArg !== \"object\" || firstArg.behavior === void 0 || firstArg.behavior === \"auto\" || firstArg.behavior === \"instant\") {\n return true;\n }\n if (typeof firstArg === \"object\" && firstArg.behavior === \"smooth\") {\n return false;\n }\n throw new TypeError(\n \"behavior member of ScrollOptions \" + firstArg.behavior + \" is not a valid value for enumeration ScrollBehavior.\"\n );\n }\n function hasScrollableSpace(el, axis) {\n if (axis === \"Y\") {\n return el.clientHeight + ROUNDING_TOLERANCE < el.scrollHeight;\n }\n if (axis === \"X\") {\n return el.clientWidth + ROUNDING_TOLERANCE < el.scrollWidth;\n }\n }\n function canOverflow(el, axis) {\n const overflowValue = w.getComputedStyle(el, null)[\"overflow\" + axis];\n return overflowValue === \"auto\" || overflowValue === \"scroll\";\n }\n function isScrollable(el) {\n const isScrollableY = hasScrollableSpace(el, \"Y\") && canOverflow(el, \"Y\");\n const isScrollableX = hasScrollableSpace(el, \"X\") && canOverflow(el, \"X\");\n return isScrollableY || isScrollableX;\n }\n function findScrollableParent(el) {\n while (el !== d.body && isScrollable(el) === false) {\n el = el.parentNode || el.host;\n }\n return el;\n }\n function step(context) {\n const time = now();\n let value;\n let currentX;\n let currentY;\n let elapsed = (time - context.startTime) / SCROLL_TIME;\n elapsed = elapsed > 1 ? 1 : elapsed;\n value = ease(elapsed);\n currentX = context.startX + (context.x - context.startX) * value;\n currentY = context.startY + (context.y - context.startY) * value;\n context.method.call(context.scrollable, currentX, currentY);\n if (currentX !== context.x || currentY !== context.y) {\n w.requestAnimationFrame(step.bind(w, context));\n }\n }\n function smoothScroll(el, x, y) {\n let scrollable;\n let startX;\n let startY;\n let method;\n const startTime = now();\n if (el === d.body) {\n scrollable = w;\n startX = w.scrollX || w.pageXOffset;\n startY = w.scrollY || w.pageYOffset;\n method = original.scroll;\n } else {\n scrollable = el;\n startX = el.scrollLeft;\n startY = el.scrollTop;\n method = scrollElement;\n }\n step({\n scrollable,\n method,\n startTime,\n startX,\n startY,\n x,\n y\n });\n }\n w.scroll = w.scrollTo = function() {\n if (arguments[0] === void 0) {\n return;\n }\n if (shouldBailOut(arguments[0]) === true) {\n original.scroll.call(\n w,\n arguments[0].left !== void 0 ? arguments[0].left : typeof arguments[0] !== \"object\" ? arguments[0] : w.scrollX || w.pageXOffset,\n // use top prop, second argument if present or fallback to scrollY\n arguments[0].top !== void 0 ? arguments[0].top : arguments[1] !== void 0 ? arguments[1] : w.scrollY || w.pageYOffset\n );\n return;\n }\n smoothScroll.call(\n w,\n d.body,\n arguments[0].left !== void 0 ? ~~arguments[0].left : w.scrollX || w.pageXOffset,\n arguments[0].top !== void 0 ? ~~arguments[0].top : w.scrollY || w.pageYOffset\n );\n };\n w.scrollBy = function() {\n if (arguments[0] === void 0) {\n return;\n }\n if (shouldBailOut(arguments[0])) {\n original.scrollBy.call(\n w,\n arguments[0].left !== void 0 ? arguments[0].left : typeof arguments[0] !== \"object\" ? arguments[0] : 0,\n arguments[0].top !== void 0 ? arguments[0].top : arguments[1] !== void 0 ? arguments[1] : 0\n );\n return;\n }\n smoothScroll.call(\n w,\n d.body,\n ~~arguments[0].left + (w.scrollX || w.pageXOffset),\n ~~arguments[0].top + (w.scrollY || w.pageYOffset)\n );\n };\n Element2.prototype.scroll = Element2.prototype.scrollTo = function() {\n if (arguments[0] === void 0) {\n return;\n }\n if (shouldBailOut(arguments[0]) === true) {\n if (typeof arguments[0] === \"number\" && arguments[1] === void 0) {\n throw new SyntaxError(\"Value could not be converted\");\n }\n original.elementScroll.call(\n this,\n // use left prop, first number argument or fallback to scrollLeft\n arguments[0].left !== void 0 ? ~~arguments[0].left : typeof arguments[0] !== \"object\" ? ~~arguments[0] : this.scrollLeft,\n // use top prop, second argument or fallback to scrollTop\n arguments[0].top !== void 0 ? ~~arguments[0].top : arguments[1] !== void 0 ? ~~arguments[1] : this.scrollTop\n );\n return;\n }\n const left = arguments[0].left;\n const top = arguments[0].top;\n smoothScroll.call(\n this,\n this,\n typeof left === \"undefined\" ? this.scrollLeft : ~~left,\n typeof top === \"undefined\" ? this.scrollTop : ~~top\n );\n };\n Element2.prototype.scrollBy = function() {\n if (arguments[0] === void 0) {\n return;\n }\n if (shouldBailOut(arguments[0]) === true) {\n original.elementScroll.call(\n this,\n arguments[0].left !== void 0 ? ~~arguments[0].left + this.scrollLeft : ~~arguments[0] + this.scrollLeft,\n arguments[0].top !== void 0 ? ~~arguments[0].top + this.scrollTop : ~~arguments[1] + this.scrollTop\n );\n return;\n }\n this.scroll({\n left: ~~arguments[0].left + this.scrollLeft,\n top: ~~arguments[0].top + this.scrollTop,\n behavior: arguments[0].behavior\n });\n };\n Element2.prototype.scrollIntoView = function() {\n if (shouldBailOut(arguments[0]) === true) {\n original.scrollIntoView.call(\n this,\n arguments[0] === void 0 ? true : arguments[0]\n );\n return;\n }\n const scrollableParent = findScrollableParent(this);\n const parentRects = scrollableParent.getBoundingClientRect();\n const clientRects = this.getBoundingClientRect();\n if (scrollableParent !== d.body) {\n smoothScroll.call(\n this,\n scrollableParent,\n scrollableParent.scrollLeft + clientRects.left - parentRects.left,\n scrollableParent.scrollTop + clientRects.top - parentRects.top\n );\n if (w.getComputedStyle(scrollableParent).position !== \"fixed\") {\n w.scrollBy({\n left: parentRects.left,\n top: parentRects.top,\n behavior: \"smooth\"\n });\n }\n } else {\n w.scrollBy({\n left: clientRects.left,\n top: clientRects.top,\n behavior: \"smooth\"\n });\n }\n };\n}\nclass Timer {\n constructor(actions = [], config) {\n __publicField(this, \"timeOffset\", 0);\n __publicField(this, \"speed\");\n __publicField(this, \"actions\");\n __publicField(this, \"raf\", null);\n __publicField(this, \"lastTimestamp\");\n this.actions = actions;\n this.speed = config.speed;\n }\n /**\n * Add an action, possibly after the timer starts.\n */\n addAction(action) {\n const rafWasActive = this.raf === true;\n if (!this.actions.length || this.actions[this.actions.length - 1].delay <= action.delay) {\n this.actions.push(action);\n } else {\n const index = this.findActionIndex(action);\n this.actions.splice(index, 0, action);\n }\n if (rafWasActive) {\n this.raf = requestAnimationFrame(this.rafCheck.bind(this));\n }\n }\n start() {\n this.timeOffset = 0;\n this.lastTimestamp = performance.now();\n this.raf = requestAnimationFrame(this.rafCheck.bind(this));\n }\n rafCheck() {\n const time = performance.now();\n this.timeOffset += (time - this.lastTimestamp) * this.speed;\n this.lastTimestamp = time;\n while (this.actions.length) {\n const action = this.actions[0];\n if (this.timeOffset >= action.delay) {\n this.actions.shift();\n action.doAction();\n } else {\n break;\n }\n }\n if (this.actions.length > 0) {\n this.raf = requestAnimationFrame(this.rafCheck.bind(this));\n } else {\n this.raf = true;\n }\n }\n clear() {\n if (this.raf) {\n if (this.raf !== true) {\n cancelAnimationFrame(this.raf);\n }\n this.raf = null;\n }\n this.actions.length = 0;\n }\n setSpeed(speed) {\n this.speed = speed;\n }\n isActive() {\n return this.raf !== null;\n }\n findActionIndex(action) {\n let start = 0;\n let end = this.actions.length - 1;\n while (start <= end) {\n const mid = Math.floor((start + end) / 2);\n if (this.actions[mid].delay < action.delay) {\n start = mid + 1;\n } else if (this.actions[mid].delay > action.delay) {\n end = mid - 1;\n } else {\n return mid + 1;\n }\n }\n return start;\n }\n}\nfunction addDelay(event, baselineTime) {\n if (event.type === EventType.IncrementalSnapshot && event.data.source === IncrementalSource.MouseMove && event.data.positions && event.data.positions.length) {\n const firstOffset = event.data.positions[0].timeOffset;\n const firstTimestamp = event.timestamp + firstOffset;\n event.delay = firstTimestamp - baselineTime;\n return firstTimestamp - baselineTime;\n }\n event.delay = event.timestamp - baselineTime;\n return event.delay;\n}\n/*! *****************************************************************************\nCopyright (c) Microsoft Corporation.\n\nPermission to use, copy, modify, and/or distribute this software for any\npurpose with or without fee is hereby granted.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\nPERFORMANCE OF THIS SOFTWARE.\n***************************************************************************** */\nfunction t(t2, n2) {\n var e2 = \"function\" == typeof Symbol && t2[Symbol.iterator];\n if (!e2) return t2;\n var r2, o2, i2 = e2.call(t2), a2 = [];\n try {\n for (; (void 0 === n2 || n2-- > 0) && !(r2 = i2.next()).done; ) a2.push(r2.value);\n } catch (t3) {\n o2 = { error: t3 };\n } finally {\n try {\n r2 && !r2.done && (e2 = i2.return) && e2.call(i2);\n } finally {\n if (o2) throw o2.error;\n }\n }\n return a2;\n}\nvar n;\n!function(t2) {\n t2[t2.NotStarted = 0] = \"NotStarted\", t2[t2.Running = 1] = \"Running\", t2[t2.Stopped = 2] = \"Stopped\";\n}(n || (n = {}));\nvar e = { type: \"xstate.init\" };\nfunction r(t2) {\n return void 0 === t2 ? [] : [].concat(t2);\n}\nfunction o(t2) {\n return { type: \"xstate.assign\", assignment: t2 };\n}\nfunction i(t2, n2) {\n return \"string\" == typeof (t2 = \"string\" == typeof t2 && n2 && n2[t2] ? n2[t2] : t2) ? { type: t2 } : \"function\" == typeof t2 ? { type: t2.name, exec: t2 } : t2;\n}\nfunction a(t2) {\n return function(n2) {\n return t2 === n2;\n };\n}\nfunction u(t2) {\n return \"string\" == typeof t2 ? { type: t2 } : t2;\n}\nfunction c(t2, n2) {\n return { value: t2, context: n2, actions: [], changed: false, matches: a(t2) };\n}\nfunction f(t2, n2, e2) {\n var r2 = n2, o2 = false;\n return [t2.filter(function(t3) {\n if (\"xstate.assign\" === t3.type) {\n o2 = true;\n var n3 = Object.assign({}, r2);\n return \"function\" == typeof t3.assignment ? n3 = t3.assignment(r2, e2) : Object.keys(t3.assignment).forEach(function(o3) {\n n3[o3] = \"function\" == typeof t3.assignment[o3] ? t3.assignment[o3](r2, e2) : t3.assignment[o3];\n }), r2 = n3, false;\n }\n return true;\n }), r2, o2];\n}\nfunction s(n2, o2) {\n void 0 === o2 && (o2 = {});\n var s2 = t(f(r(n2.states[n2.initial].entry).map(function(t2) {\n return i(t2, o2.actions);\n }), n2.context, e), 2), l2 = s2[0], v2 = s2[1], y = { config: n2, _options: o2, initialState: { value: n2.initial, actions: l2, context: v2, matches: a(n2.initial) }, transition: function(e2, o3) {\n var s3, l3, v3 = \"string\" == typeof e2 ? { value: e2, context: n2.context } : e2, p = v3.value, g = v3.context, d = u(o3), x = n2.states[p];\n if (x.on) {\n var m = r(x.on[d.type]);\n try {\n for (var h = function(t2) {\n var n3 = \"function\" == typeof Symbol && Symbol.iterator, e3 = n3 && t2[n3], r2 = 0;\n if (e3) return e3.call(t2);\n if (t2 && \"number\" == typeof t2.length) return { next: function() {\n return t2 && r2 >= t2.length && (t2 = void 0), { value: t2 && t2[r2++], done: !t2 };\n } };\n throw new TypeError(n3 ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n }(m), b = h.next(); !b.done; b = h.next()) {\n var S = b.value;\n if (void 0 === S) return c(p, g);\n var w = \"string\" == typeof S ? { target: S } : S, j = w.target, E = w.actions, R = void 0 === E ? [] : E, N = w.cond, O = void 0 === N ? function() {\n return true;\n } : N, _ = void 0 === j, k = null != j ? j : p, T = n2.states[k];\n if (O(g, d)) {\n var q = t(f((_ ? r(R) : [].concat(x.exit, R, T.entry).filter(function(t2) {\n return t2;\n })).map(function(t2) {\n return i(t2, y._options.actions);\n }), g, d), 3), z = q[0], A = q[1], B = q[2], C = null != j ? j : p;\n return { value: C, context: A, actions: z, changed: j !== p || z.length > 0 || B, matches: a(C) };\n }\n }\n } catch (t2) {\n s3 = { error: t2 };\n } finally {\n try {\n b && !b.done && (l3 = h.return) && l3.call(h);\n } finally {\n if (s3) throw s3.error;\n }\n }\n }\n return c(p, g);\n } };\n return y;\n}\nvar l = function(t2, n2) {\n return t2.actions.forEach(function(e2) {\n var r2 = e2.exec;\n return r2 && r2(t2.context, n2);\n });\n};\nfunction v(t2) {\n var r2 = t2.initialState, o2 = n.NotStarted, i2 = /* @__PURE__ */ new Set(), c2 = { _machine: t2, send: function(e2) {\n o2 === n.Running && (r2 = t2.transition(r2, e2), l(r2, u(e2)), i2.forEach(function(t3) {\n return t3(r2);\n }));\n }, subscribe: function(t3) {\n return i2.add(t3), t3(r2), { unsubscribe: function() {\n return i2.delete(t3);\n } };\n }, start: function(i3) {\n if (i3) {\n var u2 = \"object\" == typeof i3 ? i3 : { context: t2.config.context, value: i3 };\n r2 = { value: u2.value, actions: [], context: u2.context, matches: a(u2.value) };\n }\n return o2 = n.Running, l(r2, e), c2;\n }, stop: function() {\n return o2 = n.Stopped, i2.clear(), c2;\n }, get state() {\n return r2;\n }, get status() {\n return o2;\n } };\n return c2;\n}\nfunction discardPriorSnapshots(events, baselineTime) {\n for (let idx = events.length - 1; idx >= 0; idx--) {\n const event = events[idx];\n if (event.type === EventType.Meta) {\n if (event.timestamp <= baselineTime) {\n return events.slice(idx);\n }\n }\n }\n return events;\n}\nfunction createPlayerService(context, { getCastFn, applyEventsSynchronously, emitter }) {\n const playerMachine = s(\n {\n id: \"player\",\n context,\n initial: \"paused\",\n states: {\n playing: {\n on: {\n PAUSE: {\n target: \"paused\",\n actions: [\"pause\"]\n },\n CAST_EVENT: {\n target: \"playing\",\n actions: \"castEvent\"\n },\n END: {\n target: \"paused\",\n actions: [\"resetLastPlayedEvent\", \"pause\"]\n },\n ADD_EVENT: {\n target: \"playing\",\n actions: [\"addEvent\"]\n }\n }\n },\n paused: {\n on: {\n PLAY: {\n target: \"playing\",\n actions: [\"recordTimeOffset\", \"play\"]\n },\n CAST_EVENT: {\n target: \"paused\",\n actions: \"castEvent\"\n },\n TO_LIVE: {\n target: \"live\",\n actions: [\"startLive\"]\n },\n ADD_EVENT: {\n target: \"paused\",\n actions: [\"addEvent\"]\n }\n }\n },\n live: {\n on: {\n ADD_EVENT: {\n target: \"live\",\n actions: [\"addEvent\"]\n },\n CAST_EVENT: {\n target: \"live\",\n actions: [\"castEvent\"]\n }\n }\n }\n }\n },\n {\n actions: {\n castEvent: o({\n lastPlayedEvent: (ctx, event) => {\n if (event.type === \"CAST_EVENT\") {\n return event.payload.event;\n }\n return ctx.lastPlayedEvent;\n }\n }),\n recordTimeOffset: o((ctx, event) => {\n let timeOffset = ctx.timeOffset;\n if (\"payload\" in event && \"timeOffset\" in event.payload) {\n timeOffset = event.payload.timeOffset;\n }\n return {\n ...ctx,\n timeOffset,\n baselineTime: ctx.events[0].timestamp + timeOffset\n };\n }),\n play(ctx) {\n var _a2;\n const { timer, events, baselineTime, lastPlayedEvent } = ctx;\n timer.clear();\n for (const event of events) {\n addDelay(event, baselineTime);\n }\n const neededEvents = discardPriorSnapshots(events, baselineTime);\n let lastPlayedTimestamp = lastPlayedEvent == null ? void 0 : lastPlayedEvent.timestamp;\n if ((lastPlayedEvent == null ? void 0 : lastPlayedEvent.type) === EventType.IncrementalSnapshot && lastPlayedEvent.data.source === IncrementalSource.MouseMove) {\n lastPlayedTimestamp = lastPlayedEvent.timestamp + ((_a2 = lastPlayedEvent.data.positions[0]) == null ? void 0 : _a2.timeOffset);\n }\n if (baselineTime < (lastPlayedTimestamp || 0)) {\n emitter.emit(ReplayerEvents.PlayBack);\n }\n const syncEvents = new Array();\n for (const event of neededEvents) {\n if (lastPlayedTimestamp && lastPlayedTimestamp < baselineTime && (event.timestamp <= lastPlayedTimestamp || event === lastPlayedEvent)) {\n continue;\n }\n if (event.timestamp < baselineTime) {\n syncEvents.push(event);\n } else {\n const castFn = getCastFn(event, false);\n timer.addAction({\n doAction: () => {\n castFn();\n },\n delay: event.delay\n });\n }\n }\n applyEventsSynchronously(syncEvents);\n emitter.emit(ReplayerEvents.Flush);\n timer.start();\n },\n pause(ctx) {\n ctx.timer.clear();\n },\n resetLastPlayedEvent: o((ctx) => {\n return {\n ...ctx,\n lastPlayedEvent: null\n };\n }),\n startLive: o({\n baselineTime: (ctx, event) => {\n ctx.timer.start();\n if (event.type === \"TO_LIVE\" && event.payload.baselineTime) {\n return event.payload.baselineTime;\n }\n return Date.now();\n }\n }),\n addEvent: o((ctx, machineEvent) => {\n const { baselineTime, timer, events } = ctx;\n if (machineEvent.type === \"ADD_EVENT\") {\n const { event } = machineEvent.payload;\n addDelay(event, baselineTime);\n let end = events.length - 1;\n if (!events[end] || events[end].timestamp <= event.timestamp) {\n events.push(event);\n } else {\n let insertionIndex = -1;\n let start = 0;\n while (start <= end) {\n const mid = Math.floor((start + end) / 2);\n if (events[mid].timestamp <= event.timestamp) {\n start = mid + 1;\n } else {\n end = mid - 1;\n }\n }\n if (insertionIndex === -1) {\n insertionIndex = start;\n }\n events.splice(insertionIndex, 0, event);\n }\n const isSync = event.timestamp < baselineTime;\n const castFn = getCastFn(event, isSync);\n if (isSync) {\n castFn();\n } else if (timer.isActive()) {\n timer.addAction({\n doAction: () => {\n castFn();\n },\n delay: event.delay\n });\n }\n }\n return { ...ctx, events };\n })\n }\n }\n );\n return v(playerMachine);\n}\nfunction createSpeedService(context) {\n const speedMachine = s(\n {\n id: \"speed\",\n context,\n initial: \"normal\",\n states: {\n normal: {\n on: {\n FAST_FORWARD: {\n target: \"skipping\",\n actions: [\"recordSpeed\", \"setSpeed\"]\n },\n SET_SPEED: {\n target: \"normal\",\n actions: [\"setSpeed\"]\n }\n }\n },\n skipping: {\n on: {\n BACK_TO_NORMAL: {\n target: \"normal\",\n actions: [\"restoreSpeed\"]\n },\n SET_SPEED: {\n target: \"normal\",\n actions: [\"setSpeed\"]\n }\n }\n }\n }\n },\n {\n actions: {\n setSpeed: (ctx, event) => {\n if (\"payload\" in event) {\n ctx.timer.setSpeed(event.payload.speed);\n }\n },\n recordSpeed: o({\n normalSpeed: (ctx) => ctx.timer.speed\n }),\n restoreSpeed: (ctx) => {\n ctx.timer.setSpeed(ctx.normalSpeed);\n }\n }\n }\n );\n return v(speedMachine);\n}\nconst rules = (blockClass) => [\n `.${blockClass} { background: currentColor }`,\n \"noscript { display: none !important; }\"\n];\nconst webGLVarMap = /* @__PURE__ */ new Map();\nfunction variableListFor(ctx, ctor) {\n let contextMap = webGLVarMap.get(ctx);\n if (!contextMap) {\n contextMap = /* @__PURE__ */ new Map();\n webGLVarMap.set(ctx, contextMap);\n }\n if (!contextMap.has(ctor)) {\n contextMap.set(ctor, []);\n }\n return contextMap.get(ctor);\n}\nfunction deserializeArg(imageMap, ctx, preload) {\n return async (arg) => {\n if (arg && typeof arg === \"object\" && \"rr_type\" in arg) {\n if (preload) preload.isUnchanged = false;\n if (arg.rr_type === \"ImageBitmap\" && \"args\" in arg) {\n const args = await deserializeArg(imageMap, ctx, preload)(arg.args);\n return await createImageBitmap.apply(null, args);\n } else if (\"index\" in arg) {\n if (preload || ctx === null) return arg;\n const { rr_type: name, index } = arg;\n return variableListFor(ctx, name)[index];\n } else if (\"args\" in arg) {\n const { rr_type: name, args } = arg;\n const ctor = window[name];\n return new ctor(\n ...await Promise.all(\n args.map(deserializeArg(imageMap, ctx, preload))\n )\n );\n } else if (\"base64\" in arg) {\n return decode(arg.base64);\n } else if (\"src\" in arg) {\n const image = imageMap.get(arg.src);\n if (image) {\n return image;\n } else {\n const image2 = new Image();\n image2.src = arg.src;\n imageMap.set(arg.src, image2);\n return image2;\n }\n } else if (\"data\" in arg && arg.rr_type === \"Blob\") {\n const blobContents = await Promise.all(\n arg.data.map(deserializeArg(imageMap, ctx, preload))\n );\n const blob2 = new Blob(blobContents, {\n type: arg.type\n });\n return blob2;\n }\n } else if (Array.isArray(arg)) {\n const result = await Promise.all(\n arg.map(deserializeArg(imageMap, ctx, preload))\n );\n return result;\n }\n return arg;\n };\n}\nfunction getContext(target, type) {\n try {\n if (type === CanvasContext.WebGL) {\n return target.getContext(\"webgl\") || target.getContext(\"experimental-webgl\");\n }\n return target.getContext(\"webgl2\");\n } catch (e2) {\n return null;\n }\n}\nconst WebGLVariableConstructorsNames = [\n \"WebGLActiveInfo\",\n \"WebGLBuffer\",\n \"WebGLFramebuffer\",\n \"WebGLProgram\",\n \"WebGLRenderbuffer\",\n \"WebGLShader\",\n \"WebGLShaderPrecisionFormat\",\n \"WebGLTexture\",\n \"WebGLUniformLocation\",\n \"WebGLVertexArrayObject\"\n];\nfunction saveToWebGLVarMap(ctx, result) {\n if (!(result == null ? void 0 : result.constructor)) return;\n const { name } = result.constructor;\n if (!WebGLVariableConstructorsNames.includes(name)) return;\n const variables = variableListFor(ctx, name);\n if (!variables.includes(result)) variables.push(result);\n}\nasync function webglMutation({\n mutation,\n target,\n type,\n imageMap,\n errorHandler: errorHandler2\n}) {\n try {\n const ctx = getContext(target, type);\n if (!ctx) return;\n if (mutation.setter) {\n ctx[mutation.property] = mutation.args[0];\n return;\n }\n const original = ctx[mutation.property];\n const args = await Promise.all(\n mutation.args.map(deserializeArg(imageMap, ctx))\n );\n const result = original.apply(ctx, args);\n saveToWebGLVarMap(ctx, result);\n const debugMode = false;\n if (debugMode) ;\n } catch (error) {\n errorHandler2(mutation, error);\n }\n}\nasync function canvasMutation$1({\n event,\n mutations,\n target,\n imageMap,\n errorHandler: errorHandler2\n}) {\n const ctx = target.getContext(\"2d\");\n if (!ctx) {\n errorHandler2(mutations[0], new Error(\"Canvas context is null\"));\n return;\n }\n const mutationArgsPromises = mutations.map(\n async (mutation) => {\n return Promise.all(mutation.args.map(deserializeArg(imageMap, ctx)));\n }\n );\n const args = await Promise.all(mutationArgsPromises);\n args.forEach((args2, index) => {\n const mutation = mutations[index];\n try {\n if (mutation.setter) {\n ctx[mutation.property] = mutation.args[0];\n return;\n }\n const original = ctx[mutation.property];\n if (mutation.property === \"drawImage\" && typeof mutation.args[0] === \"string\") {\n imageMap.get(event);\n original.apply(ctx, mutation.args);\n } else {\n original.apply(ctx, args2);\n }\n } catch (error) {\n errorHandler2(mutation, error);\n }\n return;\n });\n}\nasync function canvasMutation({\n event,\n mutation,\n target,\n imageMap,\n canvasEventMap,\n errorHandler: errorHandler2\n}) {\n try {\n const precomputedMutation = canvasEventMap.get(event) || mutation;\n const commands = \"commands\" in precomputedMutation ? precomputedMutation.commands : [precomputedMutation];\n if ([CanvasContext.WebGL, CanvasContext.WebGL2].includes(mutation.type)) {\n for (let i2 = 0; i2 < commands.length; i2++) {\n const command = commands[i2];\n await webglMutation({\n mutation: command,\n type: mutation.type,\n target,\n imageMap,\n errorHandler: errorHandler2\n });\n }\n return;\n }\n await canvasMutation$1({\n event,\n mutations: commands,\n target,\n imageMap,\n errorHandler: errorHandler2\n });\n } catch (error) {\n errorHandler2(mutation, error);\n }\n}\nclass MediaManager {\n constructor(options) {\n __publicField(this, \"mediaMap\", /* @__PURE__ */ new Map());\n __publicField(this, \"warn\");\n __publicField(this, \"service\");\n __publicField(this, \"speedService\");\n __publicField(this, \"emitter\");\n __publicField(this, \"getCurrentTime\");\n __publicField(this, \"metadataCallbackMap\", /* @__PURE__ */ new Map());\n this.warn = options.warn;\n this.service = options.service;\n this.speedService = options.speedService;\n this.emitter = options.emitter;\n this.getCurrentTime = options.getCurrentTime;\n this.emitter.on(ReplayerEvents.Start, this.start.bind(this));\n this.emitter.on(ReplayerEvents.SkipStart, this.start.bind(this));\n this.emitter.on(ReplayerEvents.Pause, this.pause.bind(this));\n this.emitter.on(ReplayerEvents.Finish, this.pause.bind(this));\n this.speedService.subscribe(() => {\n this.syncAllMediaElements();\n });\n }\n syncAllMediaElements(options = { pause: false }) {\n this.mediaMap.forEach((_mediaState, target) => {\n this.syncTargetWithState(target);\n if (options.pause) {\n target.pause();\n }\n });\n }\n start() {\n this.syncAllMediaElements();\n }\n pause() {\n this.syncAllMediaElements({ pause: true });\n }\n seekTo({\n time,\n target,\n mediaState\n }) {\n if (mediaState.isPlaying) {\n const differenceBetweenCurrentTimeAndMediaMutationTimestamp = time - mediaState.lastInteractionTimeOffset;\n const mediaPlaybackOffset = differenceBetweenCurrentTimeAndMediaMutationTimestamp / 1e3 * mediaState.playbackRate;\n const duration = \"duration\" in target && target.duration;\n if (Number.isNaN(duration)) {\n this.waitForMetadata(target);\n return;\n }\n let seekToTime = mediaState.currentTimeAtLastInteraction + mediaPlaybackOffset;\n if (target.loop && // RRMediaElement doesn't have a duration property\n duration !== false) {\n seekToTime = seekToTime % duration;\n }\n target.currentTime = seekToTime;\n } else {\n target.pause();\n target.currentTime = mediaState.currentTimeAtLastInteraction;\n }\n }\n waitForMetadata(target) {\n if (this.metadataCallbackMap.has(target)) return;\n if (!(\"addEventListener\" in target)) return;\n const onLoadedMetadata = () => {\n this.metadataCallbackMap.delete(target);\n const mediaState = this.mediaMap.get(target);\n if (!mediaState) return;\n this.seekTo({\n time: this.getCurrentTime(),\n target,\n mediaState\n });\n };\n this.metadataCallbackMap.set(target, onLoadedMetadata);\n target.addEventListener(\"loadedmetadata\", onLoadedMetadata, {\n once: true\n });\n }\n getMediaStateFromMutation({\n target,\n timeOffset,\n mutation\n }) {\n const lastState = this.mediaMap.get(target);\n const { type, playbackRate, currentTime, muted, volume, loop } = mutation;\n const isPlaying = type === MediaInteractions.Play || type !== MediaInteractions.Pause && ((lastState == null ? void 0 : lastState.isPlaying) || target.getAttribute(\"autoplay\") !== null);\n const mediaState = {\n isPlaying,\n currentTimeAtLastInteraction: currentTime ?? (lastState == null ? void 0 : lastState.currentTimeAtLastInteraction) ?? 0,\n lastInteractionTimeOffset: timeOffset,\n playbackRate: playbackRate ?? (lastState == null ? void 0 : lastState.playbackRate) ?? 1,\n volume: volume ?? (lastState == null ? void 0 : lastState.volume) ?? 1,\n muted: muted ?? (lastState == null ? void 0 : lastState.muted) ?? target.getAttribute(\"muted\") === null,\n loop: loop ?? (lastState == null ? void 0 : lastState.loop) ?? target.getAttribute(\"loop\") === null\n };\n return mediaState;\n }\n syncTargetWithState(target) {\n const mediaState = this.mediaMap.get(target);\n if (!mediaState) return;\n const { muted, loop, volume, isPlaying } = mediaState;\n const playerIsPaused = this.service.state.matches(\"paused\");\n const playbackRate = mediaState.playbackRate * this.speedService.state.context.timer.speed;\n try {\n this.seekTo({\n time: this.getCurrentTime(),\n target,\n mediaState\n });\n if (target.volume !== volume) {\n target.volume = volume;\n }\n target.muted = muted;\n target.loop = loop;\n if (target.playbackRate !== playbackRate) {\n target.playbackRate = playbackRate;\n }\n if (isPlaying && !playerIsPaused) {\n void target.play();\n } else {\n target.pause();\n }\n } catch (error) {\n this.warn(\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, @typescript-eslint/restrict-template-expressions\n `Failed to replay media interactions: ${error.message || error}`\n );\n }\n }\n addMediaElements(node, timeOffset, mirror2) {\n if (![\"AUDIO\", \"VIDEO\"].includes(node.nodeName)) return;\n const target = node;\n const serializedNode = mirror2.getMeta(target);\n if (!serializedNode || !(\"attributes\" in serializedNode)) return;\n const playerIsPaused = this.service.state.matches(\"paused\");\n const mediaAttributes = serializedNode.attributes;\n let isPlaying = false;\n if (mediaAttributes.rr_mediaState) {\n isPlaying = mediaAttributes.rr_mediaState === \"played\";\n } else {\n isPlaying = target.getAttribute(\"autoplay\") !== null;\n }\n if (isPlaying && playerIsPaused) target.pause();\n let playbackRate = 1;\n if (typeof mediaAttributes.rr_mediaPlaybackRate === \"number\") {\n playbackRate = mediaAttributes.rr_mediaPlaybackRate;\n }\n let muted = false;\n if (typeof mediaAttributes.rr_mediaMuted === \"boolean\") {\n muted = mediaAttributes.rr_mediaMuted;\n } else {\n muted = target.getAttribute(\"muted\") !== null;\n }\n let loop = false;\n if (typeof mediaAttributes.rr_mediaLoop === \"boolean\") {\n loop = mediaAttributes.rr_mediaLoop;\n } else {\n loop = target.getAttribute(\"loop\") !== null;\n }\n let volume = 1;\n if (typeof mediaAttributes.rr_mediaVolume === \"number\") {\n volume = mediaAttributes.rr_mediaVolume;\n }\n let currentTimeAtLastInteraction = 0;\n if (typeof mediaAttributes.rr_mediaCurrentTime === \"number\") {\n currentTimeAtLastInteraction = mediaAttributes.rr_mediaCurrentTime;\n }\n this.mediaMap.set(target, {\n isPlaying,\n currentTimeAtLastInteraction,\n lastInteractionTimeOffset: timeOffset,\n playbackRate,\n volume,\n muted,\n loop\n });\n this.syncTargetWithState(target);\n }\n mediaMutation({\n target,\n timeOffset,\n mutation\n }) {\n this.mediaMap.set(\n target,\n this.getMediaStateFromMutation({\n target,\n timeOffset,\n mutation\n })\n );\n this.syncTargetWithState(target);\n }\n isSupportedMediaElement(node) {\n return [\"AUDIO\", \"VIDEO\"].includes(node.nodeName);\n }\n reset() {\n this.mediaMap.clear();\n }\n}\nconst SKIP_TIME_INTERVAL = 5 * 1e3;\nconst mitt = mitt$1 || mittProxy;\nconst REPLAY_CONSOLE_PREFIX = \"[replayer]\";\nconst defaultMouseTailConfig = {\n duration: 500,\n lineCap: \"round\",\n lineWidth: 3,\n strokeStyle: \"red\"\n};\nfunction indicatesTouchDevice(e2) {\n return e2.type == EventType.IncrementalSnapshot && (e2.data.source == IncrementalSource.TouchMove || e2.data.source == IncrementalSource.MouseInteraction && e2.data.type == MouseInteractions.TouchStart);\n}\nclass Replayer {\n constructor(events, config) {\n __publicField(this, \"wrapper\");\n __publicField(this, \"iframe\");\n __publicField(this, \"service\");\n __publicField(this, \"speedService\");\n __publicField(this, \"config\");\n // In the fast-forward process, if the virtual-dom optimization is used, this flag value is true.\n __publicField(this, \"usingVirtualDom\", false);\n __publicField(this, \"virtualDom\", new RRDocument());\n __publicField(this, \"mouse\");\n __publicField(this, \"mouseTail\", null);\n __publicField(this, \"tailPositions\", []);\n __publicField(this, \"emitter\", mitt());\n __publicField(this, \"nextUserInteractionEvent\");\n __publicField(this, \"legacy_missingNodeRetryMap\", {});\n // The replayer uses the cache to speed up replay and scrubbing.\n __publicField(this, \"cache\", createCache());\n __publicField(this, \"imageMap\", /* @__PURE__ */ new Map());\n __publicField(this, \"canvasEventMap\", /* @__PURE__ */ new Map());\n __publicField(this, \"mirror\", createMirror$2());\n // Used to track StyleSheetObjects adopted on multiple document hosts.\n __publicField(this, \"styleMirror\", new StyleSheetMirror());\n // Used to track video & audio elements, and keep them in sync with general playback.\n __publicField(this, \"mediaManager\");\n __publicField(this, \"firstFullSnapshot\", null);\n __publicField(this, \"newDocumentQueue\", []);\n __publicField(this, \"mousePos\", null);\n __publicField(this, \"touchActive\", null);\n __publicField(this, \"lastMouseDownEvent\", null);\n // Keep the rootNode of the last hovered element. So when hovering a new element, we can remove the last hovered element's :hover style.\n __publicField(this, \"lastHoveredRootNode\");\n // In the fast-forward mode, only the last selection data needs to be applied.\n __publicField(this, \"lastSelectionData\", null);\n // In the fast-forward mode using VirtualDom optimization, all stylesheetRule, and styleDeclaration events on constructed StyleSheets will be delayed to get applied until the flush stage.\n __publicField(this, \"constructedStyleMutations\", []);\n // Similar to the reason for constructedStyleMutations.\n __publicField(this, \"adoptedStyleSheets\", []);\n __publicField(this, \"handleResize\", (dimension) => {\n this.iframe.style.display = \"inherit\";\n for (const el of [this.mouseTail, this.iframe]) {\n if (!el) {\n continue;\n }\n el.setAttribute(\"width\", String(dimension.width));\n el.setAttribute(\"height\", String(dimension.height));\n }\n });\n __publicField(this, \"applyEventsSynchronously\", (events) => {\n for (const event of events) {\n switch (event.type) {\n case EventType.DomContentLoaded:\n case EventType.Load:\n case EventType.Custom:\n continue;\n case EventType.FullSnapshot:\n case EventType.Meta:\n case EventType.Plugin:\n case EventType.IncrementalSnapshot:\n break;\n }\n const castFn = this.getCastFn(event, true);\n castFn();\n }\n });\n __publicField(this, \"getCastFn\", (event, isSync = false) => {\n let castFn;\n switch (event.type) {\n case EventType.DomContentLoaded:\n case EventType.Load:\n break;\n case EventType.Custom:\n castFn = () => {\n this.emitter.emit(ReplayerEvents.CustomEvent, event);\n };\n break;\n case EventType.Meta:\n castFn = () => this.emitter.emit(ReplayerEvents.Resize, {\n width: event.data.width,\n height: event.data.height\n });\n break;\n case EventType.FullSnapshot:\n castFn = () => {\n var _a2;\n if (this.firstFullSnapshot) {\n if (this.firstFullSnapshot === event) {\n this.firstFullSnapshot = true;\n return;\n }\n } else {\n this.firstFullSnapshot = true;\n }\n this.mediaManager.reset();\n this.styleMirror.reset();\n this.rebuildFullSnapshot(event, isSync);\n (_a2 = this.iframe.contentWindow) == null ? void 0 : _a2.scrollTo(event.data.initialOffset);\n };\n break;\n case EventType.IncrementalSnapshot:\n castFn = () => {\n this.applyIncremental(event, isSync);\n if (isSync) {\n return;\n }\n if (event === this.nextUserInteractionEvent) {\n this.nextUserInteractionEvent = null;\n this.backToNormal();\n }\n if (this.config.skipInactive && !this.nextUserInteractionEvent) {\n for (const _event of this.service.state.context.events) {\n if (_event.timestamp <= event.timestamp) {\n continue;\n }\n if (this.isUserInteraction(_event)) {\n if (\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n _event.delay - event.delay > this.config.inactivePeriodThreshold * this.speedService.state.context.timer.speed\n ) {\n this.nextUserInteractionEvent = _event;\n }\n break;\n }\n }\n if (this.nextUserInteractionEvent) {\n const skipTime = (\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n this.nextUserInteractionEvent.delay - event.delay\n );\n const payload = {\n speed: Math.min(\n Math.round(skipTime / SKIP_TIME_INTERVAL),\n this.config.maxSpeed\n )\n };\n this.speedService.send({ type: \"FAST_FORWARD\", payload });\n this.emitter.emit(ReplayerEvents.SkipStart, payload);\n }\n }\n };\n break;\n }\n const wrappedCastFn = () => {\n if (castFn) {\n castFn();\n }\n for (const plugin of this.config.plugins || []) {\n if (plugin.handler) plugin.handler(event, isSync, { replayer: this });\n }\n this.service.send({ type: \"CAST_EVENT\", payload: { event } });\n const last_index = this.service.state.context.events.length - 1;\n if (!this.config.liveMode && event === this.service.state.context.events[last_index]) {\n const finish = () => {\n if (last_index < this.service.state.context.events.length - 1) {\n return;\n }\n this.backToNormal();\n this.service.send(\"END\");\n this.emitter.emit(ReplayerEvents.Finish);\n };\n let finish_buffer = 50;\n if (event.type === EventType.IncrementalSnapshot && event.data.source === IncrementalSource.MouseMove && event.data.positions.length) {\n finish_buffer += Math.max(0, -event.data.positions[0].timeOffset);\n }\n setTimeout(finish, finish_buffer);\n }\n this.emitter.emit(ReplayerEvents.EventCast, event);\n };\n return wrappedCastFn;\n });\n if (!(config == null ? void 0 : config.liveMode) && events.length < 2) {\n throw new Error(\"Replayer need at least 2 events.\");\n }\n const defaultConfig = {\n speed: 1,\n maxSpeed: 360,\n root: document.body,\n loadTimeout: 0,\n skipInactive: false,\n inactivePeriodThreshold: 10 * 1e3,\n showWarning: true,\n showDebug: false,\n blockClass: \"rr-block\",\n liveMode: false,\n insertStyleRules: [],\n triggerFocus: true,\n UNSAFE_replayCanvas: false,\n pauseAnimation: true,\n mouseTail: defaultMouseTailConfig,\n useVirtualDom: true,\n // Virtual-dom optimization is enabled by default.\n logger: console\n };\n this.config = Object.assign({}, defaultConfig, config);\n this.handleResize = this.handleResize.bind(this);\n this.getCastFn = this.getCastFn.bind(this);\n this.applyEventsSynchronously = this.applyEventsSynchronously.bind(this);\n this.emitter.on(ReplayerEvents.Resize, this.handleResize);\n this.setupDom();\n for (const plugin of this.config.plugins || []) {\n if (plugin.getMirror) plugin.getMirror({ nodeMirror: this.mirror });\n }\n this.emitter.on(ReplayerEvents.Flush, () => {\n if (this.usingVirtualDom) {\n const replayerHandler = {\n mirror: this.mirror,\n applyCanvas: (canvasEvent, canvasMutationData, target) => {\n void canvasMutation({\n event: canvasEvent,\n mutation: canvasMutationData,\n target,\n imageMap: this.imageMap,\n canvasEventMap: this.canvasEventMap,\n errorHandler: this.warnCanvasMutationFailed.bind(this)\n });\n },\n applyInput: this.applyInput.bind(this),\n applyScroll: this.applyScroll.bind(this),\n applyStyleSheetMutation: (data, styleSheet) => {\n if (data.source === IncrementalSource.StyleSheetRule)\n this.applyStyleSheetRule(data, styleSheet);\n else if (data.source === IncrementalSource.StyleDeclaration)\n this.applyStyleDeclaration(data, styleSheet);\n },\n afterAppend: (node, id) => {\n for (const plugin of this.config.plugins || []) {\n if (plugin.onBuild) plugin.onBuild(node, { id, replayer: this });\n }\n }\n };\n if (this.iframe.contentDocument)\n try {\n diff(\n this.iframe.contentDocument,\n this.virtualDom,\n replayerHandler,\n this.virtualDom.mirror\n );\n } catch (e2) {\n console.warn(e2);\n }\n this.virtualDom.destroyTree();\n this.usingVirtualDom = false;\n if (Object.keys(this.legacy_missingNodeRetryMap).length) {\n for (const key in this.legacy_missingNodeRetryMap) {\n try {\n const value = this.legacy_missingNodeRetryMap[key];\n const realNode = createOrGetNode(\n value.node,\n this.mirror,\n this.virtualDom.mirror\n );\n diff(\n realNode,\n value.node,\n replayerHandler,\n this.virtualDom.mirror\n );\n value.node = realNode;\n } catch (error) {\n this.warn(error);\n }\n }\n }\n this.constructedStyleMutations.forEach((data) => {\n this.applyStyleSheetMutation(data);\n });\n this.constructedStyleMutations = [];\n this.adoptedStyleSheets.forEach((data) => {\n this.applyAdoptedStyleSheet(data);\n });\n this.adoptedStyleSheets = [];\n }\n if (this.mousePos) {\n this.moveAndHover(\n this.mousePos.x,\n this.mousePos.y,\n this.mousePos.id,\n true,\n this.mousePos.debugData\n );\n this.mousePos = null;\n }\n if (this.touchActive === true) {\n this.mouse.classList.add(\"touch-active\");\n } else if (this.touchActive === false) {\n this.mouse.classList.remove(\"touch-active\");\n }\n this.touchActive = null;\n if (this.lastMouseDownEvent) {\n const [target, event] = this.lastMouseDownEvent;\n target.dispatchEvent(event);\n }\n this.lastMouseDownEvent = null;\n if (this.lastSelectionData) {\n this.applySelection(this.lastSelectionData);\n this.lastSelectionData = null;\n }\n });\n this.emitter.on(ReplayerEvents.PlayBack, () => {\n this.firstFullSnapshot = null;\n this.mirror.reset();\n this.styleMirror.reset();\n this.mediaManager.reset();\n });\n const timer = new Timer([], {\n speed: this.config.speed\n });\n this.service = createPlayerService(\n {\n events: events.map((e2) => {\n if (config && config.unpackFn) {\n return config.unpackFn(e2);\n }\n return e2;\n }).sort((a1, a2) => a1.timestamp - a2.timestamp),\n timer,\n timeOffset: 0,\n baselineTime: 0,\n lastPlayedEvent: null\n },\n {\n getCastFn: this.getCastFn,\n applyEventsSynchronously: this.applyEventsSynchronously,\n emitter: this.emitter\n }\n );\n this.service.start();\n this.service.subscribe((state) => {\n this.emitter.emit(ReplayerEvents.StateChange, {\n player: state\n });\n });\n this.speedService = createSpeedService({\n normalSpeed: -1,\n timer\n });\n this.speedService.start();\n this.speedService.subscribe((state) => {\n this.emitter.emit(ReplayerEvents.StateChange, {\n speed: state\n });\n });\n this.mediaManager = new MediaManager({\n warn: this.warn.bind(this),\n service: this.service,\n speedService: this.speedService,\n emitter: this.emitter,\n getCurrentTime: this.getCurrentTime.bind(this)\n });\n const firstMeta = this.service.state.context.events.find(\n (e2) => e2.type === EventType.Meta\n );\n const firstFullsnapshot = this.service.state.context.events.find(\n (e2) => e2.type === EventType.FullSnapshot\n );\n if (firstMeta) {\n const { width, height } = firstMeta.data;\n setTimeout(() => {\n this.emitter.emit(ReplayerEvents.Resize, {\n width,\n height\n });\n }, 0);\n }\n if (firstFullsnapshot) {\n setTimeout(() => {\n var _a2;\n if (this.firstFullSnapshot) {\n return;\n }\n this.firstFullSnapshot = firstFullsnapshot;\n this.rebuildFullSnapshot(\n firstFullsnapshot\n );\n (_a2 = this.iframe.contentWindow) == null ? void 0 : _a2.scrollTo(\n firstFullsnapshot.data.initialOffset\n );\n }, 1);\n }\n if (this.service.state.context.events.find(indicatesTouchDevice)) {\n this.mouse.classList.add(\"touch-device\");\n }\n }\n get timer() {\n return this.service.state.context.timer;\n }\n on(event, handler) {\n this.emitter.on(event, handler);\n return this;\n }\n off(event, handler) {\n this.emitter.off(event, handler);\n return this;\n }\n setConfig(config) {\n Object.keys(config).forEach((key) => {\n config[key];\n this.config[key] = config[key];\n });\n if (!this.config.skipInactive) {\n this.backToNormal();\n }\n if (typeof config.speed !== \"undefined\") {\n this.speedService.send({\n type: \"SET_SPEED\",\n payload: {\n speed: config.speed\n }\n });\n }\n if (typeof config.mouseTail !== \"undefined\") {\n if (config.mouseTail === false) {\n if (this.mouseTail) {\n this.mouseTail.style.display = \"none\";\n }\n } else {\n if (!this.mouseTail) {\n this.mouseTail = document.createElement(\"canvas\");\n this.mouseTail.width = Number.parseFloat(this.iframe.width);\n this.mouseTail.height = Number.parseFloat(this.iframe.height);\n this.mouseTail.classList.add(\"replayer-mouse-tail\");\n this.wrapper.insertBefore(this.mouseTail, this.iframe);\n }\n this.mouseTail.style.display = \"inherit\";\n }\n }\n }\n getMetaData() {\n const firstEvent = this.service.state.context.events[0];\n const lastEvent = this.service.state.context.events[this.service.state.context.events.length - 1];\n return {\n startTime: firstEvent.timestamp,\n endTime: lastEvent.timestamp,\n totalTime: lastEvent.timestamp - firstEvent.timestamp\n };\n }\n /**\n * Get the actual time offset the player is at now compared to the first event.\n */\n getCurrentTime() {\n return this.timer.timeOffset + this.getTimeOffset();\n }\n /**\n * Get the time offset the player is at now compared to the first event, but without regard for the timer.\n */\n getTimeOffset() {\n const { baselineTime, events } = this.service.state.context;\n return baselineTime - events[0].timestamp;\n }\n getMirror() {\n return this.mirror;\n }\n /**\n * This API was designed to be used as play at any time offset.\n * Since we minimized the data collected from recorder, we do not\n * have the ability of undo an event.\n * So the implementation of play at any time offset will always iterate\n * all of the events, cast event before the offset synchronously\n * and cast event after the offset asynchronously with timer.\n * @param timeOffset - number\n */\n play(timeOffset = 0) {\n var _a2, _b;\n if (this.service.state.matches(\"paused\")) {\n this.service.send({ type: \"PLAY\", payload: { timeOffset } });\n } else {\n this.service.send({ type: \"PAUSE\" });\n this.service.send({ type: \"PLAY\", payload: { timeOffset } });\n }\n (_b = (_a2 = this.iframe.contentDocument) == null ? void 0 : _a2.getElementsByTagName(\"html\")[0]) == null ? void 0 : _b.classList.remove(\"rrweb-paused\");\n this.emitter.emit(ReplayerEvents.Start);\n }\n pause(timeOffset) {\n var _a2, _b;\n if (timeOffset === void 0 && this.service.state.matches(\"playing\")) {\n this.service.send({ type: \"PAUSE\" });\n }\n if (typeof timeOffset === \"number\") {\n this.play(timeOffset);\n this.service.send({ type: \"PAUSE\" });\n }\n (_b = (_a2 = this.iframe.contentDocument) == null ? void 0 : _a2.getElementsByTagName(\"html\")[0]) == null ? void 0 : _b.classList.add(\"rrweb-paused\");\n this.emitter.emit(ReplayerEvents.Pause);\n }\n resume(timeOffset = 0) {\n this.warn(\n `The 'resume' was deprecated in 1.0. Please use 'play' method which has the same interface.`\n );\n this.play(timeOffset);\n this.emitter.emit(ReplayerEvents.Resume);\n }\n /**\n * Totally destroy this replayer and please be careful that this operation is irreversible.\n * Memory occupation can be released by removing all references to this replayer.\n */\n destroy() {\n this.pause();\n this.mirror.reset();\n this.styleMirror.reset();\n this.mediaManager.reset();\n this.config.root.removeChild(this.wrapper);\n this.emitter.emit(ReplayerEvents.Destroy);\n }\n startLive(baselineTime) {\n this.service.send({ type: \"TO_LIVE\", payload: { baselineTime } });\n }\n addEvent(rawEvent) {\n const event = this.config.unpackFn ? this.config.unpackFn(rawEvent) : rawEvent;\n if (indicatesTouchDevice(event)) {\n this.mouse.classList.add(\"touch-device\");\n }\n void Promise.resolve().then(\n () => this.service.send({ type: \"ADD_EVENT\", payload: { event } })\n );\n }\n enableInteract() {\n this.iframe.setAttribute(\"scrolling\", \"auto\");\n this.iframe.style.pointerEvents = \"auto\";\n }\n disableInteract() {\n this.iframe.setAttribute(\"scrolling\", \"no\");\n this.iframe.style.pointerEvents = \"none\";\n }\n /**\n * Empties the replayer's cache and reclaims memory.\n * The replayer will use this cache to speed up the playback.\n */\n resetCache() {\n this.cache = createCache();\n }\n setupDom() {\n this.wrapper = document.createElement(\"div\");\n this.wrapper.classList.add(\"replayer-wrapper\");\n this.config.root.appendChild(this.wrapper);\n this.mouse = document.createElement(\"div\");\n this.mouse.classList.add(\"replayer-mouse\");\n this.wrapper.appendChild(this.mouse);\n if (this.config.mouseTail !== false) {\n this.mouseTail = document.createElement(\"canvas\");\n this.mouseTail.classList.add(\"replayer-mouse-tail\");\n this.mouseTail.style.display = \"inherit\";\n this.wrapper.appendChild(this.mouseTail);\n }\n this.iframe = document.createElement(\"iframe\");\n const attributes = [\"allow-same-origin\"];\n if (this.config.UNSAFE_replayCanvas) {\n attributes.push(\"allow-scripts\");\n }\n this.iframe.style.display = \"none\";\n this.iframe.setAttribute(\"sandbox\", attributes.join(\" \"));\n this.disableInteract();\n this.wrapper.appendChild(this.iframe);\n if (this.iframe.contentWindow && this.iframe.contentDocument) {\n polyfill(\n this.iframe.contentWindow,\n this.iframe.contentDocument\n );\n polyfill$1(this.iframe.contentWindow);\n }\n }\n rebuildFullSnapshot(event, isSync = false) {\n if (!this.iframe.contentDocument) {\n return this.warn(\"Looks like your replayer has been destroyed.\");\n }\n if (Object.keys(this.legacy_missingNodeRetryMap).length) {\n this.warn(\n \"Found unresolved missing node map\",\n this.legacy_missingNodeRetryMap\n );\n }\n this.legacy_missingNodeRetryMap = {};\n const collected = [];\n const afterAppend = (builtNode, id) => {\n this.collectIframeAndAttachDocument(collected, builtNode);\n if (this.mediaManager.isSupportedMediaElement(builtNode)) {\n const { events } = this.service.state.context;\n this.mediaManager.addMediaElements(\n builtNode,\n event.timestamp - events[0].timestamp,\n this.mirror\n );\n }\n for (const plugin of this.config.plugins || []) {\n if (plugin.onBuild)\n plugin.onBuild(builtNode, {\n id,\n replayer: this\n });\n }\n };\n if (this.usingVirtualDom) {\n this.virtualDom.destroyTree();\n this.usingVirtualDom = false;\n }\n this.mirror.reset();\n rebuild(event.data.node, {\n doc: this.iframe.contentDocument,\n afterAppend,\n cache: this.cache,\n mirror: this.mirror\n });\n afterAppend(this.iframe.contentDocument, event.data.node.id);\n for (const { mutationInQueue, builtNode } of collected) {\n this.attachDocumentToIframe(mutationInQueue, builtNode);\n this.newDocumentQueue = this.newDocumentQueue.filter(\n (m) => m !== mutationInQueue\n );\n }\n const { documentElement, head } = this.iframe.contentDocument;\n this.insertStyleRules(documentElement, head);\n if (!this.service.state.matches(\"playing\")) {\n this.iframe.contentDocument.getElementsByTagName(\"html\")[0].classList.add(\"rrweb-paused\");\n }\n this.emitter.emit(ReplayerEvents.FullsnapshotRebuilded, event);\n if (!isSync) {\n this.waitForStylesheetLoad();\n }\n if (this.config.UNSAFE_replayCanvas) {\n void this.preloadAllImages();\n }\n }\n insertStyleRules(documentElement, head) {\n var _a2;\n const injectStylesRules = rules(\n this.config.blockClass\n ).concat(this.config.insertStyleRules);\n if (this.config.pauseAnimation) {\n injectStylesRules.push(\n \"html.rrweb-paused *, html.rrweb-paused *:before, html.rrweb-paused *:after { animation-play-state: paused !important; }\"\n );\n }\n if (this.usingVirtualDom) {\n const styleEl = this.virtualDom.createElement(\"style\");\n this.virtualDom.mirror.add(\n styleEl,\n getDefaultSN(styleEl, this.virtualDom.unserializedId)\n );\n documentElement.insertBefore(styleEl, head);\n styleEl.rules.push({\n source: IncrementalSource.StyleSheetRule,\n adds: injectStylesRules.map((cssText, index) => ({\n rule: cssText,\n index\n }))\n });\n } else {\n const styleEl = document.createElement(\"style\");\n documentElement.insertBefore(\n styleEl,\n head\n );\n for (let idx = 0; idx < injectStylesRules.length; idx++) {\n (_a2 = styleEl.sheet) == null ? void 0 : _a2.insertRule(injectStylesRules[idx], idx);\n }\n }\n }\n attachDocumentToIframe(mutation, iframeEl) {\n const mirror2 = this.usingVirtualDom ? this.virtualDom.mirror : this.mirror;\n const collected = [];\n const afterAppend = (builtNode, id) => {\n this.collectIframeAndAttachDocument(collected, builtNode);\n const sn = mirror2.getMeta(builtNode);\n if ((sn == null ? void 0 : sn.type) === NodeType$2.Element && (sn == null ? void 0 : sn.tagName.toUpperCase()) === \"HTML\") {\n const { documentElement, head } = iframeEl.contentDocument;\n this.insertStyleRules(\n documentElement,\n head\n );\n }\n if (this.usingVirtualDom) return;\n for (const plugin of this.config.plugins || []) {\n if (plugin.onBuild)\n plugin.onBuild(builtNode, {\n id,\n replayer: this\n });\n }\n };\n buildNodeWithSN(mutation.node, {\n doc: iframeEl.contentDocument,\n mirror: mirror2,\n hackCss: true,\n skipChild: false,\n afterAppend,\n cache: this.cache\n });\n afterAppend(iframeEl.contentDocument, mutation.node.id);\n for (const { mutationInQueue, builtNode } of collected) {\n this.attachDocumentToIframe(mutationInQueue, builtNode);\n this.newDocumentQueue = this.newDocumentQueue.filter(\n (m) => m !== mutationInQueue\n );\n }\n }\n collectIframeAndAttachDocument(collected, builtNode) {\n if (isSerializedIframe(builtNode, this.mirror)) {\n const mutationInQueue = this.newDocumentQueue.find(\n (m) => m.parentId === this.mirror.getId(builtNode)\n );\n if (mutationInQueue) {\n collected.push({\n mutationInQueue,\n builtNode\n });\n }\n }\n }\n /**\n * pause when loading style sheet, resume when loaded all timeout exceed\n */\n waitForStylesheetLoad() {\n var _a2;\n const head = (_a2 = this.iframe.contentDocument) == null ? void 0 : _a2.head;\n if (head) {\n const unloadSheets = /* @__PURE__ */ new Set();\n let timer;\n let beforeLoadState = this.service.state;\n const stateHandler = () => {\n beforeLoadState = this.service.state;\n };\n this.emitter.on(ReplayerEvents.Start, stateHandler);\n this.emitter.on(ReplayerEvents.Pause, stateHandler);\n const unsubscribe = () => {\n this.emitter.off(ReplayerEvents.Start, stateHandler);\n this.emitter.off(ReplayerEvents.Pause, stateHandler);\n };\n head.querySelectorAll('link[rel=\"stylesheet\"]').forEach((css) => {\n if (!css.sheet) {\n unloadSheets.add(css);\n css.addEventListener(\"load\", () => {\n unloadSheets.delete(css);\n if (unloadSheets.size === 0 && timer !== -1) {\n if (beforeLoadState.matches(\"playing\")) {\n this.play(this.getCurrentTime());\n }\n this.emitter.emit(ReplayerEvents.LoadStylesheetEnd);\n if (timer) {\n clearTimeout(timer);\n }\n unsubscribe();\n }\n });\n }\n });\n if (unloadSheets.size > 0) {\n this.service.send({ type: \"PAUSE\" });\n this.emitter.emit(ReplayerEvents.LoadStylesheetStart);\n timer = setTimeout(() => {\n if (beforeLoadState.matches(\"playing\")) {\n this.play(this.getCurrentTime());\n }\n timer = -1;\n unsubscribe();\n }, this.config.loadTimeout);\n }\n }\n }\n /**\n * pause when there are some canvas drawImage args need to be loaded\n */\n async preloadAllImages() {\n const promises = [];\n for (const event of this.service.state.context.events) {\n if (event.type === EventType.IncrementalSnapshot && event.data.source === IncrementalSource.CanvasMutation) {\n promises.push(\n this.deserializeAndPreloadCanvasEvents(event.data, event)\n );\n const commands = \"commands\" in event.data ? event.data.commands : [event.data];\n commands.forEach((c2) => {\n this.preloadImages(c2, event);\n });\n }\n }\n return Promise.all(promises);\n }\n preloadImages(data, event) {\n if (data.property === \"drawImage\" && typeof data.args[0] === \"string\" && !this.imageMap.has(event)) {\n const canvas = document.createElement(\"canvas\");\n const ctx = canvas.getContext(\"2d\");\n const imgd = ctx == null ? void 0 : ctx.createImageData(canvas.width, canvas.height);\n ctx == null ? void 0 : ctx.putImageData(imgd, 0, 0);\n }\n }\n async deserializeAndPreloadCanvasEvents(data, event) {\n if (!this.canvasEventMap.has(event)) {\n const status = {\n isUnchanged: true\n };\n if (\"commands\" in data) {\n const commands = await Promise.all(\n data.commands.map(async (c2) => {\n const args = await Promise.all(\n c2.args.map(deserializeArg(this.imageMap, null, status))\n );\n return { ...c2, args };\n })\n );\n if (status.isUnchanged === false)\n this.canvasEventMap.set(event, { ...data, commands });\n } else {\n const args = await Promise.all(\n data.args.map(deserializeArg(this.imageMap, null, status))\n );\n if (status.isUnchanged === false)\n this.canvasEventMap.set(event, { ...data, args });\n }\n }\n }\n applyIncremental(e2, isSync) {\n var _a2, _b, _c;\n const { data: d } = e2;\n switch (d.source) {\n case IncrementalSource.Mutation: {\n try {\n this.applyMutation(d, isSync);\n } catch (error) {\n this.warn(`Exception in mutation ${error.message || error}`, d);\n }\n break;\n }\n case IncrementalSource.Drag:\n case IncrementalSource.TouchMove:\n case IncrementalSource.MouseMove:\n if (isSync) {\n const lastPosition = d.positions[d.positions.length - 1];\n this.mousePos = {\n x: lastPosition.x,\n y: lastPosition.y,\n id: lastPosition.id,\n debugData: d\n };\n } else {\n d.positions.forEach((p) => {\n const action = {\n doAction: () => {\n this.moveAndHover(p.x, p.y, p.id, isSync, d);\n },\n delay: p.timeOffset + e2.timestamp - this.service.state.context.baselineTime\n };\n this.timer.addAction(action);\n });\n this.timer.addAction({\n doAction() {\n },\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n delay: e2.delay - ((_a2 = d.positions[0]) == null ? void 0 : _a2.timeOffset)\n });\n }\n break;\n case IncrementalSource.MouseInteraction: {\n if (d.id === -1) {\n break;\n }\n const event = new Event(toLowerCase(MouseInteractions[d.type]));\n const target = this.mirror.getNode(d.id);\n if (!target) {\n return this.debugNodeNotFound(d, d.id);\n }\n this.emitter.emit(ReplayerEvents.MouseInteraction, {\n type: d.type,\n target\n });\n const { triggerFocus } = this.config;\n switch (d.type) {\n case MouseInteractions.Blur:\n if (\"blur\" in target) {\n target.blur();\n }\n break;\n case MouseInteractions.Focus:\n if (triggerFocus && target.focus) {\n target.focus({\n preventScroll: true\n });\n }\n break;\n case MouseInteractions.Click:\n case MouseInteractions.TouchStart:\n case MouseInteractions.TouchEnd:\n case MouseInteractions.MouseDown:\n case MouseInteractions.MouseUp:\n if (isSync) {\n if (d.type === MouseInteractions.TouchStart) {\n this.touchActive = true;\n } else if (d.type === MouseInteractions.TouchEnd) {\n this.touchActive = false;\n }\n if (d.type === MouseInteractions.MouseDown) {\n this.lastMouseDownEvent = [target, event];\n } else if (d.type === MouseInteractions.MouseUp) {\n this.lastMouseDownEvent = null;\n }\n this.mousePos = {\n x: d.x || 0,\n y: d.y || 0,\n id: d.id,\n debugData: d\n };\n } else {\n if (d.type === MouseInteractions.TouchStart) {\n this.tailPositions.length = 0;\n }\n this.moveAndHover(d.x || 0, d.y || 0, d.id, isSync, d);\n if (d.type === MouseInteractions.Click) {\n this.mouse.classList.remove(\"active\");\n void this.mouse.offsetWidth;\n this.mouse.classList.add(\"active\");\n } else if (d.type === MouseInteractions.TouchStart) {\n void this.mouse.offsetWidth;\n this.mouse.classList.add(\"touch-active\");\n } else if (d.type === MouseInteractions.TouchEnd) {\n this.mouse.classList.remove(\"touch-active\");\n } else {\n target.dispatchEvent(event);\n }\n }\n break;\n case MouseInteractions.TouchCancel:\n if (isSync) {\n this.touchActive = false;\n } else {\n this.mouse.classList.remove(\"touch-active\");\n }\n break;\n default:\n target.dispatchEvent(event);\n }\n break;\n }\n case IncrementalSource.Scroll: {\n if (d.id === -1) {\n break;\n }\n if (this.usingVirtualDom) {\n const target = this.virtualDom.mirror.getNode(d.id);\n if (!target) {\n return this.debugNodeNotFound(d, d.id);\n }\n target.scrollData = d;\n break;\n }\n this.applyScroll(d, isSync);\n break;\n }\n case IncrementalSource.ViewportResize:\n this.emitter.emit(ReplayerEvents.Resize, {\n width: d.width,\n height: d.height\n });\n break;\n case IncrementalSource.Input: {\n if (d.id === -1) {\n break;\n }\n if (this.usingVirtualDom) {\n const target = this.virtualDom.mirror.getNode(d.id);\n if (!target) {\n return this.debugNodeNotFound(d, d.id);\n }\n target.inputData = d;\n break;\n }\n this.applyInput(d);\n break;\n }\n case IncrementalSource.MediaInteraction: {\n const target = this.usingVirtualDom ? this.virtualDom.mirror.getNode(d.id) : this.mirror.getNode(d.id);\n if (!target) {\n return this.debugNodeNotFound(d, d.id);\n }\n const mediaEl = target;\n const { events } = this.service.state.context;\n this.mediaManager.mediaMutation({\n target: mediaEl,\n timeOffset: e2.timestamp - events[0].timestamp,\n mutation: d\n });\n break;\n }\n case IncrementalSource.StyleSheetRule:\n case IncrementalSource.StyleDeclaration: {\n if (this.usingVirtualDom) {\n if (d.styleId) this.constructedStyleMutations.push(d);\n else if (d.id)\n (_b = this.virtualDom.mirror.getNode(d.id)) == null ? void 0 : _b.rules.push(d);\n } else this.applyStyleSheetMutation(d);\n break;\n }\n case IncrementalSource.CanvasMutation: {\n if (!this.config.UNSAFE_replayCanvas) {\n return;\n }\n if (this.usingVirtualDom) {\n const target = this.virtualDom.mirror.getNode(\n d.id\n );\n if (!target) {\n return this.debugNodeNotFound(d, d.id);\n }\n target.canvasMutations.push({\n event: e2,\n mutation: d\n });\n } else {\n const target = this.mirror.getNode(d.id);\n if (!target) {\n return this.debugNodeNotFound(d, d.id);\n }\n void canvasMutation({\n event: e2,\n mutation: d,\n target,\n imageMap: this.imageMap,\n canvasEventMap: this.canvasEventMap,\n errorHandler: this.warnCanvasMutationFailed.bind(this)\n });\n }\n break;\n }\n case IncrementalSource.Font: {\n try {\n const fontFace = new FontFace(\n d.family,\n d.buffer ? new Uint8Array(JSON.parse(d.fontSource)) : d.fontSource,\n d.descriptors\n );\n (_c = this.iframe.contentDocument) == null ? void 0 : _c.fonts.add(fontFace);\n } catch (error) {\n this.warn(error);\n }\n break;\n }\n case IncrementalSource.Selection: {\n if (isSync) {\n this.lastSelectionData = d;\n break;\n }\n this.applySelection(d);\n break;\n }\n case IncrementalSource.AdoptedStyleSheet: {\n if (this.usingVirtualDom) this.adoptedStyleSheets.push(d);\n else this.applyAdoptedStyleSheet(d);\n break;\n }\n }\n }\n /**\n * Apply the mutation to the virtual dom or the real dom.\n * @param d - The mutation data.\n * @param isSync - Whether the mutation should be applied synchronously (while fast-forwarding).\n */\n applyMutation(d, isSync) {\n if (this.config.useVirtualDom && !this.usingVirtualDom && isSync) {\n this.usingVirtualDom = true;\n buildFromDom(this.iframe.contentDocument, this.mirror, this.virtualDom);\n if (Object.keys(this.legacy_missingNodeRetryMap).length) {\n for (const key in this.legacy_missingNodeRetryMap) {\n try {\n const value = this.legacy_missingNodeRetryMap[key];\n const virtualNode = buildFromNode(\n value.node,\n this.virtualDom,\n this.mirror\n );\n if (virtualNode) value.node = virtualNode;\n } catch (error) {\n this.warn(error);\n }\n }\n }\n }\n const mirror2 = this.usingVirtualDom ? this.virtualDom.mirror : this.mirror;\n d.removes = d.removes.filter((mutation) => {\n if (!mirror2.getNode(mutation.id)) {\n this.warnNodeNotFound(d, mutation.id);\n return false;\n }\n return true;\n });\n d.removes.forEach((mutation) => {\n var _a2;\n const target = mirror2.getNode(mutation.id);\n if (!target) {\n return;\n }\n let parent = mirror2.getNode(\n mutation.parentId\n );\n if (!parent) {\n return this.warnNodeNotFound(d, mutation.parentId);\n }\n if (mutation.isShadow && hasShadowRoot(parent)) {\n parent = parent.shadowRoot;\n }\n mirror2.removeNodeFromMap(target);\n if (parent)\n try {\n parent.removeChild(target);\n if (this.usingVirtualDom && target.nodeName === \"#text\" && parent.nodeName === \"STYLE\" && ((_a2 = parent.rules) == null ? void 0 : _a2.length) > 0)\n parent.rules = [];\n } catch (error) {\n if (error instanceof DOMException) {\n this.warn(\n \"parent could not remove child in mutation\",\n parent,\n target,\n d\n );\n } else {\n throw error;\n }\n }\n });\n const legacy_missingNodeMap = {\n ...this.legacy_missingNodeRetryMap\n };\n const queue = [];\n const nextNotInDOM = (mutation) => {\n let next = null;\n if (mutation.nextId) {\n next = mirror2.getNode(mutation.nextId);\n }\n if (mutation.nextId !== null && mutation.nextId !== void 0 && mutation.nextId !== -1 && !next) {\n return true;\n }\n return false;\n };\n const appendNode = (mutation) => {\n var _a2, _b;\n if (!this.iframe.contentDocument) {\n return this.warn(\"Looks like your replayer has been destroyed.\");\n }\n let parent = mirror2.getNode(\n mutation.parentId\n );\n if (!parent) {\n if (mutation.node.type === NodeType$2.Document) {\n return this.newDocumentQueue.push(mutation);\n }\n return queue.push(mutation);\n }\n if (mutation.node.isShadow) {\n if (!hasShadowRoot(parent)) {\n parent.attachShadow({ mode: \"open\" });\n parent = parent.shadowRoot;\n } else parent = parent.shadowRoot;\n }\n let previous = null;\n let next = null;\n if (mutation.previousId) {\n previous = mirror2.getNode(mutation.previousId);\n }\n if (mutation.nextId) {\n next = mirror2.getNode(mutation.nextId);\n }\n if (nextNotInDOM(mutation)) {\n return queue.push(mutation);\n }\n if (mutation.node.rootId && !mirror2.getNode(mutation.node.rootId)) {\n return;\n }\n const targetDoc = mutation.node.rootId ? mirror2.getNode(mutation.node.rootId) : this.usingVirtualDom ? this.virtualDom : this.iframe.contentDocument;\n if (isSerializedIframe(parent, mirror2)) {\n this.attachDocumentToIframe(\n mutation,\n parent\n );\n return;\n }\n const afterAppend = (node, id) => {\n if (this.usingVirtualDom) return;\n for (const plugin of this.config.plugins || []) {\n if (plugin.onBuild) plugin.onBuild(node, { id, replayer: this });\n }\n };\n const target = buildNodeWithSN(mutation.node, {\n doc: targetDoc,\n // can be Document or RRDocument\n mirror: mirror2,\n // can be this.mirror or virtualDom.mirror\n skipChild: true,\n hackCss: true,\n cache: this.cache,\n /**\n * caveat: `afterAppend` only gets called on child nodes of target\n * we have to call it again below when this target was added to the DOM\n */\n afterAppend\n });\n if (mutation.previousId === -1 || mutation.nextId === -1) {\n legacy_missingNodeMap[mutation.node.id] = {\n node: target,\n mutation\n };\n return;\n }\n const parentSn = mirror2.getMeta(parent);\n if (parentSn && parentSn.type === NodeType$2.Element && parentSn.tagName === \"textarea\" && mutation.node.type === NodeType$2.Text) {\n const childNodeArray = Array.isArray(parent.childNodes) ? parent.childNodes : Array.from(parent.childNodes);\n for (const c2 of childNodeArray) {\n if (c2.nodeType === parent.TEXT_NODE) {\n parent.removeChild(c2);\n }\n }\n } else if ((parentSn == null ? void 0 : parentSn.type) === NodeType$2.Document) {\n const parentDoc = parent;\n if (mutation.node.type === NodeType$2.DocumentType && ((_a2 = parentDoc.childNodes[0]) == null ? void 0 : _a2.nodeType) === Node.DOCUMENT_TYPE_NODE)\n parentDoc.removeChild(parentDoc.childNodes[0]);\n if (target.nodeName === \"HTML\" && parentDoc.documentElement)\n parentDoc.removeChild(\n parentDoc.documentElement\n );\n }\n if (previous && previous.nextSibling && previous.nextSibling.parentNode) {\n parent.insertBefore(\n target,\n previous.nextSibling\n );\n } else if (next && next.parentNode) {\n parent.contains(next) ? parent.insertBefore(target, next) : parent.insertBefore(target, null);\n } else {\n parent.appendChild(target);\n }\n afterAppend(target, mutation.node.id);\n if (this.usingVirtualDom && target.nodeName === \"#text\" && parent.nodeName === \"STYLE\" && ((_b = parent.rules) == null ? void 0 : _b.length) > 0)\n parent.rules = [];\n if (isSerializedIframe(target, this.mirror)) {\n const targetId = this.mirror.getId(target);\n const mutationInQueue = this.newDocumentQueue.find(\n (m) => m.parentId === targetId\n );\n if (mutationInQueue) {\n this.attachDocumentToIframe(\n mutationInQueue,\n target\n );\n this.newDocumentQueue = this.newDocumentQueue.filter(\n (m) => m !== mutationInQueue\n );\n }\n }\n if (mutation.previousId || mutation.nextId) {\n this.legacy_resolveMissingNode(\n legacy_missingNodeMap,\n parent,\n target,\n mutation\n );\n }\n };\n d.adds.forEach((mutation) => {\n appendNode(mutation);\n });\n const startTime = Date.now();\n while (queue.length) {\n const resolveTrees = queueToResolveTrees(queue);\n queue.length = 0;\n if (Date.now() - startTime > 500) {\n this.warn(\n \"Timeout in the loop, please check the resolve tree data:\",\n resolveTrees\n );\n break;\n }\n for (const tree of resolveTrees) {\n const parent = mirror2.getNode(tree.value.parentId);\n if (!parent) {\n this.debug(\n \"Drop resolve tree since there is no parent for the root node.\",\n tree\n );\n } else {\n iterateResolveTree(tree, (mutation) => {\n appendNode(mutation);\n });\n }\n }\n }\n if (Object.keys(legacy_missingNodeMap).length) {\n Object.assign(this.legacy_missingNodeRetryMap, legacy_missingNodeMap);\n }\n uniqueTextMutations(d.texts).forEach((mutation) => {\n var _a2;\n const target = mirror2.getNode(mutation.id);\n if (!target) {\n if (d.removes.find((r2) => r2.id === mutation.id)) {\n return;\n }\n return this.warnNodeNotFound(d, mutation.id);\n }\n target.textContent = mutation.value;\n if (this.usingVirtualDom) {\n const parent = target.parentNode;\n if (((_a2 = parent == null ? void 0 : parent.rules) == null ? void 0 : _a2.length) > 0) parent.rules = [];\n }\n });\n d.attributes.forEach((mutation) => {\n var _a2;\n const target = mirror2.getNode(mutation.id);\n if (!target) {\n if (d.removes.find((r2) => r2.id === mutation.id)) {\n return;\n }\n return this.warnNodeNotFound(d, mutation.id);\n }\n for (const attributeName in mutation.attributes) {\n if (typeof attributeName === \"string\") {\n const value = mutation.attributes[attributeName];\n if (value === null) {\n target.removeAttribute(attributeName);\n } else if (typeof value === \"string\") {\n try {\n if (attributeName === \"_cssText\" && (target.nodeName === \"LINK\" || target.nodeName === \"STYLE\")) {\n try {\n const newSn = mirror2.getMeta(\n target\n );\n Object.assign(\n newSn.attributes,\n mutation.attributes\n );\n const newNode = buildNodeWithSN(newSn, {\n doc: target.ownerDocument,\n // can be Document or RRDocument\n mirror: mirror2,\n skipChild: true,\n hackCss: true,\n cache: this.cache\n });\n const siblingNode = target.nextSibling;\n const parentNode = target.parentNode;\n if (newNode && parentNode) {\n parentNode.removeChild(target);\n parentNode.insertBefore(\n newNode,\n siblingNode\n );\n mirror2.replace(mutation.id, newNode);\n break;\n }\n } catch (e2) {\n }\n }\n if (attributeName === \"value\" && target.nodeName === \"TEXTAREA\") {\n const textarea = target;\n textarea.childNodes.forEach(\n (c2) => textarea.removeChild(c2)\n );\n const tn = (_a2 = target.ownerDocument) == null ? void 0 : _a2.createTextNode(value);\n if (tn) {\n textarea.appendChild(tn);\n }\n } else {\n target.setAttribute(\n attributeName,\n value\n );\n }\n } catch (error) {\n this.warn(\n \"An error occurred may due to the checkout feature.\",\n error\n );\n }\n } else if (attributeName === \"style\") {\n const styleValues = value;\n const targetEl = target;\n for (const s2 in styleValues) {\n if (styleValues[s2] === false) {\n targetEl.style.removeProperty(s2);\n } else if (styleValues[s2] instanceof Array) {\n const svp = styleValues[s2];\n targetEl.style.setProperty(s2, svp[0], svp[1]);\n } else {\n const svs = styleValues[s2];\n targetEl.style.setProperty(s2, svs);\n }\n }\n }\n }\n }\n });\n }\n /**\n * Apply the scroll data on real elements.\n * If the replayer is in sync mode, smooth scroll behavior should be disabled.\n * @param d - the scroll data\n * @param isSync - whether the replayer is in sync mode(fast-forward)\n */\n applyScroll(d, isSync) {\n var _a2, _b;\n const target = this.mirror.getNode(d.id);\n if (!target) {\n return this.debugNodeNotFound(d, d.id);\n }\n const sn = this.mirror.getMeta(target);\n if (target === this.iframe.contentDocument) {\n (_a2 = this.iframe.contentWindow) == null ? void 0 : _a2.scrollTo({\n top: d.y,\n left: d.x,\n behavior: isSync ? \"auto\" : \"smooth\"\n });\n } else if ((sn == null ? void 0 : sn.type) === NodeType$2.Document) {\n (_b = target.defaultView) == null ? void 0 : _b.scrollTo({\n top: d.y,\n left: d.x,\n behavior: isSync ? \"auto\" : \"smooth\"\n });\n } else {\n try {\n target.scrollTo({\n top: d.y,\n left: d.x,\n behavior: isSync ? \"auto\" : \"smooth\"\n });\n } catch (error) {\n }\n }\n }\n applyInput(d) {\n const target = this.mirror.getNode(d.id);\n if (!target) {\n return this.debugNodeNotFound(d, d.id);\n }\n try {\n target.checked = d.isChecked;\n target.value = d.text;\n } catch (error) {\n }\n }\n applySelection(d) {\n try {\n const selectionSet = /* @__PURE__ */ new Set();\n const ranges = d.ranges.map(({ start, startOffset, end, endOffset }) => {\n const startContainer = this.mirror.getNode(start);\n const endContainer = this.mirror.getNode(end);\n if (!startContainer || !endContainer) return;\n const result = new Range();\n result.setStart(startContainer, startOffset);\n result.setEnd(endContainer, endOffset);\n const doc = startContainer.ownerDocument;\n const selection = doc == null ? void 0 : doc.getSelection();\n selection && selectionSet.add(selection);\n return {\n range: result,\n selection\n };\n });\n selectionSet.forEach((s2) => s2.removeAllRanges());\n ranges.forEach((r2) => {\n var _a2;\n return r2 && ((_a2 = r2.selection) == null ? void 0 : _a2.addRange(r2.range));\n });\n } catch (error) {\n }\n }\n applyStyleSheetMutation(data) {\n var _a2;\n let styleSheet = null;\n if (data.styleId) styleSheet = this.styleMirror.getStyle(data.styleId);\n else if (data.id)\n styleSheet = ((_a2 = this.mirror.getNode(data.id)) == null ? void 0 : _a2.sheet) || null;\n if (!styleSheet) return;\n if (data.source === IncrementalSource.StyleSheetRule)\n this.applyStyleSheetRule(data, styleSheet);\n else if (data.source === IncrementalSource.StyleDeclaration)\n this.applyStyleDeclaration(data, styleSheet);\n }\n applyStyleSheetRule(data, styleSheet) {\n var _a2, _b, _c, _d;\n (_a2 = data.adds) == null ? void 0 : _a2.forEach(({ rule, index: nestedIndex }) => {\n try {\n if (Array.isArray(nestedIndex)) {\n const { positions, index } = getPositionsAndIndex(nestedIndex);\n const nestedRule = getNestedRule(styleSheet.cssRules, positions);\n nestedRule.insertRule(rule, index);\n } else {\n const index = nestedIndex === void 0 ? void 0 : Math.min(nestedIndex, styleSheet.cssRules.length);\n styleSheet == null ? void 0 : styleSheet.insertRule(rule, index);\n }\n } catch (e2) {\n }\n });\n (_b = data.removes) == null ? void 0 : _b.forEach(({ index: nestedIndex }) => {\n try {\n if (Array.isArray(nestedIndex)) {\n const { positions, index } = getPositionsAndIndex(nestedIndex);\n const nestedRule = getNestedRule(styleSheet.cssRules, positions);\n nestedRule.deleteRule(index || 0);\n } else {\n styleSheet == null ? void 0 : styleSheet.deleteRule(nestedIndex);\n }\n } catch (e2) {\n }\n });\n if (data.replace)\n try {\n void ((_c = styleSheet.replace) == null ? void 0 : _c.call(styleSheet, data.replace));\n } catch (e2) {\n }\n if (data.replaceSync)\n try {\n (_d = styleSheet.replaceSync) == null ? void 0 : _d.call(styleSheet, data.replaceSync);\n } catch (e2) {\n }\n }\n applyStyleDeclaration(data, styleSheet) {\n if (data.set) {\n const rule = getNestedRule(\n styleSheet.rules,\n data.index\n );\n rule.style.setProperty(\n data.set.property,\n data.set.value,\n data.set.priority\n );\n }\n if (data.remove) {\n const rule = getNestedRule(\n styleSheet.rules,\n data.index\n );\n rule.style.removeProperty(data.remove.property);\n }\n }\n applyAdoptedStyleSheet(data) {\n var _a2;\n const targetHost = this.mirror.getNode(data.id);\n if (!targetHost) return;\n (_a2 = data.styles) == null ? void 0 : _a2.forEach((style) => {\n var _a3;\n let newStyleSheet = null;\n let hostWindow = null;\n if (hasShadowRoot(targetHost))\n hostWindow = ((_a3 = targetHost.ownerDocument) == null ? void 0 : _a3.defaultView) || null;\n else if (targetHost.nodeName === \"#document\")\n hostWindow = targetHost.defaultView;\n if (!hostWindow) return;\n try {\n newStyleSheet = new hostWindow.CSSStyleSheet();\n this.styleMirror.add(newStyleSheet, style.styleId);\n this.applyStyleSheetRule(\n {\n source: IncrementalSource.StyleSheetRule,\n adds: style.rules\n },\n newStyleSheet\n );\n } catch (e2) {\n }\n });\n const MAX_RETRY_TIME = 10;\n let count = 0;\n const adoptStyleSheets = (targetHost2, styleIds) => {\n const stylesToAdopt = styleIds.map((styleId) => this.styleMirror.getStyle(styleId)).filter((style) => style !== null);\n if (hasShadowRoot(targetHost2))\n targetHost2.shadowRoot.adoptedStyleSheets = stylesToAdopt;\n else if (targetHost2.nodeName === \"#document\")\n targetHost2.adoptedStyleSheets = stylesToAdopt;\n if (stylesToAdopt.length !== styleIds.length && count < MAX_RETRY_TIME) {\n setTimeout(\n () => adoptStyleSheets(targetHost2, styleIds),\n 0 + 100 * count\n );\n count++;\n }\n };\n adoptStyleSheets(targetHost, data.styleIds);\n }\n legacy_resolveMissingNode(map, parent, target, targetMutation) {\n const { previousId, nextId } = targetMutation;\n const previousInMap = previousId && map[previousId];\n const nextInMap = nextId && map[nextId];\n if (previousInMap) {\n const { node, mutation } = previousInMap;\n parent.insertBefore(node, target);\n delete map[mutation.node.id];\n delete this.legacy_missingNodeRetryMap[mutation.node.id];\n if (mutation.previousId || mutation.nextId) {\n this.legacy_resolveMissingNode(map, parent, node, mutation);\n }\n }\n if (nextInMap) {\n const { node, mutation } = nextInMap;\n parent.insertBefore(\n node,\n target.nextSibling\n );\n delete map[mutation.node.id];\n delete this.legacy_missingNodeRetryMap[mutation.node.id];\n if (mutation.previousId || mutation.nextId) {\n this.legacy_resolveMissingNode(map, parent, node, mutation);\n }\n }\n }\n moveAndHover(x, y, id, isSync, debugData) {\n const target = this.mirror.getNode(id);\n if (!target) {\n return this.debugNodeNotFound(debugData, id);\n }\n const base = getBaseDimension(target, this.iframe);\n const _x = x * base.absoluteScale + base.x;\n const _y = y * base.absoluteScale + base.y;\n this.mouse.style.left = `${_x}px`;\n this.mouse.style.top = `${_y}px`;\n if (!isSync) {\n this.drawMouseTail({ x: _x, y: _y });\n }\n this.hoverElements(target);\n }\n drawMouseTail(position) {\n if (!this.mouseTail) {\n return;\n }\n const { lineCap, lineWidth, strokeStyle, duration } = this.config.mouseTail === true ? defaultMouseTailConfig : Object.assign({}, defaultMouseTailConfig, this.config.mouseTail);\n const draw = () => {\n if (!this.mouseTail) {\n return;\n }\n const ctx = this.mouseTail.getContext(\"2d\");\n if (!ctx || !this.tailPositions.length) {\n return;\n }\n ctx.clearRect(0, 0, this.mouseTail.width, this.mouseTail.height);\n ctx.beginPath();\n ctx.lineWidth = lineWidth;\n ctx.lineCap = lineCap;\n ctx.strokeStyle = strokeStyle;\n ctx.moveTo(this.tailPositions[0].x, this.tailPositions[0].y);\n this.tailPositions.forEach((p) => ctx.lineTo(p.x, p.y));\n ctx.stroke();\n };\n this.tailPositions.push(position);\n draw();\n setTimeout(() => {\n this.tailPositions = this.tailPositions.filter((p) => p !== position);\n draw();\n }, duration / this.speedService.state.context.timer.speed);\n }\n hoverElements(el) {\n var _a2;\n (_a2 = this.lastHoveredRootNode || this.iframe.contentDocument) == null ? void 0 : _a2.querySelectorAll(\".\\\\:hover\").forEach((hoveredEl) => {\n hoveredEl.classList.remove(\":hover\");\n });\n this.lastHoveredRootNode = el.getRootNode();\n let currentEl = el;\n while (currentEl) {\n if (currentEl.classList) {\n currentEl.classList.add(\":hover\");\n }\n currentEl = currentEl.parentElement;\n }\n }\n isUserInteraction(event) {\n if (event.type !== EventType.IncrementalSnapshot) {\n return false;\n }\n return event.data.source > IncrementalSource.Mutation && event.data.source <= IncrementalSource.Input;\n }\n backToNormal() {\n this.nextUserInteractionEvent = null;\n if (this.speedService.state.matches(\"normal\")) {\n return;\n }\n this.speedService.send({ type: \"BACK_TO_NORMAL\" });\n this.emitter.emit(ReplayerEvents.SkipEnd, {\n speed: this.speedService.state.context.normalSpeed\n });\n }\n warnNodeNotFound(d, id) {\n this.warn(`Node with id '${id}' not found. `, d);\n }\n warnCanvasMutationFailed(d, error) {\n this.warn(`Has error on canvas update`, error, \"canvas mutation:\", d);\n }\n debugNodeNotFound(d, id) {\n this.debug(`Node with id '${id}' not found. `, d);\n }\n warn(...args) {\n if (!this.config.showWarning) {\n return;\n }\n this.config.logger.warn(REPLAY_CONSOLE_PREFIX, ...args);\n }\n debug(...args) {\n if (!this.config.showDebug) {\n return;\n }\n this.config.logger.log(REPLAY_CONSOLE_PREFIX, ...args);\n }\n}\nconst { addCustomEvent } = record;\nconst { freezePage } = record;\nconst version = \"2.0.0-alpha.16\"\nexport {\n EventType,\n IncrementalSource,\n MouseInteractions,\n Replayer,\n ReplayerEvents,\n addCustomEvent,\n canvasMutation,\n freezePage,\n _mirror as mirror,\n record,\n utils,\n version,\n};\n//# sourceMappingURL=rrweb.js.map\n","var __defProp = Object.defineProperty;\nvar __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __publicField = (obj, key, value) => {\n __defNormalProp(obj, typeof key !== \"symbol\" ? key + \"\" : key, value);\n return value;\n};\nvar __defProp2 = Object.defineProperty;\nvar __defNormalProp2 = (obj, key, value) => key in obj ? __defProp2(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __publicField2 = (obj, key, value) => {\n __defNormalProp2(obj, typeof key !== \"symbol\" ? key + \"\" : key, value);\n return value;\n};\nvar _a;\nvar __defProp$1 = Object.defineProperty;\nvar __defNormalProp$1 = (obj, key, value) => key in obj ? __defProp$1(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __publicField$1 = (obj, key, value) => {\n __defNormalProp$1(obj, typeof key !== \"symbol\" ? key + \"\" : key, value);\n return value;\n};\nfunction isShadowRoot(n2) {\n const host = n2 == null ? void 0 : n2.host;\n return Boolean((host == null ? void 0 : host.shadowRoot) === n2);\n}\nclass Mirror {\n constructor() {\n __publicField$1(this, \"idNodeMap\", /* @__PURE__ */ new Map());\n __publicField$1(this, \"nodeMetaMap\", /* @__PURE__ */ new WeakMap());\n }\n getId(n2) {\n var _a2;\n if (!n2)\n return -1;\n const id = (_a2 = this.getMeta(n2)) == null ? void 0 : _a2.id;\n return id ?? -1;\n }\n getNode(id) {\n return this.idNodeMap.get(id) || null;\n }\n getIds() {\n return Array.from(this.idNodeMap.keys());\n }\n getMeta(n2) {\n return this.nodeMetaMap.get(n2) || null;\n }\n // removes the node from idNodeMap\n // doesn't remove the node from nodeMetaMap\n removeNodeFromMap(n2) {\n const id = this.getId(n2);\n this.idNodeMap.delete(id);\n if (n2.childNodes) {\n n2.childNodes.forEach(\n (childNode) => this.removeNodeFromMap(childNode)\n );\n }\n }\n has(id) {\n return this.idNodeMap.has(id);\n }\n hasNode(node) {\n return this.nodeMetaMap.has(node);\n }\n add(n2, meta) {\n const id = meta.id;\n this.idNodeMap.set(id, n2);\n this.nodeMetaMap.set(n2, meta);\n }\n replace(id, n2) {\n const oldNode = this.getNode(id);\n if (oldNode) {\n const meta = this.nodeMetaMap.get(oldNode);\n if (meta)\n this.nodeMetaMap.set(n2, meta);\n }\n this.idNodeMap.set(id, n2);\n }\n reset() {\n this.idNodeMap = /* @__PURE__ */ new Map();\n this.nodeMetaMap = /* @__PURE__ */ new WeakMap();\n }\n}\nfunction createMirror$2() {\n return new Mirror();\n}\nconst IGNORED_NODE = -2;\nfunction classMatchesRegex(node, regex, checkAncestors) {\n if (!node)\n return false;\n if (node.nodeType !== node.ELEMENT_NODE) {\n if (!checkAncestors)\n return false;\n return classMatchesRegex(node.parentNode, regex, checkAncestors);\n }\n for (let eIndex = node.classList.length; eIndex--; ) {\n const className = node.classList[eIndex];\n if (regex.test(className)) {\n return true;\n }\n }\n if (!checkAncestors)\n return false;\n return classMatchesRegex(node.parentNode, regex, checkAncestors);\n}\nfunction on(type, fn, target = document) {\n const options = { capture: true, passive: true };\n target.addEventListener(type, fn, options);\n return () => target.removeEventListener(type, fn, options);\n}\nconst DEPARTED_MIRROR_ACCESS_WARNING = \"Please stop import mirror directly. Instead of that,\\r\\nnow you can use replayer.getMirror() to access the mirror instance of a replayer,\\r\\nor you can use record.mirror to access the mirror instance during recording.\";\nlet _mirror = {\n map: {},\n getId() {\n console.error(DEPARTED_MIRROR_ACCESS_WARNING);\n return -1;\n },\n getNode() {\n console.error(DEPARTED_MIRROR_ACCESS_WARNING);\n return null;\n },\n removeNodeFromMap() {\n console.error(DEPARTED_MIRROR_ACCESS_WARNING);\n },\n has() {\n console.error(DEPARTED_MIRROR_ACCESS_WARNING);\n return false;\n },\n reset() {\n console.error(DEPARTED_MIRROR_ACCESS_WARNING);\n }\n};\nif (typeof window !== \"undefined\" && window.Proxy && window.Reflect) {\n _mirror = new Proxy(_mirror, {\n get(target, prop, receiver) {\n if (prop === \"map\") {\n console.error(DEPARTED_MIRROR_ACCESS_WARNING);\n }\n return Reflect.get(target, prop, receiver);\n }\n });\n}\nfunction throttle(func, wait, options = {}) {\n let timeout = null;\n let previous = 0;\n return function(...args) {\n const now = Date.now();\n if (!previous && options.leading === false) {\n previous = now;\n }\n const remaining = wait - (now - previous);\n const context = this;\n if (remaining <= 0 || remaining > wait) {\n if (timeout) {\n clearTimeout(timeout);\n timeout = null;\n }\n previous = now;\n func.apply(context, args);\n } else if (!timeout && options.trailing !== false) {\n timeout = setTimeout(() => {\n previous = options.leading === false ? 0 : Date.now();\n timeout = null;\n func.apply(context, args);\n }, remaining);\n }\n };\n}\nfunction hookSetter(target, key, d, isRevoked, win = window) {\n const original = win.Object.getOwnPropertyDescriptor(target, key);\n win.Object.defineProperty(\n target,\n key,\n isRevoked ? d : {\n set(value) {\n setTimeout(() => {\n d.set.call(this, value);\n }, 0);\n if (original && original.set) {\n original.set.call(this, value);\n }\n }\n }\n );\n return () => hookSetter(target, key, original || {}, true);\n}\nfunction patch(source, name, replacement) {\n try {\n if (!(name in source)) {\n return () => {\n };\n }\n const original = source[name];\n const wrapped = replacement(original);\n if (typeof wrapped === \"function\") {\n wrapped.prototype = wrapped.prototype || {};\n Object.defineProperties(wrapped, {\n __rrweb_original__: {\n enumerable: false,\n value: original\n }\n });\n }\n source[name] = wrapped;\n return () => {\n source[name] = original;\n };\n } catch {\n return () => {\n };\n }\n}\nlet nowTimestamp = Date.now;\nif (!/* @__PURE__ */ /[1-9][0-9]{12}/.test(Date.now().toString())) {\n nowTimestamp = () => (/* @__PURE__ */ new Date()).getTime();\n}\nfunction getWindowScroll(win) {\n var _a2, _b, _c, _d, _e, _f;\n const doc = win.document;\n return {\n left: doc.scrollingElement ? doc.scrollingElement.scrollLeft : win.pageXOffset !== void 0 ? win.pageXOffset : (doc == null ? void 0 : doc.documentElement.scrollLeft) || ((_b = (_a2 = doc == null ? void 0 : doc.body) == null ? void 0 : _a2.parentElement) == null ? void 0 : _b.scrollLeft) || ((_c = doc == null ? void 0 : doc.body) == null ? void 0 : _c.scrollLeft) || 0,\n top: doc.scrollingElement ? doc.scrollingElement.scrollTop : win.pageYOffset !== void 0 ? win.pageYOffset : (doc == null ? void 0 : doc.documentElement.scrollTop) || ((_e = (_d = doc == null ? void 0 : doc.body) == null ? void 0 : _d.parentElement) == null ? void 0 : _e.scrollTop) || ((_f = doc == null ? void 0 : doc.body) == null ? void 0 : _f.scrollTop) || 0\n };\n}\nfunction getWindowHeight() {\n return window.innerHeight || document.documentElement && document.documentElement.clientHeight || document.body && document.body.clientHeight;\n}\nfunction getWindowWidth() {\n return window.innerWidth || document.documentElement && document.documentElement.clientWidth || document.body && document.body.clientWidth;\n}\nfunction closestElementOfNode(node) {\n if (!node) {\n return null;\n }\n const el = node.nodeType === node.ELEMENT_NODE ? node : node.parentElement;\n return el;\n}\nfunction isBlocked(node, blockClass, blockSelector, checkAncestors) {\n if (!node) {\n return false;\n }\n const el = closestElementOfNode(node);\n if (!el) {\n return false;\n }\n try {\n if (typeof blockClass === \"string\") {\n if (el.classList.contains(blockClass))\n return true;\n if (checkAncestors && el.closest(\".\" + blockClass) !== null)\n return true;\n } else {\n if (classMatchesRegex(el, blockClass, checkAncestors))\n return true;\n }\n } catch (e2) {\n }\n if (blockSelector) {\n if (el.matches(blockSelector))\n return true;\n if (checkAncestors && el.closest(blockSelector) !== null)\n return true;\n }\n return false;\n}\nfunction isSerialized(n2, mirror2) {\n return mirror2.getId(n2) !== -1;\n}\nfunction isIgnored(n2, mirror2, slimDOMOptions) {\n if (n2.tagName === \"TITLE\" && slimDOMOptions.headTitleMutations) {\n return true;\n }\n return mirror2.getId(n2) === IGNORED_NODE;\n}\nfunction isAncestorRemoved(target, mirror2) {\n if (isShadowRoot(target)) {\n return false;\n }\n const id = mirror2.getId(target);\n if (!mirror2.has(id)) {\n return true;\n }\n if (target.parentNode && target.parentNode.nodeType === target.DOCUMENT_NODE) {\n return false;\n }\n if (!target.parentNode) {\n return true;\n }\n return isAncestorRemoved(target.parentNode, mirror2);\n}\nfunction legacy_isTouchEvent(event) {\n return Boolean(event.changedTouches);\n}\nfunction polyfill$1(win = window) {\n if (\"NodeList\" in win && !win.NodeList.prototype.forEach) {\n win.NodeList.prototype.forEach = Array.prototype.forEach;\n }\n if (\"DOMTokenList\" in win && !win.DOMTokenList.prototype.forEach) {\n win.DOMTokenList.prototype.forEach = Array.prototype.forEach;\n }\n if (!Node.prototype.contains) {\n Node.prototype.contains = (...args) => {\n let node = args[0];\n if (!(0 in args)) {\n throw new TypeError(\"1 argument is required\");\n }\n do {\n if (this === node) {\n return true;\n }\n } while (node = node && node.parentNode);\n return false;\n };\n }\n}\nfunction queueToResolveTrees(queue) {\n const queueNodeMap = {};\n const putIntoMap = (m, parent) => {\n const nodeInTree = {\n value: m,\n parent,\n children: []\n };\n queueNodeMap[m.node.id] = nodeInTree;\n return nodeInTree;\n };\n const queueNodeTrees = [];\n for (const mutation of queue) {\n const { nextId, parentId } = mutation;\n if (nextId && nextId in queueNodeMap) {\n const nextInTree = queueNodeMap[nextId];\n if (nextInTree.parent) {\n const idx = nextInTree.parent.children.indexOf(nextInTree);\n nextInTree.parent.children.splice(\n idx,\n 0,\n putIntoMap(mutation, nextInTree.parent)\n );\n } else {\n const idx = queueNodeTrees.indexOf(nextInTree);\n queueNodeTrees.splice(idx, 0, putIntoMap(mutation, null));\n }\n continue;\n }\n if (parentId in queueNodeMap) {\n const parentInTree = queueNodeMap[parentId];\n parentInTree.children.push(putIntoMap(mutation, parentInTree));\n continue;\n }\n queueNodeTrees.push(putIntoMap(mutation, null));\n }\n return queueNodeTrees;\n}\nfunction iterateResolveTree(tree, cb) {\n cb(tree.value);\n for (let i2 = tree.children.length - 1; i2 >= 0; i2--) {\n iterateResolveTree(tree.children[i2], cb);\n }\n}\nfunction isSerializedIframe(n2, mirror2) {\n return Boolean(n2.nodeName === \"IFRAME\" && mirror2.getMeta(n2));\n}\nfunction isSerializedStylesheet(n2, mirror2) {\n return Boolean(\n n2.nodeName === \"LINK\" && n2.nodeType === n2.ELEMENT_NODE && n2.getAttribute && n2.getAttribute(\"rel\") === \"stylesheet\" && mirror2.getMeta(n2)\n );\n}\nfunction getBaseDimension(node, rootIframe) {\n var _a2, _b;\n const frameElement = (_b = (_a2 = node.ownerDocument) == null ? void 0 : _a2.defaultView) == null ? void 0 : _b.frameElement;\n if (!frameElement || frameElement === rootIframe) {\n return {\n x: 0,\n y: 0,\n relativeScale: 1,\n absoluteScale: 1\n };\n }\n const frameDimension = frameElement.getBoundingClientRect();\n const frameBaseDimension = getBaseDimension(frameElement, rootIframe);\n const relativeScale = frameDimension.height / frameElement.clientHeight;\n return {\n x: frameDimension.x * frameBaseDimension.relativeScale + frameBaseDimension.x,\n y: frameDimension.y * frameBaseDimension.relativeScale + frameBaseDimension.y,\n relativeScale,\n absoluteScale: frameBaseDimension.absoluteScale * relativeScale\n };\n}\nfunction hasShadowRoot(n2) {\n return Boolean(n2 == null ? void 0 : n2.shadowRoot);\n}\nfunction getNestedRule(rules2, position) {\n const rule = rules2[position[0]];\n if (position.length === 1) {\n return rule;\n } else {\n return getNestedRule(\n rule.cssRules[position[1]].cssRules,\n position.slice(2)\n );\n }\n}\nfunction getPositionsAndIndex(nestedIndex) {\n const positions = [...nestedIndex];\n const index = positions.pop();\n return { positions, index };\n}\nfunction uniqueTextMutations(mutations) {\n const idSet = /* @__PURE__ */ new Set();\n const uniqueMutations = [];\n for (let i2 = mutations.length; i2--; ) {\n const mutation = mutations[i2];\n if (!idSet.has(mutation.id)) {\n uniqueMutations.push(mutation);\n idSet.add(mutation.id);\n }\n }\n return uniqueMutations;\n}\nclass StyleSheetMirror {\n constructor() {\n __publicField2(this, \"id\", 1);\n __publicField2(this, \"styleIDMap\", /* @__PURE__ */ new WeakMap());\n __publicField2(this, \"idStyleMap\", /* @__PURE__ */ new Map());\n }\n getId(stylesheet) {\n return this.styleIDMap.get(stylesheet) ?? -1;\n }\n has(stylesheet) {\n return this.styleIDMap.has(stylesheet);\n }\n /**\n * @returns If the stylesheet is in the mirror, returns the id of the stylesheet. If not, return the new assigned id.\n */\n add(stylesheet, id) {\n if (this.has(stylesheet))\n return this.getId(stylesheet);\n let newId;\n if (id === void 0) {\n newId = this.id++;\n } else\n newId = id;\n this.styleIDMap.set(stylesheet, newId);\n this.idStyleMap.set(newId, stylesheet);\n return newId;\n }\n getStyle(id) {\n return this.idStyleMap.get(id) || null;\n }\n reset() {\n this.styleIDMap = /* @__PURE__ */ new WeakMap();\n this.idStyleMap = /* @__PURE__ */ new Map();\n this.id = 1;\n }\n generateId() {\n return this.id++;\n }\n}\nfunction getShadowHost(n2) {\n var _a2, _b;\n let shadowHost = null;\n if (((_b = (_a2 = n2.getRootNode) == null ? void 0 : _a2.call(n2)) == null ? void 0 : _b.nodeType) === Node.DOCUMENT_FRAGMENT_NODE && n2.getRootNode().host)\n shadowHost = n2.getRootNode().host;\n return shadowHost;\n}\nfunction getRootShadowHost(n2) {\n let rootShadowHost = n2;\n let shadowHost;\n while (shadowHost = getShadowHost(rootShadowHost))\n rootShadowHost = shadowHost;\n return rootShadowHost;\n}\nfunction shadowHostInDom(n2) {\n const doc = n2.ownerDocument;\n if (!doc)\n return false;\n const shadowHost = getRootShadowHost(n2);\n return doc.contains(shadowHost);\n}\nfunction inDom(n2) {\n const doc = n2.ownerDocument;\n if (!doc)\n return false;\n return doc.contains(n2) || shadowHostInDom(n2);\n}\nconst utils = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({\n __proto__: null,\n StyleSheetMirror,\n get _mirror() {\n return _mirror;\n },\n closestElementOfNode,\n getBaseDimension,\n getNestedRule,\n getPositionsAndIndex,\n getRootShadowHost,\n getShadowHost,\n getWindowHeight,\n getWindowScroll,\n getWindowWidth,\n hasShadowRoot,\n hookSetter,\n inDom,\n isAncestorRemoved,\n isBlocked,\n isIgnored,\n isSerialized,\n isSerializedIframe,\n isSerializedStylesheet,\n iterateResolveTree,\n legacy_isTouchEvent,\n get nowTimestamp() {\n return nowTimestamp;\n },\n on,\n patch,\n polyfill: polyfill$1,\n queueToResolveTrees,\n shadowHostInDom,\n throttle,\n uniqueTextMutations\n}, Symbol.toStringTag, { value: \"Module\" }));\nvar chars = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\";\nvar lookup = typeof Uint8Array === \"undefined\" ? [] : new Uint8Array(256);\nfor (var i$1 = 0; i$1 < chars.length; i$1++) {\n lookup[chars.charCodeAt(i$1)] = i$1;\n}\nconst encodedJs = \"KGZ1bmN0aW9uKCkgewogICJ1c2Ugc3RyaWN0IjsKICB2YXIgY2hhcnMgPSAiQUJDREVGR0hJSktMTU5PUFFSU1RVVldYWVphYmNkZWZnaGlqa2xtbm9wcXJzdHV2d3h5ejAxMjM0NTY3ODkrLyI7CiAgdmFyIGxvb2t1cCA9IHR5cGVvZiBVaW50OEFycmF5ID09PSAidW5kZWZpbmVkIiA/IFtdIDogbmV3IFVpbnQ4QXJyYXkoMjU2KTsKICBmb3IgKHZhciBpID0gMDsgaSA8IGNoYXJzLmxlbmd0aDsgaSsrKSB7CiAgICBsb29rdXBbY2hhcnMuY2hhckNvZGVBdChpKV0gPSBpOwogIH0KICB2YXIgZW5jb2RlID0gZnVuY3Rpb24oYXJyYXlidWZmZXIpIHsKICAgIHZhciBieXRlcyA9IG5ldyBVaW50OEFycmF5KGFycmF5YnVmZmVyKSwgaTIsIGxlbiA9IGJ5dGVzLmxlbmd0aCwgYmFzZTY0ID0gIiI7CiAgICBmb3IgKGkyID0gMDsgaTIgPCBsZW47IGkyICs9IDMpIHsKICAgICAgYmFzZTY0ICs9IGNoYXJzW2J5dGVzW2kyXSA+PiAyXTsKICAgICAgYmFzZTY0ICs9IGNoYXJzWyhieXRlc1tpMl0gJiAzKSA8PCA0IHwgYnl0ZXNbaTIgKyAxXSA+PiA0XTsKICAgICAgYmFzZTY0ICs9IGNoYXJzWyhieXRlc1tpMiArIDFdICYgMTUpIDw8IDIgfCBieXRlc1tpMiArIDJdID4+IDZdOwogICAgICBiYXNlNjQgKz0gY2hhcnNbYnl0ZXNbaTIgKyAyXSAmIDYzXTsKICAgIH0KICAgIGlmIChsZW4gJSAzID09PSAyKSB7CiAgICAgIGJhc2U2NCA9IGJhc2U2NC5zdWJzdHJpbmcoMCwgYmFzZTY0Lmxlbmd0aCAtIDEpICsgIj0iOwogICAgfSBlbHNlIGlmIChsZW4gJSAzID09PSAxKSB7CiAgICAgIGJhc2U2NCA9IGJhc2U2NC5zdWJzdHJpbmcoMCwgYmFzZTY0Lmxlbmd0aCAtIDIpICsgIj09IjsKICAgIH0KICAgIHJldHVybiBiYXNlNjQ7CiAgfTsKICBjb25zdCBsYXN0QmxvYk1hcCA9IC8qIEBfX1BVUkVfXyAqLyBuZXcgTWFwKCk7CiAgY29uc3QgdHJhbnNwYXJlbnRCbG9iTWFwID0gLyogQF9fUFVSRV9fICovIG5ldyBNYXAoKTsKICBhc3luYyBmdW5jdGlvbiBnZXRUcmFuc3BhcmVudEJsb2JGb3Iod2lkdGgsIGhlaWdodCwgZGF0YVVSTE9wdGlvbnMpIHsKICAgIGNvbnN0IGlkID0gYCR7d2lkdGh9LSR7aGVpZ2h0fWA7CiAgICBpZiAoIk9mZnNjcmVlbkNhbnZhcyIgaW4gZ2xvYmFsVGhpcykgewogICAgICBpZiAodHJhbnNwYXJlbnRCbG9iTWFwLmhhcyhpZCkpCiAgICAgICAgcmV0dXJuIHRyYW5zcGFyZW50QmxvYk1hcC5nZXQoaWQpOwogICAgICBjb25zdCBvZmZzY3JlZW4gPSBuZXcgT2Zmc2NyZWVuQ2FudmFzKHdpZHRoLCBoZWlnaHQpOwogICAgICBvZmZzY3JlZW4uZ2V0Q29udGV4dCgiMmQiKTsKICAgICAgY29uc3QgYmxvYiA9IGF3YWl0IG9mZnNjcmVlbi5jb252ZXJ0VG9CbG9iKGRhdGFVUkxPcHRpb25zKTsKICAgICAgY29uc3QgYXJyYXlCdWZmZXIgPSBhd2FpdCBibG9iLmFycmF5QnVmZmVyKCk7CiAgICAgIGNvbnN0IGJhc2U2NCA9IGVuY29kZShhcnJheUJ1ZmZlcik7CiAgICAgIHRyYW5zcGFyZW50QmxvYk1hcC5zZXQoaWQsIGJhc2U2NCk7CiAgICAgIHJldHVybiBiYXNlNjQ7CiAgICB9IGVsc2UgewogICAgICByZXR1cm4gIiI7CiAgICB9CiAgfQogIGNvbnN0IHdvcmtlciA9IHNlbGY7CiAgd29ya2VyLm9ubWVzc2FnZSA9IGFzeW5jIGZ1bmN0aW9uKGUpIHsKICAgIGlmICgiT2Zmc2NyZWVuQ2FudmFzIiBpbiBnbG9iYWxUaGlzKSB7CiAgICAgIGNvbnN0IHsgaWQsIGJpdG1hcCwgd2lkdGgsIGhlaWdodCwgZGF0YVVSTE9wdGlvbnMgfSA9IGUuZGF0YTsKICAgICAgY29uc3QgdHJhbnNwYXJlbnRCYXNlNjQgPSBnZXRUcmFuc3BhcmVudEJsb2JGb3IoCiAgICAgICAgd2lkdGgsCiAgICAgICAgaGVpZ2h0LAogICAgICAgIGRhdGFVUkxPcHRpb25zCiAgICAgICk7CiAgICAgIGNvbnN0IG9mZnNjcmVlbiA9IG5ldyBPZmZzY3JlZW5DYW52YXMod2lkdGgsIGhlaWdodCk7CiAgICAgIGNvbnN0IGN0eCA9IG9mZnNjcmVlbi5nZXRDb250ZXh0KCIyZCIpOwogICAgICBjdHguZHJhd0ltYWdlKGJpdG1hcCwgMCwgMCk7CiAgICAgIGJpdG1hcC5jbG9zZSgpOwogICAgICBjb25zdCBibG9iID0gYXdhaXQgb2Zmc2NyZWVuLmNvbnZlcnRUb0Jsb2IoZGF0YVVSTE9wdGlvbnMpOwogICAgICBjb25zdCB0eXBlID0gYmxvYi50eXBlOwogICAgICBjb25zdCBhcnJheUJ1ZmZlciA9IGF3YWl0IGJsb2IuYXJyYXlCdWZmZXIoKTsKICAgICAgY29uc3QgYmFzZTY0ID0gZW5jb2RlKGFycmF5QnVmZmVyKTsKICAgICAgaWYgKCFsYXN0QmxvYk1hcC5oYXMoaWQpICYmIGF3YWl0IHRyYW5zcGFyZW50QmFzZTY0ID09PSBiYXNlNjQpIHsKICAgICAgICBsYXN0QmxvYk1hcC5zZXQoaWQsIGJhc2U2NCk7CiAgICAgICAgcmV0dXJuIHdvcmtlci5wb3N0TWVzc2FnZSh7IGlkIH0pOwogICAgICB9CiAgICAgIGlmIChsYXN0QmxvYk1hcC5nZXQoaWQpID09PSBiYXNlNjQpCiAgICAgICAgcmV0dXJuIHdvcmtlci5wb3N0TWVzc2FnZSh7IGlkIH0pOwogICAgICB3b3JrZXIucG9zdE1lc3NhZ2UoewogICAgICAgIGlkLAogICAgICAgIHR5cGUsCiAgICAgICAgYmFzZTY0LAogICAgICAgIHdpZHRoLAogICAgICAgIGhlaWdodAogICAgICB9KTsKICAgICAgbGFzdEJsb2JNYXAuc2V0KGlkLCBiYXNlNjQpOwogICAgfSBlbHNlIHsKICAgICAgcmV0dXJuIHdvcmtlci5wb3N0TWVzc2FnZSh7IGlkOiBlLmRhdGEuaWQgfSk7CiAgICB9CiAgfTsKfSkoKTsKLy8jIHNvdXJjZU1hcHBpbmdVUkw9aW1hZ2UtYml0bWFwLWRhdGEtdXJsLXdvcmtlci1CWjFyN1JKRC5qcy5tYXAK\";\nconst decodeBase64 = (base64) => Uint8Array.from(atob(base64), (c2) => c2.charCodeAt(0));\ntypeof window !== \"undefined\" && window.Blob && new Blob([decodeBase64(encodedJs)], { type: \"text/javascript;charset=utf-8\" });\ntry {\n if (Array.from([1], (x) => x * 2)[0] !== 2) {\n const cleanFrame = document.createElement(\"iframe\");\n document.body.appendChild(cleanFrame);\n Array.from = ((_a = cleanFrame.contentWindow) == null ? void 0 : _a.Array.from) || Array.from;\n document.body.removeChild(cleanFrame);\n }\n} catch (err) {\n console.debug(\"Unable to override Array.from\", err);\n}\ncreateMirror$2();\nvar n;\n!function(t2) {\n t2[t2.NotStarted = 0] = \"NotStarted\", t2[t2.Running = 1] = \"Running\", t2[t2.Stopped = 2] = \"Stopped\";\n}(n || (n = {}));\nclass StackFrame {\n constructor(obj) {\n __publicField(this, \"fileName\");\n __publicField(this, \"functionName\");\n __publicField(this, \"lineNumber\");\n __publicField(this, \"columnNumber\");\n this.fileName = obj.fileName || \"\";\n this.functionName = obj.functionName || \"\";\n this.lineNumber = obj.lineNumber;\n this.columnNumber = obj.columnNumber;\n }\n toString() {\n const lineNumber = this.lineNumber || \"\";\n const columnNumber = this.columnNumber || \"\";\n if (this.functionName)\n return `${this.functionName} (${this.fileName}:${lineNumber}:${columnNumber})`;\n return `${this.fileName}:${lineNumber}:${columnNumber}`;\n }\n}\nconst FIREFOX_SAFARI_STACK_REGEXP = /(^|@)\\S+:\\d+/;\nconst CHROME_IE_STACK_REGEXP = /^\\s*at .*(\\S+:\\d+|\\(native\\))/m;\nconst SAFARI_NATIVE_CODE_REGEXP = /^(eval@)?(\\[native code])?$/;\nconst ErrorStackParser = {\n /**\n * Given an Error object, extract the most information from it.\n */\n parse: function(error) {\n if (!error) {\n return [];\n }\n if (\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n typeof error.stacktrace !== \"undefined\" || // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n typeof error[\"opera#sourceloc\"] !== \"undefined\"\n ) {\n return this.parseOpera(\n error\n );\n } else if (error.stack && error.stack.match(CHROME_IE_STACK_REGEXP)) {\n return this.parseV8OrIE(error);\n } else if (error.stack) {\n return this.parseFFOrSafari(error);\n } else {\n console.warn(\n \"[console-record-plugin]: Failed to parse error object:\",\n error\n );\n return [];\n }\n },\n // Separate line and column numbers from a string of the form: (URI:Line:Column)\n extractLocation: function(urlLike) {\n if (urlLike.indexOf(\":\") === -1) {\n return [urlLike];\n }\n const regExp = /(.+?)(?::(\\d+))?(?::(\\d+))?$/;\n const parts = regExp.exec(urlLike.replace(/[()]/g, \"\"));\n if (!parts)\n throw new Error(`Cannot parse given url: ${urlLike}`);\n return [parts[1], parts[2] || void 0, parts[3] || void 0];\n },\n parseV8OrIE: function(error) {\n const filtered = error.stack.split(\"\\n\").filter(function(line) {\n return !!line.match(CHROME_IE_STACK_REGEXP);\n }, this);\n return filtered.map(function(line) {\n if (line.indexOf(\"(eval \") > -1) {\n line = line.replace(/eval code/g, \"eval\").replace(/(\\(eval at [^()]*)|(\\),.*$)/g, \"\");\n }\n let sanitizedLine = line.replace(/^\\s+/, \"\").replace(/\\(eval code/g, \"(\");\n const location = sanitizedLine.match(/ (\\((.+):(\\d+):(\\d+)\\)$)/);\n sanitizedLine = location ? sanitizedLine.replace(location[0], \"\") : sanitizedLine;\n const tokens = sanitizedLine.split(/\\s+/).slice(1);\n const locationParts = this.extractLocation(\n location ? location[1] : tokens.pop()\n );\n const functionName = tokens.join(\" \") || void 0;\n const fileName = [\"eval\", \"<anonymous>\"].indexOf(locationParts[0]) > -1 ? void 0 : locationParts[0];\n return new StackFrame({\n functionName,\n fileName,\n lineNumber: locationParts[1],\n columnNumber: locationParts[2]\n });\n }, this);\n },\n parseFFOrSafari: function(error) {\n const filtered = error.stack.split(\"\\n\").filter(function(line) {\n return !line.match(SAFARI_NATIVE_CODE_REGEXP);\n }, this);\n return filtered.map(function(line) {\n if (line.indexOf(\" > eval\") > -1) {\n line = line.replace(\n / line (\\d+)(?: > eval line \\d+)* > eval:\\d+:\\d+/g,\n \":$1\"\n );\n }\n if (line.indexOf(\"@\") === -1 && line.indexOf(\":\") === -1) {\n return new StackFrame({\n functionName: line\n });\n } else {\n const functionNameRegex = /((.*\".+\"[^@]*)?[^@]*)(?:@)/;\n const matches = line.match(functionNameRegex);\n const functionName = matches && matches[1] ? matches[1] : void 0;\n const locationParts = this.extractLocation(\n line.replace(functionNameRegex, \"\")\n );\n return new StackFrame({\n functionName,\n fileName: locationParts[0],\n lineNumber: locationParts[1],\n columnNumber: locationParts[2]\n });\n }\n }, this);\n },\n parseOpera: function(e) {\n if (!e.stacktrace || e.message.indexOf(\"\\n\") > -1 && e.message.split(\"\\n\").length > e.stacktrace.split(\"\\n\").length) {\n return this.parseOpera9(e);\n } else if (!e.stack) {\n return this.parseOpera10(e);\n } else {\n return this.parseOpera11(e);\n }\n },\n parseOpera9: function(e) {\n const lineRE = /Line (\\d+).*script (?:in )?(\\S+)/i;\n const lines = e.message.split(\"\\n\");\n const result = [];\n for (let i = 2, len = lines.length; i < len; i += 2) {\n const match = lineRE.exec(lines[i]);\n if (match) {\n result.push(\n new StackFrame({\n fileName: match[2],\n lineNumber: parseFloat(match[1])\n })\n );\n }\n }\n return result;\n },\n parseOpera10: function(e) {\n const lineRE = /Line (\\d+).*script (?:in )?(\\S+)(?:: In function (\\S+))?$/i;\n const lines = e.stacktrace.split(\"\\n\");\n const result = [];\n for (let i = 0, len = lines.length; i < len; i += 2) {\n const match = lineRE.exec(lines[i]);\n if (match) {\n result.push(\n new StackFrame({\n functionName: match[3] || void 0,\n fileName: match[2],\n lineNumber: parseFloat(match[1])\n })\n );\n }\n }\n return result;\n },\n // Opera 10.65+ Error.stack very similar to FF/Safari\n parseOpera11: function(error) {\n const filtered = error.stack.split(\"\\n\").filter(function(line) {\n return !!line.match(FIREFOX_SAFARI_STACK_REGEXP) && !line.match(/^Error created at/);\n }, this);\n return filtered.map(function(line) {\n const tokens = line.split(\"@\");\n const locationParts = this.extractLocation(tokens.pop());\n const functionCall = tokens.shift() || \"\";\n const functionName = functionCall.replace(/<anonymous function(: (\\w+))?>/, \"$2\").replace(/\\([^)]*\\)/g, \"\") || void 0;\n return new StackFrame({\n functionName,\n fileName: locationParts[0],\n lineNumber: locationParts[1],\n columnNumber: locationParts[2]\n });\n }, this);\n }\n};\nfunction pathToSelector(node) {\n if (!node || !node.outerHTML) {\n return \"\";\n }\n let path = \"\";\n while (node.parentElement) {\n let name = node.localName;\n if (!name) {\n break;\n }\n name = name.toLowerCase();\n const parent = node.parentElement;\n const domSiblings = [];\n if (parent.children && parent.children.length > 0) {\n for (let i = 0; i < parent.children.length; i++) {\n const sibling = parent.children[i];\n if (sibling.localName && sibling.localName.toLowerCase) {\n if (sibling.localName.toLowerCase() === name) {\n domSiblings.push(sibling);\n }\n }\n }\n }\n if (domSiblings.length > 1) {\n name += `:eq(${domSiblings.indexOf(node)})`;\n }\n path = name + (path ? \">\" + path : \"\");\n node = parent;\n }\n return path;\n}\nfunction isObject(obj) {\n return Object.prototype.toString.call(obj) === \"[object Object]\";\n}\nfunction isObjTooDeep(obj, limit) {\n if (limit === 0) {\n return true;\n }\n const keys = Object.keys(obj);\n for (const key of keys) {\n if (isObject(obj[key]) && isObjTooDeep(obj[key], limit - 1)) {\n return true;\n }\n }\n return false;\n}\nfunction stringify(obj, stringifyOptions) {\n const options = {\n numOfKeysLimit: 50,\n depthOfLimit: 4\n };\n Object.assign(options, stringifyOptions);\n const stack = [];\n const keys = [];\n return JSON.stringify(\n obj,\n function(key, value) {\n if (stack.length > 0) {\n const thisPos = stack.indexOf(this);\n ~thisPos ? stack.splice(thisPos + 1) : stack.push(this);\n ~thisPos ? keys.splice(thisPos, Infinity, key) : keys.push(key);\n if (~stack.indexOf(value)) {\n if (stack[0] === value) {\n value = \"[Circular ~]\";\n } else {\n value = \"[Circular ~.\" + keys.slice(0, stack.indexOf(value)).join(\".\") + \"]\";\n }\n }\n } else {\n stack.push(value);\n }\n if (value === null)\n return value;\n if (value === void 0)\n return \"undefined\";\n if (shouldIgnore(value)) {\n return toString(value);\n }\n if (typeof value === \"bigint\") {\n return value.toString() + \"n\";\n }\n if (value instanceof Event) {\n const eventResult = {};\n for (const eventKey in value) {\n const eventValue = value[eventKey];\n if (Array.isArray(eventValue)) {\n eventResult[eventKey] = pathToSelector(\n eventValue.length ? eventValue[0] : null\n );\n } else {\n eventResult[eventKey] = eventValue;\n }\n }\n return eventResult;\n } else if (value instanceof Node) {\n if (value instanceof HTMLElement) {\n return value ? value.outerHTML : \"\";\n }\n return value.nodeName;\n } else if (value instanceof Error) {\n return value.stack ? value.stack + \"\\nEnd of stack for Error object\" : value.name + \": \" + value.message;\n }\n return value;\n }\n );\n function shouldIgnore(_obj) {\n if (isObject(_obj) && Object.keys(_obj).length > options.numOfKeysLimit) {\n return true;\n }\n if (typeof _obj === \"function\") {\n return true;\n }\n if (isObject(_obj) && isObjTooDeep(_obj, options.depthOfLimit)) {\n return true;\n }\n return false;\n }\n function toString(_obj) {\n let str = _obj.toString();\n if (options.stringLengthLimit && str.length > options.stringLengthLimit) {\n str = `${str.slice(0, options.stringLengthLimit)}...`;\n }\n return str;\n }\n}\nconst defaultLogOptions = {\n level: [\n \"assert\",\n \"clear\",\n \"count\",\n \"countReset\",\n \"debug\",\n \"dir\",\n \"dirxml\",\n \"error\",\n \"group\",\n \"groupCollapsed\",\n \"groupEnd\",\n \"info\",\n \"log\",\n \"table\",\n \"time\",\n \"timeEnd\",\n \"timeLog\",\n \"trace\",\n \"warn\"\n ],\n lengthThreshold: 1e3,\n logger: \"console\"\n};\nfunction initLogObserver(cb, win, options) {\n const logOptions = options ? Object.assign({}, defaultLogOptions, options) : defaultLogOptions;\n const loggerType = logOptions.logger;\n if (!loggerType) {\n return () => {\n };\n }\n let logger;\n if (typeof loggerType === \"string\") {\n logger = win[loggerType];\n } else {\n logger = loggerType;\n }\n let logCount = 0;\n let inStack = false;\n const cancelHandlers = [];\n if (logOptions.level.includes(\"error\")) {\n const errorHandler = (event) => {\n const message = event.message, error = event.error;\n const trace = ErrorStackParser.parse(error).map(\n (stackFrame) => stackFrame.toString()\n );\n const payload = [stringify(message, logOptions.stringifyOptions)];\n cb({\n level: \"error\",\n trace,\n payload\n });\n };\n win.addEventListener(\"error\", errorHandler);\n cancelHandlers.push(() => {\n win.removeEventListener(\"error\", errorHandler);\n });\n const unhandledrejectionHandler = (event) => {\n let error;\n let payload;\n if (event.reason instanceof Error) {\n error = event.reason;\n payload = [\n stringify(\n `Uncaught (in promise) ${error.name}: ${error.message}`,\n logOptions.stringifyOptions\n )\n ];\n } else {\n error = new Error();\n payload = [\n stringify(\"Uncaught (in promise)\", logOptions.stringifyOptions),\n stringify(event.reason, logOptions.stringifyOptions)\n ];\n }\n const trace = ErrorStackParser.parse(error).map(\n (stackFrame) => stackFrame.toString()\n );\n cb({\n level: \"error\",\n trace,\n payload\n });\n };\n win.addEventListener(\"unhandledrejection\", unhandledrejectionHandler);\n cancelHandlers.push(() => {\n win.removeEventListener(\"unhandledrejection\", unhandledrejectionHandler);\n });\n }\n for (const levelType of logOptions.level) {\n cancelHandlers.push(replace(logger, levelType));\n }\n return () => {\n cancelHandlers.forEach((h) => h());\n };\n function replace(_logger, level) {\n if (!_logger[level]) {\n return () => {\n };\n }\n return utils.patch(\n _logger,\n level,\n (original) => {\n return (...args) => {\n original.apply(this, args);\n if (inStack) {\n return;\n }\n inStack = true;\n try {\n const trace = ErrorStackParser.parse(new Error()).map((stackFrame) => stackFrame.toString()).splice(1);\n const payload = args.map(\n (s) => stringify(s, logOptions.stringifyOptions)\n );\n logCount++;\n if (logCount < logOptions.lengthThreshold) {\n cb({\n level,\n trace,\n payload\n });\n } else if (logCount === logOptions.lengthThreshold) {\n cb({\n level: \"warn\",\n trace: [],\n payload: [\n stringify(\"The number of log records reached the threshold.\")\n ]\n });\n }\n } catch (error) {\n original(\"rrweb logger error:\", error, ...args);\n } finally {\n inStack = false;\n }\n };\n }\n );\n }\n}\nconst PLUGIN_NAME = \"rrweb/console@1\";\nconst getRecordConsolePlugin = (options) => ({\n name: PLUGIN_NAME,\n observer: initLogObserver,\n options\n});\nexport {\n PLUGIN_NAME,\n getRecordConsolePlugin\n};\n//# sourceMappingURL=rrweb-plugin-console-record.js.map\n","// eslint-disable-next-line posthog-js/no-direct-array-check\nconst nativeIsArray = Array.isArray\nconst ObjProto = Object.prototype\nexport const hasOwnProperty = ObjProto.hasOwnProperty\nconst toString = ObjProto.toString\n\nexport const isArray =\n nativeIsArray ||\n function (obj: any): obj is any[] {\n return toString.call(obj) === '[object Array]'\n }\nexport const isUint8Array = function (x: unknown): x is Uint8Array {\n return toString.call(x) === '[object Uint8Array]'\n}\n// from a comment on http://dbj.org/dbj/?p=286\n// fails on only one very rare and deliberate custom object:\n// let bomb = { toString : undefined, valueOf: function(o) { return \"function BOMBA!\"; }};\nexport const isFunction = function (f: any): f is (...args: any[]) => any {\n // eslint-disable-next-line posthog-js/no-direct-function-check\n return typeof f === 'function'\n}\n// Underscore Addons\nexport const isObject = function (x: unknown): x is Record<string, any> {\n // eslint-disable-next-line posthog-js/no-direct-object-check\n return x === Object(x) && !isArray(x)\n}\nexport const isEmptyObject = function (x: unknown): x is Record<string, any> {\n if (isObject(x)) {\n for (const key in x) {\n if (hasOwnProperty.call(x, key)) {\n return false\n }\n }\n return true\n }\n return false\n}\nexport const isUndefined = function (x: unknown): x is undefined {\n return x === void 0\n}\n\nexport const isString = function (x: unknown): x is string {\n // eslint-disable-next-line posthog-js/no-direct-string-check\n return toString.call(x) == '[object String]'\n}\n\nexport const isEmptyString = function (x: unknown): boolean {\n return isString(x) && x.trim().length === 0\n}\n\nexport const isNull = function (x: unknown): x is null {\n // eslint-disable-next-line posthog-js/no-direct-null-check\n return x === null\n}\n\n/*\n sometimes you want to check if something is null or undefined\n that's what this is for\n */\nexport const isNullish = function (x: unknown): x is null | undefined {\n return isUndefined(x) || isNull(x)\n}\n\nexport const isDate = function (x: unknown): x is Date {\n // eslint-disable-next-line posthog-js/no-direct-date-check\n return toString.call(x) == '[object Date]'\n}\nexport const isNumber = function (x: unknown): x is number {\n // eslint-disable-next-line posthog-js/no-direct-number-check\n return toString.call(x) == '[object Number]'\n}\nexport const isBoolean = function (x: unknown): x is boolean {\n // eslint-disable-next-line posthog-js/no-direct-boolean-check\n return toString.call(x) === '[object Boolean]'\n}\n\nexport const isDocument = (x: unknown): x is Document => {\n // eslint-disable-next-line posthog-js/no-direct-document-check\n return x instanceof Document\n}\n\nexport const isFormData = (x: unknown): x is FormData => {\n // eslint-disable-next-line posthog-js/no-direct-form-data-check\n return x instanceof FormData\n}\n\nexport const isFile = (x: unknown): x is File => {\n // eslint-disable-next-line posthog-js/no-direct-file-check\n return x instanceof File\n}\n","import { ErrorProperties } from '../extensions/exception-autocapture/error-conversion'\nimport type { PostHog } from '../posthog-core'\nimport { SessionIdManager } from '../sessionid'\nimport { ErrorEventArgs, ErrorMetadata, Properties } from '../types'\n\n/*\n * Global helpers to protect access to browser globals in a way that is safer for different targets\n * like DOM, SSR, Web workers etc.\n *\n * NOTE: Typically we want the \"window\" but globalThis works for both the typical browser context as\n * well as other contexts such as the web worker context. Window is still exported for any bits that explicitly require it.\n * If in doubt - export the global you need from this file and use that as an optional value. This way the code path is forced\n * to handle the case where the global is not available.\n */\n\n// eslint-disable-next-line no-restricted-globals\nconst win: (Window & typeof globalThis) | undefined = typeof window !== 'undefined' ? window : undefined\n\n/**\n * This is our contract between (potentially) lazily loaded extensions and the SDK\n * changes to this interface can be breaking changes for users of the SDK\n */\n\nexport type PostHogExtensionKind =\n | 'toolbar'\n | 'exception-autocapture'\n | 'web-vitals'\n | 'recorder'\n | 'tracing-headers'\n | 'surveys'\n\ninterface PostHogExtensions {\n loadExternalDependency?: (\n posthog: PostHog,\n kind: PostHogExtensionKind,\n callback: (error?: string | Event, event?: Event) => void\n ) => void\n\n loadSiteApp?: (posthog: PostHog, appUrl: string, callback: (error?: string | Event, event?: Event) => void) => void\n\n parseErrorAsProperties?: (\n [event, source, lineno, colno, error]: ErrorEventArgs,\n metadata?: ErrorMetadata\n ) => ErrorProperties\n errorWrappingFunctions?: {\n wrapOnError: (captureFn: (props: Properties) => void) => () => void\n wrapUnhandledRejection: (captureFn: (props: Properties) => void) => () => void\n }\n rrweb?: { record: any; version: string; rrwebVersion: string }\n rrwebPlugins?: { getRecordConsolePlugin: any; getRecordNetworkPlugin?: any }\n canActivateRepeatedly?: (survey: any) => boolean\n generateSurveys?: (posthog: PostHog) => any | undefined\n postHogWebVitalsCallbacks?: {\n onLCP: (metric: any) => void\n onCLS: (metric: any) => void\n onFCP: (metric: any) => void\n onINP: (metric: any) => void\n }\n tracingHeadersPatchFns?: {\n _patchFetch: (sessionManager: SessionIdManager) => () => void\n _patchXHR: (sessionManager: any) => () => void\n }\n}\n\nconst global: typeof globalThis | undefined = typeof globalThis !== 'undefined' ? globalThis : win\n\nexport const ArrayProto = Array.prototype\nexport const nativeForEach = ArrayProto.forEach\nexport const nativeIndexOf = ArrayProto.indexOf\n\nexport const navigator = global?.navigator\nexport const document = global?.document\nexport const location = global?.location\nexport const fetch = global?.fetch\nexport const XMLHttpRequest =\n global?.XMLHttpRequest && 'withCredentials' in new global.XMLHttpRequest() ? global.XMLHttpRequest : undefined\nexport const AbortController = global?.AbortController\nexport const userAgent = navigator?.userAgent\nexport const assignableWindow: Window &\n typeof globalThis &\n Record<string, any> & {\n __PosthogExtensions__?: PostHogExtensions\n } = win ?? ({} as any)\n\nexport { win as window }\n","import Config from '../config'\nimport { isUndefined } from './type-utils'\nimport { assignableWindow, window } from './globals'\n\nconst LOGGER_PREFIX = '[PostHog.js]'\nexport const logger = {\n _log: (level: 'log' | 'warn' | 'error', ...args: any[]) => {\n if (\n window &&\n (Config.DEBUG || assignableWindow.POSTHOG_DEBUG) &&\n !isUndefined(window.console) &&\n window.console\n ) {\n const consoleLog =\n '__rrweb_original__' in window.console[level]\n ? (window.console[level] as any)['__rrweb_original__']\n : window.console[level]\n\n // eslint-disable-next-line no-console\n consoleLog(LOGGER_PREFIX, ...args)\n }\n },\n\n info: (...args: any[]) => {\n logger._log('log', ...args)\n },\n\n warn: (...args: any[]) => {\n logger._log('warn', ...args)\n },\n\n error: (...args: any[]) => {\n logger._log('error', ...args)\n },\n\n critical: (...args: any[]) => {\n // Critical errors are always logged to the console\n // eslint-disable-next-line no-console\n console.error(LOGGER_PREFIX, ...args)\n },\n\n uninitializedWarning: (methodName: string) => {\n logger.error(`You must initialize PostHog before calling ${methodName}`)\n },\n}\n","import { Breaker, EventHandler, Properties } from '../types'\nimport { isArray, isFormData, isFunction, isNull, isNullish, isString, hasOwnProperty } from './type-utils'\nimport { logger } from './logger'\nimport { window, nativeForEach, nativeIndexOf } from './globals'\n\nconst breaker: Breaker = {}\n\n// UNDERSCORE\n// Embed part of the Underscore Library\nexport const trim = function (str: string): string {\n return str.replace(/^[\\s\\uFEFF\\xA0]+|[\\s\\uFEFF\\xA0]+$/g, '')\n}\n\nexport function eachArray<E = any>(\n obj: E[] | null | undefined,\n iterator: (value: E, key: number) => void | Breaker,\n thisArg?: any\n): void {\n if (isArray(obj)) {\n if (nativeForEach && obj.forEach === nativeForEach) {\n obj.forEach(iterator, thisArg)\n } else if ('length' in obj && obj.length === +obj.length) {\n for (let i = 0, l = obj.length; i < l; i++) {\n if (i in obj && iterator.call(thisArg, obj[i], i) === breaker) {\n return\n }\n }\n }\n }\n}\n\n/**\n * @param {*=} obj\n * @param {function(...*)=} iterator\n * @param {Object=} thisArg\n */\nexport function each(obj: any, iterator: (value: any, key: any) => void | Breaker, thisArg?: any): void {\n if (isNullish(obj)) {\n return\n }\n if (isArray(obj)) {\n return eachArray(obj, iterator, thisArg)\n }\n if (isFormData(obj)) {\n for (const pair of obj.entries()) {\n if (iterator.call(thisArg, pair[1], pair[0]) === breaker) {\n return\n }\n }\n return\n }\n for (const key in obj) {\n if (hasOwnProperty.call(obj, key)) {\n if (iterator.call(thisArg, obj[key], key) === breaker) {\n return\n }\n }\n }\n}\n\nexport const extend = function (obj: Record<string, any>, ...args: Record<string, any>[]): Record<string, any> {\n eachArray(args, function (source) {\n for (const prop in source) {\n if (source[prop] !== void 0) {\n obj[prop] = source[prop]\n }\n }\n })\n return obj\n}\n\nexport const include = function (\n obj: null | string | Array<any> | Record<string, any>,\n target: any\n): boolean | Breaker {\n let found = false\n if (isNull(obj)) {\n return found\n }\n if (nativeIndexOf && obj.indexOf === nativeIndexOf) {\n return obj.indexOf(target) != -1\n }\n each(obj, function (value) {\n if (found || (found = value === target)) {\n return breaker\n }\n return\n })\n return found\n}\n\nexport function includes<T = any>(str: T[] | string, needle: T): boolean {\n return (str as any).indexOf(needle) !== -1\n}\n\n/**\n * Object.entries() polyfill\n * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/entries\n */\nexport function entries<T = any>(obj: Record<string, T>): [string, T][] {\n const ownProps = Object.keys(obj)\n let i = ownProps.length\n const resArray = new Array(i) // preallocate the Array\n\n while (i--) {\n resArray[i] = [ownProps[i], obj[ownProps[i]]]\n }\n return resArray\n}\n\nexport const isValidRegex = function (str: string): boolean {\n try {\n new RegExp(str)\n } catch {\n return false\n }\n return true\n}\n\nexport const trySafe = function <T>(fn: () => T): T | undefined {\n try {\n return fn()\n } catch {\n return undefined\n }\n}\n\nexport const safewrap = function <F extends (...args: any[]) => any = (...args: any[]) => any>(f: F): F {\n return function (...args) {\n try {\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n return f.apply(this, args)\n } catch (e) {\n logger.critical(\n 'Implementation error. Please turn on debug mode and open a ticket on https://app.posthog.com/home#panel=support%3Asupport%3A.'\n )\n logger.critical(e)\n }\n } as F\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unsafe-function-type\nexport const safewrapClass = function (klass: Function, functions: string[]): void {\n for (let i = 0; i < functions.length; i++) {\n klass.prototype[functions[i]] = safewrap(klass.prototype[functions[i]])\n }\n}\n\nexport const stripEmptyProperties = function (p: Properties): Properties {\n const ret: Properties = {}\n each(p, function (v, k) {\n if (isString(v) && v.length > 0) {\n ret[k] = v\n }\n })\n return ret\n}\n\nexport const stripLeadingDollar = function (s: string): string {\n return s.replace(/^\\$/, '')\n}\n\n/**\n * Deep copies an object.\n * It handles cycles by replacing all references to them with `undefined`\n * Also supports customizing native values\n *\n * @param value\n * @param customizer\n * @returns {{}|undefined|*}\n */\nfunction deepCircularCopy<T extends Record<string, any> = Record<string, any>>(\n value: T,\n customizer?: <K extends keyof T = keyof T>(value: T[K], key?: K) => T[K]\n): T | undefined {\n const COPY_IN_PROGRESS_SET = new Set()\n\n function internalDeepCircularCopy(value: T, key?: string): T | undefined {\n if (value !== Object(value)) return customizer ? customizer(value as any, key) : value // primitive value\n\n if (COPY_IN_PROGRESS_SET.has(value)) return undefined\n COPY_IN_PROGRESS_SET.add(value)\n let result: T\n\n if (isArray(value)) {\n result = [] as any as T\n eachArray(value, (it) => {\n result.push(internalDeepCircularCopy(it))\n })\n } else {\n result = {} as T\n each(value, (val, key) => {\n if (!COPY_IN_PROGRESS_SET.has(val)) {\n ;(result as any)[key] = internalDeepCircularCopy(val, key)\n }\n })\n }\n return result\n }\n return internalDeepCircularCopy(value)\n}\n\nexport function _copyAndTruncateStrings<T extends Record<string, any> = Record<string, any>>(\n object: T,\n maxStringLength: number | null\n): T {\n return deepCircularCopy(object, (value: any) => {\n if (isString(value) && !isNull(maxStringLength)) {\n return (value as string).slice(0, maxStringLength)\n }\n return value\n }) as T\n}\n\nexport function _base64Encode(data: null): null\nexport function _base64Encode(data: undefined): undefined\nexport function _base64Encode(data: string): string\nexport function _base64Encode(data: string | null | undefined): string | null | undefined {\n const b64 = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/='\n let o1,\n o2,\n o3,\n h1,\n h2,\n h3,\n h4,\n bits,\n i = 0,\n ac = 0,\n enc = ''\n const tmp_arr: string[] = []\n\n if (!data) {\n return data\n }\n\n data = utf8Encode(data)\n\n do {\n // pack three octets into four hexets\n o1 = data.charCodeAt(i++)\n o2 = data.charCodeAt(i++)\n o3 = data.charCodeAt(i++)\n\n bits = (o1 << 16) | (o2 << 8) | o3\n\n h1 = (bits >> 18) & 0x3f\n h2 = (bits >> 12) & 0x3f\n h3 = (bits >> 6) & 0x3f\n h4 = bits & 0x3f\n\n // use hexets to index into b64, and append result to encoded string\n tmp_arr[ac++] = b64.charAt(h1) + b64.charAt(h2) + b64.charAt(h3) + b64.charAt(h4)\n } while (i < data.length)\n\n enc = tmp_arr.join('')\n\n switch (data.length % 3) {\n case 1:\n enc = enc.slice(0, -2) + '=='\n break\n case 2:\n enc = enc.slice(0, -1) + '='\n break\n }\n\n return enc\n}\n\nexport const utf8Encode = function (string: string): string {\n string = (string + '').replace(/\\r\\n/g, '\\n').replace(/\\r/g, '\\n')\n\n let utftext = '',\n start,\n end\n let stringl = 0,\n n\n\n start = end = 0\n stringl = string.length\n\n for (n = 0; n < stringl; n++) {\n const c1 = string.charCodeAt(n)\n let enc = null\n\n if (c1 < 128) {\n end++\n } else if (c1 > 127 && c1 < 2048) {\n enc = String.fromCharCode((c1 >> 6) | 192, (c1 & 63) | 128)\n } else {\n enc = String.fromCharCode((c1 >> 12) | 224, ((c1 >> 6) & 63) | 128, (c1 & 63) | 128)\n }\n if (!isNull(enc)) {\n if (end > start) {\n utftext += string.substring(start, end)\n }\n utftext += enc\n start = end = n + 1\n }\n }\n\n if (end > start) {\n utftext += string.substring(start, string.length)\n }\n\n return utftext\n}\n\nexport const registerEvent = (function () {\n // written by Dean Edwards, 2005\n // with input from Tino Zijdel - crisp@xs4all.nl\n // with input from Carl Sverre - mail@carlsverre.com\n // with input from PostHog\n // http://dean.edwards.name/weblog/2005/10/add-event/\n // https://gist.github.com/1930440\n\n /**\n * @param {Object} element\n * @param {string} type\n * @param {function(...*)} handler\n * @param {boolean=} oldSchool\n * @param {boolean=} useCapture\n */\n const register_event = function (\n element: Element | Window | Document | Node,\n type: string,\n handler: EventHandler,\n oldSchool?: boolean,\n useCapture?: boolean\n ) {\n if (!element) {\n logger.error('No valid element provided to register_event')\n return\n }\n\n if (element.addEventListener && !oldSchool) {\n element.addEventListener(type, handler, !!useCapture)\n } else {\n const ontype = 'on' + type\n const old_handler = (element as any)[ontype] // can be undefined\n ;(element as any)[ontype] = makeHandler(element, handler, old_handler)\n }\n }\n\n function makeHandler(\n element: Element | Window | Document | Node,\n new_handler: EventHandler,\n old_handlers: EventHandler\n ) {\n return function (event: Event): boolean | void {\n event = event || fixEvent(window?.event)\n\n // this basically happens in firefox whenever another script\n // overwrites the onload callback and doesn't pass the event\n // object to previously defined callbacks. All the browsers\n // that don't define window.event implement addEventListener\n // so the dom_loaded handler will still be fired as usual.\n if (!event) {\n return undefined\n }\n\n let ret = true\n let old_result: any\n\n if (isFunction(old_handlers)) {\n old_result = old_handlers(event)\n }\n const new_result = new_handler.call(element, event)\n\n if (false === old_result || false === new_result) {\n ret = false\n }\n\n return ret\n }\n }\n\n function fixEvent(event: Event | undefined): Event | undefined {\n if (event) {\n event.preventDefault = fixEvent.preventDefault\n event.stopPropagation = fixEvent.stopPropagation\n }\n return event\n }\n fixEvent.preventDefault = function () {\n ;(this as any as Event).returnValue = false\n }\n fixEvent.stopPropagation = function () {\n ;(this as any as Event).cancelBubble = true\n }\n\n return register_event\n})()\n\nexport function isCrossDomainCookie(documentLocation: Location | undefined) {\n const hostname = documentLocation?.hostname\n\n if (!isString(hostname)) {\n return false\n }\n // split and slice isn't a great way to match arbitrary domains,\n // but it's good enough for ensuring we only match herokuapp.com when it is the TLD\n // for the hostname\n return hostname.split('.').slice(-2).join('.') !== 'herokuapp.com'\n}\n\nexport function isDistinctIdStringLike(value: string): boolean {\n return ['distinct_id', 'distinctid'].includes(value.toLowerCase())\n}\n\nexport function find<T>(value: T[], predicate: (value: T) => boolean): T | undefined {\n for (let i = 0; i < value.length; i++) {\n if (predicate(value[i])) {\n return value[i]\n }\n }\n return undefined\n}\n","import { each, isValidRegex } from './'\n\nimport { isArray, isFile, isUndefined } from './type-utils'\nimport { logger } from './logger'\nimport { document } from './globals'\n\nconst localDomains = ['localhost', '127.0.0.1']\n\n/**\n * IE11 doesn't support `new URL`\n * so we can create an anchor element and use that to parse the URL\n * there's a lot of overlap between HTMLHyperlinkElementUtils and URL\n * meaning useful properties like `pathname` are available on both\n */\nexport const convertToURL = (url: string): HTMLAnchorElement | null => {\n const location = document?.createElement('a')\n if (isUndefined(location)) {\n return null\n }\n\n location.href = url\n return location\n}\n\nexport const isUrlMatchingRegex = function (url: string, pattern: string): boolean {\n if (!isValidRegex(pattern)) return false\n return new RegExp(pattern).test(url)\n}\n\nexport const formDataToQuery = function (formdata: Record<string, any> | FormData, arg_separator = '&'): string {\n let use_val: string\n let use_key: string\n const tph_arr: string[] = []\n\n each(formdata, function (val: File | string | undefined, key: string | undefined) {\n // the key might be literally the string undefined for e.g. if {undefined: 'something'}\n if (isUndefined(val) || isUndefined(key) || key === 'undefined') {\n return\n }\n\n use_val = encodeURIComponent(isFile(val) ? val.name : val.toString())\n use_key = encodeURIComponent(key)\n tph_arr[tph_arr.length] = use_key + '=' + use_val\n })\n\n return tph_arr.join(arg_separator)\n}\n\nexport const getQueryParam = function (url: string, param: string): string {\n const withoutHash: string = url.split('#')[0] || ''\n const queryParams: string = withoutHash.split('?')[1] || ''\n\n const queryParts = queryParams.split('&')\n let keyValuePair\n\n for (let i = 0; i < queryParts.length; i++) {\n const parts = queryParts[i].split('=')\n if (parts[0] === param) {\n keyValuePair = parts\n break\n }\n }\n\n if (!isArray(keyValuePair) || keyValuePair.length < 2) {\n return ''\n } else {\n let result = keyValuePair[1]\n try {\n result = decodeURIComponent(result)\n } catch {\n logger.error('Skipping decoding for malformed query param: ' + result)\n }\n return result.replace(/\\+/g, ' ')\n }\n}\n\nexport const _getHashParam = function (hash: string, param: string): string | null {\n const matches = hash.match(new RegExp(param + '=([^&]*)'))\n return matches ? matches[1] : null\n}\n\nexport const isLocalhost = (): boolean => {\n return localDomains.includes(location.hostname)\n}\n","import { CapturedNetworkRequest, NetworkRecordOptions, PostHogConfig } from '../../types'\nimport { isFunction, isNullish, isString, isUndefined } from '../../utils/type-utils'\nimport { convertToURL } from '../../utils/request-utils'\nimport { logger } from '../../utils/logger'\nimport { shouldCaptureValue } from '../../autocapture-utils'\nimport { each } from '../../utils'\n\nconst LOGGER_PREFIX = '[SessionRecording]'\nconst REDACTED = 'redacted'\n\nexport const defaultNetworkOptions: Required<NetworkRecordOptions> = {\n initiatorTypes: [\n 'audio',\n 'beacon',\n 'body',\n 'css',\n 'early-hint',\n 'embed',\n 'fetch',\n 'frame',\n 'iframe',\n 'icon',\n 'image',\n 'img',\n 'input',\n 'link',\n 'navigation',\n 'object',\n 'ping',\n 'script',\n 'track',\n 'video',\n 'xmlhttprequest',\n ],\n maskRequestFn: (data: CapturedNetworkRequest) => data,\n recordHeaders: false,\n recordBody: false,\n recordInitialRequests: false,\n recordPerformance: false,\n performanceEntryTypeToObserve: [\n // 'event', // This is too noisy as it covers all browser events\n 'first-input',\n // 'mark', // Mark is used too liberally. We would need to filter for specific marks\n // 'measure', // Measure is used too liberally. We would need to filter for specific measures\n 'navigation',\n 'paint',\n 'resource',\n ],\n payloadSizeLimitBytes: 1000000,\n payloadHostDenyList: ['.lr-ingest.io', '.ingest.sentry.io'],\n}\n\nconst HEADER_DENY_LIST = [\n 'authorization',\n 'x-forwarded-for',\n 'authorization',\n 'cookie',\n 'set-cookie',\n 'x-api-key',\n 'x-real-ip',\n 'remote-addr',\n 'forwarded',\n 'proxy-authorization',\n 'x-csrf-token',\n 'x-csrftoken',\n 'x-xsrf-token',\n]\n\nconst PAYLOAD_CONTENT_DENY_LIST = [\n 'password',\n 'secret',\n 'passwd',\n 'api_key',\n 'apikey',\n 'auth',\n 'credentials',\n 'mysql_pwd',\n 'privatekey',\n 'private_key',\n 'token',\n]\n\n// we always remove headers on the deny list because we never want to capture this sensitive data\nconst removeAuthorizationHeader = (data: CapturedNetworkRequest): CapturedNetworkRequest => {\n const headers = data.requestHeaders\n if (!isNullish(headers)) {\n each(Object.keys(headers ?? {}), (header) => {\n if (HEADER_DENY_LIST.includes(header.toLowerCase())) {\n headers[header] = REDACTED\n }\n })\n }\n return data\n}\n\nconst POSTHOG_PATHS_TO_IGNORE = ['/s/', '/e/', '/i/']\n// want to ignore posthog paths when capturing requests, or we can get trapped in a loop\n// because calls to PostHog would be reported using a call to PostHog which would be reported....\nconst ignorePostHogPaths = (data: CapturedNetworkRequest): CapturedNetworkRequest | undefined => {\n const url = convertToURL(data.name)\n if (url && url.pathname && POSTHOG_PATHS_TO_IGNORE.some((path) => url.pathname.indexOf(path) === 0)) {\n return undefined\n }\n return data\n}\n\nfunction estimateBytes(payload: string): number {\n return new Blob([payload]).size\n}\n\nfunction enforcePayloadSizeLimit(\n payload: string | null | undefined,\n headers: Record<string, any> | undefined,\n limit: number,\n description: string\n): string | null | undefined {\n if (isNullish(payload)) {\n return payload\n }\n\n let requestContentLength: string | number = headers?.['content-length'] || estimateBytes(payload)\n if (isString(requestContentLength)) {\n requestContentLength = parseInt(requestContentLength)\n }\n\n if (requestContentLength > limit) {\n return LOGGER_PREFIX + ` ${description} body too large to record (${requestContentLength} bytes)`\n }\n\n return payload\n}\n\n// people can have arbitrarily large payloads on their site, but we don't want to ingest them\nconst limitPayloadSize = (\n options: NetworkRecordOptions\n): ((data: CapturedNetworkRequest | undefined) => CapturedNetworkRequest | undefined) => {\n // the smallest of 1MB or the specified limit if there is one\n const limit = Math.min(1000000, options.payloadSizeLimitBytes ?? 1000000)\n\n return (data) => {\n if (data?.requestBody) {\n data.requestBody = enforcePayloadSizeLimit(data.requestBody, data.requestHeaders, limit, 'Request')\n }\n\n if (data?.responseBody) {\n data.responseBody = enforcePayloadSizeLimit(data.responseBody, data.responseHeaders, limit, 'Response')\n }\n\n return data\n }\n}\n\nfunction scrubPayload(payload: string | null | undefined, label: 'Request' | 'Response'): string | null | undefined {\n if (isNullish(payload)) {\n return payload\n }\n let scrubbed = payload\n\n if (!shouldCaptureValue(scrubbed, false)) {\n scrubbed = LOGGER_PREFIX + ' ' + label + ' body ' + REDACTED\n }\n each(PAYLOAD_CONTENT_DENY_LIST, (text) => {\n if (scrubbed?.length && scrubbed?.indexOf(text) !== -1) {\n scrubbed = LOGGER_PREFIX + ' ' + label + ' body ' + REDACTED + ' as might contain: ' + text\n }\n })\n\n return scrubbed\n}\n\nfunction scrubPayloads(capturedRequest: CapturedNetworkRequest | undefined): CapturedNetworkRequest | undefined {\n if (isUndefined(capturedRequest)) {\n return undefined\n }\n\n capturedRequest.requestBody = scrubPayload(capturedRequest.requestBody, 'Request')\n capturedRequest.responseBody = scrubPayload(capturedRequest.responseBody, 'Response')\n\n return capturedRequest\n}\n\n/**\n * whether a maskRequestFn is provided or not,\n * we ensure that we remove the denied header from requests\n * we _never_ want to record that header by accident\n * if someone complains then we'll add an opt-in to let them override it\n */\nexport const buildNetworkRequestOptions = (\n instanceConfig: PostHogConfig,\n remoteNetworkOptions: Pick<\n NetworkRecordOptions,\n 'recordHeaders' | 'recordBody' | 'recordPerformance' | 'payloadHostDenyList'\n >\n): NetworkRecordOptions => {\n const config: NetworkRecordOptions = {\n payloadSizeLimitBytes: defaultNetworkOptions.payloadSizeLimitBytes,\n performanceEntryTypeToObserve: [...defaultNetworkOptions.performanceEntryTypeToObserve],\n payloadHostDenyList: [\n ...(remoteNetworkOptions.payloadHostDenyList || []),\n ...defaultNetworkOptions.payloadHostDenyList,\n ],\n }\n // client can always disable despite remote options\n const canRecordHeaders =\n instanceConfig.session_recording.recordHeaders === false ? false : remoteNetworkOptions.recordHeaders\n const canRecordBody =\n instanceConfig.session_recording.recordBody === false ? false : remoteNetworkOptions.recordBody\n const canRecordPerformance =\n instanceConfig.capture_performance === false ? false : remoteNetworkOptions.recordPerformance\n\n const payloadLimiter = limitPayloadSize(config)\n\n const enforcedCleaningFn: NetworkRecordOptions['maskRequestFn'] = (d: CapturedNetworkRequest) =>\n payloadLimiter(ignorePostHogPaths(removeAuthorizationHeader(d)))\n\n const hasDeprecatedMaskFunction = isFunction(instanceConfig.session_recording.maskNetworkRequestFn)\n\n if (hasDeprecatedMaskFunction && isFunction(instanceConfig.session_recording.maskCapturedNetworkRequestFn)) {\n logger.warn(\n 'Both `maskNetworkRequestFn` and `maskCapturedNetworkRequestFn` are defined. `maskNetworkRequestFn` will be ignored.'\n )\n }\n\n if (hasDeprecatedMaskFunction) {\n instanceConfig.session_recording.maskCapturedNetworkRequestFn = (data: CapturedNetworkRequest) => {\n const cleanedURL = instanceConfig.session_recording.maskNetworkRequestFn!({ url: data.name })\n return {\n ...data,\n name: cleanedURL?.url,\n } as CapturedNetworkRequest\n }\n }\n\n config.maskRequestFn = isFunction(instanceConfig.session_recording.maskCapturedNetworkRequestFn)\n ? (data) => {\n const cleanedRequest = enforcedCleaningFn(data)\n return cleanedRequest\n ? instanceConfig.session_recording.maskCapturedNetworkRequestFn?.(cleanedRequest) ?? undefined\n : undefined\n }\n : (data) => scrubPayloads(enforcedCleaningFn(data))\n\n return {\n ...defaultNetworkOptions,\n ...config,\n recordHeaders: canRecordHeaders,\n recordBody: canRecordBody,\n recordPerformance: canRecordPerformance,\n recordInitialRequests: canRecordPerformance,\n }\n}\n","// import { patch } from 'rrweb/typings/utils'\n// copied from https://github.com/rrweb-io/rrweb/blob/8aea5b00a4dfe5a6f59bd2ae72bb624f45e51e81/packages/rrweb/src/utils.ts#L129\n// which was copied from https://github.com/getsentry/sentry-javascript/blob/b2109071975af8bf0316d3b5b38f519bdaf5dc15/packages/utils/src/object.ts\nimport { isFunction } from '../../../utils/type-utils'\n\nexport function patch(\n source: { [key: string]: any },\n name: string,\n replacement: (...args: unknown[]) => unknown\n): () => void {\n try {\n if (!(name in source)) {\n return () => {\n //\n }\n }\n\n const original = source[name] as () => unknown\n const wrapped = replacement(original)\n\n // Make sure it's a function first, as we need to attach an empty prototype for `defineProperties` to work\n // otherwise it'll throw \"TypeError: Object.defineProperties called on non-object\"\n if (isFunction(wrapped)) {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n wrapped.prototype = wrapped.prototype || {}\n Object.defineProperties(wrapped, {\n __posthog_wrapped__: {\n enumerable: false,\n value: true,\n },\n })\n }\n\n source[name] = wrapped\n\n return () => {\n source[name] = original\n }\n } catch {\n return () => {\n //\n }\n // This can throw if multiple fill happens on a global object like XMLHttpRequest\n // Fixes https://github.com/getsentry/sentry-javascript/issues/2043\n }\n}\n","import { NetworkRecordOptions } from '../../../types'\n\nfunction hostnameFromURL(url: string | URL | RequestInfo): string | null {\n try {\n if (typeof url === 'string') {\n return new URL(url).hostname\n }\n if ('url' in url) {\n return new URL(url.url).hostname\n }\n return url.hostname\n } catch {\n return null\n }\n}\n\nexport function isHostOnDenyList(url: string | URL | Request, options: NetworkRecordOptions) {\n const hostname = hostnameFromURL(url)\n const defaultNotDenied = { hostname, isHostDenied: false }\n\n if (!options.payloadHostDenyList?.length || !hostname?.trim().length) {\n return defaultNotDenied\n }\n\n for (const deny of options.payloadHostDenyList) {\n if (hostname.endsWith(deny)) {\n return { hostname, isHostDenied: true }\n }\n }\n\n return defaultNotDenied\n}\n","// @ts-expect-error - Patched to include the version\nimport { record as rrwebRecord, version } from 'rrweb'\nimport { getRecordConsolePlugin } from '@rrweb/rrweb-plugin-console-record'\n\n// rrweb/network@1 code starts\n// most of what is below here will be removed when rrweb release their code for this\n// see https://github.com/rrweb-io/rrweb/pull/1105\n/// <reference lib=\"dom\" />\n// NB adopted from https://github.com/rrweb-io/rrweb/pull/1105 which looks like it will be accepted into rrweb\n// however, in the PR, it throws when the performance observer data is not available\n// and assumes it is running in a browser with the Request API (i.e. not IE11)\n// copying here so that we can use it before rrweb adopt it\nimport type { IWindow, listenerHandler, RecordPlugin } from '@rrweb/types'\nimport { CapturedNetworkRequest, Headers, InitiatorType, NetworkRecordOptions } from '../types'\nimport {\n isArray,\n isBoolean,\n isDocument,\n isFormData,\n isNull,\n isNullish,\n isObject,\n isString,\n isUndefined,\n} from '../utils/type-utils'\nimport { logger } from '../utils/logger'\nimport { assignableWindow } from '../utils/globals'\nimport { defaultNetworkOptions } from '../extensions/replay/config'\nimport { formDataToQuery } from '../utils/request-utils'\nimport { patch } from '../extensions/replay/rrweb-plugins/patch'\nimport { isHostOnDenyList } from '../extensions/replay/external/denylist'\n\nexport type NetworkData = {\n requests: CapturedNetworkRequest[]\n isInitial?: boolean\n}\n\ntype networkCallback = (data: NetworkData) => void\n\nconst isNavigationTiming = (entry: PerformanceEntry): entry is PerformanceNavigationTiming =>\n entry.entryType === 'navigation'\nconst isResourceTiming = (entry: PerformanceEntry): entry is PerformanceResourceTiming => entry.entryType === 'resource'\n\ntype ObservedPerformanceEntry = (PerformanceNavigationTiming | PerformanceResourceTiming) & {\n responseStatus?: number\n}\n\nexport function findLast<T>(array: Array<T>, predicate: (value: T) => boolean): T | undefined {\n const length = array.length\n for (let i = length - 1; i >= 0; i -= 1) {\n if (predicate(array[i])) {\n return array[i]\n }\n }\n return undefined\n}\n\nfunction initPerformanceObserver(cb: networkCallback, win: IWindow, options: Required<NetworkRecordOptions>) {\n // if we are only observing timings then we could have a single observer for all types, with buffer true,\n // but we are going to filter by initiatorType _if we are wrapping fetch and xhr as the wrapped functions\n // will deal with those.\n // so we have a block which captures requests from before fetch/xhr is wrapped\n // these are marked `isInitial` so playback can display them differently if needed\n // they will never have method/status/headers/body because they are pre-wrapping that provides that\n if (options.recordInitialRequests) {\n const initialPerformanceEntries = win.performance\n .getEntries()\n .filter(\n (entry): entry is ObservedPerformanceEntry =>\n isNavigationTiming(entry) ||\n (isResourceTiming(entry) && options.initiatorTypes.includes(entry.initiatorType as InitiatorType))\n )\n cb({\n requests: initialPerformanceEntries.flatMap((entry) =>\n prepareRequest({ entry, method: undefined, status: undefined, networkRequest: {}, isInitial: true })\n ),\n isInitial: true,\n })\n }\n const observer = new win.PerformanceObserver((entries) => {\n // if recordBody or recordHeaders is true then we don't want to record fetch or xhr here\n // as the wrapped functions will do that. Otherwise, this filter becomes a noop\n // because we do want to record them here\n const wrappedInitiatorFilter = (entry: ObservedPerformanceEntry) =>\n options.recordBody || options.recordHeaders\n ? entry.initiatorType !== 'xmlhttprequest' && entry.initiatorType !== 'fetch'\n : true\n\n const performanceEntries = entries.getEntries().filter(\n (entry): entry is ObservedPerformanceEntry =>\n isNavigationTiming(entry) ||\n (isResourceTiming(entry) &&\n options.initiatorTypes.includes(entry.initiatorType as InitiatorType) &&\n // TODO if we are _only_ capturing timing we don't want to filter initiator here\n wrappedInitiatorFilter(entry))\n )\n\n cb({\n requests: performanceEntries.flatMap((entry) =>\n prepareRequest({ entry, method: undefined, status: undefined, networkRequest: {} })\n ),\n })\n })\n // compat checked earlier\n // eslint-disable-next-line compat/compat\n const entryTypes = PerformanceObserver.supportedEntryTypes.filter((x) =>\n options.performanceEntryTypeToObserve.includes(x)\n )\n // initial records are gathered above, so we don't need to observe and buffer each type separately\n observer.observe({ entryTypes })\n return () => {\n observer.disconnect()\n }\n}\n\nfunction shouldRecordHeaders(type: 'request' | 'response', recordHeaders: NetworkRecordOptions['recordHeaders']) {\n return !!recordHeaders && (isBoolean(recordHeaders) || recordHeaders[type])\n}\n\nfunction shouldRecordBody({\n type,\n recordBody,\n headers,\n}: {\n type: 'request' | 'response'\n recordBody: NetworkRecordOptions['recordBody']\n headers: Headers\n url: string | URL | RequestInfo\n}) {\n function matchesContentType(contentTypes: string[]) {\n const contentTypeHeader = Object.keys(headers).find((key) => key.toLowerCase() === 'content-type')\n const contentType = contentTypeHeader && headers[contentTypeHeader]\n return contentTypes.some((ct) => contentType?.includes(ct))\n }\n\n if (!recordBody) return false\n if (isBoolean(recordBody)) return true\n if (isArray(recordBody)) return matchesContentType(recordBody)\n const recordBodyType = recordBody[type]\n if (isBoolean(recordBodyType)) return recordBodyType\n return matchesContentType(recordBodyType)\n}\n\nasync function getRequestPerformanceEntry(\n win: IWindow,\n initiatorType: string,\n url: string,\n start?: number,\n end?: number,\n attempt = 0\n): Promise<PerformanceResourceTiming | null> {\n if (attempt > 10) {\n logger.warn('Failed to get performance entry for request', { url, initiatorType })\n return null\n }\n const urlPerformanceEntries = win.performance.getEntriesByName(url) as PerformanceResourceTiming[]\n const performanceEntry = findLast(\n urlPerformanceEntries,\n (entry) =>\n isResourceTiming(entry) &&\n entry.initiatorType === initiatorType &&\n (isUndefined(start) || entry.startTime >= start) &&\n (isUndefined(end) || entry.startTime <= end)\n )\n if (!performanceEntry) {\n await new Promise((resolve) => setTimeout(resolve, 50 * attempt))\n return getRequestPerformanceEntry(win, initiatorType, url, start, end, attempt + 1)\n }\n return performanceEntry\n}\n\n/**\n * According to MDN https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest/response\n * xhr response is typed as any but can be an ArrayBuffer, a Blob, a Document, a JavaScript object,\n * or a string, depending on the value of XMLHttpRequest.responseType, that contains the response entity body.\n *\n * XHR request body is Document | XMLHttpRequestBodyInit | null | undefined\n */\nfunction _tryReadXHRBody({\n body,\n options,\n url,\n}: {\n body: Document | XMLHttpRequestBodyInit | any | null | undefined\n options: NetworkRecordOptions\n url: string | URL | RequestInfo\n}): string | null {\n if (isNullish(body)) {\n return null\n }\n\n const { hostname, isHostDenied } = isHostOnDenyList(url, options)\n if (isHostDenied) {\n return hostname + ' is in deny list'\n }\n\n if (isString(body)) {\n return body\n }\n\n if (isDocument(body)) {\n return body.textContent\n }\n\n if (isFormData(body)) {\n return formDataToQuery(body)\n }\n\n if (isObject(body)) {\n try {\n return JSON.stringify(body)\n } catch {\n return '[SessionReplay] Failed to stringify response object'\n }\n }\n\n return '[SessionReplay] Cannot read body of type ' + toString.call(body)\n}\n\nfunction initXhrObserver(cb: networkCallback, win: IWindow, options: Required<NetworkRecordOptions>): listenerHandler {\n if (!options.initiatorTypes.includes('xmlhttprequest')) {\n return () => {\n //\n }\n }\n const recordRequestHeaders = shouldRecordHeaders('request', options.recordHeaders)\n const recordResponseHeaders = shouldRecordHeaders('response', options.recordHeaders)\n\n const restorePatch = patch(\n win.XMLHttpRequest.prototype,\n 'open',\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n (originalOpen: typeof XMLHttpRequest.prototype.open) => {\n return function (\n method: string,\n url: string | URL,\n async = true,\n username?: string | null,\n password?: string | null\n ) {\n // because this function is returned in its actual context `this` _is_ an XMLHttpRequest\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n const xhr = this as XMLHttpRequest\n\n // check IE earlier than this, we only initialize if Request is present\n // eslint-disable-next-line compat/compat\n const req = new Request(url)\n const networkRequest: Partial<CapturedNetworkRequest> = {}\n let start: number | undefined\n let end: number | undefined\n\n const requestHeaders: Headers = {}\n const originalSetRequestHeader = xhr.setRequestHeader.bind(xhr)\n xhr.setRequestHeader = (header: string, value: string) => {\n requestHeaders[header] = value\n return originalSetRequestHeader(header, value)\n }\n if (recordRequestHeaders) {\n networkRequest.requestHeaders = requestHeaders\n }\n\n const originalSend = xhr.send.bind(xhr)\n xhr.send = (body) => {\n if (\n shouldRecordBody({\n type: 'request',\n headers: requestHeaders,\n url,\n recordBody: options.recordBody,\n })\n ) {\n networkRequest.requestBody = _tryReadXHRBody({ body, options, url })\n }\n start = win.performance.now()\n return originalSend(body)\n }\n\n xhr.addEventListener('readystatechange', () => {\n if (xhr.readyState !== xhr.DONE) {\n return\n }\n end = win.performance.now()\n const responseHeaders: Headers = {}\n const rawHeaders = xhr.getAllResponseHeaders()\n const headers = rawHeaders.trim().split(/[\\r\\n]+/)\n headers.forEach((line) => {\n const parts = line.split(': ')\n const header = parts.shift()\n const value = parts.join(': ')\n if (header) {\n responseHeaders[header] = value\n }\n })\n if (recordResponseHeaders) {\n networkRequest.responseHeaders = responseHeaders\n }\n if (\n shouldRecordBody({\n type: 'response',\n headers: responseHeaders,\n url,\n recordBody: options.recordBody,\n })\n ) {\n networkRequest.responseBody = _tryReadXHRBody({ body: xhr.response, options, url })\n }\n getRequestPerformanceEntry(win, 'xmlhttprequest', req.url, start, end)\n .then((entry) => {\n const requests = prepareRequest({\n entry,\n method: req.method,\n status: xhr?.status,\n networkRequest,\n start,\n end,\n url: url.toString(),\n initiatorType: 'xmlhttprequest',\n })\n cb({ requests })\n })\n .catch(() => {\n //\n })\n })\n originalOpen.call(xhr, method, url, async, username, password)\n }\n }\n )\n return () => {\n restorePatch()\n }\n}\n\n/**\n * Check if this PerformanceEntry is either a PerformanceResourceTiming or a PerformanceNavigationTiming\n * NB PerformanceNavigationTiming extends PerformanceResourceTiming\n * Here we don't care which interface it implements as both expose `serverTimings`\n */\nconst exposesServerTiming = (event: PerformanceEntry | null): event is PerformanceResourceTiming =>\n !isNull(event) && (event.entryType === 'navigation' || event.entryType === 'resource')\n\nfunction prepareRequest({\n entry,\n method,\n status,\n networkRequest,\n isInitial,\n start,\n end,\n url,\n initiatorType,\n}: {\n entry: PerformanceResourceTiming | null\n method: string | undefined\n status: number | undefined\n networkRequest: Partial<CapturedNetworkRequest>\n isInitial?: boolean\n start?: number\n end?: number\n // if there is no performance observer entry, we still need to know the url\n url?: string\n // if there is no performance observer entry, we can provide the initiatorType\n initiatorType?: string\n}): CapturedNetworkRequest[] {\n start = entry ? entry.startTime : start\n end = entry ? entry.responseEnd : end\n\n // kudos to sentry javascript sdk for excellent background on why to use Date.now() here\n // https://github.com/getsentry/sentry-javascript/blob/e856e40b6e71a73252e788cd42b5260f81c9c88e/packages/utils/src/time.ts#L70\n // can't start observer if performance.now() is not available\n // eslint-disable-next-line compat/compat\n const timeOrigin = Math.floor(Date.now() - performance.now())\n // clickhouse can't ingest timestamps that are floats\n // (in this case representing fractions of a millisecond we don't care about anyway)\n // use timeOrigin if we really can't gather a start time\n const timestamp = Math.floor(timeOrigin + (start || 0))\n\n const entryJSON = entry ? entry.toJSON() : { name: url }\n\n const requests: CapturedNetworkRequest[] = [\n {\n ...entryJSON,\n startTime: isUndefined(start) ? undefined : Math.round(start),\n endTime: isUndefined(end) ? undefined : Math.round(end),\n timeOrigin,\n timestamp,\n method: method,\n initiatorType: entry ? (entry.initiatorType as InitiatorType) : initiatorType,\n status,\n requestHeaders: networkRequest.requestHeaders,\n requestBody: networkRequest.requestBody,\n responseHeaders: networkRequest.responseHeaders,\n responseBody: networkRequest.responseBody,\n isInitial,\n },\n ]\n\n if (exposesServerTiming(entry)) {\n for (const timing of entry.serverTiming || []) {\n requests.push({\n timeOrigin,\n timestamp,\n startTime: Math.round(entry.startTime),\n name: timing.name,\n duration: timing.duration,\n // the spec has a closed list of possible types\n // https://developer.mozilla.org/en-US/docs/Web/API/PerformanceEntry/entryType\n // but, we need to know this was a server timing so that we know to\n // match it to the appropriate navigation or resource timing\n // that matching will have to be on timestamp and $current_url\n entryType: 'serverTiming',\n })\n }\n }\n\n return requests\n}\n\nconst contentTypePrefixDenyList = ['video/', 'audio/']\n\nfunction _checkForCannotReadResponseBody({\n r,\n options,\n url,\n}: {\n r: Response\n options: NetworkRecordOptions\n url: string | URL | RequestInfo\n}): string | null {\n if (r.headers.get('Transfer-Encoding') === 'chunked') {\n return 'Chunked Transfer-Encoding is not supported'\n }\n\n // `get` and `has` are case-insensitive\n // but return the header value with the casing that was supplied\n const contentType = r.headers.get('Content-Type')?.toLowerCase()\n const contentTypeIsDenied = contentTypePrefixDenyList.some((prefix) => contentType?.startsWith(prefix))\n if (contentType && contentTypeIsDenied) {\n return `Content-Type ${contentType} is not supported`\n }\n\n const { hostname, isHostDenied } = isHostOnDenyList(url, options)\n if (isHostDenied) {\n return hostname + ' is in deny list'\n }\n\n return null\n}\n\nfunction _tryReadBody(r: Request | Response): Promise<string> {\n // there are now already multiple places where we're using Promise...\n // eslint-disable-next-line compat/compat\n return new Promise((resolve, reject) => {\n const timeout = setTimeout(() => resolve('[SessionReplay] Timeout while trying to read body'), 500)\n try {\n r.clone()\n .text()\n .then(\n (txt) => resolve(txt),\n (reason) => reject(reason)\n )\n .finally(() => clearTimeout(timeout))\n } catch {\n clearTimeout(timeout)\n resolve('[SessionReplay] Failed to read body')\n }\n })\n}\n\nasync function _tryReadRequestBody({\n r,\n options,\n url,\n}: {\n r: Request\n options: NetworkRecordOptions\n url: string | URL | RequestInfo\n}): Promise<string> {\n const { hostname, isHostDenied } = isHostOnDenyList(url, options)\n if (isHostDenied) {\n return Promise.resolve(hostname + ' is in deny list')\n }\n\n return _tryReadBody(r)\n}\n\nasync function _tryReadResponseBody({\n r,\n options,\n url,\n}: {\n r: Response\n options: NetworkRecordOptions\n url: string | URL | RequestInfo\n}): Promise<string> {\n const cannotReadBodyReason: string | null = _checkForCannotReadResponseBody({ r, options, url })\n if (!isNull(cannotReadBodyReason)) {\n return Promise.resolve(cannotReadBodyReason)\n }\n\n return _tryReadBody(r)\n}\n\nfunction initFetchObserver(\n cb: networkCallback,\n win: IWindow,\n options: Required<NetworkRecordOptions>\n): listenerHandler {\n if (!options.initiatorTypes.includes('fetch')) {\n return () => {\n //\n }\n }\n const recordRequestHeaders = shouldRecordHeaders('request', options.recordHeaders)\n const recordResponseHeaders = shouldRecordHeaders('response', options.recordHeaders)\n\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n const restorePatch = patch(win, 'fetch', (originalFetch: typeof fetch) => {\n return async function (url: URL | RequestInfo, init?: RequestInit | undefined) {\n // check IE earlier than this, we only initialize if Request is present\n // eslint-disable-next-line compat/compat\n const req = new Request(url, init)\n let res: Response | undefined\n const networkRequest: Partial<CapturedNetworkRequest> = {}\n let start: number | undefined\n let end: number | undefined\n\n try {\n const requestHeaders: Headers = {}\n req.headers.forEach((value, header) => {\n requestHeaders[header] = value\n })\n if (recordRequestHeaders) {\n networkRequest.requestHeaders = requestHeaders\n }\n if (\n shouldRecordBody({\n type: 'request',\n headers: requestHeaders,\n url,\n recordBody: options.recordBody,\n })\n ) {\n networkRequest.requestBody = await _tryReadRequestBody({ r: req, options, url })\n }\n\n start = win.performance.now()\n res = await originalFetch(req)\n end = win.performance.now()\n\n const responseHeaders: Headers = {}\n res.headers.forEach((value, header) => {\n responseHeaders[header] = value\n })\n if (recordResponseHeaders) {\n networkRequest.responseHeaders = responseHeaders\n }\n if (\n shouldRecordBody({\n type: 'response',\n headers: responseHeaders,\n url,\n recordBody: options.recordBody,\n })\n ) {\n networkRequest.responseBody = await _tryReadResponseBody({ r: res, options, url })\n }\n\n return res\n } finally {\n getRequestPerformanceEntry(win, 'fetch', req.url, start, end)\n .then((entry) => {\n const requests = prepareRequest({\n entry,\n method: req.method,\n status: res?.status,\n networkRequest,\n start,\n end,\n url: req.url,\n initiatorType: 'fetch',\n })\n cb({ requests })\n })\n .catch(() => {\n //\n })\n }\n }\n })\n return () => {\n restorePatch()\n }\n}\n\nlet initialisedHandler: listenerHandler | null = null\n\nfunction initNetworkObserver(\n callback: networkCallback,\n win: IWindow, // top window or in an iframe\n options: NetworkRecordOptions\n): listenerHandler {\n if (!('performance' in win)) {\n return () => {\n //\n }\n }\n\n if (initialisedHandler) {\n logger.warn('Network observer already initialised, doing nothing')\n return () => {\n // the first caller should already have this handler and will be responsible for teardown\n }\n }\n\n const networkOptions = (\n options ? Object.assign({}, defaultNetworkOptions, options) : defaultNetworkOptions\n ) as Required<NetworkRecordOptions>\n\n const cb: networkCallback = (data) => {\n const requests: CapturedNetworkRequest[] = []\n data.requests.forEach((request) => {\n const maskedRequest = networkOptions.maskRequestFn(request)\n if (maskedRequest) {\n requests.push(maskedRequest)\n }\n })\n\n if (requests.length > 0) {\n callback({ ...data, requests })\n }\n }\n const performanceObserver = initPerformanceObserver(cb, win, networkOptions)\n\n // only wrap fetch and xhr if headers or body are being recorded\n let xhrObserver: listenerHandler = () => {}\n let fetchObserver: listenerHandler = () => {}\n if (networkOptions.recordHeaders || networkOptions.recordBody) {\n xhrObserver = initXhrObserver(cb, win, networkOptions)\n fetchObserver = initFetchObserver(cb, win, networkOptions)\n }\n\n initialisedHandler = () => {\n performanceObserver()\n xhrObserver()\n fetchObserver()\n }\n return initialisedHandler\n}\n\n// use the plugin name so that when this functionality is adopted into rrweb\n// we can remove this plugin and use the core functionality with the same data\nexport const NETWORK_PLUGIN_NAME = 'rrweb/network@1'\n\n// TODO how should this be typed?\n// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-ignore\nexport const getRecordNetworkPlugin: (options?: NetworkRecordOptions) => RecordPlugin = (options) => {\n return {\n name: NETWORK_PLUGIN_NAME,\n observer: initNetworkObserver,\n options: options,\n }\n}\n\n// rrweb/networ@1 ends\n\nassignableWindow.__PosthogExtensions__ = assignableWindow.__PosthogExtensions__ || {}\nassignableWindow.__PosthogExtensions__.rrwebPlugins = { getRecordConsolePlugin, getRecordNetworkPlugin }\nassignableWindow.__PosthogExtensions__.rrweb = { record: rrwebRecord, version: 'v2', rrwebVersion: version }\n\n// we used to put all of these items directly on window, and now we put it on __PosthogExtensions__\n// but that means that old clients which lazily load this extension are looking in the wrong place\n// yuck,\n// so we also put them directly on the window\n// when 1.161.1 is the oldest version seen in production we can remove this\nassignableWindow.rrweb = { record: rrwebRecord, version: 'v2', rrwebVersion: version }\nassignableWindow.rrwebConsoleRecord = { getRecordConsolePlugin }\nassignableWindow.getRecordNetworkPlugin = getRecordNetworkPlugin\n\nexport default rrwebRecord\n"],"names":["_a","__defProp","Object","defineProperty","__publicField","__publicField$1","obj","key","value","__defNormalProp$1","enumerable","configurable","writable","__defNormalProp","NodeType","NodeType2","isElement","n","nodeType","ELEMENT_NODE","isShadowRoot","host","Boolean","shadowRoot","isNativeShadowDom","prototype","toString","call","stringifyStylesheet","s","rules","cssRules","cssText","Array","from","stringifyRule","join","includes","replace","error","rule","importStringified","isCSSImportRule","styleSheet","split","length","statement","JSON","stringify","href","layerName","push","supportsText","media","mediaText","escapeImportStatement","isCSSStyleRule","selectorText","cssStringified","regex","fixSafariColons","findStylesheet","doc","styleSheets","find","constructor","this","Map","getId","n2","_a2","id","getMeta","getNode","idNodeMap","getIds","keys","nodeMetaMap","get","removeNodeFromMap","childNode","has","hasNode","node","add","meta","set","oldNode","reset","createMirror","WeakMap","maskInputValue","_ref","element","maskInputOptions","tagName","type","maskInputFn","text","actualType","toLowerCase","repeat","str","ORIGINAL_ATTRIBUTE_NAME","getInputType","extractFileExtension","baseURL","_ref2","url","err","match","pathname","_id","tagNameRegex","RegExp","IGNORED_NODE","getValidTagName","canvasService","canvasCtx","URL_IN_CSS_REF","URL_PROTOCOL_MATCH","URL_WWW_MATCH","DATA_URI","absoluteToStylesheet","path1","filePath","path2","path3","maybeQuote","quote1","quote2","origin","test","indexOf","extractOrigin","stack","parts","part","SRCSET_NOT_SPACES","SRCSET_COMMAS_OR_SPACES","cachedDocument","absoluteToDoc","attributeValue","trim","getHref","isSVGElement","el","a","ownerSVGElement","customHref","a2","createElement","startsWith","transformAttribute","name","getAbsoluteSrcsetString","pos","collectCharacters","chars2","regEx","exec","substring","chars","output","slice","descriptorsStr","inParens","c2","charAt","c","ignoreAttribute","_value","classMatchesRegex","checkAncestors","parentNode","eIndex","classList","className","needMaskingText","childNodes","parentElement","maskTextClass","closest","maskTextSelector","e","matches","e2","serializeNode","mirror","blockClass","blockSelector","needsMask","inlineStylesheet","maskTextFn","dataURLOptions","inlineImages","recordCanvas","keepIframeSrcFn","newlyAddedElement","options","rootId","mirror2","docId","getRootId","compatMode","DOCUMENT_TYPE_NODE","NodeType$2","DocumentType","publicId","systemId","serializeElementNode","needBlock","_isBlockedElement","contains","getValidTagName$1","HTMLFormElement","processedTagName","attributes","len","i2","attr","stylesheet","window","location","_cssText","sheet","innerText","textContent","checked","selected","__context","is2DCanvasBlank","ctx","canvas","x","y","height","getImageData","originalGetImageData","pixelBuffer","Math","min","data","buffer","rr_dataURL","toDataURL","quality","canvasDataURL","blankCanvas","getContext","imageSrc","image","getAttribute","priorCrossOrigin","crossOrigin","recordInlineImage","removeEventListener","naturalWidth","drawImage","addEventListener","console","warn","removeAttribute","complete","mediaAttributes","rr_mediaState","paused","rr_mediaCurrentTime","currentTime","rr_mediaMuted","muted","scrollLeft","rr_scrollLeft","scrollTop","rr_scrollTop","width","class","rr_width","rr_height","src","contentDocument","isCustomElement","customElements","isSVG","isCustom","parentTagName","isStyle","isScript","nextSibling","previousSibling","serializeTextNode","CDATA_SECTION_NODE","COMMENT_NODE","lowerIfExists","maybeAttr","serializeNodeWithId","skipChild","slimDOMOptions","onSerialize","onIframeLoad","iframeLoadTimeout","onStylesheetLoad","stylesheetLoadTimeout","preserveWhiteSpace","_serializedNode","slimDOMExcluded","sn","Comment","Element","script","rel","as","headFavicon","headMetaDescKeywords","headMetaRobots","headMetaHttpEquiv","headMetaAuthorship","property","headMetaVerification","serializedNode","assign","recordChild","Document","bypassOptions","childN","serializedChildNode","isShadow","iframeEl","listener","win","contentWindow","readyState","fired","setTimeout","clearTimeout","blankUrl","onceIframeLoaded","iframeDoc","serializedIframeNode","onceStylesheetLoaded","styleSheetLoaded","styleSheetLoadTimeout","link","serializedLinkNode","nodeName","idStyleMap","event","path","target","apply","thisArg","argumentsList","iframes","root","Mirror","maskAllInputs","slimDOM","color","date","email","month","number","range","search","tel","time","week","textarea","select","password","comment","headWhitespace","headMetaSocial","__publicField2","__defNormalProp2","__defProp$1","delete","forEach","DEPARTED_MIRROR_ACCESS_WARNING","_mirror","map","Proxy","Reflect","prop","receiver","nowTimestamp","Date","now","closestElementOfNode","getTime","getShadowHost","_b","shadowHost","getRootNode","Node","DOCUMENT_FRAGMENT_NODE","getRootShadowHost","rootShadowHost","shadowHostInDom","ownerDocument","utils","freeze","__proto__","StyleSheetMirror","_this$styleIDMap$get","styleIDMap","newId","getStyle","generateId","getBaseDimension","rootIframe","frameElement","defaultView","relativeScale","absoluteScale","frameDimension","getBoundingClientRect","frameBaseDimension","clientHeight","getNestedRule","rules2","position","getPositionsAndIndex","nestedIndex","positions","index","pop","getWindowHeight","innerHeight","document","documentElement","body","getWindowScroll","_c","_d","_e","_f","left","scrollingElement","pageXOffset","top","pageYOffset","getWindowWidth","innerWidth","clientWidth","hasShadowRoot","hookSetter","d","isRevoked","original","getOwnPropertyDescriptor","inDom","isAncestorRemoved","DOCUMENT_NODE","isBlocked","isIgnored","headTitleMutations","isSerialized","isSerializedIframe","isSerializedStylesheet","iterateResolveTree","tree","cb","children","legacy_isTouchEvent","changedTouches","on","fn","capture","passive","patch","source","replacement","wrapped","defineProperties","__rrweb_original__","polyfill","_this","NodeList","DOMTokenList","args","TypeError","queueToResolveTrees","queue","queueNodeMap","putIntoMap","m","parent","nodeInTree","queueNodeTrees","mutation","nextId","parentId","nextInTree","idx","splice","parentInTree","throttle","func","wait","arguments","undefined","timeout","previous","leading","remaining","context","trailing","uniqueTextMutations","mutations","idSet","Set","uniqueMutations","Symbol","toStringTag","lookup","Uint8Array","i$1","charCodeAt","Blob","base64","atob","decodeBase64","cleanFrame","appendChild","removeChild","debug","t2","NotStarted","Running","Stopped","nativeIsArray","isArray","ObjProto","hasOwnProperty","isFunction","f","isObject","isUndefined","isString","isNull","isNullish","isBoolean","isDocument","isFormData","FormData","global","globalThis","nativeForEach","navigator","fetch","XMLHttpRequest","AbortController","userAgent","assignableWindow","LOGGER_PREFIX","logger","_log","level","consoleLog","_len","_key","info","_len2","_key2","_len3","_key3","_len4","_key4","critical","_len5","_key5","uninitializedWarning","methodName","breaker","each","iterator","i","l","eachArray","pair","entries","formDataToQuery","formdata","use_val","use_key","arg_separator","tph_arr","val","encodeURIComponent","File","defaultNetworkOptions","initiatorTypes","maskRequestFn","recordHeaders","recordBody","recordInitialRequests","recordPerformance","performanceEntryTypeToObserve","payloadSizeLimitBytes","payloadHostDenyList","__posthog_wrapped__","isHostOnDenyList","_options$payloadHostD","hostname","URL","hostnameFromURL","defaultNotDenied","isHostDenied","deny","endsWith","isNavigationTiming","entry","entryType","isResourceTiming","findLast","array","predicate","initPerformanceObserver","initialPerformanceEntries","performance","getEntries","filter","initiatorType","requests","flatMap","prepareRequest","method","status","networkRequest","isInitial","observer","PerformanceObserver","performanceEntries","wrappedInitiatorFilter","entryTypes","supportedEntryTypes","observe","disconnect","shouldRecordHeaders","shouldRecordBody","headers","matchesContentType","contentTypes","contentTypeHeader","contentType","some","ct","recordBodyType","async","getRequestPerformanceEntry","start","end","attempt","performanceEntry","getEntriesByName","startTime","Promise","resolve","_tryReadXHRBody","exposesServerTiming","_ref3","responseEnd","timeOrigin","floor","timestamp","toJSON","round","endTime","requestHeaders","requestBody","responseHeaders","responseBody","timing","serverTiming","duration","contentTypePrefixDenyList","_tryReadBody","r","reject","clone","then","txt","reason","finally","_tryReadResponseBody","_ref6","cannotReadBodyReason","_ref4","_r$headers$get","contentTypeIsDenied","prefix","_checkForCannotReadResponseBody","initFetchObserver","recordRequestHeaders","recordResponseHeaders","restorePatch","originalFetch","init","req","Request","res","header","_ref5","_tryReadRequestBody","_res","catch","initialisedHandler","initNetworkObserver","callback","networkOptions","request","maskedRequest","performanceObserver","xhrObserver","fetchObserver","originalOpen","username","xhr","originalSetRequestHeader","setRequestHeader","bind","originalSend","send","DONE","getAllResponseHeaders","line","shift","response","initXhrObserver","NETWORK_PLUGIN_NAME","getRecordNetworkPlugin","__PosthogExtensions__","rrwebPlugins","getRecordConsolePlugin","rrweb","record","rrwebRecord","version","rrwebVersion","rrwebConsoleRecord"],"mappings":"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","x_google_ignoreList":[0,1]}
|