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

[Dialog] dialog dom not removed after end animation with React router v7 #44906

Open
diginikkari opened this issue Dec 31, 2024 · 1 comment
Open
Assignees
Labels
component: dialog This is the name of the generic UI component, not the React module! status: waiting for author Issue with insufficient information

Comments

@diginikkari
Copy link

diginikkari commented Dec 31, 2024

Steps to reproduce

Issue is hard to reproduce, but I thought that it still best to submit this, incase someone else has the same problem. At least then there is some information available.

Issue started occuring after we upgraded to react router v7, no any other changes. I have not been able to reproduce this locally, it started failing in our e2e test in CI. Same tests are passing locally. It also sometimes passes in CI so it seems to be some timing related.

Current behavior

In some unknown cases when dialog is closed, the dialog dom is not removed but it still mounted with opacity 0 and it blocks mouse clicks and scroll.

Expected behavior

After dialog is closed open=false and transition is ended, dialog should be removed from dom.

Context

We had similar issue earlier in some cases when there were react suspense used with Dialog component. Now we don't use any suspense behaviour, but the end issue is same. Issue occured after we upgraded to react router v7. Some other issues I bumped while investigating, which might bring some context are:

reactjs/react-transition-group#817
remix-run/react-router#10567

Dialog open state is controlled by useState. Dialog close callback is setting state to false, and setting some useSearchParams based on values returned from the close callback.

When I set the transitionDuration={0} in Dialog component, issue didn't occur. But as I mentioned this is very flaky issue, so it could also be just lucky guess.

Your environment

System: OS: macOS 15.1.1 Binaries: Node: 20.18.0 - ~/.nvm/versions/node/v20.18.0/bin/node npm: 10.8.2 - ~/.nvm/versions/node/v20.18.0/bin/npm pnpm: 9.10.0 - ~/.nvm/versions/node/v20.18.0/bin/pnpm Browsers: Chrome: 131.0.6778.205 Edge: Not Found Safari: 18.1.1 npmPackages: @emotion/react: 11.14.0 => 11.14.0 @emotion/styled: 11.14.0 => 11.14.0 @mui/icons-material: ^6.3.0 => 6.3.0 @mui/lab: 6.0.0-beta.21 => 6.0.0-beta.21 @mui/material: ^6.3.0 => 6.3.0 @mui/x-data-grid: ^7.23.4 => 7.23.4 @mui/x-date-pickers: ^7.23.3 => 7.23.3 @mui/x-tree-view: ^7.23.2 => 7.23.2 @types/react: 18.3.12 => 18.3.12 react: 18.3.1 => 18.3.1 react-dom: 18.3.1 => 18.3.1 typescript: 5.7.2 => 5.7.2

Browser used in e2e is Chromium

Search keywords: dialog, react router v7

@diginikkari diginikkari added the status: waiting for maintainer These issues haven't been looked at yet by a maintainer label Dec 31, 2024
@oliviertassinari oliviertassinari added the component: dialog This is the name of the generic UI component, not the React module! label Dec 31, 2024
@mnajdova
Copy link
Member

It's hard to know what may cause it without a reproduction. It would be great if you can at least share a repository where this happens, if it is public. Can you at least share a minimal reproduction code snippet where this happens?

@mnajdova mnajdova added status: waiting for author Issue with insufficient information and removed status: waiting for maintainer These issues haven't been looked at yet by a maintainer labels Jan 20, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
component: dialog This is the name of the generic UI component, not the React module! status: waiting for author Issue with insufficient information
Projects
None yet
Development

No branches or pull requests

4 participants