mirror of
https://code.castopod.org/adaures/castopod
synced 2025-04-23 01:01:20 +00:00

- add .editorconfig file - format all files to comply with castopod's coding style - switch parsedown dependency with commonmark library to better follow commonmark spec for markdown - add prettier command to format all project files at once closes #16
110 lines
2.8 KiB
JavaScript
110 lines
2.8 KiB
JavaScript
//--------------------------------------------------------------------
|
|
// Tabs
|
|
//--------------------------------------------------------------------
|
|
|
|
var tabLinks = [];
|
|
var contentDivs = [];
|
|
|
|
function init() {
|
|
// Grab the tab links and content divs from the page
|
|
var tabListItems = document.getElementById("tabs").childNodes;
|
|
console.log(tabListItems);
|
|
for (var i = 0; i < tabListItems.length; i++) {
|
|
if (tabListItems[i].nodeName == "LI") {
|
|
var tabLink = getFirstChildWithTagName(tabListItems[i], "A");
|
|
var id = getHash(tabLink.getAttribute("href"));
|
|
tabLinks[id] = tabLink;
|
|
contentDivs[id] = document.getElementById(id);
|
|
}
|
|
}
|
|
|
|
// Assign onclick events to the tab links, and
|
|
// highlight the first tab
|
|
var j = 0;
|
|
|
|
for (id in tabLinks) {
|
|
tabLinks[id].onclick = showTab;
|
|
tabLinks[id].onfocus = function () {
|
|
this.blur();
|
|
};
|
|
if (j == 0) {
|
|
tabLinks[id].className = "active";
|
|
}
|
|
j++;
|
|
}
|
|
|
|
// Hide all content divs except the first
|
|
var k = 0;
|
|
|
|
for (id in contentDivs) {
|
|
if (k != 0) {
|
|
console.log(contentDivs[id]);
|
|
contentDivs[id].className = "content hide";
|
|
}
|
|
k++;
|
|
}
|
|
}
|
|
|
|
//--------------------------------------------------------------------
|
|
|
|
function showTab() {
|
|
var selectedId = getHash(this.getAttribute("href"));
|
|
|
|
// Highlight the selected tab, and dim all others.
|
|
// Also show the selected content div, and hide all others.
|
|
for (var id in contentDivs) {
|
|
if (id == selectedId) {
|
|
tabLinks[id].className = "active";
|
|
contentDivs[id].className = "content";
|
|
} else {
|
|
tabLinks[id].className = "";
|
|
contentDivs[id].className = "content hide";
|
|
}
|
|
}
|
|
|
|
// Stop the browser following the link
|
|
return false;
|
|
}
|
|
|
|
//--------------------------------------------------------------------
|
|
|
|
function getFirstChildWithTagName(element, tagName) {
|
|
for (var i = 0; i < element.childNodes.length; i++) {
|
|
if (element.childNodes[i].nodeName == tagName) {
|
|
return element.childNodes[i];
|
|
}
|
|
}
|
|
}
|
|
|
|
//--------------------------------------------------------------------
|
|
|
|
function getHash(url) {
|
|
var hashPos = url.lastIndexOf("#");
|
|
return url.substring(hashPos + 1);
|
|
}
|
|
|
|
//--------------------------------------------------------------------
|
|
|
|
function toggle(elem) {
|
|
elem = document.getElementById(elem);
|
|
|
|
var disp = "";
|
|
if (elem.style && elem.style["display"]) {
|
|
// Only works with the "style" attr
|
|
disp = elem.style["display"];
|
|
} else if (elem.currentStyle) {
|
|
// For MSIE, naturally
|
|
disp = elem.currentStyle["display"];
|
|
} else if (window.getComputedStyle) {
|
|
// For most other browsers
|
|
disp = document.defaultView
|
|
.getComputedStyle(elem, null)
|
|
.getPropertyValue("display");
|
|
}
|
|
|
|
// Toggle the state of the "display" style
|
|
elem.style.display = disp == "block" ? "none" : "block";
|
|
|
|
return false;
|
|
}
|