Add ToggleEvent.source#11186
Conversation
This adds a new Element attribute to ToggleEvent called invoker. The ToggleEvent's invoker attribute is set to the element which invoked the element which the ToggleEvent is being fired on. Invokers can be set up as a parameter passed to element.showPopover(), an element with the popovertarget attribute, or an element with the commandfor attribute. Fixes whatwg#9111
|
I haven't kept up with all the command discussions, but didn't we decide never to use the word "invoker" in the public APIs? (I've been a bit disappointed to see it popping up in documentation given that decision, but that's a separate thing...) I thought we settled on |
|
|
|
Thank you both! I renamed it from invoker to source. |
keithamus
left a comment
There was a problem hiding this comment.
Generally this looks good, and I think it is well motivated. I've done what I'll call a "pseudo editorial review pass" and by my eyes this has no editorial issues.
Some meta commentary that's perhaps worth pointing out: details elements toggling, and dialog.show()/showModal(), all dispatch toggle events where the source will be null. I think that's a little odd, and maybe worth discussing, but I don't see it as problematic to change in a follow-up, or possibly never. For example it might be nice to later add {source} as an argument to show()/showModal().
|
Thanks Keith! If command invokers make it possible to declaratively toggle a details element in the future, we could make the command attribute invoker element get set as the source of the toggle event. We could also use the summary element as Luke mentioned in the issue thread if that seems valuable, hopefully that's not too hard to spec. Adding a source argument to show()/showModal() makes sense, but since that argument already does more for popovers I'm not sure that this change alone justifies adding that as a parameter to those methods. If an invoker/source argument is ever added though, we should add it as the source of the toggle event. |
There was a problem hiding this comment.
Generally looks good, but I think we can do the events betterNope, we can't, I was wrong.
Also, I haven't yet done a final check that all updated algorithms match all their call sites. It looks likely that you got them all, but if you want to double-check that could save us some time.
I just double checked and fixed two of them |
I recently added this to the spec PR after incorporating spec changes for the addition of dialog.requestClose: whatwg/html#11186 Bug: 4080188 Change-Id: Ia6a3a2560349760219a863dba814c5addfa60165 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6598554 Reviewed-by: Mason Freed <masonf@chromium.org> Commit-Queue: Joey Arhar <jarhar@chromium.org> Cr-Commit-Position: refs/heads/main@{#1468857}
The spec PR has been merged, so these WPTs should no longer be marked as tentative: whatwg/html#11186 Bug: 408018828 Change-Id: I6ff9da8ab80551cdb4cae3cfca3cb60872806dfa Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6621684 Reviewed-by: Luke <lwarlow@igalia.com> Commit-Queue: Luke <lwarlow@igalia.com> Cr-Commit-Position: refs/heads/main@{#1469501}
The spec PR has been merged, so these WPTs should no longer be marked as tentative: whatwg/html#11186 Bug: 4080188 Change-Id: I6ff9da8ab80551cdb4cae3cfca3cb60872806dfa Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6621684 Reviewed-by: Luke <lwarlow@igalia.com> Commit-Queue: Luke <lwarlow@igalia.com> Cr-Commit-Position: refs/heads/main@{#1469501}
The spec PR has been merged, so these WPTs should no longer be marked as tentative: whatwg/html#11186 Bug: 4080188 Change-Id: I6ff9da8ab80551cdb4cae3cfca3cb60872806dfa Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6621684 Reviewed-by: Luke <lwarlow@igalia.com> Commit-Queue: Luke <lwarlow@igalia.com> Cr-Commit-Position: refs/heads/main@{#1469501}
…requestclose, a=testonly Automatic update from web-platform-tests Implement ToggleEvent.source for dialog requestclose I recently added this to the spec PR after incorporating spec changes for the addition of dialog.requestClose: whatwg/html#11186 Bug: 408018828 Change-Id: Ia6a3a2560349760219a863dba814c5addfa60165 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6598554 Reviewed-by: Mason Freed <masonf@chromium.org> Commit-Queue: Joey Arhar <jarhar@chromium.org> Cr-Commit-Position: refs/heads/main@{#1468857} -- wpt-commits: 4f0e0581b96db8b8cb82c1ca74ee08e47225fed0 wpt-pr: 52935
…ve, a=testonly Automatic update from web-platform-tests Make ToggleEvent.source WPTs non-tentative The spec PR has been merged, so these WPTs should no longer be marked as tentative: whatwg/html#11186 Bug: 408018828 Change-Id: I6ff9da8ab80551cdb4cae3cfca3cb60872806dfa Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6621684 Reviewed-by: Luke <lwarlow@igalia.com> Commit-Queue: Luke <lwarlow@igalia.com> Cr-Commit-Position: refs/heads/main@{#1469501} -- wpt-commits: 70f0a19eac6b582538f523fdfe19fced1b6b4e1f wpt-pr: 52967
…requestclose, a=testonly Automatic update from web-platform-tests Implement ToggleEvent.source for dialog requestclose I recently added this to the spec PR after incorporating spec changes for the addition of dialog.requestClose: whatwg/html#11186 Bug: 408018828 Change-Id: Ia6a3a2560349760219a863dba814c5addfa60165 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6598554 Reviewed-by: Mason Freed <masonf@chromium.org> Commit-Queue: Joey Arhar <jarhar@chromium.org> Cr-Commit-Position: refs/heads/main@{#1468857} -- wpt-commits: 4f0e0581b96db8b8cb82c1ca74ee08e47225fed0 wpt-pr: 52935
…ve, a=testonly Automatic update from web-platform-tests Make ToggleEvent.source WPTs non-tentative The spec PR has been merged, so these WPTs should no longer be marked as tentative: whatwg/html#11186 Bug: 408018828 Change-Id: I6ff9da8ab80551cdb4cae3cfca3cb60872806dfa Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6621684 Reviewed-by: Luke <lwarlow@igalia.com> Commit-Queue: Luke <lwarlow@igalia.com> Cr-Commit-Position: refs/heads/main@{#1469501} -- wpt-commits: 70f0a19eac6b582538f523fdfe19fced1b6b4e1f wpt-pr: 52967
…requestclose, a=testonly Automatic update from web-platform-tests Implement ToggleEvent.source for dialog requestclose I recently added this to the spec PR after incorporating spec changes for the addition of dialog.requestClose: whatwg/html#11186 Bug: 408018828 Change-Id: Ia6a3a2560349760219a863dba814c5addfa60165 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6598554 Reviewed-by: Mason Freed <masonfchromium.org> Commit-Queue: Joey Arhar <jarharchromium.org> Cr-Commit-Position: refs/heads/main{#1468857} -- wpt-commits: 4f0e0581b96db8b8cb82c1ca74ee08e47225fed0 wpt-pr: 52935 UltraBlame original commit: 3d3513ffa8b83bb57598a1baf6a00479b4178660
…ve, a=testonly Automatic update from web-platform-tests Make ToggleEvent.source WPTs non-tentative The spec PR has been merged, so these WPTs should no longer be marked as tentative: whatwg/html#11186 Bug: 408018828 Change-Id: I6ff9da8ab80551cdb4cae3cfca3cb60872806dfa Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6621684 Reviewed-by: Luke <lwarlowigalia.com> Commit-Queue: Luke <lwarlowigalia.com> Cr-Commit-Position: refs/heads/main{#1469501} -- wpt-commits: 70f0a19eac6b582538f523fdfe19fced1b6b4e1f wpt-pr: 52967 UltraBlame original commit: 3adec0711c8851da2c80a50466b7e2527d4dd8d4
…requestclose, a=testonly Automatic update from web-platform-tests Implement ToggleEvent.source for dialog requestclose I recently added this to the spec PR after incorporating spec changes for the addition of dialog.requestClose: whatwg/html#11186 Bug: 408018828 Change-Id: Ia6a3a2560349760219a863dba814c5addfa60165 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6598554 Reviewed-by: Mason Freed <masonfchromium.org> Commit-Queue: Joey Arhar <jarharchromium.org> Cr-Commit-Position: refs/heads/main{#1468857} -- wpt-commits: 4f0e0581b96db8b8cb82c1ca74ee08e47225fed0 wpt-pr: 52935 UltraBlame original commit: 3d3513ffa8b83bb57598a1baf6a00479b4178660
…ve, a=testonly Automatic update from web-platform-tests Make ToggleEvent.source WPTs non-tentative The spec PR has been merged, so these WPTs should no longer be marked as tentative: whatwg/html#11186 Bug: 408018828 Change-Id: I6ff9da8ab80551cdb4cae3cfca3cb60872806dfa Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6621684 Reviewed-by: Luke <lwarlowigalia.com> Commit-Queue: Luke <lwarlowigalia.com> Cr-Commit-Position: refs/heads/main{#1469501} -- wpt-commits: 70f0a19eac6b582538f523fdfe19fced1b6b4e1f wpt-pr: 52967 UltraBlame original commit: 3adec0711c8851da2c80a50466b7e2527d4dd8d4
…requestclose, a=testonly Automatic update from web-platform-tests Implement ToggleEvent.source for dialog requestclose I recently added this to the spec PR after incorporating spec changes for the addition of dialog.requestClose: whatwg/html#11186 Bug: 408018828 Change-Id: Ia6a3a2560349760219a863dba814c5addfa60165 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6598554 Reviewed-by: Mason Freed <masonfchromium.org> Commit-Queue: Joey Arhar <jarharchromium.org> Cr-Commit-Position: refs/heads/main{#1468857} -- wpt-commits: 4f0e0581b96db8b8cb82c1ca74ee08e47225fed0 wpt-pr: 52935 UltraBlame original commit: 3d3513ffa8b83bb57598a1baf6a00479b4178660
…ve, a=testonly Automatic update from web-platform-tests Make ToggleEvent.source WPTs non-tentative The spec PR has been merged, so these WPTs should no longer be marked as tentative: whatwg/html#11186 Bug: 408018828 Change-Id: I6ff9da8ab80551cdb4cae3cfca3cb60872806dfa Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6621684 Reviewed-by: Luke <lwarlowigalia.com> Commit-Queue: Luke <lwarlowigalia.com> Cr-Commit-Position: refs/heads/main{#1469501} -- wpt-commits: 70f0a19eac6b582538f523fdfe19fced1b6b4e1f wpt-pr: 52967 UltraBlame original commit: 3adec0711c8851da2c80a50466b7e2527d4dd8d4
This adds a new Element attribute to ToggleEvent called source. The ToggleEvent's source attribute is set to the element which invoked the element which the ToggleEvent is being fired on. Sources can be set up as a parameter passed to element.showPopover(), an element with the popovertarget attribute, or an element with the commandfor attribute.
Fixes #9111
(See WHATWG Working Mode: Changes for more details.)
/form-control-infrastructure.html ( diff )
/form-elements.html ( diff )
/infrastructure.html ( diff )
/interaction.html ( diff )
/interactive-elements.html ( diff )
/popover.html ( diff )