Skip to content

bug(Table): Tab navigation on inputs inside table with sticky columns (focus out of sight) #28004

Open
@cirdeicostel

Description

@cirdeicostel

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:

  1. Scroll the table in order to hide some columns under the sticky columns
  2. Focus first inside the first cell of the row with the inputs
  3. Press TAB key in order to navigate through the inputs
  4. 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.

DEMO:
table_TAB_focus

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

added
P3An issue that is relevant to core functions, but does not impede progress. Important, but not urgent
AccessibilityThis issue is related to accessibility (a11y)
and removed
needs triageThis issue needs to be triaged by the team
on Oct 31, 2023
zarend

zarend commented on Mar 20, 2024

@zarend
Contributor

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

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Metadata

Metadata

Assignees

No one assigned

    Labels

    AccessibilityThis issue is related to accessibility (a11y)P3An issue that is relevant to core functions, but does not impede progress. Important, but not urgentarea: cdk/tablearea: material/table

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions

      bug(Table): Tab navigation on inputs inside table with sticky columns (focus out of sight) · Issue #28004 · angular/components