-
Notifications
You must be signed in to change notification settings - Fork 334
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
Tabs interface needs better way to get to panel content #860
Comments
Hi @detlevhfischer, Thanks for raising this issue related to the tabs component. We'd be keen to know if any related findings came out of the user tests you conducted? Thanks, |
It's holiday time - there will be more tests after the summer break. I'll be in touch! |
"In the operation of screen readers like NVDA and JAWS, the down arrow moves the user to the next element (focusable or otherwise) and reads it out. Without intervention, this would be the next tab in the tablist. Instead, we can intercept the down arrow key press and move focus programmatically to the open panel itself, making sure it isn't missed. See panels[i].focus() in the following snippet:" @Heydon this seems well reasoned but do you have any research that shows that the current behaviour is a barrier for NVDA users? |
Hi @NickColley. Only my own testing. I basically experienced what @detlevhfischer did. I think many rely on the idea that Related: Note that, in the book version of inclusive-components.design, I have made some updates. These include 'cycling' through tabs, rather than the left and right arrow keys just doing nothing when you reach the end or the start. I can give you the updated code should you want it. |
Some interesting guidance in the WAI-ARIA authoring guides: https://www.w3.org/TR/wai-aria-practices/#kbd_selection_follows_focus https://www.w3.org/TR/wai-aria-practices/examples/tabs/tabs-1/tabs.html In this implementation of tabs they have made the tabpanel itself a focusable element, which recieves focus when you press tab. So the interaction looks like this:
Something worth thinking about here is that clicking the panel will focus it, we have had issues with this relating to the skip-link before alphagov/govuk-design-system-backlog#66 (comment) |
Yeah, you can do that too. But, where there are focusable elements in the
panel, it becomes redundant and a bit obstructive. I added the down arrow
because that's what I think folks would reach for if tabbing became
confusing. I think either solution is OK though.
…On Mon, 17 Sep 2018, 15:18 Nick Colley, ***@***.***> wrote:
Some interesting guidance in the WAI-ARIA authoring guides:
https://www.w3.org/TR/wai-aria-practices/#kbd_selection_follows_focus
https://www.w3.org/TR/wai-aria-practices/examples/tabs/tabs-1/tabs.html
In this implementation of tabs they have made the tabpanel itself a
focusable element, which recieves focus when you press tab.
So the interaction looks like this:
1. Tab to tabs component
2. Pick a tab
3. Tab into tabs panel
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#860 (comment)>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/AApuJkGUQA_gEDZml4kxp7AZ69vwz4G0ks5ub68sgaJpZM4U_lA5>
.
|
We have had some internal conversations that I forgot to update here: I think there is a need to do more, we do not have evidence of how it impacts real users but from trying to use NVDA it seems overly complicated. I spoke with the GOV.UK Design System team (Tim, Jani and Hanna) and we agreed to try making the panel focusable, with the con that you have to tab twice to get to tabbable content within the panel. We think this will better stand the test of time as we're worried about custom keyboard behaviour colliding with newly introduced mechanics. We want to make sure our implementation is well tested across assistive technologies and if possible consult the accessibility team in one of their clinics. We then will ask the community to help test this, and if this does not happen organise a component round up ourselves. I've created a card in our internal team board to track this: https://trello.com/c/YXM4dkVc/384-make-tab-panel-focusable-in-the-tabs-component (only visible for team members sorry 😢 ) |
Possibly something to look at when we look at improving the tabs pattern or start working on the tabbed navigation proposal |
This was reported again recently. I looked into it and found that it's likely a bug in NVDA. The problem seems to be that the screen reader focus disappears. The same happens with the tabs pattern in WAI's Authoring Practice Guide. There seems to be confusion about what the exact issue is, so I'll describe it in detail... Steps to reproduce the issue
Actual vs expected behaviourAlthough step 4 above already behaves unexpectedly, it is step 5 which is the main issue. You can get out of it via tabbing (not in the example above as there is nowhere to tab to, try https://www.gov.uk/bank-holidays for that). But if there is nothing interactive in the tab container you'd have to go back up to the start of the container (as is the case with the Bank Holiday example). And that is only if you understood what was happening and have the patience to try and find where the tab container starts. Additional problems for Firefox usersThe problem gets worse for Firefox users due to another bug that means they cannot use the arrow keys at all to get to the other tabs, so have to use the tab key to get to them. |
I had initially only tested in JAWS 2023. As the user who reported the issue again has mentioned it also happens in JAWS for them and has now come back with their JAWS version (which was 2022), I retested in JAWS 2022 and lots of earlier versions as well. And I can confirm it is also an issue in JAWS up to and including 2022 but was fixed in JAWS 2023. |
Thanks to a comment from a user I realised that I was missing something in my testing. When your screen reader switches between modes automatically (which is my testing default as it's JAWS's and NVDA's default), you will switch into forms mode. That's why the screen reader focus disappears. It's easy to get out of it again, though (with the Esc key, for example). Screen reader users who know the basics of their tool will know how to handle that. Although I knew that as well, for some reason I completely missed the beep that indicated the change in mode. The question now is if this problem was ever reported by users or only by testers? If we want to be "implementing arrow down as a shortcut to move focus to the right panel content" is a related but different issue and should have its own GitHub issue. The aim of that is not to fix a bug but to improve usability. Although that would need to be tested thoroughly first as it's not the expected behaviour. |
Moving over from Frontend Toolkit
issue raised by @detlevhfischer
When used with NVDA it is difficult to get from the tabs on https://design-system.service.gov.uk/components/tabs/ to the corresponding panel. Both left / right as well as up / down arrows traverse the tabs in the tablist. I suggest to consider implementing arrow down as a shortcut to move focus to the right panel content. See https://inclusive-components.design/tabbed-interfaces/ , section "A problem reading panels".
@alex-ju commented
@detlevhfischer: hi, thanks for adding your suggestions, we took that article into consideration while building the component. have you done any user research around this?
@detlevhfischer commented
I just tried it using NVDA and Firefox and noticed that left/right arrow did the same as top/down arrow, so that latter is not used (as I believe recommended by Heydon) to move the focus to the panel. Leaving forms mode and trying reading mode to progress to the panel often lands in the wrong one because tab and its panel are not adjacent in the source code, I guess.
I intend o include the gov.uk example in the user tests I am currently conducting and will report back on issues, if there are any.
@alex-ju commented
Feedback from research would be extremely valuable for us and would help us shape the component, thank you!
The text was updated successfully, but these errors were encountered: