-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathutil.js
More file actions
67 lines (58 loc) · 1.73 KB
/
util.js
File metadata and controls
67 lines (58 loc) · 1.73 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
function createBox() {
//creating dom elements
let stickyPad = document.createElement("div");
let nav = document.createElement("div");
let minimize = document.createElement("div");
let closeBtn = document.createElement("div");
let content = document.createElement("div");
// setting attributes
stickyPad.setAttribute("class", "stickyPad");
nav.setAttribute("class", "nav");
minimize.setAttribute("class", "minimize");
closeBtn.setAttribute("class", "close");
content.setAttribute("class", "content");
//appending elements
stickyPad.append(nav);
stickyPad.append(content);
nav.append(minimize);
nav.append(closeBtn);
document.body.append(stickyPad);
let isStickyHolded = false;
let initialX;
let initialY;
nav.addEventListener("mousedown", function (e) {
isStickyHolded = true;
initialX = e.clientX;
initialY = e.clientY;
});
window.addEventListener("mousemove", function (e) {
if (isStickyHolded) {
let finalX = e.clientX;
let finalY = e.clientY;
let dx = finalX - initialX;
let dy = finalY - initialY;
let { top, left } = stickyPad.getBoundingClientRect();
stickyPad.style.top = top + dy + "px";
stickyPad.style.left = left + dx + "px";
initialX = finalX;
initialY = finalY;
}
});
nav.addEventListener("mouseup", function (e) {
isStickyHolded = false;
});
closeBtn.addEventListener("click", function () {
stickyPad.remove();
});
let isMinimized = false;
minimize.addEventListener("click", function () {
if (isMinimized) {
content.style.display = "block";
isMinimized = !isMinimized;
} else {
content.style.display = "none";
isMinimized = !isMinimized;
}
});
return content;
}