π File detail
components/PromptInput/PromptInputFooter.tsx
π§© .tsxπ 191 linesπΎ 33,176 bytesπ text
β Back to All Filesπ― Use case
This file lives under βcomponents/β, which covers shared React UI pieces. It primarily provides a default export (component, class, or entry function). Dependencies touch bun:bundle and React UI. It composes internal code from bridge, context, hooks, ink, and services (relative imports).
Generated from folder role, exports, dependency roots, and inline comments β not hand-reviewed for every path.
π§ Inline summary
import { feature } from 'bun:bundle'; import * as React from 'react'; import { memo, type ReactNode, useMemo, useRef } from 'react'; import { isBridgeEnabled } from '../../bridge/bridgeEnabled.js'; import { getBridgeStatus } from '../../bridge/bridgeStatusUtil.js';
π€ Exports (heuristic)
default
π External import roots
Package roots from from "β¦" (relative paths omitted).
bun:bundlereact
π₯οΈ Source preview
import { feature } from 'bun:bundle';
import * as React from 'react';
import { memo, type ReactNode, useMemo, useRef } from 'react';
import { isBridgeEnabled } from '../../bridge/bridgeEnabled.js';
import { getBridgeStatus } from '../../bridge/bridgeStatusUtil.js';
import { useSetPromptOverlay } from '../../context/promptOverlayContext.js';
import type { VerificationStatus } from '../../hooks/useApiKeyVerification.js';
import type { IDESelection } from '../../hooks/useIdeSelection.js';
import { useSettings } from '../../hooks/useSettings.js';
import { useTerminalSize } from '../../hooks/useTerminalSize.js';
import { Box, Text } from '../../ink.js';
import type { MCPServerConnection } from '../../services/mcp/types.js';
import { useAppState } from '../../state/AppState.js';
import type { ToolPermissionContext } from '../../Tool.js';
import type { Message } from '../../types/message.js';
import type { PromptInputMode, VimMode } from '../../types/textInputTypes.js';
import type { AutoUpdaterResult } from '../../utils/autoUpdater.js';
import { isFullscreenEnvEnabled } from '../../utils/fullscreen.js';
import { isUndercover } from '../../utils/undercover.js';
import { CoordinatorTaskPanel, useCoordinatorTaskCount } from '../CoordinatorAgentStatus.js';
import { getLastAssistantMessageId, StatusLine, statusLineShouldDisplay } from '../StatusLine.js';
import { Notifications } from './Notifications.js';
import { PromptInputFooterLeftSide } from './PromptInputFooterLeftSide.js';
import { PromptInputFooterSuggestions, type SuggestionItem } from './PromptInputFooterSuggestions.js';
import { PromptInputHelpMenu } from './PromptInputHelpMenu.js';
type Props = {
apiKeyStatus: VerificationStatus;
debug: boolean;
exitMessage: {
show: boolean;
key?: string;
};
vimMode: VimMode | undefined;
mode: PromptInputMode;
autoUpdaterResult: AutoUpdaterResult | null;
isAutoUpdating: boolean;
verbose: boolean;
onAutoUpdaterResult: (result: AutoUpdaterResult) => void;
onChangeIsUpdating: (isUpdating: boolean) => void;
suggestions: SuggestionItem[];
selectedSuggestion: number;
maxColumnWidth?: number;
toolPermissionContext: ToolPermissionContext;
helpOpen: boolean;
suppressHint: boolean;
isLoading: boolean;
tasksSelected: boolean;
teamsSelected: boolean;
bridgeSelected: boolean;
tmuxSelected: boolean;
teammateFooterIndex?: number;
ideSelection: IDESelection | undefined;
mcpClients?: MCPServerConnection[];
isPasting?: boolean;
isInputWrapped?: boolean;
messages: Message[];
isSearching: boolean;
historyQuery: string;
setHistoryQuery: (query: string) => void;
historyFailedMatch: boolean;
onOpenTasksDialog?: (taskId?: string) => void;
};
function PromptInputFooter({
apiKeyStatus,
debug,
exitMessage,
vimMode,
mode,
autoUpdaterResult,
isAutoUpdating,
verbose,
onAutoUpdaterResult,
onChangeIsUpdating,
suggestions,
selectedSuggestion,
maxColumnWidth,
toolPermissionContext,
helpOpen,
suppressHint: suppressHintFromProps,
isLoading,
tasksSelected,
teamsSelected,
bridgeSelected,
tmuxSelected,
teammateFooterIndex,
ideSelection,
mcpClients,
isPasting = false,
isInputWrapped = false,
messages,
isSearching,
historyQuery,
setHistoryQuery,
historyFailedMatch,
onOpenTasksDialog
}: Props): ReactNode {
const settings = useSettings();
const {
columns,
rows
} = useTerminalSize();
const messagesRef = useRef(messages);
messagesRef.current = messages;
const lastAssistantMessageId = useMemo(() => getLastAssistantMessageId(messages), [messages]);
const isNarrow = columns < 80;
// In fullscreen the bottom slot is flexShrink:0, so every row here is a row
// stolen from the ScrollBox. Drop the optional StatusLine first. Non-fullscreen
// has terminal scrollback to absorb overflow, so we never hide StatusLine there.
const isFullscreen = isFullscreenEnvEnabled();
const isShort = isFullscreen && rows < 24;
// Pill highlights when tasks is the active footer item AND no specific
// agent row is selected. When coordinatorTaskIndex >= 0 the pointer has
// moved into CoordinatorTaskPanel, so the pill should un-highlight.
// coordinatorTaskCount === 0 covers the bash-only case (no agent rows
// exist, pill is the only selectable item).
const coordinatorTaskCount = useCoordinatorTaskCount();
const coordinatorTaskIndex = useAppState(s => s.coordinatorTaskIndex);
const pillSelected = tasksSelected && (coordinatorTaskCount === 0 || coordinatorTaskIndex < 0);
// Hide `? for shortcuts` if the user has a custom status line, or during ctrl-r
const suppressHint = suppressHintFromProps || statusLineShouldDisplay(settings) || isSearching;
// Fullscreen: portal data to FullscreenLayout β see promptOverlayContext.tsx
const overlayData = useMemo(() => isFullscreen && suggestions.length ? {
suggestions,
selectedSuggestion,
maxColumnWidth
} : null, [isFullscreen, suggestions, selectedSuggestion, maxColumnWidth]);
useSetPromptOverlay(overlayData);
if (suggestions.length && !isFullscreen) {
return <Box paddingX={2} paddingY={0}>
<PromptInputFooterSuggestions suggestions={suggestions} selectedSuggestion={selectedSuggestion} maxColumnWidth={maxColumnWidth} />
</Box>;
}
if (helpOpen) {
return <PromptInputHelpMenu dimColor={true} fixedWidth={true} paddingX={2} />;
}
return <>
<Box flexDirection={isNarrow ? 'column' : 'row'} justifyContent={isNarrow ? 'flex-start' : 'space-between'} paddingX={2} gap={isNarrow ? 0 : 1}>
<Box flexDirection="column" flexShrink={isNarrow ? 0 : 1}>
{mode === 'prompt' && !isShort && !exitMessage.show && !isPasting && statusLineShouldDisplay(settings) && <StatusLine messagesRef={messagesRef} lastAssistantMessageId={lastAssistantMessageId} vimMode={vimMode} />}
<PromptInputFooterLeftSide exitMessage={exitMessage} vimMode={vimMode} mode={mode} toolPermissionContext={toolPermissionContext} suppressHint={suppressHint} isLoading={isLoading} tasksSelected={pillSelected} teamsSelected={teamsSelected} teammateFooterIndex={teammateFooterIndex} tmuxSelected={tmuxSelected} isPasting={isPasting} isSearching={isSearching} historyQuery={historyQuery} setHistoryQuery={setHistoryQuery} historyFailedMatch={historyFailedMatch} onOpenTasksDialog={onOpenTasksDialog} />
</Box>
<Box flexShrink={1} gap={1}>
{isFullscreen ? null : <Notifications apiKeyStatus={apiKeyStatus} autoUpdaterResult={autoUpdaterResult} debug={debug} isAutoUpdating={isAutoUpdating} verbose={verbose} messages={messages} onAutoUpdaterResult={onAutoUpdaterResult} onChangeIsUpdating={onChangeIsUpdating} ideSelection={ideSelection} mcpClients={mcpClients} isInputWrapped={isInputWrapped} isNarrow={isNarrow} />}
{"external" === 'ant' && isUndercover() && <Text dimColor>undercover</Text>}
<BridgeStatusIndicator bridgeSelected={bridgeSelected} />
</Box>
</Box>
{"external" === 'ant' && <CoordinatorTaskPanel />}
</>;
}
export default memo(PromptInputFooter);
type BridgeStatusProps = {
bridgeSelected: boolean;
};
function BridgeStatusIndicator({
bridgeSelected
}: BridgeStatusProps): React.ReactNode {
if (!feature('BRIDGE_MODE')) return null;
// biome-ignore lint/correctness/useHookAtTopLevel: feature() is a compile-time constant
const enabled = useAppState(s => s.replBridgeEnabled);
// biome-ignore lint/correctness/useHookAtTopLevel: feature() is a compile-time constant
const connected = useAppState(s_0 => s_0.replBridgeConnected);
// biome-ignore lint/correctness/useHookAtTopLevel: feature() is a compile-time constant
const sessionActive = useAppState(s_1 => s_1.replBridgeSessionActive);
// biome-ignore lint/correctness/useHookAtTopLevel: feature() is a compile-time constant
const reconnecting = useAppState(s_2 => s_2.replBridgeReconnecting);
// biome-ignore lint/correctness/useHookAtTopLevel: feature() is a compile-time constant
const explicit = useAppState(s_3 => s_3.replBridgeExplicit);
// Failed state is surfaced via notification (useReplBridge), not a footer pill.
if (!isBridgeEnabled() || !enabled) return null;
const status = getBridgeStatus({
error: undefined,
connected,
sessionActive,
reconnecting
});
// For implicit (config-driven) remote, only show the reconnecting state
if (!explicit && status.label !== 'Remote Control reconnecting') {
return null;
}
return <Text color={bridgeSelected ? 'background' : status.color} inverse={bridgeSelected} wrap="truncate">
{status.label}
{bridgeSelected && <Text dimColor> Β· Enter to view</Text>}
</Text>;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["feature","React","memo","ReactNode","useMemo","useRef","isBridgeEnabled","getBridgeStatus","useSetPromptOverlay","VerificationStatus","IDESelection","useSettings","useTerminalSize","Box","Text","MCPServerConnection","useAppState","ToolPermissionContext","Message","PromptInputMode","VimMode","AutoUpdaterResult","isFullscreenEnvEnabled","isUndercover","CoordinatorTaskPanel","useCoordinatorTaskCount","getLastAssistantMessageId","StatusLine","statusLineShouldDisplay","Notifications","PromptInputFooterLeftSide","PromptInputFooterSuggestions","SuggestionItem","PromptInputHelpMenu","Props","apiKeyStatus","debug","exitMessage","show","key","vimMode","mode","autoUpdaterResult","isAutoUpdating","verbose","onAutoUpdaterResult","result","onChangeIsUpdating","isUpdating","suggestions","selectedSuggestion","maxColumnWidth","toolPermissionContext","helpOpen","suppressHint","isLoading","tasksSelected","teamsSelected","bridgeSelected","tmuxSelected","teammateFooterIndex","ideSelection","mcpClients","isPasting","isInputWrapped","messages","isSearching","historyQuery","setHistoryQuery","query","historyFailedMatch","onOpenTasksDialog","taskId","PromptInputFooter","suppressHintFromProps","settings","columns","rows","messagesRef","current","lastAssistantMessageId","isNarrow","isFullscreen","isShort","coordinatorTaskCount","coordinatorTaskIndex","s","pillSelected","overlayData","length","BridgeStatusProps","BridgeStatusIndicator","enabled","replBridgeEnabled","connected","replBridgeConnected","sessionActive","replBridgeSessionActive","reconnecting","replBridgeReconnecting","explicit","replBridgeExplicit","status","error","undefined","label","color"],"sources":["PromptInputFooter.tsx"],"sourcesContent":["import { feature } from 'bun:bundle'\nimport * as React from 'react'\nimport { memo, type ReactNode, useMemo, useRef } from 'react'\nimport { isBridgeEnabled } from '../../bridge/bridgeEnabled.js'\nimport { getBridgeStatus } from '../../bridge/bridgeStatusUtil.js'\nimport { useSetPromptOverlay } from '../../context/promptOverlayContext.js'\nimport type { VerificationStatus } from '../../hooks/useApiKeyVerification.js'\nimport type { IDESelection } from '../../hooks/useIdeSelection.js'\nimport { useSettings } from '../../hooks/useSettings.js'\nimport { useTerminalSize } from '../../hooks/useTerminalSize.js'\nimport { Box, Text } from '../../ink.js'\nimport type { MCPServerConnection } from '../../services/mcp/types.js'\nimport { useAppState } from '../../state/AppState.js'\nimport type { ToolPermissionContext } from '../../Tool.js'\nimport type { Message } from '../../types/message.js'\nimport type { PromptInputMode, VimMode } from '../../types/textInputTypes.js'\nimport type { AutoUpdaterResult } from '../../utils/autoUpdater.js'\nimport { isFullscreenEnvEnabled } from '../../utils/fullscreen.js'\nimport { isUndercover } from '../../utils/undercover.js'\nimport {\n  CoordinatorTaskPanel,\n  useCoordinatorTaskCount,\n} from '../CoordinatorAgentStatus.js'\nimport {\n  getLastAssistantMessageId,\n  StatusLine,\n  statusLineShouldDisplay,\n} from '../StatusLine.js'\nimport { Notifications } from './Notifications.js'\nimport { PromptInputFooterLeftSide } from './PromptInputFooterLeftSide.js'\nimport {\n  PromptInputFooterSuggestions,\n  type SuggestionItem,\n} from './PromptInputFooterSuggestions.js'\nimport { PromptInputHelpMenu } from './PromptInputHelpMenu.js'\n\ntype Props = {\n  apiKeyStatus: VerificationStatus\n  debug: boolean\n  exitMessage: {\n    show: boolean\n    key?: string\n  }\n  vimMode: VimMode | undefined\n  mode: PromptInputMode\n  autoUpdaterResult: AutoUpdaterResult | null\n  isAutoUpdating: boolean\n  verbose: boolean\n  onAutoUpdaterResult: (result: AutoUpdaterResult) => void\n  onChangeIsUpdating: (isUpdating: boolean) => void\n  suggestions: SuggestionItem[]\n  selectedSuggestion: number\n  maxColumnWidth?: number\n  toolPermissionContext: ToolPermissionContext\n  helpOpen: boolean\n  suppressHint: boolean\n  isLoading: boolean\n  tasksSelected: boolean\n  teamsSelected: boolean\n  bridgeSelected: boolean\n  tmuxSelected: boolean\n  teammateFooterIndex?: number\n  ideSelection: IDESelection | undefined\n  mcpClients?: MCPServerConnection[]\n  isPasting?: boolean\n  isInputWrapped?: boolean\n  messages: Message[]\n  isSearching: boolean\n  historyQuery: string\n  setHistoryQuery: (query: string) => void\n  historyFailedMatch: boolean\n  onOpenTasksDialog?: (taskId?: string) => void\n}\n\nfunction PromptInputFooter({\n  apiKeyStatus,\n  debug,\n  exitMessage,\n  vimMode,\n  mode,\n  autoUpdaterResult,\n  isAutoUpdating,\n  verbose,\n  onAutoUpdaterResult,\n  onChangeIsUpdating,\n  suggestions,\n  selectedSuggestion,\n  maxColumnWidth,\n  toolPermissionContext,\n  helpOpen,\n  suppressHint: suppressHintFromProps,\n  isLoading,\n  tasksSelected,\n  teamsSelected,\n  bridgeSelected,\n  tmuxSelected,\n  teammateFooterIndex,\n  ideSelection,\n  mcpClients,\n  isPasting = false,\n  isInputWrapped = false,\n  messages,\n  isSearching,\n  historyQuery,\n  setHistoryQuery,\n  historyFailedMatch,\n  onOpenTasksDialog,\n}: Props): ReactNode {\n  const settings = useSettings()\n  const { columns, rows } = useTerminalSize()\n  const messagesRef = useRef(messages)\n  messagesRef.current = messages\n  const lastAssistantMessageId = useMemo(\n    () => getLastAssistantMessageId(messages),\n    [messages],\n  )\n  const isNarrow = columns < 80\n  // In fullscreen the bottom slot is flexShrink:0, so every row here is a row\n  // stolen from the ScrollBox. Drop the optional StatusLine first. Non-fullscreen\n  // has terminal scrollback to absorb overflow, so we never hide StatusLine there.\n  const isFullscreen = isFullscreenEnvEnabled()\n  const isShort = isFullscreen && rows < 24\n\n  // Pill highlights when tasks is the active footer item AND no specific\n  // agent row is selected. When coordinatorTaskIndex >= 0 the pointer has\n  // moved into CoordinatorTaskPanel, so the pill should un-highlight.\n  // coordinatorTaskCount === 0 covers the bash-only case (no agent rows\n  // exist, pill is the only selectable item).\n  const coordinatorTaskCount = useCoordinatorTaskCount()\n  const coordinatorTaskIndex = useAppState(s => s.coordinatorTaskIndex)\n  const pillSelected =\n    tasksSelected && (coordinatorTaskCount === 0 || coordinatorTaskIndex < 0)\n\n  // Hide `? for shortcuts` if the user has a custom status line, or during ctrl-r\n  const suppressHint =\n    suppressHintFromProps || statusLineShouldDisplay(settings) || isSearching\n  // Fullscreen: portal data to FullscreenLayout — see promptOverlayContext.tsx\n  const overlayData = useMemo(\n    () =>\n      isFullscreen && suggestions.length\n        ? { suggestions, selectedSuggestion, maxColumnWidth }\n        : null,\n    [isFullscreen, suggestions, selectedSuggestion, maxColumnWidth],\n  )\n  useSetPromptOverlay(overlayData)\n\n  if (suggestions.length && !isFullscreen) {\n    return (\n      <Box paddingX={2} paddingY={0}>\n        <PromptInputFooterSuggestions\n          suggestions={suggestions}\n          selectedSuggestion={selectedSuggestion}\n          maxColumnWidth={maxColumnWidth}\n        />\n      </Box>\n    )\n  }\n\n  if (helpOpen) {\n    return (\n      <PromptInputHelpMenu dimColor={true} fixedWidth={true} paddingX={2} />\n    )\n  }\n\n  return (\n    <>\n      <Box\n        flexDirection={isNarrow ? 'column' : 'row'}\n        justifyContent={isNarrow ? 'flex-start' : 'space-between'}\n        paddingX={2}\n        gap={isNarrow ? 0 : 1}\n      >\n        <Box flexDirection=\"column\" flexShrink={isNarrow ? 0 : 1}>\n          {mode === 'prompt' &&\n            !isShort &&\n            !exitMessage.show &&\n            !isPasting &&\n            statusLineShouldDisplay(settings) && (\n              <StatusLine\n                messagesRef={messagesRef}\n                lastAssistantMessageId={lastAssistantMessageId}\n                vimMode={vimMode}\n              />\n            )}\n          <PromptInputFooterLeftSide\n            exitMessage={exitMessage}\n            vimMode={vimMode}\n            mode={mode}\n            toolPermissionContext={toolPermissionContext}\n            suppressHint={suppressHint}\n            isLoading={isLoading}\n            tasksSelected={pillSelected}\n            teamsSelected={teamsSelected}\n            teammateFooterIndex={teammateFooterIndex}\n            tmuxSelected={tmuxSelected}\n            isPasting={isPasting}\n            isSearching={isSearching}\n            historyQuery={historyQuery}\n            setHistoryQuery={setHistoryQuery}\n            historyFailedMatch={historyFailedMatch}\n            onOpenTasksDialog={onOpenTasksDialog}\n          />\n        </Box>\n        <Box flexShrink={1} gap={1}>\n          {isFullscreen ? null : (\n            <Notifications\n              apiKeyStatus={apiKeyStatus}\n              autoUpdaterResult={autoUpdaterResult}\n              debug={debug}\n              isAutoUpdating={isAutoUpdating}\n              verbose={verbose}\n              messages={messages}\n              onAutoUpdaterResult={onAutoUpdaterResult}\n              onChangeIsUpdating={onChangeIsUpdating}\n              ideSelection={ideSelection}\n              mcpClients={mcpClients}\n              isInputWrapped={isInputWrapped}\n              isNarrow={isNarrow}\n            />\n          )}\n          {\"external\" === 'ant' && isUndercover() && (\n            <Text dimColor>undercover</Text>\n          )}\n          <BridgeStatusIndicator bridgeSelected={bridgeSelected} />\n        </Box>\n      </Box>\n      {\"external\" === 'ant' && <CoordinatorTaskPanel />}\n    </>\n  )\n}\n\nexport default memo(PromptInputFooter)\n\ntype BridgeStatusProps = {\n  bridgeSelected: boolean\n}\n\nfunction BridgeStatusIndicator({\n  bridgeSelected,\n}: BridgeStatusProps): React.ReactNode {\n  if (!feature('BRIDGE_MODE')) return null\n\n  // biome-ignore lint/correctness/useHookAtTopLevel: feature() is a compile-time constant\n  const enabled = useAppState(s => s.replBridgeEnabled)\n  // biome-ignore lint/correctness/useHookAtTopLevel: feature() is a compile-time constant\n  const connected = useAppState(s => s.replBridgeConnected)\n  // biome-ignore lint/correctness/useHookAtTopLevel: feature() is a compile-time constant\n  const sessionActive = useAppState(s => s.replBridgeSessionActive)\n  // biome-ignore lint/correctness/useHookAtTopLevel: feature() is a compile-time constant\n  const reconnecting = useAppState(s => s.replBridgeReconnecting)\n  // biome-ignore lint/correctness/useHookAtTopLevel: feature() is a compile-time constant\n  const explicit = useAppState(s => s.replBridgeExplicit)\n\n  // Failed state is surfaced via notification (useReplBridge), not a footer pill.\n  if (!isBridgeEnabled() || !enabled) return null\n\n  const status = getBridgeStatus({\n    error: undefined,\n    connected,\n    sessionActive,\n    reconnecting,\n  })\n\n  // For implicit (config-driven) remote, only show the reconnecting state\n  if (!explicit && status.label !== 'Remote Control reconnecting') {\n    return null\n  }\n\n  return (\n    <Text\n      color={bridgeSelected ? 'background' : status.color}\n      inverse={bridgeSelected}\n      wrap=\"truncate\"\n    >\n      {status.label}\n      {bridgeSelected && <Text dimColor> · Enter to view</Text>}\n    </Text>\n  )\n}\n"],"mappings":"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","ignoreList":[]}