Bug 135689

Summary: AX: event.target should sometimes be a descendant element on AXPress-triggered mouse clicks
Product: WebKit Reporter: James Craig <jcraig>
Component: AccessibilityAssignee: chris fleizach <cfleizach>
Status: RESOLVED FIXED    
Severity: Normal CC: aboxhall, apinheiro, cfleizach, commit-queue, dino, dmazzoni, jcraig, jdiggs, mario, samuel_white, webkit-bug-importer
Priority: P2 Keywords: InRadar
Version: 528+ (Nightly build)   
Hardware: All   
OS: All   
Bug Depends on: 131426    
Bug Blocks:    
Attachments:
Description Flags
test case
none
updated test case
none
patch mario: review+

James Craig
Reported 2014-08-06 22:26:01 PDT
AXPress sometimes triggers the click event (and other mouse events) on a different element than a real mouse click would use. We should try using hit-testing at the center of the clickable (link, button, etc.) to determine the element on which to initiate the mouse events. In some cases, it may be better to a descendant node as the event.target. If the center point hit-test results in a node that is not a descendant, we should ignore it and fire the event on the original element. To be clear, I don’t think WebKit is doing anything wrong, but there are times when web authors do silly things. VO+Space doesn’t work, but routing the mouse to an element and triggering a simulated mouse click does. This idea is mainly to work around those web authoring problems, and make it so that AXPress works in more scenarios.
Attachments
test case (736 bytes, text/html)
2014-08-06 23:26 PDT, James Craig
no flags
updated test case (1.68 KB, text/html)
2014-08-07 00:26 PDT, James Craig
no flags
patch (4.94 KB, patch)
2014-12-15 23:54 PST, chris fleizach
mario: review+
Radar WebKit Bug Importer
Comment 1 2014-08-06 22:26:17 PDT
James Craig
Comment 2 2014-08-06 23:15:10 PDT
Looks like at least part of this was done in bug 131426. I'll try to attach a test case where it doesn't work.
James Craig
Comment 3 2014-08-06 23:26:49 PDT
Created attachment 236174 [details] test case
James Craig
Comment 4 2014-08-06 23:28:36 PDT
In the attached test case, the second clickable element (image inside button) is trigger by AXPress, but the first clickable element (span inside link) is only clickable with the mouse, not AXPress.
James Craig
Comment 5 2014-08-07 00:26:51 PDT
Created attachment 236176 [details] updated test case updated test case logs the event target and includes some failure cases to ensure we don't click things that are positioned over the top of the element in the VO cursor.
James Craig
Comment 6 2014-08-08 11:25:48 PDT
Might need to ignore any child that does not accept pointer events via CSS. See bug 11395 and Dean's write-up: http://www.webkit.org/specs/PointerEventsProperty.html
chris fleizach
Comment 7 2014-12-15 23:54:39 PST
chris fleizach
Comment 8 2014-12-15 23:55:35 PST
Note: I did not cover the cases in your original test case about the intercepting view. We have code specifically to fall back to the original element if we hit-test to a non-descendant. I'm worried about removing that code.
Mario Sanchez Prada
Comment 9 2014-12-18 13:21:04 PST
Comment on attachment 243353 [details] patch View in context: https://bugs.webkit.org/attachment.cgi?id=243353&action=review > LayoutTests/accessibility/press-target-uses-text-descendant-node.html:21 > + .target { > + background-color: yellow; > + } Nit: this looks misaligned
chris fleizach
Comment 10 2014-12-18 14:59:41 PST
Note You need to log in before you can comment on or make changes to this bug.