mirror of
https://github.com/claude-code-best/claude-code.git
synced 2026-06-19 06:45:50 +00:00
* feat: 第一版大重构 * fix: 修复类型问题 * chore: 更新版本到 1.3.2 * Add brave as alternative WebSearchTool * fix: 修正顺序 * fix: 修复对穷鬼模式的 auto dream 和 session memory 越过 * feat: 穷鬼模式去除 session-summary * feat: 创建 builtin-tools 包,搬运所有工具实现 将 src/tools/ 下的全部 60 个工具目录迁移至 packages/builtin-tools/src/tools/, 内部导入路径已更新为 src/ alias 模式。 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * refactor: 更新 src/ 中所有工具引用至 builtin-tools 包,删除 src/tools/ - src/tools.ts 及 178 个 src/ 文件的 import 路径从 ./tools/ 改为 builtin-tools/tools/ - 删除 src/tools/ 整个目录(已迁移至 packages/builtin-tools/) Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * chore: 添加 builtin-tools 路径别名至 tsconfig,更新 bun.lock - tsconfig.json 新增 builtin-tools/* 和 builtin-tools 路径映射 - 新增 packages/builtin-tools/src 至 include Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * refactor: 为 builtin-tools、mcp-client、agent-tools 添加 @claude-code-best 作用域前缀 所有包名及 import 路径统一添加 @claude-code-best/ 前缀: - builtin-tools → @claude-code-best/builtin-tools - mcp-client → @claude-code-best/mcp-client - agent-tools → @claude-code-best/agent-tools Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * fix: 修复 node 环境没有 bun 的问题 --------- Co-authored-by: Eric-Guo <eric.guocz@gmail.com> Co-authored-by: Claude Opus 4.6 <noreply@anthropic.com>
113 lines
3.8 KiB
TypeScript
113 lines
3.8 KiB
TypeScript
import chalk from 'chalk'
|
|
import React, { type ReactNode, useCallback, useState } from 'react'
|
|
import {
|
|
type AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
|
|
logEvent,
|
|
} from 'src/services/analytics/index.js'
|
|
import { useSetAppState } from 'src/state/AppState.js'
|
|
import type { Tools } from '../../../../Tool.js'
|
|
import type { AgentDefinition } from '@claude-code-best/builtin-tools/tools/AgentTool/loadAgentsDir.js'
|
|
import { getActiveAgentsFromList } from '@claude-code-best/builtin-tools/tools/AgentTool/loadAgentsDir.js'
|
|
import { editFileInEditor } from '../../../../utils/promptEditor.js'
|
|
import { useWizard } from '../../../wizard/index.js'
|
|
import { getNewAgentFilePath, saveAgentToFile } from '../../agentFileUtils.js'
|
|
import type { AgentWizardData } from '../types.js'
|
|
import { ConfirmStep } from './ConfirmStep.js'
|
|
|
|
type Props = {
|
|
tools: Tools
|
|
existingAgents: AgentDefinition[]
|
|
onComplete: (message: string) => void
|
|
}
|
|
|
|
export function ConfirmStepWrapper({
|
|
tools,
|
|
existingAgents,
|
|
onComplete,
|
|
}: Props): ReactNode {
|
|
const { wizardData } = useWizard<AgentWizardData>()
|
|
const [saveError, setSaveError] = useState<string | null>(null)
|
|
const setAppState = useSetAppState()
|
|
|
|
const saveAgent = useCallback(
|
|
async (openInEditor: boolean): Promise<void> => {
|
|
if (!wizardData?.finalAgent) return
|
|
|
|
try {
|
|
await saveAgentToFile(
|
|
wizardData.location!,
|
|
wizardData.finalAgent.agentType,
|
|
wizardData.finalAgent.whenToUse,
|
|
wizardData.finalAgent.tools,
|
|
wizardData.finalAgent.getSystemPrompt(),
|
|
true,
|
|
wizardData.finalAgent.color,
|
|
wizardData.finalAgent.model,
|
|
wizardData.finalAgent.memory,
|
|
)
|
|
|
|
setAppState(state => {
|
|
if (!wizardData.finalAgent) return state
|
|
|
|
const allAgents = state.agentDefinitions.allAgents.concat(
|
|
wizardData.finalAgent,
|
|
)
|
|
return {
|
|
...state,
|
|
agentDefinitions: {
|
|
...state.agentDefinitions,
|
|
activeAgents: getActiveAgentsFromList(allAgents),
|
|
allAgents,
|
|
},
|
|
}
|
|
})
|
|
|
|
if (openInEditor) {
|
|
const filePath = getNewAgentFilePath({
|
|
source: wizardData.location!,
|
|
agentType: wizardData.finalAgent.agentType,
|
|
})
|
|
await editFileInEditor(filePath)
|
|
}
|
|
|
|
logEvent('tengu_agent_created', {
|
|
agent_type: wizardData.finalAgent.agentType,
|
|
generation_method: wizardData.wasGenerated ? 'generated' : 'manual',
|
|
source: wizardData.location!,
|
|
tool_count: wizardData.finalAgent.tools?.length ?? 'all',
|
|
has_custom_model: !!wizardData.finalAgent.model,
|
|
has_custom_color: !!wizardData.finalAgent.color,
|
|
has_memory: !!wizardData.finalAgent.memory,
|
|
memory_scope: wizardData.finalAgent.memory ?? 'none',
|
|
...(openInEditor ? { opened_in_editor: true } : {}),
|
|
} as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS)
|
|
|
|
const message = openInEditor
|
|
? `Created agent: ${chalk.bold(wizardData.finalAgent.agentType)} and opened in editor. ` +
|
|
`If you made edits, restart to load the latest version.`
|
|
: `Created agent: ${chalk.bold(wizardData.finalAgent.agentType)}`
|
|
onComplete(message)
|
|
} catch (err) {
|
|
setSaveError(
|
|
err instanceof Error ? err.message : 'Failed to save agent',
|
|
)
|
|
}
|
|
},
|
|
[wizardData, onComplete, setAppState],
|
|
)
|
|
|
|
const handleSave = useCallback(() => saveAgent(false), [saveAgent])
|
|
|
|
const handleSaveAndEdit = useCallback(() => saveAgent(true), [saveAgent])
|
|
|
|
return (
|
|
<ConfirmStep
|
|
tools={tools}
|
|
existingAgents={existingAgents}
|
|
onSave={handleSave}
|
|
onSaveAndEdit={handleSaveAndEdit}
|
|
error={saveError}
|
|
/>
|
|
)
|
|
}
|