MediaWiki:Common.js

From wiki.jriver.com
Revision as of 18:41, 9 April 2014 by Glynor (talk | contribs)
Jump to navigation Jump to search

Note: After publishing, you may have to bypass your browser's cache to see the changes.

  • Firefox / Safari: Hold Shift while clicking Reload, or press either Ctrl-F5 or Ctrl-R (⌘-R on a Mac)
  • Google Chrome: Press Ctrl-Shift-R (⌘-Shift-R on a Mac)
  • Internet Explorer / Edge: Hold Ctrl while clicking Refresh, or press Ctrl-F5
  • Opera: Press Ctrl-F5.
/* Any JavaScript here will be loaded for all users on every page load. */

// add &__vanilla=1 to URL to disable all scripts except gadgets (as enabled in [[Special:Preferences]])
if (mw.util.getParamValue('__vanilla'))
	throw void 0; // return is invalid here. oh well.
	
/*
== [[WT:PREFS]] v2.0 ==
*/

try { (function () {
"use strict";

var prefs;
try {
	prefs = window.localStorage.getItem('AGprefs');
} catch (e) {
	prefs = jQuery.cookie('AGprefs');
}
prefs = prefs && (window.JSON ? window.JSON.parse(prefs) : eval('(' + prefs + ')'));

if (wgUserGroups.indexOf('autoconfirmed') !== -1)
	return;

if (wgUserGroups.indexOf('user') === -1)
	if ((wgAction === 'view') && (wgPageName === 'Wiktionary:Preferences/V2')) {
		mw.loader.load('ext.gadget.AGprefs');
	}

if (!prefs)
	return;

mw.loader.state('the_pope_is_an_atheist_woman_alien', 'missing');
for (var key in prefs.modules) {
	if (prefs.modules[key]) {
		mw.loader.load(key);
	} else {
		// unavoidable race condition. to prevent it, every enabled-by-default gadget should have "site" as a dependency
		if (mw.loader.getState(key) !== 'ready') {
			mw.loader.moduleRegistry[key].dependencies.push('the_pope_is_an_atheist_woman_alien');
			mw.loader.state(key, 'missing');
		} else {
			// XXX
			mw.log.warn(key + ": the milk has been spilt.");
		}
	}
}

for (var key in prefs.sheets) {
	importStylesheet('MediaWiki:Gadget-' + key);
}

for (var key in prefs.scripts) {
	importScript('MediaWiki:Gadget-' + key);
}

if (wgUserGroups.indexOf('user') !== -1) {
	var changes = [];
	for (var key in prefs.gadgets)
		changes.push('gadget-' + key + '=' + (prefs.gadgets[key] ? '1' : '0'));

	(new mw.Api()).postWithToken('options', {
		action: 'options',
		change: changes.join('|')
	}).fail(function () {
		jQuery.cookie('AGprefs', null);
		try { window.localStorage.removeItem('AGprefs'); } catch (e) { /* */ }
		mw.util.jsMessage(
			'<b>Your <a href="/wiki/Wiktionary:Preferences/V2">per-browser preferences</a> have been migrated</b><br/><br/>' +
			'From now on, you should use your <a href="/wiki/Special:Preferenced">user preferences page</a>. ' +
			'Preferences will no longer apply after you log out.'
		);
	});
}

})(); } catch (e) { mw.log.warn(e); }

/*</pre>
===importScript===
<pre>*/

/**
 * importScript inserts a javascript page either 
 *    from Wiktionary: importScript('User:Connel MacKensie/yetanother.js');
 *    from another Wikimedia wiki: importScript('User:Lupin/insane.js','en.wikipedia.org');
 *
 *    by specifying the third argument, an oldid can be passed to ensure that updates to the script are not included.
 *    by specifying the fourth argument, a specific version of JavaScript can be declared.
 *
 *    based on [[w:MediaWiki:Common.js]] 2007-11-29
**/
function importScript(page, wiki, oldid, jsver) {
	if (wiki || oldid || jsver) {
		mw.log.warn("importScript called with more than one argument. This may be unreliable.");
	}

	// Default to local
	if (!wiki) {
		wiki=wgScript;
	} else {
		wiki='//'+escape(wiki)+'/w/index.php';
	}

	var url = wiki + '?title='
		+ mw.util.wikiUrlencode(page)
		+ (oldid ? '&oldid=' + encodeURIComponent(oldid) : '')
		+ '&action=raw&ctype=text/javascript';

	//Only include scripts once
	if (loadedScripts[url]) {
		return false;
	}
	loadedScripts[url] = true;

	var scriptElem = document.createElement("script");
	scriptElem.setAttribute("src",url);
	scriptElem.setAttribute("type", jsver ? "application/javascript;version=" + jsver : "text/javascript");
	document.getElementsByTagName("head")[0].appendChild(scriptElem);
	return true;
}

/*</pre>
=== DOM creation ===
<pre>*/
/**
 * Create a new DOM node for the current document.
 *    Basic usage:  var mySpan = newNode('span', "Hello World!")
 *    Supports attributes and event handlers*: var mySpan = newNode('span', {style:"color: red", focus: function(){alert(this)}, id:"hello"}, "World, Hello!")
 *    Also allows nesting to create trees: var myPar = newNode('p', newNode('b',{style:"color: blue"},"Hello"), mySpan)
 *
 * *event handlers, there are some issues with IE6 not registering event handlers on some nodes that are not yet attached to the DOM,
 * it may be safer to add event handlers later manually.
**/
function newNode(tagname){
	var node = document.createElement(tagname);

	for (var i = 1; i < arguments.length; ++i){
		if (typeof arguments[i] == 'string') { // text
			node.appendChild(document.createTextNode(arguments[i]));
		} else if (typeof arguments[i] == 'object') {
			if (arguments[i].nodeName) { //If it is a DOM Node
				node.appendChild(arguments[i]);
			} else { // Attributes (hopefully)
				for (var j in arguments[i]){
					if (j == 'class') { //Classname different because...
						node.className = arguments[i][j];
					} else if (j == 'style') { //Style is special
						node.style.cssText = arguments[i][j];
					} else if (typeof arguments[i][j] == 'function') { //Basic event handlers
						newNode.addEventHandler(node, j, arguments[i][j]);
					} else {
						node.setAttribute(j, arguments[i][j]); //Normal attributes
					}
				}
			}
		}
	}

	node.addEventHandler = function(eventName, handler) {
		newNode.addEventHandler(this, eventName, handler);
	};

	return node;
}

newNode.addEventHandler = function(node, eventName, handler)
{
	try{ node.addEventListener(eventName,handler,false); //W3C
	}catch(e){try{ node.attachEvent('on'+eventName,handler,"Language"); //MSIE
	}catch(e){ node['on'+eventName]=handler; }} //Legacy
};
/*</pre>

=== CSS ===
<pre>*/

/**
 * Cross browser CSS - yurk
 * @deprecated: Use mw.util.addCSS() instead
 */
var p_styleSheet=false;
 
window.addCSSRule = function (selector,cssText) {
	mw.log.warn("deprecated function addCSSRule called; use mw.util.addCSS(css) instead");
	mw.util.addCSS( selector+'{' + cssText + '}' );
}

/*</pre>

===Cookies===
<pre>
*/

/* @deprecated: Use $.cookie instead */
function setCookie(cookieName, cookieValue) {
	mw.log.warn("deprecated function setCookie called; use jQuery.cookie instead");
	var today = new Date();
	var expire = new Date();
	var nDays = 30;
	expire.setTime( today.getTime() + (3600000 * 24 * nDays) );
	document.cookie = cookieName + "=" + escape(cookieValue)
		+ ";path=/"
		+ ";expires="+expire.toGMTString();
}

function getCookie(cookieName) {
  mw.log.warn("deprecated function getCookie called; use jQuery.cookie instead");
  var start = document.cookie.indexOf( cookieName + "=" );
  if ( start == -1 ) return "";
  var len = start + cookieName.length + 1;
  if ( ( !start ) &&
	( cookieName != document.cookie.substring( 0, cookieName.length ) ) )
	  {
		return "";
	  }
  var end = document.cookie.indexOf( ";", len );
  if ( end == -1 ) end = document.cookie.length;
  return unescape( document.cookie.substring( len, end ) );
}

function deleteCookie(cookieName) {
	mw.log.warn("deprecated function deleteCookie called; use jQuery.cookie instead");
	if (getCookie(cookieName)) {
		document.cookie = cookieName + "=" + ";path=/" + ";expires=Thu, 01-Jan-1970 00:00:01 GMT";
	}
}

/*</pre>

==Wiktionary Customisation==
<pre>*/

if ( document.getElementById('footer') ) {
	jQuery.ready()
}

//initialize the storage for script options. Gadgets that set script
//options should also include this line as they are loaded before us.
if ( typeof WiktScriptPrefs == 'undefined') {
	WiktScriptPrefs = {};
}

/*</pre>
===[[MediaWiki:Youhavenewmessages]] to display differently for non-newbies with JS than for others===
<pre>*/
/* Suspected unresponsive page culprit: see the GP (Nov. 2010, "Blocking script execution on each page") */
/* if (wgUserGroups && wgUserGroups.join("").indexOf("autoconfirmed") > -1)
{
	addCSSRule(".msgfornewbies", "display: none");
}else{
	addCSSRule(".msgfornonnewbies", "display: none");
} */
/*</pre>

===[[WT:FEED]]===
<pre>*/
if ( !wgUserName ) {
 importScript('User:Conrad.Irwin/feedback.js');
}
/*</pre>
===WT:PREFS===
<pre>*/

if ( jQuery.cookie('WiktPrefs') || mw.config.get('wgPageName') == "Wiktionary:Per-browser_preferences") {
	//importScript('User:Connel_MacKenzie/custom.js');
	importScript('User:Hippietrail/custom.js');
}

/*</pre>

===Edit page javascript===
<pre>*/
$(document).ready( function() { 
 if ( wgAction == 'edit' || wgAction == 'submit' || document.getElementById('editpage-specialchars') ) {
  importScript('MediaWiki:Edit.js');
 }
});
/*</pre>

===Page specific extensions===
<pre>*/

/*</pre>
====Wiktionary:Main Page====
<pre>*/
// Hide the title and "Redirected from" (maybe we should keep the redirected from so's people update their bookmarks ;)
// Broken in IE!
if ( wgPageName == 'Wiktionary:Main_Page' && !( wgAction == 'view' || wgAction == 'submit' ) ){
	mw.util.addCSS( '.firstHeading { display: block !important; }' );
	mw.util.addCSS( '#contentSub { display: inline !important; }' );
}

if (wgPageName == 'Wiktionary:Main_Page') {
	$(function () {
		mw.util.addPortletLink('p-lang', '//meta.wikimedia.org/wiki/Wiktionary#List_of_Wiktionaries',
				 'Complete list', 'interwiki-completelist', 'Complete list of Wiktionaries');
	});
}

/*</pre>
====Special:Search====
<pre>*/

if ( wgPageName == 'Special:Search') {
	importScript('MediaWiki:SpecialSearch.js');
	importScript('User:Yair rand/FindTrans.js');
}
jQuery(document).ready(function () { if(document.getElementById('preloadGuide')) {
	importScript('MediaWiki:SpecialSearch.js');
}});

/*</pre>
====Unsupported titles====
<pre>*/

if (wgTitle.indexOf('Unsupported titles/') === 0)
$(document).ready(function () {
	//if (wgCanonicalNamespace != 'Appendix') return;
	//pages have been moved to mainspace, so commenting out this line
	var newTitle;
	if (document.getElementById('unsupportedpage')) {
		newTitle = document.getElementById('unsupportedpage').title;
	} else {
		newTitle = "[" + wgTitle.slice(19) + "]";
	}
	document.getElementById('firstHeading').innerHTML = newTitle;
});

/*</pre>

====Custom search engines====
<pre>*/

if( wgPageName=='Help:Tips_and_tricks' ){
	importScript('MediaWiki:CustomSearch.js');
}

/*</pre>

====Turn headings in comments into real headings on JavaScript source pages====
<pre>*/

else if ((wgNamespaceNumber == 2 || wgNamespaceNumber == 8) && wgTitle.lastIndexOf('.js') != -1 && wgAction == 'view') {
	importScript('MediaWiki:JavascriptHeadings.js');
}

/*</pre>
====Geonotice====
<pre>*/
/*Ended December 2009
else if (wgPageName == "Special:Watchlist") //watchlist scripts
{
	importScriptURI('http://toolserver.org/~para/geoip.fcgi');
	addOnloadHook(function() { importScriptURI('http://en.wiktionary.org/w/index.php?title=MediaWiki:Geonotice.js&action=raw&ctype=text/javascript&maxage=3600'); });
}
*/
/*</pre>
====New-section redirects====
<pre>*/
// This allows the new-section link (the "+" tab) to point to a different
// URL, as specified by the page (so that, for example, the new-section link
// for the Grease pit will add a new section to the appropriate monthly
// subpage):
importScript('MediaWiki:NewSectionRedirects.js');
/*</pre>

===Add editor.js for editing translations===
<pre>*/

importScript('User:Conrad.Irwin/editor.js');

/*</pre>

===Import newentrywiz.js===
<pre>*/
jQuery(document).ready(function(){
 if(document.getElementById('necblah')){
  importScript('User:Yair rand/newentrywiz.js');
 }
});


/*</pre>
===Import adddefinition.js===
<pre>*/
importScript('User:Yair rand/adddefinition.js');
/*</pre>
===Import rhymesedit.js===
<pre>*/
wgNamespaceNumber == 106 && importScript("User:Yair rand/rhymesedit.js");
/*</pre>
===Import Targeted Translations===
<pre>*/
importScript("User:Yair rand/TargetedTranslations.js");
/*</pre>

==URL Fixes==
<pre>*/

/**
 * doRedirect will redirect if a did you mean box is found, and create a 
 * "redirected from X" if a rdfrom is passed in the get parameters
 * The first half is an ugly workaround for Bugzilla:3339, :(
 * The second half is an ugly workaround for not having serverware support :(
**/

/*</pre>
===Did you mean ____ redirects===
<pre>*/

jQuery(document).ready(function () {
	// REDIRECTED FROM
	if( window.location.href.indexOf('rdfrom=') != -1 ) {
		var wiktDYMfrom = decodeURIComponent(window.location.href.replace(/^(.+[&\?]rdfrom=([^&]+).*|.*)?$/,"$2"));

		jQuery('#siteSub').after(
			newNode('div', {id: 'contentSub'}, '(Auto-redirected from ',
				newNode('a', {href: mw.util.getUrl(wiktDYMfrom) + '?redirect=no', 'class': 'new'}, wiktDYMfrom),
		')'));

	} else {
		// DID YOU MEAN
	
		var target = jQuery('#did-you-mean a').html(),
			pagetitle = jQuery('h1').first().text().replace(/^\s+|\s+$/g, '');

		if (target && target != pagetitle
			&& !window.location.href.match(/[&\?]redirect=no|[&\?]action=(?!view)/)
			&& (jQuery.cookie('WiktionaryDisableAutoRedirect') != 'true')
			&& wgArticleId === 0
			&& !/Redirected from/.test(jQuery('#contentSub').html())
		) {
			document.location = mw.util.getUrl( target, { "rdfrom": pagetitle } );
		}
	}

// Random page in a given language
	document.location.toString().replace(/[?&]rndlang=([^&#]+)[^#]*(?:#(.+))?/, function (m, lang, headlang) {
		var script = 'http://toolserver.org/~hippietrail/randompage.fcgi';

		var insert = document.getElementById('contentSub');
		if (headlang) {
			var heading = document.getElementById(headlang);
			if (heading) heading = heading.parentNode;
			if (heading) {
				insert = newNode('div', {style: 'font-size: 84%; line-height: 1.2em;'});
				heading.parentNode.insertBefore(insert, heading.nextSibling)
			}
		}

		if (!insert || insert.innerHTML != "") return;

		insert.appendChild(newNode('span', {style: 'color: #888;'}, "Another ",
			newNode('a', {href: script + '?langs=1'}, "Random"), " word in ",
			newNode('a', {href: script + '?langname=' + lang}, decodeURIComponent(lang))
		));
	});
})

/*</pre>

===Fix Wikified section titles===
<pre>*/
jQuery(document).ready(function () {
	// {temp|template}
	if (/\.7B\.7Btemp\.7C(.*?)\.7D\.7D/.test(window.location.href)) {
		var url=window.location.href.replace(/\.7B\.7Btemp.7C/g, ".7B.7B");
		window.location = url;
	}
});

jQuery(document).ready(function () {
	if(wgAction != 'edit')
		return;
	if(! /[?&]section=\d/.test(window.location.href))
		return;
	var wpSummary = document.getElementById('wpSummary');
	if(! wpSummary)
		return;
	if(wpSummary.value.substr(0, 3) != '/* ')
		return;
	if(wpSummary.value.substr(wpSummary.value.length - 4) != ' */ ')
		return;
	wpSummary.value = wpSummary.value.replace(/\{\{temp(late)?\|/g, '{{');
});

/*</pre>
== Visibility toggling ==
<pre>*/
var VisibilityToggles = {
	// toggles[category] = [[show, hide],...]; statuses[category] = [true, false,...]; buttons = <li>
	toggles: {}, statuses: {}, buttons: null,

	// Add a new toggle, adds a Show/Hide category button in the toolbar,
	// and will call show_function and hide_function once on register, and every alternate click.
	register: function (category, show_function, hide_function) {

		var id = 0;
		if (!this.toggles[category]) {
			this.toggles[category] = [];
			this.statuses[category] = [];
		} else {
			id = this.toggles[category].length;
		}
		this.toggles[category].push([show_function, hide_function]);
		this.statuses[category].push(this.currentStatus(category));
		this.addGlobalToggle(category);

		(this.statuses[category][id] ? show_function : hide_function)();

		return function () {
			var statuses = VisibilityToggles.statuses[category];
			statuses[id] = !statuses[id]
			VisibilityToggles.checkGlobalToggle(category);
			return (statuses[id] ? show_function : hide_function)();
		}

	},

	// Add a new global toggle to the side bar
	addGlobalToggle: function(category) {
		if (document.getElementById('p-visibility-'+category))
			return;
		if (!this.buttons) {
			this.buttons = newNode('ul');
			var collapsed = $.cookie("vector-nav-p-visibility") == "false", toolbox = newNode('div', {'class': "portal portlet "+(collapsed?"collapsed":"expanded"), 'id': 'p-visibility'},
							newNode('h3', 'Visibility'),
							newNode('div', {'class': "pBody body"}, collapsed?undefined:{'style':'display:block;'}, this.buttons)
						  );
			var sidebar = document.getElementById('mw-panel') || document.getElementById('column-one');
			var insert = null;
			if (insert = (document.getElementById('p-lang') || document.getElementById('p-feedback')))
				sidebar.insertBefore(toolbox, insert);
			else
				sidebar.appendChild(toolbox);

		}
		var status = this.currentStatus(category);
		var newToggle = newNode('li', newNode('a', {
			id: 'p-visibility-' + category, 
			style: 'cursor: pointer',
			href: '#visibility-' + category,
			click: function(e)
			{
				VisibilityToggles.toggleGlobal(category); 
				if (e && e.preventDefault)
					e.preventDefault();
				else 
					window.event.returnValue = false;
				return false; 
			}},
			(status ? 'Hide ' : 'Show ') + category));
		for (var i=0; i < this.buttons.childNodes.length; i++) {
			if (this.buttons.childNodes[i].id < newToggle.id) {
				this.buttons.insertBefore(newToggle, this.buttons.childNodes[i]);
				return;
			}
		}
		this.buttons.appendChild(newToggle);
	},

	// Update the toggle-all buttons when all things are toggled one way
	checkGlobalToggle: function(category) {
		var statuses = this.statuses[category];
		var status = statuses[0];
		for (var i = 1; i < statuses.length; i++) {
			if (status != statuses[i])
				return;
		}
		document.getElementById('p-visibility-' + category).innerHTML = (status ? 'Hide ' : 'Show ') + category;
	},

	// Toggle all un-toggled elements when the global button is clicked
	toggleGlobal: function(category) {
		var status = document.getElementById('p-visibility-' + category).innerHTML.indexOf('Show ') == 0;
		for (var i = 0; i < this.toggles[category].length; i++ ) {
			if (this.statuses[category][i] != status) {
				this.toggles[category][i][status ? 0 : 1]();
				this.statuses[category][i] = status;
			}
		}
		document.getElementById('p-visibility-' + category).innerHTML = (status ? 'Hide ' : 'Show ') + category;
		var current = jQuery.cookie('Visibility');
		if (!current)
			current = ";";
		current = current.replace(';' + category + ';', ';');
		if (status)
			current = current + category + ";";
		setCookie('Visibility', current);
	},

	currentStatus: function(category) {
		if (window.location.hash.toLowerCase().split('_')[0] == '#' + category.toLowerCase())
			return true;
		if (window.location.href.search(/[?](.*&)?hidecats=/) > 0)
		{
			var hidecats = window.location.href;
			hidecats = hidecats.replace(/^[^?]+[?]((?!hidecats=)[^&]*&)*hidecats=/, '');
			hidecats = hidecats.replace(/&.*/, '');
			hidecats = hidecats.split(',');
			for (var i = 0; i < hidecats.length; ++i)
				if (hidecats[i] == category || hidecats[i] == 'all')
					return false;
				else if (hidecats[i] == '!' + category || hidecats[i] == 'none')
					return true;
		}
		if (jQuery.cookie('WiktionaryPreferencesShowNav') == 'true')
			return true;
		if ((jQuery.cookie('Visibility') || "").indexOf(';' + category + ';') >= 0)
			return true;
		// TODO check category-specific cookies
		return false;
	}
}

/*</pre>
=== NavBars ===
<pre>*/
var NavigationBarHide = 'hide ▲';
var NavigationBarShow = 'show ▼';

function NavToggleCategory(navFrame)
{
	var table = navFrame.getElementsByTagName('table')[0];
	if (table && table.className == "translations")
		return "translations";

	var heading = navFrame.previousSibling;
	while (heading) {
		if (/[hH][4-6]/.test(heading.nodeName)) {
			if (heading.getElementsByTagName('span')[1])
				heading = heading.getElementsByTagName('span')[0];
			return $(heading).text().toLowerCase()
				// jQuery's .text() is inconsistent about whitespace:
				.replace(/^\s+|\s+$/g, '').replace(/\s+/g, ' ')
				// remove numbers added by the "Auto-number headings" pref:
				.replace(/^[1-9][0-9.]+ ?/, '');
		}
		else if (/[hH][1-3]/.test(heading.nodeName)) 
			break;
		heading = heading.previousSibling;
	}
	return "other boxes";
}

function createNavToggle(navFrame){
	var navHead, navToggle, navContent;
	for (var j=0; j < navFrame.childNodes.length; j++) {
		var div = navFrame.childNodes[j];
		switch (div.className) {
			case 'NavHead':
				navHead = div;
				break;
			case 'NavContent':
				navContent = div;
				break;
		}
	}
	if (!navHead || !navContent)
		return;
	// Step 1, don't react when a subitem is clicked.
	for (var i=0; i<navHead.childNodes.length; i++) {
		var child = navHead.childNodes[i];
		if (child.nodeName == "A") {
			child.onclick = function (e)
			{
				if (e && e.stopPropagation)
					e.stopPropagation();
				else
					window.event.cancelBubble = true;
			}
		}
	}
	// Step 2, toggle visibility when bar is clicked.
	// NOTE This function was chosen due to some funny behaviour in Safari.
	navToggle = newNode('a', {href: 'javascript:(function(){})()'}, '');
	navHead.insertBefore(newNode('span', {'class': 'NavToggle'}, '[', navToggle, ']'), navHead.firstChild);

	navHead.style.cursor = "pointer";
	navHead.onclick = VisibilityToggles.register(NavToggleCategory(navFrame),
		function show() {
			navToggle.innerHTML = NavigationBarHide;
			if (navContent)
				navContent.style.display = "block";
		},
		function hide() {
			navToggle.innerHTML = NavigationBarShow;
			if (navContent)
				navContent.style.display = "none";
		});
};

jQuery(document).ready( function ()
{
	var divs = $(".NavFrame");
	for (var i=0; i<divs.length; i++) {
		// NOTE: some templates use a class of NavFrame for the style, but for legacy reasons, are not NavFrames
		if (divs[i].className == "NavFrame") {
			createNavToggle(divs[i]);
		}
	}

});

/*</pre>

===Hidden Quotes===
<pre>*/

function setupHiddenQuotes(li) {
	var HQToggle, liComp, dl;
	var HQShow = 'quotations ▼';
	var HQHide = 'quotations ▲';
	for (var k = 0; k < li.childNodes.length; k++) {
		// Look at each component of the definition.
		liComp = li.childNodes[k];
		if ( liComp.nodeName.toLowerCase() === "dl" && !dl ) {
			dl = liComp;
		}
		// If we find a ul or dl, we have quotes or example sentences, and thus need a button.
		if (/^(ul|UL)$/.test(liComp.nodeName)) {
			HQToggle = newNode('a', {href: 'javascript:(function(){})()'}, '');
			li.insertBefore(newNode('span', {'class': 'HQToggle'}, ' [', HQToggle, ']'), dl || liComp);
			HQToggle.onclick = VisibilityToggles.register('quotations',
				function show() {
					HQToggle.innerHTML = HQHide;
					for (var child = li.firstChild; child != null; child = child.nextSibling) {
						if (/^(ul|UL)$/.test(child.nodeName)) {
							child.style.display = 'block';
						}
					}
				},
				function hide() {
					HQToggle.innerHTML = HQShow;
					for (var child = li.firstChild; child != null; child = child.nextSibling) {
						if (/^(ul|UL)$/.test(child.nodeName)) {
							child.style.display = 'none';
						}
					}
				});

			break;
		}
	}
}
 
jQuery(document).ready(function () {
	if (wgNamespaceNumber == 0) {
		var ols, lis, li;
		// First, find all the ordered lists, i.e. all the series of definitions.
		var ols = document.getElementsByTagName('ol');
		for(var i = 0; i < ols.length; i++) {
		 // Then, for every set, find all the individual definitions.
			for (var j = 0; j < ols[i].childNodes.length; j++) {
				li = ols[i].childNodes[j];
				if (li.nodeName.toUpperCase() == 'LI') {
					setupHiddenQuotes(li);
				}
			}
		}
	}
});

/*</pre>

== Interproject links ==
<pre>*/

/*
#########
### ProjectLinks
###  by [[user:Pathoschild]] (idea from an older, uncredited script)
###    * generates a sidebar list of links to other projects from {{projectlinks}}
#########
*/
jQuery(document).ready(function () {
	var elements = new Array();
	var spans = document.getElementsByTagName('span');

	// filter for projectlinks
	for (var i=0, j=0; i<spans.length; i++) {
		if (spans[i].className == 'interProject') {
			elements[j] = spans[i].getElementsByTagName('a')[0];
			j++;
		}
	}

	if (j == 0)
		return;

	// sort alphabetically
	function sortbylabel(a,b) {
		// get labels
		a = a.innerHTML.replace(/^.*<a[^>]*>(.*)<\/a>.*$/i,'$1');
		b = b.innerHTML.replace(/^.*<a[^>]*>(.*)<\/a>.*$/i,'$1');

		// return sort order
		if (a < b) return -1;
		if (a > b) return 1;
		return 0;
	}
	elements.sort(sortbylabel);

	// Create the list of project links
	var pllist = newNode('ul');
	for (var i=0; i<elements.length; i++) {
		pllist.appendChild(newNode('li', elements[i]));
	}
	var collapsed = $.cookie("vector-nav-p-projects") == "false";
	var projectBox = newNode('div', {'class': 'portlet portal '+(collapsed?"collapsed":"expanded"), id: 'p-projects'}, 
		newNode('h3', 'In other projects'),
		newNode('div', {'class': 'pBody body'}, collapsed?undefined:{'style':'display:block;'}, pllist)
	);

	var insert = document.getElementById('p-tb');
	if (!insert)
		return;

	if (insert.nextSibling)
		insert.parentNode.insertBefore(projectBox, insert.nextSibling);
	else
		insert.parentNode.appendChild(projectBox);
});

/*</pre>
===Scripts specific to Internet Explorer===
<pre>*/ 
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;

	function fixIEScroll()
	{
		if (!oldWidth || docEl.clientWidth > oldWidth)
			doFixIEScroll();
		else
			setTimeout(doFixIEScroll, 1);

		oldWidth = docEl.clientWidth;
	}

	function doFixIEScroll() {
		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")
	}
}

/*</pre>
===Category page fixes===
<pre>*/

$(document).ready(function($){
	var s, c = "", lang;
	if( wgNamespaceNumber === 14 && ( s = document.getElementById("catfix") ) ) {
		lang = s.className.split("CATFIX-")[1]
		if (lang.length > 0)
		{
			c = "#" + lang;
		}

		s = s.getElementsByTagName("*")[0] || document.createElement("span");
		$("#mw-pages>.mw-content-ltr").find("li>a").each(function(){
			var li = this.parentNode, clone = s.cloneNode( false );
			li.removeChild( this );
			this.setAttribute("href", this.getAttribute("href", 2) + c );
			clone.appendChild( this );
			li.appendChild( clone );
		})
	}
})

/*</pre>
===Temporary button for enabling two proposed scripts===
<pre>*/

if ( $.cookie("YRNewStuff") || location.search.indexOf("tabbedlanguages=on") != -1 )
{
	importScript("User:Yair rand/editor2.js")
	importScript("User:Yair rand/TabbedLanguages2.js")
}

jQuery(document).ready(function () {
	if(document.getElementById('YRNewStuff-enable-button'))
	{
		document.getElementById('YRNewStuff-enable-button').innerHTML = ""
		var toggle = newNode('span', {click: function ()
		{
			if( $.cookie("YRNewStuff") ){
				$.cookie("YRNewStuff", null,{path:"/"})
				toggle.innerHTML = "Enable tabbed languages and definition editing options."
			}
			else{
				$.cookie("YRNewStuff",1,{expires:30,path:"/"})
				toggle.innerHTML = "Disable tabbed languages and definition editing options."
			}
		} }, ($.cookie("YRNewStuff")?"Disable":"Enable")+" tabbed languages and definition editing options.")
		
		document.getElementById('YRNewStuff-enable-button').appendChild(toggle);
	}
 })

/*</pre>
===WT:ES Discussion tool===
<pre>*/

wgPageName == "Wiktionary:Etymology_scriptorium" && importScript("User:Yair rand/DiscussionSandbox.js");

$(document).ready(function() {
	$("table.unit-tests th.unit-tests-img-corner").bind("click", function () {
		var table = this;
		while (table.tagName !== "TABLE")
			table = table.parentNode;
		table.classList.toggle("unit-tests-hide-passing");
	})
});