Jump to content

MediaWiki:Common.js: Difference between revisions

From Continuum Universes Wiki
No edit summary
No edit summary
 
(9 intermediate revisions by the same user not shown)
Line 1: Line 1:
mw.loader.load('https://cdnjs.cloudflare.com/ajax/libs/slick-carousel/1.8.1/slick.min.js');
mw.hook('ext.popups').add(function() {
mw.loader.load('https://cdnjs.cloudflare.com/ajax/libs/slick-carousel/1.8.1/slick.css', 'text/css');
    $('.mwe-popups-extract .portable-infobox').each(function() {
mw.loader.load('https://cdnjs.cloudflare.com/ajax/libs/slick-carousel/1.8.1/slick-theme.css', 'text/css');
        var $infobox = $(this);
mw.loader.load('/extensions/JavascriptSlideshow/js/slideshow.js');
        var $firstParagraph = $('.mwe-popups-extract p:first');


mw.hook('wikipage.content').add(function($content) {
         // If there is a paragraph, move the infobox after it
    $content.find('.mw-jsslideshow').each(function() {
         if ($firstParagraph.length) {
        const $slideshowContainer = $(this);
             $infobox.insertAfter($firstParagraph);
        const $slideshow = $('<div class="slideshow"></div>');
        } else {
 
             // If there's no paragraph, just hide the infobox
         // Find all images inside mw-jsslideshow, including [[File:]] images
             $infobox.hide();
        $slideshowContainer.find('img').each(function() {
            const $img = $(this);
            const $slide = $('<div></div>').append($img.clone()); // Wrap in slide div
            $slideshow.append($slide);
        });
 
        // Replace old content with the new slick-ready slideshow
         $slideshowContainer.empty().append($slideshow);
 
        // Initialize slick
        $slideshow.slick({
            infinite: true,
            slidesToShow: 1,
            slidesToScroll: 1,
            autoplay: true,
            autoplaySpeed: 5000,
            arrows: true,
            dots: true,
            adaptiveHeight: true
        });
 
        // Fix positioning on resize
        $(window).on('resize', function() {
            $slideshow.slick('setPosition');
        });
    });
});
function waitForStartSlideshow(callback) {
    if (typeof startSlideshow === 'function') {
        callback();
    } else {
        setTimeout(function() {
            waitForStartSlideshow(callback);
        }, 100); // Try every 100ms
    }
}
 
function initMissingSlideshows() {
    var counter = 1;
 
    $('.slideshow').each(function() {
        var $this = $(this);
        if (!$this.attr('id')) {
            var newId = 'slideshow-auto-' + (counter++);
            $this.attr('id', newId);
 
             if ($('#' + newId + '-spacer').length === 0) {
                $('<div>')
                    .attr('id', newId + '-spacer')
                    .insertAfter($this);
            }
 
            // Call the slideshow init AFTER we confirm startSlideshow exists
            waitForStartSlideshow(function() {
                startSlideshow(newId);
             });
        }
    });
}
 
$(document).ready(function() {
    mw.loader.load('/extensions/JavascriptSlideshow/js/slideshow.js');
 
    // Start initializing after ensuring the script is there
    waitForStartSlideshow(initMissingSlideshows);
});
 
$(document).ready(function() {
    var counter = 1;
 
    $('.slideshow').each(function() {
        var $this = $(this);
        if (!$this.attr('id')) {
            // Assign an auto id if missing
            var newId = 'slideshow-auto-' + (counter++);
            $this.attr('id', newId);
 
            // Add the missing spacer
             if ($('#' + newId + '-spacer').length === 0) {
                $('<div>')
                    .attr('id', newId + '-spacer')
                    .insertAfter($this);
            }
 
            // Force JavascriptSlideshow to initialize this slideshow
            startSlideshow(newId);
         }
         }
     });
     });
});
});

Latest revision as of 07:20, 17 March 2025

mw.hook('ext.popups').add(function() {
    $('.mwe-popups-extract .portable-infobox').each(function() {
        var $infobox = $(this);
        var $firstParagraph = $('.mwe-popups-extract p:first');

        // If there is a paragraph, move the infobox after it
        if ($firstParagraph.length) {
            $infobox.insertAfter($firstParagraph);
        } else {
            // If there's no paragraph, just hide the infobox
            $infobox.hide();
        }
    });
});