diff --git a/js/script.js b/js/script.js index a9213f91c8..15aa2bdb99 100755 --- a/js/script.js +++ b/js/script.js @@ -121,7 +121,13 @@ var kub = (function () { if(typeof(elem.offset()) !== "undefined") { var theTop = elem.offset().top - anchorTopMargin; $('html, body').stop().animate({ scrollTop:theTop }, 250, 'easeOutCubic', function() { - window.location.hash = name; + var hash = "#" + name + if(history.pushState) { + history.pushState(null, null, hash); + } + else { + location.hash = hash; + } }); } } @@ -520,4 +526,4 @@ var pushmenu = (function(){ }; })(); -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["π-baseComponents.js","script.js"],"names":[],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;ACNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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":[" //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","// globals\nvar body;\n\n//helper 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\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 highestZ() {\n\tvar Z = 1000;\n\n\t$(\"*\").each(function(){\n\t\tvar thisZ = $(this).css('z-index');\n\n\t\tif (thisZ != \"auto\" && thisZ > Z) Z = ++thisZ;\n\t});\n\n\treturn Z;\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\nfunction px(n){\n\treturn n + 'px';\n}\n\nvar kub = (function () {\n\tvar HEADER_HEIGHT;\n\tvar html, header, mainNav, quickstartButton, hero, encyclopedia, footer, wishField, headlineWrapper;\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\theadlineWrapper = $('#headlineWrapper');\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\tsetInterval(setFooterType, 10);\n\n\t\tinitAnchorScrolling();\n\t});\n\n\tvar anchorTopMargin = 90;\n\t\n\tfunction initAnchorScrolling() {\n\t\tanchorTopMargin = HEADER_HEIGHT + 10;\n\t\t\n\t\tconsole.log(\"anchorTopMargin\", anchorTopMargin);\n\t\t\n\t\t$('a[href*=\"#\"]').each(function() {\n\t\t\tif (this.href.indexOf(\"!\") != -1) return;\n\t\t\t\t\n\t\t\tvar url = $(this).attr('href').replace(/\\/$/, \"\");\n\t\t\tvar name = (url.indexOf(\"#\") !== -1) ? url.substring(url.indexOf(\"#\")+1): url.match(/([^\\/]*)\\/*$/)[1];\n\t\t\t\n\t\t\tif (name.indexOf(\"/\") != -1) return;\n\t\t\t\n\t\t\tif(typeof($(\"a[name='\"+name+\"']\").offset()) !== \"undefined\" || $('#'+name).length) {\n\t\t\t\t$(this).click(function(e) {\n\t\t\t\t\te.preventDefault();\n\t\t\t\t\tscrollToAnchor(name);\n\t\t\t\t});\n\t\t\t}\n\t\t});\n\t}\n\t\n\tfunction scrollToAnchor(name) {\n\t\tvar elem = (!$('#'+name).length) ? $(\"a[name='\"+ name +\"']\"): $('#'+name);\n\t\tif(typeof(elem.offset()) !== \"undefined\") {\n\t\t\tvar theTop = elem.offset().top - anchorTopMargin;\n\t\t\t$('html, body').stop().animate({ scrollTop:theTop }, 250, 'easeOutCubic', function() {\n\t\t\t\twindow.location.hash = name;\n\t\t\t});\n\t\t}\n\t}\n\t\n\n\tfunction setFooterType() {\n\t\tvar windowHeight = window.innerHeight;\n\t\tvar bodyHeight;\n\n\t\tswitch (html[0].id) {\n\t\t\tcase 'docs': {\n\t\t\t\tbodyHeight = hero.outerHeight() + encyclopedia.outerHeight();\n\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tcase 'home':\n\t\t\t\tbodyHeight = windowHeight;\n\t\t\t\tbreak;\n\n\t\t\tdefault: {\n\t\t\t\tbodyHeight = hero.outerHeight() + $('#mainContent').outerHeight();\n\t\t\t}\n\t\t}\n\n\t\tvar footerHeight = footer.outerHeight();\n\t\tclassOnCondition(body, 'fixed', windowHeight - footerHeight > bodyHeight);\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\tif (html.hasClass('open-toc')) {\n\t\t\ttoggleToc();\n\t\t}\n\n\t\tclassOnCondition(html, 'flip-nav', window.pageYOffset > 0);\n\n\t\tif (html[0].id == 'home') {\n\t\t\tsetHomeHeaderStyles();\n\t\t}\n\t}\n\n\tfunction setHomeHeaderStyles() {\n\t\tvar Y = window.pageYOffset;\n\t\tvar quickstartBottom = quickstartButton[0].getBoundingClientRect().bottom;\n\n\t\tclassOnCondition(html[0], 'y-enough', Y > quickstartBottom);\n\t}\n\n\tfunction toggleMenu() {\n\t\tif (window.innerWidth < 800) {\n\t\t\tpushmenu.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[0]) {\n\t\t\t\t\tsubmitWish(wishField[0]);\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\tfunction showVideo() {\n\t\t$('body').css({overflow: 'hidden'});\n\n\t\tvar videoPlayer = $(\"#videoPlayer\");\n\t\tvar videoIframe = videoPlayer.find(\"iframe\")[0];\n\t\tvideoIframe.src = videoIframe.getAttribute(\"data-url\");\n\t\tvideoPlayer.css({zIndex: highestZ()});\n\t\tvideoPlayer.fadeIn(300);\n\t\tvideoPlayer.click(function(){\n\t\t\t$('body').css({overflow: 'auto'});\n\n\t\t\tvideoPlayer.fadeOut(300, function(){\n\t\t\t\tvideoIframe.src = '';\n\t\t\t});\n\t\t});\n\t}\n\n\tfunction tocWasClicked(e) {\n\t\tvar target = $(e.target);\n\t\tvar docsToc = $(\"#docsToc\");\n\t\treturn (target[0] === docsToc[0] || target.parents(\"#docsToc\").length > 0);\n\t}\n\n\tfunction listenForTocClick(e) {\n\t\tif (!tocWasClicked(e)) toggleToc();\n\t}\n\n\tfunction toggleToc() {\n\t\thtml.toggleClass('open-toc');\n\n\t\tsetTimeout(function () {\n\t\t\tif (html.hasClass('open-toc')) {\n\t\t\t\twindow.addEventListener('click', listenForTocClick);\n\t\t\t} else {\n\t\t\t\twindow.removeEventListener('click', listenForTocClick);\n\t\t\t}\n\t\t}, 100);\n\t}\n\n\treturn {\n\t\ttoggleToc: toggleToc,\n\t\ttoggleMenu: toggleMenu,\n\t\tshowVideo: showVideo\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\n\nvar pushmenu = (function(){\n\tvar allPushMenus = {};\n\n\t$(document).ready(function(){\n\t\t$('[data-auto-burger]').each(function(){\n\t\t\tvar container = this;\n\t\t\tvar id = container.getAttribute('data-auto-burger');\n\n\t\t\tvar autoBurger = document.getElementById(id) || newDOMElement('div', 'pi-pushmenu', id);\n\t\t\tvar ul = autoBurger.querySelector('ul') || newDOMElement('ul');\n\n\t\t\t$(container).find('a[href], button').each(function () {\n\t\t\t\tif (!booleanAttributeValue(this, 'data-auto-burger-exclude', false)) {\n\t\t\t\t\tvar clone = this.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 = newDOMElement('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\tvar li = newDOMElement('li');\n\t\t\t\t\tli.appendChild(clone);\n\t\t\t\t\tul.appendChild(li);\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tautoBurger.appendChild(ul);\n\t\t\tbody.append(autoBurger);\n\t\t});\n\n\t\t$(\".pi-pushmenu\").each(function(){\n\t\t\tallPushMenus[this.id] = PushMenu(this);\n\t\t});\n\t});\n\n\tfunction show(objId) {\n\t\tallPushMenus[objId].expose();\n\t}\n\n\tfunction PushMenu(el) {\n\t\tvar html = document.querySelector('html');\n\n\t\tvar overlay = newDOMElement('div', 'overlay');\n\t\tvar content = newDOMElement('div', 'content');\n\t\tcontent.appendChild(el.querySelector('*'));\n\n\t\tvar side = el.getAttribute(\"data-side\") || \"right\";\n\n\t\tvar sled = newDOMElement('div', 'sled');\n\t\t$(sled).css(side, 0);\n\n\t\tsled.appendChild(content);\n\n\t\tvar closeButton = newDOMElement('button', 'push-menu-close-button');\n\t\tcloseButton.onclick = closeMe;\n\n\t\tsled.appendChild(closeButton);\n\n\t\toverlay.appendChild(sled);\n\t\tel.innerHTML = '';\n\t\tel.appendChild(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\twindow.addEventListener('resize', closeMe);\n\n\t\tfunction closeMe(e) {\n\t\t\tif (e.target == sled) return;\n\n\t\t\t$(el).removeClass('on');\n\t\t\tsetTimeout(function(){\n\t\t\t\t$(el).css({display: 'none'});\n\n\t\t\t\t$(body).removeClass('overlay-on');\n\t\t\t}, 300);\n\t\t}\n\n\t\tfunction exposeMe(){\n\t\t\t$(body).addClass('overlay-on'); // in the default config, kills body scrolling\n\n\t\t\t$(el).css({\n\t\t\t\tdisplay: 'block',\n\t\t\t\tzIndex: highestZ()\n\t\t\t});\n\n\t\t\tsetTimeout(function(){\n\t\t\t\t$(el).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\treturn {\n\t\tshow: show\n\t};\n})();\n"],"sourceRoot":"/source/"} +//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["π-baseComponents.js","script.js"],"names":[],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;ACNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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":[" //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","// globals\nvar body;\n\n//helper 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\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 highestZ() {\n\tvar Z = 1000;\n\n\t$(\"*\").each(function(){\n\t\tvar thisZ = $(this).css('z-index');\n\n\t\tif (thisZ != \"auto\" && thisZ > Z) Z = ++thisZ;\n\t});\n\n\treturn Z;\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\nfunction px(n){\n\treturn n + 'px';\n}\n\nvar kub = (function () {\n\tvar HEADER_HEIGHT;\n\tvar html, header, mainNav, quickstartButton, hero, encyclopedia, footer, wishField, headlineWrapper;\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\theadlineWrapper = $('#headlineWrapper');\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\tsetInterval(setFooterType, 10);\n\n\t\tinitAnchorScrolling();\n\t});\n\n\tvar anchorTopMargin = 90;\n\t\n\tfunction initAnchorScrolling() {\n\t\tanchorTopMargin = HEADER_HEIGHT + 10;\n\t\t\n\t\tconsole.log(\"anchorTopMargin\", anchorTopMargin);\n\t\t\n\t\t$('a[href*=\"#\"]').each(function() {\n\t\t\tif (this.href.indexOf(\"!\") != -1) return;\n\t\t\t\t\n\t\t\tvar url = $(this).attr('href').replace(/\\/$/, \"\");\n\t\t\tvar name = (url.indexOf(\"#\") !== -1) ? url.substring(url.indexOf(\"#\")+1): url.match(/([^\\/]*)\\/*$/)[1];\n\t\t\t\n\t\t\tif (name.indexOf(\"/\") != -1) return;\n\t\t\t\n\t\t\tif(typeof($(\"a[name='\"+name+\"']\").offset()) !== \"undefined\" || $('#'+name).length) {\n\t\t\t\t$(this).click(function(e) {\n\t\t\t\t\te.preventDefault();\n\t\t\t\t\tscrollToAnchor(name);\n\t\t\t\t});\n\t\t\t}\n\t\t});\n\t}\n\t\n\tfunction scrollToAnchor(name) {\n\t\tvar elem = (!$('#'+name).length) ? $(\"a[name='\"+ name +\"']\"): $('#'+name);\n\t\tif(typeof(elem.offset()) !== \"undefined\") {\n\t\t\tvar theTop = elem.offset().top - anchorTopMargin;\n\t\t\t$('html, body').stop().animate({ scrollTop:theTop }, 250, 'easeOutCubic', function() {\n\t\t\t\tvar hash = \"#\" + name\n\t\t\t\tif(history.pushState) {\n\t\t\t\t\thistory.pushState(null, null, hash);\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tlocation.hash = hash;\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t}\n\t\n\n\tfunction setFooterType() {\n\t\tvar windowHeight = window.innerHeight;\n\t\tvar bodyHeight;\n\n\t\tswitch (html[0].id) {\n\t\t\tcase 'docs': {\n\t\t\t\tbodyHeight = hero.outerHeight() + encyclopedia.outerHeight();\n\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tcase 'home':\n\t\t\t\tbodyHeight = windowHeight;\n\t\t\t\tbreak;\n\n\t\t\tdefault: {\n\t\t\t\tbodyHeight = hero.outerHeight() + $('#mainContent').outerHeight();\n\t\t\t}\n\t\t}\n\n\t\tvar footerHeight = footer.outerHeight();\n\t\tclassOnCondition(body, 'fixed', windowHeight - footerHeight > bodyHeight);\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\tif (html.hasClass('open-toc')) {\n\t\t\ttoggleToc();\n\t\t}\n\n\t\tclassOnCondition(html, 'flip-nav', window.pageYOffset > 0);\n\n\t\tif (html[0].id == 'home') {\n\t\t\tsetHomeHeaderStyles();\n\t\t}\n\t}\n\n\tfunction setHomeHeaderStyles() {\n\t\tvar Y = window.pageYOffset;\n\t\tvar quickstartBottom = quickstartButton[0].getBoundingClientRect().bottom;\n\n\t\tclassOnCondition(html[0], 'y-enough', Y > quickstartBottom);\n\t}\n\n\tfunction toggleMenu() {\n\t\tif (window.innerWidth < 800) {\n\t\t\tpushmenu.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[0]) {\n\t\t\t\t\tsubmitWish(wishField[0]);\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\tfunction showVideo() {\n\t\t$('body').css({overflow: 'hidden'});\n\n\t\tvar videoPlayer = $(\"#videoPlayer\");\n\t\tvar videoIframe = videoPlayer.find(\"iframe\")[0];\n\t\tvideoIframe.src = videoIframe.getAttribute(\"data-url\");\n\t\tvideoPlayer.css({zIndex: highestZ()});\n\t\tvideoPlayer.fadeIn(300);\n\t\tvideoPlayer.click(function(){\n\t\t\t$('body').css({overflow: 'auto'});\n\n\t\t\tvideoPlayer.fadeOut(300, function(){\n\t\t\t\tvideoIframe.src = '';\n\t\t\t});\n\t\t});\n\t}\n\n\tfunction tocWasClicked(e) {\n\t\tvar target = $(e.target);\n\t\tvar docsToc = $(\"#docsToc\");\n\t\treturn (target[0] === docsToc[0] || target.parents(\"#docsToc\").length > 0);\n\t}\n\n\tfunction listenForTocClick(e) {\n\t\tif (!tocWasClicked(e)) toggleToc();\n\t}\n\n\tfunction toggleToc() {\n\t\thtml.toggleClass('open-toc');\n\n\t\tsetTimeout(function () {\n\t\t\tif (html.hasClass('open-toc')) {\n\t\t\t\twindow.addEventListener('click', listenForTocClick);\n\t\t\t} else {\n\t\t\t\twindow.removeEventListener('click', listenForTocClick);\n\t\t\t}\n\t\t}, 100);\n\t}\n\n\treturn {\n\t\ttoggleToc: toggleToc,\n\t\ttoggleMenu: toggleMenu,\n\t\tshowVideo: showVideo\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\n\nvar pushmenu = (function(){\n\tvar allPushMenus = {};\n\n\t$(document).ready(function(){\n\t\t$('[data-auto-burger]').each(function(){\n\t\t\tvar container = this;\n\t\t\tvar id = container.getAttribute('data-auto-burger');\n\n\t\t\tvar autoBurger = document.getElementById(id) || newDOMElement('div', 'pi-pushmenu', id);\n\t\t\tvar ul = autoBurger.querySelector('ul') || newDOMElement('ul');\n\n\t\t\t$(container).find('a[href], button').each(function () {\n\t\t\t\tif (!booleanAttributeValue(this, 'data-auto-burger-exclude', false)) {\n\t\t\t\t\tvar clone = this.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 = newDOMElement('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\tvar li = newDOMElement('li');\n\t\t\t\t\tli.appendChild(clone);\n\t\t\t\t\tul.appendChild(li);\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tautoBurger.appendChild(ul);\n\t\t\tbody.append(autoBurger);\n\t\t});\n\n\t\t$(\".pi-pushmenu\").each(function(){\n\t\t\tallPushMenus[this.id] = PushMenu(this);\n\t\t});\n\t});\n\n\tfunction show(objId) {\n\t\tallPushMenus[objId].expose();\n\t}\n\n\tfunction PushMenu(el) {\n\t\tvar html = document.querySelector('html');\n\n\t\tvar overlay = newDOMElement('div', 'overlay');\n\t\tvar content = newDOMElement('div', 'content');\n\t\tcontent.appendChild(el.querySelector('*'));\n\n\t\tvar side = el.getAttribute(\"data-side\") || \"right\";\n\n\t\tvar sled = newDOMElement('div', 'sled');\n\t\t$(sled).css(side, 0);\n\n\t\tsled.appendChild(content);\n\n\t\tvar closeButton = newDOMElement('button', 'push-menu-close-button');\n\t\tcloseButton.onclick = closeMe;\n\n\t\tsled.appendChild(closeButton);\n\n\t\toverlay.appendChild(sled);\n\t\tel.innerHTML = '';\n\t\tel.appendChild(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\twindow.addEventListener('resize', closeMe);\n\n\t\tfunction closeMe(e) {\n\t\t\tif (e.target == sled) return;\n\n\t\t\t$(el).removeClass('on');\n\t\t\tsetTimeout(function(){\n\t\t\t\t$(el).css({display: 'none'});\n\n\t\t\t\t$(body).removeClass('overlay-on');\n\t\t\t}, 300);\n\t\t}\n\n\t\tfunction exposeMe(){\n\t\t\t$(body).addClass('overlay-on'); // in the default config, kills body scrolling\n\n\t\t\t$(el).css({\n\t\t\t\tdisplay: 'block',\n\t\t\t\tzIndex: highestZ()\n\t\t\t});\n\n\t\t\tsetTimeout(function(){\n\t\t\t\t$(el).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\treturn {\n\t\tshow: show\n\t};\n})();\n"],"sourceRoot":"/source/"}