diff --git a/tools/server/public/index.html.gz b/tools/server/public/index.html.gz index d7363e13eb25a..b81ea699445bd 100644 Binary files a/tools/server/public/index.html.gz and b/tools/server/public/index.html.gz differ diff --git a/tools/server/webui/src/components/ChatScreen.tsx b/tools/server/webui/src/components/ChatScreen.tsx index b645a494d6853..ebf4e3f8f43f8 100644 --- a/tools/server/webui/src/components/ChatScreen.tsx +++ b/tools/server/webui/src/components/ChatScreen.tsx @@ -1,4 +1,4 @@ -import { useEffect, useMemo, useRef, useState } from 'react'; +import { ClipboardEvent, useEffect, useMemo, useRef, useState } from 'react'; import { CallbackGeneratedChunk, useAppContext } from '../utils/app.context'; import ChatMessage from './ChatMessage'; import { CanvasType, Message, PendingMessage } from '../utils/types'; @@ -328,6 +328,17 @@ function ChatInput({ {({ getRootProps, getInputProps }) => (
) => { + const files = Array.from(e.clipboardData.items) + .filter((item) => item.kind === 'file') + .map((item) => item.getAsFile()) + .filter((file) => file !== null) + + if (files.length > 0) { + e.preventDefault(); + extraContext.onFileAdded(files); + } + }} {...getRootProps()} > {!isGenerating && (