From fe90712b8a86cbcd9c90803a82b497c5a213edec Mon Sep 17 00:00:00 2001 From: Jeff Kristian Date: Wed, 10 Jan 2024 17:36:07 -0700 Subject: [PATCH] fix(textarea): add checks for height bug in chat input (#1691) --- kit/src/elements/textarea/event_listeners.js | 51 -------------------- kit/src/elements/textarea/script.js | 10 +++- 2 files changed, 8 insertions(+), 53 deletions(-) delete mode 100644 kit/src/elements/textarea/event_listeners.js diff --git a/kit/src/elements/textarea/event_listeners.js b/kit/src/elements/textarea/event_listeners.js deleted file mode 100644 index f2d509a3001..00000000000 --- a/kit/src/elements/textarea/event_listeners.js +++ /dev/null @@ -1,51 +0,0 @@ -var MULTI_LINE = $MULTI_LINE; - -var sendButton = document.getElementsByClassName("controls") -var textareas = document.getElementsByClassName("input_textarea") -for (let i = 0; i < textareas.length; i++) { - var txt = textareas[i]; - //Update the height on load - updateHeight(txt); - if (!txt.event_listener) { - txt.addEventListener("input", inputListener); - txt.addEventListener("keypress", keyPressListener); - txt.addEventListener("keydown", arrowHandlerListener); - txt.event_listener = true; - if (i == 0) { - txt.addEventListener("keypress", (event) => { - if (event.keyCode === 13 && !event.shiftKey) { - textareas[0].style.height = "22px"; - textareas[0].value = ""; - } - }); - } - } -} - -sendButton[1].addEventListener("click", (event) => { - textareas[0].style.height = "22px"; - textareas[0].value = ""; -}) - -function inputListener(e) { - updateHeight(this); -} - -function updateHeight(element) { - element.style.height = "auto"; - if (!element.value || MULTI_LINE) { - element.style.height = "0px"; - } - element.style.height = element.scrollHeight + "px"; -} -function keyPressListener(e) { - if (e.key == "Enter" && MULTI_LINE && !e.shiftKey) { - e.preventDefault(); - } -} - -function arrowHandlerListener(e) { - if (this.classList.contains("up-down-disabled") && (e.key == "ArrowUp" || e.key == "ArrowDown")) { - e.preventDefault(); - } -} diff --git a/kit/src/elements/textarea/script.js b/kit/src/elements/textarea/script.js index 68c39fa80cd..2417cecd068 100644 --- a/kit/src/elements/textarea/script.js +++ b/kit/src/elements/textarea/script.js @@ -27,8 +27,14 @@ sendButton[1].addEventListener("click", (event) => { textareas[0].value = ""; }) -if (textareas[0].style.height === "66px") { - textareas[0].style.height = "22px"; +switch (textareas[0].style.height) { + case "66px": + case "44px": + case "330px": + textareas[0].style.height = "22px"; + break; + default: + break; } function inputListener(e) {