-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathscript.js
More file actions
104 lines (86 loc) · 3.11 KB
/
script.js
File metadata and controls
104 lines (86 loc) · 3.11 KB
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
document.addEventListener("DOMContentLoaded", () => {
/* ================= PAGE FADE ================= */
const fader = document.getElementById("page-fader");
if (fader) {
requestAnimationFrame(() => {
fader.style.opacity = 0;
fader.style.pointerEvents = "none";
});
}
window.addEventListener("pageshow", () => {
if (fader) {
fader.style.opacity = 0;
fader.style.pointerEvents = "none";
}
});
/* ================= TEAM CARD CLICK ================= */
document.querySelectorAll(".team-card").forEach(card => {
card.addEventListener("click", () => {
const target = card.dataset.target;
if (!target) return;
if (fader) fader.style.opacity = 1;
setTimeout(() => {
window.location.href = target;
}, 400);
});
});
/* ================= HAMBURGER MENU ================= */
const hamburger = document.getElementById("hamburger");
const sideMenu = document.getElementById("sideMenu");
const overlay = document.getElementById("menuOverlay");
hamburger.addEventListener("click", () => {
sideMenu.classList.toggle("active");
overlay.classList.toggle("active");
document.body.classList.toggle("menu-open");
});
overlay.addEventListener("click", () => {
sideMenu.classList.remove("active");
overlay.classList.remove("active");
document.body.classList.remove("menu-open");
});
/* ================= CLOSE MENU ON LINK CLICK ================= */
document.querySelectorAll('.side-menu a').forEach(link => {
link.addEventListener('click', () => {
document.getElementById('sideMenu').classList.remove('active');
document.getElementById('menuOverlay').classList.remove('active');
document.body.classList.remove('menu-open');
});
});
/* ================= EXPLORE TEAMS BUTTON ================= */
const exploreBtn = document.getElementById("exploreTeamsBtn");
const teamsSection = document.getElementById("teams");
if (exploreBtn && teamsSection) {
exploreBtn.addEventListener("click", () => {
const headerOffset =
document.querySelector(".site-header")?.offsetHeight || 0;
const y =
teamsSection.getBoundingClientRect().top +
window.pageYOffset -
headerOffset -
20;
window.scrollTo({ top: y, behavior: "smooth" });
});
}
/* ================= TIMELINE ================= */
document.querySelectorAll(".timeline-item").forEach(item => {
item.addEventListener("click", () => {
document
.querySelectorAll(".timeline-item")
.forEach(i => i.classList.remove("active"));
item.classList.add("active");
});
});
/* ================= HERO GEARS ================= */
const gears = [
document.getElementById("hero-gear-1"),
document.getElementById("hero-gear-2")
].filter(Boolean);
let angle = [0, 0];
window.addEventListener("scroll", () => {
angle[0] += window.scrollY * 0.0005;
angle[1] -= window.scrollY * 0.0004;
gears.forEach((g, i) => {
g.style.transform = `rotate(${angle[i]}deg)`;
});
});
});