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

Материал из Бронетанковой Энциклопедии — armor.kiev.ua/wiki
Перейти к: навигация, поиск
(Новая: /* Размещённый здесь код JavaScript будет загружен всем пользователям при обращении к какой-либо странице *...)
 
(Отмена правки 12507, сделанной участником ArmorAdmin (обс.))
 
(не показаны 4 промежуточные версии этого же участника)
Строка 1: Строка 1:
/* Размещённый здесь код JavaScript будет загружен всем пользователям при обращении к какой-либо странице */
+
//Collapsible Tables and Divs, [[ВП:СБ]]
 
+
// Яндекс.Директ
+
var autoCollapse = 2
 
+
var collapseCaption = 'скрыть'
// Размер шрифтов
+
var expandCaption = 'показать'
var yandex_ad_fontSize = 1;
+
 
+
function collapsibleTables(){
// Настройки объявлений Директа
+
var Table, HRow, THs, Header, btn, a, tblIdx = 0, colTables = []
var yandex_direct_fontColor = '000000';
+
var allTables = document.getElementsByTagName('table')
var yandex_direct_BorderColor = 'FBE5C0';
+
for (var i=0; Table = allTables[i]; i++){
var yandex_direct_BgColor = 'FFF9F0';
+
  if (!hasClass(Table, 'collapsible')) continue
var yandex_direct_headerBgColor = 'FEEAC7';
+
  if (!(HRow = Table.rows[0])) continue
var yandex_direct_titleColor = '0000CC';
+
  THs = HRow.getElementsByTagName('th')
var yandex_direct_siteurlColor = '006600';
+
  if (THs.length == 0) continue
var yandex_direct_linkColor = '0000CC';
+
  Header = THs[THs.length-1] //last TH, not 1st like in en.wp
function yandex_direct_print(){ }
+
  Table.id = 'collapsibleTable' + tblIdx
 
+
  btn = document.createElement('span')
var yandex_r = Math.round(Math.random() * 100000);
+
  btn.style.styleFloat = btn.style.cssFloat = 'right'
document.write('<sc'+'ript type="text/javascript" src="http://an.yandex.ru/code/4192?rnd=' + yandex_r + '&direct-style=2&direct-limit=3&market-limit=0"></'+'sc'+'ript>');
+
  btn.style.fontWeight = 'normal'
 +
  a = document.createElement('a')
 +
  a.id = 'collapseButton' + tblIdx
 +
  a.href = 'javascript:collapseTable(' + tblIdx + ');'
 +
  a.appendChild(document.createTextNode(collapseCaption))
 +
  btn.appendChild(document.createTextNode('['))
 +
  btn.appendChild(a)
 +
  btn.appendChild(document.createTextNode(']'))
 +
  Header.insertBefore(btn, Header.childNodes[0])
 +
  colTables[tblIdx++] = Table
 +
}
 +
for (var i=0; i < tblIdx; i++)
 +
  if ((tblIdx > autoCollapse && 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 == collapseCaption)
 +
btn.firstChild.data = isShown ?  expandCaption : collapseCaption
 +
var disp = isShown ? 'none' : Rows[0].style.display
 +
for (var i=1; i < Rows.length; i++)
 +
    Rows[i].style.display = disp
 +
}
 +
 +
var NavigationBarHide = '[' + collapseCaption + ']'
 +
var NavigationBarShow = '[' + expandCaption + ']'
 +
var NavigationBarShowDefault = autoCollapse
 +
 +
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))
 +
  // 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++)
 +
    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
 +
}

Текущая версия на 14:49, 23 августа 2016

//Collapsible Tables and Divs, [[ВП:СБ]]
 
var autoCollapse = 2
var collapseCaption = 'скрыть'
var expandCaption = 'показать'
 
function collapsibleTables(){
 var Table, HRow, THs, Header, 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
   THs = HRow.getElementsByTagName('th') 
   if (THs.length == 0) continue
   Header = THs[THs.length-1] //last TH, not 1st like in en.wp
   Table.id = 'collapsibleTable' + tblIdx
   btn = document.createElement('span')
   btn.style.styleFloat = btn.style.cssFloat = 'right'
   btn.style.fontWeight = 'normal'
   a = document.createElement('a')
   a.id = 'collapseButton' + tblIdx
   a.href = 'javascript:collapseTable(' + tblIdx + ');' 
   a.appendChild(document.createTextNode(collapseCaption))
   btn.appendChild(document.createTextNode('['))
   btn.appendChild(a)
   btn.appendChild(document.createTextNode(']'))
   Header.insertBefore(btn, Header.childNodes[0])
   colTables[tblIdx++] = Table
 }
 for (var i=0; i < tblIdx; i++)
   if ((tblIdx > autoCollapse && 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 == collapseCaption)
 btn.firstChild.data = isShown ?  expandCaption : collapseCaption
 var disp = isShown ? 'none' : Rows[0].style.display
 for (var i=1; i < Rows.length; i++) 
    Rows[i].style.display = disp
}
 
var NavigationBarHide = '[' + collapseCaption + ']'
var NavigationBarShow = '[' + expandCaption + ']'
var NavigationBarShowDefault = autoCollapse
 
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))
   // 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++)
     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
}