Package Exports
- makeup-roving-tabindex
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (makeup-roving-tabindex) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
makeup-roving-tabindex
Implements a roving tab index on given collection of elements
A vanilla JavaScript port of jquery-roving-tabindex.
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
// via npm
npm install makeup-roving-tabindex
// via yarn
yarn add makeup-roving-tabindexExample
// require the module
const RovingTabindex = require('makeup-roving-tabindex');
// get an element reference
const widgetEl = document.querySelector('.widget');
// create a roving tabindex instance on the element
const rovingTabindex = RovingTabindex.createLinear(widgetEl, 'li', { index: 0 });
// listen for events (optional)
widgetEl.addEventListener('rovingTabindexChange', function(e) {
// console.log(e.detail);
})Markup before:
<div class="widget">
<ul>
<li>Item 1</li>
<li>Item 2</li>
<li>Item 3</li>
</ul>
</div>Markup after:
<div class="widget">
<ul>
<li data-makeup-index="0" tabindex="0">Item 1</li>
<li data-makeup-index="1" tabindex="-1">Item 2</li>
<li data-makeup-index="2" tabindex="-1">Item 3</li>
</ul>
</div>Options
index: the index position of the active item (default: 0)
Custom Events
rovingTabindexChange- detail
- fromIndex
- toIndex
- detail
Dependencies
makeup-navigation-emitter
Development
npm startnpm testnpm run lintnpm run fixnpm run buildnpm run clean
The following hooks exist, and do not need to be invoked manually:
npm prepublishOnlycleans, lints, tests and builds on everynpm publishcommandpre-commitcleans, lints, tests and builds on everygit commitcommand
Test Reports
Each test run will generate the following reports:
/reports/coveragecontains Istanbul code coverage report/reports/htmlcontains HTML test report
CI Build
https://travis-ci.org/makeup-js/makeup-roving-tabindex
Code Coverage
https://coveralls.io/github/makeup-js/makeup-roving-tabindex