MediaWiki:Common.js: различия между версиями
Перейти к навигации
Перейти к поиску
Karaby (обсуждение | вклад) Нет описания правки |
Karaby (обсуждение | вклад) Нет описания правки |
||
Строка 11: | Строка 11: | ||
} | } | ||
mw.config.set( 'tableSorterCollation', {'ё':'е'} ) | |||
//Messages | //Messages | ||
var listFA = { | var listFA = { | ||
Строка 174: | Строка 174: | ||
} | } | ||
} | |||
if( !wgUserName ) mw.util.addCSS('#mw-fr-revisiontag {display:none}') //hide FlaggedRevs | |||
/* Helper script for .hlist class in common.css | |||
* Author: [[:en:User:Edokter]] | |||
*/ | |||
if ( $.client.profile().name == 'msie' ) { | |||
/* Add pseudo-selector class to last child list items in IE 8 */ | |||
if ( $.client.profile().versionBase == '8' ) { | |||
$( '.hlist' ).find( 'dd:last-child, dt:last-child, li:last-child' ) | |||
.addClass( 'hlist-last-child' ); | |||
} | |||
/* Generate interpuncts and parens for IE < 8 */ | |||
if ( $.client.profile().versionBase < '8' ) { | |||
$( '.hlist' ).find( 'dt + dd, dt + dt' ).prev() | |||
.append( '<b>:</b> ' ); | |||
$( '.hlist' ).find( 'dd + dd, dd + dt, li + li' ).prev() | |||
.append( '<b>•</b> ' ); | |||
$( '.hlist' ).find( 'dl dl, ol ol, ul ul' ) | |||
.prepend( '( ' ).append( ') ' ); | |||
} | |||
} | |||
// ВП:СО, кроме статей В Контакте, Одноклассники и Facebook | |||
if (wgArticleId!=639373 && wgArticleId!=932117 && wgArticleId!=1297302 && wgArticleId!=25133866) | |||
importMW('Wikibugs') | |||
// iwiki sorting | |||
if (!wgUserName | |||
|| (wgUserName | |||
&& (((typeof wgLangPrefs == 'undefined') ? false : true) | |||
|| ((typeof wgAddLangHints == 'undefined') ? false : wgAddLangHints) | |||
|| ((typeof wgUseUserLanguage == 'undefined') ? false : wgUseUserLanguage)))) | |||
importMW('Interwiki-links'); | |||
}) | |||
//extra scripts | |||
var withJS = document.URL.match(/[&?]withjs=((mediawiki:)?([^&#]+))/i) | |||
if( withJS ) importScript_('MediaWiki:'+withJS[3]) | |||
var execJS = document.getElementById('executeJS') | |||
if( execJS ) | |||
$.each( execJS.className.split(' '), function(i, sc){ | |||
sc = $.trim( sc.replace(/[^\w ]/g,'') ) | |||
if( sc ) importMW('Script/' + sc) | |||
}) | |||
/* | |||
var | |||
DEFAULT_USER_LANGUAGE = "ru", | |||
FALLBACK_USER_LANGUAGE = "en"; | |||
var _lang_messages = {}; | |||
var _debug_lang = false; | |||
function MessageLanguage() { | |||
this.lang = DEFAULT_USER_LANGUAGE; | |||
this.messages = new Object(); | |||
this.prefix = ""; | |||
this.addMessages = function(messages, code, prefix) { | |||
if ( typeof this.messages[code] == "undefined" ) { | |||
this.messages[code] = new Object(); | |||
} | |||
var p = typeof prefix == "string" ? prefix : ""; | |||
for (var key in messages) { | |||
if ( typeof key == "string" ) { | |||
this.messages[code][p + key] = messages[key]; | |||
} | |||
} | |||
}; | |||
this.setLanguage = function(langCode) { | |||
this.lang = langCode; | |||
this.importMessages( this.lang ); | |||
}; | |||
this.setPrefix = function(prefix) { | |||
this.prefix = prefix; | |||
}; | |||
this.msg = function(key) { | |||
key = this.prefix + key; | |||
var msg = this.messages[this.lang] && this.messages[this.lang][key]; | |||
if ( typeof msg == "undefined" ) { | |||
if ( _debug_lang ) alert(key + " го няма на "+this.lang); | |||
msg = this.messages[FALLBACK_USER_LANGUAGE] | |||
&& this.messages[FALLBACK_USER_LANGUAGE][key]; | |||
} | |||
if ( typeof msg == "undefined" ) { | |||
return "{"+ key +"}"; | |||
} | |||
for (var i = 1; i < arguments.length; i++) { | |||
msg = msg.replace( new RegExp("\\$"+i, "g"), arguments[i]); | |||
} | |||
return msg; | |||
}; | |||
this.importMessages = function(lang) { | |||
importScript("MediaWiki:Messages/" + lang + ".js"); | |||
}; | |||
} | |||
var gLang = new MessageLanguage(); | |||
*/ | |||
/* * * * * * * * * * Ajax functions * * * * * * * * * */ | |||
var prevReq; | |||
var pageUrlTpl = wgScript + "?title=$1&action=raw&templates=expand"; | |||
var pageUrl = ""; | |||
var pageToFetch = ""; | |||
function loadPage(page) { | |||
prevReq = sajax_init_object(); | |||
if ( !prevReq ) return false; | |||
pageToFetch = page; | |||
pageUrl = pageUrlTpl.replace(/\$1/, encodeURI(page)); | |||
showLoadIndicator(); | |||
prevReq.onreadystatechange = insertIntoWikiTextFromRequest; | |||
prevReq.open("GET", pageUrl, true); | |||
prevReq.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); | |||
prevReq.send(null); | |||
return true; | |||
} | |||
function insertIntoWikiTextFromRequest() { | |||
if ( prevReq.readyState != 4 ) { | |||
return; | |||
} | |||
hideLoadIndicator(); | |||
if ( prevReq.status != 200 ) { | |||
window.alert(/*gLang.msg(*/"et-ajaxerror", prevReq.status, prevReq.statusText, | |||
pageToFetch, pageUrl/*)*/); | |||
return; | |||
} | |||
insertIntoWikiText(prevReq.responseText); | |||
} | |||
function insertIntoWikiText(content) { | |||
// delete text marked for no inclusion + <pre> and <nowiki> | |||
var re = /<!--noinclude-->.*<!--\/noinclude-->|<\/?pre>|<\/?nowiki>/g; | |||
content = content.replace(re, ""); | |||
// replace escaped tags | |||
var specials = ["pre", "nowiki"]; | |||
for (var i in specials) { | |||
re = new RegExp("\\[(\/?)"+ specials[i] +"\\]", "g"); | |||
content = content.replace(re, "<$1"+ specials[i] +">"); | |||
} | |||
// we can have >>|sample text|<< or >>|<< or just simple text | |||
var parts = null; | |||
var left, right, def = ""; | |||
content = escapeNl(content); | |||
if ( ( parts = content.match(/(.*)>>\|(.*)\|<<(.*)/) ) ) { | |||
left = parts[1]; | |||
def = parts[2]; | |||
right = parts[3]; | |||
} else { // no sample text: split at caret’s position | |||
parts = content.split(">>|<<"); | |||
left = parts[0]; | |||
delete(parts[0]); | |||
right = parts.join(""); | |||
} | |||
insertTags(unescapeNl(left), unescapeNl(right), unescapeNl(def)); | |||
} | |||
function escapeNl(s) { return s.replace(/\n/g, "\x01"); } | |||
function unescapeNl(s) { return s.replace(/\x01/g, "\n"); } | |||
var loadIndicator; | |||
function showLoadIndicator() { | |||
if ( loadIndicator ) { | |||
loadIndicator.style.display = "block"; | |||
return; | |||
} | |||
loadIndicator = document.createElement("div"); | |||
loadIndicator.id = "loadIndicator"; | |||
loadIndicator.appendChild( document.createTextNode(/*gLang.msg(*/"et-tplloading"/*)*/) ); | |||
document.getElementsByTagName("body")[0].appendChild(loadIndicator); | |||
} | |||
function hideLoadIndicator() { | |||
if (loadIndicator) loadIndicator.style.display = "none"; | |||
} | } | ||
Версия от 07:52, 26 декабря 2013
/* Размещённый здесь код JavaScript будет загружаться пользователям при обращении к каждой странице */
importMW = function (name) { importScript('MediaWiki:'+name+'.js') }
importScript_ = importScript
importScript = function (page, proj){
if (!proj) importScript_(page)
else {
if (proj.indexOf('.')==-1) proj += '.wikipedia.org'
importScriptURI('//'+proj+'/w/index.php?action=raw&ctype=text/javascript&title='+mw.util.wikiUrlencode(page))
}
}
mw.config.set( 'tableSorterCollation', {'ё':'е'} )
//Messages
var listFA = {
fa:'Эта статья является избранной',
fl:'Этот список или портал является избранным',
ga:'Эта статья является хорошей'}
var textFA = ' в другом языковом разделе'
var zeroSectionTip = 'Править введение'
var NavigationBarHide = '[скрыть]'
var NavigationBarShow = '[показать]'
var NavigationBarShowDefault = 2
if( /^en$/.test(wgUserLanguage) ) importMW('Common-' + wgUserLanguage)
function LinkFA(){
var ll, s
$('#p-lang li').each( function(i, iw){
ll = iw.className.split(' ')[0] + '-'
for( var s in listFA )
if( document.getElementById(ll + s) )
$( iw )
.addClass( s.toUpperCase() )
.attr( 'title', listFA[s] + textFA )
})
}
function editZeroSection(){
if( !wgArticleId ) return
mw.util.$content.find('h2')
.children('.mw-editsection:first')
.clone().prependTo('#bodyContent')
.css('float','right')
.find('a')
.attr('title', zeroSectionTip)
.attr('href', wgScript + '?title='+mw.util.wikiUrlencode(wgPageName) + '&action=edit§ion=0' )
}
//Collapsiblе: [[ВП:СБ]]
var hasClass = (function (){
var reCache = {}
return function (element, className){
return (reCache[className] ? reCache[className] : (reCache[className] = new RegExp("(?:\\s|^)" + className + "(?:\\s|$)"))).test(element.className)
}
})()
function collapsibleTables(){
var Table, HRow, HCell, btn, a, tblIdx = 0, colTables = []
var allTables = document.getElementsByTagName('table')
for (var i=0; Table = allTables[i]; i++){
if (!hasClass(Table, 'collapsible')) continue
if (!(HRow=Table.rows[0])) continue
if (!(HCell=HRow.getElementsByTagName('th')[0])) continue
Table.id = 'collapsibleTable' + tblIdx
btn = document.createElement('span')
btn.style.cssText = 'float:right; font-weight:normal; font-size:smaller'
a = document.createElement('a')
a.id = 'collapseButton' + tblIdx
a.href = 'javascript:collapseTable(' + tblIdx + ');'
a.style.color = HCell.style.color
a.appendChild(document.createTextNode(NavigationBarHide))
btn.appendChild(a)
HCell.insertBefore(btn, HCell.childNodes[0])
colTables[tblIdx++] = Table
}
for (var i=0; i < tblIdx; i++)
if ((tblIdx > NavigationBarShowDefault && hasClass(colTables[i], 'autocollapse')) || hasClass(colTables[i], 'collapsed'))
collapseTable(i)
}
function collapseTable (idx){
var Table = document.getElementById('collapsibleTable' + idx)
var btn = document.getElementById('collapseButton' + idx)
if (!Table || !btn) return false
var Rows = Table.rows
var isShown = (btn.firstChild.data == NavigationBarHide)
btn.firstChild.data = isShown ? NavigationBarShow : NavigationBarHide
var disp = isShown ? 'none' : Rows[0].style.display
for (var i=1; i < Rows.length; i++)
Rows[i].style.display = disp
}
function collapsibleDivs(){
var navIdx = 0, colNavs = [], i, NavFrame
var divs = document.getElementById('content').getElementsByTagName('div')
for (i=0; NavFrame = divs[i]; i++) {
if (!hasClass(NavFrame, 'NavFrame')) continue
NavFrame.id = 'NavFrame' + navIdx
var a = document.createElement('a')
a.className = 'NavToggle'
a.id = 'NavToggle' + navIdx
a.href = 'javascript:collapseDiv(' + navIdx + ');'
a.appendChild(document.createTextNode(NavigationBarHide))
for (var j=0; j < NavFrame.childNodes.length; j++)
if (hasClass(NavFrame.childNodes[j], 'NavHead'))
NavFrame.childNodes[j].appendChild(a)
colNavs[navIdx++] = NavFrame
}
for (i=0; i < navIdx; i++)
if ((navIdx > NavigationBarShowDefault && !hasClass(colNavs[i], 'expanded')) || hasClass(colNavs[i], 'collapsed'))
collapseDiv(i)
}
function collapseDiv(idx) {
var div = document.getElementById('NavFrame' + idx)
var btn = document.getElementById('NavToggle' + idx)
if (!div || !btn) return false
var isShown = (btn.firstChild.data == NavigationBarHide)
btn.firstChild.data = isShown ? NavigationBarShow : NavigationBarHide
var disp = isShown ? 'none' : 'block'
for (var child = div.firstChild; child != null; child = child.nextSibling)
if (hasClass(child, 'NavPic') || hasClass(child, 'NavContent'))
child.style.display = disp
}
//Execution
mw.loader.using( 'mediawiki.util', function() {
if (wgCanonicalNamespace == 'Special'){
if (/^(Uplo|Sear|Stat|Spec|Abus|Prefe|Move|Watch|Newp|Log|Block$)/i.test(wgCanonicalSpecialPageName))
importMW(wgCanonicalSpecialPageName)
}else switch (wgAction){
case 'history': importMW('History'); break
case 'delete': importMW('Deletepage'); break
case 'edit': case 'submit': importMW('Editpage') //and continue with the default: view, purge
default:
$(editZeroSection)
addOnloadHook(collapsibleDivs)
addOnloadHook(collapsibleTables)
mw.loader.load('//meta.wikimedia.org/w/index.php?title=MediaWiki:Wikiminiatlas.js&action=raw&ctype=text/javascript&smaxage=21600&maxage=86400')
if( document.location && document.location.protocol == 'https:' )
importMW('Secure')
if (navigator.platform.indexOf('Win') != -1)
mw.util.addCSS('.IPA, .Unicode { font-family: "Arial Unicode MS", "Lucida Sans Unicode"; }')
switch( wgNamespaceNumber ){
case 0: case 100:
$(LinkFA)
importMW('Osm')
if( wgArticleId==4401 ) importMW('Mainpage')
break
case 6:
importMW('Filepage')
break
}
}
if( !wgUserName ) mw.util.addCSS('#mw-fr-revisiontag {display:none}') //hide FlaggedRevs
/* Helper script for .hlist class in common.css
* Author: [[:en:User:Edokter]]
*/
if ( $.client.profile().name == 'msie' ) {
/* Add pseudo-selector class to last child list items in IE 8 */
if ( $.client.profile().versionBase == '8' ) {
$( '.hlist' ).find( 'dd:last-child, dt:last-child, li:last-child' )
.addClass( 'hlist-last-child' );
}
/* Generate interpuncts and parens for IE < 8 */
if ( $.client.profile().versionBase < '8' ) {
$( '.hlist' ).find( 'dt + dd, dt + dt' ).prev()
.append( '<b>:</b> ' );
$( '.hlist' ).find( 'dd + dd, dd + dt, li + li' ).prev()
.append( '<b>•</b> ' );
$( '.hlist' ).find( 'dl dl, ol ol, ul ul' )
.prepend( '( ' ).append( ') ' );
}
}
// ВП:СО, кроме статей В Контакте, Одноклассники и Facebook
if (wgArticleId!=639373 && wgArticleId!=932117 && wgArticleId!=1297302 && wgArticleId!=25133866)
importMW('Wikibugs')
// iwiki sorting
if (!wgUserName
|| (wgUserName
&& (((typeof wgLangPrefs == 'undefined') ? false : true)
|| ((typeof wgAddLangHints == 'undefined') ? false : wgAddLangHints)
|| ((typeof wgUseUserLanguage == 'undefined') ? false : wgUseUserLanguage))))
importMW('Interwiki-links');
})
//extra scripts
var withJS = document.URL.match(/[&?]withjs=((mediawiki:)?([^&#]+))/i)
if( withJS ) importScript_('MediaWiki:'+withJS[3])
var execJS = document.getElementById('executeJS')
if( execJS )
$.each( execJS.className.split(' '), function(i, sc){
sc = $.trim( sc.replace(/[^\w ]/g,'') )
if( sc ) importMW('Script/' + sc)
})
/*
var
DEFAULT_USER_LANGUAGE = "ru",
FALLBACK_USER_LANGUAGE = "en";
var _lang_messages = {};
var _debug_lang = false;
function MessageLanguage() {
this.lang = DEFAULT_USER_LANGUAGE;
this.messages = new Object();
this.prefix = "";
this.addMessages = function(messages, code, prefix) {
if ( typeof this.messages[code] == "undefined" ) {
this.messages[code] = new Object();
}
var p = typeof prefix == "string" ? prefix : "";
for (var key in messages) {
if ( typeof key == "string" ) {
this.messages[code][p + key] = messages[key];
}
}
};
this.setLanguage = function(langCode) {
this.lang = langCode;
this.importMessages( this.lang );
};
this.setPrefix = function(prefix) {
this.prefix = prefix;
};
this.msg = function(key) {
key = this.prefix + key;
var msg = this.messages[this.lang] && this.messages[this.lang][key];
if ( typeof msg == "undefined" ) {
if ( _debug_lang ) alert(key + " го няма на "+this.lang);
msg = this.messages[FALLBACK_USER_LANGUAGE]
&& this.messages[FALLBACK_USER_LANGUAGE][key];
}
if ( typeof msg == "undefined" ) {
return "{"+ key +"}";
}
for (var i = 1; i < arguments.length; i++) {
msg = msg.replace( new RegExp("\\$"+i, "g"), arguments[i]);
}
return msg;
};
this.importMessages = function(lang) {
importScript("MediaWiki:Messages/" + lang + ".js");
};
}
var gLang = new MessageLanguage();
*/
/* * * * * * * * * * Ajax functions * * * * * * * * * */
var prevReq;
var pageUrlTpl = wgScript + "?title=$1&action=raw&templates=expand";
var pageUrl = "";
var pageToFetch = "";
function loadPage(page) {
prevReq = sajax_init_object();
if ( !prevReq ) return false;
pageToFetch = page;
pageUrl = pageUrlTpl.replace(/\$1/, encodeURI(page));
showLoadIndicator();
prevReq.onreadystatechange = insertIntoWikiTextFromRequest;
prevReq.open("GET", pageUrl, true);
prevReq.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
prevReq.send(null);
return true;
}
function insertIntoWikiTextFromRequest() {
if ( prevReq.readyState != 4 ) {
return;
}
hideLoadIndicator();
if ( prevReq.status != 200 ) {
window.alert(/*gLang.msg(*/"et-ajaxerror", prevReq.status, prevReq.statusText,
pageToFetch, pageUrl/*)*/);
return;
}
insertIntoWikiText(prevReq.responseText);
}
function insertIntoWikiText(content) {
// delete text marked for no inclusion + <pre> and <nowiki>
var re = /<!--noinclude-->.*<!--\/noinclude-->|<\/?pre>|<\/?nowiki>/g;
content = content.replace(re, "");
// replace escaped tags
var specials = ["pre", "nowiki"];
for (var i in specials) {
re = new RegExp("\\[(\/?)"+ specials[i] +"\\]", "g");
content = content.replace(re, "<$1"+ specials[i] +">");
}
// we can have >>|sample text|<< or >>|<< or just simple text
var parts = null;
var left, right, def = "";
content = escapeNl(content);
if ( ( parts = content.match(/(.*)>>\|(.*)\|<<(.*)/) ) ) {
left = parts[1];
def = parts[2];
right = parts[3];
} else { // no sample text: split at caret’s position
parts = content.split(">>|<<");
left = parts[0];
delete(parts[0]);
right = parts.join("");
}
insertTags(unescapeNl(left), unescapeNl(right), unescapeNl(def));
}
function escapeNl(s) { return s.replace(/\n/g, "\x01"); }
function unescapeNl(s) { return s.replace(/\x01/g, "\n"); }
var loadIndicator;
function showLoadIndicator() {
if ( loadIndicator ) {
loadIndicator.style.display = "block";
return;
}
loadIndicator = document.createElement("div");
loadIndicator.id = "loadIndicator";
loadIndicator.appendChild( document.createTextNode(/*gLang.msg(*/"et-tplloading"/*)*/) );
document.getElementsByTagName("body")[0].appendChild(loadIndicator);
}
function hideLoadIndicator() {
if (loadIndicator) loadIndicator.style.display = "none";
}
var customizeToolbar = function() {
$( '#wpTextbox1' ).wikiEditor( 'addToToolbar', {
'sections': {
'blanks': {
'type': 'toolbar', // Can also be 'booklet'
'label': 'Заготовки'
// or 'labelMsg': 'section-emoticons-label' for a localized label
}
}
} );
$( '#wpTextbox1' ).wikiEditor( 'addToToolbar', {
'section': 'blanks',
'groups': {
'blanks-g': {
'tools': {
'blank-page':{
'label':'--Пустая статья--',
'type':'select',
'list':{
'blank-page-3':{
'label':'Периодическое издание',
'action':{
'type':'callback',
execute: function(context){loadPage("MediaWiki:Common.js/Edit_tools_data/Периодическое_издание");}
}
},
'blank-page-2':{
'label':'Автор и т.п.',
'action':{
'type':'callback',
execute: function(context){loadPage("MediaWiki:Common.js/Edit_tools_data/Автор");}
}
},
'blank-page-1':{
'label':'Исполнитель аудиокниг',
'action':{
'type':'callback',
execute: function(context){loadPage("MediaWiki:Common.js/Edit_tools_data/Исполнитель");}
}
}
}
},
'blank-card':{
'label':'--Карточка--',
'type':'select',
'list':{
'blank-page-1':{
'label':'Персона',
'action':{
'type':'callback',
execute: function(context){loadPage("MediaWiki:Common.js/Edit_tools_data/Персона");}
}
},
'blank-page-2':{
'label':'Периодич. издание',
'action':{
'type':'callback',
execute: function(context){loadPage("MediaWiki:Common.js/Edit_tools_data/Периодика");}
}
}
}
},
'blank-ins': {
label: '--Элемент статьи--', // or use labelMsg for a localized label, see above
type: 'select',
'list': {
'blank-ins-1' : { // Вставить новую пустую категорию
'label': 'Категория',
'action': {
'type': 'encapsulate',
'options': {
'pre': '[[Категория:',
'peri': '', // <== сюда курсор (текущее выделение)
'post': ']]',
}
}
},
'blank-ins-3' : { // Вставить includeonly
'label': 'includeonly',
'action': {
'type': 'encapsulate',
'options': {
'pre': '<includeonly>',
'peri': '', // <== сюда курсор (текущее выделение)
'post': '</includeonly>',
}
}
},
'blank-ins-4' : { // Вставить noinclude
'label': 'noinclude',
'action': {
'type': 'encapsulate',
'options': {
'pre': '<noinclude>',
'peri': '', // <== сюда курсор (текущее выделение)
'post': '</noinclude>',
}
}
},
'blank-ins-5' : { // Вставить ссылку на статью в Web
'label': 'Ссылка на статью в Web',
'action': {
'type': 'encapsulate',
'options': {
'pre': '<ref>{{cite web| url =',
'peri': 'url', // <== сюда курсор (текущее выделение)
'post': ' | title = [Заголовок статьи]}}</ref>',
}
}
},
'blank-ins-2' : { // шаблон Автор статьи
'label': 'Подпись',
'action': {
'type': 'encapsulate',
'options': {
'pre': '{{автор статьи|',
'peri': 'Автор и дата',
'post': '}}',
'regex': /^(\s*)(={1,6})(.*?)\2(\s*)$/,
'regexReplace': "$1===$3===$4",
// 'ownline': true // новая строка
}
}
}
}
}
}
}}
} );
};
////////////////////////////////////////
if ( $.inArray( mw.config.get( 'wgAction' ), ['edit', 'submit'] ) !== -1 ) {
mw.loader.using( 'user.options', function () {
if ( mw.user.options.get('usebetatoolbar') ) {
mw.loader.using( 'ext.wikiEditor.toolbar', function () {
$(document).ready( customizeToolbar );
} );
}
} );
}