meshviewer/lib/tabs.js

64 lines
1.3 KiB
JavaScript

define(function () {
'use strict';
return function () {
var self = this;
var tabs = document.createElement('ul');
tabs.classList.add('tabs');
var container = document.createElement('div');
function gotoTab(li) {
for (var i = 0; i < tabs.children.length; i++) {
tabs.children[i].classList.remove('visible');
}
while (container.firstChild) {
container.removeChild(container.firstChild);
}
li.classList.add('visible');
var tab = document.createElement('div');
tab.classList.add('tab');
container.appendChild(tab);
li.child.render(tab);
}
function switchTab() {
gotoTab(this);
return false;
}
self.add = function add(title, d) {
var li = document.createElement('li');
li.textContent = _.t(title);
li.onclick = switchTab;
li.child = d;
tabs.appendChild(li);
var anyVisible = false;
for (var i = 0; i < tabs.children.length; i++) {
if (tabs.children[i].classList.contains('visible')) {
anyVisible = true;
break;
}
}
if (!anyVisible) {
gotoTab(li);
}
};
self.render = function render(el) {
el.appendChild(tabs);
el.appendChild(container);
};
return self;
};
});