// Get the modal const modal = document.getElementById("myModal"); // Get the button that opens the modal const btn = document.getElementById("myBtn"); // Get the <span> element that closes the modal const span = document.getElementsByClassName("close")[0]; var mode = new URLSearchParams(window.location.search).get("mode"); const archiveLink = document.querySelector("#archive-link") const pendingLink = document.querySelector("#pending-link") const statusLink = document.querySelector("#status-link") function handleForm(event) { event.preventDefault(); } function main() { archiveLink.classList.remove("active"); pendingLink.classList.remove("active"); statusLink.classList.remove("active"); switch (mode) { case "status": statusLink.classList.add("active"); return statusPage(); case "pending": pendingLink.classList.add("active"); break; case "verifications": archiveLink.classList.add("active"); break; default: console.log("No mode"); mode = "verifications" archiveLink.classList.add("active"); break; } document.getElementById("main-app").innerHTML = ''; fetch(`https://thanos.nightmare.haus/api/${mode}`) .then(response => response.json()) .then(data => processData(data)); } function statusPage() { document.getElementById("main-app").innerHTML = ''; fetch(`https://thanos.nightmare.haus/api/config`) .then(response => response.json()) .then(data => { var node = document.createElement("config-status"); var upTime = document.createElement("div"); upTime.setAttribute("slot", "uptime"); upTime.innerText = data.Uptime; node.appendChild(upTime); var bumpTime = document.createElement("div"); bumpTime.setAttribute("slot", "lastbump") bumpTime.innerText = new Date(data.BumpTime).toLocaleString(); node.appendChild(bumpTime); node.setData(data); document.getElementById("main-app").appendChild(node); }); } function searchPage() { var search = document.getElementById("search-bar"); fetch('https://thanos.nightmare.haus/api/verifications') .then(response => response.json()) .then(data => { var searchData = []; for (user of data) { var match = false; if (user.Username.toLowerCase().includes(search.value.toLowerCase())) { match = true; } if (new Date(user.Closed).toLocaleString().includes(search.value)) { match = true; } if (user.UserID.includes(search.value)) { match = true; } if (match) { searchData.push(user); } } processData(searchData); }); } function processData(data) { document.getElementById("main-app").innerHTML = ''; if (data.length == 0) { alert("No data."); return; } data = Object.values(data); for (user of data) { var node = document.createElement("user-card"); var nameSlot = document.createElement("div"); nameSlot.setAttribute("slot", "username"); nameSlot.innerText = user.Username; node.appendChild(nameSlot); var joinDate = document.createElement("div"); joinDate.setAttribute("slot", "join-date"); joinDate.innerText = mode == "pending" ? new Date(user.Submitted).toLocaleString() : new Date(user.Closed).toLocaleString(); node.appendChild(joinDate); var discordSlot = document.createElement("div"); discordSlot.setAttribute("slot", "discord-id"); discordSlot.innerText = user.UserID; node.appendChild(discordSlot); var picSlot = document.createElement("div"); picSlot.setAttribute("slot", "pic-link"); var aNode = document.createElement("a"); aNode.setAttribute("href", mode == "pending" ? user.Photo : `https://thanos.nightmare.haus/${user.Photo}`); aNode.innerText = "Verification Photo"; picSlot.appendChild(aNode); node.appendChild(picSlot); document.getElementById("main-app").appendChild(node); } } // When the user clicks on <span> (x), close the modal span.onclick = function () { modal.style.display = "none"; } // When the user clicks anywhere outside of the modal, close it window.onclick = function (event) { if (event.target == modal) { modal.style.display = "none"; } } var form = document.getElementById("search-form"); form.addEventListener('submit', handleForm); main();