Добро пожаловать на Леста Игры Wiki!

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

Перейти к: навигация, поиск
Версия 17:03, 15 апреля 2012Версия 19:35, 15 апреля 2012
Строка 215:Строка 215:
 function(){ function(){
  if (!isDropDownBox) {  if (!isDropDownBox) {
? $('#bodyContent').append('<div id="dropDownBox" style="position:absolute;border:1px dotted;background:#f2f2d2;padding:5px 1em;"></div>');+ $('#bodyContent').append('<div id="dropDownBox" style="position:absolute;"></div>');
  isDropDownBox = true;  isDropDownBox = true;
  }  }
Строка 223:Строка 223:
  var obj = $.parseJSON($(this).find(".commentData").text());  var obj = $.parseJSON($(this).find(".commentData").text());
  
? var str = '<p style="text-align:center;"><b>Орудие ' + obj.mark + '</b></p>'+ var str = '<div style="border:1px dotted;background:#ffffc0;padding:5px 1em;"><p style="text-align:center;"><b>Орудие ' + obj.mark + '</b></p>'
 + ' <dl>' + ' <dl>'
 + ' <dt>Уровень:</dt><dd>' + obj.level + '</dd>' + ' <dt>Уровень:</dt><dd>' + obj.level + '</dd>'
Строка 233:Строка 233:
 + ' <dt>Вес:</dt><dd>' + obj.weight + '</dd>' + ' <dt>Вес:</dt><dd>' + obj.weight + '</dd>'
 + ' <dt>Цена:</dt><dd>' + obj.price + '</dd>' + ' <dt>Цена:</dt><dd>' + obj.price + '</dd>'
?+ ' </dl>';++ ' </dl></div><p>&nbsp;</p>';
  
  $("#dropDownBox").html(str);  $("#dropDownBox").html(str);

Версия 19:35, 15 апреля 2012

/* Размещённый здесь JavaScript код будет загружаться всем пользователям при обращении к каждой странице */
function addWikifButton() {
        var toolbar = document.getElementById('toolbar')
        if (!toolbar) return
        var i = document.createElement('img')
        i.src = 'https://upload.wikimedia.org/wikisource/ru/d/d1/Button-wikifikator.png'
        i.alt = i.title = 'викификатор'
        i.onclick = Wikify
        i.style.cursor = 'pointer'
        toolbar.appendChild(i)
}

function addPlayButton() {
  try {
    var logout = document.getElementById('pt-logout');
    if (logout != null) {
      document.getElementById('footer-wot-link').style.display = 'none';
    }   
  } catch(e) {
    return;
  }
}

var tacticCounter = 1;
var mapImages = new Array();

function tacticNext() {  
  document.getElementById('step' + tacticCounter).style.display = 'none';

  if (tacticCounter < mapImages.length - 1) { 
    tacticCounter++ ;
    if (tacticCounter == mapImages.length - 1) document.getElementById('nextsteplink').innerHTML = 'В начало';
  } else { 
    tacticCounter = 1; 
    document.getElementById('nextsteplink').innerHTML = 'Продолжить »';
  }

  document.getElementById('step' + tacticCounter).style.display = 'block';
  document.getElementById('tacticimg').src = mapImages[tacticCounter];
  return false;
}

function tacticSlideShow() {
  try {
    var mapDiv = document.getElementById('tacticmap');
    if (mapDiv == null) {
      return;
    }
    mapImages = mapDiv.innerHTML.split(',');
    mapDiv.innerHTML = '';
    mapDiv.style.background = 'url(' + mapImages[0] + ') top no-repeat';
    var imgNode = document.createElement( 'img' );
    imgNode.id = 'tacticimg';
    imgNode.src = mapImages[1];
    mapDiv.appendChild( imgNode );

    var aNode = document.createElement( 'a' ); 
    aNode.setAttribute( 'id', 'nextsteplink' );
    aNode.setAttribute( 'href', '#' );
    aNode.setAttribute( 'onClick', 'return tacticNext();' );
    aNode.appendChild(document.createTextNode('Продолжить »'));
    document.getElementById('nextstep').appendChild(aNode);
  } catch(e) {
    return;
  }
}

function tthToTop() {
  document.getElementById('stockTTH').style.display = 'none';
  document.getElementById('topTTH').style.display = 'block';
  return false;
}

function tthToStock() {
  document.getElementById('topTTH').style.display = 'none';
  document.getElementById('stockTTH').style.display = 'block';
  return false;
}

function tthTopStock() {
  try {
    var toStock = document.getElementById('toStock');
    var toTop = document.getElementById('toTop');
    if (toStock == null || toTop == null) {
      return;
    }

    var aNode = document.createElement( 'a' ); 
    aNode.setAttribute( 'href', '#' );
    aNode.setAttribute( 'onClick', 'return tthToTop();' );
    aNode.appendChild(document.createTextNode('топ'));
    toTop.appendChild(aNode);

    var aNode = document.createElement( 'a' ); 
    aNode.setAttribute( 'href', '#' );
    aNode.setAttribute( 'onClick', 'return tthToStock();' );
    aNode.appendChild(document.createTextNode('сток'));
    toStock.appendChild(aNode);

  } catch(e) {
    return;
  }
}

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

//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)
  }
})()

/*
$(document).ready(function(){
	$("table.collapsible").each(function(idx, table){
		$(table).attr( "id", 'collapsibleTable' + idx );
	});
});

*/


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
}

// Add Hooks

addOnloadHook(addPlayButton);

if (wgAction == 'edit' || wgAction == 'submit') {
	importScriptURI('https://ru.wikipedia.org/w/index.php?title=MediaWiki:Wikificator.js&action=raw&ctype=text/javascript')
	addOnloadHook(addWikifButton)
} else {
	addOnloadHook(tacticSlideShow)
	addOnloadHook(tthTopStock)
	addOnloadHook(collapsibleDivs)
	addOnloadHook(collapsibleTables)
}

var isDropDownBox = false;

$('.commentDrop').hover(
function(){
  if (!isDropDownBox) {
    $('#bodyContent').append('<div id="dropDownBox" style="position:absolute;"></div>');
    isDropDownBox = true;
  }
  var offset = $(this).position();
  var top = offset.top + $(this).height();

  var obj = $.parseJSON($(this).find(".commentData").text());

  var str = '<div style="border:1px dotted;background:#ffffc0;padding:5px 1em;"><p style="text-align:center;"><b>Орудие ' + obj.mark + '</b></p>'
+ ' <dl>'
+ '  <dt>Уровень:</dt><dd>' + obj.level + '</dd>'
+ '  <dt>Пробитие:</dt><dd>' + obj.penetration + '</dd>'
+ '  <dt>Урон:</dt><dd>' + obj.damage + '</dd>'
+ '  <dt>Скорострельность:</dt><dd>' + obj.rateOfFire + '</dd>'
+ '  <dt>Разброс:</dt><dd>' + obj.dispersion + '</dd>'
+ '  <dt>Сведение:</dt><dd>' + obj.aimingTime + '</dd>'
+ '  <dt>Вес:</dt><dd>' + obj.weight + '</dd>'
+ '  <dt>Цена:</dt><dd>' + obj.price + '</dd>'
+ ' </dl></div><p>&nbsp;</p>';

  $("#dropDownBox").html(str);
  $("#dropDownBox").css({"top": top + "px", "left":offset.left + "px"})
  $("#dropDownBox").show();
},
function(){
  $("#dropDownBox").hide();
});