@copilotkitnext/angular 1.51.4-next.7 → 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.
- package/README.md +43 -39
- package/dist/README.md +43 -39
- package/dist/esm2022/lib/agent-context.mjs +2 -2
- package/dist/esm2022/lib/agent.mjs +1 -1
- package/dist/esm2022/lib/chat-config.mjs +1 -1
- package/dist/esm2022/lib/chat-state.mjs +1 -1
- package/dist/esm2022/lib/components/chat/copilot-chat-assistant-message-buttons.mjs +1 -1
- package/dist/esm2022/lib/components/chat/copilot-chat-assistant-message-renderer.mjs +1 -1
- package/dist/esm2022/lib/components/chat/copilot-chat-assistant-message-toolbar.mjs +1 -1
- package/dist/esm2022/lib/components/chat/copilot-chat-assistant-message.mjs +1 -1
- package/dist/esm2022/lib/components/chat/copilot-chat-audio-recorder.mjs +1 -1
- package/dist/esm2022/lib/components/chat/copilot-chat-buttons.mjs +1 -1
- package/dist/esm2022/lib/components/chat/copilot-chat-input.mjs +1 -1
- package/dist/esm2022/lib/components/chat/copilot-chat-message-view-cursor.mjs +1 -1
- package/dist/esm2022/lib/components/chat/copilot-chat-message-view.mjs +1 -1
- package/dist/esm2022/lib/components/chat/copilot-chat-textarea.mjs +1 -1
- package/dist/esm2022/lib/components/chat/copilot-chat-tools-menu.mjs +1 -1
- package/dist/esm2022/lib/components/chat/copilot-chat-user-message-branch-navigation.mjs +26 -6
- package/dist/esm2022/lib/components/chat/copilot-chat-user-message-buttons.mjs +1 -1
- package/dist/esm2022/lib/components/chat/copilot-chat-user-message-renderer.mjs +1 -1
- package/dist/esm2022/lib/components/chat/copilot-chat-user-message-toolbar.mjs +1 -1
- package/dist/esm2022/lib/components/chat/copilot-chat-user-message.mjs +29 -9
- package/dist/esm2022/lib/components/chat/copilot-chat-user-message.types.mjs +1 -1
- package/dist/esm2022/lib/components/chat/copilot-chat-view-disclaimer.mjs +1 -1
- package/dist/esm2022/lib/components/chat/copilot-chat-view-feather.mjs +1 -1
- package/dist/esm2022/lib/components/chat/copilot-chat-view-input-container.mjs +1 -1
- package/dist/esm2022/lib/components/chat/copilot-chat-view-scroll-to-bottom-button.mjs +1 -1
- package/dist/esm2022/lib/components/chat/copilot-chat-view-scroll-view.mjs +1 -1
- package/dist/esm2022/lib/components/chat/copilot-chat-view.mjs +1 -1
- package/dist/esm2022/lib/components/chat/copilot-chat.mjs +20 -23
- package/dist/esm2022/lib/config.mjs +1 -1
- package/dist/esm2022/lib/copilotkit.mjs +18 -8
- package/dist/esm2022/lib/directives/stick-to-bottom.mjs +1 -1
- package/dist/esm2022/lib/human-in-the-loop.mjs +1 -1
- package/dist/esm2022/lib/render-tool-calls.mjs +40 -11
- package/dist/esm2022/lib/resize-observer.mjs +1 -1
- package/dist/esm2022/lib/scroll-position.mjs +2 -3
- package/dist/esm2022/lib/slots/copilot-slot.mjs +1 -1
- package/dist/esm2022/lib/slots/slot.utils.mjs +1 -1
- package/dist/esm2022/lib/tools.mjs +3 -3
- package/dist/fesm2022/copilotkitnext-angular.mjs +128 -54
- package/dist/fesm2022/copilotkitnext-angular.mjs.map +1 -1
- package/dist/lib/components/chat/copilot-chat.d.ts +1 -0
- 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
|
|
135
|
-
import { FormsModule } from
|
|
136
|
-
import { CopilotChatConfigurationService } from
|
|
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:
|
|
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
|
|
173
|
-
import { CopilotChatViewComponent } from
|
|
174
|
-
import { MyCustomInputComponent } from
|
|
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:
|
|
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
|
|
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(
|
|
219
|
+
console.log("Message submitted:", value);
|
|
217
220
|
};
|
|
218
|
-
|
|
221
|
+
|
|
219
222
|
handleChange = (value: string) => {
|
|
220
|
-
console.log(
|
|
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 ||
|
|
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
|
|
412
|
+
1. Register tool renderers (e.g., a wildcard that renders any tool):
|
|
413
413
|
|
|
414
414
|
```ts
|
|
415
|
-
import { ApplicationConfig, importProvidersFrom } from
|
|
416
|
-
import { BrowserModule } from
|
|
417
|
-
import { provideCopilotKit } from
|
|
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
|
|
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
|
|
449
|
+
2. Render tool calls under assistant messages using the headless view component:
|
|
450
450
|
|
|
451
451
|
```ts
|
|
452
|
-
import { Component } from
|
|
453
|
-
import {
|
|
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
|
|
135
|
-
import { FormsModule } from
|
|
136
|
-
import { CopilotChatConfigurationService } from
|
|
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:
|
|
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
|
|
173
|
-
import { CopilotChatViewComponent } from
|
|
174
|
-
import { MyCustomInputComponent } from
|
|
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:
|
|
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
|
|
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(
|
|
219
|
+
console.log("Message submitted:", value);
|
|
217
220
|
};
|
|
218
|
-
|
|
221
|
+
|
|
219
222
|
handleChange = (value: string) => {
|
|
220
|
-
console.log(
|
|
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 ||
|
|
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
|
|
412
|
+
1. Register tool renderers (e.g., a wildcard that renders any tool):
|
|
413
413
|
|
|
414
414
|
```ts
|
|
415
|
-
import { ApplicationConfig, importProvidersFrom } from
|
|
416
|
-
import { BrowserModule } from
|
|
417
|
-
import { provideCopilotKit } from
|
|
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
|
|
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
|
|
449
|
+
2. Render tool calls under assistant messages using the headless view component:
|
|
450
450
|
|
|
451
451
|
```ts
|
|
452
|
-
import { Component } from
|
|
453
|
-
import {
|
|
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,
|
|
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+
|
|
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,
|
|
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,
|
|
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"]}
|