@hivegpt/hiveai-angular 0.0.300 → 0.0.303

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 (54) hide show
  1. package/README.md +24 -24
  2. package/bundles/hivegpt-hiveai-angular.umd.js +2646 -2634
  3. package/bundles/hivegpt-hiveai-angular.umd.js.map +1 -1
  4. package/bundles/hivegpt-hiveai-angular.umd.min.js +1 -1
  5. package/bundles/hivegpt-hiveai-angular.umd.min.js.map +1 -1
  6. package/environments/environment.d.ts +14 -14
  7. package/environments/environment.d.ts.map +1 -1
  8. package/esm2015/environments/environment.js +15 -15
  9. package/esm2015/hivegpt-hiveai-angular.js +12 -12
  10. package/esm2015/lib/components/NotificationSocket.js +39 -39
  11. package/esm2015/lib/components/bot-html-editor/bot-html-editor.component.js +112 -112
  12. package/esm2015/lib/components/bot.service.js +43 -43
  13. package/esm2015/lib/components/chat-drawer/chat-drawer.component.js +1621 -1609
  14. package/esm2015/lib/components/chatbot/chatbot.component.js +50 -50
  15. package/esm2015/lib/components/conversation.service.js +40 -40
  16. package/esm2015/lib/components/socket-service.service.js +72 -72
  17. package/esm2015/lib/components/video-player/video-player.component.js +123 -123
  18. package/esm2015/lib/hivegpt.module.js +21 -21
  19. package/esm2015/lib/models/video.js +2 -2
  20. package/esm2015/lib/pipes/safe-html.pipe.js +19 -19
  21. package/esm2015/lib/utils/utils.js +36 -36
  22. package/esm2015/public-api.js +7 -7
  23. package/fesm2015/hivegpt-hiveai-angular.js +2118 -2106
  24. package/fesm2015/hivegpt-hiveai-angular.js.map +1 -1
  25. package/hivegpt-hiveai-angular.d.ts +11 -11
  26. package/hivegpt-hiveai-angular.d.ts.map +1 -1
  27. package/hivegpt-hiveai-angular.metadata.json +1 -1
  28. package/lib/components/NotificationSocket.d.ts +4 -4
  29. package/lib/components/NotificationSocket.d.ts.map +1 -1
  30. package/lib/components/bot-html-editor/bot-html-editor.component.d.ts +35 -35
  31. package/lib/components/bot-html-editor/bot-html-editor.component.d.ts.map +1 -1
  32. package/lib/components/bot.service.d.ts +11 -11
  33. package/lib/components/bot.service.d.ts.map +1 -1
  34. package/lib/components/chat-drawer/chat-drawer.component.d.ts +244 -244
  35. package/lib/components/chat-drawer/chat-drawer.component.d.ts.map +1 -1
  36. package/lib/components/chatbot/chatbot.component.d.ts +35 -35
  37. package/lib/components/chatbot/chatbot.component.d.ts.map +1 -1
  38. package/lib/components/conversation.service.d.ts +10 -10
  39. package/lib/components/conversation.service.d.ts.map +1 -1
  40. package/lib/components/socket-service.service.d.ts +19 -19
  41. package/lib/components/socket-service.service.d.ts.map +1 -1
  42. package/lib/components/video-player/video-player.component.d.ts +35 -35
  43. package/lib/components/video-player/video-player.component.d.ts.map +1 -1
  44. package/lib/hivegpt.module.d.ts +2 -2
  45. package/lib/hivegpt.module.d.ts.map +1 -1
  46. package/lib/models/video.d.ts +34 -34
  47. package/lib/models/video.d.ts.map +1 -1
  48. package/lib/pipes/safe-html.pipe.d.ts +7 -7
  49. package/lib/pipes/safe-html.pipe.d.ts.map +1 -1
  50. package/lib/utils/utils.d.ts +2 -2
  51. package/lib/utils/utils.d.ts.map +1 -1
  52. package/package.json +1 -1
  53. package/public-api.d.ts +3 -3
  54. package/public-api.d.ts.map +1 -1
@@ -1,1609 +1,1621 @@
1
- // import { Platform } from '@angular/cdk/platform';
2
- import { HttpClient, HttpHeaders } from '@angular/common/http';
3
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Output, Renderer2, ViewChild, ViewChildren, } from '@angular/core';
4
- import { DomSanitizer } from '@angular/platform-browser';
5
- import { of } from 'rxjs';
6
- import { catchError, switchMap } from 'rxjs/operators';
7
- import { formatNow, formatTimeStamps } from '../../utils/utils';
8
- import { dev_environment, prod_environment, } from '../../../environments/environment';
9
- import { ConversationService } from '../conversation.service';
10
- import { SocketService } from '../socket-service.service';
11
- import { FormBuilder, Validators } from '@angular/forms';
12
- import * as SpeechSDK from 'microsoft-cognitiveservices-speech-sdk';
13
- import { BotsService } from '../bot.service';
14
- export class ChatDrawerComponent {
15
- constructor(fb, botService, cdr, http, sanitizer, elementRef, renderer, socketService, conversationService // private platform: Platform
16
- ) {
17
- this.fb = fb;
18
- this.botService = botService;
19
- this.cdr = cdr;
20
- this.http = http;
21
- this.sanitizer = sanitizer;
22
- this.elementRef = elementRef;
23
- this.renderer = renderer;
24
- this.socketService = socketService;
25
- this.conversationService = conversationService;
26
- this.bodyOverflowClass = 'body-overflow-hidden';
27
- this.isCollapsedTrue = false;
28
- this.copilotName = 'HiveXGPT';
29
- this.feedbackEvent = new EventEmitter();
30
- this.onCloseEvent = new EventEmitter();
31
- this.openPage = new EventEmitter();
32
- this.sessionActions = new EventEmitter();
33
- this.closeBot = new EventEmitter();
34
- this.connectWithUser = new EventEmitter();
35
- this.scheduleMeeting = new EventEmitter();
36
- this.refreshToken = new EventEmitter();
37
- this.autogenKey = 'Autogen_eDJTtEU-NB0RtIpzq1w';
38
- this.addToMyAgendaAction = 'add_to_my_agenda';
39
- this.myUpcomingSessionAction = 'my_upcomming_session';
40
- this.connectOrFollowAction = 'connect_or_follow';
41
- this.aiResponse = '';
42
- this.chatLog = [];
43
- this.decoder = new TextDecoder();
44
- this.feedbackDone = false;
45
- this.greetingMsg = '';
46
- this.hasBackdropValue = false;
47
- this.input = '';
48
- this.listenerAdded = false;
49
- this.loading = false;
50
- this.mode = 'over';
51
- this.quickPrompts = [];
52
- this.thumbsDownMsgIndex = 0;
53
- this.userName = '';
54
- this.showStartAgain = false;
55
- this.isIOSDevice = false;
56
- this.showFeedBackIconsIndex = null;
57
- this.temperature = 1;
58
- this.speakers = [];
59
- this.currentWorkflowActionProgress = 0;
60
- this.currentWorkflowAction = '';
61
- this.recognizedText = '';
62
- this.authorizationToken = '';
63
- this.region = 'westeurope'; // Set your Azure region here
64
- this.isChatingWithAi = false;
65
- this.readAllChunks = (stream) => {
66
- const reader = stream.getReader();
67
- const allSuggestions = [];
68
- reader.closed.catch((err) => {
69
- if (err) {
70
- console.error('Error reading stream: ', err);
71
- }
72
- this.isChatingWithAi = false;
73
- this.scrollToBottom();
74
- return;
75
- });
76
- return new ReadableStream({
77
- start: (controller) => {
78
- return this.pump(controller, reader, allSuggestions);
79
- },
80
- });
81
- };
82
- this.currentMessageForEditor = '';
83
- this.currentIndexForEditor = -1;
84
- this.isDropdownOpen = false;
85
- this.selectedAgents = [];
86
- this.allSelected = false;
87
- this.isDocInEditMode = false;
88
- this.isContentLoaded = false;
89
- this.isCollapsed = false;
90
- this.isCollapsedForGraph = false;
91
- this.isCollapsedForFGraph = false;
92
- // [
93
- // {
94
- // "title": "AI News January 2024: In-Depth and Concise - The AI Track",
95
- // "desc": "Each month, we compile significant news, trends, and happenings in AI, providing detailed summaries with key points in bullet form for concise yet complete understanding.",
96
- // "link": "https://theaitrack.com/ai-news-january-2024/"
97
- // },
98
- // {
99
- // "title": "Top AI News, January 2024 - Everypixel Journal",
100
- // "desc": "In this monthly roundup, we spotlight the top AI news stories from January, including the OpenAI vs. The New York Times Lawsuit.",
101
- // "link": "https://journal.everypixel.com/top-ai-news-january-2024"
102
- // },
103
- // {
104
- // "title": "AI News July 2024: In-Depth and Concise - The AI Track",
105
- // "desc": "This page features AI News for July 2024, highlighting significant events such as Canva acquiring Leonardo AI.",
106
- // "link": "https://theaitrack.com/ai-news-july-2024-in-depth-and-concise/"
107
- // },
108
- // {
109
- // "title": "January news roundup: What's new in the world of AI? - Pluralsight",
110
- // "desc": "OpenAI’s new GPT store, business-ready ChatGPT plans, and a predicted rise in AI-powered cybercrime.",
111
- // "link": "https://www.pluralsight.com/resources/blog/data/ai-this-month-january-2024"
112
- // },
113
- // {
114
- // "title": "AI News August 2024: In-Depth and Concise - The AI Track",
115
- // "desc": "This page features AI News for August 2024, with highlights such as Nvidia delaying the “Blackwell” B200 AI chips delivery.",
116
- // "link": "https://theaitrack.com/ai-news-august-2024-in-depth-and-concise-duplicate/"
117
- // }
118
- // ]
119
- this.dateTime = { now: new Date().toISOString() };
120
- this.currentSourcesList = [];
121
- this.isShowEditorButton = true;
122
- this.isDrawerOpen = true;
123
- this.chatMain = new ElementRef(null);
124
- // if (this.platform.IOS) {
125
- // this.isIOSDevice = true;
126
- // }
127
- }
128
- ngOnChanges(changes) {
129
- if (changes.s27Token) {
130
- if (changes.s27Token.currentValue != changes.s27Token.previousValue) {
131
- this.s27Token = changes.s27Token.currentValue;
132
- console.log('isFetchDataFor: ', this.isFetchDataFor);
133
- console.log('msg: ', this.msg);
134
- console.log('chat: ', this.chat);
135
- if (this.is401) {
136
- if (this.isFetchDataFor) {
137
- this.fetchDataFor(this.msg, this.chat);
138
- }
139
- else {
140
- this.fetchData(this.msg);
141
- }
142
- }
143
- }
144
- }
145
- if (changes.orgId) {
146
- if (changes.orgId.currentValue != changes.orgId.previousValue &&
147
- changes.orgId.currentValue) {
148
- this.initializeSocket();
149
- if (!this.checkForCop29BotId()) {
150
- this.botService.getWorkflowsByOrgId(this.orgId).subscribe((res) => {
151
- this.orgWorkflows = res;
152
- });
153
- }
154
- }
155
- }
156
- }
157
- ngOnInit() {
158
- this.environment = this.isDev ? dev_environment : prod_environment;
159
- // this.fetchMyConnections().subscribe();
160
- // this.fetchPendingRequests().subscribe();
161
- this.changeTemperature(this.temperature);
162
- this.fetchBotConfig().subscribe((res) => {
163
- this.cdr.markForCheck();
164
- this.fetchChatHistory().subscribe((response) => {
165
- this.loading = false;
166
- this.mapChatHistory(response);
167
- this.cdr.markForCheck();
168
- }, (err) => {
169
- console.error('Error fetching chat history:', err);
170
- });
171
- }, (err) => {
172
- console.error('Error fetching chat history:', err);
173
- });
174
- this.fetchAgents();
175
- this.fetchEditorContent();
176
- this.cdr.markForCheck();
177
- // this.initializeSocket();
178
- if (!this.checkForCop29BotId()) {
179
- this.botService.fetchSpeechAuthorizationToken().subscribe((token) => {
180
- this.authorizationToken = token;
181
- this.initializeSpeechRecognizer(token);
182
- });
183
- }
184
- }
185
- initializeSocket() {
186
- try {
187
- this.socketService.disconnectSocketConnection();
188
- }
189
- catch (error) { }
190
- setTimeout(() => {
191
- this.socketService.connectSocketConnection();
192
- setTimeout(() => {
193
- console.log('YES INIT');
194
- const conversation_id = this.conversationService.getKey(this.botId);
195
- this.socketService.registerUserSpecificHiveSocket(this.botId, conversation_id, this.orgId);
196
- setTimeout(() => {
197
- this.listenSockets();
198
- }, 300);
199
- }, 200);
200
- }, 300);
201
- }
202
- listenSockets() {
203
- if (this.eventSubscription) {
204
- this.eventSubscription.unsubscribe();
205
- }
206
- console.log('Listen Socket');
207
- this.eventSubscription = this.conversationService
208
- .getUserSpecificNotification()
209
- .subscribe((res) => {
210
- var _a, _b, _c, _d, _e, _f;
211
- console.log('Listen Socket response');
212
- console.log(res);
213
- // Check if OtherFields exists in the response
214
- if ((_b = (_a = res === null || res === void 0 ? void 0 : res.m) === null || _a === void 0 ? void 0 : _a.OtherFields) === null || _b === void 0 ? void 0 : _b.workflow_id) {
215
- const { percentage, output, action_name, current_action_name, workflow_execution_id, time_stamp, } = (_c = res === null || res === void 0 ? void 0 : res.m) === null || _c === void 0 ? void 0 : _c.OtherFields;
216
- this.currentWorkflowActionProgress = percentage;
217
- this.currentWorkflowAction = action_name;
218
- const actionIndex = this.workflowExecutionDetails.Actions.findIndex((a) => a.Name == current_action_name);
219
- if (actionIndex !== -1) {
220
- this.workflowExecutionDetails.Actions[actionIndex]['Output'] = output;
221
- this.workflowExecutionDetails.Actions[actionIndex]['InsertTimeStamp'] = formatTimeStamps(this.timezone, time_stamp);
222
- }
223
- else {
224
- console.error(`Action with name ${action_name} not found`);
225
- }
226
- this.currentWorkflowExecutionDetails = this.workflowExecutionDetails;
227
- if (this.currentWorkflowActionProgress == 100) {
228
- this.chatLog[this.chatLog.length - 1]['WorkflowExecutionId'] = workflow_execution_id;
229
- this.isChatingWithAi = false;
230
- this.executingWorkflow = false;
231
- }
232
- this.cdr.detectChanges();
233
- }
234
- else if ((_d = res === null || res === void 0 ? void 0 : res.m) === null || _d === void 0 ? void 0 : _d.OtherFields) {
235
- const { conversation_id, bot_id, message_id, answer, web_results, search_results, graphs, execution_graphs, suggestions, } = (_e = res === null || res === void 0 ? void 0 : res.m) === null || _e === void 0 ? void 0 : _e.OtherFields;
236
- console.log('message_id1');
237
- console.log((_f = res === null || res === void 0 ? void 0 : res.m) === null || _f === void 0 ? void 0 : _f.OtherFields);
238
- var currentChatMessage = this.chatLog.find((p) => p._id == message_id);
239
- console.log(this.chatLog);
240
- if (!currentChatMessage) {
241
- console.log('message_id2');
242
- console.log(message_id);
243
- currentChatMessage = {
244
- _id: message_id,
245
- type: 'ai',
246
- time: formatNow(this.timezone),
247
- };
248
- this.chatLog.push(currentChatMessage);
249
- this.showFeedBackIconsIndex = this.chatLog.length - 1;
250
- console.log('message_id3');
251
- console.log(message_id);
252
- this.cdr.detectChanges();
253
- }
254
- // Handle the fields based on their presence
255
- if (search_results && Array.isArray(search_results)) {
256
- console.log('Online Search Terms:', search_results);
257
- currentChatMessage.searchTerms = search_results;
258
- this.cdr.detectChanges();
259
- }
260
- if (web_results && Array.isArray(web_results)) {
261
- console.log('Web Results:', web_results);
262
- currentChatMessage.sourcesList = web_results;
263
- currentChatMessage.displayedSources = web_results === null || web_results === void 0 ? void 0 : web_results.slice(0, 3); // First 3 cards
264
- currentChatMessage.remainingSources = web_results === null || web_results === void 0 ? void 0 : web_results.slice(3); // Remaining items
265
- this.cdr.detectChanges();
266
- }
267
- if (answer) {
268
- this.isChatingWithAi = false;
269
- console.log('Answer:', answer);
270
- currentChatMessage.message = this.processMessageForDisplay(answer);
271
- this.cdr.detectChanges();
272
- this.scrollToBottom();
273
- }
274
- if (graphs && Array.isArray(graphs)) {
275
- console.log('Graphs:', graphs);
276
- currentChatMessage.graphs = graphs;
277
- this.cdr.detectChanges();
278
- }
279
- if (execution_graphs && Array.isArray(execution_graphs)) {
280
- console.log('Execution Graphs:', execution_graphs);
281
- currentChatMessage.executionGraphs = execution_graphs;
282
- this.cdr.detectChanges();
283
- }
284
- if (suggestions && Array.isArray(suggestions)) {
285
- console.log('suggestions:', suggestions);
286
- currentChatMessage.relatedListItems = suggestions;
287
- this.cdr.detectChanges();
288
- // Process online search terms as needed
289
- }
290
- // Add any other fields and their processing here
291
- }
292
- else {
293
- console.warn('OtherFields is missing in the response');
294
- }
295
- }, (err) => {
296
- this.eventSubscription.unsubscribe();
297
- console.error('Error in fetching data from socket', err);
298
- });
299
- }
300
- initializeSocketAndListen() { }
301
- handleEvent(data, type) {
302
- switch (type) {
303
- case 'webresult':
304
- break;
305
- case 'answer':
306
- break;
307
- case 'graph':
308
- break;
309
- default:
310
- break;
311
- }
312
- }
313
- ngOnDestroy() {
314
- if (this.eventSubscription) {
315
- this.eventSubscription.unsubscribe();
316
- }
317
- this.socketService.disconnectSocketConnection();
318
- //this.socketService.close();
319
- }
320
- changeTemperature(newTemperature) {
321
- if (this.loading)
322
- return;
323
- this.temperature = newTemperature;
324
- const wrapper = document.querySelector('.hivegpt-chat-wrapper');
325
- // Remove existing theme classes from body
326
- wrapper === null || wrapper === void 0 ? void 0 : wrapper.classList.remove('creative', 'balanced', 'precise');
327
- switch (newTemperature) {
328
- case 0:
329
- wrapper === null || wrapper === void 0 ? void 0 : wrapper.classList.add('creative');
330
- break;
331
- case 1:
332
- wrapper === null || wrapper === void 0 ? void 0 : wrapper.classList.add('balanced');
333
- break;
334
- case 2:
335
- wrapper === null || wrapper === void 0 ? void 0 : wrapper.classList.add('precise');
336
- break;
337
- default:
338
- break;
339
- }
340
- }
341
- onStartAgain() {
342
- if (this.loading)
343
- return;
344
- this.showStartAgain = false;
345
- this.chatLog = [];
346
- this.chatLog.push({
347
- type: 'ai',
348
- message: this.greetingMsg,
349
- time: formatNow(this.timezone),
350
- });
351
- this.archieveMessages().subscribe();
352
- }
353
- archieveMessages() {
354
- const headers = new HttpHeaders({
355
- 'Content-Type': 'application/json',
356
- 'x-api-key': this.apiKey,
357
- });
358
- const url = `${this.environment.BASE_URL}/bot/clear-history/${this.botId}/${this.userId}`;
359
- return this.http.post(url, {}, { headers }).pipe(switchMap((res) => {
360
- return of(res);
361
- }), catchError((error) => {
362
- return of(null);
363
- }));
364
- }
365
- fetchBotConfig() {
366
- this.loading = true;
367
- const url = `${this.environment.BASE_URL}/bots?bot_id=${this.botId}`;
368
- return this.http.get(url).pipe(switchMap((res) => {
369
- var _a;
370
- this.botName = res.Name;
371
- this.botIcon = res.Icon;
372
- this.botSkills = res === null || res === void 0 ? void 0 : res.Skills;
373
- this.greetingMsg = res.Greeting;
374
- this.thumbsDownMessages = ((_a = res === null || res === void 0 ? void 0 : res.NegativeResponses) === null || _a === void 0 ? void 0 : _a.length) ? res.NegativeResponses
375
- : [
376
- "We are sorry we've not been able to answer your question.<br/> However, our dedicated support team is happy to help. <span class='feedback-link' style='cursor: pointer; text-decoration: underline; font-weight: 700; color: #17235B;'>Please click here</span> and a human agent will assist you as soon as possible",
377
- ];
378
- this.quickPrompts = res.QuickPrompts;
379
- this.cdr.markForCheck();
380
- this.loading = false;
381
- return of(res);
382
- }), catchError((error) => {
383
- console.error('Error fetching chatbot config: ', error);
384
- this.loading = false;
385
- return of(null);
386
- }));
387
- }
388
- fetchChatHistory() {
389
- this.loading = true;
390
- this.conversationKey = this.conversationService.getKey(this.botId, false);
391
- const url = `${this.environment.BASE_URL}/conversations/${this.conversationKey}`;
392
- const headers = new HttpHeaders({
393
- accept: 'application/json',
394
- });
395
- return this.http
396
- .get(url, { headers })
397
- .pipe(catchError(this.handleError('fetchConversation')));
398
- }
399
- handleError(operation = 'operation', result) {
400
- return (error) => {
401
- console.error(`${operation} failed: ${error.message}`);
402
- return of(result);
403
- };
404
- }
405
- // fetchChatHistory() {
406
- // this.loading = true;
407
- // const headers = new HttpHeaders({
408
- // 'Content-Type': 'application/json',
409
- // 'x-api-key': this.apiKey,
410
- // });
411
- // return this.http
412
- // .get(`${this.environment.BASE_URL}/conversations/${this.conversationKey}`, { headers })
413
- // .pipe(
414
- // switchMap((res: any) => {
415
- // this.loading = false;
416
- // return of(res);
417
- // }),
418
- // catchError((error: any) => {
419
- // console.error('Error fetching chat history: ', error);
420
- // this.loading = false;
421
- // return of(null);
422
- // })
423
- // );
424
- // }
425
- mapChatHistory(chats) {
426
- var _a;
427
- this.chatLog.push({
428
- type: 'ai',
429
- message: this.greetingMsg,
430
- time: formatNow(this.timezone),
431
- });
432
- if (chats && ((_a = chats === null || chats === void 0 ? void 0 : chats.Messages) === null || _a === void 0 ? void 0 : _a.length)) {
433
- chats === null || chats === void 0 ? void 0 : chats.Messages.forEach((chat) => {
434
- if (chat.Type == 'user') {
435
- this.chatLog.push({
436
- type: 'user',
437
- message: this.processMessageForDisplay(chat.Text),
438
- time: formatTimeStamps(this.timezone, chat.InsertTimestamp),
439
- copied: false,
440
- isCollapsedTrue: false,
441
- WorkflowExecutionId: chat.WorkflowExecutionId,
442
- });
443
- }
444
- if (chat.Type == 'ai') {
445
- var sourcesList = chat.WebLinks || [];
446
- var displayedSources = chat.WebLinks.slice(0, 3); // First 3 cards
447
- var remainingSources = chat.WebLinks.slice(3); // Remaining items
448
- this.chatLog.push({
449
- type: 'ai',
450
- message: this.processMessageForDisplay(chat.Text),
451
- executionGraphs: chat.ExecutionGraphs,
452
- graphs: chat.Graphs,
453
- searchTerms: chat.SearchTerms,
454
- sourcesList: sourcesList,
455
- displayedSources: displayedSources,
456
- remainingSources: remainingSources,
457
- time: formatTimeStamps(this.timezone, chat.InsertTimestamp),
458
- copied: false,
459
- isCollapsedTrue: false,
460
- });
461
- this.showFeedBackIconsIndex = this.chatLog.length - 1;
462
- }
463
- });
464
- this.showStartAgain = true;
465
- }
466
- this.scrollToBottom();
467
- this.cdr.markForCheck();
468
- }
469
- processMessage(message) {
470
- if (!message || !((message === null || message === void 0 ? void 0 : message.length) > 0)) {
471
- return '';
472
- }
473
- // console.log('here is my message')
474
- // console.log(message);
475
- message = message.trim();
476
- const markdownLinkRegex = /\[([^[]+)]\(([^)]+)\)/g;
477
- const urlRegex = /(?<!href=")\bhttps?:\/\/\S+(?<![.,])/gi;
478
- if (markdownLinkRegex.test(message)) {
479
- const html = message.replace(markdownLinkRegex, '<a href="$2" target="_blank">$1</a>');
480
- //console.log('Sanitized message: ', message);
481
- return this.sanitizeHtml(html);
482
- }
483
- if (urlRegex.test(message)) {
484
- const html = message.replace(urlRegex, '<a href="$&" target="_blank">$&</a>');
485
- // console.log('Sanitized message: ', message);
486
- return this.sanitizeHtml(html);
487
- }
488
- message = message.replace(/(?:\r\n|\r|\n)/g, '<br>');
489
- message = message.replace(/\*\*(.*?)\*\*/g, '<strong>$1</strong>');
490
- // Convert Markdown headers to HTML headers
491
- message = message.replace(/^(#{1,6})\s+(.*)$/gm, (match, hashes, text) => {
492
- const level = hashes.length;
493
- return `<h${level}>${text}</h${level}>`;
494
- });
495
- this.cdr.markForCheck();
496
- const sanitizedMessage = this.sanitizeHtml(message);
497
- return sanitizedMessage;
498
- }
499
- ngAfterViewChecked() {
500
- const feedbackLinks = this.elementRef.nativeElement.querySelectorAll('.feedback-link');
501
- feedbackLinks.forEach((link) => {
502
- link.addEventListener('click', this.onFeedbackClick.bind(this, 'zendesk'));
503
- });
504
- // if (this.elementRef.nativeElement.querySelector('.feedback-link')) {
505
- // this.elementRef.nativeElement
506
- // .querySelector('.feedback-link')
507
- // .addEventListener('click', this.onFeedbackClick.bind(this, 'zendesk'));
508
- // }
509
- }
510
- sanitizeHtml(html) {
511
- return this.sanitizer.bypassSecurityTrustHtml(html);
512
- }
513
- onFeedbackClick(value) {
514
- this.feedbackEvent.emit(value);
515
- }
516
- onClose() {
517
- this.renderer.removeClass(document.body, this.bodyOverflowClass);
518
- this.onCloseEvent.emit();
519
- }
520
- sendMessageWithTile(prompt) {
521
- this.input = prompt;
522
- this.fetchData();
523
- this.scrollToBottom();
524
- }
525
- fetchData(msg = null) {
526
- var _a;
527
- this.input = msg || ((_a = this.input) === null || _a === void 0 ? void 0 : _a.trim());
528
- this.msg = this.input;
529
- if (!this.input || this.loading) {
530
- return;
531
- }
532
- this.chatLog.push({
533
- type: 'user',
534
- message: this.processMessageForDisplay(this.input),
535
- time: formatNow(this.timezone),
536
- copied: false,
537
- isCollapsedTrue: false,
538
- });
539
- try {
540
- const textarea = this.myInput.nativeElement;
541
- textarea.style.height = 'hidden'; // Reset the height
542
- textarea.style.height = `62px`;
543
- }
544
- catch (error) { }
545
- this.cdr.markForCheck();
546
- this.aiResponse = '';
547
- this.isChatingWithAi = true;
548
- this.makeAskRequest(this.input, this.agents, this.conversationKey);
549
- }
550
- fetchDataFor(msg, chat) {
551
- const inputMsg = msg === null || msg === void 0 ? void 0 : msg.trim();
552
- if (!inputMsg || this.loading) {
553
- return;
554
- }
555
- try {
556
- chat.relatedListItems = [];
557
- this.cdr.detectChanges();
558
- }
559
- catch (error) { }
560
- this.scrollToBottom();
561
- this.chatLog.push({
562
- type: 'user',
563
- message: this.processMessageForDisplay(inputMsg),
564
- time: formatNow(this.timezone),
565
- copied: false,
566
- isCollapsedTrue: false,
567
- });
568
- this.cdr.markForCheck();
569
- this.aiResponse = '';
570
- this.isChatingWithAi = true;
571
- this.makeAskRequest(inputMsg, this.agents, this.conversationKey, msg, chat);
572
- }
573
- fetchSmallTalk() {
574
- this.loading = true;
575
- this.cdr.markForCheck();
576
- const url = `${this.environment.BASE_URL}/bot/small-talk/${this.botId}/${this.userId}`;
577
- this.http
578
- .get(url, {
579
- headers: {
580
- 'x-api-key': this.apiKey,
581
- },
582
- })
583
- .pipe(catchError((error) => {
584
- console.error('Error while fetching small talk:', error);
585
- return of(null);
586
- }))
587
- .subscribe((response) => {
588
- this.loading = false;
589
- this.cdr.markForCheck();
590
- if (!response) {
591
- return;
592
- }
593
- if (response && response.smallTalk) {
594
- this.chatLog.push({
595
- type: 'ai',
596
- message: this.processMessage(response.smallTalk),
597
- time: formatNow(this.timezone),
598
- isFeedbackMsg: true,
599
- });
600
- this.showFeedBackIconsIndex = this.chatLog.length - 2;
601
- // this.scrollToBottom();
602
- this.cdr.markForCheck();
603
- }
604
- });
605
- }
606
- pump(controller, reader, allSuggestions) {
607
- reader.read().then(({ done, value }) => {
608
- var _a, _b, _c, _d;
609
- const lastItem = this.chatLog[this.chatLog.length - 1];
610
- if (done) {
611
- lastItem.message = this.processMessageForDisplay(lastItem.message);
612
- this.chatLog.pop();
613
- this.chatLog.push(lastItem);
614
- if (allSuggestions === null || allSuggestions === void 0 ? void 0 : allSuggestions.length) {
615
- this.chatLog.push({
616
- type: 'suggestions',
617
- suggestions: allSuggestions,
618
- });
619
- }
620
- controller.close();
621
- this.isChatingWithAi = false;
622
- // this.scrollToBottom();
623
- this.cdr.markForCheck();
624
- this.showStartAgain = true;
625
- // setTimeout(() => {
626
- // this.fetchSmallTalk();
627
- // },1000)
628
- return;
629
- }
630
- let decodedChunk = this.decoder.decode(value, { stream: true });
631
- this.aiResponse += decodedChunk;
632
- if (lastItem.type === 'ai') {
633
- const suggestionsMatch = this.aiResponse.match(/<sug>(.*?)<\/sug>/g);
634
- if (suggestionsMatch) {
635
- suggestionsMatch.forEach((match) => {
636
- this.aiResponse = this.aiResponse.replace(match, '');
637
- allSuggestions.push(match === null || match === void 0 ? void 0 : match.replace(/<\/?sug>/g, ''));
638
- });
639
- }
640
- lastItem.message = this.aiResponse;
641
- this.cdr.markForCheck();
642
- }
643
- else {
644
- this.isChatingWithAi = false;
645
- let aiFormattedData;
646
- try {
647
- console.log('parsing json ');
648
- aiFormattedData = JSON.parse(JSON.parse(this.aiResponse));
649
- }
650
- catch (e) {
651
- try {
652
- console.log('parsing json 2');
653
- aiFormattedData = JSON.parse(this.aiResponse);
654
- }
655
- catch (e) { }
656
- }
657
- console.log('parsing json done');
658
- if (aiFormattedData && ((_a = aiFormattedData === null || aiFormattedData === void 0 ? void 0 : aiFormattedData.section_id) === null || _a === void 0 ? void 0 : _a.length) > 0) {
659
- if (aiFormattedData.section_id == 'company_search' ||
660
- aiFormattedData.section_id == 'user_search' ||
661
- aiFormattedData.section_id == 'industry_company_search') {
662
- this.fetchMyConnections().subscribe();
663
- this.fetchPendingRequests().subscribe();
664
- }
665
- if (aiFormattedData.section_id == this.myUpcomingSessionAction) {
666
- var speakerIds = [];
667
- (_b = aiFormattedData.content) === null || _b === void 0 ? void 0 : _b.forEach((session) => {
668
- speakerIds = [...speakerIds, ...session.speakers];
669
- });
670
- if ((speakerIds === null || speakerIds === void 0 ? void 0 : speakerIds.length) > 0)
671
- this.getSpeakersByStaffIds(speakerIds);
672
- }
673
- if (aiFormattedData.section_id == this.addToMyAgendaAction &&
674
- ((_c = aiFormattedData.content) === null || _c === void 0 ? void 0 : _c.length) > 0) {
675
- this.openPage.next({
676
- sectionId: aiFormattedData.section_id,
677
- sessionIds: aiFormattedData.content,
678
- });
679
- }
680
- if (aiFormattedData.section_id == this.connectOrFollowAction) {
681
- let usersLen = (_d = aiFormattedData.content) === null || _d === void 0 ? void 0 : _d.length;
682
- if (usersLen > 1) {
683
- this.openPage.next({
684
- sectionId: 'open_networking_drawer',
685
- search: aiFormattedData.content,
686
- });
687
- }
688
- else if (usersLen == 1) {
689
- this.openPage.next({
690
- sectionId: aiFormattedData.section_id,
691
- connetUserIds: [aiFormattedData.content[0].userId],
692
- });
693
- }
694
- }
695
- if (aiFormattedData.is_open_page == 'true') {
696
- this.openPage.next({
697
- sectionId: aiFormattedData.section_id,
698
- search: aiFormattedData.content,
699
- });
700
- if (this.isMobileBrowser()) {
701
- aiFormattedData.message +=
702
- '\n\n' + '<a id="closeBotNow">Click Here</a> to see results.';
703
- }
704
- }
705
- this.chatLog.push({
706
- type: 'ai',
707
- message: aiFormattedData.message,
708
- action: aiFormattedData,
709
- time: formatNow(this.timezone),
710
- });
711
- if (this.isMobileBrowser()) {
712
- setTimeout(() => {
713
- this.addCloseBotClickEvent();
714
- }, 500);
715
- }
716
- this.aiResponse = '';
717
- }
718
- else {
719
- this.chatLog.push({
720
- type: 'ai',
721
- message: this.aiResponse,
722
- time: formatNow(this.timezone),
723
- });
724
- }
725
- this.showFeedBackIconsIndex = this.chatLog.length - 1;
726
- this.cdr.markForCheck();
727
- }
728
- this.scrollToBottom();
729
- // Enqueue the next data chunk into our target stream
730
- controller.enqueue(value);
731
- this.pump(controller, reader, allSuggestions);
732
- });
733
- }
734
- submitFeedback(flag) {
735
- this.feedbackDone = true;
736
- this.showFeedBackIconsIndex = null;
737
- const url = `${this.environment.BASE_URL}/bot/feedback`;
738
- fetch(url, {
739
- method: 'POST',
740
- headers: {
741
- 'Content-Type': 'application/json',
742
- 'x-api-key': this.apiKey,
743
- },
744
- body: JSON.stringify({ flag, user_id: this.userId, bot_id: this.botId }),
745
- }).then(() => {
746
- if (flag) {
747
- this.chatLog.push({
748
- type: 'ai',
749
- message: this.thumbsUpMessage ||
750
- `Great. May I assist you with anything else?`,
751
- time: formatNow(this.timezone),
752
- isFeedbackMsg: true,
753
- });
754
- this.scrollToBottom();
755
- this.cdr.markForCheck();
756
- this.feedbackDone = false;
757
- this.showFeedBackIconsIndex = null;
758
- return;
759
- }
760
- this.chatLog.push({
761
- type: 'ai',
762
- message: this.processMessage(this.thumbsDownMessages[this.thumbsDownMsgIndex]),
763
- time: formatNow(this.timezone),
764
- isFeedbackMsg: true,
765
- });
766
- this.thumbsDownMsgIndex =
767
- (this.thumbsDownMsgIndex + 1) % this.thumbsDownMessages.length;
768
- this.scrollToBottom();
769
- this.cdr.markForCheck();
770
- this.feedbackDone = false;
771
- this.showFeedBackIconsIndex = null;
772
- });
773
- }
774
- handleKeydown(event) {
775
- if (event.key === 'Enter' && !event.shiftKey) {
776
- // Prevent default behavior (new line)
777
- event.preventDefault();
778
- // Call your submit function
779
- this.handleSubmit(event);
780
- }
781
- }
782
- handleSubmit(event) {
783
- this.fetchData();
784
- this.scrollToBottom();
785
- }
786
- handleUpClick(idx) {
787
- if (this.feedbackDone) {
788
- return;
789
- }
790
- this.submitFeedback(true);
791
- this.chatLog[idx].liked = !this.chatLog[idx].liked;
792
- if (this.chatLog[idx].unliked) {
793
- this.chatLog[idx].unliked = !this.chatLog[idx].unliked;
794
- }
795
- this.cdr.markForCheck();
796
- }
797
- handleDownClick(idx) {
798
- if (this.feedbackDone)
799
- return;
800
- this.submitFeedback(false);
801
- this.chatLog[idx].unliked = !this.chatLog[idx].unliked;
802
- if (this.chatLog[idx].liked)
803
- this.chatLog[idx].liked = !this.chatLog[idx].liked;
804
- }
805
- // handleCopyClick(index: any) {
806
- // // Copy the message to the clipboard
807
- // const contentToCopy = this.chatLog[index].message;
808
- // console.log('contentToCopy');
809
- // console.log(contentToCopy);
810
- // navigator.clipboard.writeText(contentToCopy).then(() => {
811
- // // Indicate that the message was copied
812
- // this.chatLog[index].copied = true;
813
- // this.cdr.detectChanges();
814
- // // Reset the copied state after a delay
815
- // setTimeout(() => {
816
- // this.chatLog[index].copied = false;
817
- // this.cdr.detectChanges();
818
- // }, 2000); // Reset after 2 seconds
819
- // });
820
- // }
821
- copyText(id, index) {
822
- // Get the text element
823
- var textElement = document.getElementById(id);
824
- // Create a temporary textarea element to copy the text
825
- var tempTextArea = document.createElement('textarea');
826
- tempTextArea.value = textElement.innerText;
827
- // Append the textarea to the body (necessary for the execCommand to work)
828
- document.body.appendChild(tempTextArea);
829
- // Select the text inside the textarea
830
- tempTextArea.select();
831
- // Copy the text to the clipboard
832
- document.execCommand('copy');
833
- // Remove the temporary textarea
834
- document.body.removeChild(tempTextArea);
835
- // Optionally, you can alert the user or change the button text to indicate the copy was successful
836
- // alert('Text copied to clipboard!');
837
- this.chatLog[index].copied = true;
838
- this.cdr.detectChanges();
839
- // Reset the copied state after a delay
840
- setTimeout(() => {
841
- this.chatLog[index].copied = false;
842
- this.cdr.detectChanges();
843
- }, 2000); // Reset after 2 seconds
844
- }
845
- handleCopyClick(index) {
846
- // Copy the message to the clipboard
847
- const contentToCopy = this.chatLog[index].message;
848
- const resutlt = this.copyText('messageText_' + index, index);
849
- }
850
- sanitizeHTML(html) {
851
- const doc = new DOMParser().parseFromString(html, 'text/html');
852
- // Create a new document fragment to hold the simplified content
853
- const fragment = document.createDocumentFragment();
854
- // Append the children of the body of the parsed document to the fragment
855
- Array.from(doc.body.childNodes).forEach((node) => {
856
- fragment.appendChild(node.cloneNode(true));
857
- });
858
- // Create a new div element to hold the simplified HTML
859
- const simplifiedDiv = document.createElement('div');
860
- simplifiedDiv.appendChild(fragment);
861
- // Remove complex tags or attributes as needed
862
- // Example: remove scripts
863
- simplifiedDiv
864
- .querySelectorAll('script')
865
- .forEach((script) => script.remove());
866
- // Return the simplified HTML as a string
867
- return simplifiedDiv.innerHTML;
868
- }
869
- handleEditorClick(index) {
870
- if (this.currentIndexForEditor == -1) {
871
- this.currentIndexForEditor = index;
872
- this.currentMessageForEditor = this.sanitizeHTML(this.chatLog[index].message);
873
- this.currentMessageForEditor = this.currentMessageForEditor.replace('SafeValue must use [property]=binding:', '');
874
- this.cdr.detectChanges();
875
- }
876
- else {
877
- if (this.currentIndexForEditor == index) {
878
- this.currentMessageForEditor += this.sanitizeHTML(this.chatLog[index].message);
879
- this.currentMessageForEditor = this.currentMessageForEditor.replace('SafeValue must use [property]=binding:', '');
880
- this.cdr.detectChanges();
881
- }
882
- else {
883
- this.currentIndexForEditor = index;
884
- this.currentMessageForEditor = this.sanitizeHTML(this.chatLog[index].message);
885
- this.currentMessageForEditor = this.currentMessageForEditor.replace('SafeValue must use [property]=binding:', '');
886
- this.cdr.detectChanges();
887
- }
888
- }
889
- this.chatLog[index].isEditor = true;
890
- this.cdr.detectChanges();
891
- // Reset the copied state after a delay
892
- setTimeout(() => {
893
- this.chatLog[index].isEditor = false;
894
- this.cdr.detectChanges();
895
- }, 2000); // Reset after 2 seconds
896
- this.editorsDrawer.open();
897
- const button = document.getElementById('botcloseplaygroundbutton');
898
- if (button) {
899
- button.style.display = 'none';
900
- }
901
- this.cdr.detectChanges();
902
- }
903
- scrollToBottom() {
904
- let counter = 0;
905
- const interval = setInterval(() => {
906
- this.chatMain.nativeElement.scrollTop = this.chatMain.nativeElement.scrollHeight;
907
- if (counter++ > 5)
908
- clearInterval(interval);
909
- }, 5);
910
- }
911
- handleAction(action) {
912
- console.info('incoming action from the chatbot AI');
913
- console.info(action);
914
- if (action === null || action === void 0 ? void 0 : action.content) {
915
- }
916
- }
917
- ngAfterViewInit() {
918
- // Check if the drawer is initially open and apply overflow hidden to body if so
919
- if (this.drawer.opened) {
920
- this.setBodyOverflow();
921
- }
922
- // Listen to changes in the drawer being opened or closed
923
- this.drawer.openedChange.subscribe((opened) => {
924
- if (opened) {
925
- this.setBodyOverflow();
926
- }
927
- else {
928
- this.removeBodyOverflow();
929
- }
930
- });
931
- this.drawer.openedChange.subscribe((opened) => {
932
- if (opened) {
933
- setTimeout(() => {
934
- if (this.myTextarea && this.myTextarea.nativeElement) {
935
- this.myTextarea.nativeElement.focus(); // Focus on the textarea
936
- }
937
- });
938
- }
939
- });
940
- }
941
- setBodyOverflow() {
942
- this.renderer.addClass(document.body, this.bodyOverflowClass);
943
- }
944
- removeBodyOverflow() {
945
- this.renderer.removeClass(document.body, this.bodyOverflowClass);
946
- }
947
- getSpeakersByStaffIds(ids) {
948
- const url = `${this.environment.USERS_API}/events/${this.eventId}/users/get-by-staff-ids`;
949
- fetch(url, {
950
- method: 'POST',
951
- headers: {
952
- 'Content-Type': 'application/json',
953
- Authorization: 'Bearer ' + 'your_token_here',
954
- },
955
- body: JSON.stringify(ids),
956
- })
957
- .then((response) => {
958
- if (response.ok) {
959
- return response.json(); // Parse the JSON body of the response
960
- }
961
- else {
962
- throw new Error('Network response was not ok.');
963
- }
964
- })
965
- .then((data) => {
966
- if ((data === null || data === void 0 ? void 0 : data.length) > 0) {
967
- data.forEach((speaker) => {
968
- this.speakers[speaker.id] = speaker;
969
- });
970
- this.cdr.markForCheck();
971
- }
972
- })
973
- .catch((err) => {
974
- console.error('Error fetching data:', err);
975
- this.loading = false;
976
- });
977
- }
978
- performSessionAction(sessionId, action) {
979
- this.sessionActions.next({
980
- sessionId,
981
- action,
982
- });
983
- }
984
- addCloseBotClickEvent() {
985
- const element = this.elementRef.nativeElement.querySelector('#closeBotNow');
986
- if (element) {
987
- this.renderer.listen(element, 'click', () => {
988
- this.closeBot.next();
989
- });
990
- }
991
- }
992
- isMobileBrowser() {
993
- return /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent);
994
- }
995
- connectToUser(userId) {
996
- this.connectWithUser.emit({
997
- connect: !this.canDisconnect(userId),
998
- userId,
999
- });
1000
- setTimeout(() => {
1001
- this.fetchMyConnections().subscribe((res) => {
1002
- this.cdr.markForCheck();
1003
- });
1004
- this.fetchPendingRequests().subscribe((res) => {
1005
- this.cdr.markForCheck();
1006
- });
1007
- }, 500);
1008
- }
1009
- scheduleMeetingWithUser(user) {
1010
- this.scheduleMeeting.emit(user);
1011
- }
1012
- canConnect(userId) {
1013
- return !(this.canDisconnect(userId) ||
1014
- this.pendingRequests.find((a) => a == userId));
1015
- }
1016
- canDisconnect(userId) {
1017
- return this.myConnections.find((conn) => conn.userId == userId);
1018
- }
1019
- fetchPendingRequests() {
1020
- const headers = new HttpHeaders({
1021
- 'Content-Type': 'application/json',
1022
- apiKey: this.autogenKey,
1023
- });
1024
- return this.http
1025
- .get(`${this.environment.USERS_API}/events/${this.eventId}/connection-requests/autogen/pending-sent-requests?userId=${this.userId}`, { headers })
1026
- .pipe(switchMap((res) => {
1027
- this.pendingRequests = res;
1028
- this.cdr.markForCheck();
1029
- return of(res);
1030
- }), catchError((error) => {
1031
- console.error('Error fetching pending requests: ', error);
1032
- return of(null);
1033
- }));
1034
- }
1035
- fetchMyConnections() {
1036
- const headers = new HttpHeaders({
1037
- 'Content-Type': 'application/json',
1038
- apiKey: this.autogenKey,
1039
- });
1040
- return this.http
1041
- .get(`${this.environment.USERS_API}/events/${this.eventId}/users-connections/autogen?userId=${this.userId}`, { headers })
1042
- .pipe(switchMap((res) => {
1043
- this.myConnections = res;
1044
- this.cdr.markForCheck();
1045
- return of(res);
1046
- }), catchError((error) => {
1047
- console.error('Error fetching pending requests: ', error);
1048
- return of(null);
1049
- }));
1050
- }
1051
- // Toggle the dropdown visibility
1052
- toggleDropdown() {
1053
- this.isDropdownOpen = !this.isDropdownOpen;
1054
- }
1055
- onSelectAll(event) {
1056
- var _a;
1057
- (_a = this.agents) === null || _a === void 0 ? void 0 : _a.forEach((agent) => (agent.selected = false));
1058
- this.cdr.detectChanges();
1059
- }
1060
- onAgentChange(agent) {
1061
- //agent.selected = !agent.selected;
1062
- //console.log(agent);
1063
- let agentFound = this.agents.filter((p) => p.id == agent.id);
1064
- if (agentFound && agentFound.length > 0) {
1065
- agentFound[0].selected = !agentFound[0].selected;
1066
- this.cdr.detectChanges();
1067
- }
1068
- this.cdr.detectChanges();
1069
- }
1070
- areAllSelected() {
1071
- var _a;
1072
- return (_a = this.agents) === null || _a === void 0 ? void 0 : _a.every((agent) => !agent.selected);
1073
- }
1074
- getDropdownHeaderText() {
1075
- var _a;
1076
- const selectedAgents = (_a = this.agents) === null || _a === void 0 ? void 0 : _a.filter((agent) => agent.selected);
1077
- if (selectedAgents && (selectedAgents === null || selectedAgents === void 0 ? void 0 : selectedAgents.length) === 0) {
1078
- return 'All Agents';
1079
- }
1080
- else {
1081
- return (selectedAgents === null || selectedAgents === void 0 ? void 0 : selectedAgents.length) > 1
1082
- ? `${selectedAgents === null || selectedAgents === void 0 ? void 0 : selectedAgents.length} Agents Selected`
1083
- : `${selectedAgents === null || selectedAgents === void 0 ? void 0 : selectedAgents.length} Agent Selected`;
1084
- }
1085
- }
1086
- fetchAgents_http() {
1087
- this.loading = true;
1088
- const url = `${this.environment.AGENTS_API}/CoPilot/${this.botId}/active-agents`;
1089
- const headers = new HttpHeaders({
1090
- 'Content-Type': 'application/json',
1091
- });
1092
- return this.http.post(url, {}, { headers }).pipe(switchMap((res) => {
1093
- if (res) {
1094
- this.agents = res.map((agent) => (Object.assign(Object.assign({}, agent), { selected: false })));
1095
- }
1096
- this.cdr.markForCheck();
1097
- return of(res);
1098
- }), catchError((error) => {
1099
- console.error('Error fetching chatbot config: ', error);
1100
- return of(null);
1101
- }));
1102
- }
1103
- fetchContent_http() {
1104
- this.isDocInEditMode = false;
1105
- this.isContentLoaded = false;
1106
- console.log('API call function');
1107
- this.loading = true;
1108
- const conversation_id = this.conversationService.getKey(this.botId);
1109
- this.conversationId = conversation_id;
1110
- const url = `${this.environment.AGENTS_API}/ConversationDocuments?conversationId=${conversation_id}&botId=${this.botId}`;
1111
- const headers = new HttpHeaders({
1112
- 'Content-Type': 'application/json',
1113
- apiKey: 'WIz/qAm+EEmfOkFaUA/weA==',
1114
- });
1115
- return this.http.get(url, { headers }).pipe(switchMap((res) => {
1116
- if (res) {
1117
- this.isDocInEditMode = true;
1118
- this.documentContent = res;
1119
- console.log('Get API callled success');
1120
- this.isContentLoaded = true;
1121
- console.log(res);
1122
- }
1123
- this.cdr.markForCheck();
1124
- return of(res);
1125
- }), catchError((error) => {
1126
- console.error('Error fetching chatbot config DJ: ', error);
1127
- this.isDocInEditMode = false;
1128
- this.isContentLoaded = true;
1129
- if ((error === null || error === void 0 ? void 0 : error.status) == 404) {
1130
- console.log('dash');
1131
- this.isDocInEditMode = false;
1132
- this.isContentLoaded = true;
1133
- }
1134
- return of(null);
1135
- }));
1136
- }
1137
- fetchAgents() {
1138
- this.fetchAgents_http().subscribe();
1139
- }
1140
- fetchEditorContent() {
1141
- this.fetchContent_http().subscribe();
1142
- }
1143
- // events/${eventId}/users-connections
1144
- processMessageForDisplay(markdown) {
1145
- var html = this.prepareHtml(markdown);
1146
- // console.log('After line breaks conversion:', html);
1147
- // Optional: Sanitize the HTML to prevent XSS
1148
- const sanitizedHtml = this.sanitizeHtml(html);
1149
- // console.log('Sanitized HTML:', sanitizedHtml);
1150
- return sanitizedHtml;
1151
- }
1152
- prepareHtml(markdown) {
1153
- if (!markdown || !(markdown.length > 0)) {
1154
- console.error('Input Markdown is null or empty');
1155
- return '';
1156
- }
1157
- // Convert Markdown headers (### or ##) to <strong> for bold headings
1158
- let html = markdown.replace(/^(#{1,6})\s+(.*)$/gm, (match, hashes, text) => {
1159
- const level = hashes.length;
1160
- if (level === 3) {
1161
- return `<h3><strong>${text}</strong></h3>`;
1162
- }
1163
- else if (level === 4) {
1164
- return `<h4><strong>${text}</strong></h4>`;
1165
- }
1166
- return `<strong>${text}</strong>`;
1167
- });
1168
- // Convert Markdown code blocks with language to preformatted HTML
1169
- html = html.replace(/```(\w+)?\n([\s\S]*?)```/g, (match, lang, code) => {
1170
- const escapedCode = this.escapeHtml(code);
1171
- const language = lang || 'plaintext';
1172
- // Create a copy button for the code block
1173
- return `
1174
- <div class="code-container">
1175
- <button id="copy-button" class="copy-button" (click)="copyToClipboard('\`${escapedCode}\`')">Copy</button>
1176
- <pre class="code_block diff"><code class="language-${language}">${escapedCode}</code></pre>
1177
- </div>`;
1178
- });
1179
- // Convert inline code (wrapped in `backticks`) to inline <code> tags
1180
- html = html.replace(/`([^`]+)`/g, '<code>$1</code>');
1181
- // Convert Markdown bold to HTML <strong>
1182
- html = html.replace(/\*\*(.*?)\*\*/g, '<strong>$1</strong>');
1183
- // Convert numbered lists
1184
- html = html.replace(/^\d+\.\s+(.*)$/gm, '<li>$1</li>');
1185
- // Convert bullet point lists
1186
- html = html.replace(/^\-\s+(.*)$/gm, '<li>$1</li>');
1187
- // Convert Markdown links to HTML links
1188
- html = html.replace(/\[([^\]]+)]\(([^)]+)\)/g, '<a href="$2" target="_blank">$1</a>');
1189
- // Convert new lines to <br> tags for paragraphs
1190
- html = html.replace(/(?:\r\n|\r|\n)/g, '<br>');
1191
- return html;
1192
- }
1193
- // Helper function to escape HTML characters for code blocks
1194
- escapeHtml(code) {
1195
- return code
1196
- .replace(/&/g, '&amp;')
1197
- .replace(/</g, '&lt;')
1198
- .replace(/>/g, '&gt;')
1199
- .replace(/"/g, '&quot;')
1200
- .replace(/'/g, '&#039;');
1201
- }
1202
- // Function to copy text to clipboard
1203
- copyToClipboard(text) {
1204
- navigator.clipboard.writeText(text).then(() => {
1205
- alert('Code copied to clipboard!');
1206
- }, (err) => {
1207
- console.error('Could not copy text: ', err);
1208
- });
1209
- }
1210
- toggleCollapse() {
1211
- this.isCollapsed = !this.isCollapsed;
1212
- this.cdr.detectChanges();
1213
- }
1214
- toggleCollapseGraph() {
1215
- this.isCollapsedForGraph = !this.isCollapsedForGraph;
1216
- this.cdr.detectChanges();
1217
- }
1218
- toggleCollapseFGraph() {
1219
- this.isCollapsedForFGraph = !this.isCollapsedForFGraph;
1220
- this.cdr.detectChanges();
1221
- }
1222
- // Extracts the domain from a URL
1223
- getDomainName(url) {
1224
- try {
1225
- const { hostname } = new URL(url);
1226
- return hostname.replace(/^www\./, ''); // Remove 'www.' if present
1227
- }
1228
- catch (_a) {
1229
- return 'unknown';
1230
- }
1231
- }
1232
- // Generates the favicon URL
1233
- getFaviconUrl(url) {
1234
- const domain = this.getDomainName(url);
1235
- return `https://www.google.com/s2/favicons?sz=128&domain=${domain}`;
1236
- }
1237
- onCardClick(sources) {
1238
- this.currentSourcesList = sources;
1239
- this.cdr.detectChanges();
1240
- this.sourcesDrawer.open();
1241
- const button = document.getElementById('botcloseplaygroundbutton');
1242
- if (button) {
1243
- button.style.display = 'none';
1244
- }
1245
- }
1246
- openOuterEditor() {
1247
- this.fetchEditorContent();
1248
- this.editorsDrawer.open();
1249
- this.isDrawerOpen = true;
1250
- this.isShowEditorButton = false;
1251
- this.cdr.detectChanges();
1252
- const button = document.getElementById('botcloseplaygroundbutton');
1253
- if (button) {
1254
- button.style.display = 'none';
1255
- }
1256
- }
1257
- onCloseEditor() {
1258
- this.editorsDrawer.close();
1259
- this.isDrawerOpen = false;
1260
- this.isShowEditorButton = true;
1261
- this.cdr.detectChanges(); // Trigger change detection if needed
1262
- this.onDrawerClosed();
1263
- }
1264
- onCloseSource() {
1265
- this.sourcesDrawer.close();
1266
- this.isDrawerOpen = false;
1267
- this.cdr.detectChanges(); // Trigger change detection if needed
1268
- this.onDrawerClosed();
1269
- }
1270
- onDrawerClosed() {
1271
- setTimeout(() => {
1272
- this.isDrawerOpen = true;
1273
- this.cdr.detectChanges(); // Trigger change detection if needed
1274
- // Use ngClass to dynamically apply the class
1275
- const button = document.getElementById('botcloseplaygroundbutton');
1276
- if (button) {
1277
- button.style.display = 'block';
1278
- }
1279
- }, 800);
1280
- }
1281
- toggleDrawer(todo) {
1282
- this.isDrawerOpen = todo;
1283
- this.cdr.detectChanges();
1284
- this.updateButtonVisibility();
1285
- }
1286
- updateButtonVisibility() {
1287
- const button = document.getElementById('botcloseplaygroundbutton');
1288
- if (button) {
1289
- button.style.display = this.isDrawerOpen ? 'block' : 'none';
1290
- }
1291
- }
1292
- openLinkInNewTab(link) {
1293
- window.open(link, '_blank');
1294
- }
1295
- adjustTextareaHeight(event) {
1296
- try {
1297
- if (event.key === 'Enter' && !event.shiftKey) {
1298
- // Prevents a new line from being added
1299
- event.preventDefault();
1300
- }
1301
- }
1302
- catch (error) {
1303
- }
1304
- const textarea = event.target;
1305
- textarea.style.height = 'auto'; // Reset the height
1306
- textarea.style.height = `${textarea.scrollHeight}px`; // Adjust height to match content
1307
- // Ensure the height doesn't exceed the max-height set in CSS
1308
- if (textarea.scrollHeight > 150) {
1309
- textarea.style.height = `150px`; // Adjust height to match content
1310
- textarea.style.overflowY = 'auto'; // Enable scrolling if content exceeds 400px
1311
- }
1312
- else {
1313
- textarea.style.overflowY = 'hidden'; // Hide scrollbar if content is within limits
1314
- }
1315
- }
1316
- toggleWorkflows(value = null) {
1317
- this.isWorkflowOpen = value == null ? !this.isWorkflowOpen : value;
1318
- if (!this.isWorkflowOpen) {
1319
- this.selectedWorkflow = null;
1320
- this.openWorkflowInput = false;
1321
- }
1322
- this.cdr.detectChanges();
1323
- }
1324
- initializeForm() {
1325
- var _a, _b;
1326
- // Create form controls dynamically based on selectedWorkflow.Trigger.InputSchema
1327
- const formControls = {};
1328
- if ((_b = (_a = this.selectedWorkflow) === null || _a === void 0 ? void 0 : _a.Trigger) === null || _b === void 0 ? void 0 : _b.InputSchema) {
1329
- this.selectedWorkflow.Trigger.InputSchema.forEach((input) => {
1330
- formControls[input.InputId] = [
1331
- input.Value || '',
1332
- input.Required ? Validators.required : null,
1333
- ];
1334
- });
1335
- }
1336
- // Initialize the form
1337
- this.workflowForm = this.fb.group(formControls);
1338
- }
1339
- onWorkflowSelected(workflow) {
1340
- this.selectedWorkflow = workflow;
1341
- this.initializeForm();
1342
- this.isWorkflowOpen = false;
1343
- this.openWorkflowInput = true;
1344
- }
1345
- onWorkflowSubmit() {
1346
- const container = document.getElementById('allChats');
1347
- if (this.workflowForm.valid) {
1348
- console.log(this.workflowForm.value);
1349
- var input = this.prepareHtml(this.generateMarkdown(this.selectedWorkflow.Name, this.workflowForm.value));
1350
- // update last two chatLog entries, set showWorkflowExecutionLoader = false
1351
- try {
1352
- this.chatLog[this.chatLog.length - 1]['showWorkflowExecutionLoader'] = false;
1353
- this.chatLog[this.chatLog.length - 2]['showWorkflowExecutionLoader'] = false;
1354
- }
1355
- catch (error) { }
1356
- this.chatLog.push({
1357
- type: 'user',
1358
- message: input,
1359
- time: formatNow(this.timezone),
1360
- copied: false,
1361
- isCollapsedTrue: false,
1362
- showWorkflowExecutionLoader: true,
1363
- });
1364
- console.log(input);
1365
- this.currentWorkflowActionProgress = 0;
1366
- this.currentWorkflowAction =
1367
- 'Executing ' + this.selectedWorkflow.Actions[0].Name;
1368
- this.isChatingWithAi = true;
1369
- this.executingWorkflow = true;
1370
- this.workflowExecutionDetails = {
1371
- Actions: this.selectedWorkflow.Actions,
1372
- Inputs: this.workflowForm.value,
1373
- workflowInputs: this.workflowForm.value,
1374
- WorkflowName: this.selectedWorkflow.Name,
1375
- };
1376
- this.currentWorkflowExecutionDetails = this.workflowExecutionDetails;
1377
- this.scrollToBottom();
1378
- this.cdr.detectChanges();
1379
- // execute the ask endpoint with workflow input
1380
- this.makeAskRequest(input, this.agents, this.conversationKey, '', null, this.selectedWorkflow['_id'], this.workflowForm.value);
1381
- }
1382
- }
1383
- makeAskRequest(inputMsg, agents, conversationId, msg, chat, workflowId, workflow_inputs) {
1384
- var url = `${this.environment.BASE_URL}/ai/ask`;
1385
- var body = {
1386
- user_question: inputMsg,
1387
- user_id: this.userId,
1388
- bot_id: this.botId,
1389
- message_id: this.conversationService.generateKey(),
1390
- agents: agents.filter((p) => p.selected).map((p) => p.id),
1391
- conversation_id: conversationId,
1392
- };
1393
- if (workflowId) {
1394
- body['workflow_id'] = workflowId;
1395
- body['workflow_inputs'] = workflow_inputs;
1396
- }
1397
- fetch(url, {
1398
- method: 'POST',
1399
- headers: {
1400
- 'Content-Type': 'application/json',
1401
- Authorization: 'Bearer ' + this.s27Token,
1402
- 'x-api-key': this.apiKey,
1403
- },
1404
- body: JSON.stringify(body),
1405
- })
1406
- .then((response) => {
1407
- if (response.status === 401 || response.status === 403) {
1408
- this.is401 = true;
1409
- this.refreshToken.emit();
1410
- // If `msg` and `chat` exist, handle them
1411
- if (msg && chat) {
1412
- this.msg = msg;
1413
- this.chat = chat;
1414
- this.isFetchDataFor = true;
1415
- }
1416
- }
1417
- else {
1418
- this.is401 = false;
1419
- }
1420
- return response.json();
1421
- })
1422
- .then((data) => {
1423
- console.log(data);
1424
- // Additional response handling if needed
1425
- })
1426
- .catch((err) => {
1427
- console.error('Error: ', err);
1428
- this.isChatingWithAi = false;
1429
- });
1430
- this.input = '';
1431
- this.selectedWorkflow = null;
1432
- this.openWorkflowInput = false;
1433
- this.isWorkflowOpen = false;
1434
- this.scrollToBottom();
1435
- this.cdr.markForCheck();
1436
- }
1437
- generateMarkdown(title, obj) {
1438
- var _a;
1439
- // Initialize markdown with the title
1440
- let markdown = `## ${title}\n`;
1441
- // Loop through the object and append the field names and values
1442
- for (const [key, value] of Object.entries(obj)) {
1443
- var key_label = ((_a = this.selectedWorkflow.Trigger.InputSchema.find((input) => input.InputId === key)) === null || _a === void 0 ? void 0 : _a.Label) || key;
1444
- markdown += `- **${key_label}**: ${value}\n`;
1445
- }
1446
- return markdown;
1447
- }
1448
- showWorkflowHistoryDetails(workflow_id) {
1449
- if (!workflow_id) {
1450
- this.workflowExecutionDetails = this.currentWorkflowExecutionDetails;
1451
- this.showWorkflowExecutionDetails = true;
1452
- this.cdr.detectChanges();
1453
- return;
1454
- }
1455
- this.botService.getWorkflowExecutionById(workflow_id).subscribe((res) => {
1456
- if (res && res.Actions && Array.isArray(res.Actions)) {
1457
- res.Actions = res.Actions.map((action) => {
1458
- if (action.InsertTimeStamp) {
1459
- action.InsertTimeStamp = formatTimeStamps(this.timezone, action.InsertTimeStamp);
1460
- }
1461
- return action;
1462
- });
1463
- }
1464
- res.InsertTimeStamp = formatTimeStamps(this.timezone, res.InsertTimeStamp);
1465
- this.workflowExecutionDetails = res;
1466
- this.showWorkflowExecutionDetails = true;
1467
- this.cdr.detectChanges();
1468
- });
1469
- }
1470
- closeModal() {
1471
- this.showWorkflowExecutionDetails = false;
1472
- }
1473
- objectToArray(obj) {
1474
- return Object.keys(obj).map((key) => ({ key, value: obj[key] }));
1475
- }
1476
- startNewConversation() {
1477
- this.conversationKey = this.conversationService.getKey(this.botId, true);
1478
- this.chatLog = [this.chatLog[0]];
1479
- this.isChatingWithAi = false;
1480
- setTimeout(() => {
1481
- this.initializeSocket();
1482
- }, 200);
1483
- this.scrollToBottom();
1484
- this.cdr.detectChanges();
1485
- }
1486
- initializeSpeechRecognizer(token) {
1487
- this.speechConfig = SpeechSDK.SpeechConfig.fromAuthorizationToken(token, this.region);
1488
- const audioConfig = SpeechSDK.AudioConfig.fromDefaultMicrophoneInput();
1489
- this.recognizer = new SpeechSDK.SpeechRecognizer(this.speechConfig, audioConfig);
1490
- this.recognizer.recognizing = (s, e) => {
1491
- if (e.result.reason === SpeechSDK.ResultReason.RecognizingSpeech) {
1492
- this.input = e.result.text;
1493
- console.log(`Recognizing: ${e.result.text}`);
1494
- this.cdr.markForCheck();
1495
- }
1496
- };
1497
- this.recognizer.recognized = (s, e) => {
1498
- if (e.result.reason === SpeechSDK.ResultReason.RecognizedSpeech) {
1499
- this.input = e.result.text;
1500
- console.log(`Recognized: ${e.result.text}`);
1501
- this.toggleRecording();
1502
- this.cdr.markForCheck();
1503
- }
1504
- };
1505
- this.recognizer.canceled = (s, e) => {
1506
- console.error('Canceled: ', e.errorDetails);
1507
- };
1508
- this.recognizer.sessionStopped = (s, e) => {
1509
- console.log('Session stopped.');
1510
- this.recognizer.stopContinuousRecognitionAsync();
1511
- this.fetchData();
1512
- };
1513
- }
1514
- toggleRecording() {
1515
- this.isRecording = !this.isRecording;
1516
- if (this.isRecording) {
1517
- this.startRecognition();
1518
- }
1519
- else {
1520
- this.stopRecognition();
1521
- }
1522
- }
1523
- startRecognition() {
1524
- this.recognizer.startContinuousRecognitionAsync();
1525
- }
1526
- stopRecognition() {
1527
- this.recognizer.stopContinuousRecognitionAsync();
1528
- }
1529
- checkForCop29BotId() {
1530
- return this.botId == '66fa3f276c5d71e2717bfea8';
1531
- }
1532
- }
1533
- ChatDrawerComponent.decorators = [
1534
- { type: Component, args: [{
1535
- selector: 'hivegpt-chat-drawer-package',
1536
- template: "<button *ngIf=\"isShowEditorButton\" (click)=\"openOuterEditor()\" class=\"fixed-btn\">\r\n <span style=\"font-size: 12px\" class=\"material-icons notranslate\">\r\n create\r\n </span>\r\n Editor\r\n</button>\r\n\r\n<button *ngIf=\"!isShowEditorButton\" (click)=\"onCloseEditor()\" class=\"fixed-btn-close\">\r\n <span style=\"font-size: 12px\" class=\"material-icons notranslate\">\r\n close\r\n </span>\r\n Close\r\n</button>\r\n\r\n<mat-drawer-container class=\"hivegpt-chat-wrapper\" [ngClass]=\"{ 'mat-drawer-container-has-open': isDrawerOpen }\"\r\n [class.ios-device]=\"isIOSDevice\" [hasBackdrop]=\"hasBackdropValue\">\r\n <mat-drawer class=\"drawer\" #drawer [position]=\"'start'\" [mode]=\"'over'\" opened=\"true\"\r\n [class.full-width-drawer]=\"fullView\" [style.background]=\"\r\n 'linear-gradient(' + (bgGradient ? bgGradient.join(', ') : '') + ')'\r\n \">\r\n <mat-drawer-content>\r\n <div class=\"chat-main\">\r\n <!-- <div class=\"chat-header\">\r\n <h2> -->\r\n <!-- {{eventName}} -->\r\n <!-- </h2> -->\r\n <!-- <button class=\"closeIcon\" (click)=\"onClose()\">\r\n <span class=\"material-symbols-outlined\">\r\n close\r\n </span>\r\n </button> -->\r\n <!-- </div> -->\r\n\r\n <div class=\"innerChat\" #chatMain>\r\n <div (click)=\"startNewConversation()\" class=\"new-conversationbutton\">\r\n New Chat <span><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"14.061\" height=\"14.261\"\r\n viewBox=\"0 0 14.061 14.261\">\r\n <path id=\"Path_164\" data-name=\"Path 164\"\r\n d=\"M10.146,5.075H4.531A1.544,1.544,0,0,0,3,6.631v7.262A1.544,1.544,0,0,0,4.531,15.45h7.146a1.544,1.544,0,0,0,1.531-1.556V8.187m-7.146,4.15L15.25,3m0,0H11.677M15.25,3V6.631\"\r\n transform=\"translate(-2.25 -1.939)\" fill=\"none\" stroke=\"#06f\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" stroke-width=\"1.5\" />\r\n </svg>\r\n\r\n </span>\r\n </div>\r\n <div class=\"sticky-header-chat\">\r\n <div class=\"title_chat\">\r\n <h2>\r\n <span>\r\n {{ botName }}\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"31.499\" height=\"31.501\" viewBox=\"0 0 31.499 31.501\">\r\n <path id=\"Icon_ion-shield-checkmark\" data-name=\"Icon ion-shield-checkmark\"\r\n d=\"M33.685,7.83a1.125,1.125,0,0,0-.925-1.036,49.227,49.227,0,0,1-14.3-4.444,1.125,1.125,0,0,0-.927,0A49.226,49.226,0,0,1,3.24,6.794,1.125,1.125,0,0,0,2.315,7.83a27.621,27.621,0,0,0,1.718,11.9A24.572,24.572,0,0,0,9.07,27.641a25.712,25.712,0,0,0,8.513,6.028,1.125,1.125,0,0,0,.844,0,25.712,25.712,0,0,0,8.513-6.028,24.572,24.572,0,0,0,5.027-7.911,27.621,27.621,0,0,0,1.718-11.9Zm-9.211,5.281-7.791,9a1.125,1.125,0,0,1-.8.389h-.046a1.125,1.125,0,0,1-.788-.322L11.587,18.79a1.125,1.125,0,1,1,1.575-1.607l2.6,2.552,7.01-8.1a1.125,1.125,0,0,1,1.7,1.472Z\"\r\n transform=\"translate(-2.25 -2.25)\" fill=\"#06f\" />\r\n </svg>\r\n </span>\r\n <span>\r\n <p class=\"small-title\">AI-powered <span>copilot</span></p>\r\n </span>\r\n </h2>\r\n </div>\r\n <div class=\"chatType\" style=\"display: none\">\r\n <h4 class=\"labelChat\">Choose a conversation style</h4>\r\n <ul>\r\n <li (click)=\"changeTemperature(0)\">\r\n <button [ngClass]=\"{ active: temperature === 0 }\">\r\n <span class=\"top-section-title\"> More Creative </span>\r\n </button>\r\n </li>\r\n <li (click)=\"changeTemperature(1)\" class=\"fdssfd\">\r\n <button [ngClass]=\"{ active: temperature === 1 }\">\r\n <span class=\"top-section-title\"> More Balanced </span>\r\n </button>\r\n </li>\r\n <li (click)=\"changeTemperature(2)\">\r\n <button [ngClass]=\"{ active: temperature === 2 }\">\r\n <span class=\"top-section-title\"> More Precise </span>\r\n </button>\r\n </li>\r\n </ul>\r\n </div>\r\n </div>\r\n <!-- chattype -->\r\n <div id=\"allChats\" class=\"chat bot\" *ngFor=\"let chat of chatLog; let i = index\">\r\n <div class=\"chat-box\">\r\n <div class=\"message\">\r\n <div class=\"time-cta\" [ngClass]=\"{\r\n 'time-cta din': showFeedBackIconsIndex === i,\r\n 'time-cta': showFeedBackIconsIndex != i\r\n }\">\r\n <div class=\"Icon_TimeSTamp\" *ngIf=\"chat?.type === 'ai'\">\r\n <!-- <img [src]=\"botIcon\" [alt]=\"botName || 'Assistant'\" /> -->\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"44\" height=\"44\" viewBox=\"0 0 44 44\">\r\n <g id=\"Group_121\" data-name=\"Group 121\" transform=\"translate(4843 -371)\">\r\n <g id=\"Ellipse_18\" data-name=\"Ellipse 18\" transform=\"translate(-4843 371)\" fill=\"#fcfcfc\"\r\n stroke=\"#dfdfdf\" stroke-width=\"1\">\r\n <circle cx=\"22\" cy=\"22\" r=\"22\" stroke=\"none\" />\r\n <circle cx=\"22\" cy=\"22\" r=\"21.5\" fill=\"none\" />\r\n </g>\r\n <g id=\"Group_120\" data-name=\"Group 120\" transform=\"translate(-4835.141 378.855)\">\r\n <g id=\"Group_1\" data-name=\"Group 1\" transform=\"translate(7.29 0)\">\r\n <path id=\"Path_1\" data-name=\"Path 1\"\r\n d=\"M93.774,41.324,98.757,44.2v5.753l-4.983,2.877-4.983-2.877V44.2l4.983-2.877m0-2.034L87.03,43.183V50.97l6.744,3.893,6.744-3.893V43.183L93.774,39.29Z\"\r\n transform=\"translate(-87.03 -39.29)\" fill=\"gray\" />\r\n </g>\r\n <g id=\"Group_2\" data-name=\"Group 2\" transform=\"translate(0 12.717)\">\r\n <path id=\"Path_2\" data-name=\"Path 2\"\r\n d=\"M52.374,113.544l4.983,2.877v5.753l-4.983,2.877-4.983-2.877v-5.753l4.983-2.877m0-2.034L45.63,115.4v7.787l6.744,3.893,6.744-3.893V115.4l-6.744-3.893Z\"\r\n transform=\"translate(-45.63 -111.51)\" fill=\"gray\" />\r\n </g>\r\n <g id=\"Group_3\" data-name=\"Group 3\" transform=\"translate(14.793 12.717)\">\r\n <path id=\"Path_3\" data-name=\"Path 3\"\r\n d=\"M136.384,113.544l4.983,2.877v5.753l-4.983,2.877-4.983-2.877v-5.753l4.983-2.877m0-2.034L129.64,115.4v7.787l6.744,3.893,6.744-3.893V115.4l-6.744-3.893Z\"\r\n transform=\"translate(-129.64 -111.51)\" fill=\"gray\" />\r\n </g>\r\n </g>\r\n </g>\r\n </svg>\r\n\r\n <div class=\"dateTime\" [style.color]=\"dateTimeColor ? '' : ''\">\r\n <span>{{ 'Assistant' }}</span> {{ chat?.time }}\r\n </div>\r\n </div>\r\n\r\n <div class=\"Icon_TimeSTamp\" *ngIf=\"chat?.type === 'user'\">\r\n <div class=\"user-Box\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"44\" height=\"44\" viewBox=\"0 0 44 44\">\r\n <g id=\"Ellipse_17\" data-name=\"Ellipse 17\" fill=\"#fcfcfc\" stroke=\"#dfdfdf\" stroke-width=\"1\">\r\n <circle cx=\"22\" cy=\"22\" r=\"22\" stroke=\"none\" />\r\n <circle cx=\"22\" cy=\"22\" r=\"21.5\" fill=\"none\" />\r\n </g>\r\n <path id=\"Icon_grommet-user-expert\" data-name=\"Icon grommet-user-expert\"\r\n d=\"M14.24,20.443a9.472,9.472,0,1,0-9.472-9.472,9.472,9.472,0,0,0,9.472,9.472Zm10.329,5.225c-1.957-3.347-6.516-5.225-10.329-5.225-3.145,0-8.046.805-10.761,5.225\"\r\n transform=\"translate(7.976 8.416)\" fill=\"none\" stroke=\"gray\" stroke-width=\"1.5\" />\r\n </svg>\r\n\r\n <div class=\"dateTime\"><span>You</span> {{ chat?.time }}\r\n </div>\r\n </div>\r\n <div class=\"bards\">\r\n <div class=\"bars\" *ngIf=\"chat?.WorkflowExecutionId || chat?.showWorkflowExecutionLoader\">\r\n <button class=\"icon-button\" (click)=\"showWorkflowHistoryDetails(chat.WorkflowExecutionId)\">\r\n <i class=\"fas fa-bars\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n </div>\r\n <div class=\"researchingCard\">\r\n <div *ngIf=\"\r\n (chat?.searchTerms && chat?.searchTerms.length > 0) ||\r\n (chat?.sourcesList && chat?.sourcesList.length > 0)\r\n \" class=\"card-header d-flex align-items-center\" (click)=\"toggleCollapse()\">\r\n <span class=\"icon\"><i class=\"bx bx-plus-circle bx-sm\"></i></span>\r\n <span class=\"ml-2\">Researching\r\n <i id=\"toggleIcon\" class=\"toggle-icon ml-2 fa\" [ngClass]=\"{\r\n 'fa-chevron-down': isCollapsed,\r\n 'fa-chevron-up': !isCollapsed\r\n }\"></i></span>\r\n </div>\r\n <div *ngIf=\"chat?.searchTerms && chat?.searchTerms.length > 0\" [ngClass]=\"{ collapse: isCollapsed }\">\r\n <ul class=\"list-group list-group-flush uptList\">\r\n <li *ngFor=\"let term of chat?.searchTerms\" class=\"list-group-item\">\r\n Searching for\r\n <strong>{{ term }}</strong>\r\n </li>\r\n </ul>\r\n\r\n <h5 class=\"mt-2\" *ngIf=\"chat?.sourcesList && chat?.sourcesList.length > 0\">\r\n <i class=\"bx bx-unite\"></i> Sources\r\n </h5>\r\n <div class=\"sources-container\" *ngIf=\"chat?.sourcesList && chat?.sourcesList.length > 0\">\r\n <div class=\"source-card\" *ngFor=\"\r\n let source of chat?.displayedSources;\r\n let i = index\r\n \">\r\n <div>\r\n <div class=\"source-title\">{{ source.title }}</div>\r\n <div class=\"source-url\">\r\n <img class=\"relative block\" [src]=\"getFaviconUrl(source.link)\"\r\n [alt]=\"getDomainName(source.link) + ' favicon'\" />\r\n {{ getDomainName(source.link) }}\r\n </div>\r\n <div class=\"popup\">\r\n <div class=\"source-url\" (click)=\"openLinkInNewTab(source.link)\">\r\n <img class=\"relative block\" [src]=\"getFaviconUrl(source.link)\"\r\n [alt]=\"getDomainName(source.link) + ' favicon'\" />\r\n {{ getDomainName(source.link) }}\r\n </div>\r\n <h5 (click)=\"openLinkInNewTab(source.link)\">\r\n {{ source.title }}\r\n </h5>\r\n <p (click)=\"openLinkInNewTab(source.link)\">\r\n {{ source.desc }}\r\n </p>\r\n </div>\r\n </div>\r\n </div>\r\n <ng-container *ngIf=\"\r\n chat?.remainingSources &&\r\n chat?.remainingSources.length > 0\r\n \">\r\n <div class=\"source-card\" (click)=\"onCardClick(chat?.sourcesList)\">\r\n <div>\r\n <div class=\"source-title\">\r\n <img *ngFor=\"\r\n let source of chat?.remainingSources;\r\n let i = index\r\n \" class=\"relative block\" [src]=\"getFaviconUrl(source.link)\"\r\n [alt]=\"getDomainName(source.link) + ' favicon'\" />\r\n </div>\r\n <div class=\"source-url\">\r\n View {{ chat?.remainingSources.length }} more\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"chat?.type === 'ai' || chat?.type === 'user'\" [ngStyle]=\"{\r\n background:\r\n chat?.type === 'ai' && bgBubbleAi\r\n ? ''\r\n : chat?.type === 'user' && bgBubbleUser\r\n ? ''\r\n : ''\r\n }\">\r\n <div id=\"messageText_{{ i }}\">\r\n <p *ngIf=\"chat?.type === 'ai' || chat?.type === 'user'\" [ngClass]=\"{\r\n 'SearchTitle ai': chat?.type === 'ai',\r\n 'SearchTitle user': chat?.type === 'user'\r\n }\" [ngStyle]=\"{\r\n background: chat?.type === 'ai' && messageTextColorAi ? messageTextColorAi : (chat?.type === 'user' && messageTextColorUser ? messageTextColorUser : 'defaultBackground'),\r\n color: chat?.type === 'ai' && messageTextColorAi ? messageTextColorAi : (chat?.type === 'user' && messageTextColorUser ? messageTextColorUser : 'defaultColor')\r\n }\" [innerHTML]=\"chat?.message\">\r\n </p>\r\n </div>\r\n </div>\r\n\r\n <div class=\"progress-container\" *ngIf=\"chat?.showWorkflowExecutionLoader\">\r\n <div class=\"circular-loader\">\r\n <div class=\"loader-spinner\" *ngIf=\"currentWorkflowActionProgress < 100\"\r\n [ngStyle]=\"{ 'transform': 'rotate(' + (percentage * 3.6) + 'deg)' }\">\r\n </div>\r\n <div class=\"checkmark\" *ngIf=\"currentWorkflowActionProgress == 100\">\r\n <svg viewBox=\"0 0 52 52\">\r\n <circle class=\"checkmark-circle\" cx=\"26\" cy=\"26\" r=\"25\" fill=\"none\" />\r\n <path class=\"checkmark-check\" fill=\"none\" d=\"M14 27l7 7 16-16\" />\r\n </svg>\r\n </div>\r\n\r\n <div class=\"loader-text\" *ngIf=\"currentWorkflowActionProgress < 100\">{{\r\n currentWorkflowActionProgress\r\n }}%</div>\r\n </div>\r\n <div class=\"loader-label\">\r\n {{currentWorkflowAction}}...\r\n </div>\r\n </div>\r\n\r\n <div class=\"exicution mt-2\" *ngIf=\"\r\n chat?.type === 'ai' &&\r\n chat?.graphs &&\r\n chat?.graphs.length > 0\r\n \">\r\n <h5 *ngIf=\"chat?.type === 'ai'\">\r\n <i class=\"bx bx-network-chart\"></i> Graphs\r\n <i (click)=\"toggleCollapseFGraph()\" class=\"toggle-icon ml-2 fa\" [ngClass]=\"{\r\n 'fas fa-chevron-down': isCollapsedForFGraph,\r\n 'fas fa-chevron-up': !isCollapsedForFGraph\r\n }\"></i>\r\n </h5>\r\n <img *ngFor=\"let image of chat?.graphs\" class=\"graph-img\"\r\n [ngClass]=\"{ collapse: isCollapsedForFGraph }\" [src]=\"image\" alt=\"\" />\r\n </div>\r\n <ng-container *ngIf=\"!checkForCop29BotId()\">\r\n <div class=\"exicution mt-2\" *ngIf=\"\r\n chat?.type === 'ai' &&\r\n chat?.executionGraphs &&\r\n chat?.executionGraphs?.length > 0\r\n \">\r\n <h5 *ngIf=\"chat?.type === 'ai'\">\r\n <i class=\"bx bx-network-chart\"></i> Execution Path Diagram\r\n For Data Visualization Workflow\r\n <i (click)=\"toggleCollapseGraph()\" class=\"toggle-icon ml-2 fa\" [ngClass]=\"{\r\n 'fas fa-chevron-down': isCollapsedForGraph,\r\n 'fas fa-chevron-up': !isCollapsedForGraph\r\n }\"></i>\r\n </h5>\r\n <img *ngFor=\"let image of chat?.executionGraphs\" class=\"graph-img\"\r\n [ngClass]=\"{ collapse: isCollapsedForGraph }\" [src]=\"image\" alt=\"\" />\r\n </div>\r\n </ng-container>\r\n <div class=\"Related mt-2\" *ngIf=\"\r\n showFeedBackIconsIndex === i &&\r\n chat?.relatedListItems &&\r\n chat?.relatedListItems.length > 0\r\n \">\r\n <h5 *ngIf=\"chat?.type === 'ai'\">\r\n <i class=\"bx bx-list-check\"></i> Related\r\n </h5>\r\n <div class=\"card-container\" *ngIf=\"chat?.type === 'ai'\">\r\n <ul class=\"list-container\">\r\n <ng-container *ngFor=\"let item of chat?.relatedListItems\">\r\n <li (click)=\"fetchDataFor(item, chat)\">{{ item }}</li>\r\n </ng-container>\r\n </ul>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"cta\" *ngIf=\"showFeedBackIconsIndex === i\">\r\n <div class=\"copyBox\" title=\"Copy\">\r\n <button title=\"{{ chat?.copied ? 'Copied!' : 'Copy' }}\" class=\"copy\" [class.active]=\"chat?.copied\"\r\n (click)=\"handleCopyClick(i)\">\r\n <i *ngIf=\"chat?.copied\">\r\n <svg width=\"18\" height=\"18\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M9 16.17L4.83 12L3.41 13.41L9 19L21 7L19.59 5.59L9 16.17Z\" fill=\"#566563\" />\r\n </svg>\r\n </i>\r\n\r\n <i *ngIf=\"!chat?.copied\">\r\n <svg width=\"18\" height=\"18\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M19.24 2H8.84C8.14 2 7.58 2.56 7.58 3.26V16.84C7.58 17.54 8.14 18.1 8.84 18.1H19.24C19.94 18.1 20.5 17.54 20.5 16.84V3.26C20.5 2.56 19.94 2 19.24 2ZM19.24 16.84H8.84V3.26H19.24V16.84ZM4.74 6.52C4.04 6.52 3.48 7.08 3.48 7.78V20.36C3.48 21.06 4.04 21.62 4.74 21.62H15.14C15.84 21.62 16.4 21.06 16.4 20.36V18.88H14.96V20.36H4.74V7.78H6.18V6.52H4.74Z\"\r\n fill=\"#566563\" />\r\n </svg>\r\n </i>\r\n </button>\r\n\r\n <button class=\"up copy\" title=\"{{ chat?.isEditor ? 'Added!' : 'Add to editor' }}\"\r\n (click)=\"handleEditorClick(i)\">\r\n <svg *ngIf=\"!chat?.isEditor\" xmlns=\"http://www.w3.org/2000/svg\" width=\"20.152\" height=\"20.152\"\r\n viewBox=\"0 0 20.152 20.152\">\r\n <g id=\"Icon_feather-edit\" data-name=\"Icon feather-edit\" transform=\"translate(-2.5 -2.166)\">\r\n <path id=\"Path_166\" data-name=\"Path 166\"\r\n d=\"M11.5,6H4.889A1.889,1.889,0,0,0,3,7.889v13.22A1.889,1.889,0,0,0,4.889,23h13.22A1.889,1.889,0,0,0,20,21.108V14.5\"\r\n transform=\"translate(0 -1.179)\" fill=\"none\" stroke=\"#393939\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" stroke-width=\"1\" />\r\n <path id=\"Path_167\" data-name=\"Path 167\"\r\n d=\"M21.915,3.4a2,2,0,0,1,2.833,2.833l-8.971,8.971L12,16.152l.944-3.777Z\"\r\n transform=\"translate(-3.334 0)\" fill=\"none\" stroke=\"#393939\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" stroke-width=\"1\" />\r\n </g>\r\n </svg>\r\n\r\n <i *ngIf=\"chat?.isEditor\">\r\n <svg width=\"18\" height=\"18\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M9 16.17L4.83 12L3.41 13.41L9 19L21 7L19.59 5.59L9 16.17Z\" fill=\"#566563\" />\r\n </svg>\r\n </i>\r\n </button>\r\n\r\n <button class=\"up copy\" title=\"Like\" [class.active]=\"chat?.liked\" (click)=\"handleUpClick(i)\">\r\n <i *ngIf=\"chat?.liked\">\r\n <svg width=\"18\" height=\"18\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M8.38989 18.4902V8.33022C8.38989 7.93022 8.50989 7.54022 8.72989 7.21022L11.4599 3.15022C11.8899 2.50022 12.9599 2.04022 13.8699 2.38022C14.8499 2.71022 15.4999 3.81022 15.2899 4.79022L14.7699 8.06022C14.7299 8.36022 14.8099 8.63022 14.9799 8.84022C15.1499 9.03022 15.3999 9.15022 15.6699 9.15022H19.7799C20.5699 9.15022 21.2499 9.47022 21.6499 10.0302C22.0299 10.5702 22.0999 11.2702 21.8499 11.9802L19.3899 19.4702C19.0799 20.7102 17.7299 21.7202 16.3899 21.7202H12.4899C11.8199 21.7202 10.8799 21.4902 10.4499 21.0602L9.16989 20.0702C8.67989 19.7002 8.38989 19.1102 8.38989 18.4902Z\"\r\n fill=\"#17235B\" />\r\n <path\r\n d=\"M5.21 6.37988H4.18C2.63 6.37988 2 6.97988 2 8.45988V18.5199C2 19.9999 2.63 20.5999 4.18 20.5999H5.21C6.76 20.5999 7.39 19.9999 7.39 18.5199V8.45988C7.39 6.97988 6.76 6.37988 5.21 6.37988Z\"\r\n fill=\"#17235B\" />\r\n </svg>\r\n </i>\r\n <i *ngIf=\"!chat?.liked\">\r\n <svg width=\"18\" height=\"18\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M10.4037 20.9264L10.381 20.9038L10.3557 20.8843L7.72165 18.85L8.02965 18.4516L10.7161 20.5315C10.9228 20.7195 11.2181 20.8517 11.4962 20.9377C11.7978 21.0309 12.1451 21.09 12.4801 21.09H16.2801C16.8572 21.09 17.4266 20.8625 17.8751 20.5306C18.3159 20.2044 18.6912 19.7385 18.8305 19.1997L21.2428 11.8732C21.4379 11.3309 21.4287 10.749 21.0965 10.2887C20.7583 9.81377 20.1844 9.58999 19.5801 9.58999H15.5801C15.2031 9.58999 14.8615 9.43143 14.6276 9.16215L14.627 9.16142C14.3873 8.88649 14.2756 8.51549 14.3345 8.11501L14.8322 4.9195C14.9978 4.1052 14.4664 3.24596 13.7053 2.98804C13.3277 2.85165 12.9297 2.89129 12.61 2.99839C12.2949 3.10396 11.9772 3.30172 11.7881 3.57673L11.7881 3.57671L11.7851 3.58107L7.96352 9.26689L7.55454 8.99314L11.3751 3.30891L11.3755 3.30836C11.8763 2.56103 13.0109 2.19028 13.8726 2.51744L13.8834 2.52151L13.8943 2.52509C14.9044 2.8564 15.556 3.98765 15.3317 5.01314L15.3284 5.02805L15.326 5.04314L14.836 8.19314L14.836 8.19313L14.8351 8.19928C14.8184 8.31642 14.7981 8.60268 15.0138 8.84924L15.0248 8.86177L15.0366 8.87354C15.1833 9.02026 15.3817 9.09999 15.5901 9.09999H19.5901C20.4308 9.09999 21.1176 9.44886 21.5113 10.0079L21.5124 10.0095C21.8964 10.5502 21.9908 11.2849 21.7202 12.0291L21.7175 12.0365L21.7151 12.044L19.3251 19.324L19.3198 19.34L19.3156 19.3564C19.0058 20.5707 17.6766 21.6 16.2801 21.6H12.4801C12.2411 21.6 11.8403 21.5625 11.4297 21.4512C11.0123 21.338 10.6406 21.1633 10.4037 20.9264Z\"\r\n fill=\"#566563\" stroke=\"#566563\" />\r\n <path\r\n d=\"M5.37988 20.4999H4.37988C3.52442 20.4999 2.98559 20.2982 2.65822 19.9825C2.33437 19.6702 2.12988 19.1614 2.12988 18.3499V8.5499C2.12988 7.73843 2.33437 7.22962 2.65822 6.91731C2.98559 6.6016 3.52442 6.3999 4.37988 6.3999H5.37988C6.23534 6.3999 6.77418 6.6016 7.10155 6.91731C7.4254 7.22962 7.62988 7.73843 7.62988 8.5499V18.3499C7.62988 19.1614 7.4254 19.6702 7.10155 19.9825C6.77418 20.2982 6.23534 20.4999 5.37988 20.4999ZM4.37988 6.8999C4.0934 6.8999 3.83578 6.9164 3.61382 6.96689C3.38745 7.01838 3.16822 7.11196 2.99258 7.2876C2.81559 7.46459 2.72807 7.67966 2.68301 7.89002C2.63948 8.09318 2.62988 8.31967 2.62988 8.5499V18.3499C2.62988 18.5801 2.63948 18.8066 2.68301 19.0098C2.72807 19.2201 2.81559 19.4352 2.99258 19.6122C3.16822 19.7878 3.38745 19.8814 3.61382 19.9329C3.83578 19.9834 4.0934 19.9999 4.37988 19.9999H5.37988C5.66637 19.9999 5.92398 19.9834 6.14595 19.9329C6.37232 19.8814 6.59155 19.7878 6.76719 19.6122C6.94418 19.4352 7.0317 19.2201 7.07676 19.0098C7.12028 18.8066 7.12988 18.5801 7.12988 18.3499V8.5499C7.12988 8.31967 7.12028 8.09318 7.07676 7.89002C7.0317 7.67966 6.94418 7.46459 6.76719 7.2876C6.59155 7.11196 6.37232 7.01838 6.14595 6.96689C5.92398 6.9164 5.66637 6.8999 5.37988 6.8999H4.37988Z\"\r\n fill=\"#566563\" stroke=\"#566563\" />\r\n </svg>\r\n </i>\r\n </button>\r\n <button class=\"down copy\" title=\"Dislike\" [class.active]=\"chat?.unliked\" (click)=\"handleDownClick(i)\">\r\n <i *ngIf=\"chat?.unliked\">\r\n <svg width=\"18\" height=\"18\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M15.61 5.50002V15.66C15.61 16.06 15.49 16.45 15.27 16.78L12.54 20.84C12.11 21.49 11.04 21.95 10.13 21.61C9.15002 21.28 8.50002 20.18 8.71002 19.2L9.23002 15.93C9.27002 15.63 9.19002 15.36 9.02002 15.15C8.85002 14.96 8.60002 14.84 8.33002 14.84H4.22002C3.43002 14.84 2.75002 14.52 2.35002 13.96C1.97002 13.42 1.90002 12.72 2.15002 12.01L4.61002 4.52002C4.92002 3.28002 6.27002 2.27002 7.61002 2.27002H11.51C12.18 2.27002 13.12 2.50002 13.55 2.93002L14.83 3.92002C15.32 4.30002 15.61 4.88002 15.61 5.50002Z\"\r\n fill=\"#17235B\" />\r\n\r\n <path\r\n d=\"M18.7901 17.6099H19.8201C21.3701 17.6099 22.0001 17.0099 22.0001 15.5299V5.4799C22.0001 3.9999 21.3701 3.3999 19.8201 3.3999H18.7901C17.2401 3.3999 16.6101 3.9999 16.6101 5.4799V15.5399C16.6101 17.0099 17.2401 17.6099 18.7901 17.6099Z\"\r\n fill=\"#17235B\" />\r\n </svg>\r\n </i>\r\n\r\n <i *ngIf=\"!chat?.unliked\">\r\n <svg width=\"18\" height=\"18\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M10.1237 21.481L10.1148 21.4778L10.1059 21.4748C9.09577 21.1435 8.44416 20.0122 8.66849 18.9867L8.67175 18.9718L8.6741 18.9568L9.1641 15.8068L9.16413 15.8068L9.16501 15.8006C9.18175 15.6835 9.20207 15.3972 8.98633 15.1507L8.97536 15.1381L8.96359 15.1263C8.81687 14.9796 8.61841 14.8999 8.41004 14.8999H4.41004C3.56937 14.8999 2.88252 14.551 2.48884 13.992L2.4877 13.9904C2.10371 13.4497 2.00931 12.715 2.27994 11.9708L2.28263 11.9634L2.28509 11.9559L4.67509 4.67586L4.68035 4.65985L4.68451 4.64353C4.99418 3.42996 6.33271 2.3999 7.72004 2.3999H11.52C11.7591 2.3999 12.1599 2.43736 12.5704 2.54872C12.9878 2.66194 13.3596 2.83655 13.5965 3.07346L13.6191 3.09608L13.6444 3.11563L16.2785 5.14986L15.9705 5.54825L13.2875 3.47111C13.0799 3.2763 12.7837 3.1413 12.5061 3.05412C12.2031 2.95897 11.8551 2.8999 11.52 2.8999H7.72004C7.1429 2.8999 6.57353 3.12735 6.12508 3.45926C5.68428 3.78551 5.30892 4.25142 5.16963 4.79019L2.75738 12.1167C2.56223 12.659 2.57147 13.2409 2.90366 13.7012C3.24183 14.1761 3.81578 14.3999 4.42004 14.3999H8.42004C8.79702 14.3999 9.13867 14.5585 9.37252 14.8277L9.37315 14.8285C9.61286 15.1034 9.72457 15.4745 9.66568 15.875C9.6656 15.8755 9.66552 15.8761 9.66544 15.8766L9.16795 19.0704C9.00242 19.8841 9.53299 20.7428 10.2933 21.0013C10.6685 21.1391 11.0675 21.0978 11.3857 20.9917C11.7001 20.8869 12.0218 20.6898 12.2121 20.4132L12.2121 20.4132L12.215 20.4088L16.0351 14.7253L16.4472 15.0045L12.6251 20.691L12.6249 20.6912C12.259 21.2361 11.5347 21.5999 10.8 21.5999C10.5668 21.5999 10.3358 21.5596 10.1237 21.481Z\"\r\n fill=\"#566563\" stroke=\"#566563\" />\r\n <path\r\n d=\"M19.6201 17.6H18.6201C17.7647 17.6 17.2258 17.3983 16.8985 17.0826C16.5746 16.7703 16.3701 16.2615 16.3701 15.45V5.65C16.3701 4.83853 16.5746 4.32972 16.8985 4.0174C17.2258 3.7017 17.7647 3.5 18.6201 3.5H19.6201C20.4756 3.5 21.0144 3.7017 21.3418 4.0174C21.6656 4.32972 21.8701 4.83853 21.8701 5.65V15.45C21.8701 16.2615 21.6656 16.7703 21.3418 17.0826C21.0144 17.3983 20.4756 17.6 19.6201 17.6ZM18.6201 4C18.3336 4 18.076 4.01649 17.8541 4.06699C17.6277 4.11848 17.4085 4.21206 17.2328 4.3877C17.0558 4.56469 16.9683 4.77976 16.9232 4.99011C16.8797 5.19328 16.8701 5.41977 16.8701 5.65V15.45C16.8701 15.6802 16.8797 15.9067 16.9232 16.1099C16.9683 16.3202 17.0558 16.5353 17.2328 16.7123C17.4085 16.8879 17.6277 16.9815 17.8541 17.033C18.076 17.0835 18.3336 17.1 18.6201 17.1H19.6201C19.9066 17.1 20.1642 17.0835 20.3862 17.033C20.6126 16.9815 20.8318 16.8879 21.0074 16.7123C21.1844 16.5353 21.2719 16.3202 21.317 16.1099C21.3605 15.9067 21.3701 15.6802 21.3701 15.45V5.65C21.3701 5.41977 21.3605 5.19328 21.317 4.99011C21.2719 4.77976 21.1844 4.56469 21.0074 4.3877C20.8318 4.21206 20.6126 4.11848 20.3862 4.06699C20.1642 4.01649 19.9066 4 19.6201 4H18.6201Z\"\r\n fill=\"#566563\" stroke=\"#566563\" />\r\n </svg>\r\n </i>\r\n </button>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n\r\n <div class=\"cta-faqs quick-prompts-extended\" *ngIf=\"i == 0 && quickPrompts?.length\">\r\n <!-- <div *ngFor=\"let tile of quickPrompts\" class=\"cta\"\r\n (click)=\"sendMessageWithTile(tile.prompt)\">\r\n Q: {{ tile.text }}\r\n </div> -->\r\n <div class=\"cta_suggestions\">\r\n <button *ngFor=\"let tile of quickPrompts\" (click)=\"sendMessageWithTile(tile.prompt)\">\r\n <ng-container *ngIf=\"tile\">{{ tile.text }}</ng-container>\r\n </button>\r\n </div>\r\n </div>\r\n <div class=\"chat bot\" *ngIf=\"i == 0 && botSkills\">\r\n <div class=\"chat-box\">\r\n <div class=\"message\">\r\n <p [innerHTML]=\"processMessageForDisplay(botSkills)\"></p>\r\n &nbsp;\r\n </div>\r\n </div>\r\n </div>\r\n <div *ngIf=\"chat?.suggestions?.length\">\r\n <h4 class=\"labelChat\">\r\n Here are some things EventsGPT Copilot can help you do:\r\n </h4>\r\n <div class=\"cta_suggestions\">\r\n <button *ngFor=\"let suggestion of chat?.suggestions\" (click)=\"sendMessageWithTile(suggestion)\">\r\n <ng-container *ngIf=\"suggestion\">{{\r\n suggestion\r\n }}</ng-container>\r\n </button>\r\n </div>\r\n </div>\r\n <div *ngIf=\"\r\n chat?.action?.section_id == 'company_search' ||\r\n chat?.action?.section_id == 'user_search' ||\r\n chat?.action?.section_id == 'industry_company_search'\r\n \">\r\n <div class=\"box\">\r\n <div class=\"tiktokwrapper\">\r\n <div class=\"tiktokshell\" *ngFor=\"let user of chat?.action.users\">\r\n <div class=\"videoPhotobox\">\r\n <ng-conatiner *ngIf=\"user?.photoPath && !user.userVideosModel\">\r\n <img [src]=\"user?.photoPath\" />\r\n </ng-conatiner>\r\n <ng-conatiner *ngIf=\"user.userVideosModel\">\r\n <app-video-player *ngIf=\"user?.userVideosModel\" [isDev]=\"isDev\" [currentUserId]=\"userId\"\r\n [videoObj]=\"user?.userVideosModel\" [user]=\"user\" [eventId]=\"eventId\" type=\"1\">\r\n </app-video-player>\r\n </ng-conatiner>\r\n </div>\r\n\r\n <div class=\"noPhoto\" *ngIf=\"!user?.photoPath && !user.userVideosModel\">\r\n <h3>\r\n {{ user.firstName | slice: 0:1\r\n }}{{ user.lastName | slice: 0:1 }}\r\n </h3>\r\n </div>\r\n <div class=\"overlymask\" *ngIf=\"!user.userVideosModel\"></div>\r\n <div class=\"onshell-content\">\r\n <div class=\"title-shell\">\r\n <h3>{{ user.firstName }} {{ user.lastName }}</h3>\r\n <h3 class=\"companyName\">{{ user.company }}</h3>\r\n </div>\r\n <div class=\"button-shell\">\r\n <button class=\"Connectbtn\" (click)=\"connectToUser(user.userId)\">\r\n {{\r\n canConnect(user.userId)\r\n ? 'Connect'\r\n : canDisconnect(user.userId)\r\n ? 'Disconnect'\r\n : 'Request\r\n Sent'\r\n }}\r\n </button>\r\n <button class=\"schedulebtn\" (click)=\"scheduleMeetingWithUser(user)\">\r\n Schedule\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div *ngIf=\"chat?.action?.section_id == myUpcomingSessionAction\">\r\n <div class=\"agenda-items-wrapper\" class=\"agenda-items-wrapper\">\r\n <div class=\"list-view\">\r\n <div class=\"session-detail-wrapper card-background-session\"\r\n *ngFor=\"let upcomingSession of chat?.action.content\">\r\n <div class=\"thumbnail\">\r\n <img alt=\"Introduction to the Imaging Radar Academy\"\r\n src=\"https://s27media.azureedge.net/8008/profile_pic/453cea2c-feba-11ed-8c0b-00155d025b0a.png\"\r\n class=\"\" />\r\n <!---->\r\n <!---->\r\n <!----><button class=\"play-btn color-primary\"\r\n title=\"Play Session: Introduction to the Imaging Radar Academy\">\r\n <span class=\"material-icons notranslate\">\r\n play_circle_outline\r\n </span>\r\n <!---->\r\n </button>\r\n <!---->\r\n <!---->\r\n </div>\r\n <!---->\r\n <!---->\r\n <div class=\"content p-3\">\r\n <div class=\"d-flex justify-content-between align-items-center\">\r\n <div class=\"d-flex flex-column\">\r\n <p class=\"fs-xs mb-0 body-text-color\">\r\n {{\r\n upcomingSession.dateTimeRange.start\r\n | date\r\n : 'MM-dd-yyyy\r\n HH:mm'\r\n : 'UTC'\r\n }}\r\n -\r\n {{\r\n upcomingSession.dateTimeRange.end\r\n | date: 'MM-dd-yyyy HH:mm':'UTC'\r\n }}\r\n {{ upcomingSession.timeZone.id }}\r\n </p>\r\n <!---->\r\n <!---->\r\n <!-- <p class=\"fs-xs mb-2 color-secondary\" title=\"Session Type: Generative AI\">Generative AI </p> -->\r\n <!---->\r\n </div>\r\n <div class=\"d-flex align-items-center actions px-2\">\r\n <!---->\r\n <button (click)=\"\r\n performSessionAction(\r\n upcomingSession.id,\r\n 'view-session'\r\n )\r\n \" class=\"s27-btn-icon body-text-color\"\r\n title=\"View Session Information: Introduction to the Imaging Radar Academy\">\r\n <span class=\"material-icons notranslate\">\r\n remove_red_eye\r\n </span>\r\n </button>\r\n\r\n <button (click)=\"\r\n performSessionAction(\r\n upcomingSession.id,\r\n 'add-to-agenda'\r\n )\r\n \" class=\"s27-btn-icon body-text-color\">\r\n <span class=\"material-icons notranslate\"\r\n title=\"Add Session: Introduction to the Imaging Radar Academy to My agendaa\">\r\n event_available\r\n </span>\r\n </button>\r\n <!---->\r\n <!---->\r\n <!---->\r\n <!---->\r\n\r\n <button (click)=\"\r\n performSessionAction(upcomingSession.id, 'play')\r\n \" class=\"s27-btn-icon body-text-color\" title=\"Copy session link to share\">\r\n <span class=\"material-icons notranslate\">\r\n play_circle_outline\r\n </span>\r\n </button>\r\n <!---->\r\n </div>\r\n </div>\r\n <h2 class=\"body-text-color\">\r\n {{ upcomingSession.title }}\r\n </h2>\r\n <div class=\"session-description color-secondary\"\r\n [innerHTML]=\"sanitizeHtml(upcomingSession.description)\">\r\n </div>\r\n <ul class=\"speakers grid-2-cols\" *ngFor=\"let speakerId of upcomingSession.speakers\">\r\n <li class=\"\">\r\n <div class=\"image\" title=\"Blair Wunderlich\">\r\n <img alt=\"Blair Wunderlich\" [src]=\"speakers[speakerId]?.photoPath\" class=\"\" />\r\n <!---->\r\n <!---->\r\n <!---->\r\n </div>\r\n <!---->\r\n <div class=\"content pl-3\" style=\"text-transform: none\">\r\n <div class=\"mb-0 body-text-color fs-xs fw-500\">\r\n {{ speakers[speakerId]?.firstName }}\r\n {{ speakers[speakerId]?.lastName }}\r\n </div>\r\n <div class=\"color-secondary fs-xxs\">\r\n {{ speakers[speakerId]?.jobTitle }}\r\n </div>\r\n <div class=\"color-secondary fs-xxs\">\r\n {{ speakers[speakerId]?.company }}\r\n </div>\r\n </div>\r\n <!---->\r\n </li>\r\n </ul>\r\n <!---->\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"chat bot\" *ngIf=\"isChatingWithAi && !executingWorkflow\">\r\n <div class=\"chat-box\">\r\n <div class=\"message\">\r\n <div class=\"o-media__body\">\r\n <div class=\"o-vertical-spacing\">\r\n <h3 class=\"blog-post__headline\">\r\n <span class=\"skeleton-box\" style=\"width: 55%\"></span>\r\n </h3>\r\n <p>\r\n <span class=\"skeleton-box\" style=\"width: 80%\"></span>\r\n <span class=\"skeleton-box\" style=\"width: 90%\"></span>\r\n <span class=\"skeleton-box\" style=\"width: 83%\"></span>\r\n <span class=\"skeleton-box\" style=\"width: 80%\"></span>\r\n </p>\r\n </div>\r\n </div>\r\n\r\n <div class=\"time-cta\">\r\n <div class=\"Icon_TimeSTamp\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"44\" height=\"44\" viewBox=\"0 0 44 44\">\r\n <g id=\"Group_121\" data-name=\"Group 121\" transform=\"translate(4843 -371)\">\r\n <g id=\"Ellipse_18\" data-name=\"Ellipse 18\" transform=\"translate(-4843 371)\" fill=\"#fcfcfc\"\r\n stroke=\"#dfdfdf\" stroke-width=\"1\">\r\n <circle cx=\"22\" cy=\"22\" r=\"22\" stroke=\"none\" />\r\n <circle cx=\"22\" cy=\"22\" r=\"21.5\" fill=\"none\" />\r\n </g>\r\n <g id=\"Group_120\" data-name=\"Group 120\" transform=\"translate(-4835.141 378.855)\">\r\n <g id=\"Group_1\" data-name=\"Group 1\" transform=\"translate(7.29 0)\">\r\n <path id=\"Path_1\" data-name=\"Path 1\"\r\n d=\"M93.774,41.324,98.757,44.2v5.753l-4.983,2.877-4.983-2.877V44.2l4.983-2.877m0-2.034L87.03,43.183V50.97l6.744,3.893,6.744-3.893V43.183L93.774,39.29Z\"\r\n transform=\"translate(-87.03 -39.29)\" fill=\"gray\" />\r\n </g>\r\n <g id=\"Group_2\" data-name=\"Group 2\" transform=\"translate(0 12.717)\">\r\n <path id=\"Path_2\" data-name=\"Path 2\"\r\n d=\"M52.374,113.544l4.983,2.877v5.753l-4.983,2.877-4.983-2.877v-5.753l4.983-2.877m0-2.034L45.63,115.4v7.787l6.744,3.893,6.744-3.893V115.4l-6.744-3.893Z\"\r\n transform=\"translate(-45.63 -111.51)\" fill=\"gray\" />\r\n </g>\r\n <g id=\"Group_3\" data-name=\"Group 3\" transform=\"translate(14.793 12.717)\">\r\n <path id=\"Path_3\" data-name=\"Path 3\"\r\n d=\"M136.384,113.544l4.983,2.877v5.753l-4.983,2.877-4.983-2.877v-5.753l4.983-2.877m0-2.034L129.64,115.4v7.787l6.744,3.893,6.744-3.893V115.4l-6.744-3.893Z\"\r\n transform=\"translate(-129.64 -111.51)\" fill=\"gray\" />\r\n </g>\r\n </g>\r\n </g>\r\n </svg>\r\n <div class=\"dateTime\" [style.color]=\"dateTimeColor ? '' : ''\">\r\n <span> {{ 'Assistant' }}</span> {{ chat?.time\r\n ? chat?.time\r\n : (dateTime.now | date: 'shortTime')\r\n }}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"chat bot\" *ngIf=\"loading\">\r\n <div class=\"chat-box\">\r\n <div class=\"message\">\r\n <div class=\"o-media__body\">\r\n <div class=\"o-vertical-spacing\">\r\n <h3 class=\"blog-post__headline\">\r\n <span class=\"skeleton-box\" style=\"width: 55%\"></span>\r\n </h3>\r\n <p>\r\n <span class=\"skeleton-box\" style=\"width: 80%\"></span>\r\n <span class=\"skeleton-box\" style=\"width: 90%\"></span>\r\n <span class=\"skeleton-box\" style=\"width: 83%\"></span>\r\n <span class=\"skeleton-box\" style=\"width: 80%\"></span>\r\n </p>\r\n </div>\r\n </div>\r\n\r\n <div class=\"time-cta\">\r\n <div class=\"Icon_TimeSTamp\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"44\" height=\"44\" viewBox=\"0 0 44 44\">\r\n <g id=\"Group_121\" data-name=\"Group 121\" transform=\"translate(4843 -371)\">\r\n <g id=\"Ellipse_18\" data-name=\"Ellipse 18\" transform=\"translate(-4843 371)\" fill=\"#fcfcfc\"\r\n stroke=\"#dfdfdf\" stroke-width=\"1\">\r\n <circle cx=\"22\" cy=\"22\" r=\"22\" stroke=\"none\" />\r\n <circle cx=\"22\" cy=\"22\" r=\"21.5\" fill=\"none\" />\r\n </g>\r\n <g id=\"Group_120\" data-name=\"Group 120\" transform=\"translate(-4835.141 378.855)\">\r\n <g id=\"Group_1\" data-name=\"Group 1\" transform=\"translate(7.29 0)\">\r\n <path id=\"Path_1\" data-name=\"Path 1\"\r\n d=\"M93.774,41.324,98.757,44.2v5.753l-4.983,2.877-4.983-2.877V44.2l4.983-2.877m0-2.034L87.03,43.183V50.97l6.744,3.893,6.744-3.893V43.183L93.774,39.29Z\"\r\n transform=\"translate(-87.03 -39.29)\" fill=\"gray\" />\r\n </g>\r\n <g id=\"Group_2\" data-name=\"Group 2\" transform=\"translate(0 12.717)\">\r\n <path id=\"Path_2\" data-name=\"Path 2\"\r\n d=\"M52.374,113.544l4.983,2.877v5.753l-4.983,2.877-4.983-2.877v-5.753l4.983-2.877m0-2.034L45.63,115.4v7.787l6.744,3.893,6.744-3.893V115.4l-6.744-3.893Z\"\r\n transform=\"translate(-45.63 -111.51)\" fill=\"gray\" />\r\n </g>\r\n <g id=\"Group_3\" data-name=\"Group 3\" transform=\"translate(14.793 12.717)\">\r\n <path id=\"Path_3\" data-name=\"Path 3\"\r\n d=\"M136.384,113.544l4.983,2.877v5.753l-4.983,2.877-4.983-2.877v-5.753l4.983-2.877m0-2.034L129.64,115.4v7.787l6.744,3.893,6.744-3.893V115.4l-6.744-3.893Z\"\r\n transform=\"translate(-129.64 -111.51)\" fill=\"gray\" />\r\n </g>\r\n </g>\r\n </g>\r\n </svg>\r\n <div class=\"dateTime\" [style.color]=\"dateTimeColor ? '' : ''\">\r\n <span>{{ 'Loading ...' }}</span>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <!-- <div #chatMain></div> -->\r\n <div *ngIf=\"openWorkflowInput && selectedWorkflow && !executingWorkflow\" class=\"chatFooterWrapper\">\r\n <!-- new UI for Chat Message Section by Amit -->\r\n <div class=\"chat-footer-upt\">\r\n <div class=\"topinfo-containerbox\">\r\n <div class=\"agents_note_wrapper\">\r\n <div>\r\n <h6>{{selectedWorkflow?.Name}}</h6>\r\n {{selectedWorkflow?.Description}}\r\n </div>\r\n </div>\r\n\r\n <div class=\"agents_note_wrapper\">\r\n <button mat-icon-button class=\"closeButtonSource\" (click)=\"toggleWorkflows(false)\">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n </div>\r\n </div>\r\n <div class=\"bottombox-wrapper\">\r\n <!-- here i need to loop through all the input fields selectedWorkflow.Trigger.InputSchema and render the input fields -->\r\n <!-- Form for Workflow Inputs -->\r\n <form [formGroup]=\"workflowForm\" (ngSubmit)=\"onWorkflowSubmit()\" class=\"form-container\">\r\n <div *ngFor=\"let input of selectedWorkflow?.Trigger?.InputSchema\" class=\"form-group\">\r\n <label>{{ input.Label }}</label>\r\n\r\n <!-- Handle Text Input or Text Area based on requirement -->\r\n <textarea *ngIf=\"input.Type === 'string'\" formControlName=\"{{input.InputId}}\"\r\n [placeholder]=\"input.Placeholder\" [rows]=\"2\" [required]=\"input.Required\"\r\n class=\"form-control\"></textarea>\r\n\r\n <!-- Dropdown for Select Options -->\r\n <select *ngIf=\"input.Type === 'select'\" formControlName=\"{{input.InputId}}\" class=\"form-control\">\r\n <option *ngFor=\"let option of input.Options\" [value]=\"option.Value\">{{\r\n option.Label }}</option>\r\n </select>\r\n </div>\r\n\r\n <!-- Submit button aligned to the right -->\r\n <div class=\"form-group\">\r\n <button type=\"submit\" class=\"btn btn-primary submit-button\">Submit</button>\r\n </div>\r\n </form>\r\n </div>\r\n </div>\r\n\r\n\r\n <!-- new UI for Chat Message Section by Amit -->\r\n </div>\r\n <div *ngIf=\"!openWorkflowInput\" class=\"chatFooterWrapper\">\r\n <!-- new UI for Chat Message Section by Amit -->\r\n <div class=\"chat-footer-upt\">\r\n <div class=\"topinfo-containerbox\">\r\n <div class=\"agents_note_wrapper\">\r\n\r\n <div class=\"agents-dropdown-wrapper\">\r\n <div class=\"dropdown-wrapper\" (click)=\"toggleDropdown()\">\r\n <div class=\"dropdown-header\">\r\n <span>{{ getDropdownHeaderText() }}</span>\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" stroke=\"currentColor\"\r\n stroke-width=\"2\" viewBox=\"0 0 24 24\">\r\n <path d=\"M19 9l-7 7-7-7\" />\r\n </svg>\r\n </div>\r\n <div class=\"dropdown-menu\" *ngIf=\"isDropdownOpen\">\r\n <label (click)=\"onSelectAll()\">\r\n <input type=\"checkbox\" [checked]=\"areAllSelected()\" />\r\n All\r\n </label>\r\n <label *ngFor=\"let agent of agents\" (click)=\"onAgentChange(agent)\">\r\n <input type=\"checkbox\" [(ngModel)]=\"agent.selected\" />\r\n {{ agent.agentName }}\r\n </label>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n\r\n <div class=\"agents_note_wrapper\" *ngIf=\"!checkForCop29BotId()\">\r\n\r\n <div class=\"agents-dropdown-wrapper\">\r\n <div class=\"dropdown-wrapper\" (click)=\"toggleWorkflows()\">\r\n <div class=\"dropdown-header\">\r\n <svg stroke=\"currentColor\" fill=\"currentColor\" stroke-width=\"0\" viewBox=\"0 0 256 256\"\r\n class=\"h-5 w-5\" height=\"1.3em\" width=\"1.3em\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M245.66,74.34l-32-32a8,8,0,0,0-11.32,11.32L220.69,72H192a74.49,74.49,0,0,0-28.35,6.73c-13.62,6.29-30.83,19.71-35.54,48-5.32,31.94-29.1,39.22-41,40.86a40,40,0,1,0,.18,16.06A71.65,71.65,0,0,0,108.13,178C121.75,172,139,158.6,143.89,129.31,150.65,88.77,190.34,88,192,88h28.69l-18.35,18.34a8,8,0,0,0,11.32,11.32l32-32A8,8,0,0,0,245.66,74.34ZM48,200a24,24,0,1,1,24-24A24,24,0,0,1,48,200Z\">\r\n </path>\r\n </svg>&nbsp;\r\n Workflows\r\n </div>\r\n <div class=\"dropdown-menu\" *ngIf=\"isWorkflowOpen\">\r\n <label *ngFor=\"let orgWorkflow of orgWorkflows\" (click)=\"onWorkflowSelected(orgWorkflow)\">\r\n {{ orgWorkflow.Name }}\r\n </label>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n\r\n </div>\r\n <div class=\"bottombox-wrapper\">\r\n <!-- <input [disabled]=\"isChatingWithAi\" type=\"text\" class=\"form-control-1 s27-scroll\"\r\n \r\n placeholder=\"Ask anything...\" [style.background]=\"formFieldBgColor ? formFieldBgColor : ''\"\r\n [style.color]=\"formFieldTextColor ? formFieldTextColor : ''\" [(ngModel)]=\"input\"\r\n (keyup.enter)=\"handleSubmit()\" #myInput /> -->\r\n <textarea [disabled]=\"isChatingWithAi\" class=\"form-control-1 s27-scroll chat-textarea\"\r\n placeholder=\"Ask anything...\" [(ngModel)]=\"input\" (keydown)=\"handleKeydown($event)\"\r\n (input)=\"adjustTextareaHeight($event)\" #myInput></textarea>\r\n\r\n <button (click)=\"toggleRecording()\" class=\"btn cta-chat mr-1\">\r\n <svg *ngIf=\"!isRecording\" stroke=\"currentColor\" fill=\"currentColor\" stroke-width=\"0\" viewBox=\"0 0 512 512\"\r\n height=\"1em\" width=\"1em\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <!-- Mic Icon -->\r\n <path\r\n d=\"M256 320c53 0 96-43 96-96V96c0-53-43-96-96-96s-96 43-96 96v128c0 53 43 96 96 96zm144-96h-16c0 66.27-52.73 120-120 120s-120-53.73-120-120h-16c-17.67 0-32 14.33-32 32v32c0 53.87 38.13 100.64 91.21 112.27C210.13 457.77 231.58 464 256 464s45.87-6.23 65.79-17.73C374.87 388.64 416 341.87 416 288v-32c0-17.67-14.33-32-32-32z\">\r\n </path>\r\n </svg>\r\n <svg *ngIf=\"isRecording\" stroke=\"currentColor\" fill=\"currentColor\" stroke-width=\"0\" viewBox=\"0 0 24 24\"\r\n height=\"1em\" width=\"1em\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <!-- Square Stop Icon -->\r\n <path d=\"M5 5h14v14H5z\"></path>\r\n </svg>\r\n </button>\r\n\r\n\r\n <button class=\"btn cta-chat rotate\" (click)=\"handleSubmit()\"\r\n [style.background]=\"sendButtonColor ? sendButtonColor : ''\"\r\n [style.color]=\"sendButtonTextColor ? sendButtonTextColor : ''\">\r\n <svg stroke=\"currentColor\" fill=\"currentColor\" stroke-width=\"0\" viewBox=\"0 0 512 512\" height=\"1em\"\r\n width=\"1em\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M476.59 227.05l-.16-.07L49.35 49.84A23.56 23.56 0 0027.14 52 24.65 24.65 0 0016 72.59v113.29a24 24 0 0019.52 23.57l232.93 43.07a4 4 0 010 7.86L35.53 303.45A24 24 0 0016 327v113.31A23.57 23.57 0 0026.59 460a23.94 23.94 0 0013.22 4 24.55 24.55 0 009.52-1.93L476.4 285.94l.19-.09a32 32 0 000-58.8z\">\r\n </path>\r\n </svg>\r\n <!-- SEND -->\r\n </button>\r\n </div>\r\n </div>\r\n\r\n\r\n <!-- new UI for Chat Message Section by Amit -->\r\n </div>\r\n\r\n <div class=\"NoteTxt\">\r\n <div class=\"note\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12.882\" height=\"12.883\" viewBox=\"0 0 12.882 12.883\">\r\n <path id=\"Icon_ion-shield-checkmark\" data-name=\"Icon ion-shield-checkmark\"\r\n d=\"M15.106,4.532a.46.46,0,0,0-.378-.424A20.132,20.132,0,0,1,8.881,2.291a.46.46,0,0,0-.379,0A20.132,20.132,0,0,1,2.655,4.108a.46.46,0,0,0-.378.424A11.3,11.3,0,0,0,2.98,9.4a10.049,10.049,0,0,0,2.06,3.235A10.516,10.516,0,0,0,8.521,15.1a.46.46,0,0,0,.345,0,10.516,10.516,0,0,0,3.481-2.465A10.049,10.049,0,0,0,14.4,9.4,11.3,11.3,0,0,0,15.106,4.532Zm-3.767,2.16L8.153,10.373a.46.46,0,0,1-.328.159H7.806a.46.46,0,0,1-.322-.131L6.069,9.014a.46.46,0,1,1,.644-.657L7.777,9.4,10.644,6.09a.46.46,0,0,1,.7.6Z\"\r\n transform=\"translate(-2.25 -2.25)\" fill=\"#06f\" />\r\n </svg>\r\n\r\n\r\n <span class=\"text\">Your personal or company information is kept\r\n private and secure\r\n within this chat.</span>\r\n </div>\r\n </div>\r\n </mat-drawer-content>\r\n </mat-drawer>\r\n <mat-drawer class=\"drawer edit-boxDrawer\" style=\"width: 45%\" #sourcesDrawer [position]=\"'end'\" [mode]=\"'over'\"\r\n [style.background]=\"\r\n 'linear-gradient(' + (bgGradient ? bgGradient.join(', ') : '') + ')'\r\n \">\r\n <mat-drawer-content>\r\n <div class=\"sourceDraweContainer\">\r\n <div class=\"container-fluid\">\r\n <button mat-icon-button class=\"closeButtonSource\" (click)=\"onCloseSource()\">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n <h1>{{ currentSourcesList?.length }} Sources</h1>\r\n <!-- <p>Tell me about latest news from Mistral about AI agents announcement done this month</p> -->\r\n <hr />\r\n <ul class=\"sources-list\">\r\n <li *ngFor=\"let item of currentSourcesList; let si = index\">\r\n <!-- <input type=\"checkbox\" id=\"source1\"> -->\r\n <div class=\"source-content\" (click)=\"openLinkInNewTab(item.link)\">\r\n <label for=\"source1\">\r\n <span class=\"source-title\"><span class=\"ml-1\">{{ si + 1\r\n }}.</span>{{ item.title }}</span>\r\n <span class=\"image-container\">\r\n <img class=\"relative block\" [src]=\"getFaviconUrl(item.link)\"\r\n [alt]=\"getDomainName(item.link) + ' favicon'\" />\r\n <span> {{ getDomainName(item.link) }}</span>\r\n </span>\r\n <span class=\"source-description\">{{ item.desc }}</span>\r\n </label>\r\n </div>\r\n </li>\r\n </ul>\r\n </div>\r\n </div>\r\n </mat-drawer-content>\r\n </mat-drawer>\r\n <mat-drawer class=\"drawer edit-boxDrawer\" style=\"width: 45%\" #editorsDrawer [position]=\"'end'\" [mode]=\"'push'\"\r\n [style.background]=\"\r\n 'linear-gradient(' + (bgGradient ? bgGradient.join(', ') : '') + ')'\r\n \">\r\n <mat-drawer-content>\r\n <lib-bot-html-editor *ngIf=\"isContentLoaded\" [editorContent]=\"currentMessageForEditor\"\r\n [isDocInEditMode]=\"isDocInEditMode\" [documentContent]=\"documentContent\" [conversationId]=\"conversationId\"\r\n [botId]=\"botId\"></lib-bot-html-editor>\r\n </mat-drawer-content>\r\n </mat-drawer>\r\n</mat-drawer-container>\r\n\r\n\r\n<div *ngIf=\"showWorkflowExecutionDetails\" class=\"modal\">\r\n <div class=\"modal-content\">\r\n <div class=\"close-wrapper\"><span class=\"close_pop\" (click)=\"closeModal()\">&times;</span></div>\r\n <div class=\"titleSection\">\r\n <!-- Workflow Title -->\r\n <h2>{{ workflowExecutionDetails.WorkflowName }}</h2>\r\n <!-- Workflow Title -->\r\n </div>\r\n <!-- Inputs Section -->\r\n <div class=\"inputs-section\">\r\n <h3>Inputs</h3>\r\n <ul>\r\n <li *ngFor=\"let input of objectToArray(workflowExecutionDetails.Inputs)\">\r\n {{ input.key }}: {{ input.value }}\r\n </li>\r\n </ul>\r\n </div>\r\n\r\n <!-- Actions Section (Displayed as Timeline) -->\r\n <div class=\"actions-section\">\r\n <h3>Agent Actions</h3>\r\n <div class=\"timeline\">\r\n <div *ngFor=\"let action of workflowExecutionDetails.Actions\" class=\"timeline-item\">\r\n <div class=\"timestamp-section\">\r\n <h4>{{ action.ActionName || action.Name }}</h4>\r\n <p><strong></strong> {{\r\n action.InsertTimeStamp }}</p>\r\n </div>\r\n <p [innerHTML]=\"processMessageForDisplay(action.Output)\"></p>\r\n <!-- <pre>{{ action.Output }}</pre> -->\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Insert Timestamp -->\r\n <div class=\"timestamp-section\">\r\n <p><strong>Inserted At:</strong> {{\r\n workflowExecutionDetails.InsertTimeStamp }}</p>\r\n </div>\r\n </div>\r\n</div>",
1537
- changeDetection: ChangeDetectionStrategy.OnPush,
1538
- styles: ["@import url(\"https://e1cdn.social27.com/digitalevents/liteversion/fonts/segoe-ui/stylesheet.css\");.sticky-header-chat{background:#fff;border-bottom:1px solid #ddd;padding:0 0 10px;position:sticky;top:-21px;transition:all 1s;z-index:100}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb,::-webkit-scrollbar-thumb:hover{background:#e5ccbc}body{overflow:hidden}.ios-device .drawer .chat-footer .form-control{font-size:16px}.hivegpt-chat-wrapper{background:transparent!important;height:100%;inset:0;opacity:0;position:fixed;visibility:hidden;z-index:999999}.hivegpt-chat-wrapper.mat-drawer-container-has-open{background:transparent!important;opacity:1;transition:all .3s;visibility:visible;z-index:999999}.hivegpt-chat-wrapper .mat-drawer:not(.mat-drawer-side){box-shadow:none}.hivegpt-chat-wrapper mat-drawer{background-color:#fff!important;background-image:none!important;width:100%}.hivegpt-chat-wrapper mat-drawer.full-width-drawer{max-width:100%}.hivegpt-chat-wrapper .mat-drawer-content{display:flex;flex-direction:column}.hivegpt-chat-wrapper .chat-header{padding:16px 40px;width:100%}.hivegpt-chat-wrapper .chat-header h2{font-family:Segoe UI,sans-serif;font-size:36px;font-weight:500;letter-spacing:-.72px;line-height:108%;margin:0;text-transform:uppercase}.hivegpt-chat-wrapper .chat-header .closeIcon{align-items:center;background:transparent;border:none;border-radius:50%;display:inline-flex;font-size:18px;height:35px;justify-content:center;outline:none;padding:0;position:absolute;right:12px;top:16px;width:35px}.hivegpt-chat-wrapper .chat-main{display:flex;flex:1;flex-direction:column;justify-content:space-between;overflow-y:auto;width:100%}.hivegpt-chat-wrapper .chat-main .innerChat{overflow-y:auto;padding:20px 40px 10px;width:100%}.hivegpt-chat-wrapper .chat-main .chat-box{max-width:80%;width:100%}.hivegpt-chat-wrapper .chat-main .chat-box .message{margin-left:70px;margin-top:20px;min-height:60px;padding:0 20px 0 0;position:relative}.hivegpt-chat-wrapper .chat-main .chat-box .message p{color:#000;font-family:Segoe UI,sans-serif;font-size:16px;font-style:normal;font-weight:500;line-height:160%;margin:0;text-align:left;white-space:pre-line}.hivegpt-chat-wrapper .chat-main .chat-box .message p a{color:#17235b!important;cursor:pointer!important;font-weight:700;text-decoration:underline}.hivegpt-chat-wrapper .chat-main .chat-box .message .cta{align-items:end;bottom:-7px;display:inline-flex;gap:10px;grid-gap:10px;position:relative;right:-10px;z-index:5}.hivegpt-chat-wrapper .chat-main .chat-box .message .cta button{background:transparent;border:none;color:#566563;cursor:pointer;padding:0;transition:all .3s}.hivegpt-chat-wrapper .chat-main .chat-box .message .cta button i{display:inline-block}.hivegpt-chat-wrapper .chat-main .chat-box .message .cta button:hover{color:#17235b}.hivegpt-chat-wrapper .chat-main .chat-box .message .cta button.up:hover i{animation:thumbsUpAnimation .5s ease-in-out;animation-fill-mode:forwards}.hivegpt-chat-wrapper .chat-main .chat-box .message .cta button.down:hover i{animation:thumbsDownAnimation .5s ease-in-out;animation-fill-mode:forwards}.hivegpt-chat-wrapper .chat-main .chat{margin-bottom:20px}.hivegpt-chat-wrapper .chat-main .chat.user{text-align:right}.hivegpt-chat-wrapper .chat-main .chat.user .chat-box{margin-left:auto}.hivegpt-chat-wrapper .chat-main .chat.user .chat-box .message{background:linear-gradient(96deg,#8b4ead -10.61%,#761c79 84.59%);border-radius:20px 20px 0 20px;color:#fff}.hivegpt-chat-wrapper .chat-main .chat.user .chat-box .message p{color:#fff;text-align:left}.hivegpt-chat-wrapper .chat-main .chat.user .dateTime{text-align:right}.hivegpt-chat-wrapper .chat-main .chat.user .time-cta{justify-content:flex-end}.hivegpt-chat-wrapper .chat-main .chat .Icon_TimeSTamp{align-content:center;align-items:center;display:flex;justify-content:left;margin:0 -60px;width:auto}.hivegpt-chat-wrapper .chat-main .chat .dateTime{color:#333232;font-size:15px;font-style:normal;font-weight:300;line-height:140%}.hivegpt-chat-wrapper .chat-main .chat .dateTime span{color:#06f;font-size:15px;font-style:normal;font-weight:500;line-height:140%;margin-left:15px;margin-right:5px}.hivegpt-chat-wrapper .chat-main .chat:last-of-type{margin-bottom:0}.hivegpt-chat-wrapper .chatFooterWrapper{background:#fff;border:2px solid hsla(0,0%,85.5%,.5882352941176471);border-radius:10px;box-shadow:2px 0 5px #e1e1e1;margin:0 auto 15px;margin-top:10px!important;transition:all .5s;width:75%}.hivegpt-chat-wrapper .chatFooterWrapper:hover{border:2px solid hsla(0,0%,72.2%,.5882352941176471);box-shadow:2px 0 4px #ddd}.hivegpt-chat-wrapper .chatFooterWrapper .chat-footer-upt{padding:4px}.hivegpt-chat-wrapper .chatFooterWrapper .note{align-items:center;background:rgba(27,117,187,.050980392156862744);border-radius:15px;color:#000;display:inline-flex;font-size:12px;gap:8px;line-height:1;margin:0 auto 4px;padding:10px 25px}.hivegpt-chat-wrapper .chatFooterWrapper .note a{text-transform:capitalize}.hivegpt-chat-wrapper .chatFooterWrapper .note i{font-size:18px}.hivegpt-chat-wrapper .chatFooterWrapper .note i svg{height:18px;width:18px}.hivegpt-chat-wrapper .chatFooterWrapper .note span{flex:1;gap:4px;line-height:1.3}.hivegpt-chat-wrapper .chat-footer{align-items:center;display:flex;gap:8px;justify-content:space-between;padding:0;position:relative}.hivegpt-chat-wrapper .chat-footer .form-control{background:#fff!important;border:0;line-height:21px;outline:0;padding:10px;position:relative;width:100%}.hivegpt-chat-wrapper .chat-footer .form-control::-moz-placeholder{color:#6c7a78}.hivegpt-chat-wrapper .chat-footer .form-control::placeholder{color:#6c7a78}.hivegpt-chat-wrapper .chat-footer .form-control:focus{border-color:#e5ccbc}.hivegpt-chat-wrapper .chat-footer .cta-footer{align-items:center;display:flex;gap:8px;justify-content:space-between;margin-bottom:10px;position:absolute;right:15px;text-align:right}.hivegpt-chat-wrapper .chat-footer .cta-footer .btn{color:#000;font-weight:500;gap:8px;max-width:150px;padding:0}.hivegpt-chat-wrapper .chat-footer .cta-footer .cta-chat{align-items:center;background:transparent!important;border:none;border-radius:0;box-shadow:0 1px 2px 0 rgba(16,24,40,.05);display:inline-flex;font-size:20px;height:auto;justify-content:center;width:auto}.hivegpt-chat-wrapper .chat-footer .cta-footer .cta-chat:hover{opacity:.8}.hivegpt-chat-wrapper .chat-footer .cta-footer .cta-again{background:#17235b;border:1px solid #17235b;color:#fff}.hivegpt-chat-wrapper .cta-faqs{align-items:flex-end;display:flex;flex-direction:column;flex-wrap:wrap;gap:8px;margin-left:auto;max-width:80%;padding:10px 0 0}.hivegpt-chat-wrapper .cta-faqs .cta{background:transparent;border:1px solid #c9a893;border-radius:20px 20px 0 20px;color:#333;cursor:pointer;font-family:Segoe UI,sans-serif;font-size:14px;font-style:normal;font-weight:500;line-height:160%;margin:0;min-height:44px;padding:12px 20px;text-align:left;text-decoration:none;transition:all .3s;white-space:pre-line}.spinner{align-items:center;display:flex;gap:2px;justify-content:center}.spinner>div{animation:bouncedelay 1.4s ease-in-out infinite;animation-fill-mode:both;background-color:#173330;border-radius:100%;display:inline-block;height:5px;width:5px}.spinner .bounce1{animation-delay:-.32s}.spinner .bounce2{animation-delay:-.16s}@keyframes bouncedelay{0%,80%,to{-webkit-transform:scale(0);transform:scale(0)}40%{-webkit-transform:scale(1);transform:scale(1)}}.time-cta{align-items:center;display:flex;gap:8px;justify-content:start;margin-top:5px}@keyframes thumbsUpAnimation{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes thumbsDownAnimation{0%,to{transform:translateY(0)}50%{transform:translateY(3px)}}@media (max-width:767px){.hivegpt-chat-wrapper .chat-main .innerChat{padding:0 24px 10px}.hivegpt-chat-wrapper .chat-footer{padding:10px 24px}.hivegpt-chat-wrapper .chat-footer .cta-footer .cta-chat{max-width:100%}.hivegpt-chat-wrapper .chat-footer .form-control{height:80px}.hivegpt-chat-wrapper .chat-header .closeIcon{height:28px;right:8px;top:8px;width:28px}.hivegpt-chat-wrapper .chat-header .closeIcon span{font-size:14px}.hivegpt-chat-wrapper .chat-header{padding:10px 24px}.hivegpt-chat-wrapper .chat-header h2{font-size:20px}.cta-faqs{padding:10px 0 0}}.body-overflow-hidden{overflow:hidden}.chat-button{align-items:center;background:#17235b;border:#17235b;border-radius:50%;color:#fff;display:inline-flex;font-size:24px;height:50px;justify-content:center;width:50px}textarea{caret-color:#000}.labelChat{font-size:14px;font-weight:400;margin:0 0 10px}.chatType h4{color:#566563;text-align:center}.chatType ul{align-items:center;background:#fff;border-radius:10px;box-shadow:0 .3px .9px rgba(0,0,0,.12),0 1.6px 3.6px rgba(0,0,0,.16);display:flex;justify-content:center;list-style:none;margin:0 0 20px;padding:4px}.chatType ul li{flex:1}.chatType ul li button{align-items:center;background:#fff;border:none;border-radius:10px;font-weight:600;min-height:48px;padding:.375rem;text-align:center;text-shadow:1px 0 rgba(0,0,0,.2);width:100%}.chatType ul li button.active{background:linear-gradient(96deg,#761c79 -10.61%,#761c79 84.59%);box-shadow:0 1px 2px 0 rgba(16,24,40,.05);color:#fff}.cta_suggestions{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:20px}.cta_suggestions button{background:#fff;border:1px solid #174ae4;border-radius:10px;box-shadow:0 1.6px 3.6px 0 rgba(0,0,0,.13),0 .3px .9px 0 rgba(0,0,0,.1);color:#1543cd;font-size:14px;font-weight:600;line-height:1.2;padding:8px 12px;position:relative;text-align:left;transition:all .3s}.cta_suggestions button:hover{background:#eff3ff}.balanced .chat-footer .cta-footer .cta-chat,.balanced .chat-main .chat.user .chat-box .message,.balanced .chatType ul li button.active{color:#000}.balanced .chat-main .innerChat .title p span{color:#06f}.balanced mat-drawer{background-image:linear-gradient(180deg,rgba(88,190,251,.05) 60%,rgba(0,102,255,.2) 96.27%)}.balanced .cta_suggestions button:hover{border:1px solid #06f}.precise .chat-footer .cta-footer .cta-chat,.precise .chat-main .chat.user .chat-box .message{background:linear-gradient(96deg,#69ca6d -10.61%,#4caf50 84.59%)}.precise .chatType ul li button.active{background:linear-gradient(96deg,#4caf50 -10.61%,#4caf50 84.59%);color:#fff}.precise .chat-main .innerChat .title p span{color:#4caf50}.precise mat-drawer{background-image:linear-gradient(180deg,rgba(76,175,80,.05) 60%,rgba(76,175,80,.3) 96.27%)}.precise .cta_suggestions button:hover{border:1px solid #4caf50}.title{margin-bottom:20px}.title h2{font-size:22px;margin:0}.title h2 span{align-items:center;color:#000;display:inline-flex;gap:10px}.title h2 i{color:#06f;font-size:30px;line-height:1}.title h2 i svg{height:30px;width:30px}.title p{font-weight:600;margin:0}.title p span{color:#06f}.agenda-items-wrapper{padding-bottom:15px;padding-top:15px}@media (max-width:576px){.list-view .session-detail-wrapper{border:none;flex-direction:column}}.card-background-session{background:#fff;border-radius:8px}.card-background-session .body-text-color{color:#111!important}.card-background-session h2{-webkit-box-orient:vertical;-webkit-line-clamp:1;display:-webkit-box;font-size:20px;margin-bottom:8px;overflow:hidden}.card-background-session .session-description{-webkit-box-orient:vertical;-webkit-line-clamp:2;color:#111!important;display:-webkit-box;font-size:14px;overflow:hidden}.card-background-session .color-secondary{color:#111!important}.card-background-session p{font-size:14px}.list-view .session-detail-wrapper .s27-btn-icon{background:transparent;border:transparent}.list-view .session-detail-wrapper{border-left:3px solid transparent;display:flex;margin-bottom:16px}.thumbnail{align-items:center;display:flex;height:160px;justify-content:center;min-width:160px;position:relative;width:160px}.thumbnail img{-o-object-fit:cover;height:100%;object-fit:cover;width:100%}@media (max-width:576px){.thumbnail{height:160px;min-height:unset;width:100%}}.thumbnail .play-btn{align-items:center;background-color:transparent;border:0;bottom:0;display:flex;font-size:60px;justify-content:center;left:0;position:absolute;right:0;top:0;width:100%}.thumbnail .play-btn span{font-size:80px;text-shadow:0 0 14px rgba(74,74,74,.45)}.content{flex-grow:1}.actions{background-color:transparent!important}.speakers{margin-bottom:0;margin-top:10px;padding:0}.speakers li{align-items:unset;display:flex}.speakers li .content{font-size:12px!important}.speakers .image{border-radius:100%;height:40px;min-width:40px;overflow:hidden;width:40px}.speakers img{-o-object-fit:cover;height:100%;object-fit:cover;width:100%}.grid-2-cols{display:grid;grid-gap:15px;grid-template-columns:calc(55% - 10px) calc(50% - 10px);padding-right:20px}@media (max-width:768px){.grid-2-cols{grid-template-columns:calc(50% - 10px) calc(50% - 10px)}}@media (max-width:575px){.grid-3-cols{grid-template-columns:100%}}.quick-prompts-extended{align-items:flex-start!important;margin-left:0!important}.border-shape .s27-scroll::-webkit-scrollbar{border-radius:30px;width:3px}.border-shape .s27-scroll::-webkit-scrollbar-track{background:#f1f1f1;border-radius:30px}.border-shape .s27-scroll::-webkit-scrollbar-thumb{background:#888;border-radius:30px}.box{display:table;height:275px;margin:10px 0;width:100%}.tiktokwrapper{display:grid;gap:10px;grid-template-columns:repeat(2,1fr);height:100%}.tiktokwrapper .tiktokshell{background:#3d2b8f;border:2px solid #fff;border-radius:5px;box-shadow:0 0 6px #494949;height:100%;min-height:275px;min-width:160px;position:relative;width:100%}.tiktokwrapper .overlymask{background-image:url(https://e1cdn.social27.com/digitalevents/HiveGpt/screen-overlay.png);background-position:0 0;bottom:0;height:100%;left:0;position:absolute;width:100%;z-index:6}.tiktokwrapper .videoPhotobox{bottom:0;height:272px;left:0;overflow:hidden;position:absolute;width:auto;z-index:6}.tiktokwrapper .videoPhotobox video{-o-object-fit:cover;border-radius:0;cursor:pointer;height:270px;object-fit:cover;outline:0;transition:.3s ease-in-out;width:100%}.tiktokwrapper .videoPhotobox img{-o-object-fit:cover;height:100%;object-fit:cover;width:100%}.tiktokwrapper .playBtn{align-items:center;border:none;cursor:pointer;display:flex;height:40px;justify-content:center;left:0;margin:0 auto;position:absolute;right:0;top:105px;transition:all 1s;width:40px;z-index:10}.tiktokwrapper .playBtn:hover{transform:scale(1.2)}.tiktokwrapper .noPhoto{align-items:center;border:none;cursor:pointer;display:flex;height:40px;justify-content:center;left:0;margin:0 auto;position:absolute;right:0;top:105px;transition:all 1s;z-index:6}.tiktokwrapper .noPhoto h3{color:#fff;font-size:46px}.tiktokwrapper .onshell-content{bottom:10px;left:5px;position:absolute;z-index:10}.tiktokwrapper .onshell-content .title-shell{margin:0 10px}.tiktokwrapper .onshell-content h3{color:#fff;font-size:13px;font-weight:500}.tiktokwrapper .onshell-content .companyName{color:#eaeaea;font-size:12px;font-weight:400}.tiktokwrapper .onshell-content .button-shell button{background:#4e4e4e;border:none;border-radius:2px;color:#fff;font-size:11px;margin:0 1px;padding:4px 7px;text-transform:capitalize}.tiktokwrapper .onshell-content .Connectbtn{background:linear-gradient(149deg,#06f,#06f)!important}.skeleton-box{background-color:#dddbdd;display:inline-block;height:1em;overflow:hidden;position:relative}.skeleton-box:after{animation:shimmer 2s infinite;background-image:linear-gradient(90deg,hsla(0,0%,100%,0),hsla(0,0%,100%,.2) 20%,hsla(0,0%,100%,.5) 60%,hsla(0,0%,100%,0));bottom:0;content:\"\";left:0;position:absolute;right:0;top:0;transform:translateX(-100%);z-index:0}@keyframes shimmer{to{transform:translateX(100%)}}.blog-post__headline{font-size:1.25em;font-weight:700}.blog-post__meta{color:#6b6b6b;font-size:.85em}.o-media{display:flex}.o-media__body{flex-grow:1;margin-left:1em}.o-vertical-spacing>*+*{margin-top:.75em}.o-vertical-spacing--l>*+*{margin-top:2em}.copy{background:none;border:none;cursor:pointer;padding:5px;transition:transform .2s ease}.copy.active{transform:scale(1.1)}.copy svg{fill:#566563;height:18px;width:18px}.copyBox{background:#f7f7f7;border-radius:13px;color:#566563;display:flex;float:right;gap:12px;padding:5px 10px;position:relative;width:135px}.copyBox button{background:transparent;border:none;color:#566563;cursor:pointer;padding:0;transition:all .3s}.copyBox button i{display:inline-block}.copyBox button:hover{color:#17235b}.copyBox button.up:hover i{animation:thumbsUpAnimation .5s ease-in-out;animation-fill-mode:forwards}.copyBox button.down:hover i{animation:thumbsDownAnimation .5s ease-in-out;animation-fill-mode:forwards}.din{display:inline-flex}.chatFooterWrapper{align-items:center;background-color:#f5f5f5;border-top:1px solid #ccc;flex-direction:column;justify-content:center}.chat-footer{background:#fff;flex-direction:column;margin-bottom:10px}.chat-footer,.topinfo-containerbox{align-items:center;display:flex;width:100%}.topinfo-containerbox{background:#f9f9f9;border-bottom:1px solid #efefef;justify-content:space-between;margin:0;padding:5px 10px 8px}.agents_note_wrapper{display:flex;justify-content:space-around}.bottombox-wrapper{display:flex;padding:10px;width:100%}.dropdown-wrapper{margin-right:10px;position:relative}.dropdown-header{align-items:center;background:#fff;border:1px solid #ddd;border-radius:48px;color:#414141!important;cursor:pointer;display:flex;font-size:14px;margin-bottom:0;padding:.5rem 1.5rem;white-space:nowrap}.dropdown-header span{margin-right:8px}.dropdown-menu{background-color:#fff;border:1px solid #ededed;border-radius:5px;bottom:100%!important;box-shadow:0 2px 4px rgba(0,0,0,.1);display:block;left:0;margin-bottom:10px;max-height:200px;overflow-y:auto;padding:0;position:absolute;top:auto;width:230px;z-index:1000}.dropdown-menu label{cursor:pointer;display:block;font-size:16px;padding:5px 15px}.dropdown-menu label input{height:16px;width:16px}.dropdown-menu label:hover{background-color:#f0f0f0}.border-shape{flex-grow:1}.form-control-1{border:1px solid #ddd;border-radius:5px;padding:10px;width:100%}.cta-footer,.text-left .note-section{align-items:center;display:flex}.text-left .note-section{background:#fff;border-radius:5px;box-shadow:0 2px 4px rgba(0,0,0,.1);margin-top:10px;max-width:800px;padding:10px;width:100%}.text-left .note{align-items:center;color:#555;display:flex}.text-left .note i{margin-right:8px}.text-left .note .text{font-size:14px}.card-container{display:flex;gap:15px}.custom-card{background:#fffefe;border:1px solid #ddd;border-radius:.25rem;box-shadow:0 4px 8px rgba(0,0,0,.1);margin-bottom:10px;overflow:hidden;width:18rem}.custom-card .card-body{padding:10px}.custom-card .card-title{font-size:1.25rem;font-weight:700}.custom-card .card-text{font-size:1rem;text-align:left}.custom-card .btn-primary{background-color:#007bff;border:none;border-radius:.25rem}.custom-card .card-footer{background-color:#f8f9fa;color:#6c757d;padding:10px;text-align:center}.list-container{list-style:none;padding:0}.list-container li{background:#f5f5f5;border-radius:8px;font-size:13px;margin-bottom:5px;padding:6px 12px}.list-container li:hover{color:#06f;cursor:pointer}.collapsible-container{margin-bottom:5px;overflow:hidden;width:100%}.collapsible-header{cursor:pointer;display:flex;padding:15px}.collapsible-header .header-icon{font-size:20px;margin-right:10px}.collapsible-header .header-title{flex:1;font-size:18px}.collapsible-header .toggle-icon{font-size:18px;margin-left:18px}.collapsible-content{background-color:#f8f9fa;color:#333;padding:15px;width:100%}.collapsible-content.show{display:block}.researchingCard{margin:0 auto}.card-header{background:#eee;border-bottom:0;border-radius:8px 8px 0 0;display:flex!important;padding:8px 15px;width:auto}.icon{font-size:20px;line-height:5px}.rotate{transform:rotate(180deg)}.collapse{display:none}.uptList{background:rgba(245,222,179,.1411764705882353);border-radius:0 0 10px 10px;margin-bottom:20px!important}.list-group-item{color:#000;font-size:13px}.sources-container{align-items:flex-start;display:flex;gap:15px}.source-card{background-color:#f0f3f5;border-radius:10px;box-sizing:border-box;cursor:pointer;display:flex;flex-direction:column;justify-content:space-between;padding:15px;position:relative;transition:box-shadow .3s ease;width:100%}.popup{background-color:#fff;border-radius:5px;box-shadow:0 4px 8px rgba(0,0,0,.2);left:50%;opacity:0;padding:10px;position:absolute;top:100%;transform:translateX(-50%) translateY(-10px);transition:opacity .3s ease,transform .3s ease;visibility:hidden;white-space:normal;width:100%;z-index:10}.popup h5{font-size:14px;font-weight:600;line-height:1.2;margin:5px 0 10px}.popup p{font-size:12px;line-height:1.4;margin:0}.popup h5:hover{color:#007bff;cursor:pointer}.popup .source-url{color:#000;text-decoration:none}.popup .source-url:hover{color:#007bff;cursor:pointer;text-decoration:underline}.source-card:hover .popup{opacity:1;transform:translateX(-50%) translateY(-15px);visibility:visible}.source-card:hover{box-shadow:0 4px 8px rgba(0,0,0,.1);transform:scale(1.05)}.source-title{-webkit-box-orient:vertical;-webkit-line-clamp:2;display:-webkit-box;font-size:14px;font-weight:500;height:55px;line-height:1.5;overflow:hidden;text-align:left;text-overflow:ellipsis}.source-title img{margin-left:10px;width:20px}.source-url{align-items:center;color:#6c757d;display:flex;font-size:12px;text-align:left}.source-url img{border-radius:50%;height:16px;margin-right:5px;width:16px}.sourceDraweContainer .container{background-color:#fff;padding:20px}.sourceDraweContainer .sources-list{list-style:none;padding:0}.sourceDraweContainer .sources-list li{align-items:flex-start;display:flex;margin-bottom:15px}.sourceDraweContainer .sources-list input[type=checkbox]{flex-shrink:0;margin-right:15px;margin-top:8px}.sourceDraweContainer .source-content{background-color:#f5f2f2;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.1);cursor:pointer;flex:1;padding:12px}.sourceDraweContainer .source-content:hover{background:#ccc}.sourceDraweContainer .source-title{display:block;font-size:1rem;font-weight:500;height:auto!important;margin-bottom:4px}.sourceDraweContainer .source-description{display:block;font-size:.875rem}.sourceDraweContainer .image-container{align-items:center;display:flex;margin:10px 0}.sourceDraweContainer .image-container img{-o-object-fit:cover;border:1px solid #ddd;border-radius:50%;height:16px;margin-right:5px;object-fit:cover;width:16px}.sourceDraweContainer .image-container span{color:#555;font-size:13px}.closeButtonEditor{border:0;border-radius:100%;height:32px;padding:3px 0 0;position:absolute;right:10px;top:5px;width:32px}.closeButtonSource{background:none!important;border-color:transparent!important;box-shadow:none!important;color:inherit;cursor:pointer;float:right;margin-top:20px;transition:color .2s ease-in-out}.closeButtonSource.closeplaygroundbutton{display:none!important}.graph-img{background:hsla(0,0%,86.7%,.23137254901960785);border-radius:15px;padding:15px;width:70%}.chat-textarea{background-color:#fff;border:none;box-sizing:border-box;font-size:15px;height:30px;line-height:1.5;overflow-y:hidden;padding:10px;resize:none;transition:all 1s;width:100%}.chat-textarea:focus,.chat-textarea:hover{height:60px}.chat-textarea:focus{outline:none}.fixed-btn{background-color:#000;border:none;border-radius:8px 8px 0 0;color:#fff;cursor:pointer;font-size:16px;padding:5px 12px;position:fixed;right:-22px;top:46%;transform:translateY(-50%) rotate(270deg);transform-origin:center;transition:all .5s;z-index:1000000}.fixed-btn:hover{background-color:#5b5b5b}.fixed-btn-close{background-color:#000;border:none;border-radius:8px 8px 0 0;color:#fff;cursor:pointer;font-size:16px;padding:5px 16px;position:fixed;right:549px;top:46%;transform:translateY(-50%) rotate(270deg);transform-origin:center;transition:all .5s;z-index:1000000}.fixed-btn-close:hover{background-color:#5b5b5b}.btn.rotate{transform:rotate(-15deg)}.btn.rotate:hover{transform:rotate(0deg)}.btn.cta-chat{align-items:center;background:#f3f3f3;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;height:40px;justify-content:center;margin:0 auto;padding:5px;text-align:center;transition:all .5s;width:40px}.btn.cta-chat:hover{background:#d7d7d7;color:#666}.btn.cta-chat svg{vertical-align:middle}.chat-footer-upt{padding:4px}.workflowbox{align-items:center;border:1px solid transparent;border-radius:48px;color:#414141!important;cursor:pointer;display:flex;font-size:14px;margin-bottom:0;padding:.5rem 1.5rem;transition:all .5s;white-space:nowrap}.workflowbox:hover{background:#fff;border:1px solid #ddd}.workflowbox svg{margin:0 10px}.edit-boxDrawer{border-left:1px solid #ddd;box-shadow:1px 1px 15px hsla(0,0%,86.7%,.7686274509803922)!important}.edit-boxDrawer mat-drawer-content,ng-deep .edit-boxDrawer mat-drawer-content{margin-left:0!important;margin-right:0!important}.SearchTitle{font-size:16px!important;text-transform:capitalize}.exicution{margin:26px 0!important}.new-conversationbutton{align-items:center;background:#f5f5f5;border:1px solid #e3e3e3;border-radius:10px;cursor:pointer;display:flex;font-size:14px;justify-content:space-around;padding:6px;position:absolute;right:88px;top:10px;transition:all .5s;width:120px;z-index:1000}.new-conversationbutton:hover{background:#eee}.NoteTxt{margin:0 auto}.NoteTxt .text{margin:0 5px}.form-container{width:100%}.progress-container{align-items:center;display:flex}.circular-loader{border:4px solid rgba(0,0,0,.1);border-radius:50%;box-sizing:border-box;height:50px;position:relative;width:50px}.loader-spinner{animation:rotate-loader 1s linear infinite;border:2px solid #2196f3;border-radius:50%;border-top-color:transparent;box-sizing:border-box;height:100%;left:0;position:absolute;top:0;width:100%}.loader-text{color:#333;font-size:12px;font-weight:700;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.loader-label{color:#333;font-size:16px;margin-left:20px}.checkmark{align-items:center;display:flex;height:100%;justify-content:center;width:100%}.checkmark-circle{animation:stroke .6s ease-in-out forwards;stroke:#4caf50;stroke-dasharray:166;stroke-dashoffset:166;stroke-width:4}.checkmark-check{animation:stroke-check .4s ease-in-out .4s forwards;stroke:#4caf50;stroke-dasharray:48;stroke-dashoffset:48;stroke-linecap:round;stroke-linejoin:round;stroke-width:4}@keyframes stroke{to{stroke-dashoffset:0}}@keyframes stroke-check{to{stroke-dashoffset:0}}@keyframes rotate-loader{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes checkmark-animation{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.circular-loader.completed .loader-spinner{animation:none;transform:rotate(1turn)}.icon-button{background-color:transparent;border:none;color:#333;cursor:pointer;font-size:24px}.icon-button:focus{outline:none}.icon-button:hover{color:#007bff}.modal{background-color:rgba(0,0,0,.4);display:block;height:100%;left:0;padding-top:0;position:fixed;top:0;width:100%;z-index:1000001}.modal-content{background-color:#fff;border-radius:8px;box-shadow:0 4px 8px rgba(0,0,0,.1);height:600px;margin:5% auto;padding:20px;position:relative;width:82%}.close{color:#aaa;float:right;font-size:28px;font-weight:700}.close:focus,.close:hover{color:#000;cursor:pointer;text-decoration:none}.SearchTitle.user{text-transform:none!important}.SearchTitle.user,.SearchTitle.user h2,.SearchTitle.user p{font-size:30px!important}.title_chat{display:flex;margin:0;padding:0}.title_chat h2{align-items:center;display:flex;font-size:20px;gap:10px;margin:10px 0}.small-title{font-size:12px;margin:2px 0}.titleSection{margin:0}.titleSection h2{color:#000;font-size:20px;margin:0}.inputs-section{background-color:#f7f7f7;border-radius:5px;margin:0 0 10px;padding:10px 15px 0}.inputs-section h3{font-size:16px}.actions-section{background-color:#f9f9f9;border-radius:5px;height:500px;margin-bottom:20px;overflow-y:auto;padding:15px}.timeline{margin-bottom:20px;padding-left:40px;position:relative}.timeline:before{border-right:2px dashed #cecece;content:\"\";height:100%;left:19px;position:absolute}.timeline-item{margin-bottom:20px;position:relative}.timeline-item:before{background-color:#007bff;border-radius:50%;content:\"\";height:20px;left:-30px;position:absolute;top:0;width:20px;z-index:1}.timeline-item h4{color:#000;font-size:16px;font-weight:700;margin:0}.timeline-item pre{background-color:#fff;border:1px solid #ddd;border-radius:5px;padding:10px;white-space:pre-wrap}.timestamp-section{color:#666;font-style:italic;justify-content:space-between}.mic-btn{background-color:#ff4d4d;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:1.5em;padding:10px}.mic-btn:active{background-color:#f66}.actions-section h3{font-size:16px}.close-wrapper{display:flex;justify-content:right;position:absolute;right:22px;top:0;width:100%}.close_pop{color:#aaa;cursor:pointer;font-size:30px;font-weight:400;justify-content:center}.close_pop,.user-Box{align-items:center;display:flex}.bards{position:absolute;right:0;top:20px}::ng-deep .code-container{margin:20px 0;position:relative}::ng-deep .copy-button{background-color:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:5px 10px;position:absolute;right:10px;top:10px}::ng-deep .copy-button:hover{background-color:#0056b3}::ng-deep .code_block.diff{background-color:#f8f8f8;border-left:4px solid #ccc;overflow:auto;padding:10px}"]
1539
- },] }
1540
- ];
1541
- ChatDrawerComponent.ctorParameters = () => [
1542
- { type: FormBuilder },
1543
- { type: BotsService },
1544
- { type: ChangeDetectorRef },
1545
- { type: HttpClient },
1546
- { type: DomSanitizer },
1547
- { type: ElementRef },
1548
- { type: Renderer2 },
1549
- { type: SocketService },
1550
- { type: ConversationService }
1551
- ];
1552
- ChatDrawerComponent.propDecorators = {
1553
- chatMain: [{ type: ViewChild, args: ['chatMain',] }],
1554
- myInput: [{ type: ViewChild, args: ['myInput',] }],
1555
- closePlaygroundButtons: [{ type: ViewChildren, args: ['closeplaygroundbutton',] }],
1556
- drawer: [{ type: ViewChild, args: ['drawer',] }],
1557
- sourcesDrawer: [{ type: ViewChild, args: ['sourcesDrawer',] }],
1558
- editorsDrawer: [{ type: ViewChild, args: ['editorsDrawer',] }],
1559
- myTextarea: [{ type: ViewChild, args: ['myTextarea', { static: false },] }],
1560
- copilotName: [{ type: Input }],
1561
- firstName: [{ type: Input }],
1562
- lastName: [{ type: Input }],
1563
- apiKey: [{ type: Input }],
1564
- bgBubbleAi: [{ type: Input }],
1565
- bgBubbleUser: [{ type: Input }],
1566
- bgGradient: [{ type: Input }],
1567
- botName: [{ type: Input }],
1568
- botSkills: [{ type: Input }],
1569
- botId: [{ type: Input }],
1570
- orgId: [{ type: Input }],
1571
- closeButtonColor: [{ type: Input }],
1572
- closeButtonbgColor: [{ type: Input }],
1573
- credentials: [{ type: Input }],
1574
- dateTimeColor: [{ type: Input }],
1575
- dateTextColor: [{ type: Input }],
1576
- eventId: [{ type: Input }],
1577
- s27Token: [{ type: Input }],
1578
- eventName: [{ type: Input }],
1579
- botIcon: [{ type: Input }],
1580
- formFieldBgColor: [{ type: Input }],
1581
- formFieldTextColor: [{ type: Input }],
1582
- fullView: [{ type: Input }],
1583
- gradientColors: [{ type: Input }],
1584
- greeting: [{ type: Input }],
1585
- messageTextColorAi: [{ type: Input }],
1586
- messageTextColorUser: [{ type: Input }],
1587
- rules: [{ type: Input }],
1588
- sendButtonColor: [{ type: Input }],
1589
- sendButtonTextColor: [{ type: Input }],
1590
- showClose: [{ type: Input }],
1591
- thumbsDownMessages: [{ type: Input }],
1592
- thumbsUpMessage: [{ type: Input }],
1593
- timezone: [{ type: Input }],
1594
- unknownResponses: [{ type: Input }],
1595
- useOpenAi: [{ type: Input }],
1596
- userId: [{ type: Input }],
1597
- isDev: [{ type: Input }],
1598
- againButtonColor: [{ type: Input }],
1599
- againButtonTextColor: [{ type: Input }],
1600
- feedbackEvent: [{ type: Output }],
1601
- onCloseEvent: [{ type: Output }],
1602
- openPage: [{ type: Output }],
1603
- sessionActions: [{ type: Output }],
1604
- closeBot: [{ type: Output }],
1605
- connectWithUser: [{ type: Output }],
1606
- scheduleMeeting: [{ type: Output }],
1607
- refreshToken: [{ type: Output }]
1608
- };
1609
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chat-drawer.component.js","sourceRoot":"D:/hiveGPT-AI-packages/HiveAI-Packages/projects/hivegpt/eventsgpt-angular/src/","sources":["lib/components/chat-drawer/chat-drawer.component.ts"],"names":[],"mappings":"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","sourcesContent":["// import { Platform } from '@angular/cdk/platform';\r\nimport { HttpClient, HttpHeaders } from '@angular/common/http';\r\nimport {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n  QueryList,\r\n  Renderer2,\r\n  SimpleChanges,\r\n  ViewChild,\r\n  ViewChildren,\r\n} from '@angular/core';\r\nimport { MatDrawer } from '@angular/material/sidenav';\r\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\r\nimport { of, Subscription } from 'rxjs';\r\nimport { catchError, switchMap } from 'rxjs/operators';\r\nimport { formatNow, formatTimeStamps } from '../../utils/utils';\r\nimport {\r\n  dev_environment,\r\n  prod_environment,\r\n} from '../../../environments/environment';\r\nimport { ConversationService } from '../conversation.service';\r\nimport { Observable } from 'rxjs';\r\nimport { SocketService } from '../socket-service.service';\r\n\r\nimport { FormBuilder, Validators } from '@angular/forms';\r\nimport * as SpeechSDK from 'microsoft-cognitiveservices-speech-sdk';\r\nimport { BotsService } from '../bot.service';\r\n\r\n@Component({\r\n  selector: 'hivegpt-chat-drawer-package',\r\n  templateUrl: './chat-drawer.component.html',\r\n  styleUrls: ['./chat-drawer.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class ChatDrawerComponent implements OnInit, OnChanges {\r\n  @ViewChild('chatMain') private chatMain: ElementRef;\r\n  @ViewChild('myInput') private myInput: ElementRef;\r\n  @ViewChildren('closeplaygroundbutton')\r\n  closePlaygroundButtons: QueryList<ElementRef>;\r\n  @ViewChild('drawer') drawer!: MatDrawer;\r\n  @ViewChild('sourcesDrawer') sourcesDrawer!: MatDrawer;\r\n  @ViewChild('editorsDrawer') editorsDrawer!: MatDrawer;\r\n  private bodyOverflowClass = 'body-overflow-hidden';\r\n  @ViewChild('myTextarea', { static: false })\r\n  myTextarea!: ElementRef<HTMLTextAreaElement>; // Reference to the textarea\r\n  isCollapsedTrue = false;\r\n  @Input() copilotName: string = 'HiveXGPT';\r\n  @Input() firstName!: string;\r\n  @Input() lastName!: string;\r\n  @Input() apiKey!: string;\r\n  @Input() bgBubbleAi!: string;\r\n  @Input() bgBubbleUser!: string;\r\n  @Input() bgGradient!: string[];\r\n  @Input() botName!: string;\r\n  @Input() botSkills!: string;\r\n  @Input() botId!: string;\r\n  @Input() orgId!: string;\r\n  @Input() closeButtonColor!: string;\r\n  @Input() closeButtonbgColor!: string;\r\n  @Input() credentials!: [];\r\n  @Input() dateTimeColor!: string;\r\n  @Input() dateTextColor!: string;\r\n  @Input() eventId!: string;\r\n  @Input() s27Token!: string;\r\n  @Input() eventName!: string;\r\n  @Input() botIcon!: string;\r\n  @Input() formFieldBgColor!: string;\r\n  @Input() formFieldTextColor!: string;\r\n  @Input() fullView!: boolean;\r\n  @Input() gradientColors!: string[];\r\n  @Input() greeting!: string;\r\n  @Input() messageTextColorAi!: string;\r\n  @Input() messageTextColorUser!: string;\r\n  @Input() rules!: string;\r\n  @Input() sendButtonColor!: string;\r\n  @Input() sendButtonTextColor!: string;\r\n  @Input() showClose!: boolean;\r\n  @Input() thumbsDownMessages!: string[];\r\n  @Input() thumbsUpMessage!: string;\r\n  @Input() timezone!: string;\r\n  @Input() unknownResponses!: [];\r\n  @Input() useOpenAi!: boolean;\r\n  @Input() userId!: string;\r\n  @Input() isDev!: boolean;\r\n\r\n  @Input() againButtonColor!: string[];\r\n  @Input() againButtonTextColor!: string[];\r\n  @Output() feedbackEvent = new EventEmitter<string>();\r\n  @Output() onCloseEvent = new EventEmitter<void>();\r\n  @Output() openPage = new EventEmitter<any>();\r\n  @Output() sessionActions = new EventEmitter<any>();\r\n  @Output() closeBot = new EventEmitter<any>();\r\n  @Output() connectWithUser = new EventEmitter<any>();\r\n  @Output() scheduleMeeting = new EventEmitter<string>();\r\n  @Output() refreshToken = new EventEmitter<any>();\r\n\r\n  autogenKey = 'Autogen_eDJTtEU-NB0RtIpzq1w';\r\n  addToMyAgendaAction = 'add_to_my_agenda';\r\n  myUpcomingSessionAction = 'my_upcomming_session';\r\n  connectOrFollowAction = 'connect_or_follow';\r\n  aiResponse: string = '';\r\n  chatLog: any[] = [];\r\n  decoder = new TextDecoder();\r\n  feedbackDone: boolean = false;\r\n  greetingMsg: string = '';\r\n  hasBackdropValue: boolean = false;\r\n  input: string = '';\r\n  listenerAdded = false;\r\n  loading: boolean = false;\r\n  mode: string = 'over';\r\n  quickPrompts: any[] = [];\r\n  thumbsDownMsgIndex = 0;\r\n  userName: string = '';\r\n  showStartAgain: boolean = false;\r\n  isIOSDevice: boolean = false;\r\n  showFeedBackIconsIndex: number | null = null;\r\n  temperature: number = 1;\r\n  speakers = [];\r\n  environment: {\r\n    USERS_API;\r\n    BASE_URL;\r\n    AGENTS_API;\r\n  };\r\n  pendingRequests: any;\r\n  myConnections: any;\r\n  conversationKey: string;\r\n  isFetchDataFor: boolean;\r\n  is401: boolean;\r\n  msg: any;\r\n  chat: any;\r\n  isWorkflowOpen: boolean;\r\n  orgWorkflows: any;\r\n  openWorkflowInput: boolean;\r\n  selectedWorkflow: any;\r\n  workflowForm: any;\r\n  currentWorkflowActionProgress: number = 0;\r\n  currentWorkflowAction: string = '';\r\n  executingWorkflow: boolean;\r\n  workflowExecutionDetails: any;\r\n  showWorkflowExecutionDetails: any;\r\n  currentWorkflowExecutionDetails: any;\r\n\r\n  speechConfig: SpeechSDK.SpeechConfig;\r\n  recognizer: SpeechSDK.SpeechRecognizer;\r\n  recognizedText: string = '';\r\n  authorizationToken: string = '';\r\n  region: string = 'westeurope'; // Set your Azure region here\r\n  isRecording: boolean;\r\n\r\n  constructor(\r\n    private fb: FormBuilder,\r\n    private botService: BotsService,\r\n    private cdr: ChangeDetectorRef,\r\n    private http: HttpClient,\r\n    private sanitizer: DomSanitizer,\r\n    private elementRef: ElementRef,\r\n    private renderer: Renderer2,\r\n    private socketService: SocketService,\r\n    private conversationService: ConversationService // private platform: Platform\r\n  ) {\r\n    this.chatMain = new ElementRef(null);\r\n\r\n    // if (this.platform.IOS) {\r\n    //   this.isIOSDevice = true;\r\n    // }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes.s27Token) {\r\n      if (changes.s27Token.currentValue != changes.s27Token.previousValue) {\r\n        this.s27Token = changes.s27Token.currentValue;\r\n\r\n        console.log('isFetchDataFor: ', this.isFetchDataFor);\r\n        console.log('msg: ', this.msg);\r\n        console.log('chat: ', this.chat);\r\n        if (this.is401) {\r\n          if (this.isFetchDataFor) {\r\n            this.fetchDataFor(this.msg, this.chat);\r\n          } else {\r\n            this.fetchData(this.msg);\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n    if (changes.orgId) {\r\n      if (\r\n        changes.orgId.currentValue != changes.orgId.previousValue &&\r\n        changes.orgId.currentValue\r\n      ) {\r\n        this.initializeSocket();\r\n        if (!this.checkForCop29BotId()) {\r\n          this.botService.getWorkflowsByOrgId(this.orgId).subscribe((res) => {\r\n            this.orgWorkflows = res;\r\n          });\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.environment = this.isDev ? dev_environment : prod_environment;\r\n\r\n    // this.fetchMyConnections().subscribe();\r\n    // this.fetchPendingRequests().subscribe();\r\n\r\n    this.changeTemperature(this.temperature);\r\n    this.fetchBotConfig().subscribe(\r\n      (res) => {\r\n        this.cdr.markForCheck();\r\n\r\n        this.fetchChatHistory().subscribe(\r\n          (response) => {\r\n            this.loading = false;\r\n            this.mapChatHistory(response);\r\n            this.cdr.markForCheck();\r\n          },\r\n          (err) => {\r\n            console.error('Error fetching chat history:', err);\r\n          }\r\n        );\r\n      },\r\n      (err) => {\r\n        console.error('Error fetching chat history:', err);\r\n      }\r\n    );\r\n    this.fetchAgents();\r\n    this.fetchEditorContent();\r\n    this.cdr.markForCheck();\r\n    // this.initializeSocket();\r\n    if (!this.checkForCop29BotId()) {\r\n      this.botService.fetchSpeechAuthorizationToken().subscribe((token) => {\r\n        this.authorizationToken = token;\r\n        this.initializeSpeechRecognizer(token);\r\n      });\r\n    }\r\n  }\r\n\r\n  private eventSubscription: Subscription;\r\n  initializeSocket() {\r\n    try {\r\n      this.socketService.disconnectSocketConnection();\r\n    } catch (error) { }\r\n    setTimeout(() => {\r\n      this.socketService.connectSocketConnection();\r\n      setTimeout(() => {\r\n        console.log('YES INIT');\r\n        const conversation_id = this.conversationService.getKey(this.botId);\r\n\r\n        this.socketService.registerUserSpecificHiveSocket(\r\n          this.botId,\r\n          conversation_id,\r\n          this.orgId\r\n        );\r\n        setTimeout(() => {\r\n          this.listenSockets();\r\n        }, 300);\r\n      }, 200);\r\n    }, 300);\r\n  }\r\n\r\n  subscriptionNew: any;\r\n  socketData: any;\r\n\r\n  listenSockets() {\r\n    if (this.eventSubscription) {\r\n      this.eventSubscription.unsubscribe();\r\n    }\r\n    console.log('Listen Socket');\r\n    this.eventSubscription = this.conversationService\r\n      .getUserSpecificNotification()\r\n      .subscribe(\r\n        (res) => {\r\n          console.log('Listen Socket response');\r\n          console.log(res);\r\n          // Check if OtherFields exists in the response\r\n          if (res?.m?.OtherFields?.workflow_id) {\r\n            const {\r\n              percentage,\r\n              output,\r\n              action_name,\r\n              current_action_name,\r\n              workflow_execution_id,\r\n              time_stamp,\r\n            } = res?.m?.OtherFields;\r\n\r\n            this.currentWorkflowActionProgress = percentage;\r\n            this.currentWorkflowAction = action_name;\r\n\r\n            const actionIndex = this.workflowExecutionDetails.Actions.findIndex(\r\n              (a) => a.Name == current_action_name\r\n            );\r\n\r\n            if (actionIndex !== -1) {\r\n              this.workflowExecutionDetails.Actions[actionIndex][\r\n                'Output'\r\n              ] = output;\r\n              this.workflowExecutionDetails.Actions[actionIndex][\r\n                'InsertTimeStamp'\r\n              ] = formatTimeStamps(this.timezone, time_stamp);\r\n            } else {\r\n              console.error(`Action with name ${action_name} not found`);\r\n            }\r\n\r\n            this.currentWorkflowExecutionDetails = this.workflowExecutionDetails;\r\n\r\n            if (this.currentWorkflowActionProgress == 100) {\r\n              this.chatLog[this.chatLog.length - 1][\r\n                'WorkflowExecutionId'\r\n              ] = workflow_execution_id;\r\n              this.isChatingWithAi = false;\r\n              this.executingWorkflow = false;\r\n            }\r\n\r\n            this.cdr.detectChanges();\r\n          } else if (res?.m?.OtherFields) {\r\n            const {\r\n              conversation_id,\r\n              bot_id,\r\n              message_id,\r\n              answer,\r\n              web_results,\r\n              search_results,\r\n              graphs,\r\n              execution_graphs,\r\n              suggestions,\r\n            } = res?.m?.OtherFields;\r\n            console.log('message_id1');\r\n            console.log(res?.m?.OtherFields);\r\n            var currentChatMessage = this.chatLog.find(\r\n              (p) => p._id == message_id\r\n            );\r\n            console.log(this.chatLog);\r\n            if (!currentChatMessage) {\r\n              console.log('message_id2');\r\n              console.log(message_id);\r\n              currentChatMessage = {\r\n                _id: message_id,\r\n                type: 'ai',\r\n                time: formatNow(this.timezone),\r\n              };\r\n\r\n              this.chatLog.push(currentChatMessage);\r\n\r\n              this.showFeedBackIconsIndex = this.chatLog.length - 1;\r\n              console.log('message_id3');\r\n              console.log(message_id);\r\n              this.cdr.detectChanges();\r\n            }\r\n\r\n            // Handle the fields based on their presence\r\n            if (search_results && Array.isArray(search_results)) {\r\n              console.log('Online Search Terms:', search_results);\r\n              currentChatMessage.searchTerms = search_results;\r\n              this.cdr.detectChanges();\r\n            }\r\n\r\n            if (web_results && Array.isArray(web_results)) {\r\n              console.log('Web Results:', web_results);\r\n              currentChatMessage.sourcesList = web_results;\r\n              currentChatMessage.displayedSources = web_results?.slice(0, 3); // First 3 cards\r\n              currentChatMessage.remainingSources = web_results?.slice(3); // Remaining items\r\n              this.cdr.detectChanges();\r\n            }\r\n\r\n            if (answer) {\r\n              this.isChatingWithAi = false;\r\n              console.log('Answer:', answer);\r\n\r\n              currentChatMessage.message = this.processMessageForDisplay(\r\n                answer\r\n              );\r\n              this.cdr.detectChanges();\r\n              this.scrollToBottom();\r\n            }\r\n\r\n            if (graphs && Array.isArray(graphs)) {\r\n              console.log('Graphs:', graphs);\r\n              currentChatMessage.graphs = graphs;\r\n              this.cdr.detectChanges();\r\n            }\r\n\r\n            if (execution_graphs && Array.isArray(execution_graphs)) {\r\n              console.log('Execution Graphs:', execution_graphs);\r\n              currentChatMessage.executionGraphs = execution_graphs;\r\n              this.cdr.detectChanges();\r\n            }\r\n\r\n            if (suggestions && Array.isArray(suggestions)) {\r\n              console.log('suggestions:', suggestions);\r\n              currentChatMessage.relatedListItems = suggestions;\r\n              this.cdr.detectChanges();\r\n              // Process online search terms as needed\r\n            }\r\n\r\n            // Add any other fields and their processing here\r\n          } else {\r\n            console.warn('OtherFields is missing in the response');\r\n          }\r\n        },\r\n        (err) => {\r\n          this.eventSubscription.unsubscribe();\r\n          console.error('Error in fetching data from socket', err);\r\n        }\r\n      );\r\n  }\r\n\r\n  initializeSocketAndListen() { }\r\n  handleEvent(data: any, type: string) {\r\n    switch (type) {\r\n      case 'webresult':\r\n        break;\r\n      case 'answer':\r\n        break;\r\n      case 'graph':\r\n        break;\r\n      default:\r\n        break;\r\n    }\r\n  }\r\n  ngOnDestroy(): void {\r\n    if (this.eventSubscription) {\r\n      this.eventSubscription.unsubscribe();\r\n    }\r\n    this.socketService.disconnectSocketConnection();\r\n    //this.socketService.close();\r\n  }\r\n  changeTemperature(newTemperature: number) {\r\n    if (this.loading) return;\r\n    this.temperature = newTemperature;\r\n    const wrapper = document.querySelector('.hivegpt-chat-wrapper');\r\n    // Remove existing theme classes from body\r\n    wrapper?.classList.remove('creative', 'balanced', 'precise');\r\n\r\n    switch (newTemperature) {\r\n      case 0:\r\n        wrapper?.classList.add('creative');\r\n        break;\r\n      case 1:\r\n        wrapper?.classList.add('balanced');\r\n        break;\r\n      case 2:\r\n        wrapper?.classList.add('precise');\r\n        break;\r\n      default:\r\n        break;\r\n    }\r\n  }\r\n\r\n  onStartAgain() {\r\n    if (this.loading) return;\r\n    this.showStartAgain = false;\r\n    this.chatLog = [];\r\n    this.chatLog.push({\r\n      type: 'ai',\r\n      message: this.greetingMsg,\r\n\r\n      time: formatNow(this.timezone),\r\n    });\r\n    this.archieveMessages().subscribe();\r\n  }\r\n\r\n  archieveMessages() {\r\n    const headers = new HttpHeaders({\r\n      'Content-Type': 'application/json',\r\n      'x-api-key': this.apiKey,\r\n    });\r\n    const url = `${this.environment.BASE_URL}/bot/clear-history/${this.botId}/${this.userId}`;\r\n    return this.http.post(url, {}, { headers }).pipe(\r\n      switchMap((res: any) => {\r\n        return of(res);\r\n      }),\r\n      catchError((error) => {\r\n        return of(null);\r\n      })\r\n    );\r\n  }\r\n\r\n  fetchBotConfig() {\r\n    this.loading = true;\r\n    const url = `${this.environment.BASE_URL}/bots?bot_id=${this.botId}`;\r\n    return this.http.get(url).pipe(\r\n      switchMap((res: any) => {\r\n        this.botName = res.Name;\r\n        this.botIcon = res.Icon;\r\n        this.botSkills = res?.Skills;\r\n        this.greetingMsg = res.Greeting;\r\n\r\n        this.thumbsDownMessages = res?.NegativeResponses?.length\r\n          ? res.NegativeResponses\r\n          : [\r\n            \"We are sorry we've not been able to answer your question.<br/> However, our dedicated support team is happy to help. <span class='feedback-link' style='cursor: pointer; text-decoration: underline; font-weight: 700; color: #17235B;'>Please click here</span> and a human agent will assist you as soon as possible\",\r\n          ];\r\n        this.quickPrompts = res.QuickPrompts;\r\n        this.cdr.markForCheck();\r\n        this.loading = false;\r\n        return of(res);\r\n      }),\r\n      catchError((error) => {\r\n        console.error('Error fetching chatbot config: ', error);\r\n        this.loading = false;\r\n        return of(null);\r\n      })\r\n    );\r\n  }\r\n\r\n  fetchChatHistory(): Observable<any> {\r\n    this.loading = true;\r\n\r\n    this.conversationKey = this.conversationService.getKey(this.botId, false);\r\n    const url = `${this.environment.BASE_URL}/conversations/${this.conversationKey}`;\r\n    const headers = new HttpHeaders({\r\n      accept: 'application/json',\r\n    });\r\n\r\n    return this.http\r\n      .get(url, { headers })\r\n      .pipe(catchError(this.handleError<any>('fetchConversation')));\r\n  }\r\n\r\n  private handleError<T>(operation = 'operation', result?: T) {\r\n    return (error: any): Observable<T> => {\r\n      console.error(`${operation} failed: ${error.message}`);\r\n      return of(result as T);\r\n    };\r\n  }\r\n  // fetchChatHistory() {\r\n  //   this.loading = true;\r\n  //   const headers = new HttpHeaders({\r\n  //     'Content-Type': 'application/json',\r\n  //     'x-api-key': this.apiKey,\r\n  //   });\r\n  //   return this.http\r\n  //     .get(`${this.environment.BASE_URL}/conversations/${this.conversationKey}`, { headers })\r\n  //     .pipe(\r\n  //       switchMap((res: any) => {\r\n  //         this.loading = false;\r\n  //         return of(res);\r\n  //       }),\r\n  //       catchError((error: any) => {\r\n  //         console.error('Error fetching chat history: ', error);\r\n  //         this.loading = false;\r\n  //         return of(null);\r\n  //       })\r\n  //     );\r\n  // }\r\n\r\n  mapChatHistory(chats: any) {\r\n    this.chatLog.push({\r\n      type: 'ai',\r\n      message: this.greetingMsg,\r\n      time: formatNow(this.timezone),\r\n    });\r\n    if (chats && chats?.Messages?.length) {\r\n      chats?.Messages.forEach((chat: any) => {\r\n        if (chat.Type == 'user') {\r\n          this.chatLog.push({\r\n            type: 'user',\r\n            message: this.processMessageForDisplay(chat.Text),\r\n            time: formatTimeStamps(this.timezone, chat.InsertTimestamp),\r\n            copied: false,\r\n            isCollapsedTrue: false,\r\n            WorkflowExecutionId: chat.WorkflowExecutionId,\r\n          });\r\n        }\r\n        if (chat.Type == 'ai') {\r\n          var sourcesList = chat.WebLinks || [];\r\n          var displayedSources = chat.WebLinks.slice(0, 3); // First 3 cards\r\n          var remainingSources = chat.WebLinks.slice(3); // Remaining items\r\n\r\n          this.chatLog.push({\r\n            type: 'ai',\r\n            message: this.processMessageForDisplay(chat.Text),\r\n            executionGraphs: chat.ExecutionGraphs,\r\n            graphs: chat.Graphs,\r\n            searchTerms: chat.SearchTerms,\r\n            sourcesList: sourcesList,\r\n            displayedSources: displayedSources,\r\n            remainingSources: remainingSources,\r\n            time: formatTimeStamps(this.timezone, chat.InsertTimestamp),\r\n            copied: false,\r\n            isCollapsedTrue: false,\r\n          });\r\n          this.showFeedBackIconsIndex = this.chatLog.length - 1;\r\n        }\r\n      });\r\n      this.showStartAgain = true;\r\n    }\r\n    this.scrollToBottom();\r\n    this.cdr.markForCheck();\r\n  }\r\n\r\n  processMessage(message: string): SafeHtml {\r\n    if (!message || !(message?.length > 0)) {\r\n      return '';\r\n    }\r\n\r\n    // console.log('here is my message')\r\n    // console.log(message);\r\n\r\n    message = message.trim();\r\n\r\n    const markdownLinkRegex = /\\[([^[]+)]\\(([^)]+)\\)/g;\r\n    const urlRegex = /(?<!href=\")\\bhttps?:\\/\\/\\S+(?<![.,])/gi;\r\n\r\n    if (markdownLinkRegex.test(message)) {\r\n      const html = message.replace(\r\n        markdownLinkRegex,\r\n        '<a href=\"$2\" target=\"_blank\">$1</a>'\r\n      );\r\n      //console.log('Sanitized message: ', message);\r\n      return this.sanitizeHtml(html);\r\n    }\r\n\r\n    if (urlRegex.test(message)) {\r\n      const html = message.replace(\r\n        urlRegex,\r\n        '<a href=\"$&\" target=\"_blank\">$&</a>'\r\n      );\r\n      // console.log('Sanitized message: ', message);\r\n      return this.sanitizeHtml(html);\r\n    }\r\n\r\n    message = message.replace(/(?:\\r\\n|\\r|\\n)/g, '<br>');\r\n\r\n    message = message.replace(/\\*\\*(.*?)\\*\\*/g, '<strong>$1</strong>');\r\n    // Convert Markdown headers to HTML headers\r\n    message = message.replace(/^(#{1,6})\\s+(.*)$/gm, (match, hashes, text) => {\r\n      const level = hashes.length;\r\n      return `<h${level}>${text}</h${level}>`;\r\n    });\r\n\r\n    this.cdr.markForCheck();\r\n    const sanitizedMessage = this.sanitizeHtml(message);\r\n    return sanitizedMessage;\r\n  }\r\n\r\n  ngAfterViewChecked() {\r\n    const feedbackLinks = this.elementRef.nativeElement.querySelectorAll(\r\n      '.feedback-link'\r\n    );\r\n    feedbackLinks.forEach((link: any) => {\r\n      link.addEventListener(\r\n        'click',\r\n        this.onFeedbackClick.bind(this, 'zendesk')\r\n      );\r\n    });\r\n    // if (this.elementRef.nativeElement.querySelector('.feedback-link')) {\r\n    //   this.elementRef.nativeElement\r\n    //     .querySelector('.feedback-link')\r\n    //     .addEventListener('click', this.onFeedbackClick.bind(this, 'zendesk'));\r\n    // }\r\n  }\r\n\r\n  sanitizeHtml(html: string): SafeHtml {\r\n    return this.sanitizer.bypassSecurityTrustHtml(html);\r\n  }\r\n\r\n  onFeedbackClick(value: string) {\r\n    this.feedbackEvent.emit(value);\r\n  }\r\n\r\n  onClose() {\r\n    this.renderer.removeClass(document.body, this.bodyOverflowClass);\r\n    this.onCloseEvent.emit();\r\n  }\r\n\r\n  sendMessageWithTile(prompt: string) {\r\n    this.input = prompt;\r\n    this.fetchData();\r\n    this.scrollToBottom();\r\n  }\r\n  isChatingWithAi = false;\r\n  fetchData(msg = null) {\r\n    this.input = msg || this.input?.trim();\r\n    this.msg = this.input;\r\n    if (!this.input || this.loading) {\r\n      return;\r\n    }\r\n\r\n    this.chatLog.push({\r\n      type: 'user',\r\n      message: this.processMessageForDisplay(this.input),\r\n      time: formatNow(this.timezone),\r\n      copied: false,\r\n      isCollapsedTrue: false,\r\n    });\r\n\r\n    try {\r\n      const textarea = this.myInput.nativeElement;\r\n      textarea.style.height = 'hidden'; // Reset the height\r\n      textarea.style.height = `62px`;\r\n    } catch (error) { }\r\n    this.cdr.markForCheck();\r\n\r\n    this.aiResponse = '';\r\n    this.isChatingWithAi = true;\r\n\r\n    this.makeAskRequest(this.input, this.agents, this.conversationKey);\r\n  }\r\n  fetchDataFor(msg, chat) {\r\n    const inputMsg = msg?.trim();\r\n    if (!inputMsg || this.loading) {\r\n      return;\r\n    }\r\n    try {\r\n      chat.relatedListItems = [];\r\n      this.cdr.detectChanges();\r\n    } catch (error) { }\r\n\r\n    this.scrollToBottom();\r\n    this.chatLog.push({\r\n      type: 'user',\r\n      message: this.processMessageForDisplay(inputMsg),\r\n      time: formatNow(this.timezone),\r\n      copied: false,\r\n      isCollapsedTrue: false,\r\n    });\r\n\r\n    this.cdr.markForCheck();\r\n\r\n    this.aiResponse = '';\r\n    this.isChatingWithAi = true;\r\n\r\n    this.makeAskRequest(inputMsg, this.agents, this.conversationKey, msg, chat);\r\n  }\r\n  fetchSmallTalk() {\r\n    this.loading = true;\r\n    this.cdr.markForCheck();\r\n\r\n    const url = `${this.environment.BASE_URL}/bot/small-talk/${this.botId}/${this.userId}`;\r\n\r\n    this.http\r\n      .get<{ smallTalk: string }>(url, {\r\n        headers: {\r\n          'x-api-key': this.apiKey,\r\n        },\r\n      })\r\n      .pipe(\r\n        catchError((error) => {\r\n          console.error('Error while fetching small talk:', error);\r\n\r\n          return of(null);\r\n        })\r\n      )\r\n      .subscribe((response) => {\r\n        this.loading = false;\r\n        this.cdr.markForCheck();\r\n\r\n        if (!response) {\r\n          return;\r\n        }\r\n\r\n        if (response && response.smallTalk) {\r\n          this.chatLog.push({\r\n            type: 'ai',\r\n            message: this.processMessage(response.smallTalk),\r\n            time: formatNow(this.timezone),\r\n            isFeedbackMsg: true,\r\n          });\r\n          this.showFeedBackIconsIndex = this.chatLog.length - 2;\r\n          // this.scrollToBottom();\r\n          this.cdr.markForCheck();\r\n        }\r\n      });\r\n  }\r\n\r\n  readAllChunks = (stream: any) => {\r\n    const reader = stream.getReader();\r\n    const allSuggestions: string[] = [];\r\n\r\n    reader.closed.catch((err: any) => {\r\n      if (err) {\r\n        console.error('Error reading stream: ', err);\r\n      }\r\n\r\n      this.isChatingWithAi = false;\r\n      this.scrollToBottom();\r\n      return;\r\n    });\r\n\r\n    return new ReadableStream({\r\n      start: (controller) => {\r\n        return this.pump(controller, reader, allSuggestions);\r\n      },\r\n    });\r\n  };\r\n\r\n  pump(controller: any, reader: any, allSuggestions: string[]) {\r\n    reader.read().then(({ done, value }: any) => {\r\n      const lastItem = this.chatLog[this.chatLog.length - 1];\r\n\r\n      if (done) {\r\n        lastItem.message = this.processMessageForDisplay(lastItem.message);\r\n        this.chatLog.pop();\r\n        this.chatLog.push(lastItem);\r\n        if (allSuggestions?.length) {\r\n          this.chatLog.push({\r\n            type: 'suggestions',\r\n            suggestions: allSuggestions,\r\n          });\r\n        }\r\n\r\n        controller.close();\r\n        this.isChatingWithAi = false;\r\n        // this.scrollToBottom();\r\n        this.cdr.markForCheck();\r\n        this.showStartAgain = true;\r\n\r\n        // setTimeout(() => {\r\n        //   this.fetchSmallTalk();\r\n        // },1000)\r\n        return;\r\n      }\r\n\r\n      let decodedChunk = this.decoder.decode(value, { stream: true });\r\n      this.aiResponse += decodedChunk;\r\n      if (lastItem.type === 'ai') {\r\n        const suggestionsMatch = this.aiResponse.match(/<sug>(.*?)<\\/sug>/g);\r\n        if (suggestionsMatch) {\r\n          suggestionsMatch.forEach((match) => {\r\n            this.aiResponse = this.aiResponse.replace(match, '');\r\n            allSuggestions.push(match?.replace(/<\\/?sug>/g, ''));\r\n          });\r\n        }\r\n\r\n        lastItem.message = this.aiResponse;\r\n        this.cdr.markForCheck();\r\n      } else {\r\n        this.isChatingWithAi = false;\r\n\r\n        let aiFormattedData: any;\r\n\r\n        try {\r\n          console.log('parsing json ');\r\n          aiFormattedData = JSON.parse(JSON.parse(this.aiResponse));\r\n        } catch (e) {\r\n          try {\r\n            console.log('parsing json 2');\r\n            aiFormattedData = JSON.parse(this.aiResponse);\r\n          } catch (e) { }\r\n        }\r\n\r\n        console.log('parsing json done');\r\n\r\n        if (aiFormattedData && aiFormattedData?.section_id?.length > 0) {\r\n          if (\r\n            aiFormattedData.section_id == 'company_search' ||\r\n            aiFormattedData.section_id == 'user_search' ||\r\n            aiFormattedData.section_id == 'industry_company_search'\r\n          ) {\r\n            this.fetchMyConnections().subscribe();\r\n            this.fetchPendingRequests().subscribe();\r\n          }\r\n\r\n          if (aiFormattedData.section_id == this.myUpcomingSessionAction) {\r\n            var speakerIds = [];\r\n            aiFormattedData.content?.forEach((session) => {\r\n              speakerIds = [...speakerIds, ...session.speakers];\r\n            });\r\n\r\n            if (speakerIds?.length > 0) this.getSpeakersByStaffIds(speakerIds);\r\n          }\r\n\r\n          if (\r\n            aiFormattedData.section_id == this.addToMyAgendaAction &&\r\n            aiFormattedData.content?.length > 0\r\n          ) {\r\n            this.openPage.next({\r\n              sectionId: aiFormattedData.section_id,\r\n              sessionIds: aiFormattedData.content,\r\n            });\r\n          }\r\n\r\n          if (aiFormattedData.section_id == this.connectOrFollowAction) {\r\n            let usersLen = aiFormattedData.content?.length;\r\n            if (usersLen > 1) {\r\n              this.openPage.next({\r\n                sectionId: 'open_networking_drawer',\r\n                search: aiFormattedData.content,\r\n              });\r\n            } else if (usersLen == 1) {\r\n              this.openPage.next({\r\n                sectionId: aiFormattedData.section_id,\r\n                connetUserIds: [aiFormattedData.content[0].userId],\r\n              });\r\n            }\r\n          }\r\n\r\n          if (aiFormattedData.is_open_page == 'true') {\r\n            this.openPage.next({\r\n              sectionId: aiFormattedData.section_id,\r\n              search: aiFormattedData.content,\r\n            });\r\n\r\n            if (this.isMobileBrowser()) {\r\n              aiFormattedData.message +=\r\n                '\\n\\n' + '<a id=\"closeBotNow\">Click Here</a> to see results.';\r\n            }\r\n          }\r\n\r\n          this.chatLog.push({\r\n            type: 'ai',\r\n            message: aiFormattedData.message,\r\n            action: aiFormattedData,\r\n            time: formatNow(this.timezone),\r\n          });\r\n\r\n          if (this.isMobileBrowser()) {\r\n            setTimeout(() => {\r\n              this.addCloseBotClickEvent();\r\n            }, 500);\r\n          }\r\n\r\n          this.aiResponse = '';\r\n        } else {\r\n          this.chatLog.push({\r\n            type: 'ai',\r\n            message: this.aiResponse,\r\n            time: formatNow(this.timezone),\r\n          });\r\n        }\r\n\r\n        this.showFeedBackIconsIndex = this.chatLog.length - 1;\r\n        this.cdr.markForCheck();\r\n      }\r\n\r\n      this.scrollToBottom();\r\n\r\n      // Enqueue the next data chunk into our target stream\r\n      controller.enqueue(value);\r\n      this.pump(controller, reader, allSuggestions);\r\n    });\r\n  }\r\n\r\n  submitFeedback(flag: boolean) {\r\n    this.feedbackDone = true;\r\n    this.showFeedBackIconsIndex = null;\r\n    const url = `${this.environment.BASE_URL}/bot/feedback`;\r\n    fetch(url, {\r\n      method: 'POST',\r\n      headers: {\r\n        'Content-Type': 'application/json',\r\n        'x-api-key': this.apiKey,\r\n      },\r\n      body: JSON.stringify({ flag, user_id: this.userId, bot_id: this.botId }),\r\n    }).then(() => {\r\n      if (flag) {\r\n        this.chatLog.push({\r\n          type: 'ai',\r\n          message:\r\n            this.thumbsUpMessage ||\r\n            `Great. May I assist you with anything else?`,\r\n          time: formatNow(this.timezone),\r\n          isFeedbackMsg: true,\r\n        });\r\n\r\n        this.scrollToBottom();\r\n        this.cdr.markForCheck();\r\n        this.feedbackDone = false;\r\n        this.showFeedBackIconsIndex = null;\r\n        return;\r\n      }\r\n\r\n      this.chatLog.push({\r\n        type: 'ai',\r\n        message: this.processMessage(\r\n          this.thumbsDownMessages[this.thumbsDownMsgIndex]\r\n        ),\r\n        time: formatNow(this.timezone),\r\n        isFeedbackMsg: true,\r\n      });\r\n      this.thumbsDownMsgIndex =\r\n        (this.thumbsDownMsgIndex + 1) % this.thumbsDownMessages.length;\r\n      this.scrollToBottom();\r\n      this.cdr.markForCheck();\r\n      this.feedbackDone = false;\r\n      this.showFeedBackIconsIndex = null;\r\n    });\r\n  }\r\n  handleKeydown(event: KeyboardEvent) {\r\n    if (event.key === 'Enter' && !event.shiftKey) {\r\n      // Prevent default behavior (new line)\r\n      event.preventDefault();\r\n      // Call your submit function\r\n      this.handleSubmit(event);\r\n    }\r\n  }\r\n  handleSubmit(event) {\r\n    this.fetchData();\r\n    this.scrollToBottom();\r\n\r\n  }\r\n\r\n  handleUpClick(idx: any) {\r\n    if (this.feedbackDone) {\r\n      return;\r\n    }\r\n\r\n    this.submitFeedback(true);\r\n    this.chatLog[idx].liked = !this.chatLog[idx].liked;\r\n\r\n    if (this.chatLog[idx].unliked) {\r\n      this.chatLog[idx].unliked = !this.chatLog[idx].unliked;\r\n    }\r\n\r\n    this.cdr.markForCheck();\r\n  }\r\n\r\n  handleDownClick(idx: any) {\r\n    if (this.feedbackDone) return;\r\n    this.submitFeedback(false);\r\n    this.chatLog[idx].unliked = !this.chatLog[idx].unliked;\r\n    if (this.chatLog[idx].liked)\r\n      this.chatLog[idx].liked = !this.chatLog[idx].liked;\r\n  }\r\n  // handleCopyClick(index: any) {\r\n  //   // Copy the message to the clipboard\r\n  //   const contentToCopy = this.chatLog[index].message;\r\n  //   console.log('contentToCopy');\r\n  //   console.log(contentToCopy);\r\n  //   navigator.clipboard.writeText(contentToCopy).then(() => {\r\n  //     // Indicate that the message was copied\r\n  //     this.chatLog[index].copied = true;\r\n  //     this.cdr.detectChanges();\r\n  //     // Reset the copied state after a delay\r\n  //     setTimeout(() => {\r\n  //       this.chatLog[index].copied = false;\r\n  //       this.cdr.detectChanges();\r\n  //     }, 2000); // Reset after 2 seconds\r\n  //   });\r\n  // }\r\n  copyText(id, index) {\r\n    // Get the text element\r\n    var textElement = document.getElementById(id);\r\n\r\n    // Create a temporary textarea element to copy the text\r\n    var tempTextArea = document.createElement('textarea');\r\n    tempTextArea.value = textElement.innerText;\r\n\r\n    // Append the textarea to the body (necessary for the execCommand to work)\r\n    document.body.appendChild(tempTextArea);\r\n\r\n    // Select the text inside the textarea\r\n    tempTextArea.select();\r\n\r\n    // Copy the text to the clipboard\r\n    document.execCommand('copy');\r\n\r\n    // Remove the temporary textarea\r\n    document.body.removeChild(tempTextArea);\r\n\r\n    // Optionally, you can alert the user or change the button text to indicate the copy was successful\r\n    // alert('Text copied to clipboard!');\r\n\r\n    this.chatLog[index].copied = true;\r\n    this.cdr.detectChanges();\r\n    // Reset the copied state after a delay\r\n    setTimeout(() => {\r\n      this.chatLog[index].copied = false;\r\n      this.cdr.detectChanges();\r\n    }, 2000); // Reset after 2 seconds\r\n  }\r\n  handleCopyClick(index: any) {\r\n    // Copy the message to the clipboard\r\n    const contentToCopy = this.chatLog[index].message;\r\n    const resutlt = this.copyText('messageText_' + index, index);\r\n  }\r\n\r\n  sanitizeHTML(html: string): string {\r\n    const doc = new DOMParser().parseFromString(html, 'text/html');\r\n\r\n    // Create a new document fragment to hold the simplified content\r\n    const fragment = document.createDocumentFragment();\r\n\r\n    // Append the children of the body of the parsed document to the fragment\r\n    Array.from(doc.body.childNodes).forEach((node) => {\r\n      fragment.appendChild(node.cloneNode(true));\r\n    });\r\n\r\n    // Create a new div element to hold the simplified HTML\r\n    const simplifiedDiv = document.createElement('div');\r\n    simplifiedDiv.appendChild(fragment);\r\n\r\n    // Remove complex tags or attributes as needed\r\n    // Example: remove scripts\r\n    simplifiedDiv\r\n      .querySelectorAll('script')\r\n      .forEach((script) => script.remove());\r\n\r\n    // Return the simplified HTML as a string\r\n    return simplifiedDiv.innerHTML;\r\n  }\r\n\r\n  currentMessageForEditor: any = '';\r\n  currentIndexForEditor: any = -1;\r\n  handleEditorClick(index: any) {\r\n    if (this.currentIndexForEditor == -1) {\r\n      this.currentIndexForEditor = index;\r\n      this.currentMessageForEditor = this.sanitizeHTML(\r\n        this.chatLog[index].message\r\n      );\r\n      this.currentMessageForEditor = this.currentMessageForEditor.replace(\r\n        'SafeValue must use [property]=binding:',\r\n        ''\r\n      );\r\n\r\n      this.cdr.detectChanges();\r\n    } else {\r\n      if (this.currentIndexForEditor == index) {\r\n        this.currentMessageForEditor += this.sanitizeHTML(\r\n          this.chatLog[index].message\r\n        );\r\n        this.currentMessageForEditor = this.currentMessageForEditor.replace(\r\n          'SafeValue must use [property]=binding:',\r\n          ''\r\n        );\r\n        this.cdr.detectChanges();\r\n      } else {\r\n        this.currentIndexForEditor = index;\r\n        this.currentMessageForEditor = this.sanitizeHTML(\r\n          this.chatLog[index].message\r\n        );\r\n        this.currentMessageForEditor = this.currentMessageForEditor.replace(\r\n          'SafeValue must use [property]=binding:',\r\n          ''\r\n        );\r\n        this.cdr.detectChanges();\r\n      }\r\n    }\r\n    this.chatLog[index].isEditor = true;\r\n    this.cdr.detectChanges();\r\n    // Reset the copied state after a delay\r\n    setTimeout(() => {\r\n      this.chatLog[index].isEditor = false;\r\n      this.cdr.detectChanges();\r\n    }, 2000); // Reset after 2 seconds\r\n    this.editorsDrawer.open();\r\n    const button = document.getElementById('botcloseplaygroundbutton');\r\n    if (button) {\r\n      button.style.display = 'none';\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n  scrollToBottom() {\r\n    let counter = 0;\r\n    const interval = setInterval(() => {\r\n      this.chatMain.nativeElement.scrollTop = this.chatMain.nativeElement.scrollHeight;\r\n      if (counter++ > 5) clearInterval(interval);\r\n    }, 5);\r\n  }\r\n\r\n  handleAction(action: any) {\r\n    console.info('incoming action from the chatbot AI');\r\n    console.info(action);\r\n\r\n    if (action?.content) {\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    // Check if the drawer is initially open and apply overflow hidden to body if so\r\n    if (this.drawer.opened) {\r\n      this.setBodyOverflow();\r\n    }\r\n\r\n    // Listen to changes in the drawer being opened or closed\r\n    this.drawer.openedChange.subscribe((opened: boolean) => {\r\n      if (opened) {\r\n        this.setBodyOverflow();\r\n      } else {\r\n        this.removeBodyOverflow();\r\n      }\r\n    });\r\n\r\n    this.drawer.openedChange.subscribe((opened) => {\r\n      if (opened) {\r\n        setTimeout(() => {\r\n          if (this.myTextarea && this.myTextarea.nativeElement) {\r\n            this.myTextarea.nativeElement.focus(); // Focus on the textarea\r\n          }\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n  private setBodyOverflow() {\r\n    this.renderer.addClass(document.body, this.bodyOverflowClass);\r\n  }\r\n\r\n  private removeBodyOverflow() {\r\n    this.renderer.removeClass(document.body, this.bodyOverflowClass);\r\n  }\r\n\r\n  getSpeakersByStaffIds(ids) {\r\n    const url = `${this.environment.USERS_API}/events/${this.eventId}/users/get-by-staff-ids`;\r\n    fetch(url, {\r\n      method: 'POST',\r\n      headers: {\r\n        'Content-Type': 'application/json',\r\n        Authorization: 'Bearer ' + 'your_token_here',\r\n      },\r\n      body: JSON.stringify(ids),\r\n    })\r\n      .then((response) => {\r\n        if (response.ok) {\r\n          return response.json(); // Parse the JSON body of the response\r\n        } else {\r\n          throw new Error('Network response was not ok.');\r\n        }\r\n      })\r\n      .then((data) => {\r\n        if (data?.length > 0) {\r\n          data.forEach((speaker) => {\r\n            this.speakers[speaker.id] = speaker;\r\n          });\r\n\r\n          this.cdr.markForCheck();\r\n        }\r\n      })\r\n      .catch((err) => {\r\n        console.error('Error fetching data:', err);\r\n        this.loading = false;\r\n      });\r\n  }\r\n\r\n  performSessionAction(sessionId, action) {\r\n    this.sessionActions.next({\r\n      sessionId,\r\n      action,\r\n    });\r\n  }\r\n\r\n  addCloseBotClickEvent() {\r\n    const element = this.elementRef.nativeElement.querySelector('#closeBotNow');\r\n    if (element) {\r\n      this.renderer.listen(element, 'click', () => {\r\n        this.closeBot.next();\r\n      });\r\n    }\r\n  }\r\n\r\n  isMobileBrowser() {\r\n    return /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(\r\n      navigator.userAgent\r\n    );\r\n  }\r\n\r\n  connectToUser(userId) {\r\n    this.connectWithUser.emit({\r\n      connect: !this.canDisconnect(userId),\r\n      userId,\r\n    });\r\n\r\n    setTimeout(() => {\r\n      this.fetchMyConnections().subscribe((res) => {\r\n        this.cdr.markForCheck();\r\n      });\r\n      this.fetchPendingRequests().subscribe((res) => {\r\n        this.cdr.markForCheck();\r\n      });\r\n    }, 500);\r\n  }\r\n\r\n  scheduleMeetingWithUser(user) {\r\n    this.scheduleMeeting.emit(user);\r\n  }\r\n\r\n  canConnect(userId) {\r\n    return !(\r\n      this.canDisconnect(userId) ||\r\n      this.pendingRequests.find((a) => a == userId)\r\n    );\r\n  }\r\n\r\n  canDisconnect(userId) {\r\n    return this.myConnections.find((conn) => conn.userId == userId);\r\n  }\r\n\r\n  fetchPendingRequests() {\r\n    const headers = new HttpHeaders({\r\n      'Content-Type': 'application/json',\r\n      apiKey: this.autogenKey,\r\n    });\r\n    return this.http\r\n      .get(\r\n        `${this.environment.USERS_API}/events/${this.eventId}/connection-requests/autogen/pending-sent-requests?userId=${this.userId}`,\r\n        { headers }\r\n      )\r\n      .pipe(\r\n        switchMap((res: any) => {\r\n          this.pendingRequests = res;\r\n          this.cdr.markForCheck();\r\n          return of(res);\r\n        }),\r\n        catchError((error: any) => {\r\n          console.error('Error fetching pending requests: ', error);\r\n          return of(null);\r\n        })\r\n      );\r\n  }\r\n\r\n  fetchMyConnections() {\r\n    const headers = new HttpHeaders({\r\n      'Content-Type': 'application/json',\r\n      apiKey: this.autogenKey,\r\n    });\r\n    return this.http\r\n      .get(\r\n        `${this.environment.USERS_API}/events/${this.eventId}/users-connections/autogen?userId=${this.userId}`,\r\n        { headers }\r\n      )\r\n      .pipe(\r\n        switchMap((res: any) => {\r\n          this.myConnections = res;\r\n          this.cdr.markForCheck();\r\n          return of(res);\r\n        }),\r\n        catchError((error: any) => {\r\n          console.error('Error fetching pending requests: ', error);\r\n          return of(null);\r\n        })\r\n      );\r\n  }\r\n\r\n  isDropdownOpen: boolean = false;\r\n  agents: any;\r\n  selectedAgents = [];\r\n  allSelected = false;\r\n  // Toggle the dropdown visibility\r\n  toggleDropdown() {\r\n    this.isDropdownOpen = !this.isDropdownOpen;\r\n  }\r\n\r\n  onSelectAll(event: Event): void {\r\n    this.agents?.forEach((agent) => (agent.selected = false));\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  onAgentChange(agent: any): void {\r\n    //agent.selected = !agent.selected;\r\n    //console.log(agent);\r\n    let agentFound = this.agents.filter((p) => p.id == agent.id);\r\n    if (agentFound && agentFound.length > 0) {\r\n      agentFound[0].selected = !agentFound[0].selected;\r\n      this.cdr.detectChanges();\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  areAllSelected(): boolean {\r\n    return this.agents?.every((agent) => !agent.selected);\r\n  }\r\n\r\n  getDropdownHeaderText(): string {\r\n    const selectedAgents = this.agents?.filter((agent) => agent.selected);\r\n    if (selectedAgents && selectedAgents?.length === 0) {\r\n      return 'All Agents';\r\n    } else {\r\n      return selectedAgents?.length > 1\r\n        ? `${selectedAgents?.length} Agents Selected`\r\n        : `${selectedAgents?.length} Agent Selected`;\r\n    }\r\n  }\r\n  fetchAgents_http() {\r\n    this.loading = true;\r\n    const url = `${this.environment.AGENTS_API}/CoPilot/${this.botId}/active-agents`;\r\n    const headers = new HttpHeaders({\r\n      'Content-Type': 'application/json',\r\n    });\r\n\r\n    return this.http.post(url, {}, { headers }).pipe(\r\n      switchMap((res: any) => {\r\n        if (res) {\r\n          this.agents = res.map((agent) => ({\r\n            ...agent,\r\n            selected: false,\r\n          }));\r\n        }\r\n        this.cdr.markForCheck();\r\n\r\n        return of(res);\r\n      }),\r\n      catchError((error) => {\r\n        console.error('Error fetching chatbot config: ', error);\r\n\r\n        return of(null);\r\n      })\r\n    );\r\n  }\r\n  isDocInEditMode = false;\r\n  documentContent: any;\r\n\r\n  conversationId: any;\r\n  isContentLoaded = false;\r\n\r\n  fetchContent_http() {\r\n    this.isDocInEditMode = false;\r\n    this.isContentLoaded = false;\r\n    console.log('API call function');\r\n    this.loading = true;\r\n    const conversation_id = this.conversationService.getKey(this.botId);\r\n    this.conversationId = conversation_id;\r\n    const url = `${this.environment.AGENTS_API}/ConversationDocuments?conversationId=${conversation_id}&botId=${this.botId}`;\r\n    const headers = new HttpHeaders({\r\n      'Content-Type': 'application/json',\r\n      apiKey: 'WIz/qAm+EEmfOkFaUA/weA==',\r\n    });\r\n\r\n    return this.http.get(url, { headers }).pipe(\r\n      switchMap((res: any) => {\r\n        if (res) {\r\n          this.isDocInEditMode = true;\r\n          this.documentContent = res;\r\n          console.log('Get API callled success');\r\n          this.isContentLoaded = true;\r\n          console.log(res);\r\n        }\r\n        this.cdr.markForCheck();\r\n\r\n        return of(res);\r\n      }),\r\n      catchError((error) => {\r\n        console.error('Error fetching chatbot config DJ: ', error);\r\n        this.isDocInEditMode = false;\r\n        this.isContentLoaded = true;\r\n\r\n        if (error?.status == 404) {\r\n          console.log('dash');\r\n          this.isDocInEditMode = false;\r\n          this.isContentLoaded = true;\r\n        }\r\n        return of(null);\r\n      })\r\n    );\r\n  }\r\n\r\n  fetchAgents() {\r\n    this.fetchAgents_http().subscribe();\r\n  }\r\n\r\n  fetchEditorContent() {\r\n    this.fetchContent_http().subscribe();\r\n  }\r\n\r\n  // events/${eventId}/users-connections\r\n  processMessageForDisplay(markdown: string): SafeHtml {\r\n    var html = this.prepareHtml(markdown);\r\n\r\n    //  console.log('After line breaks conversion:', html);\r\n\r\n    // Optional: Sanitize the HTML to prevent XSS\r\n    const sanitizedHtml = this.sanitizeHtml(html);\r\n\r\n    // console.log('Sanitized HTML:', sanitizedHtml);\r\n\r\n    return sanitizedHtml;\r\n  }\r\n\r\n  prepareHtml(markdown: string): string {\r\n    if (!markdown || !(markdown.length > 0)) {\r\n      console.error('Input Markdown is null or empty');\r\n      return '';\r\n    }\r\n\r\n    // Convert Markdown headers (### or ##) to <strong> for bold headings\r\n    let html = markdown.replace(/^(#{1,6})\\s+(.*)$/gm, (match, hashes, text) => {\r\n      const level = hashes.length;\r\n      if (level === 3) {\r\n        return `<h3><strong>${text}</strong></h3>`;\r\n      } else if (level === 4) {\r\n        return `<h4><strong>${text}</strong></h4>`;\r\n      }\r\n      return `<strong>${text}</strong>`;\r\n    });\r\n\r\n    // Convert Markdown code blocks with language to preformatted HTML\r\n    html = html.replace(/```(\\w+)?\\n([\\s\\S]*?)```/g, (match, lang, code) => {\r\n      const escapedCode = this.escapeHtml(code);\r\n      const language = lang || 'plaintext';\r\n\r\n      // Create a copy button for the code block\r\n      return `\r\n      <div class=\"code-container\">\r\n        <button id=\"copy-button\" class=\"copy-button\" (click)=\"copyToClipboard('\\`${escapedCode}\\`')\">Copy</button>\r\n        <pre class=\"code_block diff\"><code class=\"language-${language}\">${escapedCode}</code></pre>\r\n      </div>`;\r\n    });\r\n\r\n    // Convert inline code (wrapped in `backticks`) to inline <code> tags\r\n    html = html.replace(/`([^`]+)`/g, '<code>$1</code>');\r\n\r\n    // Convert Markdown bold to HTML <strong>\r\n    html = html.replace(/\\*\\*(.*?)\\*\\*/g, '<strong>$1</strong>');\r\n\r\n    // Convert numbered lists\r\n    html = html.replace(/^\\d+\\.\\s+(.*)$/gm, '<li>$1</li>');\r\n\r\n    // Convert bullet point lists\r\n    html = html.replace(/^\\-\\s+(.*)$/gm, '<li>$1</li>');\r\n\r\n    // Convert Markdown links to HTML links\r\n    html = html.replace(/\\[([^\\]]+)]\\(([^)]+)\\)/g, '<a href=\"$2\" target=\"_blank\">$1</a>');\r\n\r\n    // Convert new lines to <br> tags for paragraphs\r\n    html = html.replace(/(?:\\r\\n|\\r|\\n)/g, '<br>');\r\n\r\n    return html;\r\n  }\r\n\r\n  // Helper function to escape HTML characters for code blocks\r\n  escapeHtml(code: string): string {\r\n    return code\r\n      .replace(/&/g, '&amp;')\r\n      .replace(/</g, '&lt;')\r\n      .replace(/>/g, '&gt;')\r\n      .replace(/\"/g, '&quot;')\r\n      .replace(/'/g, '&#039;');\r\n  }\r\n\r\n  // Function to copy text to clipboard\r\n  public copyToClipboard(text: string) {\r\n    navigator.clipboard.writeText(text).then(() => {\r\n      alert('Code copied to clipboard!');\r\n    }, (err) => {\r\n      console.error('Could not copy text: ', err);\r\n    });\r\n  }\r\n\r\n\r\n\r\n\r\n\r\n\r\n  isCollapsed = false;\r\n  isCollapsedForGraph = false;\r\n  isCollapsedForFGraph = false;\r\n  toggleCollapse() {\r\n    this.isCollapsed = !this.isCollapsed;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  toggleCollapseGraph() {\r\n    this.isCollapsedForGraph = !this.isCollapsedForGraph;\r\n    this.cdr.detectChanges();\r\n  }\r\n  toggleCollapseFGraph() {\r\n    this.isCollapsedForFGraph = !this.isCollapsedForFGraph;\r\n    this.cdr.detectChanges();\r\n  }\r\n  //   [\r\n  //   {\r\n  //     \"title\": \"AI News January 2024: In-Depth and Concise - The AI Track\",\r\n  //     \"desc\": \"Each month, we compile significant news, trends, and happenings in AI, providing detailed summaries with key points in bullet form for concise yet complete understanding.\",\r\n  //     \"link\": \"https://theaitrack.com/ai-news-january-2024/\"\r\n  //   },\r\n  //   {\r\n  //     \"title\": \"Top AI News, January 2024 - Everypixel Journal\",\r\n  //     \"desc\": \"In this monthly roundup, we spotlight the top AI news stories from January, including the OpenAI vs. The New York Times Lawsuit.\",\r\n  //     \"link\": \"https://journal.everypixel.com/top-ai-news-january-2024\"\r\n  //   },\r\n  //   {\r\n  //     \"title\": \"AI News July 2024: In-Depth and Concise - The AI Track\",\r\n  //     \"desc\": \"This page features AI News for July 2024, highlighting significant events such as Canva acquiring Leonardo AI.\",\r\n  //     \"link\": \"https://theaitrack.com/ai-news-july-2024-in-depth-and-concise/\"\r\n  //   },\r\n  //   {\r\n  //     \"title\": \"January news roundup: What's new in the world of AI? - Pluralsight\",\r\n  //     \"desc\": \"OpenAI’s new GPT store, business-ready ChatGPT plans, and a predicted rise in AI-powered cybercrime.\",\r\n  //     \"link\": \"https://www.pluralsight.com/resources/blog/data/ai-this-month-january-2024\"\r\n  //   },\r\n  //   {\r\n  //     \"title\": \"AI News August 2024: In-Depth and Concise - The AI Track\",\r\n  //     \"desc\": \"This page features AI News for August 2024, with highlights such as Nvidia delaying the “Blackwell” B200 AI chips delivery.\",\r\n  //     \"link\": \"https://theaitrack.com/ai-news-august-2024-in-depth-and-concise-duplicate/\"\r\n  //   }\r\n  // ]\r\n  dateTime = { now: new Date().toISOString() };\r\n  // Extracts the domain from a URL\r\n  getDomainName(url: string): string {\r\n    try {\r\n      const { hostname } = new URL(url);\r\n      return hostname.replace(/^www\\./, ''); // Remove 'www.' if present\r\n    } catch {\r\n      return 'unknown';\r\n    }\r\n  }\r\n\r\n  // Generates the favicon URL\r\n  getFaviconUrl(url: string): string {\r\n    const domain = this.getDomainName(url);\r\n    return `https://www.google.com/s2/favicons?sz=128&domain=${domain}`;\r\n  }\r\n  currentSourcesList: any = [];\r\n  onCardClick(sources): void {\r\n    this.currentSourcesList = sources;\r\n    this.cdr.detectChanges();\r\n    this.sourcesDrawer.open();\r\n    const button = document.getElementById('botcloseplaygroundbutton');\r\n    if (button) {\r\n      button.style.display = 'none';\r\n    }\r\n  }\r\n\r\n  isShowEditorButton = true;\r\n\r\n  openOuterEditor() {\r\n    this.fetchEditorContent();\r\n    this.editorsDrawer.open();\r\n    this.isDrawerOpen = true;\r\n    this.isShowEditorButton = false;\r\n    this.cdr.detectChanges();\r\n\r\n    const button = document.getElementById('botcloseplaygroundbutton');\r\n    if (button) {\r\n      button.style.display = 'none';\r\n    }\r\n  }\r\n\r\n  onCloseEditor() {\r\n    this.editorsDrawer.close();\r\n    this.isDrawerOpen = false;\r\n    this.isShowEditorButton = true;\r\n    this.cdr.detectChanges(); // Trigger change detection if needed\r\n    this.onDrawerClosed();\r\n  }\r\n\r\n  onCloseSource() {\r\n    this.sourcesDrawer.close();\r\n    this.isDrawerOpen = false;\r\n    this.cdr.detectChanges(); // Trigger change detection if needed\r\n    this.onDrawerClosed();\r\n  }\r\n  onDrawerClosed() {\r\n    setTimeout(() => {\r\n      this.isDrawerOpen = true;\r\n      this.cdr.detectChanges(); // Trigger change detection if needed\r\n      // Use ngClass to dynamically apply the class\r\n      const button = document.getElementById('botcloseplaygroundbutton');\r\n      if (button) {\r\n        button.style.display = 'block';\r\n      }\r\n    }, 800);\r\n  }\r\n  isDrawerOpen = true;\r\n\r\n  toggleDrawer(todo) {\r\n    this.isDrawerOpen = todo;\r\n    this.cdr.detectChanges();\r\n    this.updateButtonVisibility();\r\n  }\r\n  updateButtonVisibility() {\r\n    const button = document.getElementById('botcloseplaygroundbutton');\r\n    if (button) {\r\n      button.style.display = this.isDrawerOpen ? 'block' : 'none';\r\n    }\r\n  }\r\n  openLinkInNewTab(link: string): void {\r\n    window.open(link, '_blank');\r\n  }\r\n  adjustTextareaHeight(event: any): void {\r\n    try {\r\n      if (event.key === 'Enter' && !event.shiftKey) {\r\n        // Prevents a new line from being added\r\n        event.preventDefault();\r\n      }\r\n    } catch (error) {\r\n\r\n    }\r\n    const textarea = event.target as HTMLTextAreaElement;\r\n    textarea.style.height = 'auto'; // Reset the height\r\n    textarea.style.height = `${textarea.scrollHeight}px`; // Adjust height to match content\r\n    // Ensure the height doesn't exceed the max-height set in CSS\r\n    if (textarea.scrollHeight > 150) {\r\n      textarea.style.height = `150px`; // Adjust height to match content\r\n      textarea.style.overflowY = 'auto'; // Enable scrolling if content exceeds 400px\r\n    } else {\r\n      textarea.style.overflowY = 'hidden'; // Hide scrollbar if content is within limits\r\n    }\r\n  }\r\n\r\n  toggleWorkflows(value = null) {\r\n    this.isWorkflowOpen = value == null ? !this.isWorkflowOpen : value;\r\n\r\n    if (!this.isWorkflowOpen) {\r\n      this.selectedWorkflow = null;\r\n      this.openWorkflowInput = false;\r\n    }\r\n\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  initializeForm() {\r\n    // Create form controls dynamically based on selectedWorkflow.Trigger.InputSchema\r\n    const formControls = {};\r\n    if (this.selectedWorkflow?.Trigger?.InputSchema) {\r\n      this.selectedWorkflow.Trigger.InputSchema.forEach((input) => {\r\n        formControls[input.InputId] = [\r\n          input.Value || '',\r\n          input.Required ? Validators.required : null,\r\n        ];\r\n      });\r\n    }\r\n\r\n    // Initialize the form\r\n    this.workflowForm = this.fb.group(formControls);\r\n  }\r\n\r\n  onWorkflowSelected(workflow) {\r\n    this.selectedWorkflow = workflow;\r\n    this.initializeForm();\r\n    this.isWorkflowOpen = false;\r\n    this.openWorkflowInput = true;\r\n  }\r\n\r\n  onWorkflowSubmit() {\r\n    const container = document.getElementById('allChats');\r\n    if (this.workflowForm.valid) {\r\n      console.log(this.workflowForm.value);\r\n\r\n      var input = this.prepareHtml(\r\n        this.generateMarkdown(\r\n          this.selectedWorkflow.Name,\r\n          this.workflowForm.value\r\n        )\r\n      );\r\n\r\n      // update last two chatLog entries, set showWorkflowExecutionLoader = false\r\n      try {\r\n        this.chatLog[this.chatLog.length - 1][\r\n          'showWorkflowExecutionLoader'\r\n        ] = false;\r\n        this.chatLog[this.chatLog.length - 2][\r\n          'showWorkflowExecutionLoader'\r\n        ] = false;\r\n      } catch (error) { }\r\n\r\n      this.chatLog.push({\r\n        type: 'user',\r\n        message: input,\r\n        time: formatNow(this.timezone),\r\n        copied: false,\r\n        isCollapsedTrue: false,\r\n        showWorkflowExecutionLoader: true,\r\n      });\r\n\r\n      console.log(input);\r\n\r\n      this.currentWorkflowActionProgress = 0;\r\n      this.currentWorkflowAction =\r\n        'Executing ' + this.selectedWorkflow.Actions[0].Name;\r\n      this.isChatingWithAi = true;\r\n      this.executingWorkflow = true;\r\n      this.workflowExecutionDetails = {\r\n        Actions: this.selectedWorkflow.Actions,\r\n        Inputs: this.workflowForm.value,\r\n        workflowInputs: this.workflowForm.value,\r\n        WorkflowName: this.selectedWorkflow.Name,\r\n      };\r\n      this.currentWorkflowExecutionDetails = this.workflowExecutionDetails;\r\n      this.scrollToBottom();\r\n\r\n      this.cdr.detectChanges();\r\n\r\n      // execute the ask endpoint with workflow input\r\n      this.makeAskRequest(\r\n        input,\r\n        this.agents,\r\n        this.conversationKey,\r\n        '',\r\n        null,\r\n        this.selectedWorkflow['_id'],\r\n        this.workflowForm.value\r\n      );\r\n    }\r\n  }\r\n\r\n  makeAskRequest(\r\n    inputMsg: string,\r\n    agents: any[],\r\n    conversationId: string,\r\n    msg?: any,\r\n    chat?: any,\r\n    workflowId?: string,\r\n    workflow_inputs?: any\r\n  ): void {\r\n    var url = `${this.environment.BASE_URL}/ai/ask`;\r\n\r\n    var body = {\r\n      user_question: inputMsg,\r\n      user_id: this.userId,\r\n      bot_id: this.botId,\r\n      message_id: this.conversationService.generateKey(),\r\n      agents: agents.filter((p) => p.selected).map((p) => p.id),\r\n      conversation_id: conversationId,\r\n    };\r\n\r\n    if (workflowId) {\r\n      body['workflow_id'] = workflowId;\r\n      body['workflow_inputs'] = workflow_inputs;\r\n    }\r\n\r\n    fetch(url, {\r\n      method: 'POST',\r\n      headers: {\r\n        'Content-Type': 'application/json',\r\n        Authorization: 'Bearer ' + this.s27Token,\r\n        'x-api-key': this.apiKey,\r\n      },\r\n      body: JSON.stringify(body),\r\n    })\r\n      .then((response) => {\r\n        if (response.status === 401 || response.status === 403) {\r\n          this.is401 = true;\r\n          this.refreshToken.emit();\r\n\r\n          // If `msg` and `chat` exist, handle them\r\n          if (msg && chat) {\r\n            this.msg = msg;\r\n            this.chat = chat;\r\n            this.isFetchDataFor = true;\r\n          }\r\n        } else {\r\n          this.is401 = false;\r\n        }\r\n        return response.json();\r\n      })\r\n      .then((data) => {\r\n        console.log(data);\r\n        // Additional response handling if needed\r\n      })\r\n      .catch((err) => {\r\n        console.error('Error: ', err);\r\n        this.isChatingWithAi = false;\r\n      });\r\n\r\n    this.input = '';\r\n    this.selectedWorkflow = null;\r\n    this.openWorkflowInput = false;\r\n    this.isWorkflowOpen = false;\r\n    this.scrollToBottom();\r\n    this.cdr.markForCheck();\r\n  }\r\n\r\n  generateMarkdown(title, obj) {\r\n    // Initialize markdown with the title\r\n    let markdown = `## ${title}\\n`;\r\n\r\n    // Loop through the object and append the field names and values\r\n    for (const [key, value] of Object.entries(obj)) {\r\n      var key_label =\r\n        this.selectedWorkflow.Trigger.InputSchema.find(\r\n          (input) => input.InputId === key\r\n        )?.Label || key;\r\n      markdown += `- **${key_label}**: ${value}\\n`;\r\n    }\r\n\r\n    return markdown;\r\n  }\r\n\r\n  showWorkflowHistoryDetails(workflow_id) {\r\n    if (!workflow_id) {\r\n      this.workflowExecutionDetails = this.currentWorkflowExecutionDetails;\r\n      this.showWorkflowExecutionDetails = true;\r\n      this.cdr.detectChanges();\r\n      return;\r\n    }\r\n\r\n    this.botService.getWorkflowExecutionById(workflow_id).subscribe((res) => {\r\n      if (res && res.Actions && Array.isArray(res.Actions)) {\r\n        res.Actions = res.Actions.map((action) => {\r\n          if (action.InsertTimeStamp) {\r\n            action.InsertTimeStamp = formatTimeStamps(\r\n              this.timezone,\r\n              action.InsertTimeStamp\r\n            );\r\n          }\r\n          return action;\r\n        });\r\n      }\r\n\r\n      res.InsertTimeStamp = formatTimeStamps(\r\n        this.timezone,\r\n        res.InsertTimeStamp\r\n      );\r\n      this.workflowExecutionDetails = res;\r\n      this.showWorkflowExecutionDetails = true;\r\n      this.cdr.detectChanges();\r\n    });\r\n  }\r\n\r\n  closeModal() {\r\n    this.showWorkflowExecutionDetails = false;\r\n  }\r\n\r\n  objectToArray(obj: any): any[] {\r\n    return Object.keys(obj).map((key) => ({ key, value: obj[key] }));\r\n  }\r\n\r\n  startNewConversation() {\r\n    this.conversationKey = this.conversationService.getKey(this.botId, true);\r\n    this.chatLog = [this.chatLog[0]];\r\n    this.isChatingWithAi = false;\r\n    setTimeout(() => {\r\n      this.initializeSocket();\r\n    }, 200);\r\n    this.scrollToBottom();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  initializeSpeechRecognizer(token: string) {\r\n    this.speechConfig = SpeechSDK.SpeechConfig.fromAuthorizationToken(\r\n      token,\r\n      this.region\r\n    );\r\n    const audioConfig = SpeechSDK.AudioConfig.fromDefaultMicrophoneInput();\r\n    this.recognizer = new SpeechSDK.SpeechRecognizer(\r\n      this.speechConfig,\r\n      audioConfig\r\n    );\r\n\r\n    this.recognizer.recognizing = (s, e) => {\r\n      if (e.result.reason === SpeechSDK.ResultReason.RecognizingSpeech) {\r\n        this.input = e.result.text;\r\n        console.log(`Recognizing: ${e.result.text}`);\r\n        this.cdr.markForCheck();\r\n      }\r\n    };\r\n\r\n    this.recognizer.recognized = (s, e) => {\r\n      if (e.result.reason === SpeechSDK.ResultReason.RecognizedSpeech) {\r\n        this.input = e.result.text;\r\n        console.log(`Recognized: ${e.result.text}`);\r\n        this.toggleRecording();\r\n        this.cdr.markForCheck();\r\n      }\r\n    };\r\n\r\n    this.recognizer.canceled = (s, e) => {\r\n      console.error('Canceled: ', e.errorDetails);\r\n    };\r\n\r\n    this.recognizer.sessionStopped = (s, e) => {\r\n      console.log('Session stopped.');\r\n      this.recognizer.stopContinuousRecognitionAsync();\r\n      this.fetchData();\r\n    };\r\n  }\r\n\r\n  toggleRecording() {\r\n    this.isRecording = !this.isRecording;\r\n\r\n    if (this.isRecording) {\r\n      this.startRecognition();\r\n    } else {\r\n      this.stopRecognition();\r\n    }\r\n  }\r\n\r\n  startRecognition() {\r\n    this.recognizer.startContinuousRecognitionAsync();\r\n  }\r\n\r\n  stopRecognition() {\r\n    this.recognizer.stopContinuousRecognitionAsync();\r\n  }\r\n\r\n  checkForCop29BotId() {\r\n    return this.botId == '66fa3f276c5d71e2717bfea8';\r\n  }\r\n}\r\n"]}
1
+ // import { Platform } from '@angular/cdk/platform';
2
+ import { HttpClient, HttpHeaders } from '@angular/common/http';
3
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Output, Renderer2, ViewChild, ViewChildren, } from '@angular/core';
4
+ import { DomSanitizer } from '@angular/platform-browser';
5
+ import { of } from 'rxjs';
6
+ import { catchError, switchMap } from 'rxjs/operators';
7
+ import { formatNow, formatTimeStamps } from '../../utils/utils';
8
+ import { dev_environment, prod_environment, } from '../../../environments/environment';
9
+ import { ConversationService } from '../conversation.service';
10
+ import { SocketService } from '../socket-service.service';
11
+ import { FormBuilder, Validators } from '@angular/forms';
12
+ import * as SpeechSDK from 'microsoft-cognitiveservices-speech-sdk';
13
+ import { BotsService } from '../bot.service';
14
+ export class ChatDrawerComponent {
15
+ constructor(fb, botService, cdr, http, sanitizer, elementRef, renderer, socketService, conversationService // private platform: Platform
16
+ ) {
17
+ this.fb = fb;
18
+ this.botService = botService;
19
+ this.cdr = cdr;
20
+ this.http = http;
21
+ this.sanitizer = sanitizer;
22
+ this.elementRef = elementRef;
23
+ this.renderer = renderer;
24
+ this.socketService = socketService;
25
+ this.conversationService = conversationService;
26
+ this.bodyOverflowClass = 'body-overflow-hidden';
27
+ this.isCollapsedTrue = false;
28
+ this.copilotName = 'HiveXGPT';
29
+ this.feedbackEvent = new EventEmitter();
30
+ this.onCloseEvent = new EventEmitter();
31
+ this.openPage = new EventEmitter();
32
+ this.sessionActions = new EventEmitter();
33
+ this.closeBot = new EventEmitter();
34
+ this.connectWithUser = new EventEmitter();
35
+ this.scheduleMeeting = new EventEmitter();
36
+ this.refreshToken = new EventEmitter();
37
+ this.autogenKey = 'Autogen_eDJTtEU-NB0RtIpzq1w';
38
+ this.addToMyAgendaAction = 'add_to_my_agenda';
39
+ this.myUpcomingSessionAction = 'my_upcomming_session';
40
+ this.connectOrFollowAction = 'connect_or_follow';
41
+ this.aiResponse = '';
42
+ this.chatLog = [];
43
+ this.decoder = new TextDecoder();
44
+ this.feedbackDone = false;
45
+ this.greetingMsg = '';
46
+ this.hasBackdropValue = false;
47
+ this.input = '';
48
+ this.listenerAdded = false;
49
+ this.loading = false;
50
+ this.mode = 'over';
51
+ this.quickPrompts = [];
52
+ this.thumbsDownMsgIndex = 0;
53
+ this.userName = '';
54
+ this.showStartAgain = false;
55
+ this.isIOSDevice = false;
56
+ this.showFeedBackIconsIndex = null;
57
+ this.temperature = 1;
58
+ this.speakers = [];
59
+ this.currentWorkflowActionProgress = 0;
60
+ this.currentWorkflowAction = '';
61
+ this.recognizedText = '';
62
+ this.authorizationToken = '';
63
+ this.region = 'westeurope'; // Set your Azure region here
64
+ this.isChatingWithAi = false;
65
+ this.readAllChunks = (stream) => {
66
+ const reader = stream.getReader();
67
+ const allSuggestions = [];
68
+ reader.closed.catch((err) => {
69
+ if (err) {
70
+ console.error('Error reading stream: ', err);
71
+ }
72
+ this.isChatingWithAi = false;
73
+ this.scrollToBottom();
74
+ return;
75
+ });
76
+ return new ReadableStream({
77
+ start: (controller) => {
78
+ return this.pump(controller, reader, allSuggestions);
79
+ },
80
+ });
81
+ };
82
+ this.currentMessageForEditor = '';
83
+ this.currentIndexForEditor = -1;
84
+ this.isDropdownOpen = false;
85
+ this.selectedAgents = [];
86
+ this.allSelected = false;
87
+ this.isDocInEditMode = false;
88
+ this.isContentLoaded = false;
89
+ this.isCollapsed = false;
90
+ this.isCollapsedForGraph = false;
91
+ this.isCollapsedForFGraph = false;
92
+ // [
93
+ // {
94
+ // "title": "AI News January 2024: In-Depth and Concise - The AI Track",
95
+ // "desc": "Each month, we compile significant news, trends, and happenings in AI, providing detailed summaries with key points in bullet form for concise yet complete understanding.",
96
+ // "link": "https://theaitrack.com/ai-news-january-2024/"
97
+ // },
98
+ // {
99
+ // "title": "Top AI News, January 2024 - Everypixel Journal",
100
+ // "desc": "In this monthly roundup, we spotlight the top AI news stories from January, including the OpenAI vs. The New York Times Lawsuit.",
101
+ // "link": "https://journal.everypixel.com/top-ai-news-january-2024"
102
+ // },
103
+ // {
104
+ // "title": "AI News July 2024: In-Depth and Concise - The AI Track",
105
+ // "desc": "This page features AI News for July 2024, highlighting significant events such as Canva acquiring Leonardo AI.",
106
+ // "link": "https://theaitrack.com/ai-news-july-2024-in-depth-and-concise/"
107
+ // },
108
+ // {
109
+ // "title": "January news roundup: What's new in the world of AI? - Pluralsight",
110
+ // "desc": "OpenAI’s new GPT store, business-ready ChatGPT plans, and a predicted rise in AI-powered cybercrime.",
111
+ // "link": "https://www.pluralsight.com/resources/blog/data/ai-this-month-january-2024"
112
+ // },
113
+ // {
114
+ // "title": "AI News August 2024: In-Depth and Concise - The AI Track",
115
+ // "desc": "This page features AI News for August 2024, with highlights such as Nvidia delaying the “Blackwell” B200 AI chips delivery.",
116
+ // "link": "https://theaitrack.com/ai-news-august-2024-in-depth-and-concise-duplicate/"
117
+ // }
118
+ // ]
119
+ this.dateTime = { now: new Date().toISOString() };
120
+ this.currentSourcesList = [];
121
+ this.isShowEditorButton = true;
122
+ this.isDrawerOpen = true;
123
+ this.chatMain = new ElementRef(null);
124
+ // if (this.platform.IOS) {
125
+ // this.isIOSDevice = true;
126
+ // }
127
+ }
128
+ ngOnChanges(changes) {
129
+ if (changes.s27Token) {
130
+ if (changes.s27Token.currentValue != changes.s27Token.previousValue) {
131
+ this.s27Token = changes.s27Token.currentValue;
132
+ console.log('isFetchDataFor: ', this.isFetchDataFor);
133
+ console.log('msg: ', this.msg);
134
+ console.log('chat: ', this.chat);
135
+ if (this.is401) {
136
+ if (this.isFetchDataFor) {
137
+ this.fetchDataFor(this.msg, this.chat);
138
+ }
139
+ else {
140
+ this.fetchData(this.msg);
141
+ }
142
+ }
143
+ }
144
+ }
145
+ if (changes.orgId) {
146
+ if (changes.orgId.currentValue != changes.orgId.previousValue &&
147
+ changes.orgId.currentValue) {
148
+ this.initializeSocket();
149
+ }
150
+ }
151
+ }
152
+ ngOnInit() {
153
+ this.environment = this.isDev ? dev_environment : prod_environment;
154
+ // this.fetchMyConnections().subscribe();
155
+ // this.fetchPendingRequests().subscribe();
156
+ this.changeTemperature(this.temperature);
157
+ this.fetchBotConfig().subscribe((res) => {
158
+ this.cdr.markForCheck();
159
+ this.fetchChatHistory().subscribe((response) => {
160
+ this.loading = false;
161
+ this.mapChatHistory(response);
162
+ this.cdr.markForCheck();
163
+ }, (err) => {
164
+ console.error('Error fetching chat history:', err);
165
+ });
166
+ }, (err) => {
167
+ console.error('Error fetching chat history:', err);
168
+ });
169
+ // this.fetchAgents();
170
+ // this.fetchEditorContent();
171
+ this.cdr.markForCheck();
172
+ // this.initializeSocket();
173
+ if (!this.checkForCop29BotId()) {
174
+ this.botService.fetchSpeechAuthorizationToken().subscribe((token) => {
175
+ this.authorizationToken = token;
176
+ this.initializeSpeechRecognizer(token);
177
+ });
178
+ }
179
+ }
180
+ initializeSocket() {
181
+ try {
182
+ this.socketService.disconnectSocketConnection();
183
+ }
184
+ catch (error) { }
185
+ setTimeout(() => {
186
+ this.socketService.connectSocketConnection();
187
+ setTimeout(() => {
188
+ console.log('YES INIT');
189
+ const conversation_id = this.conversationService.getKey(this.botId);
190
+ this.socketService.registerUserSpecificHiveSocket(this.botId, conversation_id, this.orgId);
191
+ setTimeout(() => {
192
+ this.listenSockets();
193
+ }, 300);
194
+ }, 200);
195
+ }, 300);
196
+ }
197
+ listenSockets() {
198
+ if (this.eventSubscription) {
199
+ this.eventSubscription.unsubscribe();
200
+ }
201
+ console.log('Listen Socket');
202
+ this.eventSubscription = this.conversationService
203
+ .getUserSpecificNotification()
204
+ .subscribe((res) => {
205
+ var _a, _b, _c, _d, _e, _f;
206
+ console.log('Listen Socket response');
207
+ console.log(res);
208
+ // Check if OtherFields exists in the response
209
+ if ((_b = (_a = res === null || res === void 0 ? void 0 : res.m) === null || _a === void 0 ? void 0 : _a.OtherFields) === null || _b === void 0 ? void 0 : _b.workflow_id) {
210
+ const { percentage, output, action_name, current_action_name, workflow_execution_id, time_stamp, } = (_c = res === null || res === void 0 ? void 0 : res.m) === null || _c === void 0 ? void 0 : _c.OtherFields;
211
+ this.currentWorkflowActionProgress = percentage;
212
+ this.currentWorkflowAction = action_name;
213
+ const actionIndex = this.workflowExecutionDetails.Actions.findIndex((a) => a.Name == current_action_name);
214
+ if (actionIndex !== -1) {
215
+ this.workflowExecutionDetails.Actions[actionIndex]['Output'] = output;
216
+ this.workflowExecutionDetails.Actions[actionIndex]['InsertTimeStamp'] = formatTimeStamps(this.timezone, time_stamp);
217
+ }
218
+ else {
219
+ console.error(`Action with name ${action_name} not found`);
220
+ }
221
+ this.currentWorkflowExecutionDetails = this.workflowExecutionDetails;
222
+ if (this.currentWorkflowActionProgress == 100) {
223
+ this.chatLog[this.chatLog.length - 1]['WorkflowExecutionId'] = workflow_execution_id;
224
+ this.isChatingWithAi = false;
225
+ this.executingWorkflow = false;
226
+ }
227
+ this.cdr.detectChanges();
228
+ }
229
+ else if ((_d = res === null || res === void 0 ? void 0 : res.m) === null || _d === void 0 ? void 0 : _d.OtherFields) {
230
+ const { conversation_id, bot_id, message_id, answer, web_results, search_results, graphs, execution_graphs, suggestions, } = (_e = res === null || res === void 0 ? void 0 : res.m) === null || _e === void 0 ? void 0 : _e.OtherFields;
231
+ console.log('message_id1');
232
+ console.log((_f = res === null || res === void 0 ? void 0 : res.m) === null || _f === void 0 ? void 0 : _f.OtherFields);
233
+ var currentChatMessage = this.chatLog.find((p) => p._id == message_id);
234
+ console.log(this.chatLog);
235
+ if (!currentChatMessage) {
236
+ console.log('message_id2');
237
+ console.log(message_id);
238
+ currentChatMessage = {
239
+ _id: message_id,
240
+ type: 'ai',
241
+ time: formatNow(this.timezone),
242
+ };
243
+ this.chatLog.push(currentChatMessage);
244
+ this.showFeedBackIconsIndex = this.chatLog.length - 1;
245
+ console.log('message_id3');
246
+ console.log(message_id);
247
+ this.cdr.detectChanges();
248
+ }
249
+ // Handle the fields based on their presence
250
+ if (search_results && Array.isArray(search_results)) {
251
+ console.log('Online Search Terms:', search_results);
252
+ currentChatMessage.searchTerms = search_results;
253
+ this.cdr.detectChanges();
254
+ }
255
+ if (web_results && Array.isArray(web_results)) {
256
+ console.log('Web Results:', web_results);
257
+ currentChatMessage.sourcesList = web_results;
258
+ currentChatMessage.displayedSources = web_results === null || web_results === void 0 ? void 0 : web_results.slice(0, 3); // First 3 cards
259
+ currentChatMessage.remainingSources = web_results === null || web_results === void 0 ? void 0 : web_results.slice(3); // Remaining items
260
+ this.cdr.detectChanges();
261
+ }
262
+ if (answer) {
263
+ this.isChatingWithAi = false;
264
+ console.log('Answer:', answer);
265
+ currentChatMessage.message = this.processMessageForDisplay(answer);
266
+ this.cdr.detectChanges();
267
+ this.scrollToBottom();
268
+ }
269
+ if (graphs && Array.isArray(graphs)) {
270
+ console.log('Graphs:', graphs);
271
+ currentChatMessage.graphs = graphs;
272
+ this.cdr.detectChanges();
273
+ }
274
+ if (execution_graphs && Array.isArray(execution_graphs)) {
275
+ console.log('Execution Graphs:', execution_graphs);
276
+ currentChatMessage.executionGraphs = execution_graphs;
277
+ this.cdr.detectChanges();
278
+ }
279
+ if (suggestions && Array.isArray(suggestions)) {
280
+ console.log('suggestions:', suggestions);
281
+ currentChatMessage.relatedListItems = suggestions;
282
+ this.cdr.detectChanges();
283
+ // Process online search terms as needed
284
+ }
285
+ // Add any other fields and their processing here
286
+ }
287
+ else {
288
+ console.warn('OtherFields is missing in the response');
289
+ }
290
+ }, (err) => {
291
+ this.eventSubscription.unsubscribe();
292
+ console.error('Error in fetching data from socket', err);
293
+ });
294
+ }
295
+ initializeSocketAndListen() { }
296
+ handleEvent(data, type) {
297
+ switch (type) {
298
+ case 'webresult':
299
+ break;
300
+ case 'answer':
301
+ break;
302
+ case 'graph':
303
+ break;
304
+ default:
305
+ break;
306
+ }
307
+ }
308
+ ngOnDestroy() {
309
+ if (this.eventSubscription) {
310
+ this.eventSubscription.unsubscribe();
311
+ }
312
+ this.socketService.disconnectSocketConnection();
313
+ //this.socketService.close();
314
+ }
315
+ changeTemperature(newTemperature) {
316
+ if (this.loading)
317
+ return;
318
+ this.temperature = newTemperature;
319
+ const wrapper = document.querySelector('.hivegpt-chat-wrapper');
320
+ // Remove existing theme classes from body
321
+ wrapper === null || wrapper === void 0 ? void 0 : wrapper.classList.remove('creative', 'balanced', 'precise');
322
+ switch (newTemperature) {
323
+ case 0:
324
+ wrapper === null || wrapper === void 0 ? void 0 : wrapper.classList.add('creative');
325
+ break;
326
+ case 1:
327
+ wrapper === null || wrapper === void 0 ? void 0 : wrapper.classList.add('balanced');
328
+ break;
329
+ case 2:
330
+ wrapper === null || wrapper === void 0 ? void 0 : wrapper.classList.add('precise');
331
+ break;
332
+ default:
333
+ break;
334
+ }
335
+ }
336
+ onStartAgain() {
337
+ if (this.loading)
338
+ return;
339
+ this.showStartAgain = false;
340
+ this.chatLog = [];
341
+ this.chatLog.push({
342
+ type: 'ai',
343
+ message: this.greetingMsg,
344
+ time: formatNow(this.timezone),
345
+ });
346
+ this.archieveMessages().subscribe();
347
+ }
348
+ archieveMessages() {
349
+ const headers = new HttpHeaders({
350
+ 'Content-Type': 'application/json',
351
+ 'x-api-key': this.apiKey,
352
+ 'hive-bot-id': this.botId
353
+ });
354
+ const url = `${this.environment.BASE_URL}/bot/clear-history/${this.botId}/${this.userId}`;
355
+ return this.http.post(url, {}, { headers }).pipe(switchMap((res) => {
356
+ return of(res);
357
+ }), catchError((error) => {
358
+ return of(null);
359
+ }));
360
+ }
361
+ fetchBotConfig() {
362
+ this.loading = true;
363
+ const headers = new HttpHeaders({
364
+ 'x-api-key': this.apiKey,
365
+ 'hive-bot-id': this.botId
366
+ });
367
+ const url = `${this.environment.BASE_URL}/bots?bot_id=${this.botId}`;
368
+ return this.http.get(url, { headers }).pipe(switchMap((res) => {
369
+ var _a;
370
+ this.botName = res.Name;
371
+ this.botIcon = res.Icon;
372
+ this.botSkills = res === null || res === void 0 ? void 0 : res.Skills;
373
+ this.greetingMsg = res.Greeting;
374
+ this.thumbsDownMessages = ((_a = res === null || res === void 0 ? void 0 : res.NegativeResponses) === null || _a === void 0 ? void 0 : _a.length) ? res.NegativeResponses
375
+ : [
376
+ "We are sorry we've not been able to answer your question.<br/> However, our dedicated support team is happy to help. <span class='feedback-link' style='cursor: pointer; text-decoration: underline; font-weight: 700; color: #17235B;'>Please click here</span> and a human agent will assist you as soon as possible",
377
+ ];
378
+ this.quickPrompts = res.QuickPrompts;
379
+ this.cdr.markForCheck();
380
+ this.loading = false;
381
+ return of(res);
382
+ }), catchError((error) => {
383
+ console.error('Error fetching chatbot config: ', error);
384
+ this.loading = false;
385
+ return of(null);
386
+ }));
387
+ }
388
+ fetchChatHistory() {
389
+ this.loading = true;
390
+ this.conversationKey = this.conversationService.getKey(this.botId, false);
391
+ const url = `${this.environment.BASE_URL}/conversations/${this.conversationKey}`;
392
+ const headers = new HttpHeaders({
393
+ accept: 'application/json',
394
+ 'x-api-key': this.apiKey,
395
+ 'hive-bot-id': this.botId
396
+ });
397
+ return this.http
398
+ .get(url, { headers })
399
+ .pipe(catchError(this.handleError('fetchConversation')));
400
+ }
401
+ handleError(operation = 'operation', result) {
402
+ return (error) => {
403
+ console.error(`${operation} failed: ${error.message}`);
404
+ return of(result);
405
+ };
406
+ }
407
+ // fetchChatHistory() {
408
+ // this.loading = true;
409
+ // const headers = new HttpHeaders({
410
+ // 'Content-Type': 'application/json',
411
+ // 'x-api-key': this.apiKey,
412
+ // });
413
+ // return this.http
414
+ // .get(`${this.environment.BASE_URL}/conversations/${this.conversationKey}`, { headers })
415
+ // .pipe(
416
+ // switchMap((res: any) => {
417
+ // this.loading = false;
418
+ // return of(res);
419
+ // }),
420
+ // catchError((error: any) => {
421
+ // console.error('Error fetching chat history: ', error);
422
+ // this.loading = false;
423
+ // return of(null);
424
+ // })
425
+ // );
426
+ // }
427
+ mapChatHistory(chats) {
428
+ var _a;
429
+ this.chatLog.push({
430
+ type: 'ai',
431
+ message: this.greetingMsg,
432
+ time: formatNow(this.timezone),
433
+ });
434
+ if (chats && ((_a = chats === null || chats === void 0 ? void 0 : chats.Messages) === null || _a === void 0 ? void 0 : _a.length)) {
435
+ chats === null || chats === void 0 ? void 0 : chats.Messages.forEach((chat) => {
436
+ if (chat.Type == 'user') {
437
+ this.chatLog.push({
438
+ type: 'user',
439
+ message: this.processMessageForDisplay(chat.Text),
440
+ time: formatTimeStamps(this.timezone, chat.InsertTimestamp),
441
+ copied: false,
442
+ isCollapsedTrue: false,
443
+ WorkflowExecutionId: chat.WorkflowExecutionId,
444
+ });
445
+ }
446
+ if (chat.Type == 'ai') {
447
+ var sourcesList = chat.WebLinks || [];
448
+ var displayedSources = chat.WebLinks.slice(0, 3); // First 3 cards
449
+ var remainingSources = chat.WebLinks.slice(3); // Remaining items
450
+ this.chatLog.push({
451
+ type: 'ai',
452
+ message: this.processMessageForDisplay(chat.Text),
453
+ executionGraphs: chat.ExecutionGraphs,
454
+ graphs: chat.Graphs,
455
+ searchTerms: chat.SearchTerms,
456
+ sourcesList: sourcesList,
457
+ displayedSources: displayedSources,
458
+ remainingSources: remainingSources,
459
+ time: formatTimeStamps(this.timezone, chat.InsertTimestamp),
460
+ copied: false,
461
+ isCollapsedTrue: false,
462
+ });
463
+ this.showFeedBackIconsIndex = this.chatLog.length - 1;
464
+ }
465
+ });
466
+ this.showStartAgain = true;
467
+ }
468
+ this.scrollToBottom();
469
+ this.cdr.markForCheck();
470
+ }
471
+ processMessage(message) {
472
+ if (!message || !((message === null || message === void 0 ? void 0 : message.length) > 0)) {
473
+ return '';
474
+ }
475
+ // console.log('here is my message')
476
+ // console.log(message);
477
+ message = message.trim();
478
+ const markdownLinkRegex = /\[([^[]+)]\(([^)]+)\)/g;
479
+ const urlRegex = /(?<!href=")\bhttps?:\/\/\S+(?<![.,])/gi;
480
+ if (markdownLinkRegex.test(message)) {
481
+ const html = message.replace(markdownLinkRegex, '<a href="$2" target="_blank">$1</a>');
482
+ //console.log('Sanitized message: ', message);
483
+ return this.sanitizeHtml(html);
484
+ }
485
+ if (urlRegex.test(message)) {
486
+ const html = message.replace(urlRegex, '<a href="$&" target="_blank">$&</a>');
487
+ // console.log('Sanitized message: ', message);
488
+ return this.sanitizeHtml(html);
489
+ }
490
+ message = message.replace(/(?:\r\n|\r|\n)/g, '<br>');
491
+ message = message.replace(/\*\*(.*?)\*\*/g, '<strong>$1</strong>');
492
+ // Convert Markdown headers to HTML headers
493
+ message = message.replace(/^(#{1,6})\s+(.*)$/gm, (match, hashes, text) => {
494
+ const level = hashes.length;
495
+ return `<h${level}>${text}</h${level}>`;
496
+ });
497
+ this.cdr.markForCheck();
498
+ const sanitizedMessage = this.sanitizeHtml(message);
499
+ return sanitizedMessage;
500
+ }
501
+ ngAfterViewChecked() {
502
+ const feedbackLinks = this.elementRef.nativeElement.querySelectorAll('.feedback-link');
503
+ feedbackLinks.forEach((link) => {
504
+ link.addEventListener('click', this.onFeedbackClick.bind(this, 'zendesk'));
505
+ });
506
+ // if (this.elementRef.nativeElement.querySelector('.feedback-link')) {
507
+ // this.elementRef.nativeElement
508
+ // .querySelector('.feedback-link')
509
+ // .addEventListener('click', this.onFeedbackClick.bind(this, 'zendesk'));
510
+ // }
511
+ }
512
+ sanitizeHtml(html) {
513
+ return this.sanitizer.bypassSecurityTrustHtml(html);
514
+ }
515
+ onFeedbackClick(value) {
516
+ this.feedbackEvent.emit(value);
517
+ }
518
+ onClose() {
519
+ this.renderer.removeClass(document.body, this.bodyOverflowClass);
520
+ this.onCloseEvent.emit();
521
+ }
522
+ sendMessageWithTile(prompt) {
523
+ this.input = prompt;
524
+ this.fetchData();
525
+ this.scrollToBottom();
526
+ }
527
+ fetchData(msg = null) {
528
+ var _a;
529
+ this.input = msg || ((_a = this.input) === null || _a === void 0 ? void 0 : _a.trim());
530
+ this.msg = this.input;
531
+ if (!this.input || this.loading) {
532
+ return;
533
+ }
534
+ this.chatLog.push({
535
+ type: 'user',
536
+ message: this.processMessageForDisplay(this.input),
537
+ time: formatNow(this.timezone),
538
+ copied: false,
539
+ isCollapsedTrue: false,
540
+ });
541
+ try {
542
+ const textarea = this.myInput.nativeElement;
543
+ textarea.style.height = 'hidden'; // Reset the height
544
+ textarea.style.height = `62px`;
545
+ }
546
+ catch (error) { }
547
+ this.cdr.markForCheck();
548
+ this.aiResponse = '';
549
+ this.isChatingWithAi = true;
550
+ this.makeAskRequest(this.input, this.agents, this.conversationKey);
551
+ }
552
+ fetchDataFor(msg, chat) {
553
+ const inputMsg = msg === null || msg === void 0 ? void 0 : msg.trim();
554
+ if (!inputMsg || this.loading) {
555
+ return;
556
+ }
557
+ try {
558
+ chat.relatedListItems = [];
559
+ this.cdr.detectChanges();
560
+ }
561
+ catch (error) { }
562
+ this.scrollToBottom();
563
+ this.chatLog.push({
564
+ type: 'user',
565
+ message: this.processMessageForDisplay(inputMsg),
566
+ time: formatNow(this.timezone),
567
+ copied: false,
568
+ isCollapsedTrue: false,
569
+ });
570
+ this.cdr.markForCheck();
571
+ this.aiResponse = '';
572
+ this.isChatingWithAi = true;
573
+ this.makeAskRequest(inputMsg, this.agents, this.conversationKey, msg, chat);
574
+ }
575
+ fetchSmallTalk() {
576
+ this.loading = true;
577
+ this.cdr.markForCheck();
578
+ const url = `${this.environment.BASE_URL}/bot/small-talk/${this.botId}/${this.userId}`;
579
+ this.http
580
+ .get(url, {
581
+ headers: {
582
+ 'x-api-key': this.apiKey,
583
+ 'hive-bot-id': this.botId
584
+ },
585
+ })
586
+ .pipe(catchError((error) => {
587
+ console.error('Error while fetching small talk:', error);
588
+ return of(null);
589
+ }))
590
+ .subscribe((response) => {
591
+ this.loading = false;
592
+ this.cdr.markForCheck();
593
+ if (!response) {
594
+ return;
595
+ }
596
+ if (response && response.smallTalk) {
597
+ this.chatLog.push({
598
+ type: 'ai',
599
+ message: this.processMessage(response.smallTalk),
600
+ time: formatNow(this.timezone),
601
+ isFeedbackMsg: true,
602
+ });
603
+ this.showFeedBackIconsIndex = this.chatLog.length - 2;
604
+ // this.scrollToBottom();
605
+ this.cdr.markForCheck();
606
+ }
607
+ });
608
+ }
609
+ pump(controller, reader, allSuggestions) {
610
+ reader.read().then(({ done, value }) => {
611
+ var _a, _b, _c, _d;
612
+ const lastItem = this.chatLog[this.chatLog.length - 1];
613
+ if (done) {
614
+ lastItem.message = this.processMessageForDisplay(lastItem.message);
615
+ this.chatLog.pop();
616
+ this.chatLog.push(lastItem);
617
+ if (allSuggestions === null || allSuggestions === void 0 ? void 0 : allSuggestions.length) {
618
+ this.chatLog.push({
619
+ type: 'suggestions',
620
+ suggestions: allSuggestions,
621
+ });
622
+ }
623
+ controller.close();
624
+ this.isChatingWithAi = false;
625
+ // this.scrollToBottom();
626
+ this.cdr.markForCheck();
627
+ this.showStartAgain = true;
628
+ // setTimeout(() => {
629
+ // this.fetchSmallTalk();
630
+ // },1000)
631
+ return;
632
+ }
633
+ let decodedChunk = this.decoder.decode(value, { stream: true });
634
+ this.aiResponse += decodedChunk;
635
+ if (lastItem.type === 'ai') {
636
+ const suggestionsMatch = this.aiResponse.match(/<sug>(.*?)<\/sug>/g);
637
+ if (suggestionsMatch) {
638
+ suggestionsMatch.forEach((match) => {
639
+ this.aiResponse = this.aiResponse.replace(match, '');
640
+ allSuggestions.push(match === null || match === void 0 ? void 0 : match.replace(/<\/?sug>/g, ''));
641
+ });
642
+ }
643
+ lastItem.message = this.aiResponse;
644
+ this.cdr.markForCheck();
645
+ }
646
+ else {
647
+ this.isChatingWithAi = false;
648
+ let aiFormattedData;
649
+ try {
650
+ console.log('parsing json ');
651
+ aiFormattedData = JSON.parse(JSON.parse(this.aiResponse));
652
+ }
653
+ catch (e) {
654
+ try {
655
+ console.log('parsing json 2');
656
+ aiFormattedData = JSON.parse(this.aiResponse);
657
+ }
658
+ catch (e) { }
659
+ }
660
+ console.log('parsing json done');
661
+ if (aiFormattedData && ((_a = aiFormattedData === null || aiFormattedData === void 0 ? void 0 : aiFormattedData.section_id) === null || _a === void 0 ? void 0 : _a.length) > 0) {
662
+ if (aiFormattedData.section_id == 'company_search' ||
663
+ aiFormattedData.section_id == 'user_search' ||
664
+ aiFormattedData.section_id == 'industry_company_search') {
665
+ this.fetchMyConnections().subscribe();
666
+ this.fetchPendingRequests().subscribe();
667
+ }
668
+ if (aiFormattedData.section_id == this.myUpcomingSessionAction) {
669
+ var speakerIds = [];
670
+ (_b = aiFormattedData.content) === null || _b === void 0 ? void 0 : _b.forEach((session) => {
671
+ speakerIds = [...speakerIds, ...session.speakers];
672
+ });
673
+ if ((speakerIds === null || speakerIds === void 0 ? void 0 : speakerIds.length) > 0)
674
+ this.getSpeakersByStaffIds(speakerIds);
675
+ }
676
+ if (aiFormattedData.section_id == this.addToMyAgendaAction &&
677
+ ((_c = aiFormattedData.content) === null || _c === void 0 ? void 0 : _c.length) > 0) {
678
+ this.openPage.next({
679
+ sectionId: aiFormattedData.section_id,
680
+ sessionIds: aiFormattedData.content,
681
+ });
682
+ }
683
+ if (aiFormattedData.section_id == this.connectOrFollowAction) {
684
+ let usersLen = (_d = aiFormattedData.content) === null || _d === void 0 ? void 0 : _d.length;
685
+ if (usersLen > 1) {
686
+ this.openPage.next({
687
+ sectionId: 'open_networking_drawer',
688
+ search: aiFormattedData.content,
689
+ });
690
+ }
691
+ else if (usersLen == 1) {
692
+ this.openPage.next({
693
+ sectionId: aiFormattedData.section_id,
694
+ connetUserIds: [aiFormattedData.content[0].userId],
695
+ });
696
+ }
697
+ }
698
+ if (aiFormattedData.is_open_page == 'true') {
699
+ this.openPage.next({
700
+ sectionId: aiFormattedData.section_id,
701
+ search: aiFormattedData.content,
702
+ });
703
+ if (this.isMobileBrowser()) {
704
+ aiFormattedData.message +=
705
+ '\n\n' + '<a id="closeBotNow">Click Here</a> to see results.';
706
+ }
707
+ }
708
+ this.chatLog.push({
709
+ type: 'ai',
710
+ message: aiFormattedData.message,
711
+ action: aiFormattedData,
712
+ time: formatNow(this.timezone),
713
+ });
714
+ if (this.isMobileBrowser()) {
715
+ setTimeout(() => {
716
+ this.addCloseBotClickEvent();
717
+ }, 500);
718
+ }
719
+ this.aiResponse = '';
720
+ }
721
+ else {
722
+ this.chatLog.push({
723
+ type: 'ai',
724
+ message: this.aiResponse,
725
+ time: formatNow(this.timezone),
726
+ });
727
+ }
728
+ this.showFeedBackIconsIndex = this.chatLog.length - 1;
729
+ this.cdr.markForCheck();
730
+ }
731
+ this.scrollToBottom();
732
+ // Enqueue the next data chunk into our target stream
733
+ controller.enqueue(value);
734
+ this.pump(controller, reader, allSuggestions);
735
+ });
736
+ }
737
+ submitFeedback(flag) {
738
+ this.feedbackDone = true;
739
+ this.showFeedBackIconsIndex = null;
740
+ const url = `${this.environment.BASE_URL}/bot/feedback`;
741
+ fetch(url, {
742
+ method: 'POST',
743
+ headers: {
744
+ 'Content-Type': 'application/json',
745
+ 'x-api-key': this.apiKey,
746
+ 'hive-bot-id': this.botId
747
+ },
748
+ body: JSON.stringify({ flag, user_id: this.userId, bot_id: this.botId }),
749
+ }).then(() => {
750
+ if (flag) {
751
+ this.chatLog.push({
752
+ type: 'ai',
753
+ message: this.thumbsUpMessage ||
754
+ `Great. May I assist you with anything else?`,
755
+ time: formatNow(this.timezone),
756
+ isFeedbackMsg: true,
757
+ });
758
+ this.scrollToBottom();
759
+ this.cdr.markForCheck();
760
+ this.feedbackDone = false;
761
+ this.showFeedBackIconsIndex = null;
762
+ return;
763
+ }
764
+ this.chatLog.push({
765
+ type: 'ai',
766
+ message: this.processMessage(this.thumbsDownMessages[this.thumbsDownMsgIndex]),
767
+ time: formatNow(this.timezone),
768
+ isFeedbackMsg: true,
769
+ });
770
+ this.thumbsDownMsgIndex =
771
+ (this.thumbsDownMsgIndex + 1) % this.thumbsDownMessages.length;
772
+ this.scrollToBottom();
773
+ this.cdr.markForCheck();
774
+ this.feedbackDone = false;
775
+ this.showFeedBackIconsIndex = null;
776
+ });
777
+ }
778
+ handleKeydown(event) {
779
+ if (event.key === 'Enter' && !event.shiftKey) {
780
+ // Prevent default behavior (new line)
781
+ event.preventDefault();
782
+ // Call your submit function
783
+ this.handleSubmit(event);
784
+ }
785
+ }
786
+ handleSubmit(event) {
787
+ this.fetchData();
788
+ this.scrollToBottom();
789
+ }
790
+ handleUpClick(idx) {
791
+ if (this.feedbackDone) {
792
+ return;
793
+ }
794
+ this.submitFeedback(true);
795
+ this.chatLog[idx].liked = !this.chatLog[idx].liked;
796
+ if (this.chatLog[idx].unliked) {
797
+ this.chatLog[idx].unliked = !this.chatLog[idx].unliked;
798
+ }
799
+ this.cdr.markForCheck();
800
+ }
801
+ handleDownClick(idx) {
802
+ if (this.feedbackDone)
803
+ return;
804
+ this.submitFeedback(false);
805
+ this.chatLog[idx].unliked = !this.chatLog[idx].unliked;
806
+ if (this.chatLog[idx].liked)
807
+ this.chatLog[idx].liked = !this.chatLog[idx].liked;
808
+ }
809
+ // handleCopyClick(index: any) {
810
+ // // Copy the message to the clipboard
811
+ // const contentToCopy = this.chatLog[index].message;
812
+ // console.log('contentToCopy');
813
+ // console.log(contentToCopy);
814
+ // navigator.clipboard.writeText(contentToCopy).then(() => {
815
+ // // Indicate that the message was copied
816
+ // this.chatLog[index].copied = true;
817
+ // this.cdr.detectChanges();
818
+ // // Reset the copied state after a delay
819
+ // setTimeout(() => {
820
+ // this.chatLog[index].copied = false;
821
+ // this.cdr.detectChanges();
822
+ // }, 2000); // Reset after 2 seconds
823
+ // });
824
+ // }
825
+ copyText(id, index) {
826
+ // Get the text element
827
+ var textElement = document.getElementById(id);
828
+ // Create a temporary textarea element to copy the text
829
+ var tempTextArea = document.createElement('textarea');
830
+ tempTextArea.value = textElement.innerText;
831
+ // Append the textarea to the body (necessary for the execCommand to work)
832
+ document.body.appendChild(tempTextArea);
833
+ // Select the text inside the textarea
834
+ tempTextArea.select();
835
+ // Copy the text to the clipboard
836
+ document.execCommand('copy');
837
+ // Remove the temporary textarea
838
+ document.body.removeChild(tempTextArea);
839
+ // Optionally, you can alert the user or change the button text to indicate the copy was successful
840
+ // alert('Text copied to clipboard!');
841
+ this.chatLog[index].copied = true;
842
+ this.cdr.detectChanges();
843
+ // Reset the copied state after a delay
844
+ setTimeout(() => {
845
+ this.chatLog[index].copied = false;
846
+ this.cdr.detectChanges();
847
+ }, 2000); // Reset after 2 seconds
848
+ }
849
+ handleCopyClick(index) {
850
+ // Copy the message to the clipboard
851
+ const contentToCopy = this.chatLog[index].message;
852
+ const resutlt = this.copyText('messageText_' + index, index);
853
+ }
854
+ sanitizeHTML(html) {
855
+ const doc = new DOMParser().parseFromString(html, 'text/html');
856
+ // Create a new document fragment to hold the simplified content
857
+ const fragment = document.createDocumentFragment();
858
+ // Append the children of the body of the parsed document to the fragment
859
+ Array.from(doc.body.childNodes).forEach((node) => {
860
+ fragment.appendChild(node.cloneNode(true));
861
+ });
862
+ // Create a new div element to hold the simplified HTML
863
+ const simplifiedDiv = document.createElement('div');
864
+ simplifiedDiv.appendChild(fragment);
865
+ // Remove complex tags or attributes as needed
866
+ // Example: remove scripts
867
+ simplifiedDiv
868
+ .querySelectorAll('script')
869
+ .forEach((script) => script.remove());
870
+ // Return the simplified HTML as a string
871
+ return simplifiedDiv.innerHTML;
872
+ }
873
+ handleEditorClick(index) {
874
+ if (this.currentIndexForEditor == -1) {
875
+ this.currentIndexForEditor = index;
876
+ this.currentMessageForEditor = this.sanitizeHTML(this.chatLog[index].message);
877
+ this.currentMessageForEditor = this.currentMessageForEditor.replace('SafeValue must use [property]=binding:', '');
878
+ this.cdr.detectChanges();
879
+ }
880
+ else {
881
+ if (this.currentIndexForEditor == index) {
882
+ this.currentMessageForEditor += this.sanitizeHTML(this.chatLog[index].message);
883
+ this.currentMessageForEditor = this.currentMessageForEditor.replace('SafeValue must use [property]=binding:', '');
884
+ this.cdr.detectChanges();
885
+ }
886
+ else {
887
+ this.currentIndexForEditor = index;
888
+ this.currentMessageForEditor = this.sanitizeHTML(this.chatLog[index].message);
889
+ this.currentMessageForEditor = this.currentMessageForEditor.replace('SafeValue must use [property]=binding:', '');
890
+ this.cdr.detectChanges();
891
+ }
892
+ }
893
+ this.chatLog[index].isEditor = true;
894
+ this.cdr.detectChanges();
895
+ // Reset the copied state after a delay
896
+ setTimeout(() => {
897
+ this.chatLog[index].isEditor = false;
898
+ this.cdr.detectChanges();
899
+ }, 2000); // Reset after 2 seconds
900
+ this.editorsDrawer.open();
901
+ const button = document.getElementById('botcloseplaygroundbutton');
902
+ if (button) {
903
+ button.style.display = 'none';
904
+ }
905
+ this.cdr.detectChanges();
906
+ }
907
+ scrollToBottom() {
908
+ let counter = 0;
909
+ const interval = setInterval(() => {
910
+ this.chatMain.nativeElement.scrollTop = this.chatMain.nativeElement.scrollHeight;
911
+ if (counter++ > 5)
912
+ clearInterval(interval);
913
+ }, 5);
914
+ }
915
+ handleAction(action) {
916
+ console.info('incoming action from the chatbot AI');
917
+ console.info(action);
918
+ if (action === null || action === void 0 ? void 0 : action.content) {
919
+ }
920
+ }
921
+ ngAfterViewInit() {
922
+ // Check if the drawer is initially open and apply overflow hidden to body if so
923
+ if (this.drawer.opened) {
924
+ this.setBodyOverflow();
925
+ }
926
+ // Listen to changes in the drawer being opened or closed
927
+ this.drawer.openedChange.subscribe((opened) => {
928
+ if (opened) {
929
+ this.setBodyOverflow();
930
+ }
931
+ else {
932
+ this.removeBodyOverflow();
933
+ }
934
+ });
935
+ this.drawer.openedChange.subscribe((opened) => {
936
+ if (opened) {
937
+ setTimeout(() => {
938
+ if (this.myTextarea && this.myTextarea.nativeElement) {
939
+ this.myTextarea.nativeElement.focus(); // Focus on the textarea
940
+ }
941
+ });
942
+ }
943
+ });
944
+ }
945
+ setBodyOverflow() {
946
+ this.renderer.addClass(document.body, this.bodyOverflowClass);
947
+ }
948
+ removeBodyOverflow() {
949
+ this.renderer.removeClass(document.body, this.bodyOverflowClass);
950
+ }
951
+ getSpeakersByStaffIds(ids) {
952
+ const url = `${this.environment.USERS_API}/events/${this.eventId}/users/get-by-staff-ids`;
953
+ fetch(url, {
954
+ method: 'POST',
955
+ headers: {
956
+ 'Content-Type': 'application/json',
957
+ Authorization: 'Bearer ' + 'your_token_here',
958
+ },
959
+ body: JSON.stringify(ids),
960
+ })
961
+ .then((response) => {
962
+ if (response.ok) {
963
+ return response.json(); // Parse the JSON body of the response
964
+ }
965
+ else {
966
+ throw new Error('Network response was not ok.');
967
+ }
968
+ })
969
+ .then((data) => {
970
+ if ((data === null || data === void 0 ? void 0 : data.length) > 0) {
971
+ data.forEach((speaker) => {
972
+ this.speakers[speaker.id] = speaker;
973
+ });
974
+ this.cdr.markForCheck();
975
+ }
976
+ })
977
+ .catch((err) => {
978
+ console.error('Error fetching data:', err);
979
+ this.loading = false;
980
+ });
981
+ }
982
+ performSessionAction(sessionId, action) {
983
+ this.sessionActions.next({
984
+ sessionId,
985
+ action,
986
+ });
987
+ }
988
+ addCloseBotClickEvent() {
989
+ const element = this.elementRef.nativeElement.querySelector('#closeBotNow');
990
+ if (element) {
991
+ this.renderer.listen(element, 'click', () => {
992
+ this.closeBot.next();
993
+ });
994
+ }
995
+ }
996
+ isMobileBrowser() {
997
+ return /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent);
998
+ }
999
+ connectToUser(userId) {
1000
+ this.connectWithUser.emit({
1001
+ connect: !this.canDisconnect(userId),
1002
+ userId,
1003
+ });
1004
+ setTimeout(() => {
1005
+ this.fetchMyConnections().subscribe((res) => {
1006
+ this.cdr.markForCheck();
1007
+ });
1008
+ this.fetchPendingRequests().subscribe((res) => {
1009
+ this.cdr.markForCheck();
1010
+ });
1011
+ }, 500);
1012
+ }
1013
+ scheduleMeetingWithUser(user) {
1014
+ this.scheduleMeeting.emit(user);
1015
+ }
1016
+ canConnect(userId) {
1017
+ return !(this.canDisconnect(userId) ||
1018
+ this.pendingRequests.find((a) => a == userId));
1019
+ }
1020
+ canDisconnect(userId) {
1021
+ return this.myConnections.find((conn) => conn.userId == userId);
1022
+ }
1023
+ fetchPendingRequests() {
1024
+ const headers = new HttpHeaders({
1025
+ 'Content-Type': 'application/json',
1026
+ apiKey: this.autogenKey,
1027
+ });
1028
+ return this.http
1029
+ .get(`${this.environment.USERS_API}/events/${this.eventId}/connection-requests/autogen/pending-sent-requests?userId=${this.userId}`, { headers })
1030
+ .pipe(switchMap((res) => {
1031
+ this.pendingRequests = res;
1032
+ this.cdr.markForCheck();
1033
+ return of(res);
1034
+ }), catchError((error) => {
1035
+ console.error('Error fetching pending requests: ', error);
1036
+ return of(null);
1037
+ }));
1038
+ }
1039
+ fetchMyConnections() {
1040
+ const headers = new HttpHeaders({
1041
+ 'Content-Type': 'application/json',
1042
+ apiKey: this.autogenKey,
1043
+ });
1044
+ return this.http
1045
+ .get(`${this.environment.USERS_API}/events/${this.eventId}/users-connections/autogen?userId=${this.userId}`, { headers })
1046
+ .pipe(switchMap((res) => {
1047
+ this.myConnections = res;
1048
+ this.cdr.markForCheck();
1049
+ return of(res);
1050
+ }), catchError((error) => {
1051
+ console.error('Error fetching pending requests: ', error);
1052
+ return of(null);
1053
+ }));
1054
+ }
1055
+ // Toggle the dropdown visibility
1056
+ toggleDropdown() {
1057
+ this.fetchAgents();
1058
+ this.isDropdownOpen = !this.isDropdownOpen;
1059
+ this.cdr.detectChanges();
1060
+ }
1061
+ onSelectAll(event) {
1062
+ var _a;
1063
+ (_a = this.agents) === null || _a === void 0 ? void 0 : _a.forEach((agent) => (agent.selected = false));
1064
+ this.cdr.detectChanges();
1065
+ }
1066
+ onAgentChange(agent) {
1067
+ //agent.selected = !agent.selected;
1068
+ //console.log(agent);
1069
+ let agentFound = this.agents.filter((p) => p.id == agent.id);
1070
+ if (agentFound && agentFound.length > 0) {
1071
+ agentFound[0].selected = !agentFound[0].selected;
1072
+ this.cdr.detectChanges();
1073
+ }
1074
+ this.cdr.detectChanges();
1075
+ }
1076
+ areAllSelected() {
1077
+ var _a;
1078
+ return (_a = this.agents) === null || _a === void 0 ? void 0 : _a.every((agent) => !agent.selected);
1079
+ }
1080
+ getDropdownHeaderText() {
1081
+ var _a;
1082
+ const selectedAgents = (_a = this.agents) === null || _a === void 0 ? void 0 : _a.filter((agent) => agent.selected);
1083
+ if (selectedAgents && (selectedAgents === null || selectedAgents === void 0 ? void 0 : selectedAgents.length) === 0) {
1084
+ return 'All Agents';
1085
+ }
1086
+ else {
1087
+ return (selectedAgents === null || selectedAgents === void 0 ? void 0 : selectedAgents.length) > 1
1088
+ ? `${selectedAgents === null || selectedAgents === void 0 ? void 0 : selectedAgents.length} Agents Selected`
1089
+ : `${selectedAgents === null || selectedAgents === void 0 ? void 0 : selectedAgents.length} Agent Selected`;
1090
+ }
1091
+ }
1092
+ fetchAgents_http() {
1093
+ this.loading = true;
1094
+ const url = `${this.environment.AGENTS_API}/CoPilot/${this.botId}/active-agents`;
1095
+ const headers = new HttpHeaders({
1096
+ 'Content-Type': 'application/json',
1097
+ });
1098
+ return this.http.post(url, {}, { headers }).pipe(switchMap((res) => {
1099
+ if (res) {
1100
+ this.agents = res.map((agent) => (Object.assign(Object.assign({}, agent), { selected: false })));
1101
+ }
1102
+ this.cdr.markForCheck();
1103
+ return of(res);
1104
+ }), catchError((error) => {
1105
+ console.error('Error fetching chatbot config: ', error);
1106
+ return of(null);
1107
+ }));
1108
+ }
1109
+ fetchContent_http() {
1110
+ this.isDocInEditMode = false;
1111
+ this.isContentLoaded = false;
1112
+ console.log('API call function');
1113
+ this.loading = true;
1114
+ const conversation_id = this.conversationService.getKey(this.botId);
1115
+ this.conversationId = conversation_id;
1116
+ const url = `${this.environment.AGENTS_API}/ConversationDocuments?conversationId=${conversation_id}&botId=${this.botId}`;
1117
+ const headers = new HttpHeaders({
1118
+ 'Content-Type': 'application/json',
1119
+ apiKey: 'WIz/qAm+EEmfOkFaUA/weA==',
1120
+ });
1121
+ return this.http.get(url, { headers }).pipe(switchMap((res) => {
1122
+ if (res) {
1123
+ this.isDocInEditMode = true;
1124
+ this.documentContent = res;
1125
+ console.log('Get API callled success');
1126
+ this.isContentLoaded = true;
1127
+ console.log(res);
1128
+ }
1129
+ this.cdr.markForCheck();
1130
+ return of(res);
1131
+ }), catchError((error) => {
1132
+ console.error('Error fetching chatbot config DJ: ', error);
1133
+ this.isDocInEditMode = false;
1134
+ this.isContentLoaded = true;
1135
+ if ((error === null || error === void 0 ? void 0 : error.status) == 404) {
1136
+ console.log('dash');
1137
+ this.isDocInEditMode = false;
1138
+ this.isContentLoaded = true;
1139
+ }
1140
+ return of(null);
1141
+ }));
1142
+ }
1143
+ fetchAgents() {
1144
+ this.fetchAgents_http().subscribe();
1145
+ }
1146
+ fetchEditorContent() {
1147
+ this.fetchContent_http().subscribe();
1148
+ }
1149
+ // events/${eventId}/users-connections
1150
+ processMessageForDisplay(markdown) {
1151
+ var html = this.prepareHtml(markdown);
1152
+ // console.log('After line breaks conversion:', html);
1153
+ // Optional: Sanitize the HTML to prevent XSS
1154
+ const sanitizedHtml = this.sanitizeHtml(html);
1155
+ // console.log('Sanitized HTML:', sanitizedHtml);
1156
+ return sanitizedHtml;
1157
+ }
1158
+ prepareHtml(markdown) {
1159
+ if (!markdown || !(markdown.length > 0)) {
1160
+ console.error('Input Markdown is null or empty');
1161
+ return '';
1162
+ }
1163
+ // Convert Markdown headers (### or ##) to <strong> for bold headings
1164
+ let html = markdown.replace(/^(#{1,6})\s+(.*)$/gm, (match, hashes, text) => {
1165
+ const level = hashes.length;
1166
+ if (level === 3) {
1167
+ return `<h3><strong>${text}</strong></h3>`;
1168
+ }
1169
+ else if (level === 4) {
1170
+ return `<h4><strong>${text}</strong></h4>`;
1171
+ }
1172
+ return `<strong>${text}</strong>`;
1173
+ });
1174
+ // Convert Markdown code blocks with language to preformatted HTML
1175
+ html = html.replace(/```(\w+)?\n([\s\S]*?)```/g, (match, lang, code) => {
1176
+ const escapedCode = this.escapeHtml(code);
1177
+ const language = lang || 'plaintext';
1178
+ // Create a copy button for the code block
1179
+ return `
1180
+ <div class="code-container">
1181
+ <button id="copy-button" class="copy-button" (click)="copyToClipboard('\`${escapedCode}\`')">Copy</button>
1182
+ <pre class="code_block diff"><code class="language-${language}">${escapedCode}</code></pre>
1183
+ </div>`;
1184
+ });
1185
+ // Convert inline code (wrapped in `backticks`) to inline <code> tags
1186
+ html = html.replace(/`([^`]+)`/g, '<code>$1</code>');
1187
+ // Convert Markdown bold to HTML <strong>
1188
+ html = html.replace(/\*\*(.*?)\*\*/g, '<strong>$1</strong>');
1189
+ // Convert numbered lists
1190
+ html = html.replace(/^\d+\.\s+(.*)$/gm, '<li>$1</li>');
1191
+ // Convert bullet point lists
1192
+ html = html.replace(/^\-\s+(.*)$/gm, '<li>$1</li>');
1193
+ // Convert Markdown links to HTML links
1194
+ html = html.replace(/\[([^\]]+)]\(([^)]+)\)/g, '<a href="$2" target="_blank">$1</a>');
1195
+ // Convert new lines to <br> tags for paragraphs
1196
+ html = html.replace(/(?:\r\n|\r|\n)/g, '<br>');
1197
+ return html;
1198
+ }
1199
+ // Helper function to escape HTML characters for code blocks
1200
+ escapeHtml(code) {
1201
+ return code
1202
+ .replace(/&/g, '&amp;')
1203
+ .replace(/</g, '&lt;')
1204
+ .replace(/>/g, '&gt;')
1205
+ .replace(/"/g, '&quot;')
1206
+ .replace(/'/g, '&#039;');
1207
+ }
1208
+ // Function to copy text to clipboard
1209
+ copyToClipboard(text) {
1210
+ navigator.clipboard.writeText(text).then(() => {
1211
+ alert('Code copied to clipboard!');
1212
+ }, (err) => {
1213
+ console.error('Could not copy text: ', err);
1214
+ });
1215
+ }
1216
+ toggleCollapse() {
1217
+ this.isCollapsed = !this.isCollapsed;
1218
+ this.cdr.detectChanges();
1219
+ }
1220
+ toggleCollapseGraph() {
1221
+ this.isCollapsedForGraph = !this.isCollapsedForGraph;
1222
+ this.cdr.detectChanges();
1223
+ }
1224
+ toggleCollapseFGraph() {
1225
+ this.isCollapsedForFGraph = !this.isCollapsedForFGraph;
1226
+ this.cdr.detectChanges();
1227
+ }
1228
+ // Extracts the domain from a URL
1229
+ getDomainName(url) {
1230
+ try {
1231
+ const { hostname } = new URL(url);
1232
+ return hostname.replace(/^www\./, ''); // Remove 'www.' if present
1233
+ }
1234
+ catch (_a) {
1235
+ return 'unknown';
1236
+ }
1237
+ }
1238
+ // Generates the favicon URL
1239
+ getFaviconUrl(url) {
1240
+ const domain = this.getDomainName(url);
1241
+ return `https://www.google.com/s2/favicons?sz=128&domain=${domain}`;
1242
+ }
1243
+ onCardClick(sources) {
1244
+ this.currentSourcesList = sources;
1245
+ this.cdr.detectChanges();
1246
+ this.sourcesDrawer.open();
1247
+ const button = document.getElementById('botcloseplaygroundbutton');
1248
+ if (button) {
1249
+ button.style.display = 'none';
1250
+ }
1251
+ }
1252
+ openOuterEditor() {
1253
+ this.fetchEditorContent();
1254
+ this.editorsDrawer.open();
1255
+ this.isDrawerOpen = true;
1256
+ this.isShowEditorButton = false;
1257
+ this.cdr.detectChanges();
1258
+ const button = document.getElementById('botcloseplaygroundbutton');
1259
+ if (button) {
1260
+ button.style.display = 'none';
1261
+ }
1262
+ }
1263
+ onCloseEditor() {
1264
+ this.editorsDrawer.close();
1265
+ this.isDrawerOpen = false;
1266
+ this.isShowEditorButton = true;
1267
+ this.cdr.detectChanges(); // Trigger change detection if needed
1268
+ this.onDrawerClosed();
1269
+ }
1270
+ onCloseSource() {
1271
+ this.sourcesDrawer.close();
1272
+ this.isDrawerOpen = false;
1273
+ this.cdr.detectChanges(); // Trigger change detection if needed
1274
+ this.onDrawerClosed();
1275
+ }
1276
+ onDrawerClosed() {
1277
+ setTimeout(() => {
1278
+ this.isDrawerOpen = true;
1279
+ this.cdr.detectChanges(); // Trigger change detection if needed
1280
+ // Use ngClass to dynamically apply the class
1281
+ const button = document.getElementById('botcloseplaygroundbutton');
1282
+ if (button) {
1283
+ button.style.display = 'block';
1284
+ }
1285
+ }, 800);
1286
+ }
1287
+ toggleDrawer(todo) {
1288
+ this.isDrawerOpen = todo;
1289
+ this.cdr.detectChanges();
1290
+ this.updateButtonVisibility();
1291
+ }
1292
+ updateButtonVisibility() {
1293
+ const button = document.getElementById('botcloseplaygroundbutton');
1294
+ if (button) {
1295
+ button.style.display = this.isDrawerOpen ? 'block' : 'none';
1296
+ }
1297
+ }
1298
+ openLinkInNewTab(link) {
1299
+ window.open(link, '_blank');
1300
+ }
1301
+ adjustTextareaHeight(event) {
1302
+ try {
1303
+ if (event.key === 'Enter' && !event.shiftKey) {
1304
+ // Prevents a new line from being added
1305
+ event.preventDefault();
1306
+ }
1307
+ }
1308
+ catch (error) {
1309
+ }
1310
+ const textarea = event.target;
1311
+ textarea.style.height = 'auto'; // Reset the height
1312
+ textarea.style.height = `${textarea.scrollHeight}px`; // Adjust height to match content
1313
+ // Ensure the height doesn't exceed the max-height set in CSS
1314
+ if (textarea.scrollHeight > 150) {
1315
+ textarea.style.height = `150px`; // Adjust height to match content
1316
+ textarea.style.overflowY = 'auto'; // Enable scrolling if content exceeds 400px
1317
+ }
1318
+ else {
1319
+ textarea.style.overflowY = 'hidden'; // Hide scrollbar if content is within limits
1320
+ }
1321
+ }
1322
+ toggleWorkflows(value = null) {
1323
+ if (!this.checkForCop29BotId()) {
1324
+ this.botService.getWorkflowsByOrgId(this.orgId).subscribe((res) => {
1325
+ this.orgWorkflows = res;
1326
+ this.isWorkflowOpen = value == null ? !this.isWorkflowOpen : value;
1327
+ if (!this.isWorkflowOpen) {
1328
+ this.selectedWorkflow = null;
1329
+ this.openWorkflowInput = false;
1330
+ }
1331
+ this.cdr.detectChanges();
1332
+ });
1333
+ }
1334
+ }
1335
+ initializeForm() {
1336
+ var _a, _b;
1337
+ // Create form controls dynamically based on selectedWorkflow.Trigger.InputSchema
1338
+ const formControls = {};
1339
+ if ((_b = (_a = this.selectedWorkflow) === null || _a === void 0 ? void 0 : _a.Trigger) === null || _b === void 0 ? void 0 : _b.InputSchema) {
1340
+ this.selectedWorkflow.Trigger.InputSchema.forEach((input) => {
1341
+ formControls[input.InputId] = [
1342
+ input.Value || '',
1343
+ input.Required ? Validators.required : null,
1344
+ ];
1345
+ });
1346
+ }
1347
+ // Initialize the form
1348
+ this.workflowForm = this.fb.group(formControls);
1349
+ }
1350
+ onWorkflowSelected(workflow) {
1351
+ this.selectedWorkflow = workflow;
1352
+ this.initializeForm();
1353
+ this.isWorkflowOpen = false;
1354
+ this.openWorkflowInput = true;
1355
+ }
1356
+ onWorkflowSubmit() {
1357
+ const container = document.getElementById('allChats');
1358
+ if (this.workflowForm.valid) {
1359
+ console.log(this.workflowForm.value);
1360
+ var input = this.prepareHtml(this.generateMarkdown(this.selectedWorkflow.Name, this.workflowForm.value));
1361
+ // update last two chatLog entries, set showWorkflowExecutionLoader = false
1362
+ try {
1363
+ this.chatLog[this.chatLog.length - 1]['showWorkflowExecutionLoader'] = false;
1364
+ this.chatLog[this.chatLog.length - 2]['showWorkflowExecutionLoader'] = false;
1365
+ }
1366
+ catch (error) { }
1367
+ this.chatLog.push({
1368
+ type: 'user',
1369
+ message: input,
1370
+ time: formatNow(this.timezone),
1371
+ copied: false,
1372
+ isCollapsedTrue: false,
1373
+ showWorkflowExecutionLoader: true,
1374
+ });
1375
+ console.log(input);
1376
+ this.currentWorkflowActionProgress = 0;
1377
+ this.currentWorkflowAction =
1378
+ 'Executing ' + this.selectedWorkflow.Actions[0].Name;
1379
+ this.isChatingWithAi = true;
1380
+ this.executingWorkflow = true;
1381
+ this.workflowExecutionDetails = {
1382
+ Actions: this.selectedWorkflow.Actions,
1383
+ Inputs: this.workflowForm.value,
1384
+ workflowInputs: this.workflowForm.value,
1385
+ WorkflowName: this.selectedWorkflow.Name,
1386
+ };
1387
+ this.currentWorkflowExecutionDetails = this.workflowExecutionDetails;
1388
+ this.scrollToBottom();
1389
+ this.cdr.detectChanges();
1390
+ // execute the ask endpoint with workflow input
1391
+ this.makeAskRequest(input, this.agents, this.conversationKey, '', null, this.selectedWorkflow['_id'], this.workflowForm.value);
1392
+ }
1393
+ }
1394
+ makeAskRequest(inputMsg, agents, conversationId, msg, chat, workflowId, workflow_inputs) {
1395
+ var url = `${this.environment.BASE_URL}/ai/ask`;
1396
+ var body = {
1397
+ user_question: inputMsg,
1398
+ user_id: this.userId,
1399
+ bot_id: this.botId,
1400
+ message_id: this.conversationService.generateKey(),
1401
+ agents: agents.filter((p) => p.selected).map((p) => p.id),
1402
+ conversation_id: conversationId,
1403
+ };
1404
+ if (workflowId) {
1405
+ body['workflow_id'] = workflowId;
1406
+ body['workflow_inputs'] = workflow_inputs;
1407
+ }
1408
+ fetch(url, {
1409
+ method: 'POST',
1410
+ headers: {
1411
+ 'Content-Type': 'application/json',
1412
+ Authorization: 'Bearer ' + this.s27Token,
1413
+ 'x-api-key': this.apiKey,
1414
+ 'hive-bot-id': this.botId
1415
+ },
1416
+ body: JSON.stringify(body),
1417
+ })
1418
+ .then((response) => {
1419
+ if (response.status === 401 || response.status === 403) {
1420
+ this.is401 = true;
1421
+ this.refreshToken.emit();
1422
+ // If `msg` and `chat` exist, handle them
1423
+ if (msg && chat) {
1424
+ this.msg = msg;
1425
+ this.chat = chat;
1426
+ this.isFetchDataFor = true;
1427
+ }
1428
+ }
1429
+ else {
1430
+ this.is401 = false;
1431
+ }
1432
+ return response.json();
1433
+ })
1434
+ .then((data) => {
1435
+ console.log(data);
1436
+ // Additional response handling if needed
1437
+ })
1438
+ .catch((err) => {
1439
+ console.error('Error: ', err);
1440
+ this.isChatingWithAi = false;
1441
+ });
1442
+ this.input = '';
1443
+ this.selectedWorkflow = null;
1444
+ this.openWorkflowInput = false;
1445
+ this.isWorkflowOpen = false;
1446
+ this.scrollToBottom();
1447
+ this.cdr.markForCheck();
1448
+ }
1449
+ generateMarkdown(title, obj) {
1450
+ var _a;
1451
+ // Initialize markdown with the title
1452
+ let markdown = `## ${title}\n`;
1453
+ // Loop through the object and append the field names and values
1454
+ for (const [key, value] of Object.entries(obj)) {
1455
+ var key_label = ((_a = this.selectedWorkflow.Trigger.InputSchema.find((input) => input.InputId === key)) === null || _a === void 0 ? void 0 : _a.Label) || key;
1456
+ markdown += `- **${key_label}**: ${value}\n`;
1457
+ }
1458
+ return markdown;
1459
+ }
1460
+ showWorkflowHistoryDetails(workflow_id) {
1461
+ if (!workflow_id) {
1462
+ this.workflowExecutionDetails = this.currentWorkflowExecutionDetails;
1463
+ this.showWorkflowExecutionDetails = true;
1464
+ this.cdr.detectChanges();
1465
+ return;
1466
+ }
1467
+ this.botService.getWorkflowExecutionById(workflow_id).subscribe((res) => {
1468
+ if (res && res.Actions && Array.isArray(res.Actions)) {
1469
+ res.Actions = res.Actions.map((action) => {
1470
+ if (action.InsertTimeStamp) {
1471
+ action.InsertTimeStamp = formatTimeStamps(this.timezone, action.InsertTimeStamp);
1472
+ }
1473
+ return action;
1474
+ });
1475
+ }
1476
+ res.InsertTimeStamp = formatTimeStamps(this.timezone, res.InsertTimeStamp);
1477
+ this.workflowExecutionDetails = res;
1478
+ this.showWorkflowExecutionDetails = true;
1479
+ this.cdr.detectChanges();
1480
+ });
1481
+ }
1482
+ closeModal() {
1483
+ this.showWorkflowExecutionDetails = false;
1484
+ }
1485
+ objectToArray(obj) {
1486
+ return Object.keys(obj).map((key) => ({ key, value: obj[key] }));
1487
+ }
1488
+ startNewConversation() {
1489
+ this.conversationKey = this.conversationService.getKey(this.botId, true);
1490
+ this.chatLog = [this.chatLog[0]];
1491
+ this.isChatingWithAi = false;
1492
+ setTimeout(() => {
1493
+ this.initializeSocket();
1494
+ }, 200);
1495
+ this.scrollToBottom();
1496
+ this.cdr.detectChanges();
1497
+ }
1498
+ initializeSpeechRecognizer(token) {
1499
+ this.speechConfig = SpeechSDK.SpeechConfig.fromAuthorizationToken(token, this.region);
1500
+ const audioConfig = SpeechSDK.AudioConfig.fromDefaultMicrophoneInput();
1501
+ this.recognizer = new SpeechSDK.SpeechRecognizer(this.speechConfig, audioConfig);
1502
+ this.recognizer.recognizing = (s, e) => {
1503
+ if (e.result.reason === SpeechSDK.ResultReason.RecognizingSpeech) {
1504
+ this.input = e.result.text;
1505
+ console.log(`Recognizing: ${e.result.text}`);
1506
+ this.cdr.markForCheck();
1507
+ }
1508
+ };
1509
+ this.recognizer.recognized = (s, e) => {
1510
+ if (e.result.reason === SpeechSDK.ResultReason.RecognizedSpeech) {
1511
+ this.input = e.result.text;
1512
+ console.log(`Recognized: ${e.result.text}`);
1513
+ this.toggleRecording();
1514
+ this.cdr.markForCheck();
1515
+ }
1516
+ };
1517
+ this.recognizer.canceled = (s, e) => {
1518
+ console.error('Canceled: ', e.errorDetails);
1519
+ };
1520
+ this.recognizer.sessionStopped = (s, e) => {
1521
+ console.log('Session stopped.');
1522
+ this.recognizer.stopContinuousRecognitionAsync();
1523
+ this.fetchData();
1524
+ };
1525
+ }
1526
+ toggleRecording() {
1527
+ this.isRecording = !this.isRecording;
1528
+ if (this.isRecording) {
1529
+ this.startRecognition();
1530
+ }
1531
+ else {
1532
+ this.stopRecognition();
1533
+ }
1534
+ }
1535
+ startRecognition() {
1536
+ this.recognizer.startContinuousRecognitionAsync();
1537
+ }
1538
+ stopRecognition() {
1539
+ this.recognizer.stopContinuousRecognitionAsync();
1540
+ }
1541
+ checkForCop29BotId() {
1542
+ return this.botId == '66fa3f276c5d71e2717bfea8';
1543
+ }
1544
+ }
1545
+ ChatDrawerComponent.decorators = [
1546
+ { type: Component, args: [{
1547
+ selector: 'hivegpt-chat-drawer-package',
1548
+ template: "<button *ngIf=\"isShowEditorButton\" (click)=\"openOuterEditor()\" class=\"fixed-btn\">\n <span style=\"font-size: 12px\" class=\"material-icons notranslate\">\n create\n </span>\n Editor\n</button>\n\n<button *ngIf=\"!isShowEditorButton\" (click)=\"onCloseEditor()\" class=\"fixed-btn-close\">\n <span style=\"font-size: 12px\" class=\"material-icons notranslate\">\n close\n </span>\n Close\n</button>\n\n<mat-drawer-container class=\"hivegpt-chat-wrapper\" [ngClass]=\"{ 'mat-drawer-container-has-open': isDrawerOpen }\"\n [class.ios-device]=\"isIOSDevice\" [hasBackdrop]=\"hasBackdropValue\">\n <mat-drawer class=\"drawer\" #drawer [position]=\"'start'\" [mode]=\"'over'\" opened=\"true\"\n [class.full-width-drawer]=\"fullView\" [style.background]=\"\n 'linear-gradient(' + (bgGradient ? bgGradient.join(', ') : '') + ')'\n \">\n <mat-drawer-content>\n <div class=\"chat-main\">\n <!-- <div class=\"chat-header\">\n <h2> -->\n <!-- {{eventName}} -->\n <!-- </h2> -->\n <!-- <button class=\"closeIcon\" (click)=\"onClose()\">\n <span class=\"material-symbols-outlined\">\n close\n </span>\n </button> -->\n <!-- </div> -->\n\n <div class=\"innerChat\" #chatMain>\n <div (click)=\"startNewConversation()\" class=\"new-conversationbutton\">\n New Chat <span><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"14.061\" height=\"14.261\"\n viewBox=\"0 0 14.061 14.261\">\n <path id=\"Path_164\" data-name=\"Path 164\"\n d=\"M10.146,5.075H4.531A1.544,1.544,0,0,0,3,6.631v7.262A1.544,1.544,0,0,0,4.531,15.45h7.146a1.544,1.544,0,0,0,1.531-1.556V8.187m-7.146,4.15L15.25,3m0,0H11.677M15.25,3V6.631\"\n transform=\"translate(-2.25 -1.939)\" fill=\"none\" stroke=\"#06f\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" stroke-width=\"1.5\" />\n </svg>\n\n </span>\n </div>\n <div class=\"sticky-header-chat\">\n <div class=\"title_chat\">\n <h2>\n <span>\n {{ botName }}\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"31.499\" height=\"31.501\" viewBox=\"0 0 31.499 31.501\">\n <path id=\"Icon_ion-shield-checkmark\" data-name=\"Icon ion-shield-checkmark\"\n d=\"M33.685,7.83a1.125,1.125,0,0,0-.925-1.036,49.227,49.227,0,0,1-14.3-4.444,1.125,1.125,0,0,0-.927,0A49.226,49.226,0,0,1,3.24,6.794,1.125,1.125,0,0,0,2.315,7.83a27.621,27.621,0,0,0,1.718,11.9A24.572,24.572,0,0,0,9.07,27.641a25.712,25.712,0,0,0,8.513,6.028,1.125,1.125,0,0,0,.844,0,25.712,25.712,0,0,0,8.513-6.028,24.572,24.572,0,0,0,5.027-7.911,27.621,27.621,0,0,0,1.718-11.9Zm-9.211,5.281-7.791,9a1.125,1.125,0,0,1-.8.389h-.046a1.125,1.125,0,0,1-.788-.322L11.587,18.79a1.125,1.125,0,1,1,1.575-1.607l2.6,2.552,7.01-8.1a1.125,1.125,0,0,1,1.7,1.472Z\"\n transform=\"translate(-2.25 -2.25)\" fill=\"#06f\" />\n </svg>\n </span>\n <span>\n <p class=\"small-title\">AI-powered <span>copilot</span></p>\n </span>\n </h2>\n </div>\n <div class=\"chatType\" style=\"display: none\">\n <h4 class=\"labelChat\">Choose a conversation style</h4>\n <ul>\n <li (click)=\"changeTemperature(0)\">\n <button [ngClass]=\"{ active: temperature === 0 }\">\n <span class=\"top-section-title\"> More Creative </span>\n </button>\n </li>\n <li (click)=\"changeTemperature(1)\" class=\"fdssfd\">\n <button [ngClass]=\"{ active: temperature === 1 }\">\n <span class=\"top-section-title\"> More Balanced </span>\n </button>\n </li>\n <li (click)=\"changeTemperature(2)\">\n <button [ngClass]=\"{ active: temperature === 2 }\">\n <span class=\"top-section-title\"> More Precise </span>\n </button>\n </li>\n </ul>\n </div>\n </div>\n <!-- chattype -->\n <div id=\"allChats\" class=\"chat bot\" *ngFor=\"let chat of chatLog; let i = index\">\n <div class=\"chat-box\">\n <div class=\"message\">\n <div class=\"time-cta\" [ngClass]=\"{\n 'time-cta din': showFeedBackIconsIndex === i,\n 'time-cta': showFeedBackIconsIndex != i\n }\">\n <div class=\"Icon_TimeSTamp\" *ngIf=\"chat?.type === 'ai'\">\n <!-- <img [src]=\"botIcon\" [alt]=\"botName || 'Assistant'\" /> -->\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"44\" height=\"44\" viewBox=\"0 0 44 44\">\n <g id=\"Group_121\" data-name=\"Group 121\" transform=\"translate(4843 -371)\">\n <g id=\"Ellipse_18\" data-name=\"Ellipse 18\" transform=\"translate(-4843 371)\" fill=\"#fcfcfc\"\n stroke=\"#dfdfdf\" stroke-width=\"1\">\n <circle cx=\"22\" cy=\"22\" r=\"22\" stroke=\"none\" />\n <circle cx=\"22\" cy=\"22\" r=\"21.5\" fill=\"none\" />\n </g>\n <g id=\"Group_120\" data-name=\"Group 120\" transform=\"translate(-4835.141 378.855)\">\n <g id=\"Group_1\" data-name=\"Group 1\" transform=\"translate(7.29 0)\">\n <path id=\"Path_1\" data-name=\"Path 1\"\n d=\"M93.774,41.324,98.757,44.2v5.753l-4.983,2.877-4.983-2.877V44.2l4.983-2.877m0-2.034L87.03,43.183V50.97l6.744,3.893,6.744-3.893V43.183L93.774,39.29Z\"\n transform=\"translate(-87.03 -39.29)\" fill=\"gray\" />\n </g>\n <g id=\"Group_2\" data-name=\"Group 2\" transform=\"translate(0 12.717)\">\n <path id=\"Path_2\" data-name=\"Path 2\"\n d=\"M52.374,113.544l4.983,2.877v5.753l-4.983,2.877-4.983-2.877v-5.753l4.983-2.877m0-2.034L45.63,115.4v7.787l6.744,3.893,6.744-3.893V115.4l-6.744-3.893Z\"\n transform=\"translate(-45.63 -111.51)\" fill=\"gray\" />\n </g>\n <g id=\"Group_3\" data-name=\"Group 3\" transform=\"translate(14.793 12.717)\">\n <path id=\"Path_3\" data-name=\"Path 3\"\n d=\"M136.384,113.544l4.983,2.877v5.753l-4.983,2.877-4.983-2.877v-5.753l4.983-2.877m0-2.034L129.64,115.4v7.787l6.744,3.893,6.744-3.893V115.4l-6.744-3.893Z\"\n transform=\"translate(-129.64 -111.51)\" fill=\"gray\" />\n </g>\n </g>\n </g>\n </svg>\n\n <div class=\"dateTime\" [style.color]=\"dateTimeColor ? '' : ''\">\n <span>{{ 'Assistant' }}</span> {{ chat?.time }}\n </div>\n </div>\n\n <div class=\"Icon_TimeSTamp\" *ngIf=\"chat?.type === 'user'\">\n <div class=\"user-Box\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"44\" height=\"44\" viewBox=\"0 0 44 44\">\n <g id=\"Ellipse_17\" data-name=\"Ellipse 17\" fill=\"#fcfcfc\" stroke=\"#dfdfdf\" stroke-width=\"1\">\n <circle cx=\"22\" cy=\"22\" r=\"22\" stroke=\"none\" />\n <circle cx=\"22\" cy=\"22\" r=\"21.5\" fill=\"none\" />\n </g>\n <path id=\"Icon_grommet-user-expert\" data-name=\"Icon grommet-user-expert\"\n d=\"M14.24,20.443a9.472,9.472,0,1,0-9.472-9.472,9.472,9.472,0,0,0,9.472,9.472Zm10.329,5.225c-1.957-3.347-6.516-5.225-10.329-5.225-3.145,0-8.046.805-10.761,5.225\"\n transform=\"translate(7.976 8.416)\" fill=\"none\" stroke=\"gray\" stroke-width=\"1.5\" />\n </svg>\n\n <div class=\"dateTime\"><span>You</span> {{ chat?.time }}\n </div>\n </div>\n <div class=\"bards\">\n <div class=\"bars\" *ngIf=\"chat?.WorkflowExecutionId || chat?.showWorkflowExecutionLoader\">\n <button class=\"icon-button\" (click)=\"showWorkflowHistoryDetails(chat.WorkflowExecutionId)\">\n <i class=\"fas fa-bars\"></i>\n </button>\n </div>\n </div>\n\n </div>\n </div>\n <div class=\"researchingCard\">\n <div *ngIf=\"\n (chat?.searchTerms && chat?.searchTerms.length > 0) ||\n (chat?.sourcesList && chat?.sourcesList.length > 0)\n \" class=\"card-header d-flex align-items-center\" (click)=\"toggleCollapse()\">\n <span class=\"icon\"><i class=\"bx bx-plus-circle bx-sm\"></i></span>\n <span class=\"ml-2\">Researching\n <i id=\"toggleIcon\" class=\"toggle-icon ml-2 fa\" [ngClass]=\"{\n 'fa-chevron-down': isCollapsed,\n 'fa-chevron-up': !isCollapsed\n }\"></i></span>\n </div>\n <div *ngIf=\"chat?.searchTerms && chat?.searchTerms.length > 0\" [ngClass]=\"{ collapse: isCollapsed }\">\n <ul class=\"list-group list-group-flush uptList\">\n <li *ngFor=\"let term of chat?.searchTerms\" class=\"list-group-item\">\n Searching for\n <strong>{{ term }}</strong>\n </li>\n </ul>\n\n <h5 class=\"mt-2\" *ngIf=\"chat?.sourcesList && chat?.sourcesList.length > 0\">\n <i class=\"bx bx-unite\"></i> Sources\n </h5>\n <div class=\"sources-container\" *ngIf=\"chat?.sourcesList && chat?.sourcesList.length > 0\">\n <div class=\"source-card\" *ngFor=\"\n let source of chat?.displayedSources;\n let i = index\n \">\n <div>\n <div class=\"source-title\">{{ source.title }}</div>\n <div class=\"source-url\">\n <img class=\"relative block\" [src]=\"getFaviconUrl(source.link)\"\n [alt]=\"getDomainName(source.link) + ' favicon'\" />\n {{ getDomainName(source.link) }}\n </div>\n <div class=\"popup\">\n <div class=\"source-url\" (click)=\"openLinkInNewTab(source.link)\">\n <img class=\"relative block\" [src]=\"getFaviconUrl(source.link)\"\n [alt]=\"getDomainName(source.link) + ' favicon'\" />\n {{ getDomainName(source.link) }}\n </div>\n <h5 (click)=\"openLinkInNewTab(source.link)\">\n {{ source.title }}\n </h5>\n <p (click)=\"openLinkInNewTab(source.link)\">\n {{ source.desc }}\n </p>\n </div>\n </div>\n </div>\n <ng-container *ngIf=\"\n chat?.remainingSources &&\n chat?.remainingSources.length > 0\n \">\n <div class=\"source-card\" (click)=\"onCardClick(chat?.sourcesList)\">\n <div>\n <div class=\"source-title\">\n <img *ngFor=\"\n let source of chat?.remainingSources;\n let i = index\n \" class=\"relative block\" [src]=\"getFaviconUrl(source.link)\"\n [alt]=\"getDomainName(source.link) + ' favicon'\" />\n </div>\n <div class=\"source-url\">\n View {{ chat?.remainingSources.length }} more\n </div>\n </div>\n </div>\n </ng-container>\n </div>\n </div>\n </div>\n\n <div *ngIf=\"chat?.type === 'ai' || chat?.type === 'user'\" [ngStyle]=\"{\n background:\n chat?.type === 'ai' && bgBubbleAi\n ? ''\n : chat?.type === 'user' && bgBubbleUser\n ? ''\n : ''\n }\">\n <div id=\"messageText_{{ i }}\">\n <p *ngIf=\"chat?.type === 'ai' || chat?.type === 'user'\" [ngClass]=\"{\n 'SearchTitle ai': chat?.type === 'ai',\n 'SearchTitle user': chat?.type === 'user'\n }\" [ngStyle]=\"{\n background: chat?.type === 'ai' && messageTextColorAi ? messageTextColorAi : (chat?.type === 'user' && messageTextColorUser ? messageTextColorUser : 'defaultBackground'),\n color: chat?.type === 'ai' && messageTextColorAi ? messageTextColorAi : (chat?.type === 'user' && messageTextColorUser ? messageTextColorUser : 'defaultColor')\n }\" [innerHTML]=\"chat?.message\">\n </p>\n </div>\n </div>\n\n <div class=\"progress-container\" *ngIf=\"chat?.showWorkflowExecutionLoader\">\n <div class=\"circular-loader\">\n <div class=\"loader-spinner\" *ngIf=\"currentWorkflowActionProgress < 100\"\n [ngStyle]=\"{ 'transform': 'rotate(' + (percentage * 3.6) + 'deg)' }\">\n </div>\n <div class=\"checkmark\" *ngIf=\"currentWorkflowActionProgress == 100\">\n <svg viewBox=\"0 0 52 52\">\n <circle class=\"checkmark-circle\" cx=\"26\" cy=\"26\" r=\"25\" fill=\"none\" />\n <path class=\"checkmark-check\" fill=\"none\" d=\"M14 27l7 7 16-16\" />\n </svg>\n </div>\n\n <div class=\"loader-text\" *ngIf=\"currentWorkflowActionProgress < 100\">{{\n currentWorkflowActionProgress\n }}%</div>\n </div>\n <div class=\"loader-label\">\n {{currentWorkflowAction}}...\n </div>\n </div>\n\n <div class=\"exicution mt-2\" *ngIf=\"\n chat?.type === 'ai' &&\n chat?.graphs &&\n chat?.graphs.length > 0\n \">\n <h5 *ngIf=\"chat?.type === 'ai'\">\n <i class=\"bx bx-network-chart\"></i> Graphs\n <i (click)=\"toggleCollapseFGraph()\" class=\"toggle-icon ml-2 fa\" [ngClass]=\"{\n 'fas fa-chevron-down': isCollapsedForFGraph,\n 'fas fa-chevron-up': !isCollapsedForFGraph\n }\"></i>\n </h5>\n <img *ngFor=\"let image of chat?.graphs\" class=\"graph-img\"\n [ngClass]=\"{ collapse: isCollapsedForFGraph }\" [src]=\"image\" alt=\"\" />\n </div>\n <ng-container *ngIf=\"!checkForCop29BotId()\">\n <div class=\"exicution mt-2\" *ngIf=\"\n chat?.type === 'ai' &&\n chat?.executionGraphs &&\n chat?.executionGraphs?.length > 0\n \">\n <h5 *ngIf=\"chat?.type === 'ai'\">\n <i class=\"bx bx-network-chart\"></i> Execution Path Diagram\n For Data Visualization Workflow\n <i (click)=\"toggleCollapseGraph()\" class=\"toggle-icon ml-2 fa\" [ngClass]=\"{\n 'fas fa-chevron-down': isCollapsedForGraph,\n 'fas fa-chevron-up': !isCollapsedForGraph\n }\"></i>\n </h5>\n <img *ngFor=\"let image of chat?.executionGraphs\" class=\"graph-img\"\n [ngClass]=\"{ collapse: isCollapsedForGraph }\" [src]=\"image\" alt=\"\" />\n </div>\n </ng-container>\n <div class=\"Related mt-2\" *ngIf=\"\n showFeedBackIconsIndex === i &&\n chat?.relatedListItems &&\n chat?.relatedListItems.length > 0\n \">\n <h5 *ngIf=\"chat?.type === 'ai'\">\n <i class=\"bx bx-list-check\"></i> Related\n </h5>\n <div class=\"card-container\" *ngIf=\"chat?.type === 'ai'\">\n <ul class=\"list-container\">\n <ng-container *ngFor=\"let item of chat?.relatedListItems\">\n <li (click)=\"fetchDataFor(item, chat)\">{{ item }}</li>\n </ng-container>\n </ul>\n </div>\n </div>\n </div>\n\n <div class=\"cta\" *ngIf=\"showFeedBackIconsIndex === i\">\n <div class=\"copyBox\" title=\"Copy\">\n <button title=\"{{ chat?.copied ? 'Copied!' : 'Copy' }}\" class=\"copy\" [class.active]=\"chat?.copied\"\n (click)=\"handleCopyClick(i)\">\n <i *ngIf=\"chat?.copied\">\n <svg width=\"18\" height=\"18\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M9 16.17L4.83 12L3.41 13.41L9 19L21 7L19.59 5.59L9 16.17Z\" fill=\"#566563\" />\n </svg>\n </i>\n\n <i *ngIf=\"!chat?.copied\">\n <svg width=\"18\" height=\"18\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n d=\"M19.24 2H8.84C8.14 2 7.58 2.56 7.58 3.26V16.84C7.58 17.54 8.14 18.1 8.84 18.1H19.24C19.94 18.1 20.5 17.54 20.5 16.84V3.26C20.5 2.56 19.94 2 19.24 2ZM19.24 16.84H8.84V3.26H19.24V16.84ZM4.74 6.52C4.04 6.52 3.48 7.08 3.48 7.78V20.36C3.48 21.06 4.04 21.62 4.74 21.62H15.14C15.84 21.62 16.4 21.06 16.4 20.36V18.88H14.96V20.36H4.74V7.78H6.18V6.52H4.74Z\"\n fill=\"#566563\" />\n </svg>\n </i>\n </button>\n\n <button class=\"up copy\" title=\"{{ chat?.isEditor ? 'Added!' : 'Add to editor' }}\"\n (click)=\"handleEditorClick(i)\">\n <svg *ngIf=\"!chat?.isEditor\" xmlns=\"http://www.w3.org/2000/svg\" width=\"20.152\" height=\"20.152\"\n viewBox=\"0 0 20.152 20.152\">\n <g id=\"Icon_feather-edit\" data-name=\"Icon feather-edit\" transform=\"translate(-2.5 -2.166)\">\n <path id=\"Path_166\" data-name=\"Path 166\"\n d=\"M11.5,6H4.889A1.889,1.889,0,0,0,3,7.889v13.22A1.889,1.889,0,0,0,4.889,23h13.22A1.889,1.889,0,0,0,20,21.108V14.5\"\n transform=\"translate(0 -1.179)\" fill=\"none\" stroke=\"#393939\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" stroke-width=\"1\" />\n <path id=\"Path_167\" data-name=\"Path 167\"\n d=\"M21.915,3.4a2,2,0,0,1,2.833,2.833l-8.971,8.971L12,16.152l.944-3.777Z\"\n transform=\"translate(-3.334 0)\" fill=\"none\" stroke=\"#393939\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" stroke-width=\"1\" />\n </g>\n </svg>\n\n <i *ngIf=\"chat?.isEditor\">\n <svg width=\"18\" height=\"18\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M9 16.17L4.83 12L3.41 13.41L9 19L21 7L19.59 5.59L9 16.17Z\" fill=\"#566563\" />\n </svg>\n </i>\n </button>\n\n <button class=\"up copy\" title=\"Like\" [class.active]=\"chat?.liked\" (click)=\"handleUpClick(i)\">\n <i *ngIf=\"chat?.liked\">\n <svg width=\"18\" height=\"18\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n d=\"M8.38989 18.4902V8.33022C8.38989 7.93022 8.50989 7.54022 8.72989 7.21022L11.4599 3.15022C11.8899 2.50022 12.9599 2.04022 13.8699 2.38022C14.8499 2.71022 15.4999 3.81022 15.2899 4.79022L14.7699 8.06022C14.7299 8.36022 14.8099 8.63022 14.9799 8.84022C15.1499 9.03022 15.3999 9.15022 15.6699 9.15022H19.7799C20.5699 9.15022 21.2499 9.47022 21.6499 10.0302C22.0299 10.5702 22.0999 11.2702 21.8499 11.9802L19.3899 19.4702C19.0799 20.7102 17.7299 21.7202 16.3899 21.7202H12.4899C11.8199 21.7202 10.8799 21.4902 10.4499 21.0602L9.16989 20.0702C8.67989 19.7002 8.38989 19.1102 8.38989 18.4902Z\"\n fill=\"#17235B\" />\n <path\n d=\"M5.21 6.37988H4.18C2.63 6.37988 2 6.97988 2 8.45988V18.5199C2 19.9999 2.63 20.5999 4.18 20.5999H5.21C6.76 20.5999 7.39 19.9999 7.39 18.5199V8.45988C7.39 6.97988 6.76 6.37988 5.21 6.37988Z\"\n fill=\"#17235B\" />\n </svg>\n </i>\n <i *ngIf=\"!chat?.liked\">\n <svg width=\"18\" height=\"18\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n d=\"M10.4037 20.9264L10.381 20.9038L10.3557 20.8843L7.72165 18.85L8.02965 18.4516L10.7161 20.5315C10.9228 20.7195 11.2181 20.8517 11.4962 20.9377C11.7978 21.0309 12.1451 21.09 12.4801 21.09H16.2801C16.8572 21.09 17.4266 20.8625 17.8751 20.5306C18.3159 20.2044 18.6912 19.7385 18.8305 19.1997L21.2428 11.8732C21.4379 11.3309 21.4287 10.749 21.0965 10.2887C20.7583 9.81377 20.1844 9.58999 19.5801 9.58999H15.5801C15.2031 9.58999 14.8615 9.43143 14.6276 9.16215L14.627 9.16142C14.3873 8.88649 14.2756 8.51549 14.3345 8.11501L14.8322 4.9195C14.9978 4.1052 14.4664 3.24596 13.7053 2.98804C13.3277 2.85165 12.9297 2.89129 12.61 2.99839C12.2949 3.10396 11.9772 3.30172 11.7881 3.57673L11.7881 3.57671L11.7851 3.58107L7.96352 9.26689L7.55454 8.99314L11.3751 3.30891L11.3755 3.30836C11.8763 2.56103 13.0109 2.19028 13.8726 2.51744L13.8834 2.52151L13.8943 2.52509C14.9044 2.8564 15.556 3.98765 15.3317 5.01314L15.3284 5.02805L15.326 5.04314L14.836 8.19314L14.836 8.19313L14.8351 8.19928C14.8184 8.31642 14.7981 8.60268 15.0138 8.84924L15.0248 8.86177L15.0366 8.87354C15.1833 9.02026 15.3817 9.09999 15.5901 9.09999H19.5901C20.4308 9.09999 21.1176 9.44886 21.5113 10.0079L21.5124 10.0095C21.8964 10.5502 21.9908 11.2849 21.7202 12.0291L21.7175 12.0365L21.7151 12.044L19.3251 19.324L19.3198 19.34L19.3156 19.3564C19.0058 20.5707 17.6766 21.6 16.2801 21.6H12.4801C12.2411 21.6 11.8403 21.5625 11.4297 21.4512C11.0123 21.338 10.6406 21.1633 10.4037 20.9264Z\"\n fill=\"#566563\" stroke=\"#566563\" />\n <path\n d=\"M5.37988 20.4999H4.37988C3.52442 20.4999 2.98559 20.2982 2.65822 19.9825C2.33437 19.6702 2.12988 19.1614 2.12988 18.3499V8.5499C2.12988 7.73843 2.33437 7.22962 2.65822 6.91731C2.98559 6.6016 3.52442 6.3999 4.37988 6.3999H5.37988C6.23534 6.3999 6.77418 6.6016 7.10155 6.91731C7.4254 7.22962 7.62988 7.73843 7.62988 8.5499V18.3499C7.62988 19.1614 7.4254 19.6702 7.10155 19.9825C6.77418 20.2982 6.23534 20.4999 5.37988 20.4999ZM4.37988 6.8999C4.0934 6.8999 3.83578 6.9164 3.61382 6.96689C3.38745 7.01838 3.16822 7.11196 2.99258 7.2876C2.81559 7.46459 2.72807 7.67966 2.68301 7.89002C2.63948 8.09318 2.62988 8.31967 2.62988 8.5499V18.3499C2.62988 18.5801 2.63948 18.8066 2.68301 19.0098C2.72807 19.2201 2.81559 19.4352 2.99258 19.6122C3.16822 19.7878 3.38745 19.8814 3.61382 19.9329C3.83578 19.9834 4.0934 19.9999 4.37988 19.9999H5.37988C5.66637 19.9999 5.92398 19.9834 6.14595 19.9329C6.37232 19.8814 6.59155 19.7878 6.76719 19.6122C6.94418 19.4352 7.0317 19.2201 7.07676 19.0098C7.12028 18.8066 7.12988 18.5801 7.12988 18.3499V8.5499C7.12988 8.31967 7.12028 8.09318 7.07676 7.89002C7.0317 7.67966 6.94418 7.46459 6.76719 7.2876C6.59155 7.11196 6.37232 7.01838 6.14595 6.96689C5.92398 6.9164 5.66637 6.8999 5.37988 6.8999H4.37988Z\"\n fill=\"#566563\" stroke=\"#566563\" />\n </svg>\n </i>\n </button>\n <button class=\"down copy\" title=\"Dislike\" [class.active]=\"chat?.unliked\" (click)=\"handleDownClick(i)\">\n <i *ngIf=\"chat?.unliked\">\n <svg width=\"18\" height=\"18\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n d=\"M15.61 5.50002V15.66C15.61 16.06 15.49 16.45 15.27 16.78L12.54 20.84C12.11 21.49 11.04 21.95 10.13 21.61C9.15002 21.28 8.50002 20.18 8.71002 19.2L9.23002 15.93C9.27002 15.63 9.19002 15.36 9.02002 15.15C8.85002 14.96 8.60002 14.84 8.33002 14.84H4.22002C3.43002 14.84 2.75002 14.52 2.35002 13.96C1.97002 13.42 1.90002 12.72 2.15002 12.01L4.61002 4.52002C4.92002 3.28002 6.27002 2.27002 7.61002 2.27002H11.51C12.18 2.27002 13.12 2.50002 13.55 2.93002L14.83 3.92002C15.32 4.30002 15.61 4.88002 15.61 5.50002Z\"\n fill=\"#17235B\" />\n\n <path\n d=\"M18.7901 17.6099H19.8201C21.3701 17.6099 22.0001 17.0099 22.0001 15.5299V5.4799C22.0001 3.9999 21.3701 3.3999 19.8201 3.3999H18.7901C17.2401 3.3999 16.6101 3.9999 16.6101 5.4799V15.5399C16.6101 17.0099 17.2401 17.6099 18.7901 17.6099Z\"\n fill=\"#17235B\" />\n </svg>\n </i>\n\n <i *ngIf=\"!chat?.unliked\">\n <svg width=\"18\" height=\"18\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n d=\"M10.1237 21.481L10.1148 21.4778L10.1059 21.4748C9.09577 21.1435 8.44416 20.0122 8.66849 18.9867L8.67175 18.9718L8.6741 18.9568L9.1641 15.8068L9.16413 15.8068L9.16501 15.8006C9.18175 15.6835 9.20207 15.3972 8.98633 15.1507L8.97536 15.1381L8.96359 15.1263C8.81687 14.9796 8.61841 14.8999 8.41004 14.8999H4.41004C3.56937 14.8999 2.88252 14.551 2.48884 13.992L2.4877 13.9904C2.10371 13.4497 2.00931 12.715 2.27994 11.9708L2.28263 11.9634L2.28509 11.9559L4.67509 4.67586L4.68035 4.65985L4.68451 4.64353C4.99418 3.42996 6.33271 2.3999 7.72004 2.3999H11.52C11.7591 2.3999 12.1599 2.43736 12.5704 2.54872C12.9878 2.66194 13.3596 2.83655 13.5965 3.07346L13.6191 3.09608L13.6444 3.11563L16.2785 5.14986L15.9705 5.54825L13.2875 3.47111C13.0799 3.2763 12.7837 3.1413 12.5061 3.05412C12.2031 2.95897 11.8551 2.8999 11.52 2.8999H7.72004C7.1429 2.8999 6.57353 3.12735 6.12508 3.45926C5.68428 3.78551 5.30892 4.25142 5.16963 4.79019L2.75738 12.1167C2.56223 12.659 2.57147 13.2409 2.90366 13.7012C3.24183 14.1761 3.81578 14.3999 4.42004 14.3999H8.42004C8.79702 14.3999 9.13867 14.5585 9.37252 14.8277L9.37315 14.8285C9.61286 15.1034 9.72457 15.4745 9.66568 15.875C9.6656 15.8755 9.66552 15.8761 9.66544 15.8766L9.16795 19.0704C9.00242 19.8841 9.53299 20.7428 10.2933 21.0013C10.6685 21.1391 11.0675 21.0978 11.3857 20.9917C11.7001 20.8869 12.0218 20.6898 12.2121 20.4132L12.2121 20.4132L12.215 20.4088L16.0351 14.7253L16.4472 15.0045L12.6251 20.691L12.6249 20.6912C12.259 21.2361 11.5347 21.5999 10.8 21.5999C10.5668 21.5999 10.3358 21.5596 10.1237 21.481Z\"\n fill=\"#566563\" stroke=\"#566563\" />\n <path\n d=\"M19.6201 17.6H18.6201C17.7647 17.6 17.2258 17.3983 16.8985 17.0826C16.5746 16.7703 16.3701 16.2615 16.3701 15.45V5.65C16.3701 4.83853 16.5746 4.32972 16.8985 4.0174C17.2258 3.7017 17.7647 3.5 18.6201 3.5H19.6201C20.4756 3.5 21.0144 3.7017 21.3418 4.0174C21.6656 4.32972 21.8701 4.83853 21.8701 5.65V15.45C21.8701 16.2615 21.6656 16.7703 21.3418 17.0826C21.0144 17.3983 20.4756 17.6 19.6201 17.6ZM18.6201 4C18.3336 4 18.076 4.01649 17.8541 4.06699C17.6277 4.11848 17.4085 4.21206 17.2328 4.3877C17.0558 4.56469 16.9683 4.77976 16.9232 4.99011C16.8797 5.19328 16.8701 5.41977 16.8701 5.65V15.45C16.8701 15.6802 16.8797 15.9067 16.9232 16.1099C16.9683 16.3202 17.0558 16.5353 17.2328 16.7123C17.4085 16.8879 17.6277 16.9815 17.8541 17.033C18.076 17.0835 18.3336 17.1 18.6201 17.1H19.6201C19.9066 17.1 20.1642 17.0835 20.3862 17.033C20.6126 16.9815 20.8318 16.8879 21.0074 16.7123C21.1844 16.5353 21.2719 16.3202 21.317 16.1099C21.3605 15.9067 21.3701 15.6802 21.3701 15.45V5.65C21.3701 5.41977 21.3605 5.19328 21.317 4.99011C21.2719 4.77976 21.1844 4.56469 21.0074 4.3877C20.8318 4.21206 20.6126 4.11848 20.3862 4.06699C20.1642 4.01649 19.9066 4 19.6201 4H18.6201Z\"\n fill=\"#566563\" stroke=\"#566563\" />\n </svg>\n </i>\n </button>\n </div>\n </div>\n\n </div>\n\n <div class=\"cta-faqs quick-prompts-extended\" *ngIf=\"i == 0 && quickPrompts?.length\">\n <!-- <div *ngFor=\"let tile of quickPrompts\" class=\"cta\"\n (click)=\"sendMessageWithTile(tile.prompt)\">\n Q: {{ tile.text }}\n </div> -->\n <div class=\"cta_suggestions\">\n <button *ngFor=\"let tile of quickPrompts\" (click)=\"sendMessageWithTile(tile.prompt)\">\n <ng-container *ngIf=\"tile\">{{ tile.text }}</ng-container>\n </button>\n </div>\n </div>\n <div class=\"chat bot\" *ngIf=\"i == 0 && botSkills\">\n <div class=\"chat-box\">\n <div class=\"message\">\n <p [innerHTML]=\"processMessageForDisplay(botSkills)\"></p>\n &nbsp;\n </div>\n </div>\n </div>\n <div *ngIf=\"chat?.suggestions?.length\">\n <h4 class=\"labelChat\">\n Here are some things EventsGPT Copilot can help you do:\n </h4>\n <div class=\"cta_suggestions\">\n <button *ngFor=\"let suggestion of chat?.suggestions\" (click)=\"sendMessageWithTile(suggestion)\">\n <ng-container *ngIf=\"suggestion\">{{\n suggestion\n }}</ng-container>\n </button>\n </div>\n </div>\n <div *ngIf=\"\n chat?.action?.section_id == 'company_search' ||\n chat?.action?.section_id == 'user_search' ||\n chat?.action?.section_id == 'industry_company_search'\n \">\n <div class=\"box\">\n <div class=\"tiktokwrapper\">\n <div class=\"tiktokshell\" *ngFor=\"let user of chat?.action.users\">\n <div class=\"videoPhotobox\">\n <ng-conatiner *ngIf=\"user?.photoPath && !user.userVideosModel\">\n <img [src]=\"user?.photoPath\" />\n </ng-conatiner>\n <ng-conatiner *ngIf=\"user.userVideosModel\">\n <app-video-player *ngIf=\"user?.userVideosModel\" [isDev]=\"isDev\" [currentUserId]=\"userId\"\n [videoObj]=\"user?.userVideosModel\" [user]=\"user\" [eventId]=\"eventId\" type=\"1\">\n </app-video-player>\n </ng-conatiner>\n </div>\n\n <div class=\"noPhoto\" *ngIf=\"!user?.photoPath && !user.userVideosModel\">\n <h3>\n {{ user.firstName | slice: 0:1\n }}{{ user.lastName | slice: 0:1 }}\n </h3>\n </div>\n <div class=\"overlymask\" *ngIf=\"!user.userVideosModel\"></div>\n <div class=\"onshell-content\">\n <div class=\"title-shell\">\n <h3>{{ user.firstName }} {{ user.lastName }}</h3>\n <h3 class=\"companyName\">{{ user.company }}</h3>\n </div>\n <div class=\"button-shell\">\n <button class=\"Connectbtn\" (click)=\"connectToUser(user.userId)\">\n {{\n canConnect(user.userId)\n ? 'Connect'\n : canDisconnect(user.userId)\n ? 'Disconnect'\n : 'Request\n Sent'\n }}\n </button>\n <button class=\"schedulebtn\" (click)=\"scheduleMeetingWithUser(user)\">\n Schedule\n </button>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div *ngIf=\"chat?.action?.section_id == myUpcomingSessionAction\">\n <div class=\"agenda-items-wrapper\" class=\"agenda-items-wrapper\">\n <div class=\"list-view\">\n <div class=\"session-detail-wrapper card-background-session\"\n *ngFor=\"let upcomingSession of chat?.action.content\">\n <div class=\"thumbnail\">\n <img alt=\"Introduction to the Imaging Radar Academy\"\n src=\"https://s27media.azureedge.net/8008/profile_pic/453cea2c-feba-11ed-8c0b-00155d025b0a.png\"\n class=\"\" />\n <!---->\n <!---->\n <!----><button class=\"play-btn color-primary\"\n title=\"Play Session: Introduction to the Imaging Radar Academy\">\n <span class=\"material-icons notranslate\">\n play_circle_outline\n </span>\n <!---->\n </button>\n <!---->\n <!---->\n </div>\n <!---->\n <!---->\n <div class=\"content p-3\">\n <div class=\"d-flex justify-content-between align-items-center\">\n <div class=\"d-flex flex-column\">\n <p class=\"fs-xs mb-0 body-text-color\">\n {{\n upcomingSession.dateTimeRange.start\n | date\n : 'MM-dd-yyyy\n HH:mm'\n : 'UTC'\n }}\n -\n {{\n upcomingSession.dateTimeRange.end\n | date: 'MM-dd-yyyy HH:mm':'UTC'\n }}\n {{ upcomingSession.timeZone.id }}\n </p>\n <!---->\n <!---->\n <!-- <p class=\"fs-xs mb-2 color-secondary\" title=\"Session Type: Generative AI\">Generative AI </p> -->\n <!---->\n </div>\n <div class=\"d-flex align-items-center actions px-2\">\n <!---->\n <button (click)=\"\n performSessionAction(\n upcomingSession.id,\n 'view-session'\n )\n \" class=\"s27-btn-icon body-text-color\"\n title=\"View Session Information: Introduction to the Imaging Radar Academy\">\n <span class=\"material-icons notranslate\">\n remove_red_eye\n </span>\n </button>\n\n <button (click)=\"\n performSessionAction(\n upcomingSession.id,\n 'add-to-agenda'\n )\n \" class=\"s27-btn-icon body-text-color\">\n <span class=\"material-icons notranslate\"\n title=\"Add Session: Introduction to the Imaging Radar Academy to My agendaa\">\n event_available\n </span>\n </button>\n <!---->\n <!---->\n <!---->\n <!---->\n\n <button (click)=\"\n performSessionAction(upcomingSession.id, 'play')\n \" class=\"s27-btn-icon body-text-color\" title=\"Copy session link to share\">\n <span class=\"material-icons notranslate\">\n play_circle_outline\n </span>\n </button>\n <!---->\n </div>\n </div>\n <h2 class=\"body-text-color\">\n {{ upcomingSession.title }}\n </h2>\n <div class=\"session-description color-secondary\"\n [innerHTML]=\"sanitizeHtml(upcomingSession.description)\">\n </div>\n <ul class=\"speakers grid-2-cols\" *ngFor=\"let speakerId of upcomingSession.speakers\">\n <li class=\"\">\n <div class=\"image\" title=\"Blair Wunderlich\">\n <img alt=\"Blair Wunderlich\" [src]=\"speakers[speakerId]?.photoPath\" class=\"\" />\n <!---->\n <!---->\n <!---->\n </div>\n <!---->\n <div class=\"content pl-3\" style=\"text-transform: none\">\n <div class=\"mb-0 body-text-color fs-xs fw-500\">\n {{ speakers[speakerId]?.firstName }}\n {{ speakers[speakerId]?.lastName }}\n </div>\n <div class=\"color-secondary fs-xxs\">\n {{ speakers[speakerId]?.jobTitle }}\n </div>\n <div class=\"color-secondary fs-xxs\">\n {{ speakers[speakerId]?.company }}\n </div>\n </div>\n <!---->\n </li>\n </ul>\n <!---->\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <div class=\"chat bot\" *ngIf=\"isChatingWithAi && !executingWorkflow\">\n <div class=\"chat-box\">\n <div class=\"message\">\n <div class=\"o-media__body\">\n <div class=\"o-vertical-spacing\">\n <h3 class=\"blog-post__headline\">\n <span class=\"skeleton-box\" style=\"width: 55%\"></span>\n </h3>\n <p>\n <span class=\"skeleton-box\" style=\"width: 80%\"></span>\n <span class=\"skeleton-box\" style=\"width: 90%\"></span>\n <span class=\"skeleton-box\" style=\"width: 83%\"></span>\n <span class=\"skeleton-box\" style=\"width: 80%\"></span>\n </p>\n </div>\n </div>\n\n <div class=\"time-cta\">\n <div class=\"Icon_TimeSTamp\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"44\" height=\"44\" viewBox=\"0 0 44 44\">\n <g id=\"Group_121\" data-name=\"Group 121\" transform=\"translate(4843 -371)\">\n <g id=\"Ellipse_18\" data-name=\"Ellipse 18\" transform=\"translate(-4843 371)\" fill=\"#fcfcfc\"\n stroke=\"#dfdfdf\" stroke-width=\"1\">\n <circle cx=\"22\" cy=\"22\" r=\"22\" stroke=\"none\" />\n <circle cx=\"22\" cy=\"22\" r=\"21.5\" fill=\"none\" />\n </g>\n <g id=\"Group_120\" data-name=\"Group 120\" transform=\"translate(-4835.141 378.855)\">\n <g id=\"Group_1\" data-name=\"Group 1\" transform=\"translate(7.29 0)\">\n <path id=\"Path_1\" data-name=\"Path 1\"\n d=\"M93.774,41.324,98.757,44.2v5.753l-4.983,2.877-4.983-2.877V44.2l4.983-2.877m0-2.034L87.03,43.183V50.97l6.744,3.893,6.744-3.893V43.183L93.774,39.29Z\"\n transform=\"translate(-87.03 -39.29)\" fill=\"gray\" />\n </g>\n <g id=\"Group_2\" data-name=\"Group 2\" transform=\"translate(0 12.717)\">\n <path id=\"Path_2\" data-name=\"Path 2\"\n d=\"M52.374,113.544l4.983,2.877v5.753l-4.983,2.877-4.983-2.877v-5.753l4.983-2.877m0-2.034L45.63,115.4v7.787l6.744,3.893,6.744-3.893V115.4l-6.744-3.893Z\"\n transform=\"translate(-45.63 -111.51)\" fill=\"gray\" />\n </g>\n <g id=\"Group_3\" data-name=\"Group 3\" transform=\"translate(14.793 12.717)\">\n <path id=\"Path_3\" data-name=\"Path 3\"\n d=\"M136.384,113.544l4.983,2.877v5.753l-4.983,2.877-4.983-2.877v-5.753l4.983-2.877m0-2.034L129.64,115.4v7.787l6.744,3.893,6.744-3.893V115.4l-6.744-3.893Z\"\n transform=\"translate(-129.64 -111.51)\" fill=\"gray\" />\n </g>\n </g>\n </g>\n </svg>\n <div class=\"dateTime\" [style.color]=\"dateTimeColor ? '' : ''\">\n <span> {{ 'Assistant' }}</span> {{ chat?.time\n ? chat?.time\n : (dateTime.now | date: 'shortTime')\n }}\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"chat bot\" *ngIf=\"loading\">\n <div class=\"chat-box\">\n <div class=\"message\">\n <div class=\"o-media__body\">\n <div class=\"o-vertical-spacing\">\n <h3 class=\"blog-post__headline\">\n <span class=\"skeleton-box\" style=\"width: 55%\"></span>\n </h3>\n <p>\n <span class=\"skeleton-box\" style=\"width: 80%\"></span>\n <span class=\"skeleton-box\" style=\"width: 90%\"></span>\n <span class=\"skeleton-box\" style=\"width: 83%\"></span>\n <span class=\"skeleton-box\" style=\"width: 80%\"></span>\n </p>\n </div>\n </div>\n\n <div class=\"time-cta\">\n <div class=\"Icon_TimeSTamp\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"44\" height=\"44\" viewBox=\"0 0 44 44\">\n <g id=\"Group_121\" data-name=\"Group 121\" transform=\"translate(4843 -371)\">\n <g id=\"Ellipse_18\" data-name=\"Ellipse 18\" transform=\"translate(-4843 371)\" fill=\"#fcfcfc\"\n stroke=\"#dfdfdf\" stroke-width=\"1\">\n <circle cx=\"22\" cy=\"22\" r=\"22\" stroke=\"none\" />\n <circle cx=\"22\" cy=\"22\" r=\"21.5\" fill=\"none\" />\n </g>\n <g id=\"Group_120\" data-name=\"Group 120\" transform=\"translate(-4835.141 378.855)\">\n <g id=\"Group_1\" data-name=\"Group 1\" transform=\"translate(7.29 0)\">\n <path id=\"Path_1\" data-name=\"Path 1\"\n d=\"M93.774,41.324,98.757,44.2v5.753l-4.983,2.877-4.983-2.877V44.2l4.983-2.877m0-2.034L87.03,43.183V50.97l6.744,3.893,6.744-3.893V43.183L93.774,39.29Z\"\n transform=\"translate(-87.03 -39.29)\" fill=\"gray\" />\n </g>\n <g id=\"Group_2\" data-name=\"Group 2\" transform=\"translate(0 12.717)\">\n <path id=\"Path_2\" data-name=\"Path 2\"\n d=\"M52.374,113.544l4.983,2.877v5.753l-4.983,2.877-4.983-2.877v-5.753l4.983-2.877m0-2.034L45.63,115.4v7.787l6.744,3.893,6.744-3.893V115.4l-6.744-3.893Z\"\n transform=\"translate(-45.63 -111.51)\" fill=\"gray\" />\n </g>\n <g id=\"Group_3\" data-name=\"Group 3\" transform=\"translate(14.793 12.717)\">\n <path id=\"Path_3\" data-name=\"Path 3\"\n d=\"M136.384,113.544l4.983,2.877v5.753l-4.983,2.877-4.983-2.877v-5.753l4.983-2.877m0-2.034L129.64,115.4v7.787l6.744,3.893,6.744-3.893V115.4l-6.744-3.893Z\"\n transform=\"translate(-129.64 -111.51)\" fill=\"gray\" />\n </g>\n </g>\n </g>\n </svg>\n <div class=\"dateTime\" [style.color]=\"dateTimeColor ? '' : ''\">\n <span>{{ 'Loading ...' }}</span>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <!-- <div #chatMain></div> -->\n <div *ngIf=\"openWorkflowInput && selectedWorkflow && !executingWorkflow\" class=\"chatFooterWrapper\">\n <!-- new UI for Chat Message Section by Amit -->\n <div class=\"chat-footer-upt\">\n <div class=\"topinfo-containerbox\">\n <div class=\"agents_note_wrapper\">\n <div>\n <h6>{{selectedWorkflow?.Name}}</h6>\n {{selectedWorkflow?.Description}}\n </div>\n </div>\n\n <div class=\"agents_note_wrapper\">\n <button mat-icon-button class=\"closeButtonSource\" (click)=\"toggleWorkflows(false)\">\n <mat-icon>close</mat-icon>\n </button>\n </div>\n </div>\n <div class=\"bottombox-wrapper\">\n <!-- here i need to loop through all the input fields selectedWorkflow.Trigger.InputSchema and render the input fields -->\n <!-- Form for Workflow Inputs -->\n <form [formGroup]=\"workflowForm\" (ngSubmit)=\"onWorkflowSubmit()\" class=\"form-container\">\n <div *ngFor=\"let input of selectedWorkflow?.Trigger?.InputSchema\" class=\"form-group\">\n <label>{{ input.Label }}</label>\n\n <!-- Handle Text Input or Text Area based on requirement -->\n <textarea *ngIf=\"input.Type === 'string'\" formControlName=\"{{input.InputId}}\"\n [placeholder]=\"input.Placeholder\" [rows]=\"2\" [required]=\"input.Required\"\n class=\"form-control\"></textarea>\n\n <!-- Dropdown for Select Options -->\n <select *ngIf=\"input.Type === 'select'\" formControlName=\"{{input.InputId}}\" class=\"form-control\">\n <option *ngFor=\"let option of input.Options\" [value]=\"option.Value\">{{\n option.Label }}</option>\n </select>\n </div>\n\n <!-- Submit button aligned to the right -->\n <div class=\"form-group\">\n <button type=\"submit\" class=\"btn btn-primary submit-button\">Submit</button>\n </div>\n </form>\n </div>\n </div>\n\n\n <!-- new UI for Chat Message Section by Amit -->\n </div>\n <div *ngIf=\"!openWorkflowInput\" class=\"chatFooterWrapper\">\n <!-- new UI for Chat Message Section by Amit -->\n <div class=\"chat-footer-upt\">\n <div class=\"topinfo-containerbox\">\n <div class=\"agents_note_wrapper\">\n\n <div class=\"agents-dropdown-wrapper\">\n <div class=\"dropdown-wrapper\" (click)=\"toggleDropdown()\">\n <div class=\"dropdown-header\">\n <span>{{ getDropdownHeaderText() }}</span>\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" stroke=\"currentColor\"\n stroke-width=\"2\" viewBox=\"0 0 24 24\">\n <path d=\"M19 9l-7 7-7-7\" />\n </svg>\n </div>\n <div class=\"dropdown-menu\" *ngIf=\"isDropdownOpen\">\n <label (click)=\"onSelectAll()\">\n <input type=\"checkbox\" [checked]=\"areAllSelected()\" />\n All\n </label>\n <label *ngFor=\"let agent of agents\" (click)=\"onAgentChange(agent)\">\n <input type=\"checkbox\" [(ngModel)]=\"agent.selected\" />\n {{ agent.agentName }}\n </label>\n </div>\n </div>\n </div>\n\n </div>\n\n <div class=\"agents_note_wrapper\" *ngIf=\"!checkForCop29BotId()\">\n\n <div class=\"agents-dropdown-wrapper\">\n <div class=\"dropdown-wrapper\" (click)=\"toggleWorkflows()\">\n <div class=\"dropdown-header\">\n <svg stroke=\"currentColor\" fill=\"currentColor\" stroke-width=\"0\" viewBox=\"0 0 256 256\"\n class=\"h-5 w-5\" height=\"1.3em\" width=\"1.3em\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n d=\"M245.66,74.34l-32-32a8,8,0,0,0-11.32,11.32L220.69,72H192a74.49,74.49,0,0,0-28.35,6.73c-13.62,6.29-30.83,19.71-35.54,48-5.32,31.94-29.1,39.22-41,40.86a40,40,0,1,0,.18,16.06A71.65,71.65,0,0,0,108.13,178C121.75,172,139,158.6,143.89,129.31,150.65,88.77,190.34,88,192,88h28.69l-18.35,18.34a8,8,0,0,0,11.32,11.32l32-32A8,8,0,0,0,245.66,74.34ZM48,200a24,24,0,1,1,24-24A24,24,0,0,1,48,200Z\">\n </path>\n </svg>&nbsp;\n Workflows\n </div>\n <div class=\"dropdown-menu\" *ngIf=\"isWorkflowOpen\">\n <label *ngFor=\"let orgWorkflow of orgWorkflows\" (click)=\"onWorkflowSelected(orgWorkflow)\">\n {{ orgWorkflow.Name }}\n </label>\n </div>\n </div>\n </div>\n\n </div>\n\n </div>\n <div class=\"bottombox-wrapper\">\n <!-- <input [disabled]=\"isChatingWithAi\" type=\"text\" class=\"form-control-1 s27-scroll\"\n \n placeholder=\"Ask anything...\" [style.background]=\"formFieldBgColor ? formFieldBgColor : ''\"\n [style.color]=\"formFieldTextColor ? formFieldTextColor : ''\" [(ngModel)]=\"input\"\n (keyup.enter)=\"handleSubmit()\" #myInput /> -->\n <textarea [disabled]=\"isChatingWithAi\" class=\"form-control-1 s27-scroll chat-textarea\"\n placeholder=\"Ask anything...\" [(ngModel)]=\"input\" (keydown)=\"handleKeydown($event)\"\n (input)=\"adjustTextareaHeight($event)\" #myInput></textarea>\n\n <button (click)=\"toggleRecording()\" class=\"btn cta-chat mr-1\">\n <svg *ngIf=\"!isRecording\" stroke=\"currentColor\" fill=\"currentColor\" stroke-width=\"0\" viewBox=\"0 0 512 512\"\n height=\"1em\" width=\"1em\" xmlns=\"http://www.w3.org/2000/svg\">\n <!-- Mic Icon -->\n <path\n d=\"M256 320c53 0 96-43 96-96V96c0-53-43-96-96-96s-96 43-96 96v128c0 53 43 96 96 96zm144-96h-16c0 66.27-52.73 120-120 120s-120-53.73-120-120h-16c-17.67 0-32 14.33-32 32v32c0 53.87 38.13 100.64 91.21 112.27C210.13 457.77 231.58 464 256 464s45.87-6.23 65.79-17.73C374.87 388.64 416 341.87 416 288v-32c0-17.67-14.33-32-32-32z\">\n </path>\n </svg>\n <svg *ngIf=\"isRecording\" stroke=\"currentColor\" fill=\"currentColor\" stroke-width=\"0\" viewBox=\"0 0 24 24\"\n height=\"1em\" width=\"1em\" xmlns=\"http://www.w3.org/2000/svg\">\n <!-- Square Stop Icon -->\n <path d=\"M5 5h14v14H5z\"></path>\n </svg>\n </button>\n\n\n <button class=\"btn cta-chat rotate\" (click)=\"handleSubmit()\"\n [style.background]=\"sendButtonColor ? sendButtonColor : ''\"\n [style.color]=\"sendButtonTextColor ? sendButtonTextColor : ''\">\n <svg stroke=\"currentColor\" fill=\"currentColor\" stroke-width=\"0\" viewBox=\"0 0 512 512\" height=\"1em\"\n width=\"1em\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n d=\"M476.59 227.05l-.16-.07L49.35 49.84A23.56 23.56 0 0027.14 52 24.65 24.65 0 0016 72.59v113.29a24 24 0 0019.52 23.57l232.93 43.07a4 4 0 010 7.86L35.53 303.45A24 24 0 0016 327v113.31A23.57 23.57 0 0026.59 460a23.94 23.94 0 0013.22 4 24.55 24.55 0 009.52-1.93L476.4 285.94l.19-.09a32 32 0 000-58.8z\">\n </path>\n </svg>\n <!-- SEND -->\n </button>\n </div>\n </div>\n\n\n <!-- new UI for Chat Message Section by Amit -->\n </div>\n\n <div class=\"NoteTxt\">\n <div class=\"note\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12.882\" height=\"12.883\" viewBox=\"0 0 12.882 12.883\">\n <path id=\"Icon_ion-shield-checkmark\" data-name=\"Icon ion-shield-checkmark\"\n d=\"M15.106,4.532a.46.46,0,0,0-.378-.424A20.132,20.132,0,0,1,8.881,2.291a.46.46,0,0,0-.379,0A20.132,20.132,0,0,1,2.655,4.108a.46.46,0,0,0-.378.424A11.3,11.3,0,0,0,2.98,9.4a10.049,10.049,0,0,0,2.06,3.235A10.516,10.516,0,0,0,8.521,15.1a.46.46,0,0,0,.345,0,10.516,10.516,0,0,0,3.481-2.465A10.049,10.049,0,0,0,14.4,9.4,11.3,11.3,0,0,0,15.106,4.532Zm-3.767,2.16L8.153,10.373a.46.46,0,0,1-.328.159H7.806a.46.46,0,0,1-.322-.131L6.069,9.014a.46.46,0,1,1,.644-.657L7.777,9.4,10.644,6.09a.46.46,0,0,1,.7.6Z\"\n transform=\"translate(-2.25 -2.25)\" fill=\"#06f\" />\n </svg>\n\n\n <span class=\"text\">Your personal or company information is kept\n private and secure\n within this chat.</span>\n </div>\n </div>\n </mat-drawer-content>\n </mat-drawer>\n <mat-drawer class=\"drawer edit-boxDrawer\" style=\"width: 45%\" #sourcesDrawer [position]=\"'end'\" [mode]=\"'over'\"\n [style.background]=\"\n 'linear-gradient(' + (bgGradient ? bgGradient.join(', ') : '') + ')'\n \">\n <mat-drawer-content>\n <div class=\"sourceDraweContainer\">\n <div class=\"container-fluid\">\n <button mat-icon-button class=\"closeButtonSource\" (click)=\"onCloseSource()\">\n <mat-icon>close</mat-icon>\n </button>\n <h1>{{ currentSourcesList?.length }} Sources</h1>\n <!-- <p>Tell me about latest news from Mistral about AI agents announcement done this month</p> -->\n <hr />\n <ul class=\"sources-list\">\n <li *ngFor=\"let item of currentSourcesList; let si = index\">\n <!-- <input type=\"checkbox\" id=\"source1\"> -->\n <div class=\"source-content\" (click)=\"openLinkInNewTab(item.link)\">\n <label for=\"source1\">\n <span class=\"source-title\"><span class=\"ml-1\">{{ si + 1\n }}.</span>{{ item.title }}</span>\n <span class=\"image-container\">\n <img class=\"relative block\" [src]=\"getFaviconUrl(item.link)\"\n [alt]=\"getDomainName(item.link) + ' favicon'\" />\n <span> {{ getDomainName(item.link) }}</span>\n </span>\n <span class=\"source-description\">{{ item.desc }}</span>\n </label>\n </div>\n </li>\n </ul>\n </div>\n </div>\n </mat-drawer-content>\n </mat-drawer>\n <mat-drawer class=\"drawer edit-boxDrawer\" style=\"width: 45%\" #editorsDrawer [position]=\"'end'\" [mode]=\"'push'\"\n [style.background]=\"\n 'linear-gradient(' + (bgGradient ? bgGradient.join(', ') : '') + ')'\n \">\n <mat-drawer-content>\n <lib-bot-html-editor *ngIf=\"isContentLoaded\" [editorContent]=\"currentMessageForEditor\"\n [isDocInEditMode]=\"isDocInEditMode\" [documentContent]=\"documentContent\" [conversationId]=\"conversationId\"\n [botId]=\"botId\"></lib-bot-html-editor>\n </mat-drawer-content>\n </mat-drawer>\n</mat-drawer-container>\n\n\n<div *ngIf=\"showWorkflowExecutionDetails\" class=\"modal\">\n <div class=\"modal-content\">\n <div class=\"close-wrapper\"><span class=\"close_pop\" (click)=\"closeModal()\">&times;</span></div>\n <div class=\"titleSection\">\n <!-- Workflow Title -->\n <h2>{{ workflowExecutionDetails.WorkflowName }}</h2>\n <!-- Workflow Title -->\n </div>\n <!-- Inputs Section -->\n <div class=\"inputs-section\">\n <h3>Inputs</h3>\n <ul>\n <li *ngFor=\"let input of objectToArray(workflowExecutionDetails.Inputs)\">\n {{ input.key }}: {{ input.value }}\n </li>\n </ul>\n </div>\n\n <!-- Actions Section (Displayed as Timeline) -->\n <div class=\"actions-section\">\n <h3>Agent Actions</h3>\n <div class=\"timeline\">\n <div *ngFor=\"let action of workflowExecutionDetails.Actions\" class=\"timeline-item\">\n <div class=\"timestamp-section\">\n <h4>{{ action.ActionName || action.Name }}</h4>\n <p><strong></strong> {{\n action.InsertTimeStamp }}</p>\n </div>\n <p [innerHTML]=\"processMessageForDisplay(action.Output)\"></p>\n <!-- <pre>{{ action.Output }}</pre> -->\n </div>\n </div>\n </div>\n\n <!-- Insert Timestamp -->\n <div class=\"timestamp-section\">\n <p><strong>Inserted At:</strong> {{\n workflowExecutionDetails.InsertTimeStamp }}</p>\n </div>\n </div>\n</div>",
1549
+ changeDetection: ChangeDetectionStrategy.OnPush,
1550
+ styles: ["@import url(\"https://e1cdn.social27.com/digitalevents/liteversion/fonts/segoe-ui/stylesheet.css\");.sticky-header-chat{background:#fff;border-bottom:1px solid #ddd;padding:0 0 10px;position:sticky;top:-21px;transition:all 1s;z-index:100}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb,::-webkit-scrollbar-thumb:hover{background:#e5ccbc}body{overflow:hidden}.ios-device .drawer .chat-footer .form-control{font-size:16px}.hivegpt-chat-wrapper{background:transparent!important;height:100%;inset:0;opacity:0;position:fixed;visibility:hidden;z-index:999999}.hivegpt-chat-wrapper.mat-drawer-container-has-open{background:transparent!important;opacity:1;transition:all .3s;visibility:visible;z-index:999999}.hivegpt-chat-wrapper .mat-drawer:not(.mat-drawer-side){box-shadow:none}.hivegpt-chat-wrapper mat-drawer{background-color:#fff!important;background-image:none!important;width:100%}.hivegpt-chat-wrapper mat-drawer.full-width-drawer{max-width:100%}.hivegpt-chat-wrapper .mat-drawer-content{display:flex;flex-direction:column}.hivegpt-chat-wrapper .chat-header{padding:16px 40px;width:100%}.hivegpt-chat-wrapper .chat-header h2{font-family:Segoe UI,sans-serif;font-size:36px;font-weight:500;letter-spacing:-.72px;line-height:108%;margin:0;text-transform:uppercase}.hivegpt-chat-wrapper .chat-header .closeIcon{align-items:center;background:transparent;border:none;border-radius:50%;display:inline-flex;font-size:18px;height:35px;justify-content:center;outline:none;padding:0;position:absolute;right:12px;top:16px;width:35px}.hivegpt-chat-wrapper .chat-main{display:flex;flex:1;flex-direction:column;justify-content:space-between;overflow-y:auto;width:100%}.hivegpt-chat-wrapper .chat-main .innerChat{overflow-y:auto;padding:20px 40px 10px;width:100%}.hivegpt-chat-wrapper .chat-main .chat-box{max-width:80%;width:100%}.hivegpt-chat-wrapper .chat-main .chat-box .message{margin-left:70px;margin-top:20px;min-height:60px;padding:0 20px 0 0;position:relative}.hivegpt-chat-wrapper .chat-main .chat-box .message p{color:#000;font-family:Segoe UI,sans-serif;font-size:16px;font-style:normal;font-weight:500;line-height:160%;margin:0;text-align:left;white-space:pre-line}.hivegpt-chat-wrapper .chat-main .chat-box .message p a{color:#17235b!important;cursor:pointer!important;font-weight:700;text-decoration:underline}.hivegpt-chat-wrapper .chat-main .chat-box .message .cta{align-items:end;bottom:-7px;display:inline-flex;gap:10px;grid-gap:10px;position:relative;right:-10px;z-index:5}.hivegpt-chat-wrapper .chat-main .chat-box .message .cta button{background:transparent;border:none;color:#566563;cursor:pointer;padding:0;transition:all .3s}.hivegpt-chat-wrapper .chat-main .chat-box .message .cta button i{display:inline-block}.hivegpt-chat-wrapper .chat-main .chat-box .message .cta button:hover{color:#17235b}.hivegpt-chat-wrapper .chat-main .chat-box .message .cta button.up:hover i{animation:thumbsUpAnimation .5s ease-in-out;animation-fill-mode:forwards}.hivegpt-chat-wrapper .chat-main .chat-box .message .cta button.down:hover i{animation:thumbsDownAnimation .5s ease-in-out;animation-fill-mode:forwards}.hivegpt-chat-wrapper .chat-main .chat{margin-bottom:20px}.hivegpt-chat-wrapper .chat-main .chat.user{text-align:right}.hivegpt-chat-wrapper .chat-main .chat.user .chat-box{margin-left:auto}.hivegpt-chat-wrapper .chat-main .chat.user .chat-box .message{background:linear-gradient(96deg,#8b4ead -10.61%,#761c79 84.59%);border-radius:20px 20px 0 20px;color:#fff}.hivegpt-chat-wrapper .chat-main .chat.user .chat-box .message p{color:#fff;text-align:left}.hivegpt-chat-wrapper .chat-main .chat.user .dateTime{text-align:right}.hivegpt-chat-wrapper .chat-main .chat.user .time-cta{justify-content:flex-end}.hivegpt-chat-wrapper .chat-main .chat .Icon_TimeSTamp{align-content:center;align-items:center;display:flex;justify-content:left;margin:0 -60px;width:auto}.hivegpt-chat-wrapper .chat-main .chat .dateTime{color:#333232;font-size:15px;font-style:normal;font-weight:300;line-height:140%}.hivegpt-chat-wrapper .chat-main .chat .dateTime span{color:#06f;font-size:15px;font-style:normal;font-weight:500;line-height:140%;margin-left:15px;margin-right:5px}.hivegpt-chat-wrapper .chat-main .chat:last-of-type{margin-bottom:0}.hivegpt-chat-wrapper .chatFooterWrapper{background:#fff;border:2px solid hsla(0,0%,85.5%,.5882352941176471);border-radius:10px;box-shadow:2px 0 5px #e1e1e1;margin:0 auto 15px;margin-top:10px!important;transition:all .5s;width:75%}.hivegpt-chat-wrapper .chatFooterWrapper:hover{border:2px solid hsla(0,0%,72.2%,.5882352941176471);box-shadow:2px 0 4px #ddd}.hivegpt-chat-wrapper .chatFooterWrapper .chat-footer-upt{padding:4px}.hivegpt-chat-wrapper .chatFooterWrapper .note{align-items:center;background:rgba(27,117,187,.050980392156862744);border-radius:15px;color:#000;display:inline-flex;font-size:12px;gap:8px;line-height:1;margin:0 auto 4px;padding:10px 25px}.hivegpt-chat-wrapper .chatFooterWrapper .note a{text-transform:capitalize}.hivegpt-chat-wrapper .chatFooterWrapper .note i{font-size:18px}.hivegpt-chat-wrapper .chatFooterWrapper .note i svg{height:18px;width:18px}.hivegpt-chat-wrapper .chatFooterWrapper .note span{flex:1;gap:4px;line-height:1.3}.hivegpt-chat-wrapper .chat-footer{align-items:center;display:flex;gap:8px;justify-content:space-between;padding:0;position:relative}.hivegpt-chat-wrapper .chat-footer .form-control{background:#fff!important;border:0;line-height:21px;outline:0;padding:10px;position:relative;width:100%}.hivegpt-chat-wrapper .chat-footer .form-control::-moz-placeholder{color:#6c7a78}.hivegpt-chat-wrapper .chat-footer .form-control::placeholder{color:#6c7a78}.hivegpt-chat-wrapper .chat-footer .form-control:focus{border-color:#e5ccbc}.hivegpt-chat-wrapper .chat-footer .cta-footer{align-items:center;display:flex;gap:8px;justify-content:space-between;margin-bottom:10px;position:absolute;right:15px;text-align:right}.hivegpt-chat-wrapper .chat-footer .cta-footer .btn{color:#000;font-weight:500;gap:8px;max-width:150px;padding:0}.hivegpt-chat-wrapper .chat-footer .cta-footer .cta-chat{align-items:center;background:transparent!important;border:none;border-radius:0;box-shadow:0 1px 2px 0 rgba(16,24,40,.05);display:inline-flex;font-size:20px;height:auto;justify-content:center;width:auto}.hivegpt-chat-wrapper .chat-footer .cta-footer .cta-chat:hover{opacity:.8}.hivegpt-chat-wrapper .chat-footer .cta-footer .cta-again{background:#17235b;border:1px solid #17235b;color:#fff}.hivegpt-chat-wrapper .cta-faqs{align-items:flex-end;display:flex;flex-direction:column;flex-wrap:wrap;gap:8px;margin-left:auto;max-width:80%;padding:10px 0 0}.hivegpt-chat-wrapper .cta-faqs .cta{background:transparent;border:1px solid #c9a893;border-radius:20px 20px 0 20px;color:#333;cursor:pointer;font-family:Segoe UI,sans-serif;font-size:14px;font-style:normal;font-weight:500;line-height:160%;margin:0;min-height:44px;padding:12px 20px;text-align:left;text-decoration:none;transition:all .3s;white-space:pre-line}.spinner{align-items:center;display:flex;gap:2px;justify-content:center}.spinner>div{animation:bouncedelay 1.4s ease-in-out infinite;animation-fill-mode:both;background-color:#173330;border-radius:100%;display:inline-block;height:5px;width:5px}.spinner .bounce1{animation-delay:-.32s}.spinner .bounce2{animation-delay:-.16s}@keyframes bouncedelay{0%,80%,to{-webkit-transform:scale(0);transform:scale(0)}40%{-webkit-transform:scale(1);transform:scale(1)}}.time-cta{align-items:center;display:flex;gap:8px;justify-content:start;margin-top:5px}@keyframes thumbsUpAnimation{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes thumbsDownAnimation{0%,to{transform:translateY(0)}50%{transform:translateY(3px)}}@media (max-width:767px){.hivegpt-chat-wrapper .chat-main .innerChat{padding:0 24px 10px}.hivegpt-chat-wrapper .chat-footer{padding:10px 24px}.hivegpt-chat-wrapper .chat-footer .cta-footer .cta-chat{max-width:100%}.hivegpt-chat-wrapper .chat-footer .form-control{height:80px}.hivegpt-chat-wrapper .chat-header .closeIcon{height:28px;right:8px;top:8px;width:28px}.hivegpt-chat-wrapper .chat-header .closeIcon span{font-size:14px}.hivegpt-chat-wrapper .chat-header{padding:10px 24px}.hivegpt-chat-wrapper .chat-header h2{font-size:20px}.cta-faqs{padding:10px 0 0}}.body-overflow-hidden{overflow:hidden}.chat-button{align-items:center;background:#17235b;border:#17235b;border-radius:50%;color:#fff;display:inline-flex;font-size:24px;height:50px;justify-content:center;width:50px}textarea{caret-color:#000}.labelChat{font-size:14px;font-weight:400;margin:0 0 10px}.chatType h4{color:#566563;text-align:center}.chatType ul{align-items:center;background:#fff;border-radius:10px;box-shadow:0 .3px .9px rgba(0,0,0,.12),0 1.6px 3.6px rgba(0,0,0,.16);display:flex;justify-content:center;list-style:none;margin:0 0 20px;padding:4px}.chatType ul li{flex:1}.chatType ul li button{align-items:center;background:#fff;border:none;border-radius:10px;font-weight:600;min-height:48px;padding:.375rem;text-align:center;text-shadow:1px 0 rgba(0,0,0,.2);width:100%}.chatType ul li button.active{background:linear-gradient(96deg,#761c79 -10.61%,#761c79 84.59%);box-shadow:0 1px 2px 0 rgba(16,24,40,.05);color:#fff}.cta_suggestions{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:20px}.cta_suggestions button{background:#fff;border:1px solid #174ae4;border-radius:10px;box-shadow:0 1.6px 3.6px 0 rgba(0,0,0,.13),0 .3px .9px 0 rgba(0,0,0,.1);color:#1543cd;font-size:14px;font-weight:600;line-height:1.2;padding:8px 12px;position:relative;text-align:left;transition:all .3s}.cta_suggestions button:hover{background:#eff3ff}.balanced .chat-footer .cta-footer .cta-chat,.balanced .chat-main .chat.user .chat-box .message,.balanced .chatType ul li button.active{color:#000}.balanced .chat-main .innerChat .title p span{color:#06f}.balanced mat-drawer{background-image:linear-gradient(180deg,rgba(88,190,251,.05) 60%,rgba(0,102,255,.2) 96.27%)}.balanced .cta_suggestions button:hover{border:1px solid #06f}.precise .chat-footer .cta-footer .cta-chat,.precise .chat-main .chat.user .chat-box .message{background:linear-gradient(96deg,#69ca6d -10.61%,#4caf50 84.59%)}.precise .chatType ul li button.active{background:linear-gradient(96deg,#4caf50 -10.61%,#4caf50 84.59%);color:#fff}.precise .chat-main .innerChat .title p span{color:#4caf50}.precise mat-drawer{background-image:linear-gradient(180deg,rgba(76,175,80,.05) 60%,rgba(76,175,80,.3) 96.27%)}.precise .cta_suggestions button:hover{border:1px solid #4caf50}.title{margin-bottom:20px}.title h2{font-size:22px;margin:0}.title h2 span{align-items:center;color:#000;display:inline-flex;gap:10px}.title h2 i{color:#06f;font-size:30px;line-height:1}.title h2 i svg{height:30px;width:30px}.title p{font-weight:600;margin:0}.title p span{color:#06f}.agenda-items-wrapper{padding-bottom:15px;padding-top:15px}@media (max-width:576px){.list-view .session-detail-wrapper{border:none;flex-direction:column}}.card-background-session{background:#fff;border-radius:8px}.card-background-session .body-text-color{color:#111!important}.card-background-session h2{-webkit-box-orient:vertical;-webkit-line-clamp:1;display:-webkit-box;font-size:20px;margin-bottom:8px;overflow:hidden}.card-background-session .session-description{-webkit-box-orient:vertical;-webkit-line-clamp:2;color:#111!important;display:-webkit-box;font-size:14px;overflow:hidden}.card-background-session .color-secondary{color:#111!important}.card-background-session p{font-size:14px}.list-view .session-detail-wrapper .s27-btn-icon{background:transparent;border:transparent}.list-view .session-detail-wrapper{border-left:3px solid transparent;display:flex;margin-bottom:16px}.thumbnail{align-items:center;display:flex;height:160px;justify-content:center;min-width:160px;position:relative;width:160px}.thumbnail img{-o-object-fit:cover;height:100%;object-fit:cover;width:100%}@media (max-width:576px){.thumbnail{height:160px;min-height:unset;width:100%}}.thumbnail .play-btn{align-items:center;background-color:transparent;border:0;bottom:0;display:flex;font-size:60px;justify-content:center;left:0;position:absolute;right:0;top:0;width:100%}.thumbnail .play-btn span{font-size:80px;text-shadow:0 0 14px rgba(74,74,74,.45)}.content{flex-grow:1}.actions{background-color:transparent!important}.speakers{margin-bottom:0;margin-top:10px;padding:0}.speakers li{align-items:unset;display:flex}.speakers li .content{font-size:12px!important}.speakers .image{border-radius:100%;height:40px;min-width:40px;overflow:hidden;width:40px}.speakers img{-o-object-fit:cover;height:100%;object-fit:cover;width:100%}.grid-2-cols{display:grid;grid-gap:15px;grid-template-columns:calc(55% - 10px) calc(50% - 10px);padding-right:20px}@media (max-width:768px){.grid-2-cols{grid-template-columns:calc(50% - 10px) calc(50% - 10px)}}@media (max-width:575px){.grid-3-cols{grid-template-columns:100%}}.quick-prompts-extended{align-items:flex-start!important;margin-left:0!important}.border-shape .s27-scroll::-webkit-scrollbar{border-radius:30px;width:3px}.border-shape .s27-scroll::-webkit-scrollbar-track{background:#f1f1f1;border-radius:30px}.border-shape .s27-scroll::-webkit-scrollbar-thumb{background:#888;border-radius:30px}.box{display:table;height:275px;margin:10px 0;width:100%}.tiktokwrapper{display:grid;gap:10px;grid-template-columns:repeat(2,1fr);height:100%}.tiktokwrapper .tiktokshell{background:#3d2b8f;border:2px solid #fff;border-radius:5px;box-shadow:0 0 6px #494949;height:100%;min-height:275px;min-width:160px;position:relative;width:100%}.tiktokwrapper .overlymask{background-image:url(https://e1cdn.social27.com/digitalevents/HiveGpt/screen-overlay.png);background-position:0 0;bottom:0;height:100%;left:0;position:absolute;width:100%;z-index:6}.tiktokwrapper .videoPhotobox{bottom:0;height:272px;left:0;overflow:hidden;position:absolute;width:auto;z-index:6}.tiktokwrapper .videoPhotobox video{-o-object-fit:cover;border-radius:0;cursor:pointer;height:270px;object-fit:cover;outline:0;transition:.3s ease-in-out;width:100%}.tiktokwrapper .videoPhotobox img{-o-object-fit:cover;height:100%;object-fit:cover;width:100%}.tiktokwrapper .playBtn{align-items:center;border:none;cursor:pointer;display:flex;height:40px;justify-content:center;left:0;margin:0 auto;position:absolute;right:0;top:105px;transition:all 1s;width:40px;z-index:10}.tiktokwrapper .playBtn:hover{transform:scale(1.2)}.tiktokwrapper .noPhoto{align-items:center;border:none;cursor:pointer;display:flex;height:40px;justify-content:center;left:0;margin:0 auto;position:absolute;right:0;top:105px;transition:all 1s;z-index:6}.tiktokwrapper .noPhoto h3{color:#fff;font-size:46px}.tiktokwrapper .onshell-content{bottom:10px;left:5px;position:absolute;z-index:10}.tiktokwrapper .onshell-content .title-shell{margin:0 10px}.tiktokwrapper .onshell-content h3{color:#fff;font-size:13px;font-weight:500}.tiktokwrapper .onshell-content .companyName{color:#eaeaea;font-size:12px;font-weight:400}.tiktokwrapper .onshell-content .button-shell button{background:#4e4e4e;border:none;border-radius:2px;color:#fff;font-size:11px;margin:0 1px;padding:4px 7px;text-transform:capitalize}.tiktokwrapper .onshell-content .Connectbtn{background:linear-gradient(149deg,#06f,#06f)!important}.skeleton-box{background-color:#dddbdd;display:inline-block;height:1em;overflow:hidden;position:relative}.skeleton-box:after{animation:shimmer 2s infinite;background-image:linear-gradient(90deg,hsla(0,0%,100%,0),hsla(0,0%,100%,.2) 20%,hsla(0,0%,100%,.5) 60%,hsla(0,0%,100%,0));bottom:0;content:\"\";left:0;position:absolute;right:0;top:0;transform:translateX(-100%);z-index:0}@keyframes shimmer{to{transform:translateX(100%)}}.blog-post__headline{font-size:1.25em;font-weight:700}.blog-post__meta{color:#6b6b6b;font-size:.85em}.o-media{display:flex}.o-media__body{flex-grow:1;margin-left:1em}.o-vertical-spacing>*+*{margin-top:.75em}.o-vertical-spacing--l>*+*{margin-top:2em}.copy{background:none;border:none;cursor:pointer;padding:5px;transition:transform .2s ease}.copy.active{transform:scale(1.1)}.copy svg{fill:#566563;height:18px;width:18px}.copyBox{background:#f7f7f7;border-radius:13px;color:#566563;display:flex;float:right;gap:12px;padding:5px 10px;position:relative;width:135px}.copyBox button{background:transparent;border:none;color:#566563;cursor:pointer;padding:0;transition:all .3s}.copyBox button i{display:inline-block}.copyBox button:hover{color:#17235b}.copyBox button.up:hover i{animation:thumbsUpAnimation .5s ease-in-out;animation-fill-mode:forwards}.copyBox button.down:hover i{animation:thumbsDownAnimation .5s ease-in-out;animation-fill-mode:forwards}.din{display:inline-flex}.chatFooterWrapper{align-items:center;background-color:#f5f5f5;border-top:1px solid #ccc;flex-direction:column;justify-content:center}.chat-footer{background:#fff;flex-direction:column;margin-bottom:10px}.chat-footer,.topinfo-containerbox{align-items:center;display:flex;width:100%}.topinfo-containerbox{background:#f9f9f9;border-bottom:1px solid #efefef;justify-content:space-between;margin:0;padding:5px 10px 8px}.agents_note_wrapper{display:flex;justify-content:space-around}.bottombox-wrapper{display:flex;padding:10px;width:100%}.dropdown-wrapper{margin-right:10px;position:relative}.dropdown-header{align-items:center;background:#fff;border:1px solid #ddd;border-radius:48px;color:#414141!important;cursor:pointer;display:flex;font-size:14px;margin-bottom:0;padding:.5rem 1.5rem;white-space:nowrap}.dropdown-header span{margin-right:8px}.dropdown-menu{background-color:#fff;border:1px solid #ededed;border-radius:5px;bottom:100%!important;box-shadow:0 2px 4px rgba(0,0,0,.1);display:block;left:0;margin-bottom:10px;max-height:200px;overflow-y:auto;padding:0;position:absolute;top:auto;width:230px;z-index:1000}.dropdown-menu label{cursor:pointer;display:block;font-size:16px;padding:5px 15px}.dropdown-menu label input{height:16px;width:16px}.dropdown-menu label:hover{background-color:#f0f0f0}.border-shape{flex-grow:1}.form-control-1{border:1px solid #ddd;border-radius:5px;padding:10px;width:100%}.cta-footer,.text-left .note-section{align-items:center;display:flex}.text-left .note-section{background:#fff;border-radius:5px;box-shadow:0 2px 4px rgba(0,0,0,.1);margin-top:10px;max-width:800px;padding:10px;width:100%}.text-left .note{align-items:center;color:#555;display:flex}.text-left .note i{margin-right:8px}.text-left .note .text{font-size:14px}.card-container{display:flex;gap:15px}.custom-card{background:#fffefe;border:1px solid #ddd;border-radius:.25rem;box-shadow:0 4px 8px rgba(0,0,0,.1);margin-bottom:10px;overflow:hidden;width:18rem}.custom-card .card-body{padding:10px}.custom-card .card-title{font-size:1.25rem;font-weight:700}.custom-card .card-text{font-size:1rem;text-align:left}.custom-card .btn-primary{background-color:#007bff;border:none;border-radius:.25rem}.custom-card .card-footer{background-color:#f8f9fa;color:#6c757d;padding:10px;text-align:center}.list-container{list-style:none;padding:0}.list-container li{background:#f5f5f5;border-radius:8px;font-size:13px;margin-bottom:5px;padding:6px 12px}.list-container li:hover{color:#06f;cursor:pointer}.collapsible-container{margin-bottom:5px;overflow:hidden;width:100%}.collapsible-header{cursor:pointer;display:flex;padding:15px}.collapsible-header .header-icon{font-size:20px;margin-right:10px}.collapsible-header .header-title{flex:1;font-size:18px}.collapsible-header .toggle-icon{font-size:18px;margin-left:18px}.collapsible-content{background-color:#f8f9fa;color:#333;padding:15px;width:100%}.collapsible-content.show{display:block}.researchingCard{margin:0 auto}.card-header{background:#eee;border-bottom:0;border-radius:8px 8px 0 0;display:flex!important;padding:8px 15px;width:auto}.icon{font-size:20px;line-height:5px}.rotate{transform:rotate(180deg)}.collapse{display:none}.uptList{background:rgba(245,222,179,.1411764705882353);border-radius:0 0 10px 10px;margin-bottom:20px!important}.list-group-item{color:#000;font-size:13px}.sources-container{align-items:flex-start;display:flex;gap:15px}.source-card{background-color:#f0f3f5;border-radius:10px;box-sizing:border-box;cursor:pointer;display:flex;flex-direction:column;justify-content:space-between;padding:15px;position:relative;transition:box-shadow .3s ease;width:100%}.popup{background-color:#fff;border-radius:5px;box-shadow:0 4px 8px rgba(0,0,0,.2);left:50%;opacity:0;padding:10px;position:absolute;top:100%;transform:translateX(-50%) translateY(-10px);transition:opacity .3s ease,transform .3s ease;visibility:hidden;white-space:normal;width:100%;z-index:10}.popup h5{font-size:14px;font-weight:600;line-height:1.2;margin:5px 0 10px}.popup p{font-size:12px;line-height:1.4;margin:0}.popup h5:hover{color:#007bff;cursor:pointer}.popup .source-url{color:#000;text-decoration:none}.popup .source-url:hover{color:#007bff;cursor:pointer;text-decoration:underline}.source-card:hover .popup{opacity:1;transform:translateX(-50%) translateY(-15px);visibility:visible}.source-card:hover{box-shadow:0 4px 8px rgba(0,0,0,.1);transform:scale(1.05)}.source-title{-webkit-box-orient:vertical;-webkit-line-clamp:2;display:-webkit-box;font-size:14px;font-weight:500;height:55px;line-height:1.5;overflow:hidden;text-align:left;text-overflow:ellipsis}.source-title img{margin-left:10px;width:20px}.source-url{align-items:center;color:#6c757d;display:flex;font-size:12px;text-align:left}.source-url img{border-radius:50%;height:16px;margin-right:5px;width:16px}.sourceDraweContainer .container{background-color:#fff;padding:20px}.sourceDraweContainer .sources-list{list-style:none;padding:0}.sourceDraweContainer .sources-list li{align-items:flex-start;display:flex;margin-bottom:15px}.sourceDraweContainer .sources-list input[type=checkbox]{flex-shrink:0;margin-right:15px;margin-top:8px}.sourceDraweContainer .source-content{background-color:#f5f2f2;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.1);cursor:pointer;flex:1;padding:12px}.sourceDraweContainer .source-content:hover{background:#ccc}.sourceDraweContainer .source-title{display:block;font-size:1rem;font-weight:500;height:auto!important;margin-bottom:4px}.sourceDraweContainer .source-description{display:block;font-size:.875rem}.sourceDraweContainer .image-container{align-items:center;display:flex;margin:10px 0}.sourceDraweContainer .image-container img{-o-object-fit:cover;border:1px solid #ddd;border-radius:50%;height:16px;margin-right:5px;object-fit:cover;width:16px}.sourceDraweContainer .image-container span{color:#555;font-size:13px}.closeButtonEditor{border:0;border-radius:100%;height:32px;padding:3px 0 0;position:absolute;right:10px;top:5px;width:32px}.closeButtonSource{background:none!important;border-color:transparent!important;box-shadow:none!important;color:inherit;cursor:pointer;float:right;margin-top:20px;transition:color .2s ease-in-out}.closeButtonSource.closeplaygroundbutton{display:none!important}.graph-img{background:hsla(0,0%,86.7%,.23137254901960785);border-radius:15px;padding:15px;width:70%}.chat-textarea{background-color:#fff;border:none;box-sizing:border-box;font-size:15px;height:30px;line-height:1.5;overflow-y:hidden;padding:10px;resize:none;transition:all 1s;width:100%}.chat-textarea:focus,.chat-textarea:hover{height:60px}.chat-textarea:focus{outline:none}.fixed-btn{background-color:#000;border:none;border-radius:8px 8px 0 0;color:#fff;cursor:pointer;font-size:16px;padding:5px 12px;position:fixed;right:-22px;top:46%;transform:translateY(-50%) rotate(270deg);transform-origin:center;transition:all .5s;z-index:1000000}.fixed-btn:hover{background-color:#5b5b5b}.fixed-btn-close{background-color:#000;border:none;border-radius:8px 8px 0 0;color:#fff;cursor:pointer;font-size:16px;padding:5px 16px;position:fixed;right:549px;top:46%;transform:translateY(-50%) rotate(270deg);transform-origin:center;transition:all .5s;z-index:1000000}.fixed-btn-close:hover{background-color:#5b5b5b}.btn.rotate{transform:rotate(-15deg)}.btn.rotate:hover{transform:rotate(0deg)}.btn.cta-chat{align-items:center;background:#f3f3f3;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;height:40px;justify-content:center;margin:0 auto;padding:5px;text-align:center;transition:all .5s;width:40px}.btn.cta-chat:hover{background:#d7d7d7;color:#666}.btn.cta-chat svg{vertical-align:middle}.chat-footer-upt{padding:4px}.workflowbox{align-items:center;border:1px solid transparent;border-radius:48px;color:#414141!important;cursor:pointer;display:flex;font-size:14px;margin-bottom:0;padding:.5rem 1.5rem;transition:all .5s;white-space:nowrap}.workflowbox:hover{background:#fff;border:1px solid #ddd}.workflowbox svg{margin:0 10px}.edit-boxDrawer{border-left:1px solid #ddd;box-shadow:1px 1px 15px hsla(0,0%,86.7%,.7686274509803922)!important}.edit-boxDrawer mat-drawer-content,ng-deep .edit-boxDrawer mat-drawer-content{margin-left:0!important;margin-right:0!important}.SearchTitle{font-size:16px!important;text-transform:capitalize}.exicution{margin:26px 0!important}.new-conversationbutton{align-items:center;background:#f5f5f5;border:1px solid #e3e3e3;border-radius:10px;cursor:pointer;display:flex;font-size:14px;justify-content:space-around;padding:6px;position:absolute;right:88px;top:10px;transition:all .5s;width:120px;z-index:1000}.new-conversationbutton:hover{background:#eee}.NoteTxt{margin:0 auto}.NoteTxt .text{margin:0 5px}.form-container{width:100%}.progress-container{align-items:center;display:flex}.circular-loader{border:4px solid rgba(0,0,0,.1);border-radius:50%;box-sizing:border-box;height:50px;position:relative;width:50px}.loader-spinner{animation:rotate-loader 1s linear infinite;border:2px solid #2196f3;border-radius:50%;border-top-color:transparent;box-sizing:border-box;height:100%;left:0;position:absolute;top:0;width:100%}.loader-text{color:#333;font-size:12px;font-weight:700;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.loader-label{color:#333;font-size:16px;margin-left:20px}.checkmark{align-items:center;display:flex;height:100%;justify-content:center;width:100%}.checkmark-circle{animation:stroke .6s ease-in-out forwards;stroke:#4caf50;stroke-dasharray:166;stroke-dashoffset:166;stroke-width:4}.checkmark-check{animation:stroke-check .4s ease-in-out .4s forwards;stroke:#4caf50;stroke-dasharray:48;stroke-dashoffset:48;stroke-linecap:round;stroke-linejoin:round;stroke-width:4}@keyframes stroke{to{stroke-dashoffset:0}}@keyframes stroke-check{to{stroke-dashoffset:0}}@keyframes rotate-loader{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes checkmark-animation{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.circular-loader.completed .loader-spinner{animation:none;transform:rotate(1turn)}.icon-button{background-color:transparent;border:none;color:#333;cursor:pointer;font-size:24px}.icon-button:focus{outline:none}.icon-button:hover{color:#007bff}.modal{background-color:rgba(0,0,0,.4);display:block;height:100%;left:0;padding-top:0;position:fixed;top:0;width:100%;z-index:1000001}.modal-content{background-color:#fff;border-radius:8px;box-shadow:0 4px 8px rgba(0,0,0,.1);height:600px;margin:5% auto;padding:20px;position:relative;width:82%}.close{color:#aaa;float:right;font-size:28px;font-weight:700}.close:focus,.close:hover{color:#000;cursor:pointer;text-decoration:none}.SearchTitle.user{text-transform:none!important}.SearchTitle.user,.SearchTitle.user h2,.SearchTitle.user p{font-size:30px!important}.title_chat{display:flex;margin:0;padding:0}.title_chat h2{align-items:center;display:flex;font-size:20px;gap:10px;margin:10px 0}.small-title{font-size:12px;margin:2px 0}.titleSection{margin:0}.titleSection h2{color:#000;font-size:20px;margin:0}.inputs-section{background-color:#f7f7f7;border-radius:5px;margin:0 0 10px;padding:10px 15px 0}.inputs-section h3{font-size:16px}.actions-section{background-color:#f9f9f9;border-radius:5px;height:500px;margin-bottom:20px;overflow-y:auto;padding:15px}.timeline{margin-bottom:20px;padding-left:40px;position:relative}.timeline:before{border-right:2px dashed #cecece;content:\"\";height:100%;left:19px;position:absolute}.timeline-item{margin-bottom:20px;position:relative}.timeline-item:before{background-color:#007bff;border-radius:50%;content:\"\";height:20px;left:-30px;position:absolute;top:0;width:20px;z-index:1}.timeline-item h4{color:#000;font-size:16px;font-weight:700;margin:0}.timeline-item pre{background-color:#fff;border:1px solid #ddd;border-radius:5px;padding:10px;white-space:pre-wrap}.timestamp-section{color:#666;font-style:italic;justify-content:space-between}.mic-btn{background-color:#ff4d4d;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:1.5em;padding:10px}.mic-btn:active{background-color:#f66}.actions-section h3{font-size:16px}.close-wrapper{display:flex;justify-content:right;position:absolute;right:22px;top:0;width:100%}.close_pop{color:#aaa;cursor:pointer;font-size:30px;font-weight:400;justify-content:center}.close_pop,.user-Box{align-items:center;display:flex}.bards{position:absolute;right:0;top:20px}::ng-deep .code-container{margin:20px 0;position:relative}::ng-deep .copy-button{background-color:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:5px 10px;position:absolute;right:10px;top:10px}::ng-deep .copy-button:hover{background-color:#0056b3}::ng-deep .code_block.diff{background-color:#f8f8f8;border-left:4px solid #ccc;overflow:auto;padding:10px}"]
1551
+ },] }
1552
+ ];
1553
+ ChatDrawerComponent.ctorParameters = () => [
1554
+ { type: FormBuilder },
1555
+ { type: BotsService },
1556
+ { type: ChangeDetectorRef },
1557
+ { type: HttpClient },
1558
+ { type: DomSanitizer },
1559
+ { type: ElementRef },
1560
+ { type: Renderer2 },
1561
+ { type: SocketService },
1562
+ { type: ConversationService }
1563
+ ];
1564
+ ChatDrawerComponent.propDecorators = {
1565
+ chatMain: [{ type: ViewChild, args: ['chatMain',] }],
1566
+ myInput: [{ type: ViewChild, args: ['myInput',] }],
1567
+ closePlaygroundButtons: [{ type: ViewChildren, args: ['closeplaygroundbutton',] }],
1568
+ drawer: [{ type: ViewChild, args: ['drawer',] }],
1569
+ sourcesDrawer: [{ type: ViewChild, args: ['sourcesDrawer',] }],
1570
+ editorsDrawer: [{ type: ViewChild, args: ['editorsDrawer',] }],
1571
+ myTextarea: [{ type: ViewChild, args: ['myTextarea', { static: false },] }],
1572
+ copilotName: [{ type: Input }],
1573
+ firstName: [{ type: Input }],
1574
+ lastName: [{ type: Input }],
1575
+ apiKey: [{ type: Input }],
1576
+ bgBubbleAi: [{ type: Input }],
1577
+ bgBubbleUser: [{ type: Input }],
1578
+ bgGradient: [{ type: Input }],
1579
+ botName: [{ type: Input }],
1580
+ botSkills: [{ type: Input }],
1581
+ botId: [{ type: Input }],
1582
+ orgId: [{ type: Input }],
1583
+ closeButtonColor: [{ type: Input }],
1584
+ closeButtonbgColor: [{ type: Input }],
1585
+ credentials: [{ type: Input }],
1586
+ dateTimeColor: [{ type: Input }],
1587
+ dateTextColor: [{ type: Input }],
1588
+ eventId: [{ type: Input }],
1589
+ s27Token: [{ type: Input }],
1590
+ eventName: [{ type: Input }],
1591
+ botIcon: [{ type: Input }],
1592
+ formFieldBgColor: [{ type: Input }],
1593
+ formFieldTextColor: [{ type: Input }],
1594
+ fullView: [{ type: Input }],
1595
+ gradientColors: [{ type: Input }],
1596
+ greeting: [{ type: Input }],
1597
+ messageTextColorAi: [{ type: Input }],
1598
+ messageTextColorUser: [{ type: Input }],
1599
+ rules: [{ type: Input }],
1600
+ sendButtonColor: [{ type: Input }],
1601
+ sendButtonTextColor: [{ type: Input }],
1602
+ showClose: [{ type: Input }],
1603
+ thumbsDownMessages: [{ type: Input }],
1604
+ thumbsUpMessage: [{ type: Input }],
1605
+ timezone: [{ type: Input }],
1606
+ unknownResponses: [{ type: Input }],
1607
+ useOpenAi: [{ type: Input }],
1608
+ userId: [{ type: Input }],
1609
+ isDev: [{ type: Input }],
1610
+ againButtonColor: [{ type: Input }],
1611
+ againButtonTextColor: [{ type: Input }],
1612
+ feedbackEvent: [{ type: Output }],
1613
+ onCloseEvent: [{ type: Output }],
1614
+ openPage: [{ type: Output }],
1615
+ sessionActions: [{ type: Output }],
1616
+ closeBot: [{ type: Output }],
1617
+ connectWithUser: [{ type: Output }],
1618
+ scheduleMeeting: [{ type: Output }],
1619
+ refreshToken: [{ type: Output }]
1620
+ };
1621
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chat-drawer.component.js","sourceRoot":"/Users/muddassirnayyer/Development/Social27/HiveAI-Packages/projects/hivegpt/eventsgpt-angular/src/","sources":["lib/components/chat-drawer/chat-drawer.component.ts"],"names":[],"mappings":"AAAA,oDAAoD;AACpD,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAC/D,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,YAAY,EAEZ,KAAK,EAGL,MAAM,EAEN,SAAS,EAET,SAAS,EACT,YAAY,GACb,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,YAAY,EAAY,MAAM,2BAA2B,CAAC;AACnE,OAAO,EAAE,EAAE,EAAgB,MAAM,MAAM,CAAC;AACxC,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AACvD,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAChE,OAAO,EACL,eAAe,EACf,gBAAgB,GACjB,MAAM,mCAAmC,CAAC;AAC3C,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAE9D,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAE1D,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AACzD,OAAO,KAAK,SAAS,MAAM,wCAAwC,CAAC;AACpE,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAQ7C,MAAM,OAAO,mBAAmB;IAmH9B,YACU,EAAe,EACf,UAAuB,EACvB,GAAsB,EACtB,IAAgB,EAChB,SAAuB,EACvB,UAAsB,EACtB,QAAmB,EACnB,aAA4B,EAC5B,mBAAwC,CAAC,6BAA6B;;QARtE,OAAE,GAAF,EAAE,CAAa;QACf,eAAU,GAAV,UAAU,CAAa;QACvB,QAAG,GAAH,GAAG,CAAmB;QACtB,SAAI,GAAJ,IAAI,CAAY;QAChB,cAAS,GAAT,SAAS,CAAc;QACvB,eAAU,GAAV,UAAU,CAAY;QACtB,aAAQ,GAAR,QAAQ,CAAW;QACnB,kBAAa,GAAb,aAAa,CAAe;QAC5B,wBAAmB,GAAnB,mBAAmB,CAAqB;QApH1C,sBAAiB,GAAG,sBAAsB,CAAC;QAGnD,oBAAe,GAAG,KAAK,CAAC;QACf,gBAAW,GAAW,UAAU,CAAC;QAyChC,kBAAa,GAAG,IAAI,YAAY,EAAU,CAAC;QAC3C,iBAAY,GAAG,IAAI,YAAY,EAAQ,CAAC;QACxC,aAAQ,GAAG,IAAI,YAAY,EAAO,CAAC;QACnC,mBAAc,GAAG,IAAI,YAAY,EAAO,CAAC;QACzC,aAAQ,GAAG,IAAI,YAAY,EAAO,CAAC;QACnC,oBAAe,GAAG,IAAI,YAAY,EAAO,CAAC;QAC1C,oBAAe,GAAG,IAAI,YAAY,EAAU,CAAC;QAC7C,iBAAY,GAAG,IAAI,YAAY,EAAO,CAAC;QAEjD,eAAU,GAAG,6BAA6B,CAAC;QAC3C,wBAAmB,GAAG,kBAAkB,CAAC;QACzC,4BAAuB,GAAG,sBAAsB,CAAC;QACjD,0BAAqB,GAAG,mBAAmB,CAAC;QAC5C,eAAU,GAAW,EAAE,CAAC;QACxB,YAAO,GAAU,EAAE,CAAC;QACpB,YAAO,GAAG,IAAI,WAAW,EAAE,CAAC;QAC5B,iBAAY,GAAY,KAAK,CAAC;QAC9B,gBAAW,GAAW,EAAE,CAAC;QACzB,qBAAgB,GAAY,KAAK,CAAC;QAClC,UAAK,GAAW,EAAE,CAAC;QACnB,kBAAa,GAAG,KAAK,CAAC;QACtB,YAAO,GAAY,KAAK,CAAC;QACzB,SAAI,GAAW,MAAM,CAAC;QACtB,iBAAY,GAAU,EAAE,CAAC;QACzB,uBAAkB,GAAG,CAAC,CAAC;QACvB,aAAQ,GAAW,EAAE,CAAC;QACtB,mBAAc,GAAY,KAAK,CAAC;QAChC,gBAAW,GAAY,KAAK,CAAC;QAC7B,2BAAsB,GAAkB,IAAI,CAAC;QAC7C,gBAAW,GAAW,CAAC,CAAC;QACxB,aAAQ,GAAG,EAAE,CAAC;QAkBd,kCAA6B,GAAW,CAAC,CAAC;QAC1C,0BAAqB,GAAW,EAAE,CAAC;QAQnC,mBAAc,GAAW,EAAE,CAAC;QAC5B,uBAAkB,GAAW,EAAE,CAAC;QAChC,WAAM,GAAW,YAAY,CAAC,CAAC,6BAA6B;QAihB5D,oBAAe,GAAG,KAAK,CAAC;QAgGxB,kBAAa,GAAG,CAAC,MAAW,EAAE,EAAE;YAC9B,MAAM,MAAM,GAAG,MAAM,CAAC,SAAS,EAAE,CAAC;YAClC,MAAM,cAAc,GAAa,EAAE,CAAC;YAEpC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,GAAQ,EAAE,EAAE;gBAC/B,IAAI,GAAG,EAAE;oBACP,OAAO,CAAC,KAAK,CAAC,wBAAwB,EAAE,GAAG,CAAC,CAAC;iBAC9C;gBAED,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;gBAC7B,IAAI,CAAC,cAAc,EAAE,CAAC;gBACtB,OAAO;YACT,CAAC,CAAC,CAAC;YAEH,OAAO,IAAI,cAAc,CAAC;gBACxB,KAAK,EAAE,CAAC,UAAU,EAAE,EAAE;oBACpB,OAAO,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,MAAM,EAAE,cAAc,CAAC,CAAC;gBACvD,CAAC;aACF,CAAC,CAAC;QACL,CAAC,CAAC;QAqTF,4BAAuB,GAAQ,EAAE,CAAC;QAClC,0BAAqB,GAAQ,CAAC,CAAC,CAAC;QAsOhC,mBAAc,GAAY,KAAK,CAAC;QAEhC,mBAAc,GAAG,EAAE,CAAC;QACpB,gBAAW,GAAG,KAAK,CAAC;QAgEpB,oBAAe,GAAG,KAAK,CAAC;QAIxB,oBAAe,GAAG,KAAK,CAAC;QA4IxB,gBAAW,GAAG,KAAK,CAAC;QACpB,wBAAmB,GAAG,KAAK,CAAC;QAC5B,yBAAoB,GAAG,KAAK,CAAC;QAc7B,MAAM;QACN,MAAM;QACN,4EAA4E;QAC5E,4LAA4L;QAC5L,6DAA6D;QAC7D,OAAO;QACP,MAAM;QACN,iEAAiE;QACjE,kJAAkJ;QAClJ,wEAAwE;QACxE,OAAO;QACP,MAAM;QACN,yEAAyE;QACzE,gIAAgI;QAChI,+EAA+E;QAC/E,OAAO;QACP,MAAM;QACN,qFAAqF;QACrF,sHAAsH;QACtH,2FAA2F;QAC3F,OAAO;QACP,MAAM;QACN,2EAA2E;QAC3E,6IAA6I;QAC7I,2FAA2F;QAC3F,MAAM;QACN,IAAI;QACJ,aAAQ,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,EAAE,CAAC;QAgB7C,uBAAkB,GAAQ,EAAE,CAAC;QAW7B,uBAAkB,GAAG,IAAI,CAAC;QAwC1B,iBAAY,GAAG,IAAI,CAAC;QAn9ClB,IAAI,CAAC,QAAQ,GAAG,IAAI,UAAU,CAAC,IAAI,CAAC,CAAC;QAErC,2BAA2B;QAC3B,6BAA6B;QAC7B,IAAI;IACN,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,QAAQ,EAAE;YACpB,IAAI,OAAO,CAAC,QAAQ,CAAC,YAAY,IAAI,OAAO,CAAC,QAAQ,CAAC,aAAa,EAAE;gBACnE,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAC;gBAE9C,OAAO,CAAC,GAAG,CAAC,kBAAkB,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;gBACrD,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;gBAC/B,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;gBACjC,IAAI,IAAI,CAAC,KAAK,EAAE;oBACd,IAAI,IAAI,CAAC,cAAc,EAAE;wBACvB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;qBACxC;yBAAM;wBACL,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;qBAC1B;iBACF;aACF;SACF;QAED,IAAI,OAAO,CAAC,KAAK,EAAE;YACjB,IACE,OAAO,CAAC,KAAK,CAAC,YAAY,IAAI,OAAO,CAAC,KAAK,CAAC,aAAa;gBACzD,OAAO,CAAC,KAAK,CAAC,YAAY,EAC1B;gBACA,IAAI,CAAC,gBAAgB,EAAE,CAAC;aAEzB;SACF;IACH,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,gBAAgB,CAAC;QAEnE,yCAAyC;QACzC,2CAA2C;QAE3C,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACzC,IAAI,CAAC,cAAc,EAAE,CAAC,SAAS,CAC7B,CAAC,GAAG,EAAE,EAAE;YACN,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YAExB,IAAI,CAAC,gBAAgB,EAAE,CAAC,SAAS,CAC/B,CAAC,QAAQ,EAAE,EAAE;gBACX,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;gBACrB,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;gBAC9B,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YAC1B,CAAC,EACD,CAAC,GAAG,EAAE,EAAE;gBACN,OAAO,CAAC,KAAK,CAAC,8BAA8B,EAAE,GAAG,CAAC,CAAC;YACrD,CAAC,CACF,CAAC;QACJ,CAAC,EACD,CAAC,GAAG,EAAE,EAAE;YACN,OAAO,CAAC,KAAK,CAAC,8BAA8B,EAAE,GAAG,CAAC,CAAC;QACrD,CAAC,CACF,CAAC;QACF,sBAAsB;QACtB,6BAA6B;QAC7B,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QACxB,2BAA2B;QAC3B,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,EAAE;YAC9B,IAAI,CAAC,UAAU,CAAC,6BAA6B,EAAE,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;gBAClE,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;gBAChC,IAAI,CAAC,0BAA0B,CAAC,KAAK,CAAC,CAAC;YACzC,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAGD,gBAAgB;QACd,IAAI;YACF,IAAI,CAAC,aAAa,CAAC,0BAA0B,EAAE,CAAC;SACjD;QAAC,OAAO,KAAK,EAAE,GAAG;QACnB,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,aAAa,CAAC,uBAAuB,EAAE,CAAC;YAC7C,UAAU,CAAC,GAAG,EAAE;gBACd,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;gBACxB,MAAM,eAAe,GAAG,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAEpE,IAAI,CAAC,aAAa,CAAC,8BAA8B,CAC/C,IAAI,CAAC,KAAK,EACV,eAAe,EACf,IAAI,CAAC,KAAK,CACX,CAAC;gBACF,UAAU,CAAC,GAAG,EAAE;oBACd,IAAI,CAAC,aAAa,EAAE,CAAC;gBACvB,CAAC,EAAE,GAAG,CAAC,CAAC;YACV,CAAC,EAAE,GAAG,CAAC,CAAC;QACV,CAAC,EAAE,GAAG,CAAC,CAAC;IACV,CAAC;IAKD,aAAa;QACX,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC1B,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE,CAAC;SACtC;QACD,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;QAC7B,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,mBAAmB;aAC9C,2BAA2B,EAAE;aAC7B,SAAS,CACR,CAAC,GAAG,EAAE,EAAE;;YACN,OAAO,CAAC,GAAG,CAAC,wBAAwB,CAAC,CAAC;YACtC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YACjB,8CAA8C;YAC9C,gBAAI,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,CAAC,0CAAE,WAAW,0CAAE,WAAW,EAAE;gBACpC,MAAM,EACJ,UAAU,EACV,MAAM,EACN,WAAW,EACX,mBAAmB,EACnB,qBAAqB,EACrB,UAAU,GACX,SAAG,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,CAAC,0CAAE,WAAW,CAAC;gBAExB,IAAI,CAAC,6BAA6B,GAAG,UAAU,CAAC;gBAChD,IAAI,CAAC,qBAAqB,GAAG,WAAW,CAAC;gBAEzC,MAAM,WAAW,GAAG,IAAI,CAAC,wBAAwB,CAAC,OAAO,CAAC,SAAS,CACjE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,mBAAmB,CACrC,CAAC;gBAEF,IAAI,WAAW,KAAK,CAAC,CAAC,EAAE;oBACtB,IAAI,CAAC,wBAAwB,CAAC,OAAO,CAAC,WAAW,CAAC,CAChD,QAAQ,CACT,GAAG,MAAM,CAAC;oBACX,IAAI,CAAC,wBAAwB,CAAC,OAAO,CAAC,WAAW,CAAC,CAChD,iBAAiB,CAClB,GAAG,gBAAgB,CAAC,IAAI,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;iBACjD;qBAAM;oBACL,OAAO,CAAC,KAAK,CAAC,oBAAoB,WAAW,YAAY,CAAC,CAAC;iBAC5D;gBAED,IAAI,CAAC,+BAA+B,GAAG,IAAI,CAAC,wBAAwB,CAAC;gBAErE,IAAI,IAAI,CAAC,6BAA6B,IAAI,GAAG,EAAE;oBAC7C,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CACnC,qBAAqB,CACtB,GAAG,qBAAqB,CAAC;oBAC1B,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;oBAC7B,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;iBAChC;gBAED,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;aAC1B;iBAAM,UAAI,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,CAAC,0CAAE,WAAW,EAAE;gBAC9B,MAAM,EACJ,eAAe,EACf,MAAM,EACN,UAAU,EACV,MAAM,EACN,WAAW,EACX,cAAc,EACd,MAAM,EACN,gBAAgB,EAChB,WAAW,GACZ,SAAG,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,CAAC,0CAAE,WAAW,CAAC;gBACxB,OAAO,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;gBAC3B,OAAO,CAAC,GAAG,OAAC,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,CAAC,0CAAE,WAAW,CAAC,CAAC;gBACjC,IAAI,kBAAkB,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CACxC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,IAAI,UAAU,CAC3B,CAAC;gBACF,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;gBAC1B,IAAI,CAAC,kBAAkB,EAAE;oBACvB,OAAO,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;oBAC3B,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;oBACxB,kBAAkB,GAAG;wBACnB,GAAG,EAAE,UAAU;wBACf,IAAI,EAAE,IAAI;wBACV,IAAI,EAAE,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC;qBAC/B,CAAC;oBAEF,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;oBAEtC,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC;oBACtD,OAAO,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;oBAC3B,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;oBACxB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;iBAC1B;gBAED,4CAA4C;gBAC5C,IAAI,cAAc,IAAI,KAAK,CAAC,OAAO,CAAC,cAAc,CAAC,EAAE;oBACnD,OAAO,CAAC,GAAG,CAAC,sBAAsB,EAAE,cAAc,CAAC,CAAC;oBACpD,kBAAkB,CAAC,WAAW,GAAG,cAAc,CAAC;oBAChD,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;iBAC1B;gBAED,IAAI,WAAW,IAAI,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE;oBAC7C,OAAO,CAAC,GAAG,CAAC,cAAc,EAAE,WAAW,CAAC,CAAC;oBACzC,kBAAkB,CAAC,WAAW,GAAG,WAAW,CAAC;oBAC7C,kBAAkB,CAAC,gBAAgB,GAAG,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,gBAAgB;oBAChF,kBAAkB,CAAC,gBAAgB,GAAG,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,kBAAkB;oBAC/E,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;iBAC1B;gBAED,IAAI,MAAM,EAAE;oBACV,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;oBAC7B,OAAO,CAAC,GAAG,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;oBAE/B,kBAAkB,CAAC,OAAO,GAAG,IAAI,CAAC,wBAAwB,CACxD,MAAM,CACP,CAAC;oBACF,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;oBACzB,IAAI,CAAC,cAAc,EAAE,CAAC;iBACvB;gBAED,IAAI,MAAM,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;oBACnC,OAAO,CAAC,GAAG,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;oBAC/B,kBAAkB,CAAC,MAAM,GAAG,MAAM,CAAC;oBACnC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;iBAC1B;gBAED,IAAI,gBAAgB,IAAI,KAAK,CAAC,OAAO,CAAC,gBAAgB,CAAC,EAAE;oBACvD,OAAO,CAAC,GAAG,CAAC,mBAAmB,EAAE,gBAAgB,CAAC,CAAC;oBACnD,kBAAkB,CAAC,eAAe,GAAG,gBAAgB,CAAC;oBACtD,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;iBAC1B;gBAED,IAAI,WAAW,IAAI,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE;oBAC7C,OAAO,CAAC,GAAG,CAAC,cAAc,EAAE,WAAW,CAAC,CAAC;oBACzC,kBAAkB,CAAC,gBAAgB,GAAG,WAAW,CAAC;oBAClD,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;oBACzB,wCAAwC;iBACzC;gBAED,iDAAiD;aAClD;iBAAM;gBACL,OAAO,CAAC,IAAI,CAAC,wCAAwC,CAAC,CAAC;aACxD;QACH,CAAC,EACD,CAAC,GAAG,EAAE,EAAE;YACN,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE,CAAC;YACrC,OAAO,CAAC,KAAK,CAAC,oCAAoC,EAAE,GAAG,CAAC,CAAC;QAC3D,CAAC,CACF,CAAC;IACN,CAAC;IAED,yBAAyB,KAAK,CAAC;IAC/B,WAAW,CAAC,IAAS,EAAE,IAAY;QACjC,QAAQ,IAAI,EAAE;YACZ,KAAK,WAAW;gBACd,MAAM;YACR,KAAK,QAAQ;gBACX,MAAM;YACR,KAAK,OAAO;gBACV,MAAM;YACR;gBACE,MAAM;SACT;IACH,CAAC;IACD,WAAW;QACT,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC1B,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE,CAAC;SACtC;QACD,IAAI,CAAC,aAAa,CAAC,0BAA0B,EAAE,CAAC;QAChD,6BAA6B;IAC/B,CAAC;IACD,iBAAiB,CAAC,cAAsB;QACtC,IAAI,IAAI,CAAC,OAAO;YAAE,OAAO;QACzB,IAAI,CAAC,WAAW,GAAG,cAAc,CAAC;QAClC,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,uBAAuB,CAAC,CAAC;QAChE,0CAA0C;QAC1C,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,SAAS,CAAC,MAAM,CAAC,UAAU,EAAE,UAAU,EAAE,SAAS,EAAE;QAE7D,QAAQ,cAAc,EAAE;YACtB,KAAK,CAAC;gBACJ,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,SAAS,CAAC,GAAG,CAAC,UAAU,EAAE;gBACnC,MAAM;YACR,KAAK,CAAC;gBACJ,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,SAAS,CAAC,GAAG,CAAC,UAAU,EAAE;gBACnC,MAAM;YACR,KAAK,CAAC;gBACJ,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,SAAS,CAAC,GAAG,CAAC,SAAS,EAAE;gBAClC,MAAM;YACR;gBACE,MAAM;SACT;IACH,CAAC;IAED,YAAY;QACV,IAAI,IAAI,CAAC,OAAO;YAAE,OAAO;QACzB,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;QAC5B,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;QAClB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;YAChB,IAAI,EAAE,IAAI;YACV,OAAO,EAAE,IAAI,CAAC,WAAW;YAEzB,IAAI,EAAE,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC;SAC/B,CAAC,CAAC;QACH,IAAI,CAAC,gBAAgB,EAAE,CAAC,SAAS,EAAE,CAAC;IACtC,CAAC;IAED,gBAAgB;QACd,MAAM,OAAO,GAAG,IAAI,WAAW,CAAC;YAC9B,cAAc,EAAE,kBAAkB;YAClC,WAAW,EAAE,IAAI,CAAC,MAAM;YACxB,aAAa,EAAE,IAAI,CAAC,KAAK;SAC1B,CAAC,CAAC;QACH,MAAM,GAAG,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,sBAAsB,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;QAC1F,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,EAAE,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC,IAAI,CAC9C,SAAS,CAAC,CAAC,GAAQ,EAAE,EAAE;YACrB,OAAO,EAAE,CAAC,GAAG,CAAC,CAAC;QACjB,CAAC,CAAC,EACF,UAAU,CAAC,CAAC,KAAK,EAAE,EAAE;YACnB,OAAO,EAAE,CAAC,IAAI,CAAC,CAAC;QAClB,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,MAAM,OAAO,GAAG,IAAI,WAAW,CAAC;YAC9B,WAAW,EAAE,IAAI,CAAC,MAAM;YACxB,aAAa,EAAE,IAAI,CAAC,KAAK;SAC1B,CAAC,CAAC;QACH,MAAM,GAAG,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,gBAAgB,IAAI,CAAC,KAAK,EAAE,CAAC;QACrE,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,EAAC,OAAO,EAAC,CAAC,CAAC,IAAI,CACvC,SAAS,CAAC,CAAC,GAAQ,EAAE,EAAE;;YACrB,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC,IAAI,CAAC;YACxB,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC,IAAI,CAAC;YACxB,IAAI,CAAC,SAAS,GAAG,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,MAAM,CAAC;YAC7B,IAAI,CAAC,WAAW,GAAG,GAAG,CAAC,QAAQ,CAAC;YAEhC,IAAI,CAAC,kBAAkB,GAAG,OAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,iBAAiB,0CAAE,MAAM,EACtD,CAAC,CAAC,GAAG,CAAC,iBAAiB;gBACvB,CAAC,CAAC;oBACA,wTAAwT;iBACzT,CAAC;YACJ,IAAI,CAAC,YAAY,GAAG,GAAG,CAAC,YAAY,CAAC;YACrC,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YACxB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,OAAO,EAAE,CAAC,GAAG,CAAC,CAAC;QACjB,CAAC,CAAC,EACF,UAAU,CAAC,CAAC,KAAK,EAAE,EAAE;YACnB,OAAO,CAAC,KAAK,CAAC,iCAAiC,EAAE,KAAK,CAAC,CAAC;YACxD,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,OAAO,EAAE,CAAC,IAAI,CAAC,CAAC;QAClB,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QAEpB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAC1E,MAAM,GAAG,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,kBAAkB,IAAI,CAAC,eAAe,EAAE,CAAC;QACjF,MAAM,OAAO,GAAG,IAAI,WAAW,CAAC;YAC9B,MAAM,EAAE,kBAAkB;YAC1B,WAAW,EAAE,IAAI,CAAC,MAAM;YACxB,aAAa,EAAE,IAAI,CAAC,KAAK;SAC1B,CAAC,CAAC;QAEH,OAAO,IAAI,CAAC,IAAI;aACb,GAAG,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,CAAC;aACrB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,WAAW,CAAM,mBAAmB,CAAC,CAAC,CAAC,CAAC;IAClE,CAAC;IAEO,WAAW,CAAI,SAAS,GAAG,WAAW,EAAE,MAAU;QACxD,OAAO,CAAC,KAAU,EAAiB,EAAE;YACnC,OAAO,CAAC,KAAK,CAAC,GAAG,SAAS,YAAY,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;YACvD,OAAO,EAAE,CAAC,MAAW,CAAC,CAAC;QACzB,CAAC,CAAC;IACJ,CAAC;IACD,uBAAuB;IACvB,yBAAyB;IACzB,sCAAsC;IACtC,0CAA0C;IAC1C,gCAAgC;IAChC,QAAQ;IACR,qBAAqB;IACrB,8FAA8F;IAC9F,aAAa;IACb,kCAAkC;IAClC,gCAAgC;IAChC,0BAA0B;IAC1B,YAAY;IACZ,qCAAqC;IACrC,iEAAiE;IACjE,gCAAgC;IAChC,2BAA2B;IAC3B,WAAW;IACX,SAAS;IACT,IAAI;IAEJ,cAAc,CAAC,KAAU;;QACvB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;YAChB,IAAI,EAAE,IAAI;YACV,OAAO,EAAE,IAAI,CAAC,WAAW;YACzB,IAAI,EAAE,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC;SAC/B,CAAC,CAAC;QACH,IAAI,KAAK,WAAI,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,QAAQ,0CAAE,MAAM,CAAA,EAAE;YACpC,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,QAAQ,CAAC,OAAO,CAAC,CAAC,IAAS,EAAE,EAAE;gBACpC,IAAI,IAAI,CAAC,IAAI,IAAI,MAAM,EAAE;oBACvB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;wBAChB,IAAI,EAAE,MAAM;wBACZ,OAAO,EAAE,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,IAAI,CAAC;wBACjD,IAAI,EAAE,gBAAgB,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,eAAe,CAAC;wBAC3D,MAAM,EAAE,KAAK;wBACb,eAAe,EAAE,KAAK;wBACtB,mBAAmB,EAAE,IAAI,CAAC,mBAAmB;qBAC9C,CAAC,CAAC;iBACJ;gBACD,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,EAAE;oBACrB,IAAI,WAAW,GAAG,IAAI,CAAC,QAAQ,IAAI,EAAE,CAAC;oBACtC,IAAI,gBAAgB,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,gBAAgB;oBAClE,IAAI,gBAAgB,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,kBAAkB;oBAEjE,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;wBAChB,IAAI,EAAE,IAAI;wBACV,OAAO,EAAE,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,IAAI,CAAC;wBACjD,eAAe,EAAE,IAAI,CAAC,eAAe;wBACrC,MAAM,EAAE,IAAI,CAAC,MAAM;wBACnB,WAAW,EAAE,IAAI,CAAC,WAAW;wBAC7B,WAAW,EAAE,WAAW;wBACxB,gBAAgB,EAAE,gBAAgB;wBAClC,gBAAgB,EAAE,gBAAgB;wBAClC,IAAI,EAAE,gBAAgB,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,eAAe,CAAC;wBAC3D,MAAM,EAAE,KAAK;wBACb,eAAe,EAAE,KAAK;qBACvB,CAAC,CAAC;oBACH,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC;iBACvD;YACH,CAAC,EAAE;YACH,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;SAC5B;QACD,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;IAED,cAAc,CAAC,OAAe;QAC5B,IAAI,CAAC,OAAO,IAAI,CAAC,CAAC,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,MAAM,IAAG,CAAC,CAAC,EAAE;YACtC,OAAO,EAAE,CAAC;SACX;QAED,oCAAoC;QACpC,wBAAwB;QAExB,OAAO,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;QAEzB,MAAM,iBAAiB,GAAG,wBAAwB,CAAC;QACnD,MAAM,QAAQ,GAAG,wCAAwC,CAAC;QAE1D,IAAI,iBAAiB,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;YACnC,MAAM,IAAI,GAAG,OAAO,CAAC,OAAO,CAC1B,iBAAiB,EACjB,qCAAqC,CACtC,CAAC;YACF,8CAA8C;YAC9C,OAAO,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;SAChC;QAED,IAAI,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;YAC1B,MAAM,IAAI,GAAG,OAAO,CAAC,OAAO,CAC1B,QAAQ,EACR,qCAAqC,CACtC,CAAC;YACF,+CAA+C;YAC/C,OAAO,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;SAChC;QAED,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,iBAAiB,EAAE,MAAM,CAAC,CAAC;QAErD,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,gBAAgB,EAAE,qBAAqB,CAAC,CAAC;QACnE,2CAA2C;QAC3C,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,qBAAqB,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE;YACvE,MAAM,KAAK,GAAG,MAAM,CAAC,MAAM,CAAC;YAC5B,OAAO,KAAK,KAAK,IAAI,IAAI,MAAM,KAAK,GAAG,CAAC;QAC1C,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QACxB,MAAM,gBAAgB,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;QACpD,OAAO,gBAAgB,CAAC;IAC1B,CAAC;IAED,kBAAkB;QAChB,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,gBAAgB,CAClE,gBAAgB,CACjB,CAAC;QACF,aAAa,CAAC,OAAO,CAAC,CAAC,IAAS,EAAE,EAAE;YAClC,IAAI,CAAC,gBAAgB,CACnB,OAAO,EACP,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,EAAE,SAAS,CAAC,CAC3C,CAAC;QACJ,CAAC,CAAC,CAAC;QACH,uEAAuE;QACvE,kCAAkC;QAClC,uCAAuC;QACvC,8EAA8E;QAC9E,IAAI;IACN,CAAC;IAED,YAAY,CAAC,IAAY;QACvB,OAAO,IAAI,CAAC,SAAS,CAAC,uBAAuB,CAAC,IAAI,CAAC,CAAC;IACtD,CAAC;IAED,eAAe,CAAC,KAAa;QAC3B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED,OAAO;QACL,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC;QACjE,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAED,mBAAmB,CAAC,MAAc;QAChC,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC;QACpB,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAED,SAAS,CAAC,GAAG,GAAG,IAAI;;QAClB,IAAI,CAAC,KAAK,GAAG,GAAG,WAAI,IAAI,CAAC,KAAK,0CAAE,IAAI,GAAE,CAAC;QACvC,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC;QACtB,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,OAAO,EAAE;YAC/B,OAAO;SACR;QAED,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;YAChB,IAAI,EAAE,MAAM;YACZ,OAAO,EAAE,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,KAAK,CAAC;YAClD,IAAI,EAAE,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC;YAC9B,MAAM,EAAE,KAAK;YACb,eAAe,EAAE,KAAK;SACvB,CAAC,CAAC;QAEH,IAAI;YACF,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC;YAC5C,QAAQ,CAAC,KAAK,CAAC,MAAM,GAAG,QAAQ,CAAC,CAAC,mBAAmB;YACrD,QAAQ,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;SAChC;QAAC,OAAO,KAAK,EAAE,GAAG;QACnB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAExB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QACrB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAE5B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;IACrE,CAAC;IACD,YAAY,CAAC,GAAG,EAAE,IAAI;QACpB,MAAM,QAAQ,GAAG,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,IAAI,EAAE,CAAC;QAC7B,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,OAAO,EAAE;YAC7B,OAAO;SACR;QACD,IAAI;YACF,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;YAC3B,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;SAC1B;QAAC,OAAO,KAAK,EAAE,GAAG;QAEnB,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;YAChB,IAAI,EAAE,MAAM;YACZ,OAAO,EAAE,IAAI,CAAC,wBAAwB,CAAC,QAAQ,CAAC;YAChD,IAAI,EAAE,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC;YAC9B,MAAM,EAAE,KAAK;YACb,eAAe,EAAE,KAAK;SACvB,CAAC,CAAC;QAEH,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAExB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QACrB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAE5B,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,eAAe,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;IAC9E,CAAC;IACD,cAAc;QACZ,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAExB,MAAM,GAAG,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,mBAAmB,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;QAEvF,IAAI,CAAC,IAAI;aACN,GAAG,CAAwB,GAAG,EAAE;YAC/B,OAAO,EAAE;gBACP,WAAW,EAAE,IAAI,CAAC,MAAM;gBACxB,aAAa,EAAE,IAAI,CAAC,KAAK;aAC1B;SACF,CAAC;aACD,IAAI,CACH,UAAU,CAAC,CAAC,KAAK,EAAE,EAAE;YACnB,OAAO,CAAC,KAAK,CAAC,kCAAkC,EAAE,KAAK,CAAC,CAAC;YAEzD,OAAO,EAAE,CAAC,IAAI,CAAC,CAAC;QAClB,CAAC,CAAC,CACH;aACA,SAAS,CAAC,CAAC,QAAQ,EAAE,EAAE;YACtB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YAExB,IAAI,CAAC,QAAQ,EAAE;gBACb,OAAO;aACR;YAED,IAAI,QAAQ,IAAI,QAAQ,CAAC,SAAS,EAAE;gBAClC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;oBAChB,IAAI,EAAE,IAAI;oBACV,OAAO,EAAE,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,SAAS,CAAC;oBAChD,IAAI,EAAE,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC;oBAC9B,aAAa,EAAE,IAAI;iBACpB,CAAC,CAAC;gBACH,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC;gBACtD,yBAAyB;gBACzB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;aACzB;QACH,CAAC,CAAC,CAAC;IACP,CAAC;IAuBD,IAAI,CAAC,UAAe,EAAE,MAAW,EAAE,cAAwB;QACzD,MAAM,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,EAAE,KAAK,EAAO,EAAE,EAAE;;YAC1C,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;YAEvD,IAAI,IAAI,EAAE;gBACR,QAAQ,CAAC,OAAO,GAAG,IAAI,CAAC,wBAAwB,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;gBACnE,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC;gBACnB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBAC5B,IAAI,cAAc,aAAd,cAAc,uBAAd,cAAc,CAAE,MAAM,EAAE;oBAC1B,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;wBAChB,IAAI,EAAE,aAAa;wBACnB,WAAW,EAAE,cAAc;qBAC5B,CAAC,CAAC;iBACJ;gBAED,UAAU,CAAC,KAAK,EAAE,CAAC;gBACnB,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;gBAC7B,yBAAyB;gBACzB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;gBACxB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;gBAE3B,qBAAqB;gBACrB,2BAA2B;gBAC3B,UAAU;gBACV,OAAO;aACR;YAED,IAAI,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;YAChE,IAAI,CAAC,UAAU,IAAI,YAAY,CAAC;YAChC,IAAI,QAAQ,CAAC,IAAI,KAAK,IAAI,EAAE;gBAC1B,MAAM,gBAAgB,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,oBAAoB,CAAC,CAAC;gBACrE,IAAI,gBAAgB,EAAE;oBACpB,gBAAgB,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;wBACjC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;wBACrD,cAAc,CAAC,IAAI,CAAC,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,OAAO,CAAC,WAAW,EAAE,EAAE,EAAE,CAAC;oBACvD,CAAC,CAAC,CAAC;iBACJ;gBAED,QAAQ,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC;gBACnC,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;aACzB;iBAAM;gBACL,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;gBAE7B,IAAI,eAAoB,CAAC;gBAEzB,IAAI;oBACF,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;oBAC7B,eAAe,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;iBAC3D;gBAAC,OAAO,CAAC,EAAE;oBACV,IAAI;wBACF,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;wBAC9B,eAAe,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;qBAC/C;oBAAC,OAAO,CAAC,EAAE,GAAG;iBAChB;gBAED,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;gBAEjC,IAAI,eAAe,IAAI,OAAA,eAAe,aAAf,eAAe,uBAAf,eAAe,CAAE,UAAU,0CAAE,MAAM,IAAG,CAAC,EAAE;oBAC9D,IACE,eAAe,CAAC,UAAU,IAAI,gBAAgB;wBAC9C,eAAe,CAAC,UAAU,IAAI,aAAa;wBAC3C,eAAe,CAAC,UAAU,IAAI,yBAAyB,EACvD;wBACA,IAAI,CAAC,kBAAkB,EAAE,CAAC,SAAS,EAAE,CAAC;wBACtC,IAAI,CAAC,oBAAoB,EAAE,CAAC,SAAS,EAAE,CAAC;qBACzC;oBAED,IAAI,eAAe,CAAC,UAAU,IAAI,IAAI,CAAC,uBAAuB,EAAE;wBAC9D,IAAI,UAAU,GAAG,EAAE,CAAC;wBACpB,MAAA,eAAe,CAAC,OAAO,0CAAE,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;4BAC3C,UAAU,GAAG,CAAC,GAAG,UAAU,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC;wBACpD,CAAC,EAAE;wBAEH,IAAI,CAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,MAAM,IAAG,CAAC;4BAAE,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,CAAC;qBACpE;oBAED,IACE,eAAe,CAAC,UAAU,IAAI,IAAI,CAAC,mBAAmB;wBACtD,OAAA,eAAe,CAAC,OAAO,0CAAE,MAAM,IAAG,CAAC,EACnC;wBACA,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;4BACjB,SAAS,EAAE,eAAe,CAAC,UAAU;4BACrC,UAAU,EAAE,eAAe,CAAC,OAAO;yBACpC,CAAC,CAAC;qBACJ;oBAED,IAAI,eAAe,CAAC,UAAU,IAAI,IAAI,CAAC,qBAAqB,EAAE;wBAC5D,IAAI,QAAQ,SAAG,eAAe,CAAC,OAAO,0CAAE,MAAM,CAAC;wBAC/C,IAAI,QAAQ,GAAG,CAAC,EAAE;4BAChB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;gCACjB,SAAS,EAAE,wBAAwB;gCACnC,MAAM,EAAE,eAAe,CAAC,OAAO;6BAChC,CAAC,CAAC;yBACJ;6BAAM,IAAI,QAAQ,IAAI,CAAC,EAAE;4BACxB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;gCACjB,SAAS,EAAE,eAAe,CAAC,UAAU;gCACrC,aAAa,EAAE,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;6BACnD,CAAC,CAAC;yBACJ;qBACF;oBAED,IAAI,eAAe,CAAC,YAAY,IAAI,MAAM,EAAE;wBAC1C,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;4BACjB,SAAS,EAAE,eAAe,CAAC,UAAU;4BACrC,MAAM,EAAE,eAAe,CAAC,OAAO;yBAChC,CAAC,CAAC;wBAEH,IAAI,IAAI,CAAC,eAAe,EAAE,EAAE;4BAC1B,eAAe,CAAC,OAAO;gCACrB,MAAM,GAAG,oDAAoD,CAAC;yBACjE;qBACF;oBAED,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;wBAChB,IAAI,EAAE,IAAI;wBACV,OAAO,EAAE,eAAe,CAAC,OAAO;wBAChC,MAAM,EAAE,eAAe;wBACvB,IAAI,EAAE,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC;qBAC/B,CAAC,CAAC;oBAEH,IAAI,IAAI,CAAC,eAAe,EAAE,EAAE;wBAC1B,UAAU,CAAC,GAAG,EAAE;4BACd,IAAI,CAAC,qBAAqB,EAAE,CAAC;wBAC/B,CAAC,EAAE,GAAG,CAAC,CAAC;qBACT;oBAED,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;iBACtB;qBAAM;oBACL,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;wBAChB,IAAI,EAAE,IAAI;wBACV,OAAO,EAAE,IAAI,CAAC,UAAU;wBACxB,IAAI,EAAE,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC;qBAC/B,CAAC,CAAC;iBACJ;gBAED,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC;gBACtD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;aACzB;YAED,IAAI,CAAC,cAAc,EAAE,CAAC;YAEtB,qDAAqD;YACrD,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;YAC1B,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,MAAM,EAAE,cAAc,CAAC,CAAC;QAChD,CAAC,CAAC,CAAC;IACL,CAAC;IAED,cAAc,CAAC,IAAa;QAC1B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC;QACnC,MAAM,GAAG,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,eAAe,CAAC;QACxD,KAAK,CAAC,GAAG,EAAE;YACT,MAAM,EAAE,MAAM;YACd,OAAO,EAAE;gBACP,cAAc,EAAE,kBAAkB;gBAClC,WAAW,EAAE,IAAI,CAAC,MAAM;gBACxB,aAAa,EAAE,IAAI,CAAC,KAAK;aAC1B;YACD,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC;SACzE,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE;YACX,IAAI,IAAI,EAAE;gBACR,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;oBAChB,IAAI,EAAE,IAAI;oBACV,OAAO,EACL,IAAI,CAAC,eAAe;wBACpB,6CAA6C;oBAC/C,IAAI,EAAE,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC;oBAC9B,aAAa,EAAE,IAAI;iBACpB,CAAC,CAAC;gBAEH,IAAI,CAAC,cAAc,EAAE,CAAC;gBACtB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;gBACxB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;gBAC1B,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC;gBACnC,OAAO;aACR;YAED,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;gBAChB,IAAI,EAAE,IAAI;gBACV,OAAO,EAAE,IAAI,CAAC,cAAc,CAC1B,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,kBAAkB,CAAC,CACjD;gBACD,IAAI,EAAE,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC;gBAC9B,aAAa,EAAE,IAAI;aACpB,CAAC,CAAC;YACH,IAAI,CAAC,kBAAkB;gBACrB,CAAC,IAAI,CAAC,kBAAkB,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC;YACjE,IAAI,CAAC,cAAc,EAAE,CAAC;YACtB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YACxB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;YAC1B,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC;QACrC,CAAC,CAAC,CAAC;IACL,CAAC;IACD,aAAa,CAAC,KAAoB;QAChC,IAAI,KAAK,CAAC,GAAG,KAAK,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE;YAC5C,sCAAsC;YACtC,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,4BAA4B;YAC5B,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;SAC1B;IACH,CAAC;IACD,YAAY,CAAC,KAAK;QAChB,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,IAAI,CAAC,cAAc,EAAE,CAAC;IAExB,CAAC;IAED,aAAa,CAAC,GAAQ;QACpB,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,OAAO;SACR;QAED,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;QAC1B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,KAAK,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC;QAEnD,IAAI,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE;YAC7B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC;SACxD;QAED,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;IAED,eAAe,CAAC,GAAQ;QACtB,IAAI,IAAI,CAAC,YAAY;YAAE,OAAO;QAC9B,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAC3B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC;QACvD,IAAI,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,KAAK;YACzB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,KAAK,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC;IACvD,CAAC;IACD,gCAAgC;IAChC,yCAAyC;IACzC,uDAAuD;IACvD,kCAAkC;IAClC,gCAAgC;IAChC,8DAA8D;IAC9D,8CAA8C;IAC9C,yCAAyC;IACzC,gCAAgC;IAChC,8CAA8C;IAC9C,yBAAyB;IACzB,4CAA4C;IAC5C,kCAAkC;IAClC,yCAAyC;IACzC,QAAQ;IACR,IAAI;IACJ,QAAQ,CAAC,EAAE,EAAE,KAAK;QAChB,uBAAuB;QACvB,IAAI,WAAW,GAAG,QAAQ,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;QAE9C,uDAAuD;QACvD,IAAI,YAAY,GAAG,QAAQ,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;QACtD,YAAY,CAAC,KAAK,GAAG,WAAW,CAAC,SAAS,CAAC;QAE3C,0EAA0E;QAC1E,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;QAExC,sCAAsC;QACtC,YAAY,CAAC,MAAM,EAAE,CAAC;QAEtB,iCAAiC;QACjC,QAAQ,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;QAE7B,gCAAgC;QAChC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;QAExC,mGAAmG;QACnG,sCAAsC;QAEtC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC;QAClC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QACzB,uCAAuC;QACvC,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,MAAM,GAAG,KAAK,CAAC;YACnC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAC3B,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,wBAAwB;IACpC,CAAC;IACD,eAAe,CAAC,KAAU;QACxB,oCAAoC;QACpC,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC;QAClD,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,cAAc,GAAG,KAAK,EAAE,KAAK,CAAC,CAAC;IAC/D,CAAC;IAED,YAAY,CAAC,IAAY;QACvB,MAAM,GAAG,GAAG,IAAI,SAAS,EAAE,CAAC,eAAe,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC;QAE/D,gEAAgE;QAChE,MAAM,QAAQ,GAAG,QAAQ,CAAC,sBAAsB,EAAE,CAAC;QAEnD,yEAAyE;QACzE,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YAC/C,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC;QAC7C,CAAC,CAAC,CAAC;QAEH,uDAAuD;QACvD,MAAM,aAAa,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACpD,aAAa,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;QAEpC,8CAA8C;QAC9C,0BAA0B;QAC1B,aAAa;aACV,gBAAgB,CAAC,QAAQ,CAAC;aAC1B,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC;QAExC,yCAAyC;QACzC,OAAO,aAAa,CAAC,SAAS,CAAC;IACjC,CAAC;IAID,iBAAiB,CAAC,KAAU;QAC1B,IAAI,IAAI,CAAC,qBAAqB,IAAI,CAAC,CAAC,EAAE;YACpC,IAAI,CAAC,qBAAqB,GAAG,KAAK,CAAC;YACnC,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,YAAY,CAC9C,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,OAAO,CAC5B,CAAC;YACF,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,uBAAuB,CAAC,OAAO,CACjE,wCAAwC,EACxC,EAAE,CACH,CAAC;YAEF,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;SAC1B;aAAM;YACL,IAAI,IAAI,CAAC,qBAAqB,IAAI,KAAK,EAAE;gBACvC,IAAI,CAAC,uBAAuB,IAAI,IAAI,CAAC,YAAY,CAC/C,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,OAAO,CAC5B,CAAC;gBACF,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,uBAAuB,CAAC,OAAO,CACjE,wCAAwC,EACxC,EAAE,CACH,CAAC;gBACF,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;aAC1B;iBAAM;gBACL,IAAI,CAAC,qBAAqB,GAAG,KAAK,CAAC;gBACnC,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,YAAY,CAC9C,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,OAAO,CAC5B,CAAC;gBACF,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,uBAAuB,CAAC,OAAO,CACjE,wCAAwC,EACxC,EAAE,CACH,CAAC;gBACF,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;aAC1B;SACF;QACD,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,QAAQ,GAAG,IAAI,CAAC;QACpC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QACzB,uCAAuC;QACvC,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,QAAQ,GAAG,KAAK,CAAC;YACrC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAC3B,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,wBAAwB;QAClC,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;QAC1B,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,0BAA0B,CAAC,CAAC;QACnE,IAAI,MAAM,EAAE;YACV,MAAM,CAAC,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC;SAC/B;QACD,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IACD,cAAc;QACZ,IAAI,OAAO,GAAG,CAAC,CAAC;QAChB,MAAM,QAAQ,GAAG,WAAW,CAAC,GAAG,EAAE;YAChC,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,YAAY,CAAC;YACjF,IAAI,OAAO,EAAE,GAAG,CAAC;gBAAE,aAAa,CAAC,QAAQ,CAAC,CAAC;QAC7C,CAAC,EAAE,CAAC,CAAC,CAAC;IACR,CAAC;IAED,YAAY,CAAC,MAAW;QACtB,OAAO,CAAC,IAAI,CAAC,qCAAqC,CAAC,CAAC;QACpD,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAErB,IAAI,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,OAAO,EAAE;SACpB;IACH,CAAC;IAED,eAAe;QACb,gFAAgF;QAChF,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE;YACtB,IAAI,CAAC,eAAe,EAAE,CAAC;SACxB;QAED,yDAAyD;QACzD,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,MAAe,EAAE,EAAE;YACrD,IAAI,MAAM,EAAE;gBACV,IAAI,CAAC,eAAe,EAAE,CAAC;aACxB;iBAAM;gBACL,IAAI,CAAC,kBAAkB,EAAE,CAAC;aAC3B;QACH,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YAC5C,IAAI,MAAM,EAAE;gBACV,UAAU,CAAC,GAAG,EAAE;oBACd,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE;wBACpD,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC,CAAC,wBAAwB;qBAChE;gBACH,CAAC,CAAC,CAAC;aACJ;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,eAAe;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC;IAChE,CAAC;IAEO,kBAAkB;QACxB,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC;IACnE,CAAC;IAED,qBAAqB,CAAC,GAAG;QACvB,MAAM,GAAG,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,WAAW,IAAI,CAAC,OAAO,yBAAyB,CAAC;QAC1F,KAAK,CAAC,GAAG,EAAE;YACT,MAAM,EAAE,MAAM;YACd,OAAO,EAAE;gBACP,cAAc,EAAE,kBAAkB;gBAClC,aAAa,EAAE,SAAS,GAAG,iBAAiB;aAC7C;YACD,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC;SAC1B,CAAC;aACC,IAAI,CAAC,CAAC,QAAQ,EAAE,EAAE;YACjB,IAAI,QAAQ,CAAC,EAAE,EAAE;gBACf,OAAO,QAAQ,CAAC,IAAI,EAAE,CAAC,CAAC,sCAAsC;aAC/D;iBAAM;gBACL,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC,CAAC;aACjD;QACH,CAAC,CAAC;aACD,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE;YACb,IAAI,CAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,MAAM,IAAG,CAAC,EAAE;gBACpB,IAAI,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;oBACvB,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC;gBACtC,CAAC,CAAC,CAAC;gBAEH,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;aACzB;QACH,CAAC,CAAC;aACD,KAAK,CAAC,CAAC,GAAG,EAAE,EAAE;YACb,OAAO,CAAC,KAAK,CAAC,sBAAsB,EAAE,GAAG,CAAC,CAAC;YAC3C,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACvB,CAAC,CAAC,CAAC;IACP,CAAC;IAED,oBAAoB,CAAC,SAAS,EAAE,MAAM;QACpC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC;YACvB,SAAS;YACT,MAAM;SACP,CAAC,CAAC;IACL,CAAC;IAED,qBAAqB;QACnB,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,aAAa,CAAC,cAAc,CAAC,CAAC;QAC5E,IAAI,OAAO,EAAE;YACX,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,EAAE;gBAC1C,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;YACvB,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAED,eAAe;QACb,OAAO,gEAAgE,CAAC,IAAI,CAC1E,SAAS,CAAC,SAAS,CACpB,CAAC;IACJ,CAAC;IAED,aAAa,CAAC,MAAM;QAClB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC;YACxB,OAAO,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC;YACpC,MAAM;SACP,CAAC,CAAC;QAEH,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,kBAAkB,EAAE,CAAC,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;gBAC1C,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YAC1B,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,oBAAoB,EAAE,CAAC,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;gBAC5C,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YAC1B,CAAC,CAAC,CAAC;QACL,CAAC,EAAE,GAAG,CAAC,CAAC;IACV,CAAC;IAED,uBAAuB,CAAC,IAAI;QAC1B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAClC,CAAC;IAED,UAAU,CAAC,MAAM;QACf,OAAO,CAAC,CACN,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC;YAC1B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,MAAM,CAAC,CAC9C,CAAC;IACJ,CAAC;IAED,aAAa,CAAC,MAAM;QAClB,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,IAAI,MAAM,CAAC,CAAC;IAClE,CAAC;IAED,oBAAoB;QAClB,MAAM,OAAO,GAAG,IAAI,WAAW,CAAC;YAC9B,cAAc,EAAE,kBAAkB;YAClC,MAAM,EAAE,IAAI,CAAC,UAAU;SACxB,CAAC,CAAC;QACH,OAAO,IAAI,CAAC,IAAI;aACb,GAAG,CACF,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,WAAW,IAAI,CAAC,OAAO,6DAA6D,IAAI,CAAC,MAAM,EAAE,EAC9H,EAAE,OAAO,EAAE,CACZ;aACA,IAAI,CACH,SAAS,CAAC,CAAC,GAAQ,EAAE,EAAE;YACrB,IAAI,CAAC,eAAe,GAAG,GAAG,CAAC;YAC3B,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YACxB,OAAO,EAAE,CAAC,GAAG,CAAC,CAAC;QACjB,CAAC,CAAC,EACF,UAAU,CAAC,CAAC,KAAU,EAAE,EAAE;YACxB,OAAO,CAAC,KAAK,CAAC,mCAAmC,EAAE,KAAK,CAAC,CAAC;YAC1D,OAAO,EAAE,CAAC,IAAI,CAAC,CAAC;QAClB,CAAC,CAAC,CACH,CAAC;IACN,CAAC;IAED,kBAAkB;QAChB,MAAM,OAAO,GAAG,IAAI,WAAW,CAAC;YAC9B,cAAc,EAAE,kBAAkB;YAClC,MAAM,EAAE,IAAI,CAAC,UAAU;SACxB,CAAC,CAAC;QACH,OAAO,IAAI,CAAC,IAAI;aACb,GAAG,CACF,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,WAAW,IAAI,CAAC,OAAO,qCAAqC,IAAI,CAAC,MAAM,EAAE,EACtG,EAAE,OAAO,EAAE,CACZ;aACA,IAAI,CACH,SAAS,CAAC,CAAC,GAAQ,EAAE,EAAE;YACrB,IAAI,CAAC,aAAa,GAAG,GAAG,CAAC;YACzB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YACxB,OAAO,EAAE,CAAC,GAAG,CAAC,CAAC;QACjB,CAAC,CAAC,EACF,UAAU,CAAC,CAAC,KAAU,EAAE,EAAE;YACxB,OAAO,CAAC,KAAK,CAAC,mCAAmC,EAAE,KAAK,CAAC,CAAC;YAC1D,OAAO,EAAE,CAAC,IAAI,CAAC,CAAC;QAClB,CAAC,CAAC,CACH,CAAC;IACN,CAAC;IAMD,iCAAiC;IACjC,cAAc;QACZ,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,cAAc,GAAG,CAAC,IAAI,CAAC,cAAc,CAAC;QAC3C,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAED,WAAW,CAAC,KAAY;;QACtB,MAAA,IAAI,CAAC,MAAM,0CAAE,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,QAAQ,GAAG,KAAK,CAAC,EAAE;QAC1D,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAED,aAAa,CAAC,KAAU;QACtB,mCAAmC;QACnC,qBAAqB;QACrB,IAAI,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,KAAK,CAAC,EAAE,CAAC,CAAC;QAC7D,IAAI,UAAU,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE;YACvC,UAAU,CAAC,CAAC,CAAC,CAAC,QAAQ,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC;YACjD,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;SAC1B;QACD,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAED,cAAc;;QACZ,aAAO,IAAI,CAAC,MAAM,0CAAE,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,QAAQ,EAAE;IACxD,CAAC;IAED,qBAAqB;;QACnB,MAAM,cAAc,SAAG,IAAI,CAAC,MAAM,0CAAE,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QACtE,IAAI,cAAc,IAAI,CAAA,cAAc,aAAd,cAAc,uBAAd,cAAc,CAAE,MAAM,MAAK,CAAC,EAAE;YAClD,OAAO,YAAY,CAAC;SACrB;aAAM;YACL,OAAO,CAAA,cAAc,aAAd,cAAc,uBAAd,cAAc,CAAE,MAAM,IAAG,CAAC;gBAC/B,CAAC,CAAC,GAAG,cAAc,aAAd,cAAc,uBAAd,cAAc,CAAE,MAAM,kBAAkB;gBAC7C,CAAC,CAAC,GAAG,cAAc,aAAd,cAAc,uBAAd,cAAc,CAAE,MAAM,iBAAiB,CAAC;SAChD;IACH,CAAC;IACD,gBAAgB;QACd,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,MAAM,GAAG,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,UAAU,YAAY,IAAI,CAAC,KAAK,gBAAgB,CAAC;QACjF,MAAM,OAAO,GAAG,IAAI,WAAW,CAAC;YAC9B,cAAc,EAAE,kBAAkB;SACnC,CAAC,CAAC;QAEH,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,EAAE,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC,IAAI,CAC9C,SAAS,CAAC,CAAC,GAAQ,EAAE,EAAE;YACrB,IAAI,GAAG,EAAE;gBACP,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,iCAC5B,KAAK,KACR,QAAQ,EAAE,KAAK,IACf,CAAC,CAAC;aACL;YACD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YAExB,OAAO,EAAE,CAAC,GAAG,CAAC,CAAC;QACjB,CAAC,CAAC,EACF,UAAU,CAAC,CAAC,KAAK,EAAE,EAAE;YACnB,OAAO,CAAC,KAAK,CAAC,iCAAiC,EAAE,KAAK,CAAC,CAAC;YAExD,OAAO,EAAE,CAAC,IAAI,CAAC,CAAC;QAClB,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAOD,iBAAiB;QACf,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAC7B,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAC7B,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;QACjC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,MAAM,eAAe,GAAG,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACpE,IAAI,CAAC,cAAc,GAAG,eAAe,CAAC;QACtC,MAAM,GAAG,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,UAAU,yCAAyC,eAAe,UAAU,IAAI,CAAC,KAAK,EAAE,CAAC;QACzH,MAAM,OAAO,GAAG,IAAI,WAAW,CAAC;YAC9B,cAAc,EAAE,kBAAkB;YAClC,MAAM,EAAE,0BAA0B;SACnC,CAAC,CAAC;QAEH,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC,IAAI,CACzC,SAAS,CAAC,CAAC,GAAQ,EAAE,EAAE;YACrB,IAAI,GAAG,EAAE;gBACP,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;gBAC5B,IAAI,CAAC,eAAe,GAAG,GAAG,CAAC;gBAC3B,OAAO,CAAC,GAAG,CAAC,yBAAyB,CAAC,CAAC;gBACvC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;gBAC5B,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;aAClB;YACD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YAExB,OAAO,EAAE,CAAC,GAAG,CAAC,CAAC;QACjB,CAAC,CAAC,EACF,UAAU,CAAC,CAAC,KAAK,EAAE,EAAE;YACnB,OAAO,CAAC,KAAK,CAAC,oCAAoC,EAAE,KAAK,CAAC,CAAC;YAC3D,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;YAC7B,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;YAE5B,IAAI,CAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,MAAM,KAAI,GAAG,EAAE;gBACxB,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;gBACpB,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;gBAC7B,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;aAC7B;YACD,OAAO,EAAE,CAAC,IAAI,CAAC,CAAC;QAClB,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,WAAW;QACT,IAAI,CAAC,gBAAgB,EAAE,CAAC,SAAS,EAAE,CAAC;IACtC,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,iBAAiB,EAAE,CAAC,SAAS,EAAE,CAAC;IACvC,CAAC;IAED,sCAAsC;IACtC,wBAAwB,CAAC,QAAgB;QACvC,IAAI,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;QAEtC,uDAAuD;QAEvD,6CAA6C;QAC7C,MAAM,aAAa,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;QAE9C,iDAAiD;QAEjD,OAAO,aAAa,CAAC;IACvB,CAAC;IAED,WAAW,CAAC,QAAgB;QAC1B,IAAI,CAAC,QAAQ,IAAI,CAAC,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,EAAE;YACvC,OAAO,CAAC,KAAK,CAAC,iCAAiC,CAAC,CAAC;YACjD,OAAO,EAAE,CAAC;SACX;QAED,qEAAqE;QACrE,IAAI,IAAI,GAAG,QAAQ,CAAC,OAAO,CAAC,qBAAqB,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE;YACzE,MAAM,KAAK,GAAG,MAAM,CAAC,MAAM,CAAC;YAC5B,IAAI,KAAK,KAAK,CAAC,EAAE;gBACf,OAAO,eAAe,IAAI,gBAAgB,CAAC;aAC5C;iBAAM,IAAI,KAAK,KAAK,CAAC,EAAE;gBACtB,OAAO,eAAe,IAAI,gBAAgB,CAAC;aAC5C;YACD,OAAO,WAAW,IAAI,WAAW,CAAC;QACpC,CAAC,CAAC,CAAC;QAEH,kEAAkE;QAClE,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,2BAA2B,EAAE,CAAC,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE;YACrE,MAAM,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YAC1C,MAAM,QAAQ,GAAG,IAAI,IAAI,WAAW,CAAC;YAErC,0CAA0C;YAC1C,OAAO;;mFAEsE,WAAW;6DACjC,QAAQ,KAAK,WAAW;aACxE,CAAC;QACV,CAAC,CAAC,CAAC;QAEH,qEAAqE;QACrE,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,iBAAiB,CAAC,CAAC;QAErD,yCAAyC;QACzC,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,gBAAgB,EAAE,qBAAqB,CAAC,CAAC;QAE7D,yBAAyB;QACzB,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,kBAAkB,EAAE,aAAa,CAAC,CAAC;QAEvD,6BAA6B;QAC7B,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,eAAe,EAAE,aAAa,CAAC,CAAC;QAEpD,uCAAuC;QACvC,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,yBAAyB,EAAE,qCAAqC,CAAC,CAAC;QAEtF,gDAAgD;QAChD,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,iBAAiB,EAAE,MAAM,CAAC,CAAC;QAE/C,OAAO,IAAI,CAAC;IACd,CAAC;IAED,4DAA4D;IAC5D,UAAU,CAAC,IAAY;QACrB,OAAO,IAAI;aACR,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC;aACtB,OAAO,CAAC,IAAI,EAAE,MAAM,CAAC;aACrB,OAAO,CAAC,IAAI,EAAE,MAAM,CAAC;aACrB,OAAO,CAAC,IAAI,EAAE,QAAQ,CAAC;aACvB,OAAO,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;IAC7B,CAAC;IAED,qCAAqC;IAC9B,eAAe,CAAC,IAAY;QACjC,SAAS,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE;YAC5C,KAAK,CAAC,2BAA2B,CAAC,CAAC;QACrC,CAAC,EAAE,CAAC,GAAG,EAAE,EAAE;YACT,OAAO,CAAC,KAAK,CAAC,uBAAuB,EAAE,GAAG,CAAC,CAAC;QAC9C,CAAC,CAAC,CAAC;IACL,CAAC;IAUD,cAAc;QACZ,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC;QACrC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAED,mBAAmB;QACjB,IAAI,CAAC,mBAAmB,GAAG,CAAC,IAAI,CAAC,mBAAmB,CAAC;QACrD,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IACD,oBAAoB;QAClB,IAAI,CAAC,oBAAoB,GAAG,CAAC,IAAI,CAAC,oBAAoB,CAAC;QACvD,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IA6BD,iCAAiC;IACjC,aAAa,CAAC,GAAW;QACvB,IAAI;YACF,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,CAAC;YAClC,OAAO,QAAQ,CAAC,OAAO,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,2BAA2B;SACnE;QAAC,WAAM;YACN,OAAO,SAAS,CAAC;SAClB;IACH,CAAC;IAED,4BAA4B;IAC5B,aAAa,CAAC,GAAW;QACvB,MAAM,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;QACvC,OAAO,oDAAoD,MAAM,EAAE,CAAC;IACtE,CAAC;IAED,WAAW,CAAC,OAAO;QACjB,IAAI,CAAC,kBAAkB,GAAG,OAAO,CAAC;QAClC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QACzB,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;QAC1B,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,0BAA0B,CAAC,CAAC;QACnE,IAAI,MAAM,EAAE;YACV,MAAM,CAAC,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC;SAC/B;IACH,CAAC;IAID,eAAe;QACb,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;QAC1B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;QAChC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAEzB,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,0BAA0B,CAAC,CAAC;QACnE,IAAI,MAAM,EAAE;YACV,MAAM,CAAC,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC;SAC/B;IACH,CAAC;IAED,aAAa;QACX,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QAC3B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;QAC/B,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC,CAAC,qCAAqC;QAC/D,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAED,aAAa;QACX,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QAC3B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC,CAAC,qCAAqC;QAC/D,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IACD,cAAc;QACZ,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;YACzB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC,CAAC,qCAAqC;YAC/D,6CAA6C;YAC7C,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,0BAA0B,CAAC,CAAC;YACnE,IAAI,MAAM,EAAE;gBACV,MAAM,CAAC,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC;aAChC;QACH,CAAC,EAAE,GAAG,CAAC,CAAC;IACV,CAAC;IAGD,YAAY,CAAC,IAAI;QACf,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QACzB,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAChC,CAAC;IACD,sBAAsB;QACpB,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,0BAA0B,CAAC,CAAC;QACnE,IAAI,MAAM,EAAE;YACV,MAAM,CAAC,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC;SAC7D;IACH,CAAC;IACD,gBAAgB,CAAC,IAAY;QAC3B,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;IAC9B,CAAC;IACD,oBAAoB,CAAC,KAAU;QAC7B,IAAI;YACF,IAAI,KAAK,CAAC,GAAG,KAAK,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE;gBAC5C,uCAAuC;gBACvC,KAAK,CAAC,cAAc,EAAE,CAAC;aACxB;SACF;QAAC,OAAO,KAAK,EAAE;SAEf;QACD,MAAM,QAAQ,GAAG,KAAK,CAAC,MAA6B,CAAC;QACrD,QAAQ,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC,mBAAmB;QACnD,QAAQ,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,QAAQ,CAAC,YAAY,IAAI,CAAC,CAAC,iCAAiC;QACvF,6DAA6D;QAC7D,IAAI,QAAQ,CAAC,YAAY,GAAG,GAAG,EAAE;YAC/B,QAAQ,CAAC,KAAK,CAAC,MAAM,GAAG,OAAO,CAAC,CAAC,iCAAiC;YAClE,QAAQ,CAAC,KAAK,CAAC,SAAS,GAAG,MAAM,CAAC,CAAC,4CAA4C;SAChF;aAAM;YACL,QAAQ,CAAC,KAAK,CAAC,SAAS,GAAG,QAAQ,CAAC,CAAC,6CAA6C;SACnF;IACH,CAAC;IAED,eAAe,CAAC,KAAK,GAAG,IAAI;QAE1B,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,EAAE;YAC9B,IAAI,CAAC,UAAU,CAAC,mBAAmB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;gBAChE,IAAI,CAAC,YAAY,GAAG,GAAG,CAAC;gBACxB,IAAI,CAAC,cAAc,GAAG,KAAK,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,KAAK,CAAC;gBAEnE,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;oBACxB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;oBAC7B,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;iBAChC;gBAED,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;YAC3B,CAAC,CAAC,CAAC;SACJ;IAEH,CAAC;IAED,cAAc;;QACZ,iFAAiF;QACjF,MAAM,YAAY,GAAG,EAAE,CAAC;QACxB,gBAAI,IAAI,CAAC,gBAAgB,0CAAE,OAAO,0CAAE,WAAW,EAAE;YAC/C,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;gBAC1D,YAAY,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG;oBAC5B,KAAK,CAAC,KAAK,IAAI,EAAE;oBACjB,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI;iBAC5C,CAAC;YACJ,CAAC,CAAC,CAAC;SACJ;QAED,sBAAsB;QACtB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;IAClD,CAAC;IAED,kBAAkB,CAAC,QAAQ;QACzB,IAAI,CAAC,gBAAgB,GAAG,QAAQ,CAAC;QACjC,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;QAC5B,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;IAChC,CAAC;IAED,gBAAgB;QACd,MAAM,SAAS,GAAG,QAAQ,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;QACtD,IAAI,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE;YAC3B,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;YAErC,IAAI,KAAK,GAAG,IAAI,CAAC,WAAW,CAC1B,IAAI,CAAC,gBAAgB,CACnB,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAC1B,IAAI,CAAC,YAAY,CAAC,KAAK,CACxB,CACF,CAAC;YAEF,2EAA2E;YAC3E,IAAI;gBACF,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CACnC,6BAA6B,CAC9B,GAAG,KAAK,CAAC;gBACV,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CACnC,6BAA6B,CAC9B,GAAG,KAAK,CAAC;aACX;YAAC,OAAO,KAAK,EAAE,GAAG;YAEnB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;gBAChB,IAAI,EAAE,MAAM;gBACZ,OAAO,EAAE,KAAK;gBACd,IAAI,EAAE,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC;gBAC9B,MAAM,EAAE,KAAK;gBACb,eAAe,EAAE,KAAK;gBACtB,2BAA2B,EAAE,IAAI;aAClC,CAAC,CAAC;YAEH,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YAEnB,IAAI,CAAC,6BAA6B,GAAG,CAAC,CAAC;YACvC,IAAI,CAAC,qBAAqB;gBACxB,YAAY,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;YACvD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;YAC5B,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;YAC9B,IAAI,CAAC,wBAAwB,GAAG;gBAC9B,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO;gBACtC,MAAM,EAAE,IAAI,CAAC,YAAY,CAAC,KAAK;gBAC/B,cAAc,EAAE,IAAI,CAAC,YAAY,CAAC,KAAK;gBACvC,YAAY,EAAE,IAAI,CAAC,gBAAgB,CAAC,IAAI;aACzC,CAAC;YACF,IAAI,CAAC,+BAA+B,GAAG,IAAI,CAAC,wBAAwB,CAAC;YACrE,IAAI,CAAC,cAAc,EAAE,CAAC;YAEtB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;YAEzB,+CAA+C;YAC/C,IAAI,CAAC,cAAc,CACjB,KAAK,EACL,IAAI,CAAC,MAAM,EACX,IAAI,CAAC,eAAe,EACpB,EAAE,EACF,IAAI,EACJ,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,EAC5B,IAAI,CAAC,YAAY,CAAC,KAAK,CACxB,CAAC;SACH;IACH,CAAC;IAED,cAAc,CACZ,QAAgB,EAChB,MAAa,EACb,cAAsB,EACtB,GAAS,EACT,IAAU,EACV,UAAmB,EACnB,eAAqB;QAErB,IAAI,GAAG,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,SAAS,CAAC;QAEhD,IAAI,IAAI,GAAG;YACT,aAAa,EAAE,QAAQ;YACvB,OAAO,EAAE,IAAI,CAAC,MAAM;YACpB,MAAM,EAAE,IAAI,CAAC,KAAK;YAClB,UAAU,EAAE,IAAI,CAAC,mBAAmB,CAAC,WAAW,EAAE;YAClD,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YACzD,eAAe,EAAE,cAAc;SAChC,CAAC;QAEF,IAAI,UAAU,EAAE;YACd,IAAI,CAAC,aAAa,CAAC,GAAG,UAAU,CAAC;YACjC,IAAI,CAAC,iBAAiB,CAAC,GAAG,eAAe,CAAC;SAC3C;QAED,KAAK,CAAC,GAAG,EAAE;YACT,MAAM,EAAE,MAAM;YACd,OAAO,EAAE;gBACP,cAAc,EAAE,kBAAkB;gBAClC,aAAa,EAAE,SAAS,GAAG,IAAI,CAAC,QAAQ;gBACxC,WAAW,EAAE,IAAI,CAAC,MAAM;gBACxB,aAAa,EAAE,IAAI,CAAC,KAAK;aAC1B;YACD,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;SAC3B,CAAC;aACC,IAAI,CAAC,CAAC,QAAQ,EAAE,EAAE;YACjB,IAAI,QAAQ,CAAC,MAAM,KAAK,GAAG,IAAI,QAAQ,CAAC,MAAM,KAAK,GAAG,EAAE;gBACtD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;gBAClB,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;gBAEzB,yCAAyC;gBACzC,IAAI,GAAG,IAAI,IAAI,EAAE;oBACf,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;oBACf,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;oBACjB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;iBAC5B;aACF;iBAAM;gBACL,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;aACpB;YACD,OAAO,QAAQ,CAAC,IAAI,EAAE,CAAC;QACzB,CAAC,CAAC;aACD,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE;YACb,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAClB,yCAAyC;QAC3C,CAAC,CAAC;aACD,KAAK,CAAC,CAAC,GAAG,EAAE,EAAE;YACb,OAAO,CAAC,KAAK,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC;YAC9B,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAC/B,CAAC,CAAC,CAAC;QAEL,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;QAChB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;QAC7B,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;QAC5B,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;IAED,gBAAgB,CAAC,KAAK,EAAE,GAAG;;QACzB,qCAAqC;QACrC,IAAI,QAAQ,GAAG,MAAM,KAAK,IAAI,CAAC;QAE/B,gEAAgE;QAChE,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;YAC9C,IAAI,SAAS,GACX,OAAA,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,CAC5C,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,KAAK,GAAG,CACjC,0CAAE,KAAK,KAAI,GAAG,CAAC;YAClB,QAAQ,IAAI,OAAO,SAAS,OAAO,KAAK,IAAI,CAAC;SAC9C;QAED,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,0BAA0B,CAAC,WAAW;QACpC,IAAI,CAAC,WAAW,EAAE;YAChB,IAAI,CAAC,wBAAwB,GAAG,IAAI,CAAC,+BAA+B,CAAC;YACrE,IAAI,CAAC,4BAA4B,GAAG,IAAI,CAAC;YACzC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;YACzB,OAAO;SACR;QAED,IAAI,CAAC,UAAU,CAAC,wBAAwB,CAAC,WAAW,CAAC,CAAC,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;YACtE,IAAI,GAAG,IAAI,GAAG,CAAC,OAAO,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE;gBACpD,GAAG,CAAC,OAAO,GAAG,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;oBACvC,IAAI,MAAM,CAAC,eAAe,EAAE;wBAC1B,MAAM,CAAC,eAAe,GAAG,gBAAgB,CACvC,IAAI,CAAC,QAAQ,EACb,MAAM,CAAC,eAAe,CACvB,CAAC;qBACH;oBACD,OAAO,MAAM,CAAC;gBAChB,CAAC,CAAC,CAAC;aACJ;YAED,GAAG,CAAC,eAAe,GAAG,gBAAgB,CACpC,IAAI,CAAC,QAAQ,EACb,GAAG,CAAC,eAAe,CACpB,CAAC;YACF,IAAI,CAAC,wBAAwB,GAAG,GAAG,CAAC;YACpC,IAAI,CAAC,4BAA4B,GAAG,IAAI,CAAC;YACzC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAC3B,CAAC,CAAC,CAAC;IACL,CAAC;IAED,UAAU;QACR,IAAI,CAAC,4BAA4B,GAAG,KAAK,CAAC;IAC5C,CAAC;IAED,aAAa,CAAC,GAAQ;QACpB,OAAO,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;IACnE,CAAC;IAED,oBAAoB;QAClB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QACzE,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;QACjC,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAC7B,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC1B,CAAC,EAAE,GAAG,CAAC,CAAC;QACR,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAED,0BAA0B,CAAC,KAAa;QACtC,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC,YAAY,CAAC,sBAAsB,CAC/D,KAAK,EACL,IAAI,CAAC,MAAM,CACZ,CAAC;QACF,MAAM,WAAW,GAAG,SAAS,CAAC,WAAW,CAAC,0BAA0B,EAAE,CAAC;QACvE,IAAI,CAAC,UAAU,GAAG,IAAI,SAAS,CAAC,gBAAgB,CAC9C,IAAI,CAAC,YAAY,EACjB,WAAW,CACZ,CAAC;QAEF,IAAI,CAAC,UAAU,CAAC,WAAW,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;YACrC,IAAI,CAAC,CAAC,MAAM,CAAC,MAAM,KAAK,SAAS,CAAC,YAAY,CAAC,iBAAiB,EAAE;gBAChE,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC;gBAC3B,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC;gBAC7C,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;aACzB;QACH,CAAC,CAAC;QAEF,IAAI,CAAC,UAAU,CAAC,UAAU,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;YACpC,IAAI,CAAC,CAAC,MAAM,CAAC,MAAM,KAAK,SAAS,CAAC,YAAY,CAAC,gBAAgB,EAAE;gBAC/D,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC;gBAC3B,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC;gBAC5C,IAAI,CAAC,eAAe,EAAE,CAAC;gBACvB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;aACzB;QACH,CAAC,CAAC;QAEF,IAAI,CAAC,UAAU,CAAC,QAAQ,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;YAClC,OAAO,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC,CAAC,YAAY,CAAC,CAAC;QAC9C,CAAC,CAAC;QAEF,IAAI,CAAC,UAAU,CAAC,cAAc,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;YACxC,OAAO,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC;YAChC,IAAI,CAAC,UAAU,CAAC,8BAA8B,EAAE,CAAC;YACjD,IAAI,CAAC,SAAS,EAAE,CAAC;QACnB,CAAC,CAAC;IACJ,CAAC;IAED,eAAe;QACb,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC;QAErC,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,IAAI,CAAC,gBAAgB,EAAE,CAAC;SACzB;aAAM;YACL,IAAI,CAAC,eAAe,EAAE,CAAC;SACxB;IACH,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,UAAU,CAAC,+BAA+B,EAAE,CAAC;IACpD,CAAC;IAED,eAAe;QACb,IAAI,CAAC,UAAU,CAAC,8BAA8B,EAAE,CAAC;IACnD,CAAC;IAED,kBAAkB;QAChB,OAAO,IAAI,CAAC,KAAK,IAAI,0BAA0B,CAAC;IAClD,CAAC;;;YAp6DF,SAAS,SAAC;gBACT,QAAQ,EAAE,6BAA6B;gBACvC,452DAA2C;gBAE3C,eAAe,EAAE,uBAAuB,CAAC,MAAM;;aAChD;;;YATQ,WAAW;YAEX,WAAW;YA9BlB,iBAAiB;YAHV,UAAU;YAmBV,YAAY;YAdnB,UAAU;YAQV,SAAS;YAgBF,aAAa;YAFb,mBAAmB;;;uBAezB,SAAS,SAAC,UAAU;sBACpB,SAAS,SAAC,SAAS;qCACnB,YAAY,SAAC,uBAAuB;qBAEpC,SAAS,SAAC,QAAQ;4BAClB,SAAS,SAAC,eAAe;4BACzB,SAAS,SAAC,eAAe;yBAEzB,SAAS,SAAC,YAAY,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;0BAGzC,KAAK;wBACL,KAAK;uBACL,KAAK;qBACL,KAAK;yBACL,KAAK;2BACL,KAAK;yBACL,KAAK;sBACL,KAAK;wBACL,KAAK;oBACL,KAAK;oBACL,KAAK;+BACL,KAAK;iCACL,KAAK;0BACL,KAAK;4BACL,KAAK;4BACL,KAAK;sBACL,KAAK;uBACL,KAAK;wBACL,KAAK;sBACL,KAAK;+BACL,KAAK;iCACL,KAAK;uBACL,KAAK;6BACL,KAAK;uBACL,KAAK;iCACL,KAAK;mCACL,KAAK;oBACL,KAAK;8BACL,KAAK;kCACL,KAAK;wBACL,KAAK;iCACL,KAAK;8BACL,KAAK;uBACL,KAAK;+BACL,KAAK;wBACL,KAAK;qBACL,KAAK;oBACL,KAAK;+BAEL,KAAK;mCACL,KAAK;4BACL,MAAM;2BACN,MAAM;uBACN,MAAM;6BACN,MAAM;uBACN,MAAM;8BACN,MAAM;8BACN,MAAM;2BACN,MAAM","sourcesContent":["// import { Platform } from '@angular/cdk/platform';\nimport { HttpClient, HttpHeaders } from '@angular/common/http';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  QueryList,\n  Renderer2,\n  SimpleChanges,\n  ViewChild,\n  ViewChildren,\n} from '@angular/core';\nimport { MatDrawer } from '@angular/material/sidenav';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { of, Subscription } from 'rxjs';\nimport { catchError, switchMap } from 'rxjs/operators';\nimport { formatNow, formatTimeStamps } from '../../utils/utils';\nimport {\n  dev_environment,\n  prod_environment,\n} from '../../../environments/environment';\nimport { ConversationService } from '../conversation.service';\nimport { Observable } from 'rxjs';\nimport { SocketService } from '../socket-service.service';\n\nimport { FormBuilder, Validators } from '@angular/forms';\nimport * as SpeechSDK from 'microsoft-cognitiveservices-speech-sdk';\nimport { BotsService } from '../bot.service';\n\n@Component({\n  selector: 'hivegpt-chat-drawer-package',\n  templateUrl: './chat-drawer.component.html',\n  styleUrls: ['./chat-drawer.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ChatDrawerComponent implements OnInit, OnChanges {\n  @ViewChild('chatMain') private chatMain: ElementRef;\n  @ViewChild('myInput') private myInput: ElementRef;\n  @ViewChildren('closeplaygroundbutton')\n  closePlaygroundButtons: QueryList<ElementRef>;\n  @ViewChild('drawer') drawer!: MatDrawer;\n  @ViewChild('sourcesDrawer') sourcesDrawer!: MatDrawer;\n  @ViewChild('editorsDrawer') editorsDrawer!: MatDrawer;\n  private bodyOverflowClass = 'body-overflow-hidden';\n  @ViewChild('myTextarea', { static: false })\n  myTextarea!: ElementRef<HTMLTextAreaElement>; // Reference to the textarea\n  isCollapsedTrue = false;\n  @Input() copilotName: string = 'HiveXGPT';\n  @Input() firstName!: string;\n  @Input() lastName!: string;\n  @Input() apiKey!: string;\n  @Input() bgBubbleAi!: string;\n  @Input() bgBubbleUser!: string;\n  @Input() bgGradient!: string[];\n  @Input() botName!: string;\n  @Input() botSkills!: string;\n  @Input() botId!: string;\n  @Input() orgId!: string;\n  @Input() closeButtonColor!: string;\n  @Input() closeButtonbgColor!: string;\n  @Input() credentials!: [];\n  @Input() dateTimeColor!: string;\n  @Input() dateTextColor!: string;\n  @Input() eventId!: string;\n  @Input() s27Token!: string;\n  @Input() eventName!: string;\n  @Input() botIcon!: string;\n  @Input() formFieldBgColor!: string;\n  @Input() formFieldTextColor!: string;\n  @Input() fullView!: boolean;\n  @Input() gradientColors!: string[];\n  @Input() greeting!: string;\n  @Input() messageTextColorAi!: string;\n  @Input() messageTextColorUser!: string;\n  @Input() rules!: string;\n  @Input() sendButtonColor!: string;\n  @Input() sendButtonTextColor!: string;\n  @Input() showClose!: boolean;\n  @Input() thumbsDownMessages!: string[];\n  @Input() thumbsUpMessage!: string;\n  @Input() timezone!: string;\n  @Input() unknownResponses!: [];\n  @Input() useOpenAi!: boolean;\n  @Input() userId!: string;\n  @Input() isDev!: boolean;\n\n  @Input() againButtonColor!: string[];\n  @Input() againButtonTextColor!: string[];\n  @Output() feedbackEvent = new EventEmitter<string>();\n  @Output() onCloseEvent = new EventEmitter<void>();\n  @Output() openPage = new EventEmitter<any>();\n  @Output() sessionActions = new EventEmitter<any>();\n  @Output() closeBot = new EventEmitter<any>();\n  @Output() connectWithUser = new EventEmitter<any>();\n  @Output() scheduleMeeting = new EventEmitter<string>();\n  @Output() refreshToken = new EventEmitter<any>();\n\n  autogenKey = 'Autogen_eDJTtEU-NB0RtIpzq1w';\n  addToMyAgendaAction = 'add_to_my_agenda';\n  myUpcomingSessionAction = 'my_upcomming_session';\n  connectOrFollowAction = 'connect_or_follow';\n  aiResponse: string = '';\n  chatLog: any[] = [];\n  decoder = new TextDecoder();\n  feedbackDone: boolean = false;\n  greetingMsg: string = '';\n  hasBackdropValue: boolean = false;\n  input: string = '';\n  listenerAdded = false;\n  loading: boolean = false;\n  mode: string = 'over';\n  quickPrompts: any[] = [];\n  thumbsDownMsgIndex = 0;\n  userName: string = '';\n  showStartAgain: boolean = false;\n  isIOSDevice: boolean = false;\n  showFeedBackIconsIndex: number | null = null;\n  temperature: number = 1;\n  speakers = [];\n  environment: {\n    USERS_API;\n    BASE_URL;\n    AGENTS_API;\n  };\n  pendingRequests: any;\n  myConnections: any;\n  conversationKey: string;\n  isFetchDataFor: boolean;\n  is401: boolean;\n  msg: any;\n  chat: any;\n  isWorkflowOpen: boolean;\n  orgWorkflows: any;\n  openWorkflowInput: boolean;\n  selectedWorkflow: any;\n  workflowForm: any;\n  currentWorkflowActionProgress: number = 0;\n  currentWorkflowAction: string = '';\n  executingWorkflow: boolean;\n  workflowExecutionDetails: any;\n  showWorkflowExecutionDetails: any;\n  currentWorkflowExecutionDetails: any;\n\n  speechConfig: SpeechSDK.SpeechConfig;\n  recognizer: SpeechSDK.SpeechRecognizer;\n  recognizedText: string = '';\n  authorizationToken: string = '';\n  region: string = 'westeurope'; // Set your Azure region here\n  isRecording: boolean;\n\n  constructor(\n    private fb: FormBuilder,\n    private botService: BotsService,\n    private cdr: ChangeDetectorRef,\n    private http: HttpClient,\n    private sanitizer: DomSanitizer,\n    private elementRef: ElementRef,\n    private renderer: Renderer2,\n    private socketService: SocketService,\n    private conversationService: ConversationService // private platform: Platform\n  ) {\n    this.chatMain = new ElementRef(null);\n\n    // if (this.platform.IOS) {\n    //   this.isIOSDevice = true;\n    // }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.s27Token) {\n      if (changes.s27Token.currentValue != changes.s27Token.previousValue) {\n        this.s27Token = changes.s27Token.currentValue;\n\n        console.log('isFetchDataFor: ', this.isFetchDataFor);\n        console.log('msg: ', this.msg);\n        console.log('chat: ', this.chat);\n        if (this.is401) {\n          if (this.isFetchDataFor) {\n            this.fetchDataFor(this.msg, this.chat);\n          } else {\n            this.fetchData(this.msg);\n          }\n        }\n      }\n    }\n\n    if (changes.orgId) {\n      if (\n        changes.orgId.currentValue != changes.orgId.previousValue &&\n        changes.orgId.currentValue\n      ) {\n        this.initializeSocket();\n\n      }\n    }\n  }\n\n  ngOnInit(): void {\n    this.environment = this.isDev ? dev_environment : prod_environment;\n\n    // this.fetchMyConnections().subscribe();\n    // this.fetchPendingRequests().subscribe();\n\n    this.changeTemperature(this.temperature);\n    this.fetchBotConfig().subscribe(\n      (res) => {\n        this.cdr.markForCheck();\n\n        this.fetchChatHistory().subscribe(\n          (response) => {\n            this.loading = false;\n            this.mapChatHistory(response);\n            this.cdr.markForCheck();\n          },\n          (err) => {\n            console.error('Error fetching chat history:', err);\n          }\n        );\n      },\n      (err) => {\n        console.error('Error fetching chat history:', err);\n      }\n    );\n    // this.fetchAgents();\n    // this.fetchEditorContent();\n    this.cdr.markForCheck();\n    // this.initializeSocket();\n    if (!this.checkForCop29BotId()) {\n      this.botService.fetchSpeechAuthorizationToken().subscribe((token) => {\n        this.authorizationToken = token;\n        this.initializeSpeechRecognizer(token);\n      });\n    }\n  }\n\n  private eventSubscription: Subscription;\n  initializeSocket() {\n    try {\n      this.socketService.disconnectSocketConnection();\n    } catch (error) { }\n    setTimeout(() => {\n      this.socketService.connectSocketConnection();\n      setTimeout(() => {\n        console.log('YES INIT');\n        const conversation_id = this.conversationService.getKey(this.botId);\n\n        this.socketService.registerUserSpecificHiveSocket(\n          this.botId,\n          conversation_id,\n          this.orgId\n        );\n        setTimeout(() => {\n          this.listenSockets();\n        }, 300);\n      }, 200);\n    }, 300);\n  }\n\n  subscriptionNew: any;\n  socketData: any;\n\n  listenSockets() {\n    if (this.eventSubscription) {\n      this.eventSubscription.unsubscribe();\n    }\n    console.log('Listen Socket');\n    this.eventSubscription = this.conversationService\n      .getUserSpecificNotification()\n      .subscribe(\n        (res) => {\n          console.log('Listen Socket response');\n          console.log(res);\n          // Check if OtherFields exists in the response\n          if (res?.m?.OtherFields?.workflow_id) {\n            const {\n              percentage,\n              output,\n              action_name,\n              current_action_name,\n              workflow_execution_id,\n              time_stamp,\n            } = res?.m?.OtherFields;\n\n            this.currentWorkflowActionProgress = percentage;\n            this.currentWorkflowAction = action_name;\n\n            const actionIndex = this.workflowExecutionDetails.Actions.findIndex(\n              (a) => a.Name == current_action_name\n            );\n\n            if (actionIndex !== -1) {\n              this.workflowExecutionDetails.Actions[actionIndex][\n                'Output'\n              ] = output;\n              this.workflowExecutionDetails.Actions[actionIndex][\n                'InsertTimeStamp'\n              ] = formatTimeStamps(this.timezone, time_stamp);\n            } else {\n              console.error(`Action with name ${action_name} not found`);\n            }\n\n            this.currentWorkflowExecutionDetails = this.workflowExecutionDetails;\n\n            if (this.currentWorkflowActionProgress == 100) {\n              this.chatLog[this.chatLog.length - 1][\n                'WorkflowExecutionId'\n              ] = workflow_execution_id;\n              this.isChatingWithAi = false;\n              this.executingWorkflow = false;\n            }\n\n            this.cdr.detectChanges();\n          } else if (res?.m?.OtherFields) {\n            const {\n              conversation_id,\n              bot_id,\n              message_id,\n              answer,\n              web_results,\n              search_results,\n              graphs,\n              execution_graphs,\n              suggestions,\n            } = res?.m?.OtherFields;\n            console.log('message_id1');\n            console.log(res?.m?.OtherFields);\n            var currentChatMessage = this.chatLog.find(\n              (p) => p._id == message_id\n            );\n            console.log(this.chatLog);\n            if (!currentChatMessage) {\n              console.log('message_id2');\n              console.log(message_id);\n              currentChatMessage = {\n                _id: message_id,\n                type: 'ai',\n                time: formatNow(this.timezone),\n              };\n\n              this.chatLog.push(currentChatMessage);\n\n              this.showFeedBackIconsIndex = this.chatLog.length - 1;\n              console.log('message_id3');\n              console.log(message_id);\n              this.cdr.detectChanges();\n            }\n\n            // Handle the fields based on their presence\n            if (search_results && Array.isArray(search_results)) {\n              console.log('Online Search Terms:', search_results);\n              currentChatMessage.searchTerms = search_results;\n              this.cdr.detectChanges();\n            }\n\n            if (web_results && Array.isArray(web_results)) {\n              console.log('Web Results:', web_results);\n              currentChatMessage.sourcesList = web_results;\n              currentChatMessage.displayedSources = web_results?.slice(0, 3); // First 3 cards\n              currentChatMessage.remainingSources = web_results?.slice(3); // Remaining items\n              this.cdr.detectChanges();\n            }\n\n            if (answer) {\n              this.isChatingWithAi = false;\n              console.log('Answer:', answer);\n\n              currentChatMessage.message = this.processMessageForDisplay(\n                answer\n              );\n              this.cdr.detectChanges();\n              this.scrollToBottom();\n            }\n\n            if (graphs && Array.isArray(graphs)) {\n              console.log('Graphs:', graphs);\n              currentChatMessage.graphs = graphs;\n              this.cdr.detectChanges();\n            }\n\n            if (execution_graphs && Array.isArray(execution_graphs)) {\n              console.log('Execution Graphs:', execution_graphs);\n              currentChatMessage.executionGraphs = execution_graphs;\n              this.cdr.detectChanges();\n            }\n\n            if (suggestions && Array.isArray(suggestions)) {\n              console.log('suggestions:', suggestions);\n              currentChatMessage.relatedListItems = suggestions;\n              this.cdr.detectChanges();\n              // Process online search terms as needed\n            }\n\n            // Add any other fields and their processing here\n          } else {\n            console.warn('OtherFields is missing in the response');\n          }\n        },\n        (err) => {\n          this.eventSubscription.unsubscribe();\n          console.error('Error in fetching data from socket', err);\n        }\n      );\n  }\n\n  initializeSocketAndListen() { }\n  handleEvent(data: any, type: string) {\n    switch (type) {\n      case 'webresult':\n        break;\n      case 'answer':\n        break;\n      case 'graph':\n        break;\n      default:\n        break;\n    }\n  }\n  ngOnDestroy(): void {\n    if (this.eventSubscription) {\n      this.eventSubscription.unsubscribe();\n    }\n    this.socketService.disconnectSocketConnection();\n    //this.socketService.close();\n  }\n  changeTemperature(newTemperature: number) {\n    if (this.loading) return;\n    this.temperature = newTemperature;\n    const wrapper = document.querySelector('.hivegpt-chat-wrapper');\n    // Remove existing theme classes from body\n    wrapper?.classList.remove('creative', 'balanced', 'precise');\n\n    switch (newTemperature) {\n      case 0:\n        wrapper?.classList.add('creative');\n        break;\n      case 1:\n        wrapper?.classList.add('balanced');\n        break;\n      case 2:\n        wrapper?.classList.add('precise');\n        break;\n      default:\n        break;\n    }\n  }\n\n  onStartAgain() {\n    if (this.loading) return;\n    this.showStartAgain = false;\n    this.chatLog = [];\n    this.chatLog.push({\n      type: 'ai',\n      message: this.greetingMsg,\n\n      time: formatNow(this.timezone),\n    });\n    this.archieveMessages().subscribe();\n  }\n\n  archieveMessages() {\n    const headers = new HttpHeaders({\n      'Content-Type': 'application/json',\n      'x-api-key': this.apiKey,\n      'hive-bot-id': this.botId\n    });\n    const url = `${this.environment.BASE_URL}/bot/clear-history/${this.botId}/${this.userId}`;\n    return this.http.post(url, {}, { headers }).pipe(\n      switchMap((res: any) => {\n        return of(res);\n      }),\n      catchError((error) => {\n        return of(null);\n      })\n    );\n  }\n\n  fetchBotConfig() {\n    this.loading = true;\n    const headers = new HttpHeaders({\n      'x-api-key': this.apiKey,\n      'hive-bot-id': this.botId\n    });\n    const url = `${this.environment.BASE_URL}/bots?bot_id=${this.botId}`;\n    return this.http.get(url, {headers}).pipe(\n      switchMap((res: any) => {\n        this.botName = res.Name;\n        this.botIcon = res.Icon;\n        this.botSkills = res?.Skills;\n        this.greetingMsg = res.Greeting;\n\n        this.thumbsDownMessages = res?.NegativeResponses?.length\n          ? res.NegativeResponses\n          : [\n            \"We are sorry we've not been able to answer your question.<br/> However, our dedicated support team is happy to help. <span class='feedback-link' style='cursor: pointer; text-decoration: underline; font-weight: 700; color: #17235B;'>Please click here</span> and a human agent will assist you as soon as possible\",\n          ];\n        this.quickPrompts = res.QuickPrompts;\n        this.cdr.markForCheck();\n        this.loading = false;\n        return of(res);\n      }),\n      catchError((error) => {\n        console.error('Error fetching chatbot config: ', error);\n        this.loading = false;\n        return of(null);\n      })\n    );\n  }\n\n  fetchChatHistory(): Observable<any> {\n    this.loading = true;\n\n    this.conversationKey = this.conversationService.getKey(this.botId, false);\n    const url = `${this.environment.BASE_URL}/conversations/${this.conversationKey}`;\n    const headers = new HttpHeaders({\n      accept: 'application/json',\n      'x-api-key': this.apiKey,\n      'hive-bot-id': this.botId\n    });\n\n    return this.http\n      .get(url, { headers })\n      .pipe(catchError(this.handleError<any>('fetchConversation')));\n  }\n\n  private handleError<T>(operation = 'operation', result?: T) {\n    return (error: any): Observable<T> => {\n      console.error(`${operation} failed: ${error.message}`);\n      return of(result as T);\n    };\n  }\n  // fetchChatHistory() {\n  //   this.loading = true;\n  //   const headers = new HttpHeaders({\n  //     'Content-Type': 'application/json',\n  //     'x-api-key': this.apiKey,\n  //   });\n  //   return this.http\n  //     .get(`${this.environment.BASE_URL}/conversations/${this.conversationKey}`, { headers })\n  //     .pipe(\n  //       switchMap((res: any) => {\n  //         this.loading = false;\n  //         return of(res);\n  //       }),\n  //       catchError((error: any) => {\n  //         console.error('Error fetching chat history: ', error);\n  //         this.loading = false;\n  //         return of(null);\n  //       })\n  //     );\n  // }\n\n  mapChatHistory(chats: any) {\n    this.chatLog.push({\n      type: 'ai',\n      message: this.greetingMsg,\n      time: formatNow(this.timezone),\n    });\n    if (chats && chats?.Messages?.length) {\n      chats?.Messages.forEach((chat: any) => {\n        if (chat.Type == 'user') {\n          this.chatLog.push({\n            type: 'user',\n            message: this.processMessageForDisplay(chat.Text),\n            time: formatTimeStamps(this.timezone, chat.InsertTimestamp),\n            copied: false,\n            isCollapsedTrue: false,\n            WorkflowExecutionId: chat.WorkflowExecutionId,\n          });\n        }\n        if (chat.Type == 'ai') {\n          var sourcesList = chat.WebLinks || [];\n          var displayedSources = chat.WebLinks.slice(0, 3); // First 3 cards\n          var remainingSources = chat.WebLinks.slice(3); // Remaining items\n\n          this.chatLog.push({\n            type: 'ai',\n            message: this.processMessageForDisplay(chat.Text),\n            executionGraphs: chat.ExecutionGraphs,\n            graphs: chat.Graphs,\n            searchTerms: chat.SearchTerms,\n            sourcesList: sourcesList,\n            displayedSources: displayedSources,\n            remainingSources: remainingSources,\n            time: formatTimeStamps(this.timezone, chat.InsertTimestamp),\n            copied: false,\n            isCollapsedTrue: false,\n          });\n          this.showFeedBackIconsIndex = this.chatLog.length - 1;\n        }\n      });\n      this.showStartAgain = true;\n    }\n    this.scrollToBottom();\n    this.cdr.markForCheck();\n  }\n\n  processMessage(message: string): SafeHtml {\n    if (!message || !(message?.length > 0)) {\n      return '';\n    }\n\n    // console.log('here is my message')\n    // console.log(message);\n\n    message = message.trim();\n\n    const markdownLinkRegex = /\\[([^[]+)]\\(([^)]+)\\)/g;\n    const urlRegex = /(?<!href=\")\\bhttps?:\\/\\/\\S+(?<![.,])/gi;\n\n    if (markdownLinkRegex.test(message)) {\n      const html = message.replace(\n        markdownLinkRegex,\n        '<a href=\"$2\" target=\"_blank\">$1</a>'\n      );\n      //console.log('Sanitized message: ', message);\n      return this.sanitizeHtml(html);\n    }\n\n    if (urlRegex.test(message)) {\n      const html = message.replace(\n        urlRegex,\n        '<a href=\"$&\" target=\"_blank\">$&</a>'\n      );\n      // console.log('Sanitized message: ', message);\n      return this.sanitizeHtml(html);\n    }\n\n    message = message.replace(/(?:\\r\\n|\\r|\\n)/g, '<br>');\n\n    message = message.replace(/\\*\\*(.*?)\\*\\*/g, '<strong>$1</strong>');\n    // Convert Markdown headers to HTML headers\n    message = message.replace(/^(#{1,6})\\s+(.*)$/gm, (match, hashes, text) => {\n      const level = hashes.length;\n      return `<h${level}>${text}</h${level}>`;\n    });\n\n    this.cdr.markForCheck();\n    const sanitizedMessage = this.sanitizeHtml(message);\n    return sanitizedMessage;\n  }\n\n  ngAfterViewChecked() {\n    const feedbackLinks = this.elementRef.nativeElement.querySelectorAll(\n      '.feedback-link'\n    );\n    feedbackLinks.forEach((link: any) => {\n      link.addEventListener(\n        'click',\n        this.onFeedbackClick.bind(this, 'zendesk')\n      );\n    });\n    // if (this.elementRef.nativeElement.querySelector('.feedback-link')) {\n    //   this.elementRef.nativeElement\n    //     .querySelector('.feedback-link')\n    //     .addEventListener('click', this.onFeedbackClick.bind(this, 'zendesk'));\n    // }\n  }\n\n  sanitizeHtml(html: string): SafeHtml {\n    return this.sanitizer.bypassSecurityTrustHtml(html);\n  }\n\n  onFeedbackClick(value: string) {\n    this.feedbackEvent.emit(value);\n  }\n\n  onClose() {\n    this.renderer.removeClass(document.body, this.bodyOverflowClass);\n    this.onCloseEvent.emit();\n  }\n\n  sendMessageWithTile(prompt: string) {\n    this.input = prompt;\n    this.fetchData();\n    this.scrollToBottom();\n  }\n  isChatingWithAi = false;\n  fetchData(msg = null) {\n    this.input = msg || this.input?.trim();\n    this.msg = this.input;\n    if (!this.input || this.loading) {\n      return;\n    }\n\n    this.chatLog.push({\n      type: 'user',\n      message: this.processMessageForDisplay(this.input),\n      time: formatNow(this.timezone),\n      copied: false,\n      isCollapsedTrue: false,\n    });\n\n    try {\n      const textarea = this.myInput.nativeElement;\n      textarea.style.height = 'hidden'; // Reset the height\n      textarea.style.height = `62px`;\n    } catch (error) { }\n    this.cdr.markForCheck();\n\n    this.aiResponse = '';\n    this.isChatingWithAi = true;\n\n    this.makeAskRequest(this.input, this.agents, this.conversationKey);\n  }\n  fetchDataFor(msg, chat) {\n    const inputMsg = msg?.trim();\n    if (!inputMsg || this.loading) {\n      return;\n    }\n    try {\n      chat.relatedListItems = [];\n      this.cdr.detectChanges();\n    } catch (error) { }\n\n    this.scrollToBottom();\n    this.chatLog.push({\n      type: 'user',\n      message: this.processMessageForDisplay(inputMsg),\n      time: formatNow(this.timezone),\n      copied: false,\n      isCollapsedTrue: false,\n    });\n\n    this.cdr.markForCheck();\n\n    this.aiResponse = '';\n    this.isChatingWithAi = true;\n\n    this.makeAskRequest(inputMsg, this.agents, this.conversationKey, msg, chat);\n  }\n  fetchSmallTalk() {\n    this.loading = true;\n    this.cdr.markForCheck();\n\n    const url = `${this.environment.BASE_URL}/bot/small-talk/${this.botId}/${this.userId}`;\n\n    this.http\n      .get<{ smallTalk: string }>(url, {\n        headers: {\n          'x-api-key': this.apiKey,\n          'hive-bot-id': this.botId\n        },\n      })\n      .pipe(\n        catchError((error) => {\n          console.error('Error while fetching small talk:', error);\n\n          return of(null);\n        })\n      )\n      .subscribe((response) => {\n        this.loading = false;\n        this.cdr.markForCheck();\n\n        if (!response) {\n          return;\n        }\n\n        if (response && response.smallTalk) {\n          this.chatLog.push({\n            type: 'ai',\n            message: this.processMessage(response.smallTalk),\n            time: formatNow(this.timezone),\n            isFeedbackMsg: true,\n          });\n          this.showFeedBackIconsIndex = this.chatLog.length - 2;\n          // this.scrollToBottom();\n          this.cdr.markForCheck();\n        }\n      });\n  }\n\n  readAllChunks = (stream: any) => {\n    const reader = stream.getReader();\n    const allSuggestions: string[] = [];\n\n    reader.closed.catch((err: any) => {\n      if (err) {\n        console.error('Error reading stream: ', err);\n      }\n\n      this.isChatingWithAi = false;\n      this.scrollToBottom();\n      return;\n    });\n\n    return new ReadableStream({\n      start: (controller) => {\n        return this.pump(controller, reader, allSuggestions);\n      },\n    });\n  };\n\n  pump(controller: any, reader: any, allSuggestions: string[]) {\n    reader.read().then(({ done, value }: any) => {\n      const lastItem = this.chatLog[this.chatLog.length - 1];\n\n      if (done) {\n        lastItem.message = this.processMessageForDisplay(lastItem.message);\n        this.chatLog.pop();\n        this.chatLog.push(lastItem);\n        if (allSuggestions?.length) {\n          this.chatLog.push({\n            type: 'suggestions',\n            suggestions: allSuggestions,\n          });\n        }\n\n        controller.close();\n        this.isChatingWithAi = false;\n        // this.scrollToBottom();\n        this.cdr.markForCheck();\n        this.showStartAgain = true;\n\n        // setTimeout(() => {\n        //   this.fetchSmallTalk();\n        // },1000)\n        return;\n      }\n\n      let decodedChunk = this.decoder.decode(value, { stream: true });\n      this.aiResponse += decodedChunk;\n      if (lastItem.type === 'ai') {\n        const suggestionsMatch = this.aiResponse.match(/<sug>(.*?)<\\/sug>/g);\n        if (suggestionsMatch) {\n          suggestionsMatch.forEach((match) => {\n            this.aiResponse = this.aiResponse.replace(match, '');\n            allSuggestions.push(match?.replace(/<\\/?sug>/g, ''));\n          });\n        }\n\n        lastItem.message = this.aiResponse;\n        this.cdr.markForCheck();\n      } else {\n        this.isChatingWithAi = false;\n\n        let aiFormattedData: any;\n\n        try {\n          console.log('parsing json ');\n          aiFormattedData = JSON.parse(JSON.parse(this.aiResponse));\n        } catch (e) {\n          try {\n            console.log('parsing json 2');\n            aiFormattedData = JSON.parse(this.aiResponse);\n          } catch (e) { }\n        }\n\n        console.log('parsing json done');\n\n        if (aiFormattedData && aiFormattedData?.section_id?.length > 0) {\n          if (\n            aiFormattedData.section_id == 'company_search' ||\n            aiFormattedData.section_id == 'user_search' ||\n            aiFormattedData.section_id == 'industry_company_search'\n          ) {\n            this.fetchMyConnections().subscribe();\n            this.fetchPendingRequests().subscribe();\n          }\n\n          if (aiFormattedData.section_id == this.myUpcomingSessionAction) {\n            var speakerIds = [];\n            aiFormattedData.content?.forEach((session) => {\n              speakerIds = [...speakerIds, ...session.speakers];\n            });\n\n            if (speakerIds?.length > 0) this.getSpeakersByStaffIds(speakerIds);\n          }\n\n          if (\n            aiFormattedData.section_id == this.addToMyAgendaAction &&\n            aiFormattedData.content?.length > 0\n          ) {\n            this.openPage.next({\n              sectionId: aiFormattedData.section_id,\n              sessionIds: aiFormattedData.content,\n            });\n          }\n\n          if (aiFormattedData.section_id == this.connectOrFollowAction) {\n            let usersLen = aiFormattedData.content?.length;\n            if (usersLen > 1) {\n              this.openPage.next({\n                sectionId: 'open_networking_drawer',\n                search: aiFormattedData.content,\n              });\n            } else if (usersLen == 1) {\n              this.openPage.next({\n                sectionId: aiFormattedData.section_id,\n                connetUserIds: [aiFormattedData.content[0].userId],\n              });\n            }\n          }\n\n          if (aiFormattedData.is_open_page == 'true') {\n            this.openPage.next({\n              sectionId: aiFormattedData.section_id,\n              search: aiFormattedData.content,\n            });\n\n            if (this.isMobileBrowser()) {\n              aiFormattedData.message +=\n                '\\n\\n' + '<a id=\"closeBotNow\">Click Here</a> to see results.';\n            }\n          }\n\n          this.chatLog.push({\n            type: 'ai',\n            message: aiFormattedData.message,\n            action: aiFormattedData,\n            time: formatNow(this.timezone),\n          });\n\n          if (this.isMobileBrowser()) {\n            setTimeout(() => {\n              this.addCloseBotClickEvent();\n            }, 500);\n          }\n\n          this.aiResponse = '';\n        } else {\n          this.chatLog.push({\n            type: 'ai',\n            message: this.aiResponse,\n            time: formatNow(this.timezone),\n          });\n        }\n\n        this.showFeedBackIconsIndex = this.chatLog.length - 1;\n        this.cdr.markForCheck();\n      }\n\n      this.scrollToBottom();\n\n      // Enqueue the next data chunk into our target stream\n      controller.enqueue(value);\n      this.pump(controller, reader, allSuggestions);\n    });\n  }\n\n  submitFeedback(flag: boolean) {\n    this.feedbackDone = true;\n    this.showFeedBackIconsIndex = null;\n    const url = `${this.environment.BASE_URL}/bot/feedback`;\n    fetch(url, {\n      method: 'POST',\n      headers: {\n        'Content-Type': 'application/json',\n        'x-api-key': this.apiKey,\n        'hive-bot-id': this.botId\n      },\n      body: JSON.stringify({ flag, user_id: this.userId, bot_id: this.botId }),\n    }).then(() => {\n      if (flag) {\n        this.chatLog.push({\n          type: 'ai',\n          message:\n            this.thumbsUpMessage ||\n            `Great. May I assist you with anything else?`,\n          time: formatNow(this.timezone),\n          isFeedbackMsg: true,\n        });\n\n        this.scrollToBottom();\n        this.cdr.markForCheck();\n        this.feedbackDone = false;\n        this.showFeedBackIconsIndex = null;\n        return;\n      }\n\n      this.chatLog.push({\n        type: 'ai',\n        message: this.processMessage(\n          this.thumbsDownMessages[this.thumbsDownMsgIndex]\n        ),\n        time: formatNow(this.timezone),\n        isFeedbackMsg: true,\n      });\n      this.thumbsDownMsgIndex =\n        (this.thumbsDownMsgIndex + 1) % this.thumbsDownMessages.length;\n      this.scrollToBottom();\n      this.cdr.markForCheck();\n      this.feedbackDone = false;\n      this.showFeedBackIconsIndex = null;\n    });\n  }\n  handleKeydown(event: KeyboardEvent) {\n    if (event.key === 'Enter' && !event.shiftKey) {\n      // Prevent default behavior (new line)\n      event.preventDefault();\n      // Call your submit function\n      this.handleSubmit(event);\n    }\n  }\n  handleSubmit(event) {\n    this.fetchData();\n    this.scrollToBottom();\n\n  }\n\n  handleUpClick(idx: any) {\n    if (this.feedbackDone) {\n      return;\n    }\n\n    this.submitFeedback(true);\n    this.chatLog[idx].liked = !this.chatLog[idx].liked;\n\n    if (this.chatLog[idx].unliked) {\n      this.chatLog[idx].unliked = !this.chatLog[idx].unliked;\n    }\n\n    this.cdr.markForCheck();\n  }\n\n  handleDownClick(idx: any) {\n    if (this.feedbackDone) return;\n    this.submitFeedback(false);\n    this.chatLog[idx].unliked = !this.chatLog[idx].unliked;\n    if (this.chatLog[idx].liked)\n      this.chatLog[idx].liked = !this.chatLog[idx].liked;\n  }\n  // handleCopyClick(index: any) {\n  //   // Copy the message to the clipboard\n  //   const contentToCopy = this.chatLog[index].message;\n  //   console.log('contentToCopy');\n  //   console.log(contentToCopy);\n  //   navigator.clipboard.writeText(contentToCopy).then(() => {\n  //     // Indicate that the message was copied\n  //     this.chatLog[index].copied = true;\n  //     this.cdr.detectChanges();\n  //     // Reset the copied state after a delay\n  //     setTimeout(() => {\n  //       this.chatLog[index].copied = false;\n  //       this.cdr.detectChanges();\n  //     }, 2000); // Reset after 2 seconds\n  //   });\n  // }\n  copyText(id, index) {\n    // Get the text element\n    var textElement = document.getElementById(id);\n\n    // Create a temporary textarea element to copy the text\n    var tempTextArea = document.createElement('textarea');\n    tempTextArea.value = textElement.innerText;\n\n    // Append the textarea to the body (necessary for the execCommand to work)\n    document.body.appendChild(tempTextArea);\n\n    // Select the text inside the textarea\n    tempTextArea.select();\n\n    // Copy the text to the clipboard\n    document.execCommand('copy');\n\n    // Remove the temporary textarea\n    document.body.removeChild(tempTextArea);\n\n    // Optionally, you can alert the user or change the button text to indicate the copy was successful\n    // alert('Text copied to clipboard!');\n\n    this.chatLog[index].copied = true;\n    this.cdr.detectChanges();\n    // Reset the copied state after a delay\n    setTimeout(() => {\n      this.chatLog[index].copied = false;\n      this.cdr.detectChanges();\n    }, 2000); // Reset after 2 seconds\n  }\n  handleCopyClick(index: any) {\n    // Copy the message to the clipboard\n    const contentToCopy = this.chatLog[index].message;\n    const resutlt = this.copyText('messageText_' + index, index);\n  }\n\n  sanitizeHTML(html: string): string {\n    const doc = new DOMParser().parseFromString(html, 'text/html');\n\n    // Create a new document fragment to hold the simplified content\n    const fragment = document.createDocumentFragment();\n\n    // Append the children of the body of the parsed document to the fragment\n    Array.from(doc.body.childNodes).forEach((node) => {\n      fragment.appendChild(node.cloneNode(true));\n    });\n\n    // Create a new div element to hold the simplified HTML\n    const simplifiedDiv = document.createElement('div');\n    simplifiedDiv.appendChild(fragment);\n\n    // Remove complex tags or attributes as needed\n    // Example: remove scripts\n    simplifiedDiv\n      .querySelectorAll('script')\n      .forEach((script) => script.remove());\n\n    // Return the simplified HTML as a string\n    return simplifiedDiv.innerHTML;\n  }\n\n  currentMessageForEditor: any = '';\n  currentIndexForEditor: any = -1;\n  handleEditorClick(index: any) {\n    if (this.currentIndexForEditor == -1) {\n      this.currentIndexForEditor = index;\n      this.currentMessageForEditor = this.sanitizeHTML(\n        this.chatLog[index].message\n      );\n      this.currentMessageForEditor = this.currentMessageForEditor.replace(\n        'SafeValue must use [property]=binding:',\n        ''\n      );\n\n      this.cdr.detectChanges();\n    } else {\n      if (this.currentIndexForEditor == index) {\n        this.currentMessageForEditor += this.sanitizeHTML(\n          this.chatLog[index].message\n        );\n        this.currentMessageForEditor = this.currentMessageForEditor.replace(\n          'SafeValue must use [property]=binding:',\n          ''\n        );\n        this.cdr.detectChanges();\n      } else {\n        this.currentIndexForEditor = index;\n        this.currentMessageForEditor = this.sanitizeHTML(\n          this.chatLog[index].message\n        );\n        this.currentMessageForEditor = this.currentMessageForEditor.replace(\n          'SafeValue must use [property]=binding:',\n          ''\n        );\n        this.cdr.detectChanges();\n      }\n    }\n    this.chatLog[index].isEditor = true;\n    this.cdr.detectChanges();\n    // Reset the copied state after a delay\n    setTimeout(() => {\n      this.chatLog[index].isEditor = false;\n      this.cdr.detectChanges();\n    }, 2000); // Reset after 2 seconds\n    this.editorsDrawer.open();\n    const button = document.getElementById('botcloseplaygroundbutton');\n    if (button) {\n      button.style.display = 'none';\n    }\n    this.cdr.detectChanges();\n  }\n  scrollToBottom() {\n    let counter = 0;\n    const interval = setInterval(() => {\n      this.chatMain.nativeElement.scrollTop = this.chatMain.nativeElement.scrollHeight;\n      if (counter++ > 5) clearInterval(interval);\n    }, 5);\n  }\n\n  handleAction(action: any) {\n    console.info('incoming action from the chatbot AI');\n    console.info(action);\n\n    if (action?.content) {\n    }\n  }\n\n  ngAfterViewInit() {\n    // Check if the drawer is initially open and apply overflow hidden to body if so\n    if (this.drawer.opened) {\n      this.setBodyOverflow();\n    }\n\n    // Listen to changes in the drawer being opened or closed\n    this.drawer.openedChange.subscribe((opened: boolean) => {\n      if (opened) {\n        this.setBodyOverflow();\n      } else {\n        this.removeBodyOverflow();\n      }\n    });\n\n    this.drawer.openedChange.subscribe((opened) => {\n      if (opened) {\n        setTimeout(() => {\n          if (this.myTextarea && this.myTextarea.nativeElement) {\n            this.myTextarea.nativeElement.focus(); // Focus on the textarea\n          }\n        });\n      }\n    });\n  }\n\n  private setBodyOverflow() {\n    this.renderer.addClass(document.body, this.bodyOverflowClass);\n  }\n\n  private removeBodyOverflow() {\n    this.renderer.removeClass(document.body, this.bodyOverflowClass);\n  }\n\n  getSpeakersByStaffIds(ids) {\n    const url = `${this.environment.USERS_API}/events/${this.eventId}/users/get-by-staff-ids`;\n    fetch(url, {\n      method: 'POST',\n      headers: {\n        'Content-Type': 'application/json',\n        Authorization: 'Bearer ' + 'your_token_here',\n      },\n      body: JSON.stringify(ids),\n    })\n      .then((response) => {\n        if (response.ok) {\n          return response.json(); // Parse the JSON body of the response\n        } else {\n          throw new Error('Network response was not ok.');\n        }\n      })\n      .then((data) => {\n        if (data?.length > 0) {\n          data.forEach((speaker) => {\n            this.speakers[speaker.id] = speaker;\n          });\n\n          this.cdr.markForCheck();\n        }\n      })\n      .catch((err) => {\n        console.error('Error fetching data:', err);\n        this.loading = false;\n      });\n  }\n\n  performSessionAction(sessionId, action) {\n    this.sessionActions.next({\n      sessionId,\n      action,\n    });\n  }\n\n  addCloseBotClickEvent() {\n    const element = this.elementRef.nativeElement.querySelector('#closeBotNow');\n    if (element) {\n      this.renderer.listen(element, 'click', () => {\n        this.closeBot.next();\n      });\n    }\n  }\n\n  isMobileBrowser() {\n    return /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(\n      navigator.userAgent\n    );\n  }\n\n  connectToUser(userId) {\n    this.connectWithUser.emit({\n      connect: !this.canDisconnect(userId),\n      userId,\n    });\n\n    setTimeout(() => {\n      this.fetchMyConnections().subscribe((res) => {\n        this.cdr.markForCheck();\n      });\n      this.fetchPendingRequests().subscribe((res) => {\n        this.cdr.markForCheck();\n      });\n    }, 500);\n  }\n\n  scheduleMeetingWithUser(user) {\n    this.scheduleMeeting.emit(user);\n  }\n\n  canConnect(userId) {\n    return !(\n      this.canDisconnect(userId) ||\n      this.pendingRequests.find((a) => a == userId)\n    );\n  }\n\n  canDisconnect(userId) {\n    return this.myConnections.find((conn) => conn.userId == userId);\n  }\n\n  fetchPendingRequests() {\n    const headers = new HttpHeaders({\n      'Content-Type': 'application/json',\n      apiKey: this.autogenKey,\n    });\n    return this.http\n      .get(\n        `${this.environment.USERS_API}/events/${this.eventId}/connection-requests/autogen/pending-sent-requests?userId=${this.userId}`,\n        { headers }\n      )\n      .pipe(\n        switchMap((res: any) => {\n          this.pendingRequests = res;\n          this.cdr.markForCheck();\n          return of(res);\n        }),\n        catchError((error: any) => {\n          console.error('Error fetching pending requests: ', error);\n          return of(null);\n        })\n      );\n  }\n\n  fetchMyConnections() {\n    const headers = new HttpHeaders({\n      'Content-Type': 'application/json',\n      apiKey: this.autogenKey,\n    });\n    return this.http\n      .get(\n        `${this.environment.USERS_API}/events/${this.eventId}/users-connections/autogen?userId=${this.userId}`,\n        { headers }\n      )\n      .pipe(\n        switchMap((res: any) => {\n          this.myConnections = res;\n          this.cdr.markForCheck();\n          return of(res);\n        }),\n        catchError((error: any) => {\n          console.error('Error fetching pending requests: ', error);\n          return of(null);\n        })\n      );\n  }\n\n  isDropdownOpen: boolean = false;\n  agents: any;\n  selectedAgents = [];\n  allSelected = false;\n  // Toggle the dropdown visibility\n  toggleDropdown() {\n    this.fetchAgents();\n    this.isDropdownOpen = !this.isDropdownOpen;\n    this.cdr.detectChanges();\n  }\n\n  onSelectAll(event: Event): void {\n    this.agents?.forEach((agent) => (agent.selected = false));\n    this.cdr.detectChanges();\n  }\n\n  onAgentChange(agent: any): void {\n    //agent.selected = !agent.selected;\n    //console.log(agent);\n    let agentFound = this.agents.filter((p) => p.id == agent.id);\n    if (agentFound && agentFound.length > 0) {\n      agentFound[0].selected = !agentFound[0].selected;\n      this.cdr.detectChanges();\n    }\n    this.cdr.detectChanges();\n  }\n\n  areAllSelected(): boolean {\n    return this.agents?.every((agent) => !agent.selected);\n  }\n\n  getDropdownHeaderText(): string {\n    const selectedAgents = this.agents?.filter((agent) => agent.selected);\n    if (selectedAgents && selectedAgents?.length === 0) {\n      return 'All Agents';\n    } else {\n      return selectedAgents?.length > 1\n        ? `${selectedAgents?.length} Agents Selected`\n        : `${selectedAgents?.length} Agent Selected`;\n    }\n  }\n  fetchAgents_http() {\n    this.loading = true;\n    const url = `${this.environment.AGENTS_API}/CoPilot/${this.botId}/active-agents`;\n    const headers = new HttpHeaders({\n      'Content-Type': 'application/json',\n    });\n\n    return this.http.post(url, {}, { headers }).pipe(\n      switchMap((res: any) => {\n        if (res) {\n          this.agents = res.map((agent) => ({\n            ...agent,\n            selected: false,\n          }));\n        }\n        this.cdr.markForCheck();\n\n        return of(res);\n      }),\n      catchError((error) => {\n        console.error('Error fetching chatbot config: ', error);\n\n        return of(null);\n      })\n    );\n  }\n  isDocInEditMode = false;\n  documentContent: any;\n\n  conversationId: any;\n  isContentLoaded = false;\n\n  fetchContent_http() {\n    this.isDocInEditMode = false;\n    this.isContentLoaded = false;\n    console.log('API call function');\n    this.loading = true;\n    const conversation_id = this.conversationService.getKey(this.botId);\n    this.conversationId = conversation_id;\n    const url = `${this.environment.AGENTS_API}/ConversationDocuments?conversationId=${conversation_id}&botId=${this.botId}`;\n    const headers = new HttpHeaders({\n      'Content-Type': 'application/json',\n      apiKey: 'WIz/qAm+EEmfOkFaUA/weA==',\n    });\n\n    return this.http.get(url, { headers }).pipe(\n      switchMap((res: any) => {\n        if (res) {\n          this.isDocInEditMode = true;\n          this.documentContent = res;\n          console.log('Get API callled success');\n          this.isContentLoaded = true;\n          console.log(res);\n        }\n        this.cdr.markForCheck();\n\n        return of(res);\n      }),\n      catchError((error) => {\n        console.error('Error fetching chatbot config DJ: ', error);\n        this.isDocInEditMode = false;\n        this.isContentLoaded = true;\n\n        if (error?.status == 404) {\n          console.log('dash');\n          this.isDocInEditMode = false;\n          this.isContentLoaded = true;\n        }\n        return of(null);\n      })\n    );\n  }\n\n  fetchAgents() {\n    this.fetchAgents_http().subscribe();\n  }\n\n  fetchEditorContent() {\n    this.fetchContent_http().subscribe();\n  }\n\n  // events/${eventId}/users-connections\n  processMessageForDisplay(markdown: string): SafeHtml {\n    var html = this.prepareHtml(markdown);\n\n    //  console.log('After line breaks conversion:', html);\n\n    // Optional: Sanitize the HTML to prevent XSS\n    const sanitizedHtml = this.sanitizeHtml(html);\n\n    // console.log('Sanitized HTML:', sanitizedHtml);\n\n    return sanitizedHtml;\n  }\n\n  prepareHtml(markdown: string): string {\n    if (!markdown || !(markdown.length > 0)) {\n      console.error('Input Markdown is null or empty');\n      return '';\n    }\n\n    // Convert Markdown headers (### or ##) to <strong> for bold headings\n    let html = markdown.replace(/^(#{1,6})\\s+(.*)$/gm, (match, hashes, text) => {\n      const level = hashes.length;\n      if (level === 3) {\n        return `<h3><strong>${text}</strong></h3>`;\n      } else if (level === 4) {\n        return `<h4><strong>${text}</strong></h4>`;\n      }\n      return `<strong>${text}</strong>`;\n    });\n\n    // Convert Markdown code blocks with language to preformatted HTML\n    html = html.replace(/```(\\w+)?\\n([\\s\\S]*?)```/g, (match, lang, code) => {\n      const escapedCode = this.escapeHtml(code);\n      const language = lang || 'plaintext';\n\n      // Create a copy button for the code block\n      return `\n      <div class=\"code-container\">\n        <button id=\"copy-button\" class=\"copy-button\" (click)=\"copyToClipboard('\\`${escapedCode}\\`')\">Copy</button>\n        <pre class=\"code_block diff\"><code class=\"language-${language}\">${escapedCode}</code></pre>\n      </div>`;\n    });\n\n    // Convert inline code (wrapped in `backticks`) to inline <code> tags\n    html = html.replace(/`([^`]+)`/g, '<code>$1</code>');\n\n    // Convert Markdown bold to HTML <strong>\n    html = html.replace(/\\*\\*(.*?)\\*\\*/g, '<strong>$1</strong>');\n\n    // Convert numbered lists\n    html = html.replace(/^\\d+\\.\\s+(.*)$/gm, '<li>$1</li>');\n\n    // Convert bullet point lists\n    html = html.replace(/^\\-\\s+(.*)$/gm, '<li>$1</li>');\n\n    // Convert Markdown links to HTML links\n    html = html.replace(/\\[([^\\]]+)]\\(([^)]+)\\)/g, '<a href=\"$2\" target=\"_blank\">$1</a>');\n\n    // Convert new lines to <br> tags for paragraphs\n    html = html.replace(/(?:\\r\\n|\\r|\\n)/g, '<br>');\n\n    return html;\n  }\n\n  // Helper function to escape HTML characters for code blocks\n  escapeHtml(code: string): string {\n    return code\n      .replace(/&/g, '&amp;')\n      .replace(/</g, '&lt;')\n      .replace(/>/g, '&gt;')\n      .replace(/\"/g, '&quot;')\n      .replace(/'/g, '&#039;');\n  }\n\n  // Function to copy text to clipboard\n  public copyToClipboard(text: string) {\n    navigator.clipboard.writeText(text).then(() => {\n      alert('Code copied to clipboard!');\n    }, (err) => {\n      console.error('Could not copy text: ', err);\n    });\n  }\n\n\n\n\n\n\n  isCollapsed = false;\n  isCollapsedForGraph = false;\n  isCollapsedForFGraph = false;\n  toggleCollapse() {\n    this.isCollapsed = !this.isCollapsed;\n    this.cdr.detectChanges();\n  }\n\n  toggleCollapseGraph() {\n    this.isCollapsedForGraph = !this.isCollapsedForGraph;\n    this.cdr.detectChanges();\n  }\n  toggleCollapseFGraph() {\n    this.isCollapsedForFGraph = !this.isCollapsedForFGraph;\n    this.cdr.detectChanges();\n  }\n  //   [\n  //   {\n  //     \"title\": \"AI News January 2024: In-Depth and Concise - The AI Track\",\n  //     \"desc\": \"Each month, we compile significant news, trends, and happenings in AI, providing detailed summaries with key points in bullet form for concise yet complete understanding.\",\n  //     \"link\": \"https://theaitrack.com/ai-news-january-2024/\"\n  //   },\n  //   {\n  //     \"title\": \"Top AI News, January 2024 - Everypixel Journal\",\n  //     \"desc\": \"In this monthly roundup, we spotlight the top AI news stories from January, including the OpenAI vs. The New York Times Lawsuit.\",\n  //     \"link\": \"https://journal.everypixel.com/top-ai-news-january-2024\"\n  //   },\n  //   {\n  //     \"title\": \"AI News July 2024: In-Depth and Concise - The AI Track\",\n  //     \"desc\": \"This page features AI News for July 2024, highlighting significant events such as Canva acquiring Leonardo AI.\",\n  //     \"link\": \"https://theaitrack.com/ai-news-july-2024-in-depth-and-concise/\"\n  //   },\n  //   {\n  //     \"title\": \"January news roundup: What's new in the world of AI? - Pluralsight\",\n  //     \"desc\": \"OpenAI’s new GPT store, business-ready ChatGPT plans, and a predicted rise in AI-powered cybercrime.\",\n  //     \"link\": \"https://www.pluralsight.com/resources/blog/data/ai-this-month-january-2024\"\n  //   },\n  //   {\n  //     \"title\": \"AI News August 2024: In-Depth and Concise - The AI Track\",\n  //     \"desc\": \"This page features AI News for August 2024, with highlights such as Nvidia delaying the “Blackwell” B200 AI chips delivery.\",\n  //     \"link\": \"https://theaitrack.com/ai-news-august-2024-in-depth-and-concise-duplicate/\"\n  //   }\n  // ]\n  dateTime = { now: new Date().toISOString() };\n  // Extracts the domain from a URL\n  getDomainName(url: string): string {\n    try {\n      const { hostname } = new URL(url);\n      return hostname.replace(/^www\\./, ''); // Remove 'www.' if present\n    } catch {\n      return 'unknown';\n    }\n  }\n\n  // Generates the favicon URL\n  getFaviconUrl(url: string): string {\n    const domain = this.getDomainName(url);\n    return `https://www.google.com/s2/favicons?sz=128&domain=${domain}`;\n  }\n  currentSourcesList: any = [];\n  onCardClick(sources): void {\n    this.currentSourcesList = sources;\n    this.cdr.detectChanges();\n    this.sourcesDrawer.open();\n    const button = document.getElementById('botcloseplaygroundbutton');\n    if (button) {\n      button.style.display = 'none';\n    }\n  }\n\n  isShowEditorButton = true;\n\n  openOuterEditor() {\n    this.fetchEditorContent();\n    this.editorsDrawer.open();\n    this.isDrawerOpen = true;\n    this.isShowEditorButton = false;\n    this.cdr.detectChanges();\n\n    const button = document.getElementById('botcloseplaygroundbutton');\n    if (button) {\n      button.style.display = 'none';\n    }\n  }\n\n  onCloseEditor() {\n    this.editorsDrawer.close();\n    this.isDrawerOpen = false;\n    this.isShowEditorButton = true;\n    this.cdr.detectChanges(); // Trigger change detection if needed\n    this.onDrawerClosed();\n  }\n\n  onCloseSource() {\n    this.sourcesDrawer.close();\n    this.isDrawerOpen = false;\n    this.cdr.detectChanges(); // Trigger change detection if needed\n    this.onDrawerClosed();\n  }\n  onDrawerClosed() {\n    setTimeout(() => {\n      this.isDrawerOpen = true;\n      this.cdr.detectChanges(); // Trigger change detection if needed\n      // Use ngClass to dynamically apply the class\n      const button = document.getElementById('botcloseplaygroundbutton');\n      if (button) {\n        button.style.display = 'block';\n      }\n    }, 800);\n  }\n  isDrawerOpen = true;\n\n  toggleDrawer(todo) {\n    this.isDrawerOpen = todo;\n    this.cdr.detectChanges();\n    this.updateButtonVisibility();\n  }\n  updateButtonVisibility() {\n    const button = document.getElementById('botcloseplaygroundbutton');\n    if (button) {\n      button.style.display = this.isDrawerOpen ? 'block' : 'none';\n    }\n  }\n  openLinkInNewTab(link: string): void {\n    window.open(link, '_blank');\n  }\n  adjustTextareaHeight(event: any): void {\n    try {\n      if (event.key === 'Enter' && !event.shiftKey) {\n        // Prevents a new line from being added\n        event.preventDefault();\n      }\n    } catch (error) {\n\n    }\n    const textarea = event.target as HTMLTextAreaElement;\n    textarea.style.height = 'auto'; // Reset the height\n    textarea.style.height = `${textarea.scrollHeight}px`; // Adjust height to match content\n    // Ensure the height doesn't exceed the max-height set in CSS\n    if (textarea.scrollHeight > 150) {\n      textarea.style.height = `150px`; // Adjust height to match content\n      textarea.style.overflowY = 'auto'; // Enable scrolling if content exceeds 400px\n    } else {\n      textarea.style.overflowY = 'hidden'; // Hide scrollbar if content is within limits\n    }\n  }\n\n  toggleWorkflows(value = null) {\n\n    if (!this.checkForCop29BotId()) {\n      this.botService.getWorkflowsByOrgId(this.orgId).subscribe((res) => {\n        this.orgWorkflows = res;\n        this.isWorkflowOpen = value == null ? !this.isWorkflowOpen : value;\n\n        if (!this.isWorkflowOpen) {\n          this.selectedWorkflow = null;\n          this.openWorkflowInput = false;\n        }\n\n        this.cdr.detectChanges();\n      });\n    }\n\n  }\n\n  initializeForm() {\n    // Create form controls dynamically based on selectedWorkflow.Trigger.InputSchema\n    const formControls = {};\n    if (this.selectedWorkflow?.Trigger?.InputSchema) {\n      this.selectedWorkflow.Trigger.InputSchema.forEach((input) => {\n        formControls[input.InputId] = [\n          input.Value || '',\n          input.Required ? Validators.required : null,\n        ];\n      });\n    }\n\n    // Initialize the form\n    this.workflowForm = this.fb.group(formControls);\n  }\n\n  onWorkflowSelected(workflow) {\n    this.selectedWorkflow = workflow;\n    this.initializeForm();\n    this.isWorkflowOpen = false;\n    this.openWorkflowInput = true;\n  }\n\n  onWorkflowSubmit() {\n    const container = document.getElementById('allChats');\n    if (this.workflowForm.valid) {\n      console.log(this.workflowForm.value);\n\n      var input = this.prepareHtml(\n        this.generateMarkdown(\n          this.selectedWorkflow.Name,\n          this.workflowForm.value\n        )\n      );\n\n      // update last two chatLog entries, set showWorkflowExecutionLoader = false\n      try {\n        this.chatLog[this.chatLog.length - 1][\n          'showWorkflowExecutionLoader'\n        ] = false;\n        this.chatLog[this.chatLog.length - 2][\n          'showWorkflowExecutionLoader'\n        ] = false;\n      } catch (error) { }\n\n      this.chatLog.push({\n        type: 'user',\n        message: input,\n        time: formatNow(this.timezone),\n        copied: false,\n        isCollapsedTrue: false,\n        showWorkflowExecutionLoader: true,\n      });\n\n      console.log(input);\n\n      this.currentWorkflowActionProgress = 0;\n      this.currentWorkflowAction =\n        'Executing ' + this.selectedWorkflow.Actions[0].Name;\n      this.isChatingWithAi = true;\n      this.executingWorkflow = true;\n      this.workflowExecutionDetails = {\n        Actions: this.selectedWorkflow.Actions,\n        Inputs: this.workflowForm.value,\n        workflowInputs: this.workflowForm.value,\n        WorkflowName: this.selectedWorkflow.Name,\n      };\n      this.currentWorkflowExecutionDetails = this.workflowExecutionDetails;\n      this.scrollToBottom();\n\n      this.cdr.detectChanges();\n\n      // execute the ask endpoint with workflow input\n      this.makeAskRequest(\n        input,\n        this.agents,\n        this.conversationKey,\n        '',\n        null,\n        this.selectedWorkflow['_id'],\n        this.workflowForm.value\n      );\n    }\n  }\n\n  makeAskRequest(\n    inputMsg: string,\n    agents: any[],\n    conversationId: string,\n    msg?: any,\n    chat?: any,\n    workflowId?: string,\n    workflow_inputs?: any\n  ): void {\n    var url = `${this.environment.BASE_URL}/ai/ask`;\n\n    var body = {\n      user_question: inputMsg,\n      user_id: this.userId,\n      bot_id: this.botId,\n      message_id: this.conversationService.generateKey(),\n      agents: agents.filter((p) => p.selected).map((p) => p.id),\n      conversation_id: conversationId,\n    };\n\n    if (workflowId) {\n      body['workflow_id'] = workflowId;\n      body['workflow_inputs'] = workflow_inputs;\n    }\n\n    fetch(url, {\n      method: 'POST',\n      headers: {\n        'Content-Type': 'application/json',\n        Authorization: 'Bearer ' + this.s27Token,\n        'x-api-key': this.apiKey,\n        'hive-bot-id': this.botId\n      },\n      body: JSON.stringify(body),\n    })\n      .then((response) => {\n        if (response.status === 401 || response.status === 403) {\n          this.is401 = true;\n          this.refreshToken.emit();\n\n          // If `msg` and `chat` exist, handle them\n          if (msg && chat) {\n            this.msg = msg;\n            this.chat = chat;\n            this.isFetchDataFor = true;\n          }\n        } else {\n          this.is401 = false;\n        }\n        return response.json();\n      })\n      .then((data) => {\n        console.log(data);\n        // Additional response handling if needed\n      })\n      .catch((err) => {\n        console.error('Error: ', err);\n        this.isChatingWithAi = false;\n      });\n\n    this.input = '';\n    this.selectedWorkflow = null;\n    this.openWorkflowInput = false;\n    this.isWorkflowOpen = false;\n    this.scrollToBottom();\n    this.cdr.markForCheck();\n  }\n\n  generateMarkdown(title, obj) {\n    // Initialize markdown with the title\n    let markdown = `## ${title}\\n`;\n\n    // Loop through the object and append the field names and values\n    for (const [key, value] of Object.entries(obj)) {\n      var key_label =\n        this.selectedWorkflow.Trigger.InputSchema.find(\n          (input) => input.InputId === key\n        )?.Label || key;\n      markdown += `- **${key_label}**: ${value}\\n`;\n    }\n\n    return markdown;\n  }\n\n  showWorkflowHistoryDetails(workflow_id) {\n    if (!workflow_id) {\n      this.workflowExecutionDetails = this.currentWorkflowExecutionDetails;\n      this.showWorkflowExecutionDetails = true;\n      this.cdr.detectChanges();\n      return;\n    }\n\n    this.botService.getWorkflowExecutionById(workflow_id).subscribe((res) => {\n      if (res && res.Actions && Array.isArray(res.Actions)) {\n        res.Actions = res.Actions.map((action) => {\n          if (action.InsertTimeStamp) {\n            action.InsertTimeStamp = formatTimeStamps(\n              this.timezone,\n              action.InsertTimeStamp\n            );\n          }\n          return action;\n        });\n      }\n\n      res.InsertTimeStamp = formatTimeStamps(\n        this.timezone,\n        res.InsertTimeStamp\n      );\n      this.workflowExecutionDetails = res;\n      this.showWorkflowExecutionDetails = true;\n      this.cdr.detectChanges();\n    });\n  }\n\n  closeModal() {\n    this.showWorkflowExecutionDetails = false;\n  }\n\n  objectToArray(obj: any): any[] {\n    return Object.keys(obj).map((key) => ({ key, value: obj[key] }));\n  }\n\n  startNewConversation() {\n    this.conversationKey = this.conversationService.getKey(this.botId, true);\n    this.chatLog = [this.chatLog[0]];\n    this.isChatingWithAi = false;\n    setTimeout(() => {\n      this.initializeSocket();\n    }, 200);\n    this.scrollToBottom();\n    this.cdr.detectChanges();\n  }\n\n  initializeSpeechRecognizer(token: string) {\n    this.speechConfig = SpeechSDK.SpeechConfig.fromAuthorizationToken(\n      token,\n      this.region\n    );\n    const audioConfig = SpeechSDK.AudioConfig.fromDefaultMicrophoneInput();\n    this.recognizer = new SpeechSDK.SpeechRecognizer(\n      this.speechConfig,\n      audioConfig\n    );\n\n    this.recognizer.recognizing = (s, e) => {\n      if (e.result.reason === SpeechSDK.ResultReason.RecognizingSpeech) {\n        this.input = e.result.text;\n        console.log(`Recognizing: ${e.result.text}`);\n        this.cdr.markForCheck();\n      }\n    };\n\n    this.recognizer.recognized = (s, e) => {\n      if (e.result.reason === SpeechSDK.ResultReason.RecognizedSpeech) {\n        this.input = e.result.text;\n        console.log(`Recognized: ${e.result.text}`);\n        this.toggleRecording();\n        this.cdr.markForCheck();\n      }\n    };\n\n    this.recognizer.canceled = (s, e) => {\n      console.error('Canceled: ', e.errorDetails);\n    };\n\n    this.recognizer.sessionStopped = (s, e) => {\n      console.log('Session stopped.');\n      this.recognizer.stopContinuousRecognitionAsync();\n      this.fetchData();\n    };\n  }\n\n  toggleRecording() {\n    this.isRecording = !this.isRecording;\n\n    if (this.isRecording) {\n      this.startRecognition();\n    } else {\n      this.stopRecognition();\n    }\n  }\n\n  startRecognition() {\n    this.recognizer.startContinuousRecognitionAsync();\n  }\n\n  stopRecognition() {\n    this.recognizer.stopContinuousRecognitionAsync();\n  }\n\n  checkForCop29BotId() {\n    return this.botId == '66fa3f276c5d71e2717bfea8';\n  }\n}\n"]}