ai-sdk-next-openai/app/use-chat-resilient-persistence/[id]/chat.tsx
2025-09-26 15:46:29 +00:00

40 lines
1.1 KiB
TypeScript

'use client';
import ChatInput from '@/component/chat-input';
import { UIMessage, useChat } from '@ai-sdk/react';
import { DefaultChatTransport } from 'ai';
import { createIdGenerator } from 'ai';
export default function Chat({
id,
initialMessages,
}: { id?: string | undefined; initialMessages?: UIMessage[] } = {}) {
const { sendMessage, status, messages, stop } = useChat({
id,
messages: initialMessages,
transport: new DefaultChatTransport({
api: '/api/use-chat-resilient-persistence',
}),
generateId: createIdGenerator({ prefix: 'msgc', size: 16 }), // id format for client-side messages
});
return (
<div className="flex flex-col w-full max-w-md py-24 mx-auto stretch">
{messages.map(m => (
<div key={m.id} className="whitespace-pre-wrap">
{m.role === 'user' ? 'User: ' : 'AI: '}
{m.parts
.map(part => (part.type === 'text' ? part.text : ''))
.join('')}
</div>
))}
<ChatInput
status={status}
stop={stop}
onSubmit={text => sendMessage({ text })}
/>
</div>
);
}