Difference between revisions of "MediaWiki:Common.js"

From Wikimedia UK
Jump to navigation Jump to search
(mw.util.addCSS)
(`mw.loader.using(["mediawiki.util"])`)
 
Line 2: Line 2:
  
 
/*<source lang="javascript">*/
 
/*<source lang="javascript">*/
 +
/* global mw, $ */
 +
/* jshint strict:false, browser:true */
  
/*
+
mw.loader.using(["mediawiki.util"]).done(function () {
* Description: Add the signature button to namespace 0 (main/default namespace)
+
  /* Start of mw.loader.using callback */
* Originally written by Roan (Catrope)
 
*/
 
jQuery( document ).ready( function() {
 
if ( !( 'wikiEditor' in jQuery ) || !jQuery.wikiEditor.isSupported( jQuery.wikiEditor.modules.toolbar ) ) {
 
return;
 
}
 
 
jQuery( '#wpTextbox1' ).wikiEditor( 'addToToolbar', { section: 'main', group: 'insert', tools: { 'signature-ns0': {
 
'labelMsg': 'wikieditor-toolbar-tool-signature',
 
'filters': [ 'body.ns-0' ], // ONLY ns 0
 
'type': 'button',
 
'offset': [2, -1872],
 
'icon': 'insert-signature.png',
 
'action': {
 
'type': 'encapsulate',
 
'options': {
 
'pre': '--~~' + '~~'
 
}
 
}
 
}
 
} } );
 
} );
 
  
/**
+
  /*
* Collapsible tables *********************************************************
+
  * Description: Add the signature button to namespace 0 (main/default namespace)
*
+
  * Originally written by Roan (Catrope)
* Description: Allows tables to be collapsed, showing only the header. See
+
  */
*             [[Wikipedia:NavFrame]].
+
  jQuery(document).ready(function () {
* Maintainers: [[User:R. Koot]]
+
     if (
*/
+
      !("wikiEditor" in jQuery) ||
+
      !jQuery.wikiEditor.isSupported(jQuery.wikiEditor.modules.toolbar)
var autoCollapse = 2;
+
     ) {
var collapseCaption = 'hide';
+
      return;
var expandCaption = 'show';
 
 
window.collapseTable = function ( tableIndex ) {
 
     var Button = document.getElementById( 'collapseButton' + tableIndex );
 
    var Table = document.getElementById( 'collapsibleTable' + tableIndex );
 
 
     if ( !Table || !Button ) {
 
        return false;
 
 
     }
 
     }
+
 
 +
    jQuery("#wpTextbox1").wikiEditor("addToToolbar", {
 +
      section: "main",
 +
      group: "insert",
 +
      tools: {
 +
        "signature-ns0": {
 +
          labelMsg: "wikieditor-toolbar-tool-signature",
 +
          filters: ["body.ns-0"], // ONLY ns 0
 +
          type: "button",
 +
          offset: [2, -1872],
 +
          icon: "insert-signature.png",
 +
          action: {
 +
            type: "encapsulate",
 +
            options: {
 +
              pre: "--~~" + "~~",
 +
            },
 +
          },
 +
        },
 +
      },
 +
    });
 +
  });
 +
 
 +
  /**
 +
  * Collapsible tables *********************************************************
 +
  *
 +
  * Description: Allows tables to be collapsed, showing only the header. See
 +
  *              [[Wikipedia:NavFrame]].
 +
  * Maintainers: [[User:R. Koot]]
 +
  */
 +
 
 +
  var autoCollapse = 2;
 +
  var collapseCaption = "hide";
 +
  var expandCaption = "show";
 +
 
 +
  window.collapseTable = function (tableIndex) {
 +
    var Button = document.getElementById("collapseButton" + tableIndex);
 +
    var Table = document.getElementById("collapsibleTable" + tableIndex);
 +
 
 +
    if (!Table || !Button) {
 +
      return false;
 +
    }
 +
 
 
     var Rows = Table.rows;
 
     var Rows = Table.rows;
 
     var i;
 
     var i;
+
 
     if ( Button.firstChild.data === collapseCaption ) {
+
     if (Button.firstChild.data === collapseCaption) {
        for ( i = 1; i < Rows.length; i++ ) {
+
      for (i = 1; i < Rows.length; i++) {
            Rows[i].style.display = 'none';
+
        Rows[i].style.display = "none";
        }
+
      }
        Button.firstChild.data = expandCaption;
+
      Button.firstChild.data = expandCaption;
 
     } else {
 
     } else {
        for ( i = 1; i < Rows.length; i++ ) {
+
      for (i = 1; i < Rows.length; i++) {
            Rows[i].style.display = Rows[0].style.display;
+
        Rows[i].style.display = Rows[0].style.display;
        }
+
      }
        Button.firstChild.data = collapseCaption;
+
      Button.firstChild.data = collapseCaption;
 
     }
 
     }
};
+
  };
+
 
function createCollapseButtons() {
+
  function createCollapseButtons() {
 
     var tableIndex = 0;
 
     var tableIndex = 0;
 
     var NavigationBoxes = {};
 
     var NavigationBoxes = {};
     var Tables = document.getElementsByTagName( 'table' );
+
     var Tables = document.getElementsByTagName("table");
 
     var i;
 
     var i;
+
 
     function handleButtonLink( index, e ) {
+
     function handleButtonLink(index, e) {
        window.collapseTable( index );
+
      window.collapseTable(index);
        e.preventDefault();
+
      e.preventDefault();
 
     }
 
     }
+
 
     for ( i = 0; i < Tables.length; i++ ) {
+
     for (i = 0; i < Tables.length; i++) {
        if ( $( Tables[i] ).hasClass( 'collapsible' ) ) {
+
      if ($(Tables[i]).hasClass("collapsible")) {
+
        /* only add button and increment count if there is a header row to work with */
            /* only add button and increment count if there is a header row to work with */
+
        var HeaderRow = Tables[i].getElementsByTagName("tr")[0];
            var HeaderRow = Tables[i].getElementsByTagName( 'tr' )[0];
+
        if (!HeaderRow) continue;
            if ( !HeaderRow ) continue;
+
        var Header = HeaderRow.getElementsByTagName("th")[0];
            var Header = HeaderRow.getElementsByTagName( 'th' )[0];
+
        if (!Header) continue;
            if ( !Header ) continue;
+
 
+
        NavigationBoxes[tableIndex] = Tables[i];
            NavigationBoxes[ tableIndex ] = Tables[i];
+
        Tables[i].setAttribute("id", "collapsibleTable" + tableIndex);
            Tables[i].setAttribute( 'id', 'collapsibleTable' + tableIndex );
+
 
+
        var Button = document.createElement("span");
            var Button     = document.createElement( 'span' );
+
        var ButtonLink = document.createElement("a");
            var ButtonLink = document.createElement( 'a' );
+
        var ButtonText = document.createTextNode(collapseCaption);
            var ButtonText = document.createTextNode( collapseCaption );
+
 
+
        Button.className =
            Button.className = 'collapseButton'; /* Styles are declared in Common.css */
+
          "collapseButton"; /* Styles are declared in Common.css */
+
 
            ButtonLink.style.color = Header.style.color;
+
        ButtonLink.style.color = Header.style.color;
            ButtonLink.setAttribute( 'id', 'collapseButton' + tableIndex );
+
        ButtonLink.setAttribute("id", "collapseButton" + tableIndex);
            ButtonLink.setAttribute( 'href', '#' );
+
        ButtonLink.setAttribute("href", "#");
            $( ButtonLink ).on( 'click', $.proxy( handleButtonLink, ButtonLink, tableIndex ) );
+
        $(ButtonLink).on(
            ButtonLink.appendChild( ButtonText );
+
          "click",
+
          $.proxy(handleButtonLink, ButtonLink, tableIndex)
            Button.appendChild( document.createTextNode( '[' ) );
+
        );
            Button.appendChild( ButtonLink );
+
        ButtonLink.appendChild(ButtonText);
            Button.appendChild( document.createTextNode( ']' ) );
+
 
+
        Button.appendChild(document.createTextNode("["));
            Header.insertBefore( Button, Header.firstChild );
+
        Button.appendChild(ButtonLink);
            tableIndex++;
+
        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"))
 +
      ) {
 +
        window.collapseTable(i);
 +
      } else if ($(NavigationBoxes[i]).hasClass("innercollapse")) {
 +
        var element = NavigationBoxes[i];
 +
        while ((element = element.parentNode)) {
 +
          if ($(element).hasClass("outercollapse")) {
 +
            window.collapseTable(i);
 +
            break;
 +
          }
 
         }
 
         }
 +
      }
 
     }
 
     }
+
  }
    for ( i = 0;  i < tableIndex; i++ ) {
+
 
        if ( $( NavigationBoxes[i] ).hasClass( 'collapsed' ) || ( tableIndex >= autoCollapse && $( NavigationBoxes[i] ).hasClass( 'autocollapse' ) ) ) {
+
  mw.hook("wikipage.content").add(createCollapseButtons);
            window.collapseTable( i );
+
 
        }
+
  //Shuffle for election candidates
        else if ( $( NavigationBoxes[i] ).hasClass ( 'innercollapse' ) ) {
+
  function dshuf() {
            var element = NavigationBoxes[i];
+
    var shufsets = {};
            while ((element = element.parentNode)) {
+
    var rx = new RegExp("dshuf" + "\\s+(dshufset\\d+)", "i");
                if ( $( element ).hasClass( 'outercollapse' ) ) {
+
    var divs = document.getElementsByTagName("div");
                    window.collapseTable ( i );
+
    var i = divs.length;
                    break;
+
    while (i--) {
                }
+
      if (rx.test(divs[i].className)) {
            }
+
        if (typeof shufsets[RegExp.$1] == "undefined") {
 +
          shufsets[RegExp.$1] = {};
 +
          shufsets[RegExp.$1].inner = [];
 +
          shufsets[RegExp.$1].member = [];
 
         }
 
         }
 +
        shufsets[RegExp.$1].inner.push({
 +
          key: Math.random(),
 +
          html: divs[i].innerHTML,
 +
        });
 +
        shufsets[RegExp.$1].member.push(divs[i]);
 +
      }
 +
    }
 +
    for (shufset in shufsets) {
 +
      shufsets[shufset].inner.sort(function (a, b) {
 +
        return a.key - b.key;
 +
      });
 +
      i = shufsets[shufset].member.length;
 +
      while (i--) {
 +
        shufsets[shufset].member[i].innerHTML = shufsets[shufset].inner[i].html;
 +
        shufsets[shufset].member[i].style.display = "block";
 +
      }
 
     }
 
     }
}
+
  }
+
  $(dshuf);
mw.hook( 'wikipage.content' ).add( createCollapseButtons );
 
  
//Shuffle for election candidates
+
  /**
function dshuf() {
+
  * AJAX transclusion table [[m:User:Pathoschild/Scripts/AJAX_transclusion_table]]
var shufsets = {};
+
  * by [[m:User:Pathoschild]]
var rx = new RegExp('dshuf' + '\\s+(dshufset\\d+)', 'i');
+
  */
var divs = document.getElementsByTagName('div');
+
  function attLoader() {
var i = divs.length;
+
    if (
while (i--) {
+
      document.getElementsByClassName(
  if (rx.test(divs[i].className)) {
+
        document.getElementsByTagName("body")[0],
  if (typeof shufsets[RegExp.$1] == 'undefined') {
+
        "table",
    shufsets[RegExp.$1] = {};
+
        "attable"
    shufsets[RegExp.$1].inner = [];
+
      ).length
     shufsets[RegExp.$1].member = [];
+
     ) {
  }
+
      importScript("User:Pathoschild/Scripts/AJAX_transclusion_table.js");
  shufsets[RegExp.$1].inner.push({
+
     }
    key: Math.random(),
 
     html: divs[i].innerHTML
 
  });
 
  shufsets[RegExp.$1].member.push(divs[i]);
 
 
   }
 
   }
  }
+
  $(attLoader);
  for (shufset in shufsets) {
+
 
  shufsets[shufset].inner.sort(function (a, b) {
+
  /** JSconfig ************
  return a.key - b.key;
+
  * Global configuration options to enable/disable and configure
  });
+
  * specific script features from [[MediaWiki:Common.js]] and
  i = shufsets[shufset].member.length;
+
  * [[MediaWiki:Monobook.js]]
  while (i--) {
+
  * This framework adds config options (saved as cookies) to [[Special:Preferences]]
  shufsets[shufset].member[i].innerHTML = shufsets[shufset].inner[i].html;
+
  * For a more permanent change you can override the default settings in your
  shufsets[shufset].member[i].style.display = 'block';
+
  * [[Special:Mypage/monobook.js]]
  }
+
  * for Example: JSconfig.keys[loadAutoInformationTemplate] = false;
}
+
  *
}
+
  * Maintainer: [[User:Dschwen]]
$(dshuf);
+
  */
 +
 
 +
  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();
* AJAX transclusion table [[m:User:Pathoschild/Scripts/AJAX_transclusion_table]]
+
   $(JSconfig.setUpForm);
* by [[m:User:Pathoschild]]
 
*/
 
function attLoader() {
 
   if ( document.getElementsByClassName( document.getElementsByTagName('body')[0], 'table', 'attable' ).length ) {
 
    importScript( 'User:Pathoschild/Scripts/AJAX_transclusion_table.js' );
 
   }
 
}
 
$( attLoader );
 
  
/** JSconfig ************
+
  // ability to pull [[MediaWiki:Gadget-rtl.css]] on individual page loads by [[testwiki:User:Splarka]] and [[wm2008:User:Mr.Z-man]]
* Global configuration options to enable/disable and configure
+
   function importStylesheet(page) {
* specific script features from [[MediaWiki:Common.js]] and
+
    if (
* [[MediaWiki:Monobook.js]]
+
      page.indexOf("http://") === -1 &&
* This framework adds config options (saved as cookies) to [[Special:Preferences]]
+
      page.indexOf("https://") === -1 &&
* For a more permanent change you can override the default settings in your
+
      page.indexOf("//") !== 0 &&
* [[Special:Mypage/monobook.js]]
+
      page.indexOf("file:///") == -1
* for Example: JSconfig.keys[loadAutoInformationTemplate] = false;
+
    ) {
*
+
      page =
*  Maintainer: [[User:Dschwen]]
+
        wgScript +
*/
+
        "?action=raw&ctype=text/css&smaxage=0&title=" +
+
        encodeURIComponent(page.replace(/ /g, "_"));
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;
 
 
     }
 
     }
  }
+
    return document.createStyleSheet
 +
      ? document.createStyleSheet(page)
 +
      : mw.util.addCSS('@import "' + page + '";');
 
   }
 
   }
 
  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();
 
$( JSconfig.setUpForm );
 
  
// ability to pull [[MediaWiki:Gadget-rtl.css]] on individual page loads by [[testwiki:User:Splarka]] and [[wm2008:User:Mr.Z-man]]
+
   if (document.URL.indexOf("rtl=1") != -1)
function importStylesheet(page) {
+
    importStylesheet(
   if (page.indexOf('http://') === -1 && page.indexOf('https://') === -1 && page.indexOf('//') !== 0 && page.indexOf('file:///') == -1) {
+
      "//meta.wikimedia.org/w/index.php?title=MediaWiki:Gadget-rtl.css&action=raw&ctype=text/css"
    page = wgScript + '?action=raw&ctype=text/css&smaxage=0&title='
+
    );
    + encodeURIComponent(page.replace(/ /g,'_'));
 
  }
 
  return document.createStyleSheet ? document.createStyleSheet(page) : mw.util.addCSS('@import "' + page + '";')
 
}
 
 
if(document.URL.indexOf('rtl=1') != -1) importStylesheet('//meta.wikimedia.org/w/index.php?title=MediaWiki:Gadget-rtl.css&action=raw&ctype=text/css');
 
  
// Fix links like User:Example@somewiki. Author: VasilievVV, with modifications by Kalan and attempted rewrite by Splarka
+
  // Fix links like User:Example@somewiki. Author: VasilievVV, with modifications by Kalan and attempted rewrite by Splarka
if((typeof(disableInterlinkLogs) == 'undefined' || disableInterlinkLogs == false) && (wgCanonicalSpecialPageName == 'Log' || wgCanonicalSpecialPageName == 'Recentchanges'))
+
  if (
importScript('MediaWiki:Common.js/interlinker.js')
+
    (typeof disableInterlinkLogs == "undefined" ||
 +
      disableInterlinkLogs == false) &&
 +
    (wgCanonicalSpecialPageName == "Log" ||
 +
      wgCanonicalSpecialPageName == "Recentchanges")
 +
  )
 +
    importScript("MediaWiki:Common.js/interlinker.js");
  
$(function() {
+
  $(function () {
 
     //Set a default of anon-only global blocks
 
     //Set a default of anon-only global blocks
 
     //We don't want to override the user's request when they're specifying [?&]wpAnonOnly=[01] in the URL or
 
     //We don't want to override the user's request when they're specifying [?&]wpAnonOnly=[01] in the URL or
 
     //if we're loading up the block settings for an already-blocked IP (then you can't see whether the block was AO or not)
 
     //if we're loading up the block settings for an already-blocked IP (then you can't see whether the block was AO or not)
     if(wgCanonicalSpecialPageName == 'GlobalBlock' && window.wgUserGroups && wgUserGroups.join(' ').indexOf('steward') != -1){
+
     if (
        if (document.getElementById('mw-globalblock-expiry-other') != null) {
+
      wgCanonicalSpecialPageName == "GlobalBlock" &&
            var expiry = document.getElementById('mw-globalblock-expiry-other').value;
+
      window.wgUserGroups &&
            if ( expiry == "" && document.location.href.indexOf('wpAnonOnly=') == -1){
+
      wgUserGroups.join(" ").indexOf("steward") != -1
                document.getElementById('mw-globalblock-anon-only').checked = true;
+
    ) {
            }
+
      if (document.getElementById("mw-globalblock-expiry-other") != null) {
 +
        var expiry = document.getElementById(
 +
          "mw-globalblock-expiry-other"
 +
        ).value;
 +
        if (
 +
          expiry == "" &&
 +
          document.location.href.indexOf("wpAnonOnly=") == -1
 +
        ) {
 +
          document.getElementById("mw-globalblock-anon-only").checked = true;
 
         }
 
         }
 +
      }
 
     }
 
     }
});
+
  });
 +
 
 +
  // stolen from [[commons:MediaWiki:Common.js]] by [[commons:User:Remember the dot]] - thanks
 +
  // Import language-specific stylesheet, especially useful for languages like German that have (un)usual capitalization rules
 +
  //
 +
  importStylesheet("MediaWiki:" + skin + ".css/" + wgUserLanguage);
  
// stolen from [[commons:MediaWiki:Common.js]] by [[commons:User:Remember the dot]] - thanks
+
  //Multilingual description.js from commons
// Import language-specific stylesheet, especially useful for languages like German that have (un)usual capitalization rules
+
  mw.loader.load(
//
+
    "//commons.wikimedia.org/w/index.php?title=MediaWiki:Gadget-LanguageSelect.js&action=raw&ctype=text/javascript"
importStylesheet("MediaWiki:" + skin + ".css/" + wgUserLanguage);
+
  );
  
//Multilingual description.js from commons
+
  //Tabs
mw.loader.load('//commons.wikimedia.org/w/index.php?title=MediaWiki:Gadget-LanguageSelect.js&action=raw&ctype=text/javascript');
+
  mw.loader.load(
 +
    "/w/index.php?title=MediaWiki:Tabs.js&action=raw&ctype=text/javascript"
 +
  );
  
//Tabs
+
  // Www portal preview script
mw.loader.load('/w/index.php?title=MediaWiki:Tabs.js&action=raw&ctype=text/javascript');
+
  mw.loader.load(
 +
    "/w/index.php?title=User:Splarka/portalpreview.js&action=raw&ctype=text/javascript"
 +
  );
  
// Www portal preview script
+
  // Handle {{InterProject}}
mw.loader.load('/w/index.php?title=User:Splarka/portalpreview.js&action=raw&ctype=text/javascript');
+
  mw.loader.load(
 +
    "/w/index.php?title=MediaWiki:InterProject.js&action=raw&ctype=text/javascript"
 +
  );
  
// Handle {{InterProject}}
+
  /*
mw.loader.load('/w/index.php?title=MediaWiki:InterProject.js&action=raw&ctype=text/javascript');
+
  * Description: Stay on the secure server as much as possible
 +
  * Maintainers: [[User:TheDJ]]
 +
  */
 +
  if (wgServer == "https://secure.wikimedia.org") {
 +
    importScript("MediaWiki:Common.js/secure.js");
 +
  }
  
/*
+
  /* End of mw.loader.using callback */
* Description: Stay on the secure server as much as possible
+
});
* Maintainers: [[User:TheDJ]]
+
/* DO NOT ADD CODE BELOW THIS LINE */
*/
 
if(wgServer == 'https://secure.wikimedia.org') {
 
    importScript( 'MediaWiki:Common.js/secure.js');
 
}
 

Latest revision as of 13:28, 5 October 2021

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

/*<source lang="javascript">*/
/* global mw, $ */
/* jshint strict:false, browser:true */

mw.loader.using(["mediawiki.util"]).done(function () {
  /* Start of mw.loader.using callback */

  /*
   * Description: Add the signature button to namespace 0 (main/default namespace)
   * Originally written by Roan (Catrope)
   */
  jQuery(document).ready(function () {
    if (
      !("wikiEditor" in jQuery) ||
      !jQuery.wikiEditor.isSupported(jQuery.wikiEditor.modules.toolbar)
    ) {
      return;
    }

    jQuery("#wpTextbox1").wikiEditor("addToToolbar", {
      section: "main",
      group: "insert",
      tools: {
        "signature-ns0": {
          labelMsg: "wikieditor-toolbar-tool-signature",
          filters: ["body.ns-0"], // ONLY ns 0
          type: "button",
          offset: [2, -1872],
          icon: "insert-signature.png",
          action: {
            type: "encapsulate",
            options: {
              pre: "--~~" + "~~",
            },
          },
        },
      },
    });
  });

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

  var autoCollapse = 2;
  var collapseCaption = "hide";
  var expandCaption = "show";

  window.collapseTable = function (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 createCollapseButtons() {
    var tableIndex = 0;
    var NavigationBoxes = {};
    var Tables = document.getElementsByTagName("table");
    var i;

    function handleButtonLink(index, e) {
      window.collapseTable(index);
      e.preventDefault();
    }

    for (i = 0; i < Tables.length; i++) {
      if ($(Tables[i]).hasClass("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.className =
          "collapseButton"; /* Styles are declared in Common.css */

        ButtonLink.style.color = Header.style.color;
        ButtonLink.setAttribute("id", "collapseButton" + tableIndex);
        ButtonLink.setAttribute("href", "#");
        $(ButtonLink).on(
          "click",
          $.proxy(handleButtonLink, ButtonLink, 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"))
      ) {
        window.collapseTable(i);
      } else if ($(NavigationBoxes[i]).hasClass("innercollapse")) {
        var element = NavigationBoxes[i];
        while ((element = element.parentNode)) {
          if ($(element).hasClass("outercollapse")) {
            window.collapseTable(i);
            break;
          }
        }
      }
    }
  }

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

  //Shuffle for election candidates
  function dshuf() {
    var shufsets = {};
    var rx = new RegExp("dshuf" + "\\s+(dshufset\\d+)", "i");
    var divs = document.getElementsByTagName("div");
    var i = divs.length;
    while (i--) {
      if (rx.test(divs[i].className)) {
        if (typeof shufsets[RegExp.$1] == "undefined") {
          shufsets[RegExp.$1] = {};
          shufsets[RegExp.$1].inner = [];
          shufsets[RegExp.$1].member = [];
        }
        shufsets[RegExp.$1].inner.push({
          key: Math.random(),
          html: divs[i].innerHTML,
        });
        shufsets[RegExp.$1].member.push(divs[i]);
      }
    }
    for (shufset in shufsets) {
      shufsets[shufset].inner.sort(function (a, b) {
        return a.key - b.key;
      });
      i = shufsets[shufset].member.length;
      while (i--) {
        shufsets[shufset].member[i].innerHTML = shufsets[shufset].inner[i].html;
        shufsets[shufset].member[i].style.display = "block";
      }
    }
  }
  $(dshuf);

  /**
   * AJAX transclusion table [[m:User:Pathoschild/Scripts/AJAX_transclusion_table]]
   * by [[m:User:Pathoschild]]
   */
  function attLoader() {
    if (
      document.getElementsByClassName(
        document.getElementsByTagName("body")[0],
        "table",
        "attable"
      ).length
    ) {
      importScript("User:Pathoschild/Scripts/AJAX_transclusion_table.js");
    }
  }
  $(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();
  $(JSconfig.setUpForm);

  // ability to pull [[MediaWiki:Gadget-rtl.css]] on individual page loads by [[testwiki:User:Splarka]] and [[wm2008:User:Mr.Z-man]]
  function importStylesheet(page) {
    if (
      page.indexOf("http://") === -1 &&
      page.indexOf("https://") === -1 &&
      page.indexOf("//") !== 0 &&
      page.indexOf("file:///") == -1
    ) {
      page =
        wgScript +
        "?action=raw&ctype=text/css&smaxage=0&title=" +
        encodeURIComponent(page.replace(/ /g, "_"));
    }
    return document.createStyleSheet
      ? document.createStyleSheet(page)
      : mw.util.addCSS('@import "' + page + '";');
  }

  if (document.URL.indexOf("rtl=1") != -1)
    importStylesheet(
      "//meta.wikimedia.org/w/index.php?title=MediaWiki:Gadget-rtl.css&action=raw&ctype=text/css"
    );

  // Fix links like User:Example@somewiki. Author: VasilievVV, with modifications by Kalan and attempted rewrite by Splarka
  if (
    (typeof disableInterlinkLogs == "undefined" ||
      disableInterlinkLogs == false) &&
    (wgCanonicalSpecialPageName == "Log" ||
      wgCanonicalSpecialPageName == "Recentchanges")
  )
    importScript("MediaWiki:Common.js/interlinker.js");

  $(function () {
    //Set a default of anon-only global blocks
    //We don't want to override the user's request when they're specifying [?&]wpAnonOnly=[01] in the URL or
    //if we're loading up the block settings for an already-blocked IP (then you can't see whether the block was AO or not)
    if (
      wgCanonicalSpecialPageName == "GlobalBlock" &&
      window.wgUserGroups &&
      wgUserGroups.join(" ").indexOf("steward") != -1
    ) {
      if (document.getElementById("mw-globalblock-expiry-other") != null) {
        var expiry = document.getElementById(
          "mw-globalblock-expiry-other"
        ).value;
        if (
          expiry == "" &&
          document.location.href.indexOf("wpAnonOnly=") == -1
        ) {
          document.getElementById("mw-globalblock-anon-only").checked = true;
        }
      }
    }
  });

  // stolen from [[commons:MediaWiki:Common.js]] by [[commons:User:Remember the dot]] - thanks
  // Import language-specific stylesheet, especially useful for languages like German that have (un)usual capitalization rules
  //
  importStylesheet("MediaWiki:" + skin + ".css/" + wgUserLanguage);

  //Multilingual description.js from commons
  mw.loader.load(
    "//commons.wikimedia.org/w/index.php?title=MediaWiki:Gadget-LanguageSelect.js&action=raw&ctype=text/javascript"
  );

  //Tabs
  mw.loader.load(
    "/w/index.php?title=MediaWiki:Tabs.js&action=raw&ctype=text/javascript"
  );

  // Www portal preview script
  mw.loader.load(
    "/w/index.php?title=User:Splarka/portalpreview.js&action=raw&ctype=text/javascript"
  );

  // Handle {{InterProject}}
  mw.loader.load(
    "/w/index.php?title=MediaWiki:InterProject.js&action=raw&ctype=text/javascript"
  );

  /*
   * Description: Stay on the secure server as much as possible
   * Maintainers: [[User:TheDJ]]
   */
  if (wgServer == "https://secure.wikimedia.org") {
    importScript("MediaWiki:Common.js/secure.js");
  }

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