Difference between revisions of "MediaWiki:Wptouch.js"

From CS Codex
Jump to: navigation, search
(Created page with "Any JavaScript here will be loaded for all users on every page load.: var toggleMapListSetup = function() { var btn = $('a[id^="collapseButton"]'); btn.each(function(...")
 
(No difference)

Latest revision as of 15:47, 17 July 2021

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

var toggleMapListSetup = function() {
	var btn = $('a[id^="collapseButton"]');

	btn.each(function() {
		var table = $(this).closest('table');
		var m = $('.maprow', table);

		if (m.length) {
			m.hide(); // Collapse maps by default

			var span = $('<span>', {
				'class': 'mapsCollapseButton',
				'css': {
					'font-weight': 'normal',
					'float': 'right',
					'margin-right': '7px',
					'cursor': 'pointer'
				}
			});

			table.data('maps-collapsed', true);

			var toggleMaps = function() {
				table.find('.maprow').toggle();
				table.data('maps-collapsed', !table.data('maps-collapsed'));

				$(this).text(function(i, txt) {
					return txt.replace(/\+|−/, function(a) {
						return a === '+' ? '−' : '+';
					});
				});
			};

			var a = $('<a>+maps</a>').click(toggleMaps);

			span.append('[', a, ']');
			$(this).parent().after(span);

			if (table.hasClass('uncollapsed-maps')) {
				a.trigger('click');
			}
		}
	});
};

/** Collapsible tables *********************************************************
*
* From English Wikipedia, 2008-09-15
*
*  Description: Allows tables to be collapsed, showing only the header. See
*               [[Wikipedia:NavFrame]].
*  Maintainers: [[User:R. Koot]]
*/

var autoCollapse = 2;
var collapseCaption = "hide";
var expandCaption = "show";

function collapseTable( tableIndex )
{
	var Button = document.getElementById( "collapseButton" + tableIndex );
	var Table = document.getElementById( "collapsibleTable" + tableIndex );

	if ( !Table || !Button ) {
		return false;
	}

	var Rows = Table.rows;

	if ( Button.firstChild.data == collapseCaption ) {
		for ( var i = 1; i < Rows.length; i++ ) {
			Rows[i].style.display = "none";
		}
		Button.firstChild.data = expandCaption;

		$('.mapsCollapseButton', Table).hide();
	} else {
		for ( var i = 1; i < Rows.length; i++ ) {
			if ( hasClass( Rows[i], "maprow" ) ) {
				// Skip showing for this row if the maps are in collapsed state
				if ($(Table).data('maps-collapsed')) {
					continue;
				}
			}

			Rows[i].style.display = Rows[0].style.display;
		}
		Button.firstChild.data = collapseCaption;

		$('.mapsCollapseButton', Table).show();
	}
}

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" ) ) {

			/* only add button and increment count if there is a header row to work with */
			var HeaderRow = Tables[i].getElementsByTagName( "tr" )[0];
			if (!HeaderRow) continue;
			var Header = HeaderRow.getElementsByTagName( "th" )[0];
			if (!Header) continue;

			NavigationBoxes[ tableIndex ] = Tables[i];
			Tables[i].setAttribute( "id", "collapsibleTable" + tableIndex );

			var Button     = document.createElement( "span" );
			var ButtonLink = document.createElement( "a" );
			var ButtonText = document.createTextNode( collapseCaption );

			Button.className = "collapseButton";  //Styles are declared in Common.css

			ButtonLink.style.color = Header.style.color;
			ButtonLink.setAttribute( "id", "collapseButton" + tableIndex );
			ButtonLink.setAttribute( "href", "javascript:collapseTable(" + tableIndex + ");" );
			ButtonLink.appendChild( ButtonText );

			Button.appendChild( document.createTextNode( "[" ) );
				Button.appendChild( ButtonLink );
				Button.appendChild( document.createTextNode( "]" ) );

				Header.insertBefore( Button, Header.childNodes[0] );
				tableIndex++;
		}
	}

	// Create [+maps] buttons after setting up the table collapse buttons,
	// but before initial collapseTable calls
	toggleMapListSetup();

	for ( var i = 0;  i < tableIndex; i++ ) {
		if ( hasClass( NavigationBoxes[i], "collapsed" ) || ( tableIndex >= autoCollapse && hasClass( NavigationBoxes[i], "autocollapse" ) ) ) {
			collapseTable( i );
		}
	}
}
/** Test if an element has a certain class **************************************
*
* Description: Uses regular expressions and caching for better performance.
* Maintainers: [[User:Mike Dillon]], [[User:R. Koot]], [[User:SG]]
*/

var hasClass = (function () {
	var reCache = {};
	return function (element, className) {
		return (reCache[className] ? reCache[className] : (reCache[className] = new RegExp("(?:\\s|^)" + className + "(?:\\s|$)"))).test(element.className);
	};
})();

/** 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 isCollapsed = hasClass( NavFrame, "collapsed" );
			/*
			* Check if any children are already hidden.  This loop is here for backwards compatibility:
			* the old way of making NavFrames start out collapsed was to manually add style="display:none"
			* to all the NavPic/NavContent elements.  Since this was bad for accessibility (no way to make
			* the content visible without JavaScript support), the new recommended way is to add the class
			* "collapsed" to the NavFrame itself, just like with collapsible tables.
			*/
			for (var NavChild = NavFrame.firstChild; NavChild != null && !isCollapsed; NavChild = NavChild.nextSibling) {
				if ( hasClass( NavChild, 'NavPic' ) || hasClass( NavChild, 'NavContent' ) ) {
					if ( NavChild.style.display == 'none' ) {
						isCollapsed = true;
					}
				}
			}
			if (isCollapsed) {
				for (var NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling) {
					if ( hasClass( NavChild, 'NavPic' ) || hasClass( NavChild, 'NavContent' ) ) {
						NavChild.style.display = 'none';
					}
				}
			}
			var NavToggleText = document.createTextNode(isCollapsed ? NavigationBarShow : NavigationBarHide);
			NavToggle.appendChild(NavToggleText);

			// Find the NavHead and attach the toggle link (Must be this complicated because Moz's firstChild handling is borked)
			for(var j=0; j < NavFrame.childNodes.length; j++) {
				if (hasClass(NavFrame.childNodes[j], "NavHead")) {
					NavFrame.childNodes[j].appendChild(NavToggle);
				}
			}
			NavFrame.setAttribute('id', 'NavFrame' + indexNavigationBar);
		}
	}
}

$(document).ready (function() {
  createCollapseButtons();
  createNavigationBarToggleButton();
});

/* Card Hover (by PhiLtheFisH)*/
$(document).ready(function () {
	$('.hovercard').hover(function() {
		var imagelink = $(this).attr('data-img');
		if (imagelink) {
			imagelink = imagelink.replace(' ', '_');
			var left = $(this).position().left + 20;
			var top = $(this).position().top + 20;
			if (($(window).width() - (left + 480)) < 0) {
				left = left - 280;
			}
			if ((($(this).offset().top + 20) - $(window).scrollTop()) > ($(window).height()/1.5)) {
				top = top - 220;
			}
			var imagediv = $('<div id="hoverimage"><img style="height:auto; width:auto; max-width:200px; max-height:200px;" src="' + imagelink + '"></div>');
			$(this).append(imagediv);
 			imagediv.css('top', top);
			imagediv.css('left', left);
		}
	},function () {
		$('#hoverimage').remove();
	});
});

$(document).ready(function () {
	if($('.scrollTimeline').length > 0) {
		$('.scrollTimeline')[0].scrollLeft = $('.timeline').width();
	}
});

/* Countdown Time code by Kenjin`- */
;(function(w, doc, isAlreadyDeleted) {
	var datetimes = [].slice.call(doc.querySelectorAll('.datetime'));
	var countdowns = [].slice.call(doc.querySelectorAll('.countdown'));
	var streamLink = [].slice.call(doc.querySelectorAll('.streamLink'));

	var times = [], tempDate, tempTimezone, tempStream, tempStreams, streams = [];
	var tage = 'd';
	var timeNow = new Date();
	var endTime;
	isAlreadyDeleted = [];
	ClassIsAlreadySet = [];

	for (var i = 0, length = datetimes.length; i < length; i++) {
		tempDate = datetimes[i];
		//console.log(datetimes[i].childNodes.length);
		elemsChildNodes = datetimes[i].childNodes;

		for (j = 0; j < elemsChildNodes.length; j++) {
			if (elemsChildNodes[j].nodeName === 'ABBR') {
				tempTimezone = elemsChildNodes[j].getAttribute("title").trim();
				break;
			} else
				tempTimezone = false;
		}

		// Check if the class is set
		isAlreadyDeleted[i] = 0;
		ClassIsAlreadySet[i] = 0;
		// UTC Time from the Event is in times now
		times[i] = stringToDate(tempDate, tempTimezone);
	}

	for (var j = 0, lengthStream = streamLink.length; j < lengthStream; j++) {
		tempStream = streamLink[j];
		//console.log(datetimes[j].childNodes.length);
		elemsChildNodesStream = streamLink[j].childNodes;

		if(elemsChildNodesStream.length > 0){
			for (var k = 0; k < elemsChildNodesStream.length; k++) {
				tempStreams = elemsChildNodesStream[k];
			}
		} else {
			tempStreams = 0;
		}

		streams[j] = tempStreams;
	}

	function stringToDate(tempDate, tempTimezone) {
		var tempDateinnerhTML,
			posTimezone,
			tempPosTimezone,
			UTCTime = 0;

		if (tempDate.childNodes !== undefined && typeof tempDate.childNodes[1] !== 'undefined' && typeof tempDate.childNodes[1].childNodes[0] !== 'undefined' && tempDate.childNodes[1].childNodes[0].nodeValue !== null) {
			tempDateinnerhTML = tempDate.childNodes[0].nodeValue + tempDate.childNodes[1].childNodes[0].nodeValue;
		} else {
			tempDateinnerhTML = tempDate.childNodes[0].nodeValue;
		}

		if (tempTimezone !== false) {
			posTimezone = tempTimezone.indexOf("(UTC") + 1;

			if (posTimezone > 0) {
				tempPosTimezone = tempTimezone.slice(posTimezone, -1);
				UTCTime = tempPosTimezone.substring(3);
			}
		} else {
			posTimezone = tempDate.innerHTML.trim().indexOf("(UTC") + 1;

			if (posTimezone > 0) {
				tempPosTimezone = tempDate.innerHTML.trim().slice(posTimezone, -1);
				UTCTime = tempPosTimezone.substring(3, 5);
			}
		}

		// Creating DateObject from tempDate
		var str = tempDateinnerhTML.trim().split(" ");

		for (var j = 0; j < str.length; j++)
			str[j] = str[j].trim();

		str = str.filter(function(e) { return e; });

		if (tempDateinnerhTML.indexOf(':') === -1) {
			return 0;
		} else {
			if (('TBA' in oc(str)) || ('TBD' in oc(str))) {
				return 0;
			} else {
				var index2 = str.indexOf('-');

				var placeholder_temp2 = 0;
				if (index2 !== -1) {
					str.splice(index2, 1);
					placeholder_temp2 = 1;
				}
				if (str.length === 6)
					str.splice(str.length - 2, 1, 'GMT');
				if (str.length === 5)
					str.splice(str.length - 1, 1, 'GMT');
				if (str.length === 4)
					str.splice(str.length, 1, 'GMT');

				var date_temp_2 = str.join(" ");

				//get the UTC time, and setHours according to it
				endTime = new Date(date_temp_2);
				endTime.setHours(endTime.getHours() - UTCTime);
			}
			return endTime;
		}
	}

	function oc(a) {
		var o = {};
		for (var i = 0; i < a.length; i++) {
			o[a[i]] = '';
		}
		return o;
	}

	function hasClass(element, cls) {
		return (' ' + element.className + ' ').indexOf(' ' + cls + ' ') > -1;
	}

	function updateCountdowns(times) {

		return function() {
			var cssClass = [].slice.call(doc.querySelectorAll('.cssTestClass'));

			//console.log(cssClass);

			if (cssClass) {
				for (var x = 0; x < cssClass.length; x++) {
					cssClass[x].nextElementSibling.parentNode.removeChild(cssClass[x].nextElementSibling);
					cssClass[x].parentNode.removeChild(cssClass[x]);
				}
			}

			var calculatedDifference, time, timeIfEventIsOver, countdown_h;

			for (var i = 0, length = countdowns.length; i < length; i++) {
				calculatedDifference = 0;
				time = times[i];

				timeIfEventIsOver = time - timeNow;
				timeIfEventIsOver = Math.floor(timeIfEventIsOver / 1000);

				countdown_h = Math.floor(timeIfEventIsOver / 3600);
				if (countdown_h < -12) {
					calculatedDifference = 'Done';
				} else if (isNaN(countdown_h))
					calculatedDifference = 'ERROR';
				else {
					calculatedDifference = calculateDifference(time);
				}
				// calculate the difference
				// and update the countdown div/span
				if (calculatedDifference === 'Done') {
					if (isAlreadyDeleted[i] === 0) {
						countdowns[i].parentNode.removeChild(countdowns[i]);
						isAlreadyDeleted[i] = '1';
					}
				} else {
					if (calculatedDifference !== 'LIVE!')
						countdowns[i].innerHTML = calculatedDifference;
					else {
						if (ClassIsAlreadySet[i] === 0) {
							calculatedDifference = (streams[i] && streams[i] != 0) ? '<a class="hasStream" href=http://www.teamliquid.net/video/streams/'+streams[i].data+' target="_blank">LIVE!</a>' : "LIVE!";
							countdowns[i].innerHTML = calculatedDifference;
							countdowns[i].className += " EventIsLive";
							ClassIsAlreadySet[i] = 1;
						}
					}
				}
			}
		};
	}

	function calculateDifference(diffTime) {

		var string;
		var countdown_d, countdown_h, countdown_m, countdown_s, countdown_w;
		var output_s, output_m, output_h, error = '1';
		timeNow = new Date();

		diffTime -= timeNow;
		// calculate difference and save it as String in "string"
		diffTime = Math.floor(diffTime / 1000);

		if (diffTime >= 0) {

			countdown_w = Math.floor(diffTime / 604800);
			diffTime = diffTime % 604800;
			countdown_d = Math.floor(diffTime / 86400);
			diffTime = diffTime % 86400;
			countdown_h = Math.floor(diffTime / 3600);
			diffTime = diffTime % 3600;
			countdown_m = Math.floor(diffTime / 60);
			countdown_s = diffTime % 60;

			if (countdown_s < 10) output_s = '0' + countdown_s;
			else output_s = countdown_s;
			if (countdown_m < 10) output_m = '0' + countdown_m;
			else output_m = countdown_m;
			if (countdown_h < 10) output_h = '0' + countdown_h;
			else output_h = countdown_h;

			if (countdown_d >= 1 && countdown_w >= 1)
				string = countdown_w + 'w ' + countdown_d + tage;
			else if (countdown_d === 0 && countdown_w >= 1)
				string = countdown_w + 'w ' + countdown_d + tage;
			else if (countdown_d > 0 && countdown_w === 0)
				string = countdown_d + tage + ' ' + output_h + 'h ' + output_m + 'm';
			else
				string = output_h + 'h ' + output_m + 'm ' + output_s + 's';
		} else {
			//after 12h the div/span says "done" instead of live
			string = 'LIVE!';
		}
		return string;
	}

	function isInt(n) {
		return typeof n === 'number' && n % 1 === 0;
	}

	setInterval(updateCountdowns(times), 1000);

/* Calendar code by PhiLtheFisH */

	$('.calendar').ready(function () {
	var nowDate = new Date();
	var referenceDate = new Date(
		nowDate.getFullYear(),
		nowDate.getMonth(),
		nowDate.getDate(),
		0, 0, 0);

	// Constants
	var PX_PER_MINUTE = 0.5;
	var MINUTES_PER_DAY = 1440;
	var WIDTH_OF_COLUMN = 103;
	var HEIGHT_OF_CALENDAR = 719;
	var NUMBER_OF_DAYS = 7;

        // Label header row
	var DAYS = ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'];
	for (var i = 0; i < NUMBER_OF_DAYS; i++) {
		$('.calendar-header').append('<div class="calendar-column">' + DAYS[(nowDate.getDay() + i) % 7] + '</div>');
	}
	$('.calendar-header').append('<div style="clear:both;"></div>');

	// Add a red line that marks the current time
	difference = ((nowDate - referenceDate) / 60000);
	topOffset = difference * PX_PER_MINUTE;
	$('.calendar-events').append('<div style="position: absolute; z-index: 2; width: ' + WIDTH_OF_COLUMN + 'px; border-bottom: 2px solid red; top: ' + topOffset + 'px;"></div>');

	// Add events
	$('.calendar-events').find('.calendar-event-item').each(function () {
		var startDate, endDate;

		$(this).find('.start-datetime').each(function () {
			var firstChildAbbr = $(this).find('abbr').first();
			tempTimezone = firstChildAbbr.length > 0 ? firstChildAbbr.attr('title') : false;
			startDate = stringToDate($(this), tempTimezone);
		});
		$(this).find('.end-datetime').each(function () {
			var firstChildAbbr = $(this).find('abbr').first();
			tempTimezone = firstChildAbbr.length > 0 ? firstChildAbbr.attr('title') : false;
			endDate = stringToDate($(this), tempTimezone);
		});

		// Check if dates are properly entered
		if (Object.prototype.toString.call(startDate) === "[object Date]" &&
			Object.prototype.toString.call(endDate) === "[object Date]") {
			if (!isNaN(startDate.getTime()) && !isNaN(endDate.getTime())) {
				// calculate position of the event in the calendar
 				eventLength = ((endDate - startDate) / 60000) * PX_PER_MINUTE - 9;
				difference = ((startDate - referenceDate) / 60000);
				topOffset = ((difference % MINUTES_PER_DAY + MINUTES_PER_DAY) % MINUTES_PER_DAY) * PX_PER_MINUTE + 1;
				leftOffset = WIDTH_OF_COLUMN * Math.floor(difference / MINUTES_PER_DAY) + 1;
				// event was yesterday or more than a week in the future
				if (leftOffset < -1 || topOffset < -2 || leftOffset > WIDTH_OF_COLUMN * (NUMBER_OF_DAYS - 1) + 1 || topOffset > HEIGHT_OF_CALENDAR) {
					if (eventLength + topOffset > 0 && leftOffset == -(WIDTH_OF_COLUMN-1)) {
						var $clone = $(this).clone();
						$(this).after($clone);
						$clone.css('top', (topOffset - HEIGHT_OF_CALENDAR) + 'px');
						$clone.css('left', (leftOffset + WIDTH_OF_COLUMN) + 'px');
						$clone.css('height', eventLength + 'px');
					}
					$(this).css('display', 'none');
				} else {
					// add event to calendar
					$(this).css('top', topOffset + 'px');
					$(this).css('left', leftOffset + 'px');
					$(this).css('height', eventLength + 'px');
					// if it overlaps (from one day to another), add the another event that is positioned on the next day
					if ((topOffset + eventLength) > HEIGHT_OF_CALENDAR) {
 						$(this).before($(this).clone());
						$(this).css('top', (topOffset - HEIGHT_OF_CALENDAR) + 'px');
						$(this).css('left', (leftOffset + WIDTH_OF_COLUMN) + 'px');
						$(this).css('height', eventLength + 'px');
					}
				}
			} else {
				$(this).css('display', 'none');
			}
		} else {
			$(this).css('display', 'none');
		}
	});
	});

})(window,document);

/* Liquid Layout for Boxes code by Kenjin and stijn */

$(window).on('resize', function() {
	$('.justify-wrap').each(function() {
		var boxes = $(this).find('> div');
		var boxCount = boxes.size();
		var windowSize = $(this).parent().width();
		var boxWidth = boxes.eq(1).width();

		//save box padding upon first resize
		if(!$(this).data('boxPadding'))
			$(this).data('boxPadding', parseInt(boxes.eq(1).css('padding-right')) + parseInt(boxes.eq(1).css('padding-left')));
		var boxPadding = $(this).data('boxPadding');
		//take box model into account when calculating width
		//padding is calculated earlier and reset to be used as margin
		var realWidth = boxWidth + boxPadding +
		parseInt(boxes.eq(1).css('border-left-width')) +
		parseInt(boxes.eq(1).css('border-right-width'));
		//halt reformatting if box is wider than window (no visible effect anyway)
		if(realWidth > windowSize) {
			return false;
		}
		//find the least amount of boxes that fit on a row, while
		//still using the least amount of rows
		var maxBoxes = Math.ceil(boxCount / Math.ceil(boxCount / Math.floor(windowSize / realWidth)));
		var perRow = (boxCount < maxBoxes) ? boxCount : maxBoxes;
		console.log(windowSize);
		//calculate margin between boxes, clamped by box size (max) and padding (min)
		/*
		var margin = Math.floor((windowSize - ((perRow) * realWidth)) / (perRow + 0.5));
		if(margin > realWidth) margin = realWidth;
		if(margin < boxPadding) margin = boxPadding;
		*/
		var margin = boxPadding;
		boxes.each(function(i) {
			$(this).css('padding-left', 0).css('padding-right', 0).css('margin-right', 0);
			$(this).css('display', 'block').css('float', 'left');
			if(i % maxBoxes == 0) {
				$(this).css('clear', 'left').css('margin-left', 0);
			} else {
				$(this).css('clear', 'none').css('margin-left', margin + 'px');
			}
		});
	});
});
$(document).ready(function() {
	$(window).trigger('resize');
});

/* Tabs by ChapatiyaqPTSM, with scroll-to-in-tab-header functionality */
var scrollToUrlAnchor = function() {
	var $j = jQuery;
	if (location.hash) {
		var selector = location.hash.replace( /(:|\.|\[|\])/g, "\\$1" ),
			$tabsPanel, index, $tabs;

		if ($j(selector).length > 0) {
			// If the anchor is in a tab, we need to activate it first.
			$tabsPanel = $j(selector).closest('.ui-tabs-panel');
			if ($tabsPanel.length > 0) {
				var index = $tabsPanel.index('.ui-tabs-panel');
				var $tabs = $tabsPanel.closest('.ui-tabs');
				$tabs.tabs('option', 'selected', index);
			}

			$j(document).scrollTop($j(selector).offset().top);
		}
	}
};
jQuery(document).ready(function() {
	mw.loader.using( 'jquery.ui.tabs', function () {
		jQuery('.tabs-container').tabs({create: scrollToUrlAnchor});
	});
});
jQuery(window).on('load', scrollToUrlAnchor);

/* Liquipedia links */
jQuery(document).ready(function () {
	jQuery('.LiquipediaLinks > a').attr('target', '_blank');
	if (jQuery('h1.firstHeading').length > 0) {
		// Desktop version
		jQuery('h1.firstHeading').first().append(jQuery('.LiquipediaLinks').detach());
	} else if (jQuery('.content .post h2').length > 0) {
		// Mobile version
		jQuery('.content .post h2').first().append(jQuery('.LiquipediaLinks').detach()); 
	}
});

/* Tabs by FO-nTTaX */
$(document).ready (function() {
	$('div.tabs-dynamic ul.nav-tabs > li').each(
		function () {
			$(this).parent().parent().children('div.tabs-content').children('div:eq(' + $(this).index() + ')').prepend('<h6 style="display:none;">' + $(this).html() + '</h6>');
			$(this).html('<a href="javascript:;">' + $(this).html() + '</a>');
		}
	);
	$('div.tabs-dynamic ul.nav-tabs > li:not(.show-all)').click(
		function () {
			var i = $(this).index() + 1;
			$(this).parent().children('li').removeClass('active');
			$(this).addClass('active');
			$(this).parent().parent().children('div.tabs-content').children('div').removeClass('active');
			$(this).parent().parent().children('div.tabs-content').children('div.content' + i).addClass('active');
			$(this).parent().parent().find('div.tabs-content > div > h6:first-child').hide();
		}
	);
	$('div.tabs-dynamic ul.nav-tabs > li.show-all').click(
		function () {
			$(this).parent().children('li').removeClass('active');
			$(this).addClass('active');
			$(this).parent().parent().children('div.tabs-content').children('div').addClass('active');
			$(this).parent().parent().find('div.tabs-content > div > h6:first-child').show();
		}
	);
	$('div.tabs-dynamic').each(function(index) {
		var h = $(this).children('ul.nav-tabs').children('li.active').index() + 1;
		$(this).children('div.tabs-content').children('div.content' + h).addClass('active');
	});
	onHashChangeTabs();
});
window.addEventListener("hashchange", onHashChangeTabs, false);
function onHashChangeTabs() {
	var hash = location.hash.slice(1);
	if (hash.substring(0, 4) == 'tab-') {
		var hasharr = hash.split('-scrollto-');
		var tabno = hasharr[0].replace('tab-', '');
		var scrollto = null;
		if (hasharr.length == 2) {
			scrollto = '#' + hasharr[1];
		}
		showDynamicTab(tabno, scrollto);
	} else {
		var scrollto = location.hash;
		var tabno = $(scrollto).parents('.tabs-dynamic .tabs-content [class*=content]').index();
		if(tabno != -1) {
			showDynamicTab(tabno + 1, scrollto);
		}
	}
}
function showDynamicTab(tabno, scrollto) {
	$('div.tabs-dynamic ul.nav-tabs li').removeClass('active');
	$('div.tabs-dynamic ul.nav-tabs li.tab' + tabno).addClass('active');
	$('div.tabs-dynamic div.tabs-content div').removeClass('active');
	$('div.tabs-dynamic div.tabs-content div.content' + tabno).addClass('active');
	if (scrollto != null) {
		setTimeout(function(){$(window).scrollTop($(scrollto).offset().top)}, 500);
	}
}
$('.tabs-dynamic .nav-tabs > li a, .matchlistslot a').attr('href', 'javascript:;');

/* Cross table row/column highlights */
$('.crosstable td').hover(function() {
	var crcolumn = parseInt($(this).index()) + 1;
	var crcolumnp = crcolumn + 1;
	var crcolumnm = crcolumn - 1;
	var crrow = parseInt($(this).parent().index()) + 1;
	var crrowp = crrow + 1;
	var crrowm = crrow - 1;
	$(this).closest('table').find('tr:not(:nth-child(' + crrow + '))').find('td:nth-child(' + crcolumnp + ')').addClass('crosstable-highlighted-column-right');
	$(this).closest('table').find('tr:not(:nth-child(' + crrow + '))').find('td:nth-child(' + crcolumnm + ')').addClass('crosstable-highlighted-column-left');
	$(this).closest('table').find('tr:nth-child(' + crrowp + ')').find('td:not(:nth-child(' + crcolumn + '))').addClass('crosstable-highlighted-row-lower');
	$(this).closest('table').find('tr:nth-child(' + crrowm + ')').find('td:not(:nth-child(' + crcolumn + '))').addClass('crosstable-highlighted-row-upper');
	$(this).closest('table').find('tr:not(:nth-child(' + crrow + '))').find('td:not(:nth-child(' + crcolumn + '))').addClass('crosstable-muted');
},
function() {
	var crcolumn = parseInt($(this).index()) + 1;
	var crcolumnp = crcolumn + 1;
	var crcolumnm = crcolumn - 1;
	var crrow = parseInt($(this).parent().index()) + 1;
	var crrowp = crrow + 1;
	var crrowm = crrow - 1;
	$(this).closest('table').find('td:nth-child(' + crcolumnp + ')').removeClass('crosstable-highlighted-column-right');
	$(this).closest('table').find('td:nth-child(' + crcolumnm + ')').removeClass('crosstable-highlighted-column-left');
	$(this).closest('table').find('tr:nth-child(' + crrowp + ')').find('td').removeClass('crosstable-highlighted-row-lower');
	$(this).closest('table').find('tr:nth-child(' + crrowm + ')').find('td').removeClass('crosstable-highlighted-row-upper');
	$(this).closest('table').find('tr:not(:nth-child(' + crrow + '))').find('td:not(:nth-child(' + crcolumn + '))').removeClass('crosstable-muted');
});
;$('.crosstable').find('tr:not(:last-child)').children('th').hover(function() {
	var crrow = parseInt($(this).parent().index()) + 1;
	var crrowp = crrow + 1;
	var crrowm = crrow - 1;
	$(this).closest('table').find('tr:nth-child(' + crrowp + ')').find('td').addClass('crosstable-highlighted-row-lower');
	$(this).closest('table').find('tr:nth-child(' + crrowm + ')').find('td').addClass('crosstable-highlighted-row-upper');
	$(this).closest('table').find('tr:not(:nth-child(' + crrow + '))').find('td').addClass('crosstable-muted');
}, 
function() {
	var crrow = parseInt($(this).parent().index()) + 1;
	var crrowp = crrow + 1;
	var crrowm = crrow - 1;
	$(this).closest('table').find('tr:nth-child(' + crrowp + ')').find('td').removeClass('crosstable-highlighted-row-lower');
	$(this).closest('table').find('tr:nth-child(' + crrowm + ')').find('td').removeClass('crosstable-highlighted-row-upper');
	$(this).closest('table').find('tr:not(:nth-child(' + crrow + '))').find('td').removeClass('crosstable-muted');
});

/* Toggle groups (see Template:Toggle group start) */
var toggleShowCaption = 'show all', toggleHideCaption = 'hide all';
$('.toggle-group').each( function(index) {
	var toggleDefaultState = $(this).is('.toggle-state-hide') ? 'Hide' : 'Show',
	    $button = $('<span>')
		.html('[')
		.append($('<a>').addClass('toggle-button').text(window['toggle' + toggleDefaultState + 'Caption']).data('toggle-group-index', index).attr('href', 'javascript:'))
		.append(']');
	$(this).prepend($button);
	$(this).attr('id', 'toggle-group-' + index);
});
$('.toggle-button').click( function() {
	var toggleAction = $(this).text();
	$('#toggle-group-' + $(this).data('toggle-group-index')).find('.collapseButton a').each( function() {
		if (($(this).text() == collapseCaption && toggleAction == toggleHideCaption) || ($(this).text() == expandCaption && toggleAction == toggleShowCaption)) {
			$(this)[0].click();
		}
	});
	$(this).text($(this).text() == toggleShowCaption ? toggleHideCaption : toggleShowCaption);
});

/* collapse new prize pool tables */
$(document).ready(function () {
	if ($('table.prizepooltable').length) {
		$('table.prizepooltable').each(function (index) {
			$(this).addClass('collapsed');
			var cutafter;
			if (($(this).attr('data-cutafter')) && ($(this).data('cutafter') == '')) {
				cutafter = 5;
			} else {
				cutafter = parseInt($(this).data('cutafter')) +  1;
			}
			var cutfrom = cutafter;
			var cutto = $(this).find('tr').length - 1;
			if ($(this).hasClass('prizepooltable2')) {
				cutfrom = Math.ceil(cutfrom / 2);
				cutto = Math.ceil(cutto / 2);
			}
			$(this).data('definedcutafter', cutafter + 2);
			if ($(this).find('tr').length > cutafter) {
				$(this).find('tr:nth-child('+cutafter+')').after('<tr><td colspan="'+$(this).find('tr:nth-child(2) td').length+'"><small class="prizepooltableshow">click "show" to display place '+cutfrom+' to '+ cutto +'</small><small class="prizepooltablehide">click "hide" to hide place '+cutfrom+' to '+ cutto +'</small><span class="prizepooltablecollapsebutton">[<span class="prizepooltableshow">show</span><span class="prizepooltablehide">hide</span>]</span></td></tr>');
				$(this).closest('table.prizepooltable').find('tr:nth-child(n+'+ $(this).closest('table.prizepooltable').data('definedcutafter') +')').css('display', 'none');
			}
		});
		$('.prizepooltablecollapsebutton').click(function() {
			$(this).closest('table.prizepooltable').toggleClass('collapsed');
			$(this).closest('table.prizepooltable').find('tr:nth-child(n+'+ $(this).closest('table.prizepooltable').data('definedcutafter') +')').toggle();
		});
	}
});

/*******************************************************************************
Template(s): Popups for all Brackets
Author(s): Anomek, FO-nTTaX
*******************************************************************************/
var bracketGame;
$.fn.justtext = function() {
	return $(this).clone().children().remove('div.bracket-score').end().text().trim();
};
$(document).ready(function() {
	$('.bracket-game').each( function() {
		if ($(this).find('.bracket-game-details, .bracket-popup-wrapper').length > 0) {
			var margin = $(this).find(':first-child').height() - 6;
			$(this).prepend('<div class="icon" style="margin-top:' + margin + 'px;"></div>');
			$(this).find('.bracket-team-top, .bracket-team-bottom, .bracket-player-top, .bracket-player-bottom').each(function() {
				$(this).css('cursor', 'pointer');
				$(this).attr('title', 'Click for further information');
			});
		}
	});
	$('tr.match-row').each( function() {
		if ($(this).find('.bracket-game-details, .bracket-popup-wrapper').length > 0) {
			$(this).children('td:eq(2)').prepend('<div style="position:relative"><div class="match-row-icon"></div></div>');
		}
		$(this).attr('title', 'Click for further information');
	});

	$('html').click(function () {
		if (bracketGame != null) {
			bracketGame.find('.bracket-game-details, .bracket-popup-wrapper').toggle();
			bracketGame = null;
		}
	});

	$('.bracket-team-top, .bracket-team-bottom, .bracket-player-top, .bracket-player-bottom, .bracket-game .icon').click(
	function (event) {
		var bracket = $(this).closest('.bracket, .crosstable td'), bracketWrapper = $(this).closest('.bracket-wrapper, .crosstable'),
			detailsHeight, detailsWidth, spaceOnTheRight, popupOnTheRight = true;
		if (bracketGame != null) {
			bracketGame.find('.bracket-game-details, .bracket-popup-wrapper').toggle();
			if (bracketGame[0] === $(this).closest('.bracket-game')[0]) {
				bracketGame = null;
				return;
			}
		}
		bracketGame = $(this).closest('.bracket-game');

		positionBracketPopup();

		bracketGame.children('.bracket-game-details, .bracket-popup-wrapper').css('margin-left', '');
		bracketGame.children('.bracket-game-details, .bracket-popup-wrapper').toggle();
		if(popupOnTheRight && bracketGame.offset().left + bracketGame.outerWidth() + detailsWidth > bracketWrapper.outerWidth() + bracketWrapper.offset().left) {
			bracketWrapper.scrollLeft(bracketWrapper.scrollLeft() + detailsWidth);
		}

		positionBracketPopup();
		
		event.stopPropagation();
	});
	$('tr.match-row').click(function (event) {
		if (bracketGame != null) {
			bracketGame.find('.bracket-game-details, .bracket-popup-wrapper').toggle();
			if (bracketGame[0] === $(this)[0]) {
				bracketGame = null;
				return;
			}
		}
		bracketGame = $(this);
		bracketGame.find('.bracket-game-details').css('position', 'fixed');
		positionGroupTablePopup();
		bracketGame.find('.bracket-game-details, .bracket-popup-wrapper').css('margin-left', '');
		bracketGame.find('.bracket-game-details, .bracket-popup-wrapper').toggle();
		positionGroupTablePopup();
		event.stopPropagation();
	});
	$('.bracket-game-details, .bracket-popup-wrapper').click(function (event) {
		event.stopPropagation();
	});
});

$(window).scroll(function() {
	positionBracketPopup();
	positionGroupTablePopup();
});
$('.bracket-wrapper').scroll(function() {
	positionBracketPopup();
});
$(window).resize(function() {
	positionBracketPopup();
	positionGroupTablePopup();
});

$('head').append('<style>.bracket-popup-mobile{position:fixed;bottom:0px;left:0px;margin:0;width:100% !important;border-radius:0px !important;border-left:0 !important;border-right:0 !important;}</style>');

function positionBracketPopup() {
	if((bracketGame != null) && (bracketGame.find('.icon').length)) {
		if($(document).width() > 600) {
			var bracket = bracketGame.closest('.bracket, .crosstable td'), bracketWrapper = bracketGame.closest('.bracket-wrapper, .crosstable'),
				detailsHeight, detailsWidth, spaceOnTheRight, popupOnTheRight = true;
			detailsHeight = bracketGame.children('.bracket-game-details, .bracket-popup-wrapper').height();
			detailsWidth = bracketGame.children('.bracket-game-details, .bracket-popup-wrapper').width();
			bracketGame.children('.bracket-game-details, .bracket-popup-wrapper').css('top', bracketGame.find('.icon').offset().top + (bracketGame.find('.icon').height() / 2) - (detailsHeight / 2) - $(window).scrollTop());
			spaceOnTheRight = Math.max($(window).width(), bracket.offset().left + bracketWrapper.outerWidth()) - (bracketGame.offset().left + bracketGame.outerWidth());
			if((spaceOnTheRight < detailsWidth && bracketGame.offset().left > detailsWidth) || (bracketGame.offset().left + bracketGame.width() > $('#mw-content-text').offset().left + $('#mw-content-text').width())) {
				bracketGame.children('.bracket-game-details, .bracket-popup-wrapper').css('left', bracketGame.offset().left - detailsWidth - 1);
			} else {
				bracketGame.children('.bracket-game-details, .bracket-popup-wrapper').css('left', bracketGame.offset().left + bracketGame.width());
			}
			bracketGame.children('.bracket-game-details, .bracket-popup-wrapper').removeClass('bracket-popup-mobile');
			bracketGame.children('.bracket-game-details').css('position', 'fixed');
			bracketGame.children('.bracket-game-details').css('margin-left', '');
			bracketGame.children('.bracket-game-details').children('div').css('width', '');
			bracketGame.children('.bracket-game-details').children('div').children('.left, .right').css('width', '');
		} else {
			var bracket = bracketGame.closest('.bracket, .crosstable td');
			if(!bracketGame.children('.bracket-game-details, .bracket-popup-wrapper').hasClass('bracket-popup-mobile')) {
				bracketGame.children('.bracket-game-details, .bracket-popup-wrapper').addClass('bracket-popup-mobile');
			}
			bracketGame.children('.bracket-game-details, .bracket-popup-wrapper').css('top', '').css('left', '');
			bracketGame.children('.bracket-game-details').css('position', 'fixed');
			bracketGame.children('.bracket-game-details').css('margin-left', '');
			bracketGame.children('.bracket-game-details').children('div').css('width', bracketGame.children('.bracket-game-details').width() + 'px');
			bracketGame.children('.bracket-game-details').children('div').children('.left, .right').css('width', (bracketGame.children('.bracket-game-details, .bracket-popup-wrapper').width() / 2) + 'px');
		}
	}
}
function positionGroupTablePopup() {
	if((bracketGame != null) && (bracketGame.find('.match-row-icon').length)) {
		if($(document).width() > 600) {
			var row = bracketGame, detailsWidth;
			detailsWidth = bracketGame.find('.bracket-popup-wrapper').width();
			bracketGame.find('.bracket-popup-wrapper').css('top', row.offset().top + row.height() - $(window).scrollTop());
			bracketGame.find('.bracket-popup-wrapper').css('left', row.offset().left + (row.width() / 2) - (detailsWidth / 2));
			bracketGame.find('.bracket-popup-wrapper').removeClass('bracket-popup-mobile');
		} else {
			if(!bracketGame.find('.bracket-popup-wrapper').hasClass('bracket-popup-mobile')) {
				bracketGame.find('.bracket-popup-wrapper').addClass('bracket-popup-mobile');
			}
			bracketGame.find('.bracket-popup-wrapper').css('top', '').css('left', '');
		}
	}
}

/*******************************************************************************
Template(s): Highlighting for all Brackets
Author(s): FO-nTTaX
*******************************************************************************/
var highlightingsearch = [];
var highlightingstandardicon = [
	'Csgologo_std.png', //CS:GO
	'Csslogo_std.png', //CS:Source
	'Cstrikelogo_std.png', //CS:1.6
	'Dotalogo_std.png', //Dota 2
	'Fistlogo_std.png', //Fighting Games
	'Hotslogo_std.png', //Heroes of the Storm
	'Logo_filler_std.png', //Blank file, SC, SC2
	'Overwatchlogo_std.png', //Overwatch
	'Rllogo_std.png', //Rocketleague
	'Warcraft_std.png' //Warcraft
];
$(document).ready(function() {

	$('tr.match-row').hover(function () {
		$(this).addClass('bracket-hover');
		if ($(this).closest('tr.match-row').find('.bracket-game-details, .bracket-popup-wrapper').length) {
			$(this).css('cursor', 'pointer');
		}
	}, function () {
		$(this).removeClass('bracket-hover');
	});

	if($('.bind-highlighting').length > 0) {
		var highlightingbinds = [];
		$('.bind-highlighting').each(function () {
			var to = $(this).children('.bind-highlighting-to');
			var from = $(this).children('.bind-highlighting-from');

			var icto = $(to).find('.team-template-image img');
			if (icto.length == 1) {
				var icsrcto = icto.attr('src').split('/');
				icsrcto = icsrcto[icsrcto.length - 1];
				icsrcto = icsrcto.replace("-icon", "_std");
				if (icsrcto.indexOf('-') != -1) {
					icsrcto = icsrcto.split('-');
					icsrcto = icsrcto[icsrcto.length - 1];
				}
				if (highlightingstandardicon.indexOf(icsrcto) != -1) {
					icsrcto = $(to).justtext();
				}
			} else {
				var icsrcto = $(to).justtext();
			}
			var icfrom = $(from).find('.team-template-image img');
			if (icfrom.length == 1) {
				var icsrcfrom = icfrom.attr('src').split('/');
				icsrcfrom = icsrcfrom[icsrcfrom.length - 1];
				icsrcfrom = icsrcfrom.replace("-icon", "_std");
				if (icsrcfrom.indexOf('-') != -1) {
					icsrcfrom = icsrcfrom.split('-');
					icsrcfrom = icsrcfrom[icsrcfrom.length - 1];
				}
				if (highlightingstandardicon.indexOf(icsrcfrom) != -1) {
					icsrcfrom = $(from).justtext();
				}
			} else {
				var icsrcfrom = $(from).justtext();
			}
			highlightingbinds[icsrcfrom] = icsrcto;
		});
	}
	$('.bracket-team-top, .bracket-team-bottom, .bracket-team-middle, .bracket-player-top, .bracket-player-bottom, .bracket-player-middle, .matchlistslot, .matchslot, .grouptableslot').each(function() {
		var ic = $(this).find('.team-template-image img');
		if (ic.length == 1) {
			var icsrc = ic.attr('src').split('/');
			icsrc = icsrc[icsrc.length - 1];
			icsrc = icsrc.replace("-icon", "_std");
			if (icsrc.indexOf('-') != -1) {
				icsrc = icsrc.split('-');
				icsrc = icsrc[icsrc.length - 1];
			}
			if (highlightingstandardicon.indexOf(icsrc) != -1) {
				icsrc = $(this).justtext();
			}
			if ((typeof highlightingbinds !== 'undefined') && (icsrc in highlightingbinds)) {
				icsrc = highlightingbinds[icsrc];
			}
			if (!Array.isArray(highlightingsearch[icsrc])) {
				highlightingsearch[icsrc] = [];
			}
			highlightingsearch[icsrc].push(this);
			$(this).data('highlightingkey', icsrc);
		} else {
			var icsrc = $(this).justtext();
			if ((typeof highlightingbinds !== 'undefined') && (icsrc in highlightingbinds)) {
				icsrc = highlightingbinds[icsrc];
			}
			if (!Array.isArray(highlightingsearch[icsrc])) {
				highlightingsearch[icsrc] = [];
			}
			highlightingsearch[icsrc].push(this);
			$(this).data('highlightingkey', icsrc);
			
			/* Starcraft/Warcraft specific start */
			if ((!$(this).hasClass('grouptableslot')) && (!$(this).hasClass('matchlistslot'))) {
				$(this).data('background-color', $(this).css('background-color'));
				switch ($(this).data('background-color')) {
					case 'rgb(242, 184, 184)':
						$(this).data('background-color-hover', 'rgb(250,217,217)'); //Zerg/Orc
						break;
					case 'rgb(184, 242, 184)':
						$(this).data('background-color-hover', 'rgb(217,250,217)'); //Protoss/Nightelf
						break;
					case 'rgb(184, 184, 242)':
						$(this).data('background-color-hover', 'rgb(217,217,250)'); //Terran/Human
						break;
					case 'rgb(242, 184, 242)':
						$(this).data('background-color-hover', 'rgb(250,217,250)'); //Undead
						break;
					case 'rgb(242, 242, 184)':
						$(this).data('background-color-hover', 'rgb(250,250,217)'); //Random
						break;
					default:
						$(this).data('background-color-hover', 'rgb(250,250,250)'); //normal
						break;
				}
			}
			/* Starcraft/Warcraft specific end */
		}
	});
	$('.bracket-team-top, .bracket-team-bottom, .bracket-team-middle, .bracket-player-top, .bracket-player-bottom, .bracket-player-middle, .matchlistslot, .matchslot, .grouptableslot').hover(function() {
		var icsrc = $(this).data('highlightingkey');
		if (typeof icsrc !== 'undefined') {
			var filter = ['BYE', 'TBD', 'TBA', '', 'LOGO_FILLER_STD.PNG'];
			if (filter.indexOf(icsrc.toUpperCase()) == -1) {
				$.each(highlightingsearch[icsrc], function() {
					$(this).addClass('bracket-hover');
					/* Starcraft specific start */
					if (typeof $(this).data('background-color-hover') !== 'undefined') {
						$(this).css('background-color', $(this).data('background-color-hover'));
					}
					/* Starcraft specific end */
				});
			}
		}
	}, function() {
		var icsrc = $(this).data('highlightingkey');
		if (typeof icsrc !== 'undefined') {
			$.each(highlightingsearch[icsrc], function() {
				$(this).removeClass('bracket-hover');
				/* Starcraft specific start */
				if (typeof $(this).data('background-color-hover') !== 'undefined') {
					$(this).css('background-color', $(this).data('background-color'));
				}
				/* Starcraft specific end */
			});
		}
	});
  
});

/* "Select all" by Chapatiyaq */
$(document).ready( function() {
	$( 'pre.selectall' ).each( function() {
		var $wrapper, $relative;
 
		$wrapper = $( '<div class="selectall-wrapper"></div>' ).insertBefore( $(this) );
		$(this).detach().appendTo( $wrapper );
 
		$(this).before( $( '<a class="selectall-button" href="javascript:;">Select all</a>' ) );
 
		$relative = $( '<div class="selectall-relative"></div>' ).insertBefore( $(this) );
		$(this).detach().appendTo( $relative );
	});
 
	$( 'div.selectall-wrapper' ).on( 'blur', 'textarea.selectall-duplicate', function() {
		$(this).remove();
	});
 
	$( 'a.selectall-button' ).on( 'click', function() {
		var $wrapper = $(this).closest( 'div.selectall-wrapper' ),
			$pre = $wrapper.find( 'pre.selectall' );
 
		$( '<textarea>' )
			.attr( 'readonly', true )
			.addClass( 'selectall-duplicate' )
			.text( $pre.text() )
			.appendTo( $wrapper.find( 'div.selectall-relative' ) )
			.css( {
				'padding': $pre.css( 'padding' ),
				'line-height': $pre.css( 'line-height' ),
				'font-family': $pre.css( 'font-family' ),
				'font-size': $pre.css( 'font-size' )
			})
			.focus().select();
	});
});

/* Hide / show stuff when logged in (does not work with the WPtouch skin for now) */
$(document).ready(function () {
	mw.loader.using('mediawiki.user', function() {
		$('.hidden-when-logged-in').toggle( mw.user.isAnon() );
		$('.shown-when-logged-in').toggle( !mw.user.isAnon() );
	});
});

/* Dismissable SiteNotice by FO-nTTaX */
$(document).ready(function() {
	$('#siteNotice').prepend('<div id="closeSiteNotice" style="float:right;cursor:pointer;font-size:14px;border:1px solid #333333;margin:10px;line-height:10px;padding:5px;" title="Close Notice">x</div>');

	$('#closeSiteNotice').click(function() {
		$('#siteNotice').fadeOut(500);
		var d = new Date(+new Date + 12096e5);
		document.cookie='showSiteNotice=false; domain=wiki.teamliquid.net; expires=' + d.toUTCString() + '; path=/' + window.location.href.split('/')[3] + '/';
	});

	if(document.cookie.indexOf('showSiteNotice=false') != -1) {
		$('#siteNotice').hide();
	}
});


/***************************************************************************/

/* check if the user is scrolling */
var dragging = false;
$('body').on('touchmove', function(){
	/* set to true when the user is scrolling */
	dragging = true;
});
/* reset dragging to false when a touchevent starts */
$('body').on('touchstart', function(){
	dragging = false;
});

/*! matchMedia() polyfill - Test a CSS media type/query in JS. Authors & copyright (c) 2012: Scott Jehl, Paul Irish, Nicholas Zakas, David Knight. Dual MIT/BSD license 
Full license: https://raw.githubusercontent.com/paulirish/matchMedia.js/master/LICENSE.txt */

window.matchMedia || (window.matchMedia = function() {
	"use strict";

	// For browsers that support matchMedium api such as IE 9 and webkit
	var styleMedia = (window.styleMedia || window.media);

	// For those that don't support matchMedium
	if (!styleMedia) {
		var style       = document.createElement('style'),
			script      = document.getElementsByTagName('script')[0],
			info        = null;

		style.type  = 'text/css';
		style.id    = 'matchmediajs-test';

		script.parentNode.insertBefore(style, script);

		// 'style.currentStyle' is used by IE <= 8 and 'window.getComputedStyle' for all other browsers
		info = ('getComputedStyle' in window) && window.getComputedStyle(style, null) || style.currentStyle;

		styleMedia = {
			matchMedium: function(media) {
				var text = '@media ' + media + '{ #matchmediajs-test { width: 1px; } }';

				// 'style.styleSheet' is used by IE <= 8 and 'style.textContent' for all other browsers
				if (style.styleSheet) {
					style.styleSheet.cssText = text;
				} else {
					style.textContent = text;
				}

				// Test if media query is true or false
				return info.width === '1px';
			}
		};
	}

	return function(media) {
		return {
			matches: styleMedia.matchMedium(media || 'all'),
			media: media || 'all'
		};
	};
}());

/* Scale brackets to screenwidth */
function scalebrackets () {
	$('.bracket-wrapper').css('position', 'relative');
	var windowwidth = window.innerWidth;
	var bracketscale;
	var bracketheight;
	var bracketwidth;
	var bracketscalestr;
	$('.bracket-wrapper').each(function() {
		if ($(this).parents('.tabs-content').length) {
			return;
		}
		$(this).children('.bracket').css('position', 'absolute');
		$(this).children('.bracket-push').data('padding-top', $(this).children('.bracket').height());
		$(this).children('.bracket-wrapper').data('width', $(this).children('.bracket').width());
		$(this).children('.bracket-push').css('padding-top', $(this).children('.bracket').height()+'px');
		$(this).css('width', parseInt($(this).children('.bracket').css('width'))+'px');
		bracketscale = windowwidth / parseInt($(this).children('.bracket').css('width'));
		if (bracketscale < 1) {
			bracketheight = parseInt($(this).children('.bracket').css('height')) * bracketscale;
			bracketwidth = parseInt($(this).children('.bracket').css('width')) * bracketscale;
			bracketscalestr = 'scale('+bracketscale+')';
			$(this).children('.bracket').css('-webkit-transform', bracketscalestr);
			$(this).children('.bracket').css('transform', bracketscalestr);
			$(this).children('.bracket-push').css('padding-top', bracketheight+'px');
			$(this).css('width', bracketwidth+'px');
		}
	});
}
$('.bracket-wrapper').bind('touchend', function(){
	/* only trigger the resize, when the user is not scrolling */
	if (dragging) {
		return;
	}
	$(this).children('.bracket').css('-webkit-transform', 'scale(1)');$(this).children('.bracket').css('transform', 'scale(1)');
	$(this).children('.bracket-push').css('padding-top', $(this).children('.bracket-push').data('padding-top')+'px');
	$(this).children('.bracket-wrapper').css('width', $(this).data('width')+'px');
});

/* Main Page specific */
jQuery(document).ready( function($) {
	if (matchMedia("screen and (max-width : 1000px)").matches
		&& $('.page-Main_Page').length > 0) {
		var boxesOrder = [
			'#infobox_tournaments',
			'#infobox_portals',
			'#infobox_game_news',
			'#infobox_transfers',
			'#infobox_liquipedia_news'
		];

		$('.content > .post > h2').hide();
		$('.content > .post > h2 + hr').hide();

		$.each(boxesOrder, function(i, value) {
			$(value).detach().appendTo($('.infoboxes'));
		});
		
		$('.infobox_news_2').css('height', 'inherit');
		$('.infobox_news_2 .mpboxtitle').click(function() {
			$(this).parent().toggleClass('open-section');
		});
	}
	/* Scale brackets to screenwidth */
	scalebrackets();
});