MediaWiki:Common.js
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.
mw.loader.getScript( 'https://commons.wiki.gg/index.php?title=MediaWiki:Common-base.js&action=raw&ctype=text/javascript' ).then(function(){
////////////////////////////////////////////////////////////////////////////////
$('<div class="menu-toggle"/>').insertAfter($('#p-logo')).on("click", function(event){
event.stopPropagation();
$(this).toggleClass('expanded');
});
////////////////////////////////////////////////////////////////////////////////
/*end of mw.loader.getScript().then callback*/ });
if ( mw.config.get('wgIsArticle') || window.location.href.indexOf( 'action=submit' ) > -1 )
{
function CollapsibleTables ()
{
var classCollapsible = 'collapsible';
var classExpandable = 'expandable';
var linkTextShow = '[show]';
var linkTextHide = '[hide]';
var reCollapsible = new RegExp( '(?:\\s|^)' + classCollapsible + '(?:\\s|$)' );
var reExpandable = new RegExp( '(?:\\s|^)' + classExpandable + '(?:\\s|$)' );
var sections = new Array();
// link element
var linkElement = document.createElement( 'a' );
linkElement.style.fontSize = '85%';
linkElement.style.fontWeight = 'normal';
linkElement.style.width = '3em';
linkElement.style.cssFloat = 'right';
linkElement.style.styleFloat = 'right';
linkElement.style.textAlign = 'center';
linkElement.style.marginLeft = '1em';
linkElement.style.padding = '0px 3px';
linkElement.href = 'javascript:void(0);';
initialize();
/** private void initialize () :: initializes CollapsibleTables class **/
function initialize ()
{
if ( mw.config.get('wgIsArticle') == false && window.location.href.indexOf( 'action=submit' ) < 0 )
return;
var docContent = document.getElementById( 'bodyContent' ) || document.getElementById( 'article' ) || document.getElementById( 'mw_contentholder' );
var tables = docContent.getElementsByTagName( 'table' );
var sectionId = -1;
var defaultStatus;
for ( var i = 0, n = tables.length; i < n; i++ )
{
if ( reCollapsible.test( tables[i].className ) )
defaultStatus = true;
else if ( reExpandable.test( tables[i].className ) )
defaultStatus = false;
else
continue;
var tableRows = tables[i].rows;
var sectionFound = false;
var status = false;
for ( var j = 0, m = tableRows.length; j < m; j++ )
{
if ( reCollapsible.test( tableRows[j].className ) )
status = true;
else if ( reExpandable.test( tableRows[j].className ) )
status = false;
else
{
if ( sectionFound )
{
sections[ sectionId ].content.push( tableRows[j] );
tableRows[j].style.display = sections[ sectionId ].status ? '' : 'none';
}
continue;
}
var section = new Object();
section.header = tableRows[j];
section.content = new Array();
section.status = defaultStatus ? status : false;
sections[ ++sectionId ] = section;
sectionFound = true;
initHeaderRow( tableRows[j], sectionId, section.status );
}
if ( sectionFound == false )
{
var section = new Object();
section.header = tableRows[0];
section.content = new Array();
section.status = defaultStatus;
for ( var j = 1; j < tableRows.length; j++ )
{
section.content.push( tableRows[j] );
tableRows[j].style.display = section.status ? '' : 'none';
}
sections[ ++sectionId ] = section;
initHeaderRow( tableRows[0], sectionId, defaultStatus );
}
}
}
/** private void initHeaderRow ( headerRow, sectionId, sectionStatus ) :: adds show/hide button **/
function initHeaderRow ( headerRow, sectionId, sectionStatus )
{
var lastCell, link;
headerRow.id = 'collapsible-section_' + sectionId;
lastCell = headerRow.cells[ headerRow.cells.length - 1 ];
link = linkElement.cloneNode( false );
link.onclick = toggleSection;
link.appendChild( document.createTextNode( sectionStatus ? linkTextHide : linkTextShow ) );
lastCell.insertBefore( link, lastCell.firstChild );
}
/** private void toggleSection () :: onclick event handler **/
function toggleSection ()
{
var trHead = this.parentNode.parentNode;
var section = sections[ trHead.id.substr( 20 ) ];
var content = section.content;
var display = section.status ? 'none' : '';
for ( var i = 0, n = content.length; i < n; i++ )
content[i].style.display = display;
section.status = !section.status;
this.firstChild.data = section.status ? linkTextHide : linkTextShow;
}
}
addOnloadHook(function () { new CollapsibleTables(); });
}
// **************************************************
// Experimental javascript countdown timer (Splarka)
// Version 0.0.3
// **************************************************
//
// Usage example:
// <span class="countdown" style="display:none;">
// Only <span class="countdowndate">January 01 2007 00:00:00 PST</span> until New years.
// </span>
// <span class="nocountdown">Javascript disabled.</span>
function updatetimer(i) {
var now = new Date();
var then = timers[i].eventdate;
var diff = count=Math.floor((then.getTime()-now.getTime())/1000);
// catch bad date strings
if(isNaN(diff)) {
timers[i].firstChild.nodeValue = '** ' + timers[i].eventdate + ' **' ;
return;
}
// determine plus/minus
if(diff<0) {
diff = -diff;
var tpm = ' ';
} else {
var tpm = ' ';
}
// calcuate the diff
var left = (diff%60) + ' seconds';
diff=Math.floor(diff/60);
if(diff > 0) left = (diff%60) + ' minutes ' + left;
diff=Math.floor(diff/60);
if(diff > 0) left = (diff%24) + ' hours ' + left;
diff=Math.floor(diff/24);
if(diff > 0) left = diff + ' days ' + left
timers[i].firstChild.nodeValue = tpm + left;
// a setInterval() is more efficient, but calling setTimeout()
// makes errors break the script rather than infinitely recurse
timeouts[i] = setTimeout('updatetimer(' + i + ')',1000);
}
function checktimers() {
//hide 'nocountdown' and show 'countdown'
var nocountdowns = document.getElementsByClassName(document, 'span', 'nocountdown');
for(var i=0; i< nocountdowns.length; i++){ nocountdowns[i].style.display = 'none'; }
var countdowns = document.getElementsByClassName(document, 'span', 'countdown');
for(var i=0; i< countdowns.length; i++){ countdowns[i].style.display = 'inline' }
//set up global objects timers and timeouts.
timers = document.getElementsByClassName(document, 'span', 'countdowndate'); //global
timeouts = new Array(); // generic holder for the timeouts, global
if(timers.length == 0) return;
for(var i=0; i< timers.length; i++) {
timers[i].eventdate = new Date(timers[i].firstChild.nodeValue);
updatetimer(i); //start it up
}
}
addOnloadHook(checktimers);
// **************************************************
// - end - Experimental javascript countdown timer
// **************************************************
function formatDate(t)
{
var month = new Array();
month[0] = 'January';
month[1] = 'February';
month[2] = 'March';
month[3] = 'April';
month[4] = 'May';
month[5] = 'June';
month[6] = 'July';
month[7] = 'August';
month[8] = 'September';
month[9] = 'October';
month[10] = 'November';
month[11] = 'December';
y = t.getUTCFullYear();
M = t.getUTCMonth();
D = t.getUTCDate();
h = t.getUTCHours();
m = t.getUTCMinutes();
s = t.getUTCSeconds();
if (h > 0 || m > 0 || s > 0)
{
hms = '';
if (s > 10)
hms = ':' + s;
else if (s > 0)
hms = ':0' + s;
if (m > 10)
hms = ':' + m + hms;
else if (m > 0)
hms = ':0' + m + hms;
if (h > 12)
hms = (h - 12) + hms + ' PM';
else if (h > 0)
hms = h + hms + ' AM';
else
hms = '12' + hms + ' AM';
return hms + ', ' + month[M] + ' ' + D + ', ' + y;
} else {
return month[M] + ' ' + D + ', ' + y;
}
}
function formatTime(h, m, s)
{
var o = '';
if (h != 1)
{
o = h + ' hours ';
} else {
o = '1 hour ';
}
if (m != 1)
{
o += m + ' minutes ';
} else {
o += '1 minute ';
}
if (s != 1)
{
o += s + ' seconds';
} else {
o += '1 second';
}
return o;
}
function updateClocks()
{
var t = new Date();
setTimeout(updateClocks, 1000);
D = t.getUTCDate();
M = t.getUTCMonth();
y = t.getUTCFullYear();
h = t.getUTCHours();
m = t.getUTCMinutes();
s = t.getUTCSeconds();
t = Date.UTC(y, M, D, h, m, s);
t = (T - t) / 1000;
if (t < 0 && t > -86400 && (h > 0 || m > 0 || s > 0))
{
document.getElementById('countdown-big').innerHTML = 'Today';
document.getElementById('countdown-small').innerHTML = '';
document.getElementById('countdown-target').innerHTML = 'is ' + formatDate(new Date(T + tzOffset)) + ' ' + tz;
return;
} else if (t < 0) {
document.getElementById('countdown-big').innerHTML = 'Past';
document.getElementById('countdown-target').innerHTML = formatDate(new Date(T + tzOffset)) + ' ' + tz;
return;
}
D = Math.floor(t / 86400.0);
h = Math.floor(t % 86400.0 / 3600.0);
m = Math.floor(t % 3600.0 / 60.0);
s = Math.floor(t % 60.0)
if (D == 1)
{
document.getElementById('countdown-big').innerHTML = '1 day';
} else if (D == 0) {
document.getElementById('countdown-big').innerHTML = '';
} else {
document.getElementById('countdown-big').innerHTML = D + ' days';
}
document.getElementById('countdown-small').innerHTML = formatTime(h, m, s);
}
function startCountdown()
{
document.getElementById('countdown-target').innerHTML = 'to ' + formatDate(new Date(T + tzOffset)) + ' ' + tz;
document.getElementById('countdown').style.display = 'block';
updateClocks();
}