-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.js
56 lines (45 loc) · 1.17 KB
/
main.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
(function () {
'use strict';
let filter = document.querySelector('.filter');
let line = document.querySelector('.line');
/*
let mouseX;
document.addEventListener('mousemove', (e) => {
mouseX = e.clientX;
line.style.left = mouseX + 'px';
filter.style.width = `calc(${mouseX}px)`;
});
*/
let isDragged;
let posX;
let boundingClientRect;
let grabPointX;
function dragStart(e) {
e.preventDefault();
isDragged = this;
boundingClientRect = isDragged.getBoundingClientRect();
grabPointX = boundingClientRect.left - e.clientX;
}
function onDrag(e) {
if (!isDragged) {
return;
}
posX = e.clientX + grabPointX;
console.log(`posX ${posX}`);
console.log(`e.clientX ${e.clientX}`);
if (posX < 0) {
posX = 0;
}
isDragged.style.transform = `translate(${posX - 1000}px)`;
filter.style.width = `calc(${posX}px)`;
}
function dragStop() {
isDragged = null;
posX = null;
boundingClientRect = null;
grabPointX = null;
}
line.addEventListener('mousedown', dragStart, false);
document.addEventListener('mousemove', onDrag, false);
document.addEventListener('mouseup', dragStop, false);
})();