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

Add variant for ::file-selector-button pseudo element #4936

Merged
merged 2 commits into from
Sep 23, 2021

Conversation

lukewarlow
Copy link
Contributor

@lukewarlow lukewarlow commented Jul 9, 2021

This PR adds a variant for the ::file-selector-button pseudo element, which is supported by the latest versions of all three engines.

I think I've added to the relevant tests but feel free to point out any others that are required.

@lukewarlow lukewarlow changed the title Add variant for file-selector-button pseudo element Add variant for ::file-selector-button pseudo element Jul 9, 2021
@lukewarlow lukewarlow force-pushed the file-selector-button-variant branch from 60be2a0 to 3b5d12e Compare July 9, 2021 17:06
@mainej
Copy link

mainej commented Aug 21, 2021

+1 I'd love to have this too. Would address tailwindlabs/tailwindcss-forms#25

@lukewarlow
Copy link
Contributor Author

https://play.tailwindcss.com/dAUlXDZt6r - In the meantime a simple plugin like this can address the basic use cases.

Though it doesn't play well with other variants (like hover). My knowledge of tailwind's plugin API isn't good enough to work out why. Potentially, you'd need to fall down into using the raw postcss API mentioned here https://tailwindcss.com/docs/plugins#complex-variants.

@mainej
Copy link

mainej commented Aug 27, 2021

@lukewarlow nice! Your Tailwind Play example uses the older style of defining plugins. I updated it to use the JIT-influenced style of defining plugins, which is what you have in this PR. Now it seems to work with other variants like hover: https://play.tailwindcss.com/Bgd6hn9eI9. (For some reason, the updated Play version works for me on Chrome, but not Firefox. In any case, it should work in a real project.)

I still think this makes sense in the core library, but in the meantime, it's nice to have a quick plugin. Thanks for the inspiration.

@lukewarlow
Copy link
Contributor Author

lukewarlow commented Aug 27, 2021

I agree it makes sense as a core feature. Thanks for working that one out, will be useful in some projects of mine! Odd it doesn't work in Firefox but seems to work in Chrome and Safari. And most people are gonna be using it in a build system anyway so not really an issue.

Edit: it only works in Safari TP not standard Safari. Presumably this relies on some modern browser feature.

@lukewarlow lukewarlow force-pushed the file-selector-button-variant branch from 1567208 to ee756b0 Compare September 4, 2021 10:56
@lukewarlow lukewarlow force-pushed the file-selector-button-variant branch from ee756b0 to 682fa46 Compare September 9, 2021 22:55
@reinink
Copy link
Member

reinink commented Sep 23, 2021

Hey thanks for this PR @lukewarlow, didn't know about this feature! Let's go with just file since file-selector-button is a bear to type 😅 I've also added a test for combining this with hover, which works perfect in the new JIT mode 👍 Thanks again!

@colbyhemond
Copy link

For those that end up here looking for the solution (like myself), here's a link to the section of the tailwind docs that mentions styling file input buttons: https://tailwindcss.com/docs/hover-focus-and-other-states#file-input-buttons

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.

4 participants