MediaWiki:Common.js: различия между версиями
Перейти к навигации
Перейти к поиску
Flaco (обсуждение | вклад) Нет описания правки |
Flaco (обсуждение | вклад) Нет описания правки Метка: отменено |
||
Строка 57: | Строка 57: | ||
// Найдите элемент боковой панели, в который вы хотите вставить виджет | // Найдите элемент боковой панели, в который вы хотите вставить виджет | ||
var sidebar = document. | var sidebar = document.querySelector('#p-sidebar-ad .body') || document.querySelector('#p-sidebar-ad'); | ||
if (sidebar) { | if (sidebar) { | ||
sidebar.appendChild(sidebarAd); | sidebar.appendChild(sidebarAd); |
Версия от 18:47, 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.querySelector('#p-sidebar-ad .body') || document.querySelector('#p-sidebar-ad');
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 } );
} );
} );
} );
}() );
} );
/* Конец хука */