Jump to content

MediaWiki:Common.js: Difference between revisions

 
(43 intermediate revisions by the same user not shown)
Line 1: Line 1:
(function() {
mw.hook('wikipage.content').add(function () {
    function cleanSlideshowStyles(slideshowContainer) {
  const el = document.getElementById('article-countdown');
        const slideshow = slideshowContainer.querySelector('.slideshow');
  console.log('countdown hook fired; element is:', el);
        if (slideshow) {
            // Remove inline styles on the main slideshow container
            slideshow.style.width = '';
            slideshow.style.height = '';


            // Remove inline styles on each slide div
  if (!el) return;
            slideshow.querySelectorAll('div').forEach(slide => {
  el.textContent = '✅ Countdown JS is running…';
                slide.style.width = '';
                slide.style.height = '';
            });
        }
    }


    function initSlideshowFix() {
  const apiUrl = mw.util.wikiScript('api') +
        // Locate all mw-jsslideshow instances
    '?action=query&meta=siteinfo&siprop=statistics&format=json&origin=*';
        document.querySelectorAll('.mw-jsslideshow').forEach(mwSlideshow => {
            // Clean styles on page load
            cleanSlideshowStyles(mwSlideshow);


            // Optional: Re-clean styles on window resize
  fetch(apiUrl)
            window.addEventListener('resize', () => {
    .then(r => r.json())
                cleanSlideshowStyles(mwSlideshow);
    .then(d => {
            });
      const current = d.query.statistics.articles;
      const goal = 1000;
      const left = goal - current;


            // Hook into slide transitions if needed (depends on the specific JS driving the slideshow)
      el.innerHTML = left > 0
            const slideshow = mwSlideshow.querySelector('.slideshow');
        ? `🚧 Only <strong>${left}</strong> articles to go until 1000!`
            if (slideshow) {
        : `🎯 We've reached 1000 articles! Let's Go Boyz and Girlz!`;
                const observer = new MutationObserver(() => {
    })
                    cleanSlideshowStyles(mwSlideshow);
    .catch(err => {
                });
      el.textContent = 'API request failed (see console).';
      console.error(err);
    });
});


                observer.observe(slideshow, {
                    attributes: true,
                    attributeFilter: ['style'],
                    childList: false,
                    subtree: false
                });
            }
        });
    }


    // Run once DOM is ready (in case the slideshows are injected late)
// MediaWiki:Common.js
    if (document.readyState === 'complete' || document.readyState === 'interactive') {
mw.hook('rcfilters.ui.initialized').add(function () {
        initSlideshowFix();
  document.documentElement.classList.add('rcfilters-ready');
    } else {
});
        document.addEventListener('DOMContentLoaded', initSlideshowFix);
    }
})();
/* Any JavaScript here will be loaded for all users on every page load. */
(function() {
    function cleanSlideshowStyles(slideshowContainer) {
        const slideshow = slideshowContainer.querySelector('.slideshow');
        if (slideshow) {
            // Remove inline styles on the main slideshow container
            slideshow.style.width = '';
            slideshow.style.height = '';
 
            // Remove inline styles on each slide div
            slideshow.querySelectorAll('div').forEach(slide => {
                slide.style.width = '';
                slide.style.height = '';
            });
        }
    }
 
    function initSlideshowFix() {
        // Locate all mw-jsslideshow instances
        document.querySelectorAll('.mw-jsslideshow').forEach(mwSlideshow => {
            // Clean styles on page load
            cleanSlideshowStyles(mwSlideshow);
 
            // Optional: Re-clean styles on window resize
            window.addEventListener('resize', () => {
                cleanSlideshowStyles(mwSlideshow);
            });
 
            // Hook into slide transitions if needed (depends on the specific JS driving the slideshow)
            const slideshow = mwSlideshow.querySelector('.slideshow');
            if (slideshow) {
                const observer = new MutationObserver(() => {
                    cleanSlideshowStyles(mwSlideshow);
                });
 
                observer.observe(slideshow, {
                    attributes: true,
                    attributeFilter: ['style'],
                    childList: false,
                    subtree: false
                });
            }
        });
    }
 
    // Run once DOM is ready (in case the slideshows are injected late)
    if (document.readyState === 'complete' || document.readyState === 'interactive') {
        initSlideshowFix();
    } else {
        document.addEventListener('DOMContentLoaded', initSlideshowFix);
    }
})();