Description
Is this a regression?
- Yes, this behavior used to work in the previous version
The previous version in which this bug was not present was
No response
Description
When having multiple inputs on one row, one input per cell, inside a table with one or more sticky columns the TAB key navigation is focusing at some point on an input that is hidden under the sticky columns, making the focus out of sight, but still inside the table.
The current behavior it's not compliant with the latest accessibility guidelines (WCAG) that states that an element that is focused needs to be in sight. (ref link: https://www.w3.org/WAI/WCAG22/Understanding/focus-not-obscured-minimum)
Reproduction
StackBlitz link:
https://stackblitz.com/edit/r22tvc?file=src%2Fexample%2Ftable-sticky-complex-flex-example.html
Table state:
- have horizontal scroll (requires a higher number of columns)
- one or more columns sticky
- on at least one row have an input on each cell
Steps to reproduce:
- Scroll the table in order to hide some columns under the sticky columns
- Focus first inside the first cell of the row with the inputs
- Press TAB key in order to navigate through the inputs
- The focus at some point is on the input that is hidden under the sticky columns
Expected Behavior
The focused element should be in sight, visible, not hidden under the sticky columns.
Actual Behavior
The focus is hidden under the sticky columns, out of sight.
Environment
- Angular: 16.1.1
- CDK/Material: 16.2.9
- Browser(s): Chrome (118.0.5993.89) / Firefix (119.0)
- Operating System (e.g. Windows, macOS, Ubuntu): Windows x64
Activity
zarend commentedon Mar 20, 2024
Hello folks,
Generally, we let the browser handle scrolling focused items into view. It would be interesting to see if we can reproduce this example in vanilla html. That would help determine if this is a problem with Angular components or perhaps a browser issue.
Best Regards,
Zach