@progress/wct-a11y-spec
Version:
Contains accessibility and keyboard navigation specification of Telerik and Kendo web components.
173 lines • 6.84 kB
JSON
[
{
"h2": "Accessibility Support"
},
{
"p": "Out of the box, the Telerik and Kendo UI OTP provides extensive accessibility support and enables users with disabilities to acquire complete control over its features."
},
{
"p": "The OTP is compliant with the [Web Content Accessibility Guidelines (WCAG) 2.2 standards](https://www.w3.org/TR/WCAG22/) and [Section 508](http://www.section508.gov/) requirements, follows the [Web Accessibility Initiative - Accessible Rich Internet Applications (WAI-ARIA)](https://www.w3.org/WAI/ARIA/apg/) best practices for implementing the [keyboard navigation](#keyboard-navigation) for its `component` role, provides options for [managing its focus](#managing-the-focus) and is tested against the most popular [screen readers](#screen-readers)."
},
{
"h3": "WAI-ARIA"
},
{
"p": "This section lists the selectors, attributes, and behavior patterns supported by the component and its composite elements, if any."
},
{
"p": "No role attribute is implemented as the `html input type=\"text\"` element is sufficient for defining the purpose of the component."
},
{
"table": {
"headers": [
"Selector",
"Attribute",
"Usage"
],
"rows": [
{
"Selector": "`.k-otp`",
"Attribute": "`role=group`",
"Usage": "Sets the proper role for the OTP."
},
{
"Selector": "`.k-otp>input`",
"Attribute": "`type=hidden`",
"Usage": "The hidden input holding the OTP inputs value."
},
{
"Selector": "",
"Attribute": "`aria-hidden=true`",
"Usage": "Hides the hidden input from assistive technologies."
},
{
"Selector": "`.k-otp-input .k-input-inner`",
"Attribute": "`label for` or `aria-label` or `aria-labelledby`",
"Usage": "The input needs an accessible name to be assigned to it."
},
{
"Selector": "",
"Attribute": "`aria-required=true`",
"Usage": "The attribute is rendered only when the OTP is in a `form` HTML element and announces the required state of the component."
},
{
"Selector": "",
"Attribute": "`aria-describedby=.k-form-hint id/.k-form-error id`",
"Usage": "Points to the hint for the input, or if the input is invalid, to the error message. This attribute should only be present when a hint is set or when the input is invalid."
},
{
"Selector": "",
"Attribute": "`autocomplete=off`",
"Usage": "Sets the default autocomplete for the input."
},
{
"Selector": "`.k-invalid .k-input-inner,.ng-invalid .k-input-inner`",
"Attribute": "`aria-invalid=true`",
"Usage": "The attribute is rendered only when the OTP is in a form and announces the valid state of the component."
},
{
"Selector": "`.k-disabled .k-input-inner`",
"Attribute": "`disabled=disabled` or `aria-disabled=true`",
"Usage": "The attribute is rendered only when the OTP is disabled."
}
]
}
},
{
"h3": "Managing the Focus"
},
{
"p": "All of the inputs in the OTP are focusable by default, and follow the regular tab order of the page. When an input is focused (on focus), its character is selected."
},
{
"h3": "Keyboard Navigation"
},
{
"p": "The OTP supports the following keyboard shortcuts:"
},
{
"table": {
"headers": [
"Shortcut",
"Behavior"
],
"rows": [
{
"Shortcut": "Typing in the input",
"Behavior": "Sets the value in the input and moves the focus to the next focusable input in the OTP. (if any)"
},
{
"Shortcut": "`Tab`",
"Behavior": "Focuses the next input in the OTP. If the focus is on the last input, focuses the next focusable element on the page."
},
{
"Shortcut": "`Shift` + `Tab`",
"Behavior": "Focuses the previous input in the OTP. If the focus is on the first input, focuses the previous focusable element before the OTP."
},
{
"Shortcut": "`Right Arrow`",
"Behavior": "Moves the focus to the next focusable input in the OTP. (if any)"
},
{
"Shortcut": "`Left Arrow`",
"Behavior": "Moves the focus to the previous focusable input in the OTP. (if any)"
},
{
"Shortcut": "`Backspace`",
"Behavior": "Deletes the value of the focused input and moves the focus on the previous input. (if any)."
},
{
"Shortcut": "`Delete`",
"Behavior": "Deletes the value of the focused input."
}
]
}
},
{
"h3": "Testing"
},
{
"p": "The OTP has been extensively tested automatically with [axe-core](https://github.com/dequelabs/axe-core) and manually with the most popular screen readers."
},
{
"h3": "Screen Readers"
},
{
"p": "The OTP has been tested with the following screen readers and browsers combinations:"
},
{
"table": {
"headers": [
"Environment",
"Tool"
],
"rows": [
[
"Firefox",
"NVDA"
],
[
"Chrome",
"JAWS"
],
[
"Microsoft Edge",
"JAWS"
]
]
}
},
{
"h3": "Resources"
},
{
"ul": [
{
"link": {
"source": "https://www.w3.org/TR/wai-aria-1.2/#textbox",
"title": "WAI-ARIA Specification for the TextBox"
}
}
]
}
]