MediaWiki:Common.js:修订间差异

来自Fuckrooms Wiki
无编辑摘要
无编辑摘要
 
(未显示4个用户的26个中间版本)
第1行: 第1行:
/* 这里的任何JavaScript将为所有用户在每次页面加载时加载。 */
// console.log("Hello World!");
/* CSS模板 */
(function() {
(function() {
   var importCssDivs = document.querySelectorAll('div.import-css');
   var importCssDivs = document.querySelectorAll('div.import-css');
第14行: 第18行:
   });
   });
})();
})();
importScript('MediaWiki:Importjs/'+ wgPageName + '.js');


/* 落叶特效 */
(function(){
(function(){
     if (!document.getElementById('snow-style')) {
     if (!document.getElementById('snow-style')) {
第21行: 第25行:
         style.id = 'snow-style';
         style.id = 'snow-style';
         style.textContent = `
         style.textContent = `
             @keyframes snowFall {
             @keyframes snowRise {
                 0% { transform: translateY(-110px) rotate(0deg); }
                 0% {  
                 100% { transform: translateY(calc(100vh + 130px)) rotate(9000deg); }
                    transform: translateY(0) rotate(0deg);  
                    bottom: -130px;
                }
                 100% {  
                    transform: translateY(-100vh) rotate(80deg);
                    bottom: calc(100% + 130px);
                }
             }
             }
             .snowflake {
             .snowflake {
                 position: fixed;
                 position: fixed;
                 top: -130px;
                 bottom: -130px;
                 z-index: 9999;
                 z-index: 9999;
                 pointer-events: none;
                 pointer-events: none;
                 user-select: none;
                 user-select: none;
                 animation-timing-function: linear;
                 animation-timing-function: linear;
                will-change: transform;
             }
             }
         `;
         `;
第37行: 第48行:
     }
     }


   
     function createSnowflake() {
     function createSnowflake() {
         const snowflake = document.createElement('div');
         const snowflake = document.createElement('div');
         snowflake.className = 'snowflake';
         snowflake.className = 'snowflake';
         const icons = ['🍀','☘️','🍃','🌿'];
         const icons = ['🎂','🎂'];
         snowflake.innerHTML = icons[Math.floor(Math.random() * 4)];
         snowflake.innerHTML = icons[Math.floor(Math.random() * icons.length)];
         const size = Math.random() * 16 + 8;
         const size = Math.random() * 32 + 8;
         const left = Math.random() * 100;
         const left = Math.random() * 100;
         const duration = Math.random() * 8 + 8;
         const duration = Math.random() * 8 + 8;
第49行: 第59行:
             font-size: ${size}px;
             font-size: ${size}px;
             left: ${left}%;
             left: ${left}%;
             animation: snowFall ${duration}s linear 1; // 移除delay参数
             animation: snowRise ${duration}s linear forwards;
             opacity: ${Math.random() * 0.5 + 0.5};
             opacity: ${Math.random() * 0.5 + 0.5};
             color: hsl(${Math.random() * 360}, 100%, 90%);
             color: hsl(${Math.random() * 360}, 100%, 90%);
         `;
         `;


     
        // 确保动画结束后移除元素
         snowflake.addEventListener('animationend', function() {
         const removeSnowflake = () => {
             snowflake.remove();
             snowflake.remove();
         });
            snowflake.removeEventListener('animationend', removeSnowflake);
         };
        snowflake.addEventListener('animationend', removeSnowflake);


         document.body.appendChild(snowflake);
         document.body.appendChild(snowflake);
     }
     }


   
     let interval = setInterval(createSnowflake, 250);
     let interval = setInterval(createSnowflake, 250);


   
     document.addEventListener('visibilitychange', function() {
     document.addEventListener('visibilitychange', function() {
         if (document.hidden) {
         if (document.hidden) {
第74行: 第84行:
     });
     });


      
     // 初始创建雪花
     for (let i = 0; i < 10; i++) {
     for (let i = 0; i < 10; i++) {
         createSnowflake();
         createSnowflake();
     }
     }
})();
})();
importScript('MediaWiki:Importjs/'+ wgPageName + '.js');
/*
* Script Name: Template CSS
* Author: Fandom Backrooms
*/
(function () {
    const eles = document.querySelectorAll('.js-action-play');
    eles.forEach(function (e) {
        const targetId = e.getAttribute('data-media-id');
        if (!targetId) {
            console.error('No data-media-id present on element', e);
            return;
        }
        const target = document.getElementsByClassName('media-id-' + targetId)[0];
        if (!target) {
            console.error('No element found with .media-id-' + targetId, e);
            return;
        }
        e.addEventListener('click', function () {
            console.log(target);
            if (target.paused || target.ended) {
                target.play();
            } else {
                target.pause();
            }
        });
    });
})();
mw.loader.load(["mediawiki.util", "mediawiki.Title"]);
mw.hook("wikipage.content").add(function () {
    $("span.import-css").each(function () {
    mw.util.addCSS($(this).attr("data-css"));
    });
   
    $(".sitenotice-tab-container").each(function() {
var container = $(this);
function switchTab(offset) {
return function() {
var tabs = container.children(".sitenotice-tab").toArray();
var no = Number(container.find(".sitenotice-tab-no")[0].innerText) + offset;
var count = tabs.length;
if (no < 1) no = count;
else if (no > count) no = 1;
for (var i = 0; i < count; i++)
tabs[i].style.display = (i + 1 == no ? null : "none");
container.find(".sitenotice-tab-no")[0].innerText = no;
};
}
container.find(".sitenotice-tab-arrow.prev").click(switchTab(-1));
container.find(".sitenotice-tab-arrow.next").click(switchTab(1));
});
});
$.getJSON(mw.util.wikiScript("index"), {
    title: "MediaWiki:Custom-import-scripts.json",
    action: "raw"
}).done(function (result, status) {
    if (status != "success" || typeof (result) != "object") return;
    var scripts = result[mw.config.get("wgPageName")];
    if (scripts) {
        if (typeof (scripts) == "string") scripts = [scripts];
        importArticles({ type: "script", articles: scripts });
    }
});

2025年8月8日 (五) 15:10的最新版本

/* 这里的任何JavaScript将为所有用户在每次页面加载时加载。 */
// console.log("Hello World!");

/* CSS模板 */
(function() {
  var importCssDivs = document.querySelectorAll('div.import-css');

  importCssDivs.forEach(function(div) {
    var cssContent = div.textContent || div.innerText;

    if (cssContent) {
      var styleTag = document.createElement('style');
      styleTag.type = 'text/css';
	  styleTag.appendChild(document.createTextNode(cssContent));

      document.head.appendChild(styleTag);
    }
  });
})();

/* 落叶特效 */
(function(){
    if (!document.getElementById('snow-style')) {
        const style = document.createElement('style');
        style.id = 'snow-style';
        style.textContent = `
            @keyframes snowRise {
                0% { 
                    transform: translateY(0) rotate(0deg); 
                    bottom: -130px;
                }
                100% { 
                    transform: translateY(-100vh) rotate(80deg); 
                    bottom: calc(100% + 130px);
                }
            }
            .snowflake {
                position: fixed;
                bottom: -130px;
                z-index: 9999;
                pointer-events: none;
                user-select: none;
                animation-timing-function: linear;
                will-change: transform;
            }
        `;
        document.head.appendChild(style);
    }

    function createSnowflake() {
        const snowflake = document.createElement('div');
        snowflake.className = 'snowflake';
        const icons = ['🎂','🎂'];
        snowflake.innerHTML = icons[Math.floor(Math.random() * icons.length)];
        const size = Math.random() * 32 + 8;
        const left = Math.random() * 100;
        const duration = Math.random() * 8 + 8;
        snowflake.style.cssText = `
            font-size: ${size}px;
            left: ${left}%;
            animation: snowRise ${duration}s linear forwards;
            opacity: ${Math.random() * 0.5 + 0.5};
            color: hsl(${Math.random() * 360}, 100%, 90%);
        `;

        // 确保动画结束后移除元素
        const removeSnowflake = () => {
            snowflake.remove();
            snowflake.removeEventListener('animationend', removeSnowflake);
        };
        snowflake.addEventListener('animationend', removeSnowflake);

        document.body.appendChild(snowflake);
    }

    let interval = setInterval(createSnowflake, 250);

    document.addEventListener('visibilitychange', function() {
        if (document.hidden) {
            clearInterval(interval);
        } else {
            interval = setInterval(createSnowflake, 250);
        }
    });

    // 初始创建雪花
    for (let i = 0; i < 10; i++) {
        createSnowflake();
    }
})();