mirror of
https://github.com/google-gemini/gemini-cli.git
synced 2026-03-12 15:10:59 -07:00
76 lines
2.2 KiB
TypeScript
76 lines
2.2 KiB
TypeScript
/**
|
|
* @license
|
|
* Copyright 2025 Google LLC
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
import { useEffect, useState } from 'react';
|
|
import { Box, Text } from 'ink';
|
|
import {
|
|
CoreEvent,
|
|
coreEvents,
|
|
type McpClient,
|
|
MCPServerStatus,
|
|
} from '@google/gemini-cli-core';
|
|
import { GeminiSpinner } from './GeminiRespondingSpinner.js';
|
|
import { theme } from '../semantic-colors.js';
|
|
|
|
export const ConfigInitDisplay = ({
|
|
message: initialMessage = 'Initializing...',
|
|
}: {
|
|
message?: string;
|
|
}) => {
|
|
const [message, setMessage] = useState(initialMessage);
|
|
|
|
useEffect(() => {
|
|
const onChange = (clients?: Map<string, McpClient>) => {
|
|
if (!clients || clients.size === 0) {
|
|
setMessage(initialMessage);
|
|
return;
|
|
}
|
|
let connected = 0;
|
|
const connecting: string[] = [];
|
|
for (const [name, client] of clients.entries()) {
|
|
if (client.getStatus() === MCPServerStatus.CONNECTED) {
|
|
connected++;
|
|
} else {
|
|
connecting.push(name);
|
|
}
|
|
}
|
|
|
|
if (connecting.length > 0) {
|
|
const maxDisplay = 3;
|
|
const displayedServers = connecting.slice(0, maxDisplay).join(', ');
|
|
const remaining = connecting.length - maxDisplay;
|
|
const suffix = remaining > 0 ? `, +${remaining} more` : '';
|
|
const mcpMessage = `Connecting to MCP servers... (${connected}/${clients.size}) - Waiting for: ${displayedServers}${suffix}`;
|
|
setMessage(
|
|
initialMessage && initialMessage !== 'Initializing...'
|
|
? `${initialMessage} (${mcpMessage})`
|
|
: mcpMessage,
|
|
);
|
|
} else {
|
|
const mcpMessage = `Connecting to MCP servers... (${connected}/${clients.size})`;
|
|
setMessage(
|
|
initialMessage && initialMessage !== 'Initializing...'
|
|
? `${initialMessage} (${mcpMessage})`
|
|
: mcpMessage,
|
|
);
|
|
}
|
|
};
|
|
|
|
coreEvents.on(CoreEvent.McpClientUpdate, onChange);
|
|
return () => {
|
|
coreEvents.off(CoreEvent.McpClientUpdate, onChange);
|
|
};
|
|
}, [initialMessage]);
|
|
|
|
return (
|
|
<Box marginTop={1}>
|
|
<Text>
|
|
<GeminiSpinner /> <Text color={theme.text.primary}>{message}</Text>
|
|
</Text>
|
|
</Box>
|
|
);
|
|
};
|