source dump of claude code
at main 185 lines 25 kB view raw
1import { c as _c } from "react/compiler-runtime"; 2import type { ToolResultBlockParam } from '@anthropic-ai/sdk/resources/index.mjs'; 3import * as React from 'react'; 4import { KeyboardShortcutHint } from '../../components/design-system/KeyboardShortcutHint.js'; 5import { FallbackToolUseErrorMessage } from '../../components/FallbackToolUseErrorMessage.js'; 6import { MessageResponse } from '../../components/MessageResponse.js'; 7import { ShellProgressMessage } from '../../components/shell/ShellProgressMessage.js'; 8import { Box, Text } from '../../ink.js'; 9import { useKeybinding } from '../../keybindings/useKeybinding.js'; 10import { useShortcutDisplay } from '../../keybindings/useShortcutDisplay.js'; 11import { useAppStateStore, useSetAppState } from '../../state/AppState.js'; 12import type { Tool } from '../../Tool.js'; 13import { backgroundAll } from '../../tasks/LocalShellTask/LocalShellTask.js'; 14import type { ProgressMessage } from '../../types/message.js'; 15import { env } from '../../utils/env.js'; 16import { isEnvTruthy } from '../../utils/envUtils.js'; 17import { getDisplayPath } from '../../utils/file.js'; 18import { isFullscreenEnvEnabled } from '../../utils/fullscreen.js'; 19import type { ThemeName } from '../../utils/theme.js'; 20import type { BashProgress, BashToolInput, Out } from './BashTool.js'; 21import BashToolResultMessage from './BashToolResultMessage.js'; 22import { extractBashCommentLabel } from './commentLabel.js'; 23import { parseSedEditCommand } from './sedEditParser.js'; 24 25// Constants for command display 26const MAX_COMMAND_DISPLAY_LINES = 2; 27const MAX_COMMAND_DISPLAY_CHARS = 160; 28 29// Simple component to show background hint and handle ctrl+b 30// When ctrl+b is pressed, backgrounds ALL running foreground commands 31export function BackgroundHint(t0) { 32 const $ = _c(9); 33 let t1; 34 if ($[0] !== t0) { 35 t1 = t0 === undefined ? {} : t0; 36 $[0] = t0; 37 $[1] = t1; 38 } else { 39 t1 = $[1]; 40 } 41 const { 42 onBackground 43 } = t1; 44 const store = useAppStateStore(); 45 const setAppState = useSetAppState(); 46 let t2; 47 if ($[2] !== onBackground || $[3] !== setAppState || $[4] !== store) { 48 t2 = () => { 49 backgroundAll(() => store.getState(), setAppState); 50 onBackground?.(); 51 }; 52 $[2] = onBackground; 53 $[3] = setAppState; 54 $[4] = store; 55 $[5] = t2; 56 } else { 57 t2 = $[5]; 58 } 59 const handleBackground = t2; 60 let t3; 61 if ($[6] === Symbol.for("react.memo_cache_sentinel")) { 62 t3 = { 63 context: "Task" 64 }; 65 $[6] = t3; 66 } else { 67 t3 = $[6]; 68 } 69 useKeybinding("task:background", handleBackground, t3); 70 const baseShortcut = useShortcutDisplay("task:background", "Task", "ctrl+b"); 71 const shortcut = env.terminal === "tmux" && baseShortcut === "ctrl+b" ? "ctrl+b ctrl+b (twice)" : baseShortcut; 72 if (isEnvTruthy(process.env.CLAUDE_CODE_DISABLE_BACKGROUND_TASKS)) { 73 return null; 74 } 75 let t4; 76 if ($[7] !== shortcut) { 77 t4 = <Box paddingLeft={5}><Text dimColor={true}><KeyboardShortcutHint shortcut={shortcut} action="run in background" parens={true} /></Text></Box>; 78 $[7] = shortcut; 79 $[8] = t4; 80 } else { 81 t4 = $[8]; 82 } 83 return t4; 84} 85export function renderToolUseMessage(input: Partial<BashToolInput>, { 86 verbose, 87 theme: _theme 88}: { 89 verbose: boolean; 90 theme: ThemeName; 91}): React.ReactNode { 92 const { 93 command 94 } = input; 95 if (!command) { 96 return null; 97 } 98 99 // Render sed in-place edits like file edits (show file path only) 100 const sedInfo = parseSedEditCommand(command); 101 if (sedInfo) { 102 return verbose ? sedInfo.filePath : getDisplayPath(sedInfo.filePath); 103 } 104 if (!verbose) { 105 const lines = command.split('\n'); 106 if (isFullscreenEnvEnabled()) { 107 const label = extractBashCommentLabel(command); 108 if (label) { 109 return label.length > MAX_COMMAND_DISPLAY_CHARS ? label.slice(0, MAX_COMMAND_DISPLAY_CHARS) + '…' : label; 110 } 111 } 112 const needsLineTruncation = lines.length > MAX_COMMAND_DISPLAY_LINES; 113 const needsCharTruncation = command.length > MAX_COMMAND_DISPLAY_CHARS; 114 if (needsLineTruncation || needsCharTruncation) { 115 let truncated = command; 116 117 // First truncate by lines if needed 118 if (needsLineTruncation) { 119 truncated = lines.slice(0, MAX_COMMAND_DISPLAY_LINES).join('\n'); 120 } 121 122 // Then truncate by chars if still too long 123 if (truncated.length > MAX_COMMAND_DISPLAY_CHARS) { 124 truncated = truncated.slice(0, MAX_COMMAND_DISPLAY_CHARS); 125 } 126 return <Text>{truncated.trim()}</Text>; 127 } 128 } 129 return command; 130} 131export function renderToolUseProgressMessage(progressMessagesForMessage: ProgressMessage<BashProgress>[], { 132 verbose, 133 tools: _tools, 134 terminalSize: _terminalSize, 135 inProgressToolCallCount: _inProgressToolCallCount 136}: { 137 tools: Tool[]; 138 verbose: boolean; 139 terminalSize?: { 140 columns: number; 141 rows: number; 142 }; 143 inProgressToolCallCount?: number; 144}): React.ReactNode { 145 const lastProgress = progressMessagesForMessage.at(-1); 146 if (!lastProgress || !lastProgress.data) { 147 return <MessageResponse height={1}> 148 <Text dimColor>Running</Text> 149 </MessageResponse>; 150 } 151 const data = lastProgress.data; 152 return <ShellProgressMessage fullOutput={data.fullOutput} output={data.output} elapsedTimeSeconds={data.elapsedTimeSeconds} totalLines={data.totalLines} totalBytes={data.totalBytes} timeoutMs={data.timeoutMs} taskId={data.taskId} verbose={verbose} />; 153} 154export function renderToolUseQueuedMessage(): React.ReactNode { 155 return <MessageResponse height={1}> 156 <Text dimColor>Waiting</Text> 157 </MessageResponse>; 158} 159export function renderToolResultMessage(content: Out, progressMessagesForMessage: ProgressMessage<BashProgress>[], { 160 verbose, 161 theme: _theme, 162 tools: _tools, 163 style: _style 164}: { 165 verbose: boolean; 166 theme: ThemeName; 167 tools: Tool[]; 168 style?: 'condensed'; 169}): React.ReactNode { 170 const lastProgress = progressMessagesForMessage.at(-1); 171 const timeoutMs = lastProgress?.data?.timeoutMs; 172 return <BashToolResultMessage content={content} verbose={verbose} timeoutMs={timeoutMs} />; 173} 174export function renderToolUseErrorMessage(result: ToolResultBlockParam['content'], { 175 verbose, 176 progressMessagesForMessage: _progressMessagesForMessage, 177 tools: _tools 178}: { 179 verbose: boolean; 180 progressMessagesForMessage: ProgressMessage<BashProgress>[]; 181 tools: Tool[]; 182}): React.ReactNode { 183 return <FallbackToolUseErrorMessage result={result} verbose={verbose} />; 184} 185//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["ToolResultBlockParam","React","KeyboardShortcutHint","FallbackToolUseErrorMessage","MessageResponse","ShellProgressMessage","Box","Text","useKeybinding","useShortcutDisplay","useAppStateStore","useSetAppState","Tool","backgroundAll","ProgressMessage","env","isEnvTruthy","getDisplayPath","isFullscreenEnvEnabled","ThemeName","BashProgress","BashToolInput","Out","BashToolResultMessage","extractBashCommentLabel","parseSedEditCommand","MAX_COMMAND_DISPLAY_LINES","MAX_COMMAND_DISPLAY_CHARS","BackgroundHint","t0","$","_c","t1","undefined","onBackground","store","setAppState","t2","getState","handleBackground","t3","Symbol","for","context","baseShortcut","shortcut","terminal","process","CLAUDE_CODE_DISABLE_BACKGROUND_TASKS","t4","renderToolUseMessage","input","Partial","verbose","theme","_theme","ReactNode","command","sedInfo","filePath","lines","split","label","length","slice","needsLineTruncation","needsCharTruncation","truncated","join","trim","renderToolUseProgressMessage","progressMessagesForMessage","tools","_tools","terminalSize","_terminalSize","inProgressToolCallCount","_inProgressToolCallCount","columns","rows","lastProgress","at","data","fullOutput","output","elapsedTimeSeconds","totalLines","totalBytes","timeoutMs","taskId","renderToolUseQueuedMessage","renderToolResultMessage","content","style","_style","renderToolUseErrorMessage","result","_progressMessagesForMessage"],"sources":["UI.tsx"],"sourcesContent":["import type { ToolResultBlockParam } from '@anthropic-ai/sdk/resources/index.mjs'\nimport * as React from 'react'\nimport { KeyboardShortcutHint } from '../../components/design-system/KeyboardShortcutHint.js'\nimport { FallbackToolUseErrorMessage } from '../../components/FallbackToolUseErrorMessage.js'\nimport { MessageResponse } from '../../components/MessageResponse.js'\nimport { ShellProgressMessage } from '../../components/shell/ShellProgressMessage.js'\nimport { Box, Text } from '../../ink.js'\nimport { useKeybinding } from '../../keybindings/useKeybinding.js'\nimport { useShortcutDisplay } from '../../keybindings/useShortcutDisplay.js'\nimport { useAppStateStore, useSetAppState } from '../../state/AppState.js'\nimport type { Tool } from '../../Tool.js'\nimport { backgroundAll } from '../../tasks/LocalShellTask/LocalShellTask.js'\nimport type { ProgressMessage } from '../../types/message.js'\nimport { env } from '../../utils/env.js'\nimport { isEnvTruthy } from '../../utils/envUtils.js'\nimport { getDisplayPath } from '../../utils/file.js'\nimport { isFullscreenEnvEnabled } from '../../utils/fullscreen.js'\nimport type { ThemeName } from '../../utils/theme.js'\nimport type { BashProgress, BashToolInput, Out } from './BashTool.js'\nimport BashToolResultMessage from './BashToolResultMessage.js'\nimport { extractBashCommentLabel } from './commentLabel.js'\nimport { parseSedEditCommand } from './sedEditParser.js'\n\n// Constants for command display\nconst MAX_COMMAND_DISPLAY_LINES = 2\nconst MAX_COMMAND_DISPLAY_CHARS = 160\n\n// Simple component to show background hint and handle ctrl+b\n// When ctrl+b is pressed, backgrounds ALL running foreground commands\nexport function BackgroundHint({\n  onBackground,\n}: {\n  onBackground?: () => void\n} = {}): React.ReactElement | null {\n  const store = useAppStateStore()\n  const setAppState = useSetAppState()\n\n  // Handler for task:background - background all foreground tasks\n  const handleBackground = React.useCallback(() => {\n    // Background ALL foreground bash tasks\n    backgroundAll(() => store.getState(), setAppState)\n    // Also call the optional callback (used for non-bash tasks like agents)\n    onBackground?.()\n  }, [store, setAppState, onBackground])\n\n  useKeybinding('task:background', handleBackground, {\n    context: 'Task',\n  })\n\n  // Get the configured shortcut for task:background\n  const baseShortcut = useShortcutDisplay('task:background', 'Task', 'ctrl+b')\n  // In tmux, ctrl+b is the prefix key, so users need to press it twice to send ctrl+b\n  const shortcut =\n    env.terminal === 'tmux' && baseShortcut === 'ctrl+b'\n      ? 'ctrl+b ctrl+b (twice)'\n      : baseShortcut\n\n  // Don't show background hint if background tasks are disabled\n  if (isEnvTruthy(process.env.CLAUDE_CODE_DISABLE_BACKGROUND_TASKS)) {\n    return null\n  }\n\n  return (\n    <Box paddingLeft={5}>\n      <Text dimColor>\n        <KeyboardShortcutHint\n          shortcut={shortcut}\n          action=\"run in background\"\n          parens\n        />\n      </Text>\n    </Box>\n  )\n}\n\nexport function renderToolUseMessage(\n  input: Partial<BashToolInput>,\n  { verbose, theme: _theme }: { verbose: boolean; theme: ThemeName },\n): React.ReactNode {\n  const { command } = input\n  if (!command) {\n    return null\n  }\n\n  // Render sed in-place edits like file edits (show file path only)\n  const sedInfo = parseSedEditCommand(command)\n  if (sedInfo) {\n    return verbose ? sedInfo.filePath : getDisplayPath(sedInfo.filePath)\n  }\n\n  if (!verbose) {\n    const lines = command.split('\\n')\n\n    if (isFullscreenEnvEnabled()) {\n      const label = extractBashCommentLabel(command)\n      if (label) {\n        return label.length > MAX_COMMAND_DISPLAY_CHARS\n          ? label.slice(0, MAX_COMMAND_DISPLAY_CHARS) + '…'\n          : label\n      }\n    }\n\n    const needsLineTruncation = lines.length > MAX_COMMAND_DISPLAY_LINES\n    const needsCharTruncation = command.length > MAX_COMMAND_DISPLAY_CHARS\n\n    if (needsLineTruncation || needsCharTruncation) {\n      let truncated = command\n\n      // First truncate by lines if needed\n      if (needsLineTruncation) {\n        truncated = lines.slice(0, MAX_COMMAND_DISPLAY_LINES).join('\\n')\n      }\n\n      // Then truncate by chars if still too long\n      if (truncated.length > MAX_COMMAND_DISPLAY_CHARS) {\n        truncated = truncated.slice(0, MAX_COMMAND_DISPLAY_CHARS)\n      }\n\n      return <Text>{truncated.trim()}…</Text>\n    }\n  }\n\n  return command\n}\n\nexport function renderToolUseProgressMessage(\n  progressMessagesForMessage: ProgressMessage<BashProgress>[],\n  {\n    verbose,\n    tools: _tools,\n    terminalSize: _terminalSize,\n    inProgressToolCallCount: _inProgressToolCallCount,\n  }: {\n    tools: Tool[]\n    verbose: boolean\n    terminalSize?: { columns: number; rows: number }\n    inProgressToolCallCount?: number\n  },\n): React.ReactNode {\n  const lastProgress = progressMessagesForMessage.at(-1)\n\n  if (!lastProgress || !lastProgress.data) {\n    return (\n      <MessageResponse height={1}>\n        <Text dimColor>Running…</Text>\n      </MessageResponse>\n    )\n  }\n\n  const data = lastProgress.data\n\n  return (\n    <ShellProgressMessage\n      fullOutput={data.fullOutput}\n      output={data.output}\n      elapsedTimeSeconds={data.elapsedTimeSeconds}\n      totalLines={data.totalLines}\n      totalBytes={data.totalBytes}\n      timeoutMs={data.timeoutMs}\n      taskId={data.taskId}\n      verbose={verbose}\n    />\n  )\n}\n\nexport function renderToolUseQueuedMessage(): React.ReactNode {\n  return (\n    <MessageResponse height={1}>\n      <Text dimColor>Waiting…</Text>\n    </MessageResponse>\n  )\n}\n\nexport function renderToolResultMessage(\n  content: Out,\n  progressMessagesForMessage: ProgressMessage<BashProgress>[],\n  {\n    verbose,\n    theme: _theme,\n    tools: _tools,\n    style: _style,\n  }: {\n    verbose: boolean\n    theme: ThemeName\n    tools: Tool[]\n    style?: 'condensed'\n  },\n): React.ReactNode {\n  const lastProgress = progressMessagesForMessage.at(-1)\n  const timeoutMs = lastProgress?.data?.timeoutMs\n  return (\n    <BashToolResultMessage\n      content={content}\n      verbose={verbose}\n      timeoutMs={timeoutMs}\n    />\n  )\n}\n\nexport function renderToolUseErrorMessage(\n  result: ToolResultBlockParam['content'],\n  {\n    verbose,\n    progressMessagesForMessage: _progressMessagesForMessage,\n    tools: _tools,\n  }: {\n    verbose: boolean\n    progressMessagesForMessage: ProgressMessage<BashProgress>[]\n    tools: Tool[]\n  },\n): React.ReactNode {\n  return <FallbackToolUseErrorMessage result={result} verbose={verbose} />\n}\n"],"mappings":"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","ignoreList":[]}