sort category listing

This commit is contained in:
Neale Pickett 2017-11-10 00:50:30 +00:00
parent 7662a67ca4
commit 6902af3db0
1 changed files with 47 additions and 41 deletions

View File

@ -6,56 +6,62 @@ function loadPuzzle(cat, id, points) {
} }
function puzzlesRefresh(term, obj) { function puzzlesRefresh(term, obj) {
term.clear(); term.clear();
let cats = [];
for (let cat in obj) {
cats.push(cat);
}
cats.sort();
for (var cat in obj) { for (let cat of cats) {
var puzzles = obj[cat]; let puzzles = obj[cat];
var pdiv = createElement('div'); let pdiv = createElement('div');
pdiv.className = 'category'; pdiv.className = 'category';
var h = createElement('h2'); let h = createElement('h2');
pdiv.appendChild(h); pdiv.appendChild(h);
h.textContent = cat; h.textContent = cat;
var l = createElement('ul'); let l = createElement('ul');
pdiv.appendChild(l); pdiv.appendChild(l);
for (var puzzle of puzzles) { for (var puzzle of puzzles) {
var points = puzzle[0]; var points = puzzle[0];
var id = puzzle[1]; var id = puzzle[1];
var i = createElement('li'); var i = createElement('li');
l.appendChild(i); l.appendChild(i);
if (points == 0) { if (points === 0) {
i.textContent = "‡"; i.textContent = "‡";
} else { } else {
var a = createElement('a'); var a = createElement('a');
i.appendChild(a); i.appendChild(a);
a.className = "link"; a.className = "link";
a.textContent = points; a.textContent = points;
a.href = cat + "/" + id + "/index.html"; a.href = cat + "/" + id + "/index.html";
// a.addEventListener("click", loadPuzzle.bind(undefined, cat, id, points)); // a.addEventListener("click", loadPuzzle.bind(undefined, cat, id, points));
} }
} }
term.appendShallow(pdiv); term.appendShallow(pdiv);
} }
} }
function puzzles_start() { function puzzles_start() {
var element = document.getElementById("puzzles"); var element = document.getElementById("puzzles");
var puzzlesTerminal = new Terminal(element); var puzzlesTerminal = new Terminal(element);
var refreshInterval = 40 * 1000; var refreshInterval = 40 * 1000;
var refreshCallback = puzzlesRefresh.bind(undefined, puzzlesTerminal); var refreshCallback = puzzlesRefresh.bind(undefined, puzzlesTerminal);
var refreshFunction = loadJSON.bind(undefined, puzzlesJsonUrl, refreshCallback); var refreshFunction = loadJSON.bind(undefined, puzzlesJsonUrl, refreshCallback);
puzzlesTerminal.clear(); puzzlesTerminal.clear();
puzzlesTerminal.par("Loading..."); puzzlesTerminal.par("Loading...");
refreshFunction(); refreshFunction();
setInterval(refreshFunction, refreshInterval); setInterval(refreshFunction, refreshInterval);
} }
window.addEventListener("load", puzzles_start); window.addEventListener("load", puzzles_start);