Template:AudioPlayer: Difference between revisions

From Tuyin Archives
No edit summary
Tag: Reverted
No edit summary
Tag: Manual revert
 
(28 intermediate revisions by the same user not shown)
Line 1: Line 1:
<includeonly><html>
<includeonly>{{#tag:div|Loading audio player...|class=audioplayer|data-filename={{{1}}}|data-caption={{{2|Audio File}}}}}</includeonly>
<audio id="audio_{{{1}}}" preload="auto">
  <source src="https://tuyin.online/images/{{{1}}}" type="audio/ogg">
</audio>
<script>
(function() {
    var audioId = 'audio_{{{1}}}';
    var btnId = 'btn_{{{1}}}';
    var progId = 'prog_{{{1}}}';
    var audio = document.getElementById(audioId);
    var isPlaying = false;
   
    window['togglePlay_' + '{{{1}}}'.replace(/[^a-zA-Z0-9]/g, '')] = function() {
        var button = document.getElementById(btnId);
        if (isPlaying) {
            audio.pause();
            button.innerHTML = '▶️';
            isPlaying = false;
        } else {
            audio.play();
            button.innerHTML = '⏸️';
            isPlaying = true;
        }
    };
   
    audio.addEventListener('timeupdate', function() {
        var progress = document.getElementById(progId);
        var percentage = (audio.currentTime / audio.duration) * 100;
        progress.style.width = percentage + '%';
    });
   
    audio.addEventListener('ended', function() {
        document.getElementById(btnId).innerHTML = '▶️';
        isPlaying = false;
        document.getElementById(progId).style.width = '0%';
    });
})();
</script>
 
<div style="display: inline-flex; align-items: center; gap: 12px;">
    <div style="border: 1px solid #8B7355; padding: 8px; display: inline-block; border-radius: 4px; background-color: #F5F0E8; width: 200px;">
        <button id="btn_{{{1}}}" onclick="window['togglePlay_' + '{{{1}}}'.replace(/[^a-zA-Z0-9]/g, '')]();" style="padding: 4px 8px; margin-right: 8px; font-size: 12px; border: 1px solid #8B7355; background: #D4C4A8; color: #5D4E37;">▶️</button>
        <div style="display: inline-block; width: 120px; height: 6px; background-color: #D4C4A8; border-radius: 3px; vertical-align: middle;">
            <div id="prog_{{{1}}}" style="height: 100%; background-color: #8B7355; border-radius: 3px; width: 0%; transition: width 0.1s;"></div>
        </div>
    </div>
    <span style="color: #8B7355; font-style: italic;">{{{2|Audio File}}}</span>
</div>
</html></includeonly>

Latest revision as of 20:23, 23 July 2025