Difference between revisions of "MediaWiki:Common.js"
Jump to navigation
Jump to search
Line 1: | Line 1: | ||
− | |||
/* Any JavaScript here will be loaded for all users on every page load. */ | /* Any JavaScript here will be loaded for all users on every page load. */ | ||
Line 19: | Line 18: | ||
var $element = $(this); | var $element = $(this); | ||
$element.addClass('copied'); | $element.addClass('copied'); | ||
− | |||
− | |||
setTimeout(function() { | setTimeout(function() { | ||
$element.removeClass('copied'); | $element.removeClass('copied'); | ||
Line 35: | Line 32: | ||
.attr('data-copy', '@warp ' + npcId) | .attr('data-copy', '@warp ' + npcId) | ||
.css('cursor', 'pointer'); | .css('cursor', 'pointer'); | ||
− | |||
− | |||
− | |||
− | |||
− | |||
} | } | ||
}); | }); | ||
} | } | ||
− | // Função para aplicar larguras e alturas aos containers | + | // Função corrigida para aplicar larguras e alturas aos containers, não às imagens |
function fixNpcContainerWidths() { | function fixNpcContainerWidths() { | ||
$('.contents-equipment.tile-halves').each(function() { | $('.contents-equipment.tile-halves').each(function() { | ||
Line 57: | Line 49: | ||
}); | }); | ||
− | // Aplicar altura aos containers de imagem | + | // Aplicar altura aos containers de imagem, não às próprias imagens |
$('.tile-top.tile-image').each(function() { | $('.tile-top.tile-image').each(function() { | ||
var $imageContainer = $(this); | var $imageContainer = $(this); | ||
− | var height = | + | var height = $imageContainer.css('--image-height'); |
if (height && height !== 'auto') { | if (height && height !== 'auto') { | ||
− | $imageContainer.css(' | + | $imageContainer.css('height', height); |
} | } | ||
}); | }); | ||
Line 170: | Line 162: | ||
} | } | ||
}); | }); | ||
− | // Função para inicializar | + | |
− | function | + | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
+ | |||
+ | |||
+ | $(document).ready(function() { | ||
+ | // Função para inicializar os containers de NPC para cópia | ||
+ | function initNpcContainerCopy() { | ||
+ | $('.contents-equipment.tile-halves').each(function() { | ||
+ | var $container = $(this); | ||
− | // | + | // Skip se já estiver inicializado |
− | $ | + | if ($container.hasClass('warp-copy')) { |
− | + | return; | |
− | + | } | |
− | // | + | // Encontre o ID do warp a partir do elemento filho |
− | $ | + | var $warpElement = $container.find('.warp-copy[data-copy^="@warp"]'); |
− | } | + | if ($warpElement.length) { |
− | }); | + | var dataCopy = $warpElement.attr('data-copy'); |
− | } | + | |
+ | // Adicione a classe e atributo ao container | ||
+ | $container.addClass('warp-copy') | ||
+ | .attr('data-copy', dataCopy); | ||
+ | } | ||
+ | }); | ||
+ | } | ||
+ | |||
+ | // Atualizar função de inicialização existente | ||
+ | function initAll() { | ||
+ | initImageCopy(); | ||
+ | fixNpcContainerWidths(); | ||
+ | initNpcContainerCopy(); // Nova função | ||
+ | } | ||
− | // | + | // Inicializar funções ao carregar |
− | + | initAll(); | |
− | |||
− | |||
− | // | + | // Inicializar ao atualizar conteúdo da wiki |
− | |||
if (typeof mw !== 'undefined' && mw.hook) { | if (typeof mw !== 'undefined' && mw.hook) { | ||
mw.hook('wikipage.content').add(function() { | mw.hook('wikipage.content').add(function() { | ||
− | + | initAll(); | |
}); | }); | ||
} | } | ||
}); | }); |
Revision as of 16:48, 9 May 2025
/* Any JavaScript here will be loaded for all users on every page load. */ $(document).ready(function() { // Função única para cópia de texto $(document).on('click', '.warp-copy', function(e) { e.preventDefault(); var textToCopy = $(this).attr('data-copy'); // Cria elemento temporário para cópia var tempInput = document.createElement('textarea'); tempInput.value = textToCopy; document.body.appendChild(tempInput); tempInput.select(); document.execCommand('copy'); document.body.removeChild(tempInput); // Adiciona classe para feedback visual var $element = $(this); $element.addClass('copied'); setTimeout(function() { $element.removeClass('copied'); }, 2000); }); // Adicionar funcionalidade às imagens dos NPCs function initImageCopy() { $('.tile-top.tile-image a').each(function() { var $link = $(this); if (!$link.hasClass('warp-copy')) { var npcId = $link.attr('href').replace('#',''); $link.addClass('warp-copy') .attr('data-copy', '@warp ' + npcId) .css('cursor', 'pointer'); } }); } // Função corrigida para aplicar larguras e alturas aos containers, não às imagens function fixNpcContainerWidths() { $('.contents-equipment.tile-halves').each(function() { var $container = $(this); var width = $container.data('width'); if (width && width > 0) { $container.css({ '--container-width': width + 'px' }); } }); // Aplicar altura aos containers de imagem, não às próprias imagens $('.tile-top.tile-image').each(function() { var $imageContainer = $(this); var height = $imageContainer.css('--image-height'); if (height && height !== 'auto') { $imageContainer.css('height', height); } }); } // Inicializar funções ao carregar e em atualizações de conteúdo initImageCopy(); fixNpcContainerWidths(); if (typeof mw !== 'undefined' && mw.hook) { mw.hook('wikipage.content').add(function() { initImageCopy(); fixNpcContainerWidths(); }); } /* Auto-expand sections when clicking anchored links */ console.log("Inicializando script para expandir seções com links âncora"); // Handle initial page load with hash if (window.location.hash) { console.log("Página carregada com hash: " + window.location.hash); setTimeout(function() { expandSectionForAnchor(window.location.hash); }, 300); } // Handle clicks on anchor links $(document).on('click', 'a[href^="#"]', function(event) { var hash = $(this).attr('href'); console.log("Clique em link âncora: " + hash); event.preventDefault(); if (history.pushState) { history.pushState(null, null, hash); } else { location.hash = hash; } expandSectionForAnchor(hash); }); function expandSectionForAnchor(hash) { console.log("Procurando e expandindo seção para âncora: " + hash); var targetElement = $(hash); if (targetElement.length) { console.log("Elemento alvo encontrado"); var collapsibleSections = targetElement.parents('.mw-collapsible.mw-collapsed'); var directCollapsible = targetElement.closest('.mw-collapsible.mw-collapsed'); if (directCollapsible.length) { collapsibleSections = collapsibleSections.add(directCollapsible); } console.log("Seções colapsáveis encontradas: " + collapsibleSections.length); if (collapsibleSections.length > 0) { collapsibleSections.each(function() { var section = $(this); console.log("Expandindo seção colapsável"); section.removeClass('mw-collapsed'); var toggleButton = section.find('.mw-collapsible-toggle').first(); if (toggleButton.length) { console.log("Clicando no botão de expansão"); toggleButton.click(); } if (section.hasClass('wikitable')) { console.log("Expandindo tabela wikitable"); section.find('tr:not(:first-child)').show(); } section.find('.mw-collapsible-content').show(); }); setTimeout(function() { scrollToTarget(targetElement); }, 400); } else { scrollToTarget(targetElement); } } else { console.log("Elemento alvo não encontrado para hash: " + hash); } } function scrollToTarget(element) { console.log("Rolando até o elemento alvo"); $('html, body').animate({ scrollTop: element.offset().top - 100 }, 200); } if (typeof mw !== 'undefined' && mw.hook) { mw.hook('wikipage.content').add(function() { console.log("Conteúdo da wiki atualizado"); if (window.location.hash) { setTimeout(function() { expandSectionForAnchor(window.location.hash); }, 300); } }); } }); $(document).ready(function() { // Função para inicializar os containers de NPC para cópia function initNpcContainerCopy() { $('.contents-equipment.tile-halves').each(function() { var $container = $(this); // Skip se já estiver inicializado if ($container.hasClass('warp-copy')) { return; } // Encontre o ID do warp a partir do elemento filho var $warpElement = $container.find('.warp-copy[data-copy^="@warp"]'); if ($warpElement.length) { var dataCopy = $warpElement.attr('data-copy'); // Adicione a classe e atributo ao container $container.addClass('warp-copy') .attr('data-copy', dataCopy); } }); } // Atualizar função de inicialização existente function initAll() { initImageCopy(); fixNpcContainerWidths(); initNpcContainerCopy(); // Nova função } // Inicializar funções ao carregar initAll(); // Inicializar ao atualizar conteúdo da wiki if (typeof mw !== 'undefined' && mw.hook) { mw.hook('wikipage.content').add(function() { initAll(); }); } });