/** * @license * Copyright 2025 Google LLC * SPDX-License-Identifier: Apache-2.0 */ import { useEffect, useState } from 'react'; import { appEvents } from './../../utils/events.js'; import { Box, Text } from 'ink'; import { useConfig } from '../contexts/ConfigContext.js'; import { type McpClient, MCPServerStatus } from '@qwen-code/qwen-code-core'; import { GeminiSpinner } from './GeminiRespondingSpinner.js'; import { theme } from '../semantic-colors.js'; import { t } from '../../i18n/index.js'; export const ConfigInitDisplay = () => { const config = useConfig(); const [message, setMessage] = useState(t('Initializing...')); useEffect(() => { const onChange = (clients?: Map) => { if (!clients || clients.size === 0) { setMessage(t('Initializing...')); return; } let connected = 0; for (const client of clients.values()) { if (client.getStatus() === MCPServerStatus.CONNECTED) { connected++; } } setMessage( t('Connecting to MCP servers... ({{connected}}/{{total}})', { connected: String(connected), total: String(clients.size), }), ); }; appEvents.on('mcp-client-update', onChange); return () => { appEvents.off('mcp-client-update', onChange); }; }, [config]); return ( {message} ); };