@copilotkitnext/angular 0.0.1 → 0.0.4

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.
Files changed (171) hide show
  1. package/README.md +248 -0
  2. package/dist/README.md +248 -0
  3. package/dist/components/chat/copilot-chat-assistant-message.component.d.ts +10 -10
  4. package/dist/components/chat/copilot-chat-message-view.component.d.ts +42 -42
  5. package/dist/components/chat/copilot-chat-view.component.d.ts +14 -14
  6. package/dist/esm2022/components/chat/copilot-chat-assistant-message-buttons.component.mjs +384 -0
  7. package/dist/esm2022/components/chat/copilot-chat-assistant-message-renderer.component.mjs +286 -0
  8. package/dist/esm2022/components/chat/copilot-chat-assistant-message-toolbar.component.mjs +27 -0
  9. package/dist/esm2022/components/chat/copilot-chat-assistant-message.component.mjs +433 -0
  10. package/dist/esm2022/components/chat/copilot-chat-assistant-message.types.mjs +2 -0
  11. package/dist/esm2022/components/chat/copilot-chat-audio-recorder.component.mjs +202 -0
  12. package/dist/esm2022/components/chat/copilot-chat-buttons.component.mjs +321 -0
  13. package/dist/esm2022/components/chat/copilot-chat-input-defaults.mjs +38 -0
  14. package/dist/esm2022/components/chat/copilot-chat-input.component.mjs +666 -0
  15. package/dist/esm2022/components/chat/copilot-chat-input.types.mjs +10 -0
  16. package/dist/esm2022/components/chat/copilot-chat-message-view-cursor.component.mjs +45 -0
  17. package/dist/esm2022/components/chat/copilot-chat-message-view.component.mjs +296 -0
  18. package/dist/esm2022/components/chat/copilot-chat-message-view.types.mjs +2 -0
  19. package/dist/esm2022/components/chat/copilot-chat-textarea.component.mjs +188 -0
  20. package/dist/esm2022/components/chat/copilot-chat-tool-calls-view.component.mjs +216 -0
  21. package/dist/esm2022/components/chat/copilot-chat-toolbar.component.mjs +25 -0
  22. package/dist/esm2022/components/chat/copilot-chat-tools-menu.component.mjs +199 -0
  23. package/dist/esm2022/components/chat/copilot-chat-user-message-branch-navigation.component.mjs +137 -0
  24. package/dist/esm2022/components/chat/copilot-chat-user-message-buttons.component.mjs +207 -0
  25. package/dist/esm2022/components/chat/copilot-chat-user-message-renderer.component.mjs +35 -0
  26. package/dist/esm2022/components/chat/copilot-chat-user-message-toolbar.component.mjs +34 -0
  27. package/dist/esm2022/components/chat/copilot-chat-user-message.component.mjs +341 -0
  28. package/dist/esm2022/components/chat/copilot-chat-user-message.types.mjs +2 -0
  29. package/dist/esm2022/components/chat/copilot-chat-view-disclaimer.component.mjs +52 -0
  30. package/dist/esm2022/components/chat/copilot-chat-view-feather.component.mjs +55 -0
  31. package/dist/esm2022/components/chat/copilot-chat-view-handlers.service.mjs +19 -0
  32. package/dist/esm2022/components/chat/copilot-chat-view-input-container.component.mjs +110 -0
  33. package/dist/esm2022/components/chat/copilot-chat-view-scroll-to-bottom-button.component.mjs +93 -0
  34. package/dist/esm2022/components/chat/copilot-chat-view-scroll-view.component.mjs +443 -0
  35. package/dist/esm2022/components/chat/copilot-chat-view.component.mjs +479 -0
  36. package/dist/esm2022/components/chat/copilot-chat-view.types.mjs +2 -0
  37. package/dist/esm2022/components/chat/copilot-chat.component.mjs +214 -0
  38. package/dist/esm2022/components/copilotkit-tool-render.component.mjs +153 -0
  39. package/dist/esm2022/copilotkitnext-angular.mjs +5 -0
  40. package/dist/esm2022/core/chat-configuration/chat-configuration.providers.mjs +65 -0
  41. package/dist/esm2022/core/chat-configuration/chat-configuration.service.mjs +145 -0
  42. package/dist/esm2022/core/chat-configuration/chat-configuration.types.mjs +26 -0
  43. package/dist/esm2022/core/copilotkit.providers.mjs +34 -0
  44. package/dist/esm2022/core/copilotkit.service.mjs +430 -0
  45. package/dist/esm2022/core/copilotkit.types.mjs +12 -0
  46. package/dist/esm2022/directives/copilotkit-agent-context.directive.mjs +130 -0
  47. package/dist/esm2022/directives/copilotkit-agent.directive.mjs +217 -0
  48. package/dist/esm2022/directives/copilotkit-chat-config.directive.mjs +218 -0
  49. package/dist/esm2022/directives/copilotkit-config.directive.mjs +94 -0
  50. package/dist/esm2022/directives/copilotkit-frontend-tool.directive.mjs +130 -0
  51. package/dist/esm2022/directives/copilotkit-human-in-the-loop.directive.mjs +266 -0
  52. package/dist/esm2022/directives/stick-to-bottom.directive.mjs +181 -0
  53. package/dist/esm2022/index.mjs +70 -0
  54. package/dist/esm2022/lib/directives/tooltip.directive.mjs +211 -0
  55. package/dist/esm2022/lib/slots/copilot-slot.component.mjs +144 -0
  56. package/dist/esm2022/lib/slots/slot.types.mjs +6 -0
  57. package/dist/esm2022/lib/slots/slot.utils.mjs +222 -0
  58. package/dist/esm2022/lib/utils.mjs +10 -0
  59. package/dist/esm2022/services/resize-observer.service.mjs +152 -0
  60. package/dist/esm2022/services/scroll-position.service.mjs +124 -0
  61. package/dist/esm2022/types/frontend-tool.mjs +2 -0
  62. package/dist/esm2022/types/human-in-the-loop.mjs +2 -0
  63. package/dist/esm2022/utils/agent-context.utils.mjs +114 -0
  64. package/dist/esm2022/utils/agent.utils.mjs +204 -0
  65. package/dist/esm2022/utils/chat-config.utils.mjs +186 -0
  66. package/dist/esm2022/utils/copilotkit.utils.mjs +20 -0
  67. package/dist/esm2022/utils/frontend-tool.utils.mjs +228 -0
  68. package/dist/esm2022/utils/human-in-the-loop.utils.mjs +296 -0
  69. package/dist/fesm2022/copilotkitnext-angular.mjs +163 -164
  70. package/dist/fesm2022/copilotkitnext-angular.mjs.map +1 -1
  71. package/dist/styles.css +0 -27
  72. package/package.json +23 -20
  73. package/vitest.config.mts +32 -21
  74. package/.turbo/turbo-build.log +0 -39
  75. package/.turbo/turbo-check-types.log +0 -0
  76. package/.turbo/turbo-test.log +0 -71
  77. package/README-agent-context.md +0 -310
  78. package/ng-package.json +0 -19
  79. package/slots.md +0 -331
  80. package/src/components/chat/__tests__/copilot-chat-assistant-message.component.spec.ts +0 -282
  81. package/src/components/chat/__tests__/copilot-chat-input.component.spec.ts +0 -419
  82. package/src/components/chat/__tests__/copilot-chat-message-view.component.spec.ts +0 -372
  83. package/src/components/chat/__tests__/copilot-chat-user-message.component.spec.ts +0 -249
  84. package/src/components/chat/copilot-chat-assistant-message-buttons.component.ts +0 -292
  85. package/src/components/chat/copilot-chat-assistant-message-renderer.component.ts +0 -472
  86. package/src/components/chat/copilot-chat-assistant-message-toolbar.component.ts +0 -29
  87. package/src/components/chat/copilot-chat-assistant-message.component.ts +0 -463
  88. package/src/components/chat/copilot-chat-assistant-message.types.ts +0 -50
  89. package/src/components/chat/copilot-chat-audio-recorder.component.ts +0 -241
  90. package/src/components/chat/copilot-chat-buttons.component.ts +0 -308
  91. package/src/components/chat/copilot-chat-buttons.component.ts.bak +0 -471
  92. package/src/components/chat/copilot-chat-input-defaults.ts +0 -47
  93. package/src/components/chat/copilot-chat-input.component.ts +0 -512
  94. package/src/components/chat/copilot-chat-input.types.ts +0 -148
  95. package/src/components/chat/copilot-chat-message-view-cursor.component.ts +0 -51
  96. package/src/components/chat/copilot-chat-message-view.component.ts +0 -233
  97. package/src/components/chat/copilot-chat-message-view.types.ts +0 -39
  98. package/src/components/chat/copilot-chat-textarea.component.ts +0 -220
  99. package/src/components/chat/copilot-chat-tool-calls-view.component.ts +0 -261
  100. package/src/components/chat/copilot-chat-toolbar.component.ts +0 -35
  101. package/src/components/chat/copilot-chat-tools-menu.component.ts +0 -185
  102. package/src/components/chat/copilot-chat-user-message-branch-navigation.component.ts +0 -121
  103. package/src/components/chat/copilot-chat-user-message-buttons.component.ts +0 -170
  104. package/src/components/chat/copilot-chat-user-message-renderer.component.ts +0 -37
  105. package/src/components/chat/copilot-chat-user-message-toolbar.component.ts +0 -37
  106. package/src/components/chat/copilot-chat-user-message.component.ts +0 -247
  107. package/src/components/chat/copilot-chat-user-message.types.ts +0 -42
  108. package/src/components/chat/copilot-chat-view-disclaimer.component.ts +0 -51
  109. package/src/components/chat/copilot-chat-view-feather.component.ts +0 -47
  110. package/src/components/chat/copilot-chat-view-handlers.service.ts +0 -14
  111. package/src/components/chat/copilot-chat-view-input-container.component.ts +0 -87
  112. package/src/components/chat/copilot-chat-view-scroll-to-bottom-button.component.ts +0 -79
  113. package/src/components/chat/copilot-chat-view-scroll-view.component.ts +0 -322
  114. package/src/components/chat/copilot-chat-view.component.ts +0 -420
  115. package/src/components/chat/copilot-chat-view.types.ts +0 -52
  116. package/src/components/chat/copilot-chat.component.ts +0 -232
  117. package/src/components/copilotkit-tool-render.component.ts +0 -169
  118. package/src/core/__tests__/copilotkit.service.spec.ts +0 -1051
  119. package/src/core/__tests__/copilotkit.service.wildcard.spec.ts +0 -316
  120. package/src/core/chat-configuration/__tests__/chat-configuration.service.spec.ts +0 -287
  121. package/src/core/chat-configuration/chat-configuration.providers.ts +0 -71
  122. package/src/core/chat-configuration/chat-configuration.service.ts +0 -162
  123. package/src/core/chat-configuration/chat-configuration.types.ts +0 -57
  124. package/src/core/copilotkit.providers.ts +0 -59
  125. package/src/core/copilotkit.service.ts +0 -542
  126. package/src/core/copilotkit.types.ts +0 -132
  127. package/src/directives/__tests__/copilotkit-agent-context.directive.spec.ts +0 -384
  128. package/src/directives/__tests__/copilotkit-agent.directive.spec.ts +0 -253
  129. package/src/directives/__tests__/copilotkit-chat-config.directive.spec.ts +0 -385
  130. package/src/directives/__tests__/copilotkit-config.directive.spec.ts +0 -69
  131. package/src/directives/__tests__/copilotkit-frontend-tool-simple.directive.spec.ts +0 -60
  132. package/src/directives/__tests__/copilotkit-frontend-tool.directive.spec.ts +0 -108
  133. package/src/directives/__tests__/copilotkit-human-in-the-loop.directive.spec.ts +0 -452
  134. package/src/directives/copilotkit-agent-context.directive.ts +0 -138
  135. package/src/directives/copilotkit-agent.directive.ts +0 -225
  136. package/src/directives/copilotkit-chat-config.directive.ts +0 -241
  137. package/src/directives/copilotkit-config.directive.ts +0 -81
  138. package/src/directives/copilotkit-frontend-tool.directive.ts +0 -145
  139. package/src/directives/copilotkit-human-in-the-loop.directive.ts +0 -281
  140. package/src/directives/stick-to-bottom.directive.ts +0 -204
  141. package/src/index.ts +0 -105
  142. package/src/lib/directives/tooltip.directive.ts +0 -292
  143. package/src/lib/slots/__tests__/slot.utils.spec.ts +0 -377
  144. package/src/lib/slots/copilot-slot.component.ts +0 -135
  145. package/src/lib/slots/index.ts +0 -3
  146. package/src/lib/slots/slot.types.ts +0 -64
  147. package/src/lib/slots/slot.utils.ts +0 -289
  148. package/src/lib/utils.ts +0 -10
  149. package/src/public-api.ts +0 -1
  150. package/src/services/resize-observer.service.ts +0 -181
  151. package/src/services/scroll-position.service.ts +0 -169
  152. package/src/styles/globals.css +0 -266
  153. package/src/styles/index.css +0 -3
  154. package/src/test-setup.ts +0 -15
  155. package/src/testing/index.ts +0 -3
  156. package/src/testing/testing.utils.ts +0 -248
  157. package/src/types/frontend-tool.ts +0 -44
  158. package/src/types/human-in-the-loop.ts +0 -52
  159. package/src/utils/__tests__/agent.utils.spec.ts +0 -234
  160. package/src/utils/__tests__/chat-config.utils.spec.ts +0 -306
  161. package/src/utils/__tests__/frontend-tool-inject.spec.ts +0 -350
  162. package/src/utils/__tests__/frontend-tool-integration.spec.ts +0 -199
  163. package/src/utils/__tests__/frontend-tool.utils.spec.ts +0 -272
  164. package/src/utils/__tests__/human-in-the-loop.utils.spec.ts +0 -365
  165. package/src/utils/agent-context.utils.ts +0 -133
  166. package/src/utils/agent.utils.ts +0 -239
  167. package/src/utils/chat-config.utils.ts +0 -221
  168. package/src/utils/copilotkit.utils.ts +0 -20
  169. package/src/utils/frontend-tool.utils.ts +0 -266
  170. package/src/utils/human-in-the-loop.utils.ts +0 -359
  171. 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"]}