0.0.2 • Published 9 years ago
boost-js-tabs v0.0.2
Boost JS Tabs 
A style-free tabs plugin for jQuery and Boost JS. While other plugins style and arrange your tabs and panels for you, this plugin only handles the functionality, leaving the layout and styling up to you.
Installation
Install with npm:
npm install boost-js-tabsInstall in browser:
<script src="https://cdn.rawgit.com/marksmccann/boost-js-tabs/master/dist/tabs.min.js"></script>Usage
Create Plugin
var boost = require('boost-js');
// var boost = $.fn.boost; (browser install)
var tabs = require('boost-js-tabs');
// var tabs = $.fn.boost.tabs; (browser install)
$.fn.tabs = boost( tabs.plugin, tabs.defaults );Markup Structure
<ul id="tabs">
<li><a href="#panel1" data-bind="#tabs" data-role="tab">Tab 1</a></li>
<li><a href="#panel2" data-bind="#tabs" data-role="tab">Tab 2</a></li>
<li><a href="#panel3" data-bind="#tabs" data-role="tab">Tab 3</a></li>
</ul>
<div id="panel1" data-bind="#tabs" data-role="panel">Panel 1</div>
<div id="panel2" data-bind="#tabs" data-role="panel">Panel 2</div>
<div id="panel3" data-bind="#tabs" data-role="panel">Panel 3</div>Note: data-bind is used to link the element to the instance, data-role is used to define the element's role in that instance. See Boost JS for more details.
Instantiate Plugin
$('#tabs').tabs();Options
| Name | Default | Description |
|---|---|---|
| activeClass | "is-active" | the class added to tab and panel when active |
| onInit | null | a callback function called when plugin is intialized |
| onChange | null | a callback function called when tabs switch |
Usage
$('#tabs').tabs({
onInit: function() {
console.log( this.id ); // 'tabs'
}
});- or -
<ul id="tabs" data-active-class="your-new-class">...</ul>API
changeToPanel( 'panelID', callback )
Activate a tab by providing the desired panel's id. Optional callback function called after change.
instance.changeToPanel( 'panel2', function(){
console.log("Panel 2 is now active.");
});activePanel
The id of the current active panel.
instance.activePanel // [panelID]pairsByPanel
Each panel and corresponding tab grouped into a jquery object and organized by panel id.
instance.pairsByPanel // { panel1: $( 0:tab1, 1:panel1 ), ... }Running Tests
$ npm install && npm testLicense
Copyright © 2016, Mark McCann. Released under the MIT license.