MediaWiki:Common.js: mudanças entre as edições
Ir para navegação
Ir para pesquisar
Sem resumo de edição |
Sem resumo de edição |
||
| Linha 111: | Linha 111: | ||
}); | }); | ||
/* --- Tradutor | /* --- Tradutor Integrado com a API Oficial do MediaWiki --- */ | ||
mw.loader.using(['mediawiki.util']).then(function() { | |||
var defaultLang = 'pt'; | var defaultLang = 'pt'; | ||
// 1. | // 1. Carrega o Google Translate invisível | ||
$('body').append('<div id="google_translate_element" style="display:none;"></div>'); | $('body').append('<div id="google_translate_element" style="display:none;"></div>'); | ||
window.googleTranslateElementInit = function() { | window.googleTranslateElementInit = function() { | ||
new google.translate.TranslateElement({ | new google.translate.TranslateElement({ | ||
pageLanguage: defaultLang, | pageLanguage: defaultLang, | ||
includedLanguages: 'pt,en,es,pl', | includedLanguages: 'pt,en,es,pl', | ||
autoDisplay: false | autoDisplay: false | ||
}, 'google_translate_element'); | }, 'google_translate_element'); | ||
| Linha 200: | Linha 127: | ||
$.getScript("https://translate.google.com/translate_a/element.js?cb=googleTranslateElementInit"); | $.getScript("https://translate.google.com/translate_a/element.js?cb=googleTranslateElementInit"); | ||
// 2. | // 2. Adiciona os links no menu "Navegação" (p-navigation) usando a API nativa | ||
// Se preferir no menu "Ferramentas", troque 'p-navigation' por 'p-tb' | |||
var ptLink = mw.util.addPortletLink('p-navigation', '#', 'Português (Brasil)', 'n-lang-pt', 'Mudar para Português'); | |||
var enLink = mw.util.addPortletLink('p-navigation', '#', 'English', 'n-lang-en', 'Change to English'); | |||
var esLink = mw.util.addPortletLink('p-navigation', '#', 'Español', 'n-lang-es', 'Cambiar a Español'); | |||
var plLink = mw.util.addPortletLink('p-navigation', '#', 'Polski', 'n-lang-pl', 'Zmień na Polski'); | |||
// 3. | // 3. Prepara os links para o script de tradução | ||
$(ptLink).find('a').addClass('lang-btn').attr('data-lang', 'pt'); | |||
$(enLink).find('a').addClass('lang-btn').attr('data-lang', 'en'); | |||
$(' | $(esLink).find('a').addClass('lang-btn').attr('data-lang', 'es'); | ||
$(plLink).find('a').addClass('lang-btn').attr('data-lang', 'pl'); | |||
// 4. Lógica para | // 4. Lógica de clique para traduzir | ||
$(document).on('click', '.lang-btn', function(e) { | $(document).on('click', '.lang-btn', function(e) { | ||
e.preventDefault(); | e.preventDefault(); | ||
var targetLang = $(this). | var targetLang = $(this).attr('data-lang'); | ||
var select = document.querySelector('.goog-te-combo'); | var select = document.querySelector('.goog-te-combo'); | ||
// | // Retorna ao original (PT) | ||
if (targetLang === defaultLang) { | if (targetLang === defaultLang) { | ||
document.cookie = "googtrans=; expires=Thu, 01 Jan 1970 00:00:00 UTC; path=/;"; | document.cookie = "googtrans=; expires=Thu, 01 Jan 1970 00:00:00 UTC; path=/;"; | ||
| Linha 233: | Linha 154: | ||
} | } | ||
// Aciona | // Aciona o Google Translate | ||
if (select) { | if (select) { | ||
select.value = targetLang; | select.value = targetLang; | ||
select.dispatchEvent(new Event('change')); | select.dispatchEvent(new Event('change')); | ||
} else { | } else { | ||
alert('O | alert('O tradutor está carregando. Aguarde um segundo e tente novamente.'); | ||
} | } | ||
}); | }); | ||
}); | }); | ||
Edição das 12h37min de 7 de março de 2026
var coll1 = document.getElementsByClassName("collapsible-battle-pass");
var coll2 = document.getElementsByClassName("collapsible-pokemon");
function toggleContent(clickedButton, contentToToggle) {
var allContents = document.getElementsByClassName("content");
for (var j = 0; j < allContents.length; j++) {
allContents[j].style.maxHeight = null;
}
var allButtons = document.getElementsByClassName("collapsible-battle-pass");
for (var k = 0; k < allButtons.length; k++) {
allButtons[k].classList.remove("active");
}
allButtons = document.getElementsByClassName("collapsible-pokemon");
for (var k = 0; k < allButtons.length; k++) {
allButtons[k].classList.remove("active");
}
if (contentToToggle.style.maxHeight) {
contentToToggle.style.maxHeight = null;
} else {
contentToToggle.style.maxHeight = contentToToggle.scrollHeight + "px";
}
clickedButton.classList.add("active");
}
for (var i = 0; i < coll1.length; i++) {
coll1[i].addEventListener("click", function() {
var content = this.nextElementSibling;
toggleContent(this, content);
});
}
for (var i = 0; i < coll2.length; i++) {
coll2[i].addEventListener("click", function() {
var content = this.nextElementSibling;
toggleContent(this, content);
});
}
/* Pokedex */
var coll3 = document.getElementsByClassName("collapsible-pokedex");
function toggleContent(clickedButton, contentToToggle) {
var allContents = document.getElementsByClassName("content");
for (var j = 0; j < allContents.length; j++) {
allContents[j].style.maxHeight = null;
}
var allButtons2 = document.getElementsByClassName("collapsible-pokedex");
for (var k = 0; k < allButtons2.length; k++) {
allButtons2[k].classList.remove("active");
}
if (contentToToggle.style.maxHeight) {
contentToToggle.style.maxHeight = null;
} else {
contentToToggle.style.maxHeight = contentToToggle.scrollHeight + "px";
}
clickedButton.classList.add("active");
}
for (var i = 0; i < coll3.length; i++) {
coll3[i].addEventListener("click", function() {
var content = this.nextElementSibling;
toggleContent(this, content);
});
}
/* Pokedex */
function toggleShinyList() {
var shinyList = document.getElementById("shiny-list");
if (shinyList.style.display === "none" || shinyList.style.display === "") {
shinyList.style.display = "block";
} else {
shinyList.style.display = "flex";
}
}
mw.loader.using('jquery', function () {
$(document).ready(function () {
var isAscending = true;
var $sortButton = $('<div class="sort-button" style="width: 60px; height: 50px; background-image: url(https://wiki.otpokemon.com/images/9/92/O-c.png); background-position: center; background-repeat: no-repeat; background-size: cover; border-radius: 3px; cursor: pointer; float: right; margin-right: 0.5%;margin-top: -50px;"></div>');
$('.square-div-shiny').before($sortButton);
$sortButton.on('click', function () {
var $container = $('.square-div-shiny');
var $boxes = $container.children('.square-box-shiny');
$boxes.sort(function (a, b) {
var numA = parseInt($(a).find('.square-name-shiny').text().match(/\d+/)[0], 10);
var numB = parseInt($(b).find('.square-name-shiny').text().match(/\d+/)[0], 10);
return isAscending ? numA - numB : numB - numA;
});
$container.append($boxes);
isAscending = !isAscending;
var newImage = isAscending
? 'https://wiki.otpokemon.com/images/e/e2/O-d.png'
: 'https://wiki.otpokemon.com/images/9/92/O-c.png';
$sortButton.css('background-image', 'url(' + newImage + ')');
});
});
});
/* --- Tradutor Integrado com a API Oficial do MediaWiki --- */
mw.loader.using(['mediawiki.util']).then(function() {
var defaultLang = 'pt';
// 1. Carrega o Google Translate invisível
$('body').append('<div id="google_translate_element" style="display:none;"></div>');
window.googleTranslateElementInit = function() {
new google.translate.TranslateElement({
pageLanguage: defaultLang,
includedLanguages: 'pt,en,es,pl',
autoDisplay: false
}, 'google_translate_element');
};
$.getScript("https://translate.google.com/translate_a/element.js?cb=googleTranslateElementInit");
// 2. Adiciona os links no menu "Navegação" (p-navigation) usando a API nativa
// Se preferir no menu "Ferramentas", troque 'p-navigation' por 'p-tb'
var ptLink = mw.util.addPortletLink('p-navigation', '#', 'Português (Brasil)', 'n-lang-pt', 'Mudar para Português');
var enLink = mw.util.addPortletLink('p-navigation', '#', 'English', 'n-lang-en', 'Change to English');
var esLink = mw.util.addPortletLink('p-navigation', '#', 'Español', 'n-lang-es', 'Cambiar a Español');
var plLink = mw.util.addPortletLink('p-navigation', '#', 'Polski', 'n-lang-pl', 'Zmień na Polski');
// 3. Prepara os links para o script de tradução
$(ptLink).find('a').addClass('lang-btn').attr('data-lang', 'pt');
$(enLink).find('a').addClass('lang-btn').attr('data-lang', 'en');
$(esLink).find('a').addClass('lang-btn').attr('data-lang', 'es');
$(plLink).find('a').addClass('lang-btn').attr('data-lang', 'pl');
// 4. Lógica de clique para traduzir
$(document).on('click', '.lang-btn', function(e) {
e.preventDefault();
var targetLang = $(this).attr('data-lang');
var select = document.querySelector('.goog-te-combo');
// Retorna ao original (PT)
if (targetLang === defaultLang) {
document.cookie = "googtrans=; expires=Thu, 01 Jan 1970 00:00:00 UTC; path=/;";
document.cookie = "googtrans=; expires=Thu, 01 Jan 1970 00:00:00 UTC; path=/; domain=" + location.hostname + ";";
location.reload();
return;
}
// Aciona o Google Translate
if (select) {
select.value = targetLang;
select.dispatchEvent(new Event('change'));
} else {
alert('O tradutor está carregando. Aguarde um segundo e tente novamente.');
}
});
});