Spaces:
Runtime error
Runtime error
| import useLLM from "@react-llm/headless"; | |
| import Image from "next/image"; | |
| import { useCallback, useEffect, useState } from "react"; | |
| import MessageList from './MessageList'; | |
| import {FileLoader} from './FileLoader'; | |
| import Loader from "./Loader"; | |
| function ChatWindow({ | |
| stopStrings, | |
| maxTokens, | |
| }) { | |
| const { loadingStatus, send, isGenerating, setOnMessage } = useLLM(); | |
| const [userInput, setUserInput] = useState(""); | |
| const handleChange = (event) => { | |
| setUserInput(event.target.value); | |
| }; | |
| const isReady = loadingStatus.progress === 1; | |
| const handleSubmit = useCallback(() => { | |
| if (isGenerating || !isReady) { | |
| return; | |
| } | |
| send(userInput, maxTokens, stopStrings); | |
| setUserInput(""); | |
| }, [ | |
| userInput, | |
| send, | |
| isGenerating, | |
| isReady, | |
| maxTokens, | |
| stopStrings | |
| ]); | |
| useEffect(() => { | |
| const handleKeyPress = (event) => { | |
| if (event.key === "Enter") { | |
| event.preventDefault(); | |
| handleSubmit(); | |
| } | |
| }; | |
| window.addEventListener("keydown", handleKeyPress); | |
| return () => { | |
| window.removeEventListener("keydown", handleKeyPress); | |
| }; | |
| }, [handleSubmit]); | |
| return ( | |
| <div className="window sm:w-[500px] w-full"> | |
| <div className="window-content w-full"> | |
| <div className="flex flex-col w-full"> | |
| <MessageList | |
| screenName={"me"} | |
| assistantScreenName={"vicuna"} | |
| /> | |
| {/* <Separator /> */} | |
| <div className="h-4" /> | |
| {isReady && ( | |
| <div> | |
| <form onSubmit={handleSubmit}> | |
| <div className="flex"> | |
| <input | |
| style={{ width: '95%', padding: '10px'}} | |
| value={userInput} | |
| placeholder="Say something..." | |
| onChange={handleChange} | |
| /> | |
| </div> | |
| </form> | |
| <div className="h-4"> | |
| {isGenerating && ( | |
| <span>is typing...</span> | |
| )} | |
| </div> | |
| <div className="flex justify-start m-2"> | |
| <div> | |
| <div> | |
| <button | |
| onClick={handleSubmit} | |
| className="submit" | |
| style={{ height: "65px", width: "65px" }} | |
| > | |
| <Image | |
| src="" | |
| alt="Send Message" | |
| style={{ | |
| filter: | |
| !isReady || isGenerating | |
| ? "grayscale(100%)" | |
| : undefined, | |
| }} | |
| width="40" | |
| height="40" | |
| /> | |
| </button> | |
| <FileLoader /> | |
| </div> | |
| <div | |
| className="w-full h-1 mt-2" | |
| style={{ | |
| backgroundColor: | |
| !isReady || isGenerating ? "red" : "green", | |
| width: "100%", | |
| height: "5px", | |
| marginTop: "2px", | |
| }} | |
| ></div> | |
| </div> | |
| </div> | |
| </div> | |
| )} | |
| {!isReady && <Loader />} | |
| </div> | |
| </div> | |
| </div> | |
| ); | |
| } | |
| export default ChatWindow; |