Difference between revisions of "MediaWiki:Common.js"
Jump to navigation
Jump to search
| (73 intermediate revisions by the same user not shown) | |||
| Line 2: | Line 2: | ||
$(document).ready(function() { | $(document).ready(function() { | ||
| − | $(document).on('click', '.warp-copy', function() { | + | // Função única para cópia de texto |
| + | $(document).on('click', '.warp-copy', function(e) { | ||
| + | e.preventDefault(); | ||
var textToCopy = $(this).attr('data-copy'); | var textToCopy = $(this).attr('data-copy'); | ||
| + | // Cria elemento temporário para cópia | ||
var tempInput = document.createElement('textarea'); | var tempInput = document.createElement('textarea'); | ||
tempInput.value = textToCopy; | tempInput.value = textToCopy; | ||
| Line 12: | Line 15: | ||
document.body.removeChild(tempInput); | document.body.removeChild(tempInput); | ||
| − | var | + | // Adiciona classe para feedback visual |
| − | $ | + | var $element = $(this); |
| − | + | $element.addClass('copied'); | |
setTimeout(function() { | setTimeout(function() { | ||
| − | $ | + | $element.removeClass('copied'); |
| − | }, | + | }, 2000); |
}); | }); | ||
| − | |||
| − | /* Auto-expand sections when clicking anchored links */ | + | // 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) { | if (window.location.hash) { | ||
| − | // | + | console.log("Página carregada com hash: " + window.location.hash); |
| − | var | + | 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) { | if (targetElement.length) { | ||
| − | + | console.log("Elemento alvo encontrado"); | |
| − | var | + | |
| + | var collapsibleSections = targetElement.parents('.mw-collapsible.mw-collapsed'); | ||
| + | var directCollapsible = targetElement.closest('.mw-collapsible.mw-collapsed'); | ||
| − | + | if (directCollapsible.length) { | |
| − | if ( | + | 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() { | setTimeout(function() { | ||
| − | $('html, body').animate({ | + | 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); | }, 300); | ||
} | } | ||
| + | }); | ||
| + | } | ||
| + | }); | ||
| + | |||
| + | /* Código JavaScript limpo para os NPCs - MANTER APENAS ESTE BLOCO */ | ||
| + | $(document).ready(function() { | ||
| + | // Manipulador de clique direto nos containers NPC | ||
| + | $(document).on('click', '.contents-equipment.tile-halves', function(e) { | ||
| + | // Previne comportamento padrão apenas se não for um link | ||
| + | if (!$(e.target).is('a') && !$(e.target).parents('a').length) { | ||
| + | e.preventDefault(); | ||
| + | } | ||
| + | |||
| + | // Encontra o comando warp dentro do container | ||
| + | var $warpElement = $(this).find('.warp-copy[data-copy^="@warp"]'); | ||
| + | |||
| + | if ($warpElement.length) { | ||
| + | var warpCommand = $warpElement.attr('data-copy'); | ||
| + | |||
| + | // Copia o texto para a área de transferência | ||
| + | var tempInput = document.createElement('textarea'); | ||
| + | tempInput.value = warpCommand; | ||
| + | document.body.appendChild(tempInput); | ||
| + | tempInput.select(); | ||
| + | document.execCommand('copy'); | ||
| + | document.body.removeChild(tempInput); | ||
| + | |||
| + | // Adiciona classe para feedback visual | ||
| + | var $container = $(this); | ||
| + | $container.addClass('npc-copied'); | ||
| + | |||
| + | // Remove a classe após 2 segundos | ||
| + | setTimeout(function() { | ||
| + | $container.removeClass('npc-copied'); | ||
| + | }, 2000); | ||
} | } | ||
| + | }); | ||
| + | |||
| + | // Inicializa na carga da página e em atualizações | ||
| + | if (typeof mw !== 'undefined' && mw.hook) { | ||
| + | mw.hook('wikipage.content').add(function() { | ||
| + | console.log("Inicializando comportamento de cópia nos NPCs"); | ||
| + | }); | ||
} | } | ||
}); | }); | ||
Latest revision as of 17:01, 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);
}
});
}
});
/* Código JavaScript limpo para os NPCs - MANTER APENAS ESTE BLOCO */
$(document).ready(function() {
// Manipulador de clique direto nos containers NPC
$(document).on('click', '.contents-equipment.tile-halves', function(e) {
// Previne comportamento padrão apenas se não for um link
if (!$(e.target).is('a') && !$(e.target).parents('a').length) {
e.preventDefault();
}
// Encontra o comando warp dentro do container
var $warpElement = $(this).find('.warp-copy[data-copy^="@warp"]');
if ($warpElement.length) {
var warpCommand = $warpElement.attr('data-copy');
// Copia o texto para a área de transferência
var tempInput = document.createElement('textarea');
tempInput.value = warpCommand;
document.body.appendChild(tempInput);
tempInput.select();
document.execCommand('copy');
document.body.removeChild(tempInput);
// Adiciona classe para feedback visual
var $container = $(this);
$container.addClass('npc-copied');
// Remove a classe após 2 segundos
setTimeout(function() {
$container.removeClass('npc-copied');
}, 2000);
}
});
// Inicializa na carga da página e em atualizações
if (typeof mw !== 'undefined' && mw.hook) {
mw.hook('wikipage.content').add(function() {
console.log("Inicializando comportamento de cópia nos NPCs");
});
}
});