moth/theme/puzzle.html

104 lines
3.1 KiB
HTML
Raw Normal View History

2018-09-19 17:56:47 -06:00
<!DOCTYPE html>
<html>
<head>
<title>Puzzle</title>
<link rel="stylesheet" href="basic.css">
<meta name="viewport" content="width=device-width">
2018-10-02 19:21:54 -06:00
<meta charset="utf-8">
<script src="devel.js"></script>
2018-09-19 17:56:47 -06:00
<script>
function init() {
let params = new URLSearchParams(window.location.search);
let categoryName = params.get("cat");
let points = params.get("points");
let puzzleId = params.get("pid");
2018-09-21 14:42:38 -06:00
let base = "content/" + categoryName + "/" + puzzleId + "/";
let fn = base + "puzzle.json";
2018-09-19 17:56:47 -06:00
fetch(fn)
.then(function(resp) {
return resp.json();
}).then(function(obj) {
document.getElementById("puzzle").innerHTML = obj.body;
2018-09-21 17:45:28 -06:00
document.getElementById("authors").textContent = obj.authors.join(", ");
2018-10-02 19:21:54 -06:00
if (obj.answers) {
devel_addin(obj, document.getElementById("devel"));
}
for (let script of obj.scripts) {
let st = document.createElement("script");
document.head.appendChild(st);
st.src = base + script;
2018-10-02 19:21:54 -06:00
}
2018-09-21 17:45:28 -06:00
for (let fn of obj.files) {
let li = document.createElement("li");
let a = document.createElement("a");
a.href = base + fn;
a.innerText = fn;
li.appendChild(a);
document.getElementById("files").appendChild(li);
}
}).catch(function(err) {
console.log("Error", err);
});
document.querySelector("body > h1").innerText = categoryName + " " + points
document.querySelector("input[name=cat]").value = categoryName;
document.querySelector("input[name=points]").value = points;
2018-09-21 17:45:28 -06:00
function mutated(mutationsList, observer) {
for (let mutation of mutationsList) {
if (mutation.type == 'childList') {
for (let e of mutation.addedNodes) {
//console.log(e);
if (! e.querySelectorAll) { continue; }
2018-09-21 17:45:28 -06:00
for (let se of e.querySelectorAll("[src],[href]")) {
se.outerHTML = se.outerHTML.replace(/(src|href)="([^/]+)"/i, "$1=\"" + base + "$2\"")
//console.log(se.outerHTML);
2018-09-21 17:45:28 -06:00
}
//console.log(e.querySelectorAll("[src]"));
2018-09-21 17:45:28 -06:00
}
//console.log(mutation.addedNodes);
2018-09-21 17:45:28 -06:00
} else {
console.log(mutation);
}
}
}
let puzzle = document.getElementById("puzzle");
let observerOptions = {
childList: true,
attributes: true,
subtree: true,
};
window.observer = new MutationObserver(mutated);
observer.observe(puzzle, observerOptions);
2018-09-19 17:56:47 -06:00
}
document.addEventListener("DOMContentLoaded", init);
</script>
</head>
<body>
<h1>Puzzle</h1>
<section>
2018-09-21 17:45:28 -06:00
<div id="puzzle">Loading...</div>
<ul id="files"></ul>
<p>Puzzle by <span id="authors"></span></p>
2018-09-19 17:56:47 -06:00
</section>
<form action="answer" method="post">
<input type="hidden" name="cat">
<input type="hidden" name="points">
Team ID: <input type="text" name="id"> <br>
Answer: <input type="text" name="answer" id="answer"> <br>
<input type="submit" value="Submit">
</form>
<div id="devel"></div>
2018-09-19 17:56:47 -06:00
<nav>
<ul>
<li><a href="puzzle-list.html">Puzzles</a></li>
<li><a href="scoreboard.html">Scoreboard</a></li>
</ul>
</nav>
</body>
</html>