Skip to content
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

Tech Debt: can we implement a disclosure-like pattern that works for showing and hiding elements to AT #4769

Open
thiessenp-cds opened this issue Dec 3, 2024 · 0 comments
Labels
a11y Accessibility related issue App tech debt Includes: refactoring, documentation, organization, and dependency management. Does not include bugs

Comments

@thiessenp-cds
Copy link
Contributor

thiessenp-cds commented Dec 3, 2024

Exploring showing and hiding a "complex" element to AT

Issue

The issue is how to let an AT know that a new "complex" element has been added to the page (DOM). For simple elements like a text update or an element that contains a few text elements, a live-region can handle this great. But if an element could have a lot of content or an element that has a number of nested elements, the update announced in an AT would be way too verbose to be usable for a user. An example of this is the show-hide feature in the form builder that allows a user to group one or more elements into a rule that can be shown hidden depending.

Solutions

There are not currently any full solutions known, only partly working solutions.
The current best practice from the W3C is to use the "disclosure pattern". This adds an aria-controls to the button that controls visibility and an id from what is being shown/hidden. The button also adds an aria-expanded that is toggled to true when visible. The relationship that this pattern sets up should be work great in theory. The problem is that most AT vendors decided not to support aria-controls. So this won't work.
Another option is to just add a live-region=polite around the area containing the "complex" element. Then when it's shown it will verbosely be announced. To tweak this, parts of the "complex" element could be overridden to not be announced using a aria-live=off. Note that it is important that the initial aria-live=polite is in the original displayed HTML or in the DOM long before the dynamic updates. This helps improve the chance of an AT seeing the change.

What is the best solution?

Ideally this would involve some investigation into a new solution or tweaking the existing solutions to work for us better.

@thiessenp-cds thiessenp-cds added bug Something isn't working a11y Accessibility related issue App tech debt Includes: refactoring, documentation, organization, and dependency management. Does not include bugs and removed bug Something isn't working labels Dec 3, 2024
@thiessenp-cds thiessenp-cds changed the title chore: can we implement a "disclosure-like pattern" that works for exposing showing and hiding an element to AT Tech Debt: can we implement a "disclosure-like pattern" that works for exposing showing and hiding an element to AT Dec 5, 2024
@thiessenp-cds thiessenp-cds changed the title Tech Debt: can we implement a "disclosure-like pattern" that works for exposing showing and hiding an element to AT Tech Debt: can we implement a disclosure-like pattern that works for showing and hiding elements to AT Dec 5, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
a11y Accessibility related issue App tech debt Includes: refactoring, documentation, organization, and dependency management. Does not include bugs
Projects
None yet
Development

No branches or pull requests

1 participant