MediaWiki:Common.js: Difference between revisions
Jump to navigation
Jump to search
ThePoet444 (talk | contribs) mNo edit summary |
ThePoet444 (talk | contribs) mNo edit summary |
||
| Line 3: | Line 3: | ||
// Common.js originally from Wookieepedia. | // Common.js originally from Wookieepedia. | ||
// Thanks, Wookieepedia! | // Thanks, Wookieepedia! | ||
/* | |||
document.write('<script type="text/javascript" src="' | document.write('<script type="text/javascript" src="' | ||
+ '/index.php?title=MediaWiki:Function.js&action=raw&ctype=text/javascript"></script>'); | + '/index.php?title=MediaWiki:Function.js&action=raw&ctype=text/javascript"></script>'); | ||
*/ | |||
//Load Functions.js | |||
importScript('MediaWiki:Functions.js'); | |||
// onload stuff | // onload stuff | ||
var firstRun = true; | |||
function loadFunc() | function loadFunc() | ||
Revision as of 12:05, 24 May 2010
/* <pre style="overflow: scroll; height: 25em"><nowiki> */
// Common.js originally from Wookieepedia.
// Thanks, Wookieepedia!
/*
document.write('<script type="text/javascript" src="'
+ '/index.php?title=MediaWiki:Function.js&action=raw&ctype=text/javascript"></script>');
*/
//Load Functions.js
importScript('MediaWiki:Functions.js');
// onload stuff
var firstRun = true;
function loadFunc()
{
initFunctionsJS();
// DEPRECATED
if(document.getElementById('infoboxinternal') != null && document.getElementById('infoboxend') != null)
{
document.getElementById('infoboxend').innerHTML = '<a id="infoboxtoggle" href="javascript:infoboxToggle()">[Hide]</a>';
}
addHideButtons();
if(document.getElementById('mp3-navlink') != null)
{
document.getElementById('mp3-navlink').onclick = onArticleNavClick;
document.getElementById('mp3-navlink').getElementsByTagName('a')[0].href = 'javascript:void(0)';
}
if(window.storagePresent)
initVisibility();
rewriteSearchFormLink();
fillEditSummaries();
fillDeleteReasons();
fillPreloads();
substUsername();
substUsernameTOC();
rewriteTitle();
showTitleIcons('title-eraicons');
showEras('title-shortcut');
rewriteHover();
addAlternatingRowColors();
replaceSearchIcon();
if(typeof(onPageLoad) != "undefined")
{
onPageLoad();
}
}
function infoboxToggle()
{
var page = window.pageName.replace(/\W/g, '_');
var nowShown;
if(document.getElementById('infoboxtoggle').innerHTML == '[Hide]')
{
document.getElementById('infoboxinternal').style.display = 'none';
document.getElementById('infoboxtoggle').innerHTML = '[Show]';
nowShown = false;
}
else
{
document.getElementById('infoboxinternal').style.display = 'block';
document.getElementById('infoboxtoggle').innerHTML = '[Hide]';
nowShown = true;
}
if(window.storagePresent)
{
var storage = globalStorage[window.location.hostname];
storage.setItem('infoboxshow-' + page, nowShown);
}
}
function fillEditSummaries()
{
var label = document.getElementById("wpSummaryLabel");
if(label == null)
return;
var comboString = "Standard summaries: <select id='stdSummaries' onchange='onStdSummaryChange()'>";
comboString += "</select><br />";
label.innerHTML = comboString + label.innerHTML;
requestComboFill('stdSummaries', 'Template:Stdsummaries');
}
function onStdSummaryChange()
{
var combo = document.getElementById("stdSummaries");
var value = combo.options[combo.selectedIndex].value;
if(value != "")
document.getElementById("wpSummary").value = value;
}
function fillDeleteReasons()
{
var label = document.getElementById("wpReason");
if(label == null)
return;
label = document.getElementById("contentSub");
if(label == null)
return;
var comboString = "<br /><select id='stdReasons' onchange='onStdReasonChange()'>";
comboString += "</select>";
label.innerHTML += comboString;
requestComboFill('stdReasons', "Template:Stdreasons");
}
function onStdReasonChange()
{
var combo = document.getElementById("stdReasons");
var value = combo.options[combo.selectedIndex].value;
if(value != "")
document.getElementById("wpReason").value = value;
}
function fillPreloads()
{
var div = document.getElementById("lf-preload");
if(div == null)
return;
div.style.display = 'block';
var span = document.getElementById('lf-preload-cbox');
var comboString = "<select id='stdPreloads' onchange='onPreloadChange()'>";
comboString += "</select>";
span.innerHTML = comboString;
span = document.getElementById('lf-preload-pagename');
span.innerHTML = '<input type="text" class="textbox" />';
span = document.getElementById('lf-preload-button');
span.innerHTML = '<input type="button" class="button" value="Insert" onclick="doCustomPreload()" />';
requestComboFill('stdPreloads', "Template:Stdpreloads");
}
function doCustomPreload()
{
doPreload(document.getElementById('lf-preload-pagename').getElementsByTagName('input')[0].value);
}
function onPreloadChange()
{
var combo = document.getElementById("stdPreloads");
var value = combo.options[combo.selectedIndex].value;
if(value == "")
return;
value = "Template:" + value + "/preload";
value = value.replace(" ", "_");
doPreload(value);
}
// ============================================================
// BEGIN JavaScript title rewrite
function rewriteTitle()
{
if(typeof(window.SKIP_TITLE_REWRITE) != 'undefined' && window.SKIP_TITLE_REWRITE)
return;
var titleDiv = document.getElementById('title-meta');
if(titleDiv == null)
return;
var cloneNode = titleDiv.cloneNode(true);
var firstHeading = getFirstHeading();
var node = firstHeading.childNodes[0];
// new, then old!
firstHeading.replaceChild(cloneNode, node);
cloneNode.style.display = "inline";
var titleAlign = document.getElementById('title-align');
firstHeading.style.textAlign = titleAlign.childNodes[0].nodeValue;
}
function showTitleIcons(idName)
{
var titleDiv = document.getElementById(idName);
if(titleDiv == null || titleDiv == undefined)
return;
var cloneNode = titleDiv.cloneNode(true);
var firstHeading = getFirstHeading();
firstHeading.insertBefore(cloneNode, firstHeading.childNodes[0]);
cloneNode.style.display = "block";
}
// END JavaScript title rewrite
function initVisibility()
{
var storage = globalStorage[window.location.hostname];
var page = window.pageName.replace(/\W/g,'_');
var show = storage.getItem('infoboxshow-' + page);
if(show == 'false')
{
infoboxToggle();
}
var hidables = getElementsByClass('hidable');
for(var i = 0; i < hidables.length; i++)
{
show = storage.getItem('hidableshow-' + i + '_' + page);
if(show == 'false')
{
var content = getElementsByClass('hidable-content', hidables[i]);
var button = getElementsByClass('hidable-button', hidables[i]);
if(content != null && content.length > 0 &&
button != null && button.length > 0 && content[0].style.display != 'none')
{
button[0].onclick('bypass');
}
}
else if(show == 'true')
{
var content = getElementsByClass('hidable-content', hidables[i]);
var button = getElementsByClass('hidable-button', hidables[i]);
if(content != null && content.length > 0 &&
button != null && button.length > 0 && content[0].style.display == 'none')
{
button[0].onclick('bypass');
}
}
}
}
function onArticleNavClick()
{
var div = document.getElementById('mp3-nav');
if(div.style.display == 'block')
div.style.display = 'none';
else
div.style.display = 'block';
}
function addAlternatingRowColors()
{
var infoboxes = getElementsByClass('infobox', document.getElementById('content'));
if(infoboxes.length == 0)
return;
for(var k = 0; k < infoboxes.length; k++)
{
var infobox = infoboxes[k];
var rows = infobox.getElementsByTagName('tr');
var changeColor = false;
for(var i = 0; i < rows.length; i++)
{
if(rows[i].className.indexOf('infoboxstopalt') != -1)
break;
var ths = rows[i].getElementsByTagName('th');
if(ths.length > 0)
{
continue;
}
if(changeColor)
rows[i].style.backgroundColor = '#f9f9f9';
changeColor = !changeColor;
}
}
}
function addHideButtons()
{
var hidables = getElementsByClass('hidable');
for(var i = 0; i < hidables.length; i++)
{
var box = hidables[i];
var button = getElementsByClass('hidable-button', box, 'span');
if(button != null && button.length > 0)
{
button = button[0];
button.onclick = toggleHidable;
button.appendChild(document.createTextNode('[Hide]'));
if(new ClassTester('start-hidden').isMatch(box))
button.onclick('bypass');
}
}
}
function toggleHidable(bypassStorage)
{
var parent = getParentByClass('hidable', this);
var content = getElementsByClass('hidable-content', parent);
var nowShown;
if(content != null && content.length > 0)
{
content = content[0];
if(content.style.display == 'none')
{
content.style.display = content.oldDisplayStyle;
this.firstChild.nodeValue = '[Hide]';
nowShown = true;
}
else
{
content.oldDisplayStyle = content.style.display;
content.style.display = 'none';
this.firstChild.nodeValue = '[Show]';
nowShown = false;
}
if(window.storagePresent && (typeof(bypassStorage) == 'undefined' || bypassStorage != 'bypass'))
{
var page = window.pageName.replace(/\W/g, '_');
var items = getElementsByClass('hidable');
var item = -1;
for(var i = 0; i < items.length; i++)
{
if(items[i] == parent)
{
item = i;
break;
}
}
if(item == -1)
{
return;
}
var storage = globalStorage[window.location.hostname];
storage.setItem('hidableshow-' + item + '_' + page, nowShown);
}
}
}
function substUsernameTOC()
{
var toc = document.getElementById('toc');
var userpage = document.getElementById('pt-userpage');
if(!userpage || !toc)
return;
var username = userpage.firstChild.firstChild.nodeValue;
var elements = getElementsByClass('toctext', toc, 'span');
for(var i = 0; i < elements.length; i++)
elements[i].firstChild.nodeValue = elements[i].firstChild.nodeValue.replace('<insert name here>', username);
}
function replaceSearchIcon()
{
var searchbox = document.getElementById('searchBody');
var innerDiv = searchbox.getElementsByTagName('div')[0];
var link = innerDiv.getElementsByTagName('a')[0];
if(link)
innerDiv.removeChild(link);
// innerDiv.style.paddingTop = '56px';
var loader = new ContentLoader();
loader.div = innerDiv;
loader.callback = onSearchIconsArrival;
loader.send('/index.php?title=Template:Searchicons&action=raw');
}
function rand(n)
{
return Math.round(Math.random() * n);
}
function onSearchIconsArrival()
{
var lines = this.text.split('\n');
var link = document.createElement('a');
link.href = '/index.php?title=Special:Search&adv=1';
var img = document.createElement('img');
img.alt = 'Search';
img.src = lines[rand(lines.length - 1)];
link.appendChild(img);
this.div.insertBefore(link, this.div.firstChild);
}
addOnloadHook(loadFunc);
// </nowiki></pre>