import { html } from '../lib/preact.js'; import { getUserMessageBg } from '../utils/status.js'; import { MessageBubble, filterDisplayMessages } from './MessageBubble.js'; export function ChatMessages({ messages, status, limit = 20 }) { const userBgClass = getUserMessageBg(status); if (!messages || messages.length === 0) { return html`
No messages to show
`; } const allDisplayMessages = filterDisplayMessages(messages); const displayMessages = limit ? allDisplayMessages.slice(-limit) : allDisplayMessages; const offset = allDisplayMessages.length - displayMessages.length; return html`
${displayMessages.map((msg, i) => html` <${MessageBubble} key=${`${msg.role}-${msg.timestamp || (offset + i)}`} msg=${msg} userBg=${userBgClass} compact=${true} /> `)}
`; }