diff options
-rw-r--r-- | level.js | 10 | ||||
-rw-r--r-- | levelSelect.js | 28 | ||||
-rw-r--r-- | main.js | 6 |
3 files changed, 42 insertions, 2 deletions
@@ -1,3 +1,4 @@ +import { setupLevelSelectUi } from './levelSelect.js'; import { render } from './render.js'; @@ -91,6 +92,15 @@ export function setupLevelUi(level, root, audio) { ui.canvas.height = 600; root.appendChild(ui.canvas); + ui.returnBtn = document.createElement('input'); + ui.returnBtn.type = 'button'; + ui.returnBtn.value = 'Return'; + ui.returnBtn.onclick = () => { + root.innerText = ''; + setupLevelSelectUi(root, audio); + } + root.appendChild(ui.returnBtn); + ui.ctx = ui.canvas.getContext('2d'); ui.ctx.translate(ui.canvas.width/2, ui.canvas.height/2) ui.ctx.scale(ui.canvas.width/20, -ui.canvas.height/20); diff --git a/levelSelect.js b/levelSelect.js new file mode 100644 index 0000000..6c0d995 --- /dev/null +++ b/levelSelect.js @@ -0,0 +1,28 @@ +import{ setupLevel, setupLevelUi } from './level.js'; + +const levels = { + 'Initial Jump': [ [], setupLevel([], [8, 0]) ], + 'Monopole Mining': [ ['Initial Jump'], setupLevel([[3, 3]], [8,8]) ], +}; + +export function setupLevelSelectUi(root, audio) { + const levelList = document.createElement('ol'); + const levelPicker = name => { + const [ dependencies, level ] = levels[name]; + const allDependenciesSatisfied = dependencies.map(x => levels[x][1].completed).reduce((acc, x) => acc && x, true); + if (allDependenciesSatisfied) { + const button = document.createElement('input'); + button.type = 'button'; + button.onclick = () => { + root.innerText = ''; + setupLevelUi(level, root, audio); + } + const li = document.createElement('li'); + li.appendChild(button); + levelList.appendChild(li); + } + } + + [...Object.keys(levels)].forEach(levelPicker); + root.appendChild(levelList); +} @@ -1,3 +1,4 @@ +import { setupLevelSelectUi } from './levelSelect.js'; import { setupLevel, setupLevelUi } from './level.js'; window.onload = () => { @@ -34,8 +35,9 @@ window.onload = () => { ) musicList[0].element.play(); - const level = setupLevel([[2, 2], [3,3]], [7, 7]); - const ui = setupLevelUi(level, root, audio); + // const level = setupLevel([[2, 2], [3,3]], [7, 7]); + // const ui = setupLevelUi(level, root, audio); + setupLevelSelectUi(root, audio); }; root.appendChild(start); } |