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

Disclosure - Accessibility section #2706

Open
carmacleod opened this issue Jan 16, 2022 · 7 comments
Open

Disclosure - Accessibility section #2706

carmacleod opened this issue Jan 16, 2022 · 7 comments

Comments

@carmacleod
Copy link

carmacleod commented Jan 16, 2022

In the Accessibility section for Disclosure, it only talks about how to activate the trigger button.
https://v11.carbondesignsystem.com/patterns/disclosures-pattern/#accessibility

Where does Carbon usually put guidance for developers when ARIA is needed to make something understandable for screen readers? For example, a Disclosure needs to have aria-expanded="true"/"false" on the button, and optionally aria-controls pointing to the popover.

Also, I would expect to see advice around using Carbon icon button tooltips to give a label to the icon button and add aria-labelledby so that the icon button has a text label for screen readers to read.

@jnm2377
Copy link
Contributor

jnm2377 commented Jan 24, 2022

@carmacleod thanks for opening this. You're right, we should include the a11y information. We'll have a dev work on adding this to the docs. :)

@sstrubberg sstrubberg moved this to 🪆 Needs Refined in Design System Nov 30, 2022
@sstrubberg sstrubberg added type: enhancement 💡 proposal: accepted version: 11 Issues pertaining to Carbon v11 adopter: PAL Work-stream that directly helps a Pattern & Asset Library. labels Nov 30, 2022
@sstrubberg sstrubberg added this to the 2023 Q1 milestone Dec 5, 2022
@sstrubberg sstrubberg moved this to Backlog in Roadmap Dec 7, 2022
@sstrubberg sstrubberg moved this from Backlog to Triage in Roadmap Dec 7, 2022
@sstrubberg sstrubberg moved this from Triage to Icebox in Roadmap Dec 12, 2022
@sstrubberg
Copy link
Member

Notes from our Backlog Cleaning meeting today:

  • We don't know how a consumer isgoing to use Disclosure, which makes it difficult to prescribe aria usage here.
  • Would feel better if @mbgower took a run at this. If he could provide recommendations on what to do with all the aria suggestions that would give us direction we need to improve the guidance.

@mbgower
Copy link
Contributor

mbgower commented Dec 12, 2022

The challenge I see is that the disclosure pattern is fitting into a lot of different user interactions (basically anything where content is revealed).

It's also very unclear whether the disclosure covers things that persist until closed by the user (i.e., a user can go to other parts of the part and the disclosed content continues to appear). Things that fit in here would be accordions; collapsible left navs or other sections, which once opened stay open until specifically closed by the user.

This is a VERY different interaction model than menus, selects, date pickers, etc., which disclose information, but the information is component-specific; once the user navigates to another component (that is not a child) the disclosure vanishes.

Perhaps there are 2 clear variants for the disclosure pattern?

There might be a very basic naming convention that applies in all situations, and which can be covered by what Carolyn was advocating for. But to ascertain that, we really need a Venn diagram showing every possible thing that might be covered by this pattern, to make sure we have something consistent.

@sstrubberg sstrubberg removed this from the 2023 Q1 milestone Dec 16, 2022
@sstrubberg sstrubberg removed adopter: PAL Work-stream that directly helps a Pattern & Asset Library. version: 11 Issues pertaining to Carbon v11 labels Mar 29, 2023
@sstrubberg sstrubberg moved this from Icebox to Next in Roadmap Mar 29, 2023
@sstrubberg sstrubberg moved this to 🪆 Needs Refined in Design System Mar 29, 2023
@sstrubberg sstrubberg moved this from Next to Icebox in Roadmap Aug 22, 2023
@sstrubberg
Copy link
Member

We need to figure out where this lives on the website.

@laurenmrice
Copy link
Member

laurenmrice commented Sep 5, 2023

The challenge I see is that the disclosure pattern is fitting into a lot of different user interactions (basically anything where content is revealed)

A disclosure uses a popover and a trigger to open it and only opens on click or by using your keyboard. Disclosures should be user initiated.

It's also very unclear whether the disclosure covers things that persist until closed by the user

Disclosures open on a layer above the current page, which can cover up information on the page behind the open disclosure temporarily until the disclosure has been closed by the user.


I think this information can live on the Disclosure pattern page in the Accessibility section but we need to make some changes to it.

I would remove the current guidance in the Accessibility section and provide Accessibility information about how a disclosure opens and closes via mouse and keyboard. This could be around the actual ui trigger (which could potentially require a tooltip depending on what the trigger is) and around how to dismiss or close out the disclosure. With that said, this is just a pattern of a couple different ways people could show disclosures but it doesn't show every example that exists, it is just showing a few common visual recommendations to get people started. The accessibility section could show some common recommendations but we could also say it may not pertain to all situations.

@mbgower
Copy link
Contributor

mbgower commented Sep 6, 2023

Disclosures open on a layer above the current page, which can cover up information on the page behind the open disclosure temporarily until the disclosure has been closed by the user.

That isn't specific enough. The two key sticking points are "temporarily" (persistent or non-persistent) and "closed by the user".

My point is that a slide-in side panel is only 'temporarily' open from the perspective that its trigger can be reactivated to make it go away if desired. So I would call that persistent.

Whereas a menu is temporarily open until it loses focus. It doesn't need to be closed by the user -- at least not intentionally. If the user puts focus somewhere else (by mouse or, much more critically from an accessibility perspective, by keyboard) it closes. I call that non-persistent.

The crux of the matter is that the keyboard implementation unintentionally often makes something persistent by keyboard where it was meant to be non-persistent.

Examples of Carbon components that I would say use a disclosure pattern which are persistent:

  • accordion (which by Lauren's description, I don't think Carbon would call use of a disclosure pattern; not sure what you'd categorize it as)
  • dialog
  • UI shell side panel (where the user can open the side panel and it persists even when it loses focus, until specifically dismissed by the user by re-activating the toggle button; I think you still have this pattern, although I think the intent is to make them all non-persistent.)

Examples of Carbon components that use a disclosure pattern which is not persistent:

  • date picker (calendar)
  • dropdown
  • overflow menu
  • search
  • select
  • toggle tip
  • tooltip
  • dialog

If I assess the ibm.com stuff, I'm sure there would be many things that would correctly or incorrectly fit in the first category. That's why I think there needs to be much more clarity around what is meant by a disclosure, and why I'm keen to get that captured.

I also think that maybe we could come up with a pattern of "displacement". I think the qualities of such a pattern would be:

  1. it reveals content that displaces other content (that content reflow to make room for it, either moving down the page or reflowing to a narrower width)
  2. it persists until manually closed by the user, typically by re-activating the trigger. It normally would also return to its starting state when the page is reloaded

@sstrubberg sstrubberg moved this from 🪆 Needs Refined to ♿ Needs CAG in Design System Sep 6, 2023
@laurenmrice
Copy link
Member

We need to resolve #3428 before tackling this issue. So marking as blocked for now.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
Status: Later 🧊
Development

No branches or pull requests

6 participants