MediaWiki:Common.js
Версия от 19:35, 15 апреля 2012;
Замечание. Возможно, после сохранения вам придётся очистить кэш своего браузера, чтобы увидеть изменения.
- Firefox / Safari: Удерживая клавишу Shift, нажмите на панели инструментов Обновить либо нажмите Ctrl-F5 или Ctrl-R (⌘-R на Mac)
- Google Chrome: Нажмите Ctrl-Shift-R (⌘-Shift-R на Mac)
- Internet Explorer: Удерживая Ctrl, нажмите Обновить либо нажмите Ctrl-F5
- Opera: Выберите очистку кэша в меню Инструменты → Настройки
/* Размещённый здесь 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(); });