Mudanças entre as edições de "Widget:VisnoTeste"

De Wiki Gla
Ir para navegação Ir para pesquisar
(Criou página com '<div class="infobox-boss-wide"> <div class="infobox-boss-right"> <div class="infobox-skill-info-area"> <div class="skill-box"> <div class="infobox-skill-ta...')
 
 
(95 revisões intermediárias pelo mesmo usuário não estão sendo mostradas)
Linha 1: Linha 1:
<div class="infobox-boss-wide">
<!-- WEAPON TOGGLE SYSTEM - Estado global + popup -->
  <div class="infobox-boss-right">
<script>
    <div class="infobox-skill-info-area">
    (() => {
      <div class="skill-box">
         let modalListenersBound = false;
         <div class="infobox-skill-tabs">
 
          <button class="infobox-skill-tab active" data-video="video1">Golpe Congelante</button>
        const bindModalEvents = () => {
          <button class="infobox-skill-tab" data-video="video2">Muralha de Gelo</button>
            if (modalListenersBound) return;
          <button class="infobox-skill-tab" data-video="video3">Explosão Ártica</button>
            modalListenersBound = true;
        </div>
            document.addEventListener('click', (ev) => {
        <div class="skill-desc" id="desc-text">
                if (ev.target.closest('.weapon-modal-close') || ev.target.closest('.weapon-modal-btn')) {
          Golpe Congelante: Causa dano em área e reduz a velocidade dos inimigos.
                    const checkbox = document.getElementById('weapon-dont-show');
        </div>
                    if (checkbox && checkbox.checked) {
      </div>
                        try { localStorage.setItem('glaWeaponPopupDismissed', '1'); } catch (x) { }
    </div>
                    }
    <div class="infobox-skill-video-area">
                    hidePopup();
      <video id="video1" class="skill-video" controls autoplay loop>
                    return;
        <source src="https://wiki.gla.com.br/images/2/22/Aokiji_sk3.webm" type="video/mp4">
                }
         Seu navegador não suporta vídeo.
                if (ev.target.classList.contains('weapon-modal-overlay')) {
      </video>
                    hidePopup();
      <video id="video2" class="skill-video" controls autoplay loop style="display:none"></video>
                }
      <video id="video3" class="skill-video" controls autoplay loop style="display:none"></video>
            });
     </div>
         };
  </div>
 
</div>
const applyWeaponState = (enabled) => {
    const first = document.querySelector('.skill-icon');
    const selected = document.querySelector('.skill-icon.selected');
     if (first) {
        if (selected) selected.classList.remove('selected');
        first.classList.add('selected');
    }


<script>
     if (typeof window.__setGlobalWeaponEnabled === 'function') {
  const videoSources = {
        window.__setGlobalWeaponEnabled(enabled);
     video1: "https://wiki.gla.com.br/images/2/22/Aokiji_sk3.webm",
     }
    video2: "https://wiki.gla.com.br/images/6/6b/Aokiji_sk2.webm",
    video3: "https://wiki.gla.com.br/images/7/76/Aokiji_sk1.webm"
  };
  const skillDescriptions = {
    video1: "Golpe Congelante: Causa dano em área e reduz a velocidade dos inimigos.",
    video2: "Muralha de Gelo: Cria uma barreira protetora de gelo.",
     video3: "Explosão Ártica: Dispara fragmentos de gelo em várias direções."
  };


  const tabs = document.querySelectorAll('.infobox-skill-tab');
    try {
  const videos = document.querySelectorAll('.skill-video');
        localStorage.setItem('glaWeaponEnabled', enabled ? '1' : '0');
  const desc = document.getElementById('desc-text');
    } catch (x) { }


  tabs.forEach(tab => {
     document.querySelectorAll('.skill-icon[data-weapon]').forEach(el => {
     tab.addEventListener('click', () => {
        if (enabled) {
      tabs.forEach(i => i.classList.remove('active'));
            el.classList.add('has-weapon-available');
      tab.classList.add('active');
            let ind = el.querySelector('.weapon-indicator');
      const vid = tab.getAttribute('data-video');
            if (!ind) {
      desc.textContent = skillDescriptions[vid];
                ind = document.createElement('div');
      videos.forEach(v => {
                ind.className = 'weapon-indicator';
        if (v.id === vid) {
                el.appendChild(ind);
          if (!v.querySelector('source')) {
            }
            const source = document.createElement('source');
            source.src = videoSources[vid];
            source.type = "video/mp4";
            v.appendChild(source);
          }
          v.style.display = '';
          v.load();
          v.play();
         } else {
         } else {
          v.pause();
            el.classList.remove('has-weapon-available');
          v.style.display = 'none';
            el.classList.remove('weapon-equipped');
          while (v.firstChild) v.removeChild(v.firstChild);
            el.style.removeProperty('--weapon-badge-url');
            const ind = el.querySelector('.weapon-indicator');
            if (ind) ind.remove();
         }
         }
      });
     });
     });
  });
 
    const sel = document.querySelector('.skill-icon.selected');
    if (sel) {
        sel.dispatchEvent(new Event('click', { bubbles: true }));
    }
};
 
 
        const ensureModal = () => {
            let modal = document.getElementById('weapon-info-modal');
            if (modal) return modal;
            modal = document.createElement('div');
            modal.id = 'weapon-info-modal';
            modal.className = 'weapon-modal';
            modal.innerHTML = `
            <div class="weapon-modal-overlay"></div>
            <div class="weapon-modal-content">
                <div class="weapon-modal-header">
                    <h3>Visualização com Arma Especial</h3>
                    <button class="weapon-modal-close">&times;</button>
                </div>
                <div class="weapon-modal-body">
                    <p>Este modo ativa a visualização do personagem equipado com sua <strong>arma especial</strong>.</p>
                    <p>As habilidades melhoradas ficam <strong>destacadas com borda e brilho azul</strong>, mesmo quando não selecionadas.</p>
                    <p class="weapon-info-link" style="margin-top:8px;display:none"></p>
                </div>
                <div class="weapon-modal-footer">
                    <label class="weapon-modal-checkbox">
                        <input type="checkbox" id="weapon-dont-show">
                        <span>Não mostrar novamente</span>
                    </label>
                    <button class="weapon-modal-btn">Entendi</button>
                </div>
            </div>
        `;
            document.body.appendChild(modal);
            try {
                const firstWithWeapon = document.querySelector('.skill-icon[data-weapon]');
                if (firstWithWeapon) {
                    const raw = firstWithWeapon.getAttribute('data-weapon');
                    const obj = JSON.parse(raw || '{}');
                    const nm = (obj && obj.name) ? String(obj.name).trim() : '';
                    if (nm) {
                        const linkHost = (window.mw && mw.util && typeof mw.util.getUrl === 'function') ? mw.util.getUrl(nm) : ('/index.php?title=' + encodeURIComponent(nm));
                        const holder = modal.querySelector('.weapon-info-link');
                        if (holder) {
                            holder.style.display = 'block';
                            holder.innerHTML = `<a href="${linkHost}" style="color:#6BB3FF;text-decoration:none;font-weight:600">Ver página da arma: ${nm}</a>`;
                        }
                    }
                }
            } catch (_) { }
            bindModalEvents();
            return modal;
        };
 
        const showPopup = () => {
            const modal = ensureModal();
            if (modal) modal.classList.add('show');
        };
 
        const hidePopup = () => {
            const m = document.getElementById('weapon-info-modal');
            if (m) m.classList.remove('show');
        };
 
        window.__applyWeaponState = applyWeaponState;
        window.__glaWeaponShowPopup = showPopup;
        window.__glaWeaponHidePopup = hidePopup;
        try {
            window.dispatchEvent(new CustomEvent('weapon:ready', { detail: { applyWeaponState, showPopup, hidePopup } }));
        } catch (err) {
        }
 
        const boot = () => {
            // Verificar se existe alguma skill com arma
            const hasAnyWeapon = document.querySelectorAll('.skill-icon[data-weapon]').length > 0;
            if (!hasAnyWeapon) return;
 
            ensureModal();
 
            // Estado inicial do toggle
            let init = false;
            try {
                if (localStorage.getItem('glaWeaponEnabled') === '1') init = true;
            } catch (x) { }
            setTimeout(() => applyWeaponState(init), 150);
        };
 
        if (document.readyState === 'loading') {
            document.addEventListener('DOMContentLoaded', boot);
        } else {
            boot();
        }
    })();
</script>
</script>
<style>
    .weapon-modal {
        position: fixed;
        inset: 0;
        z-index: 9999;
        display: flex;
        align-items: center;
        justify-content: center;
        opacity: 0;
        pointer-events: none;
        transition: opacity .3s;
    }


<style>
    .weapon-modal.show {
body {
        opacity: 1;
  background: transparent;
        pointer-events: all;
  margin: 0;
    }
  padding: 0;
 
  min-height: 100vh;
    .weapon-modal-overlay {
  width: 100vw;
        position: absolute;
  box-sizing: border-box;
        inset: 0;
  display: flex;
        background: rgba(0, 0, 0, .75);
  align-items: center;
        -webkit-backdrop-filter: blur(4px);
  justify-content: center;
        backdrop-filter: blur(4px);
}
    }
.infobox-boss-wide {
 
  display: flex;
    .weapon-modal-content {
  flex-direction: column;
        position: relative;
  align-items: center;
        background: linear-gradient(135deg, #1f1f1f, #2a2a2a);
  justify-content: center;
        border: 1px solid rgba(255, 255, 255, .12);
  width: 100vw;
        border-radius: 12px;
  min-height: 100vh;
        max-width: 420px;
  background: transparent;
        width: 90%;
  border: none;
        box-shadow: 0 20px 60px rgba(0, 0, 0, .6);
  border-radius: 12px;
        animation: modalIn .3s;
  box-shadow: none;
    }
  font-family: sans-serif;
 
  color: #222;
    @keyframes modalIn {
  overflow: hidden;
        from {
}
            transform: translateY(-20px);
.infobox-boss-right {
            opacity: 0;
  width: 100%;
        }
  display: flex;
 
  flex-direction: column;
        to {
  align-items: center;
            transform: translateY(0);
  justify-content: center;
            opacity: 1;
}
        }
.skill-box {
    }
  background: rgba(255,255,255,0.15);
 
  color: #222;
    .weapon-modal-header {
  border-radius: 12px;
        display: flex;
  box-shadow: none;
        align-items: center;
  width: 100%;
        justify-content: space-between;
  max-width: 700px;
        padding: 16px 20px;
  box-sizing: border-box;
        border-bottom: 1px solid rgba(255, 255, 255, .08);
  padding: 24px 24px 20px 24px;
    }
  display: flex;
 
  flex-direction: column;
    .weapon-modal-header h3 {
  align-items: center;
        margin: 0;
  gap: 18px;
        font-size: 16px;
  backdrop-filter: blur(2px);
        font-weight: 600;
  margin: 0 auto 24px auto;
        color: #fff;
}
    }
.infobox-skill-info-area {
 
  width: 100%;
    .weapon-modal-close {
  max-width: 900px;
        background: transparent;
  display: flex;
        border: none;
  flex-direction: column;
        color: rgba(255, 255, 255, .5);
  align-items: center;
        font-size: 24px;
  justify-content: center;
        cursor: pointer;
  margin-bottom: 16px;
        padding: 0;
  margin-top: 24px;
        width: 28px;
  gap: 12px;
        height: 28px;
}
        display: flex;
.infobox-skill-tabs {
        align-items: center;
  display: flex;
        justify-content: center;
  gap: 12px;
        border-radius: 4px;
  justify-content: center;
        transition: background .15s, color .15s;
  margin-bottom: 0;
    }
  width: 100%;
 
}
    .weapon-modal-close:hover {
.infobox-skill-tab {
        background: rgba(255, 255, 255, .1);
  cursor: pointer;
        color: #fff;
  background: #fff;
    }
  color: #222;
 
  border: 2px solid #ffc107;
    .weapon-modal-body {
  border-radius: 8px;
        padding: 20px;
  padding: 10px 24px;
        color: rgba(255, 255, 255, .8);
  font-size: 1em;
        line-height: 1.6;
  font-weight: bold;
        font-size: 14px;
  transition: 0.2s;
    }
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
 
  opacity: 0.7;
    .weapon-modal-body p {
  margin-bottom: 0;
        margin: 0 0 12px;
}
    }
.infobox-skill-tab.active,
 
.infobox-skill-tab:hover {
    .weapon-modal-body p:last-child {
  opacity: 1;
        margin: 0;
  background: #ffc107;
    }
  color: #181f2a;
 
  border-color: #ffc107;
    .weapon-modal-body strong {
}
        color: #6BB3FF;
.skill-desc {
    }
  font-size: 1.08em;
 
  width: 100%;
    .weapon-modal-footer {
  text-align: center;
        display: flex;
  font-weight: 500;
        align-items: center;
  line-height: 1.5;
        justify-content: space-between;
  margin-top: 0;
        padding: 14px 20px;
  margin-bottom: 0;
        border-top: 1px solid rgba(255, 255, 255, .08);
  background: none;
        gap: 12px;
  color: #222;
    }
  box-shadow: none;
 
  border-radius: 0;
    .weapon-modal-checkbox {
  padding: 0;
        display: flex;
}
        align-items: center;
.infobox-skill-video-area {
        gap: 8px;
  width: 100%;
        font-size: 12px;
  max-width: 900px;
        color: rgba(255, 255, 255, .6);
  min-height: 270px;
        cursor: pointer;
  display: flex;
    }
  align-items: center;
 
  justify-content: center;
    .weapon-modal-checkbox input[type="checkbox"] {
  background: transparent;
        accent-color: #4A9EFF;
  border-radius: 8px;
    }
  margin-top: 0;
 
  margin-bottom: 0;
    .weapon-modal-btn {
  box-shadow: none;
        background: #4A9EFF;
  padding: 16px 0;
        border: none;
  margin-left: auto;
        color: #fff;
  margin-right: auto;
        padding: 10px 24px;
}
        border-radius: 6px;
.skill-video {
        font-weight: 600;
  width: 100%;
        font-size: 13px;
  height: auto;
        cursor: pointer;
  max-width: 700px;
        transition: background .15s;
  border-radius: 8px;
    }
  background: #000;
 
  display: block;
    .weapon-modal-btn:hover {
  margin: 0 auto;
        background: #3A8EEF;
}
    }
@media (max-width: 900px) {
 
  .infobox-boss-wide {
    @media (max-width: 600px) {
    min-height: unset;
        .weapon-modal-content {
  }
            width: 95%;
  .infobox-skill-info-area,
        }
  .infobox-skill-video-area {
 
    max-width: 100vw;
        .weapon-modal-header,
    width: 100%;
        .weapon-modal-body,
    padding: 0 2vw;
        .weapon-modal-footer {
  }
            padding: 12px 16px;
  .skill-video,
        }
  .skill-box {
    max-width: 100vw;
    width: 100%;
  }
}


        .weapon-modal-footer {
            flex-direction: column;
        }
    }
</style>
</style>

Edição atual tal como às 16h34min de 2 de dezembro de 2025

<script>

   (() => {
       let modalListenersBound = false;
       const bindModalEvents = () => {
           if (modalListenersBound) return;
           modalListenersBound = true;
           document.addEventListener('click', (ev) => {
               if (ev.target.closest('.weapon-modal-close') || ev.target.closest('.weapon-modal-btn')) {
                   const checkbox = document.getElementById('weapon-dont-show');
                   if (checkbox && checkbox.checked) {
                       try { localStorage.setItem('glaWeaponPopupDismissed', '1'); } catch (x) { }
                   }
                   hidePopup();
                   return;
               }
               if (ev.target.classList.contains('weapon-modal-overlay')) {
                   hidePopup();
               }
           });
       };

const applyWeaponState = (enabled) => {

   const first = document.querySelector('.skill-icon');
   const selected = document.querySelector('.skill-icon.selected');
   if (first) {
       if (selected) selected.classList.remove('selected');
       first.classList.add('selected');
   }
   if (typeof window.__setGlobalWeaponEnabled === 'function') {
       window.__setGlobalWeaponEnabled(enabled);
   }
   try {
       localStorage.setItem('glaWeaponEnabled', enabled ? '1' : '0');
   } catch (x) { }
   document.querySelectorAll('.skill-icon[data-weapon]').forEach(el => {
       if (enabled) {
           el.classList.add('has-weapon-available');
           let ind = el.querySelector('.weapon-indicator');
           if (!ind) {
               ind = document.createElement('div');
               ind.className = 'weapon-indicator';
               el.appendChild(ind);
           }
       } else {
           el.classList.remove('has-weapon-available');
           el.classList.remove('weapon-equipped');
           el.style.removeProperty('--weapon-badge-url');
           const ind = el.querySelector('.weapon-indicator');
           if (ind) ind.remove();
       }
   });
   const sel = document.querySelector('.skill-icon.selected');
   if (sel) {
       sel.dispatchEvent(new Event('click', { bubbles: true }));
   }

};


       const ensureModal = () => {
           let modal = document.getElementById('weapon-info-modal');
           if (modal) return modal;
           modal = document.createElement('div');
           modal.id = 'weapon-info-modal';
           modal.className = 'weapon-modal';
           modal.innerHTML = `

Visualização com Arma Especial

                   <button class="weapon-modal-close">×</button>

Este modo ativa a visualização do personagem equipado com sua arma especial.

As habilidades melhoradas ficam destacadas com borda e brilho azul, mesmo quando não selecionadas.

       `;
           document.body.appendChild(modal);
           try {
               const firstWithWeapon = document.querySelector('.skill-icon[data-weapon]');
               if (firstWithWeapon) {
                   const raw = firstWithWeapon.getAttribute('data-weapon');
                   const obj = JSON.parse(raw || '{}');
                   const nm = (obj && obj.name) ? String(obj.name).trim() : ;
                   if (nm) {
                       const linkHost = (window.mw && mw.util && typeof mw.util.getUrl === 'function') ? mw.util.getUrl(nm) : ('/index.php?title=' + encodeURIComponent(nm));
                       const holder = modal.querySelector('.weapon-info-link');
                       if (holder) {
                           holder.style.display = 'block';
                           holder.innerHTML = `<a href="${linkHost}" style="color:#6BB3FF;text-decoration:none;font-weight:600">Ver página da arma: ${nm}</a>`;
                       }
                   }
               }
           } catch (_) { }
           bindModalEvents();
           return modal;
       };
       const showPopup = () => {
           const modal = ensureModal();
           if (modal) modal.classList.add('show');
       };
       const hidePopup = () => {
           const m = document.getElementById('weapon-info-modal');
           if (m) m.classList.remove('show');
       };
       window.__applyWeaponState = applyWeaponState;
       window.__glaWeaponShowPopup = showPopup;
       window.__glaWeaponHidePopup = hidePopup;
       try {
           window.dispatchEvent(new CustomEvent('weapon:ready', { detail: { applyWeaponState, showPopup, hidePopup } }));
       } catch (err) {
       }
       const boot = () => {
           // Verificar se existe alguma skill com arma
           const hasAnyWeapon = document.querySelectorAll('.skill-icon[data-weapon]').length > 0;
           if (!hasAnyWeapon) return;
           ensureModal();
           // Estado inicial do toggle
           let init = false;
           try {
               if (localStorage.getItem('glaWeaponEnabled') === '1') init = true;
           } catch (x) { }
           setTimeout(() => applyWeaponState(init), 150);
       };
       if (document.readyState === 'loading') {
           document.addEventListener('DOMContentLoaded', boot);
       } else {
           boot();
       }
   })();

</script> <style>

   .weapon-modal {
       position: fixed;
       inset: 0;
       z-index: 9999;
       display: flex;
       align-items: center;
       justify-content: center;
       opacity: 0;
       pointer-events: none;
       transition: opacity .3s;
   }
   .weapon-modal.show {
       opacity: 1;
       pointer-events: all;
   }
   .weapon-modal-overlay {
       position: absolute;
       inset: 0;
       background: rgba(0, 0, 0, .75);
       -webkit-backdrop-filter: blur(4px);
       backdrop-filter: blur(4px);
   }
   .weapon-modal-content {
       position: relative;
       background: linear-gradient(135deg, #1f1f1f, #2a2a2a);
       border: 1px solid rgba(255, 255, 255, .12);
       border-radius: 12px;
       max-width: 420px;
       width: 90%;
       box-shadow: 0 20px 60px rgba(0, 0, 0, .6);
       animation: modalIn .3s;
   }
   @keyframes modalIn {
       from {
           transform: translateY(-20px);
           opacity: 0;
       }
       to {
           transform: translateY(0);
           opacity: 1;
       }
   }
   .weapon-modal-header {
       display: flex;
       align-items: center;
       justify-content: space-between;
       padding: 16px 20px;
       border-bottom: 1px solid rgba(255, 255, 255, .08);
   }
   .weapon-modal-header h3 {
       margin: 0;
       font-size: 16px;
       font-weight: 600;
       color: #fff;
   }
   .weapon-modal-close {
       background: transparent;
       border: none;
       color: rgba(255, 255, 255, .5);
       font-size: 24px;
       cursor: pointer;
       padding: 0;
       width: 28px;
       height: 28px;
       display: flex;
       align-items: center;
       justify-content: center;
       border-radius: 4px;
       transition: background .15s, color .15s;
   }
   .weapon-modal-close:hover {
       background: rgba(255, 255, 255, .1);
       color: #fff;
   }
   .weapon-modal-body {
       padding: 20px;
       color: rgba(255, 255, 255, .8);
       line-height: 1.6;
       font-size: 14px;
   }
   .weapon-modal-body p {
       margin: 0 0 12px;
   }
   .weapon-modal-body p:last-child {
       margin: 0;
   }
   .weapon-modal-body strong {
       color: #6BB3FF;
   }
   .weapon-modal-footer {
       display: flex;
       align-items: center;
       justify-content: space-between;
       padding: 14px 20px;
       border-top: 1px solid rgba(255, 255, 255, .08);
       gap: 12px;
   }
   .weapon-modal-checkbox {
       display: flex;
       align-items: center;
       gap: 8px;
       font-size: 12px;
       color: rgba(255, 255, 255, .6);
       cursor: pointer;
   }
   .weapon-modal-checkbox input[type="checkbox"] {
       accent-color: #4A9EFF;
   }
   .weapon-modal-btn {
       background: #4A9EFF;
       border: none;
       color: #fff;
       padding: 10px 24px;
       border-radius: 6px;
       font-weight: 600;
       font-size: 13px;
       cursor: pointer;
       transition: background .15s;
   }
   .weapon-modal-btn:hover {
       background: #3A8EEF;
   }
   @media (max-width: 600px) {
       .weapon-modal-content {
           width: 95%;
       }
       .weapon-modal-header,
       .weapon-modal-body,
       .weapon-modal-footer {
           padding: 12px 16px;
       }
       .weapon-modal-footer {
           flex-direction: column;
       }
   }

</style>