summaryrefslogtreecommitdiff
path: root/packages/cli/src/ui/components/HistoryDisplay.tsx
blob: fe0bf4c1735ff809947e5e905f6c0c86f7f0c1db (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
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 {
  history: HistoryItem[];
  onSubmit: (value: PartListUnion) => void;
}

const HistoryDisplay: React.FC<HistoryDisplayProps> = ({
  history,
  onSubmit,
}) => 
  // No grouping logic needed here anymore
   (
    <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} />}

          {/* Render the tool group component */}
          {item.type === 'tool_group' && (
            <ToolGroupMessage toolCalls={item.tools} onSubmit={onSubmit} />
          )}
        </Box>
      ))}
    </Box>
  )
;

export default HistoryDisplay;