Difference between revisions of "MediaWiki:Common.js"

From Lafayette Inc Wiki
Jump to navigation Jump to search
m (1 revision)
 
 
(2 intermediate revisions by the same user not shown)
Line 1: Line 1:
/* Any JavaScript here will be loaded for all users on every page load. */
+
/**
 +
* Keep code in MediaWiki:Common.js to a minimum as it is unconditionally
 +
* loaded for all users on every wiki page. If possible create a gadget that is
 +
* enabled by default instead of adding it here (since gadgets are fully
 +
* optimized ResourceLoader modules with possibility to add dependencies etc.)
 +
*
 +
* Since Common.js isn't a gadget, there is no place to declare its
 +
* dependencies, so we have to lazy load them with mw.loader.using on demand and
 +
* then execute the rest in the callback. In most cases these dependencies will
 +
* be loaded (or loading) already and the callback will not be delayed. In case a
 +
* dependency hasn't arrived yet it'll make sure those are loaded before this.
 +
*/
  
/*<source lang="javascript">*/
+
/* global mw, $, importStylesheet, importScript */
 +
/* jshint strict:false, browser:true */
  
/** Collapsible tables *********************************************************
+
mw.loader.using( ['mediawiki.util', 'mediawiki.notify', 'jquery.client'] ).done( function () {
  *
+
/* Begin of mw.loader.using callback */
  * Description: Allows tables to be collapsed, showing only the header. See
+
 
  *               [[Wikipedia:NavFrame]].
+
/**
  *  Maintainer on Wikipedia: [[User:R. Koot]]
+
* Main Page layout fixes
  */
+
*
+
* Description: Adds an additional link to the complete list of languages available.
var autoCollapse = 2;
+
* Maintainers: [[User:AzaToth]], [[User:R. Koot]], [[User:Alex Smotrov]]
var collapseCaption = "hide";
+
*/
var expandCaption = "show";
+
if ( mw.config.get( 'wgPageName' ) === 'Main_Page' || mw.config.get( 'wgPageName' ) === 'Talk:Main_Page' ) {
+
     $( function () {
function hasClass( element, className ) {
+
        mw.util.addPortletLink( 'p-lang', '//meta.wikimedia.org/wiki/List_of_Wikipedias',
  var Classes = element.className.split( " " );
+
            'Complete list', 'interwiki-completelist', 'Complete list of Wikipedias' );
  for ( var i = 0; i < Classes.length; i++ ) {
+
     } );
     if ( Classes[i] == className ) {
 
      return ( true );
 
     }
 
  }
 
  return ( false );
 
 
}
 
}
  
function collapseTable( tableIndex )
+
/**
{
+
* Redirect User:Name/skin.js and skin.css to the current skin's pages
    var Button = document.getElementById( "collapseButton" + tableIndex );
+
* (unless the 'skin' page really exists)
    var Table = document.getElementById( "collapsibleTable" + tableIndex );
+
* @source: http://www.mediawiki.org/wiki/Snippets/Redirect_skin.js
+
* @rev: 2
    if ( !Table || !Button ) {
+
*/
        return false;
+
if ( mw.config.get( 'wgArticleId' ) === 0 && mw.config.get( 'wgNamespaceNumber' ) === 2 ) {
    }
+
    var titleParts = mw.config.get( 'wgPageName' ).split( '/' );
+
    /* Make sure there was a part before and after the slash
    var Rows = Table.getElementsByTagName( "tr" );  
+
      and that the latter is 'skin.js' or 'skin.css' */
+
    if ( titleParts.length == 2 ) {
    if ( Button.firstChild.data == collapseCaption ) {
+
        var userSkinPage = titleParts.shift() + '/' + mw.config.get( 'skin' );
        for ( var i = 1; i < Rows.length; i++ ) {
+
        if ( titleParts.slice( -1 ) == 'skin.js' ) {
            Rows[i].style.display = "none";
+
            window.location.href = mw.util.getUrl( userSkinPage + '.js' );
        }
+
        } else if ( titleParts.slice( -1 ) == 'skin.css' ) {
        Button.firstChild.data = expandCaption;
+
            window.location.href = mw.util.getUrl( userSkinPage + '.css' );
    } 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" ) ) {
 
            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.setAttribute( "id", "collapseButton" + tableIndex );
 
            ButtonLink.setAttribute( "href", "javascript:collapseTable(" + tableIndex + ");" );
 
            ButtonLink.appendChild( ButtonText );
 
 
            Button.appendChild( document.createTextNode( "[" ) );
 
            Button.appendChild( ButtonLink );
 
            Button.appendChild( document.createTextNode( "]" ) );
 
 
            var Header = Tables[i].getElementsByTagName( "tr" )[0].getElementsByTagName( "th" )[0];
 
            /* only add button and increment count if there is a header row to work with */
 
            if (Header) {
 
                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 );
 
  
 +
/**
 +
* Map addPortletLink to mw.util
 +
* @deprecated: Use mw.util.addPortletLink instead.
 +
*/
 +
mw.log.deprecate( window, 'addPortletLink', mw.util.addPortletLink, 'Use mw.util.addPortletLink instead' );
  
/** Dynamic Navigation Bars (experimental) *************************************
+
/**
*
+
* Extract a URL parameter from the current URL
* Description: See [[Wikipedia:NavFrame]].
+
* @deprecated: Use mw.util.getParamValue with proper escaping
* Maintainers: UNMAINTAINED
+
  */
*/
+
mw.log.deprecate( window, 'getURLParamValue', mw.util.getParamValue, 'Use mw.util.getParamValue instead' );
  
// set up the words in your language
+
/**
var NavigationBarHide = '[' + collapseCaption + ']';
+
* Test if an element has a certain class
var NavigationBarShow = '[' + expandCaption + ']';
+
* @deprecated:  Use $(element).hasClass() instead.
 +
*/
 +
mw.log.deprecate( window, 'hasClass', function ( element, className ) {
 +
    return $( element ).hasClass( className );
 +
}, 'Use jQuery.hasClass() instead' );
  
// shows and hides content and picture (if available) of navigation bars
+
/**
// Parameters:
+
* @source www.mediawiki.org/wiki/Snippets/Load_JS_and_CSS_by_URL
//     indexNavigationBar: the index of navigation bar to be toggled
+
* @rev 6
function toggleNavigationBar(indexNavigationBar)
+
*/
{
+
var extraCSS = mw.util.getParamValue( 'withCSS' ),
    var NavToggle = document.getElementById("NavToggle" + indexNavigationBar);
+
     extraJS = mw.util.getParamValue( 'withJS' );
     var NavFrame = document.getElementById("NavFrame" + indexNavigationBar);
 
  
     if (!NavFrame || !NavToggle) {
+
if ( extraCSS ) {
         return false;
+
     if ( extraCSS.match( /^MediaWiki:[^&<>=%#]*\.css$/ ) ) {
 +
         importStylesheet( extraCSS );
 +
    } else {
 +
        mw.notify( 'Only pages from the MediaWiki namespace are allowed.', { title: 'Invalid withCSS value' } );
 
     }
 
     }
 +
}
  
    // if shown now
+
if ( extraJS ) {
     if (NavToggle.firstChild.data == NavigationBarHide) {
+
     if ( extraJS.match( /^MediaWiki:[^&<>=%#]*\.js$/ ) ) {
        for (var NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling) {
+
        importScript( extraJS );
            if ( hasClass( NavChild, 'NavPic' ) ) {
+
     } else {
                NavChild.style.display = 'none';
+
         mw.notify( 'Only pages from the MediaWiki namespace are allowed.', { title: 'Invalid withJS value' } );
            }
 
            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()
+
* Import more specific scripts if necessary
{
+
*/
    var indexNavigationBar = 0;
+
if ( mw.config.get( 'wgAction' ) === 'edit' || mw.config.get( 'wgAction' ) === 'submit' || mw.config.get( 'wgCanonicalSpecialPageName' ) === 'Upload' ) {
     // iterate over all < div >-elements
+
     /* scripts specific to editing pages */
     var divs = document.getElementsByTagName("div");
+
     importScript( 'MediaWiki:Common.js/edit.js' );
    for (var i = 0; NavFrame = divs[i]; i++) {
+
} else if ( mw.config.get( 'wgCanonicalSpecialPageName' ) === 'Watchlist' ) {
        // if found a navigation bar
+
    /* watchlist scripts */
        if (hasClass(NavFrame, "NavFrame")) {
+
    importScript( 'MediaWiki:Common.js/watchlist.js' );
 +
}
 +
if ( mw.config.get( 'wgNamespaceNumber' ) === 6 ) {
 +
    /* file description page scripts */
 +
    importScript( 'MediaWiki:Common.js/file.js' );
 +
}
  
            indexNavigationBar++;
+
/**
            var NavToggle = document.createElement("a");
+
* Helper script for .hlist class in Common.css
            NavToggle.className = 'NavToggle';
+
* Add pseudo-selector class to last-child list items in IE8
            NavToggle.setAttribute('id', 'NavToggle' + indexNavigationBar);
+
* @source mediawiki.org/wiki/Snippets/Horizontal_lists
             NavToggle.setAttribute('href', 'javascript:toggleNavigationBar(' + indexNavigationBar + ');');
+
* @revision 6 (2014-08-23)
 +
* @author [[User:Edokter]]
 +
*/
 +
( function ( mw, $ ) {
 +
    var profile = $.client.profile();
 +
    if ( profile.name === 'msie' && profile.versionNumber === 8 ) {
 +
        mw.hook( 'wikipage.content' ).add( function ( $content ) {
 +
             $content.find( '.hlist' ).find( 'dd:last-child, dt:last-child, li:last-child' )
 +
                .addClass( 'hlist-last-child' );
 +
        } );
 +
    }
 +
}( mediaWiki, jQuery ) );
  
            var NavToggleText = document.createTextNode(NavigationBarHide);
+
/**
            for (var NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling) {
+
* Fix for Windows XP Unicode font rendering
                if ( hasClass( NavChild, 'NavPic' ) || hasClass( NavChild, 'NavContent' ) ) {
+
*/
                    if (NavChild.style.display == 'none') {
+
if ( navigator.appVersion.search(/windows nt 5/i) !== -1 ) {
                        NavToggleText = document.createTextNode(NavigationBarShow);
+
    mw.util.addCSS( '.IPA { font-family: "Lucida Sans Unicode", "Arial Unicode MS"; } ' +
                        break;
+
                 '.Unicode { font-family: "Arial Unicode MS", "Lucida Sans Unicode"; } ' );
                    }
+
}
                 }
 
            }
 
  
            NavToggle.appendChild(NavToggleText);
+
/**
            // Find the NavHead and attach the toggle link (Must be this complicated because Moz's firstChild handling is borked)
+
* WikiMiniAtlas
            for(var j=0; j < NavFrame.childNodes.length; j++) {
+
*
                if (hasClass(NavFrame.childNodes[j], "NavHead")) {
+
* Description: WikiMiniAtlas is a popup click and drag world map.
                    NavFrame.childNodes[j].appendChild(NavToggle);
+
*              This script causes all of our coordinate links to display the WikiMiniAtlas popup button.
                 }
+
*              The script itself is located on meta because it is used by many projects.
 +
*              See [[Meta:WikiMiniAtlas]] for more information.
 +
* Maintainers: [[User:Dschwen]]
 +
*/
 +
( function () {
 +
    var require_wikiminiatlas = false;
 +
    var coord_filter = /geohack/;
 +
    $( function () {
 +
        $( 'a.external.text' ).each( function( key, link ) {
 +
            if ( link.href && coord_filter.exec( link.href ) ) {
 +
                require_wikiminiatlas = true;
 +
                 // break from loop
 +
                return false;
 
             }
 
             }
             NavFrame.setAttribute('id', 'NavFrame' + indexNavigationBar);
+
        } );
 +
        if ( $( 'div.kmldata' ).length ) {
 +
            require_wikiminiatlas = true;
 +
        }
 +
        if ( require_wikiminiatlas ) {
 +
             mw.loader.load( '//meta.wikimedia.org/w/index.php?title=MediaWiki:Wikiminiatlas.js&action=raw&ctype=text/javascript' );
 
         }
 
         }
     }
+
     } );
}
+
} )();
  
addOnloadHook( createNavigationBarToggleButton );
+
/**
 +
* Collapsible tables
 +
*
 +
* Allows tables to be collapsed, showing only the header. See [[Wikipedia:NavFrame]].
 +
*
 +
* @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;
  
//Shuffle for election candidates
+
function collapseTable( tableIndex ) {
function dshuf(){
+
    var Button = document.getElementById( 'collapseButton' + tableIndex );
                var shufsets=new Object()
+
    var Table = document.getElementById( 'collapsibleTable' + tableIndex );
                var rx=new RegExp('dshuf'+'\\s+(dshufset\\d+)', 'i')  
 
                var divs=document.getElementsByTagName("div")
 
                for (var i=0; i<divs.length; i++){
 
                        if (rx.test(divs[i].className)){
 
                                if (typeof shufsets[RegExp.$1]=="undefined"){
 
                                        shufsets[RegExp.$1]=new Object()
 
                                        shufsets[RegExp.$1].inner=[]
 
                                        shufsets[RegExp.$1].member=[]
 
                                }
 
                                        shufsets[RegExp.$1].inner.push(divs[i].innerHTML)
 
                                        shufsets[RegExp.$1].member.push(divs[i])
 
                        }
 
                }
 
                for (shufset in shufsets){
 
                        shufsets[shufset].inner.sort(function() {return 0.5 - Math.random()})
 
                        for (var i=0; i<shufsets[shufset].member.length; i++){
 
                                shufsets[shufset].member[i].innerHTML=shufsets[shufset].inner[i]
 
                                shufsets[shufset].member[i].style.display="block"
 
                        }
 
                }
 
  
}
+
    if ( !Table || !Button ) {
 +
        return false;
 +
    }
  
addOnloadHook(dshuf);
+
    var Rows = Table.rows;
 +
    var i;
  
/*************
+
    if ( Button.firstChild.data === collapseCaption ) {
*** AJAX transclusion table <http://meta.wikimedia.org/wiki/User:Pathoschild/Scripts/AJAX_transclusion_table>
+
        for ( i = 1; i < Rows.length; i++ ) {
*** by [[m:user:Pathoschild]]
+
            Rows[i].style.display = 'none';
*************/
+
        }
function attLoader() {
+
        Button.firstChild.data = expandCaption;
if(getElementsByClassName(document.getElementsByTagName('body')[0],'table','attable').length) {
+
     } else {
        document.write('<script type="text/javascript" src="'
+
        for ( i = 1; i < Rows.length; i++ ) {
          + 'http://meta.wikimedia.org/w/index.php?title=User:Pathoschild/Scripts/AJAX_transclusion_table.js'
+
            Rows[i].style.display = Rows[0].style.display;
          + '&action=raw&ctype=text/javascript&dontcountme=s"></script>');
+
        }
}
+
        Button.firstChild.data = collapseCaption;
}
 
addOnloadHook(attLoader);
 
 
 
/** JSconfig ************
 
* Global configuration options to enable/disable and configure
 
* specific script features from [[MediaWiki:Common.js]] and
 
* [[MediaWiki:Monobook.js]]
 
* This framework adds config options (saved as cookies) to [[Special:Preferences]]
 
* For a more permanent change you can override the default settings in your
 
* [[Special:Mypage/monobook.js]]
 
* for Example: JSconfig.keys[loadAutoInformationTemplate] = false;
 
*
 
*  Maintainer: [[User:Dschwen]]
 
*/
 
 
var JSconfig =
 
{
 
prefix : 'jsconfig_',
 
keys : {},
 
meta : {},
 
 
//
 
// Register a new configuration item
 
//  * name          : String, internal name
 
//  * default_value : String or Boolean (type determines configuration widget)
 
//  * description  : String, text appearing next to the widget in the preferences
 
//  * prefpage      : Integer (optional), section in the preferences to insert the widget:
 
//                    0 : User profile
 
//                    1 : Skin
 
//                    2 : Math
 
//                    3 : Files
 
//                    4 : Date and time
 
//                    5 : Editing
 
//                    6 : Recent changes
 
//                    7 : Watchlist
 
//                    8 : Search
 
//                    9 : Misc
 
//
 
// Access keys through JSconfig.keys[name]
 
//
 
registerKey : function( name, default_value, description, prefpage )
 
{
 
  if( typeof(JSconfig.keys[name]) == 'undefined' )
 
  JSconfig.keys[name] = default_value;
 
  else {
 
 
  // all cookies are read as strings,
 
  // convert to the type of the default value
 
  switch( typeof(default_value) )
 
  {
 
    case 'boolean' : JSconfig.keys[name] = ( JSconfig.keys[name] == 'true' ); break;
 
     case 'number'  : JSconfig.keys[name] = JSconfig.keys[name]/1; break;
 
  }
 
 
  }
 
 
  JSconfig.meta[name] = { 'description' : description, 'page' : prefpage || 0, 'default_value' : default_value };
 
},
 
 
readCookies : function()
 
{
 
  var cookies = document.cookie.split("; ");
 
  var p =JSconfig.prefix.length;
 
  var i;
 
 
  for( var key in cookies )
 
  {
 
  if( cookies[key].substring(0,p) == JSconfig.prefix )
 
  {
 
    i = cookies[key].indexOf('=');
 
    //alert( cookies[key] + ',' + key + ',' + cookies[key].substring(p,i) );
 
    JSconfig.keys[cookies[key].substring(p,i)] = cookies[key].substring(i+1);
 
  }
 
  }
 
},
 
 
writeCookies : function()
 
{
 
  for( var key in JSconfig.keys )
 
  document.cookie = JSconfig.prefix + key + '=' + JSconfig.keys[key] + '; path=/; expires=Thu, 2 Aug 2009 10:10:10 UTC';
 
},
 
 
evaluateForm : function()
 
{
 
  var w_ctrl,wt;
 
  //alert('about to save JSconfig');
 
  for( var key in JSconfig.meta ) {
 
  w_ctrl = document.getElementById( JSconfig.prefix + key )
 
  if( w_ctrl )
 
  {
 
    wt = typeof( JSconfig.meta[key].default_value );
 
    switch( wt ) {
 
    case 'boolean' : JSconfig.keys[key] = w_ctrl.checked; break;
 
    case 'string' : JSconfig.keys[key] = w_ctrl.value; break;
 
 
     }
 
     }
  }
 
  }
 
 
  JSconfig.writeCookies();
 
  return true;
 
},
 
 
setUpForm : function()
 
{
 
  var prefChild = document.getElementById('preferences');
 
  if( !prefChild ) return;
 
  prefChild = prefChild.childNodes;
 
 
  //
 
  // make a list of all preferences sections
 
  //
 
  var tabs = new Array;
 
  var len = prefChild.length;
 
  for( var key = 0; key < len; key++ ) {
 
  if( prefChild[key].tagName &&
 
      prefChild[key].tagName.toLowerCase() == 'fieldset' )
 
    tabs.push(prefChild[key]);
 
  }
 
 
  //
 
  // Create Widgets for all registered config keys
 
  //
 
  var w_div, w_label, w_ctrl, wt;
 
  for( var key in JSconfig.meta ) {
 
  w_div = document.createElement( 'DIV' );
 
 
  w_label = document.createElement( 'LABEL' );
 
  w_label.appendChild( document.createTextNode( JSconfig.meta[key].description ) )
 
  w_label.htmlFor = JSconfig.prefix + key;
 
 
  wt = typeof( JSconfig.meta[key].default_value );
 
 
  w_ctrl = document.createElement( 'INPUT' );
 
  w_ctrl.id = JSconfig.prefix + key;
 
 
  // before insertion into the DOM tree
 
  switch( wt ) {
 
    case 'boolean' : w_ctrl.type = 'checkbox'; break;
 
    case 'string'  : w_ctrl.type = 'text'; break;
 
  }
 
 
  w_div.appendChild( w_label );
 
  w_div.appendChild( w_ctrl );
 
  tabs[JSconfig.meta[key].page].appendChild( w_div );
 
 
  // after insertion into the DOM tree
 
  switch( wt ) {
 
    case 'boolean' : w_ctrl.defaultChecked = w_ctrl.checked = JSconfig.keys[key]; break;
 
    case 'string' : w_ctrl.defaultValue = w_ctrl.value = JSconfig.keys[key]; break;
 
  }
 
 
  }
 
  addHandler(document.getElementById('preferences').parentNode, 'submit', JSconfig.evaluateForm );
 
}
 
 
}
 
}
 
JSconfig.readCookies();
 
addOnloadHook(JSconfig.setUpForm);
 
  
// ability to pull [[MediaWiki:Gadget-rtl.css]] on individual page loads by [[testwiki:User:Splarka]] and [[wm2008:User:Mr.Z-man]]
+
function createClickHandler( tableIndex ) {
function importStylesheet(page) {
+
    return function ( e ) {
  if (page.indexOf('http://') == -1 && page.indexOf('https://') == -1 && page.indexOf('file:///') == -1)
+
        e.preventDefault();
    page = wgScript + '?action=raw&ctype=text/css&smaxage=0&title='
+
        collapseTable( tableIndex );
    + encodeURIComponent(page.replace(/ /g,'_'))
+
    };
  return document.createStyleSheet ? document.createStyleSheet(page) : appendCSS('@import "' + page + '";')
 
 
}
 
}
 
function appendCSS(text){
 
var s = document.createElement('style')
 
s.setAttribute('type', 'text/css')
 
if (s.styleSheet) s.styleSheet.cssText = text //IE
 
else s.appendChild(document.createTextNode(text))
 
document.getElementsByTagName('head')[0].appendChild(s)
 
return s
 
}
 
 
if(document.URL.indexOf('rtl=1') != -1) importStylesheet('http://meta.wikimedia.org/w/index.php?title=MediaWiki:Gadget-rtl.css&action=raw&ctype=text/css');
 
  
//import module
+
function createCollapseButtons( $content ) {
importedScripts = {}
+
    var NavigationBoxes = {};
function importScript(page, lang) {
+
    var $Tables = $content.find( 'table' );
page = '?title=' + encodeURIComponent(page.replace(' ','_'))
+
    var i;
if (lang) page = 'http://' + lang + '.wikipedia.org/w/index.php' + page
 
else page = wgScript + page
 
if (importedScripts[page]) return
 
importedScripts[page] = true
 
var s = document.createElement('script')
 
s.type = 'text/javascript'
 
s.src = page + '&action=raw&ctype=text/javascript'
 
document.getElementsByTagName('head')[0].appendChild(s)
 
}
 
  
// Fix links like User:Example@somewiki. Author: VasilievVV, with modifications by Kalan and attempted rewrite by Splarka
+
    $Tables.each( function( i, table ) {
if(wgCanonicalSpecialPageName == 'Log' || wgCanonicalSpecialPageName == 'Recentchanges')
+
        if ( $(table).hasClass( 'collapsible' ) ) {
importScript('MediaWiki:Common.js/interlinker.js')
 
 
if(wgCanonicalSpecialPageName == 'GlobalBlock' && window.wgUserGroups && wgUserGroups.join(' ').indexOf('steward') != -1)
 
addOnloadHook(function() {
 
  document.getElementById('mw-globalblock-anon-only').checked = true;
 
});
 
  
// stolen from [[commons:MediaWiki:Common.js]] by [[commons:User:Remember the dot]] - thanks
+
            /* only add button and increment count if there is a header row to work with */
// Import language-specific stylesheet, especially useful for languages like German that have (un)usual capitalization rules
+
            var HeaderRow = table.getElementsByTagName( 'tr' )[0];
//
+
            if ( !HeaderRow ) {
importStylesheet("MediaWiki:" + skin + ".css/" + wgUserLanguage);
+
                return;
 +
            }
 +
            var Header = table.getElementsByTagName( 'th' )[0];
 +
            if ( !Header ) {
 +
                return;
 +
            }
  
/**
+
            NavigationBoxes[ tableIndex ] = table;
* Implements language selection for multilingual elements
+
            table.setAttribute( 'id', 'collapsibleTable' + tableIndex );
*
 
* In certain environments, it's not feasible to neatly box away each
 
* different language into its own section of the site. By marking elements
 
* multilingual, you can emulate this behavior by only displaying the
 
* message in the user's language. This reduced the "Tower of Babel" effect.
 
*
 
* @author Edward Z. Yang (Ambush Commander)
 
* @version $Id: language_select.js 1358 2007-02-19 15:34:59Z Edward $
 
*/
 
  
/* Configuration: */
+
            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';
  
// in your monobook.js, set ls_enable = false to stop the javascript
+
            ButtonLink.style.color = Header.style.color;
// maybe it should be cookie configurable. However, you can achieve
+
            ButtonLink.setAttribute( 'id', 'collapseButton' + tableIndex );
// something almost to this effect through cookie settings
+
            ButtonLink.setAttribute( 'href', '#' );
var ls_enable = true;
+
            $( ButtonLink ).on( 'click', createClickHandler( tableIndex ) );
 +
            ButtonLink.appendChild( ButtonText );
  
// the cookie name we use to stash the info.
+
            Button.appendChild( document.createTextNode( '[' ) );
// change this if you are porting it to another wiki!
+
            Button.appendChild( ButtonLink );
var ls_cookie = 'metawiki_language_js';
+
            Button.appendChild( document.createTextNode( ']' ) );
  
// link to the language select page
+
            Header.insertBefore( Button, Header.firstChild );
var ls_help_url = 'http://meta.wikimedia.org/wiki/Meta:Language_select';
+
            tableIndex++;
 +
        }
 +
    } );
  
// strings that are part of the widgets
+
    for ( i = 0;  i < tableIndex; i++ ) {
var ls_string_help = 'Language select:';
+
        if ( $( NavigationBoxes[i] ).hasClass( 'collapsed' ) ||
var ls_string_select = 'Select';
+
            ( tableIndex >= autoCollapse && $( NavigationBoxes[i] ).hasClass( 'autocollapse' ) )
var ls_string_showall = 'Show all';
+
        ) {
 
+
            collapseTable( i );
// define some meta-variables
+
        }
var ls__first = true; // the first iteration?
+
        else if ( $( NavigationBoxes[i] ).hasClass ( 'innercollapse' ) ) {
 
+
            var element = NavigationBoxes[i];
// node compatability fix
+
            while ((element = element.parentNode)) {
if (!window.Node) {
+
                if ( $( element ).hasClass( 'outercollapse' ) ) {
    var Node = {
+
                    collapseTable ( i );
        ELEMENT_NODE : 1,
+
                    break;
        ATTRIBUTE_NODE: 2,
+
                }
        TEXT_NODE: 3,
+
            }
        COMMENT_NODE: 8,
+
         }
        DOCUMENT_NODE: 9,
 
        DOCUMENT_FRAGMENT_NODE: 11
 
    };
 
}
 
 
 
// autodetects a browser language
 
function ls_getBrowserLanguage() {
 
    var language;
 
    // borrowed from Wikimedia's site error notice
 
    // find the language
 
    if (navigator.userLanguage) {
 
        // use the user's preferred language (non-Gecko)
 
        language = navigator.userLanguage;
 
    } else if (navigator.appName == 'Netscape') {
 
        // use the only language information available to Gecko
 
        language = navigator.language;
 
    } else {
 
        // get the browser language information in non-Gecko browsers
 
         // (IE, Opera, Konqueror)
 
        language = navigator.browserLanguage;
 
 
     }
 
     }
    return language;
 
 
}
 
}
  
// grabs language from cookie
+
mw.hook( 'wikipage.content' ).add( createCollapseButtons );
function ls_getCookieLanguage() {
 
    var allcookies = document.cookie;
 
    var marker = ls_cookie + '=';
 
    var pos = allcookies.indexOf(marker);
 
   
 
    // cookie isn't set, so no behavior defined
 
    if (pos === -1) return null;
 
   
 
    // cookie is set
 
    var start = pos + marker.length;
 
    var end  = allcookies.indexOf(';', start);
 
    if (end == -1) end = allcookies.length;
 
   
 
    var raw  = allcookies.substring(start,end);
 
    var value = unescape(raw);
 
   
 
    return value;
 
}
 
  
// sets a new language to the cookie
+
/**
function ls_setCookieLanguage(language) {
+
* Dynamic Navigation Bars (experimental)
    var today = new Date();
+
*
    var expiry = new Date(today.getUTCFullYear() + 30, 1);
+
* Description: See [[Wikipedia:NavFrame]].
    document.cookie = ls_cookie + '=' + escape(language) + '; expires=' + expiry.toGMTString();
+
* Maintainers: UNMAINTAINED
}
+
*/
  
// deletes the cookie
+
/* set up the words in your language */
function ls_deleteCookieLanguage(language) {
+
var NavigationBarHide = '[' + collapseCaption + ']';
    document.cookie = ls_cookie + '=; expires=Fri, 02-Jan-1970 00:00:00 GMT';
+
var NavigationBarShow = '[' + expandCaption + ']';
}
+
var indexNavigationBar = 0;
  
// grabs the ISO 639 language code based
+
/**
// on either the browser or a supplied cookie
+
* Shows and hides content and picture (if available) of navigation bars
// return of "mul" will display all available strings
+
* Parameters:
function ls_getLanguage() {
+
  *     indexNavigationBar: the index of navigation bar to be toggled
    var language = '';
+
  **/
   
+
window.toggleNavigationBar = function ( indexNavigationBar, event ) {
    // Priority:
+
    var NavToggle = document.getElementById( 'NavToggle' + indexNavigationBar );
    // 1. Cookie
+
     var NavFrame = document.getElementById( 'NavFrame' + indexNavigationBar );
     //  2. wgUserLanguage global variable
+
     var NavChild;
    // 3. Browser autodetection
 
   
 
    // grab according to cookie
 
    language = ls_getCookieLanguage();
 
   
 
    // grab according to wgUserLanguage
 
    if (!language && window.wgUserLanguage) {
 
        language = wgUserLanguage;
 
    }
 
   
 
    // grab according to browser if none defined
 
    if (!language) {
 
        language = ls_getBrowserLanguage();
 
    }
 
   
 
    // inflexible: can't accept multiple languages
 
   
 
    // remove dialect/region code, leaving only the ISO 639 code
 
     var length;
 
    // possible bug: supposedly the language string could be en_US
 
    // switch to regexps when we get the chance
 
    if ((length = language.indexOf('-')) !== -1) {
 
        language = language.substr(0, length);
 
     }
 
   
 
    return language;
 
}
 
  
// walks all child elements and finds all elements with multilingual in them
+
     if ( !NavFrame || !NavToggle ) {
function ls_getAllMultilingualElements(n) {
+
         return false;
    var elements = new Array();
 
    // possible bug if we have a classname that includes the word multilingual
 
    //  but it's unlikely
 
     if (n.className && n.className.indexOf('multilingual') != -1) {
 
         elements = elements.concat(n);
 
 
     }
 
     }
    var children = n.childNodes;
 
    for(var i=0; i < children.length; i++) {
 
        if (children[i].nodeType !== Node.ELEMENT_NODE) continue;
 
        elements = elements.concat(ls_getAllMultilingualElements(children[i]));
 
    }
 
    return elements;
 
}
 
  
// walks a hash and hides all non-matching languages
+
    /* if shown now */
function ls_hideAllExcept(lang_element_hash, language) {
+
     if ( NavToggle.firstChild.data === NavigationBarHide ) {
     for (var n in lang_element_hash) {
+
         for ( NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling ) {
         if (n == language) {
+
             if ( $( NavChild ).hasClass( 'NavContent' ) || $( NavChild ).hasClass( 'NavPic' ) ) {
             lang_element_hash[n].style.display = '';
+
                NavChild.style.display = 'none';
        } else {
+
            }
            lang_element_hash[n].style.display = 'none';
 
 
         }
 
         }
     }
+
     NavToggle.firstChild.data = NavigationBarShow;
}
 
  
// walks a hash and shows all languages
+
    /* if hidden now */
function ls_showAll(lang_element_hash) {
+
    } else if ( NavToggle.firstChild.data === NavigationBarShow ) {
    for (var n in lang_element_hash) {
+
        for ( NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling ) {
        if (lang_element_hash[n].style.display) {
+
            if ( $( NavChild ).hasClass( 'NavContent' ) || $( NavChild ).hasClass( 'NavPic' ) ) {
            lang_element_hash[n].style.display = '';
+
                NavChild.style.display = 'block';
 +
            }
 
         }
 
         }
 +
        NavToggle.firstChild.data = NavigationBarHide;
 
     }
 
     }
}
 
  
// build widget for changing the language cookie
+
    event.preventDefault();
function ls_buildWidget(language) {
+
};
 
+
 
     // set up the floating form
+
/* adds show/hide-button to navigation bars */
     var form = document.createElement('form');
+
function createNavigationBarToggleButton( $content ) {
    form.className = 'lang_info';
+
    var NavChild;
    form.onsubmit = function() {
+
     /* iterate over all < div >-elements */
        if (this.elements[2].ls_mul_flag) {
+
     var $divs = $content.find( 'div' );
            this.elements[2].ls_mul_flag = false;
+
    $divs.each( function ( i, NavFrame ) {
             var language = 'mul';
+
        /* if found a navigation bar */
             var temporary = true;
+
        if ( $( NavFrame ).hasClass( 'NavFrame' ) ) {
        } else {
+
 
             ls_setCookieLanguage(this.elements[0].value);
+
            indexNavigationBar++;
            var language = this.elements[0].value;
+
            var NavToggle = document.createElement( 'a' );
             var temporary = false;
+
            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 );
 
         }
 
         }
        ls_applyLanguageSelect(language, temporary);
+
     } );
       
 
        return false; // don't perform action
 
     };
 
    form.appendSpace = function() {
 
        this.appendChild(document.createTextNode(' '));
 
    };
 
   
 
    // link to language select description page
 
    var link = document.createElement('a');
 
    link.href = ls_help_url;
 
    link.className = 'ls_link';
 
    link.appendChild(document.createTextNode(ls_string_help));
 
    form.appendChild(link);
 
   
 
    form.appendSpace();
 
   
 
    // input box for the language
 
    var input = document.createElement('input');
 
    input.setAttribute('type', 'text');
 
    input.setAttribute('size', '2');
 
//    input.setAttribute('maxlength', '7');
 
    input.onclick = function() { this.select(); };
 
    input.className = 'ls_input';
 
    input.value = language;
 
    form.appendChild(input);
 
   
 
    form.appendSpace();
 
   
 
    // save button
 
    var submit = document.createElement('input');
 
    submit.setAttribute('type', 'submit');
 
    submit.value = ls_string_select;
 
    submit.className = 'ls_select';
 
    form.appendChild(submit);
 
   
 
    form.appendSpace();
 
   
 
    // show all button
 
    // equivalent to setting input box to "mul" and pressing save
 
    var showall = document.createElement('input');
 
    showall.setAttribute('type', 'submit');
 
    showall.value = ls_string_showall;
 
    showall.onclick = function() {
 
        this.ls_mul_flag = true;
 
    };
 
    form.appendChild(showall);
 
   
 
    return form;
 
   
 
 
}
 
}
  
// main body of the function
+
mw.hook( 'wikipage.content' ).add( createNavigationBarToggleButton );
function ls_applyLanguageSelect(language, temporary) {
+
 
   
+
/**
    // possible site for cookie checking to disable language select
+
* Uploadwizard_newusers
    if (!ls_enable) return;
+
* Switches in a message for non-autoconfirmed users at [[Wikipedia:Upload]]
   
+
*
    // if language is blank, delete the cookie and then recalculate
+
* Maintainers: [[User:Krimpet]]
    if (!language) {
+
*/
        ls_deleteCookieLanguage();
+
function uploadwizard_newusers() {
        language = ls_getLanguage();
+
    if ( mw.config.get( 'wgNamespaceNumber' ) === 4 && mw.config.get( 'wgTitle' ) === 'Upload' && mw.config.get( 'wgAction' ) === 'view' ) {
    }
+
        var oldDiv = document.getElementById( 'autoconfirmedusers' ),
   
+
            newDiv = document.getElementById( 'newusers' );
    // grab the body element (only one)
+
        if ( oldDiv && newDiv ) {
    var body = document.getElementsByTagName('body')[0];
+
            var userGroups = mw.config.get( 'wgUserGroups' );
   
+
            if ( userGroups ) {
    // grab an array of multilingual elements
+
                for ( var i = 0; i < userGroups.length; i++ ) {
    var mls = ls_getAllMultilingualElements(body);
+
                    if ( userGroups[i] === 'autoconfirmed' ) {
   
+
                        oldDiv.style.display = 'block';
    // this will get overwritten many times, temporary variable
+
                        newDiv.style.display = 'none';
    var form, language_element_hash;
+
                        return;
   
+
                    }
    // iterate through all those elements
+
                 }
    for (var i = 0; i < mls.length; i++) {
 
        var ml  = mls[i];        // the current multilingual container
 
        var ml_c = ml.childNodes; // children of the container
 
       
 
        // if it's the first iteration...
 
        if (ls__first) {
 
            form = ls_buildWidget(language);
 
            ml.appendChild(form, ml_c[0]);
 
        } else {
 
            // update widget
 
            form = ml_c[ml_c.length - 1]; // form is last element
 
            if (!temporary) {
 
                form.elements[0].value = language;
 
                form.elements[0].removeAttribute('disabled');
 
                form.elements[2].removeAttribute('disabled');
 
            } else {
 
                 form.elements[0].setAttribute('disabled', 'disabled');
 
                form.elements[2].setAttribute('disabled', 'disabled');
 
 
             }
 
             }
 +
            oldDiv.style.display = 'none';
 +
            newDiv.style.display = 'block';
 +
            return;
 
         }
 
         }
       
 
        form.elements[0].style.background="#FFF";
 
       
 
        // tells us whether or not to blindly perform the keep
 
        var message_exists  = false;
 
       
 
        // iterate through all languages and set up a hash
 
        //  with references to each of the language nodes
 
        lang_element_hash = new Object();
 
        for (var j = 0; j < ml_c.length; j++) {
 
            var n = ml_c[j];
 
            if (n.nodeType != Node.ELEMENT_NODE) continue; // skip non-elements
 
            if (!n.lang) continue; // skip non-language specific elements
 
            if (n.lang.indexOf(language) === 0) {
 
                // it turns out our language is here
 
                message_exists  = true;
 
            }
 
            lang_element_hash[n.lang] = n;
 
        }
 
       
 
        // if a preferred language was kept, do quickest processing
 
        if (message_exists) {
 
            ls_hideAllExcept(lang_element_hash, language);
 
            continue;
 
        }
 
       
 
        // otherwise, nothing happened, this means that it wasn't found
 
       
 
        // if it's not the first time, repaint all of them
 
        if (!ls__first) {
 
            ls_showAll(lang_element_hash);
 
        }
 
       
 
        if (language != 'mul') {
 
            form.elements[0].style.background="#FCC";
 
        }
 
       
 
 
     }
 
     }
   
 
    // we've already processed once
 
    ls__first = false;
 
   
 
 
}
 
}
  
function ls_applyDefaultLanguageSelect() {
+
$(uploadwizard_newusers);
     ls_applyLanguageSelect(ls_getLanguage(), false);
+
 
 +
/**
 +
* Magic editintros ****************************************************
 +
*
 +
* Description: Adds editintros on disambiguation pages and BLP pages.
 +
* Maintainers: [[User:RockMFR]]
 +
*/
 +
function addEditIntro( name ) {
 +
     $( '.mw-editsection, #ca-edit' ).find( 'a' ).each( function ( i, el ) {
 +
        el.href = $( this ).attr( 'href' ) + '&editintro=' + name;
 +
    } );
 
}
 
}
  
// register as onload function (there must be a better way)
+
if ( mw.config.get( 'wgNamespaceNumber' ) === 0 ) {
if (window.addEventListener) {
+
    $( function () {
     window.addEventListener("load", ls_applyDefaultLanguageSelect, false);
+
        if ( document.getElementById( 'disambigbox' ) ) {
} else if (window.attachEvent) {
+
            addEditIntro( 'Template:Disambig_editintro' );
     window.attachEvent("onload", ls_applyDefaultLanguageSelect);
+
        }
 +
     } );
 +
 
 +
    $( function () {
 +
        var cats = mw.config.get('wgCategories');
 +
        if ( !cats ) {
 +
            return;
 +
        }
 +
        if ( $.inArray( 'Living people', cats ) !== -1 || $.inArray( 'Possibly living people', cats ) !== -1 ) {
 +
            addEditIntro( 'Template:BLP_editintro' );
 +
        }
 +
     } );
 
}
 
}
 +
 +
/* End of mw.loader.using callback */
 +
} );
 +
/* DO NOT ADD CODE BELOW THIS LINE */

Latest revision as of 10:17, 28 June 2015

/**
 * Keep code in MediaWiki:Common.js to a minimum as it is unconditionally
 * loaded for all users on every wiki page. If possible create a gadget that is
 * enabled by default instead of adding it here (since gadgets are fully
 * optimized ResourceLoader modules with possibility to add dependencies etc.)
 *
 * Since Common.js isn't a gadget, there is no place to declare its
 * dependencies, so we have to lazy load them with mw.loader.using on demand and
 * then execute the rest in the callback. In most cases these dependencies will
 * be loaded (or loading) already and the callback will not be delayed. In case a
 * dependency hasn't arrived yet it'll make sure those are loaded before this.
 */

/* global mw, $, importStylesheet, importScript */
/* jshint strict:false, browser:true */

mw.loader.using( ['mediawiki.util', 'mediawiki.notify', 'jquery.client'] ).done( function () {
/* Begin of mw.loader.using callback */

/**
 * Main Page layout fixes
 *
 * Description: Adds an additional link to the complete list of languages available.
 * Maintainers: [[User:AzaToth]], [[User:R. Koot]], [[User:Alex Smotrov]]
 */
if ( mw.config.get( 'wgPageName' ) === 'Main_Page' || mw.config.get( 'wgPageName' ) === 'Talk:Main_Page' ) {
    $( function () {
        mw.util.addPortletLink( 'p-lang', '//meta.wikimedia.org/wiki/List_of_Wikipedias',
            'Complete list', 'interwiki-completelist', 'Complete list of Wikipedias' );
    } );
}

/**
 * Redirect User:Name/skin.js and skin.css to the current skin's pages
 * (unless the 'skin' page really exists)
 * @source: http://www.mediawiki.org/wiki/Snippets/Redirect_skin.js
 * @rev: 2
 */
if ( mw.config.get( 'wgArticleId' ) === 0 && mw.config.get( 'wgNamespaceNumber' ) === 2 ) {
    var titleParts = mw.config.get( 'wgPageName' ).split( '/' );
    /* Make sure there was a part before and after the slash
       and that the latter is 'skin.js' or 'skin.css' */
    if ( titleParts.length == 2 ) {
        var userSkinPage = titleParts.shift() + '/' + mw.config.get( 'skin' );
        if ( titleParts.slice( -1 ) == 'skin.js' ) {
            window.location.href = mw.util.getUrl( userSkinPage + '.js' );
        } else if ( titleParts.slice( -1 ) == 'skin.css' ) {
            window.location.href = mw.util.getUrl( userSkinPage + '.css' );
        }
    }
}

/**
 * Map addPortletLink to mw.util
 * @deprecated: Use mw.util.addPortletLink instead.
 */
mw.log.deprecate( window, 'addPortletLink', mw.util.addPortletLink, 'Use mw.util.addPortletLink instead' );

/**
 * Extract a URL parameter from the current URL
 * @deprecated: Use mw.util.getParamValue with proper escaping
 */
mw.log.deprecate( window, 'getURLParamValue', mw.util.getParamValue, 'Use mw.util.getParamValue instead' );

/**
 * Test if an element has a certain class
 * @deprecated:  Use $(element).hasClass() instead.
 */
mw.log.deprecate( window, 'hasClass', function ( element, className ) {
    return $( element ).hasClass( className );
}, 'Use jQuery.hasClass() instead' );

/**
 * @source www.mediawiki.org/wiki/Snippets/Load_JS_and_CSS_by_URL
 * @rev 6
 */
var extraCSS = mw.util.getParamValue( 'withCSS' ),
    extraJS = mw.util.getParamValue( 'withJS' );

if ( extraCSS ) {
    if ( extraCSS.match( /^MediaWiki:[^&<>=%#]*\.css$/ ) ) {
        importStylesheet( extraCSS );
    } else {
        mw.notify( 'Only pages from the MediaWiki namespace are allowed.', { title: 'Invalid withCSS value' } );
    }
}

if ( extraJS ) {
    if ( extraJS.match( /^MediaWiki:[^&<>=%#]*\.js$/ ) ) {
        importScript( extraJS );
    } else {
        mw.notify( 'Only pages from the MediaWiki namespace are allowed.', { title: 'Invalid withJS value' } );
    }
}

/**
 * Import more specific scripts if necessary
 */
if ( mw.config.get( 'wgAction' ) === 'edit' || mw.config.get( 'wgAction' ) === 'submit' || mw.config.get( 'wgCanonicalSpecialPageName' ) === 'Upload' ) {
    /* scripts specific to editing pages */
    importScript( 'MediaWiki:Common.js/edit.js' );
} else if ( mw.config.get( 'wgCanonicalSpecialPageName' ) === 'Watchlist' ) {
    /* watchlist scripts */
    importScript( 'MediaWiki:Common.js/watchlist.js' );
}
if ( mw.config.get( 'wgNamespaceNumber' ) === 6 ) {
    /* file description page scripts */
    importScript( 'MediaWiki:Common.js/file.js' );
}

/**
 * Helper script for .hlist class in Common.css
 * Add pseudo-selector class to last-child list items in IE8
 * @source mediawiki.org/wiki/Snippets/Horizontal_lists
 * @revision 6 (2014-08-23)
 * @author [[User:Edokter]]
 */
( function ( mw, $ ) {
    var profile = $.client.profile();
    if ( profile.name === 'msie' && profile.versionNumber === 8 ) {
        mw.hook( 'wikipage.content' ).add( function ( $content ) {
            $content.find( '.hlist' ).find( 'dd:last-child, dt:last-child, li:last-child' )
                .addClass( 'hlist-last-child' );
        } );
    }
}( mediaWiki, jQuery ) );

/**
 * Fix for Windows XP Unicode font rendering
 */
if ( navigator.appVersion.search(/windows nt 5/i) !== -1 ) {
    mw.util.addCSS( '.IPA { font-family: "Lucida Sans Unicode", "Arial Unicode MS"; } ' +
                '.Unicode { font-family: "Arial Unicode MS", "Lucida Sans Unicode"; } ' );
}

/**
 * WikiMiniAtlas
 *
 * Description: WikiMiniAtlas is a popup click and drag world map.
 *              This script causes all of our coordinate links to display the WikiMiniAtlas popup button.
 *              The script itself is located on meta because it is used by many projects.
 *              See [[Meta:WikiMiniAtlas]] for more information.
 * Maintainers: [[User:Dschwen]]
 */
( function () {
    var require_wikiminiatlas = false;
    var coord_filter = /geohack/;
    $( function () {
        $( 'a.external.text' ).each( function( key, link ) {
            if ( link.href && coord_filter.exec( link.href ) ) {
                require_wikiminiatlas = true;
                // break from loop
                return false;
            }
        } );
        if ( $( 'div.kmldata' ).length ) {
            require_wikiminiatlas = true;
        }
        if ( require_wikiminiatlas ) {
            mw.loader.load( '//meta.wikimedia.org/w/index.php?title=MediaWiki:Wikiminiatlas.js&action=raw&ctype=text/javascript' );
        }
    } );
} )();

/**
 * Collapsible tables
 *
 * Allows tables to be collapsed, showing only the header. See [[Wikipedia:NavFrame]].
 *
 * @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;

    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 = Rows[0].style.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 );

/**
 * Dynamic Navigation Bars (experimental)
 *
 * Description: See [[Wikipedia: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 < div >-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 );

/**
 * Uploadwizard_newusers
 * Switches in a message for non-autoconfirmed users at [[Wikipedia:Upload]]
 *
 * Maintainers: [[User:Krimpet]]
 */
function uploadwizard_newusers() {
    if ( mw.config.get( 'wgNamespaceNumber' ) === 4 && mw.config.get( 'wgTitle' ) === 'Upload' && mw.config.get( 'wgAction' ) === 'view' ) {
        var oldDiv = document.getElementById( 'autoconfirmedusers' ),
            newDiv = document.getElementById( 'newusers' );
        if ( oldDiv && newDiv ) {
            var userGroups = mw.config.get( 'wgUserGroups' );
            if ( userGroups ) {
                for ( var i = 0; i < userGroups.length; i++ ) {
                    if ( userGroups[i] === 'autoconfirmed' ) {
                        oldDiv.style.display = 'block';
                        newDiv.style.display = 'none';
                        return;
                    }
                }
            }
            oldDiv.style.display = 'none';
            newDiv.style.display = 'block';
            return;
        }
    }
}

$(uploadwizard_newusers);

/**
 * Magic editintros ****************************************************
 *
 * Description: Adds editintros on disambiguation pages and BLP pages.
 * Maintainers: [[User:RockMFR]]
 */
function addEditIntro( name ) {
    $( '.mw-editsection, #ca-edit' ).find( 'a' ).each( function ( i, el ) {
        el.href = $( this ).attr( 'href' ) + '&editintro=' + name;
    } );
}

if ( mw.config.get( 'wgNamespaceNumber' ) === 0 ) {
    $( function () {
        if ( document.getElementById( 'disambigbox' ) ) {
            addEditIntro( 'Template:Disambig_editintro' );
        }
    } );

    $( function () {
        var cats = mw.config.get('wgCategories');
        if ( !cats ) {
            return;
        }
        if ( $.inArray( 'Living people', cats ) !== -1 || $.inArray( 'Possibly living people', cats ) !== -1 ) {
            addEditIntro( 'Template:BLP_editintro' );
        }
    } );
}

/* End of mw.loader.using callback */
} );
/* DO NOT ADD CODE BELOW THIS LINE */