From 187f6aff3e60e7c4a193453fab5f32bff2db88b0 Mon Sep 17 00:00:00 2001 From: Thomas Weber Date: Tue, 7 Jan 2025 18:47:01 -0600 Subject: [PATCH] veggiecan/mobilekeyboard: a couple changes (#1851) - Fix "show keyboard and wait" getting stuck forever if run more than once concurrently (may have other problems still) - Add note that it only works on Android --- extensions/veggiecan/mobilekeyboard.js | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) diff --git a/extensions/veggiecan/mobilekeyboard.js b/extensions/veggiecan/mobilekeyboard.js index 2ddf765fd6..86f0ec307d 100644 --- a/extensions/veggiecan/mobilekeyboard.js +++ b/extensions/veggiecan/mobilekeyboard.js @@ -19,7 +19,8 @@ class MobileKeyboard { constructor() { this.keyboardOpen = false; - this.waitCallback = null; + /** @type {Array<() => void>} */ + this.waitCallbacks = []; this.defaultValue = ""; this.inputElement = null; } @@ -34,6 +35,10 @@ blockIconURI: blockicon, name: Scratch.translate("Mobile Keyboard"), blocks: [ + { + blockType: Scratch.BlockType.LABEL, + text: Scratch.translate("Currently only works on Android"), + }, { opcode: "showKeyboardBlock", blockType: Scratch.BlockType.COMMAND, @@ -207,10 +212,10 @@ input.parentNode.removeChild(input); } - if (this.waitCallback) { - this.waitCallback(); - this.waitCallback = null; + for (const callback of this.waitCallbacks) { + callback(); } + this.waitCallbacks.length = 0; }; input.addEventListener("input", () => { @@ -236,7 +241,7 @@ showKeyboardAndWaitBlock(args) { return new Promise((resolve) => { - this.waitCallback = resolve; + this.waitCallbacks.push(() => resolve()); this.showKeyboard(args.TYPE); }); }