@hivegpt/hiveai-angular 0.0.355 → 0.0.360

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