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

De Wiki Gla
Ir para navegação Ir para pesquisar
Linha 1: Linha 1:
<div class="skillbox-container">
<div class="skillbox-container">
  <div class="skillbox-inner">
    <div class="skillbox-inner">
    <div class="skillbox-info-area">
        <div class="skillbox-info-area">
      <div class="skillbox-wrapper">
            <div class="skillbox-wrapper">
        <div class="skillbox-tabs" id="skill-tabs"></div>
                <div class="skillbox-tabs" id="skill-tabs"></div>
        <div class="skillbox-tabs-separator"></div>
                <div class="skillbox-tabs-separator"></div>
        <div class="skillbox-desc" id="desc-text"></div>
                <div class="skillbox-desc" id="desc-text"></div>
      </div>
            </div>
        </div>
        <div class="skillbox-video-area" id="skill-videos"></div>
     </div>
     </div>
    <div class="skillbox-video-area" id="skill-videos"></div>
  </div>
</div>
</div>


<script>
<script>
(function () {
    (function () {
    const raw = document.getElementById('skillbox-data');
        const raw = document.getElementById('skillbox-data');
    if (!raw) return;
        if (!raw) return;


    const habilidades = [];
        const habilidades = [];


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


        habilidades.push({
            habilidades.push({
            nome,
                nome,
            descricao,
                descricao,
            videoUrl: `https://wiki.gla.com.br/index.php/Special:FilePath/${videoFile}`,
                videoUrl: `https://wiki.gla.com.br/index.php/Special:FilePath/${videoFile}`,
            id: `video${i}`
                id: `video${i}`
        });
            });
    }
        }


    const tabsContainer = document.getElementById('skill-tabs');
        const tabsContainer = document.getElementById('skill-tabs');
    const videoContainer = document.getElementById('skill-videos');
        const videoContainer = document.getElementById('skill-videos');
    const descText = document.getElementById('desc-text');
        const descText = document.getElementById('desc-text');


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


        const videoWrapper = document.createElement('div');
            const videoWrapper = document.createElement('div');
        videoWrapper.id = hab.id;
            videoWrapper.id = hab.id;
        videoWrapper.className = 'skillbox-video' + (idx === 0 ? ' active' : '');
            videoWrapper.className = 'skillbox-video' + (idx === 0 ? ' active' : '');


        const video = document.createElement('video');
            const video = document.createElement('video');
        video.className = 'skillbox-video-element';
            video.className = 'skillbox-video-element';
        video.controls = true;
            video.controls = true;
        video.preload = 'auto';
            video.preload = 'auto';


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


        videoWrapper.appendChild(video);
            videoWrapper.appendChild(video);
        videoContainer.appendChild(videoWrapper);
            videoContainer.appendChild(videoWrapper);
    });
        });


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


    const tabs = document.querySelectorAll('.skillbox-tab');
        const tabs = document.querySelectorAll('.skillbox-tab');
    const videos = document.querySelectorAll('.skillbox-video');
        const videos = document.querySelectorAll('.skillbox-video');


    tabs.forEach((tab, idx) => {
        tabs.forEach((tab, idx) => {
        tab.addEventListener('click', () => {
            tab.addEventListener('click', () => {
            tabs.forEach(t => t.classList.remove('active'));
                tabs.forEach(t => t.classList.remove('active'));
            tab.classList.add('active');
                tab.classList.add('active');


            habilidades[idx].descricao = habilidades[idx].descricao.replace(/'''(.*?)'''/g, '<b>$1</b>');
                habilidades[idx].descricao = habilidades[idx].descricao.replace(/'''(.*?)'''/g, '<b>$1</b>');
            descText.innerHTML = habilidades[idx].descricao;
                descText.innerHTML = habilidades[idx].descricao;


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


    raw.remove();
        raw.remove();
 
     })();
    setTimeout(() => {
        const descTempContainer = document.createElement('div');
        descTempContainer.style.position = 'absolute';
        descTempContainer.style.visibility = 'hidden';
        descTempContainer.style.pointerEvents = 'none';
        descTempContainer.style.width = descText.offsetWidth + 'px';
        descTempContainer.style.fontFamily = window.getComputedStyle(descText).fontFamily;
        descTempContainer.style.fontSize = window.getComputedStyle(descText).fontSize;
        descTempContainer.style.lineHeight = window.getComputedStyle(descText).lineHeight;
        descTempContainer.style.fontWeight = window.getComputedStyle(descText).fontWeight;
        descTempContainer.style.boxSizing = 'border-box';
        descTempContainer.style.padding = window.getComputedStyle(descText).padding;
 
        let maxHeight = 0;
 
        habilidades.forEach(hab => {
            const span = document.createElement('div');
            span.innerHTML = hab.descricao.replace(/'''(.*?)'''/g, '<b>$1</b>');
            descTempContainer.appendChild(span);
        });
 
        document.body.appendChild(descTempContainer);
        maxHeight = descTempContainer.offsetHeight;
        document.body.removeChild(descTempContainer);
 
        descText.style.height = maxHeight + 'px';
     }, 100);
})();
</script>
</script>


<style>
<style>
.skillbox-video {
    .skillbox-video {
  aspect-ratio: 16 / 9;
        aspect-ratio: 16 / 9;
  opacity: 0;
        opacity: 0;
  transition: opacity 0.2s ease;
        transition: opacity 0.2s ease;
  visibility: hidden;
        visibility: hidden;
  height: 0;
        height: 0;
  overflow: hidden;
        overflow: hidden;
  position: absolute;
        position: absolute;
  width: 100%;
        width: 100%;
  max-width: 900px;
        max-width: 900px;
  margin: 0 auto;
        margin: 0 auto;
}
    }


.skillbox-video.active {
    .skillbox-video.active {
  position: static;
        position: static;
  opacity: 1;
        opacity: 1;
  visibility: visible;
        visibility: visible;
  height: auto;
        height: auto;
}
    }
</style>
</style>

Edição das 01h30min de 24 de maio de 2025

<script>

   (function () {
       const raw = document.getElementById('skillbox-data');
       if (!raw) return;
       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: `video${i}`
           });
       }
       const tabsContainer = document.getElementById('skill-tabs');
       const videoContainer = document.getElementById('skill-videos');
       const descText = document.getElementById('desc-text');
       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) {
           habilidades[0].descricao = habilidades[0].descricao.replace(/(.*?)/g, '$1');
           descText.innerHTML = habilidades[0].descricao;
       }
       const tabs = document.querySelectorAll('.skillbox-tab');
       const videos = document.querySelectorAll('.skillbox-video');
       tabs.forEach((tab, idx) => {
           tab.addEventListener('click', () => {
               tabs.forEach(t => t.classList.remove('active'));
               tab.classList.add('active');
               habilidades[idx].descricao = habilidades[idx].descricao.replace(/(.*?)/g, '$1');
               descText.innerHTML = habilidades[idx].descricao;
               videos.forEach(v => {
                   const videoTag = v.querySelector('video');
                   if (v.id === habilidades[idx].id) {
                       v.classList.add('active');
                       videoTag.currentTime = 0;
                       videoTag.play();
                   } else {
                       v.classList.remove('active');
                       videoTag.pause();
                   }
               });
           });
       });
       raw.remove();
   })();

</script>

<style>

   .skillbox-video {
       aspect-ratio: 16 / 9;
       opacity: 0;
       transition: opacity 0.2s ease;
       visibility: hidden;
       height: 0;
       overflow: hidden;
       position: absolute;
       width: 100%;
       max-width: 900px;
       margin: 0 auto;
   }
   .skillbox-video.active {
       position: static;
       opacity: 1;
       visibility: visible;
       height: auto;
   }

</style>