2014-09-25 08:52:58 -05:00
|
|
|
/*
|
|
|
|
js tabs and tabbed content plugin
|
2014-07-25 23:24:27 -05:00
|
|
|
*/
|
|
|
|
function Tabs(selector) {
|
|
|
|
|
|
|
|
function hide($nav) {
|
|
|
|
console.log("hide", $nav);
|
|
|
|
$nav.removeClass("js-tab-nav-show");
|
|
|
|
$($nav.data("tab-target")).removeClass("js-tab-show").hide();
|
|
|
|
}
|
|
|
|
|
|
|
|
function show($nav) {
|
|
|
|
console.log("show", $nav);
|
|
|
|
$nav.addClass("js-tab-nav-show");
|
|
|
|
$($nav.data("tab-target")).addClass("js-tab-show").show();
|
|
|
|
}
|
|
|
|
|
|
|
|
var $e = $(selector);
|
|
|
|
if ($e.length) {
|
|
|
|
// pre-assign init index
|
|
|
|
var $current = $e.find('.js-tab-nav-show');
|
|
|
|
if ($current.length) {
|
|
|
|
$($current.data("tab-target")).addClass("js-tab-show");
|
|
|
|
}
|
|
|
|
// bind nav click
|
2014-09-25 08:52:58 -05:00
|
|
|
$e.on("click", ".js-tab-nav", function (e) {
|
|
|
|
e.preventDefault();
|
2014-07-25 23:24:27 -05:00
|
|
|
var $this = $(this);
|
|
|
|
// is showing, not change.
|
|
|
|
if ($this.hasClass("js-tab-nav-show")) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
$current = $e.find(".js-tab-nav-show").eq(0);
|
|
|
|
hide($current);
|
|
|
|
show($this);
|
|
|
|
});
|
|
|
|
console.log("init tabs @", selector)
|
|
|
|
}
|
2014-09-25 08:52:58 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
$.fn.extend({
|
|
|
|
tabs: function () {
|
|
|
|
Tabs(this);
|
|
|
|
}
|
|
|
|
});
|