Skip to content

Conversation

@trusktr
Copy link
Member

@trusktr trusktr commented Jan 11, 2025

Re-opening of

to get the tests to run and update it with latest from main.

alphabetX and others added 2 commits September 13, 2024 13:55
* main:
  code formatting
  update tests.yml: use npm ci instead of npm i for reproducible builds
  Update tests.yml: update setup-node action version
  Update tests.yml to use the latest LTS version of Node.js
  #697: Added a section in the user-guide regarding the new "setNow" functionality.
  #697: Added the ability to override the internal "now" function using the "setNow" function.
  fix: Fixed error when registered tweens are not completed in order
  fix: Fixed error when registered tweens are not completed in order
  test: add test tween unit
  feature: implement group-level onComplete callback, triggering both group and individual tween completion callbacks
@trusktr
Copy link
Member Author

trusktr commented Jan 11, 2025

Hey @alphabetabc, I moved your changes into this branch in the main repo, so that I could get the tests to run. Some of the tests are failing with this change now. Can you fix the tests? Would love to merge this!

@alphabetabc
Copy link

Hey @alphabetabc, I moved your changes into this branch in the main repo, so that I could get the tests to run. Some of the tests are failing with this change now. Can you fix the tests? Would love to merge this!

Sorry, I've been quite busy lately. I'll take a look later

@alphabetabc
Copy link

@trusktr
I have tried to fix it, please confirm if the following code is usable

const elapsedTime = time - this._startTime;
const durationAndDelay = this._duration + (this._repeatDelayTime ?? this._delayTime);
const totalTime = this._duration + this._repeat * durationAndDelay;

const calculateElapsedPortion = () => {
    if (this._duration === 0) return 1;
    if (elapsedTime > totalTime) {
        return 1;
    }

    const timesRepeated = Math.trunc(elapsedTime / durationAndDelay);
    const timeIntoCurrentRepeat = elapsedTime - timesRepeated * durationAndDelay;
    // TODO use %?
    // const timeIntoCurrentRepeat = elapsedTime % durationAndDelay

    const portion = Math.min(timeIntoCurrentRepeat / this._duration, 1);
    if (portion === 0 && elapsedTime === this._duration) {
        return 1;
    }
    if (this._yoyo) {
        if (timesRepeated % 2 === 1) {
            return 1 - portion;
        }
    }

    return portion;
};

image

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants