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

fix: Keep focus on input after select to improve accessibility #1727

Merged
merged 9 commits into from
Dec 16, 2022

Conversation

Pytal
Copy link
Contributor

@Pytal Pytal commented Dec 14, 2022

Keep focus on the input after option selection and when hitting the Escape key to comply with W3C accessibility guidelines as demonstrated and described in:

@netlify
Copy link

netlify bot commented Dec 14, 2022

👷 Deploy request for vueselect accepted.

Name Link
🔨 Latest commit a7af988
🔍 Latest deploy log https://app.netlify.com/sites/vueselect/deploys/639bdcf153bbb5000996213a

@sagalbot
Copy link
Owner

Thanks for this! This behaviour is definitely how the component should work. This needs some refining though before I can merge. After a selection has been made, the input still has focus, but it's unresponsive. There's no way to bring the dropdown back up after a selection was made since the open state is tied to input focus.

I think what likely needs to happen, is the outer div of the template gets tabindex="0", and when it is focused and a key is pressed, the dropdown opens and if filterable=true, focus is moved to the input box. I am fixing this in the next major release, but if you'd like to take a try at this, please do.

@Pytal
Copy link
Contributor Author

Pytal commented Dec 14, 2022

Thanks for this! This behaviour is definitely how the component should work. This needs some refining though before I can merge. After a selection has been made, the input still has focus, but it's unresponsive. There's no way to bring the dropdown back up after a selection was made since the open state is tied to input focus.

I think what likely needs to happen, is the outer div of the template gets tabindex="0", and when it is focused and a key is pressed, the dropdown opens and if filterable=true, focus is moved to the input box. I am fixing this in the next major release, but if you'd like to take a try at this, please do.

No problem and thanks for taking a look! I've tried reproducing this locally and on https://deploy-preview-1727--vueselect.netlify.app/sandbox.html but both seem to work for me as after selecting an option I can hit Enter to reopen the dropdown and make another selection. Which steps can I take to reproduce the unresponsiveness?

@Pytal Pytal force-pushed the enh/a11y-keep-focus branch from fed8148 to dde83a8 Compare December 14, 2022 19:11
@sagalbot
Copy link
Owner

Here's what we'll need. These are basically test cases.

After a selection has been made and the dropdown is closed but the input remains in focus:

  • pressing one of up/down/enter/space keys will display the dropdown and focus the selected item
  • pressing return should not select a new option
    • right now if you select an option, hit down twice, then return, you'll have a new selection
    • the return keypress that opens the menu I think is actually just re-selecting the currently highlighted option
  • pressing any alphanumeric key should open the dropdown and start filtering

In the next major, clicking into the search input when filterable is true will not immediately open the dropdown until an additional key is pressed. Clicking the toggle icon will still always open the dropdown.

@Pytal Pytal force-pushed the enh/a11y-keep-focus branch from dde83a8 to 3f7bfcb Compare December 15, 2022 02:01
@Pytal
Copy link
Contributor Author

Pytal commented Dec 15, 2022

Made the changes and added some tests, what do you think @sagalbot?

src/components/Select.vue Outdated Show resolved Hide resolved
@sagalbot
Copy link
Owner

This is looking awesome. A huge upgrade to accessibility for the component and something that I've really wanted to fix for a long time now. Thanks @Pytal!

Signed-off-by: Christopher Ng <[email protected]>
- Comply with W3C accessibility guidelines
- Expected behaviour described in https://www.w3.org/WAI/ARIA/apg/example-index/combobox/combobox-select-only.html

Signed-off-by: Christopher Ng <[email protected]>
- Only move typeAheadPointer when dropdown is open

Signed-off-by: Christopher Ng <[email protected]>
Signed-off-by: Christopher Ng <[email protected]>
@Pytal Pytal force-pushed the enh/a11y-keep-focus branch from 3f7bfcb to a7af988 Compare December 16, 2022 02:50
@sagalbot sagalbot changed the title Keep focus on input box to improve accessibility fix: Keep focus on input after select to improve accessibility Dec 16, 2022
@sagalbot sagalbot merged commit 26f0827 into sagalbot:master Dec 16, 2022
@sagalbot
Copy link
Owner

Released in v3.20.1. Thank you @Pytal for the awesome contributions.

You might want to consider setting up a GitHub sponsor profile.. just sayin!

@Yury-Shautsou-GY
Copy link

Hi all! You are doing an excellent work.

But we have one problem with this new behavior after the 3.20.1 updates.

On the input event, we call the API and open the bootstrap-vue b-modal dialog before the endpoint call completes. After closing the modal dialog, the dropdown list reopens, and this new behavior is something we don't expect at all. How can we leave the dropdown menu closed after closing the modal dialog.

Maybe new props need to be made to prevent this behavior?!

Thanks!

@sagalbot
Copy link
Owner

Thanks, @Yury-Shautsou-GY if possbile, could you provide a reproduction link?

@Pytal Pytal deleted the enh/a11y-keep-focus branch January 27, 2023 19:49
Maff- added a commit to Maff-/simple-time that referenced this pull request Jul 26, 2024
Accounts for changes introduced in vue-select v3.20.1; sagalbot/vue-select#1727. Otherwise, pressing enter followed by tab would replace the selection with the first option before jumping to the next input.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants