MediaWiki:Common.js: Difference between revisions
Jump to navigation
Jump to search
ThePoet444 (talk | contribs) mNo edit summary |
title override correction - will rollback if something breaks |
||
| (21 intermediate revisions by one other user not shown) | |||
| Line 1: | Line 1: | ||
/* <pre><nowiki> */ | /* <pre style="overflow: scroll; height: 25em"><nowiki> */ | ||
importScript('MediaWiki: | // Common.js originally from Wookieepedia. | ||
// Thanks, Wookieepedia! | |||
// plus updates from mediawii's common.js | |||
if ( /^MediaWiki(\/.+)?$/.test( wgPageName ) && wgAction == 'view' ) { | |||
addOnloadHook(function(){ | |||
document.body.className+=" mainpage"; | |||
}) | |||
} | |||
/** includePage ************ | |||
* force the loading of another JavaScript file | |||
* @todo Is this still needed? We have importScript and importScriptURI in wikibits.js | |||
* Maintainer: [[Commons:User:Dschwen]] | |||
*/ | |||
function includePage( name ){ | |||
document.write('<script type="text/javascript" src="' + wgScript + '?title=' | |||
+ name + '&action=raw&ctype=text/javascript"><\/script>' | |||
); | |||
} | |||
includePage('MediaWiki:Functions.js'); | |||
//Load Functions.js | |||
importScript('MediaWiki:Functions.js'); | |||
var hasClass = (function() { | |||
var reCache = {}; | |||
return function ( element, className ) { | |||
return (reCache[className] ? reCache[className] : (reCache[className] = new RegExp("(?:\\s|^)" + className + "(?:\\s|$)"))).test(element.className); | |||
}; | |||
})(); | |||
// onload stuff | // onload stuff | ||
var firstRun = true; | var firstRun = true; | ||
function loadFunc() { | function loadFunc() | ||
{ | |||
if( firstRun ) | |||
firstRun = false; | firstRun = false; | ||
else | else | ||
| Line 18: | Line 50: | ||
initFunctionsJS(); | 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(); | |||
showEras('title-eraicons'); | |||
showEras('title-shortcut'); | |||
rewriteHover(); | |||
addAlternatingRowColors(); | |||
replaceSearchIcon(); | |||
fixSearch(); | |||
var body = document.getElementsByTagName('body')[0]; | var body = document.getElementsByTagName('body')[0]; | ||
| Line 59: | Line 94: | ||
} | } | ||
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 != "" ) { | |||
if( skin == 'monaco' ) { | if( skin == 'monaco' ) { | ||
document.getElementById("wpSummaryEnhanced").value = value; | document.getElementById("wpSummaryEnhanced").value = value; | ||
| Line 110: | Line 153: | ||
} | } | ||
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 171: | Line 226: | ||
function rewriteTitle() { | function rewriteTitle() { | ||
if( typeof( window.SKIP_TITLE_REWRITE ) != 'undefined' && window.SKIP_TITLE_REWRITE ) | if( typeof( window.SKIP_TITLE_REWRITE ) != 'undefined' && window.SKIP_TITLE_REWRITE ) { | ||
return; | return; | ||
} | |||
if( $('#title-meta').length == 0 ) { | |||
return; | return; | ||
} | |||
var newTitle = $('#title-meta').html(); | |||
if( skin == "oasis" ) { | |||
$('header.WikiaPageHeader > h1').html('<div id="title-meta" style="display: inline;">' + newTitle + '</div>'); | |||
$('header.WikiaPageHeader > h1').attr('style','text-align:' + $('#title-align').html() + ';'); | |||
} else { | |||
$('.firstHeading').html('<div id="title-meta" style="display: inline;">' + newTitle + '</div>'); | |||
$('.firstHeading').attr('style','text-align:' + $('#title-align').html() + ';'); | |||
} | |||
} | |||
function showEras(className) | |||
{ | |||
if( typeof( SKIP_ERAS ) != 'undefined' && SKIP_ERAS ) | |||
return; | |||
var titleDiv = document.getElementById(className); | |||
var titleDiv = document.getElementById( | |||
if(titleDiv == null || titleDiv == undefined) | if(titleDiv == null || titleDiv == undefined) | ||
| Line 202: | Line 260: | ||
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); | |||
} | } | ||
addOnloadHook(loadFunc); | |||
$(loadFunc); | $(loadFunc); | ||
| Line 388: | Line 483: | ||
/////////////////////////////////////////////////////////////////////////////////////////////////////////// | /////////////////////////////////////////////////////////////////////////////////////////////////////////// | ||
//disabled for testing | |||
ajaxPages = new Array("Special:RecentChanges", "Special:Watchlist", "Special:Log", "Special:NewFiles"); | //ajaxPages = new Array("Special:RecentChanges", "Special:Watchlist", "Special:Log", "Special:NewFiles"); | ||
function setCookie(c_name,value,expiredays) { | //function setCookie(c_name,value,expiredays) { | ||
var exdate=new Date() | //var exdate=new Date() | ||
exdate.setDate(exdate.getDate()+expiredays) | //exdate.setDate(exdate.getDate()+expiredays) | ||
document.cookie=c_name+ "=" +escape(value) + ((expiredays==null) ? "" : ";expires="+exdate.toGMTString()) | //document.cookie=c_name+ "=" +escape(value) + ((expiredays==null) ? "" : ";expires="+exdate.toGMTString()) | ||
} | //} | ||
function getCookie(c_name) { | //function getCookie(c_name) { | ||
if (document.cookie.length>0) { | //if (document.cookie.length>0) { | ||
c_start=document.cookie.indexOf(c_name + "=") | //c_start=document.cookie.indexOf(c_name + "=") | ||
if (c_start!=-1) { | //if (c_start!=-1) { | ||
c_start=c_start + c_name.length+1 | //c_start=c_start + c_name.length+1 | ||
c_end=document.cookie.indexOf(";",c_start) | //c_end=document.cookie.indexOf(";",c_start) | ||
if (c_end==-1) c_end=document.cookie.length | //if (c_end==-1) c_end=document.cookie.length | ||
return unescape(document.cookie.substring(c_start,c_end)) | //return unescape(document.cookie.substring(c_start,c_end)) | ||
} | //} | ||
} | //} | ||
return "" | //return "" | ||
} | //} | ||
function getXmlHttpRequestObject() { | //function getXmlHttpRequestObject() { | ||
if (window.XMLHttpRequest) { | //if (window.XMLHttpRequest) { | ||
return new XMLHttpRequest(); //Not Internet Explorer | //return new XMLHttpRequest(); //Not Internet Explorer | ||
} else if(window.ActiveXObject) { | //} else if(window.ActiveXObject) { | ||
return new ActiveXObject("Microsoft.XMLHTTP"); //Internet Explorer | //return new ActiveXObject("Microsoft.XMLHTTP"); //Internet Explorer | ||
} else { | //} else { | ||
//fail silently | //fail silently | ||
} | //} | ||
} | //} | ||
getRCDataRO = getXmlHttpRequestObject(); | //getRCDataRO = getXmlHttpRequestObject(); | ||
var cr = new RegExp("\r", "gm"); | //var cr = new RegExp("\r", "gm"); | ||
var lf = new RegExp("\n", "gm"); | //var lf = new RegExp("\n", "gm"); | ||
var endText = new RegExp('</div>[\t\s]*?<!-- end content -->[\t\s]*?<div class="visualClear">', "mi"); | //var endText = new RegExp('</div>[\t\s]*?<!-- end content -->[\t\s]*?<div class="visualClear">', "mi"); | ||
var rcTimer; | //var rcTimer; | ||
var rcRefresh = 60000; | //var rcRefresh = 60000; | ||
function preloadAJAXRC() { | //function preloadAJAXRC() { | ||
if (skin == "monaco") { | //if (skin == "monaco") { | ||
s = 1; | //s = 1; | ||
} else { | //} else { | ||
s = 0; | //s = 0; | ||
} | //} | ||
ajaxRCCookie = (getCookie("ajaxload-"+wgPageName)=="on") ? true:false; | //ajaxRCCookie = (getCookie("ajaxload-"+wgPageName)=="on") ? true:false; | ||
document.getElementsByTagName("h1")[0].innerHTML += ' <span style="font-size: xx-small; border-bottom: 1px dotted; cursor:help;" title="Enable auto-refreshing page loads">Automatically refresh:</span><input type="checkbox" id="ajaxRCtoggle" onClick="toggleRC();">'; | //document.getElementsByTagName("h1")[0].innerHTML += ' <span style="font-size: xx-small; border-bottom: 1px dotted; cursor:help;" title="Enable auto-refreshing page loads">Automatically refresh:</span><input type="checkbox" id="ajaxRCtoggle" onClick="toggleRC();">'; | ||
document.getElementById("ajaxRCtoggle").checked = ajaxRCCookie; | //document.getElementById("ajaxRCtoggle").checked = ajaxRCCookie; | ||
if (getCookie("ajaxload-"+wgPageName)=="on") loadRCData(); | //if (getCookie("ajaxload-"+wgPageName)=="on") loadRCData(); | ||
//} | |||
} | |||
function | //function toggleRC() { | ||
if ( | //if (document.getElementById("ajaxRCtoggle").checked == true) { | ||
//setCookie("ajaxload-"+wgPageName, "on", 30); | |||
//loadRCData(); | |||
} else { | //} else { | ||
//setCookie("ajaxload-"+wgPageName, "off", 30); | |||
//clearTimeout(rcTimer); | |||
//} | |||
//} | |||
} | |||
} | |||
function | //function loadRCData() { | ||
if (getRCDataRO.readyState == 4) { | //if (getRCDataRO.readyState == 4 || getRCDataRO.readyState == 0) { | ||
//if (location.href.indexOf("/wiki/")) { | |||
//rcURL = "http://" + location.hostname + "/wiki/" + wgPageName + location.search; | |||
//} else { | |||
//rcURL = "http://" + location.hostname + "/" + wgPageName + location.search; | |||
//} | |||
//getRCDataRO.open("GET", rcURL, true); | |||
} | //getRCDataRO.onreadystatechange = parseRCdata; | ||
} | //getRCDataRO.send(null); | ||
//} | |||
//} | |||
//function parseRCdata() { | |||
if ( | //if (getRCDataRO.readyState == 4) { | ||
} | //textFilter = new RegExp('<div id="bodyContent">.*?</div>[\t\s]*?<!-- end content -->[\t\s]*?<div class="visualClear">', "i"); | ||
//rawRCdata = getRCDataRO.responseText.replace(cr, "").replace(lf, ""); | |||
//filteredRCdata = textFilter.exec(rawRCdata); | |||
//updatedText = filteredRCdata[0].replace('<div id="bodyContent">', "").replace(endText, ""); | |||
//document.getElementById("bodyContent").innerHTML = updatedText; | |||
//rcTimer = setTimeout("loadRCData();", rcRefresh); | |||
//} | |||
//} | |||
//for (x in ajaxPages) { | |||
//if (wgPageName == ajaxPages[x]) addOnloadHook(preloadAJAXRC); | |||
//} | |||
// | |||
/////////////////////////////////////////////////////////////////////////////////////////////////////////// | /////////////////////////////////////////////////////////////////////////////////////////////////////////// | ||
| Line 607: | Line 703: | ||
addOnloadHook( disableOldForumEdit ); | addOnloadHook( disableOldForumEdit ); | ||
/** Collapsible tables ********************************************************* | |||
* | |||
* From English Wikipedia, 2008-09-15 | |||
* | |||
* Description: Allows tables to be collapsed, showing only the header. See | |||
* [[Wikipedia:NavFrame]]. | |||
* Maintainers: [[User:R. Koot]] | |||
*/ | |||
var autoCollapse = 2; | |||
var collapseCaption = 'hide'; | |||
var expandCaption = 'show'; | |||
function collapseTable( tableIndex ){ | |||
var Button = document.getElementById( 'collapseButton' + tableIndex ); | |||
var Table = document.getElementById( 'collapsibleTable' + tableIndex ); | |||
if ( !Table || !Button ) { | |||
return false; | |||
} | |||
var Rows = Table.rows; | |||
if ( Button.firstChild.data == collapseCaption ) { | |||
for ( var i = 1; i < Rows.length; i++ ) { | |||
Rows[i].style.display = 'none'; | |||
} | |||
Button.firstChild.data = expandCaption; | |||
} else { | |||
for ( var i = 1; i < Rows.length; i++ ) { | |||
Rows[i].style.display = Rows[0].style.display; | |||
} | |||
Button.firstChild.data = collapseCaption; | |||
} | |||
} | |||
function createCollapseButtons(){ | |||
var tableIndex = 0; | |||
var NavigationBoxes = new Object(); | |||
var Tables = document.getElementsByTagName( 'table' ); | |||
for ( var i = 0; i < Tables.length; i++ ) { | |||
if ( hasClass( Tables[i], 'collapsible' ) ) { | |||
/* only add button and increment count if there is a header row to work with */ | |||
var HeaderRow = Tables[i].getElementsByTagName( 'tr' )[0]; | |||
if( !HeaderRow ) | |||
continue; | |||
var Header = HeaderRow.getElementsByTagName( 'th' )[0]; | |||
if( !Header ) | |||
continue; | |||
NavigationBoxes[tableIndex] = Tables[i]; | |||
Tables[i].setAttribute( 'id', 'collapsibleTable' + tableIndex ); | |||
var Button = document.createElement( 'span' ); | |||
var ButtonLink = document.createElement( 'a' ); | |||
var ButtonText = document.createTextNode( collapseCaption ); | |||
Button.style.styleFloat = 'right'; | |||
Button.style.cssFloat = 'right'; | |||
Button.style.fontWeight = 'normal'; | |||
Button.style.textAlign = 'right'; | |||
Button.style.width = '6em'; | |||
ButtonLink.style.color = Header.style.color; | |||
ButtonLink.setAttribute( 'id', 'collapseButton' + tableIndex ); | |||
ButtonLink.setAttribute( 'href', "javascript:collapseTable(" + tableIndex + ");" ); | |||
ButtonLink.appendChild( ButtonText ); | |||
Button.appendChild( document.createTextNode( "[" ) ); | |||
Button.appendChild( ButtonLink ); | |||
Button.appendChild( document.createTextNode( "]" ) ); | |||
Header.insertBefore( Button, Header.childNodes[0] ); | |||
tableIndex++; | |||
} | |||
} | |||
for ( var i = 0; i < tableIndex; i++ ) { | |||
if ( hasClass( NavigationBoxes[i], 'collapsed' ) || ( tableIndex >= autoCollapse && hasClass( NavigationBoxes[i], 'autocollapse' ) ) ) { | |||
collapseTable( i ); | |||
} | |||
} | |||
} | |||
addOnloadHook( createCollapseButtons ); | |||
/** Dynamic Navigation Bars (experimental) ************************************* | |||
* | |||
* From English Wikipedia, 2008-09-15 | |||
* | |||
* Description: See [[Wikipedia:NavFrame]]. | |||
* Maintainers: UNMAINTAINED | |||
*/ | |||
// set up the words in your language | |||
var NavigationBarHide = '[' + collapseCaption + ']'; | |||
var NavigationBarShow = '[' + expandCaption + ']'; | |||
// shows and hides content and picture (if available) of navigation bars | |||
// Parameters: | |||
// indexNavigationBar: the index of navigation bar to be toggled | |||
function toggleNavigationBar( indexNavigationBar ){ | |||
var NavToggle = document.getElementById('NavToggle' + indexNavigationBar); | |||
var NavFrame = document.getElementById('NavFrame' + indexNavigationBar); | |||
if( !NavFrame || !NavToggle ) { | |||
return false; | |||
} | |||
// if shown now | |||
if( NavToggle.firstChild.data == NavigationBarHide ) { | |||
for( var NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling ) { | |||
if ( hasClass( NavChild, 'NavPic' ) ) { | |||
NavChild.style.display = 'none'; | |||
} | |||
if ( hasClass( NavChild, 'NavContent') ) { | |||
NavChild.style.display = 'none'; | |||
} | |||
} | |||
NavToggle.firstChild.data = NavigationBarShow; | |||
// if hidden now | |||
} else if( NavToggle.firstChild.data == NavigationBarShow) { | |||
for( var NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling ) { | |||
if( hasClass( NavChild, 'NavPic' ) ) { | |||
NavChild.style.display = 'block'; | |||
} | |||
if( hasClass( NavChild, 'NavContent' ) ) { | |||
NavChild.style.display = 'block'; | |||
} | |||
} | |||
NavToggle.firstChild.data = NavigationBarHide; | |||
} | |||
} | |||
// adds show/hide-button to navigation bars | |||
function createNavigationBarToggleButton(){ | |||
var indexNavigationBar = 0; | |||
// iterate over all < div >-elements | |||
var divs = document.getElementsByTagName('div'); | |||
for( var i = 0; NavFrame = divs[i]; i++ ) { | |||
// if found a navigation bar | |||
if( hasClass( NavFrame, 'NavFrame' ) ) { | |||
indexNavigationBar++; | |||
var NavToggle = document.createElement("a"); | |||
NavToggle.className = 'NavToggle'; | |||
NavToggle.setAttribute('id', 'NavToggle' + indexNavigationBar); | |||
NavToggle.setAttribute('href', 'javascript:toggleNavigationBar(' + indexNavigationBar + ');'); | |||
var NavToggleText = document.createTextNode(NavigationBarHide); | |||
for( var NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling ) { | |||
if ( hasClass( NavChild, 'NavPic' ) || hasClass( NavChild, 'NavContent' ) ) { | |||
if( NavChild.style.display == 'none' ) { | |||
NavToggleText = document.createTextNode(NavigationBarShow); | |||
break; | |||
} | |||
} | |||
} | |||
NavToggle.appendChild(NavToggleText); | |||
// Find the NavHead and attach the toggle link (Must be this complicated because Moz's firstChild handling is borked) | |||
for( var j=0; j < NavFrame.childNodes.length; j++) { | |||
if( hasClass( NavFrame.childNodes[j], 'NavHead' ) ) { | |||
NavFrame.childNodes[j].appendChild(NavToggle); | |||
} | |||
} | |||
NavFrame.setAttribute('id', 'NavFrame' + indexNavigationBar); | |||
} | |||
} | |||
} | |||
addOnloadHook( createNavigationBarToggleButton ); | |||
// </nowiki></pre> | // </nowiki></pre> | ||
Latest revision as of 18:10, 12 June 2013
/* <pre style="overflow: scroll; height: 25em"><nowiki> */
// Common.js originally from Wookieepedia.
// Thanks, Wookieepedia!
// plus updates from mediawii's common.js
if ( /^MediaWiki(\/.+)?$/.test( wgPageName ) && wgAction == 'view' ) {
addOnloadHook(function(){
document.body.className+=" mainpage";
})
}
/** includePage ************
* force the loading of another JavaScript file
* @todo Is this still needed? We have importScript and importScriptURI in wikibits.js
* Maintainer: [[Commons:User:Dschwen]]
*/
function includePage( name ){
document.write('<script type="text/javascript" src="' + wgScript + '?title='
+ name + '&action=raw&ctype=text/javascript"><\/script>'
);
}
includePage('MediaWiki:Functions.js');
//Load Functions.js
importScript('MediaWiki:Functions.js');
var hasClass = (function() {
var reCache = {};
return function ( element, className ) {
return (reCache[className] ? reCache[className] : (reCache[className] = new RegExp("(?:\\s|^)" + className + "(?:\\s|$)"))).test(element.className);
};
})();
// onload stuff
var firstRun = true;
function loadFunc()
{
if( firstRun )
firstRun = false;
else
return;
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();
showEras('title-eraicons');
showEras('title-shortcut');
rewriteHover();
addAlternatingRowColors();
replaceSearchIcon();
fixSearch();
var body = document.getElementsByTagName('body')[0];
var bodyClass = body.className;
if( !bodyClass || (bodyClass.indexOf('page-') == -1) ) {
var page = window.pageName.replace(/\W/g, '_');
body.className += ' page-' + page;
}
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 != "" ) {
if( skin == 'monaco' ) {
document.getElementById("wpSummaryEnhanced").value = value;
} else {
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;
}
if( $('#title-meta').length == 0 ) {
return;
}
var newTitle = $('#title-meta').html();
if( skin == "oasis" ) {
$('header.WikiaPageHeader > h1').html('<div id="title-meta" style="display: inline;">' + newTitle + '</div>');
$('header.WikiaPageHeader > h1').attr('style','text-align:' + $('#title-align').html() + ';');
} else {
$('.firstHeading').html('<div id="title-meta" style="display: inline;">' + newTitle + '</div>');
$('.firstHeading').attr('style','text-align:' + $('#title-align').html() + ';');
}
}
function showEras(className)
{
if( typeof( SKIP_ERAS ) != 'undefined' && SKIP_ERAS )
return;
var titleDiv = document.getElementById(className);
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);
$(loadFunc);
///////////////////////////////////////////////////////////////////////////////////////////////////////////
// ADVANCED AJAX AUTO-REFRESHING ARTICLES
// Code courtesy of "pcj" of WoWWiki.
///////////////////////////////////////////////////////////////////////////////////////////////////////////
//disabled for testing
//ajaxPages = new Array("Special:RecentChanges", "Special:Watchlist", "Special:Log", "Special:NewFiles");
//function setCookie(c_name,value,expiredays) {
//var exdate=new Date()
//exdate.setDate(exdate.getDate()+expiredays)
//document.cookie=c_name+ "=" +escape(value) + ((expiredays==null) ? "" : ";expires="+exdate.toGMTString())
//}
//function getCookie(c_name) {
//if (document.cookie.length>0) {
//c_start=document.cookie.indexOf(c_name + "=")
//if (c_start!=-1) {
//c_start=c_start + c_name.length+1
//c_end=document.cookie.indexOf(";",c_start)
//if (c_end==-1) c_end=document.cookie.length
//return unescape(document.cookie.substring(c_start,c_end))
//}
//}
//return ""
//}
//function getXmlHttpRequestObject() {
//if (window.XMLHttpRequest) {
//return new XMLHttpRequest(); //Not Internet Explorer
//} else if(window.ActiveXObject) {
//return new ActiveXObject("Microsoft.XMLHTTP"); //Internet Explorer
//} else {
//fail silently
//}
//}
//getRCDataRO = getXmlHttpRequestObject();
//var cr = new RegExp("\r", "gm");
//var lf = new RegExp("\n", "gm");
//var endText = new RegExp('</div>[\t\s]*?<!-- end content -->[\t\s]*?<div class="visualClear">', "mi");
//var rcTimer;
//var rcRefresh = 60000;
//function preloadAJAXRC() {
//if (skin == "monaco") {
//s = 1;
//} else {
//s = 0;
//}
//ajaxRCCookie = (getCookie("ajaxload-"+wgPageName)=="on") ? true:false;
//document.getElementsByTagName("h1")[0].innerHTML += ' <span style="font-size: xx-small; border-bottom: 1px dotted; cursor:help;" title="Enable auto-refreshing page loads">Automatically refresh:</span><input type="checkbox" id="ajaxRCtoggle" onClick="toggleRC();">';
//document.getElementById("ajaxRCtoggle").checked = ajaxRCCookie;
//if (getCookie("ajaxload-"+wgPageName)=="on") loadRCData();
//}
//function toggleRC() {
//if (document.getElementById("ajaxRCtoggle").checked == true) {
//setCookie("ajaxload-"+wgPageName, "on", 30);
//loadRCData();
//} else {
//setCookie("ajaxload-"+wgPageName, "off", 30);
//clearTimeout(rcTimer);
//}
//}
//function loadRCData() {
//if (getRCDataRO.readyState == 4 || getRCDataRO.readyState == 0) {
//if (location.href.indexOf("/wiki/")) {
//rcURL = "http://" + location.hostname + "/wiki/" + wgPageName + location.search;
//} else {
//rcURL = "http://" + location.hostname + "/" + wgPageName + location.search;
//}
//getRCDataRO.open("GET", rcURL, true);
//getRCDataRO.onreadystatechange = parseRCdata;
//getRCDataRO.send(null);
//}
//}
//function parseRCdata() {
//if (getRCDataRO.readyState == 4) {
//textFilter = new RegExp('<div id="bodyContent">.*?</div>[\t\s]*?<!-- end content -->[\t\s]*?<div class="visualClear">', "i");
//rawRCdata = getRCDataRO.responseText.replace(cr, "").replace(lf, "");
//filteredRCdata = textFilter.exec(rawRCdata);
//updatedText = filteredRCdata[0].replace('<div id="bodyContent">', "").replace(endText, "");
//document.getElementById("bodyContent").innerHTML = updatedText;
//rcTimer = setTimeout("loadRCData();", rcRefresh);
//}
//}
//for (x in ajaxPages) {
//if (wgPageName == ajaxPages[x]) addOnloadHook(preloadAJAXRC);
//}
//
///////////////////////////////////////////////////////////////////////////////////////////////////////////
// END OF AJAX AUTO-REFRESH
///////////////////////////////////////////////////////////////////////////////////////////////////////////
//Link FA
var FA_enabled = true;
function addfaicon() {
// if disabled
if (!FA_enabled) return;
var pLang = document.getElementById("p-lang");
if (!pLang) return;
var lis = pLang.getElementsByTagName("li");
for (var i = 0; i < lis.length; i++) {
var li = lis[i];
// only links with a corresponding Link_FA template are interesting
if (!document.getElementById(li.className + "-fa")) continue;
// additional class so the template can be hidden with CSS
li.className += " FA";
// change title (mouse over)
li.title = "This article is rated as featured article.";
}
}
addOnloadHook(addfaicon);
/* Magic edit intro. Copied from Wikipedia's MediaWiki:Common.js, modified for use in both Monaco and Monobook skins by Sikon*/
function addEditIntro(name) {
// Top link
var el = document.getElementById('ca-edit');
if( typeof(el.href) == 'undefined' ) {
el = el.getElementsByTagName('a')[0];
}
if (el)
el.href += '&editintro=' + name;
// Section links
var spans = document.getElementsByTagName('span');
for ( var i = 0; i < spans.length; i++ ) {
el = null;
if (spans[i].className == 'editsection') {
el = spans[i].getElementsByTagName('a')[0];
if (el)
el.href += '&editintro=' + name;
} else if (spans[i].className == 'editsection-upper') {
el = spans[i].getElementsByTagName('a')[0];
if (el)
el.href += '&editintro=' + name;
}
}
}
if (wgNamespaceNumber == 0) {
addOnloadHook(function(){
var cats = document.getElementById('mw-normal-catlinks');
if (!cats)
return;
cats = cats.getElementsByTagName('a');
for (var i = 0; i < cats.length; i++) {
if (cats[i].title == 'Category:Wookieepedia featured articles') {
addEditIntro('Template:Featured_editintro');
break;
} else if (cats[i].title == 'Category:Wookieepedia good articles') {
addEditIntro('Template:Good_editintro');
break;
} else if ( cats[i].title == 'Category:Articles undergoing major edits' || cats[i].title == 'Category:Works in progress' ) {
addEditIntro('Template:Inuse_editintro‎');
break;
}
}
});
}
// [[Main Page]] JS transform. Originally from [[Wikipedia:MediaWiki:Monobook.js]]/[[Wikipedia:MediaWiki:Common.js]] and may be further modified for local use.
function mainPageRenameNamespaceTab() {
try {
var Node = document.getElementById( 'ca-nstab-main' ).firstChild;
if ( Node.textContent ) { // Per DOM Level 3
Node.textContent = 'Main Page';
} else if ( Node.innerText ) { // IE doesn't handle .textContent
Node.innerText = 'Main Page';
} else { // Fallback
Node.replaceChild( Node.firstChild, document.createTextNode( 'Main Page' ) );
}
} catch(e) {
// bailing out!
}
}
if ( wgTitle == 'Main Page' && ( wgNamespaceNumber == 0 || wgNamespaceNumber == 1 ) ) {
addOnloadHook( mainPageRenameNamespaceTab );
}
/** Archive edit tab disabling *************************************
* Disables the edit tab on old forum topic pages to stop noobs bumping old topics.
* Page can still be edited by going via the edit tab on the history etc, or by
* typing the edit address manually.
* By [[User:Spang|Spang]]
* Monaco support by [[User:Uberfuzzy|]]
* Removal of new section tab on talk pages added by [[User:Grunny|Grunny]]
*/
function disableOldForumEdit() {
if( typeof( enableOldForumEdit ) != 'undefined' && enableOldForumEdit )
return;
if(!document.getElementById('old-forum-warning') ||
!document.getElementById('ca-edit') )
return;
if( skin == 'monaco' ) {
editLink = document.getElementById('ca-edit');
} else if( skin == 'monobook' ) {
editLink = document.getElementById('ca-edit').firstChild;
}
editLink.removeAttribute('href', 0);
editLink.removeAttribute('title', 0);
editLink.style.color = 'gray';
editLink.innerHTML = 'Archived';
$('span.editsection-upper').remove();
$('span.editsection').remove();
appendCSS( '#control_addsection, #ca-addsection { display: none !important; }' );
}
addOnloadHook( disableOldForumEdit );
/** Collapsible tables *********************************************************
*
* From English Wikipedia, 2008-09-15
*
* Description: Allows tables to be collapsed, showing only the header. See
* [[Wikipedia:NavFrame]].
* Maintainers: [[User:R. Koot]]
*/
var autoCollapse = 2;
var collapseCaption = 'hide';
var expandCaption = 'show';
function collapseTable( tableIndex ){
var Button = document.getElementById( 'collapseButton' + tableIndex );
var Table = document.getElementById( 'collapsibleTable' + tableIndex );
if ( !Table || !Button ) {
return false;
}
var Rows = Table.rows;
if ( Button.firstChild.data == collapseCaption ) {
for ( var i = 1; i < Rows.length; i++ ) {
Rows[i].style.display = 'none';
}
Button.firstChild.data = expandCaption;
} else {
for ( var i = 1; i < Rows.length; i++ ) {
Rows[i].style.display = Rows[0].style.display;
}
Button.firstChild.data = collapseCaption;
}
}
function createCollapseButtons(){
var tableIndex = 0;
var NavigationBoxes = new Object();
var Tables = document.getElementsByTagName( 'table' );
for ( var i = 0; i < Tables.length; i++ ) {
if ( hasClass( Tables[i], 'collapsible' ) ) {
/* only add button and increment count if there is a header row to work with */
var HeaderRow = Tables[i].getElementsByTagName( 'tr' )[0];
if( !HeaderRow )
continue;
var Header = HeaderRow.getElementsByTagName( 'th' )[0];
if( !Header )
continue;
NavigationBoxes[tableIndex] = Tables[i];
Tables[i].setAttribute( 'id', 'collapsibleTable' + tableIndex );
var Button = document.createElement( 'span' );
var ButtonLink = document.createElement( 'a' );
var ButtonText = document.createTextNode( collapseCaption );
Button.style.styleFloat = 'right';
Button.style.cssFloat = 'right';
Button.style.fontWeight = 'normal';
Button.style.textAlign = 'right';
Button.style.width = '6em';
ButtonLink.style.color = Header.style.color;
ButtonLink.setAttribute( 'id', 'collapseButton' + tableIndex );
ButtonLink.setAttribute( 'href', "javascript:collapseTable(" + tableIndex + ");" );
ButtonLink.appendChild( ButtonText );
Button.appendChild( document.createTextNode( "[" ) );
Button.appendChild( ButtonLink );
Button.appendChild( document.createTextNode( "]" ) );
Header.insertBefore( Button, Header.childNodes[0] );
tableIndex++;
}
}
for ( var i = 0; i < tableIndex; i++ ) {
if ( hasClass( NavigationBoxes[i], 'collapsed' ) || ( tableIndex >= autoCollapse && hasClass( NavigationBoxes[i], 'autocollapse' ) ) ) {
collapseTable( i );
}
}
}
addOnloadHook( createCollapseButtons );
/** Dynamic Navigation Bars (experimental) *************************************
*
* From English Wikipedia, 2008-09-15
*
* Description: See [[Wikipedia:NavFrame]].
* Maintainers: UNMAINTAINED
*/
// set up the words in your language
var NavigationBarHide = '[' + collapseCaption + ']';
var NavigationBarShow = '[' + expandCaption + ']';
// shows and hides content and picture (if available) of navigation bars
// Parameters:
// indexNavigationBar: the index of navigation bar to be toggled
function toggleNavigationBar( indexNavigationBar ){
var NavToggle = document.getElementById('NavToggle' + indexNavigationBar);
var NavFrame = document.getElementById('NavFrame' + indexNavigationBar);
if( !NavFrame || !NavToggle ) {
return false;
}
// if shown now
if( NavToggle.firstChild.data == NavigationBarHide ) {
for( var NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling ) {
if ( hasClass( NavChild, 'NavPic' ) ) {
NavChild.style.display = 'none';
}
if ( hasClass( NavChild, 'NavContent') ) {
NavChild.style.display = 'none';
}
}
NavToggle.firstChild.data = NavigationBarShow;
// if hidden now
} else if( NavToggle.firstChild.data == NavigationBarShow) {
for( var NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling ) {
if( hasClass( NavChild, 'NavPic' ) ) {
NavChild.style.display = 'block';
}
if( hasClass( NavChild, 'NavContent' ) ) {
NavChild.style.display = 'block';
}
}
NavToggle.firstChild.data = NavigationBarHide;
}
}
// adds show/hide-button to navigation bars
function createNavigationBarToggleButton(){
var indexNavigationBar = 0;
// iterate over all < div >-elements
var divs = document.getElementsByTagName('div');
for( var i = 0; NavFrame = divs[i]; i++ ) {
// if found a navigation bar
if( hasClass( NavFrame, 'NavFrame' ) ) {
indexNavigationBar++;
var NavToggle = document.createElement("a");
NavToggle.className = 'NavToggle';
NavToggle.setAttribute('id', 'NavToggle' + indexNavigationBar);
NavToggle.setAttribute('href', 'javascript:toggleNavigationBar(' + indexNavigationBar + ');');
var NavToggleText = document.createTextNode(NavigationBarHide);
for( var NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling ) {
if ( hasClass( NavChild, 'NavPic' ) || hasClass( NavChild, 'NavContent' ) ) {
if( NavChild.style.display == 'none' ) {
NavToggleText = document.createTextNode(NavigationBarShow);
break;
}
}
}
NavToggle.appendChild(NavToggleText);
// Find the NavHead and attach the toggle link (Must be this complicated because Moz's firstChild handling is borked)
for( var j=0; j < NavFrame.childNodes.length; j++) {
if( hasClass( NavFrame.childNodes[j], 'NavHead' ) ) {
NavFrame.childNodes[j].appendChild(NavToggle);
}
}
NavFrame.setAttribute('id', 'NavFrame' + indexNavigationBar);
}
}
}
addOnloadHook( createNavigationBarToggleButton );
// </nowiki></pre>