var mods = {}; mods.load = (mods_obj) => { modcount.innerHTML = `${lang("gui.mods.count")} ${mods_obj.all.length}`; let normalized_names = []; let set_mod = (mod) => { let name = mod.name; if (mod.package) { name = mod.package.package_name; } let normalized_name = "mod-list-" + normalize(name); normalized_names.push(normalized_name); let el = document.getElementById(normalized_name); if (el) { if (mod.disabled) { el.querySelector(".switch").classList.remove("on"); } else { el.querySelector(".switch").classList.add("on"); } return; } let div = document.createElement("div"); div.classList.add("el"); div.id = normalized_name; let mod_details = { name: mod.name, version: mod.version, description: mod.description } if (mod.package) { mod_details = { image: mod.package.icon, name: mod.package.manifest.name, version: mod.package.manifest.version_number, description: mod.package.manifest.description } } div.innerHTML += `
${mod_details.name}
${mod_details.description}
`; if (mod_details.name.match(/^Northstar\..*/)) { div.querySelector("img").src = "icons/northstar.png" } div.querySelector(".remove").onclick = () => { if (! mod.package) { return mods.remove(mod.name); } for (let i = 0; i < mod.packaged_mods.length; i++) { mods.remove(mod.packaged_mods[i]); } } if (mod.disabled) { div.querySelector(".switch").classList.remove("on"); } div.querySelector(".switch").addEventListener("click", () => { if (! mod.package) { return mods.toggle(mod.name); } for (let i = 0; i < mod.packaged_mods.length; i++) { mods.toggle(mod.packaged_mods[i]); } }) div.querySelector(".image").style.display = "none"; modsdiv.append(div); } for (let i = 0; i < mods_obj.all.length; i++) { set_mod(mods_obj.all[i]); } let mod_els = document.querySelectorAll("#modsdiv .el"); let mod_update_els = []; for (let i = 0; i < mod_els.length; i++) { let update_btn = mod_els[i].querySelector(".update"); if (update_btn && update_btn.style.display != "none") { mod_update_els.push(mod_els[i].id); } else { break; } } for (let i = 0; i < mod_els.length; i++) { let mod = mod_els[i].id.replace(/^mod-list-/, ""); if (! normalized_names.includes(mod_els[i].id)) { mod_els[i].remove(); return; } let image_container = mod_els[i].querySelector(".image"); let image_el = image_container.querySelector("img") let image_blur_el = image_container.querySelector("img.blur") if (mod_versions[mod]) { image_el.src = mod_versions[mod].package.versions[0].icon; } if (image_el.getAttribute("src") && ! image_container.parentElement.classList.contains("has-icon")) { let image_src = image_el.getAttribute("src"); image_blur_el.src = image_src; image_container.style.display = null; image_container.parentElement.classList.add("has-icon"); } if (mod_versions[mod] && mod_versions[mod].has_update) { mod_els[i].querySelector(".update").style.display = null; mod_els[i].querySelector(".update").setAttribute( "onclick", `mod_versions["${mod}"].install()` ) if (mod_update_els.includes(mod_els[i].id)) { continue; } let mod_el = mod_els[i].cloneNode(true); // copy click event of the remove button to the new button mod_el.querySelector(".remove").onclick = mod_els[i].querySelector(".remove").onclick; mod_el.classList.add("no-animation"); mod_el.querySelector(".switch").addEventListener("click", () => { if (mod_versions[mod].local_name) { mods.toggle(mod_versions[mod].local_name); } }) mod_els[i].remove(); modsdiv.querySelector(".line").after(mod_el); } else { mod_els[i].querySelector(".update").style.display = "none"; } } } mods.remove = (mod) => { if (mod.toLowerCase().match(/^northstar\./)) { if (! confirm(lang("gui.mods.required_confirm"))) { return; } } else if (mod == "allmods") { if (! confirm(lang("gui.mods.remove_all_confirm"))) { return; } } ipcRenderer.send("remove-mod", mod); } mods.toggle = (mod) => { if (mod.toLowerCase().match(/^northstar\./)) { if (! confirm(lang("gui.mods.required_confirm"))) { return; } } else if (mod == "allmods") { if (! confirm(lang("gui.mods.toggle_all_confirm"))) { return; } } ipcRenderer.send("toggle-mod", mod); }