Commit 829031b
fix: prevent keyboard focus on hidden sidebar items
When the sidebar is collapsed on small screens, its interactive elements
(links, buttons) could still receive keyboard focus because they were only
hidden via margin-left offset.
Changes:
- Add visibility: hidden to collapsed sidebar state and visibility: visible
to the .show state in Sidebar.scss for CSS-level hiding
- Use the inert attribute in the JS toggle handler to immediately remove
sidebar items from the tab order and accessibility tree on close,
eliminating the 300ms transition window where items remain focusable
- Move focus back to the toggle button when closing the sidebar
- Add a useEffect in the Sidebar component to set inert initially on
mobile viewports, with a media query listener for responsive behavior
Fixes Bug 2737380
Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>1 parent 32433bc commit 829031b
2 files changed
Lines changed: 23 additions & 0 deletions
Lines changed: 2 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
209 | 209 | | |
210 | 210 | | |
211 | 211 | | |
| 212 | + | |
212 | 213 | | |
213 | 214 | | |
214 | 215 | | |
| |||
223 | 224 | | |
224 | 225 | | |
225 | 226 | | |
| 227 | + | |
226 | 228 | | |
227 | 229 | | |
228 | 230 | | |
| |||
Lines changed: 21 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
44 | 44 | | |
45 | 45 | | |
46 | 46 | | |
| 47 | + | |
47 | 48 | | |
48 | 49 | | |
49 | 50 | | |
| 51 | + | |
| 52 | + | |
50 | 53 | | |
51 | 54 | | |
| 55 | + | |
52 | 56 | | |
53 | 57 | | |
54 | 58 | | |
| |||
127 | 131 | | |
128 | 132 | | |
129 | 133 | | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
| 141 | + | |
| 142 | + | |
| 143 | + | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
| 150 | + | |
130 | 151 | | |
131 | 152 | | |
132 | 153 | | |
| |||
0 commit comments