From dd821efbe2967f0970d8bb3a9df38812c4d80609 Mon Sep 17 00:00:00 2001 From: Paul D'Ambra Date: Wed, 27 Nov 2024 11:54:46 +0000 Subject: [PATCH] fix: patch to angular detection in rrweb --- patches/@rrweb__record@2.0.0-alpha.17.patch | 46 ++++++++++++++------- pnpm-lock.yaml | 6 +-- 2 files changed, 35 insertions(+), 17 deletions(-) diff --git a/patches/@rrweb__record@2.0.0-alpha.17.patch b/patches/@rrweb__record@2.0.0-alpha.17.patch index 842d04ded..c3b75e0cd 100644 --- a/patches/@rrweb__record@2.0.0-alpha.17.patch +++ b/patches/@rrweb__record@2.0.0-alpha.17.patch @@ -1,23 +1,28 @@ diff --git a/dist/record.js b/dist/record.js -index 46ec389fefb698243008b39db65470dbdf0a3857..bfebdc6a3887a3ddae46b21d21896092d2963fe9 100644 +index 46ec389fefb698243008b39db65470dbdf0a3857..70db907755d68b08232e25e1b255a974f56f3c65 100644 --- a/dist/record.js +++ b/dist/record.js -@@ -26,6 +26,14 @@ const testableMethods$1 = { +@@ -26,6 +26,19 @@ const testableMethods$1 = { Element: [], MutationObserver: ["constructor"] }; +const isFunction = (x) => typeof x === 'function'; +const isAngularZonePatchedFunction = (x) => { -+ if (!isFunction(x)) { -+ return false; ++ try { ++ if (!isFunction(x)) { ++ return false; ++ } ++ const prototypeKeys = Object.getOwnPropertyNames(x.prototype || {}); ++ return prototypeKeys.some((key) => key.indexOf('__zone')); ++ } catch { ++ // we've seen some intermittent problems in Safari since introducing this check ++ return false + } -+ const prototypeKeys = Object.getOwnPropertyNames(x.prototype || {}); -+ return prototypeKeys.some((key) => key.indexOf('__zone')); +} const untaintedBasePrototype$1 = {}; function getUntaintedPrototype$1(key) { if (untaintedBasePrototype$1[key]) -@@ -54,7 +62,7 @@ function getUntaintedPrototype$1(key) { +@@ -54,7 +67,7 @@ function getUntaintedPrototype$1(key) { } ) ); @@ -26,7 +31,20 @@ index 46ec389fefb698243008b39db65470dbdf0a3857..bfebdc6a3887a3ddae46b21d21896092 untaintedBasePrototype$1[key] = defaultObj.prototype; return defaultObj.prototype; } -@@ -246,6 +254,9 @@ function isCSSImportRule(rule2) { +@@ -65,10 +78,10 @@ function getUntaintedPrototype$1(key) { + if (!win) return defaultObj.prototype; + const untaintedObject = win[key].prototype; + document.body.removeChild(iframeEl); +- if (!untaintedObject) return defaultPrototype; ++ if (!untaintedObject) return defaultObj.prototype; + return untaintedBasePrototype$1[key] = untaintedObject; + } catch { +- return defaultPrototype; ++ return defaultObj.prototype; + } + } + const untaintedAccessorCache$1 = {}; +@@ -246,6 +259,9 @@ function isCSSImportRule(rule2) { function isCSSStyleRule(rule2) { return "selectorText" in rule2; } @@ -36,7 +54,7 @@ index 46ec389fefb698243008b39db65470dbdf0a3857..bfebdc6a3887a3ddae46b21d21896092 class Mirror { constructor() { __publicField$1(this, "idNodeMap", /* @__PURE__ */ new Map()); -@@ -809,9 +820,14 @@ function serializeElementNode(n2, options) { +@@ -809,9 +825,14 @@ function serializeElementNode(n2, options) { } } if (tagName === "link" && inlineStylesheet) { @@ -54,7 +72,7 @@ index 46ec389fefb698243008b39db65470dbdf0a3857..bfebdc6a3887a3ddae46b21d21896092 let cssText = null; if (stylesheet) { cssText = stringifyStylesheet(stylesheet); -@@ -855,7 +871,15 @@ function serializeElementNode(n2, options) { +@@ -855,7 +876,15 @@ function serializeElementNode(n2, options) { } } if (tagName === "dialog" && n2.open) { @@ -71,7 +89,7 @@ index 46ec389fefb698243008b39db65470dbdf0a3857..bfebdc6a3887a3ddae46b21d21896092 } if (tagName === "canvas" && recordCanvas) { if (n2.__context === "2d") { -@@ -1116,7300 +1140,227 @@ function serializeNodeWithId(n2, options) { +@@ -1116,7300 +1145,227 @@ function serializeNodeWithId(n2, options) { keepIframeSrcFn }; if (serializedNode.type === NodeType$2.Element && serializedNode.tagName === "textarea" && serializedNode.attributes.value !== void 0) ; @@ -7581,7 +7599,7 @@ index 46ec389fefb698243008b39db65470dbdf0a3857..bfebdc6a3887a3ddae46b21d21896092 class BaseRRNode { // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/no-explicit-any constructor(..._args) { -@@ -8507,7 +1458,7 @@ function getUntaintedPrototype(key) { +@@ -8507,7 +1463,7 @@ function getUntaintedPrototype(key) { } ) ); @@ -7590,7 +7608,7 @@ index 46ec389fefb698243008b39db65470dbdf0a3857..bfebdc6a3887a3ddae46b21d21896092 untaintedBasePrototype[key] = defaultObj.prototype; return defaultObj.prototype; } -@@ -11382,11 +4333,19 @@ class CanvasManager { +@@ -11382,11 +4338,19 @@ class CanvasManager { let rafId; const getCanvas = () => { const matchedCanvas = []; @@ -7615,7 +7633,7 @@ index 46ec389fefb698243008b39db65470dbdf0a3857..bfebdc6a3887a3ddae46b21d21896092 return matchedCanvas; }; const takeCanvasSnapshots = (timestamp) => { -@@ -11407,13 +4366,20 @@ class CanvasManager { +@@ -11407,13 +4371,20 @@ class CanvasManager { context.clear(context.COLOR_BUFFER_BIT); } } diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 0d6fb70a4..fa8253331 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -6,7 +6,7 @@ settings: patchedDependencies: '@rrweb/record@2.0.0-alpha.17': - hash: c2gbrcq5pbh4ogznn2cbid5ple + hash: viz5vmxcmz5nggemb4cjgrd3iy path: patches/@rrweb__record@2.0.0-alpha.17.patch '@rrweb/rrweb-plugin-console-record@2.0.0-alpha.17': hash: ytsspyi7p3hvqcq64vqb7wb6bu @@ -74,7 +74,7 @@ devDependencies: version: 12.1.1(rollup@4.24.0)(tslib@2.5.0)(typescript@5.5.4) '@rrweb/record': specifier: 2.0.0-alpha.17 - version: 2.0.0-alpha.17(patch_hash=c2gbrcq5pbh4ogznn2cbid5ple) + version: 2.0.0-alpha.17(patch_hash=viz5vmxcmz5nggemb4cjgrd3iy) '@rrweb/rrweb-plugin-console-record': specifier: 2.0.0-alpha.17 version: 2.0.0-alpha.17(patch_hash=ytsspyi7p3hvqcq64vqb7wb6bu)(rrweb@2.0.0-alpha.17) @@ -2870,7 +2870,7 @@ packages: dev: true optional: true - /@rrweb/record@2.0.0-alpha.17(patch_hash=c2gbrcq5pbh4ogznn2cbid5ple): + /@rrweb/record@2.0.0-alpha.17(patch_hash=viz5vmxcmz5nggemb4cjgrd3iy): resolution: {integrity: sha512-Je+lzjeWMF8/I0IDoXFzkGPKT8j7AkaBup5YcwUHlkp18VhLVze416MvI6915teE27uUA2ScXMXzG0Yiu5VTIw==} dependencies: '@rrweb/types': 2.0.0-alpha.17