-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathscript.js
93 lines (72 loc) · 2.36 KB
/
script.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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
console.log("Hello world");
//Set current year
const yearEl = document.querySelector('.year');
const currentYear = new Date().getFullYear();
console.log(currentYear)
yearEl.textContent = currentYear;
//MAKE MOBILE NAV WORK
const btnNavEl = document.querySelector(".btn-mobile-nav");
const headerEl = document.querySelector(".header");
btnNavEl.addEventListener('click', function() {
headerEl.classList.toggle("nav-open");
});
/////////////////////////////////////////
//smooth scroliing animation
const allLinks = document.querySelectorAll('a:link');
allLinks.forEach(function(link) {
link.addEventListener('click', function(e) {
e.preventDefault();
const href = link.getAttribute('href');
console.log(href);
//Scroll back to top
if (href === "#") window.scrollTo({
top:0,
behavior:"smooth",
});
//Scroll to other links
if (href !== "#" && href.startsWith("#") ) {
const sectionEl = document.querySelector(href);
sectionEl.scrollIntoView({ behavior: "smooth" });
}
//close mobile nav
if (link.classList.contains('main-nav-link'))
headerEl.classList.toggle("nav-open");
});
});
/////////////////////////////////////////////
//Sticky nav
const sectionHeroEl = document.querySelector(".section-hero");
const obs = new IntersectionObserver(
function (entries) {
const ent = entries[0];
console.log(ent);
if(ent.isIntersecting === false) {
document.body.classList.add("sticky");
}
if (ent.isIntersecting === true) {
document.body.classList.remove("sticky");
}
},
{
root:null,
threshold:0,
rootMargin: "-80px",
} );
obs.observe(sectionHeroEl);
/////////////////////////////////////////
//Fixing Flexbox gap property missing in safari version
function checkFlexGap(){
var flex = document.createElement("div")
flex.style.display = "flex";
flex.style.flexDirection ="column";
flex.style.rowGap ="1px"
flex.appendChild(document.createElement("div"));
flex.appendChild(document.createElement("div"));
document.body.appendChild(flex);
var isSupported =flex.scrollHeight === 1;
flex.parentNode.removeChild(flex);
console.log(isSupported)
if(!isSupported) document.body.classList.add("no-flexbox-gap");
}
checkFlexGap();
///////////////////////////////////////////