makeup-active-descendant
Implements ARIA active descendant keyboard navigation.
A vanilla JavaScript port of jquery-active-descendant.
Experimental
This module is still in an experimental state, until it reaches v1.0.0 you must consider all minor releases as breaking changes. Patch releases may introduce new features, but will be backwards compatible.
Install
npm install makeup-active-descendant
yarn add makeup-active-descendant
Example
const ActiveDescendant = require('makeup-active-descendant');
const widgetEl = document.querySelector('.widget');
const inputEl = widgetEl.querySelector('input');
const ownedEl = widgetEl.querySelector('ul');
const activeDescendant = ActiveDescendant.createLinear(widgetEl, focusEl, ownedEl, 'li');
activeDescendant.index = 0;
widgetEl.addEventListener('activeDescendantChange', function(e) {
})
Markup before:
<div class="widget">
<input type="text">
<ul>
<li>Item 1</li>
<li>Item 2</li>
<li>Item 3</li>
</ul>
</div>
Markup after:
<div class="widget" id="widget-0">
<input type="text" aria-activedescendant="widget-0-item-0" aria-owns="widget-0-list-0">
<ul id="widget-0-list-0">
<li id="widget-0-item-0" data-makeup-index="0">Item 1</li>
<li id="widget-0-item-1" data-makeup-index="1">Item 2</li>
<li id="widget-0-item-1" data-makeup-index="2">Item 3</li>
</ul>
</div>
Custom Events
Dependencies
makeup-navigation-emitter
makeup-next-id
Development
npm start
npm test
npm run lint
npm run fix
npm run build
npm run clean
The following hooks exist, and do not need to be invoked manually:
npm prepublishOnly
cleans, lints, tests and builds on every npm publish
commandpre-commit
cleans, lints, tests and builds on every git commit
command
Test Reports
Each test run will generate the following reports:
/reports/coverage
contains Istanbul code coverage report/reports/html
contains HTML test report
CI Build
https://travis-ci.org/makeup-js/makeup-active-descendant
Code Coverage
https://coveralls.io/github/makeup-js/makeup-active-descendant