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

:user-invalid & :user-valid browser support #178

Closed
brandonmcconnell opened this issue Oct 2, 2022 · 11 comments
Closed

:user-invalid & :user-valid browser support #178

brandonmcconnell opened this issue Oct 2, 2022 · 11 comments
Labels
accepted An accepted proposal focus-area-proposal Focus Area Proposal

Comments

@brandonmcconnell
Copy link

brandonmcconnell commented Oct 2, 2022

Description

Quoting the specification:

The :user-invalid and the :user-valid pseudo-classes represent an element with incorrect or correct input, respectively, but only after the user has significantly interacted with it.

The :user-invalid pseudo-class must match an :invalid, :out-of-range, or blank-but-:required elements between the time the user has attempted to submit the form and before the user has interacted again with the form element.

The :user-valid pseudo-class must match a :valid element between the time the user has attempted to submit the form and before the user has interacted again with the form element.

User-agents may allow them to match such elements at other times, as would be appropriate for highlighting an error to the user. For example, a UA may choose to have :user-invalid match an :invalid element once the user has typed some text into it and changed the focus to another element, and to stop matching only after the user has successfully corrected the input.

Rationale

There has been plenty of discussions and workarounds supporting this for over a decade now (or at least as far back as I can remember)— not so much the pseudo itself so much as clunky methods to accomplish what this pseudo would provide effortlessly.

Oftentimes, we want to validate/invalidate form data, but we don't want to show the field as valid or invalid until after the first change event so the user has a chance to interact with the form field before the page applies successful/failure styling to the element.

Specification

https://w3c.github.io/csswg-drafts/selectors-4/#user-pseudos

Tests

@brandonmcconnell brandonmcconnell added the focus-area-proposal Focus Area Proposal label Oct 2, 2022
@gsnedders gsnedders added this to the Interop 2023 milestone Oct 2, 2022
@foolip
Copy link
Member

foolip commented Oct 3, 2022

Looks like this is supported in Firefox, and these are the implementation bugs for Chromium and WebKit:
https://bugs.chromium.org/p/chromium/issues/detail?id=1156069
https://bugs.webkit.org/show_bug.cgi?id=222267

(Linked in BCD in mdn/browser-compat-data#17930.)

@foolip foolip moved this to Proposed in Interop 2023 Oct 7, 2022
@foolip foolip removed this from the Interop 2023 milestone Oct 7, 2022
@annevk
Copy link
Member

annevk commented Oct 28, 2022

I wonder if whoever implemented these in Firefox can help out with whatwg/html#8452 as it's not clear how they work in terms of HTML. Selectors doesn't dictate the rules for host languages after all.

@jgraham
Copy link
Contributor

jgraham commented Nov 9, 2022

Seems like @emilio did the Gecko implementation.

@emilio
Copy link

emilio commented Nov 9, 2022

I mostly rejiggered :-moz-ui-{valid,invalid}, which were pre-existing. The rules are a bit complex, but I can try to explain them:

  • For <button>, :valid and :user-valid are equivalent (code
  • Seems like the same is true for form-associated custom-elements (code). That was implemented afterwards, maybe @EdgarChen can comment. Might be useful to allow authors to customize them.
  • For <input>, <select> and <textarea> the rules are described in this comment. <select> code is here, <textarea> is here.

@annevk
Copy link
Member

annevk commented Nov 9, 2022

I think for this to be part of Interop 2023 someone would have to turn that into a PR against the HTML Standard. A lot of it looks somewhat straightforward, but some of the state keeping and when to invalidate that state might be tricky I suppose. And yeah, I suspect that for form-associated elements we need to reconsider when they would apply.

@foolip
Copy link
Member

foolip commented Nov 11, 2022

In the State of CSS 2022 question about browser incompatibilities, there was one mention of :user-invalid and one of :user-valid, so not enough to make the top list in #248.

(I'm commenting on all proposals where I could find some mention at all in State of CSS results.)

@foolip
Copy link
Member

foolip commented Nov 11, 2022

In the MDN short survey on CSS & HTML, "CSS :user-invalid and :user-valid pseudo-classes" was selected by ~11% of survey takers, putting it in the bottom third of the 20 options. (There is some uncertainty as with any survey data.)

@mfreed7
Copy link

mfreed7 commented Nov 12, 2022

I think for this to be part of Interop 2023 someone would have to turn that into a PR against the HTML Standard. A lot of it looks somewhat straightforward, but some of the state keeping and when to invalidate that state might be tricky I suppose. And yeah, I suspect that for form-associated elements we need to reconsider when they would apply.

I agree with this comment. It's tough to tell what the standardized behavior is or should be for this. E.g. there seems to be a lot of flexibility built into this sentence:

User-agents may allow them to match such elements at other times, as would be appropriate for highlighting an error to the user.

@emilio would it be possible to expand on your comment just a bit to summarize the behavior itself?

@foolip foolip added the accepted An accepted proposal label Feb 1, 2023
@foolip
Copy link
Member

foolip commented Feb 1, 2023

Thank you for proposing :user-invalid and :user-valid for gradients for inclusion in Interop 2023.

We are pleased to let you know that this proposal was accepted as part of the Custom Properties focus area. You can follow the progress of this Focus Area on the Interop 2023 dashboard.

For an overview of our process, see the proposal selection summary. Thank you for contributing to Interop 2023!

Posted on behalf of the Interop team.

@foolip foolip closed this as completed Feb 1, 2023
@brandonmcconnell
Copy link
Author

Thank you for proposing :user-invalid and :user-valid for gradients for inclusion in Interop 2023.

@foolip Just to confirm, this is unrelated to gradients

@foolip
Copy link
Member

foolip commented Feb 18, 2023

@brandonmcconnell sorry, of course, that was copypasta.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
accepted An accepted proposal focus-area-proposal Focus Area Proposal
Projects
No open projects
Status: Proposed
Development

No branches or pull requests

7 participants