const badgeGray = document.getElementById("badgeGray"); const badgeGreen = document.getElementById("badgeGreen"); const badgeOrange = document.getElementById("badgeOrange"); const badgePurple = document.getElementById("badgePurple"); // generate a number between 1 and 3, also generate a random bool (true/false), if the number is 3 AND false, purple const maxCol = 3 const minCol = 1 const randomCol = Math.floor(Math.random() * (maxCol - minCol + 1)) + minCol; const is_root = location.pathname === "/"; const badgeAmount = 20 // loads all the functions to be loaded on load, pretty simple, it loads shit on load. function onLoad() { jsEnabled(); checkThemeStorage(); getSGAState(); redirect(); checkBoxes(); getPlaceholder(); } // if javascript is enabled, this script will load, enabling all site elements that use javascript, by default these are all hidden. function jsEnabled() { // if on main page, activate widgets if (is_root) { const lastFmWidget = document.getElementById("lastfm-widget"); const ntfyWidgetContainer = document.getElementById("ntfyWidgetContainer"); lastFmWidget.style.display = "initial"; ntfyWidgetContainer.style.display = "initial"; } // Get JS required element ids const sgaButton = document.getElementById("sgaButton"); const sgaButtonText = document.getElementById("sgaButtonText"); const incrementButton = document.getElementById("incrementButton"); // enable js required element ids sgaButton.style.display = "initial"; sgaButtonText.style.visibility = "initial"; incrementButton.style.display = "initial"; // badge for (var badgeNum = 0; badgeNum < badgeAmount; badgeNum++) { document.getElementById('badge' + (badgeNum + 1)).style.display = "initial"; } for (var badgeDefaultNum = 0; badgeDefaultNum < badgeAmount; badgeDefaultNum++) { document.getElementById('badgeDefault' + (badgeDefaultNum + 1)).style.display = "none"; } getbadges() } // LastFM stuff const user = "limepotato"; const url = `https://lastfm-last-played.biancarosa.com.br/${user}/latest-song`; const song = document.querySelector("#song"); fetch(url) .then((response) => response.json()) .then((json) => { song.innerHTML = `${json.track.name} - ${json.track.artist["#text"]}`; }); // Chrome Redirect function redirect() { const chromium = /Chrome|Chromium|OPR|Opera|Edge|UC|QQ/.test( navigator.userAgent, ); if (navigator.brave) { window.location.replace("https://www.youtube.com/watch?v=dQw4w9WgXcQ"); } if (!navigator.brave) { if (!localStorage.getItem("disclaimerAccepted")) { if (chromium && screen.width >= 699) { window.location.replace("/bsod"); } if (chromium && screen.width <= 699) { window.location.replace("/mobile-warn"); } } } } // Show/Hide Info Boxes const posterInfoButton = document.getElementById("poster-info-button"); const posterInfo = document.getElementById("poster-info"); let isPosterInfoHidden = true; const ntfyInfoButton = document.getElementById("ntfy-info-button"); const ntfyInfo = document.getElementById("ntfy-info"); let isNtfyInfoHidden = true; function showPosterInfo() { if (isPosterInfoHidden) { posterInfo.style.display = "initial"; posterInfoButton.innerHTML = "[hide more info]"; isPosterInfoHidden = false; } else { posterInfo.style.display = "none"; posterInfoButton.innerHTML = "[show more info]"; isPosterInfoHidden = true; } } function showNtfyInfo() { if (isNtfyInfoHidden) { ntfyInfo.style.display = "initial"; ntfyInfoButton.innerHTML = "[hide more info]"; isNtfyInfoHidden = false; } else { ntfyInfo.style.display = "none"; ntfyInfoButton.innerHTML = "[show more info]"; isNtfyInfoHidden = true; } } //// badges const elke = 'dark static background, on the left side, a triquetra, in yellow/orange text \'elke.cafe\'' const tomo = 'kait' const lily = 'the word \'lily!!\' next to a microwave' const eris = 'purple background, with pink text that reads \'eris\' and a cat' const zvava = 'black background, with a slanted dark purple grid, and a purple outline, pink text saying \'zvava.org\'' const mira = 'miras button\'' const tempest = 'badge for tempest.dev\'' const disarray = 'jade disarray site' const astrid = 'astrid dot tech' const nbsp = 'ralsei clapping next to the text \'nbsp\'' const loveshock = 'dark background, with a curved grid/web, with the text \'vist the jukebox at loveshock.xyz\'' const pancakes = 'purple background, with a drawing of a cat, to the left of the cat is the underlined word \'pancakes\'' const sophari = 'black background, with white borders and text, colorful snow-like substance falling down, text says \'Sophari.org\' ' const micro = 'prototype from oneshot giviing a :3c expression with a darker background and Micro in purple 500 from tailwindcss on the right with dithering between the two sections' const lykrast = 'hand holding a black hole, with the text \'Lykrast\'' const starshines = 'image of a neofox in a box, next to it is some text reading off the screen \'fox fox fox fox fox\'' const umbreon = 'a button a striped teal background, an umbreon sprite, and the text \'umbreon dot online\' in white' const ako = 'a blue/white grainy background, a little pixel-art house sits next to the word Ako in blue bordered white text' const a = 'a@trwnh.com with a person laying down on it and another copy of the same person waving hello. there is also a golden jiggy' const missing = 'magenta and black checker pattern' const badges = [ elke, tomo, lily, eris, zvava, mira, tempest, disarray, astrid, nbsp, micro, loveshock, pancakes, sophari, lykrast, starshines, umbreon, ako, a, missing ]; function shuffle(array) { var currentIndex = array.length; var temporaryValue; var randomIndex; while (0 !== currentIndex) { randomIndex = Math.floor(Math.random() * currentIndex); currentIndex -= 1; temporaryValue = array[currentIndex]; array[currentIndex] = array[randomIndex]; array[randomIndex] = temporaryValue; } return array; } function getbadges() { var shuffledBadges = shuffle(badges); for (var badgeNum = 0; badgeNum < badgeAmount; badgeNum++) { document.getElementById('badge' + (badgeNum + 1)).innerHTML = shuffledBadges[badgeNum]; } } //// color scheme change const headTag = document.getElementsByTagName("head")[0]; const styleTag = document.createElement("style"); function checkThemeStorage() { if (sessionStorage.getItem("themeGreen")) { setGreen(); } if (sessionStorage.getItem("themeOrange")) { setOrange(); } if (sessionStorage.getItem("themePurple")) { setPurple(); } if ( !sessionStorage.getItem("themeOrange") && !sessionStorage.getItem("themeGreen") && !sessionStorage.getItem("themePurple") ) { getTheme(); } } function setGreen() { badgeGreen.style.display = "initial"; badgeOrange.style.display = "none"; badgeGray.style.display = "none"; badgePurple.style.display = "none"; styleTag.innerHTML = ` :root { --text: #e7eeea; --background: #060d09; --primary: #9ae2b9; --secondary: #14904a; --accent: #47e48a; --content-gradient: linear-gradient(to bottom right, var(--secondary-800), var(--primary-900)); --accent-gradient: linear-gradient(to bottom right, var(--accent), var(--accent-200) 30%, var(--text) 60%); --link: var(--accent-300); --visited: var(--accent-400); --hover: var(--accent-500); --text-50: #f0f4f2; --text-100: #e1eae5; --text-200: #c3d5cb; --text-300: #a5c0b1; --text-400: #88aa97; --text-500: #6a957d; --text-600: #557764; --text-700: #3f5a4b; --text-800: #2a3c32; --text-900: #151e19; --text-950: #0b0f0c; --background-50: #eef7f2; --background-100: #dcefe4; --background-200: #b9dfc9; --background-300: #96cfaf; --background-400: #73bf94; --background-500: #50af79; --background-600: #408c61; --background-700: #306949; --background-800: #204630; --background-900: #102318; --background-950: #08110c; --primary-50: #ebf9f1; --primary-100: #d7f4e4; --primary-200: #b0e8c8; --primary-300: #88ddad; --primary-400: #61d192; --primary-500: #39c676; --primary-600: #2e9e5f; --primary-700: #227747; --primary-800: #174f2f; --primary-900: #0b2818; --primary-950: #06140c; --secondary-50: #e9fcf1; --secondary-100: #d2f9e3; --secondary-200: #a5f3c7; --secondary-300: #78edab; --secondary-400: #4be78f; --secondary-500: #1fe073; --secondary-600: #18b45c; --secondary-700: #128745; --secondary-800: #0c5a2e; --secondary-900: #062d17; --secondary-950: #03160b; --accent-50: #e9fcf1; --accent-100: #d3f8e3; --accent-200: #a6f2c7; --accent-300: #7aebab; --accent-400: #4ee48f; --accent-500: #21de73; --accent-600: #1bb15c; --accent-700: #148545; --accent-800: #0d592e; --accent-900: #072c17; --accent-950: #03160b; --alt-accent: #fbb055; /* TODO: Alter This */ --glitch-1: var(--alt-accent-400); --glitch-2: var(--alt-accent-500); --glitch-3: var(--alt-accent-600); --alt-accent-50: #fef3e7; --alt-accent-100: #fce8cf; --alt-accent-200: #fad19e; --alt-accent-300: #f7b96e; --alt-accent-400: #f5a23d; --alt-accent-500: #f28b0d; --alt-accent-600: #c26f0a; --alt-accent-700: #915308; --alt-accent-800: #613805; --alt-accent-900: #301c03; --alt-accent-950: #180e01; } `; headTag.appendChild(styleTag); sessionStorage.setItem("themeGreen", 1); } function setOrange() { badgeOrange.style.display = "initial"; badgeGreen.style.display = "none"; badgeGray.style.display = "none"; badgePurple.style.display = "none"; styleTag.innerHTML = ` :root { --text: #f2ede7; --background: var(--background-950); --primary: #d7bfa2; --secondary: #76552e; --accent: #ffa941; --content-gradient: linear-gradient(to bottom right, var(--secondary-800), var(--primary-900)); --accent-gradient: linear-gradient(to bottom right, var(--accent), var(--accent-200) 30%, var(--text) 60%); --link: var(--accent-300); --visited: var(--accent-400); --hover: var(--accent-500); --text-50: #f6f3ee; --text-100: #ede6de; --text-200: #dbcebd; --text-300: #c9b59c; --text-400: #b89c7a; --text-500: #a68359; --text-600: #856947; --text-700: #634f36; --text-800: #423524; --text-900: #211a12; --text-950: #110d09; --background-50: #f7f3ee; --background-100: #efe7dc; --background-200: #dfcfb9; --background-300: #cfb696; --background-400: #bf9e73; --background-500: #af8650; --background-600: #8c6b40; --background-700: #695030; --background-800: #463620; --background-900: #231b10; --background-950: #110d08; --primary-50: #f7f3ed; --primary-100: #f0e7db; --primary-200: #e0ceb8; --primary-300: #d1b694; --primary-400: #c29d70; --primary-500: #b3854d; --primary-600: #8f6a3d; --primary-700: #6b502e; --primary-800: #47351f; --primary-900: #241b0f; --primary-950: #120d08; --secondary-50: #f8f3ed; --secondary-100: #f1e7da; --secondary-200: #e2ceb6; --secondary-300: #d4b691; --secondary-400: #c69d6c; --secondary-500: #b88547; --secondary-600: #936a39; --secondary-700: #6e502b; --secondary-800: #49351d; --secondary-900: #251b0e; --secondary-950: #120d07; --accent-50: #fff4e5; --accent-100: #ffe8cc; --accent-200: #ffd199; --accent-300: #ffba66; --accent-400: #ffa333; --accent-500: #ff8c00; --accent-600: #cc7000; --accent-700: #995400; --accent-800: #663800; --accent-900: #331c00; --accent-950: #1a0e00; --alt-accent: #60fe35; --glitch-1: var(--alt-accent-600); --glitch-2: var(--alt-accent-700); --glitch-3: var(--alt-accent-800); --alt-accent-50: #ebffe6; --alt-accent-100: #d7ffcc; --alt-accent-200: #affe9a; --alt-accent-300: #88fe67; --alt-accent-400: #60fe34; --alt-accent-500: #38fe01; --alt-accent-600: #2dcb01; --alt-accent-700: #229801; --alt-accent-800: #166501; --alt-accent-900: #0b3300; --alt-accent-950: #061900; } `; headTag.appendChild(styleTag); sessionStorage.setItem("themeOrange", 1); } function setPurple() { badgeOrange.style.display = "none"; badgeGreen.style.display = "none"; badgeGray.style.display = "none"; badgePurple.style.display = "initial"; styleTag.innerHTML = ` :root { --text: #cdd6f4; --background: #1d1d2e; --primary: #45475a; --secondary: #181825; --accent: #cba6f7; --content-gradient: linear-gradient(to bottom right, var(--secondary-800), var(--primary-900)); --accent-gradient: linear-gradient(to bottom right, var(--accent), var(--accent-200) 30%, var(--text) 60%); --link: var(--accent-200); --visited: var(--accent-400); --hover: var(--accent-500); --text-50: #eaeefa; --text-100: #d5ddf6; --text-200: #abbbed; --text-300: #8298e3; --text-400: #5876da; --text-500: #2e54d1; --text-600: #2543a7; --text-700: #1c327d; --text-800: #122254; --text-900: #09112a; --text-950: #050815; --background-50: #efeff5; --background-100: #e0e0eb; --background-200: #c0c0d8; --background-300: #a1a1c4; --background-400: #8282b0; --background-500: #62629d; --background-600: #4f4f7d; --background-700: #3b3b5e; --background-800: #27273f; --background-900: #14141f; --background-950: #0a0a10; --primary-50: #f1f1f4; --primary-100: #e2e3e9; --primary-200: #c5c7d3; --primary-300: #a9abbc; --primary-400: #8c8ea6; --primary-500: #6f7290; --primary-600: #595b73; --primary-700: #434556; --primary-800: #2c2e3a; --primary-900: #16171d; --primary-950: #0b0b0e; --secondary-50: #f0f0f5; --secondary-100: #e0e0eb; --secondary-200: #c1c1d7; --secondary-300: #a2a2c3; --secondary-400: #8484ae; --secondary-500: #65659a; --secondary-600: #51517b; --secondary-700: #3c3c5d; --secondary-800: #28283e; --secondary-900: #14141f; --secondary-950: #0a0a0f; --accent-50: #f1e8fd; --accent-100: #e3d0fb; --accent-200: #c8a1f7; --accent-300: #ac72f3; --accent-400: #9043ef; --accent-500: #7514eb; --accent-600: #5d10bc; --accent-700: #460c8d; --accent-800: #2f085e; --accent-900: #17042f; --accent-950: #0c0217; --alt-accent: #bf8bfd; --glitch-1: var(--alt-accent-200); --glitch-2: var(--alt-accent-300); --glitch-3: var(--alt-accent-400); --alt-accent-50: #f1eafa; --alt-accent-100: #e4d6f5; --alt-accent-200: #cfb2f3; --alt-accent-300: #bf97f1; --alt-accent-400: #a16be4; --alt-accent-500: #7830cf; --alt-accent-600: #6027a5; --alt-accent-700: #481d7c; --alt-accent-800: #301353; --alt-accent-900: #180a29; --alt-accent-950: #0c0515; } `; headTag.appendChild(styleTag); sessionStorage.setItem("themePurple", 1); } function getTheme() { switch(randomCol) { case 1: setGreen(); break; case 2: setOrange(); break; case 3: setPurple(); break; } }