1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
|
var Browser = {
toggle: (state) => {
if (state) {
overlay.classList.add("shown")
browser.classList.add("shown")
return
} else if (! state) {
if (state != undefined) {
overlay.classList.remove("shown")
browser.classList.remove("shown")
return
}
}
overlay.classList.toggle("shown")
browser.classList.toggle("shown")
},
loadfront: async () => {
let packages = await (await fetch("https://northstar.thunderstore.io/api/v1/package/")).json();
for (let i in packages) {
let pkg = {...packages[i], ...packages[i].versions[0]};
new BrowserEl({
title: pkg.name,
image: pkg.icon,
author: pkg.owner,
download: pkg.download_url,
version: pkg.version_number,
description: pkg.description
})
}
},
loading: () => {
if (! browserEntries.querySelector(".loading")) {
browserEntries.innerHTML = `<div class="loading">${lang("gui.browser.loading")}</div>`;
}
}
}; Browser.toggle()
Browser.loadfront()
document.body.addEventListener("keyup", (e) => {
if (e.key == "Escape") {Browser.toggle(false)}
})
function BrowserEl(properties) {
properties = {
title: "No name",
version: "1.0.0",
image: "icons/no-image.png",
author: "Unnamed Pilot",
description: "No description",
...properties
}
if (properties.version[0] != "v") {
properties.version = "v" + properties.version;
}
if (browserEntries.querySelector(".loading")) {
browserEntries.innerHTML = "";
}
let installstr = lang("gui.browser.install");
if (normalize(modsdiv.innerText.split("\n")).includes(normalize(properties.title))) {
installstr = lang("gui.browser.reinstall");
}
browserEntries.innerHTML += `
<div class="el" id="${normalize(properties.title)}">
<div class="image">
<img src="${properties.image}">
</div>
<div class="text">
<div class="title">${properties.title}</div>
<div class="description">${properties.description} - ${lang("gui.browser.madeby")} ${properties.author}</div>
<button onclick="installFromURL('${properties.download}')">${installstr}</button>
<button class="visual">${properties.version}</button>
</div>
</div>
`
}
ipcRenderer.on("installedmod", (event, modname) => {
setButtons(true);
modname = normalize(modname);
if (document.getElementById(modname)) {
document.getElementById(modname).querySelector(".text button").innerHTML = lang("gui.browser.reinstall");
}
})
function normalize(items) {
let main = (string) => {
return string.replaceAll(" ", "").replaceAll(".", "").toLowerCase()
}
if (typeof items == "string") {
return main(items)
} else {
let newArray = [];
for (let i = 0; i < items.length; i++) {
newArray.push(main(items[i]));
}
return newArray;
}
}
|