@sunbird-cb/cbp-ai 0.0.1
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.
- package/README.md +24 -0
- package/esm2022/lib/ai-cbp-routing.module.mjs +56 -0
- package/esm2022/lib/ai-cbp.component.mjs +14 -0
- package/esm2022/lib/ai-cbp.module.mjs +263 -0
- package/esm2022/lib/ai-cbp.service.mjs +14 -0
- package/esm2022/lib/components/add-course/add-course.component.mjs +444 -0
- package/esm2022/lib/components/add-designation/add-designation.component.mjs +460 -0
- package/esm2022/lib/components/add-personalisation/add-personalisation.component.mjs +33 -0
- package/esm2022/lib/components/approval-request-form/approval-request-form.component.mjs +392 -0
- package/esm2022/lib/components/approval-requests/approval-requests.component.mjs +398 -0
- package/esm2022/lib/components/dashboard/dashboard.component.mjs +265 -0
- package/esm2022/lib/components/delete-role-mapping/delete-role-mapping.component.mjs +53 -0
- package/esm2022/lib/components/delete-role-mapping-popup/delete-role-mapping-popup.component.mjs +39 -0
- package/esm2022/lib/components/edit-cbp-plan/edit-cbp-plan.component.mjs +699 -0
- package/esm2022/lib/components/gap-analysis-recommended-course/gap-analysis-recommended-course.component.mjs +188 -0
- package/esm2022/lib/components/generate-course-recommendation/generate-course-recommendation.component.mjs +1949 -0
- package/esm2022/lib/components/list-popup/list-popup.component.mjs +32 -0
- package/esm2022/lib/components/review-request/review-request.component.mjs +138 -0
- package/esm2022/lib/components/role-mapping-generation/role-mapping-generation.component.mjs +1082 -0
- package/esm2022/lib/components/role-mapping-list/role-mapping-list.component.mjs +714 -0
- package/esm2022/lib/components/suggest-more-courses/suggest-more-courses.component.mjs +370 -0
- package/esm2022/lib/components/update-designation-hierarchy/update-designation-hierarchy.component.mjs +235 -0
- package/esm2022/lib/components/view-cbp-plan/view-cbp-plan.component.mjs +125 -0
- package/esm2022/lib/components/view-course-recommendation/view-course-recommendation.component.mjs +397 -0
- package/esm2022/lib/components/view-final-cbp-plan/view-final-cbp-plan.component.mjs +883 -0
- package/esm2022/lib/modules/initial-screen/initial-screen.component.mjs +127 -0
- package/esm2022/lib/modules/shared/constant/app.constant.mjs +2036 -0
- package/esm2022/lib/modules/shared/directives/clickoutside.directive.mjs +38 -0
- package/esm2022/lib/modules/shared/directives/directive.module.mjs +21 -0
- package/esm2022/lib/modules/shared/pipes/order-by-name.pipe.mjs +23 -0
- package/esm2022/lib/modules/shared/services/event.service.mjs +24 -0
- package/esm2022/lib/modules/shared/services/events.mjs +125 -0
- package/esm2022/lib/modules/shared/services/init.service.mjs +41 -0
- package/esm2022/lib/modules/shared/services/role-mapping.service.mjs +261 -0
- package/esm2022/lib/modules/shared/services/shared.service.mjs +869 -0
- package/esm2022/lib/modules/upload-document-page/progress-dialog/progress-dialog.component.mjs +53 -0
- package/esm2022/lib/modules/upload-document-page/upload-dialog/upload-dialog.component.mjs +186 -0
- package/esm2022/lib/modules/upload-document-page/upload-document-page.component.mjs +367 -0
- package/esm2022/lib/pipe-public-URL/pipe-public-URL.module.mjs +20 -0
- package/esm2022/lib/pipe-public-URL/pipe-public-URL.pipe.mjs +23 -0
- package/esm2022/public-api.mjs +14 -0
- package/esm2022/sunbird-cb-cbp-ai.mjs +5 -0
- package/fesm2022/sunbird-cb-cbp-ai.mjs +12952 -0
- package/fesm2022/sunbird-cb-cbp-ai.mjs.map +1 -0
- package/index.d.ts +6 -0
- package/lib/ai-cbp-routing.module.d.ts +8 -0
- package/lib/ai-cbp-routing.module.d.ts.map +1 -0
- package/lib/ai-cbp.component.d.ts +7 -0
- package/lib/ai-cbp.component.d.ts.map +1 -0
- package/lib/ai-cbp.module.d.ts +68 -0
- package/lib/ai-cbp.module.d.ts.map +1 -0
- package/lib/ai-cbp.service.d.ts +7 -0
- package/lib/ai-cbp.service.d.ts.map +1 -0
- package/lib/components/add-course/add-course.component.d.ts +67 -0
- package/lib/components/add-course/add-course.component.d.ts.map +1 -0
- package/lib/components/add-designation/add-designation.component.d.ts +52 -0
- package/lib/components/add-designation/add-designation.component.d.ts.map +1 -0
- package/lib/components/add-personalisation/add-personalisation.component.d.ts +16 -0
- package/lib/components/add-personalisation/add-personalisation.component.d.ts.map +1 -0
- package/lib/components/approval-request-form/approval-request-form.component.d.ts +48 -0
- package/lib/components/approval-request-form/approval-request-form.component.d.ts.map +1 -0
- package/lib/components/approval-requests/approval-requests.component.d.ts +80 -0
- package/lib/components/approval-requests/approval-requests.component.d.ts.map +1 -0
- package/lib/components/dashboard/dashboard.component.d.ts +55 -0
- package/lib/components/dashboard/dashboard.component.d.ts.map +1 -0
- package/lib/components/delete-role-mapping/delete-role-mapping.component.d.ts +18 -0
- package/lib/components/delete-role-mapping/delete-role-mapping.component.d.ts.map +1 -0
- package/lib/components/delete-role-mapping-popup/delete-role-mapping-popup.component.d.ts +18 -0
- package/lib/components/delete-role-mapping-popup/delete-role-mapping-popup.component.d.ts.map +1 -0
- package/lib/components/edit-cbp-plan/edit-cbp-plan.component.d.ts +94 -0
- package/lib/components/edit-cbp-plan/edit-cbp-plan.component.d.ts.map +1 -0
- package/lib/components/gap-analysis-recommended-course/gap-analysis-recommended-course.component.d.ts +35 -0
- package/lib/components/gap-analysis-recommended-course/gap-analysis-recommended-course.component.d.ts.map +1 -0
- package/lib/components/generate-course-recommendation/generate-course-recommendation.component.d.ts +198 -0
- package/lib/components/generate-course-recommendation/generate-course-recommendation.component.d.ts.map +1 -0
- package/lib/components/list-popup/list-popup.component.d.ts +13 -0
- package/lib/components/list-popup/list-popup.component.d.ts.map +1 -0
- package/lib/components/review-request/review-request.component.d.ts +39 -0
- package/lib/components/review-request/review-request.component.d.ts.map +1 -0
- package/lib/components/role-mapping-generation/role-mapping-generation.component.d.ts +99 -0
- package/lib/components/role-mapping-generation/role-mapping-generation.component.d.ts.map +1 -0
- package/lib/components/role-mapping-list/role-mapping-list.component.d.ts +83 -0
- package/lib/components/role-mapping-list/role-mapping-list.component.d.ts.map +1 -0
- package/lib/components/suggest-more-courses/suggest-more-courses.component.d.ts +48 -0
- package/lib/components/suggest-more-courses/suggest-more-courses.component.d.ts.map +1 -0
- package/lib/components/update-designation-hierarchy/update-designation-hierarchy.component.d.ts +41 -0
- package/lib/components/update-designation-hierarchy/update-designation-hierarchy.component.d.ts.map +1 -0
- package/lib/components/view-cbp-plan/view-cbp-plan.component.d.ts +29 -0
- package/lib/components/view-cbp-plan/view-cbp-plan.component.d.ts.map +1 -0
- package/lib/components/view-course-recommendation/view-course-recommendation.component.d.ts +49 -0
- package/lib/components/view-course-recommendation/view-course-recommendation.component.d.ts.map +1 -0
- package/lib/components/view-final-cbp-plan/view-final-cbp-plan.component.d.ts +73 -0
- package/lib/components/view-final-cbp-plan/view-final-cbp-plan.component.d.ts.map +1 -0
- package/lib/modules/initial-screen/initial-screen.component.d.ts +85 -0
- package/lib/modules/initial-screen/initial-screen.component.d.ts.map +1 -0
- package/lib/modules/shared/constant/app.constant.d.ts +457 -0
- package/lib/modules/shared/constant/app.constant.d.ts.map +1 -0
- package/lib/modules/shared/directives/clickoutside.directive.d.ts +13 -0
- package/lib/modules/shared/directives/clickoutside.directive.d.ts.map +1 -0
- package/lib/modules/shared/directives/directive.module.d.ts +8 -0
- package/lib/modules/shared/directives/directive.module.d.ts.map +1 -0
- package/lib/modules/shared/pipes/order-by-name.pipe.d.ts +8 -0
- package/lib/modules/shared/pipes/order-by-name.pipe.d.ts.map +1 -0
- package/lib/modules/shared/services/event.service.d.ts +12 -0
- package/lib/modules/shared/services/event.service.d.ts.map +1 -0
- package/lib/modules/shared/services/events.d.ts +200 -0
- package/lib/modules/shared/services/events.d.ts.map +1 -0
- package/lib/modules/shared/services/init.service.d.ts +13 -0
- package/lib/modules/shared/services/init.service.d.ts.map +1 -0
- package/lib/modules/shared/services/role-mapping.service.d.ts +21 -0
- package/lib/modules/shared/services/role-mapping.service.d.ts.map +1 -0
- package/lib/modules/shared/services/shared.service.d.ts +108 -0
- package/lib/modules/shared/services/shared.service.d.ts.map +1 -0
- package/lib/modules/upload-document-page/progress-dialog/progress-dialog.component.d.ts +14 -0
- package/lib/modules/upload-document-page/progress-dialog/progress-dialog.component.d.ts.map +1 -0
- package/lib/modules/upload-document-page/upload-dialog/upload-dialog.component.d.ts +29 -0
- package/lib/modules/upload-document-page/upload-dialog/upload-dialog.component.d.ts.map +1 -0
- package/lib/modules/upload-document-page/upload-document-page.component.d.ts +64 -0
- package/lib/modules/upload-document-page/upload-document-page.component.d.ts.map +1 -0
- package/lib/pipe-public-URL/pipe-public-URL.module.d.ts +9 -0
- package/lib/pipe-public-URL/pipe-public-URL.module.d.ts.map +1 -0
- package/lib/pipe-public-URL/pipe-public-URL.pipe.d.ts +11 -0
- package/lib/pipe-public-URL/pipe-public-URL.pipe.d.ts.map +1 -0
- package/package.json +28 -0
- package/public-api.d.ts +11 -0
- package/public-api.d.ts.map +1 -0
- package/sunbird-cb-cbp-ai-0.0.1.tgz +0 -0
- package/sunbird-cb-cbp-ai.d.ts.map +1 -0
package/esm2022/lib/components/view-course-recommendation/view-course-recommendation.component.mjs
ADDED
|
@@ -0,0 +1,397 @@
|
|
|
1
|
+
import { MAT_DIALOG_DATA } from '@angular/material/dialog';
|
|
2
|
+
import { Component, Inject, ViewChild } from '@angular/core';
|
|
3
|
+
import { GenerateCourseRecommendationComponent } from '../generate-course-recommendation/generate-course-recommendation.component';
|
|
4
|
+
import { AddPersonalisationComponent } from '../add-personalisation/add-personalisation.component';
|
|
5
|
+
import html2pdf from 'html2pdf.js';
|
|
6
|
+
import { DeleteRoleMappingPopupComponent } from '../delete-role-mapping-popup/delete-role-mapping-popup.component';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "@angular/material/dialog";
|
|
9
|
+
import * as i2 from "../../modules/shared/services/shared.service";
|
|
10
|
+
import * as i3 from "@angular/material/snack-bar";
|
|
11
|
+
import * as i4 from "@angular/common";
|
|
12
|
+
import * as i5 from "@angular/material/icon";
|
|
13
|
+
import * as i6 from "@angular/material/progress-spinner";
|
|
14
|
+
import * as i7 from "@angular/material/tooltip";
|
|
15
|
+
export class ViewCourseRecommendationComponent {
|
|
16
|
+
constructor(dialogRef, data, sharedService, dialog, snackBar) {
|
|
17
|
+
this.dialogRef = dialogRef;
|
|
18
|
+
this.data = data;
|
|
19
|
+
this.sharedService = sharedService;
|
|
20
|
+
this.dialog = dialog;
|
|
21
|
+
this.snackBar = snackBar;
|
|
22
|
+
this.loading = false;
|
|
23
|
+
this.recommended_course_id = '';
|
|
24
|
+
this.suggestedCourses = [];
|
|
25
|
+
this.searchText = '';
|
|
26
|
+
this.selectFilterCourses = [];
|
|
27
|
+
this.competenciesCount = { total: 0, public_courses: 0, igot: 0 };
|
|
28
|
+
this.expandedCompetencies = {}; // Track expanded state for each course and competency type
|
|
29
|
+
this.isPDFDownload = false;
|
|
30
|
+
this.planData = data;
|
|
31
|
+
}
|
|
32
|
+
ngOnInit() {
|
|
33
|
+
this.loading = true;
|
|
34
|
+
this.cbpPlanData = this.sharedService.cbpPlanFinalObj;
|
|
35
|
+
// this.sharedService.getRecommendedCourse(this.planData.id).subscribe((res)=>{
|
|
36
|
+
// this.loading = false
|
|
37
|
+
// console.log('res', res)
|
|
38
|
+
// this.recommended_course_id = res.id
|
|
39
|
+
// let allCourses = []
|
|
40
|
+
// if(res && res.filtered_courses && res.filtered_courses.length) {
|
|
41
|
+
// res.filtered_courses.forEach((item)=>{
|
|
42
|
+
// if(item?.relevancy > 85) {
|
|
43
|
+
// allCourses.push(item)
|
|
44
|
+
// }
|
|
45
|
+
// })
|
|
46
|
+
// }
|
|
47
|
+
// this.filterdCourses = allCourses
|
|
48
|
+
// console.log('this.filterdCourses', this.filterdCourses)
|
|
49
|
+
// this.updateCompetencyCounts()
|
|
50
|
+
// this.getUserCourse()
|
|
51
|
+
// })
|
|
52
|
+
this.sharedService.getUserRecommendationCourse(this.planData.id).subscribe({
|
|
53
|
+
next: (res) => {
|
|
54
|
+
this.loading = false;
|
|
55
|
+
console.log('res', res);
|
|
56
|
+
this.recommended_course_id = res.id;
|
|
57
|
+
let allCourses = [];
|
|
58
|
+
if (res && res.selected_courses && res.selected_courses.length) {
|
|
59
|
+
res.selected_courses.forEach((item) => {
|
|
60
|
+
// if(item?.relevancy >= 85) {
|
|
61
|
+
allCourses.push(item);
|
|
62
|
+
// }
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
this.filterdCourses = allCourses;
|
|
66
|
+
let identifiersArr = [];
|
|
67
|
+
console.log('this.filterdCourses', this.filterdCourses);
|
|
68
|
+
this.filterdCourses.map((item) => {
|
|
69
|
+
identifiersArr.push(item?.identifier);
|
|
70
|
+
});
|
|
71
|
+
this.sharedService.getAdditionalParameterforSuggestedCourses(identifiersArr).subscribe((response) => {
|
|
72
|
+
if (response && response.result && response.result.content && response.result.content.length) {
|
|
73
|
+
for (let i = 0; i < response.result.content.length; i++) {
|
|
74
|
+
for (let j = 0; j < this.filterdCourses.length; j++) {
|
|
75
|
+
if (this.filterdCourses[j]['identifier'] === response.result.content[i]['identifier']) {
|
|
76
|
+
this.filterdCourses[j]['language'] = response.result.content[i]['language'];
|
|
77
|
+
this.filterdCourses[j]['avgRating'] = response.result.content[i]['avgRating'];
|
|
78
|
+
this.filterdCourses[j]['course'] = response.result.content[i]['name'];
|
|
79
|
+
break;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
});
|
|
85
|
+
this.updateCompetencyCounts();
|
|
86
|
+
// this.getSuggestedCourse()
|
|
87
|
+
// this.getUserCourse()
|
|
88
|
+
},
|
|
89
|
+
error: (error) => {
|
|
90
|
+
this.loading = false;
|
|
91
|
+
this.snackBar.open(error?.error?.detail, 'X', {
|
|
92
|
+
duration: 3000,
|
|
93
|
+
panelClass: ['snackbar-error']
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
updateCompetencyCounts() {
|
|
99
|
+
// const comps = this.competenciesArray.value;
|
|
100
|
+
this.competenciesCount = { total: 0, public_courses: 0, igot: 0 };
|
|
101
|
+
this.filterdCourses.forEach(c => {
|
|
102
|
+
this.competenciesCount.total++;
|
|
103
|
+
if (c.is_public)
|
|
104
|
+
this.competenciesCount.public_courses++;
|
|
105
|
+
if (!c.is_public)
|
|
106
|
+
this.competenciesCount.igot++;
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
closeDialog() {
|
|
110
|
+
this.dialogRef.close();
|
|
111
|
+
}
|
|
112
|
+
addMoreCourses() {
|
|
113
|
+
this.dialogRef.close();
|
|
114
|
+
console.log('Generate Course Recommendation clicked', this.planData);
|
|
115
|
+
console.log('Edit Role Mapping clicked', this.planData);
|
|
116
|
+
// Navigate or open modal
|
|
117
|
+
console.log('View CBP Plan clicked', this.planData);
|
|
118
|
+
const dialogRef = this.dialog.open(GenerateCourseRecommendationComponent, {
|
|
119
|
+
width: '1000px',
|
|
120
|
+
data: this.planData,
|
|
121
|
+
panelClass: 'view-cbp-plan-popup',
|
|
122
|
+
minHeight: '400px',
|
|
123
|
+
maxHeight: '90vh',
|
|
124
|
+
disableClose: true // Optional: prevent closing with outside click
|
|
125
|
+
});
|
|
126
|
+
dialogRef.afterClosed().subscribe(result => {
|
|
127
|
+
if (result === 'saved') {
|
|
128
|
+
console.log('Changes saved!');
|
|
129
|
+
// Refresh data or show a toast here
|
|
130
|
+
}
|
|
131
|
+
});
|
|
132
|
+
}
|
|
133
|
+
addPersonilisation() {
|
|
134
|
+
this.dialogRef.close();
|
|
135
|
+
console.log('Generate Course Recommendation clicked', this.planData);
|
|
136
|
+
console.log('Edit Role Mapping clicked', this.planData);
|
|
137
|
+
// Navigate or open modal
|
|
138
|
+
console.log('View CBP Plan clicked', this.planData);
|
|
139
|
+
const dialogRef = this.dialog.open(AddPersonalisationComponent, {
|
|
140
|
+
width: '1000px',
|
|
141
|
+
data: this.planData,
|
|
142
|
+
panelClass: 'view-cbp-plan-popup',
|
|
143
|
+
minHeight: '400px',
|
|
144
|
+
maxHeight: '90vh',
|
|
145
|
+
disableClose: true // Optional: prevent closing with outside click
|
|
146
|
+
});
|
|
147
|
+
dialogRef.afterClosed().subscribe(result => {
|
|
148
|
+
if (result === 'saved') {
|
|
149
|
+
console.log('Changes saved!');
|
|
150
|
+
// Refresh data or show a toast here
|
|
151
|
+
}
|
|
152
|
+
});
|
|
153
|
+
}
|
|
154
|
+
getSuggestedCourse() {
|
|
155
|
+
let role_mapping_id = this.planData.id;
|
|
156
|
+
this.loading = true;
|
|
157
|
+
this.sharedService.getSuggestedCourses(role_mapping_id).subscribe({
|
|
158
|
+
next: (res) => {
|
|
159
|
+
// Success handling
|
|
160
|
+
this.loading = false;
|
|
161
|
+
console.log('getSuggestedCourses res', res);
|
|
162
|
+
// Store suggested courses separately
|
|
163
|
+
this.suggestedCourses = [...res];
|
|
164
|
+
// Add suggested courses to filtered courses
|
|
165
|
+
for (let i = 0; i < res.length; i++) {
|
|
166
|
+
this.filterdCourses.push(res[i]);
|
|
167
|
+
}
|
|
168
|
+
// Update competency counts after adding suggested courses
|
|
169
|
+
this.updateCompetencyCounts();
|
|
170
|
+
console.log('filterdCourses after adding suggested courses:', this.filterdCourses);
|
|
171
|
+
},
|
|
172
|
+
error: (error) => {
|
|
173
|
+
console.log('getSuggestedCourse error', error);
|
|
174
|
+
this.loading = false;
|
|
175
|
+
if (error.status === 401) {
|
|
176
|
+
console.log('Unauthorized access - user will be redirected to login');
|
|
177
|
+
}
|
|
178
|
+
else {
|
|
179
|
+
console.error('Failed to load suggested courses');
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
});
|
|
183
|
+
}
|
|
184
|
+
getUserCourse() {
|
|
185
|
+
let role_mapping_id = this.planData.id;
|
|
186
|
+
this.loading = true;
|
|
187
|
+
this.sharedService.getUserCourse(role_mapping_id).subscribe({
|
|
188
|
+
next: (res) => {
|
|
189
|
+
// Success handling
|
|
190
|
+
this.loading = false;
|
|
191
|
+
// Process user-added courses to ensure proper structure
|
|
192
|
+
for (let i = 0; i < res.length; i++) {
|
|
193
|
+
this.filterdCourses.push(res[i]);
|
|
194
|
+
}
|
|
195
|
+
// Update competency counts after adding user courses
|
|
196
|
+
this.updateCompetencyCounts();
|
|
197
|
+
console.log('filterdCourses after adding user courses:', this.filterdCourses);
|
|
198
|
+
//this.successRoleMapping.emit(this.roleMappingForm)
|
|
199
|
+
},
|
|
200
|
+
error: (error) => {
|
|
201
|
+
console.log('error', error);
|
|
202
|
+
this.loading = false;
|
|
203
|
+
// Handle 409 Conflict here
|
|
204
|
+
// alert('Conflict detected: The resource already exists or action conflicts.');
|
|
205
|
+
//this.get
|
|
206
|
+
// Or you can set a UI error message variable
|
|
207
|
+
this.loading = false;
|
|
208
|
+
//this.alreadyAvailableRoleMapping.emit(this.roleMappingForm)
|
|
209
|
+
}
|
|
210
|
+
});
|
|
211
|
+
}
|
|
212
|
+
getCompetenciesByType(type, index) {
|
|
213
|
+
const course = this.filterdCourses[index];
|
|
214
|
+
if (!course) {
|
|
215
|
+
console.log(`No course found at index ${index}`);
|
|
216
|
+
return [];
|
|
217
|
+
}
|
|
218
|
+
// Handle different competency property names
|
|
219
|
+
// AI Recommended & Public courses use 'competencies'
|
|
220
|
+
// Manually Suggested - iGOT courses use 'competencies_v6'
|
|
221
|
+
// User Added courses use 'competencies'
|
|
222
|
+
let competencies = [];
|
|
223
|
+
if (course.competencies && Array.isArray(course.competencies)) {
|
|
224
|
+
competencies = course.competencies;
|
|
225
|
+
console.log(`Course ${index} (${course.course_type || course.name || 'Unknown'}) using 'competencies' property:`, competencies);
|
|
226
|
+
}
|
|
227
|
+
else if (course.competencies_v6 && Array.isArray(course.competencies_v6)) {
|
|
228
|
+
competencies = course.competencies_v6;
|
|
229
|
+
console.log(`Course ${index} (${course.course_type || course.name || 'Unknown'}) using 'competencies_v6' property:`, competencies);
|
|
230
|
+
}
|
|
231
|
+
else {
|
|
232
|
+
console.log(`Course ${index} (${course.course_type || course.name || 'Unknown'}) has no valid competencies property:`, {
|
|
233
|
+
hasCompetencies: !!course.competencies,
|
|
234
|
+
competenciesType: typeof course.competencies,
|
|
235
|
+
hasCompetenciesV6: !!course.competencies_v6,
|
|
236
|
+
competenciesV6Type: typeof course.competencies_v6,
|
|
237
|
+
courseKeys: Object.keys(course)
|
|
238
|
+
});
|
|
239
|
+
}
|
|
240
|
+
if (competencies.length === 0) {
|
|
241
|
+
console.log(`No competencies found for course ${index} and type ${type}`);
|
|
242
|
+
return [];
|
|
243
|
+
}
|
|
244
|
+
// Normalize the type for comparison (case-insensitive + handle spelling variations)
|
|
245
|
+
const normalizedType = type.toLowerCase().trim();
|
|
246
|
+
const matchedCompetencies = competencies.filter(c => {
|
|
247
|
+
if (!c || !c.competencyAreaName) {
|
|
248
|
+
console.log(`Invalid competency structure in course ${index}:`, c);
|
|
249
|
+
return false;
|
|
250
|
+
}
|
|
251
|
+
const competencyArea = c.competencyAreaName.toLowerCase().trim();
|
|
252
|
+
// Handle both "behavioral" and "behavioural" spellings
|
|
253
|
+
if (normalizedType === 'behavioural' || normalizedType === 'behavioral') {
|
|
254
|
+
return competencyArea === 'behavioral' || competencyArea === 'behavioural';
|
|
255
|
+
}
|
|
256
|
+
// For other types, do case-insensitive comparison
|
|
257
|
+
return competencyArea === normalizedType;
|
|
258
|
+
});
|
|
259
|
+
console.log(`Found ${matchedCompetencies.length} competencies of type ${type} for course ${index}:`, matchedCompetencies);
|
|
260
|
+
return matchedCompetencies;
|
|
261
|
+
}
|
|
262
|
+
getDisplayedCompetencies(type, index) {
|
|
263
|
+
const competencies = this.getCompetenciesByType(type, index);
|
|
264
|
+
const key = `${index}-${type}`;
|
|
265
|
+
if (this.expandedCompetencies[key]) {
|
|
266
|
+
return competencies;
|
|
267
|
+
}
|
|
268
|
+
return competencies.slice(0, 2);
|
|
269
|
+
}
|
|
270
|
+
toggleCompetencies(type, index) {
|
|
271
|
+
const key = `${index}-${type}`;
|
|
272
|
+
this.expandedCompetencies[key] = !this.expandedCompetencies[key];
|
|
273
|
+
}
|
|
274
|
+
isExpanded(type, index) {
|
|
275
|
+
const key = `${index}-${type}`;
|
|
276
|
+
return this.expandedCompetencies[key] || false;
|
|
277
|
+
}
|
|
278
|
+
hasMoreThanTwo(type, index) {
|
|
279
|
+
return this.getCompetenciesByType(type, index).length > 2;
|
|
280
|
+
}
|
|
281
|
+
getRemainingCount(type, index) {
|
|
282
|
+
const totalCount = this.getCompetenciesByType(type, index).length;
|
|
283
|
+
return totalCount - 2;
|
|
284
|
+
}
|
|
285
|
+
downloadPDF() {
|
|
286
|
+
this.loading = true;
|
|
287
|
+
this.isPDFDownload = true;
|
|
288
|
+
const element = this.pdfContent.nativeElement;
|
|
289
|
+
// Wait for images to load
|
|
290
|
+
const images = element.querySelectorAll('img');
|
|
291
|
+
const promises = Array.from(images).map((img) => {
|
|
292
|
+
if (img.complete)
|
|
293
|
+
return Promise.resolve();
|
|
294
|
+
return new Promise(resolve => img.onload = resolve);
|
|
295
|
+
});
|
|
296
|
+
Promise.all(promises).then(() => {
|
|
297
|
+
const options = {
|
|
298
|
+
margin: 0.5,
|
|
299
|
+
filename: 'Recommended Coureses.pdf',
|
|
300
|
+
image: { type: 'jpeg', quality: 0.98 },
|
|
301
|
+
html2canvas: {
|
|
302
|
+
scale: 2,
|
|
303
|
+
useCORS: true,
|
|
304
|
+
scrollY: 0,
|
|
305
|
+
},
|
|
306
|
+
jsPDF: {
|
|
307
|
+
unit: 'in',
|
|
308
|
+
format: 'a4',
|
|
309
|
+
orientation: 'portrait'
|
|
310
|
+
},
|
|
311
|
+
pagebreak: {
|
|
312
|
+
mode: ['css', 'legacy', 'avoid-all']
|
|
313
|
+
}
|
|
314
|
+
};
|
|
315
|
+
html2pdf().from(element).set(options).save();
|
|
316
|
+
setTimeout(() => {
|
|
317
|
+
this.loading = false;
|
|
318
|
+
this.isPDFDownload = false;
|
|
319
|
+
}, 3000);
|
|
320
|
+
});
|
|
321
|
+
}
|
|
322
|
+
downloadPdfFromBE() {
|
|
323
|
+
this.loading = true;
|
|
324
|
+
// this.sharedService.downloadPdf(this.sharedService?.cbpPlanFinalObj.ministry.identifier)
|
|
325
|
+
this.sharedService.downloadPdfForCourseRecommendation(this.data?.id);
|
|
326
|
+
setTimeout(() => {
|
|
327
|
+
this.loading = false;
|
|
328
|
+
}, 5000);
|
|
329
|
+
}
|
|
330
|
+
confirmDeleteCourse(item, index) {
|
|
331
|
+
const roleMappingId = this.recommended_course_id;
|
|
332
|
+
const courseIdentifier = item?.course_identifier || item?.id || item?.identifier;
|
|
333
|
+
if (!roleMappingId || !courseIdentifier) {
|
|
334
|
+
this.snackBar.open('Unable to delete course', 'X', {
|
|
335
|
+
duration: 3000,
|
|
336
|
+
panelClass: ['snackbar-error']
|
|
337
|
+
});
|
|
338
|
+
return;
|
|
339
|
+
}
|
|
340
|
+
this.loading = true;
|
|
341
|
+
this.sharedService
|
|
342
|
+
.deleteRecommendedCourse(roleMappingId, courseIdentifier)
|
|
343
|
+
.subscribe({
|
|
344
|
+
next: () => {
|
|
345
|
+
// Remove from UI
|
|
346
|
+
this.filterdCourses.splice(index, 1);
|
|
347
|
+
// Update counts
|
|
348
|
+
this.updateCompetencyCounts();
|
|
349
|
+
this.loading = false;
|
|
350
|
+
this.snackBar.open('Course deleted successfully', 'X', {
|
|
351
|
+
duration: 3000,
|
|
352
|
+
panelClass: ['snackbar-success']
|
|
353
|
+
});
|
|
354
|
+
},
|
|
355
|
+
error: (error) => {
|
|
356
|
+
this.loading = false;
|
|
357
|
+
this.snackBar.open(error?.error?.detail || 'Failed to delete course', 'X', {
|
|
358
|
+
duration: 3000,
|
|
359
|
+
panelClass: ['snackbar-error']
|
|
360
|
+
});
|
|
361
|
+
}
|
|
362
|
+
});
|
|
363
|
+
}
|
|
364
|
+
deleteCard(item, index) {
|
|
365
|
+
const dialogRef = this.dialog.open(DeleteRoleMappingPopupComponent, {
|
|
366
|
+
width: '600px',
|
|
367
|
+
data: {
|
|
368
|
+
planId: this.planData?.id,
|
|
369
|
+
course: item,
|
|
370
|
+
index: index,
|
|
371
|
+
from: 'viewCourse' // index for UI removal
|
|
372
|
+
},
|
|
373
|
+
panelClass: 'view-cbp-plan-popup',
|
|
374
|
+
minHeight: '300px',
|
|
375
|
+
maxHeight: '90vh',
|
|
376
|
+
disableClose: true
|
|
377
|
+
});
|
|
378
|
+
dialogRef.afterClosed().subscribe(result => {
|
|
379
|
+
if (result === 'saved') {
|
|
380
|
+
this.confirmDeleteCourse(item, index);
|
|
381
|
+
}
|
|
382
|
+
});
|
|
383
|
+
}
|
|
384
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ViewCourseRecommendationComponent, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }, { token: i2.SharedService }, { token: i1.MatDialog }, { token: i3.MatSnackBar }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
385
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ViewCourseRecommendationComponent, selector: "app-view-course-recommendation", viewQueries: [{ propertyName: "pdfContent", first: true, predicate: ["pdfContent"], descendants: true }], ngImport: i0, template: "<div class=\"view-cbp-plan\">\n <div class=\"popup-container\">\n <div class=\"popup-header\">\n <div>\n <div class=\"heading\">View Course Recommendation</div>\n </div>\n <div class=\"cursor-pointer\" (click)=\"closeDialog()\">\n <mat-icon>close</mat-icon>\n </div>\n </div>\n </div>\n <div class=\"section-container mt-2\" #pdfContent>\n <div class=\"ministry-heading mt-2\">\n <span *ngIf=\"!cbpPlanData?.department_name\">{{cbpPlanData?.ministry.orgName}}</span> \n <span *ngIf=\"cbpPlanData?.department_name\">{{cbpPlanData?.department_name}}</span> \n <span *ngIf=\"planData?.designation_name\"> / {{planData?.designation_name}}</span>\n </div>\n <div class=\"competency-container mt-4\">\n <div class=\"outside-layer-total\">\n <div class=\"inside-layer\">\n Total Courses\n </div>\n <div class=\"count\">\n {{competenciesCount?.total}}\n </div>\n </div>\n <div class=\"outside-layer-total\">\n <div class=\"inside-layer\">\n iGOT Platform Courses\n </div>\n <div class=\"count\">\n {{competenciesCount?.igot}}\n </div>\n </div>\n <div class=\"outside-layer-total\">\n <div class=\"inside-layer\">\n Public Courses\n </div>\n <div class=\"count\">\n {{competenciesCount?.public_courses}}\n \n </div>\n </div>\n \n </div>\n <div class=\"my-4\">\n \n <div class=\"course-list-container\">\n <div class=\"course-list-item\" *ngFor=\"let item of filterdCourses;let i=index\">\n <div class=\"course-header\">\n <div class=\"checked-course-container\">\n \n <div>\n <div class=\"course-pill\">\n <div class=\"course-pill-text\">\n <span><img src=\"assets/icons/course.svg\"></span> <span>Course</span>\n </div>\n </div>\n </div>\n\n </div>\n\n <!-- <div>\n <div class=\"ai-recommened-pill\">\n <div class=\"ai-recommened-pill-text\">\n <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span>\n <span>AI Recommended</span>\n\n </div>\n </div>\n </div> -->\n <div *ngIf=\"item?.rationale && !item?.is_public\">\n <div class=\"ai-recommened-pill-green\">\n <div class=\"ai-recommened-pill-green-text\">\n <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span>\n \n <span >AI Recommended - iGOT </span>\n\n </div>\n </div>\n <div class=\"ai-recommened-pill-orange mt-2\" *ngIf=\"item?.platform\">\n <div class=\"ai-recommened-pill-orange-text\">\n <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span>\n <a class=\"cursor-pointer\" [href]=\"item?.public_link\" target=\"_blank\"><span>Platform - {{item?.platform}}</span></a>\n </div> \n </div>\n <div class=\"ai-recommened-pill-orange mt-2\" *ngIf=\"item?.organisation?.length\">\n <div class=\"ai-recommened-pill-orange-text\">\n <span class=\"ai-loader-icon\"><img\n src=\"assets/icons/ai-loader.gif\"></span>\n <span>Provider - {{item?.organisation[0]}}</span>\n </div>\n </div>\n </div>\n <div *ngIf=\"item?.rationale && item?.is_public\">\n <div class=\"ai-recommened-pill-public\">\n <div class=\"ai-recommened-pill-public-text\">\n <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span>\n \n <span >AI Recommended - Public </span>\n\n </div>\n </div>\n <div class=\"ai-recommened-pill-orange mt-2\" *ngIf=\"item?.platform\">\n <div class=\"ai-recommened-pill-orange-text\">\n <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span>\n <a class=\"cursor-pointer\" [href]=\"item?.public_link\" target=\"_blank\"><span>Platform - {{item?.platform}}</span></a>\n </div> \n </div>\n <div class=\"ai-recommened-pill-orange mt-2\" *ngIf=\"item?.organisation?.length\">\n <div class=\"ai-recommened-pill-orange-text\">\n <span class=\"ai-loader-icon\"><img\n src=\"assets/icons/ai-loader.gif\"></span>\n <span>Provider - {{item?.organisation[0]}}</span>\n </div>\n </div>\n </div>\n <div *ngIf=\"!item?.rationale\">\n <div class=\"ai-recommened-pill-gray\">\n <div class=\"ai-recommened-pill-gray-text\">\n <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span>\n \n <span>Manually Suggested - iGOT </span>\n\n </div>\n </div>\n <div class=\"ai-recommened-pill-orange mt-2\" *ngIf=\"item?.platform\">\n <div class=\"ai-recommened-pill-orange-text\">\n <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span>\n <a class=\"cursor-pointer\" [href]=\"item?.public_link\" target=\"_blank\"><span>Platform - {{item?.platform}}</span></a>\n </div> \n </div>\n <div class=\"ai-recommened-pill-orange mt-2\" *ngIf=\"item?.organisation?.length\">\n <div class=\"ai-recommened-pill-orange-text\">\n <span class=\"ai-loader-icon\"><img\n src=\"assets/icons/ai-loader.gif\"></span>\n <span>Provider - {{item?.organisation[0]}}</span>\n </div>\n </div>\n </div>\n </div>\n <div class=\"course-title mt-4\">\n <div>\n <div *ngIf=\"item?.course\">{{item?.course}}</div>\n <!-- <div *ngIf=\"item?.name\">{{item?.name}}</div> -->\n </div>\n </div>\n <div class=\"course-desc mt-2\">\n <div *ngIf=\"isPDFDownload\">\n <div>{{item?.rationale}}</div>\n </div>\n </div>\n <div class=\"mt-3\" *ngIf=\"getCompetenciesByType('Behavioural',i)?.length\">\n <div class=\"competency-sub-heading\">Behavioral Competencies</div>\n <ul class=\"competency-list mt-1\">\n <li class=\"behavioural-pill\"\n *ngFor=\"let comp of getDisplayedCompetencies('Behavioural',i)\">\n <span class=\"competency-text\"> {{ comp.competencyThemeName }} -\n {{\n comp.competencySubThemeName }} </span>\n </li>\n <li *ngIf=\"hasMoreThanTwo('Behavioural',i)\"\n class=\"show-more-competency\">\n <span class=\"show-more-link cursor-pointer\"\n (click)=\"toggleCompetencies('Behavioural',i)\">\n {{ isExpanded('Behavioural',i) ? 'Show Less' : '+' +\n getRemainingCount('Behavioural',i) + ' More' }}\n </span>\n </li>\n </ul>\n </div>\n <div class=\"mt-2\" *ngIf=\"getCompetenciesByType('Functional',i)?.length\">\n <div class=\"competency-sub-heading\">Functional Competencies</div>\n <ul class=\"competency-list mt-1\">\n <li class=\"functional-pill\"\n *ngFor=\"let comp of getDisplayedCompetencies('Functional',i)\">\n <span class=\"competency-text\"> {{ comp.competencyThemeName }} -\n {{\n comp.competencySubThemeName }} </span>\n </li>\n <li *ngIf=\"hasMoreThanTwo('Functional',i)\"\n class=\"show-more-competency\">\n <span class=\"show-more-link cursor-pointer\"\n (click)=\"toggleCompetencies('Functional',i)\">\n {{ isExpanded('Functional',i) ? 'Show Less' : '+' +\n getRemainingCount('Functional',i) + ' More' }}\n </span>\n </li>\n </ul>\n </div>\n <div class=\"mt-2\" *ngIf=\"getCompetenciesByType('Domain',i)?.length\">\n <div class=\"competency-sub-heading\">Domain Competencies</div>\n <ul class=\"competency-list mt-1\">\n <li class=\"domain-pill\"\n *ngFor=\"let comp of getDisplayedCompetencies('Domain',i)\">\n <span class=\"competency-text\"> {{ comp.competencyThemeName }} -\n {{\n comp.competencySubThemeName }} </span>\n </li>\n <li *ngIf=\"hasMoreThanTwo('Domain',i)\" class=\"show-more-competency\">\n <span class=\"show-more-link cursor-pointer\"\n (click)=\"toggleCompetencies('Domain',i)\">\n {{ isExpanded('Domain',i) ? 'Show Less' : '+' +\n getRemainingCount('Domain',i) + ' More' }}\n </span>\n </li>\n </ul>\n </div>\n <div class=\"mt-2 d-flex justify-content-between item\">\n <div class=\"relevancy-container\">\n <div class=\"relevancy\">Relevancy</div>\n <div class=\"dash\">-</div>\n <div class=\"percentage\" *ngIf=\"item?.relevancy\">{{item?.relevancy}}%</div>\n <div class=\"percentage\" *ngIf=\"!item?.relevancy\">N/A</div>\n </div>\n <div class=\"delete-button\">\n <mat-icon matTooltip=\"Delete Course\" matTooltipPosition=\"above\" class=\"text-danger cursor-pointer\" (click)=\"deleteCard(item, i)\" >delete</mat-icon>\n </div>\n </div>\n <!-- <div>\n <div class=\"competencies-matched-container\">\n <div class=\"competencies-matched\">Competencies Matched</div>\n <div class=\"dash\">-</div>\n <div class=\"percentage\">80%</div>\n </div>\n </div> -->\n </div>\n <!-- <div class=\"course-list-item\">\n <div class=\"course-header\">\n <div>\n <div class=\"course-pill\">\n <div class=\"course-pill-text\">Course</div>\n </div>\n </div>\n <div>\n <div class=\"ai-recommened-pill\">\n <div class=\"ai-recommened-pill-text\">\n <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span>\n <span>AI Recommended</span>\n\n </div>\n </div>\n </div>\n </div>\n <div class=\"course-title\">\n <div>\n <div>Maternal, Infant And Young Child Nutrition</div>\n </div>\n </div>\n <div class=\"course-desc\">\n <div>\n <div>This Course directly addresses a primary responsibility of Anganwandi Care takers,\n which is\n to provide and educate on nutrition for mother and young children</div>\n </div>\n </div>\n <div>\n <div class=\"relevancy-container\">\n <div class=\"relevancy\">Relevancy</div>\n <div class=\"dash\">-</div>\n <div class=\"percentage\">90%</div>\n </div>\n </div>\n <div>\n <div class=\"competencies-matched-container\">\n <div class=\"competencies-matched\">Competencies Matched</div>\n <div class=\"dash\">-</div>\n <div class=\"percentage\">80%</div>\n </div>\n </div>\n </div> -->\n\n </div>\n </div>\n </div>\n <div class=\"popup-footer\" *ngIf=\"filterdCourses?.length\">\n <div>\n <input class=\"btn-active\" type=\"button\" value=\"Download\" (click)=\"downloadPdfFromBE()\"/>\n </div>\n <!-- <div>\n <input class=\"btn-active\" type=\"button\" value=\"Add Personalisation\" (click)=\"addPersonilisation()\"/>\n </div> -->\n <!-- <div>\n <input class=\"btn-active\" type=\"button\" value=\"Add More Courses\" (click)=\"addMoreCourses()\"/>\n </div> -->\n </div>\n</div>\n<div class=\"overlay-loader\" *ngIf=\"loading\">\n <mat-spinner diameter=\"50\"></mat-spinner>\n</div>", styles: ["@charset \"UTF-8\";.container{margin:10px auto}.sub-heading p{color:#000;font-family:Montserrat;font-size:16px;font-style:normal;font-weight:600;line-height:normal}.ministry-heading{color:#1b4ca1;font-family:Montserrat;font-size:20px;font-style:normal;font-weight:600;line-height:normal}.radio-label{color:#000;font-family:Lato;font-size:16px;font-style:normal;font-weight:400;line-height:normal}.radio-btn-group{display:flex;width:32px;height:32px;padding:2px;gap:10px}.label{color:var(--Body-Text-Body-Color, #212529);font-family:Lato;font-size:16px;font-style:normal;font-weight:700;line-height:150%}::ng-deep mat-form-field{background-color:#fff!important;border-radius:25px!important;padding-left:12px;padding-right:12px;height:42px;width:100%}::ng-deep mat-select{border-radius:25px!important;background-color:#fff!important}::ng-deep .mat-select-panel{background-color:#fff!important}::ng-deep .mat-select-panel .mat-option{border-radius:0!important}::ng-deep mat-form-field .mat-form-field-underline{display:none!important}::ng-deep mat-select .mat-select-placeholder{color:#0006;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal}::ng-deep mat-select .mat-select-value-text{color:#000;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal;line-height:normal!important;padding-top:0!important;padding-bottom:0!important}::ng-deep mat-select .mat-select-value{display:flex!important;align-items:center!important;height:100%!important}.additional-details textarea{display:flex;padding:16px 16px 0;flex-direction:column;align-items:flex-start;gap:10px;flex:1 0 0;align-self:stretch;width:100%;color:#000;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal;resize:none}.section-header{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.btn-disable{border-radius:var(--Radius-Full-Round, 9999999px);opacity:.4;background:var(--Primary-KB-Primary-Light, #1B4CA1);color:var(--white-kb-white-100, #FFF);text-align:center;font-family:Lato;font-size:14px;font-style:normal;font-weight:700;line-height:normal;display:flex;height:32px;padding:0 16px;justify-content:center;align-items:center;gap:8px;border:none}.btn-group{display:flex;flex-direction:row;justify-content:space-between}.pl-2{padding-left:5px}.search-filter-section{display:flex;flex-direction:row;justify-content:space-between}.search .rsearch{position:relative}.search .search-icon{position:absolute;top:15px;font-size:20px;left:10px}.search .sinput{border-radius:32px;border:1px solid #d5d0d0;padding:15px 36px;font:400 14px Lato;width:800px}.select-map-route-container{display:flex;flex-direction:row}.selected-mapping-route p{color:#1b4ca1;font-family:Lato;font-size:20px;font-style:normal;font-weight:400;line-height:normal;text-decoration-line:underline;text-decoration-style:solid;-webkit-text-decoration-skip:ink;text-decoration-skip-ink:auto;text-decoration-thickness:auto;text-underline-offset:auto;text-underline-position:from-font}.edit-plan{display:flex;padding:4px;justify-content:center;align-items:center;gap:8px;border-radius:4px;background:#1b4ca129;color:#1b4ca1;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal;margin-left:10px}.search-container{display:flex;flex-direction:row}.course-container{display:flex;width:100%;padding:16px;flex-direction:column;align-items:flex-start;gap:24px;grid-row:2/span 1;grid-column:1/span 1;border-radius:12px;border:1px solid var(--borders-black-border-16-black, rgba(0, 0, 0, .16));background:#fff}.course-header{display:flex;flex-direction:row;justify-content:space-between;width:100%}.course-pill{display:flex;height:24px;padding:8px;align-items:center;gap:4px;border-radius:16px;border:1px solid var(--borders-border-fill-focussed-4-light-100, #EF951E);background:#fefaf4}.ai-recommened-pill-green{display:flex;padding:4px 8px;align-items:center;gap:8px;border-radius:var(--Radius-4, 4px);background:#0080001c}.ai-recommened-pill-green-text{color:#006400;font-family:Lato;font-size:11px;font-style:normal;font-weight:600;line-height:normal}.ai-recommened-pill-public{display:flex;padding:4px 8px;align-items:center;gap:8px;border-radius:var(--Radius-4, 4px);background:#1b4ca129}.ai-recommened-pill-public-text{color:#1b4ca1;font-family:Lato;font-size:11px;font-style:normal;font-weight:600;line-height:normal}.ai-recommened-pill-gray{display:flex;padding:4px 8px;align-items:center;gap:8px;border-radius:var(--Radius-4, 4px);background:#d3d3d3}.ai-recommened-pill-gray-text{color:#000;font-family:Lato;font-size:11px;font-style:normal;font-weight:600;line-height:normal}.ai-recommened-pill-orange{display:flex;padding:4px 8px;align-items:center;gap:8px;border-radius:var(--Radius-4, 4px);background:#ffa50052}.ai-recommened-pill-orange-text{color:#5a3f0d;font-family:Lato;font-size:11px;font-style:normal;font-weight:600;line-height:normal}.ai-recommened-pill-orange-text a{color:#5a3f0d!important;font-family:Lato;font-size:11px;font-style:normal;font-weight:600;line-height:normal}.igot-platform-pill{display:flex;padding:4px 8px;align-items:center;gap:8px;border-radius:var(--Radius-4, 4px);border:1px solid #EF951E;background:#ef951e29}.course-title{color:var(--Primary-KB-Primary-Light, #1B4CA1);font-family:Montserrat;font-size:16px;font-style:normal;font-weight:600;line-height:22px}.course-desc{color:#0009;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.relevancy,.competencies-matched{color:#6c757d;font-family:Lato;font-size:12px;font-style:normal;font-weight:500;line-height:normal;align-items:center}.percentage{color:#1b4ca1;font-family:Lato;font-size:14px;font-style:normal;font-weight:600;line-height:normal}.delete-button input{background-color:#b60a0a;border-radius:10px}.relevancy-container,.competencies-matched-container{display:flex;flex-direction:row;align-items:center}.dash{padding:0 5px}::ng-deep .mat-radio-checked .mat-radio-inner-circle{background:#1b4ca1!important}.course-list-container{display:flex;flex-wrap:wrap;gap:16px;width:100%;padding:1rem}.course-list-item{flex:1 1 calc(50% - 10px);min-width:350px;max-width:500px;box-sizing:border-box;border:1px solid #e0e0e0;padding:16px;background-color:#fff;border-radius:12px;min-height:auto;box-shadow:0 2px 4px #0000001a;transition:box-shadow .2s ease;display:flex;flex-direction:column}.course-list-item:hover{box-shadow:0 4px 8px #00000026}.course-list-item:only-child{flex:1 1 auto;max-width:800px}.checked-course-container{display:flex;width:60%}.ml-2{margin-left:8px}::ng-deep .mat-checkbox-checked .mat-checkbox-background{background:#1b4ca1!important}.igot-platform-pill-text{color:#1b4ca1;font-family:Lato;font-size:12px;font-style:normal;font-weight:700;line-height:normal}.course-pill-text{color:var(--accessbility-shades-without-opacity-kb-greys-black-87, #212121);text-align:center;font-family:Poppins;font-size:12px;font-style:normal;font-weight:400;line-height:normal}.ai-loader-icon img,.igot-platform-icon img{width:15.714px;height:15.714px;flex-shrink:0}.competency-container{display:flex;justify-content:normal;gap:16px;flex-direction:row}.outside-layer-total{display:flex;padding:4px 12px;justify-content:center;align-items:center;gap:16px;border-radius:12px 4px 4px 12px;border-left:2px solid #1B4CA1;background:#edf1f8;width:132px}.outside-layer-functional{display:flex;padding:4px 12px;justify-content:center;align-items:center;gap:16px;border-radius:12px 4px 4px 12px;border-left:2px solid #E24577;background:#f8d2de;width:132px}.outside-layer-domain{display:flex;padding:4px 12px;justify-content:center;align-items:center;gap:16px;border-radius:12px 4px 4px 12px;border-left:2px solid #7B47A4;background:#dfd3e9;width:132px}.outside-layer-behavioral{display:flex;padding:4px 12px;justify-content:center;align-items:center;gap:16px;border-radius:12px 4px 4px 12px;border-left:2px solid #F8B861;background:#fde8cc;width:132px}.inside-layer{color:#1b4ca1;font-family:Lato;font-size:16px;font-style:normal;font-weight:400;line-height:normal}.count{color:#1b4ca1;font-family:Montserrat;font-size:18px;font-style:normal;font-weight:600;line-height:normal}.suggest-courses-header{display:flex;flex-direction:row;justify-content:space-between}.suggest-course-control{display:flex;flex-direction:row}.course-card-container{width:172px;border-radius:3.307px;border:.827px solid var(--borders-border-8-black, rgba(0, 0, 0, .08));background-color:#fff}.highlight-ai{font-family:Montserrat;font-size:24px;font-style:normal;font-weight:600;line-height:normal;background:linear-gradient(90deg,#3b27ff,#2de3d6);background-clip:text;-webkit-background-clip:text;color:transparent;-webkit-text-fill-color:transparent;display:inline-block}.ai-loader-icon-medium img{width:40px;height:40px;flex-shrink:0}.heading{color:#000;font-family:Montserrat;font-size:16px;font-style:normal;font-weight:600;line-height:normal;margin:10px 0}.pdf-heading{color:#000;font-family:Montserrat;font-size:18px;font-style:normal;font-weight:600;line-height:normal;margin:10px 0;text-align:center}.popup-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid #e0e0e0}.header-left{flex:1}.header-actions{display:flex;align-items:center;gap:12px}.regenerate-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;min-width:auto}.regenerate-btn .mat-icon{margin:0;font-size:18px;width:18px;height:18px}.regenerate-btn .mat-spinner{margin:0}.regenerate-btn:disabled{opacity:.7;cursor:not-allowed}.close-btn{padding:8px;border-radius:4px;transition:background-color .2s ease}.close-btn:hover{background-color:#f5f5f5}.close-btn .mat-icon{font-size:20px;width:20px;height:20px}.progress-popup{display:flex;flex-direction:column;justify-content:center;align-items:center}.progress-popup .desc{color:#000000de;text-align:center;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal}.behavioural-pill{display:flex;padding:2px 6px;justify-content:center;align-items:center;gap:4px;border-radius:16px;border:1px solid #F8B861;background:linear-gradient(0deg,#f8b86152 0% 100%),#fff;margin:2px 4px 2px 0;font-size:12px}.functional-pill{display:flex;padding:2px 6px;justify-content:center;align-items:center;gap:4px;border-radius:16px;border:1px solid #E24577;background:linear-gradient(0deg,#e245773d 0% 100%),#fff;margin:2px 4px 2px 0;font-size:12px}.domain-pill{display:flex;padding:2px 6px;justify-content:center;align-items:center;gap:4px;border-radius:16px;border:1px solid #7B47A4;background:linear-gradient(0deg,#7b47a43d 0% 100%),#fff;margin:2px 4px 2px 0;font-size:12px}.popup-header{display:flex;flex-direction:row;justify-content:space-between}.popup-footer{display:flex;flex-direction:row;justify-content:end}.view-cbp-plan{margin:10px;padding:10px}.view-cbp-plan-popup{padding:24px;max-height:70vh;overflow-y:auto}.section{border-radius:8px;background:#1b4ca114;padding:16px}.popup-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #ddd;font-weight:700;flex-shrink:0}.popup-footer{display:flex;justify-content:flex-end;gap:16px;padding:16px 24px;border-top:1px solid #ddd;background-color:#fff;flex-shrink:0;position:sticky;bottom:0}.section-container{overflow-y:auto;flex:1 1 auto}.competency-list{display:flex;flex-direction:row;gap:0px;flex-wrap:wrap;margin:0;padding:0;list-style:none}.competency-text{color:#000;font-family:Lato;font-size:12px;font-style:normal;font-weight:400;line-height:normal;padding:3px 6px}.competency-text-behavioral{color:#654321;font-family:Lato;font-size:14px;font-style:normal;line-height:normal;font-weight:550}.competency-text-functional{color:#b01669;font-family:Lato;font-size:14px;font-style:normal;line-height:normal;font-weight:550}.competency-text-domain{color:#301934;font-family:Lato;font-size:14px;font-style:normal;line-height:normal;font-weight:550}.competency-sub-heading{color:#1b4ca1;font-family:Montserrat;font-size:14px;font-style:normal;font-weight:600;line-height:normal}.cursor-pointer{cursor:pointer}.btn-active{border-radius:var(--Radius-Full-Round, 9999999px);opacity:1;background:var(--Primary-KB-Primary-Light, #1B4CA1);color:var(--white-kb-white-100, #FFF);text-align:center;font-family:Lato;font-size:14px;font-style:normal;font-weight:700;line-height:normal;display:flex;height:32px;padding:0 16px;justify-content:center;align-items:center;gap:8px;border:none}.custom-textarea{color:#000;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal}.overlay-loader{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#ffffffbf;z-index:9999;display:flex;justify-content:center;align-items:center}.competencis-grid{display:flex;flex-direction:row;justify-content:space-between;gap:16px}.grid-list-item-behavioral div{border-left:2px solid darkorange}.grid-list-item-functional div{border-left:2px solid #ff1493}.grid-list-item-domain div{border-left:2px solid #6b21a8}.competencies-grid-3{width:33%}.bg-blue-50{background-color:#fde8cc;border-radius:4px}.bg-green-50{background-color:#f8d2de;border-radius:4px}.bg-purple-50{background-color:#dfd3e9;border-radius:4px}.grid-list-item div{padding:5px 10px;margin:10px 0}.course-pill-container{display:flex;gap:8px}.relevancy-pill-green{display:flex;padding:4px 8px;align-items:center;gap:4px;border-radius:16px;border:1px solid #e0e0e0;background:#f8f9fa}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.show-more-competency{display:inline-flex;align-items:center}.show-more-link{color:#1b4ca1;font-family:Lato;font-size:12px;font-style:normal;font-weight:500;line-height:normal;margin:2px 4px 2px 0;text-decoration:none}.show-more-link:hover{text-decoration:underline}.course-content{flex:1;display:flex;flex-direction:column}.course-footer{margin-top:auto;padding-top:12px;display:flex;justify-content:space-between}::ng-deep .mdc-tab__text-label{font-weight:700;font-family:Montserrat!important;font-size:16px;color:#000!important;text-transform:capitalize}.competency-tag{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;margin-right:.5rem;margin-bottom:.5rem}.menu-list-item.active{background-color:#1b4ca1;color:#fff}.menu-list-item:hover{background-color:#1b4ca1;color:#fff;border-color:#1b4ca1}.gray-bg{background-color:rgb(248,250,252,var(--tw-bg-opacity, 1));border-radius:8px;border:1px solid #ccc}.div-count{font-family:Lato;font-size:20px;font-weight:700}.green-bg{background-color:#0080001c;border:1px solid #006400;border-radius:8px}.div-green-count{font-family:Lato;font-size:20px;font-weight:700;color:#006400}.div-green-label{color:#006400;font-family:Montserrat;font-size:16px;font-style:normal;font-weight:600;line-height:normal}.gray-bg-item{background-color:rgb(248,250,252,var(--tw-bg-opacity, 1));border-radius:8px;border:1px solid #ccc;padding:4px 8px;margin:10px}.add-btn{color:#1b4ca1;font-size:14px;font-family:Lato}.list-flex{display:flex;flex-direction:row;justify-content:space-between}.all-category-list .mat-icon{vertical-align:middle}.course-list-container-flex{display:flex;align-items:flex-start;gap:2rem}.left-panel{flex:0 0 250px;font-weight:700;text-align:left}.right-panel{flex:1;display:flex;flex-direction:row;flex-wrap:wrap;gap:20px;align-content:flex-start;justify-content:flex-start}.category-list-item{font-weight:400;font-size:16px;font-family:Lato;padding:5px}.right-panel-flex{display:flex;flex:0 0 100%;width:100%;flex-direction:row;flex-wrap:wrap;gap:20px;justify-content:flex-start}.course-list-container-right-flex{display:flex}.no-gaps-message{display:flex;flex-direction:column;align-items:center;padding:24px;background:linear-gradient(135deg,#4caf501a,#81c7841a);border:2px solid #4CAF50;border-radius:16px;margin:16px 0}.no-gaps-message .success-icon{font-size:25px;color:#4caf50;margin-bottom:16px}.no-gaps-message h4{color:#2e7d32;font-family:Montserrat;font-size:20px;font-weight:600;margin:0 0 8px;text-align:center}.no-gaps-message p{color:#388e3c;font-family:Lato;font-size:14px;font-weight:400;margin:0;text-align:center;line-height:1.5}.section-header-improved{display:flex;flex-direction:column;gap:16px}.search-and-buttons-container{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.search-container-compact{flex:0 0 auto;min-width:280px}.search-container-compact .rsearch{position:relative;display:flex;align-items:center}.search-container-compact .search-icon{position:absolute;left:12px;color:#666;font-size:20px;z-index:1}.search-container-compact .sinput-compact{border-radius:25px;border:1px solid #d5d0d0;padding:8px 12px 8px 40px;height:32px;width:100%;font:400 14px Lato;box-sizing:border-box;transition:border-color .3s ease}.search-container-compact .sinput-compact:focus{outline:none;border-color:#1b4ca1;box-shadow:0 0 0 2px #1b4ca11a}.search-container-compact .sinput-compact::placeholder{color:#999}.btn-group-compact{display:flex;gap:8px;flex:0 0 auto}.category-list-item{padding:8px 12px!important;border-radius:6px;border:1px solid transparent;transition:all .3s ease;background:#f8f9fa;color:#333;font-family:Lato;font-size:14px!important;font-weight:400!important}.category-list-item:hover{background:#1b4ca10d;border-color:#1b4ca133}.category-list-item.selected-theme{background:#1b4ca11a;border-color:#1b4ca1;color:#1b4ca1;font-weight:600!important}.category-list-item.selected-theme:before{content:\"\\2713 \";color:#1b4ca1;font-weight:700}.theme-filter-controls{margin-bottom:8px}.clear-filter-btn{background:#f8f9fa;border:1px solid #ddd;border-radius:20px;padding:4px 12px;font-size:12px;color:#666;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:4px}.clear-filter-btn:hover{background:#e9ecef;border-color:#adb5bd}.clear-filter-btn mat-icon{font-size:16px;width:16px;height:16px}.no-course-found-container{display:flex;justify-content:center;align-items:center;min-height:300px;padding:20px}.no-course-card{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:2px dashed #ced4da;border-radius:16px;padding:40px;text-align:center;max-width:500px;box-shadow:0 4px 12px #0000000d}.no-course-card .no-course-icon{margin-bottom:20px}.no-course-card .no-course-icon mat-icon{font-size:48px;width:48px;height:48px;color:#6c757d}.no-course-card .no-course-content h4{color:#495057;font-family:Montserrat;font-size:24px;font-weight:600;margin-bottom:12px}.no-course-card .no-course-content p{color:#6c757d;font-family:Lato;font-size:16px;line-height:1.5;margin-bottom:12px}.no-course-card .no-course-content p strong{color:#1b4ca1;font-weight:600}.no-course-card .suggest-course-btn{background:linear-gradient(135deg,#1b4ca1,#164080);color:#fff;border:none;border-radius:25px;padding:12px 24px;font-family:Lato;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;margin:20px auto 0;transition:all .3s ease;box-shadow:0 4px 12px #1b4ca14d}.no-course-card .suggest-course-btn:hover{background:linear-gradient(135deg,#164080,#0f2f5f);transform:translateY(-2px);box-shadow:0 6px 16px #1b4ca166}.no-course-card .suggest-course-btn:active{transform:translateY(0)}.no-course-card .suggest-course-btn mat-icon{font-size:18px;width:18px;height:18px}.left-panel{flex:0 0 280px!important;background:#f8f9fa;border-radius:12px;padding:16px;border:1px solid #e9ecef;max-height:600px;overflow-y:auto;font-weight:400!important}@media (max-width: 1200px){.search-and-buttons-container{flex-direction:column;align-items:stretch}.search-container-compact{min-width:auto;width:100%}.btn-group-compact{justify-content:center;flex-wrap:wrap}}@media (max-width: 1200px) and (min-width: 769px){.course-list-item{flex:1 1 calc(50% - 10px);min-width:300px;max-width:none}}@media (max-width: 768px){.course-list-container-flex{flex-direction:column}.left-panel{flex:none!important;max-height:300px}.course-list-item{flex:0 0 100%;max-width:100%}.no-course-card{padding:20px}.no-course-card .no-course-content h4{font-size:20px}.no-course-card .no-course-content p{font-size:14px}}::ng-deep .error-snackbar{background-color:#f44336!important;color:#fff!important;font-weight:500}::ng-deep .error-snackbar .mat-simple-snackbar-action{color:#fff!important}::ng-deep .session-expired-snackbar{background-color:#ff9800!important;color:#fff!important;font-weight:600}::ng-deep .session-expired-snackbar .mat-simple-snackbar-action{color:#fff!important;font-weight:700}.download-pdf{justify-content:end;display:flex;flex-direction:row}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i6.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "directive", type: i7.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }] }); }
|
|
386
|
+
}
|
|
387
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ViewCourseRecommendationComponent, decorators: [{
|
|
388
|
+
type: Component,
|
|
389
|
+
args: [{ selector: 'app-view-course-recommendation', template: "<div class=\"view-cbp-plan\">\n <div class=\"popup-container\">\n <div class=\"popup-header\">\n <div>\n <div class=\"heading\">View Course Recommendation</div>\n </div>\n <div class=\"cursor-pointer\" (click)=\"closeDialog()\">\n <mat-icon>close</mat-icon>\n </div>\n </div>\n </div>\n <div class=\"section-container mt-2\" #pdfContent>\n <div class=\"ministry-heading mt-2\">\n <span *ngIf=\"!cbpPlanData?.department_name\">{{cbpPlanData?.ministry.orgName}}</span> \n <span *ngIf=\"cbpPlanData?.department_name\">{{cbpPlanData?.department_name}}</span> \n <span *ngIf=\"planData?.designation_name\"> / {{planData?.designation_name}}</span>\n </div>\n <div class=\"competency-container mt-4\">\n <div class=\"outside-layer-total\">\n <div class=\"inside-layer\">\n Total Courses\n </div>\n <div class=\"count\">\n {{competenciesCount?.total}}\n </div>\n </div>\n <div class=\"outside-layer-total\">\n <div class=\"inside-layer\">\n iGOT Platform Courses\n </div>\n <div class=\"count\">\n {{competenciesCount?.igot}}\n </div>\n </div>\n <div class=\"outside-layer-total\">\n <div class=\"inside-layer\">\n Public Courses\n </div>\n <div class=\"count\">\n {{competenciesCount?.public_courses}}\n \n </div>\n </div>\n \n </div>\n <div class=\"my-4\">\n \n <div class=\"course-list-container\">\n <div class=\"course-list-item\" *ngFor=\"let item of filterdCourses;let i=index\">\n <div class=\"course-header\">\n <div class=\"checked-course-container\">\n \n <div>\n <div class=\"course-pill\">\n <div class=\"course-pill-text\">\n <span><img src=\"assets/icons/course.svg\"></span> <span>Course</span>\n </div>\n </div>\n </div>\n\n </div>\n\n <!-- <div>\n <div class=\"ai-recommened-pill\">\n <div class=\"ai-recommened-pill-text\">\n <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span>\n <span>AI Recommended</span>\n\n </div>\n </div>\n </div> -->\n <div *ngIf=\"item?.rationale && !item?.is_public\">\n <div class=\"ai-recommened-pill-green\">\n <div class=\"ai-recommened-pill-green-text\">\n <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span>\n \n <span >AI Recommended - iGOT </span>\n\n </div>\n </div>\n <div class=\"ai-recommened-pill-orange mt-2\" *ngIf=\"item?.platform\">\n <div class=\"ai-recommened-pill-orange-text\">\n <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span>\n <a class=\"cursor-pointer\" [href]=\"item?.public_link\" target=\"_blank\"><span>Platform - {{item?.platform}}</span></a>\n </div> \n </div>\n <div class=\"ai-recommened-pill-orange mt-2\" *ngIf=\"item?.organisation?.length\">\n <div class=\"ai-recommened-pill-orange-text\">\n <span class=\"ai-loader-icon\"><img\n src=\"assets/icons/ai-loader.gif\"></span>\n <span>Provider - {{item?.organisation[0]}}</span>\n </div>\n </div>\n </div>\n <div *ngIf=\"item?.rationale && item?.is_public\">\n <div class=\"ai-recommened-pill-public\">\n <div class=\"ai-recommened-pill-public-text\">\n <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span>\n \n <span >AI Recommended - Public </span>\n\n </div>\n </div>\n <div class=\"ai-recommened-pill-orange mt-2\" *ngIf=\"item?.platform\">\n <div class=\"ai-recommened-pill-orange-text\">\n <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span>\n <a class=\"cursor-pointer\" [href]=\"item?.public_link\" target=\"_blank\"><span>Platform - {{item?.platform}}</span></a>\n </div> \n </div>\n <div class=\"ai-recommened-pill-orange mt-2\" *ngIf=\"item?.organisation?.length\">\n <div class=\"ai-recommened-pill-orange-text\">\n <span class=\"ai-loader-icon\"><img\n src=\"assets/icons/ai-loader.gif\"></span>\n <span>Provider - {{item?.organisation[0]}}</span>\n </div>\n </div>\n </div>\n <div *ngIf=\"!item?.rationale\">\n <div class=\"ai-recommened-pill-gray\">\n <div class=\"ai-recommened-pill-gray-text\">\n <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span>\n \n <span>Manually Suggested - iGOT </span>\n\n </div>\n </div>\n <div class=\"ai-recommened-pill-orange mt-2\" *ngIf=\"item?.platform\">\n <div class=\"ai-recommened-pill-orange-text\">\n <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span>\n <a class=\"cursor-pointer\" [href]=\"item?.public_link\" target=\"_blank\"><span>Platform - {{item?.platform}}</span></a>\n </div> \n </div>\n <div class=\"ai-recommened-pill-orange mt-2\" *ngIf=\"item?.organisation?.length\">\n <div class=\"ai-recommened-pill-orange-text\">\n <span class=\"ai-loader-icon\"><img\n src=\"assets/icons/ai-loader.gif\"></span>\n <span>Provider - {{item?.organisation[0]}}</span>\n </div>\n </div>\n </div>\n </div>\n <div class=\"course-title mt-4\">\n <div>\n <div *ngIf=\"item?.course\">{{item?.course}}</div>\n <!-- <div *ngIf=\"item?.name\">{{item?.name}}</div> -->\n </div>\n </div>\n <div class=\"course-desc mt-2\">\n <div *ngIf=\"isPDFDownload\">\n <div>{{item?.rationale}}</div>\n </div>\n </div>\n <div class=\"mt-3\" *ngIf=\"getCompetenciesByType('Behavioural',i)?.length\">\n <div class=\"competency-sub-heading\">Behavioral Competencies</div>\n <ul class=\"competency-list mt-1\">\n <li class=\"behavioural-pill\"\n *ngFor=\"let comp of getDisplayedCompetencies('Behavioural',i)\">\n <span class=\"competency-text\"> {{ comp.competencyThemeName }} -\n {{\n comp.competencySubThemeName }} </span>\n </li>\n <li *ngIf=\"hasMoreThanTwo('Behavioural',i)\"\n class=\"show-more-competency\">\n <span class=\"show-more-link cursor-pointer\"\n (click)=\"toggleCompetencies('Behavioural',i)\">\n {{ isExpanded('Behavioural',i) ? 'Show Less' : '+' +\n getRemainingCount('Behavioural',i) + ' More' }}\n </span>\n </li>\n </ul>\n </div>\n <div class=\"mt-2\" *ngIf=\"getCompetenciesByType('Functional',i)?.length\">\n <div class=\"competency-sub-heading\">Functional Competencies</div>\n <ul class=\"competency-list mt-1\">\n <li class=\"functional-pill\"\n *ngFor=\"let comp of getDisplayedCompetencies('Functional',i)\">\n <span class=\"competency-text\"> {{ comp.competencyThemeName }} -\n {{\n comp.competencySubThemeName }} </span>\n </li>\n <li *ngIf=\"hasMoreThanTwo('Functional',i)\"\n class=\"show-more-competency\">\n <span class=\"show-more-link cursor-pointer\"\n (click)=\"toggleCompetencies('Functional',i)\">\n {{ isExpanded('Functional',i) ? 'Show Less' : '+' +\n getRemainingCount('Functional',i) + ' More' }}\n </span>\n </li>\n </ul>\n </div>\n <div class=\"mt-2\" *ngIf=\"getCompetenciesByType('Domain',i)?.length\">\n <div class=\"competency-sub-heading\">Domain Competencies</div>\n <ul class=\"competency-list mt-1\">\n <li class=\"domain-pill\"\n *ngFor=\"let comp of getDisplayedCompetencies('Domain',i)\">\n <span class=\"competency-text\"> {{ comp.competencyThemeName }} -\n {{\n comp.competencySubThemeName }} </span>\n </li>\n <li *ngIf=\"hasMoreThanTwo('Domain',i)\" class=\"show-more-competency\">\n <span class=\"show-more-link cursor-pointer\"\n (click)=\"toggleCompetencies('Domain',i)\">\n {{ isExpanded('Domain',i) ? 'Show Less' : '+' +\n getRemainingCount('Domain',i) + ' More' }}\n </span>\n </li>\n </ul>\n </div>\n <div class=\"mt-2 d-flex justify-content-between item\">\n <div class=\"relevancy-container\">\n <div class=\"relevancy\">Relevancy</div>\n <div class=\"dash\">-</div>\n <div class=\"percentage\" *ngIf=\"item?.relevancy\">{{item?.relevancy}}%</div>\n <div class=\"percentage\" *ngIf=\"!item?.relevancy\">N/A</div>\n </div>\n <div class=\"delete-button\">\n <mat-icon matTooltip=\"Delete Course\" matTooltipPosition=\"above\" class=\"text-danger cursor-pointer\" (click)=\"deleteCard(item, i)\" >delete</mat-icon>\n </div>\n </div>\n <!-- <div>\n <div class=\"competencies-matched-container\">\n <div class=\"competencies-matched\">Competencies Matched</div>\n <div class=\"dash\">-</div>\n <div class=\"percentage\">80%</div>\n </div>\n </div> -->\n </div>\n <!-- <div class=\"course-list-item\">\n <div class=\"course-header\">\n <div>\n <div class=\"course-pill\">\n <div class=\"course-pill-text\">Course</div>\n </div>\n </div>\n <div>\n <div class=\"ai-recommened-pill\">\n <div class=\"ai-recommened-pill-text\">\n <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span>\n <span>AI Recommended</span>\n\n </div>\n </div>\n </div>\n </div>\n <div class=\"course-title\">\n <div>\n <div>Maternal, Infant And Young Child Nutrition</div>\n </div>\n </div>\n <div class=\"course-desc\">\n <div>\n <div>This Course directly addresses a primary responsibility of Anganwandi Care takers,\n which is\n to provide and educate on nutrition for mother and young children</div>\n </div>\n </div>\n <div>\n <div class=\"relevancy-container\">\n <div class=\"relevancy\">Relevancy</div>\n <div class=\"dash\">-</div>\n <div class=\"percentage\">90%</div>\n </div>\n </div>\n <div>\n <div class=\"competencies-matched-container\">\n <div class=\"competencies-matched\">Competencies Matched</div>\n <div class=\"dash\">-</div>\n <div class=\"percentage\">80%</div>\n </div>\n </div>\n </div> -->\n\n </div>\n </div>\n </div>\n <div class=\"popup-footer\" *ngIf=\"filterdCourses?.length\">\n <div>\n <input class=\"btn-active\" type=\"button\" value=\"Download\" (click)=\"downloadPdfFromBE()\"/>\n </div>\n <!-- <div>\n <input class=\"btn-active\" type=\"button\" value=\"Add Personalisation\" (click)=\"addPersonilisation()\"/>\n </div> -->\n <!-- <div>\n <input class=\"btn-active\" type=\"button\" value=\"Add More Courses\" (click)=\"addMoreCourses()\"/>\n </div> -->\n </div>\n</div>\n<div class=\"overlay-loader\" *ngIf=\"loading\">\n <mat-spinner diameter=\"50\"></mat-spinner>\n</div>", styles: ["@charset \"UTF-8\";.container{margin:10px auto}.sub-heading p{color:#000;font-family:Montserrat;font-size:16px;font-style:normal;font-weight:600;line-height:normal}.ministry-heading{color:#1b4ca1;font-family:Montserrat;font-size:20px;font-style:normal;font-weight:600;line-height:normal}.radio-label{color:#000;font-family:Lato;font-size:16px;font-style:normal;font-weight:400;line-height:normal}.radio-btn-group{display:flex;width:32px;height:32px;padding:2px;gap:10px}.label{color:var(--Body-Text-Body-Color, #212529);font-family:Lato;font-size:16px;font-style:normal;font-weight:700;line-height:150%}::ng-deep mat-form-field{background-color:#fff!important;border-radius:25px!important;padding-left:12px;padding-right:12px;height:42px;width:100%}::ng-deep mat-select{border-radius:25px!important;background-color:#fff!important}::ng-deep .mat-select-panel{background-color:#fff!important}::ng-deep .mat-select-panel .mat-option{border-radius:0!important}::ng-deep mat-form-field .mat-form-field-underline{display:none!important}::ng-deep mat-select .mat-select-placeholder{color:#0006;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal}::ng-deep mat-select .mat-select-value-text{color:#000;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal;line-height:normal!important;padding-top:0!important;padding-bottom:0!important}::ng-deep mat-select .mat-select-value{display:flex!important;align-items:center!important;height:100%!important}.additional-details textarea{display:flex;padding:16px 16px 0;flex-direction:column;align-items:flex-start;gap:10px;flex:1 0 0;align-self:stretch;width:100%;color:#000;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal;resize:none}.section-header{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.btn-disable{border-radius:var(--Radius-Full-Round, 9999999px);opacity:.4;background:var(--Primary-KB-Primary-Light, #1B4CA1);color:var(--white-kb-white-100, #FFF);text-align:center;font-family:Lato;font-size:14px;font-style:normal;font-weight:700;line-height:normal;display:flex;height:32px;padding:0 16px;justify-content:center;align-items:center;gap:8px;border:none}.btn-group{display:flex;flex-direction:row;justify-content:space-between}.pl-2{padding-left:5px}.search-filter-section{display:flex;flex-direction:row;justify-content:space-between}.search .rsearch{position:relative}.search .search-icon{position:absolute;top:15px;font-size:20px;left:10px}.search .sinput{border-radius:32px;border:1px solid #d5d0d0;padding:15px 36px;font:400 14px Lato;width:800px}.select-map-route-container{display:flex;flex-direction:row}.selected-mapping-route p{color:#1b4ca1;font-family:Lato;font-size:20px;font-style:normal;font-weight:400;line-height:normal;text-decoration-line:underline;text-decoration-style:solid;-webkit-text-decoration-skip:ink;text-decoration-skip-ink:auto;text-decoration-thickness:auto;text-underline-offset:auto;text-underline-position:from-font}.edit-plan{display:flex;padding:4px;justify-content:center;align-items:center;gap:8px;border-radius:4px;background:#1b4ca129;color:#1b4ca1;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal;margin-left:10px}.search-container{display:flex;flex-direction:row}.course-container{display:flex;width:100%;padding:16px;flex-direction:column;align-items:flex-start;gap:24px;grid-row:2/span 1;grid-column:1/span 1;border-radius:12px;border:1px solid var(--borders-black-border-16-black, rgba(0, 0, 0, .16));background:#fff}.course-header{display:flex;flex-direction:row;justify-content:space-between;width:100%}.course-pill{display:flex;height:24px;padding:8px;align-items:center;gap:4px;border-radius:16px;border:1px solid var(--borders-border-fill-focussed-4-light-100, #EF951E);background:#fefaf4}.ai-recommened-pill-green{display:flex;padding:4px 8px;align-items:center;gap:8px;border-radius:var(--Radius-4, 4px);background:#0080001c}.ai-recommened-pill-green-text{color:#006400;font-family:Lato;font-size:11px;font-style:normal;font-weight:600;line-height:normal}.ai-recommened-pill-public{display:flex;padding:4px 8px;align-items:center;gap:8px;border-radius:var(--Radius-4, 4px);background:#1b4ca129}.ai-recommened-pill-public-text{color:#1b4ca1;font-family:Lato;font-size:11px;font-style:normal;font-weight:600;line-height:normal}.ai-recommened-pill-gray{display:flex;padding:4px 8px;align-items:center;gap:8px;border-radius:var(--Radius-4, 4px);background:#d3d3d3}.ai-recommened-pill-gray-text{color:#000;font-family:Lato;font-size:11px;font-style:normal;font-weight:600;line-height:normal}.ai-recommened-pill-orange{display:flex;padding:4px 8px;align-items:center;gap:8px;border-radius:var(--Radius-4, 4px);background:#ffa50052}.ai-recommened-pill-orange-text{color:#5a3f0d;font-family:Lato;font-size:11px;font-style:normal;font-weight:600;line-height:normal}.ai-recommened-pill-orange-text a{color:#5a3f0d!important;font-family:Lato;font-size:11px;font-style:normal;font-weight:600;line-height:normal}.igot-platform-pill{display:flex;padding:4px 8px;align-items:center;gap:8px;border-radius:var(--Radius-4, 4px);border:1px solid #EF951E;background:#ef951e29}.course-title{color:var(--Primary-KB-Primary-Light, #1B4CA1);font-family:Montserrat;font-size:16px;font-style:normal;font-weight:600;line-height:22px}.course-desc{color:#0009;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.relevancy,.competencies-matched{color:#6c757d;font-family:Lato;font-size:12px;font-style:normal;font-weight:500;line-height:normal;align-items:center}.percentage{color:#1b4ca1;font-family:Lato;font-size:14px;font-style:normal;font-weight:600;line-height:normal}.delete-button input{background-color:#b60a0a;border-radius:10px}.relevancy-container,.competencies-matched-container{display:flex;flex-direction:row;align-items:center}.dash{padding:0 5px}::ng-deep .mat-radio-checked .mat-radio-inner-circle{background:#1b4ca1!important}.course-list-container{display:flex;flex-wrap:wrap;gap:16px;width:100%;padding:1rem}.course-list-item{flex:1 1 calc(50% - 10px);min-width:350px;max-width:500px;box-sizing:border-box;border:1px solid #e0e0e0;padding:16px;background-color:#fff;border-radius:12px;min-height:auto;box-shadow:0 2px 4px #0000001a;transition:box-shadow .2s ease;display:flex;flex-direction:column}.course-list-item:hover{box-shadow:0 4px 8px #00000026}.course-list-item:only-child{flex:1 1 auto;max-width:800px}.checked-course-container{display:flex;width:60%}.ml-2{margin-left:8px}::ng-deep .mat-checkbox-checked .mat-checkbox-background{background:#1b4ca1!important}.igot-platform-pill-text{color:#1b4ca1;font-family:Lato;font-size:12px;font-style:normal;font-weight:700;line-height:normal}.course-pill-text{color:var(--accessbility-shades-without-opacity-kb-greys-black-87, #212121);text-align:center;font-family:Poppins;font-size:12px;font-style:normal;font-weight:400;line-height:normal}.ai-loader-icon img,.igot-platform-icon img{width:15.714px;height:15.714px;flex-shrink:0}.competency-container{display:flex;justify-content:normal;gap:16px;flex-direction:row}.outside-layer-total{display:flex;padding:4px 12px;justify-content:center;align-items:center;gap:16px;border-radius:12px 4px 4px 12px;border-left:2px solid #1B4CA1;background:#edf1f8;width:132px}.outside-layer-functional{display:flex;padding:4px 12px;justify-content:center;align-items:center;gap:16px;border-radius:12px 4px 4px 12px;border-left:2px solid #E24577;background:#f8d2de;width:132px}.outside-layer-domain{display:flex;padding:4px 12px;justify-content:center;align-items:center;gap:16px;border-radius:12px 4px 4px 12px;border-left:2px solid #7B47A4;background:#dfd3e9;width:132px}.outside-layer-behavioral{display:flex;padding:4px 12px;justify-content:center;align-items:center;gap:16px;border-radius:12px 4px 4px 12px;border-left:2px solid #F8B861;background:#fde8cc;width:132px}.inside-layer{color:#1b4ca1;font-family:Lato;font-size:16px;font-style:normal;font-weight:400;line-height:normal}.count{color:#1b4ca1;font-family:Montserrat;font-size:18px;font-style:normal;font-weight:600;line-height:normal}.suggest-courses-header{display:flex;flex-direction:row;justify-content:space-between}.suggest-course-control{display:flex;flex-direction:row}.course-card-container{width:172px;border-radius:3.307px;border:.827px solid var(--borders-border-8-black, rgba(0, 0, 0, .08));background-color:#fff}.highlight-ai{font-family:Montserrat;font-size:24px;font-style:normal;font-weight:600;line-height:normal;background:linear-gradient(90deg,#3b27ff,#2de3d6);background-clip:text;-webkit-background-clip:text;color:transparent;-webkit-text-fill-color:transparent;display:inline-block}.ai-loader-icon-medium img{width:40px;height:40px;flex-shrink:0}.heading{color:#000;font-family:Montserrat;font-size:16px;font-style:normal;font-weight:600;line-height:normal;margin:10px 0}.pdf-heading{color:#000;font-family:Montserrat;font-size:18px;font-style:normal;font-weight:600;line-height:normal;margin:10px 0;text-align:center}.popup-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid #e0e0e0}.header-left{flex:1}.header-actions{display:flex;align-items:center;gap:12px}.regenerate-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;min-width:auto}.regenerate-btn .mat-icon{margin:0;font-size:18px;width:18px;height:18px}.regenerate-btn .mat-spinner{margin:0}.regenerate-btn:disabled{opacity:.7;cursor:not-allowed}.close-btn{padding:8px;border-radius:4px;transition:background-color .2s ease}.close-btn:hover{background-color:#f5f5f5}.close-btn .mat-icon{font-size:20px;width:20px;height:20px}.progress-popup{display:flex;flex-direction:column;justify-content:center;align-items:center}.progress-popup .desc{color:#000000de;text-align:center;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal}.behavioural-pill{display:flex;padding:2px 6px;justify-content:center;align-items:center;gap:4px;border-radius:16px;border:1px solid #F8B861;background:linear-gradient(0deg,#f8b86152 0% 100%),#fff;margin:2px 4px 2px 0;font-size:12px}.functional-pill{display:flex;padding:2px 6px;justify-content:center;align-items:center;gap:4px;border-radius:16px;border:1px solid #E24577;background:linear-gradient(0deg,#e245773d 0% 100%),#fff;margin:2px 4px 2px 0;font-size:12px}.domain-pill{display:flex;padding:2px 6px;justify-content:center;align-items:center;gap:4px;border-radius:16px;border:1px solid #7B47A4;background:linear-gradient(0deg,#7b47a43d 0% 100%),#fff;margin:2px 4px 2px 0;font-size:12px}.popup-header{display:flex;flex-direction:row;justify-content:space-between}.popup-footer{display:flex;flex-direction:row;justify-content:end}.view-cbp-plan{margin:10px;padding:10px}.view-cbp-plan-popup{padding:24px;max-height:70vh;overflow-y:auto}.section{border-radius:8px;background:#1b4ca114;padding:16px}.popup-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #ddd;font-weight:700;flex-shrink:0}.popup-footer{display:flex;justify-content:flex-end;gap:16px;padding:16px 24px;border-top:1px solid #ddd;background-color:#fff;flex-shrink:0;position:sticky;bottom:0}.section-container{overflow-y:auto;flex:1 1 auto}.competency-list{display:flex;flex-direction:row;gap:0px;flex-wrap:wrap;margin:0;padding:0;list-style:none}.competency-text{color:#000;font-family:Lato;font-size:12px;font-style:normal;font-weight:400;line-height:normal;padding:3px 6px}.competency-text-behavioral{color:#654321;font-family:Lato;font-size:14px;font-style:normal;line-height:normal;font-weight:550}.competency-text-functional{color:#b01669;font-family:Lato;font-size:14px;font-style:normal;line-height:normal;font-weight:550}.competency-text-domain{color:#301934;font-family:Lato;font-size:14px;font-style:normal;line-height:normal;font-weight:550}.competency-sub-heading{color:#1b4ca1;font-family:Montserrat;font-size:14px;font-style:normal;font-weight:600;line-height:normal}.cursor-pointer{cursor:pointer}.btn-active{border-radius:var(--Radius-Full-Round, 9999999px);opacity:1;background:var(--Primary-KB-Primary-Light, #1B4CA1);color:var(--white-kb-white-100, #FFF);text-align:center;font-family:Lato;font-size:14px;font-style:normal;font-weight:700;line-height:normal;display:flex;height:32px;padding:0 16px;justify-content:center;align-items:center;gap:8px;border:none}.custom-textarea{color:#000;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal}.overlay-loader{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#ffffffbf;z-index:9999;display:flex;justify-content:center;align-items:center}.competencis-grid{display:flex;flex-direction:row;justify-content:space-between;gap:16px}.grid-list-item-behavioral div{border-left:2px solid darkorange}.grid-list-item-functional div{border-left:2px solid #ff1493}.grid-list-item-domain div{border-left:2px solid #6b21a8}.competencies-grid-3{width:33%}.bg-blue-50{background-color:#fde8cc;border-radius:4px}.bg-green-50{background-color:#f8d2de;border-radius:4px}.bg-purple-50{background-color:#dfd3e9;border-radius:4px}.grid-list-item div{padding:5px 10px;margin:10px 0}.course-pill-container{display:flex;gap:8px}.relevancy-pill-green{display:flex;padding:4px 8px;align-items:center;gap:4px;border-radius:16px;border:1px solid #e0e0e0;background:#f8f9fa}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.show-more-competency{display:inline-flex;align-items:center}.show-more-link{color:#1b4ca1;font-family:Lato;font-size:12px;font-style:normal;font-weight:500;line-height:normal;margin:2px 4px 2px 0;text-decoration:none}.show-more-link:hover{text-decoration:underline}.course-content{flex:1;display:flex;flex-direction:column}.course-footer{margin-top:auto;padding-top:12px;display:flex;justify-content:space-between}::ng-deep .mdc-tab__text-label{font-weight:700;font-family:Montserrat!important;font-size:16px;color:#000!important;text-transform:capitalize}.competency-tag{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;margin-right:.5rem;margin-bottom:.5rem}.menu-list-item.active{background-color:#1b4ca1;color:#fff}.menu-list-item:hover{background-color:#1b4ca1;color:#fff;border-color:#1b4ca1}.gray-bg{background-color:rgb(248,250,252,var(--tw-bg-opacity, 1));border-radius:8px;border:1px solid #ccc}.div-count{font-family:Lato;font-size:20px;font-weight:700}.green-bg{background-color:#0080001c;border:1px solid #006400;border-radius:8px}.div-green-count{font-family:Lato;font-size:20px;font-weight:700;color:#006400}.div-green-label{color:#006400;font-family:Montserrat;font-size:16px;font-style:normal;font-weight:600;line-height:normal}.gray-bg-item{background-color:rgb(248,250,252,var(--tw-bg-opacity, 1));border-radius:8px;border:1px solid #ccc;padding:4px 8px;margin:10px}.add-btn{color:#1b4ca1;font-size:14px;font-family:Lato}.list-flex{display:flex;flex-direction:row;justify-content:space-between}.all-category-list .mat-icon{vertical-align:middle}.course-list-container-flex{display:flex;align-items:flex-start;gap:2rem}.left-panel{flex:0 0 250px;font-weight:700;text-align:left}.right-panel{flex:1;display:flex;flex-direction:row;flex-wrap:wrap;gap:20px;align-content:flex-start;justify-content:flex-start}.category-list-item{font-weight:400;font-size:16px;font-family:Lato;padding:5px}.right-panel-flex{display:flex;flex:0 0 100%;width:100%;flex-direction:row;flex-wrap:wrap;gap:20px;justify-content:flex-start}.course-list-container-right-flex{display:flex}.no-gaps-message{display:flex;flex-direction:column;align-items:center;padding:24px;background:linear-gradient(135deg,#4caf501a,#81c7841a);border:2px solid #4CAF50;border-radius:16px;margin:16px 0}.no-gaps-message .success-icon{font-size:25px;color:#4caf50;margin-bottom:16px}.no-gaps-message h4{color:#2e7d32;font-family:Montserrat;font-size:20px;font-weight:600;margin:0 0 8px;text-align:center}.no-gaps-message p{color:#388e3c;font-family:Lato;font-size:14px;font-weight:400;margin:0;text-align:center;line-height:1.5}.section-header-improved{display:flex;flex-direction:column;gap:16px}.search-and-buttons-container{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.search-container-compact{flex:0 0 auto;min-width:280px}.search-container-compact .rsearch{position:relative;display:flex;align-items:center}.search-container-compact .search-icon{position:absolute;left:12px;color:#666;font-size:20px;z-index:1}.search-container-compact .sinput-compact{border-radius:25px;border:1px solid #d5d0d0;padding:8px 12px 8px 40px;height:32px;width:100%;font:400 14px Lato;box-sizing:border-box;transition:border-color .3s ease}.search-container-compact .sinput-compact:focus{outline:none;border-color:#1b4ca1;box-shadow:0 0 0 2px #1b4ca11a}.search-container-compact .sinput-compact::placeholder{color:#999}.btn-group-compact{display:flex;gap:8px;flex:0 0 auto}.category-list-item{padding:8px 12px!important;border-radius:6px;border:1px solid transparent;transition:all .3s ease;background:#f8f9fa;color:#333;font-family:Lato;font-size:14px!important;font-weight:400!important}.category-list-item:hover{background:#1b4ca10d;border-color:#1b4ca133}.category-list-item.selected-theme{background:#1b4ca11a;border-color:#1b4ca1;color:#1b4ca1;font-weight:600!important}.category-list-item.selected-theme:before{content:\"\\2713 \";color:#1b4ca1;font-weight:700}.theme-filter-controls{margin-bottom:8px}.clear-filter-btn{background:#f8f9fa;border:1px solid #ddd;border-radius:20px;padding:4px 12px;font-size:12px;color:#666;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:4px}.clear-filter-btn:hover{background:#e9ecef;border-color:#adb5bd}.clear-filter-btn mat-icon{font-size:16px;width:16px;height:16px}.no-course-found-container{display:flex;justify-content:center;align-items:center;min-height:300px;padding:20px}.no-course-card{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:2px dashed #ced4da;border-radius:16px;padding:40px;text-align:center;max-width:500px;box-shadow:0 4px 12px #0000000d}.no-course-card .no-course-icon{margin-bottom:20px}.no-course-card .no-course-icon mat-icon{font-size:48px;width:48px;height:48px;color:#6c757d}.no-course-card .no-course-content h4{color:#495057;font-family:Montserrat;font-size:24px;font-weight:600;margin-bottom:12px}.no-course-card .no-course-content p{color:#6c757d;font-family:Lato;font-size:16px;line-height:1.5;margin-bottom:12px}.no-course-card .no-course-content p strong{color:#1b4ca1;font-weight:600}.no-course-card .suggest-course-btn{background:linear-gradient(135deg,#1b4ca1,#164080);color:#fff;border:none;border-radius:25px;padding:12px 24px;font-family:Lato;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;margin:20px auto 0;transition:all .3s ease;box-shadow:0 4px 12px #1b4ca14d}.no-course-card .suggest-course-btn:hover{background:linear-gradient(135deg,#164080,#0f2f5f);transform:translateY(-2px);box-shadow:0 6px 16px #1b4ca166}.no-course-card .suggest-course-btn:active{transform:translateY(0)}.no-course-card .suggest-course-btn mat-icon{font-size:18px;width:18px;height:18px}.left-panel{flex:0 0 280px!important;background:#f8f9fa;border-radius:12px;padding:16px;border:1px solid #e9ecef;max-height:600px;overflow-y:auto;font-weight:400!important}@media (max-width: 1200px){.search-and-buttons-container{flex-direction:column;align-items:stretch}.search-container-compact{min-width:auto;width:100%}.btn-group-compact{justify-content:center;flex-wrap:wrap}}@media (max-width: 1200px) and (min-width: 769px){.course-list-item{flex:1 1 calc(50% - 10px);min-width:300px;max-width:none}}@media (max-width: 768px){.course-list-container-flex{flex-direction:column}.left-panel{flex:none!important;max-height:300px}.course-list-item{flex:0 0 100%;max-width:100%}.no-course-card{padding:20px}.no-course-card .no-course-content h4{font-size:20px}.no-course-card .no-course-content p{font-size:14px}}::ng-deep .error-snackbar{background-color:#f44336!important;color:#fff!important;font-weight:500}::ng-deep .error-snackbar .mat-simple-snackbar-action{color:#fff!important}::ng-deep .session-expired-snackbar{background-color:#ff9800!important;color:#fff!important;font-weight:600}::ng-deep .session-expired-snackbar .mat-simple-snackbar-action{color:#fff!important;font-weight:700}.download-pdf{justify-content:end;display:flex;flex-direction:row}\n"] }]
|
|
390
|
+
}], ctorParameters: function () { return [{ type: i1.MatDialogRef }, { type: undefined, decorators: [{
|
|
391
|
+
type: Inject,
|
|
392
|
+
args: [MAT_DIALOG_DATA]
|
|
393
|
+
}] }, { type: i2.SharedService }, { type: i1.MatDialog }, { type: i3.MatSnackBar }]; }, propDecorators: { pdfContent: [{
|
|
394
|
+
type: ViewChild,
|
|
395
|
+
args: ['pdfContent', { static: false }]
|
|
396
|
+
}] } });
|
|
397
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"view-course-recommendation.component.js","sourceRoot":"","sources":["../../../../../../../library/sunbird-cb/cbp-ai/src/lib/components/view-course-recommendation/view-course-recommendation.component.ts","../../../../../../../library/sunbird-cb/cbp-ai/src/lib/components/view-course-recommendation/view-course-recommendation.component.html"],"names":[],"mappings":"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","sourcesContent":["import { MAT_DIALOG_DATA, MatDialog, MatDialogRef } from '@angular/material/dialog';\nimport { ChangeDetectorRef, Component, ElementRef, Inject, OnInit, ViewChild } from '@angular/core';\nimport { FormBuilder, FormGroup, FormArray, Validators, FormControl } from '@angular/forms';\nimport { MatSnackBar } from '@angular/material/snack-bar';\nimport { GenerateCourseRecommendationComponent } from '../generate-course-recommendation/generate-course-recommendation.component';\nimport { AddPersonalisationComponent } from '../add-personalisation/add-personalisation.component';\nimport html2pdf from 'html2pdf.js';\nimport { DeleteRoleMappingPopupComponent } from '../delete-role-mapping-popup/delete-role-mapping-popup.component';\nimport { SharedService } from '../../modules/shared/services/shared.service';\n\n@Component({\n  selector: 'app-view-course-recommendation',\n  templateUrl: './view-course-recommendation.component.html',\n  styleUrls: ['./view-course-recommendation.component.scss']\n})\nexport class ViewCourseRecommendationComponent {\n  @ViewChild('pdfContent', { static: false }) pdfContent!: ElementRef;\n  planData:any\n  loading=false\n  recommended_course_id=''\n  cbpPlanData:any\n  suggestedCourses: any = []\n  constructor( public dialogRef: MatDialogRef<ViewCourseRecommendationComponent>,\n    @Inject(MAT_DIALOG_DATA) public data: any, private sharedService: SharedService, private dialog: MatDialog, private snackBar: MatSnackBar) {\n      this.planData = data\n    }\n  searchText = ''\n  filterdCourses :any\n  selectFilterCourses:any = []\n  competenciesCount = {total:0, public_courses:0, igot:0}\n  expandedCompetencies: any = {}; // Track expanded state for each course and competency type\n  isPDFDownload = false\n  ngOnInit() {\n    this.loading = true\n    this.cbpPlanData = this.sharedService.cbpPlanFinalObj\n    // this.sharedService.getRecommendedCourse(this.planData.id).subscribe((res)=>{\n    //   this.loading = false\n    //   console.log('res', res)\n    //   this.recommended_course_id = res.id\n    //   let allCourses = []\n    //   if(res && res.filtered_courses && res.filtered_courses.length) {\n    //     res.filtered_courses.forEach((item)=>{\n    //       if(item?.relevancy > 85) {\n    //         allCourses.push(item)\n    //       }\n    //     })\n    //   }\n    //   this.filterdCourses = allCourses\n    //   console.log('this.filterdCourses', this.filterdCourses)\n    //   this.updateCompetencyCounts()\n    //   this.getUserCourse()\n    // })\n\n    this.sharedService.getUserRecommendationCourse(this.planData.id).subscribe({\n      next: (res) => {\n        this.loading = false\n        console.log('res', res)\n        this.recommended_course_id = res.id\n        let allCourses = []\n        if(res && res.selected_courses && res.selected_courses.length) {\n          res.selected_courses.forEach((item)=>{\n            // if(item?.relevancy >= 85) {\n              allCourses.push(item)\n            // }\n          })\n        }\n        this.filterdCourses = allCourses\n        let identifiersArr = []\n        console.log('this.filterdCourses', this.filterdCourses)\n        this.filterdCourses.map((item)=>{\n          identifiersArr.push(item?.identifier)\n        })\n        this.sharedService.getAdditionalParameterforSuggestedCourses(identifiersArr).subscribe((response)=>{\n          if(response && response.result && response.result.content && response.result.content.length) {\n            for(let i=0; i < response.result.content.length;i++) {\n              for(let j=0; j<this.filterdCourses.length;j++) {\n                if(this.filterdCourses[j]['identifier'] === response.result.content[i]['identifier'] ) {\n                  this.filterdCourses[j]['language'] = response.result.content[i]['language']\n                  this.filterdCourses[j]['avgRating'] = response.result.content[i]['avgRating']\n                  this.filterdCourses[j]['course'] = response.result.content[i]['name']\n                  break;\n                }\n              }\n              \n            }\n          }\n          \n        })\n        this.updateCompetencyCounts()\n        // this.getSuggestedCourse()\n        // this.getUserCourse()\n      },\n      error: (error) => {\n        this.loading = false\n        this.snackBar.open(error?.error?.detail, 'X', {\n          duration: 3000,\n          panelClass: ['snackbar-error']\n        });\n      }\n    });\n  }\n\n  updateCompetencyCounts() {\n   // const comps = this.competenciesArray.value;\n    this.competenciesCount = {total: 0, public_courses: 0, igot: 0};\n    this.filterdCourses.forEach(c => {\n      this.competenciesCount.total++;\n      if (c.is_public) this.competenciesCount.public_courses++;\n      if (!c.is_public) this.competenciesCount.igot++;\n    });\n  }\n\n  closeDialog() {\n    this.dialogRef.close()\n  }\n\n  addMoreCourses() {\n    this.dialogRef.close();\n    console.log('Generate Course Recommendation clicked', this.planData);\n    \n    console.log('Edit Role Mapping clicked', this.planData);\n    // Navigate or open modal\n    console.log('View CBP Plan clicked', this.planData);\n    const dialogRef = this.dialog.open(GenerateCourseRecommendationComponent, {\n      width: '1000px',\n      data: this.planData,\n       panelClass: 'view-cbp-plan-popup',\n      minHeight: '400px',          // Set minimum height\n      maxHeight: '90vh',           // Prevent it from going beyond viewport\n      disableClose: true // Optional: prevent closing with outside click\n    });\n  \n    dialogRef.afterClosed().subscribe(result => {\n      if (result === 'saved') {\n        console.log('Changes saved!');\n        // Refresh data or show a toast here\n       \n        \n      }\n    });\n  }\n\n  addPersonilisation() {\n    this.dialogRef.close();\n    console.log('Generate Course Recommendation clicked', this.planData);\n    \n    console.log('Edit Role Mapping clicked', this.planData);\n    // Navigate or open modal\n    console.log('View CBP Plan clicked', this.planData);\n    const dialogRef = this.dialog.open(AddPersonalisationComponent, {\n      width: '1000px',\n      data: this.planData,\n       panelClass: 'view-cbp-plan-popup',\n      minHeight: '400px',          // Set minimum height\n      maxHeight: '90vh',           // Prevent it from going beyond viewport\n      disableClose: true // Optional: prevent closing with outside click\n    });\n  \n    dialogRef.afterClosed().subscribe(result => {\n      if (result === 'saved') {\n        console.log('Changes saved!');\n        // Refresh data or show a toast here\n       \n        \n      }\n    });\n  }\n\n  getSuggestedCourse() {\n    let role_mapping_id = this.planData.id\n    this.loading = true\n    this.sharedService.getSuggestedCourses(role_mapping_id).subscribe({\n      next: (res) => {\n        // Success handling\n        this.loading = false\n        console.log('getSuggestedCourses res', res)\n        \n        // Store suggested courses separately\n        this.suggestedCourses = [...res];\n        \n        // Add suggested courses to filtered courses\n        for (let i = 0; i < res.length; i++) {\n          this.filterdCourses.push(res[i])\n        }\n        \n        // Update competency counts after adding suggested courses\n        this.updateCompetencyCounts()\n        \n        console.log('filterdCourses after adding suggested courses:', this.filterdCourses);\n      },\n      error: (error) => {\n        console.log('getSuggestedCourse error', error)\n        this.loading = false\n        if (error.status === 401) {\n          console.log('Unauthorized access - user will be redirected to login');\n        } else {\n          console.error('Failed to load suggested courses');\n        }\n      }\n    })\n  }\n\n  getUserCourse() {\n    let role_mapping_id = this.planData.id\n    this.loading = true\n    this.sharedService.getUserCourse(role_mapping_id).subscribe({\n      next: (res) => {\n        // Success handling\n        this.loading = false\n        \n        // Process user-added courses to ensure proper structure\n        for (let i = 0; i < res.length; i++) {\n          this.filterdCourses.push(res[i])\n        }\n        \n        // Update competency counts after adding user courses\n        this.updateCompetencyCounts()\n        \n        console.log('filterdCourses after adding user courses:', this.filterdCourses);\n        //this.successRoleMapping.emit(this.roleMappingForm)\n      },\n      error: (error) => {\n        console.log('error', error)\n        this.loading = false\n        // Handle 409 Conflict here\n        // alert('Conflict detected: The resource already exists or action conflicts.');\n        //this.get\n        // Or you can set a UI error message variable\n\n        this.loading = false\n        //this.alreadyAvailableRoleMapping.emit(this.roleMappingForm)\n      }\n\n\n    })\n  }\n\n  getCompetenciesByType(type: string, index): any[] {\n    const course = this.filterdCourses[index];\n    if (!course) {\n      console.log(`No course found at index ${index}`);\n      return [];\n    }\n    \n    // Handle different competency property names\n    // AI Recommended & Public courses use 'competencies'\n    // Manually Suggested - iGOT courses use 'competencies_v6'\n    // User Added courses use 'competencies'\n    let competencies = [];\n    if (course.competencies && Array.isArray(course.competencies)) {\n      competencies = course.competencies;\n      console.log(`Course ${index} (${course.course_type || course.name || 'Unknown'}) using 'competencies' property:`, competencies);\n    } else if (course.competencies_v6 && Array.isArray(course.competencies_v6)) {\n      competencies = course.competencies_v6;\n      console.log(`Course ${index} (${course.course_type || course.name || 'Unknown'}) using 'competencies_v6' property:`, competencies);\n    } else {\n      console.log(`Course ${index} (${course.course_type || course.name || 'Unknown'}) has no valid competencies property:`, {\n        hasCompetencies: !!course.competencies,\n        competenciesType: typeof course.competencies,\n        hasCompetenciesV6: !!course.competencies_v6,\n        competenciesV6Type: typeof course.competencies_v6,\n        courseKeys: Object.keys(course)\n      });\n    }\n    \n    if (competencies.length === 0) {\n      console.log(`No competencies found for course ${index} and type ${type}`);\n      return [];\n    }\n    \n    // Normalize the type for comparison (case-insensitive + handle spelling variations)\n    const normalizedType = type.toLowerCase().trim();\n    \n    const matchedCompetencies = competencies.filter(c => {\n      if (!c || !c.competencyAreaName) {\n        console.log(`Invalid competency structure in course ${index}:`, c);\n        return false;\n      }\n      \n      const competencyArea = c.competencyAreaName.toLowerCase().trim();\n      \n      // Handle both \"behavioral\" and \"behavioural\" spellings\n      if (normalizedType === 'behavioural' || normalizedType === 'behavioral') {\n        return competencyArea === 'behavioral' || competencyArea === 'behavioural';\n      }\n      \n      // For other types, do case-insensitive comparison\n      return competencyArea === normalizedType;\n    });\n    \n    console.log(`Found ${matchedCompetencies.length} competencies of type ${type} for course ${index}:`, matchedCompetencies);\n    return matchedCompetencies;\n  }\n\n  getDisplayedCompetencies(type: string, index: number): any[] {\n    const competencies = this.getCompetenciesByType(type, index);\n    const key = `${index}-${type}`;\n\n    if (this.expandedCompetencies[key]) {\n      return competencies;\n    }\n\n    return competencies.slice(0, 2);\n  }\n\n  toggleCompetencies(type: string, index: number): void {\n    const key = `${index}-${type}`;\n    this.expandedCompetencies[key] = !this.expandedCompetencies[key];\n  }\n\n  isExpanded(type: string, index: number): boolean {\n    const key = `${index}-${type}`;\n    return this.expandedCompetencies[key] || false;\n  }\n\n  hasMoreThanTwo(type: string, index: number): boolean {\n    return this.getCompetenciesByType(type, index).length > 2;\n  }\n\n  getRemainingCount(type: string, index: number): number {\n    const totalCount = this.getCompetenciesByType(type, index).length;\n    return totalCount - 2;\n  }\n\n  downloadPDF() {\n    this.loading = true\n    this.isPDFDownload = true\n    const element = this.pdfContent.nativeElement;\n\n  // Wait for images to load\n  const images = element.querySelectorAll('img');\n  const promises = Array.from(images).map((img: HTMLImageElement) => {\n    if (img.complete) return Promise.resolve();\n    return new Promise(resolve => img.onload = resolve);\n  });\n\n  Promise.all(promises).then(() => {\n    const options = {\n      margin: 0.5,\n      filename: 'Recommended Coureses.pdf',\n      image: { type: 'jpeg', quality: 0.98 },\n      html2canvas: {\n        scale: 2,\n        useCORS: true,\n        scrollY: 0,\n      },\n      jsPDF: {\n        unit: 'in',\n        format: 'a4',\n        orientation: 'portrait'\n      },\n      pagebreak: {\n        mode: ['css', 'legacy', 'avoid-all']\n      }\n    };\n\n    html2pdf().from(element).set(options).save()\n    setTimeout(() => {\n      this.loading = false;\n      this.isPDFDownload = false\n    }, 3000); \n  });\n}\n\ndownloadPdfFromBE() {\n  this.loading = true\n//  this.sharedService.downloadPdf(this.sharedService?.cbpPlanFinalObj.ministry.identifier)\n  \n  this.sharedService.downloadPdfForCourseRecommendation(this.data?.id)  \n  \n  \n  setTimeout(()=>{\n    this.loading = false\n  },5000)\n}\n\nconfirmDeleteCourse(item: any, index: number) {\n  const roleMappingId = this.recommended_course_id;\n  const courseIdentifier =\n    item?.course_identifier || item?.id || item?.identifier;\n\n  if (!roleMappingId || !courseIdentifier) {\n    this.snackBar.open('Unable to delete course', 'X', {\n      duration: 3000,\n      panelClass: ['snackbar-error']\n    });\n    return;\n  }\n\n  this.loading = true;\n\n  this.sharedService\n    .deleteRecommendedCourse(roleMappingId, courseIdentifier)\n    .subscribe({\n      next: () => {\n        // Remove from UI\n        this.filterdCourses.splice(index, 1);\n\n        // Update counts\n        this.updateCompetencyCounts();\n\n        this.loading = false;\n\n        this.snackBar.open('Course deleted successfully', 'X', {\n          duration: 3000,\n          panelClass: ['snackbar-success']\n        });\n      },\n      error: (error) => {\n        this.loading = false;\n\n        this.snackBar.open(\n          error?.error?.detail || 'Failed to delete course',\n          'X',\n          {\n            duration: 3000,\n            panelClass: ['snackbar-error']\n          }\n        );\n      }\n    });\n\n  }\n\ndeleteCard(item: any, index: number) {\n  const dialogRef = this.dialog.open(DeleteRoleMappingPopupComponent, {\n    width: '600px',\n    data: {\n      planId: this.planData?.id,   // role mapping id\n      course: item,                // course object\n      index: index,\n      from : 'viewCourse'                 // index for UI removal\n    },\n    panelClass: 'view-cbp-plan-popup',\n    minHeight: '300px',\n    maxHeight: '90vh',\n    disableClose: true\n  });\n\n  dialogRef.afterClosed().subscribe(result => {\n    if (result === 'saved') {\n      this.confirmDeleteCourse(item, index);\n    }\n  });\n}\n}\n","<div class=\"view-cbp-plan\">\n    <div class=\"popup-container\">\n        <div class=\"popup-header\">\n            <div>\n                <div class=\"heading\">View Course Recommendation</div>\n            </div>\n            <div class=\"cursor-pointer\" (click)=\"closeDialog()\">\n                <mat-icon>close</mat-icon>\n            </div>\n        </div>\n    </div>\n    <div class=\"section-container mt-2\" #pdfContent>\n        <div class=\"ministry-heading mt-2\">\n           <span *ngIf=\"!cbpPlanData?.department_name\">{{cbpPlanData?.ministry.orgName}}</span> \n           <span *ngIf=\"cbpPlanData?.department_name\">{{cbpPlanData?.department_name}}</span> \n            <span *ngIf=\"planData?.designation_name\"> / {{planData?.designation_name}}</span>\n        </div>\n        <div class=\"competency-container mt-4\">\n            <div class=\"outside-layer-total\">\n                <div class=\"inside-layer\">\n                    Total Courses\n                </div>\n                <div class=\"count\">\n                    {{competenciesCount?.total}}\n                </div>\n            </div>\n            <div class=\"outside-layer-total\">\n                <div class=\"inside-layer\">\n                    iGOT Platform Courses\n                </div>\n                <div class=\"count\">\n                    {{competenciesCount?.igot}}\n                </div>\n            </div>\n            <div class=\"outside-layer-total\">\n                <div class=\"inside-layer\">\n                    Public Courses\n                </div>\n                <div class=\"count\">\n                    {{competenciesCount?.public_courses}}\n                    \n                </div>\n            </div>\n            \n        </div>\n        <div class=\"my-4\">\n        \n            <div class=\"course-list-container\">\n                <div class=\"course-list-item\" *ngFor=\"let item of filterdCourses;let i=index\">\n                    <div class=\"course-header\">\n                        <div class=\"checked-course-container\">\n                           \n                            <div>\n                                <div class=\"course-pill\">\n                                    <div class=\"course-pill-text\">\n                                        <span><img src=\"assets/icons/course.svg\"></span>&nbsp;<span>Course</span>\n                                    </div>\n                                </div>\n                            </div>\n\n                        </div>\n\n                        <!-- <div>\n                            <div class=\"ai-recommened-pill\">\n                                <div class=\"ai-recommened-pill-text\">\n                                    <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span>\n                                    <span>AI Recommended</span>\n\n                                </div>\n                            </div>\n                        </div> -->\n                        <div *ngIf=\"item?.rationale && !item?.is_public\">\n                            <div class=\"ai-recommened-pill-green\">\n                                <div class=\"ai-recommened-pill-green-text\">\n                                    <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span>\n                                    \n                                    <span >AI Recommended - iGOT </span>\n\n                                </div>\n                            </div>\n                            <div class=\"ai-recommened-pill-orange mt-2\" *ngIf=\"item?.platform\">\n                                <div class=\"ai-recommened-pill-orange-text\">\n                                    <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span>\n                                    <a class=\"cursor-pointer\" [href]=\"item?.public_link\" target=\"_blank\"><span>Platform - {{item?.platform}}</span></a>\n                                </div>  \n                            </div>\n                            <div class=\"ai-recommened-pill-orange mt-2\" *ngIf=\"item?.organisation?.length\">\n                                <div class=\"ai-recommened-pill-orange-text\">\n                                    <span class=\"ai-loader-icon\"><img\n                                            src=\"assets/icons/ai-loader.gif\"></span>\n                                    <span>Provider - {{item?.organisation[0]}}</span>\n                                </div>\n                            </div>\n                        </div>\n                        <div *ngIf=\"item?.rationale && item?.is_public\">\n                            <div class=\"ai-recommened-pill-public\">\n                                <div class=\"ai-recommened-pill-public-text\">\n                                    <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span>\n                                    \n                                    <span >AI Recommended - Public </span>\n\n                                </div>\n                            </div>\n                            <div class=\"ai-recommened-pill-orange mt-2\" *ngIf=\"item?.platform\">\n                                <div class=\"ai-recommened-pill-orange-text\">\n                                    <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span>\n                                    <a class=\"cursor-pointer\" [href]=\"item?.public_link\" target=\"_blank\"><span>Platform - {{item?.platform}}</span></a>\n                                </div>  \n                            </div>\n                            <div class=\"ai-recommened-pill-orange mt-2\" *ngIf=\"item?.organisation?.length\">\n                                <div class=\"ai-recommened-pill-orange-text\">\n                                    <span class=\"ai-loader-icon\"><img\n                                            src=\"assets/icons/ai-loader.gif\"></span>\n                                    <span>Provider - {{item?.organisation[0]}}</span>\n                                </div>\n                            </div>\n                        </div>\n                        <div *ngIf=\"!item?.rationale\">\n                            <div class=\"ai-recommened-pill-gray\">\n                                <div class=\"ai-recommened-pill-gray-text\">\n                                    <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span>\n                                    \n                                    <span>Manually Suggested - iGOT </span>\n\n                                </div>\n                            </div>\n                            <div class=\"ai-recommened-pill-orange mt-2\" *ngIf=\"item?.platform\">\n                                <div class=\"ai-recommened-pill-orange-text\">\n                                    <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span>\n                                    <a class=\"cursor-pointer\" [href]=\"item?.public_link\" target=\"_blank\"><span>Platform - {{item?.platform}}</span></a>\n                                </div>  \n                            </div>\n                            <div class=\"ai-recommened-pill-orange mt-2\" *ngIf=\"item?.organisation?.length\">\n                                <div class=\"ai-recommened-pill-orange-text\">\n                                    <span class=\"ai-loader-icon\"><img\n                                            src=\"assets/icons/ai-loader.gif\"></span>\n                                    <span>Provider - {{item?.organisation[0]}}</span>\n                                </div>\n                            </div>\n                        </div>\n                    </div>\n                    <div class=\"course-title mt-4\">\n                        <div>\n                            <div *ngIf=\"item?.course\">{{item?.course}}</div>\n                            <!-- <div *ngIf=\"item?.name\">{{item?.name}}</div> -->\n                        </div>\n                    </div>\n                    <div class=\"course-desc mt-2\">\n                        <div *ngIf=\"isPDFDownload\">\n                            <div>{{item?.rationale}}</div>\n                        </div>\n                    </div>\n                    <div class=\"mt-3\" *ngIf=\"getCompetenciesByType('Behavioural',i)?.length\">\n                        <div class=\"competency-sub-heading\">Behavioral Competencies</div>\n                        <ul class=\"competency-list mt-1\">\n                            <li class=\"behavioural-pill\"\n                                *ngFor=\"let comp of getDisplayedCompetencies('Behavioural',i)\">\n                                <span class=\"competency-text\"> {{ comp.competencyThemeName }} -\n                                    {{\n                                    comp.competencySubThemeName }} </span>\n                            </li>\n                            <li *ngIf=\"hasMoreThanTwo('Behavioural',i)\"\n                                class=\"show-more-competency\">\n                                <span class=\"show-more-link cursor-pointer\"\n                                    (click)=\"toggleCompetencies('Behavioural',i)\">\n                                    {{ isExpanded('Behavioural',i) ? 'Show Less' : '+' +\n                                    getRemainingCount('Behavioural',i) + ' More' }}\n                                </span>\n                            </li>\n                        </ul>\n                    </div>\n                    <div class=\"mt-2\" *ngIf=\"getCompetenciesByType('Functional',i)?.length\">\n                        <div class=\"competency-sub-heading\">Functional Competencies</div>\n                        <ul class=\"competency-list mt-1\">\n                            <li class=\"functional-pill\"\n                                *ngFor=\"let comp of getDisplayedCompetencies('Functional',i)\">\n                                <span class=\"competency-text\"> {{ comp.competencyThemeName }} -\n                                    {{\n                                    comp.competencySubThemeName }} </span>\n                            </li>\n                            <li *ngIf=\"hasMoreThanTwo('Functional',i)\"\n                                class=\"show-more-competency\">\n                                <span class=\"show-more-link cursor-pointer\"\n                                    (click)=\"toggleCompetencies('Functional',i)\">\n                                    {{ isExpanded('Functional',i) ? 'Show Less' : '+' +\n                                    getRemainingCount('Functional',i) + ' More' }}\n                                </span>\n                            </li>\n                        </ul>\n                    </div>\n                    <div class=\"mt-2\" *ngIf=\"getCompetenciesByType('Domain',i)?.length\">\n                        <div class=\"competency-sub-heading\">Domain Competencies</div>\n                        <ul class=\"competency-list mt-1\">\n                            <li class=\"domain-pill\"\n                                *ngFor=\"let comp of getDisplayedCompetencies('Domain',i)\">\n                                <span class=\"competency-text\"> {{ comp.competencyThemeName }} -\n                                    {{\n                                    comp.competencySubThemeName }} </span>\n                            </li>\n                            <li *ngIf=\"hasMoreThanTwo('Domain',i)\" class=\"show-more-competency\">\n                                <span class=\"show-more-link cursor-pointer\"\n                                    (click)=\"toggleCompetencies('Domain',i)\">\n                                    {{ isExpanded('Domain',i) ? 'Show Less' : '+' +\n                                    getRemainingCount('Domain',i) + ' More' }}\n                                </span>\n                            </li>\n                        </ul>\n                    </div>\n                    <div class=\"mt-2 d-flex justify-content-between item\">\n                        <div class=\"relevancy-container\">\n                            <div class=\"relevancy\">Relevancy</div>\n                            <div class=\"dash\">-</div>\n                            <div class=\"percentage\" *ngIf=\"item?.relevancy\">{{item?.relevancy}}%</div>\n                            <div class=\"percentage\" *ngIf=\"!item?.relevancy\">N/A</div>\n                        </div>\n                        <div class=\"delete-button\">\n                           <mat-icon matTooltip=\"Delete Course\" matTooltipPosition=\"above\" class=\"text-danger cursor-pointer\" (click)=\"deleteCard(item, i)\" >delete</mat-icon>\n                        </div>\n                    </div>\n                    <!-- <div>\n                        <div class=\"competencies-matched-container\">\n                            <div class=\"competencies-matched\">Competencies Matched</div>\n                            <div class=\"dash\">-</div>\n                            <div class=\"percentage\">80%</div>\n                        </div>\n                    </div> -->\n                </div>\n                <!-- <div class=\"course-list-item\">\n                    <div class=\"course-header\">\n                        <div>\n                            <div class=\"course-pill\">\n                                <div class=\"course-pill-text\">Course</div>\n                            </div>\n                        </div>\n                        <div>\n                            <div class=\"ai-recommened-pill\">\n                                <div class=\"ai-recommened-pill-text\">\n                                    <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span>\n                                    <span>AI Recommended</span>\n\n                                </div>\n                            </div>\n                        </div>\n                    </div>\n                    <div class=\"course-title\">\n                        <div>\n                            <div>Maternal, Infant And Young Child Nutrition</div>\n                        </div>\n                    </div>\n                    <div class=\"course-desc\">\n                        <div>\n                            <div>This Course directly addresses a primary responsibility of Anganwandi Care takers,\n                                which is\n                                to provide and educate on nutrition for mother and young children</div>\n                        </div>\n                    </div>\n                    <div>\n                        <div class=\"relevancy-container\">\n                            <div class=\"relevancy\">Relevancy</div>\n                            <div class=\"dash\">-</div>\n                            <div class=\"percentage\">90%</div>\n                        </div>\n                    </div>\n                    <div>\n                        <div class=\"competencies-matched-container\">\n                            <div class=\"competencies-matched\">Competencies Matched</div>\n                            <div class=\"dash\">-</div>\n                            <div class=\"percentage\">80%</div>\n                        </div>\n                    </div>\n                </div> -->\n\n            </div>\n        </div>\n    </div>\n    <div class=\"popup-footer\" *ngIf=\"filterdCourses?.length\">\n        <div>\n            <input class=\"btn-active\" type=\"button\" value=\"Download\" (click)=\"downloadPdfFromBE()\"/>\n        </div>\n        <!-- <div>\n            <input class=\"btn-active\" type=\"button\" value=\"Add Personalisation\" (click)=\"addPersonilisation()\"/>\n        </div> -->\n        <!-- <div>\n            <input class=\"btn-active\" type=\"button\" value=\"Add More Courses\" (click)=\"addMoreCourses()\"/>\n        </div> -->\n    </div>\n</div>\n<div class=\"overlay-loader\" *ngIf=\"loading\">\n    <mat-spinner diameter=\"50\"></mat-spinner>\n</div>"]}
|