From 97d68a6a05caaeef6fd3ac07fafe7af78ff325fd Mon Sep 17 00:00:00 2001 From: "Timothy J. Baek" Date: Sat, 20 Apr 2024 13:41:16 -0500 Subject: [PATCH] feat: multiple files input Co-Authored-By: Entaigner <61445450+entaigner@users.noreply.github.com> --- src/lib/components/chat/MessageInput.svelte | 80 +++++++++++---------- 1 file changed, 42 insertions(+), 38 deletions(-) diff --git a/src/lib/components/chat/MessageInput.svelte b/src/lib/components/chat/MessageInput.svelte index eff65a254..ebf8e9713 100644 --- a/src/lib/components/chat/MessageInput.svelte +++ b/src/lib/components/chat/MessageInput.svelte @@ -328,27 +328,28 @@ ]; }; - const inputFiles = e.dataTransfer?.files; + const inputFiles = Array.from(e.dataTransfer?.files); if (inputFiles && inputFiles.length > 0) { - const file = inputFiles[0]; - console.log(file, file.name.split('.').at(-1)); - if (['image/gif', 'image/jpeg', 'image/png'].includes(file['type'])) { - reader.readAsDataURL(file); - } else if ( - SUPPORTED_FILE_TYPE.includes(file['type']) || - SUPPORTED_FILE_EXTENSIONS.includes(file.name.split('.').at(-1)) - ) { - uploadDoc(file); - } else { - toast.error( - $i18n.t( - `Unknown File Type '{{file_type}}', but accepting and treating as plain text`, - { file_type: file['type'] } - ) - ); - uploadDoc(file); - } + inputFiles.forEach((file) => { + console.log(file, file.name.split('.').at(-1)); + if (['image/gif', 'image/jpeg', 'image/png'].includes(file['type'])) { + reader.readAsDataURL(file); + } else if ( + SUPPORTED_FILE_TYPE.includes(file['type']) || + SUPPORTED_FILE_EXTENSIONS.includes(file.name.split('.').at(-1)) + ) { + uploadDoc(file); + } else { + toast.error( + $i18n.t( + `Unknown File Type '{{file_type}}', but accepting and treating as plain text`, + { file_type: file['type'] } + ) + ); + uploadDoc(file); + } + }); } else { toast.error($i18n.t(`File not found.`)); } @@ -467,6 +468,7 @@ bind:files={inputFiles} type="file" hidden + multiple on:change={async () => { let reader = new FileReader(); reader.onload = (event) => { @@ -482,25 +484,27 @@ }; if (inputFiles && inputFiles.length > 0) { - const file = inputFiles[0]; - if (['image/gif', 'image/jpeg', 'image/png'].includes(file['type'])) { - reader.readAsDataURL(file); - } else if ( - SUPPORTED_FILE_TYPE.includes(file['type']) || - SUPPORTED_FILE_EXTENSIONS.includes(file.name.split('.').at(-1)) - ) { - uploadDoc(file); - filesInputElement.value = ''; - } else { - toast.error( - $i18n.t( - `Unknown File Type '{{file_type}}', but accepting and treating as plain text`, - { file_type: file['type'] } - ) - ); - uploadDoc(file); - filesInputElement.value = ''; - } + const _inputFiles = Array.from(inputFiles); + _inputFiles.forEach((file) => { + if (['image/gif', 'image/jpeg', 'image/png'].includes(file['type'])) { + reader.readAsDataURL(file); + } else if ( + SUPPORTED_FILE_TYPE.includes(file['type']) || + SUPPORTED_FILE_EXTENSIONS.includes(file.name.split('.').at(-1)) + ) { + uploadDoc(file); + filesInputElement.value = ''; + } else { + toast.error( + $i18n.t( + `Unknown File Type '{{file_type}}', but accepting and treating as plain text`, + { file_type: file['type'] } + ) + ); + uploadDoc(file); + filesInputElement.value = ''; + } + }); } else { toast.error($i18n.t(`File not found.`)); }