跳转到内容

MediaWiki:Gadget-AudioText.js

来自电棍ottowiki
OctoberSama留言 | 贡献2025年5月24日 (六) 23:45的版本

注意:在发布之后,您可能需要清除浏览器缓存才能看到所作出的更改的影响。

  • Firefox或Safari:按住Shift的同时单击刷新,或按Ctrl-F5Ctrl-R(Mac为⌘-R
  • Google Chrome:Ctrl-Shift-R(Mac为⌘-Shift-R
  • Edge:按住Ctrl的同时单击刷新,或按Ctrl-F5
// MediaWiki:Gadget-AudioText.js
(function() {
    const audioUrlCache = new Map();

    function handlePlay(element) {
        const audioFile = element.dataset.audioFile;
        if (audioUrlCache.has(audioFile)) {
            new Audio(audioUrlCache.get(audioFile)).play();
            return;
        }

        const apiUrl = mw.util.wikiScript('api') + '?action=query&titles=' + 
            encodeURIComponent(audioFile) + '&prop=imageinfo&iiprop=url&format=json';

        fetch(apiUrl)
            .then(response => response.json())
            .then(data => {
                const pages = data.query.pages;
                const pageId = Object.keys(pages)[0];
                const audioUrl = pages[pageId].imageinfo[0].url;
                audioUrlCache.set(audioFile, audioUrl);
                new Audio(audioUrl).play();
            });
    }

    function initAudioTriggers() {
        document.querySelectorAll('.audio-trigger').forEach(element => {
            if (element._audioBound) return;
            element._audioBound = true;

            // 修改事件处理逻辑
            const handler = (event) => {
                // 关键修改:不阻止默认行为和冒泡
                const toggle = element.closest('.mw-customtoggle');
                if (toggle) {
                    // 手动触发折叠状态切换
                    mw.collapse.handleClicks(event);
                }
                handlePlay(element);
            };

            element.addEventListener('click', handler);
            element.addEventListener('touchstart', handler);
        });
    }

    mw.hook('wikipage.content').add(initAudioTriggers);
    mw.loader.using(['mediawiki.api', 'mediawiki.collapse']).then(initAudioTriggers);
})();