πŸ“„ File detail

components/PromptInput/PromptInputModeIndicator.tsx

🧩 .tsxπŸ“ 93 linesπŸ’Ύ 11,127 bytesπŸ“ text
← Back to All Files

🎯 Use case

This file lives under β€œcomponents/”, which covers shared React UI pieces. On the API surface it exposes PromptInputModeIndicator β€” mainly types, interfaces, or factory objects. Dependencies touch React UI, figures, and src. It composes internal code from utils (relative imports).

Generated from folder role, exports, dependency roots, and inline comments β€” not hand-reviewed for every path.

🧠 Inline summary

import { c as _c } from "react/compiler-runtime"; import figures from 'figures'; import * as React from 'react'; import { Box, Text } from 'src/ink.js'; import { AGENT_COLOR_TO_THEME_COLOR, AGENT_COLORS, type AgentColorName } from 'src/tools/AgentTool/agentColorManager.js';

πŸ“€ Exports (heuristic)

  • PromptInputModeIndicator

πŸ“š External import roots

Package roots from from "…" (relative paths omitted).

  • react
  • figures
  • src

πŸ–₯️ Source preview

import { c as _c } from "react/compiler-runtime";
import figures from 'figures';
import * as React from 'react';
import { Box, Text } from 'src/ink.js';
import { AGENT_COLOR_TO_THEME_COLOR, AGENT_COLORS, type AgentColorName } from 'src/tools/AgentTool/agentColorManager.js';
import type { PromptInputMode } from 'src/types/textInputTypes.js';
import { getTeammateColor } from 'src/utils/teammate.js';
import type { Theme } from 'src/utils/theme.js';
import { isAgentSwarmsEnabled } from '../../utils/agentSwarmsEnabled.js';
type Props = {
  mode: PromptInputMode;
  isLoading: boolean;
  viewingAgentName?: string;
  viewingAgentColor?: AgentColorName;
};

/**
 * Gets the theme color key for the teammate's assigned color.
 * Returns undefined if not a teammate or if the color is invalid.
 */
function getTeammateThemeColor(): keyof Theme | undefined {
  if (!isAgentSwarmsEnabled()) {
    return undefined;
  }
  const colorName = getTeammateColor();
  if (!colorName) {
    return undefined;
  }
  if (AGENT_COLORS.includes(colorName as AgentColorName)) {
    return AGENT_COLOR_TO_THEME_COLOR[colorName as AgentColorName];
  }
  return undefined;
}
type PromptCharProps = {
  isLoading: boolean;
  // Dead code elimination: parameter named themeColor to avoid "teammate" string in external builds
  themeColor?: keyof Theme;
};

/**
 * Renders the prompt character (❯).
 * Teammate color overrides the default color when set.
 */
function PromptChar(t0) {
  const $ = _c(3);
  const {
    isLoading,
    themeColor
  } = t0;
  const teammateColor = themeColor;
  const color = teammateColor ?? (false ? "subtle" : undefined);
  let t1;
  if ($[0] !== color || $[1] !== isLoading) {
    t1 = <Text color={color} dimColor={isLoading}>{figures.pointer}Β </Text>;
    $[0] = color;
    $[1] = isLoading;
    $[2] = t1;
  } else {
    t1 = $[2];
  }
  return t1;
}
export function PromptInputModeIndicator(t0) {
  const $ = _c(6);
  const {
    mode,
    isLoading,
    viewingAgentName,
    viewingAgentColor
  } = t0;
  let t1;
  if ($[0] === Symbol.for("react.memo_cache_sentinel")) {
    t1 = getTeammateThemeColor();
    $[0] = t1;
  } else {
    t1 = $[0];
  }
  const teammateColor = t1;
  const viewedTeammateThemeColor = viewingAgentColor ? AGENT_COLOR_TO_THEME_COLOR[viewingAgentColor] : undefined;
  let t2;
  if ($[1] !== isLoading || $[2] !== mode || $[3] !== viewedTeammateThemeColor || $[4] !== viewingAgentName) {
    t2 = <Box alignItems="flex-start" alignSelf="flex-start" flexWrap="nowrap" justifyContent="flex-start">{viewingAgentName ? <PromptChar isLoading={isLoading} themeColor={viewedTeammateThemeColor} /> : mode === "bash" ? <Text color="bashBorder" dimColor={isLoading}>!Β </Text> : <PromptChar isLoading={isLoading} themeColor={isAgentSwarmsEnabled() ? teammateColor : undefined} />}</Box>;
    $[1] = isLoading;
    $[2] = mode;
    $[3] = viewedTeammateThemeColor;
    $[4] = viewingAgentName;
    $[5] = t2;
  } else {
    t2 = $[5];
  }
  return t2;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["figures","React","Box","Text","AGENT_COLOR_TO_THEME_COLOR","AGENT_COLORS","AgentColorName","PromptInputMode","getTeammateColor","Theme","isAgentSwarmsEnabled","Props","mode","isLoading","viewingAgentName","viewingAgentColor","getTeammateThemeColor","undefined","colorName","includes","PromptCharProps","themeColor","PromptChar","t0","$","_c","teammateColor","color","t1","pointer","PromptInputModeIndicator","Symbol","for","viewedTeammateThemeColor","t2"],"sources":["PromptInputModeIndicator.tsx"],"sourcesContent":["import figures from 'figures'\nimport * as React from 'react'\nimport { Box, Text } from 'src/ink.js'\nimport {\n  AGENT_COLOR_TO_THEME_COLOR,\n  AGENT_COLORS,\n  type AgentColorName,\n} from 'src/tools/AgentTool/agentColorManager.js'\nimport type { PromptInputMode } from 'src/types/textInputTypes.js'\nimport { getTeammateColor } from 'src/utils/teammate.js'\nimport type { Theme } from 'src/utils/theme.js'\nimport { isAgentSwarmsEnabled } from '../../utils/agentSwarmsEnabled.js'\n\ntype Props = {\n  mode: PromptInputMode\n  isLoading: boolean\n  viewingAgentName?: string\n  viewingAgentColor?: AgentColorName\n}\n\n/**\n * Gets the theme color key for the teammate's assigned color.\n * Returns undefined if not a teammate or if the color is invalid.\n */\nfunction getTeammateThemeColor(): keyof Theme | undefined {\n  if (!isAgentSwarmsEnabled()) {\n    return undefined\n  }\n  const colorName = getTeammateColor()\n  if (!colorName) {\n    return undefined\n  }\n  if (AGENT_COLORS.includes(colorName as AgentColorName)) {\n    return AGENT_COLOR_TO_THEME_COLOR[colorName as AgentColorName]\n  }\n  return undefined\n}\n\ntype PromptCharProps = {\n  isLoading: boolean\n  // Dead code elimination: parameter named themeColor to avoid \"teammate\" string in external builds\n  themeColor?: keyof Theme\n}\n\n/**\n * Renders the prompt character (❯).\n * Teammate color overrides the default color when set.\n */\nfunction PromptChar({\n  isLoading,\n  themeColor,\n}: PromptCharProps): React.ReactNode {\n  // Assign to original name for clarity within the function\n  const teammateColor = themeColor\n  const isAnt = \"external\" === 'ant'\n  const color = teammateColor ?? (isAnt ? 'subtle' : undefined)\n\n  return (\n    <Text color={color} dimColor={isLoading}>\n      {figures.pointer}&nbsp;\n    </Text>\n  )\n}\n\nexport function PromptInputModeIndicator({\n  mode,\n  isLoading,\n  viewingAgentName,\n  viewingAgentColor,\n}: Props): React.ReactNode {\n  const teammateColor = getTeammateThemeColor()\n\n  // Convert viewed teammate's color to theme color\n  // Falls back to PromptChar's default (subtle for ants, undefined for external)\n  const viewedTeammateThemeColor = viewingAgentColor\n    ? AGENT_COLOR_TO_THEME_COLOR[viewingAgentColor]\n    : undefined\n\n  return (\n    <Box\n      alignItems=\"flex-start\"\n      alignSelf=\"flex-start\"\n      flexWrap=\"nowrap\"\n      justifyContent=\"flex-start\"\n    >\n      {viewingAgentName ? (\n        // Use teammate's color on the standard prompt character, matching established style\n        <PromptChar\n          isLoading={isLoading}\n          themeColor={viewedTeammateThemeColor}\n        />\n      ) : mode === 'bash' ? (\n        <Text color=\"bashBorder\" dimColor={isLoading}>\n          !&nbsp;\n        </Text>\n      ) : (\n        <PromptChar\n          isLoading={isLoading}\n          themeColor={isAgentSwarmsEnabled() ? teammateColor : undefined}\n        />\n      )}\n    </Box>\n  )\n}\n"],"mappings":"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","ignoreList":[]}