let JS handle the DOM; rearrange code

This commit is contained in:
Max Bradbury 2020-07-19 22:36:36 +01:00
parent ffd8a15eda
commit 3cdf52b5e2
2 changed files with 40 additions and 47 deletions

View File

@ -1,17 +1,5 @@
import init, {load_default_game_data, add_tiles} from './pkg/bitsy_tiles.js'; import init, {load_default_game_data, add_tiles} from './pkg/bitsy_tiles.js';
async function run() {
await init();
const output = document.getElementById("output");
// hide all pages except start page
for (let page of document.getElementsByClassName('page')) {
page.style.display = "none";
}
document.getElementById("start").style.display = "block";
function pagination(e) { function pagination(e) {
const parent = e.target.parentNode; const parent = e.target.parentNode;
@ -26,33 +14,6 @@ async function run() {
} }
} }
for (let pageButton of document.getElementsByClassName("pagination")) {
pageButton.addEventListener('click', pagination);
pageButton.addEventListener('touchend', pagination);
}
const gameDataInput = document.getElementById("game-data");
const buttonGameDataProceed = document.getElementById("game-data-next");
function new_game() {
load_default_game_data();
// we don't need to look at the default game data, so skip ahead to the image page
buttonGameDataProceed.click();
}
function clear_game() {
gameDataInput.value = "";
}
let new_game_button = document.getElementById("new");
new_game_button.addEventListener("click", new_game);
new_game_button.addEventListener("touchend", new_game);
let load_game_button = document.getElementById("load");
load_game_button.addEventListener("click", clear_game);
load_game_button.addEventListener("touchend", clear_game);
// handle game data and image
function readFile(input, callback, type = "text") { function readFile(input, callback, type = "text") {
if (input.files && input.files[0]) { if (input.files && input.files[0]) {
let reader = new FileReader(); let reader = new FileReader();
@ -66,6 +27,47 @@ async function run() {
} }
} }
async function run() {
await init();
const addImageButton = document.getElementById("add");
const buttonGameDataProceed = document.getElementById("game-data-next");
const gameDataInput = document.getElementById("game-data");
const importButton = document.getElementById("import");
const load_game_button = document.getElementById("load");
const new_game_button = document.getElementById("new");
const output = document.getElementById("output");
const preview = document.getElementById("preview");
const resetButton = document.getElementById("reset");
// hide all pages except start page
for (let page of document.getElementsByClassName('page')) {
page.style.display = "none";
}
document.getElementById("start").style.display = "block";
for (let pageButton of document.getElementsByClassName("pagination")) {
pageButton.addEventListener('click', pagination);
pageButton.addEventListener('touchend', pagination);
}
function new_game() {
gameDataInput.value = load_default_game_data();
// we don't need to look at the default game data, so skip ahead to the image page
buttonGameDataProceed.click();
}
function clear_game() {
gameDataInput.value = "";
}
new_game_button.addEventListener("click", new_game);
new_game_button.addEventListener("touchend", new_game);
load_game_button.addEventListener("click", clear_game);
load_game_button.addEventListener("touchend", clear_game);
// handle game data and image
document.getElementById("game").addEventListener("change", function() { document.getElementById("game").addEventListener("change", function() {
readFile(this, function (e) { readFile(this, function (e) {
gameDataInput.value = e.target.result; gameDataInput.value = e.target.result;
@ -84,7 +86,6 @@ async function run() {
gameDataInput.addEventListener("change", checkGameData); gameDataInput.addEventListener("change", checkGameData);
gameDataInput.addEventListener("keyup", checkGameData); gameDataInput.addEventListener("keyup", checkGameData);
const preview = document.getElementById("preview");
preview.style.display = "none"; preview.style.display = "none";
document.getElementById('image').addEventListener('change', function () { document.getElementById('image').addEventListener('change', function () {
@ -102,7 +103,6 @@ async function run() {
output.value = add_tiles(gameData, image, prefix); output.value = add_tiles(gameData, image, prefix);
} }
const importButton = document.getElementById("import");
importButton.addEventListener("click", addTiles); importButton.addEventListener("click", addTiles);
importButton.addEventListener("touchend", addTiles); importButton.addEventListener("touchend", addTiles);
@ -111,8 +111,6 @@ async function run() {
output.value = ""; output.value = "";
} }
const addImageButton = document.getElementById("add");
addImageButton.addEventListener("click", addImage); addImageButton.addEventListener("click", addImage);
addImageButton.addEventListener("touchend", addImage); addImageButton.addEventListener("touchend", addImage);
@ -121,8 +119,6 @@ async function run() {
preview.removeAttribute("src"); preview.removeAttribute("src");
} }
let resetButton = document.getElementById("reset");
resetButton.addEventListener("click", reset); resetButton.addEventListener("click", reset);
} }

View File

@ -7,11 +7,8 @@ use wasm_bindgen::prelude::*;
const SD: u32 = 8; const SD: u32 = 8;
#[wasm_bindgen] #[wasm_bindgen]
pub fn load_default_game_data() { pub fn load_default_game_data() -> String {
let window = web_sys::window().expect("no global `window` exists"); bitsy_parser::mock::game_default().to_string()
let document = window.document().expect("should have a document on window");
let game_data_input = document.get_element_by_id("game-data").expect("no game data input");
game_data_input.set_inner_html(&bitsy_parser::mock::game_default().to_string());
} }
fn tile_name(prefix: &str, index: &u32) -> Option<String> { fn tile_name(prefix: &str, index: &u32) -> Option<String> {