Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[BUG] AnimatePresence - enter and exit animations are mixed when they alternate rapidly #2618

Closed
Thanaen opened this issue Apr 11, 2024 · 7 comments Β· Fixed by #2741
Closed
Labels
bug Something isn't working

Comments

@Thanaen
Copy link

Thanaen commented Apr 11, 2024

1. Read the FAQs πŸ‘‡
Done βœ…

2. Describe the bug
Enter and exit animations are mixed when they alternate rapidly.

3. IMPORTANT: Provide a CodeSandbox reproduction of the bug
https://stackblitz.com/edit/vitejs-vite-5ocwzr?file=src%2FApp.tsx

4. Steps to reproduce

  1. Slow click on "Next" and "Previous" to see the animation properly working
  2. Now quickly click on "Next" and "Previous" to see the animation break

5. Expected behavior

The animation that works when slowly clicking on "Next" and "Previous" should also work when quickly clicking on "Next" and "Previous"

6. Video or screenshots
framer-presence-issue

If applicable, add a video or screenshots to help explain the bug.

7. Environment details
Tested on:

  • Microsoft Edge 123.0.2420.81
  • Google Chrome 123.0.6312.123
  • Firefox 124.0.2

Tested on both framer-motion@^10 (currently 10.18.0) & framer-motion@^11 (currently 11.0.28)

UPDATE:
The problem doesn't actually exist on 10.18.0, even though this version has a small glitch visual (it blinks) when you make a quick change.

@Thanaen Thanaen added the bug Something isn't working label Apr 11, 2024
@Thanaen
Copy link
Author

Thanaen commented Apr 11, 2024

PS: This is possibly a duplicate of bug #2554 , but the work-around proposed in this bug (use framer-motion@11.0.10) does not solve the problem in my repro repository.

@Thanaen
Copy link
Author

Thanaen commented Apr 11, 2024

After analysis, it would appear that you end up with both elements systematically in the DOM when you quickly do the "Next" / "Previous", which corresponds to the situation in the other bug mentioned.

@beefchimi
Copy link

beefchimi commented Apr 29, 2024

I have also been battling with this issue for awhile, and have not found a fix.

While I am unable to reproduce the issue in the StackBlitz link provided by the author, I can consistently re-create it in several of my local projects.

Here is a video of a TextArea UI animating some "invalid character count" UI. We can see that the UI animates in/out perfectly when making edits at a moderate pace. But once I start making edits more quickly - such as removing and re-adding the e - the "invalid UI" gets stuck and remains visible even after the conditions that would render it are no longer true.

hereisme.mov

The code for this would look something like:

const characterCountMarkup = !validateUsernameLength(value) ? (
    <CharacterCount key={`UserName-CharacterCount-${value.length}`} count={value.length} />
) : null;

<AnimatePresence>{characterCountMarkup}</AnimatePresence>

I am currently on version 11.1.7 but have tried this on 11.0 as well with the same result.

As indicated by OP, there appear to be several issues raising this same concern: #2554 and #2462

@beefchimi
Copy link

beefchimi commented Apr 30, 2024

I've created another minimal reproduction in case it is helpful:
https://stackblitz.com/edit/framer-motion-fast-change-bug?terminal=dev

bug.mov

As discovered in the other threads... opacity seems to be the culprit in causing this bug. I've forked my reproduction above to use a translate animation, and it appears to work without issue:
https://stackblitz.com/edit/framer-motion-fast-change-bug-workaround?terminal=dev

However... for my specific needs, I do in fact need an opacity animation.

@Thanaen
Copy link
Author

Thanaen commented Apr 30, 2024

@beefchimi
Not using opacity reduces the problem, but doesn't solve it entirely (link to my own comment πŸ˜„: #2554 (comment))

psychedelicious added a commit to invoke-ai/InvokeAI that referenced this issue May 6, 2024
There are a number of bugs with `framer-motion` that can result in sync issues with AnimatePresence and the conditionally rendered component.

You can see this if you rapidly click an accordion, occasionally it gets out of sync and is closed when it should be open.

This is a bigger problem with the viewer where the user may hold down the `z` key. It's trivial to get it to lock up.

For now, just remove the animation entirely.

Upstream issues for reference:
motiondivision/motion#2023
motiondivision/motion#2618
motiondivision/motion#2554
hipsterusername pushed a commit to invoke-ai/InvokeAI that referenced this issue May 6, 2024
There are a number of bugs with `framer-motion` that can result in sync issues with AnimatePresence and the conditionally rendered component.

You can see this if you rapidly click an accordion, occasionally it gets out of sync and is closed when it should be open.

This is a bigger problem with the viewer where the user may hold down the `z` key. It's trivial to get it to lock up.

For now, just remove the animation entirely.

Upstream issues for reference:
motiondivision/motion#2023
motiondivision/motion#2618
motiondivision/motion#2554
@Taib-Rabah
Copy link

I also faced that problem, I had to prevent the user from changing the state rapidly by disabling the buttons while the animation is running

here's what I created if any1 is interested:

@LeonLiu2020
Copy link

I ran into the same problem. And it's not only about opacity, just using x, the same problem occurs. Someone mentioned in another issue that using different keys could help. I tried that and didn't work for me. In the DOM tree, there are many elements with different keys that should disappear due to conditional rendering, but none of them did.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

Successfully merging a pull request may close this issue.

4 participants