-
Notifications
You must be signed in to change notification settings - Fork 685
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
[css-pseudo-4] Add highlight pseudo for in-page search #3812
Comments
I find myself really wishing for this when interacting with the ECMAScript specification, which supports its own highlighting of variables in algorithms. For example, visit https://tc39.es/ecma262/multipage/notational-conventions.html#sec-returnifabrupt , click on the italicized argument to highlight all instances of that variable in the section, and then use the native browser find-in-page facility to search for "arg". On my machine, the styling for matching selections is almost completely indistinguishable from that of the page-provided highlights—in fact, the only difference I can discern is slight bolding of the former, although technically the background color is Since there is no standard for in-page match styling, there is no color that the custom functionality could use which would be guaranteed to not have this issue. So what's really missing here is a way for the page to set that styling along with the custom highlighting via something like the above-mentioned |
I would recommend |
We are preparing an intent to prototype this in Chromium (cc @schenney-chromium, @jihyerish). Based on this issue and the discussion in #5233 and #5522, it seems there are a few things worth resolving:
|
I like the proposal of
I think it makes sense for the match to be painted above everything including the selection. Is there a downside to this? I tested in Safari, Chrome, and Firefox (on macOS) and in all three, selection isn't visible while in find-on-page mode. Given that, I don't think there'd ever be a case where you'd want a selection to appear on top of a search match.
This second option sounds similar in some ways to CSS What Safari's doing brings up another question, though – should authors also be able to style the dark backdrop? There is a |
What system color keywords will be assigned? I am assuming For context, § 3.3. Default UA Styles defines
I could not find this in the related issues, so apologies if my search-fu was terrible. |
Split out to another issue: #10329 |
Presumably this is telling the page information about what the user has typed into the find-in-page box which may be a privacy concern, but hopefully we can use the same justification that I used for hidden=until-found and auto-expanding Edit: it sounds like this feature might actually not reveal anything about find-in-page, in which case this is no problem - I'd have to mess around with an implementation to find out. |
The CSS Working Group just discussed The full IRC log of that discussion<fantasai> schenney: Use cases for modifying the colors for find-in-page results on platforms that use colors<fantasai> schenney: wouldn't apply in Safari's case <fantasai> schenney: but both FF and Chromium browsers basically put a highlight the text <fantasai> schenney: and some authors want to tweak colors to avoid conflicts or improve contrast <fantasai> schenney: We prototyped, now want to ask if anyone has comments <fantasai> emilio: we do implement this as a non-exposed system color so seems ok <fantasai> emilio: they're hard-coded, so doesn't expose system colors <fantasai> schenney: Page has no idea of what's actually highlighted <fantasai> schenney: So don't think there are any new privacy issues here. <astearns> fantasai: the main thing to worry about is if the author chooses intentionally-obscurre colors <fserb> annevk, I see. Could we set up a "WHATWG subgroup to discuss canvas text"? Would that work? <fantasai> schenney: There are people trying to prevent people from searching, e.g. suggestion to capture Ctrl+F <fantasai> schenney: similar problem for selection and grammar-error <fserb> annevk if we could have someone to participate at that from Apple, that would work. <fantasai> schenney: If no other comments, then will go forward with previosu resolution. |
This feature would behave the same as ::spelling-error, ::grammer-error and other styling that may reveal user's dictionaries or other private information. A page can see how a search result would be styled if it were a search result, but has no way of knowing whether an element is currently rendered using the style. |
I'm closing this issue since the spec is updated by #10475 |
::spelling-error
and::grammar-error
allow authors to change the style of two browser-provided highlighting mechanisms.Using the same system, it would be useful to have a pseudo to change the styling of the highlight shown by browsers when using in-page search. As browsers differentiate between the currently active search result, and other search results, we'd need two pseudos. Straw-man naming proposals:
::active-search
::inactive-search
Safari goes beyond just highlighting the range and also provides additional effects, including bouncy zooming effects when switching which element is focused, or an effect graying out the rest of the page. The proposal here does not try to account for these UI effects, which would continue to exist as desired by the browser.
Note: this is not covered by proposals discussed previously, such as the one from Microsoft, to enable authors to create their own custom stylable ranges via some kind of js api, since the point here is to style a browser-provided range, not an author provided-range.
The text was updated successfully, but these errors were encountered: