-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathindex.html
112 lines (94 loc) · 4.06 KB
/
index.html
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
108
109
110
111
112
<!DOCTYPE html>
<html lang="en-US">
<head>
<title>Emotecraft Wiki</title>
<link rel="icon" href="./assets/icon.webp">
<link rel="stylesheet" href="./style/style.css">
</head>
<body>
<div id="content">
<div id="sidebar"></div>
<div id="main"></div>
</div>
<script src="https://cdn.jsdelivr.net/npm/marked/marked.min.js"></script>
<script>
var search = new URLSearchParams(window.location.search)
var page = search.get("page") || "home"
var lang = search.get("lang") || "en"
console.log("Loading page " + page + " in language " + lang)
fetch("./pages/" + lang + "/" + page + ".md").then(res => {
if (res.status != 404) {
return res.text()
} else {
return fetch("./pages/" + lang + "/language.json").then(res => {
if (res.status != 404) {
return fetch("./pages/en/" + page + ".md").then(res => {
if (res.status == 404) {
return fetch("./pages/" + lang + "/404-notfound.md").then(res => {
if (res.status != 404) {
return res.text()
} else {
return fetch("./pages/en/404-notfound.md").then(res => res.text())
}
})
} else {
return fetch("./pages/en/404-untranslated-page.md").then(res => res.text())
}
})
} else {
return fetch("./pages/en/404-untranslated-language.md").then(res => res.text())
}
})
}
}).then(markdown => {
function fixLinks(parent) {
for (var index = 0; index < parent.children.length; index++) {
var child = parent.children.item(index)
if (child.tagName == "A") {
var href = child.getAttribute("href")
if (href.startsWith("./")) {
child.href = "./?page=" + href.replace("./", "") + "&lang=" + lang
child.target = "_parent"
}
}
fixLinks(child)
}
}
var main = document.getElementById("main")
main.innerHTML = marked.parse(markdown)
fixLinks(main)
fetch("./pages/" + lang + "/sidebar.md").then(res => {
if (res.status != 404) {
return res.text()
} else {
return ""
}
}).then(markdown => {
var sidebar = document.getElementById("sidebar")
sidebar.innerHTML = marked.parse(markdown)
fixLinks(sidebar)
var header = 0
for (var index = 0; index < sidebar.children.length; index++) {
var element = sidebar.children.item(index)
if (element.tagName == "H3") {
header = index
element.classList.add("dropdown")
element.addEventListener("click", event => {
if (!event.srcElement.classList.contains("open")) {
event.srcElement.classList.add("open")
} else {
event.srcElement.classList.remove("open")
}
})
} else if (element.tagName == "P" && header != 0) {
element.remove()
element.classList.add("dropdown-element")
sidebar.children.item(header).appendChild(element)
index--
}
}
})
})
</script>
</body>
</html>