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
The mat-calendar component contains a button for each selectable date. When navigating the calendar using a screen reader, each button will be read as "toggle button" indicating that the buttons state should change each time the button is pressed. However the button does not behave like a toggle button. Once the button is toggled it cannot be "untoggled", potentially causing confusion for the user. I believe the aria-pressed
attribute on the button should be removed to correctly reflect the buttons behaviour.
This was discovered during a recent accessibility evaluation and they provided the following link: https://www.w3.org/WAI/WCAG22/Understanding/name-role-value.html
Reproduction
Example link: https://material.angular.io/components/datepicker/overview#datepicker-inline-calendar
Steps to reproduce:
- Use the example link in the browser (I used Chrome)
- Start the screen reader (I used VoiceOver on MacOS)
- Navigate to the calendar dates an hear them being read as "toggle button"
- Realize that you cannot change the pressed state of the toggle button by pressing it multiple times
Expected Behavior
That the button isn't announced as a toggle button when it doesn't behave like a toggle button.
Actual Behavior
The button is announced as a toggle button even though it doesn't behave like one.
Environment
- Angular: 19.0.4
- CDK/Material: 19.0.3
- Browser(s): Chrome (similar result expected in other browsers)
- Operating System: macOS