import { basename } from 'path'
import * as React from 'react'
import { useIdeConnectionStatus } from '../hooks/useIdeConnectionStatus.js'
import type { IDESelection } from '../hooks/useIdeSelection.js'
import { Text } from '../ink.js'
import type { MCPServerConnection } from '../services/mcp/types.js'
type IdeStatusIndicatorProps = {
ideSelection: IDESelection | undefined
mcpClients?: MCPServerConnection[]
}
export function IdeStatusIndicator({
ideSelection,
mcpClients,
}: IdeStatusIndicatorProps): React.ReactNode {
const { status: ideStatus } = useIdeConnectionStatus(mcpClients)
// Check if we should show the IDE selection indicator
const shouldShowIdeSelection =
ideStatus === 'connected' &&
(ideSelection?.filePath ||
(ideSelection?.text && ideSelection.lineCount > 0))
if (ideStatus === null || !shouldShowIdeSelection || !ideSelection) {
return null
}
if (ideSelection.text && ideSelection.lineCount > 0) {
return (
⧉ {ideSelection.lineCount}{' '}
{ideSelection.lineCount === 1 ? 'line' : 'lines'} selected
)
}
if (ideSelection.filePath) {
return (
⧉ In {basename(ideSelection.filePath)}
)
}
}