-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmainmy.js
56 lines (47 loc) · 2.05 KB
/
mainmy.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
const showMenu = (toggleId, navId) => {
const toggle = document.getElementById(toggleId),
nav = document.getElementById(navId);
if (toggle && nav) {
toggle.addEventListener('click', () => {
nav.classList.toggle('show');
});
}
};
showMenu('nav-toggle', 'nav-menu');
/*==================== REMOVE MENU MOBILE ====================*/
const navLink = document.querySelectorAll('.nav__link');
function linkAction() {
const navMenu = document.getElementById('nav-menu');
// When we click on each nav__link, we remove the show-menu class
navMenu.classList.remove('show');
}
navLink.forEach(n => n.addEventListener('click', linkAction));
/*==================== SCROLL SECTIONS ACTIVE LINK ====================*/
const sections = document.querySelectorAll('section[id]');
const scrollActive = () => {
const scrollDown = window.scrollY;
sections.forEach(current => {
const sectionHeight = current.offsetHeight,
sectionTop = current.offsetTop - 58,
sectionId = current.getAttribute('id'),
sectionsClass = document.querySelector('.nav__menu a[href*=' + sectionId + ']');
if (scrollDown > sectionTop && scrollDown <= sectionTop + sectionHeight) {
sectionsClass?.classList.add('active-link');
} else {
sectionsClass?.classList.remove('active-link');
}
});
};
window.addEventListener('scroll', scrollActive);
/*===== SCROLL REVEAL ANIMATION =====*/
const sr = ScrollReveal({
origin: 'top',
distance: '60px',
duration: 2000,
delay: 200,
// reset: true // Uncomment to make animations repeat when scrolling
});
sr.reveal('.home__data, .about__img, .skills__subtitle, .skills__text', {});
sr.reveal('.home__img, .about__subtitle, .about__text, .skills__img', { delay: 400 });
sr.reveal('.home__social-icon', { interval: 200 });
sr.reveal('.skills__data, .work__img, .contact__input', { interval: 200 });