MediaWiki:Common.js

/* ######################################################################## */ /* ### JavaScript here will be loaded for all users on every page load. ### */ /* ######################################################################## */

//

// ============================================================ // BEGIN Scripts for Internet Explorer 6 // ============================================================

// Description: Import scripts specific to Internet Explorer 6 // Credit:     This script is from Wikipedia. Please see http://en.wikipedia.org/w/index.php?title=MediaWiki:Common.js&action=history

if (navigator.appName == "Microsoft Internet Explorer") { if (navigator.appVersion.substr(22, 1) == "6") { importScript("MediaWiki:Common.js/IE60Fixes.js") } }

// ============================================================ // END Scripts for Internet Explorer 6 // ============================================================

// ============================================================ // BEGIN Template:Games // ============================================================

// Description: Add game icons to top right corner of articles // Credit:     User:Mirar (based on Template:Eras by User:Sikon)

function addTitleGames { var titleDiv = document.getElementById("title-games"); if (titleDiv != null && titleDiv != undefined) {     var content = document.getElementById('article'); if (!content) { var content = document.getElementById('content'); }

if (content) { var hs = content.getElementsByTagName('h1'); var firstHeading; for (var i = 0; i < hs.length; i++) {           if ( (' '+hs[i].className+' ').indexOf(' firstHeading ') != -1){ firstHeading=hs[i]; break; }        }

var cloneNode = titleDiv.cloneNode(true); firstHeading.insertBefore(cloneNode, firstHeading.childNodes[0]); cloneNode.style.display = "block"; cloneNode.style.visibility = "visible"; if (skin != "monaco") { cloneNode.style.marginTop = "-11px"; }     }   } }

addOnloadHook( addTitleGames );

// ============================================================ // END Template:Games // ============================================================

// ============================================================ // BEGIN Collapsible tables // ============================================================

// Description: Allow tables to be collapsible // Credit:     This script is from Wikipedia. Please see http://en.wikipedia.org/w/index.php?title=MediaWiki:Common.js&action=history //             Customized for Fallout Wiki by User:Porter21

/* Test if an element has a certain class ************************************** * * Description: Uses regular expressions and caching for better performance. * Maintainers: User:Mike Dillon, User:R. Koot, User:SG */

var hasClass = (function {   var reCache = {};   return function (element, className) {      return (reCache[className] ? reCache[className] : (reCache[className] = new RegExp("(?:\\s|^)" + className + "(?:\\s|$)"))).test(element.className);  }; });

/** Collapsible tables ********************************************************* * * Description: Allows tables to be collapsed, showing only the header. See *              NavFrame. * Maintainers: User:R. Koot */

var autoCollapse = 1; 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 collapseIndex = 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 = "4em"; Button.className = "t_show_hide";

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] );

if ( !hasClass( Tables[i], "nocount" ) ) { collapseIndex++; }        tableIndex++; }  }

for ( var i = 0; i < tableIndex; i++ ) { if ( hasClass( NavigationBoxes[i], "collapsed" ) || ( collapseIndex >= autoCollapse && hasClass( NavigationBoxes[i], "autocollapse" ) ) ) { collapseTable( i ); }      else if ( hasClass( NavigationBoxes[i], "innercollapse" ) ) { var element = NavigationBoxes[i]; while (element = element.parentNode) { if ( hasClass( element, "outercollapse" ) ) { collapseTable ( i ); break; }        }      }   } }

addOnloadHook( createCollapseButtons );

// ============================================================ // END Collapsible tables // ============================================================

// ============================================================ // BEGIN ArchiveTool // ============================================================

// Description: Add tool for easier talk page archiving // Credit:     User:Dantman (http://dev.wikia.com)

var archiveListTemplate = 'Archives'; var archivePageTemplate = 'Archivepage'; importScriptPage('ArchiveTool/code.js', 'dev');

// ============================================================ // END ArchiveTool // ============================================================

// ============================================================ // BEGIN AjaxRC // ============================================================

// Description: Automatically refreshes "Recent changes" // Credit:     User:pcj (http://www.wowwiki.com)

var AjaxRCRefreshText = 'Auto-refresh'; var ajaxPages = ["Special:RecentChanges"]; importScriptPage('AjaxRC/code.js', 'dev');

// ============================================================ // END AjaxRC // ============================================================

// ============================================================ // BEGIN Facebook Fanbox // ============================================================

// Description: Integrate Facebook Fanbox into Wiki // Credit:     User:edricteo (http://redwall.wikia.com)

function fBox { $('#Wikifbox').append(''); }

$(fBox);

// ============================================================ // END Facebook Fanbox // ============================================================

// ============================================================ // BEGIN Grayed-out edit button for archived talk pages // ============================================================

// Description: Remove section edit links and gray out main edit button on archived talk pages // Credit:     User:Porter21 (based on "Archive edit tab disabling" by User:Spang and User:Uberfuzzy)

function disableArchiveEdit { if ((wgNamespaceNumber%2 == 0 && wgNamespaceNumber%2 != 501) ||     (wgTitle.indexOf('/Archive ') == -1 && wgTitle.indexOf('/archive ') == -1)) { return; }

if (document.getElementById('ca-edit')) { if (skin == 'monaco') { editLink = document.getElementById('ca-edit'); }    else if (skin == 'monobook') { editLink = document.getElementById('ca-edit').firstChild; }    editLink.title = 'This page is an archive and should usually not be edited.'; editLink.style.color = 'gray'; editLink.innerHTML = 'Archived'; }

$('span.editsection').remove;

if((skin == 'monaco' && document.getElementById('control_addsection')) ||    (skin == 'monobook' && document.getElementById('ca-addsection'))) { if (skin == 'monaco') { addsectionButton = document.getElementById('control_addsection'); }    else if (skin == 'monobook') { addsectionButton = document.getElementById('ca-addsection'); }    addsectionButton.style.display = 'none'; addsectionButton.style.visibility = 'hidden'; }

if (skin == 'monaco' && document.getElementById('fe_newsection')) { document.getElementById('fe_newsection').style.display = 'none'; document.getElementById('fe_newsection').style.visibility = 'hidden'; } }

addOnloadHook (disableArchiveEdit);

// ============================================================ // END Grayed-out edit button for archived talk pages // ============================================================

// ============================================================ // BEGIN Intro text for My Home // ============================================================

// Description: Add intro text to Special:MyHome // Credit:     User:Porter21 (based on Template:Eras by User:Sikon) // Notes:      The intro text and style is stored in MediaWiki:Myhome-intro. //             Also requires  in e.g. MediaWiki:Community-corner.

function addMyHomeIntro { if ( skin == 'monaco' && wgNamespaceNumber == -1 && wgCanonicalSpecialPageName == 'MyHome' && wgUserName != null ) { var introDiv = document.getElementById("fw-myhome-intro"); if (introDiv != null && introDiv != undefined) { var bodyDiv = document.getElementById('article');

if (bodyDiv != null && bodyDiv != undefined) { var cloneDiv = introDiv.cloneNode(true); cloneDiv.style.display = "block"; cloneDiv.style.visibility = "visible";

bodyDiv.insertBefore(cloneDiv, bodyDiv.childNodes[0]); }     }   } }

addOnloadHook( addMyHomeIntro );

// ============================================================ // END Intro text for My Home // ============================================================

//

// ************************************************** // Experimental javascript countdown timer (Splarka) // Version 0.0.3 // ************************************************** // // Usage example: // //  Only January 01 2007 00:00:00 PST until New years. // //  Javascript disabled.

function updatetimer(i) { var now = new Date; var then = timers[i].eventdate; var diff = count=Math.floor((then.getTime-now.getTime)/1000);

// catch bad date strings if(isNaN(diff)) { timers[i].firstChild.nodeValue = '** ' + timers[i].eventdate + ' **' ; return; }

// determine plus/minus if(diff<0) { diff = -diff; var tpm = 'T plus '; } else { var tpm = 'T minus '; }

// calcuate the diff var left = (diff%60) + ' seconds'; diff=Math.floor(diff/60); if(diff > 0) left = (diff%60) + ' minutes ' + left; diff=Math.floor(diff/60); if(diff > 0) left = (diff%24) + ' hours ' + left; diff=Math.floor(diff/24); if(diff > 0) left = diff + ' days ' + left timers[i].firstChild.nodeValue = tpm + left;

// a setInterval is more efficient, but calling setTimeout // makes errors break the script rather than infinitely recurse timeouts[i] = setTimeout('updatetimer(' + i + ')',1000); }

function checktimers { //hide 'nocountdown' and show 'countdown' var nocountdowns = getElementsByClassName(document, 'span', 'nocountdown'); for(var i in nocountdowns) nocountdowns[i].style.display = 'none' var countdowns = getElementsByClassName(document, 'span', 'countdown'); for(var i in countdowns) countdowns[i].style.display = 'inline'

//set up global objects timers and timeouts. timers = getElementsByClassName(document, 'span', 'countdowndate'); //global timeouts = new Array; // generic holder for the timeouts, global if(timers.length == 0) return; for(var i in timers) { timers[i].eventdate = new Date(timers[i].firstChild.nodeValue); updatetimer(i); //start it up  } } addOnloadHook(checktimers);

// ************************************************** // - end -  Experimental javascript countdown timer // **************************************************