forked from HENRYMARTIN5/Clarity
-
Notifications
You must be signed in to change notification settings - Fork 0
/
ClarityUser.js
90 lines (69 loc) · 2.8 KB
/
ClarityUser.js
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
function splitIntoChunk(inputArray, perChunk) {
var result = inputArray.reduce((resultArray, item, index) => {
const chunkIndex = Math.floor(index / perChunk)
if (!resultArray[chunkIndex]) {
resultArray[chunkIndex] = [] // start a new chunk
}
resultArray[chunkIndex].push(item)
return resultArray
}, [])
return result
}
window.onload = function () {
var request = new XMLHttpRequest();
const queryString = window.location.search;
const urlParams = new URLSearchParams(queryString);
if (urlParams.has('user')) {
var user = urlParams.get('user');
} else {
var user = "N3rdL0rd";
}
request.open('GET', 'https://clarityworkshop.n3rdl0rd.repl.co/getuser/' + user, false); // `false` makes the request synchronous
request.send(null);
if (request.status === 200) {
var currentLvls = request.responseText;
var lvlJson = JSON.parse(currentLvls);
console.log(lvlJson);
var splitLvlJson = splitIntoChunk(lvlJson, 3);
console.log(splitLvlJson);
document.getElementById("container").innerHTML = "";
const container = document.getElementById("container");
document.getElementById("title").innerText = user+"'s Clarity Workshop";
container.innerHTML = `
<div id="pinnedcontainer">
</div>
<p>Created Levels</p>
</div>`
splitLvlJson.forEach(levels => {
console.log(levels);
const container = document.getElementById("container");
var newRow = document.createElement("div");
newRow.class = "w3-row-padding";
levels.forEach(level => {
console.log(level);
var newelem = `
<div class="w3-third w3-container w3-margin-bottom w3-hover-opacity" style= "cursor: pointer;" onclick="loadLevelById({levelId});">
<div class="w3-container level">
<p><b>{level}</b></p>
<p>By {author}</p>
</div>
</div>`.replace("{level}", level["name"]).replace("{author}", level["author"]).replace("{levelId}", level["id"])
newRow.innerHTML = newRow.innerHTML + newelem;
})
newRow.innerHTML = newRow.innerHTML + "</br>";
container.appendChild(newRow);
})
// append pagination buttons (back, fwd, etc)
container.innerHTML = container.innerHTML + `
<center>
<div id="pagination" class="w3-row-padding">
<div class="button-62" style= "cursor: pointer;" id="back" onclick="window.location.href='https://discountdevs.github.io/Clarity-Legacy/workshop.html'">
<p>< Back</p>
</div>
</div>
</center>`
}
}
function loadLevelById(id) {
window.location.href = "https://discountdevs.github.io/Clarity-Legacy/level.html?id=" + (id).toString();
}