@copilotkitnext/angular 0.0.4 → 0.0.6
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/dist/components/chat/copilot-chat-assistant-message.component.d.ts +1 -0
- package/dist/core/copilotkit.providers.d.ts +1 -1
- package/dist/core/copilotkit.service.d.ts +5 -5
- package/dist/core/copilotkit.types.d.ts +8 -10
- package/dist/directives/copilotkit-frontend-tool.directive.d.ts +1 -1
- package/dist/esm2022/components/chat/copilot-chat-assistant-message.component.mjs +11 -5
- package/dist/esm2022/components/chat/copilot-chat-input.component.mjs +2 -2
- package/dist/esm2022/components/chat/copilot-chat-textarea.component.mjs +2 -2
- package/dist/esm2022/components/chat/copilot-chat-tool-calls-view.component.mjs +14 -8
- package/dist/esm2022/components/chat/copilot-chat.component.mjs +10 -3
- package/dist/esm2022/components/copilotkit-tool-render.component.mjs +7 -10
- package/dist/esm2022/core/copilotkit.providers.mjs +1 -1
- package/dist/esm2022/core/copilotkit.service.mjs +6 -22
- package/dist/esm2022/core/copilotkit.types.mjs +2 -1
- package/dist/esm2022/directives/copilotkit-frontend-tool.directive.mjs +1 -3
- package/dist/esm2022/directives/copilotkit-human-in-the-loop.directive.mjs +1 -2
- package/dist/esm2022/lib/slots/copilot-slot.component.mjs +15 -5
- package/dist/esm2022/lib/slots/slot.utils.mjs +14 -5
- package/dist/esm2022/utils/frontend-tool.utils.mjs +1 -5
- package/dist/esm2022/utils/human-in-the-loop.utils.mjs +4 -7
- package/dist/fesm2022/copilotkitnext-angular.mjs +76 -65
- package/dist/fesm2022/copilotkitnext-angular.mjs.map +1 -1
- package/dist/utils/frontend-tool.utils.d.ts +1 -1
- package/package.json +3 -3
|
@@ -69,6 +69,7 @@ export declare class CopilotChatAssistantMessageComponent {
|
|
|
69
69
|
clicked: () => void;
|
|
70
70
|
};
|
|
71
71
|
toolbarContext: import("@angular/core").Signal<AssistantMessageToolbarContext>;
|
|
72
|
+
hasMessageContent(): boolean;
|
|
72
73
|
toolCallsViewContext: import("@angular/core").Signal<{
|
|
73
74
|
message: {
|
|
74
75
|
id: string;
|
|
@@ -6,7 +6,7 @@ export interface ProvideCopilotKitOptions {
|
|
|
6
6
|
headers?: Record<string, string>;
|
|
7
7
|
properties?: Record<string, unknown>;
|
|
8
8
|
agents?: Record<string, AbstractAgent>;
|
|
9
|
-
renderToolCalls?: ToolCallRender
|
|
9
|
+
renderToolCalls?: ToolCallRender[];
|
|
10
10
|
frontendTools?: AngularFrontendTool<any>[];
|
|
11
11
|
humanInTheLoop?: AngularHumanInTheLoop<any>[];
|
|
12
12
|
}
|
|
@@ -41,7 +41,7 @@ export declare class CopilotKitService {
|
|
|
41
41
|
readonly humanInTheLoop$: any;
|
|
42
42
|
readonly context: any;
|
|
43
43
|
readonly context$: any;
|
|
44
|
-
constructor(runtimeUrl: string | undefined, headers: Record<string, string>, properties: Record<string, unknown>, agents: Record<string, AbstractAgent>, renderToolCalls: ToolCallRender
|
|
44
|
+
constructor(runtimeUrl: string | undefined, headers: Record<string, string>, properties: Record<string, unknown>, agents: Record<string, AbstractAgent>, renderToolCalls: ToolCallRender[], frontendTools: AngularFrontendTool<any>[], humanInTheLoop: AngularHumanInTheLoop<any>[]);
|
|
45
45
|
/**
|
|
46
46
|
* Process frontend tools and human-in-the-loop tools
|
|
47
47
|
*/
|
|
@@ -89,7 +89,7 @@ export declare class CopilotKitService {
|
|
|
89
89
|
/**
|
|
90
90
|
* Update render tool calls (warns if object reference changes)
|
|
91
91
|
*/
|
|
92
|
-
setRenderToolCalls(renderToolCalls: ToolCallRender
|
|
92
|
+
setRenderToolCalls(renderToolCalls: ToolCallRender[]): void;
|
|
93
93
|
/**
|
|
94
94
|
* Update frontend tools array
|
|
95
95
|
*/
|
|
@@ -101,11 +101,11 @@ export declare class CopilotKitService {
|
|
|
101
101
|
/**
|
|
102
102
|
* Update current render tool calls
|
|
103
103
|
*/
|
|
104
|
-
setCurrentRenderToolCalls(renderToolCalls: ToolCallRender
|
|
104
|
+
setCurrentRenderToolCalls(renderToolCalls: ToolCallRender[]): void;
|
|
105
105
|
/**
|
|
106
106
|
* Register a tool render
|
|
107
107
|
*/
|
|
108
|
-
registerToolRender(name: string, render: ToolCallRender
|
|
108
|
+
registerToolRender(name: string, render: ToolCallRender): void;
|
|
109
109
|
/**
|
|
110
110
|
* Unregister a tool render
|
|
111
111
|
*/
|
|
@@ -113,7 +113,7 @@ export declare class CopilotKitService {
|
|
|
113
113
|
/**
|
|
114
114
|
* Get a specific tool render
|
|
115
115
|
*/
|
|
116
|
-
getToolRender(name: string): ToolCallRender
|
|
116
|
+
getToolRender(name: string): ToolCallRender | undefined;
|
|
117
117
|
static ɵfac: i0.ɵɵFactoryDeclaration<CopilotKitService, never>;
|
|
118
118
|
static ɵprov: i0.ɵɵInjectableDeclaration<CopilotKitService>;
|
|
119
119
|
}
|
|
@@ -2,7 +2,6 @@ import { InjectionToken, TemplateRef, Type, Signal } from "@angular/core";
|
|
|
2
2
|
import { Observable } from "rxjs";
|
|
3
3
|
import { CopilotKitCore, ToolCallStatus } from "@copilotkitnext/core";
|
|
4
4
|
import { AbstractAgent } from "@ag-ui/client";
|
|
5
|
-
import type { z } from "zod";
|
|
6
5
|
import type { AngularFrontendTool } from "../types/frontend-tool";
|
|
7
6
|
import type { AngularHumanInTheLoop } from "../types/human-in-the-loop";
|
|
8
7
|
export type { Context } from "@ag-ui/client";
|
|
@@ -28,35 +27,34 @@ export type ToolCallProps<T = unknown> = {
|
|
|
28
27
|
status: ToolCallStatus.Complete;
|
|
29
28
|
result: string;
|
|
30
29
|
};
|
|
31
|
-
export interface AngularToolCallRender
|
|
30
|
+
export interface AngularToolCallRender {
|
|
32
31
|
name: string;
|
|
33
|
-
args: z.ZodSchema<T>;
|
|
34
32
|
/**
|
|
35
33
|
* Optional agent ID to constrain this tool render to a specific agent.
|
|
36
34
|
* If specified, this render will only be used for the specified agent.
|
|
37
35
|
*/
|
|
38
36
|
agentId?: string;
|
|
39
|
-
render: Type<any> | TemplateRef<ToolCallProps<
|
|
37
|
+
render: Type<any> | TemplateRef<ToolCallProps<any>>;
|
|
40
38
|
}
|
|
41
|
-
export type ToolCallRender
|
|
39
|
+
export type ToolCallRender = AngularToolCallRender;
|
|
42
40
|
export interface CopilotKitContextValue {
|
|
43
41
|
copilotkit: CopilotKitCore;
|
|
44
|
-
renderToolCalls: ToolCallRender
|
|
45
|
-
currentRenderToolCalls: ToolCallRender
|
|
46
|
-
setCurrentRenderToolCalls: (v: ToolCallRender
|
|
42
|
+
renderToolCalls: ToolCallRender[];
|
|
43
|
+
currentRenderToolCalls: ToolCallRender[];
|
|
44
|
+
setCurrentRenderToolCalls: (v: ToolCallRender[]) => void;
|
|
47
45
|
}
|
|
48
46
|
export interface CopilotKitRuntimeInputs {
|
|
49
47
|
runtimeUrl?: string;
|
|
50
48
|
headers?: Record<string, string>;
|
|
51
49
|
properties?: Record<string, unknown>;
|
|
52
50
|
agents?: Record<string, AbstractAgent>;
|
|
53
|
-
renderToolCalls?: ToolCallRender
|
|
51
|
+
renderToolCalls?: ToolCallRender[];
|
|
54
52
|
}
|
|
55
53
|
export declare const COPILOTKIT_RUNTIME_URL: InjectionToken<string>;
|
|
56
54
|
export declare const COPILOTKIT_HEADERS: InjectionToken<Record<string, string>>;
|
|
57
55
|
export declare const COPILOTKIT_PROPERTIES: InjectionToken<Record<string, unknown>>;
|
|
58
56
|
export declare const COPILOTKIT_AGENTS: InjectionToken<Record<string, AbstractAgent>>;
|
|
59
|
-
export declare const COPILOTKIT_RENDER_TOOL_CALLS: InjectionToken<
|
|
57
|
+
export declare const COPILOTKIT_RENDER_TOOL_CALLS: InjectionToken<AngularToolCallRender[]>;
|
|
60
58
|
export declare const COPILOTKIT_FRONTEND_TOOLS: InjectionToken<AngularFrontendTool<any>[]>;
|
|
61
59
|
export declare const COPILOTKIT_HUMAN_IN_THE_LOOP: InjectionToken<AngularHumanInTheLoop<any>[]>;
|
|
62
60
|
import type { Message } from "@ag-ui/client";
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { OnInit, OnChanges, OnDestroy, SimpleChanges, TemplateRef, Type } from "@angular/core";
|
|
2
2
|
import { CopilotKitService } from "../core/copilotkit.service";
|
|
3
3
|
import type { AngularFrontendTool } from "../core/copilotkit.types";
|
|
4
|
-
import { z } from "zod";
|
|
4
|
+
import type { z } from "zod";
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
export declare class CopilotKitFrontendToolDirective<T extends Record<string, any> = Record<string, any>> implements OnInit, OnChanges, OnDestroy {
|
|
7
7
|
private readonly copilotkit;
|
|
@@ -84,6 +84,12 @@ export class CopilotChatAssistantMessageComponent {
|
|
|
84
84
|
toolbarContext = computed(() => ({
|
|
85
85
|
children: null // Will be populated by the toolbar content
|
|
86
86
|
}));
|
|
87
|
+
// Return true if assistant message has non-empty text content
|
|
88
|
+
hasMessageContent() {
|
|
89
|
+
const raw = (this.message?.content ?? '');
|
|
90
|
+
const content = typeof raw === 'string' ? raw : String(raw ?? '');
|
|
91
|
+
return content.trim().length > 0;
|
|
92
|
+
}
|
|
87
93
|
toolCallsViewContext = computed(() => ({
|
|
88
94
|
message: this.message,
|
|
89
95
|
messages: this.messages,
|
|
@@ -141,8 +147,8 @@ export class CopilotChatAssistantMessageComponent {
|
|
|
141
147
|
</copilot-chat-tool-calls-view>
|
|
142
148
|
}
|
|
143
149
|
|
|
144
|
-
<!-- Toolbar -->
|
|
145
|
-
<ng-container *ngIf="toolbarVisible">
|
|
150
|
+
<!-- Toolbar: show only when there is assistant text content -->
|
|
151
|
+
<ng-container *ngIf="toolbarVisible && hasMessageContent()">
|
|
146
152
|
@if (toolbarTemplate || toolbarComponent) {
|
|
147
153
|
<copilot-slot
|
|
148
154
|
[slot]="toolbarTemplate || toolbarComponent"
|
|
@@ -269,8 +275,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
269
275
|
</copilot-chat-tool-calls-view>
|
|
270
276
|
}
|
|
271
277
|
|
|
272
|
-
<!-- Toolbar -->
|
|
273
|
-
<ng-container *ngIf="toolbarVisible">
|
|
278
|
+
<!-- Toolbar: show only when there is assistant text content -->
|
|
279
|
+
<ng-container *ngIf="toolbarVisible && hasMessageContent()">
|
|
274
280
|
@if (toolbarTemplate || toolbarComponent) {
|
|
275
281
|
<copilot-slot
|
|
276
282
|
[slot]="toolbarTemplate || toolbarComponent"
|
|
@@ -430,4 +436,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
430
436
|
}], regenerate: [{
|
|
431
437
|
type: Output
|
|
432
438
|
}] } });
|
|
433
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"copilot-chat-assistant-message.component.js","sourceRoot":"","sources":["../../../../src/components/chat/copilot-chat-assistant-message.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  TemplateRef,\n  ContentChild,\n  signal,\n  computed,\n  Type,\n  ChangeDetectionStrategy,\n  ViewEncapsulation,\n  Optional,\n  Inject\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { CopilotSlotComponent } from '../../lib/slots/copilot-slot.component';\nimport { CopilotChatToolCallsViewComponent } from './copilot-chat-tool-calls-view.component';\nimport type { Message } from '@ag-ui/core';\nimport {\n  type AssistantMessage,\n  type CopilotChatAssistantMessageOnThumbsUpProps,\n  type CopilotChatAssistantMessageOnThumbsDownProps,\n  type CopilotChatAssistantMessageOnReadAloudProps,\n  type CopilotChatAssistantMessageOnRegenerateProps,\n  type AssistantMessageMarkdownRendererContext,\n  type AssistantMessageCopyButtonContext,\n  type ThumbsUpButtonContext,\n  type ThumbsDownButtonContext,\n  type ReadAloudButtonContext,\n  type RegenerateButtonContext,\n  type AssistantMessageToolbarContext\n} from './copilot-chat-assistant-message.types';\nimport { CopilotChatAssistantMessageRendererComponent } from './copilot-chat-assistant-message-renderer.component';\nimport {\n  CopilotChatAssistantMessageCopyButtonComponent,\n  CopilotChatAssistantMessageThumbsUpButtonComponent,\n  CopilotChatAssistantMessageThumbsDownButtonComponent,\n  CopilotChatAssistantMessageReadAloudButtonComponent,\n  CopilotChatAssistantMessageRegenerateButtonComponent\n} from './copilot-chat-assistant-message-buttons.component';\nimport { CopilotChatAssistantMessageToolbarComponent } from './copilot-chat-assistant-message-toolbar.component';\nimport { cn } from '../../lib/utils';\nimport { CopilotChatViewHandlersService } from './copilot-chat-view-handlers.service';\n\n@Component({\n  selector: 'copilot-chat-assistant-message',\n  standalone: true,\n  imports: [\n    CommonModule,\n    CopilotSlotComponent,\n    CopilotChatAssistantMessageRendererComponent,\n    CopilotChatAssistantMessageCopyButtonComponent,\n    CopilotChatAssistantMessageThumbsUpButtonComponent,\n    CopilotChatAssistantMessageThumbsDownButtonComponent,\n    CopilotChatAssistantMessageReadAloudButtonComponent,\n    CopilotChatAssistantMessageRegenerateButtonComponent,\n    CopilotChatAssistantMessageToolbarComponent,\n    CopilotChatToolCallsViewComponent\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  template: `\n    <div \n      [class]=\"computedClass()\"\n      [attr.data-message-id]=\"message?.id\">\n      \n      <!-- Markdown Renderer -->\n      @if (markdownRendererTemplate || markdownRendererComponent) {\n        <copilot-slot\n          [slot]=\"markdownRendererTemplate || markdownRendererComponent\"\n          [context]=\"markdownRendererContext()\"\n          [defaultComponent]=\"CopilotChatAssistantMessageRendererComponent\"\n          >\n        </copilot-slot>\n      } @else {\n        <copilot-chat-assistant-message-renderer\n          [content]=\"message?.content || ''\"\n          [inputClass]=\"markdownRendererClass\">\n        </copilot-chat-assistant-message-renderer>\n      }\n      \n      <!-- Tool Calls View -->\n      @if (toolCallsViewTemplate || toolCallsViewComponent) {\n        <copilot-slot\n          [slot]=\"toolCallsViewTemplate || toolCallsViewComponent\"\n          [context]=\"toolCallsViewContext()\"\n          [defaultComponent]=\"CopilotChatToolCallsViewComponent\">\n        </copilot-slot>\n      } @else if (message?.toolCalls && message.toolCalls.length > 0) {\n        <copilot-chat-tool-calls-view\n          [message]=\"message\"\n          [messages]=\"messages\"\n          [isLoading]=\"isLoading\">\n        </copilot-chat-tool-calls-view>\n      }\n      \n      <!-- Toolbar -->\n      <ng-container *ngIf=\"toolbarVisible\">\n        @if (toolbarTemplate || toolbarComponent) {\n          <copilot-slot\n            [slot]=\"toolbarTemplate || toolbarComponent\"\n            [context]=\"toolbarContext()\"\n            [defaultComponent]=\"CopilotChatAssistantMessageToolbarComponent\"\n            >\n          </copilot-slot>\n        } @else {\n          <div copilotChatAssistantMessageToolbar [inputClass]=\"toolbarClass\">\n            <div class=\"flex items-center gap-1\">\n              <!-- Copy button -->\n              @if (copyButtonTemplate || copyButtonComponent) {\n                <copilot-slot\n                  [slot]=\"copyButtonTemplate || copyButtonComponent\"\n                  [context]=\"{ content: message?.content || '' }\"\n                  [defaultComponent]=\"CopilotChatAssistantMessageCopyButtonComponent\"\n                  [outputs]=\"copyButtonOutputs\"\n                  >\n                </copilot-slot>\n              } @else {\n                <copilot-chat-assistant-message-copy-button\n                  [content]=\"message?.content\"\n                  [inputClass]=\"copyButtonClass\"\n                  (clicked)=\"handleCopy()\">\n                </copilot-chat-assistant-message-copy-button>\n              }\n              \n              <!-- Thumbs up button - show if custom slot provided OR if handler available at top level -->\n              @if (thumbsUpButtonComponent || thumbsUpButtonTemplate || handlers.hasAssistantThumbsUpHandler()) {\n                <copilot-slot\n                  [slot]=\"thumbsUpButtonTemplate || thumbsUpButtonComponent\"\n                  [context]=\"{}\"\n                  [defaultComponent]=\"defaultThumbsUpButtonComponent\"\n                  [outputs]=\"thumbsUpButtonOutputs\">\n                </copilot-slot>\n              }\n              \n              <!-- Thumbs down button - show if custom slot provided OR if handler available at top level -->\n              @if (thumbsDownButtonComponent || thumbsDownButtonTemplate || handlers.hasAssistantThumbsDownHandler()) {\n                <copilot-slot\n                  [slot]=\"thumbsDownButtonTemplate || thumbsDownButtonComponent\"\n                  [context]=\"{}\"\n                  [defaultComponent]=\"defaultThumbsDownButtonComponent\"\n                  [outputs]=\"thumbsDownButtonOutputs\">\n                </copilot-slot>\n              }\n              \n              <!-- Read aloud button - only show if custom slot provided -->\n              @if (readAloudButtonComponent || readAloudButtonTemplate) {\n                <copilot-slot\n                  [slot]=\"readAloudButtonTemplate || readAloudButtonComponent\"\n                  [context]=\"{}\"\n                  [outputs]=\"readAloudButtonOutputs\"\n                  >\n                </copilot-slot>\n              }\n              \n              <!-- Regenerate button - only show if custom slot provided -->\n              @if (regenerateButtonComponent || regenerateButtonTemplate) {\n                <copilot-slot\n                  [slot]=\"regenerateButtonTemplate || regenerateButtonComponent\"\n                  [context]=\"{}\"\n                  [outputs]=\"regenerateButtonOutputs\"\n                  >\n                </copilot-slot>\n              }\n              \n              <!-- Additional toolbar items -->\n              @if (additionalToolbarItems) {\n                <ng-container *ngTemplateOutlet=\"additionalToolbarItems\"></ng-container>\n              }\n            </div>\n          </div>\n        }\n      </ng-container>\n    </div>\n  `,\n  styles: [`\n    /* Import KaTeX styles */\n    @import 'katex/dist/katex.min.css';\n\n    :host {\n      display: block;\n      width: 100%;\n    }\n\n    /* Atom One Light theme for highlight.js */\n    .hljs {\n      color: rgb(56, 58, 66);\n      background: transparent;\n    }\n\n    .hljs-comment,\n    .hljs-quote {\n      color: #a0a1a7;\n      font-style: italic;\n    }\n\n    .hljs-doctag,\n    .hljs-formula,\n    .hljs-keyword {\n      color: #a626a4;\n    }\n\n    .hljs-deletion,\n    .hljs-name,\n    .hljs-section,\n    .hljs-selector-tag,\n    .hljs-subst {\n      color: #e45649;\n    }\n\n    .hljs-literal {\n      color: #0184bb;\n    }\n\n    .hljs-addition,\n    .hljs-attribute,\n    .hljs-meta .hljs-string,\n    .hljs-regexp,\n    .hljs-string {\n      color: #50a14f;\n    }\n\n    .hljs-attr,\n    .hljs-number,\n    .hljs-selector-attr,\n    .hljs-selector-class,\n    .hljs-selector-pseudo,\n    .hljs-template-variable,\n    .hljs-type,\n    .hljs-variable {\n      color: #986801;\n    }\n\n    .hljs-params {\n      color: rgb(56, 58, 66);\n    }\n\n    .hljs-bullet,\n    .hljs-link,\n    .hljs-meta,\n    .hljs-selector-id,\n    .hljs-symbol,\n    .hljs-title {\n      color: #4078f2;\n    }\n\n    .hljs-built_in,\n    .hljs-class .hljs-title,\n    .hljs-title.class_ {\n      color: #c18401;\n    }\n\n    .hljs-emphasis {\n      font-style: italic;\n    }\n\n    .hljs-strong {\n      font-weight: 700;\n    }\n\n    .hljs-link {\n      text-decoration: underline;\n    }\n\n    /* Atom One Dark theme for highlight.js */\n    .dark .hljs {\n      color: #abb2bf;\n      background: transparent;\n    }\n\n    .dark .hljs-comment,\n    .dark .hljs-quote {\n      color: #5c6370;\n      font-style: italic;\n    }\n\n    .dark .hljs-doctag,\n    .dark .hljs-formula,\n    .dark .hljs-keyword {\n      color: #c678dd;\n    }\n\n    .dark .hljs-deletion,\n    .dark .hljs-name,\n    .dark .hljs-section,\n    .dark .hljs-selector-tag,\n    .dark .hljs-subst {\n      color: #e06c75;\n    }\n\n    .dark .hljs-literal {\n      color: #56b6c2;\n    }\n\n    .dark .hljs-addition,\n    .dark .hljs-attribute,\n    .dark .hljs-meta .hljs-string,\n    .dark .hljs-regexp,\n    .dark .hljs-string {\n      color: #98c379;\n    }\n\n    .dark .hljs-attr,\n    .dark .hljs-number,\n    .dark .hljs-selector-attr,\n    .dark .hljs-selector-class,\n    .dark .hljs-selector-pseudo,\n    .dark .hljs-template-variable,\n    .dark .hljs-type,\n    .dark .hljs-variable {\n      color: #d19a66;\n    }\n\n    .dark .hljs-bullet,\n    .dark .hljs-link,\n    .dark .hljs-meta,\n    .dark .hljs-selector-id,\n    .dark .hljs-symbol,\n    .dark .hljs-title {\n      color: #61aeee;\n    }\n\n    .dark .hljs-built_in,\n    .dark .hljs-class .hljs-title,\n    .dark .hljs-title.class_ {\n      color: #e6c07b;\n    }\n\n    .dark .hljs-params {\n      color: #abb2bf; /* same as regular text */\n    }\n\n    .dark .hljs-emphasis {\n      font-style: italic;\n    }\n\n    .dark .hljs-strong {\n      font-weight: 700;\n    }\n\n    .dark .hljs-link {\n      text-decoration: underline;\n    }\n  `]\n})\nexport class CopilotChatAssistantMessageComponent {\n  // Capture templates from content projection\n  @ContentChild('markdownRenderer', { read: TemplateRef }) markdownRendererTemplate?: TemplateRef<AssistantMessageMarkdownRendererContext>;\n  @ContentChild('toolbar', { read: TemplateRef }) toolbarTemplate?: TemplateRef<AssistantMessageToolbarContext>;\n  @ContentChild('copyButton', { read: TemplateRef }) copyButtonTemplate?: TemplateRef<AssistantMessageCopyButtonContext>;\n  @ContentChild('thumbsUpButton', { read: TemplateRef }) thumbsUpButtonTemplate?: TemplateRef<ThumbsUpButtonContext>;\n  @ContentChild('thumbsDownButton', { read: TemplateRef }) thumbsDownButtonTemplate?: TemplateRef<ThumbsDownButtonContext>;\n  @ContentChild('readAloudButton', { read: TemplateRef }) readAloudButtonTemplate?: TemplateRef<ReadAloudButtonContext>;\n  @ContentChild('regenerateButton', { read: TemplateRef }) regenerateButtonTemplate?: TemplateRef<RegenerateButtonContext>;\n  @ContentChild('toolCallsView', { read: TemplateRef }) toolCallsViewTemplate?: TemplateRef<any>;\n  \n  // Class inputs for styling default components\n  @Input() markdownRendererClass?: string;\n  @Input() toolbarClass?: string;\n  @Input() copyButtonClass?: string;\n  @Input() thumbsUpButtonClass?: string;\n  @Input() thumbsDownButtonClass?: string;\n  @Input() readAloudButtonClass?: string;\n  @Input() regenerateButtonClass?: string;\n  @Input() toolCallsViewClass?: string;\n  \n  // Component inputs for overrides\n  @Input() markdownRendererComponent?: Type<any>;\n  @Input() toolbarComponent?: Type<any>;\n  @Input() copyButtonComponent?: Type<any>;\n  @Input() thumbsUpButtonComponent?: Type<any>;\n  @Input() thumbsDownButtonComponent?: Type<any>;\n  @Input() readAloudButtonComponent?: Type<any>;\n  @Input() regenerateButtonComponent?: Type<any>;\n  @Input() toolCallsViewComponent?: Type<any>;\n  \n  // Regular inputs\n  @Input() message!: AssistantMessage;\n  @Input() messages: Message[] = [];\n  @Input() isLoading = false;\n  @Input() additionalToolbarItems?: TemplateRef<any>;\n  @Input() toolbarVisible = true;\n  @Input() set inputClass(val: string | undefined) {\n    this.customClass.set(val);\n  }\n  \n  // DI service exposes handler availability scoped to CopilotChatView\n  // Make it optional with a default fallback for testing\n  handlers: CopilotChatViewHandlersService;\n  \n  constructor(@Optional() @Inject(CopilotChatViewHandlersService) handlers?: CopilotChatViewHandlersService | null) {\n    this.handlers = handlers || new CopilotChatViewHandlersService();\n  }\n  \n  // Output events\n  @Output() thumbsUp = new EventEmitter<CopilotChatAssistantMessageOnThumbsUpProps>();\n  @Output() thumbsDown = new EventEmitter<CopilotChatAssistantMessageOnThumbsDownProps>();\n  @Output() readAloud = new EventEmitter<CopilotChatAssistantMessageOnReadAloudProps>();\n  @Output() regenerate = new EventEmitter<CopilotChatAssistantMessageOnRegenerateProps>();\n  \n  // Signals\n  customClass = signal<string | undefined>(undefined);\n  \n  // Computed values\n  computedClass = computed(() => {\n    return cn(\n      \"prose max-w-full break-words dark:prose-invert\",\n      this.customClass()\n    );\n  });\n  \n  // Default components\n  protected readonly defaultThumbsUpButtonComponent = CopilotChatAssistantMessageThumbsUpButtonComponent;\n  protected readonly defaultThumbsDownButtonComponent = CopilotChatAssistantMessageThumbsDownButtonComponent;\n  protected readonly CopilotChatAssistantMessageRendererComponent = CopilotChatAssistantMessageRendererComponent;\n  protected readonly CopilotChatAssistantMessageToolbarComponent = CopilotChatAssistantMessageToolbarComponent;\n  protected readonly CopilotChatAssistantMessageCopyButtonComponent = CopilotChatAssistantMessageCopyButtonComponent;\n  protected readonly CopilotChatToolCallsViewComponent = CopilotChatToolCallsViewComponent;\n  \n  // Context for slots (reactive via signals)\n  markdownRendererContext = computed<AssistantMessageMarkdownRendererContext>(() => ({\n    content: this.message?.content || ''\n  }));\n  \n  // Output maps for slots\n  copyButtonOutputs = { clicked: () => this.handleCopy() };\n  thumbsUpButtonOutputs = { clicked: () => this.handleThumbsUp() };\n  thumbsDownButtonOutputs = { clicked: () => this.handleThumbsDown() };\n  readAloudButtonOutputs = { clicked: () => this.handleReadAloud() };\n  regenerateButtonOutputs = { clicked: () => this.handleRegenerate() };\n  \n  toolbarContext = computed<AssistantMessageToolbarContext>(() => ({\n    children: null // Will be populated by the toolbar content\n  }));\n  \n  toolCallsViewContext = computed(() => ({\n    message: this.message,\n    messages: this.messages,\n    isLoading: this.isLoading\n  }));\n  \n  handleCopy(): void {\n    // Copy is handled by the button component itself\n    // This is just for any additional logic if needed\n  }\n  \n  handleThumbsUp(): void {\n    this.thumbsUp.emit({ message: this.message });\n  }\n  \n  handleThumbsDown(): void {\n    this.thumbsDown.emit({ message: this.message });\n  }\n  \n  handleReadAloud(): void {\n    this.readAloud.emit({ message: this.message });\n  }\n  \n  handleRegenerate(): void {\n    this.regenerate.emit({ message: this.message });\n  }\n}\n"]}
|
|
439
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"copilot-chat-assistant-message.component.js","sourceRoot":"","sources":["../../../../src/components/chat/copilot-chat-assistant-message.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  TemplateRef,\n  ContentChild,\n  signal,\n  computed,\n  Type,\n  ChangeDetectionStrategy,\n  ViewEncapsulation,\n  Optional,\n  Inject\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { CopilotSlotComponent } from '../../lib/slots/copilot-slot.component';\nimport { CopilotChatToolCallsViewComponent } from './copilot-chat-tool-calls-view.component';\nimport type { Message } from '@ag-ui/core';\nimport {\n  type AssistantMessage,\n  type CopilotChatAssistantMessageOnThumbsUpProps,\n  type CopilotChatAssistantMessageOnThumbsDownProps,\n  type CopilotChatAssistantMessageOnReadAloudProps,\n  type CopilotChatAssistantMessageOnRegenerateProps,\n  type AssistantMessageMarkdownRendererContext,\n  type AssistantMessageCopyButtonContext,\n  type ThumbsUpButtonContext,\n  type ThumbsDownButtonContext,\n  type ReadAloudButtonContext,\n  type RegenerateButtonContext,\n  type AssistantMessageToolbarContext\n} from './copilot-chat-assistant-message.types';\nimport { CopilotChatAssistantMessageRendererComponent } from './copilot-chat-assistant-message-renderer.component';\nimport {\n  CopilotChatAssistantMessageCopyButtonComponent,\n  CopilotChatAssistantMessageThumbsUpButtonComponent,\n  CopilotChatAssistantMessageThumbsDownButtonComponent,\n  CopilotChatAssistantMessageReadAloudButtonComponent,\n  CopilotChatAssistantMessageRegenerateButtonComponent\n} from './copilot-chat-assistant-message-buttons.component';\nimport { CopilotChatAssistantMessageToolbarComponent } from './copilot-chat-assistant-message-toolbar.component';\nimport { cn } from '../../lib/utils';\nimport { CopilotChatViewHandlersService } from './copilot-chat-view-handlers.service';\n\n@Component({\n  selector: 'copilot-chat-assistant-message',\n  standalone: true,\n  imports: [\n    CommonModule,\n    CopilotSlotComponent,\n    CopilotChatAssistantMessageRendererComponent,\n    CopilotChatAssistantMessageCopyButtonComponent,\n    CopilotChatAssistantMessageThumbsUpButtonComponent,\n    CopilotChatAssistantMessageThumbsDownButtonComponent,\n    CopilotChatAssistantMessageReadAloudButtonComponent,\n    CopilotChatAssistantMessageRegenerateButtonComponent,\n    CopilotChatAssistantMessageToolbarComponent,\n    CopilotChatToolCallsViewComponent\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  template: `\n    <div \n      [class]=\"computedClass()\"\n      [attr.data-message-id]=\"message?.id\">\n      \n      <!-- Markdown Renderer -->\n      @if (markdownRendererTemplate || markdownRendererComponent) {\n        <copilot-slot\n          [slot]=\"markdownRendererTemplate || markdownRendererComponent\"\n          [context]=\"markdownRendererContext()\"\n          [defaultComponent]=\"CopilotChatAssistantMessageRendererComponent\"\n          >\n        </copilot-slot>\n      } @else {\n        <copilot-chat-assistant-message-renderer\n          [content]=\"message?.content || ''\"\n          [inputClass]=\"markdownRendererClass\">\n        </copilot-chat-assistant-message-renderer>\n      }\n      \n      <!-- Tool Calls View -->\n      @if (toolCallsViewTemplate || toolCallsViewComponent) {\n        <copilot-slot\n          [slot]=\"toolCallsViewTemplate || toolCallsViewComponent\"\n          [context]=\"toolCallsViewContext()\"\n          [defaultComponent]=\"CopilotChatToolCallsViewComponent\">\n        </copilot-slot>\n      } @else if (message?.toolCalls && message.toolCalls.length > 0) {\n        <copilot-chat-tool-calls-view\n          [message]=\"message\"\n          [messages]=\"messages\"\n          [isLoading]=\"isLoading\">\n        </copilot-chat-tool-calls-view>\n      }\n      \n      <!-- Toolbar: show only when there is assistant text content -->\n      <ng-container *ngIf=\"toolbarVisible && hasMessageContent()\">\n        @if (toolbarTemplate || toolbarComponent) {\n          <copilot-slot\n            [slot]=\"toolbarTemplate || toolbarComponent\"\n            [context]=\"toolbarContext()\"\n            [defaultComponent]=\"CopilotChatAssistantMessageToolbarComponent\"\n            >\n          </copilot-slot>\n        } @else {\n          <div copilotChatAssistantMessageToolbar [inputClass]=\"toolbarClass\">\n            <div class=\"flex items-center gap-1\">\n              <!-- Copy button -->\n              @if (copyButtonTemplate || copyButtonComponent) {\n                <copilot-slot\n                  [slot]=\"copyButtonTemplate || copyButtonComponent\"\n                  [context]=\"{ content: message?.content || '' }\"\n                  [defaultComponent]=\"CopilotChatAssistantMessageCopyButtonComponent\"\n                  [outputs]=\"copyButtonOutputs\"\n                  >\n                </copilot-slot>\n              } @else {\n                <copilot-chat-assistant-message-copy-button\n                  [content]=\"message?.content\"\n                  [inputClass]=\"copyButtonClass\"\n                  (clicked)=\"handleCopy()\">\n                </copilot-chat-assistant-message-copy-button>\n              }\n              \n              <!-- Thumbs up button - show if custom slot provided OR if handler available at top level -->\n              @if (thumbsUpButtonComponent || thumbsUpButtonTemplate || handlers.hasAssistantThumbsUpHandler()) {\n                <copilot-slot\n                  [slot]=\"thumbsUpButtonTemplate || thumbsUpButtonComponent\"\n                  [context]=\"{}\"\n                  [defaultComponent]=\"defaultThumbsUpButtonComponent\"\n                  [outputs]=\"thumbsUpButtonOutputs\">\n                </copilot-slot>\n              }\n              \n              <!-- Thumbs down button - show if custom slot provided OR if handler available at top level -->\n              @if (thumbsDownButtonComponent || thumbsDownButtonTemplate || handlers.hasAssistantThumbsDownHandler()) {\n                <copilot-slot\n                  [slot]=\"thumbsDownButtonTemplate || thumbsDownButtonComponent\"\n                  [context]=\"{}\"\n                  [defaultComponent]=\"defaultThumbsDownButtonComponent\"\n                  [outputs]=\"thumbsDownButtonOutputs\">\n                </copilot-slot>\n              }\n              \n              <!-- Read aloud button - only show if custom slot provided -->\n              @if (readAloudButtonComponent || readAloudButtonTemplate) {\n                <copilot-slot\n                  [slot]=\"readAloudButtonTemplate || readAloudButtonComponent\"\n                  [context]=\"{}\"\n                  [outputs]=\"readAloudButtonOutputs\"\n                  >\n                </copilot-slot>\n              }\n              \n              <!-- Regenerate button - only show if custom slot provided -->\n              @if (regenerateButtonComponent || regenerateButtonTemplate) {\n                <copilot-slot\n                  [slot]=\"regenerateButtonTemplate || regenerateButtonComponent\"\n                  [context]=\"{}\"\n                  [outputs]=\"regenerateButtonOutputs\"\n                  >\n                </copilot-slot>\n              }\n              \n              <!-- Additional toolbar items -->\n              @if (additionalToolbarItems) {\n                <ng-container *ngTemplateOutlet=\"additionalToolbarItems\"></ng-container>\n              }\n            </div>\n          </div>\n        }\n      </ng-container>\n    </div>\n  `,\n  styles: [`\n    /* Import KaTeX styles */\n    @import 'katex/dist/katex.min.css';\n\n    :host {\n      display: block;\n      width: 100%;\n    }\n\n    /* Atom One Light theme for highlight.js */\n    .hljs {\n      color: rgb(56, 58, 66);\n      background: transparent;\n    }\n\n    .hljs-comment,\n    .hljs-quote {\n      color: #a0a1a7;\n      font-style: italic;\n    }\n\n    .hljs-doctag,\n    .hljs-formula,\n    .hljs-keyword {\n      color: #a626a4;\n    }\n\n    .hljs-deletion,\n    .hljs-name,\n    .hljs-section,\n    .hljs-selector-tag,\n    .hljs-subst {\n      color: #e45649;\n    }\n\n    .hljs-literal {\n      color: #0184bb;\n    }\n\n    .hljs-addition,\n    .hljs-attribute,\n    .hljs-meta .hljs-string,\n    .hljs-regexp,\n    .hljs-string {\n      color: #50a14f;\n    }\n\n    .hljs-attr,\n    .hljs-number,\n    .hljs-selector-attr,\n    .hljs-selector-class,\n    .hljs-selector-pseudo,\n    .hljs-template-variable,\n    .hljs-type,\n    .hljs-variable {\n      color: #986801;\n    }\n\n    .hljs-params {\n      color: rgb(56, 58, 66);\n    }\n\n    .hljs-bullet,\n    .hljs-link,\n    .hljs-meta,\n    .hljs-selector-id,\n    .hljs-symbol,\n    .hljs-title {\n      color: #4078f2;\n    }\n\n    .hljs-built_in,\n    .hljs-class .hljs-title,\n    .hljs-title.class_ {\n      color: #c18401;\n    }\n\n    .hljs-emphasis {\n      font-style: italic;\n    }\n\n    .hljs-strong {\n      font-weight: 700;\n    }\n\n    .hljs-link {\n      text-decoration: underline;\n    }\n\n    /* Atom One Dark theme for highlight.js */\n    .dark .hljs {\n      color: #abb2bf;\n      background: transparent;\n    }\n\n    .dark .hljs-comment,\n    .dark .hljs-quote {\n      color: #5c6370;\n      font-style: italic;\n    }\n\n    .dark .hljs-doctag,\n    .dark .hljs-formula,\n    .dark .hljs-keyword {\n      color: #c678dd;\n    }\n\n    .dark .hljs-deletion,\n    .dark .hljs-name,\n    .dark .hljs-section,\n    .dark .hljs-selector-tag,\n    .dark .hljs-subst {\n      color: #e06c75;\n    }\n\n    .dark .hljs-literal {\n      color: #56b6c2;\n    }\n\n    .dark .hljs-addition,\n    .dark .hljs-attribute,\n    .dark .hljs-meta .hljs-string,\n    .dark .hljs-regexp,\n    .dark .hljs-string {\n      color: #98c379;\n    }\n\n    .dark .hljs-attr,\n    .dark .hljs-number,\n    .dark .hljs-selector-attr,\n    .dark .hljs-selector-class,\n    .dark .hljs-selector-pseudo,\n    .dark .hljs-template-variable,\n    .dark .hljs-type,\n    .dark .hljs-variable {\n      color: #d19a66;\n    }\n\n    .dark .hljs-bullet,\n    .dark .hljs-link,\n    .dark .hljs-meta,\n    .dark .hljs-selector-id,\n    .dark .hljs-symbol,\n    .dark .hljs-title {\n      color: #61aeee;\n    }\n\n    .dark .hljs-built_in,\n    .dark .hljs-class .hljs-title,\n    .dark .hljs-title.class_ {\n      color: #e6c07b;\n    }\n\n    .dark .hljs-params {\n      color: #abb2bf; /* same as regular text */\n    }\n\n    .dark .hljs-emphasis {\n      font-style: italic;\n    }\n\n    .dark .hljs-strong {\n      font-weight: 700;\n    }\n\n    .dark .hljs-link {\n      text-decoration: underline;\n    }\n  `]\n})\nexport class CopilotChatAssistantMessageComponent {\n  // Capture templates from content projection\n  @ContentChild('markdownRenderer', { read: TemplateRef }) markdownRendererTemplate?: TemplateRef<AssistantMessageMarkdownRendererContext>;\n  @ContentChild('toolbar', { read: TemplateRef }) toolbarTemplate?: TemplateRef<AssistantMessageToolbarContext>;\n  @ContentChild('copyButton', { read: TemplateRef }) copyButtonTemplate?: TemplateRef<AssistantMessageCopyButtonContext>;\n  @ContentChild('thumbsUpButton', { read: TemplateRef }) thumbsUpButtonTemplate?: TemplateRef<ThumbsUpButtonContext>;\n  @ContentChild('thumbsDownButton', { read: TemplateRef }) thumbsDownButtonTemplate?: TemplateRef<ThumbsDownButtonContext>;\n  @ContentChild('readAloudButton', { read: TemplateRef }) readAloudButtonTemplate?: TemplateRef<ReadAloudButtonContext>;\n  @ContentChild('regenerateButton', { read: TemplateRef }) regenerateButtonTemplate?: TemplateRef<RegenerateButtonContext>;\n  @ContentChild('toolCallsView', { read: TemplateRef }) toolCallsViewTemplate?: TemplateRef<any>;\n  \n  // Class inputs for styling default components\n  @Input() markdownRendererClass?: string;\n  @Input() toolbarClass?: string;\n  @Input() copyButtonClass?: string;\n  @Input() thumbsUpButtonClass?: string;\n  @Input() thumbsDownButtonClass?: string;\n  @Input() readAloudButtonClass?: string;\n  @Input() regenerateButtonClass?: string;\n  @Input() toolCallsViewClass?: string;\n  \n  // Component inputs for overrides\n  @Input() markdownRendererComponent?: Type<any>;\n  @Input() toolbarComponent?: Type<any>;\n  @Input() copyButtonComponent?: Type<any>;\n  @Input() thumbsUpButtonComponent?: Type<any>;\n  @Input() thumbsDownButtonComponent?: Type<any>;\n  @Input() readAloudButtonComponent?: Type<any>;\n  @Input() regenerateButtonComponent?: Type<any>;\n  @Input() toolCallsViewComponent?: Type<any>;\n  \n  // Regular inputs\n  @Input() message!: AssistantMessage;\n  @Input() messages: Message[] = [];\n  @Input() isLoading = false;\n  @Input() additionalToolbarItems?: TemplateRef<any>;\n  @Input() toolbarVisible = true;\n  @Input() set inputClass(val: string | undefined) {\n    this.customClass.set(val);\n  }\n  \n  // DI service exposes handler availability scoped to CopilotChatView\n  // Make it optional with a default fallback for testing\n  handlers: CopilotChatViewHandlersService;\n  \n  constructor(@Optional() @Inject(CopilotChatViewHandlersService) handlers?: CopilotChatViewHandlersService | null) {\n    this.handlers = handlers || new CopilotChatViewHandlersService();\n  }\n  \n  // Output events\n  @Output() thumbsUp = new EventEmitter<CopilotChatAssistantMessageOnThumbsUpProps>();\n  @Output() thumbsDown = new EventEmitter<CopilotChatAssistantMessageOnThumbsDownProps>();\n  @Output() readAloud = new EventEmitter<CopilotChatAssistantMessageOnReadAloudProps>();\n  @Output() regenerate = new EventEmitter<CopilotChatAssistantMessageOnRegenerateProps>();\n  \n  // Signals\n  customClass = signal<string | undefined>(undefined);\n  \n  // Computed values\n  computedClass = computed(() => {\n    return cn(\n      \"prose max-w-full break-words dark:prose-invert\",\n      this.customClass()\n    );\n  });\n  \n  // Default components\n  protected readonly defaultThumbsUpButtonComponent = CopilotChatAssistantMessageThumbsUpButtonComponent;\n  protected readonly defaultThumbsDownButtonComponent = CopilotChatAssistantMessageThumbsDownButtonComponent;\n  protected readonly CopilotChatAssistantMessageRendererComponent = CopilotChatAssistantMessageRendererComponent;\n  protected readonly CopilotChatAssistantMessageToolbarComponent = CopilotChatAssistantMessageToolbarComponent;\n  protected readonly CopilotChatAssistantMessageCopyButtonComponent = CopilotChatAssistantMessageCopyButtonComponent;\n  protected readonly CopilotChatToolCallsViewComponent = CopilotChatToolCallsViewComponent;\n  \n  // Context for slots (reactive via signals)\n  markdownRendererContext = computed<AssistantMessageMarkdownRendererContext>(() => ({\n    content: this.message?.content || ''\n  }));\n  \n  // Output maps for slots\n  copyButtonOutputs = { clicked: () => this.handleCopy() };\n  thumbsUpButtonOutputs = { clicked: () => this.handleThumbsUp() };\n  thumbsDownButtonOutputs = { clicked: () => this.handleThumbsDown() };\n  readAloudButtonOutputs = { clicked: () => this.handleReadAloud() };\n  regenerateButtonOutputs = { clicked: () => this.handleRegenerate() };\n  \n  toolbarContext = computed<AssistantMessageToolbarContext>(() => ({\n    children: null // Will be populated by the toolbar content\n  }));\n\n  // Return true if assistant message has non-empty text content\n  hasMessageContent(): boolean {\n    const raw = (this.message?.content ?? '') as any;\n    const content = typeof raw === 'string' ? raw : String(raw ?? '');\n    return content.trim().length > 0;\n  }\n  \n  toolCallsViewContext = computed(() => ({\n    message: this.message,\n    messages: this.messages,\n    isLoading: this.isLoading\n  }));\n  \n  handleCopy(): void {\n    // Copy is handled by the button component itself\n    // This is just for any additional logic if needed\n  }\n  \n  handleThumbsUp(): void {\n    this.thumbsUp.emit({ message: this.message });\n  }\n  \n  handleThumbsDown(): void {\n    this.thumbsDown.emit({ message: this.message });\n  }\n  \n  handleReadAloud(): void {\n    this.readAloud.emit({ message: this.message });\n  }\n  \n  handleRegenerate(): void {\n    this.regenerate.emit({ message: this.message });\n  }\n}\n"]}
|
|
@@ -166,7 +166,7 @@ export class CopilotChatInputComponent {
|
|
|
166
166
|
if (configValue !== undefined && !this.valueSignal()) {
|
|
167
167
|
this.valueSignal.set(configValue);
|
|
168
168
|
}
|
|
169
|
-
});
|
|
169
|
+
}, { allowSignalWrites: true });
|
|
170
170
|
}
|
|
171
171
|
// Output maps for slots
|
|
172
172
|
addFileButtonOutputs = { clicked: () => this.handleAddFile() };
|
|
@@ -663,4 +663,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
663
663
|
}], valueChange: [{
|
|
664
664
|
type: Output
|
|
665
665
|
}] } });
|
|
666
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"copilot-chat-input.component.js","sourceRoot":"","sources":["../../../../src/components/chat/copilot-chat-input.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  ViewChild,\n  TemplateRef,\n  signal,\n  computed,\n  effect,\n  inject,\n  ChangeDetectionStrategy,\n  AfterViewInit,\n  OnDestroy,\n  Type,\n  ViewEncapsulation,\n  ContentChild\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { CopilotSlotComponent } from '../../lib/slots/copilot-slot.component';\nimport { CopilotChatConfigurationService } from '../../core/chat-configuration/chat-configuration.service';\nimport { LucideAngularModule, ArrowUp } from 'lucide-angular';\nimport { CopilotChatTextareaComponent } from './copilot-chat-textarea.component';\nimport { CopilotChatAudioRecorderComponent } from './copilot-chat-audio-recorder.component';\nimport {\n  CopilotChatSendButtonComponent,\n  CopilotChatStartTranscribeButtonComponent,\n  CopilotChatCancelTranscribeButtonComponent,\n  CopilotChatFinishTranscribeButtonComponent,\n  CopilotChatAddFileButtonComponent\n} from './copilot-chat-buttons.component';\nimport { CopilotChatToolbarComponent } from './copilot-chat-toolbar.component';\nimport { CopilotChatToolsMenuComponent } from './copilot-chat-tools-menu.component';\nimport type {\n  CopilotChatInputMode,\n  ToolsMenuItem\n} from './copilot-chat-input.types';\nimport { cn } from '../../lib/utils';\n\n/**\n * Context provided to slot templates\n */\nexport interface SendButtonContext {\n  send: () => void;\n  disabled: boolean;\n  value: string;\n}\n\nexport interface ToolbarContext {\n  mode: CopilotChatInputMode;\n  value: string;\n}\n\n@Component({\n  selector: 'copilot-chat-input',\n  standalone: true,\n  imports: [\n    CommonModule,\n    CopilotSlotComponent,\n    LucideAngularModule,\n    CopilotChatTextareaComponent,\n    CopilotChatAudioRecorderComponent,\n    CopilotChatSendButtonComponent,\n    CopilotChatStartTranscribeButtonComponent,\n    CopilotChatCancelTranscribeButtonComponent,\n    CopilotChatFinishTranscribeButtonComponent,\n    CopilotChatAddFileButtonComponent,\n    CopilotChatToolbarComponent,\n    CopilotChatToolsMenuComponent\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  template: `\n    <div [class]=\"computedClass()\">\n      <!-- Main input area: either textarea or audio recorder -->\n      @if (computedMode() === 'transcribe') {\n        @if (audioRecorderTemplate || audioRecorderComponent) {\n          <copilot-slot \n            [slot]=\"audioRecorderTemplate || audioRecorderComponent\"\n            [context]=\"audioRecorderContext()\"\n            [defaultComponent]=\"defaultAudioRecorder\"\n            >\n          </copilot-slot>\n        } @else {\n          <copilot-chat-audio-recorder\n            [inputShowControls]=\"true\">\n          </copilot-chat-audio-recorder>\n        }\n      } @else {\n        @if (textAreaTemplate || textAreaComponent) {\n          <copilot-slot\n            [slot]=\"textAreaTemplate || textAreaComponent\"\n            [context]=\"textAreaContext()\"\n            >\n          </copilot-slot>\n        } @else {\n          <textarea copilotChatTextarea\n            [inputValue]=\"computedValue()\"\n            [inputAutoFocus]=\"computedAutoFocus()\"\n            [inputDisabled]=\"computedMode() === 'processing'\"\n            [inputClass]=\"textAreaClass\"\n            [inputMaxRows]=\"textAreaMaxRows\"\n            [inputPlaceholder]=\"textAreaPlaceholder\"\n            (keyDown)=\"handleKeyDown($event)\"\n            (valueChange)=\"handleValueChange($event)\"></textarea>\n        }\n      }\n      \n      <!-- Toolbar -->\n      @if (toolbarTemplate || toolbarComponent) {\n        <copilot-slot\n          [slot]=\"toolbarTemplate || toolbarComponent\"\n          [context]=\"toolbarContext()\"\n          [defaultComponent]=\"CopilotChatToolbarComponent\"\n          >\n        </copilot-slot>\n      } @else {\n        <div copilotChatToolbar>\n          <div class=\"flex items-center\">\n            @if (addFile.observed) {\n              @if (addFileButtonTemplate || addFileButtonComponent) {\n                <copilot-slot\n                  [slot]=\"addFileButtonTemplate || addFileButtonComponent\"\n                  [context]=\"{ inputDisabled: computedMode() === 'transcribe' }\"\n                  [outputs]=\"addFileButtonOutputs\"\n                  [defaultComponent]=\"CopilotChatAddFileButtonComponent\"\n                  >\n                </copilot-slot>\n              } @else {\n                <copilot-chat-add-file-button\n                  [disabled]=\"computedMode() === 'transcribe'\"\n                  (clicked)=\"handleAddFile()\">\n                </copilot-chat-add-file-button>\n              }\n            }\n            @if (computedToolsMenu().length > 0) {\n              @if (toolsButtonTemplate || toolsButtonComponent) {\n                <copilot-slot\n                  [slot]=\"toolsButtonTemplate || toolsButtonComponent\"\n                  [context]=\"toolsContext()\"\n                  [defaultComponent]=\"CopilotChatToolsMenuComponent\"\n                  >\n                </copilot-slot>\n              } @else {\n                <copilot-chat-tools-menu\n                  [inputToolsMenu]=\"computedToolsMenu()\"\n                  [inputDisabled]=\"computedMode() === 'transcribe'\">\n                </copilot-chat-tools-menu>\n              }\n            }\n            @if (additionalToolbarItems) {\n              <ng-container *ngTemplateOutlet=\"additionalToolbarItems\"></ng-container>\n            }\n          </div>\n          <div class=\"flex items-center\">\n            @if (computedMode() === 'transcribe') {\n              @if (cancelTranscribe.observed) {\n                @if (cancelTranscribeButtonTemplate || cancelTranscribeButtonComponent) {\n                  <copilot-slot\n                    [slot]=\"cancelTranscribeButtonTemplate || cancelTranscribeButtonComponent\"\n                    [context]=\"{}\"\n                    [outputs]=\"cancelTranscribeButtonOutputs\"\n                    [defaultComponent]=\"CopilotChatCancelTranscribeButtonComponent\"\n                    >\n                  </copilot-slot>\n                } @else {\n                  <copilot-chat-cancel-transcribe-button\n                    (clicked)=\"handleCancelTranscribe()\">\n                  </copilot-chat-cancel-transcribe-button>\n                }\n              }\n              @if (finishTranscribe.observed) {\n                @if (finishTranscribeButtonTemplate || finishTranscribeButtonComponent) {\n                  <copilot-slot\n                    [slot]=\"finishTranscribeButtonTemplate || finishTranscribeButtonComponent\"\n                    [context]=\"{}\"\n                    [outputs]=\"finishTranscribeButtonOutputs\"\n                    [defaultComponent]=\"CopilotChatFinishTranscribeButtonComponent\"\n                    >\n                  </copilot-slot>\n                } @else {\n                  <copilot-chat-finish-transcribe-button\n                    (clicked)=\"handleFinishTranscribe()\">\n                  </copilot-chat-finish-transcribe-button>\n                }\n              }\n            } @else {\n              @if (startTranscribe.observed) {\n                @if (startTranscribeButtonTemplate || startTranscribeButtonComponent) {\n                  <copilot-slot\n                    [slot]=\"startTranscribeButtonTemplate || startTranscribeButtonComponent\"\n                    [context]=\"{}\"\n                    [outputs]=\"startTranscribeButtonOutputs\"\n                    [defaultComponent]=\"CopilotChatStartTranscribeButtonComponent\"\n                    >\n                  </copilot-slot>\n                } @else {\n                  <copilot-chat-start-transcribe-button\n                    (clicked)=\"handleStartTranscribe()\">\n                  </copilot-chat-start-transcribe-button>\n                }\n              }\n              <!-- Send button with slot -->\n              @if (sendButtonTemplate || sendButtonComponent) {\n                <copilot-slot\n                  [slot]=\"sendButtonTemplate || sendButtonComponent\"\n                  [context]=\"sendButtonContext()\"\n                  [outputs]=\"sendButtonOutputs\"\n                  >\n                </copilot-slot>\n              } @else {\n                <div class=\"mr-[10px]\">\n                  <button \n                    type=\"button\"\n                    [class]=\"sendButtonClass || defaultButtonClass\"\n                    [disabled]=\"!computedValue().trim() || computedMode() === 'processing'\"\n                    (click)=\"send()\">\n                    <lucide-angular [img]=\"ArrowUpIcon\" [size]=\"18\"></lucide-angular>\n                  </button>\n                </div>\n              }\n            }\n          </div>\n        </div>\n      }\n    </div>\n  `,\n  styles: [`\n    :host {\n      display: block;\n      width: 100%;\n    }\n    .shadow-\\\\[0_4px_4px_0_\\\\#0000000a\\\\2c_0_0_1px_0_\\\\#0000009e\\\\] {\n      box-shadow: 0 4px 4px 0 #0000000a, 0 0 1px 0 #0000009e !important;\n    }\n  `]\n})\nexport class CopilotChatInputComponent implements AfterViewInit, OnDestroy {\n  @ViewChild(CopilotChatTextareaComponent, { read: CopilotChatTextareaComponent }) \n  textAreaRef?: CopilotChatTextareaComponent;\n  \n  @ViewChild(CopilotChatAudioRecorderComponent) \n  audioRecorderRef?: CopilotChatAudioRecorderComponent;\n  \n  // Capture templates from content projection\n  @ContentChild('sendButton', { read: TemplateRef }) sendButtonTemplate?: TemplateRef<SendButtonContext>;\n  @ContentChild('toolbar', { read: TemplateRef }) toolbarTemplate?: TemplateRef<ToolbarContext>;\n  @ContentChild('textArea', { read: TemplateRef }) textAreaTemplate?: TemplateRef<any>;\n  @ContentChild('audioRecorder', { read: TemplateRef }) audioRecorderTemplate?: TemplateRef<any>;\n  @ContentChild('startTranscribeButton', { read: TemplateRef }) startTranscribeButtonTemplate?: TemplateRef<any>;\n  @ContentChild('cancelTranscribeButton', { read: TemplateRef }) cancelTranscribeButtonTemplate?: TemplateRef<any>;\n  @ContentChild('finishTranscribeButton', { read: TemplateRef }) finishTranscribeButtonTemplate?: TemplateRef<any>;\n  @ContentChild('addFileButton', { read: TemplateRef }) addFileButtonTemplate?: TemplateRef<any>;\n  @ContentChild('toolsButton', { read: TemplateRef }) toolsButtonTemplate?: TemplateRef<any>;\n  \n  // Class inputs for styling default components\n  @Input() sendButtonClass?: string;\n  @Input() toolbarClass?: string;\n  @Input() textAreaClass?: string;\n  @Input() textAreaMaxRows?: number;\n  @Input() textAreaPlaceholder?: string;\n  @Input() audioRecorderClass?: string;\n  @Input() startTranscribeButtonClass?: string;\n  @Input() cancelTranscribeButtonClass?: string;\n  @Input() finishTranscribeButtonClass?: string;\n  @Input() addFileButtonClass?: string;\n  @Input() toolsButtonClass?: string;\n  \n  // Component inputs for overrides\n  @Input() sendButtonComponent?: Type<any>;\n  @Input() toolbarComponent?: Type<any>;\n  @Input() textAreaComponent?: Type<any>;\n  @Input() audioRecorderComponent?: Type<any>;\n  @Input() startTranscribeButtonComponent?: Type<any>;\n  @Input() cancelTranscribeButtonComponent?: Type<any>;\n  @Input() finishTranscribeButtonComponent?: Type<any>;\n  @Input() addFileButtonComponent?: Type<any>;\n  @Input() toolsButtonComponent?: Type<any>;\n  \n  // Regular inputs\n  @Input() set mode(val: CopilotChatInputMode | undefined) {\n    this.modeSignal.set(val || 'input');\n  }\n  @Input() set toolsMenu(val: (ToolsMenuItem | '-')[] | undefined) {\n    this.toolsMenuSignal.set(val || []);\n  }\n  @Input() set autoFocus(val: boolean | undefined) {\n    this.autoFocusSignal.set(val ?? true);\n  }\n  @Input() set value(val: string | undefined) {\n    this.valueSignal.set(val || '');\n  }\n  @Input() set inputClass(val: string | undefined) {\n    this.customClass.set(val);\n  }\n  // Note: Prefer host `class` for styling this component;\n  // keep only `inputClass` to style the internal wrapper if needed.\n  @Input() additionalToolbarItems?: TemplateRef<any>;\n  \n  // Output events\n  @Output() submitMessage = new EventEmitter<string>();\n  @Output() startTranscribe = new EventEmitter<void>();\n  @Output() cancelTranscribe = new EventEmitter<void>();\n  @Output() finishTranscribe = new EventEmitter<void>();\n  @Output() addFile = new EventEmitter<void>();\n  @Output() valueChange = new EventEmitter<string>();\n  \n  // Icons and default classes\n  readonly ArrowUpIcon = ArrowUp;\n  readonly defaultButtonClass = cn(\n    // Base button styles\n    'inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium',\n    'transition-all disabled:pointer-events-none disabled:opacity-50',\n    'shrink-0 outline-none',\n    'focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px]',\n    // chatInputToolbarPrimary variant\n    'cursor-pointer',\n    'bg-black text-white',\n    'dark:bg-white dark:text-black dark:focus-visible:outline-white',\n    'rounded-full h-9 w-9',\n    'transition-colors',\n    'focus:outline-none',\n    'hover:opacity-70 disabled:hover:opacity-100',\n    'disabled:cursor-not-allowed disabled:bg-[#00000014] disabled:text-[rgb(13,13,13)]',\n    'dark:disabled:bg-[#454545] dark:disabled:text-white'\n  );\n  \n  // Services\n  private chatConfig = inject(CopilotChatConfigurationService, { optional: true });\n  \n  // Signals\n  modeSignal = signal<CopilotChatInputMode>('input');\n  toolsMenuSignal = signal<(ToolsMenuItem | '-')[]>([]);\n  autoFocusSignal = signal<boolean>(true);\n  valueSignal = signal<string>('');\n  customClass = signal<string | undefined>(undefined);\n  \n  // Default components\n  // Note: CopilotChatTextareaComponent uses attribute selector but is a component\n  defaultAudioRecorder = CopilotChatAudioRecorderComponent;\n  defaultSendButton: any = null; // Will be set to avoid circular dependency\n  CopilotChatToolbarComponent = CopilotChatToolbarComponent;\n  CopilotChatAddFileButtonComponent = CopilotChatAddFileButtonComponent;\n  CopilotChatToolsMenuComponent = CopilotChatToolsMenuComponent;\n  CopilotChatCancelTranscribeButtonComponent = CopilotChatCancelTranscribeButtonComponent;\n  CopilotChatFinishTranscribeButtonComponent = CopilotChatFinishTranscribeButtonComponent;\n  CopilotChatStartTranscribeButtonComponent = CopilotChatStartTranscribeButtonComponent;\n  \n  // Computed values\n  computedMode = computed(() => this.modeSignal());\n  computedToolsMenu = computed(() => this.toolsMenuSignal());\n  computedAutoFocus = computed(() => this.autoFocusSignal());\n  computedValue = computed(() => {\n    const customValue = this.valueSignal();\n    const configValue = this.chatConfig?.inputValue();\n    return customValue || configValue || '';\n  });\n  \n  computedClass = computed(() => {\n    const baseClasses = cn(\n      // Layout\n      'flex w-full flex-col items-center justify-center',\n      // Interaction\n      'cursor-text',\n      // Overflow and clipping\n      'overflow-visible bg-clip-padding contain-inline-size',\n      // Background\n      'bg-white dark:bg-[#303030]',\n      // Visual effects\n      'shadow-[0_4px_4px_0_#0000000a,0_0_1px_0_#0000009e] rounded-[28px]'\n    );\n    return cn(baseClasses, this.customClass());\n  });\n  \n  // Context for slots (reactive via signals)\n  sendButtonContext = computed<SendButtonContext>(() => ({\n    send: () => this.send(),\n    disabled: !this.computedValue().trim() || this.computedMode() === 'processing',\n    value: this.computedValue()\n  }));\n  \n  toolbarContext = computed<ToolbarContext>(() => ({\n    mode: this.computedMode(),\n    value: this.computedValue()\n  }));\n  \n  textAreaContext = computed(() => ({\n    value: this.computedValue(),\n    autoFocus: this.computedAutoFocus(),\n    disabled: this.computedMode() === 'processing',\n    maxRows: this.textAreaMaxRows,\n    placeholder: this.textAreaPlaceholder,\n    inputClass: this.textAreaClass,\n    onKeyDown: (event: KeyboardEvent) => this.handleKeyDown(event),\n    onChange: (value: string) => this.handleValueChange(value)\n  }));\n  \n  audioRecorderContext = computed(() => ({\n    inputShowControls: true\n  }));\n  \n  // Button contexts removed - now using outputs map for click handlers\n  \n  toolsContext = computed(() => ({\n    inputToolsMenu: this.computedToolsMenu(),\n    inputDisabled: this.computedMode() === 'transcribe'\n  }));\n  \n  constructor() {\n    // Effect to handle mode changes\n    effect(() => {\n      const currentMode = this.computedMode();\n      if (currentMode === 'transcribe' && this.audioRecorderRef) {\n        this.audioRecorderRef.start().catch(console.error);\n      } else if (this.audioRecorderRef?.getState() === 'recording') {\n        this.audioRecorderRef.stop().catch(console.error);\n      }\n    });\n    \n    // Sync with chat configuration\n    effect(() => {\n      const configValue = this.chatConfig?.inputValue();\n      if (configValue !== undefined && !this.valueSignal()) {\n        this.valueSignal.set(configValue);\n      }\n    });\n  }\n  \n  // Output maps for slots\n  addFileButtonOutputs = { clicked: () => this.handleAddFile() };\n  cancelTranscribeButtonOutputs = { clicked: () => this.handleCancelTranscribe() };\n  finishTranscribeButtonOutputs = { clicked: () => this.handleFinishTranscribe() };\n  startTranscribeButtonOutputs = { clicked: () => this.handleStartTranscribe() };\n  // Support both `clicked` (idiomatic in our slots) and `click` (legacy)\n  sendButtonOutputs = { clicked: () => this.send(), click: () => this.send() };\n  \n  ngAfterViewInit(): void {\n    // Auto-focus if needed\n    if (this.computedAutoFocus() && this.textAreaRef) {\n      setTimeout(() => {\n        this.textAreaRef?.focus();\n      });\n    }\n  }\n  \n  ngOnDestroy(): void {\n    // Clean up any resources\n    if (this.audioRecorderRef?.getState() === 'recording') {\n      this.audioRecorderRef.stop().catch(console.error);\n    }\n  }\n  \n  handleKeyDown(event: KeyboardEvent): void {\n    if (event.key === 'Enter' && !event.shiftKey) {\n      event.preventDefault();\n      this.send();\n    }\n  }\n  \n  handleValueChange(value: string): void {\n    this.valueSignal.set(value);\n    this.valueChange.emit(value);\n    \n    if (this.chatConfig) {\n      this.chatConfig.setInputValue(value);\n    }\n  }\n  \n  send(): void {\n    const trimmed = this.computedValue().trim();\n    if (trimmed) {\n      this.submitMessage.emit(trimmed);\n      \n      // Use chat config handler if available\n      if (this.chatConfig) {\n        this.chatConfig.submitInput(trimmed);\n      }\n      \n      // Clear input\n      this.valueSignal.set('');\n      if (this.textAreaRef) {\n        this.textAreaRef.setValue('');\n      }\n      \n      // Refocus input\n      if (this.textAreaRef) {\n        setTimeout(() => {\n          this.textAreaRef?.focus();\n        });\n      }\n    }\n  }\n  \n  handleStartTranscribe(): void {\n    this.startTranscribe.emit();\n    this.modeSignal.set('transcribe');\n  }\n  \n  handleCancelTranscribe(): void {\n    this.cancelTranscribe.emit();\n    this.modeSignal.set('input');\n  }\n  \n  handleFinishTranscribe(): void {\n    this.finishTranscribe.emit();\n    this.modeSignal.set('input');\n  }\n  \n  handleAddFile(): void {\n    this.addFile.emit();\n  }\n}\n"]}
|
|
666
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"copilot-chat-input.component.js","sourceRoot":"","sources":["../../../../src/components/chat/copilot-chat-input.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  ViewChild,\n  TemplateRef,\n  signal,\n  computed,\n  effect,\n  inject,\n  ChangeDetectionStrategy,\n  AfterViewInit,\n  OnDestroy,\n  Type,\n  ViewEncapsulation,\n  ContentChild\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { CopilotSlotComponent } from '../../lib/slots/copilot-slot.component';\nimport { CopilotChatConfigurationService } from '../../core/chat-configuration/chat-configuration.service';\nimport { LucideAngularModule, ArrowUp } from 'lucide-angular';\nimport { CopilotChatTextareaComponent } from './copilot-chat-textarea.component';\nimport { CopilotChatAudioRecorderComponent } from './copilot-chat-audio-recorder.component';\nimport {\n  CopilotChatSendButtonComponent,\n  CopilotChatStartTranscribeButtonComponent,\n  CopilotChatCancelTranscribeButtonComponent,\n  CopilotChatFinishTranscribeButtonComponent,\n  CopilotChatAddFileButtonComponent\n} from './copilot-chat-buttons.component';\nimport { CopilotChatToolbarComponent } from './copilot-chat-toolbar.component';\nimport { CopilotChatToolsMenuComponent } from './copilot-chat-tools-menu.component';\nimport type {\n  CopilotChatInputMode,\n  ToolsMenuItem\n} from './copilot-chat-input.types';\nimport { cn } from '../../lib/utils';\n\n/**\n * Context provided to slot templates\n */\nexport interface SendButtonContext {\n  send: () => void;\n  disabled: boolean;\n  value: string;\n}\n\nexport interface ToolbarContext {\n  mode: CopilotChatInputMode;\n  value: string;\n}\n\n@Component({\n  selector: 'copilot-chat-input',\n  standalone: true,\n  imports: [\n    CommonModule,\n    CopilotSlotComponent,\n    LucideAngularModule,\n    CopilotChatTextareaComponent,\n    CopilotChatAudioRecorderComponent,\n    CopilotChatSendButtonComponent,\n    CopilotChatStartTranscribeButtonComponent,\n    CopilotChatCancelTranscribeButtonComponent,\n    CopilotChatFinishTranscribeButtonComponent,\n    CopilotChatAddFileButtonComponent,\n    CopilotChatToolbarComponent,\n    CopilotChatToolsMenuComponent\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  template: `\n    <div [class]=\"computedClass()\">\n      <!-- Main input area: either textarea or audio recorder -->\n      @if (computedMode() === 'transcribe') {\n        @if (audioRecorderTemplate || audioRecorderComponent) {\n          <copilot-slot \n            [slot]=\"audioRecorderTemplate || audioRecorderComponent\"\n            [context]=\"audioRecorderContext()\"\n            [defaultComponent]=\"defaultAudioRecorder\"\n            >\n          </copilot-slot>\n        } @else {\n          <copilot-chat-audio-recorder\n            [inputShowControls]=\"true\">\n          </copilot-chat-audio-recorder>\n        }\n      } @else {\n        @if (textAreaTemplate || textAreaComponent) {\n          <copilot-slot\n            [slot]=\"textAreaTemplate || textAreaComponent\"\n            [context]=\"textAreaContext()\"\n            >\n          </copilot-slot>\n        } @else {\n          <textarea copilotChatTextarea\n            [inputValue]=\"computedValue()\"\n            [inputAutoFocus]=\"computedAutoFocus()\"\n            [inputDisabled]=\"computedMode() === 'processing'\"\n            [inputClass]=\"textAreaClass\"\n            [inputMaxRows]=\"textAreaMaxRows\"\n            [inputPlaceholder]=\"textAreaPlaceholder\"\n            (keyDown)=\"handleKeyDown($event)\"\n            (valueChange)=\"handleValueChange($event)\"></textarea>\n        }\n      }\n      \n      <!-- Toolbar -->\n      @if (toolbarTemplate || toolbarComponent) {\n        <copilot-slot\n          [slot]=\"toolbarTemplate || toolbarComponent\"\n          [context]=\"toolbarContext()\"\n          [defaultComponent]=\"CopilotChatToolbarComponent\"\n          >\n        </copilot-slot>\n      } @else {\n        <div copilotChatToolbar>\n          <div class=\"flex items-center\">\n            @if (addFile.observed) {\n              @if (addFileButtonTemplate || addFileButtonComponent) {\n                <copilot-slot\n                  [slot]=\"addFileButtonTemplate || addFileButtonComponent\"\n                  [context]=\"{ inputDisabled: computedMode() === 'transcribe' }\"\n                  [outputs]=\"addFileButtonOutputs\"\n                  [defaultComponent]=\"CopilotChatAddFileButtonComponent\"\n                  >\n                </copilot-slot>\n              } @else {\n                <copilot-chat-add-file-button\n                  [disabled]=\"computedMode() === 'transcribe'\"\n                  (clicked)=\"handleAddFile()\">\n                </copilot-chat-add-file-button>\n              }\n            }\n            @if (computedToolsMenu().length > 0) {\n              @if (toolsButtonTemplate || toolsButtonComponent) {\n                <copilot-slot\n                  [slot]=\"toolsButtonTemplate || toolsButtonComponent\"\n                  [context]=\"toolsContext()\"\n                  [defaultComponent]=\"CopilotChatToolsMenuComponent\"\n                  >\n                </copilot-slot>\n              } @else {\n                <copilot-chat-tools-menu\n                  [inputToolsMenu]=\"computedToolsMenu()\"\n                  [inputDisabled]=\"computedMode() === 'transcribe'\">\n                </copilot-chat-tools-menu>\n              }\n            }\n            @if (additionalToolbarItems) {\n              <ng-container *ngTemplateOutlet=\"additionalToolbarItems\"></ng-container>\n            }\n          </div>\n          <div class=\"flex items-center\">\n            @if (computedMode() === 'transcribe') {\n              @if (cancelTranscribe.observed) {\n                @if (cancelTranscribeButtonTemplate || cancelTranscribeButtonComponent) {\n                  <copilot-slot\n                    [slot]=\"cancelTranscribeButtonTemplate || cancelTranscribeButtonComponent\"\n                    [context]=\"{}\"\n                    [outputs]=\"cancelTranscribeButtonOutputs\"\n                    [defaultComponent]=\"CopilotChatCancelTranscribeButtonComponent\"\n                    >\n                  </copilot-slot>\n                } @else {\n                  <copilot-chat-cancel-transcribe-button\n                    (clicked)=\"handleCancelTranscribe()\">\n                  </copilot-chat-cancel-transcribe-button>\n                }\n              }\n              @if (finishTranscribe.observed) {\n                @if (finishTranscribeButtonTemplate || finishTranscribeButtonComponent) {\n                  <copilot-slot\n                    [slot]=\"finishTranscribeButtonTemplate || finishTranscribeButtonComponent\"\n                    [context]=\"{}\"\n                    [outputs]=\"finishTranscribeButtonOutputs\"\n                    [defaultComponent]=\"CopilotChatFinishTranscribeButtonComponent\"\n                    >\n                  </copilot-slot>\n                } @else {\n                  <copilot-chat-finish-transcribe-button\n                    (clicked)=\"handleFinishTranscribe()\">\n                  </copilot-chat-finish-transcribe-button>\n                }\n              }\n            } @else {\n              @if (startTranscribe.observed) {\n                @if (startTranscribeButtonTemplate || startTranscribeButtonComponent) {\n                  <copilot-slot\n                    [slot]=\"startTranscribeButtonTemplate || startTranscribeButtonComponent\"\n                    [context]=\"{}\"\n                    [outputs]=\"startTranscribeButtonOutputs\"\n                    [defaultComponent]=\"CopilotChatStartTranscribeButtonComponent\"\n                    >\n                  </copilot-slot>\n                } @else {\n                  <copilot-chat-start-transcribe-button\n                    (clicked)=\"handleStartTranscribe()\">\n                  </copilot-chat-start-transcribe-button>\n                }\n              }\n              <!-- Send button with slot -->\n              @if (sendButtonTemplate || sendButtonComponent) {\n                <copilot-slot\n                  [slot]=\"sendButtonTemplate || sendButtonComponent\"\n                  [context]=\"sendButtonContext()\"\n                  [outputs]=\"sendButtonOutputs\"\n                  >\n                </copilot-slot>\n              } @else {\n                <div class=\"mr-[10px]\">\n                  <button \n                    type=\"button\"\n                    [class]=\"sendButtonClass || defaultButtonClass\"\n                    [disabled]=\"!computedValue().trim() || computedMode() === 'processing'\"\n                    (click)=\"send()\">\n                    <lucide-angular [img]=\"ArrowUpIcon\" [size]=\"18\"></lucide-angular>\n                  </button>\n                </div>\n              }\n            }\n          </div>\n        </div>\n      }\n    </div>\n  `,\n  styles: [`\n    :host {\n      display: block;\n      width: 100%;\n    }\n    .shadow-\\\\[0_4px_4px_0_\\\\#0000000a\\\\2c_0_0_1px_0_\\\\#0000009e\\\\] {\n      box-shadow: 0 4px 4px 0 #0000000a, 0 0 1px 0 #0000009e !important;\n    }\n  `]\n})\nexport class CopilotChatInputComponent implements AfterViewInit, OnDestroy {\n  @ViewChild(CopilotChatTextareaComponent, { read: CopilotChatTextareaComponent }) \n  textAreaRef?: CopilotChatTextareaComponent;\n  \n  @ViewChild(CopilotChatAudioRecorderComponent) \n  audioRecorderRef?: CopilotChatAudioRecorderComponent;\n  \n  // Capture templates from content projection\n  @ContentChild('sendButton', { read: TemplateRef }) sendButtonTemplate?: TemplateRef<SendButtonContext>;\n  @ContentChild('toolbar', { read: TemplateRef }) toolbarTemplate?: TemplateRef<ToolbarContext>;\n  @ContentChild('textArea', { read: TemplateRef }) textAreaTemplate?: TemplateRef<any>;\n  @ContentChild('audioRecorder', { read: TemplateRef }) audioRecorderTemplate?: TemplateRef<any>;\n  @ContentChild('startTranscribeButton', { read: TemplateRef }) startTranscribeButtonTemplate?: TemplateRef<any>;\n  @ContentChild('cancelTranscribeButton', { read: TemplateRef }) cancelTranscribeButtonTemplate?: TemplateRef<any>;\n  @ContentChild('finishTranscribeButton', { read: TemplateRef }) finishTranscribeButtonTemplate?: TemplateRef<any>;\n  @ContentChild('addFileButton', { read: TemplateRef }) addFileButtonTemplate?: TemplateRef<any>;\n  @ContentChild('toolsButton', { read: TemplateRef }) toolsButtonTemplate?: TemplateRef<any>;\n  \n  // Class inputs for styling default components\n  @Input() sendButtonClass?: string;\n  @Input() toolbarClass?: string;\n  @Input() textAreaClass?: string;\n  @Input() textAreaMaxRows?: number;\n  @Input() textAreaPlaceholder?: string;\n  @Input() audioRecorderClass?: string;\n  @Input() startTranscribeButtonClass?: string;\n  @Input() cancelTranscribeButtonClass?: string;\n  @Input() finishTranscribeButtonClass?: string;\n  @Input() addFileButtonClass?: string;\n  @Input() toolsButtonClass?: string;\n  \n  // Component inputs for overrides\n  @Input() sendButtonComponent?: Type<any>;\n  @Input() toolbarComponent?: Type<any>;\n  @Input() textAreaComponent?: Type<any>;\n  @Input() audioRecorderComponent?: Type<any>;\n  @Input() startTranscribeButtonComponent?: Type<any>;\n  @Input() cancelTranscribeButtonComponent?: Type<any>;\n  @Input() finishTranscribeButtonComponent?: Type<any>;\n  @Input() addFileButtonComponent?: Type<any>;\n  @Input() toolsButtonComponent?: Type<any>;\n  \n  // Regular inputs\n  @Input() set mode(val: CopilotChatInputMode | undefined) {\n    this.modeSignal.set(val || 'input');\n  }\n  @Input() set toolsMenu(val: (ToolsMenuItem | '-')[] | undefined) {\n    this.toolsMenuSignal.set(val || []);\n  }\n  @Input() set autoFocus(val: boolean | undefined) {\n    this.autoFocusSignal.set(val ?? true);\n  }\n  @Input() set value(val: string | undefined) {\n    this.valueSignal.set(val || '');\n  }\n  @Input() set inputClass(val: string | undefined) {\n    this.customClass.set(val);\n  }\n  // Note: Prefer host `class` for styling this component;\n  // keep only `inputClass` to style the internal wrapper if needed.\n  @Input() additionalToolbarItems?: TemplateRef<any>;\n  \n  // Output events\n  @Output() submitMessage = new EventEmitter<string>();\n  @Output() startTranscribe = new EventEmitter<void>();\n  @Output() cancelTranscribe = new EventEmitter<void>();\n  @Output() finishTranscribe = new EventEmitter<void>();\n  @Output() addFile = new EventEmitter<void>();\n  @Output() valueChange = new EventEmitter<string>();\n  \n  // Icons and default classes\n  readonly ArrowUpIcon = ArrowUp;\n  readonly defaultButtonClass = cn(\n    // Base button styles\n    'inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium',\n    'transition-all disabled:pointer-events-none disabled:opacity-50',\n    'shrink-0 outline-none',\n    'focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px]',\n    // chatInputToolbarPrimary variant\n    'cursor-pointer',\n    'bg-black text-white',\n    'dark:bg-white dark:text-black dark:focus-visible:outline-white',\n    'rounded-full h-9 w-9',\n    'transition-colors',\n    'focus:outline-none',\n    'hover:opacity-70 disabled:hover:opacity-100',\n    'disabled:cursor-not-allowed disabled:bg-[#00000014] disabled:text-[rgb(13,13,13)]',\n    'dark:disabled:bg-[#454545] dark:disabled:text-white'\n  );\n  \n  // Services\n  private chatConfig = inject(CopilotChatConfigurationService, { optional: true });\n  \n  // Signals\n  modeSignal = signal<CopilotChatInputMode>('input');\n  toolsMenuSignal = signal<(ToolsMenuItem | '-')[]>([]);\n  autoFocusSignal = signal<boolean>(true);\n  valueSignal = signal<string>('');\n  customClass = signal<string | undefined>(undefined);\n  \n  // Default components\n  // Note: CopilotChatTextareaComponent uses attribute selector but is a component\n  defaultAudioRecorder = CopilotChatAudioRecorderComponent;\n  defaultSendButton: any = null; // Will be set to avoid circular dependency\n  CopilotChatToolbarComponent = CopilotChatToolbarComponent;\n  CopilotChatAddFileButtonComponent = CopilotChatAddFileButtonComponent;\n  CopilotChatToolsMenuComponent = CopilotChatToolsMenuComponent;\n  CopilotChatCancelTranscribeButtonComponent = CopilotChatCancelTranscribeButtonComponent;\n  CopilotChatFinishTranscribeButtonComponent = CopilotChatFinishTranscribeButtonComponent;\n  CopilotChatStartTranscribeButtonComponent = CopilotChatStartTranscribeButtonComponent;\n  \n  // Computed values\n  computedMode = computed(() => this.modeSignal());\n  computedToolsMenu = computed(() => this.toolsMenuSignal());\n  computedAutoFocus = computed(() => this.autoFocusSignal());\n  computedValue = computed(() => {\n    const customValue = this.valueSignal();\n    const configValue = this.chatConfig?.inputValue();\n    return customValue || configValue || '';\n  });\n  \n  computedClass = computed(() => {\n    const baseClasses = cn(\n      // Layout\n      'flex w-full flex-col items-center justify-center',\n      // Interaction\n      'cursor-text',\n      // Overflow and clipping\n      'overflow-visible bg-clip-padding contain-inline-size',\n      // Background\n      'bg-white dark:bg-[#303030]',\n      // Visual effects\n      'shadow-[0_4px_4px_0_#0000000a,0_0_1px_0_#0000009e] rounded-[28px]'\n    );\n    return cn(baseClasses, this.customClass());\n  });\n  \n  // Context for slots (reactive via signals)\n  sendButtonContext = computed<SendButtonContext>(() => ({\n    send: () => this.send(),\n    disabled: !this.computedValue().trim() || this.computedMode() === 'processing',\n    value: this.computedValue()\n  }));\n  \n  toolbarContext = computed<ToolbarContext>(() => ({\n    mode: this.computedMode(),\n    value: this.computedValue()\n  }));\n  \n  textAreaContext = computed(() => ({\n    value: this.computedValue(),\n    autoFocus: this.computedAutoFocus(),\n    disabled: this.computedMode() === 'processing',\n    maxRows: this.textAreaMaxRows,\n    placeholder: this.textAreaPlaceholder,\n    inputClass: this.textAreaClass,\n    onKeyDown: (event: KeyboardEvent) => this.handleKeyDown(event),\n    onChange: (value: string) => this.handleValueChange(value)\n  }));\n  \n  audioRecorderContext = computed(() => ({\n    inputShowControls: true\n  }));\n  \n  // Button contexts removed - now using outputs map for click handlers\n  \n  toolsContext = computed(() => ({\n    inputToolsMenu: this.computedToolsMenu(),\n    inputDisabled: this.computedMode() === 'transcribe'\n  }));\n  \n  constructor() {\n    // Effect to handle mode changes\n    effect(() => {\n      const currentMode = this.computedMode();\n      if (currentMode === 'transcribe' && this.audioRecorderRef) {\n        this.audioRecorderRef.start().catch(console.error);\n      } else if (this.audioRecorderRef?.getState() === 'recording') {\n        this.audioRecorderRef.stop().catch(console.error);\n      }\n    });\n    \n    // Sync with chat configuration\n    effect(\n      () => {\n        const configValue = this.chatConfig?.inputValue();\n        if (configValue !== undefined && !this.valueSignal()) {\n          this.valueSignal.set(configValue);\n        }\n      },\n      { allowSignalWrites: true }\n    );\n  }\n  \n  // Output maps for slots\n  addFileButtonOutputs = { clicked: () => this.handleAddFile() };\n  cancelTranscribeButtonOutputs = { clicked: () => this.handleCancelTranscribe() };\n  finishTranscribeButtonOutputs = { clicked: () => this.handleFinishTranscribe() };\n  startTranscribeButtonOutputs = { clicked: () => this.handleStartTranscribe() };\n  // Support both `clicked` (idiomatic in our slots) and `click` (legacy)\n  sendButtonOutputs = { clicked: () => this.send(), click: () => this.send() };\n  \n  ngAfterViewInit(): void {\n    // Auto-focus if needed\n    if (this.computedAutoFocus() && this.textAreaRef) {\n      setTimeout(() => {\n        this.textAreaRef?.focus();\n      });\n    }\n  }\n  \n  ngOnDestroy(): void {\n    // Clean up any resources\n    if (this.audioRecorderRef?.getState() === 'recording') {\n      this.audioRecorderRef.stop().catch(console.error);\n    }\n  }\n  \n  handleKeyDown(event: KeyboardEvent): void {\n    if (event.key === 'Enter' && !event.shiftKey) {\n      event.preventDefault();\n      this.send();\n    }\n  }\n  \n  handleValueChange(value: string): void {\n    this.valueSignal.set(value);\n    this.valueChange.emit(value);\n    \n    if (this.chatConfig) {\n      this.chatConfig.setInputValue(value);\n    }\n  }\n  \n  send(): void {\n    const trimmed = this.computedValue().trim();\n    if (trimmed) {\n      this.submitMessage.emit(trimmed);\n      \n      // Use chat config handler if available\n      if (this.chatConfig) {\n        this.chatConfig.submitInput(trimmed);\n      }\n      \n      // Clear input\n      this.valueSignal.set('');\n      if (this.textAreaRef) {\n        this.textAreaRef.setValue('');\n      }\n      \n      // Refocus input\n      if (this.textAreaRef) {\n        setTimeout(() => {\n          this.textAreaRef?.focus();\n        });\n      }\n    }\n  }\n  \n  handleStartTranscribe(): void {\n    this.startTranscribe.emit();\n    this.modeSignal.set('transcribe');\n  }\n  \n  handleCancelTranscribe(): void {\n    this.cancelTranscribe.emit();\n    this.modeSignal.set('input');\n  }\n  \n  handleFinishTranscribe(): void {\n    this.finishTranscribe.emit();\n    this.modeSignal.set('input');\n  }\n  \n  handleAddFile(): void {\n    this.addFile.emit();\n  }\n}\n"]}
|
|
@@ -59,7 +59,7 @@ export class CopilotChatTextareaComponent {
|
|
|
59
59
|
if (configValue !== undefined && !this.customPlaceholder()) {
|
|
60
60
|
this.value.set(configValue);
|
|
61
61
|
}
|
|
62
|
-
});
|
|
62
|
+
}, { allowSignalWrites: true });
|
|
63
63
|
}
|
|
64
64
|
ngAfterViewInit() {
|
|
65
65
|
this.calculateMaxHeight();
|
|
@@ -185,4 +185,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
185
185
|
}], keyDown: [{
|
|
186
186
|
type: Output
|
|
187
187
|
}] } });
|
|
188
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"copilot-chat-textarea.component.js","sourceRoot":"","sources":["../../../../src/components/chat/copilot-chat-textarea.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  ElementRef,\n  AfterViewInit,\n  OnChanges,\n  SimpleChanges,\n  signal,\n  computed,\n  effect,\n  inject,\n  ChangeDetectionStrategy,\n  ViewEncapsulation\n} from '@angular/core';\nimport { CopilotChatConfigurationService } from '../../core/chat-configuration/chat-configuration.service';\nimport { cn } from '../../lib/utils';\n\n@Component({\n  selector: 'textarea[copilotChatTextarea]',\n  standalone: true,\n  imports: [],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  host: {\n    '[value]': 'value()',\n    '[placeholder]': 'placeholder()',\n    '[disabled]': 'disabled()',\n    '[class]': 'computedClass()',\n    '[style.max-height.px]': 'maxHeight()',\n    '[style.overflow]': \"'auto'\",\n    '[style.resize]': \"'none'\",\n    '(input)': 'onInput($event)',\n    '(keydown)': 'onKeyDown($event)',\n    '[attr.rows]': '1'\n  },\n  template: '',\n  styles: []\n})\nexport class CopilotChatTextareaComponent implements AfterViewInit, OnChanges {\n  private elementRef = inject(ElementRef<HTMLTextAreaElement>);\n  get textareaRef() { return this.elementRef; }\n  \n  @Input() set inputValue(val: string | undefined) {\n    this.value.set(val || '');\n  }\n  @Input() set inputPlaceholder(val: string | undefined) {\n    this.customPlaceholder.set(val);\n  }\n  @Input() set inputMaxRows(val: number | undefined) {\n    this.maxRows.set(val || 5);\n  }\n  @Input() set inputAutoFocus(val: boolean | undefined) {\n    this.autoFocus.set(val ?? true);\n  }\n  @Input() set inputDisabled(val: boolean | undefined) {\n    this.disabled.set(val || false);\n  }\n  @Input() set inputClass(val: string | undefined) {\n    this.customClass.set(val);\n  }\n  \n  @Output() valueChange = new EventEmitter<string>();\n  @Output() keyDown = new EventEmitter<KeyboardEvent>();\n  \n  private chatConfig = inject(CopilotChatConfigurationService);\n  \n  // Signals for reactive state\n  value = signal<string>('');\n  customPlaceholder = signal<string | undefined>(undefined);\n  maxRows = signal<number>(5);\n  autoFocus = signal<boolean>(true);\n  disabled = signal<boolean>(false);\n  customClass = signal<string | undefined>(undefined);\n  maxHeight = signal<number>(0);\n  \n  // Computed values\n  placeholder = computed(() => {\n    return this.customPlaceholder() || this.chatConfig.labels().chatInputPlaceholder;\n  });\n  \n  computedClass = computed(() => {\n    const baseClasses = cn(\n      // Layout and sizing\n      'w-full p-5 pb-0',\n      // Behavior\n      'outline-none resize-none',\n      // Background\n      'bg-transparent',\n      // Typography\n      'antialiased font-regular leading-relaxed text-[16px]',\n      // Placeholder styles\n      'placeholder:text-[#00000077] dark:placeholder:text-[#fffc]'\n    );\n    return cn(baseClasses, this.customClass());\n  });\n  \n  constructor() {\n    // Effect to sync value with chat configuration if available\n    effect(() => {\n      const configValue = this.chatConfig.inputValue();\n      if (configValue !== undefined && !this.customPlaceholder()) {\n        this.value.set(configValue);\n      }\n    });\n  }\n  \n  ngAfterViewInit(): void {\n    this.calculateMaxHeight();\n    this.adjustHeight();\n    \n    if (this.autoFocus()) {\n      setTimeout(() => {\n        this.elementRef.nativeElement.focus();\n      });\n    }\n  }\n  \n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['inputMaxRows']) {\n      this.calculateMaxHeight();\n    }\n  }\n  \n  onInput(event: Event): void {\n    const textarea = event.target as HTMLTextAreaElement;\n    const newValue = textarea.value;\n    \n    this.value.set(newValue);\n    this.valueChange.emit(newValue);\n    \n    // Update chat configuration if available\n    if (this.chatConfig) {\n      this.chatConfig.setInputValue(newValue);\n    }\n    \n    this.adjustHeight();\n  }\n  \n  onKeyDown(event: KeyboardEvent): void {\n    // Check for Enter key without Shift\n    if (event.key === 'Enter' && !event.shiftKey) {\n      event.preventDefault();\n      this.keyDown.emit(event);\n    } else {\n      this.keyDown.emit(event);\n    }\n  }\n  \n  private calculateMaxHeight(): void {\n    const textarea = this.elementRef.nativeElement;\n    const maxRowsValue = this.maxRows();\n    \n    // Save current value\n    const currentValue = textarea.value;\n    \n    // Clear content to measure single row height\n    textarea.value = '';\n    textarea.style.height = 'auto';\n    \n    // Get computed styles to account for padding\n    const computedStyle = window.getComputedStyle(textarea);\n    const paddingTop = parseFloat(computedStyle.paddingTop);\n    const paddingBottom = parseFloat(computedStyle.paddingBottom);\n    \n    // Calculate actual content height (without padding)\n    const contentHeight = textarea.scrollHeight - paddingTop - paddingBottom;\n    \n    // Calculate max height: content height for maxRows + padding\n    const calculatedMaxHeight = contentHeight * maxRowsValue + paddingTop + paddingBottom;\n    this.maxHeight.set(calculatedMaxHeight);\n    \n    // Restore original value\n    textarea.value = currentValue;\n    \n    // Adjust height after calculating maxHeight\n    if (currentValue) {\n      this.adjustHeight();\n    }\n  }\n  \n  private adjustHeight(): void {\n    const textarea = this.elementRef.nativeElement;\n    const maxHeightValue = this.maxHeight();\n    \n    if (maxHeightValue > 0) {\n      textarea.style.height = 'auto';\n      textarea.style.height = `${Math.min(textarea.scrollHeight, maxHeightValue)}px`;\n    }\n  }\n  \n  /**\n   * Public method to focus the textarea\n   */\n  focus(): void {\n    this.elementRef.nativeElement.focus();\n  }\n  \n  /**\n   * Public method to get current value\n   */\n  getValue(): string {\n    return this.value();\n  }\n  \n  /**\n   * Public method to set value programmatically\n   */\n  setValue(value: string): void {\n    this.value.set(value);\n    this.valueChange.emit(value);\n    \n    if (this.chatConfig) {\n      this.chatConfig.setInputValue(value);\n    }\n    \n    setTimeout(() => this.adjustHeight());\n  }\n}\n"]}
|
|
188
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"copilot-chat-textarea.component.js","sourceRoot":"","sources":["../../../../src/components/chat/copilot-chat-textarea.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  ElementRef,\n  AfterViewInit,\n  OnChanges,\n  SimpleChanges,\n  signal,\n  computed,\n  effect,\n  inject,\n  ChangeDetectionStrategy,\n  ViewEncapsulation\n} from '@angular/core';\nimport { CopilotChatConfigurationService } from '../../core/chat-configuration/chat-configuration.service';\nimport { cn } from '../../lib/utils';\n\n@Component({\n  selector: 'textarea[copilotChatTextarea]',\n  standalone: true,\n  imports: [],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  host: {\n    '[value]': 'value()',\n    '[placeholder]': 'placeholder()',\n    '[disabled]': 'disabled()',\n    '[class]': 'computedClass()',\n    '[style.max-height.px]': 'maxHeight()',\n    '[style.overflow]': \"'auto'\",\n    '[style.resize]': \"'none'\",\n    '(input)': 'onInput($event)',\n    '(keydown)': 'onKeyDown($event)',\n    '[attr.rows]': '1'\n  },\n  template: '',\n  styles: []\n})\nexport class CopilotChatTextareaComponent implements AfterViewInit, OnChanges {\n  private elementRef = inject(ElementRef<HTMLTextAreaElement>);\n  get textareaRef() { return this.elementRef; }\n  \n  @Input() set inputValue(val: string | undefined) {\n    this.value.set(val || '');\n  }\n  @Input() set inputPlaceholder(val: string | undefined) {\n    this.customPlaceholder.set(val);\n  }\n  @Input() set inputMaxRows(val: number | undefined) {\n    this.maxRows.set(val || 5);\n  }\n  @Input() set inputAutoFocus(val: boolean | undefined) {\n    this.autoFocus.set(val ?? true);\n  }\n  @Input() set inputDisabled(val: boolean | undefined) {\n    this.disabled.set(val || false);\n  }\n  @Input() set inputClass(val: string | undefined) {\n    this.customClass.set(val);\n  }\n  \n  @Output() valueChange = new EventEmitter<string>();\n  @Output() keyDown = new EventEmitter<KeyboardEvent>();\n  \n  private chatConfig = inject(CopilotChatConfigurationService);\n  \n  // Signals for reactive state\n  value = signal<string>('');\n  customPlaceholder = signal<string | undefined>(undefined);\n  maxRows = signal<number>(5);\n  autoFocus = signal<boolean>(true);\n  disabled = signal<boolean>(false);\n  customClass = signal<string | undefined>(undefined);\n  maxHeight = signal<number>(0);\n  \n  // Computed values\n  placeholder = computed(() => {\n    return this.customPlaceholder() || this.chatConfig.labels().chatInputPlaceholder;\n  });\n  \n  computedClass = computed(() => {\n    const baseClasses = cn(\n      // Layout and sizing\n      'w-full p-5 pb-0',\n      // Behavior\n      'outline-none resize-none',\n      // Background\n      'bg-transparent',\n      // Typography\n      'antialiased font-regular leading-relaxed text-[16px]',\n      // Placeholder styles\n      'placeholder:text-[#00000077] dark:placeholder:text-[#fffc]'\n    );\n    return cn(baseClasses, this.customClass());\n  });\n  \n  constructor() {\n    // Effect to sync value with chat configuration if available\n    effect(\n      () => {\n        const configValue = this.chatConfig.inputValue();\n        if (configValue !== undefined && !this.customPlaceholder()) {\n          this.value.set(configValue);\n        }\n      },\n      { allowSignalWrites: true }\n    );\n  }\n  \n  ngAfterViewInit(): void {\n    this.calculateMaxHeight();\n    this.adjustHeight();\n    \n    if (this.autoFocus()) {\n      setTimeout(() => {\n        this.elementRef.nativeElement.focus();\n      });\n    }\n  }\n  \n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['inputMaxRows']) {\n      this.calculateMaxHeight();\n    }\n  }\n  \n  onInput(event: Event): void {\n    const textarea = event.target as HTMLTextAreaElement;\n    const newValue = textarea.value;\n    \n    this.value.set(newValue);\n    this.valueChange.emit(newValue);\n    \n    // Update chat configuration if available\n    if (this.chatConfig) {\n      this.chatConfig.setInputValue(newValue);\n    }\n    \n    this.adjustHeight();\n  }\n  \n  onKeyDown(event: KeyboardEvent): void {\n    // Check for Enter key without Shift\n    if (event.key === 'Enter' && !event.shiftKey) {\n      event.preventDefault();\n      this.keyDown.emit(event);\n    } else {\n      this.keyDown.emit(event);\n    }\n  }\n  \n  private calculateMaxHeight(): void {\n    const textarea = this.elementRef.nativeElement;\n    const maxRowsValue = this.maxRows();\n    \n    // Save current value\n    const currentValue = textarea.value;\n    \n    // Clear content to measure single row height\n    textarea.value = '';\n    textarea.style.height = 'auto';\n    \n    // Get computed styles to account for padding\n    const computedStyle = window.getComputedStyle(textarea);\n    const paddingTop = parseFloat(computedStyle.paddingTop);\n    const paddingBottom = parseFloat(computedStyle.paddingBottom);\n    \n    // Calculate actual content height (without padding)\n    const contentHeight = textarea.scrollHeight - paddingTop - paddingBottom;\n    \n    // Calculate max height: content height for maxRows + padding\n    const calculatedMaxHeight = contentHeight * maxRowsValue + paddingTop + paddingBottom;\n    this.maxHeight.set(calculatedMaxHeight);\n    \n    // Restore original value\n    textarea.value = currentValue;\n    \n    // Adjust height after calculating maxHeight\n    if (currentValue) {\n      this.adjustHeight();\n    }\n  }\n  \n  private adjustHeight(): void {\n    const textarea = this.elementRef.nativeElement;\n    const maxHeightValue = this.maxHeight();\n    \n    if (maxHeightValue > 0) {\n      textarea.style.height = 'auto';\n      textarea.style.height = `${Math.min(textarea.scrollHeight, maxHeightValue)}px`;\n    }\n  }\n  \n  /**\n   * Public method to focus the textarea\n   */\n  focus(): void {\n    this.elementRef.nativeElement.focus();\n  }\n  \n  /**\n   * Public method to get current value\n   */\n  getValue(): string {\n    return this.value();\n  }\n  \n  /**\n   * Public method to set value programmatically\n   */\n  setValue(value: string): void {\n    this.value.set(value);\n    this.valueChange.emit(value);\n    \n    if (this.chatConfig) {\n      this.chatConfig.setInputValue(value);\n    }\n    \n    setTimeout(() => this.adjustHeight());\n  }\n}\n"]}
|