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

Hidden DisclosurePanels are given display: none by tailwind's base layer #7160

Closed
neefrehman opened this issue Oct 8, 2024 · 3 comments
Closed

Comments

@neefrehman
Copy link
Contributor

neefrehman commented Oct 8, 2024

Provide a general summary of the issue here

I'm currently implementing Disclosure in a codebase that uses tailwind. At first, when nesting a Table element inside this disclosure, I noticed some jank related to column widths. After some investigation I found that the DisclosurePanel element implicitly had a width of 0, due to having been given display: none by tailwind's @tailwind base layer:

/* Make elements with the HTML hidden attribute stay hidden by default */
[hidden] {
  display: none;
}

Tailwind source can be seen here, (and on the next branch it will be made !important)

To bring the behaviour closer in line with how details/summary elements work, I've had to override this manually:

  /*
    By default tailwind's reset will give any element with the `hidden` attribute `display: none`.
    Here, we undo that default for RAC's `Disclosure` elements, so that hidden `DisclosurePanel`s
    can still inherit a width, bringing them closer in behaviour to `details`/`summary` elements.
  */
  [data-rac][hidden="until-found"] {
    display: block;
  }

But, since I'm also using the tailwindcss-react-aria-components plugin, I wonder if this is something that could be handled there?

🤔 Expected Behavior?

DisclosurePanel elements should inherit their parent's width, even when hidden, as implementations in the docs do.

😯 Current Behavior

DisclosurePanel elements have no width due to tailwind's reset, leading to potentially janky animations when opening them

💁 Possible Solution

The tailwindcss-react-aria-components plugin could help undo this for DisclosurePanel elements.

🔦 Context

No response

🖥️ Steps to Reproduce

Use Disclosure in any codebase that adds tailwind's @tailwind base styles

Version

"react-aria-components": "1.4.0"

What browsers are you seeing the problem on?

Firefox, Chrome, Safari, Microsoft Edge

If other, please specify.

No response

What operating system are you using?

MacOS

🧢 Your Company/Team

No response

🕷 Tracking Issue

No response

@neefrehman neefrehman changed the title DisclosurePanels are given display: none when hidden by tailwind Hidden DisclosurePanels are given display: none by tailwind's base layer Oct 8, 2024
adamwathan added a commit to tailwindlabs/tailwindcss that referenced this issue Oct 8, 2024
Fixes an issue reported by the React Aria Components team here:

adobe/react-spectrum#7160

Basically `hidden="until-found"` behaves very differently than `hidden` and doesn't actually use `display: none`, so we don't want to apply the behavior we apply for the regular `hidden` attribute.
@devongovett
Copy link
Member

Thanks for reporting! I reached out to the Tailwind team about this and they are looking into updating their reset. See tailwindlabs/tailwindcss#14625

RobinMalfait added a commit to tailwindlabs/tailwindcss that referenced this issue Oct 9, 2024
Fixes an issue reported by the React Aria Components team here:

adobe/react-spectrum#7160

Basically `hidden="until-found"` behaves very differently than `hidden` and doesn't actually use `display: none`, so we don't want to apply the behavior we apply for the regular `hidden` attribute.
RobinMalfait added a commit to tailwindlabs/tailwindcss that referenced this issue Oct 9, 2024
…#14625)

Fixes an issue reported by the React Aria Components team here:

adobe/react-spectrum#7160

Basically `hidden="until-found"` behaves very differently than `hidden`
and doesn't actually use `display: none`, so we don't want to apply the
behavior we apply for the regular `hidden` attribute.

---------

Co-authored-by: Robin Malfait <malfait.robin@gmail.com>
RobinMalfait added a commit to tailwindlabs/tailwindcss that referenced this issue Oct 9, 2024
…#14631)

Fixes an issue reported by the React Aria Components team here:

adobe/react-spectrum#7160

Basically `hidden="until-found"` behaves very differently than `hidden`
and doesn't actually use `display: none`, so we don't want to apply the
behavior we apply for the regular `hidden` attribute.
@RobinMalfait
Copy link

This should be fixed and will be available in the next release of Tailwind CSS. Will leave a comment when we have a new version out.

RobinMalfait added a commit to tailwindlabs/tailwindcss that referenced this issue Oct 9, 2024
…#14631)

Fixes an issue reported by the React Aria Components team here:

adobe/react-spectrum#7160

Basically `hidden="until-found"` behaves very differently than `hidden`
and doesn't actually use `display: none`, so we don't want to apply the
behavior we apply for the regular `hidden` attribute.
@RobinMalfait
Copy link

Hi! Quick update, this has been released in the latest v3 version and the latest v4 alpha release.

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

No branches or pull requests

4 participants