From f6fcc6edbeeb01d23ce33c0ceb9a239f545bdab2 Mon Sep 17 00:00:00 2001 From: Ahmed Awan Date: Mon, 22 Jul 2024 11:54:47 -0500 Subject: [PATCH] add explicit event listeners to prevent modal closing from selects --- client/src/components/Upload/UploadModal.vue | 18 +++++++++++++++++- client/src/components/Upload/UploadSelect.vue | 17 ++++++++++++++++- 2 files changed, 33 insertions(+), 2 deletions(-) diff --git a/client/src/components/Upload/UploadModal.vue b/client/src/components/Upload/UploadModal.vue index 30e1ed261734..5da48c2f5a2e 100644 --- a/client/src/components/Upload/UploadModal.vue +++ b/client/src/components/Upload/UploadModal.vue @@ -4,7 +4,7 @@ import { setIframeEvents } from "components/Upload/utils"; import { useConfig } from "composables/config"; import { useUserHistories } from "composables/userHistories"; import { storeToRefs } from "pinia"; -import { ref, watch } from "vue"; +import { onBeforeUnmount, onMounted, ref, watch } from "vue"; import { useUserStore } from "@/stores/userStore"; import { wait } from "@/utils/utils"; @@ -68,10 +68,26 @@ watch( defineExpose({ open, }); + +// Handle escape key press in modal +// (modal stays open when esc key is pressed in some child components, hence using `no-close-on-esc`) +const uploadModal = ref(null); +onMounted(() => { + uploadModal.value?.$el.addEventListener("keyup", handleKeyUp); +}); +onBeforeUnmount(() => { + uploadModal.value?.$el.removeEventListener("keyup", handleKeyUp); +}); +function handleKeyUp(event) { + if (event.key === "Escape") { + dismiss(); + } +}