Files
gemini-cli/packages/cli/src/ui/components/HistoryDisplay.tsx
T

43 lines
1.4 KiB
TypeScript
Raw Normal View History

2025-04-15 21:41:08 -07:00
import React from 'react';
import { Box } from 'ink';
import type { HistoryItem } from '../types.js';
import { UI_WIDTH } from '../constants.js';
import UserMessage from './messages/UserMessage.js';
import GeminiMessage from './messages/GeminiMessage.js';
import InfoMessage from './messages/InfoMessage.js';
import ErrorMessage from './messages/ErrorMessage.js';
import ToolGroupMessage from './messages/ToolGroupMessage.js';
import { PartListUnion } from '@google/genai';
interface HistoryDisplayProps {
2025-04-17 18:06:21 -04:00
history: HistoryItem[];
onSubmit: (value: PartListUnion) => void;
2025-04-15 21:41:08 -07:00
}
2025-04-17 18:06:21 -04:00
const HistoryDisplay: React.FC<HistoryDisplayProps> = ({
history,
onSubmit,
2025-04-18 10:53:16 -04:00
}) =>
2025-04-17 18:06:21 -04:00
// No grouping logic needed here anymore
2025-04-18 10:53:16 -04:00
(
2025-04-17 18:06:21 -04:00
<Box flexDirection="column">
{history.map((item) => (
<Box key={item.id} marginBottom={1}>
{/* Render standard message types */}
{item.type === 'user' && <UserMessage text={item.text} />}
{item.type === 'gemini' && <GeminiMessage text={item.text} />}
{item.type === 'info' && <InfoMessage text={item.text} />}
{item.type === 'error' && <ErrorMessage text={item.text} />}
2025-04-15 21:41:08 -07:00
2025-04-17 18:06:21 -04:00
{/* Render the tool group component */}
{item.type === 'tool_group' && (
<ToolGroupMessage toolCalls={item.tools} onSubmit={onSubmit} />
)}
2025-04-15 21:41:08 -07:00
</Box>
2025-04-17 18:06:21 -04:00
))}
</Box>
2025-04-18 10:53:16 -04:00
)
;
2025-04-15 21:41:08 -07:00
2025-04-17 18:06:21 -04:00
export default HistoryDisplay;