@copilotkitnext/angular 0.0.2 → 0.0.5
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/README.md +3 -3
- package/dist/README.md +3 -3
- package/dist/components/chat/copilot-chat-assistant-message.component.d.ts +10 -10
- package/dist/components/chat/copilot-chat-message-view.component.d.ts +42 -42
- package/dist/components/chat/copilot-chat-view.component.d.ts +14 -14
- package/dist/core/copilotkit.providers.d.ts +1 -1
- package/dist/core/copilotkit.service.d.ts +5 -5
- package/dist/core/copilotkit.types.d.ts +8 -10
- package/dist/directives/copilotkit-frontend-tool.directive.d.ts +1 -1
- package/dist/esm2022/components/chat/copilot-chat-assistant-message-buttons.component.mjs +384 -0
- package/dist/esm2022/components/chat/copilot-chat-assistant-message-renderer.component.mjs +286 -0
- package/dist/esm2022/components/chat/copilot-chat-assistant-message-toolbar.component.mjs +27 -0
- package/dist/esm2022/components/chat/copilot-chat-assistant-message.component.mjs +433 -0
- package/dist/esm2022/components/chat/copilot-chat-assistant-message.types.mjs +2 -0
- package/dist/esm2022/components/chat/copilot-chat-audio-recorder.component.mjs +202 -0
- package/dist/esm2022/components/chat/copilot-chat-buttons.component.mjs +321 -0
- package/dist/esm2022/components/chat/copilot-chat-input-defaults.mjs +38 -0
- package/dist/esm2022/components/chat/copilot-chat-input.component.mjs +666 -0
- package/dist/esm2022/components/chat/copilot-chat-input.types.mjs +10 -0
- package/dist/esm2022/components/chat/copilot-chat-message-view-cursor.component.mjs +45 -0
- package/dist/esm2022/components/chat/copilot-chat-message-view.component.mjs +296 -0
- package/dist/esm2022/components/chat/copilot-chat-message-view.types.mjs +2 -0
- package/dist/esm2022/components/chat/copilot-chat-textarea.component.mjs +188 -0
- package/dist/esm2022/components/chat/copilot-chat-tool-calls-view.component.mjs +216 -0
- package/dist/esm2022/components/chat/copilot-chat-toolbar.component.mjs +25 -0
- package/dist/esm2022/components/chat/copilot-chat-tools-menu.component.mjs +199 -0
- package/dist/esm2022/components/chat/copilot-chat-user-message-branch-navigation.component.mjs +137 -0
- package/dist/esm2022/components/chat/copilot-chat-user-message-buttons.component.mjs +207 -0
- package/dist/esm2022/components/chat/copilot-chat-user-message-renderer.component.mjs +35 -0
- package/dist/esm2022/components/chat/copilot-chat-user-message-toolbar.component.mjs +34 -0
- package/dist/esm2022/components/chat/copilot-chat-user-message.component.mjs +341 -0
- package/dist/esm2022/components/chat/copilot-chat-user-message.types.mjs +2 -0
- package/dist/esm2022/components/chat/copilot-chat-view-disclaimer.component.mjs +52 -0
- package/dist/esm2022/components/chat/copilot-chat-view-feather.component.mjs +55 -0
- package/dist/esm2022/components/chat/copilot-chat-view-handlers.service.mjs +19 -0
- package/dist/esm2022/components/chat/copilot-chat-view-input-container.component.mjs +110 -0
- package/dist/esm2022/components/chat/copilot-chat-view-scroll-to-bottom-button.component.mjs +93 -0
- package/dist/esm2022/components/chat/copilot-chat-view-scroll-view.component.mjs +443 -0
- package/dist/esm2022/components/chat/copilot-chat-view.component.mjs +479 -0
- package/dist/esm2022/components/chat/copilot-chat-view.types.mjs +2 -0
- package/dist/esm2022/components/chat/copilot-chat.component.mjs +214 -0
- package/dist/esm2022/components/copilotkit-tool-render.component.mjs +153 -0
- package/dist/esm2022/copilotkitnext-angular.mjs +5 -0
- package/dist/esm2022/core/chat-configuration/chat-configuration.providers.mjs +65 -0
- package/dist/esm2022/core/chat-configuration/chat-configuration.service.mjs +145 -0
- package/dist/esm2022/core/chat-configuration/chat-configuration.types.mjs +26 -0
- package/dist/esm2022/core/copilotkit.providers.mjs +34 -0
- package/dist/esm2022/core/copilotkit.service.mjs +426 -0
- package/dist/esm2022/core/copilotkit.types.mjs +13 -0
- package/dist/esm2022/directives/copilotkit-agent-context.directive.mjs +130 -0
- package/dist/esm2022/directives/copilotkit-agent.directive.mjs +217 -0
- package/dist/esm2022/directives/copilotkit-chat-config.directive.mjs +218 -0
- package/dist/esm2022/directives/copilotkit-config.directive.mjs +94 -0
- package/dist/esm2022/directives/copilotkit-frontend-tool.directive.mjs +128 -0
- package/dist/esm2022/directives/copilotkit-human-in-the-loop.directive.mjs +265 -0
- package/dist/esm2022/directives/stick-to-bottom.directive.mjs +181 -0
- package/dist/esm2022/index.mjs +70 -0
- package/dist/esm2022/lib/directives/tooltip.directive.mjs +211 -0
- package/dist/esm2022/lib/slots/copilot-slot.component.mjs +144 -0
- package/dist/esm2022/lib/slots/slot.types.mjs +6 -0
- package/dist/esm2022/lib/slots/slot.utils.mjs +222 -0
- package/dist/esm2022/lib/utils.mjs +10 -0
- package/dist/esm2022/services/resize-observer.service.mjs +152 -0
- package/dist/esm2022/services/scroll-position.service.mjs +124 -0
- package/dist/esm2022/types/frontend-tool.mjs +2 -0
- package/dist/esm2022/types/human-in-the-loop.mjs +2 -0
- package/dist/esm2022/utils/agent-context.utils.mjs +114 -0
- package/dist/esm2022/utils/agent.utils.mjs +204 -0
- package/dist/esm2022/utils/chat-config.utils.mjs +186 -0
- package/dist/esm2022/utils/copilotkit.utils.mjs +20 -0
- package/dist/esm2022/utils/frontend-tool.utils.mjs +224 -0
- package/dist/esm2022/utils/human-in-the-loop.utils.mjs +293 -0
- package/dist/fesm2022/copilotkitnext-angular.mjs +174 -187
- package/dist/fesm2022/copilotkitnext-angular.mjs.map +1 -1
- package/dist/utils/frontend-tool.utils.d.ts +1 -1
- package/package.json +23 -20
- package/vitest.config.mts +32 -21
- package/.turbo/turbo-build.log +0 -38
- package/.turbo/turbo-check-types.log +0 -0
- package/.turbo/turbo-test.log +0 -71
- package/ng-package.json +0 -19
- package/src/components/chat/__tests__/copilot-chat-assistant-message.component.spec.ts +0 -282
- package/src/components/chat/__tests__/copilot-chat-input.component.spec.ts +0 -419
- package/src/components/chat/__tests__/copilot-chat-message-view.component.spec.ts +0 -372
- package/src/components/chat/__tests__/copilot-chat-user-message.component.spec.ts +0 -249
- package/src/components/chat/copilot-chat-assistant-message-buttons.component.ts +0 -292
- package/src/components/chat/copilot-chat-assistant-message-renderer.component.ts +0 -472
- package/src/components/chat/copilot-chat-assistant-message-toolbar.component.ts +0 -29
- package/src/components/chat/copilot-chat-assistant-message.component.ts +0 -463
- package/src/components/chat/copilot-chat-assistant-message.types.ts +0 -50
- package/src/components/chat/copilot-chat-audio-recorder.component.ts +0 -241
- package/src/components/chat/copilot-chat-buttons.component.ts +0 -308
- package/src/components/chat/copilot-chat-buttons.component.ts.bak +0 -471
- package/src/components/chat/copilot-chat-input-defaults.ts +0 -47
- package/src/components/chat/copilot-chat-input.component.ts +0 -512
- package/src/components/chat/copilot-chat-input.types.ts +0 -148
- package/src/components/chat/copilot-chat-message-view-cursor.component.ts +0 -51
- package/src/components/chat/copilot-chat-message-view.component.ts +0 -233
- package/src/components/chat/copilot-chat-message-view.types.ts +0 -39
- package/src/components/chat/copilot-chat-textarea.component.ts +0 -220
- package/src/components/chat/copilot-chat-tool-calls-view.component.ts +0 -261
- package/src/components/chat/copilot-chat-toolbar.component.ts +0 -35
- package/src/components/chat/copilot-chat-tools-menu.component.ts +0 -185
- package/src/components/chat/copilot-chat-user-message-branch-navigation.component.ts +0 -121
- package/src/components/chat/copilot-chat-user-message-buttons.component.ts +0 -170
- package/src/components/chat/copilot-chat-user-message-renderer.component.ts +0 -37
- package/src/components/chat/copilot-chat-user-message-toolbar.component.ts +0 -37
- package/src/components/chat/copilot-chat-user-message.component.ts +0 -247
- package/src/components/chat/copilot-chat-user-message.types.ts +0 -42
- package/src/components/chat/copilot-chat-view-disclaimer.component.ts +0 -51
- package/src/components/chat/copilot-chat-view-feather.component.ts +0 -47
- package/src/components/chat/copilot-chat-view-handlers.service.ts +0 -14
- package/src/components/chat/copilot-chat-view-input-container.component.ts +0 -87
- package/src/components/chat/copilot-chat-view-scroll-to-bottom-button.component.ts +0 -79
- package/src/components/chat/copilot-chat-view-scroll-view.component.ts +0 -322
- package/src/components/chat/copilot-chat-view.component.ts +0 -420
- package/src/components/chat/copilot-chat-view.types.ts +0 -52
- package/src/components/chat/copilot-chat.component.ts +0 -232
- package/src/components/copilotkit-tool-render.component.ts +0 -169
- package/src/core/__tests__/copilotkit.service.spec.ts +0 -1051
- package/src/core/__tests__/copilotkit.service.wildcard.spec.ts +0 -316
- package/src/core/chat-configuration/__tests__/chat-configuration.service.spec.ts +0 -287
- package/src/core/chat-configuration/chat-configuration.providers.ts +0 -71
- package/src/core/chat-configuration/chat-configuration.service.ts +0 -162
- package/src/core/chat-configuration/chat-configuration.types.ts +0 -57
- package/src/core/copilotkit.providers.ts +0 -59
- package/src/core/copilotkit.service.ts +0 -542
- package/src/core/copilotkit.types.ts +0 -132
- package/src/directives/__tests__/copilotkit-agent-context.directive.spec.ts +0 -384
- package/src/directives/__tests__/copilotkit-agent.directive.spec.ts +0 -253
- package/src/directives/__tests__/copilotkit-chat-config.directive.spec.ts +0 -385
- package/src/directives/__tests__/copilotkit-config.directive.spec.ts +0 -69
- package/src/directives/__tests__/copilotkit-frontend-tool-simple.directive.spec.ts +0 -60
- package/src/directives/__tests__/copilotkit-frontend-tool.directive.spec.ts +0 -108
- package/src/directives/__tests__/copilotkit-human-in-the-loop.directive.spec.ts +0 -452
- package/src/directives/copilotkit-agent-context.directive.ts +0 -138
- package/src/directives/copilotkit-agent.directive.ts +0 -225
- package/src/directives/copilotkit-chat-config.directive.ts +0 -241
- package/src/directives/copilotkit-config.directive.ts +0 -81
- package/src/directives/copilotkit-frontend-tool.directive.ts +0 -145
- package/src/directives/copilotkit-human-in-the-loop.directive.ts +0 -281
- package/src/directives/stick-to-bottom.directive.ts +0 -204
- package/src/index.ts +0 -105
- package/src/lib/directives/tooltip.directive.ts +0 -292
- package/src/lib/slots/__tests__/slot.utils.spec.ts +0 -377
- package/src/lib/slots/copilot-slot.component.ts +0 -135
- package/src/lib/slots/index.ts +0 -3
- package/src/lib/slots/slot.types.ts +0 -64
- package/src/lib/slots/slot.utils.ts +0 -289
- package/src/lib/utils.ts +0 -10
- package/src/public-api.ts +0 -1
- package/src/services/resize-observer.service.ts +0 -181
- package/src/services/scroll-position.service.ts +0 -169
- package/src/styles/globals.css +0 -266
- package/src/styles/index.css +0 -3
- package/src/test-setup.ts +0 -15
- package/src/testing/index.ts +0 -3
- package/src/testing/testing.utils.ts +0 -248
- package/src/types/frontend-tool.ts +0 -44
- package/src/types/human-in-the-loop.ts +0 -52
- package/src/utils/__tests__/agent.utils.spec.ts +0 -234
- package/src/utils/__tests__/chat-config.utils.spec.ts +0 -306
- package/src/utils/__tests__/frontend-tool-inject.spec.ts +0 -350
- package/src/utils/__tests__/frontend-tool-integration.spec.ts +0 -199
- package/src/utils/__tests__/frontend-tool.utils.spec.ts +0 -272
- package/src/utils/__tests__/human-in-the-loop.utils.spec.ts +0 -365
- package/src/utils/agent-context.utils.ts +0 -133
- package/src/utils/agent.utils.ts +0 -239
- package/src/utils/chat-config.utils.ts +0 -221
- package/src/utils/copilotkit.utils.ts +0 -20
- package/src/utils/frontend-tool.utils.ts +0 -266
- package/src/utils/human-in-the-loop.utils.ts +0 -359
- package/tsconfig.spec.json +0 -12
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
import { Directive, Input, Inject, } from "@angular/core";
|
|
2
|
+
import { CopilotKitService } from "../core/copilotkit.service";
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../core/copilotkit.service";
|
|
5
|
+
/**
|
|
6
|
+
* Directive to manage agent context in CopilotKit.
|
|
7
|
+
* Automatically adds context on init, updates on changes, and removes on destroy.
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* ```html
|
|
11
|
+
* <!-- With separate inputs -->
|
|
12
|
+
* <div copilotkitAgentContext
|
|
13
|
+
* [description]="'User preferences'"
|
|
14
|
+
* [value]="userSettings">
|
|
15
|
+
* </div>
|
|
16
|
+
*
|
|
17
|
+
* <!-- With context object -->
|
|
18
|
+
* <div [copilotkitAgentContext]="contextObject">
|
|
19
|
+
* </div>
|
|
20
|
+
*
|
|
21
|
+
* <!-- With dynamic values -->
|
|
22
|
+
* <div copilotkitAgentContext
|
|
23
|
+
* description="Form state"
|
|
24
|
+
* [value]="formData$ | async">
|
|
25
|
+
* </div>
|
|
26
|
+
* ```
|
|
27
|
+
*/
|
|
28
|
+
export class CopilotKitAgentContextDirective {
|
|
29
|
+
copilotkit;
|
|
30
|
+
contextId;
|
|
31
|
+
constructor(copilotkit) {
|
|
32
|
+
this.copilotkit = copilotkit;
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Context object containing both description and value.
|
|
36
|
+
* If provided, this takes precedence over individual inputs.
|
|
37
|
+
*/
|
|
38
|
+
context;
|
|
39
|
+
/**
|
|
40
|
+
* Description of the context.
|
|
41
|
+
* Used when context object is not provided.
|
|
42
|
+
*/
|
|
43
|
+
description;
|
|
44
|
+
/**
|
|
45
|
+
* Value of the context.
|
|
46
|
+
* Used when context object is not provided.
|
|
47
|
+
*/
|
|
48
|
+
value;
|
|
49
|
+
ngOnInit() {
|
|
50
|
+
this.addContext();
|
|
51
|
+
}
|
|
52
|
+
ngOnChanges(changes) {
|
|
53
|
+
// Check if any relevant input has changed
|
|
54
|
+
const hasContextChange = "context" in changes;
|
|
55
|
+
const hasDescriptionChange = "description" in changes;
|
|
56
|
+
const hasValueChange = "value" in changes;
|
|
57
|
+
if (hasContextChange || hasDescriptionChange || hasValueChange) {
|
|
58
|
+
// Skip the first change as ngOnInit handles initial setup
|
|
59
|
+
if (this.contextId) {
|
|
60
|
+
this.updateContext();
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
ngOnDestroy() {
|
|
65
|
+
this.removeContext();
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* Adds the context to CopilotKit
|
|
69
|
+
*/
|
|
70
|
+
addContext() {
|
|
71
|
+
const contextToAdd = this.getContext();
|
|
72
|
+
if (contextToAdd) {
|
|
73
|
+
this.contextId = this.copilotkit.copilotkit.addContext(contextToAdd);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* Updates the context by removing the old one and adding a new one
|
|
78
|
+
*/
|
|
79
|
+
updateContext() {
|
|
80
|
+
this.removeContext();
|
|
81
|
+
this.addContext();
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Removes the current context from CopilotKit
|
|
85
|
+
*/
|
|
86
|
+
removeContext() {
|
|
87
|
+
if (this.contextId) {
|
|
88
|
+
this.copilotkit.copilotkit.removeContext(this.contextId);
|
|
89
|
+
this.contextId = undefined;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* Gets the context object from inputs
|
|
94
|
+
*/
|
|
95
|
+
getContext() {
|
|
96
|
+
// If context object is provided, use it
|
|
97
|
+
if (this.context) {
|
|
98
|
+
return this.context;
|
|
99
|
+
}
|
|
100
|
+
// Otherwise, build from individual inputs
|
|
101
|
+
// Note: null is a valid value, but undefined means not set
|
|
102
|
+
if (this.description !== undefined && this.value !== undefined) {
|
|
103
|
+
return {
|
|
104
|
+
description: this.description,
|
|
105
|
+
value: this.value,
|
|
106
|
+
};
|
|
107
|
+
}
|
|
108
|
+
return null;
|
|
109
|
+
}
|
|
110
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CopilotKitAgentContextDirective, deps: [{ token: CopilotKitService }], target: i0.ɵɵFactoryTarget.Directive });
|
|
111
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: CopilotKitAgentContextDirective, isStandalone: true, selector: "[copilotkitAgentContext]", inputs: { context: ["copilotkitAgentContext", "context"], description: "description", value: "value" }, usesOnChanges: true, ngImport: i0 });
|
|
112
|
+
}
|
|
113
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CopilotKitAgentContextDirective, decorators: [{
|
|
114
|
+
type: Directive,
|
|
115
|
+
args: [{
|
|
116
|
+
selector: "[copilotkitAgentContext]",
|
|
117
|
+
standalone: true,
|
|
118
|
+
}]
|
|
119
|
+
}], ctorParameters: () => [{ type: i1.CopilotKitService, decorators: [{
|
|
120
|
+
type: Inject,
|
|
121
|
+
args: [CopilotKitService]
|
|
122
|
+
}] }], propDecorators: { context: [{
|
|
123
|
+
type: Input,
|
|
124
|
+
args: ["copilotkitAgentContext"]
|
|
125
|
+
}], description: [{
|
|
126
|
+
type: Input
|
|
127
|
+
}], value: [{
|
|
128
|
+
type: Input
|
|
129
|
+
}] } });
|
|
130
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29waWxvdGtpdC1hZ2VudC1jb250ZXh0LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9kaXJlY3RpdmVzL2NvcGlsb3RraXQtYWdlbnQtY29udGV4dC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCxLQUFLLEVBS0wsTUFBTSxHQUNQLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDRCQUE0QixDQUFDOzs7QUFHL0Q7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FzQkc7QUFLSCxNQUFNLE9BQU8sK0JBQStCO0lBTUk7SUFIdEMsU0FBUyxDQUFVO0lBRTNCLFlBQzhDLFVBQTZCO1FBQTdCLGVBQVUsR0FBVixVQUFVLENBQW1CO0lBQ3hFLENBQUM7SUFFSjs7O09BR0c7SUFDOEIsT0FBTyxDQUFXO0lBRW5EOzs7T0FHRztJQUNNLFdBQVcsQ0FBVTtJQUU5Qjs7O09BR0c7SUFDTSxLQUFLLENBQU87SUFFckIsUUFBUTtRQUNOLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUNwQixDQUFDO0lBRUQsV0FBVyxDQUFDLE9BQXNCO1FBQ2hDLDBDQUEwQztRQUMxQyxNQUFNLGdCQUFnQixHQUFHLFNBQVMsSUFBSSxPQUFPLENBQUM7UUFDOUMsTUFBTSxvQkFBb0IsR0FBRyxhQUFhLElBQUksT0FBTyxDQUFDO1FBQ3RELE1BQU0sY0FBYyxHQUFHLE9BQU8sSUFBSSxPQUFPLENBQUM7UUFFMUMsSUFBSSxnQkFBZ0IsSUFBSSxvQkFBb0IsSUFBSSxjQUFjLEVBQUUsQ0FBQztZQUMvRCwwREFBMEQ7WUFDMUQsSUFBSSxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7Z0JBQ25CLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUN2QixDQUFDO1FBQ0gsQ0FBQztJQUNILENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQ3ZCLENBQUM7SUFFRDs7T0FFRztJQUNLLFVBQVU7UUFDaEIsTUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO1FBRXZDLElBQUksWUFBWSxFQUFFLENBQUM7WUFDakIsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLFVBQVUsQ0FBQyxVQUFVLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDdkUsQ0FBQztJQUNILENBQUM7SUFFRDs7T0FFRztJQUNLLGFBQWE7UUFDbkIsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO1FBQ3JCLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUNwQixDQUFDO0lBRUQ7O09BRUc7SUFDSyxhQUFhO1FBQ25CLElBQUksSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQ25CLElBQUksQ0FBQyxVQUFVLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7WUFDekQsSUFBSSxDQUFDLFNBQVMsR0FBRyxTQUFTLENBQUM7UUFDN0IsQ0FBQztJQUNILENBQUM7SUFFRDs7T0FFRztJQUNLLFVBQVU7UUFDaEIsd0NBQXdDO1FBQ3hDLElBQUksSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1lBQ2pCLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQztRQUN0QixDQUFDO1FBRUQsMENBQTBDO1FBQzFDLDJEQUEyRDtRQUMzRCxJQUFJLElBQUksQ0FBQyxXQUFXLEtBQUssU0FBUyxJQUFJLElBQUksQ0FBQyxLQUFLLEtBQUssU0FBUyxFQUFFLENBQUM7WUFDL0QsT0FBTztnQkFDTCxXQUFXLEVBQUUsSUFBSSxDQUFDLFdBQVc7Z0JBQzdCLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSzthQUNsQixDQUFDO1FBQ0osQ0FBQztRQUVELE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQzt3R0FqR1UsK0JBQStCLGtCQU1oQyxpQkFBaUI7NEZBTmhCLCtCQUErQjs7NEZBQS9CLCtCQUErQjtrQkFKM0MsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsMEJBQTBCO29CQUNwQyxVQUFVLEVBQUUsSUFBSTtpQkFDakI7OzBCQU9JLE1BQU07MkJBQUMsaUJBQWlCO3lDQU9NLE9BQU87c0JBQXZDLEtBQUs7dUJBQUMsd0JBQXdCO2dCQU10QixXQUFXO3NCQUFuQixLQUFLO2dCQU1HLEtBQUs7c0JBQWIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIERpcmVjdGl2ZSxcbiAgSW5wdXQsXG4gIE9uSW5pdCxcbiAgT25DaGFuZ2VzLFxuICBPbkRlc3Ryb3ksXG4gIFNpbXBsZUNoYW5nZXMsXG4gIEluamVjdCxcbn0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IENvcGlsb3RLaXRTZXJ2aWNlIH0gZnJvbSBcIi4uL2NvcmUvY29waWxvdGtpdC5zZXJ2aWNlXCI7XG5pbXBvcnQgdHlwZSB7IENvbnRleHQgfSBmcm9tIFwiQGFnLXVpL2NsaWVudFwiO1xuXG4vKipcbiAqIERpcmVjdGl2ZSB0byBtYW5hZ2UgYWdlbnQgY29udGV4dCBpbiBDb3BpbG90S2l0LlxuICogQXV0b21hdGljYWxseSBhZGRzIGNvbnRleHQgb24gaW5pdCwgdXBkYXRlcyBvbiBjaGFuZ2VzLCBhbmQgcmVtb3ZlcyBvbiBkZXN0cm95LlxuICpcbiAqIEBleGFtcGxlXG4gKiBgYGBodG1sXG4gKiA8IS0tIFdpdGggc2VwYXJhdGUgaW5wdXRzIC0tPlxuICogPGRpdiBjb3BpbG90a2l0QWdlbnRDb250ZXh0XG4gKiAgICAgIFtkZXNjcmlwdGlvbl09XCInVXNlciBwcmVmZXJlbmNlcydcIlxuICogICAgICBbdmFsdWVdPVwidXNlclNldHRpbmdzXCI+XG4gKiA8L2Rpdj5cbiAqXG4gKiA8IS0tIFdpdGggY29udGV4dCBvYmplY3QgLS0+XG4gKiA8ZGl2IFtjb3BpbG90a2l0QWdlbnRDb250ZXh0XT1cImNvbnRleHRPYmplY3RcIj5cbiAqIDwvZGl2PlxuICpcbiAqIDwhLS0gV2l0aCBkeW5hbWljIHZhbHVlcyAtLT5cbiAqIDxkaXYgY29waWxvdGtpdEFnZW50Q29udGV4dFxuICogICAgICBkZXNjcmlwdGlvbj1cIkZvcm0gc3RhdGVcIlxuICogICAgICBbdmFsdWVdPVwiZm9ybURhdGEkIHwgYXN5bmNcIj5cbiAqIDwvZGl2PlxuICogYGBgXG4gKi9cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogXCJbY29waWxvdGtpdEFnZW50Q29udGV4dF1cIixcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgQ29waWxvdEtpdEFnZW50Q29udGV4dERpcmVjdGl2ZVxuICBpbXBsZW1lbnRzIE9uSW5pdCwgT25DaGFuZ2VzLCBPbkRlc3Ryb3lcbntcbiAgcHJpdmF0ZSBjb250ZXh0SWQ/OiBzdHJpbmc7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgQEluamVjdChDb3BpbG90S2l0U2VydmljZSkgcHJpdmF0ZSByZWFkb25seSBjb3BpbG90a2l0OiBDb3BpbG90S2l0U2VydmljZVxuICApIHt9XG5cbiAgLyoqXG4gICAqIENvbnRleHQgb2JqZWN0IGNvbnRhaW5pbmcgYm90aCBkZXNjcmlwdGlvbiBhbmQgdmFsdWUuXG4gICAqIElmIHByb3ZpZGVkLCB0aGlzIHRha2VzIHByZWNlZGVuY2Ugb3ZlciBpbmRpdmlkdWFsIGlucHV0cy5cbiAgICovXG4gIEBJbnB1dChcImNvcGlsb3RraXRBZ2VudENvbnRleHRcIikgY29udGV4dD86IENvbnRleHQ7XG5cbiAgLyoqXG4gICAqIERlc2NyaXB0aW9uIG9mIHRoZSBjb250ZXh0LlxuICAgKiBVc2VkIHdoZW4gY29udGV4dCBvYmplY3QgaXMgbm90IHByb3ZpZGVkLlxuICAgKi9cbiAgQElucHV0KCkgZGVzY3JpcHRpb24/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFZhbHVlIG9mIHRoZSBjb250ZXh0LlxuICAgKiBVc2VkIHdoZW4gY29udGV4dCBvYmplY3QgaXMgbm90IHByb3ZpZGVkLlxuICAgKi9cbiAgQElucHV0KCkgdmFsdWU/OiBhbnk7XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5hZGRDb250ZXh0KCk7XG4gIH1cblxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XG4gICAgLy8gQ2hlY2sgaWYgYW55IHJlbGV2YW50IGlucHV0IGhhcyBjaGFuZ2VkXG4gICAgY29uc3QgaGFzQ29udGV4dENoYW5nZSA9IFwiY29udGV4dFwiIGluIGNoYW5nZXM7XG4gICAgY29uc3QgaGFzRGVzY3JpcHRpb25DaGFuZ2UgPSBcImRlc2NyaXB0aW9uXCIgaW4gY2hhbmdlcztcbiAgICBjb25zdCBoYXNWYWx1ZUNoYW5nZSA9IFwidmFsdWVcIiBpbiBjaGFuZ2VzO1xuXG4gICAgaWYgKGhhc0NvbnRleHRDaGFuZ2UgfHwgaGFzRGVzY3JpcHRpb25DaGFuZ2UgfHwgaGFzVmFsdWVDaGFuZ2UpIHtcbiAgICAgIC8vIFNraXAgdGhlIGZpcnN0IGNoYW5nZSBhcyBuZ09uSW5pdCBoYW5kbGVzIGluaXRpYWwgc2V0dXBcbiAgICAgIGlmICh0aGlzLmNvbnRleHRJZCkge1xuICAgICAgICB0aGlzLnVwZGF0ZUNvbnRleHQoKTtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLnJlbW92ZUNvbnRleHQoKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBBZGRzIHRoZSBjb250ZXh0IHRvIENvcGlsb3RLaXRcbiAgICovXG4gIHByaXZhdGUgYWRkQ29udGV4dCgpOiB2b2lkIHtcbiAgICBjb25zdCBjb250ZXh0VG9BZGQgPSB0aGlzLmdldENvbnRleHQoKTtcblxuICAgIGlmIChjb250ZXh0VG9BZGQpIHtcbiAgICAgIHRoaXMuY29udGV4dElkID0gdGhpcy5jb3BpbG90a2l0LmNvcGlsb3RraXQuYWRkQ29udGV4dChjb250ZXh0VG9BZGQpO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBVcGRhdGVzIHRoZSBjb250ZXh0IGJ5IHJlbW92aW5nIHRoZSBvbGQgb25lIGFuZCBhZGRpbmcgYSBuZXcgb25lXG4gICAqL1xuICBwcml2YXRlIHVwZGF0ZUNvbnRleHQoKTogdm9pZCB7XG4gICAgdGhpcy5yZW1vdmVDb250ZXh0KCk7XG4gICAgdGhpcy5hZGRDb250ZXh0KCk7XG4gIH1cblxuICAvKipcbiAgICogUmVtb3ZlcyB0aGUgY3VycmVudCBjb250ZXh0IGZyb20gQ29waWxvdEtpdFxuICAgKi9cbiAgcHJpdmF0ZSByZW1vdmVDb250ZXh0KCk6IHZvaWQge1xuICAgIGlmICh0aGlzLmNvbnRleHRJZCkge1xuICAgICAgdGhpcy5jb3BpbG90a2l0LmNvcGlsb3RraXQucmVtb3ZlQ29udGV4dCh0aGlzLmNvbnRleHRJZCk7XG4gICAgICB0aGlzLmNvbnRleHRJZCA9IHVuZGVmaW5lZDtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogR2V0cyB0aGUgY29udGV4dCBvYmplY3QgZnJvbSBpbnB1dHNcbiAgICovXG4gIHByaXZhdGUgZ2V0Q29udGV4dCgpOiBDb250ZXh0IHwgbnVsbCB7XG4gICAgLy8gSWYgY29udGV4dCBvYmplY3QgaXMgcHJvdmlkZWQsIHVzZSBpdFxuICAgIGlmICh0aGlzLmNvbnRleHQpIHtcbiAgICAgIHJldHVybiB0aGlzLmNvbnRleHQ7XG4gICAgfVxuXG4gICAgLy8gT3RoZXJ3aXNlLCBidWlsZCBmcm9tIGluZGl2aWR1YWwgaW5wdXRzXG4gICAgLy8gTm90ZTogbnVsbCBpcyBhIHZhbGlkIHZhbHVlLCBidXQgdW5kZWZpbmVkIG1lYW5zIG5vdCBzZXRcbiAgICBpZiAodGhpcy5kZXNjcmlwdGlvbiAhPT0gdW5kZWZpbmVkICYmIHRoaXMudmFsdWUgIT09IHVuZGVmaW5lZCkge1xuICAgICAgcmV0dXJuIHtcbiAgICAgICAgZGVzY3JpcHRpb246IHRoaXMuZGVzY3JpcHRpb24sXG4gICAgICAgIHZhbHVlOiB0aGlzLnZhbHVlLFxuICAgICAgfTtcbiAgICB9XG5cbiAgICByZXR1cm4gbnVsbDtcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,217 @@
|
|
|
1
|
+
import { Directive, Input, Output, EventEmitter, signal, Inject, } from "@angular/core";
|
|
2
|
+
import { toObservable } from "@angular/core/rxjs-interop";
|
|
3
|
+
import { CopilotKitService } from "../core/copilotkit.service";
|
|
4
|
+
import { DEFAULT_AGENT_ID } from "@copilotkitnext/shared";
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../core/copilotkit.service";
|
|
7
|
+
/**
|
|
8
|
+
* Directive to watch and interact with CopilotKit agents.
|
|
9
|
+
* Provides reactive outputs for agent state changes.
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* ```html
|
|
13
|
+
* <!-- Basic usage with default agent -->
|
|
14
|
+
* <div copilotkitAgent
|
|
15
|
+
* (agentChange)="onAgentChange($event)"
|
|
16
|
+
* (runningChange)="isProcessing = $event">
|
|
17
|
+
* Content here
|
|
18
|
+
* </div>
|
|
19
|
+
*
|
|
20
|
+
* <!-- With specific agent ID -->
|
|
21
|
+
* <div copilotkitAgent
|
|
22
|
+
* [agentId]="'my-agent-id'"
|
|
23
|
+
* (agentChange)="currentAgent = $event"
|
|
24
|
+
* (runningChange)="onRunningStateChange($event)"
|
|
25
|
+
* (messagesChange)="onMessagesUpdate($event)"
|
|
26
|
+
* (stateChange)="onStateUpdate($event)">
|
|
27
|
+
* Content here
|
|
28
|
+
* </div>
|
|
29
|
+
*
|
|
30
|
+
* <!-- Two-way binding for running state -->
|
|
31
|
+
* <div copilotkitAgent
|
|
32
|
+
* [(running)]="isAgentRunning">
|
|
33
|
+
* <span *ngIf="isAgentRunning">Processing...</span>
|
|
34
|
+
* </div>
|
|
35
|
+
* ```
|
|
36
|
+
*/
|
|
37
|
+
export class CopilotKitAgentDirective {
|
|
38
|
+
copilotkit;
|
|
39
|
+
agent;
|
|
40
|
+
agentSubscription;
|
|
41
|
+
coreUnsubscribe; // subscribe returns function directly
|
|
42
|
+
_isRunning = false;
|
|
43
|
+
runningSignal = signal(false);
|
|
44
|
+
agentSignal = signal(undefined);
|
|
45
|
+
constructor(copilotkit) {
|
|
46
|
+
this.copilotkit = copilotkit;
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* The ID of the agent to watch.
|
|
50
|
+
* If not provided, uses the default agent ID.
|
|
51
|
+
*/
|
|
52
|
+
agentId;
|
|
53
|
+
/**
|
|
54
|
+
* Alternative input using the directive selector.
|
|
55
|
+
* Allows: [copilotkitAgent]="'agent-id'"
|
|
56
|
+
*/
|
|
57
|
+
set directiveAgentId(value) {
|
|
58
|
+
this.agentId = value || undefined;
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* Emits when the agent instance changes.
|
|
62
|
+
*/
|
|
63
|
+
agentChange = new EventEmitter();
|
|
64
|
+
/**
|
|
65
|
+
* Emits when the running state changes.
|
|
66
|
+
*/
|
|
67
|
+
runningChange = new EventEmitter();
|
|
68
|
+
/**
|
|
69
|
+
* Observable of the running state.
|
|
70
|
+
*/
|
|
71
|
+
get running$() {
|
|
72
|
+
return toObservable(this.runningSignal);
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* Observable of the agent instance.
|
|
76
|
+
*/
|
|
77
|
+
get agent$() {
|
|
78
|
+
return toObservable(this.agentSignal);
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* Two-way binding for running state.
|
|
82
|
+
*/
|
|
83
|
+
get running() {
|
|
84
|
+
return this._isRunning;
|
|
85
|
+
}
|
|
86
|
+
set running(value) {
|
|
87
|
+
// Input setter for two-way binding (though typically read-only from agent)
|
|
88
|
+
this._isRunning = value;
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Emits when agent messages change.
|
|
92
|
+
*/
|
|
93
|
+
messagesChange = new EventEmitter();
|
|
94
|
+
/**
|
|
95
|
+
* Emits when agent state changes.
|
|
96
|
+
*/
|
|
97
|
+
stateChange = new EventEmitter();
|
|
98
|
+
/**
|
|
99
|
+
* Emits when a run is initialized.
|
|
100
|
+
*/
|
|
101
|
+
runInitialized = new EventEmitter();
|
|
102
|
+
/**
|
|
103
|
+
* Emits when a run is finalized.
|
|
104
|
+
*/
|
|
105
|
+
runFinalized = new EventEmitter();
|
|
106
|
+
/**
|
|
107
|
+
* Emits when a run fails.
|
|
108
|
+
*/
|
|
109
|
+
runFailed = new EventEmitter();
|
|
110
|
+
ngOnInit() {
|
|
111
|
+
this.setupAgent();
|
|
112
|
+
this.subscribeToCore();
|
|
113
|
+
}
|
|
114
|
+
ngOnChanges(changes) {
|
|
115
|
+
if (changes["agentId"] && !changes["agentId"].firstChange) {
|
|
116
|
+
// Agent ID changed, re-setup
|
|
117
|
+
this.cleanupAgentSubscription();
|
|
118
|
+
this.setupAgent();
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
ngOnDestroy() {
|
|
122
|
+
this.cleanupAgentSubscription();
|
|
123
|
+
this.cleanupCoreSubscription();
|
|
124
|
+
}
|
|
125
|
+
setupAgent() {
|
|
126
|
+
const effectiveAgentId = this.agentId ?? DEFAULT_AGENT_ID;
|
|
127
|
+
this.agent = this.copilotkit.getAgent(effectiveAgentId);
|
|
128
|
+
// Update signals
|
|
129
|
+
this.agentSignal.set(this.agent);
|
|
130
|
+
// Emit initial agent
|
|
131
|
+
this.agentChange.emit(this.agent);
|
|
132
|
+
// Subscribe to agent events
|
|
133
|
+
this.subscribeToAgent();
|
|
134
|
+
}
|
|
135
|
+
subscribeToAgent() {
|
|
136
|
+
this.cleanupAgentSubscription();
|
|
137
|
+
if (this.agent) {
|
|
138
|
+
this.agentSubscription = this.agent.subscribe({
|
|
139
|
+
onMessagesChanged: (params) => {
|
|
140
|
+
this.messagesChange.emit(params);
|
|
141
|
+
},
|
|
142
|
+
onStateChanged: (params) => {
|
|
143
|
+
this.stateChange.emit(params);
|
|
144
|
+
},
|
|
145
|
+
onRunInitialized: (params) => {
|
|
146
|
+
this._isRunning = true;
|
|
147
|
+
this.runningSignal.set(true);
|
|
148
|
+
this.runningChange.emit(true);
|
|
149
|
+
this.runInitialized.emit(params);
|
|
150
|
+
},
|
|
151
|
+
onRunFinalized: (params) => {
|
|
152
|
+
this._isRunning = false;
|
|
153
|
+
this.runningSignal.set(false);
|
|
154
|
+
this.runningChange.emit(false);
|
|
155
|
+
this.runFinalized.emit(params);
|
|
156
|
+
},
|
|
157
|
+
onRunFailed: (params) => {
|
|
158
|
+
this._isRunning = false;
|
|
159
|
+
this.runningSignal.set(false);
|
|
160
|
+
this.runningChange.emit(false);
|
|
161
|
+
this.runFailed.emit(params);
|
|
162
|
+
},
|
|
163
|
+
});
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
subscribeToCore() {
|
|
167
|
+
// Subscribe to CopilotKit changes to detect agent updates
|
|
168
|
+
this.coreUnsubscribe = this.copilotkit.copilotkit.subscribe({
|
|
169
|
+
onRuntimeLoaded: () => {
|
|
170
|
+
// Re-check agent when runtime loads
|
|
171
|
+
this.setupAgent();
|
|
172
|
+
},
|
|
173
|
+
});
|
|
174
|
+
}
|
|
175
|
+
cleanupAgentSubscription() {
|
|
176
|
+
this.agentSubscription?.unsubscribe();
|
|
177
|
+
this.agentSubscription = undefined;
|
|
178
|
+
}
|
|
179
|
+
cleanupCoreSubscription() {
|
|
180
|
+
this.coreUnsubscribe?.();
|
|
181
|
+
this.coreUnsubscribe = undefined;
|
|
182
|
+
}
|
|
183
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CopilotKitAgentDirective, deps: [{ token: CopilotKitService }], target: i0.ɵɵFactoryTarget.Directive });
|
|
184
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: CopilotKitAgentDirective, isStandalone: true, selector: "[copilotkitAgent]", inputs: { agentId: "agentId", directiveAgentId: ["copilotkitAgent", "directiveAgentId"], running: "running" }, outputs: { agentChange: "agentChange", runningChange: "runningChange", messagesChange: "messagesChange", stateChange: "stateChange", runInitialized: "runInitialized", runFinalized: "runFinalized", runFailed: "runFailed" }, usesOnChanges: true, ngImport: i0 });
|
|
185
|
+
}
|
|
186
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CopilotKitAgentDirective, decorators: [{
|
|
187
|
+
type: Directive,
|
|
188
|
+
args: [{
|
|
189
|
+
selector: "[copilotkitAgent]",
|
|
190
|
+
standalone: true,
|
|
191
|
+
}]
|
|
192
|
+
}], ctorParameters: () => [{ type: i1.CopilotKitService, decorators: [{
|
|
193
|
+
type: Inject,
|
|
194
|
+
args: [CopilotKitService]
|
|
195
|
+
}] }], propDecorators: { agentId: [{
|
|
196
|
+
type: Input
|
|
197
|
+
}], directiveAgentId: [{
|
|
198
|
+
type: Input,
|
|
199
|
+
args: ["copilotkitAgent"]
|
|
200
|
+
}], agentChange: [{
|
|
201
|
+
type: Output
|
|
202
|
+
}], runningChange: [{
|
|
203
|
+
type: Output
|
|
204
|
+
}], running: [{
|
|
205
|
+
type: Input
|
|
206
|
+
}], messagesChange: [{
|
|
207
|
+
type: Output
|
|
208
|
+
}], stateChange: [{
|
|
209
|
+
type: Output
|
|
210
|
+
}], runInitialized: [{
|
|
211
|
+
type: Output
|
|
212
|
+
}], runFinalized: [{
|
|
213
|
+
type: Output
|
|
214
|
+
}], runFailed: [{
|
|
215
|
+
type: Output
|
|
216
|
+
}] } });
|
|
217
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"copilotkit-agent.directive.js","sourceRoot":"","sources":["../../../src/directives/copilotkit-agent.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  Input,\n  Output,\n  EventEmitter,\n  OnInit,\n  OnChanges,\n  OnDestroy,\n  SimpleChanges,\n  signal,\n  Inject,\n} from \"@angular/core\";\nimport { toObservable } from \"@angular/core/rxjs-interop\";\nimport { Observable } from \"rxjs\";\nimport { CopilotKitService } from \"../core/copilotkit.service\";\nimport { AbstractAgent } from \"@ag-ui/client\";\nimport { DEFAULT_AGENT_ID } from \"@copilotkitnext/shared\";\n\n/**\n * Directive to watch and interact with CopilotKit agents.\n * Provides reactive outputs for agent state changes.\n *\n * @example\n * ```html\n * <!-- Basic usage with default agent -->\n * <div copilotkitAgent\n *      (agentChange)=\"onAgentChange($event)\"\n *      (runningChange)=\"isProcessing = $event\">\n *   Content here\n * </div>\n *\n * <!-- With specific agent ID -->\n * <div copilotkitAgent\n *      [agentId]=\"'my-agent-id'\"\n *      (agentChange)=\"currentAgent = $event\"\n *      (runningChange)=\"onRunningStateChange($event)\"\n *      (messagesChange)=\"onMessagesUpdate($event)\"\n *      (stateChange)=\"onStateUpdate($event)\">\n *   Content here\n * </div>\n *\n * <!-- Two-way binding for running state -->\n * <div copilotkitAgent\n *      [(running)]=\"isAgentRunning\">\n *   <span *ngIf=\"isAgentRunning\">Processing...</span>\n * </div>\n * ```\n */\n@Directive({\n  selector: \"[copilotkitAgent]\",\n  standalone: true,\n})\nexport class CopilotKitAgentDirective implements OnInit, OnChanges, OnDestroy {\n  private agent?: AbstractAgent;\n  private agentSubscription?: { unsubscribe: () => void };\n  private coreUnsubscribe?: () => void; // subscribe returns function directly\n  private _isRunning = false;\n  private runningSignal = signal<boolean>(false);\n  private agentSignal = signal<AbstractAgent | undefined>(undefined);\n\n  constructor(\n    @Inject(CopilotKitService) private readonly copilotkit: CopilotKitService\n  ) {}\n\n  /**\n   * The ID of the agent to watch.\n   * If not provided, uses the default agent ID.\n   */\n  @Input() agentId?: string;\n\n  /**\n   * Alternative input using the directive selector.\n   * Allows: [copilotkitAgent]=\"'agent-id'\"\n   */\n  @Input(\"copilotkitAgent\")\n  set directiveAgentId(value: string | undefined) {\n    this.agentId = value || undefined;\n  }\n\n  /**\n   * Emits when the agent instance changes.\n   */\n  @Output() agentChange = new EventEmitter<AbstractAgent | undefined>();\n\n  /**\n   * Emits when the running state changes.\n   */\n  @Output() runningChange = new EventEmitter<boolean>();\n\n  /**\n   * Observable of the running state.\n   */\n  get running$(): Observable<boolean> {\n    return toObservable(this.runningSignal);\n  }\n\n  /**\n   * Observable of the agent instance.\n   */\n  get agent$(): Observable<AbstractAgent | undefined> {\n    return toObservable(this.agentSignal);\n  }\n\n  /**\n   * Two-way binding for running state.\n   */\n  @Input()\n  get running(): boolean {\n    return this._isRunning;\n  }\n  set running(value: boolean) {\n    // Input setter for two-way binding (though typically read-only from agent)\n    this._isRunning = value;\n  }\n\n  /**\n   * Emits when agent messages change.\n   */\n  @Output() messagesChange = new EventEmitter<any>();\n\n  /**\n   * Emits when agent state changes.\n   */\n  @Output() stateChange = new EventEmitter<any>();\n\n  /**\n   * Emits when a run is initialized.\n   */\n  @Output() runInitialized = new EventEmitter<any>();\n\n  /**\n   * Emits when a run is finalized.\n   */\n  @Output() runFinalized = new EventEmitter<any>();\n\n  /**\n   * Emits when a run fails.\n   */\n  @Output() runFailed = new EventEmitter<any>();\n\n  ngOnInit(): void {\n    this.setupAgent();\n    this.subscribeToCore();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes[\"agentId\"] && !changes[\"agentId\"].firstChange) {\n      // Agent ID changed, re-setup\n      this.cleanupAgentSubscription();\n      this.setupAgent();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.cleanupAgentSubscription();\n    this.cleanupCoreSubscription();\n  }\n\n  private setupAgent(): void {\n    const effectiveAgentId = this.agentId ?? DEFAULT_AGENT_ID;\n    this.agent = this.copilotkit.getAgent(effectiveAgentId);\n\n    // Update signals\n    this.agentSignal.set(this.agent);\n\n    // Emit initial agent\n    this.agentChange.emit(this.agent);\n\n    // Subscribe to agent events\n    this.subscribeToAgent();\n  }\n\n  private subscribeToAgent(): void {\n    this.cleanupAgentSubscription();\n\n    if (this.agent) {\n      this.agentSubscription = this.agent.subscribe({\n        onMessagesChanged: (params) => {\n          this.messagesChange.emit(params);\n        },\n        onStateChanged: (params) => {\n          this.stateChange.emit(params);\n        },\n        onRunInitialized: (params) => {\n          this._isRunning = true;\n          this.runningSignal.set(true);\n          this.runningChange.emit(true);\n          this.runInitialized.emit(params);\n        },\n        onRunFinalized: (params) => {\n          this._isRunning = false;\n          this.runningSignal.set(false);\n          this.runningChange.emit(false);\n          this.runFinalized.emit(params);\n        },\n        onRunFailed: (params) => {\n          this._isRunning = false;\n          this.runningSignal.set(false);\n          this.runningChange.emit(false);\n          this.runFailed.emit(params);\n        },\n      });\n    }\n  }\n\n  private subscribeToCore(): void {\n    // Subscribe to CopilotKit changes to detect agent updates\n    this.coreUnsubscribe = this.copilotkit.copilotkit.subscribe({\n      onRuntimeLoaded: () => {\n        // Re-check agent when runtime loads\n        this.setupAgent();\n      },\n    });\n  }\n\n  private cleanupAgentSubscription(): void {\n    this.agentSubscription?.unsubscribe();\n    this.agentSubscription = undefined;\n  }\n\n  private cleanupCoreSubscription(): void {\n    this.coreUnsubscribe?.();\n    this.coreUnsubscribe = undefined;\n  }\n}\n"]}
|
|
@@ -0,0 +1,218 @@
|
|
|
1
|
+
import { Directive, Input, Output, EventEmitter, Optional, isDevMode, Inject, } from "@angular/core";
|
|
2
|
+
import { CopilotChatConfigurationService } from "../core/chat-configuration/chat-configuration.service";
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../core/chat-configuration/chat-configuration.service";
|
|
5
|
+
/**
|
|
6
|
+
* Directive for configuring CopilotKit chat settings declaratively in templates.
|
|
7
|
+
* Works with the CopilotChatConfigurationService to provide reactive chat configuration.
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* ```html
|
|
11
|
+
* <!-- Basic usage with individual inputs -->
|
|
12
|
+
* <div copilotkitChatConfig
|
|
13
|
+
* [labels]="customLabels"
|
|
14
|
+
* [inputValue]="currentInput"
|
|
15
|
+
* (submitInput)="onSubmit($event)"
|
|
16
|
+
* (changeInput)="onChange($event)">
|
|
17
|
+
* <!-- Chat UI components -->
|
|
18
|
+
* </div>
|
|
19
|
+
*
|
|
20
|
+
* <!-- Using configuration object -->
|
|
21
|
+
* <div [copilotkitChatConfig]="chatConfig">
|
|
22
|
+
* <!-- Chat UI components -->
|
|
23
|
+
* </div>
|
|
24
|
+
*
|
|
25
|
+
* <!-- Two-way binding for input value -->
|
|
26
|
+
* <div copilotkitChatConfig
|
|
27
|
+
* [(value)]="chatInput"
|
|
28
|
+
* (submitInput)="handleSubmit($event)">
|
|
29
|
+
* <!-- Chat UI components -->
|
|
30
|
+
* </div>
|
|
31
|
+
* ```
|
|
32
|
+
*/
|
|
33
|
+
export class CopilotKitChatConfigDirective {
|
|
34
|
+
chatConfig;
|
|
35
|
+
_value;
|
|
36
|
+
submitHandler;
|
|
37
|
+
changeHandler;
|
|
38
|
+
constructor(chatConfig) {
|
|
39
|
+
this.chatConfig = chatConfig;
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Partial labels to override defaults
|
|
43
|
+
*/
|
|
44
|
+
labels;
|
|
45
|
+
/**
|
|
46
|
+
* The current input value
|
|
47
|
+
*/
|
|
48
|
+
inputValue;
|
|
49
|
+
/**
|
|
50
|
+
* Event emitted when input is submitted
|
|
51
|
+
*/
|
|
52
|
+
submitInput = new EventEmitter();
|
|
53
|
+
/**
|
|
54
|
+
* Event emitted when input value changes
|
|
55
|
+
*/
|
|
56
|
+
changeInput = new EventEmitter();
|
|
57
|
+
/**
|
|
58
|
+
* Alternative: accept full configuration object
|
|
59
|
+
*/
|
|
60
|
+
set config(value) {
|
|
61
|
+
if (value) {
|
|
62
|
+
if (value.labels)
|
|
63
|
+
this.labels = value.labels;
|
|
64
|
+
if (value.inputValue !== undefined)
|
|
65
|
+
this.inputValue = value.inputValue;
|
|
66
|
+
// Store handlers for later setup
|
|
67
|
+
if (value.onSubmitInput)
|
|
68
|
+
this.submitHandler = value.onSubmitInput;
|
|
69
|
+
if (value.onChangeInput)
|
|
70
|
+
this.changeHandler = value.onChangeInput;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* Two-way binding for input value
|
|
75
|
+
*/
|
|
76
|
+
get value() {
|
|
77
|
+
return this._value;
|
|
78
|
+
}
|
|
79
|
+
set value(v) {
|
|
80
|
+
this._value = v;
|
|
81
|
+
this.valueChange.emit(v);
|
|
82
|
+
if (v !== undefined) {
|
|
83
|
+
this.updateInputValue(v);
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* Two-way binding output for value
|
|
88
|
+
*/
|
|
89
|
+
valueChange = new EventEmitter();
|
|
90
|
+
ngOnInit() {
|
|
91
|
+
if (!this.chatConfig) {
|
|
92
|
+
if (isDevMode()) {
|
|
93
|
+
console.warn("CopilotKitChatConfigDirective: No CopilotChatConfigurationService found. " +
|
|
94
|
+
"Make sure to provide it using provideCopilotChatConfiguration().");
|
|
95
|
+
}
|
|
96
|
+
return;
|
|
97
|
+
}
|
|
98
|
+
this.updateConfiguration();
|
|
99
|
+
this.setupHandlers();
|
|
100
|
+
}
|
|
101
|
+
ngOnChanges(changes) {
|
|
102
|
+
if (!this.chatConfig) {
|
|
103
|
+
return;
|
|
104
|
+
}
|
|
105
|
+
const relevantChanges = changes["labels"] || changes["inputValue"] || changes["value"];
|
|
106
|
+
if (relevantChanges && !relevantChanges.firstChange) {
|
|
107
|
+
this.updateConfiguration();
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
ngOnDestroy() {
|
|
111
|
+
// Cleanup if needed
|
|
112
|
+
}
|
|
113
|
+
/**
|
|
114
|
+
* Submit the current input value
|
|
115
|
+
*/
|
|
116
|
+
submit(value) {
|
|
117
|
+
// Emit to template binding
|
|
118
|
+
this.submitInput.emit(value);
|
|
119
|
+
// Call service handler
|
|
120
|
+
if (this.chatConfig) {
|
|
121
|
+
this.chatConfig.submitInput(value);
|
|
122
|
+
}
|
|
123
|
+
// Call provided handler
|
|
124
|
+
if (this.submitHandler) {
|
|
125
|
+
this.submitHandler(value);
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
/**
|
|
129
|
+
* Handle input value change
|
|
130
|
+
*/
|
|
131
|
+
change(value) {
|
|
132
|
+
// Update internal value
|
|
133
|
+
this._value = value;
|
|
134
|
+
// Emit to template bindings
|
|
135
|
+
this.changeInput.emit(value);
|
|
136
|
+
this.valueChange.emit(value);
|
|
137
|
+
// Call service handler
|
|
138
|
+
if (this.chatConfig) {
|
|
139
|
+
this.chatConfig.changeInput(value);
|
|
140
|
+
}
|
|
141
|
+
// Call provided handler
|
|
142
|
+
if (this.changeHandler) {
|
|
143
|
+
this.changeHandler(value);
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
updateConfiguration() {
|
|
147
|
+
if (!this.chatConfig) {
|
|
148
|
+
return;
|
|
149
|
+
}
|
|
150
|
+
// Update labels if provided
|
|
151
|
+
if (this.labels) {
|
|
152
|
+
this.chatConfig.setLabels(this.labels);
|
|
153
|
+
}
|
|
154
|
+
// Update input value if provided
|
|
155
|
+
const valueToSet = this._value !== undefined ? this._value : this.inputValue;
|
|
156
|
+
if (valueToSet !== undefined) {
|
|
157
|
+
this.chatConfig.setInputValue(valueToSet);
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
updateInputValue(value) {
|
|
161
|
+
if (this.chatConfig) {
|
|
162
|
+
this.chatConfig.setInputValue(value);
|
|
163
|
+
this.chatConfig.changeInput(value);
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
setupHandlers() {
|
|
167
|
+
if (!this.chatConfig) {
|
|
168
|
+
return;
|
|
169
|
+
}
|
|
170
|
+
// Create composite handlers that call both service and directive handlers
|
|
171
|
+
const submitComposite = (value) => {
|
|
172
|
+
this.submitInput.emit(value);
|
|
173
|
+
if (this.submitHandler) {
|
|
174
|
+
this.submitHandler(value);
|
|
175
|
+
}
|
|
176
|
+
};
|
|
177
|
+
const changeComposite = (value) => {
|
|
178
|
+
this.changeInput.emit(value);
|
|
179
|
+
this.valueChange.emit(value);
|
|
180
|
+
if (this.changeHandler) {
|
|
181
|
+
this.changeHandler(value);
|
|
182
|
+
}
|
|
183
|
+
};
|
|
184
|
+
// Set handlers on the service
|
|
185
|
+
this.chatConfig.setSubmitHandler(submitComposite);
|
|
186
|
+
this.chatConfig.setChangeHandler(changeComposite);
|
|
187
|
+
}
|
|
188
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CopilotKitChatConfigDirective, deps: [{ token: CopilotChatConfigurationService, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
|
|
189
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: CopilotKitChatConfigDirective, isStandalone: true, selector: "[copilotkitChatConfig]", inputs: { labels: "labels", inputValue: "inputValue", config: ["copilotkitChatConfig", "config"], value: "value" }, outputs: { submitInput: "submitInput", changeInput: "changeInput", valueChange: "valueChange" }, usesOnChanges: true, ngImport: i0 });
|
|
190
|
+
}
|
|
191
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CopilotKitChatConfigDirective, decorators: [{
|
|
192
|
+
type: Directive,
|
|
193
|
+
args: [{
|
|
194
|
+
selector: "[copilotkitChatConfig]",
|
|
195
|
+
standalone: true,
|
|
196
|
+
}]
|
|
197
|
+
}], ctorParameters: () => [{ type: i1.CopilotChatConfigurationService, decorators: [{
|
|
198
|
+
type: Optional
|
|
199
|
+
}, {
|
|
200
|
+
type: Inject,
|
|
201
|
+
args: [CopilotChatConfigurationService]
|
|
202
|
+
}] }], propDecorators: { labels: [{
|
|
203
|
+
type: Input
|
|
204
|
+
}], inputValue: [{
|
|
205
|
+
type: Input
|
|
206
|
+
}], submitInput: [{
|
|
207
|
+
type: Output
|
|
208
|
+
}], changeInput: [{
|
|
209
|
+
type: Output
|
|
210
|
+
}], config: [{
|
|
211
|
+
type: Input,
|
|
212
|
+
args: ["copilotkitChatConfig"]
|
|
213
|
+
}], value: [{
|
|
214
|
+
type: Input
|
|
215
|
+
}], valueChange: [{
|
|
216
|
+
type: Output
|
|
217
|
+
}] } });
|
|
218
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"copilotkit-chat-config.directive.js","sourceRoot":"","sources":["../../../src/directives/copilotkit-chat-config.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  Input,\n  Output,\n  EventEmitter,\n  OnInit,\n  OnChanges,\n  OnDestroy,\n  SimpleChanges,\n  Optional,\n  isDevMode,\n  Inject,\n} from \"@angular/core\";\nimport { CopilotChatConfigurationService } from \"../core/chat-configuration/chat-configuration.service\";\nimport {\n  CopilotChatConfiguration,\n  CopilotChatLabels,\n} from \"../core/chat-configuration/chat-configuration.types\";\n\n/**\n * Directive for configuring CopilotKit chat settings declaratively in templates.\n * Works with the CopilotChatConfigurationService to provide reactive chat configuration.\n *\n * @example\n * ```html\n * <!-- Basic usage with individual inputs -->\n * <div copilotkitChatConfig\n *      [labels]=\"customLabels\"\n *      [inputValue]=\"currentInput\"\n *      (submitInput)=\"onSubmit($event)\"\n *      (changeInput)=\"onChange($event)\">\n *   <!-- Chat UI components -->\n * </div>\n *\n * <!-- Using configuration object -->\n * <div [copilotkitChatConfig]=\"chatConfig\">\n *   <!-- Chat UI components -->\n * </div>\n *\n * <!-- Two-way binding for input value -->\n * <div copilotkitChatConfig\n *      [(value)]=\"chatInput\"\n *      (submitInput)=\"handleSubmit($event)\">\n *   <!-- Chat UI components -->\n * </div>\n * ```\n */\n@Directive({\n  selector: \"[copilotkitChatConfig]\",\n  standalone: true,\n})\nexport class CopilotKitChatConfigDirective\n  implements OnInit, OnChanges, OnDestroy\n{\n  private _value?: string;\n  private submitHandler?: (value: string) => void;\n  private changeHandler?: (value: string) => void;\n\n  constructor(\n    @Optional()\n    @Inject(CopilotChatConfigurationService)\n    private readonly chatConfig: CopilotChatConfigurationService | null\n  ) {}\n\n  /**\n   * Partial labels to override defaults\n   */\n  @Input() labels?: Partial<CopilotChatLabels>;\n\n  /**\n   * The current input value\n   */\n  @Input() inputValue?: string;\n\n  /**\n   * Event emitted when input is submitted\n   */\n  @Output() submitInput = new EventEmitter<string>();\n\n  /**\n   * Event emitted when input value changes\n   */\n  @Output() changeInput = new EventEmitter<string>();\n\n  /**\n   * Alternative: accept full configuration object\n   */\n  @Input(\"copilotkitChatConfig\")\n  set config(value: CopilotChatConfiguration | undefined) {\n    if (value) {\n      if (value.labels) this.labels = value.labels;\n      if (value.inputValue !== undefined) this.inputValue = value.inputValue;\n      // Store handlers for later setup\n      if (value.onSubmitInput) this.submitHandler = value.onSubmitInput;\n      if (value.onChangeInput) this.changeHandler = value.onChangeInput;\n    }\n  }\n\n  /**\n   * Two-way binding for input value\n   */\n  @Input()\n  get value(): string | undefined {\n    return this._value;\n  }\n  set value(v: string | undefined) {\n    this._value = v;\n    this.valueChange.emit(v);\n    if (v !== undefined) {\n      this.updateInputValue(v);\n    }\n  }\n\n  /**\n   * Two-way binding output for value\n   */\n  @Output() valueChange = new EventEmitter<string | undefined>();\n\n  ngOnInit(): void {\n    if (!this.chatConfig) {\n      if (isDevMode()) {\n        console.warn(\n          \"CopilotKitChatConfigDirective: No CopilotChatConfigurationService found. \" +\n            \"Make sure to provide it using provideCopilotChatConfiguration().\"\n        );\n      }\n      return;\n    }\n\n    this.updateConfiguration();\n    this.setupHandlers();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (!this.chatConfig) {\n      return;\n    }\n\n    const relevantChanges =\n      changes[\"labels\"] || changes[\"inputValue\"] || changes[\"value\"];\n\n    if (relevantChanges && !relevantChanges.firstChange) {\n      this.updateConfiguration();\n    }\n  }\n\n  ngOnDestroy(): void {\n    // Cleanup if needed\n  }\n\n  /**\n   * Submit the current input value\n   */\n  submit(value: string): void {\n    // Emit to template binding\n    this.submitInput.emit(value);\n\n    // Call service handler\n    if (this.chatConfig) {\n      this.chatConfig.submitInput(value);\n    }\n\n    // Call provided handler\n    if (this.submitHandler) {\n      this.submitHandler(value);\n    }\n  }\n\n  /**\n   * Handle input value change\n   */\n  change(value: string): void {\n    // Update internal value\n    this._value = value;\n\n    // Emit to template bindings\n    this.changeInput.emit(value);\n    this.valueChange.emit(value);\n\n    // Call service handler\n    if (this.chatConfig) {\n      this.chatConfig.changeInput(value);\n    }\n\n    // Call provided handler\n    if (this.changeHandler) {\n      this.changeHandler(value);\n    }\n  }\n\n  private updateConfiguration(): void {\n    if (!this.chatConfig) {\n      return;\n    }\n\n    // Update labels if provided\n    if (this.labels) {\n      this.chatConfig.setLabels(this.labels);\n    }\n\n    // Update input value if provided\n    const valueToSet =\n      this._value !== undefined ? this._value : this.inputValue;\n    if (valueToSet !== undefined) {\n      this.chatConfig.setInputValue(valueToSet);\n    }\n  }\n\n  private updateInputValue(value: string): void {\n    if (this.chatConfig) {\n      this.chatConfig.setInputValue(value);\n      this.chatConfig.changeInput(value);\n    }\n  }\n\n  private setupHandlers(): void {\n    if (!this.chatConfig) {\n      return;\n    }\n\n    // Create composite handlers that call both service and directive handlers\n    const submitComposite = (value: string) => {\n      this.submitInput.emit(value);\n      if (this.submitHandler) {\n        this.submitHandler(value);\n      }\n    };\n\n    const changeComposite = (value: string) => {\n      this.changeInput.emit(value);\n      this.valueChange.emit(value);\n      if (this.changeHandler) {\n        this.changeHandler(value);\n      }\n    };\n\n    // Set handlers on the service\n    this.chatConfig.setSubmitHandler(submitComposite);\n    this.chatConfig.setChangeHandler(changeComposite);\n  }\n}\n"]}
|