@hivegpt/hiveai-angular 0.0.316 → 0.0.318

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 +2666 -2663
  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 +49 -43
  13. package/esm2015/lib/components/chat-drawer/chat-drawer.component.js +1637 -1639
  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 +2139 -2136
  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,1639 +1,1637 @@
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
- import * as marked from 'marked'; // Import marked
15
- export class ChatDrawerComponent {
16
- constructor(fb, botService, cdr, http, sanitizer, elementRef, renderer, socketService, conversationService // private platform: Platform
17
- ) {
18
- this.fb = fb;
19
- this.botService = botService;
20
- this.cdr = cdr;
21
- this.http = http;
22
- this.sanitizer = sanitizer;
23
- this.elementRef = elementRef;
24
- this.renderer = renderer;
25
- this.socketService = socketService;
26
- this.conversationService = conversationService;
27
- this.bodyOverflowClass = 'body-overflow-hidden';
28
- this.isCollapsedTrue = false;
29
- this.copilotName = 'HiveXGPT';
30
- this.feedbackEvent = new EventEmitter();
31
- this.onCloseEvent = new EventEmitter();
32
- this.openPage = new EventEmitter();
33
- this.sessionActions = new EventEmitter();
34
- this.closeBot = new EventEmitter();
35
- this.connectWithUser = new EventEmitter();
36
- this.scheduleMeeting = new EventEmitter();
37
- this.refreshToken = new EventEmitter();
38
- this.autogenKey = 'Autogen_eDJTtEU-NB0RtIpzq1w';
39
- this.addToMyAgendaAction = 'add_to_my_agenda';
40
- this.myUpcomingSessionAction = 'my_upcomming_session';
41
- this.connectOrFollowAction = 'connect_or_follow';
42
- this.aiResponse = '';
43
- this.chatLog = [];
44
- this.decoder = new TextDecoder();
45
- this.feedbackDone = false;
46
- this.greetingMsg = '';
47
- this.hasBackdropValue = false;
48
- this.input = '';
49
- this.listenerAdded = false;
50
- this.loading = false;
51
- this.mode = 'over';
52
- this.quickPrompts = [];
53
- this.thumbsDownMsgIndex = 0;
54
- this.userName = '';
55
- this.showStartAgain = false;
56
- this.isIOSDevice = false;
57
- this.showFeedBackIconsIndex = null;
58
- this.temperature = 1;
59
- this.speakers = [];
60
- this.currentWorkflowActionProgress = 0;
61
- this.currentWorkflowAction = '';
62
- this.recognizedText = '';
63
- this.authorizationToken = '';
64
- this.region = 'westeurope'; // Set your Azure region here
65
- this.isChatingWithAi = false;
66
- this.readAllChunks = (stream) => {
67
- const reader = stream.getReader();
68
- const allSuggestions = [];
69
- reader.closed.catch((err) => {
70
- if (err) {
71
- console.error('Error reading stream: ', err);
72
- }
73
- this.isChatingWithAi = false;
74
- this.scrollToBottom();
75
- return;
76
- });
77
- return new ReadableStream({
78
- start: (controller) => {
79
- return this.pump(controller, reader, allSuggestions);
80
- },
81
- });
82
- };
83
- this.currentMessageForEditor = '';
84
- this.currentIndexForEditor = -1;
85
- this.isDropdownOpen = false;
86
- this.selectedAgents = [];
87
- this.allSelected = false;
88
- this.isDocInEditMode = false;
89
- this.isContentLoaded = false;
90
- this.isCollapsed = false;
91
- this.isCollapsedForGraph = false;
92
- this.isCollapsedForFGraph = false;
93
- // [
94
- // {
95
- // "title": "AI News January 2024: In-Depth and Concise - The AI Track",
96
- // "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.",
97
- // "link": "https://theaitrack.com/ai-news-january-2024/"
98
- // },
99
- // {
100
- // "title": "Top AI News, January 2024 - Everypixel Journal",
101
- // "desc": "In this monthly roundup, we spotlight the top AI news stories from January, including the OpenAI vs. The New York Times Lawsuit.",
102
- // "link": "https://journal.everypixel.com/top-ai-news-january-2024"
103
- // },
104
- // {
105
- // "title": "AI News July 2024: In-Depth and Concise - The AI Track",
106
- // "desc": "This page features AI News for July 2024, highlighting significant events such as Canva acquiring Leonardo AI.",
107
- // "link": "https://theaitrack.com/ai-news-july-2024-in-depth-and-concise/"
108
- // },
109
- // {
110
- // "title": "January news roundup: What's new in the world of AI? - Pluralsight",
111
- // "desc": "OpenAI’s new GPT store, business-ready ChatGPT plans, and a predicted rise in AI-powered cybercrime.",
112
- // "link": "https://www.pluralsight.com/resources/blog/data/ai-this-month-january-2024"
113
- // },
114
- // {
115
- // "title": "AI News August 2024: In-Depth and Concise - The AI Track",
116
- // "desc": "This page features AI News for August 2024, with highlights such as Nvidia delaying the “Blackwell” B200 AI chips delivery.",
117
- // "link": "https://theaitrack.com/ai-news-august-2024-in-depth-and-concise-duplicate/"
118
- // }
119
- // ]
120
- this.dateTime = { now: new Date().toISOString() };
121
- this.currentSourcesList = [];
122
- this.isShowEditorButton = true;
123
- this.isDrawerOpen = true;
124
- this.chatMain = new ElementRef(null);
125
- // if (this.platform.IOS) {
126
- // this.isIOSDevice = true;
127
- // }
128
- }
129
- ngOnChanges(changes) {
130
- if (changes.s27Token) {
131
- if (changes.s27Token.currentValue != changes.s27Token.previousValue) {
132
- this.s27Token = changes.s27Token.currentValue;
133
- console.log('isFetchDataFor: ', this.isFetchDataFor);
134
- console.log('msg: ', this.msg);
135
- console.log('chat: ', this.chat);
136
- if (this.is401) {
137
- if (this.isFetchDataFor) {
138
- this.fetchDataFor(this.msg, this.chat);
139
- }
140
- else {
141
- this.fetchData(this.msg);
142
- }
143
- }
144
- }
145
- }
146
- if (changes.orgId) {
147
- if (changes.orgId.currentValue != changes.orgId.previousValue &&
148
- changes.orgId.currentValue) {
149
- this.initializeSocket();
150
- }
151
- }
152
- }
153
- ngOnInit() {
154
- this.environment = this.isDev ? dev_environment : prod_environment;
155
- // this.fetchMyConnections().subscribe();
156
- // this.fetchPendingRequests().subscribe();
157
- this.changeTemperature(this.temperature);
158
- this.fetchBotConfig().subscribe((res) => {
159
- this.cdr.markForCheck();
160
- this.fetchChatHistory().subscribe((response) => {
161
- this.loading = false;
162
- this.mapChatHistory(response);
163
- this.cdr.markForCheck();
164
- }, (err) => {
165
- console.error('Error fetching chat history:', err);
166
- });
167
- }, (err) => {
168
- console.error('Error fetching chat history:', err);
169
- });
170
- // this.fetchAgents();
171
- // this.fetchEditorContent();
172
- this.cdr.markForCheck();
173
- // this.initializeSocket();
174
- if (!this.checkForCop29BotId()) {
175
- this.botService.fetchSpeechAuthorizationToken().subscribe((token) => {
176
- this.authorizationToken = token;
177
- this.initializeSpeechRecognizer(token);
178
- });
179
- }
180
- }
181
- initializeSocket() {
182
- try {
183
- this.socketService.disconnectSocketConnection();
184
- }
185
- catch (error) { }
186
- setTimeout(() => {
187
- this.socketService.connectSocketConnection();
188
- setTimeout(() => {
189
- console.log('YES INIT');
190
- const conversation_id = this.conversationService.getKey(this.botId);
191
- this.socketService.registerUserSpecificHiveSocket(this.botId, conversation_id, this.orgId);
192
- setTimeout(() => {
193
- this.listenSockets();
194
- }, 300);
195
- }, 200);
196
- }, 300);
197
- }
198
- listenSockets() {
199
- if (this.eventSubscription) {
200
- this.eventSubscription.unsubscribe();
201
- }
202
- console.log('Listen Socket');
203
- this.eventSubscription = this.conversationService
204
- .getUserSpecificNotification()
205
- .subscribe((res) => {
206
- var _a, _b, _c, _d, _e, _f;
207
- console.log('Listen Socket response');
208
- console.log(res);
209
- // Check if OtherFields exists in the response
210
- 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) {
211
- 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;
212
- this.currentWorkflowActionProgress = percentage;
213
- this.currentWorkflowAction = action_name;
214
- const actionIndex = this.workflowExecutionDetails.Actions.findIndex((a) => a.Name == current_action_name);
215
- if (actionIndex !== -1) {
216
- this.workflowExecutionDetails.Actions[actionIndex]['Output'] = output;
217
- this.workflowExecutionDetails.Actions[actionIndex]['InsertTimeStamp'] = formatTimeStamps(this.timezone, time_stamp);
218
- }
219
- else {
220
- console.error(`Action with name ${action_name} not found`);
221
- }
222
- this.currentWorkflowExecutionDetails = this.workflowExecutionDetails;
223
- if (this.currentWorkflowActionProgress == 100) {
224
- this.chatLog[this.chatLog.length - 1]['WorkflowExecutionId'] = workflow_execution_id;
225
- this.isChatingWithAi = false;
226
- this.executingWorkflow = false;
227
- }
228
- this.cdr.detectChanges();
229
- }
230
- else if ((_d = res === null || res === void 0 ? void 0 : res.m) === null || _d === void 0 ? void 0 : _d.OtherFields) {
231
- 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;
232
- console.log('message_id1');
233
- console.log((_f = res === null || res === void 0 ? void 0 : res.m) === null || _f === void 0 ? void 0 : _f.OtherFields);
234
- var currentChatMessage = this.chatLog.find((p) => p._id == message_id);
235
- console.log(this.chatLog);
236
- if (!currentChatMessage) {
237
- console.log('message_id2');
238
- console.log(message_id);
239
- currentChatMessage = {
240
- _id: message_id,
241
- type: 'ai',
242
- time: formatNow(this.timezone),
243
- };
244
- this.chatLog.push(currentChatMessage);
245
- this.showFeedBackIconsIndex = this.chatLog.length - 1;
246
- console.log('message_id3');
247
- console.log(message_id);
248
- this.cdr.detectChanges();
249
- }
250
- // Handle the fields based on their presence
251
- if (search_results && Array.isArray(search_results)) {
252
- console.log('Online Search Terms:', search_results);
253
- currentChatMessage.searchTerms = search_results;
254
- this.cdr.detectChanges();
255
- }
256
- if (web_results && Array.isArray(web_results)) {
257
- console.log('Web Results:', web_results);
258
- currentChatMessage.sourcesList = web_results;
259
- currentChatMessage.displayedSources = web_results === null || web_results === void 0 ? void 0 : web_results.slice(0, 3); // First 3 cards
260
- currentChatMessage.remainingSources = web_results === null || web_results === void 0 ? void 0 : web_results.slice(3); // Remaining items
261
- this.cdr.detectChanges();
262
- }
263
- if (answer) {
264
- this.isChatingWithAi = false;
265
- console.log('Answer:', answer);
266
- currentChatMessage.message = this.processMessageForDisplay(answer);
267
- this.cdr.detectChanges();
268
- this.scrollToBottom();
269
- }
270
- if (graphs && Array.isArray(graphs)) {
271
- console.log('Graphs:', graphs);
272
- currentChatMessage.graphs = graphs;
273
- this.cdr.detectChanges();
274
- }
275
- if (execution_graphs && Array.isArray(execution_graphs)) {
276
- console.log('Execution Graphs:', execution_graphs);
277
- currentChatMessage.executionGraphs = execution_graphs;
278
- this.cdr.detectChanges();
279
- }
280
- if (suggestions && Array.isArray(suggestions)) {
281
- console.log('suggestions:', suggestions);
282
- currentChatMessage.relatedListItems = suggestions;
283
- this.cdr.detectChanges();
284
- // Process online search terms as needed
285
- }
286
- // Add any other fields and their processing here
287
- }
288
- else {
289
- console.warn('OtherFields is missing in the response');
290
- }
291
- }, (err) => {
292
- this.eventSubscription.unsubscribe();
293
- console.error('Error in fetching data from socket', err);
294
- });
295
- }
296
- initializeSocketAndListen() { }
297
- handleEvent(data, type) {
298
- switch (type) {
299
- case 'webresult':
300
- break;
301
- case 'answer':
302
- break;
303
- case 'graph':
304
- break;
305
- default:
306
- break;
307
- }
308
- }
309
- ngOnDestroy() {
310
- if (this.eventSubscription) {
311
- this.eventSubscription.unsubscribe();
312
- }
313
- this.socketService.disconnectSocketConnection();
314
- //this.socketService.close();
315
- }
316
- changeTemperature(newTemperature) {
317
- if (this.loading)
318
- return;
319
- this.temperature = newTemperature;
320
- const wrapper = document.querySelector('.hivegpt-chat-wrapper');
321
- // Remove existing theme classes from body
322
- wrapper === null || wrapper === void 0 ? void 0 : wrapper.classList.remove('creative', 'balanced', 'precise');
323
- switch (newTemperature) {
324
- case 0:
325
- wrapper === null || wrapper === void 0 ? void 0 : wrapper.classList.add('creative');
326
- break;
327
- case 1:
328
- wrapper === null || wrapper === void 0 ? void 0 : wrapper.classList.add('balanced');
329
- break;
330
- case 2:
331
- wrapper === null || wrapper === void 0 ? void 0 : wrapper.classList.add('precise');
332
- break;
333
- default:
334
- break;
335
- }
336
- }
337
- onStartAgain() {
338
- if (this.loading)
339
- return;
340
- this.showStartAgain = false;
341
- this.chatLog = [];
342
- this.chatLog.push({
343
- type: 'ai',
344
- message: this.greetingMsg,
345
- time: formatNow(this.timezone),
346
- });
347
- this.archieveMessages().subscribe();
348
- }
349
- archieveMessages() {
350
- const headers = new HttpHeaders({
351
- 'Content-Type': 'application/json',
352
- 'x-api-key': this.apiKey,
353
- 'hive-bot-id': this.botId
354
- });
355
- const url = `${this.environment.BASE_URL}/bot/clear-history/${this.botId}/${this.userId}`;
356
- return this.http.post(url, {}, { headers }).pipe(switchMap((res) => {
357
- return of(res);
358
- }), catchError((error) => {
359
- return of(null);
360
- }));
361
- }
362
- fetchBotConfig() {
363
- this.loading = true;
364
- const headers = new HttpHeaders({
365
- 'x-api-key': this.apiKey,
366
- 'hive-bot-id': this.botId
367
- });
368
- const url = `${this.environment.BASE_URL}/bots?bot_id=${this.botId}`;
369
- return this.http.get(url, { headers }).pipe(switchMap((res) => {
370
- var _a;
371
- this.botName = res.Name;
372
- this.botIcon = res.Icon;
373
- this.botSkills = res === null || res === void 0 ? void 0 : res.Skills;
374
- this.greetingMsg = res.Greeting;
375
- this.thumbsDownMessages = ((_a = res === null || res === void 0 ? void 0 : res.NegativeResponses) === null || _a === void 0 ? void 0 : _a.length) ? res.NegativeResponses
376
- : [
377
- "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;'><a href='mailto:support@social27.com' style='color: inherit; text-decoration: none;'>Please click here</a></span> and a human agent will assist you as soon as possible",
378
- ];
379
- this.quickPrompts = res.QuickPrompts;
380
- this.cdr.markForCheck();
381
- this.loading = false;
382
- return of(res);
383
- }), catchError((error) => {
384
- console.error('Error fetching chatbot config: ', error);
385
- this.loading = false;
386
- return of(null);
387
- }));
388
- }
389
- fetchChatHistory() {
390
- this.loading = true;
391
- this.conversationKey = this.conversationService.getKey(this.botId, false);
392
- const url = `${this.environment.BASE_URL}/conversations/${this.conversationKey}`;
393
- const headers = new HttpHeaders({
394
- accept: 'application/json',
395
- 'x-api-key': this.apiKey,
396
- 'hive-bot-id': this.botId
397
- });
398
- return this.http
399
- .get(url, { headers })
400
- .pipe(catchError(this.handleError('fetchConversation')));
401
- }
402
- handleError(operation = 'operation', result) {
403
- return (error) => {
404
- console.error(`${operation} failed: ${error.message}`);
405
- return of(result);
406
- };
407
- }
408
- // fetchChatHistory() {
409
- // this.loading = true;
410
- // const headers = new HttpHeaders({
411
- // 'Content-Type': 'application/json',
412
- // 'x-api-key': this.apiKey,
413
- // });
414
- // return this.http
415
- // .get(`${this.environment.BASE_URL}/conversations/${this.conversationKey}`, { headers })
416
- // .pipe(
417
- // switchMap((res: any) => {
418
- // this.loading = false;
419
- // return of(res);
420
- // }),
421
- // catchError((error: any) => {
422
- // console.error('Error fetching chat history: ', error);
423
- // this.loading = false;
424
- // return of(null);
425
- // })
426
- // );
427
- // }
428
- mapChatHistory(chats) {
429
- var _a;
430
- this.chatLog.push({
431
- type: 'ai',
432
- message: this.greetingMsg,
433
- time: formatNow(this.timezone),
434
- });
435
- if (chats && ((_a = chats === null || chats === void 0 ? void 0 : chats.Messages) === null || _a === void 0 ? void 0 : _a.length)) {
436
- chats === null || chats === void 0 ? void 0 : chats.Messages.forEach((chat) => {
437
- if (chat.Type == 'user') {
438
- this.chatLog.push({
439
- type: 'user',
440
- message: this.processMessageForDisplay(chat.Text),
441
- time: formatTimeStamps(this.timezone, chat.InsertTimestamp),
442
- copied: false,
443
- isCollapsedTrue: false,
444
- WorkflowExecutionId: chat.WorkflowExecutionId,
445
- _id: chat._id
446
- });
447
- }
448
- if (chat.Type == 'ai') {
449
- var sourcesList = chat.WebLinks || [];
450
- var displayedSources = chat.WebLinks.slice(0, 3); // First 3 cards
451
- var remainingSources = chat.WebLinks.slice(3); // Remaining items
452
- this.chatLog.push({
453
- type: 'ai',
454
- message: this.processMessageForDisplay(chat.Text),
455
- executionGraphs: chat.ExecutionGraphs,
456
- graphs: chat.Graphs,
457
- searchTerms: chat.SearchTerms,
458
- sourcesList: sourcesList,
459
- displayedSources: displayedSources,
460
- remainingSources: remainingSources,
461
- time: formatTimeStamps(this.timezone, chat.InsertTimestamp),
462
- copied: false,
463
- isCollapsedTrue: false,
464
- _id: chat._id
465
- });
466
- this.showFeedBackIconsIndex = this.chatLog.length - 1;
467
- }
468
- });
469
- this.showStartAgain = true;
470
- }
471
- this.scrollToBottom();
472
- this.cdr.markForCheck();
473
- }
474
- processMessage(message) {
475
- if (!message || !((message === null || message === void 0 ? void 0 : message.length) > 0)) {
476
- return '';
477
- }
478
- // console.log('here is my message')
479
- // console.log(message);
480
- message = message.trim();
481
- const markdownLinkRegex = /\[([^[]+)]\(([^)]+)\)/g;
482
- const urlRegex = /(?<!href=")\bhttps?:\/\/\S+(?<![.,])/gi;
483
- if (markdownLinkRegex.test(message)) {
484
- const html = message.replace(markdownLinkRegex, '<a href="$2" target="_blank">$1</a>');
485
- //console.log('Sanitized message: ', message);
486
- return this.sanitizeHtml(html);
487
- }
488
- if (urlRegex.test(message)) {
489
- const html = message.replace(urlRegex, '<a href="$&" target="_blank">$&</a>');
490
- // console.log('Sanitized message: ', message);
491
- return this.sanitizeHtml(html);
492
- }
493
- message = message.replace(/(?:\r\n|\r|\n)/g, '<br>');
494
- message = message.replace(/\*\*(.*?)\*\*/g, '<strong>$1</strong>');
495
- // Convert Markdown headers to HTML headers
496
- message = message.replace(/^(#{1,6})\s+(.*)$/gm, (match, hashes, text) => {
497
- const level = hashes.length;
498
- return `<h${level}>${text}</h${level}>`;
499
- });
500
- this.cdr.markForCheck();
501
- const sanitizedMessage = this.sanitizeHtml(message);
502
- return sanitizedMessage;
503
- }
504
- ngAfterViewChecked() {
505
- const feedbackLinks = this.elementRef.nativeElement.querySelectorAll('.feedback-link');
506
- feedbackLinks.forEach((link) => {
507
- link.addEventListener('click', this.onFeedbackClick.bind(this, 'zendesk'));
508
- });
509
- // if (this.elementRef.nativeElement.querySelector('.feedback-link')) {
510
- // this.elementRef.nativeElement
511
- // .querySelector('.feedback-link')
512
- // .addEventListener('click', this.onFeedbackClick.bind(this, 'zendesk'));
513
- // }
514
- }
515
- sanitizeHtml(html) {
516
- return this.sanitizer.bypassSecurityTrustHtml(html);
517
- }
518
- onFeedbackClick(value) {
519
- this.feedbackEvent.emit(value);
520
- }
521
- onClose() {
522
- this.renderer.removeClass(document.body, this.bodyOverflowClass);
523
- this.onCloseEvent.emit();
524
- }
525
- sendMessageWithTile(prompt) {
526
- this.input = prompt;
527
- this.fetchData();
528
- this.scrollToBottom();
529
- }
530
- fetchData(msg = null) {
531
- var _a;
532
- this.input = msg || ((_a = this.input) === null || _a === void 0 ? void 0 : _a.trim());
533
- this.msg = this.input;
534
- if (!this.input || this.loading) {
535
- return;
536
- }
537
- this.chatLog.push({
538
- type: 'user',
539
- message: this.processMessageForDisplay(this.input),
540
- time: formatNow(this.timezone),
541
- copied: false,
542
- isCollapsedTrue: false,
543
- });
544
- try {
545
- const textarea = this.myInput.nativeElement;
546
- textarea.style.height = 'hidden'; // Reset the height
547
- textarea.style.height = `62px`;
548
- }
549
- catch (error) { }
550
- this.cdr.markForCheck();
551
- this.aiResponse = '';
552
- this.isChatingWithAi = true;
553
- this.makeAskRequest(this.input, this.agents, this.conversationKey);
554
- }
555
- fetchDataFor(msg, chat) {
556
- const inputMsg = msg === null || msg === void 0 ? void 0 : msg.trim();
557
- if (!inputMsg || this.loading) {
558
- return;
559
- }
560
- try {
561
- chat.relatedListItems = [];
562
- this.cdr.detectChanges();
563
- }
564
- catch (error) { }
565
- this.scrollToBottom();
566
- this.chatLog.push({
567
- type: 'user',
568
- message: this.processMessageForDisplay(inputMsg),
569
- time: formatNow(this.timezone),
570
- copied: false,
571
- isCollapsedTrue: false,
572
- });
573
- this.cdr.markForCheck();
574
- this.aiResponse = '';
575
- this.isChatingWithAi = true;
576
- this.makeAskRequest(inputMsg, this.agents, this.conversationKey, msg, chat);
577
- }
578
- fetchSmallTalk() {
579
- this.loading = true;
580
- this.cdr.markForCheck();
581
- const url = `${this.environment.BASE_URL}/bot/small-talk/${this.botId}/${this.userId}`;
582
- this.http
583
- .get(url, {
584
- headers: {
585
- 'x-api-key': this.apiKey,
586
- 'hive-bot-id': this.botId
587
- },
588
- })
589
- .pipe(catchError((error) => {
590
- console.error('Error while fetching small talk:', error);
591
- return of(null);
592
- }))
593
- .subscribe((response) => {
594
- this.loading = false;
595
- this.cdr.markForCheck();
596
- if (!response) {
597
- return;
598
- }
599
- if (response && response.smallTalk) {
600
- this.chatLog.push({
601
- type: 'ai',
602
- message: this.processMessage(response.smallTalk),
603
- time: formatNow(this.timezone),
604
- isFeedbackMsg: true,
605
- });
606
- this.showFeedBackIconsIndex = this.chatLog.length - 2;
607
- // this.scrollToBottom();
608
- this.cdr.markForCheck();
609
- }
610
- });
611
- }
612
- pump(controller, reader, allSuggestions) {
613
- reader.read().then(({ done, value }) => {
614
- var _a, _b, _c, _d;
615
- const lastItem = this.chatLog[this.chatLog.length - 1];
616
- if (done) {
617
- lastItem.message = this.processMessageForDisplay(lastItem.message);
618
- this.chatLog.pop();
619
- this.chatLog.push(lastItem);
620
- if (allSuggestions === null || allSuggestions === void 0 ? void 0 : allSuggestions.length) {
621
- this.chatLog.push({
622
- type: 'suggestions',
623
- suggestions: allSuggestions,
624
- });
625
- }
626
- controller.close();
627
- this.isChatingWithAi = false;
628
- // this.scrollToBottom();
629
- this.cdr.markForCheck();
630
- this.showStartAgain = true;
631
- // setTimeout(() => {
632
- // this.fetchSmallTalk();
633
- // },1000)
634
- return;
635
- }
636
- let decodedChunk = this.decoder.decode(value, { stream: true });
637
- this.aiResponse += decodedChunk;
638
- if (lastItem.type === 'ai') {
639
- const suggestionsMatch = this.aiResponse.match(/<sug>(.*?)<\/sug>/g);
640
- if (suggestionsMatch) {
641
- suggestionsMatch.forEach((match) => {
642
- this.aiResponse = this.aiResponse.replace(match, '');
643
- allSuggestions.push(match === null || match === void 0 ? void 0 : match.replace(/<\/?sug>/g, ''));
644
- });
645
- }
646
- lastItem.message = this.aiResponse;
647
- this.cdr.markForCheck();
648
- }
649
- else {
650
- this.isChatingWithAi = false;
651
- let aiFormattedData;
652
- try {
653
- console.log('parsing json ');
654
- aiFormattedData = JSON.parse(JSON.parse(this.aiResponse));
655
- }
656
- catch (e) {
657
- try {
658
- console.log('parsing json 2');
659
- aiFormattedData = JSON.parse(this.aiResponse);
660
- }
661
- catch (e) { }
662
- }
663
- console.log('parsing json done');
664
- if (aiFormattedData && ((_a = aiFormattedData === null || aiFormattedData === void 0 ? void 0 : aiFormattedData.section_id) === null || _a === void 0 ? void 0 : _a.length) > 0) {
665
- if (aiFormattedData.section_id == 'company_search' ||
666
- aiFormattedData.section_id == 'user_search' ||
667
- aiFormattedData.section_id == 'industry_company_search') {
668
- this.fetchMyConnections().subscribe();
669
- this.fetchPendingRequests().subscribe();
670
- }
671
- if (aiFormattedData.section_id == this.myUpcomingSessionAction) {
672
- var speakerIds = [];
673
- (_b = aiFormattedData.content) === null || _b === void 0 ? void 0 : _b.forEach((session) => {
674
- speakerIds = [...speakerIds, ...session.speakers];
675
- });
676
- if ((speakerIds === null || speakerIds === void 0 ? void 0 : speakerIds.length) > 0)
677
- this.getSpeakersByStaffIds(speakerIds);
678
- }
679
- if (aiFormattedData.section_id == this.addToMyAgendaAction &&
680
- ((_c = aiFormattedData.content) === null || _c === void 0 ? void 0 : _c.length) > 0) {
681
- this.openPage.next({
682
- sectionId: aiFormattedData.section_id,
683
- sessionIds: aiFormattedData.content,
684
- });
685
- }
686
- if (aiFormattedData.section_id == this.connectOrFollowAction) {
687
- let usersLen = (_d = aiFormattedData.content) === null || _d === void 0 ? void 0 : _d.length;
688
- if (usersLen > 1) {
689
- this.openPage.next({
690
- sectionId: 'open_networking_drawer',
691
- search: aiFormattedData.content,
692
- });
693
- }
694
- else if (usersLen == 1) {
695
- this.openPage.next({
696
- sectionId: aiFormattedData.section_id,
697
- connetUserIds: [aiFormattedData.content[0].userId],
698
- });
699
- }
700
- }
701
- if (aiFormattedData.is_open_page == 'true') {
702
- this.openPage.next({
703
- sectionId: aiFormattedData.section_id,
704
- search: aiFormattedData.content,
705
- });
706
- if (this.isMobileBrowser()) {
707
- aiFormattedData.message +=
708
- '\n\n' + '<a id="closeBotNow">Click Here</a> to see results.';
709
- }
710
- }
711
- this.chatLog.push({
712
- type: 'ai',
713
- message: aiFormattedData.message,
714
- action: aiFormattedData,
715
- time: formatNow(this.timezone),
716
- });
717
- if (this.isMobileBrowser()) {
718
- setTimeout(() => {
719
- this.addCloseBotClickEvent();
720
- }, 500);
721
- }
722
- this.aiResponse = '';
723
- }
724
- else {
725
- this.chatLog.push({
726
- type: 'ai',
727
- message: this.aiResponse,
728
- time: formatNow(this.timezone),
729
- });
730
- }
731
- this.showFeedBackIconsIndex = this.chatLog.length - 1;
732
- this.cdr.markForCheck();
733
- }
734
- this.scrollToBottom();
735
- // Enqueue the next data chunk into our target stream
736
- controller.enqueue(value);
737
- this.pump(controller, reader, allSuggestions);
738
- });
739
- }
740
- submitFeedback(flag, message) {
741
- console.log(message);
742
- this.feedbackDone = true;
743
- this.showFeedBackIconsIndex = null;
744
- const conversation_id = this.conversationService.getKey(this.botId);
745
- const url = `${this.environment.AGENTS_API}/Conversation/coPilot/${this.botId}/conversation/${conversation_id}/helpful-response`;
746
- fetch(url, {
747
- method: 'POST',
748
- headers: {
749
- 'Content-Type': 'application/json',
750
- 'apiKey': 'Conversation_WIz/qAm+EEmfOkFaUA/weA==',
751
- 'hive-bot-id': this.botId
752
- },
753
- body: JSON.stringify({ messageId: message._id, isHelpful: flag }),
754
- }).then(() => {
755
- if (flag) {
756
- this.chatLog.push({
757
- type: 'ai',
758
- message: this.thumbsUpMessage ||
759
- `Great. May I assist you with anything else?`,
760
- time: formatNow(this.timezone),
761
- isFeedbackMsg: true,
762
- });
763
- this.scrollToBottom();
764
- this.cdr.markForCheck();
765
- this.feedbackDone = false;
766
- this.showFeedBackIconsIndex = null;
767
- return;
768
- }
769
- this.chatLog.push({
770
- type: 'ai',
771
- message: this.processMessage(this.thumbsDownMessages[this.thumbsDownMsgIndex]),
772
- time: formatNow(this.timezone),
773
- isFeedbackMsg: true,
774
- });
775
- this.thumbsDownMsgIndex =
776
- (this.thumbsDownMsgIndex + 1) % this.thumbsDownMessages.length;
777
- this.scrollToBottom();
778
- this.cdr.markForCheck();
779
- this.feedbackDone = false;
780
- this.showFeedBackIconsIndex = null;
781
- });
782
- }
783
- handleKeydown(event) {
784
- if (event.key === 'Enter' && !event.shiftKey) {
785
- // Prevent default behavior (new line)
786
- event.preventDefault();
787
- // Call your submit function
788
- this.handleSubmit(event);
789
- }
790
- }
791
- handleSubmit(event) {
792
- this.fetchData();
793
- this.scrollToBottom();
794
- }
795
- handleUpClick(idx) {
796
- if (this.feedbackDone) {
797
- return;
798
- }
799
- this.submitFeedback(true, this.chatLog[idx]);
800
- this.chatLog[idx].liked = !this.chatLog[idx].liked;
801
- if (this.chatLog[idx].unliked) {
802
- this.chatLog[idx].unliked = !this.chatLog[idx].unliked;
803
- }
804
- this.cdr.markForCheck();
805
- }
806
- handleDownClick(idx) {
807
- if (this.feedbackDone)
808
- return;
809
- this.submitFeedback(false, this.chatLog[idx]);
810
- this.chatLog[idx].unliked = !this.chatLog[idx].unliked;
811
- if (this.chatLog[idx].liked)
812
- this.chatLog[idx].liked = !this.chatLog[idx].liked;
813
- }
814
- // handleCopyClick(index: any) {
815
- // // Copy the message to the clipboard
816
- // const contentToCopy = this.chatLog[index].message;
817
- // console.log('contentToCopy');
818
- // console.log(contentToCopy);
819
- // navigator.clipboard.writeText(contentToCopy).then(() => {
820
- // // Indicate that the message was copied
821
- // this.chatLog[index].copied = true;
822
- // this.cdr.detectChanges();
823
- // // Reset the copied state after a delay
824
- // setTimeout(() => {
825
- // this.chatLog[index].copied = false;
826
- // this.cdr.detectChanges();
827
- // }, 2000); // Reset after 2 seconds
828
- // });
829
- // }
830
- copyText(id, index) {
831
- // Get the text element
832
- var textElement = document.getElementById(id);
833
- // Create a temporary textarea element to copy the text
834
- var tempTextArea = document.createElement('textarea');
835
- tempTextArea.value = textElement.innerText;
836
- // Append the textarea to the body (necessary for the execCommand to work)
837
- document.body.appendChild(tempTextArea);
838
- // Select the text inside the textarea
839
- tempTextArea.select();
840
- // Copy the text to the clipboard
841
- document.execCommand('copy');
842
- // Remove the temporary textarea
843
- document.body.removeChild(tempTextArea);
844
- // Optionally, you can alert the user or change the button text to indicate the copy was successful
845
- // alert('Text copied to clipboard!');
846
- this.chatLog[index].copied = true;
847
- this.cdr.detectChanges();
848
- // Reset the copied state after a delay
849
- setTimeout(() => {
850
- this.chatLog[index].copied = false;
851
- this.cdr.detectChanges();
852
- }, 2000); // Reset after 2 seconds
853
- }
854
- handleCopyClick(index) {
855
- // Copy the message to the clipboard
856
- const contentToCopy = this.chatLog[index].message;
857
- const resutlt = this.copyText('messageText_' + index, index);
858
- }
859
- sanitizeHTML(html) {
860
- const doc = new DOMParser().parseFromString(html, 'text/html');
861
- // Create a new document fragment to hold the simplified content
862
- const fragment = document.createDocumentFragment();
863
- // Append the children of the body of the parsed document to the fragment
864
- Array.from(doc.body.childNodes).forEach((node) => {
865
- fragment.appendChild(node.cloneNode(true));
866
- });
867
- // Create a new div element to hold the simplified HTML
868
- const simplifiedDiv = document.createElement('div');
869
- simplifiedDiv.appendChild(fragment);
870
- // Remove complex tags or attributes as needed
871
- // Example: remove scripts
872
- simplifiedDiv
873
- .querySelectorAll('script')
874
- .forEach((script) => script.remove());
875
- // Return the simplified HTML as a string
876
- return simplifiedDiv.innerHTML;
877
- }
878
- handleEditorClick(index) {
879
- if (this.currentIndexForEditor == -1) {
880
- this.currentIndexForEditor = index;
881
- this.currentMessageForEditor = this.sanitizeHTML(this.chatLog[index].message);
882
- this.currentMessageForEditor = this.currentMessageForEditor.replace('SafeValue must use [property]=binding:', '');
883
- this.cdr.detectChanges();
884
- }
885
- else {
886
- if (this.currentIndexForEditor == index) {
887
- this.currentMessageForEditor += this.sanitizeHTML(this.chatLog[index].message);
888
- this.currentMessageForEditor = this.currentMessageForEditor.replace('SafeValue must use [property]=binding:', '');
889
- this.cdr.detectChanges();
890
- }
891
- else {
892
- this.currentIndexForEditor = index;
893
- this.currentMessageForEditor = this.sanitizeHTML(this.chatLog[index].message);
894
- this.currentMessageForEditor = this.currentMessageForEditor.replace('SafeValue must use [property]=binding:', '');
895
- this.cdr.detectChanges();
896
- }
897
- }
898
- this.chatLog[index].isEditor = true;
899
- this.cdr.detectChanges();
900
- // Reset the copied state after a delay
901
- setTimeout(() => {
902
- this.chatLog[index].isEditor = false;
903
- this.cdr.detectChanges();
904
- }, 2000); // Reset after 2 seconds
905
- this.editorsDrawer.open();
906
- const button = document.getElementById('botcloseplaygroundbutton');
907
- if (button) {
908
- button.style.display = 'none';
909
- }
910
- this.cdr.detectChanges();
911
- }
912
- scrollToBottom() {
913
- let counter = 0;
914
- const interval = setInterval(() => {
915
- this.chatMain.nativeElement.scrollTop = this.chatMain.nativeElement.scrollHeight;
916
- if (counter++ > 5)
917
- clearInterval(interval);
918
- }, 5);
919
- }
920
- handleAction(action) {
921
- console.info('incoming action from the chatbot AI');
922
- console.info(action);
923
- if (action === null || action === void 0 ? void 0 : action.content) {
924
- }
925
- }
926
- ngAfterViewInit() {
927
- // Check if the drawer is initially open and apply overflow hidden to body if so
928
- if (this.drawer.opened) {
929
- this.setBodyOverflow();
930
- }
931
- // Listen to changes in the drawer being opened or closed
932
- this.drawer.openedChange.subscribe((opened) => {
933
- if (opened) {
934
- this.setBodyOverflow();
935
- }
936
- else {
937
- this.removeBodyOverflow();
938
- }
939
- });
940
- this.drawer.openedChange.subscribe((opened) => {
941
- if (opened) {
942
- setTimeout(() => {
943
- if (this.myTextarea && this.myTextarea.nativeElement) {
944
- this.myTextarea.nativeElement.focus(); // Focus on the textarea
945
- }
946
- });
947
- }
948
- });
949
- }
950
- setBodyOverflow() {
951
- this.renderer.addClass(document.body, this.bodyOverflowClass);
952
- }
953
- removeBodyOverflow() {
954
- this.renderer.removeClass(document.body, this.bodyOverflowClass);
955
- }
956
- getSpeakersByStaffIds(ids) {
957
- const url = `${this.environment.USERS_API}/events/${this.eventId}/users/get-by-staff-ids`;
958
- fetch(url, {
959
- method: 'POST',
960
- headers: {
961
- 'Content-Type': 'application/json',
962
- Authorization: 'Bearer ' + 'your_token_here',
963
- },
964
- body: JSON.stringify(ids),
965
- })
966
- .then((response) => {
967
- if (response.ok) {
968
- return response.json(); // Parse the JSON body of the response
969
- }
970
- else {
971
- throw new Error('Network response was not ok.');
972
- }
973
- })
974
- .then((data) => {
975
- if ((data === null || data === void 0 ? void 0 : data.length) > 0) {
976
- data.forEach((speaker) => {
977
- this.speakers[speaker.id] = speaker;
978
- });
979
- this.cdr.markForCheck();
980
- }
981
- })
982
- .catch((err) => {
983
- console.error('Error fetching data:', err);
984
- this.loading = false;
985
- });
986
- }
987
- performSessionAction(sessionId, action) {
988
- this.sessionActions.next({
989
- sessionId,
990
- action,
991
- });
992
- }
993
- addCloseBotClickEvent() {
994
- const element = this.elementRef.nativeElement.querySelector('#closeBotNow');
995
- if (element) {
996
- this.renderer.listen(element, 'click', () => {
997
- this.closeBot.next();
998
- });
999
- }
1000
- }
1001
- isMobileBrowser() {
1002
- return /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent);
1003
- }
1004
- connectToUser(userId) {
1005
- this.connectWithUser.emit({
1006
- connect: !this.canDisconnect(userId),
1007
- userId,
1008
- });
1009
- setTimeout(() => {
1010
- this.fetchMyConnections().subscribe((res) => {
1011
- this.cdr.markForCheck();
1012
- });
1013
- this.fetchPendingRequests().subscribe((res) => {
1014
- this.cdr.markForCheck();
1015
- });
1016
- }, 500);
1017
- }
1018
- scheduleMeetingWithUser(user) {
1019
- this.scheduleMeeting.emit(user);
1020
- }
1021
- canConnect(userId) {
1022
- return !(this.canDisconnect(userId) ||
1023
- this.pendingRequests.find((a) => a == userId));
1024
- }
1025
- canDisconnect(userId) {
1026
- return this.myConnections.find((conn) => conn.userId == userId);
1027
- }
1028
- fetchPendingRequests() {
1029
- const headers = new HttpHeaders({
1030
- 'Content-Type': 'application/json',
1031
- apiKey: this.autogenKey,
1032
- });
1033
- return this.http
1034
- .get(`${this.environment.USERS_API}/events/${this.eventId}/connection-requests/autogen/pending-sent-requests?userId=${this.userId}`, { headers })
1035
- .pipe(switchMap((res) => {
1036
- this.pendingRequests = res;
1037
- this.cdr.markForCheck();
1038
- return of(res);
1039
- }), catchError((error) => {
1040
- console.error('Error fetching pending requests: ', error);
1041
- return of(null);
1042
- }));
1043
- }
1044
- fetchMyConnections() {
1045
- const headers = new HttpHeaders({
1046
- 'Content-Type': 'application/json',
1047
- apiKey: this.autogenKey,
1048
- });
1049
- return this.http
1050
- .get(`${this.environment.USERS_API}/events/${this.eventId}/users-connections/autogen?userId=${this.userId}`, { headers })
1051
- .pipe(switchMap((res) => {
1052
- this.myConnections = res;
1053
- this.cdr.markForCheck();
1054
- return of(res);
1055
- }), catchError((error) => {
1056
- console.error('Error fetching pending requests: ', error);
1057
- return of(null);
1058
- }));
1059
- }
1060
- // Toggle the dropdown visibility
1061
- toggleDropdown() {
1062
- if (!this.agents)
1063
- this.fetchAgents();
1064
- this.isDropdownOpen = !this.isDropdownOpen;
1065
- this.cdr.detectChanges();
1066
- }
1067
- onSelectAll(event) {
1068
- var _a;
1069
- (_a = this.agents) === null || _a === void 0 ? void 0 : _a.forEach((agent) => (agent.selected = false));
1070
- this.cdr.detectChanges();
1071
- }
1072
- onAgentChange(agent) {
1073
- //agent.selected = !agent.selected;
1074
- //console.log(agent);
1075
- let agentFound = this.agents.filter((p) => p.id == agent.id);
1076
- if (agentFound && agentFound.length > 0) {
1077
- agentFound[0].selected = !agentFound[0].selected;
1078
- this.cdr.detectChanges();
1079
- }
1080
- this.cdr.detectChanges();
1081
- }
1082
- areAllSelected() {
1083
- var _a;
1084
- return (_a = this.agents) === null || _a === void 0 ? void 0 : _a.every((agent) => !agent.selected);
1085
- }
1086
- getDropdownHeaderText() {
1087
- var _a;
1088
- const selectedAgents = (_a = this.agents) === null || _a === void 0 ? void 0 : _a.filter((agent) => agent.selected);
1089
- if (!selectedAgents) {
1090
- return 'All Agents';
1091
- }
1092
- else {
1093
- if (selectedAgents && (selectedAgents === null || selectedAgents === void 0 ? void 0 : selectedAgents.length) === 0) {
1094
- return 'All Agents';
1095
- }
1096
- else {
1097
- return (selectedAgents === null || selectedAgents === void 0 ? void 0 : selectedAgents.length) > 1
1098
- ? `${selectedAgents === null || selectedAgents === void 0 ? void 0 : selectedAgents.length} Agents Selected`
1099
- : `${selectedAgents === null || selectedAgents === void 0 ? void 0 : selectedAgents.length} Agent Selected`;
1100
- }
1101
- }
1102
- }
1103
- fetchAgents_http() {
1104
- this.loading = true;
1105
- const url = `${this.environment.AGENTS_API}/CoPilot/${this.botId}/active-agents`;
1106
- const headers = new HttpHeaders({
1107
- 'Content-Type': 'application/json',
1108
- });
1109
- return this.http.post(url, {}, { headers }).pipe(switchMap((res) => {
1110
- if (res) {
1111
- this.agents = res.map((agent) => (Object.assign(Object.assign({}, agent), { selected: false })));
1112
- }
1113
- this.cdr.markForCheck();
1114
- return of(res);
1115
- }), catchError((error) => {
1116
- console.error('Error fetching chatbot config: ', error);
1117
- return of(null);
1118
- }));
1119
- }
1120
- fetchContent_http() {
1121
- this.isDocInEditMode = false;
1122
- this.isContentLoaded = false;
1123
- console.log('API call function');
1124
- this.loading = true;
1125
- const conversation_id = this.conversationService.getKey(this.botId);
1126
- this.conversationId = conversation_id;
1127
- const url = `${this.environment.AGENTS_API}/ConversationDocuments?conversationId=${conversation_id}&botId=${this.botId}`;
1128
- const headers = new HttpHeaders({
1129
- 'Content-Type': 'application/json',
1130
- apiKey: 'WIz/qAm+EEmfOkFaUA/weA==',
1131
- });
1132
- return this.http.get(url, { headers }).pipe(switchMap((res) => {
1133
- if (res) {
1134
- this.isDocInEditMode = true;
1135
- this.documentContent = res;
1136
- console.log('Get API callled success');
1137
- this.isContentLoaded = true;
1138
- console.log(res);
1139
- }
1140
- this.cdr.markForCheck();
1141
- return of(res);
1142
- }), catchError((error) => {
1143
- console.error('Error fetching chatbot config DJ: ', error);
1144
- this.isDocInEditMode = false;
1145
- this.isContentLoaded = true;
1146
- if ((error === null || error === void 0 ? void 0 : error.status) == 404) {
1147
- console.log('dash');
1148
- this.isDocInEditMode = false;
1149
- this.isContentLoaded = true;
1150
- }
1151
- return of(null);
1152
- }));
1153
- }
1154
- fetchAgents() {
1155
- this.fetchAgents_http().subscribe();
1156
- }
1157
- fetchEditorContent() {
1158
- this.fetchContent_http().subscribe();
1159
- }
1160
- // events/${eventId}/users-connections
1161
- processMessageForDisplay(markdown) {
1162
- try {
1163
- // Parse the markdown content to HTML using marked
1164
- const markdownContent = marked.parse(markdown);
1165
- // Sanitize the parsed HTML using Angular's DomSanitizer
1166
- // const sanitizedHtml = this.sanitizer.bypassSecurityTrustHtml(markdownContent);
1167
- // Return the safe HTML content for display
1168
- return markdownContent;
1169
- }
1170
- catch (error) {
1171
- console.error('Error processing markdown:', error);
1172
- return ''; // Return an empty string or handle the error appropriately
1173
- }
1174
- }
1175
- prepareHtml(markdown) {
1176
- if (!markdown || !(markdown.length > 0)) {
1177
- console.error('Input Markdown is null or empty');
1178
- return '';
1179
- }
1180
- // Convert Markdown headers (### or ##) to <strong> for bold headings
1181
- let html = markdown.replace(/^(#{1,6})\s+(.*)$/gm, (match, hashes, text) => {
1182
- const level = hashes.length;
1183
- if (level === 3) {
1184
- return `<h3><strong>${text}</strong></h3>`;
1185
- }
1186
- else if (level === 4) {
1187
- return `<h4><strong>${text}</strong></h4>`;
1188
- }
1189
- return `<strong>${text}</strong>`;
1190
- });
1191
- // Convert Markdown code blocks with language to preformatted HTML
1192
- html = html.replace(/```(\w+)?\n([\s\S]*?)```/g, (match, lang, code) => {
1193
- const escapedCode = this.escapeHtml(code);
1194
- const language = lang || 'plaintext';
1195
- // Create a copy button for the code block
1196
- return `
1197
- <div class="code-container">
1198
- <button id="copy-button" class="copy-button" (click)="copyToClipboard('\`${escapedCode}\`')">Copy</button>
1199
- <pre class="code_block diff"><code class="language-${language}">${escapedCode}</code></pre>
1200
- </div>`;
1201
- });
1202
- // Convert inline code (wrapped in `backticks`) to inline <code> tags
1203
- html = html.replace(/`([^`]+)`/g, '<code>$1</code>');
1204
- // Convert Markdown bold to HTML <strong>
1205
- html = html.replace(/\*\*(.*?)\*\*/g, '<strong>$1</strong>');
1206
- // Convert numbered lists
1207
- html = html.replace(/^\d+\.\s+(.*)$/gm, '<li>$1</li>');
1208
- // Convert bullet point lists
1209
- html = html.replace(/^\-\s+(.*)$/gm, '<li>$1</li>');
1210
- // Convert Markdown links to HTML links
1211
- html = html.replace(/\[([^\]]+)]\(([^)]+)\)/g, '<a href="$2" target="_blank">$1</a>');
1212
- // Convert new lines to <br> tags for paragraphs
1213
- html = html.replace(/(?:\r\n|\r|\n)/g, '<br>');
1214
- return html;
1215
- }
1216
- // Helper function to escape HTML characters for code blocks
1217
- escapeHtml(code) {
1218
- return code
1219
- .replace(/&/g, '&amp;')
1220
- .replace(/</g, '&lt;')
1221
- .replace(/>/g, '&gt;')
1222
- .replace(/"/g, '&quot;')
1223
- .replace(/'/g, '&#039;');
1224
- }
1225
- // Function to copy text to clipboard
1226
- copyToClipboard(text) {
1227
- navigator.clipboard.writeText(text).then(() => {
1228
- alert('Code copied to clipboard!');
1229
- }, (err) => {
1230
- console.error('Could not copy text: ', err);
1231
- });
1232
- }
1233
- toggleCollapse() {
1234
- this.isCollapsed = !this.isCollapsed;
1235
- this.cdr.detectChanges();
1236
- }
1237
- toggleCollapseGraph() {
1238
- this.isCollapsedForGraph = !this.isCollapsedForGraph;
1239
- this.cdr.detectChanges();
1240
- }
1241
- toggleCollapseFGraph() {
1242
- this.isCollapsedForFGraph = !this.isCollapsedForFGraph;
1243
- this.cdr.detectChanges();
1244
- }
1245
- // Extracts the domain from a URL
1246
- getDomainName(url) {
1247
- try {
1248
- const { hostname } = new URL(url);
1249
- return hostname.replace(/^www\./, ''); // Remove 'www.' if present
1250
- }
1251
- catch (_a) {
1252
- return 'unknown';
1253
- }
1254
- }
1255
- // Generates the favicon URL
1256
- getFaviconUrl(url) {
1257
- const domain = this.getDomainName(url);
1258
- return `https://www.google.com/s2/favicons?sz=128&domain=${domain}`;
1259
- }
1260
- onCardClick(sources) {
1261
- this.currentSourcesList = sources;
1262
- this.cdr.detectChanges();
1263
- this.sourcesDrawer.open();
1264
- const button = document.getElementById('botcloseplaygroundbutton');
1265
- if (button) {
1266
- button.style.display = 'none';
1267
- }
1268
- }
1269
- openOuterEditor() {
1270
- this.fetchEditorContent();
1271
- this.editorsDrawer.open();
1272
- this.isDrawerOpen = true;
1273
- this.isShowEditorButton = false;
1274
- this.cdr.detectChanges();
1275
- const button = document.getElementById('botcloseplaygroundbutton');
1276
- if (button) {
1277
- button.style.display = 'none';
1278
- }
1279
- }
1280
- onCloseEditor() {
1281
- this.editorsDrawer.close();
1282
- this.isDrawerOpen = false;
1283
- this.isShowEditorButton = true;
1284
- this.cdr.detectChanges(); // Trigger change detection if needed
1285
- this.onDrawerClosed();
1286
- }
1287
- onCloseSource() {
1288
- this.sourcesDrawer.close();
1289
- this.isDrawerOpen = false;
1290
- this.cdr.detectChanges(); // Trigger change detection if needed
1291
- this.onDrawerClosed();
1292
- }
1293
- onDrawerClosed() {
1294
- setTimeout(() => {
1295
- this.isDrawerOpen = true;
1296
- this.cdr.detectChanges(); // Trigger change detection if needed
1297
- // Use ngClass to dynamically apply the class
1298
- const button = document.getElementById('botcloseplaygroundbutton');
1299
- if (button) {
1300
- button.style.display = 'block';
1301
- }
1302
- }, 800);
1303
- }
1304
- toggleDrawer(todo) {
1305
- this.isDrawerOpen = todo;
1306
- this.cdr.detectChanges();
1307
- this.updateButtonVisibility();
1308
- }
1309
- updateButtonVisibility() {
1310
- const button = document.getElementById('botcloseplaygroundbutton');
1311
- if (button) {
1312
- button.style.display = this.isDrawerOpen ? 'block' : 'none';
1313
- }
1314
- }
1315
- openLinkInNewTab(link) {
1316
- window.open(link, '_blank');
1317
- }
1318
- adjustTextareaHeight(event) {
1319
- try {
1320
- if (event.key === 'Enter' && !event.shiftKey) {
1321
- // Prevents a new line from being added
1322
- event.preventDefault();
1323
- }
1324
- }
1325
- catch (error) {
1326
- }
1327
- const textarea = event.target;
1328
- textarea.style.height = 'auto'; // Reset the height
1329
- textarea.style.height = `${textarea.scrollHeight}px`; // Adjust height to match content
1330
- // Ensure the height doesn't exceed the max-height set in CSS
1331
- if (textarea.scrollHeight > 150) {
1332
- textarea.style.height = `150px`; // Adjust height to match content
1333
- textarea.style.overflowY = 'auto'; // Enable scrolling if content exceeds 400px
1334
- }
1335
- else {
1336
- textarea.style.overflowY = 'hidden'; // Hide scrollbar if content is within limits
1337
- }
1338
- }
1339
- toggleWorkflows(value = null) {
1340
- if (!this.checkForCop29BotId()) {
1341
- this.botService.getWorkflowsByOrgId(this.orgId).subscribe((res) => {
1342
- this.orgWorkflows = res;
1343
- this.isWorkflowOpen = value == null ? !this.isWorkflowOpen : value;
1344
- if (!this.isWorkflowOpen) {
1345
- this.selectedWorkflow = null;
1346
- this.openWorkflowInput = false;
1347
- }
1348
- this.cdr.detectChanges();
1349
- });
1350
- }
1351
- }
1352
- initializeForm() {
1353
- var _a, _b;
1354
- // Create form controls dynamically based on selectedWorkflow.Trigger.InputSchema
1355
- const formControls = {};
1356
- if ((_b = (_a = this.selectedWorkflow) === null || _a === void 0 ? void 0 : _a.Trigger) === null || _b === void 0 ? void 0 : _b.InputSchema) {
1357
- this.selectedWorkflow.Trigger.InputSchema.forEach((input) => {
1358
- formControls[input.InputId] = [
1359
- input.Value || '',
1360
- input.Required ? Validators.required : null,
1361
- ];
1362
- });
1363
- }
1364
- // Initialize the form
1365
- this.workflowForm = this.fb.group(formControls);
1366
- }
1367
- onWorkflowSelected(workflow) {
1368
- this.selectedWorkflow = workflow;
1369
- this.initializeForm();
1370
- this.isWorkflowOpen = false;
1371
- this.openWorkflowInput = true;
1372
- }
1373
- onWorkflowSubmit() {
1374
- const container = document.getElementById('allChats');
1375
- if (this.workflowForm.valid) {
1376
- console.log(this.workflowForm.value);
1377
- var input = this.prepareHtml(this.generateMarkdown(this.selectedWorkflow.Name, this.workflowForm.value));
1378
- // update last two chatLog entries, set showWorkflowExecutionLoader = false
1379
- try {
1380
- this.chatLog[this.chatLog.length - 1]['showWorkflowExecutionLoader'] = false;
1381
- this.chatLog[this.chatLog.length - 2]['showWorkflowExecutionLoader'] = false;
1382
- }
1383
- catch (error) { }
1384
- this.chatLog.push({
1385
- type: 'user',
1386
- message: input,
1387
- time: formatNow(this.timezone),
1388
- copied: false,
1389
- isCollapsedTrue: false,
1390
- showWorkflowExecutionLoader: true,
1391
- });
1392
- console.log(input);
1393
- this.currentWorkflowActionProgress = 0;
1394
- this.currentWorkflowAction =
1395
- 'Executing ' + this.selectedWorkflow.Actions[0].Name;
1396
- this.isChatingWithAi = true;
1397
- this.executingWorkflow = true;
1398
- this.workflowExecutionDetails = {
1399
- Actions: this.selectedWorkflow.Actions,
1400
- Inputs: this.workflowForm.value,
1401
- workflowInputs: this.workflowForm.value,
1402
- WorkflowName: this.selectedWorkflow.Name,
1403
- };
1404
- this.currentWorkflowExecutionDetails = this.workflowExecutionDetails;
1405
- this.scrollToBottom();
1406
- this.cdr.detectChanges();
1407
- // execute the ask endpoint with workflow input
1408
- this.makeAskRequest(input, this.agents, this.conversationKey, '', null, this.selectedWorkflow['_id'], this.workflowForm.value);
1409
- }
1410
- }
1411
- makeAskRequest(inputMsg, agents, conversationId, msg, chat, workflowId, workflow_inputs) {
1412
- var _a;
1413
- var url = `${this.environment.BASE_URL}/ai/ask`;
1414
- var body = {
1415
- user_question: inputMsg,
1416
- user_id: this.userId,
1417
- bot_id: this.botId,
1418
- message_id: this.conversationService.generateKey(),
1419
- agents: (_a = agents === null || agents === void 0 ? void 0 : agents.filter((p) => p.selected).map((p) => p.id)) !== null && _a !== void 0 ? _a : [],
1420
- conversation_id: conversationId,
1421
- };
1422
- if (workflowId) {
1423
- body['workflow_id'] = workflowId;
1424
- body['workflow_inputs'] = workflow_inputs;
1425
- }
1426
- fetch(url, {
1427
- method: 'POST',
1428
- headers: {
1429
- 'Content-Type': 'application/json',
1430
- Authorization: 'Bearer ' + this.s27Token,
1431
- 'x-api-key': this.apiKey,
1432
- 'hive-bot-id': this.botId
1433
- },
1434
- body: JSON.stringify(body),
1435
- })
1436
- .then((response) => {
1437
- if (response.status === 401 || response.status === 403) {
1438
- this.is401 = true;
1439
- this.refreshToken.emit();
1440
- // If `msg` and `chat` exist, handle them
1441
- if (msg && chat) {
1442
- this.msg = msg;
1443
- this.chat = chat;
1444
- this.isFetchDataFor = true;
1445
- }
1446
- }
1447
- else {
1448
- this.is401 = false;
1449
- }
1450
- return response.json();
1451
- })
1452
- .then((data) => {
1453
- console.log(data);
1454
- // Additional response handling if needed
1455
- })
1456
- .catch((err) => {
1457
- console.error('Error: ', err);
1458
- this.isChatingWithAi = false;
1459
- });
1460
- this.input = '';
1461
- this.selectedWorkflow = null;
1462
- this.openWorkflowInput = false;
1463
- this.isWorkflowOpen = false;
1464
- this.scrollToBottom();
1465
- this.cdr.markForCheck();
1466
- }
1467
- generateMarkdown(title, obj) {
1468
- var _a;
1469
- // Initialize markdown with the title
1470
- let markdown = `## ${title}\n`;
1471
- // Loop through the object and append the field names and values
1472
- for (const [key, value] of Object.entries(obj)) {
1473
- var key_label = ((_a = this.selectedWorkflow.Trigger.InputSchema.find((input) => input.InputId === key)) === null || _a === void 0 ? void 0 : _a.Label) || key;
1474
- markdown += `- **${key_label}**: ${value}\n`;
1475
- }
1476
- return markdown;
1477
- }
1478
- showWorkflowHistoryDetails(workflow_id) {
1479
- if (!workflow_id) {
1480
- this.workflowExecutionDetails = this.currentWorkflowExecutionDetails;
1481
- this.showWorkflowExecutionDetails = true;
1482
- this.cdr.detectChanges();
1483
- return;
1484
- }
1485
- this.botService.getWorkflowExecutionById(workflow_id).subscribe((res) => {
1486
- if (res && res.Actions && Array.isArray(res.Actions)) {
1487
- res.Actions = res.Actions.map((action) => {
1488
- if (action.InsertTimeStamp) {
1489
- action.InsertTimeStamp = formatTimeStamps(this.timezone, action.InsertTimeStamp);
1490
- }
1491
- return action;
1492
- });
1493
- }
1494
- res.InsertTimeStamp = formatTimeStamps(this.timezone, res.InsertTimeStamp);
1495
- this.workflowExecutionDetails = res;
1496
- this.showWorkflowExecutionDetails = true;
1497
- this.cdr.detectChanges();
1498
- });
1499
- }
1500
- closeModal() {
1501
- this.showWorkflowExecutionDetails = false;
1502
- }
1503
- objectToArray(obj) {
1504
- return Object.keys(obj).map((key) => ({ key, value: obj[key] }));
1505
- }
1506
- startNewConversation() {
1507
- this.conversationKey = this.conversationService.getKey(this.botId, true);
1508
- this.chatLog = [this.chatLog[0]];
1509
- this.isChatingWithAi = false;
1510
- setTimeout(() => {
1511
- this.initializeSocket();
1512
- }, 200);
1513
- this.scrollToBottom();
1514
- this.cdr.detectChanges();
1515
- }
1516
- initializeSpeechRecognizer(token) {
1517
- this.speechConfig = SpeechSDK.SpeechConfig.fromAuthorizationToken(token, this.region);
1518
- const audioConfig = SpeechSDK.AudioConfig.fromDefaultMicrophoneInput();
1519
- this.recognizer = new SpeechSDK.SpeechRecognizer(this.speechConfig, audioConfig);
1520
- this.recognizer.recognizing = (s, e) => {
1521
- if (e.result.reason === SpeechSDK.ResultReason.RecognizingSpeech) {
1522
- this.input = e.result.text;
1523
- console.log(`Recognizing: ${e.result.text}`);
1524
- this.cdr.markForCheck();
1525
- }
1526
- };
1527
- this.recognizer.recognized = (s, e) => {
1528
- if (e.result.reason === SpeechSDK.ResultReason.RecognizedSpeech) {
1529
- this.input = e.result.text;
1530
- console.log(`Recognized: ${e.result.text}`);
1531
- this.toggleRecording();
1532
- this.cdr.markForCheck();
1533
- }
1534
- };
1535
- this.recognizer.canceled = (s, e) => {
1536
- console.error('Canceled: ', e.errorDetails);
1537
- };
1538
- this.recognizer.sessionStopped = (s, e) => {
1539
- console.log('Session stopped.');
1540
- this.recognizer.stopContinuousRecognitionAsync();
1541
- this.fetchData();
1542
- };
1543
- }
1544
- toggleRecording() {
1545
- this.isRecording = !this.isRecording;
1546
- if (this.isRecording) {
1547
- this.startRecognition();
1548
- }
1549
- else {
1550
- this.stopRecognition();
1551
- }
1552
- }
1553
- startRecognition() {
1554
- this.recognizer.startContinuousRecognitionAsync();
1555
- }
1556
- stopRecognition() {
1557
- this.recognizer.stopContinuousRecognitionAsync();
1558
- }
1559
- checkForCop29BotId() {
1560
- return this.botId == '66fa3f276c5d71e2717bfea8';
1561
- }
1562
- }
1563
- ChatDrawerComponent.decorators = [
1564
- { type: Component, args: [{
1565
- selector: 'hivegpt-chat-drawer-package',
1566
- template: "<button *ngIf=\"isShowEditorButton && !checkForCop29BotId()\" (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 *ngIf=\"!checkForCop29BotId()\" xmlns=\"http://www.w3.org/2000/svg\" width=\"31.499\" height=\"31.501\"\r\n 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 *ngIf=\"!checkForCop29BotId()\">\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 *ngIf=\"!checkForCop29BotId()\" class=\"up copy\"\r\n title=\"{{ chat?.isEditor ? 'Added!' : 'Add to editor' }}\" (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\" *ngIf=\"!checkForCop29BotId()\">\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\">\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>",
1567
- changeDetection: ChangeDetectionStrategy.OnPush,
1568
- 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}.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:normal;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}"]
1569
- },] }
1570
- ];
1571
- ChatDrawerComponent.ctorParameters = () => [
1572
- { type: FormBuilder },
1573
- { type: BotsService },
1574
- { type: ChangeDetectorRef },
1575
- { type: HttpClient },
1576
- { type: DomSanitizer },
1577
- { type: ElementRef },
1578
- { type: Renderer2 },
1579
- { type: SocketService },
1580
- { type: ConversationService }
1581
- ];
1582
- ChatDrawerComponent.propDecorators = {
1583
- chatMain: [{ type: ViewChild, args: ['chatMain',] }],
1584
- myInput: [{ type: ViewChild, args: ['myInput',] }],
1585
- closePlaygroundButtons: [{ type: ViewChildren, args: ['closeplaygroundbutton',] }],
1586
- drawer: [{ type: ViewChild, args: ['drawer',] }],
1587
- sourcesDrawer: [{ type: ViewChild, args: ['sourcesDrawer',] }],
1588
- editorsDrawer: [{ type: ViewChild, args: ['editorsDrawer',] }],
1589
- myTextarea: [{ type: ViewChild, args: ['myTextarea', { static: false },] }],
1590
- copilotName: [{ type: Input }],
1591
- firstName: [{ type: Input }],
1592
- lastName: [{ type: Input }],
1593
- apiKey: [{ type: Input }],
1594
- bgBubbleAi: [{ type: Input }],
1595
- bgBubbleUser: [{ type: Input }],
1596
- bgGradient: [{ type: Input }],
1597
- botName: [{ type: Input }],
1598
- botSkills: [{ type: Input }],
1599
- botId: [{ type: Input }],
1600
- orgId: [{ type: Input }],
1601
- closeButtonColor: [{ type: Input }],
1602
- closeButtonbgColor: [{ type: Input }],
1603
- credentials: [{ type: Input }],
1604
- dateTimeColor: [{ type: Input }],
1605
- dateTextColor: [{ type: Input }],
1606
- eventId: [{ type: Input }],
1607
- s27Token: [{ type: Input }],
1608
- eventName: [{ type: Input }],
1609
- botIcon: [{ type: Input }],
1610
- formFieldBgColor: [{ type: Input }],
1611
- formFieldTextColor: [{ type: Input }],
1612
- fullView: [{ type: Input }],
1613
- gradientColors: [{ type: Input }],
1614
- greeting: [{ type: Input }],
1615
- messageTextColorAi: [{ type: Input }],
1616
- messageTextColorUser: [{ type: Input }],
1617
- rules: [{ type: Input }],
1618
- sendButtonColor: [{ type: Input }],
1619
- sendButtonTextColor: [{ type: Input }],
1620
- showClose: [{ type: Input }],
1621
- thumbsDownMessages: [{ type: Input }],
1622
- thumbsUpMessage: [{ type: Input }],
1623
- timezone: [{ type: Input }],
1624
- unknownResponses: [{ type: Input }],
1625
- useOpenAi: [{ type: Input }],
1626
- userId: [{ type: Input }],
1627
- isDev: [{ type: Input }],
1628
- againButtonColor: [{ type: Input }],
1629
- againButtonTextColor: [{ type: Input }],
1630
- feedbackEvent: [{ type: Output }],
1631
- onCloseEvent: [{ type: Output }],
1632
- openPage: [{ type: Output }],
1633
- sessionActions: [{ type: Output }],
1634
- closeBot: [{ type: Output }],
1635
- connectWithUser: [{ type: Output }],
1636
- scheduleMeeting: [{ type: Output }],
1637
- refreshToken: [{ type: Output }]
1638
- };
1639
- //# 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\nimport * as marked from 'marked';  // Import marked\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\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      'hive-bot-id': this.botId\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 headers = new HttpHeaders({\r\n      'x-api-key': this.apiKey,\r\n      'hive-bot-id': this.botId\r\n    });\r\n    const url = `${this.environment.BASE_URL}/bots?bot_id=${this.botId}`;\r\n    return this.http.get(url, { headers }).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;'><a href='mailto:support@social27.com' style='color: inherit; text-decoration: none;'>Please click here</a></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      'x-api-key': this.apiKey,\r\n      'hive-bot-id': this.botId\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            _id: chat._id\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            _id: chat._id\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          'hive-bot-id': this.botId\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, message) {\r\n    console.log(message);\r\n\r\n    this.feedbackDone = true;\r\n    this.showFeedBackIconsIndex = null;\r\n    const conversation_id = this.conversationService.getKey(this.botId);\r\n    const url = `${this.environment.AGENTS_API}/Conversation/coPilot/${this.botId}/conversation/${conversation_id}/helpful-response`;\r\n    fetch(url, {\r\n      method: 'POST',\r\n      headers: {\r\n        'Content-Type': 'application/json',\r\n        'apiKey': 'Conversation_WIz/qAm+EEmfOkFaUA/weA==',\r\n        'hive-bot-id': this.botId\r\n      },\r\n      body: JSON.stringify({ messageId: message._id, isHelpful: flag }),\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, this.chatLog[idx]);\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, this.chatLog[idx]);\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    if (!this.agents)\r\n      this.fetchAgents();\r\n    this.isDropdownOpen = !this.isDropdownOpen;\r\n    this.cdr.detectChanges();\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) {\r\n      return 'All Agents';\r\n    } else {\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  }\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    try {\r\n      // Parse the markdown content to HTML using marked\r\n      const markdownContent = marked.parse(markdown);\r\n\r\n      // Sanitize the parsed HTML using Angular's DomSanitizer\r\n      // const sanitizedHtml = this.sanitizer.bypassSecurityTrustHtml(markdownContent);\r\n\r\n      // Return the safe HTML content for display\r\n      return markdownContent;\r\n\r\n    } catch (error) {\r\n      console.error('Error processing markdown:', error);\r\n      return ''; // Return an empty string or handle the error appropriately\r\n    }\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\r\n    if (!this.checkForCop29BotId()) {\r\n      this.botService.getWorkflowsByOrgId(this.orgId).subscribe((res) => {\r\n        this.orgWorkflows = res;\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\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        'hive-bot-id': this.botId\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
+ import * as marked from 'marked'; // Import marked
15
+ export class ChatDrawerComponent {
16
+ constructor(fb, botService, cdr, http, sanitizer, elementRef, renderer, socketService, conversationService // private platform: Platform
17
+ ) {
18
+ this.fb = fb;
19
+ this.botService = botService;
20
+ this.cdr = cdr;
21
+ this.http = http;
22
+ this.sanitizer = sanitizer;
23
+ this.elementRef = elementRef;
24
+ this.renderer = renderer;
25
+ this.socketService = socketService;
26
+ this.conversationService = conversationService;
27
+ this.bodyOverflowClass = 'body-overflow-hidden';
28
+ this.isCollapsedTrue = false;
29
+ this.copilotName = 'HiveXGPT';
30
+ this.feedbackEvent = new EventEmitter();
31
+ this.onCloseEvent = new EventEmitter();
32
+ this.openPage = new EventEmitter();
33
+ this.sessionActions = new EventEmitter();
34
+ this.closeBot = new EventEmitter();
35
+ this.connectWithUser = new EventEmitter();
36
+ this.scheduleMeeting = new EventEmitter();
37
+ this.refreshToken = new EventEmitter();
38
+ this.autogenKey = 'Autogen_eDJTtEU-NB0RtIpzq1w';
39
+ this.addToMyAgendaAction = 'add_to_my_agenda';
40
+ this.myUpcomingSessionAction = 'my_upcomming_session';
41
+ this.connectOrFollowAction = 'connect_or_follow';
42
+ this.aiResponse = '';
43
+ this.chatLog = [];
44
+ this.decoder = new TextDecoder();
45
+ this.feedbackDone = false;
46
+ this.greetingMsg = '';
47
+ this.hasBackdropValue = false;
48
+ this.input = '';
49
+ this.listenerAdded = false;
50
+ this.loading = false;
51
+ this.mode = 'over';
52
+ this.quickPrompts = [];
53
+ this.thumbsDownMsgIndex = 0;
54
+ this.userName = '';
55
+ this.showStartAgain = false;
56
+ this.isIOSDevice = false;
57
+ this.showFeedBackIconsIndex = null;
58
+ this.temperature = 1;
59
+ this.speakers = [];
60
+ this.currentWorkflowActionProgress = 0;
61
+ this.currentWorkflowAction = '';
62
+ this.recognizedText = '';
63
+ this.authorizationToken = '';
64
+ this.region = 'westeurope'; // Set your Azure region here
65
+ this.isChatingWithAi = false;
66
+ this.readAllChunks = (stream) => {
67
+ const reader = stream.getReader();
68
+ const allSuggestions = [];
69
+ reader.closed.catch((err) => {
70
+ if (err) {
71
+ console.error('Error reading stream: ', err);
72
+ }
73
+ this.isChatingWithAi = false;
74
+ this.scrollToBottom();
75
+ return;
76
+ });
77
+ return new ReadableStream({
78
+ start: (controller) => {
79
+ return this.pump(controller, reader, allSuggestions);
80
+ },
81
+ });
82
+ };
83
+ this.currentMessageForEditor = '';
84
+ this.currentIndexForEditor = -1;
85
+ this.isDropdownOpen = false;
86
+ this.selectedAgents = [];
87
+ this.allSelected = false;
88
+ this.isDocInEditMode = false;
89
+ this.isContentLoaded = false;
90
+ this.isCollapsed = false;
91
+ this.isCollapsedForGraph = false;
92
+ this.isCollapsedForFGraph = false;
93
+ // [
94
+ // {
95
+ // "title": "AI News January 2024: In-Depth and Concise - The AI Track",
96
+ // "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.",
97
+ // "link": "https://theaitrack.com/ai-news-january-2024/"
98
+ // },
99
+ // {
100
+ // "title": "Top AI News, January 2024 - Everypixel Journal",
101
+ // "desc": "In this monthly roundup, we spotlight the top AI news stories from January, including the OpenAI vs. The New York Times Lawsuit.",
102
+ // "link": "https://journal.everypixel.com/top-ai-news-january-2024"
103
+ // },
104
+ // {
105
+ // "title": "AI News July 2024: In-Depth and Concise - The AI Track",
106
+ // "desc": "This page features AI News for July 2024, highlighting significant events such as Canva acquiring Leonardo AI.",
107
+ // "link": "https://theaitrack.com/ai-news-july-2024-in-depth-and-concise/"
108
+ // },
109
+ // {
110
+ // "title": "January news roundup: What's new in the world of AI? - Pluralsight",
111
+ // "desc": "OpenAI’s new GPT store, business-ready ChatGPT plans, and a predicted rise in AI-powered cybercrime.",
112
+ // "link": "https://www.pluralsight.com/resources/blog/data/ai-this-month-january-2024"
113
+ // },
114
+ // {
115
+ // "title": "AI News August 2024: In-Depth and Concise - The AI Track",
116
+ // "desc": "This page features AI News for August 2024, with highlights such as Nvidia delaying the “Blackwell” B200 AI chips delivery.",
117
+ // "link": "https://theaitrack.com/ai-news-august-2024-in-depth-and-concise-duplicate/"
118
+ // }
119
+ // ]
120
+ this.dateTime = { now: new Date().toISOString() };
121
+ this.currentSourcesList = [];
122
+ this.isShowEditorButton = true;
123
+ this.isDrawerOpen = true;
124
+ this.chatMain = new ElementRef(null);
125
+ // if (this.platform.IOS) {
126
+ // this.isIOSDevice = true;
127
+ // }
128
+ }
129
+ ngOnChanges(changes) {
130
+ if (changes.s27Token) {
131
+ if (changes.s27Token.currentValue != changes.s27Token.previousValue) {
132
+ this.s27Token = changes.s27Token.currentValue;
133
+ console.log('isFetchDataFor: ', this.isFetchDataFor);
134
+ console.log('msg: ', this.msg);
135
+ console.log('chat: ', this.chat);
136
+ if (this.is401) {
137
+ if (this.isFetchDataFor) {
138
+ this.fetchDataFor(this.msg, this.chat);
139
+ }
140
+ else {
141
+ this.fetchData(this.msg);
142
+ }
143
+ }
144
+ }
145
+ }
146
+ if (changes.orgId) {
147
+ if (changes.orgId.currentValue != changes.orgId.previousValue &&
148
+ changes.orgId.currentValue) {
149
+ this.initializeSocket();
150
+ }
151
+ }
152
+ }
153
+ ngOnInit() {
154
+ this.environment = this.isDev ? dev_environment : prod_environment;
155
+ // this.fetchMyConnections().subscribe();
156
+ // this.fetchPendingRequests().subscribe();
157
+ this.changeTemperature(this.temperature);
158
+ this.fetchBotConfig().subscribe((res) => {
159
+ this.cdr.markForCheck();
160
+ this.fetchChatHistory().subscribe((response) => {
161
+ this.loading = false;
162
+ this.mapChatHistory(response);
163
+ this.cdr.markForCheck();
164
+ }, (err) => {
165
+ console.error('Error fetching chat history:', err);
166
+ });
167
+ }, (err) => {
168
+ console.error('Error fetching chat history:', err);
169
+ });
170
+ // this.fetchAgents();
171
+ // this.fetchEditorContent();
172
+ this.cdr.markForCheck();
173
+ // this.initializeSocket();
174
+ this.botService.fetchSpeechAuthorizationToken(this.botId, this.apiKey).subscribe((token) => {
175
+ this.authorizationToken = token;
176
+ this.initializeSpeechRecognizer(token);
177
+ });
178
+ }
179
+ initializeSocket() {
180
+ try {
181
+ this.socketService.disconnectSocketConnection();
182
+ }
183
+ catch (error) { }
184
+ setTimeout(() => {
185
+ this.socketService.connectSocketConnection();
186
+ setTimeout(() => {
187
+ console.log('YES INIT');
188
+ const conversation_id = this.conversationService.getKey(this.botId);
189
+ this.socketService.registerUserSpecificHiveSocket(this.botId, conversation_id, this.orgId);
190
+ setTimeout(() => {
191
+ this.listenSockets();
192
+ }, 300);
193
+ }, 200);
194
+ }, 300);
195
+ }
196
+ listenSockets() {
197
+ if (this.eventSubscription) {
198
+ this.eventSubscription.unsubscribe();
199
+ }
200
+ console.log('Listen Socket');
201
+ this.eventSubscription = this.conversationService
202
+ .getUserSpecificNotification()
203
+ .subscribe((res) => {
204
+ var _a, _b, _c, _d, _e, _f;
205
+ console.log('Listen Socket response');
206
+ console.log(res);
207
+ // Check if OtherFields exists in the response
208
+ 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) {
209
+ 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;
210
+ this.currentWorkflowActionProgress = percentage;
211
+ this.currentWorkflowAction = action_name;
212
+ const actionIndex = this.workflowExecutionDetails.Actions.findIndex((a) => a.Name == current_action_name);
213
+ if (actionIndex !== -1) {
214
+ this.workflowExecutionDetails.Actions[actionIndex]['Output'] = output;
215
+ this.workflowExecutionDetails.Actions[actionIndex]['InsertTimeStamp'] = formatTimeStamps(this.timezone, time_stamp);
216
+ }
217
+ else {
218
+ console.error(`Action with name ${action_name} not found`);
219
+ }
220
+ this.currentWorkflowExecutionDetails = this.workflowExecutionDetails;
221
+ if (this.currentWorkflowActionProgress == 100) {
222
+ this.chatLog[this.chatLog.length - 1]['WorkflowExecutionId'] = workflow_execution_id;
223
+ this.isChatingWithAi = false;
224
+ this.executingWorkflow = false;
225
+ }
226
+ this.cdr.detectChanges();
227
+ }
228
+ else if ((_d = res === null || res === void 0 ? void 0 : res.m) === null || _d === void 0 ? void 0 : _d.OtherFields) {
229
+ 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;
230
+ console.log('message_id1');
231
+ console.log((_f = res === null || res === void 0 ? void 0 : res.m) === null || _f === void 0 ? void 0 : _f.OtherFields);
232
+ var currentChatMessage = this.chatLog.find((p) => p._id == message_id);
233
+ console.log(this.chatLog);
234
+ if (!currentChatMessage) {
235
+ console.log('message_id2');
236
+ console.log(message_id);
237
+ currentChatMessage = {
238
+ _id: message_id,
239
+ type: 'ai',
240
+ time: formatNow(this.timezone),
241
+ };
242
+ this.chatLog.push(currentChatMessage);
243
+ this.showFeedBackIconsIndex = this.chatLog.length - 1;
244
+ console.log('message_id3');
245
+ console.log(message_id);
246
+ this.cdr.detectChanges();
247
+ }
248
+ // Handle the fields based on their presence
249
+ if (search_results && Array.isArray(search_results)) {
250
+ console.log('Online Search Terms:', search_results);
251
+ currentChatMessage.searchTerms = search_results;
252
+ this.cdr.detectChanges();
253
+ }
254
+ if (web_results && Array.isArray(web_results)) {
255
+ console.log('Web Results:', web_results);
256
+ currentChatMessage.sourcesList = web_results;
257
+ currentChatMessage.displayedSources = web_results === null || web_results === void 0 ? void 0 : web_results.slice(0, 3); // First 3 cards
258
+ currentChatMessage.remainingSources = web_results === null || web_results === void 0 ? void 0 : web_results.slice(3); // Remaining items
259
+ this.cdr.detectChanges();
260
+ }
261
+ if (answer) {
262
+ this.isChatingWithAi = false;
263
+ console.log('Answer:', answer);
264
+ currentChatMessage.message = this.processMessageForDisplay(answer);
265
+ this.cdr.detectChanges();
266
+ this.scrollToBottom();
267
+ }
268
+ if (graphs && Array.isArray(graphs)) {
269
+ console.log('Graphs:', graphs);
270
+ currentChatMessage.graphs = graphs;
271
+ this.cdr.detectChanges();
272
+ }
273
+ if (execution_graphs && Array.isArray(execution_graphs)) {
274
+ console.log('Execution Graphs:', execution_graphs);
275
+ currentChatMessage.executionGraphs = execution_graphs;
276
+ this.cdr.detectChanges();
277
+ }
278
+ if (suggestions && Array.isArray(suggestions)) {
279
+ console.log('suggestions:', suggestions);
280
+ currentChatMessage.relatedListItems = suggestions;
281
+ this.cdr.detectChanges();
282
+ // Process online search terms as needed
283
+ }
284
+ // Add any other fields and their processing here
285
+ }
286
+ else {
287
+ console.warn('OtherFields is missing in the response');
288
+ }
289
+ }, (err) => {
290
+ this.eventSubscription.unsubscribe();
291
+ console.error('Error in fetching data from socket', err);
292
+ });
293
+ }
294
+ initializeSocketAndListen() { }
295
+ handleEvent(data, type) {
296
+ switch (type) {
297
+ case 'webresult':
298
+ break;
299
+ case 'answer':
300
+ break;
301
+ case 'graph':
302
+ break;
303
+ default:
304
+ break;
305
+ }
306
+ }
307
+ ngOnDestroy() {
308
+ if (this.eventSubscription) {
309
+ this.eventSubscription.unsubscribe();
310
+ }
311
+ this.socketService.disconnectSocketConnection();
312
+ //this.socketService.close();
313
+ }
314
+ changeTemperature(newTemperature) {
315
+ if (this.loading)
316
+ return;
317
+ this.temperature = newTemperature;
318
+ const wrapper = document.querySelector('.hivegpt-chat-wrapper');
319
+ // Remove existing theme classes from body
320
+ wrapper === null || wrapper === void 0 ? void 0 : wrapper.classList.remove('creative', 'balanced', 'precise');
321
+ switch (newTemperature) {
322
+ case 0:
323
+ wrapper === null || wrapper === void 0 ? void 0 : wrapper.classList.add('creative');
324
+ break;
325
+ case 1:
326
+ wrapper === null || wrapper === void 0 ? void 0 : wrapper.classList.add('balanced');
327
+ break;
328
+ case 2:
329
+ wrapper === null || wrapper === void 0 ? void 0 : wrapper.classList.add('precise');
330
+ break;
331
+ default:
332
+ break;
333
+ }
334
+ }
335
+ onStartAgain() {
336
+ if (this.loading)
337
+ return;
338
+ this.showStartAgain = false;
339
+ this.chatLog = [];
340
+ this.chatLog.push({
341
+ type: 'ai',
342
+ message: this.greetingMsg,
343
+ time: formatNow(this.timezone),
344
+ });
345
+ this.archieveMessages().subscribe();
346
+ }
347
+ archieveMessages() {
348
+ const headers = new HttpHeaders({
349
+ 'Content-Type': 'application/json',
350
+ 'x-api-key': this.apiKey,
351
+ 'hive-bot-id': this.botId
352
+ });
353
+ const url = `${this.environment.BASE_URL}/bot/clear-history/${this.botId}/${this.userId}`;
354
+ return this.http.post(url, { headers }).pipe(switchMap((res) => {
355
+ return of(res);
356
+ }), catchError((error) => {
357
+ return of(null);
358
+ }));
359
+ }
360
+ fetchBotConfig() {
361
+ this.loading = true;
362
+ const headers = new HttpHeaders({
363
+ 'x-api-key': this.apiKey,
364
+ 'hive-bot-id': this.botId
365
+ });
366
+ const url = `${this.environment.BASE_URL}/bots?bot_id=${this.botId}`;
367
+ return this.http.get(url, { headers }).pipe(switchMap((res) => {
368
+ var _a;
369
+ this.botName = res.Name;
370
+ this.botIcon = res.Icon;
371
+ this.botSkills = res === null || res === void 0 ? void 0 : res.Skills;
372
+ this.greetingMsg = res.Greeting;
373
+ this.thumbsDownMessages = ((_a = res === null || res === void 0 ? void 0 : res.NegativeResponses) === null || _a === void 0 ? void 0 : _a.length) ? res.NegativeResponses
374
+ : [
375
+ "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;'><a href='mailto:support@social27.com' style='color: inherit; text-decoration: none;'>Please click here</a></span> and a human agent will assist you as soon as possible",
376
+ ];
377
+ this.quickPrompts = res.QuickPrompts;
378
+ this.cdr.markForCheck();
379
+ this.loading = false;
380
+ return of(res);
381
+ }), catchError((error) => {
382
+ console.error('Error fetching chatbot config: ', error);
383
+ this.loading = false;
384
+ return of(null);
385
+ }));
386
+ }
387
+ fetchChatHistory() {
388
+ this.loading = true;
389
+ this.conversationKey = this.conversationService.getKey(this.botId, false);
390
+ const url = `${this.environment.BASE_URL}/conversations/${this.conversationKey}`;
391
+ const headers = new HttpHeaders({
392
+ accept: 'application/json',
393
+ 'x-api-key': this.apiKey,
394
+ 'hive-bot-id': this.botId
395
+ });
396
+ return this.http
397
+ .get(url, { headers })
398
+ .pipe(catchError(this.handleError('fetchConversation')));
399
+ }
400
+ handleError(operation = 'operation', result) {
401
+ return (error) => {
402
+ console.error(`${operation} failed: ${error.message}`);
403
+ return of(result);
404
+ };
405
+ }
406
+ // fetchChatHistory() {
407
+ // this.loading = true;
408
+ // const headers = new HttpHeaders({
409
+ // 'Content-Type': 'application/json',
410
+ // 'x-api-key': this.apiKey,
411
+ // });
412
+ // return this.http
413
+ // .get(`${this.environment.BASE_URL}/conversations/${this.conversationKey}`, { headers })
414
+ // .pipe(
415
+ // switchMap((res: any) => {
416
+ // this.loading = false;
417
+ // return of(res);
418
+ // }),
419
+ // catchError((error: any) => {
420
+ // console.error('Error fetching chat history: ', error);
421
+ // this.loading = false;
422
+ // return of(null);
423
+ // })
424
+ // );
425
+ // }
426
+ mapChatHistory(chats) {
427
+ var _a;
428
+ this.chatLog.push({
429
+ type: 'ai',
430
+ message: this.greetingMsg,
431
+ time: formatNow(this.timezone),
432
+ });
433
+ if (chats && ((_a = chats === null || chats === void 0 ? void 0 : chats.Messages) === null || _a === void 0 ? void 0 : _a.length)) {
434
+ chats === null || chats === void 0 ? void 0 : chats.Messages.forEach((chat) => {
435
+ if (chat.Type == 'user') {
436
+ this.chatLog.push({
437
+ type: 'user',
438
+ message: this.processMessageForDisplay(chat.Text),
439
+ time: formatTimeStamps(this.timezone, chat.InsertTimestamp),
440
+ copied: false,
441
+ isCollapsedTrue: false,
442
+ WorkflowExecutionId: chat.WorkflowExecutionId,
443
+ _id: chat._id
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
+ _id: chat._id
463
+ });
464
+ this.showFeedBackIconsIndex = this.chatLog.length - 1;
465
+ }
466
+ });
467
+ this.showStartAgain = true;
468
+ }
469
+ this.scrollToBottom();
470
+ this.cdr.markForCheck();
471
+ }
472
+ processMessage(message) {
473
+ if (!message || !((message === null || message === void 0 ? void 0 : message.length) > 0)) {
474
+ return '';
475
+ }
476
+ // console.log('here is my message')
477
+ // console.log(message);
478
+ message = message.trim();
479
+ const markdownLinkRegex = /\[([^[]+)]\(([^)]+)\)/g;
480
+ const urlRegex = /(?<!href=")\bhttps?:\/\/\S+(?<![.,])/gi;
481
+ if (markdownLinkRegex.test(message)) {
482
+ const html = message.replace(markdownLinkRegex, '<a href="$2" target="_blank">$1</a>');
483
+ //console.log('Sanitized message: ', message);
484
+ return this.sanitizeHtml(html);
485
+ }
486
+ if (urlRegex.test(message)) {
487
+ const html = message.replace(urlRegex, '<a href="$&" target="_blank">$&</a>');
488
+ // console.log('Sanitized message: ', message);
489
+ return this.sanitizeHtml(html);
490
+ }
491
+ message = message.replace(/(?:\r\n|\r|\n)/g, '<br>');
492
+ message = message.replace(/\*\*(.*?)\*\*/g, '<strong>$1</strong>');
493
+ // Convert Markdown headers to HTML headers
494
+ message = message.replace(/^(#{1,6})\s+(.*)$/gm, (match, hashes, text) => {
495
+ const level = hashes.length;
496
+ return `<h${level}>${text}</h${level}>`;
497
+ });
498
+ this.cdr.markForCheck();
499
+ const sanitizedMessage = this.sanitizeHtml(message);
500
+ return sanitizedMessage;
501
+ }
502
+ ngAfterViewChecked() {
503
+ const feedbackLinks = this.elementRef.nativeElement.querySelectorAll('.feedback-link');
504
+ feedbackLinks.forEach((link) => {
505
+ link.addEventListener('click', this.onFeedbackClick.bind(this, 'zendesk'));
506
+ });
507
+ // if (this.elementRef.nativeElement.querySelector('.feedback-link')) {
508
+ // this.elementRef.nativeElement
509
+ // .querySelector('.feedback-link')
510
+ // .addEventListener('click', this.onFeedbackClick.bind(this, 'zendesk'));
511
+ // }
512
+ }
513
+ sanitizeHtml(html) {
514
+ return this.sanitizer.bypassSecurityTrustHtml(html);
515
+ }
516
+ onFeedbackClick(value) {
517
+ this.feedbackEvent.emit(value);
518
+ }
519
+ onClose() {
520
+ this.renderer.removeClass(document.body, this.bodyOverflowClass);
521
+ this.onCloseEvent.emit();
522
+ }
523
+ sendMessageWithTile(prompt) {
524
+ this.input = prompt;
525
+ this.fetchData();
526
+ this.scrollToBottom();
527
+ }
528
+ fetchData(msg = null) {
529
+ var _a;
530
+ this.input = msg || ((_a = this.input) === null || _a === void 0 ? void 0 : _a.trim());
531
+ this.msg = this.input;
532
+ if (!this.input || this.loading) {
533
+ return;
534
+ }
535
+ this.chatLog.push({
536
+ type: 'user',
537
+ message: this.processMessageForDisplay(this.input),
538
+ time: formatNow(this.timezone),
539
+ copied: false,
540
+ isCollapsedTrue: false,
541
+ });
542
+ try {
543
+ const textarea = this.myInput.nativeElement;
544
+ textarea.style.height = 'hidden'; // Reset the height
545
+ textarea.style.height = `62px`;
546
+ }
547
+ catch (error) { }
548
+ this.cdr.markForCheck();
549
+ this.aiResponse = '';
550
+ this.isChatingWithAi = true;
551
+ this.makeAskRequest(this.input, this.agents, this.conversationKey);
552
+ }
553
+ fetchDataFor(msg, chat) {
554
+ const inputMsg = msg === null || msg === void 0 ? void 0 : msg.trim();
555
+ if (!inputMsg || this.loading) {
556
+ return;
557
+ }
558
+ try {
559
+ chat.relatedListItems = [];
560
+ this.cdr.detectChanges();
561
+ }
562
+ catch (error) { }
563
+ this.scrollToBottom();
564
+ this.chatLog.push({
565
+ type: 'user',
566
+ message: this.processMessageForDisplay(inputMsg),
567
+ time: formatNow(this.timezone),
568
+ copied: false,
569
+ isCollapsedTrue: false,
570
+ });
571
+ this.cdr.markForCheck();
572
+ this.aiResponse = '';
573
+ this.isChatingWithAi = true;
574
+ this.makeAskRequest(inputMsg, this.agents, this.conversationKey, msg, chat);
575
+ }
576
+ fetchSmallTalk() {
577
+ this.loading = true;
578
+ this.cdr.markForCheck();
579
+ const url = `${this.environment.BASE_URL}/bot/small-talk/${this.botId}/${this.userId}`;
580
+ this.http
581
+ .get(url, {
582
+ headers: {
583
+ 'x-api-key': this.apiKey,
584
+ 'hive-bot-id': this.botId
585
+ },
586
+ })
587
+ .pipe(catchError((error) => {
588
+ console.error('Error while fetching small talk:', error);
589
+ return of(null);
590
+ }))
591
+ .subscribe((response) => {
592
+ this.loading = false;
593
+ this.cdr.markForCheck();
594
+ if (!response) {
595
+ return;
596
+ }
597
+ if (response && response.smallTalk) {
598
+ this.chatLog.push({
599
+ type: 'ai',
600
+ message: this.processMessage(response.smallTalk),
601
+ time: formatNow(this.timezone),
602
+ isFeedbackMsg: true,
603
+ });
604
+ this.showFeedBackIconsIndex = this.chatLog.length - 2;
605
+ // this.scrollToBottom();
606
+ this.cdr.markForCheck();
607
+ }
608
+ });
609
+ }
610
+ pump(controller, reader, allSuggestions) {
611
+ reader.read().then(({ done, value }) => {
612
+ var _a, _b, _c, _d;
613
+ const lastItem = this.chatLog[this.chatLog.length - 1];
614
+ if (done) {
615
+ lastItem.message = this.processMessageForDisplay(lastItem.message);
616
+ this.chatLog.pop();
617
+ this.chatLog.push(lastItem);
618
+ if (allSuggestions === null || allSuggestions === void 0 ? void 0 : allSuggestions.length) {
619
+ this.chatLog.push({
620
+ type: 'suggestions',
621
+ suggestions: allSuggestions,
622
+ });
623
+ }
624
+ controller.close();
625
+ this.isChatingWithAi = false;
626
+ // this.scrollToBottom();
627
+ this.cdr.markForCheck();
628
+ this.showStartAgain = true;
629
+ // setTimeout(() => {
630
+ // this.fetchSmallTalk();
631
+ // },1000)
632
+ return;
633
+ }
634
+ let decodedChunk = this.decoder.decode(value, { stream: true });
635
+ this.aiResponse += decodedChunk;
636
+ if (lastItem.type === 'ai') {
637
+ const suggestionsMatch = this.aiResponse.match(/<sug>(.*?)<\/sug>/g);
638
+ if (suggestionsMatch) {
639
+ suggestionsMatch.forEach((match) => {
640
+ this.aiResponse = this.aiResponse.replace(match, '');
641
+ allSuggestions.push(match === null || match === void 0 ? void 0 : match.replace(/<\/?sug>/g, ''));
642
+ });
643
+ }
644
+ lastItem.message = this.aiResponse;
645
+ this.cdr.markForCheck();
646
+ }
647
+ else {
648
+ this.isChatingWithAi = false;
649
+ let aiFormattedData;
650
+ try {
651
+ console.log('parsing json ');
652
+ aiFormattedData = JSON.parse(JSON.parse(this.aiResponse));
653
+ }
654
+ catch (e) {
655
+ try {
656
+ console.log('parsing json 2');
657
+ aiFormattedData = JSON.parse(this.aiResponse);
658
+ }
659
+ catch (e) { }
660
+ }
661
+ console.log('parsing json done');
662
+ if (aiFormattedData && ((_a = aiFormattedData === null || aiFormattedData === void 0 ? void 0 : aiFormattedData.section_id) === null || _a === void 0 ? void 0 : _a.length) > 0) {
663
+ if (aiFormattedData.section_id == 'company_search' ||
664
+ aiFormattedData.section_id == 'user_search' ||
665
+ aiFormattedData.section_id == 'industry_company_search') {
666
+ this.fetchMyConnections().subscribe();
667
+ this.fetchPendingRequests().subscribe();
668
+ }
669
+ if (aiFormattedData.section_id == this.myUpcomingSessionAction) {
670
+ var speakerIds = [];
671
+ (_b = aiFormattedData.content) === null || _b === void 0 ? void 0 : _b.forEach((session) => {
672
+ speakerIds = [...speakerIds, ...session.speakers];
673
+ });
674
+ if ((speakerIds === null || speakerIds === void 0 ? void 0 : speakerIds.length) > 0)
675
+ this.getSpeakersByStaffIds(speakerIds);
676
+ }
677
+ if (aiFormattedData.section_id == this.addToMyAgendaAction &&
678
+ ((_c = aiFormattedData.content) === null || _c === void 0 ? void 0 : _c.length) > 0) {
679
+ this.openPage.next({
680
+ sectionId: aiFormattedData.section_id,
681
+ sessionIds: aiFormattedData.content,
682
+ });
683
+ }
684
+ if (aiFormattedData.section_id == this.connectOrFollowAction) {
685
+ let usersLen = (_d = aiFormattedData.content) === null || _d === void 0 ? void 0 : _d.length;
686
+ if (usersLen > 1) {
687
+ this.openPage.next({
688
+ sectionId: 'open_networking_drawer',
689
+ search: aiFormattedData.content,
690
+ });
691
+ }
692
+ else if (usersLen == 1) {
693
+ this.openPage.next({
694
+ sectionId: aiFormattedData.section_id,
695
+ connetUserIds: [aiFormattedData.content[0].userId],
696
+ });
697
+ }
698
+ }
699
+ if (aiFormattedData.is_open_page == 'true') {
700
+ this.openPage.next({
701
+ sectionId: aiFormattedData.section_id,
702
+ search: aiFormattedData.content,
703
+ });
704
+ if (this.isMobileBrowser()) {
705
+ aiFormattedData.message +=
706
+ '\n\n' + '<a id="closeBotNow">Click Here</a> to see results.';
707
+ }
708
+ }
709
+ this.chatLog.push({
710
+ type: 'ai',
711
+ message: aiFormattedData.message,
712
+ action: aiFormattedData,
713
+ time: formatNow(this.timezone),
714
+ });
715
+ if (this.isMobileBrowser()) {
716
+ setTimeout(() => {
717
+ this.addCloseBotClickEvent();
718
+ }, 500);
719
+ }
720
+ this.aiResponse = '';
721
+ }
722
+ else {
723
+ this.chatLog.push({
724
+ type: 'ai',
725
+ message: this.aiResponse,
726
+ time: formatNow(this.timezone),
727
+ });
728
+ }
729
+ this.showFeedBackIconsIndex = this.chatLog.length - 1;
730
+ this.cdr.markForCheck();
731
+ }
732
+ this.scrollToBottom();
733
+ // Enqueue the next data chunk into our target stream
734
+ controller.enqueue(value);
735
+ this.pump(controller, reader, allSuggestions);
736
+ });
737
+ }
738
+ submitFeedback(flag, message) {
739
+ console.log(message);
740
+ this.feedbackDone = true;
741
+ this.showFeedBackIconsIndex = null;
742
+ const conversation_id = this.conversationService.getKey(this.botId);
743
+ const url = `${this.environment.AGENTS_API}/Conversation/coPilot/${this.botId}/conversation/${conversation_id}/helpful-response`;
744
+ fetch(url, {
745
+ method: 'POST',
746
+ headers: {
747
+ 'Content-Type': 'application/json',
748
+ 'apiKey': 'Conversation_WIz/qAm+EEmfOkFaUA/weA==',
749
+ 'hive-bot-id': this.botId
750
+ },
751
+ body: JSON.stringify({ messageId: message._id, isHelpful: flag }),
752
+ }).then(() => {
753
+ if (flag) {
754
+ this.chatLog.push({
755
+ type: 'ai',
756
+ message: this.thumbsUpMessage ||
757
+ `Great. May I assist you with anything else?`,
758
+ time: formatNow(this.timezone),
759
+ isFeedbackMsg: true,
760
+ });
761
+ this.scrollToBottom();
762
+ this.cdr.markForCheck();
763
+ this.feedbackDone = false;
764
+ this.showFeedBackIconsIndex = null;
765
+ return;
766
+ }
767
+ this.chatLog.push({
768
+ type: 'ai',
769
+ message: this.processMessage(this.thumbsDownMessages[this.thumbsDownMsgIndex]),
770
+ time: formatNow(this.timezone),
771
+ isFeedbackMsg: true,
772
+ });
773
+ this.thumbsDownMsgIndex =
774
+ (this.thumbsDownMsgIndex + 1) % this.thumbsDownMessages.length;
775
+ this.scrollToBottom();
776
+ this.cdr.markForCheck();
777
+ this.feedbackDone = false;
778
+ this.showFeedBackIconsIndex = null;
779
+ });
780
+ }
781
+ handleKeydown(event) {
782
+ if (event.key === 'Enter' && !event.shiftKey) {
783
+ // Prevent default behavior (new line)
784
+ event.preventDefault();
785
+ // Call your submit function
786
+ this.handleSubmit(event);
787
+ }
788
+ }
789
+ handleSubmit(event) {
790
+ this.fetchData();
791
+ this.scrollToBottom();
792
+ }
793
+ handleUpClick(idx) {
794
+ if (this.feedbackDone) {
795
+ return;
796
+ }
797
+ this.submitFeedback(true, this.chatLog[idx]);
798
+ this.chatLog[idx].liked = !this.chatLog[idx].liked;
799
+ if (this.chatLog[idx].unliked) {
800
+ this.chatLog[idx].unliked = !this.chatLog[idx].unliked;
801
+ }
802
+ this.cdr.markForCheck();
803
+ }
804
+ handleDownClick(idx) {
805
+ if (this.feedbackDone)
806
+ return;
807
+ this.submitFeedback(false, this.chatLog[idx]);
808
+ this.chatLog[idx].unliked = !this.chatLog[idx].unliked;
809
+ if (this.chatLog[idx].liked)
810
+ this.chatLog[idx].liked = !this.chatLog[idx].liked;
811
+ }
812
+ // handleCopyClick(index: any) {
813
+ // // Copy the message to the clipboard
814
+ // const contentToCopy = this.chatLog[index].message;
815
+ // console.log('contentToCopy');
816
+ // console.log(contentToCopy);
817
+ // navigator.clipboard.writeText(contentToCopy).then(() => {
818
+ // // Indicate that the message was copied
819
+ // this.chatLog[index].copied = true;
820
+ // this.cdr.detectChanges();
821
+ // // Reset the copied state after a delay
822
+ // setTimeout(() => {
823
+ // this.chatLog[index].copied = false;
824
+ // this.cdr.detectChanges();
825
+ // }, 2000); // Reset after 2 seconds
826
+ // });
827
+ // }
828
+ copyText(id, index) {
829
+ // Get the text element
830
+ var textElement = document.getElementById(id);
831
+ // Create a temporary textarea element to copy the text
832
+ var tempTextArea = document.createElement('textarea');
833
+ tempTextArea.value = textElement.innerText;
834
+ // Append the textarea to the body (necessary for the execCommand to work)
835
+ document.body.appendChild(tempTextArea);
836
+ // Select the text inside the textarea
837
+ tempTextArea.select();
838
+ // Copy the text to the clipboard
839
+ document.execCommand('copy');
840
+ // Remove the temporary textarea
841
+ document.body.removeChild(tempTextArea);
842
+ // Optionally, you can alert the user or change the button text to indicate the copy was successful
843
+ // alert('Text copied to clipboard!');
844
+ this.chatLog[index].copied = true;
845
+ this.cdr.detectChanges();
846
+ // Reset the copied state after a delay
847
+ setTimeout(() => {
848
+ this.chatLog[index].copied = false;
849
+ this.cdr.detectChanges();
850
+ }, 2000); // Reset after 2 seconds
851
+ }
852
+ handleCopyClick(index) {
853
+ // Copy the message to the clipboard
854
+ const contentToCopy = this.chatLog[index].message;
855
+ const resutlt = this.copyText('messageText_' + index, index);
856
+ }
857
+ sanitizeHTML(html) {
858
+ const doc = new DOMParser().parseFromString(html, 'text/html');
859
+ // Create a new document fragment to hold the simplified content
860
+ const fragment = document.createDocumentFragment();
861
+ // Append the children of the body of the parsed document to the fragment
862
+ Array.from(doc.body.childNodes).forEach((node) => {
863
+ fragment.appendChild(node.cloneNode(true));
864
+ });
865
+ // Create a new div element to hold the simplified HTML
866
+ const simplifiedDiv = document.createElement('div');
867
+ simplifiedDiv.appendChild(fragment);
868
+ // Remove complex tags or attributes as needed
869
+ // Example: remove scripts
870
+ simplifiedDiv
871
+ .querySelectorAll('script')
872
+ .forEach((script) => script.remove());
873
+ // Return the simplified HTML as a string
874
+ return simplifiedDiv.innerHTML;
875
+ }
876
+ handleEditorClick(index) {
877
+ if (this.currentIndexForEditor == -1) {
878
+ this.currentIndexForEditor = index;
879
+ this.currentMessageForEditor = this.sanitizeHTML(this.chatLog[index].message);
880
+ this.currentMessageForEditor = this.currentMessageForEditor.replace('SafeValue must use [property]=binding:', '');
881
+ this.cdr.detectChanges();
882
+ }
883
+ else {
884
+ if (this.currentIndexForEditor == index) {
885
+ this.currentMessageForEditor += this.sanitizeHTML(this.chatLog[index].message);
886
+ this.currentMessageForEditor = this.currentMessageForEditor.replace('SafeValue must use [property]=binding:', '');
887
+ this.cdr.detectChanges();
888
+ }
889
+ else {
890
+ this.currentIndexForEditor = index;
891
+ this.currentMessageForEditor = this.sanitizeHTML(this.chatLog[index].message);
892
+ this.currentMessageForEditor = this.currentMessageForEditor.replace('SafeValue must use [property]=binding:', '');
893
+ this.cdr.detectChanges();
894
+ }
895
+ }
896
+ this.chatLog[index].isEditor = true;
897
+ this.cdr.detectChanges();
898
+ // Reset the copied state after a delay
899
+ setTimeout(() => {
900
+ this.chatLog[index].isEditor = false;
901
+ this.cdr.detectChanges();
902
+ }, 2000); // Reset after 2 seconds
903
+ this.editorsDrawer.open();
904
+ const button = document.getElementById('botcloseplaygroundbutton');
905
+ if (button) {
906
+ button.style.display = 'none';
907
+ }
908
+ this.cdr.detectChanges();
909
+ }
910
+ scrollToBottom() {
911
+ let counter = 0;
912
+ const interval = setInterval(() => {
913
+ this.chatMain.nativeElement.scrollTop = this.chatMain.nativeElement.scrollHeight;
914
+ if (counter++ > 5)
915
+ clearInterval(interval);
916
+ }, 5);
917
+ }
918
+ handleAction(action) {
919
+ console.info('incoming action from the chatbot AI');
920
+ console.info(action);
921
+ if (action === null || action === void 0 ? void 0 : action.content) {
922
+ }
923
+ }
924
+ ngAfterViewInit() {
925
+ // Check if the drawer is initially open and apply overflow hidden to body if so
926
+ if (this.drawer.opened) {
927
+ this.setBodyOverflow();
928
+ }
929
+ // Listen to changes in the drawer being opened or closed
930
+ this.drawer.openedChange.subscribe((opened) => {
931
+ if (opened) {
932
+ this.setBodyOverflow();
933
+ }
934
+ else {
935
+ this.removeBodyOverflow();
936
+ }
937
+ });
938
+ this.drawer.openedChange.subscribe((opened) => {
939
+ if (opened) {
940
+ setTimeout(() => {
941
+ if (this.myTextarea && this.myTextarea.nativeElement) {
942
+ this.myTextarea.nativeElement.focus(); // Focus on the textarea
943
+ }
944
+ });
945
+ }
946
+ });
947
+ }
948
+ setBodyOverflow() {
949
+ this.renderer.addClass(document.body, this.bodyOverflowClass);
950
+ }
951
+ removeBodyOverflow() {
952
+ this.renderer.removeClass(document.body, this.bodyOverflowClass);
953
+ }
954
+ getSpeakersByStaffIds(ids) {
955
+ const url = `${this.environment.USERS_API}/events/${this.eventId}/users/get-by-staff-ids`;
956
+ fetch(url, {
957
+ method: 'POST',
958
+ headers: {
959
+ 'Content-Type': 'application/json',
960
+ Authorization: 'Bearer ' + 'your_token_here',
961
+ },
962
+ body: JSON.stringify(ids),
963
+ })
964
+ .then((response) => {
965
+ if (response.ok) {
966
+ return response.json(); // Parse the JSON body of the response
967
+ }
968
+ else {
969
+ throw new Error('Network response was not ok.');
970
+ }
971
+ })
972
+ .then((data) => {
973
+ if ((data === null || data === void 0 ? void 0 : data.length) > 0) {
974
+ data.forEach((speaker) => {
975
+ this.speakers[speaker.id] = speaker;
976
+ });
977
+ this.cdr.markForCheck();
978
+ }
979
+ })
980
+ .catch((err) => {
981
+ console.error('Error fetching data:', err);
982
+ this.loading = false;
983
+ });
984
+ }
985
+ performSessionAction(sessionId, action) {
986
+ this.sessionActions.next({
987
+ sessionId,
988
+ action,
989
+ });
990
+ }
991
+ addCloseBotClickEvent() {
992
+ const element = this.elementRef.nativeElement.querySelector('#closeBotNow');
993
+ if (element) {
994
+ this.renderer.listen(element, 'click', () => {
995
+ this.closeBot.next();
996
+ });
997
+ }
998
+ }
999
+ isMobileBrowser() {
1000
+ return /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent);
1001
+ }
1002
+ connectToUser(userId) {
1003
+ this.connectWithUser.emit({
1004
+ connect: !this.canDisconnect(userId),
1005
+ userId,
1006
+ });
1007
+ setTimeout(() => {
1008
+ this.fetchMyConnections().subscribe((res) => {
1009
+ this.cdr.markForCheck();
1010
+ });
1011
+ this.fetchPendingRequests().subscribe((res) => {
1012
+ this.cdr.markForCheck();
1013
+ });
1014
+ }, 500);
1015
+ }
1016
+ scheduleMeetingWithUser(user) {
1017
+ this.scheduleMeeting.emit(user);
1018
+ }
1019
+ canConnect(userId) {
1020
+ return !(this.canDisconnect(userId) ||
1021
+ this.pendingRequests.find((a) => a == userId));
1022
+ }
1023
+ canDisconnect(userId) {
1024
+ return this.myConnections.find((conn) => conn.userId == userId);
1025
+ }
1026
+ fetchPendingRequests() {
1027
+ const headers = new HttpHeaders({
1028
+ 'Content-Type': 'application/json',
1029
+ apiKey: this.autogenKey,
1030
+ });
1031
+ return this.http
1032
+ .get(`${this.environment.USERS_API}/events/${this.eventId}/connection-requests/autogen/pending-sent-requests?userId=${this.userId}`, { headers })
1033
+ .pipe(switchMap((res) => {
1034
+ this.pendingRequests = res;
1035
+ this.cdr.markForCheck();
1036
+ return of(res);
1037
+ }), catchError((error) => {
1038
+ console.error('Error fetching pending requests: ', error);
1039
+ return of(null);
1040
+ }));
1041
+ }
1042
+ fetchMyConnections() {
1043
+ const headers = new HttpHeaders({
1044
+ 'Content-Type': 'application/json',
1045
+ apiKey: this.autogenKey,
1046
+ });
1047
+ return this.http
1048
+ .get(`${this.environment.USERS_API}/events/${this.eventId}/users-connections/autogen?userId=${this.userId}`, { headers })
1049
+ .pipe(switchMap((res) => {
1050
+ this.myConnections = res;
1051
+ this.cdr.markForCheck();
1052
+ return of(res);
1053
+ }), catchError((error) => {
1054
+ console.error('Error fetching pending requests: ', error);
1055
+ return of(null);
1056
+ }));
1057
+ }
1058
+ // Toggle the dropdown visibility
1059
+ toggleDropdown() {
1060
+ if (!this.agents)
1061
+ this.fetchAgents();
1062
+ this.isDropdownOpen = !this.isDropdownOpen;
1063
+ this.cdr.detectChanges();
1064
+ }
1065
+ onSelectAll(event) {
1066
+ var _a;
1067
+ (_a = this.agents) === null || _a === void 0 ? void 0 : _a.forEach((agent) => (agent.selected = false));
1068
+ this.cdr.detectChanges();
1069
+ }
1070
+ onAgentChange(agent) {
1071
+ //agent.selected = !agent.selected;
1072
+ //console.log(agent);
1073
+ let agentFound = this.agents.filter((p) => p.id == agent.id);
1074
+ if (agentFound && agentFound.length > 0) {
1075
+ agentFound[0].selected = !agentFound[0].selected;
1076
+ this.cdr.detectChanges();
1077
+ }
1078
+ this.cdr.detectChanges();
1079
+ }
1080
+ areAllSelected() {
1081
+ var _a;
1082
+ return (_a = this.agents) === null || _a === void 0 ? void 0 : _a.every((agent) => !agent.selected);
1083
+ }
1084
+ getDropdownHeaderText() {
1085
+ var _a;
1086
+ const selectedAgents = (_a = this.agents) === null || _a === void 0 ? void 0 : _a.filter((agent) => agent.selected);
1087
+ if (!selectedAgents) {
1088
+ return 'All Agents';
1089
+ }
1090
+ else {
1091
+ if (selectedAgents && (selectedAgents === null || selectedAgents === void 0 ? void 0 : selectedAgents.length) === 0) {
1092
+ return 'All Agents';
1093
+ }
1094
+ else {
1095
+ return (selectedAgents === null || selectedAgents === void 0 ? void 0 : selectedAgents.length) > 1
1096
+ ? `${selectedAgents === null || selectedAgents === void 0 ? void 0 : selectedAgents.length} Agents Selected`
1097
+ : `${selectedAgents === null || selectedAgents === void 0 ? void 0 : selectedAgents.length} Agent Selected`;
1098
+ }
1099
+ }
1100
+ }
1101
+ fetchAgents_http() {
1102
+ this.loading = true;
1103
+ const url = `${this.environment.AGENTS_API}/CoPilot/${this.botId}/active-agents`;
1104
+ const headers = new HttpHeaders({
1105
+ 'Content-Type': 'application/json',
1106
+ });
1107
+ return this.http.post(url, {}, { headers }).pipe(switchMap((res) => {
1108
+ if (res) {
1109
+ this.agents = res.map((agent) => (Object.assign(Object.assign({}, agent), { selected: false })));
1110
+ }
1111
+ this.cdr.markForCheck();
1112
+ return of(res);
1113
+ }), catchError((error) => {
1114
+ console.error('Error fetching chatbot config: ', error);
1115
+ return of(null);
1116
+ }));
1117
+ }
1118
+ fetchContent_http() {
1119
+ this.isDocInEditMode = false;
1120
+ this.isContentLoaded = false;
1121
+ console.log('API call function');
1122
+ this.loading = true;
1123
+ const conversation_id = this.conversationService.getKey(this.botId);
1124
+ this.conversationId = conversation_id;
1125
+ const url = `${this.environment.AGENTS_API}/ConversationDocuments?conversationId=${conversation_id}&botId=${this.botId}`;
1126
+ const headers = new HttpHeaders({
1127
+ 'Content-Type': 'application/json',
1128
+ apiKey: 'WIz/qAm+EEmfOkFaUA/weA==',
1129
+ });
1130
+ return this.http.get(url, { headers }).pipe(switchMap((res) => {
1131
+ if (res) {
1132
+ this.isDocInEditMode = true;
1133
+ this.documentContent = res;
1134
+ console.log('Get API callled success');
1135
+ this.isContentLoaded = true;
1136
+ console.log(res);
1137
+ }
1138
+ this.cdr.markForCheck();
1139
+ return of(res);
1140
+ }), catchError((error) => {
1141
+ console.error('Error fetching chatbot config DJ: ', error);
1142
+ this.isDocInEditMode = false;
1143
+ this.isContentLoaded = true;
1144
+ if ((error === null || error === void 0 ? void 0 : error.status) == 404) {
1145
+ console.log('dash');
1146
+ this.isDocInEditMode = false;
1147
+ this.isContentLoaded = true;
1148
+ }
1149
+ return of(null);
1150
+ }));
1151
+ }
1152
+ fetchAgents() {
1153
+ this.fetchAgents_http().subscribe();
1154
+ }
1155
+ fetchEditorContent() {
1156
+ this.fetchContent_http().subscribe();
1157
+ }
1158
+ // events/${eventId}/users-connections
1159
+ processMessageForDisplay(markdown) {
1160
+ try {
1161
+ // Parse the markdown content to HTML using marked
1162
+ const markdownContent = marked.parse(markdown);
1163
+ // Sanitize the parsed HTML using Angular's DomSanitizer
1164
+ // const sanitizedHtml = this.sanitizer.bypassSecurityTrustHtml(markdownContent);
1165
+ // Return the safe HTML content for display
1166
+ return markdownContent;
1167
+ }
1168
+ catch (error) {
1169
+ console.error('Error processing markdown:', error);
1170
+ return ''; // Return an empty string or handle the error appropriately
1171
+ }
1172
+ }
1173
+ prepareHtml(markdown) {
1174
+ if (!markdown || !(markdown.length > 0)) {
1175
+ console.error('Input Markdown is null or empty');
1176
+ return '';
1177
+ }
1178
+ // Convert Markdown headers (### or ##) to <strong> for bold headings
1179
+ let html = markdown.replace(/^(#{1,6})\s+(.*)$/gm, (match, hashes, text) => {
1180
+ const level = hashes.length;
1181
+ if (level === 3) {
1182
+ return `<h3><strong>${text}</strong></h3>`;
1183
+ }
1184
+ else if (level === 4) {
1185
+ return `<h4><strong>${text}</strong></h4>`;
1186
+ }
1187
+ return `<strong>${text}</strong>`;
1188
+ });
1189
+ // Convert Markdown code blocks with language to preformatted HTML
1190
+ html = html.replace(/```(\w+)?\n([\s\S]*?)```/g, (match, lang, code) => {
1191
+ const escapedCode = this.escapeHtml(code);
1192
+ const language = lang || 'plaintext';
1193
+ // Create a copy button for the code block
1194
+ return `
1195
+ <div class="code-container">
1196
+ <button id="copy-button" class="copy-button" (click)="copyToClipboard('\`${escapedCode}\`')">Copy</button>
1197
+ <pre class="code_block diff"><code class="language-${language}">${escapedCode}</code></pre>
1198
+ </div>`;
1199
+ });
1200
+ // Convert inline code (wrapped in `backticks`) to inline <code> tags
1201
+ html = html.replace(/`([^`]+)`/g, '<code>$1</code>');
1202
+ // Convert Markdown bold to HTML <strong>
1203
+ html = html.replace(/\*\*(.*?)\*\*/g, '<strong>$1</strong>');
1204
+ // Convert numbered lists
1205
+ html = html.replace(/^\d+\.\s+(.*)$/gm, '<li>$1</li>');
1206
+ // Convert bullet point lists
1207
+ html = html.replace(/^\-\s+(.*)$/gm, '<li>$1</li>');
1208
+ // Convert Markdown links to HTML links
1209
+ html = html.replace(/\[([^\]]+)]\(([^)]+)\)/g, '<a href="$2" target="_blank">$1</a>');
1210
+ // Convert new lines to <br> tags for paragraphs
1211
+ html = html.replace(/(?:\r\n|\r|\n)/g, '<br>');
1212
+ return html;
1213
+ }
1214
+ // Helper function to escape HTML characters for code blocks
1215
+ escapeHtml(code) {
1216
+ return code
1217
+ .replace(/&/g, '&amp;')
1218
+ .replace(/</g, '&lt;')
1219
+ .replace(/>/g, '&gt;')
1220
+ .replace(/"/g, '&quot;')
1221
+ .replace(/'/g, '&#039;');
1222
+ }
1223
+ // Function to copy text to clipboard
1224
+ copyToClipboard(text) {
1225
+ navigator.clipboard.writeText(text).then(() => {
1226
+ alert('Code copied to clipboard!');
1227
+ }, (err) => {
1228
+ console.error('Could not copy text: ', err);
1229
+ });
1230
+ }
1231
+ toggleCollapse() {
1232
+ this.isCollapsed = !this.isCollapsed;
1233
+ this.cdr.detectChanges();
1234
+ }
1235
+ toggleCollapseGraph() {
1236
+ this.isCollapsedForGraph = !this.isCollapsedForGraph;
1237
+ this.cdr.detectChanges();
1238
+ }
1239
+ toggleCollapseFGraph() {
1240
+ this.isCollapsedForFGraph = !this.isCollapsedForFGraph;
1241
+ this.cdr.detectChanges();
1242
+ }
1243
+ // Extracts the domain from a URL
1244
+ getDomainName(url) {
1245
+ try {
1246
+ const { hostname } = new URL(url);
1247
+ return hostname.replace(/^www\./, ''); // Remove 'www.' if present
1248
+ }
1249
+ catch (_a) {
1250
+ return 'unknown';
1251
+ }
1252
+ }
1253
+ // Generates the favicon URL
1254
+ getFaviconUrl(url) {
1255
+ const domain = this.getDomainName(url);
1256
+ return `https://www.google.com/s2/favicons?sz=128&domain=${domain}`;
1257
+ }
1258
+ onCardClick(sources) {
1259
+ this.currentSourcesList = sources;
1260
+ this.cdr.detectChanges();
1261
+ this.sourcesDrawer.open();
1262
+ const button = document.getElementById('botcloseplaygroundbutton');
1263
+ if (button) {
1264
+ button.style.display = 'none';
1265
+ }
1266
+ }
1267
+ openOuterEditor() {
1268
+ this.fetchEditorContent();
1269
+ this.editorsDrawer.open();
1270
+ this.isDrawerOpen = true;
1271
+ this.isShowEditorButton = false;
1272
+ this.cdr.detectChanges();
1273
+ const button = document.getElementById('botcloseplaygroundbutton');
1274
+ if (button) {
1275
+ button.style.display = 'none';
1276
+ }
1277
+ }
1278
+ onCloseEditor() {
1279
+ this.editorsDrawer.close();
1280
+ this.isDrawerOpen = false;
1281
+ this.isShowEditorButton = true;
1282
+ this.cdr.detectChanges(); // Trigger change detection if needed
1283
+ this.onDrawerClosed();
1284
+ }
1285
+ onCloseSource() {
1286
+ this.sourcesDrawer.close();
1287
+ this.isDrawerOpen = false;
1288
+ this.cdr.detectChanges(); // Trigger change detection if needed
1289
+ this.onDrawerClosed();
1290
+ }
1291
+ onDrawerClosed() {
1292
+ setTimeout(() => {
1293
+ this.isDrawerOpen = true;
1294
+ this.cdr.detectChanges(); // Trigger change detection if needed
1295
+ // Use ngClass to dynamically apply the class
1296
+ const button = document.getElementById('botcloseplaygroundbutton');
1297
+ if (button) {
1298
+ button.style.display = 'block';
1299
+ }
1300
+ }, 800);
1301
+ }
1302
+ toggleDrawer(todo) {
1303
+ this.isDrawerOpen = todo;
1304
+ this.cdr.detectChanges();
1305
+ this.updateButtonVisibility();
1306
+ }
1307
+ updateButtonVisibility() {
1308
+ const button = document.getElementById('botcloseplaygroundbutton');
1309
+ if (button) {
1310
+ button.style.display = this.isDrawerOpen ? 'block' : 'none';
1311
+ }
1312
+ }
1313
+ openLinkInNewTab(link) {
1314
+ window.open(link, '_blank');
1315
+ }
1316
+ adjustTextareaHeight(event) {
1317
+ try {
1318
+ if (event.key === 'Enter' && !event.shiftKey) {
1319
+ // Prevents a new line from being added
1320
+ event.preventDefault();
1321
+ }
1322
+ }
1323
+ catch (error) {
1324
+ }
1325
+ const textarea = event.target;
1326
+ textarea.style.height = 'auto'; // Reset the height
1327
+ textarea.style.height = `${textarea.scrollHeight}px`; // Adjust height to match content
1328
+ // Ensure the height doesn't exceed the max-height set in CSS
1329
+ if (textarea.scrollHeight > 150) {
1330
+ textarea.style.height = `150px`; // Adjust height to match content
1331
+ textarea.style.overflowY = 'auto'; // Enable scrolling if content exceeds 400px
1332
+ }
1333
+ else {
1334
+ textarea.style.overflowY = 'hidden'; // Hide scrollbar if content is within limits
1335
+ }
1336
+ }
1337
+ toggleWorkflows(value = null) {
1338
+ if (!this.checkForCop29BotId()) {
1339
+ this.botService.getWorkflowsByOrgId(this.orgId).subscribe((res) => {
1340
+ this.orgWorkflows = res;
1341
+ this.isWorkflowOpen = value == null ? !this.isWorkflowOpen : value;
1342
+ if (!this.isWorkflowOpen) {
1343
+ this.selectedWorkflow = null;
1344
+ this.openWorkflowInput = false;
1345
+ }
1346
+ this.cdr.detectChanges();
1347
+ });
1348
+ }
1349
+ }
1350
+ initializeForm() {
1351
+ var _a, _b;
1352
+ // Create form controls dynamically based on selectedWorkflow.Trigger.InputSchema
1353
+ const formControls = {};
1354
+ if ((_b = (_a = this.selectedWorkflow) === null || _a === void 0 ? void 0 : _a.Trigger) === null || _b === void 0 ? void 0 : _b.InputSchema) {
1355
+ this.selectedWorkflow.Trigger.InputSchema.forEach((input) => {
1356
+ formControls[input.InputId] = [
1357
+ input.Value || '',
1358
+ input.Required ? Validators.required : null,
1359
+ ];
1360
+ });
1361
+ }
1362
+ // Initialize the form
1363
+ this.workflowForm = this.fb.group(formControls);
1364
+ }
1365
+ onWorkflowSelected(workflow) {
1366
+ this.selectedWorkflow = workflow;
1367
+ this.initializeForm();
1368
+ this.isWorkflowOpen = false;
1369
+ this.openWorkflowInput = true;
1370
+ }
1371
+ onWorkflowSubmit() {
1372
+ const container = document.getElementById('allChats');
1373
+ if (this.workflowForm.valid) {
1374
+ console.log(this.workflowForm.value);
1375
+ var input = this.prepareHtml(this.generateMarkdown(this.selectedWorkflow.Name, this.workflowForm.value));
1376
+ // update last two chatLog entries, set showWorkflowExecutionLoader = false
1377
+ try {
1378
+ this.chatLog[this.chatLog.length - 1]['showWorkflowExecutionLoader'] = false;
1379
+ this.chatLog[this.chatLog.length - 2]['showWorkflowExecutionLoader'] = false;
1380
+ }
1381
+ catch (error) { }
1382
+ this.chatLog.push({
1383
+ type: 'user',
1384
+ message: input,
1385
+ time: formatNow(this.timezone),
1386
+ copied: false,
1387
+ isCollapsedTrue: false,
1388
+ showWorkflowExecutionLoader: true,
1389
+ });
1390
+ console.log(input);
1391
+ this.currentWorkflowActionProgress = 0;
1392
+ this.currentWorkflowAction =
1393
+ 'Executing ' + this.selectedWorkflow.Actions[0].Name;
1394
+ this.isChatingWithAi = true;
1395
+ this.executingWorkflow = true;
1396
+ this.workflowExecutionDetails = {
1397
+ Actions: this.selectedWorkflow.Actions,
1398
+ Inputs: this.workflowForm.value,
1399
+ workflowInputs: this.workflowForm.value,
1400
+ WorkflowName: this.selectedWorkflow.Name,
1401
+ };
1402
+ this.currentWorkflowExecutionDetails = this.workflowExecutionDetails;
1403
+ this.scrollToBottom();
1404
+ this.cdr.detectChanges();
1405
+ // execute the ask endpoint with workflow input
1406
+ this.makeAskRequest(input, this.agents, this.conversationKey, '', null, this.selectedWorkflow['_id'], this.workflowForm.value);
1407
+ }
1408
+ }
1409
+ makeAskRequest(inputMsg, agents, conversationId, msg, chat, workflowId, workflow_inputs) {
1410
+ var _a;
1411
+ var url = `${this.environment.BASE_URL}/ai/ask`;
1412
+ var body = {
1413
+ user_question: inputMsg,
1414
+ user_id: this.userId,
1415
+ bot_id: this.botId,
1416
+ message_id: this.conversationService.generateKey(),
1417
+ agents: (_a = agents === null || agents === void 0 ? void 0 : agents.filter((p) => p.selected).map((p) => p.id)) !== null && _a !== void 0 ? _a : [],
1418
+ conversation_id: conversationId,
1419
+ };
1420
+ if (workflowId) {
1421
+ body['workflow_id'] = workflowId;
1422
+ body['workflow_inputs'] = workflow_inputs;
1423
+ }
1424
+ fetch(url, {
1425
+ method: 'POST',
1426
+ headers: {
1427
+ 'Content-Type': 'application/json',
1428
+ Authorization: 'Bearer ' + this.s27Token,
1429
+ 'x-api-key': this.apiKey,
1430
+ 'hive-bot-id': this.botId
1431
+ },
1432
+ body: JSON.stringify(body),
1433
+ })
1434
+ .then((response) => {
1435
+ if (response.status === 401 || response.status === 403) {
1436
+ this.is401 = true;
1437
+ this.refreshToken.emit();
1438
+ // If `msg` and `chat` exist, handle them
1439
+ if (msg && chat) {
1440
+ this.msg = msg;
1441
+ this.chat = chat;
1442
+ this.isFetchDataFor = true;
1443
+ }
1444
+ }
1445
+ else {
1446
+ this.is401 = false;
1447
+ }
1448
+ return response.json();
1449
+ })
1450
+ .then((data) => {
1451
+ console.log(data);
1452
+ // Additional response handling if needed
1453
+ })
1454
+ .catch((err) => {
1455
+ console.error('Error: ', err);
1456
+ this.isChatingWithAi = false;
1457
+ });
1458
+ this.input = '';
1459
+ this.selectedWorkflow = null;
1460
+ this.openWorkflowInput = false;
1461
+ this.isWorkflowOpen = false;
1462
+ this.scrollToBottom();
1463
+ this.cdr.markForCheck();
1464
+ }
1465
+ generateMarkdown(title, obj) {
1466
+ var _a;
1467
+ // Initialize markdown with the title
1468
+ let markdown = `## ${title}\n`;
1469
+ // Loop through the object and append the field names and values
1470
+ for (const [key, value] of Object.entries(obj)) {
1471
+ var key_label = ((_a = this.selectedWorkflow.Trigger.InputSchema.find((input) => input.InputId === key)) === null || _a === void 0 ? void 0 : _a.Label) || key;
1472
+ markdown += `- **${key_label}**: ${value}\n`;
1473
+ }
1474
+ return markdown;
1475
+ }
1476
+ showWorkflowHistoryDetails(workflow_id) {
1477
+ if (!workflow_id) {
1478
+ this.workflowExecutionDetails = this.currentWorkflowExecutionDetails;
1479
+ this.showWorkflowExecutionDetails = true;
1480
+ this.cdr.detectChanges();
1481
+ return;
1482
+ }
1483
+ this.botService.getWorkflowExecutionById(workflow_id).subscribe((res) => {
1484
+ if (res && res.Actions && Array.isArray(res.Actions)) {
1485
+ res.Actions = res.Actions.map((action) => {
1486
+ if (action.InsertTimeStamp) {
1487
+ action.InsertTimeStamp = formatTimeStamps(this.timezone, action.InsertTimeStamp);
1488
+ }
1489
+ return action;
1490
+ });
1491
+ }
1492
+ res.InsertTimeStamp = formatTimeStamps(this.timezone, res.InsertTimeStamp);
1493
+ this.workflowExecutionDetails = res;
1494
+ this.showWorkflowExecutionDetails = true;
1495
+ this.cdr.detectChanges();
1496
+ });
1497
+ }
1498
+ closeModal() {
1499
+ this.showWorkflowExecutionDetails = false;
1500
+ }
1501
+ objectToArray(obj) {
1502
+ return Object.keys(obj).map((key) => ({ key, value: obj[key] }));
1503
+ }
1504
+ startNewConversation() {
1505
+ this.conversationKey = this.conversationService.getKey(this.botId, true);
1506
+ this.chatLog = [this.chatLog[0]];
1507
+ this.isChatingWithAi = false;
1508
+ setTimeout(() => {
1509
+ this.initializeSocket();
1510
+ }, 200);
1511
+ this.scrollToBottom();
1512
+ this.cdr.detectChanges();
1513
+ }
1514
+ initializeSpeechRecognizer(token) {
1515
+ this.speechConfig = SpeechSDK.SpeechConfig.fromAuthorizationToken(token, this.region);
1516
+ const audioConfig = SpeechSDK.AudioConfig.fromDefaultMicrophoneInput();
1517
+ this.recognizer = new SpeechSDK.SpeechRecognizer(this.speechConfig, audioConfig);
1518
+ this.recognizer.recognizing = (s, e) => {
1519
+ if (e.result.reason === SpeechSDK.ResultReason.RecognizingSpeech) {
1520
+ this.input = e.result.text;
1521
+ console.log(`Recognizing: ${e.result.text}`);
1522
+ this.cdr.markForCheck();
1523
+ }
1524
+ };
1525
+ this.recognizer.recognized = (s, e) => {
1526
+ if (e.result.reason === SpeechSDK.ResultReason.RecognizedSpeech) {
1527
+ this.input = e.result.text;
1528
+ console.log(`Recognized: ${e.result.text}`);
1529
+ this.toggleRecording();
1530
+ this.cdr.markForCheck();
1531
+ }
1532
+ };
1533
+ this.recognizer.canceled = (s, e) => {
1534
+ console.error('Canceled: ', e.errorDetails);
1535
+ };
1536
+ this.recognizer.sessionStopped = (s, e) => {
1537
+ console.log('Session stopped.');
1538
+ this.recognizer.stopContinuousRecognitionAsync();
1539
+ this.fetchData();
1540
+ };
1541
+ }
1542
+ toggleRecording() {
1543
+ this.isRecording = !this.isRecording;
1544
+ if (this.isRecording) {
1545
+ this.startRecognition();
1546
+ }
1547
+ else {
1548
+ this.stopRecognition();
1549
+ }
1550
+ }
1551
+ startRecognition() {
1552
+ this.recognizer.startContinuousRecognitionAsync();
1553
+ }
1554
+ stopRecognition() {
1555
+ this.recognizer.stopContinuousRecognitionAsync();
1556
+ }
1557
+ checkForCop29BotId() {
1558
+ return this.botId == '66fa3f276c5d71e2717bfea8';
1559
+ }
1560
+ }
1561
+ ChatDrawerComponent.decorators = [
1562
+ { type: Component, args: [{
1563
+ selector: 'hivegpt-chat-drawer-package',
1564
+ template: "<button *ngIf=\"isShowEditorButton && !checkForCop29BotId()\" (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 *ngIf=\"!checkForCop29BotId()\" xmlns=\"http://www.w3.org/2000/svg\" width=\"31.499\" height=\"31.501\"\n 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 *ngIf=\"!checkForCop29BotId()\">\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 *ngIf=\"!checkForCop29BotId()\" class=\"up copy\"\n title=\"{{ chat?.isEditor ? 'Added!' : 'Add to editor' }}\" (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\" *ngIf=\"!checkForCop29BotId()\">\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\">\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>",
1565
+ changeDetection: ChangeDetectionStrategy.OnPush,
1566
+ 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}.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:normal;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}"]
1567
+ },] }
1568
+ ];
1569
+ ChatDrawerComponent.ctorParameters = () => [
1570
+ { type: FormBuilder },
1571
+ { type: BotsService },
1572
+ { type: ChangeDetectorRef },
1573
+ { type: HttpClient },
1574
+ { type: DomSanitizer },
1575
+ { type: ElementRef },
1576
+ { type: Renderer2 },
1577
+ { type: SocketService },
1578
+ { type: ConversationService }
1579
+ ];
1580
+ ChatDrawerComponent.propDecorators = {
1581
+ chatMain: [{ type: ViewChild, args: ['chatMain',] }],
1582
+ myInput: [{ type: ViewChild, args: ['myInput',] }],
1583
+ closePlaygroundButtons: [{ type: ViewChildren, args: ['closeplaygroundbutton',] }],
1584
+ drawer: [{ type: ViewChild, args: ['drawer',] }],
1585
+ sourcesDrawer: [{ type: ViewChild, args: ['sourcesDrawer',] }],
1586
+ editorsDrawer: [{ type: ViewChild, args: ['editorsDrawer',] }],
1587
+ myTextarea: [{ type: ViewChild, args: ['myTextarea', { static: false },] }],
1588
+ copilotName: [{ type: Input }],
1589
+ firstName: [{ type: Input }],
1590
+ lastName: [{ type: Input }],
1591
+ apiKey: [{ type: Input }],
1592
+ bgBubbleAi: [{ type: Input }],
1593
+ bgBubbleUser: [{ type: Input }],
1594
+ bgGradient: [{ type: Input }],
1595
+ botName: [{ type: Input }],
1596
+ botSkills: [{ type: Input }],
1597
+ botId: [{ type: Input }],
1598
+ orgId: [{ type: Input }],
1599
+ closeButtonColor: [{ type: Input }],
1600
+ closeButtonbgColor: [{ type: Input }],
1601
+ credentials: [{ type: Input }],
1602
+ dateTimeColor: [{ type: Input }],
1603
+ dateTextColor: [{ type: Input }],
1604
+ eventId: [{ type: Input }],
1605
+ s27Token: [{ type: Input }],
1606
+ eventName: [{ type: Input }],
1607
+ botIcon: [{ type: Input }],
1608
+ formFieldBgColor: [{ type: Input }],
1609
+ formFieldTextColor: [{ type: Input }],
1610
+ fullView: [{ type: Input }],
1611
+ gradientColors: [{ type: Input }],
1612
+ greeting: [{ type: Input }],
1613
+ messageTextColorAi: [{ type: Input }],
1614
+ messageTextColorUser: [{ type: Input }],
1615
+ rules: [{ type: Input }],
1616
+ sendButtonColor: [{ type: Input }],
1617
+ sendButtonTextColor: [{ type: Input }],
1618
+ showClose: [{ type: Input }],
1619
+ thumbsDownMessages: [{ type: Input }],
1620
+ thumbsUpMessage: [{ type: Input }],
1621
+ timezone: [{ type: Input }],
1622
+ unknownResponses: [{ type: Input }],
1623
+ useOpenAi: [{ type: Input }],
1624
+ userId: [{ type: Input }],
1625
+ isDev: [{ type: Input }],
1626
+ againButtonColor: [{ type: Input }],
1627
+ againButtonTextColor: [{ type: Input }],
1628
+ feedbackEvent: [{ type: Output }],
1629
+ onCloseEvent: [{ type: Output }],
1630
+ openPage: [{ type: Output }],
1631
+ sessionActions: [{ type: Output }],
1632
+ closeBot: [{ type: Output }],
1633
+ connectWithUser: [{ type: Output }],
1634
+ scheduleMeeting: [{ type: Output }],
1635
+ refreshToken: [{ type: Output }]
1636
+ };
1637
+ //# 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":"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","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';\nimport * as marked from 'marked';  // Import marked\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    this.botService.fetchSpeechAuthorizationToken(this.botId, this.apiKey).subscribe((token) => {\n      this.authorizationToken = token;\n      this.initializeSpeechRecognizer(token);\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;'><a href='mailto:support@social27.com' style='color: inherit; text-decoration: none;'>Please click here</a></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            _id: chat._id\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            _id: chat._id\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, message) {\n    console.log(message);\n\n    this.feedbackDone = true;\n    this.showFeedBackIconsIndex = null;\n    const conversation_id = this.conversationService.getKey(this.botId);\n    const url = `${this.environment.AGENTS_API}/Conversation/coPilot/${this.botId}/conversation/${conversation_id}/helpful-response`;\n    fetch(url, {\n      method: 'POST',\n      headers: {\n        'Content-Type': 'application/json',\n        'apiKey': 'Conversation_WIz/qAm+EEmfOkFaUA/weA==',\n        'hive-bot-id': this.botId\n      },\n      body: JSON.stringify({ messageId: message._id, isHelpful: flag }),\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, this.chatLog[idx]);\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, this.chatLog[idx]);\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    if (!this.agents)\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) {\n      return 'All Agents';\n    } else {\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  }\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    try {\n      // Parse the markdown content to HTML using marked\n      const markdownContent = marked.parse(markdown);\n\n      // Sanitize the parsed HTML using Angular's DomSanitizer\n      // const sanitizedHtml = this.sanitizer.bypassSecurityTrustHtml(markdownContent);\n\n      // Return the safe HTML content for display\n      return markdownContent;\n\n    } catch (error) {\n      console.error('Error processing markdown:', error);\n      return ''; // Return an empty string or handle the error appropriately\n    }\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"]}