MediaWiki:Common.js

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

/* Changes the width of margin on right/left on the frontpage when the window is smaller than 1500px */ $(function {    var windowWidth = window.innerWidth;    if (windowWidth < 1500){        var point = document.getElementsByClassName("FrontpageOuterDiv");        var i;        for (i = 0; i < point.length; i++){           point[i].style.maxWidth="100%";           }    } });

$(document).ready(function {	if ($("#noTitle").length > 0){		$("#firstHeading").detach	} });

/** * Countdown * * @version 2.1 * * @author Pecoes  * @author Asaba  * * Version 1 authors: * - Splarka  * - Eladkse  * * documentation and examples at: *  */ /*jshint jquery:true, browser:true, devel:true, camelcase:true, curly:false, undef:true, bitwise:true, eqeqeq:true, forin:true, immed:true, latedef:true, newcap:true, noarg:true, unused:true, regexp:true, strict:true, trailing:false */ /*global mediaWiki:true*/ 'use strict'; var translations = $.extend(true, {		// English (English)		en: {			and: 'and',			second: 'second',			seconds: 'seconds',			minute: 'minute',			minutes: 'minutes',			hour: 'hour',			hours: 'hours',			day: 'day',			days: 'days'		},	}, module.translations || {}), i18n = translations[ mw.config.get('wgContentLanguage') ] || translations.en; var countdowns = []; var NO_LEADING_ZEROS = 1, SHORT_FORMAT = 1, NO_ZEROS = 4; function output (i, diff) { /*jshint bitwise:false*/ var delta, result, parts = []; delta = diff % 60; //result = ' ' + i18n[delta === 1 ? 'second' : 'seconds']; //if (countdowns[i].opts & SHORT_FORMAT) result = result.charAt(1); //parts.unshift(delta + result); diff = Math.floor(diff / 60); delta = diff % 60; result = ' ' + i18n[delta === 1 ? 'minute' : 'minutes']; if (countdowns[i].opts & SHORT_FORMAT) result = result.charAt(1); parts.unshift(delta + result); diff = Math.floor(diff / 60); delta = diff % 24; result = ' ' + i18n[delta === 1 ? 'hour'  : 'hours'  ]; if (countdowns[i].opts & SHORT_FORMAT) result = result.charAt(1); parts.unshift(delta + result); diff = Math.floor(diff / 24); result = ' ' + i18n[diff === 1 ? 'day'   : 'days'   ]; if (countdowns[i].opts & SHORT_FORMAT) result = result.charAt(1); parts.unshift(diff + result); result = parts.pop; if (countdowns[i].opts & NO_LEADING_ZEROS) { while (parts.length && parts[0][0] === '0') { parts.shift; }		}		if (countdowns[i].opts & NO_ZEROS) { parts = parts.filter(function(part) {				return part[0] !== '0';			}); }		if (parts.length) { if (countdowns[i].opts & SHORT_FORMAT) { result = parts.join(' ') + ' ' + result; } else { result = parts.join(', ') + ' ' + i18n.and + ' ' + result; }		}		countdowns[i].node.text(result); }	function end(i) { var c = countdowns[i].node.parent; switch (c.attr('data-end')) { case 'remove': c.remove; return true; case 'stop': output(i, 0); return true; case 'toggle': var toggle = c.attr('data-toggle'); if (toggle && toggle == 'next') { c.next.css('display', 'inline'); c.css('display', 'none'); return true; }			if (toggle && $(toggle).length) { $(toggle).css('display', 'inline'); c.css('display', 'none'); return true; }			break; case 'callback': var callback = c.attr('data-callback'); if (callback && $.isFunction(module[callback])) { output(i, 0); module[callback].call(c); return true; }			break; }		countdowns[i].countup = true; output(i, 0); return false; }	function update { var now = Date.now; var countdownsToRemove = []; $.each(countdowns.slice(0), function (i, countdown) {			var diff = Math.floor((countdown.date - now) / 1000);			if (diff <= 0 && !countdown.countup) {				if (end(i)) countdownsToRemove.push(i);			} else {				output(i, Math.abs(diff));			}		}); var x;		while((x = countdownsToRemove.pop) !== undefined) { countdowns.splice(x, 1); }		if (countdowns.length) { window.setTimeout(function {				update;			}, 1000); }	}	function getOptions (node) { /*jshint bitwise:false*/ var text = node.parent.attr('data-options'), opts = 0; if (text) { if (/no-leading-zeros/.test(text)) { opts |= NO_LEADING_ZEROS; }			if (/short-format/.test(text)) { opts |= SHORT_FORMAT; }			if (/no-zeros/.test(text)) { opts |= NO_ZEROS; }		}		return opts; }	function toggleInit { var countdown = $('.countdown:not(.handled)'); if (!countdown.length) return; $('.nocountdown').css('display', 'none'); countdown .css('display', 'inline') .find('.countdowndate') .each(function {			var $this = $(this),				date = (new Date($this.text)).valueOf;			if (isNaN(date)) {				$this.text('BAD DATE');				return;			}			countdowns.push({ node: $this, opts: getOptions($this), date: date, });		});		countdown.addClass('handled'); if (countdowns.length) { update; }	}	mw.hook('wikipage.content').add(toggleInit); }(window.countdownTimer = window.countdownTimer || {}, mediaWiki, jQuery));
 * (function (module, mw, $, undefined) {

var toggleMapListSetup = function { var btn = $('a[id^="collapseButton"]');

btn.each(function {		var table = $(this).closest('table');		var m = $('.maprow', table);

if (m.length) { m.hide; // Collapse maps by default

var span = $(' ', {				class: 'mapsCollapseButton',				css: {					'font-weight': 'normal',					'float': 'right',					'margin-right': '7px',					'cursor': 'pointer'				}			});

table.data('maps-collapsed', true);

var toggleMaps = function { table.find('.maprow').toggle; table.data('maps-collapsed', !table.data('maps-collapsed'));

$(this).text(function(i, txt) {					return txt.replace(/\+|−/, function(a) { return a === '+' ? '−' : '+';					});				});			}

var a = $('+maps').click(toggleMaps);

span.append('[', a, ']'); $(this).parent.after(span);

if (table.hasClass('uncollapsed-maps')) { a.trigger('click'); }		}	}); };

function includePage( name ) { document.write('<\/script>'  ); } /* End of includePage */

/* ======================================================================== * Bootstrap: dropdown.js v3.1.1 * http://getbootstrap.com/javascript/#dropdowns * ======================================================================== * Copyright 2011-2014 Twitter, Inc. * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE) * ======================================================================== */

+function ($) { 'use strict';

// DROPDOWN CLASS DEFINITION // =========================

var backdrop = '.dropdown-backdrop' var toggle  = '[data-toggle=dropdown]' var Dropdown = function (element) { $(element).on('click.bs.dropdown', this.toggle) }

Dropdown.prototype.toggle = function (e) { var $this = $(this)

if ($this.is('.disabled, :disabled')) return

var $parent = getParent($this) var isActive = $parent.hasClass('open')

clearMenus

if (!isActive) { if ('ontouchstart' in document.documentElement && !$parent.closest('.navbar-nav').length) { // if mobile we use a backdrop because click events don't delegate $(' ').insertAfter($(this)).on('click', clearMenus) }

var relatedTarget = { relatedTarget: this } $parent.trigger(e = $.Event('show.bs.dropdown', relatedTarget))

if (e.isDefaultPrevented) return

$parent .toggleClass('open') .trigger('shown.bs.dropdown', relatedTarget)

$this.focus }

return false }

Dropdown.prototype.keydown = function (e) { if (!/(38|40|27)/.test(e.keyCode)) return

var $this = $(this)

e.preventDefault e.stopPropagation

if ($this.is('.disabled, :disabled')) return

var $parent = getParent($this) var isActive = $parent.hasClass('open')

if (!isActive || (isActive && e.keyCode == 27)) { if (e.which == 27) $parent.find(toggle).focus return $this.click }

var desc = ' li:not(.divider):visible a'   var $items = $parent.find('[role=menu]' + desc + ', [role=listbox]' + desc)

if (!$items.length) return

var index = $items.index($items.filter(':focus'))

if (e.keyCode == 38 && index > 0)                index--                        // up    if (e.keyCode == 40 && index < $items.length - 1) index++                        // down if (!~index)                                     index = 0

$items.eq(index).focus }

function clearMenus(e) { $(backdrop).remove $(toggle).each(function {      var $parent = getParent($(this))      var relatedTarget = { relatedTarget: this }      if (!$parent.hasClass('open')) return      $parent.trigger(e = $.Event('hide.bs.dropdown', relatedTarget))      if (e.isDefaultPrevented) return      $parent.removeClass('open').trigger('hidden.bs.dropdown', relatedTarget)    }) }

function getParent($this) { var selector = $this.attr('data-target')

if (!selector) { selector = $this.attr('href') selector = selector && /#[A-Za-z]/.test(selector) && selector.replace(/.*(?=#[^\s]*$)/, '') //strip for ie7 }

var $parent = selector && $(selector)

return $parent && $parent.length ? $parent : $this.parent }

// DROPDOWN PLUGIN DEFINITION // ==========================

var old = $.fn.dropdown

$.fn.dropdown = function (option) { return this.each(function {      var $this = $(this)      var data  = $this.data('bs.dropdown')

if (!data) $this.data('bs.dropdown', (data = new Dropdown(this))) if (typeof option == 'string') data[option].call($this) }) }

$.fn.dropdown.Constructor = Dropdown

// DROPDOWN NO CONFLICT // ====================

$.fn.dropdown.noConflict = function { $.fn.dropdown = old return this }

// APPLY TO STANDARD DROPDOWN ELEMENTS // ===================================

$(document) .on('click.bs.dropdown.data-api', clearMenus) .on('click.bs.dropdown.data-api', '.dropdown form', function (e) { e.stopPropagation }) .on('click.bs.dropdown.data-api', toggle, Dropdown.prototype.toggle) .on('keydown.bs.dropdown.data-api', toggle + ', [role=menu], [role=listbox]', Dropdown.prototype.keydown)

}(jQuery);

jQuery(function($) { $('.dropdown').hover(function { $(this).find('.dropdown-menu').first.stop(true, true).delay(100).slideDown;

}, function { if ($(this).find('.dropdown-menu').parents('.open').length) {

} else { $(this).find('.dropdown-menu').first.stop(true, true).delay(100).slideUp; } });

$('.dropdown > a').click(function{ location.href = this.href; });

});

/* Dynamic Tabs - Adapted from Liquipedia - http://wiki.teamliquid.net/dota2/MediaWiki:Common.js */ /* Tabs by FO-nTTaX */ $(document).ready (function {	$('div.tabs-dynamic ul.tabs li').click( function { var i = $(this).index + 1; $(this).parent.children('li').removeClass('active'); $(this).addClass('active'); $(this).parent.parent.children('div.tabs-content').children('div').removeClass('active'); $(this).parent.parent.children('div.tabs-content').children('div.content' + i).addClass('active'); }	);	$('div.tabs-dynamic').each(function(index) { var h = $(this).children('ul.tabs').children('li.active').index + 1; $(this).children('div.tabs-content').children('div.content' + h).addClass('active'); });	var hash = location.hash.slice(1);	if (hash.substring(0, 4) == 'tab-') {		var hasharr = hash.split('-scrollto-');		var tabno = hasharr[0].replace('tab-', '');   		$('div.tabs-dynamic ul.tabs li').removeClass('active');		$('div.tabs-dynamic ul.tabs li.tab' + tabno).addClass('active');		$('div.tabs-dynamic div.tabs-content div').removeClass('active');		$('div.tabs-dynamic div.tabs-content div.content' + tabno).addClass('active');		if (hasharr.length == 2) {			var scrollto = '#' + hasharr[1];			setTimeout(function{$(window).scrollTop($(scrollto).offset.top)}, 500);		}	} }); /* Dynamic Tabs - END */ /* Bracket Highlighting - Adapted from Liquipedia - http://wiki.teamliquid.net/dota2/MediaWiki:Common.js */ var highlighted; $.fn.justtext = function { return $(this).clone.children.remove('div').end.text.trim; }; var bracketGame; $(document).ready(function {	$('.bracket-game').each( function { if ($(this).find('.bracket-game-details').length > 0) { var margin = $(this).find(':first-child').height - 6; $(this).prepend(' '); }	});	$('.match-row').each( function { if ($(this).find('.bracket-game-details').length > 0) { $(this).find('td:eq(2)').prepend('  '); }	});	$('.match-row').hover(function { $(this).addClass('bracket-hover'); if ($(this).closest('.match-row').find('.bracket-game-details').length) { $(this).css('cursor', 'pointer'); }	},	function { $(this).removeClass('bracket-hover'); });	$('.bracket-team-top, .bracket-team-top-oldschool, .bracket-team-bottom, .bracket-team-bottom-oldschool, .bracket-game .icon').hover(function { var t = $(this), text = t.justtext; if ((text) && (text.toUpperCase != 'BYE')) { highlighted = $('.bracket').find('.bracket-team-top, .bracket-team-bottom, .bracket-team-top-oldschool, .bracket-team-bottom-oldschool').filter(function {				return $(this).justtext == text;			}); highlighted.css('background', '#cecece'); }		if (t.closest('.bracket-game').children('.bracket-game-details').length) { t.css('cursor', 'pointer'); }	},	function { if (highlighted != null) highlighted.css('background', ''); });

$('html').click(function {		if (bracketGame != null) {			bracketGame.find('.bracket-game-details').toggle;			bracketGame = null;		}	});

$('.bracket-team-top, .bracket-team-bottom, .bracket-team-top-oldschool, .bracket-team-bottom-oldschool, .bracket-game .icon').click(	function (event) {		var bracket = $(this).closest('.bracket'),			detailsHeight, detailsWidth, spaceOnTheRight;		if (bracketGame != null) {			bracketGame.children('.bracket-game-details').toggle;			if (bracketGame[0] === $(this).closest('.bracket-game')[0]) {				bracketGame = null;				return;			}		}		bracketGame = $(this).closest('.bracket-game');		detailsHeight= bracketGame.children('.bracket-game-details').height; 		detailsWidth = bracketGame.children('.bracket-game-details').width;		bracketGame.children('.bracket-game-details').css('margin-top', -detailsHeight / 2);		spaceOnTheRight = Math.max($(window).width, bracket.offset.left + bracket.outerWidth) - (bracketGame.offset.left + bracketGame.outerWidth);		if (spaceOnTheRight < detailsWidth && bracketGame.offset.left > detailsWidth) { bracketGame.children('.bracket-game-details').css('margin-left', -detailsWidth - 1); } else { bracketGame.children('.bracket-game-details').css('margin-left', bracketGame.width); }		bracketGame.children('.bracket-game-details').toggle; event.stopPropagation; });	$('.match-row').click(function (event) { if (bracketGame != null) { bracketGame.find('.bracket-game-details').toggle; if (bracketGame[0] === $(this)[0]) { bracketGame = null; return; }		}		bracketGame = $(this); var height = bracketGame.find('.bracket-game-details').height; bracketGame.find('.bracket-game-details').css('margin-top', 3); bracketGame.find('.bracket-game-details').toggle; event.stopPropagation; });

$('.bracket-game-details').click(function (event) {		event.stopPropagation;	}); }); /* End Bracket Highlighting */

/* PentakillTV Embed Stuff */ $(function { $('.embedframe').find('a:not(.toggler-link)').each(function {

$(this).attr("target","_blank");

});

});

/* Sideways text for blockbox needs the height of the parent div altered */ $(document).ready(function {   $('.vert-text').each(function{ var parentHeight = $(this).parent.height; $(this).height(parentHeight); }); });

/* Including extra .js pages */ $(function { var allowedKeys = {  37: 'left',  38: 'up',  39: 'right',  40: 'down',  65: 'a',  66: 'b' };

var secret = ['up', 'up', 'down', 'down', 'left', 'right', 'left', 'right', 'b', 'a'];

// a variable to remember the 'position' the user has reached so far. var secretCodePosition = 0;

// add keydown event listener document.addEventListener('keydown', function(e) { // get the value of the key code from the key map  var key = allowedKeys[e.keyCode];  var requiredKey = secret[secretCodePosition];

// compare the key with the required key if (key == requiredKey) {

// move to the next key in the konami code sequence secretCodePosition++;

// if the last key is reached, activate cheats if (secretCodePosition == secret.length) activateCheats; } else secretCodePosition = 0; });

function activateCheats { document.body.style.backgroundImage = "url('/w/images/Zileanbg.png')"; var audio = new Audio('/w/images/Chronokeeper.joke.ogx'); audio.play;

} });

/** * Collapsible tables * * Allows tables to be collapsed, showing only the header. See Help:Collapsing. * * @version 2.0.3 (2014-03-14) * @source https://www.mediawiki.org/wiki/MediaWiki:Gadget-collapsibleTables.js * @author User:R. Koot * @author User:Krinkle * @deprecated Since MediaWiki 1.20: Use class="mw-collapsible" instead which * is supported in MediaWiki core. */

var autoCollapse = 2; var collapseCaption = 'hide'; var expandCaption = 'show'; var tableIndex = 0;

function collapseTable( tableIndex ) { var Button = document.getElementById( 'collapseButton' + tableIndex ); var Table = document.getElementById( 'collapsibleTable' + tableIndex );

if ( !Table || !Button ) { return false; }

var Rows = Table.rows; var i;   var $row0 = $(Rows[0]);

if ( Button.firstChild.data === collapseCaption ) { for ( i = 1; i < Rows.length; i++ ) { Rows[i].style.display = 'none'; }       Button.firstChild.data = expandCaption; } else { for ( i = 1; i < Rows.length; i++ ) { Rows[i].style.display = $row0.css( 'display' ); }       Button.firstChild.data = collapseCaption; } }

function createClickHandler( tableIndex ) { return function ( e ) { e.preventDefault; collapseTable( tableIndex ); }; }

function createCollapseButtons( $content ) { var NavigationBoxes = {}; var $Tables = $content.find( 'table' ); var i;

$Tables.each( function( i, table ) {       if ( $(table).hasClass( 'collapsible' ) ) {

/* only add button and increment count if there is a header row to work with */ var HeaderRow = table.getElementsByTagName( 'tr' )[0]; if ( !HeaderRow ) { return; }           var Header = table.getElementsByTagName( 'th' )[0]; if ( !Header ) { return; }

NavigationBoxes[ tableIndex ] = table; table.setAttribute( 'id', 'collapsibleTable' + tableIndex );

var Button    = document.createElement( 'span' ); var ButtonLink = document.createElement( 'a' ); var ButtonText = document.createTextNode( collapseCaption ); // Styles are declared in MediaWiki:Common.css Button.className = 'collapseButton';

ButtonLink.style.color = Header.style.color; ButtonLink.setAttribute( 'id', 'collapseButton' + tableIndex ); ButtonLink.setAttribute( 'href', '#' ); $( ButtonLink ).on( 'click', createClickHandler( tableIndex ) ); ButtonLink.appendChild( ButtonText );

Button.appendChild( document.createTextNode( '[' ) ); Button.appendChild( ButtonLink ); Button.appendChild( document.createTextNode( ']' ) );

Header.insertBefore( Button, Header.firstChild ); tableIndex++; }   } );

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

mw.hook( 'wikipage.content' ).add( createCollapseButtons );

/** * Add support to mw-collapsible for autocollapse, innercollapse and outercollapse * * Maintainers: TheDJ */ function mwCollapsibleSetup( $collapsibleContent ) { var $element, $toggle, autoCollapseThreshold = 2; $.each( $collapsibleContent, function (index, element) {		$element = $( element );		if ( $collapsibleContent.length > autoCollapseThreshold && $element.hasClass( 'autocollapse' ) ) {			$element.data( 'mw-collapsible' ).collapse;		} else if ( $element.hasClass( 'innercollapse' ) ) {			if ( $element.parents( '.outercollapse' ).length > 0 ) {				$element.data( 'mw-collapsible' ).collapse;			}		}		$toggle = $element.find( '.mw-collapsible-toggle' );		if ( $toggle.length ) {			// Make the toggle inherit text color			if( $toggle.parent[0].style.color ) {				$toggle.find( 'a' ).css( 'color', 'inherit' );			}		}	} ); }

mw.hook( 'wikipage.collapsibleContent' ).add( mwCollapsibleSetup );

/** * Dynamic Navigation Bars (experimental) * * Description: See NavFrame. * Maintainers: UNMAINTAINED */

/* set up the words in your language */ var NavigationBarHide = '[' + collapseCaption + ']'; var NavigationBarShow = '[' + expandCaption + ']'; var indexNavigationBar = 0;

/** * Shows and hides content and picture (if available) of navigation bars * Parameters: *    indexNavigationBar: the index of navigation bar to be toggled **/ window.toggleNavigationBar = function ( indexNavigationBar, event ) { var NavToggle = document.getElementById( 'NavToggle' + indexNavigationBar ); var NavFrame = document.getElementById( 'NavFrame' + indexNavigationBar ); var NavChild;

if ( !NavFrame || !NavToggle ) { return false; }

/* if shown now */ if ( NavToggle.firstChild.data === NavigationBarHide ) { for ( NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling ) { if ( $( NavChild ).hasClass( 'NavContent' ) || $( NavChild ).hasClass( 'NavPic' ) ) { NavChild.style.display = 'none'; }       }    NavToggle.firstChild.data = NavigationBarShow;

/* if hidden now */ } else if ( NavToggle.firstChild.data === NavigationBarShow ) { for ( NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling ) { if ( $( NavChild ).hasClass( 'NavContent' ) || $( NavChild ).hasClass( 'NavPic' ) ) { NavChild.style.display = 'block'; }       }        NavToggle.firstChild.data = NavigationBarHide; }

event.preventDefault; };

/* adds show/hide-button to navigation bars */ function createNavigationBarToggleButton( $content ) { var NavChild; /* iterate over all -elements */ var $divs = $content.find( 'div' ); $divs.each( function ( i, NavFrame ) {       /* if found a navigation bar */        if ( $( NavFrame ).hasClass( 'NavFrame' ) ) {

indexNavigationBar++; var NavToggle = document.createElement( 'a' ); NavToggle.className = 'NavToggle'; NavToggle.setAttribute( 'id', 'NavToggle' + indexNavigationBar ); NavToggle.setAttribute( 'href', '#' ); $( NavToggle ).on( 'click', $.proxy( window.toggleNavigationBar, window, indexNavigationBar ) );

var isCollapsed = $( NavFrame ).hasClass( 'collapsed' ); /**            * Check if any children are already hidden. This loop is here for backwards compatibility: * the old way of making NavFrames start out collapsed was to manually add style="display:none" * to all the NavPic/NavContent elements. Since this was bad for accessibility (no way to make            * the content visible without JavaScript support), the new recommended way is to add the class * "collapsed" to the NavFrame itself, just like with collapsible tables. */           for ( NavChild = NavFrame.firstChild; NavChild != null && !isCollapsed; NavChild = NavChild.nextSibling ) { if ( $( NavChild ).hasClass( 'NavPic' ) || $( NavChild ).hasClass( 'NavContent' ) ) { if ( NavChild.style.display === 'none' ) { isCollapsed = true; }               }            }            if ( isCollapsed ) { for ( NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling ) { if ( $( NavChild ).hasClass( 'NavPic' ) || $( NavChild ).hasClass( 'NavContent' ) ) { NavChild.style.display = 'none'; }               }            }            var NavToggleText = document.createTextNode( isCollapsed ? NavigationBarShow : NavigationBarHide ); 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 ( $( NavFrame.childNodes[j] ).hasClass( 'NavHead' ) ) { NavToggle.style.color = NavFrame.childNodes[j].style.color; NavFrame.childNodes[j].appendChild( NavToggle ); }           }            NavFrame.setAttribute( 'id', 'NavFrame' + indexNavigationBar ); }   } ); }

mw.hook( 'wikipage.content' ).add( createNavigationBarToggleButton );

/* functions for gadgets */ window.displayColor = function(colorclass) { $("#p-cactions").addClass(colorclass); return; }

window.clearDisplayColor = function { $("#p-cactions").removeClass("gadget-action-fail gadget-action-incomplete gadget-action-success"); } /* end functions for gadgets */

$(function {	var title = mw.config.get('wgTitle');	$('[data-to-target-title="' + title + '"]').each(function { $(this).removeClass('to_hasTooltip'); $(this).attr('data-to-id',''); }	); });