forked from ayush-that/FinVeda
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathnavbar.js
68 lines (60 loc) · 1.83 KB
/
navbar.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
63
64
65
66
67
68
const mobile_menu = document.querySelector(".mobile-menu"),
mobile_trigger = document.querySelector(".mobile-menu__trigger");
let initialPoint,
finalPoint;
document.addEventListener("touchstart", function(event) {
initialPoint = event.changedTouches[0];
});
document.addEventListener("touchend", function(event) {
finalPoint = event.changedTouches[0];
let xAbs = Math.abs(initialPoint.pageX - finalPoint.pageX),
yAbs = Math.abs(initialPoint.pageY - finalPoint.pageY);
if(xAbs > 120 || yAbs > 120) { // 120 - SWIPE WIDTH
if(xAbs > yAbs) {
if(finalPoint.pageX < initialPoint.pageX) {
// SWIPE LEFT
mobile_menu.classList.remove("mobile-menu_open");
} else {
// SWIPE RIGTH
mobile_menu.classList.add("mobile-menu_open");
}
} else {
if(finalPoint.pageY < initialPoint.pageY) {
// SWIPE UP
} else {
// SWIPE DOWN
}
}
}
});
document.addEventListener("click", function(event) {
const target = event.target.closest(".mobile-menu__trigger");
if(target && target == mobile_trigger) {
mobile_menu.classList.toggle("mobile-menu_open");
} else if(event.target !== mobile_trigger && event.target !== mobile_menu) {
if( mobile_menu.classList.contains("mobile-menu_open") ) {
mobile_menu.classList.remove("mobile-menu_open");
}
}
});
mobile_menu.querySelectorAll("a").forEach(function(element) {
element.addEventListener("click", function(event) {
const anchor_href = event.currentTarget.getAttribute("href");
if(anchor_href.charAt(0) === "#") {
event.preventDefault();
if(anchor_href.length > 1) { // if #hash is not empty
const scroll_to_node = document.querySelector(event.currentTarget.hash);
if(scroll_to_node) {
SmoothScrollTo(scroll_to_node);
}
}
}
});
});
function SmoothScrollTo(element) {
if(element) {
element.scrollIntoView({
behavior: "smooth"
});
}
}