RESOLVED FIXED 240978
AX: WebKit does not trap user focus inside modals that have been DOM moved
https://bugs.webkit.org/show_bug.cgi?id=240978
Summary AX: WebKit does not trap user focus inside modals that have been DOM moved
Tyler Wilcock
Reported 2022-05-26 14:46:26 PDT
WebKit does not trap user focus inside modals that have been DOM moved. This pattern is used in the WAI-ARIA aria-modal usage example: https://w3c.github.io/aria-practices/examples/dialog-modal/dialog.html
Attachments
Patch (40.69 KB, patch)
2022-05-26 15:12 PDT, Tyler Wilcock
ews-feeder: commit-queue-
Patch (40.83 KB, patch)
2022-05-26 15:35 PDT, Tyler Wilcock
no flags
Patch (33.25 KB, patch)
2022-06-01 14:10 PDT, Tyler Wilcock
no flags
Patch (33.19 KB, patch)
2022-06-03 10:32 PDT, Tyler Wilcock
no flags
Radar WebKit Bug Importer
Comment 1 2022-05-26 14:46:38 PDT
Tyler Wilcock
Comment 2 2022-05-26 15:12:04 PDT
Tyler Wilcock
Comment 3 2022-05-26 15:35:52 PDT
Tyler Wilcock
Comment 4 2022-06-01 14:10:02 PDT
Andres Gonzalez
Comment 5 2022-06-02 08:01:07 PDT
(In reply to Tyler Wilcock from comment #4) > Created attachment 459933 [details] > Patch --- a/Source/WebCore/accessibility/AXObjectCache.cpp +++ a/Source/WebCore/accessibility/AXObjectCache.cpp -Element* AXObjectCache::currentModalNode() +Element* AXObjectCache::recomputeCurrentModalNode() Wouldn't it make more sense to name it updateCurrentModalNode or updateCurrentModalElement and have a void return? Since in most calls the returned value is not used. We have another method named modalNode that can do the update if needed and return the stored pointer. +{ + auto* previousModal = m_currentModalElement.get(); + m_currentModalElement = recomputeCurrentModalNodeInner(); + if (previousModal != m_currentModalElement.get()) { + childrenChanged(rootWebArea()); +#if ENABLE(ACCESSIBILITY_ISOLATED_TREE) + // Because the presence of a modal affects every element on the page, + // regenerate the entire isolated tree with the next cache update. + m_deferredRegenerateIsolatedTree = true; +#endif Would it be more appropriate to do the update of the isolated tree in the childrenChanged or handleChildrenChanged as everything else? Perhaps we need to add an AXNotification for a new modal and update the isolated tree upon that notification. +Element* AXObjectCache::recomputeCurrentModalNodeInner() See comment above about update versus recompute prefix. I think Internal is more customary than Inner as a suffix for a private method name that is invoked by another possibly public method, but I don't feel strongly either way. --- a/Source/WebCore/accessibility/AXObjectCache.h +++ a/Source/WebCore/accessibility/AXObjectCache.h - void handleFocusedUIElementChanged(Node* oldFocusedNode, Node* newFocusedNode); + enum class RecomputeModal : bool { No, Yes }; + void handleFocusedUIElementChanged(Node* oldFocusedNode, Node* newFocusedNode, RecomputeModal = RecomputeModal::Yes); RecomputeModal -> UpdateModal ? +#if ENABLE(ACCESSIBILITY_ISOLATED_TREE) + bool m_deferredRegenerateIsolatedTree { false }; +#endif If we handle this as an AXNotification as the rest of all isolated tree updates, I don't think we would need this.
Tyler Wilcock
Comment 6 2022-06-03 10:32:25 PDT
EWS
Comment 7 2022-06-07 14:45:34 PDT
Committed r295366 (251374@main): <https://commits.webkit.org/251374@main> All reviewed patches have been landed. Closing bug and clearing flags on attachment 460016 [details].
Giacomo Petri
Comment 8 2022-06-13 00:14:11 PDT
Hi, there is still a bug on Safari mobile + VO. I'm not sure if the issue is related to this topic or more to this one https://bugs.webkit.org/show_bug.cgi?id=239295, but on mobile users are still not trapped within the modal. Giacomo
Note You need to log in before you can comment on or make changes to this bug.