Fixed input handling

This commit is contained in:
FlamedDogo99 2024-06-08 07:45:11 -06:00
parent 09e7789ec5
commit 84065d8573
2 changed files with 53 additions and 31 deletions

View File

@ -134,22 +134,23 @@ Object.defineProperty(Document.prototype, "exitFullscreen", {
const _createElement = document.createElement; const _createElement = document.createElement;
document.createElement = function(type, ignore) { document.createElement = function(type, ignore) {
this._createElement = _createElement; this._createElement = _createElement;
let element = this._createElement(type); var element = this._createElement(type);
if(type == "input" && !ignore) { if(type == "input" && !ignore) {
let newElement = document.querySelector('input'); document.querySelectorAll('#fileUpload').forEach(e => e.parentNode.removeChild(e));
if(!newElement) { element.id = "fileUpload";
this.body.appendChild(element); element.addEventListener('change', function(e) {
newElement = document.querySelector('input'); element.hidden = true;
newElement.addEventListener('change', function(e) { element.style.display = "none";
this.hidden = true; }, {passive: false, once: true});
}) window.addEventListener('focus', function(e) {
setTimeout(() => {
element.hidden = true;
element.style.display = "none";
}, 300)
}, { once: true })
document.body.appendChild(element);
} }
newElement.value = null; return element;
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;
}
return this._createElement(type);
} }
// Lazy way to hide touch controls through CSS. // 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. // 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.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.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 let inputData = e.data ?? "delete"; // backspace makes null
window.lastKey = inputData window.lastKey = inputData
hiddenInput.value = " "; // We need a character to detect deleting hiddenInput.value = " "; // We need a character to detect deleting
@ -529,6 +530,16 @@ customStyle.textContent = `
.hide { .hide {
display: none; 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 { .strafeRightButton {
background-image: url(""); background-image: url("");
} }

View File

@ -6,7 +6,7 @@
// @downloadURL https://raw.githubusercontent.com/FlamedDogo99/EaglerMobile/main/eaglermobile.user.js // @downloadURL https://raw.githubusercontent.com/FlamedDogo99/EaglerMobile/main/eaglermobile.user.js
// @license Apache License 2.0 - http://www.apache.org/licenses/ // @license Apache License 2.0 - http://www.apache.org/licenses/
// @match https://eaglercraft.com/mc/* // @match https://eaglercraft.com/mc/*
// @version 3.0.1 // @version 3.0.2
// @updateURL https://raw.githubusercontent.com/FlamedDogo99/EaglerMobile/main/eaglermobile.user.js // @updateURL https://raw.githubusercontent.com/FlamedDogo99/EaglerMobile/main/eaglermobile.user.js
// @run-at document-start // @run-at document-start
// ==/UserScript== // ==/UserScript==
@ -148,22 +148,23 @@ Object.defineProperty(Document.prototype, "exitFullscreen", {
const _createElement = document.createElement; const _createElement = document.createElement;
document.createElement = function(type, ignore) { document.createElement = function(type, ignore) {
this._createElement = _createElement; this._createElement = _createElement;
let element = this._createElement(type); var element = this._createElement(type);
if(type == "input" && !ignore) { if(type == "input" && !ignore) {
let newElement = document.querySelector('input'); document.querySelectorAll('#fileUpload').forEach(e => e.parentNode.removeChild(e));
if(!newElement) { element.id = "fileUpload";
this.body.appendChild(element); element.addEventListener('change', function(e) {
newElement = document.querySelector('input'); element.hidden = true;
newElement.addEventListener('change', function(e) { element.style.display = "none";
this.hidden = true; }, {passive: false, once: true});
}) window.addEventListener('focus', function(e) {
setTimeout(() => {
element.hidden = true;
element.style.display = "none";
}, 300)
}, { once: true })
document.body.appendChild(element);
} }
newElement.value = null; return element;
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;
}
return this._createElement(type);
} }
// Lazy way to hide touch controls through CSS. // 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. // 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.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.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 let inputData = e.data ?? "delete"; // backspace makes null
window.lastKey = inputData window.lastKey = inputData
hiddenInput.value = " "; // We need a character to detect deleting hiddenInput.value = " "; // We need a character to detect deleting
@ -543,6 +544,16 @@ customStyle.textContent = `
.hide { .hide {
display: none; 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 { .strafeRightButton {
background-image: url(""); background-image: url("");
} }