<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="lt">
	<id>https://wiki.mcslime.lt/index.php?action=history&amp;feed=atom&amp;title=MediaWiki%3AGadget-site.js</id>
	<title>MediaWiki:Gadget-site.js - Versijų istorija</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.mcslime.lt/index.php?action=history&amp;feed=atom&amp;title=MediaWiki%3AGadget-site.js"/>
	<link rel="alternate" type="text/html" href="https://wiki.mcslime.lt/index.php?title=MediaWiki:Gadget-site.js&amp;action=history"/>
	<updated>2026-04-09T07:26:12Z</updated>
	<subtitle>Šio puslapio versijų istorija projekte</subtitle>
	<generator>MediaWiki 1.41.0</generator>
	<entry>
		<id>https://wiki.mcslime.lt/index.php?title=MediaWiki:Gadget-site.js&amp;diff=1000&amp;oldid=prev</id>
		<title>M0dii: Naujas puslapis: /**  * Scripts placed here are loaded on both desktop and mobile views.  *   * Desktop-only scripts should go in MediaWiki:Common.js  * Mobile-only scripts should go in MediaWiki:Minerva.js.  */  ( function() { &#039;use strict&#039;;  /* Variables for interface text used throughout the script, for ease of translating */ var i18n = { 	// Collapsible elements and page loader 	hideText: &#039;hide&#039;, 	showText: &#039;show&#039;, 	loadErrorTitle: &#039;An error occurred loading the content&#039; };  /* F...</title>
		<link rel="alternate" type="text/html" href="https://wiki.mcslime.lt/index.php?title=MediaWiki:Gadget-site.js&amp;diff=1000&amp;oldid=prev"/>
		<updated>2025-04-13T09:59:36Z</updated>

		<summary type="html">&lt;p&gt;Naujas puslapis: &lt;span dir=&quot;auto&quot;&gt;&lt;span class=&quot;autocomment&quot;&gt;*  * Scripts placed here are loaded on both desktop and mobile views.  *   * Desktop-only scripts should go in &lt;a href=&quot;/w/MediaWiki:Common.js&quot; title=&quot;MediaWiki:Common.js&quot;&gt;MediaWiki:Common.js&lt;/a&gt;  * Mobile-only scripts should go in &lt;a href=&quot;/w/MediaWiki:Minerva.js&quot; title=&quot;MediaWiki:Minerva.js&quot;&gt;MediaWiki:Minerva.js&lt;/a&gt;.: &lt;/span&gt;  ( function() { &amp;#039;use strict&amp;#039;;  &lt;span dir=&quot;auto&quot;&gt;&lt;span class=&quot;autocomment&quot;&gt;Variables for interface text used throughout the script, for ease of translating: &lt;/span&gt; var i18n = { 	// Collapsible elements and page loader 	hideText: &amp;#039;hide&amp;#039;, 	showText: &amp;#039;show&amp;#039;, 	loadErrorTitle: &amp;#039;An error occurred loading the content&amp;#039; };  /* F...&lt;/span&gt;&lt;/span&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Naujas puslapis&lt;/b&gt;&lt;/p&gt;&lt;div&gt;/**&lt;br /&gt;
 * Scripts placed here are loaded on both desktop and mobile views.&lt;br /&gt;
 * &lt;br /&gt;
 * Desktop-only scripts should go in [[MediaWiki:Common.js]]&lt;br /&gt;
 * Mobile-only scripts should go in [[MediaWiki:Minerva.js]].&lt;br /&gt;
 */&lt;br /&gt;
&lt;br /&gt;
( function() {&lt;br /&gt;
&amp;#039;use strict&amp;#039;;&lt;br /&gt;
&lt;br /&gt;
/* Variables for interface text used throughout the script, for ease of translating */&lt;br /&gt;
var i18n = {&lt;br /&gt;
	// Collapsible elements and page loader&lt;br /&gt;
	hideText: &amp;#039;hide&amp;#039;,&lt;br /&gt;
	showText: &amp;#039;show&amp;#039;,&lt;br /&gt;
	loadErrorTitle: &amp;#039;An error occurred loading the content&amp;#039;&lt;br /&gt;
};&lt;br /&gt;
&lt;br /&gt;
/* Fired whenever wiki content is added. (#mw-content-text, live preview, load page, etc.) */&lt;br /&gt;
mw.hook( &amp;#039;wikipage.content&amp;#039; ).add( function( $wikipageContent ) {&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
/**&lt;br /&gt;
 * Collapsible elements&lt;br /&gt;
 *&lt;br /&gt;
 * Add the &amp;quot;collapsible&amp;quot; class to an element and the child element with class &amp;quot;collapsible-content&amp;quot;&lt;br /&gt;
 * (or everything but the header row if a table) will be hidden when the element is collapsed.&lt;br /&gt;
 *&lt;br /&gt;
 * * Add the class &amp;quot;collapsed&amp;quot; to the element to make it start out collapsed.&lt;br /&gt;
 * * Add either &amp;quot;collapsetoggle-left&amp;quot; or &amp;quot;collapsetoggle-inline&amp;quot; to the element to choose the collapse&lt;br /&gt;
 *   toggle alignment (defaults to right).&lt;br /&gt;
 * * Add an ID in the format of &amp;quot;collapsible-&amp;lt;x&amp;gt;&amp;quot; to the element to make any element with the class&lt;br /&gt;
 *  &amp;quot;collapsetoggle-custom&amp;quot; and a matching class in the format of &amp;quot;collapsible-&amp;lt;x&amp;gt;-toggle&amp;quot; control&lt;br /&gt;
 *   the collapsing instead of the standard button.&lt;br /&gt;
 *   If the custom toggle contains an element with the &amp;quot;jslink&amp;quot; class, only that will be clickable.&lt;br /&gt;
 */&lt;br /&gt;
( function() {&lt;br /&gt;
	var $collapsibles = $wikipageContent.find( &amp;#039;.collapsible&amp;#039; );&lt;br /&gt;
	if ( !$collapsibles.length ) {&lt;br /&gt;
		return;&lt;br /&gt;
	}&lt;br /&gt;
	&lt;br /&gt;
	var $toggleTemplate = $( &amp;#039;&amp;lt;span&amp;gt;&amp;#039; ).addClass( &amp;#039;collapsetoggle&amp;#039; ).append(&lt;br /&gt;
		&amp;#039;[&amp;#039;, $( &amp;#039;&amp;lt;span&amp;gt;&amp;#039; ).addClass( &amp;#039;jslink&amp;#039; ), &amp;#039;]&amp;#039;&lt;br /&gt;
	);&lt;br /&gt;
	$collapsibles.each( function() {&lt;br /&gt;
		var $collapsible = $( this );&lt;br /&gt;
		if ( $collapsible.data( &amp;#039;made-collapsible&amp;#039; ) ) {&lt;br /&gt;
			return true;&lt;br /&gt;
		}&lt;br /&gt;
		&lt;br /&gt;
		var $children = $collapsible.children();&lt;br /&gt;
		var showText = $collapsible.data( &amp;#039;expandtext&amp;#039; ) || i18n.showText;&lt;br /&gt;
		var hideText = $collapsible.data( &amp;#039;collapsetext&amp;#039; ) || i18n.hideText;&lt;br /&gt;
		&lt;br /&gt;
		// If there is no content area, add it&lt;br /&gt;
		if ( !$collapsible.is( &amp;#039;table&amp;#039; ) &amp;amp;&amp;amp; !$children.filter( &amp;#039;.collapsible-content&amp;#039; ).length ) {&lt;br /&gt;
			if ( $collapsible.is( &amp;#039;tr.collapsible-rows&amp;#039; ) ) {&lt;br /&gt;
				var $collapsibleRows = $collapsible.nextUntil( &amp;#039;.collapsible-rows&amp;#039; );&lt;br /&gt;
				if ( $collapsibleRows.hasClass( &amp;#039;collapsible-row&amp;#039; ) ) {&lt;br /&gt;
					$collapsibleRows = $collapsibleRows.filter( &amp;#039;collapsible-row&amp;#039; );&lt;br /&gt;
				} else {&lt;br /&gt;
					$collapsibleRows.addClass( &amp;#039;collapsible-row&amp;#039; );&lt;br /&gt;
				}&lt;br /&gt;
				if ( $collapsible.hasClass( &amp;#039;collapsed&amp;#039; ) &amp;amp;&amp;amp; !$collapsibleRows.hasClass( &amp;#039;collapsed&amp;#039; ) ) {&lt;br /&gt;
					$collapsibleRows.addClass( &amp;#039;collapsed&amp;#039; );&lt;br /&gt;
				}&lt;br /&gt;
				$collapsible = $collapsible.add( $collapsibleRows );&lt;br /&gt;
			} else if ( $collapsible.is( &amp;#039;tr&amp;#039; ) ) {&lt;br /&gt;
				$children.addClass( &amp;#039;collapsible-content&amp;#039; );&lt;br /&gt;
			} else {&lt;br /&gt;
				$collapsible.wrapInner( &amp;#039;&amp;lt;div class=&amp;quot;collapsible-content&amp;quot;&amp;gt;&amp;#039; );&lt;br /&gt;
				$children = $collapsible.children();&lt;br /&gt;
			}&lt;br /&gt;
		}&lt;br /&gt;
		&lt;br /&gt;
		var $toggle;&lt;br /&gt;
		var id = $collapsible.attr( &amp;#039;id&amp;#039; );&lt;br /&gt;
		if ( id &amp;amp;&amp;amp; id.match( /^collapsible-./ ) ) {&lt;br /&gt;
			$toggle = $( $wikipageContent[0].getElementsByClassName( id + &amp;#039;-toggle&amp;#039; ) )&lt;br /&gt;
				.filter( &amp;#039;.collapsetoggle-custom&amp;#039; ).css( &amp;#039;visibility&amp;#039;, &amp;#039;visible&amp;#039; );&lt;br /&gt;
		}&lt;br /&gt;
		&lt;br /&gt;
		// Create and insert the toggle button if there is no custom one&lt;br /&gt;
		if ( !$toggle || !$toggle.length ) {&lt;br /&gt;
			var $toggleContainer;&lt;br /&gt;
			if ( $collapsible.is( &amp;#039;table&amp;#039; ) ) {&lt;br /&gt;
				var $rows = $children.filter( &amp;#039;thead&amp;#039; ).children();&lt;br /&gt;
				if ( !$rows.length ) {&lt;br /&gt;
					$rows = $children.filter( &amp;#039;tbody&amp;#039; ).first().children();&lt;br /&gt;
					if ( !$rows.length ) {&lt;br /&gt;
						$rows = $children.filter( &amp;#039;tr&amp;#039; );&lt;br /&gt;
					}&lt;br /&gt;
				}&lt;br /&gt;
				$toggleContainer = $rows.first().children().last();&lt;br /&gt;
			} else {&lt;br /&gt;
				$toggleContainer = $children.first();&lt;br /&gt;
				if ( $toggleContainer.hasClass( &amp;#039;collapsible-content&amp;#039; ) ) {&lt;br /&gt;
					$toggleContainer = $collapsible;&lt;br /&gt;
				}&lt;br /&gt;
			}&lt;br /&gt;
			&lt;br /&gt;
			$toggle = $toggleTemplate.clone();&lt;br /&gt;
			if (&lt;br /&gt;
				$toggleContainer !== $collapsible &amp;amp;&amp;amp; (&lt;br /&gt;
				$collapsible.hasClass( &amp;#039;collapsetoggle-inline&amp;#039; ) ||&lt;br /&gt;
				$collapsible.hasClass( &amp;#039;collapse-button-none&amp;#039; )&lt;br /&gt;
			) ) {&lt;br /&gt;
				$toggleContainer.append( $toggle );&lt;br /&gt;
			} else {&lt;br /&gt;
				$toggleContainer.prepend( $toggle );&lt;br /&gt;
			}&lt;br /&gt;
		}&lt;br /&gt;
		&lt;br /&gt;
		var $toggleLink = $toggle.find( &amp;#039;.jslink&amp;#039; );&lt;br /&gt;
		if ( !$toggleLink.length ) {&lt;br /&gt;
			$toggleLink = $toggle;&lt;br /&gt;
		}&lt;br /&gt;
		$toggleLink.attr( &amp;#039;tabindex&amp;#039;, 0 ).text( hideText );&lt;br /&gt;
		&lt;br /&gt;
		// Find max toggle size, and set its min-width to it&lt;br /&gt;
		var hideWidth = $toggle.width();&lt;br /&gt;
		$toggleLink.text( showText );&lt;br /&gt;
		var showWidth = $toggle.width();&lt;br /&gt;
		if ( hideWidth !== showWidth ) {&lt;br /&gt;
			$toggle.css( &amp;#039;min-width&amp;#039;, hideWidth &amp;gt; showWidth ? hideWidth : showWidth );&lt;br /&gt;
		}&lt;br /&gt;
		&lt;br /&gt;
		// Set the text back to hide if it&amp;#039;s not collapsed to begin with&lt;br /&gt;
		if ( !$collapsible.first().hasClass( &amp;#039;collapsed&amp;#039; ) ) {&lt;br /&gt;
			$toggleLink.text( hideText );&lt;br /&gt;
		}&lt;br /&gt;
		&lt;br /&gt;
		$toggleLink.on( &amp;#039;click keydown&amp;#039;, function( e ) {&lt;br /&gt;
			// Only trigger on enter press&lt;br /&gt;
			if ( e.keyCode &amp;amp;&amp;amp; e.keyCode !== 13 ) {&lt;br /&gt;
				return;&lt;br /&gt;
			}&lt;br /&gt;
			&lt;br /&gt;
			// Don&amp;#039;t toggle when clicking buttons or links inside the toggle&lt;br /&gt;
			var $target = $( e.target );&lt;br /&gt;
			if ( $target.is( &amp;#039;button&amp;#039; ) || $target.is( &amp;#039;a&amp;#039; ) ) {&lt;br /&gt;
				return;&lt;br /&gt;
			}&lt;br /&gt;
			&lt;br /&gt;
			$collapsible.toggleClass( &amp;#039;collapsed&amp;#039; );&lt;br /&gt;
			if ( $collapsible.first().hasClass( &amp;#039;collapsed&amp;#039; ) ) {&lt;br /&gt;
				$toggleLink.text( showText );&lt;br /&gt;
			} else {&lt;br /&gt;
				$toggleLink.text( hideText );&lt;br /&gt;
			}&lt;br /&gt;
			&lt;br /&gt;
			// Stop table sorting activating when clicking the link&lt;br /&gt;
			e.stopPropagation();&lt;br /&gt;
		} );&lt;br /&gt;
		&lt;br /&gt;
		$collapsible.data( &amp;#039;made-collapsible&amp;#039;, true );&lt;br /&gt;
	} );&lt;br /&gt;
}() );&lt;br /&gt;
&lt;br /&gt;
/**&lt;br /&gt;
 * Page loader&lt;br /&gt;
 *&lt;br /&gt;
 * Allows a page to be downloaded and displayed on demand.&lt;br /&gt;
 * Use with [[Template:LoadPage]] and [[Template:LoadBox]]&lt;br /&gt;
 */&lt;br /&gt;
( function() {&lt;br /&gt;
	var $loadPage = $wikipageContent.find( &amp;#039;.load-page&amp;#039; );&lt;br /&gt;
	if ( !$loadPage.length ) {&lt;br /&gt;
		return;&lt;br /&gt;
	}&lt;br /&gt;
	&lt;br /&gt;
	// We need the spinner to show loading is happening, but we don&amp;#039;t want&lt;br /&gt;
	// to have a delay while the module downloads, so we&amp;#039;ll load this now,&lt;br /&gt;
	// regardless of if something is clicked&lt;br /&gt;
	mw.loader.load( &amp;#039;jquery.spinner&amp;#039; );&lt;br /&gt;
	&lt;br /&gt;
	// Create button starting with hide text&lt;br /&gt;
	// Will be changed to the show text while calculating the maximum button size&lt;br /&gt;
	var $buttonTemplate = $( &amp;#039;&amp;lt;span&amp;gt;&amp;#039; ).addClass( &amp;#039;mw-editsection-like load-page-button&amp;#039; )&lt;br /&gt;
		.append( &amp;#039;[&amp;#039;, $( &amp;#039;&amp;lt;span&amp;gt;&amp;#039; ).addClass( &amp;#039;jslink&amp;#039; ).text( i18n.hideText ), &amp;#039;]&amp;#039; );&lt;br /&gt;
	&lt;br /&gt;
	var extractList = function( $contentContainer, listClass ) {&lt;br /&gt;
		var $content = $contentContainer.find( &amp;#039;.mw-parser-output &amp;gt; ul &amp;gt; li &amp;gt; ul&amp;#039; ).children();&lt;br /&gt;
		if ( listClass ) {&lt;br /&gt;
			$content.addClass( listClass );&lt;br /&gt;
		}&lt;br /&gt;
		&lt;br /&gt;
		return $content;&lt;br /&gt;
	};&lt;br /&gt;
	&lt;br /&gt;
	$loadPage.each( function() {&lt;br /&gt;
		var $body = $( this );&lt;br /&gt;
		var page = $body.data( &amp;#039;page&amp;#039; );&lt;br /&gt;
		if ( !page ) {&lt;br /&gt;
			return;&lt;br /&gt;
		}&lt;br /&gt;
		&lt;br /&gt;
		var template = $body.data( &amp;#039;template&amp;#039; );&lt;br /&gt;
		var treeview = $body.data( &amp;#039;treeview&amp;#039; );&lt;br /&gt;
		var treeviewClass = $body.data( &amp;#039;treeviewclass&amp;#039; );&lt;br /&gt;
		var $heading;&lt;br /&gt;
		var $contentContainer;&lt;br /&gt;
		var $content;&lt;br /&gt;
		var $button = $buttonTemplate.clone();&lt;br /&gt;
		var $buttonLink = $button.find( &amp;#039;.jslink&amp;#039; );&lt;br /&gt;
		if ( treeview ) {&lt;br /&gt;
			$heading = $body;&lt;br /&gt;
			$contentContainer = $( &amp;#039;&amp;lt;div&amp;gt;&amp;#039; );&lt;br /&gt;
		} else {&lt;br /&gt;
			$heading = $body.children().first();&lt;br /&gt;
			$contentContainer = $body.find( &amp;#039;.load-page-content&amp;#039; );&lt;br /&gt;
		}&lt;br /&gt;
		&lt;br /&gt;
		// Add the button&lt;br /&gt;
		$heading.append( $button );&lt;br /&gt;
		&lt;br /&gt;
		// Move the edit button to the right spot&lt;br /&gt;
		$contentContainer.find( &amp;#039;.mw-editsection, .mw-editsection-like&amp;#039; ).insertAfter( $button );&lt;br /&gt;
		&lt;br /&gt;
		// Find max button width, and set its min-width to it&lt;br /&gt;
		var hideWidth = $button.width();&lt;br /&gt;
		$buttonLink.text( i18n.showText );&lt;br /&gt;
		var showWidth = $button.width();&lt;br /&gt;
		&lt;br /&gt;
		if ( hideWidth !== showWidth ) {&lt;br /&gt;
			$button.css( &amp;#039;min-width&amp;#039;, hideWidth &amp;gt; showWidth ? hideWidth : showWidth );&lt;br /&gt;
		}&lt;br /&gt;
		&lt;br /&gt;
		$buttonLink.click( function() {&lt;br /&gt;
			if ( $body.hasClass( &amp;#039;pageloader-contentloaded&amp;#039; ) ) {&lt;br /&gt;
				if ( $buttonLink.text() === i18n.showText ) {&lt;br /&gt;
					if ( treeview ) {&lt;br /&gt;
						$content.insertAfter( $body );&lt;br /&gt;
					} else {&lt;br /&gt;
						$contentContainer.show();&lt;br /&gt;
					}&lt;br /&gt;
					$buttonLink.text( i18n.hideText );&lt;br /&gt;
				} else {&lt;br /&gt;
					if ( treeview ) {&lt;br /&gt;
						$content.children(&amp;quot;.load-page-button&amp;quot;).children(&amp;quot;.jslink&amp;quot;).each(function() {&lt;br /&gt;
							if ($(this).text() === i18n.hideText) this.click();&lt;br /&gt;
						});&lt;br /&gt;
						$content.detach();&lt;br /&gt;
					} else {&lt;br /&gt;
						$contentContainer.hide();&lt;br /&gt;
					}&lt;br /&gt;
					$buttonLink.text( i18n.showText );&lt;br /&gt;
				}&lt;br /&gt;
				return;&lt;br /&gt;
			}&lt;br /&gt;
			&lt;br /&gt;
			// See if this was loaded elsewhere before making a request&lt;br /&gt;
			var gotContent;&lt;br /&gt;
			$( &amp;#039;.pageloader-contentloaded&amp;#039; ).each( function() {&lt;br /&gt;
				var $fLoader = $( this );&lt;br /&gt;
				if ( $fLoader.data( &amp;#039;page&amp;#039; ) === page &amp;amp;&amp;amp; $fLoader.data( &amp;#039;mw-pageloader-content&amp;#039; ) ) {&lt;br /&gt;
					$contentContainer.html( $fLoader.data( &amp;#039;mw-pageloader-content&amp;#039; ) ).removeClass( &amp;#039;noscript&amp;#039; );&lt;br /&gt;
					mw.hook( &amp;#039;wikipage.content&amp;#039; ).fire( $contentContainer );&lt;br /&gt;
					&lt;br /&gt;
					if ( treeview ) {&lt;br /&gt;
						$body.find( &amp;#039;.noscript&amp;#039; ).remove();&lt;br /&gt;
						$content = extractList( $contentContainer, treeviewClass );&lt;br /&gt;
						$content.insertAfter( $body );&lt;br /&gt;
					}&lt;br /&gt;
					&lt;br /&gt;
					$buttonLink.text( i18n.hideText );&lt;br /&gt;
					$body.addClass( &amp;#039;pageloader-contentloaded&amp;#039; );&lt;br /&gt;
					gotContent = true;&lt;br /&gt;
					return false;&lt;br /&gt;
				}&lt;br /&gt;
			} );&lt;br /&gt;
			if ( gotContent ) {&lt;br /&gt;
				return;&lt;br /&gt;
			}&lt;br /&gt;
			&lt;br /&gt;
			// Just in-case the spinner module is still not ready yet&lt;br /&gt;
			var $spinner = $();&lt;br /&gt;
			mw.loader.using( &amp;#039;jquery.spinner&amp;#039;, function() {&lt;br /&gt;
				// $spinner will be false if the content somehow loaded before the module did&lt;br /&gt;
				if ( $spinner ) {&lt;br /&gt;
					$spinner = $.createSpinner().addClass( &amp;#039;mw-editsection-like&amp;#039; )&lt;br /&gt;
						.css( &amp;#039;min-width&amp;#039;, $button.css( &amp;#039;min-width&amp;#039; ) );&lt;br /&gt;
					$button.hide().after( $spinner );&lt;br /&gt;
				}&lt;br /&gt;
			} );&lt;br /&gt;
			&lt;br /&gt;
			var requestData = {&lt;br /&gt;
				action: &amp;#039;parse&amp;#039;,&lt;br /&gt;
				prop: &amp;#039;text|modules|jsconfigvars&amp;#039;,&lt;br /&gt;
				redirects: true&lt;br /&gt;
			};&lt;br /&gt;
			if ( template ) {&lt;br /&gt;
				requestData.page = page;&lt;br /&gt;
			} else {&lt;br /&gt;
				requestData.title = mw.config.get( &amp;#039;wgPageName&amp;#039; );&lt;br /&gt;
				requestData.text = &amp;#039;{&amp;#039; + &amp;#039;{:&amp;#039; + page + &amp;#039;}}&amp;#039;;&lt;br /&gt;
			}&lt;br /&gt;
			new mw.Api().get( requestData ).done( function( data ) {&lt;br /&gt;
				// Add config and modules&lt;br /&gt;
				if ( data.parse.jsconfigvars ) {&lt;br /&gt;
					mw.config.set( data.parse.jsconfigvars );&lt;br /&gt;
				}&lt;br /&gt;
				if ( data.parse.modules ) {&lt;br /&gt;
					mw.loader.load( data.parse.modules.concat(&lt;br /&gt;
						data.parse.modulescripts,&lt;br /&gt;
						data.parse.modulestyles&lt;br /&gt;
					) );&lt;br /&gt;
				}&lt;br /&gt;
				&lt;br /&gt;
				var html = data.parse.text[&amp;#039;*&amp;#039;];&lt;br /&gt;
				$contentContainer.html( html ).removeClass( &amp;#039;noscript&amp;#039; );&lt;br /&gt;
				&lt;br /&gt;
				// Resolve self-links&lt;br /&gt;
				if ( template ) {&lt;br /&gt;
					var curPage = &amp;#039;/&amp;#039; + mw.config.get( &amp;#039;wgPageName&amp;#039; );&lt;br /&gt;
					$contentContainer.find( &amp;#039;a&amp;#039; ).each( function() {&lt;br /&gt;
						var $link = $( this );&lt;br /&gt;
						if ( $link.attr( &amp;#039;href&amp;#039; ) === curPage ) {&lt;br /&gt;
							$link.replaceWith( $( &amp;#039;&amp;lt;strong&amp;gt;&amp;#039; ).addClass( &amp;#039;selflink&amp;#039; ).append( $link.contents() ) );&lt;br /&gt;
						}&lt;br /&gt;
					} );&lt;br /&gt;
					html = $contentContainer.html();&lt;br /&gt;
				}&lt;br /&gt;
				&lt;br /&gt;
				$body.data( &amp;#039;mw-pageloader-content&amp;#039;, html );&lt;br /&gt;
				&lt;br /&gt;
				// Fire content hook on the new content, running all this stuff again and more :)&lt;br /&gt;
				mw.hook( &amp;#039;wikipage.content&amp;#039; ).fire( $contentContainer );&lt;br /&gt;
				&lt;br /&gt;
				if ( treeview ) {&lt;br /&gt;
					$body.find( &amp;#039;.noscript&amp;#039; ).remove();&lt;br /&gt;
					$content = extractList( $contentContainer, treeviewClass );&lt;br /&gt;
					$content.insertAfter( $body );&lt;br /&gt;
				}&lt;br /&gt;
				&lt;br /&gt;
				$spinner.remove();&lt;br /&gt;
				$spinner = false;&lt;br /&gt;
				$buttonLink.text( i18n.hideText );&lt;br /&gt;
				$button.show();&lt;br /&gt;
				$body.addClass( &amp;#039;pageloader-contentloaded&amp;#039; );&lt;br /&gt;
			} ).fail( function( _, error ) {&lt;br /&gt;
				$spinner.remove();&lt;br /&gt;
				$spinner = false;&lt;br /&gt;
				$button.show();&lt;br /&gt;
				&lt;br /&gt;
				var errorText = &amp;#039;&amp;#039;;&lt;br /&gt;
				if ( error.textStatus ) {&lt;br /&gt;
					errorText = error.textStatus;&lt;br /&gt;
				} else if ( error.error ) {&lt;br /&gt;
					errorText = error.error.info;&lt;br /&gt;
				}&lt;br /&gt;
				&lt;br /&gt;
				mw.notify( errorText, { title: i18n.loadErrorTitle, autoHide: false } );&lt;br /&gt;
			} );&lt;br /&gt;
		} );&lt;br /&gt;
	} );&lt;br /&gt;
}() );&lt;br /&gt;
&lt;br /&gt;
/**&lt;br /&gt;
 * Set minimum height for animations to prevent moving the page if the frames&lt;br /&gt;
 * differ in height&lt;br /&gt;
 */&lt;br /&gt;
( function() {&lt;br /&gt;
	// Set frames to be visible for measuring height&lt;br /&gt;
	var $animated = $wikipageContent.find( &amp;#039;.animated&amp;#039; ).addClass( &amp;#039;animated-visible&amp;#039; );&lt;br /&gt;
	&lt;br /&gt;
	// Group frames per animation&lt;br /&gt;
	var animateds = [];&lt;br /&gt;
	$animated.each( function() {&lt;br /&gt;
		animateds.push( {&lt;br /&gt;
			$: $( this ).find( &amp;#039;&amp;gt; .animated-subframe&amp;#039; ).addBack()&lt;br /&gt;
				.find( &amp;#039;&amp;gt; *:not(.animated-subframe)&amp;#039; ),&lt;br /&gt;
		} );&lt;br /&gt;
	} );&lt;br /&gt;
	&lt;br /&gt;
	// Get highest frame for each animation (if heights differ)&lt;br /&gt;
	$.each( animateds, function() {&lt;br /&gt;
		var minHeight = 0, differentHeights;&lt;br /&gt;
		this.$.each( function() {&lt;br /&gt;
			var height = this.offsetHeight;&lt;br /&gt;
			differentHeights = differentHeights || minHeight &amp;amp;&amp;amp; height !== minHeight;&lt;br /&gt;
			minHeight = Math.max( height, minHeight );&lt;br /&gt;
		} );&lt;br /&gt;
		&lt;br /&gt;
		if ( differentHeights ) {&lt;br /&gt;
			this.height = minHeight;&lt;br /&gt;
		}&lt;br /&gt;
	} );&lt;br /&gt;
	&lt;br /&gt;
	// Set animation to be at least as tall as the tallest frame,&lt;br /&gt;
	// and set the non-active frames to be hidden again&lt;br /&gt;
	$animated.each( function( i ) {&lt;br /&gt;
		$( this ).css( &amp;#039;min-height&amp;#039;, animateds[i].height );&lt;br /&gt;
	} ).removeClass( &amp;#039;animated-visible&amp;#039; );&lt;br /&gt;
	&lt;br /&gt;
	// Load all images in the animation as soon as the animated content becomes visible&lt;br /&gt;
	var animatedObserver = new IntersectionObserver( function( entries ) {&lt;br /&gt;
		entries.forEach( function( entry ) {&lt;br /&gt;
			if ( entry.isIntersecting &amp;amp;&amp;amp; !entry.target.classList.contains( &amp;#039;animated-lazyloaded&amp;#039; ) ) {&lt;br /&gt;
				$( entry.target ).find( &amp;#039;img&amp;#039; ).attr( &amp;#039;loading&amp;#039;, &amp;#039;eager&amp;#039; );&lt;br /&gt;
				entry.target.classList.add( &amp;#039;animated-lazyloaded&amp;#039; );&lt;br /&gt;
				animatedObserver.unobserve( entry.target );&lt;br /&gt;
			}&lt;br /&gt;
		} );&lt;br /&gt;
	} );&lt;br /&gt;
	&lt;br /&gt;
	// Observe every animation&lt;br /&gt;
	$animated.each( function() {&lt;br /&gt;
		animatedObserver.observe(this);&lt;br /&gt;
	} );&lt;br /&gt;
}() );&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
} );&lt;br /&gt;
/* End wiki content hook */&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
/* Fires when DOM is ready */&lt;br /&gt;
$( function() {&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
/**&lt;br /&gt;
 * Element animator&lt;br /&gt;
 *&lt;br /&gt;
 * Cycles through a set of elements (or &amp;quot;frames&amp;quot;) on a 2 second timer per frame&lt;br /&gt;
 * Add the &amp;quot;animated&amp;quot; class to the frame containing the elements to animate.&lt;br /&gt;
 * Optionally, add the &amp;quot;animated-active&amp;quot; class to the frame to display first.&lt;br /&gt;
 * Optionally, add the &amp;quot;animated-subframe&amp;quot; class to a frame, and the&lt;br /&gt;
 * &amp;quot;animated-active&amp;quot; class to a subframe within, in order to designate a set of&lt;br /&gt;
 * subframes which will only be cycled every time the parent frame is displayed.&lt;br /&gt;
 * Animations with the &amp;quot;animated-paused&amp;quot; class will be skipped each interval.&lt;br /&gt;
 *&lt;br /&gt;
 * Requires some styling from [[MediaWiki:Gadget-site-styles.css]].&lt;br /&gt;
 */&lt;br /&gt;
( function() {&lt;br /&gt;
	var $content = $( &amp;#039;#mw-content-text&amp;#039; );&lt;br /&gt;
	var advanceFrame = function( parentElem, parentSelector ) {&lt;br /&gt;
		var curFrame = parentElem.querySelector( parentSelector + &amp;#039; &amp;gt; .animated-active&amp;#039; );&lt;br /&gt;
		$( curFrame ).removeClass( &amp;#039;animated-active&amp;#039; );&lt;br /&gt;
		var $nextFrame = $( curFrame &amp;amp;&amp;amp; curFrame.nextElementSibling || parentElem.firstElementChild );&lt;br /&gt;
		return $nextFrame.addClass( &amp;#039;animated-active&amp;#039; );&lt;br /&gt;
	};&lt;br /&gt;
	&lt;br /&gt;
	// Set the name of the hidden property&lt;br /&gt;
	var hidden; &lt;br /&gt;
	if ( typeof document.hidden !== &amp;#039;undefined&amp;#039; ) {&lt;br /&gt;
		hidden = &amp;#039;hidden&amp;#039;;&lt;br /&gt;
	} else if ( typeof document.msHidden !== &amp;#039;undefined&amp;#039; ) {&lt;br /&gt;
		hidden = &amp;#039;msHidden&amp;#039;;&lt;br /&gt;
	} else if ( typeof document.webkitHidden !== &amp;#039;undefined&amp;#039; ) {&lt;br /&gt;
		hidden = &amp;#039;webkitHidden&amp;#039;;&lt;br /&gt;
	}&lt;br /&gt;
	&lt;br /&gt;
	setInterval( function() {&lt;br /&gt;
		if ( hidden &amp;amp;&amp;amp; document[hidden] ) {&lt;br /&gt;
			return;&lt;br /&gt;
		}&lt;br /&gt;
		$content.find( &amp;#039;.animated&amp;#039; ).each( function() {&lt;br /&gt;
			if ( $( this ).hasClass( &amp;#039;animated-paused&amp;#039; ) ) {&lt;br /&gt;
				return;&lt;br /&gt;
			}&lt;br /&gt;
			&lt;br /&gt;
			var $nextFrame = advanceFrame( this, &amp;#039;.animated&amp;#039; );&lt;br /&gt;
			if ( $nextFrame.hasClass( &amp;#039;animated-subframe&amp;#039; ) ) {&lt;br /&gt;
				advanceFrame( $nextFrame[0], &amp;#039;.animated-subframe&amp;#039; );&lt;br /&gt;
			}&lt;br /&gt;
		} );&lt;br /&gt;
	}, 2000 );&lt;br /&gt;
}() );&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
} );&lt;br /&gt;
/* End DOM ready */&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
}() );&lt;/div&gt;</summary>
		<author><name>M0dii</name></author>
	</entry>
</feed>