MediaWiki:Common.js: различия между версиями

Материал из FIJTeam Project Wiki
Перейти к навигации Перейти к поиску
мНет описания правки
Метка: отменено
мНет описания правки
 
(не показано 19 промежуточных версий этого же участника)
Строка 1: Строка 1:
/* Размещённый здесь код JavaScript будет загружаться пользователям при обращении к каждой странице */
/* Размещённый здесь код JavaScript будет загружаться пользователям при обращении к каждой странице */


// Добавляет кнопку для очистки кэша
// Yandex.RTB
if (!$('#ca-purge').length) {
window.yaContextCb = window.yaContextCb || [];
     $('#p-cactions').find('ul').append(
(function() {
        $('<li>').attr({'id': 'ca-purge', 'class': 'mw-list-item'}).append(
     var yaScript = document.createElement('script');
            $('<a>').attr({'href': mw.util.getUrl(null, { action: 'purge' }), 'title': 'Очистить серверный кэш страницы'}).append(
    yaScript.type = 'text/javascript';
                $('<span>').text('Очистить кэш')
    yaScript.async = true;
            )
    yaScript.src = 'https://yandex.ru/ads/system/context.js';
         )
    var s = document.getElementsByTagName('script')[0];
    );
    s.parentNode.insertBefore(yaScript, s);
}
})();
 
// Yandex.RTB на каждой странице
mw.loader.using('mediawiki.util').then(function() {
    mw.hook('wikipage.content').add(function ($content) {
        // Создайте HTML-элемент для виджета в начале страницы
         var widgetElement = document.createElement('div');
        widgetElement.innerHTML = '<div id="widget-container">{{#widget:YaWidget}}</div>';


// Меняем обычную ссылку очистки кэша на API-запрос, чтобы избежать окна подтверждения
        // Вставьте виджет в начало содержимого страницы
mw.loader.using('mediawiki.api').then(function() {
        $content.prepend(widgetElement);
    $('#ca-purge a').on('click', function(e) {
        e.preventDefault(); // Предотвращаем стандартное действие ссылки


        // Используйте API для повторного выполнения парсинга для верхнего виджета
         new mw.Api().post({
         new mw.Api().post({
             action: 'purge',
             action: 'parse',
             titles: mw.config.get('wgPageName')
             text: widgetElement.innerHTML,
         }).done(function() {
            contentmodel: 'wikitext'
             location.reload();
         }).done(function (data) {
         }).fail(function(xhr, status, error) {
             $('#widget-container').html(data.parse.text['*']);
             mw.notify('Purge failed: ' + (xhr.responseText || status || error), { type: 'error' });
         }).fail(function () {
             mw.notify('Не удалось загрузить виджет', { type: 'error' });
         });
         });
    });
});


/* Fired whenever wiki content is added. (#mw-content-text, live preview, load page, etc.) */
        // Создайте HTML-элемент для нового виджета внизу страницы
mw.hook('wikipage.content').add(function($wikipageContent) {
        var widgetDownElement = document.createElement('div');
    $(function() {
         widgetDownElement.innerHTML = '<div id="widget-container-down">{{#widget:YaWidgetDown}}</div>';
         $("footer#footer").append($("<span></span>")
 
            .attr({
        // Вставьте новый виджет в конец содержимого страницы
                "id": "scroll-top",
         $content.append(widgetDownElement);
                "title": "Наверх"
            })
         );


         $("#scroll-top").click(function(e) {
         // Используйте API для повторного выполнения парсинга для нижнего виджета
             $('body,html').animate({scrollTop: 0}, 300);
        new mw.Api().post({
            action: 'parse',
            text: widgetDownElement.innerHTML,
            contentmodel: 'wikitext'
        }).done(function (data) {
             $('#widget-container-down').html(data.parse.text['*']);
        }).fail(function () {
            mw.notify('Не удалось загрузить нижний виджет', { type: 'error' });
         });
         });
    });


    /**
        // Вставка виджета в боковую панель
    * Page loader
        // Создаем HTML-элемент для виджета в боковой панели
    *
         var sidebarAd = document.createElement('div');
    * Allows a page to be downloaded and displayed on demand.
         sidebarAd.innerHTML = '<div id="sidebar-ad-container">{{#widget:YaWidgetSidebar}}</div>';
    * Use with Template:LoadPage and Template:LoadBox
    */
    (function() {
         var $loadPage = $wikipageContent.find('.load-page');
         if (!$loadPage.length) {
            return;
        }


         // We need the spinner to show loading is happening, but we don't want
         // Найдите элемент боковой панели, в который вы хотите вставить виджет
         // to have a delay while the module downloads, so we'll load this now,
         var sidebar = document.getElementById('p-SS13-LumiAurora');
         // regardless of if something is clicked
         if (sidebar) {
        mw.loader.load('jquery.spinner');
            sidebar.appendChild(sidebarAd);


        // Create button starting with hide text
            // Используйте API для повторного выполнения парсинга
        // Will be changed to the show text while calculating the maximum button size
            new mw.Api().post({
        var $buttonTemplate = $('<span>').addClass('mw-editsection-like load-page-button')
                action: 'parse',
            .append('[ ', $('<span>').addClass('jslink').text(i18n.hideText), ' ]');
                text: sidebarAd.innerHTML,
                contentmodel: 'wikitext'
            }).done(function(data) {
                $('#sidebar-ad-container').html(data.parse.text['*']);
            }).fail(function() {
                mw.notify('Не удалось загрузить виджет в боковую панель', { type: 'error' });
            });
        }
    });
});


        var extractList = function($contentContainer, listClass) {
// Добавляет кнопку для очистки кэша
            var $content = $contentContainer.find('.mw-parser-output > ul > li > ul').children(':not(.nbttree-inherited)');
if ( !$( '#ca-purge' ).length ) {
             if (listClass) {
    $( '#p-cactions' ).find( 'ul' ).append(
                $content.addClass(listClass);
        $( '<li>' ).attr( { 'id': 'ca-purge', 'class': 'mw-list-item' } ).append(
             }
            $( '<a>' ).attr( { 'href': mw.util.getUrl( null, { action: 'purge' } ), 'title': 'Очистить серверный кэш страницы' } ).append(
                $( '<span>' ).text( 'Очистить кэш' )
            )
        )
    );
}
// Меняем обычную ссылку очистки кэша на API-запрос, чтобы избежать окна подтверждения
mw.loader.using( 'mediawiki.api' ).then( function() {
    $( '#ca-purge a' ).on( 'click', function( e ) {
        new mw.Api().post( {
            action: 'purge',
             titles: mw.config.get( 'wgPageName' )
        } ).then( function() {
            location.reload();
        }, function() {
             mw.notify( 'Purge failed', { type: 'error' } );
        } );
       
        e.preventDefault();
    } );
} );


            return $content;
/* Fired whenever wiki content is added. (#mw-content-text, live preview, load page, etc.) */
        };
mw.hook( 'wikipage.content' ).add( function( $wikipageContent ) {


        $loadPage.each(function() {
$(function(){
            var $body = $(this);
$("footer#footer").append($("<span></span>")
            var page = $body.data('page');
.attr({
            if (!page) {
"id": "scroll-top",
                return;
"title": "Наверх"
            }
})
 
);
            var template = $body.data('template');
$("#scroll-top").click(function(e) {
            var treeview = $body.data('treeview');
$('body,html').animate({scrollTop:0},300);
            var treeviewClass = $body.data('treeviewclass');
});
            var $heading;
scrollTop();
            var $contentContainer;
});
            var $content;
            var $button = $buttonTemplate.clone();
            var $buttonLink = $button.find('.jslink');
            if (treeview) {
                $heading = $body;
                $contentContainer = $('<div>');
            } else {
                $heading = $body.children().first();
                $contentContainer = $body.find('.load-page-content');
            }
 
            // Add the button
            $heading.append($button);
 
            // Move the edit button to the right spot
            $contentContainer.find('.mw-editsection, .mw-editsection-like').insertAfter($button);
 
            // Find max button width, and set its min-width to it
            var hideWidth = $button.width();
            $buttonLink.text(i18n.showText);
            var showWidth = $button.width();
 
            if (hideWidth !== showWidth) {
                $button.css('min-width', hideWidth > showWidth ? hideWidth : showWidth);
            }
 
            $buttonLink.click(function() {
                if ($body.hasClass('pageloader-contentloaded')) {
                    if ($buttonLink.text() === i18n.showText) {
                        if (treeview) {
                            $content.insertAfter($body);
                        } else {
                            $contentContainer.show();
                        }
                        $buttonLink.text(i18n.hideText);
                    } else {
                        if (treeview) {
                            $content.detach();
                        } else {
                            $contentContainer.hide();
                        }
                        $buttonLink.text(i18n.showText);
                    }
                    return;
                }
 
                // See if this was loaded elsewhere before making a request
                var gotContent;
                $('.pageloader-contentloaded').each(function() {
                    var $fLoader = $(this);
                    if ($fLoader.data('page') === page && $fLoader.data('pageloader-content')) {
                        $contentContainer.html($fLoader.data('pageloader-content')).removeClass('noscript');
                        mw.hook('wikipage.content').fire($contentContainer);
 
                        if (treeview) {
                            $body.find('.noscript').remove();
                            $content = extractList($contentContainer, treeviewClass);
                            $content.insertAfter($body);
                        }
 
                        $buttonLink.text(i18n.hideText);
                        $body.addClass('pageloader-contentloaded');
                        gotContent = true;
                        return false;
                    }
                });
                if (gotContent) {
                    return;
                }
 
                // Just in-case the spinner module is still not ready yet
                var $spinner = $();
                mw.loader.using('jquery.spinner', function() {
                    // $spinner will be false if the content somehow loaded before the module did
                    if ($spinner) {
                        $spinner = $.createSpinner().addClass('mw-editsection-like')
                            .css('min-width', $button.css('min-width'));
                        $button.hide().after($spinner);
                    }
                });
 
                var requestData = {
                    action: 'parse',
                    prop: 'text'
                };
                if (template) {
                    requestData.page = page;
                } else {
                    requestData.title = mw.config.get('wgPageName');
                    requestData.text = '{{:' + page + '}}';
                }
                new mw.Api().get(requestData).done(function(data) {
                    var html = data.parse.text['*'];
                    $contentContainer.html(html).removeClass('noscript');
 
                    // Resolve self-links
                    if (template) {
                        var curPage = '/' + mw.config.get('wgPageName');
                        $contentContainer.find('a').each(function() {
                            var $link = $(this);
                            if ($link.attr('href') === curPage) {
                                $link.replaceWith($('<strong>').addClass('selflink').append($link.contents()));
                            }
                        });
                        html = $contentContainer.html();
                    }
 
                    $body.data('pageloader-content', html);
 
                    // Fire content hook on the new content, running all this stuff again and more :)
                    mw.hook('wikipage.content').fire($contentContainer);
 
                    if (treeview) {
                        $body.find('.noscript').remove();
                        $content = extractList($contentContainer, treeviewClass);
                        $content.insertAfter($body);
                    }


                    $spinner.remove();
/**
                    $spinner = false;
* Page loader
                    $buttonLink.text(i18n.hideText);
*
                    $button.show();
* Allows a page to be downloaded and displayed on demand.
                    $body.addClass('pageloader-contentloaded');
* Use with Template:LoadPage and Template:LoadBox
                }).fail(function(_, error) {
*/
                    $spinner.remove();
                    $spinner = false;
                    $button.show();


                    var errorText = '';
( function() {
                    if (error.textStatus) {
var $loadPage = $wikipageContent.find( '.load-page' );
                        errorText = error.textStatus;
if ( !$loadPage.length ) {
                    } else if (error.error) {
return;
                        errorText = error.error.info;
}
                    }
// We need the spinner to show loading is happening, but we don't want
// to have a delay while the module downloads, so we'll load this now,
// regardless of if something is clicked
mw.loader.load( 'jquery.spinner' );
// Create button starting with hide text
// Will be changed to the show text while calculating the maximum button size
var $buttonTemplate = $( '<span>' ).addClass( 'mw-editsection-like load-page-button' )
.append( '[ ', $( '<span>' ).addClass( 'jslink' ).text( i18n.hideText ), ' ]' );
var extractList = function( $contentContainer, listClass ) {
var $content = $contentContainer.find( '.mw-parser-output > ul > li > ul' ).children( ':not(.nbttree-inherited)' );
if ( listClass ) {
$content.addClass( listClass );
}
return $content;
};
$loadPage.each( function() {
var $body = $( this );
var page = $body.data( 'page' );
if ( !page ) {
return;
}
var template = $body.data( 'template' );
var treeview = $body.data( 'treeview' );
var treeviewClass = $body.data( 'treeviewclass' );
var $heading;
var $contentContainer;
var $content;
var $button = $buttonTemplate.clone();
var $buttonLink = $button.find( '.jslink' );
if ( treeview ) {
$heading = $body;
$contentContainer = $( '<div>' );
} else {
$heading = $body.children().first();
$contentContainer = $body.find( '.load-page-content' );
}
// Add the button
$heading.append( $button );
// Move the edit button to the right spot
$contentContainer.find( '.mw-editsection, .mw-editsection-like' ).insertAfter( $button );
// Find max button width, and set its min-width to it
var hideWidth = $button.width();
$buttonLink.text( i18n.showText );
var showWidth = $button.width();
if ( hideWidth !== showWidth ) {
$button.css( 'min-width', hideWidth > showWidth ? hideWidth : showWidth );
}
$buttonLink.click( function() {
if ( $body.hasClass( 'pageloader-contentloaded' ) ) {
if ( $buttonLink.text() === i18n.showText ) {
if ( treeview ) {
$content.insertAfter( $body );
} else {
$contentContainer.show();
}
$buttonLink.text( i18n.hideText );
} else {
if ( treeview ) {
$content.detach();
} else {
$contentContainer.hide();
}
$buttonLink.text( i18n.showText );
}
return;
}
// See if this was loaded elsewhere before making a request
var gotContent;
$( '.pageloader-contentloaded' ).each( function() {
var $fLoader = $( this );
if ( $fLoader.data( 'page' ) === page && $fLoader.data( 'pageloader-content' ) ) {
$contentContainer.html( $fLoader.data( 'pageloader-content' ) ).removeClass( 'noscript' );
mw.hook( 'wikipage.content' ).fire( $contentContainer );
if ( treeview ) {
$body.find( '.noscript' ).remove();
$content = extractList( $contentContainer, treeviewClass );
$content.insertAfter( $body );
}
$buttonLink.text( i18n.hideText );
$body.addClass( 'pageloader-contentloaded' );
gotContent = true;
return false;
}
} );
if ( gotContent ) {
return;
}
// Just in-case the spinner module is still not ready yet
var $spinner = $();
mw.loader.using( 'jquery.spinner', function() {
// $spinner will be false if the content somehow loaded before the module did
if ( $spinner ) {
$spinner = $.createSpinner().addClass( 'mw-editsection-like' )
.css( 'min-width', $button.css( 'min-width' ) );
$button.hide().after( $spinner );
}
} );
var requestData = {
action: 'parse',
prop: 'text'
};
if ( template ) {
requestData.page = page;
} else {
requestData.title = mw.config.get( 'wgPageName' );
requestData.text = '{' + '{:' + page + '}}';
}
new mw.Api().get( requestData ).done( function( data ) {
var html = data.parse.text['*'];
$contentContainer.html( html ).removeClass( 'noscript' );
// Resolve self-links
if ( template ) {
var curPage = '/' + mw.config.get( 'wgPageName' );
$contentContainer.find( 'a' ).each( function() {
var $link = $( this );
if ( $link.attr( 'href' ) === curPage ) {
$link.replaceWith( $( '<strong>' ).addClass( 'selflink' ).append( $link.contents() ) );
}
} );
html = $contentContainer.html();
}
$body.data( 'pageloader-content', html );
// Fire content hook on the new content, running all this stuff again and more :)
mw.hook( 'wikipage.content' ).fire( $contentContainer );
if ( treeview ) {
$body.find( '.noscript' ).remove();
$content = extractList( $contentContainer, treeviewClass );
$content.insertAfter( $body );
}
$spinner.remove();
$spinner = false;
$buttonLink.text( i18n.hideText );
$button.show();
$body.addClass( 'pageloader-contentloaded' );
} ).fail( function( _, error ) {
$spinner.remove();
$spinner = false;
$button.show();
var errorText = '';
if ( error.textStatus ) {
errorText = error.textStatus;
} else if ( error.error ) {
errorText = error.error.info;
}
mw.notify( errorText, { title: i18n.loadErrorTitle, autoHide: false } );
} );
} );
} );
}() );


                    mw.notify(errorText, { title: i18n.loadErrorTitle, autoHide: false });
} );
                });
/* Конец хука */
            });
        });
    }());
});

Текущая версия от 21:13, 22 июля 2024

/* Размещённый здесь код JavaScript будет загружаться пользователям при обращении к каждой странице */

// Yandex.RTB
window.yaContextCb = window.yaContextCb || [];
(function() {
    var yaScript = document.createElement('script');
    yaScript.type = 'text/javascript';
    yaScript.async = true;
    yaScript.src = 'https://yandex.ru/ads/system/context.js';
    var s = document.getElementsByTagName('script')[0];
    s.parentNode.insertBefore(yaScript, s);
})();

// Yandex.RTB на каждой странице
mw.loader.using('mediawiki.util').then(function() {
    mw.hook('wikipage.content').add(function ($content) {
        // Создайте HTML-элемент для виджета в начале страницы
        var widgetElement = document.createElement('div');
        widgetElement.innerHTML = '<div id="widget-container">{{#widget:YaWidget}}</div>';

        // Вставьте виджет в начало содержимого страницы
        $content.prepend(widgetElement);

        // Используйте API для повторного выполнения парсинга для верхнего виджета
        new mw.Api().post({
            action: 'parse',
            text: widgetElement.innerHTML,
            contentmodel: 'wikitext'
        }).done(function (data) {
            $('#widget-container').html(data.parse.text['*']);
        }).fail(function () {
            mw.notify('Не удалось загрузить виджет', { type: 'error' });
        });

        // Создайте HTML-элемент для нового виджета внизу страницы
        var widgetDownElement = document.createElement('div');
        widgetDownElement.innerHTML = '<div id="widget-container-down">{{#widget:YaWidgetDown}}</div>';

        // Вставьте новый виджет в конец содержимого страницы
        $content.append(widgetDownElement);

        // Используйте API для повторного выполнения парсинга для нижнего виджета
        new mw.Api().post({
            action: 'parse',
            text: widgetDownElement.innerHTML,
            contentmodel: 'wikitext'
        }).done(function (data) {
            $('#widget-container-down').html(data.parse.text['*']);
        }).fail(function () {
            mw.notify('Не удалось загрузить нижний виджет', { type: 'error' });
        });

        // Вставка виджета в боковую панель
        // Создаем HTML-элемент для виджета в боковой панели
        var sidebarAd = document.createElement('div');
        sidebarAd.innerHTML = '<div id="sidebar-ad-container">{{#widget:YaWidgetSidebar}}</div>';

        // Найдите элемент боковой панели, в который вы хотите вставить виджет
        var sidebar = document.getElementById('p-SS13-LumiAurora');
        if (sidebar) {
            sidebar.appendChild(sidebarAd);

            // Используйте API для повторного выполнения парсинга
            new mw.Api().post({
                action: 'parse',
                text: sidebarAd.innerHTML,
                contentmodel: 'wikitext'
            }).done(function(data) {
                $('#sidebar-ad-container').html(data.parse.text['*']);
            }).fail(function() {
                mw.notify('Не удалось загрузить виджет в боковую панель', { type: 'error' });
            });
        }
    });
});

// Добавляет кнопку для очистки кэша
if ( !$( '#ca-purge' ).length ) {
    $( '#p-cactions' ).find( 'ul' ).append(
        $( '<li>' ).attr( { 'id': 'ca-purge', 'class': 'mw-list-item' } ).append(
            $( '<a>' ).attr( { 'href': mw.util.getUrl( null, { action: 'purge' } ), 'title': 'Очистить серверный кэш страницы' } ).append(
                $( '<span>' ).text( 'Очистить кэш' )
            )
        )
    );
}
// Меняем обычную ссылку очистки кэша на API-запрос, чтобы избежать окна подтверждения
mw.loader.using( 'mediawiki.api' ).then( function() {
    $( '#ca-purge a' ).on( 'click', function( e ) {
        new mw.Api().post( {
            action: 'purge',
            titles: mw.config.get( 'wgPageName' )
        } ).then( function() {
            location.reload();
        }, function() {
            mw.notify( 'Purge failed', { type: 'error' } );
        } );
        
        e.preventDefault();
    } );
} );

/* Fired whenever wiki content is added. (#mw-content-text, live preview, load page, etc.) */
mw.hook( 'wikipage.content' ).add( function( $wikipageContent ) {

$(function(){
	$("footer#footer").append($("<span></span>")
		.attr({
			"id": "scroll-top",
			"title": "Наверх"
		})
	);
	$("#scroll-top").click(function(e) {
		$('body,html').animate({scrollTop:0},300);
		});
	scrollTop();
});

/**
 * Page loader
 *
 * Allows a page to be downloaded and displayed on demand.
 * Use with Template:LoadPage and Template:LoadBox
 */

( function() {
	var $loadPage = $wikipageContent.find( '.load-page' );
	if ( !$loadPage.length ) {
		return;
	}
	
	// We need the spinner to show loading is happening, but we don't want
	// to have a delay while the module downloads, so we'll load this now,
	// regardless of if something is clicked
	mw.loader.load( 'jquery.spinner' );
	
	// Create button starting with hide text
	// Will be changed to the show text while calculating the maximum button size
	var $buttonTemplate = $( '<span>' ).addClass( 'mw-editsection-like load-page-button' )
		.append( '[ ', $( '<span>' ).addClass( 'jslink' ).text( i18n.hideText ), ' ]' );
	
	var extractList = function( $contentContainer, listClass ) {
		var $content = $contentContainer.find( '.mw-parser-output > ul > li > ul' ).children( ':not(.nbttree-inherited)' );
		if ( listClass ) {
			$content.addClass( listClass );
		}
		
		return $content;
	};
	
	$loadPage.each( function() {
		var $body = $( this );
		var page = $body.data( 'page' );
		if ( !page ) {
			return;
		}
		
		var template = $body.data( 'template' );
		var treeview = $body.data( 'treeview' );
		var treeviewClass = $body.data( 'treeviewclass' );
		var $heading;
		var $contentContainer;
		var $content;
		var $button = $buttonTemplate.clone();
		var $buttonLink = $button.find( '.jslink' );
		if ( treeview ) {
			$heading = $body;
			$contentContainer = $( '<div>' );
		} else {
			$heading = $body.children().first();
			$contentContainer = $body.find( '.load-page-content' );
		}
		
		// Add the button
		$heading.append( $button );
		
		// Move the edit button to the right spot
		$contentContainer.find( '.mw-editsection, .mw-editsection-like' ).insertAfter( $button );
		
		// Find max button width, and set its min-width to it
		var hideWidth = $button.width();
		$buttonLink.text( i18n.showText );
		var showWidth = $button.width();
		
		if ( hideWidth !== showWidth ) {
			$button.css( 'min-width', hideWidth > showWidth ? hideWidth : showWidth );
		}
		
		$buttonLink.click( function() {
			if ( $body.hasClass( 'pageloader-contentloaded' ) ) {
				if ( $buttonLink.text() === i18n.showText ) {
					if ( treeview ) {
						$content.insertAfter( $body );
					} else {
						$contentContainer.show();
					}
					$buttonLink.text( i18n.hideText );
				} else {
					if ( treeview ) {
						$content.detach();
					} else {
						$contentContainer.hide();
					}
					$buttonLink.text( i18n.showText );
				}
				return;
			}
			
			// See if this was loaded elsewhere before making a request
			var gotContent;
			$( '.pageloader-contentloaded' ).each( function() {
				var $fLoader = $( this );
				if ( $fLoader.data( 'page' ) === page && $fLoader.data( 'pageloader-content' ) ) {
					$contentContainer.html( $fLoader.data( 'pageloader-content' ) ).removeClass( 'noscript' );
					mw.hook( 'wikipage.content' ).fire( $contentContainer );
					
					if ( treeview ) {
						$body.find( '.noscript' ).remove();
						$content = extractList( $contentContainer, treeviewClass );
						$content.insertAfter( $body );
					}
					
					$buttonLink.text( i18n.hideText );
					$body.addClass( 'pageloader-contentloaded' );
					gotContent = true;
					return false;
				}
			} );
			if ( gotContent ) {
				return;
			}
			
			// Just in-case the spinner module is still not ready yet
			var $spinner = $();
			mw.loader.using( 'jquery.spinner', function() {
				// $spinner will be false if the content somehow loaded before the module did
				if ( $spinner ) {
					$spinner = $.createSpinner().addClass( 'mw-editsection-like' )
						.css( 'min-width', $button.css( 'min-width' ) );
					$button.hide().after( $spinner );
				}
			} );
			
			var requestData = {
				action: 'parse',
				prop: 'text'
			};
			if ( template ) {
				requestData.page = page;
			} else {
				requestData.title = mw.config.get( 'wgPageName' );
				requestData.text = '{' + '{:' + page + '}}';
			}
			new mw.Api().get( requestData ).done( function( data ) {
				var html = data.parse.text['*'];
				$contentContainer.html( html ).removeClass( 'noscript' );
				
				// Resolve self-links
				if ( template ) {
					var curPage = '/' + mw.config.get( 'wgPageName' );
					$contentContainer.find( 'a' ).each( function() {
						var $link = $( this );
						if ( $link.attr( 'href' ) === curPage ) {
							$link.replaceWith( $( '<strong>' ).addClass( 'selflink' ).append( $link.contents() ) );
						}
					} );
					html = $contentContainer.html();
				}
				
				$body.data( 'pageloader-content', html );
				
				// Fire content hook on the new content, running all this stuff again and more :)
				mw.hook( 'wikipage.content' ).fire( $contentContainer );
				
				if ( treeview ) {
					$body.find( '.noscript' ).remove();
					$content = extractList( $contentContainer, treeviewClass );
					$content.insertAfter( $body );
				}
				
				$spinner.remove();
				$spinner = false;
				$buttonLink.text( i18n.hideText );
				$button.show();
				$body.addClass( 'pageloader-contentloaded' );
			} ).fail( function( _, error ) {
				$spinner.remove();
				$spinner = false;
				$button.show();
				
				var errorText = '';
				if ( error.textStatus ) {
					errorText = error.textStatus;
				} else if ( error.error ) {
					errorText = error.error.info;
				}
				
				mw.notify( errorText, { title: i18n.loadErrorTitle, autoHide: false } );
			} );
		} );
	} );
}() );

} );
/* Конец хука */