Accessibility in Vue Calendar component
11 Jun 20248 minutes to read
The Calendar component followed the accessibility guidelines and standards, including ADA, Section 508, WCAG 2.2 standards, and WCAG roles that are commonly used to evaluate accessibility.
The accessibility compliance for the Calendar component is outlined below.
WAI-ARIA attributes
The web accessibility makes web content and web applications more accessible for disabled people. It especially helps in dynamic content change and development of advanced user interface controls with AJAX, HTML, JavaScript, and related technologies.
Calendar provides built-in compliance with WAI-ARIA specifications. WAI-ARIA support is achieved through attributes like aria-label
, aria-selected
, aria-disabled
, and aria-activedescendant
applied for navigation buttons, and disable and active day cells.
It helps disabled persons by providing information about the widget for assistive technology in the screen readers. Calendar component contains grid role and grid cell for each day cell.
-
Aria-label: This attribute provides text labels for an object for the previous and next month’s elements. It helps the screen reader object to read.
-
Aria-selected: Indicates the currently selected date of the Calendar component.
-
Aria-disabled: Indicates the disabled state of the Calendar component.
-
Aria-activedescendent: Helps in managing the current active child of the Calendar component.
-
Role: Gives information to assistive technologies about how to handle each element in a widget.
-
Grid-cell: Defines the individual cell that can be focused and selected.
Keyboard interaction
You can use the following keys to interact with the Calendar. This component implements keyboard navigation support by following the WAI-ARIA practices.
It supports the following list of shortcut keys:
Press | To do this |
---|---|
Upper Arrow | Focuses the same day of the previous week. |
Down Arrow | Focuses the same day of the next week. |
Left Arrow | Focuses the day before. |
Right Arrow | Focuses the next day. |
Home | Focuses the first day of the month. |
End | Focuses the last day of the month. |
Page Up | Focuses the same date of the previous month. |
Page Down | Focuses the same date of the next month. |
Enter | Selects the currently focused date. |
Shift + Page Up | Focuses the same date for the previous year. |
Shift + Page Down | Focuses the same date for the next year. |
Control + Upper Arrow | Moves to the inner level of view like month to year and year to decade. |
Control + Down Arrow | Moves out from the depth level view like decade to year and year to month. |
Control + Home | Focuses the first date of the current year. |
Control + End | Focuses the last date of the current year. |
To focus the Calendar component, use
alt+t
keys.
<template>
<div id="app">
<div class='wrap'>
<ejs-calendar id='calendar' ref="CalendarInstance"></ejs-calendar>
</div>
</div>
</template>
<script setup>
import { CalendarComponent as EjsCalendar } from "@syncfusion/ej2-vue-calendars";
import { onMounted, ref } from "vue";
const CalendarInstance = ref(null);
onMounted(() => {
let calendarObj = CalendarInstance.value;
document.onkeyup = function (e) {
if (e.altKey && e.keyCode === 84) {
// press alt+t to focus the control.
calendarObj.$el.querySelectorAll('.e-content table')[0].focus();
}
}
});
</script>
<style>
@import "../node_modules/@syncfusion/ej2-base/styles/material.css";
@import "../node_modules/@syncfusion/ej2-buttons/styles/material.css";
@import "../node_modules/@syncfusion/ej2-vue-calendars/styles/material.css";
.wrap {
margin: 35px auto;
width: 240px;
}
</style>
<template>
<div id="app">
<div class='wrap'>
<ejs-calendar id='calendar' ref="CalendarInstance"></ejs-calendar>
</div>
</div>
</template>
<script>
import { CalendarComponent } from "@syncfusion/ej2-vue-calendars";
export default {
name: "App",
components: {
"ejs-calendar": CalendarComponent
},
mounted() {
let calendarObj = this.$refs.CalendarInstance;
document.onkeyup = function (e) {
if (e.altKey && e.keyCode === 84) {
// press alt+t to focus the control.
calendarObj.$el.querySelectorAll('.e-content table')[0].focus();
}
}
}
}
</script>
<style>
@import "../node_modules/@syncfusion/ej2-base/styles/material.css";
@import "../node_modules/@syncfusion/ej2-buttons/styles/material.css";
@import "../node_modules/@syncfusion/ej2-vue-calendars/styles/material.css";
.wrap {
margin: 35px auto;
width: 240px;
}
</style>
Ensuring accessibility
The Calendar component’s accessibility levels are ensured through an accessibility-checker and axe-core software tools during automated testing.
The accessibility compliance of the Calendar component is shown in the following sample. Open the sample in a new window to evaluate the accessibility of the Calendar component with accessibility tools.