mirror of
https://github.com/claude-code-best/claude-code.git
synced 2026-06-22 16:25:51 +00:00
更新大量 tsx 原始文件; 已经迁移 login panel; 部分 (#121)
* 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>
This commit is contained in:
@@ -1,73 +1,112 @@
|
||||
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 '../../../../tools/AgentTool/loadAgentsDir.js';
|
||||
import { getActiveAgentsFromList } from '../../../../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';
|
||||
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 '../../../../tools/AgentTool/loadAgentsDir.js'
|
||||
import { getActiveAgentsFromList } from '../../../../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;
|
||||
};
|
||||
tools: Tools
|
||||
existingAgents: AgentDefinition[]
|
||||
onComplete: (message: string) => void
|
||||
}
|
||||
|
||||
export function ConfirmStepWrapper({
|
||||
tools,
|
||||
existingAgents,
|
||||
onComplete
|
||||
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
|
||||
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({
|
||||
})
|
||||
|
||||
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!,
|
||||
agentType: wizardData.finalAgent.agentType
|
||||
});
|
||||
await editFileInEditor(filePath);
|
||||
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',
|
||||
)
|
||||
}
|
||||
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} />;
|
||||
},
|
||||
[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}
|
||||
/>
|
||||
)
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user