@sunbird-cb/toc 0.0.25 → 0.0.27

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 (26) hide show
  1. package/esm2022/lib/_collection/_common/ai-tutor/ai-tutor.component.mjs +1169 -0
  2. package/esm2022/lib/_collection/_common/ai-tutor/socket.service.mjs +121 -0
  3. package/esm2022/lib/_collection/_common/content-toc/ai-tutor-confirm-popup/ai-tutor-confirm-popup.component.mjs +3 -3
  4. package/esm2022/lib/_collection/_common/content-toc/content-toc.component.mjs +15 -6
  5. package/esm2022/lib/_collection/_common/content-toc/content-toc.module.mjs +7 -2
  6. package/esm2022/lib/components/app-toc-cios-home/app-toc-cios-home.component.mjs +3 -3
  7. package/esm2022/lib/components/app-toc-home-v2/app-toc-home-v2.component.mjs +2 -2
  8. package/esm2022/lib/services/root.service.mjs +106 -0
  9. package/esm2022/public-api.mjs +2 -1
  10. package/fesm2022/sunbird-cb-toc.mjs +7801 -6424
  11. package/fesm2022/sunbird-cb-toc.mjs.map +1 -1
  12. package/lib/_collection/_common/ai-tutor/ai-tutor.component.d.ts +140 -0
  13. package/lib/_collection/_common/ai-tutor/ai-tutor.component.d.ts.map +1 -0
  14. package/lib/_collection/_common/ai-tutor/socket.service.d.ts +20 -0
  15. package/lib/_collection/_common/ai-tutor/socket.service.d.ts.map +1 -0
  16. package/lib/_collection/_common/content-toc/ai-tutor-confirm-popup/ai-tutor-confirm-popup.component.d.ts +1 -1
  17. package/lib/_collection/_common/content-toc/ai-tutor-confirm-popup/ai-tutor-confirm-popup.component.d.ts.map +1 -1
  18. package/lib/_collection/_common/content-toc/content-toc.component.d.ts +2 -1
  19. package/lib/_collection/_common/content-toc/content-toc.component.d.ts.map +1 -1
  20. package/lib/_collection/_common/content-toc/content-toc.module.d.ts +29 -28
  21. package/lib/_collection/_common/content-toc/content-toc.module.d.ts.map +1 -1
  22. package/lib/services/root.service.d.ts +27 -0
  23. package/lib/services/root.service.d.ts.map +1 -0
  24. package/package.json +1 -1
  25. package/public-api.d.ts +1 -0
  26. package/public-api.d.ts.map +1 -1
@@ -0,0 +1,1169 @@
1
+ import { Component, EventEmitter, Input, Output, ViewChild, Inject } from '@angular/core';
2
+ import { NavigationEnd } from '@angular/router';
3
+ import { WsEvents } from '@sunbird-cb/utils-v2';
4
+ // import { MatLegacySnackBar as MatSnackBar } from '@angular/material/legacy-snack-bar'
5
+ import cloneDeep from 'lodash/cloneDeep';
6
+ import { NonReleventFeedbackDialogComponent } from '../../../components/non-relevent-feedback-dialog/non-relevent-feedback-dialog.component';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@angular/router";
9
+ import * as i2 from "@sunbird-cb/utils-v2";
10
+ import * as i3 from "./../../../services/root.service";
11
+ import * as i4 from "./socket.service";
12
+ import * as i5 from "@angular/material/legacy-dialog";
13
+ import * as i6 from "@angular/material/snack-bar";
14
+ import * as i7 from "@angular/common";
15
+ import * as i8 from "@angular/forms";
16
+ import * as i9 from "@angular/material/icon";
17
+ import * as i10 from "@angular/material/legacy-tooltip";
18
+ import * as i11 from "@angular/material/form-field";
19
+ import * as i12 from "@angular/material/select";
20
+ import * as i13 from "@angular/material/core";
21
+ export class AiTutorComponent {
22
+ constructor(route, configSvc, eventSvc, renderer, chatbotService, websocketService, dialog, matSnackBarNew, utilitySvc, environment, router) {
23
+ this.route = route;
24
+ this.configSvc = configSvc;
25
+ this.eventSvc = eventSvc;
26
+ this.renderer = renderer;
27
+ this.chatbotService = chatbotService;
28
+ this.websocketService = websocketService;
29
+ this.dialog = dialog;
30
+ this.matSnackBarNew = matSnackBarNew;
31
+ this.utilitySvc = utilitySvc;
32
+ this.router = router;
33
+ this.from = '';
34
+ this.userJourney = [];
35
+ this.showIcon = true;
36
+ this.categories = [];
37
+ this.language = [];
38
+ this.currentFilter = 'information';
39
+ this.selectedLaguage = 'en';
40
+ this.recomendedQns = {};
41
+ this.questionsAndAns = {};
42
+ this.userIcon = '';
43
+ this.more = false;
44
+ this.chatInformation = [];
45
+ this.chatIssues = [];
46
+ this.displayLoader = false;
47
+ this.expanded = false;
48
+ this.callText = '';
49
+ this.emailText = '';
50
+ this.searchQueryAItutor = '';
51
+ this.copiedIndex = -1;
52
+ this.random = Math.random().toString(36).slice(2);
53
+ this.iGOTAITutorResultArr = [];
54
+ this.maximize = true;
55
+ // tslint:disable
56
+ this.localization = {
57
+ 'en': {
58
+ 'Hi': 'Namaste',
59
+ 'information': 'Information',
60
+ 'issue': 'Issues',
61
+ 'categories': 'Show All Categories',
62
+ 'showmore': 'Show More'
63
+ },
64
+ 'hi': {
65
+ 'Hi': 'नमस्ते',
66
+ 'information': 'जानकारी',
67
+ 'issue': 'समस्या',
68
+ 'categories': 'सभी कैटगोरी दिखायें',
69
+ 'showmore': 'और दिखाओ'
70
+ }
71
+ };
72
+ this.colors = [
73
+ '#EB7181',
74
+ '#306933',
75
+ '#000000',
76
+ '#3670B2',
77
+ '#4E9E87',
78
+ '#7E4C8D',
79
+ ];
80
+ this.randomcolors = [
81
+ '#EB7181',
82
+ '#006400',
83
+ '#000000',
84
+ '#3670B2',
85
+ '#4E9E87',
86
+ '#7E4C8D',
87
+ ];
88
+ this.messages = [];
89
+ this.inputMessage = '';
90
+ this.aiTutorResultArr = [];
91
+ this.cloneSearchQuery = '';
92
+ this.jwtToken = '';
93
+ this.learningStyle = [
94
+ { title: 'None', subtitle: 'Learn with Natural query process' },
95
+ { title: 'Socratic Style', subtitle: 'Explore ideas through thoughtful questions.' },
96
+ { title: 'Storytelling', subtitle: 'Learn through relatable narratives and real-life examples.' },
97
+ ];
98
+ this.resultFetch = false;
99
+ this.authTokenHost = '';
100
+ this.NoneSocketHost = '';
101
+ this.SocraticeStyleHost = '';
102
+ this.StorytellingHost = '';
103
+ this.closeAIPopup = new EventEmitter();
104
+ this.containerHeight = 38;
105
+ this.isMobile = false;
106
+ this.showAITutorPopup = false;
107
+ this.chatId = '';
108
+ this.selectedLearningStyle = this.learningStyle[0];
109
+ this.environment = environment;
110
+ }
111
+ ngOnInit() {
112
+ this.isMobile = this.utilitySvc.isMobile;
113
+ if (this.environment?.sitePath?.includes('portal.igotkarmayogi.gov.in')) {
114
+ this.authTokenHost = 'learning-ai.prod.karmayogibharat.net';
115
+ this.NoneSocketHost = 'learning-ai.prod.karmayogibharat.net';
116
+ this.SocraticeStyleHost = 'learning-ai.prod.karmayogibharat.net';
117
+ this.StorytellingHost = 'learning-ai.prod.karmayogibharat.net';
118
+ }
119
+ else {
120
+ this.authTokenHost = 'learning-ai.uat.karmayogibharat.net';
121
+ this.NoneSocketHost = 'learning-ai.uat.karmayogibharat.net';
122
+ this.SocraticeStyleHost = 'learning-ai.uat.karmayogibharat.net';
123
+ this.StorytellingHost = 'learning-ai.uat.karmayogibharat.net';
124
+ }
125
+ this.userInfo = this.configSvc && this.configSvc.userProfile;
126
+ this.websocketService.getJWTToken().subscribe((data) => {
127
+ if (data && data['x-authenticated-user-token']) {
128
+ this.jwtToken = data['x-authenticated-user-token'];
129
+ //wss://learning-ai.uat.karmayogibharat.net/socratic/v1/
130
+ this.websocketService.connect(`wss://${this.authTokenHost}/ws?token=${this.jwtToken}`);
131
+ }
132
+ });
133
+ //let jwtToken = 'eyJhbGciOiJSUzI1NiIsInR5cCIgOiAiSldUIiwia2lkIiA6ICJhMTk5WXh3UkxNQWpBb3JVRmJUSkl4YjZDWE1JdUk4WVp4Y0pLaGxMdHQwIn0.eyJqdGkiOiI4ZWQ2MzE1Yi02OGQ1LTRhZDktYWU3MC1hYzRiNjZmNjIzOWIiLCJleHAiOjE3NDQ4NTM3NDMsIm5iZiI6MCwiaWF0IjoxNzQ0ODEwNTQzLCJpc3MiOiJodHRwczovL3BvcnRhbC51YXQua2FybWF5b2dpYmhhcmF0Lm5ldC9hdXRoL3JlYWxtcy9zdW5iaXJkIiwic3ViIjoiZjo5MWVjOTVkMi1hM2Q1LTQxM2UtYjRlNC01M2IwZGNjOTY0ODU6Y2VlYzAyYzYtYzE5MS00OWZlLTg0NTYtNjYyNDVhOWE3ODM1IiwidHlwIjoiQmVhcmVyIiwiYXpwIjoiYWRtaW4tY2xpIiwiYXV0aF90aW1lIjowLCJzZXNzaW9uX3N0YXRlIjoiYjUyNTliYmMtZDVjYy00YWJkLThjY2UtZThlZTZiYjA4NGYyIiwiYWNyIjoiMSIsImFsbG93ZWQtb3JpZ2lucyI6WyJodHRwOi8vbG9jYWxob3N0OjQyMDAiXSwicmVhbG1fYWNjZXNzIjp7InJvbGVzIjpbIm9mZmxpbmVfYWNjZXNzIiwidW1hX2F1dGhvcml6YXRpb24iXX0sInNjb3BlIjoiIiwib3JnIjoiMDEzMzc4MzA5NTgyMzgxMDU2MCIsIm5hbWUiOiJTcHYgQWRtaW4iLCJ1c2VyX3JvbGVzIjpbIk1FTlRPUiIsIlBVQkxJQyIsIlNQVl9BRE1JTiJdLCJwcmVmZXJyZWRfdXNlcm5hbWUiOiJzcHZhZG1pbl9qZzJ5IiwiZ2l2ZW5fbmFtZSI6IlNwdiBBZG1pbiIsImZhbWlseV9uYW1lIjoiIiwiZW1haWwiOiJzcCoqKioqKioqKioqQHlvcG1haWwuY29tIn0.naO_FUNci_ImWHQIylfmMGI2B-85koIyb9Sfy0mOguPpLIKeiGZiLZvccP_I_1QUScBewOrrP3fYxeq8oU98dj7sQGmBFOoU1dSZClZce3U4QEjSiugcbxdiNHcQXlpZTyub5aAJE-ub9Hb1bhS_RQjTMUeDfh5wrlZz6Lqg7kdDh5esXFLibfnUcFqmFFqZBtN5iP2sbRCnCFyS1Vw5TEFKxTiGdRPYT-XUzNE_iZuQPm2z-zyK0FEc1E9odaiwwpW5hkn3TznDwwXe7VdJS2E-HtjujmI-naAqZ__R68SuLyRHuq_PGhj2TZ_rjoaVIhjlgiFqHfOVLUsRat8HpA'
134
+ this.router.events.subscribe((event) => {
135
+ if (event instanceof NavigationEnd) {
136
+ //certificate link check
137
+ this.isHubEnable = (event.url.includes('/certs') || event.url.includes('/public/certs')) ? false : true;
138
+ }
139
+ });
140
+ this.userInfo = this.configSvc && this.configSvc.userProfile;
141
+ // this.aiGlobalSearch()
142
+ this.checkForApiCalls();
143
+ this.enableScroll();
144
+ // tslint:disable-next-line: max-line-length
145
+ this.userIcon = this.userInfo && this.userInfo.profileImageUrl ? this.userInfo.profileImageUrl : '';
146
+ if (!this.userInfo.profileImageUrl && this.userInfo && this.userInfo.firstName) {
147
+ this.createInititals(this.userInfo.firstName);
148
+ }
149
+ const email = this.environment.supportEmail || 'mission.karmayogi@gov.in';
150
+ this.callText = `<a class='hint-text' target='_blank' href='https://bit.ly/44MJlo4'>Teams Call</a>&nbsp;`;
151
+ this.emailText = `<a class='hint-text' target='_blank' href='mailto:${email}'>${email}.</a>`;
152
+ const event = {
153
+ eventType: WsEvents.WsEventType.Telemetry,
154
+ eventLogLevel: WsEvents.WsEventLogLevel.Info,
155
+ data: {
156
+ edata: { type: 'click', "id": "ai-tutor-card-content", "pageid": `viewer/${this.content}`, "subType": this.selectedLearningStyle.title },
157
+ object: { id: this.content },
158
+ state: WsEvents.EnumTelemetrySubType.Loaded,
159
+ eventSubType: WsEvents.EnumTelemetrySubType.Chatbot,
160
+ mode: 'view',
161
+ },
162
+ pageContext: { pageId: `viewer/${this.content}`, module: 'Learn' },
163
+ from: '',
164
+ to: 'Telemetry',
165
+ };
166
+ this.eventSvc.dispatchChatbotEvent(event);
167
+ const timestamp = Date.now();
168
+ this.chatId = `${this.configSvc.unMappedUser.userId}-${timestamp}`;
169
+ }
170
+ ngAfterViewInit() {
171
+ this.resizeTextarea(this.textArea?.nativeElement, '');
172
+ }
173
+ greetings() {
174
+ return this.localization[this.selectedLaguage]['Hi'] || 'Hi';
175
+ }
176
+ getInfoText(label) {
177
+ return this.localization[this.selectedLaguage][label] || label;
178
+ }
179
+ showMore() {
180
+ return this.localization[this.selectedLaguage]['showmore'] || 'Show More';
181
+ }
182
+ getData() {
183
+ const lang = {
184
+ information: 'IN',
185
+ issue: 'IS'
186
+ };
187
+ const tabType = {
188
+ lang: this.selectedLaguage,
189
+ config_type: lang[this.currentFilter]
190
+ };
191
+ this.displayLoader = true;
192
+ this.chatbotService.getChatData(tabType).subscribe((res) => {
193
+ if (res && res.payload && res.payload.config) {
194
+ this.setDataToLocalStorage(res.payload.config);
195
+ this.checkForApiCalls();
196
+ // this.initData(res.payload.config)
197
+ this.displayLoader = false;
198
+ }
199
+ });
200
+ }
201
+ setDataToLocalStorage(data) {
202
+ let localObject = {};
203
+ localObject = JSON.parse(localStorage.getItem('faq') || '{}');
204
+ localObject[this.selectedLaguage] = { ...localObject[this.selectedLaguage], [this.currentFilter]: data };
205
+ localStorage.setItem('faq', JSON.stringify(localObject));
206
+ this.toggleFilter(this.currentFilter === 'information' ? 'information' : this.currentFilter);
207
+ }
208
+ initData(_getData) {
209
+ // tslint:disable-next-line
210
+ // console.log(getData)
211
+ this.userJourney = [];
212
+ let userDetails = {
213
+ type: 'incoming',
214
+ message: '',
215
+ recommendedQues: this.getPriorityQuestion(1),
216
+ selectedValue: '',
217
+ title: '',
218
+ tab: 'information',
219
+ };
220
+ this.pushData(userDetails);
221
+ // this.pushData(userDetailsForIssues)
222
+ this.getQns();
223
+ }
224
+ getQns() {
225
+ this.responseData.quesMap.map((q) => {
226
+ this.questionsAndAns[q.quesId] = q;
227
+ });
228
+ }
229
+ selectLaguage(event) {
230
+ this.selectedLaguage = event.target.value;
231
+ localStorage.setItem('selectedLanguage', event.target.value);
232
+ this.chatInformation = [];
233
+ this.chatIssues = [];
234
+ this.checkForApiCalls();
235
+ }
236
+ readFromLocalStorage() {
237
+ let localStg = localStorage.getItem('result');
238
+ if (localStg) {
239
+ if (this.currentFilter === 'information') {
240
+ this.responseData = JSON.parse(localStg)[this.selectedLaguage].information;
241
+ }
242
+ else {
243
+ this.responseData = JSON.parse(localStg)[this.selectedLaguage].issue;
244
+ }
245
+ }
246
+ }
247
+ goToBottom() {
248
+ window.scrollTo(0, document.body.scrollHeight);
249
+ }
250
+ iconClick(type) {
251
+ this.showIcon = !this.showIcon;
252
+ this.currentFilter = 'information';
253
+ this.expanded = false;
254
+ if (type === 'start') {
255
+ this.disableScroll();
256
+ this.raiseChatStartTelemetry();
257
+ // this.toggleFilter(this.currentFilter)
258
+ }
259
+ else {
260
+ this.raiseChatEndTelemetry();
261
+ this.userJourney = [];
262
+ this.chatInformation = [];
263
+ this.chatIssues = [];
264
+ this.selectedLaguage = 'en';
265
+ this.currentFilter = 'information';
266
+ this.checkForApiCalls();
267
+ this.more = false;
268
+ this.enableScroll();
269
+ }
270
+ }
271
+ toggleFilter(tab) {
272
+ this.currentFilter = tab;
273
+ this.checkForApiCalls();
274
+ this.more = false;
275
+ }
276
+ selectedQuestion(question, data) {
277
+ data.selectedValue = question.quesID;
278
+ const sendMsg = {
279
+ type: 'sendMsg',
280
+ question: this.questionsAndAns[question.quesID].quesValue,
281
+ tab: this.currentFilter,
282
+ };
283
+ const incomingMsg = {
284
+ type: 'incoming',
285
+ // tslint:disable-next-line:max-line-length
286
+ message: this.questionsAndAns[question.quesID].ansVal.replace('<teams_call_link>', this.callText).replace('<email_configuration>', this.emailText),
287
+ recommendedQues: question.recommendedQues || [],
288
+ title: '',
289
+ relatedQes: 'above Question',
290
+ tab: this.currentFilter,
291
+ };
292
+ this.pushData(sendMsg);
293
+ this.pushData(incomingMsg);
294
+ this.raiseTemeletyInterat(question.quesID);
295
+ }
296
+ pushData(msg) {
297
+ this.userJourney = [];
298
+ if (this.currentFilter === 'information') {
299
+ this.chatInformation.push(msg);
300
+ this.userJourney = this.chatInformation;
301
+ }
302
+ else {
303
+ this.chatIssues.push(msg);
304
+ this.userJourney = this.chatIssues;
305
+ }
306
+ }
307
+ getuserjourney(tab) {
308
+ return this.userJourney.filter((j) => j.tab === tab);
309
+ }
310
+ getPriorityQuestion(priority) {
311
+ const recommendedQues = [];
312
+ const isLogedIn = this.userInfo ? 'Logged-In' : 'Not Logged-In';
313
+ this.responseData.recommendationMap.map((question) => {
314
+ question.recommendedQues.map((ques) => {
315
+ if (ques.priority === priority && (question.categoryType === isLogedIn || question.categoryType === 'Both')) {
316
+ recommendedQues.push(ques);
317
+ }
318
+ });
319
+ });
320
+ return recommendedQues;
321
+ }
322
+ showMoreQuestion() {
323
+ const showMoreQes = {
324
+ type: 'incoming',
325
+ message: '',
326
+ recommendedQues: this.getPriorityQuestion(1),
327
+ selectedValue: '',
328
+ title: '', //'Showing more questions',
329
+ };
330
+ this.pushData(showMoreQes);
331
+ }
332
+ showCategory(catItem) {
333
+ let incomingMsg = {
334
+ type: 'category',
335
+ message: '',
336
+ recommendedQues: [],
337
+ title: '',
338
+ relatedQes: `${catItem.catName}?`,
339
+ tab: this.currentFilter,
340
+ };
341
+ this.more = false;
342
+ if (catItem.catId === 'all') {
343
+ incomingMsg.title = '', // 'Here is the list of all the topics'
344
+ incomingMsg.relatedQes = '';
345
+ incomingMsg.recommendedQues = this.sortCategory();
346
+ }
347
+ else {
348
+ this.responseData.recommendationMap.forEach((element) => {
349
+ if (catItem.catId === element.catId) {
350
+ incomingMsg.type = 'incoming',
351
+ incomingMsg.recommendedQues = element.recommendedQues;
352
+ }
353
+ });
354
+ this.raiseCategotyTelemetry(catItem.catId);
355
+ }
356
+ const sendMsg = {
357
+ type: 'sendMsg',
358
+ question: catItem.catName,
359
+ };
360
+ this.pushData(sendMsg);
361
+ this.pushData(incomingMsg);
362
+ }
363
+ raiseCategotyTelemetry(catItem) {
364
+ const event = {
365
+ eventType: WsEvents.WsEventType.Telemetry,
366
+ eventLogLevel: WsEvents.WsEventLogLevel.Info,
367
+ data: {
368
+ edata: { type: 'click', id: catItem },
369
+ object: { id: catItem, type: 'Category' },
370
+ state: WsEvents.EnumTelemetrySubType.Interact,
371
+ eventSubType: WsEvents.EnumTelemetrySubType.Chatbot,
372
+ mode: 'view',
373
+ },
374
+ pageContext: { pageId: '/chatbot', module: 'Assistant' },
375
+ from: '',
376
+ to: 'Telemetry',
377
+ };
378
+ this.eventSvc.dispatchChatbotEvent(event);
379
+ }
380
+ raiseChatStartTelemetry() {
381
+ const event = {
382
+ eventType: WsEvents.WsEventType.Telemetry,
383
+ eventLogLevel: WsEvents.WsEventLogLevel.Info,
384
+ data: {
385
+ edata: { type: '' },
386
+ object: { type: 'zse', id: 'asd' },
387
+ state: WsEvents.EnumTelemetrySubType.Loaded,
388
+ eventSubType: WsEvents.EnumTelemetrySubType.Chatbot,
389
+ type: 'session',
390
+ mode: 'view',
391
+ },
392
+ pageContext: { pageId: '/chatbot', module: 'Assistant' },
393
+ from: '',
394
+ to: 'Telemetry',
395
+ };
396
+ this.eventSvc.dispatchChatbotEvent(event);
397
+ }
398
+ raiseChatEndTelemetry() {
399
+ const event = {
400
+ eventType: WsEvents.WsEventType.Telemetry,
401
+ eventLogLevel: WsEvents.WsEventLogLevel.Info,
402
+ data: {
403
+ edata: { type: '' },
404
+ object: {},
405
+ state: WsEvents.EnumTelemetrySubType.Unloaded,
406
+ eventSubType: WsEvents.EnumTelemetrySubType.Chatbot,
407
+ type: 'session',
408
+ mode: 'view',
409
+ },
410
+ pageContext: { pageId: '/chatbot', module: 'Assistant' },
411
+ from: '',
412
+ to: 'Telemetry',
413
+ };
414
+ this.eventSvc.dispatchChatbotEvent(event);
415
+ }
416
+ raiseTemeletyInterat(idn) {
417
+ const event = {
418
+ eventType: WsEvents.WsEventType.Telemetry,
419
+ eventLogLevel: WsEvents.WsEventLogLevel.Info,
420
+ data: {
421
+ edata: { type: 'click', id: idn },
422
+ object: { id: idn, type: this.currentFilter.charAt(0).toUpperCase() + this.currentFilter.slice(1) },
423
+ state: WsEvents.EnumTelemetrySubType.Interact,
424
+ eventSubType: WsEvents.EnumTelemetrySubType.Chatbot,
425
+ mode: 'view'
426
+ },
427
+ pageContext: { pageId: '/chatbot', module: 'Assistant' },
428
+ from: '',
429
+ to: 'Telemetry',
430
+ };
431
+ this.eventSvc.dispatchChatbotEvent(event);
432
+ }
433
+ checkForAIQuestionResponse() {
434
+ }
435
+ checkForApiCalls() {
436
+ this.selectedLaguage = localStorage.getItem('selectedLanguage') || 'en';
437
+ let localStg = JSON.parse(localStorage.getItem('faq') || '{}');
438
+ let languageStg = JSON.parse(localStorage.getItem('faq-languages') || '{}');
439
+ if (languageStg.length > 0) {
440
+ this.language = languageStg;
441
+ }
442
+ else {
443
+ this.getLanguages();
444
+ }
445
+ if (localStg && languageStg) {
446
+ if (localStg[this.selectedLaguage] && localStg[this.selectedLaguage][this.currentFilter]) {
447
+ const localStorageData = localStg[this.selectedLaguage][this.currentFilter];
448
+ this.userJourney = [];
449
+ if (this.currentFilter === 'information') {
450
+ if (this.chatInformation.length === 0) {
451
+ this.responseData = localStorageData;
452
+ this.initData(localStorageData);
453
+ }
454
+ else {
455
+ this.responseData = localStorageData;
456
+ this.userJourney = this.chatInformation;
457
+ }
458
+ }
459
+ else {
460
+ if (this.chatIssues.length === 0) {
461
+ this.responseData = localStorageData;
462
+ this.initData(localStorageData);
463
+ }
464
+ else {
465
+ this.responseData = localStorageData;
466
+ this.userJourney = this.chatIssues;
467
+ }
468
+ }
469
+ this.getQns();
470
+ this.getCategories();
471
+ }
472
+ else {
473
+ this.getLanguages();
474
+ // this.getData()
475
+ }
476
+ }
477
+ }
478
+ getCategories() {
479
+ this.categories = [{ catId: 'all', catName: this.localization[this.selectedLaguage]['categories'], priority: 0 }];
480
+ const categories = [];
481
+ const isLogedIn = this.userInfo ? 'Logged-In' : 'Not Logged-In';
482
+ this.responseData.recommendationMap.map((catandques) => {
483
+ this.responseData.categoryMap.map((cat) => {
484
+ if (catandques.catId === cat.catId && (catandques.categoryType === isLogedIn || catandques.categoryType === 'Both')) {
485
+ const category = {
486
+ catId: cat.catId,
487
+ catName: cat.catName,
488
+ priority: catandques.priority,
489
+ categoryType: catandques.categoryType,
490
+ };
491
+ categories.push(category);
492
+ }
493
+ });
494
+ });
495
+ if (categories.length < 6) {
496
+ this.categories = categories;
497
+ }
498
+ else {
499
+ this.categories = [...this.categories, ...categories];
500
+ }
501
+ }
502
+ sortCategory() {
503
+ // tslint:disable-next-line: max-line-length
504
+ return this.categories.sort((a, b) => a['priority'] > b['priority'] ? 1 : a['priority'] === b['priority'] ? 0 : -1);
505
+ }
506
+ getLanguages() {
507
+ this.displayLoader = true;
508
+ this.chatbotService.getLangugages().subscribe((resp) => {
509
+ if (resp && resp.status && resp.status.code === 200) {
510
+ this.language = resp.payload.languages;
511
+ localStorage.setItem('faq-languages', JSON.stringify(resp.payload.languages));
512
+ localStorage.setItem('selectedLanguage', this.selectedLaguage);
513
+ this.getData();
514
+ this.displayLoader = false;
515
+ }
516
+ });
517
+ }
518
+ ngAfterViewChecked() {
519
+ // this.scrollToBottom()
520
+ }
521
+ scrollToBottom() {
522
+ let messageContainer = document.getElementById('container-none');
523
+ if (messageContainer) {
524
+ messageContainer.scrollTo({ top: messageContainer.scrollHeight, behavior: 'smooth' });
525
+ }
526
+ }
527
+ clickOutside() {
528
+ this.iconClick('end');
529
+ }
530
+ disableScroll() {
531
+ this.renderer.addClass(document.body, 'disable-scroll');
532
+ }
533
+ enableScroll() {
534
+ this.renderer.removeClass(document.body, 'disable-scroll');
535
+ }
536
+ submitSearchQuery(textArea, event) {
537
+ if (!this.searchQueryAItutor.trim()) {
538
+ event.preventDefault(); // Prevents Enter key from adding a new line
539
+ }
540
+ if (!this.searchQueryAItutor.trim()) {
541
+ return false;
542
+ }
543
+ this.cloneSearchQuery = '';
544
+ this.cloneSearchQuery = cloneDeep(this.searchQueryAItutor);
545
+ this.searchQueryAItutor = this.searchQueryAItutor.trim();
546
+ this.searchQueryAItutor = '';
547
+ this.resetTextAreaHeight(textArea);
548
+ this.aiTutorResultArr.map((item, index) => {
549
+ if (item && (item.newMessage === '')) {
550
+ // delete this.aiTutorResultArr[index]
551
+ this.aiTutorResultArr.splice(index, 1);
552
+ }
553
+ });
554
+ this.resultFetch = false;
555
+ // this.searchQuery = 'Soil Erosion and Conservation'
556
+ let sendMsgObj = {
557
+ type: 'sendMsg',
558
+ tab: 'sarthi',
559
+ question: this.cloneSearchQuery
560
+ };
561
+ this.aiTutorResultArr.push(sendMsgObj);
562
+ this.aiTutorResultArr.push({ type: 'incoming', tab: 'sarthi', answer: '', newMessage: '' });
563
+ // this.searchQuery = ''
564
+ // this.aiGlobalSearch()
565
+ // this.getAiTutorMessage()
566
+ setTimeout(() => {
567
+ this.scrollToBottom();
568
+ }, 0);
569
+ this.sendAITutorMessage();
570
+ }
571
+ sendAITutorMessage() {
572
+ if (this.cloneSearchQuery) {
573
+ let message = {
574
+ message: this.cloneSearchQuery,
575
+ query: this.cloneSearchQuery,
576
+ folder_name: this.content //this.content
577
+ };
578
+ this.websocketService.sendMessage(message);
579
+ setTimeout(() => {
580
+ this.getAiTutorMessage();
581
+ }, 1000);
582
+ }
583
+ }
584
+ getAiTutorMessage() {
585
+ this.messageSubscription = this.websocketService
586
+ .getMessages()
587
+ .subscribe((message) => {
588
+ // this.messages.push(message);
589
+ this.aiTutorResult = message;
590
+ this.resultFetch = true;
591
+ this.aiTutorResultMessage();
592
+ // this.searchQueryAItutor = '';
593
+ });
594
+ }
595
+ aiTutorResultMessage() {
596
+ this.iGOTAITutorResultArr = [];
597
+ // let requestBody:any = {
598
+ // "query":this.cloneSearchQuery
599
+ // }
600
+ // this.chatbotService.aiGlobalSearch(requestBody).subscribe((data)=>{
601
+ // console.log('data--', data)
602
+ // })
603
+ // console.log('requestBody', requestBody)
604
+ // console.log('aiSearchResult', this.aiTutorResult)
605
+ // console.log('this.aiSearchResultArr', this.aiTutorResultArr)
606
+ const queryString = Object.entries(this.route.snapshot.queryParams)
607
+ .map(([key, value]) => `${encodeURI(key)}=${encodeURI(value)}`)
608
+ .join('&');
609
+ //const queryString = new URLSearchParams(this.route.snapshot.queryParams).toString();
610
+ // let arr:any = []
611
+ console.log('this.aiTutorResult--', this.aiTutorResult);
612
+ if (this.aiTutorResult && !this.aiTutorResult.answer && !this.aiTutorResult.retrievedChunks) {
613
+ this.aiTutorResult.retrievedChunks = [];
614
+ }
615
+ this.aiTutorResult.retrievedChunks && this.aiTutorResult.retrievedChunks.map((item) => {
616
+ let startTime = -1;
617
+ let endTime = -1;
618
+ let pageNumber = 1;
619
+ if (item && item?.ContentStart?.trim()) {
620
+ startTime = item?.ContentStart;
621
+ pageNumber = item?.ContentStart;
622
+ }
623
+ if (item && item?.ContentEnd?.trim()) {
624
+ endTime = item?.ContentEnd;
625
+ pageNumber = item?.ContentEnd;
626
+ }
627
+ pageNumber = pageNumber !== " " ? pageNumber : 1;
628
+ let resultObj = {
629
+ message: item.Name,
630
+ recommendedQues: '',
631
+ selectedValue: '',
632
+ title: item.Name,
633
+ content: item,
634
+ mimeType: item.MimeType,
635
+ contentType: item.ContentType,
636
+ artifactUrl: item.ArtifactURL,
637
+ description: item?.Description?.replace(/^\s{4,}/gm, ''),
638
+ identifier: item.Identifier,
639
+ contentStart: startTime,
640
+ contentEnd: endTime,
641
+ pageNumber: pageNumber ? pageNumber : 1,
642
+ query: this.aiTutorResult.query,
643
+ query_id: this.aiTutorResult.query_id,
644
+ feedback: '',
645
+ resourceLink: item.MimeType === 'application/pdf' ? `https://portal.igotkarmayogi.gov.in/viewer/pdf/${item.Identifier}?${queryString}&from=globalSearch&playerPreview=true&pn=${pageNumber}` :
646
+ (startTime <= 0 && endTime <= 0) ? `https://portal.igotkarmayogi.gov.in/viewer/video/${item.Identifier}?${queryString}&from=globalSearch&playerPreview=true` : `https://portal.igotkarmayogi.gov.in/viewer/video/${item.Identifier}?${queryString}&from=globalSearch&playerPreview=true&st=${startTime}&et=${endTime}`
647
+ };
648
+ // arr.push(resultObj)
649
+ this.iGOTAITutorResultArr.push(resultObj);
650
+ });
651
+ let answer = this.aiTutorResult.answer ? this.aiTutorResult.answer.trim().replace(/\n/g, '<br>') : "";
652
+ let shortAnswer = this.splitParagraphByWords(answer);
653
+ // console.log(this.aiTutorResult.retrievedChunks, { wordsCount: answer.trim().split(/\s+/).length, showLess: answer.trim().split(/\s+/).length > 30 ? true : false ,answer: answer, shortAnswer: shortAnswer ,result: this.iGOTAITutorResultArr, type: 'incoming', tab: 'sarthi',reterivedChunks: this.iGOTAITutorResultArr.retrievedChunks, showFromInternet: (!this.aiTutorResult.retrievedChunks ? true : false)});
654
+ this.aiTutorResultArr.push({ query: this.aiTutorResult.query, query_id: this.aiTutorResult.query_id, clientId: this.aiTutorResult.clientId, wordsCount: answer.trim().split(/\s+/).length, showLess: answer.trim().split(/\s+/).length > 30 ? true : false, answer: answer, shortAnswer: shortAnswer, result: this.iGOTAITutorResultArr, type: 'incoming', tab: 'sarthi', reterivedChunks: this.iGOTAITutorResultArr.retrievedChunks, showFromInternet: (!(this.aiTutorResult.answer) && !(this.aiTutorResult.retrievedChunks)) ? true : false });
655
+ this.aiTutorResultArr.map((item, index) => {
656
+ if (item && (item.newMessage === '')) {
657
+ // delete this.aiSearchResultArr[index]
658
+ this.aiTutorResultArr.splice(index, 1);
659
+ }
660
+ });
661
+ console.log('this.aiTutorResultArr---', this.aiTutorResultArr);
662
+ setTimeout(() => {
663
+ // this.scrollToBottom()
664
+ }, 0);
665
+ const event = {
666
+ eventType: WsEvents.WsEventType.Telemetry,
667
+ eventLogLevel: WsEvents.WsEventLogLevel.Info,
668
+ data: {
669
+ edata: { type: 'click', "id": "ai-tutor-card-content", "pageid": `viewer/${this.content}`, "subType": this.selectedLearningStyle.title },
670
+ object: {},
671
+ state: WsEvents.EnumTelemetrySubType.Interact,
672
+ eventSubType: WsEvents.EnumTelemetrySubType.Chatbot,
673
+ mode: 'view',
674
+ },
675
+ pageContext: { pageId: `viewer/${this.content}`, module: 'Learn' },
676
+ from: '',
677
+ to: 'Telemetry',
678
+ };
679
+ this.eventSvc.dispatchChatbotEvent(event);
680
+ }
681
+ redirectToResource(item) {
682
+ let queryParams = { ...this.route.snapshot.queryParams };
683
+ console.log(queryParams);
684
+ // Remove specific parameters
685
+ delete queryParams.st;
686
+ delete queryParams.et;
687
+ delete queryParams.pn;
688
+ delete queryParams.from;
689
+ delete queryParams.playerPreview;
690
+ let queryString = '';
691
+ queryString = Object.entries(queryParams)
692
+ .map(([key, value]) => `${encodeURI(key)}=${encodeURI(value)}`)
693
+ .join('&');
694
+ let path = '';
695
+ path = (item.mimeType === 'application/pdf') ? `/viewer/pdf/${item.identifier}?${queryString}&from=globalSearch&playerPreview=true&pn=${item?.pageNumber}` :
696
+ (item?.contentStart <= 0 && item?.contentEnd <= 0) ? `/viewer/video/${item.identifier}?${queryString}&from=globalSearch&playerPreview=true` : `/viewer/video/${item.identifier}?${queryString}&from=globalSearch&playerPreview=true&st=${item?.contentStart}&et=${item?.contentEnd}`;
697
+ // console.log('path', path)
698
+ // window.open(path, '_blank')
699
+ if (this.isMobile) {
700
+ this.maximize = false;
701
+ }
702
+ this.router.navigateByUrl(path);
703
+ }
704
+ copyPath(item, cindex) {
705
+ const queryString = Object.entries(this.route.snapshot.queryParams)
706
+ .map(([key, value]) => `${encodeURI(key)}=${encodeURI(value)}`)
707
+ .join('&');
708
+ //const queryString = new URLSearchParams(this.route.snapshot.queryParams).toString();
709
+ const selBox = document.createElement('textarea');
710
+ selBox.style.position = 'fixed';
711
+ selBox.style.left = '0';
712
+ selBox.style.top = '0';
713
+ selBox.style.opacity = '0';
714
+ selBox.value = item.mimeType === 'application/pdf' ? `https://portal.igotkarmayogi.gov.in/viewer/pdf/${item.identifier}?${queryString}&from=globalSearch&playerPreview=true&pn=${item?.pageNumber}` :
715
+ (item?.contentStart <= 0 && item?.contentEnd <= 0) ? `https://portal.igotkarmayogi.gov.in/viewer/video/${item.identifier}?${queryString}&from=globalSearch&playerPreview=true` : `https://portal.igotkarmayogi.gov.in/viewer/video/${item.identifier}?${queryString}&from=globalSearch&playerPreview=true&st=${item?.contentStart}&et=${item?.contentEnd}`;
716
+ document.body.appendChild(selBox);
717
+ selBox.focus();
718
+ selBox.select();
719
+ document.execCommand('copy');
720
+ document.body.removeChild(selBox);
721
+ this.copiedIndex = cindex;
722
+ setTimeout(() => {
723
+ this.copiedIndex = -1;
724
+ }, 1000);
725
+ }
726
+ redirectToToc(chat) {
727
+ const event = {
728
+ eventType: WsEvents.WsEventType.Telemetry,
729
+ eventLogLevel: WsEvents.WsEventLogLevel.Info,
730
+ data: {
731
+ edata: { type: 'click', "id": "ai-tutor-card-content", "pageid": `viewer/${this.content}`, "subType": this.selectedLearningStyle.title },
732
+ object: { id: chat?.identifier, type: chat?.contentType },
733
+ state: WsEvents.EnumTelemetrySubType.Interact,
734
+ eventSubType: WsEvents.EnumTelemetrySubType.Chatbot,
735
+ mode: 'view',
736
+ },
737
+ pageContext: { pageId: `viewer/${this.content}`, module: 'Learn' },
738
+ from: '',
739
+ to: 'Telemetry',
740
+ };
741
+ this.eventSvc.dispatchChatbotEvent(event);
742
+ let path = `https://portal.igotkarmayogi.gov.in/app/toc/${chat?.identifier}/overview`;
743
+ window.open(path, '_blank');
744
+ }
745
+ splitParagraphByWords(paragraph, wordsPerChunk = 30) {
746
+ const words = paragraph.trim().split(/\s+/);
747
+ const chunks = [];
748
+ for (let i = 0; i < wordsPerChunk; i++) {
749
+ chunks.push(words[i]);
750
+ }
751
+ return chunks.join(' ');
752
+ }
753
+ toggleShow(index, showType) {
754
+ if (showType === 'less') {
755
+ this.aiTutorResultArr[index]['showLess'] = true;
756
+ }
757
+ else {
758
+ this.aiTutorResultArr[index]['showLess'] = false;
759
+ }
760
+ }
761
+ get userInitials() {
762
+ return this.initials;
763
+ }
764
+ createInititals(name) {
765
+ const randomIndex = Math.floor(Math.random() * Math.floor(this.colors.length));
766
+ this.circleColor = this.colors[randomIndex];
767
+ if (this.randomcolors) {
768
+ const randomIndex1 = Math.floor(Math.random() * Math.floor(this.randomcolors.length));
769
+ this.circleColor = this.randomcolors[randomIndex1];
770
+ }
771
+ let initials = '';
772
+ const array = `${name} `.toString().split(' ');
773
+ if (array[0] !== 'undefined' && typeof array[1] !== 'undefined') {
774
+ initials += array[0].charAt(0);
775
+ initials += array[1].charAt(0);
776
+ }
777
+ else {
778
+ for (let i = 0; i < name.length; i += 1) {
779
+ if (name.charAt(i) === ' ') {
780
+ continue;
781
+ }
782
+ if (name && (name.charAt(i) === name.charAt(i))) {
783
+ initials += name.charAt(i);
784
+ if (initials.length === 2) {
785
+ break;
786
+ }
787
+ }
788
+ }
789
+ }
790
+ this.initials = initials.toUpperCase();
791
+ }
792
+ getLearningStyle() {
793
+ const timestamp = Date.now();
794
+ this.chatId = `${this.configSvc.unMappedUser.userId}-${timestamp}`;
795
+ if (this.selectedLearningStyle && this.selectedLearningStyle.title === 'Socratic Style') {
796
+ this.aiTutorResultArr = [];
797
+ this.websocketService.closeConnection();
798
+ this.chatId = `${this.configSvc.unMappedUser.userId}-${timestamp}`;
799
+ this.websocketService.connect(`wss://${this.SocraticeStyleHost}/socratic/v1/ws?token=${this.jwtToken}`);
800
+ }
801
+ else if (this.selectedLearningStyle && this.selectedLearningStyle.title === 'None') {
802
+ this.aiTutorResultArr = [];
803
+ this.websocketService.closeConnection();
804
+ this.chatId = `${this.configSvc.unMappedUser.userId}-${timestamp}`;
805
+ this.websocketService.connect(`wss://${this.NoneSocketHost}/ws?token=${this.jwtToken}`);
806
+ }
807
+ else if (this.selectedLearningStyle && this.selectedLearningStyle.title === 'Storytelling') {
808
+ this.aiTutorResultArr = [];
809
+ this.websocketService.closeConnection();
810
+ this.chatId = `${this.configSvc.unMappedUser.userId}-${timestamp}`;
811
+ this.websocketService.connect(`wss://${this.StorytellingHost}/storytelling/v1/ws?token=${this.jwtToken}`);
812
+ }
813
+ // console.log('selectedLearningStyle--', this.selectedLearningStyle)
814
+ }
815
+ raiseTelemetryForResource(item) {
816
+ const event = {
817
+ eventType: WsEvents.WsEventType.Telemetry,
818
+ eventLogLevel: WsEvents.WsEventLogLevel.Info,
819
+ data: {
820
+ edata: { type: 'click', "id": "ai-tutor-card-content", "pageid": `viewer/${this.content}`, "subType": this.selectedLearningStyle.title },
821
+ object: { id: item?.identifier, type: item?.contentType },
822
+ state: WsEvents.EnumTelemetrySubType.Interact,
823
+ eventSubType: WsEvents.EnumTelemetrySubType.Chatbot,
824
+ mode: 'view',
825
+ },
826
+ pageContext: { pageId: `viewer/${this.content}`, module: 'Learn' },
827
+ from: '',
828
+ to: 'Telemetry',
829
+ };
830
+ this.eventSvc.dispatchChatbotEvent(event);
831
+ }
832
+ sharePositiveContentRating(item, index, cindex) {
833
+ let requestBody = {
834
+ "query_id": item?.query_id,
835
+ "response": this.aiTutorResultArr[index]['answer'],
836
+ "comments": "",
837
+ "is_liked": true,
838
+ "rating": "5",
839
+ "identifier": this.content,
840
+ "query": item.query,
841
+ chat_id: this.chatId,
842
+ user_id: this.configSvc.unMappedUser.userId,
843
+ };
844
+ if (this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index]) {
845
+ if (this.aiTutorResultArr[index].result && this.aiTutorResultArr[index].result[cindex])
846
+ this.aiTutorResultArr[index].result[cindex]['showLoader'] = true;
847
+ this.aiTutorResultArr[index].result[cindex]['showLoaderForUp'] = true;
848
+ }
849
+ //this.matSnackBar.open('Unable to fetch content data, due to some error!')
850
+ this.chatbotService.saveAIChatPositiveContentRating(requestBody, this.chatId, this.userInfo?.userId).subscribe((data) => {
851
+ if (data && data.status === 'success') {
852
+ if (this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index]) {
853
+ if (this.aiTutorResultArr[index].result && this.aiTutorResultArr[index].result[cindex])
854
+ this.aiTutorResultArr[index].result[cindex]['feedback'] = 'up';
855
+ this.aiTutorResultArr[index].result[cindex]['showLoader'] = false;
856
+ this.aiTutorResultArr[index].result[cindex]['showLoaderForUp'] = false;
857
+ }
858
+ this.matSnackBarNew.open('Thank you for your feedback.', 'X', { duration: 5000, panelClass: ['success'] });
859
+ }
860
+ else {
861
+ if (this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index]) {
862
+ if (this.aiTutorResultArr[index].result && this.aiTutorResultArr[index].result[cindex])
863
+ this.aiTutorResultArr[index].result[cindex]['showLoader'] = false;
864
+ this.aiTutorResultArr[index].result[cindex]['showLoaderForUp'] = false;
865
+ }
866
+ this.matSnackBarNew.open('Something is wrong. Please try again later.', 'X', { duration: 5000, panelClass: ['error'] });
867
+ }
868
+ });
869
+ }
870
+ openAIFeedbackPopup(item, index, cindex) {
871
+ if (this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index] && this.aiTutorResultArr[index]) {
872
+ if (this.aiTutorResultArr[index].result && this.aiTutorResultArr[index].result[cindex] && this.aiTutorResultArr[index].result[cindex]['feedback'] !== 'down') {
873
+ const dialogRef = this.dialog.open(NonReleventFeedbackDialogComponent, {
874
+ disableClose: true,
875
+ width: '502px',
876
+ panelClass: ['relevent-feedback-dialog'],
877
+ });
878
+ dialogRef.afterClosed().subscribe((result) => {
879
+ if (result) {
880
+ this.shareAIFeedback(item, result, index, cindex);
881
+ dialogRef.close();
882
+ }
883
+ else {
884
+ dialogRef.close();
885
+ }
886
+ });
887
+ }
888
+ else {
889
+ this.matSnackBarNew.open('You have already submitted feedback', 'X', { duration: 5000, panelClass: ['error'] });
890
+ }
891
+ }
892
+ }
893
+ shareAIFeedback(item, result, index, cindex) {
894
+ let requestBody = {
895
+ "query_id": item?.query_id,
896
+ "response": this.aiTutorResultArr[index]['answer'],
897
+ "comments": result,
898
+ "is_liked": false,
899
+ "rating": "0",
900
+ "identifier": this.content,
901
+ "query": item.query,
902
+ chat_id: this.chatId,
903
+ user_id: this.configSvc.unMappedUser.userId,
904
+ };
905
+ if (this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index]) {
906
+ if (this.aiTutorResultArr[index].result && this.aiTutorResultArr[index].result[cindex]) {
907
+ this.aiTutorResultArr[index].result[cindex]['showLoader'] = true;
908
+ this.aiTutorResultArr[index].result[cindex]['showLoaderForDown'] = true;
909
+ }
910
+ }
911
+ this.chatbotService.shareAIFeedback(requestBody, this.chatId, this.userInfo?.userId).subscribe((data) => {
912
+ if (data && data.status === 'success') {
913
+ if (this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index]) {
914
+ if (this.aiTutorResultArr[index].result && this.aiTutorResultArr[index].result[cindex])
915
+ this.aiTutorResultArr[index].result[cindex]['feedback'] = 'down';
916
+ this.aiTutorResultArr[index].result[cindex]['showLoader'] = false;
917
+ this.aiTutorResultArr[index].result[cindex]['showLoaderForDown'] = false;
918
+ }
919
+ this.matSnackBarNew.open('Thank you for your feedback.', 'X', { duration: 5000, panelClass: ['success'] });
920
+ }
921
+ else {
922
+ if (this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index]) {
923
+ if (this.aiTutorResultArr[index].result && this.aiTutorResultArr[index].result[cindex])
924
+ this.aiTutorResultArr[index].result[cindex]['showLoader'] = false;
925
+ this.aiTutorResultArr[index].result[cindex]['showLoaderForDown'] = false;
926
+ }
927
+ this.matSnackBarNew.open('Something is wrong. Please try again later.', 'X', { duration: 5000, panelClass: ['error'] });
928
+ }
929
+ });
930
+ }
931
+ sharePositiveContentRatingForAnswer(item, index) {
932
+ let requestBody = {
933
+ "query_id": item.query_id,
934
+ "response": item.answer,
935
+ "comments": "",
936
+ "is_liked": true,
937
+ "rating": "5",
938
+ "identifier": this.content,
939
+ "query": item.query
940
+ };
941
+ if (this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index]) {
942
+ if (this.aiTutorResultArr[index] && this.aiTutorResultArr[index])
943
+ this.aiTutorResultArr[index]['showLoader'] = true;
944
+ this.aiTutorResultArr[index]['showLoaderForUp'] = true;
945
+ }
946
+ //this.matSnackBar.open('Unable to fetch content data, due to some error!')
947
+ this.chatbotService.saveAIChatPositiveContentRating(requestBody, this.chatId, this.userInfo?.userId).subscribe((data) => {
948
+ if (data && data.status === 'success') {
949
+ if (this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index]) {
950
+ if (this.aiTutorResultArr[index] && this.aiTutorResultArr[index])
951
+ this.aiTutorResultArr[index]['feedback'] = 'up';
952
+ this.aiTutorResultArr[index]['showLoader'] = false;
953
+ this.aiTutorResultArr[index]['showLoaderForUp'] = false;
954
+ }
955
+ this.matSnackBarNew.open('Thank you for your feedback.', 'X', { duration: 5000, panelClass: ['success'] });
956
+ }
957
+ else {
958
+ if (this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index]) {
959
+ if (this.aiTutorResultArr[index] && this.aiTutorResultArr[index])
960
+ this.aiTutorResultArr[index]['showLoader'] = false;
961
+ this.aiTutorResultArr[index]['showLoaderForUp'] = false;
962
+ }
963
+ this.matSnackBarNew.open('Something is wrong. Please try again later.', 'X', { duration: 5000, panelClass: ['error'] });
964
+ }
965
+ });
966
+ }
967
+ openAIFeedbackPopupForAnswer(item, index) {
968
+ if (this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index] && this.aiTutorResultArr[index]) {
969
+ if (this.aiTutorResultArr[index] && this.aiTutorResultArr[index] && this.aiTutorResultArr[index]['feedback'] !== 'down') {
970
+ const dialogRef = this.dialog.open(NonReleventFeedbackDialogComponent, {
971
+ disableClose: true,
972
+ width: '502px',
973
+ panelClass: ['relevent-feedback-dialog'],
974
+ });
975
+ dialogRef.afterClosed().subscribe((result) => {
976
+ if (result) {
977
+ this.shareAIForAnswerFeedback(item, result, index);
978
+ dialogRef.close();
979
+ }
980
+ else {
981
+ dialogRef.close();
982
+ }
983
+ });
984
+ }
985
+ else {
986
+ this.matSnackBarNew.open('You have already submitted feedback', 'X', { duration: 5000, panelClass: ['error'] });
987
+ }
988
+ }
989
+ }
990
+ shareAIForAnswerFeedback(item, result, index) {
991
+ let requestBody = {
992
+ "query_id": item.query_id,
993
+ "response": item?.answer,
994
+ "comments": result,
995
+ "is_liked": false,
996
+ "rating": "0",
997
+ "identifier": this.content,
998
+ "query": item.query
999
+ };
1000
+ if (this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index]) {
1001
+ if (this.aiTutorResultArr[index] && this.aiTutorResultArr[index]) {
1002
+ this.aiTutorResultArr[index]['showLoader'] = true;
1003
+ this.aiTutorResultArr[index]['showLoaderForDown'] = true;
1004
+ }
1005
+ }
1006
+ this.chatbotService.shareAIFeedback(requestBody, this.chatId, this.userInfo?.userId).subscribe((data) => {
1007
+ if (data && data.status === 'success') {
1008
+ if (this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index]) {
1009
+ if (this.aiTutorResultArr[index] && this.aiTutorResultArr[index])
1010
+ this.aiTutorResultArr[index]['feedback'] = 'down';
1011
+ this.aiTutorResultArr[index]['showLoader'] = false;
1012
+ this.aiTutorResultArr[index]['showLoaderForDown'] = false;
1013
+ }
1014
+ this.matSnackBarNew.open('Thank you for your feedback.', 'X', { duration: 5000, panelClass: ['success'] });
1015
+ }
1016
+ else {
1017
+ if (this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index]) {
1018
+ if (this.aiTutorResultArr[index] && this.aiTutorResultArr[index])
1019
+ this.aiTutorResultArr[index]['showLoader'] = false;
1020
+ this.aiTutorResultArr[index]['showLoaderForDown'] = false;
1021
+ }
1022
+ this.matSnackBarNew.open('Something is wrong. Please try again later.', 'X', { duration: 5000, panelClass: ['error'] });
1023
+ }
1024
+ });
1025
+ }
1026
+ callFromInternet(item, index) {
1027
+ this.aiTutorResultArr.push({ type: 'incoming', tab: 'sarthi', answer: '' });
1028
+ if (this.aiTutorResultArr[index] && this.aiTutorResultArr[index]['showFromInternet']) {
1029
+ this.aiTutorResultArr[index]['showFromInternet'] = false;
1030
+ }
1031
+ if (item && !item.answer) {
1032
+ let internetGlobalSearchRequest = {
1033
+ "query": this.cloneSearchQuery,
1034
+ "designation": this.userInfo?.professionalDetails && this.userInfo?.professionalDetails.length ? this.userInfo?.professionalDetails[0].designation : '',
1035
+ "department": this.userInfo?.departmentName ? this.userInfo?.departmentName : '',
1036
+ };
1037
+ this.chatbotService.aiGlobalSearchFromInternet(internetGlobalSearchRequest, '', this.userInfo?.userId).subscribe((idata) => {
1038
+ this.resultFetch = true;
1039
+ this.aiTutorResultArr.map((item, index) => {
1040
+ if (item && (item.newMessage === '')) {
1041
+ // delete this.aiSearchResultArr[index]
1042
+ this.aiTutorResultArr.splice(index, 1);
1043
+ }
1044
+ });
1045
+ let resultObj = {
1046
+ message: idata.answer,
1047
+ recommendedQues: '',
1048
+ selectedValue: '',
1049
+ title: idata.answer,
1050
+ content: idata,
1051
+ mimeType: idata,
1052
+ contentType: idata,
1053
+ artifactUrl: idata,
1054
+ description: idata.answer,
1055
+ identifier: idata,
1056
+ contentStart: idata,
1057
+ contentEnd: idata,
1058
+ pageNumber: idata,
1059
+ query: this.cloneSearchQuery,
1060
+ query_id: idata.query_id,
1061
+ resourceLink: '',
1062
+ feedback: '',
1063
+ fromInternet: true
1064
+ };
1065
+ this.iGOTAITutorResultArr.push(resultObj);
1066
+ let answer = idata.answer ? idata.answer.trim().replace(/\n/g, '<br>') : "";
1067
+ let shortAnswer = this.splitParagraphByWords(answer);
1068
+ this.aiTutorResultArr.push({ feedback: '', wordsCount: answer.trim().split(/\s+/).length, showLess: answer.trim().split(/\s+/).length > 30 ? true : false, answer: answer, shortAnswer: shortAnswer, result: this.iGOTAITutorResultArr, type: 'incoming', tab: 'sarthi', reterivedChunks: this.aiTutorResult.retrievedChunks, showFromInternet: false });
1069
+ this.aiTutorResultArr.map((item, index) => {
1070
+ if (item && (item.newMessage === '')) {
1071
+ // delete this.aiSearchResultArr[index]
1072
+ this.aiTutorResultArr.splice(index, 1);
1073
+ }
1074
+ });
1075
+ });
1076
+ }
1077
+ }
1078
+ rejectFromInternet(index) {
1079
+ if (this.aiTutorResultArr[index] && this.aiTutorResultArr[index]['showFromInternet']) {
1080
+ this.aiTutorResultArr[index]['showFromInternet'] = false;
1081
+ }
1082
+ this.resultFetch = true;
1083
+ this.aiTutorResultArr.map((item, index) => {
1084
+ if (item && (item.newMessage === '')) {
1085
+ // delete this.aiSearchResultArr[index]
1086
+ this.aiTutorResultArr.splice(index, 1);
1087
+ }
1088
+ });
1089
+ }
1090
+ ngOnDestroy() {
1091
+ // Clean up the subscription and WebSocket connection
1092
+ if (this.messageSubscription) {
1093
+ this.messageSubscription.unsubscribe();
1094
+ }
1095
+ const event = {
1096
+ eventType: WsEvents.WsEventType.Telemetry,
1097
+ eventLogLevel: WsEvents.WsEventLogLevel.Info,
1098
+ data: {
1099
+ edata: { type: 'click', "id": "ai-tutor-card-content", "pageid": `viewer/${this.content}`, "subType": this.selectedLearningStyle.title },
1100
+ object: { id: this.content },
1101
+ state: WsEvents.EnumTelemetrySubType.Unloaded,
1102
+ eventSubType: WsEvents.EnumTelemetrySubType.Chatbot,
1103
+ mode: 'view',
1104
+ },
1105
+ pageContext: { pageId: `viewer/${this.content}`, module: 'Learn' },
1106
+ from: '',
1107
+ to: 'Telemetry',
1108
+ };
1109
+ this.eventSvc.dispatchChatbotEvent(event);
1110
+ // this.websocketService.closeConnection();
1111
+ }
1112
+ resizeTextarea(textArea, _fromInput) {
1113
+ if (textArea) {
1114
+ textArea.style.height = 'auto'; // Reset height first
1115
+ requestAnimationFrame(() => {
1116
+ textArea.style.height = textArea.scrollHeight + 'px';
1117
+ const computed = getComputedStyle(textArea);
1118
+ const paddingTop = parseFloat(computed.paddingTop) || 0;
1119
+ const paddingBottom = parseFloat(computed.paddingBottom) || 0;
1120
+ const marginExtra = 0;
1121
+ this.containerHeight = textArea.scrollHeight + paddingTop + paddingBottom + marginExtra;
1122
+ });
1123
+ }
1124
+ }
1125
+ resetTextAreaHeight(_textArea) {
1126
+ if (this.textArea.nativeElement && this.textArea.nativeElement.style && this.textArea.nativeElement.style.height) {
1127
+ setTimeout(() => {
1128
+ this.searchQueryAItutor = this.searchQueryAItutor.trim();
1129
+ this.textArea.nativeElement.style.height = 'auto';
1130
+ this.textArea.nativeElement.style.height = '30px';
1131
+ const computed = getComputedStyle(this.textArea.nativeElement);
1132
+ const paddingTop = parseFloat(computed.paddingTop) || 0;
1133
+ const paddingBottom = parseFloat(computed.paddingBottom) || 0;
1134
+ const marginExtra = 0;
1135
+ this.containerHeight = 30 + paddingTop + paddingBottom + marginExtra;
1136
+ });
1137
+ }
1138
+ }
1139
+ closeAITutorPopup() {
1140
+ this.closeAIPopup.emit(true);
1141
+ }
1142
+ minimizeAITutor() {
1143
+ this.maximize = false;
1144
+ }
1145
+ maximizeAITutor() {
1146
+ this.maximize = true;
1147
+ }
1148
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AiTutorComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.ConfigurationsService }, { token: i2.EventService }, { token: i0.Renderer2 }, { token: i3.RootService }, { token: i4.WebSocketService }, { token: i5.MatLegacyDialog }, { token: i6.MatSnackBar }, { token: i2.UtilityService }, { token: "environment" }, { token: i1.Router }], target: i0.ɵɵFactoryTarget.Component }); }
1149
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AiTutorComponent, selector: "ws-widget-ai-tutor", inputs: { from: "from", content: "content", userJourney: "userJourney" }, outputs: { closeAIPopup: "closeAIPopup" }, viewQueries: [{ propertyName: "textArea", first: true, predicate: ["autoResizeTextarea"], descendants: true }], ngImport: i0, template: "<!-- <div class=\"tutor-container\">\n<div class=\"learning-type-container\">\n <mat-form-field appearance=\"none\">\n <select matNativeControl required class=\"section-dd\" >\n <option value=\"\">Select learning type here </option>\n <option value=\"\">None</option>\n <option value=\"\">Socratic</option>\n <option value=\"\">Story Telling</option>\n <option value=\"\">Summarisation</option>\n </select>\n </mat-form-field>\n</div>\n<div [ngClass]=\"from === 'chatbot' ? 'ai-tutor-container-chatbot':'ai-tutor-container'\" #scrollMe>\n <div class=\"message-container\" #scrollMe>\n <div class=\"start-chat\" *ngIf=\"aiTutorResultArr?.length === 0\">\n <h2 class=\"hey\">Hey<span *ngIf=\"userInfo?.firstName\">, {{userInfo?.firstName}}</span> </h2>\n <p>Welcome to Ai Tutor,\u2028Get instant explanations, step-by-step learning guidance, and customised learning tailored just for you.</p>\n </div>\n <ng-container *ngFor=\"let chat of aiTutorResultArr; let i =index\">\n <ng-container *ngIf=\"chat.type === 'incoming'\">\n <ng-container *ngIf=\"chat?.answer\">\n <div class=\"flex row-start incoming-msg margin-bottom-s\">\n <div class=\"system-icon\"><img alt=\"ai-icon\" src=\"/assets/icons/chatbot-ai-new.svg\"></div>\n \n <div class=\"system-msg padding-xs\" *ngIf=\"chat?.wordsCount <= 30\" [innerHTML]=\"chat.answer\">\n </div>\n <div class=\"system-msg padding-xs\">\n <div *ngIf=\"chat?.wordsCount > 30\" [innerHTML]=\"chat?.showLess ? chat.shortAnswer : chat.answer\"></div>\n <a class=\"link\" href=\"javascript:void(0)\" *ngIf=\"!chat?.showLess\" (click)=\"toggleShow(i, 'less')\">Show Less</a>\n <a class=\"link\" href=\"javascript:void(0)\" *ngIf=\"chat?.showLess\" (click)=\"toggleShow(i, 'more')\">Show More</a>\n </div>\n \n\n </div>\n <ng-container *ngFor=\"let item of chat?.result; let ci=index\">\n <div class=\"system-msg-mimetype flex flex-col\" *ngIf=\"item?.contentType === 'Resource'\">\n <ng-container *ngIf=\"item?.mimeType === 'application/pdf'\">\n <div class=\"resource-icon\"><a [href]=\"item?.resourceLink\" target=\"_blank\"><img src=\"/assets/icons/ai-pdf-icon.jpg\"></a></div>\n <div class=\"resource-link\">\n <a [href]=\"item?.resourceLink\" target=\"_blank\">Open Resource Link</a>\n </div>\n </ng-container>\n <ng-container *ngIf=\"item?.mimeType === 'video/mp4'\">\n \n <div class=\"position-relative\">\n <div class=\"position-relative\">\n <img src=\"/assets/icons/ai-video-icon.jpg\">\n\n </div>\n <div class=\"content-duration\" *ngIf=\"item?.contentStart || item?.contentEnd\">\n <span *ngIf=\"item?.contentStart\">{{item?.contentStart}}</span>\n <span *ngIf=\"item?.contentEnd\">:{{item?.contentEnd}}</span>\n </div>\n </div>\n <div class=\"resource-link\">\n <a [href]=\"item?.resourceLink\" target=\"_blank\">Open Resource Link</a>\n </div>\n </ng-container>\n </div>\n <div class=\"recommended-question my-5px\" [ngClass]=\"{'margin-left-5': item?.message }\">\n <div class=\"my-5px mr-2\">\n <ng-container *ngIf=\"item?.contentType !== 'Resource'\">\n <div class=\"btn-default\" (click)=\"redirectToToc(item)\">{{item?.title}}\n <mat-icon class=\"vertical-middle\">navigate_next</mat-icon>\n </div>\n <div>\n {{item?.description | slice : 0:50}}\n </div>\n </ng-container>\n </div>\n <div class=\"flex flex-row font-12\">\n <div class=\"cursor-pointer\" (click)=\"copyPath(item, ci)\">\n <mat-icon matTooltip=\"Copy\" aria-label=\"Copy\">content_copy</mat-icon>\n <span *ngIf=\"copiedIndex === ci\" class=\"copied-tooltip\">Link Copied!</span>\n </div>\n <div class=\"ml-2 mr-2\"><img alt=\"ai-icon\" src=\"/assets/ai-tutor/ai-icon.svg\"></div>\n <div class=\"ai-generated-content ml-2\">These are AI generated results</div>\n </div>\n </div>\n </ng-container>\n \n \n </ng-container>\n <ng-container *ngIf=\"!chat?.answer\">\n <div class=\"flex row-start incoming-msg margin-bottom-s\">\n <div class=\"system-icon\"><img alt=\"ai-icon\" src=\"/assets/icons/chatbot-ai-new.svg\"></div>\n <div class=\"loading-bar-icon\"><img alt=\"ai-icon\" src=\"/assets/icons/loading_bar.gif\"></div>\n </div>\n \n </ng-container>\n </ng-container>\n \n <ng-container *ngIf=\"chat.type === 'sendMsg'\">\n <div class=\"flex width-1-1 row-end padding-top-l padding-bottom-m\">\n <div class=\"user-seleted-question padding-xs\">\n {{chat?.question}}\n </div>\n <div class=\"user-icon\" *ngIf=\"userIcon\">\n <img alt=\"ai-icon\" src=\"{{userIcon}}\">\n </div>\n <div class=\"circle-s user-icon\" *ngIf=\"!userIcon\" [ngStyle]=\"{'background-color': circleColor }\">\n <div class=\"initials\" i18n-aria-label>\n {{ userInitials }} \n </div>\n </div>\n </div>\n </ng-container>\n </ng-container>\n </div> \n</div>\n<div class=\"control-container\">\n <div class=\"border-gradient-rounded\">\n <div class=\"flex flex-row mx-5 justify-between\">\n\n <div class=\"query-box\">\n <input class=\"width-500\" type=\"text\" placeholder=\"Ask anything...\" [(ngModel)]=\"searchQueryAItutor\" (keydown.enter)=\"submitSearchQuery()\"/>\n \n </div>\n\n <div>\n <button type=\"button\" class=\"flex-auto-display send-btn\" (click)=\"submitSearchQuery()\" [disabled]=\"!searchQueryAItutor\">\n <mat-icon class=\"send-btn-icon\">send</mat-icon>\n </button>\n </div>\n </div>\n </div>\n</div>\n</div> -->\n\n<div class=\"overflow-y-hidden\" [ngClass]=\"(isMobile && !maximize ? 'ai-tutor-popup-minimize' : (isMobile ? 'ai-tutor-popup': ''))\">\n<div *ngIf=\"isMobile\">\n <div class=\"flex flex-row ai-tutor-mobile-header\">\n <div class=\"flex flex-row\">\n <div class=\"flex\">\n <span class=\"font-bold\">AI Tutor</span>\n </div> \n <div class=\"red-circle ml-5\">\n New\n </div>\n </div>\n <div class=\"flex flex-row justify-end\">\n <div *ngIf=\"maximize\" (click)=\"minimizeAITutor()\">\n <mat-icon>minimize</mat-icon>\n </div>\n <div *ngIf=\"!maximize\" (click)=\"maximizeAITutor()\">\n <mat-icon>maximize</mat-icon>\n </div>\n <div (click)=\"closeAITutorPopup()\">\n <mat-icon>close</mat-icon>\n </div>\n </div>\n \n \n </div>\n</div>\n<div [hidden]=\"!maximize\">\n<div class=\"header\">\n <!-- <mat-form-field appearance=\"none\" style=\"width:100%\">\n <select matNativeControl required class=\"section-dd\" >\n <option value=\"\">You can also choose a learning style that suits you best from here.</option>\n <option value=\"\">None</option>\n <option value=\"\">Socratic</option>\n <option value=\"\">Story Telling</option>\n <option value=\"\">Summarisation</option>\n </select>\n </mat-form-field> -->\n <mat-form-field class=\"multiline-select\" appearance=\"fill\" style=\"width: 100%; height: 80px;\" floatLabel=\"never\">\n <mat-select class=\"multiline-select-box\" required [(value)]=\"selectedLearningStyle\" (selectionChange)=\"getLearningStyle()\">\n <mat-select-trigger class=\"multiline-select-box-trigger\">\n <div class=\"option-content\">\n <div class=\"title\">{{ selectedLearningStyle?.title }}</div>\n <div class=\"subtitle\">{{ selectedLearningStyle?.subtitle }}</div>\n </div>\n </mat-select-trigger>\n <mat-option class=\"multiline-select-option\" value=\"\" *ngFor=\"let item of learningStyle\" [value]=\"item\">\n <div class=\"option-content\">\n <div class=\"title\">{{item?.title}}</div>\n <div class=\"subtitle\">{{item?.subtitle}}</div>\n </div>\n </mat-option>\n </mat-select>\n </mat-form-field>\n \n</div>\n\n<div class=\"container-none\" id=\"container-none\">\n <div [ngClass]=\"from === 'chatbot' ? 'ai-tutor-container-chatbot':'ai-tutor-container'\">\n <div class=\"message-container\" #scrollMe>\n <div class=\"start-chat\" *ngIf=\"aiTutorResultArr?.length === 0\">\n <h2 class=\"hey\">Hey<span *ngIf=\"userInfo?.firstName\">, {{userInfo?.firstName}}</span> </h2>\n <p>Welcome to AI Tutor,\u2028Get instant explanations, step-by-step learning guidance, and customised learning tailored just for you.</p>\n </div>\n <ng-container *ngFor=\"let chat of aiTutorResultArr; let i =index\">\n <ng-container *ngIf=\"chat.type === 'incoming'\">\n <ng-container *ngIf=\"chat?.answer || chat?.showFromInternet\">\n <div class=\"flex row-start incoming-msg margin-bottom-s\" *ngIf=\"chat?.answer\">\n <div class=\"system-icon\"><img alt=\"ai-icon\" src=\"/assets/icons/bot-chat-small.svg\"></div>\n \n <!-- <div class=\"system-msg padding-xs\" *ngIf=\"chat?.wordsCount <= 30\" [innerHTML]=\"chat.answer\">\n </div> -->\n <div class=\"flex row-start incoming-msg margin-bottom-s\" *ngIf=\"chat?.showFromInternet\">\n <div class=\"system-msg padding-xs mx-10\">\n I couldn\u2019t find any relevant results for your query. Would you like me to search outside the iGOT platform for more information?\n </div>\n \n </div>\n <ng-container *ngIf=\"chat?.answer\">\n <div class=\"system-msg padding-xs\" *ngIf=\"chat?.wordsCount <= 30\">\n <markdown [data]=\"chat?.answer\"></markdown>\n </div>\n \n <div class=\"system-msg padding-xs\" *ngIf=\"chat?.wordsCount > 30\" >\n <!-- <div [innerHTML]=\"chat?.showLess ? chat.shortAnswer : chat.answer\"></div> -->\n <markdown [data]=\"chat?.answer\"></markdown>\n <!-- <markdown [data]=\"chat?.showLess ? chat.shortAnswer : chat.answer\"></markdown> -->\n <!-- <a class=\"link\" href=\"javascript:void(0)\" *ngIf=\"!chat?.showLess\" (click)=\"toggleShow(i, 'less')\">Show Less</a>\n <a class=\"link\" href=\"javascript:void(0)\" *ngIf=\"chat?.showLess\" (click)=\"toggleShow(i, 'more')\">Show More</a> -->\n </div>\n </ng-container>\n \n \n </div>\n \n <div *ngIf=\"chat?.showFromInternet\">\n <div class=\"flex row my-2 justify-start mx-10 my-5\">\n <div (click)=\"callFromInternet(chat, i)\">\n <button type=\"button\" class=\"web-button px-4 cursor-pointer\">\n <mat-icon class=\"web-search-icon\">search </mat-icon><span class=\"blue-color\">Search the web</span>\n </button>\n </div>\n <div (click)=\"rejectFromInternet(i)\" class=\"mx-2\">\n <button type=\"button\" class=\"web-button py-2 px-4 cursor-pointer\">\n <mat-icon class=\"web-close-icon\">close</mat-icon><span class=\"blue-color\">No</span>\n </button>\n </div>\n </div>\n </div>\n <ng-container *ngFor=\"let item of chat?.result; let ci=index\">\n <div class=\"system-msg-mimetype flex flex-col\" *ngIf=\"item?.contentType === 'Resource'\">\n <ng-container *ngIf=\"item?.mimeType === 'application/pdf'\">\n <!-- <div class=\"resource-icon\"><a [href]=\"item?.resourceLink\" target=\"_blank\" (click)=\"raiseTelemetryForResource(item)\">\n <img src=\"/assets/icons/ai-pdf-icon.jpg\"></a>\n </div> -->\n <div class=\"recommended-question-for-resource mx-10\" (click)=\"redirectToResource(item);raiseTelemetryForResource(item)\">\n <!-- <div class=\"resource-icon\">\n <a [href]=\"item?.resourceLink\" target=\"_blank\" (click)=\"raiseTelemetryForResource(item)\">\n <img src=\"/assets/ai-tutor/pdf.svg\">\n </a>\n <p>{{item?.message}}</p>\n </div> -->\n <div class=\"btn-default mb-2\">\n <a [href]=\"item?.resourceLink\" target=\"_blank\">\n <img class=\"vertical-middle h-w-34\" src=\"/assets/ai-tutor/pdf.svg\">\n </a>\n {{item?.title}}\n <mat-icon class=\"vertical-middle\" *ngIf=\"!(item?.fromInternet)\">navigate_next</mat-icon>\n </div>\n </div>\n <!-- <div class=\"resource-link\">\n <a [href]=\"item?.resourceLink\" target=\"_blank\">Click to view</a>\n </div> -->\n </ng-container>\n <!-- <ng-container *ngIf=\"item?.mimeType === 'video/mp4'\">\n \n <div class=\"resource-icon\">\n <a [href]=\"item?.resourceLink\" target=\"_blank\" (click)=\"raiseTelemetryForResource(item)\">\n <div class=\"position-relative\">\n <div class=\"position-relative\">\n <img src=\"/assets/icons/ai-video-icon.jpg\">\n \n </div>\n <div class=\"content-duration flex\" *ngIf=\"item?.contentStart > -1 && item?.contentEnd > -1 && !(item?.fromInternet)\">\n <span><mat-icon>access_time</mat-icon>&nbsp;&nbsp;</span>\n <span *ngIf=\"item?.contentStart > -1\">\n <span *ngIf=\"item?.contentStart > 0\">{{item?.contentStart | pipeDurationTransform: 'hms'}}</span>\n <span *ngIf=\"item.contentStart === '0'\">0</span>\n </span>\n <span *ngIf=\"item?.contentEnd > -1\">&nbsp;-&nbsp;{{item?.contentEnd | pipeDurationTransform: 'hms'}}</span>\n </div>\n </div>\n \n \n </a>\n </div>\n </ng-container> -->\n <ng-container *ngIf=\"item?.mimeType === 'video/mp4'\">\n <div class=\"recommended-question-for-resource mx-10\" (click)=\"redirectToResource(item);raiseTelemetryForResource(item)\">\n \n <div class=\"btn-default mb-2\">\n <div class=\"flex flex-row\">\n <div>\n <a [href]=\"item?.resourceLink\" target=\"_blank\">\n <img class=\"vertical-middle h-w-34\" src=\"/assets/ai-tutor/video.svg\">\n </a>\n </div>\n <div class=\"ml-1\">\n <span>{{item?.title}} </span>\n </div>\n <div>\n <span class=\"content-duration flex ml-1\" *ngIf=\"item?.contentStart > -1 && item?.contentEnd > -1 && !(item?.fromInternet)\">\n <span><mat-icon>access_time</mat-icon>&nbsp;&nbsp;</span>\n <span *ngIf=\"item?.contentStart > -1\">\n <span *ngIf=\"item?.contentStart > 0\">{{item?.contentStart | pipeDurationTransform: 'hms'}}</span>\n <span *ngIf=\"item.contentStart === '0'\">0</span>\n </span>\n <span *ngIf=\"item?.contentEnd > -1\">&nbsp;-&nbsp;{{item?.contentEnd | pipeDurationTransform: 'hms'}}</span>\n </span> \n </div>\n <div>\n <mat-icon class=\"vertical-middle\" *ngIf=\"!(item?.fromInternet)\">navigate_next</mat-icon>\n </div>\n </div>\n </div>\n <!-- <a [href]=\"item?.resourceLink\" target=\"_blank\" (click)=\"raiseTelemetryForResource(item)\">\n <div class=\"position-relative\">\n <div class=\"position-relative\">\n <img class=\"h-w-34\" src=\"/assets/ai-tutor/video.svg\">\n <p>{{item?.message}}</p>\n </div>\n <div class=\"content-duration flex\" *ngIf=\"item?.contentStart > -1 && item?.contentEnd > -1 && !(item?.fromInternet)\">\n <span><mat-icon>access_time</mat-icon>&nbsp;&nbsp;</span>\n <span *ngIf=\"item?.contentStart > -1\">\n <span *ngIf=\"item?.contentStart > 0\">{{item?.contentStart | pipeDurationTransform: 'hms'}}</span>\n <span *ngIf=\"item.contentStart === '0'\">0</span>\n </span>\n <span *ngIf=\"item?.contentEnd > -1\">&nbsp;-&nbsp;{{item?.contentEnd | pipeDurationTransform: 'hms'}}</span>\n </div>\n </div>\n \n \n </a> -->\n </div>\n </ng-container>\n <div class=\"flex flex-row cursor-pointer\">\n <!-- <div class=\"resource-link\" *ngIf=\"!(item?.fromInternet)\">\n <a [href]=\"item?.resourceLink\" target=\"_blank\">Click to view</a>\n </div> -->\n <div class=\"cursor-pointer ml-10 mr-2 my-1\" (click)=\"copyPath(item, ci)\" *ngIf=\"item?.contentType === 'Resource' && !(item?.fromInternet)\">\n <mat-icon matTooltip=\"Copy\" aria-label=\"Copy\">content_copy</mat-icon>\n <span *ngIf=\"copiedIndex === ci\" class=\"copied-tooltip\">Link Copied!</span>\n </div>\n <!-- <div class=\"feefback-section flex flex-row my-1\" *ngIf=\"(item?.feedback)\">\n <div *ngIf=\"item?.feedback !== 'down'\"\n class=\"cursor-pointer feedback-icon mt-1\" [ngClass]=\"item?.feedback !== 'up' ? 'rotate-180' : ''\">\n <img *ngIf=\"item?.feedback !== 'up'\" src=\"/assets/ai-tutor/down.svg\">\n <img *ngIf=\"item?.feedback == 'up'\" src=\"/assets/ai-tutor/up.svg\">\n </div>\n <div *ngIf=\"item?.feedback !== 'up'\" class=\"ml-2 cursor-pointer feedback-icon\">\n <img src=\"/assets/ai-tutor/fill-down.svg\">\n </div>\n </div>\n <div class=\"feefback-section flex flex-row my-1\" *ngIf=\"item?.feedback === ''\">\n <div *ngIf=\"item?.feedback !== 'down'\" (click)=\"sharePositiveContentRating(item,i, ci)\"\n class=\"cursor-pointer feedback-icon\" [ngClass]=\"item?.feedback !== 'up' ? 'rotate-180' : ''\">\n <img *ngIf=\"item?.feedback !== 'up'\" src=\"/assets/ai-tutor/down.svg\">\n <img *ngIf=\"item?.feedback == 'up'\" src=\"/assets/ai-tutor/up.svg\">\n </div>\n <div *ngIf=\"item?.feedback !== 'up'\" (click)=\"openAIFeedbackPopup(item,i, ci)\" class=\"ml-2 cursor-pointer feedback-icon mt-1\">\n <img src=\"/assets/ai-tutor/down.svg\">\n </div>\n </div> -->\n <div class=\"feefback-section flex flex-row my-1\">\n <div (click)=\"sharePositiveContentRating(item,i, ci)\" class=\"cursor-pointer feedback-icon mt-1\" \n >\n <img [ngClass]=\"'rotate-180'\" *ngIf=\"item?.feedback !== 'up' && !item?.showLoaderForUp\" src=\"/assets/ai-tutor/down.svg\">\n <img *ngIf=\"item?.feedback === 'up' && !item?.showLoaderForUp\" src=\"/assets/ai-tutor/up.svg\">\n <img *ngIf=\"item?.showLoaderForUp\" class=\"blue-loader-animation\" height=\"18\" width=\"18\" src=\"/assets/ai-tutor/blue-loader.png\">\n </div>\n <div (click)=\"openAIFeedbackPopup(item,i, ci)\" class=\"ml-2 cursor-pointer feedback-icon mt-1\">\n <img *ngIf=\"item?.feedback !== 'down' && !item?.showLoaderForDown\" src=\"/assets/ai-tutor/down.svg\"> \n <img *ngIf=\"item?.feedback === 'down' && !item?.showLoaderForDown\" src=\"/assets/ai-tutor/fill-down.svg\"> \n <img *ngIf=\"item?.showLoaderForDown\" class=\"blue-loader-animation\" height=\"18\" width=\"18\" src=\"/assets/ai-tutor/blue-loader.png\">\n </div>\n </div>\n <!-- <div class=\"flex flex-row font-12 mt-1\">\n <div class=\"ml-2 mr-2 cu\"><img alt=\"ai-icon\" src=\"/assets/ai-tutor/ai-icon.svg\"></div>\n <div class=\"ai-generated-content ml-2\">These are <span *ngIf=\"item?.fromInternet\">Web</span><span *ngIf=\"!(item?.fromInternet)\">AI</span> generated results</div>\n </div> -->\n <!-- <div class=\"feefback-section flex flex-row\">\n \n <div *ngIf=\"item?.feedback !== 'down'\" (click)=\"sharePositiveContentRating(item,i, ci)\"\n class=\"cursor-pointer feedback-icon\" [ngClass]=\"item?.feedback !== 'up' ? 'rotate-180' : ''\">\n <img *ngIf=\"item?.feedback !== 'up'\" src=\"/assets/ai-tutor/down.svg\">\n <img *ngIf=\"item?.feedback == 'up'\" src=\"/assets/ai-tutor/up.svg\">\n </div>\n <div *ngIf=\"item?.feedback !== 'up'\" (click)=\"openAIFeedbackPopup(item,i, ci)\" class=\"ml-2 cursor-pointer feedback-icon\"><img src=\"/assets/ai-tutor/down.svg\"></div>\n </div> -->\n </div>\n \n </div>\n <div class=\"recommended-question\" [ngClass]=\"{'ml-10': item?.message }\">\n <div class=\"my-5px mr-2 w-92\">\n <ng-container *ngIf=\"item?.contentType !== 'Resource' && !(item?.fromInternet)\">\n <div class=\"btn-default\" (click)=\"redirectToToc(item)\">{{item?.title}}\n <mat-icon class=\"vertical-middle\" *ngIf=\"!(item?.fromInternet)\">navigate_next</mat-icon>\n </div>\n <div class=\"recommended-question-desc\" *ngIf=\"!(item?.fromInternet)\">\n <!-- {{item?.description}} -->\n <markdown [data]=\"item?.description\"></markdown>\n </div>\n </ng-container>\n </div>\n <div class=\"flex flex-row font-12 mb-2\">\n <div class=\"cursor-pointer\" (click)=\"copyPath(item, ci)\" *ngIf=\"item?.contentType !== 'Resource' && !(item?.fromInternet)\">\n <mat-icon matTooltip=\"Copy\" aria-label=\"Copy\">content_copy</mat-icon>\n <span *ngIf=\"copiedIndex === ci\" class=\"copied-tooltip\">Link Copied!</span>\n </div>\n <!-- <div class=\"feefback-section flex flex-row\" *ngIf=\"item?.contentType !== 'Resource'\">\n \n <div *ngIf=\"item?.feedback !== 'down'\" (click)=\"sharePositiveContentRating(item, i,ci)\" \n class=\"cursor-pointer feedback-icon\" [ngClass]=\"item?.feedback !== 'up' ? 'rotate-180' : ''\">\n <img *ngIf=\"item?.feedback !== 'up'\" src=\"/assets/ai-tutor/down.svg\">\n <img *ngIf=\"item?.feedback == 'up'\" src=\"/assets/ai-tutor/up.svg\">\n </div>\n <div *ngIf=\"item?.feedback !== 'up'\" (click)=\"openAIFeedbackPopup(item, i,ci)\" class=\"ml-2 cursor-pointer feedback-icon\"><img src=\"/assets/ai-tutor/down.svg\"></div>\n </div> -->\n <div class=\"feefback-section flex flex-row\" *ngIf=\"item?.contentType !== 'Resource'\">\n <div (click)=\"sharePositiveContentRating(item,i, ci)\" class=\"cursor-pointer feedback-icon mt-1\" \n >\n <img [ngClass]=\"'rotate-180'\" *ngIf=\"item?.feedback !== 'up' && !item?.showLoaderForUp\" src=\"/assets/ai-tutor/down.svg\">\n <img *ngIf=\"item?.feedback === 'up' && !item?.showLoaderForUp\" src=\"/assets/ai-tutor/up.svg\">\n <img *ngIf=\"item?.showLoaderForUp\" class=\"blue-loader-animation\" height=\"18\" width=\"18\" src=\"/assets/ai-tutor/blue-loader.png\">\n </div>\n <div (click)=\"openAIFeedbackPopup(item,i, ci)\" class=\"ml-2 cursor-pointer feedback-icon mt-1\">\n <img *ngIf=\"item?.feedback !== 'down' && !item?.showLoaderForDown\" src=\"/assets/ai-tutor/down.svg\"> \n <img *ngIf=\"item?.feedback === 'down' && !item?.showLoaderForDown\" src=\"/assets/ai-tutor/fill-down.svg\"> \n <img *ngIf=\"item?.showLoaderForDown\" class=\"blue-loader-animation\" height=\"18\" width=\"18\" src=\"/assets/ai-tutor/blue-loader.png\">\n </div>\n </div> \n </div>\n <!-- <div class=\"flex flex-row font-12 mt-1\" *ngIf=\"item?.contentType !== 'Resource'\">\n <div class=\"ml-2 mr-2 cu\"><img alt=\"ai-icon\" src=\"/assets/ai-tutor/ai-icon.svg\"></div>\n <div class=\"ai-generated-content ml-2\">These are <span *ngIf=\"item?.fromInternet\">Web</span><span *ngIf=\"!(item?.fromInternet)\">AI</span> generated results</div>\n </div> -->\n </div>\n </ng-container>\n <div class=\" flex flex-row ml-10\" *ngIf=\"chat?.answer && !(chat?.result?.length)\">\n <div (click)=\"sharePositiveContentRatingForAnswer(chat,i)\" class=\"cursor-pointer feedback-icon mt-1\" \n >\n <img [ngClass]=\"'rotate-180'\" *ngIf=\"chat?.feedback !== 'up' && !chat?.showLoaderForUp\" src=\"/assets/ai-tutor/down.svg\">\n <img *ngIf=\"chat?.feedback === 'up' && !chat?.showLoaderForUp\" src=\"/assets/ai-tutor/up.svg\">\n <img *ngIf=\"chat?.showLoaderForUp\" class=\"blue-loader-animation\" height=\"18\" width=\"18\" src=\"/assets/ai-tutor/blue-loader.png\">\n </div>\n <div (click)=\"openAIFeedbackPopupForAnswer(chat,i)\" class=\"ml-2 cursor-pointer feedback-icon mt-1\">\n <img *ngIf=\"chat?.feedback !== 'down' && !chat?.showLoaderForDown\" src=\"/assets/ai-tutor/down.svg\"> \n <img *ngIf=\"chat?.feedback === 'down' && !chat?.showLoaderForDown\" src=\"/assets/ai-tutor/fill-down.svg\"> \n <img *ngIf=\"chat?.showLoaderForDown\" class=\"blue-loader-animation\" height=\"18\" width=\"18\" src=\"/assets/ai-tutor/blue-loader.png\">\n </div>\n </div> \n <div class=\"flex flex-row font-12 mt-1 mb-1 ai-generated-content-container\" *ngIf=\"chat?.result?.length\">\n <div class=\"ml-5 mr-2 cu\"><img alt=\"ai-icon\" src=\"/assets/ai-tutor/ai-icon.svg\"></div>\n <div class=\"ai-generated-content ml-2\">These are <span *ngIf=\"item?.fromInternet\">Web</span><span *ngIf=\"!(item?.fromInternet)\">AI</span> generated results</div>\n </div>\n \n </ng-container>\n <ng-container>\n <div class=\"flex row-start incoming-msg margin-bottom-s\" *ngIf=\"chat?.newMessage === '' && !resultFetch\">\n <div class=\"system-icon\"><img alt=\"ai-icon\" src=\"/assets/icons/bot-chat-small.svg\"></div>\n <div class=\"loading-bar-icon flex flex-row vertical-middle\">\n <div class=\"mt-2\"><span class=\"blue-color\">Retrieving Results</span></div>\n <div><img alt=\"ai-icon\" src=\"/assets/icons/loading_bar.gif\"></div>\n </div>\n </div>\n \n </ng-container>\n </ng-container>\n \n <ng-container *ngIf=\"chat.type === 'sendMsg'\">\n <div class=\"flex width-1-1 row-end padding-top-l padding-bottom-m\">\n <div class=\"user-seleted-question padding-xs\">\n {{chat?.question}}\n </div>\n <div class=\"user-icon\" *ngIf=\"userIcon\">\n <img alt=\"ai-icon\" src=\"{{userIcon}}\">\n </div>\n <div class=\"circle-s user-icon\" *ngIf=\"!userIcon\" [ngStyle]=\"{'background-color': circleColor }\">\n <div class=\"initials\" i18n-aria-label>\n {{ userInitials }} \n </div>\n </div>\n </div>\n </ng-container>\n </ng-container>\n </div> \n </div>\n</div>\n\n<div class=\"footer\" [ngClass]=\"isMobile ? 'ai-popup-mobile-footer':''\">\n <div class=\"border-gradient-rounded\" [style.height.px]=\"containerHeight\">\n <div class=\"flex flex-row ml-5 mr-2 justify-between\">\n\n <div class=\"query-box\">\n <!-- <input class=\"width-500\" type=\"text\" placeholder=\"Ask anything...\" [(ngModel)]=\"searchQueryAItutor\" (keydown.enter)=\"submitSearchQuery()\"/> -->\n <textarea #autoResizeTextarea class=\"width-500\"\n placeholder=\"Ask Me Anything...\"\n (input)=\"resizeTextarea(autoResizeTextarea, 'fromInput')\"\n [(ngModel)]=\"searchQueryAItutor\" (keydown.enter)=\"submitSearchQuery(autoResizeTextarea, $event)\"\n rows=\"1\"\n >\n </textarea>\n \n </div>\n\n <div class=\"margin-top-2px\">\n <button type=\"button\" class=\"flex-auto-display send-btn\" (click)=\"submitSearchQuery(autoResizeTextarea, $event)\" [disabled]=\"!searchQueryAItutor\">\n <mat-icon class=\"send-btn-icon\">send</mat-icon>\n </button>\n </div>\n </div>\n </div>\n</div>\n</div>\n</div>", styles: [".hey{background:linear-gradient(90deg,#32b9dfde,#1b4ca1de);-webkit-background-clip:text;background-clip:text;color:transparent}.ai-generated-content{background:linear-gradient(90deg,#f3962f,#1b4ca1);-webkit-background-clip:text;background-clip:text;color:transparent}.ai-tutor-container .control-container{position:fixed;bottom:0;width:24%;z-index:2;background:#fff;height:40px}.ai-tutor-container-chatbot .control-container{position:fixed;bottom:100px;width:600px;margin:1%;z-index:2}.start-chat{text-align:center;padding-top:37.5%}.query-box{min-height:38px;transition:height .2s;width:100%}.query-box input{border:0;outline:0}.border-gradient-rounded{border:2px solid transparent;border-radius:20px;background:linear-gradient(to right,#fff,#fff),linear-gradient(to right,#efa34f,#4881e4);background-clip:padding-box,border-box;background-origin:padding-box,border-box;width:96%;min-height:36px;margin-left:1%;z-index:3}.send-btn{background-color:#fff!important;color:#1b4ca1!important;border:none!important;margin-left:14px}.ai-tutor-container-chatbot{background-image:url(/assets/ai-tutor/background.svg);height:90vh;width:525px}.message-container{z-index:2;position:relative;width:100%}.chatbot-icon-container{position:fixed;bottom:120px;right:0;cursor:pointer;height:90px;align-items:flex-start;display:flex;justify-content:center;width:auto;z-index:999999999}.chatbot-icon{position:absolute;right:30px;animation-delay:1s;transition:1s ease}.chatbot-icon-expanded{right:0}.expand-text{width:110px;display:flex;align-items:center;justify-content:center;background-color:#1b4ca1;color:#fff;font-size:18px;border-top:2px solid #fff;border-bottom:2px solid #fff;vertical-align:middle}.chatbot{width:610px;position:fixed;bottom:20px;right:50px;z-index:9999999999;border-radius:15px;background-color:#fff;box-shadow:0 6px 16px #0000003d;height:calc(100vh - 20%)}.cb-close{cursor:pointer}.cb-header{color:#fff!important;background-color:#1b4ca1;border-top-left-radius:15px;border-top-right-radius:15px;align-items:center;justify-content:space-between;position:absolute;width:100%;top:0}.cb-header .user-info-div{width:88%;justify-content:space-between}.cb-header .lang-select{height:32px;background-color:#fff;border-color:#00000029!important}.cb-header .user-name{padding-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:74%}.cb-content{background-color:#f0f3f4;overflow:auto}.cb-topics{padding:16px;background-color:#f5f5f5;overflow:auto}.cb-footer{border-bottom-left-radius:15px;border-bottom-right-radius:15px;background-color:#fff}.cb-footer .info{width:33%;padding:5px 0;align-items:center;display:flex;justify-content:center;flex-wrap:wrap;cursor:pointer}.cb-footer .info .info-text{font-size:10px;width:100%;text-align:center}.cb-footer .info .info-icon{height:24px}.br-br{border-bottom-right-radius:15px}.br-bl{border-bottom-left-radius:15px}.language{background-color:#0000000a}.active{background-color:#fbead1;border-top:3px solid rgb(239,149,30)}.active .mat-icon{color:#ef951e!important}.cat-list{margin:0;padding:0;width:100%;display:flex}.cat-item{padding:10px 16px;border-radius:21px;border:1px solid rgba(0,0,0,.16);background-color:#0000000a;opacity:1;color:#000000de;font-family:Lato-Regular,sans-serif;font-size:14px;font-weight:400;font-style:normal;letter-spacing:.25px;text-align:center;line-height:20px;width:fit-content;margin-right:12px;height:fit-content;cursor:pointer;white-space:nowrap}.lang-select{width:70px}.lang-select .mat-form-field-flex{background-color:#fff!important}.lang-select .mat-form-field-underline{background-color:transparent!important}.loader{position:absolute;left:50%;top:39%}.default-info .default-icon{width:60px;float:left;display:flex;flex-wrap:wrap}.default-info .default-msg{background-color:#0000000a;border:1px solid rgba(0,0,0,.16);border-radius:0 15px 15px;display:flex;flex-wrap:wrap}.chat-bot-icon{padding-top:8px}.row-start{justify-content:flex-start}.row-start .system-icon{padding-right:3px}.row-start .system-msg{background-color:#d1dbec;border:1px solid rgb(209,219,236);border-radius:0 15px 15px;display:flex;flex-wrap:wrap;min-width:auto;max-width:80%;height:100%;word-break:break-word}.row-start .system-msg ::ng-deep markdown *{margin:0}.recommended-question-desc ::ng-deep markdown *{margin:0;width:100%;word-wrap:break-word}.word-break{word-break:break-all;white-space:unset}.margin-left-5{margin-left:5%}.question-hint{font-weight:700}.recommended-question{display:flex;flex-wrap:wrap;height:fit-content}.recommended-question .rec-item{height:fit-content}.recommended-question .my-5px{margin-top:5px;margin-bottom:5px}.recommended-question .mr-5px{margin-right:5px}.recommended-question .btn-default{background:#d5c7c70a;border:1px solid #1B4CA1;color:#1b4ca1;padding:10px;font-size:14px;font-weight:700;cursor:pointer;border-radius:5px}.recommended-question .showmore-icon{align-items:flex-start}.recommended-question .btn-active{background:#000;border:1px solid rgba(0,0,0,.16);color:#fff}.btn-show-more,.btn-show-less{background:#1b4ca1;color:#fff;padding:10px 20px;font-size:14px;cursor:pointer;border-radius:40px}.row-end{justify-content:flex-end;height:100%}.row-end .user-seleted-question{background-color:#000;border-radius:15px 0 15px 15px;display:flex;flex-wrap:wrap;color:#fff;float:right;text-align:left;max-width:62%;word-break:break-word}.highlight-title{color:#1b4ca1}.incoming-msg{height:fit-content}.hint-text{color:#1b4ca1}@media only screen and (max-width: 600px){.chatbot{right:6px;bottom:67px}}@media only screen and (max-width: 390px){.chatbot{right:6px;bottom:67px}}.chatbot-wrapper{position:relative}.cb-content-wrapper{position:absolute;width:100%;top:64px;bottom:130px;max-height:100%;overflow:auto;box-sizing:border-box;background-color:#f0f3f4}.cb-footer-wrapper{position:absolute;width:100%;bottom:0}.my-5px{margin-top:5px;margin-bottom:5px}.mr-5px{margin-right:5px}*,:after,:before{box-sizing:border-box}::ng-deep .disable-scroll{overflow-x:hidden!important;overflow:hidden}@media only screen and (max-width: 600px){.chatbot{right:0;bottom:0;width:100%;height:100svh;z-index:999999999}.cb-footer-wrapper{bottom:0}.cb-content-wrapper{bottom:130px}.chatbot-icon-container{bottom:190px}.cb-header{border-top-left-radius:unset;border-top-right-radius:unset}.cb-footer{border-bottom-left-radius:unset;border-bottom-right-radius:unset}.br-br{border-bottom-right-radius:unset}.br-bl{border-bottom-left-radius:unset}}.feefback-section{margin-left:10px}.resource-icon{margin-left:10%}.resource-link{margin-left:40px}.resource-icon img{height:65px;width:115.25px}.font-12{font-size:12px}.vertical-middle{vertical-align:middle}.send-btn-icon{height:22px!important}.width-500{width:262px}.learning-type-container{width:98%}.section-dd{border:1px solid #ccc;padding:12px 16px;width:100%;height:65px;font-size:12px;font-weight:400;position:relative;z-index:2}.system-icon img{height:36px;width:36px}.circle-s{border-radius:50%;width:36px;height:36px;display:flex;justify-content:center;align-items:center;margin-left:4px}.circle-s img{border-radius:50%;width:100%;height:100%}.circle-s .initials{color:#fff;font-size:10px;line-height:12px;font-size:14px;letter-spacing:.2625px}.copied-tooltip{position:absolute;left:20%;transform:translate(-50%);background-color:#000;color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;opacity:1;pointer-events:none;transition:opacity .3s ease;z-index:999}.loading-bar-icon img{height:50px;width:50px}.link{color:#1b4ca1;text-decoration:underline}.content-duration{position:relative;background:#f3962f;color:#fff;width:auto;border-radius:8px;text-align:center;bottom:11px;left:0;padding:0 5px;font-size:12px;display:flex;align-items:center;justify-content:center;margin-top:12px;white-space:nowrap}.content-duration .mat-icon{vertical-align:middle;color:#fff!important;height:14px!important;width:14px!important;font-size:14px}.position-relative{position:relative}.control-container{position:fixed;bottom:10px;z-index:2}.tutor-container{width:100%}.header{top:127px;width:100%;color:#fff;display:flex;align-items:flex-start;justify-content:flex-start}::ng-deep .header .mat-form-field{width:100%}.footer{bottom:0;width:100%;height:50px;color:#fff;display:flex;align-items:flex-end;justify-content:center;z-index:2}.container-none{margin-bottom:10px;padding:20px;height:calc(100vh - 261px);background:url(/assets/ai-tutor/background.svg);background-color:#f0f3f4;overflow-y:auto;overflow-x:hidden;position:relative;background-color:#ffffffe6;background-blend-mode:overlay}.option-content{display:flex;flex-direction:column;line-height:2}.option-content .title{font-weight:600}.option-content .subtitle{font-size:12px;color:gray}:host ::ng-deep .multiline-select .mat-mdc-select-value-text{white-space:pre-wrap!important}:host ::ng-deep .mat-pseudo-checkbox{display:none!important}:host ::ng-deep .mat-pseudo-checkbox-checked{display:none!important}:host ::ng-deep .multiline-select-option{background-color:#fff!important}:host ::ng-deep .player-content .mat-tab-label-active{opacity:1!important}.user-icon{margin-left:5px}.user-icon img{height:36px;width:36px;border-radius:50%}.w-92{width:92%}::ng-deep .copy-icon .material-icons{font-size:18px!important}::ng-deep .copy-icon .mat-icon{vertical-align:middle}.internet-result-query{background:#add8e6;border:1px solid #1B4CA1;color:#000;padding:10px;font-size:14px;font-weight:700;cursor:pointer;border-radius:5px}.blue-color{color:#1b4ca1;font-size:14px;font-weight:700}.web-button{background-color:#fff;color:#1b4ca1;border-radius:8px;padding:10px;border:1px solid #1B4CA1}.web-search-icon,.web-close-icon{color:#1b4ca1;vertical-align:middle}::ng-deep .mat-mdc-select-panel{background-color:#fff!important}.rotate-180{rotate:180deg}.feedback-icon{height:18px;width:18px}.recommended-question-for-resource{display:flex;flex-wrap:wrap;height:fit-content}.recommended-question-for-resource .rec-item{height:fit-content}.recommended-question-for-resource .my-5px{margin-top:5px;margin-bottom:5px}.recommended-question-for-resource .mr-5px{margin-right:5px}.recommended-question-for-resource .btn-default{background:#d5c7c70a;border:1px solid #F3962F;color:#1b4ca1;padding:10px;font-size:14px;font-weight:700;cursor:pointer;border-radius:5px}.recommended-question-for-resource .showmore-icon{align-items:flex-start}.recommended-question-for-resource .btn-active{background:#000;border:1px solid rgba(0,0,0,.16);color:#fff}.h-w-34{height:34px;width:34px}.border-gradient-rounded textarea{width:100%;border:none;resize:none;overflow:hidden;font-size:14px;font-family:Lato;box-sizing:border-box;min-height:32px;padding-top:5px}.border-gradient-rounded textarea:focus{outline:none;border:1px solid transparent}.overflow-y-hidden{overflow-y:hidden}.blue-loader-animation{width:18px;height:18px;animation:spin 2s linear infinite;transform-origin:center center}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.margin-top-2px{margin-top:2px}.recommended-question-desc ::ng-deep markdown pre{all:unset;display:revert;box-sizing:border-box;word-wrap:break-word;width:100%}.ai-tutor-popup{position:fixed;top:50px;z-index:999;background-color:#fff;width:100%}.ai-tutor-popup-minimize{position:fixed;bottom:65px;z-index:999;background-color:#fff;width:100%;border-top:3px solid #eff3f9}.ai-popup-mobile-footer{height:25px;bottom:70px;position:fixed}.ai-tutor-mobile-header{justify-content:space-between;padding:0 10px;border-bottom:1px solid #ccc;height:35px;margin-top:15px}.red-circle{background:red;opacity:1;color:#fff;padding:2px 10px;height:20px;width:50px;border-radius:2px;vertical-align:middle;display:flex;justify-content:center;align-items:center;margin-left:8px;margin-top:-10px}\n"], dependencies: [{ kind: "directive", type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i7.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i8.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i8.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i9.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i10.MatLegacyTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i11.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "component", type: i12.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex", "panelWidth", "hideSingleSelectionIndicator"], exportAs: ["matSelect"] }, { kind: "directive", type: i12.MatSelectTrigger, selector: "mat-select-trigger" }, { kind: "component", type: i13.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "pipe", type: i2.PipeDurationTransformPipe, name: "pipeDurationTransform" }] }); }
1150
+ }
1151
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AiTutorComponent, decorators: [{
1152
+ type: Component,
1153
+ args: [{ selector: 'ws-widget-ai-tutor', template: "<!-- <div class=\"tutor-container\">\n<div class=\"learning-type-container\">\n <mat-form-field appearance=\"none\">\n <select matNativeControl required class=\"section-dd\" >\n <option value=\"\">Select learning type here </option>\n <option value=\"\">None</option>\n <option value=\"\">Socratic</option>\n <option value=\"\">Story Telling</option>\n <option value=\"\">Summarisation</option>\n </select>\n </mat-form-field>\n</div>\n<div [ngClass]=\"from === 'chatbot' ? 'ai-tutor-container-chatbot':'ai-tutor-container'\" #scrollMe>\n <div class=\"message-container\" #scrollMe>\n <div class=\"start-chat\" *ngIf=\"aiTutorResultArr?.length === 0\">\n <h2 class=\"hey\">Hey<span *ngIf=\"userInfo?.firstName\">, {{userInfo?.firstName}}</span> </h2>\n <p>Welcome to Ai Tutor,\u2028Get instant explanations, step-by-step learning guidance, and customised learning tailored just for you.</p>\n </div>\n <ng-container *ngFor=\"let chat of aiTutorResultArr; let i =index\">\n <ng-container *ngIf=\"chat.type === 'incoming'\">\n <ng-container *ngIf=\"chat?.answer\">\n <div class=\"flex row-start incoming-msg margin-bottom-s\">\n <div class=\"system-icon\"><img alt=\"ai-icon\" src=\"/assets/icons/chatbot-ai-new.svg\"></div>\n \n <div class=\"system-msg padding-xs\" *ngIf=\"chat?.wordsCount <= 30\" [innerHTML]=\"chat.answer\">\n </div>\n <div class=\"system-msg padding-xs\">\n <div *ngIf=\"chat?.wordsCount > 30\" [innerHTML]=\"chat?.showLess ? chat.shortAnswer : chat.answer\"></div>\n <a class=\"link\" href=\"javascript:void(0)\" *ngIf=\"!chat?.showLess\" (click)=\"toggleShow(i, 'less')\">Show Less</a>\n <a class=\"link\" href=\"javascript:void(0)\" *ngIf=\"chat?.showLess\" (click)=\"toggleShow(i, 'more')\">Show More</a>\n </div>\n \n\n </div>\n <ng-container *ngFor=\"let item of chat?.result; let ci=index\">\n <div class=\"system-msg-mimetype flex flex-col\" *ngIf=\"item?.contentType === 'Resource'\">\n <ng-container *ngIf=\"item?.mimeType === 'application/pdf'\">\n <div class=\"resource-icon\"><a [href]=\"item?.resourceLink\" target=\"_blank\"><img src=\"/assets/icons/ai-pdf-icon.jpg\"></a></div>\n <div class=\"resource-link\">\n <a [href]=\"item?.resourceLink\" target=\"_blank\">Open Resource Link</a>\n </div>\n </ng-container>\n <ng-container *ngIf=\"item?.mimeType === 'video/mp4'\">\n \n <div class=\"position-relative\">\n <div class=\"position-relative\">\n <img src=\"/assets/icons/ai-video-icon.jpg\">\n\n </div>\n <div class=\"content-duration\" *ngIf=\"item?.contentStart || item?.contentEnd\">\n <span *ngIf=\"item?.contentStart\">{{item?.contentStart}}</span>\n <span *ngIf=\"item?.contentEnd\">:{{item?.contentEnd}}</span>\n </div>\n </div>\n <div class=\"resource-link\">\n <a [href]=\"item?.resourceLink\" target=\"_blank\">Open Resource Link</a>\n </div>\n </ng-container>\n </div>\n <div class=\"recommended-question my-5px\" [ngClass]=\"{'margin-left-5': item?.message }\">\n <div class=\"my-5px mr-2\">\n <ng-container *ngIf=\"item?.contentType !== 'Resource'\">\n <div class=\"btn-default\" (click)=\"redirectToToc(item)\">{{item?.title}}\n <mat-icon class=\"vertical-middle\">navigate_next</mat-icon>\n </div>\n <div>\n {{item?.description | slice : 0:50}}\n </div>\n </ng-container>\n </div>\n <div class=\"flex flex-row font-12\">\n <div class=\"cursor-pointer\" (click)=\"copyPath(item, ci)\">\n <mat-icon matTooltip=\"Copy\" aria-label=\"Copy\">content_copy</mat-icon>\n <span *ngIf=\"copiedIndex === ci\" class=\"copied-tooltip\">Link Copied!</span>\n </div>\n <div class=\"ml-2 mr-2\"><img alt=\"ai-icon\" src=\"/assets/ai-tutor/ai-icon.svg\"></div>\n <div class=\"ai-generated-content ml-2\">These are AI generated results</div>\n </div>\n </div>\n </ng-container>\n \n \n </ng-container>\n <ng-container *ngIf=\"!chat?.answer\">\n <div class=\"flex row-start incoming-msg margin-bottom-s\">\n <div class=\"system-icon\"><img alt=\"ai-icon\" src=\"/assets/icons/chatbot-ai-new.svg\"></div>\n <div class=\"loading-bar-icon\"><img alt=\"ai-icon\" src=\"/assets/icons/loading_bar.gif\"></div>\n </div>\n \n </ng-container>\n </ng-container>\n \n <ng-container *ngIf=\"chat.type === 'sendMsg'\">\n <div class=\"flex width-1-1 row-end padding-top-l padding-bottom-m\">\n <div class=\"user-seleted-question padding-xs\">\n {{chat?.question}}\n </div>\n <div class=\"user-icon\" *ngIf=\"userIcon\">\n <img alt=\"ai-icon\" src=\"{{userIcon}}\">\n </div>\n <div class=\"circle-s user-icon\" *ngIf=\"!userIcon\" [ngStyle]=\"{'background-color': circleColor }\">\n <div class=\"initials\" i18n-aria-label>\n {{ userInitials }} \n </div>\n </div>\n </div>\n </ng-container>\n </ng-container>\n </div> \n</div>\n<div class=\"control-container\">\n <div class=\"border-gradient-rounded\">\n <div class=\"flex flex-row mx-5 justify-between\">\n\n <div class=\"query-box\">\n <input class=\"width-500\" type=\"text\" placeholder=\"Ask anything...\" [(ngModel)]=\"searchQueryAItutor\" (keydown.enter)=\"submitSearchQuery()\"/>\n \n </div>\n\n <div>\n <button type=\"button\" class=\"flex-auto-display send-btn\" (click)=\"submitSearchQuery()\" [disabled]=\"!searchQueryAItutor\">\n <mat-icon class=\"send-btn-icon\">send</mat-icon>\n </button>\n </div>\n </div>\n </div>\n</div>\n</div> -->\n\n<div class=\"overflow-y-hidden\" [ngClass]=\"(isMobile && !maximize ? 'ai-tutor-popup-minimize' : (isMobile ? 'ai-tutor-popup': ''))\">\n<div *ngIf=\"isMobile\">\n <div class=\"flex flex-row ai-tutor-mobile-header\">\n <div class=\"flex flex-row\">\n <div class=\"flex\">\n <span class=\"font-bold\">AI Tutor</span>\n </div> \n <div class=\"red-circle ml-5\">\n New\n </div>\n </div>\n <div class=\"flex flex-row justify-end\">\n <div *ngIf=\"maximize\" (click)=\"minimizeAITutor()\">\n <mat-icon>minimize</mat-icon>\n </div>\n <div *ngIf=\"!maximize\" (click)=\"maximizeAITutor()\">\n <mat-icon>maximize</mat-icon>\n </div>\n <div (click)=\"closeAITutorPopup()\">\n <mat-icon>close</mat-icon>\n </div>\n </div>\n \n \n </div>\n</div>\n<div [hidden]=\"!maximize\">\n<div class=\"header\">\n <!-- <mat-form-field appearance=\"none\" style=\"width:100%\">\n <select matNativeControl required class=\"section-dd\" >\n <option value=\"\">You can also choose a learning style that suits you best from here.</option>\n <option value=\"\">None</option>\n <option value=\"\">Socratic</option>\n <option value=\"\">Story Telling</option>\n <option value=\"\">Summarisation</option>\n </select>\n </mat-form-field> -->\n <mat-form-field class=\"multiline-select\" appearance=\"fill\" style=\"width: 100%; height: 80px;\" floatLabel=\"never\">\n <mat-select class=\"multiline-select-box\" required [(value)]=\"selectedLearningStyle\" (selectionChange)=\"getLearningStyle()\">\n <mat-select-trigger class=\"multiline-select-box-trigger\">\n <div class=\"option-content\">\n <div class=\"title\">{{ selectedLearningStyle?.title }}</div>\n <div class=\"subtitle\">{{ selectedLearningStyle?.subtitle }}</div>\n </div>\n </mat-select-trigger>\n <mat-option class=\"multiline-select-option\" value=\"\" *ngFor=\"let item of learningStyle\" [value]=\"item\">\n <div class=\"option-content\">\n <div class=\"title\">{{item?.title}}</div>\n <div class=\"subtitle\">{{item?.subtitle}}</div>\n </div>\n </mat-option>\n </mat-select>\n </mat-form-field>\n \n</div>\n\n<div class=\"container-none\" id=\"container-none\">\n <div [ngClass]=\"from === 'chatbot' ? 'ai-tutor-container-chatbot':'ai-tutor-container'\">\n <div class=\"message-container\" #scrollMe>\n <div class=\"start-chat\" *ngIf=\"aiTutorResultArr?.length === 0\">\n <h2 class=\"hey\">Hey<span *ngIf=\"userInfo?.firstName\">, {{userInfo?.firstName}}</span> </h2>\n <p>Welcome to AI Tutor,\u2028Get instant explanations, step-by-step learning guidance, and customised learning tailored just for you.</p>\n </div>\n <ng-container *ngFor=\"let chat of aiTutorResultArr; let i =index\">\n <ng-container *ngIf=\"chat.type === 'incoming'\">\n <ng-container *ngIf=\"chat?.answer || chat?.showFromInternet\">\n <div class=\"flex row-start incoming-msg margin-bottom-s\" *ngIf=\"chat?.answer\">\n <div class=\"system-icon\"><img alt=\"ai-icon\" src=\"/assets/icons/bot-chat-small.svg\"></div>\n \n <!-- <div class=\"system-msg padding-xs\" *ngIf=\"chat?.wordsCount <= 30\" [innerHTML]=\"chat.answer\">\n </div> -->\n <div class=\"flex row-start incoming-msg margin-bottom-s\" *ngIf=\"chat?.showFromInternet\">\n <div class=\"system-msg padding-xs mx-10\">\n I couldn\u2019t find any relevant results for your query. Would you like me to search outside the iGOT platform for more information?\n </div>\n \n </div>\n <ng-container *ngIf=\"chat?.answer\">\n <div class=\"system-msg padding-xs\" *ngIf=\"chat?.wordsCount <= 30\">\n <markdown [data]=\"chat?.answer\"></markdown>\n </div>\n \n <div class=\"system-msg padding-xs\" *ngIf=\"chat?.wordsCount > 30\" >\n <!-- <div [innerHTML]=\"chat?.showLess ? chat.shortAnswer : chat.answer\"></div> -->\n <markdown [data]=\"chat?.answer\"></markdown>\n <!-- <markdown [data]=\"chat?.showLess ? chat.shortAnswer : chat.answer\"></markdown> -->\n <!-- <a class=\"link\" href=\"javascript:void(0)\" *ngIf=\"!chat?.showLess\" (click)=\"toggleShow(i, 'less')\">Show Less</a>\n <a class=\"link\" href=\"javascript:void(0)\" *ngIf=\"chat?.showLess\" (click)=\"toggleShow(i, 'more')\">Show More</a> -->\n </div>\n </ng-container>\n \n \n </div>\n \n <div *ngIf=\"chat?.showFromInternet\">\n <div class=\"flex row my-2 justify-start mx-10 my-5\">\n <div (click)=\"callFromInternet(chat, i)\">\n <button type=\"button\" class=\"web-button px-4 cursor-pointer\">\n <mat-icon class=\"web-search-icon\">search </mat-icon><span class=\"blue-color\">Search the web</span>\n </button>\n </div>\n <div (click)=\"rejectFromInternet(i)\" class=\"mx-2\">\n <button type=\"button\" class=\"web-button py-2 px-4 cursor-pointer\">\n <mat-icon class=\"web-close-icon\">close</mat-icon><span class=\"blue-color\">No</span>\n </button>\n </div>\n </div>\n </div>\n <ng-container *ngFor=\"let item of chat?.result; let ci=index\">\n <div class=\"system-msg-mimetype flex flex-col\" *ngIf=\"item?.contentType === 'Resource'\">\n <ng-container *ngIf=\"item?.mimeType === 'application/pdf'\">\n <!-- <div class=\"resource-icon\"><a [href]=\"item?.resourceLink\" target=\"_blank\" (click)=\"raiseTelemetryForResource(item)\">\n <img src=\"/assets/icons/ai-pdf-icon.jpg\"></a>\n </div> -->\n <div class=\"recommended-question-for-resource mx-10\" (click)=\"redirectToResource(item);raiseTelemetryForResource(item)\">\n <!-- <div class=\"resource-icon\">\n <a [href]=\"item?.resourceLink\" target=\"_blank\" (click)=\"raiseTelemetryForResource(item)\">\n <img src=\"/assets/ai-tutor/pdf.svg\">\n </a>\n <p>{{item?.message}}</p>\n </div> -->\n <div class=\"btn-default mb-2\">\n <a [href]=\"item?.resourceLink\" target=\"_blank\">\n <img class=\"vertical-middle h-w-34\" src=\"/assets/ai-tutor/pdf.svg\">\n </a>\n {{item?.title}}\n <mat-icon class=\"vertical-middle\" *ngIf=\"!(item?.fromInternet)\">navigate_next</mat-icon>\n </div>\n </div>\n <!-- <div class=\"resource-link\">\n <a [href]=\"item?.resourceLink\" target=\"_blank\">Click to view</a>\n </div> -->\n </ng-container>\n <!-- <ng-container *ngIf=\"item?.mimeType === 'video/mp4'\">\n \n <div class=\"resource-icon\">\n <a [href]=\"item?.resourceLink\" target=\"_blank\" (click)=\"raiseTelemetryForResource(item)\">\n <div class=\"position-relative\">\n <div class=\"position-relative\">\n <img src=\"/assets/icons/ai-video-icon.jpg\">\n \n </div>\n <div class=\"content-duration flex\" *ngIf=\"item?.contentStart > -1 && item?.contentEnd > -1 && !(item?.fromInternet)\">\n <span><mat-icon>access_time</mat-icon>&nbsp;&nbsp;</span>\n <span *ngIf=\"item?.contentStart > -1\">\n <span *ngIf=\"item?.contentStart > 0\">{{item?.contentStart | pipeDurationTransform: 'hms'}}</span>\n <span *ngIf=\"item.contentStart === '0'\">0</span>\n </span>\n <span *ngIf=\"item?.contentEnd > -1\">&nbsp;-&nbsp;{{item?.contentEnd | pipeDurationTransform: 'hms'}}</span>\n </div>\n </div>\n \n \n </a>\n </div>\n </ng-container> -->\n <ng-container *ngIf=\"item?.mimeType === 'video/mp4'\">\n <div class=\"recommended-question-for-resource mx-10\" (click)=\"redirectToResource(item);raiseTelemetryForResource(item)\">\n \n <div class=\"btn-default mb-2\">\n <div class=\"flex flex-row\">\n <div>\n <a [href]=\"item?.resourceLink\" target=\"_blank\">\n <img class=\"vertical-middle h-w-34\" src=\"/assets/ai-tutor/video.svg\">\n </a>\n </div>\n <div class=\"ml-1\">\n <span>{{item?.title}} </span>\n </div>\n <div>\n <span class=\"content-duration flex ml-1\" *ngIf=\"item?.contentStart > -1 && item?.contentEnd > -1 && !(item?.fromInternet)\">\n <span><mat-icon>access_time</mat-icon>&nbsp;&nbsp;</span>\n <span *ngIf=\"item?.contentStart > -1\">\n <span *ngIf=\"item?.contentStart > 0\">{{item?.contentStart | pipeDurationTransform: 'hms'}}</span>\n <span *ngIf=\"item.contentStart === '0'\">0</span>\n </span>\n <span *ngIf=\"item?.contentEnd > -1\">&nbsp;-&nbsp;{{item?.contentEnd | pipeDurationTransform: 'hms'}}</span>\n </span> \n </div>\n <div>\n <mat-icon class=\"vertical-middle\" *ngIf=\"!(item?.fromInternet)\">navigate_next</mat-icon>\n </div>\n </div>\n </div>\n <!-- <a [href]=\"item?.resourceLink\" target=\"_blank\" (click)=\"raiseTelemetryForResource(item)\">\n <div class=\"position-relative\">\n <div class=\"position-relative\">\n <img class=\"h-w-34\" src=\"/assets/ai-tutor/video.svg\">\n <p>{{item?.message}}</p>\n </div>\n <div class=\"content-duration flex\" *ngIf=\"item?.contentStart > -1 && item?.contentEnd > -1 && !(item?.fromInternet)\">\n <span><mat-icon>access_time</mat-icon>&nbsp;&nbsp;</span>\n <span *ngIf=\"item?.contentStart > -1\">\n <span *ngIf=\"item?.contentStart > 0\">{{item?.contentStart | pipeDurationTransform: 'hms'}}</span>\n <span *ngIf=\"item.contentStart === '0'\">0</span>\n </span>\n <span *ngIf=\"item?.contentEnd > -1\">&nbsp;-&nbsp;{{item?.contentEnd | pipeDurationTransform: 'hms'}}</span>\n </div>\n </div>\n \n \n </a> -->\n </div>\n </ng-container>\n <div class=\"flex flex-row cursor-pointer\">\n <!-- <div class=\"resource-link\" *ngIf=\"!(item?.fromInternet)\">\n <a [href]=\"item?.resourceLink\" target=\"_blank\">Click to view</a>\n </div> -->\n <div class=\"cursor-pointer ml-10 mr-2 my-1\" (click)=\"copyPath(item, ci)\" *ngIf=\"item?.contentType === 'Resource' && !(item?.fromInternet)\">\n <mat-icon matTooltip=\"Copy\" aria-label=\"Copy\">content_copy</mat-icon>\n <span *ngIf=\"copiedIndex === ci\" class=\"copied-tooltip\">Link Copied!</span>\n </div>\n <!-- <div class=\"feefback-section flex flex-row my-1\" *ngIf=\"(item?.feedback)\">\n <div *ngIf=\"item?.feedback !== 'down'\"\n class=\"cursor-pointer feedback-icon mt-1\" [ngClass]=\"item?.feedback !== 'up' ? 'rotate-180' : ''\">\n <img *ngIf=\"item?.feedback !== 'up'\" src=\"/assets/ai-tutor/down.svg\">\n <img *ngIf=\"item?.feedback == 'up'\" src=\"/assets/ai-tutor/up.svg\">\n </div>\n <div *ngIf=\"item?.feedback !== 'up'\" class=\"ml-2 cursor-pointer feedback-icon\">\n <img src=\"/assets/ai-tutor/fill-down.svg\">\n </div>\n </div>\n <div class=\"feefback-section flex flex-row my-1\" *ngIf=\"item?.feedback === ''\">\n <div *ngIf=\"item?.feedback !== 'down'\" (click)=\"sharePositiveContentRating(item,i, ci)\"\n class=\"cursor-pointer feedback-icon\" [ngClass]=\"item?.feedback !== 'up' ? 'rotate-180' : ''\">\n <img *ngIf=\"item?.feedback !== 'up'\" src=\"/assets/ai-tutor/down.svg\">\n <img *ngIf=\"item?.feedback == 'up'\" src=\"/assets/ai-tutor/up.svg\">\n </div>\n <div *ngIf=\"item?.feedback !== 'up'\" (click)=\"openAIFeedbackPopup(item,i, ci)\" class=\"ml-2 cursor-pointer feedback-icon mt-1\">\n <img src=\"/assets/ai-tutor/down.svg\">\n </div>\n </div> -->\n <div class=\"feefback-section flex flex-row my-1\">\n <div (click)=\"sharePositiveContentRating(item,i, ci)\" class=\"cursor-pointer feedback-icon mt-1\" \n >\n <img [ngClass]=\"'rotate-180'\" *ngIf=\"item?.feedback !== 'up' && !item?.showLoaderForUp\" src=\"/assets/ai-tutor/down.svg\">\n <img *ngIf=\"item?.feedback === 'up' && !item?.showLoaderForUp\" src=\"/assets/ai-tutor/up.svg\">\n <img *ngIf=\"item?.showLoaderForUp\" class=\"blue-loader-animation\" height=\"18\" width=\"18\" src=\"/assets/ai-tutor/blue-loader.png\">\n </div>\n <div (click)=\"openAIFeedbackPopup(item,i, ci)\" class=\"ml-2 cursor-pointer feedback-icon mt-1\">\n <img *ngIf=\"item?.feedback !== 'down' && !item?.showLoaderForDown\" src=\"/assets/ai-tutor/down.svg\"> \n <img *ngIf=\"item?.feedback === 'down' && !item?.showLoaderForDown\" src=\"/assets/ai-tutor/fill-down.svg\"> \n <img *ngIf=\"item?.showLoaderForDown\" class=\"blue-loader-animation\" height=\"18\" width=\"18\" src=\"/assets/ai-tutor/blue-loader.png\">\n </div>\n </div>\n <!-- <div class=\"flex flex-row font-12 mt-1\">\n <div class=\"ml-2 mr-2 cu\"><img alt=\"ai-icon\" src=\"/assets/ai-tutor/ai-icon.svg\"></div>\n <div class=\"ai-generated-content ml-2\">These are <span *ngIf=\"item?.fromInternet\">Web</span><span *ngIf=\"!(item?.fromInternet)\">AI</span> generated results</div>\n </div> -->\n <!-- <div class=\"feefback-section flex flex-row\">\n \n <div *ngIf=\"item?.feedback !== 'down'\" (click)=\"sharePositiveContentRating(item,i, ci)\"\n class=\"cursor-pointer feedback-icon\" [ngClass]=\"item?.feedback !== 'up' ? 'rotate-180' : ''\">\n <img *ngIf=\"item?.feedback !== 'up'\" src=\"/assets/ai-tutor/down.svg\">\n <img *ngIf=\"item?.feedback == 'up'\" src=\"/assets/ai-tutor/up.svg\">\n </div>\n <div *ngIf=\"item?.feedback !== 'up'\" (click)=\"openAIFeedbackPopup(item,i, ci)\" class=\"ml-2 cursor-pointer feedback-icon\"><img src=\"/assets/ai-tutor/down.svg\"></div>\n </div> -->\n </div>\n \n </div>\n <div class=\"recommended-question\" [ngClass]=\"{'ml-10': item?.message }\">\n <div class=\"my-5px mr-2 w-92\">\n <ng-container *ngIf=\"item?.contentType !== 'Resource' && !(item?.fromInternet)\">\n <div class=\"btn-default\" (click)=\"redirectToToc(item)\">{{item?.title}}\n <mat-icon class=\"vertical-middle\" *ngIf=\"!(item?.fromInternet)\">navigate_next</mat-icon>\n </div>\n <div class=\"recommended-question-desc\" *ngIf=\"!(item?.fromInternet)\">\n <!-- {{item?.description}} -->\n <markdown [data]=\"item?.description\"></markdown>\n </div>\n </ng-container>\n </div>\n <div class=\"flex flex-row font-12 mb-2\">\n <div class=\"cursor-pointer\" (click)=\"copyPath(item, ci)\" *ngIf=\"item?.contentType !== 'Resource' && !(item?.fromInternet)\">\n <mat-icon matTooltip=\"Copy\" aria-label=\"Copy\">content_copy</mat-icon>\n <span *ngIf=\"copiedIndex === ci\" class=\"copied-tooltip\">Link Copied!</span>\n </div>\n <!-- <div class=\"feefback-section flex flex-row\" *ngIf=\"item?.contentType !== 'Resource'\">\n \n <div *ngIf=\"item?.feedback !== 'down'\" (click)=\"sharePositiveContentRating(item, i,ci)\" \n class=\"cursor-pointer feedback-icon\" [ngClass]=\"item?.feedback !== 'up' ? 'rotate-180' : ''\">\n <img *ngIf=\"item?.feedback !== 'up'\" src=\"/assets/ai-tutor/down.svg\">\n <img *ngIf=\"item?.feedback == 'up'\" src=\"/assets/ai-tutor/up.svg\">\n </div>\n <div *ngIf=\"item?.feedback !== 'up'\" (click)=\"openAIFeedbackPopup(item, i,ci)\" class=\"ml-2 cursor-pointer feedback-icon\"><img src=\"/assets/ai-tutor/down.svg\"></div>\n </div> -->\n <div class=\"feefback-section flex flex-row\" *ngIf=\"item?.contentType !== 'Resource'\">\n <div (click)=\"sharePositiveContentRating(item,i, ci)\" class=\"cursor-pointer feedback-icon mt-1\" \n >\n <img [ngClass]=\"'rotate-180'\" *ngIf=\"item?.feedback !== 'up' && !item?.showLoaderForUp\" src=\"/assets/ai-tutor/down.svg\">\n <img *ngIf=\"item?.feedback === 'up' && !item?.showLoaderForUp\" src=\"/assets/ai-tutor/up.svg\">\n <img *ngIf=\"item?.showLoaderForUp\" class=\"blue-loader-animation\" height=\"18\" width=\"18\" src=\"/assets/ai-tutor/blue-loader.png\">\n </div>\n <div (click)=\"openAIFeedbackPopup(item,i, ci)\" class=\"ml-2 cursor-pointer feedback-icon mt-1\">\n <img *ngIf=\"item?.feedback !== 'down' && !item?.showLoaderForDown\" src=\"/assets/ai-tutor/down.svg\"> \n <img *ngIf=\"item?.feedback === 'down' && !item?.showLoaderForDown\" src=\"/assets/ai-tutor/fill-down.svg\"> \n <img *ngIf=\"item?.showLoaderForDown\" class=\"blue-loader-animation\" height=\"18\" width=\"18\" src=\"/assets/ai-tutor/blue-loader.png\">\n </div>\n </div> \n </div>\n <!-- <div class=\"flex flex-row font-12 mt-1\" *ngIf=\"item?.contentType !== 'Resource'\">\n <div class=\"ml-2 mr-2 cu\"><img alt=\"ai-icon\" src=\"/assets/ai-tutor/ai-icon.svg\"></div>\n <div class=\"ai-generated-content ml-2\">These are <span *ngIf=\"item?.fromInternet\">Web</span><span *ngIf=\"!(item?.fromInternet)\">AI</span> generated results</div>\n </div> -->\n </div>\n </ng-container>\n <div class=\" flex flex-row ml-10\" *ngIf=\"chat?.answer && !(chat?.result?.length)\">\n <div (click)=\"sharePositiveContentRatingForAnswer(chat,i)\" class=\"cursor-pointer feedback-icon mt-1\" \n >\n <img [ngClass]=\"'rotate-180'\" *ngIf=\"chat?.feedback !== 'up' && !chat?.showLoaderForUp\" src=\"/assets/ai-tutor/down.svg\">\n <img *ngIf=\"chat?.feedback === 'up' && !chat?.showLoaderForUp\" src=\"/assets/ai-tutor/up.svg\">\n <img *ngIf=\"chat?.showLoaderForUp\" class=\"blue-loader-animation\" height=\"18\" width=\"18\" src=\"/assets/ai-tutor/blue-loader.png\">\n </div>\n <div (click)=\"openAIFeedbackPopupForAnswer(chat,i)\" class=\"ml-2 cursor-pointer feedback-icon mt-1\">\n <img *ngIf=\"chat?.feedback !== 'down' && !chat?.showLoaderForDown\" src=\"/assets/ai-tutor/down.svg\"> \n <img *ngIf=\"chat?.feedback === 'down' && !chat?.showLoaderForDown\" src=\"/assets/ai-tutor/fill-down.svg\"> \n <img *ngIf=\"chat?.showLoaderForDown\" class=\"blue-loader-animation\" height=\"18\" width=\"18\" src=\"/assets/ai-tutor/blue-loader.png\">\n </div>\n </div> \n <div class=\"flex flex-row font-12 mt-1 mb-1 ai-generated-content-container\" *ngIf=\"chat?.result?.length\">\n <div class=\"ml-5 mr-2 cu\"><img alt=\"ai-icon\" src=\"/assets/ai-tutor/ai-icon.svg\"></div>\n <div class=\"ai-generated-content ml-2\">These are <span *ngIf=\"item?.fromInternet\">Web</span><span *ngIf=\"!(item?.fromInternet)\">AI</span> generated results</div>\n </div>\n \n </ng-container>\n <ng-container>\n <div class=\"flex row-start incoming-msg margin-bottom-s\" *ngIf=\"chat?.newMessage === '' && !resultFetch\">\n <div class=\"system-icon\"><img alt=\"ai-icon\" src=\"/assets/icons/bot-chat-small.svg\"></div>\n <div class=\"loading-bar-icon flex flex-row vertical-middle\">\n <div class=\"mt-2\"><span class=\"blue-color\">Retrieving Results</span></div>\n <div><img alt=\"ai-icon\" src=\"/assets/icons/loading_bar.gif\"></div>\n </div>\n </div>\n \n </ng-container>\n </ng-container>\n \n <ng-container *ngIf=\"chat.type === 'sendMsg'\">\n <div class=\"flex width-1-1 row-end padding-top-l padding-bottom-m\">\n <div class=\"user-seleted-question padding-xs\">\n {{chat?.question}}\n </div>\n <div class=\"user-icon\" *ngIf=\"userIcon\">\n <img alt=\"ai-icon\" src=\"{{userIcon}}\">\n </div>\n <div class=\"circle-s user-icon\" *ngIf=\"!userIcon\" [ngStyle]=\"{'background-color': circleColor }\">\n <div class=\"initials\" i18n-aria-label>\n {{ userInitials }} \n </div>\n </div>\n </div>\n </ng-container>\n </ng-container>\n </div> \n </div>\n</div>\n\n<div class=\"footer\" [ngClass]=\"isMobile ? 'ai-popup-mobile-footer':''\">\n <div class=\"border-gradient-rounded\" [style.height.px]=\"containerHeight\">\n <div class=\"flex flex-row ml-5 mr-2 justify-between\">\n\n <div class=\"query-box\">\n <!-- <input class=\"width-500\" type=\"text\" placeholder=\"Ask anything...\" [(ngModel)]=\"searchQueryAItutor\" (keydown.enter)=\"submitSearchQuery()\"/> -->\n <textarea #autoResizeTextarea class=\"width-500\"\n placeholder=\"Ask Me Anything...\"\n (input)=\"resizeTextarea(autoResizeTextarea, 'fromInput')\"\n [(ngModel)]=\"searchQueryAItutor\" (keydown.enter)=\"submitSearchQuery(autoResizeTextarea, $event)\"\n rows=\"1\"\n >\n </textarea>\n \n </div>\n\n <div class=\"margin-top-2px\">\n <button type=\"button\" class=\"flex-auto-display send-btn\" (click)=\"submitSearchQuery(autoResizeTextarea, $event)\" [disabled]=\"!searchQueryAItutor\">\n <mat-icon class=\"send-btn-icon\">send</mat-icon>\n </button>\n </div>\n </div>\n </div>\n</div>\n</div>\n</div>", styles: [".hey{background:linear-gradient(90deg,#32b9dfde,#1b4ca1de);-webkit-background-clip:text;background-clip:text;color:transparent}.ai-generated-content{background:linear-gradient(90deg,#f3962f,#1b4ca1);-webkit-background-clip:text;background-clip:text;color:transparent}.ai-tutor-container .control-container{position:fixed;bottom:0;width:24%;z-index:2;background:#fff;height:40px}.ai-tutor-container-chatbot .control-container{position:fixed;bottom:100px;width:600px;margin:1%;z-index:2}.start-chat{text-align:center;padding-top:37.5%}.query-box{min-height:38px;transition:height .2s;width:100%}.query-box input{border:0;outline:0}.border-gradient-rounded{border:2px solid transparent;border-radius:20px;background:linear-gradient(to right,#fff,#fff),linear-gradient(to right,#efa34f,#4881e4);background-clip:padding-box,border-box;background-origin:padding-box,border-box;width:96%;min-height:36px;margin-left:1%;z-index:3}.send-btn{background-color:#fff!important;color:#1b4ca1!important;border:none!important;margin-left:14px}.ai-tutor-container-chatbot{background-image:url(/assets/ai-tutor/background.svg);height:90vh;width:525px}.message-container{z-index:2;position:relative;width:100%}.chatbot-icon-container{position:fixed;bottom:120px;right:0;cursor:pointer;height:90px;align-items:flex-start;display:flex;justify-content:center;width:auto;z-index:999999999}.chatbot-icon{position:absolute;right:30px;animation-delay:1s;transition:1s ease}.chatbot-icon-expanded{right:0}.expand-text{width:110px;display:flex;align-items:center;justify-content:center;background-color:#1b4ca1;color:#fff;font-size:18px;border-top:2px solid #fff;border-bottom:2px solid #fff;vertical-align:middle}.chatbot{width:610px;position:fixed;bottom:20px;right:50px;z-index:9999999999;border-radius:15px;background-color:#fff;box-shadow:0 6px 16px #0000003d;height:calc(100vh - 20%)}.cb-close{cursor:pointer}.cb-header{color:#fff!important;background-color:#1b4ca1;border-top-left-radius:15px;border-top-right-radius:15px;align-items:center;justify-content:space-between;position:absolute;width:100%;top:0}.cb-header .user-info-div{width:88%;justify-content:space-between}.cb-header .lang-select{height:32px;background-color:#fff;border-color:#00000029!important}.cb-header .user-name{padding-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:74%}.cb-content{background-color:#f0f3f4;overflow:auto}.cb-topics{padding:16px;background-color:#f5f5f5;overflow:auto}.cb-footer{border-bottom-left-radius:15px;border-bottom-right-radius:15px;background-color:#fff}.cb-footer .info{width:33%;padding:5px 0;align-items:center;display:flex;justify-content:center;flex-wrap:wrap;cursor:pointer}.cb-footer .info .info-text{font-size:10px;width:100%;text-align:center}.cb-footer .info .info-icon{height:24px}.br-br{border-bottom-right-radius:15px}.br-bl{border-bottom-left-radius:15px}.language{background-color:#0000000a}.active{background-color:#fbead1;border-top:3px solid rgb(239,149,30)}.active .mat-icon{color:#ef951e!important}.cat-list{margin:0;padding:0;width:100%;display:flex}.cat-item{padding:10px 16px;border-radius:21px;border:1px solid rgba(0,0,0,.16);background-color:#0000000a;opacity:1;color:#000000de;font-family:Lato-Regular,sans-serif;font-size:14px;font-weight:400;font-style:normal;letter-spacing:.25px;text-align:center;line-height:20px;width:fit-content;margin-right:12px;height:fit-content;cursor:pointer;white-space:nowrap}.lang-select{width:70px}.lang-select .mat-form-field-flex{background-color:#fff!important}.lang-select .mat-form-field-underline{background-color:transparent!important}.loader{position:absolute;left:50%;top:39%}.default-info .default-icon{width:60px;float:left;display:flex;flex-wrap:wrap}.default-info .default-msg{background-color:#0000000a;border:1px solid rgba(0,0,0,.16);border-radius:0 15px 15px;display:flex;flex-wrap:wrap}.chat-bot-icon{padding-top:8px}.row-start{justify-content:flex-start}.row-start .system-icon{padding-right:3px}.row-start .system-msg{background-color:#d1dbec;border:1px solid rgb(209,219,236);border-radius:0 15px 15px;display:flex;flex-wrap:wrap;min-width:auto;max-width:80%;height:100%;word-break:break-word}.row-start .system-msg ::ng-deep markdown *{margin:0}.recommended-question-desc ::ng-deep markdown *{margin:0;width:100%;word-wrap:break-word}.word-break{word-break:break-all;white-space:unset}.margin-left-5{margin-left:5%}.question-hint{font-weight:700}.recommended-question{display:flex;flex-wrap:wrap;height:fit-content}.recommended-question .rec-item{height:fit-content}.recommended-question .my-5px{margin-top:5px;margin-bottom:5px}.recommended-question .mr-5px{margin-right:5px}.recommended-question .btn-default{background:#d5c7c70a;border:1px solid #1B4CA1;color:#1b4ca1;padding:10px;font-size:14px;font-weight:700;cursor:pointer;border-radius:5px}.recommended-question .showmore-icon{align-items:flex-start}.recommended-question .btn-active{background:#000;border:1px solid rgba(0,0,0,.16);color:#fff}.btn-show-more,.btn-show-less{background:#1b4ca1;color:#fff;padding:10px 20px;font-size:14px;cursor:pointer;border-radius:40px}.row-end{justify-content:flex-end;height:100%}.row-end .user-seleted-question{background-color:#000;border-radius:15px 0 15px 15px;display:flex;flex-wrap:wrap;color:#fff;float:right;text-align:left;max-width:62%;word-break:break-word}.highlight-title{color:#1b4ca1}.incoming-msg{height:fit-content}.hint-text{color:#1b4ca1}@media only screen and (max-width: 600px){.chatbot{right:6px;bottom:67px}}@media only screen and (max-width: 390px){.chatbot{right:6px;bottom:67px}}.chatbot-wrapper{position:relative}.cb-content-wrapper{position:absolute;width:100%;top:64px;bottom:130px;max-height:100%;overflow:auto;box-sizing:border-box;background-color:#f0f3f4}.cb-footer-wrapper{position:absolute;width:100%;bottom:0}.my-5px{margin-top:5px;margin-bottom:5px}.mr-5px{margin-right:5px}*,:after,:before{box-sizing:border-box}::ng-deep .disable-scroll{overflow-x:hidden!important;overflow:hidden}@media only screen and (max-width: 600px){.chatbot{right:0;bottom:0;width:100%;height:100svh;z-index:999999999}.cb-footer-wrapper{bottom:0}.cb-content-wrapper{bottom:130px}.chatbot-icon-container{bottom:190px}.cb-header{border-top-left-radius:unset;border-top-right-radius:unset}.cb-footer{border-bottom-left-radius:unset;border-bottom-right-radius:unset}.br-br{border-bottom-right-radius:unset}.br-bl{border-bottom-left-radius:unset}}.feefback-section{margin-left:10px}.resource-icon{margin-left:10%}.resource-link{margin-left:40px}.resource-icon img{height:65px;width:115.25px}.font-12{font-size:12px}.vertical-middle{vertical-align:middle}.send-btn-icon{height:22px!important}.width-500{width:262px}.learning-type-container{width:98%}.section-dd{border:1px solid #ccc;padding:12px 16px;width:100%;height:65px;font-size:12px;font-weight:400;position:relative;z-index:2}.system-icon img{height:36px;width:36px}.circle-s{border-radius:50%;width:36px;height:36px;display:flex;justify-content:center;align-items:center;margin-left:4px}.circle-s img{border-radius:50%;width:100%;height:100%}.circle-s .initials{color:#fff;font-size:10px;line-height:12px;font-size:14px;letter-spacing:.2625px}.copied-tooltip{position:absolute;left:20%;transform:translate(-50%);background-color:#000;color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;opacity:1;pointer-events:none;transition:opacity .3s ease;z-index:999}.loading-bar-icon img{height:50px;width:50px}.link{color:#1b4ca1;text-decoration:underline}.content-duration{position:relative;background:#f3962f;color:#fff;width:auto;border-radius:8px;text-align:center;bottom:11px;left:0;padding:0 5px;font-size:12px;display:flex;align-items:center;justify-content:center;margin-top:12px;white-space:nowrap}.content-duration .mat-icon{vertical-align:middle;color:#fff!important;height:14px!important;width:14px!important;font-size:14px}.position-relative{position:relative}.control-container{position:fixed;bottom:10px;z-index:2}.tutor-container{width:100%}.header{top:127px;width:100%;color:#fff;display:flex;align-items:flex-start;justify-content:flex-start}::ng-deep .header .mat-form-field{width:100%}.footer{bottom:0;width:100%;height:50px;color:#fff;display:flex;align-items:flex-end;justify-content:center;z-index:2}.container-none{margin-bottom:10px;padding:20px;height:calc(100vh - 261px);background:url(/assets/ai-tutor/background.svg);background-color:#f0f3f4;overflow-y:auto;overflow-x:hidden;position:relative;background-color:#ffffffe6;background-blend-mode:overlay}.option-content{display:flex;flex-direction:column;line-height:2}.option-content .title{font-weight:600}.option-content .subtitle{font-size:12px;color:gray}:host ::ng-deep .multiline-select .mat-mdc-select-value-text{white-space:pre-wrap!important}:host ::ng-deep .mat-pseudo-checkbox{display:none!important}:host ::ng-deep .mat-pseudo-checkbox-checked{display:none!important}:host ::ng-deep .multiline-select-option{background-color:#fff!important}:host ::ng-deep .player-content .mat-tab-label-active{opacity:1!important}.user-icon{margin-left:5px}.user-icon img{height:36px;width:36px;border-radius:50%}.w-92{width:92%}::ng-deep .copy-icon .material-icons{font-size:18px!important}::ng-deep .copy-icon .mat-icon{vertical-align:middle}.internet-result-query{background:#add8e6;border:1px solid #1B4CA1;color:#000;padding:10px;font-size:14px;font-weight:700;cursor:pointer;border-radius:5px}.blue-color{color:#1b4ca1;font-size:14px;font-weight:700}.web-button{background-color:#fff;color:#1b4ca1;border-radius:8px;padding:10px;border:1px solid #1B4CA1}.web-search-icon,.web-close-icon{color:#1b4ca1;vertical-align:middle}::ng-deep .mat-mdc-select-panel{background-color:#fff!important}.rotate-180{rotate:180deg}.feedback-icon{height:18px;width:18px}.recommended-question-for-resource{display:flex;flex-wrap:wrap;height:fit-content}.recommended-question-for-resource .rec-item{height:fit-content}.recommended-question-for-resource .my-5px{margin-top:5px;margin-bottom:5px}.recommended-question-for-resource .mr-5px{margin-right:5px}.recommended-question-for-resource .btn-default{background:#d5c7c70a;border:1px solid #F3962F;color:#1b4ca1;padding:10px;font-size:14px;font-weight:700;cursor:pointer;border-radius:5px}.recommended-question-for-resource .showmore-icon{align-items:flex-start}.recommended-question-for-resource .btn-active{background:#000;border:1px solid rgba(0,0,0,.16);color:#fff}.h-w-34{height:34px;width:34px}.border-gradient-rounded textarea{width:100%;border:none;resize:none;overflow:hidden;font-size:14px;font-family:Lato;box-sizing:border-box;min-height:32px;padding-top:5px}.border-gradient-rounded textarea:focus{outline:none;border:1px solid transparent}.overflow-y-hidden{overflow-y:hidden}.blue-loader-animation{width:18px;height:18px;animation:spin 2s linear infinite;transform-origin:center center}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.margin-top-2px{margin-top:2px}.recommended-question-desc ::ng-deep markdown pre{all:unset;display:revert;box-sizing:border-box;word-wrap:break-word;width:100%}.ai-tutor-popup{position:fixed;top:50px;z-index:999;background-color:#fff;width:100%}.ai-tutor-popup-minimize{position:fixed;bottom:65px;z-index:999;background-color:#fff;width:100%;border-top:3px solid #eff3f9}.ai-popup-mobile-footer{height:25px;bottom:70px;position:fixed}.ai-tutor-mobile-header{justify-content:space-between;padding:0 10px;border-bottom:1px solid #ccc;height:35px;margin-top:15px}.red-circle{background:red;opacity:1;color:#fff;padding:2px 10px;height:20px;width:50px;border-radius:2px;vertical-align:middle;display:flex;justify-content:center;align-items:center;margin-left:8px;margin-top:-10px}\n"] }]
1154
+ }], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i2.ConfigurationsService }, { type: i2.EventService }, { type: i0.Renderer2 }, { type: i3.RootService }, { type: i4.WebSocketService }, { type: i5.MatLegacyDialog }, { type: i6.MatSnackBar }, { type: i2.UtilityService }, { type: undefined, decorators: [{
1155
+ type: Inject,
1156
+ args: ["environment"]
1157
+ }] }, { type: i1.Router }]; }, propDecorators: { from: [{
1158
+ type: Input
1159
+ }], content: [{
1160
+ type: Input
1161
+ }], userJourney: [{
1162
+ type: Input
1163
+ }], textArea: [{
1164
+ type: ViewChild,
1165
+ args: ['autoResizeTextarea']
1166
+ }], closeAIPopup: [{
1167
+ type: Output
1168
+ }] } });
1169
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ai-tutor.component.js","sourceRoot":"","sources":["../../../../../../../../library/sunbird-cb/toc/src/lib/_collection/_common/ai-tutor/ai-tutor.component.ts","../../../../../../../../library/sunbird-cb/toc/src/lib/_collection/_common/ai-tutor/ai-tutor.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewChecked, AfterViewInit, Component,ElementRef,EventEmitter,Input, OnDestroy, OnInit, Output, Renderer2, ViewChild , Inject} from '@angular/core';\nimport { ActivatedRoute, Router, NavigationEnd } from '@angular/router';\nimport { ConfigurationsService, EventService, UtilityService, WsEvents } from '@sunbird-cb/utils-v2';\nimport { RootService } from './../../../services/root.service';\nimport { WebSocketService } from './socket.service';\nimport { Subscription } from 'rxjs';\nimport { MatLegacyDialog as MatDialog } from '@angular/material/legacy-dialog'\n// import { MatLegacySnackBar as MatSnackBar } from '@angular/material/legacy-snack-bar'\nimport cloneDeep from 'lodash/cloneDeep';\nimport { MatSnackBar as MatSnackbarNew } from '@angular/material/snack-bar'\nimport { NonReleventFeedbackDialogComponent } from '../../../components/non-relevent-feedback-dialog/non-relevent-feedback-dialog.component';\n\n@Component({\n  selector: 'ws-widget-ai-tutor',\n  templateUrl: './ai-tutor.component.html',\n  styleUrls: ['./ai-tutor.component.scss']\n})\nexport class AiTutorComponent implements OnInit, AfterViewInit, AfterViewChecked, OnDestroy {\n  @Input() from = ''\n  @Input() content:any\n  @Input() userJourney = []\n  showIcon = true\n  categories: any[] = []\n  language: any[] = []\n  currentFilter = 'information'\n  selectedLaguage = 'en'\n\n  responseData: any\n  userInfo: any\n  recomendedQns: any = {}\n  questionsAndAns: any = {}\n  userIcon = ''\n  more = false\n  chatInformation: any = []\n  chatIssues: any = []\n  displayLoader = false\n  expanded = false\n  callText = ''\n  emailText = ''\n  searchQueryAItutor: any = ''\n  initials:any\n  copiedIndex = -1\n  public circleColor!: string\n  random = Math.random().toString(36).slice(2)\n  iGOTAITutorResultArr:any = []\n  maximize = true\n  // tslint:disable\n  localization: any = {\n    'en' : {\n      'Hi' : 'Namaste',\n      'information': 'Information',\n      'issue': 'Issues',\n      'categories': 'Show All Categories',\n      'showmore': 'Show More'\n    },\n    'hi' : {\n      'Hi' : 'नमस्ते',\n      'information': 'जानकारी',\n      'issue': 'समस्या',\n      'categories': 'सभी कैटगोरी दिखायें',\n      'showmore': 'और दिखाओ'\n\n    }\n  }\n\n  private colors = [\n    '#EB7181', // red\n    '#306933', // green\n    '#000000', // black\n    '#3670B2', // blue\n    '#4E9E87',\n    '#7E4C8D',\n  ]\n\n  private randomcolors = [\n    '#EB7181', // red\n    '#006400', // green\n    '#000000', // black\n    '#3670B2', // blue\n    '#4E9E87',\n    '#7E4C8D',\n  ]\n\n  aiTutorResult:any\n\n  private messageSubscription: Subscription | undefined;\n  public messages: string[] = [];\n  public inputMessage: string = '';\n\n  aiTutorResultArr:any = []\n  cloneSearchQuery = ''\n  jwtToken = ''\n  // tslint: disable\n // @ViewChild('scrollMe') private myScrollContainer: ElementRef | undefined\n  isHubEnable!: boolean\n  learningStyle = [\n    { title: 'None', subtitle: 'Learn with Natural query process' },\n    { title: 'Socratic Style', subtitle: 'Explore ideas through thoughtful questions.' },\n    { title: 'Storytelling', subtitle: 'Learn through relatable narratives and real-life examples.' },\n  ]\n  selectedLearningStyle :any\n  resultFetch = false\n  authTokenHost = ''\n  NoneSocketHost = ''\n  SocraticeStyleHost = ''\n  StorytellingHost = ''\n  @ViewChild('autoResizeTextarea') textArea!: ElementRef<HTMLTextAreaElement>;\n  @Output() closeAIPopup = new EventEmitter<any>()\n  containerHeight = 38;\n  isMobile = false\n  showAITutorPopup = false\n  chatId = ''\n  environment: any\n  constructor(\n    private route: ActivatedRoute,\n    private configSvc: ConfigurationsService,\n    private eventSvc: EventService,\n    private renderer: Renderer2,\n    private chatbotService: RootService,\n    private websocketService: WebSocketService,\n    private dialog: MatDialog,\n    private matSnackBarNew: MatSnackbarNew,\n    private utilitySvc: UtilityService,\n     @Inject(\"environment\") environment: any,\n    private router: Router) { \n      this.selectedLearningStyle = this.learningStyle[0]\n      this.environment = environment\n    }\n\n  ngOnInit() {\n    this.isMobile = this.utilitySvc.isMobile\n    if (this.environment?.sitePath?.includes('portal.igotkarmayogi.gov.in')) {\n      this.authTokenHost = 'learning-ai.prod.karmayogibharat.net'\n      this.NoneSocketHost = 'learning-ai.prod.karmayogibharat.net'\n      this.SocraticeStyleHost = 'learning-ai.prod.karmayogibharat.net'\n      this.StorytellingHost = 'learning-ai.prod.karmayogibharat.net'\n    } else {\n      this.authTokenHost = 'learning-ai.uat.karmayogibharat.net'\n      this.NoneSocketHost = 'learning-ai.uat.karmayogibharat.net'\n      this.SocraticeStyleHost = 'learning-ai.uat.karmayogibharat.net'\n      this.StorytellingHost = 'learning-ai.uat.karmayogibharat.net'\n    }\n    this.userInfo = this.configSvc && this.configSvc.userProfile\n    this.websocketService.getJWTToken().subscribe((data:any)=>{\n      if(data && data['x-authenticated-user-token']) {\n        this.jwtToken = data['x-authenticated-user-token']\n        //wss://learning-ai.uat.karmayogibharat.net/socratic/v1/\n        this.websocketService.connect(`wss://${this.authTokenHost}/ws?token=${this.jwtToken}`);\n      }\n      \n    })\n\n    //let jwtToken = 'eyJhbGciOiJSUzI1NiIsInR5cCIgOiAiSldUIiwia2lkIiA6ICJhMTk5WXh3UkxNQWpBb3JVRmJUSkl4YjZDWE1JdUk4WVp4Y0pLaGxMdHQwIn0.eyJqdGkiOiI4ZWQ2MzE1Yi02OGQ1LTRhZDktYWU3MC1hYzRiNjZmNjIzOWIiLCJleHAiOjE3NDQ4NTM3NDMsIm5iZiI6MCwiaWF0IjoxNzQ0ODEwNTQzLCJpc3MiOiJodHRwczovL3BvcnRhbC51YXQua2FybWF5b2dpYmhhcmF0Lm5ldC9hdXRoL3JlYWxtcy9zdW5iaXJkIiwic3ViIjoiZjo5MWVjOTVkMi1hM2Q1LTQxM2UtYjRlNC01M2IwZGNjOTY0ODU6Y2VlYzAyYzYtYzE5MS00OWZlLTg0NTYtNjYyNDVhOWE3ODM1IiwidHlwIjoiQmVhcmVyIiwiYXpwIjoiYWRtaW4tY2xpIiwiYXV0aF90aW1lIjowLCJzZXNzaW9uX3N0YXRlIjoiYjUyNTliYmMtZDVjYy00YWJkLThjY2UtZThlZTZiYjA4NGYyIiwiYWNyIjoiMSIsImFsbG93ZWQtb3JpZ2lucyI6WyJodHRwOi8vbG9jYWxob3N0OjQyMDAiXSwicmVhbG1fYWNjZXNzIjp7InJvbGVzIjpbIm9mZmxpbmVfYWNjZXNzIiwidW1hX2F1dGhvcml6YXRpb24iXX0sInNjb3BlIjoiIiwib3JnIjoiMDEzMzc4MzA5NTgyMzgxMDU2MCIsIm5hbWUiOiJTcHYgQWRtaW4iLCJ1c2VyX3JvbGVzIjpbIk1FTlRPUiIsIlBVQkxJQyIsIlNQVl9BRE1JTiJdLCJwcmVmZXJyZWRfdXNlcm5hbWUiOiJzcHZhZG1pbl9qZzJ5IiwiZ2l2ZW5fbmFtZSI6IlNwdiBBZG1pbiIsImZhbWlseV9uYW1lIjoiIiwiZW1haWwiOiJzcCoqKioqKioqKioqQHlvcG1haWwuY29tIn0.naO_FUNci_ImWHQIylfmMGI2B-85koIyb9Sfy0mOguPpLIKeiGZiLZvccP_I_1QUScBewOrrP3fYxeq8oU98dj7sQGmBFOoU1dSZClZce3U4QEjSiugcbxdiNHcQXlpZTyub5aAJE-ub9Hb1bhS_RQjTMUeDfh5wrlZz6Lqg7kdDh5esXFLibfnUcFqmFFqZBtN5iP2sbRCnCFyS1Vw5TEFKxTiGdRPYT-XUzNE_iZuQPm2z-zyK0FEc1E9odaiwwpW5hkn3TznDwwXe7VdJS2E-HtjujmI-naAqZ__R68SuLyRHuq_PGhj2TZ_rjoaVIhjlgiFqHfOVLUsRat8HpA'\n    \n    this.router.events.subscribe((event: any) => {\n      if (event instanceof NavigationEnd) {\n        //certificate link check\n        this.isHubEnable = (event.url.includes('/certs') || event.url.includes('/public/certs')) ? false : true;\n      }\n    })\n    this.userInfo = this.configSvc && this.configSvc.userProfile\n    // this.aiGlobalSearch()\n    this.checkForApiCalls()\n    this.enableScroll()\n    // tslint:disable-next-line: max-line-length\n    this.userIcon = this.userInfo && this.userInfo.profileImageUrl ? this.userInfo.profileImageUrl : ''\n    if(!this.userInfo.profileImageUrl && this.userInfo && this.userInfo.firstName) {\n      this.createInititals(this.userInfo.firstName)\n    }\n    const email = this.environment.supportEmail || 'mission.karmayogi@gov.in'\n    this.callText = `<a class='hint-text' target='_blank' href='https://bit.ly/44MJlo4'>Teams Call</a>&nbsp;`\n    this.emailText = `<a class='hint-text' target='_blank' href='mailto:${email}'>${email}.</a>`\n\n    const event = {\n      eventType: WsEvents.WsEventType.Telemetry,\n      eventLogLevel: WsEvents.WsEventLogLevel.Info,\n      data: {\n        edata: { type: 'click',  \"id\": \"ai-tutor-card-content\", \"pageid\": `viewer/${this.content}`, \"subType\" :   this.selectedLearningStyle.title  },\n        object: { id: this.content},\n        state: WsEvents.EnumTelemetrySubType.Loaded,\n        eventSubType: WsEvents.EnumTelemetrySubType.Chatbot,\n        mode: 'view',\n      },\n      pageContext: {pageId: `viewer/${this.content}`, module: 'Learn'},\n      from: '',\n      to: 'Telemetry',\n    }\n    this.eventSvc.dispatchChatbotEvent<WsEvents.IWsEventTelemetryInteract>(event)\n    const timestamp = Date.now();\n    this.chatId = `${this.configSvc.unMappedUser.userId}-${timestamp}`\n  }\n\n  ngAfterViewInit(): void {\n    this.resizeTextarea(this.textArea?.nativeElement,'');\n  }\n\n  greetings() {\n    return this.localization[this.selectedLaguage]['Hi'] || 'Hi'\n  }\n\n  getInfoText(label: string) {\n    return this.localization[this.selectedLaguage][label] || label\n  }\n\n  showMore() {\n    return this.localization[this.selectedLaguage]['showmore'] || 'Show More'\n  }\n\n  getData() {\n    const lang: any = {\n      information: 'IN',\n      issue: 'IS'\n    }\n    const tabType: any = {\n      lang: this.selectedLaguage,\n      config_type: lang[this.currentFilter]\n    }\n    this.displayLoader = true\n    this.chatbotService.getChatData(tabType).subscribe((res: any) => {\n      if (res && res.payload && res.payload.config) {\n        this.setDataToLocalStorage(res.payload.config)\n        this.checkForApiCalls()\n        // this.initData(res.payload.config)\n        this.displayLoader = false\n      }\n    })\n  }\n  setDataToLocalStorage(data: any) {\n    let localObject: any = {}\n    localObject = JSON.parse(localStorage.getItem('faq')|| '{}')\n    localObject[this.selectedLaguage] = {...localObject[this.selectedLaguage], [this.currentFilter] : data}\n    localStorage.setItem('faq', JSON.stringify(localObject))\n    this.toggleFilter(this.currentFilter === 'information' ? 'information': this.currentFilter)\n  }\n\n  initData(_getData: any) {\n    // tslint:disable-next-line\n    // console.log(getData)\n    this.userJourney = []\n    let userDetails: any = {\n      type: 'incoming',\n      message: '', //` Hi ${this.userInfo && this.userInfo.firstName || ''}, I'm KarmaSahayogi - Digital Assistant, I'm here to help you.`,\n      recommendedQues: this.getPriorityQuestion(1),\n      selectedValue: '',\n      title: '',//'Here are the most frequently asked questions users have looked for',\n      tab: 'information',\n    }\n\n    this.pushData(userDetails)\n    // this.pushData(userDetailsForIssues)\n    this.getQns()\n  }\n  getQns() {\n    this.responseData.quesMap.map((q: any) => {\n      this.questionsAndAns[q.quesId] = q\n    })\n  }\n\n  selectLaguage(event: any) {\n    this.selectedLaguage = event.target.value\n    localStorage.setItem('selectedLanguage', event.target.value)\n    this.chatInformation=[]\n    this.chatIssues = []\n    this.checkForApiCalls()\n  }\n\n  readFromLocalStorage() {\n    let localStg: any = localStorage.getItem('result')\n    if (localStg) {\n      if (this.currentFilter === 'information') {\n        this.responseData = JSON.parse(localStg)[this.selectedLaguage].information\n      } else {\n        this.responseData = JSON.parse(localStg)[this.selectedLaguage].issue\n      }\n    }\n  }\n\n  goToBottom() {\n    window.scrollTo(0, document.body.scrollHeight)\n  }\n\n  iconClick(type: string) {\n    this.showIcon = !this.showIcon\n    this.currentFilter = 'information'\n    this.expanded = false\n    if (type === 'start') {\n      this.disableScroll()\n      this.raiseChatStartTelemetry()\n      // this.toggleFilter(this.currentFilter)\n    } else {\n      this.raiseChatEndTelemetry()\n      this.userJourney = []\n      this.chatInformation = []\n      this.chatIssues = []\n      this.selectedLaguage = 'en'\n      this.currentFilter = 'information'\n      this.checkForApiCalls()\n      this.more = false\n      this.enableScroll()\n    }\n  }\n\n  toggleFilter(tab: string) {\n    this.currentFilter = tab\n    this.checkForApiCalls()\n    this.more = false\n  }\n\n  selectedQuestion(question: any, data: any) {\n    data.selectedValue = question.quesID\n    const sendMsg = {\n      type: 'sendMsg',\n      question: this.questionsAndAns[question.quesID].quesValue,\n      tab: this.currentFilter,\n    }\n\n    const incomingMsg = {\n      type: 'incoming',\n      // tslint:disable-next-line:max-line-length\n      message: this.questionsAndAns[question.quesID].ansVal.replace('<teams_call_link>', this.callText).replace('<email_configuration>', this.emailText),\n      recommendedQues: question.recommendedQues || [],\n      title: '', // 'Questions related to',\n      relatedQes: 'above Question',\n      tab: this.currentFilter,\n    }\n    this.pushData(sendMsg)\n    this.pushData(incomingMsg)\n    this.raiseTemeletyInterat(question.quesID)\n  }\n\n  pushData(msg: any) {\n    this.userJourney = []\n    if (this.currentFilter === 'information') {\n      this.chatInformation.push(msg)\n      this.userJourney = this.chatInformation\n    } else {\n      this.chatIssues.push(msg)\n      this.userJourney = this.chatIssues\n    }\n  }\n\n  getuserjourney(tab: string) {\n    return this.userJourney.filter((j: any) => j.tab === tab)\n  }\n\n  getPriorityQuestion(priority: any) {\n    const recommendedQues: any[] = []\n    const isLogedIn: string = this.userInfo ? 'Logged-In' : 'Not Logged-In'\n    this.responseData.recommendationMap.map((question: any) => {\n      question.recommendedQues.map((ques: any)=> {\n        if (ques.priority === priority && (question.categoryType === isLogedIn || question.categoryType === 'Both')) {\n          recommendedQues.push(ques)\n        }\n      })\n    })\n    return recommendedQues\n  }\n\n  showMoreQuestion() {\n    const showMoreQes: any = {\n      type: 'incoming',\n      message: '',\n      recommendedQues: this.getPriorityQuestion(1),\n      selectedValue: '',\n      title: '', //'Showing more questions',\n    }\n    this.pushData(showMoreQes)\n  }\n\n  showCategory(catItem: any) {\n    let incomingMsg = {\n      type: 'category',\n      message: '',\n      recommendedQues: [],\n      title: '', //' What do you want to know under',\n      relatedQes: `${catItem.catName}?`,\n      tab: this.currentFilter,\n    }\n    this.more= false\n    if (catItem.catId === 'all') {\n      incomingMsg.title = '', // 'Here is the list of all the topics'\n      incomingMsg.relatedQes = ''\n      incomingMsg.recommendedQues = this.sortCategory()\n    } else {\n      this.responseData.recommendationMap.forEach((element: any) => {\n        if (catItem.catId === element.catId) {\n          incomingMsg.type = 'incoming',\n          incomingMsg.recommendedQues = element.recommendedQues\n        }\n      })\n      this.raiseCategotyTelemetry(catItem.catId)\n    }\n    const sendMsg = {\n      type: 'sendMsg',\n      question: catItem.catName,\n    }\n    this.pushData(sendMsg)\n    this.pushData(incomingMsg)\n  }\n\n  raiseCategotyTelemetry(catItem: string) {\n    const event = {\n      eventType: WsEvents.WsEventType.Telemetry,\n      eventLogLevel: WsEvents.WsEventLogLevel.Info,\n      data: {\n        edata: { type: 'click', id: catItem },\n        object: { id: catItem, type: 'Category' },\n        state: WsEvents.EnumTelemetrySubType.Interact,\n        eventSubType: WsEvents.EnumTelemetrySubType.Chatbot,\n        mode: 'view',\n      },\n      pageContext: {pageId: '/chatbot', module: 'Assistant'},\n      from: '',\n      to: 'Telemetry',\n    }\n    this.eventSvc.dispatchChatbotEvent<WsEvents.IWsEventTelemetryInteract>(event)\n  }\n\n  raiseChatStartTelemetry() {\n    const event = {\n      eventType: WsEvents.WsEventType.Telemetry,\n      eventLogLevel: WsEvents.WsEventLogLevel.Info,\n      data: {\n        edata: { type: '' },\n        object: { type: 'zse', id: 'asd'},\n        state: WsEvents.EnumTelemetrySubType.Loaded,\n        eventSubType: WsEvents.EnumTelemetrySubType.Chatbot,\n        type: 'session',\n        mode: 'view',\n      },\n      pageContext: { pageId: '/chatbot', module: 'Assistant' },\n      from: '',\n      to: 'Telemetry',\n    }\n    this.eventSvc.dispatchChatbotEvent<WsEvents.IWsEventTelemetryInteract>(event)\n  }\n\n  raiseChatEndTelemetry() {\n    const event = {\n      eventType: WsEvents.WsEventType.Telemetry,\n      eventLogLevel: WsEvents.WsEventLogLevel.Info,\n      data: {\n        edata: { type: '' },\n        object: {},\n        state: WsEvents.EnumTelemetrySubType.Unloaded,\n        eventSubType: WsEvents.EnumTelemetrySubType.Chatbot,\n        type: 'session',\n        mode: 'view',\n      },\n      pageContext: { pageId: '/chatbot', module: 'Assistant' },\n      from: '',\n      to: 'Telemetry',\n    }\n    this.eventSvc.dispatchChatbotEvent<WsEvents.IWsEventTelemetryInteract>(event)\n  }\n\n  raiseTemeletyInterat(idn: string) {\n    const event = {\n      eventType: WsEvents.WsEventType.Telemetry,\n      eventLogLevel: WsEvents.WsEventLogLevel.Info,\n      data: {\n        edata: { type: 'click', id: idn },\n        object: {id: idn, type: this.currentFilter.charAt(0).toUpperCase() + this.currentFilter.slice(1)},\n        state: WsEvents.EnumTelemetrySubType.Interact,\n        eventSubType: WsEvents.EnumTelemetrySubType.Chatbot,\n        mode: 'view'\n      },\n      pageContext: { pageId: '/chatbot', module: 'Assistant' },\n      from: '',\n      to: 'Telemetry',\n    }\n    this.eventSvc.dispatchChatbotEvent<WsEvents.IWsEventTelemetryInteract>(event)\n  }\n\n  checkForAIQuestionResponse() {\n\n  }\n\n  checkForApiCalls() {\n    this.selectedLaguage = localStorage.getItem('selectedLanguage') || 'en'\n    let localStg: any = JSON.parse(localStorage.getItem('faq') || '{}')\n    let languageStg: any = JSON.parse(localStorage.getItem('faq-languages') || '{}')\n    if (languageStg.length > 0) {\n      this.language = languageStg\n    } else {\n      this.getLanguages()\n    }\n\n    if (localStg && languageStg) {\n      if (localStg[this.selectedLaguage] && localStg[this.selectedLaguage][this.currentFilter]) {\n        const localStorageData = localStg[this.selectedLaguage][this.currentFilter]\n        this.userJourney = []\n        if (this.currentFilter === 'information') {\n          if (this.chatInformation.length === 0) {\n            this.responseData = localStorageData\n            this.initData(localStorageData)\n          } else {\n            this.responseData = localStorageData\n            this.userJourney = this.chatInformation\n          }\n        } else {\n          if (this.chatIssues.length === 0) {\n            this.responseData = localStorageData\n            this.initData(localStorageData)\n          } else {\n            this.responseData = localStorageData\n            this.userJourney = this.chatIssues\n          }\n        }\n        this.getQns()\n        this.getCategories()\n      } else {\n        this.getLanguages()\n        // this.getData()\n      }\n    }\n  }\n  getCategories() {\n    this.categories = [{ catId: 'all', catName: this.localization[this.selectedLaguage]['categories'], priority: 0 }]\n    const categories: any = []\n    const isLogedIn: string = this.userInfo ? 'Logged-In' : 'Not Logged-In'\n    this.responseData.recommendationMap.map((catandques: any) => {\n      this.responseData.categoryMap.map((cat: any) => {\n        if (catandques.catId === cat.catId && (catandques.categoryType === isLogedIn || catandques.categoryType === 'Both')) {\n          const category = {\n            catId: cat.catId,\n            catName: cat.catName,\n            priority: catandques.priority,\n            categoryType: catandques.categoryType,\n          }\n          categories.push(category)\n        }\n      })\n    })\n    if (categories.length < 6) {\n      this.categories = categories\n    } else {\n      this.categories = [...this.categories, ...categories]\n    }\n  }\n  sortCategory(): any {\n    // tslint:disable-next-line: max-line-length\n    return this.categories.sort((a: any, b: any) => a['priority'] > b['priority'] ? 1 : a['priority'] === b['priority'] ? 0 : -1)\n  }\n\n  getLanguages() {\n    this.displayLoader = true\n    this.chatbotService.getLangugages().subscribe((resp: any) => {\n      if (resp && resp.status && resp.status.code === 200) {\n        this.language = resp.payload.languages\n        localStorage.setItem('faq-languages', JSON.stringify(resp.payload.languages))\n        localStorage.setItem('selectedLanguage', this.selectedLaguage)\n        this.getData()\n        this.displayLoader = false\n      }\n    })\n  }\n\n  ngAfterViewChecked() {\n  //  this.scrollToBottom()\n  }\n  scrollToBottom(): void {\n    let messageContainer = document.getElementById('container-none')\n    if(messageContainer) {\n      messageContainer.scrollTo({top: messageContainer.scrollHeight, behavior: 'smooth'})\n    }\n    \n    \n   \n  }\n  clickOutside() {\n    this.iconClick('end')\n  }\n  private disableScroll() {\n    this.renderer.addClass(document.body, 'disable-scroll')\n  }\n\n  private enableScroll() {\n    this.renderer.removeClass(document.body, 'disable-scroll')\n  }\n\n  submitSearchQuery(textArea: HTMLTextAreaElement, event:any) {\n    if (!this.searchQueryAItutor.trim()) {\n      event.preventDefault(); // Prevents Enter key from adding a new line\n    }\n    if(!this.searchQueryAItutor.trim()) {\n      return false\n    }\n    this.cloneSearchQuery = ''\n    this.cloneSearchQuery = cloneDeep(this.searchQueryAItutor);\n    this.searchQueryAItutor = this.searchQueryAItutor.trim()\n    this.searchQueryAItutor = ''\n    this.resetTextAreaHeight(textArea)\n    this.aiTutorResultArr.map((item:any, index:any)=>{\n      if(item && (item.newMessage === '')) {\n        // delete this.aiTutorResultArr[index]\n        this.aiTutorResultArr.splice(index,1)\n      }\n     })\n     this.resultFetch = false \n    \n  // this.searchQuery = 'Soil Erosion and Conservation'\n   let sendMsgObj = {\n     type: 'sendMsg',\n     tab: 'sarthi',\n     question: this.cloneSearchQuery\n   }\n   \n   this.aiTutorResultArr.push(sendMsgObj)\n   this.aiTutorResultArr.push({type: 'incoming',  tab: 'sarthi', answer: '',newMessage: ''})\n  //  this.searchQuery = ''\n  //  this.aiGlobalSearch()\n  //  this.getAiTutorMessage()\n \n  setTimeout(()=>{\n    this.scrollToBottom()\n  },0)\n  \n   this.sendAITutorMessage()\n   \n  }\n\n\n  sendAITutorMessage() {\n    if (this.cloneSearchQuery) {\n      let message = {\n        message: this.cloneSearchQuery, \n        query: this.cloneSearchQuery,\n        folder_name: this.content //this.content\n      }\n      this.websocketService.sendMessage(message);\n      setTimeout(()=>{\n        this.getAiTutorMessage()\n      }, 1000)\n      \n    }\n  }\n  \n\n  getAiTutorMessage() {\n    this.messageSubscription = this.websocketService\n      .getMessages()\n      .subscribe((message: string) => {\n      \n       // this.messages.push(message);\n       this.aiTutorResult = message\n       this.resultFetch = true\n       \n      this.aiTutorResultMessage()\n      //  this.searchQueryAItutor = '';\n       \n      });\n  }\n\n  aiTutorResultMessage() {\n    this.iGOTAITutorResultArr = []\n  //   let requestBody:any = {\n  //     \"query\":this.cloneSearchQuery\n  //  }\n    // this.chatbotService.aiGlobalSearch(requestBody).subscribe((data)=>{\n    //   console.log('data--', data)\n    // })\n    // console.log('requestBody', requestBody)\n    // console.log('aiSearchResult', this.aiTutorResult)\n    // console.log('this.aiSearchResultArr', this.aiTutorResultArr)\n\n\n      const queryString = Object.entries(this.route.snapshot.queryParams)\n        .map(([key, value]) => `${encodeURI(key)}=${encodeURI(value)}`)\n        .join('&');\n\n    //const queryString = new URLSearchParams(this.route.snapshot.queryParams).toString();\n   // let arr:any = []\n   console.log('this.aiTutorResult--',this.aiTutorResult)\n   if(this.aiTutorResult && !this.aiTutorResult.answer && !this.aiTutorResult.retrievedChunks) {\n    this.aiTutorResult.retrievedChunks = []\n   }\n    this.aiTutorResult.retrievedChunks && this.aiTutorResult.retrievedChunks.map((item:any)=>{\n      let startTime = -1\n      let endTime = -1\n      let pageNumber:any = 1\n      if(item && item?.ContentStart?.trim()) {\n        startTime = item?.ContentStart\n        pageNumber = item?.ContentStart\n      }\n      if(item && item?.ContentEnd?.trim()) {\n        endTime = item?.ContentEnd\n        pageNumber = item?.ContentEnd\n      }\n      pageNumber = pageNumber !== \" \" ? pageNumber : 1\n      let resultObj = {        \n        message: item.Name,\n        recommendedQues: '',\n        selectedValue: '',       \n        title: item.Name,\n        content: item,\n        mimeType: item.MimeType,\n        contentType: item.ContentType,\n        artifactUrl: item.ArtifactURL,\n        description: item?.Description?.replace(/^\\s{4,}/gm, ''),\n        identifier: item.Identifier,   \n        contentStart: startTime,\n        contentEnd: endTime,\n        pageNumber:  pageNumber ? pageNumber : 1,  \n        query: this.aiTutorResult.query,  \n        query_id: this.aiTutorResult.query_id,\n        feedback: '',\n        resourceLink : item.MimeType === 'application/pdf'? `https://portal.igotkarmayogi.gov.in/viewer/pdf/${item.Identifier}?${queryString}&from=globalSearch&playerPreview=true&pn=${pageNumber}`: \n        (startTime <= 0 && endTime <= 0) ? `https://portal.igotkarmayogi.gov.in/viewer/video/${item.Identifier}?${queryString}&from=globalSearch&playerPreview=true`:  `https://portal.igotkarmayogi.gov.in/viewer/video/${item.Identifier}?${queryString}&from=globalSearch&playerPreview=true&st=${startTime}&et=${endTime}`\n      }\n\n      // arr.push(resultObj)\n      this.iGOTAITutorResultArr.push(resultObj)\n      \n    })\n    let answer = this.aiTutorResult.answer ? this.aiTutorResult.answer.trim().replace(/\\n/g, '<br>') : \"\"\n \n    let shortAnswer =  this.splitParagraphByWords(answer)\n   // console.log(this.aiTutorResult.retrievedChunks, { wordsCount: answer.trim().split(/\\s+/).length, showLess: answer.trim().split(/\\s+/).length > 30 ? true : false ,answer: answer, shortAnswer: shortAnswer ,result: this.iGOTAITutorResultArr, type: 'incoming',  tab: 'sarthi',reterivedChunks: this.iGOTAITutorResultArr.retrievedChunks, showFromInternet:  (!this.aiTutorResult.retrievedChunks ? true : false)});\n    this.aiTutorResultArr.push({ query: this.aiTutorResult.query, query_id: this.aiTutorResult.query_id,clientId: this.aiTutorResult.clientId, wordsCount: answer.trim().split(/\\s+/).length, showLess: answer.trim().split(/\\s+/).length > 30 ? true : false ,answer: answer, shortAnswer: shortAnswer ,result: this.iGOTAITutorResultArr, type: 'incoming',  tab: 'sarthi',reterivedChunks: this.iGOTAITutorResultArr.retrievedChunks, showFromInternet: (!(this.aiTutorResult.answer) && !(this.aiTutorResult.retrievedChunks)) ? true : false})\n    this.aiTutorResultArr.map((item:any, index:any)=>{\n      if(item && (item.newMessage === '')) {\n        // delete this.aiSearchResultArr[index]\n        this.aiTutorResultArr.splice(index,1)\n      }\n     })     \n    console.log('this.aiTutorResultArr---', this.aiTutorResultArr)\n     setTimeout(()=>{\n     // this.scrollToBottom()\n    },0)\n\n    const event = {\n      eventType: WsEvents.WsEventType.Telemetry,\n      eventLogLevel: WsEvents.WsEventLogLevel.Info,\n      data: {\n        edata: { type: 'click',  \"id\": \"ai-tutor-card-content\", \"pageid\": `viewer/${this.content}`, \"subType\" :   this.selectedLearningStyle.title  },\n        object: { },\n        state: WsEvents.EnumTelemetrySubType.Interact,\n        eventSubType: WsEvents.EnumTelemetrySubType.Chatbot,\n        mode: 'view',\n      },\n      pageContext: {pageId:  `viewer/${this.content}`, module: 'Learn'},\n      from: '',\n      to: 'Telemetry',\n    }\n    this.eventSvc.dispatchChatbotEvent<WsEvents.IWsEventTelemetryInteract>(event)\n  }\n\n  redirectToResource(item:any) {\n    let queryParams = { ...this.route.snapshot.queryParams };\n    console.log(queryParams)\n    // Remove specific parameters\n    delete queryParams.st;\n    delete queryParams.et;\n    delete queryParams.pn;\n    delete queryParams.from;\n    delete queryParams.playerPreview;\n    let queryString = ''\n    queryString = Object.entries(queryParams)\n        .map(([key, value]) => `${encodeURI(key)}=${encodeURI(value)}`)\n        .join('&');\n    let path = ''\n    path = (item.mimeType === 'application/pdf')? `/viewer/pdf/${item.identifier}?${queryString}&from=globalSearch&playerPreview=true&pn=${item?.pageNumber}`: \n    (item?.contentStart <= 0 && item?.contentEnd <=0) ? `/viewer/video/${item.identifier}?${queryString}&from=globalSearch&playerPreview=true` : `/viewer/video/${item.identifier}?${queryString}&from=globalSearch&playerPreview=true&st=${item?.contentStart}&et=${item?.contentEnd}`\n    // console.log('path', path)\n   // window.open(path, '_blank')\n   if(this.isMobile) {\n    this.maximize = false\n   }\n   \n   this.router.navigateByUrl(path)\n  }\n\n  copyPath(item:any, cindex:any) {\n    const queryString = Object.entries(this.route.snapshot.queryParams)\n        .map(([key, value]) => `${encodeURI(key)}=${encodeURI(value)}`)\n        .join('&');\n\n    //const queryString = new URLSearchParams(this.route.snapshot.queryParams).toString();    \n    const selBox = document.createElement('textarea')\n    selBox.style.position = 'fixed'\n    selBox.style.left = '0'\n    selBox.style.top = '0'\n    selBox.style.opacity = '0'\n     selBox.value = item.mimeType === 'application/pdf'? `https://portal.igotkarmayogi.gov.in/viewer/pdf/${item.identifier}?${queryString}&from=globalSearch&playerPreview=true&pn=${item?.pageNumber}`: \n     (item?.contentStart <=0 && item?.contentEnd <=0 ) ? `https://portal.igotkarmayogi.gov.in/viewer/video/${item.identifier}?${queryString}&from=globalSearch&playerPreview=true` :  `https://portal.igotkarmayogi.gov.in/viewer/video/${item.identifier}?${queryString}&from=globalSearch&playerPreview=true&st=${item?.contentStart}&et=${item?.contentEnd}`\n    document.body.appendChild(selBox)\n    selBox.focus()\n    selBox.select()\n    document.execCommand('copy')\n    document.body.removeChild(selBox)\n    this.copiedIndex = cindex\n    setTimeout(()=>{\n      this.copiedIndex = -1\n    },1000)\n    \n  }\n\n  redirectToToc(chat:any) {\n    const event = {\n      eventType: WsEvents.WsEventType.Telemetry,\n      eventLogLevel: WsEvents.WsEventLogLevel.Info,\n      data: {\n        edata: { type: 'click',  \"id\": \"ai-tutor-card-content\", \"pageid\": `viewer/${this.content}`, \"subType\" :   this.selectedLearningStyle.title  },\n        object: { id: chat?.identifier, type: chat?.contentType},\n        state: WsEvents.EnumTelemetrySubType.Interact,\n        eventSubType: WsEvents.EnumTelemetrySubType.Chatbot,\n        mode: 'view',\n      },\n      pageContext: {pageId: `viewer/${this.content}`, module: 'Learn'},\n      from: '',\n      to: 'Telemetry',\n    }\n    this.eventSvc.dispatchChatbotEvent<WsEvents.IWsEventTelemetryInteract>(event)\n    let path = `https://portal.igotkarmayogi.gov.in/app/toc/${chat?.identifier}/overview`\n    window.open(path, '_blank')\n  }\n\n  splitParagraphByWords(paragraph:any, wordsPerChunk = 30) {\n    const words = paragraph.trim().split(/\\s+/);\n    const chunks = [];\n  \n    for (let i = 0; i < wordsPerChunk; i++) {\n      chunks.push(words[i])\n    }\n    \n    return chunks.join(' ');\n  }\n\n  toggleShow(index:any, showType:any) {\n    if(showType === 'less') {\n      this.aiTutorResultArr[index]['showLess'] = true\n    } else {\n      this.aiTutorResultArr[index]['showLess'] = false\n    }\n    \n  }\n\n  get userInitials() {\n    return this.initials\n  }\n  private createInititals(name:any): void {\n    const randomIndex = Math.floor(Math.random() * Math.floor(this.colors.length))\n    this.circleColor = this.colors[randomIndex]\n    if (this.randomcolors) {\n      const randomIndex1 = Math.floor(Math.random() * Math.floor(this.randomcolors.length))\n      this.circleColor = this.randomcolors[randomIndex1]\n    }\n    let initials = ''\n    const array = `${name} `.toString().split(' ')\n    if (array[0] !== 'undefined' && typeof array[1] !== 'undefined') {\n      initials += array[0].charAt(0)\n      initials += array[1].charAt(0)\n    } else {\n      for (let i = 0; i < name.length; i += 1) {\n        if (name.charAt(i) === ' ') {\n          continue\n        }\n\n        if (name && (name.charAt(i) === name.charAt(i))) {\n          initials += name.charAt(i)\n\n          if (initials.length === 2) {\n            break\n          }\n        }\n      }\n    }\n    this.initials = initials.toUpperCase()\n  }\n\n  getLearningStyle() {\n    const timestamp = Date.now();\n    this.chatId = `${this.configSvc.unMappedUser.userId}-${timestamp}`\n    if(this.selectedLearningStyle && this.selectedLearningStyle.title === 'Socratic Style') {\n      this.aiTutorResultArr = []\n      this.websocketService.closeConnection()\n      this.chatId = `${this.configSvc.unMappedUser.userId}-${timestamp}`\n      \n      this.websocketService.connect(`wss://${this.SocraticeStyleHost}/socratic/v1/ws?token=${this.jwtToken}`);\n    } else if (this.selectedLearningStyle && this.selectedLearningStyle.title === 'None') {\n      this.aiTutorResultArr = []\n      this.websocketService.closeConnection()\n      this.chatId = `${this.configSvc.unMappedUser.userId}-${timestamp}`\n      \n      this.websocketService.connect(`wss://${this.NoneSocketHost}/ws?token=${this.jwtToken}`);\n    }  else if (this.selectedLearningStyle && this.selectedLearningStyle.title === 'Storytelling') {\n      this.aiTutorResultArr = []\n      this.websocketService.closeConnection()\n      this.chatId = `${this.configSvc.unMappedUser.userId}-${timestamp}`\n      \n      this.websocketService.connect(`wss://${this.StorytellingHost}/storytelling/v1/ws?token=${this.jwtToken}`);\n    }\n   // console.log('selectedLearningStyle--', this.selectedLearningStyle)\n  }\n\n  raiseTelemetryForResource(item:any) {\n    const event = {\n      eventType: WsEvents.WsEventType.Telemetry,\n      eventLogLevel: WsEvents.WsEventLogLevel.Info,\n      data: {\n        edata: { type: 'click',  \"id\": \"ai-tutor-card-content\", \"pageid\": `viewer/${this.content}`, \"subType\" :   this.selectedLearningStyle.title    },\n        object: { id: item?.identifier, type: item?.contentType},\n        state: WsEvents.EnumTelemetrySubType.Interact,\n        eventSubType: WsEvents.EnumTelemetrySubType.Chatbot,\n        mode: 'view',\n      },\n      pageContext: {pageId: `viewer/${this.content}`, module: 'Learn'},\n      from: '',\n      to: 'Telemetry',\n    }\n    this.eventSvc.dispatchChatbotEvent<WsEvents.IWsEventTelemetryInteract>(event)\n  }\n\n  sharePositiveContentRating(item:any, index:any, cindex:any) {\n    let requestBody:any = {\n      \"query_id\": item?.query_id,\n      \"response\":  this.aiTutorResultArr[index]['answer'],\n      \"comments\": \"\",\n      \"is_liked\":true,\n      \"rating\": \"5\",\n      \"identifier\":this.content,\n      \"query\": item.query,\n      chat_id: this.chatId,\n      user_id: this.configSvc.unMappedUser.userId,\n\n   }\n   if(this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index]) {\n    if(this.aiTutorResultArr[index].result && this.aiTutorResultArr[index].result[cindex])\n      this.aiTutorResultArr[index].result[cindex]['showLoader'] = true\n      this.aiTutorResultArr[index].result[cindex]['showLoaderForUp'] = true\n   }\n   //this.matSnackBar.open('Unable to fetch content data, due to some error!')\n   this.chatbotService.saveAIChatPositiveContentRating(requestBody, this.chatId, this.userInfo?.userId).subscribe((data:any)=>{\n    if(data && data.status === 'success') {\n      if(this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index]) {\n        if(this.aiTutorResultArr[index].result && this.aiTutorResultArr[index].result[cindex])\n          this.aiTutorResultArr[index].result[cindex]['feedback'] = 'up'\n          this.aiTutorResultArr[index].result[cindex]['showLoader'] = false\n          this.aiTutorResultArr[index].result[cindex]['showLoaderForUp'] = false\n      }\n      this.matSnackBarNew.open(\n        'Thank you for your feedback.', 'X',\n        { duration: 5000, panelClass: ['success'] }\n      );\n    } else {\n      if(this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index]) {\n        if(this.aiTutorResultArr[index].result && this.aiTutorResultArr[index].result[cindex])\n          this.aiTutorResultArr[index].result[cindex]['showLoader'] = false\n          this.aiTutorResultArr[index].result[cindex]['showLoaderForUp'] = false\n      }\n      this.matSnackBarNew.open(\n        'Something is wrong. Please try again later.', 'X',\n        { duration: 5000, panelClass: ['error'] }\n      );\n    }\n\n  })\n  }\n\n  openAIFeedbackPopup(item:any, index:any, cindex:any) {\n    if(this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index] && this.aiTutorResultArr[index]) {\n      if(this.aiTutorResultArr[index].result && this.aiTutorResultArr[index].result[cindex] && this.aiTutorResultArr[index].result[cindex]['feedback'] !== 'down') {\n        const dialogRef = this.dialog.open(NonReleventFeedbackDialogComponent, {\n          disableClose: true,\n          width: '502px',\n          panelClass: ['relevent-feedback-dialog'],\n        })\n        dialogRef.afterClosed().subscribe((result: any) => {\n          if (result) {\n            this.shareAIFeedback(item, result, index, cindex);\n            dialogRef.close();\n          } else {\n            dialogRef.close();\n          }\n        })\n      } else {\n        this.matSnackBarNew.open(\n          'You have already submitted feedback', 'X',\n          { duration: 5000, panelClass: ['error'] }\n        );\n      }\n    }\n\n  }\n\n  shareAIFeedback(item:any, result:any, index:any, cindex:any) {\n\n    let requestBody:any = {\n      \"query_id\": item?.query_id,\n      \"response\": this.aiTutorResultArr[index]['answer'],\n      \"comments\": result,\n      \"is_liked\":false,\n      \"rating\": \"0\",\n      \"identifier\":this.content,\n      \"query\": item.query,\n      chat_id: this.chatId,\n      user_id: this.configSvc.unMappedUser.userId,\n\n   }\n   if(this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index]) {\n    if(this.aiTutorResultArr[index].result && this.aiTutorResultArr[index].result[cindex]) {\n      this.aiTutorResultArr[index].result[cindex]['showLoader'] = true\n      this.aiTutorResultArr[index].result[cindex]['showLoaderForDown'] = true\n    }\n\n  }\n     this.chatbotService.shareAIFeedback(requestBody, this.chatId, this.userInfo?.userId).subscribe((data:any)=>{\n      if(data  && data.status === 'success') {\n        if(this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index]) {\n          if(this.aiTutorResultArr[index].result && this.aiTutorResultArr[index].result[cindex])\n            this.aiTutorResultArr[index].result[cindex]['feedback'] = 'down'\n            this.aiTutorResultArr[index].result[cindex]['showLoader'] = false\n            this.aiTutorResultArr[index].result[cindex]['showLoaderForDown'] = false\n        }\n        this.matSnackBarNew.open(\n          'Thank you for your feedback.', 'X',\n          { duration: 5000, panelClass: ['success'] }\n        );\n      } else {\n        if(this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index]) {\n          if(this.aiTutorResultArr[index].result && this.aiTutorResultArr[index].result[cindex])\n            this.aiTutorResultArr[index].result[cindex]['showLoader'] = false\n          this.aiTutorResultArr[index].result[cindex]['showLoaderForDown'] = false\n        }\n        this.matSnackBarNew.open(\n          'Something is wrong. Please try again later.', 'X',\n          { duration: 5000, panelClass: ['error'] }\n        );\n      }\n     })\n  }\n\n\n  sharePositiveContentRatingForAnswer(item:any, index:any) {\n    let requestBody:any = {\n      \"query_id\": item.query_id,\n      \"response\": item.answer,\n      \"comments\": \"\",\n      \"is_liked\":true,\n      \"rating\": \"5\",\n      \"identifier\":this.content,\n      \"query\": item.query\n\n   }\n   if(this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index]) {\n    if(this.aiTutorResultArr[index] && this.aiTutorResultArr[index])\n      this.aiTutorResultArr[index]['showLoader'] = true\n      this.aiTutorResultArr[index]['showLoaderForUp'] = true\n   }\n   //this.matSnackBar.open('Unable to fetch content data, due to some error!')\n   this.chatbotService.saveAIChatPositiveContentRating(requestBody, this.chatId, this.userInfo?.userId).subscribe((data:any)=>{\n    if(data && data.status === 'success') {\n      if(this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index]) {\n        if(this.aiTutorResultArr[index] && this.aiTutorResultArr[index])\n          this.aiTutorResultArr[index]['feedback'] = 'up'\n          this.aiTutorResultArr[index]['showLoader'] = false\n          this.aiTutorResultArr[index]['showLoaderForUp'] = false\n      }\n      this.matSnackBarNew.open(\n        'Thank you for your feedback.', 'X',\n        { duration: 5000, panelClass: ['success'] }\n      );\n    } else {\n      if(this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index]) {\n        if(this.aiTutorResultArr[index] && this.aiTutorResultArr[index])\n          this.aiTutorResultArr[index]['showLoader'] = false\n          this.aiTutorResultArr[index]['showLoaderForUp'] = false\n      }\n      this.matSnackBarNew.open(\n        'Something is wrong. Please try again later.', 'X',\n        { duration: 5000, panelClass: ['error'] }\n      );\n    }\n\n  })\n  }\n\n  openAIFeedbackPopupForAnswer(item:any, index:any) {\n    if(this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index] && this.aiTutorResultArr[index]) {\n      if(this.aiTutorResultArr[index] && this.aiTutorResultArr[index] && this.aiTutorResultArr[index]['feedback'] !== 'down') {\n        const dialogRef = this.dialog.open(NonReleventFeedbackDialogComponent, {\n          disableClose: true,\n          width: '502px',\n          panelClass: ['relevent-feedback-dialog'],\n        })\n        dialogRef.afterClosed().subscribe((result: any) => {\n          if (result) {\n            this.shareAIForAnswerFeedback(item, result, index);\n            dialogRef.close();\n          } else {\n            dialogRef.close();\n          }\n        })\n      } else {\n        this.matSnackBarNew.open(\n          'You have already submitted feedback', 'X',\n          { duration: 5000, panelClass: ['error'] }\n        );\n      }\n    }\n\n  }\n\n  shareAIForAnswerFeedback(item:any, result:any, index:any) {\n\n    let requestBody:any = {\n      \"query_id\": item.query_id,\n      \"response\": item?.answer,\n      \"comments\": result,\n      \"is_liked\":false,\n      \"rating\": \"0\",\n      \"identifier\":this.content,\n      \"query\": item.query\n\n   }\n   if(this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index]) {\n    if(this.aiTutorResultArr[index] && this.aiTutorResultArr[index]) {\n      this.aiTutorResultArr[index]['showLoader'] = true\n      this.aiTutorResultArr[index]['showLoaderForDown'] = true\n    }\n\n  }\n     this.chatbotService.shareAIFeedback(requestBody, this.chatId, this.userInfo?.userId).subscribe((data:any)=>{\n      if(data  && data.status === 'success') {\n        if(this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index]) {\n          if(this.aiTutorResultArr[index] && this.aiTutorResultArr[index])\n            this.aiTutorResultArr[index]['feedback'] = 'down'\n            this.aiTutorResultArr[index]['showLoader'] = false\n            this.aiTutorResultArr[index]['showLoaderForDown'] = false\n        }\n        this.matSnackBarNew.open(\n          'Thank you for your feedback.', 'X',\n          { duration: 5000, panelClass: ['success'] }\n        );\n      } else {\n        if(this.aiTutorResultArr && this.aiTutorResultArr.length && this.aiTutorResultArr[index]) {\n          if(this.aiTutorResultArr[index] && this.aiTutorResultArr[index])\n            this.aiTutorResultArr[index]['showLoader'] = false\n          this.aiTutorResultArr[index]['showLoaderForDown'] = false\n        }\n        this.matSnackBarNew.open(\n          'Something is wrong. Please try again later.', 'X',\n          { duration: 5000, panelClass: ['error'] }\n        );\n      }\n     })\n  }\n\n  callFromInternet(item:any, index:any) {\n    this.aiTutorResultArr.push({type: 'incoming',  tab: 'sarthi', answer: ''})\n    if( this.aiTutorResultArr[index] && this.aiTutorResultArr[index]['showFromInternet']) {\n      this.aiTutorResultArr[index]['showFromInternet'] = false\n    }\n    if(item && !item.answer) {\n\n      let internetGlobalSearchRequest = {\n        \"query\": this.cloneSearchQuery,\n        \"designation\":  this.userInfo?.professionalDetails && this.userInfo?.professionalDetails.length ? this.userInfo?.professionalDetails[0].designation : '',\n        \"department\": this.userInfo?.departmentName ? this.userInfo?.departmentName : '',\n      }\n      this.chatbotService.aiGlobalSearchFromInternet(internetGlobalSearchRequest, '', this.userInfo?.userId).subscribe((idata:any)=>{\n        this.resultFetch = true\n        this.aiTutorResultArr.map((item:any, index:any)=>{\n          if(item && (item.newMessage === '')) {\n            // delete this.aiSearchResultArr[index]\n            this.aiTutorResultArr.splice(index,1)\n          }\n         })\n        let resultObj = {        \n          message: idata.answer,\n          recommendedQues: '',\n          selectedValue: '',       \n          title: idata.answer,\n          content: idata,\n          mimeType: idata,\n          contentType: idata,\n          artifactUrl: idata,\n          description: idata.answer,\n          identifier: idata,    \n          contentStart: idata,\n          contentEnd: idata, \n          pageNumber:   idata,\n          query: this.cloneSearchQuery,\n          query_id: idata.query_id,\n          resourceLink : '', \n          feedback: '',\n          fromInternet: true\n        }\n\n        this.iGOTAITutorResultArr.push(resultObj)\n        let answer = idata.answer ? idata.answer.trim().replace(/\\n/g, '<br>') : \"\"\n        let shortAnswer =  this.splitParagraphByWords(answer)\n        this.aiTutorResultArr.push({ feedback:'', wordsCount: answer.trim().split(/\\s+/).length, showLess: answer.trim().split(/\\s+/).length > 30 ? true : false ,answer: answer, shortAnswer: shortAnswer ,result: this.iGOTAITutorResultArr, type: 'incoming',  tab: 'sarthi', reterivedChunks: this.aiTutorResult.retrievedChunks, showFromInternet: false})\n        this.aiTutorResultArr.map((item:any, index:any)=>{\n          if(item && (item.newMessage === '')) {\n            // delete this.aiSearchResultArr[index]\n            this.aiTutorResultArr.splice(index,1)\n          }\n         })\n      })\n    }\n  }\n\n  rejectFromInternet(index:any) {\n    if( this.aiTutorResultArr[index] && this.aiTutorResultArr[index]['showFromInternet']) {\n      this.aiTutorResultArr[index]['showFromInternet'] = false\n    }\n    this.resultFetch = true\n    this.aiTutorResultArr.map((item:any, index:any)=>{\n      if(item && (item.newMessage === '')) {\n        // delete this.aiSearchResultArr[index]\n        this.aiTutorResultArr.splice(index,1)\n      }\n     })\n  }\n\n  ngOnDestroy(): void {\n    // Clean up the subscription and WebSocket connection\n    if (this.messageSubscription) {\n      this.messageSubscription.unsubscribe();\n    }\n    const event = {\n      eventType: WsEvents.WsEventType.Telemetry,\n      eventLogLevel: WsEvents.WsEventLogLevel.Info,\n      data: {\n        edata: { type: 'click',  \"id\": \"ai-tutor-card-content\", \"pageid\": `viewer/${this.content}`, \"subType\" :   this.selectedLearningStyle.title  },\n        object: { id: this.content},\n        state: WsEvents.EnumTelemetrySubType.Unloaded,\n        eventSubType: WsEvents.EnumTelemetrySubType.Chatbot,\n        mode: 'view',\n      },\n      pageContext: {pageId: `viewer/${this.content}`, module: 'Learn'},\n      from: '',\n      to: 'Telemetry',\n    }\n    this.eventSvc.dispatchChatbotEvent<WsEvents.IWsEventTelemetryInteract>(event)\n    // this.websocketService.closeConnection();\n  }\n\n  resizeTextarea(textArea: HTMLTextAreaElement,_fromInput:any): void {\n    if (textArea) {\n      textArea.style.height = 'auto'; // Reset height first\n      requestAnimationFrame(() => {\n        textArea.style.height = textArea.scrollHeight + 'px';\n  \n        const computed = getComputedStyle(textArea);\n        const paddingTop = parseFloat(computed.paddingTop) || 0;\n        const paddingBottom = parseFloat(computed.paddingBottom) || 0;\n        const marginExtra = 0;\n        this.containerHeight = textArea.scrollHeight + paddingTop + paddingBottom + marginExtra;\n      });\n    }\n  }\n\n  resetTextAreaHeight(_textArea:HTMLTextAreaElement) {\n    if(this.textArea.nativeElement && this.textArea.nativeElement.style && this.textArea.nativeElement.style.height) {\n      setTimeout(()=>{\n        this.searchQueryAItutor = this.searchQueryAItutor.trim()        \n        this.textArea.nativeElement.style.height = 'auto';\n        this.textArea.nativeElement.style.height = '30px';\n        const computed = getComputedStyle(this.textArea.nativeElement);\n        const paddingTop = parseFloat(computed.paddingTop) || 0;\n        const paddingBottom = parseFloat(computed.paddingBottom) || 0;\n        const marginExtra = 0;\n        this.containerHeight = 30 + paddingTop + paddingBottom + marginExtra;        \n      })     \n    }\n\n\n  }\n\n  closeAITutorPopup() {\n    this.closeAIPopup.emit(true)\n  }\n\n  minimizeAITutor() {\n    this.maximize = false\n  }\n\n  maximizeAITutor() {\n    this.maximize = true\n  }\n}","<!-- <div class=\"tutor-container\">\n<div class=\"learning-type-container\">\n  <mat-form-field appearance=\"none\">\n    <select  matNativeControl required class=\"section-dd\" >\n      <option value=\"\">Select learning type here </option>\n      <option value=\"\">None</option>\n      <option value=\"\">Socratic</option>\n      <option value=\"\">Story Telling</option>\n      <option value=\"\">Summarisation</option>\n    </select>\n  </mat-form-field>\n</div>\n<div [ngClass]=\"from === 'chatbot' ? 'ai-tutor-container-chatbot':'ai-tutor-container'\" #scrollMe>\n  <div class=\"message-container\" #scrollMe>\n    <div class=\"start-chat\" *ngIf=\"aiTutorResultArr?.length === 0\">\n      <h2 class=\"hey\">Hey<span *ngIf=\"userInfo?.firstName\">, {{userInfo?.firstName}}</span> </h2>\n      <p>Welcome to Ai Tutor, Get instant explanations, step-by-step learning guidance, and customised learning tailored just for you.</p>\n    </div>\n    <ng-container *ngFor=\"let chat of aiTutorResultArr; let i =index\">\n      <ng-container *ngIf=\"chat.type === 'incoming'\">\n        <ng-container *ngIf=\"chat?.answer\">\n          <div class=\"flex row-start incoming-msg margin-bottom-s\">\n            <div class=\"system-icon\"><img alt=\"ai-icon\" src=\"/assets/icons/chatbot-ai-new.svg\"></div>\n          \n            <div class=\"system-msg padding-xs\"  *ngIf=\"chat?.wordsCount <= 30\"  [innerHTML]=\"chat.answer\">\n            </div>\n              <div class=\"system-msg padding-xs\">\n                <div   *ngIf=\"chat?.wordsCount > 30\" [innerHTML]=\"chat?.showLess ? chat.shortAnswer :  chat.answer\"></div>\n                <a class=\"link\" href=\"javascript:void(0)\" *ngIf=\"!chat?.showLess\" (click)=\"toggleShow(i, 'less')\">Show Less</a>\n                <a class=\"link\" href=\"javascript:void(0)\" *ngIf=\"chat?.showLess\" (click)=\"toggleShow(i, 'more')\">Show More</a>\n              </div>\n            \n\n          </div>\n          <ng-container *ngFor=\"let item of chat?.result; let ci=index\">\n          <div class=\"system-msg-mimetype flex flex-col\" *ngIf=\"item?.contentType === 'Resource'\">\n            <ng-container *ngIf=\"item?.mimeType === 'application/pdf'\">\n              <div class=\"resource-icon\"><a [href]=\"item?.resourceLink\" target=\"_blank\"><img src=\"/assets/icons/ai-pdf-icon.jpg\"></a></div>\n              <div class=\"resource-link\">\n                <a [href]=\"item?.resourceLink\" target=\"_blank\">Open Resource Link</a>\n              </div>\n            </ng-container>\n            <ng-container *ngIf=\"item?.mimeType === 'video/mp4'\">\n              \n              <div class=\"position-relative\">\n                <div class=\"position-relative\">\n                  <img src=\"/assets/icons/ai-video-icon.jpg\">\n\n                </div>\n                <div class=\"content-duration\" *ngIf=\"item?.contentStart || item?.contentEnd\">\n                  <span *ngIf=\"item?.contentStart\">{{item?.contentStart}}</span>\n                  <span *ngIf=\"item?.contentEnd\">:{{item?.contentEnd}}</span>\n                </div>\n              </div>\n              <div class=\"resource-link\">\n                <a [href]=\"item?.resourceLink\" target=\"_blank\">Open Resource Link</a>\n              </div>\n            </ng-container>\n          </div>\n          <div class=\"recommended-question my-5px\" [ngClass]=\"{'margin-left-5': item?.message }\">\n            <div class=\"my-5px mr-2\">\n              <ng-container *ngIf=\"item?.contentType !== 'Resource'\">\n                <div class=\"btn-default\" (click)=\"redirectToToc(item)\">{{item?.title}}\n                  <mat-icon class=\"vertical-middle\">navigate_next</mat-icon>\n                </div>\n                <div>\n                  {{item?.description | slice : 0:50}}\n                </div>\n              </ng-container>\n            </div>\n            <div class=\"flex flex-row font-12\">\n              <div class=\"cursor-pointer\" (click)=\"copyPath(item, ci)\">\n                <mat-icon matTooltip=\"Copy\" aria-label=\"Copy\">content_copy</mat-icon>\n                <span *ngIf=\"copiedIndex === ci\" class=\"copied-tooltip\">Link Copied!</span>\n              </div>\n              <div class=\"ml-2 mr-2\"><img alt=\"ai-icon\" src=\"/assets/ai-tutor/ai-icon.svg\"></div>\n              <div class=\"ai-generated-content ml-2\">These are AI generated results</div>\n            </div>\n          </div>\n        </ng-container>\n          \n          \n        </ng-container>\n        <ng-container *ngIf=\"!chat?.answer\">\n          <div class=\"flex row-start incoming-msg margin-bottom-s\">\n            <div class=\"system-icon\"><img alt=\"ai-icon\" src=\"/assets/icons/chatbot-ai-new.svg\"></div>\n            <div class=\"loading-bar-icon\"><img alt=\"ai-icon\" src=\"/assets/icons/loading_bar.gif\"></div>\n          </div>\n  \n        </ng-container>\n      </ng-container>\n      \n      <ng-container *ngIf=\"chat.type === 'sendMsg'\">\n        <div class=\"flex width-1-1 row-end padding-top-l padding-bottom-m\">\n          <div class=\"user-seleted-question padding-xs\">\n            {{chat?.question}}\n          </div>\n          <div class=\"user-icon\" *ngIf=\"userIcon\">\n            <img alt=\"ai-icon\" src=\"{{userIcon}}\">\n          </div>\n          <div class=\"circle-s user-icon\" *ngIf=\"!userIcon\" [ngStyle]=\"{'background-color':  circleColor }\">\n            <div  class=\"initials\" i18n-aria-label>\n              {{ userInitials }} \n            </div>\n          </div>\n        </div>\n      </ng-container>\n    </ng-container>\n  </div>  \n</div>\n<div class=\"control-container\">\n  <div class=\"border-gradient-rounded\">\n    <div class=\"flex flex-row mx-5 justify-between\">\n\n      <div class=\"query-box\">\n        <input class=\"width-500\" type=\"text\" placeholder=\"Ask anything...\" [(ngModel)]=\"searchQueryAItutor\" (keydown.enter)=\"submitSearchQuery()\"/>\n        \n      </div>\n\n      <div>\n        <button type=\"button\" class=\"flex-auto-display send-btn\" (click)=\"submitSearchQuery()\" [disabled]=\"!searchQueryAItutor\">\n          <mat-icon class=\"send-btn-icon\">send</mat-icon>\n        </button>\n      </div>\n    </div>\n  </div>\n</div>\n</div> -->\n\n<div class=\"overflow-y-hidden\" [ngClass]=\"(isMobile && !maximize ? 'ai-tutor-popup-minimize' : (isMobile ? 'ai-tutor-popup': ''))\">\n<div *ngIf=\"isMobile\">\n  <div class=\"flex flex-row ai-tutor-mobile-header\">\n      <div class=\"flex flex-row\">\n          <div class=\"flex\">\n              <span class=\"font-bold\">AI Tutor</span>\n            </div>        \n            <div class=\"red-circle ml-5\">\n              New\n            </div>\n      </div>\n      <div class=\"flex flex-row justify-end\">\n        <div *ngIf=\"maximize\" (click)=\"minimizeAITutor()\">\n          <mat-icon>minimize</mat-icon>\n        </div>\n        <div *ngIf=\"!maximize\" (click)=\"maximizeAITutor()\">\n          <mat-icon>maximize</mat-icon>\n        </div>\n        <div (click)=\"closeAITutorPopup()\">\n            <mat-icon>close</mat-icon>\n        </div>\n      </div>\n      \n      \n  </div>\n</div>\n<div [hidden]=\"!maximize\">\n<div class=\"header\">\n  <!-- <mat-form-field appearance=\"none\" style=\"width:100%\">\n    <select  matNativeControl required class=\"section-dd\" >\n      <option value=\"\">You can also choose a learning style that suits you best from here.</option>\n      <option value=\"\">None</option>\n      <option value=\"\">Socratic</option>\n      <option value=\"\">Story Telling</option>\n      <option value=\"\">Summarisation</option>\n    </select>\n  </mat-form-field> -->\n  <mat-form-field class=\"multiline-select\" appearance=\"fill\" style=\"width: 100%; height: 80px;\" floatLabel=\"never\">\n    <mat-select class=\"multiline-select-box\" required [(value)]=\"selectedLearningStyle\" (selectionChange)=\"getLearningStyle()\">\n      <mat-select-trigger class=\"multiline-select-box-trigger\">\n        <div class=\"option-content\">\n          <div class=\"title\">{{ selectedLearningStyle?.title }}</div>\n          <div class=\"subtitle\">{{ selectedLearningStyle?.subtitle }}</div>\n        </div>\n      </mat-select-trigger>\n      <mat-option class=\"multiline-select-option\" value=\"\" *ngFor=\"let item of learningStyle\" [value]=\"item\">\n        <div class=\"option-content\">\n          <div class=\"title\">{{item?.title}}</div>\n          <div class=\"subtitle\">{{item?.subtitle}}</div>\n        </div>\n      </mat-option>\n    </mat-select>\n  </mat-form-field>\n  \n</div>\n\n<div class=\"container-none\" id=\"container-none\">\n  <div [ngClass]=\"from === 'chatbot' ? 'ai-tutor-container-chatbot':'ai-tutor-container'\">\n    <div class=\"message-container\" #scrollMe>\n      <div class=\"start-chat\" *ngIf=\"aiTutorResultArr?.length === 0\">\n        <h2 class=\"hey\">Hey<span *ngIf=\"userInfo?.firstName\">, {{userInfo?.firstName}}</span> </h2>\n        <p>Welcome to AI Tutor, Get instant explanations, step-by-step learning guidance, and customised learning tailored just for you.</p>\n      </div>\n      <ng-container *ngFor=\"let chat of aiTutorResultArr; let i =index\">\n        <ng-container *ngIf=\"chat.type === 'incoming'\">\n          <ng-container *ngIf=\"chat?.answer || chat?.showFromInternet\">\n            <div class=\"flex row-start incoming-msg margin-bottom-s\" *ngIf=\"chat?.answer\">\n              <div class=\"system-icon\"><img alt=\"ai-icon\" src=\"/assets/icons/bot-chat-small.svg\"></div>\n            \n              <!-- <div class=\"system-msg padding-xs\"  *ngIf=\"chat?.wordsCount <= 30\"  [innerHTML]=\"chat.answer\">\n              </div> -->\n              <div class=\"flex row-start incoming-msg margin-bottom-s\" *ngIf=\"chat?.showFromInternet\">\n                <div class=\"system-msg padding-xs mx-10\">\n                  I couldn’t find any relevant results for your query. Would you like me to search outside the iGOT platform for more information?\n                </div>\n    \n              </div>\n              <ng-container *ngIf=\"chat?.answer\">\n              <div class=\"system-msg padding-xs\"  *ngIf=\"chat?.wordsCount <= 30\">\n                <markdown [data]=\"chat?.answer\"></markdown>\n              </div>\n              \n                <div class=\"system-msg padding-xs\" *ngIf=\"chat?.wordsCount > 30\" >\n                  <!-- <div   [innerHTML]=\"chat?.showLess ? chat.shortAnswer :  chat.answer\"></div> -->\n                  <markdown [data]=\"chat?.answer\"></markdown>\n                  <!-- <markdown [data]=\"chat?.showLess ? chat.shortAnswer :  chat.answer\"></markdown> -->\n                  <!-- <a class=\"link\" href=\"javascript:void(0)\" *ngIf=\"!chat?.showLess\" (click)=\"toggleShow(i, 'less')\">Show Less</a>\n                  <a class=\"link\" href=\"javascript:void(0)\" *ngIf=\"chat?.showLess\" (click)=\"toggleShow(i, 'more')\">Show More</a> -->\n                </div>\n              </ng-container>\n              \n  \n            </div>\n            \n            <div *ngIf=\"chat?.showFromInternet\">\n              <div class=\"flex row my-2 justify-start mx-10 my-5\">\n                <div (click)=\"callFromInternet(chat, i)\">\n                  <button type=\"button\" class=\"web-button px-4 cursor-pointer\">\n                    <mat-icon class=\"web-search-icon\">search  </mat-icon><span class=\"blue-color\">Search the web</span>\n                  </button>\n                </div>\n                <div (click)=\"rejectFromInternet(i)\" class=\"mx-2\">\n                  <button type=\"button\" class=\"web-button py-2 px-4 cursor-pointer\">\n                    <mat-icon class=\"web-close-icon\">close</mat-icon><span class=\"blue-color\">No</span>\n                  </button>\n                </div>\n            </div>\n            </div>\n            <ng-container *ngFor=\"let item of chat?.result; let ci=index\">\n            <div class=\"system-msg-mimetype flex flex-col\" *ngIf=\"item?.contentType === 'Resource'\">\n              <ng-container *ngIf=\"item?.mimeType === 'application/pdf'\">\n                <!-- <div class=\"resource-icon\"><a [href]=\"item?.resourceLink\" target=\"_blank\" (click)=\"raiseTelemetryForResource(item)\">\n                  <img src=\"/assets/icons/ai-pdf-icon.jpg\"></a>\n                </div> -->\n                <div class=\"recommended-question-for-resource mx-10\" (click)=\"redirectToResource(item);raiseTelemetryForResource(item)\">\n                  <!-- <div class=\"resource-icon\">\n                    <a [href]=\"item?.resourceLink\" target=\"_blank\" (click)=\"raiseTelemetryForResource(item)\">\n                    <img src=\"/assets/ai-tutor/pdf.svg\">\n                    </a>\n                    <p>{{item?.message}}</p>\n                  </div> -->\n                  <div class=\"btn-default mb-2\">\n                    <a [href]=\"item?.resourceLink\" target=\"_blank\">\n                      <img class=\"vertical-middle h-w-34\" src=\"/assets/ai-tutor/pdf.svg\">\n                    </a>\n                    {{item?.title}}\n                    <mat-icon class=\"vertical-middle\" *ngIf=\"!(item?.fromInternet)\">navigate_next</mat-icon>\n                  </div>\n                </div>\n                <!-- <div class=\"resource-link\">\n                  <a [href]=\"item?.resourceLink\" target=\"_blank\">Click to view</a>\n                </div> -->\n              </ng-container>\n              <!-- <ng-container *ngIf=\"item?.mimeType === 'video/mp4'\">\n                \n                <div class=\"resource-icon\">\n                <a [href]=\"item?.resourceLink\" target=\"_blank\" (click)=\"raiseTelemetryForResource(item)\">\n                  <div class=\"position-relative\">\n                    <div class=\"position-relative\">\n                      <img src=\"/assets/icons/ai-video-icon.jpg\">\n  \n                    </div>\n                    <div class=\"content-duration flex\" *ngIf=\"item?.contentStart > -1 && item?.contentEnd > -1 && !(item?.fromInternet)\">\n                      <span><mat-icon>access_time</mat-icon>&nbsp;&nbsp;</span>\n                      <span *ngIf=\"item?.contentStart > -1\">\n                        <span *ngIf=\"item?.contentStart > 0\">{{item?.contentStart | pipeDurationTransform: 'hms'}}</span>\n                        <span *ngIf=\"item.contentStart === '0'\">0</span>\n                      </span>\n                      <span *ngIf=\"item?.contentEnd > -1\">&nbsp;-&nbsp;{{item?.contentEnd | pipeDurationTransform: 'hms'}}</span>\n                    </div>\n                  </div>\n                  \n                  \n                </a>\n              </div>\n            </ng-container> -->\n            <ng-container *ngIf=\"item?.mimeType === 'video/mp4'\">\n              <div class=\"recommended-question-for-resource mx-10\" (click)=\"redirectToResource(item);raiseTelemetryForResource(item)\">\n                \n                <div class=\"btn-default mb-2\">\n                  <div class=\"flex flex-row\">\n                  <div>\n                  <a [href]=\"item?.resourceLink\" target=\"_blank\">\n                    <img class=\"vertical-middle h-w-34\" src=\"/assets/ai-tutor/video.svg\">\n                  </a>\n                </div>\n                <div class=\"ml-1\">\n                  <span>{{item?.title}} </span>\n                </div>\n                <div>\n                  <span class=\"content-duration flex ml-1\" *ngIf=\"item?.contentStart > -1 && item?.contentEnd > -1 && !(item?.fromInternet)\">\n                    <span><mat-icon>access_time</mat-icon>&nbsp;&nbsp;</span>\n                    <span *ngIf=\"item?.contentStart > -1\">\n                      <span *ngIf=\"item?.contentStart > 0\">{{item?.contentStart | pipeDurationTransform: 'hms'}}</span>\n                      <span *ngIf=\"item.contentStart === '0'\">0</span>\n                    </span>\n                    <span *ngIf=\"item?.contentEnd > -1\">&nbsp;-&nbsp;{{item?.contentEnd | pipeDurationTransform: 'hms'}}</span>\n                  </span>                  \n                </div>\n                <div>\n                  <mat-icon class=\"vertical-middle\" *ngIf=\"!(item?.fromInternet)\">navigate_next</mat-icon>\n                </div>\n              </div>\n                </div>\n                <!-- <a [href]=\"item?.resourceLink\" target=\"_blank\" (click)=\"raiseTelemetryForResource(item)\">\n                  <div class=\"position-relative\">\n                    <div class=\"position-relative\">\n                      <img class=\"h-w-34\" src=\"/assets/ai-tutor/video.svg\">\n                      <p>{{item?.message}}</p>\n                    </div>\n                    <div class=\"content-duration flex\" *ngIf=\"item?.contentStart > -1 && item?.contentEnd > -1 && !(item?.fromInternet)\">\n                      <span><mat-icon>access_time</mat-icon>&nbsp;&nbsp;</span>\n                      <span *ngIf=\"item?.contentStart > -1\">\n                        <span *ngIf=\"item?.contentStart > 0\">{{item?.contentStart | pipeDurationTransform: 'hms'}}</span>\n                        <span *ngIf=\"item.contentStart === '0'\">0</span>\n                      </span>\n                      <span *ngIf=\"item?.contentEnd > -1\">&nbsp;-&nbsp;{{item?.contentEnd | pipeDurationTransform: 'hms'}}</span>\n                    </div>\n                  </div>\n                  \n                  \n                </a> -->\n              </div>\n            </ng-container>\n                <div class=\"flex flex-row cursor-pointer\">\n                  <!-- <div class=\"resource-link\"  *ngIf=\"!(item?.fromInternet)\">\n                    <a [href]=\"item?.resourceLink\" target=\"_blank\">Click to view</a>\n                  </div> -->\n                  <div class=\"cursor-pointer ml-10 mr-2 my-1\" (click)=\"copyPath(item, ci)\" *ngIf=\"item?.contentType === 'Resource' && !(item?.fromInternet)\">\n                    <mat-icon matTooltip=\"Copy\" aria-label=\"Copy\">content_copy</mat-icon>\n                    <span *ngIf=\"copiedIndex === ci\" class=\"copied-tooltip\">Link Copied!</span>\n                  </div>\n                  <!-- <div class=\"feefback-section flex flex-row my-1\" *ngIf=\"(item?.feedback)\">\n                    <div *ngIf=\"item?.feedback !== 'down'\"\n                     class=\"cursor-pointer feedback-icon mt-1\" [ngClass]=\"item?.feedback !== 'up' ? 'rotate-180' : ''\">\n                     <img *ngIf=\"item?.feedback !== 'up'\" src=\"/assets/ai-tutor/down.svg\">\n                     <img *ngIf=\"item?.feedback == 'up'\" src=\"/assets/ai-tutor/up.svg\">\n                    </div>\n                    <div *ngIf=\"item?.feedback !== 'up'\"  class=\"ml-2 cursor-pointer feedback-icon\">\n                      <img src=\"/assets/ai-tutor/fill-down.svg\">\n                    </div>\n                  </div>\n                  <div class=\"feefback-section flex flex-row my-1\" *ngIf=\"item?.feedback === ''\">\n                    <div *ngIf=\"item?.feedback !== 'down'\" (click)=\"sharePositiveContentRating(item,i, ci)\"\n                     class=\"cursor-pointer feedback-icon\" [ngClass]=\"item?.feedback !== 'up' ? 'rotate-180' : ''\">\n                     <img *ngIf=\"item?.feedback !== 'up'\" src=\"/assets/ai-tutor/down.svg\">\n                     <img *ngIf=\"item?.feedback == 'up'\" src=\"/assets/ai-tutor/up.svg\">\n                    </div>\n                    <div *ngIf=\"item?.feedback !== 'up'\" (click)=\"openAIFeedbackPopup(item,i, ci)\" class=\"ml-2 cursor-pointer feedback-icon mt-1\">\n                      <img src=\"/assets/ai-tutor/down.svg\">\n                    </div>\n                  </div> -->\n                  <div class=\"feefback-section flex flex-row my-1\">\n                    <div  (click)=\"sharePositiveContentRating(item,i, ci)\" class=\"cursor-pointer feedback-icon mt-1\" \n                  >\n                    <img [ngClass]=\"'rotate-180'\" *ngIf=\"item?.feedback !== 'up' && !item?.showLoaderForUp\" src=\"/assets/ai-tutor/down.svg\">\n                    <img *ngIf=\"item?.feedback === 'up'  && !item?.showLoaderForUp\" src=\"/assets/ai-tutor/up.svg\">\n                    <img *ngIf=\"item?.showLoaderForUp\" class=\"blue-loader-animation\" height=\"18\" width=\"18\" src=\"/assets/ai-tutor/blue-loader.png\">\n                  </div>\n                  <div (click)=\"openAIFeedbackPopup(item,i, ci)\" class=\"ml-2 cursor-pointer feedback-icon mt-1\">\n                    <img *ngIf=\"item?.feedback !== 'down' && !item?.showLoaderForDown\" src=\"/assets/ai-tutor/down.svg\"> \n                    <img *ngIf=\"item?.feedback === 'down'  && !item?.showLoaderForDown\" src=\"/assets/ai-tutor/fill-down.svg\"> \n                    <img *ngIf=\"item?.showLoaderForDown\" class=\"blue-loader-animation\" height=\"18\" width=\"18\" src=\"/assets/ai-tutor/blue-loader.png\">\n                  </div>\n                  </div>\n                  <!-- <div class=\"flex flex-row font-12 mt-1\">\n                    <div class=\"ml-2 mr-2 cu\"><img alt=\"ai-icon\" src=\"/assets/ai-tutor/ai-icon.svg\"></div>\n                    <div class=\"ai-generated-content ml-2\">These are <span *ngIf=\"item?.fromInternet\">Web</span><span *ngIf=\"!(item?.fromInternet)\">AI</span> generated results</div>\n                  </div> -->\n                  <!-- <div class=\"feefback-section flex flex-row\">\n                    \n                    <div *ngIf=\"item?.feedback !== 'down'\" (click)=\"sharePositiveContentRating(item,i, ci)\"\n                 class=\"cursor-pointer feedback-icon\" [ngClass]=\"item?.feedback !== 'up' ? 'rotate-180' : ''\">\n                 <img *ngIf=\"item?.feedback !== 'up'\" src=\"/assets/ai-tutor/down.svg\">\n                 <img *ngIf=\"item?.feedback == 'up'\" src=\"/assets/ai-tutor/up.svg\">\n                </div>\n                <div *ngIf=\"item?.feedback !== 'up'\" (click)=\"openAIFeedbackPopup(item,i, ci)\" class=\"ml-2 cursor-pointer feedback-icon\"><img src=\"/assets/ai-tutor/down.svg\"></div>\n                  </div> -->\n                </div>\n              \n            </div>\n            <div class=\"recommended-question\" [ngClass]=\"{'ml-10': item?.message }\">\n              <div class=\"my-5px mr-2 w-92\">\n                <ng-container *ngIf=\"item?.contentType !== 'Resource' && !(item?.fromInternet)\">\n                  <div class=\"btn-default\" (click)=\"redirectToToc(item)\">{{item?.title}}\n                    <mat-icon class=\"vertical-middle\" *ngIf=\"!(item?.fromInternet)\">navigate_next</mat-icon>\n                  </div>\n                  <div class=\"recommended-question-desc\" *ngIf=\"!(item?.fromInternet)\">\n                    <!-- {{item?.description}} -->\n                     <markdown [data]=\"item?.description\"></markdown>\n                  </div>\n                </ng-container>\n              </div>\n              <div class=\"flex flex-row font-12 mb-2\">\n                <div class=\"cursor-pointer\" (click)=\"copyPath(item, ci)\" *ngIf=\"item?.contentType !== 'Resource' && !(item?.fromInternet)\">\n                  <mat-icon matTooltip=\"Copy\" aria-label=\"Copy\">content_copy</mat-icon>\n                  <span *ngIf=\"copiedIndex === ci\" class=\"copied-tooltip\">Link Copied!</span>\n                </div>\n                <!-- <div class=\"feefback-section flex flex-row\" *ngIf=\"item?.contentType !== 'Resource'\">\n                  \n                  <div *ngIf=\"item?.feedback !== 'down'\" (click)=\"sharePositiveContentRating(item, i,ci)\" \n                class=\"cursor-pointer feedback-icon\" [ngClass]=\"item?.feedback !== 'up' ? 'rotate-180' : ''\">\n                  <img *ngIf=\"item?.feedback !== 'up'\" src=\"/assets/ai-tutor/down.svg\">\n                  <img *ngIf=\"item?.feedback == 'up'\" src=\"/assets/ai-tutor/up.svg\">\n                </div>\n                <div *ngIf=\"item?.feedback !== 'up'\"  (click)=\"openAIFeedbackPopup(item, i,ci)\" class=\"ml-2 cursor-pointer feedback-icon\"><img src=\"/assets/ai-tutor/down.svg\"></div>\n                </div>   -->\n                <div class=\"feefback-section flex flex-row\" *ngIf=\"item?.contentType !== 'Resource'\">\n                  <div  (click)=\"sharePositiveContentRating(item,i, ci)\" class=\"cursor-pointer feedback-icon mt-1\" \n                  >\n                    <img [ngClass]=\"'rotate-180'\" *ngIf=\"item?.feedback !== 'up' && !item?.showLoaderForUp\" src=\"/assets/ai-tutor/down.svg\">\n                    <img *ngIf=\"item?.feedback === 'up'  && !item?.showLoaderForUp\" src=\"/assets/ai-tutor/up.svg\">\n                    <img *ngIf=\"item?.showLoaderForUp\" class=\"blue-loader-animation\" height=\"18\" width=\"18\" src=\"/assets/ai-tutor/blue-loader.png\">\n                  </div>\n                  <div (click)=\"openAIFeedbackPopup(item,i, ci)\" class=\"ml-2 cursor-pointer feedback-icon mt-1\">\n                    <img *ngIf=\"item?.feedback !== 'down' && !item?.showLoaderForDown\" src=\"/assets/ai-tutor/down.svg\"> \n                    <img *ngIf=\"item?.feedback === 'down'  && !item?.showLoaderForDown\" src=\"/assets/ai-tutor/fill-down.svg\"> \n                    <img *ngIf=\"item?.showLoaderForDown\" class=\"blue-loader-animation\" height=\"18\" width=\"18\" src=\"/assets/ai-tutor/blue-loader.png\">\n                  </div>\n                </div> \n              </div>\n              <!-- <div class=\"flex flex-row font-12 mt-1\" *ngIf=\"item?.contentType !== 'Resource'\">\n                <div class=\"ml-2 mr-2 cu\"><img alt=\"ai-icon\" src=\"/assets/ai-tutor/ai-icon.svg\"></div>\n                <div class=\"ai-generated-content ml-2\">These are <span *ngIf=\"item?.fromInternet\">Web</span><span *ngIf=\"!(item?.fromInternet)\">AI</span> generated results</div>\n              </div> -->\n            </div>\n          </ng-container>\n          <div class=\" flex flex-row ml-10\" *ngIf=\"chat?.answer && !(chat?.result?.length)\">\n            <div  (click)=\"sharePositiveContentRatingForAnswer(chat,i)\" class=\"cursor-pointer feedback-icon mt-1\" \n            >\n              <img [ngClass]=\"'rotate-180'\" *ngIf=\"chat?.feedback !== 'up' && !chat?.showLoaderForUp\" src=\"/assets/ai-tutor/down.svg\">\n              <img *ngIf=\"chat?.feedback === 'up'  && !chat?.showLoaderForUp\" src=\"/assets/ai-tutor/up.svg\">\n              <img *ngIf=\"chat?.showLoaderForUp\" class=\"blue-loader-animation\" height=\"18\" width=\"18\" src=\"/assets/ai-tutor/blue-loader.png\">\n            </div>\n            <div (click)=\"openAIFeedbackPopupForAnswer(chat,i)\" class=\"ml-2 cursor-pointer feedback-icon mt-1\">\n              <img *ngIf=\"chat?.feedback !== 'down' && !chat?.showLoaderForDown\" src=\"/assets/ai-tutor/down.svg\"> \n              <img *ngIf=\"chat?.feedback === 'down'  && !chat?.showLoaderForDown\" src=\"/assets/ai-tutor/fill-down.svg\"> \n              <img *ngIf=\"chat?.showLoaderForDown\" class=\"blue-loader-animation\" height=\"18\" width=\"18\" src=\"/assets/ai-tutor/blue-loader.png\">\n            </div>\n          </div> \n          <div class=\"flex flex-row font-12 mt-1 mb-1 ai-generated-content-container\" *ngIf=\"chat?.result?.length\">\n            <div class=\"ml-5 mr-2 cu\"><img alt=\"ai-icon\" src=\"/assets/ai-tutor/ai-icon.svg\"></div>\n            <div class=\"ai-generated-content ml-2\">These are <span *ngIf=\"item?.fromInternet\">Web</span><span *ngIf=\"!(item?.fromInternet)\">AI</span> generated results</div>\n          </div>\n            \n          </ng-container>\n          <ng-container>\n            <div class=\"flex row-start incoming-msg margin-bottom-s\" *ngIf=\"chat?.newMessage === '' && !resultFetch\">\n              <div class=\"system-icon\"><img alt=\"ai-icon\" src=\"/assets/icons/bot-chat-small.svg\"></div>\n              <div class=\"loading-bar-icon flex flex-row vertical-middle\">\n                <div class=\"mt-2\"><span class=\"blue-color\">Retrieving Results</span></div>\n                <div><img alt=\"ai-icon\" src=\"/assets/icons/loading_bar.gif\"></div>\n              </div>\n            </div>\n    \n          </ng-container>\n        </ng-container>\n        \n        <ng-container *ngIf=\"chat.type === 'sendMsg'\">\n          <div class=\"flex width-1-1 row-end padding-top-l padding-bottom-m\">\n            <div class=\"user-seleted-question padding-xs\">\n              {{chat?.question}}\n            </div>\n            <div class=\"user-icon\" *ngIf=\"userIcon\">\n              <img alt=\"ai-icon\" src=\"{{userIcon}}\">\n            </div>\n            <div class=\"circle-s user-icon\" *ngIf=\"!userIcon\" [ngStyle]=\"{'background-color':  circleColor }\">\n              <div  class=\"initials\" i18n-aria-label>\n                {{ userInitials }} \n              </div>\n            </div>\n          </div>\n        </ng-container>\n      </ng-container>\n    </div>  \n  </div>\n</div>\n\n<div class=\"footer\" [ngClass]=\"isMobile ? 'ai-popup-mobile-footer':''\">\n  <div class=\"border-gradient-rounded\" [style.height.px]=\"containerHeight\">\n    <div class=\"flex flex-row ml-5 mr-2 justify-between\">\n\n      <div class=\"query-box\">\n        <!-- <input class=\"width-500\" type=\"text\" placeholder=\"Ask anything...\" [(ngModel)]=\"searchQueryAItutor\" (keydown.enter)=\"submitSearchQuery()\"/>  -->\n        <textarea #autoResizeTextarea class=\"width-500\"\n        placeholder=\"Ask Me Anything...\"\n        (input)=\"resizeTextarea(autoResizeTextarea, 'fromInput')\"\n        [(ngModel)]=\"searchQueryAItutor\" (keydown.enter)=\"submitSearchQuery(autoResizeTextarea, $event)\"\n        rows=\"1\"\n        >\n        </textarea>\n        \n      </div>\n\n      <div class=\"margin-top-2px\">\n        <button type=\"button\" class=\"flex-auto-display send-btn\" (click)=\"submitSearchQuery(autoResizeTextarea, $event)\" [disabled]=\"!searchQueryAItutor\">\n          <mat-icon class=\"send-btn-icon\">send</mat-icon>\n        </button>\n      </div>\n    </div>\n  </div>\n</div>\n</div>\n</div>"]}