NEW 209975
AX: combobox aria-activedescendant is not read in VoiceOver unless the listbox has `display: none` until input has focus
https://bugs.webkit.org/show_bug.cgi?id=209975
Summary AX: combobox aria-activedescendant is not read in VoiceOver unless the listbo...
Chase
Reported 2020-04-03 10:37:30 PDT
Created attachment 395394 [details] Sample HTML to reproduce the issue For a combobox that contains an input and owns a listbox (following this pattern: https://www.w3.org/TR/wai-aria-practices/examples/combobox/aria1.1pattern/listbox-combo.html): If the listbox does not start out with `display: none` at the time the input receives focus, then VoiceOver does not announce the active option as the input's `aria-activedescendant` gets updated. However, if the listbox starts with `display: none` and dynamically changes to `display: block` some time after the input receives focus, VoiceOver will announce the active option correctly. Steps to reproduce, using attached sample HTML: 1. Focus the input field 2. Press ArrowDown to set `aria-activedescendant` to the IDs of one of the options EXPECTED: VoiceOver should announce the active options as user arrows through them ACTUAL: VoiceOver does not announce anything However, if the `display: none` property for the .hidden class is uncommented so that the listbox is initially `display: none`, the same steps listed above will cause VoiceOver to read the options while arrowing through. Also tested Chrome (Version 80.0.3987.122) and Firefox (76.0a1), where VoiceOver does correctly announce the options even when the listbox never has `display: none`
Attachments
Sample HTML to reproduce the issue (2.46 KB, text/html)
2020-04-03 10:37 PDT, Chase
no flags
Radar WebKit Bug Importer
Comment 1 2020-04-03 10:37:39 PDT
James Craig
Comment 2 2020-07-17 17:14:16 PDT
*** Bug 212471 has been marked as a duplicate of this bug. ***
James Craig
Comment 3 2020-09-08 12:32:54 PDT
According to another's diagnosis, "the element passed along with the notification has a frame size of 0,0." So VO assumes it's an invalid notification.
Note You need to log in before you can comment on or make changes to this bug.