MediaWiki:Test.js: различия между версиями

Страница интерфейса MediaWiki
Нет описания правки
Метка: отменено
Нет описания правки
Метка: ручная отмена
Строка 1: Строка 1:
(function() {
(function() {
     if (window.halloweenScriptLoaded) return;
     var today = new Date();
     window.halloweenScriptLoaded = true;
    var month = today.getMonth() + 1;
     if (month === 10 || month === 11) {
        mw.loader.load('/w/index.php?title=MediaWiki:Test.css&action=raw&ctype=text/css');


    var body = document.body;
        mw.hook('wikipage.content').add(function($content) {
            var leaves = document.createElement('div');
            leaves.className = 'halloween-leaves';
            document.body.appendChild(leaves);


    function createLeaf() {
            for (var i = 0; i < 30; i++) {
        var leaf = document.createElement('span');
                var leaf = document.createElement('span');
        leaf.className = 'halloween-leaf';
                leaf.className = 'halloween-leaf';
        leaf.innerHTML = '🍂';
                leaf.innerHTML = ['🍂','🍁','🦇','🕸️'][Math.floor(Math.random()*4)];
        leaf.style.left = Math.random() * window.innerWidth + 'px';
                leaf.style.left = Math.random()*100+'%';
        leaf.style.fontSize = (10 + Math.random() * 20) + 'px';
                leaf.style.animationDelay = (Math.random()*5)+'s';
        leaf.style.opacity = Math.random();
                leaf.style.fontSize = (12+Math.random()*24)+'px';
        leaf.style.animationDuration = (5 + Math.random() * 5) + 's';
                leaves.appendChild(leaf);
        body.appendChild(leaf);
            }
        setTimeout(function() {
 
            body.removeChild(leaf);
            var firstHeading = document.getElementById('firstHeading');
        }, 10000);
            if (firstHeading) {
    }
                var pumpkin = document.createElement('span');
                pumpkin.className = 'halloween-pumpkin';
                pumpkin.innerHTML = ' 🎃 ';
                firstHeading.appendChild(pumpkin);
            }


    function createPumpkin() {
            var links = document.getElementsByTagName('a');
        var pumpkin = document.createElement('span');
            for (var i = 0; i < links.length; i++) {
        pumpkin.className = 'halloween-pumpkin';
                links[i].style.transition = 'color 0.3s ease, text-shadow 0.3s ease';
        pumpkin.innerHTML = '🎃';
                links[i].onmouseover = function() { this.style.color = '#ffa500'; this.style.textShadow = '0 0 8px #ffa500'; };
        pumpkin.style.position = 'fixed';
                links[i].onmouseout = function() { this.style.color = ''; this.style.textShadow = ''; };
        pumpkin.style.left = Math.random() * window.innerWidth + 'px';
             }
        pumpkin.style.top = (window.innerHeight - 50) * Math.random() + 'px';
         });
        pumpkin.style.fontSize = (20 + Math.random() * 30) + 'px';
        pumpkin.style.opacity = 0.8;
        body.appendChild(pumpkin);
        setTimeout(function() {
             body.removeChild(pumpkin);
         }, 10000);
     }
     }
    setInterval(createLeaf, 500);      // каждые 0.5 секунды падает лист
    setInterval(createPumpkin, 2000);  // каждые 2 секунды летает тыква
})();
})();

Версия от 17:58, 23 октября 2025

(function() {
    var today = new Date();
    var month = today.getMonth() + 1;
    if (month === 10 || month === 11) {
        mw.loader.load('/w/index.php?title=MediaWiki:Test.css&action=raw&ctype=text/css');

        mw.hook('wikipage.content').add(function($content) {
            var leaves = document.createElement('div');
            leaves.className = 'halloween-leaves';
            document.body.appendChild(leaves);

            for (var i = 0; i < 30; i++) {
                var leaf = document.createElement('span');
                leaf.className = 'halloween-leaf';
                leaf.innerHTML = ['🍂','🍁','🦇','🕸️'][Math.floor(Math.random()*4)];
                leaf.style.left = Math.random()*100+'%';
                leaf.style.animationDelay = (Math.random()*5)+'s';
                leaf.style.fontSize = (12+Math.random()*24)+'px';
                leaves.appendChild(leaf);
            }

            var firstHeading = document.getElementById('firstHeading');
            if (firstHeading) {
                var pumpkin = document.createElement('span');
                pumpkin.className = 'halloween-pumpkin';
                pumpkin.innerHTML = ' 🎃 ';
                firstHeading.appendChild(pumpkin);
            }

            var links = document.getElementsByTagName('a');
            for (var i = 0; i < links.length; i++) {
                links[i].style.transition = 'color 0.3s ease, text-shadow 0.3s ease';
                links[i].onmouseover = function() { this.style.color = '#ffa500'; this.style.textShadow = '0 0 8px #ffa500'; };
                links[i].onmouseout = function() { this.style.color = ''; this.style.textShadow = ''; };
            }
        });
    }
})();