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

Материал из ЕЖЕВИКИ - EJWiki.org - Академической Вики-энциклопедии по еврейским и израильским темам
Перейти к навигацииПерейти к поиску
BorisG (обсуждение | вклад)
Нет описания правки
 
BorisG (обсуждение | вклад)
Нет описания правки
Строка 1: Строка 1:
/**
/* Размещённый здесь JavaScript код будет загружаться всем пользователям при обращении к каждой странице */
* Keep code in MediaWiki:Common.js to a minimum as it is unconditionally
//See http://ru.wikipedia.org/wiki/project:code //<source lang=javascript>
* loaded for all users on every wiki page. If possible create a gadget that is
* enabled by default instead of adding it here (since gadgets are fully
* optimized ResourceLoader modules with possibility to add dependencies etc.)
*
* Since Common.js isn't a gadget, there is no place to declare its
* dependencies, so we have to lazy load them with mw.loader.using on demand and
* then execute the rest in the callback. In most cases these dependencies will
* be loaded (or loading) already and the callback will not be delayed. In case a
* dependency hasn't arrived yet it'll make sure those are loaded before this.
*/
/*global mw, $, importStylesheet, importScript */
/*jshint curly:false eqnull:true, strict:false, browser:true, */


window.hotcat_translations_from_commons = true;
importScript_ = importScript
  mw.loader.load('//commons.wikimedia.org/w/index.php?title=MediaWiki:Gadget-HotCat.js&action=raw&ctype=text/javascript');
importScript = function (page, proj){
/*WikiEditor/Викификатор*/
  if (!proj) importScript_(page)
if ( $.inArray( mw.config.get( 'wgAction' ), ['edit', 'submit'] ) !== -1 ) {
else {
        mw.loader.load( '//www.ejwiki.org/w/index.php?title=MediaWiki:Wikificator.js&action=raw&ctype=text/javascript' );
  if (proj.indexOf('.')==-1) proj += '.wikipedia.org'
  importScriptURI('http://'+proj+'/w/index.php?action=raw&ctype=text/javascript&title='+encodeURIComponent(page.replace(/ /g,'_')))
}
}
}


addLoadEvent = addOnloadHook
var customizeToolbar = function() {
var customizeToolbar = function() {
  $('#wpTextbox1').wikiEditor('addToToolbar', {
  $('#wpTextbox1').wikiEditor('addToToolbar', {
Строка 74: Строка 65:
                                       execute: function(context){
                                       execute: function(context){
                                               Wikify();
                                               Wikify();
                                       }
                                       }  
                             }
                             }
                 }
                 }
Строка 89: Строка 80:
         } );
         } );
}
}
mw.loader.using( ['mediawiki.util', 'mediawiki.notify', 'jquery.client'], function () {
/* Begin of mw.loader.using callback */


/**
if (/(Android|iPhone|iPod|webOS|Opera Mini)/.test(navigator.userAgent)
* Main Page layout fixes
  && document.cookie.indexOf('stopMobileRedirect=true') == -1){
*
  if (wgCanonicalNamespace == 'Special' && wgCanonicalSpecialPageName == 'Search')
* Description: Adds an additional link to the complete list of languages available.
    var _mobiLink = '?search=' + encodeURIComponent(document.getElementById('searchText').value)
* Maintainers: [[User:AzaToth]], [[User:R. Koot]], [[User:Alex Smotrov]]
  else if (wgArticleId==4401)
  */
    var _mobiLink = '::Home'
if ( mw.config.get( 'wgPageName' ) === 'Main_Page' || mw.config.get( 'wgPageName' ) === 'Talk:Main_Page' ) {
  else
     $( document ).ready( function () {
     var _mobiLink = encodeURIComponent(wgPageName).replace('%2F','/').replace('%3A',':')
        mw.util.addPortletLink( 'p-lang', '//meta.wikimedia.org/wiki/List_of_Wikipedias',
  document.location = 'http://wiki.m.ejwiki.org/wiki/' + _mobiLink + '?wasRedirected=true'
            'Complete list', 'interwiki-completelist', 'Complete list of Wikipedias' );
    } );
}
}


/**
function LinkFA(){
  * Redirect User:Name/skin.js and skin.css to the current skin's pages
  var pLang = document.getElementById('p-lang')
* (unless the 'skin' page really exists)
  if (!pLang) return
  * @source: http://www.mediawiki.org/wiki/Snippets/Redirect_skin.js
var iw = pLang.getElementsByTagName('li')
* @rev: 2
for (var i=0; i < iw.length; i++)
*/
  if (document.getElementById(iw[i].className+'-fa')){
if ( mw.config.get( 'wgArticleId' ) === 0 && mw.config.get( 'wgNamespaceNumber' ) === 2 ) {
    iw[i].className += ' FA'
    var titleParts = mw.config.get( 'wgPageName' ).split( '/' );
    iw[i].title = 'Эта статья является избранной в одном из языковых разделов Википедии'
    /* Make sure there was a part before and after the slash
  }else if (document.getElementById(iw[i].className+'-ga')){
      and that the latter is 'skin.js' or 'skin.css' */
    iw[i].className += ' GA'
    if ( titleParts.length == 2 ) {
    iw[i].title = 'Эта статья является хорошей в одном из языковых разделов Википедии'
        var userSkinPage = titleParts.shift() + '/' + mw.config.get( 'skin' );
  }
        if ( titleParts.slice( -1 ) == 'skin.js' ) {
            window.location.href = mw.util.wikiGetlink( userSkinPage + '.js' );
        } else if ( titleParts.slice( -1 ) == 'skin.css' ) {
            window.location.href = mw.util.wikiGetlink( userSkinPage + '.css' );
        }
    }
}
}


  try {
      //try/catch added by BorisG - 20141106
      //mw.log.deprecate is not defined
      /**
      * Map addPortletLink to mw.util
      *
      * @deprecated: Use mw.util.addPortletLink instead.
      */
      mw.log.deprecate(window, 'addPortletLink', function () {
        return mw.util.addPortletLink.apply(mw.util, arguments);
      }, 'Use mw.util.addPortletLink() instead');


      /**
function icqIcons(){
      * Extract a URL parameter from the current URL
var a, spans = document.getElementById('content').getElementsByTagName('span')
      *
for (var i=0; a=spans[i]; i++)
      * @deprecated: Use mw.util.getParamValue with proper escaping
  if (a.className == 'ICQ')  
      */
    a.style.backgroundImage = "url('http://status.icq.com/online.gif?icq="+a.id+"&img=5&randseed="+Math.floor(Math.random()*10000000)+"')"
      mw.log.deprecate(window, 'getURLParamValue', function () {
}
        return mw.util.getParamValue.apply(mw.util, arguments);
      }, 'Use mw.util.getParamValue() instead');


      /**
      * Test if an element has a certain class
      *
      * @deprecated:  Use $(element).hasClass() instead.
      */
      mw.log.deprecate(window, 'hasClass', function (element, className) {
        return $(element).hasClass(className);
      }, 'Use jQuery.hasClass() instead');
  } catch(e) {
      console.log("Error: " + e.message);
  }


/**
function newSectionLink(){
  * @source www.mediawiki.org/wiki/Snippets/Load_JS_and_CSS_by_URL
  var plus = document.getElementById('ca-addsection')
* @rev 5
if (!plus) return
*/
var custom = document.getElementById('add-custom-section')
// CSS
if (!custom) return
var extraCSS = mw.util.getParamValue( 'withCSS' );
plus.firstChild.setAttribute('href', custom.getElementsByTagName('a')[0].href)
if ( extraCSS ) {
if ( extraCSS.match( /^MediaWiki:[^&<>=%#]*\.css$/ ) ) {
importStylesheet( extraCSS );
} else {
mw.notify( 'Only pages from the MediaWiki namespace are allowed.', { title: 'Invalid withCSS value' } );
}
}
}


// JS
 
var extraJS = mw.util.getParamValue( 'withJS' );
function editZeroSection(){
if ( extraJS ) {
var body = document.getElementById('bodyContent')
if ( extraJS.match( /^MediaWiki:[^&<>=%#]*\.js$/ ) ) {
if (!body) return
importScript( extraJS );
var h2s = body.getElementsByTagName('H2')
} else {
var h2 = h2s[0]
mw.notify( 'Only pages from the MediaWiki namespace are allowed.', { title: 'Invalid withJS value' } );
if (!h2) return
}
if (h2.parentNode.id == 'toctitle') h2 = h2s[1]
if (!h2) return
var span = h2.firstChild
if (!span || span.className != 'editsection') return
var zero = span.cloneNode(true)
body.insertBefore(zero, body.firstChild)
var a = zero.getElementsByTagName('a')[0]
if (a.href.indexOf('&section=T') == -1 )  a.title = a.title.replace(/:.*$/,': 0')
else a.title = 'Править секцию: 0'
a.setAttribute('href', wgScript + '?title='+encodeURIComponent(wgPageName) + '&action=edit&section=0')
}
}


/**
* Import more specific scripts if necessary
*/
if ( mw.config.get( 'wgAction' ) === 'edit' || mw.config.get( 'wgAction' ) === 'submit' || mw.config.get( 'wgCanonicalSpecialPageName' ) === 'Upload' ) {
    /* scripts specific to editing pages */
    importScript("MediaWiki:AboutArticle.js"); //added by BorisG - 20141106
    importScript( 'MediaWiki:Common.js/edit.js' );
} else if ( mw.config.get( 'wgCanonicalSpecialPageName' ) === 'Watchlist' ) {
    /* watchlist scripts */
    importScript( 'MediaWiki:Common.js/watchlist.js' );
}
if ( mw.config.get( 'wgNamespaceNumber' ) === 6 ) {
    /* file description page scripts */
    importScript( 'MediaWiki:Common.js/file.js' );
}


/**
function mainPage(){
  * Load scripts specific to Internet Explorer
  if (wgArticleId == 1){
*/
  var li = addPortletLink('p-lang', wgArticlePath.replace(/\$1/, 'Википедия:Список_Википедий'), 'Полный список', 'interwiki-completelist')
if ( $.client.profile().name === 'msie' ) {
  if (li) li.style.fontWeight = 'bold'
    importScript( 'MediaWiki:Common.js/IEFixes.js' );
  var nstab = document.getElementById('ca-nstab-main') || document.getElementById('ca-current')
  if (nstab && wgUserLanguage == 'ru')  nstab.firstChild.firstChild.nodeValue = 'Заглавная'
}
}
}


/**
* Fix for Windows XP Unicode font rendering
*/
if ( navigator.appVersion.search(/windows nt 5/i) !== -1 ) {
    mw.util.addCSS( '.IPA { font-family: "Lucida Sans Unicode", "Arial Unicode MS"; } ' +
                '.Unicode { font-family: "Arial Unicode MS", "Lucida Sans Unicode"; } ' );
}


//Collapsiblе: [[ВП:СБ]]


/**
var NavigationBarShowDefault = 2
* WikiMiniAtlas
var NavigationBarHide = '[скрыть]'
*
var NavigationBarShow = '[показать]'
* Description: WikiMiniAtlas is a popup click and drag world map.
*              This script causes all of our coordinate links to display the WikiMiniAtlas popup button.
*              The script itself is located on meta because it is used by many projects.
*              See [[Meta:WikiMiniAtlas]] for more information.
* Maintainers: [[User:Dschwen]]
*/
( function () {
    var require_wikiminiatlas = false;
    var coord_filter = /geohack/;
    $( document ).ready( function() {
        $( 'a.external.text' ).each( function( key, link ) {
            if ( link.href && coord_filter.exec( link.href ) ) {
                require_wikiminiatlas = true;
                // break from loop
                return false;
            }
        } );
        if ( $( 'div.kmldata' ).length ) {
            require_wikiminiatlas = true;
        }
        if ( require_wikiminiatlas ) {
            mw.loader.load( '//meta.wikimedia.org/w/index.php?title=MediaWiki:Wikiminiatlas.js&action=raw&ctype=text/javascript' );
        }
    } );
} )();


/**
var hasClass = (function (){
  * Interwiki links to featured articles ***************************************
  var reCache = {}
  *
  return function (element, className){
* Description: Highlights interwiki links to featured articles (or
  return (reCache[className] ? reCache[className] : (reCache[className] = new RegExp("(?:\\s|^)" + className + "(?:\\s|$)"))).test(element.className)
*              equivalents) by changing the bullet before the interwiki link
  }
*              into a star.
})()
* Maintainers: [[User:R. Koot]]
*/
function LinkFA() {
    if ( document.getElementById( 'p-lang' ) ) {
        var InterwikiLinks = document.getElementById( 'p-lang' ).getElementsByTagName( 'li' );


        for ( var i = 0; i < InterwikiLinks.length; i++ ) {
function collapsibleTables(){
            var className = InterwikiLinks[i].className.match(/interwiki-[-\w]+/);
var Table, HRow,  HCell, btn, a, tblIdx = 0, colTables = []
            if ( document.getElementById( className + '-fa' ) ) {
var allTables = document.getElementsByTagName('table')
                InterwikiLinks[i].className += ' FA';
for (var i=0; Table = allTables[i]; i++){
                InterwikiLinks[i].title = 'This is a featured article in this language.';
  if (!hasClass(Table, 'collapsible')) continue
            } else if ( document.getElementById( className + '-ga' ) ) {
  if (!(HRow=Table.rows[0])) continue
                InterwikiLinks[i].className += ' GA';
  if (!(HCell=HRow.getElementsByTagName('th')[0])) continue
                InterwikiLinks[i].title = 'This is a good article in this language.';
  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)
}
}


  try {
function collapseTable (idx){
      //try/catch added by BorisG - 20141106
var Table = document.getElementById('collapsibleTable' + idx)
      mw.hook('wikipage.content').add(LinkFA);
var btn = document.getElementById('collapseButton' + idx)
  } catch(e) {
if (!Table || !btn) return false
      console.log("Error: " + e.message);
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(){
  * Collapsible tables *********************************************************
  var navIdx = 0, colNavs = [], i, NavFrame
  *
  var divs = document.getElementById('content').getElementsByTagName('div')
  * Description: Allows tables to be collapsed, showing only the header. See
  for (i=0; NavFrame = divs[i]; i++) {
*              [[Wikipedia:NavFrame]].
  if (!hasClass(NavFrame, 'NavFrame')) continue
  * Maintainers: [[User:R. Koot]]
  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)
}


var autoCollapse = 2;
function collapseDiv(idx) {
var collapseCaption = 'hide';
var div = document.getElementById('NavFrame' + idx)
var expandCaption = 'show';
var btn = document.getElementById('NavToggle' + idx)
 
if (!div || !btn) return false
window.collapseTable = function ( tableIndex ) {
var isShown = (btn.firstChild.data == NavigationBarHide)
    var Button = document.getElementById( 'collapseButton' + tableIndex );
btn.firstChild.data = isShown ? NavigationBarShow : NavigationBarHide
    var Table = document.getElementById( 'collapsibleTable' + tableIndex );
var disp = isShown ? 'none' : 'block'
 
for (var child = div.firstChild; child != null;  child = child.nextSibling)
    if ( !Table || !Button ) {
  if (hasClass(child, 'NavPic') || hasClass(child, 'NavContent'))
        return false;
      child.style.display = disp
    }
}


    var Rows = Table.rows;
    var i;


    if ( Button.firstChild.data === collapseCaption ) {
//Execution
        for ( i = 1; i < Rows.length; i++ ) {
if (wgCanonicalNamespace == 'Special'){
            Rows[i].style.display = 'none';
  switch (wgCanonicalSpecialPageName){
        }
  case 'Upload': importScript_('MediaWiki:Upload.js'); break
        Button.firstChild.data = expandCaption;
  //case 'Search': importScript_('MediaWiki:Search.js'); break
    } else {
  }
        for ( i = 1; i < Rows.length; i++ ) {
}else if (wgAction != 'history'){
            Rows[i].style.display = Rows[0].style.display;
  addOnloadHook(editZeroSection)
        }
  addOnloadHook(collapsibleDivs)
        Button.firstChild.data = collapseCaption;
  addOnloadHook(collapsibleTables)
     }
  addOnloadHook(mainPage)
};
  //importScript('MediaWiki:Wikiminiatlas.js', 'meta.wikimedia.org')
  if (navigator.appName=='Microsoft Internet Explorer' && document.createStyleSheet)
    document.createStyleSheet().addRule('.IPA', 'font-family: "Doulos SIL", "Charis SIL", Gentium, "DejaVu Sans", Code2000, "TITUS Cyberbit Basic", "Arial Unicode MS", "Lucida Sans Unicode", "Chrysanthi Unicode";')
  if (wgNamespaceNumber==0 || wgNamespaceNumber==100)
    addOnloadHook(LinkFA)
  else {
    addOnloadHook(icqIcons)
     addOnloadHook(newSectionLink)
  }


function createCollapseButtons() {
if (wgAction=='edit' || wgAction=='submit') {
    var tableIndex = 0;
  //упрощённое добавление шаблона Остатье
    var NavigationBoxes = {};
  //importScript_('MediaWiki:AboutArticle.js')
    var Tables = document.getElementsByTagName( 'table' );
    var i;


    function handleButtonLink( index, e ) {
  //упрощённое добавление шаблона О_тексте
        window.collapseTable( index );
  importScript('MediaWiki:AboutTextPub.js');
        e.preventDefault();
    }


    for ( i = 0; i < Tables.length; i++ ) {
  //добавление панели редактирования
        if ( $( Tables[i] ).hasClass( 'collapsible' ) ) {
  importScript_('MediaWiki:Editpage.js')


            /* only add button and increment count if there is a header row to work with */
//упрощённое добавление шаблонов ссылок на источники
            var HeaderRow = Tables[i].getElementsByTagName( 'tr' )[0];
//importScript_('MediaWiki:RefToolbar.js')
            if ( !HeaderRow ) continue;
            var Header = HeaderRow.getElementsByTagName( 'th' )[0];
            if ( !Header ) continue;


            NavigationBoxes[ tableIndex ] = Tables[i];
//Скрипт превращает слово в [[гиперссылку]], используя при этом содержимое окна поиска (слева).
            Tables[i].setAttribute( 'id', 'collapsibleTable' + tableIndex );
//importScript_('MediaWiki:Wordwikify.js')


            var Button    = document.createElement( 'span' );
//Скрипт редактирования для Википедии. Переводит выделенный фрагмент текста в нижний регистр.
            var ButtonLink = document.createElement( 'a' );
//importScript_('MediaWiki:Lowercase.js')
            var ButtonText = document.createTextNode( collapseCaption );


            Button.className = 'collapseButton'; /* Styles are declared in Common.css */
  //Транслитерация выделенного текста из латиницы в кириллицу
//importScript_('MediaWiki:Translit.js')


            ButtonLink.style.color = Header.style.color;
//Форматирует таблицу, скопированную из Excel, по правилам вики-разметки
            ButtonLink.setAttribute( 'id', 'collapseButton' + tableIndex );
//importScript_('MediaWiki:Tablifikator.js')
            ButtonLink.setAttribute( 'href', '#' );
            $( ButtonLink ).on( 'click', $.proxy( handleButtonLink, ButtonLink, tableIndex ) );
            ButtonLink.appendChild( ButtonText );


            Button.appendChild( document.createTextNode( '[' ) );
//Упрощение ссылок в более читаемые и короткие
            Button.appendChild( ButtonLink );
//importScript_('MediaWiki:Urldecoder.js')
            Button.appendChild( document.createTextNode( ']' ) );
  }
}


            Header.insertBefore( Button, Header.firstChild );
            tableIndex++;
        }
    }


    for ( i = 0; i < tableIndex; i++ ) {
if (wgUserGroups)
        if ( $( NavigationBoxes[i] ).hasClass( 'collapsed' ) || ( tableIndex >= autoCollapse && $( NavigationBoxes[i] ).hasClass( 'autocollapse' ) ) ) {
for (var i=0; i<wgUserGroups.length; i++) switch (wgUserGroups[i]){
            window.collapseTable( i );
//case 'autoconfirmed': importStylesheet('MediaWiki:Gadget-FlaggedRevs.css'); break
        }
case 'sysop': importScript_('MediaWiki:Sysop.js'); break
        else if ( $( NavigationBoxes[i] ).hasClass ( 'innercollapse' ) ) {
            var element = NavigationBoxes[i];
            while ((element = element.parentNode)) {
                if ( $( element ).hasClass( 'outercollapse' ) ) {
                    window.collapseTable ( i );
                    break;
                }
            }
        }
    }
}
}


  try {
// reader-driven error reporting (ВП:СО)
      //try/catch added by BorisG - 20141106
  importScript_('MediaWiki:Wikibugs.js')
      mw.hook('wikipage.content').add(createCollapseButtons);
  } catch(e) {
      console.log("Error: " + e.message);
  }
 
  /**
* Dynamic Navigation Bars (experimental)
*
* Description: See [[Wikipedia:NavFrame]].
* Maintainers: UNMAINTAINED
*/
 
/* set up the words in your language */
var NavigationBarHide = '[' + collapseCaption + ']';
var NavigationBarShow = '[' + expandCaption + ']';
 
/**
* Shows and hides content and picture (if available) of navigation bars
* Parameters:
*    indexNavigationBar: the index of navigation bar to be toggled
**/
window.toggleNavigationBar = function ( indexNavigationBar, event ) {
    var NavToggle = document.getElementById( 'NavToggle' + indexNavigationBar );
    var NavFrame = document.getElementById( 'NavFrame' + indexNavigationBar );
    var NavChild;


    if ( !NavFrame || !NavToggle ) {
// iwiki sorting
        return false;
if (!wgUserName
    }
    || (wgUserName
        && (((typeof wgLangPrefs == 'undefined') ? false : true)
            || ((typeof wgAddLangHints == 'undefined') ? false : wgAddLangHints)
            || ((typeof wgUseUserLanguage == 'undefined') ? false : wgUseUserLanguage))))
    importScript('MediaWiki:Interwiki-links.js')


    /* if shown now */
//HotCat: Adds an easy way to add, modify and remove categories
    if ( NavToggle.firstChild.data === NavigationBarHide ) {
importScript_('MediaWiki:HotCat.js')
        for ( NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling ) {
            if ( $( NavChild ).hasClass( 'NavContent' ) || $( NavChild ).hasClass( 'NavPic' ) ) {
                NavChild.style.display = 'none';
            }
        }
    NavToggle.firstChild.data = NavigationBarShow;


    /* if hidden now */
// collapsible references
    } else if ( NavToggle.firstChild.data === NavigationBarShow ) {
if (wgAction.match(/view|purge|edit|submit/) && wgNamespaceNumber == 0) importScript_('MediaWiki:Collapserefs.js')
        for ( NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling ) {
            if ( $( NavChild ).hasClass( 'NavContent' ) || $( NavChild ).hasClass( 'NavPic' ) ) {
                NavChild.style.display = 'block';
            }
        }
        NavToggle.firstChild.data = NavigationBarHide;
    }


    event.preventDefault();
//Показывает переполнение поля «Описание изменений»
};
importScript_('MediaWiki:Summary show overload.js')


/* adds show/hide-button to navigation bars */
//Выделяет мелким шрифтом дату и время в обсуждениях
function createNavigationBarToggleButton() {
importScript_('MediaWiki:Time small.js')
    var indexNavigationBar = 0;
    var NavFrame;
    var NavChild;
    /* iterate over all < div >-elements */
    var divs = document.getElementsByTagName( 'div' );
    for ( var i = 0; (NavFrame = divs[i]); i++ ) {
        /* if found a navigation bar */
        if ( $( NavFrame ).hasClass( 'NavFrame' ) ) {


            indexNavigationBar++;
//Скрипт проверяет правильность закрытия тегов
            var NavToggle = document.createElement( 'a' );
importScript_('MediaWiki:Check tags.js')
            NavToggle.className = 'NavToggle';
            NavToggle.setAttribute( 'id', 'NavToggle' + indexNavigationBar );
            NavToggle.setAttribute( 'href', '#' );
            $( NavToggle ).on( 'click', $.proxy( window.toggleNavigationBar, window, indexNavigationBar ) );


            var isCollapsed = $( NavFrame ).hasClass( 'collapsed' );
//Быстрый предпросмотр с помощью Ajax
            /**
//importScript_('MediaWiki:Preview.js')
            * Check if any children are already hidden.  This loop is here for backwards compatibility:
            * the old way of making NavFrames start out collapsed was to manually add style="display:none"
            * to all the NavPic/NavContent elements.  Since this was bad for accessibility (no way to make
            * the content visible without JavaScript support), the new recommended way is to add the class
            * "collapsed" to the NavFrame itself, just like with collapsible tables.
            */
            for ( NavChild = NavFrame.firstChild; NavChild != null && !isCollapsed; NavChild = NavChild.nextSibling ) {
                if ( $( NavChild ).hasClass( 'NavPic' ) || $( NavChild ).hasClass( 'NavContent' ) ) {
                    if ( NavChild.style.display === 'none' ) {
                        isCollapsed = true;
                    }
                }
            }
            if ( isCollapsed ) {
                for ( NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling ) {
                    if ( $( NavChild ).hasClass( 'NavPic' ) || $( NavChild ).hasClass( 'NavContent' ) ) {
                        NavChild.style.display = 'none';
                    }
                }
            }
            var NavToggleText = document.createTextNode( isCollapsed ? NavigationBarShow : NavigationBarHide );
            NavToggle.appendChild( NavToggleText );


            /* Find the NavHead and attach the toggle link (Must be this complicated because Moz's firstChild handling is borked) */
//В списке наблюдения: только новые изменения, сортировка списка, мгновенное «не следить»
            for( var j = 0; j < NavFrame.childNodes.length; j++ ) {
importScript_('MediaWiki:watchlist.js')
                if ( $( NavFrame.childNodes[j] ).hasClass( 'NavHead' ) ) {
                    NavToggle.style.color = NavFrame.childNodes[j].style.color;
                    NavFrame.childNodes[j].appendChild( NavToggle );
                }
            }
            NavFrame.setAttribute( 'id', 'NavFrame' + indexNavigationBar );
        }
    }
}


  try {
//Скрипт дополняет форму поиска ссылками на поиск в гугле по различным вики-проектам.
      //try/catch added by BorisG - 20141106
//importScript('MediaWiki:Searchlist.js');
      mw.hook('wikipage.content').add(createNavigationBarToggleButton);
  } catch(e) {
      console.log("Error: " + e.message);
  }
 
/**
* Uploadwizard_newusers
* Switches in a message for non-autoconfirmed users at [[Wikipedia:Upload]]
*
* Maintainers: [[User:Krimpet]]
*/
function uploadwizard_newusers() {
    if ( mw.config.get( 'wgNamespaceNumber' ) === 4 && mw.config.get( 'wgTitle' ) === 'Upload' && mw.config.get( 'wgAction' ) === 'view' ) {
        var oldDiv = document.getElementById( 'autoconfirmedusers' ),
            newDiv = document.getElementById( 'newusers' );
        if ( oldDiv && newDiv ) {
            var userGroups = mw.config.get( 'wgUserGroups' );
            if ( userGroups ) {
                for ( var i = 0; i < userGroups.length; i++ ) {
                    if ( userGroups[i] === 'autoconfirmed' ) {
                        oldDiv.style.display = 'block';
                        newDiv.style.display = 'none';
                        return;
                    }
                }
            }
            oldDiv.style.display = 'none';
            newDiv.style.display = 'block';
            return;
        }
    }
}
 
$(uploadwizard_newusers);
 
/**
* Magic editintros ****************************************************
*
* Description: Adds editintros on disambiguation pages and BLP pages.
* Maintainers: [[User:RockMFR]]
*/
function addEditIntro( name ) {
    $( '.mw-editsection, #ca-edit' ).find( 'a' ).each( function ( i, el ) {
        el.href = $( this ).attr( 'href' ) + '&editintro=' + name;
    } );
}
 
if ( mw.config.get( 'wgNamespaceNumber' ) === 0 ) {
    $( function () {
        if ( document.getElementById( 'disambigbox' ) ) {
            addEditIntro( 'Template:Disambig_editintro' );
        }
    } );
 
    $( function () {
        var cats = document.getElementById( 'mw-normal-catlinks' );
        if ( !cats ) {
            return;
        }
        cats = cats.getElementsByTagName( 'a' );
        for ( var i = 0; i < cats.length; i++ ) {
            if ( cats[i].title === 'Category:Living people' || cats[i].title === 'Category:Possibly living people' ) {
                addEditIntro( 'Template:BLP_editintro' );
                break;
            }
        }
    } );
}


/**
//</source>
* Description: Stay on the secure server as much as possible
* Maintainers: [[User:TheDJ]]
*/
if ( document.location && document.location.protocol  && document.location.protocol === 'https:' ) {
    /* New secure servers */
    importScript( 'MediaWiki:Common.js/secure new.js' );
}
/* End of mw.loader.using callback */
}
);
/* DO NOT ADD CODE BELOW THIS LINE */

Версия от 18:22, 10 ноября 2014

/* Размещённый здесь JavaScript код будет загружаться всем пользователям при обращении к каждой странице */
//See http://ru.wikipedia.org/wiki/project:code //<source lang=javascript>

importScript_ = importScript
importScript = function (page, proj){
 if (!proj) importScript_(page)
 else {
   if (proj.indexOf('.')==-1) proj += '.wikipedia.org'
   importScriptURI('http://'+proj+'/w/index.php?action=raw&ctype=text/javascript&title='+encodeURIComponent(page.replace(/ /g,'_')))
 }
}

addLoadEvent = addOnloadHook 
var customizeToolbar = function() {
 $('#wpTextbox1').wikiEditor('addToToolbar', {
        'section': 'main',
        'group': 'format',
        'tools': {
            'CommentButton': {
                label: 'Вставь Комментарий',
                type: 'button',
                icon: '//upload.wikimedia.org/wikipedia/commons/f/f9/Toolbaricon_regular_S_stroke.png',
                action: {
                    type: 'encapsulate',
                    options: {
                        pre: "<!-- ",
                        peri: "Insert comment here",
                        post: " -->"
                    }
                }
            }
        }
    });
$('#wpTextbox1').wikiEditor('addToToolbar', {
        'section': 'main',
        'group': 'format',
        'tools': {
            'QuoteButton': {
                label: 'ЗаКавычки',
                type: 'button',
                icon: '//upload.wikimedia.org/wikipedia/commons/2/26/Button_latinas.png',
                action: {
                    type: 'encapsulate',
                    options: {
                        pre: "«",
                        peri: "Что желаете закавычить?",
                        post: "»"
                    }
                }
            }
        }
    });


$( '#wpTextbox1' ).wikiEditor( 'addToToolbar', {
        'section': 'main',
        'group': 'format',
        'tools': {
                'wikify': {
                        label: 'Eжефикатор',
                        type: 'button',
                        icon: '//upload.wikimedia.org/wikipedia/commons/0/06/Wikify-toolbutton.png',
                             action: {
                                  type: 'callback',
                                       execute: function(context){
                                              Wikify();
                                       } 
                             }
                }
        }
} );
};
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 );
                        } );
                }
        } );
}

if (/(Android|iPhone|iPod|webOS|Opera Mini)/.test(navigator.userAgent)
 && document.cookie.indexOf('stopMobileRedirect=true') == -1){
  if (wgCanonicalNamespace == 'Special' && wgCanonicalSpecialPageName == 'Search')
    var _mobiLink = '?search=' + encodeURIComponent(document.getElementById('searchText').value)
  else if (wgArticleId==4401)
    var _mobiLink = '::Home'
  else
    var _mobiLink = encodeURIComponent(wgPageName).replace('%2F','/').replace('%3A',':')
  document.location = 'http://wiki.m.ejwiki.org/wiki/' + _mobiLink + '?wasRedirected=true'
}

function LinkFA(){
 var pLang = document.getElementById('p-lang')
 if (!pLang) return
 var iw = pLang.getElementsByTagName('li')
 for (var i=0; i < iw.length; i++)
   if (document.getElementById(iw[i].className+'-fa')){
     iw[i].className += ' FA'
     iw[i].title = 'Эта статья является избранной в одном из языковых разделов Википедии'
   }else if (document.getElementById(iw[i].className+'-ga')){
     iw[i].className += ' GA'
     iw[i].title = 'Эта статья является хорошей в одном из языковых разделов Википедии'
   }
}


function icqIcons(){
 var a, spans = document.getElementById('content').getElementsByTagName('span')
 for (var i=0; a=spans[i]; i++)
   if (a.className == 'ICQ') 
     a.style.backgroundImage = "url('http://status.icq.com/online.gif?icq="+a.id+"&img=5&randseed="+Math.floor(Math.random()*10000000)+"')"
}


function newSectionLink(){
 var plus = document.getElementById('ca-addsection')
 if (!plus) return
 var custom = document.getElementById('add-custom-section')
 if (!custom) return
 plus.firstChild.setAttribute('href', custom.getElementsByTagName('a')[0].href)
}


function editZeroSection(){
 var body = document.getElementById('bodyContent')
 if (!body) return
 var h2s = body.getElementsByTagName('H2')
 var h2 = h2s[0]
 if (!h2) return
 if (h2.parentNode.id == 'toctitle') h2 = h2s[1]
 if (!h2) return
 var span = h2.firstChild
 if (!span || span.className != 'editsection') return
 var zero = span.cloneNode(true)
 body.insertBefore(zero, body.firstChild)
 var a = zero.getElementsByTagName('a')[0]
 if (a.href.indexOf('&section=T') == -1 )  a.title = a.title.replace(/:.*$/,': 0')
 else a.title = 'Править секцию: 0'
 a.setAttribute('href', wgScript + '?title='+encodeURIComponent(wgPageName) + '&action=edit&section=0')
}


function mainPage(){
 if (wgArticleId == 1){
  var li = addPortletLink('p-lang', wgArticlePath.replace(/\$1/, 'Википедия:Список_Википедий'), 'Полный список', 'interwiki-completelist')
  if (li) li.style.fontWeight = 'bold'
  var nstab = document.getElementById('ca-nstab-main') || document.getElementById('ca-current')
  if (nstab && wgUserLanguage == 'ru')  nstab.firstChild.firstChild.nodeValue = 'Заглавная'
 }
}


//Collapsiblе: [[ВП:СБ]]

var NavigationBarShowDefault = 2
var NavigationBarHide = '[скрыть]'
var NavigationBarShow = '[показать]'

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
if (wgCanonicalNamespace == 'Special'){
  switch (wgCanonicalSpecialPageName){
   case 'Upload': importScript_('MediaWiki:Upload.js'); break
   //case 'Search': importScript_('MediaWiki:Search.js'); break
  }
}else if (wgAction != 'history'){
  addOnloadHook(editZeroSection)
  addOnloadHook(collapsibleDivs)
  addOnloadHook(collapsibleTables)
  addOnloadHook(mainPage)
  //importScript('MediaWiki:Wikiminiatlas.js', 'meta.wikimedia.org')
  if (navigator.appName=='Microsoft Internet Explorer' && document.createStyleSheet)
    document.createStyleSheet().addRule('.IPA', 'font-family: "Doulos SIL", "Charis SIL", Gentium, "DejaVu Sans", Code2000, "TITUS Cyberbit Basic", "Arial Unicode MS", "Lucida Sans Unicode", "Chrysanthi Unicode";')
  if (wgNamespaceNumber==0 || wgNamespaceNumber==100)
    addOnloadHook(LinkFA)
  else {
    addOnloadHook(icqIcons)
    addOnloadHook(newSectionLink)
  }

if (wgAction=='edit' || wgAction=='submit') {
  //упрощённое добавление шаблона Остатье
  //importScript_('MediaWiki:AboutArticle.js')

  //упрощённое добавление шаблона О_тексте
  importScript('MediaWiki:AboutTextPub.js');

  //добавление панели редактирования
  importScript_('MediaWiki:Editpage.js')

 //упрощённое добавление шаблонов ссылок на источники
 //importScript_('MediaWiki:RefToolbar.js')

 //Скрипт превращает слово в [[гиперссылку]], используя при этом содержимое окна поиска (слева).
 //importScript_('MediaWiki:Wordwikify.js')

 //Скрипт редактирования для Википедии. Переводит выделенный фрагмент текста в нижний регистр.
 //importScript_('MediaWiki:Lowercase.js')

 //Транслитерация выделенного текста из латиницы в кириллицу
 //importScript_('MediaWiki:Translit.js')

 //Форматирует таблицу, скопированную из Excel, по правилам вики-разметки
 //importScript_('MediaWiki:Tablifikator.js')

 //Упрощение ссылок в более читаемые и короткие
 //importScript_('MediaWiki:Urldecoder.js')
  }
}


if (wgUserGroups)
for (var i=0; i<wgUserGroups.length; i++) switch (wgUserGroups[i]){
 //case 'autoconfirmed': importStylesheet('MediaWiki:Gadget-FlaggedRevs.css'); break
 case 'sysop': importScript_('MediaWiki:Sysop.js'); break
}

// reader-driven error reporting (ВП:СО)
  importScript_('MediaWiki:Wikibugs.js')

// iwiki sorting
 if (!wgUserName
     || (wgUserName
         && (((typeof wgLangPrefs == 'undefined') ? false : true)
             || ((typeof wgAddLangHints == 'undefined') ? false : wgAddLangHints)
             || ((typeof wgUseUserLanguage == 'undefined') ? false : wgUseUserLanguage))))
     importScript('MediaWiki:Interwiki-links.js')

//HotCat: Adds an easy way to add, modify and remove categories 
 importScript_('MediaWiki:HotCat.js')

// collapsible references
if (wgAction.match(/view|purge|edit|submit/) && wgNamespaceNumber == 0) importScript_('MediaWiki:Collapserefs.js')

//Показывает переполнение поля «Описание изменений»
importScript_('MediaWiki:Summary show overload.js')

//Выделяет мелким шрифтом дату и время в обсуждениях
importScript_('MediaWiki:Time small.js')

//Скрипт проверяет правильность закрытия тегов
importScript_('MediaWiki:Check tags.js')

//Быстрый предпросмотр с помощью Ajax
//importScript_('MediaWiki:Preview.js')

//В списке наблюдения: только новые изменения, сортировка списка, мгновенное «не следить»
importScript_('MediaWiki:watchlist.js')

//Скрипт дополняет форму поиска ссылками на поиск в гугле по различным вики-проектам.
//importScript('MediaWiki:Searchlist.js');

//</source>