@copilotkitnext/angular 0.0.7 → 0.0.9-alpha.0

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.
@@ -2,6 +2,7 @@ import { DestroyRef, inject, signal, computed, runInInjectionContext, } from "@a
2
2
  import { toObservable } from "@angular/core/rxjs-interop";
3
3
  import { CopilotKitService } from "../core/copilotkit.service";
4
4
  import { DEFAULT_AGENT_ID } from "@copilotkitnext/shared";
5
+ import { CopilotKitCoreRuntimeConnectionStatus } from "@copilotkitnext/core";
5
6
  /**
6
7
  * Watches an agent and provides reactive signals for its state.
7
8
  * Must be called within an injection context.
@@ -84,15 +85,14 @@ export function watchAgent(config) {
84
85
  subscribeToAgent();
85
86
  // Subscribe to CopilotKit changes to detect agent updates
86
87
  const coreUnsubscribe = service.copilotkit.subscribe({
87
- onRuntimeLoaded() {
88
- // Re-check agent when runtime loads
89
- currentAgent = updateAgent();
90
- subscribeToAgent();
91
- },
92
- onRuntimeLoadError() {
93
- // Also re-check agent on runtime load error to ensure consistency
94
- currentAgent = updateAgent();
95
- subscribeToAgent();
88
+ onRuntimeConnectionStatusChanged({ status }) {
89
+ if (status === CopilotKitCoreRuntimeConnectionStatus.Connected ||
90
+ status === CopilotKitCoreRuntimeConnectionStatus.Disconnected ||
91
+ status === CopilotKitCoreRuntimeConnectionStatus.Error) {
92
+ // Re-check agent when runtime connection state changes
93
+ currentAgent = updateAgent();
94
+ subscribeToAgent();
95
+ }
96
96
  },
97
97
  });
98
98
  // Register cleanup
@@ -209,4 +209,4 @@ export function subscribeToAgent(service, agentId, callbacks) {
209
209
  });
210
210
  return () => subscription.unsubscribe();
211
211
  }
212
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"agent.utils.js","sourceRoot":"","sources":["../../../src/utils/agent.utils.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  DestroyRef,\n  inject,\n  signal,\n  computed,\n  Injector,\n  runInInjectionContext,\n} from \"@angular/core\";\nimport { toObservable } from \"@angular/core/rxjs-interop\";\nimport { CopilotKitService } from \"../core/copilotkit.service\";\nimport {\n  AgentSubscriptionCallbacks,\n  AgentWatchResult,\n} from \"../core/copilotkit.types\";\nimport { AbstractAgent } from \"@ag-ui/client\";\nimport { DEFAULT_AGENT_ID } from \"@copilotkitnext/shared\";\n\n/**\n * Watches an agent and provides reactive signals for its state.\n * Must be called within an injection context.\n * Automatically cleans up when the component/service is destroyed.\n *\n * @param config - Optional configuration with agentId\n * @returns Object with agent, messages, and isRunning signals plus observables\n *\n * @example\n * ```typescript\n * export class MyComponent {\n *   // Automatically tracks agent state\n *   agentState = watchAgent({ agentId: 'my-agent' });\n *\n *   constructor() {\n *     effect(() => {\n *       const messages = this.agentState.messages();\n *       const isRunning = this.agentState.isRunning();\n *       console.log('Messages:', messages.length, 'Running:', isRunning);\n *     });\n *   }\n * }\n * ```\n */\nexport function watchAgent(config?: { agentId?: string }): AgentWatchResult {\n  // Use inject() internally to get required services\n  const service = inject(CopilotKitService);\n  const destroyRef = inject(DestroyRef);\n  const effectiveAgentId = config?.agentId ?? DEFAULT_AGENT_ID;\n\n  // Create reactive signals with tick mechanism for reliable updates\n  const agentSignal = signal<AbstractAgent | undefined>(undefined);\n  const tick = signal<number>(0);\n  const isRunningSignal = signal<boolean>(false);\n\n  // Create computed messages signal that reacts to tick changes\n  const messages = computed(() => {\n    // Access tick to ensure recomputation\n    tick();\n    const a = agentSignal();\n    if (!a) return [];\n    // Return a shallow clone to ensure change detection\n    return a.messages.map((m) => ({ ...m }));\n  });\n\n  // Get initial agent\n  const updateAgent = () => {\n    const agent = service.copilotkit.getAgent(effectiveAgentId);\n    agentSignal.set(agent);\n    return agent;\n  };\n\n  // Initial update\n  let currentAgent = updateAgent();\n\n  // Subscribe to agent changes\n  let agentSubscription: { unsubscribe: () => void } | undefined;\n\n  const subscribeToAgent = () => {\n    // Unsubscribe from previous agent if any\n    agentSubscription?.unsubscribe();\n\n    if (currentAgent) {\n      agentSubscription = currentAgent.subscribe({\n        onMessagesChanged() {\n          // Increment tick to force recomputation of messages computed\n          tick.update((v) => v + 1);\n        },\n        onStateChanged() {\n          // Increment tick to force recomputation\n          tick.update((v) => v + 1);\n        },\n        onRunInitialized() {\n          isRunningSignal.set(true);\n        },\n        onRunFinalized() {\n          isRunningSignal.set(false);\n        },\n        onRunFailed() {\n          isRunningSignal.set(false);\n        },\n      });\n    }\n  };\n\n  // Initial subscription\n  subscribeToAgent();\n\n  // Subscribe to CopilotKit changes to detect agent updates\n  const coreUnsubscribe = service.copilotkit.subscribe({\n    onRuntimeLoaded() {\n      // Re-check agent when runtime loads\n      currentAgent = updateAgent();\n      subscribeToAgent();\n    },\n    onRuntimeLoadError() {\n      // Also re-check agent on runtime load error to ensure consistency\n      currentAgent = updateAgent();\n      subscribeToAgent();\n    },\n  });\n\n  // Register cleanup\n  const unsubscribe = () => {\n    agentSubscription?.unsubscribe();\n    coreUnsubscribe(); // subscribe returns a function directly\n  };\n\n  destroyRef.onDestroy(unsubscribe);\n\n  // Create observables from signals using toObservable\n  const agent$ = toObservable(agentSignal);\n  const isRunning$ = toObservable(isRunningSignal);\n  const messages$ = toObservable(messages);\n\n  return {\n    agent: agentSignal.asReadonly(),\n    messages: messages,\n    isRunning: isRunningSignal.asReadonly(),\n    agent$,\n    messages$,\n    isRunning$,\n    unsubscribe,\n  };\n}\n\n/**\n * Gets an agent by ID without subscribing to changes.\n *\n * @param service - The CopilotKitService instance\n * @param agentId - Optional agent ID (defaults to DEFAULT_AGENT_ID)\n * @returns The agent or undefined if not found\n *\n * @example\n * ```typescript\n * export class MyComponent {\n *   constructor(private copilotkit: CopilotKitService) {}\n *\n *   getCurrentAgent() {\n *     return getAgent(this.copilotkit, 'my-agent');\n *   }\n * }\n * ```\n */\nexport function getAgent(\n  service: CopilotKitService,\n  agentId?: string\n): AbstractAgent | undefined {\n  const effectiveAgentId = agentId ?? DEFAULT_AGENT_ID;\n  return service.copilotkit.getAgent(effectiveAgentId);\n}\n\n// Re-export the type for convenience (the actual type is in copilotkit.types)\nexport type { AgentWatchResult } from \"../core/copilotkit.types\";\n\n/**\n * Convenience wrapper for watchAgent that handles injection context.\n * Useful when you need to call watchAgent outside of a constructor or field initializer.\n *\n * @param injector - The Angular Injector to use for injection context\n * @param config - Optional configuration with agentId\n * @returns Object with agent, messages, and isRunning signals plus observables\n *\n * @example\n * ```typescript\n * export class MyComponent {\n *   constructor(private injector: Injector) {}\n *\n *   switchAgent(newAgentId: string) {\n *     // Can call outside of constructor using watchAgentWith\n *     const watcher = watchAgentWith(this.injector, { agentId: newAgentId });\n *     this.agent = watcher.agent;\n *     this.messages = watcher.messages;\n *     this.isRunning = watcher.isRunning;\n *   }\n * }\n * ```\n */\nexport function watchAgentWith(\n  injector: Injector,\n  config?: { agentId?: string }\n): AgentWatchResult {\n  return runInInjectionContext(injector, () => watchAgent(config));\n}\n\n/**\n * Subscribes to an agent's events with custom callbacks.\n * Returns a cleanup function that should be called to unsubscribe.\n *\n * @param service - The CopilotKitService instance\n * @param agentId - Optional agent ID (defaults to DEFAULT_AGENT_ID)\n * @param callbacks - Event callbacks\n * @returns Cleanup function to unsubscribe\n *\n * @example\n * ```typescript\n * export class MyComponent implements OnInit, OnDestroy {\n *   private unsubscribe?: () => void;\n *\n *   constructor(private copilotkit: CopilotKitService) {}\n *\n *   ngOnInit() {\n *     this.unsubscribe = subscribeToAgent(this.copilotkit, 'my-agent', {\n *       onRunInitialized: () => console.log('Run started'),\n *       onRunFinalized: () => console.log('Run completed'),\n *       onRunFailed: (error) => console.error('Run failed', error),\n *     });\n *   }\n *\n *   ngOnDestroy() {\n *     this.unsubscribe?.();\n *   }\n * }\n * ```\n */\nexport function subscribeToAgent(\n  service: CopilotKitService,\n  agentId?: string,\n  callbacks?: AgentSubscriptionCallbacks\n): () => void {\n  const effectiveAgentId = agentId ?? DEFAULT_AGENT_ID;\n  const agent = service.copilotkit.getAgent(effectiveAgentId);\n\n  if (!agent) {\n    // Return no-op cleanup if agent doesn't exist\n    return () => {};\n  }\n\n  const subscription = agent.subscribe({\n    onMessagesChanged: callbacks?.onMessagesChanged,\n    onStateChanged: callbacks?.onStateChanged,\n    onRunInitialized: callbacks?.onRunInitialized,\n    onRunFinalized: callbacks?.onRunFinalized,\n    onRunFailed: callbacks?.onRunFailed,\n  });\n\n  return () => subscription.unsubscribe();\n}\n"]}
212
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"agent.utils.js","sourceRoot":"","sources":["../../../src/utils/agent.utils.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  DestroyRef,\n  inject,\n  signal,\n  computed,\n  Injector,\n  runInInjectionContext,\n} from \"@angular/core\";\nimport { toObservable } from \"@angular/core/rxjs-interop\";\nimport { CopilotKitService } from \"../core/copilotkit.service\";\nimport {\n  AgentSubscriptionCallbacks,\n  AgentWatchResult,\n} from \"../core/copilotkit.types\";\nimport { AbstractAgent } from \"@ag-ui/client\";\nimport { DEFAULT_AGENT_ID } from \"@copilotkitnext/shared\";\nimport { CopilotKitCoreRuntimeConnectionStatus } from \"@copilotkitnext/core\";\n\n/**\n * Watches an agent and provides reactive signals for its state.\n * Must be called within an injection context.\n * Automatically cleans up when the component/service is destroyed.\n *\n * @param config - Optional configuration with agentId\n * @returns Object with agent, messages, and isRunning signals plus observables\n *\n * @example\n * ```typescript\n * export class MyComponent {\n *   // Automatically tracks agent state\n *   agentState = watchAgent({ agentId: 'my-agent' });\n *\n *   constructor() {\n *     effect(() => {\n *       const messages = this.agentState.messages();\n *       const isRunning = this.agentState.isRunning();\n *       console.log('Messages:', messages.length, 'Running:', isRunning);\n *     });\n *   }\n * }\n * ```\n */\nexport function watchAgent(config?: { agentId?: string }): AgentWatchResult {\n  // Use inject() internally to get required services\n  const service = inject(CopilotKitService);\n  const destroyRef = inject(DestroyRef);\n  const effectiveAgentId = config?.agentId ?? DEFAULT_AGENT_ID;\n\n  // Create reactive signals with tick mechanism for reliable updates\n  const agentSignal = signal<AbstractAgent | undefined>(undefined);\n  const tick = signal<number>(0);\n  const isRunningSignal = signal<boolean>(false);\n\n  // Create computed messages signal that reacts to tick changes\n  const messages = computed(() => {\n    // Access tick to ensure recomputation\n    tick();\n    const a = agentSignal();\n    if (!a) return [];\n    // Return a shallow clone to ensure change detection\n    return a.messages.map((m) => ({ ...m }));\n  });\n\n  // Get initial agent\n  const updateAgent = () => {\n    const agent = service.copilotkit.getAgent(effectiveAgentId);\n    agentSignal.set(agent);\n    return agent;\n  };\n\n  // Initial update\n  let currentAgent = updateAgent();\n\n  // Subscribe to agent changes\n  let agentSubscription: { unsubscribe: () => void } | undefined;\n\n  const subscribeToAgent = () => {\n    // Unsubscribe from previous agent if any\n    agentSubscription?.unsubscribe();\n\n    if (currentAgent) {\n      agentSubscription = currentAgent.subscribe({\n        onMessagesChanged() {\n          // Increment tick to force recomputation of messages computed\n          tick.update((v) => v + 1);\n        },\n        onStateChanged() {\n          // Increment tick to force recomputation\n          tick.update((v) => v + 1);\n        },\n        onRunInitialized() {\n          isRunningSignal.set(true);\n        },\n        onRunFinalized() {\n          isRunningSignal.set(false);\n        },\n        onRunFailed() {\n          isRunningSignal.set(false);\n        },\n      });\n    }\n  };\n\n  // Initial subscription\n  subscribeToAgent();\n\n  // Subscribe to CopilotKit changes to detect agent updates\n  const coreUnsubscribe = service.copilotkit.subscribe({\n    onRuntimeConnectionStatusChanged({ status }) {\n      if (\n        status === CopilotKitCoreRuntimeConnectionStatus.Connected ||\n        status === CopilotKitCoreRuntimeConnectionStatus.Disconnected ||\n        status === CopilotKitCoreRuntimeConnectionStatus.Error\n      ) {\n        // Re-check agent when runtime connection state changes\n        currentAgent = updateAgent();\n        subscribeToAgent();\n      }\n    },\n  });\n\n  // Register cleanup\n  const unsubscribe = () => {\n    agentSubscription?.unsubscribe();\n    coreUnsubscribe(); // subscribe returns a function directly\n  };\n\n  destroyRef.onDestroy(unsubscribe);\n\n  // Create observables from signals using toObservable\n  const agent$ = toObservable(agentSignal);\n  const isRunning$ = toObservable(isRunningSignal);\n  const messages$ = toObservable(messages);\n\n  return {\n    agent: agentSignal.asReadonly(),\n    messages: messages,\n    isRunning: isRunningSignal.asReadonly(),\n    agent$,\n    messages$,\n    isRunning$,\n    unsubscribe,\n  };\n}\n\n/**\n * Gets an agent by ID without subscribing to changes.\n *\n * @param service - The CopilotKitService instance\n * @param agentId - Optional agent ID (defaults to DEFAULT_AGENT_ID)\n * @returns The agent or undefined if not found\n *\n * @example\n * ```typescript\n * export class MyComponent {\n *   constructor(private copilotkit: CopilotKitService) {}\n *\n *   getCurrentAgent() {\n *     return getAgent(this.copilotkit, 'my-agent');\n *   }\n * }\n * ```\n */\nexport function getAgent(\n  service: CopilotKitService,\n  agentId?: string\n): AbstractAgent | undefined {\n  const effectiveAgentId = agentId ?? DEFAULT_AGENT_ID;\n  return service.copilotkit.getAgent(effectiveAgentId);\n}\n\n// Re-export the type for convenience (the actual type is in copilotkit.types)\nexport type { AgentWatchResult } from \"../core/copilotkit.types\";\n\n/**\n * Convenience wrapper for watchAgent that handles injection context.\n * Useful when you need to call watchAgent outside of a constructor or field initializer.\n *\n * @param injector - The Angular Injector to use for injection context\n * @param config - Optional configuration with agentId\n * @returns Object with agent, messages, and isRunning signals plus observables\n *\n * @example\n * ```typescript\n * export class MyComponent {\n *   constructor(private injector: Injector) {}\n *\n *   switchAgent(newAgentId: string) {\n *     // Can call outside of constructor using watchAgentWith\n *     const watcher = watchAgentWith(this.injector, { agentId: newAgentId });\n *     this.agent = watcher.agent;\n *     this.messages = watcher.messages;\n *     this.isRunning = watcher.isRunning;\n *   }\n * }\n * ```\n */\nexport function watchAgentWith(\n  injector: Injector,\n  config?: { agentId?: string }\n): AgentWatchResult {\n  return runInInjectionContext(injector, () => watchAgent(config));\n}\n\n/**\n * Subscribes to an agent's events with custom callbacks.\n * Returns a cleanup function that should be called to unsubscribe.\n *\n * @param service - The CopilotKitService instance\n * @param agentId - Optional agent ID (defaults to DEFAULT_AGENT_ID)\n * @param callbacks - Event callbacks\n * @returns Cleanup function to unsubscribe\n *\n * @example\n * ```typescript\n * export class MyComponent implements OnInit, OnDestroy {\n *   private unsubscribe?: () => void;\n *\n *   constructor(private copilotkit: CopilotKitService) {}\n *\n *   ngOnInit() {\n *     this.unsubscribe = subscribeToAgent(this.copilotkit, 'my-agent', {\n *       onRunInitialized: () => console.log('Run started'),\n *       onRunFinalized: () => console.log('Run completed'),\n *       onRunFailed: (error) => console.error('Run failed', error),\n *     });\n *   }\n *\n *   ngOnDestroy() {\n *     this.unsubscribe?.();\n *   }\n * }\n * ```\n */\nexport function subscribeToAgent(\n  service: CopilotKitService,\n  agentId?: string,\n  callbacks?: AgentSubscriptionCallbacks\n): () => void {\n  const effectiveAgentId = agentId ?? DEFAULT_AGENT_ID;\n  const agent = service.copilotkit.getAgent(effectiveAgentId);\n\n  if (!agent) {\n    // Return no-op cleanup if agent doesn't exist\n    return () => {};\n  }\n\n  const subscription = agent.subscribe({\n    onMessagesChanged: callbacks?.onMessagesChanged,\n    onStateChanged: callbacks?.onStateChanged,\n    onRunInitialized: callbacks?.onRunInitialized,\n    onRunFinalized: callbacks?.onRunFinalized,\n    onRunFailed: callbacks?.onRunFailed,\n  });\n\n  return () => subscription.unsubscribe();\n}\n"]}
@@ -1,7 +1,7 @@
1
1
  import * as i0 from '@angular/core';
2
2
  import { InjectionToken, signal, computed, effect, untracked, Inject, Injectable, Optional, inject, DestroyRef, runInInjectionContext, ChangeDetectionStrategy, Component, ElementRef, ViewContainerRef, HostListener, Input, Directive, isDevMode, EventEmitter, Output, TemplateRef, ViewChild, ViewEncapsulation, ContentChild, ChangeDetectorRef, PLATFORM_ID, forwardRef, SkipSelf } from '@angular/core';
3
3
  import { toObservable } from '@angular/core/rxjs-interop';
4
- import { CopilotKitCore, ToolCallStatus, completePartialMarkdown } from '@copilotkitnext/core';
4
+ import { CopilotKitCore, CopilotKitCoreRuntimeConnectionStatus, ToolCallStatus, completePartialMarkdown, ProxiedCopilotRuntimeAgent } from '@copilotkitnext/core';
5
5
  export { ToolCallStatus } from '@copilotkitnext/core';
6
6
  import { DEFAULT_AGENT_ID, partialJSONParse, randomUUID } from '@copilotkitnext/shared';
7
7
  import { Overlay, OverlayPositionBuilder, OverlayModule } from '@angular/cdk/overlay';
@@ -108,26 +108,24 @@ class CopilotKitService {
108
108
  this._runtimeStateVersion = signal(0);
109
109
  // Initialize computed signals for processed values
110
110
  this._allTools = computed(() => {
111
- const tools = {};
112
- // Add frontend tools
111
+ const toolMap = new Map();
113
112
  this._frontendTools().forEach((tool) => {
114
- tools[tool.name] = tool;
113
+ toolMap.set(tool.name, tool);
115
114
  });
116
- // Process human-in-the-loop tools
117
115
  this._humanInTheLoop().forEach((tool) => {
118
116
  const frontendTool = {
119
117
  name: tool.name,
120
118
  description: tool.description,
121
119
  parameters: tool.parameters,
122
120
  followUp: tool.followUp,
123
- handler: async (args) => {
121
+ handler: async () => {
124
122
  console.warn(`Human-in-the-loop tool '${tool.name}' called but no interactive handler is set up.`);
125
123
  return undefined;
126
124
  },
127
125
  };
128
- tools[tool.name] = frontendTool;
126
+ toolMap.set(tool.name, frontendTool);
129
127
  });
130
- return tools;
128
+ return Array.from(toolMap.values());
131
129
  });
132
130
  this._allRenderToolCalls = computed(() => {
133
131
  const combined = [...this._renderToolCalls()];
@@ -194,11 +192,11 @@ class CopilotKitService {
194
192
  * Process frontend tools and human-in-the-loop tools
195
193
  */
196
194
  processTools(frontendTools, humanInTheLoop, renderToolCalls) {
197
- const allTools = {};
195
+ const toolMap = new Map();
198
196
  const allRenderToolCalls = [...renderToolCalls];
199
197
  // Add frontend tools
200
198
  frontendTools.forEach((tool) => {
201
- allTools[tool.name] = tool;
199
+ toolMap.set(tool.name, tool);
202
200
  // Add render component if provided
203
201
  if (tool.render) {
204
202
  allRenderToolCalls.push({
@@ -223,7 +221,7 @@ class CopilotKitService {
223
221
  return undefined;
224
222
  },
225
223
  };
226
- allTools[tool.name] = frontendTool;
224
+ toolMap.set(tool.name, frontendTool);
227
225
  // Add the render component
228
226
  if (tool.render) {
229
227
  allRenderToolCalls.push({
@@ -233,7 +231,7 @@ class CopilotKitService {
233
231
  });
234
232
  }
235
233
  });
236
- return { allTools, allRenderToolCalls };
234
+ return { allTools: Array.from(toolMap.values()), allRenderToolCalls };
237
235
  }
238
236
  /**
239
237
  * Setup stability warning effects
@@ -268,7 +266,9 @@ class CopilotKitService {
268
266
  // Sync runtime URL
269
267
  effect(() => {
270
268
  const url = this.runtimeUrl();
271
- untracked(() => this.copilotkit.setRuntimeUrl(url));
269
+ untracked(() => {
270
+ this.copilotkit.setRuntimeUrl(url);
271
+ });
272
272
  });
273
273
  // Sync headers
274
274
  effect(() => {
@@ -288,9 +288,11 @@ class CopilotKitService {
288
288
  // Sync tools - computed from frontend tools and human-in-the-loop
289
289
  effect(() => {
290
290
  const tools = this._allTools();
291
- // Update copilotkit.tools directly since there's no setTools method
292
291
  untracked(() => {
293
- this.copilotkit.tools = tools;
292
+ const setTools = this.copilotkit?.setTools;
293
+ if (typeof setTools === "function") {
294
+ setTools.call(this.copilotkit, tools);
295
+ }
294
296
  });
295
297
  });
296
298
  }
@@ -299,12 +301,7 @@ class CopilotKitService {
299
301
  */
300
302
  setupEventSubscription() {
301
303
  const unsubscribe = this.copilotkit.subscribe({
302
- onRuntimeLoaded: () => {
303
- // Increment version to notify all consumers that runtime state has changed
304
- // This triggers re-evaluation of computed signals that depend on runtime state
305
- this.notifyRuntimeStateChange();
306
- },
307
- onRuntimeLoadError: () => {
304
+ onRuntimeConnectionStatusChanged: () => {
308
305
  // Increment version to notify all consumers that runtime state has changed
309
306
  // This triggers re-evaluation of computed signals that depend on runtime state
310
307
  this.notifyRuntimeStateChange();
@@ -1138,15 +1135,14 @@ function watchAgent(config) {
1138
1135
  subscribeToAgent();
1139
1136
  // Subscribe to CopilotKit changes to detect agent updates
1140
1137
  const coreUnsubscribe = service.copilotkit.subscribe({
1141
- onRuntimeLoaded() {
1142
- // Re-check agent when runtime loads
1143
- currentAgent = updateAgent();
1144
- subscribeToAgent();
1145
- },
1146
- onRuntimeLoadError() {
1147
- // Also re-check agent on runtime load error to ensure consistency
1148
- currentAgent = updateAgent();
1149
- subscribeToAgent();
1138
+ onRuntimeConnectionStatusChanged({ status }) {
1139
+ if (status === CopilotKitCoreRuntimeConnectionStatus.Connected ||
1140
+ status === CopilotKitCoreRuntimeConnectionStatus.Disconnected ||
1141
+ status === CopilotKitCoreRuntimeConnectionStatus.Error) {
1142
+ // Re-check agent when runtime connection state changes
1143
+ currentAgent = updateAgent();
1144
+ subscribeToAgent();
1145
+ }
1150
1146
  },
1151
1147
  });
1152
1148
  // Register cleanup
@@ -2446,9 +2442,12 @@ class CopilotKitAgentDirective {
2446
2442
  subscribeToCore() {
2447
2443
  // Subscribe to CopilotKit changes to detect agent updates
2448
2444
  this.coreUnsubscribe = this.copilotkit.copilotkit.subscribe({
2449
- onRuntimeLoaded: () => {
2450
- // Re-check agent when runtime loads
2451
- this.setupAgent();
2445
+ onRuntimeConnectionStatusChanged: ({ status }) => {
2446
+ if (status === CopilotKitCoreRuntimeConnectionStatus.Connected ||
2447
+ status === CopilotKitCoreRuntimeConnectionStatus.Disconnected) {
2448
+ // Re-check agent when runtime connection changes state
2449
+ this.setupAgent();
2450
+ }
2452
2451
  },
2453
2452
  });
2454
2453
  }
@@ -4567,7 +4566,7 @@ class CopilotChatInputComponent {
4567
4566
  else if (this.audioRecorderRef?.getState() === 'recording') {
4568
4567
  this.audioRecorderRef.stop().catch(console.error);
4569
4568
  }
4570
- });
4569
+ }, { allowSignalWrites: true });
4571
4570
  // Sync with chat configuration
4572
4571
  effect(() => {
4573
4572
  const configValue = this.chatConfig?.inputValue();
@@ -9124,6 +9123,7 @@ class CopilotChatComponent {
9124
9123
  injector;
9125
9124
  agentId;
9126
9125
  threadId;
9126
+ inputComponent;
9127
9127
  constructor(chatConfig, cdr, injector) {
9128
9128
  this.chatConfig = chatConfig;
9129
9129
  this.cdr = cdr;
@@ -9140,7 +9140,7 @@ class CopilotChatComponent {
9140
9140
  a.threadId = this.threadId || this.generatedThreadId;
9141
9141
  if (!this.hasConnectedOnce) {
9142
9142
  this.hasConnectedOnce = true;
9143
- if ('isCopilotKitAgent' in a) {
9143
+ if (a instanceof ProxiedCopilotRuntimeAgent) {
9144
9144
  this.connectToAgent(a);
9145
9145
  }
9146
9146
  else {
@@ -9259,7 +9259,7 @@ class CopilotChatComponent {
9259
9259
  this.hasConnectedOnce = false;
9260
9260
  }
9261
9261
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CopilotChatComponent, deps: [{ token: CopilotChatConfigurationService, optional: true }, { token: i0.ChangeDetectorRef }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
9262
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CopilotChatComponent, isStandalone: true, selector: "copilot-chat", inputs: { agentId: "agentId", threadId: "threadId" }, providers: [
9262
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CopilotChatComponent, isStandalone: true, selector: "copilot-chat", inputs: { agentId: "agentId", threadId: "threadId", inputComponent: "inputComponent" }, providers: [
9263
9263
  {
9264
9264
  provide: CopilotChatConfigurationService,
9265
9265
  deps: [
@@ -9274,6 +9274,7 @@ class CopilotChatComponent {
9274
9274
  [autoScroll]="true"
9275
9275
  [messageViewClass]="'w-full'"
9276
9276
  [showCursor]="showCursor()"
9277
+ [inputComponent]="inputComponent"
9277
9278
  >
9278
9279
  </copilot-chat-view>
9279
9280
  `, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: CopilotChatViewComponent, selector: "copilot-chat-view", inputs: ["messages", "autoScroll", "showCursor", "messageViewComponent", "messageViewTemplate", "messageViewClass", "scrollViewComponent", "scrollViewTemplate", "scrollViewClass", "scrollToBottomButtonComponent", "scrollToBottomButtonTemplate", "scrollToBottomButtonClass", "inputComponent", "inputTemplate", "inputContainerComponent", "inputContainerTemplate", "inputContainerClass", "featherComponent", "featherTemplate", "featherClass", "disclaimerComponent", "disclaimerTemplate", "disclaimerClass", "disclaimerText"], outputs: ["assistantMessageThumbsUp", "assistantMessageThumbsDown", "assistantMessageReadAloud", "assistantMessageRegenerate", "userMessageCopy", "userMessageEdit"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
@@ -9302,6 +9303,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
9302
9303
  [autoScroll]="true"
9303
9304
  [messageViewClass]="'w-full'"
9304
9305
  [showCursor]="showCursor()"
9306
+ [inputComponent]="inputComponent"
9305
9307
  >
9306
9308
  </copilot-chat-view>
9307
9309
  `,
@@ -9312,6 +9314,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
9312
9314
  type: Input
9313
9315
  }], threadId: [{
9314
9316
  type: Input
9317
+ }], inputComponent: [{
9318
+ type: Input
9315
9319
  }] } });
9316
9320
 
9317
9321
  // Testing utilities are not exported from the main entry point