Line 105: | Line 105: | ||
}; | }; | ||
document.addEventListener("DOMContentLoaded", function () { | document.addEventListener("DOMContentLoaded", function () { | ||
− | window.html = qs("template") | + | window.html = qs("template"); |
var handle = qs(".JC #handle"), | var handle = qs(".JC #handle"), | ||
sprite = qs(".JC #sprite"); | sprite = qs(".JC #sprite"); |
Revision as of 14:59, 1 November 2017
var st,qs = document.querySelector.bind(document),
magic = !1, objectList = null, qsa = document.querySelectorAll.bind(document), page = (location.pathname.length >14)?location.pathname.substring(14).replace(/\//g, "*"):"Home", mouseDetected = !1, safe = !0;
if (window.NodeList && !NodeList.prototype.forEach) {
NodeList.prototype.forEach = function (callback, thisArg) { thisArg = thisArg || window; for (var i = 0; i < this.length; i++) { callback.call(thisArg, this[i], i, this); } };
} function animate() {
safe && (handle.style.webkitAnimationName = "handle", handle.style.animationName = "handle", sprite.style.webkitAnimationName = "sprite", sprite.style.animationName = "sprite", safe = !1)
}
function loadStyleSheet(e) {
if (document.createStyleSheet) document.createStyleSheet(e); else { var t = document.createElement("link"); t.href = e, t.rel = "stylesheet", t.type = "text/css", document.getElementsByTagName("head")[0].appendChild(t) }
}
function AJAX(e, t, z) {
clearTimeout(st); var n, lb = qs(".JC #loadbar"); lb.style.opacity = "1"; (n = new XMLHttpRequest).onreadystatechange = function () { if (z) lb.style.width = n.readyState * 25 + "%"; 4 == n.readyState && t(n) }, n.open("GET", e, !0), n.send(), st = setTimeout(function () { lb.style.opacity = "0"; st = setTimeout(function () { lb.style.width = "0%" }, 500) }, 1000)
}
function createindex() {
var e = contentIndexData; Object.keys(e.project).forEach(function (t, n) {"string" == typeof e.project[t] ? qs("#O2>ul").innerHTML += '
})) }), Object.keys(e.team).forEach(function (t, n) {"string" == typeof e.team[t] ? qs("#O4>ul").innerHTML += '
})) }), Object.keys(e.humanPractices).forEach(function (t, n) {"string" == typeof e.humanPractices[t] ? qs("#O3>ul").innerHTML += '
})) })
}
function newPage(e) {
var t = (e = window.e || e).target.getAttribute("href"); if (null !== t && ("£" == t[0] || "#" == t[0])) { if ("#" == t[0]) { magic = !0; try { qs(".JC #content-body " + t).scrollIntoView({ behavior: "smooth", block: "start", inline: "nearest" }) } catch (e) { location.hash = t } return t == "#" + e.target.parentElement.id && window.scrollTo(0, document.body.scrollTop), void e.preventDefault() } e.preventDefault(), loadPage(t = t.substring(1)), window.history.pushState(null, null, "/Team:Judd_UK/" + t.replace("*", "/")) }
}
function renderPage() {
var n = html.content || html; qs(".JC #content-body").innerHTML = "", qs(".JC #content-index ol").innerHTML = "", "false" != n.querySelector("div").dataset.templated && qsa("[data-selector]").forEach(function (e) { var t = n.querySelector(e.dataset.selector); e.innerHTML = t ? e.dataset.text ? t.innerText : t.outerHTML : "" }), "false" != n.querySelector("div").dataset.wiki ? (qs(".JC #content-index").style.display = "block", n.querySelectorAll("h2, h3").forEach(function (e, t) {"H2" == e.tagName ? qs(".JC #content-index ol").innerHTML += '
- <a href="#' + e.innerHTML.replace(/\s+/g, "-").replace(/[^A-Z0-9-_]+/gi, "") + "-" + t + '">' + e.innerHTML + "</a>
}), n.querySelectorAll("div h2, div h3").forEach(function (e, t) { e.id = e.innerHTML.replace(/\s+/g, "-").replace(/[^A-Z0-9-_]+/gi, "") + "-" + t })) : qs(".JC #content-index").style.display = "none", qs(".JC #content-body").innerHTML = n.querySelector("div") ? n.querySelector("div").innerHTML : ""; n.querySelectorAll("script").forEach(function (p) { if (p.dataset.run != "false") eval(p.innerHTML) })
}
function loadPage(e) {
qs(".JC #content-container").style.visibility = "hidden", AJAX("/Team:Judd_UK/Pages/" + e + "?action=raw&ctype=text/plain", function (t) { if (200 == t.status) { page = e, html.innerHTML = t.responseText; renderPage(), qs(".JC #content-container").style.visibility = "visible", animate() } else loadPage("404") }, true)
} window.onpopstate = function (e) {
return magic ? void(magic = !1) : void((location.pathname.length >14)?location.pathname.substring(14).replace(/\//g, "*"):"Home" != page && loadPage((location.pathname.length >14)?location.pathname.substring(14).replace(/\//g, "*"):"Home"))
}; document.addEventListener("DOMContentLoaded", function () { window.html = qs("template");
var handle = qs(".JC #handle"), sprite = qs(".JC #sprite"); qs("#HQ_page #bodyContent>.mw-content-ltr").classList.remove("mw-content-ltr"), qs("#HQ_page #bodyContent").id = "", qs("#HQ_page").id = "", page != "Home" ? loadPage(page) : "", createindex(), qs(".JC #sprite").addEventListener((void 0 === qs(".JC").style.animationName ? "webkit" : "") + "animationend", function () { handle.style.webkitAnimationName = "", handle.style.animationName = "", sprite.style.webkitAnimationName = "", sprite.style.animationName = "", safe = !0 }, !1), qs(".JC #main-img").onmouseenter = animate, document.addEventListener("click", newPage, !1), document.addEventListener("mousemove", function () { mouseDetected && (qs("#topstyles").innerHTML = ""), mouseDetected = !0, document.removeEventListener("mousemove", arguments.callee) }, !1), qs("#topstyles").innerHTML = ".JC #O1 a{transform:translateX(-150%)!important;opacity:1!important}.JC #O2 a{transform: translateX(-50%)!important;opacity:1!important}.JC #O3 a{transform:translateX(50%)!important;opacity:1!important}.JC #O4 a{transform:translateX(150%)!important;opacity:1!important}", setTimeout(function () { mouseDetected ? qs("#topstyles").innerHTML = "" : mouseDetected = !0 }, 4e3), loadStyleSheet("https://fonts.googleapis.com/css?family=Raleway%7COpen+Sans:300"), loadStyleSheet("https://fonts.googleapis.com/css?family=Creepster");
});