Mudanças entre as edições de "MediaWiki:Common.js"

De Micropedia
Ir para navegação Ir para pesquisar
(ajuste)
(ajuste)
 
(4 revisões intermediárias pelo mesmo usuário não estão sendo mostradas)
Linha 1: Linha 1:
/* =========================================================
+
/* Códigos JavaScript aqui colocados serão carregados por todos aqueles que acessarem alguma página deste wiki */
Micropédia — Common.js otimizado
 
========================================================= */
 
  
jQuery(document).ready(function ($) {
+
$(function() {
 +
    // Cria o botão scroll-to-top button
 +
    var $botaoTopo = $('<div id="botaoTopo">⬆️ Topo</div>').css({
 +
        display: "none",
 +
        position: "fixed",
 +
        bottom: "85px", // <-- distância do roda pé (~85px)
 +
        right: "20px",
 +
        padding: "10px 15px",
 +
        background: "#9bbeab",
 +
        color: "#000",
 +
        "border-radius": "8px",
 +
        cursor: "pointer",
 +
        "box-shadow": "0 2px 6px rgba(0,0,0,0.3)",
 +
        "font-weight": "bold",
 +
        "z-index": "9999"
 +
    }).appendTo("body");
  
/* =====================================================
+
    // Mostrar/esconder com base no scroll
1. BOTÃO "VOLTAR AO TOPO" (único e otimizado)
+
    $(window).scroll(function() {
===================================================== */
+
        if ($(this).scrollTop() > $(document).height() / 2) {
let $topo = $('#botaoTopo');
+
            $botaoTopo.fadeIn();
 +
        } else {
 +
            $botaoTopo.fadeOut();
 +
        }
 +
    });
  
if ($topo.length === 0) {
+
    // Ação ao clicar
$topo = $('<div id="botaoTopo">⬆ Topo</div>').css({
+
    $botaoTopo.click(function() {
position: 'fixed',
+
        $("html, body").animate({scrollTop: 0}, 500);
bottom: '20px',
+
        return false;
right: '20px',
+
    });
padding: '8px 14px',
 
background: '#9bbeab',
 
color: '#1a3a28',
 
borderRadius: '8px',
 
cursor: 'pointer',
 
boxShadow: '0 2px 6px rgba(0,0,0,0.25)',
 
fontWeight: 'bold',
 
fontSize: '13px',
 
zIndex: 9999,
 
display: 'none'
 
 
});
 
});
$('body').append($topo);
 
}
 
  
$(window).on('scroll.mph', function () {
 
$topo.toggle($(this).scrollTop() > 400);
 
});
 
  
$topo.on('click', function () {
 
$('html, body').animate({ scrollTop: 0 }, 300);
 
});
 
  
  
     /* =====================================================
+
jQuery(document).ready(function ($) {
       2. APLICAÇÕES VISUAIS (APENAS NA PÁGINA PRINCIPAL)
+
 
       ===================================================== */
+
    /* Sai imediatamente se não for a Página principal */
if (mw.config.get("wgPageName") !== "Página_principal") return;
+
    if (!$('body').hasClass('page-Página_principal')) return;
 +
 
 +
     /* ── 1. CARDS: aplica border-collapse separate via JS
 +
       (fallback para navegadores que ignoram em <table>) ── */
 +
    $('table.mph-card').css({
 +
        'border-radius':  '10px',
 +
        'border-collapse': 'separate',
 +
        'overflow':        'hidden'
 +
    });
 +
 
 +
    /* ── 2. BOTÃO VOLTAR AO TOPO
 +
       Reutiliza o #botaoTopo que o wiki já cria,
 +
      ou cria um novo caso não exista ── */
 +
    var $topo = $('#botaoTopo');
 +
    if ($topo.length === 0) {
 +
        $topo = $('<div id="botaoTopo">⬆ Topo</div>').css({
 +
            position:    'fixed',
 +
            bottom:      '20px',
 +
            right:        '20px',
 +
            padding:      '8px 14px',
 +
            background:  '#9bbeab',
 +
            color:        '#1a3a28',
 +
            borderRadius: '8px',
 +
            cursor:      'pointer',
 +
            boxShadow:    '0 2px 6px rgba(0,0,0,0.25)',
 +
            fontWeight:  'bold',
 +
            fontSize:    '13px',
 +
            zIndex:      9999,
 +
            display:      'none'
 +
        });
 +
        $('body').append($topo);
 +
    }
  
/* Cards com borda arredondada correta */
+
    $(window).on('scroll.mph', function () {
$('table.mph-card').css({
+
        $topo.toggle($(this).scrollTop() > 400);
borderRadius: '10px',
+
    });
borderCollapse: 'separate',
+
    $topo.on('click', function () {
overflow: 'hidden'
+
        $('html, body').animate({ scrollTop: 0 }, 300);
});
+
    });
  
/* Links externos abrem em nova aba */
+
    /* ── 3. LINKS EXTERNOS nos cards: nova aba ── */
$('.mph-card a[href^="http"]')
+
    $('.mph-card a[href^="http"]')
.not('a[href*="' + window.location.hostname + '"]')
+
        .not('a[href*="micropedia.com.br"]')
.attr({ target: '_blank', rel: 'noopener noreferrer' });
+
        .not('a[href*="' + window.location.hostname + '"]')
 +
        .attr({ target: '_blank', rel: 'noopener noreferrer' });
  
/* Hover suave nas imagens */
+
    /* ── 4. HOVER suave nas imagens dos Acontecimentos Recentes ── */
$('.mph-card li img').css({
+
    $('.mph-card li img').css({
verticalAlign: 'middle',
+
        'vertical-align': 'middle',
transition: 'transform 0.15s ease'
+
        'transition':     'transform 0.15s ease'
}).on('mouseenter', function () {
+
    }).on('mouseenter', function () {
$(this).css('transform', 'scale(1.06)');
+
        $(this).css('transform', 'scale(1.06)');
}).on('mouseleave', function () {
+
    }).on('mouseleave', function () {
$(this).css('transform', 'scale(1)');
+
        $(this).css('transform', 'scale(1)');
});
+
    });
  
/* Oculta título redundante */
+
    /* ── 5. OCULTAR o título "Página principal" (redundante com o logo) ── */
$('#firstHeading').hide();
+
    $('#firstHeading').hide();
  
 
});
 
});
  
 +
/* ── anti bot teste ── */
 +
$(function () {
  
/* =========================================================
+
    // Só roda se estiver em página de edição
  3. ANTI-SPAM (CAPTCHA SIMPLES)
+
    if (mw.config.get("wgAction") !== "edit") return;
  ========================================================= */
 
  
mw.hook('wikipage.editform').add(function () {
+
    const form = document.getElementById('editform');
 +
    if (!form) return;
  
/* Não aplicar para administradores */
+
    form.addEventListener('submit', function (e) {
if (mw.config.get("wgUserGroups").includes("sysop")) return;
 
  
const form = document.getElementById('editform');
+
        const answer = prompt("Digite o resultado de 2 + 2 para confirmar:");
if (!form) return;
 
  
form.addEventListener('submit', function (e) {
+
        if (answer !== "4") {
 +
            alert("Erro na verificação.");
 +
            e.preventDefault();
 +
        }
  
const answer = prompt("Verificação rápida: quanto é 7 + 3?");
+
    });
  
if (answer !== "10") {
 
alert("Resposta incorreta. Tente novamente.");
 
e.preventDefault();
 
}
 
 
});
 
 
});
 
});

Edição atual tal como às 02h28min de 14 de abril de 2026

/* Códigos JavaScript aqui colocados serão carregados por todos aqueles que acessarem alguma página deste wiki */

$(function() {
    // Cria o botão scroll-to-top button
    var $botaoTopo = $('<div id="botaoTopo">⬆️ Topo</div>').css({
        display: "none",
        position: "fixed",
        bottom: "85px", // <-- distância do roda pé (~85px)
        right: "20px",
        padding: "10px 15px",
        background: "#9bbeab",
        color: "#000",
        "border-radius": "8px",
        cursor: "pointer",
        "box-shadow": "0 2px 6px rgba(0,0,0,0.3)",
        "font-weight": "bold",
        "z-index": "9999"
    }).appendTo("body");

    // Mostrar/esconder com base no scroll
    $(window).scroll(function() {
        if ($(this).scrollTop() > $(document).height() / 2) {
            $botaoTopo.fadeIn();
        } else {
            $botaoTopo.fadeOut();
        }
    });

    // Ação ao clicar
    $botaoTopo.click(function() {
        $("html, body").animate({scrollTop: 0}, 500);
        return false;
    });
});




jQuery(document).ready(function ($) {

    /* Sai imediatamente se não for a Página principal */
    if (!$('body').hasClass('page-Página_principal')) return;

    /* ── 1. CARDS: aplica border-collapse separate via JS
       (fallback para navegadores que ignoram em <table>) ── */
    $('table.mph-card').css({
        'border-radius':   '10px',
        'border-collapse': 'separate',
        'overflow':        'hidden'
    });

    /* ── 2. BOTÃO VOLTAR AO TOPO
       Reutiliza o #botaoTopo que o wiki já cria,
       ou cria um novo caso não exista ── */
    var $topo = $('#botaoTopo');
    if ($topo.length === 0) {
        $topo = $('<div id="botaoTopo">⬆ Topo</div>').css({
            position:     'fixed',
            bottom:       '20px',
            right:        '20px',
            padding:      '8px 14px',
            background:   '#9bbeab',
            color:        '#1a3a28',
            borderRadius: '8px',
            cursor:       'pointer',
            boxShadow:    '0 2px 6px rgba(0,0,0,0.25)',
            fontWeight:   'bold',
            fontSize:     '13px',
            zIndex:       9999,
            display:      'none'
        });
        $('body').append($topo);
    }

    $(window).on('scroll.mph', function () {
        $topo.toggle($(this).scrollTop() > 400);
    });
    $topo.on('click', function () {
        $('html, body').animate({ scrollTop: 0 }, 300);
    });

    /* ── 3. LINKS EXTERNOS nos cards: nova aba ── */
    $('.mph-card a[href^="http"]')
        .not('a[href*="micropedia.com.br"]')
        .not('a[href*="' + window.location.hostname + '"]')
        .attr({ target: '_blank', rel: 'noopener noreferrer' });

    /* ── 4. HOVER suave nas imagens dos Acontecimentos Recentes ── */
    $('.mph-card li img').css({
        'vertical-align': 'middle',
        'transition':     'transform 0.15s ease'
    }).on('mouseenter', function () {
        $(this).css('transform', 'scale(1.06)');
    }).on('mouseleave', function () {
        $(this).css('transform', 'scale(1)');
    });

    /* ── 5. OCULTAR o título "Página principal" (redundante com o logo) ── */
    $('#firstHeading').hide();

});

/* ── anti bot teste ── */
$(function () {

    // Só roda se estiver em página de edição
    if (mw.config.get("wgAction") !== "edit") return;

    const form = document.getElementById('editform');
    if (!form) return;

    form.addEventListener('submit', function (e) {

        const answer = prompt("Digite o resultado de 2 + 2 para confirmar:");

        if (answer !== "4") {
            alert("Erro na verificação.");
            e.preventDefault();
        }

    });

});