Версия для слабовидящих

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

Материал из Ярославский педагогический университет
Перейти к: навигация, поиск
 
(не показаны 43 промежуточных версий 2 участников)
Строка 3: Строка 3:
 
// (не обязательно участникам проекта) при обращении к какой-либо странице.
 
// (не обязательно участникам проекта) при обращении к какой-либо странице.
 
*/
 
*/
/**********************************************************************************/
 
function addLoadEvent( f ) { addOnloadHook( f ); }
 
 
/** Функции импортирования *************************************************************
 
*
 
*  Описание: Включают викистраницу в сыром виде, в качестве джаваскрипта или CSS,
 
*            что полезно при подключении дополнительных модулей в определённых условиях.
 
*/
 
 
function importScript( page ) {
 
  var url = wgScriptPath + '/index.php?title='
 
                          + escape( page.replace( ' ', '_' ) )
 
                          + '&action=raw&ctype=text/javascript&dontcountme=s';
 
  var scriptElem = document.createElement( 'script' );
 
  scriptElem.setAttribute( 'src' , url );
 
  scriptElem.setAttribute( 'type' , 'text/javascript' );
 
  document.getElementsByTagName( 'head' )[0].appendChild( scriptElem );
 
}
 
 
function importStylesheet( page ) {
 
  var sheetPath = wgScriptPath +
 
                  '/index.php?title=' +
 
                  escape( page.replace( ' ', '_' ) ) +
 
                  '&action=raw&ctype=text/css';
 
  var sheetRule = '@import "' + sheetPath + '";';
 
  var styleElem = document.createElement( 'style' );
 
  styleElem.setAttribute( 'type' , 'text/css' );
 
  try {
 
      var SheetTextNode = document.createTextNode( sheetRule );
 
      styleElem.appendChild( SheetTextNode );
 
      document.getElementsByTagName( 'head' )[0].appendChild( styleElem );
 
  } catch (e) {
 
      try {
 
        document.createStyleSheet(sheetPath);
 
      } catch (ee) {}
 
  }
 
}
 
 
// Простой пример импортирования:
 
// *) подключаем jQuery
 
// *) подключаем jQuery.scrollTo
 
// *) подключаем jQuery.localScroll
 
// *) когда всё подгрузится, задаём плавную прокрутку по ссылкам из оглавлений
 
importScript('MediaWiki:JQuery.js');
 
importScript('MediaWiki:ScrollTo.js');
 
importScript('MediaWiki:LocalScroll.js');
 
 
 
 
 
 
 
/*  Функция hasClass, заимствованная из английской Википедии через русскоязычную.
 
*
 
*  Создаёт закрытый (private в объектно-ориентированном смысле) объект reCache
 
*  (от англ. «regular expression cache», кэш регулярных выражений), который кэширует
 
*  регулярные выражения (тоже объекты), при помощи которых можно проверять, принадлежит ли
 
*  тот или иной элемент тому или иному классу (классу в HTML/CSS-смысле, а не в объектном).
 
*
 
*  Такой подход позволяет функции hasClass не создавать регулярные выражения «на лету»
 
*  всякий раз, когда они понадобятся, а использовать вместо этого готовые. Поэтому
 
*  функция hasClass() удобна во всех случаях, когда есть необходимость проверять много
 
*  элементов HTML на принадлежность одному и тому же классу. Она используется
 
*  в реализации сворачивающихся таблиц и блоков (см. функции collapsibleTables
 
*  и collapsibleDivs и тому подобные ниже); а может, и ещё для чего пригодится.
 
*
 
*  Закрытость объекта reCache достигается механизмом JavaScript function closures:
 
*  http://developer.mozilla.org/en/docs/Core_JavaScript_1.5_Guide:Working_with_Closures
 
*/
 
var hasClass = (function (){
 
  var reCache = {};
 
  return function (element, className){
 
      return (reCache[className] ? reCache[className] :
 
                                  (reCache[className] = new RegExp("(?:\\s|^)" + className + "(?:\\s|$)"))
 
            ).test(element.className);
 
  };
 
})();
 
 
 
/******************************************************************************************
 
*
 
*  Сворачивающиеся блоки для шаблонов {{Навигационная полоса ЯГПУ (скрыть/показать)}}
 
*  и для таблиц class="collapsible" (см. на [[Справка:Оформление таблиц]] пример).
 
*
 
*
 
*/
 
 
var autoCollapse = 2;
 
var collapseCaption = 'скрыть';
 
var expandCaption = 'показать';
 
 
function collapsibleTables(){
 
  var allTables = $('#content table.collapsible');
 
 
  allTables.each(function(tblIdx){
 
      var HRow = $('tr:first', this);
 
      if (HRow.length == 0){
 
        $(this).addClass('wontCollapse'); // no rows
 
        return true; // continue next iteration of each()
 
      }
 
      if (HRow.parent().children().filter('tr').not(':first').length == 0){
 
        $(this).addClass('wontCollapse'); // no rows after the first
 
        return true; // continue next iteration of each()
 
      }
 
 
      var Header = $('th:last', HRow);
 
      if (Header.length == 0){
 
        $(this).addClass('wontCollapse'); // no TH in the first row
 
        return true; // continue next iteration of each()
 
      }
 
 
      $(this).data('collapseIndex', tblIdx);
 
      Header.prepend(
 
        '<span style="float: right; font-weight: normal;">'+
 
        '[<a id="collapseButton' + tblIdx + '" href="#" onClick="collapseTable(this); return false;">'+
 
        collapseCaption + '</a>]</span>');
 
  });
 
 
  var processedTables = allTables.not('.wontCollapse');
 
  if (processedTables.length > autoCollapse){
 
      processedTables.filter('.autocollapse').each(function(i){
 
        var linkIDX = $(this).data('collapseIndex');
 
        collapseTable($('a#collapseButton' + linkIDX, this).eq(0));
 
      });
 
  }
 
  processedTables.filter('.collapsed').each(function(i){
 
      var linkIDX = $(this).data('collapseIndex');
 
      collapseTable($('a#collapseButton' + linkIDX, this).eq(0));
 
  });
 
}
 
 
function collapseTable(linkObject){ // accepts both raw and jQuery-wrapped objects
 
  var TheLink = $(linkObject);
 
  var TableRows = TheLink.closest('tr').parent().children().filter('tr').not(':first');
 
  if (TableRows.length == 0) return;
 
 
  var isShown = (TheLink.text() == collapseCaption);
 
  if (isShown) {
 
      TheLink.text(expandCaption);
 
      TableRows.each(function(i){
 
        $(this).fadeOut(1000);
 
      });
 
  } else {
 
      TheLink.text(collapseCaption);
 
      TableRows.each(function(i){
 
        $(this).fadeIn(1000);
 
      });
 
  };
 
}
 
addOnloadHook(collapsibleTables);
 
 
var NavigationBarHide = '[' + collapseCaption + ']';
 
var NavigationBarShow = '[' + expandCaption + ']';
 
var NavigationBarShowDefault = autoCollapse;
 
 
function collapsibleDivs(){
 
  var NavFrameList = $('#content div.NavFrame');
 
  NavFrameList.each(function(navIdx){
 
      var TheNavHead = $('.NavHead:first', this);
 
      if (TheNavHead.length == 0) {
 
        $(this).addClass('wontCollapse'); // no NavHead inside!
 
        return true;      // continue next iteration of each()
 
      }
 
      $(this).data('NavFrameIndex', navIdx);
 
      TheNavHead.prepend('<a class="NavToggle" '+
 
        'id="NavToggle' + navIdx + '" href="#" '+
 
        'onClick="collapseDiv(this); return false;">'+
 
        NavigationBarHide + '</a>'
 
      );
 
  });
 
 
  var processedDivs = NavFrameList.not('.wontCollapse');
 
  if (processedDivs.length > NavigationBarShowDefault){
 
      processedDivs.not('.expanded').each(function(i){
 
        var linkIDX = $(this).data('NavFrameIndex');
 
        collapseDiv($('a#NavToggle' + linkIDX, this).eq(0));
 
      });
 
  }
 
  processedDivs.filter('.collapsed').each(function(i){
 
      var linkIDX = $(this).data('NavFrameIndex');
 
      collapseDiv($('a#NavToggle' + linkIDX, this).eq(0));
 
  });
 
}
 
 
function collapseDiv(toggleObject){ // accepts both raw and jQuery-wrapped objects
 
  var TheToggle = $(toggleObject);
 
  var TheFrame  = TheToggle.closest('div.NavFrame');
 
  if (TheFrame.length == 0) return false;
 
 
  TheToggle.text( (TheToggle.text() == NavigationBarHide) ? NavigationBarShow : NavigationBarHide);
 
 
  TheFrame.children().filter('.NavPic, .NavContent').each(function(i){
 
      $(this).slideToggle(1000);
 
  });
 
}
 
addOnloadHook(collapsibleDivs);
 
 
/*  Замена гиперссылки на кнопке «+» (например, наверху обсуждений) на другой адрес,
 
*  если на странице был поставлен шаблон {{modifynewsectionlink}}.
 
*/
 
function newSectionLink(){
 
  try{ 
 
    var customLink = $('#add-custom-section a:first');
 
    if (customLink.length == 0) return;
 
    $('#ca-addsection a:first').attr('href', customLink.attr('href'));
 
  }catch(e){}
 
}
 
  
 
/* Колмогоровские чтения:Подать заявку */
 
/* Колмогоровские чтения:Подать заявку */
if (wgArticleId=="1722" || wgArticleId=="1313" ){
+
if (mw.config.get("wgArticleId")=="1722" || mw.config.get("wgArticleId")=="1313" ){
var mURL = wgServer +"/" + wgScriptPath ;
+
var mURL = mw.config.get("wgServer") +"/" + mw.config.get("wgScriptPath") ;
 
     var a = mURL+"/kolmogor/js/wiki.js";
 
     var a = mURL+"/kolmogor/js/wiki.js";
 
     var GET = "?"+(1000 + Math.floor(Math.random() * 8999)) + "=1";
 
     var GET = "?"+(1000 + Math.floor(Math.random() * 8999)) + "=1";
 
     a += GET;
 
     a += GET;
 
+
    /*alert (a);*/
 
     importScriptURI(a);
 
     importScriptURI(a);
  
Строка 226: Строка 19:
 
     importStylesheetURI(a);
 
     importStylesheetURI(a);
 
};
 
};
 +
/***********************************************/
  
 
/* «Человек в информационном пространстве» */
 
/* «Человек в информационном пространстве» */
if (wgArticleId == "3063" || wgArticleId == "3065" || wgArticleId == "3067" || wgArticleId == "3068" || wgArticleId == "3073" || wgArticleId == "3070" || wgArticleId == "3074"){
+
if (mw.wgArticleId == "3063" || mw.wgArticleId == "3065" || mw.wgArticleId == "3067" || mw.wgArticleId == "3068" || mw.wgArticleId == "3073" || mw.wgArticleId == "3070" || mw.wgArticleId == "3074"){
  
 
  function ReplaceHead(o){
 
  function ReplaceHead(o){
Строка 252: Строка 46:
  
  
 +
/**********************************************************************************/
  
addOnloadHook(newSectionLink);
 
  
 
/* </source> */
 
/* </source> */

Текущая версия на 10:42, 4 марта 2015

/* <source lang="javascript">
// Размещённый здесь код JavaScript будет загружен всем читателям
// (не обязательно участникам проекта) при обращении к какой-либо странице.
*/
 
/* Колмогоровские чтения:Подать заявку */
if (mw.config.get("wgArticleId")=="1722" || mw.config.get("wgArticleId")=="1313" ){
var mURL = mw.config.get("wgServer") +"/" + mw.config.get("wgScriptPath") ;
    var a = mURL+"/kolmogor/js/wiki.js";
    var GET = "?"+(1000 + Math.floor(Math.random() * 8999)) + "=1";
    a += GET;
    /*alert (a);*/
    importScriptURI(a);
 
    var a = mURL+"/kolmogor/css/kolmogor.css";
    var GET = "?"+(1000 + Math.floor(Math.random() * 8999)) + "=1";
    a += GET;
 
    importStylesheetURI(a);
};
/***********************************************/
 
/* «Человек в информационном пространстве» */
if (mw.wgArticleId == "3063" || mw.wgArticleId == "3065" || mw.wgArticleId == "3067" || mw.wgArticleId == "3068" || mw.wgArticleId == "3073" || mw.wgArticleId == "3070" || mw.wgArticleId == "3074"){
 
 function ReplaceHead(o){
  var title = o.innerHTML.replace(/[0-9]/g,"");
  o.innerHTML = title;
 };
 
 var ci = 0;
 
 function myOnloadHook(){
    ci++;
    var h1 = document.getElementById("firstHeading");
    if(h1){
      ReplaceHead(h1);
    }else{
     setTimeout(function(){return myOnloadHook();},100);
   };
 };
 
 myOnloadHook();
 
};
 
 
/**********************************************************************************/
 
 
/* </source> */