const discStatuses = { "online": { "text": "Online", "color": "rgb(100, 255, 100)" }, "dnd": { "text": "DND", "color": "rgb(255, 100, 100)" }, "idle": { "text": "Idle", "color": "rgb(255, 255, 75)" }, "offline": { "text": "", "color": "rgb(175, 175, 200)" } } var pfp var music = new Audio("/snds/Lotus Waters.ogg") var whipLash = new Audio("/snds/johnny-test-whip-crack.mp3") music.loop = true music.volume = 0.45 whipLash.volume = 0.25 var sock var spins = 1 var globalSpins = 0 var firsttimeDebounce = true var spinWaiting = false function resetPFP() { pfp.src = "https://api.violets-purgatory.dev/v1/pfp?" + new Date().getTime() } function spinLoop() { spinWaiting = true setTimeout(() => { spinWaiting = false if (!music.paused) { if (spins > 1) { document.querySelector(".spinnyCount").style.display = "block" document.querySelector(".localSpins").innerHTML = Math.ceil(spins - 1); } spins += 0.5 if (Math.round(spins) == spins && sock && sock.OPEN) { // resetPFP() sock.send(`{"op": 4}`) console.log("Spin Sent!") } spinLoop() } }, 1500); } window.onbeforeunload = function () { window.scrollTo(0, 0); } window.onload = function () { window.scrollTo(0, 0); pfp = document.querySelector(".pfp") pfp.addEventListener("mousedown", () => { if (!spinWaiting) { spinLoop(); } music.play() pfp.style.animationName = "spinny" pfp.style.scale = "1.1" }) document.body.onmouseup = () => { if (music.currentTime != 0) { music.currentTime = 0 music.pause() whipLash.currentTime = 0 whipLash.play() pfp.style.animationName = "unset" pfp.style.scale = "1" } } socketeer() } var lastPong = Date.now() function ping(dur) { sock.send(JSON.stringify({ op: 3 })) setTimeout(() => { ping(dur) if (Date.now() - lastPong > 120000) { sock.close() console.log("Max duration since last pong exceeded- Closing socket.") } }, dur); } function socketeer() { sock = new WebSocket('wss://api.violets-purgatory.dev') sock.addEventListener("open", () => { ping(30000) }) sock.addEventListener("error", (error) => { console.log(error) }) sock.addEventListener("close", () => { console.log("Connection Closed. Attempting Reconnect in 30 seconds.") setTimeout(() => { socketeer() }, 30000); }) sock.addEventListener("message", async (data) => { data = data.data data = JSON.parse(data) if (data.op == 4) { globalSpins = data.spins if (firsttimeDebounce == true) { firsttimeDebounce = false document.querySelector(".globalSpins").innerHTML = globalSpins + 1; } else { document.querySelector(".globalSpins").innerHTML = globalSpins; } } else if (data.op == 0) { var lanyard = data.d var statusInfo = discStatuses[lanyard.discord_status] var lastStatus = document.querySelector(".statusColor") if (lastStatus.innerHTML != statusInfo.text) { lastStatus.innerHTML = statusInfo.text lastStatus.style.color = statusInfo.color pfp.style.borderColor = lastStatus.style.color resetPFP() } if (lanyard.activities[0] && lanyard.activities[0].type == 4) { document.querySelector(".customStatus").innerHTML = `
${lanyard.activities[0].state}
` } else { document.querySelector(".customStatus").innerHTML = "" } var discFetch = await (await fetch("/discHTML")).text() document.querySelector("#activityHtml").innerHTML = discFetch } else if (data.op == 3) { lastPong = Date.now() } else { console.log(data) } }) }