You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Describe the bug
The container of the error message which is programmatically determined as a live region is being added and removed from the DOM when the inline error appears and disappears respectively. This practice prevents the error message from being immediately communicated to screen reader users especially those who use VoiceOver on iPhone, iPad, or Mac devices.
To Reproduce
Steps to reproduce the behavior:
Go to the checkout page Payment Section
Enter a invalid card number or expiry date
You can see a message of enter a valid credit card number in red Color is displayed
Inspect the error message span tag , role=alert is missing in the span tag.
Expected behavior
To fix this, make sure that an empty container with the live region role (such as, role="alert" or aria-live="assertive") must be present on the page load. The error message needs to be dynamically added to the container when the error is triggered
For example:
Invalid card number
Screenshots
Expected change in span tag where role=alert is required.
Desktop (please complete the following information):
OS: IOS
Browser chrome, safari
Version - Any latest Version
Smartphone (please complete the following information):
Device: iPhone14
OS: [e.g. iOS17
Browser Safari
Version Any Latest
Additional context
Add any other context about the problem here.
The text was updated successfully, but these errors were encountered:
Hi @saidyson which sdk version are you testing? I believe this should be fixed from v5.37.0 - we added a live region, errors are added and removed from the DOM respectively in terms of invalid and valid situations.
@saidyson - just to clarify... the aria-live element, present on the page load, exists, not on a "per input" basis, rather as a "SR (screenreader) panel" that sits in the <body> and "collects" errors as they appear.
This also allows for a list of errors to be read out, when, for example, the shopper presses the pay button and multiple errors are generated at once
Hi @sponglord
The live regions for the errors are being added to the DOM individually when triggered, not present on pages load. The live regions will not work correctly with many screen readers including VoiceOver.
Describe the bug
The container of the error message which is programmatically determined as a live region is being added and removed from the DOM when the inline error appears and disappears respectively. This practice prevents the error message from being immediately communicated to screen reader users especially those who use VoiceOver on iPhone, iPad, or Mac devices.
To Reproduce
Steps to reproduce the behavior:
Expected behavior
To fix this, make sure that an empty container with the live region role (such as, role="alert" or aria-live="assertive") must be present on the page load. The error message needs to be dynamically added to the container when the error is triggered
For example:
Invalid card number
Screenshots
data:image/s3,"s3://crabby-images/b814f/b814fcc0f6ea5f875fe1a678d95787b0c91dd681" alt="Image"
Expected change in span tag where role=alert is required.
Desktop (please complete the following information):
Smartphone (please complete the following information):
Additional context
Add any other context about the problem here.
The text was updated successfully, but these errors were encountered: