@copilotkitnext/angular 0.0.2 → 0.0.4

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 (168) 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/esm2022/components/chat/copilot-chat-assistant-message-buttons.component.mjs +384 -0
  7. package/dist/esm2022/components/chat/copilot-chat-assistant-message-renderer.component.mjs +286 -0
  8. package/dist/esm2022/components/chat/copilot-chat-assistant-message-toolbar.component.mjs +27 -0
  9. package/dist/esm2022/components/chat/copilot-chat-assistant-message.component.mjs +433 -0
  10. package/dist/esm2022/components/chat/copilot-chat-assistant-message.types.mjs +2 -0
  11. package/dist/esm2022/components/chat/copilot-chat-audio-recorder.component.mjs +202 -0
  12. package/dist/esm2022/components/chat/copilot-chat-buttons.component.mjs +321 -0
  13. package/dist/esm2022/components/chat/copilot-chat-input-defaults.mjs +38 -0
  14. package/dist/esm2022/components/chat/copilot-chat-input.component.mjs +666 -0
  15. package/dist/esm2022/components/chat/copilot-chat-input.types.mjs +10 -0
  16. package/dist/esm2022/components/chat/copilot-chat-message-view-cursor.component.mjs +45 -0
  17. package/dist/esm2022/components/chat/copilot-chat-message-view.component.mjs +296 -0
  18. package/dist/esm2022/components/chat/copilot-chat-message-view.types.mjs +2 -0
  19. package/dist/esm2022/components/chat/copilot-chat-textarea.component.mjs +188 -0
  20. package/dist/esm2022/components/chat/copilot-chat-tool-calls-view.component.mjs +216 -0
  21. package/dist/esm2022/components/chat/copilot-chat-toolbar.component.mjs +25 -0
  22. package/dist/esm2022/components/chat/copilot-chat-tools-menu.component.mjs +199 -0
  23. package/dist/esm2022/components/chat/copilot-chat-user-message-branch-navigation.component.mjs +137 -0
  24. package/dist/esm2022/components/chat/copilot-chat-user-message-buttons.component.mjs +207 -0
  25. package/dist/esm2022/components/chat/copilot-chat-user-message-renderer.component.mjs +35 -0
  26. package/dist/esm2022/components/chat/copilot-chat-user-message-toolbar.component.mjs +34 -0
  27. package/dist/esm2022/components/chat/copilot-chat-user-message.component.mjs +341 -0
  28. package/dist/esm2022/components/chat/copilot-chat-user-message.types.mjs +2 -0
  29. package/dist/esm2022/components/chat/copilot-chat-view-disclaimer.component.mjs +52 -0
  30. package/dist/esm2022/components/chat/copilot-chat-view-feather.component.mjs +55 -0
  31. package/dist/esm2022/components/chat/copilot-chat-view-handlers.service.mjs +19 -0
  32. package/dist/esm2022/components/chat/copilot-chat-view-input-container.component.mjs +110 -0
  33. package/dist/esm2022/components/chat/copilot-chat-view-scroll-to-bottom-button.component.mjs +93 -0
  34. package/dist/esm2022/components/chat/copilot-chat-view-scroll-view.component.mjs +443 -0
  35. package/dist/esm2022/components/chat/copilot-chat-view.component.mjs +479 -0
  36. package/dist/esm2022/components/chat/copilot-chat-view.types.mjs +2 -0
  37. package/dist/esm2022/components/chat/copilot-chat.component.mjs +214 -0
  38. package/dist/esm2022/components/copilotkit-tool-render.component.mjs +153 -0
  39. package/dist/esm2022/copilotkitnext-angular.mjs +5 -0
  40. package/dist/esm2022/core/chat-configuration/chat-configuration.providers.mjs +65 -0
  41. package/dist/esm2022/core/chat-configuration/chat-configuration.service.mjs +145 -0
  42. package/dist/esm2022/core/chat-configuration/chat-configuration.types.mjs +26 -0
  43. package/dist/esm2022/core/copilotkit.providers.mjs +34 -0
  44. package/dist/esm2022/core/copilotkit.service.mjs +430 -0
  45. package/dist/esm2022/core/copilotkit.types.mjs +12 -0
  46. package/dist/esm2022/directives/copilotkit-agent-context.directive.mjs +130 -0
  47. package/dist/esm2022/directives/copilotkit-agent.directive.mjs +217 -0
  48. package/dist/esm2022/directives/copilotkit-chat-config.directive.mjs +218 -0
  49. package/dist/esm2022/directives/copilotkit-config.directive.mjs +94 -0
  50. package/dist/esm2022/directives/copilotkit-frontend-tool.directive.mjs +130 -0
  51. package/dist/esm2022/directives/copilotkit-human-in-the-loop.directive.mjs +266 -0
  52. package/dist/esm2022/directives/stick-to-bottom.directive.mjs +181 -0
  53. package/dist/esm2022/index.mjs +70 -0
  54. package/dist/esm2022/lib/directives/tooltip.directive.mjs +211 -0
  55. package/dist/esm2022/lib/slots/copilot-slot.component.mjs +144 -0
  56. package/dist/esm2022/lib/slots/slot.types.mjs +6 -0
  57. package/dist/esm2022/lib/slots/slot.utils.mjs +222 -0
  58. package/dist/esm2022/lib/utils.mjs +10 -0
  59. package/dist/esm2022/services/resize-observer.service.mjs +152 -0
  60. package/dist/esm2022/services/scroll-position.service.mjs +124 -0
  61. package/dist/esm2022/types/frontend-tool.mjs +2 -0
  62. package/dist/esm2022/types/human-in-the-loop.mjs +2 -0
  63. package/dist/esm2022/utils/agent-context.utils.mjs +114 -0
  64. package/dist/esm2022/utils/agent.utils.mjs +204 -0
  65. package/dist/esm2022/utils/chat-config.utils.mjs +186 -0
  66. package/dist/esm2022/utils/copilotkit.utils.mjs +20 -0
  67. package/dist/esm2022/utils/frontend-tool.utils.mjs +228 -0
  68. package/dist/esm2022/utils/human-in-the-loop.utils.mjs +296 -0
  69. package/dist/fesm2022/copilotkitnext-angular.mjs +163 -164
  70. package/dist/fesm2022/copilotkitnext-angular.mjs.map +1 -1
  71. package/package.json +21 -18
  72. package/vitest.config.mts +32 -21
  73. package/.turbo/turbo-build.log +0 -38
  74. package/.turbo/turbo-check-types.log +0 -0
  75. package/.turbo/turbo-test.log +0 -71
  76. package/ng-package.json +0 -19
  77. package/src/components/chat/__tests__/copilot-chat-assistant-message.component.spec.ts +0 -282
  78. package/src/components/chat/__tests__/copilot-chat-input.component.spec.ts +0 -419
  79. package/src/components/chat/__tests__/copilot-chat-message-view.component.spec.ts +0 -372
  80. package/src/components/chat/__tests__/copilot-chat-user-message.component.spec.ts +0 -249
  81. package/src/components/chat/copilot-chat-assistant-message-buttons.component.ts +0 -292
  82. package/src/components/chat/copilot-chat-assistant-message-renderer.component.ts +0 -472
  83. package/src/components/chat/copilot-chat-assistant-message-toolbar.component.ts +0 -29
  84. package/src/components/chat/copilot-chat-assistant-message.component.ts +0 -463
  85. package/src/components/chat/copilot-chat-assistant-message.types.ts +0 -50
  86. package/src/components/chat/copilot-chat-audio-recorder.component.ts +0 -241
  87. package/src/components/chat/copilot-chat-buttons.component.ts +0 -308
  88. package/src/components/chat/copilot-chat-buttons.component.ts.bak +0 -471
  89. package/src/components/chat/copilot-chat-input-defaults.ts +0 -47
  90. package/src/components/chat/copilot-chat-input.component.ts +0 -512
  91. package/src/components/chat/copilot-chat-input.types.ts +0 -148
  92. package/src/components/chat/copilot-chat-message-view-cursor.component.ts +0 -51
  93. package/src/components/chat/copilot-chat-message-view.component.ts +0 -233
  94. package/src/components/chat/copilot-chat-message-view.types.ts +0 -39
  95. package/src/components/chat/copilot-chat-textarea.component.ts +0 -220
  96. package/src/components/chat/copilot-chat-tool-calls-view.component.ts +0 -261
  97. package/src/components/chat/copilot-chat-toolbar.component.ts +0 -35
  98. package/src/components/chat/copilot-chat-tools-menu.component.ts +0 -185
  99. package/src/components/chat/copilot-chat-user-message-branch-navigation.component.ts +0 -121
  100. package/src/components/chat/copilot-chat-user-message-buttons.component.ts +0 -170
  101. package/src/components/chat/copilot-chat-user-message-renderer.component.ts +0 -37
  102. package/src/components/chat/copilot-chat-user-message-toolbar.component.ts +0 -37
  103. package/src/components/chat/copilot-chat-user-message.component.ts +0 -247
  104. package/src/components/chat/copilot-chat-user-message.types.ts +0 -42
  105. package/src/components/chat/copilot-chat-view-disclaimer.component.ts +0 -51
  106. package/src/components/chat/copilot-chat-view-feather.component.ts +0 -47
  107. package/src/components/chat/copilot-chat-view-handlers.service.ts +0 -14
  108. package/src/components/chat/copilot-chat-view-input-container.component.ts +0 -87
  109. package/src/components/chat/copilot-chat-view-scroll-to-bottom-button.component.ts +0 -79
  110. package/src/components/chat/copilot-chat-view-scroll-view.component.ts +0 -322
  111. package/src/components/chat/copilot-chat-view.component.ts +0 -420
  112. package/src/components/chat/copilot-chat-view.types.ts +0 -52
  113. package/src/components/chat/copilot-chat.component.ts +0 -232
  114. package/src/components/copilotkit-tool-render.component.ts +0 -169
  115. package/src/core/__tests__/copilotkit.service.spec.ts +0 -1051
  116. package/src/core/__tests__/copilotkit.service.wildcard.spec.ts +0 -316
  117. package/src/core/chat-configuration/__tests__/chat-configuration.service.spec.ts +0 -287
  118. package/src/core/chat-configuration/chat-configuration.providers.ts +0 -71
  119. package/src/core/chat-configuration/chat-configuration.service.ts +0 -162
  120. package/src/core/chat-configuration/chat-configuration.types.ts +0 -57
  121. package/src/core/copilotkit.providers.ts +0 -59
  122. package/src/core/copilotkit.service.ts +0 -542
  123. package/src/core/copilotkit.types.ts +0 -132
  124. package/src/directives/__tests__/copilotkit-agent-context.directive.spec.ts +0 -384
  125. package/src/directives/__tests__/copilotkit-agent.directive.spec.ts +0 -253
  126. package/src/directives/__tests__/copilotkit-chat-config.directive.spec.ts +0 -385
  127. package/src/directives/__tests__/copilotkit-config.directive.spec.ts +0 -69
  128. package/src/directives/__tests__/copilotkit-frontend-tool-simple.directive.spec.ts +0 -60
  129. package/src/directives/__tests__/copilotkit-frontend-tool.directive.spec.ts +0 -108
  130. package/src/directives/__tests__/copilotkit-human-in-the-loop.directive.spec.ts +0 -452
  131. package/src/directives/copilotkit-agent-context.directive.ts +0 -138
  132. package/src/directives/copilotkit-agent.directive.ts +0 -225
  133. package/src/directives/copilotkit-chat-config.directive.ts +0 -241
  134. package/src/directives/copilotkit-config.directive.ts +0 -81
  135. package/src/directives/copilotkit-frontend-tool.directive.ts +0 -145
  136. package/src/directives/copilotkit-human-in-the-loop.directive.ts +0 -281
  137. package/src/directives/stick-to-bottom.directive.ts +0 -204
  138. package/src/index.ts +0 -105
  139. package/src/lib/directives/tooltip.directive.ts +0 -292
  140. package/src/lib/slots/__tests__/slot.utils.spec.ts +0 -377
  141. package/src/lib/slots/copilot-slot.component.ts +0 -135
  142. package/src/lib/slots/index.ts +0 -3
  143. package/src/lib/slots/slot.types.ts +0 -64
  144. package/src/lib/slots/slot.utils.ts +0 -289
  145. package/src/lib/utils.ts +0 -10
  146. package/src/public-api.ts +0 -1
  147. package/src/services/resize-observer.service.ts +0 -181
  148. package/src/services/scroll-position.service.ts +0 -169
  149. package/src/styles/globals.css +0 -266
  150. package/src/styles/index.css +0 -3
  151. package/src/test-setup.ts +0 -15
  152. package/src/testing/index.ts +0 -3
  153. package/src/testing/testing.utils.ts +0 -248
  154. package/src/types/frontend-tool.ts +0 -44
  155. package/src/types/human-in-the-loop.ts +0 -52
  156. package/src/utils/__tests__/agent.utils.spec.ts +0 -234
  157. package/src/utils/__tests__/chat-config.utils.spec.ts +0 -306
  158. package/src/utils/__tests__/frontend-tool-inject.spec.ts +0 -350
  159. package/src/utils/__tests__/frontend-tool-integration.spec.ts +0 -199
  160. package/src/utils/__tests__/frontend-tool.utils.spec.ts +0 -272
  161. package/src/utils/__tests__/human-in-the-loop.utils.spec.ts +0 -365
  162. package/src/utils/agent-context.utils.ts +0 -133
  163. package/src/utils/agent.utils.ts +0 -239
  164. package/src/utils/chat-config.utils.ts +0 -221
  165. package/src/utils/copilotkit.utils.ts +0 -20
  166. package/src/utils/frontend-tool.utils.ts +0 -266
  167. package/src/utils/human-in-the-loop.utils.ts +0 -359
  168. package/tsconfig.spec.json +0 -12
@@ -0,0 +1,479 @@
1
+ import { Component, Input, Output, EventEmitter, ContentChild, ViewChild, ElementRef, ChangeDetectionStrategy, ViewEncapsulation, signal, computed, effect } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { CopilotSlotComponent } from '../../lib/slots/copilot-slot.component';
4
+ import { CopilotChatMessageViewComponent } from './copilot-chat-message-view.component';
5
+ import { CopilotChatInputComponent } from './copilot-chat-input.component';
6
+ import { CopilotChatViewScrollViewComponent } from './copilot-chat-view-scroll-view.component';
7
+ import { CopilotChatViewScrollToBottomButtonComponent } from './copilot-chat-view-scroll-to-bottom-button.component';
8
+ import { CopilotChatViewFeatherComponent } from './copilot-chat-view-feather.component';
9
+ import { CopilotChatViewInputContainerComponent } from './copilot-chat-view-input-container.component';
10
+ import { CopilotChatViewDisclaimerComponent } from './copilot-chat-view-disclaimer.component';
11
+ import { cn } from '../../lib/utils';
12
+ import { ResizeObserverService } from '../../services/resize-observer.service';
13
+ import { CopilotChatViewHandlersService } from './copilot-chat-view-handlers.service';
14
+ import { Subject } from 'rxjs';
15
+ import { takeUntil } from 'rxjs/operators';
16
+ import * as i0 from "@angular/core";
17
+ import * as i1 from "../../services/resize-observer.service";
18
+ import * as i2 from "./copilot-chat-view-handlers.service";
19
+ import * as i3 from "@angular/common";
20
+ /**
21
+ * CopilotChatView component - Angular port of the React component.
22
+ * A complete chat interface with message feed and input components.
23
+ *
24
+ * @example
25
+ * ```html
26
+ * <copilot-chat-view
27
+ * [messages]="messages"
28
+ * [autoScroll]="true"
29
+ * [messageViewProps]="{ assistantMessage: { onThumbsUp: handleThumbsUp } }">
30
+ * </copilot-chat-view>
31
+ * ```
32
+ */
33
+ export class CopilotChatViewComponent {
34
+ resizeObserverService;
35
+ cdr;
36
+ handlers;
37
+ // Core inputs matching React props
38
+ messages = [];
39
+ autoScroll = true;
40
+ showCursor = false;
41
+ // MessageView slot inputs
42
+ messageViewComponent;
43
+ messageViewTemplate;
44
+ messageViewClass;
45
+ // ScrollView slot inputs
46
+ scrollViewComponent;
47
+ scrollViewTemplate;
48
+ scrollViewClass;
49
+ // ScrollToBottomButton slot inputs
50
+ scrollToBottomButtonComponent;
51
+ scrollToBottomButtonTemplate;
52
+ scrollToBottomButtonClass;
53
+ // Input slot inputs
54
+ inputComponent;
55
+ inputTemplate;
56
+ // InputContainer slot inputs
57
+ inputContainerComponent;
58
+ inputContainerTemplate;
59
+ inputContainerClass;
60
+ // Feather slot inputs
61
+ featherComponent;
62
+ featherTemplate;
63
+ featherClass;
64
+ // Disclaimer slot inputs
65
+ disclaimerComponent;
66
+ disclaimerTemplate;
67
+ disclaimerClass;
68
+ disclaimerText;
69
+ // Custom layout template (render prop pattern)
70
+ customLayoutTemplate;
71
+ // Named template slots for deep customization
72
+ sendButtonTemplate;
73
+ toolbarTemplate;
74
+ textAreaTemplate;
75
+ audioRecorderTemplate;
76
+ assistantMessageMarkdownRendererTemplate;
77
+ thumbsUpButtonTemplate;
78
+ thumbsDownButtonTemplate;
79
+ readAloudButtonTemplate;
80
+ regenerateButtonTemplate;
81
+ // Output events for assistant message actions (bubbled from child components)
82
+ assistantMessageThumbsUp = new EventEmitter();
83
+ assistantMessageThumbsDown = new EventEmitter();
84
+ assistantMessageReadAloud = new EventEmitter();
85
+ assistantMessageRegenerate = new EventEmitter();
86
+ // Output events for user message actions (if applicable)
87
+ userMessageCopy = new EventEmitter();
88
+ userMessageEdit = new EventEmitter();
89
+ // ViewChild references
90
+ inputContainerSlotRef;
91
+ // Default components for slots
92
+ defaultScrollViewComponent = CopilotChatViewScrollViewComponent;
93
+ defaultScrollToBottomButtonComponent = CopilotChatViewScrollToBottomButtonComponent;
94
+ defaultInputContainerComponent = CopilotChatViewInputContainerComponent;
95
+ defaultFeatherComponent = CopilotChatViewFeatherComponent;
96
+ defaultDisclaimerComponent = CopilotChatViewDisclaimerComponent;
97
+ // Signals for reactive state
98
+ messagesSignal = signal([]);
99
+ autoScrollSignal = signal(true);
100
+ showCursorSignal = signal(false);
101
+ disclaimerTextSignal = signal(undefined);
102
+ disclaimerClassSignal = signal(undefined);
103
+ inputContainerHeight = signal(0);
104
+ isResizing = signal(false);
105
+ contentPaddingBottom = computed(() => this.inputContainerHeight() + 32);
106
+ // Computed signals
107
+ computedClass = computed(() => cn('relative h-full'));
108
+ // Slot resolution computed signals
109
+ messageViewSlot = computed(() => this.messageViewTemplate || this.messageViewComponent);
110
+ scrollViewSlot = computed(() => this.scrollViewTemplate || this.scrollViewComponent);
111
+ scrollToBottomButtonSlot = computed(() => this.scrollToBottomButtonTemplate || this.scrollToBottomButtonComponent);
112
+ inputSlot = computed(() => this.inputTemplate || this.inputComponent);
113
+ inputContainerSlot = computed(() => this.inputContainerTemplate || this.inputContainerComponent);
114
+ featherSlot = computed(() => this.featherTemplate || this.featherComponent);
115
+ disclaimerSlot = computed(() => this.disclaimerTemplate || this.disclaimerComponent);
116
+ // Context objects for slots
117
+ scrollViewContext = computed(() => ({
118
+ autoScroll: this.autoScrollSignal(),
119
+ scrollToBottomButton: this.scrollToBottomButtonSlot(),
120
+ scrollToBottomButtonClass: this.scrollToBottomButtonClass,
121
+ inputContainerHeight: this.inputContainerHeight(),
122
+ isResizing: this.isResizing(),
123
+ messages: this.messagesSignal(),
124
+ messageView: this.messageViewSlot(),
125
+ messageViewClass: this.messageViewClass
126
+ }));
127
+ // Removed scrollViewPropsComputed - no longer needed
128
+ inputContainerContext = computed(() => ({
129
+ input: this.inputSlot(),
130
+ disclaimer: this.disclaimerSlot(),
131
+ disclaimerText: this.disclaimerTextSignal(),
132
+ disclaimerClass: this.disclaimerClassSignal(),
133
+ inputContainerClass: this.inputContainerClass
134
+ }));
135
+ // Removed inputContainerPropsComputed - no longer needed
136
+ // Layout context for custom templates (render prop pattern)
137
+ layoutContext = computed(() => ({
138
+ messageView: this.messageViewSlot(),
139
+ input: this.inputSlot(),
140
+ scrollView: this.scrollViewSlot(),
141
+ scrollToBottomButton: this.scrollToBottomButtonSlot(),
142
+ feather: this.featherSlot(),
143
+ inputContainer: this.inputContainerSlot(),
144
+ disclaimer: this.disclaimerSlot()
145
+ }));
146
+ destroy$ = new Subject();
147
+ resizeTimeoutRef;
148
+ constructor(resizeObserverService, cdr, handlers) {
149
+ this.resizeObserverService = resizeObserverService;
150
+ this.cdr = cdr;
151
+ this.handlers = handlers;
152
+ // Set up effect to handle resize state timeout
153
+ effect(() => {
154
+ const resizing = this.isResizing();
155
+ if (resizing && this.resizeTimeoutRef) {
156
+ clearTimeout(this.resizeTimeoutRef);
157
+ this.resizeTimeoutRef = undefined;
158
+ }
159
+ });
160
+ }
161
+ ngOnInit() {
162
+ // Initialize signals with input values
163
+ this.messagesSignal.set(this.messages);
164
+ this.autoScrollSignal.set(this.autoScroll);
165
+ this.showCursorSignal.set(this.showCursor);
166
+ this.disclaimerTextSignal.set(this.disclaimerText);
167
+ this.disclaimerClassSignal.set(this.disclaimerClass);
168
+ // Initialize handler availability in the view-scoped service
169
+ this.handlers.hasAssistantThumbsUpHandler.set(this.assistantMessageThumbsUp.observed);
170
+ this.handlers.hasAssistantThumbsDownHandler.set(this.assistantMessageThumbsDown.observed);
171
+ this.handlers.hasAssistantReadAloudHandler.set(this.assistantMessageReadAloud.observed);
172
+ this.handlers.hasAssistantRegenerateHandler.set(this.assistantMessageRegenerate.observed);
173
+ this.handlers.hasUserCopyHandler.set(this.userMessageCopy.observed);
174
+ this.handlers.hasUserEditHandler.set(this.userMessageEdit.observed);
175
+ }
176
+ ngOnChanges() {
177
+ // Update signals when inputs change
178
+ this.messagesSignal.set(this.messages);
179
+ this.autoScrollSignal.set(this.autoScroll);
180
+ this.showCursorSignal.set(this.showCursor);
181
+ this.disclaimerTextSignal.set(this.disclaimerText);
182
+ this.disclaimerClassSignal.set(this.disclaimerClass);
183
+ // Keep handler availability in sync
184
+ this.handlers.hasAssistantThumbsUpHandler.set(this.assistantMessageThumbsUp.observed);
185
+ this.handlers.hasAssistantThumbsDownHandler.set(this.assistantMessageThumbsDown.observed);
186
+ this.handlers.hasAssistantReadAloudHandler.set(this.assistantMessageReadAloud.observed);
187
+ this.handlers.hasAssistantRegenerateHandler.set(this.assistantMessageRegenerate.observed);
188
+ this.handlers.hasUserCopyHandler.set(this.userMessageCopy.observed);
189
+ this.handlers.hasUserEditHandler.set(this.userMessageEdit.observed);
190
+ }
191
+ ngAfterViewInit() {
192
+ // Don't set a default height - measure it dynamically
193
+ // Set up input container height monitoring
194
+ const measureAndObserve = () => {
195
+ if (!this.inputContainerSlotRef || !this.inputContainerSlotRef.nativeElement) {
196
+ return false;
197
+ }
198
+ // The slot ref points to the copilot-slot element
199
+ // We need to find the actual input container component inside it
200
+ const slotElement = this.inputContainerSlotRef.nativeElement;
201
+ const componentElement = slotElement.querySelector('copilot-chat-view-input-container');
202
+ if (!componentElement) {
203
+ return false;
204
+ }
205
+ // Look for the absolute positioned div that contains the input
206
+ let innerDiv = componentElement.querySelector('div.absolute');
207
+ // If not found by class, try first child
208
+ if (!innerDiv) {
209
+ innerDiv = componentElement.firstElementChild;
210
+ }
211
+ if (!innerDiv) {
212
+ return false;
213
+ }
214
+ // Measure the actual height
215
+ const measuredHeight = innerDiv.offsetHeight;
216
+ if (measuredHeight === 0) {
217
+ return false;
218
+ }
219
+ // Success! Set the initial height
220
+ this.inputContainerHeight.set(measuredHeight);
221
+ this.cdr.detectChanges();
222
+ // Create an ElementRef wrapper for ResizeObserver
223
+ const innerDivRef = new ElementRef(innerDiv);
224
+ // Set up ResizeObserver to track changes
225
+ this.resizeObserverService.observeElement(innerDivRef, 0, 250)
226
+ .pipe(takeUntil(this.destroy$))
227
+ .subscribe(state => {
228
+ const newHeight = state.height;
229
+ if (newHeight !== this.inputContainerHeight() && newHeight > 0) {
230
+ this.inputContainerHeight.set(newHeight);
231
+ this.isResizing.set(true);
232
+ this.cdr.detectChanges();
233
+ // Clear existing timeout
234
+ if (this.resizeTimeoutRef) {
235
+ clearTimeout(this.resizeTimeoutRef);
236
+ }
237
+ // Set isResizing to false after a short delay
238
+ this.resizeTimeoutRef = window.setTimeout(() => {
239
+ this.isResizing.set(false);
240
+ this.resizeTimeoutRef = undefined;
241
+ this.cdr.detectChanges();
242
+ }, 250);
243
+ }
244
+ });
245
+ return true;
246
+ };
247
+ // Try to measure immediately
248
+ if (!measureAndObserve()) {
249
+ // If failed, retry with increasing delays
250
+ let attempts = 0;
251
+ const maxAttempts = 10;
252
+ const retry = () => {
253
+ attempts++;
254
+ if (measureAndObserve()) {
255
+ // Successfully measured
256
+ }
257
+ else if (attempts < maxAttempts) {
258
+ // Exponential backoff: 50ms, 100ms, 200ms, 400ms, etc.
259
+ const delay = 50 * Math.pow(2, Math.min(attempts - 1, 4));
260
+ setTimeout(retry, delay);
261
+ }
262
+ else {
263
+ // Failed to measure after max attempts
264
+ }
265
+ };
266
+ // Start retry with first delay
267
+ setTimeout(retry, 50);
268
+ }
269
+ }
270
+ ngOnDestroy() {
271
+ if (this.resizeTimeoutRef) {
272
+ clearTimeout(this.resizeTimeoutRef);
273
+ }
274
+ this.destroy$.next();
275
+ this.destroy$.complete();
276
+ }
277
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CopilotChatViewComponent, deps: [{ token: i1.ResizeObserverService }, { token: i0.ChangeDetectorRef }, { token: i2.CopilotChatViewHandlersService }], target: i0.ɵɵFactoryTarget.Component });
278
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: CopilotChatViewComponent, isStandalone: true, selector: "copilot-chat-view", inputs: { messages: "messages", autoScroll: "autoScroll", showCursor: "showCursor", messageViewComponent: "messageViewComponent", messageViewTemplate: "messageViewTemplate", messageViewClass: "messageViewClass", scrollViewComponent: "scrollViewComponent", scrollViewTemplate: "scrollViewTemplate", scrollViewClass: "scrollViewClass", scrollToBottomButtonComponent: "scrollToBottomButtonComponent", scrollToBottomButtonTemplate: "scrollToBottomButtonTemplate", scrollToBottomButtonClass: "scrollToBottomButtonClass", inputComponent: "inputComponent", inputTemplate: "inputTemplate", inputContainerComponent: "inputContainerComponent", inputContainerTemplate: "inputContainerTemplate", inputContainerClass: "inputContainerClass", featherComponent: "featherComponent", featherTemplate: "featherTemplate", featherClass: "featherClass", disclaimerComponent: "disclaimerComponent", disclaimerTemplate: "disclaimerTemplate", disclaimerClass: "disclaimerClass", disclaimerText: "disclaimerText" }, outputs: { assistantMessageThumbsUp: "assistantMessageThumbsUp", assistantMessageThumbsDown: "assistantMessageThumbsDown", assistantMessageReadAloud: "assistantMessageReadAloud", assistantMessageRegenerate: "assistantMessageRegenerate", userMessageCopy: "userMessageCopy", userMessageEdit: "userMessageEdit" }, providers: [ResizeObserverService, CopilotChatViewHandlersService], queries: [{ propertyName: "customLayoutTemplate", first: true, predicate: ["customLayout"], descendants: true }, { propertyName: "sendButtonTemplate", first: true, predicate: ["sendButton"], descendants: true }, { propertyName: "toolbarTemplate", first: true, predicate: ["toolbar"], descendants: true }, { propertyName: "textAreaTemplate", first: true, predicate: ["textArea"], descendants: true }, { propertyName: "audioRecorderTemplate", first: true, predicate: ["audioRecorder"], descendants: true }, { propertyName: "assistantMessageMarkdownRendererTemplate", first: true, predicate: ["assistantMessageMarkdownRenderer"], descendants: true }, { propertyName: "thumbsUpButtonTemplate", first: true, predicate: ["thumbsUpButton"], descendants: true }, { propertyName: "thumbsDownButtonTemplate", first: true, predicate: ["thumbsDownButton"], descendants: true }, { propertyName: "readAloudButtonTemplate", first: true, predicate: ["readAloudButton"], descendants: true }, { propertyName: "regenerateButtonTemplate", first: true, predicate: ["regenerateButton"], descendants: true }], viewQueries: [{ propertyName: "inputContainerSlotRef", first: true, predicate: ["inputContainerSlotRef"], descendants: true, read: ElementRef }], usesOnChanges: true, ngImport: i0, template: `
279
+ <!-- Custom layout template support (render prop pattern) -->
280
+ @if (customLayoutTemplate) {
281
+ <ng-container *ngTemplateOutlet="customLayoutTemplate; context: layoutContext()"></ng-container>
282
+ } @else {
283
+ <!-- Default layout - exact React DOM structure -->
284
+ <div [class]="computedClass()">
285
+ <!-- ScrollView -->
286
+ <copilot-chat-view-scroll-view
287
+ [autoScroll]="autoScrollSignal()"
288
+ [inputContainerHeight]="inputContainerHeight()"
289
+ [isResizing]="isResizing()"
290
+ [messages]="messagesSignal()"
291
+ [messageView]="messageViewSlot()"
292
+ [messageViewClass]="messageViewClass"
293
+ [scrollToBottomButton]="scrollToBottomButtonSlot()"
294
+ [scrollToBottomButtonClass]="scrollToBottomButtonClass"
295
+ [showCursor]="showCursorSignal()"
296
+ (assistantMessageThumbsUp)="assistantMessageThumbsUp.emit($event)"
297
+ (assistantMessageThumbsDown)="assistantMessageThumbsDown.emit($event)"
298
+ (assistantMessageReadAloud)="assistantMessageReadAloud.emit($event)"
299
+ (assistantMessageRegenerate)="assistantMessageRegenerate.emit($event)"
300
+ (userMessageCopy)="userMessageCopy.emit($event)"
301
+ (userMessageEdit)="userMessageEdit.emit($event)">
302
+ </copilot-chat-view-scroll-view>
303
+
304
+ <!-- Feather effect -->
305
+ <copilot-slot
306
+ [slot]="featherSlot()"
307
+ [context]="{ inputClass: featherClass }"
308
+ [defaultComponent]="defaultFeatherComponent">
309
+ </copilot-slot>
310
+
311
+ <!-- Input container -->
312
+ <copilot-slot
313
+ #inputContainerSlotRef
314
+ [slot]="inputContainerSlot()"
315
+ [context]="inputContainerContext()"
316
+ [defaultComponent]="defaultInputContainerComponent">
317
+ </copilot-slot>
318
+ </div>
319
+ }
320
+ `, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: CopilotSlotComponent, selector: "copilot-slot", inputs: ["slot", "context", "defaultComponent", "outputs"] }, { kind: "component", type: CopilotChatViewScrollViewComponent, selector: "copilot-chat-view-scroll-view", inputs: ["autoScroll", "inputContainerHeight", "isResizing", "inputClass", "messages", "messageView", "messageViewClass", "showCursor", "scrollToBottomButton", "scrollToBottomButtonClass"], outputs: ["assistantMessageThumbsUp", "assistantMessageThumbsDown", "assistantMessageReadAloud", "assistantMessageRegenerate", "userMessageCopy", "userMessageEdit"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
321
+ }
322
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CopilotChatViewComponent, decorators: [{
323
+ type: Component,
324
+ args: [{
325
+ selector: 'copilot-chat-view',
326
+ standalone: true,
327
+ imports: [
328
+ CommonModule,
329
+ CopilotSlotComponent,
330
+ CopilotChatMessageViewComponent,
331
+ CopilotChatInputComponent,
332
+ CopilotChatViewScrollViewComponent,
333
+ CopilotChatViewScrollToBottomButtonComponent,
334
+ CopilotChatViewFeatherComponent,
335
+ CopilotChatViewInputContainerComponent,
336
+ CopilotChatViewDisclaimerComponent
337
+ ],
338
+ changeDetection: ChangeDetectionStrategy.OnPush,
339
+ encapsulation: ViewEncapsulation.None,
340
+ providers: [ResizeObserverService, CopilotChatViewHandlersService],
341
+ template: `
342
+ <!-- Custom layout template support (render prop pattern) -->
343
+ @if (customLayoutTemplate) {
344
+ <ng-container *ngTemplateOutlet="customLayoutTemplate; context: layoutContext()"></ng-container>
345
+ } @else {
346
+ <!-- Default layout - exact React DOM structure -->
347
+ <div [class]="computedClass()">
348
+ <!-- ScrollView -->
349
+ <copilot-chat-view-scroll-view
350
+ [autoScroll]="autoScrollSignal()"
351
+ [inputContainerHeight]="inputContainerHeight()"
352
+ [isResizing]="isResizing()"
353
+ [messages]="messagesSignal()"
354
+ [messageView]="messageViewSlot()"
355
+ [messageViewClass]="messageViewClass"
356
+ [scrollToBottomButton]="scrollToBottomButtonSlot()"
357
+ [scrollToBottomButtonClass]="scrollToBottomButtonClass"
358
+ [showCursor]="showCursorSignal()"
359
+ (assistantMessageThumbsUp)="assistantMessageThumbsUp.emit($event)"
360
+ (assistantMessageThumbsDown)="assistantMessageThumbsDown.emit($event)"
361
+ (assistantMessageReadAloud)="assistantMessageReadAloud.emit($event)"
362
+ (assistantMessageRegenerate)="assistantMessageRegenerate.emit($event)"
363
+ (userMessageCopy)="userMessageCopy.emit($event)"
364
+ (userMessageEdit)="userMessageEdit.emit($event)">
365
+ </copilot-chat-view-scroll-view>
366
+
367
+ <!-- Feather effect -->
368
+ <copilot-slot
369
+ [slot]="featherSlot()"
370
+ [context]="{ inputClass: featherClass }"
371
+ [defaultComponent]="defaultFeatherComponent">
372
+ </copilot-slot>
373
+
374
+ <!-- Input container -->
375
+ <copilot-slot
376
+ #inputContainerSlotRef
377
+ [slot]="inputContainerSlot()"
378
+ [context]="inputContainerContext()"
379
+ [defaultComponent]="defaultInputContainerComponent">
380
+ </copilot-slot>
381
+ </div>
382
+ }
383
+ `
384
+ }]
385
+ }], ctorParameters: () => [{ type: i1.ResizeObserverService }, { type: i0.ChangeDetectorRef }, { type: i2.CopilotChatViewHandlersService }], propDecorators: { messages: [{
386
+ type: Input
387
+ }], autoScroll: [{
388
+ type: Input
389
+ }], showCursor: [{
390
+ type: Input
391
+ }], messageViewComponent: [{
392
+ type: Input
393
+ }], messageViewTemplate: [{
394
+ type: Input
395
+ }], messageViewClass: [{
396
+ type: Input
397
+ }], scrollViewComponent: [{
398
+ type: Input
399
+ }], scrollViewTemplate: [{
400
+ type: Input
401
+ }], scrollViewClass: [{
402
+ type: Input
403
+ }], scrollToBottomButtonComponent: [{
404
+ type: Input
405
+ }], scrollToBottomButtonTemplate: [{
406
+ type: Input
407
+ }], scrollToBottomButtonClass: [{
408
+ type: Input
409
+ }], inputComponent: [{
410
+ type: Input
411
+ }], inputTemplate: [{
412
+ type: Input
413
+ }], inputContainerComponent: [{
414
+ type: Input
415
+ }], inputContainerTemplate: [{
416
+ type: Input
417
+ }], inputContainerClass: [{
418
+ type: Input
419
+ }], featherComponent: [{
420
+ type: Input
421
+ }], featherTemplate: [{
422
+ type: Input
423
+ }], featherClass: [{
424
+ type: Input
425
+ }], disclaimerComponent: [{
426
+ type: Input
427
+ }], disclaimerTemplate: [{
428
+ type: Input
429
+ }], disclaimerClass: [{
430
+ type: Input
431
+ }], disclaimerText: [{
432
+ type: Input
433
+ }], customLayoutTemplate: [{
434
+ type: ContentChild,
435
+ args: ['customLayout']
436
+ }], sendButtonTemplate: [{
437
+ type: ContentChild,
438
+ args: ['sendButton']
439
+ }], toolbarTemplate: [{
440
+ type: ContentChild,
441
+ args: ['toolbar']
442
+ }], textAreaTemplate: [{
443
+ type: ContentChild,
444
+ args: ['textArea']
445
+ }], audioRecorderTemplate: [{
446
+ type: ContentChild,
447
+ args: ['audioRecorder']
448
+ }], assistantMessageMarkdownRendererTemplate: [{
449
+ type: ContentChild,
450
+ args: ['assistantMessageMarkdownRenderer']
451
+ }], thumbsUpButtonTemplate: [{
452
+ type: ContentChild,
453
+ args: ['thumbsUpButton']
454
+ }], thumbsDownButtonTemplate: [{
455
+ type: ContentChild,
456
+ args: ['thumbsDownButton']
457
+ }], readAloudButtonTemplate: [{
458
+ type: ContentChild,
459
+ args: ['readAloudButton']
460
+ }], regenerateButtonTemplate: [{
461
+ type: ContentChild,
462
+ args: ['regenerateButton']
463
+ }], assistantMessageThumbsUp: [{
464
+ type: Output
465
+ }], assistantMessageThumbsDown: [{
466
+ type: Output
467
+ }], assistantMessageReadAloud: [{
468
+ type: Output
469
+ }], assistantMessageRegenerate: [{
470
+ type: Output
471
+ }], userMessageCopy: [{
472
+ type: Output
473
+ }], userMessageEdit: [{
474
+ type: Output
475
+ }], inputContainerSlotRef: [{
476
+ type: ViewChild,
477
+ args: ['inputContainerSlotRef', { read: ElementRef }]
478
+ }] } });
479
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"copilot-chat-view.component.js","sourceRoot":"","sources":["../../../../src/components/chat/copilot-chat-view.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  ContentChild,\n  TemplateRef,\n  Type,\n  ViewChild,\n  ElementRef,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  ViewEncapsulation,\n  signal,\n  computed,\n  OnInit,\n  OnChanges,\n  OnDestroy,\n  AfterViewInit,\n  ViewContainerRef,\n  effect\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { CopilotSlotComponent } from '../../lib/slots/copilot-slot.component';\nimport { CopilotChatMessageViewComponent } from './copilot-chat-message-view.component';\nimport { CopilotChatInputComponent } from './copilot-chat-input.component';\nimport { CopilotChatViewScrollViewComponent } from './copilot-chat-view-scroll-view.component';\nimport { CopilotChatViewScrollToBottomButtonComponent } from './copilot-chat-view-scroll-to-bottom-button.component';\nimport { CopilotChatViewFeatherComponent } from './copilot-chat-view-feather.component';\nimport { CopilotChatViewInputContainerComponent } from './copilot-chat-view-input-container.component';\nimport { CopilotChatViewDisclaimerComponent } from './copilot-chat-view-disclaimer.component';\nimport { Message } from '@ag-ui/client';\nimport { cn } from '../../lib/utils';\nimport { ResizeObserverService } from '../../services/resize-observer.service';\nimport { CopilotChatViewHandlersService } from './copilot-chat-view-handlers.service';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\n/**\n * CopilotChatView component - Angular port of the React component.\n * A complete chat interface with message feed and input components.\n * \n * @example\n * ```html\n * <copilot-chat-view\n *   [messages]=\"messages\"\n *   [autoScroll]=\"true\"\n *   [messageViewProps]=\"{ assistantMessage: { onThumbsUp: handleThumbsUp } }\">\n * </copilot-chat-view>\n * ```\n */\n@Component({\n  selector: 'copilot-chat-view',\n  standalone: true,\n  imports: [\n    CommonModule,\n    CopilotSlotComponent,\n    CopilotChatMessageViewComponent,\n    CopilotChatInputComponent,\n    CopilotChatViewScrollViewComponent,\n    CopilotChatViewScrollToBottomButtonComponent,\n    CopilotChatViewFeatherComponent,\n    CopilotChatViewInputContainerComponent,\n    CopilotChatViewDisclaimerComponent\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  providers: [ResizeObserverService, CopilotChatViewHandlersService],\n  template: `\n    <!-- Custom layout template support (render prop pattern) -->\n    @if (customLayoutTemplate) {\n      <ng-container *ngTemplateOutlet=\"customLayoutTemplate; context: layoutContext()\"></ng-container>\n    } @else {\n      <!-- Default layout - exact React DOM structure -->\n      <div [class]=\"computedClass()\">\n        <!-- ScrollView -->\n        <copilot-chat-view-scroll-view\n          [autoScroll]=\"autoScrollSignal()\"\n          [inputContainerHeight]=\"inputContainerHeight()\"\n          [isResizing]=\"isResizing()\"\n          [messages]=\"messagesSignal()\"\n          [messageView]=\"messageViewSlot()\"\n          [messageViewClass]=\"messageViewClass\"\n          [scrollToBottomButton]=\"scrollToBottomButtonSlot()\"\n          [scrollToBottomButtonClass]=\"scrollToBottomButtonClass\"\n          [showCursor]=\"showCursorSignal()\"\n          (assistantMessageThumbsUp)=\"assistantMessageThumbsUp.emit($event)\"\n          (assistantMessageThumbsDown)=\"assistantMessageThumbsDown.emit($event)\"\n          (assistantMessageReadAloud)=\"assistantMessageReadAloud.emit($event)\"\n          (assistantMessageRegenerate)=\"assistantMessageRegenerate.emit($event)\"\n          (userMessageCopy)=\"userMessageCopy.emit($event)\"\n          (userMessageEdit)=\"userMessageEdit.emit($event)\">\n        </copilot-chat-view-scroll-view>\n\n        <!-- Feather effect -->\n        <copilot-slot\n          [slot]=\"featherSlot()\"\n          [context]=\"{ inputClass: featherClass }\"\n          [defaultComponent]=\"defaultFeatherComponent\">\n        </copilot-slot>\n\n        <!-- Input container -->\n        <copilot-slot\n          #inputContainerSlotRef\n          [slot]=\"inputContainerSlot()\"\n          [context]=\"inputContainerContext()\"\n          [defaultComponent]=\"defaultInputContainerComponent\">\n        </copilot-slot>\n      </div>\n    }\n  `\n})\nexport class CopilotChatViewComponent implements OnInit, OnChanges, AfterViewInit, OnDestroy {\n  // Core inputs matching React props\n  @Input() messages: Message[] = [];\n  @Input() autoScroll: boolean = true;\n  @Input() showCursor: boolean = false;\n  \n  // MessageView slot inputs\n  @Input() messageViewComponent?: Type<any>;\n  @Input() messageViewTemplate?: TemplateRef<any>;\n  @Input() messageViewClass?: string;\n  \n  // ScrollView slot inputs\n  @Input() scrollViewComponent?: Type<any>;\n  @Input() scrollViewTemplate?: TemplateRef<any>;\n  @Input() scrollViewClass?: string;\n  \n  // ScrollToBottomButton slot inputs\n  @Input() scrollToBottomButtonComponent?: Type<any>;\n  @Input() scrollToBottomButtonTemplate?: TemplateRef<any>;\n  @Input() scrollToBottomButtonClass?: string;\n  \n  // Input slot inputs\n  @Input() inputComponent?: Type<any>;\n  @Input() inputTemplate?: TemplateRef<any>;\n  \n  // InputContainer slot inputs\n  @Input() inputContainerComponent?: Type<any>;\n  @Input() inputContainerTemplate?: TemplateRef<any>;\n  @Input() inputContainerClass?: string;\n  \n  // Feather slot inputs\n  @Input() featherComponent?: Type<any>;\n  @Input() featherTemplate?: TemplateRef<any>;\n  @Input() featherClass?: string;\n  \n  // Disclaimer slot inputs\n  @Input() disclaimerComponent?: Type<any>;\n  @Input() disclaimerTemplate?: TemplateRef<any>;\n  @Input() disclaimerClass?: string;\n  @Input() disclaimerText?: string;\n  \n  // Custom layout template (render prop pattern)\n  @ContentChild('customLayout') customLayoutTemplate?: TemplateRef<any>;\n  \n  // Named template slots for deep customization\n  @ContentChild('sendButton') sendButtonTemplate?: TemplateRef<any>;\n  @ContentChild('toolbar') toolbarTemplate?: TemplateRef<any>;\n  @ContentChild('textArea') textAreaTemplate?: TemplateRef<any>;\n  @ContentChild('audioRecorder') audioRecorderTemplate?: TemplateRef<any>;\n  @ContentChild('assistantMessageMarkdownRenderer') assistantMessageMarkdownRendererTemplate?: TemplateRef<any>;\n  @ContentChild('thumbsUpButton') thumbsUpButtonTemplate?: TemplateRef<any>;\n  @ContentChild('thumbsDownButton') thumbsDownButtonTemplate?: TemplateRef<any>;\n  @ContentChild('readAloudButton') readAloudButtonTemplate?: TemplateRef<any>;\n  @ContentChild('regenerateButton') regenerateButtonTemplate?: TemplateRef<any>;\n  \n  // Output events for assistant message actions (bubbled from child components)\n  @Output() assistantMessageThumbsUp = new EventEmitter<{ message: Message }>();\n  @Output() assistantMessageThumbsDown = new EventEmitter<{ message: Message }>();\n  @Output() assistantMessageReadAloud = new EventEmitter<{ message: Message }>();\n  @Output() assistantMessageRegenerate = new EventEmitter<{ message: Message }>();\n  \n  // Output events for user message actions (if applicable)\n  @Output() userMessageCopy = new EventEmitter<{ message: Message }>();\n  @Output() userMessageEdit = new EventEmitter<{ message: Message }>();\n  \n  // ViewChild references\n  @ViewChild('inputContainerSlotRef', { read: ElementRef }) inputContainerSlotRef?: ElementRef;\n  \n  // Default components for slots\n  protected readonly defaultScrollViewComponent = CopilotChatViewScrollViewComponent;\n  protected readonly defaultScrollToBottomButtonComponent = CopilotChatViewScrollToBottomButtonComponent;\n  protected readonly defaultInputContainerComponent = CopilotChatViewInputContainerComponent;\n  protected readonly defaultFeatherComponent = CopilotChatViewFeatherComponent;\n  protected readonly defaultDisclaimerComponent = CopilotChatViewDisclaimerComponent;\n  \n  // Signals for reactive state\n  protected messagesSignal = signal<Message[]>([]);\n  protected autoScrollSignal = signal(true);\n  protected showCursorSignal = signal(false);\n  protected disclaimerTextSignal = signal<string | undefined>(undefined);\n  protected disclaimerClassSignal = signal<string | undefined>(undefined);\n  protected inputContainerHeight = signal<number>(0);\n  protected isResizing = signal<boolean>(false);\n  protected contentPaddingBottom = computed(() => this.inputContainerHeight() + 32);\n  \n  // Computed signals\n  protected computedClass = computed(() => cn('relative h-full'));\n  \n  // Slot resolution computed signals\n  protected messageViewSlot = computed(() => \n    this.messageViewTemplate || this.messageViewComponent\n  );\n  \n  protected scrollViewSlot = computed(() => \n    this.scrollViewTemplate || this.scrollViewComponent\n  );\n  \n  protected scrollToBottomButtonSlot = computed(() => \n    this.scrollToBottomButtonTemplate || this.scrollToBottomButtonComponent\n  );\n  \n  protected inputSlot = computed(() => \n    this.inputTemplate || this.inputComponent\n  );\n  \n  protected inputContainerSlot = computed(() => \n    this.inputContainerTemplate || this.inputContainerComponent\n  );\n  \n  protected featherSlot = computed(() => \n    this.featherTemplate || this.featherComponent\n  );\n  \n  protected disclaimerSlot = computed(() => \n    this.disclaimerTemplate || this.disclaimerComponent\n  );\n  \n  // Context objects for slots\n  protected scrollViewContext = computed(() => ({\n    autoScroll: this.autoScrollSignal(),\n    scrollToBottomButton: this.scrollToBottomButtonSlot(),\n    scrollToBottomButtonClass: this.scrollToBottomButtonClass,\n    inputContainerHeight: this.inputContainerHeight(),\n    isResizing: this.isResizing(),\n    messages: this.messagesSignal(),\n    messageView: this.messageViewSlot(),\n    messageViewClass: this.messageViewClass\n  }));\n  \n  // Removed scrollViewPropsComputed - no longer needed\n  \n  protected inputContainerContext = computed(() => ({\n    input: this.inputSlot(),\n    disclaimer: this.disclaimerSlot(),\n    disclaimerText: this.disclaimerTextSignal(),\n    disclaimerClass: this.disclaimerClassSignal(),\n    inputContainerClass: this.inputContainerClass\n  }));\n  \n  // Removed inputContainerPropsComputed - no longer needed\n  \n  // Layout context for custom templates (render prop pattern)\n  protected layoutContext = computed(() => ({\n    messageView: this.messageViewSlot(),\n    input: this.inputSlot(),\n    scrollView: this.scrollViewSlot(),\n    scrollToBottomButton: this.scrollToBottomButtonSlot(),\n    feather: this.featherSlot(),\n    inputContainer: this.inputContainerSlot(),\n    disclaimer: this.disclaimerSlot()\n  }));\n  \n  private destroy$ = new Subject<void>();\n  private resizeTimeoutRef?: number;\n  \n  constructor(\n    private resizeObserverService: ResizeObserverService,\n    private cdr: ChangeDetectorRef,\n    private handlers: CopilotChatViewHandlersService\n  ) {\n    // Set up effect to handle resize state timeout\n    effect(() => {\n      const resizing = this.isResizing();\n      if (resizing && this.resizeTimeoutRef) {\n        clearTimeout(this.resizeTimeoutRef);\n        this.resizeTimeoutRef = undefined;\n      }\n    });\n  }\n  \n  ngOnInit(): void {\n    // Initialize signals with input values\n    this.messagesSignal.set(this.messages);\n    this.autoScrollSignal.set(this.autoScroll);\n    this.showCursorSignal.set(this.showCursor);\n    this.disclaimerTextSignal.set(this.disclaimerText);\n    this.disclaimerClassSignal.set(this.disclaimerClass);\n\n    // Initialize handler availability in the view-scoped service\n    this.handlers.hasAssistantThumbsUpHandler.set(this.assistantMessageThumbsUp.observed);\n    this.handlers.hasAssistantThumbsDownHandler.set(this.assistantMessageThumbsDown.observed);\n    this.handlers.hasAssistantReadAloudHandler.set(this.assistantMessageReadAloud.observed);\n    this.handlers.hasAssistantRegenerateHandler.set(this.assistantMessageRegenerate.observed);\n    this.handlers.hasUserCopyHandler.set(this.userMessageCopy.observed);\n    this.handlers.hasUserEditHandler.set(this.userMessageEdit.observed);\n  }\n  \n  ngOnChanges(): void {\n    // Update signals when inputs change\n    this.messagesSignal.set(this.messages);\n    this.autoScrollSignal.set(this.autoScroll);\n    this.showCursorSignal.set(this.showCursor);\n    this.disclaimerTextSignal.set(this.disclaimerText);\n    this.disclaimerClassSignal.set(this.disclaimerClass);\n\n    // Keep handler availability in sync\n    this.handlers.hasAssistantThumbsUpHandler.set(this.assistantMessageThumbsUp.observed);\n    this.handlers.hasAssistantThumbsDownHandler.set(this.assistantMessageThumbsDown.observed);\n    this.handlers.hasAssistantReadAloudHandler.set(this.assistantMessageReadAloud.observed);\n    this.handlers.hasAssistantRegenerateHandler.set(this.assistantMessageRegenerate.observed);\n    this.handlers.hasUserCopyHandler.set(this.userMessageCopy.observed);\n    this.handlers.hasUserEditHandler.set(this.userMessageEdit.observed);\n  }\n  \n  ngAfterViewInit(): void {\n    // Don't set a default height - measure it dynamically\n    \n    // Set up input container height monitoring\n    const measureAndObserve = () => {\n      if (!this.inputContainerSlotRef || !this.inputContainerSlotRef.nativeElement) {\n        return false;\n      }\n      \n      // The slot ref points to the copilot-slot element\n      // We need to find the actual input container component inside it\n      const slotElement = this.inputContainerSlotRef.nativeElement;\n      const componentElement = slotElement.querySelector('copilot-chat-view-input-container');\n      \n      if (!componentElement) {\n        return false;\n      }\n      \n      // Look for the absolute positioned div that contains the input\n      let innerDiv = componentElement.querySelector('div.absolute') as HTMLElement;\n      \n      // If not found by class, try first child\n      if (!innerDiv) {\n        innerDiv = componentElement.firstElementChild as HTMLElement;\n      }\n      \n      if (!innerDiv) {\n        return false;\n      }\n      \n      // Measure the actual height\n      const measuredHeight = innerDiv.offsetHeight;\n      \n      if (measuredHeight === 0) {\n        return false;\n      }\n      \n      // Success! Set the initial height\n      this.inputContainerHeight.set(measuredHeight);\n      this.cdr.detectChanges();\n      \n      // Create an ElementRef wrapper for ResizeObserver\n      const innerDivRef = new ElementRef(innerDiv);\n      \n      // Set up ResizeObserver to track changes\n      this.resizeObserverService.observeElement(innerDivRef, 0, 250)\n        .pipe(takeUntil(this.destroy$))\n        .subscribe(state => {\n          const newHeight = state.height;\n          \n          if (newHeight !== this.inputContainerHeight() && newHeight > 0) {\n            this.inputContainerHeight.set(newHeight);\n            this.isResizing.set(true);\n            this.cdr.detectChanges();\n            \n            // Clear existing timeout\n            if (this.resizeTimeoutRef) {\n              clearTimeout(this.resizeTimeoutRef);\n            }\n            \n            // Set isResizing to false after a short delay\n            this.resizeTimeoutRef = window.setTimeout(() => {\n              this.isResizing.set(false);\n              this.resizeTimeoutRef = undefined;\n              this.cdr.detectChanges();\n            }, 250);\n          }\n        });\n      \n      return true;\n    };\n    \n    // Try to measure immediately\n    if (!measureAndObserve()) {\n      // If failed, retry with increasing delays\n      let attempts = 0;\n      const maxAttempts = 10;\n      \n      const retry = () => {\n        attempts++;\n        if (measureAndObserve()) {\n          // Successfully measured\n        } else if (attempts < maxAttempts) {\n          // Exponential backoff: 50ms, 100ms, 200ms, 400ms, etc.\n          const delay = 50 * Math.pow(2, Math.min(attempts - 1, 4));\n          setTimeout(retry, delay);\n        } else {\n          // Failed to measure after max attempts\n        }\n      };\n      \n      // Start retry with first delay\n      setTimeout(retry, 50);\n    }\n  }\n  \n  ngOnDestroy(): void {\n    if (this.resizeTimeoutRef) {\n      clearTimeout(this.resizeTimeoutRef);\n    }\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n}\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29waWxvdC1jaGF0LXZpZXcudHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9jaGF0L2NvcGlsb3QtY2hhdC12aWV3LnR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUeXBlLCBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTWVzc2FnZSB9IGZyb20gJ0BhZy11aS9jbGllbnQnO1xuXG4vKipcbiAqIFByb3BzIGZvciBDb3BpbG90Q2hhdFZpZXcgY29tcG9uZW50XG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQ29waWxvdENoYXRWaWV3UHJvcHMge1xuICBtZXNzYWdlcz86IE1lc3NhZ2VbXTtcbiAgYXV0b1Njcm9sbD86IGJvb2xlYW47XG4gIFxuICAvLyBTbG90IGNvbmZpZ3VyYXRpb25zXG4gIG1lc3NhZ2VWaWV3Q29tcG9uZW50PzogVHlwZTxhbnk+O1xuICBtZXNzYWdlVmlld1RlbXBsYXRlPzogVGVtcGxhdGVSZWY8YW55PjtcbiAgbWVzc2FnZVZpZXdDbGFzcz86IHN0cmluZztcbiAgXG4gIHNjcm9sbFZpZXdDb21wb25lbnQ/OiBUeXBlPGFueT47XG4gIHNjcm9sbFZpZXdUZW1wbGF0ZT86IFRlbXBsYXRlUmVmPGFueT47XG4gIHNjcm9sbFZpZXdDbGFzcz86IHN0cmluZztcbiAgXG4gIHNjcm9sbFRvQm90dG9tQnV0dG9uQ29tcG9uZW50PzogVHlwZTxhbnk+O1xuICBzY3JvbGxUb0JvdHRvbUJ1dHRvblRlbXBsYXRlPzogVGVtcGxhdGVSZWY8YW55PjtcbiAgc2Nyb2xsVG9Cb3R0b21CdXR0b25DbGFzcz86IHN0cmluZztcbiAgXG4gIGlucHV0Q29tcG9uZW50PzogVHlwZTxhbnk+O1xuICBpbnB1dFRlbXBsYXRlPzogVGVtcGxhdGVSZWY8YW55PjtcbiAgXG4gIGlucHV0Q29udGFpbmVyQ29tcG9uZW50PzogVHlwZTxhbnk+O1xuICBpbnB1dENvbnRhaW5lclRlbXBsYXRlPzogVGVtcGxhdGVSZWY8YW55PjtcbiAgaW5wdXRDb250YWluZXJDbGFzcz86IHN0cmluZztcbiAgXG4gIGZlYXRoZXJDb21wb25lbnQ/OiBUeXBlPGFueT47XG4gIGZlYXRoZXJUZW1wbGF0ZT86IFRlbXBsYXRlUmVmPGFueT47XG4gIGZlYXRoZXJDbGFzcz86IHN0cmluZztcbiAgXG4gIGRpc2NsYWltZXJDb21wb25lbnQ/OiBUeXBlPGFueT47XG4gIGRpc2NsYWltZXJUZW1wbGF0ZT86IFRlbXBsYXRlUmVmPGFueT47XG4gIGRpc2NsYWltZXJDbGFzcz86IHN0cmluZztcbiAgZGlzY2xhaW1lclRleHQ/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogQ29udGV4dCBmb3IgY3VzdG9tIGxheW91dCB0ZW1wbGF0ZVxuICovXG5leHBvcnQgaW50ZXJmYWNlIENvcGlsb3RDaGF0Vmlld0xheW91dENvbnRleHQge1xuICBtZXNzYWdlVmlldzogYW55O1xuICBpbnB1dDogYW55O1xuICBzY3JvbGxWaWV3OiBhbnk7XG4gIHNjcm9sbFRvQm90dG9tQnV0dG9uOiBhbnk7XG4gIGZlYXRoZXI6IGFueTtcbiAgaW5wdXRDb250YWluZXI6IGFueTtcbiAgZGlzY2xhaW1lcjogYW55O1xufVxuIl19