MediaWiki:Common.js
Выгляд
Заўвага: каб пабачыць зьмены пасьля публікацыі, Вам можа спатрэбіцца ачысьціць кэш Вашага браўзэра.
- Firefox / Safari: трымайце Shift і націсьніце Reload, ці націсьніце Ctrl-F5 ці Ctrl-R (⌘-R на Mac)
- Google Chrome: націсьніце Ctrl-Shift-R (⌘-Shift-R на Mac)
- Edge: трымайце Ctrl і націсьніце Refresh, ці націсьніце Ctrl-F5.
/* Any JavaScript here will be loaded for all users on every page load. */
function closeRCBanner() {
$.cookie('hide_'+$('#rc-banner').data('id'), 'yes');
$('#rc-banner').hide();
}
mw.loader.using( ['mediawiki.user', 'mediawiki.util', 'jquery.client'] ).done( function () {
/* бягучая дата */
mw.messages.set({
'month-1-gen': 'студзеня',
'month-2-gen': 'лютага',
'month-3-gen': 'сакавіка',
'month-4-gen': 'красавіка',
'month-5-gen': 'траўня',
'month-6-gen': 'чэрвеня',
'month-7-gen': 'ліпеня',
'month-8-gen': 'жніўня',
'month-9-gen': 'верасьня',
'month-10-gen': 'кастрычніка',
'month-11-gen': 'лістапада',
'month-12-gen': 'сьнежня'
});
/**
* @deprecated: Выкарыстоўвайце $( selector )
*/
function returnObjById( id ) {
return $( '#' + id );
}
/**
* Выстаўленьне літараў Ё, І і Ў на слушныя месцы пры сартаваньні табліцаў.
* FIXME: ці трэба, каб у адваротным накірунку спачатку ішла Ў, потым У?
* Пры альфабэтным пераліку яны здаецца ж маюць аднолькавую вагу... (User:Wizardist)
*/
mw.config.set('tableSorterCollation', {'ё':'е}', 'і':'з}', 'ў':'у'});
/* Test if an element has a certain class **************************************
*
* Description: Uses regular expressions and caching for better performance.
* Maintainers: [[User:Wizardist]]
* @deprecated: Выкарыстоўвайце $( selector ).hasClass( className )
*/
window.hasClass = function ( element, className ) {
return $( element ).hasClass( className );
};
/** Для шаблёну Шаблён:Галерэя ***********************************************
*
*/
$(function() {
if (document.URL.match(/printable/g)) return;
function toggleImageFunction(group, remindex, shwindex) {
return function() {
document.getElementById("ImageGroupsGr" + group + "Im" + remindex).style["display"] = "none";
document.getElementById("ImageGroupsGr" + group + "Im" + shwindex).style["display"] = "block";
return false;
};
}
var divs = document.getElementsByTagName("div");
var i = 0, j = 0;
var units, search;
var currentimage;
var UnitNode;
for (i = 0; i < divs.length; i++) {
if (divs[i].className !== "ImageGroup") { continue; }
UnitNode = undefined;
search = divs[i].getElementsByTagName("div");
for (j = 0; j < search.length; j++) {
if (search[j].className !== "ImageGroupUnits") { continue; }
UnitNode=search[j];
break;
}
if (UnitNode === undefined) { continue; }
units = [];
for (j = 0 ; j < UnitNode.childNodes.length ; j++ ) {
var temp = UnitNode.childNodes[j];
if (['center', 'mw-halign-center'].some(function(className) { return temp.classList.contains(className); })) { units.push(temp); }
}
var rightlink = undefined;
var commentText = undefined;
var wrap;
for (j = 0; j < units.length; j++) {
currentimage = units[j];
wrap = document.createElement('div');
wrap.id = "ImageGroupsGr" + i + "Im" + j;
currentimage.parentNode.insertBefore(wrap, currentimage);
wrap.appendChild(currentimage);
var leftlink = document.createElement("a");
if (commentText !== undefined) {
leftlink.setAttribute("title", commentText);
}
var comment;
if (typeof(currentimage.getAttribute("title")) !== "string") {
commentText = (j+1) + "/" + units.length;
comment = document.createElement("tt").appendChild(document.createTextNode("("+ commentText + ")"));
}
else {
commentText = currentimage.getAttribute("title");
comment = document.createElement("span").appendChild(document.createTextNode(commentText));
currentimage.removeAttribute("title");
}
if(rightlink !== undefined) {
rightlink.setAttribute("title", commentText);
}
var imghead = document.createElement("div");
rightlink = document.createElement("a");
if (j != 0) {
leftlink.href = "#";
leftlink.onclick = toggleImageFunction(i, j, j-1);
leftlink.appendChild(document.createTextNode("◀"));
}
if (j != units.length - 1) {
rightlink.href = "#";
rightlink.onclick = toggleImageFunction(i, j, j+1);
rightlink.appendChild(document.createTextNode("▶"));
}
imghead.style["fontSize"] = "110%";
imghead.style["fontweight"] = "bold";
imghead.appendChild(leftlink);
imghead.appendChild(document.createTextNode("\xA0"));
imghead.appendChild(comment);
imghead.appendChild(document.createTextNode("\xA0"));
imghead.appendChild(rightlink);
if (units.length > 1) {
wrap.insertBefore(imghead,wrap.childNodes[0]);
}
if (j != 0) {
wrap.style["display"] = "none";
}
}
}
});
/**
* Код для карэктнага функцыяваньня [[Шаблён:Падказка]] у выпадку, калі зададзены трэці парамэтар.
*/
$('.changeLinkHover').each(function(){
$(this).find("a").attr('title',$(this).attr('title'))
});
/**
* Кантэйнэр кнопак гаджэтаў на панэлі рэдагаваньня
*/
$(function(){
if(mw.user.options.get('usebetatoolbar') && $.inArray( mw.config.get( 'wgAction' ), ['edit', 'submit'] ) !== -1) {
mw.loader.using(['ext.wikiEditor'], function(){
$( '#wpTextbox1' ).wikiEditor( 'addToToolbar', {
'section': 'main',
'groups': {
'gadgets': {
}
}
});
// ссоўваем групу 'gadgets' у пачатак
$('.group.group-gadgets').detach().prependTo($('.toolbar.section.section-main'));
// кажам асяродзьдзю, што група 'gadgets' падрыхтаваная
$( '#wpTextbox1' ).trigger( 'wikiEditor-toolbar-buildGroup-gadgets' );
}); // ResourceLoader 'using' wrapper
}
});
mw.loader.load( '/w/index.php?title=MediaWiki:EditSummaryHelpers.js&action=raw&ctype=text/javascript' );
mw.loader.load( '/w/index.php?title=MediaWiki:Common.js/coordinates.js&action=raw&ctype=text/javascript' );
mw.loader.load( '/w/index.php?title=MediaWiki:Common.js/potdViewer.js&action=raw&ctype=text/javascript' );
// прагляд Выяваў дня ў шаблёнах + апісаньні
/**
* Стварэньне банэру ў Апошніх зьменах
* 133024 — ідэнтыфікатар Шаблён:Апошнія_зьмены_банэр
* 143344 — ідэнтыфікатар User:Wizardist/RCtest
*/
if( ( mw.config.get('wgPageName') == 'Спэцыяльныя:Апошнія_зьмены' || $.inArray( mw.config.get( 'wgArticleId' ), [143344, 133024] ) ) && $('#rc-banner').length) {
if($.cookie('hide_'+$('#rc-banner').data('id'))) {
$('#rc-banner').hide();
} else {
$('#rc-banner').css('background', 'url('+$('#rc-banner').data('background').replace('%size%', $('#rc-banner').width()+'px')+') no-repeat center center'); // загрузка слушнага тла
if ( $( '#rc-banner' ).data( 'backgroundpos' ) ) {
$( '#rc-banner' ).css( 'background-position', $( '#rc-banner' ).data( 'backgroundpos' ) );
}
$('#rc-banner span').wrap('<a href="'+mw.util.getUrl($('#rc-banner').data('link'))+'" style="width:100%;height:100%;display:block;text-decoration:none;" />'); // стварэньне спасылкі
$('#rc-banner').prepend('<a href="javascript:void(0)" onclick="closeRCBanner();" style="position:absolute;float:right;right:5px;padding-top:5px;"><img src="//upload.wikimedia.org/wikipedia/commons/2/20/CloseWindow19x19.png"></a>');
}
}
/* Пераключэньне мапаў у картках */
$( '.localmap-switcher' ).click( function() {
var currentMap = $( ' ~ div.localmap-basket > div:not(:hidden)', $( this ).parent() );
var nextMap = $( ' + div.localmap-basket > div:hidden', $( this ).parent() );
var captionContainer = $( this ).prev()
$( currentMap ).hide();
$( nextMap ).show();
$( captionContainer ).text( $( nextMap ).data( 'caption' ) );
$( this ).attr( 'title', $( currentMap ).data( 'title' ) );
} );
// загрузка модуля для падтрымкі PLURAL і іншага ў JavaScript
$(function(){
mw.loader.using(['mediawiki.language']);
});
/**
* Выпраўленьні галоўнай старонкі
*
* Апісаньне: Дадае дадатковую спасылку «поўны сьпіс» у сьпісе інтэрвікі-спасылак на галоўнай старонцы
*/
if (mw.config.get( 'wgPageName' ) === 'Галоўная_старонка') {
$(document).ready(function () {
mw.util.addPortletLink( 'p-lang', '//meta.wikimedia.org/wiki/List_of_Wikipedias',
'поўны сьпіс', 'interwiki-completelist', 'Поўны сьпіс Вікіпэдыяў' );
$("#interwiki-completelist").addClass('interlanguage-link');
});
}
/**
* @source www.mediawiki.org/wiki/Snippets/Load_JS_and_CSS_by_URL
* @rev 6
*/
var extraCSS = mw.util.getParamValue( 'withCSS' ),
extraJS = mw.util.getParamValue( 'withJS' );
if ( extraCSS ) {
if ( extraCSS.match( /^MediaWiki:[^&<>=%#]*\.css$/ ) ) {
mw.loader.load( '/w/index.php?title=' + extraCSS + '&action=raw&ctype=text/css', 'text/css' );
} else {
mw.notify( 'Дазваляюцца толькі старонкі прасторы MediaWiki.', { title: 'Памылковае значэньне withCSS' } );
}
}
if ( extraJS ) {
if ( extraJS.match( /^MediaWiki:[^&<>=%#]*\.js$/ ) ) {
mw.loader.load( '/w/index.php?title=' + extraJS + '&action=raw&ctype=text/javascript' );
} else {
mw.notify( 'Дазваляюцца толькі старонкі прасторы MediaWiki.', { title: 'Памылковае значэньне withJS' } );
}
}
/**
* Collapsible tables; reimplemented with mw-collapsible
* Styling is also in place to avoid FOUC
*
* Allows tables to be collapsed, showing only the header. See [[Help:Collapsing]].
* @version 3.0.0 (2018-05-20)
* @source https://www.mediawiki.org/wiki/MediaWiki:Gadget-collapsibleTables.js
* @author [[User:R. Koot]]
* @author [[User:Krinkle]]
* @author [[User:TheDJ]]
* @deprecated Since MediaWiki 1.20: Use class="mw-collapsible" instead which
* is supported in MediaWiki core. Shimmable since MediaWiki 1.32
*
* @param {jQuery} $content
*/
function makeCollapsibleMwCollapsible( $content ) {
var $tables = $content
.find( 'table.collapsible:not(.mw-collapsible)' )
.addClass( 'mw-collapsible' );
$.each( $tables, function ( index, table ) {
// mw.log.warn( 'This page is using the deprecated class collapsible. Please replace it with mw-collapsible.');
if ( $( table ).hasClass( 'collapsed' ) ) {
$( table ).addClass( 'mw-collapsed' );
// mw.log.warn( 'This page is using the deprecated class collapsed. Please replace it with mw-collapsed.');
}
} );
if ( $tables.length > 0 ) {
mw.loader.using( 'jquery.makeCollapsible' ).then( function () {
$tables.makeCollapsible();
} );
}
}
mw.hook( 'wikipage.content' ).add( makeCollapsibleMwCollapsible );
/**
* Add support to mw-collapsible for autocollapse, innercollapse and outercollapse
*
* Maintainers: TheDJ
*/
function mwCollapsibleSetup( $collapsibleContent ) {
var $element,
$toggle,
autoCollapseThreshold = 2;
$.each( $collapsibleContent, function ( index, element ) {
$element = $( element );
if ( $element.hasClass( 'collapsible' ) ) {
$element.find( 'tr:first > th:first' ).prepend( $element.find( 'tr:first > * > .mw-collapsible-toggle' ) );
}
if ( $collapsibleContent.length >= autoCollapseThreshold && $element.hasClass( 'autocollapse' ) ) {
$element.data( 'mw-collapsible' ).collapse();
} else if ( $element.hasClass( 'innercollapse' ) ) {
if ( $element.parents( '.outercollapse' ).length > 0 ) {
$element.data( 'mw-collapsible' ).collapse();
}
}
// because of colored backgrounds, style the link in the text color
// to ensure accessible contrast
$toggle = $element.find( '.mw-collapsible-toggle' );
if ( $toggle.length ) {
// Make the toggle inherit text color (Updated for T333357 2023-04-29)
if ( $toggle.parent()[ 0 ].style.color ) {
$toggle.css( 'color', 'inherit' );
$toggle.find( '.mw-collapsible-text' ).css( 'color', 'inherit' );
}
}
} );
}
mw.hook( 'wikipage.collapsibleContent' ).add( mwCollapsibleSetup );
} ); // wrapper end