Skip to content

Commit

Permalink
2.8.0
Browse files Browse the repository at this point in the history
  • Loading branch information
eccs0103 committed May 26, 2024
1 parent 93237f1 commit ddc3cf6
Show file tree
Hide file tree
Showing 3 changed files with 452 additions and 621 deletions.
45 changes: 24 additions & 21 deletions sandbox/script.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,13 +3,14 @@
import { FastEngine, PreciseEngine } from "../scripts/modules/generators.js";
import { Color } from "../scripts/modules/palette.js";
import { ArchiveManager } from "../scripts/modules/storage.js";
import { CycleTypes, RenderEvent, Settings, board } from "../scripts/structure.js";
import { Ability, CycleTypes, Elemental, RenderEvent, Settings } from "../scripts/structure.js";

//#region Initialize
const canvas = await window.ensure(() => document.getElement(HTMLCanvasElement, `canvas#display`));
const context = await window.ensure(() => canvas.getContext(`2d`) ?? (() => {
throw new EvalError(`Unable to get context`);
})());
const board = Elemental.Board.self;
const inputTogglePlay = await window.ensure(() => document.getElement(HTMLInputElement, `input#toggle-play`));
const buttonReloadBoard = await window.ensure(() => document.getElement(HTMLButtonElement, `button#reload-board`));
const buttonCaptureCanvas = await window.ensure(() => document.getElement(HTMLButtonElement, `button#capture-canvas`));
Expand All @@ -28,14 +29,14 @@ window.addEventListener(`resize`, (event) => {
});
window.dispatchEvent(new UIEvent(`resize`));

await window.ensure(() => Promise.withSignal((signal, resolve, reject) => {
await window.load(Promise.withSignal((signal, resolve, reject) => window.ensure(() => {
const scriptElements = document.createElement(`script`);
scriptElements.type = `module`;
scriptElements.src = `../scripts/elements.js`;
scriptElements.addEventListener(`load`, (event) => resolve(undefined), { signal });
scriptElements.addEventListener(`error`, (event) => reject(event.error), { signal });
document.head.appendChild(scriptElements);
}));
})));

engine.limit = settings.FPSLimit;
board.addEventListener(`generate`, (event) => {
Expand All @@ -49,24 +50,26 @@ window.addEventListener(`resize`, (event) => {
engine.addEventListener(`update`, (event) => {
board.dispatchEvent(new RenderEvent(`render`, { context }));
});
engine.addEventListener(`update`, async (event) => {
if (!board.dispatchEvent(new Event(`execute`, { cancelable: true }))) {
engine.launched = false;
const repeat = await (async () => {
switch (settings.cycleType) {
case CycleTypes.break: return false;
case CycleTypes.ask: return await window.confirmAsync(`Elements have no more moves. Do you want to reload the board?`);
case CycleTypes.loop: return true;
default: throw new EvalError(`Invalid '${settings.cycleType}' cycle type`);
}
})();
if (repeat) {
board.dispatchEvent(new Event(`generate`));
engine.launched = true;
engine.addEventListener(`update`, (event) => window.ensure(async () => {
const invoker = new Ability.Invoker();
invoker.observe();
board.execute(invoker);
if (invoker.summarize()) return;
engine.launched = false;
const repeat = await (async () => {
switch (settings.cycleType) {
case CycleTypes.break: return false;
case CycleTypes.ask: return await window.confirmAsync(`Elements have no more moves. Do you want to reload the board?`);
case CycleTypes.loop: return true;
default: throw new EvalError(`Invalid '${settings.cycleType}' cycle type`);
}
inputTogglePlay.checked = engine.launched;
})();
if (repeat) {
board.dispatchEvent(new Event(`generate`));
engine.launched = true;
}
});
inputTogglePlay.checked = engine.launched;
}));

inputTogglePlay.addEventListener(`change`, (event) => {
engine.launched = inputTogglePlay.checked;
Expand All @@ -75,12 +78,12 @@ buttonReloadBoard.addEventListener(`click`, (event) => {
board.dispatchEvent(new Event(`generate`));
});

buttonCaptureCanvas.addEventListener(`click`, (event) => {
buttonCaptureCanvas.addEventListener(`click`, (event) => window.insure(() => {
canvas.toBlob((blob) => {
if (blob === null) throw new EvalError(`Unable to convert canvas for capture`);
navigator.download(new File([blob], `${Date.now()}.png`, { type: `png` }));
});
});
}));
//#endregion
//#region Aside
divFPSCounter.hidden = !settings.showFPS;
Expand Down
Loading

0 comments on commit ddc3cf6

Please sign in to comment.