Bug 151657
Summary: | AX: VoiceOver with Safari Bug: aria-activedescendant not respected when container has absolute position and child has flex display. | ||
---|---|---|---|
Product: | WebKit | Reporter: | wilson.louie |
Component: | Accessibility | Assignee: | Nobody <webkit-unassigned> |
Status: | NEW | ||
Severity: | Major | CC: | webkit-bug-importer |
Priority: | P2 | Keywords: | InRadar |
Version: | Safari 9 | ||
Hardware: | iPhone / iPad | ||
OS: | iOS 9.0 | ||
URL: | https://jsbin.com/vafubucuyo/edit?output |
wilson.louie
Hi,
I'm writing to report an accessibility related bug that is reproducible in both iOS 8 and iOS 9 using VoiceOver with Safari: aria-activedescendant is not respected when a container element has absolute position and the child element has flex display property. The examples in this link demonstrate this bug: https://jsbin.com/vafubucuyo/edit?output
The link brings up a page with 6 cases, each with a button and an unordered list. The 6 cases differ only by the CSS applied to each. Clicking a button induces browser focus on the list below the button via javascript. Each list uses aria-activedescendant so that when browser focus is on the list, "logical focus" is on the first list item. That is, if you turn on VoiceOver, move cursor to 'Action' button, double tap, then the cursor should move to 'Eat' item. This works as expected in every case except the last one, where the VoiceOver cursor remains on the 'Action' button rather than moving to the first item. This last case differs from the other cases only in that the list is absolutely positioned and the list items have flex display properties.
Some important things to note:
- This will be encountered often in the wild. "position: absolute with aria-activedescendant" is a very likely combination for UI widgets such as popup menu, and flex display is also becoming popular with wide browser support. Therefore, a common setup for a popup menu would be the container having position: absolute with aria-activedescendant, and the items having flex display.
- This platform bug makes that common setup completely inaccesible. The VoiceOver cursor doesn't move to the Menu when it is launched, so VoiceOver users can't use it.
- Many page authors will be unsuccessful in identifying a workaround (causing the page to remain inaccessible for VoiceOver users), as it takes quite a lot of debugging effort to narrow down what is triggering this platform issue, and the answer is completely non-obvious.
- This is not an issue with other screen readers on touch devices, e.g. Android Talkback.
If possible, I would also like to request a bug number with URL so we can track it.
Thank you very much for your time and attention, and please feel free to contact me or Jim (CCed) if you have any additional questions or comments regarding this bug.
Sincerely,
Wilson
Attachments | ||
---|---|---|
Add attachment proposed patch, testcase, etc. |
Radar WebKit Bug Importer
<rdar://problem/23688652>