From 3c047efe0d7484b80ab90a4c696936338d321523 Mon Sep 17 00:00:00 2001 From: sxjeru Date: Tue, 14 May 2024 13:23:56 +0800 Subject: [PATCH] =?UTF-8?q?=F0=9F=90=9B=20fix:=20dragging=20text=20mistake?= =?UTF-8?q?nly=20as=20image=20(#2111)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../ChatInput/Desktop/Footer/DragUpload.tsx | 55 ++++++++++++------- 1 file changed, 36 insertions(+), 19 deletions(-) diff --git a/src/app/(main)/chat/(workspace)/@conversation/features/ChatInput/Desktop/Footer/DragUpload.tsx b/src/app/(main)/chat/(workspace)/@conversation/features/ChatInput/Desktop/Footer/DragUpload.tsx index 9b275cc9de25..0b7e8d9cc5df 100644 --- a/src/app/(main)/chat/(workspace)/@conversation/features/ChatInput/Desktop/Footer/DragUpload.tsx +++ b/src/app/(main)/chat/(workspace)/@conversation/features/ChatInput/Desktop/Footer/DragUpload.tsx @@ -61,7 +61,12 @@ const useStyles = createStyles(({ css, token, stylish }) => { }); const handleDragOver = (e: DragEvent) => { - e.preventDefault(); + if (!e.dataTransfer?.items || e.dataTransfer.items.length === 0) return; + + const isFile = e.dataTransfer.types.includes('Files'); + if (isFile) { + e.preventDefault(); + } }; const DragUpload = memo(() => { @@ -92,43 +97,55 @@ const DragUpload = memo(() => { }; const handleDragEnter = (e: DragEvent) => { - e.preventDefault(); + if (!e.dataTransfer?.items || e.dataTransfer.items.length === 0) return; - dragCounter.current += 1; - if (e.dataTransfer?.items && e.dataTransfer.items.length > 0) { + const isFile = e.dataTransfer.types.includes('Files'); + if (isFile) { + dragCounter.current += 1; + e.preventDefault(); setIsDragging(true); } }; const handleDragLeave = (e: DragEvent) => { - e.preventDefault(); + if (!e.dataTransfer?.items || e.dataTransfer.items.length === 0) return; - // reset counter - dragCounter.current -= 1; + const isFile = e.dataTransfer.types.includes('Files'); + if (isFile) { + e.preventDefault(); - if (dragCounter.current === 0) { - setIsDragging(false); + // reset counter + dragCounter.current -= 1; + + if (dragCounter.current === 0) { + setIsDragging(false); + } } }; const handleDrop = async (e: DragEvent) => { - e.preventDefault(); - // reset counter - dragCounter.current = 0; + if (!e.dataTransfer?.items || e.dataTransfer.items.length === 0) return; - setIsDragging(false); + const isFile = e.dataTransfer.types.includes('Files'); + if (isFile) { + e.preventDefault(); - // get filesList - // TODO: support folder files upload - const files = e.dataTransfer?.files; + // reset counter + dragCounter.current = 0; - // upload files - uploadImages(files); + setIsDragging(false); + + // get filesList + // TODO: support folder files upload + const files = e.dataTransfer?.files; + + // upload files + uploadImages(files); + } }; const handlePaste = (event: ClipboardEvent) => { // get files from clipboard - const files = event.clipboardData?.files; uploadImages(files);