π File detail
components/agents/new-agent-creation/wizard-steps/ConfirmStepWrapper.tsx
π― Use case
This file lives under βcomponents/β, which covers shared React UI pieces. On the API surface it exposes ConfirmStepWrapper β mainly types, interfaces, or factory objects. Dependencies touch terminal styling, React UI, and src. It composes internal code from Tool, tools, utils, wizard, and agentFileUtils (relative imports).
Generated from folder role, exports, dependency roots, and inline comments β not hand-reviewed for every path.
π§ Inline summary
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';
π€ Exports (heuristic)
ConfirmStepWrapper
π External import roots
Package roots from from "β¦" (relative paths omitted).
chalkreactsrc
π₯οΈ Source preview
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;
};
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} />;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["chalk","React","ReactNode","useCallback","useState","AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS","logEvent","useSetAppState","Tools","AgentDefinition","getActiveAgentsFromList","editFileInEditor","useWizard","getNewAgentFilePath","saveAgentToFile","AgentWizardData","ConfirmStep","Props","tools","existingAgents","onComplete","message","ConfirmStepWrapper","wizardData","saveError","setSaveError","setAppState","saveAgent","openInEditor","Promise","finalAgent","location","agentType","whenToUse","getSystemPrompt","color","model","memory","state","allAgents","agentDefinitions","concat","activeAgents","filePath","source","agent_type","generation_method","wasGenerated","tool_count","length","has_custom_model","has_custom_color","has_memory","memory_scope","opened_in_editor","bold","err","Error","handleSave","handleSaveAndEdit"],"sources":["ConfirmStepWrapper.tsx"],"sourcesContent":["import chalk from 'chalk'\nimport React, { type ReactNode, useCallback, useState } from 'react'\nimport {\n  type AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n  logEvent,\n} from 'src/services/analytics/index.js'\nimport { useSetAppState } from 'src/state/AppState.js'\nimport type { Tools } from '../../../../Tool.js'\nimport type { AgentDefinition } from '../../../../tools/AgentTool/loadAgentsDir.js'\nimport { getActiveAgentsFromList } from '../../../../tools/AgentTool/loadAgentsDir.js'\nimport { editFileInEditor } from '../../../../utils/promptEditor.js'\nimport { useWizard } from '../../../wizard/index.js'\nimport { getNewAgentFilePath, saveAgentToFile } from '../../agentFileUtils.js'\nimport type { AgentWizardData } from '../types.js'\nimport { ConfirmStep } from './ConfirmStep.js'\n\ntype Props = {\n  tools: Tools\n  existingAgents: AgentDefinition[]\n  onComplete: (message: string) => void\n}\n\nexport function ConfirmStepWrapper({\n  tools,\n  existingAgents,\n  onComplete,\n}: Props): ReactNode {\n  const { wizardData } = useWizard<AgentWizardData>()\n  const [saveError, setSaveError] = useState<string | null>(null)\n  const setAppState = useSetAppState()\n\n  const saveAgent = useCallback(\n    async (openInEditor: boolean): Promise<void> => {\n      if (!wizardData?.finalAgent) return\n\n      try {\n        await saveAgentToFile(\n          wizardData.location!,\n          wizardData.finalAgent.agentType,\n          wizardData.finalAgent.whenToUse,\n          wizardData.finalAgent.tools,\n          wizardData.finalAgent.getSystemPrompt(),\n          true,\n          wizardData.finalAgent.color,\n          wizardData.finalAgent.model,\n          wizardData.finalAgent.memory,\n        )\n\n        setAppState(state => {\n          if (!wizardData.finalAgent) return state\n\n          const allAgents = state.agentDefinitions.allAgents.concat(\n            wizardData.finalAgent,\n          )\n          return {\n            ...state,\n            agentDefinitions: {\n              ...state.agentDefinitions,\n              activeAgents: getActiveAgentsFromList(allAgents),\n              allAgents,\n            },\n          }\n        })\n\n        if (openInEditor) {\n          const filePath = getNewAgentFilePath({\n            source: wizardData.location!,\n            agentType: wizardData.finalAgent.agentType,\n          })\n          await editFileInEditor(filePath)\n        }\n\n        logEvent('tengu_agent_created', {\n          agent_type: wizardData.finalAgent.agentType,\n          generation_method: wizardData.wasGenerated ? 'generated' : 'manual',\n          source: wizardData.location!,\n          tool_count: wizardData.finalAgent.tools?.length ?? 'all',\n          has_custom_model: !!wizardData.finalAgent.model,\n          has_custom_color: !!wizardData.finalAgent.color,\n          has_memory: !!wizardData.finalAgent.memory,\n          memory_scope: wizardData.finalAgent.memory ?? 'none',\n          ...(openInEditor ? { opened_in_editor: true } : {}),\n        } as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS)\n\n        const message = openInEditor\n          ? `Created agent: ${chalk.bold(wizardData.finalAgent.agentType)} and opened in editor. ` +\n            `If you made edits, restart to load the latest version.`\n          : `Created agent: ${chalk.bold(wizardData.finalAgent.agentType)}`\n        onComplete(message)\n      } catch (err) {\n        setSaveError(\n          err instanceof Error ? err.message : 'Failed to save agent',\n        )\n      }\n    },\n    [wizardData, onComplete, setAppState],\n  )\n\n  const handleSave = useCallback(() => saveAgent(false), [saveAgent])\n\n  const handleSaveAndEdit = useCallback(() => saveAgent(true), [saveAgent])\n\n  return (\n    <ConfirmStep\n      tools={tools}\n      existingAgents={existingAgents}\n      onSave={handleSave}\n      onSaveAndEdit={handleSaveAndEdit}\n      error={saveError}\n    />\n  )\n}\n"],"mappings":"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","ignoreList":[]}