@copilotkitnext/angular 0.0.1 → 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 (171) hide show
  1. package/README.md +248 -0
  2. package/dist/README.md +248 -0
  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/dist/styles.css +0 -27
  72. package/package.json +23 -20
  73. package/vitest.config.mts +32 -21
  74. package/.turbo/turbo-build.log +0 -39
  75. package/.turbo/turbo-check-types.log +0 -0
  76. package/.turbo/turbo-test.log +0 -71
  77. package/README-agent-context.md +0 -310
  78. package/ng-package.json +0 -19
  79. package/slots.md +0 -331
  80. package/src/components/chat/__tests__/copilot-chat-assistant-message.component.spec.ts +0 -282
  81. package/src/components/chat/__tests__/copilot-chat-input.component.spec.ts +0 -419
  82. package/src/components/chat/__tests__/copilot-chat-message-view.component.spec.ts +0 -372
  83. package/src/components/chat/__tests__/copilot-chat-user-message.component.spec.ts +0 -249
  84. package/src/components/chat/copilot-chat-assistant-message-buttons.component.ts +0 -292
  85. package/src/components/chat/copilot-chat-assistant-message-renderer.component.ts +0 -472
  86. package/src/components/chat/copilot-chat-assistant-message-toolbar.component.ts +0 -29
  87. package/src/components/chat/copilot-chat-assistant-message.component.ts +0 -463
  88. package/src/components/chat/copilot-chat-assistant-message.types.ts +0 -50
  89. package/src/components/chat/copilot-chat-audio-recorder.component.ts +0 -241
  90. package/src/components/chat/copilot-chat-buttons.component.ts +0 -308
  91. package/src/components/chat/copilot-chat-buttons.component.ts.bak +0 -471
  92. package/src/components/chat/copilot-chat-input-defaults.ts +0 -47
  93. package/src/components/chat/copilot-chat-input.component.ts +0 -512
  94. package/src/components/chat/copilot-chat-input.types.ts +0 -148
  95. package/src/components/chat/copilot-chat-message-view-cursor.component.ts +0 -51
  96. package/src/components/chat/copilot-chat-message-view.component.ts +0 -233
  97. package/src/components/chat/copilot-chat-message-view.types.ts +0 -39
  98. package/src/components/chat/copilot-chat-textarea.component.ts +0 -220
  99. package/src/components/chat/copilot-chat-tool-calls-view.component.ts +0 -261
  100. package/src/components/chat/copilot-chat-toolbar.component.ts +0 -35
  101. package/src/components/chat/copilot-chat-tools-menu.component.ts +0 -185
  102. package/src/components/chat/copilot-chat-user-message-branch-navigation.component.ts +0 -121
  103. package/src/components/chat/copilot-chat-user-message-buttons.component.ts +0 -170
  104. package/src/components/chat/copilot-chat-user-message-renderer.component.ts +0 -37
  105. package/src/components/chat/copilot-chat-user-message-toolbar.component.ts +0 -37
  106. package/src/components/chat/copilot-chat-user-message.component.ts +0 -247
  107. package/src/components/chat/copilot-chat-user-message.types.ts +0 -42
  108. package/src/components/chat/copilot-chat-view-disclaimer.component.ts +0 -51
  109. package/src/components/chat/copilot-chat-view-feather.component.ts +0 -47
  110. package/src/components/chat/copilot-chat-view-handlers.service.ts +0 -14
  111. package/src/components/chat/copilot-chat-view-input-container.component.ts +0 -87
  112. package/src/components/chat/copilot-chat-view-scroll-to-bottom-button.component.ts +0 -79
  113. package/src/components/chat/copilot-chat-view-scroll-view.component.ts +0 -322
  114. package/src/components/chat/copilot-chat-view.component.ts +0 -420
  115. package/src/components/chat/copilot-chat-view.types.ts +0 -52
  116. package/src/components/chat/copilot-chat.component.ts +0 -232
  117. package/src/components/copilotkit-tool-render.component.ts +0 -169
  118. package/src/core/__tests__/copilotkit.service.spec.ts +0 -1051
  119. package/src/core/__tests__/copilotkit.service.wildcard.spec.ts +0 -316
  120. package/src/core/chat-configuration/__tests__/chat-configuration.service.spec.ts +0 -287
  121. package/src/core/chat-configuration/chat-configuration.providers.ts +0 -71
  122. package/src/core/chat-configuration/chat-configuration.service.ts +0 -162
  123. package/src/core/chat-configuration/chat-configuration.types.ts +0 -57
  124. package/src/core/copilotkit.providers.ts +0 -59
  125. package/src/core/copilotkit.service.ts +0 -542
  126. package/src/core/copilotkit.types.ts +0 -132
  127. package/src/directives/__tests__/copilotkit-agent-context.directive.spec.ts +0 -384
  128. package/src/directives/__tests__/copilotkit-agent.directive.spec.ts +0 -253
  129. package/src/directives/__tests__/copilotkit-chat-config.directive.spec.ts +0 -385
  130. package/src/directives/__tests__/copilotkit-config.directive.spec.ts +0 -69
  131. package/src/directives/__tests__/copilotkit-frontend-tool-simple.directive.spec.ts +0 -60
  132. package/src/directives/__tests__/copilotkit-frontend-tool.directive.spec.ts +0 -108
  133. package/src/directives/__tests__/copilotkit-human-in-the-loop.directive.spec.ts +0 -452
  134. package/src/directives/copilotkit-agent-context.directive.ts +0 -138
  135. package/src/directives/copilotkit-agent.directive.ts +0 -225
  136. package/src/directives/copilotkit-chat-config.directive.ts +0 -241
  137. package/src/directives/copilotkit-config.directive.ts +0 -81
  138. package/src/directives/copilotkit-frontend-tool.directive.ts +0 -145
  139. package/src/directives/copilotkit-human-in-the-loop.directive.ts +0 -281
  140. package/src/directives/stick-to-bottom.directive.ts +0 -204
  141. package/src/index.ts +0 -105
  142. package/src/lib/directives/tooltip.directive.ts +0 -292
  143. package/src/lib/slots/__tests__/slot.utils.spec.ts +0 -377
  144. package/src/lib/slots/copilot-slot.component.ts +0 -135
  145. package/src/lib/slots/index.ts +0 -3
  146. package/src/lib/slots/slot.types.ts +0 -64
  147. package/src/lib/slots/slot.utils.ts +0 -289
  148. package/src/lib/utils.ts +0 -10
  149. package/src/public-api.ts +0 -1
  150. package/src/services/resize-observer.service.ts +0 -181
  151. package/src/services/scroll-position.service.ts +0 -169
  152. package/src/styles/globals.css +0 -266
  153. package/src/styles/index.css +0 -3
  154. package/src/test-setup.ts +0 -15
  155. package/src/testing/index.ts +0 -3
  156. package/src/testing/testing.utils.ts +0 -248
  157. package/src/types/frontend-tool.ts +0 -44
  158. package/src/types/human-in-the-loop.ts +0 -52
  159. package/src/utils/__tests__/agent.utils.spec.ts +0 -234
  160. package/src/utils/__tests__/chat-config.utils.spec.ts +0 -306
  161. package/src/utils/__tests__/frontend-tool-inject.spec.ts +0 -350
  162. package/src/utils/__tests__/frontend-tool-integration.spec.ts +0 -199
  163. package/src/utils/__tests__/frontend-tool.utils.spec.ts +0 -272
  164. package/src/utils/__tests__/human-in-the-loop.utils.spec.ts +0 -365
  165. package/src/utils/agent-context.utils.ts +0 -133
  166. package/src/utils/agent.utils.ts +0 -239
  167. package/src/utils/chat-config.utils.ts +0 -221
  168. package/src/utils/copilotkit.utils.ts +0 -20
  169. package/src/utils/frontend-tool.utils.ts +0 -266
  170. package/src/utils/human-in-the-loop.utils.ts +0 -359
  171. package/tsconfig.spec.json +0 -12
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29waWxvdC1jaGF0LWFzc2lzdGFudC1tZXNzYWdlLnR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvY2hhdC9jb3BpbG90LWNoYXQtYXNzaXN0YW50LW1lc3NhZ2UudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFzc2lzdGFudE1lc3NhZ2UgfSBmcm9tICdAYWctdWkvY2xpZW50JztcblxuLy8gQ29udGV4dCBpbnRlcmZhY2VzIGZvciBzbG90c1xuZXhwb3J0IGludGVyZmFjZSBBc3Npc3RhbnRNZXNzYWdlTWFya2Rvd25SZW5kZXJlckNvbnRleHQge1xuICBjb250ZW50OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQXNzaXN0YW50TWVzc2FnZVRvb2xiYXJDb250ZXh0IHtcbiAgY2hpbGRyZW4/OiBhbnk7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQXNzaXN0YW50TWVzc2FnZUNvcHlCdXR0b25Db250ZXh0IHtcbiAgY29udGVudD86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBUaHVtYnNVcEJ1dHRvbkNvbnRleHQge1xuICAvLyBFbXB0eSBjb250ZXh0IC0gY2xpY2sgaGFuZGxlZCB2aWEgb3V0cHV0cyBtYXBcbn1cblxuZXhwb3J0IGludGVyZmFjZSBUaHVtYnNEb3duQnV0dG9uQ29udGV4dCB7XG4gIC8vIEVtcHR5IGNvbnRleHQgLSBjbGljayBoYW5kbGVkIHZpYSBvdXRwdXRzIG1hcFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIFJlYWRBbG91ZEJ1dHRvbkNvbnRleHQge1xuICAvLyBFbXB0eSBjb250ZXh0IC0gY2xpY2sgaGFuZGxlZCB2aWEgb3V0cHV0cyBtYXBcbn1cblxuZXhwb3J0IGludGVyZmFjZSBSZWdlbmVyYXRlQnV0dG9uQ29udGV4dCB7XG4gIC8vIEVtcHR5IGNvbnRleHQgLSBjbGljayBoYW5kbGVkIHZpYSBvdXRwdXRzIG1hcFxufVxuXG4vLyBFdmVudCBoYW5kbGVyIHByb3BzXG5leHBvcnQgaW50ZXJmYWNlIENvcGlsb3RDaGF0QXNzaXN0YW50TWVzc2FnZU9uVGh1bWJzVXBQcm9wcyB7XG4gIG1lc3NhZ2U6IEFzc2lzdGFudE1lc3NhZ2U7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29waWxvdENoYXRBc3Npc3RhbnRNZXNzYWdlT25UaHVtYnNEb3duUHJvcHMge1xuICBtZXNzYWdlOiBBc3Npc3RhbnRNZXNzYWdlO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIENvcGlsb3RDaGF0QXNzaXN0YW50TWVzc2FnZU9uUmVhZEFsb3VkUHJvcHMge1xuICBtZXNzYWdlOiBBc3Npc3RhbnRNZXNzYWdlO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIENvcGlsb3RDaGF0QXNzaXN0YW50TWVzc2FnZU9uUmVnZW5lcmF0ZVByb3BzIHtcbiAgbWVzc2FnZTogQXNzaXN0YW50TWVzc2FnZTtcbn1cblxuLy8gUmUtZXhwb3J0IGZvciBjb252ZW5pZW5jZVxuZXhwb3J0IHR5cGUgeyBBc3Npc3RhbnRNZXNzYWdlIH07Il19
@@ -0,0 +1,202 @@
1
+ import { Component, Input, Output, EventEmitter, ViewChild, signal, computed, ChangeDetectionStrategy, ViewEncapsulation } from '@angular/core';
2
+ import { AudioRecorderError } from './copilot-chat-input.types';
3
+ import * as i0 from "@angular/core";
4
+ export class CopilotChatAudioRecorderComponent {
5
+ canvasRef;
6
+ set inputClass(val) {
7
+ this.customClass.set(val);
8
+ }
9
+ set inputShowControls(val) {
10
+ this.showControls.set(val ?? false);
11
+ }
12
+ stateChange = new EventEmitter();
13
+ error = new EventEmitter();
14
+ // Signals for state management
15
+ state = signal('idle');
16
+ customClass = signal(undefined);
17
+ showControls = signal(false);
18
+ // Computed values
19
+ computedClass = computed(() => {
20
+ const baseClasses = 'h-11 w-full px-5';
21
+ return `${baseClasses} ${this.customClass() || ''}`;
22
+ });
23
+ statusText = computed(() => {
24
+ switch (this.state()) {
25
+ case 'recording':
26
+ return 'Recording...';
27
+ case 'processing':
28
+ return 'Processing...';
29
+ default:
30
+ return 'Ready';
31
+ }
32
+ });
33
+ // Animation and canvas properties
34
+ animationFrameId;
35
+ ngAfterViewInit() {
36
+ this.startAnimation();
37
+ }
38
+ ngOnDestroy() {
39
+ this.dispose();
40
+ }
41
+ /**
42
+ * Start recording audio
43
+ */
44
+ async start() {
45
+ try {
46
+ if (this.state() === 'recording') {
47
+ return;
48
+ }
49
+ this.setState('recording');
50
+ this.startAnimation();
51
+ // In a real implementation, this would start actual audio recording
52
+ // For now, we just simulate the recording state
53
+ }
54
+ catch (err) {
55
+ const error = new AudioRecorderError(err instanceof Error ? err.message : 'Failed to start recording');
56
+ this.error.emit(error);
57
+ this.setState('idle');
58
+ throw error;
59
+ }
60
+ }
61
+ /**
62
+ * Stop recording audio and return blob
63
+ */
64
+ async stop() {
65
+ try {
66
+ this.setState('idle');
67
+ // Return empty blob - stub implementation
68
+ const emptyBlob = new Blob([], { type: 'audio/webm' });
69
+ return emptyBlob;
70
+ }
71
+ catch (err) {
72
+ const error = new AudioRecorderError(err instanceof Error ? err.message : 'Failed to stop recording');
73
+ this.error.emit(error);
74
+ this.setState('idle');
75
+ throw error;
76
+ }
77
+ }
78
+ /**
79
+ * Get current recorder state
80
+ */
81
+ getState() {
82
+ return this.state();
83
+ }
84
+ /**
85
+ * Dispose of resources
86
+ */
87
+ dispose() {
88
+ this.stopAnimation();
89
+ }
90
+ setState(state) {
91
+ this.state.set(state);
92
+ this.stateChange.emit(state);
93
+ }
94
+ startAnimation() {
95
+ const canvas = this.canvasRef.nativeElement;
96
+ if (!canvas)
97
+ return;
98
+ const ctx = canvas.getContext('2d');
99
+ if (!ctx)
100
+ return;
101
+ const draw = () => {
102
+ const rect = canvas.getBoundingClientRect();
103
+ const dpr = window.devicePixelRatio || 1;
104
+ // Update canvas dimensions if container resized
105
+ if (canvas.width !== rect.width * dpr ||
106
+ canvas.height !== rect.height * dpr) {
107
+ canvas.width = rect.width * dpr;
108
+ canvas.height = rect.height * dpr;
109
+ ctx.scale(dpr, dpr);
110
+ ctx.imageSmoothingEnabled = false;
111
+ }
112
+ // Configuration
113
+ const barWidth = 2;
114
+ const minHeight = 2;
115
+ const maxHeight = 20;
116
+ const gap = 2;
117
+ const numSamples = Math.ceil(rect.width / (barWidth + gap));
118
+ // Get loudness data
119
+ const loudnessData = this.getLoudness(numSamples);
120
+ // Clear canvas
121
+ ctx.clearRect(0, 0, rect.width, rect.height);
122
+ // Get current foreground color
123
+ const computedStyle = getComputedStyle(canvas);
124
+ const currentForeground = computedStyle.color;
125
+ // Draw bars
126
+ ctx.fillStyle = currentForeground;
127
+ const centerY = rect.height / 2;
128
+ for (let i = 0; i < loudnessData.length; i++) {
129
+ const sample = loudnessData[i] ?? 0;
130
+ const barHeight = Math.round(sample * (maxHeight - minHeight) + minHeight);
131
+ const x = Math.round(i * (barWidth + gap));
132
+ const y = Math.round(centerY - barHeight / 2);
133
+ ctx.fillRect(x, y, barWidth, barHeight);
134
+ }
135
+ this.animationFrameId = requestAnimationFrame(draw);
136
+ };
137
+ draw();
138
+ }
139
+ stopAnimation() {
140
+ if (this.animationFrameId) {
141
+ cancelAnimationFrame(this.animationFrameId);
142
+ this.animationFrameId = undefined;
143
+ }
144
+ }
145
+ getLoudness(n) {
146
+ const elapsed = Date.now() / 1000; // Use current timestamp directly
147
+ const samples = [];
148
+ for (let i = 0; i < n; i++) {
149
+ // Create a position that moves from left to right over time
150
+ const position = (i / n) * 10 + elapsed * 0.5; // Scroll speed (slower)
151
+ // Generate waveform using multiple sine waves for realism
152
+ const wave1 = Math.sin(position * 2) * 0.3;
153
+ const wave2 = Math.sin(position * 5 + elapsed) * 0.2;
154
+ const wave3 = Math.sin(position * 0.5 + elapsed * 0.3) * 0.4;
155
+ // Add some randomness for natural variation
156
+ const noise = (Math.random() - 0.5) * 0.1;
157
+ // Combine waves and add envelope for realistic amplitude variation
158
+ const envelope = Math.sin(elapsed * 0.7) * 0.5 + 0.5; // Slow amplitude modulation
159
+ let amplitude = (wave1 + wave2 + wave3 + noise) * envelope;
160
+ // Clamp to 0-1 range
161
+ amplitude = Math.max(0, Math.min(1, amplitude * 0.5 + 0.3));
162
+ samples.push(amplitude);
163
+ }
164
+ return samples;
165
+ }
166
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CopilotChatAudioRecorderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
167
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CopilotChatAudioRecorderComponent, isStandalone: true, selector: "copilot-chat-audio-recorder", inputs: { inputClass: "inputClass", inputShowControls: "inputShowControls" }, outputs: { stateChange: "stateChange", error: "error" }, host: { properties: { "class.copilot-chat-audio-recorder": "true" } }, viewQueries: [{ propertyName: "canvasRef", first: true, predicate: ["canvasRef"], descendants: true, static: true }], ngImport: i0, template: `
168
+ <div [class]="computedClass()">
169
+ <canvas
170
+ #canvasRef
171
+ class="w-full h-full"
172
+ [style.imageRendering]="'pixelated'"
173
+ ></canvas>
174
+ </div>
175
+ `, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
176
+ }
177
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CopilotChatAudioRecorderComponent, decorators: [{
178
+ type: Component,
179
+ args: [{ selector: 'copilot-chat-audio-recorder', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: `
180
+ <div [class]="computedClass()">
181
+ <canvas
182
+ #canvasRef
183
+ class="w-full h-full"
184
+ [style.imageRendering]="'pixelated'"
185
+ ></canvas>
186
+ </div>
187
+ `, host: {
188
+ '[class.copilot-chat-audio-recorder]': 'true'
189
+ } }]
190
+ }], propDecorators: { canvasRef: [{
191
+ type: ViewChild,
192
+ args: ['canvasRef', { static: true }]
193
+ }], inputClass: [{
194
+ type: Input
195
+ }], inputShowControls: [{
196
+ type: Input
197
+ }], stateChange: [{
198
+ type: Output
199
+ }], error: [{
200
+ type: Output
201
+ }] } });
202
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"copilot-chat-audio-recorder.component.js","sourceRoot":"","sources":["../../../../src/components/chat/copilot-chat-audio-recorder.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  ViewChild,\n  ElementRef,\n  AfterViewInit,\n  OnDestroy,\n  signal,\n  computed,\n  ChangeDetectionStrategy,\n  ViewEncapsulation\n} from '@angular/core';\nimport { AudioRecorderState, AudioRecorderError } from './copilot-chat-input.types';\n\n@Component({\n  selector: 'copilot-chat-audio-recorder',\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  template: `\n    <div [class]=\"computedClass()\">\n      <canvas\n        #canvasRef\n        class=\"w-full h-full\"\n        [style.imageRendering]=\"'pixelated'\"\n      ></canvas>\n    </div>\n  `,\n  styles: [],\n  host: {\n    '[class.copilot-chat-audio-recorder]': 'true'\n  }\n})\nexport class CopilotChatAudioRecorderComponent implements AfterViewInit, OnDestroy {\n  @ViewChild('canvasRef', { static: true }) canvasRef!: ElementRef<HTMLCanvasElement>;\n  \n  @Input() set inputClass(val: string | undefined) {\n    this.customClass.set(val);\n  }\n  \n  @Input() set inputShowControls(val: boolean | undefined) {\n    this.showControls.set(val ?? false);\n  }\n  \n  @Output() stateChange = new EventEmitter<AudioRecorderState>();\n  @Output() error = new EventEmitter<AudioRecorderError>();\n  \n  // Signals for state management\n  state = signal<AudioRecorderState>('idle');\n  customClass = signal<string | undefined>(undefined);\n  showControls = signal<boolean>(false);\n  \n  // Computed values\n  computedClass = computed(() => {\n    const baseClasses = 'h-11 w-full px-5';\n    return `${baseClasses} ${this.customClass() || ''}`;\n  });\n  \n  statusText = computed(() => {\n    switch (this.state()) {\n      case 'recording':\n        return 'Recording...';\n      case 'processing':\n        return 'Processing...';\n      default:\n        return 'Ready';\n    }\n  });\n  \n  // Animation and canvas properties\n  private animationFrameId?: number;\n  \n  ngAfterViewInit(): void {\n    this.startAnimation();\n  }\n  \n  ngOnDestroy(): void {\n    this.dispose();\n  }\n  \n  /**\n   * Start recording audio\n   */\n  async start(): Promise<void> {\n    try {\n      if (this.state() === 'recording') {\n        return;\n      }\n      \n      this.setState('recording');\n      this.startAnimation();\n      \n      // In a real implementation, this would start actual audio recording\n      // For now, we just simulate the recording state\n      \n    } catch (err) {\n      const error = new AudioRecorderError(\n        err instanceof Error ? err.message : 'Failed to start recording'\n      );\n      this.error.emit(error);\n      this.setState('idle');\n      throw error;\n    }\n  }\n  \n  /**\n   * Stop recording audio and return blob\n   */\n  async stop(): Promise<Blob> {\n    try {\n      this.setState('idle');\n      // Return empty blob - stub implementation\n      const emptyBlob = new Blob([], { type: 'audio/webm' });\n      return emptyBlob;\n    } catch (err) {\n      const error = new AudioRecorderError(\n        err instanceof Error ? err.message : 'Failed to stop recording'\n      );\n      this.error.emit(error);\n      this.setState('idle');\n      throw error;\n    }\n  }\n  \n  /**\n   * Get current recorder state\n   */\n  getState(): AudioRecorderState {\n    return this.state();\n  }\n  \n  /**\n   * Dispose of resources\n   */\n  dispose(): void {\n    this.stopAnimation();\n  }\n\n  private setState(state: AudioRecorderState): void {\n    this.state.set(state);\n    this.stateChange.emit(state);\n  }\n  \n  private startAnimation(): void {\n    const canvas = this.canvasRef.nativeElement;\n    if (!canvas) return;\n\n    const ctx = canvas.getContext('2d');\n    if (!ctx) return;\n\n    const draw = () => {\n      const rect = canvas.getBoundingClientRect();\n      const dpr = window.devicePixelRatio || 1;\n\n      // Update canvas dimensions if container resized\n      if (\n        canvas.width !== rect.width * dpr ||\n        canvas.height !== rect.height * dpr\n      ) {\n        canvas.width = rect.width * dpr;\n        canvas.height = rect.height * dpr;\n        ctx.scale(dpr, dpr);\n        ctx.imageSmoothingEnabled = false;\n      }\n\n      // Configuration\n      const barWidth = 2;\n      const minHeight = 2;\n      const maxHeight = 20;\n      const gap = 2;\n      const numSamples = Math.ceil(rect.width / (barWidth + gap));\n\n      // Get loudness data\n      const loudnessData = this.getLoudness(numSamples);\n\n      // Clear canvas\n      ctx.clearRect(0, 0, rect.width, rect.height);\n\n      // Get current foreground color\n      const computedStyle = getComputedStyle(canvas);\n      const currentForeground = computedStyle.color;\n\n      // Draw bars\n      ctx.fillStyle = currentForeground;\n      const centerY = rect.height / 2;\n\n      for (let i = 0; i < loudnessData.length; i++) {\n        const sample = loudnessData[i] ?? 0;\n        const barHeight = Math.round(\n          sample * (maxHeight - minHeight) + minHeight\n        );\n        const x = Math.round(i * (barWidth + gap));\n        const y = Math.round(centerY - barHeight / 2);\n\n        ctx.fillRect(x, y, barWidth, barHeight);\n      }\n\n      this.animationFrameId = requestAnimationFrame(draw);\n    };\n\n    draw();\n  }\n  \n  private stopAnimation(): void {\n    if (this.animationFrameId) {\n      cancelAnimationFrame(this.animationFrameId);\n      this.animationFrameId = undefined;\n    }\n  }\n\n  private getLoudness(n: number): number[] {\n    const elapsed = Date.now() / 1000; // Use current timestamp directly\n    const samples: number[] = [];\n\n    for (let i = 0; i < n; i++) {\n      // Create a position that moves from left to right over time\n      const position = (i / n) * 10 + elapsed * 0.5; // Scroll speed (slower)\n\n      // Generate waveform using multiple sine waves for realism\n      const wave1 = Math.sin(position * 2) * 0.3;\n      const wave2 = Math.sin(position * 5 + elapsed) * 0.2;\n      const wave3 = Math.sin(position * 0.5 + elapsed * 0.3) * 0.4;\n\n      // Add some randomness for natural variation\n      const noise = (Math.random() - 0.5) * 0.1;\n\n      // Combine waves and add envelope for realistic amplitude variation\n      const envelope = Math.sin(elapsed * 0.7) * 0.5 + 0.5; // Slow amplitude modulation\n      let amplitude = (wave1 + wave2 + wave3 + noise) * envelope;\n\n      // Clamp to 0-1 range\n      amplitude = Math.max(0, Math.min(1, amplitude * 0.5 + 0.3));\n\n      samples.push(amplitude);\n    }\n\n    return samples;\n  }\n}"]}
@@ -0,0 +1,321 @@
1
+ import { Component, Input, Output, EventEmitter, ChangeDetectionStrategy, inject, signal, computed, ViewEncapsulation } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { LucideAngularModule, ArrowUp, Mic, X, Check, Plus } from 'lucide-angular';
4
+ import { CopilotChatConfigurationService } from '../../core/chat-configuration/chat-configuration.service';
5
+ import { CopilotTooltipDirective } from '../../lib/directives/tooltip.directive';
6
+ import { cn } from '../../lib/utils';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "lucide-angular";
9
+ // Base button classes matching React's button variants
10
+ const buttonBase = cn('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]');
11
+ const chatInputToolbarPrimary = cn('cursor-pointer',
12
+ // Background and text
13
+ 'bg-black text-white',
14
+ // Dark mode
15
+ 'dark:bg-white dark:text-black dark:focus-visible:outline-white',
16
+ // Shape and sizing
17
+ 'rounded-full h-9 w-9',
18
+ // Interactions
19
+ 'transition-colors',
20
+ // Focus states
21
+ 'focus:outline-none',
22
+ // Hover states
23
+ 'hover:opacity-70 disabled:hover:opacity-100',
24
+ // Disabled states
25
+ 'disabled:cursor-not-allowed disabled:bg-[#00000014] disabled:text-[rgb(13,13,13)]', 'dark:disabled:bg-[#454545] dark:disabled:text-white');
26
+ const chatInputToolbarSecondary = cn('cursor-pointer',
27
+ // Background and text
28
+ 'bg-transparent text-[#444444]',
29
+ // Dark mode
30
+ 'dark:text-white dark:border-[#404040]',
31
+ // Shape and sizing
32
+ 'rounded-full h-9 w-9',
33
+ // Interactions
34
+ 'transition-colors',
35
+ // Focus states
36
+ 'focus:outline-none',
37
+ // Hover states
38
+ 'hover:bg-[#f8f8f8] hover:text-[#333333]', 'dark:hover:bg-[#404040] dark:hover:text-[#FFFFFF]',
39
+ // Disabled states
40
+ 'disabled:cursor-not-allowed disabled:opacity-50', 'disabled:hover:bg-transparent disabled:hover:text-[#444444]', 'dark:disabled:hover:bg-transparent dark:disabled:hover:text-[#CCCCCC]');
41
+ export class CopilotChatSendButtonComponent {
42
+ disabled = false;
43
+ clicked = new EventEmitter();
44
+ ArrowUpIcon = ArrowUp;
45
+ buttonClass = cn(buttonBase, chatInputToolbarPrimary);
46
+ onClick() {
47
+ if (!this.disabled) {
48
+ this.clicked.emit();
49
+ }
50
+ }
51
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CopilotChatSendButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
52
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CopilotChatSendButtonComponent, isStandalone: true, selector: "copilot-chat-send-button", inputs: { disabled: "disabled" }, outputs: { clicked: "clicked" }, ngImport: i0, template: `
53
+ <div class="mr-[10px]">
54
+ <button
55
+ type="button"
56
+ [disabled]="disabled"
57
+ [class]="buttonClass"
58
+ (click)="onClick()"
59
+ >
60
+ <lucide-angular [img]="ArrowUpIcon" [size]="18"></lucide-angular>
61
+ </button>
62
+ </div>
63
+ `, isInline: true, styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: LucideAngularModule }, { kind: "component", type: i1.LucideAngularComponent, selector: "lucide-angular, lucide-icon, i-lucide, span-lucide", inputs: ["class", "name", "img", "color", "absoluteStrokeWidth", "size", "strokeWidth"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
64
+ }
65
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CopilotChatSendButtonComponent, decorators: [{
66
+ type: Component,
67
+ args: [{ selector: 'copilot-chat-send-button', standalone: true, imports: [CommonModule, LucideAngularModule], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: `
68
+ <div class="mr-[10px]">
69
+ <button
70
+ type="button"
71
+ [disabled]="disabled"
72
+ [class]="buttonClass"
73
+ (click)="onClick()"
74
+ >
75
+ <lucide-angular [img]="ArrowUpIcon" [size]="18"></lucide-angular>
76
+ </button>
77
+ </div>
78
+ ` }]
79
+ }], propDecorators: { disabled: [{
80
+ type: Input
81
+ }], clicked: [{
82
+ type: Output
83
+ }] } });
84
+ export class CopilotChatStartTranscribeButtonComponent {
85
+ disabled = false;
86
+ clicked = new EventEmitter();
87
+ chatConfig = inject(CopilotChatConfigurationService);
88
+ MicIcon = Mic;
89
+ buttonClass = cn(buttonBase, chatInputToolbarSecondary, 'mr-2');
90
+ get label() {
91
+ return this.chatConfig.labels().chatInputToolbarStartTranscribeButtonLabel;
92
+ }
93
+ onClick() {
94
+ if (!this.disabled) {
95
+ this.clicked.emit();
96
+ }
97
+ }
98
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CopilotChatStartTranscribeButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
99
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CopilotChatStartTranscribeButtonComponent, isStandalone: true, selector: "copilot-chat-start-transcribe-button", inputs: { disabled: "disabled" }, outputs: { clicked: "clicked" }, ngImport: i0, template: `
100
+ <button
101
+ type="button"
102
+ [disabled]="disabled"
103
+ [class]="buttonClass"
104
+ [copilotTooltip]="label"
105
+ tooltipPosition="below"
106
+ (click)="onClick()"
107
+ >
108
+ <lucide-angular [img]="MicIcon" [size]="18"></lucide-angular>
109
+ </button>
110
+ `, isInline: true, styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: LucideAngularModule }, { kind: "component", type: i1.LucideAngularComponent, selector: "lucide-angular, lucide-icon, i-lucide, span-lucide", inputs: ["class", "name", "img", "color", "absoluteStrokeWidth", "size", "strokeWidth"] }, { kind: "directive", type: CopilotTooltipDirective, selector: "[copilotTooltip]", inputs: ["copilotTooltip", "tooltipPosition", "tooltipDelay"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
111
+ }
112
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CopilotChatStartTranscribeButtonComponent, decorators: [{
113
+ type: Component,
114
+ args: [{ selector: 'copilot-chat-start-transcribe-button', standalone: true, imports: [CommonModule, LucideAngularModule, CopilotTooltipDirective], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: `
115
+ <button
116
+ type="button"
117
+ [disabled]="disabled"
118
+ [class]="buttonClass"
119
+ [copilotTooltip]="label"
120
+ tooltipPosition="below"
121
+ (click)="onClick()"
122
+ >
123
+ <lucide-angular [img]="MicIcon" [size]="18"></lucide-angular>
124
+ </button>
125
+ ` }]
126
+ }], propDecorators: { disabled: [{
127
+ type: Input
128
+ }], clicked: [{
129
+ type: Output
130
+ }] } });
131
+ export class CopilotChatCancelTranscribeButtonComponent {
132
+ disabled = false;
133
+ clicked = new EventEmitter();
134
+ chatConfig = inject(CopilotChatConfigurationService);
135
+ XIcon = X;
136
+ buttonClass = cn(buttonBase, chatInputToolbarSecondary, 'mr-2');
137
+ get label() {
138
+ return this.chatConfig.labels().chatInputToolbarCancelTranscribeButtonLabel;
139
+ }
140
+ onClick() {
141
+ if (!this.disabled) {
142
+ this.clicked.emit();
143
+ }
144
+ }
145
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CopilotChatCancelTranscribeButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
146
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CopilotChatCancelTranscribeButtonComponent, isStandalone: true, selector: "copilot-chat-cancel-transcribe-button", inputs: { disabled: "disabled" }, outputs: { clicked: "clicked" }, ngImport: i0, template: `
147
+ <button
148
+ type="button"
149
+ [disabled]="disabled"
150
+ [class]="buttonClass"
151
+ [copilotTooltip]="label"
152
+ tooltipPosition="below"
153
+ (click)="onClick()"
154
+ >
155
+ <lucide-angular [img]="XIcon" [size]="18"></lucide-angular>
156
+ </button>
157
+ `, isInline: true, styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: LucideAngularModule }, { kind: "component", type: i1.LucideAngularComponent, selector: "lucide-angular, lucide-icon, i-lucide, span-lucide", inputs: ["class", "name", "img", "color", "absoluteStrokeWidth", "size", "strokeWidth"] }, { kind: "directive", type: CopilotTooltipDirective, selector: "[copilotTooltip]", inputs: ["copilotTooltip", "tooltipPosition", "tooltipDelay"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
158
+ }
159
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CopilotChatCancelTranscribeButtonComponent, decorators: [{
160
+ type: Component,
161
+ args: [{ selector: 'copilot-chat-cancel-transcribe-button', standalone: true, imports: [CommonModule, LucideAngularModule, CopilotTooltipDirective], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: `
162
+ <button
163
+ type="button"
164
+ [disabled]="disabled"
165
+ [class]="buttonClass"
166
+ [copilotTooltip]="label"
167
+ tooltipPosition="below"
168
+ (click)="onClick()"
169
+ >
170
+ <lucide-angular [img]="XIcon" [size]="18"></lucide-angular>
171
+ </button>
172
+ ` }]
173
+ }], propDecorators: { disabled: [{
174
+ type: Input
175
+ }], clicked: [{
176
+ type: Output
177
+ }] } });
178
+ export class CopilotChatFinishTranscribeButtonComponent {
179
+ disabled = false;
180
+ clicked = new EventEmitter();
181
+ chatConfig = inject(CopilotChatConfigurationService);
182
+ CheckIcon = Check;
183
+ buttonClass = cn(buttonBase, chatInputToolbarSecondary, 'mr-[10px]');
184
+ get label() {
185
+ return this.chatConfig.labels().chatInputToolbarFinishTranscribeButtonLabel;
186
+ }
187
+ onClick() {
188
+ if (!this.disabled) {
189
+ this.clicked.emit();
190
+ }
191
+ }
192
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CopilotChatFinishTranscribeButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
193
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CopilotChatFinishTranscribeButtonComponent, isStandalone: true, selector: "copilot-chat-finish-transcribe-button", inputs: { disabled: "disabled" }, outputs: { clicked: "clicked" }, ngImport: i0, template: `
194
+ <button
195
+ type="button"
196
+ [disabled]="disabled"
197
+ [class]="buttonClass"
198
+ [copilotTooltip]="label"
199
+ tooltipPosition="below"
200
+ (click)="onClick()"
201
+ >
202
+ <lucide-angular [img]="CheckIcon" [size]="18"></lucide-angular>
203
+ </button>
204
+ `, isInline: true, styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: LucideAngularModule }, { kind: "component", type: i1.LucideAngularComponent, selector: "lucide-angular, lucide-icon, i-lucide, span-lucide", inputs: ["class", "name", "img", "color", "absoluteStrokeWidth", "size", "strokeWidth"] }, { kind: "directive", type: CopilotTooltipDirective, selector: "[copilotTooltip]", inputs: ["copilotTooltip", "tooltipPosition", "tooltipDelay"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
205
+ }
206
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CopilotChatFinishTranscribeButtonComponent, decorators: [{
207
+ type: Component,
208
+ args: [{ selector: 'copilot-chat-finish-transcribe-button', standalone: true, imports: [CommonModule, LucideAngularModule, CopilotTooltipDirective], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: `
209
+ <button
210
+ type="button"
211
+ [disabled]="disabled"
212
+ [class]="buttonClass"
213
+ [copilotTooltip]="label"
214
+ tooltipPosition="below"
215
+ (click)="onClick()"
216
+ >
217
+ <lucide-angular [img]="CheckIcon" [size]="18"></lucide-angular>
218
+ </button>
219
+ ` }]
220
+ }], propDecorators: { disabled: [{
221
+ type: Input
222
+ }], clicked: [{
223
+ type: Output
224
+ }] } });
225
+ export class CopilotChatAddFileButtonComponent {
226
+ disabled = false;
227
+ clicked = new EventEmitter();
228
+ chatConfig = inject(CopilotChatConfigurationService);
229
+ PlusIcon = Plus;
230
+ buttonClass = cn(buttonBase, chatInputToolbarSecondary, 'ml-2');
231
+ get label() {
232
+ return this.chatConfig.labels().chatInputToolbarAddButtonLabel;
233
+ }
234
+ onClick() {
235
+ if (!this.disabled) {
236
+ this.clicked.emit();
237
+ }
238
+ }
239
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CopilotChatAddFileButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
240
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CopilotChatAddFileButtonComponent, isStandalone: true, selector: "copilot-chat-add-file-button", inputs: { disabled: "disabled" }, outputs: { clicked: "clicked" }, ngImport: i0, template: `
241
+ <button
242
+ type="button"
243
+ [disabled]="disabled"
244
+ [class]="buttonClass"
245
+ [copilotTooltip]="label"
246
+ tooltipPosition="below"
247
+ (click)="onClick()"
248
+ >
249
+ <lucide-angular [img]="PlusIcon" [size]="20"></lucide-angular>
250
+ </button>
251
+ `, isInline: true, styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: LucideAngularModule }, { kind: "component", type: i1.LucideAngularComponent, selector: "lucide-angular, lucide-icon, i-lucide, span-lucide", inputs: ["class", "name", "img", "color", "absoluteStrokeWidth", "size", "strokeWidth"] }, { kind: "directive", type: CopilotTooltipDirective, selector: "[copilotTooltip]", inputs: ["copilotTooltip", "tooltipPosition", "tooltipDelay"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
252
+ }
253
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CopilotChatAddFileButtonComponent, decorators: [{
254
+ type: Component,
255
+ args: [{ selector: 'copilot-chat-add-file-button', standalone: true, imports: [CommonModule, LucideAngularModule, CopilotTooltipDirective], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: `
256
+ <button
257
+ type="button"
258
+ [disabled]="disabled"
259
+ [class]="buttonClass"
260
+ [copilotTooltip]="label"
261
+ tooltipPosition="below"
262
+ (click)="onClick()"
263
+ >
264
+ <lucide-angular [img]="PlusIcon" [size]="20"></lucide-angular>
265
+ </button>
266
+ ` }]
267
+ }], propDecorators: { disabled: [{
268
+ type: Input
269
+ }], clicked: [{
270
+ type: Output
271
+ }] } });
272
+ // Base toolbar button component that other buttons can use
273
+ export class CopilotChatToolbarButtonComponent {
274
+ disabled = signal(false);
275
+ variant = signal('secondary');
276
+ customClass = signal('');
277
+ title = signal('');
278
+ clicked = new EventEmitter();
279
+ computedClass = computed(() => {
280
+ const variantClass = this.variant() === 'primary'
281
+ ? chatInputToolbarPrimary
282
+ : chatInputToolbarSecondary;
283
+ return cn(buttonBase, variantClass, this.customClass());
284
+ });
285
+ onClick() {
286
+ if (!this.disabled()) {
287
+ this.clicked.emit();
288
+ }
289
+ }
290
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CopilotChatToolbarButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
291
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CopilotChatToolbarButtonComponent, isStandalone: true, selector: "copilot-chat-toolbar-button", outputs: { clicked: "clicked" }, ngImport: i0, template: `
292
+ <button
293
+ type="button"
294
+ [disabled]="disabled()"
295
+ [class]="computedClass()"
296
+ [copilotTooltip]="title()"
297
+ tooltipPosition="below"
298
+ (click)="onClick()"
299
+ >
300
+ <ng-content></ng-content>
301
+ </button>
302
+ `, isInline: true, styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: CopilotTooltipDirective, selector: "[copilotTooltip]", inputs: ["copilotTooltip", "tooltipPosition", "tooltipDelay"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
303
+ }
304
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CopilotChatToolbarButtonComponent, decorators: [{
305
+ type: Component,
306
+ args: [{ selector: 'copilot-chat-toolbar-button', standalone: true, imports: [CommonModule, CopilotTooltipDirective], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: `
307
+ <button
308
+ type="button"
309
+ [disabled]="disabled()"
310
+ [class]="computedClass()"
311
+ [copilotTooltip]="title()"
312
+ tooltipPosition="below"
313
+ (click)="onClick()"
314
+ >
315
+ <ng-content></ng-content>
316
+ </button>
317
+ ` }]
318
+ }], propDecorators: { clicked: [{
319
+ type: Output
320
+ }] } });
321
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"copilot-chat-buttons.component.js","sourceRoot":"","sources":["../../../../src/components/chat/copilot-chat-buttons.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  ChangeDetectionStrategy,\n  inject,\n  signal,\n  computed,\n  ViewEncapsulation\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { \n  LucideAngularModule,\n  ArrowUp,\n  Mic,\n  X,\n  Check,\n  Plus\n} from 'lucide-angular';\nimport { CopilotChatConfigurationService } from '../../core/chat-configuration/chat-configuration.service';\nimport { CopilotTooltipDirective } from '../../lib/directives/tooltip.directive';\nimport { cn } from '../../lib/utils';\n\n// Base button classes matching React's button variants\nconst buttonBase = cn(\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);\n\nconst chatInputToolbarPrimary = cn(\n  'cursor-pointer',\n  // Background and text\n  'bg-black text-white',\n  // Dark mode\n  'dark:bg-white dark:text-black dark:focus-visible:outline-white',\n  // Shape and sizing\n  'rounded-full h-9 w-9',\n  // Interactions\n  'transition-colors',\n  // Focus states\n  'focus:outline-none',\n  // Hover states\n  'hover:opacity-70 disabled:hover:opacity-100',\n  // Disabled states\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\nconst chatInputToolbarSecondary = cn(\n  'cursor-pointer',\n  // Background and text\n  'bg-transparent text-[#444444]',\n  // Dark mode\n  'dark:text-white dark:border-[#404040]',\n  // Shape and sizing\n  'rounded-full h-9 w-9',\n  // Interactions\n  'transition-colors',\n  // Focus states\n  'focus:outline-none',\n  // Hover states\n  'hover:bg-[#f8f8f8] hover:text-[#333333]',\n  'dark:hover:bg-[#404040] dark:hover:text-[#FFFFFF]',\n  // Disabled states\n  'disabled:cursor-not-allowed disabled:opacity-50',\n  'disabled:hover:bg-transparent disabled:hover:text-[#444444]',\n  'dark:disabled:hover:bg-transparent dark:disabled:hover:text-[#CCCCCC]'\n);\n\n@Component({\n  selector: 'copilot-chat-send-button',\n  standalone: true,\n  imports: [CommonModule, LucideAngularModule],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  template: `\n    <div class=\"mr-[10px]\">\n      <button\n        type=\"button\"\n        [disabled]=\"disabled\"\n        [class]=\"buttonClass\"\n        (click)=\"onClick()\"\n      >\n        <lucide-angular [img]=\"ArrowUpIcon\" [size]=\"18\"></lucide-angular>\n      </button>\n    </div>\n  `,\n  styles: [``]\n})\nexport class CopilotChatSendButtonComponent {\n  @Input() disabled = false;\n  @Output() clicked = new EventEmitter<void>();\n  \n  readonly ArrowUpIcon = ArrowUp;\n  buttonClass = cn(buttonBase, chatInputToolbarPrimary);\n  \n  onClick(): void {\n    if (!this.disabled) {\n      this.clicked.emit();\n    }\n  }\n}\n\n@Component({\n  selector: 'copilot-chat-start-transcribe-button',\n  standalone: true,\n  imports: [CommonModule, LucideAngularModule, CopilotTooltipDirective],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  template: `\n    <button\n      type=\"button\"\n      [disabled]=\"disabled\"\n      [class]=\"buttonClass\"\n      [copilotTooltip]=\"label\"\n      tooltipPosition=\"below\"\n      (click)=\"onClick()\"\n    >\n      <lucide-angular [img]=\"MicIcon\" [size]=\"18\"></lucide-angular>\n    </button>\n  `,\n  styles: [``]\n})\nexport class CopilotChatStartTranscribeButtonComponent {\n  @Input() disabled = false;\n  @Output() clicked = new EventEmitter<void>();\n  \n  private chatConfig = inject(CopilotChatConfigurationService);\n  \n  readonly MicIcon = Mic;\n  buttonClass = cn(buttonBase, chatInputToolbarSecondary, 'mr-2');\n  \n  get label(): string {\n    return this.chatConfig.labels().chatInputToolbarStartTranscribeButtonLabel;\n  }\n  \n  onClick(): void {\n    if (!this.disabled) {\n      this.clicked.emit();\n    }\n  }\n}\n\n@Component({\n  selector: 'copilot-chat-cancel-transcribe-button',\n  standalone: true,\n  imports: [CommonModule, LucideAngularModule, CopilotTooltipDirective],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  template: `\n    <button\n      type=\"button\"\n      [disabled]=\"disabled\"\n      [class]=\"buttonClass\"\n      [copilotTooltip]=\"label\"\n      tooltipPosition=\"below\"\n      (click)=\"onClick()\"\n    >\n      <lucide-angular [img]=\"XIcon\" [size]=\"18\"></lucide-angular>\n    </button>\n  `,\n  styles: [``]\n})\nexport class CopilotChatCancelTranscribeButtonComponent {\n  @Input() disabled = false;\n  @Output() clicked = new EventEmitter<void>();\n  \n  private chatConfig = inject(CopilotChatConfigurationService);\n  \n  readonly XIcon = X;\n  buttonClass = cn(buttonBase, chatInputToolbarSecondary, 'mr-2');\n  \n  get label(): string {\n    return this.chatConfig.labels().chatInputToolbarCancelTranscribeButtonLabel;\n  }\n  \n  onClick(): void {\n    if (!this.disabled) {\n      this.clicked.emit();\n    }\n  }\n}\n\n@Component({\n  selector: 'copilot-chat-finish-transcribe-button',\n  standalone: true,\n  imports: [CommonModule, LucideAngularModule, CopilotTooltipDirective],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  template: `\n    <button\n      type=\"button\"\n      [disabled]=\"disabled\"\n      [class]=\"buttonClass\"\n      [copilotTooltip]=\"label\"\n      tooltipPosition=\"below\"\n      (click)=\"onClick()\"\n    >\n      <lucide-angular [img]=\"CheckIcon\" [size]=\"18\"></lucide-angular>\n    </button>\n  `,\n  styles: [``]\n})\nexport class CopilotChatFinishTranscribeButtonComponent {\n  @Input() disabled = false;\n  @Output() clicked = new EventEmitter<void>();\n  \n  private chatConfig = inject(CopilotChatConfigurationService);\n  \n  readonly CheckIcon = Check;\n  buttonClass = cn(buttonBase, chatInputToolbarSecondary, 'mr-[10px]');\n  \n  get label(): string {\n    return this.chatConfig.labels().chatInputToolbarFinishTranscribeButtonLabel;\n  }\n  \n  onClick(): void {\n    if (!this.disabled) {\n      this.clicked.emit();\n    }\n  }\n}\n\n@Component({\n  selector: 'copilot-chat-add-file-button',\n  standalone: true,\n  imports: [CommonModule, LucideAngularModule, CopilotTooltipDirective],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  template: `\n    <button\n      type=\"button\"\n      [disabled]=\"disabled\"\n      [class]=\"buttonClass\"\n      [copilotTooltip]=\"label\"\n      tooltipPosition=\"below\"\n      (click)=\"onClick()\"\n    >\n      <lucide-angular [img]=\"PlusIcon\" [size]=\"20\"></lucide-angular>\n    </button>\n  `,\n  styles: [``]\n})\nexport class CopilotChatAddFileButtonComponent {\n  @Input() disabled = false;\n  @Output() clicked = new EventEmitter<void>();\n  \n  private chatConfig = inject(CopilotChatConfigurationService);\n  \n  readonly PlusIcon = Plus;\n  buttonClass = cn(buttonBase, chatInputToolbarSecondary, 'ml-2');\n  \n  get label(): string {\n    return this.chatConfig.labels().chatInputToolbarAddButtonLabel;\n  }\n  \n  onClick(): void {\n    if (!this.disabled) {\n      this.clicked.emit();\n    }\n  }\n}\n\n// Base toolbar button component that other buttons can use\n@Component({\n  selector: 'copilot-chat-toolbar-button',\n  standalone: true,\n  imports: [CommonModule, CopilotTooltipDirective],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  template: `\n    <button\n      type=\"button\"\n      [disabled]=\"disabled()\"\n      [class]=\"computedClass()\"\n      [copilotTooltip]=\"title()\"\n      tooltipPosition=\"below\"\n      (click)=\"onClick()\"\n    >\n      <ng-content></ng-content>\n    </button>\n  `,\n  styles: [``]\n})\nexport class CopilotChatToolbarButtonComponent {\n  disabled = signal(false);\n  variant = signal<'primary' | 'secondary'>('secondary');\n  customClass = signal('');\n  title = signal('');\n  \n  @Output() clicked = new EventEmitter<void>();\n  \n  computedClass = computed(() => {\n    const variantClass = this.variant() === 'primary' \n      ? chatInputToolbarPrimary \n      : chatInputToolbarSecondary;\n    return cn(buttonBase, variantClass, this.customClass());\n  });\n  \n  onClick(): void {\n    if (!this.disabled()) {\n      this.clicked.emit();\n    }\n  }\n}\n"]}
@@ -0,0 +1,38 @@
1
+ import { CopilotChatTextareaComponent } from "./copilot-chat-textarea.component";
2
+ import { CopilotChatAudioRecorderComponent } from "./copilot-chat-audio-recorder.component";
3
+ import { CopilotChatSendButtonComponent, CopilotChatStartTranscribeButtonComponent, CopilotChatCancelTranscribeButtonComponent, CopilotChatFinishTranscribeButtonComponent, CopilotChatAddFileButtonComponent, } from "./copilot-chat-buttons.component";
4
+ import { CopilotChatToolbarComponent } from "./copilot-chat-toolbar.component";
5
+ import { CopilotChatToolsMenuComponent } from "./copilot-chat-tools-menu.component";
6
+ /**
7
+ * Default components used by CopilotChatInput.
8
+ * These can be imported and reused when creating custom slot implementations.
9
+ *
10
+ * @example
11
+ * ```typescript
12
+ * import { CopilotChatInputDefaults } from '@copilotkitnext/angular';
13
+ *
14
+ * @Component({
15
+ * template: `
16
+ * <copilot-chat-input [sendButtonSlot]="CustomSendButton">
17
+ * </copilot-chat-input>
18
+ * `
19
+ * })
20
+ * export class MyComponent {
21
+ * CustomSendButton = class extends CopilotChatInputDefaults.SendButton {
22
+ * // Custom implementation
23
+ * };
24
+ * }
25
+ * ```
26
+ */
27
+ export class CopilotChatInputDefaults {
28
+ static TextArea = CopilotChatTextareaComponent;
29
+ static AudioRecorder = CopilotChatAudioRecorderComponent;
30
+ static SendButton = CopilotChatSendButtonComponent;
31
+ static StartTranscribeButton = CopilotChatStartTranscribeButtonComponent;
32
+ static CancelTranscribeButton = CopilotChatCancelTranscribeButtonComponent;
33
+ static FinishTranscribeButton = CopilotChatFinishTranscribeButtonComponent;
34
+ static AddFileButton = CopilotChatAddFileButtonComponent;
35
+ static Toolbar = CopilotChatToolbarComponent;
36
+ static ToolsMenu = CopilotChatToolsMenuComponent;
37
+ }
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29waWxvdC1jaGF0LWlucHV0LWRlZmF1bHRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvY2hhdC9jb3BpbG90LWNoYXQtaW5wdXQtZGVmYXVsdHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDakYsT0FBTyxFQUFFLGlDQUFpQyxFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDNUYsT0FBTyxFQUNMLDhCQUE4QixFQUM5Qix5Q0FBeUMsRUFDekMsMENBQTBDLEVBQzFDLDBDQUEwQyxFQUMxQyxpQ0FBaUMsR0FDbEMsTUFBTSxrQ0FBa0MsQ0FBQztBQUMxQyxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUMvRSxPQUFPLEVBQUUsNkJBQTZCLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUVwRjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FvQkc7QUFDSCxNQUFNLE9BQU8sd0JBQXdCO0lBQ25DLE1BQU0sQ0FBVSxRQUFRLEdBQUcsNEJBQTRCLENBQUM7SUFDeEQsTUFBTSxDQUFVLGFBQWEsR0FBRyxpQ0FBaUMsQ0FBQztJQUNsRSxNQUFNLENBQVUsVUFBVSxHQUFHLDhCQUE4QixDQUFDO0lBQzVELE1BQU0sQ0FBVSxxQkFBcUIsR0FDbkMseUNBQXlDLENBQUM7SUFDNUMsTUFBTSxDQUFVLHNCQUFzQixHQUNwQywwQ0FBMEMsQ0FBQztJQUM3QyxNQUFNLENBQVUsc0JBQXNCLEdBQ3BDLDBDQUEwQyxDQUFDO0lBQzdDLE1BQU0sQ0FBVSxhQUFhLEdBQUcsaUNBQWlDLENBQUM7SUFDbEUsTUFBTSxDQUFVLE9BQU8sR0FBRywyQkFBMkIsQ0FBQztJQUN0RCxNQUFNLENBQVUsU0FBUyxHQUFHLDZCQUE2QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29waWxvdENoYXRUZXh0YXJlYUNvbXBvbmVudCB9IGZyb20gXCIuL2NvcGlsb3QtY2hhdC10ZXh0YXJlYS5jb21wb25lbnRcIjtcbmltcG9ydCB7IENvcGlsb3RDaGF0QXVkaW9SZWNvcmRlckNvbXBvbmVudCB9IGZyb20gXCIuL2NvcGlsb3QtY2hhdC1hdWRpby1yZWNvcmRlci5jb21wb25lbnRcIjtcbmltcG9ydCB7XG4gIENvcGlsb3RDaGF0U2VuZEJ1dHRvbkNvbXBvbmVudCxcbiAgQ29waWxvdENoYXRTdGFydFRyYW5zY3JpYmVCdXR0b25Db21wb25lbnQsXG4gIENvcGlsb3RDaGF0Q2FuY2VsVHJhbnNjcmliZUJ1dHRvbkNvbXBvbmVudCxcbiAgQ29waWxvdENoYXRGaW5pc2hUcmFuc2NyaWJlQnV0dG9uQ29tcG9uZW50LFxuICBDb3BpbG90Q2hhdEFkZEZpbGVCdXR0b25Db21wb25lbnQsXG59IGZyb20gXCIuL2NvcGlsb3QtY2hhdC1idXR0b25zLmNvbXBvbmVudFwiO1xuaW1wb3J0IHsgQ29waWxvdENoYXRUb29sYmFyQ29tcG9uZW50IH0gZnJvbSBcIi4vY29waWxvdC1jaGF0LXRvb2xiYXIuY29tcG9uZW50XCI7XG5pbXBvcnQgeyBDb3BpbG90Q2hhdFRvb2xzTWVudUNvbXBvbmVudCB9IGZyb20gXCIuL2NvcGlsb3QtY2hhdC10b29scy1tZW51LmNvbXBvbmVudFwiO1xuXG4vKipcbiAqIERlZmF1bHQgY29tcG9uZW50cyB1c2VkIGJ5IENvcGlsb3RDaGF0SW5wdXQuXG4gKiBUaGVzZSBjYW4gYmUgaW1wb3J0ZWQgYW5kIHJldXNlZCB3aGVuIGNyZWF0aW5nIGN1c3RvbSBzbG90IGltcGxlbWVudGF0aW9ucy5cbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHlwZXNjcmlwdFxuICogaW1wb3J0IHsgQ29waWxvdENoYXRJbnB1dERlZmF1bHRzIH0gZnJvbSAnQGNvcGlsb3RraXRuZXh0L2FuZ3VsYXInO1xuICpcbiAqIEBDb21wb25lbnQoe1xuICogICB0ZW1wbGF0ZTogYFxuICogICAgIDxjb3BpbG90LWNoYXQtaW5wdXQgW3NlbmRCdXR0b25TbG90XT1cIkN1c3RvbVNlbmRCdXR0b25cIj5cbiAqICAgICA8L2NvcGlsb3QtY2hhdC1pbnB1dD5cbiAqICAgYFxuICogfSlcbiAqIGV4cG9ydCBjbGFzcyBNeUNvbXBvbmVudCB7XG4gKiAgIEN1c3RvbVNlbmRCdXR0b24gPSBjbGFzcyBleHRlbmRzIENvcGlsb3RDaGF0SW5wdXREZWZhdWx0cy5TZW5kQnV0dG9uIHtcbiAqICAgICAvLyBDdXN0b20gaW1wbGVtZW50YXRpb25cbiAqICAgfTtcbiAqIH1cbiAqIGBgYFxuICovXG5leHBvcnQgY2xhc3MgQ29waWxvdENoYXRJbnB1dERlZmF1bHRzIHtcbiAgc3RhdGljIHJlYWRvbmx5IFRleHRBcmVhID0gQ29waWxvdENoYXRUZXh0YXJlYUNvbXBvbmVudDtcbiAgc3RhdGljIHJlYWRvbmx5IEF1ZGlvUmVjb3JkZXIgPSBDb3BpbG90Q2hhdEF1ZGlvUmVjb3JkZXJDb21wb25lbnQ7XG4gIHN0YXRpYyByZWFkb25seSBTZW5kQnV0dG9uID0gQ29waWxvdENoYXRTZW5kQnV0dG9uQ29tcG9uZW50O1xuICBzdGF0aWMgcmVhZG9ubHkgU3RhcnRUcmFuc2NyaWJlQnV0dG9uID1cbiAgICBDb3BpbG90Q2hhdFN0YXJ0VHJhbnNjcmliZUJ1dHRvbkNvbXBvbmVudDtcbiAgc3RhdGljIHJlYWRvbmx5IENhbmNlbFRyYW5zY3JpYmVCdXR0b24gPVxuICAgIENvcGlsb3RDaGF0Q2FuY2VsVHJhbnNjcmliZUJ1dHRvbkNvbXBvbmVudDtcbiAgc3RhdGljIHJlYWRvbmx5IEZpbmlzaFRyYW5zY3JpYmVCdXR0b24gPVxuICAgIENvcGlsb3RDaGF0RmluaXNoVHJhbnNjcmliZUJ1dHRvbkNvbXBvbmVudDtcbiAgc3RhdGljIHJlYWRvbmx5IEFkZEZpbGVCdXR0b24gPSBDb3BpbG90Q2hhdEFkZEZpbGVCdXR0b25Db21wb25lbnQ7XG4gIHN0YXRpYyByZWFkb25seSBUb29sYmFyID0gQ29waWxvdENoYXRUb29sYmFyQ29tcG9uZW50O1xuICBzdGF0aWMgcmVhZG9ubHkgVG9vbHNNZW51ID0gQ29waWxvdENoYXRUb29sc01lbnVDb21wb25lbnQ7XG59XG4iXX0=