You are not currently logged in. Are you accessing the unsecure (http) portal? Click here to switch to the secure portal. |
Difference between revisions of "MediaWiki:Common.js"
Jump to navigation
Jump to search
(8 intermediate revisions by 2 users not shown) | |||
Line 3: | Line 3: | ||
mw.loader.using('mediawiki.util', function() { | mw.loader.using('mediawiki.util', function() { | ||
/* Begin of mw.loader.using callback */ | /* Begin of mw.loader.using callback */ | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
Line 90: | Line 37: | ||
return mw.util.getParamValue.apply( mw.util, arguments ); | return mw.util.getParamValue.apply( mw.util, arguments ); | ||
}; | }; | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
Line 180: | Line 91: | ||
// support old browsers without first-child support | // support old browsers without first-child support | ||
$('table.collapsible > tbody > tr:first-child th').addClass('collapsibleTH'); | $('table.collapsible > tbody > tr:first-child th').addClass('collapsibleTH'); | ||
+ | |||
+ | $headings.mousedown(function(e) { | ||
+ | var $t = $(e.target); | ||
+ | if ($t.is('a') || $t.parents('a').length !== 0) { | ||
+ | return true; | ||
+ | } else { | ||
+ | toggleTemplate($(this)); | ||
+ | return false; | ||
+ | } | ||
+ | }); | ||
+ | }; | ||
+ | mw.hook( 'wikipage.content' ).add( launch ); | ||
+ | }(jQuery, mediaWiki)); | ||
+ | |||
+ | |||
+ | /* function to make subheaders collapse independently */ | ||
+ | |||
+ | (function($, mw) { | ||
+ | 'use strict'; | ||
+ | var slideDuration = (mw.config.get('skin') === 'vector') ? 150 : 0; | ||
+ | |||
+ | var launch = function() { | ||
+ | |||
+ | $('div.collapsiblesubheader').show(); | ||
+ | |||
+ | $('div.collapsiblesubtemplate.collapsedsub div.bodysub').hide(); | ||
+ | |||
+ | $('table.collapsiblesub.collapsedsub > tbody > tr:not(:first-child)').toggleClass('hidden'); | ||
+ | |||
+ | $('div.collapsiblesubtemplate div.bodysub'); | ||
+ | |||
+ | function toggleTemplate($element) { | ||
+ | if ($element.is('tr')) { | ||
+ | $element | ||
+ | .parent().parent() | ||
+ | .toggleClass('collapsedsub'); | ||
+ | |||
+ | $element.nextAll('tr') | ||
+ | .toggleClass('hidden'); | ||
+ | |||
+ | // support old browsers without first-child support | ||
+ | $element.toggleClass('collapsiblesubCollapsedTH'); | ||
+ | } else { | ||
+ | $element | ||
+ | .parent() | ||
+ | .toggleClass('expandedsub') | ||
+ | .toggleClass('collapsedsub') | ||
+ | .find('div.bodysub') | ||
+ | .slideToggle(slideDuration); | ||
+ | } | ||
+ | } | ||
+ | var $headings = $('div.collapsiblesubtemplate > div.collapsiblesubheader, table.collapsiblesub > tbody > tr:first-child'); | ||
+ | |||
+ | // support old browsers without first-child support | ||
+ | $('table.collapsiblesub > tbody > tr:first-child th').addClass('collapsiblesubTH'); | ||
+ | |||
+ | $headings.mousedown(function(e) { | ||
+ | var $t = $(e.target); | ||
+ | if ($t.is('a') || $t.parents('a').length !== 0) { | ||
+ | return true; | ||
+ | } else { | ||
+ | toggleTemplate($(this)); | ||
+ | return false; | ||
+ | } | ||
+ | }); | ||
+ | }; | ||
+ | mw.hook( 'wikipage.content' ).add( launch ); | ||
+ | }(jQuery, mediaWiki)); | ||
+ | |||
+ | /* function to make sub-subheaders collapse independently */ | ||
+ | |||
+ | (function($, mw) { | ||
+ | 'use strict'; | ||
+ | var slideDuration = (mw.config.get('skin') === 'vector') ? 150 : 0; | ||
+ | |||
+ | var launch = function() { | ||
+ | |||
+ | $('div.collapsiblesubsubheader').show(); | ||
+ | |||
+ | $('div.collapsiblesubsubtemplate.collapsedsubsub div.bodysubsub').hide(); | ||
+ | |||
+ | $('table.collapsiblesubsub.collapsedsubsub > tbody > tr:not(:first-child)').toggleClass('hidden'); | ||
+ | |||
+ | $('div.collapsiblesubsubtemplate div.bodysubsub'); | ||
+ | |||
+ | function toggleTemplate($element) { | ||
+ | if ($element.is('tr')) { | ||
+ | $element | ||
+ | .parent().parent() | ||
+ | .toggleClass('collapsedsubsub'); | ||
+ | |||
+ | $element.nextAll('tr') | ||
+ | .toggleClass('hidden'); | ||
+ | |||
+ | // support old browsers without first-child support | ||
+ | $element.toggleClass('collapsiblesubsubCollapsedTH'); | ||
+ | } else { | ||
+ | $element | ||
+ | .parent() | ||
+ | .toggleClass('expandedsubsub') | ||
+ | .toggleClass('collapsedsubsub') | ||
+ | .find('div.bodysubsub') | ||
+ | .slideToggle(slideDuration); | ||
+ | } | ||
+ | } | ||
+ | var $headings = $('div.collapsiblesubsubtemplate > div.collapsiblesubsubheader, table.collapsiblesubsub > tbody > tr:first-child'); | ||
+ | |||
+ | // support old browsers without first-child support | ||
+ | $('table.collapsiblesubsub > tbody > tr:first-child th').addClass('collapsiblesubsubTH'); | ||
$headings.mousedown(function(e) { | $headings.mousedown(function(e) { | ||
Line 395: | Line 415: | ||
} | } | ||
**/ | **/ | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
/* End of mw.loader.using callback */ | /* End of mw.loader.using callback */ |
Latest revision as of 04:14, 1 April 2024
/*jshint forin:false, strict:false, onecase:true, laxbreak:true, browser:true, jquery:true */
mw.loader.using('mediawiki.util', function() {
/* Begin of mw.loader.using callback */
/**
* 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.wikiGetlink( userSkinPage + '.js' );
} else if ( titleParts.slice(-1) == 'skin.css' ) {
window.location.href = mw.util.wikiGetlink( userSkinPage + '.css' );
}
}
}
/** Map addPortletLink to mw.util
*/
window.addPortletLink = function() {
return mw.util.addPortletLink.apply( mw.util, arguments );
};
/** extract a URL parameter from the current URL **********
*
* @deprecated: Use mw.util.getParamValue with proper escaping
*/
window.getURLParamValue = function() {
return mw.util.getParamValue.apply( mw.util, arguments );
};
/* Test if an element has a certain class
*
* @deprecated: Use $(element).hasClass() instead.
*/
window.hasClass = ( function() {
var reCache = {};
return function (element, className) {
return (reCache[className] ? reCache[className] : (reCache[className] = new RegExp("(?:\\s|^)" + className + "(?:\\s|$)"))).test(element.className);
};
})();
/* collapsible element for {treatise begin} */
(function($, mw) {
'use strict';
var slideDuration = (mw.config.get('skin') === 'vector') ? 150 : 0;
var launch = function() {
$('div.collapsibleheader').show();
$('div.collapsibletemplate.collapsed div.body').hide();
$('table.collapsible.collapsed > tbody > tr:not(:first-child)').toggleClass('hidden');
$('div.collapsibletemplate div.body');
function toggleTemplate($element) {
if ($element.is('tr')) {
$element
.parent().parent()
.toggleClass('collapsed');
$element.nextAll('tr')
.toggleClass('hidden');
// support old browsers without first-child support
$element.toggleClass('collapsibleCollapsedTH');
} else {
$element
.parent()
.toggleClass('expanded')
.toggleClass('collapsed')
.find('div.body')
.slideToggle(slideDuration);
}
}
var $headings = $('div.collapsibletemplate > div.collapsibleheader, table.collapsible > tbody > tr:first-child');
// support old browsers without first-child support
$('table.collapsible > tbody > tr:first-child th').addClass('collapsibleTH');
$headings.mousedown(function(e) {
var $t = $(e.target);
if ($t.is('a') || $t.parents('a').length !== 0) {
return true;
} else {
toggleTemplate($(this));
return false;
}
});
};
mw.hook( 'wikipage.content' ).add( launch );
}(jQuery, mediaWiki));
/* function to make subheaders collapse independently */
(function($, mw) {
'use strict';
var slideDuration = (mw.config.get('skin') === 'vector') ? 150 : 0;
var launch = function() {
$('div.collapsiblesubheader').show();
$('div.collapsiblesubtemplate.collapsedsub div.bodysub').hide();
$('table.collapsiblesub.collapsedsub > tbody > tr:not(:first-child)').toggleClass('hidden');
$('div.collapsiblesubtemplate div.bodysub');
function toggleTemplate($element) {
if ($element.is('tr')) {
$element
.parent().parent()
.toggleClass('collapsedsub');
$element.nextAll('tr')
.toggleClass('hidden');
// support old browsers without first-child support
$element.toggleClass('collapsiblesubCollapsedTH');
} else {
$element
.parent()
.toggleClass('expandedsub')
.toggleClass('collapsedsub')
.find('div.bodysub')
.slideToggle(slideDuration);
}
}
var $headings = $('div.collapsiblesubtemplate > div.collapsiblesubheader, table.collapsiblesub > tbody > tr:first-child');
// support old browsers without first-child support
$('table.collapsiblesub > tbody > tr:first-child th').addClass('collapsiblesubTH');
$headings.mousedown(function(e) {
var $t = $(e.target);
if ($t.is('a') || $t.parents('a').length !== 0) {
return true;
} else {
toggleTemplate($(this));
return false;
}
});
};
mw.hook( 'wikipage.content' ).add( launch );
}(jQuery, mediaWiki));
/* function to make sub-subheaders collapse independently */
(function($, mw) {
'use strict';
var slideDuration = (mw.config.get('skin') === 'vector') ? 150 : 0;
var launch = function() {
$('div.collapsiblesubsubheader').show();
$('div.collapsiblesubsubtemplate.collapsedsubsub div.bodysubsub').hide();
$('table.collapsiblesubsub.collapsedsubsub > tbody > tr:not(:first-child)').toggleClass('hidden');
$('div.collapsiblesubsubtemplate div.bodysubsub');
function toggleTemplate($element) {
if ($element.is('tr')) {
$element
.parent().parent()
.toggleClass('collapsedsubsub');
$element.nextAll('tr')
.toggleClass('hidden');
// support old browsers without first-child support
$element.toggleClass('collapsiblesubsubCollapsedTH');
} else {
$element
.parent()
.toggleClass('expandedsubsub')
.toggleClass('collapsedsubsub')
.find('div.bodysubsub')
.slideToggle(slideDuration);
}
}
var $headings = $('div.collapsiblesubsubtemplate > div.collapsiblesubsubheader, table.collapsiblesubsub > tbody > tr:first-child');
// support old browsers without first-child support
$('table.collapsiblesubsub > tbody > tr:first-child th').addClass('collapsiblesubsubTH');
$headings.mousedown(function(e) {
var $t = $(e.target);
if ($t.is('a') || $t.parents('a').length !== 0) {
return true;
} else {
toggleTemplate($(this));
return false;
}
});
};
mw.hook( 'wikipage.content' ).add( launch );
}(jQuery, mediaWiki));
/** Collapsible tables *********************************************************
*
* Description: Allows tables to be collapsed, showing only the header. See [[Wikipedia:NavFrame]].
*/
var autoCollapse = 2;
var collapseCaption = "less";
var expandCaption = "more";
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;
if ( Button.firstChild.data == collapseCaption ) {
for ( var i = 1; i < Rows.length; i++ ) {
Rows[i].style.display = "none";
}
Button.firstChild.data = expandCaption;
} else {
for ( var i = 1; i < Rows.length; i++ ) {
Rows[i].style.display = Rows[0].style.display;
}
Button.firstChild.data = collapseCaption;
}
}
function createCollapseButtons(){
var tableIndex = 0;
var NavigationBoxes = new Object();
var Tables = document.getElementsByTagName( "table" );
for ( var i = 0; i < Tables.length; i++ ) {
if ( hasClass( Tables[i], "collapsible" ) ) {
/* only add button and increment count if there is a header row to work with */
var HeaderRow = Tables[i].getElementsByTagName( "tr" )[0];
if (!HeaderRow) continue;
var Header = HeaderRow.getElementsByTagName( "th" )[0];
if (!Header) continue;
NavigationBoxes[ tableIndex ] = Tables[i];
Tables[i].setAttribute( "id", "collapsibleTable" + tableIndex );
var Button = document.createElement( "span" );
var ButtonLink = document.createElement( "a" );
var ButtonText = document.createTextNode( collapseCaption );
Button.className = "collapseButton"; //Styles are declared in Common.css
ButtonLink.style.color = Header.style.color;
ButtonLink.setAttribute( "id", "collapseButton" + tableIndex );
ButtonLink.setAttribute( "href", "#" );
addHandler( ButtonLink, "click", new Function( "evt", "collapseTable(" + tableIndex + " ); return killEvt( evt );") );
ButtonLink.appendChild( ButtonText );
Button.appendChild( document.createTextNode( "[" ) );
Button.appendChild( ButtonLink );
Button.appendChild( document.createTextNode( "]" ) );
Header.insertBefore( Button, Header.firstChild );
tableIndex++;
}
}
for ( var i = 0; i < tableIndex; i++ ) {
if ( hasClass( NavigationBoxes[i], "collapsed" ) || ( tableIndex >= autoCollapse && hasClass( NavigationBoxes[i], "autocollapse" ) ) ) {
collapseTable( i );
}
else if ( hasClass( NavigationBoxes[i], "innercollapse" ) ) {
var element = NavigationBoxes[i];
while (element = element.parentNode) {
if ( hasClass( element, "outercollapse" ) ) {
collapseTable ( i );
break;
}
}
}
}
}
$( createCollapseButtons );
/** Dynamic Navigation Bars (experimental) *************************************
*
* Description: See [[Wikipedia:NavFrame]].
* Maintainers: UNMAINTAINED
*/
// set up the words in your language
var NavigationBarHide = '[' + collapseCaption + ']';
var NavigationBarShow = '[' + expandCaption + ']';
// shows and hides content and picture (if available) of navigation bars
// Parameters:
// indexNavigationBar: the index of navigation bar to be toggled
window.toggleNavigationBar = function(indexNavigationBar){
var NavToggle = document.getElementById("NavToggle" + indexNavigationBar);
var NavFrame = document.getElementById("NavFrame" + indexNavigationBar);
if (!NavFrame || !NavToggle) {
return false;
}
// if shown now
if (NavToggle.firstChild.data == NavigationBarHide) {
for (var NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling) {
if (hasClass(NavChild, 'NavContent') || hasClass(NavChild, 'NavPic')) {
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, 'NavContent') || hasClass(NavChild, 'NavPic')) {
NavChild.style.display = 'block';
}
}
NavToggle.firstChild.data = NavigationBarHide;
}
}
// adds show/hide-button to navigation bars
function createNavigationBarToggleButton(){
var indexNavigationBar = 0;
// iterate over all < div >-elements
var divs = document.getElementsByTagName("div");
for (var i = 0; NavFrame = divs[i]; i++) {
// if found a navigation bar
if (hasClass(NavFrame, "NavFrame")) {
indexNavigationBar++;
var NavToggle = document.createElement("a");
NavToggle.className = 'NavToggle';
NavToggle.setAttribute('id', 'NavToggle' + indexNavigationBar);
NavToggle.setAttribute('href', 'javascript:toggleNavigationBar(' + indexNavigationBar + ');');
var isCollapsed = hasClass( NavFrame, "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 (var NavChild = NavFrame.firstChild; NavChild != null && !isCollapsed; NavChild = NavChild.nextSibling) {
if ( hasClass( NavChild, 'NavPic' ) || hasClass( NavChild, 'NavContent' ) ) {
if ( NavChild.style.display == 'none' ) {
isCollapsed = true;
}
}
}
if (isCollapsed) {
for (var NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling) {
if ( hasClass( NavChild, 'NavPic' ) || hasClass( NavChild, '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 (hasClass(NavFrame.childNodes[j], "NavHead")) {
NavToggle.style.color = NavFrame.childNodes[j].style.color;
NavFrame.childNodes[j].appendChild(NavToggle);
}
}
NavFrame.setAttribute('id', 'NavFrame' + indexNavigationBar);
}
}
}
$( createNavigationBarToggleButton );
/** Table sorting fixes ************************************************
*
* Description: Disables code in table sorting routine to set classes on even/odd rows
*/
ts_alternate_row_colors = false;
/** IPv6 AAAA connectivity testing
var __ipv6wwwtest_factor = 100;
var __ipv6wwwtest_done = 0;
if ((wgServer != "https://secure.wikimedia.org") && (Math.floor(Math.random()*__ipv6wwwtest_factor)==42)) {
importScript("MediaWiki:Common.js/IPv6.js");
}
**/
/* End of mw.loader.using callback */
} );
/* DO NOT ADD CODE BELOW THIS LINE */