From bbbfa226fc5882a01ecc1607b713f0caf797775e Mon Sep 17 00:00:00 2001 From: fukang wang Date: Fri, 7 Jul 2023 17:57:37 +0800 Subject: [PATCH] fix: Resize and MediaInteraction events repeat generated after the iframe appeared (#1251) * fix: Resize and MediaInteraction events repeat generated after the iframe appeared * Create nervous-buses-pump.md * Apply formatting changes --------- Co-authored-by: wangfukang Co-authored-by: wfk007 --- .changeset/nervous-buses-pump.md | 5 +++++ packages/rrweb/src/record/observer.ts | 24 ++++++++++++++---------- 2 files changed, 19 insertions(+), 10 deletions(-) create mode 100644 .changeset/nervous-buses-pump.md diff --git a/.changeset/nervous-buses-pump.md b/.changeset/nervous-buses-pump.md new file mode 100644 index 0000000000..49b7617159 --- /dev/null +++ b/.changeset/nervous-buses-pump.md @@ -0,0 +1,5 @@ +--- +'rrweb': patch +--- + +fix: Resize and MediaInteraction events repeat generated after the iframe appeared diff --git a/packages/rrweb/src/record/observer.ts b/packages/rrweb/src/record/observer.ts index 78690578ad..0da565f085 100644 --- a/packages/rrweb/src/record/observer.ts +++ b/packages/rrweb/src/record/observer.ts @@ -378,9 +378,10 @@ export function initScrollObserver({ return on('scroll', updatePosition, doc); } -function initViewportResizeObserver({ - viewportResizeCb, -}: observerParam): listenerHandler { +function initViewportResizeObserver( + { viewportResizeCb }: observerParam, + { win }: { win: IWindow }, +): listenerHandler { let lastH = -1; let lastW = -1; const updateDimension = callbackWrapper( @@ -400,7 +401,7 @@ function initViewportResizeObserver({ 200, ), ); - return on('resize', updateDimension, window); + return on('resize', updateDimension, win); } function wrapEventWithUserTriggeredFlag( @@ -1035,6 +1036,7 @@ function initMediaInteractionObserver({ blockSelector, mirror, sampling, + doc, }: observerParam): listenerHandler { const handler = callbackWrapper((type: MediaInteractions) => throttle( @@ -1061,11 +1063,11 @@ function initMediaInteractionObserver({ ), ); const handlers = [ - on('play', handler(MediaInteractions.Play)), - on('pause', handler(MediaInteractions.Pause)), - on('seeked', handler(MediaInteractions.Seeked)), - on('volumechange', handler(MediaInteractions.VolumeChange)), - on('ratechange', handler(MediaInteractions.RateChange)), + on('play', handler(MediaInteractions.Play), doc), + on('pause', handler(MediaInteractions.Pause), doc), + on('seeked', handler(MediaInteractions.Seeked), doc), + on('volumechange', handler(MediaInteractions.VolumeChange), doc), + on('ratechange', handler(MediaInteractions.RateChange), doc), ]; return callbackWrapper(() => { handlers.forEach((h) => h()); @@ -1279,7 +1281,9 @@ export function initObservers( const mousemoveHandler = initMoveObserver(o); const mouseInteractionHandler = initMouseInteractionObserver(o); const scrollHandler = initScrollObserver(o); - const viewportResizeHandler = initViewportResizeObserver(o); + const viewportResizeHandler = initViewportResizeObserver(o, { + win: currentWindow, + }); const inputHandler = initInputObserver(o); const mediaInteractionHandler = initMediaInteractionObserver(o);