import { PreviewMessage, ThinkingMessage } from './message'; import { Greeting } from './greeting'; import { memo } from 'react'; import type { Vote } from '@/lib/db/schema'; import equal from 'fast-deep-equal'; import type { UseChatHelpers } from '@ai-sdk/react'; import { motion } from 'framer-motion'; import { useMessages } from '@/hooks/use-messages'; import type { ChatMessage } from '@/lib/types'; import { useDataStream } from './data-stream-provider'; import { Conversation, ConversationContent, ConversationScrollButton } from './elements/conversation'; interface MessagesProps { chatId: string; status: UseChatHelpers['status']; votes: Array | undefined; messages: ChatMessage[]; setMessages: UseChatHelpers['setMessages']; regenerate: UseChatHelpers['regenerate']; isReadonly: boolean; isArtifactVisible: boolean; } function PureMessages({ chatId, status, votes, messages, setMessages, regenerate, isReadonly, }: MessagesProps) { const { containerRef: messagesContainerRef, endRef: messagesEndRef, onViewportEnter, onViewportLeave, hasSentMessage, } = useMessages({ chatId, status, }); useDataStream(); return (
{messages.length === 0 && } {messages.map((message, index) => ( vote.messageId === message.id) : undefined } setMessages={setMessages} regenerate={regenerate} isReadonly={isReadonly} requiresScrollPadding={ hasSentMessage && index === messages.length - 1 } /> ))} {status === 'submitted' && messages.length > 0 && messages[messages.length - 1].role === 'user' && }
); } export const Messages = memo(PureMessages, (prevProps, nextProps) => { if (prevProps.isArtifactVisible && nextProps.isArtifactVisible) return true; if (prevProps.status !== nextProps.status) return false; if (prevProps.messages.length !== nextProps.messages.length) return false; if (!equal(prevProps.messages, nextProps.messages)) return false; if (!equal(prevProps.votes, nextProps.votes)) return false; return false; });