mirror of
https://github.com/claude-code-best/claude-code.git
synced 2026-06-17 13:55:50 +00:00
* style(B1-1): 格式化 ink/buddy/cli/context/screens/tasks/services/keybindings/state (43 files) 纯格式化:移除分号、React Compiler import、import 多行展开。 修复了 Box.tsx 和 ScrollBox.tsx 中无效的 global.d.ts import。 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * style(B1-2): 格式化 commands (79 files) 纯格式化:移除分号、React Compiler import、import 多行展开。 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * style(B1-3): 格式化 components/messages,permissions,mcp,sandbox,shell (104 files) 纯格式化:移除分号、React Compiler import、import 多行展开。 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * style(B1-4): 格式化 components/PromptInput,FeedbackSurvey,tasks,agents,skills,design-system,wizard (73 files) 纯格式化:移除分号、React Compiler import、import 多行展开。 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * style(B1-5): 格式化 components其余 + hooks + tools (232 files) 纯格式化:移除分号、React Compiler import、import 多行展开。 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * style(B1-6): 格式化 main/entrypoints/utils/moreright (21 files) 纯格式化:移除分号、React Compiler import、import 多行展开。 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * docs: 更新 README,新增 Run.ps1/TODO.md,删除 V6.md - README.md: 大幅重写,更详细版本历史和配置示例 - Run.ps1: 新增 Windows 启动脚本 - TODO.md: 新增包完成清单 - V6.md: 删除(架构重构规划已不适用) Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * fix: 修复以前的问题 * fix: 修复 login 面板的问题 --------- Co-authored-by: Claude Opus 4.6 <noreply@anthropic.com>
102 lines
2.6 KiB
TypeScript
102 lines
2.6 KiB
TypeScript
import type { ToolResultBlockParam } from '@anthropic-ai/sdk/resources/index.mjs'
|
|
import * as React from 'react'
|
|
import type { Tools } from '../../../Tool.js'
|
|
import type {
|
|
NormalizedUserMessage,
|
|
ProgressMessage,
|
|
} from '../../../types/message.js'
|
|
import {
|
|
type buildMessageLookups,
|
|
CANCEL_MESSAGE,
|
|
INTERRUPT_MESSAGE_FOR_TOOL_USE,
|
|
REJECT_MESSAGE,
|
|
} from '../../../utils/messages.js'
|
|
import { UserToolCanceledMessage } from './UserToolCanceledMessage.js'
|
|
import { UserToolErrorMessage } from './UserToolErrorMessage.js'
|
|
import { UserToolRejectMessage } from './UserToolRejectMessage.js'
|
|
import { UserToolSuccessMessage } from './UserToolSuccessMessage.js'
|
|
import { useGetToolFromMessages } from './utils.js'
|
|
|
|
type Props = {
|
|
param: ToolResultBlockParam
|
|
message: NormalizedUserMessage
|
|
lookups: ReturnType<typeof buildMessageLookups>
|
|
progressMessagesForMessage: ProgressMessage[]
|
|
style?: 'condensed'
|
|
tools: Tools
|
|
verbose: boolean
|
|
width: number | string
|
|
isTranscriptMode?: boolean
|
|
}
|
|
|
|
export function UserToolResultMessage({
|
|
param,
|
|
message,
|
|
lookups,
|
|
progressMessagesForMessage,
|
|
style,
|
|
tools,
|
|
verbose,
|
|
width,
|
|
isTranscriptMode,
|
|
}: Props): React.ReactNode {
|
|
const toolUse = useGetToolFromMessages(param.tool_use_id, tools, lookups)
|
|
if (!toolUse) {
|
|
return null
|
|
}
|
|
|
|
if (
|
|
typeof param.content === 'string' &&
|
|
param.content.startsWith(CANCEL_MESSAGE)
|
|
) {
|
|
return <UserToolCanceledMessage />
|
|
}
|
|
|
|
if (
|
|
(typeof param.content === 'string' &&
|
|
param.content.startsWith(REJECT_MESSAGE)) ||
|
|
param.content === INTERRUPT_MESSAGE_FOR_TOOL_USE
|
|
) {
|
|
return (
|
|
<UserToolRejectMessage
|
|
input={toolUse.toolUse.input as { [key: string]: unknown }}
|
|
progressMessagesForMessage={progressMessagesForMessage}
|
|
tool={toolUse.tool}
|
|
tools={tools}
|
|
lookups={lookups}
|
|
style={style}
|
|
verbose={verbose}
|
|
isTranscriptMode={isTranscriptMode}
|
|
/>
|
|
)
|
|
}
|
|
|
|
if (param.is_error) {
|
|
return (
|
|
<UserToolErrorMessage
|
|
progressMessagesForMessage={progressMessagesForMessage}
|
|
tool={toolUse.tool}
|
|
tools={tools}
|
|
param={param}
|
|
verbose={verbose}
|
|
isTranscriptMode={isTranscriptMode}
|
|
/>
|
|
)
|
|
}
|
|
|
|
return (
|
|
<UserToolSuccessMessage
|
|
message={message}
|
|
lookups={lookups}
|
|
toolUseID={toolUse.toolUse.id}
|
|
progressMessagesForMessage={progressMessagesForMessage}
|
|
style={style}
|
|
tool={toolUse.tool}
|
|
tools={tools}
|
|
verbose={verbose}
|
|
width={width}
|
|
isTranscriptMode={isTranscriptMode}
|
|
/>
|
|
)
|
|
}
|