@copilotkitnext/angular 0.0.2 → 0.0.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (173) hide show
  1. package/README.md +3 -3
  2. package/dist/README.md +3 -3
  3. package/dist/components/chat/copilot-chat-assistant-message.component.d.ts +10 -10
  4. package/dist/components/chat/copilot-chat-message-view.component.d.ts +42 -42
  5. package/dist/components/chat/copilot-chat-view.component.d.ts +14 -14
  6. package/dist/core/copilotkit.providers.d.ts +1 -1
  7. package/dist/core/copilotkit.service.d.ts +5 -5
  8. package/dist/core/copilotkit.types.d.ts +8 -10
  9. package/dist/directives/copilotkit-frontend-tool.directive.d.ts +1 -1
  10. package/dist/esm2022/components/chat/copilot-chat-assistant-message-buttons.component.mjs +384 -0
  11. package/dist/esm2022/components/chat/copilot-chat-assistant-message-renderer.component.mjs +286 -0
  12. package/dist/esm2022/components/chat/copilot-chat-assistant-message-toolbar.component.mjs +27 -0
  13. package/dist/esm2022/components/chat/copilot-chat-assistant-message.component.mjs +433 -0
  14. package/dist/esm2022/components/chat/copilot-chat-assistant-message.types.mjs +2 -0
  15. package/dist/esm2022/components/chat/copilot-chat-audio-recorder.component.mjs +202 -0
  16. package/dist/esm2022/components/chat/copilot-chat-buttons.component.mjs +321 -0
  17. package/dist/esm2022/components/chat/copilot-chat-input-defaults.mjs +38 -0
  18. package/dist/esm2022/components/chat/copilot-chat-input.component.mjs +666 -0
  19. package/dist/esm2022/components/chat/copilot-chat-input.types.mjs +10 -0
  20. package/dist/esm2022/components/chat/copilot-chat-message-view-cursor.component.mjs +45 -0
  21. package/dist/esm2022/components/chat/copilot-chat-message-view.component.mjs +296 -0
  22. package/dist/esm2022/components/chat/copilot-chat-message-view.types.mjs +2 -0
  23. package/dist/esm2022/components/chat/copilot-chat-textarea.component.mjs +188 -0
  24. package/dist/esm2022/components/chat/copilot-chat-tool-calls-view.component.mjs +216 -0
  25. package/dist/esm2022/components/chat/copilot-chat-toolbar.component.mjs +25 -0
  26. package/dist/esm2022/components/chat/copilot-chat-tools-menu.component.mjs +199 -0
  27. package/dist/esm2022/components/chat/copilot-chat-user-message-branch-navigation.component.mjs +137 -0
  28. package/dist/esm2022/components/chat/copilot-chat-user-message-buttons.component.mjs +207 -0
  29. package/dist/esm2022/components/chat/copilot-chat-user-message-renderer.component.mjs +35 -0
  30. package/dist/esm2022/components/chat/copilot-chat-user-message-toolbar.component.mjs +34 -0
  31. package/dist/esm2022/components/chat/copilot-chat-user-message.component.mjs +341 -0
  32. package/dist/esm2022/components/chat/copilot-chat-user-message.types.mjs +2 -0
  33. package/dist/esm2022/components/chat/copilot-chat-view-disclaimer.component.mjs +52 -0
  34. package/dist/esm2022/components/chat/copilot-chat-view-feather.component.mjs +55 -0
  35. package/dist/esm2022/components/chat/copilot-chat-view-handlers.service.mjs +19 -0
  36. package/dist/esm2022/components/chat/copilot-chat-view-input-container.component.mjs +110 -0
  37. package/dist/esm2022/components/chat/copilot-chat-view-scroll-to-bottom-button.component.mjs +93 -0
  38. package/dist/esm2022/components/chat/copilot-chat-view-scroll-view.component.mjs +443 -0
  39. package/dist/esm2022/components/chat/copilot-chat-view.component.mjs +479 -0
  40. package/dist/esm2022/components/chat/copilot-chat-view.types.mjs +2 -0
  41. package/dist/esm2022/components/chat/copilot-chat.component.mjs +214 -0
  42. package/dist/esm2022/components/copilotkit-tool-render.component.mjs +153 -0
  43. package/dist/esm2022/copilotkitnext-angular.mjs +5 -0
  44. package/dist/esm2022/core/chat-configuration/chat-configuration.providers.mjs +65 -0
  45. package/dist/esm2022/core/chat-configuration/chat-configuration.service.mjs +145 -0
  46. package/dist/esm2022/core/chat-configuration/chat-configuration.types.mjs +26 -0
  47. package/dist/esm2022/core/copilotkit.providers.mjs +34 -0
  48. package/dist/esm2022/core/copilotkit.service.mjs +426 -0
  49. package/dist/esm2022/core/copilotkit.types.mjs +13 -0
  50. package/dist/esm2022/directives/copilotkit-agent-context.directive.mjs +130 -0
  51. package/dist/esm2022/directives/copilotkit-agent.directive.mjs +217 -0
  52. package/dist/esm2022/directives/copilotkit-chat-config.directive.mjs +218 -0
  53. package/dist/esm2022/directives/copilotkit-config.directive.mjs +94 -0
  54. package/dist/esm2022/directives/copilotkit-frontend-tool.directive.mjs +128 -0
  55. package/dist/esm2022/directives/copilotkit-human-in-the-loop.directive.mjs +265 -0
  56. package/dist/esm2022/directives/stick-to-bottom.directive.mjs +181 -0
  57. package/dist/esm2022/index.mjs +70 -0
  58. package/dist/esm2022/lib/directives/tooltip.directive.mjs +211 -0
  59. package/dist/esm2022/lib/slots/copilot-slot.component.mjs +144 -0
  60. package/dist/esm2022/lib/slots/slot.types.mjs +6 -0
  61. package/dist/esm2022/lib/slots/slot.utils.mjs +222 -0
  62. package/dist/esm2022/lib/utils.mjs +10 -0
  63. package/dist/esm2022/services/resize-observer.service.mjs +152 -0
  64. package/dist/esm2022/services/scroll-position.service.mjs +124 -0
  65. package/dist/esm2022/types/frontend-tool.mjs +2 -0
  66. package/dist/esm2022/types/human-in-the-loop.mjs +2 -0
  67. package/dist/esm2022/utils/agent-context.utils.mjs +114 -0
  68. package/dist/esm2022/utils/agent.utils.mjs +204 -0
  69. package/dist/esm2022/utils/chat-config.utils.mjs +186 -0
  70. package/dist/esm2022/utils/copilotkit.utils.mjs +20 -0
  71. package/dist/esm2022/utils/frontend-tool.utils.mjs +224 -0
  72. package/dist/esm2022/utils/human-in-the-loop.utils.mjs +293 -0
  73. package/dist/fesm2022/copilotkitnext-angular.mjs +174 -187
  74. package/dist/fesm2022/copilotkitnext-angular.mjs.map +1 -1
  75. package/dist/utils/frontend-tool.utils.d.ts +1 -1
  76. package/package.json +23 -20
  77. package/vitest.config.mts +32 -21
  78. package/.turbo/turbo-build.log +0 -38
  79. package/.turbo/turbo-check-types.log +0 -0
  80. package/.turbo/turbo-test.log +0 -71
  81. package/ng-package.json +0 -19
  82. package/src/components/chat/__tests__/copilot-chat-assistant-message.component.spec.ts +0 -282
  83. package/src/components/chat/__tests__/copilot-chat-input.component.spec.ts +0 -419
  84. package/src/components/chat/__tests__/copilot-chat-message-view.component.spec.ts +0 -372
  85. package/src/components/chat/__tests__/copilot-chat-user-message.component.spec.ts +0 -249
  86. package/src/components/chat/copilot-chat-assistant-message-buttons.component.ts +0 -292
  87. package/src/components/chat/copilot-chat-assistant-message-renderer.component.ts +0 -472
  88. package/src/components/chat/copilot-chat-assistant-message-toolbar.component.ts +0 -29
  89. package/src/components/chat/copilot-chat-assistant-message.component.ts +0 -463
  90. package/src/components/chat/copilot-chat-assistant-message.types.ts +0 -50
  91. package/src/components/chat/copilot-chat-audio-recorder.component.ts +0 -241
  92. package/src/components/chat/copilot-chat-buttons.component.ts +0 -308
  93. package/src/components/chat/copilot-chat-buttons.component.ts.bak +0 -471
  94. package/src/components/chat/copilot-chat-input-defaults.ts +0 -47
  95. package/src/components/chat/copilot-chat-input.component.ts +0 -512
  96. package/src/components/chat/copilot-chat-input.types.ts +0 -148
  97. package/src/components/chat/copilot-chat-message-view-cursor.component.ts +0 -51
  98. package/src/components/chat/copilot-chat-message-view.component.ts +0 -233
  99. package/src/components/chat/copilot-chat-message-view.types.ts +0 -39
  100. package/src/components/chat/copilot-chat-textarea.component.ts +0 -220
  101. package/src/components/chat/copilot-chat-tool-calls-view.component.ts +0 -261
  102. package/src/components/chat/copilot-chat-toolbar.component.ts +0 -35
  103. package/src/components/chat/copilot-chat-tools-menu.component.ts +0 -185
  104. package/src/components/chat/copilot-chat-user-message-branch-navigation.component.ts +0 -121
  105. package/src/components/chat/copilot-chat-user-message-buttons.component.ts +0 -170
  106. package/src/components/chat/copilot-chat-user-message-renderer.component.ts +0 -37
  107. package/src/components/chat/copilot-chat-user-message-toolbar.component.ts +0 -37
  108. package/src/components/chat/copilot-chat-user-message.component.ts +0 -247
  109. package/src/components/chat/copilot-chat-user-message.types.ts +0 -42
  110. package/src/components/chat/copilot-chat-view-disclaimer.component.ts +0 -51
  111. package/src/components/chat/copilot-chat-view-feather.component.ts +0 -47
  112. package/src/components/chat/copilot-chat-view-handlers.service.ts +0 -14
  113. package/src/components/chat/copilot-chat-view-input-container.component.ts +0 -87
  114. package/src/components/chat/copilot-chat-view-scroll-to-bottom-button.component.ts +0 -79
  115. package/src/components/chat/copilot-chat-view-scroll-view.component.ts +0 -322
  116. package/src/components/chat/copilot-chat-view.component.ts +0 -420
  117. package/src/components/chat/copilot-chat-view.types.ts +0 -52
  118. package/src/components/chat/copilot-chat.component.ts +0 -232
  119. package/src/components/copilotkit-tool-render.component.ts +0 -169
  120. package/src/core/__tests__/copilotkit.service.spec.ts +0 -1051
  121. package/src/core/__tests__/copilotkit.service.wildcard.spec.ts +0 -316
  122. package/src/core/chat-configuration/__tests__/chat-configuration.service.spec.ts +0 -287
  123. package/src/core/chat-configuration/chat-configuration.providers.ts +0 -71
  124. package/src/core/chat-configuration/chat-configuration.service.ts +0 -162
  125. package/src/core/chat-configuration/chat-configuration.types.ts +0 -57
  126. package/src/core/copilotkit.providers.ts +0 -59
  127. package/src/core/copilotkit.service.ts +0 -542
  128. package/src/core/copilotkit.types.ts +0 -132
  129. package/src/directives/__tests__/copilotkit-agent-context.directive.spec.ts +0 -384
  130. package/src/directives/__tests__/copilotkit-agent.directive.spec.ts +0 -253
  131. package/src/directives/__tests__/copilotkit-chat-config.directive.spec.ts +0 -385
  132. package/src/directives/__tests__/copilotkit-config.directive.spec.ts +0 -69
  133. package/src/directives/__tests__/copilotkit-frontend-tool-simple.directive.spec.ts +0 -60
  134. package/src/directives/__tests__/copilotkit-frontend-tool.directive.spec.ts +0 -108
  135. package/src/directives/__tests__/copilotkit-human-in-the-loop.directive.spec.ts +0 -452
  136. package/src/directives/copilotkit-agent-context.directive.ts +0 -138
  137. package/src/directives/copilotkit-agent.directive.ts +0 -225
  138. package/src/directives/copilotkit-chat-config.directive.ts +0 -241
  139. package/src/directives/copilotkit-config.directive.ts +0 -81
  140. package/src/directives/copilotkit-frontend-tool.directive.ts +0 -145
  141. package/src/directives/copilotkit-human-in-the-loop.directive.ts +0 -281
  142. package/src/directives/stick-to-bottom.directive.ts +0 -204
  143. package/src/index.ts +0 -105
  144. package/src/lib/directives/tooltip.directive.ts +0 -292
  145. package/src/lib/slots/__tests__/slot.utils.spec.ts +0 -377
  146. package/src/lib/slots/copilot-slot.component.ts +0 -135
  147. package/src/lib/slots/index.ts +0 -3
  148. package/src/lib/slots/slot.types.ts +0 -64
  149. package/src/lib/slots/slot.utils.ts +0 -289
  150. package/src/lib/utils.ts +0 -10
  151. package/src/public-api.ts +0 -1
  152. package/src/services/resize-observer.service.ts +0 -181
  153. package/src/services/scroll-position.service.ts +0 -169
  154. package/src/styles/globals.css +0 -266
  155. package/src/styles/index.css +0 -3
  156. package/src/test-setup.ts +0 -15
  157. package/src/testing/index.ts +0 -3
  158. package/src/testing/testing.utils.ts +0 -248
  159. package/src/types/frontend-tool.ts +0 -44
  160. package/src/types/human-in-the-loop.ts +0 -52
  161. package/src/utils/__tests__/agent.utils.spec.ts +0 -234
  162. package/src/utils/__tests__/chat-config.utils.spec.ts +0 -306
  163. package/src/utils/__tests__/frontend-tool-inject.spec.ts +0 -350
  164. package/src/utils/__tests__/frontend-tool-integration.spec.ts +0 -199
  165. package/src/utils/__tests__/frontend-tool.utils.spec.ts +0 -272
  166. package/src/utils/__tests__/human-in-the-loop.utils.spec.ts +0 -365
  167. package/src/utils/agent-context.utils.ts +0 -133
  168. package/src/utils/agent.utils.ts +0 -239
  169. package/src/utils/chat-config.utils.ts +0 -221
  170. package/src/utils/copilotkit.utils.ts +0 -20
  171. package/src/utils/frontend-tool.utils.ts +0 -266
  172. package/src/utils/human-in-the-loop.utils.ts +0 -359
  173. package/tsconfig.spec.json +0 -12
@@ -0,0 +1,666 @@
1
+ import { Component, Input, Output, EventEmitter, ViewChild, TemplateRef, signal, computed, effect, inject, ChangeDetectionStrategy, ViewEncapsulation, ContentChild } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { CopilotSlotComponent } from '../../lib/slots/copilot-slot.component';
4
+ import { CopilotChatConfigurationService } from '../../core/chat-configuration/chat-configuration.service';
5
+ import { LucideAngularModule, ArrowUp } from 'lucide-angular';
6
+ import { CopilotChatTextareaComponent } from './copilot-chat-textarea.component';
7
+ import { CopilotChatAudioRecorderComponent } from './copilot-chat-audio-recorder.component';
8
+ import { CopilotChatSendButtonComponent, CopilotChatStartTranscribeButtonComponent, CopilotChatCancelTranscribeButtonComponent, CopilotChatFinishTranscribeButtonComponent, CopilotChatAddFileButtonComponent } from './copilot-chat-buttons.component';
9
+ import { CopilotChatToolbarComponent } from './copilot-chat-toolbar.component';
10
+ import { CopilotChatToolsMenuComponent } from './copilot-chat-tools-menu.component';
11
+ import { cn } from '../../lib/utils';
12
+ import * as i0 from "@angular/core";
13
+ import * as i1 from "@angular/common";
14
+ import * as i2 from "lucide-angular";
15
+ export class CopilotChatInputComponent {
16
+ textAreaRef;
17
+ audioRecorderRef;
18
+ // Capture templates from content projection
19
+ sendButtonTemplate;
20
+ toolbarTemplate;
21
+ textAreaTemplate;
22
+ audioRecorderTemplate;
23
+ startTranscribeButtonTemplate;
24
+ cancelTranscribeButtonTemplate;
25
+ finishTranscribeButtonTemplate;
26
+ addFileButtonTemplate;
27
+ toolsButtonTemplate;
28
+ // Class inputs for styling default components
29
+ sendButtonClass;
30
+ toolbarClass;
31
+ textAreaClass;
32
+ textAreaMaxRows;
33
+ textAreaPlaceholder;
34
+ audioRecorderClass;
35
+ startTranscribeButtonClass;
36
+ cancelTranscribeButtonClass;
37
+ finishTranscribeButtonClass;
38
+ addFileButtonClass;
39
+ toolsButtonClass;
40
+ // Component inputs for overrides
41
+ sendButtonComponent;
42
+ toolbarComponent;
43
+ textAreaComponent;
44
+ audioRecorderComponent;
45
+ startTranscribeButtonComponent;
46
+ cancelTranscribeButtonComponent;
47
+ finishTranscribeButtonComponent;
48
+ addFileButtonComponent;
49
+ toolsButtonComponent;
50
+ // Regular inputs
51
+ set mode(val) {
52
+ this.modeSignal.set(val || 'input');
53
+ }
54
+ set toolsMenu(val) {
55
+ this.toolsMenuSignal.set(val || []);
56
+ }
57
+ set autoFocus(val) {
58
+ this.autoFocusSignal.set(val ?? true);
59
+ }
60
+ set value(val) {
61
+ this.valueSignal.set(val || '');
62
+ }
63
+ set inputClass(val) {
64
+ this.customClass.set(val);
65
+ }
66
+ // Note: Prefer host `class` for styling this component;
67
+ // keep only `inputClass` to style the internal wrapper if needed.
68
+ additionalToolbarItems;
69
+ // Output events
70
+ submitMessage = new EventEmitter();
71
+ startTranscribe = new EventEmitter();
72
+ cancelTranscribe = new EventEmitter();
73
+ finishTranscribe = new EventEmitter();
74
+ addFile = new EventEmitter();
75
+ valueChange = new EventEmitter();
76
+ // Icons and default classes
77
+ ArrowUpIcon = ArrowUp;
78
+ defaultButtonClass = cn(
79
+ // Base button styles
80
+ 'inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium', 'transition-all disabled:pointer-events-none disabled:opacity-50', 'shrink-0 outline-none', 'focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px]',
81
+ // chatInputToolbarPrimary variant
82
+ 'cursor-pointer', 'bg-black text-white', 'dark:bg-white dark:text-black dark:focus-visible:outline-white', 'rounded-full h-9 w-9', 'transition-colors', 'focus:outline-none', 'hover:opacity-70 disabled:hover:opacity-100', 'disabled:cursor-not-allowed disabled:bg-[#00000014] disabled:text-[rgb(13,13,13)]', 'dark:disabled:bg-[#454545] dark:disabled:text-white');
83
+ // Services
84
+ chatConfig = inject(CopilotChatConfigurationService, { optional: true });
85
+ // Signals
86
+ modeSignal = signal('input');
87
+ toolsMenuSignal = signal([]);
88
+ autoFocusSignal = signal(true);
89
+ valueSignal = signal('');
90
+ customClass = signal(undefined);
91
+ // Default components
92
+ // Note: CopilotChatTextareaComponent uses attribute selector but is a component
93
+ defaultAudioRecorder = CopilotChatAudioRecorderComponent;
94
+ defaultSendButton = null; // Will be set to avoid circular dependency
95
+ CopilotChatToolbarComponent = CopilotChatToolbarComponent;
96
+ CopilotChatAddFileButtonComponent = CopilotChatAddFileButtonComponent;
97
+ CopilotChatToolsMenuComponent = CopilotChatToolsMenuComponent;
98
+ CopilotChatCancelTranscribeButtonComponent = CopilotChatCancelTranscribeButtonComponent;
99
+ CopilotChatFinishTranscribeButtonComponent = CopilotChatFinishTranscribeButtonComponent;
100
+ CopilotChatStartTranscribeButtonComponent = CopilotChatStartTranscribeButtonComponent;
101
+ // Computed values
102
+ computedMode = computed(() => this.modeSignal());
103
+ computedToolsMenu = computed(() => this.toolsMenuSignal());
104
+ computedAutoFocus = computed(() => this.autoFocusSignal());
105
+ computedValue = computed(() => {
106
+ const customValue = this.valueSignal();
107
+ const configValue = this.chatConfig?.inputValue();
108
+ return customValue || configValue || '';
109
+ });
110
+ computedClass = computed(() => {
111
+ const baseClasses = cn(
112
+ // Layout
113
+ 'flex w-full flex-col items-center justify-center',
114
+ // Interaction
115
+ 'cursor-text',
116
+ // Overflow and clipping
117
+ 'overflow-visible bg-clip-padding contain-inline-size',
118
+ // Background
119
+ 'bg-white dark:bg-[#303030]',
120
+ // Visual effects
121
+ 'shadow-[0_4px_4px_0_#0000000a,0_0_1px_0_#0000009e] rounded-[28px]');
122
+ return cn(baseClasses, this.customClass());
123
+ });
124
+ // Context for slots (reactive via signals)
125
+ sendButtonContext = computed(() => ({
126
+ send: () => this.send(),
127
+ disabled: !this.computedValue().trim() || this.computedMode() === 'processing',
128
+ value: this.computedValue()
129
+ }));
130
+ toolbarContext = computed(() => ({
131
+ mode: this.computedMode(),
132
+ value: this.computedValue()
133
+ }));
134
+ textAreaContext = computed(() => ({
135
+ value: this.computedValue(),
136
+ autoFocus: this.computedAutoFocus(),
137
+ disabled: this.computedMode() === 'processing',
138
+ maxRows: this.textAreaMaxRows,
139
+ placeholder: this.textAreaPlaceholder,
140
+ inputClass: this.textAreaClass,
141
+ onKeyDown: (event) => this.handleKeyDown(event),
142
+ onChange: (value) => this.handleValueChange(value)
143
+ }));
144
+ audioRecorderContext = computed(() => ({
145
+ inputShowControls: true
146
+ }));
147
+ // Button contexts removed - now using outputs map for click handlers
148
+ toolsContext = computed(() => ({
149
+ inputToolsMenu: this.computedToolsMenu(),
150
+ inputDisabled: this.computedMode() === 'transcribe'
151
+ }));
152
+ constructor() {
153
+ // Effect to handle mode changes
154
+ effect(() => {
155
+ const currentMode = this.computedMode();
156
+ if (currentMode === 'transcribe' && this.audioRecorderRef) {
157
+ this.audioRecorderRef.start().catch(console.error);
158
+ }
159
+ else if (this.audioRecorderRef?.getState() === 'recording') {
160
+ this.audioRecorderRef.stop().catch(console.error);
161
+ }
162
+ });
163
+ // Sync with chat configuration
164
+ effect(() => {
165
+ const configValue = this.chatConfig?.inputValue();
166
+ if (configValue !== undefined && !this.valueSignal()) {
167
+ this.valueSignal.set(configValue);
168
+ }
169
+ }, { allowSignalWrites: true });
170
+ }
171
+ // Output maps for slots
172
+ addFileButtonOutputs = { clicked: () => this.handleAddFile() };
173
+ cancelTranscribeButtonOutputs = { clicked: () => this.handleCancelTranscribe() };
174
+ finishTranscribeButtonOutputs = { clicked: () => this.handleFinishTranscribe() };
175
+ startTranscribeButtonOutputs = { clicked: () => this.handleStartTranscribe() };
176
+ // Support both `clicked` (idiomatic in our slots) and `click` (legacy)
177
+ sendButtonOutputs = { clicked: () => this.send(), click: () => this.send() };
178
+ ngAfterViewInit() {
179
+ // Auto-focus if needed
180
+ if (this.computedAutoFocus() && this.textAreaRef) {
181
+ setTimeout(() => {
182
+ this.textAreaRef?.focus();
183
+ });
184
+ }
185
+ }
186
+ ngOnDestroy() {
187
+ // Clean up any resources
188
+ if (this.audioRecorderRef?.getState() === 'recording') {
189
+ this.audioRecorderRef.stop().catch(console.error);
190
+ }
191
+ }
192
+ handleKeyDown(event) {
193
+ if (event.key === 'Enter' && !event.shiftKey) {
194
+ event.preventDefault();
195
+ this.send();
196
+ }
197
+ }
198
+ handleValueChange(value) {
199
+ this.valueSignal.set(value);
200
+ this.valueChange.emit(value);
201
+ if (this.chatConfig) {
202
+ this.chatConfig.setInputValue(value);
203
+ }
204
+ }
205
+ send() {
206
+ const trimmed = this.computedValue().trim();
207
+ if (trimmed) {
208
+ this.submitMessage.emit(trimmed);
209
+ // Use chat config handler if available
210
+ if (this.chatConfig) {
211
+ this.chatConfig.submitInput(trimmed);
212
+ }
213
+ // Clear input
214
+ this.valueSignal.set('');
215
+ if (this.textAreaRef) {
216
+ this.textAreaRef.setValue('');
217
+ }
218
+ // Refocus input
219
+ if (this.textAreaRef) {
220
+ setTimeout(() => {
221
+ this.textAreaRef?.focus();
222
+ });
223
+ }
224
+ }
225
+ }
226
+ handleStartTranscribe() {
227
+ this.startTranscribe.emit();
228
+ this.modeSignal.set('transcribe');
229
+ }
230
+ handleCancelTranscribe() {
231
+ this.cancelTranscribe.emit();
232
+ this.modeSignal.set('input');
233
+ }
234
+ handleFinishTranscribe() {
235
+ this.finishTranscribe.emit();
236
+ this.modeSignal.set('input');
237
+ }
238
+ handleAddFile() {
239
+ this.addFile.emit();
240
+ }
241
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CopilotChatInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
242
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: CopilotChatInputComponent, isStandalone: true, selector: "copilot-chat-input", inputs: { sendButtonClass: "sendButtonClass", toolbarClass: "toolbarClass", textAreaClass: "textAreaClass", textAreaMaxRows: "textAreaMaxRows", textAreaPlaceholder: "textAreaPlaceholder", audioRecorderClass: "audioRecorderClass", startTranscribeButtonClass: "startTranscribeButtonClass", cancelTranscribeButtonClass: "cancelTranscribeButtonClass", finishTranscribeButtonClass: "finishTranscribeButtonClass", addFileButtonClass: "addFileButtonClass", toolsButtonClass: "toolsButtonClass", sendButtonComponent: "sendButtonComponent", toolbarComponent: "toolbarComponent", textAreaComponent: "textAreaComponent", audioRecorderComponent: "audioRecorderComponent", startTranscribeButtonComponent: "startTranscribeButtonComponent", cancelTranscribeButtonComponent: "cancelTranscribeButtonComponent", finishTranscribeButtonComponent: "finishTranscribeButtonComponent", addFileButtonComponent: "addFileButtonComponent", toolsButtonComponent: "toolsButtonComponent", mode: "mode", toolsMenu: "toolsMenu", autoFocus: "autoFocus", value: "value", inputClass: "inputClass", additionalToolbarItems: "additionalToolbarItems" }, outputs: { submitMessage: "submitMessage", startTranscribe: "startTranscribe", cancelTranscribe: "cancelTranscribe", finishTranscribe: "finishTranscribe", addFile: "addFile", valueChange: "valueChange" }, queries: [{ propertyName: "sendButtonTemplate", first: true, predicate: ["sendButton"], descendants: true, read: TemplateRef }, { propertyName: "toolbarTemplate", first: true, predicate: ["toolbar"], descendants: true, read: TemplateRef }, { propertyName: "textAreaTemplate", first: true, predicate: ["textArea"], descendants: true, read: TemplateRef }, { propertyName: "audioRecorderTemplate", first: true, predicate: ["audioRecorder"], descendants: true, read: TemplateRef }, { propertyName: "startTranscribeButtonTemplate", first: true, predicate: ["startTranscribeButton"], descendants: true, read: TemplateRef }, { propertyName: "cancelTranscribeButtonTemplate", first: true, predicate: ["cancelTranscribeButton"], descendants: true, read: TemplateRef }, { propertyName: "finishTranscribeButtonTemplate", first: true, predicate: ["finishTranscribeButton"], descendants: true, read: TemplateRef }, { propertyName: "addFileButtonTemplate", first: true, predicate: ["addFileButton"], descendants: true, read: TemplateRef }, { propertyName: "toolsButtonTemplate", first: true, predicate: ["toolsButton"], descendants: true, read: TemplateRef }], viewQueries: [{ propertyName: "textAreaRef", first: true, predicate: CopilotChatTextareaComponent, descendants: true, read: CopilotChatTextareaComponent }, { propertyName: "audioRecorderRef", first: true, predicate: CopilotChatAudioRecorderComponent, descendants: true }], ngImport: i0, template: `
243
+ <div [class]="computedClass()">
244
+ <!-- Main input area: either textarea or audio recorder -->
245
+ @if (computedMode() === 'transcribe') {
246
+ @if (audioRecorderTemplate || audioRecorderComponent) {
247
+ <copilot-slot
248
+ [slot]="audioRecorderTemplate || audioRecorderComponent"
249
+ [context]="audioRecorderContext()"
250
+ [defaultComponent]="defaultAudioRecorder"
251
+ >
252
+ </copilot-slot>
253
+ } @else {
254
+ <copilot-chat-audio-recorder
255
+ [inputShowControls]="true">
256
+ </copilot-chat-audio-recorder>
257
+ }
258
+ } @else {
259
+ @if (textAreaTemplate || textAreaComponent) {
260
+ <copilot-slot
261
+ [slot]="textAreaTemplate || textAreaComponent"
262
+ [context]="textAreaContext()"
263
+ >
264
+ </copilot-slot>
265
+ } @else {
266
+ <textarea copilotChatTextarea
267
+ [inputValue]="computedValue()"
268
+ [inputAutoFocus]="computedAutoFocus()"
269
+ [inputDisabled]="computedMode() === 'processing'"
270
+ [inputClass]="textAreaClass"
271
+ [inputMaxRows]="textAreaMaxRows"
272
+ [inputPlaceholder]="textAreaPlaceholder"
273
+ (keyDown)="handleKeyDown($event)"
274
+ (valueChange)="handleValueChange($event)"></textarea>
275
+ }
276
+ }
277
+
278
+ <!-- Toolbar -->
279
+ @if (toolbarTemplate || toolbarComponent) {
280
+ <copilot-slot
281
+ [slot]="toolbarTemplate || toolbarComponent"
282
+ [context]="toolbarContext()"
283
+ [defaultComponent]="CopilotChatToolbarComponent"
284
+ >
285
+ </copilot-slot>
286
+ } @else {
287
+ <div copilotChatToolbar>
288
+ <div class="flex items-center">
289
+ @if (addFile.observed) {
290
+ @if (addFileButtonTemplate || addFileButtonComponent) {
291
+ <copilot-slot
292
+ [slot]="addFileButtonTemplate || addFileButtonComponent"
293
+ [context]="{ inputDisabled: computedMode() === 'transcribe' }"
294
+ [outputs]="addFileButtonOutputs"
295
+ [defaultComponent]="CopilotChatAddFileButtonComponent"
296
+ >
297
+ </copilot-slot>
298
+ } @else {
299
+ <copilot-chat-add-file-button
300
+ [disabled]="computedMode() === 'transcribe'"
301
+ (clicked)="handleAddFile()">
302
+ </copilot-chat-add-file-button>
303
+ }
304
+ }
305
+ @if (computedToolsMenu().length > 0) {
306
+ @if (toolsButtonTemplate || toolsButtonComponent) {
307
+ <copilot-slot
308
+ [slot]="toolsButtonTemplate || toolsButtonComponent"
309
+ [context]="toolsContext()"
310
+ [defaultComponent]="CopilotChatToolsMenuComponent"
311
+ >
312
+ </copilot-slot>
313
+ } @else {
314
+ <copilot-chat-tools-menu
315
+ [inputToolsMenu]="computedToolsMenu()"
316
+ [inputDisabled]="computedMode() === 'transcribe'">
317
+ </copilot-chat-tools-menu>
318
+ }
319
+ }
320
+ @if (additionalToolbarItems) {
321
+ <ng-container *ngTemplateOutlet="additionalToolbarItems"></ng-container>
322
+ }
323
+ </div>
324
+ <div class="flex items-center">
325
+ @if (computedMode() === 'transcribe') {
326
+ @if (cancelTranscribe.observed) {
327
+ @if (cancelTranscribeButtonTemplate || cancelTranscribeButtonComponent) {
328
+ <copilot-slot
329
+ [slot]="cancelTranscribeButtonTemplate || cancelTranscribeButtonComponent"
330
+ [context]="{}"
331
+ [outputs]="cancelTranscribeButtonOutputs"
332
+ [defaultComponent]="CopilotChatCancelTranscribeButtonComponent"
333
+ >
334
+ </copilot-slot>
335
+ } @else {
336
+ <copilot-chat-cancel-transcribe-button
337
+ (clicked)="handleCancelTranscribe()">
338
+ </copilot-chat-cancel-transcribe-button>
339
+ }
340
+ }
341
+ @if (finishTranscribe.observed) {
342
+ @if (finishTranscribeButtonTemplate || finishTranscribeButtonComponent) {
343
+ <copilot-slot
344
+ [slot]="finishTranscribeButtonTemplate || finishTranscribeButtonComponent"
345
+ [context]="{}"
346
+ [outputs]="finishTranscribeButtonOutputs"
347
+ [defaultComponent]="CopilotChatFinishTranscribeButtonComponent"
348
+ >
349
+ </copilot-slot>
350
+ } @else {
351
+ <copilot-chat-finish-transcribe-button
352
+ (clicked)="handleFinishTranscribe()">
353
+ </copilot-chat-finish-transcribe-button>
354
+ }
355
+ }
356
+ } @else {
357
+ @if (startTranscribe.observed) {
358
+ @if (startTranscribeButtonTemplate || startTranscribeButtonComponent) {
359
+ <copilot-slot
360
+ [slot]="startTranscribeButtonTemplate || startTranscribeButtonComponent"
361
+ [context]="{}"
362
+ [outputs]="startTranscribeButtonOutputs"
363
+ [defaultComponent]="CopilotChatStartTranscribeButtonComponent"
364
+ >
365
+ </copilot-slot>
366
+ } @else {
367
+ <copilot-chat-start-transcribe-button
368
+ (clicked)="handleStartTranscribe()">
369
+ </copilot-chat-start-transcribe-button>
370
+ }
371
+ }
372
+ <!-- Send button with slot -->
373
+ @if (sendButtonTemplate || sendButtonComponent) {
374
+ <copilot-slot
375
+ [slot]="sendButtonTemplate || sendButtonComponent"
376
+ [context]="sendButtonContext()"
377
+ [outputs]="sendButtonOutputs"
378
+ >
379
+ </copilot-slot>
380
+ } @else {
381
+ <div class="mr-[10px]">
382
+ <button
383
+ type="button"
384
+ [class]="sendButtonClass || defaultButtonClass"
385
+ [disabled]="!computedValue().trim() || computedMode() === 'processing'"
386
+ (click)="send()">
387
+ <lucide-angular [img]="ArrowUpIcon" [size]="18"></lucide-angular>
388
+ </button>
389
+ </div>
390
+ }
391
+ }
392
+ </div>
393
+ </div>
394
+ }
395
+ </div>
396
+ `, isInline: true, styles: [":host{display:block;width:100%}.shadow-\\[0_4px_4px_0_\\#0000000a\\,_0_0_1px_0_\\#0000009e\\]{box-shadow:0 4px 4px #0000000a,0 0 1px #0000009e!important}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: CopilotSlotComponent, selector: "copilot-slot", inputs: ["slot", "context", "defaultComponent", "outputs"] }, { kind: "ngmodule", type: LucideAngularModule }, { kind: "component", type: i2.LucideAngularComponent, selector: "lucide-angular, lucide-icon, i-lucide, span-lucide", inputs: ["class", "name", "img", "color", "absoluteStrokeWidth", "size", "strokeWidth"] }, { kind: "component", type: CopilotChatTextareaComponent, selector: "textarea[copilotChatTextarea]", inputs: ["inputValue", "inputPlaceholder", "inputMaxRows", "inputAutoFocus", "inputDisabled", "inputClass"], outputs: ["valueChange", "keyDown"] }, { kind: "component", type: CopilotChatAudioRecorderComponent, selector: "copilot-chat-audio-recorder", inputs: ["inputClass", "inputShowControls"], outputs: ["stateChange", "error"] }, { kind: "component", type: CopilotChatStartTranscribeButtonComponent, selector: "copilot-chat-start-transcribe-button", inputs: ["disabled"], outputs: ["clicked"] }, { kind: "component", type: CopilotChatCancelTranscribeButtonComponent, selector: "copilot-chat-cancel-transcribe-button", inputs: ["disabled"], outputs: ["clicked"] }, { kind: "component", type: CopilotChatFinishTranscribeButtonComponent, selector: "copilot-chat-finish-transcribe-button", inputs: ["disabled"], outputs: ["clicked"] }, { kind: "component", type: CopilotChatAddFileButtonComponent, selector: "copilot-chat-add-file-button", inputs: ["disabled"], outputs: ["clicked"] }, { kind: "component", type: CopilotChatToolbarComponent, selector: "div[copilotChatToolbar]", inputs: ["inputClass"] }, { kind: "component", type: CopilotChatToolsMenuComponent, selector: "copilot-chat-tools-menu", inputs: ["inputToolsMenu", "inputDisabled", "inputClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
397
+ }
398
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CopilotChatInputComponent, decorators: [{
399
+ type: Component,
400
+ args: [{ selector: 'copilot-chat-input', standalone: true, imports: [
401
+ CommonModule,
402
+ CopilotSlotComponent,
403
+ LucideAngularModule,
404
+ CopilotChatTextareaComponent,
405
+ CopilotChatAudioRecorderComponent,
406
+ CopilotChatSendButtonComponent,
407
+ CopilotChatStartTranscribeButtonComponent,
408
+ CopilotChatCancelTranscribeButtonComponent,
409
+ CopilotChatFinishTranscribeButtonComponent,
410
+ CopilotChatAddFileButtonComponent,
411
+ CopilotChatToolbarComponent,
412
+ CopilotChatToolsMenuComponent
413
+ ], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: `
414
+ <div [class]="computedClass()">
415
+ <!-- Main input area: either textarea or audio recorder -->
416
+ @if (computedMode() === 'transcribe') {
417
+ @if (audioRecorderTemplate || audioRecorderComponent) {
418
+ <copilot-slot
419
+ [slot]="audioRecorderTemplate || audioRecorderComponent"
420
+ [context]="audioRecorderContext()"
421
+ [defaultComponent]="defaultAudioRecorder"
422
+ >
423
+ </copilot-slot>
424
+ } @else {
425
+ <copilot-chat-audio-recorder
426
+ [inputShowControls]="true">
427
+ </copilot-chat-audio-recorder>
428
+ }
429
+ } @else {
430
+ @if (textAreaTemplate || textAreaComponent) {
431
+ <copilot-slot
432
+ [slot]="textAreaTemplate || textAreaComponent"
433
+ [context]="textAreaContext()"
434
+ >
435
+ </copilot-slot>
436
+ } @else {
437
+ <textarea copilotChatTextarea
438
+ [inputValue]="computedValue()"
439
+ [inputAutoFocus]="computedAutoFocus()"
440
+ [inputDisabled]="computedMode() === 'processing'"
441
+ [inputClass]="textAreaClass"
442
+ [inputMaxRows]="textAreaMaxRows"
443
+ [inputPlaceholder]="textAreaPlaceholder"
444
+ (keyDown)="handleKeyDown($event)"
445
+ (valueChange)="handleValueChange($event)"></textarea>
446
+ }
447
+ }
448
+
449
+ <!-- Toolbar -->
450
+ @if (toolbarTemplate || toolbarComponent) {
451
+ <copilot-slot
452
+ [slot]="toolbarTemplate || toolbarComponent"
453
+ [context]="toolbarContext()"
454
+ [defaultComponent]="CopilotChatToolbarComponent"
455
+ >
456
+ </copilot-slot>
457
+ } @else {
458
+ <div copilotChatToolbar>
459
+ <div class="flex items-center">
460
+ @if (addFile.observed) {
461
+ @if (addFileButtonTemplate || addFileButtonComponent) {
462
+ <copilot-slot
463
+ [slot]="addFileButtonTemplate || addFileButtonComponent"
464
+ [context]="{ inputDisabled: computedMode() === 'transcribe' }"
465
+ [outputs]="addFileButtonOutputs"
466
+ [defaultComponent]="CopilotChatAddFileButtonComponent"
467
+ >
468
+ </copilot-slot>
469
+ } @else {
470
+ <copilot-chat-add-file-button
471
+ [disabled]="computedMode() === 'transcribe'"
472
+ (clicked)="handleAddFile()">
473
+ </copilot-chat-add-file-button>
474
+ }
475
+ }
476
+ @if (computedToolsMenu().length > 0) {
477
+ @if (toolsButtonTemplate || toolsButtonComponent) {
478
+ <copilot-slot
479
+ [slot]="toolsButtonTemplate || toolsButtonComponent"
480
+ [context]="toolsContext()"
481
+ [defaultComponent]="CopilotChatToolsMenuComponent"
482
+ >
483
+ </copilot-slot>
484
+ } @else {
485
+ <copilot-chat-tools-menu
486
+ [inputToolsMenu]="computedToolsMenu()"
487
+ [inputDisabled]="computedMode() === 'transcribe'">
488
+ </copilot-chat-tools-menu>
489
+ }
490
+ }
491
+ @if (additionalToolbarItems) {
492
+ <ng-container *ngTemplateOutlet="additionalToolbarItems"></ng-container>
493
+ }
494
+ </div>
495
+ <div class="flex items-center">
496
+ @if (computedMode() === 'transcribe') {
497
+ @if (cancelTranscribe.observed) {
498
+ @if (cancelTranscribeButtonTemplate || cancelTranscribeButtonComponent) {
499
+ <copilot-slot
500
+ [slot]="cancelTranscribeButtonTemplate || cancelTranscribeButtonComponent"
501
+ [context]="{}"
502
+ [outputs]="cancelTranscribeButtonOutputs"
503
+ [defaultComponent]="CopilotChatCancelTranscribeButtonComponent"
504
+ >
505
+ </copilot-slot>
506
+ } @else {
507
+ <copilot-chat-cancel-transcribe-button
508
+ (clicked)="handleCancelTranscribe()">
509
+ </copilot-chat-cancel-transcribe-button>
510
+ }
511
+ }
512
+ @if (finishTranscribe.observed) {
513
+ @if (finishTranscribeButtonTemplate || finishTranscribeButtonComponent) {
514
+ <copilot-slot
515
+ [slot]="finishTranscribeButtonTemplate || finishTranscribeButtonComponent"
516
+ [context]="{}"
517
+ [outputs]="finishTranscribeButtonOutputs"
518
+ [defaultComponent]="CopilotChatFinishTranscribeButtonComponent"
519
+ >
520
+ </copilot-slot>
521
+ } @else {
522
+ <copilot-chat-finish-transcribe-button
523
+ (clicked)="handleFinishTranscribe()">
524
+ </copilot-chat-finish-transcribe-button>
525
+ }
526
+ }
527
+ } @else {
528
+ @if (startTranscribe.observed) {
529
+ @if (startTranscribeButtonTemplate || startTranscribeButtonComponent) {
530
+ <copilot-slot
531
+ [slot]="startTranscribeButtonTemplate || startTranscribeButtonComponent"
532
+ [context]="{}"
533
+ [outputs]="startTranscribeButtonOutputs"
534
+ [defaultComponent]="CopilotChatStartTranscribeButtonComponent"
535
+ >
536
+ </copilot-slot>
537
+ } @else {
538
+ <copilot-chat-start-transcribe-button
539
+ (clicked)="handleStartTranscribe()">
540
+ </copilot-chat-start-transcribe-button>
541
+ }
542
+ }
543
+ <!-- Send button with slot -->
544
+ @if (sendButtonTemplate || sendButtonComponent) {
545
+ <copilot-slot
546
+ [slot]="sendButtonTemplate || sendButtonComponent"
547
+ [context]="sendButtonContext()"
548
+ [outputs]="sendButtonOutputs"
549
+ >
550
+ </copilot-slot>
551
+ } @else {
552
+ <div class="mr-[10px]">
553
+ <button
554
+ type="button"
555
+ [class]="sendButtonClass || defaultButtonClass"
556
+ [disabled]="!computedValue().trim() || computedMode() === 'processing'"
557
+ (click)="send()">
558
+ <lucide-angular [img]="ArrowUpIcon" [size]="18"></lucide-angular>
559
+ </button>
560
+ </div>
561
+ }
562
+ }
563
+ </div>
564
+ </div>
565
+ }
566
+ </div>
567
+ `, styles: [":host{display:block;width:100%}.shadow-\\[0_4px_4px_0_\\#0000000a\\,_0_0_1px_0_\\#0000009e\\]{box-shadow:0 4px 4px #0000000a,0 0 1px #0000009e!important}\n"] }]
568
+ }], ctorParameters: () => [], propDecorators: { textAreaRef: [{
569
+ type: ViewChild,
570
+ args: [CopilotChatTextareaComponent, { read: CopilotChatTextareaComponent }]
571
+ }], audioRecorderRef: [{
572
+ type: ViewChild,
573
+ args: [CopilotChatAudioRecorderComponent]
574
+ }], sendButtonTemplate: [{
575
+ type: ContentChild,
576
+ args: ['sendButton', { read: TemplateRef }]
577
+ }], toolbarTemplate: [{
578
+ type: ContentChild,
579
+ args: ['toolbar', { read: TemplateRef }]
580
+ }], textAreaTemplate: [{
581
+ type: ContentChild,
582
+ args: ['textArea', { read: TemplateRef }]
583
+ }], audioRecorderTemplate: [{
584
+ type: ContentChild,
585
+ args: ['audioRecorder', { read: TemplateRef }]
586
+ }], startTranscribeButtonTemplate: [{
587
+ type: ContentChild,
588
+ args: ['startTranscribeButton', { read: TemplateRef }]
589
+ }], cancelTranscribeButtonTemplate: [{
590
+ type: ContentChild,
591
+ args: ['cancelTranscribeButton', { read: TemplateRef }]
592
+ }], finishTranscribeButtonTemplate: [{
593
+ type: ContentChild,
594
+ args: ['finishTranscribeButton', { read: TemplateRef }]
595
+ }], addFileButtonTemplate: [{
596
+ type: ContentChild,
597
+ args: ['addFileButton', { read: TemplateRef }]
598
+ }], toolsButtonTemplate: [{
599
+ type: ContentChild,
600
+ args: ['toolsButton', { read: TemplateRef }]
601
+ }], sendButtonClass: [{
602
+ type: Input
603
+ }], toolbarClass: [{
604
+ type: Input
605
+ }], textAreaClass: [{
606
+ type: Input
607
+ }], textAreaMaxRows: [{
608
+ type: Input
609
+ }], textAreaPlaceholder: [{
610
+ type: Input
611
+ }], audioRecorderClass: [{
612
+ type: Input
613
+ }], startTranscribeButtonClass: [{
614
+ type: Input
615
+ }], cancelTranscribeButtonClass: [{
616
+ type: Input
617
+ }], finishTranscribeButtonClass: [{
618
+ type: Input
619
+ }], addFileButtonClass: [{
620
+ type: Input
621
+ }], toolsButtonClass: [{
622
+ type: Input
623
+ }], sendButtonComponent: [{
624
+ type: Input
625
+ }], toolbarComponent: [{
626
+ type: Input
627
+ }], textAreaComponent: [{
628
+ type: Input
629
+ }], audioRecorderComponent: [{
630
+ type: Input
631
+ }], startTranscribeButtonComponent: [{
632
+ type: Input
633
+ }], cancelTranscribeButtonComponent: [{
634
+ type: Input
635
+ }], finishTranscribeButtonComponent: [{
636
+ type: Input
637
+ }], addFileButtonComponent: [{
638
+ type: Input
639
+ }], toolsButtonComponent: [{
640
+ type: Input
641
+ }], mode: [{
642
+ type: Input
643
+ }], toolsMenu: [{
644
+ type: Input
645
+ }], autoFocus: [{
646
+ type: Input
647
+ }], value: [{
648
+ type: Input
649
+ }], inputClass: [{
650
+ type: Input
651
+ }], additionalToolbarItems: [{
652
+ type: Input
653
+ }], submitMessage: [{
654
+ type: Output
655
+ }], startTranscribe: [{
656
+ type: Output
657
+ }], cancelTranscribe: [{
658
+ type: Output
659
+ }], finishTranscribe: [{
660
+ type: Output
661
+ }], addFile: [{
662
+ type: Output
663
+ }], valueChange: [{
664
+ type: Output
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      () => {\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"]}