MediaWiki:Common.js: Difference between revisions
Jump to navigation
Jump to search
(appears that the divhide template is broken again, retracing my steps from 2008...) |
(updating to current version of Common.js from WP) |
||
Line 1: | Line 1: | ||
window.addPortletLink = mw.util.addPortletLink; | |||
// | /** extract a URL parameter from the current URL ********** | ||
* | |||
* @deprecated: Use mw.util.getParamValue with proper escaping | |||
*/ | |||
function getURLParamValue(paramName, url){ | |||
return mw.util.getParamValue(paramName, url); | |||
} | |||
/* | /** &withCSS= and &withJS= URL parameters ******* | ||
* Allow to try custom scripts from MediaWiki space | |||
if ( | * without editing personal .css or .js files | ||
{ | */ | ||
var extraCSS = mw.util.getParamValue("withCSS"); | |||
if ( extraCSS && extraCSS.match("^MediaWiki:[^&<>=%]*\.css$") ) { | |||
importStylesheet(extraCSS); | |||
} | } | ||
var extraJS = mw.util.getParamValue("withJS"); | |||
if ( extraJS && extraJS.match("^MediaWiki:[^&<>=%]*\.js$") ) { | |||
importScript(extraJS); | |||
{ | |||
importScript( | |||
} | } | ||
// makeCollapsible (remove when deployed) | |||
importStylesheet('MediaWiki:JQuery-makeCollapsible.css'); | |||
importScript('MediaWiki:JQuery-makeCollapsible.js'); | |||
// | /* Import more specific scripts if necessary */ | ||
if (wgAction == 'edit' || wgAction == 'submit' || wgPageName == 'Special:Upload') { //scripts specific to editing pages | |||
importScript('MediaWiki:Common.js/edit.js'); | |||
} | |||
else if (mw.config.get('wgPageName') == 'Special:Watchlist') { //watchlist scripts | |||
mw.loader.load(mw.config.get('wgServer') + mw.config.get('wgScript') + '?title=MediaWiki:Common.js/watchlist.js&action=raw&ctype=text/javascript&smaxage=21600&maxage=86400'); | |||
} | |||
/* Scripts specific to Internet Explorer */ | /* Scripts specific to Internet Explorer */ | ||
if (navigator.appName == 'Microsoft Internet Explorer'){ | |||
if (navigator.appName == | |||
{ | |||
/** Internet Explorer bug fix ************************************************** | /** Internet Explorer bug fix ************************************************** | ||
* | * | ||
Line 50: | Line 47: | ||
var docEl = document.documentElement; | var docEl = document.documentElement; | ||
function | var fixIEScroll = function() { | ||
if (!oldWidth || docEl.clientWidth > oldWidth) { | |||
if (!oldWidth || docEl.clientWidth > oldWidth) | |||
doFixIEScroll(); | doFixIEScroll(); | ||
else | } else { | ||
setTimeout(doFixIEScroll, 1); | setTimeout(doFixIEScroll, 1); | ||
} | |||
oldWidth = docEl.clientWidth; | oldWidth = docEl.clientWidth; | ||
} | }; | ||
function | var doFixIEScroll = function () { | ||
docEl.style.overflowX = (docEl.scrollWidth - docEl.clientWidth < 4) ? "hidden" : ""; | docEl.style.overflowX = (docEl.scrollWidth - docEl.clientWidth < 4) ? "hidden" : ""; | ||
} | }; | ||
document.attachEvent("onreadystatechange", fixIEScroll); | document.attachEvent("onreadystatechange", fixIEScroll); | ||
document.attachEvent("onresize", fixIEScroll); | document.attachEvent("onresize", fixIEScroll); | ||
// In print IE (7?) does not like line-height | |||
mw.util.addCSS( '@media print { sup, sub, p, .documentDescription { line-height: normal; }}'); | |||
// IE overflow bug | |||
mw.util.addCSS('div.overflowbugx { overflow-x: scroll !important; overflow-y: hidden !important; } div.overflowbugy { overflow-y: scroll !important; overflow-x: hidden !important; }'); | |||
// IE zoomfix | |||
// Use to fix right floating div/table inside tables | |||
mw.util.addCSS('.iezoomfix div, .iezoomfix table { zoom: 1;}'); | |||
// Import scripts specific to Internet Explorer 6 | |||
if (navigator.appVersion.substr(22, 1) == '6') { | |||
importScript('MediaWiki:Common.js/IE60Fixes.js'); | |||
//Import scripts specific to Internet Explorer 6 | |||
if (navigator.appVersion.substr(22, 1) == | |||
importScript( | |||
} | } | ||
} | } | ||
/* Test if an element has a certain class * | /* Test if an element has a certain class | ||
* Maintainers: [[User:Mike Dillon]], [[User:R. Koot]], [[User:SG]] | |||
* | * | ||
* | * @deprecated: Use $(element).hasClass() instead. | ||
*/ | */ | ||
Line 110: | Line 106: | ||
var expandCaption = "show"; | var expandCaption = "show"; | ||
function collapseTable( tableIndex ) | function collapseTable( tableIndex ){ | ||
{ | |||
var Button = document.getElementById( "collapseButton" + tableIndex ); | var Button = document.getElementById( "collapseButton" + tableIndex ); | ||
var Table = document.getElementById( "collapsibleTable" + tableIndex ); | var Table = document.getElementById( "collapsibleTable" + tableIndex ); | ||
Line 134: | Line 129: | ||
} | } | ||
function createCollapseButtons() | function createCollapseButtons(){ | ||
{ | |||
var tableIndex = 0; | var tableIndex = 0; | ||
var NavigationBoxes = new Object(); | var NavigationBoxes = new Object(); | ||
Line 156: | Line 150: | ||
var ButtonText = document.createTextNode( collapseCaption ); | var ButtonText = document.createTextNode( collapseCaption ); | ||
Button. | Button.className = "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", "#" ); | ||
addHandler( ButtonLink, "click", new Function( "evt", "collapseTable(" + tableIndex + " ); return killEvt( evt );") ); | |||
ButtonLink.appendChild( ButtonText ); | ButtonLink.appendChild( ButtonText ); | ||
Line 180: | Line 171: | ||
collapseTable( i ); | collapseTable( i ); | ||
} | } | ||
else if ( hasClass( NavigationBoxes[i], "innercollapse" ) ) { | |||
var element = NavigationBoxes[i]; | var element = NavigationBoxes[i]; | ||
while (element = element.parentNode) { | while (element = element.parentNode) { | ||
Line 188: | Line 179: | ||
} | } | ||
} | } | ||
} | } | ||
} | } | ||
} | } | ||
$( createCollapseButtons ); | |||
Line 208: | Line 199: | ||
// Parameters: | // Parameters: | ||
// indexNavigationBar: the index of navigation bar to be toggled | // indexNavigationBar: the index of navigation bar to be toggled | ||
function toggleNavigationBar(indexNavigationBar) | function toggleNavigationBar(indexNavigationBar){ | ||
{ | |||
var NavToggle = document.getElementById("NavToggle" + indexNavigationBar); | var NavToggle = document.getElementById("NavToggle" + indexNavigationBar); | ||
var NavFrame = document.getElementById("NavFrame" + indexNavigationBar); | var NavFrame = document.getElementById("NavFrame" + indexNavigationBar); | ||
Line 220: | Line 210: | ||
if (NavToggle.firstChild.data == NavigationBarHide) { | if (NavToggle.firstChild.data == NavigationBarHide) { | ||
for (var NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling) { | for (var NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling) { | ||
if ( hasClass( NavChild, ' | if (hasClass(NavChild, 'NavContent') || hasClass(NavChild, 'NavPic')) { | ||
NavChild.style.display = 'none'; | NavChild.style.display = 'none'; | ||
} | } | ||
Line 232: | Line 219: | ||
} else if (NavToggle.firstChild.data == NavigationBarShow) { | } else if (NavToggle.firstChild.data == NavigationBarShow) { | ||
for (var NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling) { | for (var NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling) { | ||
if (hasClass(NavChild, ' | if (hasClass(NavChild, 'NavContent') || hasClass(NavChild, 'NavPic')) { | ||
NavChild.style.display = 'block'; | NavChild.style.display = 'block'; | ||
} | } | ||
Line 244: | Line 228: | ||
// adds show/hide-button to navigation bars | // adds show/hide-button to navigation bars | ||
function createNavigationBarToggleButton() | function createNavigationBarToggleButton(){ | ||
{ | |||
var indexNavigationBar = 0; | var indexNavigationBar = 0; | ||
// iterate over all < div >-elements | // iterate over all < div >-elements | ||
Line 252: | Line 235: | ||
// if found a navigation bar | // if found a navigation bar | ||
if (hasClass(NavFrame, "NavFrame")) { | if (hasClass(NavFrame, "NavFrame")) { | ||
indexNavigationBar++; | indexNavigationBar++; | ||
var NavToggle = document.createElement("a"); | var NavToggle = document.createElement("a"); | ||
Line 258: | Line 241: | ||
NavToggle.setAttribute('id', 'NavToggle' + indexNavigationBar); | NavToggle.setAttribute('id', 'NavToggle' + indexNavigationBar); | ||
NavToggle.setAttribute('href', 'javascript:toggleNavigationBar(' + indexNavigationBar + ');'); | NavToggle.setAttribute('href', 'javascript:toggleNavigationBar(' + indexNavigationBar + ');'); | ||
var | var isCollapsed = hasClass( NavFrame, "collapsed" ); | ||
for (var NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling) { | /* | ||
* 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 ( hasClass( NavChild, 'NavPic' ) || hasClass( NavChild, 'NavContent' ) ) { | ||
if (NavChild.style.display == 'none') { | 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); | NavToggle.appendChild(NavToggleText); | ||
// Find the NavHead and attach the toggle link (Must be this complicated because Moz's firstChild handling is borked) | // 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++) { | for(var j=0; j < NavFrame.childNodes.length; j++) { | ||
if (hasClass(NavFrame.childNodes[j], "NavHead")) { | if (hasClass(NavFrame.childNodes[j], "NavHead")) { | ||
NavToggle.style.color = NavFrame.childNodes[j].style.color; | |||
NavFrame.childNodes[j].appendChild(NavToggle); | NavFrame.childNodes[j].appendChild(NavToggle); | ||
} | } | ||
Line 281: | Line 279: | ||
} | } | ||
$( createNavigationBarToggleButton ); | |||
Line 394: | Line 287: | ||
* Maintainers: [[User:Random832]] | * Maintainers: [[User:Random832]] | ||
*/ | */ | ||
ts_alternate_row_colors = false; | ts_alternate_row_colors = false; | ||
Line 402: | Line 294: | ||
* | * | ||
* Maintainers: [[User:Krimpet]] | * Maintainers: [[User:Krimpet]] | ||
*/ | |||
function uploadwizard_newusers() { | function uploadwizard_newusers() { | ||
if (wgNamespaceNumber == 4 && wgTitle == "Upload" && wgAction == "view") { | if (wgNamespaceNumber == 4 && wgTitle == "Upload" && wgAction == "view") { | ||
Line 423: | Line 315: | ||
} | } | ||
} | } | ||
$(uploadwizard_newusers); | |||
Revision as of 00:54, 5 June 2011
window.addPortletLink = mw.util.addPortletLink; /** extract a URL parameter from the current URL ********** * * @deprecated: Use mw.util.getParamValue with proper escaping */ function getURLParamValue(paramName, url){ return mw.util.getParamValue(paramName, url); } /** &withCSS= and &withJS= URL parameters ******* * Allow to try custom scripts from MediaWiki space * without editing personal .css or .js files */ var extraCSS = mw.util.getParamValue("withCSS"); if ( extraCSS && extraCSS.match("^MediaWiki:[^&<>=%]*\.css$") ) { importStylesheet(extraCSS); } var extraJS = mw.util.getParamValue("withJS"); if ( extraJS && extraJS.match("^MediaWiki:[^&<>=%]*\.js$") ) { importScript(extraJS); } // makeCollapsible (remove when deployed) importStylesheet('MediaWiki:JQuery-makeCollapsible.css'); importScript('MediaWiki:JQuery-makeCollapsible.js'); /* Import more specific scripts if necessary */ if (wgAction == 'edit' || wgAction == 'submit' || wgPageName == 'Special:Upload') { //scripts specific to editing pages importScript('MediaWiki:Common.js/edit.js'); } else if (mw.config.get('wgPageName') == 'Special:Watchlist') { //watchlist scripts mw.loader.load(mw.config.get('wgServer') + mw.config.get('wgScript') + '?title=MediaWiki:Common.js/watchlist.js&action=raw&ctype=text/javascript&smaxage=21600&maxage=86400'); } /* Scripts specific to Internet Explorer */ if (navigator.appName == 'Microsoft Internet Explorer'){ /** Internet Explorer bug fix ************************************************** * * Description: Fixes IE horizontal scrollbar bug * Maintainers: [[User:Tom-]]? */ var oldWidth; var docEl = document.documentElement; var fixIEScroll = function() { if (!oldWidth || docEl.clientWidth > oldWidth) { doFixIEScroll(); } else { setTimeout(doFixIEScroll, 1); } oldWidth = docEl.clientWidth; }; var doFixIEScroll = function () { docEl.style.overflowX = (docEl.scrollWidth - docEl.clientWidth < 4) ? "hidden" : ""; }; document.attachEvent("onreadystatechange", fixIEScroll); document.attachEvent("onresize", fixIEScroll); // In print IE (7?) does not like line-height mw.util.addCSS( '@media print { sup, sub, p, .documentDescription { line-height: normal; }}'); // IE overflow bug mw.util.addCSS('div.overflowbugx { overflow-x: scroll !important; overflow-y: hidden !important; } div.overflowbugy { overflow-y: scroll !important; overflow-x: hidden !important; }'); // IE zoomfix // Use to fix right floating div/table inside tables mw.util.addCSS('.iezoomfix div, .iezoomfix table { zoom: 1;}'); // Import scripts specific to Internet Explorer 6 if (navigator.appVersion.substr(22, 1) == '6') { importScript('MediaWiki:Common.js/IE60Fixes.js'); } } /* Test if an element has a certain class * Maintainers: [[User:Mike Dillon]], [[User:R. Koot]], [[User:SG]] * * @deprecated: Use $(element).hasClass() instead. */ var hasClass = (function () { var reCache = {}; return function (element, className) { return (reCache[className] ? reCache[className] : (reCache[className] = new RegExp("(?:\\s|^)" + className + "(?:\\s|$)"))).test(element.className); }; })(); /** Collapsible tables ********************************************************* * * Description: Allows tables to be collapsed, showing only the header. See * [[Wikipedia:NavFrame]]. * Maintainers: [[User:R. Koot]] */ var autoCollapse = 2; var collapseCaption = "hide"; var expandCaption = "show"; function collapseTable( tableIndex ){ var Button = document.getElementById( "collapseButton" + tableIndex ); var Table = document.getElementById( "collapsibleTable" + tableIndex ); if ( !Table || !Button ) { return false; } var Rows = Table.rows; if ( Button.firstChild.data == collapseCaption ) { for ( var i = 1; i < Rows.length; i++ ) { Rows[i].style.display = "none"; } Button.firstChild.data = expandCaption; } else { for ( var i = 1; i < Rows.length; i++ ) { Rows[i].style.display = Rows[0].style.display; } Button.firstChild.data = collapseCaption; } } function createCollapseButtons(){ var tableIndex = 0; var 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.childNodes[0] ); 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 function toggleNavigationBar(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 * Maintainers: [[User:Random832]] */ ts_alternate_row_colors = false; /***** uploadwizard_newusers ******** * Switches in a message for non-autoconfirmed users at [[Wikipedia:Upload]] * * Maintainers: [[User:Krimpet]] */ function uploadwizard_newusers() { if (wgNamespaceNumber == 4 && wgTitle == "Upload" && wgAction == "view") { var oldDiv = document.getElementById("autoconfirmedusers"), newDiv = document.getElementById("newusers"); if (oldDiv && newDiv) { if (typeof wgUserGroups == "object" && wgUserGroups) { for (i = 0; i < wgUserGroups.length; i++) { if (wgUserGroups[i] == "autoconfirmed") { oldDiv.style.display = "block"; newDiv.style.display = "none"; return; } } } oldDiv.style.display = "none"; newDiv.style.display = "block"; return; } } } $(uploadwizard_newusers);