<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
	<id>http://wiki.ministation.ru//index.php?action=history&amp;feed=atom&amp;title=MediaWiki%3ACommon.js</id>
	<title>MediaWiki:Common.js - История изменений</title>
	<link rel="self" type="application/atom+xml" href="http://wiki.ministation.ru//index.php?action=history&amp;feed=atom&amp;title=MediaWiki%3ACommon.js"/>
	<link rel="alternate" type="text/html" href="http://wiki.ministation.ru//index.php?title=MediaWiki:Common.js&amp;action=history"/>
	<updated>2026-06-19T20:52:05Z</updated>
	<subtitle>История изменений этой страницы в вики</subtitle>
	<generator>MediaWiki 1.44.0</generator>
	<entry>
		<id>http://wiki.ministation.ru//index.php?title=MediaWiki:Common.js&amp;diff=37&amp;oldid=prev</id>
		<title>Als: Новая страница: «/* Variables for interface text used throughout the script, for ease of translating */ var i18n = {     // Collapsible elements and page loader     hideText: &#039;скрыть&#039;,     showText: &#039;показать&#039;,          // Page loader     loadErrorTitle: &#039;Возникла ошибка при загрузке содержимого&#039; };  /**  * Instead of cluttering up the global scope with  * variables, they should instead be set as a  * property of this global...»</title>
		<link rel="alternate" type="text/html" href="http://wiki.ministation.ru//index.php?title=MediaWiki:Common.js&amp;diff=37&amp;oldid=prev"/>
		<updated>2025-07-26T10:03:07Z</updated>

		<summary type="html">&lt;p&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;скрыть&amp;#039;,     showText: &amp;#039;показать&amp;#039;,          // Page loader     loadErrorTitle: &amp;#039;Возникла ошибка при загрузке содержимого&amp;#039; };  /**  * Instead of cluttering up the global scope with  * variables, they should instead be set as a  * property of this global...»&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&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;скрыть&amp;#039;,&lt;br /&gt;
    showText: &amp;#039;показать&amp;#039;,&lt;br /&gt;
    &lt;br /&gt;
    // Page loader&lt;br /&gt;
    loadErrorTitle: &amp;#039;Возникла ошибка при загрузке содержимого&amp;#039;&lt;br /&gt;
};&lt;br /&gt;
&lt;br /&gt;
/**&lt;br /&gt;
 * Instead of cluttering up the global scope with&lt;br /&gt;
 * variables, they should instead be set as a&lt;br /&gt;
 * property of this global variable&lt;br /&gt;
 *&lt;br /&gt;
 * E.g: Instead of&lt;br /&gt;
 *   myVar = &amp;#039;blah&amp;#039;;&lt;br /&gt;
 * use&lt;br /&gt;
 *   mcw.myVar = &amp;#039;blah&amp;#039;;&lt;br /&gt;
 */&lt;br /&gt;
var mcw = window.mcw = {};&lt;br /&gt;
&lt;br /&gt;
/* Keep track of delegated events on dynamic content */&lt;br /&gt;
mcw.events = {};&lt;br /&gt;
&lt;br /&gt;
$(function () {&lt;br /&gt;
&lt;br /&gt;
    const elemsSwitch = Array.from(document.querySelectorAll(&amp;quot;.kaskadavionics .switchtab&amp;quot;));&lt;br /&gt;
&lt;br /&gt;
    for (var ii = 0; ii &amp;lt; elemsSwitch.length; ii++) {&lt;br /&gt;
&lt;br /&gt;
        elemsSwitch[ii].onclick = function () {&lt;br /&gt;
&lt;br /&gt;
            const tabId = this.getAttribute(&amp;quot;data-tab&amp;quot;);&lt;br /&gt;
&lt;br /&gt;
            var elemens = Array.from(document.querySelectorAll(&amp;quot;.kaskadavionics .switchtab&amp;quot;));&lt;br /&gt;
&lt;br /&gt;
            for (var iii = 0; iii &amp;lt; elemens.length; iii++) {&lt;br /&gt;
&lt;br /&gt;
                elemens[iii].classList.remove(&amp;quot;current&amp;quot;);&lt;br /&gt;
&lt;br /&gt;
            }&lt;br /&gt;
            elemens = Array.from(document.querySelectorAll(&amp;quot;.kaskadavionics .tabcontent&amp;quot;));&lt;br /&gt;
            for (var jj = 0; jj &amp;lt; elemens.length; jj++) {&lt;br /&gt;
&lt;br /&gt;
                elemens[jj].classList.remove(&amp;quot;current&amp;quot;);&lt;br /&gt;
&lt;br /&gt;
            }&lt;br /&gt;
            this.classList.add(&amp;quot;current&amp;quot;);&lt;br /&gt;
            document.querySelector(&amp;quot;[data-tab=&amp;#039;&amp;quot;+tabId+&amp;quot;&amp;#039;]&amp;quot;).classList.add(&amp;quot;current&amp;quot;);&lt;br /&gt;
            document.querySelector(&amp;quot;#p&amp;quot;+tabId).classList.add(&amp;quot;current&amp;quot;);&lt;br /&gt;
&lt;br /&gt;
        };&lt;br /&gt;
&lt;br /&gt;
    }&lt;br /&gt;
&lt;br /&gt;
}());&lt;br /&gt;
&lt;br /&gt;
// Если кнопка «Ещё» у нас скрыта, отображаем её, но не на спецстраницах.&lt;br /&gt;
if ($( &amp;#039;#p-cactions&amp;#039; ).hasClass( &amp;#039;emptyPortlet&amp;#039; ) &amp;amp; !$( &amp;#039;#p-views&amp;#039; ).hasClass( &amp;#039;emptyPortlet&amp;#039; )){&lt;br /&gt;
	$( &amp;#039;#p-cactions&amp;#039; ).removeClass( &amp;#039;emptyPortlet&amp;#039; )&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
// from Minecraft Wiki&lt;br /&gt;
/* Добавляет кнопку «Вверх» слева */&lt;br /&gt;
function scrollTop(){&lt;br /&gt;
    $(window).scroll(function(e) {&lt;br /&gt;
	    if($(window).scrollTop()&amp;gt;0) {&lt;br /&gt;
	    	$(&amp;quot;#scroll-top&amp;quot;).fadeIn(300);&lt;br /&gt;
	    } else{ &lt;br /&gt;
	    	$(&amp;quot;#scroll-top&amp;quot;).fadeOut(300);&lt;br /&gt;
	    }&lt;br /&gt;
    });&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;
$(function(){&lt;br /&gt;
	$(&amp;quot;footer#footer&amp;quot;).append($(&amp;quot;&amp;lt;span&amp;gt;&amp;lt;/span&amp;gt;&amp;quot;)&lt;br /&gt;
		.attr({&lt;br /&gt;
			&amp;quot;id&amp;quot;: &amp;quot;scroll-top&amp;quot;,&lt;br /&gt;
			&amp;quot;title&amp;quot;: &amp;quot;Наверх&amp;quot;&lt;br /&gt;
		})&lt;br /&gt;
	);&lt;br /&gt;
	$(&amp;quot;#scroll-top&amp;quot;).click(function(e) {&lt;br /&gt;
		$(&amp;#039;body,html&amp;#039;).animate({scrollTop:0},300);&lt;br /&gt;
		});&lt;br /&gt;
	scrollTop();&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;
&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;load-page-button&amp;#039; )&lt;br /&gt;
		.append($( &amp;#039;&amp;lt;span&amp;gt;&amp;#039; ).addClass( &amp;#039;jslink&amp;#039; ).text( i18n.hideText ));&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( &amp;#039;:not(.nbttree-inherited)&amp;#039; );&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&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.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;pageloader-content&amp;#039; ) ) {&lt;br /&gt;
					$contentContainer.html( $fLoader.data( &amp;#039;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()&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&amp;#039;&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;
				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;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;
/* End wiki content hook */&lt;/div&gt;</summary>
		<author><name>Als</name></author>
	</entry>
</feed>