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 popover=hint #9778

Merged
merged 42 commits into from
Jan 10, 2025
Merged

Add popover=hint #9778

merged 42 commits into from
Jan 10, 2025

Conversation

josepharhar
Copy link
Contributor

@josepharhar josepharhar commented Sep 23, 2023

This PR adds the hint value to the popover attribute. popovers with popover=hint cant be light dismissed like auto popovers, but there can only be one hint open at a time.

Fixes #9776

Explainer: https://open-ui.org/components/popover-hint.research.explainer/#popoverhint-behavior

(See WHATWG Working Mode: Changes for more details.)


/interactive-elements.html ( diff )
/popover.html ( diff )

@mfreed7 mfreed7 mentioned this pull request Sep 29, 2023
3 tasks
@nt1m
Copy link
Member

nt1m commented Oct 8, 2023

I would probably want https://github.com/keithamus/invoker-buttons-proposal to be worked on first before addressing this, as I think it's a building block for this and other declarative attributes.

@mfreed7
Copy link
Contributor

mfreed7 commented Oct 30, 2023

I would probably want https://github.com/keithamus/invoker-buttons-proposal to be worked on first before addressing this, as I think it's a building block for this and other declarative attributes.

So I've significantly updated the popover=hint explainer, and there are a few sections detailing why I believe the functionality described in this PR is independent of the hover-triggering functionality described by the Invokers explainer (note that it was moved to the OpenUI repo). See this section:

Indeed both are important bits of functionality, but I'm hoping we can tackle them independently rather than needing to put up another huge spec PR. That didn't work very well for the original Popover spec PR, at least in my opinion.

@mfreed7 mfreed7 mentioned this pull request Oct 30, 2023
@josepharhar josepharhar added the topic: popover The popover attribute and friends label Dec 21, 2023
@josepharhar
Copy link
Contributor Author

Note to self: this will require additional changes in https://chromium-review.googlesource.com/c/chromium/src/+/5229300 if the corresponding PR to be opened gets merged

Copy link
Contributor

@mfreed7 mfreed7 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ok, I reviewed mostly for the correctness of the algorithms, and things look pretty good. I made a few corrections, but other than those, LGTM.

source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
@mfreed7
Copy link
Contributor

mfreed7 commented Mar 7, 2024

Gentle ping - any chance we could get an initial review of this PR? @annevk @domenic

@domenic
Copy link
Member

domenic commented Oct 22, 2024

Thanks for the comment @annevk. Am I to take it that WebKit is invoking the "strongly recommended" working mode criteria that "There should be no strong implementer objections to the new feature."?

@mfreed7
Copy link
Contributor

mfreed7 commented Oct 22, 2024

WebKit is opposed to this. I don't think this should land.

Thanks for the feedback, @annevk. With reference to the Standards of Behavior, I'd like to ask you to "Take actions that are constructive, and move towards consensus when possible". In this case, I think that'd include a lot more detail about the specifics of your objection, including what obstacles we'd have to overcome in order for you to be supportive of this proposal. I presume (but would love confirmation) that your objection here is related to your comment on the standards position request. If so, could you point out the person we should be talking to in order to co-design a tooltip/hovercard solution that works for Apple?

@mfreed7
Copy link
Contributor

mfreed7 commented Nov 7, 2024

We discussed, in two OpenUI meetings now, the utility of popover=hint in isolation. I.e. without an interesttarget feature. The developer feedback was solidly supportive, primarily because existing hovercards/tooltips today have to use popover=manual and then re-implement all of the light dismiss functionality via javascript. The popover=hint feature would remove the need to manually implement that logic.

@mfreed7
Copy link
Contributor

mfreed7 commented Dec 2, 2024

Given this comment (WebKit/standards-positions#305 (comment)) it sounds like the objection has been removed. Given that it has all checkboxes checked now, and editor approval, would it be ok to land?

@annevk
Copy link
Member

annevk commented Dec 3, 2024

Is there a corresponding accessibility PR? This seems like the kind of feature that needs one.

@mfreed7
Copy link
Contributor

mfreed7 commented Dec 4, 2024

Is there a corresponding accessibility PR? This seems like the kind of feature that needs one.

See this comment mozilla/standards-positions#965 (comment) from @scottaohara. It sounds like all that will be needed is to add hint to the existing list(s) - no "new" behavior is needed beyond what the other popover values already do. @scottaohara any updates on that one?

@annevk annevk added the addition/proposal New features or enhancements label Dec 4, 2024
@domenic
Copy link
Member

domenic commented Dec 6, 2024

I will plan to merge this once we have a html-aam PR adding hint as a sibling of auto and manual.

I was thinking of doing it myself but I'm confused about the status of the html-aam repo vs. the aria monorepo per w3c/html-aam#548.

@lukewarlow
Copy link
Member

Does this actually need any chages to aam? https://w3c.github.io/html-aam/#att-popover - the existing entry doesn't mention the auto or manual values?

@scottaohara
Copy link
Collaborator

scottaohara commented Dec 12, 2024

the PR exists - w3c/aria#2375

but the PR essentially states that there are no mappings tied to a specific value for popover (which is why there wasn't direct mention of the manual or auto states before - because the mappings are the same)

@domenic, just responding to your comment, the HTML AAM repo is essentially an issue tracker now. all spec updates occur over in the mono (aria) repo - direct link to the html aam spec in the mono repo

@domfarolino
Copy link
Member

domfarolino commented Jan 10, 2025

Given (a) the existence of #9778 (comment) which appeared to be the only blocker stopping @domenic from merging this, (b) the fact that he is OOO right now, (c) the commit message being added to the OP, and (d) the formatting nits fixed in 49da2e0, I'll go ahead and merge this PR.

domfarolino added a commit to domfarolino/specfmt that referenced this pull request Jan 10, 2025
When formatting whatwg/html#9778, I noticed
that the previous branch diff logic never explicitly considered
`current_branch`, and it seemed that in part due to this, the diff was
including (only sometimes though?) merge commits, which is incorrect.

The command line syntax introduced by this commit seems to fix this.
@domfarolino domfarolino merged commit 7a307cd into whatwg:main Jan 10, 2025
2 checks passed
@mfreed7
Copy link
Contributor

mfreed7 commented Jan 10, 2025

Thank you @domenic and @domfarolino for the help getting this landed! (And @josepharhar for writing it in the first place.)

@annevk
Copy link
Member

annevk commented Jan 13, 2025

Where is the rename PR for WPT?

@mfreed7
Copy link
Contributor

mfreed7 commented Jan 15, 2025

Where is the rename PR for WPT?

Ah, sorry. Forgot about that - I'll put one up today. Thanks for the reminder.

chromium-wpt-export-bot pushed a commit to web-platform-tests/wpt that referenced this pull request Jan 15, 2025
The spec landed:

  whatwg/html#9778

I also found one more that was just a general popover test that
likely should have been renamed a while ago.

Bug: 40256776
Change-Id: I57f0fb9f25b2e1d8b2b9509bb3c97786c6ac59ac
chromium-wpt-export-bot pushed a commit to web-platform-tests/wpt that referenced this pull request Jan 15, 2025
The spec landed:

  whatwg/html#9778

I also found one more that was just a general popover test that
likely should have been renamed a while ago.

Bug: 40256776
Change-Id: I57f0fb9f25b2e1d8b2b9509bb3c97786c6ac59ac
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6168803
Auto-Submit: Mason Freed <masonf@chromium.org>
Reviewed-by: Di Zhang <dizhangg@chromium.org>
Commit-Queue: Di Zhang <dizhangg@chromium.org>
Cr-Commit-Position: refs/heads/main@{#1406978}
@mfreed7
Copy link
Contributor

mfreed7 commented Jan 16, 2025

Where is the rename PR for WPT?

Ah, sorry. Forgot about that - I'll put one up today. Thanks for the reminder.

web-platform-tests/wpt#50103

Looks like they need manual review.

chromium-wpt-export-bot pushed a commit to web-platform-tests/wpt that referenced this pull request Jan 16, 2025
The spec landed:

  whatwg/html#9778

I also found one more that was just a general popover test that
likely should have been renamed a while ago.

Bug: 40256776
Change-Id: I57f0fb9f25b2e1d8b2b9509bb3c97786c6ac59ac
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6168803
Auto-Submit: Mason Freed <masonf@chromium.org>
Reviewed-by: Di Zhang <dizhangg@chromium.org>
Commit-Queue: Di Zhang <dizhangg@chromium.org>
Cr-Commit-Position: refs/heads/main@{#1406978}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
addition/proposal New features or enhancements topic: popover The popover attribute and friends
Development

Successfully merging this pull request may close these issues.

popover=hint