-
Notifications
You must be signed in to change notification settings - Fork 0
/
script.js
124 lines (103 loc) · 3.14 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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
///////////////////////////////////////////////////////////
// Set current year
const yearEl = document.querySelector(".year");
yearEl.textContent= new Date().getFullYear();
///////////////////////////////////////////////////////////
// Mobile navigation
const btnNavEl = document.querySelector('.btn-mobile-nav');
const headerEl = document.querySelector('.header');
btnNavEl.addEventListener('click',function(){
headerEl.classList.toggle('nav-open');
})
///////////////////////////////////////////////////////////
// Smooth scroll
const allLinks = document.querySelectorAll('a:link');
allLinks.forEach(function(link){
link.addEventListener('click', function(e){
e.preventDefault();
const href=link.getAttribute('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 navigation
if(link.classList.contains('main-nav-link')) headerEl.classList.toggle('nav-open');
});
});
///////////////////////////////////////////////////////////
// sticky navigation
const sectionHeroEl = document.querySelector(".section-hero");
const obs = new IntersectionObserver(function(entries){
const ent = entries[0];
if(!ent.isIntersecting){
document.body.classList.add("sticky");
}
if(ent.isIntersecting){
document.body.classList.remove("sticky");
}
}, {
root:null,
threshold:0,
rootMargin: "-80px"
})
obs.observe(sectionHeroEl);
///////////////////////////////////////////////////////////
// Fixing flexbox gap property missing in some Safari versions
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();
// https://unpkg.com/[email protected]/dist/smoothscroll.min.js
/*
.no-flexbox-gap .main-nav-list li:not(:last-child) {
margin-right: 4.8rem;
}
.no-flexbox-gap .list-item:not(:last-child) {
margin-bottom: 1.6rem;
}
.no-flexbox-gap .list-icon:not(:last-child) {
margin-right: 1.6rem;
}
.no-flexbox-gap .delivered-faces {
margin-right: 1.6rem;
}
.no-flexbox-gap .meal-attribute:not(:last-child) {
margin-bottom: 2rem;
}
.no-flexbox-gap .meal-icon {
margin-right: 1.6rem;
}
.no-flexbox-gap .footer-row div:not(:last-child) {
margin-right: 6.4rem;
}
.no-flexbox-gap .social-links li:not(:last-child) {
margin-right: 2.4rem;
}
.no-flexbox-gap .footer-nav li:not(:last-child) {
margin-bottom: 2.4rem;
}
@media (max-width: 75em) {
.no-flexbox-gap .main-nav-list li:not(:last-child) {
margin-right: 3.2rem;
}
}
@media (max-width: 59em) {
.no-flexbox-gap .main-nav-list li:not(:last-child) {
margin-right: 0;
margin-bottom: 4.8rem;
}
}
*/