refac: chat input file handling

This commit is contained in:
Timothy J. Baek
2024-10-26 12:56:37 -07:00
parent 032abba88e
commit 15cfdc69a8
3 changed files with 22 additions and 5 deletions

View File

@@ -1,5 +1,7 @@
<script lang="ts">
import { toast } from 'svelte-sonner';
import { v4 as uuidv4 } from 'uuid';
import { onMount, tick, getContext, createEventDispatcher, onDestroy } from 'svelte';
const dispatch = createEventDispatcher();
@@ -89,6 +91,7 @@
const uploadFileHandler = async (file) => {
console.log(file);
const tempItemId = uuidv4();
const fileItem = {
type: 'file',
file: '',
@@ -98,10 +101,16 @@
collection_name: '',
status: 'uploading',
size: file.size,
error: ''
error: '',
itemId: tempItemId
};
files = [...files, fileItem];
if (fileItem.size == 0) {
toast.error($i18n.t('You cannot upload an empty file.'));
return null;
}
files = [...files, fileItem];
// Check if the file is an audio file and transcribe/convert it to text file
if (['audio/mpeg', 'audio/wav', 'audio/ogg', 'audio/x-m4a'].includes(file['type'])) {
const res = await transcribeAudio(localStorage.token, file).catch((error) => {
@@ -132,11 +141,11 @@
files = files;
} else {
files = files.filter((item) => item.status !== null);
files = files.filter((item) => item?.itemId !== tempItemId);
}
} catch (e) {
toast.error(e);
files = files.filter((item) => item.status !== null);
files = files.filter((item) => item?.itemId !== tempItemId);
}
};