From 0d5cd52517eebdc5b017e643c767262238ee6176 Mon Sep 17 00:00:00 2001 From: Paul D'Ambra Date: Tue, 19 Nov 2024 20:40:14 +0100 Subject: [PATCH] fix: patch angular wrap detection in rrweb (#1543) --- patches/@rrweb__record@2.0.0-alpha.17.patch | 45 ++++++++++++++++++--- pnpm-lock.yaml | 6 +-- 2 files changed, 42 insertions(+), 9 deletions(-) diff --git a/patches/@rrweb__record@2.0.0-alpha.17.patch b/patches/@rrweb__record@2.0.0-alpha.17.patch index 56ad4aedd..9f5ab8084 100644 --- a/patches/@rrweb__record@2.0.0-alpha.17.patch +++ b/patches/@rrweb__record@2.0.0-alpha.17.patch @@ -1,8 +1,32 @@ diff --git a/dist/record.js b/dist/record.js -index 46ec389fefb698243008b39db65470dbdf0a3857..39d9ac821fd84f5a1494ac1e00c8d4e0e58c432a 100644 +index 46ec389fefb698243008b39db65470dbdf0a3857..891e1cf6439630d19e9b745ff428db438943a0b2 100644 --- a/dist/record.js +++ b/dist/record.js -@@ -246,6 +246,9 @@ function isCSSImportRule(rule2) { +@@ -26,6 +26,14 @@ const testableMethods$1 = { + Element: [], + MutationObserver: ["constructor"] + }; ++const isFunction = (x) => typeof x === 'function'; ++const isAngularZonePatchedFunction = (x) => { ++ if (!isFunction(x)) { ++ 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) { + } + ) + ); +- if (isUntaintedAccessors && isUntaintedMethods) { ++ if (isUntaintedAccessors && isUntaintedMethods && !isAngularZonePatchedFunction(defaultObj)) { + untaintedBasePrototype$1[key] = defaultObj.prototype; + return defaultObj.prototype; + } +@@ -246,6 +254,9 @@ function isCSSImportRule(rule2) { function isCSSStyleRule(rule2) { return "selectorText" in rule2; } @@ -12,7 +36,7 @@ index 46ec389fefb698243008b39db65470dbdf0a3857..39d9ac821fd84f5a1494ac1e00c8d4e0 class Mirror { constructor() { __publicField$1(this, "idNodeMap", /* @__PURE__ */ new Map()); -@@ -809,9 +812,14 @@ function serializeElementNode(n2, options) { +@@ -809,9 +820,14 @@ function serializeElementNode(n2, options) { } } if (tagName === "link" && inlineStylesheet) { @@ -30,7 +54,7 @@ index 46ec389fefb698243008b39db65470dbdf0a3857..39d9ac821fd84f5a1494ac1e00c8d4e0 let cssText = null; if (stylesheet) { cssText = stringifyStylesheet(stylesheet); -@@ -1116,7300 +1124,227 @@ function serializeNodeWithId(n2, options) { +@@ -1116,7300 +1132,227 @@ function serializeNodeWithId(n2, options) { keepIframeSrcFn }; if (serializedNode.type === NodeType$2.Element && serializedNode.tagName === "textarea" && serializedNode.attributes.value !== void 0) ; @@ -7540,7 +7564,16 @@ index 46ec389fefb698243008b39db65470dbdf0a3857..39d9ac821fd84f5a1494ac1e00c8d4e0 class BaseRRNode { // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/no-explicit-any constructor(..._args) { -@@ -11382,11 +4317,19 @@ class CanvasManager { +@@ -8507,7 +1450,7 @@ function getUntaintedPrototype(key) { + } + ) + ); +- if (isUntaintedAccessors && isUntaintedMethods) { ++ if (isUntaintedAccessors && isUntaintedMethods && !isAngularZonePatchedFunction(defaultObj)) { + untaintedBasePrototype[key] = defaultObj.prototype; + return defaultObj.prototype; + } +@@ -11382,11 +4325,19 @@ class CanvasManager { let rafId; const getCanvas = () => { const matchedCanvas = []; @@ -7565,7 +7598,7 @@ index 46ec389fefb698243008b39db65470dbdf0a3857..39d9ac821fd84f5a1494ac1e00c8d4e0 return matchedCanvas; }; const takeCanvasSnapshots = (timestamp) => { -@@ -11407,13 +4350,20 @@ class CanvasManager { +@@ -11407,13 +4358,20 @@ class CanvasManager { context.clear(context.COLOR_BUFFER_BIT); } } diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index dd632721b..c0a2b7098 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -6,7 +6,7 @@ settings: patchedDependencies: '@rrweb/record@2.0.0-alpha.17': - hash: ds4wzvngpacxicd464fatv6v44 + hash: vxikte2wlhu3ltbso5lzopaskq 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=ds4wzvngpacxicd464fatv6v44) + version: 2.0.0-alpha.17(patch_hash=vxikte2wlhu3ltbso5lzopaskq) '@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=ds4wzvngpacxicd464fatv6v44): + /@rrweb/record@2.0.0-alpha.17(patch_hash=vxikte2wlhu3ltbso5lzopaskq): resolution: {integrity: sha512-Je+lzjeWMF8/I0IDoXFzkGPKT8j7AkaBup5YcwUHlkp18VhLVze416MvI6915teE27uUA2ScXMXzG0Yiu5VTIw==} dependencies: '@rrweb/types': 2.0.0-alpha.17