Версия 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> </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> </p>';
$("#dropDownBox").html(str);
$("#dropDownBox").css({"top": top + "px", "left":offset.left + "px"})
$("#dropDownBox").show();
},
function(){
$("#dropDownBox").hide();
});