@townco/agent 0.1.124 → 0.1.125

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,6 +1,13 @@
1
1
  import type { z } from "zod";
2
2
  import type { AgentDefinition, McpConfigSchema } from "../definition";
3
3
  type McpConfig = z.infer<typeof McpConfigSchema>;
4
+ /** Config for a subagent to wire up via makeSubagentsTool */
5
+ export interface SubagentConfig {
6
+ agentName: string;
7
+ toolDescription: string;
8
+ displayName?: string;
9
+ path: string;
10
+ }
4
11
  export interface TemplateVars {
5
12
  name: string;
6
13
  model: string;
@@ -21,6 +28,7 @@ export interface TemplateVars {
21
28
  schema: unknown;
22
29
  }>;
23
30
  mcps?: McpConfig[];
31
+ subagents?: SubagentConfig[];
24
32
  systemPrompt: string | null;
25
33
  hasWebSearch: boolean;
26
34
  hasGenerateImage: boolean;
@@ -23,6 +23,11 @@ export function getTemplateVars(name, definition) {
23
23
  if (definition.mcps && definition.mcps.length > 0) {
24
24
  result.mcps = definition.mcps;
25
25
  }
26
+ // Handle subagents if defined (using type assertion since AgentDefinition may not have subagents yet)
27
+ const defWithSubagents = definition;
28
+ if (defWithSubagents.subagents && defWithSubagents.subagents.length > 0) {
29
+ result.subagents = defWithSubagents.subagents;
30
+ }
26
31
  return result;
27
32
  }
28
33
  export function generatePackageJson(vars) {
@@ -59,33 +64,57 @@ export function generatePackageJson(vars) {
59
64
  return JSON.stringify(pkg, null, 2);
60
65
  }
61
66
  export async function generateIndexTs(vars) {
62
- // Build agent definition with fields in a logical order
63
- const agentDef = {
64
- model: vars.model,
65
- };
67
+ const hasSubagents = vars.subagents && vars.subagents.length > 0;
68
+ let imports = 'import type { AgentDefinition } from "@townco/agent/definition";';
69
+ if (hasSubagents) {
70
+ imports += '\nimport { makeSubagentsTool } from "@townco/agent/utils";';
71
+ }
72
+ // Build tools code - either plain JSON or with makeSubagentsTool call
73
+ const toolsCode = (() => {
74
+ if (!hasSubagents) {
75
+ return JSON.stringify(vars.tools);
76
+ }
77
+ // makeSubagentsTool expects 'description' not 'toolDescription'
78
+ const subagentConfigs = vars.subagents.map((s) => ({
79
+ agentName: s.agentName,
80
+ description: s.toolDescription,
81
+ ...(s.displayName && { displayName: s.displayName }),
82
+ path: s.path,
83
+ }));
84
+ const subagentToolCall = `makeSubagentsTool(${JSON.stringify(subagentConfigs, null, 2)})`;
85
+ const toolItems = vars.tools.map((t) => JSON.stringify(t));
86
+ toolItems.push(subagentToolCall);
87
+ return `[${toolItems.join(", ")}]`;
88
+ })();
89
+ // Build optional fields
90
+ const optionalFields = [];
66
91
  if (vars.displayName) {
67
- agentDef.displayName = vars.displayName;
92
+ optionalFields.push(`displayName: ${JSON.stringify(vars.displayName)},`);
68
93
  }
69
94
  if (vars.description) {
70
- agentDef.description = vars.description;
95
+ optionalFields.push(`description: ${JSON.stringify(vars.description)},`);
71
96
  }
72
97
  if (vars.suggestedPrompts) {
73
- agentDef.suggestedPrompts = vars.suggestedPrompts;
98
+ optionalFields.push(`suggestedPrompts: ${JSON.stringify(vars.suggestedPrompts)},`);
74
99
  }
75
- agentDef.systemPrompt = vars.systemPrompt;
76
- agentDef.tools = vars.tools;
77
100
  if (vars.mcps && vars.mcps.length > 0) {
78
- agentDef.mcps = vars.mcps;
101
+ optionalFields.push(`mcps: ${JSON.stringify(vars.mcps)},`);
79
102
  }
80
103
  if (vars.hooks) {
81
- agentDef.hooks = vars.hooks;
104
+ optionalFields.push(`hooks: ${JSON.stringify(vars.hooks)},`);
82
105
  }
83
- return prettier.format(`import type { AgentDefinition } from "@townco/agent/definition";
106
+ const optionalFieldsStr = optionalFields.length > 0 ? `\n ${optionalFields.join("\n ")}` : "";
107
+ const code = `${imports}
84
108
 
85
- const agent: AgentDefinition = ${JSON.stringify(agentDef)};
109
+ const agent: AgentDefinition = {
110
+ model: ${JSON.stringify(vars.model)},${optionalFieldsStr}
111
+ systemPrompt: ${JSON.stringify(vars.systemPrompt)},
112
+ tools: ${toolsCode},
113
+ };
86
114
 
87
115
  export default agent;
88
- `, { parser: "typescript" });
116
+ `;
117
+ return prettier.format(code, { parser: "typescript" });
89
118
  }
90
119
  export function generateBinTs() {
91
120
  return `#!/usr/bin/env bun