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]: #881

Closed
juanzgc opened this issue Oct 22, 2021 · 8 comments
Closed

[Bug]: #881

juanzgc opened this issue Oct 22, 2021 · 8 comments

Comments

@juanzgc
Copy link

juanzgc commented Oct 22, 2021

What package within Headless UI are you using?

@headlessui/react

What version of that package are you using?

1.4.1

What browser are you using?

Chrome

Reproduction repository

none

Describe your issue

I'm using the following Context Provider to handle two dialog states:

  • Modal Provider
  • Alert Provider

The Modal provider opens a Dialog with a form that when submitted adds products to the user's cart.
The Alert provider opens a Dialog - Alert Popup.

In the following scenario, a user intends to add a product to their cart. The Modal Dialog is set to open. Upon submission the Modal Dialog is set to false to disable and close the Dialog.

After the Modal Dialog is set to close, I set the Alert Provider to open, in order to display a Success Alert to the user confirming their product has been added to their cart.

The issue is the following:
After the Modal Dialog is closed and the Alert Dialog opens, the <html> element gets overflow: hidden. This is usually expected, but not once a user clicks to close the Dialog. In my case I close the Alert Dialog, but the overflow: hidden is added on the close. As you can tell in the GIF below, while the Alert Dialog is open a user can scroll. But once he/she closes the Dialog, the user can no longer scroll. It seems that the order of the events are incorrect.

Just to point out this error only happens in the case where a user submits the Modal Dialog form and then the Success Dialog appears.

TailwindUIIssue

@juanzgc
Copy link
Author

juanzgc commented Oct 22, 2021

Temporary solution to the problem:

Upon submit form within Modal, wrap the success alert within a timeout (I set it to 500ms), so that we give the DOM some time to remove the overflow: hidden and re-add it in time for the Success Alert.

@RobinMalfait
Copy link
Member

Hey! Thank you for your bug report!
Much appreciated! 🙏

I don't think this is an issue anymore, but can you double check that by bumping to the latest version of Headless UI? If this issue still occurs, can you create a new issue with a minimal reproduction repo attached?

@okbill
Copy link

okbill commented Jan 26, 2022

I'm facing same issue with version 1.4.3. After the Modal Dialog is opened, the element gets overflow: hidden. However, when Model Dialog is closed, overflow:hidden is not removed from html element. Should I remove it manually?

@RobinMalfait
Copy link
Member

@okbill can you create a reproduction repo and open a new issue?

@juanzgc
Copy link
Author

juanzgc commented Jan 26, 2022

@okbill If you create a new issue do you mind tagging me or including the issue number here as well.

Yes, I’m still able to reproduce @RobinMalfait

would it be possible to re-open this issue?

@Milankorangi
Copy link

I get same issue

@hsellik
Copy link

hsellik commented Jun 7, 2022

Same issue for me, please reopen.

@RobinMalfait
Copy link
Member

If this is still a problem for anyone, please open a new issue with a proper reproduction Repo / CodeSandbox attached so that we can take a look at the problem.

@tailwindlabs tailwindlabs locked as off-topic and limited conversation to collaborators Jun 7, 2022
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

No branches or pull requests

5 participants