-
Notifications
You must be signed in to change notification settings - Fork 2.8k
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
When the popover attribute is removed, the hide popover algorithm will return too early #9367
Comments
Since Chromium's implementation seems to have been the main inspiration for the spec, it seems worth to mention that implementation is sometimes imprecisely checking for whether an element has has the popover attribute: https://source.chromium.org/chromium/chromium/src/+/refs/heads/main:third_party/blink/renderer/core/html/html_element.cc;l=1277;drc=c4efcabd32a851d4d7816206d3c8793a55e9d57e So one way forward could be to check for which callers that method's return value might differ from the element actually having a popover attribute. |
I see. My first thought would be to add a parameter to hide popover and to check popover validity called "skipAttributeCheck", which would be set to true when hide popover is called from the attribute removal steps.
I don't fully understand... is this the same as my "skipAttributeCheck" idea? |
That seems rather hacky. That parameter would have to be passed to all three calls of "check popover validity" in the hide popover algorithm. The thing is, it opens the door for misuse of of the hide popover algorithm and "check popover validity".
No. It's an approach which might help to determine a cleaner solution for this issue. |
To be explicit, the "skipAttributeCheck" idea should work. |
Is "that method" the "check popover validity" algorithm? I don't see how we can get around this without changing check popover validity to not look at the attribute or replacing the call to check popover validity with something else that doesn't care about the attribute. |
Sorry for the imprecision. With "that method", |
Maybe "skipAttributeCheck" could be expanded to a "ignoreDomState" parameter which would also satisfy the need to hide the popover after it has been disconnected: whatwg/dom#1185 (comment) Instead of modifying the check popover algorithm, we could just replace calls to the check popover algorithm with a simple check of whether or not the popover is in the showing state when the hide popover algorithm is called with the "ignoreDomState" option |
Fixes whatwg#9161 Fixes whatwg#9367 Makes obsolete whatwg/dom#1185 This PR prevents the hide popover algorithm from returning early when the popover attribute is removed or when the element with the popover attribute is removed from the document. The fireEvents parameter is used as an indicator that either the element is being removed or that the attribute is being removed, and when it is false, the calls to check popover validity are replaced with a check to simply see if the popover is already hidden. This patch also makes removal of the popover attribute stop firing events in order to signal to the hide popover algorithm that checks for the popover attribute should be ignored.
Fixes whatwg#9161 Fixes whatwg#9367 Makes obsolete whatwg/dom#1185 This PR prevents the hide popover algorithm from returning early when the popover attribute is removed or when the element with the popover attribute is removed from the document. The fireEvents parameter is used as an indicator that either the element is being removed or that the attribute is being removed, and when it is false, the calls to check popover validity are replaced with a check to simply see if the popover is already hidden. This patch also makes removal of the popover attribute stop firing events in order to signal to the hide popover algorithm that checks for the popover attribute should be ignored.
I opened a PR to implement my last comment: #9457 |
Given whatwg/dom#1176, the popover attribute is removed before running the element's attribute change steps.
Those steps are defined for the popover attribute: https://html.spec.whatwg.org/#attr-popover which in step 3 invoke the hide popover algorithm (https://html.spec.whatwg.org/#hide-popover-algorithm). That invokes checking the popover validity (https://html.spec.whatwg.org/#check-popover-validity) as its first step and if it returns
false
, returns early. The latter function checks in its first step, whether the element's popover attribute is in the "no popover state". Hence,will return early from the hide popover algorithm. Hence, the popover will remain open.
Seems related to #9161 and whatwg/dom#1185 (comment)
CC @josepharhar @jakearchibald @rwlbuis
The text was updated successfully, but these errors were encountered: