Difference between revisions of "MediaWiki:Common.js"

From SFU_Public
Jump to: navigation, search
(New page: Any JavaScript here will be loaded for all users on every page load.: <br> <br><source lang="javascript">: <br> <br>/** Collapsible tables ***********************************...)
 
 
Line 1: Line 1:
/* Any JavaScript here will be loaded for all users on every page load. */<br>
+
/* Any JavaScript here will be loaded for all users on every page load. */
  
<br>/*&lt;source lang="javascript"&gt;*/<br> <br>/** Collapsible tables *********************************************************<br> *<br> * Description: Allows tables to be collapsed, showing only the header. See<br> * [[:wikipedia:NavFrame|:wikipedia:NavFrame]].<br> * Maintainer on Wikipedia: [[User:R. Koot|User:R. Koot]]<br> */<br> <br>var autoCollapse = 2;<br>var collapseCaption = "hide";<br>var expandCaption = "show";<br> <br>function hasClass( element, className ) {<br> var Classes = element.className.split( " " );<br> for ( var i = 0; i &lt; Classes.length; i++ ) {<br> if ( Classes[i] == className ) {<br> return ( true );<br> }<br> }<br> return ( false );<br>}<br> <br>function collapseTable( tableIndex )<br>{<br> var Button = document.getElementById( "collapseButton" + tableIndex );<br> var Table = document.getElementById( "collapsibleTable" + tableIndex );<br> <br> if (&nbsp;!Table ||&nbsp;!Button ) {<br> return false;<br> }<br> <br> var Rows = Table.getElementsByTagName( "tr" ); <br> <br> if ( Button.firstChild.data == collapseCaption ) {<br> for ( var i = 1; i &lt; Rows.length; i++ ) {<br> Rows[i].style.display = "none";<br> }<br> Button.firstChild.data = expandCaption;<br> } else {<br> for ( var i = 1; i &lt; Rows.length; i++ ) {<br> Rows[i].style.display = Rows[0].style.display;<br> }<br> Button.firstChild.data = collapseCaption;<br> }<br>}<br> <br>function createCollapseButtons()<br>{<br> var tableIndex = 0;<br> var NavigationBoxes = new Object();<br> var Tables = document.getElementsByTagName( "table" );<br> <br> for ( var i = 0; i &lt; Tables.length; i++ ) {<br> if ( hasClass( Tables[i], "collapsible" ) ) {<br> NavigationBoxes[ tableIndex ] = Tables[i];<br> Tables[i].setAttribute( "id", "collapsibleTable" + tableIndex );<br> <br> var Button = document.createElement( "span" );<br> var ButtonLink = document.createElement( "a" );<br> var ButtonText = document.createTextNode( collapseCaption );<br> <br> Button.style.styleFloat = "right";<br> Button.style.cssFloat = "right";<br> Button.style.fontWeight = "normal";<br> Button.style.textAlign = "right";<br> Button.style.width = "6em";<br> <br> ButtonLink.setAttribute( "id", "collapseButton" + tableIndex );<br> ButtonLink.setAttribute( "href", "javascript:collapseTable(" + tableIndex + ");" );<br> ButtonLink.appendChild( ButtonText );<br> <br> Button.appendChild( document.createTextNode( "[" ) );<br> Button.appendChild( ButtonLink );<br> Button.appendChild( document.createTextNode( "]" ) );<br> <br> var Header = Tables[i].getElementsByTagName( "tr" )[0].getElementsByTagName( "th" )[0];<br> /* only add button and increment count if there is a header row to work with */<br> if (Header) {<br> Header.insertBefore( Button, Header.childNodes[0] );<br> tableIndex++;<br> }<br> }<br> }<br> <br> for ( var i = 0; i &lt; tableIndex; i++ ) {<br> if ( hasClass( NavigationBoxes[i], "collapsed" ) || ( tableIndex &gt;= autoCollapse &amp;&amp; hasClass( NavigationBoxes[i], "autocollapse" ) ) ) {<br> collapseTable( i );<br> }<br> }<br>}<br> <br>addOnloadHook( createCollapseButtons );<br> <br> <br>/** Dynamic Navigation Bars (experimental) *************************************<br>*<br>* Description: See [[:wikipedia:NavFrame|:wikipedia:NavFrame]].<br>* Maintainers: UNMAINTAINED<br>*/<br> <br>// set up the words in your language<br>var NavigationBarHide = '[' + collapseCaption + ']';<br>var NavigationBarShow = '[' + expandCaption + ']';<br> <br>// shows and hides content and picture (if available) of navigation bars<br>// Parameters:<br>// indexNavigationBar: the index of navigation bar to be toggled<br>function toggleNavigationBar(indexNavigationBar)<br>{<br> var NavToggle = document.getElementById("NavToggle" + indexNavigationBar);<br> var NavFrame = document.getElementById("NavFrame" + indexNavigationBar);<br> <br> if (!NavFrame ||&nbsp;!NavToggle) {<br> return false;<br> }<br> <br> // if shown now<br> if (NavToggle.firstChild.data == NavigationBarHide) {<br> for (var NavChild = NavFrame.firstChild; NavChild&nbsp;!= null; NavChild = NavChild.nextSibling) {<br> if ( hasClass( NavChild, 'NavPic' ) ) {<br> NavChild.style.display = 'none';<br> }<br> if ( hasClass( NavChild, 'NavContent') ) {<br> NavChild.style.display = 'none';<br> }<br> }<br> NavToggle.firstChild.data = NavigationBarShow;<br> <br> // if hidden now<br> } else if (NavToggle.firstChild.data == NavigationBarShow) {<br> for (var NavChild = NavFrame.firstChild; NavChild&nbsp;!= null; NavChild = NavChild.nextSibling) {<br> if (hasClass(NavChild, 'NavPic')) {<br> NavChild.style.display = 'block';<br> }<br> if (hasClass(NavChild, 'NavContent')) {<br> NavChild.style.display = 'block';<br> }<br> }<br> NavToggle.firstChild.data = NavigationBarHide;<br> }<br>}<br> <br>// adds show/hide-button to navigation bars<br>function createNavigationBarToggleButton()<br>{<br> var indexNavigationBar = 0;<br> // iterate over all &lt; div &gt;-elements <br> var divs = document.getElementsByTagName("div");<br> for (var i = 0; NavFrame = divs[i]; i++) {<br> // if found a navigation bar<br> if (hasClass(NavFrame, "NavFrame")) {<br> <br> indexNavigationBar++;<br> var NavToggle = document.createElement("a");<br> NavToggle.className = 'NavToggle';<br> NavToggle.setAttribute('id', 'NavToggle' + indexNavigationBar);<br> NavToggle.setAttribute('href', 'javascript:toggleNavigationBar(' + indexNavigationBar + ');');<br> <br> var NavToggleText = document.createTextNode(NavigationBarHide);<br> for (var NavChild = NavFrame.firstChild; NavChild&nbsp;!= null; NavChild = NavChild.nextSibling) {<br> if ( hasClass( NavChild, 'NavPic' ) || hasClass( NavChild, 'NavContent' ) ) {<br> if (NavChild.style.display == 'none') {<br> NavToggleText = document.createTextNode(NavigationBarShow);<br> break;<br> }<br> }<br> }<br> <br> NavToggle.appendChild(NavToggleText);<br> // Find the NavHead and attach the toggle link (Must be this complicated because Moz's firstChild handling is borked)<br> for(var j=0; j &lt; NavFrame.childNodes.length; j++) {<br> if (hasClass(NavFrame.childNodes[j], "NavHead")) {<br> NavFrame.childNodes[j].appendChild(NavToggle);<br> }<br> }<br> NavFrame.setAttribute('id', 'NavFrame' + indexNavigationBar);<br> }<br> }<br>}<br> <br>addOnloadHook( createNavigationBarToggleButton );<br> <br> <br>//Shuffle for election candidates<br>function dshuf(){<br> var shufsets=new Object()<br> var rx=new RegExp('dshuf'+'\\s+(dshufset\\d+)', 'i') <br> var divs=document.getElementsByTagName("div")<br> for (var i=0; i&lt;divs.length; i++){<br> if (rx.test(divs[i].className)){<br> if (typeof shufsets[RegExp.$1]=="undefined"){ <br> shufsets[RegExp.$1]=new Object() <br> shufsets[RegExp.$1].inner=[] <br> shufsets[RegExp.$1].member=[]<br> }<br> shufsets[RegExp.$1].inner.push(divs[i].innerHTML) <br> shufsets[RegExp.$1].member.push(divs[i]) <br> }<br> }<br> for (shufset in shufsets){<br> shufsets[shufset].inner.sort(function() {return 0.5 - Math.random()})<br> for (var i=0; i&lt;shufsets[shufset].member.length; i++){<br> shufsets[shufset].member[i].innerHTML=shufsets[shufset].inner[i]<br> shufsets[shufset].member[i].style.display="block"<br> }<br> }<br> <br>}<br> <br>addOnloadHook(dshuf);<br> <br>/*************<br>*** AJAX transclusion table &lt;http://meta.wikimedia.org/wiki/User:Pathoschild/Scripts/AJAX_transclusion_table&gt;<br>*** by [[M:user:Pathoschild|m:user:Pathoschild]]<br>*************/<br>function attLoader() {<br>if(getElementsByClassName(document.getElementsByTagName('body')[0],'table','attable').length) {<br> document.write('&lt;script type="text/javascript" src="'<br> + 'http://meta.wikimedia.org/w/index.php?title=User:Pathoschild/Scripts/AJAX_transclusion_table.js' <br> + '&amp;action=raw&amp;ctype=text/javascript&amp;dontcountme=s"&gt;&lt;/script&gt;');<br>}<br>}<br>addOnloadHook(attLoader);<br> <br>/** JSconfig ************<br>* Global configuration options to enable/disable and configure<br>* specific script features from [[MediaWiki:Common.js|MediaWiki:Common.js]] and<br>* [[MediaWiki:Monobook.js|MediaWiki:Monobook.js]]<br>* This framework adds config options (saved as cookies) to [[Special:Preferences|Special:Preferences]]<br>* For a more permanent change you can override the default settings in your <br>* [[Special:Mypage/monobook.js|Special:Mypage/monobook.js]]<br>* for Example: JSconfig.keys[loadAutoInformationTemplate] = false;<br>*<br>* Maintainer: [[User:Dschwen|User:Dschwen]]<br>*/<br> <br>var JSconfig =<br>{<br>prefix&nbsp;: 'jsconfig_',<br>keys&nbsp;: {},<br>meta&nbsp;: {},<br> <br>//<br>// Register a new configuration item<br>// * name&nbsp;: String, internal name<br>// * default_value&nbsp;: String or Boolean (type determines configuration widget)<br>// * description&nbsp;: String, text appearing next to the widget in the preferences<br>// * prefpage&nbsp;: Integer (optional), section in the preferences to insert the widget:<br>// 0&nbsp;: User profile<br>// 1&nbsp;: Skin<br>// 2&nbsp;: Math<br>// 3&nbsp;: Files<br>// 4&nbsp;: Date and time<br>// 5&nbsp;: Editing<br>// 6&nbsp;: Recent changes<br>// 7&nbsp;: Watchlist<br>// 8&nbsp;: Search<br>// 9&nbsp;: Misc<br>//<br>// Access keys through JSconfig.keys[name]<br>//<br>registerKey&nbsp;: function( name, default_value, description, prefpage )<br>{<br> if( typeof(JSconfig.keys[name]) == 'undefined' ) <br> JSconfig.keys[name] = default_value;<br> else {<br> <br> // all cookies are read as strings, <br> // convert to the type of the default value<br> switch( typeof(default_value) )<br> {<br> case 'boolean'&nbsp;: JSconfig.keys[name] = ( JSconfig.keys[name] == 'true' ); break;<br> case 'number'&nbsp;: JSconfig.keys[name] = JSconfig.keys[name]/1; break;<br> }<br> <br> }<br> <br> JSconfig.meta[name] = { 'description'&nbsp;: description, 'page'&nbsp;: prefpage || 0, 'default_value'&nbsp;: default_value };<br>},<br> <br>readCookies&nbsp;: function()<br>{<br> var cookies = document.cookie.split("; ");<br> var p =JSconfig.prefix.length;<br> var i;<br> <br> for( var key in cookies )<br> {<br> if( cookies[key].substring(0,p) == JSconfig.prefix )<br> {<br> i = cookies[key].indexOf('=');<br> //alert( cookies[key] + ',' + key + ',' + cookies[key].substring(p,i) );<br> JSconfig.keys[cookies[key].substring(p,i)] = cookies[key].substring(i+1);<br> }<br> }<br>},<br> <br>writeCookies&nbsp;: function()<br>{<br> for( var key in JSconfig.keys )<br> document.cookie = JSconfig.prefix + key + '=' + JSconfig.keys[key] + '; path=/; expires=Thu, 2 Aug 2009 10:10:10 UTC';<br>},<br> <br>evaluateForm&nbsp;: function()<br>{<br> var w_ctrl,wt;<br> //alert('about to save JSconfig');<br> for( var key in JSconfig.meta ) {<br> w_ctrl = document.getElementById( JSconfig.prefix + key )<br> if( w_ctrl ) <br> {<br> wt = typeof( JSconfig.meta[key].default_value );<br> switch( wt ) {<br> case 'boolean'&nbsp;: JSconfig.keys[key] = w_ctrl.checked; break;<br> case 'string'&nbsp;: JSconfig.keys[key] = w_ctrl.value; break;<br> }<br> }<br> }<br> <br> JSconfig.writeCookies();<br> return true;<br>},<br> <br>setUpForm&nbsp;: function()<br>{ <br> var prefChild = document.getElementById('preferences');<br> if(&nbsp;!prefChild ) return;<br> prefChild = prefChild.childNodes;<br> <br> //<br> // make a list of all preferences sections<br> //<br> var tabs = new Array;<br> var len = prefChild.length;<br> for( var key = 0; key &lt; len; key++ ) {<br> if( prefChild[key].tagName &amp;&amp;<br> prefChild[key].tagName.toLowerCase() == 'fieldset' ) <br> tabs.push(prefChild[key]);<br> }<br> <br> //<br> // Create Widgets for all registered config keys<br> //<br> var w_div, w_label, w_ctrl, wt;<br> for( var key in JSconfig.meta ) {<br> w_div = document.createElement( 'DIV' );<br> <br> w_label = document.createElement( 'LABEL' );<br> w_label.appendChild( document.createTextNode( JSconfig.meta[key].description ) )<br> w_label.htmlFor = JSconfig.prefix + key;<br> <br> wt = typeof( JSconfig.meta[key].default_value );<br> <br> w_ctrl = document.createElement( 'INPUT' );<br> w_ctrl.id = JSconfig.prefix + key;<br> <br> // before insertion into the DOM tree<br> switch( wt ) {<br> case 'boolean'&nbsp;: w_ctrl.type = 'checkbox'; break;<br> case 'string'&nbsp;: w_ctrl.type = 'text'; break;<br> }<br> <br> w_div.appendChild( w_label );<br> w_div.appendChild( w_ctrl );<br> tabs[JSconfig.meta[key].page].appendChild( w_div );<br> <br> // after insertion into the DOM tree<br> switch( wt ) {<br> case 'boolean'&nbsp;: w_ctrl.defaultChecked = w_ctrl.checked = JSconfig.keys[key]; break;<br> case 'string'&nbsp;: w_ctrl.defaultValue = w_ctrl.value = JSconfig.keys[key]; break;<br> }<br> <br> }<br> addHandler(document.getElementById('preferences').parentNode, 'submit', JSconfig.evaluateForm );<br>}<br>}<br> <br>JSconfig.readCookies();<br>addOnloadHook(JSconfig.setUpForm);<br> <br>// ability to pull [[MediaWiki:Gadget-rtl.css|MediaWiki:Gadget-rtl.css]] on individual page loads by [[Testwiki:User:Splarka|testwiki:User:Splarka]] and [[Wm2008:User:Mr.Z-man|wm2008:User:Mr.Z-man]]<br>function importStylesheet(page) {<br> if (page.indexOf('http://') == -1 &amp;&amp; page.indexOf('https://') == -1 &amp;&amp; page.indexOf('file:///') == -1)<br> page = wgScript + '?action=raw&amp;ctype=text/css&amp;smaxage=0&amp;title='<br> + encodeURIComponent(page.replace(/ /g,'_'))<br> return document.createStyleSheet&nbsp;? document.createStyleSheet(page)&nbsp;: appendCSS('@import "' + page + '";')<br>}<br> <br>function appendCSS(text){<br>var s = document.createElement('style')<br>s.setAttribute('type', 'text/css')<br>if (s.styleSheet) s.styleSheet.cssText = text //IE<br>else s.appendChild(document.createTextNode(text))<br>document.getElementsByTagName('head')[0].appendChild(s)<br>return s<br>}<br> <br>if(document.URL.indexOf('rtl=1')&nbsp;!= -1) importStylesheet('http://meta.wikimedia.org/w/index.php?title=MediaWiki:Gadget-rtl.css&amp;action=raw&amp;ctype=text/css');<br> <br>//import module<br>importedScripts = {} <br>function importScript(page, lang) {<br>page = '?title=' + encodeURIComponent(page.replace(' ','_'))<br>if (lang) page = 'http://' + lang + '.wikipedia.org/w/index.php' + page<br>else page = wgScript + page<br>if (importedScripts[page]) return<br>importedScripts[page] = true<br>var s = document.createElement('script')<br>s.type = 'text/javascript'<br>s.src = page + '&amp;action=raw&amp;ctype=text/javascript'<br>document.getElementsByTagName('head')[0].appendChild(s)<br>}<br> <br>// Fix links like User:Example@somewiki. Author: VasilievVV, with modifications by Kalan and attempted rewrite by Splarka<br>if(wgCanonicalSpecialPageName == 'Log' || wgCanonicalSpecialPageName == 'Recentchanges')<br> importScript('MediaWiki:Common.js/interlinker.js')<br> <br> if(wgCanonicalSpecialPageName == 'GlobalBlock' &amp;&amp; window.wgUserGroups &amp;&amp; wgUserGroups.join(' ').indexOf('steward')&nbsp;!= -1)<br> addOnloadHook(function() {<br> document.getElementById('wpAnonOnly').checked = true;<br> addHandler(document.forms['uluser'],'submit',addblocktype);<br> });<br> <br> function addblocktype() { // DerHexer<br> if (document.getElementById('wpAnonOnly').checked == true) {<br> document.getElementById('mw-globalblocking-block-reason').getElementsByTagName('input')[0].value += ' (sb)';<br> } else {<br> document.getElementById('mw-globalblocking-block-reason').getElementsByTagName('input')[0].value += ' (hb)';<br> }<br> }<br> <br>// stolen from [[:commons:MediaWiki:Common.js|:commons:MediaWiki:Common.js]] by [[:commons:User:Remember_the_dot|:commons:User:Remember_the_dot]] - thanks<br>// Import language-specific stylesheet, especially useful for languages like German that have (un)usual capitalization rules<br>//<br>importStylesheet("MediaWiki:" + skin + ".css/" + wgUserLanguage);<br> <br>/**<br> * Implements language selection for multilingual elements<br> * <br> * In certain environments, it's not feasible to neatly box away each<br> * different language into its own section of the site. By marking elements<br> * multilingual, you can emulate this behavior by only displaying the <br> * message in the user's language. This reduced the "Tower of Babel" effect.<br> * <br> * @author Edward Z. Yang (Ambush Commander)<br> * @version $Id: language_select.js 1358 2007-02-19 15:34:59Z Edward $<br> */<br> <br>/* Configuration: */<br> <br>// in your monobook.js, set ls_enable = false to stop the javascript<br>// maybe it should be cookie configurable. However, you can achieve<br>// something almost to this effect through cookie settings<br>var ls_enable = true;<br> <br>// the cookie name we use to stash the info.<br>// change this if you are porting it to another wiki!<br>var ls_cookie = 'metawiki_language_js';<br> <br>// link to the language select page<br>var ls_help_url = 'http://meta.wikimedia.org/wiki/Meta:Language_select';<br> <br>// strings that are part of the widgets<br>var ls_string_help = 'Language select:';<br>var ls_string_select = 'Select';<br>var ls_string_showall = 'Show all';<br> <br>// define some meta-variables<br>var ls__first = true; // the first iteration?<br> <br>// node compatability fix<br>if (!window.Node) {<br> var Node = {<br> ELEMENT_NODE&nbsp;: 1,<br> ATTRIBUTE_NODE: 2,<br> TEXT_NODE: 3,<br> COMMENT_NODE: 8,<br> DOCUMENT_NODE: 9,<br> DOCUMENT_FRAGMENT_NODE: 11<br> };<br>}<br> <br>// autodetects a browser language<br>function ls_getBrowserLanguage() {<br> var language;<br> // borrowed from Wikimedia's site error notice<br> // find the language<br> if (navigator.userLanguage) {<br> // use the user's preferred language (non-Gecko)<br> language = navigator.userLanguage;<br> } else if (navigator.appName == 'Netscape') {<br> // use the only language information available to Gecko<br> language = navigator.language;<br> } else {<br> // get the browser language information in non-Gecko browsers<br> // (IE, Opera, Konqueror)<br> language = navigator.browserLanguage;<br> }<br> return language;<br>}<br> <br>// grabs language from cookie<br>function ls_getCookieLanguage() {<br> var allcookies = document.cookie;<br> var marker = ls_cookie + '=';<br> var pos = allcookies.indexOf(marker);<br> <br> // cookie isn't set, so no behavior defined<br> if (pos === -1) return null;<br> <br> // cookie is set<br> var start = pos + marker.length;<br> var end = allcookies.indexOf(';', start);<br> if (end == -1) end = allcookies.length;<br> <br> var raw = allcookies.substring(start,end);<br> var value = unescape(raw);<br> <br> return value;<br>}<br> <br>// sets a new language to the cookie<br>function ls_setCookieLanguage(language) {<br> var today = new Date();<br> var expiry = new Date(today.getUTCFullYear() + 30, 1);<br> document.cookie = ls_cookie + '=' + escape(language) + '; expires=' + expiry.toGMTString();<br>}<br> <br>// deletes the cookie<br>function ls_deleteCookieLanguage(language) {<br> document.cookie = ls_cookie + '=; expires=Fri, 02-Jan-1970 00:00:00 GMT';<br>}<br> <br>// grabs the ISO 639 language code based<br>// on either the browser or a supplied cookie<br>// return of "mul" will display all available strings<br>function ls_getLanguage() {<br> var language = '';<br> <br> // Priority:<br> // 1. Cookie<br> // 2. wgUserLanguage global variable<br> // 3. Browser autodetection<br> <br> // grab according to cookie<br> language = ls_getCookieLanguage();<br> <br> // grab according to wgUserLanguage<br> if (!language &amp;&amp; window.wgUserLanguage) {<br> language = wgUserLanguage;<br> }<br> <br> // grab according to browser if none defined<br> if (!language) {<br> language = ls_getBrowserLanguage();<br> }<br> <br> // inflexible: can't accept multiple languages<br> <br> // remove dialect/region code, leaving only the ISO 639 code<br> var length;<br> // possible bug: supposedly the language string could be en_US<br> // switch to regexps when we get the chance<br> if ((length = language.indexOf('-'))&nbsp;!== -1) {<br> language = language.substr(0, length);<br> }<br> <br> return language;<br>}<br> <br>// walks all child elements and finds all elements with multilingual in them<br>function ls_getAllMultilingualElements(n) {<br> var elements = new Array();<br> // possible bug if we have a classname that includes the word multilingual<br> // but it's unlikely<br> if (n.className &amp;&amp; n.className.indexOf('multilingual')&nbsp;!= -1) {<br> elements = elements.concat(n);<br> }<br> var children = n.childNodes;<br> for(var i=0; i &lt; children.length; i++) {<br> if (children[i].nodeType&nbsp;!== Node.ELEMENT_NODE) continue;<br> elements = elements.concat(ls_getAllMultilingualElements(children[i]));<br> }<br> return elements;<br>}<br> <br>// walks a hash and hides all non-matching languages<br>function ls_hideAllExcept(lang_element_hash, language) {<br> for (var n in lang_element_hash) {<br> if (n == language) {<br> lang_element_hash[n].style.display = '';<br> } else {<br> lang_element_hash[n].style.display = 'none';<br> }<br> }<br>}<br> <br>// walks a hash and shows all languages<br>function ls_showAll(lang_element_hash) {<br> for (var n in lang_element_hash) {<br> if (lang_element_hash[n].style.display) {<br> lang_element_hash[n].style.display = '';<br> }<br> }<br>}<br> <br>// build widget for changing the language cookie<br>function ls_buildWidget(language) {<br> <br> // set up the floating form<br> var form = document.createElement('form');<br> form.className = 'lang_info';<br> form.onsubmit = function() {<br> if (this.elements[2].ls_mul_flag) {<br> this.elements[2].ls_mul_flag = false;<br> var language = 'mul';<br> var temporary = true;<br> } else {<br> ls_setCookieLanguage(this.elements[0].value);<br> var language = this.elements[0].value;<br> var temporary = false;<br> }<br> ls_applyLanguageSelect(language, temporary);<br> <br> return false; // don't perform action<br> };<br> form.appendSpace = function() {<br> this.appendChild(document.createTextNode(' '));<br> };<br> <br> // link to language select description page<br> var link = document.createElement('a');<br> link.href = ls_help_url;<br> link.className = 'ls_link';<br> link.appendChild(document.createTextNode(ls_string_help));<br> form.appendChild(link);<br> <br> form.appendSpace();<br> <br> // input box for the language<br> var input = document.createElement('input');<br> input.setAttribute('type', 'text');<br> input.setAttribute('size', '2');<br>// input.setAttribute('maxlength', '7');<br> input.onclick = function() { this.select(); };<br> input.className = 'ls_input';<br> input.value = language;<br> form.appendChild(input);<br> <br> form.appendSpace();<br> <br> // save button<br> var submit = document.createElement('input');<br> submit.setAttribute('type', 'submit');<br> submit.value = ls_string_select;<br> submit.className = 'ls_select';<br> form.appendChild(submit);<br> <br> form.appendSpace();<br> <br> // show all button <br> // equivalent to setting input box to "mul" and pressing save<br> var showall = document.createElement('input');<br> showall.setAttribute('type', 'submit');<br> showall.value = ls_string_showall;<br> showall.onclick = function() {<br> this.ls_mul_flag = true;<br> };<br> form.appendChild(showall);<br> <br> return form;<br> <br>}<br> <br>// main body of the function<br>function ls_applyLanguageSelect(language, temporary) {<br> <br> // possible site for cookie checking to disable language select<br> if (!ls_enable) return;<br> <br> // if language is blank, delete the cookie and then recalculate<br> if (!language) {<br> ls_deleteCookieLanguage();<br> language = ls_getLanguage();<br> }<br> <br> // grab the body element (only one)<br> var body = document.getElementsByTagName('body')[0];<br> <br> // grab an array of multilingual elements<br> var mls = ls_getAllMultilingualElements(body);<br> <br> // this will get overwritten many times, temporary variable<br> var form, language_element_hash;<br> <br> // iterate through all those elements<br> for (var i = 0; i &lt; mls.length; i++) {<br> var ml = mls[i]; // the current multilingual container<br> var ml_c = ml.childNodes; // children of the container<br> <br> // if it's the first iteration...<br> if (ls__first) {<br> form = ls_buildWidget(language);<br> ml.appendChild(form, ml_c[0]);<br> } else {<br> // update widget<br> form = ml_c[ml_c.length - 1]; // form is last element<br> if (!temporary) {<br> form.elements[0].value = language;<br> form.elements[0].removeAttribute('disabled');<br> form.elements[2].removeAttribute('disabled');<br> } else {<br> form.elements[0].setAttribute('disabled', 'disabled');<br> form.elements[2].setAttribute('disabled', 'disabled');<br> }<br> }<br> <br> form.elements[0].style.background="#FFF";<br> <br> // tells us whether or not to blindly perform the keep<br> var message_exists = false;<br> <br> // iterate through all languages and set up a hash<br> // with references to each of the language nodes<br> lang_element_hash = new Object();<br> for (var j = 0; j &lt; ml_c.length; j++) {<br> var n = ml_c[j];<br> if (n.nodeType&nbsp;!= Node.ELEMENT_NODE) continue; // skip non-elements<br> if (!n.lang) continue; // skip non-language specific elements<br> if (n.lang.indexOf(language) === 0) {<br> // it turns out our language is here<br> message_exists = true;<br> }<br> lang_element_hash[n.lang] = n;<br> }<br> <br> // if a preferred language was kept, do quickest processing<br> if (message_exists) {<br> ls_hideAllExcept(lang_element_hash, language);<br> continue;<br> }<br> <br> // otherwise, nothing happened, this means that it wasn't found<br> <br> // if it's not the first time, repaint all of them<br> if (!ls__first) {<br> ls_showAll(lang_element_hash);<br> }<br> <br> if (language&nbsp;!= 'mul') {<br> form.elements[0].style.background="#FCC";<br> }<br> <br> }<br> <br> // we've already processed once<br> ls__first = false;<br> <br>}<br> <br>function ls_applyDefaultLanguageSelect() {<br> ls_applyLanguageSelect(ls_getLanguage(), false);<br>}<br> <br>// register as onload function (there must be a better way)<br>if (window.addEventListener) {<br> window.addEventListener("load", ls_applyDefaultLanguageSelect, false);<br>} else if (window.attachEvent) {<br> window.attachEvent("onload", ls_applyDefaultLanguageSelect);<br>}''
+
/*<source lang="javascript">*/
 +
 
 +
/** Collapsible tables *********************************************************
 +
  *
 +
  *  Description: Allows tables to be collapsed, showing only the header. See
 +
  *              [[Wikipedia:NavFrame]].
 +
  *  Maintainer on Wikipedia: [[User:R. Koot]]
 +
  */
 +
 +
var autoCollapse = 2;
 +
var collapseCaption = "hide";
 +
var expandCaption = "show";
 +
 +
function hasClass( element, className ) {
 +
  var Classes = element.className.split( " " );
 +
  for ( var i = 0; i < Classes.length; i++ ) {
 +
    if ( Classes[i] == className ) {
 +
      return ( true );
 +
    }
 +
  }
 +
  return ( false );
 +
}
 +
 
 +
function collapseTable( tableIndex )
 +
{
 +
    var Button = document.getElementById( "collapseButton" + tableIndex );
 +
    var Table = document.getElementById( "collapsibleTable" + tableIndex );
 +
 +
    if ( !Table || !Button ) {
 +
        return false;
 +
    }
 +
 +
    var Rows = Table.getElementsByTagName( "tr" );
 +
 +
    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" ) ) {
 +
            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.style.styleFloat = "right";
 +
            Button.style.cssFloat = "right";
 +
            Button.style.fontWeight = "normal";
 +
            Button.style.textAlign = "right";
 +
            Button.style.width = "6em";
 +
 +
            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( "]" ) );
 +
 +
            var Header = Tables[i].getElementsByTagName( "tr" )[0].getElementsByTagName( "th" )[0];
 +
            /* only add button and increment count if there is a header row to work with */
 +
            if (Header) {
 +
                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 );
 +
        }
 +
    }
 +
}
 +
 +
addOnloadHook( 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, 'NavPic' ) ) {
 +
                NavChild.style.display = 'none';
 +
            }
 +
            if ( hasClass( NavChild, 'NavContent') ) {
 +
                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, 'NavPic')) {
 +
                NavChild.style.display = 'block';
 +
            }
 +
            if (hasClass(NavChild, 'NavContent')) {
 +
                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 NavToggleText = document.createTextNode(NavigationBarHide);
 +
            for (var NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling) {
 +
                if ( hasClass( NavChild, 'NavPic' ) || hasClass( NavChild, 'NavContent' ) ) {
 +
                    if (NavChild.style.display == 'none') {
 +
                        NavToggleText = document.createTextNode(NavigationBarShow);
 +
                        break;
 +
                    }
 +
                }
 +
            }
 +
 
 +
            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 );
 +
 
 +
 
 +
//Shuffle for election candidates
 +
function dshuf(){
 +
                var shufsets=new Object()
 +
                var rx=new RegExp('dshuf'+'\\s+(dshufset\\d+)', 'i')
 +
                var divs=document.getElementsByTagName("div")
 +
                for (var i=0; i<divs.length; i++){
 +
                        if (rx.test(divs[i].className)){
 +
                                if (typeof shufsets[RegExp.$1]=="undefined"){
 +
                                        shufsets[RegExp.$1]=new Object()
 +
                                        shufsets[RegExp.$1].inner=[]
 +
                                        shufsets[RegExp.$1].member=[]
 +
                                }
 +
                                        shufsets[RegExp.$1].inner.push(divs[i].innerHTML)
 +
                                        shufsets[RegExp.$1].member.push(divs[i])
 +
                        }
 +
                }
 +
                for (shufset in shufsets){
 +
                        shufsets[shufset].inner.sort(function() {return 0.5 - Math.random()})
 +
                        for (var i=0; i<shufsets[shufset].member.length; i++){
 +
                                shufsets[shufset].member[i].innerHTML=shufsets[shufset].inner[i]
 +
                                shufsets[shufset].member[i].style.display="block"
 +
                        }
 +
                }
 +
 
 +
}
 +
 
 +
addOnloadHook(dshuf);
 +
 
 +
/*************
 +
*** AJAX transclusion table <http://meta.wikimedia.org/wiki/User:Pathoschild/Scripts/AJAX_transclusion_table>
 +
*** by [[m:user:Pathoschild]]
 +
*************/
 +
function attLoader() {
 +
if(getElementsByClassName(document.getElementsByTagName('body')[0],'table','attable').length) {
 +
        document.write('<script type="text/javascript" src="'
 +
          + 'http://meta.wikimedia.org/w/index.php?title=User:Pathoschild/Scripts/AJAX_transclusion_table.js'
 +
          + '&action=raw&ctype=text/javascript&dontcountme=s"></script>');
 +
}
 +
}
 +
addOnloadHook(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();
 +
addOnloadHook(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('file:///') == -1)
 +
    page = wgScript + '?action=raw&ctype=text/css&smaxage=0&title='
 +
    + encodeURIComponent(page.replace(/ /g,'_'))
 +
  return document.createStyleSheet ? document.createStyleSheet(page) : appendCSS('@import "' + page + '";')
 +
}
 +
 +
function appendCSS(text){
 +
var s = document.createElement('style')
 +
s.setAttribute('type', 'text/css')
 +
if (s.styleSheet) s.styleSheet.cssText = text //IE
 +
else s.appendChild(document.createTextNode(text))
 +
document.getElementsByTagName('head')[0].appendChild(s)
 +
return s
 +
}
 +
 +
if(document.URL.indexOf('rtl=1') != -1) importStylesheet('http://meta.wikimedia.org/w/index.php?title=MediaWiki:Gadget-rtl.css&action=raw&ctype=text/css');
 +
 
 +
//import module
 +
importedScripts = {}
 +
function importScript(page, lang) {
 +
page = '?title=' + encodeURIComponent(page.replace(' ','_'))
 +
if (lang) page = 'http://' + lang + '.wikipedia.org/w/index.php' + page
 +
else page = wgScript + page
 +
if (importedScripts[page]) return
 +
importedScripts[page] = true
 +
var s = document.createElement('script')
 +
s.type = 'text/javascript'
 +
s.src = page + '&action=raw&ctype=text/javascript'
 +
document.getElementsByTagName('head')[0].appendChild(s)
 +
}
 +
 
 +
// Fix links like User:Example@somewiki. Author: VasilievVV, with modifications by Kalan and attempted rewrite by Splarka
 +
if(wgCanonicalSpecialPageName == 'Log' || wgCanonicalSpecialPageName == 'Recentchanges')
 +
importScript('MediaWiki:Common.js/interlinker.js')
 +
 +
if(wgCanonicalSpecialPageName == 'GlobalBlock' && window.wgUserGroups && wgUserGroups.join(' ').indexOf('steward') != -1)
 +
addOnloadHook(function() {
 +
  document.getElementById('wpAnonOnly').checked = true;
 +
  addHandler(document.forms['uluser'],'submit',addblocktype);
 +
});
 +
 +
function addblocktype() { // DerHexer
 +
  if (document.getElementById('wpAnonOnly').checked == true) {
 +
    document.getElementById('mw-globalblocking-block-reason').getElementsByTagName('input')[0].value += ' (sb)';
 +
  } else {
 +
    document.getElementById('mw-globalblocking-block-reason').getElementsByTagName('input')[0].value += ' (hb)';
 +
  }
 +
}
 +
 
 +
// 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);
 +
 
 +
/**
 +
* Implements language selection for multilingual elements
 +
*
 +
* In certain environments, it's not feasible to neatly box away each
 +
* different language into its own section of the site. By marking elements
 +
* multilingual, you can emulate this behavior by only displaying the
 +
* message in the user's language. This reduced the "Tower of Babel" effect.
 +
*
 +
* @author Edward Z. Yang (Ambush Commander)
 +
* @version $Id: language_select.js 1358 2007-02-19 15:34:59Z Edward $
 +
*/
 +
 
 +
/* Configuration: */
 +
 
 +
// in your monobook.js, set ls_enable = false to stop the javascript
 +
// maybe it should be cookie configurable. However, you can achieve
 +
// something almost to this effect through cookie settings
 +
var ls_enable = true;
 +
 
 +
// the cookie name we use to stash the info.
 +
// change this if you are porting it to another wiki!
 +
var ls_cookie = 'metawiki_language_js';
 +
 
 +
// link to the language select page
 +
var ls_help_url = 'http://meta.wikimedia.org/wiki/Meta:Language_select';
 +
 
 +
// strings that are part of the widgets
 +
var ls_string_help = 'Language select:';
 +
var ls_string_select = 'Select';
 +
var ls_string_showall = 'Show all';
 +
 
 +
// define some meta-variables
 +
var ls__first = true; // the first iteration?
 +
 
 +
// node compatability fix
 +
if (!window.Node) {
 +
    var Node = {
 +
        ELEMENT_NODE : 1,
 +
        ATTRIBUTE_NODE: 2,
 +
        TEXT_NODE: 3,
 +
        COMMENT_NODE: 8,
 +
        DOCUMENT_NODE: 9,
 +
        DOCUMENT_FRAGMENT_NODE: 11
 +
    };
 +
}
 +
 
 +
// autodetects a browser language
 +
function ls_getBrowserLanguage() {
 +
    var language;
 +
    // borrowed from Wikimedia's site error notice
 +
    // find the language
 +
    if (navigator.userLanguage) {
 +
        // use the user's preferred language (non-Gecko)
 +
        language = navigator.userLanguage;
 +
    } else if (navigator.appName == 'Netscape') {
 +
        // use the only language information available to Gecko
 +
        language = navigator.language;
 +
    } else {
 +
        // get the browser language information in non-Gecko browsers
 +
        // (IE, Opera, Konqueror)
 +
        language = navigator.browserLanguage;
 +
    }
 +
    return language;
 +
}
 +
 
 +
// grabs language from cookie
 +
function ls_getCookieLanguage() {
 +
    var allcookies = document.cookie;
 +
    var marker = ls_cookie + '=';
 +
    var pos = allcookies.indexOf(marker);
 +
   
 +
    // cookie isn't set, so no behavior defined
 +
    if (pos === -1) return null;
 +
   
 +
    // cookie is set
 +
    var start = pos + marker.length;
 +
    var end  = allcookies.indexOf(';', start);
 +
    if (end == -1) end = allcookies.length;
 +
   
 +
    var raw  = allcookies.substring(start,end);
 +
    var value = unescape(raw);
 +
   
 +
    return value;
 +
}
 +
 
 +
// sets a new language to the cookie
 +
function ls_setCookieLanguage(language) {
 +
    var today = new Date();
 +
    var expiry = new Date(today.getUTCFullYear() + 30, 1);
 +
    document.cookie = ls_cookie + '=' + escape(language) + '; expires=' + expiry.toGMTString();
 +
}
 +
 
 +
// deletes the cookie
 +
function ls_deleteCookieLanguage(language) {
 +
    document.cookie = ls_cookie + '=; expires=Fri, 02-Jan-1970 00:00:00 GMT';
 +
}
 +
 
 +
// grabs the ISO 639 language code based
 +
// on either the browser or a supplied cookie
 +
// return of "mul" will display all available strings
 +
function ls_getLanguage() {
 +
    var language = '';
 +
   
 +
    // Priority:
 +
    //  1. Cookie
 +
    //  2. wgUserLanguage global variable
 +
    //  3. Browser autodetection
 +
   
 +
    // grab according to cookie
 +
    language = ls_getCookieLanguage();
 +
   
 +
    // grab according to wgUserLanguage
 +
    if (!language && window.wgUserLanguage) {
 +
        language = wgUserLanguage;
 +
    }
 +
   
 +
    // grab according to browser if none defined
 +
    if (!language) {
 +
        language = ls_getBrowserLanguage();
 +
    }
 +
   
 +
    // inflexible: can't accept multiple languages
 +
   
 +
    // remove dialect/region code, leaving only the ISO 639 code
 +
    var length;
 +
    // possible bug: supposedly the language string could be en_US
 +
    // switch to regexps when we get the chance
 +
    if ((length = language.indexOf('-')) !== -1) {
 +
        language = language.substr(0, length);
 +
    }
 +
   
 +
    return language;
 +
}
 +
 
 +
// walks all child elements and finds all elements with multilingual in them
 +
function ls_getAllMultilingualElements(n) {
 +
    var elements = new Array();
 +
    // possible bug if we have a classname that includes the word multilingual
 +
    //  but it's unlikely
 +
    if (n.className && n.className.indexOf('multilingual') != -1) {
 +
        elements = elements.concat(n);
 +
    }
 +
    var children = n.childNodes;
 +
    for(var i=0; i < children.length; i++) {
 +
        if (children[i].nodeType !== Node.ELEMENT_NODE) continue;
 +
        elements = elements.concat(ls_getAllMultilingualElements(children[i]));
 +
    }
 +
    return elements;
 +
}
 +
 
 +
// walks a hash and hides all non-matching languages
 +
function ls_hideAllExcept(lang_element_hash, language) {
 +
    for (var n in lang_element_hash) {
 +
        if (n == language) {
 +
            lang_element_hash[n].style.display = '';
 +
        } else {
 +
            lang_element_hash[n].style.display = 'none';
 +
        }
 +
    }
 +
}
 +
 
 +
// walks a hash and shows all languages
 +
function ls_showAll(lang_element_hash) {
 +
    for (var n in lang_element_hash) {
 +
        if (lang_element_hash[n].style.display) {
 +
            lang_element_hash[n].style.display = '';
 +
        }
 +
    }
 +
}
 +
 
 +
// build widget for changing the language cookie
 +
function ls_buildWidget(language) {
 +
 
 +
    // set up the floating form
 +
    var form = document.createElement('form');
 +
    form.className = 'lang_info';
 +
    form.onsubmit = function() {
 +
        if (this.elements[2].ls_mul_flag) {
 +
            this.elements[2].ls_mul_flag = false;
 +
            var language = 'mul';
 +
            var temporary = true;
 +
        } else {
 +
            ls_setCookieLanguage(this.elements[0].value);
 +
            var language = this.elements[0].value;
 +
            var temporary = false;
 +
        }
 +
        ls_applyLanguageSelect(language, temporary);
 +
       
 +
        return false; // don't perform action
 +
    };
 +
    form.appendSpace = function() {
 +
        this.appendChild(document.createTextNode(' '));
 +
    };
 +
   
 +
    // link to language select description page
 +
    var link = document.createElement('a');
 +
    link.href = ls_help_url;
 +
    link.className = 'ls_link';
 +
    link.appendChild(document.createTextNode(ls_string_help));
 +
    form.appendChild(link);
 +
   
 +
    form.appendSpace();
 +
   
 +
    // input box for the language
 +
    var input = document.createElement('input');
 +
    input.setAttribute('type', 'text');
 +
    input.setAttribute('size', '2');
 +
//    input.setAttribute('maxlength', '7');
 +
    input.onclick = function() { this.select(); };
 +
    input.className = 'ls_input';
 +
    input.value = language;
 +
    form.appendChild(input);
 +
   
 +
    form.appendSpace();
 +
   
 +
    // save button
 +
    var submit = document.createElement('input');
 +
    submit.setAttribute('type', 'submit');
 +
    submit.value = ls_string_select;
 +
    submit.className = 'ls_select';
 +
    form.appendChild(submit);
 +
   
 +
    form.appendSpace();
 +
   
 +
    // show all button
 +
    // equivalent to setting input box to "mul" and pressing save
 +
    var showall = document.createElement('input');
 +
    showall.setAttribute('type', 'submit');
 +
    showall.value = ls_string_showall;
 +
    showall.onclick = function() {
 +
        this.ls_mul_flag = true;
 +
    };
 +
    form.appendChild(showall);
 +
   
 +
    return form;
 +
   
 +
}
 +
 
 +
// main body of the function
 +
function ls_applyLanguageSelect(language, temporary) {
 +
   
 +
    // possible site for cookie checking to disable language select
 +
    if (!ls_enable) return;
 +
   
 +
    // if language is blank, delete the cookie and then recalculate
 +
    if (!language) {
 +
        ls_deleteCookieLanguage();
 +
        language = ls_getLanguage();
 +
    }
 +
   
 +
    // grab the body element (only one)
 +
    var body = document.getElementsByTagName('body')[0];
 +
   
 +
    // grab an array of multilingual elements
 +
    var mls = ls_getAllMultilingualElements(body);
 +
   
 +
    // this will get overwritten many times, temporary variable
 +
    var form, language_element_hash;
 +
   
 +
    // iterate through all those elements
 +
    for (var i = 0; i < mls.length; i++) {
 +
        var ml  = mls[i];        // the current multilingual container
 +
        var ml_c = ml.childNodes; // children of the container
 +
       
 +
        // if it's the first iteration...
 +
        if (ls__first) {
 +
            form = ls_buildWidget(language);
 +
            ml.appendChild(form, ml_c[0]);
 +
        } else {
 +
            // update widget
 +
            form = ml_c[ml_c.length - 1]; // form is last element
 +
            if (!temporary) {
 +
                form.elements[0].value = language;
 +
                form.elements[0].removeAttribute('disabled');
 +
                form.elements[2].removeAttribute('disabled');
 +
            } else {
 +
                form.elements[0].setAttribute('disabled', 'disabled');
 +
                form.elements[2].setAttribute('disabled', 'disabled');
 +
            }
 +
        }
 +
       
 +
        form.elements[0].style.background="#FFF";
 +
       
 +
        // tells us whether or not to blindly perform the keep
 +
        var message_exists  = false;
 +
       
 +
        // iterate through all languages and set up a hash
 +
        //  with references to each of the language nodes
 +
        lang_element_hash = new Object();
 +
        for (var j = 0; j < ml_c.length; j++) {
 +
            var n = ml_c[j];
 +
            if (n.nodeType != Node.ELEMENT_NODE) continue; // skip non-elements
 +
            if (!n.lang) continue; // skip non-language specific elements
 +
            if (n.lang.indexOf(language) === 0) {
 +
                // it turns out our language is here
 +
                message_exists  = true;
 +
            }
 +
            lang_element_hash[n.lang] = n;
 +
        }
 +
       
 +
        // if a preferred language was kept, do quickest processing
 +
        if (message_exists) {
 +
            ls_hideAllExcept(lang_element_hash, language);
 +
            continue;
 +
        }
 +
       
 +
        // otherwise, nothing happened, this means that it wasn't found
 +
       
 +
        // if it's not the first time, repaint all of them
 +
        if (!ls__first) {
 +
            ls_showAll(lang_element_hash);
 +
        }
 +
       
 +
        if (language != 'mul') {
 +
            form.elements[0].style.background="#FCC";
 +
        }
 +
       
 +
    }
 +
   
 +
    // we've already processed once
 +
    ls__first = false;
 +
   
 +
}
 +
 
 +
function ls_applyDefaultLanguageSelect() {
 +
    ls_applyLanguageSelect(ls_getLanguage(), false);
 +
}
 +
 
 +
// register as onload function (there must be a better way)
 +
if (window.addEventListener) {
 +
    window.addEventListener("load", ls_applyDefaultLanguageSelect, false);
 +
} else if (window.attachEvent) {
 +
    window.attachEvent("onload", ls_applyDefaultLanguageSelect);
 +
}

Latest revision as of 23:59, 19 February 2009

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

/*<source lang="javascript">*/

/** Collapsible tables *********************************************************
  *
  *  Description: Allows tables to be collapsed, showing only the header. See
  *               [[Wikipedia:NavFrame]].
  *  Maintainer on Wikipedia: [[User:R. Koot]]
  */
 
var autoCollapse = 2;
var collapseCaption = "hide";
var expandCaption = "show";
 
function hasClass( element, className ) {
  var Classes = element.className.split( " " );
  for ( var i = 0; i < Classes.length; i++ ) {
    if ( Classes[i] == className ) {
      return ( true );
    }
  }
  return ( false );
}

function collapseTable( tableIndex )
{
     var Button = document.getElementById( "collapseButton" + tableIndex );
     var Table = document.getElementById( "collapsibleTable" + tableIndex );
 
     if ( !Table || !Button ) {
         return false;
     }
 
     var Rows = Table.getElementsByTagName( "tr" ); 
 
     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" ) ) {
             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.style.styleFloat = "right";
             Button.style.cssFloat = "right";
             Button.style.fontWeight = "normal";
             Button.style.textAlign = "right";
             Button.style.width = "6em";
 
             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( "]" ) );
 
             var Header = Tables[i].getElementsByTagName( "tr" )[0].getElementsByTagName( "th" )[0];
             /* only add button and increment count if there is a header row to work with */
             if (Header) {
                 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 );
         }
     }
}
 
addOnloadHook( 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, 'NavPic' ) ) {
                NavChild.style.display = 'none';
            }
            if ( hasClass( NavChild, 'NavContent') ) {
                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, 'NavPic')) {
                NavChild.style.display = 'block';
            }
            if (hasClass(NavChild, 'NavContent')) {
                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 NavToggleText = document.createTextNode(NavigationBarHide);
            for (var NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling) {
                if ( hasClass( NavChild, 'NavPic' ) || hasClass( NavChild, 'NavContent' ) ) {
                    if (NavChild.style.display == 'none') {
                        NavToggleText = document.createTextNode(NavigationBarShow);
                        break;
                    }
                }
            }

            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 );


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

}

addOnloadHook(dshuf);

/*************
*** AJAX transclusion table <http://meta.wikimedia.org/wiki/User:Pathoschild/Scripts/AJAX_transclusion_table>
*** by [[m:user:Pathoschild]]
*************/
function attLoader() {
if(getElementsByClassName(document.getElementsByTagName('body')[0],'table','attable').length) {
         document.write('<script type="text/javascript" src="'
           + 'http://meta.wikimedia.org/w/index.php?title=User:Pathoschild/Scripts/AJAX_transclusion_table.js' 
           + '&action=raw&ctype=text/javascript&dontcountme=s"></script>');
}
}
addOnloadHook(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();
addOnloadHook(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('file:///') == -1)
     page = wgScript + '?action=raw&ctype=text/css&smaxage=0&title='
     + encodeURIComponent(page.replace(/ /g,'_'))
  return document.createStyleSheet ? document.createStyleSheet(page) : appendCSS('@import "' + page + '";')
}
 
function appendCSS(text){
var s = document.createElement('style')
s.setAttribute('type', 'text/css')
if (s.styleSheet) s.styleSheet.cssText = text //IE
else s.appendChild(document.createTextNode(text))
document.getElementsByTagName('head')[0].appendChild(s)
return s
}
 
if(document.URL.indexOf('rtl=1') != -1) importStylesheet('http://meta.wikimedia.org/w/index.php?title=MediaWiki:Gadget-rtl.css&action=raw&ctype=text/css');

//import module
importedScripts = {} 
function importScript(page, lang) {
page = '?title=' + encodeURIComponent(page.replace(' ','_'))
if (lang) page = 'http://' + lang + '.wikipedia.org/w/index.php' + page
else page = wgScript + page
if (importedScripts[page]) return
importedScripts[page] = true
var s = document.createElement('script')
s.type = 'text/javascript'
s.src = page + '&action=raw&ctype=text/javascript'
document.getElementsByTagName('head')[0].appendChild(s)
}

// Fix links like User:Example@somewiki. Author: VasilievVV, with modifications by Kalan and attempted rewrite by Splarka
if(wgCanonicalSpecialPageName == 'Log' || wgCanonicalSpecialPageName == 'Recentchanges')
	importScript('MediaWiki:Common.js/interlinker.js')
 
 if(wgCanonicalSpecialPageName == 'GlobalBlock' && window.wgUserGroups && wgUserGroups.join(' ').indexOf('steward') != -1)
 	addOnloadHook(function() {
   		document.getElementById('wpAnonOnly').checked = true;
   		addHandler(document.forms['uluser'],'submit',addblocktype);
 	});
 
 function addblocktype() { // DerHexer
   if (document.getElementById('wpAnonOnly').checked == true) {
     document.getElementById('mw-globalblocking-block-reason').getElementsByTagName('input')[0].value += ' (sb)';
   } else {
     document.getElementById('mw-globalblocking-block-reason').getElementsByTagName('input')[0].value += ' (hb)';
   }
 }

// 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);

/**
 * Implements language selection for multilingual elements
 * 
 * In certain environments, it's not feasible to neatly box away each
 * different language into its own section of the site. By marking elements
 * multilingual, you can emulate this behavior by only displaying the 
 * message in the user's language. This reduced the "Tower of Babel" effect.
 * 
 * @author Edward Z. Yang (Ambush Commander)
 * @version $Id: language_select.js 1358 2007-02-19 15:34:59Z Edward $
 */

/* Configuration: */

// in your monobook.js, set ls_enable = false to stop the javascript
// maybe it should be cookie configurable. However, you can achieve
// something almost to this effect through cookie settings
var ls_enable = true;

// the cookie name we use to stash the info.
// change this if you are porting it to another wiki!
var ls_cookie = 'metawiki_language_js';

// link to the language select page
var ls_help_url = 'http://meta.wikimedia.org/wiki/Meta:Language_select';

// strings that are part of the widgets
var ls_string_help = 'Language select:';
var ls_string_select = 'Select';
var ls_string_showall = 'Show all';

// define some meta-variables
var ls__first = true; // the first iteration?

// node compatability fix
if (!window.Node) {
    var Node = {
        ELEMENT_NODE : 1,
        ATTRIBUTE_NODE: 2,
        TEXT_NODE: 3,
        COMMENT_NODE: 8,
        DOCUMENT_NODE: 9,
        DOCUMENT_FRAGMENT_NODE: 11
    };
}

// autodetects a browser language
function ls_getBrowserLanguage() {
    var language;
    // borrowed from Wikimedia's site error notice
    // find the language
    if (navigator.userLanguage) {
        // use the user's preferred language (non-Gecko)
        language = navigator.userLanguage;
    } else if (navigator.appName == 'Netscape') {
        // use the only language information available to Gecko
        language = navigator.language;
    } else {
        // get the browser language information in non-Gecko browsers
        // (IE, Opera, Konqueror)
        language = navigator.browserLanguage;
    }
    return language;
}

// grabs language from cookie
function ls_getCookieLanguage() {
    var allcookies = document.cookie;
    var marker = ls_cookie + '=';
    var pos = allcookies.indexOf(marker);
    
    // cookie isn't set, so no behavior defined
    if (pos === -1) return null;
    
    // cookie is set
    var start = pos + marker.length;
    var end   = allcookies.indexOf(';', start);
    if (end == -1) end = allcookies.length;
    
    var raw   = allcookies.substring(start,end);
    var value = unescape(raw);
    
    return value;
}

// sets a new language to the cookie
function ls_setCookieLanguage(language) {
    var today = new Date();
    var expiry = new Date(today.getUTCFullYear() + 30, 1);
    document.cookie = ls_cookie + '=' + escape(language) + '; expires=' + expiry.toGMTString();
}

// deletes the cookie
function ls_deleteCookieLanguage(language) {
    document.cookie = ls_cookie + '=; expires=Fri, 02-Jan-1970 00:00:00 GMT';
}

// grabs the ISO 639 language code based
// on either the browser or a supplied cookie
// return of "mul" will display all available strings
function ls_getLanguage() {
    var language = '';
    
    // Priority:
    //  1. Cookie
    //  2. wgUserLanguage global variable
    //  3. Browser autodetection
    
    // grab according to cookie
    language = ls_getCookieLanguage();
    
    // grab according to wgUserLanguage
    if (!language && window.wgUserLanguage) {
        language = wgUserLanguage;
    }
    
    // grab according to browser if none defined
    if (!language) {
        language = ls_getBrowserLanguage();
    }
    
    // inflexible: can't accept multiple languages
    
    // remove dialect/region code, leaving only the ISO 639 code
    var length;
    // possible bug: supposedly the language string could be en_US
    // switch to regexps when we get the chance
    if ((length = language.indexOf('-')) !== -1) {
        language = language.substr(0, length);
    }
    
    return language;
}

// walks all child elements and finds all elements with multilingual in them
function ls_getAllMultilingualElements(n) {
    var elements = new Array();
    // possible bug if we have a classname that includes the word multilingual
    //   but it's unlikely
    if (n.className && n.className.indexOf('multilingual') != -1) {
        elements = elements.concat(n);
    }
    var children = n.childNodes;
    for(var i=0; i < children.length; i++) {
        if (children[i].nodeType !== Node.ELEMENT_NODE) continue;
        elements = elements.concat(ls_getAllMultilingualElements(children[i]));
    }
    return elements;
}

// walks a hash and hides all non-matching languages
function ls_hideAllExcept(lang_element_hash, language) {
    for (var n in lang_element_hash) {
        if (n == language) {
            lang_element_hash[n].style.display = '';
        } else {
            lang_element_hash[n].style.display = 'none';
        }
    }
}

// walks a hash and shows all languages
function ls_showAll(lang_element_hash) {
    for (var n in lang_element_hash) {
        if (lang_element_hash[n].style.display) {
            lang_element_hash[n].style.display = '';
        }
    }
}

// build widget for changing the language cookie
function ls_buildWidget(language) {
   
    // set up the floating form
    var form = document.createElement('form');
    form.className = 'lang_info';
    form.onsubmit = function() {
        if (this.elements[2].ls_mul_flag) {
            this.elements[2].ls_mul_flag = false;
            var language = 'mul';
            var temporary = true;
        } else {
            ls_setCookieLanguage(this.elements[0].value);
            var language = this.elements[0].value;
            var temporary = false;
        }
        ls_applyLanguageSelect(language, temporary);
        
        return false; // don't perform action
    };
    form.appendSpace = function() {
        this.appendChild(document.createTextNode(' '));
    };
    
    // link to language select description page
    var link = document.createElement('a');
    link.href = ls_help_url;
    link.className = 'ls_link';
    link.appendChild(document.createTextNode(ls_string_help));
    form.appendChild(link);
    
    form.appendSpace();
    
    // input box for the language
    var input = document.createElement('input');
    input.setAttribute('type', 'text');
    input.setAttribute('size', '2');
//    input.setAttribute('maxlength', '7');
    input.onclick = function() { this.select(); };
    input.className = 'ls_input';
    input.value = language;
    form.appendChild(input);
    
    form.appendSpace();
    
    // save button
    var submit = document.createElement('input');
    submit.setAttribute('type', 'submit');
    submit.value = ls_string_select;
    submit.className = 'ls_select';
    form.appendChild(submit);
    
    form.appendSpace();
    
    // show all button 
    // equivalent to setting input box to "mul" and pressing save
    var showall = document.createElement('input');
    showall.setAttribute('type', 'submit');
    showall.value = ls_string_showall;
    showall.onclick = function() {
        this.ls_mul_flag = true;
    };
    form.appendChild(showall);
    
    return form;
    
}

// main body of the function
function ls_applyLanguageSelect(language, temporary) {
    
    // possible site for cookie checking to disable language select
    if (!ls_enable) return;
    
    // if language is blank, delete the cookie and then recalculate
    if (!language) {
        ls_deleteCookieLanguage();
        language = ls_getLanguage();
    }
    
    // grab the body element (only one)
    var body = document.getElementsByTagName('body')[0];
    
    // grab an array of multilingual elements
    var mls = ls_getAllMultilingualElements(body);
    
    // this will get overwritten many times, temporary variable
    var form, language_element_hash;
    
    // iterate through all those elements
    for (var i = 0; i < mls.length; i++) {
        var ml   = mls[i];        // the current multilingual container
        var ml_c = ml.childNodes; // children of the container
        
        // if it's the first iteration...
        if (ls__first) {
            form = ls_buildWidget(language);
            ml.appendChild(form, ml_c[0]);
        } else {
            // update widget
            form = ml_c[ml_c.length - 1]; // form is last element
            if (!temporary) {
                form.elements[0].value = language;
                form.elements[0].removeAttribute('disabled');
                form.elements[2].removeAttribute('disabled');
            } else {
                form.elements[0].setAttribute('disabled', 'disabled');
                form.elements[2].setAttribute('disabled', 'disabled');
            }
        }
        
        form.elements[0].style.background="#FFF";
        
        // tells us whether or not to blindly perform the keep
        var message_exists  = false;
        
        // iterate through all languages and set up a hash
        //   with references to each of the language nodes
        lang_element_hash = new Object();
        for (var j = 0; j < ml_c.length; j++) {
            var n = ml_c[j];
            if (n.nodeType != Node.ELEMENT_NODE) continue; // skip non-elements
            if (!n.lang) continue; // skip non-language specific elements
            if (n.lang.indexOf(language) === 0) {
                // it turns out our language is here
                message_exists  = true;
            }
            lang_element_hash[n.lang] = n;
        }
        
        // if a preferred language was kept, do quickest processing
        if (message_exists) {
            ls_hideAllExcept(lang_element_hash, language);
            continue;
        }
        
        // otherwise, nothing happened, this means that it wasn't found
        
        // if it's not the first time, repaint all of them
        if (!ls__first) {
            ls_showAll(lang_element_hash);
        }
        
        if (language != 'mul') {
            form.elements[0].style.background="#FCC";
        }
        
    }
    
    // we've already processed once
    ls__first = false;
    
}

function ls_applyDefaultLanguageSelect() {
    ls_applyLanguageSelect(ls_getLanguage(), false);
}

// register as onload function (there must be a better way)
if (window.addEventListener) {
    window.addEventListener("load", ls_applyDefaultLanguageSelect, false);
} else if (window.attachEvent) {
    window.attachEvent("onload", ls_applyDefaultLanguageSelect);
}