@progress/wct-a11y-spec
Version:
Contains accessibility and keyboard navigation specification of Telerik and Kendo web components.
194 lines • 8.08 kB
JSON
[
{
"h2": "Accessibility Support"
},
{
"p": "Out of the box, the Telerik and Kendo UI Splitter provides extensive accessibility support and enables users with disabilities to acquire complete control over its features."
},
{
"p": "The Splitter 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."
},
{
"h4": "Splitter Pane"
},
{
"table": {
"headers": [
"Selector",
"Attribute",
"Usage"
],
"rows": [
{
"Selector": "`.k-pane`",
"Attribute": "`role=group`",
"Usage": "Sets the proper role for the Splitter pane that identifies a set of user interface objects that is not intended to be included in the page's summary or table of contents."
}
]
}
},
{
"blockquote": "Note: The value of the `aria-label` attribute of the split-bar elements will be provided to their respective preceding pane element through the API."
},
{
"h4": "SplitBar"
},
{
"table": {
"headers": [
"Selector",
"Attribute",
"Usage"
],
"rows": [
{
"Selector": "`.k-splitbar`",
"Attribute": "`role=separator`",
"Usage": "Sets the proper role for the Splitter split-bar element."
},
{
"Selector": "",
"Attribute": "`aria-label`",
"Usage": "An accessible name, with aria-label should be included if there is more than one focusable separator. The value is set through the corresponding SplitterPane API."
},
{
"Selector": "`.k-splitbar-horizontal`",
"Attribute": "`aria-orientation=vertical`",
"Usage": "When a splitbar separates two panes horizontally, its aria-orientation must be explicitly set to 'vertical'."
},
{
"Selector": "",
"Attribute": "`aria-keyshortcuts=ArrowLeft ArrowRight ArrowUp ArrowDown`",
"Usage": "Sets the aria-keyshortcuts attribute value to announce available keyboard shortcuts. Some are omitted for brevity."
}
]
}
},
{
"blockquote": "Note: Setting the value-now attribute of the separator element is not applicable, as the Splitter is a complex layout component allowing splitting the content into multiple panes across any number and level of nested Splitters and panes, thus announcing a value would not convey any meaningful information. Moreover, there is no specification, or WAI-ARIA recommendation that explains how value should be set in multiple panes scenario. If needed, developers can still apply attributes as they see fit, using the respective API option. Further information on this complicated scenario could be found in the following WAI-ARIA GitHub issue:"
},
{
"link": {
"source": "https://github.com/w3c/aria-practices/issues/129#issuecomment-456976215",
"title": "WAI-ARIA Practices on GitHub"
}
},
{
"h3": "Keyboard Shortcuts"
},
{
"table": {
"headers": [
"Shortcut",
"Behavior"
],
"rows": [
{
"Shortcut": "`Up Arrow`",
"Behavior": "Moves up the split-bar in a vertical Splitter."
},
{
"Shortcut": "`Down Arrow`",
"Behavior": "Moves down a split-bar in a vertical Splitter."
},
{
"Shortcut": "`Left Arrow`",
"Behavior": "Moves left a split-bar in a horizontal Splitter."
},
{
"Shortcut": "`Right Arrow`",
"Behavior": "Moves right a split-bar in a horizontal Splitter."
},
{
"Shortcut": "`Ctrl/Cmd(Mac) + Up Arrow`",
"Behavior": "Moves the splitbar up to collapse/expand the adjacent panes in the up direction."
},
{
"Shortcut": "`Ctrl/Cmd(Mac) + Down Arrow`",
"Behavior": "Moves the splitbar down to collapse/expand the adjacent panes in the down direction."
},
{
"Shortcut": "`Ctrl/Cmd(Mac) + Left Arrow`",
"Behavior": "Moves the splitbar left to collapse/expand the adjacent panes in the left direction."
},
{
"Shortcut": "`Ctrl/Cmd(Mac) + Right Arrow`",
"Behavior": "Moves the splitbar right to collapse/expand the adjacent panes in the right direction."
},
{
"Shortcut": "`Enter`",
"Behavior": "Toggles the collapsed state of the nearest collapsible pane."
},
{
"Shortcut": "`Tab`",
"Behavior": "The key that allows focusing a splitter bar. Thus, all splitbars have `tabindex` and are included in the tab sequence."
}
]
}
},
{
"blockquote": "Note 1:** The \"splitter bar/split-bar\" is the section between two panes that allows collapsing/resizing."
},
{
"blockquote": "Note 2:** Splitter bars can be expanded/collapsed when double clicked apart from clicking on the expand/collapse icon element. Double-clicking (or `Enter` key) toggles the closest collapsible pane (left pane has priority over right pane if both are collapsible)."
},
{
"h3": "Testing"
},
{
"p": "The Splitter 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 Splitter 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/#separator",
"title": "WAI-ARIA specification for separator"
}
},
{
"link": {
"source": "https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Roles/separator_role",
"title": "MDN reference for the separator role"
}
}
]
}
]