From 138d84d054b648a351603a263f0b7cfc285f315e Mon Sep 17 00:00:00 2001 From: mister-ben <1676039+mister-ben@users.noreply.github.com> Date: Sun, 14 Jul 2024 19:04:49 +0200 Subject: [PATCH] fix: Change named to apply last change per frame instead of first --- src/js/component.js | 4 +++- test/unit/component.test.js | 18 +++++++++--------- 2 files changed, 12 insertions(+), 10 deletions(-) diff --git a/src/js/component.js b/src/js/component.js index ad8e67f627..a0420e9ac2 100644 --- a/src/js/component.js +++ b/src/js/component.js @@ -1714,7 +1714,9 @@ class Component { */ requestNamedAnimationFrame(name, fn) { if (this.namedRafs_.has(name)) { - return; + // Don't return, because we want to overwrite + // return; + this.cancelNamedAnimationFrame(name); } this.clearTimersOnDispose_(); diff --git a/test/unit/component.test.js b/test/unit/component.test.js index 903dc8f425..2b384bcd93 100644 --- a/test/unit/component.test.js +++ b/test/unit/component.test.js @@ -1377,7 +1377,7 @@ QUnit.test('requestNamedAnimationFrame should only allow one raf of a specific n comp.requestNamedAnimationFrame(name, handlerTwo); - assert.deepEqual(cancelNames, [], 'no named cancels'); + assert.deepEqual(cancelNames, ['testing'], 'one handler was cancelled'); assert.equal(comp.namedRafs_.size, 1, 'still only one named raf'); assert.equal(comp.rafIds_.size, 1, 'still only one raf id'); @@ -1386,16 +1386,16 @@ QUnit.test('requestNamedAnimationFrame should only allow one raf of a specific n assert.equal(comp.namedRafs_.size, 0, 'we removed a named raf'); assert.equal(comp.rafIds_.size, 0, 'we removed a raf id'); assert.deepEqual(calls, { - one: 1, - two: 0, + one: 0, + two: 1, three: 0 - }, 'only handlerOne was called'); + }, 'only handlerTwo was called'); comp.requestNamedAnimationFrame(name, handlerOne); comp.requestNamedAnimationFrame(name, handlerTwo); comp.requestNamedAnimationFrame(name, handlerThree); - assert.deepEqual(cancelNames, [], 'no named cancels for testing'); + assert.deepEqual(cancelNames, ['testing', 'testing', 'testing'], 'two more cancels'); assert.equal(comp.namedRafs_.size, 1, 'only added one named raf'); assert.equal(comp.rafIds_.size, 1, 'only added one named raf'); @@ -1404,10 +1404,10 @@ QUnit.test('requestNamedAnimationFrame should only allow one raf of a specific n assert.equal(comp.namedRafs_.size, 0, 'we removed a named raf'); assert.equal(comp.rafIds_.size, 0, 'we removed a raf id'); assert.deepEqual(calls, { - one: 2, - two: 0, - three: 0 - }, 'only the handlerOne called'); + one: 0, + two: 1, + three: 1 + }, 'now handlerThree has also been called'); window.requestAnimationFrame = oldRAF; window.cancelAnimationFrame = oldCAF;