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

79 lines
2.3 KiB
TypeScript
Raw Normal View History

/**
* @license
* Copyright 2025 Google LLC
* SPDX-License-Identifier: Apache-2.0
*/
2025-04-15 21:41:08 -07:00
import React from 'react';
import { Box, Text } from 'ink';
import Spinner from 'ink-spinner';
import { ToolCallStatus } from '../../types.js';
2025-04-17 17:25:01 -04:00
import { ToolResultDisplay } from '../../../tools/tools.js';
2025-04-18 19:09:41 -04:00
import { DiffRenderer } from './DiffRenderer.js';
2025-04-15 21:41:08 -07:00
import { MarkdownRenderer } from '../../utils/MarkdownRenderer.js';
interface ToolMessageProps {
2025-04-17 18:06:21 -04:00
name: string;
description: string;
resultDisplay: ToolResultDisplay | undefined;
status: ToolCallStatus;
2025-04-15 21:41:08 -07:00
}
2025-04-18 19:09:41 -04:00
export const ToolMessage: React.FC<ToolMessageProps> = ({
2025-04-17 18:06:21 -04:00
name,
description,
resultDisplay,
status,
}) => {
const statusIndicatorWidth = 3;
const hasResult =
(status === ToolCallStatus.Invoked || status === ToolCallStatus.Canceled) &&
resultDisplay &&
resultDisplay.toString().trim().length > 0;
2025-04-15 21:41:08 -07:00
2025-04-17 18:06:21 -04:00
return (
<Box paddingX={1} paddingY={0} flexDirection="column">
{/* Row for Status Indicator and Tool Info */}
<Box minHeight={1}>
{/* Status Indicator */}
<Box minWidth={statusIndicatorWidth}>
{status === ToolCallStatus.Pending && <Spinner type="dots" />}
{status === ToolCallStatus.Invoked && <Text color="green"></Text>}
{status === ToolCallStatus.Confirming && <Text color="blue">?</Text>}
{status === ToolCallStatus.Canceled && (
<Text color="red" bold>
-
</Text>
)}
</Box>
<Box>
<Text
color="blue"
wrap="truncate-end"
strikethrough={status === ToolCallStatus.Canceled}
>
<Text bold>{name}</Text> <Text color="gray">{description}</Text>
</Text>
</Box>
</Box>
2025-04-15 21:41:08 -07:00
2025-04-17 18:06:21 -04:00
{hasResult && (
<Box paddingLeft={statusIndicatorWidth}>
<Box flexShrink={1} flexDirection="row">
<Text color="gray"> </Text>
{/* Use default text color (white) or gray instead of dimColor */}
{typeof resultDisplay === 'string' && (
<Box flexDirection="column">
{MarkdownRenderer.render(resultDisplay)}
</Box>
)}
{typeof resultDisplay === 'object' && (
<DiffRenderer diffContent={resultDisplay.fileDiff} />
2025-04-15 21:41:08 -07:00
)}
2025-04-17 18:06:21 -04:00
</Box>
2025-04-15 21:41:08 -07:00
</Box>
2025-04-17 18:06:21 -04:00
)}
</Box>
);
2025-04-15 21:41:08 -07:00
};