-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathscript.js
More file actions
83 lines (56 loc) · 1.9 KB
/
script.js
File metadata and controls
83 lines (56 loc) · 1.9 KB
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
63
64
65
66
67
68
69
70
71
72
73
74
// First we get our elements from the DOM
const player=document.querySelector('.player');
const video=player.querySelector('.viewer');
const progress=player.querySelector('.progress');
const progressBar=player.querySelector('.progress__filled');
const toggle=player.querySelector('.toggle');
const skipButtons=player.querySelectorAll('[data-skip]');
const ranges=player.querySelectorAll('.player__slider');
progressBar.style.width=0;
//Build out functions
function togglePlay(){
if(video.paused){
video.play();
}
else{
video.pause();
}
}
function updateButton(){
const icon=this.paused? '►' : '❚ ❚';
toggle.textContent = icon;
console.log("updateButton")
}
function skip(){
video.currentTime += parseFloat(this.dataset.skip);
}
function handleRangeUpdate(){
video[this.name]=this.value;
console.log(this.value);
}
function handleProgress(){
const percent=(video.currentTime/video.duration)*100;
progressBar.style.flexBasis=`${percent}%`;
}
function scrub(e){
const scrubTime=(e.offsetX/progress.offsetWidth)*video.duration;
video.currentTime = scrubTime;
}
//Hook up for the event listeners
video.addEventListener('click', togglePlay);
video.addEventListener('play', updateButton);
video.addEventListener('pause', updateButton);
video.addEventListener('timeupdate', handleProgress);
toggle.addEventListener('click', togglePlay);
skipButtons.forEach(button => button.addEventListener('click', skip));
ranges.forEach(range => range.addEventListener('change', handleRangeUpdate));
ranges.forEach(range => range.addEventListener('mousemove', handleRangeUpdate));
progress.addEventListener('click', scrub);
let mousedown=false;
progress.addEventListener('mousemove', ()=>{
if(!mousedown){
scrub();
}
});
progress.addEventListener('mousedown',()=> mousedown=true);
progress.addEventListener('mouseup',()=> mousedown=false);