-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmenu.js
40 lines (37 loc) · 1.47 KB
/
menu.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
document.onclick = hideMenu;
window.oncontextmenu = rightClick;
function hideMenu() {
document.getElementById("contextMenu")
.style.transform = "scale(0)"
setTimeout(() => {
document.getElementById("contextMenu")
.style.display = 'none'
}, 200)
}
function rightClick(e) {
e.preventDefault();
var menu = document.getElementById("contextMenu")
if (window.innerWidth - e.clientX <= menu.getBoundingClientRect().width) {
if (e.clientY >= menu.getBoundingClientRect().height) {
menu.style.display = 'block';
menu.style.transform = 'scale(1)';
menu.style.left = e.pageX - menu.getBoundingClientRect().width + "px";
menu.style.top = e.pageY - menu.getBoundingClientRect().height + "px";
} else {
menu.style.display = 'block';
menu.style.transform = 'scale(1)';
menu.style.left = e.pageX - menu.getBoundingClientRect().width + "px";
menu.style.top = e.pageY + "px";
}
} else if (window.innerHeight - e.clientY <= menu.getBoundingClientRect().height) {
menu.style.display = 'block';
menu.style.transform = 'scale(1)';
menu.style.left = e.pageX + "px";
menu.style.top = e.pageY - menu.getBoundingClientRect().height + "px";
} else {
menu.style.display = 'block';
menu.style.transform = 'scale(1)';
menu.style.left = e.pageX + "px";
menu.style.top = e.pageY + "px";
}
}