Skip to content

Commit

Permalink
Fixes for a1b64e, ebe86a due to surveys (#2209)
Browse files Browse the repository at this point in the history
* Update a1b64e Pass 2 to add role

* Add a support note for issue 1909 regarding cycle to browser

* Add a passing modal example

* Fix spacing

* Fix spacing

---------

Co-authored-by: Carlos Duarte <carlosapaduarte@gmail.com>
  • Loading branch information
tombrunet and carlosapaduarte authored Dec 5, 2024
1 parent d1b7a2a commit 041fe61
Show file tree
Hide file tree
Showing 2 changed files with 52 additions and 3 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ For each target element focus can cycle to the browser UI by using the method ad

### Accessibility Support

There are no accessibility support issues known.
Some browsers have settings that will immediately cycle focus back to the web document. This fulfills the expectation because focus can cycle to the browser UI and the browser UI cycles focus back to the web document.

### Bibliography

Expand Down
53 changes: 51 additions & 2 deletions _rules/focusable-no-keyboard-trap-standard-nav-a1b64e.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ acknowledgments:
- Malin Øvrebø
- Shadi Abou-Zahra
- Stein Erik Skotkjerra
- Tom Brunet
funding:
- WAI-Tools
---
Expand All @@ -43,7 +44,7 @@ This rule only requires navigation in one direction (either forward or backward)

### Accessibility Support

There are no accessibility support issues known.
Some browsers have settings that will immediately cycle focus back to the web document. This fulfills the expectation because focus can cycle to the browser UI and the browser UI cycles focus back to the web document.

### Bibliography

Expand All @@ -68,7 +69,7 @@ These [focusable][] elements do not create a trap for keyboard navigation.
This element is made [focusable][] by the `tabindex` attribute. It does not create a trap for keyboard navigation.

```html
<div tabindex="1">Text</div>
<div role="button" tabindex="1">Text</div>
```

#### Passed Example 3
Expand All @@ -79,6 +80,54 @@ This element is made [focusable][] by the `tabindex` attribute, even if it is no
<div tabindex="-1">Text</div>
```

#### Passed Example 4

While the elements with id "sentinelBefore" and "sentinelAfter" contain focus to the contents of the div with name "Sample Modal", focus is not trapped since the user can
use [standard keyboard navigation](#standard-keyboard-navigation) using the Escape key or by activating the "Close button" to dismiss the modal

```html
<div>Main page content with <a href="#">some link</a></div>
<div aria-hidden="true">
<a href="#" id="sentinelBefore" style="position:absolute; top:-999em"
>Upon receiving focus, this focus sentinel should wrap focus to the bottom of the modal</a
>
</div>
<div
id="sampleModal"
role="dialog"
aria-label="Sample Modal"
aria-modal="true"
style="border: solid black 1px; padding: 1rem;"
>
<label>First and last name <input id="dialogFirst"/></label><br />
<button id="closeButton">Close button</button>
</div>
<div aria-hidden="true">
<a href="#" id="sentinelAfter" style="position:absolute; top:-999em"
>Upon receiving focus, this focus sentinel should wrap focus to the top of the modal</a
>
</div>
<script>
window.addEventListener('load', () => {
document.getElementById('dialogFirst').focus();
})
document.getElementById('sentinelBefore').addEventListener('focus', () => {
document.getElementById('closeButton').focus()
})
document.getElementById('sentinelAfter').addEventListener('focus', () => {
document.getElementById('dialogFirst').focus()
})
document.getElementById('closeButton').addEventListener('click', () => {
document.getElementById('sampleModal').style.display = 'none'
})
document.getElementById('sampleModal').addEventListener('keydown', (evt) => {
if (evt.key === "Escape") {
document.getElementById('sampleModal').style.display = 'none';
}
})
</script>
```

### Failed

#### Failed Example 1
Expand Down

0 comments on commit 041fe61

Please sign in to comment.