The component InputColor is a wrapper for the native HTML element <input type="color">
which has accessibility problems:
- With NVDA, the element is announced as "clickable" and not as an input element.
- It's not possible to select a color using a screen reader.
For full accessibility, consider using predefined colors lists, e.g. using KolSelect or KolCheckbox.
When a table column changes its sort order (i.e. when its aria-sort
attribut changes), screen readers announce this change automatically.
For unknown reasons, this sometime does not happen in NVDA.
🐞 GitHub issue (PR) #5780 🐞 NVDA issue #10890 🐞 NVDA issue #8132
The components InputNumber and InputDate render their respective native HTML elements <input type="number">
and <input type="date">
which both support the
attribute readonly
.
When focusing the element, it's expected that the readonly
attribute is announced as part of the element description. This isn't the case for NVDA.
🐞 GitHub issue #5554 (For number) 🐞 GitHub issue #5749 (For date) 🐞 NVDA issue #13672
Toasts are rendered in a container that's appended as first element of <body>
and elevated using a high z-index
.
When using modal Dialogs these are rendered above toasts on the top layer. Hence, toast messages are always blocked by Modal Dialogs. We recommend completely avoiding Toasts in Modals and giving feedback within the modal directly.
The search
of this component is highly browser-dependent. For example, the close button is either shown or hidden depending on the browser. Accessibility is therefore not achieved.
🐞 GitHub issue #6307
KolSelect is using native HTML <select>
.
When using KolSelect with the multiple
property, the native HTML <select>
may cause problems with screen readers.
Often the entire selection is not read out, but only the last one. Therefore, the KolSelect has no full accessibility.
The <select>
element and its <option>
tags offer limited styling options. Specifically, states such as "selected", "focus" or "active" cannot be reliably customized using CSS. This leads to challenges in meeting accessibility standards, especially in ensuring sufficient contrast ratios.
Impact:
-
Limited Customization: The visual state of dropdown options (e.g., on focus or selection) cannot be consistently customized across all browsers. This makes it difficult to create an accessible visual experience for all users.
-
Browser-Dependent Rendering: The appearance of the
<select>
element varies across browsers and operating systems, resulting in inconsistent user experiences. -
Contrast Issues: Since the contrast of the default dropdown rendering is controlled by the browser, it's not always possible to ensure WCAG-compliant contrast ratios, which may hinder readability for users with visual impairments.
In Google Chrome, when using VoiceOver with empty date
input fields (no initial value), an unexpected percentage value is read aloud alongside the usual prompt.
Notably, this issue does not occur with Windows Narrator, which handles empty date inputs correctly.
There is a Bug Report for this Issue:
VoiceOver reads negative percent values for month, day, and year steppers in <input type="date">
Related: 🐞 GitHub issue #7076
The use of aria-label
or aria-labelledby
on <kol-icon>
or its nested elements does not work reliably in Firefox. Even applying these attributes directly to <kol-icon>
has no effect, which points to a browser-specific issue with ARIA support in custom elements or shadow DOM contexts.
- The issue lies in Firefox's handling of ARIA attributes on custom web components or deeply nested elements.
- This is not related to dynamic announcements (
aria-live
) but specifically to the inability of Firefox to processaria-label
oraria-labelledby
correctly in these cases. - The issue is browser-specific and does not consistently occur in Chrome, Edge, or Safari.
This is a limitation in Firefox’s ARIA implementation. Until it is resolved, alternative strategies like visually hidden text near the element or redundant error messages should be used to ensure accessibility. We have created a ticket for this: 🐞 GitHub issue #7119