@copilotkitnext/angular 1.51.4-next.6 → 1.51.4-next.8

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 (44) hide show
  1. package/README.md +43 -39
  2. package/dist/README.md +43 -39
  3. package/dist/esm2022/lib/agent-context.mjs +2 -2
  4. package/dist/esm2022/lib/agent.mjs +1 -1
  5. package/dist/esm2022/lib/chat-config.mjs +1 -1
  6. package/dist/esm2022/lib/chat-state.mjs +1 -1
  7. package/dist/esm2022/lib/components/chat/copilot-chat-assistant-message-buttons.mjs +1 -1
  8. package/dist/esm2022/lib/components/chat/copilot-chat-assistant-message-renderer.mjs +1 -1
  9. package/dist/esm2022/lib/components/chat/copilot-chat-assistant-message-toolbar.mjs +1 -1
  10. package/dist/esm2022/lib/components/chat/copilot-chat-assistant-message.mjs +1 -1
  11. package/dist/esm2022/lib/components/chat/copilot-chat-audio-recorder.mjs +1 -1
  12. package/dist/esm2022/lib/components/chat/copilot-chat-buttons.mjs +1 -1
  13. package/dist/esm2022/lib/components/chat/copilot-chat-input.mjs +1 -1
  14. package/dist/esm2022/lib/components/chat/copilot-chat-message-view-cursor.mjs +1 -1
  15. package/dist/esm2022/lib/components/chat/copilot-chat-message-view.mjs +1 -1
  16. package/dist/esm2022/lib/components/chat/copilot-chat-textarea.mjs +1 -1
  17. package/dist/esm2022/lib/components/chat/copilot-chat-tools-menu.mjs +1 -1
  18. package/dist/esm2022/lib/components/chat/copilot-chat-user-message-branch-navigation.mjs +26 -6
  19. package/dist/esm2022/lib/components/chat/copilot-chat-user-message-buttons.mjs +1 -1
  20. package/dist/esm2022/lib/components/chat/copilot-chat-user-message-renderer.mjs +1 -1
  21. package/dist/esm2022/lib/components/chat/copilot-chat-user-message-toolbar.mjs +1 -1
  22. package/dist/esm2022/lib/components/chat/copilot-chat-user-message.mjs +29 -9
  23. package/dist/esm2022/lib/components/chat/copilot-chat-user-message.types.mjs +1 -1
  24. package/dist/esm2022/lib/components/chat/copilot-chat-view-disclaimer.mjs +1 -1
  25. package/dist/esm2022/lib/components/chat/copilot-chat-view-feather.mjs +1 -1
  26. package/dist/esm2022/lib/components/chat/copilot-chat-view-input-container.mjs +1 -1
  27. package/dist/esm2022/lib/components/chat/copilot-chat-view-scroll-to-bottom-button.mjs +1 -1
  28. package/dist/esm2022/lib/components/chat/copilot-chat-view-scroll-view.mjs +1 -1
  29. package/dist/esm2022/lib/components/chat/copilot-chat-view.mjs +1 -1
  30. package/dist/esm2022/lib/components/chat/copilot-chat.mjs +20 -23
  31. package/dist/esm2022/lib/config.mjs +1 -1
  32. package/dist/esm2022/lib/copilotkit.mjs +18 -8
  33. package/dist/esm2022/lib/directives/stick-to-bottom.mjs +1 -1
  34. package/dist/esm2022/lib/human-in-the-loop.mjs +1 -1
  35. package/dist/esm2022/lib/render-tool-calls.mjs +40 -11
  36. package/dist/esm2022/lib/resize-observer.mjs +1 -1
  37. package/dist/esm2022/lib/scroll-position.mjs +2 -3
  38. package/dist/esm2022/lib/slots/copilot-slot.mjs +1 -1
  39. package/dist/esm2022/lib/slots/slot.utils.mjs +1 -1
  40. package/dist/esm2022/lib/tools.mjs +3 -3
  41. package/dist/fesm2022/copilotkitnext-angular.mjs +128 -54
  42. package/dist/fesm2022/copilotkitnext-angular.mjs.map +1 -1
  43. package/dist/lib/components/chat/copilot-chat.d.ts +1 -0
  44. package/package.json +5 -6
package/README.md CHANGED
@@ -131,36 +131,36 @@ When building custom input components for CopilotKit Angular, use the service-ba
131
131
  ### Service-Based Custom Input Example:
132
132
 
133
133
  ```typescript
134
- import { Component } from '@angular/core';
135
- import { FormsModule } from '@angular/forms';
136
- import { CopilotChatConfigurationService } from '@copilotkitnext/angular';
134
+ import { Component } from "@angular/core";
135
+ import { FormsModule } from "@angular/forms";
136
+ import { CopilotChatConfigurationService } from "@copilotkitnext/angular";
137
137
 
138
138
  @Component({
139
- selector: 'my-custom-input',
139
+ selector: "my-custom-input",
140
140
  standalone: true,
141
141
  imports: [FormsModule],
142
142
  template: `
143
143
  <div class="custom-input-wrapper">
144
- <input
144
+ <input
145
145
  [(ngModel)]="inputValue"
146
146
  (keyup.enter)="submitMessage()"
147
147
  placeholder="Type your message..."
148
148
  />
149
149
  <button (click)="submitMessage()">Send</button>
150
150
  </div>
151
- `
151
+ `,
152
152
  })
153
153
  export class MyCustomInputComponent {
154
- inputValue = '';
155
-
154
+ inputValue = "";
155
+
156
156
  constructor(private chat: CopilotChatConfigurationService) {}
157
-
157
+
158
158
  submitMessage() {
159
159
  const value = this.inputValue.trim();
160
160
  if (value) {
161
161
  // Use the service to submit the message
162
162
  this.chat.submitInput(value);
163
- this.inputValue = '';
163
+ this.inputValue = "";
164
164
  }
165
165
  }
166
166
  }
@@ -169,20 +169,21 @@ export class MyCustomInputComponent {
169
169
  ### Using the Custom Input Component:
170
170
 
171
171
  ```typescript
172
- import { Component } from '@angular/core';
173
- import { CopilotChatViewComponent } from '@copilotkitnext/angular';
174
- import { MyCustomInputComponent } from './my-custom-input.component';
172
+ import { Component } from "@angular/core";
173
+ import { CopilotChatViewComponent } from "@copilotkitnext/angular";
174
+ import { MyCustomInputComponent } from "./my-custom-input.component";
175
175
 
176
176
  @Component({
177
- selector: 'app-chat',
177
+ selector: "app-chat",
178
178
  standalone: true,
179
179
  imports: [CopilotChatViewComponent],
180
180
  template: `
181
181
  <copilot-chat-view
182
182
  [messages]="messages"
183
- [inputComponent]="customInputComponent">
183
+ [inputComponent]="customInputComponent"
184
+ >
184
185
  </copilot-chat-view>
185
- `
186
+ `,
186
187
  })
187
188
  export class ChatComponent {
188
189
  messages = [];
@@ -202,10 +203,12 @@ export class ChatComponent {
202
203
  For template-level hooks, you can also use the `copilotkitChatConfig` directive:
203
204
 
204
205
  ```html
205
- <div [copilotkitChatConfig]="{
206
+ <div
207
+ [copilotkitChatConfig]="{
206
208
  onSubmitInput: handleSubmit,
207
209
  onChangeInput: handleChange
208
- }">
210
+ }"
211
+ >
209
212
  <copilot-chat></copilot-chat>
210
213
  </div>
211
214
  ```
@@ -213,11 +216,11 @@ For template-level hooks, you can also use the `copilotkitChatConfig` directive:
213
216
  ```typescript
214
217
  export class ChatComponent {
215
218
  handleSubmit = (value: string) => {
216
- console.log('Message submitted:', value);
219
+ console.log("Message submitted:", value);
217
220
  };
218
-
221
+
219
222
  handleChange = (value: string) => {
220
- console.log('Input changed:', value);
223
+ console.log("Input changed:", value);
221
224
  };
222
225
  }
223
226
  ```
@@ -267,7 +270,7 @@ app.use(
267
270
  exposeHeaders: ["Content-Type"],
268
271
  credentials: true,
269
272
  maxAge: 86400,
270
- })
273
+ }),
271
274
  );
272
275
 
273
276
  // Create the CopilotKit endpoint
@@ -282,7 +285,7 @@ app.route("/", copilotApp);
282
285
  const port = Number(process.env.PORT || 3001);
283
286
  serve({ fetch: app.fetch, port });
284
287
  console.log(
285
- `CopilotKit runtime listening at http://localhost:${port}/api/copilotkit`
288
+ `CopilotKit runtime listening at http://localhost:${port}/api/copilotkit`,
286
289
  );
287
290
  ```
288
291
 
@@ -322,10 +325,7 @@ import { watchAgent } from "@copilotkitnext/angular";
322
325
  <div *ngFor="let msg of messages()" class="message">
323
326
  {{ msg.content }}
324
327
  </div>
325
- <input
326
- [disabled]="isRunning()"
327
- (keyup.enter)="sendMessage($event)"
328
- />
328
+ <input [disabled]="isRunning()" (keyup.enter)="sendMessage($event)" />
329
329
  </div>
330
330
  `,
331
331
  })
@@ -375,7 +375,7 @@ import { watchAgent, watchAgentWith } from "@copilotkitnext/angular";
375
375
  template: `
376
376
  <button (click)="switchToAgent('sales')">Sales Agent</button>
377
377
  <button (click)="switchToAgent('support')">Support Agent</button>
378
- <div>Current Agent: {{ agent()?.id || 'None' }}</div>
378
+ <div>Current Agent: {{ agent()?.id || "None" }}</div>
379
379
  `,
380
380
  })
381
381
  export class AgentSwitcherComponent {
@@ -409,18 +409,20 @@ export class AgentSwitcherComponent {
409
409
 
410
410
  To render tool calls in a headless UI, register renderers in your providers and drop the lightweight view in your template.
411
411
 
412
- 1) Register tool renderers (e.g., a wildcard that renders any tool):
412
+ 1. Register tool renderers (e.g., a wildcard that renders any tool):
413
413
 
414
414
  ```ts
415
- import { ApplicationConfig, importProvidersFrom } from '@angular/core';
416
- import { BrowserModule } from '@angular/platform-browser';
417
- import { provideCopilotKit } from '@copilotkitnext/angular';
415
+ import { ApplicationConfig, importProvidersFrom } from "@angular/core";
416
+ import { BrowserModule } from "@angular/platform-browser";
417
+ import { provideCopilotKit } from "@copilotkitnext/angular";
418
418
 
419
419
  // Simple demo renderer (Component or TemplateRef accepted)
420
420
  @Component({
421
421
  standalone: true,
422
422
  template: `
423
- <div style="padding:12px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;margin:8px 0;">
423
+ <div
424
+ style="padding:12px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;margin:8px 0;"
425
+ >
424
426
  <div style="font-weight:600;margin-bottom:6px;">Tool: {{ name }}</div>
425
427
  <pre style="margin:0;white-space:pre-wrap;">{{ args | json }}</pre>
426
428
  <div *ngIf="result" style="margin-top:6px;">Result: {{ result }}</div>
@@ -438,19 +440,20 @@ export const appConfig: ApplicationConfig = {
438
440
  providers: [
439
441
  importProvidersFrom(BrowserModule),
440
442
  ...provideCopilotKit({
441
- renderToolCalls: [
442
- { name: '*', render: WildcardToolRenderComponent },
443
- ],
443
+ renderToolCalls: [{ name: "*", render: WildcardToolRenderComponent }],
444
444
  }),
445
445
  ],
446
446
  };
447
447
  ```
448
448
 
449
- 2) Render tool calls under assistant messages using the headless view component:
449
+ 2. Render tool calls under assistant messages using the headless view component:
450
450
 
451
451
  ```ts
452
- import { Component } from '@angular/core';
453
- import { watchAgent, CopilotChatToolCallsViewComponent } from '@copilotkitnext/angular';
452
+ import { Component } from "@angular/core";
453
+ import {
454
+ watchAgent,
455
+ CopilotChatToolCallsViewComponent,
456
+ } from "@copilotkitnext/angular";
454
457
 
455
458
  @Component({
456
459
  standalone: true,
@@ -476,6 +479,7 @@ export class HeadlessWithToolsComponent {
476
479
  ```
477
480
 
478
481
  Notes:
482
+
479
483
  - If you prefer full manual control, you can render a specific tool call with `CopilotKitToolRenderComponent` and pass `toolName`, `args`, `status`, and `result` yourself.
480
484
  - You can also register tool renders declaratively via the `CopilotKitFrontendToolDirective` by using `[copilotkitFrontendTool]` in templates.
481
485
 
package/dist/README.md CHANGED
@@ -131,36 +131,36 @@ When building custom input components for CopilotKit Angular, use the service-ba
131
131
  ### Service-Based Custom Input Example:
132
132
 
133
133
  ```typescript
134
- import { Component } from '@angular/core';
135
- import { FormsModule } from '@angular/forms';
136
- import { CopilotChatConfigurationService } from '@copilotkitnext/angular';
134
+ import { Component } from "@angular/core";
135
+ import { FormsModule } from "@angular/forms";
136
+ import { CopilotChatConfigurationService } from "@copilotkitnext/angular";
137
137
 
138
138
  @Component({
139
- selector: 'my-custom-input',
139
+ selector: "my-custom-input",
140
140
  standalone: true,
141
141
  imports: [FormsModule],
142
142
  template: `
143
143
  <div class="custom-input-wrapper">
144
- <input
144
+ <input
145
145
  [(ngModel)]="inputValue"
146
146
  (keyup.enter)="submitMessage()"
147
147
  placeholder="Type your message..."
148
148
  />
149
149
  <button (click)="submitMessage()">Send</button>
150
150
  </div>
151
- `
151
+ `,
152
152
  })
153
153
  export class MyCustomInputComponent {
154
- inputValue = '';
155
-
154
+ inputValue = "";
155
+
156
156
  constructor(private chat: CopilotChatConfigurationService) {}
157
-
157
+
158
158
  submitMessage() {
159
159
  const value = this.inputValue.trim();
160
160
  if (value) {
161
161
  // Use the service to submit the message
162
162
  this.chat.submitInput(value);
163
- this.inputValue = '';
163
+ this.inputValue = "";
164
164
  }
165
165
  }
166
166
  }
@@ -169,20 +169,21 @@ export class MyCustomInputComponent {
169
169
  ### Using the Custom Input Component:
170
170
 
171
171
  ```typescript
172
- import { Component } from '@angular/core';
173
- import { CopilotChatViewComponent } from '@copilotkitnext/angular';
174
- import { MyCustomInputComponent } from './my-custom-input.component';
172
+ import { Component } from "@angular/core";
173
+ import { CopilotChatViewComponent } from "@copilotkitnext/angular";
174
+ import { MyCustomInputComponent } from "./my-custom-input.component";
175
175
 
176
176
  @Component({
177
- selector: 'app-chat',
177
+ selector: "app-chat",
178
178
  standalone: true,
179
179
  imports: [CopilotChatViewComponent],
180
180
  template: `
181
181
  <copilot-chat-view
182
182
  [messages]="messages"
183
- [inputComponent]="customInputComponent">
183
+ [inputComponent]="customInputComponent"
184
+ >
184
185
  </copilot-chat-view>
185
- `
186
+ `,
186
187
  })
187
188
  export class ChatComponent {
188
189
  messages = [];
@@ -202,10 +203,12 @@ export class ChatComponent {
202
203
  For template-level hooks, you can also use the `copilotkitChatConfig` directive:
203
204
 
204
205
  ```html
205
- <div [copilotkitChatConfig]="{
206
+ <div
207
+ [copilotkitChatConfig]="{
206
208
  onSubmitInput: handleSubmit,
207
209
  onChangeInput: handleChange
208
- }">
210
+ }"
211
+ >
209
212
  <copilot-chat></copilot-chat>
210
213
  </div>
211
214
  ```
@@ -213,11 +216,11 @@ For template-level hooks, you can also use the `copilotkitChatConfig` directive:
213
216
  ```typescript
214
217
  export class ChatComponent {
215
218
  handleSubmit = (value: string) => {
216
- console.log('Message submitted:', value);
219
+ console.log("Message submitted:", value);
217
220
  };
218
-
221
+
219
222
  handleChange = (value: string) => {
220
- console.log('Input changed:', value);
223
+ console.log("Input changed:", value);
221
224
  };
222
225
  }
223
226
  ```
@@ -267,7 +270,7 @@ app.use(
267
270
  exposeHeaders: ["Content-Type"],
268
271
  credentials: true,
269
272
  maxAge: 86400,
270
- })
273
+ }),
271
274
  );
272
275
 
273
276
  // Create the CopilotKit endpoint
@@ -282,7 +285,7 @@ app.route("/", copilotApp);
282
285
  const port = Number(process.env.PORT || 3001);
283
286
  serve({ fetch: app.fetch, port });
284
287
  console.log(
285
- `CopilotKit runtime listening at http://localhost:${port}/api/copilotkit`
288
+ `CopilotKit runtime listening at http://localhost:${port}/api/copilotkit`,
286
289
  );
287
290
  ```
288
291
 
@@ -322,10 +325,7 @@ import { watchAgent } from "@copilotkitnext/angular";
322
325
  <div *ngFor="let msg of messages()" class="message">
323
326
  {{ msg.content }}
324
327
  </div>
325
- <input
326
- [disabled]="isRunning()"
327
- (keyup.enter)="sendMessage($event)"
328
- />
328
+ <input [disabled]="isRunning()" (keyup.enter)="sendMessage($event)" />
329
329
  </div>
330
330
  `,
331
331
  })
@@ -375,7 +375,7 @@ import { watchAgent, watchAgentWith } from "@copilotkitnext/angular";
375
375
  template: `
376
376
  <button (click)="switchToAgent('sales')">Sales Agent</button>
377
377
  <button (click)="switchToAgent('support')">Support Agent</button>
378
- <div>Current Agent: {{ agent()?.id || 'None' }}</div>
378
+ <div>Current Agent: {{ agent()?.id || "None" }}</div>
379
379
  `,
380
380
  })
381
381
  export class AgentSwitcherComponent {
@@ -409,18 +409,20 @@ export class AgentSwitcherComponent {
409
409
 
410
410
  To render tool calls in a headless UI, register renderers in your providers and drop the lightweight view in your template.
411
411
 
412
- 1) Register tool renderers (e.g., a wildcard that renders any tool):
412
+ 1. Register tool renderers (e.g., a wildcard that renders any tool):
413
413
 
414
414
  ```ts
415
- import { ApplicationConfig, importProvidersFrom } from '@angular/core';
416
- import { BrowserModule } from '@angular/platform-browser';
417
- import { provideCopilotKit } from '@copilotkitnext/angular';
415
+ import { ApplicationConfig, importProvidersFrom } from "@angular/core";
416
+ import { BrowserModule } from "@angular/platform-browser";
417
+ import { provideCopilotKit } from "@copilotkitnext/angular";
418
418
 
419
419
  // Simple demo renderer (Component or TemplateRef accepted)
420
420
  @Component({
421
421
  standalone: true,
422
422
  template: `
423
- <div style="padding:12px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;margin:8px 0;">
423
+ <div
424
+ style="padding:12px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;margin:8px 0;"
425
+ >
424
426
  <div style="font-weight:600;margin-bottom:6px;">Tool: {{ name }}</div>
425
427
  <pre style="margin:0;white-space:pre-wrap;">{{ args | json }}</pre>
426
428
  <div *ngIf="result" style="margin-top:6px;">Result: {{ result }}</div>
@@ -438,19 +440,20 @@ export const appConfig: ApplicationConfig = {
438
440
  providers: [
439
441
  importProvidersFrom(BrowserModule),
440
442
  ...provideCopilotKit({
441
- renderToolCalls: [
442
- { name: '*', render: WildcardToolRenderComponent },
443
- ],
443
+ renderToolCalls: [{ name: "*", render: WildcardToolRenderComponent }],
444
444
  }),
445
445
  ],
446
446
  };
447
447
  ```
448
448
 
449
- 2) Render tool calls under assistant messages using the headless view component:
449
+ 2. Render tool calls under assistant messages using the headless view component:
450
450
 
451
451
  ```ts
452
- import { Component } from '@angular/core';
453
- import { watchAgent, CopilotChatToolCallsViewComponent } from '@copilotkitnext/angular';
452
+ import { Component } from "@angular/core";
453
+ import {
454
+ watchAgent,
455
+ CopilotChatToolCallsViewComponent,
456
+ } from "@copilotkitnext/angular";
454
457
 
455
458
  @Component({
456
459
  standalone: true,
@@ -476,6 +479,7 @@ export class HeadlessWithToolsComponent {
476
479
  ```
477
480
 
478
481
  Notes:
482
+
479
483
  - If you prefer full manual control, you can render a specific tool call with `CopilotKitToolRenderComponent` and pass `toolName`, `args`, `status`, and `result` yourself.
480
484
  - You can also register tool renders declaratively via the `CopilotKitFrontendToolDirective` by using `[copilotkitFrontendTool]` in templates.
481
485
 
@@ -1,4 +1,4 @@
1
- import { effect, inject, Injector, runInInjectionContext } from "@angular/core";
1
+ import { effect, inject, Injector, runInInjectionContext, } from "@angular/core";
2
2
  import { CopilotKit } from "./copilotkit";
3
3
  /**
4
4
  * Connects context to the agent.
@@ -22,4 +22,4 @@ export function connectAgentContext(context, config) {
22
22
  });
23
23
  });
24
24
  }
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWdlbnQtY29udGV4dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvYWdlbnQtY29udGV4dC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxRQUFRLEVBQUUscUJBQXFCLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFFeEYsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQU0xQzs7Ozs7R0FLRztBQUNILE1BQU0sVUFBVSxtQkFBbUIsQ0FBQyxPQUFrQyxFQUFFLE1BQWtDO0lBQ3hHLE1BQU0sUUFBUSxHQUFHLE1BQU0sQ0FBQyxRQUFRLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLENBQUMsSUFBSSxNQUFNLEVBQUUsUUFBUSxDQUFDO0lBRTFFLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNkLE1BQU0sSUFBSSxLQUFLLENBQ2IsZ0hBQWdILENBQ2pILENBQUM7SUFDSixDQUFDO0lBRUQscUJBQXFCLENBQUMsUUFBUSxFQUFFLEdBQUcsRUFBRTtRQUNuQyxNQUFNLFVBQVUsR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7UUFFdEMsTUFBTSxDQUFDLENBQUMsUUFBUSxFQUFFLEVBQUU7WUFDbEIsTUFBTSxZQUFZLEdBQUcsT0FBTyxPQUFPLEtBQUssVUFBVSxDQUFDLENBQUMsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDO1lBQ3pFLE1BQU0sRUFBRSxHQUFHLFVBQVUsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLFlBQVksQ0FBQyxDQUFDO1lBRXBELFFBQVEsQ0FBQyxHQUFHLEVBQUU7Z0JBQ1osVUFBVSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsRUFBRSxDQUFDLENBQUM7WUFDcEMsQ0FBQyxDQUFDLENBQUM7UUFDTCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGVmZmVjdCwgaW5qZWN0LCBJbmplY3RvciwgcnVuSW5JbmplY3Rpb25Db250ZXh0LCBTaWduYWwgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgQ29udGV4dCB9IGZyb20gXCJAYWctdWkvY2xpZW50XCI7XG5pbXBvcnQgeyBDb3BpbG90S2l0IH0gZnJvbSBcIi4vY29waWxvdGtpdFwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIENvbm5lY3RBZ2VudENvbnRleHRDb25maWcge1xuICBpbmplY3Rvcj86IEluamVjdG9yO1xufVxuXG4vKipcbiAqIENvbm5lY3RzIGNvbnRleHQgdG8gdGhlIGFnZW50LlxuICpcbiAqIEBwYXJhbSBjb250ZXh0IC0gVGhlIGNvbnRleHQgKG9yIGEgc2lnbmFsIG9mIGNvbnRleHQpIHRvIGNvbm5lY3QgdG8gdGhlIGFnZW50LlxuICogQHBhcmFtIGNvbmZpZyAtIE9wdGlvbmFsIGNvbmZpZ3VyYXRpb24gZm9yIGNvbm5lY3RpbmcgdGhlIGNvbnRleHQuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjb25uZWN0QWdlbnRDb250ZXh0KGNvbnRleHQ6IENvbnRleHQgfCBTaWduYWw8Q29udGV4dD4sIGNvbmZpZz86IENvbm5lY3RBZ2VudENvbnRleHRDb25maWcpIHtcbiAgY29uc3QgaW5qZWN0b3IgPSBpbmplY3QoSW5qZWN0b3IsIHsgb3B0aW9uYWw6IHRydWUgfSkgPz8gY29uZmlnPy5pbmplY3RvcjtcblxuICBpZiAoIWluamVjdG9yKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgXCJJbmplY3RvciBub3QgZm91bmQuIFlvdSBtdXN0IGNhbGwgY29ubmVjdEFnZW50Q29udGV4dCBpbiBhbiBpbmplY3RvciBjb250ZXh0IG9yIHBhc3MgYW4gaW5qZWN0b3IgaW4gdGhlIGNvbmZpZ1wiLFxuICAgICk7XG4gIH1cblxuICBydW5JbkluamVjdGlvbkNvbnRleHQoaW5qZWN0b3IsICgpID0+IHtcbiAgICBjb25zdCBjb3BpbG90a2l0ID0gaW5qZWN0KENvcGlsb3RLaXQpO1xuXG4gICAgZWZmZWN0KCh0ZWFyZG93bikgPT4ge1xuICAgICAgY29uc3QgY29udGV4dFZhbHVlID0gdHlwZW9mIGNvbnRleHQgPT09IFwiZnVuY3Rpb25cIiA/IGNvbnRleHQoKSA6IGNvbnRleHQ7XG4gICAgICBjb25zdCBpZCA9IGNvcGlsb3RraXQuY29yZS5hZGRDb250ZXh0KGNvbnRleHRWYWx1ZSk7XG5cbiAgICAgIHRlYXJkb3duKCgpID0+IHtcbiAgICAgICAgY29waWxvdGtpdC5jb3JlLnJlbW92ZUNvbnRleHQoaWQpO1xuICAgICAgfSk7XG4gICAgfSk7XG4gIH0pO1xufVxuIl19
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWdlbnQtY29udGV4dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvYWdlbnQtY29udGV4dC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsTUFBTSxFQUNOLE1BQU0sRUFDTixRQUFRLEVBQ1IscUJBQXFCLEdBRXRCLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFNMUM7Ozs7O0dBS0c7QUFDSCxNQUFNLFVBQVUsbUJBQW1CLENBQ2pDLE9BQWtDLEVBQ2xDLE1BQWtDO0lBRWxDLE1BQU0sUUFBUSxHQUFHLE1BQU0sQ0FBQyxRQUFRLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLENBQUMsSUFBSSxNQUFNLEVBQUUsUUFBUSxDQUFDO0lBRTFFLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNkLE1BQU0sSUFBSSxLQUFLLENBQ2IsZ0hBQWdILENBQ2pILENBQUM7SUFDSixDQUFDO0lBRUQscUJBQXFCLENBQUMsUUFBUSxFQUFFLEdBQUcsRUFBRTtRQUNuQyxNQUFNLFVBQVUsR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7UUFFdEMsTUFBTSxDQUFDLENBQUMsUUFBUSxFQUFFLEVBQUU7WUFDbEIsTUFBTSxZQUFZLEdBQUcsT0FBTyxPQUFPLEtBQUssVUFBVSxDQUFDLENBQUMsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDO1lBQ3pFLE1BQU0sRUFBRSxHQUFHLFVBQVUsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLFlBQVksQ0FBQyxDQUFDO1lBRXBELFFBQVEsQ0FBQyxHQUFHLEVBQUU7Z0JBQ1osVUFBVSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsRUFBRSxDQUFDLENBQUM7WUFDcEMsQ0FBQyxDQUFDLENBQUM7UUFDTCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIGVmZmVjdCxcbiAgaW5qZWN0LFxuICBJbmplY3RvcixcbiAgcnVuSW5JbmplY3Rpb25Db250ZXh0LFxuICBTaWduYWwsXG59IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBDb250ZXh0IH0gZnJvbSBcIkBhZy11aS9jbGllbnRcIjtcbmltcG9ydCB7IENvcGlsb3RLaXQgfSBmcm9tIFwiLi9jb3BpbG90a2l0XCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29ubmVjdEFnZW50Q29udGV4dENvbmZpZyB7XG4gIGluamVjdG9yPzogSW5qZWN0b3I7XG59XG5cbi8qKlxuICogQ29ubmVjdHMgY29udGV4dCB0byB0aGUgYWdlbnQuXG4gKlxuICogQHBhcmFtIGNvbnRleHQgLSBUaGUgY29udGV4dCAob3IgYSBzaWduYWwgb2YgY29udGV4dCkgdG8gY29ubmVjdCB0byB0aGUgYWdlbnQuXG4gKiBAcGFyYW0gY29uZmlnIC0gT3B0aW9uYWwgY29uZmlndXJhdGlvbiBmb3IgY29ubmVjdGluZyB0aGUgY29udGV4dC5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGNvbm5lY3RBZ2VudENvbnRleHQoXG4gIGNvbnRleHQ6IENvbnRleHQgfCBTaWduYWw8Q29udGV4dD4sXG4gIGNvbmZpZz86IENvbm5lY3RBZ2VudENvbnRleHRDb25maWcsXG4pIHtcbiAgY29uc3QgaW5qZWN0b3IgPSBpbmplY3QoSW5qZWN0b3IsIHsgb3B0aW9uYWw6IHRydWUgfSkgPz8gY29uZmlnPy5pbmplY3RvcjtcblxuICBpZiAoIWluamVjdG9yKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgXCJJbmplY3RvciBub3QgZm91bmQuIFlvdSBtdXN0IGNhbGwgY29ubmVjdEFnZW50Q29udGV4dCBpbiBhbiBpbmplY3RvciBjb250ZXh0IG9yIHBhc3MgYW4gaW5qZWN0b3IgaW4gdGhlIGNvbmZpZ1wiLFxuICAgICk7XG4gIH1cblxuICBydW5JbkluamVjdGlvbkNvbnRleHQoaW5qZWN0b3IsICgpID0+IHtcbiAgICBjb25zdCBjb3BpbG90a2l0ID0gaW5qZWN0KENvcGlsb3RLaXQpO1xuXG4gICAgZWZmZWN0KCh0ZWFyZG93bikgPT4ge1xuICAgICAgY29uc3QgY29udGV4dFZhbHVlID0gdHlwZW9mIGNvbnRleHQgPT09IFwiZnVuY3Rpb25cIiA/IGNvbnRleHQoKSA6IGNvbnRleHQ7XG4gICAgICBjb25zdCBpZCA9IGNvcGlsb3RraXQuY29yZS5hZGRDb250ZXh0KGNvbnRleHRWYWx1ZSk7XG5cbiAgICAgIHRlYXJkb3duKCgpID0+IHtcbiAgICAgICAgY29waWxvdGtpdC5jb3JlLnJlbW92ZUNvbnRleHQoaWQpO1xuICAgICAgfSk7XG4gICAgfSk7XG4gIH0pO1xufVxuIl19
@@ -70,4 +70,4 @@ export function injectAgentStore(agentId) {
70
70
  const agentIdSignal = typeof agentId === "function" ? agentId : computed(() => agentId);
71
71
  return agentFactory.createAgentStoreSignal(agentIdSignal, destroyRef);
72
72
  }
73
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWdlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL2FnZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxVQUFVLEVBQ1YsVUFBVSxFQUNWLE1BQU0sRUFDTixNQUFNLEVBQ04sUUFBUSxHQUVULE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFHMUMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7O0FBRTFELE1BQU0sT0FBTyxVQUFVO0lBQ1osYUFBYSxDQUVwQjtJQUNPLFVBQVUsR0FBRyxNQUFNLENBQVUsS0FBSyxDQUFDLENBQUM7SUFDcEMsU0FBUyxHQUFHLE1BQU0sQ0FBWSxFQUFFLENBQUMsQ0FBQztJQUNsQyxNQUFNLEdBQUcsTUFBTSxDQUFNLFNBQVMsQ0FBQyxDQUFDO0lBRWhDLEtBQUssQ0FBZ0I7SUFDckIsU0FBUyxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsVUFBVSxFQUFFLENBQUM7SUFDekMsUUFBUSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsVUFBVSxFQUFFLENBQUM7SUFDdkMsS0FBSyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsVUFBVSxFQUFFLENBQUM7SUFFMUMsWUFBWSxhQUE0QixFQUFFLFVBQXNCO1FBQzlELElBQUksQ0FBQyxLQUFLLEdBQUcsYUFBYSxDQUFDO1FBRTNCLElBQUksQ0FBQyxhQUFhLEdBQUcsYUFBYSxDQUFDLFNBQVMsQ0FBQztZQUMzQyxpQkFBaUIsRUFBRSxHQUFHLEVBQUU7Z0JBQ3RCLElBQUksQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLGFBQWEsQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUM3QyxDQUFDO1lBQ0QsY0FBYyxFQUFFLEdBQUcsRUFBRTtnQkFDbkIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ3ZDLENBQUM7WUFDRCxnQkFBZ0IsRUFBRSxHQUFHLEVBQUU7Z0JBQ3JCLElBQUksQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQzVCLENBQUM7WUFDRCxjQUFjLEVBQUUsR0FBRyxFQUFFO2dCQUNuQixJQUFJLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUM3QixDQUFDO1lBQ0QsV0FBVyxFQUFFLEdBQUcsRUFBRTtnQkFDaEIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDN0IsQ0FBQztTQUNGLENBQUMsQ0FBQztRQUVILFVBQVUsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ3hCLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNsQixDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxRQUFRO1FBQ04sSUFBSSxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7WUFDdkIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUNuQyxDQUFDO0lBQ0gsQ0FBQztDQUNGO0FBR0QsTUFBTSxPQUFPLHNCQUFzQjtJQUN4QixXQUFXLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBRTFDLHNCQUFzQixDQUNwQixPQUFtQyxFQUNuQyxVQUFzQjtRQUV0QixJQUFJLGNBQXNDLENBQUM7UUFFM0MsT0FBTyxRQUFRLENBQUMsR0FBRyxFQUFFO1lBQ25CLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxFQUFFLENBQUM7WUFFMUIsSUFBSSxjQUFjLEVBQUUsQ0FBQztnQkFDbkIsY0FBYyxDQUFDLFFBQVEsRUFBRSxDQUFDO2dCQUMxQixjQUFjLEdBQUcsU0FBUyxDQUFDO1lBQzdCLENBQUM7WUFFRCxNQUFNLGFBQWEsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FDN0MsT0FBTyxFQUFFLElBQUksZ0JBQWdCLENBQzlCLENBQUM7WUFDRixJQUFJLENBQUMsYUFBYTtnQkFBRSxPQUFPLFNBQVMsQ0FBQztZQUVyQyxjQUFjLEdBQUcsSUFBSSxVQUFVLENBQUMsYUFBYSxFQUFFLFVBQVUsQ0FBQyxDQUFDO1lBQzNELE9BQU8sY0FBYyxDQUFDO1FBQ3hCLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzt3R0F6QlUsc0JBQXNCOzRHQUF0QixzQkFBc0IsY0FEVCxNQUFNOzs0RkFDbkIsc0JBQXNCO2tCQURsQyxVQUFVO21CQUFDLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRTs7QUE2QmxDLE1BQU0sVUFBVSxnQkFBZ0IsQ0FDOUIsT0FBNEM7SUFFNUMsTUFBTSxZQUFZLEdBQUcsTUFBTSxDQUFDLHNCQUFzQixDQUFDLENBQUM7SUFDcEQsTUFBTSxVQUFVLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQ3RDLE1BQU0sYUFBYSxHQUNqQixPQUFPLE9BQU8sS0FBSyxVQUFVLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBRXBFLE9BQU8sWUFBWSxDQUFDLHNCQUFzQixDQUFDLGFBQWEsRUFBRSxVQUFVLENBQUMsQ0FBQztBQUN4RSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgRGVzdHJveVJlZixcbiAgSW5qZWN0YWJsZSxcbiAgaW5qZWN0LFxuICBzaWduYWwsXG4gIGNvbXB1dGVkLFxuICBTaWduYWwsXG59IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBDb3BpbG90S2l0IH0gZnJvbSBcIi4vY29waWxvdGtpdFwiO1xuaW1wb3J0IHR5cGUgeyBBYnN0cmFjdEFnZW50IH0gZnJvbSBcIkBhZy11aS9jbGllbnRcIjtcbmltcG9ydCB0eXBlIHsgTWVzc2FnZSB9IGZyb20gXCJAYWctdWkvY2xpZW50XCI7XG5pbXBvcnQgeyBERUZBVUxUX0FHRU5UX0lEIH0gZnJvbSBcIkBjb3BpbG90a2l0bmV4dC9zaGFyZWRcIjtcblxuZXhwb3J0IGNsYXNzIEFnZW50U3RvcmUge1xuICByZWFkb25seSAjc3Vic2NyaXB0aW9uPzoge1xuICAgIHVuc3Vic2NyaWJlOiAoKSA9PiB2b2lkO1xuICB9O1xuICByZWFkb25seSAjaXNSdW5uaW5nID0gc2lnbmFsPGJvb2xlYW4+KGZhbHNlKTtcbiAgcmVhZG9ubHkgI21lc3NhZ2VzID0gc2lnbmFsPE1lc3NhZ2VbXT4oW10pO1xuICByZWFkb25seSAjc3RhdGUgPSBzaWduYWw8YW55Pih1bmRlZmluZWQpO1xuXG4gIHJlYWRvbmx5IGFnZW50OiBBYnN0cmFjdEFnZW50O1xuICByZWFkb25seSBpc1J1bm5pbmcgPSB0aGlzLiNpc1J1bm5pbmcuYXNSZWFkb25seSgpO1xuICByZWFkb25seSBtZXNzYWdlcyA9IHRoaXMuI21lc3NhZ2VzLmFzUmVhZG9ubHkoKTtcbiAgcmVhZG9ubHkgc3RhdGUgPSB0aGlzLiNzdGF0ZS5hc1JlYWRvbmx5KCk7XG5cbiAgY29uc3RydWN0b3IoYWJzdHJhY3RBZ2VudDogQWJzdHJhY3RBZ2VudCwgZGVzdHJveVJlZjogRGVzdHJveVJlZikge1xuICAgIHRoaXMuYWdlbnQgPSBhYnN0cmFjdEFnZW50O1xuXG4gICAgdGhpcy4jc3Vic2NyaXB0aW9uID0gYWJzdHJhY3RBZ2VudC5zdWJzY3JpYmUoe1xuICAgICAgb25NZXNzYWdlc0NoYW5nZWQ6ICgpID0+IHtcbiAgICAgICAgdGhpcy4jbWVzc2FnZXMuc2V0KGFic3RyYWN0QWdlbnQubWVzc2FnZXMpO1xuICAgICAgfSxcbiAgICAgIG9uU3RhdGVDaGFuZ2VkOiAoKSA9PiB7XG4gICAgICAgIHRoaXMuI3N0YXRlLnNldChhYnN0cmFjdEFnZW50LnN0YXRlKTtcbiAgICAgIH0sXG4gICAgICBvblJ1bkluaXRpYWxpemVkOiAoKSA9PiB7XG4gICAgICAgIHRoaXMuI2lzUnVubmluZy5zZXQodHJ1ZSk7XG4gICAgICB9LFxuICAgICAgb25SdW5GaW5hbGl6ZWQ6ICgpID0+IHtcbiAgICAgICAgdGhpcy4jaXNSdW5uaW5nLnNldChmYWxzZSk7XG4gICAgICB9LFxuICAgICAgb25SdW5GYWlsZWQ6ICgpID0+IHtcbiAgICAgICAgdGhpcy4jaXNSdW5uaW5nLnNldChmYWxzZSk7XG4gICAgICB9LFxuICAgIH0pO1xuXG4gICAgZGVzdHJveVJlZi5vbkRlc3Ryb3koKCkgPT4ge1xuICAgICAgdGhpcy50ZWFyZG93bigpO1xuICAgIH0pO1xuICB9XG5cbiAgdGVhcmRvd24oKTogdm9pZCB7XG4gICAgaWYgKHRoaXMuI3N1YnNjcmlwdGlvbikge1xuICAgICAgdGhpcy4jc3Vic2NyaXB0aW9uLnVuc3Vic2NyaWJlKCk7XG4gICAgfVxuICB9XG59XG5cbkBJbmplY3RhYmxlKHsgcHJvdmlkZWRJbjogXCJyb290XCIgfSlcbmV4cG9ydCBjbGFzcyBDb3BpbG90a2l0QWdlbnRGYWN0b3J5IHtcbiAgcmVhZG9ubHkgI2NvcGlsb3RraXQgPSBpbmplY3QoQ29waWxvdEtpdCk7XG5cbiAgY3JlYXRlQWdlbnRTdG9yZVNpZ25hbChcbiAgICBhZ2VudElkOiBTaWduYWw8c3RyaW5nIHwgdW5kZWZpbmVkPixcbiAgICBkZXN0cm95UmVmOiBEZXN0cm95UmVmXG4gICk6IFNpZ25hbDxBZ2VudFN0b3JlIHwgdW5kZWZpbmVkPiB7XG4gICAgbGV0IGxhc3RBZ2VudFN0b3JlOiBBZ2VudFN0b3JlIHwgdW5kZWZpbmVkO1xuXG4gICAgcmV0dXJuIGNvbXB1dGVkKCgpID0+IHtcbiAgICAgIHRoaXMuI2NvcGlsb3RraXQuYWdlbnRzKCk7XG5cbiAgICAgIGlmIChsYXN0QWdlbnRTdG9yZSkge1xuICAgICAgICBsYXN0QWdlbnRTdG9yZS50ZWFyZG93bigpO1xuICAgICAgICBsYXN0QWdlbnRTdG9yZSA9IHVuZGVmaW5lZDtcbiAgICAgIH1cblxuICAgICAgY29uc3QgYWJzdHJhY3RBZ2VudCA9IHRoaXMuI2NvcGlsb3RraXQuZ2V0QWdlbnQoXG4gICAgICAgIGFnZW50SWQoKSB8fCBERUZBVUxUX0FHRU5UX0lEXG4gICAgICApO1xuICAgICAgaWYgKCFhYnN0cmFjdEFnZW50KSByZXR1cm4gdW5kZWZpbmVkO1xuXG4gICAgICBsYXN0QWdlbnRTdG9yZSA9IG5ldyBBZ2VudFN0b3JlKGFic3RyYWN0QWdlbnQsIGRlc3Ryb3lSZWYpO1xuICAgICAgcmV0dXJuIGxhc3RBZ2VudFN0b3JlO1xuICAgIH0pO1xuICB9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpbmplY3RBZ2VudFN0b3JlKFxuICBhZ2VudElkOiBzdHJpbmcgfCBTaWduYWw8c3RyaW5nIHwgdW5kZWZpbmVkPlxuKTogU2lnbmFsPEFnZW50U3RvcmUgfCB1bmRlZmluZWQ+IHtcbiAgY29uc3QgYWdlbnRGYWN0b3J5ID0gaW5qZWN0KENvcGlsb3RraXRBZ2VudEZhY3RvcnkpO1xuICBjb25zdCBkZXN0cm95UmVmID0gaW5qZWN0KERlc3Ryb3lSZWYpO1xuICBjb25zdCBhZ2VudElkU2lnbmFsID1cbiAgICB0eXBlb2YgYWdlbnRJZCA9PT0gXCJmdW5jdGlvblwiID8gYWdlbnRJZCA6IGNvbXB1dGVkKCgpID0+IGFnZW50SWQpO1xuXG4gIHJldHVybiBhZ2VudEZhY3RvcnkuY3JlYXRlQWdlbnRTdG9yZVNpZ25hbChhZ2VudElkU2lnbmFsLCBkZXN0cm95UmVmKTtcbn1cbiJdfQ==
73
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWdlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL2FnZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxVQUFVLEVBQ1YsVUFBVSxFQUNWLE1BQU0sRUFDTixNQUFNLEVBQ04sUUFBUSxHQUVULE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFHMUMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7O0FBRTFELE1BQU0sT0FBTyxVQUFVO0lBQ1osYUFBYSxDQUVwQjtJQUNPLFVBQVUsR0FBRyxNQUFNLENBQVUsS0FBSyxDQUFDLENBQUM7SUFDcEMsU0FBUyxHQUFHLE1BQU0sQ0FBWSxFQUFFLENBQUMsQ0FBQztJQUNsQyxNQUFNLEdBQUcsTUFBTSxDQUFNLFNBQVMsQ0FBQyxDQUFDO0lBRWhDLEtBQUssQ0FBZ0I7SUFDckIsU0FBUyxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsVUFBVSxFQUFFLENBQUM7SUFDekMsUUFBUSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsVUFBVSxFQUFFLENBQUM7SUFDdkMsS0FBSyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsVUFBVSxFQUFFLENBQUM7SUFFMUMsWUFBWSxhQUE0QixFQUFFLFVBQXNCO1FBQzlELElBQUksQ0FBQyxLQUFLLEdBQUcsYUFBYSxDQUFDO1FBRTNCLElBQUksQ0FBQyxhQUFhLEdBQUcsYUFBYSxDQUFDLFNBQVMsQ0FBQztZQUMzQyxpQkFBaUIsRUFBRSxHQUFHLEVBQUU7Z0JBQ3RCLElBQUksQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLGFBQWEsQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUM3QyxDQUFDO1lBQ0QsY0FBYyxFQUFFLEdBQUcsRUFBRTtnQkFDbkIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ3ZDLENBQUM7WUFDRCxnQkFBZ0IsRUFBRSxHQUFHLEVBQUU7Z0JBQ3JCLElBQUksQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQzVCLENBQUM7WUFDRCxjQUFjLEVBQUUsR0FBRyxFQUFFO2dCQUNuQixJQUFJLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUM3QixDQUFDO1lBQ0QsV0FBVyxFQUFFLEdBQUcsRUFBRTtnQkFDaEIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDN0IsQ0FBQztTQUNGLENBQUMsQ0FBQztRQUVILFVBQVUsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ3hCLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNsQixDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxRQUFRO1FBQ04sSUFBSSxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7WUFDdkIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUNuQyxDQUFDO0lBQ0gsQ0FBQztDQUNGO0FBR0QsTUFBTSxPQUFPLHNCQUFzQjtJQUN4QixXQUFXLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBRTFDLHNCQUFzQixDQUNwQixPQUFtQyxFQUNuQyxVQUFzQjtRQUV0QixJQUFJLGNBQXNDLENBQUM7UUFFM0MsT0FBTyxRQUFRLENBQUMsR0FBRyxFQUFFO1lBQ25CLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxFQUFFLENBQUM7WUFFMUIsSUFBSSxjQUFjLEVBQUUsQ0FBQztnQkFDbkIsY0FBYyxDQUFDLFFBQVEsRUFBRSxDQUFDO2dCQUMxQixjQUFjLEdBQUcsU0FBUyxDQUFDO1lBQzdCLENBQUM7WUFFRCxNQUFNLGFBQWEsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FDN0MsT0FBTyxFQUFFLElBQUksZ0JBQWdCLENBQzlCLENBQUM7WUFDRixJQUFJLENBQUMsYUFBYTtnQkFBRSxPQUFPLFNBQVMsQ0FBQztZQUVyQyxjQUFjLEdBQUcsSUFBSSxVQUFVLENBQUMsYUFBYSxFQUFFLFVBQVUsQ0FBQyxDQUFDO1lBQzNELE9BQU8sY0FBYyxDQUFDO1FBQ3hCLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzt3R0F6QlUsc0JBQXNCOzRHQUF0QixzQkFBc0IsY0FEVCxNQUFNOzs0RkFDbkIsc0JBQXNCO2tCQURsQyxVQUFVO21CQUFDLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRTs7QUE2QmxDLE1BQU0sVUFBVSxnQkFBZ0IsQ0FDOUIsT0FBNEM7SUFFNUMsTUFBTSxZQUFZLEdBQUcsTUFBTSxDQUFDLHNCQUFzQixDQUFDLENBQUM7SUFDcEQsTUFBTSxVQUFVLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQ3RDLE1BQU0sYUFBYSxHQUNqQixPQUFPLE9BQU8sS0FBSyxVQUFVLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBRXBFLE9BQU8sWUFBWSxDQUFDLHNCQUFzQixDQUFDLGFBQWEsRUFBRSxVQUFVLENBQUMsQ0FBQztBQUN4RSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgRGVzdHJveVJlZixcbiAgSW5qZWN0YWJsZSxcbiAgaW5qZWN0LFxuICBzaWduYWwsXG4gIGNvbXB1dGVkLFxuICBTaWduYWwsXG59IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBDb3BpbG90S2l0IH0gZnJvbSBcIi4vY29waWxvdGtpdFwiO1xuaW1wb3J0IHR5cGUgeyBBYnN0cmFjdEFnZW50IH0gZnJvbSBcIkBhZy11aS9jbGllbnRcIjtcbmltcG9ydCB0eXBlIHsgTWVzc2FnZSB9IGZyb20gXCJAYWctdWkvY2xpZW50XCI7XG5pbXBvcnQgeyBERUZBVUxUX0FHRU5UX0lEIH0gZnJvbSBcIkBjb3BpbG90a2l0bmV4dC9zaGFyZWRcIjtcblxuZXhwb3J0IGNsYXNzIEFnZW50U3RvcmUge1xuICByZWFkb25seSAjc3Vic2NyaXB0aW9uPzoge1xuICAgIHVuc3Vic2NyaWJlOiAoKSA9PiB2b2lkO1xuICB9O1xuICByZWFkb25seSAjaXNSdW5uaW5nID0gc2lnbmFsPGJvb2xlYW4+KGZhbHNlKTtcbiAgcmVhZG9ubHkgI21lc3NhZ2VzID0gc2lnbmFsPE1lc3NhZ2VbXT4oW10pO1xuICByZWFkb25seSAjc3RhdGUgPSBzaWduYWw8YW55Pih1bmRlZmluZWQpO1xuXG4gIHJlYWRvbmx5IGFnZW50OiBBYnN0cmFjdEFnZW50O1xuICByZWFkb25seSBpc1J1bm5pbmcgPSB0aGlzLiNpc1J1bm5pbmcuYXNSZWFkb25seSgpO1xuICByZWFkb25seSBtZXNzYWdlcyA9IHRoaXMuI21lc3NhZ2VzLmFzUmVhZG9ubHkoKTtcbiAgcmVhZG9ubHkgc3RhdGUgPSB0aGlzLiNzdGF0ZS5hc1JlYWRvbmx5KCk7XG5cbiAgY29uc3RydWN0b3IoYWJzdHJhY3RBZ2VudDogQWJzdHJhY3RBZ2VudCwgZGVzdHJveVJlZjogRGVzdHJveVJlZikge1xuICAgIHRoaXMuYWdlbnQgPSBhYnN0cmFjdEFnZW50O1xuXG4gICAgdGhpcy4jc3Vic2NyaXB0aW9uID0gYWJzdHJhY3RBZ2VudC5zdWJzY3JpYmUoe1xuICAgICAgb25NZXNzYWdlc0NoYW5nZWQ6ICgpID0+IHtcbiAgICAgICAgdGhpcy4jbWVzc2FnZXMuc2V0KGFic3RyYWN0QWdlbnQubWVzc2FnZXMpO1xuICAgICAgfSxcbiAgICAgIG9uU3RhdGVDaGFuZ2VkOiAoKSA9PiB7XG4gICAgICAgIHRoaXMuI3N0YXRlLnNldChhYnN0cmFjdEFnZW50LnN0YXRlKTtcbiAgICAgIH0sXG4gICAgICBvblJ1bkluaXRpYWxpemVkOiAoKSA9PiB7XG4gICAgICAgIHRoaXMuI2lzUnVubmluZy5zZXQodHJ1ZSk7XG4gICAgICB9LFxuICAgICAgb25SdW5GaW5hbGl6ZWQ6ICgpID0+IHtcbiAgICAgICAgdGhpcy4jaXNSdW5uaW5nLnNldChmYWxzZSk7XG4gICAgICB9LFxuICAgICAgb25SdW5GYWlsZWQ6ICgpID0+IHtcbiAgICAgICAgdGhpcy4jaXNSdW5uaW5nLnNldChmYWxzZSk7XG4gICAgICB9LFxuICAgIH0pO1xuXG4gICAgZGVzdHJveVJlZi5vbkRlc3Ryb3koKCkgPT4ge1xuICAgICAgdGhpcy50ZWFyZG93bigpO1xuICAgIH0pO1xuICB9XG5cbiAgdGVhcmRvd24oKTogdm9pZCB7XG4gICAgaWYgKHRoaXMuI3N1YnNjcmlwdGlvbikge1xuICAgICAgdGhpcy4jc3Vic2NyaXB0aW9uLnVuc3Vic2NyaWJlKCk7XG4gICAgfVxuICB9XG59XG5cbkBJbmplY3RhYmxlKHsgcHJvdmlkZWRJbjogXCJyb290XCIgfSlcbmV4cG9ydCBjbGFzcyBDb3BpbG90a2l0QWdlbnRGYWN0b3J5IHtcbiAgcmVhZG9ubHkgI2NvcGlsb3RraXQgPSBpbmplY3QoQ29waWxvdEtpdCk7XG5cbiAgY3JlYXRlQWdlbnRTdG9yZVNpZ25hbChcbiAgICBhZ2VudElkOiBTaWduYWw8c3RyaW5nIHwgdW5kZWZpbmVkPixcbiAgICBkZXN0cm95UmVmOiBEZXN0cm95UmVmLFxuICApOiBTaWduYWw8QWdlbnRTdG9yZSB8IHVuZGVmaW5lZD4ge1xuICAgIGxldCBsYXN0QWdlbnRTdG9yZTogQWdlbnRTdG9yZSB8IHVuZGVmaW5lZDtcblxuICAgIHJldHVybiBjb21wdXRlZCgoKSA9PiB7XG4gICAgICB0aGlzLiNjb3BpbG90a2l0LmFnZW50cygpO1xuXG4gICAgICBpZiAobGFzdEFnZW50U3RvcmUpIHtcbiAgICAgICAgbGFzdEFnZW50U3RvcmUudGVhcmRvd24oKTtcbiAgICAgICAgbGFzdEFnZW50U3RvcmUgPSB1bmRlZmluZWQ7XG4gICAgICB9XG5cbiAgICAgIGNvbnN0IGFic3RyYWN0QWdlbnQgPSB0aGlzLiNjb3BpbG90a2l0LmdldEFnZW50KFxuICAgICAgICBhZ2VudElkKCkgfHwgREVGQVVMVF9BR0VOVF9JRCxcbiAgICAgICk7XG4gICAgICBpZiAoIWFic3RyYWN0QWdlbnQpIHJldHVybiB1bmRlZmluZWQ7XG5cbiAgICAgIGxhc3RBZ2VudFN0b3JlID0gbmV3IEFnZW50U3RvcmUoYWJzdHJhY3RBZ2VudCwgZGVzdHJveVJlZik7XG4gICAgICByZXR1cm4gbGFzdEFnZW50U3RvcmU7XG4gICAgfSk7XG4gIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGluamVjdEFnZW50U3RvcmUoXG4gIGFnZW50SWQ6IHN0cmluZyB8IFNpZ25hbDxzdHJpbmcgfCB1bmRlZmluZWQ+LFxuKTogU2lnbmFsPEFnZW50U3RvcmUgfCB1bmRlZmluZWQ+IHtcbiAgY29uc3QgYWdlbnRGYWN0b3J5ID0gaW5qZWN0KENvcGlsb3RraXRBZ2VudEZhY3RvcnkpO1xuICBjb25zdCBkZXN0cm95UmVmID0gaW5qZWN0KERlc3Ryb3lSZWYpO1xuICBjb25zdCBhZ2VudElkU2lnbmFsID1cbiAgICB0eXBlb2YgYWdlbnRJZCA9PT0gXCJmdW5jdGlvblwiID8gYWdlbnRJZCA6IGNvbXB1dGVkKCgpID0+IGFnZW50SWQpO1xuXG4gIHJldHVybiBhZ2VudEZhY3RvcnkuY3JlYXRlQWdlbnRTdG9yZVNpZ25hbChhZ2VudElkU2lnbmFsLCBkZXN0cm95UmVmKTtcbn1cbiJdfQ==
@@ -32,4 +32,4 @@ export function provideCopilotChatLabels(config) {
32
32
  },
33
33
  };
34
34
  }
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhdC1jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL2NoYXQtY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsY0FBYyxFQUFZLE1BQU0sZUFBZSxDQUFDO0FBc0JqRSwwQkFBMEI7QUFDMUIsTUFBTSxDQUFDLE1BQU0sMkJBQTJCLEdBQXNCO0lBQzVELG9CQUFvQixFQUFFLG1CQUFtQjtJQUN6QywwQ0FBMEMsRUFBRSxZQUFZO0lBQ3hELDJDQUEyQyxFQUFFLFFBQVE7SUFDckQsMkNBQTJDLEVBQUUsUUFBUTtJQUNyRCw4QkFBOEIsRUFBRSxxQkFBcUI7SUFDckQsZ0NBQWdDLEVBQUUsT0FBTztJQUN6QyxvQ0FBb0MsRUFBRSxNQUFNO0lBQzVDLDBDQUEwQyxFQUFFLFFBQVE7SUFDcEQsdUNBQXVDLEVBQUUsTUFBTTtJQUMvQyxvQ0FBb0MsRUFBRSxlQUFlO0lBQ3JELHNDQUFzQyxFQUFFLGNBQWM7SUFDdEQscUNBQXFDLEVBQUUsWUFBWTtJQUNuRCxzQ0FBc0MsRUFBRSxZQUFZO0lBQ3BELGtDQUFrQyxFQUFFLE1BQU07SUFDMUMsa0NBQWtDLEVBQUUsTUFBTTtJQUMxQyxrQkFBa0IsRUFDaEIsNERBQTREO0NBQy9ELENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBRyxJQUFJLGNBQWMsQ0FDbkQscUJBQXFCLENBQ3RCLENBQUM7QUFFRixNQUFNLFVBQVUsZ0JBQWdCO0lBQzlCLE9BQU8sQ0FDTCxNQUFNLENBQUMsbUJBQW1CLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLENBQUM7UUFDL0MsMkJBQTJCLENBQzVCLENBQUM7QUFDSixDQUFDO0FBRUQsTUFBTSxVQUFVLHdCQUF3QixDQUN0QyxNQUFrQztJQUVsQyxPQUFPO1FBQ0wsT0FBTyxFQUFFLG1CQUFtQjtRQUM1QixRQUFRLEVBQUU7WUFDUixHQUFHLDJCQUEyQjtZQUM5QixHQUFHLE1BQU07U0FDVjtLQUNGLENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaW5qZWN0LCBJbmplY3Rpb25Ub2tlbiwgUHJvdmlkZXIgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuXG4vLyBUeXBlIGZvciBjaGF0IGxhYmVsc1xuZXhwb3J0IGludGVyZmFjZSBDb3BpbG90Q2hhdExhYmVscyB7XG4gIGNoYXRJbnB1dFBsYWNlaG9sZGVyOiBzdHJpbmc7XG4gIGNoYXRJbnB1dFRvb2xiYXJTdGFydFRyYW5zY3JpYmVCdXR0b25MYWJlbDogc3RyaW5nO1xuICBjaGF0SW5wdXRUb29sYmFyQ2FuY2VsVHJhbnNjcmliZUJ1dHRvbkxhYmVsOiBzdHJpbmc7XG4gIGNoYXRJbnB1dFRvb2xiYXJGaW5pc2hUcmFuc2NyaWJlQnV0dG9uTGFiZWw6IHN0cmluZztcbiAgY2hhdElucHV0VG9vbGJhckFkZEJ1dHRvbkxhYmVsOiBzdHJpbmc7XG4gIGNoYXRJbnB1dFRvb2xiYXJUb29sc0J1dHRvbkxhYmVsOiBzdHJpbmc7XG4gIGFzc2lzdGFudE1lc3NhZ2VUb29sYmFyQ29weUNvZGVMYWJlbDogc3RyaW5nO1xuICBhc3Npc3RhbnRNZXNzYWdlVG9vbGJhckNvcHlDb2RlQ29waWVkTGFiZWw6IHN0cmluZztcbiAgYXNzaXN0YW50TWVzc2FnZVRvb2xiYXJDb3B5TWVzc2FnZUxhYmVsOiBzdHJpbmc7XG4gIGFzc2lzdGFudE1lc3NhZ2VUb29sYmFyVGh1bWJzVXBMYWJlbDogc3RyaW5nO1xuICBhc3Npc3RhbnRNZXNzYWdlVG9vbGJhclRodW1ic0Rvd25MYWJlbDogc3RyaW5nO1xuICBhc3Npc3RhbnRNZXNzYWdlVG9vbGJhclJlYWRBbG91ZExhYmVsOiBzdHJpbmc7XG4gIGFzc2lzdGFudE1lc3NhZ2VUb29sYmFyUmVnZW5lcmF0ZUxhYmVsOiBzdHJpbmc7XG4gIHVzZXJNZXNzYWdlVG9vbGJhckNvcHlNZXNzYWdlTGFiZWw6IHN0cmluZztcbiAgdXNlck1lc3NhZ2VUb29sYmFyRWRpdE1lc3NhZ2VMYWJlbDogc3RyaW5nO1xuICBjaGF0RGlzY2xhaW1lclRleHQ6IHN0cmluZztcbn1cblxuLy8gRGVmYXVsdCBsYWJlbHMgY29uc3RhbnRcbmV4cG9ydCBjb25zdCBDT1BJTE9UX0NIQVRfREVGQVVMVF9MQUJFTFM6IENvcGlsb3RDaGF0TGFiZWxzID0ge1xuICBjaGF0SW5wdXRQbGFjZWhvbGRlcjogXCJUeXBlIGEgbWVzc2FnZS4uLlwiLFxuICBjaGF0SW5wdXRUb29sYmFyU3RhcnRUcmFuc2NyaWJlQnV0dG9uTGFiZWw6IFwiVHJhbnNjcmliZVwiLFxuICBjaGF0SW5wdXRUb29sYmFyQ2FuY2VsVHJhbnNjcmliZUJ1dHRvbkxhYmVsOiBcIkNhbmNlbFwiLFxuICBjaGF0SW5wdXRUb29sYmFyRmluaXNoVHJhbnNjcmliZUJ1dHRvbkxhYmVsOiBcIkZpbmlzaFwiLFxuICBjaGF0SW5wdXRUb29sYmFyQWRkQnV0dG9uTGFiZWw6IFwiQWRkIHBob3RvcyBvciBmaWxlc1wiLFxuICBjaGF0SW5wdXRUb29sYmFyVG9vbHNCdXR0b25MYWJlbDogXCJUb29sc1wiLFxuICBhc3Npc3RhbnRNZXNzYWdlVG9vbGJhckNvcHlDb2RlTGFiZWw6IFwiQ29weVwiLFxuICBhc3Npc3RhbnRNZXNzYWdlVG9vbGJhckNvcHlDb2RlQ29waWVkTGFiZWw6IFwiQ29waWVkXCIsXG4gIGFzc2lzdGFudE1lc3NhZ2VUb29sYmFyQ29weU1lc3NhZ2VMYWJlbDogXCJDb3B5XCIsXG4gIGFzc2lzdGFudE1lc3NhZ2VUb29sYmFyVGh1bWJzVXBMYWJlbDogXCJHb29kIHJlc3BvbnNlXCIsXG4gIGFzc2lzdGFudE1lc3NhZ2VUb29sYmFyVGh1bWJzRG93bkxhYmVsOiBcIkJhZCByZXNwb25zZVwiLFxuICBhc3Npc3RhbnRNZXNzYWdlVG9vbGJhclJlYWRBbG91ZExhYmVsOiBcIlJlYWQgYWxvdWRcIixcbiAgYXNzaXN0YW50TWVzc2FnZVRvb2xiYXJSZWdlbmVyYXRlTGFiZWw6IFwiUmVnZW5lcmF0ZVwiLFxuICB1c2VyTWVzc2FnZVRvb2xiYXJDb3B5TWVzc2FnZUxhYmVsOiBcIkNvcHlcIixcbiAgdXNlck1lc3NhZ2VUb29sYmFyRWRpdE1lc3NhZ2VMYWJlbDogXCJFZGl0XCIsXG4gIGNoYXREaXNjbGFpbWVyVGV4dDpcbiAgICBcIkFJIGNhbiBtYWtlIG1pc3Rha2VzLiBQbGVhc2UgdmVyaWZ5IGltcG9ydGFudCBpbmZvcm1hdGlvbi5cIixcbn07XG5cbmV4cG9ydCBjb25zdCBDT1BJTE9UX0NIQVRfTEFCRUxTID0gbmV3IEluamVjdGlvblRva2VuPENvcGlsb3RDaGF0TGFiZWxzPihcbiAgXCJDT1BJTE9UX0NIQVRfTEFCRUxTXCJcbik7XG5cbmV4cG9ydCBmdW5jdGlvbiBpbmplY3RDaGF0TGFiZWxzKCk6IENvcGlsb3RDaGF0TGFiZWxzIHtcbiAgcmV0dXJuIChcbiAgICBpbmplY3QoQ09QSUxPVF9DSEFUX0xBQkVMUywgeyBvcHRpb25hbDogdHJ1ZSB9KSA/P1xuICAgIENPUElMT1RfQ0hBVF9ERUZBVUxUX0xBQkVMU1xuICApO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gcHJvdmlkZUNvcGlsb3RDaGF0TGFiZWxzKFxuICBjb25maWc6IFBhcnRpYWw8Q29waWxvdENoYXRMYWJlbHM+XG4pOiBQcm92aWRlciB7XG4gIHJldHVybiB7XG4gICAgcHJvdmlkZTogQ09QSUxPVF9DSEFUX0xBQkVMUyxcbiAgICB1c2VWYWx1ZToge1xuICAgICAgLi4uQ09QSUxPVF9DSEFUX0RFRkFVTFRfTEFCRUxTLFxuICAgICAgLi4uY29uZmlnLFxuICAgIH0sXG4gIH07XG59XG4iXX0=
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhdC1jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL2NoYXQtY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsY0FBYyxFQUFZLE1BQU0sZUFBZSxDQUFDO0FBc0JqRSwwQkFBMEI7QUFDMUIsTUFBTSxDQUFDLE1BQU0sMkJBQTJCLEdBQXNCO0lBQzVELG9CQUFvQixFQUFFLG1CQUFtQjtJQUN6QywwQ0FBMEMsRUFBRSxZQUFZO0lBQ3hELDJDQUEyQyxFQUFFLFFBQVE7SUFDckQsMkNBQTJDLEVBQUUsUUFBUTtJQUNyRCw4QkFBOEIsRUFBRSxxQkFBcUI7SUFDckQsZ0NBQWdDLEVBQUUsT0FBTztJQUN6QyxvQ0FBb0MsRUFBRSxNQUFNO0lBQzVDLDBDQUEwQyxFQUFFLFFBQVE7SUFDcEQsdUNBQXVDLEVBQUUsTUFBTTtJQUMvQyxvQ0FBb0MsRUFBRSxlQUFlO0lBQ3JELHNDQUFzQyxFQUFFLGNBQWM7SUFDdEQscUNBQXFDLEVBQUUsWUFBWTtJQUNuRCxzQ0FBc0MsRUFBRSxZQUFZO0lBQ3BELGtDQUFrQyxFQUFFLE1BQU07SUFDMUMsa0NBQWtDLEVBQUUsTUFBTTtJQUMxQyxrQkFBa0IsRUFDaEIsNERBQTREO0NBQy9ELENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBRyxJQUFJLGNBQWMsQ0FDbkQscUJBQXFCLENBQ3RCLENBQUM7QUFFRixNQUFNLFVBQVUsZ0JBQWdCO0lBQzlCLE9BQU8sQ0FDTCxNQUFNLENBQUMsbUJBQW1CLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLENBQUM7UUFDL0MsMkJBQTJCLENBQzVCLENBQUM7QUFDSixDQUFDO0FBRUQsTUFBTSxVQUFVLHdCQUF3QixDQUN0QyxNQUFrQztJQUVsQyxPQUFPO1FBQ0wsT0FBTyxFQUFFLG1CQUFtQjtRQUM1QixRQUFRLEVBQUU7WUFDUixHQUFHLDJCQUEyQjtZQUM5QixHQUFHLE1BQU07U0FDVjtLQUNGLENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaW5qZWN0LCBJbmplY3Rpb25Ub2tlbiwgUHJvdmlkZXIgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuXG4vLyBUeXBlIGZvciBjaGF0IGxhYmVsc1xuZXhwb3J0IGludGVyZmFjZSBDb3BpbG90Q2hhdExhYmVscyB7XG4gIGNoYXRJbnB1dFBsYWNlaG9sZGVyOiBzdHJpbmc7XG4gIGNoYXRJbnB1dFRvb2xiYXJTdGFydFRyYW5zY3JpYmVCdXR0b25MYWJlbDogc3RyaW5nO1xuICBjaGF0SW5wdXRUb29sYmFyQ2FuY2VsVHJhbnNjcmliZUJ1dHRvbkxhYmVsOiBzdHJpbmc7XG4gIGNoYXRJbnB1dFRvb2xiYXJGaW5pc2hUcmFuc2NyaWJlQnV0dG9uTGFiZWw6IHN0cmluZztcbiAgY2hhdElucHV0VG9vbGJhckFkZEJ1dHRvbkxhYmVsOiBzdHJpbmc7XG4gIGNoYXRJbnB1dFRvb2xiYXJUb29sc0J1dHRvbkxhYmVsOiBzdHJpbmc7XG4gIGFzc2lzdGFudE1lc3NhZ2VUb29sYmFyQ29weUNvZGVMYWJlbDogc3RyaW5nO1xuICBhc3Npc3RhbnRNZXNzYWdlVG9vbGJhckNvcHlDb2RlQ29waWVkTGFiZWw6IHN0cmluZztcbiAgYXNzaXN0YW50TWVzc2FnZVRvb2xiYXJDb3B5TWVzc2FnZUxhYmVsOiBzdHJpbmc7XG4gIGFzc2lzdGFudE1lc3NhZ2VUb29sYmFyVGh1bWJzVXBMYWJlbDogc3RyaW5nO1xuICBhc3Npc3RhbnRNZXNzYWdlVG9vbGJhclRodW1ic0Rvd25MYWJlbDogc3RyaW5nO1xuICBhc3Npc3RhbnRNZXNzYWdlVG9vbGJhclJlYWRBbG91ZExhYmVsOiBzdHJpbmc7XG4gIGFzc2lzdGFudE1lc3NhZ2VUb29sYmFyUmVnZW5lcmF0ZUxhYmVsOiBzdHJpbmc7XG4gIHVzZXJNZXNzYWdlVG9vbGJhckNvcHlNZXNzYWdlTGFiZWw6IHN0cmluZztcbiAgdXNlck1lc3NhZ2VUb29sYmFyRWRpdE1lc3NhZ2VMYWJlbDogc3RyaW5nO1xuICBjaGF0RGlzY2xhaW1lclRleHQ6IHN0cmluZztcbn1cblxuLy8gRGVmYXVsdCBsYWJlbHMgY29uc3RhbnRcbmV4cG9ydCBjb25zdCBDT1BJTE9UX0NIQVRfREVGQVVMVF9MQUJFTFM6IENvcGlsb3RDaGF0TGFiZWxzID0ge1xuICBjaGF0SW5wdXRQbGFjZWhvbGRlcjogXCJUeXBlIGEgbWVzc2FnZS4uLlwiLFxuICBjaGF0SW5wdXRUb29sYmFyU3RhcnRUcmFuc2NyaWJlQnV0dG9uTGFiZWw6IFwiVHJhbnNjcmliZVwiLFxuICBjaGF0SW5wdXRUb29sYmFyQ2FuY2VsVHJhbnNjcmliZUJ1dHRvbkxhYmVsOiBcIkNhbmNlbFwiLFxuICBjaGF0SW5wdXRUb29sYmFyRmluaXNoVHJhbnNjcmliZUJ1dHRvbkxhYmVsOiBcIkZpbmlzaFwiLFxuICBjaGF0SW5wdXRUb29sYmFyQWRkQnV0dG9uTGFiZWw6IFwiQWRkIHBob3RvcyBvciBmaWxlc1wiLFxuICBjaGF0SW5wdXRUb29sYmFyVG9vbHNCdXR0b25MYWJlbDogXCJUb29sc1wiLFxuICBhc3Npc3RhbnRNZXNzYWdlVG9vbGJhckNvcHlDb2RlTGFiZWw6IFwiQ29weVwiLFxuICBhc3Npc3RhbnRNZXNzYWdlVG9vbGJhckNvcHlDb2RlQ29waWVkTGFiZWw6IFwiQ29waWVkXCIsXG4gIGFzc2lzdGFudE1lc3NhZ2VUb29sYmFyQ29weU1lc3NhZ2VMYWJlbDogXCJDb3B5XCIsXG4gIGFzc2lzdGFudE1lc3NhZ2VUb29sYmFyVGh1bWJzVXBMYWJlbDogXCJHb29kIHJlc3BvbnNlXCIsXG4gIGFzc2lzdGFudE1lc3NhZ2VUb29sYmFyVGh1bWJzRG93bkxhYmVsOiBcIkJhZCByZXNwb25zZVwiLFxuICBhc3Npc3RhbnRNZXNzYWdlVG9vbGJhclJlYWRBbG91ZExhYmVsOiBcIlJlYWQgYWxvdWRcIixcbiAgYXNzaXN0YW50TWVzc2FnZVRvb2xiYXJSZWdlbmVyYXRlTGFiZWw6IFwiUmVnZW5lcmF0ZVwiLFxuICB1c2VyTWVzc2FnZVRvb2xiYXJDb3B5TWVzc2FnZUxhYmVsOiBcIkNvcHlcIixcbiAgdXNlck1lc3NhZ2VUb29sYmFyRWRpdE1lc3NhZ2VMYWJlbDogXCJFZGl0XCIsXG4gIGNoYXREaXNjbGFpbWVyVGV4dDpcbiAgICBcIkFJIGNhbiBtYWtlIG1pc3Rha2VzLiBQbGVhc2UgdmVyaWZ5IGltcG9ydGFudCBpbmZvcm1hdGlvbi5cIixcbn07XG5cbmV4cG9ydCBjb25zdCBDT1BJTE9UX0NIQVRfTEFCRUxTID0gbmV3IEluamVjdGlvblRva2VuPENvcGlsb3RDaGF0TGFiZWxzPihcbiAgXCJDT1BJTE9UX0NIQVRfTEFCRUxTXCIsXG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gaW5qZWN0Q2hhdExhYmVscygpOiBDb3BpbG90Q2hhdExhYmVscyB7XG4gIHJldHVybiAoXG4gICAgaW5qZWN0KENPUElMT1RfQ0hBVF9MQUJFTFMsIHsgb3B0aW9uYWw6IHRydWUgfSkgPz9cbiAgICBDT1BJTE9UX0NIQVRfREVGQVVMVF9MQUJFTFNcbiAgKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHByb3ZpZGVDb3BpbG90Q2hhdExhYmVscyhcbiAgY29uZmlnOiBQYXJ0aWFsPENvcGlsb3RDaGF0TGFiZWxzPixcbik6IFByb3ZpZGVyIHtcbiAgcmV0dXJuIHtcbiAgICBwcm92aWRlOiBDT1BJTE9UX0NIQVRfTEFCRUxTLFxuICAgIHVzZVZhbHVlOiB7XG4gICAgICAuLi5DT1BJTE9UX0NIQVRfREVGQVVMVF9MQUJFTFMsXG4gICAgICAuLi5jb25maWcsXG4gICAgfSxcbiAgfTtcbn1cbiJdfQ==
@@ -15,4 +15,4 @@ export function injectChatState() {
15
15
  throw new Error("ChatState not found. A parent component must provide ChatState.");
16
16
  }
17
17
  }
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhdC1zdGF0ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvY2hhdC1zdGF0ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBa0IsTUFBTSxlQUFlLENBQUM7O0FBR25FLE1BQU0sT0FBZ0IsU0FBUzt3R0FBVCxTQUFTOzRHQUFULFNBQVM7OzRGQUFULFNBQVM7a0JBRDlCLFVBQVU7O0FBUVgsTUFBTSxVQUFVLGVBQWU7SUFDN0IsSUFBSSxDQUFDO1FBQ0gsT0FBTyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDM0IsQ0FBQztJQUFDLE1BQU0sQ0FBQztRQUNQLE1BQU0sSUFBSSxLQUFLLENBQ2IsaUVBQWlFLENBQ2xFLENBQUM7SUFDSixDQUFDO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGluamVjdCwgSW5qZWN0YWJsZSwgV3JpdGFibGVTaWduYWwgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQ2hhdFN0YXRlIHtcbiAgYWJzdHJhY3QgcmVhZG9ubHkgaW5wdXRWYWx1ZTogV3JpdGFibGVTaWduYWw8c3RyaW5nPjtcblxuICBhYnN0cmFjdCBzdWJtaXRJbnB1dCh2YWx1ZTogc3RyaW5nKTogdm9pZDtcbiAgYWJzdHJhY3QgY2hhbmdlSW5wdXQodmFsdWU6IHN0cmluZyk6IHZvaWQ7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpbmplY3RDaGF0U3RhdGUoKTogQ2hhdFN0YXRlIHtcbiAgdHJ5IHtcbiAgICByZXR1cm4gaW5qZWN0KENoYXRTdGF0ZSk7XG4gIH0gY2F0Y2gge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgIFwiQ2hhdFN0YXRlIG5vdCBmb3VuZC4gQSBwYXJlbnQgY29tcG9uZW50IG11c3QgcHJvdmlkZSBDaGF0U3RhdGUuXCJcbiAgICApO1xuICB9XG59XG4iXX0=
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhdC1zdGF0ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvY2hhdC1zdGF0ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBa0IsTUFBTSxlQUFlLENBQUM7O0FBR25FLE1BQU0sT0FBZ0IsU0FBUzt3R0FBVCxTQUFTOzRHQUFULFNBQVM7OzRGQUFULFNBQVM7a0JBRDlCLFVBQVU7O0FBUVgsTUFBTSxVQUFVLGVBQWU7SUFDN0IsSUFBSSxDQUFDO1FBQ0gsT0FBTyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDM0IsQ0FBQztJQUFDLE1BQU0sQ0FBQztRQUNQLE1BQU0sSUFBSSxLQUFLLENBQ2IsaUVBQWlFLENBQ2xFLENBQUM7SUFDSixDQUFDO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGluamVjdCwgSW5qZWN0YWJsZSwgV3JpdGFibGVTaWduYWwgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQ2hhdFN0YXRlIHtcbiAgYWJzdHJhY3QgcmVhZG9ubHkgaW5wdXRWYWx1ZTogV3JpdGFibGVTaWduYWw8c3RyaW5nPjtcblxuICBhYnN0cmFjdCBzdWJtaXRJbnB1dCh2YWx1ZTogc3RyaW5nKTogdm9pZDtcbiAgYWJzdHJhY3QgY2hhbmdlSW5wdXQodmFsdWU6IHN0cmluZyk6IHZvaWQ7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpbmplY3RDaGF0U3RhdGUoKTogQ2hhdFN0YXRlIHtcbiAgdHJ5IHtcbiAgICByZXR1cm4gaW5qZWN0KENoYXRTdGF0ZSk7XG4gIH0gY2F0Y2gge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgIFwiQ2hhdFN0YXRlIG5vdCBmb3VuZC4gQSBwYXJlbnQgY29tcG9uZW50IG11c3QgcHJvdmlkZSBDaGF0U3RhdGUuXCIsXG4gICAgKTtcbiAgfVxufVxuIl19
@@ -341,4 +341,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
341
341
  `,
342
342
  }]
343
343
  }] });
344
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"copilot-chat-assistant-message-buttons.js","sourceRoot":"","sources":["../../../../../src/lib/components/chat/copilot-chat-assistant-message-buttons.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  input,\n  output,\n  signal,\n  computed,\n  ChangeDetectionStrategy,\n  ViewEncapsulation,\n} from \"@angular/core\";\nimport { CommonModule } from \"@angular/common\";\nimport {\n  LucideAngularModule,\n  Copy,\n  Check,\n  ThumbsUp,\n  ThumbsDown,\n  Volume2,\n  RefreshCw,\n} from \"lucide-angular\";\nimport { CopilotTooltip } from \"../../directives/tooltip\";\nimport { cn } from \"../../utils\";\nimport { injectChatLabels } from \"../../chat-config\";\n\n// Base toolbar button component\n@Component({\n  standalone: true,\n  selector: \"button[copilotChatAssistantMessageToolbarButton]\",\n  imports: [CommonModule],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  template: ` <ng-content></ng-content> `,\n  host: {\n    \"[class]\": \"computedClass()\",\n    \"[attr.disabled]\": \"disabled() ? true : null\",\n    type: \"button\",\n    \"[attr.aria-label]\": \"title()\",\n  },\n  hostDirectives: [\n    {\n      directive: CopilotTooltip,\n      inputs: [\"copilotTooltip: title\", \"tooltipPosition\", \"tooltipDelay\"],\n    },\n  ],\n})\nexport class CopilotChatAssistantMessageToolbarButton {\n  title = input<string>(\"\");\n  disabled = input<boolean>(false);\n  inputClass = input<string | undefined>();\n\n  computedClass = computed(() => {\n    return cn(\n      // Flex centering with gap (from React button base styles)\n      \"inline-flex items-center justify-center gap-2\",\n      // Cursor\n      \"cursor-pointer\",\n      // Background and text\n      \"p-0 text-[rgb(93,93,93)] hover:bg-[#E8E8E8]\",\n      // Dark mode\n      \"dark:text-[rgb(243,243,243)] dark:hover:bg-[#303030]\",\n      // Shape and sizing\n      \"h-8 w-8 rounded-md\",\n      // Interactions\n      \"transition-colors\",\n      // Hover states\n      \"hover:text-[rgb(93,93,93)]\",\n      \"dark:hover:text-[rgb(243,243,243)]\",\n      // Focus states\n      \"focus:outline-none focus:ring-2 focus:ring-offset-2\",\n      // Disabled state\n      \"disabled:opacity-50 disabled:cursor-not-allowed\",\n      // SVG styling from React Button component\n      \"[&_svg]:pointer-events-none [&_svg]:shrink-0\",\n      // Ensure proper sizing\n      \"shrink-0\",\n      this.inputClass()\n    );\n  });\n}\n\n// Copy button component\n@Component({\n  standalone: true,\n  selector: \"copilot-chat-assistant-message-copy-button\",\n  imports: [\n    CommonModule,\n    LucideAngularModule,\n    CopilotChatAssistantMessageToolbarButton,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  template: `\n    <button\n      copilotChatAssistantMessageToolbarButton\n      [title]=\"title() || labels.assistantMessageToolbarCopyMessageLabel\"\n      [disabled]=\"disabled()\"\n      [inputClass]=\"inputClass()\"\n      (click)=\"handleCopy($event)\"\n    >\n      @if (copied()) {\n        <lucide-angular [img]=\"CheckIcon\" [size]=\"18\"></lucide-angular>\n      } @else {\n        <lucide-angular [img]=\"CopyIcon\" [size]=\"18\"></lucide-angular>\n      }\n    </button>\n  `,\n})\nexport class CopilotChatAssistantMessageCopyButton {\n  readonly title = input<string | undefined>();\n  readonly disabled = input<boolean>(false);\n  readonly inputClass = input<string | undefined>();\n  readonly content = input<string | undefined>();\n  readonly clicked = output<void>();\n  readonly CopyIcon = Copy;\n  readonly CheckIcon = Check;\n  readonly copied = signal(false);\n  readonly labels = injectChatLabels();\n\n  handleCopy(event?: Event): void {\n    event?.stopPropagation();\n    if (!this.content()) return;\n\n    // Set copied immediately for instant feedback\n    this.copied.set(true);\n    setTimeout(() => this.copied.set(false), 2000);\n\n    // Copy to clipboard (fire and forget)\n    navigator.clipboard.writeText(this.content()!).then(\n      () => this.clicked.emit(),\n      (err) => {\n        console.error(\"Failed to copy message:\", err);\n        this.copied.set(false);\n      }\n    );\n  }\n}\n\n// Thumbs up button component\n@Component({\n  standalone: true,\n  selector: \"copilot-chat-assistant-message-thumbs-up-button\",\n  imports: [\n    CommonModule,\n    LucideAngularModule,\n    CopilotChatAssistantMessageToolbarButton,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  template: `\n    <button\n      copilotChatAssistantMessageToolbarButton\n      [title]=\"title() || labels.assistantMessageToolbarThumbsUpLabel\"\n      [disabled]=\"disabled()\"\n      [inputClass]=\"inputClass()\"\n      (click)=\"handleClick($event)\"\n    >\n      <lucide-angular [img]=\"ThumbsUpIcon\" [size]=\"18\"></lucide-angular>\n    </button>\n  `,\n})\nexport class CopilotChatAssistantMessageThumbsUpButton {\n  readonly title = input<string | undefined>();\n  readonly disabled = input<boolean>(false);\n  readonly inputClass = input<string | undefined>();\n  readonly clicked = output<void>();\n  readonly ThumbsUpIcon = ThumbsUp;\n  readonly labels = injectChatLabels();\n\n  handleClick(event?: Event): void {\n    event?.stopPropagation();\n    if (!this.disabled()) {\n      this.clicked.emit();\n    }\n  }\n}\n\n// Thumbs down button component\n@Component({\n  standalone: true,\n  selector: \"copilot-chat-assistant-message-thumbs-down-button\",\n  imports: [\n    CommonModule,\n    LucideAngularModule,\n    CopilotChatAssistantMessageToolbarButton,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  template: `\n    <button\n      copilotChatAssistantMessageToolbarButton\n      [title]=\"title() || labels.assistantMessageToolbarThumbsDownLabel\"\n      [disabled]=\"disabled()\"\n      [inputClass]=\"inputClass()\"\n      (click)=\"handleClick($event)\"\n    >\n      <lucide-angular [img]=\"ThumbsDownIcon\" [size]=\"18\"></lucide-angular>\n    </button>\n  `,\n})\nexport class CopilotChatAssistantMessageThumbsDownButton {\n  readonly title = input<string | undefined>();\n  readonly disabled = input<boolean>(false);\n  readonly inputClass = input<string | undefined>();\n  readonly clicked = output<void>();\n  readonly ThumbsDownIcon = ThumbsDown;\n  readonly labels = injectChatLabels();\n\n  handleClick(event?: Event): void {\n    event?.stopPropagation();\n    if (!this.disabled()) {\n      this.clicked.emit();\n    }\n  }\n}\n\n// Read aloud button component\n@Component({\n  standalone: true,\n  selector: \"copilot-chat-assistant-message-read-aloud-button\",\n  imports: [\n    CommonModule,\n    LucideAngularModule,\n    CopilotChatAssistantMessageToolbarButton,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  template: `\n    <button\n      copilotChatAssistantMessageToolbarButton\n      [title]=\"title() || labels.assistantMessageToolbarReadAloudLabel\"\n      [disabled]=\"disabled()\"\n      [inputClass]=\"inputClass()\"\n      (click)=\"handleClick($event)\"\n    >\n      <lucide-angular [img]=\"Volume2Icon\" [size]=\"20\"></lucide-angular>\n    </button>\n  `,\n})\nexport class CopilotChatAssistantMessageReadAloudButton {\n  readonly title = input<string | undefined>();\n  readonly disabled = input<boolean>(false);\n  readonly inputClass = input<string | undefined>();\n  readonly clicked = output<void>();\n  readonly Volume2Icon = Volume2;\n  readonly labels = injectChatLabels();\n\n  handleClick(event?: Event): void {\n    event?.stopPropagation();\n    if (!this.disabled()) {\n      this.clicked.emit();\n    }\n  }\n}\n\n// Regenerate button component\n@Component({\n  standalone: true,\n  selector: \"copilot-chat-assistant-message-regenerate-button\",\n  imports: [\n    CommonModule,\n    LucideAngularModule,\n    CopilotChatAssistantMessageToolbarButton,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  template: `\n    <button\n      copilotChatAssistantMessageToolbarButton\n      [title]=\"title() || labels.assistantMessageToolbarRegenerateLabel\"\n      [disabled]=\"disabled()\"\n      [inputClass]=\"inputClass()\"\n      (click)=\"handleClick($event)\"\n    >\n      <lucide-angular [img]=\"RefreshCwIcon\" [size]=\"18\"></lucide-angular>\n    </button>\n  `,\n})\nexport class CopilotChatAssistantMessageRegenerateButton {\n  readonly title = input<string | undefined>();\n  readonly disabled = input<boolean>(false);\n  readonly inputClass = input<string | undefined>();\n  readonly clicked = output<void>();\n  readonly RefreshCwIcon = RefreshCw;\n  readonly labels = injectChatLabels();\n\n  handleClick(event?: Event): void {\n    event?.stopPropagation();\n    if (!this.disabled()) {\n      this.clicked.emit();\n    }\n  }\n}\n"]}
344
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"copilot-chat-assistant-message-buttons.js","sourceRoot":"","sources":["../../../../../src/lib/components/chat/copilot-chat-assistant-message-buttons.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  input,\n  output,\n  signal,\n  computed,\n  ChangeDetectionStrategy,\n  ViewEncapsulation,\n} from \"@angular/core\";\nimport { CommonModule } from \"@angular/common\";\nimport {\n  LucideAngularModule,\n  Copy,\n  Check,\n  ThumbsUp,\n  ThumbsDown,\n  Volume2,\n  RefreshCw,\n} from \"lucide-angular\";\nimport { CopilotTooltip } from \"../../directives/tooltip\";\nimport { cn } from \"../../utils\";\nimport { injectChatLabels } from \"../../chat-config\";\n\n// Base toolbar button component\n@Component({\n  standalone: true,\n  selector: \"button[copilotChatAssistantMessageToolbarButton]\",\n  imports: [CommonModule],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  template: ` <ng-content></ng-content> `,\n  host: {\n    \"[class]\": \"computedClass()\",\n    \"[attr.disabled]\": \"disabled() ? true : null\",\n    type: \"button\",\n    \"[attr.aria-label]\": \"title()\",\n  },\n  hostDirectives: [\n    {\n      directive: CopilotTooltip,\n      inputs: [\"copilotTooltip: title\", \"tooltipPosition\", \"tooltipDelay\"],\n    },\n  ],\n})\nexport class CopilotChatAssistantMessageToolbarButton {\n  title = input<string>(\"\");\n  disabled = input<boolean>(false);\n  inputClass = input<string | undefined>();\n\n  computedClass = computed(() => {\n    return cn(\n      // Flex centering with gap (from React button base styles)\n      \"inline-flex items-center justify-center gap-2\",\n      // Cursor\n      \"cursor-pointer\",\n      // Background and text\n      \"p-0 text-[rgb(93,93,93)] hover:bg-[#E8E8E8]\",\n      // Dark mode\n      \"dark:text-[rgb(243,243,243)] dark:hover:bg-[#303030]\",\n      // Shape and sizing\n      \"h-8 w-8 rounded-md\",\n      // Interactions\n      \"transition-colors\",\n      // Hover states\n      \"hover:text-[rgb(93,93,93)]\",\n      \"dark:hover:text-[rgb(243,243,243)]\",\n      // Focus states\n      \"focus:outline-none focus:ring-2 focus:ring-offset-2\",\n      // Disabled state\n      \"disabled:opacity-50 disabled:cursor-not-allowed\",\n      // SVG styling from React Button component\n      \"[&_svg]:pointer-events-none [&_svg]:shrink-0\",\n      // Ensure proper sizing\n      \"shrink-0\",\n      this.inputClass(),\n    );\n  });\n}\n\n// Copy button component\n@Component({\n  standalone: true,\n  selector: \"copilot-chat-assistant-message-copy-button\",\n  imports: [\n    CommonModule,\n    LucideAngularModule,\n    CopilotChatAssistantMessageToolbarButton,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  template: `\n    <button\n      copilotChatAssistantMessageToolbarButton\n      [title]=\"title() || labels.assistantMessageToolbarCopyMessageLabel\"\n      [disabled]=\"disabled()\"\n      [inputClass]=\"inputClass()\"\n      (click)=\"handleCopy($event)\"\n    >\n      @if (copied()) {\n        <lucide-angular [img]=\"CheckIcon\" [size]=\"18\"></lucide-angular>\n      } @else {\n        <lucide-angular [img]=\"CopyIcon\" [size]=\"18\"></lucide-angular>\n      }\n    </button>\n  `,\n})\nexport class CopilotChatAssistantMessageCopyButton {\n  readonly title = input<string | undefined>();\n  readonly disabled = input<boolean>(false);\n  readonly inputClass = input<string | undefined>();\n  readonly content = input<string | undefined>();\n  readonly clicked = output<void>();\n  readonly CopyIcon = Copy;\n  readonly CheckIcon = Check;\n  readonly copied = signal(false);\n  readonly labels = injectChatLabels();\n\n  handleCopy(event?: Event): void {\n    event?.stopPropagation();\n    if (!this.content()) return;\n\n    // Set copied immediately for instant feedback\n    this.copied.set(true);\n    setTimeout(() => this.copied.set(false), 2000);\n\n    // Copy to clipboard (fire and forget)\n    navigator.clipboard.writeText(this.content()!).then(\n      () => this.clicked.emit(),\n      (err) => {\n        console.error(\"Failed to copy message:\", err);\n        this.copied.set(false);\n      },\n    );\n  }\n}\n\n// Thumbs up button component\n@Component({\n  standalone: true,\n  selector: \"copilot-chat-assistant-message-thumbs-up-button\",\n  imports: [\n    CommonModule,\n    LucideAngularModule,\n    CopilotChatAssistantMessageToolbarButton,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  template: `\n    <button\n      copilotChatAssistantMessageToolbarButton\n      [title]=\"title() || labels.assistantMessageToolbarThumbsUpLabel\"\n      [disabled]=\"disabled()\"\n      [inputClass]=\"inputClass()\"\n      (click)=\"handleClick($event)\"\n    >\n      <lucide-angular [img]=\"ThumbsUpIcon\" [size]=\"18\"></lucide-angular>\n    </button>\n  `,\n})\nexport class CopilotChatAssistantMessageThumbsUpButton {\n  readonly title = input<string | undefined>();\n  readonly disabled = input<boolean>(false);\n  readonly inputClass = input<string | undefined>();\n  readonly clicked = output<void>();\n  readonly ThumbsUpIcon = ThumbsUp;\n  readonly labels = injectChatLabels();\n\n  handleClick(event?: Event): void {\n    event?.stopPropagation();\n    if (!this.disabled()) {\n      this.clicked.emit();\n    }\n  }\n}\n\n// Thumbs down button component\n@Component({\n  standalone: true,\n  selector: \"copilot-chat-assistant-message-thumbs-down-button\",\n  imports: [\n    CommonModule,\n    LucideAngularModule,\n    CopilotChatAssistantMessageToolbarButton,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  template: `\n    <button\n      copilotChatAssistantMessageToolbarButton\n      [title]=\"title() || labels.assistantMessageToolbarThumbsDownLabel\"\n      [disabled]=\"disabled()\"\n      [inputClass]=\"inputClass()\"\n      (click)=\"handleClick($event)\"\n    >\n      <lucide-angular [img]=\"ThumbsDownIcon\" [size]=\"18\"></lucide-angular>\n    </button>\n  `,\n})\nexport class CopilotChatAssistantMessageThumbsDownButton {\n  readonly title = input<string | undefined>();\n  readonly disabled = input<boolean>(false);\n  readonly inputClass = input<string | undefined>();\n  readonly clicked = output<void>();\n  readonly ThumbsDownIcon = ThumbsDown;\n  readonly labels = injectChatLabels();\n\n  handleClick(event?: Event): void {\n    event?.stopPropagation();\n    if (!this.disabled()) {\n      this.clicked.emit();\n    }\n  }\n}\n\n// Read aloud button component\n@Component({\n  standalone: true,\n  selector: \"copilot-chat-assistant-message-read-aloud-button\",\n  imports: [\n    CommonModule,\n    LucideAngularModule,\n    CopilotChatAssistantMessageToolbarButton,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  template: `\n    <button\n      copilotChatAssistantMessageToolbarButton\n      [title]=\"title() || labels.assistantMessageToolbarReadAloudLabel\"\n      [disabled]=\"disabled()\"\n      [inputClass]=\"inputClass()\"\n      (click)=\"handleClick($event)\"\n    >\n      <lucide-angular [img]=\"Volume2Icon\" [size]=\"20\"></lucide-angular>\n    </button>\n  `,\n})\nexport class CopilotChatAssistantMessageReadAloudButton {\n  readonly title = input<string | undefined>();\n  readonly disabled = input<boolean>(false);\n  readonly inputClass = input<string | undefined>();\n  readonly clicked = output<void>();\n  readonly Volume2Icon = Volume2;\n  readonly labels = injectChatLabels();\n\n  handleClick(event?: Event): void {\n    event?.stopPropagation();\n    if (!this.disabled()) {\n      this.clicked.emit();\n    }\n  }\n}\n\n// Regenerate button component\n@Component({\n  standalone: true,\n  selector: \"copilot-chat-assistant-message-regenerate-button\",\n  imports: [\n    CommonModule,\n    LucideAngularModule,\n    CopilotChatAssistantMessageToolbarButton,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  template: `\n    <button\n      copilotChatAssistantMessageToolbarButton\n      [title]=\"title() || labels.assistantMessageToolbarRegenerateLabel\"\n      [disabled]=\"disabled()\"\n      [inputClass]=\"inputClass()\"\n      (click)=\"handleClick($event)\"\n    >\n      <lucide-angular [img]=\"RefreshCwIcon\" [size]=\"18\"></lucide-angular>\n    </button>\n  `,\n})\nexport class CopilotChatAssistantMessageRegenerateButton {\n  readonly title = input<string | undefined>();\n  readonly disabled = input<boolean>(false);\n  readonly inputClass = input<string | undefined>();\n  readonly clicked = output<void>();\n  readonly RefreshCwIcon = RefreshCw;\n  readonly labels = injectChatLabels();\n\n  handleClick(event?: Event): void {\n    event?.stopPropagation();\n    if (!this.disabled()) {\n      this.clicked.emit();\n    }\n  }\n}\n"]}