@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.
Files changed (128) hide show
  1. package/README.md +24 -0
  2. package/esm2022/lib/ai-cbp-routing.module.mjs +56 -0
  3. package/esm2022/lib/ai-cbp.component.mjs +14 -0
  4. package/esm2022/lib/ai-cbp.module.mjs +263 -0
  5. package/esm2022/lib/ai-cbp.service.mjs +14 -0
  6. package/esm2022/lib/components/add-course/add-course.component.mjs +444 -0
  7. package/esm2022/lib/components/add-designation/add-designation.component.mjs +460 -0
  8. package/esm2022/lib/components/add-personalisation/add-personalisation.component.mjs +33 -0
  9. package/esm2022/lib/components/approval-request-form/approval-request-form.component.mjs +392 -0
  10. package/esm2022/lib/components/approval-requests/approval-requests.component.mjs +398 -0
  11. package/esm2022/lib/components/dashboard/dashboard.component.mjs +265 -0
  12. package/esm2022/lib/components/delete-role-mapping/delete-role-mapping.component.mjs +53 -0
  13. package/esm2022/lib/components/delete-role-mapping-popup/delete-role-mapping-popup.component.mjs +39 -0
  14. package/esm2022/lib/components/edit-cbp-plan/edit-cbp-plan.component.mjs +699 -0
  15. package/esm2022/lib/components/gap-analysis-recommended-course/gap-analysis-recommended-course.component.mjs +188 -0
  16. package/esm2022/lib/components/generate-course-recommendation/generate-course-recommendation.component.mjs +1949 -0
  17. package/esm2022/lib/components/list-popup/list-popup.component.mjs +32 -0
  18. package/esm2022/lib/components/review-request/review-request.component.mjs +138 -0
  19. package/esm2022/lib/components/role-mapping-generation/role-mapping-generation.component.mjs +1082 -0
  20. package/esm2022/lib/components/role-mapping-list/role-mapping-list.component.mjs +714 -0
  21. package/esm2022/lib/components/suggest-more-courses/suggest-more-courses.component.mjs +370 -0
  22. package/esm2022/lib/components/update-designation-hierarchy/update-designation-hierarchy.component.mjs +235 -0
  23. package/esm2022/lib/components/view-cbp-plan/view-cbp-plan.component.mjs +125 -0
  24. package/esm2022/lib/components/view-course-recommendation/view-course-recommendation.component.mjs +397 -0
  25. package/esm2022/lib/components/view-final-cbp-plan/view-final-cbp-plan.component.mjs +883 -0
  26. package/esm2022/lib/modules/initial-screen/initial-screen.component.mjs +127 -0
  27. package/esm2022/lib/modules/shared/constant/app.constant.mjs +2036 -0
  28. package/esm2022/lib/modules/shared/directives/clickoutside.directive.mjs +38 -0
  29. package/esm2022/lib/modules/shared/directives/directive.module.mjs +21 -0
  30. package/esm2022/lib/modules/shared/pipes/order-by-name.pipe.mjs +23 -0
  31. package/esm2022/lib/modules/shared/services/event.service.mjs +24 -0
  32. package/esm2022/lib/modules/shared/services/events.mjs +125 -0
  33. package/esm2022/lib/modules/shared/services/init.service.mjs +41 -0
  34. package/esm2022/lib/modules/shared/services/role-mapping.service.mjs +261 -0
  35. package/esm2022/lib/modules/shared/services/shared.service.mjs +869 -0
  36. package/esm2022/lib/modules/upload-document-page/progress-dialog/progress-dialog.component.mjs +53 -0
  37. package/esm2022/lib/modules/upload-document-page/upload-dialog/upload-dialog.component.mjs +186 -0
  38. package/esm2022/lib/modules/upload-document-page/upload-document-page.component.mjs +367 -0
  39. package/esm2022/lib/pipe-public-URL/pipe-public-URL.module.mjs +20 -0
  40. package/esm2022/lib/pipe-public-URL/pipe-public-URL.pipe.mjs +23 -0
  41. package/esm2022/public-api.mjs +14 -0
  42. package/esm2022/sunbird-cb-cbp-ai.mjs +5 -0
  43. package/fesm2022/sunbird-cb-cbp-ai.mjs +12952 -0
  44. package/fesm2022/sunbird-cb-cbp-ai.mjs.map +1 -0
  45. package/index.d.ts +6 -0
  46. package/lib/ai-cbp-routing.module.d.ts +8 -0
  47. package/lib/ai-cbp-routing.module.d.ts.map +1 -0
  48. package/lib/ai-cbp.component.d.ts +7 -0
  49. package/lib/ai-cbp.component.d.ts.map +1 -0
  50. package/lib/ai-cbp.module.d.ts +68 -0
  51. package/lib/ai-cbp.module.d.ts.map +1 -0
  52. package/lib/ai-cbp.service.d.ts +7 -0
  53. package/lib/ai-cbp.service.d.ts.map +1 -0
  54. package/lib/components/add-course/add-course.component.d.ts +67 -0
  55. package/lib/components/add-course/add-course.component.d.ts.map +1 -0
  56. package/lib/components/add-designation/add-designation.component.d.ts +52 -0
  57. package/lib/components/add-designation/add-designation.component.d.ts.map +1 -0
  58. package/lib/components/add-personalisation/add-personalisation.component.d.ts +16 -0
  59. package/lib/components/add-personalisation/add-personalisation.component.d.ts.map +1 -0
  60. package/lib/components/approval-request-form/approval-request-form.component.d.ts +48 -0
  61. package/lib/components/approval-request-form/approval-request-form.component.d.ts.map +1 -0
  62. package/lib/components/approval-requests/approval-requests.component.d.ts +80 -0
  63. package/lib/components/approval-requests/approval-requests.component.d.ts.map +1 -0
  64. package/lib/components/dashboard/dashboard.component.d.ts +55 -0
  65. package/lib/components/dashboard/dashboard.component.d.ts.map +1 -0
  66. package/lib/components/delete-role-mapping/delete-role-mapping.component.d.ts +18 -0
  67. package/lib/components/delete-role-mapping/delete-role-mapping.component.d.ts.map +1 -0
  68. package/lib/components/delete-role-mapping-popup/delete-role-mapping-popup.component.d.ts +18 -0
  69. package/lib/components/delete-role-mapping-popup/delete-role-mapping-popup.component.d.ts.map +1 -0
  70. package/lib/components/edit-cbp-plan/edit-cbp-plan.component.d.ts +94 -0
  71. package/lib/components/edit-cbp-plan/edit-cbp-plan.component.d.ts.map +1 -0
  72. package/lib/components/gap-analysis-recommended-course/gap-analysis-recommended-course.component.d.ts +35 -0
  73. package/lib/components/gap-analysis-recommended-course/gap-analysis-recommended-course.component.d.ts.map +1 -0
  74. package/lib/components/generate-course-recommendation/generate-course-recommendation.component.d.ts +198 -0
  75. package/lib/components/generate-course-recommendation/generate-course-recommendation.component.d.ts.map +1 -0
  76. package/lib/components/list-popup/list-popup.component.d.ts +13 -0
  77. package/lib/components/list-popup/list-popup.component.d.ts.map +1 -0
  78. package/lib/components/review-request/review-request.component.d.ts +39 -0
  79. package/lib/components/review-request/review-request.component.d.ts.map +1 -0
  80. package/lib/components/role-mapping-generation/role-mapping-generation.component.d.ts +99 -0
  81. package/lib/components/role-mapping-generation/role-mapping-generation.component.d.ts.map +1 -0
  82. package/lib/components/role-mapping-list/role-mapping-list.component.d.ts +83 -0
  83. package/lib/components/role-mapping-list/role-mapping-list.component.d.ts.map +1 -0
  84. package/lib/components/suggest-more-courses/suggest-more-courses.component.d.ts +48 -0
  85. package/lib/components/suggest-more-courses/suggest-more-courses.component.d.ts.map +1 -0
  86. package/lib/components/update-designation-hierarchy/update-designation-hierarchy.component.d.ts +41 -0
  87. package/lib/components/update-designation-hierarchy/update-designation-hierarchy.component.d.ts.map +1 -0
  88. package/lib/components/view-cbp-plan/view-cbp-plan.component.d.ts +29 -0
  89. package/lib/components/view-cbp-plan/view-cbp-plan.component.d.ts.map +1 -0
  90. package/lib/components/view-course-recommendation/view-course-recommendation.component.d.ts +49 -0
  91. package/lib/components/view-course-recommendation/view-course-recommendation.component.d.ts.map +1 -0
  92. package/lib/components/view-final-cbp-plan/view-final-cbp-plan.component.d.ts +73 -0
  93. package/lib/components/view-final-cbp-plan/view-final-cbp-plan.component.d.ts.map +1 -0
  94. package/lib/modules/initial-screen/initial-screen.component.d.ts +85 -0
  95. package/lib/modules/initial-screen/initial-screen.component.d.ts.map +1 -0
  96. package/lib/modules/shared/constant/app.constant.d.ts +457 -0
  97. package/lib/modules/shared/constant/app.constant.d.ts.map +1 -0
  98. package/lib/modules/shared/directives/clickoutside.directive.d.ts +13 -0
  99. package/lib/modules/shared/directives/clickoutside.directive.d.ts.map +1 -0
  100. package/lib/modules/shared/directives/directive.module.d.ts +8 -0
  101. package/lib/modules/shared/directives/directive.module.d.ts.map +1 -0
  102. package/lib/modules/shared/pipes/order-by-name.pipe.d.ts +8 -0
  103. package/lib/modules/shared/pipes/order-by-name.pipe.d.ts.map +1 -0
  104. package/lib/modules/shared/services/event.service.d.ts +12 -0
  105. package/lib/modules/shared/services/event.service.d.ts.map +1 -0
  106. package/lib/modules/shared/services/events.d.ts +200 -0
  107. package/lib/modules/shared/services/events.d.ts.map +1 -0
  108. package/lib/modules/shared/services/init.service.d.ts +13 -0
  109. package/lib/modules/shared/services/init.service.d.ts.map +1 -0
  110. package/lib/modules/shared/services/role-mapping.service.d.ts +21 -0
  111. package/lib/modules/shared/services/role-mapping.service.d.ts.map +1 -0
  112. package/lib/modules/shared/services/shared.service.d.ts +108 -0
  113. package/lib/modules/shared/services/shared.service.d.ts.map +1 -0
  114. package/lib/modules/upload-document-page/progress-dialog/progress-dialog.component.d.ts +14 -0
  115. package/lib/modules/upload-document-page/progress-dialog/progress-dialog.component.d.ts.map +1 -0
  116. package/lib/modules/upload-document-page/upload-dialog/upload-dialog.component.d.ts +29 -0
  117. package/lib/modules/upload-document-page/upload-dialog/upload-dialog.component.d.ts.map +1 -0
  118. package/lib/modules/upload-document-page/upload-document-page.component.d.ts +64 -0
  119. package/lib/modules/upload-document-page/upload-document-page.component.d.ts.map +1 -0
  120. package/lib/pipe-public-URL/pipe-public-URL.module.d.ts +9 -0
  121. package/lib/pipe-public-URL/pipe-public-URL.module.d.ts.map +1 -0
  122. package/lib/pipe-public-URL/pipe-public-URL.pipe.d.ts +11 -0
  123. package/lib/pipe-public-URL/pipe-public-URL.pipe.d.ts.map +1 -0
  124. package/package.json +28 -0
  125. package/public-api.d.ts +11 -0
  126. package/public-api.d.ts.map +1 -0
  127. package/sunbird-cb-cbp-ai-0.0.1.tgz +0 -0
  128. package/sunbird-cb-cbp-ai.d.ts.map +1 -0
@@ -0,0 +1,883 @@
1
+ import { Component, Inject, ViewChild } from '@angular/core';
2
+ import { MAT_DIALOG_DATA } from '@angular/material/dialog';
3
+ import html2pdf from 'html2pdf.js';
4
+ import jsPDF from 'jspdf';
5
+ import html2canvas from 'html2canvas';
6
+ import * as XLSX from 'xlsx';
7
+ import { DeleteRoleMappingPopupComponent } from '../delete-role-mapping-popup/delete-role-mapping-popup.component';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "@angular/material/dialog";
10
+ import * as i2 from "../../modules/shared/services/shared.service";
11
+ import * as i3 from "@angular/material/snack-bar";
12
+ import * as i4 from "@angular/forms";
13
+ import * as i5 from "@angular/common";
14
+ import * as i6 from "@angular/material/legacy-form-field";
15
+ import * as i7 from "@angular/material/legacy-input";
16
+ import * as i8 from "@angular/material/icon";
17
+ import * as i9 from "@angular/material/legacy-select";
18
+ import * as i10 from "@angular/material/legacy-core";
19
+ import * as i11 from "@angular/material/progress-spinner";
20
+ export class ViewFinalCbpPlanComponent {
21
+ constructor(dialogRef, data, dialog, cdr, sharedService, snackBar, fb) {
22
+ this.dialogRef = dialogRef;
23
+ this.data = data;
24
+ this.dialog = dialog;
25
+ this.cdr = cdr;
26
+ this.sharedService = sharedService;
27
+ this.snackBar = snackBar;
28
+ this.fb = fb;
29
+ this.languages = [{ "code": "en", label: "English" },
30
+ { "code": "hi", label: "Hindi" },
31
+ { "code": "te", label: "Telugu" },
32
+ { "code": "kn", label: "Kannada" },
33
+ { "code": "mr", label: "Marathi" },
34
+ { "code": "ta", label: "Tamil" },
35
+ { "code": "gu", label: "Gujarati" },
36
+ { "code": "ml", label: "Malayalam" },
37
+ { "code": "bn", label: "Bengali" },];
38
+ this.filteredLanguages = [...this.languages];
39
+ this.loading = false;
40
+ this.designationData = [];
41
+ this.totalCompetencieObj = { total: 0, behavioral: 0, functional: 0, domain: 0 };
42
+ this.pdfTrigger = false;
43
+ this.jsonData = [];
44
+ this.filterdCourses = [];
45
+ this.recommended_course_id = '';
46
+ this.expandedCompetencies = {};
47
+ this.competenciesCount = { total: 0, public_courses: 0, igot: 0 };
48
+ this.filterForm = this.fb.group({
49
+ language: ['en']
50
+ });
51
+ this.openedFrom = data?.openedFrom;
52
+ this.getMappingData();
53
+ }
54
+ // designationData = [
55
+ // {
56
+ // designation: "Secretary (WCD)",
57
+ // wing: "Ministry Leadership",
58
+ // updated: "10/09/2025",
59
+ // rolesResponsibilities: [
60
+ // "Provide overall supervision of ministry programmes and schemes",
61
+ // "Ensure effective coordination with State Governments for scheme implementation",
62
+ // "Strategic policy formulation and implementation oversight",
63
+ // "Inter-ministerial coordination and liaison",
64
+ // "Parliamentary affairs management",
65
+ // "Senior leadership governance and oversight",
66
+ // "National programme strategic direction",
67
+ // "Cabinet note writing and policy briefs"
68
+ // ],
69
+ // behavioralCompetencies: [
70
+ // "Strategic Leadership", "Executive Presence", "Influencing and Negotiation",
71
+ // "Relationship Management", "Verbal & Non-Verbal Fluency", "Planning & Prioritization",
72
+ // "Accountability", "Conflict Management"
73
+ // ],
74
+ // functionalCompetencies: [
75
+ // "Rules of business (AoB/ToB)", "Cabinet note writing", "Submission of briefs, supply of information",
76
+ // "Policy design/ amendment", "Policy implementation", "Policy monitoring & impact assessment",
77
+ // "Project Planning", "Project Evaluation & Monitoring", "Creation of M&E Framework",
78
+ // "Citizen Partnering & Collaboration", "Public Grievance Handling"
79
+ // ],
80
+ // domainCompetencies: [
81
+ // "Strategic Policy Formulation", "Inter-ministerial & State Government Coordination",
82
+ // "Senior Leadership Governance & Oversight", "Legislative & Parliamentary Affairs Management",
83
+ // "National Programme Strategic Direction"
84
+ // ],
85
+ // completionRate: { behavioral: 85, functional: 78, domain: 92 }
86
+ // }
87
+ // ];
88
+ // // Calculate the totals dynamically
89
+ // private behavioralTotal = this.designationData.reduce((acc, item) => acc + item.behavioralCompetencies.length, 0);
90
+ // private functionalTotal = this.designationData.reduce((acc, item) => acc + item.functionalCompetencies.length, 0);
91
+ // private domainTotal = this.designationData.reduce((acc, item) => acc + item.domainCompetencies.length, 0);
92
+ // // Calculate the averages dynamically
93
+ // private behavioralAvg = Math.round(this.designationData.reduce((acc, item) => acc + item.completionRate.behavioral, 0) / this.designationData.length);
94
+ // private functionalAvg = Math.round(this.designationData.reduce((acc, item) => acc + item.completionRate.functional, 0) / this.designationData.length);
95
+ // private domainAvg = Math.round(this.designationData.reduce((acc, item) => acc + item.completionRate.domain, 0) / this.designationData.length);
96
+ // overallKPIs = [
97
+ // {
98
+ // name: 'Behavioral Competencies',
99
+ // total: this.behavioralTotal,
100
+ // avgCompletion: this.behavioralAvg,
101
+ // color: '#3B82F6',
102
+ // bgColor: 'bg-blue-50',
103
+ // },
104
+ // {
105
+ // name: 'Functional Competencies',
106
+ // total: this.functionalTotal,
107
+ // avgCompletion: this.functionalAvg,
108
+ // color: '#10B981',
109
+ // bgColor: 'bg-green-50',
110
+ // },
111
+ // {
112
+ // name: 'Domain Competencies',
113
+ // total: this.domainTotal,
114
+ // avgCompletion: this.domainAvg,
115
+ // color: '#8B5CF6',
116
+ // bgColor: 'bg-purple-50',
117
+ // },
118
+ // {
119
+ // name: 'Total Competencies',
120
+ // total: this.behavioralTotal + this.functionalTotal + this.domainTotal,
121
+ // avgCompletion: Math.round((this.behavioralAvg + this.functionalAvg + this.domainAvg) / 3),
122
+ // color: '#4B5563',
123
+ // bgColor: 'bg-gray-200',
124
+ // }
125
+ // ];
126
+ closeDialog() {
127
+ this.dialogRef.close();
128
+ }
129
+ cancelForm() {
130
+ this.dialogRef.close();
131
+ }
132
+ saveRoleMapping() {
133
+ }
134
+ ngAfterViewInit() {
135
+ console.log('this.data', this.data);
136
+ this.jsonData = this.data?.payload;
137
+ this.cdr.detectChanges();
138
+ setTimeout(() => {
139
+ this.scrollToTop();
140
+ });
141
+ if (this.dialogContent) {
142
+ setTimeout(() => {
143
+ this.dialogContent.nativeElement.scrollTo({
144
+ top: 0,
145
+ behavior: 'smooth'
146
+ });
147
+ }, 500);
148
+ }
149
+ }
150
+ getMappingData() {
151
+ console.log('haredService?.cbpPlanFinalObj', this.sharedService.getCbpPlansWithSelectedCourses());
152
+ if (this.sharedService?.cbpPlanFinalObj.ministry.sbOrgType === 'ministry') {
153
+ this.loading = true;
154
+ let state_center_id = this.sharedService?.cbpPlanFinalObj.ministry.identifier;
155
+ if (this.sharedService?.cbpPlanFinalObj.departments?.length) {
156
+ let department_id = this.sharedService?.cbpPlanFinalObj.departments;
157
+ this.sharedService.getRoleMappingByStateCenterAndDepartment(state_center_id, department_id).subscribe({
158
+ next: (res) => {
159
+ this.loading = false;
160
+ this.totalCompetencieObj = { total: 0, behavioral: 0, functional: 0, domain: 0 };
161
+ this.designationData = [];
162
+ // ✅ GLOBAL UNIQUE SETS (for overall unique count)
163
+ const globalTotalSet = new Set();
164
+ const globalBehavioralSet = new Set();
165
+ const globalFunctionalSet = new Set();
166
+ const globalDomainSet = new Set();
167
+ for (let i = 0; i < res.length; i++) {
168
+ // ✅ LOCAL UNIQUE SETS (per designation)
169
+ const totalSet = new Set();
170
+ const behavioralSet = new Set();
171
+ const functionalSet = new Set();
172
+ const domainSet = new Set();
173
+ let competenciesObj = { total: 0, behavioral: 0, functional: 0, domain: 0 };
174
+ res[i]?.competencies?.forEach(c => {
175
+ const theme = (c?.theme || '').trim().toLowerCase();
176
+ const subTheme = (c?.sub_theme || '').trim().toLowerCase();
177
+ const type = (c?.type || '').trim().toLowerCase();
178
+ if (!theme && !subTheme)
179
+ return;
180
+ const key = `${theme}-${subTheme}`;
181
+ // ✅ PER DESIGNATION UNIQUE
182
+ if (!totalSet.has(key)) {
183
+ totalSet.add(key);
184
+ competenciesObj.total++;
185
+ }
186
+ if (type === 'behavioral' && !behavioralSet.has(key)) {
187
+ behavioralSet.add(key);
188
+ competenciesObj.behavioral++;
189
+ }
190
+ if (type === 'functional' && !functionalSet.has(key)) {
191
+ functionalSet.add(key);
192
+ competenciesObj.functional++;
193
+ }
194
+ if (type === 'domain' && !domainSet.has(key)) {
195
+ domainSet.add(key);
196
+ competenciesObj.domain++;
197
+ }
198
+ // ✅ GLOBAL UNIQUE TRACKING
199
+ globalTotalSet.add(key);
200
+ if (type === 'behavioral')
201
+ globalBehavioralSet.add(key);
202
+ if (type === 'functional')
203
+ globalFunctionalSet.add(key);
204
+ if (type === 'domain')
205
+ globalDomainSet.add(key);
206
+ });
207
+ this.designationData.push({
208
+ designation: res[i].designation_name,
209
+ wing: res[i].wing_division_section,
210
+ updated: res[i].updated_at,
211
+ rolesResponsibilities: res[i].role_responsibilities,
212
+ activities: res[i].activities,
213
+ competenciesObj,
214
+ behavioralCompetencies: [...behavioralSet],
215
+ functionalCompetencies: [...functionalSet],
216
+ domainCompetencies: [...domainSet],
217
+ selectedCourses: res[i]?.cbp_plans?.at(-1)?.selected_courses || []
218
+ });
219
+ }
220
+ // ✅ SET GLOBAL COUNTS AFTER LOOP
221
+ this.totalCompetencieObj.total = globalTotalSet.size;
222
+ this.totalCompetencieObj.behavioral = globalBehavioralSet.size;
223
+ this.totalCompetencieObj.functional = globalFunctionalSet.size;
224
+ this.totalCompetencieObj.domain = globalDomainSet.size;
225
+ this.cdr.detectChanges();
226
+ this.cdr.detectChanges();
227
+ setTimeout(() => {
228
+ this.scrollToTop();
229
+ }, 1000);
230
+ console.log('this.designationData', this.designationData);
231
+ console.log('this.totalCompetencieObj', this.totalCompetencieObj);
232
+ },
233
+ error: (error) => {
234
+ this.loading = false;
235
+ this.snackBar.open(error?.error?.detail, 'X', {
236
+ duration: 3000,
237
+ panelClass: ['snackbar-error']
238
+ });
239
+ }
240
+ });
241
+ }
242
+ else {
243
+ this.sharedService.getRoleMappingByStateCenter(state_center_id).subscribe({
244
+ next: (res) => {
245
+ this.loading = false;
246
+ console.log('res', res);
247
+ this.totalCompetencieObj = { total: 0, behavioral: 0, functional: 0, domain: 0 };
248
+ this.designationData = [];
249
+ // ✅ GLOBAL UNIQUE SETS (for overall unique count)
250
+ const globalTotalSet = new Set();
251
+ const globalBehavioralSet = new Set();
252
+ const globalFunctionalSet = new Set();
253
+ const globalDomainSet = new Set();
254
+ for (let i = 0; i < res.length; i++) {
255
+ // ✅ LOCAL UNIQUE SETS (per designation)
256
+ const totalSet = new Set();
257
+ const behavioralSet = new Set();
258
+ const functionalSet = new Set();
259
+ const domainSet = new Set();
260
+ let competenciesObj = { total: 0, behavioral: 0, functional: 0, domain: 0 };
261
+ res[i]?.competencies?.forEach(c => {
262
+ const theme = (c?.theme || '').trim().toLowerCase();
263
+ const subTheme = (c?.sub_theme || '').trim().toLowerCase();
264
+ const type = (c?.type || '').trim().toLowerCase();
265
+ if (!theme && !subTheme)
266
+ return;
267
+ const key = `${theme}-${subTheme}`;
268
+ // ✅ PER DESIGNATION UNIQUE
269
+ if (!totalSet.has(key)) {
270
+ totalSet.add(key);
271
+ competenciesObj.total++;
272
+ }
273
+ if (type === 'behavioral' && !behavioralSet.has(key)) {
274
+ behavioralSet.add(key);
275
+ competenciesObj.behavioral++;
276
+ }
277
+ if (type === 'functional' && !functionalSet.has(key)) {
278
+ functionalSet.add(key);
279
+ competenciesObj.functional++;
280
+ }
281
+ if (type === 'domain' && !domainSet.has(key)) {
282
+ domainSet.add(key);
283
+ competenciesObj.domain++;
284
+ }
285
+ // ✅ GLOBAL UNIQUE TRACKING
286
+ globalTotalSet.add(key);
287
+ if (type === 'behavioral')
288
+ globalBehavioralSet.add(key);
289
+ if (type === 'functional')
290
+ globalFunctionalSet.add(key);
291
+ if (type === 'domain')
292
+ globalDomainSet.add(key);
293
+ });
294
+ this.designationData.push({
295
+ designation: res[i].designation_name,
296
+ wing: res[i].wing_division_section,
297
+ updated: res[i].updated_at,
298
+ rolesResponsibilities: res[i].role_responsibilities,
299
+ activities: res[i].activities,
300
+ competenciesObj,
301
+ behavioralCompetencies: [...behavioralSet],
302
+ functionalCompetencies: [...functionalSet],
303
+ domainCompetencies: [...domainSet],
304
+ selectedCourses: res[i]?.cbp_plans?.at(-1)?.selected_courses || []
305
+ });
306
+ }
307
+ // ✅ SET GLOBAL COUNTS AFTER LOOP
308
+ this.totalCompetencieObj.total = globalTotalSet.size;
309
+ this.totalCompetencieObj.behavioral = globalBehavioralSet.size;
310
+ this.totalCompetencieObj.functional = globalFunctionalSet.size;
311
+ this.totalCompetencieObj.domain = globalDomainSet.size;
312
+ this.cdr.detectChanges();
313
+ this.cdr.detectChanges();
314
+ setTimeout(() => {
315
+ this.scrollToTop();
316
+ }, 1000);
317
+ },
318
+ error: (error) => {
319
+ this.loading = false;
320
+ this.snackBar.open(error?.error?.detail, 'X', {
321
+ duration: 3000,
322
+ panelClass: ['snackbar-error']
323
+ });
324
+ }
325
+ });
326
+ }
327
+ }
328
+ if (this.sharedService?.cbpPlanFinalObj.ministry.sbOrgType === 'state') {
329
+ this.loading = true;
330
+ console.log('this.sharedService?.cbpPlanFinalObj', this.sharedService?.cbpPlanFinalObj);
331
+ let state_center_id = this.sharedService?.cbpPlanFinalObj.ministry.identifier;
332
+ let department_id = this.sharedService?.cbpPlanFinalObj.departments;
333
+ // this.sharedService.getRoleMappingByStateCenterAndDepartment(state_center_id, department_id).subscribe((res)=>{
334
+ // console.log('res', res)
335
+ // let behavioralCompetencies =[]
336
+ // let functionalCompetencies =[]
337
+ // let domainCompetencies =[]
338
+ // for(let i=0; i<res.length;i++) {
339
+ // behavioralCompetencies = []
340
+ // functionalCompetencies =[]
341
+ // domainCompetencies =[]
342
+ // let competenciesObj = {total:0, behavioral:0, functional:0, domain:0}
343
+ // res[i].competencies.forEach(c => {
344
+ // competenciesObj.total++;
345
+ // this.totalCompetencieObj.total++
346
+ // if (c.type.toLowerCase() === 'behavioral') {
347
+ // behavioralCompetencies.push(`${c.theme} - ${c.sub_theme}`)
348
+ // competenciesObj.behavioral++;
349
+ // this.totalCompetencieObj.behavioral++
350
+ // }
351
+ // if (c.type.toLowerCase() === 'functional') {
352
+ // functionalCompetencies.push(`${c.theme} - ${c.sub_theme}`)
353
+ // competenciesObj.functional++;
354
+ // this.totalCompetencieObj.functional++
355
+ // }
356
+ // if (c.type.toLowerCase() === 'domain') {
357
+ // domainCompetencies.push(`${c.theme} - ${c.sub_theme}`)
358
+ // competenciesObj.domain++;
359
+ // this.totalCompetencieObj.domain++
360
+ // }
361
+ // });
362
+ // let obj:any = {
363
+ // designation: res[i].designation_name,
364
+ // wing: res[i].wing_division_section,
365
+ // updated: res[i].updated_at,
366
+ // rolesResponsibilities: res[i].role_responsibilities,
367
+ // activities:res[i].activities,
368
+ // competenciesObj: competenciesObj,
369
+ // behavioralCompetencies: behavioralCompetencies,
370
+ // functionalCompetencies: functionalCompetencies,
371
+ // domainCompetencies: domainCompetencies
372
+ // // behavioralCompetencies: [
373
+ // // "Strategic Leadership", "Executive Presence", "Influencing and Negotiation",
374
+ // // "Relationship Management", "Verbal & Non-Verbal Fluency", "Planning & Prioritization",
375
+ // // "Accountability", "Conflict Management"
376
+ // // ],
377
+ // // functionalCompetencies: [
378
+ // // "Rules of business (AoB/ToB)", "Cabinet note writing", "Submission of briefs, supply of information",
379
+ // // "Policy design/ amendment", "Policy implementation", "Policy monitoring & impact assessment",
380
+ // // "Project Planning", "Project Evaluation & Monitoring", "Creation of M&E Framework",
381
+ // // "Citizen Partnering & Collaboration", "Public Grievance Handling"
382
+ // // ],
383
+ // // domainCompetencies: [
384
+ // // "Strategic Policy Formulation", "Inter-ministerial & State Government Coordination",
385
+ // // "Senior Leadership Governance & Oversight", "Legislative & Parliamentary Affairs Management",
386
+ // // "National Programme Strategic Direction"
387
+ // // ],
388
+ // // completionRate: { behavioral: 85, functional: 78, domain: 92 }
389
+ // }
390
+ // this.designationData.push(obj)
391
+ // }
392
+ // this.cdr.detectChanges();
393
+ // setTimeout(() => {
394
+ // this.scrollToTop()
395
+ // }, 1000);
396
+ // console.log('this.designationData', this.designationData)
397
+ // console.log('this.totalCompetencieObj', this.totalCompetencieObj )
398
+ // })
399
+ this.sharedService.getRoleMappingByStateCenterAndDepartment(state_center_id, department_id).subscribe({
400
+ next: (res) => {
401
+ this.loading = false;
402
+ console.log('res', res);
403
+ this.totalCompetencieObj = { total: 0, behavioral: 0, functional: 0, domain: 0 };
404
+ this.designationData = [];
405
+ // ✅ GLOBAL UNIQUE SETS (for overall unique count)
406
+ const globalTotalSet = new Set();
407
+ const globalBehavioralSet = new Set();
408
+ const globalFunctionalSet = new Set();
409
+ const globalDomainSet = new Set();
410
+ for (let i = 0; i < res.length; i++) {
411
+ // ✅ LOCAL UNIQUE SETS (per designation)
412
+ const totalSet = new Set();
413
+ const behavioralSet = new Set();
414
+ const functionalSet = new Set();
415
+ const domainSet = new Set();
416
+ let competenciesObj = { total: 0, behavioral: 0, functional: 0, domain: 0 };
417
+ res[i]?.competencies?.forEach(c => {
418
+ const theme = (c?.theme || '').trim().toLowerCase();
419
+ const subTheme = (c?.sub_theme || '').trim().toLowerCase();
420
+ const type = (c?.type || '').trim().toLowerCase();
421
+ if (!theme && !subTheme)
422
+ return;
423
+ const key = `${theme}-${subTheme}`;
424
+ // ✅ PER DESIGNATION UNIQUE
425
+ if (!totalSet.has(key)) {
426
+ totalSet.add(key);
427
+ competenciesObj.total++;
428
+ }
429
+ if (type === 'behavioral' && !behavioralSet.has(key)) {
430
+ behavioralSet.add(key);
431
+ competenciesObj.behavioral++;
432
+ }
433
+ if (type === 'functional' && !functionalSet.has(key)) {
434
+ functionalSet.add(key);
435
+ competenciesObj.functional++;
436
+ }
437
+ if (type === 'domain' && !domainSet.has(key)) {
438
+ domainSet.add(key);
439
+ competenciesObj.domain++;
440
+ }
441
+ // ✅ GLOBAL UNIQUE TRACKING
442
+ globalTotalSet.add(key);
443
+ if (type === 'behavioral')
444
+ globalBehavioralSet.add(key);
445
+ if (type === 'functional')
446
+ globalFunctionalSet.add(key);
447
+ if (type === 'domain')
448
+ globalDomainSet.add(key);
449
+ });
450
+ this.designationData.push({
451
+ designation: res[i].designation_name,
452
+ wing: res[i].wing_division_section,
453
+ updated: res[i].updated_at,
454
+ rolesResponsibilities: res[i].role_responsibilities,
455
+ activities: res[i].activities,
456
+ competenciesObj,
457
+ behavioralCompetencies: [...behavioralSet],
458
+ functionalCompetencies: [...functionalSet],
459
+ domainCompetencies: [...domainSet],
460
+ selectedCourses: res[i]?.cbp_plans?.at(-1)?.selected_courses || []
461
+ });
462
+ }
463
+ // ✅ SET GLOBAL COUNTS AFTER LOOP
464
+ this.totalCompetencieObj.total = globalTotalSet.size;
465
+ this.totalCompetencieObj.behavioral = globalBehavioralSet.size;
466
+ this.totalCompetencieObj.functional = globalFunctionalSet.size;
467
+ this.totalCompetencieObj.domain = globalDomainSet.size;
468
+ this.cdr.detectChanges();
469
+ this.cdr.detectChanges();
470
+ setTimeout(() => {
471
+ this.scrollToTop();
472
+ }, 1000);
473
+ console.log('this.designationData', this.designationData);
474
+ console.log('this.totalCompetencieObj', this.totalCompetencieObj);
475
+ },
476
+ error: (error) => {
477
+ this.loading = false;
478
+ this.snackBar.open(error?.error?.detail, 'X', {
479
+ duration: 3000,
480
+ panelClass: ['snackbar-error']
481
+ });
482
+ }
483
+ });
484
+ }
485
+ }
486
+ getCompetenciesByType(type, course) {
487
+ if (!course) {
488
+ return [];
489
+ }
490
+ let competencies = [];
491
+ // AI Recommended / Public / User Added
492
+ if (Array.isArray(course.competencies)) {
493
+ competencies = course.competencies;
494
+ }
495
+ // Manually Suggested - iGOT (v6)
496
+ else if (Array.isArray(course.competencies_v6)) {
497
+ competencies = course.competencies_v6;
498
+ }
499
+ if (!competencies.length) {
500
+ return [];
501
+ }
502
+ const normalizedType = type.toLowerCase().trim();
503
+ return competencies.filter(c => {
504
+ if (!c?.competencyAreaName) {
505
+ return false;
506
+ }
507
+ const area = c.competencyAreaName.toLowerCase().trim();
508
+ // handle behavioural / behavioral
509
+ if (normalizedType === 'behavioural' || normalizedType === 'behavioral') {
510
+ return area === 'behavioural' || area === 'behavioral';
511
+ }
512
+ return area === normalizedType;
513
+ });
514
+ }
515
+ getDisplayedCompetencies(type, index) {
516
+ const competencies = this.getCompetenciesByType(type, index);
517
+ const key = `${index}-${type}`;
518
+ if (this.expandedCompetencies[key]) {
519
+ return competencies;
520
+ }
521
+ return competencies.slice(0, 2);
522
+ }
523
+ toggleCompetencies(type, index) {
524
+ const key = `${index}-${type}`;
525
+ this.expandedCompetencies[key] = !this.expandedCompetencies[key];
526
+ }
527
+ isExpanded(type, index) {
528
+ const key = `${index}-${type}`;
529
+ return this.expandedCompetencies[key] || false;
530
+ }
531
+ hasMoreThanTwo(type, index) {
532
+ return this.getCompetenciesByType(type, index).length > 2;
533
+ }
534
+ getRemainingCount(type, index) {
535
+ const totalCount = this.getCompetenciesByType(type, index).length;
536
+ return totalCount - 2;
537
+ }
538
+ updateCompetencyCounts() {
539
+ // const comps = this.competenciesArray.value;
540
+ this.competenciesCount = { total: 0, public_courses: 0, igot: 0 };
541
+ this.filterdCourses.forEach(c => {
542
+ this.competenciesCount.total++;
543
+ if (c.is_public)
544
+ this.competenciesCount.public_courses++;
545
+ if (!c.is_public)
546
+ this.competenciesCount.igot++;
547
+ });
548
+ }
549
+ confirmDeleteCourse(item, index) {
550
+ const roleMappingId = this.recommended_course_id;
551
+ const courseIdentifier = item?.course_identifier || item?.id || item?.identifier;
552
+ if (!roleMappingId || !courseIdentifier) {
553
+ this.snackBar.open('Unable to delete course', 'X', {
554
+ duration: 3000,
555
+ panelClass: ['snackbar-error']
556
+ });
557
+ return;
558
+ }
559
+ this.loading = true;
560
+ this.sharedService
561
+ .deleteRecommendedCourse(roleMappingId, courseIdentifier)
562
+ .subscribe({
563
+ next: () => {
564
+ // Remove from UI
565
+ this.filterdCourses.splice(index, 1);
566
+ // Update counts
567
+ this.updateCompetencyCounts();
568
+ this.loading = false;
569
+ this.snackBar.open('Course deleted successfully', 'X', {
570
+ duration: 3000,
571
+ panelClass: ['snackbar-success']
572
+ });
573
+ },
574
+ error: (error) => {
575
+ this.loading = false;
576
+ this.snackBar.open(error?.error?.detail || 'Failed to delete course', 'X', {
577
+ duration: 3000,
578
+ panelClass: ['snackbar-error']
579
+ });
580
+ }
581
+ });
582
+ }
583
+ deleteCard(item, index) {
584
+ console.log("item, index", item, index);
585
+ const dialogRef = this.dialog.open(DeleteRoleMappingPopupComponent, {
586
+ width: '600px',
587
+ data: {
588
+ planId: this.planData?.id,
589
+ course: item,
590
+ index: index,
591
+ from: 'viewCourse' // index for UI removal
592
+ },
593
+ panelClass: 'view-cbp-plan-popup',
594
+ minHeight: '300px',
595
+ maxHeight: '90vh',
596
+ disableClose: true
597
+ });
598
+ dialogRef.afterClosed().subscribe(result => {
599
+ if (result === 'saved') {
600
+ this.confirmDeleteCourse(item, index);
601
+ }
602
+ });
603
+ }
604
+ scrollToTop() {
605
+ // if (this.pdfContent && this.pdfContent.nativeElement && this.pdfContent.nativeElement.scrollTop !== undefined) {
606
+ // this.pdfContent.nativeElement.scrollTop = 0;
607
+ // } else {
608
+ // window.scrollTo({ top: 0, behavior: 'smooth' });
609
+ // }
610
+ // const dialogContainer = document.querySelector('mat-dialog-container');
611
+ // if (dialogContainer) {
612
+ // dialogContainer.scrollTop = 0;
613
+ // }
614
+ }
615
+ downloadPDF() {
616
+ this.pdfTrigger = true;
617
+ this.loading = true;
618
+ // const element = this.pdfContent.nativeElement;
619
+ // // Wait for images to load
620
+ // const images = element.querySelectorAll('img');
621
+ // const promises = Array.from(images).map((img: HTMLImageElement) => {
622
+ // if (img.complete) return Promise.resolve();
623
+ // return new Promise(resolve => img.onload = resolve);
624
+ // });
625
+ // Promise.all(promises).then(() => {
626
+ // const options = {
627
+ // margin: 0.5,
628
+ // filename: 'Final CBP Plan.pdf',
629
+ // image: { type: 'jpeg', quality: 0.98 },
630
+ // html2canvas: {
631
+ // scale: 2,
632
+ // useCORS: true,
633
+ // scrollY: 0,
634
+ // },
635
+ // jsPDF: {
636
+ // unit: 'in',
637
+ // format: 'a4',
638
+ // orientation: 'portrait'
639
+ // },
640
+ // pagebreak: {
641
+ // mode: ['css', 'legacy', 'avoid-all']
642
+ // }
643
+ // };
644
+ // html2pdf().from(element).set(options).save();
645
+ // });
646
+ //const element = this.pdfContent.nativeElement;
647
+ this.loading = true;
648
+ const element = this.pdfContent.nativeElement;
649
+ html2canvas(element, {
650
+ scale: 1.25,
651
+ useCORS: true,
652
+ scrollY: 0,
653
+ logging: true,
654
+ }).then((canvas) => {
655
+ const pdf = new jsPDF('p', 'mm', 'a4');
656
+ const pdfWidth = pdf.internal.pageSize.getWidth();
657
+ const pdfHeight = pdf.internal.pageSize.getHeight();
658
+ // Margins
659
+ const marginLeft = 5;
660
+ const marginTop = 15;
661
+ const marginRight = 5;
662
+ const marginBottom = 15;
663
+ const usableWidth = pdfWidth - marginLeft - marginRight;
664
+ const usableHeight = pdfHeight - marginTop - marginBottom;
665
+ const canvasWidth = canvas.width;
666
+ const canvasHeight = canvas.height;
667
+ const ratio = canvasWidth / usableWidth;
668
+ const pageHeightPx = usableHeight * ratio;
669
+ const totalPages = Math.ceil(canvasHeight / pageHeightPx);
670
+ for (let page = 0; page < totalPages; page++) {
671
+ const canvasPage = document.createElement('canvas');
672
+ canvasPage.width = canvasWidth;
673
+ canvasPage.height = Math.min(pageHeightPx, canvasHeight - page * pageHeightPx);
674
+ const ctx = canvasPage.getContext('2d');
675
+ if (ctx) {
676
+ ctx.fillStyle = '#ffffff';
677
+ ctx.fillRect(0, 0, canvasPage.width, canvasPage.height);
678
+ ctx.drawImage(canvas, 0, page * pageHeightPx, canvasWidth, canvasPage.height, 0, 0, canvasWidth, canvasPage.height);
679
+ }
680
+ const imgData = canvasPage.toDataURL('image/png', 1);
681
+ if (page > 0)
682
+ pdf.addPage();
683
+ const imgHeightMM = canvasPage.height / ratio;
684
+ pdf.addImage(imgData, 'PNG', marginLeft, marginTop, usableWidth, imgHeightMM);
685
+ }
686
+ pdf.save('Final_CBP.pdf');
687
+ this.loading = false;
688
+ }).catch((error) => {
689
+ console.error('PDF generation error:', error);
690
+ this.loading = false;
691
+ });
692
+ }
693
+ downloadPDFNew() {
694
+ this.loading = true;
695
+ const element = this.pdfContent.nativeElement;
696
+ const opt = {
697
+ margin: [10, 5, 5, 10],
698
+ filename: 'CBP_Plan.pdf',
699
+ image: { type: 'jpeg', quality: 0.85 },
700
+ html2canvas: { scale: 1.5, useCORS: true, logging: false },
701
+ jsPDF: { unit: 'mm', format: 'a4', orientation: 'landscape' },
702
+ pagebreak: { mode: ['avoid-all', 'css', 'legacy'] } // avoid cutting text
703
+ };
704
+ html2pdf()
705
+ .set(opt)
706
+ .from(element)
707
+ .save()
708
+ .then(() => {
709
+ // PDF download finished
710
+ this.loading = false;
711
+ })
712
+ .catch(() => {
713
+ // Handle errors and stop loading
714
+ this.loading = false;
715
+ });
716
+ setTimeout(() => {
717
+ this.loading = false;
718
+ }, 2000);
719
+ }
720
+ generateExcel(jsonArray, filename = "final.xlsx") {
721
+ console.log('jsonArray', jsonArray);
722
+ if (!jsonArray || jsonArray.length === 0)
723
+ return;
724
+ // -------- MAIN HEADER FROM FIRST OBJECT ---------
725
+ const firstObj = jsonArray[0];
726
+ let title = firstObj.state_center_name || "";
727
+ if (firstObj.department_name)
728
+ title += " / " + firstObj.department_name;
729
+ // -------- COLUMN HEADERS ---------
730
+ const headers = [
731
+ "Designation",
732
+ "Role & Responsibilities",
733
+ "Activities",
734
+ "Behavioral Competencies",
735
+ "Functional Competencies",
736
+ "Domain Competencies",
737
+ 'courseDetails'
738
+ ];
739
+ // -------- DATA ROWS ---------
740
+ const dataRows = jsonArray.map(json => {
741
+ const courses = json?.cbp_plans?.length
742
+ ? json.cbp_plans[json.cbp_plans.length - 1]?.selected_courses || []
743
+ : [];
744
+ const courseDetails = courses.map((c, i) => {
745
+ const competencies = (c.competencies || [])
746
+ .map((cc) => `${cc.competencyAreaName} → ${cc.competencyThemeName} → ${cc.competencySubThemeName}`)
747
+ .join(" | ");
748
+ return (`${i + 1}. Course Name: ${c.course}\n` +
749
+ ` Identifier: ${c.identifier}\n` +
750
+ ` Duration (mins): ${Math.round(+c.duration / 60)}\n` +
751
+ ` Relevancy: ${c.relevancy}%\n` +
752
+ ` Rationale: ${c.rationale}\n` +
753
+ ` Organisation: ${(c.organisation || []).join(", ")}\n` +
754
+ ` Competencies: ${competencies}`);
755
+ }).join("\n\n");
756
+ return {
757
+ "Designation": `${json.designation_name} : Wing/Division - ${json.wing_division_section}`,
758
+ "Role & Responsibilities": (json.role_responsibilities || [])
759
+ .map((v, i) => `${i + 1}. ${v}`).join("\n\n"),
760
+ "Activities": (json.activities || [])
761
+ .map((v, i) => `${i + 1}. ${v}`).join("\n\n"),
762
+ "Behavioral Competencies": (json.competencies || [])
763
+ .filter((c) => c.type === "Behavioral")
764
+ .map((c, i) => `${i + 1}. ${c.theme} - ${c.sub_theme}`).join("\n\n"),
765
+ "Functional Competencies": (json.competencies || [])
766
+ .filter((c) => c.type === "Functional")
767
+ .map((c, i) => `${i + 1}. ${c.theme} - ${c.sub_theme}`).join("\n\n"),
768
+ "Domain Competencies": (json.competencies || [])
769
+ .filter((c) => c.type === "Domain")
770
+ .map((c, i) => `${i + 1}. ${c.theme} - ${c.sub_theme}`).join("\n\n"),
771
+ "Course Details": courseDetails
772
+ };
773
+ });
774
+ // -------- CREATE WORKSHEET ---------
775
+ const ws = XLSX.utils.aoa_to_sheet([]);
776
+ // Main header (merged)
777
+ XLSX.utils.sheet_add_aoa(ws, [[title]], { origin: "A1" });
778
+ ws['!merges'] = [{
779
+ s: { r: 0, c: 0 },
780
+ e: { r: 0, c: headers.length - 1 }
781
+ }];
782
+ // Column headers at row 2
783
+ XLSX.utils.sheet_add_aoa(ws, [headers], { origin: "A2" });
784
+ // Style column headers
785
+ headers.forEach((header, index) => {
786
+ const cellAddress = XLSX.utils.encode_cell({ r: 1, c: index });
787
+ if (ws[cellAddress]) {
788
+ ws[cellAddress].s = {
789
+ font: { bold: true },
790
+ fill: { patternType: "solid", fgColor: { rgb: "FFFF00" } },
791
+ alignment: { horizontal: "center", vertical: "center", wrapText: true }
792
+ };
793
+ }
794
+ });
795
+ // Insert data rows starting from row 3
796
+ XLSX.utils.sheet_add_json(ws, dataRows, { origin: "A3", skipHeader: true });
797
+ // Auto column widths based on longest line in each column
798
+ const colWidths = headers.map((header, idx) => {
799
+ const maxLen = Math.max(header.length, ...dataRows.map(row => (row[header] || "").split("\n").reduce((a, b) => Math.max(a, b.length), 0)));
800
+ return { wch: Math.min(Math.max(maxLen + 5, 20), 80) }; // min 20, max 80
801
+ });
802
+ ws['!cols'] = colWidths;
803
+ // Wrap text in data rows
804
+ dataRows.forEach((row, rowIndex) => {
805
+ headers.forEach((header, colIndex) => {
806
+ const cellAddress = XLSX.utils.encode_cell({ r: rowIndex + 2, c: colIndex });
807
+ if (ws[cellAddress]) {
808
+ ws[cellAddress].s = { alignment: { wrapText: true, vertical: "top" } };
809
+ }
810
+ });
811
+ });
812
+ // Style main header
813
+ if (ws["A1"]) {
814
+ ws["A1"].s = {
815
+ font: { bold: true, sz: 16 },
816
+ alignment: { horizontal: "center", vertical: "center" }
817
+ };
818
+ }
819
+ // -------- CREATE WORKBOOK ---------
820
+ const wb = XLSX.utils.book_new();
821
+ XLSX.utils.book_append_sheet(wb, ws, "Sheet1");
822
+ // Export Excel
823
+ XLSX.writeFile(wb, filename);
824
+ }
825
+ downloadCSV() {
826
+ let fileName = '';
827
+ if (!this.sharedService?.cbpPlanFinalObj.departments) {
828
+ fileName = `CBP_Report_${this.sharedService?.cbpPlanFinalObj.ministry.identifier}_${this.sharedService?.cbpPlanFinalObj.departments}.xlsx`;
829
+ }
830
+ else {
831
+ fileName = `CBP_Report_${this.sharedService?.cbpPlanFinalObj.ministry.identifier}.xlsx`;
832
+ }
833
+ this.generateExcel(this.jsonData, fileName);
834
+ }
835
+ downloadPdfFromBE(context) {
836
+ let selectedLanguage = this.filterForm.get('language')?.value || 'en';
837
+ this.loading = true;
838
+ // this.sharedService.downloadPdf(this.sharedService?.cbpPlanFinalObj.ministry.identifier)
839
+ if (!this.sharedService?.cbpPlanFinalObj.departments) {
840
+ this.sharedService.downloadPdf(this.sharedService?.cbpPlanFinalObj.ministry.identifier, context, selectedLanguage);
841
+ }
842
+ else {
843
+ this.sharedService.downloadPdfForDepartment(this.sharedService?.cbpPlanFinalObj.ministry.identifier, this.sharedService?.cbpPlanFinalObj.departments, context, selectedLanguage);
844
+ }
845
+ setTimeout(() => {
846
+ this.loading = false;
847
+ }, 5000);
848
+ }
849
+ getSelectedCourses(department) {
850
+ if (!department?.cbp_plans?.length) {
851
+ return [];
852
+ }
853
+ // take latest CBP plan (or adjust logic if needed)
854
+ const latestPlan = department.cbp_plans[department.cbp_plans.length - 1];
855
+ return latestPlan?.selected_courses || [];
856
+ }
857
+ applyFilters() {
858
+ }
859
+ filterList(value, type) {
860
+ const search = value.toLowerCase();
861
+ switch (type) {
862
+ case 'language':
863
+ this.filteredLanguages = this.languages.filter(v => v.label?.toLowerCase().includes(search));
864
+ break;
865
+ }
866
+ }
867
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ViewFinalCbpPlanComponent, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }, { token: i1.MatDialog }, { token: i0.ChangeDetectorRef }, { token: i2.SharedService }, { token: i3.MatSnackBar }, { token: i4.FormBuilder }], target: i0.ɵɵFactoryTarget.Component }); }
868
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ViewFinalCbpPlanComponent, selector: "app-view-final-cbp-plan", viewQueries: [{ propertyName: "pdfContent", first: true, predicate: ["pdfContent"], descendants: true }, { propertyName: "dialogContent", first: true, predicate: ["dialogContent"], descendants: true }], ngImport: i0, template: "<div class=\"view-cbp-plan\" #dialogContent style=\"max-height: 80vh; overflow: auto;\">\n <div class=\"popup-container\">\n <div class=\"popup-header\">\n <div class=\"header-container\">\n <div>\n <div class=\"heading\">View Final <span *ngIf=\"openedFrom === 'cbp'\">CBP</span><span\n *ngIf=\"openedFrom === 'acbp'\">ACBP</span></div>\n </div>\n <div class=\"right-side-container\">\n <div class=\"search-and-buttons-container\">\n <form [formGroup]=\"filterForm\">\n <div>\n <mat-form-field appearance=\"outline\" class=\"language-select\" style=\" height: 34px;\">\n <mat-label style=\"font-weight: normal;\">\n {{ filterForm.get('language')?.value ? '' : 'Select Language' }}\n </mat-label>\n\n <mat-select formControlName=\"language\" panelClass=\"select-search-panel\"\n (selectionChange)=\"applyFilters()\">\n\n <!-- Search box -->\n <input style=\"border:1px solid #ccc; padding: 5px;width: 92%;margin: 5px;\"\n matInput placeholder=\"Search Languages\" (click)=\"$event.stopPropagation()\"\n (keydown)=\"$event.stopPropagation()\"\n (keyup)=\"filterList($any($event.target).value, 'language')\" />\n\n <!-- Values -->\n <mat-option *ngFor=\"let r of filteredLanguages\" [value]=\"r?.code\">\n {{ r?.label }}\n </mat-option>\n\n </mat-select>\n </mat-form-field>\n </div>\n </form>\n </div>\n <div class=\"cursor-pointer\" (click)=\"closeDialog()\">\n <mat-icon>close</mat-icon>\n </div>\n </div>\n </div>\n\n\n\n </div>\n <div class=\"section-container\" #pdfContent>\n <header class=\"bg-white header-border\">\n <div class=\"header-flex justify-between\" style=\"width:100%\">\n <div class=\"flex items-center space-x-4\" style=\"width:50%\">\n <div class=\"image-container\">\n <div>\n <img src=\"assets/icons/dopt-logo.png\" alt=\"Department of Personnel & Training\"\n class=\"h-15\" />\n </div>\n <div>\n <img src=\"assets/icons/CBC_logo.svg\" alt=\"Capacity Building Commission Logo\"\n class=\"h-10\" />\n </div>\n <div>\n <img src=\"assets/icons/karmayogiLogo-min.png\" alt=\"Karmayogi Bharat Logo\"\n class=\"h-10\" />\n </div>\n </div>\n </div>\n <div class=\"text-right\" style=\"width:50%\">\n <h1 class=\"text-2xl font-bold text-gray-900\">\n <span\n *ngIf=\"sharedService?.cbpPlanFinalObj?.ministry?.sbOrgType === 'state'\">{{sharedService?.cbpPlanFinalObj?.ministry?.orgName}}</span>\n <span\n *ngIf=\"sharedService?.cbpPlanFinalObj?.ministry?.sbOrgType === 'ministry'\">{{sharedService?.cbpPlanFinalObj?.ministry?.orgName}}</span>\n <span\n *ngIf=\"sharedService?.cbpPlanFinalObj?.department_name\">/{{sharedService?.cbpPlanFinalObj?.department_name}}</span>\n - Capacity Building Plan\n </h1>\n <p class=\"text-gray-600\">Comprehensive Role-Based Competency Analysis</p>\n </div>\n </div>\n </header>\n <div class=\"min-h-screen bg-gradient-to-br from-slate-50 via-blue-50 to-indigo-100\">\n <!-- Header -->\n\n\n <div class=\"max-w-7xl mx-auto px-6 py-8 mt-4\">\n <!-- KPI Dashboard -->\n <div class=\"competency-container mt-2\">\n <div class=\"outside-layer-total\">\n <div class=\"horizontal-flex mt-2\">\n <div>\n <svg class=\"h-8 w-8 icon-sm\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\"\n stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" viewBox=\"0 0 24 24\">\n <path d=\"M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z\" />\n <path d=\"M14 2v6h6\" />\n <path d=\"M16 13H8\" />\n <path d=\"M16 17H8\" />\n <path d=\"M10 9H8\" />\n </svg>\n </div>\n <div>\n <div class=\"count\">{{totalCompetencieObj?.total}}</div>\n </div>\n </div>\n\n <div class=\"mt-4\">\n <div class=\"sub-heading\">\n <p>Total Competencies</p>\n </div>\n </div>\n <div class=\"progress-bar mt-2\">\n <div class=\"progress-bar-fill\" style=\"width: 60%;\"></div>\n </div>\n <div>\n <div class=\"sub-text\">Total Competencies: {{totalCompetencieObj?.total}}</div>\n </div>\n <div class=\"count\">\n <!-- {{competenciesCount?.total}} -->\n </div>\n </div>\n <div class=\"outside-layer-behavioral\">\n <div class=\"horizontal-flex mt-2\">\n <div>\n <svg class=\"h-8 w-8 icon-sm\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\"\n stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" viewBox=\"0 0 24 24\">\n <path d=\"M15.5 17a4 4 0 0 1-5 0\" />\n <path d=\"M13 14h.01\" />\n <path d=\"M11 11h.01\" />\n <path d=\"M17 14h.01\" />\n <path d=\"M13 10h.01\" />\n <path d=\"M13 18h.01\" />\n <path d=\"M13 6h.01\" />\n <path d=\"M17 18h.01\" />\n <path d=\"M17 6h.01\" />\n <path d=\"M21 12a9 9 0 0 1-9 9a9 9 0 0 1-9-9a9 9 0 0 1 9-9a9 9 0 0 1 9 9z\" />\n </svg>\n </div>\n <div>\n <div class=\"count\">{{totalCompetencieObj?.behavioral}}</div>\n </div>\n </div>\n\n <div class=\"mt-2\">\n <div class=\"sub-heading\">\n <p>Behavioral Competencies</p>\n </div>\n </div>\n <div class=\"progress-bar mt-2\">\n <div class=\"progress-bar-fill-behavioural\" style=\"width: 60%;\"></div>\n </div>\n <div>\n <div class=\"sub-text\">Behavioral Competencies: {{totalCompetencieObj?.behavioral}}\n </div>\n </div>\n\n </div>\n <div class=\"outside-layer-functional\">\n <div class=\"horizontal-flex mt-2\">\n <div>\n <svg class=\"h-8 w-8 icon-sm\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\"\n stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" viewBox=\"0 0 24 24\">\n <path d=\"M2 3h6a4 4 0 0 1 4 4v14a3 3 0 0 0-3-3H2z\" />\n <path d=\"M22 3h-6a4 4 0 0 0-4 4v14a3 3 0 0 1 3-3h7z\" />\n </svg>\n </div>\n <div>\n <div class=\"count\">{{totalCompetencieObj?.functional}}</div>\n </div>\n </div>\n\n <div class=\"mt-2\">\n <div class=\"sub-heading\">\n <p>Functional Competencies</p>\n </div>\n </div>\n <div class=\"progress-bar mt-2\">\n <div class=\"progress-bar-fill-functional\" style=\"width: 60%;\"></div>\n </div>\n <div>\n <div class=\"sub-text\">Functional Competencies: {{totalCompetencieObj?.functional}}</div>\n </div>\n\n\n </div>\n <div class=\"outside-layer-domain\">\n <div class=\"horizontal-flex mt-2\">\n <div>\n <svg class=\"h-8 w-8 icon-sm\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\"\n stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" viewBox=\"0 0 24 24\">\n <circle cx=\"12\" cy=\"12\" r=\"10\" />\n <circle cx=\"12\" cy=\"12\" r=\"6\" />\n <circle cx=\"12\" cy=\"12\" r=\"2\" />\n </svg>\n </div>\n <div>\n <div class=\"count\">{{totalCompetencieObj?.domain}}</div>\n </div>\n </div>\n\n <div class=\"mt-2\">\n <div class=\"sub-heading\">\n <p>Domain Competencies</p>\n </div>\n </div>\n <div class=\"progress-bar mt-2\">\n <div class=\"progress-bar-fill-domain\" style=\"width: 60%;\"></div>\n </div>\n <div>\n <div class=\"sub-text\">Domain Competencies: {{totalCompetencieObj?.domain}}</div>\n </div>\n\n </div>\n </div>\n <!-- <div class=\"mb-8\">\n <h2 class=\"text-2xl font-bold text-gray-900 mb-6nheading\">Competency Overview</h2>\n <div class=\"competency-grid\">\n <ng-container *ngFor=\"let kpi of overallKPIs;\">\n <div class=\"bg-white rounded-xl outside-layer-total p-6 border-l-4 hover:shadow-xl transition-shadow\" [style.border-left-color]=\"kpi.color\">\n <div class=\"flex items-center justify-between mb-4 inside-layer\">\n <div [class]=\"'p-3 rounded-lg ' + kpi.bgColor\">\n <ng-container [ngSwitch]=\"kpi.name\">\n <svg *ngSwitchCase=\"'Behavioral Competencies'\" class=\"h-8 w-8 icon-sm\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" viewBox=\"0 0 24 24\">\n <path d=\"M15.5 17a4 4 0 0 1-5 0\"/>\n <path d=\"M13 14h.01\"/><path d=\"M11 11h.01\"/><path d=\"M17 14h.01\"/><path d=\"M13 10h.01\"/>\n <path d=\"M13 18h.01\"/><path d=\"M13 6h.01\"/><path d=\"M17 18h.01\"/><path d=\"M17 6h.01\"/>\n <path d=\"M21 12a9 9 0 0 1-9 9a9 9 0 0 1-9-9a9 9 0 0 1 9-9a9 9 0 0 1 9 9z\"/>\n </svg>\n \n <svg *ngSwitchCase=\"'Functional Competencies'\" class=\"h-8 w-8 icon-sm\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" viewBox=\"0 0 24 24\">\n <path d=\"M2 3h6a4 4 0 0 1 4 4v14a3 3 0 0 0-3-3H2z\"/><path d=\"M22 3h-6a4 4 0 0 0-4 4v14a3 3 0 0 1 3-3h7z\"/>\n </svg>\n \n <svg *ngSwitchCase=\"'Domain Competencies'\" class=\"h-8 w-8 icon-sm\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" viewBox=\"0 0 24 24\">\n <circle cx=\"12\" cy=\"12\" r=\"10\"/><circle cx=\"12\" cy=\"12\" r=\"6\"/><circle cx=\"12\" cy=\"12\" r=\"2\"/>\n </svg>\n \n <svg *ngSwitchCase=\"'Total Competencies'\" class=\"h-8 w-8 icon-sm\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" viewBox=\"0 0 24 24\">\n <path d=\"M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z\"/>\n <path d=\"M14 2v6h6\"/><path d=\"M16 13H8\"/><path d=\"M16 17H8\"/><path d=\"M10 9H8\"/>\n </svg>\n \n </ng-container>\n </div>\n <div class=\"text-right\">\n <div class=\"text-2xl font-bold text-gray-900\">{{kpi.total}}</div>\n </div>\n </div>\n <h3 class=\"text-gray-900 font-semibold mb-2 heading\">{{kpi.name}}</h3>\n <div class=\"w-full bg-gray-200 rounded-full h-3\">\n <div class=\"h-3 rounded-full transition-all duration-500\"\n [style.width.%]=\"kpi.avgCompletion\"\n [style.background-color]=\"kpi.color\">\n </div>\n </div>\n <p class=\"text-sm text-gray-500 mt-2\">Total Competencies: {{kpi.total}}</p>\n </div>\n </ng-container>\n </div>\n </div> -->\n\n <!-- Designation Reports -->\n <div class=\"space-y-8 mt-4\">\n <h2 class=\"text-2xl font-bold text-gray-900 mb-6 heading\">Detailed Competency Framework by\n Designation</h2>\n\n <ng-container *ngFor=\"let designation of designationData;\">\n <div class=\"bg-white rounded-xl overflow-hidden section-shadow\">\n <!-- Header -->\n <div\n class=\"bg-gradient-to-r from-indigo-600 to-blue-600 text-white p-6 heading-with-bg\">\n <div class=\"flex items-center justify-between\">\n <div>\n <h3 class=\"text-2xl font-bold mb-2 heading-bg\">{{designation.designation}}\n </h3>\n <p class=\"text-indigo-100 mb-1\">Wing/Division: {{designation.wing}}</p>\n </div>\n <div class=\"flex items-center space-x-4 competency-count-by-designation\">\n <span class=\"font-semibold text-sm\">Behavioral:\n {{designation.behavioralCompetencies.length}} total</span>\n <span class=\"font-semibold text-sm\">Functional:\n {{designation.functionalCompetencies.length}} total</span>\n <span class=\"font-semibold text-sm\">Domain:\n {{designation.domainCompetencies.length}} total</span>\n </div>\n </div>\n </div>\n\n <!-- Body -->\n <div class=\"p-4 section-shadow\">\n <!-- Roles -->\n <div class=\"mb-6\">\n <h4 class=\"text-xl font-semibold text-gray-900 mb-3 flex items-center\">\n <svg class=\"h-5 w-5 mr-2 text-indigo-600 icon-sm\" fill=\"none\"\n viewBox=\"0 0 24 24\" stroke=\"currentColor\">\n <path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\"\n d=\"M16 7a4 4 0 11-8 0 4 4 0 018 0zM12 14a7 7 0 00-7 7h14a7 7 0 00-7-7z\" />\n </svg>\n Roles & Responsibilities\n </h4>\n <div class=\"grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-2\">\n <div *ngFor=\"let role of designation.rolesResponsibilities; let i = index\"\n class=\"bg-gray-50 p-2 rounded border-l-3 border-indigo-500\">\n <p class=\"text-sm text-gray-700 leading-relaxed\">{{role}}</p>\n </div>\n </div>\n </div>\n <!-- Activities -->\n <div class=\"mb-6 mt-4\">\n <h4 class=\"text-xl font-semibold text-gray-900 mb-3 flex items-center\">\n <svg class=\"h-5 w-5 mr-2 text-indigo-600 icon-sm\" fill=\"none\"\n viewBox=\"0 0 24 24\" stroke=\"currentColor\">\n <path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\"\n d=\"M16 7a4 4 0 11-8 0 4 4 0 018 0zM12 14a7 7 0 00-7 7h14a7 7 0 00-7-7z\" />\n </svg>\n Activities\n </h4>\n <div class=\"grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-2\">\n <div *ngFor=\"let role of designation.activities; let i = index\"\n class=\"bg-gray-50 p-2 rounded border-l-3 border-indigo-500\">\n <p class=\"text-sm text-gray-700 leading-relaxed\">{{role}}</p>\n </div>\n </div>\n </div>\n <div class=\"page-break\"></div>\n <!-- Competencies -->\n <div class=\"competencis-grid mt-4\">\n <!-- Behavioral -->\n <div class=\"bg-blue-50 rounded-lg p-3 competencies-grid-3\">\n <h4 class=\"font-semibold text-blue-800 text-base mb-2\">Behavioral</h4>\n <div class=\"space-y-1 grid-list-item grid-list-item-behavioral\">\n <div *ngFor=\"let comp of designation.behavioralCompetencies; let i = index\"\n class=\"bg-white p-1.5 rounded text-sm text-gray-700 border-l-2 border-blue-400\">\n {{comp}}\n </div>\n </div>\n <div class=\"mt-2 text-sm text-blue-600 font-medium\">\n {{designation.behavioralCompetencies.length}} total\n </div>\n </div>\n\n <!-- Functional -->\n <div class=\"bg-green-50 rounded-lg p-3 competencies-grid-3\">\n <h4 class=\"font-semibold text-green-800 text-base mb-2\">Functional</h4>\n <div class=\"space-y-1 grid-list-item grid-list-item-functional\">\n <div *ngFor=\"let comp of designation.functionalCompetencies; let i = index\"\n class=\"bg-white p-1.5 rounded text-sm text-gray-700 border-l-2 border-green-400\">\n {{comp}}\n </div>\n </div>\n <div class=\"mt-2 text-sm text-green-600 font-medium\">\n {{designation.functionalCompetencies.length}} total\n </div>\n </div>\n\n <!-- Domain -->\n <div class=\"bg-purple-50 rounded-lg p-3 competencies-grid-3\">\n <h4 class=\"font-semibold text-purple-800 text-base mb-2\">Domain</h4>\n <div class=\"space-y-1 grid-list-item grid-list-item-domain\">\n <div *ngFor=\"let comp of designation.domainCompetencies; let i = index\"\n class=\"bg-white p-1.5 rounded text-sm text-gray-700 border-l-2 border-purple-400\">\n {{comp}}\n </div>\n </div>\n <div class=\"mt-2 text-sm text-purple-600 font-medium\">\n {{designation.domainCompetencies.length}} total\n </div>\n </div>\n </div>\n <!-- Adding courses -->\n <div class=\"cbp mt-4\"\n *ngIf=\"designation.selectedCourses?.length && openedFrom === 'acbp'\">\n <h4 class=\"text-xl font-semibold text-gray-900 mb-3 flex items-center\">\n <svg class=\"h-5 w-5 mr-2 text-indigo-600 icon-sm\" fill=\"none\"\n viewBox=\"0 0 24 24\" stroke=\"currentColor\">\n <path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\"\n d=\"M16 7a4 4 0 11-8 0 4 4 0 018 0zM12 14a7 7 0 00-7 7h14a7 7 0 00-7-7z\" />\n </svg>\n Courses\n </h4>\n <div class=\"course-list-container\">\n <div class=\"course-list-item\"\n *ngFor=\"let item of designation.selectedCourses; 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\n src=\"assets/icons/course.svg\"></span>&nbsp;<span>Course</span>\n </div>\n </div>\n </div>\n\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\n 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\"\n *ngIf=\"item?.platform\">\n <div class=\"ai-recommened-pill-orange-text\">\n <span class=\"ai-loader-icon\"><img\n src=\"assets/icons/ai-loader.gif\"></span>\n <a class=\"cursor-pointer\" [href]=\"item?.public_link\"\n target=\"_blank\"><span>Platform -\n {{item?.platform}}</span></a>\n </div>\n </div>\n <div class=\"ai-recommened-pill-orange mt-2\"\n *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\n 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\"\n *ngIf=\"item?.platform\">\n <div class=\"ai-recommened-pill-orange-text\">\n <span class=\"ai-loader-icon\"><img\n src=\"assets/icons/ai-loader.gif\"></span>\n <a class=\"cursor-pointer\" [href]=\"item?.public_link\"\n target=\"_blank\"><span>Platform -\n {{item?.platform}}</span></a>\n </div>\n </div>\n <div class=\"ai-recommened-pill-orange mt-2\"\n *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\n 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\"\n *ngIf=\"item?.platform\">\n <div class=\"ai-recommened-pill-orange-text\">\n <span class=\"ai-loader-icon\"><img\n src=\"assets/icons/ai-loader.gif\"></span>\n <a class=\"cursor-pointer\" [href]=\"item?.public_link\"\n target=\"_blank\"><span>Platform -\n {{item?.platform}}</span></a>\n </div>\n </div>\n <div class=\"ai-recommened-pill-orange mt-2\"\n *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\"\n *ngIf=\"getCompetenciesByType('Behavioural',item)?.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',item)\">\n <span class=\"competency-text\"> {{ comp.competencyThemeName\n }} -\n {{\n comp.competencySubThemeName }} </span>\n </li>\n <li *ngIf=\"hasMoreThanTwo('Behavioural',item)\"\n class=\"show-more-competency\">\n <span class=\"show-more-link cursor-pointer\"\n (click)=\"toggleCompetencies('Behavioural',item)\">\n {{ isExpanded('Behavioural',item) ? 'Show Less' : '+' +\n getRemainingCount('Behavioural',item) + ' More' }}\n </span>\n </li>\n </ul>\n </div>\n <div class=\"mt-2\"\n *ngIf=\"getCompetenciesByType('Functional',item)?.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',item)\">\n <span class=\"competency-text\"> {{ comp.competencyThemeName\n }} -\n {{\n comp.competencySubThemeName }} </span>\n </li>\n <li *ngIf=\"hasMoreThanTwo('Functional',item)\"\n class=\"show-more-competency\">\n <span class=\"show-more-link cursor-pointer\"\n (click)=\"toggleCompetencies('Functional',item)\">\n {{ isExpanded('Functional',item) ? 'Show Less' : '+' +\n getRemainingCount('Functional',item) + ' More' }}\n </span>\n </li>\n </ul>\n </div>\n <div class=\"mt-2\" *ngIf=\"getCompetenciesByType('Domain',item)?.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',item)\">\n <span class=\"competency-text\"> {{ comp.competencyThemeName\n }} -\n {{\n comp.competencySubThemeName }} </span>\n </li>\n <li *ngIf=\"hasMoreThanTwo('Domain',item)\"\n class=\"show-more-competency\">\n <span class=\"show-more-link cursor-pointer\"\n (click)=\"toggleCompetencies('Domain',item)\">\n {{ isExpanded('Domain',item) ? 'Show Less' : '+' +\n getRemainingCount('Domain',item) + ' 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\">\n {{item?.relevancy}}%</div>\n <div class=\"percentage\" *ngIf=\"!item?.relevancy\">N/A</div>\n </div>\n\n </div>\n\n </div>\n\n </div>\n </div>\n\n <!-- adding courses -->\n </div>\n </div>\n </ng-container>\n </div>\n </div>\n\n <!-- Footer -->\n\n </div>\n <footer class=\"org-footer\">\n <div class=\"max-w-7xl mx-auto px-6 flex flex-col md:flex-row items-center justify-between\">\n <div class=\"flex items-center space-x-4 mb-4 mt-4 md:mb-0 footer-container\">\n <div class=\"footer-logo-container\">\n <img src=\"assets/icons/karmayogiLogo-min.png\" alt=\"Karmayogi Bharat Logo\" class=\"h-10\"\n style=\"margin-left:20px\" />\n </div>\n <div style=\"margin-left: 100px;\">\n <a href=\"https://karmayogibharat.gov.in\" target=\"_blank\" rel=\"noopener noreferrer\"\n class=\"text-sm font-semibold transition-colors\">\n karmayogibharat.gov.in\n </a>\n </div>\n\n\n </div>\n <div class=\"text-sm text-center md:text-right mb-4\" style=\"margin-left: 100px;\">\n <p>&copy; 2025 All Rights Reserved.</p>\n </div>\n </div>\n </footer>\n </div>\n <div class=\"popup-footer\">\n <div>\n <input class=\"btn-active\" type=\"button\" value=\"Download as Excel\" (click)=\"downloadCSV()\" />\n </div>\n <div>\n <input class=\"btn-active\" type=\"button\" value=\"Download as PDF\"\n (click)=\"downloadPdfFromBE(openedFrom)\" />\n </div>\n <div>\n <input class=\"btn-active\" type=\"button\" value=\"Cancel\" (click)=\"cancelForm()\" />\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}.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:14px;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{display:flex;padding:4px 8px;align-items:center;gap:8px;border-radius:var(--Radius-4, 4px);border:1px solid #1B4CA1;background:#1b4ca129}.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:20px;font-style:normal;font-weight:600;line-height:30px}.course-desc{color:#0009;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal}.relevancy,.competencies-matched{color:var(--accessbility-shades-with-opacity-kb-greys-black-60, rgba(0, 0, 0, .6));font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal;align-items:center}.percentage{color:#1d8923;font-family:Lato;font-size:14px;font-style:normal;font-weight:800;line-height:normal}.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}.course-list-item{flex:0 0 48%;box-sizing:border-box;border:1px solid #ccc;padding:16px;background-color:#fff;border-radius:8px}.checked-course-container{display:flex}.ml-2{margin-left:8px}::ng-deep .mat-checkbox-checked .mat-checkbox-background{background:#1b4ca1!important}.ai-recommened-pill-text,.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;flex-direction:row;gap:16px}.outside-layer-total{display:flex;padding:4px 20px;justify-content:left;align-items:left;gap:6px;border-radius:12px;border-left:2px solid #1B4CA1;border-right:2px solid #1B4CA1;background:#edf1f8;flex-direction:column;width:25%}.outside-layer-functional{display:flex;padding:4px 12px;justify-content:left;align-items:left;gap:16px;border-radius:12px;border-left:2px solid #E24577;border-right:2px solid #E24577;background:#f8d2de;flex-direction:column;width:25%}.outside-layer-domain{display:flex;padding:4px 12px;justify-content:left;align-items:left;gap:16px;border-radius:12px;border-left:2px solid #7B47A4;border-right:2px solid #7B47A4;background:#dfd3e9;flex-direction:column;width:25%}.outside-layer-behavioral{display:flex;padding:4px 12px;justify-content:left;align-items:left;gap:16px;border-radius:12px;border-left:2px solid #F8B861;border-right:2px solid #F8B861;background:#fde8cc;flex-direction:column;width:25%}.inside-layer{color:#1b4ca1;font-family:Lato;font-size:12px;font-style:normal;font-weight:400;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:20px;font-style:normal;font-weight:600;line-height:normal;margin:10px 0}.heading-bg{color:#fff;font-family:Montserrat;font-size:20px;font-style:normal;font-weight:600;line-height:normal;margin:10px 0}.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:0 8px;justify-content:center;align-items:center;gap:10px;border-radius:99px;border:1px solid #F8B861;background:linear-gradient(0deg,#f8b86152 0% 100%),#fff;margin:5px 0}.functional-pill{display:flex;padding:0 8px;justify-content:center;align-items:center;gap:10px;border-radius:99px;border:1px solid #E24577;background:linear-gradient(0deg,#e245773d 0% 100%),#fff;margin:5px 0}.domain-pill{display:flex;padding:0 8px;justify-content:center;align-items:center;gap:10px;border-radius:99px;border:1px solid #7B47A4;background:linear-gradient(0deg,#7b47a43d 0% 100%),#fff;margin:5px 0}.popup-header{display:flex;flex-direction:row;justify-content:space-between}.popup-footer{display:flex;flex-direction:row;justify-content:center}.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:center;gap:16px;padding:16px 24px;background-color:#fff;flex-shrink:0;position:sticky;bottom:-15px}.section-container{overflow-y:auto;flex:1 1 auto;display:flex;flex-direction:column;justify-content:center;align-items:center}.competency-list{display:flex;flex-direction:row;gap:16px}.competency-text{color:#000;font-family:Lato;font-size:10px;font-style:normal;font-weight:700;line-height:normal}.competency-sub-heading{color:#1b4ca1;font-family:Montserrat;font-size:12px;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}.grid{display:grid;gap:1.5rem}.grid-cols-1{grid-template-columns:repeat(1,1fr)}@media (min-width: 768px){.md\\:grid-cols-2{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.lg\\:grid-cols-4{grid-template-columns:repeat(4,1fr)}}.kpi-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 14px #0000000d;border-left:4px solid transparent;transition:box-shadow .3s ease}.kpi-card:hover{box-shadow:0 8px 24px #0000001a}.kpi-icon{padding:.75rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center}.kpi-text{font-size:1.25rem;font-weight:700}.progress-container{background:#e5e7eb;height:.75rem;border-radius:9999px;margin-top:.5rem}.progress-bar{height:100%;border-radius:9999px;transition:width .4s ease}.competency-block{background-color:#fff;border-radius:12px;box-shadow:0 2px 10px #0000000f;overflow:hidden}.competency-header{padding:1.5rem;background:linear-gradient(to right,#4f46e5,#3b82f6);color:#fff}.competency-header h3{font-size:1.25rem;font-weight:600}.competency-body{padding:1rem}.role-card{background-color:#f9fafb;padding:.5rem;border-left:4px solid #6366f1;border-radius:6px}.role-title{font-size:1rem;font-weight:600;margin-bottom:.75rem;display:flex;align-items:center;color:#1e40af}.comp-section{border-radius:.5rem;padding:.75rem;background-color:#f0f9ff;margin-bottom:1rem}.comp-section h4{font-weight:600;margin-bottom:.5rem}.comp-item{background-color:#fff;border-left:3px solid #3b82f6;padding:.5rem;border-radius:4px;margin-bottom:.25rem;font-size:.875rem}.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}.text-blue-800{color:#1e3a8a}.text-green-800{color:#ff1493}.text-purple-800{color:#6b21a8}.border-blue-400{border-color:#60a5fa}.border-green-400{border-color:#34d399}.border-purple-400{border-color:#c084fc}.text-sm{font-size:.875rem}.text-gray-700{color:#374151}.icon-sm{width:24px;height:24px}.heading-with-bg{background:#4f46e5;padding:24px;border-radius:8px 8px 0 0}.competencis-grid{display:flex;flex-direction:row;justify-content:space-between;gap:16px}.section-shadow{padding:16px;border-radius:4px;background:#fff;box-shadow:0 2px 4px #0000001a,0 1px 10px #0000000f}.count{color:#1b4ca1;font-family:Montserrat;font-size:16px;font-style:normal;font-weight:600;line-height:normal}.competency-grid{display:flex;flex-direction:row;gap:16px;justify-content:space-between}.text-blue-600{color:#1b4ca1;font-weight:600}.text-green-600{color:#ff1493;font-weight:600}.text-purple-600{color:#6b21a8;font-weight:600}.horizontal-flex{display:flex;align-items:center;justify-content:space-between;width:100%}.progress-bar{width:100%;height:10px;background-color:#e0e0e0;border-radius:10px;overflow:hidden;box-shadow:inset 0 1px 3px #0003}.progress-bar-fill{height:100%;background-color:#1b4ca1;width:0;border-radius:10px 0 0 10px;transition:width .5s ease-in-out}.progress-bar-fill-behavioural{height:100%;background-color:#f8b861;width:0;border-radius:10px 0 0 10px;transition:width .5s ease-in-out}.progress-bar-fill-functional{height:100%;background-color:#e24577;width:0;border-radius:10px 0 0 10px;transition:width .5s ease-in-out}.progress-bar-fill-domain{height:100%;background-color:#7b47a4;width:0;border-radius:10px 0 0 10px;transition:width .5s ease-in-out}.sub-text{font-size:12px;font-weight:600;font-family:Lato}.competency-count-by-designation{display:flex;gap:10px;flex-direction:row}.competencies-grid-3{width:33%}.grid-list-item div{padding:5px 10px;margin:10px 0}.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}.header-flex{display:flex;flex-direction:row;width:100%;justify-content:space-between;gap:30px}.header-border{border-bottom:1px solid #ccc;margin:10px;padding:10px}.text-gray-600{font-family:Lato;font-size:14px;font-weight:600}.image-container .h-10,.image-container .h-15{height:50px}.image-container{display:flex;gap:10px;flex-direction:row}.org-footer{display:flex;flex-direction:row;background:#fff;gap:16px;color:#000;width:100%;justify-content:center;align-items:center;border-top:1px solid #ccc;border-bottom:1px solid #ccc}.dialog-scrollable-content{max-height:70vh;overflow-y:auto}.org-footer a{color:#000!important}h1{font-size:1.75rem!important}@media print{.org-footer,.header-border{page-break-inside:avoid}}.header-border{padding-top:10px;padding-bottom:10px;background-color:#fff}.footer-container{display:flex;justify-content:center;align-items:center;flex-direction:column}.footer-logo-container{display:flex;justify-content:center;align-items:center;flex-direction:row;width:30%}.avoid-page-break{page-break-inside:avoid;break-inside:avoid}.pdf-clean *{box-shadow:none!important;filter:none!important;transform:none!important}.view-cbp-plan.pdf-clean{overflow:visible!important;max-height:none!important}.section-container,.popup-container,.outside-layer-total,.outside-layer-behavioral,.outside-layer-functional,.outside-layer-domain,.section-shadow{page-break-inside:avoid!important;break-inside:avoid!important}.bg-gradient-to-br{background:none!important}.section-container,.outside-layer-total,.outside-layer-behavioral,.outside-layer-functional,.outside-layer-domain,.competencis-grid{page-break-inside:avoid}.page-break{page-break-before:always}.cbp .container{margin:10px auto}.cbp .sub-heading p{color:#000;font-family:Montserrat;font-size:16px;font-style:normal;font-weight:600;line-height:normal}.cbp .ministry-heading{color:#1b4ca1;font-family:Montserrat;font-size:24px;font-style:normal;font-weight:600;line-height:normal}.cbp .radio-label{color:#000;font-family:Lato;font-size:16px;font-style:normal;font-weight:400;line-height:normal}.cbp .radio-btn-group{display:flex;width:32px;height:32px;padding:2px;gap:10px}.cbp .label{color:var(--Body-Text-Body-Color, #212529);font-family:Lato;font-size:16px;font-style:normal;font-weight:700;line-height:150%}.cbp ::ng-deep mat-form-field{background-color:#fff!important;border-radius:25px!important;padding-left:12px;padding-right:12px;height:42px;width:100%}.cbp ::ng-deep mat-select{border-radius:25px!important;background-color:#fff!important}.cbp ::ng-deep .mat-select-panel{background-color:#fff!important}.cbp ::ng-deep .mat-select-panel .mat-option{border-radius:0!important}.cbp ::ng-deep mat-form-field .mat-form-field-underline{display:none!important}.cbp ::ng-deep mat-select .mat-select-placeholder{color:#0006;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal}.cbp ::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}.cbp ::ng-deep mat-select .mat-select-value{display:flex!important;align-items:center!important;height:100%!important}.cbp .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}.cbp .section-header{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.cbp .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}.cbp .btn-group{display:flex;flex-direction:row;justify-content:space-between}.cbp .pl-2{padding-left:5px}.cbp .search-filter-section{display:flex;flex-direction:row;justify-content:space-between}.cbp .search .rsearch{position:relative}.cbp .search .search-icon{position:absolute;top:15px;font-size:20px;left:10px}.cbp .search .sinput{border-radius:32px;border:1px solid #d5d0d0;padding:15px 36px;font:400 14px Lato;width:800px}.cbp .select-map-route-container{display:flex;flex-direction:row}.cbp .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}.cbp .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}.cbp .search-container{display:flex;flex-direction:row}.cbp .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}.cbp .course-header{display:flex;flex-direction:row;justify-content:space-between;width:100%}.cbp .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}.cbp .ai-recommened-pill-green{display:flex;padding:4px 8px;align-items:center;gap:8px;border-radius:var(--Radius-4, 4px);background:#0080001c}.cbp .ai-recommened-pill-green-text{color:#006400;font-family:Lato;font-size:11px;font-style:normal;font-weight:600;line-height:normal}.cbp .ai-recommened-pill-public{display:flex;padding:4px 8px;align-items:center;gap:8px;border-radius:var(--Radius-4, 4px);background:#1b4ca129}.cbp .ai-recommened-pill-public-text{color:#1b4ca1;font-family:Lato;font-size:11px;font-style:normal;font-weight:600;line-height:normal}.cbp .ai-recommened-pill-gray{display:flex;padding:4px 8px;align-items:center;gap:8px;border-radius:var(--Radius-4, 4px);background:#d3d3d3}.cbp .ai-recommened-pill-gray-text{color:#000;font-family:Lato;font-size:11px;font-style:normal;font-weight:600;line-height:normal}.cbp .ai-recommened-pill-orange{display:flex;padding:4px 8px;align-items:center;gap:8px;border-radius:var(--Radius-4, 4px);background:#ffa50052}.cbp .ai-recommened-pill-orange-text{color:#5a3f0d;font-family:Lato;font-size:11px;font-style:normal;font-weight:600;line-height:normal}.cbp .ai-recommened-pill-orange-text a{color:#5a3f0d!important;font-family:Lato;font-size:11px;font-style:normal;font-weight:600;line-height:normal}.cbp .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}.cbp .course-title{color:var(--Primary-KB-Primary-Light, #1B4CA1);font-family:Montserrat;font-size:16px;font-style:normal;font-weight:600;line-height:22px}.cbp .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}.cbp .relevancy,.cbp .competencies-matched{color:#6c757d;font-family:Lato;font-size:12px;font-style:normal;font-weight:500;line-height:normal;align-items:center}.cbp .percentage{color:#1b4ca1;font-family:Lato;font-size:14px;font-style:normal;font-weight:600;line-height:normal}.cbp .delete-button input{background-color:#b60a0a;border-radius:10px}.cbp .relevancy-container,.cbp .competencies-matched-container{display:flex;flex-direction:row;align-items:center}.cbp .dash{padding:0 5px}.cbp ::ng-deep .mat-radio-checked .mat-radio-inner-circle{background:#1b4ca1!important}.cbp .course-list-container{display:flex;flex-wrap:wrap;gap:16px;width:100%;padding:1rem}.cbp .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}.cbp .course-list-item:hover{box-shadow:0 4px 8px #00000026}.cbp .course-list-item:only-child{flex:1 1 auto;max-width:800px}.cbp .checked-course-container{display:flex;width:60%}.cbp .ml-2{margin-left:8px}.cbp ::ng-deep .mat-checkbox-checked .mat-checkbox-background{background:#1b4ca1!important}.cbp .igot-platform-pill-text{color:#1b4ca1;font-family:Lato;font-size:12px;font-style:normal;font-weight:700;line-height:normal}.cbp .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}.cbp .ai-loader-icon img,.cbp .igot-platform-icon img{width:15.714px;height:15.714px;flex-shrink:0}.cbp .competency-container{display:flex;justify-content:normal;gap:16px;flex-direction:row}.cbp .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}.cbp .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}.cbp .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}.cbp .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}.cbp .inside-layer{color:#1b4ca1;font-family:Lato;font-size:16px;font-style:normal;font-weight:400;line-height:normal}.cbp .count{color:#1b4ca1;font-family:Montserrat;font-size:18px;font-style:normal;font-weight:600;line-height:normal}.cbp .suggest-courses-header{display:flex;flex-direction:row;justify-content:space-between}.cbp .suggest-course-control{display:flex;flex-direction:row}.cbp .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}.cbp .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}.cbp .ai-loader-icon-medium img{width:40px;height:40px;flex-shrink:0}.cbp .heading{color:#000;font-family:Montserrat;font-size:16px;font-style:normal;font-weight:600;line-height:normal;margin:10px 0}.cbp .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}.cbp .popup-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid #e0e0e0}.cbp .header-left{flex:1}.cbp .header-actions{display:flex;align-items:center;gap:12px}.cbp .regenerate-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;min-width:auto}.cbp .regenerate-btn .mat-icon{margin:0;font-size:18px;width:18px;height:18px}.cbp .regenerate-btn .mat-spinner{margin:0}.cbp .regenerate-btn:disabled{opacity:.7;cursor:not-allowed}.cbp .close-btn{padding:8px;border-radius:4px;transition:background-color .2s ease}.cbp .close-btn:hover{background-color:#f5f5f5}.cbp .close-btn .mat-icon{font-size:20px;width:20px;height:20px}.cbp .progress-popup{display:flex;flex-direction:column;justify-content:center;align-items:center}.cbp .progress-popup .desc{color:#000000de;text-align:center;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal}.cbp .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}.cbp .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}.cbp .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}.cbp .popup-header{display:flex;flex-direction:row;justify-content:space-between}.cbp .popup-footer{display:flex;flex-direction:row;justify-content:end}.cbp .view-cbp-plan{margin:10px;padding:10px}.cbp .view-cbp-plan-popup{padding:24px;max-height:70vh;overflow-y:auto}.cbp .section{border-radius:8px;background:#1b4ca114;padding:16px}.cbp .popup-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #ddd;font-weight:700;flex-shrink:0}.cbp .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}.cbp .section-container{overflow-y:auto;flex:1 1 auto}.cbp .competency-list{display:flex;flex-direction:row;gap:0px;flex-wrap:wrap;margin:0;padding:0;list-style:none}.cbp .competency-text{color:#000;font-family:Lato;font-size:12px;font-style:normal;font-weight:400;line-height:normal;padding:3px 6px}.cbp .competency-text-behavioral{color:#654321;font-family:Lato;font-size:14px;font-style:normal;line-height:normal;font-weight:550}.cbp .competency-text-functional{color:#b01669;font-family:Lato;font-size:14px;font-style:normal;line-height:normal;font-weight:550}.cbp .competency-text-domain{color:#301934;font-family:Lato;font-size:14px;font-style:normal;line-height:normal;font-weight:550}.cbp .competency-sub-heading{color:#1b4ca1;font-family:Montserrat;font-size:14px;font-style:normal;font-weight:600;line-height:normal}.cbp .cursor-pointer{cursor:pointer}.cbp .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}.cbp .custom-textarea{color:#000;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal}.cbp .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}.cbp .competencis-grid{display:flex;flex-direction:row;justify-content:space-between;gap:16px}.cbp .grid-list-item-behavioral div{border-left:2px solid darkorange}.cbp .grid-list-item-functional div{border-left:2px solid #ff1493}.cbp .grid-list-item-domain div{border-left:2px solid #6b21a8}.cbp .competencies-grid-3{width:33%}.cbp .bg-blue-50{background-color:#fde8cc;border-radius:4px}.cbp .bg-green-50{background-color:#f8d2de;border-radius:4px}.cbp .bg-purple-50{background-color:#dfd3e9;border-radius:4px}.cbp .grid-list-item div{padding:5px 10px;margin:10px 0}.cbp .course-pill-container{display:flex;gap:8px}.cbp .relevancy-pill-green{display:flex;padding:4px 8px;align-items:center;gap:4px;border-radius:16px;border:1px solid #e0e0e0;background:#f8f9fa}.cbp .mt-1{margin-top:.25rem}.cbp .mt-2{margin-top:.5rem}.cbp .mt-3{margin-top:.75rem}.cbp .show-more-competency{display:inline-flex;align-items:center}.cbp .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}.cbp .show-more-link:hover{text-decoration:underline}.cbp .course-content{flex:1;display:flex;flex-direction:column}.cbp .course-footer{margin-top:auto;padding-top:12px;display:flex;justify-content:space-between}.cbp ::ng-deep .mdc-tab__text-label{font-weight:700;font-family:Montserrat!important;font-size:16px;color:#000!important;text-transform:capitalize}.cbp .competency-tag{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;margin-right:.5rem;margin-bottom:.5rem}.cbp .menu-list-item.active{background-color:#1b4ca1;color:#fff}.cbp .menu-list-item:hover{background-color:#1b4ca1;color:#fff;border-color:#1b4ca1}.cbp .gray-bg{background-color:rgb(248,250,252,var(--tw-bg-opacity, 1));border-radius:8px;border:1px solid #ccc}.cbp .div-count{font-family:Lato;font-size:20px;font-weight:700}.cbp .green-bg{background-color:#0080001c;border:1px solid #006400;border-radius:8px}.cbp .div-green-count{font-family:Lato;font-size:20px;font-weight:700;color:#006400}.cbp .div-green-label{color:#006400;font-family:Montserrat;font-size:16px;font-style:normal;font-weight:600;line-height:normal}.cbp .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}.cbp .add-btn{color:#1b4ca1;font-size:14px;font-family:Lato}.cbp .list-flex{display:flex;flex-direction:row;justify-content:space-between}.cbp .all-category-list .mat-icon{vertical-align:middle}.cbp .course-list-container-flex{display:flex;align-items:flex-start;gap:2rem}.cbp .left-panel{flex:0 0 250px;font-weight:700;text-align:left}.cbp .right-panel{flex:1;display:flex;flex-direction:row;flex-wrap:wrap;gap:20px;align-content:flex-start;justify-content:flex-start}.cbp .category-list-item{font-weight:400;font-size:16px;font-family:Lato;padding:5px}.cbp .right-panel-flex{display:flex;flex:0 0 100%;width:100%;flex-direction:row;flex-wrap:wrap;gap:20px;justify-content:flex-start}.cbp .course-list-container-right-flex{display:flex}.cbp .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}.cbp .no-gaps-message .success-icon{font-size:25px;color:#4caf50;margin-bottom:16px}.cbp .no-gaps-message h4{color:#2e7d32;font-family:Montserrat;font-size:20px;font-weight:600;margin:0 0 8px;text-align:center}.cbp .no-gaps-message p{color:#388e3c;font-family:Lato;font-size:14px;font-weight:400;margin:0;text-align:center;line-height:1.5}.cbp .section-header-improved{display:flex;flex-direction:column;gap:16px}.cbp .search-and-buttons-container{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.cbp .search-container-compact{flex:0 0 auto;min-width:280px}.cbp .search-container-compact .rsearch{position:relative;display:flex;align-items:center}.cbp .search-container-compact .search-icon{position:absolute;left:12px;color:#666;font-size:20px;z-index:1}.cbp .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}.cbp .search-container-compact .sinput-compact:focus{outline:none;border-color:#1b4ca1;box-shadow:0 0 0 2px #1b4ca11a}.cbp .search-container-compact .sinput-compact::placeholder{color:#999}.cbp .btn-group-compact{display:flex;gap:8px;flex:0 0 auto}.cbp .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}.cbp .category-list-item:hover{background:#1b4ca10d;border-color:#1b4ca133}.cbp .category-list-item.selected-theme{background:#1b4ca11a;border-color:#1b4ca1;color:#1b4ca1;font-weight:600!important}.cbp .category-list-item.selected-theme:before{content:\"\\2713 \";color:#1b4ca1;font-weight:700}.cbp .theme-filter-controls{margin-bottom:8px}.cbp .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}.cbp .clear-filter-btn:hover{background:#e9ecef;border-color:#adb5bd}.cbp .clear-filter-btn mat-icon{font-size:16px;width:16px;height:16px}.cbp .no-course-found-container{display:flex;justify-content:center;align-items:center;min-height:300px;padding:20px}.cbp .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}.cbp .no-course-card .no-course-icon{margin-bottom:20px}.cbp .no-course-card .no-course-icon mat-icon{font-size:48px;width:48px;height:48px;color:#6c757d}.cbp .no-course-card .no-course-content h4{color:#495057;font-family:Montserrat;font-size:24px;font-weight:600;margin-bottom:12px}.cbp .no-course-card .no-course-content p{color:#6c757d;font-family:Lato;font-size:16px;line-height:1.5;margin-bottom:12px}.cbp .no-course-card .no-course-content p strong{color:#1b4ca1;font-weight:600}.cbp .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}.cbp .no-course-card .suggest-course-btn:hover{background:linear-gradient(135deg,#164080,#0f2f5f);transform:translateY(-2px);box-shadow:0 6px 16px #1b4ca166}.cbp .no-course-card .suggest-course-btn:active{transform:translateY(0)}.cbp .no-course-card .suggest-course-btn mat-icon{font-size:18px;width:18px;height:18px}.cbp .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){.cbp .search-and-buttons-container{flex-direction:column;align-items:stretch}.cbp .search-container-compact{min-width:auto;width:100%}.cbp .btn-group-compact{justify-content:center;flex-wrap:wrap}}@media (max-width: 1200px) and (min-width: 769px){.cbp .course-list-item{flex:1 1 calc(50% - 10px);min-width:300px;max-width:none}}@media (max-width: 768px){.cbp .course-list-container-flex{flex-direction:column}.cbp .left-panel{flex:none!important;max-height:300px}.cbp .course-list-item{flex:0 0 100%;max-width:100%}.cbp .no-course-card{padding:20px}.cbp .no-course-card .no-course-content h4{font-size:20px}.cbp .no-course-card .no-course-content p{font-size:14px}}.cbp ::ng-deep .error-snackbar{background-color:#f44336!important;color:#fff!important;font-weight:500}.cbp ::ng-deep .error-snackbar .mat-simple-snackbar-action{color:#fff!important}.cbp ::ng-deep .session-expired-snackbar{background-color:#ff9800!important;color:#fff!important;font-weight:600}.cbp ::ng-deep .session-expired-snackbar .mat-simple-snackbar-action{color:#fff!important;font-weight:700}.cbp .download-pdf{justify-content:end;display:flex;flex-direction:row}.section-header-improved,.section-header-improved-sec-2{display:flex;flex-direction:row;gap:0px;width:100%}.search-and-buttons-container{display:flex;justify-content:space-between;gap:4px;flex-direction:column;flex-wrap:wrap;width:37%;margin:0 5px}::ng-deep .select-search-panel{border:1px solid #ccc!important;border-radius:12px!important;box-shadow:0 8px 20px #0000001f}:host ::ng-deep .mat-select-arrow-wrapper{margin-top:5px!important}:host ::ng-deep .mat-form-field-appearance-outline .mat-form-field-outline{color:#ccc}:host ::ng-deep .mat-form-field-appearance-outline.mat-focused .mat-form-field-outline-thick{color:#1b4ca1;border-color:#1b4ca1!important}::ng-deep .select-search-panel .mat-option.mat-selected:not(.mat-option-disabled){background-color:#1b4ca1!important;color:#fff!important}:host ::ng-deep .mat-form-field-appearance-outline{border-radius:25px;border:1px solid #ccc}:host ::ng-deep .mat-form-field-focused .mat-form-field-appearance-outline{border-color:#1b4ca1!important}:host ::ng-deep .mat-form-field-appearance-outline .mat-form-field-outline-start{border-radius:25px 0 0 25px;border:none!important}:host ::ng-deep .mat-form-field-appearance-outline .mat-form-field-outline-end{border-right:none!important;border:none!important;border-radius:0 25px 25px 0}:host ::ng-deep .mat-form-field-appearance-outline .mat-form-field-outline-gap{border:none!important;border-radius:25px}:host::ng-deep .mat-form-field-appearance-outline .mat-form-field-infix{background-color:transparent!important}:host ::ng-deep .search-and-buttons-container .mat-option-text{color:#fff!important}.header-container{display:flex;flex-direction:row;justify-content:space-between;width:100%;margin:10px 0}.right-side-container{display:flex;justify-content:space-between;gap:64px}::ng-deep .language-select .mat-select-trigger{font-weight:400!important}::ng-deep .language-select .mat-select-value{color:#fff!important}:host ::ng-deep .select-search-panel .mat-option-text{color:#fff!important}\n"], dependencies: [{ kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "component", type: i6.MatLegacyFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i6.MatLegacyLabel, selector: "mat-label" }, { kind: "directive", type: i7.MatLegacyInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", exportAs: ["matInput"] }, { kind: "component", type: i8.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i9.MatLegacySelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "component", type: i10.MatLegacyOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i11.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }] }); }
869
+ }
870
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ViewFinalCbpPlanComponent, decorators: [{
871
+ type: Component,
872
+ args: [{ selector: 'app-view-final-cbp-plan', template: "<div class=\"view-cbp-plan\" #dialogContent style=\"max-height: 80vh; overflow: auto;\">\n <div class=\"popup-container\">\n <div class=\"popup-header\">\n <div class=\"header-container\">\n <div>\n <div class=\"heading\">View Final <span *ngIf=\"openedFrom === 'cbp'\">CBP</span><span\n *ngIf=\"openedFrom === 'acbp'\">ACBP</span></div>\n </div>\n <div class=\"right-side-container\">\n <div class=\"search-and-buttons-container\">\n <form [formGroup]=\"filterForm\">\n <div>\n <mat-form-field appearance=\"outline\" class=\"language-select\" style=\" height: 34px;\">\n <mat-label style=\"font-weight: normal;\">\n {{ filterForm.get('language')?.value ? '' : 'Select Language' }}\n </mat-label>\n\n <mat-select formControlName=\"language\" panelClass=\"select-search-panel\"\n (selectionChange)=\"applyFilters()\">\n\n <!-- Search box -->\n <input style=\"border:1px solid #ccc; padding: 5px;width: 92%;margin: 5px;\"\n matInput placeholder=\"Search Languages\" (click)=\"$event.stopPropagation()\"\n (keydown)=\"$event.stopPropagation()\"\n (keyup)=\"filterList($any($event.target).value, 'language')\" />\n\n <!-- Values -->\n <mat-option *ngFor=\"let r of filteredLanguages\" [value]=\"r?.code\">\n {{ r?.label }}\n </mat-option>\n\n </mat-select>\n </mat-form-field>\n </div>\n </form>\n </div>\n <div class=\"cursor-pointer\" (click)=\"closeDialog()\">\n <mat-icon>close</mat-icon>\n </div>\n </div>\n </div>\n\n\n\n </div>\n <div class=\"section-container\" #pdfContent>\n <header class=\"bg-white header-border\">\n <div class=\"header-flex justify-between\" style=\"width:100%\">\n <div class=\"flex items-center space-x-4\" style=\"width:50%\">\n <div class=\"image-container\">\n <div>\n <img src=\"assets/icons/dopt-logo.png\" alt=\"Department of Personnel & Training\"\n class=\"h-15\" />\n </div>\n <div>\n <img src=\"assets/icons/CBC_logo.svg\" alt=\"Capacity Building Commission Logo\"\n class=\"h-10\" />\n </div>\n <div>\n <img src=\"assets/icons/karmayogiLogo-min.png\" alt=\"Karmayogi Bharat Logo\"\n class=\"h-10\" />\n </div>\n </div>\n </div>\n <div class=\"text-right\" style=\"width:50%\">\n <h1 class=\"text-2xl font-bold text-gray-900\">\n <span\n *ngIf=\"sharedService?.cbpPlanFinalObj?.ministry?.sbOrgType === 'state'\">{{sharedService?.cbpPlanFinalObj?.ministry?.orgName}}</span>\n <span\n *ngIf=\"sharedService?.cbpPlanFinalObj?.ministry?.sbOrgType === 'ministry'\">{{sharedService?.cbpPlanFinalObj?.ministry?.orgName}}</span>\n <span\n *ngIf=\"sharedService?.cbpPlanFinalObj?.department_name\">/{{sharedService?.cbpPlanFinalObj?.department_name}}</span>\n - Capacity Building Plan\n </h1>\n <p class=\"text-gray-600\">Comprehensive Role-Based Competency Analysis</p>\n </div>\n </div>\n </header>\n <div class=\"min-h-screen bg-gradient-to-br from-slate-50 via-blue-50 to-indigo-100\">\n <!-- Header -->\n\n\n <div class=\"max-w-7xl mx-auto px-6 py-8 mt-4\">\n <!-- KPI Dashboard -->\n <div class=\"competency-container mt-2\">\n <div class=\"outside-layer-total\">\n <div class=\"horizontal-flex mt-2\">\n <div>\n <svg class=\"h-8 w-8 icon-sm\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\"\n stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" viewBox=\"0 0 24 24\">\n <path d=\"M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z\" />\n <path d=\"M14 2v6h6\" />\n <path d=\"M16 13H8\" />\n <path d=\"M16 17H8\" />\n <path d=\"M10 9H8\" />\n </svg>\n </div>\n <div>\n <div class=\"count\">{{totalCompetencieObj?.total}}</div>\n </div>\n </div>\n\n <div class=\"mt-4\">\n <div class=\"sub-heading\">\n <p>Total Competencies</p>\n </div>\n </div>\n <div class=\"progress-bar mt-2\">\n <div class=\"progress-bar-fill\" style=\"width: 60%;\"></div>\n </div>\n <div>\n <div class=\"sub-text\">Total Competencies: {{totalCompetencieObj?.total}}</div>\n </div>\n <div class=\"count\">\n <!-- {{competenciesCount?.total}} -->\n </div>\n </div>\n <div class=\"outside-layer-behavioral\">\n <div class=\"horizontal-flex mt-2\">\n <div>\n <svg class=\"h-8 w-8 icon-sm\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\"\n stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" viewBox=\"0 0 24 24\">\n <path d=\"M15.5 17a4 4 0 0 1-5 0\" />\n <path d=\"M13 14h.01\" />\n <path d=\"M11 11h.01\" />\n <path d=\"M17 14h.01\" />\n <path d=\"M13 10h.01\" />\n <path d=\"M13 18h.01\" />\n <path d=\"M13 6h.01\" />\n <path d=\"M17 18h.01\" />\n <path d=\"M17 6h.01\" />\n <path d=\"M21 12a9 9 0 0 1-9 9a9 9 0 0 1-9-9a9 9 0 0 1 9-9a9 9 0 0 1 9 9z\" />\n </svg>\n </div>\n <div>\n <div class=\"count\">{{totalCompetencieObj?.behavioral}}</div>\n </div>\n </div>\n\n <div class=\"mt-2\">\n <div class=\"sub-heading\">\n <p>Behavioral Competencies</p>\n </div>\n </div>\n <div class=\"progress-bar mt-2\">\n <div class=\"progress-bar-fill-behavioural\" style=\"width: 60%;\"></div>\n </div>\n <div>\n <div class=\"sub-text\">Behavioral Competencies: {{totalCompetencieObj?.behavioral}}\n </div>\n </div>\n\n </div>\n <div class=\"outside-layer-functional\">\n <div class=\"horizontal-flex mt-2\">\n <div>\n <svg class=\"h-8 w-8 icon-sm\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\"\n stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" viewBox=\"0 0 24 24\">\n <path d=\"M2 3h6a4 4 0 0 1 4 4v14a3 3 0 0 0-3-3H2z\" />\n <path d=\"M22 3h-6a4 4 0 0 0-4 4v14a3 3 0 0 1 3-3h7z\" />\n </svg>\n </div>\n <div>\n <div class=\"count\">{{totalCompetencieObj?.functional}}</div>\n </div>\n </div>\n\n <div class=\"mt-2\">\n <div class=\"sub-heading\">\n <p>Functional Competencies</p>\n </div>\n </div>\n <div class=\"progress-bar mt-2\">\n <div class=\"progress-bar-fill-functional\" style=\"width: 60%;\"></div>\n </div>\n <div>\n <div class=\"sub-text\">Functional Competencies: {{totalCompetencieObj?.functional}}</div>\n </div>\n\n\n </div>\n <div class=\"outside-layer-domain\">\n <div class=\"horizontal-flex mt-2\">\n <div>\n <svg class=\"h-8 w-8 icon-sm\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\"\n stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" viewBox=\"0 0 24 24\">\n <circle cx=\"12\" cy=\"12\" r=\"10\" />\n <circle cx=\"12\" cy=\"12\" r=\"6\" />\n <circle cx=\"12\" cy=\"12\" r=\"2\" />\n </svg>\n </div>\n <div>\n <div class=\"count\">{{totalCompetencieObj?.domain}}</div>\n </div>\n </div>\n\n <div class=\"mt-2\">\n <div class=\"sub-heading\">\n <p>Domain Competencies</p>\n </div>\n </div>\n <div class=\"progress-bar mt-2\">\n <div class=\"progress-bar-fill-domain\" style=\"width: 60%;\"></div>\n </div>\n <div>\n <div class=\"sub-text\">Domain Competencies: {{totalCompetencieObj?.domain}}</div>\n </div>\n\n </div>\n </div>\n <!-- <div class=\"mb-8\">\n <h2 class=\"text-2xl font-bold text-gray-900 mb-6nheading\">Competency Overview</h2>\n <div class=\"competency-grid\">\n <ng-container *ngFor=\"let kpi of overallKPIs;\">\n <div class=\"bg-white rounded-xl outside-layer-total p-6 border-l-4 hover:shadow-xl transition-shadow\" [style.border-left-color]=\"kpi.color\">\n <div class=\"flex items-center justify-between mb-4 inside-layer\">\n <div [class]=\"'p-3 rounded-lg ' + kpi.bgColor\">\n <ng-container [ngSwitch]=\"kpi.name\">\n <svg *ngSwitchCase=\"'Behavioral Competencies'\" class=\"h-8 w-8 icon-sm\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" viewBox=\"0 0 24 24\">\n <path d=\"M15.5 17a4 4 0 0 1-5 0\"/>\n <path d=\"M13 14h.01\"/><path d=\"M11 11h.01\"/><path d=\"M17 14h.01\"/><path d=\"M13 10h.01\"/>\n <path d=\"M13 18h.01\"/><path d=\"M13 6h.01\"/><path d=\"M17 18h.01\"/><path d=\"M17 6h.01\"/>\n <path d=\"M21 12a9 9 0 0 1-9 9a9 9 0 0 1-9-9a9 9 0 0 1 9-9a9 9 0 0 1 9 9z\"/>\n </svg>\n \n <svg *ngSwitchCase=\"'Functional Competencies'\" class=\"h-8 w-8 icon-sm\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" viewBox=\"0 0 24 24\">\n <path d=\"M2 3h6a4 4 0 0 1 4 4v14a3 3 0 0 0-3-3H2z\"/><path d=\"M22 3h-6a4 4 0 0 0-4 4v14a3 3 0 0 1 3-3h7z\"/>\n </svg>\n \n <svg *ngSwitchCase=\"'Domain Competencies'\" class=\"h-8 w-8 icon-sm\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" viewBox=\"0 0 24 24\">\n <circle cx=\"12\" cy=\"12\" r=\"10\"/><circle cx=\"12\" cy=\"12\" r=\"6\"/><circle cx=\"12\" cy=\"12\" r=\"2\"/>\n </svg>\n \n <svg *ngSwitchCase=\"'Total Competencies'\" class=\"h-8 w-8 icon-sm\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" viewBox=\"0 0 24 24\">\n <path d=\"M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z\"/>\n <path d=\"M14 2v6h6\"/><path d=\"M16 13H8\"/><path d=\"M16 17H8\"/><path d=\"M10 9H8\"/>\n </svg>\n \n </ng-container>\n </div>\n <div class=\"text-right\">\n <div class=\"text-2xl font-bold text-gray-900\">{{kpi.total}}</div>\n </div>\n </div>\n <h3 class=\"text-gray-900 font-semibold mb-2 heading\">{{kpi.name}}</h3>\n <div class=\"w-full bg-gray-200 rounded-full h-3\">\n <div class=\"h-3 rounded-full transition-all duration-500\"\n [style.width.%]=\"kpi.avgCompletion\"\n [style.background-color]=\"kpi.color\">\n </div>\n </div>\n <p class=\"text-sm text-gray-500 mt-2\">Total Competencies: {{kpi.total}}</p>\n </div>\n </ng-container>\n </div>\n </div> -->\n\n <!-- Designation Reports -->\n <div class=\"space-y-8 mt-4\">\n <h2 class=\"text-2xl font-bold text-gray-900 mb-6 heading\">Detailed Competency Framework by\n Designation</h2>\n\n <ng-container *ngFor=\"let designation of designationData;\">\n <div class=\"bg-white rounded-xl overflow-hidden section-shadow\">\n <!-- Header -->\n <div\n class=\"bg-gradient-to-r from-indigo-600 to-blue-600 text-white p-6 heading-with-bg\">\n <div class=\"flex items-center justify-between\">\n <div>\n <h3 class=\"text-2xl font-bold mb-2 heading-bg\">{{designation.designation}}\n </h3>\n <p class=\"text-indigo-100 mb-1\">Wing/Division: {{designation.wing}}</p>\n </div>\n <div class=\"flex items-center space-x-4 competency-count-by-designation\">\n <span class=\"font-semibold text-sm\">Behavioral:\n {{designation.behavioralCompetencies.length}} total</span>\n <span class=\"font-semibold text-sm\">Functional:\n {{designation.functionalCompetencies.length}} total</span>\n <span class=\"font-semibold text-sm\">Domain:\n {{designation.domainCompetencies.length}} total</span>\n </div>\n </div>\n </div>\n\n <!-- Body -->\n <div class=\"p-4 section-shadow\">\n <!-- Roles -->\n <div class=\"mb-6\">\n <h4 class=\"text-xl font-semibold text-gray-900 mb-3 flex items-center\">\n <svg class=\"h-5 w-5 mr-2 text-indigo-600 icon-sm\" fill=\"none\"\n viewBox=\"0 0 24 24\" stroke=\"currentColor\">\n <path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\"\n d=\"M16 7a4 4 0 11-8 0 4 4 0 018 0zM12 14a7 7 0 00-7 7h14a7 7 0 00-7-7z\" />\n </svg>\n Roles & Responsibilities\n </h4>\n <div class=\"grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-2\">\n <div *ngFor=\"let role of designation.rolesResponsibilities; let i = index\"\n class=\"bg-gray-50 p-2 rounded border-l-3 border-indigo-500\">\n <p class=\"text-sm text-gray-700 leading-relaxed\">{{role}}</p>\n </div>\n </div>\n </div>\n <!-- Activities -->\n <div class=\"mb-6 mt-4\">\n <h4 class=\"text-xl font-semibold text-gray-900 mb-3 flex items-center\">\n <svg class=\"h-5 w-5 mr-2 text-indigo-600 icon-sm\" fill=\"none\"\n viewBox=\"0 0 24 24\" stroke=\"currentColor\">\n <path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\"\n d=\"M16 7a4 4 0 11-8 0 4 4 0 018 0zM12 14a7 7 0 00-7 7h14a7 7 0 00-7-7z\" />\n </svg>\n Activities\n </h4>\n <div class=\"grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-2\">\n <div *ngFor=\"let role of designation.activities; let i = index\"\n class=\"bg-gray-50 p-2 rounded border-l-3 border-indigo-500\">\n <p class=\"text-sm text-gray-700 leading-relaxed\">{{role}}</p>\n </div>\n </div>\n </div>\n <div class=\"page-break\"></div>\n <!-- Competencies -->\n <div class=\"competencis-grid mt-4\">\n <!-- Behavioral -->\n <div class=\"bg-blue-50 rounded-lg p-3 competencies-grid-3\">\n <h4 class=\"font-semibold text-blue-800 text-base mb-2\">Behavioral</h4>\n <div class=\"space-y-1 grid-list-item grid-list-item-behavioral\">\n <div *ngFor=\"let comp of designation.behavioralCompetencies; let i = index\"\n class=\"bg-white p-1.5 rounded text-sm text-gray-700 border-l-2 border-blue-400\">\n {{comp}}\n </div>\n </div>\n <div class=\"mt-2 text-sm text-blue-600 font-medium\">\n {{designation.behavioralCompetencies.length}} total\n </div>\n </div>\n\n <!-- Functional -->\n <div class=\"bg-green-50 rounded-lg p-3 competencies-grid-3\">\n <h4 class=\"font-semibold text-green-800 text-base mb-2\">Functional</h4>\n <div class=\"space-y-1 grid-list-item grid-list-item-functional\">\n <div *ngFor=\"let comp of designation.functionalCompetencies; let i = index\"\n class=\"bg-white p-1.5 rounded text-sm text-gray-700 border-l-2 border-green-400\">\n {{comp}}\n </div>\n </div>\n <div class=\"mt-2 text-sm text-green-600 font-medium\">\n {{designation.functionalCompetencies.length}} total\n </div>\n </div>\n\n <!-- Domain -->\n <div class=\"bg-purple-50 rounded-lg p-3 competencies-grid-3\">\n <h4 class=\"font-semibold text-purple-800 text-base mb-2\">Domain</h4>\n <div class=\"space-y-1 grid-list-item grid-list-item-domain\">\n <div *ngFor=\"let comp of designation.domainCompetencies; let i = index\"\n class=\"bg-white p-1.5 rounded text-sm text-gray-700 border-l-2 border-purple-400\">\n {{comp}}\n </div>\n </div>\n <div class=\"mt-2 text-sm text-purple-600 font-medium\">\n {{designation.domainCompetencies.length}} total\n </div>\n </div>\n </div>\n <!-- Adding courses -->\n <div class=\"cbp mt-4\"\n *ngIf=\"designation.selectedCourses?.length && openedFrom === 'acbp'\">\n <h4 class=\"text-xl font-semibold text-gray-900 mb-3 flex items-center\">\n <svg class=\"h-5 w-5 mr-2 text-indigo-600 icon-sm\" fill=\"none\"\n viewBox=\"0 0 24 24\" stroke=\"currentColor\">\n <path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\"\n d=\"M16 7a4 4 0 11-8 0 4 4 0 018 0zM12 14a7 7 0 00-7 7h14a7 7 0 00-7-7z\" />\n </svg>\n Courses\n </h4>\n <div class=\"course-list-container\">\n <div class=\"course-list-item\"\n *ngFor=\"let item of designation.selectedCourses; 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\n src=\"assets/icons/course.svg\"></span>&nbsp;<span>Course</span>\n </div>\n </div>\n </div>\n\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\n 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\"\n *ngIf=\"item?.platform\">\n <div class=\"ai-recommened-pill-orange-text\">\n <span class=\"ai-loader-icon\"><img\n src=\"assets/icons/ai-loader.gif\"></span>\n <a class=\"cursor-pointer\" [href]=\"item?.public_link\"\n target=\"_blank\"><span>Platform -\n {{item?.platform}}</span></a>\n </div>\n </div>\n <div class=\"ai-recommened-pill-orange mt-2\"\n *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\n 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\"\n *ngIf=\"item?.platform\">\n <div class=\"ai-recommened-pill-orange-text\">\n <span class=\"ai-loader-icon\"><img\n src=\"assets/icons/ai-loader.gif\"></span>\n <a class=\"cursor-pointer\" [href]=\"item?.public_link\"\n target=\"_blank\"><span>Platform -\n {{item?.platform}}</span></a>\n </div>\n </div>\n <div class=\"ai-recommened-pill-orange mt-2\"\n *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\n 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\"\n *ngIf=\"item?.platform\">\n <div class=\"ai-recommened-pill-orange-text\">\n <span class=\"ai-loader-icon\"><img\n src=\"assets/icons/ai-loader.gif\"></span>\n <a class=\"cursor-pointer\" [href]=\"item?.public_link\"\n target=\"_blank\"><span>Platform -\n {{item?.platform}}</span></a>\n </div>\n </div>\n <div class=\"ai-recommened-pill-orange mt-2\"\n *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\"\n *ngIf=\"getCompetenciesByType('Behavioural',item)?.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',item)\">\n <span class=\"competency-text\"> {{ comp.competencyThemeName\n }} -\n {{\n comp.competencySubThemeName }} </span>\n </li>\n <li *ngIf=\"hasMoreThanTwo('Behavioural',item)\"\n class=\"show-more-competency\">\n <span class=\"show-more-link cursor-pointer\"\n (click)=\"toggleCompetencies('Behavioural',item)\">\n {{ isExpanded('Behavioural',item) ? 'Show Less' : '+' +\n getRemainingCount('Behavioural',item) + ' More' }}\n </span>\n </li>\n </ul>\n </div>\n <div class=\"mt-2\"\n *ngIf=\"getCompetenciesByType('Functional',item)?.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',item)\">\n <span class=\"competency-text\"> {{ comp.competencyThemeName\n }} -\n {{\n comp.competencySubThemeName }} </span>\n </li>\n <li *ngIf=\"hasMoreThanTwo('Functional',item)\"\n class=\"show-more-competency\">\n <span class=\"show-more-link cursor-pointer\"\n (click)=\"toggleCompetencies('Functional',item)\">\n {{ isExpanded('Functional',item) ? 'Show Less' : '+' +\n getRemainingCount('Functional',item) + ' More' }}\n </span>\n </li>\n </ul>\n </div>\n <div class=\"mt-2\" *ngIf=\"getCompetenciesByType('Domain',item)?.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',item)\">\n <span class=\"competency-text\"> {{ comp.competencyThemeName\n }} -\n {{\n comp.competencySubThemeName }} </span>\n </li>\n <li *ngIf=\"hasMoreThanTwo('Domain',item)\"\n class=\"show-more-competency\">\n <span class=\"show-more-link cursor-pointer\"\n (click)=\"toggleCompetencies('Domain',item)\">\n {{ isExpanded('Domain',item) ? 'Show Less' : '+' +\n getRemainingCount('Domain',item) + ' 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\">\n {{item?.relevancy}}%</div>\n <div class=\"percentage\" *ngIf=\"!item?.relevancy\">N/A</div>\n </div>\n\n </div>\n\n </div>\n\n </div>\n </div>\n\n <!-- adding courses -->\n </div>\n </div>\n </ng-container>\n </div>\n </div>\n\n <!-- Footer -->\n\n </div>\n <footer class=\"org-footer\">\n <div class=\"max-w-7xl mx-auto px-6 flex flex-col md:flex-row items-center justify-between\">\n <div class=\"flex items-center space-x-4 mb-4 mt-4 md:mb-0 footer-container\">\n <div class=\"footer-logo-container\">\n <img src=\"assets/icons/karmayogiLogo-min.png\" alt=\"Karmayogi Bharat Logo\" class=\"h-10\"\n style=\"margin-left:20px\" />\n </div>\n <div style=\"margin-left: 100px;\">\n <a href=\"https://karmayogibharat.gov.in\" target=\"_blank\" rel=\"noopener noreferrer\"\n class=\"text-sm font-semibold transition-colors\">\n karmayogibharat.gov.in\n </a>\n </div>\n\n\n </div>\n <div class=\"text-sm text-center md:text-right mb-4\" style=\"margin-left: 100px;\">\n <p>&copy; 2025 All Rights Reserved.</p>\n </div>\n </div>\n </footer>\n </div>\n <div class=\"popup-footer\">\n <div>\n <input class=\"btn-active\" type=\"button\" value=\"Download as Excel\" (click)=\"downloadCSV()\" />\n </div>\n <div>\n <input class=\"btn-active\" type=\"button\" value=\"Download as PDF\"\n (click)=\"downloadPdfFromBE(openedFrom)\" />\n </div>\n <div>\n <input class=\"btn-active\" type=\"button\" value=\"Cancel\" (click)=\"cancelForm()\" />\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}.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:14px;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{display:flex;padding:4px 8px;align-items:center;gap:8px;border-radius:var(--Radius-4, 4px);border:1px solid #1B4CA1;background:#1b4ca129}.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:20px;font-style:normal;font-weight:600;line-height:30px}.course-desc{color:#0009;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal}.relevancy,.competencies-matched{color:var(--accessbility-shades-with-opacity-kb-greys-black-60, rgba(0, 0, 0, .6));font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal;align-items:center}.percentage{color:#1d8923;font-family:Lato;font-size:14px;font-style:normal;font-weight:800;line-height:normal}.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}.course-list-item{flex:0 0 48%;box-sizing:border-box;border:1px solid #ccc;padding:16px;background-color:#fff;border-radius:8px}.checked-course-container{display:flex}.ml-2{margin-left:8px}::ng-deep .mat-checkbox-checked .mat-checkbox-background{background:#1b4ca1!important}.ai-recommened-pill-text,.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;flex-direction:row;gap:16px}.outside-layer-total{display:flex;padding:4px 20px;justify-content:left;align-items:left;gap:6px;border-radius:12px;border-left:2px solid #1B4CA1;border-right:2px solid #1B4CA1;background:#edf1f8;flex-direction:column;width:25%}.outside-layer-functional{display:flex;padding:4px 12px;justify-content:left;align-items:left;gap:16px;border-radius:12px;border-left:2px solid #E24577;border-right:2px solid #E24577;background:#f8d2de;flex-direction:column;width:25%}.outside-layer-domain{display:flex;padding:4px 12px;justify-content:left;align-items:left;gap:16px;border-radius:12px;border-left:2px solid #7B47A4;border-right:2px solid #7B47A4;background:#dfd3e9;flex-direction:column;width:25%}.outside-layer-behavioral{display:flex;padding:4px 12px;justify-content:left;align-items:left;gap:16px;border-radius:12px;border-left:2px solid #F8B861;border-right:2px solid #F8B861;background:#fde8cc;flex-direction:column;width:25%}.inside-layer{color:#1b4ca1;font-family:Lato;font-size:12px;font-style:normal;font-weight:400;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:20px;font-style:normal;font-weight:600;line-height:normal;margin:10px 0}.heading-bg{color:#fff;font-family:Montserrat;font-size:20px;font-style:normal;font-weight:600;line-height:normal;margin:10px 0}.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:0 8px;justify-content:center;align-items:center;gap:10px;border-radius:99px;border:1px solid #F8B861;background:linear-gradient(0deg,#f8b86152 0% 100%),#fff;margin:5px 0}.functional-pill{display:flex;padding:0 8px;justify-content:center;align-items:center;gap:10px;border-radius:99px;border:1px solid #E24577;background:linear-gradient(0deg,#e245773d 0% 100%),#fff;margin:5px 0}.domain-pill{display:flex;padding:0 8px;justify-content:center;align-items:center;gap:10px;border-radius:99px;border:1px solid #7B47A4;background:linear-gradient(0deg,#7b47a43d 0% 100%),#fff;margin:5px 0}.popup-header{display:flex;flex-direction:row;justify-content:space-between}.popup-footer{display:flex;flex-direction:row;justify-content:center}.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:center;gap:16px;padding:16px 24px;background-color:#fff;flex-shrink:0;position:sticky;bottom:-15px}.section-container{overflow-y:auto;flex:1 1 auto;display:flex;flex-direction:column;justify-content:center;align-items:center}.competency-list{display:flex;flex-direction:row;gap:16px}.competency-text{color:#000;font-family:Lato;font-size:10px;font-style:normal;font-weight:700;line-height:normal}.competency-sub-heading{color:#1b4ca1;font-family:Montserrat;font-size:12px;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}.grid{display:grid;gap:1.5rem}.grid-cols-1{grid-template-columns:repeat(1,1fr)}@media (min-width: 768px){.md\\:grid-cols-2{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.lg\\:grid-cols-4{grid-template-columns:repeat(4,1fr)}}.kpi-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 14px #0000000d;border-left:4px solid transparent;transition:box-shadow .3s ease}.kpi-card:hover{box-shadow:0 8px 24px #0000001a}.kpi-icon{padding:.75rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center}.kpi-text{font-size:1.25rem;font-weight:700}.progress-container{background:#e5e7eb;height:.75rem;border-radius:9999px;margin-top:.5rem}.progress-bar{height:100%;border-radius:9999px;transition:width .4s ease}.competency-block{background-color:#fff;border-radius:12px;box-shadow:0 2px 10px #0000000f;overflow:hidden}.competency-header{padding:1.5rem;background:linear-gradient(to right,#4f46e5,#3b82f6);color:#fff}.competency-header h3{font-size:1.25rem;font-weight:600}.competency-body{padding:1rem}.role-card{background-color:#f9fafb;padding:.5rem;border-left:4px solid #6366f1;border-radius:6px}.role-title{font-size:1rem;font-weight:600;margin-bottom:.75rem;display:flex;align-items:center;color:#1e40af}.comp-section{border-radius:.5rem;padding:.75rem;background-color:#f0f9ff;margin-bottom:1rem}.comp-section h4{font-weight:600;margin-bottom:.5rem}.comp-item{background-color:#fff;border-left:3px solid #3b82f6;padding:.5rem;border-radius:4px;margin-bottom:.25rem;font-size:.875rem}.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}.text-blue-800{color:#1e3a8a}.text-green-800{color:#ff1493}.text-purple-800{color:#6b21a8}.border-blue-400{border-color:#60a5fa}.border-green-400{border-color:#34d399}.border-purple-400{border-color:#c084fc}.text-sm{font-size:.875rem}.text-gray-700{color:#374151}.icon-sm{width:24px;height:24px}.heading-with-bg{background:#4f46e5;padding:24px;border-radius:8px 8px 0 0}.competencis-grid{display:flex;flex-direction:row;justify-content:space-between;gap:16px}.section-shadow{padding:16px;border-radius:4px;background:#fff;box-shadow:0 2px 4px #0000001a,0 1px 10px #0000000f}.count{color:#1b4ca1;font-family:Montserrat;font-size:16px;font-style:normal;font-weight:600;line-height:normal}.competency-grid{display:flex;flex-direction:row;gap:16px;justify-content:space-between}.text-blue-600{color:#1b4ca1;font-weight:600}.text-green-600{color:#ff1493;font-weight:600}.text-purple-600{color:#6b21a8;font-weight:600}.horizontal-flex{display:flex;align-items:center;justify-content:space-between;width:100%}.progress-bar{width:100%;height:10px;background-color:#e0e0e0;border-radius:10px;overflow:hidden;box-shadow:inset 0 1px 3px #0003}.progress-bar-fill{height:100%;background-color:#1b4ca1;width:0;border-radius:10px 0 0 10px;transition:width .5s ease-in-out}.progress-bar-fill-behavioural{height:100%;background-color:#f8b861;width:0;border-radius:10px 0 0 10px;transition:width .5s ease-in-out}.progress-bar-fill-functional{height:100%;background-color:#e24577;width:0;border-radius:10px 0 0 10px;transition:width .5s ease-in-out}.progress-bar-fill-domain{height:100%;background-color:#7b47a4;width:0;border-radius:10px 0 0 10px;transition:width .5s ease-in-out}.sub-text{font-size:12px;font-weight:600;font-family:Lato}.competency-count-by-designation{display:flex;gap:10px;flex-direction:row}.competencies-grid-3{width:33%}.grid-list-item div{padding:5px 10px;margin:10px 0}.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}.header-flex{display:flex;flex-direction:row;width:100%;justify-content:space-between;gap:30px}.header-border{border-bottom:1px solid #ccc;margin:10px;padding:10px}.text-gray-600{font-family:Lato;font-size:14px;font-weight:600}.image-container .h-10,.image-container .h-15{height:50px}.image-container{display:flex;gap:10px;flex-direction:row}.org-footer{display:flex;flex-direction:row;background:#fff;gap:16px;color:#000;width:100%;justify-content:center;align-items:center;border-top:1px solid #ccc;border-bottom:1px solid #ccc}.dialog-scrollable-content{max-height:70vh;overflow-y:auto}.org-footer a{color:#000!important}h1{font-size:1.75rem!important}@media print{.org-footer,.header-border{page-break-inside:avoid}}.header-border{padding-top:10px;padding-bottom:10px;background-color:#fff}.footer-container{display:flex;justify-content:center;align-items:center;flex-direction:column}.footer-logo-container{display:flex;justify-content:center;align-items:center;flex-direction:row;width:30%}.avoid-page-break{page-break-inside:avoid;break-inside:avoid}.pdf-clean *{box-shadow:none!important;filter:none!important;transform:none!important}.view-cbp-plan.pdf-clean{overflow:visible!important;max-height:none!important}.section-container,.popup-container,.outside-layer-total,.outside-layer-behavioral,.outside-layer-functional,.outside-layer-domain,.section-shadow{page-break-inside:avoid!important;break-inside:avoid!important}.bg-gradient-to-br{background:none!important}.section-container,.outside-layer-total,.outside-layer-behavioral,.outside-layer-functional,.outside-layer-domain,.competencis-grid{page-break-inside:avoid}.page-break{page-break-before:always}.cbp .container{margin:10px auto}.cbp .sub-heading p{color:#000;font-family:Montserrat;font-size:16px;font-style:normal;font-weight:600;line-height:normal}.cbp .ministry-heading{color:#1b4ca1;font-family:Montserrat;font-size:24px;font-style:normal;font-weight:600;line-height:normal}.cbp .radio-label{color:#000;font-family:Lato;font-size:16px;font-style:normal;font-weight:400;line-height:normal}.cbp .radio-btn-group{display:flex;width:32px;height:32px;padding:2px;gap:10px}.cbp .label{color:var(--Body-Text-Body-Color, #212529);font-family:Lato;font-size:16px;font-style:normal;font-weight:700;line-height:150%}.cbp ::ng-deep mat-form-field{background-color:#fff!important;border-radius:25px!important;padding-left:12px;padding-right:12px;height:42px;width:100%}.cbp ::ng-deep mat-select{border-radius:25px!important;background-color:#fff!important}.cbp ::ng-deep .mat-select-panel{background-color:#fff!important}.cbp ::ng-deep .mat-select-panel .mat-option{border-radius:0!important}.cbp ::ng-deep mat-form-field .mat-form-field-underline{display:none!important}.cbp ::ng-deep mat-select .mat-select-placeholder{color:#0006;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal}.cbp ::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}.cbp ::ng-deep mat-select .mat-select-value{display:flex!important;align-items:center!important;height:100%!important}.cbp .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}.cbp .section-header{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.cbp .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}.cbp .btn-group{display:flex;flex-direction:row;justify-content:space-between}.cbp .pl-2{padding-left:5px}.cbp .search-filter-section{display:flex;flex-direction:row;justify-content:space-between}.cbp .search .rsearch{position:relative}.cbp .search .search-icon{position:absolute;top:15px;font-size:20px;left:10px}.cbp .search .sinput{border-radius:32px;border:1px solid #d5d0d0;padding:15px 36px;font:400 14px Lato;width:800px}.cbp .select-map-route-container{display:flex;flex-direction:row}.cbp .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}.cbp .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}.cbp .search-container{display:flex;flex-direction:row}.cbp .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}.cbp .course-header{display:flex;flex-direction:row;justify-content:space-between;width:100%}.cbp .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}.cbp .ai-recommened-pill-green{display:flex;padding:4px 8px;align-items:center;gap:8px;border-radius:var(--Radius-4, 4px);background:#0080001c}.cbp .ai-recommened-pill-green-text{color:#006400;font-family:Lato;font-size:11px;font-style:normal;font-weight:600;line-height:normal}.cbp .ai-recommened-pill-public{display:flex;padding:4px 8px;align-items:center;gap:8px;border-radius:var(--Radius-4, 4px);background:#1b4ca129}.cbp .ai-recommened-pill-public-text{color:#1b4ca1;font-family:Lato;font-size:11px;font-style:normal;font-weight:600;line-height:normal}.cbp .ai-recommened-pill-gray{display:flex;padding:4px 8px;align-items:center;gap:8px;border-radius:var(--Radius-4, 4px);background:#d3d3d3}.cbp .ai-recommened-pill-gray-text{color:#000;font-family:Lato;font-size:11px;font-style:normal;font-weight:600;line-height:normal}.cbp .ai-recommened-pill-orange{display:flex;padding:4px 8px;align-items:center;gap:8px;border-radius:var(--Radius-4, 4px);background:#ffa50052}.cbp .ai-recommened-pill-orange-text{color:#5a3f0d;font-family:Lato;font-size:11px;font-style:normal;font-weight:600;line-height:normal}.cbp .ai-recommened-pill-orange-text a{color:#5a3f0d!important;font-family:Lato;font-size:11px;font-style:normal;font-weight:600;line-height:normal}.cbp .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}.cbp .course-title{color:var(--Primary-KB-Primary-Light, #1B4CA1);font-family:Montserrat;font-size:16px;font-style:normal;font-weight:600;line-height:22px}.cbp .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}.cbp .relevancy,.cbp .competencies-matched{color:#6c757d;font-family:Lato;font-size:12px;font-style:normal;font-weight:500;line-height:normal;align-items:center}.cbp .percentage{color:#1b4ca1;font-family:Lato;font-size:14px;font-style:normal;font-weight:600;line-height:normal}.cbp .delete-button input{background-color:#b60a0a;border-radius:10px}.cbp .relevancy-container,.cbp .competencies-matched-container{display:flex;flex-direction:row;align-items:center}.cbp .dash{padding:0 5px}.cbp ::ng-deep .mat-radio-checked .mat-radio-inner-circle{background:#1b4ca1!important}.cbp .course-list-container{display:flex;flex-wrap:wrap;gap:16px;width:100%;padding:1rem}.cbp .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}.cbp .course-list-item:hover{box-shadow:0 4px 8px #00000026}.cbp .course-list-item:only-child{flex:1 1 auto;max-width:800px}.cbp .checked-course-container{display:flex;width:60%}.cbp .ml-2{margin-left:8px}.cbp ::ng-deep .mat-checkbox-checked .mat-checkbox-background{background:#1b4ca1!important}.cbp .igot-platform-pill-text{color:#1b4ca1;font-family:Lato;font-size:12px;font-style:normal;font-weight:700;line-height:normal}.cbp .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}.cbp .ai-loader-icon img,.cbp .igot-platform-icon img{width:15.714px;height:15.714px;flex-shrink:0}.cbp .competency-container{display:flex;justify-content:normal;gap:16px;flex-direction:row}.cbp .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}.cbp .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}.cbp .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}.cbp .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}.cbp .inside-layer{color:#1b4ca1;font-family:Lato;font-size:16px;font-style:normal;font-weight:400;line-height:normal}.cbp .count{color:#1b4ca1;font-family:Montserrat;font-size:18px;font-style:normal;font-weight:600;line-height:normal}.cbp .suggest-courses-header{display:flex;flex-direction:row;justify-content:space-between}.cbp .suggest-course-control{display:flex;flex-direction:row}.cbp .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}.cbp .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}.cbp .ai-loader-icon-medium img{width:40px;height:40px;flex-shrink:0}.cbp .heading{color:#000;font-family:Montserrat;font-size:16px;font-style:normal;font-weight:600;line-height:normal;margin:10px 0}.cbp .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}.cbp .popup-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid #e0e0e0}.cbp .header-left{flex:1}.cbp .header-actions{display:flex;align-items:center;gap:12px}.cbp .regenerate-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;min-width:auto}.cbp .regenerate-btn .mat-icon{margin:0;font-size:18px;width:18px;height:18px}.cbp .regenerate-btn .mat-spinner{margin:0}.cbp .regenerate-btn:disabled{opacity:.7;cursor:not-allowed}.cbp .close-btn{padding:8px;border-radius:4px;transition:background-color .2s ease}.cbp .close-btn:hover{background-color:#f5f5f5}.cbp .close-btn .mat-icon{font-size:20px;width:20px;height:20px}.cbp .progress-popup{display:flex;flex-direction:column;justify-content:center;align-items:center}.cbp .progress-popup .desc{color:#000000de;text-align:center;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal}.cbp .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}.cbp .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}.cbp .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}.cbp .popup-header{display:flex;flex-direction:row;justify-content:space-between}.cbp .popup-footer{display:flex;flex-direction:row;justify-content:end}.cbp .view-cbp-plan{margin:10px;padding:10px}.cbp .view-cbp-plan-popup{padding:24px;max-height:70vh;overflow-y:auto}.cbp .section{border-radius:8px;background:#1b4ca114;padding:16px}.cbp .popup-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #ddd;font-weight:700;flex-shrink:0}.cbp .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}.cbp .section-container{overflow-y:auto;flex:1 1 auto}.cbp .competency-list{display:flex;flex-direction:row;gap:0px;flex-wrap:wrap;margin:0;padding:0;list-style:none}.cbp .competency-text{color:#000;font-family:Lato;font-size:12px;font-style:normal;font-weight:400;line-height:normal;padding:3px 6px}.cbp .competency-text-behavioral{color:#654321;font-family:Lato;font-size:14px;font-style:normal;line-height:normal;font-weight:550}.cbp .competency-text-functional{color:#b01669;font-family:Lato;font-size:14px;font-style:normal;line-height:normal;font-weight:550}.cbp .competency-text-domain{color:#301934;font-family:Lato;font-size:14px;font-style:normal;line-height:normal;font-weight:550}.cbp .competency-sub-heading{color:#1b4ca1;font-family:Montserrat;font-size:14px;font-style:normal;font-weight:600;line-height:normal}.cbp .cursor-pointer{cursor:pointer}.cbp .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}.cbp .custom-textarea{color:#000;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal}.cbp .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}.cbp .competencis-grid{display:flex;flex-direction:row;justify-content:space-between;gap:16px}.cbp .grid-list-item-behavioral div{border-left:2px solid darkorange}.cbp .grid-list-item-functional div{border-left:2px solid #ff1493}.cbp .grid-list-item-domain div{border-left:2px solid #6b21a8}.cbp .competencies-grid-3{width:33%}.cbp .bg-blue-50{background-color:#fde8cc;border-radius:4px}.cbp .bg-green-50{background-color:#f8d2de;border-radius:4px}.cbp .bg-purple-50{background-color:#dfd3e9;border-radius:4px}.cbp .grid-list-item div{padding:5px 10px;margin:10px 0}.cbp .course-pill-container{display:flex;gap:8px}.cbp .relevancy-pill-green{display:flex;padding:4px 8px;align-items:center;gap:4px;border-radius:16px;border:1px solid #e0e0e0;background:#f8f9fa}.cbp .mt-1{margin-top:.25rem}.cbp .mt-2{margin-top:.5rem}.cbp .mt-3{margin-top:.75rem}.cbp .show-more-competency{display:inline-flex;align-items:center}.cbp .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}.cbp .show-more-link:hover{text-decoration:underline}.cbp .course-content{flex:1;display:flex;flex-direction:column}.cbp .course-footer{margin-top:auto;padding-top:12px;display:flex;justify-content:space-between}.cbp ::ng-deep .mdc-tab__text-label{font-weight:700;font-family:Montserrat!important;font-size:16px;color:#000!important;text-transform:capitalize}.cbp .competency-tag{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;margin-right:.5rem;margin-bottom:.5rem}.cbp .menu-list-item.active{background-color:#1b4ca1;color:#fff}.cbp .menu-list-item:hover{background-color:#1b4ca1;color:#fff;border-color:#1b4ca1}.cbp .gray-bg{background-color:rgb(248,250,252,var(--tw-bg-opacity, 1));border-radius:8px;border:1px solid #ccc}.cbp .div-count{font-family:Lato;font-size:20px;font-weight:700}.cbp .green-bg{background-color:#0080001c;border:1px solid #006400;border-radius:8px}.cbp .div-green-count{font-family:Lato;font-size:20px;font-weight:700;color:#006400}.cbp .div-green-label{color:#006400;font-family:Montserrat;font-size:16px;font-style:normal;font-weight:600;line-height:normal}.cbp .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}.cbp .add-btn{color:#1b4ca1;font-size:14px;font-family:Lato}.cbp .list-flex{display:flex;flex-direction:row;justify-content:space-between}.cbp .all-category-list .mat-icon{vertical-align:middle}.cbp .course-list-container-flex{display:flex;align-items:flex-start;gap:2rem}.cbp .left-panel{flex:0 0 250px;font-weight:700;text-align:left}.cbp .right-panel{flex:1;display:flex;flex-direction:row;flex-wrap:wrap;gap:20px;align-content:flex-start;justify-content:flex-start}.cbp .category-list-item{font-weight:400;font-size:16px;font-family:Lato;padding:5px}.cbp .right-panel-flex{display:flex;flex:0 0 100%;width:100%;flex-direction:row;flex-wrap:wrap;gap:20px;justify-content:flex-start}.cbp .course-list-container-right-flex{display:flex}.cbp .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}.cbp .no-gaps-message .success-icon{font-size:25px;color:#4caf50;margin-bottom:16px}.cbp .no-gaps-message h4{color:#2e7d32;font-family:Montserrat;font-size:20px;font-weight:600;margin:0 0 8px;text-align:center}.cbp .no-gaps-message p{color:#388e3c;font-family:Lato;font-size:14px;font-weight:400;margin:0;text-align:center;line-height:1.5}.cbp .section-header-improved{display:flex;flex-direction:column;gap:16px}.cbp .search-and-buttons-container{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.cbp .search-container-compact{flex:0 0 auto;min-width:280px}.cbp .search-container-compact .rsearch{position:relative;display:flex;align-items:center}.cbp .search-container-compact .search-icon{position:absolute;left:12px;color:#666;font-size:20px;z-index:1}.cbp .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}.cbp .search-container-compact .sinput-compact:focus{outline:none;border-color:#1b4ca1;box-shadow:0 0 0 2px #1b4ca11a}.cbp .search-container-compact .sinput-compact::placeholder{color:#999}.cbp .btn-group-compact{display:flex;gap:8px;flex:0 0 auto}.cbp .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}.cbp .category-list-item:hover{background:#1b4ca10d;border-color:#1b4ca133}.cbp .category-list-item.selected-theme{background:#1b4ca11a;border-color:#1b4ca1;color:#1b4ca1;font-weight:600!important}.cbp .category-list-item.selected-theme:before{content:\"\\2713 \";color:#1b4ca1;font-weight:700}.cbp .theme-filter-controls{margin-bottom:8px}.cbp .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}.cbp .clear-filter-btn:hover{background:#e9ecef;border-color:#adb5bd}.cbp .clear-filter-btn mat-icon{font-size:16px;width:16px;height:16px}.cbp .no-course-found-container{display:flex;justify-content:center;align-items:center;min-height:300px;padding:20px}.cbp .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}.cbp .no-course-card .no-course-icon{margin-bottom:20px}.cbp .no-course-card .no-course-icon mat-icon{font-size:48px;width:48px;height:48px;color:#6c757d}.cbp .no-course-card .no-course-content h4{color:#495057;font-family:Montserrat;font-size:24px;font-weight:600;margin-bottom:12px}.cbp .no-course-card .no-course-content p{color:#6c757d;font-family:Lato;font-size:16px;line-height:1.5;margin-bottom:12px}.cbp .no-course-card .no-course-content p strong{color:#1b4ca1;font-weight:600}.cbp .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}.cbp .no-course-card .suggest-course-btn:hover{background:linear-gradient(135deg,#164080,#0f2f5f);transform:translateY(-2px);box-shadow:0 6px 16px #1b4ca166}.cbp .no-course-card .suggest-course-btn:active{transform:translateY(0)}.cbp .no-course-card .suggest-course-btn mat-icon{font-size:18px;width:18px;height:18px}.cbp .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){.cbp .search-and-buttons-container{flex-direction:column;align-items:stretch}.cbp .search-container-compact{min-width:auto;width:100%}.cbp .btn-group-compact{justify-content:center;flex-wrap:wrap}}@media (max-width: 1200px) and (min-width: 769px){.cbp .course-list-item{flex:1 1 calc(50% - 10px);min-width:300px;max-width:none}}@media (max-width: 768px){.cbp .course-list-container-flex{flex-direction:column}.cbp .left-panel{flex:none!important;max-height:300px}.cbp .course-list-item{flex:0 0 100%;max-width:100%}.cbp .no-course-card{padding:20px}.cbp .no-course-card .no-course-content h4{font-size:20px}.cbp .no-course-card .no-course-content p{font-size:14px}}.cbp ::ng-deep .error-snackbar{background-color:#f44336!important;color:#fff!important;font-weight:500}.cbp ::ng-deep .error-snackbar .mat-simple-snackbar-action{color:#fff!important}.cbp ::ng-deep .session-expired-snackbar{background-color:#ff9800!important;color:#fff!important;font-weight:600}.cbp ::ng-deep .session-expired-snackbar .mat-simple-snackbar-action{color:#fff!important;font-weight:700}.cbp .download-pdf{justify-content:end;display:flex;flex-direction:row}.section-header-improved,.section-header-improved-sec-2{display:flex;flex-direction:row;gap:0px;width:100%}.search-and-buttons-container{display:flex;justify-content:space-between;gap:4px;flex-direction:column;flex-wrap:wrap;width:37%;margin:0 5px}::ng-deep .select-search-panel{border:1px solid #ccc!important;border-radius:12px!important;box-shadow:0 8px 20px #0000001f}:host ::ng-deep .mat-select-arrow-wrapper{margin-top:5px!important}:host ::ng-deep .mat-form-field-appearance-outline .mat-form-field-outline{color:#ccc}:host ::ng-deep .mat-form-field-appearance-outline.mat-focused .mat-form-field-outline-thick{color:#1b4ca1;border-color:#1b4ca1!important}::ng-deep .select-search-panel .mat-option.mat-selected:not(.mat-option-disabled){background-color:#1b4ca1!important;color:#fff!important}:host ::ng-deep .mat-form-field-appearance-outline{border-radius:25px;border:1px solid #ccc}:host ::ng-deep .mat-form-field-focused .mat-form-field-appearance-outline{border-color:#1b4ca1!important}:host ::ng-deep .mat-form-field-appearance-outline .mat-form-field-outline-start{border-radius:25px 0 0 25px;border:none!important}:host ::ng-deep .mat-form-field-appearance-outline .mat-form-field-outline-end{border-right:none!important;border:none!important;border-radius:0 25px 25px 0}:host ::ng-deep .mat-form-field-appearance-outline .mat-form-field-outline-gap{border:none!important;border-radius:25px}:host::ng-deep .mat-form-field-appearance-outline .mat-form-field-infix{background-color:transparent!important}:host ::ng-deep .search-and-buttons-container .mat-option-text{color:#fff!important}.header-container{display:flex;flex-direction:row;justify-content:space-between;width:100%;margin:10px 0}.right-side-container{display:flex;justify-content:space-between;gap:64px}::ng-deep .language-select .mat-select-trigger{font-weight:400!important}::ng-deep .language-select .mat-select-value{color:#fff!important}:host ::ng-deep .select-search-panel .mat-option-text{color:#fff!important}\n"] }]
873
+ }], ctorParameters: function () { return [{ type: i1.MatDialogRef }, { type: undefined, decorators: [{
874
+ type: Inject,
875
+ args: [MAT_DIALOG_DATA]
876
+ }] }, { type: i1.MatDialog }, { type: i0.ChangeDetectorRef }, { type: i2.SharedService }, { type: i3.MatSnackBar }, { type: i4.FormBuilder }]; }, propDecorators: { pdfContent: [{
877
+ type: ViewChild,
878
+ args: ['pdfContent', { static: false }]
879
+ }], dialogContent: [{
880
+ type: ViewChild,
881
+ args: ['dialogContent']
882
+ }] } });
883
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"view-final-cbp-plan.component.js","sourceRoot":"","sources":["../../../../../../../library/sunbird-cb/cbp-ai/src/lib/components/view-final-cbp-plan/view-final-cbp-plan.component.ts","../../../../../../../library/sunbird-cb/cbp-ai/src/lib/components/view-final-cbp-plan/view-final-cbp-plan.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ChangeDetectorRef, ElementRef, Inject, ViewChild } from '@angular/core';\nimport { MAT_DIALOG_DATA, MatDialog, MatDialogRef } from '@angular/material/dialog';\nimport html2pdf from 'html2pdf.js';\nimport jsPDF from 'jspdf';\nimport html2canvas from 'html2canvas';\nimport { MatSnackBar } from '@angular/material/snack-bar';\nimport * as XLSX from 'xlsx';\nimport { DeleteRoleMappingPopupComponent } from '../delete-role-mapping-popup/delete-role-mapping-popup.component';\nimport { FormBuilder, FormGroup } from '@angular/forms';\nimport { SharedService } from '../../modules/shared/services/shared.service';\n@Component({\n  selector: 'app-view-final-cbp-plan',\n  templateUrl: './view-final-cbp-plan.component.html',\n  styleUrls: ['./view-final-cbp-plan.component.scss']\n})\nexport class ViewFinalCbpPlanComponent {\n  constructor(\n    public dialogRef: MatDialogRef<ViewFinalCbpPlanComponent>,\n    @Inject(MAT_DIALOG_DATA) public data: any,\n    private dialog: MatDialog,\n    private cdr: ChangeDetectorRef,\n    public sharedService: SharedService,\n    private snackBar: MatSnackBar,\n    private fb: FormBuilder\n  ) {\n    this.filterForm = this.fb.group({\n      language: ['en']\n    });\n    this.openedFrom = data?.openedFrom;\n    this.getMappingData()\n  }\n  filterForm!: FormGroup;\n  languages = [{ \"code\": \"en\", label: \"English\" },\n  { \"code\": \"hi\", label: \"Hindi\" },\n  { \"code\": \"te\", label: \"Telugu\" },\n  { \"code\": \"kn\", label: \"Kannada\" },\n  { \"code\": \"mr\", label: \"Marathi\" },\n  { \"code\": \"ta\", label: \"Tamil\" },\n  { \"code\": \"gu\", label: \"Gujarati\" },\n  { \"code\": \"ml\", label: \"Malayalam\" },\n  { \"code\": \"bn\", label: \"Bengali\" },];\n  filteredLanguages = [...this.languages];\n  @ViewChild('pdfContent', { static: false }) pdfContent!: ElementRef;\n  loading = false\n  designationData: any = []\n  totalCompetencieObj = { total: 0, behavioral: 0, functional: 0, domain: 0 }\n  pdfTrigger = false\n  jsonData = []\n  filterdCourses = [];\n  planData: any\n  recommended_course_id = ''\n  expandedCompetencies: any = {};\n  competenciesCount = { total: 0, public_courses: 0, igot: 0 };\n  openedFrom!: string;\n  @ViewChild('dialogContent') dialogContent!: ElementRef;\n  // designationData = [\n  //   {\n  //     designation: \"Secretary (WCD)\",\n  //     wing: \"Ministry Leadership\",\n  //     updated: \"10/09/2025\",\n  //     rolesResponsibilities: [\n  //       \"Provide overall supervision of ministry programmes and schemes\",\n  //       \"Ensure effective coordination with State Governments for scheme implementation\",\n  //       \"Strategic policy formulation and implementation oversight\",\n  //       \"Inter-ministerial coordination and liaison\",\n  //       \"Parliamentary affairs management\",\n  //       \"Senior leadership governance and oversight\",\n  //       \"National programme strategic direction\",\n  //       \"Cabinet note writing and policy briefs\"\n  //     ],\n  //     behavioralCompetencies: [\n  //       \"Strategic Leadership\", \"Executive Presence\", \"Influencing and Negotiation\",\n  //       \"Relationship Management\", \"Verbal & Non-Verbal Fluency\", \"Planning & Prioritization\",\n  //       \"Accountability\", \"Conflict Management\"\n  //     ],\n  //     functionalCompetencies: [\n  //       \"Rules of business (AoB/ToB)\", \"Cabinet note writing\", \"Submission of briefs, supply of information\",\n  //       \"Policy design/ amendment\", \"Policy implementation\", \"Policy monitoring & impact assessment\",\n  //       \"Project Planning\", \"Project Evaluation & Monitoring\", \"Creation of M&E Framework\",\n  //       \"Citizen Partnering & Collaboration\", \"Public Grievance Handling\"\n  //     ],\n  //     domainCompetencies: [\n  //       \"Strategic Policy Formulation\", \"Inter-ministerial & State Government Coordination\",\n  //       \"Senior Leadership Governance & Oversight\", \"Legislative & Parliamentary Affairs Management\",\n  //       \"National Programme Strategic Direction\"\n  //     ],\n  //     completionRate: { behavioral: 85, functional: 78, domain: 92 }\n  //   }\n  // ];\n\n  // // Calculate the totals dynamically\n  // private behavioralTotal = this.designationData.reduce((acc, item) => acc + item.behavioralCompetencies.length, 0);\n  // private functionalTotal = this.designationData.reduce((acc, item) => acc + item.functionalCompetencies.length, 0);\n  // private domainTotal = this.designationData.reduce((acc, item) => acc + item.domainCompetencies.length, 0);\n\n  // // Calculate the averages dynamically\n  // private behavioralAvg = Math.round(this.designationData.reduce((acc, item) => acc + item.completionRate.behavioral, 0) / this.designationData.length);\n  // private functionalAvg = Math.round(this.designationData.reduce((acc, item) => acc + item.completionRate.functional, 0) / this.designationData.length);\n  // private domainAvg = Math.round(this.designationData.reduce((acc, item) => acc + item.completionRate.domain, 0) / this.designationData.length);\n\n  // overallKPIs = [\n  //   {\n  //     name: 'Behavioral Competencies',\n  //     total: this.behavioralTotal,\n  //     avgCompletion: this.behavioralAvg,\n  //     color: '#3B82F6',\n  //     bgColor: 'bg-blue-50',\n  //   },\n  //   {\n  //     name: 'Functional Competencies',\n  //     total: this.functionalTotal,\n  //     avgCompletion: this.functionalAvg,\n  //     color: '#10B981',\n  //     bgColor: 'bg-green-50',\n  //   },\n  //   {\n  //     name: 'Domain Competencies',\n  //     total: this.domainTotal,\n  //     avgCompletion: this.domainAvg,\n  //     color: '#8B5CF6',\n  //     bgColor: 'bg-purple-50',\n  //   },\n  //   {\n  //     name: 'Total Competencies',\n  //     total: this.behavioralTotal + this.functionalTotal + this.domainTotal,\n  //     avgCompletion: Math.round((this.behavioralAvg + this.functionalAvg + this.domainAvg) / 3),\n  //     color: '#4B5563',\n  //     bgColor: 'bg-gray-200',\n  //   }\n  // ];\n\n  closeDialog() {\n    this.dialogRef.close()\n  }\n\n  cancelForm() {\n    this.dialogRef.close()\n  }\n\n  saveRoleMapping() {\n\n  }\n\n  ngAfterViewInit() {\n    console.log('this.data', this.data)\n    this.jsonData = this.data?.payload\n    this.cdr.detectChanges();\n\n    setTimeout(() => {\n      this.scrollToTop();\n    });\n\n    if (this.dialogContent) {\n      setTimeout(() => {\n        this.dialogContent.nativeElement.scrollTo({\n          top: 0,\n          behavior: 'smooth'\n        });\n      }, 500)\n\n    }\n  }\n\n  getMappingData() {\n    console.log('haredService?.cbpPlanFinalObj', this.sharedService.getCbpPlansWithSelectedCourses())\n    if (this.sharedService?.cbpPlanFinalObj.ministry.sbOrgType === 'ministry') {\n      this.loading = true\n      let state_center_id = this.sharedService?.cbpPlanFinalObj.ministry.identifier\n\n      if (this.sharedService?.cbpPlanFinalObj.departments?.length) {\n\n        let department_id = this.sharedService?.cbpPlanFinalObj.departments\n        this.sharedService.getRoleMappingByStateCenterAndDepartment(state_center_id, department_id).subscribe({\n          next: (res) => {\n            this.loading = false\n            this.totalCompetencieObj = { total: 0, behavioral: 0, functional: 0, domain: 0 };\n            this.designationData = [];\n\n            // ✅ GLOBAL UNIQUE SETS (for overall unique count)\n            const globalTotalSet = new Set<string>();\n            const globalBehavioralSet = new Set<string>();\n            const globalFunctionalSet = new Set<string>();\n            const globalDomainSet = new Set<string>();\n\n            for (let i = 0; i < res.length; i++) {\n\n              // ✅ LOCAL UNIQUE SETS (per designation)\n              const totalSet = new Set<string>();\n              const behavioralSet = new Set<string>();\n              const functionalSet = new Set<string>();\n              const domainSet = new Set<string>();\n\n              let competenciesObj = { total: 0, behavioral: 0, functional: 0, domain: 0 };\n\n              res[i]?.competencies?.forEach(c => {\n\n                const theme = (c?.theme || '').trim().toLowerCase();\n                const subTheme = (c?.sub_theme || '').trim().toLowerCase();\n                const type = (c?.type || '').trim().toLowerCase();\n\n                if (!theme && !subTheme) return;\n\n                const key = `${theme}-${subTheme}`;\n\n                // ✅ PER DESIGNATION UNIQUE\n                if (!totalSet.has(key)) {\n                  totalSet.add(key);\n                  competenciesObj.total++;\n                }\n\n                if (type === 'behavioral' && !behavioralSet.has(key)) {\n                  behavioralSet.add(key);\n                  competenciesObj.behavioral++;\n                }\n\n                if (type === 'functional' && !functionalSet.has(key)) {\n                  functionalSet.add(key);\n                  competenciesObj.functional++;\n                }\n\n                if (type === 'domain' && !domainSet.has(key)) {\n                  domainSet.add(key);\n                  competenciesObj.domain++;\n                }\n\n                // ✅ GLOBAL UNIQUE TRACKING\n                globalTotalSet.add(key);\n\n                if (type === 'behavioral') globalBehavioralSet.add(key);\n                if (type === 'functional') globalFunctionalSet.add(key);\n                if (type === 'domain') globalDomainSet.add(key);\n\n              });\n\n              this.designationData.push({\n                designation: res[i].designation_name,\n                wing: res[i].wing_division_section,\n                updated: res[i].updated_at,\n                rolesResponsibilities: res[i].role_responsibilities,\n                activities: res[i].activities,\n                competenciesObj,\n                behavioralCompetencies: [...behavioralSet],\n                functionalCompetencies: [...functionalSet],\n                domainCompetencies: [...domainSet],\n                selectedCourses: res[i]?.cbp_plans?.at(-1)?.selected_courses || []\n              });\n\n            }\n\n            // ✅ SET GLOBAL COUNTS AFTER LOOP\n            this.totalCompetencieObj.total = globalTotalSet.size;\n            this.totalCompetencieObj.behavioral = globalBehavioralSet.size;\n            this.totalCompetencieObj.functional = globalFunctionalSet.size;\n            this.totalCompetencieObj.domain = globalDomainSet.size;\n\n            this.cdr.detectChanges();\n            this.cdr.detectChanges();\n            setTimeout(() => {\n              this.scrollToTop()\n            }, 1000);\n            console.log('this.designationData', this.designationData)\n            console.log('this.totalCompetencieObj', this.totalCompetencieObj)\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      } else {\n\n        this.sharedService.getRoleMappingByStateCenter(state_center_id).subscribe({\n          next: (res) => {\n            this.loading = false\n            console.log('res', res)\n            this.totalCompetencieObj = { total: 0, behavioral: 0, functional: 0, domain: 0 };\n            this.designationData = [];\n\n            // ✅ GLOBAL UNIQUE SETS (for overall unique count)\n            const globalTotalSet = new Set<string>();\n            const globalBehavioralSet = new Set<string>();\n            const globalFunctionalSet = new Set<string>();\n            const globalDomainSet = new Set<string>();\n\n            for (let i = 0; i < res.length; i++) {\n\n              // ✅ LOCAL UNIQUE SETS (per designation)\n              const totalSet = new Set<string>();\n              const behavioralSet = new Set<string>();\n              const functionalSet = new Set<string>();\n              const domainSet = new Set<string>();\n\n              let competenciesObj = { total: 0, behavioral: 0, functional: 0, domain: 0 };\n\n              res[i]?.competencies?.forEach(c => {\n\n                const theme = (c?.theme || '').trim().toLowerCase();\n                const subTheme = (c?.sub_theme || '').trim().toLowerCase();\n                const type = (c?.type || '').trim().toLowerCase();\n\n                if (!theme && !subTheme) return;\n\n                const key = `${theme}-${subTheme}`;\n\n                // ✅ PER DESIGNATION UNIQUE\n                if (!totalSet.has(key)) {\n                  totalSet.add(key);\n                  competenciesObj.total++;\n                }\n\n                if (type === 'behavioral' && !behavioralSet.has(key)) {\n                  behavioralSet.add(key);\n                  competenciesObj.behavioral++;\n                }\n\n                if (type === 'functional' && !functionalSet.has(key)) {\n                  functionalSet.add(key);\n                  competenciesObj.functional++;\n                }\n\n                if (type === 'domain' && !domainSet.has(key)) {\n                  domainSet.add(key);\n                  competenciesObj.domain++;\n                }\n\n                // ✅ GLOBAL UNIQUE TRACKING\n                globalTotalSet.add(key);\n\n                if (type === 'behavioral') globalBehavioralSet.add(key);\n                if (type === 'functional') globalFunctionalSet.add(key);\n                if (type === 'domain') globalDomainSet.add(key);\n\n              });\n\n              this.designationData.push({\n                designation: res[i].designation_name,\n                wing: res[i].wing_division_section,\n                updated: res[i].updated_at,\n                rolesResponsibilities: res[i].role_responsibilities,\n                activities: res[i].activities,\n                competenciesObj,\n                behavioralCompetencies: [...behavioralSet],\n                functionalCompetencies: [...functionalSet],\n                domainCompetencies: [...domainSet],\n                selectedCourses: res[i]?.cbp_plans?.at(-1)?.selected_courses || []\n              });\n\n            }\n\n            // ✅ SET GLOBAL COUNTS AFTER LOOP\n            this.totalCompetencieObj.total = globalTotalSet.size;\n            this.totalCompetencieObj.behavioral = globalBehavioralSet.size;\n            this.totalCompetencieObj.functional = globalFunctionalSet.size;\n            this.totalCompetencieObj.domain = globalDomainSet.size;\n\n            this.cdr.detectChanges();\n            this.cdr.detectChanges();\n            setTimeout(() => {\n              this.scrollToTop()\n            }, 1000);\n\n          },\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\n\n    }\n    if (this.sharedService?.cbpPlanFinalObj.ministry.sbOrgType === 'state') {\n      this.loading = true\n      console.log('this.sharedService?.cbpPlanFinalObj', this.sharedService?.cbpPlanFinalObj)\n      let state_center_id = this.sharedService?.cbpPlanFinalObj.ministry.identifier\n      let department_id = this.sharedService?.cbpPlanFinalObj.departments\n      // this.sharedService.getRoleMappingByStateCenterAndDepartment(state_center_id, department_id).subscribe((res)=>{\n      //   console.log('res', res)\n      //   let behavioralCompetencies =[]\n      //   let functionalCompetencies =[]\n      //   let domainCompetencies =[]\n      //   for(let i=0; i<res.length;i++) {\n      //    behavioralCompetencies = []\n      //    functionalCompetencies =[]\n      //    domainCompetencies =[]\n      //    let competenciesObj = {total:0, behavioral:0, functional:0, domain:0}\n      //   res[i].competencies.forEach(c => {\n      //    competenciesObj.total++;\n      //    this.totalCompetencieObj.total++\n      //     if (c.type.toLowerCase() === 'behavioral') { \n\n      //      behavioralCompetencies.push(`${c.theme} - ${c.sub_theme}`)\n      //      competenciesObj.behavioral++;\n      //      this.totalCompetencieObj.behavioral++\n      //     }\n      //     if (c.type.toLowerCase() === 'functional') {\n      //      functionalCompetencies.push(`${c.theme} - ${c.sub_theme}`)\n      //      competenciesObj.functional++;\n      //      this.totalCompetencieObj.functional++\n      //     }\n      //     if (c.type.toLowerCase() === 'domain') { \n      //      domainCompetencies.push(`${c.theme} - ${c.sub_theme}`)\n      //      competenciesObj.domain++;\n      //      this.totalCompetencieObj.domain++\n\n      //     }\n      //   });\n      //    let obj:any =  {\n      //      designation: res[i].designation_name,\n      //      wing: res[i].wing_division_section,\n      //      updated: res[i].updated_at,\n      //      rolesResponsibilities: res[i].role_responsibilities,\n      //      activities:res[i].activities,\n      //      competenciesObj: competenciesObj,\n      //      behavioralCompetencies: behavioralCompetencies,\n      //      functionalCompetencies: functionalCompetencies,\n      //      domainCompetencies: domainCompetencies\n      //      // behavioralCompetencies: [\n      //      //   \"Strategic Leadership\", \"Executive Presence\", \"Influencing and Negotiation\",\n      //      //   \"Relationship Management\", \"Verbal & Non-Verbal Fluency\", \"Planning & Prioritization\",\n      //      //   \"Accountability\", \"Conflict Management\"\n      //      // ],\n      //      // functionalCompetencies: [\n      //      //   \"Rules of business (AoB/ToB)\", \"Cabinet note writing\", \"Submission of briefs, supply of information\",\n      //      //   \"Policy design/ amendment\", \"Policy implementation\", \"Policy monitoring & impact assessment\",\n      //      //   \"Project Planning\", \"Project Evaluation & Monitoring\", \"Creation of M&E Framework\",\n      //      //   \"Citizen Partnering & Collaboration\", \"Public Grievance Handling\"\n      //      // ],\n      //      // domainCompetencies: [\n      //      //   \"Strategic Policy Formulation\", \"Inter-ministerial & State Government Coordination\",\n      //      //   \"Senior Leadership Governance & Oversight\", \"Legislative & Parliamentary Affairs Management\",\n      //      //   \"National Programme Strategic Direction\"\n      //      // ],\n      //      // completionRate: { behavioral: 85, functional: 78, domain: 92 }\n      //    }\n\n\n      //   this.designationData.push(obj)\n      //   }\n      //   this.cdr.detectChanges();\n      //   setTimeout(() => {\n      //    this.scrollToTop()\n      //   }, 1000);\n      //   console.log('this.designationData', this.designationData)\n      //   console.log('this.totalCompetencieObj', this.totalCompetencieObj )\n\n      //  })\n      this.sharedService.getRoleMappingByStateCenterAndDepartment(state_center_id, department_id).subscribe({\n        next: (res) => {\n          this.loading = false\n          console.log('res', res)\n          this.totalCompetencieObj = { total: 0, behavioral: 0, functional: 0, domain: 0 };\n          this.designationData = [];\n\n          // ✅ GLOBAL UNIQUE SETS (for overall unique count)\n          const globalTotalSet = new Set<string>();\n          const globalBehavioralSet = new Set<string>();\n          const globalFunctionalSet = new Set<string>();\n          const globalDomainSet = new Set<string>();\n\n          for (let i = 0; i < res.length; i++) {\n\n            // ✅ LOCAL UNIQUE SETS (per designation)\n            const totalSet = new Set<string>();\n            const behavioralSet = new Set<string>();\n            const functionalSet = new Set<string>();\n            const domainSet = new Set<string>();\n\n            let competenciesObj = { total: 0, behavioral: 0, functional: 0, domain: 0 };\n\n            res[i]?.competencies?.forEach(c => {\n\n              const theme = (c?.theme || '').trim().toLowerCase();\n              const subTheme = (c?.sub_theme || '').trim().toLowerCase();\n              const type = (c?.type || '').trim().toLowerCase();\n\n              if (!theme && !subTheme) return;\n\n              const key = `${theme}-${subTheme}`;\n\n              // ✅ PER DESIGNATION UNIQUE\n              if (!totalSet.has(key)) {\n                totalSet.add(key);\n                competenciesObj.total++;\n              }\n\n              if (type === 'behavioral' && !behavioralSet.has(key)) {\n                behavioralSet.add(key);\n                competenciesObj.behavioral++;\n              }\n\n              if (type === 'functional' && !functionalSet.has(key)) {\n                functionalSet.add(key);\n                competenciesObj.functional++;\n              }\n\n              if (type === 'domain' && !domainSet.has(key)) {\n                domainSet.add(key);\n                competenciesObj.domain++;\n              }\n\n              // ✅ GLOBAL UNIQUE TRACKING\n              globalTotalSet.add(key);\n\n              if (type === 'behavioral') globalBehavioralSet.add(key);\n              if (type === 'functional') globalFunctionalSet.add(key);\n              if (type === 'domain') globalDomainSet.add(key);\n\n            });\n\n            this.designationData.push({\n              designation: res[i].designation_name,\n              wing: res[i].wing_division_section,\n              updated: res[i].updated_at,\n              rolesResponsibilities: res[i].role_responsibilities,\n              activities: res[i].activities,\n              competenciesObj,\n              behavioralCompetencies: [...behavioralSet],\n              functionalCompetencies: [...functionalSet],\n              domainCompetencies: [...domainSet],\n              selectedCourses: res[i]?.cbp_plans?.at(-1)?.selected_courses || []\n            });\n\n          }\n\n          // ✅ SET GLOBAL COUNTS AFTER LOOP\n          this.totalCompetencieObj.total = globalTotalSet.size;\n          this.totalCompetencieObj.behavioral = globalBehavioralSet.size;\n          this.totalCompetencieObj.functional = globalFunctionalSet.size;\n          this.totalCompetencieObj.domain = globalDomainSet.size;\n\n          this.cdr.detectChanges();\n\n\n          this.cdr.detectChanges();\n          setTimeout(() => {\n            this.scrollToTop()\n          }, 1000);\n          console.log('this.designationData', this.designationData)\n          console.log('this.totalCompetencieObj', this.totalCompetencieObj)\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\n\n  }\n  getCompetenciesByType(type: string, course: any): any[] {\n    if (!course) {\n      return [];\n    }\n\n    let competencies: any[] = [];\n\n    // AI Recommended / Public / User Added\n    if (Array.isArray(course.competencies)) {\n      competencies = course.competencies;\n    }\n    // Manually Suggested - iGOT (v6)\n    else if (Array.isArray(course.competencies_v6)) {\n      competencies = course.competencies_v6;\n    }\n\n    if (!competencies.length) {\n      return [];\n    }\n\n    const normalizedType = type.toLowerCase().trim();\n\n    return competencies.filter(c => {\n      if (!c?.competencyAreaName) {\n        return false;\n      }\n\n      const area = c.competencyAreaName.toLowerCase().trim();\n\n      // handle behavioural / behavioral\n      if (normalizedType === 'behavioural' || normalizedType === 'behavioral') {\n        return area === 'behavioural' || area === 'behavioral';\n      }\n\n      return area === normalizedType;\n    });\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  getRemainingCount(type: string, index: number): number {\n    const totalCount = this.getCompetenciesByType(type, index).length;\n    return totalCount - 2;\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  confirmDeleteCourse(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  deleteCard(item: any, index: number) {\n    console.log(\"item, index\", item, index)\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  scrollToTop(): void {\n\n    // if (this.pdfContent && this.pdfContent.nativeElement && this.pdfContent.nativeElement.scrollTop !== undefined) {\n    //   this.pdfContent.nativeElement.scrollTop = 0;\n    // } else {\n    //   window.scrollTo({ top: 0, behavior: 'smooth' });\n    // }\n    // const dialogContainer = document.querySelector('mat-dialog-container');\n    // if (dialogContainer) {\n    //   dialogContainer.scrollTop = 0;\n    // }\n  }\n\n  downloadPDF() {\n    this.pdfTrigger = true\n    this.loading = 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: 'Final CBP Plan.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    // });\n    //const element = this.pdfContent.nativeElement;\n\n    this.loading = true;\n    const element = this.pdfContent.nativeElement;\n    html2canvas(element, {\n      scale: 1.25,\n      useCORS: true,\n      scrollY: 0,\n      logging: true,\n    }).then((canvas) => {\n      const pdf = new jsPDF('p', 'mm', 'a4');\n      const pdfWidth = pdf.internal.pageSize.getWidth();\n      const pdfHeight = pdf.internal.pageSize.getHeight();\n\n      // Margins\n      const marginLeft = 5;\n      const marginTop = 15;\n      const marginRight = 5;\n      const marginBottom = 15;\n\n      const usableWidth = pdfWidth - marginLeft - marginRight;\n      const usableHeight = pdfHeight - marginTop - marginBottom;\n\n      const canvasWidth = canvas.width;\n      const canvasHeight = canvas.height;\n\n      const ratio = canvasWidth / usableWidth;\n      const pageHeightPx = usableHeight * ratio;\n\n      const totalPages = Math.ceil(canvasHeight / pageHeightPx);\n\n      for (let page = 0; page < totalPages; page++) {\n        const canvasPage = document.createElement('canvas');\n        canvasPage.width = canvasWidth;\n        canvasPage.height = Math.min(pageHeightPx, canvasHeight - page * pageHeightPx);\n\n        const ctx = canvasPage.getContext('2d');\n        if (ctx) {\n          ctx.fillStyle = '#ffffff';\n          ctx.fillRect(0, 0, canvasPage.width, canvasPage.height);\n\n          ctx.drawImage(\n            canvas,\n            0, page * pageHeightPx,\n            canvasWidth, canvasPage.height,\n            0, 0,\n            canvasWidth, canvasPage.height\n          );\n        }\n\n        const imgData = canvasPage.toDataURL('image/png', 1);\n        if (page > 0) pdf.addPage();\n        const imgHeightMM = canvasPage.height / ratio;\n        pdf.addImage(imgData, 'PNG', marginLeft, marginTop, usableWidth, imgHeightMM);\n      }\n\n      pdf.save('Final_CBP.pdf');\n      this.loading = false;\n    }).catch((error) => {\n      console.error('PDF generation error:', error);\n      this.loading = false;\n    });\n\n\n\n\n\n\n\n  }\n\n  downloadPDFNew() {\n    this.loading = true\n    const element = this.pdfContent.nativeElement;\n\n    const opt = {\n      margin: [10, 5, 5, 10], // top, left, bottom, right in mm\n      filename: 'CBP_Plan.pdf',\n      image: { type: 'jpeg', quality: 0.85 },\n      html2canvas: { scale: 1.5, useCORS: true, logging: false },\n      jsPDF: { unit: 'mm', format: 'a4', orientation: 'landscape' },\n      pagebreak: { mode: ['avoid-all', 'css', 'legacy'] } // avoid cutting text\n    };\n\n    html2pdf()\n      .set(opt)\n      .from(element)\n      .save()\n      .then(() => {\n        // PDF download finished\n        this.loading = false;\n      })\n      .catch(() => {\n        // Handle errors and stop loading\n        this.loading = false;\n      });\n\n    setTimeout(() => {\n      this.loading = false;\n    }, 2000);\n\n\n\n  }\n\n\n\n  generateExcel(jsonArray: any[], filename: string = \"final.xlsx\") {\n    console.log('jsonArray', jsonArray)\n\n    if (!jsonArray || jsonArray.length === 0) return;\n\n    // -------- MAIN HEADER FROM FIRST OBJECT ---------\n    const firstObj = jsonArray[0];\n    let title = firstObj.state_center_name || \"\";\n    if (firstObj.department_name) title += \" / \" + firstObj.department_name;\n\n    // -------- COLUMN HEADERS ---------\n    const headers = [\n      \"Designation\",\n      \"Role & Responsibilities\",\n      \"Activities\",\n      \"Behavioral Competencies\",\n      \"Functional Competencies\",\n      \"Domain Competencies\",\n      'courseDetails'\n    ];\n\n    // -------- DATA ROWS ---------\n    const dataRows = jsonArray.map(json => {\n      const courses =\n        json?.cbp_plans?.length\n          ? json.cbp_plans[json.cbp_plans.length - 1]?.selected_courses || []\n          : [];\n\n      const courseDetails = courses.map((c: any, i: number) => {\n        const competencies = (c.competencies || [])\n          .map((cc: any) =>\n            `${cc.competencyAreaName} → ${cc.competencyThemeName} → ${cc.competencySubThemeName}`\n          )\n          .join(\" | \");\n\n        return (\n          `${i + 1}. Course Name: ${c.course}\\n` +\n          `   Identifier: ${c.identifier}\\n` +\n          `   Duration (mins): ${Math.round(+c.duration / 60)}\\n` +\n          `   Relevancy: ${c.relevancy}%\\n` +\n          `   Rationale: ${c.rationale}\\n` +\n          `   Organisation: ${(c.organisation || []).join(\", \")}\\n` +\n          `   Competencies: ${competencies}`\n        );\n      }).join(\"\\n\\n\");\n      return {\n        \"Designation\": `${json.designation_name} : Wing/Division - ${json.wing_division_section}`,\n        \"Role & Responsibilities\": (json.role_responsibilities || [])\n          .map((v: string, i: number) => `${i + 1}. ${v}`).join(\"\\n\\n\"),\n        \"Activities\": (json.activities || [])\n          .map((v: string, i: number) => `${i + 1}. ${v}`).join(\"\\n\\n\"),\n        \"Behavioral Competencies\": (json.competencies || [])\n          .filter((c: any) => c.type === \"Behavioral\")\n          .map((c: any, i: number) => `${i + 1}. ${c.theme} - ${c.sub_theme}`).join(\"\\n\\n\"),\n        \"Functional Competencies\": (json.competencies || [])\n          .filter((c: any) => c.type === \"Functional\")\n          .map((c: any, i: number) => `${i + 1}. ${c.theme} - ${c.sub_theme}`).join(\"\\n\\n\"),\n        \"Domain Competencies\": (json.competencies || [])\n          .filter((c: any) => c.type === \"Domain\")\n          .map((c: any, i: number) => `${i + 1}. ${c.theme} - ${c.sub_theme}`).join(\"\\n\\n\"),\n        \"Course Details\": courseDetails\n      };\n    });\n\n\n    // -------- CREATE WORKSHEET ---------\n    const ws = XLSX.utils.aoa_to_sheet([]);\n\n    // Main header (merged)\n    XLSX.utils.sheet_add_aoa(ws, [[title]], { origin: \"A1\" });\n    ws['!merges'] = [{\n      s: { r: 0, c: 0 },\n      e: { r: 0, c: headers.length - 1 }\n    }];\n\n    // Column headers at row 2\n    XLSX.utils.sheet_add_aoa(ws, [headers], { origin: \"A2\" });\n\n    // Style column headers\n    headers.forEach((header, index) => {\n      const cellAddress = XLSX.utils.encode_cell({ r: 1, c: index });\n      if (ws[cellAddress]) {\n        ws[cellAddress].s = {\n          font: { bold: true },\n          fill: { patternType: \"solid\", fgColor: { rgb: \"FFFF00\" } },\n          alignment: { horizontal: \"center\", vertical: \"center\", wrapText: true }\n        };\n      }\n    });\n\n    // Insert data rows starting from row 3\n    XLSX.utils.sheet_add_json(ws, dataRows, { origin: \"A3\", skipHeader: true });\n\n    // Auto column widths based on longest line in each column\n    const colWidths = headers.map((header, idx) => {\n      const maxLen = Math.max(\n        header.length,\n        ...dataRows.map(row => (row[header] || \"\").split(\"\\n\").reduce((a, b) => Math.max(a, b.length), 0))\n      );\n      return { wch: Math.min(Math.max(maxLen + 5, 20), 80) }; // min 20, max 80\n    });\n    ws['!cols'] = colWidths;\n\n    // Wrap text in data rows\n    dataRows.forEach((row, rowIndex) => {\n      headers.forEach((header, colIndex) => {\n        const cellAddress = XLSX.utils.encode_cell({ r: rowIndex + 2, c: colIndex });\n        if (ws[cellAddress]) {\n          ws[cellAddress].s = { alignment: { wrapText: true, vertical: \"top\" } };\n        }\n      });\n    });\n\n    // Style main header\n    if (ws[\"A1\"]) {\n      ws[\"A1\"].s = {\n        font: { bold: true, sz: 16 },\n        alignment: { horizontal: \"center\", vertical: \"center\" }\n      };\n    }\n\n    // -------- CREATE WORKBOOK ---------\n    const wb = XLSX.utils.book_new();\n    XLSX.utils.book_append_sheet(wb, ws, \"Sheet1\");\n\n    // Export Excel\n    XLSX.writeFile(wb, filename);\n  }\n\n\n\n\n  downloadCSV() {\n    let fileName = ''\n    if (!this.sharedService?.cbpPlanFinalObj.departments) {\n      fileName = `CBP_Report_${this.sharedService?.cbpPlanFinalObj.ministry.identifier}_${this.sharedService?.cbpPlanFinalObj.departments}.xlsx`\n    } else {\n      fileName = `CBP_Report_${this.sharedService?.cbpPlanFinalObj.ministry.identifier}.xlsx`\n    }\n    this.generateExcel(this.jsonData, fileName);\n  }\n\n  downloadPdfFromBE(context: string) {\n    let selectedLanguage = this.filterForm.get('language')?.value || 'en';\n    this.loading = true\n    //  this.sharedService.downloadPdf(this.sharedService?.cbpPlanFinalObj.ministry.identifier)\n    if (!this.sharedService?.cbpPlanFinalObj.departments) {\n      this.sharedService.downloadPdf(this.sharedService?.cbpPlanFinalObj.ministry.identifier, context, selectedLanguage)\n    } else {\n      this.sharedService.downloadPdfForDepartment(this.sharedService?.cbpPlanFinalObj.ministry.identifier, this.sharedService?.cbpPlanFinalObj.departments, context, selectedLanguage)\n    }\n\n    setTimeout(() => {\n      this.loading = false\n    }, 5000)\n  }\n  getSelectedCourses(department: any): any[] {\n    if (!department?.cbp_plans?.length) {\n      return [];\n    }\n\n    // take latest CBP plan (or adjust logic if needed)\n    const latestPlan = department.cbp_plans[department.cbp_plans.length - 1];\n\n    return latestPlan?.selected_courses || [];\n  }\n\n  applyFilters() {\n\n  }\n\n  filterList(value: string, type: string) {\n    const search = value.toLowerCase();\n\n    switch (type) {\n\n      case 'language':\n        this.filteredLanguages = this.languages.filter(v => v.label?.toLowerCase().includes(search));\n        break;\n    }\n  }\n\n}","<div class=\"view-cbp-plan\" #dialogContent style=\"max-height: 80vh; overflow: auto;\">\n    <div class=\"popup-container\">\n        <div class=\"popup-header\">\n            <div class=\"header-container\">\n                <div>\n                    <div class=\"heading\">View Final <span *ngIf=\"openedFrom === 'cbp'\">CBP</span><span\n                            *ngIf=\"openedFrom === 'acbp'\">ACBP</span></div>\n                </div>\n                <div class=\"right-side-container\">\n                    <div class=\"search-and-buttons-container\">\n                        <form [formGroup]=\"filterForm\">\n                            <div>\n                                <mat-form-field appearance=\"outline\" class=\"language-select\" style=\" height: 34px;\">\n                                    <mat-label style=\"font-weight: normal;\">\n                                        {{ filterForm.get('language')?.value ? '' : 'Select Language' }}\n                                    </mat-label>\n\n                                    <mat-select formControlName=\"language\" panelClass=\"select-search-panel\"\n                                        (selectionChange)=\"applyFilters()\">\n\n                                        <!-- Search box -->\n                                        <input style=\"border:1px solid #ccc; padding: 5px;width: 92%;margin: 5px;\"\n                                            matInput placeholder=\"Search Languages\" (click)=\"$event.stopPropagation()\"\n                                            (keydown)=\"$event.stopPropagation()\"\n                                            (keyup)=\"filterList($any($event.target).value, 'language')\" />\n\n                                        <!-- Values -->\n                                        <mat-option *ngFor=\"let r of filteredLanguages\" [value]=\"r?.code\">\n                                            {{ r?.label }}\n                                        </mat-option>\n\n                                    </mat-select>\n                                </mat-form-field>\n                            </div>\n                        </form>\n                    </div>\n                    <div class=\"cursor-pointer\" (click)=\"closeDialog()\">\n                        <mat-icon>close</mat-icon>\n                    </div>\n                </div>\n            </div>\n\n\n\n        </div>\n        <div class=\"section-container\" #pdfContent>\n            <header class=\"bg-white header-border\">\n                <div class=\"header-flex justify-between\" style=\"width:100%\">\n                    <div class=\"flex items-center space-x-4\" style=\"width:50%\">\n                        <div class=\"image-container\">\n                            <div>\n                                <img src=\"assets/icons/dopt-logo.png\" alt=\"Department of Personnel & Training\"\n                                    class=\"h-15\" />\n                            </div>\n                            <div>\n                                <img src=\"assets/icons/CBC_logo.svg\" alt=\"Capacity Building Commission Logo\"\n                                    class=\"h-10\" />\n                            </div>\n                            <div>\n                                <img src=\"assets/icons/karmayogiLogo-min.png\" alt=\"Karmayogi Bharat Logo\"\n                                    class=\"h-10\" />\n                            </div>\n                        </div>\n                    </div>\n                    <div class=\"text-right\" style=\"width:50%\">\n                        <h1 class=\"text-2xl font-bold text-gray-900\">\n                            <span\n                                *ngIf=\"sharedService?.cbpPlanFinalObj?.ministry?.sbOrgType === 'state'\">{{sharedService?.cbpPlanFinalObj?.ministry?.orgName}}</span>\n                            <span\n                                *ngIf=\"sharedService?.cbpPlanFinalObj?.ministry?.sbOrgType === 'ministry'\">{{sharedService?.cbpPlanFinalObj?.ministry?.orgName}}</span>\n                            <span\n                                *ngIf=\"sharedService?.cbpPlanFinalObj?.department_name\">/{{sharedService?.cbpPlanFinalObj?.department_name}}</span>\n                            - Capacity Building Plan\n                        </h1>\n                        <p class=\"text-gray-600\">Comprehensive Role-Based Competency Analysis</p>\n                    </div>\n                </div>\n            </header>\n            <div class=\"min-h-screen bg-gradient-to-br from-slate-50 via-blue-50 to-indigo-100\">\n                <!-- Header -->\n\n\n                <div class=\"max-w-7xl mx-auto px-6 py-8 mt-4\">\n                    <!-- KPI Dashboard -->\n                    <div class=\"competency-container mt-2\">\n                        <div class=\"outside-layer-total\">\n                            <div class=\"horizontal-flex mt-2\">\n                                <div>\n                                    <svg class=\"h-8 w-8 icon-sm\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\"\n                                        stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                        stroke-linejoin=\"round\" viewBox=\"0 0 24 24\">\n                                        <path d=\"M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z\" />\n                                        <path d=\"M14 2v6h6\" />\n                                        <path d=\"M16 13H8\" />\n                                        <path d=\"M16 17H8\" />\n                                        <path d=\"M10 9H8\" />\n                                    </svg>\n                                </div>\n                                <div>\n                                    <div class=\"count\">{{totalCompetencieObj?.total}}</div>\n                                </div>\n                            </div>\n\n                            <div class=\"mt-4\">\n                                <div class=\"sub-heading\">\n                                    <p>Total Competencies</p>\n                                </div>\n                            </div>\n                            <div class=\"progress-bar mt-2\">\n                                <div class=\"progress-bar-fill\" style=\"width: 60%;\"></div>\n                            </div>\n                            <div>\n                                <div class=\"sub-text\">Total Competencies: {{totalCompetencieObj?.total}}</div>\n                            </div>\n                            <div class=\"count\">\n                                <!-- {{competenciesCount?.total}} -->\n                            </div>\n                        </div>\n                        <div class=\"outside-layer-behavioral\">\n                            <div class=\"horizontal-flex mt-2\">\n                                <div>\n                                    <svg class=\"h-8 w-8 icon-sm\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\"\n                                        stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                        stroke-linejoin=\"round\" viewBox=\"0 0 24 24\">\n                                        <path d=\"M15.5 17a4 4 0 0 1-5 0\" />\n                                        <path d=\"M13 14h.01\" />\n                                        <path d=\"M11 11h.01\" />\n                                        <path d=\"M17 14h.01\" />\n                                        <path d=\"M13 10h.01\" />\n                                        <path d=\"M13 18h.01\" />\n                                        <path d=\"M13 6h.01\" />\n                                        <path d=\"M17 18h.01\" />\n                                        <path d=\"M17 6h.01\" />\n                                        <path d=\"M21 12a9 9 0 0 1-9 9a9 9 0 0 1-9-9a9 9 0 0 1 9-9a9 9 0 0 1 9 9z\" />\n                                    </svg>\n                                </div>\n                                <div>\n                                    <div class=\"count\">{{totalCompetencieObj?.behavioral}}</div>\n                                </div>\n                            </div>\n\n                            <div class=\"mt-2\">\n                                <div class=\"sub-heading\">\n                                    <p>Behavioral Competencies</p>\n                                </div>\n                            </div>\n                            <div class=\"progress-bar mt-2\">\n                                <div class=\"progress-bar-fill-behavioural\" style=\"width: 60%;\"></div>\n                            </div>\n                            <div>\n                                <div class=\"sub-text\">Behavioral Competencies: {{totalCompetencieObj?.behavioral}}\n                                </div>\n                            </div>\n\n                        </div>\n                        <div class=\"outside-layer-functional\">\n                            <div class=\"horizontal-flex mt-2\">\n                                <div>\n                                    <svg class=\"h-8 w-8 icon-sm\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\"\n                                        stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                        stroke-linejoin=\"round\" viewBox=\"0 0 24 24\">\n                                        <path d=\"M2 3h6a4 4 0 0 1 4 4v14a3 3 0 0 0-3-3H2z\" />\n                                        <path d=\"M22 3h-6a4 4 0 0 0-4 4v14a3 3 0 0 1 3-3h7z\" />\n                                    </svg>\n                                </div>\n                                <div>\n                                    <div class=\"count\">{{totalCompetencieObj?.functional}}</div>\n                                </div>\n                            </div>\n\n                            <div class=\"mt-2\">\n                                <div class=\"sub-heading\">\n                                    <p>Functional Competencies</p>\n                                </div>\n                            </div>\n                            <div class=\"progress-bar mt-2\">\n                                <div class=\"progress-bar-fill-functional\" style=\"width: 60%;\"></div>\n                            </div>\n                            <div>\n                                <div class=\"sub-text\">Functional Competencies: {{totalCompetencieObj?.functional}}</div>\n                            </div>\n\n\n                        </div>\n                        <div class=\"outside-layer-domain\">\n                            <div class=\"horizontal-flex mt-2\">\n                                <div>\n                                    <svg class=\"h-8 w-8 icon-sm\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\"\n                                        stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                        stroke-linejoin=\"round\" viewBox=\"0 0 24 24\">\n                                        <circle cx=\"12\" cy=\"12\" r=\"10\" />\n                                        <circle cx=\"12\" cy=\"12\" r=\"6\" />\n                                        <circle cx=\"12\" cy=\"12\" r=\"2\" />\n                                    </svg>\n                                </div>\n                                <div>\n                                    <div class=\"count\">{{totalCompetencieObj?.domain}}</div>\n                                </div>\n                            </div>\n\n                            <div class=\"mt-2\">\n                                <div class=\"sub-heading\">\n                                    <p>Domain Competencies</p>\n                                </div>\n                            </div>\n                            <div class=\"progress-bar mt-2\">\n                                <div class=\"progress-bar-fill-domain\" style=\"width: 60%;\"></div>\n                            </div>\n                            <div>\n                                <div class=\"sub-text\">Domain Competencies: {{totalCompetencieObj?.domain}}</div>\n                            </div>\n\n                        </div>\n                    </div>\n                    <!-- <div class=\"mb-8\">\n                <h2 class=\"text-2xl font-bold text-gray-900 mb-6nheading\">Competency Overview</h2>\n                <div class=\"competency-grid\">\n                  <ng-container *ngFor=\"let kpi of overallKPIs;\">\n                    <div class=\"bg-white rounded-xl  outside-layer-total p-6 border-l-4 hover:shadow-xl transition-shadow\" [style.border-left-color]=\"kpi.color\">\n                      <div class=\"flex items-center justify-between mb-4 inside-layer\">\n                        <div [class]=\"'p-3 rounded-lg ' + kpi.bgColor\">\n                          <ng-container [ngSwitch]=\"kpi.name\">\n                            <svg *ngSwitchCase=\"'Behavioral Competencies'\" class=\"h-8 w-8 icon-sm\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" viewBox=\"0 0 24 24\">\n                              <path d=\"M15.5 17a4 4 0 0 1-5 0\"/>\n                              <path d=\"M13 14h.01\"/><path d=\"M11 11h.01\"/><path d=\"M17 14h.01\"/><path d=\"M13 10h.01\"/>\n                              <path d=\"M13 18h.01\"/><path d=\"M13 6h.01\"/><path d=\"M17 18h.01\"/><path d=\"M17 6h.01\"/>\n                              <path d=\"M21 12a9 9 0 0 1-9 9a9 9 0 0 1-9-9a9 9 0 0 1 9-9a9 9 0 0 1 9 9z\"/>\n                            </svg>\n          \n                            <svg *ngSwitchCase=\"'Functional Competencies'\" class=\"h-8 w-8 icon-sm\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" viewBox=\"0 0 24 24\">\n                              <path d=\"M2 3h6a4 4 0 0 1 4 4v14a3 3 0 0 0-3-3H2z\"/><path d=\"M22 3h-6a4 4 0 0 0-4 4v14a3 3 0 0 1 3-3h7z\"/>\n                            </svg>\n          \n                            <svg *ngSwitchCase=\"'Domain Competencies'\" class=\"h-8 w-8 icon-sm\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" viewBox=\"0 0 24 24\">\n                              <circle cx=\"12\" cy=\"12\" r=\"10\"/><circle cx=\"12\" cy=\"12\" r=\"6\"/><circle cx=\"12\" cy=\"12\" r=\"2\"/>\n                            </svg>\n          \n                            <svg *ngSwitchCase=\"'Total Competencies'\" class=\"h-8 w-8 icon-sm\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" viewBox=\"0 0 24 24\">\n                              <path d=\"M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z\"/>\n                              <path d=\"M14 2v6h6\"/><path d=\"M16 13H8\"/><path d=\"M16 17H8\"/><path d=\"M10 9H8\"/>\n                            </svg>\n                            \n                          </ng-container>\n                        </div>\n                        <div class=\"text-right\">\n                          <div class=\"text-2xl font-bold text-gray-900\">{{kpi.total}}</div>\n                        </div>\n                      </div>\n                      <h3 class=\"text-gray-900 font-semibold mb-2 heading\">{{kpi.name}}</h3>\n                      <div class=\"w-full bg-gray-200 rounded-full h-3\">\n                        <div class=\"h-3 rounded-full transition-all duration-500\"\n                             [style.width.%]=\"kpi.avgCompletion\"\n                             [style.background-color]=\"kpi.color\">\n                        </div>\n                      </div>\n                      <p class=\"text-sm text-gray-500 mt-2\">Total Competencies: {{kpi.total}}</p>\n                    </div>\n                  </ng-container>\n                </div>\n              </div> -->\n\n                    <!-- Designation Reports -->\n                    <div class=\"space-y-8 mt-4\">\n                        <h2 class=\"text-2xl font-bold text-gray-900 mb-6 heading\">Detailed Competency Framework by\n                            Designation</h2>\n\n                        <ng-container *ngFor=\"let designation of designationData;\">\n                            <div class=\"bg-white rounded-xl  overflow-hidden section-shadow\">\n                                <!-- Header -->\n                                <div\n                                    class=\"bg-gradient-to-r from-indigo-600 to-blue-600 text-white p-6 heading-with-bg\">\n                                    <div class=\"flex items-center justify-between\">\n                                        <div>\n                                            <h3 class=\"text-2xl font-bold mb-2 heading-bg\">{{designation.designation}}\n                                            </h3>\n                                            <p class=\"text-indigo-100 mb-1\">Wing/Division: {{designation.wing}}</p>\n                                        </div>\n                                        <div class=\"flex items-center space-x-4 competency-count-by-designation\">\n                                            <span class=\"font-semibold text-sm\">Behavioral:\n                                                {{designation.behavioralCompetencies.length}} total</span>\n                                            <span class=\"font-semibold text-sm\">Functional:\n                                                {{designation.functionalCompetencies.length}} total</span>\n                                            <span class=\"font-semibold text-sm\">Domain:\n                                                {{designation.domainCompetencies.length}} total</span>\n                                        </div>\n                                    </div>\n                                </div>\n\n                                <!-- Body -->\n                                <div class=\"p-4 section-shadow\">\n                                    <!-- Roles -->\n                                    <div class=\"mb-6\">\n                                        <h4 class=\"text-xl font-semibold text-gray-900 mb-3 flex items-center\">\n                                            <svg class=\"h-5 w-5 mr-2 text-indigo-600 icon-sm\" fill=\"none\"\n                                                viewBox=\"0 0 24 24\" stroke=\"currentColor\">\n                                                <path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\"\n                                                    d=\"M16 7a4 4 0 11-8 0 4 4 0 018 0zM12 14a7 7 0 00-7 7h14a7 7 0 00-7-7z\" />\n                                            </svg>\n                                            Roles & Responsibilities\n                                        </h4>\n                                        <div class=\"grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-2\">\n                                            <div *ngFor=\"let role of designation.rolesResponsibilities; let i = index\"\n                                                class=\"bg-gray-50 p-2 rounded border-l-3 border-indigo-500\">\n                                                <p class=\"text-sm text-gray-700 leading-relaxed\">{{role}}</p>\n                                            </div>\n                                        </div>\n                                    </div>\n                                    <!-- Activities -->\n                                    <div class=\"mb-6 mt-4\">\n                                        <h4 class=\"text-xl font-semibold text-gray-900 mb-3 flex items-center\">\n                                            <svg class=\"h-5 w-5 mr-2 text-indigo-600 icon-sm\" fill=\"none\"\n                                                viewBox=\"0 0 24 24\" stroke=\"currentColor\">\n                                                <path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\"\n                                                    d=\"M16 7a4 4 0 11-8 0 4 4 0 018 0zM12 14a7 7 0 00-7 7h14a7 7 0 00-7-7z\" />\n                                            </svg>\n                                            Activities\n                                        </h4>\n                                        <div class=\"grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-2\">\n                                            <div *ngFor=\"let role of designation.activities; let i = index\"\n                                                class=\"bg-gray-50 p-2 rounded border-l-3 border-indigo-500\">\n                                                <p class=\"text-sm text-gray-700 leading-relaxed\">{{role}}</p>\n                                            </div>\n                                        </div>\n                                    </div>\n                                    <div class=\"page-break\"></div>\n                                    <!-- Competencies -->\n                                    <div class=\"competencis-grid mt-4\">\n                                        <!-- Behavioral -->\n                                        <div class=\"bg-blue-50 rounded-lg p-3 competencies-grid-3\">\n                                            <h4 class=\"font-semibold text-blue-800 text-base mb-2\">Behavioral</h4>\n                                            <div class=\"space-y-1 grid-list-item grid-list-item-behavioral\">\n                                                <div *ngFor=\"let comp of designation.behavioralCompetencies; let i = index\"\n                                                    class=\"bg-white p-1.5 rounded text-sm text-gray-700 border-l-2 border-blue-400\">\n                                                    {{comp}}\n                                                </div>\n                                            </div>\n                                            <div class=\"mt-2 text-sm text-blue-600 font-medium\">\n                                                {{designation.behavioralCompetencies.length}} total\n                                            </div>\n                                        </div>\n\n                                        <!-- Functional -->\n                                        <div class=\"bg-green-50 rounded-lg p-3 competencies-grid-3\">\n                                            <h4 class=\"font-semibold text-green-800 text-base mb-2\">Functional</h4>\n                                            <div class=\"space-y-1 grid-list-item grid-list-item-functional\">\n                                                <div *ngFor=\"let comp of designation.functionalCompetencies; let i = index\"\n                                                    class=\"bg-white p-1.5 rounded text-sm text-gray-700 border-l-2 border-green-400\">\n                                                    {{comp}}\n                                                </div>\n                                            </div>\n                                            <div class=\"mt-2 text-sm text-green-600 font-medium\">\n                                                {{designation.functionalCompetencies.length}} total\n                                            </div>\n                                        </div>\n\n                                        <!-- Domain -->\n                                        <div class=\"bg-purple-50 rounded-lg p-3 competencies-grid-3\">\n                                            <h4 class=\"font-semibold text-purple-800 text-base mb-2\">Domain</h4>\n                                            <div class=\"space-y-1 grid-list-item grid-list-item-domain\">\n                                                <div *ngFor=\"let comp of designation.domainCompetencies; let i = index\"\n                                                    class=\"bg-white p-1.5 rounded text-sm text-gray-700 border-l-2 border-purple-400\">\n                                                    {{comp}}\n                                                </div>\n                                            </div>\n                                            <div class=\"mt-2 text-sm text-purple-600 font-medium\">\n                                                {{designation.domainCompetencies.length}} total\n                                            </div>\n                                        </div>\n                                    </div>\n                                    <!-- Adding courses -->\n                                    <div class=\"cbp mt-4\"\n                                        *ngIf=\"designation.selectedCourses?.length && openedFrom === 'acbp'\">\n                                        <h4 class=\"text-xl font-semibold text-gray-900 mb-3 flex items-center\">\n                                            <svg class=\"h-5 w-5 mr-2 text-indigo-600 icon-sm\" fill=\"none\"\n                                                viewBox=\"0 0 24 24\" stroke=\"currentColor\">\n                                                <path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\"\n                                                    d=\"M16 7a4 4 0 11-8 0 4 4 0 018 0zM12 14a7 7 0 00-7 7h14a7 7 0 00-7-7z\" />\n                                            </svg>\n                                            Courses\n                                        </h4>\n                                        <div class=\"course-list-container\">\n                                            <div class=\"course-list-item\"\n                                                *ngFor=\"let item of designation.selectedCourses; 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\n                                                                            src=\"assets/icons/course.svg\"></span>&nbsp;<span>Course</span>\n                                                                </div>\n                                                            </div>\n                                                        </div>\n\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\n                                                                        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\"\n                                                            *ngIf=\"item?.platform\">\n                                                            <div class=\"ai-recommened-pill-orange-text\">\n                                                                <span class=\"ai-loader-icon\"><img\n                                                                        src=\"assets/icons/ai-loader.gif\"></span>\n                                                                <a class=\"cursor-pointer\" [href]=\"item?.public_link\"\n                                                                    target=\"_blank\"><span>Platform -\n                                                                        {{item?.platform}}</span></a>\n                                                            </div>\n                                                        </div>\n                                                        <div class=\"ai-recommened-pill-orange mt-2\"\n                                                            *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\n                                                                        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\"\n                                                            *ngIf=\"item?.platform\">\n                                                            <div class=\"ai-recommened-pill-orange-text\">\n                                                                <span class=\"ai-loader-icon\"><img\n                                                                        src=\"assets/icons/ai-loader.gif\"></span>\n                                                                <a class=\"cursor-pointer\" [href]=\"item?.public_link\"\n                                                                    target=\"_blank\"><span>Platform -\n                                                                        {{item?.platform}}</span></a>\n                                                            </div>\n                                                        </div>\n                                                        <div class=\"ai-recommened-pill-orange mt-2\"\n                                                            *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\n                                                                        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\"\n                                                            *ngIf=\"item?.platform\">\n                                                            <div class=\"ai-recommened-pill-orange-text\">\n                                                                <span class=\"ai-loader-icon\"><img\n                                                                        src=\"assets/icons/ai-loader.gif\"></span>\n                                                                <a class=\"cursor-pointer\" [href]=\"item?.public_link\"\n                                                                    target=\"_blank\"><span>Platform -\n                                                                        {{item?.platform}}</span></a>\n                                                            </div>\n                                                        </div>\n                                                        <div class=\"ai-recommened-pill-orange mt-2\"\n                                                            *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\"\n                                                    *ngIf=\"getCompetenciesByType('Behavioural',item)?.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',item)\">\n                                                            <span class=\"competency-text\"> {{ comp.competencyThemeName\n                                                                }} -\n                                                                {{\n                                                                comp.competencySubThemeName }} </span>\n                                                        </li>\n                                                        <li *ngIf=\"hasMoreThanTwo('Behavioural',item)\"\n                                                            class=\"show-more-competency\">\n                                                            <span class=\"show-more-link cursor-pointer\"\n                                                                (click)=\"toggleCompetencies('Behavioural',item)\">\n                                                                {{ isExpanded('Behavioural',item) ? 'Show Less' : '+' +\n                                                                getRemainingCount('Behavioural',item) + ' More' }}\n                                                            </span>\n                                                        </li>\n                                                    </ul>\n                                                </div>\n                                                <div class=\"mt-2\"\n                                                    *ngIf=\"getCompetenciesByType('Functional',item)?.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',item)\">\n                                                            <span class=\"competency-text\"> {{ comp.competencyThemeName\n                                                                }} -\n                                                                {{\n                                                                comp.competencySubThemeName }} </span>\n                                                        </li>\n                                                        <li *ngIf=\"hasMoreThanTwo('Functional',item)\"\n                                                            class=\"show-more-competency\">\n                                                            <span class=\"show-more-link cursor-pointer\"\n                                                                (click)=\"toggleCompetencies('Functional',item)\">\n                                                                {{ isExpanded('Functional',item) ? 'Show Less' : '+' +\n                                                                getRemainingCount('Functional',item) + ' More' }}\n                                                            </span>\n                                                        </li>\n                                                    </ul>\n                                                </div>\n                                                <div class=\"mt-2\" *ngIf=\"getCompetenciesByType('Domain',item)?.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',item)\">\n                                                            <span class=\"competency-text\"> {{ comp.competencyThemeName\n                                                                }} -\n                                                                {{\n                                                                comp.competencySubThemeName }} </span>\n                                                        </li>\n                                                        <li *ngIf=\"hasMoreThanTwo('Domain',item)\"\n                                                            class=\"show-more-competency\">\n                                                            <span class=\"show-more-link cursor-pointer\"\n                                                                (click)=\"toggleCompetencies('Domain',item)\">\n                                                                {{ isExpanded('Domain',item) ? 'Show Less' : '+' +\n                                                                getRemainingCount('Domain',item) + ' 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\">\n                                                            {{item?.relevancy}}%</div>\n                                                        <div class=\"percentage\" *ngIf=\"!item?.relevancy\">N/A</div>\n                                                    </div>\n\n                                                </div>\n\n                                            </div>\n\n                                        </div>\n                                    </div>\n\n                                    <!-- adding courses -->\n                                </div>\n                            </div>\n                        </ng-container>\n                    </div>\n                </div>\n\n                <!-- Footer -->\n\n            </div>\n            <footer class=\"org-footer\">\n                <div class=\"max-w-7xl mx-auto px-6 flex flex-col md:flex-row items-center justify-between\">\n                    <div class=\"flex items-center space-x-4 mb-4 mt-4 md:mb-0 footer-container\">\n                        <div class=\"footer-logo-container\">\n                            <img src=\"assets/icons/karmayogiLogo-min.png\" alt=\"Karmayogi Bharat Logo\" class=\"h-10\"\n                                style=\"margin-left:20px\" />\n                        </div>\n                        <div style=\"margin-left: 100px;\">\n                            <a href=\"https://karmayogibharat.gov.in\" target=\"_blank\" rel=\"noopener noreferrer\"\n                                class=\"text-sm font-semibold transition-colors\">\n                                karmayogibharat.gov.in\n                            </a>\n                        </div>\n\n\n                    </div>\n                    <div class=\"text-sm text-center md:text-right mb-4\" style=\"margin-left: 100px;\">\n                        <p>&copy; 2025 All Rights Reserved.</p>\n                    </div>\n                </div>\n            </footer>\n        </div>\n        <div class=\"popup-footer\">\n            <div>\n                <input class=\"btn-active\" type=\"button\" value=\"Download as Excel\" (click)=\"downloadCSV()\" />\n            </div>\n            <div>\n                <input class=\"btn-active\" type=\"button\" value=\"Download as PDF\"\n                    (click)=\"downloadPdfFromBE(openedFrom)\" />\n            </div>\n            <div>\n                <input class=\"btn-active\" type=\"button\" value=\"Cancel\" (click)=\"cancelForm()\" />\n            </div>\n        </div>\n    </div>\n    <div class=\"overlay-loader\" *ngIf=\"loading\">\n        <mat-spinner diameter=\"50\"></mat-spinner>\n    </div>"]}