website/js/script.js

486 lines
32 KiB
JavaScript
Executable File

// adorable little functions
function booleanAttributeValue(element, attribute, defaultValue){
// returns true if an attribute is present with no value
// e.g. booleanAttributeValue(element, 'data-modal', false);
if (element.hasAttribute(attribute)) {
var value = element.getAttribute(attribute);
if (value === '' || value === 'true') {
return true;
} else if (value === 'false') {
return false;
}
}
return defaultValue;
}
var π, π1, πd;
(function(){
return;
})(); // end π
//modal close button
(function(){
//π.modalCloseButton = function(closingFunction){
// return π.button('pi-modal-close-button', null, null, closingFunction);
//};
})();
///********************************************************************
// π-pushmenu.js
// // TODO: USAGE AND API REFERENCE
// ______________________________________________
// DEPENDENCIES:
//
// HAL.js
//
// ______________________________________________
// DATA ATTRIBUTES:
//
// side: ["left", "right"]
// ______________________________________________
// MARKUP AND DEFAULTS:
//
// <div class="pi-pushmenu" id="myPushMenu">
// <ul>
// <li><a href="#">foo</a></li>
// <li><a href="#">bar</a></li>
// <li><a href="#">gronk</a></li>
// <li><a href="#">fleebles</a></li>
// <li><a href="#">sepulveda</a></li>
// </ul>
// </div>
//
//elsewhere...
//
// <button onclick="π-pushmenu.show('myPushMenu')">show menu</button>
//
// ______________________________________________
// GENERATED HTML:
//
//
// ______________________________________________
// API
//
//
// ***************************************************************************************/
//
//π.pushmenu = (function(){
// var allPushMenus = {};
//
// function init(){
// π('[data-auto-burger]').forEach(function(container){
// var id = container.getAttribute('data-auto-burger');
//
// var autoBurger = πd(id) || π.div('pi-pushmenu', id);
// var ul = autoBurger.π1('ul') || π.ul();
//
// container.π('a[href], button').forEach(function (obj) {
// if (!booleanAttributeValue(obj, 'data-auto-burger-exclude', false)) {
// var clone = obj.cloneNode(true);
// clone.id = '';
//
// if (clone.tagName == "BUTTON") {
// var aTag = π.srcElement('a');
// aTag.href = '';
// aTag.innerHTML = clone.innerHTML;
// aTag.onclick = clone.onclick;
// clone = aTag;
// }
// ul.add(π.li(0, 0, clone));
// }
// });
//
// autoBurger.add(ul);
// π1('body').add(autoBurger);
// });
//
// π(".pi-pushmenu").forEach(function(el){
// allPushMenus[el.id] = PushMenu(el);
// });
//
// π.setTriggers('pushmenu', π.pushmenu);
// }
//
// function show(objId) {
// allPushMenus[objId].expose();
// }
//
// // TODO: dismiss on click?
// // this works:
//
// //π('.pi-pushmenu li a').forEach(function(a){
// // a.onclick = function(){
// // this.parent('.pi-pushmenu').π1('.pi-modal-close-button').click();
// // console.log("message");
// // };
// //});
//
//
// function PushMenu(el) {
// var html = π1('html');
// var body = π1('body');
//
// var overlay = π.div("overlay");
// var content = π.div('content', null, el.π1('*'));
//
// var side = el.getAttribute("data-side") || "right";
//
// var sled = π.div("sled");
// sled.css(side, 0);
//
// var topBar = π.div("top-bar");
//
// topBar.fill(π.modalCloseButton(closeMe));
// sled.fill([topBar, content]);
//
// overlay.fill(sled);
// el.fill(overlay);
//
// sled.onclick = function(e){
// e.stopPropagation();
// };
//
// overlay.onclick = closeMe;
//
// π.listen(closeMe, 'resize');
//
// function closeMe(e) {
// var t = e.target;
// if (t == sled || t == topBar) return;
//
// el.killClass("on");
// setTimeout(function(){
// el.css({display: "none"});
//
// body.killClass("overlay-on");
// }, 300);
// }
//
// function exposeMe(){
// body.addClass("overlay-on"); // in the default config, kills body scrolling
//
// el.css({
// display: "block",
// zIndex: π.highestZ()
// });
// setTimeout(function(){
// el.addClass("on");
// }, 10);
// }
//
// return {
// expose: exposeMe
// };
// }
//
// //π.mods.push(init);
//
// return {
// show: show
// };
//})();
// globals
var body;
//helper functions
function classOnCondition(element, className, condition) {
if (condition)
$(element).addClass(className);
else
$(element).removeClass(className);
}
function px(n){
return n + 'px';
}
function newDOMElement(tag, className, id){
var el = document.createElement(tag);
if (className) el.className = className;
if (id) el.id = id;
return el;
}
var kub = (function () {
var HEADER_HEIGHT;
var html, header, mainNav, quickstartButton, hero, encyclopedia, footer, wishField;
$(document).ready(function () {
html = $('html');
body = $('body');
header = $('header');
mainNav = $('#mainNav');
wishField = $('#wishField');
quickstartButton = $('#quickstartButton');
hero = $('#hero');
encyclopedia = $('#encyclopedia');
footer = $('footer');
HEADER_HEIGHT = header.outerHeight();
resetTheView();
window.addEventListener('resize', resetTheView);
window.addEventListener('scroll', resetTheView);
window.addEventListener('keydown', handleKeystrokes);
wishField[0].addEventListener('keydown', handleKeystrokes);
document.onunload = function(){
window.removeEventListener('resize', resetTheView);
window.removeEventListener('scroll', resetTheView);
window.removeEventListener('keydown', handleKeystrokes);
wishField[0].removeEventListener('keydown', handleKeystrokes);
};
$('.dropdown').each(function () {
var dropdown = $(this);
var readout = dropdown.find('.readout');
readout.html(dropdown.find('a')[0].innerHTML);
readout.click(function () {
dropdown.toggleClass('on');
window.addEventListener('click', closeOpenDropdown);
function closeOpenDropdown(e) {
if (dropdown.hasClass('on') && !(dropdownWasClicked(e))) {
dropdown.removeClass('on');
window.removeEventListener('click', closeOpenDropdown);
}
}
function dropdownWasClicked(e) {
return $(e.target).parents('.dropdown').length;
}
});
});
setInterval(setFooterType, 10);
});
function setFooterType() {
if (html[0].id == "docs") {
var bodyHeight = hero.outerHeight() + encyclopedia.outerHeight();
var footerHeight = footer.outerHeight();
classOnCondition(body, 'fixed', window.innerHeight - footerHeight > bodyHeight);
}
}
function resetTheView() {
if (html.hasClass('open-nav')) {
toggleMenu();
} else {
HEADER_HEIGHT = header.outerHeight();
}
classOnCondition(html, 'flip-nav', window.pageYOffset > 0);
}
function toggleMenu() {
if (window.innerWidth < 800) {
π.pushmenu.show('primary');
}
else {
var newHeight = HEADER_HEIGHT;
if (!html.hasClass('open-nav')) {
newHeight = mainNav.outerHeight();
}
header.css({height: px(newHeight)});
html.toggleClass('open-nav');
}
}
function submitWish(textfield) {
window.location.replace("https://github.com/kubernetes/kubernetes.github.io/issues/new?title=I%20wish%20" +
window.location.pathname + "%20" + textfield.value + "&body=I%20wish%20" +
window.location.pathname + "%20" + textfield.value);
textfield.value = '';
textfield.blur();
}
function handleKeystrokes(e) {
switch (e.which) {
case 13: {
if (e.currentTarget === wishField) {
submitWish(wishField);
}
break;
}
case 27: {
if (html.hasClass('open-nav')) {
toggleMenu();
}
break;
}
}
}
return {
toggleMenu: toggleMenu
};
})();
// accordion
(function(){
var yah = true;
var moving = false;
var CSS_BROWSER_HACK_DELAY = 25;
$(document).ready(function(){
// Safari chokes on the animation here, so...
if (navigator.userAgent.indexOf('Chrome') == -1 && navigator.userAgent.indexOf('Safari') != -1){
var hackStyle = newDOMElement('style');
hackStyle.innerHTML = '.pi-accordion .wrapper{transition: none}';
body.append(hackStyle);
}
// Gross.
$('.pi-accordion').each(function () {
var accordion = this;
var content = this.innerHTML;
var container = newDOMElement('div', 'container');
container.innerHTML = content;
$(accordion).empty();
accordion.appendChild(container);
CollapseBox($(container));
});
setYAH();
setTimeout(function () {
yah = false;
}, 500);
});
function CollapseBox(container){
container.children('.item').each(function(){
// build the TOC DOM
// the animated open/close is enabled by having each item's content exist in the flow, at its natural height,
// enclosed in a wrapper with height = 0 when closed, and height = contentHeight when open.
var item = this;
// only add content wrappers to containers, not to links
var isContainer = item.tagName === 'DIV';
var titleText = item.getAttribute('data-title');
var title = newDOMElement('div', 'title');
title.innerHTML = titleText;
var wrapper, content;
if (isContainer) {
wrapper = newDOMElement('div', 'wrapper');
content = newDOMElement('div', 'content');
content.innerHTML = item.innerHTML;
wrapper.appendChild(content);
}
item.innerHTML = '';
item.appendChild(title);
if (wrapper) {
item.appendChild(wrapper);
$(wrapper).css({height: 0});
}
$(title).click(function(){
if (!yah) {
if (moving) return;
moving = true;
}
if (container[0].getAttribute('data-single')) {
var openSiblings = item.siblings().filter(function(sib){return sib.hasClass('on');});
openSiblings.forEach(function(sibling){
toggleItem(sibling);
});
}
setTimeout(function(){
if (!isContainer) {
moving = false;
return;
}
toggleItem(item);
}, CSS_BROWSER_HACK_DELAY);
});
function toggleItem(thisItem){
var thisWrapper = $(thisItem).find('.wrapper').eq(0);
if (!thisWrapper) return;
var contentHeight = thisWrapper.find('.content').eq(0).innerHeight() + 'px';
if ($(thisItem).hasClass('on')) {
thisWrapper.css({height: contentHeight});
$(thisItem).removeClass('on');
setTimeout(function(){
thisWrapper.css({height: 0});
moving = false;
}, CSS_BROWSER_HACK_DELAY);
} else {
$(item).addClass('on');
thisWrapper.css({height: contentHeight});
var duration = parseFloat(getComputedStyle(thisWrapper[0]).transitionDuration) * 1000;
setTimeout(function(){
thisWrapper.css({height: ''});
moving = false;
}, duration);
}
}
if (content) {
var innerContainers = $(content).children('.container');
if (innerContainers.length > 0) {
innerContainers.each(function(){
CollapseBox($(this));
});
}
}
});
}
function setYAH() {
var pathname = location.href.split('#')[0]; // on page load, make sure the page is YAH even if there's a hash
var currentLinks = [];
$('.pi-accordion a').each(function () {
if (pathname === this.href) currentLinks.push(this);
});
currentLinks.forEach(function (yahLink) {
$(yahLink).parents('.item').each(function(){
$(this).addClass('on');
$(this).find('.wrapper').eq(0).css({height: 'auto'});
$(this).find('.content').eq(0).css({opacity: 1});
});
$(yahLink).addClass('yah');
yahLink.onclick = function(e){e.preventDefault();};
});
}
//π.mods.push(init);
})();
// TODO: scrollintoview in-page TOC
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["alf.js","π.js","π-baseComponents.js","π-accordion/π-accordion.js","π-pushmenu/π-pushmenu.js","script.js"],"names":[],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AChBA;AACA;AACA;AACA;ACHA;AACA;AACA;AACA;AACA;AACA;AACA;ACNA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC1JA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"script.js","sourcesContent":["// adorable little functions\nfunction booleanAttributeValue(element, attribute, defaultValue){\n\t// returns true if an attribute is present with no value\n\t// e.g. booleanAttributeValue(element, 'data-modal', false);\n\tif (element.hasAttribute(attribute)) {\n\t\tvar value = element.getAttribute(attribute);\n\t\tif (value === '' || value === 'true') {\n\t\t\treturn true;\n\t\t} else if (value === 'false') {\n\t\t\treturn false;\n\t\t}\n\t}\n\n\treturn defaultValue;\n}\n\n","var π, π1, πd;\n(function(){\n\treturn;\n})();  // end π"," //modal close button\n(function(){\n\t//π.modalCloseButton = function(closingFunction){\n\t//\treturn π.button('pi-modal-close-button', null, null, closingFunction);\n\t//};\n})();\n","","///********************************************************************\n// π-pushmenu.js\n// // TODO:  USAGE AND API REFERENCE\n// ______________________________________________\n// DEPENDENCIES:\n//\n// HAL.js\n//\n// ______________________________________________\n// DATA ATTRIBUTES:\n//\n// side: [\"left\", \"right\"]\n// ______________________________________________\n// MARKUP AND DEFAULTS:\n//\n//\t<div class=\"pi-pushmenu\" id=\"myPushMenu\">\n//\t\t <ul>\n//\t\t\t <li><a href=\"#\">foo</a></li>\n//\t\t\t <li><a href=\"#\">bar</a></li>\n//\t\t\t <li><a href=\"#\">gronk</a></li>\n//\t\t\t <li><a href=\"#\">fleebles</a></li>\n//\t\t\t <li><a href=\"#\">sepulveda</a></li>\n//\t\t </ul>\n//\t</div>\n//\n//elsewhere...\n//\n// <button onclick=\"π-pushmenu.show('myPushMenu')\">show menu</button>\n//\n// ______________________________________________\n// GENERATED HTML:\n//\n//\n// ______________________________________________\n// API\n//\n//\n// ***************************************************************************************/\n//\n//π.pushmenu = (function(){\n//\tvar allPushMenus = {};\n//\n//\tfunction init(){\n//\t\tπ('[data-auto-burger]').forEach(function(container){\n//\t\t\tvar id = container.getAttribute('data-auto-burger');\n//\n//\t\t\tvar autoBurger = πd(id) || π.div('pi-pushmenu', id);\n//\t\t\tvar ul = autoBurger.π1('ul') || π.ul();\n//\n//\t\t\tcontainer.π('a[href], button').forEach(function (obj) {\n//\t\t\t\tif (!booleanAttributeValue(obj, 'data-auto-burger-exclude', false)) {\n//\t\t\t\t\tvar clone = obj.cloneNode(true);\n//\t\t\t\t\tclone.id = '';\n//\n//\t\t\t\t\tif (clone.tagName == \"BUTTON\") {\n//\t\t\t\t\t\tvar aTag = π.srcElement('a');\n//\t\t\t\t\t\taTag.href = '';\n//\t\t\t\t\t\taTag.innerHTML = clone.innerHTML;\n//\t\t\t\t\t\taTag.onclick = clone.onclick;\n//\t\t\t\t\t\tclone = aTag;\n//\t\t\t\t\t}\n//\t\t\t\t\tul.add(π.li(0, 0, clone));\n//\t\t\t\t}\n//\t\t\t});\n//\n//\t\t\tautoBurger.add(ul);\n//\t\t\tπ1('body').add(autoBurger);\n//\t\t});\n//\n//\t\tπ(\".pi-pushmenu\").forEach(function(el){\n//\t\t\tallPushMenus[el.id] = PushMenu(el);\n//\t\t});\n//\n//\t\tπ.setTriggers('pushmenu', π.pushmenu);\n//\t}\n//\n//\tfunction show(objId) {\n//\t\tallPushMenus[objId].expose();\n//\t}\n//\n//\t// TODO: dismiss on click?\n//\t// this works:\n//\n//\t//π('.pi-pushmenu li a').forEach(function(a){\n//\t//\ta.onclick = function(){\n//\t//\t\tthis.parent('.pi-pushmenu').π1('.pi-modal-close-button').click();\n//\t//\t\tconsole.log(\"message\");\n//\t//\t};\n//\t//});\n//\n//\n//\tfunction PushMenu(el) {\n//\t\tvar html = π1('html');\n//\t\tvar body = π1('body');\n//\n//\t\tvar overlay = π.div(\"overlay\");\n//\t\tvar content = π.div('content', null, el.π1('*'));\n//\n//\t\tvar side = el.getAttribute(\"data-side\") || \"right\";\n//\n//\t\tvar sled = π.div(\"sled\");\n//\t\tsled.css(side, 0);\n//\n//\t\tvar topBar = π.div(\"top-bar\");\n//\n//\t\ttopBar.fill(π.modalCloseButton(closeMe));\n//\t\tsled.fill([topBar, content]);\n//\n//\t\toverlay.fill(sled);\n//\t\tel.fill(overlay);\n//\n//\t\tsled.onclick = function(e){\n//\t\t\te.stopPropagation();\n//\t\t};\n//\n//\t\toverlay.onclick = closeMe;\n//\n//\t\tπ.listen(closeMe, 'resize');\n//\n//\t\tfunction closeMe(e) {\n//\t\t\tvar t = e.target;\n//\t\t\tif (t == sled || t == topBar) return;\n//\n//\t\t\tel.killClass(\"on\");\n//\t\t\tsetTimeout(function(){\n//\t\t\t\tel.css({display: \"none\"});\n//\n//\t\t\t\tbody.killClass(\"overlay-on\");\n//\t\t\t}, 300);\n//\t\t}\n//\n//\t\tfunction exposeMe(){\n//\t\t\tbody.addClass(\"overlay-on\"); // in the default config, kills body scrolling\n//\n//\t\t\tel.css({\n//\t\t\t\tdisplay: \"block\",\n//\t\t\t\tzIndex: π.highestZ()\n//\t\t\t});\n//\t\t\tsetTimeout(function(){\n//\t\t\t\tel.addClass(\"on\");\n//\t\t\t}, 10);\n//\t\t}\n//\n//\t\treturn {\n//\t\t\texpose: exposeMe\n//\t\t};\n//\t}\n//\n//\t//π.mods.push(init);\n//\n//\treturn {\n//\t\tshow: show\n//\t};\n//})();\n","// globals\nvar body;\n\n//helper functions\nfunction classOnCondition(element, className, condition) {\n\tif (condition)\n\t\t$(element).addClass(className);\n\telse\n\t\t$(element).removeClass(className);\n}\n\nfunction px(n){\n\treturn n + 'px';\n}\n\nfunction newDOMElement(tag, className, id){\n\tvar el = document.createElement(tag);\n\n\tif (className) el.className = className;\n\tif (id) el.id = id;\n\n\treturn el;\n}\n\n\nvar kub = (function () {\n\tvar HEADER_HEIGHT;\n\tvar html, header, mainNav, quickstartButton, hero, encyclopedia, footer, wishField;\n\n\t$(document).ready(function () {\n\t\thtml = $('html');\n\t\tbody = $('body');\n\t\theader = $('header');\n\t\tmainNav = $('#mainNav');\n\t\twishField = $('#wishField');\n\t\tquickstartButton = $('#quickstartButton');\n\t\thero = $('#hero');\n\t\tencyclopedia = $('#encyclopedia');\n\t\tfooter = $('footer');\n\t\tHEADER_HEIGHT = header.outerHeight();\n\n\t\tresetTheView();\n\n\t\twindow.addEventListener('resize', resetTheView);\n\t\twindow.addEventListener('scroll', resetTheView);\n\t\twindow.addEventListener('keydown', handleKeystrokes);\n\t\twishField[0].addEventListener('keydown', handleKeystrokes);\n\n\t\tdocument.onunload = function(){\n\t\t\twindow.removeEventListener('resize', resetTheView);\n\t\t\twindow.removeEventListener('scroll', resetTheView);\n\t\t\twindow.removeEventListener('keydown', handleKeystrokes);\n\t\t\twishField[0].removeEventListener('keydown', handleKeystrokes);\n\t\t};\n\n\t\t$('.dropdown').each(function () {\n\t\t\tvar dropdown = $(this);\n\t\t\tvar readout = dropdown.find('.readout');\n\n\t\t\treadout.html(dropdown.find('a')[0].innerHTML);\n\t\t\treadout.click(function () {\n\t\t\t\tdropdown.toggleClass('on');\n\t\t\t\twindow.addEventListener('click', closeOpenDropdown);\n\n\t\t\t\tfunction closeOpenDropdown(e) {\n\t\t\t\t\tif (dropdown.hasClass('on') && !(dropdownWasClicked(e))) {\n\t\t\t\t\t\tdropdown.removeClass('on');\n\t\t\t\t\t\twindow.removeEventListener('click', closeOpenDropdown);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tfunction dropdownWasClicked(e) {\n\t\t\t\t\treturn $(e.target).parents('.dropdown').length;\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\n\t\tsetInterval(setFooterType, 10);\n\t});\n\n\tfunction setFooterType() {\n\t\tif (html[0].id == \"docs\") {\n\t\t\tvar bodyHeight = hero.outerHeight() + encyclopedia.outerHeight();\n\t\t\tvar footerHeight = footer.outerHeight();\n\n\t\t\tclassOnCondition(body, 'fixed', window.innerHeight - footerHeight > bodyHeight);\n\t\t}\n\t}\n\n\tfunction resetTheView() {\n\t\tif (html.hasClass('open-nav')) {\n\t\t\ttoggleMenu();\n\t\t} else {\n\t\t\tHEADER_HEIGHT = header.outerHeight();\n\t\t}\n\n\t\tclassOnCondition(html, 'flip-nav', window.pageYOffset > 0);\n\t}\n\n\tfunction toggleMenu() {\n\t\tif (window.innerWidth < 800) {\n\t\t\tπ.pushmenu.show('primary');\n\t\t}\n\n\t\telse {\n\t\t\tvar newHeight = HEADER_HEIGHT;\n\n\t\t\tif (!html.hasClass('open-nav')) {\n\t\t\t\tnewHeight = mainNav.outerHeight();\n\t\t\t}\n\n\t\t\theader.css({height: px(newHeight)});\n\t\t\thtml.toggleClass('open-nav');\n\t\t}\n\t}\n\n\tfunction submitWish(textfield) {\n\t\twindow.location.replace(\"https://github.com/kubernetes/kubernetes.github.io/issues/new?title=I%20wish%20\" +\n\t\t\twindow.location.pathname + \"%20\" + textfield.value + \"&body=I%20wish%20\" +\n\t\t\twindow.location.pathname + \"%20\" + textfield.value);\n\n\t\ttextfield.value = '';\n\t\ttextfield.blur();\n\t}\n\n\tfunction handleKeystrokes(e) {\n\t\tswitch (e.which) {\n\t\t\tcase 13: {\n\t\t\t\tif (e.currentTarget === wishField) {\n\t\t\t\t\tsubmitWish(wishField);\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tcase 27: {\n\t\t\t\tif (html.hasClass('open-nav')) {\n\t\t\t\t\ttoggleMenu();\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t}\n\n\treturn {\n\t\ttoggleMenu: toggleMenu\n\t};\n})();\n\n\n// accordion\n(function(){\n\tvar yah = true;\n\tvar moving = false;\n\tvar CSS_BROWSER_HACK_DELAY = 25;\n\n\t$(document).ready(function(){\n\t\t// Safari chokes on the animation here, so...\n\t\tif (navigator.userAgent.indexOf('Chrome') == -1 && navigator.userAgent.indexOf('Safari') != -1){\n\t\t\tvar hackStyle = newDOMElement('style');\n\t\t\thackStyle.innerHTML = '.pi-accordion .wrapper{transition: none}';\n\t\t\tbody.append(hackStyle);\n\t\t}\n\t\t// Gross.\n\n\t\t$('.pi-accordion').each(function () {\n\t\t\tvar accordion = this;\n\t\t\tvar content = this.innerHTML;\n\t\t\tvar container = newDOMElement('div', 'container');\n\t\t\tcontainer.innerHTML = content;\n\t\t\t$(accordion).empty();\n\t\t\taccordion.appendChild(container);\n\t\t\tCollapseBox($(container));\n\t\t});\n\n\t\tsetYAH();\n\n\t\tsetTimeout(function () {\n\t\t\tyah = false;\n\t\t}, 500);\n\t});\n\n\tfunction CollapseBox(container){\n\t\tcontainer.children('.item').each(function(){\n\t\t\t// build the TOC DOM\n\t\t\t// the animated open/close is enabled by having each item's content exist in the flow, at its natural height,\n\t\t\t// enclosed in a wrapper with height = 0 when closed, and height = contentHeight when open.\n\t\t\tvar item = this;\n\n\t\t\t// only add content wrappers to containers, not to links\n\t\t\tvar isContainer = item.tagName === 'DIV';\n\n\t\t\tvar titleText = item.getAttribute('data-title');\n\t\t\tvar title = newDOMElement('div', 'title');\n\t\t\ttitle.innerHTML = titleText;\n\n\t\t\tvar wrapper, content;\n\n\t\t\tif (isContainer) {\n\t\t\t\twrapper = newDOMElement('div', 'wrapper');\n\t\t\t\tcontent = newDOMElement('div', 'content');\n\t\t\t\tcontent.innerHTML = item.innerHTML;\n\t\t\t\twrapper.appendChild(content);\n\t\t\t}\n\n\t\t\titem.innerHTML = '';\n\t\t\titem.appendChild(title);\n\n\t\t\tif (wrapper) {\n\t\t\t\titem.appendChild(wrapper);\n\t\t\t\t$(wrapper).css({height: 0});\n\t\t\t}\n\n\n\t\t\t$(title).click(function(){\n\t\t\t\tif (!yah) {\n\t\t\t\t\tif (moving) return;\n\t\t\t\t\tmoving = true;\n\t\t\t\t}\n\n\t\t\t\tif (container[0].getAttribute('data-single')) {\n\t\t\t\t\tvar openSiblings = item.siblings().filter(function(sib){return sib.hasClass('on');});\n\t\t\t\t\topenSiblings.forEach(function(sibling){\n\t\t\t\t\t\ttoggleItem(sibling);\n\t\t\t\t\t});\n\t\t\t\t}\n\n\t\t\t\tsetTimeout(function(){\n\t\t\t\t\tif (!isContainer) {\n\t\t\t\t\t\tmoving = false;\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\t\t\t\t\ttoggleItem(item);\n\t\t\t\t}, CSS_BROWSER_HACK_DELAY);\n\t\t\t});\n\n\t\t\tfunction toggleItem(thisItem){\n\t\t\t\tvar thisWrapper = $(thisItem).find('.wrapper').eq(0);\n\n\t\t\t\tif (!thisWrapper) return;\n\n\t\t\t\tvar contentHeight = thisWrapper.find('.content').eq(0).innerHeight() + 'px';\n\n\t\t\t\tif ($(thisItem).hasClass('on')) {\n\t\t\t\t\tthisWrapper.css({height: contentHeight});\n\t\t\t\t\t$(thisItem).removeClass('on');\n\n\t\t\t\t\tsetTimeout(function(){\n\t\t\t\t\t\tthisWrapper.css({height: 0});\n\t\t\t\t\t\tmoving = false;\n\t\t\t\t\t}, CSS_BROWSER_HACK_DELAY);\n\t\t\t\t} else {\n\t\t\t\t\t$(item).addClass('on');\n\t\t\t\t\tthisWrapper.css({height: contentHeight});\n\n\t\t\t\t\tvar duration = parseFloat(getComputedStyle(thisWrapper[0]).transitionDuration) * 1000;\n\n\t\t\t\t\tsetTimeout(function(){\n\t\t\t\t\t\tthisWrapper.css({height: ''});\n\t\t\t\t\t\tmoving = false;\n\t\t\t\t\t}, duration);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (content) {\n\t\t\t\tvar innerContainers = $(content).children('.container');\n\t\t\t\tif (innerContainers.length > 0) {\n\t\t\t\t\tinnerContainers.each(function(){\n\t\t\t\t\t\tCollapseBox($(this));\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n\n\tfunction setYAH() {\n\t\tvar pathname = location.href.split('#')[0]; // on page load, make sure the page is YAH even if there's a hash\n\t\tvar currentLinks = [];\n\n\t\t$('.pi-accordion a').each(function () {\n\t\t\tif (pathname === this.href) currentLinks.push(this);\n\t\t});\n\n\t\tcurrentLinks.forEach(function (yahLink) {\n\t\t\t$(yahLink).parents('.item').each(function(){\n\t\t\t\t$(this).addClass('on');\n\t\t\t\t$(this).find('.wrapper').eq(0).css({height: 'auto'});\n\t\t\t\t$(this).find('.content').eq(0).css({opacity: 1});\n\t\t\t});\n\n\t\t\t$(yahLink).addClass('yah');\n\t\t\tyahLink.onclick = function(e){e.preventDefault();};\n\t\t});\n\t}\n\n\t//π.mods.push(init);\n})();\n\n\n\n// TODO: scrollintoview in-page TOC"],"sourceRoot":"/source/"}