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

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...')
 
 
(3 revisões intermediárias por 2 usuários não estão sendo mostradas)
Linha 1: Linha 1:
<div class="infobox-boss-wide">
<div class="skillbox-container">
  <div class="infobox-boss-right">
    <div class="skillbox-inner">
    <div class="infobox-skill-info-area">
        <div class="skillbox-info-area">
      <div class="skill-box">
            <div class="skillbox-wrapper">
        <div class="infobox-skill-tabs" id="skill-tabs"></div>
                <div class="skillbox-tabs" id="skill-tabs"></div>
        <div class="skill-desc" id="desc-text"></div>
                <div class="skillbox-tabs-separator"></div>
      </div>
                <div class="skillbox-desc" id="desc-text"></div>
            </div>
        </div>
        <div class="skillbox-video-area" id="skill-videos"></div>
     </div>
     </div>
    <div class="infobox-skill-video-area" id="skill-videos"></div>
  </div>
</div>
</div>
<script src="//api.html5media.info/1.2.2/html5media.min.js"></script>
 
<script>
<script>
(function () {
(function () {
  const raw = document.getElementById('infoboxboss-data');
    const allRawBlocks = document.querySelectorAll('.skillbox-data');
  if (!raw) return;
    if (!allRawBlocks.length) return;
 
    allRawBlocks.forEach((raw, index) => {
        const uniqueId = raw.dataset.skillboxId || `skillbox${index}`;
 
        const habilidades = [];
        for (let i = 1; i <= 15; i++) {
            const nome = raw.dataset[`hab${i}`];
            const descricao = raw.dataset[`de${i}`] || "";
            const videoFile = raw.dataset[`vid${i}`];
            if (!nome || !videoFile || videoFile.trim() === '') continue;
 
            habilidades.push({
                nome,
                descricao,
                videoUrl: `https://wiki.gla.com.br/index.php/Special:FilePath/${videoFile}`,
                id: `${uniqueId}-video${i}`
            });
        }
 
        // Criar estrutura DOM local
        const container = document.createElement('div');
        container.className = 'skillbox-container';


  const habilidades = [];
        container.innerHTML = `
            <div class="skillbox-inner">
                <div class="skillbox-info-area">
                    <div class="skillbox-wrapper">
                        <div class="skillbox-tabs" id="${uniqueId}-tabs"></div>
                        <div class="skillbox-tabs-separator"></div>
                        <div class="skillbox-desc" id="${uniqueId}-desc"></div>
                    </div>
                </div>
                <div class="skillbox-video-area" id="${uniqueId}-videos"></div>
            </div>
        `;


  for (let i = 1; i <= 10; i++) {
        raw.insertAdjacentElement('afterend', container);
    const nome = raw.dataset[`hab${i}`];
    const descricao = raw.dataset[`de${i}`];
    const videoFile = raw.dataset[`vid${i}`];
    if (!nome || !videoFile) continue;


    habilidades.push({
        const tabsContainer = container.querySelector(`#${uniqueId}-tabs`);
      nome,
        const videoContainer = container.querySelector(`#${uniqueId}-videos`);
      descricao,
        const descText = container.querySelector(`#${uniqueId}-desc`);
      videoUrl: `https://wiki.gla.com.br/index.php/Special:FilePath/${videoFile}`,
      id: `video${i}`
    });
  }


  const tabsContainer = document.getElementById('skill-tabs');
        habilidades.forEach((hab, idx) => {
  const videoContainer = document.getElementById('skill-videos');
            const btn = document.createElement('button');
  const descText = document.getElementById('desc-text');
            btn.className = 'skillbox-tab' + (idx === 0 ? ' active' : '');
            btn.dataset.video = hab.id;
            btn.textContent = hab.nome;
            tabsContainer.appendChild(btn);


  habilidades.forEach((hab, idx) => {
            const videoWrapper = document.createElement('div');
    const btn = document.createElement('button');
            videoWrapper.id = hab.id;
    btn.className = 'infobox-skill-tab' + (idx === 0 ? ' active' : '');
            videoWrapper.className = 'skillbox-video' + (idx === 0 ? ' active' : '');
    btn.dataset.video = hab.id;
    btn.textContent = hab.nome;
    tabsContainer.appendChild(btn);


    const videoWrapper = document.createElement('div');
            const video = document.createElement('video');
    videoWrapper.id = hab.id;
            video.className = 'skillbox-video-element';
    videoWrapper.className = 'skill-video';
            video.controls = true;
    videoWrapper.style.display = idx === 0 ? 'block' : 'none';
            video.preload = 'auto';


    const video = document.createElement('video');
            const source = document.createElement('source');
    video.className = 'infobox-skill-video';
            source.src = hab.videoUrl;
    video.controls = true;
            source.type = 'video/mp4';
    video.preload = 'auto';
            video.appendChild(source);


    const source = document.createElement('source');
            videoWrapper.appendChild(video);
    source.src = hab.videoUrl;
            videoContainer.appendChild(videoWrapper);
    source.type = 'video/mp4';
        });
    video.appendChild(source);


    videoWrapper.appendChild(video);
        if (habilidades.length) {
    videoContainer.appendChild(videoWrapper);
            descText.innerHTML = habilidades[0].descricao.replace(/'''(.*?)'''/g, '<b>$1</b>');
  });
        }


  if (habilidades.length) {
        const tabs = container.querySelectorAll('.skillbox-tab');
    descText.innerHTML = `${habilidades[0].descricao}`;
        const videos = container.querySelectorAll('.skillbox-video');
  }


  const tabs = document.querySelectorAll('.infobox-skill-tab');
        tabs.forEach((tab, idx) => {
  const videos = document.querySelectorAll('.skill-video');
            tab.addEventListener('click', () => {
                tabs.forEach(t => t.classList.remove('active'));
                tab.classList.add('active');


  tabs.forEach((tab, idx) => {
                const desc = habilidades[idx].descricao || "";
    tab.addEventListener('click', () => {
                descText.innerHTML = desc.replace(/'''(.*?)'''/g, '<b>$1</b>');
      tabs.forEach(t => t.classList.remove('active'));
      tab.classList.add('active');


      descText.innerHTML = `${habilidades[idx].descricao}`;
                videos.forEach(v => {
                    const videoTag = v.querySelector('video');
                    if (v.id === habilidades[idx].id) {
                        v.classList.add('active');
                        if (videoTag) {
                            videoTag.currentTime = 0;
                            videoTag.play();
                        }
                    } else {
                        v.classList.remove('active');
                        if (videoTag) videoTag.pause();
                    }
                });
            });
        });


      videos.forEach(v => {
         raw.remove();
        v.style.display = (v.id === habilidades[idx].id) ? 'block' : 'none';
        const videoTag = v.querySelector('video');
        if (v.id === habilidades[idx].id) {
          videoTag.load();
          videoTag.play();
         } else {
          videoTag.pause();
        }
      });
     });
     });
  });
})();


  raw.remove();
})();
</script>
</script>


<style>
<style>
.skill-box {
.skillbox-video {
  background: none;;
    display: none;
  color: #222;
    width: 100%;
  border-radius: 12px;
    max-width: 900px;
  box-shadow: none;
    aspect-ratio: 16 / 9;
  width: 100%;
    margin: 0 auto;
  max-width: 700px;
    padding: 0;
  box-sizing: border-box;
  padding: 24px 24px 20px 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;
  backdrop-filter: blur(2px);
  margin: 0 auto 24px auto;
}
}
.skill-video{
 
  aspect-ratio: 16 / 9;
.skillbox-video.active {
    display: flex;
    justify-content: center;
    align-items: center;
}
}
</style>
</style>

Edição atual tal como às 11h23min de 9 de junho de 2025

<script> (function () {

   const allRawBlocks = document.querySelectorAll('.skillbox-data');
   if (!allRawBlocks.length) return;
   allRawBlocks.forEach((raw, index) => {
       const uniqueId = raw.dataset.skillboxId || `skillbox${index}`;
       const habilidades = [];
       for (let i = 1; i <= 15; i++) {
           const nome = raw.dataset[`hab${i}`];
           const descricao = raw.dataset[`de${i}`] || "";
           const videoFile = raw.dataset[`vid${i}`];
           if (!nome || !videoFile || videoFile.trim() === ) continue;
           habilidades.push({
               nome,
               descricao,
               videoUrl: `https://wiki.gla.com.br/index.php/Special:FilePath/${videoFile}`,
               id: `${uniqueId}-video${i}`
           });
       }
       // Criar estrutura DOM local
       const container = document.createElement('div');
       container.className = 'skillbox-container';
       container.innerHTML = `
       `;
       raw.insertAdjacentElement('afterend', container);
       const tabsContainer = container.querySelector(`#${uniqueId}-tabs`);
       const videoContainer = container.querySelector(`#${uniqueId}-videos`);
       const descText = container.querySelector(`#${uniqueId}-desc`);
       habilidades.forEach((hab, idx) => {
           const btn = document.createElement('button');
           btn.className = 'skillbox-tab' + (idx === 0 ? ' active' : );
           btn.dataset.video = hab.id;
           btn.textContent = hab.nome;
           tabsContainer.appendChild(btn);
           const videoWrapper = document.createElement('div');
           videoWrapper.id = hab.id;
           videoWrapper.className = 'skillbox-video' + (idx === 0 ? ' active' : );
           const video = document.createElement('video');
           video.className = 'skillbox-video-element';
           video.controls = true;
           video.preload = 'auto';
           const source = document.createElement('source');
           source.src = hab.videoUrl;
           source.type = 'video/mp4';
           video.appendChild(source);
           videoWrapper.appendChild(video);
           videoContainer.appendChild(videoWrapper);
       });
       if (habilidades.length) {
           descText.innerHTML = habilidades[0].descricao.replace(/(.*?)/g, '$1');
       }
       const tabs = container.querySelectorAll('.skillbox-tab');
       const videos = container.querySelectorAll('.skillbox-video');
       tabs.forEach((tab, idx) => {
           tab.addEventListener('click', () => {
               tabs.forEach(t => t.classList.remove('active'));
               tab.classList.add('active');
               const desc = habilidades[idx].descricao || "";
               descText.innerHTML = desc.replace(/(.*?)/g, '$1');
               videos.forEach(v => {
                   const videoTag = v.querySelector('video');
                   if (v.id === habilidades[idx].id) {
                       v.classList.add('active');
                       if (videoTag) {
                           videoTag.currentTime = 0;
                           videoTag.play();
                       }
                   } else {
                       v.classList.remove('active');
                       if (videoTag) videoTag.pause();
                   }
               });
           });
       });
       raw.remove();
   });

})();

</script>

<style> .skillbox-video {

   display: none;
   width: 100%;
   max-width: 900px;
   aspect-ratio: 16 / 9;
   margin: 0 auto;
   padding: 0;

}

.skillbox-video.active {

   display: flex;
   justify-content: center;
   align-items: center;

} </style>