From 84065d8573c84146079a6621cfb3cb7f64ad6897 Mon Sep 17 00:00:00 2001 From: FlamedDogo99 <96555444+FlamedDogo99@users.noreply.github.com> Date: Sat, 8 Jun 2024 07:45:11 -0600 Subject: [PATCH] Fixed input handling --- eaglermobile-ef.js | 41 ++++++++++++++++++++++++++--------------- eaglermobile.user.js | 43 +++++++++++++++++++++++++++---------------- 2 files changed, 53 insertions(+), 31 deletions(-) diff --git a/eaglermobile-ef.js b/eaglermobile-ef.js index a30a05a..b3811c5 100644 --- a/eaglermobile-ef.js +++ b/eaglermobile-ef.js @@ -134,22 +134,23 @@ Object.defineProperty(Document.prototype, "exitFullscreen", { const _createElement = document.createElement; document.createElement = function(type, ignore) { this._createElement = _createElement; - let element = this._createElement(type); + var element = this._createElement(type); if(type == "input" && !ignore) { - let newElement = document.querySelector('input'); - if(!newElement) { - this.body.appendChild(element); - newElement = document.querySelector('input'); - newElement.addEventListener('change', function(e) { - this.hidden = true; - }) - } - newElement.value = null; - newElement.style.cssText ="position:absolute;left:0%;right:100%;top:0%;bottom:100%;width:100%;height:100%;background-color:rgba(255,255,255,0.5);"; - newElement.hidden = false; - return newElement; + document.querySelectorAll('#fileUpload').forEach(e => e.parentNode.removeChild(e)); + element.id = "fileUpload"; + element.addEventListener('change', function(e) { + element.hidden = true; + element.style.display = "none"; + }, {passive: false, once: true}); + window.addEventListener('focus', function(e) { + setTimeout(() => { + element.hidden = true; + element.style.display = "none"; + }, 300) + }, { once: true }) + document.body.appendChild(element); } - return this._createElement(type); + return element; } // Lazy way to hide touch controls through CSS. @@ -351,7 +352,7 @@ function insertCanvasElements() { // We are hiding the text input behind button because opacity was causing problems. hiddenInput.style.cssText = "position:absolute;top: 0vh; margin: auto; left: 8vh; right:0vh; width: 8vh; height: 8vh;font-size:20px;z-index:-10;color: transparent;text-shadow: 0 0 0 black;"; hiddenInput.value = " " //Allows delete to be detected before input is changed - hiddenInput.addEventListener("input", function hiddenInputHandler(e) { + hiddenInput.addEventListener("input", function(e) { let inputData = e.data ?? "delete"; // backspace makes null window.lastKey = inputData hiddenInput.value = " "; // We need a character to detect deleting @@ -529,6 +530,16 @@ customStyle.textContent = ` .hide { display: none; } + #fileUpload { + position: absolute; + left: 0; + right: 100vw; + top: 0; + bottom: 100vh; + width: 100vw; + height: 100vh; + background-color:rgba(255,255,255,0.5); + } .strafeRightButton { background-image: url(""); } diff --git a/eaglermobile.user.js b/eaglermobile.user.js index 6a07c76..93050be 100644 --- a/eaglermobile.user.js +++ b/eaglermobile.user.js @@ -6,7 +6,7 @@ // @downloadURL https://raw.githubusercontent.com/FlamedDogo99/EaglerMobile/main/eaglermobile.user.js // @license Apache License 2.0 - http://www.apache.org/licenses/ // @match https://eaglercraft.com/mc/* -// @version 3.0.1 +// @version 3.0.2 // @updateURL https://raw.githubusercontent.com/FlamedDogo99/EaglerMobile/main/eaglermobile.user.js // @run-at document-start // ==/UserScript== @@ -148,22 +148,23 @@ Object.defineProperty(Document.prototype, "exitFullscreen", { const _createElement = document.createElement; document.createElement = function(type, ignore) { this._createElement = _createElement; - let element = this._createElement(type); + var element = this._createElement(type); if(type == "input" && !ignore) { - let newElement = document.querySelector('input'); - if(!newElement) { - this.body.appendChild(element); - newElement = document.querySelector('input'); - newElement.addEventListener('change', function(e) { - this.hidden = true; - }) - } - newElement.value = null; - newElement.style.cssText ="position:absolute;left:0%;right:100%;top:0%;bottom:100%;width:100%;height:100%;background-color:rgba(255,255,255,0.5);"; - newElement.hidden = false; - return newElement; + document.querySelectorAll('#fileUpload').forEach(e => e.parentNode.removeChild(e)); + element.id = "fileUpload"; + element.addEventListener('change', function(e) { + element.hidden = true; + element.style.display = "none"; + }, {passive: false, once: true}); + window.addEventListener('focus', function(e) { + setTimeout(() => { + element.hidden = true; + element.style.display = "none"; + }, 300) + }, { once: true }) + document.body.appendChild(element); } - return this._createElement(type); + return element; } // Lazy way to hide touch controls through CSS. @@ -365,7 +366,7 @@ function insertCanvasElements() { // We are hiding the text input behind button because opacity was causing problems. hiddenInput.style.cssText = "position:absolute;top: 0vh; margin: auto; left: 8vh; right:0vh; width: 8vh; height: 8vh;font-size:20px;z-index:-10;color: transparent;text-shadow: 0 0 0 black;"; hiddenInput.value = " " //Allows delete to be detected before input is changed - hiddenInput.addEventListener("input", function hiddenInputHandler(e) { + hiddenInput.addEventListener("input", function(e) { let inputData = e.data ?? "delete"; // backspace makes null window.lastKey = inputData hiddenInput.value = " "; // We need a character to detect deleting @@ -543,6 +544,16 @@ customStyle.textContent = ` .hide { display: none; } + #fileUpload { + position: absolute; + left: 0; + right: 100vw; + top: 0; + bottom: 100vh; + width: 100vw; + height: 100vh; + background-color:rgba(255,255,255,0.5); + } .strafeRightButton { background-image: url(""); }