๐Ÿ“„ File detail

components/messages/AssistantToolUseMessage.tsx

๐Ÿงฉ .tsx๐Ÿ“ 368 lines๐Ÿ’พ 45,285 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 AssistantToolUseMessage โ€” mainly types, interfaces, or factory objects. Dependencies touch React UI, @anthropic-ai, and src. It composes internal code from commands, constants, ink, state, and Tool (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 type { ToolUseBlockParam } from '@anthropic-ai/sdk/resources/index.mjs'; import React, { useMemo } from 'react'; import { useTerminalSize } from 'src/hooks/useTerminalSize.js'; import type { ThemeName } from 'src/utils/theme.js';

๐Ÿ“ค Exports (heuristic)

  • AssistantToolUseMessage

๐Ÿ“š External import roots

Package roots from from "โ€ฆ" (relative paths omitted).

  • react
  • @anthropic-ai
  • src

๐Ÿ–ฅ๏ธ Source preview

import { c as _c } from "react/compiler-runtime";
import type { ToolUseBlockParam } from '@anthropic-ai/sdk/resources/index.mjs';
import React, { useMemo } from 'react';
import { useTerminalSize } from 'src/hooks/useTerminalSize.js';
import type { ThemeName } from 'src/utils/theme.js';
import type { Command } from '../../commands.js';
import { BLACK_CIRCLE } from '../../constants/figures.js';
import { stringWidth } from '../../ink/stringWidth.js';
import { Box, Text, useTheme } from '../../ink.js';
import { useAppStateMaybeOutsideOfProvider } from '../../state/AppState.js';
import { findToolByName, type Tool, type ToolProgressData, type Tools } from '../../Tool.js';
import type { ProgressMessage } from '../../types/message.js';
import { useIsClassifierChecking } from '../../utils/classifierApprovalsHook.js';
import { logError } from '../../utils/log.js';
import type { buildMessageLookups } from '../../utils/messages.js';
import { MessageResponse } from '../MessageResponse.js';
import { useSelectedMessageBg } from '../messageActions.js';
import { SentryErrorBoundary } from '../SentryErrorBoundary.js';
import { ToolUseLoader } from '../ToolUseLoader.js';
import { HookProgressMessage } from './HookProgressMessage.js';
type Props = {
  param: ToolUseBlockParam;
  addMargin: boolean;
  tools: Tools;
  commands: Command[];
  verbose: boolean;
  inProgressToolUseIDs: Set<string>;
  progressMessagesForMessage: ProgressMessage[];
  shouldAnimate: boolean;
  shouldShowDot: boolean;
  inProgressToolCallCount?: number;
  lookups: ReturnType<typeof buildMessageLookups>;
  isTranscriptMode?: boolean;
};
export function AssistantToolUseMessage(t0) {
  const $ = _c(81);
  const {
    param,
    addMargin,
    tools,
    commands,
    verbose,
    inProgressToolUseIDs,
    progressMessagesForMessage,
    shouldAnimate,
    shouldShowDot,
    inProgressToolCallCount,
    lookups,
    isTranscriptMode
  } = t0;
  const terminalSize = useTerminalSize();
  const [theme] = useTheme();
  const bg = useSelectedMessageBg();
  const pendingWorkerRequest = useAppStateMaybeOutsideOfProvider(_temp);
  const isClassifierCheckingRaw = useIsClassifierChecking(param.id);
  const permissionMode = useAppStateMaybeOutsideOfProvider(_temp2);
  const hasStrippedRules = useAppStateMaybeOutsideOfProvider(_temp3);
  const isAutoClassifier = permissionMode === "auto" || permissionMode === "plan" && hasStrippedRules;
  const isClassifierChecking = false && isClassifierCheckingRaw && permissionMode !== "auto";
  let t1;
  if ($[0] !== param.input || $[1] !== param.name || $[2] !== tools) {
    bb0: {
      if (!tools) {
        t1 = null;
        break bb0;
      }
      const tool = findToolByName(tools, param.name);
      if (!tool) {
        t1 = null;
        break bb0;
      }
      const input = tool.inputSchema.safeParse(param.input);
      const data = input.success ? input.data : undefined;
      t1 = {
        tool,
        input,
        userFacingToolName: tool.userFacingName(data),
        userFacingToolNameBackgroundColor: tool.userFacingNameBackgroundColor?.(data),
        isTransparentWrapper: tool.isTransparentWrapper?.() ?? false
      };
    }
    $[0] = param.input;
    $[1] = param.name;
    $[2] = tools;
    $[3] = t1;
  } else {
    t1 = $[3];
  }
  const parsed = t1;
  if (!parsed) {
    logError(new Error(tools ? `Tool ${param.name} not found` : `Tools array is undefined for tool ${param.name}`));
    return null;
  }
  const {
    tool: tool_0,
    input: input_0,
    userFacingToolName,
    userFacingToolNameBackgroundColor,
    isTransparentWrapper
  } = parsed;
  let t2;
  if ($[4] !== lookups.resolvedToolUseIDs || $[5] !== param.id) {
    t2 = lookups.resolvedToolUseIDs.has(param.id);
    $[4] = lookups.resolvedToolUseIDs;
    $[5] = param.id;
    $[6] = t2;
  } else {
    t2 = $[6];
  }
  const isResolved = t2;
  let t3;
  if ($[7] !== inProgressToolUseIDs || $[8] !== isResolved || $[9] !== param.id) {
    t3 = !inProgressToolUseIDs.has(param.id) && !isResolved;
    $[7] = inProgressToolUseIDs;
    $[8] = isResolved;
    $[9] = param.id;
    $[10] = t3;
  } else {
    t3 = $[10];
  }
  const isQueued = t3;
  const isWaitingForPermission = pendingWorkerRequest?.toolUseId === param.id;
  if (isTransparentWrapper) {
    if (isQueued || isResolved) {
      return null;
    }
    let t4;
    if ($[11] !== inProgressToolCallCount || $[12] !== isTranscriptMode || $[13] !== lookups || $[14] !== param.id || $[15] !== progressMessagesForMessage || $[16] !== terminalSize || $[17] !== tool_0 || $[18] !== tools || $[19] !== verbose) {
      t4 = renderToolUseProgressMessage(tool_0, tools, lookups, param.id, progressMessagesForMessage, {
        verbose,
        inProgressToolCallCount,
        isTranscriptMode
      }, terminalSize);
      $[11] = inProgressToolCallCount;
      $[12] = isTranscriptMode;
      $[13] = lookups;
      $[14] = param.id;
      $[15] = progressMessagesForMessage;
      $[16] = terminalSize;
      $[17] = tool_0;
      $[18] = tools;
      $[19] = verbose;
      $[20] = t4;
    } else {
      t4 = $[20];
    }
    let t5;
    if ($[21] !== bg || $[22] !== t4) {
      t5 = <Box flexDirection="column" width="100%" backgroundColor={bg}>{t4}</Box>;
      $[21] = bg;
      $[22] = t4;
      $[23] = t5;
    } else {
      t5 = $[23];
    }
    return t5;
  }
  if (userFacingToolName === "") {
    return null;
  }
  let t4;
  if ($[24] !== commands || $[25] !== input_0.data || $[26] !== input_0.success || $[27] !== theme || $[28] !== tool_0 || $[29] !== verbose) {
    t4 = input_0.success ? renderToolUseMessage(tool_0, input_0.data, {
      theme,
      verbose,
      commands
    }) : null;
    $[24] = commands;
    $[25] = input_0.data;
    $[26] = input_0.success;
    $[27] = theme;
    $[28] = tool_0;
    $[29] = verbose;
    $[30] = t4;
  } else {
    t4 = $[30];
  }
  const renderedToolUseMessage = t4;
  if (renderedToolUseMessage === null) {
    return null;
  }
  const t5 = addMargin ? 1 : 0;
  const t6 = stringWidth(userFacingToolName) + (shouldShowDot ? 2 : 0);
  let t7;
  if ($[31] !== isQueued || $[32] !== isResolved || $[33] !== lookups.erroredToolUseIDs || $[34] !== param.id || $[35] !== shouldAnimate || $[36] !== shouldShowDot) {
    t7 = shouldShowDot && (isQueued ? <Box minWidth={2}><Text dimColor={isQueued}>{BLACK_CIRCLE}</Text></Box> : <ToolUseLoader shouldAnimate={shouldAnimate} isUnresolved={!isResolved} isError={lookups.erroredToolUseIDs.has(param.id)} />);
    $[31] = isQueued;
    $[32] = isResolved;
    $[33] = lookups.erroredToolUseIDs;
    $[34] = param.id;
    $[35] = shouldAnimate;
    $[36] = shouldShowDot;
    $[37] = t7;
  } else {
    t7 = $[37];
  }
  const t8 = userFacingToolNameBackgroundColor ? "inverseText" : undefined;
  let t9;
  if ($[38] !== t8 || $[39] !== userFacingToolName || $[40] !== userFacingToolNameBackgroundColor) {
    t9 = <Box flexShrink={0}><Text bold={true} wrap="truncate-end" backgroundColor={userFacingToolNameBackgroundColor} color={t8}>{userFacingToolName}</Text></Box>;
    $[38] = t8;
    $[39] = userFacingToolName;
    $[40] = userFacingToolNameBackgroundColor;
    $[41] = t9;
  } else {
    t9 = $[41];
  }
  let t10;
  if ($[42] !== renderedToolUseMessage) {
    t10 = renderedToolUseMessage !== "" && <Box flexWrap="nowrap"><Text>({renderedToolUseMessage})</Text></Box>;
    $[42] = renderedToolUseMessage;
    $[43] = t10;
  } else {
    t10 = $[43];
  }
  let t11;
  if ($[44] !== input_0.data || $[45] !== input_0.success || $[46] !== tool_0) {
    t11 = input_0.success && tool_0.renderToolUseTag && tool_0.renderToolUseTag(input_0.data);
    $[44] = input_0.data;
    $[45] = input_0.success;
    $[46] = tool_0;
    $[47] = t11;
  } else {
    t11 = $[47];
  }
  let t12;
  if ($[48] !== t10 || $[49] !== t11 || $[50] !== t6 || $[51] !== t7 || $[52] !== t9) {
    t12 = <Box flexDirection="row" flexWrap="nowrap" minWidth={t6}>{t7}{t9}{t10}{t11}</Box>;
    $[48] = t10;
    $[49] = t11;
    $[50] = t6;
    $[51] = t7;
    $[52] = t9;
    $[53] = t12;
  } else {
    t12 = $[53];
  }
  let t13;
  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) {
    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, {
      verbose,
      inProgressToolCallCount,
      isTranscriptMode
    }, terminalSize));
    $[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;
    $[68] = t13;
  } else {
    t13 = $[68];
  }
  let t14;
  if ($[69] !== isQueued || $[70] !== isResolved || $[71] !== tool_0) {
    t14 = !isResolved && isQueued && renderToolUseQueuedMessage(tool_0);
    $[69] = isQueued;
    $[70] = isResolved;
    $[71] = tool_0;
    $[72] = t14;
  } else {
    t14 = $[72];
  }
  let t15;
  if ($[73] !== t12 || $[74] !== t13 || $[75] !== t14) {
    t15 = <Box flexDirection="column">{t12}{t13}{t14}</Box>;
    $[73] = t12;
    $[74] = t13;
    $[75] = t14;
    $[76] = t15;
  } else {
    t15 = $[76];
  }
  let t16;
  if ($[77] !== bg || $[78] !== t15 || $[79] !== t5) {
    t16 = <Box flexDirection="row" justifyContent="space-between" marginTop={t5} width="100%" backgroundColor={bg}>{t15}</Box>;
    $[77] = bg;
    $[78] = t15;
    $[79] = t5;
    $[80] = t16;
  } else {
    t16 = $[80];
  }
  return t16;
}
function _temp3(state_1) {
  return !!state_1.toolPermissionContext.strippedDangerousRules;
}
function _temp2(state_0) {
  return state_0.toolPermissionContext.mode;
}
function _temp(state) {
  return state.pendingWorkerRequest;
}
function renderToolUseMessage(tool: Tool, input: unknown, {
  theme,
  verbose,
  commands
}: {
  theme: ThemeName;
  verbose: boolean;
  commands: Command[];
}): React.ReactNode {
  try {
    const parsed = tool.inputSchema.safeParse(input);
    if (!parsed.success) {
      return '';
    }
    return tool.renderToolUseMessage(parsed.data, {
      theme,
      verbose,
      commands
    });
  } catch (error) {
    logError(new Error(`Error rendering tool use message for ${tool.name}: ${error}`));
    return '';
  }
}
function renderToolUseProgressMessage(tool: Tool, tools: Tools, lookups: ReturnType<typeof buildMessageLookups>, toolUseID: string, progressMessagesForMessage: ProgressMessage[], {
  verbose,
  inProgressToolCallCount,
  isTranscriptMode
}: {
  verbose: boolean;
  inProgressToolCallCount?: number;
  isTranscriptMode?: boolean;
}, terminalSize: {
  columns: number;
  rows: number;
}): React.ReactNode {
  const toolProgressMessages = progressMessagesForMessage.filter((msg): msg is ProgressMessage<ToolProgressData> => msg.data.type !== 'hook_progress');
  try {
    const toolMessages = tool.renderToolUseProgressMessage?.(toolProgressMessages, {
      tools,
      verbose,
      terminalSize,
      inProgressToolCallCount: inProgressToolCallCount ?? 1,
      isTranscriptMode
    }) ?? null;
    return <>
        <SentryErrorBoundary>
          <HookProgressMessage hookEvent="PreToolUse" lookups={lookups} toolUseID={toolUseID} verbose={verbose} isTranscriptMode={isTranscriptMode} />
        </SentryErrorBoundary>
        {toolMessages}
      </>;
  } catch (error) {
    logError(new Error(`Error rendering tool use progress message for ${tool.name}: ${error}`));
    return null;
  }
}
function renderToolUseQueuedMessage(tool: Tool): React.ReactNode {
  try {
    return tool.renderToolUseQueuedMessage?.();
  } catch (error) {
    logError(new Error(`Error rendering tool use queued message for ${tool.name}: ${error}`));
    return null;
  }
}
//# 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":[]}