2021-06-27 23:11:41 +00:00
|
|
|
const audio = document.querySelector('audio');
|
2021-06-28 00:40:24 +00:00
|
|
|
const audioPlayer = document.getElementById('audio-player');
|
|
|
|
const audioTitle = document.getElementById('audio-title');
|
2021-06-27 23:11:41 +00:00
|
|
|
const durationContainer = document.getElementById('duration');
|
|
|
|
const seekSlider = document.getElementById('seek-slider');
|
|
|
|
const currentTimeContainer = document.getElementById('current-time');
|
|
|
|
const playIconContainer = document.getElementById('play-icon');
|
|
|
|
const volumeSlider = document.getElementById('volume-slider');
|
|
|
|
|
|
|
|
const showInfo = document.getElementById('show-info');
|
|
|
|
|
2021-06-28 00:40:24 +00:00
|
|
|
let shows = document.getElementById('showlist').children;
|
2021-06-27 23:11:41 +00:00
|
|
|
|
|
|
|
for (var i = 0; i < shows.length; i += 1)
|
|
|
|
{
|
|
|
|
let show = shows[i];
|
|
|
|
let urlSpan = show.children[1];
|
|
|
|
let audioURL = urlSpan.textContent;
|
|
|
|
show.addEventListener('click', () => {
|
2021-06-28 00:40:24 +00:00
|
|
|
audioTitle.textContent = show.children[0].textContent;
|
|
|
|
audioPlayer.classList.remove('hidden');
|
2021-06-27 23:11:41 +00:00
|
|
|
audio.src = audioURL;
|
|
|
|
audio.load();
|
|
|
|
showInfo.removeChild(showInfo.children[0]);
|
|
|
|
showInfo.appendChild(show.children[2].cloneNode(true));
|
2021-06-28 00:40:24 +00:00
|
|
|
showInfo.children[0].classList.remove('hidden');
|
2021-06-27 23:11:41 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
const PlayState = {
|
|
|
|
Play: 'Play',
|
|
|
|
Pause: 'Pause'
|
|
|
|
}
|
|
|
|
|
|
|
|
let playState = PlayState.Pause;
|
|
|
|
|
|
|
|
const calculateTimeString = (secs) => {
|
|
|
|
const hours = Math.floor(secs / (60 * 60));
|
|
|
|
const minutes = String(Math.floor(secs / 60) - (60 * hours)).padStart(2, '0');
|
|
|
|
const seconds = String(Math.floor(secs % 60)).padStart(2, '0');
|
|
|
|
return `${hours}:${minutes}:${seconds}`;
|
|
|
|
}
|
|
|
|
|
|
|
|
const displayDuration = () => {
|
|
|
|
durationContainer.textContent = calculateTimeString(audio.duration);
|
|
|
|
}
|
|
|
|
|
|
|
|
const setSliderMax = () => {
|
|
|
|
seekSlider.max = Math.floor(audio.duration);
|
|
|
|
}
|
|
|
|
|
|
|
|
seekSlider.addEventListener('input', () => {
|
|
|
|
currentTimeContainer.textContent = calculateTimeString(seekSlider.value);
|
|
|
|
});
|
|
|
|
|
|
|
|
seekSlider.addEventListener('change', () => {
|
|
|
|
audio.currentTime = seekSlider.value;
|
|
|
|
currentTimeContainer.textContent = calculateTimeString(seekSlider.value);
|
|
|
|
});
|
|
|
|
|
|
|
|
audio.addEventListener('timeupdate', () => {
|
|
|
|
seekSlider.value = Math.floor(audio.currentTime);
|
|
|
|
currentTimeContainer.textContent = calculateTimeString(seekSlider.value);
|
|
|
|
});
|
|
|
|
|
|
|
|
playIconContainer.addEventListener('click', () => {
|
|
|
|
if(playState === PlayState.Pause) {
|
|
|
|
audio.play();
|
|
|
|
playState = PlayState.Play;
|
2021-06-28 00:40:24 +00:00
|
|
|
playIconContainer.textContent = '❚❚';
|
2021-06-27 23:11:41 +00:00
|
|
|
} else {
|
|
|
|
audio.pause();
|
|
|
|
playState = PlayState.Pause;
|
2021-06-28 00:40:24 +00:00
|
|
|
playIconContainer.textContent = '▶';
|
2021-06-27 23:11:41 +00:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
volumeSlider.addEventListener('input', (e) => {
|
|
|
|
const value = e.target.value;
|
|
|
|
audio.volume = value / 100;
|
|
|
|
});
|
|
|
|
|
|
|
|
if (audio.readyState > 0) {
|
|
|
|
displayDuration();
|
|
|
|
setSliderMax();
|
|
|
|
} else {
|
|
|
|
audio.addEventListener('loadedmetadata', () => {
|
|
|
|
displayDuration();
|
|
|
|
setSliderMax();
|
|
|
|
});
|
|
|
|
}
|