Skip to content

Commit

Permalink
feat: improve rendering with static
Browse files Browse the repository at this point in the history
  • Loading branch information
mdjastrzebski committed May 7, 2024
1 parent 26aa42c commit b8a856f
Showing 1 changed file with 23 additions and 16 deletions.
39 changes: 23 additions & 16 deletions src/commands/chat/ui/list/ChatMessageList.tsx
Original file line number Diff line number Diff line change
@@ -1,30 +1,37 @@
import * as React from 'react';
import { Box } from 'ink';
import { useChatState } from '../../state/state.js';
import { Box, Static } from 'ink';
import { useChatState, type ChatMessage } from '../../state/state.js';
import { ProgramChatMessageItem } from './ProgramChatMessageItem.js';
import { UserChatMessageItem } from './UserChatMessageItem.js';
import { AiChatMessageItem } from './AiChatMessageItem.js';

export function ChatMessageList() {
const messages = useChatState((state) => state.chatMessages);

const olderMessages = messages.slice(0, -1);
const latestMessage = messages[messages.length - 1];

return (
<Box display="flex" flexDirection="column">
{messages.map((message, index) => {
if (message.type === 'user') {
return <UserChatMessageItem key={index} message={message} />;
}

if (message.type === 'ai') {
return <AiChatMessageItem key={index} message={message} />;
}
<Static items={olderMessages}>{renderMessage}</Static>

if (message.type === 'program') {
return <ProgramChatMessageItem key={index} output={message} />;
}

return null;
})}
{latestMessage ? renderMessage(latestMessage, messages.length - 1) : null}
</Box>
);
}

function renderMessage(message: ChatMessage, index: number): React.ReactNode {
if (message.type === 'user') {
return <UserChatMessageItem key={index} message={message} />;
}

if (message.type === 'ai') {
return <AiChatMessageItem key={index} message={message} />;
}

if (message.type === 'program') {
return <ProgramChatMessageItem key={index} output={message} />;
}

return null;
}

0 comments on commit b8a856f

Please sign in to comment.