Skip to content

Commit

Permalink
Improving accessibility
Browse files Browse the repository at this point in the history
* Improving keyboard navigation. Now works with time picker too.
* Shorthand weekday names are now displayed as `abbr` tags, with full names as title.
* Using a colour with higher contrast for month navigation.
* Adding a WAI-ARIA compatible description.
* The text field now has `aria-live="polite"`, which should update screenreader users as soon as the value changes.
* The date picker popper now has the `aria-hidden` tag, making it invisible to screenreaders and assistive technologies, in order to make navigation more straightforward.

Detailed discussion at WordPress/gutenberg#1311
  • Loading branch information
aldavigdis committed Jun 16, 2018
1 parent 67f05e9 commit 768dcea
Show file tree
Hide file tree
Showing 8 changed files with 7,030 additions and 7,486 deletions.
14,215 changes: 6,784 additions & 7,431 deletions docs-site/bundle.js

Large diffs are not rendered by default.

12 changes: 8 additions & 4 deletions docs-site/style.css
Original file line number Diff line number Diff line change
Expand Up @@ -431,6 +431,9 @@
position: relative;
display: inline-block;
}
.react-datepicker__input-container .keyboard-nav-description {
display: none;
}

.react-datepicker__year-read-view,
.react-datepicker__month-read-view,
Expand Down Expand Up @@ -620,10 +623,10 @@
border: 0.81rem solid transparent;
}
.react-datepicker__portal .react-datepicker__navigation--previous {
border-right-color: #ccc;
border-right-color: #000;
}
.react-datepicker__portal .react-datepicker__navigation--previous:hover {
border-right-color: #b3b3b3;
border-right-color: #1a1a1a;
}
.react-datepicker__portal .react-datepicker__navigation--previous--disabled,
.react-datepicker__portal
Expand All @@ -632,10 +635,11 @@
cursor: default;
}
.react-datepicker__portal .react-datepicker__navigation--next {
border-left-color: #ccc;
outline: 10px solid red;
border-left-color: #000;
}
.react-datepicker__portal .react-datepicker__navigation--next:hover {
border-left-color: #b3b3b3;
border-left-color: #1a1a1a;
}
.react-datepicker__portal .react-datepicker__navigation--next--disabled,
.react-datepicker__portal .react-datepicker__navigation--next--disabled:hover {
Expand Down
18 changes: 13 additions & 5 deletions src/calendar.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,8 @@ import {
allDaysDisabledBefore,
allDaysDisabledAfter,
getEffectiveMinDate,
getEffectiveMaxDate
getEffectiveMaxDate,
getWeedayLongInLocale
} from "./date_utils";

const DROPDOWN_FOCUS_CLASSNAMES = [
Expand Down Expand Up @@ -117,7 +118,9 @@ export default class Calendar extends React.Component {
onDropdownFocus: () => {},
monthsShown: 1,
forceShowMonthNavigation: false,
timeCaption: "Time"
timeCaption: "Time",
navigationNextText: "Next month",
navigationPreviousText: "Previous month"
};
}

Expand Down Expand Up @@ -284,10 +287,11 @@ export default class Calendar extends React.Component {
const day = addDays(cloneDate(startOfWeek), offset);
const localeData = getLocaleData(day);
const weekDayName = this.formatWeekday(localeData, day);
const weekDayNameLong = getWeedayLongInLocale(localeData, day);

return (
<div key={offset} className="react-datepicker__day-name">
{weekDayName}
<abbr title={weekDayNameLong}>{weekDayName}</abbr>
</div>
);
})
Expand Down Expand Up @@ -340,7 +344,9 @@ export default class Calendar extends React.Component {
type="button"
className={classes.join(" ")}
onClick={clickHandler}
/>
>
{this.props.navigationPreviousText}
</button>
);
};

Expand Down Expand Up @@ -383,7 +389,9 @@ export default class Calendar extends React.Component {
type="button"
className={classes.join(" ")}
onClick={clickHandler}
/>
>
{this.props.navigationNextText}
</button>
);
};

Expand Down
46 changes: 46 additions & 0 deletions src/date_utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -197,6 +197,18 @@ export function addMinutes(date, amount) {
return add(date, amount, "minutes");
}

export function increaseMinutes(date, interval) {
date = date.seconds(0);
var diff = intervalMinutesDiffInc(date, interval);
return addMinutes(date, diff);
}

export function decreaseMinutes(date, interval) {
date = date.seconds(0);
var diff = intervalMinutesDiffDec(date, interval);
return subtractMinutes(date, diff);
}

export function addHours(date, amount) {
return add(date, amount, "hours");
}
Expand All @@ -218,6 +230,14 @@ export function addYears(date, amount) {
}

// *** Subtraction ***
export function subtractMinutes(date, amount) {
return subtract(date, amount, "minutes");
}

export function subtractHours(date, amount) {
return subtract(date, amount, "hours");
}

export function subtractDays(date, amount) {
return subtract(date, amount, "days");
}
Expand Down Expand Up @@ -301,6 +321,28 @@ export function getDaysDiff(date1, date2) {
return getDiff(date1, date2, "days");
}

export function intervalMinutesDiffInc(date, interval) {
var minute = date.minute();
var newMinute = Math.ceil(date.minute() / interval) * interval;
var diff = Math.abs(newMinute - minute);

if (diff == 0) {
return interval;
}
return diff;
}

export function intervalMinutesDiffDec(date, interval) {
var minute = date.minute();
var newMinute = Math.floor(date.minute() / interval) * interval;
var diff = Math.abs(newMinute - minute);

if (diff == 0) {
return interval;
}
return diff;
}

// ** Date Localization **

export function localizeDate(date, locale) {
Expand Down Expand Up @@ -339,6 +381,10 @@ export function getWeekdayShortInLocale(locale, date) {
return locale.weekdaysShort(date);
}

export function getWeedayLongInLocale(locale, date) {
return moment.localeData().weekdays(date);
}

// TODO what is this format exactly?
export function getMonthInLocale(locale, date, format) {
return locale.months(date, format);
Expand Down
Loading

0 comments on commit 768dcea

Please sign in to comment.