ai-sdk-next-openai/app/use-chat-image-output/page.tsx
2025-09-26 15:46:29 +00:00

37 lines
1.1 KiB
TypeScript

'use client';
import ChatInput from '@/component/chat-input';
import { useChat } from '@ai-sdk/react';
import { DefaultChatTransport } from 'ai';
export default function Chat() {
const { status, sendMessage, messages } = useChat({
transport: new DefaultChatTransport({ api: '/api/use-chat-image-output' }),
});
return (
<div className="flex flex-col w-full max-w-md py-24 mx-auto stretch">
{messages.map(message => (
<div key={message.id} className="whitespace-pre-wrap">
{message.role === 'user' ? 'User: ' : 'AI: '}
{message.parts.map((part, index) => {
if (part.type === 'text') {
return <div key={index}>{part.text}</div>;
} else if (
part.type === 'file' &&
part.mediaType.startsWith('image/')
) {
return (
// eslint-disable-next-line @next/next/no-img-element
<img key={index} src={part.url} alt="Generated image" />
);
}
})}
</div>
))}
<ChatInput status={status} onSubmit={text => sendMessage({ text })} />
</div>
);
}