/
scripts.js
62 lines (50 loc) · 1.93 KB
/
scripts.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
// get elements
const player = document.querySelector('.player');
const video = player.querySelector('.viewer');
const palyBtn = player.querySelector('.toggle');
const skipButtons = player.querySelectorAll('.skip');
const progress = player.querySelector('.progress');
const progressBar = player.querySelector('.progress__filled');
const ranges = player.querySelectorAll('.player__slider');
// - play & pause
function togglePlay() {
const method = video.paused ? 'play' : 'pause';
video[method]();
}
function togglePlayBtn() {
const icon = this.paused ? '►' : '❚ ❚';
palyBtn.textContent = icon;
}
palyBtn.addEventListener('click', togglePlay);
video.addEventListener('click', togglePlay);
video.addEventListener('play', togglePlayBtn)
video.addEventListener('pause', togglePlayBtn)
// - skip
function skip() {
video.currentTime += parseFloat(this.dataset.skip);
}
skipButtons.forEach(skipBtn =>
skipBtn.addEventListener('click', skip)
)
// - range
function rangeUpdateHandler() {
video[this.name] = this.value; // volume / playbackRate
}
ranges.forEach(range => range.addEventListener('change', rangeUpdateHandler));
ranges.forEach(range => range.addEventListener('mousemove', rangeUpdateHandler));
// - progress
function progressHandler(){
const percent= (video.currentTime / video.duration) * 100;
progressBar.style.flexBasis = `${percent}%`;
}
video.addEventListener('timeupdate', progressHandler)
// - scrub
function scrub(e) {
const scrubTime = (e.offsetX / progress.offsetWidth) * video.duration;
video.currentTime = scrubTime;
}
let isMousedown = false;
progress.addEventListener('mousedown', () => isMousedown = true);
progress.addEventListener('mouseup', () => isMousedown = false);
progress.addEventListener('mousemove', (e) => isMousedown && scrub(e));
progress.addEventListener('click', scrub);