source dump of claude code
at main 368 lines 45 kB view raw
1import { c as _c } from "react/compiler-runtime"; 2import type { ToolUseBlockParam } from '@anthropic-ai/sdk/resources/index.mjs'; 3import React, { useMemo } from 'react'; 4import { useTerminalSize } from 'src/hooks/useTerminalSize.js'; 5import type { ThemeName } from 'src/utils/theme.js'; 6import type { Command } from '../../commands.js'; 7import { BLACK_CIRCLE } from '../../constants/figures.js'; 8import { stringWidth } from '../../ink/stringWidth.js'; 9import { Box, Text, useTheme } from '../../ink.js'; 10import { useAppStateMaybeOutsideOfProvider } from '../../state/AppState.js'; 11import { findToolByName, type Tool, type ToolProgressData, type Tools } from '../../Tool.js'; 12import type { ProgressMessage } from '../../types/message.js'; 13import { useIsClassifierChecking } from '../../utils/classifierApprovalsHook.js'; 14import { logError } from '../../utils/log.js'; 15import type { buildMessageLookups } from '../../utils/messages.js'; 16import { MessageResponse } from '../MessageResponse.js'; 17import { useSelectedMessageBg } from '../messageActions.js'; 18import { SentryErrorBoundary } from '../SentryErrorBoundary.js'; 19import { ToolUseLoader } from '../ToolUseLoader.js'; 20import { HookProgressMessage } from './HookProgressMessage.js'; 21type Props = { 22 param: ToolUseBlockParam; 23 addMargin: boolean; 24 tools: Tools; 25 commands: Command[]; 26 verbose: boolean; 27 inProgressToolUseIDs: Set<string>; 28 progressMessagesForMessage: ProgressMessage[]; 29 shouldAnimate: boolean; 30 shouldShowDot: boolean; 31 inProgressToolCallCount?: number; 32 lookups: ReturnType<typeof buildMessageLookups>; 33 isTranscriptMode?: boolean; 34}; 35export function AssistantToolUseMessage(t0) { 36 const $ = _c(81); 37 const { 38 param, 39 addMargin, 40 tools, 41 commands, 42 verbose, 43 inProgressToolUseIDs, 44 progressMessagesForMessage, 45 shouldAnimate, 46 shouldShowDot, 47 inProgressToolCallCount, 48 lookups, 49 isTranscriptMode 50 } = t0; 51 const terminalSize = useTerminalSize(); 52 const [theme] = useTheme(); 53 const bg = useSelectedMessageBg(); 54 const pendingWorkerRequest = useAppStateMaybeOutsideOfProvider(_temp); 55 const isClassifierCheckingRaw = useIsClassifierChecking(param.id); 56 const permissionMode = useAppStateMaybeOutsideOfProvider(_temp2); 57 const hasStrippedRules = useAppStateMaybeOutsideOfProvider(_temp3); 58 const isAutoClassifier = permissionMode === "auto" || permissionMode === "plan" && hasStrippedRules; 59 const isClassifierChecking = false && isClassifierCheckingRaw && permissionMode !== "auto"; 60 let t1; 61 if ($[0] !== param.input || $[1] !== param.name || $[2] !== tools) { 62 bb0: { 63 if (!tools) { 64 t1 = null; 65 break bb0; 66 } 67 const tool = findToolByName(tools, param.name); 68 if (!tool) { 69 t1 = null; 70 break bb0; 71 } 72 const input = tool.inputSchema.safeParse(param.input); 73 const data = input.success ? input.data : undefined; 74 t1 = { 75 tool, 76 input, 77 userFacingToolName: tool.userFacingName(data), 78 userFacingToolNameBackgroundColor: tool.userFacingNameBackgroundColor?.(data), 79 isTransparentWrapper: tool.isTransparentWrapper?.() ?? false 80 }; 81 } 82 $[0] = param.input; 83 $[1] = param.name; 84 $[2] = tools; 85 $[3] = t1; 86 } else { 87 t1 = $[3]; 88 } 89 const parsed = t1; 90 if (!parsed) { 91 logError(new Error(tools ? `Tool ${param.name} not found` : `Tools array is undefined for tool ${param.name}`)); 92 return null; 93 } 94 const { 95 tool: tool_0, 96 input: input_0, 97 userFacingToolName, 98 userFacingToolNameBackgroundColor, 99 isTransparentWrapper 100 } = parsed; 101 let t2; 102 if ($[4] !== lookups.resolvedToolUseIDs || $[5] !== param.id) { 103 t2 = lookups.resolvedToolUseIDs.has(param.id); 104 $[4] = lookups.resolvedToolUseIDs; 105 $[5] = param.id; 106 $[6] = t2; 107 } else { 108 t2 = $[6]; 109 } 110 const isResolved = t2; 111 let t3; 112 if ($[7] !== inProgressToolUseIDs || $[8] !== isResolved || $[9] !== param.id) { 113 t3 = !inProgressToolUseIDs.has(param.id) && !isResolved; 114 $[7] = inProgressToolUseIDs; 115 $[8] = isResolved; 116 $[9] = param.id; 117 $[10] = t3; 118 } else { 119 t3 = $[10]; 120 } 121 const isQueued = t3; 122 const isWaitingForPermission = pendingWorkerRequest?.toolUseId === param.id; 123 if (isTransparentWrapper) { 124 if (isQueued || isResolved) { 125 return null; 126 } 127 let t4; 128 if ($[11] !== inProgressToolCallCount || $[12] !== isTranscriptMode || $[13] !== lookups || $[14] !== param.id || $[15] !== progressMessagesForMessage || $[16] !== terminalSize || $[17] !== tool_0 || $[18] !== tools || $[19] !== verbose) { 129 t4 = renderToolUseProgressMessage(tool_0, tools, lookups, param.id, progressMessagesForMessage, { 130 verbose, 131 inProgressToolCallCount, 132 isTranscriptMode 133 }, terminalSize); 134 $[11] = inProgressToolCallCount; 135 $[12] = isTranscriptMode; 136 $[13] = lookups; 137 $[14] = param.id; 138 $[15] = progressMessagesForMessage; 139 $[16] = terminalSize; 140 $[17] = tool_0; 141 $[18] = tools; 142 $[19] = verbose; 143 $[20] = t4; 144 } else { 145 t4 = $[20]; 146 } 147 let t5; 148 if ($[21] !== bg || $[22] !== t4) { 149 t5 = <Box flexDirection="column" width="100%" backgroundColor={bg}>{t4}</Box>; 150 $[21] = bg; 151 $[22] = t4; 152 $[23] = t5; 153 } else { 154 t5 = $[23]; 155 } 156 return t5; 157 } 158 if (userFacingToolName === "") { 159 return null; 160 } 161 let t4; 162 if ($[24] !== commands || $[25] !== input_0.data || $[26] !== input_0.success || $[27] !== theme || $[28] !== tool_0 || $[29] !== verbose) { 163 t4 = input_0.success ? renderToolUseMessage(tool_0, input_0.data, { 164 theme, 165 verbose, 166 commands 167 }) : null; 168 $[24] = commands; 169 $[25] = input_0.data; 170 $[26] = input_0.success; 171 $[27] = theme; 172 $[28] = tool_0; 173 $[29] = verbose; 174 $[30] = t4; 175 } else { 176 t4 = $[30]; 177 } 178 const renderedToolUseMessage = t4; 179 if (renderedToolUseMessage === null) { 180 return null; 181 } 182 const t5 = addMargin ? 1 : 0; 183 const t6 = stringWidth(userFacingToolName) + (shouldShowDot ? 2 : 0); 184 let t7; 185 if ($[31] !== isQueued || $[32] !== isResolved || $[33] !== lookups.erroredToolUseIDs || $[34] !== param.id || $[35] !== shouldAnimate || $[36] !== shouldShowDot) { 186 t7 = shouldShowDot && (isQueued ? <Box minWidth={2}><Text dimColor={isQueued}>{BLACK_CIRCLE}</Text></Box> : <ToolUseLoader shouldAnimate={shouldAnimate} isUnresolved={!isResolved} isError={lookups.erroredToolUseIDs.has(param.id)} />); 187 $[31] = isQueued; 188 $[32] = isResolved; 189 $[33] = lookups.erroredToolUseIDs; 190 $[34] = param.id; 191 $[35] = shouldAnimate; 192 $[36] = shouldShowDot; 193 $[37] = t7; 194 } else { 195 t7 = $[37]; 196 } 197 const t8 = userFacingToolNameBackgroundColor ? "inverseText" : undefined; 198 let t9; 199 if ($[38] !== t8 || $[39] !== userFacingToolName || $[40] !== userFacingToolNameBackgroundColor) { 200 t9 = <Box flexShrink={0}><Text bold={true} wrap="truncate-end" backgroundColor={userFacingToolNameBackgroundColor} color={t8}>{userFacingToolName}</Text></Box>; 201 $[38] = t8; 202 $[39] = userFacingToolName; 203 $[40] = userFacingToolNameBackgroundColor; 204 $[41] = t9; 205 } else { 206 t9 = $[41]; 207 } 208 let t10; 209 if ($[42] !== renderedToolUseMessage) { 210 t10 = renderedToolUseMessage !== "" && <Box flexWrap="nowrap"><Text>({renderedToolUseMessage})</Text></Box>; 211 $[42] = renderedToolUseMessage; 212 $[43] = t10; 213 } else { 214 t10 = $[43]; 215 } 216 let t11; 217 if ($[44] !== input_0.data || $[45] !== input_0.success || $[46] !== tool_0) { 218 t11 = input_0.success && tool_0.renderToolUseTag && tool_0.renderToolUseTag(input_0.data); 219 $[44] = input_0.data; 220 $[45] = input_0.success; 221 $[46] = tool_0; 222 $[47] = t11; 223 } else { 224 t11 = $[47]; 225 } 226 let t12; 227 if ($[48] !== t10 || $[49] !== t11 || $[50] !== t6 || $[51] !== t7 || $[52] !== t9) { 228 t12 = <Box flexDirection="row" flexWrap="nowrap" minWidth={t6}>{t7}{t9}{t10}{t11}</Box>; 229 $[48] = t10; 230 $[49] = t11; 231 $[50] = t6; 232 $[51] = t7; 233 $[52] = t9; 234 $[53] = t12; 235 } else { 236 t12 = $[53]; 237 } 238 let t13; 239 if ($[54] !== inProgressToolCallCount || $[55] !== isAutoClassifier || $[56] !== isClassifierChecking || $[57] !== isQueued || $[58] !== isResolved || $[59] !== isTranscriptMode || $[60] !== isWaitingForPermission || $[61] !== lookups || $[62] !== param.id || $[63] !== progressMessagesForMessage || $[64] !== terminalSize || $[65] !== tool_0 || $[66] !== tools || $[67] !== verbose) { 240 t13 = !isResolved && !isQueued && (isClassifierChecking ? <MessageResponse height={1}><Text dimColor={true}>{isAutoClassifier ? "Auto classifier checking\u2026" : "Bash classifier checking\u2026"}</Text></MessageResponse> : isWaitingForPermission ? <MessageResponse height={1}><Text dimColor={true}>Waiting for permission</Text></MessageResponse> : renderToolUseProgressMessage(tool_0, tools, lookups, param.id, progressMessagesForMessage, { 241 verbose, 242 inProgressToolCallCount, 243 isTranscriptMode 244 }, terminalSize)); 245 $[54] = inProgressToolCallCount; 246 $[55] = isAutoClassifier; 247 $[56] = isClassifierChecking; 248 $[57] = isQueued; 249 $[58] = isResolved; 250 $[59] = isTranscriptMode; 251 $[60] = isWaitingForPermission; 252 $[61] = lookups; 253 $[62] = param.id; 254 $[63] = progressMessagesForMessage; 255 $[64] = terminalSize; 256 $[65] = tool_0; 257 $[66] = tools; 258 $[67] = verbose; 259 $[68] = t13; 260 } else { 261 t13 = $[68]; 262 } 263 let t14; 264 if ($[69] !== isQueued || $[70] !== isResolved || $[71] !== tool_0) { 265 t14 = !isResolved && isQueued && renderToolUseQueuedMessage(tool_0); 266 $[69] = isQueued; 267 $[70] = isResolved; 268 $[71] = tool_0; 269 $[72] = t14; 270 } else { 271 t14 = $[72]; 272 } 273 let t15; 274 if ($[73] !== t12 || $[74] !== t13 || $[75] !== t14) { 275 t15 = <Box flexDirection="column">{t12}{t13}{t14}</Box>; 276 $[73] = t12; 277 $[74] = t13; 278 $[75] = t14; 279 $[76] = t15; 280 } else { 281 t15 = $[76]; 282 } 283 let t16; 284 if ($[77] !== bg || $[78] !== t15 || $[79] !== t5) { 285 t16 = <Box flexDirection="row" justifyContent="space-between" marginTop={t5} width="100%" backgroundColor={bg}>{t15}</Box>; 286 $[77] = bg; 287 $[78] = t15; 288 $[79] = t5; 289 $[80] = t16; 290 } else { 291 t16 = $[80]; 292 } 293 return t16; 294} 295function _temp3(state_1) { 296 return !!state_1.toolPermissionContext.strippedDangerousRules; 297} 298function _temp2(state_0) { 299 return state_0.toolPermissionContext.mode; 300} 301function _temp(state) { 302 return state.pendingWorkerRequest; 303} 304function renderToolUseMessage(tool: Tool, input: unknown, { 305 theme, 306 verbose, 307 commands 308}: { 309 theme: ThemeName; 310 verbose: boolean; 311 commands: Command[]; 312}): React.ReactNode { 313 try { 314 const parsed = tool.inputSchema.safeParse(input); 315 if (!parsed.success) { 316 return ''; 317 } 318 return tool.renderToolUseMessage(parsed.data, { 319 theme, 320 verbose, 321 commands 322 }); 323 } catch (error) { 324 logError(new Error(`Error rendering tool use message for ${tool.name}: ${error}`)); 325 return ''; 326 } 327} 328function renderToolUseProgressMessage(tool: Tool, tools: Tools, lookups: ReturnType<typeof buildMessageLookups>, toolUseID: string, progressMessagesForMessage: ProgressMessage[], { 329 verbose, 330 inProgressToolCallCount, 331 isTranscriptMode 332}: { 333 verbose: boolean; 334 inProgressToolCallCount?: number; 335 isTranscriptMode?: boolean; 336}, terminalSize: { 337 columns: number; 338 rows: number; 339}): React.ReactNode { 340 const toolProgressMessages = progressMessagesForMessage.filter((msg): msg is ProgressMessage<ToolProgressData> => msg.data.type !== 'hook_progress'); 341 try { 342 const toolMessages = tool.renderToolUseProgressMessage?.(toolProgressMessages, { 343 tools, 344 verbose, 345 terminalSize, 346 inProgressToolCallCount: inProgressToolCallCount ?? 1, 347 isTranscriptMode 348 }) ?? null; 349 return <> 350 <SentryErrorBoundary> 351 <HookProgressMessage hookEvent="PreToolUse" lookups={lookups} toolUseID={toolUseID} verbose={verbose} isTranscriptMode={isTranscriptMode} /> 352 </SentryErrorBoundary> 353 {toolMessages} 354 </>; 355 } catch (error) { 356 logError(new Error(`Error rendering tool use progress message for ${tool.name}: ${error}`)); 357 return null; 358 } 359} 360function renderToolUseQueuedMessage(tool: Tool): React.ReactNode { 361 try { 362 return tool.renderToolUseQueuedMessage?.(); 363 } catch (error) { 364 logError(new Error(`Error rendering tool use queued message for ${tool.name}: ${error}`)); 365 return null; 366 } 367} 368//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["ToolUseBlockParam","React","useMemo","useTerminalSize","ThemeName","Command","BLACK_CIRCLE","stringWidth","Box","Text","useTheme","useAppStateMaybeOutsideOfProvider","findToolByName","Tool","ToolProgressData","Tools","ProgressMessage","useIsClassifierChecking","logError","buildMessageLookups","MessageResponse","useSelectedMessageBg","SentryErrorBoundary","ToolUseLoader","HookProgressMessage","Props","param","addMargin","tools","commands","verbose","inProgressToolUseIDs","Set","progressMessagesForMessage","shouldAnimate","shouldShowDot","inProgressToolCallCount","lookups","ReturnType","isTranscriptMode","AssistantToolUseMessage","t0","$","_c","terminalSize","theme","bg","pendingWorkerRequest","_temp","isClassifierCheckingRaw","id","permissionMode","_temp2","hasStrippedRules","_temp3","isAutoClassifier","isClassifierChecking","t1","input","name","bb0","tool","inputSchema","safeParse","data","success","undefined","userFacingToolName","userFacingName","userFacingToolNameBackgroundColor","userFacingNameBackgroundColor","isTransparentWrapper","parsed","Error","tool_0","input_0","t2","resolvedToolUseIDs","has","isResolved","t3","isQueued","isWaitingForPermission","toolUseId","t4","renderToolUseProgressMessage","t5","renderToolUseMessage","renderedToolUseMessage","t6","t7","erroredToolUseIDs","t8","t9","t10","t11","renderToolUseTag","t12","t13","t14","renderToolUseQueuedMessage","t15","t16","state_1","state","toolPermissionContext","strippedDangerousRules","state_0","mode","ReactNode","error","toolUseID","columns","rows","toolProgressMessages","filter","msg","type","toolMessages"],"sources":["AssistantToolUseMessage.tsx"],"sourcesContent":["import type { ToolUseBlockParam } from '@anthropic-ai/sdk/resources/index.mjs'\nimport React, { useMemo } from 'react'\nimport { useTerminalSize } from 'src/hooks/useTerminalSize.js'\nimport type { ThemeName } from 'src/utils/theme.js'\nimport type { Command } from '../../commands.js'\nimport { BLACK_CIRCLE } from '../../constants/figures.js'\nimport { stringWidth } from '../../ink/stringWidth.js'\nimport { Box, Text, useTheme } from '../../ink.js'\nimport { useAppStateMaybeOutsideOfProvider } from '../../state/AppState.js'\nimport {\n  findToolByName,\n  type Tool,\n  type ToolProgressData,\n  type Tools,\n} from '../../Tool.js'\nimport type { ProgressMessage } from '../../types/message.js'\nimport { useIsClassifierChecking } from '../../utils/classifierApprovalsHook.js'\nimport { logError } from '../../utils/log.js'\nimport type { buildMessageLookups } from '../../utils/messages.js'\nimport { MessageResponse } from '../MessageResponse.js'\nimport { useSelectedMessageBg } from '../messageActions.js'\nimport { SentryErrorBoundary } from '../SentryErrorBoundary.js'\nimport { ToolUseLoader } from '../ToolUseLoader.js'\nimport { HookProgressMessage } from './HookProgressMessage.js'\n\ntype Props = {\n  param: ToolUseBlockParam\n  addMargin: boolean\n  tools: Tools\n  commands: Command[]\n  verbose: boolean\n  inProgressToolUseIDs: Set<string>\n  progressMessagesForMessage: ProgressMessage[]\n  shouldAnimate: boolean\n  shouldShowDot: boolean\n  inProgressToolCallCount?: number\n  lookups: ReturnType<typeof buildMessageLookups>\n  isTranscriptMode?: boolean\n}\n\nexport function AssistantToolUseMessage({\n  param,\n  addMargin,\n  tools,\n  commands,\n  verbose,\n  inProgressToolUseIDs,\n  progressMessagesForMessage,\n  shouldAnimate,\n  shouldShowDot,\n  inProgressToolCallCount,\n  lookups,\n  isTranscriptMode,\n}: Props): React.ReactNode {\n  const terminalSize = useTerminalSize()\n  const [theme] = useTheme()\n  const bg = useSelectedMessageBg()\n  const pendingWorkerRequest = useAppStateMaybeOutsideOfProvider(\n    state => state.pendingWorkerRequest,\n  )\n  const isClassifierCheckingRaw = useIsClassifierChecking(param.id)\n  const permissionMode = useAppStateMaybeOutsideOfProvider(\n    state => state.toolPermissionContext.mode,\n  )\n  // strippedDangerousRules is set by stripDangerousPermissionsForAutoMode\n  // (even to {}) whenever auto is active, and cleared by restoreDangerousPermissions\n  // on deactivation — a reliable proxy for isAutoModeActive() during plan.\n  // prePlanMode would be stale after transitionPlanAutoMode deactivates mid-plan.\n  const hasStrippedRules = useAppStateMaybeOutsideOfProvider(\n    state => !!state.toolPermissionContext.strippedDangerousRules,\n  )\n  const isAutoClassifier =\n    permissionMode === 'auto' || (permissionMode === 'plan' && hasStrippedRules)\n  const isClassifierChecking =\n    \"external\" === 'ant' &&\n    isClassifierCheckingRaw &&\n    permissionMode !== 'auto'\n\n  // Memoize on param identity (stable — from the persisted message object).\n  // Zod safeParse allocates per call, and some tools' userFacingName()\n  // (BashTool → shouldUseSandbox → shell-quote parse) are expensive. Without\n  // this, ~50 bash messages × shell-quote-per-render pushed transition\n  // render past the shimmer tick → abort → infinite retry (#21605).\n  const parsed = useMemo(() => {\n    if (!tools) return null\n    const tool = findToolByName(tools, param.name)\n    if (!tool) return null\n    const input = tool.inputSchema.safeParse(param.input)\n    const data = input.success ? input.data : undefined\n    return {\n      tool,\n      input,\n      userFacingToolName: tool.userFacingName(data),\n      userFacingToolNameBackgroundColor:\n        tool.userFacingNameBackgroundColor?.(data),\n      isTransparentWrapper: tool.isTransparentWrapper?.() ?? false,\n    }\n  }, [tools, param])\n\n  if (!parsed) {\n    // Guard against undefined tools (required prop) or unknown tool name\n    logError(\n      new Error(\n        tools\n          ? `Tool ${param.name} not found`\n          : `Tools array is undefined for tool ${param.name}`,\n      ),\n    )\n    return null\n  }\n\n  const {\n    tool,\n    input,\n    userFacingToolName,\n    userFacingToolNameBackgroundColor,\n    isTransparentWrapper,\n  } = parsed\n\n  const isResolved = lookups.resolvedToolUseIDs.has(param.id)\n  const isQueued = !inProgressToolUseIDs.has(param.id) && !isResolved\n  const isWaitingForPermission = pendingWorkerRequest?.toolUseId === param.id\n\n  if (isTransparentWrapper) {\n    if (isQueued || isResolved) return null\n    return (\n      <Box flexDirection=\"column\" width=\"100%\" backgroundColor={bg}>\n        {renderToolUseProgressMessage(\n          tool,\n          tools,\n          lookups,\n          param.id,\n          progressMessagesForMessage,\n          { verbose, inProgressToolCallCount, isTranscriptMode },\n          terminalSize,\n        )}\n      </Box>\n    )\n  }\n\n  if (userFacingToolName === '') {\n    return null\n  }\n\n  const renderedToolUseMessage = input.success\n    ? renderToolUseMessage(tool, input.data, { theme, verbose, commands })\n    : null\n  if (renderedToolUseMessage === null) {\n    return null\n  }\n\n  return (\n    <Box\n      flexDirection=\"row\"\n      justifyContent=\"space-between\"\n      marginTop={addMargin ? 1 : 0}\n      width=\"100%\"\n      backgroundColor={bg}\n    >\n      <Box flexDirection=\"column\">\n        <Box\n          flexDirection=\"row\"\n          flexWrap=\"nowrap\"\n          minWidth={stringWidth(userFacingToolName) + (shouldShowDot ? 2 : 0)}\n        >\n          {shouldShowDot &&\n            (isQueued ? (\n              <Box minWidth={2}>\n                <Text dimColor={isQueued}>{BLACK_CIRCLE}</Text>\n              </Box>\n            ) : (\n              // WARNING: The code here and in ToolUseLoader is particularly\n              // sensitive to what *should* just be trivial refactorings. See\n              // the comment in ToolUseLoader for more details.\n              <ToolUseLoader\n                shouldAnimate={shouldAnimate}\n                isUnresolved={!isResolved}\n                isError={lookups.erroredToolUseIDs.has(param.id)}\n              />\n            ))}\n          <Box flexShrink={0}>\n            <Text\n              bold\n              wrap=\"truncate-end\"\n              backgroundColor={userFacingToolNameBackgroundColor}\n              color={\n                userFacingToolNameBackgroundColor ? 'inverseText' : undefined\n              }\n            >\n              {userFacingToolName}\n            </Text>\n          </Box>\n          {renderedToolUseMessage !== '' && (\n            <Box flexWrap=\"nowrap\">\n              <Text>({renderedToolUseMessage})</Text>\n            </Box>\n          )}\n          {/* Render tool-specific tags (timeout, model, resume ID, etc.) */}\n          {input.success &&\n            tool.renderToolUseTag &&\n            tool.renderToolUseTag(input.data)}\n        </Box>\n        {!isResolved &&\n          !isQueued &&\n          (isClassifierChecking ? (\n            <MessageResponse height={1}>\n              <Text dimColor>\n                {isAutoClassifier\n                  ? 'Auto classifier checking\\u2026'\n                  : 'Bash classifier checking\\u2026'}\n              </Text>\n            </MessageResponse>\n          ) : isWaitingForPermission ? (\n            <MessageResponse height={1}>\n              <Text dimColor>Waiting for permission…</Text>\n            </MessageResponse>\n          ) : (\n            renderToolUseProgressMessage(\n              tool,\n              tools,\n              lookups,\n              param.id,\n              progressMessagesForMessage,\n              {\n                verbose,\n                inProgressToolCallCount,\n                isTranscriptMode,\n              },\n              terminalSize,\n            )\n          ))}\n        {!isResolved && isQueued && renderToolUseQueuedMessage(tool)}\n      </Box>\n    </Box>\n  )\n}\n\nfunction renderToolUseMessage(\n  tool: Tool,\n  input: unknown,\n  {\n    theme,\n    verbose,\n    commands,\n  }: { theme: ThemeName; verbose: boolean; commands: Command[] },\n): React.ReactNode {\n  try {\n    const parsed = tool.inputSchema.safeParse(input)\n    if (!parsed.success) {\n      return ''\n    }\n    return tool.renderToolUseMessage(parsed.data, { theme, verbose, commands })\n  } catch (error) {\n    logError(\n      new Error(`Error rendering tool use message for ${tool.name}: ${error}`),\n    )\n    return ''\n  }\n}\n\nfunction renderToolUseProgressMessage(\n  tool: Tool,\n  tools: Tools,\n  lookups: ReturnType<typeof buildMessageLookups>,\n  toolUseID: string,\n  progressMessagesForMessage: ProgressMessage[],\n  {\n    verbose,\n    inProgressToolCallCount,\n    isTranscriptMode,\n  }: {\n    verbose: boolean\n    inProgressToolCallCount?: number\n    isTranscriptMode?: boolean\n  },\n  terminalSize: { columns: number; rows: number },\n): React.ReactNode {\n  const toolProgressMessages = progressMessagesForMessage.filter(\n    (msg): msg is ProgressMessage<ToolProgressData> =>\n      msg.data.type !== 'hook_progress',\n  )\n  try {\n    const toolMessages =\n      tool.renderToolUseProgressMessage?.(toolProgressMessages, {\n        tools,\n        verbose,\n        terminalSize,\n        inProgressToolCallCount: inProgressToolCallCount ?? 1,\n        isTranscriptMode,\n      }) ?? null\n    return (\n      <>\n        <SentryErrorBoundary>\n          <HookProgressMessage\n            hookEvent=\"PreToolUse\"\n            lookups={lookups}\n            toolUseID={toolUseID}\n            verbose={verbose}\n            isTranscriptMode={isTranscriptMode}\n          />\n        </SentryErrorBoundary>\n        {toolMessages}\n      </>\n    )\n  } catch (error) {\n    logError(\n      new Error(\n        `Error rendering tool use progress message for ${tool.name}: ${error}`,\n      ),\n    )\n    return null\n  }\n}\n\nfunction renderToolUseQueuedMessage(tool: Tool): React.ReactNode {\n  try {\n    return tool.renderToolUseQueuedMessage?.()\n  } catch (error) {\n    logError(\n      new Error(\n        `Error rendering tool use queued message for ${tool.name}: ${error}`,\n      ),\n    )\n    return null\n  }\n}\n"],"mappings":"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","ignoreList":[]}