MediaWiki:Vector.js: Difference between revisions

From Forklift Certified Video Games
Jump to navigation Jump to search
Line 15: Line 15:
     } );
     } );
}
}
/* SHOW ALL BUTTON */
$(function() {
    $('.cargo-show-all-btn').on('click', function() {
        var $btn = $(this);
        var $grid = $btn.next('.cargo-hidden-grid');
        // Toggle the grid visibility
        $grid.toggleClass('grid-visible');
       
        // Toggle button text and active state
        if ($grid.hasClass('grid-visible')) {
            $btn.text('Hide Video Games').addClass('btn-active');
        } else {
            $btn.text('Show All Video Games').removeClass('btn-active');
        }
    });
});


/* NEWS SLIDESHOW */
/* NEWS SLIDESHOW */

Revision as of 19:30, 31 January 2026

/* All JavaScript here will be loaded for users of the Vector skin */

/* Move subcategories to the top on Category:Forklifts and Category:Video_Games */
if ( mw.config.get( 'wgPageName' ) === 'Category:Forklifts' || mw.config.get( 'wgPageName' ) === 'Category:Video_Games' ) {
    $( function() {
        var subcats = $( '#mw-subcategories' );
        var content = $( '.mw-parser-output' );
        if ( subcats.length && content.length ) {
            subcats.insertBefore( content );
            $( 'body' ).addClass( 'move-subcategories-up-active' );
            $( '#bodyContent' ).css( { 'display': 'flex', 'flex-direction': 'column' } );
            content.css( 'order', '2' );
            subcats.css( 'order', '1' );
        }
    } );
}

/* SHOW ALL BUTTON */
$(function() {
    $('.cargo-show-all-btn').on('click', function() {
        var $btn = $(this);
        var $grid = $btn.next('.cargo-hidden-grid');

        // Toggle the grid visibility
        $grid.toggleClass('grid-visible');
        
        // Toggle button text and active state
        if ($grid.hasClass('grid-visible')) {
            $btn.text('Hide Video Games').addClass('btn-active');
        } else {
            $btn.text('Show All Video Games').removeClass('btn-active');
        }
    });
});


/* NEWS SLIDESHOW */
mw.loader.using('mediawiki.util').then(function () {
    mw.hook('wikipage.content').add(function () {
        document.querySelectorAll('.news-slideshow-container').forEach(function (container) {
            var slides = container.querySelectorAll('.news-slideshow-slide');
            if (slides.length <= 1) return;

            var current = 0;
            var intervalId = null;
            var delay = 8000; // 8 seconds

            function showSlide(index) {
                slides.forEach(function (slide, i) {
                    slide.classList.toggle('active', i === index);
                });
            }

            function startSlideshow() {
                if (intervalId !== null) return;
                intervalId = setInterval(function () {
                    current = (current + 1) % slides.length;
                    showSlide(current);
                }, delay);
            }

            function stopSlideshow() {
                if (intervalId !== null) {
                    clearInterval(intervalId);
                    intervalId = null;
                }
            }

            // Initial state
            showSlide(current);
            startSlideshow();

            // Pause on hover
            container.addEventListener('mouseenter', stopSlideshow);
            container.addEventListener('mouseleave', startSlideshow);
        });
    });
});


/* FORM TABLE */
document.addEventListener('click', function (e) {
	const header = e.target.closest('.pf-collapsible');
	if (!header) return;

	const targetId = header.dataset.target;
	const section = document.getElementById(targetId);
	if (!section) return;

	const isOpen = section.style.display === 'block';
	section.style.display = isOpen ? 'none' : 'block';
});