-
+
@@ -439,78 +400,13 @@ export function Block({
-
-
-
-
-
- Copy to clipboard
-
-
-
-
-
- View Previous version
-
-
-
-
-
- View Next version
-
-
-
-
-
- View changes
-
-
+
@@ -570,3 +466,7 @@ export function Block({
);
}
+
+export const Block = memo(PureBlock, (prevProps, nextProps) => {
+ return false;
+});
diff --git a/components/chat-header.tsx b/components/chat-header.tsx
index 2e6be7cd3..27e9e7529 100644
--- a/components/chat-header.tsx
+++ b/components/chat-header.tsx
@@ -10,8 +10,9 @@ import { Button } from '@/components/ui/button';
import { BetterTooltip } from '@/components/ui/tooltip';
import { PlusIcon, VercelIcon } from './icons';
import { useSidebar } from './ui/sidebar';
+import { memo } from 'react';
-export function ChatHeader({ selectedModelId }: { selectedModelId: string }) {
+function PureChatHeader({ selectedModelId }: { selectedModelId: string }) {
const router = useRouter();
const { open } = useSidebar();
@@ -54,3 +55,7 @@ export function ChatHeader({ selectedModelId }: { selectedModelId: string }) {
);
}
+
+export const ChatHeader = memo(PureChatHeader, (prevProps, nextProps) => {
+ return prevProps.selectedModelId === nextProps.selectedModelId;
+});
diff --git a/components/chat.tsx b/components/chat.tsx
index 425ea1513..ad65857e6 100644
--- a/components/chat.tsx
+++ b/components/chat.tsx
@@ -8,15 +8,13 @@ import useSWR, { useSWRConfig } from 'swr';
import { useWindowSize } from 'usehooks-ts';
import { ChatHeader } from '@/components/chat-header';
-import { PreviewMessage, ThinkingMessage } from '@/components/message';
-import { useScrollToBottom } from '@/components/use-scroll-to-bottom';
import type { Vote } from '@/lib/db/schema';
import { fetcher } from '@/lib/utils';
import { Block, type UIBlock } from './block';
import { BlockStreamHandler } from './block-stream-handler';
import { MultimodalInput } from './multimodal-input';
-import { Overview } from './overview';
+import { Messages } from './messages';
export function Chat({
id,
@@ -69,48 +67,22 @@ export function Chat({
fetcher,
);
- const [messagesContainerRef, messagesEndRef] =
- useScrollToBottom
();
-
const [attachments, setAttachments] = useState>([]);
return (
<>
-
- {messages.length === 0 &&
}
-
- {messages.map((message, index) => (
-
vote.messageId === message.id)
- : undefined
- }
- />
- ))}
- {isLoading &&
- messages.length > 0 &&
- messages[messages.length - 1].role === 'user' && (
-
- )}
+
-
-