var Settings = { toggle: (state) => { if (state) { Settings.load(); options.scrollTo(0, 0); overlay.classList.add("shown") options.classList.add("shown") return } else if (! state) { if (state != undefined) { overlay.classList.remove("shown") options.classList.remove("shown") return } } Settings.load(); options.scrollTo(0, 0); overlay.classList.toggle("shown") options.classList.toggle("shown") }, apply: () => { settings = {...settings, ...Settings.get()}; ipcRenderer.send("savesettings", Settings.get()); }, reloadSwitches: () => { let switches = document.querySelectorAll(".switch"); for (let i = 0; i < switches.length; i++) { switches[i].setAttribute("onclick", `Settings.switch(${i})`); } }, switch: (element, state) => { let switches = document.querySelectorAll(".switch"); if (switches[element]) { element = switches[element]; } let on = () => { element.classList.add("on"); element.classList.remove("off"); } let off = () => { element.classList.add("off"); element.classList.remove("on"); } if (state != undefined) { if (state) {on()} else {off()} } else { if (element.classList.contains("on")) {off()} else {on()} } Settings.reloadSwitches(); }, get: () => { let opts = {}; let options = document.querySelectorAll(".option"); for (let i = 0; i < options.length; i++) { let optName = options[i].getAttribute("name"); if (options[i].querySelector(".actions input")) { let input = options[i].querySelector(".actions input").value; if (options[i].getAttribute("type")) { opts[optName] = input.split(" "); } else { opts[optName] = input; } } else if (options[i].querySelector(".actions select")) { opts[optName] = options[i].querySelector(".actions select").value; } else if (options[i].querySelector(".actions .switch")) { if (options[i].querySelector(".actions .switch.on")) { opts[optName] = true; } else { opts[optName] = false; } } } return opts; }, load: () => { let options = document.querySelectorAll(".option"); for (let i = 0; i < options.length; i++) { let optName = options[i].getAttribute("name"); if (optName == "forcedlang") { let div = options[i].querySelector("select"); div.innerHTML = ""; let langs = fs.readdirSync(__dirname + "/../lang"); for (let i in langs) { title = JSON.parse(fs.readFileSync(__dirname + `/../lang/${langs[i]}`, "utf8"))["lang.title"]; if (title) { div.innerHTML += `` } } div.value = settings.forcedlang; continue; } if (settings[optName] != undefined) { switch(typeof settings[optName]) { case "string": options[i].querySelector(".actions input").value = settings[optName]; break case "object": options[i].querySelector(".actions input").value = settings[optName].join(" "); break case "boolean": let switchDiv = options[i].querySelector(".actions .switch"); if (settings[optName]) { switchDiv.classList.add("on"); switchDiv.classList.remove("off"); } else { switchDiv.classList.add("off"); switchDiv.classList.remove("on"); } break } } } if (process.platform == "win32") { let linuxopts = document.querySelectorAll(".options .linuxopt"); for (let i = 0; i < linuxopts.length; i++) { linuxopts[i].style.display = "none"; } } ipcRenderer.send("can-autoupdate"); ipcRenderer.on("cant-autoupdate", () => { document.querySelector(".option[name=autoupdate]").style.display = "none"; }) } } Settings.reloadSwitches(); Settings.load();