-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathscript.js
More file actions
105 lines (82 loc) · 2.97 KB
/
script.js
File metadata and controls
105 lines (82 loc) · 2.97 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
105
/* ---------- Ambient Audio ---------- */
const audio = document.getElementById("forest-audio");
const audioBtn = document.getElementById("audio-toggle");
audioBtn.addEventListener("click", () => {
if (audio.paused) {
audio.volume = 0.3;
audio.play();
audioBtn.textContent = " ambience: on";
} else {
audio.pause();
audioBtn.textContent = " ambience: off";
}
});
/* ---------- Theme Toggle ---------- */
const themeBtn = document.getElementById("theme-toggle");
const html = document.documentElement;
themeBtn.addEventListener("click", () => {
const isNight = html.dataset.theme === "night";
html.dataset.theme = isNight ? "day" : "night";
themeBtn.textContent = isNight ? "Light Mode" : "Dark Mode";
});
/* ---------- Collapsible About ---------- */
document.querySelectorAll(".collapse-toggle").forEach(btn => {
btn.addEventListener("click", () => {
const content = btn.nextElementSibling;
content.style.display =
content.style.display === "block" ? "none" : "block";
});
});
/* ---------- Twitch Live Detection ---------- */
fetch("https://decapi.me/twitch/uptime/rhowyen")
.then(res => res.text())
.then(text => {
const status = document.querySelector(".status");
const banner = document.getElementById("offline-banner");
if (!text.toLowerCase().includes("offline")) {
status.dataset.live = "true";
status.textContent = "🔴 Live on Twitch";
banner.style.display = "none";
}
})
.catch(() => {
console.warn("Twitch status check failed");
});
/* ---------- Sparkle Trail (Desktop Only) ---------- */
document.addEventListener("mousemove", e => {
if (window.innerWidth < 768) return;
const sparkle = document.createElement("span");
sparkle.className = "sparkle";
sparkle.textContent = "✨";
sparkle.style.left = e.clientX + "px";
sparkle.style.top = e.clientY + "px";
document.body.appendChild(sparkle);
requestAnimationFrame(() => {
sparkle.style.opacity = "0";
sparkle.style.transform = "translateY(-10px)";
});
setTimeout(() => sparkle.remove(), 800);
});
/* ---------- Discord Widget Toggle (Mobile) ---------- */
const discordToggle = document.querySelector(".discord-toggle");
const discordWidget = document.querySelector(".discord-widget");
discordToggle.addEventListener("click", () => {
discordWidget.classList.toggle("open");
discordToggle.textContent = discordWidget.classList.contains("open")
? " Hide Community"
: " Join the Community";
});
/* ---------- Sync Discord Theme With Site Theme ---------- */
const discordIframe = document.getElementById("discord-iframe");
function updateDiscordTheme() {
const theme = document.documentElement.dataset.theme === "day"
? "light"
: "dark";
const baseSrc = "https://discord.com/widget?id=1219428215546712117";
discordIframe.src = `${baseSrc}&theme=${theme}`;
}
updateDiscordTheme();
themeBtn.addEventListener("click", () => {
setTimeout(updateDiscordTheme, 50);
});
/* ---------- End of Script ---------- */