MediaWiki:Common.js: Difference between revisions

From Freephile Wiki
installs Edittools -- whittled down version of code from wp
comment out the floating toolbar for VE because it's built-in
 
(24 intermediate revisions by 2 users not shown)
Line 1: Line 1:
/* Any JavaScript here will be loaded for all users on every page load. */
/* Any JavaScript here will be loaded for all users on every page load.*/  


/* This would be one way of enabling wikEd
/* Make the VisualEditor Sticky */
// install [[User:Cacycle/wikEd]] in-browser text editor
/* leverage jQuery for the selector and the sticky class from Chameleon?
document.write('<script type="text/javascript" src="'
This doesn't actually work properly
+ 'http://en.wikipedia.org/w/index.php?title=User:Cacycle/wikEd.js'
AND, the VE Toolbar is floating in Vector2022 skin
+ '&action=raw&ctype=text/javascript"></' + 'script>');
So, it's a bug? in Chameleon
$('.ve-ui-toolbar').addClass('sticky');
*/
*/


/** Matomo **/
  var _paq = window._paq || [];
  /* tracker methods like "setCustomDimension" should be called before "trackPageView" */
  _paq.push(['trackPageView']);
  _paq.push(['enableLinkTracking']);
  (function() {
    var u="//wiki.freephile.org/analytics/";
    _paq.push(['setTrackerUrl', u+'matomo.php']);
    _paq.push(['setSiteId', '1']);
    var d=document, g=d.createElement('script'), s=d.getElementsByTagName('script')[0];
    g.type='text/javascript'; g.async=true; g.defer=true; g.src=u+'matomo.js'; s.parentNode.insertBefore(g,s);
  })();
/** End Matomo **/


//<source lang="javascript">
/**
   
  * wikEd.js is a Gadget implemented at MediaWiki:Gadget-wikEd.js and in Special:Preferences
/* Import more specific scripts if necessary */
 
// install [[:Wikipedia:User:Cacycle/wikEd]] in-browser text editor
if (wgAction == "edit" || wgAction == "submit" || wgPageName == "Special:Upload") //scripts specific to editing pages
(function ()
{
{
importScript("MediaWiki:Common.js/edit.js")
var script = document.createElement('script');
}
script.src = '//en.wikipedia.org/w/index.php?title=User:Cacycle/wikEd.js&action=raw&ctype=text/javascript';
script.async = true;
document.getElementsByTagName('head')[0].appendChild(script);
}
) ();
*/


/*To add <script src="https://use.fontawesome.com/14c71d3de0.js"></script>
  we use load instead of the deprecated importScriptURI */
/* Test if an element has a certain class **************************************
mw.loader.load('//use.fontawesome.com/14c71d3de0.js');
*
* Description: Uses regular expressions and caching for better performance.
* Maintainers: [[User:Mike Dillon]], [[User:R. Koot]], [[User:SG]]
*/
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 *********************************************************
/**  
*
* Cusomize the sidebar for the Html2Wiki extension
* Description: Allows tables to be collapsed, showing only the header. See
* @see https://www.mediawiki.org/wiki/Manual:Interface/Sidebar
*               [[Wikipedia:NavFrame]].
* added by Greg Rundlett <info@eQuality-Tech.com>
* Maintainers: [[User:R. Koot]]
  */
*/
function isObject( obj ) {
        return typeof obj == 'object' && obj !== null;
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;
function isArray( obj ) {
        return isObject( obj ) && obj.constructor.toString().indexOf( 'Array' ) != -1;
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()
Array.prototype.Contains = function( element, strict ) {
{
        for( var i in this ) {
var tableIndex = 0;
                if( this[i] == element && !strict || this[i] === element ) {
var NavigationBoxes = new Object();
                        return true;
var Tables = document.getElementsByTagName( "table" );
                }
        }
for ( var i = 0; i < Tables.length; i++ ) {
        return false;
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", "javascript:collapseTable(" + tableIndex + ");" );
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++ ) {
function ModifySidebar( action, section, name, link ) {
if ( hasClass( NavigationBoxes[i], "collapsed" ) || ( tableIndex >= autoCollapse && hasClass( NavigationBoxes[i], "autocollapse" ) ) ) {
        try {
collapseTable( i );
                var target;
}
                switch ( section ) {
else if ( hasClass( NavigationBoxes[i], "innercollapse" ) ) {
                        case 'languages':
var element = NavigationBoxes[i];
                                target = 'p-lang';
while (element = element.parentNode) {
                                break;
if ( hasClass( element, "outercollapse" ) ) {
                        case 'toolbox':
collapseTable ( i );
                                target = 'p-tb';
break;
                                break;
}
                        case 'navigation':
}
                                target = 'p-navigation';
}
                                break;
}
                        default:
}
                                target = 'p-' + section;
                                break;
                }
   
   
addOnloadHook( createCollapseButtons );
                if ( action == 'add' ) {
                        var node = document.getElementById( target )
                                                          .getElementsByTagName( 'div' )[0]
                                                          .getElementsByTagName( 'ul' )[0];
   
   
                        var aNode = document.createElement( 'a' );
                        var liNode = document.createElement( 'li' );
   
   
/** Dynamic Navigation Bars (experimental) *************************************
                        aNode.appendChild( document.createTextNode( name ) );
*
                        aNode.setAttribute( 'href', link );
*  Description: See [[Wikipedia:NavFrame]].
                        liNode.appendChild( aNode );
*  Maintainers: UNMAINTAINED
                        liNode.className = 'plainlinks';
*/
                        node.appendChild( liNode );
                }
   
   
// set up the words in your language
                if ( action == 'remove' ) {
var NavigationBarHide = '[' + collapseCaption + ']';
                        var list = document.getElementById( target )
var NavigationBarShow = '[' + expandCaption + ']';
                                                          .getElementsByTagName( 'div' )[0]
                                                          .getElementsByTagName( 'ul' )[0];
   
   
// shows and hides content and picture (if available) of navigation bars
                        var listelements = list.getElementsByTagName( 'li' );
// 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) {
                        for ( var i = 0; i < listelements.length; i++ ) {
return false;
                                if (
}
                                        listelements[i].getElementsByTagName( 'a' )[0].innerHTML == name ||
                                        listelements[i].getElementsByTagName( 'a' )[0].href == link
// if shown now
                                )
if (NavToggle.firstChild.data == NavigationBarHide) {
                                {
for (var NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling) {
                                        list.removeChild( listelements[i] );
if ( hasClass( NavChild, 'NavPic' ) ) {
                                }
NavChild.style.display = 'none';
                        }
}
                }
if ( hasClass( NavChild, 'NavContent') ) {
NavChild.style.display = 'none';
}
}
NavToggle.firstChild.data = NavigationBarShow;
   
   
// if hidden now
        } catch( e ) {
} else if (NavToggle.firstChild.data == NavigationBarShow) {
                // let's just ignore what's happened
for (var NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling) {
                return;
if (hasClass(NavChild, 'NavPic')) {
        }
NavChild.style.display = 'block';
}
if (hasClass(NavChild, 'NavContent')) {
NavChild.style.display = 'block';
}
}
NavToggle.firstChild.data = NavigationBarHide;
}
}
}
/**
jQuery( document ).ready( function( $ ) {
// adds show/hide-button to navigation bars
        // adds [[Special:Html2Wiki]] to toolbox
function createNavigationBarToggleButton()
        ModifySidebar( 'add', 'toolbox', 'Import HTML', '/wiki/Special:Html2Wiki' );
{
} );
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")) {
NavFrame.childNodes[j].appendChild(NavToggle);
}
}
NavFrame.setAttribute('id', 'NavFrame' + indexNavigationBar);
}
}
}
addOnloadHook( 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;
}
}
}
addOnloadHook(uploadwizard_newusers);


// import the SubPages 'gadget' for all users. non-optional
/** Disambig editintro ********************************************************
/** See https://www.mediawiki.org/wiki/Extension:Gadgets/Scripts/SubPages.js **/
*
$( function () {
*  Description: Adds an editintro on disambiguation pages. Original code
var NSWithoutSubpages = [ -1, 6, 8, 12, 13, 14, 15, 104, 105 ];
*  located at [[User:RockMFR/disambigeditintro.js]].
if ( NSWithoutSubpages.indexOf( mw.config.get( 'wgNamespaceNumber' ) ) === -1 ) {
*
var subpagesLink = mw.util.getUrl( 'Special:PrefixIndex/' + mw.config.get( 'wgPageName' ) + '/' );
*  Maintainers: [[User:RockMFR]], [[User:Quiddity]]
mw.util.addPortletLink( 'p-tb', subpagesLink, 'Subpages', 't-subpages', 'Subpages of this page' );
*/
}
} );
if (wgNamespaceNumber == 0) addOnloadHook(function(){
if (!document.getElementById('disambig')) return
var el = document.getElementById('ca-edit')
if (el) el = el.getElementsByTagName('a')[0]
if (el) el.href += '&editintro=Template:Disambig_editintro'
})
/** Mobile browser helper link ************************************************
*
*  Adds a link to the mobile-optimized gateway at en.m.wikimedia.org
*  for viewers on iPhone, iPod Touch, and Android devices.
*  This is semi-experimental to drive more test traffic there for now;
*  it's still in development but very usable for reading!
*
*  Currently set to always show the link on main page and search results,
*  and w/ 25% probability on other page views.
*
*  Maintainer: [[User:Brion VIBBER]]
*/
if (/(Android|iPhone|iPod)/.test(navigator.userAgent)) {
addOnloadHook(function() {
var prob = 1.0;
if (wgCanonicalNamespace == 'Special' && wgCanonicalSpecialPageName == 'Search') {
var pageLink = '?search=' + encodeURIComponent(document.getElementById('searchText').value);
} else if (wgPageName == 'Main_Page') {
var pageLink = '::Home'; // Special case
} else {
var pageLink = encodeURIComponent(wgPageName).replace('%2F','/').replace('%3A',':');
prob = 0.25;
}
if (prob < Math.random()) return;
var div = document.createElement('div');
div.style.fontSize = '30pt';
div.style.lineHeight = '40pt';
div.style.textAlign = 'center';
div.style.marginTop = '20px';
div.style.marginBottom = '20px';
div.style.padding = '20px';
div.style.border = '2px solid gray';
div.appendChild(document.createTextNode("View this page in "));
var link = document.createElement('a');
link.href = 'http://en.m.wikipedia.org/wiki/' + pageLink;
link.appendChild(document.createTextNode("Wikipedia's mobile site"));
div.appendChild(link);
var content=document.getElementById('content');
content.insertBefore(div,content.firstChild);
});
}
//</source>

Latest revision as of 13:41, 14 January 2025

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

/* Make the VisualEditor Sticky */
/* leverage jQuery for the selector and the sticky class from Chameleon? 
This doesn't actually work properly
AND, the VE Toolbar is floating in Vector2022 skin
So, it's a bug? in Chameleon
$('.ve-ui-toolbar').addClass('sticky');
*/

/** Matomo **/
  var _paq = window._paq || [];
  /* tracker methods like "setCustomDimension" should be called before "trackPageView" */
  _paq.push(['trackPageView']);
  _paq.push(['enableLinkTracking']);
  (function() {
    var u="//wiki.freephile.org/analytics/";
    _paq.push(['setTrackerUrl', u+'matomo.php']);
    _paq.push(['setSiteId', '1']);
    var d=document, g=d.createElement('script'), s=d.getElementsByTagName('script')[0];
    g.type='text/javascript'; g.async=true; g.defer=true; g.src=u+'matomo.js'; s.parentNode.insertBefore(g,s);
  })();
/** End Matomo **/

/**
 * wikEd.js is a Gadget implemented at MediaWiki:Gadget-wikEd.js and in Special:Preferences

// install [[:Wikipedia:User:Cacycle/wikEd]] in-browser text editor
(function ()
{
	var script = document.createElement('script');
	script.src = '//en.wikipedia.org/w/index.php?title=User:Cacycle/wikEd.js&action=raw&ctype=text/javascript';
	script.async = true;
	document.getElementsByTagName('head')[0].appendChild(script);
 }
) ();
*/

/*To add <script src="https://use.fontawesome.com/14c71d3de0.js"></script>
   we use load instead of the deprecated importScriptURI */
mw.loader.load('//use.fontawesome.com/14c71d3de0.js');

/** 
 * Cusomize the sidebar for the Html2Wiki extension
 * @see https://www.mediawiki.org/wiki/Manual:Interface/Sidebar
 * added by Greg Rundlett <info@eQuality-Tech.com>
 */
function isObject( obj ) {
        return typeof obj == 'object' && obj !== null;
}
 
function isArray( obj ) {
        return isObject( obj ) && obj.constructor.toString().indexOf( 'Array' ) != -1;
}
 
Array.prototype.Contains = function( element, strict ) {
        for( var i in this ) {
                if( this[i] == element && !strict || this[i] === element ) {
                        return true;
                }
        }
        return false;
};
 
function ModifySidebar( action, section, name, link ) {
        try {
                var target;
                switch ( section ) {
                        case 'languages':
                                target = 'p-lang';
                                break;
                        case 'toolbox':
                                target = 'p-tb';
                                break;
                        case 'navigation':
                                target = 'p-navigation';
                                break;
                        default:
                                target = 'p-' + section;
                                break;
                }
 
                if ( action == 'add' ) {
                        var node = document.getElementById( target )
                                                           .getElementsByTagName( 'div' )[0]
                                                           .getElementsByTagName( 'ul' )[0];
 
                        var aNode = document.createElement( 'a' );
                        var liNode = document.createElement( 'li' );
 
                        aNode.appendChild( document.createTextNode( name ) );
                        aNode.setAttribute( 'href', link );
                        liNode.appendChild( aNode );
                        liNode.className = 'plainlinks';
                        node.appendChild( liNode );
                }
 
                if ( action == 'remove' ) {
                        var list = document.getElementById( target )
                                                           .getElementsByTagName( 'div' )[0]
                                                           .getElementsByTagName( 'ul' )[0];
 
                        var listelements = list.getElementsByTagName( 'li' );
 
                        for ( var i = 0; i < listelements.length; i++ ) {
                                if (
                                        listelements[i].getElementsByTagName( 'a' )[0].innerHTML == name ||
                                        listelements[i].getElementsByTagName( 'a' )[0].href == link
                                )
                                {
                                        list.removeChild( listelements[i] );
                                }
                        }
                }
 
        } catch( e ) {
                // let's just ignore what's happened
                return;
        }
}
/** 
jQuery( document ).ready( function( $ ) {
        // adds [[Special:Html2Wiki]] to toolbox
        ModifySidebar( 'add', 'toolbox', 'Import HTML', '/wiki/Special:Html2Wiki' );
} );
*/


// import the SubPages 'gadget' for all users. non-optional
/** See https://www.mediawiki.org/wiki/Extension:Gadgets/Scripts/SubPages.js **/
$( function () {
	var NSWithoutSubpages = [ -1, 6, 8, 12, 13, 14, 15, 104, 105 ];
	if ( NSWithoutSubpages.indexOf( mw.config.get( 'wgNamespaceNumber' ) ) === -1 ) {
		var subpagesLink = mw.util.getUrl( 'Special:PrefixIndex/' + mw.config.get( 'wgPageName' ) + '/' );
		mw.util.addPortletLink( 'p-tb', subpagesLink, 'Subpages', 't-subpages', 'Subpages of this page' );
	}
} );