@copilotkitnext/angular 0.0.19 → 0.0.20
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.
- package/dist/esm2022/lib/copilotkit.mjs +7 -16
- package/dist/esm2022/lib/render-tool-calls.mjs +23 -4
- package/dist/esm2022/lib/tools.mjs +1 -1
- package/dist/fesm2022/copilotkitnext-angular.mjs +27 -17
- package/dist/fesm2022/copilotkitnext-angular.mjs.map +1 -1
- package/dist/lib/tools.d.ts +5 -3
- package/package.json +3 -3
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { CopilotKitCore } from "@copilotkitnext/core";
|
|
2
|
-
import { Injectable, Injector, runInInjectionContext, signal, inject
|
|
2
|
+
import { Injectable, Injector, runInInjectionContext, signal, inject } from "@angular/core";
|
|
3
3
|
import { injectCopilotKitConfig } from "./config";
|
|
4
4
|
import { HumanInTheLoop } from "./human-in-the-loop";
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
@@ -58,10 +58,7 @@ export class CopilotKit {
|
|
|
58
58
|
addFrontendTool(clientToolWithInjector) {
|
|
59
59
|
const tool = this.#bindClientTool(clientToolWithInjector);
|
|
60
60
|
this.core.addTool(tool);
|
|
61
|
-
this.#clientToolCallRenderConfigs.update((current) => [
|
|
62
|
-
...current,
|
|
63
|
-
clientToolWithInjector,
|
|
64
|
-
]);
|
|
61
|
+
this.#clientToolCallRenderConfigs.update((current) => [...current, clientToolWithInjector]);
|
|
65
62
|
}
|
|
66
63
|
addRenderToolCall(renderConfig) {
|
|
67
64
|
this.#toolCallRenderConfigs.update((current) => [...current, renderConfig]);
|
|
@@ -75,10 +72,7 @@ export class CopilotKit {
|
|
|
75
72
|
};
|
|
76
73
|
}
|
|
77
74
|
addHumanInTheLoop(humanInTheLoopTool) {
|
|
78
|
-
this.#humanInTheLoopToolRenderConfigs.update((current) => [
|
|
79
|
-
...current,
|
|
80
|
-
humanInTheLoopTool,
|
|
81
|
-
]);
|
|
75
|
+
this.#humanInTheLoopToolRenderConfigs.update((current) => [...current, humanInTheLoopTool]);
|
|
82
76
|
const tool = this.#bindHumanInTheLoopTool(humanInTheLoopTool);
|
|
83
77
|
this.core.addTool(tool);
|
|
84
78
|
}
|
|
@@ -90,12 +84,9 @@ export class CopilotKit {
|
|
|
90
84
|
}
|
|
91
85
|
removeTool(toolName, agentId) {
|
|
92
86
|
this.core.removeTool(toolName);
|
|
93
|
-
this.#clientToolCallRenderConfigs.update((current) => current.filter((renderConfig) => renderConfig.name !== toolName &&
|
|
94
|
-
|
|
95
|
-
this.#
|
|
96
|
-
this.#isSameAgentId(renderConfig, agentId)));
|
|
97
|
-
this.#toolCallRenderConfigs.update((current) => current.filter((renderConfig) => renderConfig.name !== toolName &&
|
|
98
|
-
this.#isSameAgentId(renderConfig, agentId)));
|
|
87
|
+
this.#clientToolCallRenderConfigs.update((current) => current.filter((renderConfig) => renderConfig.name !== toolName && this.#isSameAgentId(renderConfig, agentId)));
|
|
88
|
+
this.#humanInTheLoopToolRenderConfigs.update((current) => current.filter((renderConfig) => renderConfig.name !== toolName && this.#isSameAgentId(renderConfig, agentId)));
|
|
89
|
+
this.#toolCallRenderConfigs.update((current) => current.filter((renderConfig) => renderConfig.name !== toolName && this.#isSameAgentId(renderConfig, agentId)));
|
|
99
90
|
}
|
|
100
91
|
getAgent(agentId) {
|
|
101
92
|
return this.core.getAgent(agentId);
|
|
@@ -121,4 +112,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
121
112
|
type: Injectable,
|
|
122
113
|
args: [{ providedIn: "root" }]
|
|
123
114
|
}], ctorParameters: () => [] });
|
|
124
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"copilotkit.js","sourceRoot":"","sources":["../../../src/lib/copilotkit.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractAgent } from \"@ag-ui/client\";\nimport { FrontendTool, CopilotKitCore } from \"@copilotkitnext/core\";\nimport {\n  Injectable,\n  Injector,\n  Signal,\n  WritableSignal,\n  runInInjectionContext,\n  signal,\n  inject,\n} from \"@angular/core\";\nimport {\n  FrontendToolConfig,\n  HumanInTheLoopConfig,\n  RenderToolCallConfig,\n} from \"./tools\";\nimport { injectCopilotKitConfig } from \"./config\";\nimport { HumanInTheLoop } from \"./human-in-the-loop\";\n\n@Injectable({ providedIn: \"root\" })\nexport class CopilotKit {\n  readonly #config = injectCopilotKitConfig();\n  readonly #hitl = inject(HumanInTheLoop);\n  readonly #rootInjector = inject(Injector);\n  readonly #agents = signal<Record<string, AbstractAgent>>(\n    this.#config.agents ?? {}\n  );\n  readonly agents = this.#agents.asReadonly();\n\n  readonly core = new CopilotKitCore({\n    runtimeUrl: this.#config.runtimeUrl,\n    headers: this.#config.headers,\n    properties: this.#config.properties,\n    agents__unsafe_dev_only: this.#config.agents,\n    tools: this.#config.tools,\n  });\n\n  readonly #toolCallRenderConfigs: WritableSignal<RenderToolCallConfig[]> =\n    signal([]);\n  readonly #clientToolCallRenderConfigs: WritableSignal<FrontendToolConfig[]> =\n    signal([]);\n  readonly #humanInTheLoopToolRenderConfigs: WritableSignal<\n    HumanInTheLoopConfig[]\n  > = signal([]);\n\n  readonly toolCallRenderConfigs: Signal<RenderToolCallConfig[]> =\n    this.#toolCallRenderConfigs.asReadonly();\n  readonly clientToolCallRenderConfigs: Signal<FrontendToolConfig[]> =\n    this.#clientToolCallRenderConfigs.asReadonly();\n  readonly humanInTheLoopToolRenderConfigs: Signal<HumanInTheLoopConfig[]> =\n    this.#humanInTheLoopToolRenderConfigs.asReadonly();\n\n  constructor() {\n    this.#config.renderToolCalls?.forEach((renderConfig) => {\n      this.addRenderToolCall(renderConfig);\n    });\n\n    this.#config.tools?.forEach((tool) => {\n      if (tool.renderer && tool.parameters) {\n        this.addRenderToolCall({\n          name: tool.name,\n          args: tool.parameters,\n          component: tool.renderer,\n          agentId: tool.agentId,\n        });\n      }\n    });\n\n    this.#config.frontendTools?.forEach((clientTool) => {\n      this.addFrontendTool({ ...clientTool, injector: this.#rootInjector });\n    });\n\n    this.#config.humanInTheLoop?.forEach((humanInTheLoopTool) => {\n      this.addHumanInTheLoop(humanInTheLoopTool);\n    });\n\n    this.core.subscribe({\n      onAgentsChanged: () => {\n        this.#agents.set(this.core.agents);\n      },\n    });\n  }\n\n  #bindClientTool(\n    clientToolWithInjector: FrontendToolConfig & {\n      injector: Injector;\n    }\n  ): FrontendTool {\n    const { injector, handler, ...frontendCandidate } = clientToolWithInjector;\n\n    return {\n      ...frontendCandidate,\n      handler: (args) => runInInjectionContext(injector, () => handler(args)),\n    };\n  }\n\n  addFrontendTool(\n    clientToolWithInjector: FrontendToolConfig & {\n      injector: Injector;\n    }\n  ): void {\n    const tool = this.#bindClientTool(clientToolWithInjector);\n\n    this.core.addTool(tool);\n\n    this.#clientToolCallRenderConfigs.update((current) => [\n      ...current,\n      clientToolWithInjector,\n    ]);\n  }\n\n  addRenderToolCall(renderConfig: RenderToolCallConfig): void {\n    this.#toolCallRenderConfigs.update((current) => [...current, renderConfig]);\n  }\n\n  #bindHumanInTheLoopTool(\n    humanInTheLoopTool: HumanInTheLoopConfig\n  ): FrontendTool {\n    return {\n      ...humanInTheLoopTool,\n      handler: (args, toolCall) => {\n        return this.#hitl.onResult(toolCall.id, humanInTheLoopTool.name);\n      },\n    };\n  }\n\n  addHumanInTheLoop(humanInTheLoopTool: HumanInTheLoopConfig): void {\n    this.#humanInTheLoopToolRenderConfigs.update((current) => [\n      ...current,\n      humanInTheLoopTool,\n    ]);\n\n    const tool = this.#bindHumanInTheLoopTool(humanInTheLoopTool);\n\n    this.core.addTool(tool);\n  }\n\n  #isSameAgentId<T extends { agentId?: string }>(\n    target: T,\n    agentId?: string\n  ): boolean {\n    if (agentId) {\n      return target.agentId === agentId;\n    }\n\n    return true;\n  }\n\n  removeTool(toolName: string, agentId?: string): void {\n    this.core.removeTool(toolName);\n    this.#clientToolCallRenderConfigs.update((current) =>\n      current.filter(\n        (renderConfig) =>\n          renderConfig.name !== toolName &&\n          this.#isSameAgentId(renderConfig, agentId)\n      )\n    );\n    this.#humanInTheLoopToolRenderConfigs.update((current) =>\n      current.filter(\n        (renderConfig) =>\n          renderConfig.name !== toolName &&\n          this.#isSameAgentId(renderConfig, agentId)\n      )\n    );\n    this.#toolCallRenderConfigs.update((current) =>\n      current.filter(\n        (renderConfig) =>\n          renderConfig.name !== toolName &&\n          this.#isSameAgentId(renderConfig, agentId)\n      )\n    );\n  }\n\n  getAgent(agentId: string): AbstractAgent | undefined {\n    return this.core.getAgent(agentId);\n  }\n\n  updateRuntime(options: {\n    runtimeUrl?: string;\n    headers?: Record<string, string>;\n    properties?: Record<string, unknown>;\n    agents?: Record<string, AbstractAgent>;\n  }): void {\n    if (options.runtimeUrl !== undefined) {\n      this.core.setRuntimeUrl(options.runtimeUrl);\n    }\n    if (options.headers !== undefined) {\n      this.core.setHeaders(options.headers);\n    }\n    if (options.properties !== undefined) {\n      this.core.setProperties(options.properties);\n    }\n    if (options.agents !== undefined) {\n      this.core.setAgents__unsafe_dev_only(options.agents);\n    }\n  }\n}\n"]}
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"copilotkit.js","sourceRoot":"","sources":["../../../src/lib/copilotkit.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractAgent } from \"@ag-ui/client\";\nimport { FrontendTool, CopilotKitCore } from \"@copilotkitnext/core\";\nimport { Injectable, Injector, Signal, WritableSignal, runInInjectionContext, signal, inject } from \"@angular/core\";\nimport { FrontendToolConfig, HumanInTheLoopConfig, RenderToolCallConfig } from \"./tools\";\nimport { injectCopilotKitConfig } from \"./config\";\nimport { HumanInTheLoop } from \"./human-in-the-loop\";\n\n@Injectable({ providedIn: \"root\" })\nexport class CopilotKit {\n  readonly #config = injectCopilotKitConfig();\n  readonly #hitl = inject(HumanInTheLoop);\n  readonly #rootInjector = inject(Injector);\n  readonly #agents = signal<Record<string, AbstractAgent>>(this.#config.agents ?? {});\n  readonly agents = this.#agents.asReadonly();\n\n  readonly core = new CopilotKitCore({\n    runtimeUrl: this.#config.runtimeUrl,\n    headers: this.#config.headers,\n    properties: this.#config.properties,\n    agents__unsafe_dev_only: this.#config.agents,\n    tools: this.#config.tools,\n  });\n\n  readonly #toolCallRenderConfigs: WritableSignal<RenderToolCallConfig[]> = signal([]);\n  readonly #clientToolCallRenderConfigs: WritableSignal<FrontendToolConfig[]> = signal([]);\n  readonly #humanInTheLoopToolRenderConfigs: WritableSignal<HumanInTheLoopConfig[]> = signal([]);\n\n  readonly toolCallRenderConfigs: Signal<RenderToolCallConfig[]> = this.#toolCallRenderConfigs.asReadonly();\n  readonly clientToolCallRenderConfigs: Signal<FrontendToolConfig[]> = this.#clientToolCallRenderConfigs.asReadonly();\n  readonly humanInTheLoopToolRenderConfigs: Signal<HumanInTheLoopConfig[]> =\n    this.#humanInTheLoopToolRenderConfigs.asReadonly();\n\n  constructor() {\n    this.#config.renderToolCalls?.forEach((renderConfig) => {\n      this.addRenderToolCall(renderConfig);\n    });\n\n    this.#config.tools?.forEach((tool) => {\n      if (tool.renderer && tool.parameters) {\n        this.addRenderToolCall({\n          name: tool.name,\n          args: tool.parameters,\n          component: tool.renderer,\n          agentId: tool.agentId,\n        });\n      }\n    });\n\n    this.#config.frontendTools?.forEach((clientTool) => {\n      this.addFrontendTool({ ...clientTool, injector: this.#rootInjector });\n    });\n\n    this.#config.humanInTheLoop?.forEach((humanInTheLoopTool) => {\n      this.addHumanInTheLoop(humanInTheLoopTool);\n    });\n\n    this.core.subscribe({\n      onAgentsChanged: () => {\n        this.#agents.set(this.core.agents);\n      },\n    });\n  }\n\n  #bindClientTool(\n    clientToolWithInjector: FrontendToolConfig & {\n      injector: Injector;\n    },\n  ): FrontendTool {\n    const { injector, handler, ...frontendCandidate } = clientToolWithInjector;\n\n    return {\n      ...frontendCandidate,\n      handler: (args) => runInInjectionContext(injector, () => handler(args)),\n    };\n  }\n\n  addFrontendTool(\n    clientToolWithInjector: FrontendToolConfig & {\n      injector: Injector;\n    },\n  ): void {\n    const tool = this.#bindClientTool(clientToolWithInjector);\n\n    this.core.addTool(tool);\n\n    this.#clientToolCallRenderConfigs.update((current) => [...current, clientToolWithInjector]);\n  }\n\n  addRenderToolCall(renderConfig: RenderToolCallConfig): void {\n    this.#toolCallRenderConfigs.update((current) => [...current, renderConfig]);\n  }\n\n  #bindHumanInTheLoopTool(humanInTheLoopTool: HumanInTheLoopConfig): FrontendTool {\n    return {\n      ...humanInTheLoopTool,\n      handler: (args, toolCall) => {\n        return this.#hitl.onResult(toolCall.id, humanInTheLoopTool.name);\n      },\n    };\n  }\n\n  addHumanInTheLoop(humanInTheLoopTool: HumanInTheLoopConfig): void {\n    this.#humanInTheLoopToolRenderConfigs.update((current) => [...current, humanInTheLoopTool]);\n\n    const tool = this.#bindHumanInTheLoopTool(humanInTheLoopTool);\n\n    this.core.addTool(tool);\n  }\n\n  #isSameAgentId<T extends { agentId?: string }>(target: T, agentId?: string): boolean {\n    if (agentId) {\n      return target.agentId === agentId;\n    }\n\n    return true;\n  }\n\n  removeTool(toolName: string, agentId?: string): void {\n    this.core.removeTool(toolName);\n    this.#clientToolCallRenderConfigs.update((current) =>\n      current.filter((renderConfig) => renderConfig.name !== toolName && this.#isSameAgentId(renderConfig, agentId)),\n    );\n    this.#humanInTheLoopToolRenderConfigs.update((current) =>\n      current.filter((renderConfig) => renderConfig.name !== toolName && this.#isSameAgentId(renderConfig, agentId)),\n    );\n    this.#toolCallRenderConfigs.update((current) =>\n      current.filter((renderConfig) => renderConfig.name !== toolName && this.#isSameAgentId(renderConfig, agentId)),\n    );\n  }\n\n  getAgent(agentId: string): AbstractAgent | undefined {\n    return this.core.getAgent(agentId);\n  }\n\n  updateRuntime(options: {\n    runtimeUrl?: string;\n    headers?: Record<string, string>;\n    properties?: Record<string, unknown>;\n    agents?: Record<string, AbstractAgent>;\n  }): void {\n    if (options.runtimeUrl !== undefined) {\n      this.core.setRuntimeUrl(options.runtimeUrl);\n    }\n    if (options.headers !== undefined) {\n      this.core.setHeaders(options.headers);\n    }\n    if (options.properties !== undefined) {\n      this.core.setProperties(options.properties);\n    }\n    if (options.agents !== undefined) {\n      this.core.setAgents__unsafe_dev_only(options.agents);\n    }\n  }\n}\n"]}
|
|
@@ -57,11 +57,15 @@ export class RenderToolCalls {
|
|
|
57
57
|
buildHumanInTheLoopToolCall(toolCall) {
|
|
58
58
|
const args = partialJSONParse(toolCall.function.arguments);
|
|
59
59
|
const message = this.#getToolMessage(toolCall.id);
|
|
60
|
+
const respond = (result) => {
|
|
61
|
+
this.#hitl.addResult(toolCall.id, toolCall.function.name, result);
|
|
62
|
+
};
|
|
60
63
|
if (message) {
|
|
61
64
|
return {
|
|
62
65
|
args,
|
|
63
66
|
status: "complete",
|
|
64
67
|
result: message.content,
|
|
68
|
+
respond,
|
|
65
69
|
};
|
|
66
70
|
}
|
|
67
71
|
else if (this.isLoading()) {
|
|
@@ -69,6 +73,7 @@ export class RenderToolCalls {
|
|
|
69
73
|
args,
|
|
70
74
|
status: "in-progress",
|
|
71
75
|
result: undefined,
|
|
76
|
+
respond,
|
|
72
77
|
};
|
|
73
78
|
}
|
|
74
79
|
else {
|
|
@@ -76,9 +81,7 @@ export class RenderToolCalls {
|
|
|
76
81
|
args,
|
|
77
82
|
status: "executing",
|
|
78
83
|
result: undefined,
|
|
79
|
-
respond
|
|
80
|
-
this.#hitl.addResult(toolCall.id, toolCall.function.name, result);
|
|
81
|
-
},
|
|
84
|
+
respond,
|
|
82
85
|
};
|
|
83
86
|
}
|
|
84
87
|
}
|
|
@@ -94,6 +97,14 @@ export class RenderToolCalls {
|
|
|
94
97
|
*ngComponentOutlet="renderConfig.config.component; inputs: { toolCall: buildToolCall(toolCall) }"
|
|
95
98
|
/>
|
|
96
99
|
}
|
|
100
|
+
@if (renderConfig && renderConfig.type === "humanInTheLoopTool" && renderConfig.config.component) {
|
|
101
|
+
<ng-container
|
|
102
|
+
*ngComponentOutlet="
|
|
103
|
+
renderConfig.config.component;
|
|
104
|
+
inputs: { toolCall: buildHumanInTheLoopToolCall(toolCall) }
|
|
105
|
+
"
|
|
106
|
+
/>
|
|
107
|
+
}
|
|
97
108
|
}
|
|
98
109
|
`, isInline: true, dependencies: [{ kind: "directive", type: NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInputs", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"] }] });
|
|
99
110
|
}
|
|
@@ -111,8 +122,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
111
122
|
*ngComponentOutlet="renderConfig.config.component; inputs: { toolCall: buildToolCall(toolCall) }"
|
|
112
123
|
/>
|
|
113
124
|
}
|
|
125
|
+
@if (renderConfig && renderConfig.type === "humanInTheLoopTool" && renderConfig.config.component) {
|
|
126
|
+
<ng-container
|
|
127
|
+
*ngComponentOutlet="
|
|
128
|
+
renderConfig.config.component;
|
|
129
|
+
inputs: { toolCall: buildHumanInTheLoopToolCall(toolCall) }
|
|
130
|
+
"
|
|
131
|
+
/>
|
|
132
|
+
}
|
|
114
133
|
}
|
|
115
134
|
`,
|
|
116
135
|
}]
|
|
117
136
|
}] });
|
|
118
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"render-tool-calls.js","sourceRoot":"","sources":["../../../src/lib/render-tool-calls.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgComponentOutlet } from \"@angular/common\";\nimport { Component, inject, input } from \"@angular/core\";\nimport { AssistantMessage, Message, ToolCall } from \"@ag-ui/client\";\nimport { CopilotKit } from \"./copilotkit\";\nimport {\n  FrontendToolConfig,\n  HumanInTheLoopToolCall,\n  HumanInTheLoopConfig,\n  AngularToolCall,\n  RenderToolCallConfig,\n} from \"./tools\";\nimport { partialJSONParse } from \"@copilotkitnext/shared\";\nimport { HumanInTheLoop } from \"./human-in-the-loop\";\n\ntype RendererToolCallHandler = {\n  type: \"renderer\";\n  config: RenderToolCallConfig;\n};\ntype ClientToolCallHandler = {\n  type: \"clientTool\";\n  config: FrontendToolConfig;\n};\ntype HumanInTheLoopToolCallHandler = {\n  type: \"humanInTheLoopTool\";\n  config: HumanInTheLoopConfig;\n};\n\ntype ToolCallHandler = RendererToolCallHandler | ClientToolCallHandler | HumanInTheLoopToolCallHandler;\n\n@Component({\n  selector: \"copilot-render-tool-calls\",\n  standalone: true,\n  imports: [NgComponentOutlet],\n  template: `\n    @for (toolCall of message().toolCalls ?? []; track toolCall.id) {\n      @let renderConfig = pickRenderer(toolCall.function.name);\n      @if (renderConfig && renderConfig.type !== \"humanInTheLoopTool\" && renderConfig.config.component) {\n        <ng-container\n          *ngComponentOutlet=\"renderConfig.config.component; inputs: { toolCall: buildToolCall(toolCall) }\"\n        />\n      }\n    }\n  `,\n})\nexport class RenderToolCalls {\n  readonly #copilotKit = inject(CopilotKit);\n  readonly #hitl = inject(HumanInTheLoop);\n  readonly message = input.required<AssistantMessage>();\n  readonly messages = input.required<Message[]>();\n  readonly isLoading = input<boolean>(false);\n\n  protected pickRenderer(name: string): ToolCallHandler | undefined {\n    type AssistantMessageWithAgent = AssistantMessage & {\n      agentId?: string;\n    };\n    const messageAgentId = (this.message() as AssistantMessageWithAgent).agentId;\n    const renderers = this.#copilotKit.toolCallRenderConfigs();\n    const clientTools = this.#copilotKit.clientToolCallRenderConfigs();\n    const humanInTheLoopTools = this.#copilotKit.humanInTheLoopToolRenderConfigs();\n\n    const renderer = renderers.find(\n      (candidate) =>\n        candidate.name === name && (candidate.agentId === undefined || candidate.agentId === messageAgentId),\n    );\n\n    if (renderer) return { type: \"renderer\", config: renderer };\n\n    const clientTool = clientTools.find(\n      (candidate) =>\n        candidate.name === name && (candidate.agentId === undefined || candidate.agentId === messageAgentId),\n    );\n    if (clientTool) return { type: \"clientTool\", config: clientTool };\n\n    const humanInTheLoopTool = humanInTheLoopTools.find(\n      (candidate) =>\n        candidate.name === name && (candidate.agentId === undefined || candidate.agentId === messageAgentId),\n    );\n    if (humanInTheLoopTool) return { type: \"humanInTheLoopTool\", config: humanInTheLoopTool };\n\n    const starRenderer = renderers.find((candidate) => candidate.name === \"*\");\n    if (starRenderer) return { type: \"renderer\", config: starRenderer };\n\n    return undefined;\n  }\n\n  protected buildToolCall<Args extends Record<string, unknown>>(toolCall: ToolCall): AngularToolCall<Args> {\n    const args = partialJSONParse(toolCall.function.arguments);\n    const message = this.#getToolMessage(toolCall.id);\n\n    if (message) {\n      return {\n        args,\n        status: \"complete\",\n        result: message.content!,\n      };\n    } else if (this.isLoading()) {\n      return {\n        args,\n        status: \"in-progress\",\n        result: undefined,\n      };\n    } else {\n      return {\n        args,\n        status: \"executing\",\n        result: undefined,\n      };\n    }\n  }\n\n  protected buildHumanInTheLoopToolCall<Args extends Record<string, unknown>>(\n    toolCall: ToolCall,\n  ): HumanInTheLoopToolCall<Args> {\n    const args = partialJSONParse(toolCall.function.arguments);\n    const message = this.#getToolMessage(toolCall.id);\n\n    if (message) {\n      return {\n        args,\n        status: \"complete\",\n        result: message.content!,\n      };\n    } else if (this.isLoading()) {\n      return {\n        args,\n        status: \"in-progress\",\n        result: undefined,\n      };\n    } else {\n      return {\n        args,\n        status: \"executing\",\n        result: undefined,\n        respond: (result) => {\n          this.#hitl.addResult(toolCall.id, toolCall.function.name, result);\n        },\n      };\n    }\n  }\n\n  #getToolMessage(toolCallId: string): Message | undefined {\n    return this.messages().find((m) => m.role === \"tool\" && m.toolCallId === toolCallId);\n  }\n}\n"]}
|
|
137
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"render-tool-calls.js","sourceRoot":"","sources":["../../../src/lib/render-tool-calls.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgComponentOutlet } from \"@angular/common\";\nimport { Component, inject, input } from \"@angular/core\";\nimport { AssistantMessage, Message, ToolCall } from \"@ag-ui/client\";\nimport { CopilotKit } from \"./copilotkit\";\nimport {\n  FrontendToolConfig,\n  HumanInTheLoopToolCall,\n  HumanInTheLoopConfig,\n  AngularToolCall,\n  RenderToolCallConfig,\n} from \"./tools\";\nimport { partialJSONParse } from \"@copilotkitnext/shared\";\nimport { HumanInTheLoop } from \"./human-in-the-loop\";\n\ntype RendererToolCallHandler = {\n  type: \"renderer\";\n  config: RenderToolCallConfig;\n};\ntype ClientToolCallHandler = {\n  type: \"clientTool\";\n  config: FrontendToolConfig;\n};\ntype HumanInTheLoopToolCallHandler = {\n  type: \"humanInTheLoopTool\";\n  config: HumanInTheLoopConfig;\n};\n\ntype ToolCallHandler = RendererToolCallHandler | ClientToolCallHandler | HumanInTheLoopToolCallHandler;\n\n@Component({\n  selector: \"copilot-render-tool-calls\",\n  standalone: true,\n  imports: [NgComponentOutlet],\n  template: `\n    @for (toolCall of message().toolCalls ?? []; track toolCall.id) {\n      @let renderConfig = pickRenderer(toolCall.function.name);\n      @if (renderConfig && renderConfig.type !== \"humanInTheLoopTool\" && renderConfig.config.component) {\n        <ng-container\n          *ngComponentOutlet=\"renderConfig.config.component; inputs: { toolCall: buildToolCall(toolCall) }\"\n        />\n      }\n      @if (renderConfig && renderConfig.type === \"humanInTheLoopTool\" && renderConfig.config.component) {\n        <ng-container\n          *ngComponentOutlet=\"\n            renderConfig.config.component;\n            inputs: { toolCall: buildHumanInTheLoopToolCall(toolCall) }\n          \"\n        />\n      }\n    }\n  `,\n})\nexport class RenderToolCalls {\n  readonly #copilotKit = inject(CopilotKit);\n  readonly #hitl = inject(HumanInTheLoop);\n  readonly message = input.required<AssistantMessage>();\n  readonly messages = input.required<Message[]>();\n  readonly isLoading = input<boolean>(false);\n\n  protected pickRenderer(name: string): ToolCallHandler | undefined {\n    type AssistantMessageWithAgent = AssistantMessage & {\n      agentId?: string;\n    };\n    const messageAgentId = (this.message() as AssistantMessageWithAgent).agentId;\n    const renderers = this.#copilotKit.toolCallRenderConfigs();\n    const clientTools = this.#copilotKit.clientToolCallRenderConfigs();\n    const humanInTheLoopTools = this.#copilotKit.humanInTheLoopToolRenderConfigs();\n\n    const renderer = renderers.find(\n      (candidate) =>\n        candidate.name === name && (candidate.agentId === undefined || candidate.agentId === messageAgentId),\n    );\n\n    if (renderer) return { type: \"renderer\", config: renderer };\n\n    const clientTool = clientTools.find(\n      (candidate) =>\n        candidate.name === name && (candidate.agentId === undefined || candidate.agentId === messageAgentId),\n    );\n    if (clientTool) return { type: \"clientTool\", config: clientTool };\n\n    const humanInTheLoopTool = humanInTheLoopTools.find(\n      (candidate) =>\n        candidate.name === name && (candidate.agentId === undefined || candidate.agentId === messageAgentId),\n    );\n    if (humanInTheLoopTool) return { type: \"humanInTheLoopTool\", config: humanInTheLoopTool };\n\n    const starRenderer = renderers.find((candidate) => candidate.name === \"*\");\n    if (starRenderer) return { type: \"renderer\", config: starRenderer };\n\n    return undefined;\n  }\n\n  protected buildToolCall<Args extends Record<string, unknown>>(toolCall: ToolCall): AngularToolCall<Args> {\n    const args = partialJSONParse(toolCall.function.arguments);\n    const message = this.#getToolMessage(toolCall.id);\n\n    if (message) {\n      return {\n        args,\n        status: \"complete\",\n        result: message.content!,\n      };\n    } else if (this.isLoading()) {\n      return {\n        args,\n        status: \"in-progress\",\n        result: undefined,\n      };\n    } else {\n      return {\n        args,\n        status: \"executing\",\n        result: undefined,\n      };\n    }\n  }\n\n  protected buildHumanInTheLoopToolCall<Args extends Record<string, unknown>>(\n    toolCall: ToolCall,\n  ): HumanInTheLoopToolCall<Args> {\n    const args = partialJSONParse(toolCall.function.arguments);\n    const message = this.#getToolMessage(toolCall.id);\n    const respond = (result: unknown) => {\n      this.#hitl.addResult(toolCall.id, toolCall.function.name, result);\n    };\n\n    if (message) {\n      return {\n        args,\n        status: \"complete\",\n        result: message.content!,\n        respond,\n      };\n    } else if (this.isLoading()) {\n      return {\n        args,\n        status: \"in-progress\",\n        result: undefined,\n        respond,\n      };\n    } else {\n      return {\n        args,\n        status: \"executing\",\n        result: undefined,\n        respond,\n      };\n    }\n  }\n\n  #getToolMessage(toolCallId: string): Message | undefined {\n    return this.messages().find((m) => m.role === \"tool\" && m.toolCallId === toolCallId);\n  }\n}\n"]}
|
|
@@ -28,4 +28,4 @@ export function registerHumanInTheLoop(humanInTheLoop) {
|
|
|
28
28
|
copilotKit.removeTool(humanInTheLoop.name);
|
|
29
29
|
});
|
|
30
30
|
}
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL3Rvb2xzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFnQixNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHM0UsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQThFMUMsTUFBTSxVQUFVLHNCQUFzQixDQUNwQyxjQUEwQztJQUUxQyxNQUFNLFVBQVUsR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDdEMsTUFBTSxVQUFVLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBRXRDLFVBQVUsQ0FBQyxpQkFBaUIsQ0FBQyxjQUFjLENBQUMsQ0FBQztJQUU3QyxVQUFVLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRTtRQUN4QixVQUFVLENBQUMsVUFBVSxDQUFDLGNBQWMsQ0FBQyxJQUFJLEVBQUUsY0FBYyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3JFLENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQztBQUVELE1BQU0sVUFBVSxvQkFBb0IsQ0FDbEMsWUFBc0M7SUFFdEMsTUFBTSxRQUFRLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ2xDLE1BQU0sVUFBVSxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUN0QyxNQUFNLFVBQVUsR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7SUFFdEMsVUFBVSxDQUFDLGVBQWUsQ0FBQztRQUN6QixHQUFJLFlBQW1DO1FBQ3ZDLFFBQVE7S0FDVCxDQUFDLENBQUM7SUFFSCxVQUFVLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRTtRQUN4QixVQUFVLENBQUMsVUFBVSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUMzQyxDQUFDLENBQUMsQ0FBQztBQUNMLENBQUM7QUFFRCxNQUFNLFVBQVUsc0JBQXNCLENBQ3BDLGNBQTBDO0lBRTFDLE1BQU0sVUFBVSxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUN0QyxNQUFNLFVBQVUsR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7SUFFdEMsVUFBVSxDQUFDLGlCQUFpQixDQUFDLGNBQWMsQ0FBQyxDQUFDO0lBRTdDLFVBQVUsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1FBQ3hCLFVBQVUsQ0FBQyxVQUFVLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQzdDLENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERlc3Ryb3lSZWYsIEluamVjdG9yLCBTaWduYWwsIFR5cGUsIGluamVjdCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBGcm9udGVuZFRvb2wgfSBmcm9tIFwiQGNvcGlsb3RraXRuZXh0L2NvcmVcIjtcbmltcG9ydCB7IHogfSBmcm9tIFwiem9kXCI7XG5pbXBvcnQgeyBDb3BpbG90S2l0IH0gZnJvbSBcIi4vY29waWxvdGtpdFwiO1xuXG5leHBvcnQgdHlwZSBBbmd1bGFyVG9vbENhbGw8QXJncyBleHRlbmRzIFJlY29yZDxzdHJpbmcsIHVua25vd24+ID0gUmVjb3JkPHN0cmluZywgdW5rbm93bj4+ID1cbiAgfCB7XG4gICAgICBhcmdzOiBQYXJ0aWFsPEFyZ3M+O1xuICAgICAgc3RhdHVzOiBcImluLXByb2dyZXNzXCI7XG4gICAgICByZXN1bHQ6IHVuZGVmaW5lZDtcbiAgICB9XG4gIHwge1xuICAgICAgYXJnczogQXJncztcbiAgICAgIHN0YXR1czogXCJleGVjdXRpbmdcIjtcbiAgICAgIHJlc3VsdDogdW5kZWZpbmVkO1xuICAgIH1cbiAgfCB7XG4gICAgICBhcmdzOiBBcmdzO1xuICAgICAgc3RhdHVzOiBcImNvbXBsZXRlXCI7XG4gICAgICByZXN1bHQ6IHN0cmluZztcbiAgICB9O1xuXG5leHBvcnQgdHlwZSBIdW1hbkluVGhlTG9vcFRvb2xDYWxsPEFyZ3MgZXh0ZW5kcyBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPiA9IFJlY29yZDxzdHJpbmcsIHVua25vd24+PiA9XG4gIHwge1xuICAgICAgYXJnczogUGFydGlhbDxBcmdzPjtcbiAgICAgIHN0YXR1czogXCJpbi1wcm9ncmVzc1wiO1xuICAgICAgcmVzdWx0OiB1bmRlZmluZWQ7XG4gICAgICByZXNwb25kOiAocmVzdWx0OiB1bmtub3duKSA9PiB2b2lkO1xuICAgIH1cbiAgfCB7XG4gICAgICBhcmdzOiBBcmdzO1xuICAgICAgc3RhdHVzOiBcImV4ZWN1dGluZ1wiO1xuICAgICAgcmVzdWx0OiB1bmRlZmluZWQ7XG4gICAgICByZXNwb25kOiAocmVzdWx0OiB1bmtub3duKSA9PiB2b2lkO1xuICAgIH1cbiAgfCB7XG4gICAgICBhcmdzOiBBcmdzO1xuICAgICAgc3RhdHVzOiBcImNvbXBsZXRlXCI7XG4gICAgICByZXN1bHQ6IHN0cmluZztcbiAgICAgIHJlc3BvbmQ6IChyZXN1bHQ6IHVua25vd24pID0+IHZvaWQ7XG4gICAgfTtcblxuZXhwb3J0IGludGVyZmFjZSBUb29sUmVuZGVyZXI8QXJncyBleHRlbmRzIFJlY29yZDxzdHJpbmcsIHVua25vd24+ID0gUmVjb3JkPHN0cmluZywgdW5rbm93bj4+IHtcbiAgdG9vbENhbGw6IFNpZ25hbDxBbmd1bGFyVG9vbENhbGw8QXJncz4+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEh1bWFuSW5UaGVMb29wVG9vbFJlbmRlcmVyPEFyZ3MgZXh0ZW5kcyBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPiA9IFJlY29yZDxzdHJpbmcsIHVua25vd24+PiB7XG4gIHRvb2xDYWxsOiBTaWduYWw8SHVtYW5JblRoZUxvb3BUb29sQ2FsbDxBcmdzPj47XG59XG5cbmV4cG9ydCB0eXBlIENsaWVudFRvb2w8QXJncyBleHRlbmRzIFJlY29yZDxzdHJpbmcsIHVua25vd24+ID0gUmVjb3JkPHN0cmluZywgdW5rbm93bj4+ID0gT21pdDxcbiAgRnJvbnRlbmRUb29sPEFyZ3M+LFxuICBcImhhbmRsZXJcIlxuPiAmIHtcbiAgcmVuZGVyZXI/OiBUeXBlPFRvb2xSZW5kZXJlcjxBcmdzPj47XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIFJlbmRlclRvb2xDYWxsQ29uZmlnPEFyZ3MgZXh0ZW5kcyBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPiA9IFJlY29yZDxzdHJpbmcsIHVua25vd24+PiB7XG4gIG5hbWU6IHN0cmluZztcbiAgYXJnczogei5ab2RUeXBlPEFyZ3M+O1xuICBjb21wb25lbnQ6IFR5cGU8VG9vbFJlbmRlcmVyPEFyZ3M+PjtcbiAgYWdlbnRJZD86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBGcm9udGVuZFRvb2xDb25maWc8QXJncyBleHRlbmRzIFJlY29yZDxzdHJpbmcsIHVua25vd24+ID0gUmVjb3JkPHN0cmluZywgdW5rbm93bj4+IHtcbiAgbmFtZTogc3RyaW5nO1xuICBkZXNjcmlwdGlvbjogc3RyaW5nO1xuICBwYXJhbWV0ZXJzOiB6LlpvZFR5cGU8QXJncz47XG4gIGNvbXBvbmVudD86IFR5cGU8VG9vbFJlbmRlcmVyPEFyZ3M+PjtcbiAgaGFuZGxlcjogKGFyZ3M6IEFyZ3MpID0+IFByb21pc2U8dW5rbm93bj47XG4gIGFnZW50SWQ/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSHVtYW5JblRoZUxvb3BDb25maWc8QXJncyBleHRlbmRzIFJlY29yZDxzdHJpbmcsIHVua25vd24+ID0gUmVjb3JkPHN0cmluZywgdW5rbm93bj4+IHtcbiAgbmFtZTogc3RyaW5nO1xuICBkZXNjcmlwdGlvbjogc3RyaW5nO1xuICBwYXJhbWV0ZXJzOiB6LlpvZFR5cGU8QXJncz47XG4gIGNvbXBvbmVudDogVHlwZTxIdW1hbkluVGhlTG9vcFRvb2xSZW5kZXJlcjxBcmdzPj47XG4gIGFnZW50SWQ/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiByZWdpc3RlclJlbmRlclRvb2xDYWxsPEFyZ3MgZXh0ZW5kcyBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPiA9IFJlY29yZDxzdHJpbmcsIHVua25vd24+PihcbiAgcmVuZGVyVG9vbENhbGw6IFJlbmRlclRvb2xDYWxsQ29uZmlnPEFyZ3M+LFxuKTogdm9pZCB7XG4gIGNvbnN0IGNvcGlsb3RLaXQgPSBpbmplY3QoQ29waWxvdEtpdCk7XG4gIGNvbnN0IGRlc3Ryb3lSZWYgPSBpbmplY3QoRGVzdHJveVJlZik7XG5cbiAgY29waWxvdEtpdC5hZGRSZW5kZXJUb29sQ2FsbChyZW5kZXJUb29sQ2FsbCk7XG5cbiAgZGVzdHJveVJlZi5vbkRlc3Ryb3koKCkgPT4ge1xuICAgIGNvcGlsb3RLaXQucmVtb3ZlVG9vbChyZW5kZXJUb29sQ2FsbC5uYW1lLCByZW5kZXJUb29sQ2FsbC5hZ2VudElkKTtcbiAgfSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiByZWdpc3RlckZyb250ZW5kVG9vbDxBcmdzIGV4dGVuZHMgUmVjb3JkPHN0cmluZywgdW5rbm93bj4gPSBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPj4oXG4gIGZyb250ZW5kVG9vbDogRnJvbnRlbmRUb29sQ29uZmlnPEFyZ3M+LFxuKTogdm9pZCB7XG4gIGNvbnN0IGluamVjdG9yID0gaW5qZWN0KEluamVjdG9yKTtcbiAgY29uc3QgZGVzdHJveVJlZiA9IGluamVjdChEZXN0cm95UmVmKTtcbiAgY29uc3QgY29waWxvdEtpdCA9IGluamVjdChDb3BpbG90S2l0KTtcblxuICBjb3BpbG90S2l0LmFkZEZyb250ZW5kVG9vbCh7XG4gICAgLi4uKGZyb250ZW5kVG9vbCBhcyBGcm9udGVuZFRvb2xDb25maWcpLFxuICAgIGluamVjdG9yLFxuICB9KTtcblxuICBkZXN0cm95UmVmLm9uRGVzdHJveSgoKSA9PiB7XG4gICAgY29waWxvdEtpdC5yZW1vdmVUb29sKGZyb250ZW5kVG9vbC5uYW1lKTtcbiAgfSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiByZWdpc3Rlckh1bWFuSW5UaGVMb29wPEFyZ3MgZXh0ZW5kcyBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPiA9IFJlY29yZDxzdHJpbmcsIHVua25vd24+PihcbiAgaHVtYW5JblRoZUxvb3A6IEh1bWFuSW5UaGVMb29wQ29uZmlnPEFyZ3M+LFxuKTogdm9pZCB7XG4gIGNvbnN0IGRlc3Ryb3lSZWYgPSBpbmplY3QoRGVzdHJveVJlZik7XG4gIGNvbnN0IGNvcGlsb3RLaXQgPSBpbmplY3QoQ29waWxvdEtpdCk7XG5cbiAgY29waWxvdEtpdC5hZGRIdW1hbkluVGhlTG9vcChodW1hbkluVGhlTG9vcCk7XG5cbiAgZGVzdHJveVJlZi5vbkRlc3Ryb3koKCkgPT4ge1xuICAgIGNvcGlsb3RLaXQucmVtb3ZlVG9vbChodW1hbkluVGhlTG9vcC5uYW1lKTtcbiAgfSk7XG59XG4iXX0=
|
|
@@ -99,10 +99,7 @@ class CopilotKit {
|
|
|
99
99
|
addFrontendTool(clientToolWithInjector) {
|
|
100
100
|
const tool = this.#bindClientTool(clientToolWithInjector);
|
|
101
101
|
this.core.addTool(tool);
|
|
102
|
-
this.#clientToolCallRenderConfigs.update((current) => [
|
|
103
|
-
...current,
|
|
104
|
-
clientToolWithInjector,
|
|
105
|
-
]);
|
|
102
|
+
this.#clientToolCallRenderConfigs.update((current) => [...current, clientToolWithInjector]);
|
|
106
103
|
}
|
|
107
104
|
addRenderToolCall(renderConfig) {
|
|
108
105
|
this.#toolCallRenderConfigs.update((current) => [...current, renderConfig]);
|
|
@@ -116,10 +113,7 @@ class CopilotKit {
|
|
|
116
113
|
};
|
|
117
114
|
}
|
|
118
115
|
addHumanInTheLoop(humanInTheLoopTool) {
|
|
119
|
-
this.#humanInTheLoopToolRenderConfigs.update((current) => [
|
|
120
|
-
...current,
|
|
121
|
-
humanInTheLoopTool,
|
|
122
|
-
]);
|
|
116
|
+
this.#humanInTheLoopToolRenderConfigs.update((current) => [...current, humanInTheLoopTool]);
|
|
123
117
|
const tool = this.#bindHumanInTheLoopTool(humanInTheLoopTool);
|
|
124
118
|
this.core.addTool(tool);
|
|
125
119
|
}
|
|
@@ -131,12 +125,9 @@ class CopilotKit {
|
|
|
131
125
|
}
|
|
132
126
|
removeTool(toolName, agentId) {
|
|
133
127
|
this.core.removeTool(toolName);
|
|
134
|
-
this.#clientToolCallRenderConfigs.update((current) => current.filter((renderConfig) => renderConfig.name !== toolName &&
|
|
135
|
-
|
|
136
|
-
this.#
|
|
137
|
-
this.#isSameAgentId(renderConfig, agentId)));
|
|
138
|
-
this.#toolCallRenderConfigs.update((current) => current.filter((renderConfig) => renderConfig.name !== toolName &&
|
|
139
|
-
this.#isSameAgentId(renderConfig, agentId)));
|
|
128
|
+
this.#clientToolCallRenderConfigs.update((current) => current.filter((renderConfig) => renderConfig.name !== toolName && this.#isSameAgentId(renderConfig, agentId)));
|
|
129
|
+
this.#humanInTheLoopToolRenderConfigs.update((current) => current.filter((renderConfig) => renderConfig.name !== toolName && this.#isSameAgentId(renderConfig, agentId)));
|
|
130
|
+
this.#toolCallRenderConfigs.update((current) => current.filter((renderConfig) => renderConfig.name !== toolName && this.#isSameAgentId(renderConfig, agentId)));
|
|
140
131
|
}
|
|
141
132
|
getAgent(agentId) {
|
|
142
133
|
return this.core.getAgent(agentId);
|
|
@@ -245,11 +236,15 @@ class RenderToolCalls {
|
|
|
245
236
|
buildHumanInTheLoopToolCall(toolCall) {
|
|
246
237
|
const args = partialJSONParse(toolCall.function.arguments);
|
|
247
238
|
const message = this.#getToolMessage(toolCall.id);
|
|
239
|
+
const respond = (result) => {
|
|
240
|
+
this.#hitl.addResult(toolCall.id, toolCall.function.name, result);
|
|
241
|
+
};
|
|
248
242
|
if (message) {
|
|
249
243
|
return {
|
|
250
244
|
args,
|
|
251
245
|
status: "complete",
|
|
252
246
|
result: message.content,
|
|
247
|
+
respond,
|
|
253
248
|
};
|
|
254
249
|
}
|
|
255
250
|
else if (this.isLoading()) {
|
|
@@ -257,6 +252,7 @@ class RenderToolCalls {
|
|
|
257
252
|
args,
|
|
258
253
|
status: "in-progress",
|
|
259
254
|
result: undefined,
|
|
255
|
+
respond,
|
|
260
256
|
};
|
|
261
257
|
}
|
|
262
258
|
else {
|
|
@@ -264,9 +260,7 @@ class RenderToolCalls {
|
|
|
264
260
|
args,
|
|
265
261
|
status: "executing",
|
|
266
262
|
result: undefined,
|
|
267
|
-
respond
|
|
268
|
-
this.#hitl.addResult(toolCall.id, toolCall.function.name, result);
|
|
269
|
-
},
|
|
263
|
+
respond,
|
|
270
264
|
};
|
|
271
265
|
}
|
|
272
266
|
}
|
|
@@ -282,6 +276,14 @@ class RenderToolCalls {
|
|
|
282
276
|
*ngComponentOutlet="renderConfig.config.component; inputs: { toolCall: buildToolCall(toolCall) }"
|
|
283
277
|
/>
|
|
284
278
|
}
|
|
279
|
+
@if (renderConfig && renderConfig.type === "humanInTheLoopTool" && renderConfig.config.component) {
|
|
280
|
+
<ng-container
|
|
281
|
+
*ngComponentOutlet="
|
|
282
|
+
renderConfig.config.component;
|
|
283
|
+
inputs: { toolCall: buildHumanInTheLoopToolCall(toolCall) }
|
|
284
|
+
"
|
|
285
|
+
/>
|
|
286
|
+
}
|
|
285
287
|
}
|
|
286
288
|
`, isInline: true, dependencies: [{ kind: "directive", type: NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInputs", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"] }] });
|
|
287
289
|
}
|
|
@@ -299,6 +301,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
299
301
|
*ngComponentOutlet="renderConfig.config.component; inputs: { toolCall: buildToolCall(toolCall) }"
|
|
300
302
|
/>
|
|
301
303
|
}
|
|
304
|
+
@if (renderConfig && renderConfig.type === "humanInTheLoopTool" && renderConfig.config.component) {
|
|
305
|
+
<ng-container
|
|
306
|
+
*ngComponentOutlet="
|
|
307
|
+
renderConfig.config.component;
|
|
308
|
+
inputs: { toolCall: buildHumanInTheLoopToolCall(toolCall) }
|
|
309
|
+
"
|
|
310
|
+
/>
|
|
311
|
+
}
|
|
302
312
|
}
|
|
303
313
|
`,
|
|
304
314
|
}]
|