Difference between revisions of "MediaWiki:Common.js"
Jump to navigationJump to search
ThePoet444 (talk | contribs) m |
ThePoet444 (talk | contribs) m |
||
Line 1: | Line 1: | ||
− | /* <pre><nowiki> */ | + | /* <pre style="overflow: scroll; height: 25em"><nowiki> */ |
+ | |||
+ | // Common.js originally from Wookieepedia. | ||
+ | // Thanks, Wookieepedia! | ||
− | |||
document.write('<script type="text/javascript" src="' | document.write('<script type="text/javascript" src="' | ||
− | + '/index.php?title=MediaWiki: | + | + '/index.php?title=MediaWiki:Functions.js&action=raw&ctype=text/javascript"></script>'); |
− | |||
− | |||
− | |||
// onload stuff | // onload stuff | ||
− | |||
− | function loadFunc() { | + | function loadFunc() |
− | + | { | |
− | + | initFunctionsJS(); | |
− | |||
− | |||
− | |||
− | |||
− | + | // DEPRECATED | |
− | + | if(document.getElementById('infoboxinternal') != null && document.getElementById('infoboxend') != null) | |
− | + | { | |
− | + | document.getElementById('infoboxend').innerHTML = '<a id="infoboxtoggle" href="javascript:infoboxToggle()">[Hide]</a>'; | |
+ | } | ||
− | + | addHideButtons(); | |
− | |||
− | + | if(document.getElementById('mp3-navlink') != null) | |
+ | { | ||
+ | document.getElementById('mp3-navlink').onclick = onArticleNavClick; | ||
+ | document.getElementById('mp3-navlink').getElementsByTagName('a')[0].href = 'javascript:void(0)'; | ||
+ | } | ||
− | + | if(window.storagePresent) | |
− | + | initVisibility(); | |
− | |||
− | |||
− | + | rewriteSearchFormLink(); | |
− | + | /* fillEditSummaries(); */ | |
+ | //fillDeleteReasons(); | ||
+ | //fillPreloads(); | ||
− | + | //substUsername(); | |
− | + | //substUsernameTOC(); | |
− | |||
− | |||
− | + | rewriteTitle(); | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | + | showTitleIcons('title-eraicons'); | |
− | + | //showEras('title-shortcut'); | |
− | + | //rewriteHover(); | |
− | + | addAlternatingRowColors(); | |
− | + | replaceSearchIcon(); | |
− | |||
− | + | if(typeof(onPageLoad) != "undefined") | |
− | + | { | |
− | + | onPageLoad(); | |
+ | } | ||
} | } | ||
− | function infoboxToggle() { | + | function infoboxToggle() |
− | + | { | |
− | + | var page = window.pageName.replace(/\W/g, '_'); | |
+ | var nowShown; | ||
− | + | if(document.getElementById('infoboxtoggle').innerHTML == '[Hide]') | |
− | + | { | |
− | + | document.getElementById('infoboxinternal').style.display = 'none'; | |
− | + | document.getElementById('infoboxtoggle').innerHTML = '[Show]'; | |
− | + | nowShown = false; | |
− | + | } | |
− | + | else | |
− | + | { | |
− | + | document.getElementById('infoboxinternal').style.display = 'block'; | |
+ | document.getElementById('infoboxtoggle').innerHTML = '[Hide]'; | ||
+ | nowShown = true; | ||
+ | } | ||
− | + | if(window.storagePresent) | |
− | + | { | |
− | + | var storage = globalStorage[window.location.hostname]; | |
− | + | storage.setItem('infoboxshow-' + page, nowShown); | |
+ | } | ||
} | } | ||
− | function fillEditSummaries() { | + | function fillEditSummaries() |
− | + | { | |
+ | var label = document.getElementById("wpSummaryLabel"); | ||
− | + | if(label == null) | |
− | + | return; | |
− | + | var comboString = "Standard summaries: <select id='stdSummaries' onchange='onStdSummaryChange()'>"; | |
− | + | comboString += "</select><br />"; | |
− | + | label.innerHTML = comboString + label.innerHTML; | |
− | + | requestComboFill('stdSummaries', 'Template:Stdsummaries'); | |
} | } | ||
− | function onStdSummaryChange() { | + | function onStdSummaryChange() |
− | + | { | |
− | + | var combo = document.getElementById("stdSummaries"); | |
+ | var value = combo.options[combo.selectedIndex].value; | ||
− | + | if(value != "") | |
− | + | document.getElementById("wpSummary").value = value; | |
− | |||
− | |||
− | |||
− | |||
− | |||
} | } | ||
− | function fillDeleteReasons() { | + | function fillDeleteReasons() |
− | + | { | |
+ | var label = document.getElementById("wpReason"); | ||
+ | |||
+ | if(label == null) | ||
+ | return; | ||
+ | |||
+ | label = document.getElementById("contentSub"); | ||
− | + | if(label == null) | |
− | + | return; | |
− | + | var comboString = "<br /><select id='stdReasons' onchange='onStdReasonChange()'>"; | |
+ | comboString += "</select>"; | ||
+ | label.innerHTML += comboString; | ||
− | + | requestComboFill('stdReasons', "Template:Stdreasons"); | |
− | |||
} | } | ||
− | function onStdReasonChange() { | + | function onStdReasonChange() |
− | + | { | |
− | + | var combo = document.getElementById("stdReasons"); | |
+ | var value = combo.options[combo.selectedIndex].value; | ||
− | + | if(value != "") | |
− | + | document.getElementById("wpReason").value = value; | |
} | } | ||
− | function fillPreloads() { | + | function fillPreloads() |
− | + | { | |
+ | var div = document.getElementById("lf-preload"); | ||
− | + | if(div == null) | |
− | + | return; | |
− | + | div.style.display = 'block'; | |
− | + | var span = document.getElementById('lf-preload-cbox'); | |
− | + | var comboString = "<select id='stdPreloads' onchange='onPreloadChange()'>"; | |
− | + | comboString += "</select>"; | |
− | + | span.innerHTML = comboString; | |
− | + | span = document.getElementById('lf-preload-pagename'); | |
− | + | span.innerHTML = '<input type="text" class="textbox" />'; | |
− | + | span = document.getElementById('lf-preload-button'); | |
− | + | span.innerHTML = '<input type="button" class="button" value="Insert" onclick="doCustomPreload()" />'; | |
− | + | requestComboFill('stdPreloads', "Template:Stdpreloads"); | |
} | } | ||
− | function doCustomPreload() { | + | function doCustomPreload() |
− | + | { | |
+ | doPreload(document.getElementById('lf-preload-pagename').getElementsByTagName('input')[0].value); | ||
} | } | ||
− | function onPreloadChange() { | + | function onPreloadChange() |
− | + | { | |
− | + | var combo = document.getElementById("stdPreloads"); | |
+ | var value = combo.options[combo.selectedIndex].value; | ||
− | + | if(value == "") | |
− | + | return; | |
− | + | value = "Template:" + value + "/preload"; | |
− | + | value = value.replace(" ", "_"); | |
− | + | doPreload(value); | |
} | } | ||
Line 172: | Line 173: | ||
// BEGIN JavaScript title rewrite | // BEGIN JavaScript title rewrite | ||
− | function rewriteTitle() { | + | function rewriteTitle() |
− | + | { | |
− | + | if(typeof(window.SKIP_TITLE_REWRITE) != 'undefined' && window.SKIP_TITLE_REWRITE) | |
− | + | return; | |
− | + | var titleDiv = document.getElementById('title-meta'); | |
− | |||
− | + | if(titleDiv == null) | |
− | + | return; | |
− | |||
− | + | var cloneNode = titleDiv.cloneNode(true); | |
− | + | var firstHeading = getFirstHeading(); | |
− | + | var node = firstHeading.childNodes[0]; | |
− | + | // new, then old! | |
− | + | firstHeading.replaceChild(cloneNode, node); | |
+ | cloneNode.style.display = "inline"; | ||
+ | |||
+ | var titleAlign = document.getElementById('title-align'); | ||
+ | firstHeading.style.textAlign = titleAlign.childNodes[0].nodeValue; | ||
} | } | ||
− | function | + | function showTitleIcons(idName) |
{ | { | ||
var titleDiv = document.getElementById(idName); | var titleDiv = document.getElementById(idName); | ||
Line 204: | Line 207: | ||
cloneNode.style.display = "block"; | cloneNode.style.display = "block"; | ||
} | } | ||
− | |||
// END JavaScript title rewrite | // END JavaScript title rewrite | ||
− | function initVisibility() { | + | function initVisibility() |
− | + | { | |
+ | var storage = globalStorage[window.location.hostname]; | ||
− | + | var page = window.pageName.replace(/\W/g,'_'); | |
− | + | var show = storage.getItem('infoboxshow-' + page); | |
− | + | if(show == 'false') | |
− | + | { | |
− | + | infoboxToggle(); | |
+ | } | ||
− | + | var hidables = getElementsByClass('hidable'); | |
− | + | for(var i = 0; i < hidables.length; i++) | |
− | + | { | |
+ | show = storage.getItem('hidableshow-' + i + '_' + page); | ||
− | + | if(show == 'false') | |
− | + | { | |
− | + | var content = getElementsByClass('hidable-content', hidables[i]); | |
+ | var button = getElementsByClass('hidable-button', hidables[i]); | ||
− | + | if(content != null && content.length > 0 && | |
− | + | button != null && button.length > 0 && content[0].style.display != 'none') | |
− | + | { | |
− | + | button[0].onclick('bypass'); | |
− | + | } | |
− | + | } | |
− | + | else if(show == 'true') | |
− | + | { | |
+ | var content = getElementsByClass('hidable-content', hidables[i]); | ||
+ | var button = getElementsByClass('hidable-button', hidables[i]); | ||
− | + | if(content != null && content.length > 0 && | |
− | + | button != null && button.length > 0 && content[0].style.display == 'none') | |
− | + | { | |
− | + | button[0].onclick('bypass'); | |
− | + | } | |
− | + | } | |
− | + | } | |
} | } | ||
− | function onArticleNavClick() { | + | function onArticleNavClick() |
− | + | { | |
+ | var div = document.getElementById('mp3-nav'); | ||
− | + | if(div.style.display == 'block') | |
− | + | div.style.display = 'none'; | |
− | + | else | |
− | + | div.style.display = 'block'; | |
} | } | ||
− | function addAlternatingRowColors() { | + | function addAlternatingRowColors() |
− | + | { | |
+ | var infoboxes = getElementsByClass('infobox', document.getElementById('content')); | ||
+ | |||
+ | if(infoboxes.length == 0) | ||
+ | return; | ||
− | + | for(var k = 0; k < infoboxes.length; k++) | |
− | + | { | |
+ | var infobox = infoboxes[k]; | ||
− | + | var rows = infobox.getElementsByTagName('tr'); | |
− | + | var changeColor = false; | |
− | + | for(var i = 0; i < rows.length; i++) | |
− | + | { | |
+ | if(rows[i].className.indexOf('infoboxstopalt') != -1) | ||
+ | break; | ||
− | + | var ths = rows[i].getElementsByTagName('th'); | |
− | |||
− | |||
− | + | if(ths.length > 0) | |
+ | { | ||
+ | continue; | ||
+ | } | ||
− | + | if(changeColor) | |
− | + | rows[i].style.backgroundColor = '#f9f9f9'; | |
− | |||
− | + | changeColor = !changeColor; | |
− | + | } | |
− | + | } | |
− | |||
− | |||
} | } | ||
− | function addHideButtons() { | + | function addHideButtons() |
− | + | { | |
+ | var hidables = getElementsByClass('hidable'); | ||
− | + | for(var i = 0; i < hidables.length; i++) | |
− | + | { | |
− | + | var box = hidables[i]; | |
+ | var button = getElementsByClass('hidable-button', box, 'span'); | ||
− | + | if(button != null && button.length > 0) | |
− | + | { | |
+ | button = button[0]; | ||
− | + | button.onclick = toggleHidable; | |
− | + | button.appendChild(document.createTextNode('[Hide]')); | |
− | + | if(new ClassTester('start-hidden').isMatch(box)) | |
− | + | button.onclick('bypass'); | |
− | + | } | |
− | + | } | |
} | } | ||
− | function toggleHidable(bypassStorage) { | + | function toggleHidable(bypassStorage) |
− | + | { | |
− | + | var parent = getParentByClass('hidable', this); | |
− | + | var content = getElementsByClass('hidable-content', parent); | |
+ | var nowShown; | ||
− | + | if(content != null && content.length > 0) | |
− | + | { | |
+ | content = content[0]; | ||
− | + | if(content.style.display == 'none') | |
− | + | { | |
− | + | content.style.display = content.oldDisplayStyle; | |
− | + | this.firstChild.nodeValue = '[Hide]'; | |
− | + | nowShown = true; | |
− | + | } | |
− | + | else | |
− | + | { | |
− | + | content.oldDisplayStyle = content.style.display; | |
− | + | content.style.display = 'none'; | |
+ | this.firstChild.nodeValue = '[Show]'; | ||
+ | nowShown = false; | ||
+ | } | ||
− | + | if(window.storagePresent && (typeof(bypassStorage) == 'undefined' || bypassStorage != 'bypass')) | |
− | + | { | |
− | + | var page = window.pageName.replace(/\W/g, '_'); | |
− | + | var items = getElementsByClass('hidable'); | |
+ | var item = -1; | ||
− | + | for(var i = 0; i < items.length; i++) | |
− | + | { | |
− | + | if(items[i] == parent) | |
− | + | { | |
− | + | item = i; | |
− | + | break; | |
+ | } | ||
+ | } | ||
− | + | if(item == -1) | |
− | + | { | |
− | + | return; | |
+ | } | ||
− | + | var storage = globalStorage[window.location.hostname]; | |
− | + | storage.setItem('hidableshow-' + item + '_' + page, nowShown); | |
− | + | } | |
− | + | } | |
} | } | ||
− | function substUsernameTOC() { | + | function substUsernameTOC() |
− | + | { | |
− | + | var toc = document.getElementById('toc'); | |
+ | var userpage = document.getElementById('pt-userpage'); | ||
− | + | if(!userpage || !toc) | |
− | + | return; | |
− | + | var username = userpage.firstChild.firstChild.nodeValue; | |
− | + | var elements = getElementsByClass('toctext', toc, 'span'); | |
− | + | for(var i = 0; i < elements.length; i++) | |
− | + | elements[i].firstChild.nodeValue = elements[i].firstChild.nodeValue.replace('<insert name here>', username); | |
} | } | ||
− | // | + | function replaceSearchIcon() |
− | + | { | |
− | + | var searchbox = document.getElementById('searchBody'); | |
+ | var innerDiv = searchbox.getElementsByTagName('div')[0]; | ||
+ | var link = innerDiv.getElementsByTagName('a')[0]; | ||
+ | |||
+ | if(link) | ||
+ | innerDiv.removeChild(link); | ||
+ | |||
+ | // innerDiv.style.paddingTop = '56px'; | ||
+ | |||
+ | var loader = new ContentLoader(); | ||
+ | loader.div = innerDiv; | ||
+ | loader.callback = onSearchIconsArrival; | ||
+ | loader.send('/index.php?title=Template:Searchicons&action=raw'); | ||
} | } | ||
− | + | function rand(n) | |
− | + | { | |
− | + | return Math.round(Math.random() * n); | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
} | } | ||
− | |||
− | |||
− | + | function onSearchIconsArrival() | |
− | + | { | |
− | + | var lines = this.text.split('\n'); | |
− | + | ||
− | + | var link = document.createElement('a'); | |
− | + | link.href = '/index.php?title=Special:Search&adv=1'; | |
− | + | var img = document.createElement('img'); | |
− | + | img.alt = 'Search'; | |
− | + | img.src = lines[rand(lines.length - 1)]; | |
− | + | link.appendChild(img); | |
− | + | ||
− | + | this.div.insertBefore(link, this.div.firstChild); | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | var | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | var | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | document. | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
} | } | ||
− | + | addOnloadHook(loadFunc); | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
// </nowiki></pre> | // </nowiki></pre> |
Revision as of 14:32, 21 May 2010
/* <pre style="overflow: scroll; height: 25em"><nowiki> */ // Common.js originally from Wookieepedia. // Thanks, Wookieepedia! document.write('<script type="text/javascript" src="' + '/index.php?title=MediaWiki:Functions.js&action=raw&ctype=text/javascript"></script>'); // onload stuff function loadFunc() { initFunctionsJS(); // DEPRECATED if(document.getElementById('infoboxinternal') != null && document.getElementById('infoboxend') != null) { document.getElementById('infoboxend').innerHTML = '<a id="infoboxtoggle" href="javascript:infoboxToggle()">[Hide]</a>'; } addHideButtons(); if(document.getElementById('mp3-navlink') != null) { document.getElementById('mp3-navlink').onclick = onArticleNavClick; document.getElementById('mp3-navlink').getElementsByTagName('a')[0].href = 'javascript:void(0)'; } if(window.storagePresent) initVisibility(); rewriteSearchFormLink(); /* fillEditSummaries(); */ //fillDeleteReasons(); //fillPreloads(); //substUsername(); //substUsernameTOC(); rewriteTitle(); showTitleIcons('title-eraicons'); //showEras('title-shortcut'); //rewriteHover(); addAlternatingRowColors(); replaceSearchIcon(); if(typeof(onPageLoad) != "undefined") { onPageLoad(); } } function infoboxToggle() { var page = window.pageName.replace(/\W/g, '_'); var nowShown; if(document.getElementById('infoboxtoggle').innerHTML == '[Hide]') { document.getElementById('infoboxinternal').style.display = 'none'; document.getElementById('infoboxtoggle').innerHTML = '[Show]'; nowShown = false; } else { document.getElementById('infoboxinternal').style.display = 'block'; document.getElementById('infoboxtoggle').innerHTML = '[Hide]'; nowShown = true; } if(window.storagePresent) { var storage = globalStorage[window.location.hostname]; storage.setItem('infoboxshow-' + page, nowShown); } } function fillEditSummaries() { var label = document.getElementById("wpSummaryLabel"); if(label == null) return; var comboString = "Standard summaries: <select id='stdSummaries' onchange='onStdSummaryChange()'>"; comboString += "</select><br />"; label.innerHTML = comboString + label.innerHTML; requestComboFill('stdSummaries', 'Template:Stdsummaries'); } function onStdSummaryChange() { var combo = document.getElementById("stdSummaries"); var value = combo.options[combo.selectedIndex].value; if(value != "") document.getElementById("wpSummary").value = value; } function fillDeleteReasons() { var label = document.getElementById("wpReason"); if(label == null) return; label = document.getElementById("contentSub"); if(label == null) return; var comboString = "<br /><select id='stdReasons' onchange='onStdReasonChange()'>"; comboString += "</select>"; label.innerHTML += comboString; requestComboFill('stdReasons', "Template:Stdreasons"); } function onStdReasonChange() { var combo = document.getElementById("stdReasons"); var value = combo.options[combo.selectedIndex].value; if(value != "") document.getElementById("wpReason").value = value; } function fillPreloads() { var div = document.getElementById("lf-preload"); if(div == null) return; div.style.display = 'block'; var span = document.getElementById('lf-preload-cbox'); var comboString = "<select id='stdPreloads' onchange='onPreloadChange()'>"; comboString += "</select>"; span.innerHTML = comboString; span = document.getElementById('lf-preload-pagename'); span.innerHTML = '<input type="text" class="textbox" />'; span = document.getElementById('lf-preload-button'); span.innerHTML = '<input type="button" class="button" value="Insert" onclick="doCustomPreload()" />'; requestComboFill('stdPreloads', "Template:Stdpreloads"); } function doCustomPreload() { doPreload(document.getElementById('lf-preload-pagename').getElementsByTagName('input')[0].value); } function onPreloadChange() { var combo = document.getElementById("stdPreloads"); var value = combo.options[combo.selectedIndex].value; if(value == "") return; value = "Template:" + value + "/preload"; value = value.replace(" ", "_"); doPreload(value); } // ============================================================ // BEGIN JavaScript title rewrite function rewriteTitle() { if(typeof(window.SKIP_TITLE_REWRITE) != 'undefined' && window.SKIP_TITLE_REWRITE) return; var titleDiv = document.getElementById('title-meta'); if(titleDiv == null) return; var cloneNode = titleDiv.cloneNode(true); var firstHeading = getFirstHeading(); var node = firstHeading.childNodes[0]; // new, then old! firstHeading.replaceChild(cloneNode, node); cloneNode.style.display = "inline"; var titleAlign = document.getElementById('title-align'); firstHeading.style.textAlign = titleAlign.childNodes[0].nodeValue; } function showTitleIcons(idName) { var titleDiv = document.getElementById(idName); if(titleDiv == null || titleDiv == undefined) return; var cloneNode = titleDiv.cloneNode(true); var firstHeading = getFirstHeading(); firstHeading.insertBefore(cloneNode, firstHeading.childNodes[0]); cloneNode.style.display = "block"; } // END JavaScript title rewrite function initVisibility() { var storage = globalStorage[window.location.hostname]; var page = window.pageName.replace(/\W/g,'_'); var show = storage.getItem('infoboxshow-' + page); if(show == 'false') { infoboxToggle(); } var hidables = getElementsByClass('hidable'); for(var i = 0; i < hidables.length; i++) { show = storage.getItem('hidableshow-' + i + '_' + page); if(show == 'false') { var content = getElementsByClass('hidable-content', hidables[i]); var button = getElementsByClass('hidable-button', hidables[i]); if(content != null && content.length > 0 && button != null && button.length > 0 && content[0].style.display != 'none') { button[0].onclick('bypass'); } } else if(show == 'true') { var content = getElementsByClass('hidable-content', hidables[i]); var button = getElementsByClass('hidable-button', hidables[i]); if(content != null && content.length > 0 && button != null && button.length > 0 && content[0].style.display == 'none') { button[0].onclick('bypass'); } } } } function onArticleNavClick() { var div = document.getElementById('mp3-nav'); if(div.style.display == 'block') div.style.display = 'none'; else div.style.display = 'block'; } function addAlternatingRowColors() { var infoboxes = getElementsByClass('infobox', document.getElementById('content')); if(infoboxes.length == 0) return; for(var k = 0; k < infoboxes.length; k++) { var infobox = infoboxes[k]; var rows = infobox.getElementsByTagName('tr'); var changeColor = false; for(var i = 0; i < rows.length; i++) { if(rows[i].className.indexOf('infoboxstopalt') != -1) break; var ths = rows[i].getElementsByTagName('th'); if(ths.length > 0) { continue; } if(changeColor) rows[i].style.backgroundColor = '#f9f9f9'; changeColor = !changeColor; } } } function addHideButtons() { var hidables = getElementsByClass('hidable'); for(var i = 0; i < hidables.length; i++) { var box = hidables[i]; var button = getElementsByClass('hidable-button', box, 'span'); if(button != null && button.length > 0) { button = button[0]; button.onclick = toggleHidable; button.appendChild(document.createTextNode('[Hide]')); if(new ClassTester('start-hidden').isMatch(box)) button.onclick('bypass'); } } } function toggleHidable(bypassStorage) { var parent = getParentByClass('hidable', this); var content = getElementsByClass('hidable-content', parent); var nowShown; if(content != null && content.length > 0) { content = content[0]; if(content.style.display == 'none') { content.style.display = content.oldDisplayStyle; this.firstChild.nodeValue = '[Hide]'; nowShown = true; } else { content.oldDisplayStyle = content.style.display; content.style.display = 'none'; this.firstChild.nodeValue = '[Show]'; nowShown = false; } if(window.storagePresent && (typeof(bypassStorage) == 'undefined' || bypassStorage != 'bypass')) { var page = window.pageName.replace(/\W/g, '_'); var items = getElementsByClass('hidable'); var item = -1; for(var i = 0; i < items.length; i++) { if(items[i] == parent) { item = i; break; } } if(item == -1) { return; } var storage = globalStorage[window.location.hostname]; storage.setItem('hidableshow-' + item + '_' + page, nowShown); } } } function substUsernameTOC() { var toc = document.getElementById('toc'); var userpage = document.getElementById('pt-userpage'); if(!userpage || !toc) return; var username = userpage.firstChild.firstChild.nodeValue; var elements = getElementsByClass('toctext', toc, 'span'); for(var i = 0; i < elements.length; i++) elements[i].firstChild.nodeValue = elements[i].firstChild.nodeValue.replace('<insert name here>', username); } function replaceSearchIcon() { var searchbox = document.getElementById('searchBody'); var innerDiv = searchbox.getElementsByTagName('div')[0]; var link = innerDiv.getElementsByTagName('a')[0]; if(link) innerDiv.removeChild(link); // innerDiv.style.paddingTop = '56px'; var loader = new ContentLoader(); loader.div = innerDiv; loader.callback = onSearchIconsArrival; loader.send('/index.php?title=Template:Searchicons&action=raw'); } function rand(n) { return Math.round(Math.random() * n); } function onSearchIconsArrival() { var lines = this.text.split('\n'); var link = document.createElement('a'); link.href = '/index.php?title=Special:Search&adv=1'; var img = document.createElement('img'); img.alt = 'Search'; img.src = lines[rand(lines.length - 1)]; link.appendChild(img); this.div.insertBefore(link, this.div.firstChild); } addOnloadHook(loadFunc); // </nowiki></pre>