UNPKG

@progress/wct-a11y-spec

Version:

Contains accessibility and keyboard navigation specification of Telerik and Kendo web components.

276 lines 10.9 kB
[ { "h2": "Accessibility Support" }, { "p": "Out of the box, the Telerik and Kendo UI Pager provides extensive accessibility support and enables users with disabilities to acquire complete control over its features." }, { "p": "The Pager 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": "The `PageSize` select must be implemented either as a DropDownList component with no filtering or through a native `<select>` element." }, { "p": "The `Page` select, which is present for mobile devices and smaller screens with limited space for page links, must be a native `<select>` element." }, { "table": { "headers": [ "Selector", "Attribute", "Usage" ], "rows": [ { "Selector": "`.k-pager`", "Attribute": "`role=application`", "Usage": "Indicates that the `pager` element has its own keyboard navigation implemented." }, { "Selector": "", "Attribute": "`aria-roledescription=pager`", "Usage": "Clarifies the role of the Pager." }, { "Selector": "", "Attribute": "`aria-keyshortcuts=Enter ArrowRight ArrowLeft`", "Usage": "Announces the available keyboard shortcuts while the `pager` element is focused." }, { "Selector": "", "Attribute": "`aria-label`", "Usage": "Announces the currently selected page and the number of available pages." }, { "Selector": "", "Attribute": "`aria-controls`", "Usage": "Points to the `id` of the element that is being controlled, for example, a Grid." }, { "Selector": "`.k-pager-nav`", "Attribute": "`role=button` or `nodeName=button`", "Usage": "Specifies the role of the element." }, { "Selector": "", "Attribute": "`aria-disabled=true`", "Usage": "The attribute is present when the the `Arrow` button is disabled, for example, present on the **Previous** button when the current page is the first one." }, { "Selector": "", "Attribute": "`title`", "Usage": "Specifies the purpose of each button." }, { "Selector": "", "Attribute": "`aria-label` or `title`", "Usage": "Specifies the purpose of each link, for example, `Page 6`." }, { "Selector": "", "Attribute": "`aria-current=page`", "Usage": "The attribute must be present on the currently selected page element." }, { "Selector": "`.k-pager-sizes>.k-dropdownlist`", "Attribute": "`aria-label`", "Usage": "The element requires an `aria-label` to specify its purpose." }, { "Selector": "`.k-pager-numbers-wrap>.k-dropdown`", "Attribute": "`aria-label`", "Usage": "The element requires an `aria-label` to specify its purpose." }, { "Selector": "`.k-pager-input>.k-input>.k-input-inner`", "Attribute": "`aria-label`", "Usage": "The element requires an `aria-label` to specify its purpose." } ] } }, { "h3": "Managing the Focus" }, { "p": "The Pager wrapper element is part of the page tab sequence. When focused, it allows the user to press `Enter` to activate its inner navigation. The inner navigation in the component also relies on `Tab`. When the focus is inside the Pager, it is trapped." }, { "p": "Each specific implementation of the Pager component may offer a configuration option that allows you to change the default behavior of the component that is described in this section. The purpose of such alternative behavior may be to include all Pager elements directly in the document tab sequence or to implement `Arrow`-based navigation among the inner Pager elements." }, { "p": "Important notes:" }, { "ul": [ "All buttons in the Pager, including the disabled ones, are always focusable.", "In scenarios when the currently focused button disappears from the Pager upon user interaction, for example, the **More pages** button, you must move the focus to the button representing the currently selected page." ] }, { "h3": "Keyboard Shortcuts" }, { "p": "The following sections describe the keyboard navigation of the Pager according to the specific use-case scenario." }, { "h4": "All Scenarios" }, { "p": "The following table lists the keyboard combinations supported by the Pager and valid for all scenarios." }, { "table": { "headers": [ "Shortcut", "Behavior" ], "rows": [ { "Shortcut": "`Home`", "Behavior": "Loads the first page of data if the current page is not the first one." }, { "Shortcut": "`End`", "Behavior": "Loads the last page of data if the current page is not the last one." } ] } }, { "h4": "Focused Wrapper" }, { "p": "The following table lists the keyboard combinations supported by the Pager when its wrapper element is focused." }, { "table": { "headers": [ "Shortcut", "Behavior" ], "rows": [ { "Shortcut": "`Enter`", "Behavior": "Activates the inner Pager navigation." }, { "Shortcut": "`Tab`", "Behavior": "Navigates to the next focusable element on the page." }, { "Shortcut": "`Shift` + `Tab`", "Behavior": "Navigates to the previous focusable element on the page." }, { "Shortcut": "`Left Arrow`", "Behavior": "Loads the previous page of data, if any." }, { "Shortcut": "`Right Arrow`", "Behavior": "Loads the next page of data, if any." }, { "Shortcut": "`Page Up`", "Behavior": "Loads the previous page of data, if any." }, { "Shortcut": "`Page Down`", "Behavior": "Loads the next page of data, if any." } ] } }, { "h4": "Activated Inner Navigation" }, { "p": "The following table lists the keyboard combinations supported by the Pager when its inner navigatin is activated." }, { "table": { "headers": [ "Shortcut", "Behavior" ], "rows": [ { "Shortcut": "`Esc`", "Behavior": "Moves the focus back to the wrapper element. Deactivates the inner Pager navigation." }, { "Shortcut": "`Tab`", "Behavior": "Navigates to the next focusable element in the Pager. If the current focus is on the last element, moves the focus to the first focusable item in the component." }, { "Shortcut": "`Shift` + `Tab`", "Behavior": "Navigates to the previous focusable element in the Pager. If the current focus is on the first element, moves the focus to the last focusable item in the component." }, { "Shortcut": "`Enter`", "Behavior": "For button items, and Pager input executes the currently focused action (page change)." } ] } }, { "h3": "Testing" }, { "p": "The Pager 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 Pager 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/#navigation", "title": "WAI-ARIA Specification for Navigation" } }, { "link": { "source": "https://a11y-style-guide.com/style-guide/section-navigation.html#kssref-navigation-pagination", "title": "Accessibility Style Guide: Pagination" } } ] } ]