MediaWiki:Common.js
Материал из Provizorii
Замечание. Возможно, после сохранения вам придётся очистить кэш своего браузера, чтобы увидеть изменения.
- Firefox / Safari: Удерживая клавишу Shift, нажмите на панели инструментов Обновить либо нажмите Ctrl-F5 или Ctrl-R (⌘-R на Mac)
- Google Chrome: Нажмите Ctrl-Shift-R (⌘-Shift-R на Mac)
- Internet Explorer: Удерживая Ctrl, нажмите Обновить либо нажмите Ctrl-F5
- Opera: Выберите очистку кэша в меню Инструменты → Настройки
function addLoadEvent(func) { if (window.addEventListener) window.addEventListener("load", func, false); else if (window.attachEvent) window.attachEvent("onload", func); } var hasClass = (function (){ var reCache = {}; return function (element, className){ return (reCache[className] ? reCache[className] : (reCache[className] = new RegExp("(?:\\s|^)" + className + "(?:\\s|$)")) ).test(element.className); }; })(); //Сворачивающиеся блоки 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 } addOnloadHook(collapsibleTables); 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 } addOnloadHook(collapsibleDivs); function navpanels() { var idx = 0 body = document.getElementById('bodyContent') if (!body) return panels = getElementsByClassName(body, 'div', 'navpanel') for (var i = 0; i < panels.length; i++) { lc = getElementsByClassName(panels[i], 'div', 'navpanellinks')[0] bc = getElementsByClassName(panels[i], 'div', 'navpanelblocks')[0] links = lc.getElementsByTagName('a') nodes = bc.childNodes var k = 0; for (var j = 0; j < nodes.length; j++) { if(nodes[j].nodeName.toLowerCase() == 'div') { if(links[k]) { id = 'navblock-' + idx nodes[j].id = links[k].navid = id links[k].href = '#' + id links[k].onmousedown = links[k].onclick = uncovernav; links[k].blocks = bc if (k == 0) { nodes[j].style.display = 'block' bc.snav = nodes[j].id bc.slink = links[0] links[0].style.fontWeight = 'bold' } k++ idx++ } else break }}}} function uncovernav() { if (this.blocks.snav != this.navid) { var newnav = document.getElementById(this.navid) var oldnav = document.getElementById(this.blocks.snav) newnav.style.display = 'block' oldnav.style.display = 'none' this.style.fontWeight = 'bold' this.blocks.slink.style.fontWeight = 'normal' this.blocks.snav = this.navid this.blocks.slink = this } return false } addOnloadHook(navpanels); //if (wgUserGroups) //for (var i=0; i<wgUserGroups.length; i++) switch (wgUserGroups[i]){ // case 'editor': importStylesheet('MediaWiki:Gadget-FlaggedRevs.css'); break // case 'sysop': importScript('MediaWiki:Sysop.js'); break //} //importScript('MediaWiki:Histcomb.js') importStylesheet('MediaWiki:Newpagesblacklinks.css'); /** * @author Falchenko Maxim aka be3 * @plugin_page http://tops.net.ua/jquery_addtocopy/ * @desc Adds a link to the copied text * @version 1.2 * @example * $("#content").addtocopy(); * @license free **/ jQuery.fn.addtocopy = function(usercopytxt) { var options = {htmlcopytxt: '<br>More: <a href="'+window.location.href+'">'+window.location.href+'</a><br>', minlen: 25, addcopyfirst: false} $.extend(options, usercopytxt); var copy_sp = document.createElement('span'); copy_sp.id = 'ctrlcopy'; copy_sp.innerHTML = options.htmlcopytxt; return this.each(function(){ $(this).mousedown(function(){$('#ctrlcopy').remove();}); $(this).mouseup(function(){ if(window.getSelection){ //good times var slcted=window.getSelection(); var seltxt=slcted.toString(); if(!seltxt||seltxt.length<options.minlen) return; var nslct = slcted.getRangeAt(0); seltxt = nslct.cloneRange(); seltxt.collapse(options.addcopyfirst); seltxt.insertNode(copy_sp); if (!options.addcopyfirst) nslct.setEndAfter(copy_sp); slcted.removeAllRanges(); slcted.addRange(nslct); } else if(document.selection){ //bad times var slcted = document.selection; var nslct=slcted.createRange(); var seltxt=nslct.text; if (!seltxt||seltxt.length<options.minlen) return; seltxt=nslct.duplicate(); seltxt.collapse(options.addcopyfirst); seltxt.pasteHTML(copy_sp.outerHTML); if (!options.addcopyfirst) {nslct.setEndPoint("EndToEnd",seltxt); nslct.select();} } }); }); } if (wgUserName == null) { $(document).addtocopy({htmlcopytxt: '<br>Подробнее: <a href="'+window.location.href+'">'+window.location.href+'</a>'}); } $.getScript('http://s7.addthis.com/js/250/addthis_widget.js#pubid=ra-56974f7a629a6df1'); $(function(){ if( (null && typeof EnablePlusOne == 'undefined') || (wgNamespaceNumber != 0 && wgNamespaceNumber != 6 && wgNamespaceNumber != 100) || wgAction != 'view' || /(oldid|diff)=/.test(window.location) ) return; $('#firstHeading').prepend( '<div id="addthis" class="share-box addthis_toolbox addthis_default_style"></a>' + '<a class="addthis_button_livejournal at300b"></a><a class="addthis_button_twitter at300b"></a>' + '<a class="addthis_button_vk at300b"></a><a class="addthis_button_facebook at300b"></a>' + '<a class="addthis_button_compact"></a><a class="addthis_button_google_plusone"></a></div>' ); }); // Размеры версий в истории правок function returnOfTheDiffSizes(){ var classes = [ '.mw-plusminus-pos', '.mw-plusminus-neg', '.mw-plusminus-null' ] for(i=0;i<=2;i++) { $(classes[i]).each( function(i, elem) { var title = elem.title.replace(/Размер после изменения: ([0-9 ]+ байта?)/, "$1") $('<span />').text(' . . ('+title+')').insertAfter($(elem)) } ) } } if (wgAction == 'history') { returnOfTheDiffSizes() } $(function() { if(wgUserName != null) return; var $counter = "<div style=\"margin-top:0.6em\"><a href='http://www.liveinternet.ru/click' "+ "target=_blank><img src='//counter.yadro.ru/hit?t23.6;r"+ escape(document.referrer)+((typeof(screen)=="undefined")?"": ";s"+screen.width+"*"+screen.height+"*"+(screen.colorDepth? screen.colorDepth:screen.pixelDepth))+";u"+escape(document.URL)+ ";h"+escape(document.title.substring(0,80))+";"+Math.random()+ "' alt='' title='LiveInternet: number of visitors for today is"+ " shown' border='0' width='88' height='15'></a></div>"; $('#p-tb').append($counter); }); /* + ссылка «править» для нулевой секции. */ $(function(){ if( (wgNamespaceNumber != 0 && wgNamespaceNumber != 6 && wgNamespaceNumber != 100) || wgAction != 'view' || /(oldid|diff)=/.test(window.location) ) return; $('#firstHeading').append('<span class="editsection">[<a title="Править секцию: 0" href="/w/index.php?title=' + encodeURIComponent(wgPageName) + '&action=edit§ion=0">править преамбулу</a>]</span>'); $('#firstHeading .editsection').show().css('text-shadow', 'none'); });