ref: 5ba1bf55600443ca6cdad448aa629ffbce7c4e22
parent: 48ded126a9fd399cf2d9c66ee928f4d1d6d065e4
author: Ben Harris <bjh21@bjh21.me.uk>
date: Sun Dec 11 07:17:54 EST 2022
js: Tolerate the absence of various UI elements from the HTML To make things more consistent, the static buttons now all have their own variables.
--- a/emcclib.js
+++ b/emcclib.js
@@ -62,9 +62,11 @@
* provides neither presets nor configurability.
*/
js_remove_type_dropdown: function() {+ if (gametypelist === null) return;
var gametypeitem = gametypelist.closest("li");if (gametypeitem === null) return;
gametypeitem.parentNode.removeChild(gametypeitem);
+ gametypelist = null;
},
/*
@@ -74,11 +76,11 @@
* time if the game doesn't support an in-game solve function.
*/
js_remove_solve_button: function() {- var solvebutton = document.getElementById("solve");- if (solvebutton === null) return;
- var solveitem = solvebutton.closest("li");- if (solveitem === null) return;
- solveitem.parentNode.removeChild(solveitem);
+ if (solve_button === null) return;
+ var solve_item = solve_button.closest("li");+ if (solve_item === null) return;
+ solve_item.parentNode.removeChild(solve_item);
+ solve_button = null;
},
/*
--- a/emccpre.js
+++ b/emccpre.js
@@ -146,9 +146,16 @@
var permalink_seed = document.getElementById("permalink-seed"); var permalink_desc = document.getElementById("permalink-desc");-// The undo and redo buttons. Used by js_enable_undo_redo().
+// The various buttons. Undo and redo are used by js_enable_undo_redo().
+var specific_button = document.getElementById("specific");+var random_button = document.getElementById("random");+var new_button = document.getElementById("new");+var restart_button = document.getElementById("restart"); var undo_button = document.getElementById("undo"); var redo_button = document.getElementById("redo");+var solve_button = document.getElementById("solve");+var save_button = document.getElementById("save");+var load_button = document.getElementById("load");// A div element enclosing both the puzzle and its status bar, used
// for positioning the resize handle.
@@ -359,7 +366,7 @@
command = Module.cwrap('command', 'void', ['number']);// Event handlers for buttons and things, which call command().
- document.getElementById("specific").onclick = function(event) {+ if (specific_button) specific_button.onclick = function(event) {// Ensure we don't accidentally process these events when a
// dialog is actually active, e.g. because the button still
// has keyboard focus
@@ -366,27 +373,27 @@
if (dlg_dimmer === null)
command(0);
};
- document.getElementById("random").onclick = function(event) {+ if (random_button) random_button.onclick = function(event) {if (dlg_dimmer === null)
command(1);
};
- document.getElementById("new").onclick = function(event) {+ if (new_button) new_button.onclick = function(event) {if (dlg_dimmer === null)
command(5);
};
- document.getElementById("restart").onclick = function(event) {+ if (restart_button) restart_button.onclick = function(event) {if (dlg_dimmer === null)
command(6);
};
- undo_button.onclick = function(event) {+ if (undo_button) undo_button.onclick = function(event) {if (dlg_dimmer === null)
command(7);
};
- redo_button.onclick = function(event) {+ if (redo_button) redo_button.onclick = function(event) {if (dlg_dimmer === null)
command(8);
};
- document.getElementById("solve").onclick = function(event) {+ if (solve_button) solve_button.onclick = function(event) {if (dlg_dimmer === null)
command(9);
};
@@ -396,7 +403,7 @@
var free_save_file = Module.cwrap('free_save_file', 'void', ['number']); var load_game = Module.cwrap('load_game', 'void', ['string', 'number']);- document.getElementById("save").onclick = function(event) {+ if (save_button) save_button.onclick = function(event) { if (dlg_dimmer === null) {var savefile_ptr = get_save_file();
var savefile_text = UTF8ToString(savefile_ptr);
@@ -418,7 +425,7 @@
}
};
- document.getElementById("load").onclick = function(event) {+ if (load_button) load_button.onclick = function(event) { if (dlg_dimmer === null) { var input = document.createElement("input");input.type = "file";
--
⑨