Spaces:
Running
Running
function displayGui() { | |
function gui() { | |
if (document.querySelector("#eaglerpl_gui")) { | |
document.querySelector("#eaglerpl_gui").remove(); | |
} | |
localStorage.setItem( | |
"ml::Mods", | |
localStorage.getItem("ml::Mods") || "[]" | |
); | |
try { | |
localStorage.setItem( | |
"ml::Mods", | |
JSON.stringify(JSON.parse(localStorage.getItem("ml::Mods"))) | |
); | |
} catch (error) { | |
localStorage.setItem("ml::Mods", "[]"); | |
} | |
var Mods = JSON.parse(localStorage.getItem("ml::Mods")); | |
var container = document.createElement("div"); | |
container.id = "eaglerpl_gui"; | |
container.style = `width:100%; height: 100%; position: fixed; top: 0; left: 0; z-index: 10; color: white; font-family: Minecraftia, sans-serif; overflow-y: scroll; overflow-x: hidden; background-image: url(); background-color: rgb(60,60,60); background-blend-mode: multiply; background-size: 64px;`; | |
var title = document.createElement("h1"); | |
title.style = "text-shadow: 0px 0px 4px;"; | |
title.innerHTML = "Mod Manager"; | |
var closeButton = document.createElement("a"); | |
closeButton.style = `margin-left: 2rem; color: red;`; | |
closeButton.href = "javascript:void(0)"; | |
closeButton.addEventListener("click", () => { | |
document.querySelector("#eaglerpl_gui").remove(); | |
}); | |
closeButton.innerHTML = "[X]"; | |
title.appendChild(closeButton); | |
container.appendChild(title); | |
var warningPoster = document.createElement("p"); | |
warningPoster.style = "font-size: 0.8rem; color: orangered;"; | |
warningPoster.innerHTML = | |
"Warning: Installing Mods gives them full control over the game. Be cautious when installing them.<br>Mods that have been removed also need a reload to stop running in the background."; | |
container.appendChild(warningPoster); | |
var tipPoster = document.createElement("p"); | |
tipPoster.style = "font-size: 0.8rem; color: yellow;"; | |
tipPoster.innerHTML = | |
"Tip: if the mods say that they failed loading, try refreshing the gui"; | |
container.appendChild(tipPoster); | |
var table = document.createElement("table"); | |
table.style = "table-layout: fixed; width: 100%"; | |
var headerRow = document.createElement("tr"); | |
headerRow.style = "background: rgb(50,50,50);"; | |
var urlBox = document.createElement("th"); | |
urlBox.style = "text-align: center;"; | |
urlBox.innerHTML = "URL"; | |
headerRow.appendChild(urlBox); | |
var statusBox = document.createElement("th"); | |
statusBox.style = "text-align: center; width: 15%;"; | |
statusBox.innerHTML = "Status"; | |
headerRow.appendChild(statusBox); | |
table.appendChild(headerRow); | |
Mods.forEach((url) => { | |
var row = document.createElement("tr"); | |
row.style = `box-shadow: 0px 2px 0px grey;`; | |
var urlBox = document.createElement("td"); | |
urlBox.style = "user-select: text;"; | |
var textWrapper = document.createElement("div"); | |
textWrapper.style = `max-width: 100%; overflow-wrap: anywhere; max-height: 3rem; overflow-y: scroll;`; | |
textWrapper.innerText = url; | |
urlBox.append(textWrapper); | |
row.appendChild(urlBox); | |
var statusBox = document.createElement("td"); | |
statusBox.innerHTML = ((curl) => { | |
var targs = document.querySelectorAll("script[data-Mod]"); | |
for (let i = 0; i < targs.length; i++) { | |
const elem = targs[i]; | |
if (elem.getAttribute("data-Mod") === curl) { | |
return "LOADED"; | |
} | |
} | |
return "FAILED"; | |
})(url); | |
switch (statusBox.innerHTML) { | |
case "LOADED": | |
statusBox.style = "background-color: green; text-align: center;"; | |
break; | |
case "FAILED": | |
statusBox.style = "background-color: dimgrey; text-align: center;"; | |
break; | |
default: | |
break; | |
} | |
var binBtn = document.createElement("button"); | |
binBtn.style = | |
"background: transparent; text-align: center; color: yellow; cursor: pointer; font-family: 'Minecraftia', sans-serif; text-decoration: underline; border: 0; margin-left: 1rem; font-size: 1rem;"; | |
binBtn.innerHTML = "[X]"; | |
binBtn.addEventListener("click", () => { | |
if (!window.confirm("Delete Mod?") || Mods.indexOf(url) === -1) { | |
return; | |
} | |
Mods.splice(Mods.indexOf(url), 1); | |
localStorage.setItem("ml::Mods", JSON.stringify(Mods)); | |
gui(); | |
}); | |
statusBox.appendChild(binBtn); | |
row.appendChild(statusBox); | |
table.appendChild(row); | |
}); | |
var addBtn = document.createElement("button"); | |
addBtn.style = | |
"background: transparent; text-align: center; color: yellow; cursor: pointer; font-family: 'Minecraftia', sans-serif; text-decoration: underline; border: 0; margin-right: 1rem; font-size: 1rem;"; | |
addBtn.innerHTML = "Add new"; | |
addBtn.addEventListener("click", () => { | |
var newMod = window.prompt("URL of Mod: ", "http://example.com/example.js"); | |
if (!newMod) { | |
return; //User pressed cancel | |
} | |
Mods.push( | |
newMod | |
); | |
localStorage.setItem("ml::Mods", JSON.stringify(Mods)); | |
if(window.ModLoader){ | |
ModLoader([newMod]); | |
} | |
gui(); | |
}); | |
var uploadBtn = document.createElement("button"); | |
uploadBtn.style = | |
"background: transparent; text-align: center; color: yellow; cursor: pointer; font-family: 'Minecraftia', sans-serif; text-decoration: underline; border: 0; font-size: 1rem;"; | |
uploadBtn.innerHTML = "Upload..."; | |
uploadBtn.addEventListener("click", function uploadBtnListener() { | |
var filePicker = document.createElement("input"); | |
filePicker.type = "file"; | |
filePicker.accept = ".js"; | |
filePicker.addEventListener("input", function onInput() { | |
if (filePicker.files[0]) { | |
var reader = new FileReader(); | |
reader.addEventListener("load", function onModRead() { | |
var newMod = reader.result.replace(";base64", `;fs=${encodeURIComponent(filePicker.files[0].name) || "unknown"};base64`); | |
Mods.push(newMod); | |
localStorage.setItem("ml::Mods", JSON.stringify(Mods)); | |
if(window.ModLoader){ | |
ModLoader([newMod]); | |
} | |
gui(); | |
}); | |
reader.readAsDataURL(filePicker.files[0]); | |
} | |
}); | |
filePicker.click(); | |
}); | |
container.appendChild(table); | |
container.appendChild(addBtn); | |
container.appendChild(uploadBtn); | |
var notice = document.createElement("a"); | |
notice.innerHTML = "Refresh GUI"; | |
notice.href = "javascript:void(0)"; | |
notice.addEventListener("click", function reloadListener() { | |
setTimeout(gui, 500); | |
this.remove(); | |
}); | |
notice.style = | |
"color: yellow; display: block; margin-top: 2rem; width: 0; white-space: nowrap;"; | |
container.appendChild(notice); | |
ModAPI.events.callEvent("gui", {}); | |
document.body.appendChild(container); | |
} | |
gui(); | |
} | |