mirror of
https://github.com/MODSetter/SurfSense.git
synced 2025-09-02 02:29:08 +00:00
71 lines
2.6 KiB
TypeScript
71 lines
2.6 KiB
TypeScript
"use client";
|
|
|
|
import React from "react";
|
|
import { ChatMessage as LlamaIndexChatMessage, ChatMessages as LlamaIndexChatMessages, Message, useChatUI } from "@llamaindex/chat-ui";
|
|
import TerminalDisplay from "@/components/chat_v2/ChatTerminal";
|
|
import ChatSourcesDisplay from "@/components/chat_v2/ChatSources";
|
|
import { CitationDisplay } from "@/components/chat_v2/ChatCitation";
|
|
import { ChatFurtherQuestions } from "@/components/chat_v2/ChatFurtherQuestions";
|
|
|
|
export function ChatMessagesUI() {
|
|
const { messages } = useChatUI();
|
|
|
|
return (
|
|
<LlamaIndexChatMessages className="flex-1">
|
|
<LlamaIndexChatMessages.List className="p-4">
|
|
{messages.map((message, index) => (
|
|
<ChatMessageUI
|
|
key={`Message-${index}`}
|
|
message={message}
|
|
isLast={index === messages.length - 1}
|
|
/>
|
|
))}
|
|
</LlamaIndexChatMessages.List>
|
|
<LlamaIndexChatMessages.Loading />
|
|
</LlamaIndexChatMessages>
|
|
);
|
|
}
|
|
|
|
function ChatMessageUI({
|
|
message,
|
|
isLast,
|
|
}: {
|
|
message: Message;
|
|
isLast: boolean;
|
|
}) {
|
|
|
|
const bottomRef = React.useRef<HTMLDivElement>(null);
|
|
|
|
React.useEffect(() => {
|
|
if (isLast && bottomRef.current) {
|
|
bottomRef.current.scrollIntoView({ behavior: "smooth" });
|
|
}
|
|
}, [message]);
|
|
|
|
return (
|
|
<LlamaIndexChatMessage
|
|
message={message}
|
|
isLast={isLast}
|
|
className="flex flex-col "
|
|
>
|
|
{message.role === "assistant" ? (
|
|
<div className="flex-1 flex flex-col space-y-4">
|
|
<TerminalDisplay message={message} open={isLast} />
|
|
<ChatSourcesDisplay message={message} />
|
|
<LlamaIndexChatMessage.Content className="flex-1">
|
|
<LlamaIndexChatMessage.Content.Markdown citationComponent={CitationDisplay} />
|
|
</LlamaIndexChatMessage.Content>
|
|
<div ref={bottomRef} />
|
|
<div className="flex flex-row justify-end gap-2">
|
|
{isLast && <ChatFurtherQuestions message={message} />}
|
|
<LlamaIndexChatMessage.Actions className="flex-1 flex-col" />
|
|
</div>
|
|
</div>
|
|
) : (
|
|
<LlamaIndexChatMessage.Content className="flex-1">
|
|
<LlamaIndexChatMessage.Content.Markdown />
|
|
</LlamaIndexChatMessage.Content>
|
|
)}
|
|
</LlamaIndexChatMessage>
|
|
);
|
|
}
|