import { c as _c } from "react/compiler-runtime"; import type { ToolResultBlockParam } from '@anthropic-ai/sdk/resources/index.mjs'; import type { StructuredPatchHunk } from 'diff'; import * as React from 'react'; import { Suspense, use, useState } from 'react'; import { FileEditToolUseRejectedMessage } from 'src/components/FileEditToolUseRejectedMessage.js'; import { MessageResponse } from 'src/components/MessageResponse.js'; import { extractTag } from 'src/utils/messages.js'; import { FallbackToolUseErrorMessage } from '../../components/FallbackToolUseErrorMessage.js'; import { FileEditToolUpdatedMessage } from '../../components/FileEditToolUpdatedMessage.js'; import { FilePathLink } from '../../components/FilePathLink.js'; import { Text } from '../../ink.js'; import type { Tools } from '../../Tool.js'; import type { Message, ProgressMessage } from '../../types/message.js'; import { adjustHunkLineNumbers, CONTEXT_LINES } from '../../utils/diff.js'; import { FILE_NOT_FOUND_CWD_NOTE, getDisplayPath } from '../../utils/file.js'; import { logError } from '../../utils/log.js'; import { getPlansDirectory } from '../../utils/plans.js'; import { readEditContext } from '../../utils/readEditContext.js'; import { firstLineOf } from '../../utils/stringUtils.js'; import type { ThemeName } from '../../utils/theme.js'; import type { FileEditOutput } from './types.js'; import { findActualString, getPatchForEdit, preserveQuoteStyle } from './utils.js'; export function userFacingName(input: Partial<{ file_path: string; old_string: string; new_string: string; replace_all: boolean; edits: unknown[]; }> | undefined): string { if (!input) { return 'Update'; } if (input.file_path?.startsWith(getPlansDirectory())) { return 'Updated plan'; } // Hashline edits always modify an existing file (line-ref based) if (input.edits != null) { return 'Update'; } if (input.old_string === '') { return 'Create'; } return 'Update'; } export function getToolUseSummary(input: Partial<{ file_path: string; old_string: string; new_string: string; replace_all: boolean; }> | undefined): string | null { if (!input?.file_path) { return null; } return getDisplayPath(input.file_path); } export function renderToolUseMessage({ file_path }: { file_path?: string; }, { verbose }: { verbose: boolean; }): React.ReactNode { if (!file_path) { return null; } // For plan files, path is already in userFacingName if (file_path.startsWith(getPlansDirectory())) { return ''; } return {verbose ? file_path : getDisplayPath(file_path)} ; } export function renderToolResultMessage({ filePath, structuredPatch, originalFile }: FileEditOutput, _progressMessagesForMessage: ProgressMessage[], { style, verbose }: { style?: 'condensed'; verbose: boolean; }): React.ReactNode { // For plan files, show /plan hint above the diff const isPlanFile = filePath.startsWith(getPlansDirectory()); return ; } export function renderToolUseRejectedMessage(input: { file_path: string; old_string?: string; new_string?: string; replace_all?: boolean; edits?: unknown[]; }, options: { columns: number; messages: Message[]; progressMessagesForMessage: ProgressMessage[]; style?: 'condensed'; theme: ThemeName; tools: Tools; verbose: boolean; }): React.ReactElement { const { style, verbose } = options; const filePath = input.file_path; const oldString = input.old_string ?? ''; const newString = input.new_string ?? ''; const replaceAll = input.replace_all ?? false; // Defensive: if input has an unexpected shape, show a simple rejection message if ('edits' in input && input.edits != null) { return ; } const isNewFile = oldString === ''; // For new file creation, show content preview instead of diff if (isNewFile) { return ; } return ; } export function renderToolUseErrorMessage(result: ToolResultBlockParam['content'], options: { progressMessagesForMessage: ProgressMessage[]; tools: Tools; verbose: boolean; }): React.ReactElement { const { verbose } = options; if (!verbose && typeof result === 'string' && extractTag(result, 'tool_use_error')) { const errorMessage = extractTag(result, 'tool_use_error'); // Show a less scary message for intended behavior if (errorMessage?.includes('File has not been read yet')) { return File must be read first ; } if (errorMessage?.includes(FILE_NOT_FOUND_CWD_NOTE)) { return File not found ; } return Error editing file ; } return ; } type RejectionDiffData = { patch: StructuredPatchHunk[]; firstLine: string | null; fileContent: string | undefined; }; function EditRejectionDiff(t0) { const $ = _c(16); const { filePath, oldString, newString, replaceAll, style, verbose } = t0; let t1; if ($[0] !== filePath || $[1] !== newString || $[2] !== oldString || $[3] !== replaceAll) { t1 = () => loadRejectionDiff(filePath, oldString, newString, replaceAll); $[0] = filePath; $[1] = newString; $[2] = oldString; $[3] = replaceAll; $[4] = t1; } else { t1 = $[4]; } const [dataPromise] = useState(t1); let t2; if ($[5] !== filePath || $[6] !== verbose) { t2 = ; $[5] = filePath; $[6] = verbose; $[7] = t2; } else { t2 = $[7]; } let t3; if ($[8] !== dataPromise || $[9] !== filePath || $[10] !== style || $[11] !== verbose) { t3 = ; $[8] = dataPromise; $[9] = filePath; $[10] = style; $[11] = verbose; $[12] = t3; } else { t3 = $[12]; } let t4; if ($[13] !== t2 || $[14] !== t3) { t4 = {t3}; $[13] = t2; $[14] = t3; $[15] = t4; } else { t4 = $[15]; } return t4; } function EditRejectionBody(t0) { const $ = _c(7); const { promise, filePath, style, verbose } = t0; const { patch, firstLine, fileContent } = use(promise); let t1; if ($[0] !== fileContent || $[1] !== filePath || $[2] !== firstLine || $[3] !== patch || $[4] !== style || $[5] !== verbose) { t1 = ; $[0] = fileContent; $[1] = filePath; $[2] = firstLine; $[3] = patch; $[4] = style; $[5] = verbose; $[6] = t1; } else { t1 = $[6]; } return t1; } async function loadRejectionDiff(filePath: string, oldString: string, newString: string, replaceAll: boolean): Promise { try { // Chunked read — context window around the first occurrence. replaceAll // still shows matches *within* the window via getPatchForEdit; we accept // losing the all-occurrences view to keep the read bounded. const ctx = await readEditContext(filePath, oldString, CONTEXT_LINES); if (ctx === null || ctx.truncated || ctx.content === '') { // ENOENT / not found / truncated — diff just the tool inputs. const { patch } = getPatchForEdit({ filePath, fileContents: oldString, oldString, newString }); return { patch, firstLine: null, fileContent: undefined }; } const actualOld = findActualString(ctx.content, oldString) || oldString; const actualNew = preserveQuoteStyle(oldString, actualOld, newString); const { patch } = getPatchForEdit({ filePath, fileContents: ctx.content, oldString: actualOld, newString: actualNew, replaceAll }); return { patch: adjustHunkLineNumbers(patch, ctx.lineOffset - 1), firstLine: ctx.lineOffset === 1 ? firstLineOf(ctx.content) : null, fileContent: ctx.content }; } catch (e) { // User may have manually applied the change while the diff was shown. logError(e as Error); return { patch: [], firstLine: null, fileContent: undefined }; } } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["ToolResultBlockParam","StructuredPatchHunk","React","Suspense","use","useState","FileEditToolUseRejectedMessage","MessageResponse","extractTag","FallbackToolUseErrorMessage","FileEditToolUpdatedMessage","FilePathLink","Text","Tools","Message","ProgressMessage","adjustHunkLineNumbers","CONTEXT_LINES","FILE_NOT_FOUND_CWD_NOTE","getDisplayPath","logError","getPlansDirectory","readEditContext","firstLineOf","ThemeName","FileEditOutput","findActualString","getPatchForEdit","preserveQuoteStyle","userFacingName","input","Partial","file_path","old_string","new_string","replace_all","edits","startsWith","getToolUseSummary","renderToolUseMessage","verbose","ReactNode","renderToolResultMessage","filePath","structuredPatch","originalFile","_progressMessagesForMessage","style","isPlanFile","split","undefined","renderToolUseRejectedMessage","options","columns","messages","progressMessagesForMessage","theme","tools","ReactElement","oldString","newString","replaceAll","isNewFile","renderToolUseErrorMessage","result","errorMessage","includes","RejectionDiffData","patch","firstLine","fileContent","EditRejectionDiff","t0","$","_c","t1","loadRejectionDiff","dataPromise","t2","t3","t4","EditRejectionBody","promise","Promise","ctx","truncated","content","fileContents","actualOld","actualNew","lineOffset","e","Error"],"sources":["UI.tsx"],"sourcesContent":["import type { ToolResultBlockParam } from '@anthropic-ai/sdk/resources/index.mjs'\nimport type { StructuredPatchHunk } from 'diff'\nimport * as React from 'react'\nimport { Suspense, use, useState } from 'react'\nimport { FileEditToolUseRejectedMessage } from 'src/components/FileEditToolUseRejectedMessage.js'\nimport { MessageResponse } from 'src/components/MessageResponse.js'\nimport { extractTag } from 'src/utils/messages.js'\nimport { FallbackToolUseErrorMessage } from '../../components/FallbackToolUseErrorMessage.js'\nimport { FileEditToolUpdatedMessage } from '../../components/FileEditToolUpdatedMessage.js'\nimport { FilePathLink } from '../../components/FilePathLink.js'\nimport { Text } from '../../ink.js'\nimport type { Tools } from '../../Tool.js'\nimport type { Message, ProgressMessage } from '../../types/message.js'\nimport { adjustHunkLineNumbers, CONTEXT_LINES } from '../../utils/diff.js'\nimport { FILE_NOT_FOUND_CWD_NOTE, getDisplayPath } from '../../utils/file.js'\nimport { logError } from '../../utils/log.js'\nimport { getPlansDirectory } from '../../utils/plans.js'\nimport { readEditContext } from '../../utils/readEditContext.js'\nimport { firstLineOf } from '../../utils/stringUtils.js'\nimport type { ThemeName } from '../../utils/theme.js'\nimport type { FileEditOutput } from './types.js'\nimport {\n  findActualString,\n  getPatchForEdit,\n  preserveQuoteStyle,\n} from './utils.js'\n\nexport function userFacingName(\n  input:\n    | Partial<{\n        file_path: string\n        old_string: string\n        new_string: string\n        replace_all: boolean\n        edits: unknown[]\n      }>\n    | undefined,\n): string {\n  if (!input) {\n    return 'Update'\n  }\n  if (input.file_path?.startsWith(getPlansDirectory())) {\n    return 'Updated plan'\n  }\n  // Hashline edits always modify an existing file (line-ref based)\n  if (input.edits != null) {\n    return 'Update'\n  }\n  if (input.old_string === '') {\n    return 'Create'\n  }\n  return 'Update'\n}\n\nexport function getToolUseSummary(\n  input:\n    | Partial<{\n        file_path: string\n        old_string: string\n        new_string: string\n        replace_all: boolean\n      }>\n    | undefined,\n): string | null {\n  if (!input?.file_path) {\n    return null\n  }\n  return getDisplayPath(input.file_path)\n}\n\nexport function renderToolUseMessage(\n  { file_path }: { file_path?: string },\n  { verbose }: { verbose: boolean },\n): React.ReactNode {\n  if (!file_path) {\n    return null\n  }\n  // For plan files, path is already in userFacingName\n  if (file_path.startsWith(getPlansDirectory())) {\n    return ''\n  }\n  return (\n    <FilePathLink filePath={file_path}>\n      {verbose ? file_path : getDisplayPath(file_path)}\n    </FilePathLink>\n  )\n}\n\nexport function renderToolResultMessage(\n  { filePath, structuredPatch, originalFile }: FileEditOutput,\n  _progressMessagesForMessage: ProgressMessage[],\n  { style, verbose }: { style?: 'condensed'; verbose: boolean },\n): React.ReactNode {\n  // For plan files, show /plan hint above the diff\n  const isPlanFile = filePath.startsWith(getPlansDirectory())\n\n  return (\n    <FileEditToolUpdatedMessage\n      filePath={filePath}\n      structuredPatch={structuredPatch}\n      firstLine={originalFile.split('\\n')[0] ?? null}\n      fileContent={originalFile}\n      style={style}\n      verbose={verbose}\n      previewHint={isPlanFile ? '/plan to preview' : undefined}\n    />\n  )\n}\n\nexport function renderToolUseRejectedMessage(\n  input: {\n    file_path: string\n    old_string?: string\n    new_string?: string\n    replace_all?: boolean\n    edits?: unknown[]\n  },\n  options: {\n    columns: number\n    messages: Message[]\n    progressMessagesForMessage: ProgressMessage[]\n    style?: 'condensed'\n    theme: ThemeName\n    tools: Tools\n    verbose: boolean\n  },\n): React.ReactElement {\n  const { style, verbose } = options\n  const filePath = input.file_path\n  const oldString = input.old_string ?? ''\n  const newString = input.new_string ?? ''\n  const replaceAll = input.replace_all ?? false\n\n  // Defensive: if input has an unexpected shape, show a simple rejection message\n  if ('edits' in input && input.edits != null) {\n    return (\n      <FileEditToolUseRejectedMessage\n        file_path={filePath}\n        operation=\"update\"\n        firstLine={null}\n        verbose={verbose}\n      />\n    )\n  }\n\n  const isNewFile = oldString === ''\n\n  // For new file creation, show content preview instead of diff\n  if (isNewFile) {\n    return (\n      <FileEditToolUseRejectedMessage\n        file_path={filePath}\n        operation=\"write\"\n        content={newString}\n        firstLine={firstLineOf(newString)}\n        verbose={verbose}\n      />\n    )\n  }\n\n  return (\n    <EditRejectionDiff\n      filePath={filePath}\n      oldString={oldString}\n      newString={newString}\n      replaceAll={replaceAll}\n      style={style}\n      verbose={verbose}\n    />\n  )\n}\n\nexport function renderToolUseErrorMessage(\n  result: ToolResultBlockParam['content'],\n  options: {\n    progressMessagesForMessage: ProgressMessage[]\n    tools: Tools\n    verbose: boolean\n  },\n): React.ReactElement {\n  const { verbose } = options\n  if (\n    !verbose &&\n    typeof result === 'string' &&\n    extractTag(result, 'tool_use_error')\n  ) {\n    const errorMessage = extractTag(result, 'tool_use_error')\n    // Show a less scary message for intended behavior\n    if (errorMessage?.includes('File has not been read yet')) {\n      return (\n        <MessageResponse>\n          <Text dimColor>File must be read first</Text>\n        </MessageResponse>\n      )\n    }\n    if (errorMessage?.includes(FILE_NOT_FOUND_CWD_NOTE)) {\n      return (\n        <MessageResponse>\n          <Text color=\"error\">File not found</Text>\n        </MessageResponse>\n      )\n    }\n    return (\n      <MessageResponse>\n        <Text color=\"error\">Error editing file</Text>\n      </MessageResponse>\n    )\n  }\n  return <FallbackToolUseErrorMessage result={result} verbose={verbose} />\n}\n\ntype RejectionDiffData = {\n  patch: StructuredPatchHunk[]\n  firstLine: string | null\n  fileContent: string | undefined\n}\n\nfunction EditRejectionDiff({\n  filePath,\n  oldString,\n  newString,\n  replaceAll,\n  style,\n  verbose,\n}: {\n  filePath: string\n  oldString: string\n  newString: string\n  replaceAll: boolean\n  style?: 'condensed'\n  verbose: boolean\n}): React.ReactNode {\n  const [dataPromise] = useState(() =>\n    loadRejectionDiff(filePath, oldString, newString, replaceAll),\n  )\n  return (\n    <Suspense\n      fallback={\n        <FileEditToolUseRejectedMessage\n          file_path={filePath}\n          operation=\"update\"\n          firstLine={null}\n          verbose={verbose}\n        />\n      }\n    >\n      <EditRejectionBody\n        promise={dataPromise}\n        filePath={filePath}\n        style={style}\n        verbose={verbose}\n      />\n    </Suspense>\n  )\n}\n\nfunction EditRejectionBody({\n  promise,\n  filePath,\n  style,\n  verbose,\n}: {\n  promise: Promise<RejectionDiffData>\n  filePath: string\n  style?: 'condensed'\n  verbose: boolean\n}): React.ReactNode {\n  const { patch, firstLine, fileContent } = use(promise)\n  return (\n    <FileEditToolUseRejectedMessage\n      file_path={filePath}\n      operation=\"update\"\n      patch={patch}\n      firstLine={firstLine}\n      fileContent={fileContent}\n      style={style}\n      verbose={verbose}\n    />\n  )\n}\n\nasync function loadRejectionDiff(\n  filePath: string,\n  oldString: string,\n  newString: string,\n  replaceAll: boolean,\n): Promise<RejectionDiffData> {\n  try {\n    // Chunked read — context window around the first occurrence. replaceAll\n    // still shows matches *within* the window via getPatchForEdit; we accept\n    // losing the all-occurrences view to keep the read bounded.\n    const ctx = await readEditContext(filePath, oldString, CONTEXT_LINES)\n    if (ctx === null || ctx.truncated || ctx.content === '') {\n      // ENOENT / not found / truncated — diff just the tool inputs.\n      const { patch } = getPatchForEdit({\n        filePath,\n        fileContents: oldString,\n        oldString,\n        newString,\n      })\n      return { patch, firstLine: null, fileContent: undefined }\n    }\n    const actualOld = findActualString(ctx.content, oldString) || oldString\n    const actualNew = preserveQuoteStyle(oldString, actualOld, newString)\n    const { patch } = getPatchForEdit({\n      filePath,\n      fileContents: ctx.content,\n      oldString: actualOld,\n      newString: actualNew,\n      replaceAll,\n    })\n    return {\n      patch: adjustHunkLineNumbers(patch, ctx.lineOffset - 1),\n      firstLine: ctx.lineOffset === 1 ? firstLineOf(ctx.content) : null,\n      fileContent: ctx.content,\n    }\n  } catch (e) {\n    // User may have manually applied the change while the diff was shown.\n    logError(e as Error)\n    return { patch: [], firstLine: null, fileContent: undefined }\n  }\n}\n"],"mappings":"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","ignoreList":[]}