|
|
| (One intermediate revision by the same user not shown) |
| Line 1: |
Line 1: |
| // Este pedaço bugou o stylesheet
| | /* Script para copiar navegação */ |
| // ~ Alphard
| | $(function() { |
| | | // Usa 'body' para garantir que funcione mesmo em elementos carregados dinamicamente |
| /** var tocImgHid = stylepath + '/common/images/Arr_r.png'; | | $('body').on('click', '.navi-link', function(e) { |
| var tocImgSho = stylepath + '/common/images/Arr_d.png';
| |
| | |
| function tocTree() {
| |
| mw.util.addCSS('a.toctogHidden img, a.toctogShown img, a.toctogNull img {width:12px;height:12px;} #toc li a {padding-right:3px;} a.toctogNull img {visibility:hidden;}');
| |
| | |
| var toc = document.getElementById('toc');
| |
| if(!toc) return
| |
| var li = toc.getElementsByTagName('li');
| |
| for(var i=0;i<li.length;i++) {
| |
| var cul = li[i].getElementsByTagName('ul');
| |
| var a = document.createElement('a');
| |
| if(cul.length == 0) {
| |
| a.setAttribute('class','toctogNull');
| |
| } else {
| |
| a.setAttribute('class','toctogShown');
| |
| a.setAttribute('id','toctog-a-' + i );
| |
| a.setAttribute('href','javascript:tocTreeToggle("' + i + '");');
| |
| }
| |
| var img = document.createElement('img');
| |
| img.setAttribute('src',tocImgHid);
| |
| img.setAttribute('id','toctog-i-' + i );
| |
| a.appendChild(img);
| |
| li[i].insertBefore(a,li[i].firstChild);
| |
| if(cul.length != 0) tocTreeToggle(i)
| |
| }
| |
| }
| |
| if(wgNamespaceNumber != -1 && wgArticleId != 0)
| |
| $(tocTree)
| |
| | |
| function tocTreeToggle(id) { | |
| var a = document.getElementById('toctog-a-' + id);
| |
| var img = document.getElementById('toctog-i-' + id);
| |
| var cul = a.parentNode.getElementsByTagName('ul');
| |
| var disp;
| |
| if(a.getAttribute('class') == 'toctogShown') {
| |
| disp = 'none'; | |
| a.setAttribute('class','toctogHidden'); | |
| img.setAttribute('src',tocImgHid);
| |
| } else {
| |
| disp = 'block';
| |
| a.setAttribute('class','toctogShown');
| |
| img.setAttribute('src',tocImgSho);
| |
| }
| |
| for(var j=0;j<cul.length;j++) {
| |
| if(cul[j].parentNode == a.parentNode) cul[j].style.display = disp
| |
| }
| |
| } */
| |
| | |
| /**
| |
| * Collapsible tables *********************************************************
| |
| *
| |
| * Description: Allows tables to be collapsed, showing only the header. See
| |
| * [[Wikipedia:NavFrame]].
| |
| * Maintainers: [[User:R. Koot]]
| |
| */
| |
| | |
| var autoCollapse = 2;
| |
| var collapseCaption = 'hide';
| |
| var expandCaption = 'show';
| |
| | |
| window.collapseTable = function ( tableIndex ) {
| |
| var Button = document.getElementById( 'collapseButton' + tableIndex );
| |
| var Table = document.getElementById( 'collapsibleTable' + tableIndex );
| |
| | |
| if ( !Table || !Button ) {
| |
| return false;
| |
| }
| |
| | |
| var Rows = Table.rows;
| |
| var i;
| |
| | |
| if ( Button.firstChild.data === collapseCaption ) {
| |
| for ( i = 1; i < Rows.length; i++ ) {
| |
| Rows[i].style.display = 'none';
| |
| }
| |
| Button.firstChild.data = expandCaption;
| |
| } else {
| |
| for ( i = 1; i < Rows.length; i++ ) {
| |
| Rows[i].style.display = Rows[0].style.display;
| |
| }
| |
| Button.firstChild.data = collapseCaption;
| |
| }
| |
| };
| |
| | |
| function createCollapseButtons() {
| |
| var tableIndex = 0;
| |
| var NavigationBoxes = {};
| |
| var Tables = document.getElementsByTagName( 'table' );
| |
| var i;
| |
| | |
| function handleButtonLink( index, e ) {
| |
| window.collapseTable( index );
| |
| e.preventDefault(); | | e.preventDefault(); |
| }
| | var $this = $(this); |
| | | var map = $this.data('map'); |
| for ( i = 0; i < Tables.length; i++ ) {
| | var x = $this.data('x'); |
| if ( $( Tables[i] ).hasClass( 'collapsible' ) ) { | | var y = $this.data('y'); |
| | | |
| /* only add button and increment count if there is a header row to work with */
| | // Remove espaços extras caso existam |
| var HeaderRow = Tables[i].getElementsByTagName( 'tr' )[0];
| | if(map) map = map.trim(); |
| if ( !HeaderRow ) continue;
| | |
| var Header = HeaderRow.getElementsByTagName( 'th' )[0];
| | var command = '/navi ' + map + ' ' + x + '/' + y; |
| if ( !Header ) continue;
| | |
| | | // Cria elemento invisível para copiar |
| NavigationBoxes[ tableIndex ] = Tables[i];
| | var $temp = $("<input>"); |
| Tables[i].setAttribute( 'id', 'collapsibleTable' + tableIndex );
| | $("body").append($temp); |
| | | $temp.val(command).select(); |
| var Button = document.createElement( 'span' );
| | document.execCommand("copy"); |
| var ButtonLink = document.createElement( 'a' );
| | $temp.remove(); |
| var ButtonText = document.createTextNode( collapseCaption );
| | |
| | | // Feedback visual |
| Button.className = 'collapseButton'; /* Styles are declared in Common.css */
| | var $msg = $this.find('.navi-msg'); |
| | | $msg.show().fadeOut(2000); |
| ButtonLink.style.color = Header.style.color;
| | }); |
| ButtonLink.setAttribute( 'id', 'collapseButton' + tableIndex );
| |
| ButtonLink.setAttribute( 'href', '#' );
| |
| $( ButtonLink ).on( 'click', $.proxy( handleButtonLink, ButtonLink, tableIndex ) );
| |
| ButtonLink.appendChild( ButtonText );
| |
| | |
| Button.appendChild( document.createTextNode( '[' ) );
| |
| Button.appendChild( ButtonLink );
| |
| Button.appendChild( document.createTextNode( ']' ) );
| |
| | |
| Header.insertBefore( Button, Header.firstChild );
| |
| tableIndex++;
| |
| }
| |
| }
| |
| | |
| for ( i = 0; i < tableIndex; i++ ) {
| |
| if ( $( NavigationBoxes[i] ).hasClass( 'collapsed' ) || ( tableIndex >= autoCollapse && $( NavigationBoxes[i] ).hasClass( 'autocollapse' ) ) ) { | |
| window.collapseTable( i );
| |
| } | |
| else if ( $( NavigationBoxes[i] ).hasClass ( 'innercollapse' ) ) { | |
| var element = NavigationBoxes[i];
| |
| while ((element = element.parentNode)) {
| |
| if ( $( element ).hasClass( 'outercollapse' ) ) {
| |
| window.collapseTable ( i );
| |
| break;
| |
| }
| |
| }
| |
| }
| |
| }
| |
| }
| |
| | |
| $( createCollapseButtons );
| |
|
| |
| /** Test if an element has a certain class **************************************
| |
| *
| |
| * Description: Uses regular expressions and caching for better performance.
| |
| * Maintainers: [[User:Mike Dillon]], [[User:R. Koot]], [[User:SG]]
| |
| */
| |
|
| |
| var hasClass = (function() {
| |
| var reCache = {};
| |
| return function( element, className ) {
| |
| return ( reCache[className] ? reCache[className] : ( reCache[className] = new RegExp( "(?:\\s|^)" + className + "(?:\\s|$)" ) ) ).test( element.className );
| |
| };
| |
| })();
| |
| | |
| /** Hideable notes ********************************************************* | |
| * This is based off of code from Wikipedia's Common.js (http://en.wikipedia.org/wiki/MediaWiki:Common.js)
| |
| */
| |
|
| |
| function showNotes( spanIndex )
| |
| {
| |
| var Button = document.getElementById( "showNoteLink" + spanIndex );
| |
| var Span = document.getElementById( "showNotes" + spanIndex );
| |
|
| |
| if (!Span || !Button)
| |
| {
| |
| return false;
| |
| }
| |
|
| |
| if (Button.firstChild.data == "[show]")
| |
| {
| |
| Span.style.display = "inline";
| |
| Button.firstChild.data = " [hide]"; | |
| }
| |
| else
| |
| {
| |
| Span.style.display = "none"; | |
| Button.firstChild.data = "[show]"; | |
| }
| |
| }
| |
|
| |
| function createShowNotesLinks()
| |
| {
| |
| var spanIndex = 0;
| |
| var Spans = document.getElementsByTagName( "span" );
| |
| var CurrentSpan = new Object();
| |
|
| |
| for ( var i = 0; i < Spans.length; i++ )
| |
| {
| |
| if ( hasClass( Spans[i], "hiddenNotes" ) ) | |
| {
| |
| CurrentSpan = Spans[i];
| |
| CurrentSpan.setAttribute( "id", "showNotes" + spanIndex );
| |
|
| |
| var Button = document.createElement( "span" );
| |
| var ButtonLink = document.createElement( "a" );
| |
| var ButtonText = document.createTextNode( "[show]" );
| |
|
| |
| ButtonLink.setAttribute( "id", "showNoteLink" + spanIndex );
| |
| ButtonLink.setAttribute( "href", "javascript:" );
| |
| addHandler( ButtonLink, "click", new Function( "evt", "showNotes(" + spanIndex + " ); return killEvt( evt );") );
| |
| ButtonLink.appendChild( ButtonText );
| |
|
| |
| Button.appendChild(document.createTextNode( " " ));
| |
| Button.appendChild(ButtonLink);
| |
|
| |
| CurrentSpan.parentNode.insertBefore( Button, CurrentSpan.nextSibling );
| |
| CurrentSpan.style.display="none";
| |
|
| |
| spanIndex++;
| |
| } | |
| }
| |
| }
| |
|
| |
| $( createShowNotesLinks ); | |
| | |
| /* Any JavaScript here will be loaded for all users on every page load. */
| |
|
| |
|
| |
| /* Test if an element has a certain class **************************************
| |
| * Note: this is straight out of Wikipedia's Common.js (http://en.wikipedia.org/wiki/MediaWiki:Common.js)
| |
| */
| |
|
| |
| var hasClass = (function () {
| |
| var reCache = {};
| |
| return function (element, className) {
| |
| return (reCache[className] ? reCache[className] : (reCache[className] = new RegExp("(?:\\s|^)" + className + "(?:\\s|$)"))).test(element.className); | |
| };
| |
| })();
| |
| | |
| | |
| // Navi Copy JQuery Code by Kaddy! | |
| $('.navi-copy').each(function(index, element) { | |
| if ($("#navi-copy-textarea").attr('exists') != "true") {
| |
| txtdiv = '<textarea style="height:1px;width:1px; position:absolute;left:-1000px;" id="navi-copy-textarea" exists="true">Filler Text</textarea><style>.navi-copy-text { cursor:pointer; color:#006400; padding:1px; display:inline-block; } .navi-copy-text:hover { color:#c1a1f1; } .navi-copied { text-align:center; border:1px dotted #2899e8; border-radius:3px; color:#006400; display:inline-block; } .navi-copy { display:inline-block; } </style>';
| |
| $("body").append(txtdiv);
| |
| }
| |
| var map = $(element).children().get(0).innerHTML;
| |
| var x = $(element).children().get(1).innerHTML;
| |
| var y = $(element).children().get(2).innerHTML;
| |
| var newhtml = "<div class=\"navi-copy-text\" onclick=\"CopyNaviLink(this, '"+map+"','"+x+"','"+y+"');\">("+map+" "+x+", "+y+")</div><div class=\"navi-copied\" style=\"display:none;\">Copiado</div>";
| |
| $(element).html(newhtml);
| |
| }); | | }); |
| function CopyNaviLink(ele, map, x, y) {
| |
| element = $(ele);
| |
| sibling = element.siblings();
| |
| width = element.width();
| |
| height = element.height()+0;
| |
| sibling.css('width',width);
| |
| sibling.css('height',height);
| |
| element.css('display','none');
| |
| sibling.css('display','inline-block');
| |
| setTimeout(function() {
| |
| sibling.fadeOut().delay(300).css('display','none');
| |
| element.css('display','inline-block');
| |
| }, 1400);
| |
| var ClipBoardText = "/navi "+map+" "+x+"/"+y;
| |
| var textarea = document.getElementById('navi-copy-textarea');
| |
| $('#navi-copy-textarea').text(ClipBoardText);
| |
| $("#navi-copy-textarea").select();
| |
| document.execCommand('copy');
| |
| }
| |