@sunbird-cb/cbp-ai 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +24 -0
- package/esm2022/lib/ai-cbp-routing.module.mjs +56 -0
- package/esm2022/lib/ai-cbp.component.mjs +14 -0
- package/esm2022/lib/ai-cbp.module.mjs +263 -0
- package/esm2022/lib/ai-cbp.service.mjs +14 -0
- package/esm2022/lib/components/add-course/add-course.component.mjs +444 -0
- package/esm2022/lib/components/add-designation/add-designation.component.mjs +460 -0
- package/esm2022/lib/components/add-personalisation/add-personalisation.component.mjs +33 -0
- package/esm2022/lib/components/approval-request-form/approval-request-form.component.mjs +392 -0
- package/esm2022/lib/components/approval-requests/approval-requests.component.mjs +398 -0
- package/esm2022/lib/components/dashboard/dashboard.component.mjs +265 -0
- package/esm2022/lib/components/delete-role-mapping/delete-role-mapping.component.mjs +53 -0
- package/esm2022/lib/components/delete-role-mapping-popup/delete-role-mapping-popup.component.mjs +39 -0
- package/esm2022/lib/components/edit-cbp-plan/edit-cbp-plan.component.mjs +699 -0
- package/esm2022/lib/components/gap-analysis-recommended-course/gap-analysis-recommended-course.component.mjs +188 -0
- package/esm2022/lib/components/generate-course-recommendation/generate-course-recommendation.component.mjs +1949 -0
- package/esm2022/lib/components/list-popup/list-popup.component.mjs +32 -0
- package/esm2022/lib/components/review-request/review-request.component.mjs +138 -0
- package/esm2022/lib/components/role-mapping-generation/role-mapping-generation.component.mjs +1082 -0
- package/esm2022/lib/components/role-mapping-list/role-mapping-list.component.mjs +714 -0
- package/esm2022/lib/components/suggest-more-courses/suggest-more-courses.component.mjs +370 -0
- package/esm2022/lib/components/update-designation-hierarchy/update-designation-hierarchy.component.mjs +235 -0
- package/esm2022/lib/components/view-cbp-plan/view-cbp-plan.component.mjs +125 -0
- package/esm2022/lib/components/view-course-recommendation/view-course-recommendation.component.mjs +397 -0
- package/esm2022/lib/components/view-final-cbp-plan/view-final-cbp-plan.component.mjs +883 -0
- package/esm2022/lib/modules/initial-screen/initial-screen.component.mjs +127 -0
- package/esm2022/lib/modules/shared/constant/app.constant.mjs +2036 -0
- package/esm2022/lib/modules/shared/directives/clickoutside.directive.mjs +38 -0
- package/esm2022/lib/modules/shared/directives/directive.module.mjs +21 -0
- package/esm2022/lib/modules/shared/pipes/order-by-name.pipe.mjs +23 -0
- package/esm2022/lib/modules/shared/services/event.service.mjs +24 -0
- package/esm2022/lib/modules/shared/services/events.mjs +125 -0
- package/esm2022/lib/modules/shared/services/init.service.mjs +41 -0
- package/esm2022/lib/modules/shared/services/role-mapping.service.mjs +261 -0
- package/esm2022/lib/modules/shared/services/shared.service.mjs +869 -0
- package/esm2022/lib/modules/upload-document-page/progress-dialog/progress-dialog.component.mjs +53 -0
- package/esm2022/lib/modules/upload-document-page/upload-dialog/upload-dialog.component.mjs +186 -0
- package/esm2022/lib/modules/upload-document-page/upload-document-page.component.mjs +367 -0
- package/esm2022/lib/pipe-public-URL/pipe-public-URL.module.mjs +20 -0
- package/esm2022/lib/pipe-public-URL/pipe-public-URL.pipe.mjs +23 -0
- package/esm2022/public-api.mjs +14 -0
- package/esm2022/sunbird-cb-cbp-ai.mjs +5 -0
- package/fesm2022/sunbird-cb-cbp-ai.mjs +12952 -0
- package/fesm2022/sunbird-cb-cbp-ai.mjs.map +1 -0
- package/index.d.ts +6 -0
- package/lib/ai-cbp-routing.module.d.ts +8 -0
- package/lib/ai-cbp-routing.module.d.ts.map +1 -0
- package/lib/ai-cbp.component.d.ts +7 -0
- package/lib/ai-cbp.component.d.ts.map +1 -0
- package/lib/ai-cbp.module.d.ts +68 -0
- package/lib/ai-cbp.module.d.ts.map +1 -0
- package/lib/ai-cbp.service.d.ts +7 -0
- package/lib/ai-cbp.service.d.ts.map +1 -0
- package/lib/components/add-course/add-course.component.d.ts +67 -0
- package/lib/components/add-course/add-course.component.d.ts.map +1 -0
- package/lib/components/add-designation/add-designation.component.d.ts +52 -0
- package/lib/components/add-designation/add-designation.component.d.ts.map +1 -0
- package/lib/components/add-personalisation/add-personalisation.component.d.ts +16 -0
- package/lib/components/add-personalisation/add-personalisation.component.d.ts.map +1 -0
- package/lib/components/approval-request-form/approval-request-form.component.d.ts +48 -0
- package/lib/components/approval-request-form/approval-request-form.component.d.ts.map +1 -0
- package/lib/components/approval-requests/approval-requests.component.d.ts +80 -0
- package/lib/components/approval-requests/approval-requests.component.d.ts.map +1 -0
- package/lib/components/dashboard/dashboard.component.d.ts +55 -0
- package/lib/components/dashboard/dashboard.component.d.ts.map +1 -0
- package/lib/components/delete-role-mapping/delete-role-mapping.component.d.ts +18 -0
- package/lib/components/delete-role-mapping/delete-role-mapping.component.d.ts.map +1 -0
- package/lib/components/delete-role-mapping-popup/delete-role-mapping-popup.component.d.ts +18 -0
- package/lib/components/delete-role-mapping-popup/delete-role-mapping-popup.component.d.ts.map +1 -0
- package/lib/components/edit-cbp-plan/edit-cbp-plan.component.d.ts +94 -0
- package/lib/components/edit-cbp-plan/edit-cbp-plan.component.d.ts.map +1 -0
- package/lib/components/gap-analysis-recommended-course/gap-analysis-recommended-course.component.d.ts +35 -0
- package/lib/components/gap-analysis-recommended-course/gap-analysis-recommended-course.component.d.ts.map +1 -0
- package/lib/components/generate-course-recommendation/generate-course-recommendation.component.d.ts +198 -0
- package/lib/components/generate-course-recommendation/generate-course-recommendation.component.d.ts.map +1 -0
- package/lib/components/list-popup/list-popup.component.d.ts +13 -0
- package/lib/components/list-popup/list-popup.component.d.ts.map +1 -0
- package/lib/components/review-request/review-request.component.d.ts +39 -0
- package/lib/components/review-request/review-request.component.d.ts.map +1 -0
- package/lib/components/role-mapping-generation/role-mapping-generation.component.d.ts +99 -0
- package/lib/components/role-mapping-generation/role-mapping-generation.component.d.ts.map +1 -0
- package/lib/components/role-mapping-list/role-mapping-list.component.d.ts +83 -0
- package/lib/components/role-mapping-list/role-mapping-list.component.d.ts.map +1 -0
- package/lib/components/suggest-more-courses/suggest-more-courses.component.d.ts +48 -0
- package/lib/components/suggest-more-courses/suggest-more-courses.component.d.ts.map +1 -0
- package/lib/components/update-designation-hierarchy/update-designation-hierarchy.component.d.ts +41 -0
- package/lib/components/update-designation-hierarchy/update-designation-hierarchy.component.d.ts.map +1 -0
- package/lib/components/view-cbp-plan/view-cbp-plan.component.d.ts +29 -0
- package/lib/components/view-cbp-plan/view-cbp-plan.component.d.ts.map +1 -0
- package/lib/components/view-course-recommendation/view-course-recommendation.component.d.ts +49 -0
- package/lib/components/view-course-recommendation/view-course-recommendation.component.d.ts.map +1 -0
- package/lib/components/view-final-cbp-plan/view-final-cbp-plan.component.d.ts +73 -0
- package/lib/components/view-final-cbp-plan/view-final-cbp-plan.component.d.ts.map +1 -0
- package/lib/modules/initial-screen/initial-screen.component.d.ts +85 -0
- package/lib/modules/initial-screen/initial-screen.component.d.ts.map +1 -0
- package/lib/modules/shared/constant/app.constant.d.ts +457 -0
- package/lib/modules/shared/constant/app.constant.d.ts.map +1 -0
- package/lib/modules/shared/directives/clickoutside.directive.d.ts +13 -0
- package/lib/modules/shared/directives/clickoutside.directive.d.ts.map +1 -0
- package/lib/modules/shared/directives/directive.module.d.ts +8 -0
- package/lib/modules/shared/directives/directive.module.d.ts.map +1 -0
- package/lib/modules/shared/pipes/order-by-name.pipe.d.ts +8 -0
- package/lib/modules/shared/pipes/order-by-name.pipe.d.ts.map +1 -0
- package/lib/modules/shared/services/event.service.d.ts +12 -0
- package/lib/modules/shared/services/event.service.d.ts.map +1 -0
- package/lib/modules/shared/services/events.d.ts +200 -0
- package/lib/modules/shared/services/events.d.ts.map +1 -0
- package/lib/modules/shared/services/init.service.d.ts +13 -0
- package/lib/modules/shared/services/init.service.d.ts.map +1 -0
- package/lib/modules/shared/services/role-mapping.service.d.ts +21 -0
- package/lib/modules/shared/services/role-mapping.service.d.ts.map +1 -0
- package/lib/modules/shared/services/shared.service.d.ts +108 -0
- package/lib/modules/shared/services/shared.service.d.ts.map +1 -0
- package/lib/modules/upload-document-page/progress-dialog/progress-dialog.component.d.ts +14 -0
- package/lib/modules/upload-document-page/progress-dialog/progress-dialog.component.d.ts.map +1 -0
- package/lib/modules/upload-document-page/upload-dialog/upload-dialog.component.d.ts +29 -0
- package/lib/modules/upload-document-page/upload-dialog/upload-dialog.component.d.ts.map +1 -0
- package/lib/modules/upload-document-page/upload-document-page.component.d.ts +64 -0
- package/lib/modules/upload-document-page/upload-document-page.component.d.ts.map +1 -0
- package/lib/pipe-public-URL/pipe-public-URL.module.d.ts +9 -0
- package/lib/pipe-public-URL/pipe-public-URL.module.d.ts.map +1 -0
- package/lib/pipe-public-URL/pipe-public-URL.pipe.d.ts +11 -0
- package/lib/pipe-public-URL/pipe-public-URL.pipe.d.ts.map +1 -0
- package/package.json +28 -0
- package/public-api.d.ts +11 -0
- package/public-api.d.ts.map +1 -0
- package/sunbird-cb-cbp-ai-0.0.1.tgz +0 -0
- package/sunbird-cb-cbp-ai.d.ts.map +1 -0
|
@@ -0,0 +1,714 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { MatTableDataSource } from '@angular/material/table';
|
|
3
|
+
import { MatPaginator } from '@angular/material/paginator';
|
|
4
|
+
import { ViewCbpPlanComponent } from '../view-cbp-plan/view-cbp-plan.component';
|
|
5
|
+
import { EditCbpPlanComponent } from '../edit-cbp-plan/edit-cbp-plan.component';
|
|
6
|
+
import { GenerateCourseRecommendationComponent } from '../generate-course-recommendation/generate-course-recommendation.component';
|
|
7
|
+
import { DeleteRoleMappingComponent } from '../delete-role-mapping/delete-role-mapping.component';
|
|
8
|
+
import { ViewCourseRecommendationComponent } from '../view-course-recommendation/view-course-recommendation.component';
|
|
9
|
+
import { ViewFinalCbpPlanComponent } from '../view-final-cbp-plan/view-final-cbp-plan.component';
|
|
10
|
+
import { ListPopupComponent } from '../list-popup/list-popup.component';
|
|
11
|
+
import { AddDesignationComponent } from '../add-designation/add-designation.component';
|
|
12
|
+
import { SelectionModel } from '@angular/cdk/collections';
|
|
13
|
+
import { ApprovalRequestFormComponent } from '../approval-request-form/approval-request-form.component';
|
|
14
|
+
import * as i0 from "@angular/core";
|
|
15
|
+
import * as i1 from "../../modules/shared/services/shared.service";
|
|
16
|
+
import * as i2 from "@angular/material/dialog";
|
|
17
|
+
import * as i3 from "@angular/common";
|
|
18
|
+
import * as i4 from "@angular/material/legacy-card";
|
|
19
|
+
import * as i5 from "@angular/forms";
|
|
20
|
+
import * as i6 from "@angular/material/legacy-button";
|
|
21
|
+
import * as i7 from "@angular/material/icon";
|
|
22
|
+
import * as i8 from "@angular/material/progress-spinner";
|
|
23
|
+
import * as i9 from "@angular/material/table";
|
|
24
|
+
import * as i10 from "@angular/material/paginator";
|
|
25
|
+
import * as i11 from "@angular/material/menu";
|
|
26
|
+
export class RoleMappingListComponent {
|
|
27
|
+
constructor(sharedService, dialog) {
|
|
28
|
+
this.sharedService = sharedService;
|
|
29
|
+
this.dialog = dialog;
|
|
30
|
+
this.formData = {};
|
|
31
|
+
this.searchText = '';
|
|
32
|
+
this.selectedValue = '';
|
|
33
|
+
//'select'
|
|
34
|
+
this.displayedColumns = [
|
|
35
|
+
'designation_name',
|
|
36
|
+
'role_responsibilities',
|
|
37
|
+
'activities',
|
|
38
|
+
'behavioral',
|
|
39
|
+
'functional',
|
|
40
|
+
'domain',
|
|
41
|
+
'action'
|
|
42
|
+
];
|
|
43
|
+
this.dataSource = new MatTableDataSource([]);
|
|
44
|
+
this.originalDataSource = new MatTableDataSource([]);
|
|
45
|
+
this.filteredData = [];
|
|
46
|
+
this.originalData = [];
|
|
47
|
+
this.searchResults = []; // Store search results for pagination
|
|
48
|
+
this.expandedResponsibilityRows = {};
|
|
49
|
+
this.expandedActivityRows = {};
|
|
50
|
+
this.cbpFinalObj = {};
|
|
51
|
+
this.loading = false;
|
|
52
|
+
this.selection = new SelectionModel(true, []); // true = multi-select
|
|
53
|
+
this.matchedRoleMapping = 0;
|
|
54
|
+
this.unMatchedRoleMapping = 0;
|
|
55
|
+
this.matchedRoleMappingIds = [];
|
|
56
|
+
this.matchedDesignationNames = [];
|
|
57
|
+
this.moveToInitialScreen = new EventEmitter();
|
|
58
|
+
this.activeTab = 'matched';
|
|
59
|
+
this.matchedDesignationSet = new Set();
|
|
60
|
+
this.masterData = [];
|
|
61
|
+
this.tabFilteredData = []; // after matched/unmatched filter
|
|
62
|
+
}
|
|
63
|
+
ngAfterViewInit() {
|
|
64
|
+
// this.dataSource.paginator = this.paginator;
|
|
65
|
+
// this.dataSource.sort = this.sort;
|
|
66
|
+
}
|
|
67
|
+
ngOnInit() {
|
|
68
|
+
console.log('haredService?.cbpPlanFinalObj', this.sharedService?.cbpPlanFinalObj);
|
|
69
|
+
this.sharedService.checkRoleMappingFormValidation.next(true);
|
|
70
|
+
this.sharedService.updateDesignationHierarchySubject.subscribe((data) => {
|
|
71
|
+
if (data) {
|
|
72
|
+
this.loadRoleMappingList();
|
|
73
|
+
}
|
|
74
|
+
});
|
|
75
|
+
this.loadRoleMappingList();
|
|
76
|
+
}
|
|
77
|
+
getCompetenciesByType(competencies, type) {
|
|
78
|
+
return competencies?.filter(c => c.type === type) || [];
|
|
79
|
+
}
|
|
80
|
+
viewDetails(element) {
|
|
81
|
+
console.log('View clicked:', element);
|
|
82
|
+
}
|
|
83
|
+
deleteItem(element) {
|
|
84
|
+
console.log('Delete clicked:', element);
|
|
85
|
+
// Optionally remove from dataSource
|
|
86
|
+
this.dataSource.data = this.dataSource.data.filter(item => item.id !== element.id);
|
|
87
|
+
}
|
|
88
|
+
searchData() {
|
|
89
|
+
this.applyFilter();
|
|
90
|
+
}
|
|
91
|
+
applyFilter() {
|
|
92
|
+
// if (this.searchText.trim()) {
|
|
93
|
+
// // Search only in designation names
|
|
94
|
+
// this.searchResults = this.filterByDesignationName(this.searchText);
|
|
95
|
+
// this.dataSource = new MatTableDataSource(this.searchResults);
|
|
96
|
+
// } else {
|
|
97
|
+
// // If search is cleared, restore original data
|
|
98
|
+
// this.searchResults = [];
|
|
99
|
+
// this.dataSource = new MatTableDataSource(this.originalData);
|
|
100
|
+
// }
|
|
101
|
+
// // Set up pagination for filtered results
|
|
102
|
+
// setTimeout(() => {
|
|
103
|
+
// if (this.paginator) {
|
|
104
|
+
// this.dataSource.paginator = this.paginator;
|
|
105
|
+
// this.paginator.firstPage();
|
|
106
|
+
// }
|
|
107
|
+
// }, 100);
|
|
108
|
+
this.applyAllFilters();
|
|
109
|
+
}
|
|
110
|
+
clearSearch() {
|
|
111
|
+
// this.searchText = '';
|
|
112
|
+
// this.searchResults = [];
|
|
113
|
+
// this.dataSource = new MatTableDataSource(this.originalData);
|
|
114
|
+
// setTimeout(() => {
|
|
115
|
+
// if (this.paginator) {
|
|
116
|
+
// this.dataSource.paginator = this.paginator;
|
|
117
|
+
// this.paginator.firstPage();
|
|
118
|
+
// }
|
|
119
|
+
// }, 100);
|
|
120
|
+
this.searchText = '';
|
|
121
|
+
this.applyAllFilters();
|
|
122
|
+
}
|
|
123
|
+
refreshRoleMappingData() {
|
|
124
|
+
console.log('Refreshing role mapping data...');
|
|
125
|
+
if (this.sharedService.cbpPlanFinalObj && this.sharedService.cbpPlanFinalObj.ministry && this.sharedService.cbpPlanFinalObj.ministry.identifier) {
|
|
126
|
+
const ministryType = this.sharedService.cbpPlanFinalObj.ministry.sbOrgType;
|
|
127
|
+
const ministryId = this.sharedService.cbpPlanFinalObj.ministry.identifier;
|
|
128
|
+
this.loading = true;
|
|
129
|
+
if (ministryType === 'ministry') {
|
|
130
|
+
if (this.sharedService.cbpPlanFinalObj.departments) {
|
|
131
|
+
const departmentId = this.sharedService.cbpPlanFinalObj.departments;
|
|
132
|
+
this.sharedService.getRoleMappingByStateCenterAndDepartment(ministryId, departmentId).subscribe({
|
|
133
|
+
next: (res) => {
|
|
134
|
+
this.loading = false;
|
|
135
|
+
console.log('State role mapping data refreshed:', res);
|
|
136
|
+
this.updateDataSource(res);
|
|
137
|
+
},
|
|
138
|
+
error: (error) => {
|
|
139
|
+
this.loading = false;
|
|
140
|
+
console.error('Error refreshing state role mapping data:', error);
|
|
141
|
+
}
|
|
142
|
+
});
|
|
143
|
+
}
|
|
144
|
+
else {
|
|
145
|
+
this.sharedService.getRoleMappingByStateCenter(ministryId).subscribe({
|
|
146
|
+
next: (res) => {
|
|
147
|
+
this.loading = false;
|
|
148
|
+
console.log('Center role mapping data refreshed:', res);
|
|
149
|
+
this.updateDataSource(res);
|
|
150
|
+
},
|
|
151
|
+
error: (error) => {
|
|
152
|
+
this.loading = false;
|
|
153
|
+
console.error('Error refreshing center role mapping data:', error);
|
|
154
|
+
}
|
|
155
|
+
});
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
else if (ministryType === 'state') {
|
|
159
|
+
const departmentId = this.sharedService.cbpPlanFinalObj.departments;
|
|
160
|
+
this.sharedService.getRoleMappingByStateCenterAndDepartment(ministryId, departmentId).subscribe({
|
|
161
|
+
next: (res) => {
|
|
162
|
+
this.loading = false;
|
|
163
|
+
console.log('State role mapping data refreshed:', res);
|
|
164
|
+
this.updateDataSource(res);
|
|
165
|
+
},
|
|
166
|
+
error: (error) => {
|
|
167
|
+
this.loading = false;
|
|
168
|
+
console.error('Error refreshing state role mapping data:', error);
|
|
169
|
+
}
|
|
170
|
+
});
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
this.loading = false;
|
|
174
|
+
}
|
|
175
|
+
updateDataSource(res) {
|
|
176
|
+
this.sharedService.cbpPlanFinalObj['role_mapping_generation'] = res;
|
|
177
|
+
this.dataSource = new MatTableDataSource(res);
|
|
178
|
+
this.originalData = res;
|
|
179
|
+
this.searchResults = []; // Clear search results when data is updated
|
|
180
|
+
setTimeout(() => {
|
|
181
|
+
this.dataSource.paginator = this.paginator;
|
|
182
|
+
}, 100);
|
|
183
|
+
console.log('DataSource updated:', this.dataSource);
|
|
184
|
+
}
|
|
185
|
+
editRoleMapping(element) {
|
|
186
|
+
this.activeRowElement = element;
|
|
187
|
+
console.log('Edit Role Mapping clicked', element);
|
|
188
|
+
// Navigate or open modal
|
|
189
|
+
console.log('View CBP Plan clicked', element);
|
|
190
|
+
const dialogRef = this.dialog.open(EditCbpPlanComponent, {
|
|
191
|
+
width: '1000px',
|
|
192
|
+
data: element,
|
|
193
|
+
panelClass: 'view-cbp-plan-popup',
|
|
194
|
+
minHeight: '300px',
|
|
195
|
+
maxHeight: '80vh',
|
|
196
|
+
disableClose: true // Optional: prevent closing with outside click
|
|
197
|
+
});
|
|
198
|
+
dialogRef.afterClosed().subscribe(result => {
|
|
199
|
+
// if (result === 'saved') {
|
|
200
|
+
// console.log('Changes saved!');
|
|
201
|
+
// // Refresh data or show a toast here
|
|
202
|
+
// }
|
|
203
|
+
this.refreshRoleMappingData();
|
|
204
|
+
});
|
|
205
|
+
}
|
|
206
|
+
viewCBPPlan(element) {
|
|
207
|
+
this.activeRowElement = element;
|
|
208
|
+
console.log('View CBP Plan clicked', element);
|
|
209
|
+
const dialogRef = this.dialog.open(ViewCbpPlanComponent, {
|
|
210
|
+
width: '1000px',
|
|
211
|
+
data: element,
|
|
212
|
+
panelClass: 'view-cbp-plan-popup',
|
|
213
|
+
minHeight: '300px',
|
|
214
|
+
maxHeight: '80vh',
|
|
215
|
+
disableClose: true // Optional: prevent closing with outside click
|
|
216
|
+
});
|
|
217
|
+
dialogRef.afterClosed().subscribe(result => {
|
|
218
|
+
if (result === 'saved') {
|
|
219
|
+
console.log('Changes saved!');
|
|
220
|
+
// Refresh data or show a toast here
|
|
221
|
+
}
|
|
222
|
+
});
|
|
223
|
+
}
|
|
224
|
+
generateCourseRecommendation(element) {
|
|
225
|
+
console.log('Generate Course Recommendation clicked', element);
|
|
226
|
+
this.activeRowElement = element;
|
|
227
|
+
console.log('Edit Role Mapping clicked', element);
|
|
228
|
+
// Navigate or open modal
|
|
229
|
+
console.log('View CBP Plan clicked', element);
|
|
230
|
+
const dialogRef = this.dialog.open(GenerateCourseRecommendationComponent, {
|
|
231
|
+
width: '1100px',
|
|
232
|
+
data: element,
|
|
233
|
+
panelClass: 'view-cbp-plan-popup',
|
|
234
|
+
minHeight: '400px',
|
|
235
|
+
maxHeight: '90vh',
|
|
236
|
+
disableClose: true // Optional: prevent closing with outside click
|
|
237
|
+
});
|
|
238
|
+
dialogRef.afterClosed().subscribe(result => {
|
|
239
|
+
if (result === 'saved') {
|
|
240
|
+
console.log('Changes saved!');
|
|
241
|
+
// Refresh data or show a toast here
|
|
242
|
+
console.log(this.sharedService.cbpPlanFinalObj);
|
|
243
|
+
if (this.sharedService.cbpPlanFinalObj && this.sharedService.cbpPlanFinalObj.ministry && this.sharedService.cbpPlanFinalObj.ministry.identifier) {
|
|
244
|
+
if (this.sharedService.cbpPlanFinalObj.departments) {
|
|
245
|
+
this.loading = true;
|
|
246
|
+
this.sharedService.getRoleMappingByStateCenter(this.sharedService.cbpPlanFinalObj.ministry.identifier).subscribe((res) => {
|
|
247
|
+
console.log('res', res);
|
|
248
|
+
this.selection.clear();
|
|
249
|
+
this.loadRoleMappingList();
|
|
250
|
+
this.loading = false;
|
|
251
|
+
});
|
|
252
|
+
}
|
|
253
|
+
else {
|
|
254
|
+
this.loading = true;
|
|
255
|
+
this.sharedService.getRoleMappingByStateCenterAndDepartment(this.sharedService.cbpPlanFinalObj.ministry.identifier, this.sharedService.cbpPlanFinalObj.departments).subscribe((res) => {
|
|
256
|
+
console.log('res', res);
|
|
257
|
+
this.selection.clear();
|
|
258
|
+
this.loadRoleMappingList();
|
|
259
|
+
console.log('this.dataSource', this.dataSource);
|
|
260
|
+
this.loading = false;
|
|
261
|
+
});
|
|
262
|
+
}
|
|
263
|
+
}
|
|
264
|
+
else if (this.sharedService.cbpPlanFinalObj && this.sharedService.cbpPlanFinalObj.ministry && this.sharedService.cbpPlanFinalObj.ministry.identifier && this.sharedService.cbpPlanFinalObj.departments) {
|
|
265
|
+
{
|
|
266
|
+
this.loading = true;
|
|
267
|
+
this.sharedService.getRoleMappingByStateCenterAndDepartment(this.sharedService.cbpPlanFinalObj.ministry.identifier, this.sharedService.cbpPlanFinalObj.departments).subscribe((res) => {
|
|
268
|
+
console.log('res', res);
|
|
269
|
+
this.selection.clear();
|
|
270
|
+
this.loadRoleMappingList();
|
|
271
|
+
console.log('this.dataSource', this.dataSource);
|
|
272
|
+
this.loading = false;
|
|
273
|
+
});
|
|
274
|
+
}
|
|
275
|
+
}
|
|
276
|
+
}
|
|
277
|
+
});
|
|
278
|
+
}
|
|
279
|
+
viewCourseRecommendation(element) {
|
|
280
|
+
console.log('View Course Recommendation clicked', element);
|
|
281
|
+
this.activeRowElement = element;
|
|
282
|
+
console.log('Edit Role Mapping clicked', element);
|
|
283
|
+
// Navigate or open modal
|
|
284
|
+
console.log('View CBP Plan clicked', element);
|
|
285
|
+
const dialogRef = this.dialog.open(ViewCourseRecommendationComponent, {
|
|
286
|
+
width: '1000px',
|
|
287
|
+
data: element,
|
|
288
|
+
panelClass: 'view-cbp-plan-popup',
|
|
289
|
+
minHeight: '400px',
|
|
290
|
+
maxHeight: '90vh',
|
|
291
|
+
disableClose: true // Optional: prevent closing with outside click
|
|
292
|
+
});
|
|
293
|
+
dialogRef.afterClosed().subscribe(result => {
|
|
294
|
+
if (result === 'saved') {
|
|
295
|
+
console.log('Changes saved!');
|
|
296
|
+
// Refresh data or show a toast here
|
|
297
|
+
console.log(this.sharedService.cbpPlanFinalObj);
|
|
298
|
+
if (this.sharedService.cbpPlanFinalObj && this.sharedService.cbpPlanFinalObj.ministry && this.sharedService.cbpPlanFinalObj.ministry.id) {
|
|
299
|
+
this.sharedService.getRoleMappingByStateCenter(this.sharedService.cbpPlanFinalObj.ministry.id).subscribe((res) => {
|
|
300
|
+
console.log('res', res);
|
|
301
|
+
this.dataSource = new MatTableDataSource(res);
|
|
302
|
+
this.dataSource.paginator = this.paginator;
|
|
303
|
+
this.originalData = res;
|
|
304
|
+
console.log('this.dataSource', this.dataSource);
|
|
305
|
+
});
|
|
306
|
+
}
|
|
307
|
+
else {
|
|
308
|
+
}
|
|
309
|
+
}
|
|
310
|
+
});
|
|
311
|
+
}
|
|
312
|
+
/**
|
|
313
|
+
* Filter data by designation name only
|
|
314
|
+
* Supports single and multiple word searches
|
|
315
|
+
*/
|
|
316
|
+
filterByDesignationName(searchText) {
|
|
317
|
+
const searchTerms = searchText.trim().toLowerCase().split(/\s+/);
|
|
318
|
+
return this.originalData.filter(item => {
|
|
319
|
+
const designationName = (item.designation_name || '').toLowerCase();
|
|
320
|
+
// Check if all search terms are found in the designation name
|
|
321
|
+
return searchTerms.every(term => designationName.includes(term));
|
|
322
|
+
});
|
|
323
|
+
}
|
|
324
|
+
flattenObjectToString(obj) {
|
|
325
|
+
let result = '';
|
|
326
|
+
for (const key in obj) {
|
|
327
|
+
const value = obj[key];
|
|
328
|
+
if (typeof value === 'string') {
|
|
329
|
+
result += ' ' + value;
|
|
330
|
+
}
|
|
331
|
+
else if (Array.isArray(value)) {
|
|
332
|
+
value.forEach(val => {
|
|
333
|
+
if (typeof val === 'string') {
|
|
334
|
+
result += ' ' + val;
|
|
335
|
+
}
|
|
336
|
+
else if (typeof val === 'object') {
|
|
337
|
+
result += ' ' + this.flattenObjectToString(val);
|
|
338
|
+
}
|
|
339
|
+
});
|
|
340
|
+
}
|
|
341
|
+
else if (typeof value === 'object' && value !== null) {
|
|
342
|
+
result += ' ' + this.flattenObjectToString(value);
|
|
343
|
+
}
|
|
344
|
+
}
|
|
345
|
+
return result;
|
|
346
|
+
}
|
|
347
|
+
getSectors(sector) {
|
|
348
|
+
if (sector && sector.length) {
|
|
349
|
+
return Array.isArray(sector) ? sector.join('/ ') : '';
|
|
350
|
+
}
|
|
351
|
+
}
|
|
352
|
+
toggleResponsibilityExpand(id) {
|
|
353
|
+
this.expandedResponsibilityRows[id] = !this.expandedResponsibilityRows[id];
|
|
354
|
+
}
|
|
355
|
+
isResponisbilityExpanded(id) {
|
|
356
|
+
// const dialogRef = this.dialog.open(ListPopupComponent, {
|
|
357
|
+
// width: '1000px',
|
|
358
|
+
// data: this.activeRowElement,
|
|
359
|
+
// panelClass: 'view-cbp-plan-popup',
|
|
360
|
+
// minHeight: '400px', // Set minimum height
|
|
361
|
+
// maxHeight: '90vh', // Prevent it from going beyond viewport
|
|
362
|
+
// disableClose: true // Optional: prevent closing with outside click
|
|
363
|
+
// });
|
|
364
|
+
// dialogRef.afterClosed().subscribe(result => {
|
|
365
|
+
// return false
|
|
366
|
+
// });
|
|
367
|
+
return this.expandedResponsibilityRows[id];
|
|
368
|
+
}
|
|
369
|
+
toggleActivityExpand(id) {
|
|
370
|
+
this.expandedActivityRows[id] = !this.expandedActivityRows[id];
|
|
371
|
+
}
|
|
372
|
+
isActivityExpanded(id) {
|
|
373
|
+
return this.expandedActivityRows[id];
|
|
374
|
+
}
|
|
375
|
+
addMoreDesignation() {
|
|
376
|
+
const dialogRef = this.dialog.open(AddDesignationComponent, {
|
|
377
|
+
width: '600px',
|
|
378
|
+
data: { state_center_id: '' },
|
|
379
|
+
panelClass: 'view-cbp-plan-popup',
|
|
380
|
+
minHeight: '300px',
|
|
381
|
+
maxHeight: '90vh',
|
|
382
|
+
disableClose: true // Optional: prevent closing with outside click
|
|
383
|
+
});
|
|
384
|
+
dialogRef.afterClosed().subscribe(result => {
|
|
385
|
+
if (result === 'saved') {
|
|
386
|
+
console.log('Changes saved!');
|
|
387
|
+
// Refresh data or show a toast here
|
|
388
|
+
this.refreshRoleMappingData();
|
|
389
|
+
}
|
|
390
|
+
});
|
|
391
|
+
}
|
|
392
|
+
deleteRoleMapping(element) {
|
|
393
|
+
console.log('Generate Course Recommendation clicked', element);
|
|
394
|
+
this.activeRowElement = element;
|
|
395
|
+
console.log('Edit Role Mapping clicked', element);
|
|
396
|
+
// Navigate or open modal
|
|
397
|
+
console.log('View CBP Plan clicked', element);
|
|
398
|
+
const dialogRef = this.dialog.open(DeleteRoleMappingComponent, {
|
|
399
|
+
width: '600px',
|
|
400
|
+
data: element,
|
|
401
|
+
panelClass: 'view-cbp-plan-popup',
|
|
402
|
+
minHeight: '300px',
|
|
403
|
+
maxHeight: '90vh',
|
|
404
|
+
disableClose: true // Optional: prevent closing with outside click
|
|
405
|
+
});
|
|
406
|
+
dialogRef.afterClosed().subscribe(result => {
|
|
407
|
+
if (result === 'saved') {
|
|
408
|
+
console.log('Changes saved!');
|
|
409
|
+
// Refresh data or show a toast here
|
|
410
|
+
console.log(this.sharedService.cbpPlanFinalObj);
|
|
411
|
+
if (this.sharedService.cbpPlanFinalObj && this.sharedService.cbpPlanFinalObj.ministry && this.sharedService.cbpPlanFinalObj.ministry.identifier &&
|
|
412
|
+
this.sharedService.cbpPlanFinalObj.ministry?.sbOrgType === 'ministry') {
|
|
413
|
+
if (this.sharedService.cbpPlanFinalObj.departments) {
|
|
414
|
+
this.sharedService.getRoleMappingByStateCenterAndDepartment(this.sharedService.cbpPlanFinalObj.ministry.identifier, this.sharedService.cbpPlanFinalObj.departments).subscribe((res) => {
|
|
415
|
+
console.log('res', res);
|
|
416
|
+
this.dataSource = new MatTableDataSource(res);
|
|
417
|
+
this.dataSource.paginator = this.paginator;
|
|
418
|
+
this.originalData = res;
|
|
419
|
+
console.log('this.dataSource', this.dataSource);
|
|
420
|
+
});
|
|
421
|
+
}
|
|
422
|
+
else {
|
|
423
|
+
this.sharedService.getRoleMappingByStateCenter(this.sharedService.cbpPlanFinalObj.ministry.identifier).subscribe((res) => {
|
|
424
|
+
console.log('res', res);
|
|
425
|
+
this.dataSource = new MatTableDataSource(res);
|
|
426
|
+
this.dataSource.paginator = this.paginator;
|
|
427
|
+
this.originalData = res;
|
|
428
|
+
console.log('this.dataSource', this.dataSource);
|
|
429
|
+
});
|
|
430
|
+
}
|
|
431
|
+
}
|
|
432
|
+
else {
|
|
433
|
+
this.sharedService.getRoleMappingByStateCenterAndDepartment(this.sharedService.cbpPlanFinalObj.ministry.identifier, this.sharedService.cbpPlanFinalObj.departments).subscribe((res) => {
|
|
434
|
+
console.log('res', res);
|
|
435
|
+
this.dataSource = new MatTableDataSource(res);
|
|
436
|
+
this.dataSource.paginator = this.paginator;
|
|
437
|
+
this.originalData = res;
|
|
438
|
+
console.log('this.dataSource', this.dataSource);
|
|
439
|
+
});
|
|
440
|
+
}
|
|
441
|
+
}
|
|
442
|
+
});
|
|
443
|
+
}
|
|
444
|
+
viewFinalCBPPlan(context) {
|
|
445
|
+
const dialogRef = this.dialog.open(ViewFinalCbpPlanComponent, {
|
|
446
|
+
width: '1100px',
|
|
447
|
+
data: {
|
|
448
|
+
payload: this.originalData,
|
|
449
|
+
openedFrom: context // 👈 BEST PRACTICE
|
|
450
|
+
},
|
|
451
|
+
panelClass: 'view-cbp-plan-popup',
|
|
452
|
+
minHeight: '300px',
|
|
453
|
+
maxHeight: '90vh',
|
|
454
|
+
disableClose: true // Optional: prevent closing with outside click
|
|
455
|
+
});
|
|
456
|
+
dialogRef.afterClosed().subscribe(result => {
|
|
457
|
+
if (result === 'saved') {
|
|
458
|
+
console.log('Changes saved!');
|
|
459
|
+
// Refresh data or show a toast here
|
|
460
|
+
}
|
|
461
|
+
});
|
|
462
|
+
}
|
|
463
|
+
moveToInitialScreenLayout(event) {
|
|
464
|
+
this.moveToInitialScreen.emit(event);
|
|
465
|
+
}
|
|
466
|
+
openFullList(element, type) {
|
|
467
|
+
const listToShow = element[type] || [];
|
|
468
|
+
const title = type === 'role_responsibilities' ? 'Role & Responsibilities' : 'Activities';
|
|
469
|
+
const dialogRef = this.dialog.open(ListPopupComponent, {
|
|
470
|
+
width: '600px',
|
|
471
|
+
data: { element: element, type: type },
|
|
472
|
+
disableClose: true,
|
|
473
|
+
maxHeight: '80vh'
|
|
474
|
+
});
|
|
475
|
+
dialogRef.afterClosed().subscribe(() => {
|
|
476
|
+
// No need to do anything special here to reset inline expanded state
|
|
477
|
+
// Because you're using dialog, not inline expand – view remains in initial (collapsed) state
|
|
478
|
+
});
|
|
479
|
+
}
|
|
480
|
+
loadRoleMappingList() {
|
|
481
|
+
this.cbpFinalObj = this.sharedService.getCBPPlanLocalStorage();
|
|
482
|
+
this.dataSource = new MatTableDataSource(this.cbpFinalObj?.role_mapping_generation);
|
|
483
|
+
this.originalDataSource = new MatTableDataSource(this.cbpFinalObj?.role_mapping_generation);
|
|
484
|
+
this.originalData = this.cbpFinalObj?.role_mapping_generation;
|
|
485
|
+
if (this.cbpFinalObj && this.cbpFinalObj?.ministry && (this.cbpFinalObj?.ministry.sbOrgType)) {
|
|
486
|
+
this.sharedService.cbpPlanFinalObj = this.cbpFinalObj;
|
|
487
|
+
if (this.cbpFinalObj?.ministry.sbOrgType === 'ministry') {
|
|
488
|
+
this.formData = {};
|
|
489
|
+
this.formData['value'] = {};
|
|
490
|
+
this.formData['value']['ministryType'] = this.cbpFinalObj?.ministry.sbOrgType;
|
|
491
|
+
this.formData['value']['ministry'] = this.cbpFinalObj?.ministry?.identifier;
|
|
492
|
+
this.formData['value']['departments'] = this.cbpFinalObj?.departments;
|
|
493
|
+
}
|
|
494
|
+
else if (this.cbpFinalObj?.ministry.sbOrgType === 'state') {
|
|
495
|
+
this.formData = {};
|
|
496
|
+
this.formData['value'] = {};
|
|
497
|
+
this.formData['value']['ministryType'] = this.cbpFinalObj?.ministry.sbOrgType;
|
|
498
|
+
this.formData['value']['ministry'] = this.cbpFinalObj?.ministry?.identifier;
|
|
499
|
+
this.formData['value']['departments'] = this.cbpFinalObj?.departments;
|
|
500
|
+
}
|
|
501
|
+
}
|
|
502
|
+
console.log('this.formData', this.formData);
|
|
503
|
+
if (this.formData && this.formData.value && this.formData.value.ministryType === 'ministry') {
|
|
504
|
+
let state_center_id = this.formData.value.ministry;
|
|
505
|
+
this.loading = true;
|
|
506
|
+
if (this.formData.value.departments) {
|
|
507
|
+
let department_id = this.formData.value.departments;
|
|
508
|
+
if (typeof department_id === 'string') {
|
|
509
|
+
this.sharedService.getRoleMappingByStateCenterAndDepartment(state_center_id, department_id).subscribe({
|
|
510
|
+
next: (res) => {
|
|
511
|
+
this.loading = false;
|
|
512
|
+
this.sharedService.cbpPlanFinalObj['role_mapping_generation'] = res;
|
|
513
|
+
localStorage.setItem('cbpPlanFinalObj', JSON.stringify(this.sharedService.cbpPlanFinalObj));
|
|
514
|
+
let obj = {
|
|
515
|
+
state_center_id: this.formData.value.ministry
|
|
516
|
+
};
|
|
517
|
+
if (this.formData.value.departments) {
|
|
518
|
+
obj['department_id'] = this.formData.value.departments;
|
|
519
|
+
}
|
|
520
|
+
this.sharedService.getMatchedRoleMapping(obj).subscribe((matchedRoleMapping) => {
|
|
521
|
+
console.log('res', res);
|
|
522
|
+
console.log('matchedRoleMapping', matchedRoleMapping);
|
|
523
|
+
this.matchedRoleMapping = matchedRoleMapping?.matched_count;
|
|
524
|
+
this.matchedDesignationNames =
|
|
525
|
+
matchedRoleMapping?.matched_details?.map(x => x.igot_designation_name?.toLowerCase()) || [];
|
|
526
|
+
const matchedNames = matchedRoleMapping?.matched_details?.map(x => x.igot_designation_name?.trim().toLowerCase()) || [];
|
|
527
|
+
this.matchedDesignationSet = new Set(matchedNames);
|
|
528
|
+
this.matchedRoleMapping = matchedNames.length;
|
|
529
|
+
this.unMatchedRoleMapping = this.masterData.length - this.matchedRoleMapping;
|
|
530
|
+
this.applyAllFilters();
|
|
531
|
+
});
|
|
532
|
+
this.dataSource = new MatTableDataSource(res);
|
|
533
|
+
this.originalDataSource = new MatTableDataSource(res);
|
|
534
|
+
setTimeout(() => {
|
|
535
|
+
this.dataSource.paginator = this.paginator;
|
|
536
|
+
}, 1000);
|
|
537
|
+
this.originalData = res;
|
|
538
|
+
this.masterData = res;
|
|
539
|
+
console.log('this.dataSource', this.dataSource);
|
|
540
|
+
},
|
|
541
|
+
error: () => {
|
|
542
|
+
this.loading = false;
|
|
543
|
+
}
|
|
544
|
+
});
|
|
545
|
+
}
|
|
546
|
+
else {
|
|
547
|
+
this.loading = false;
|
|
548
|
+
}
|
|
549
|
+
}
|
|
550
|
+
else {
|
|
551
|
+
this.sharedService.getRoleMappingByStateCenter(state_center_id).subscribe((res) => {
|
|
552
|
+
this.loading = false;
|
|
553
|
+
console.log('res', res);
|
|
554
|
+
this.sharedService.cbpPlanFinalObj['role_mapping_generation'] = res;
|
|
555
|
+
localStorage.setItem('cbpPlanFinalObj', JSON.stringify(this.sharedService.cbpPlanFinalObj));
|
|
556
|
+
let obj = {
|
|
557
|
+
state_center_id: this.formData.value.ministry
|
|
558
|
+
};
|
|
559
|
+
if (this.formData.value.departments) {
|
|
560
|
+
obj['department_id'] = this.formData.value.departments;
|
|
561
|
+
}
|
|
562
|
+
this.sharedService.getMatchedRoleMapping(obj).subscribe((matchedRoleMapping) => {
|
|
563
|
+
console.log('res', res);
|
|
564
|
+
console.log('matchedRoleMapping', matchedRoleMapping);
|
|
565
|
+
this.matchedRoleMapping = matchedRoleMapping?.matched_count;
|
|
566
|
+
this.matchedDesignationNames =
|
|
567
|
+
matchedRoleMapping?.matched_details?.map(x => x.igot_designation_name?.toLowerCase()) || [];
|
|
568
|
+
const matchedNames = matchedRoleMapping?.matched_details?.map(x => x.igot_designation_name?.trim().toLowerCase()) || [];
|
|
569
|
+
this.matchedDesignationSet = new Set(matchedNames);
|
|
570
|
+
this.matchedRoleMapping = matchedNames.length;
|
|
571
|
+
this.unMatchedRoleMapping = this.masterData.length - this.matchedRoleMapping;
|
|
572
|
+
this.applyAllFilters();
|
|
573
|
+
});
|
|
574
|
+
this.dataSource = new MatTableDataSource(res);
|
|
575
|
+
this.originalDataSource = new MatTableDataSource(res);
|
|
576
|
+
setTimeout(() => {
|
|
577
|
+
this.dataSource.paginator = this.paginator;
|
|
578
|
+
}, 1000);
|
|
579
|
+
this.originalData = res;
|
|
580
|
+
this.masterData = res;
|
|
581
|
+
console.log('this.dataSource', this.dataSource);
|
|
582
|
+
});
|
|
583
|
+
}
|
|
584
|
+
}
|
|
585
|
+
if (this.formData && this.formData.value && this.formData.value.ministryType === 'state') {
|
|
586
|
+
this.loading = true;
|
|
587
|
+
console.log('this.formData', this.formData);
|
|
588
|
+
let state_center_id = this.formData.value.ministry;
|
|
589
|
+
let department_id = this.formData.value.departments;
|
|
590
|
+
this.sharedService.getRoleMappingByStateCenterAndDepartment(state_center_id, department_id).subscribe({
|
|
591
|
+
next: (res) => {
|
|
592
|
+
this.loading = false;
|
|
593
|
+
this.sharedService.cbpPlanFinalObj['role_mapping_generation'] = res;
|
|
594
|
+
localStorage.setItem('cbpPlanFinalObj', JSON.stringify(this.sharedService.cbpPlanFinalObj));
|
|
595
|
+
let obj = {
|
|
596
|
+
state_center_id: this.formData.value.ministry
|
|
597
|
+
};
|
|
598
|
+
if (this.formData.value.departments) {
|
|
599
|
+
obj['department_id'] = this.formData.value.departments;
|
|
600
|
+
}
|
|
601
|
+
this.sharedService.getMatchedRoleMapping(obj).subscribe((matchedRoleMapping) => {
|
|
602
|
+
console.log('res', res);
|
|
603
|
+
console.log('matchedRoleMapping', matchedRoleMapping);
|
|
604
|
+
this.matchedRoleMapping = matchedRoleMapping?.matched_count;
|
|
605
|
+
this.matchedDesignationNames =
|
|
606
|
+
matchedRoleMapping?.matched_details?.map(x => x.igot_designation_name?.toLowerCase()) || [];
|
|
607
|
+
const matchedNames = matchedRoleMapping?.matched_details?.map(x => x.igot_designation_name?.trim().toLowerCase()) || [];
|
|
608
|
+
this.matchedDesignationSet = new Set(matchedNames);
|
|
609
|
+
this.matchedRoleMapping = matchedNames.length;
|
|
610
|
+
this.unMatchedRoleMapping = this.masterData.length - this.matchedRoleMapping;
|
|
611
|
+
this.applyAllFilters();
|
|
612
|
+
});
|
|
613
|
+
this.dataSource = new MatTableDataSource(res);
|
|
614
|
+
this.originalDataSource = new MatTableDataSource(res);
|
|
615
|
+
setTimeout(() => {
|
|
616
|
+
this.dataSource.paginator = this.paginator;
|
|
617
|
+
}, 1000);
|
|
618
|
+
this.originalData = res;
|
|
619
|
+
this.masterData = res;
|
|
620
|
+
console.log('this.dataSource', this.dataSource);
|
|
621
|
+
},
|
|
622
|
+
error: () => {
|
|
623
|
+
this.loading = false;
|
|
624
|
+
}
|
|
625
|
+
});
|
|
626
|
+
}
|
|
627
|
+
}
|
|
628
|
+
toggleRow(row) {
|
|
629
|
+
if (!row?.cbp_plans?.length)
|
|
630
|
+
return;
|
|
631
|
+
this.selection.toggle(row);
|
|
632
|
+
console.log('Selected rows:', this.selection.selected);
|
|
633
|
+
}
|
|
634
|
+
isAllSelected() {
|
|
635
|
+
const numSelected = this.selection.selected.length;
|
|
636
|
+
const numRows = this.dataSource.data.length;
|
|
637
|
+
return numSelected === numRows;
|
|
638
|
+
}
|
|
639
|
+
isSomeSelected() {
|
|
640
|
+
const numSelected = this.selection.selected.length;
|
|
641
|
+
const numRows = this.dataSource.data.length;
|
|
642
|
+
return numSelected > 0 && numSelected < numRows;
|
|
643
|
+
}
|
|
644
|
+
toggleAllRows(event) {
|
|
645
|
+
if (event.checked) {
|
|
646
|
+
this.dataSource.data.forEach(row => this.selection.select(row));
|
|
647
|
+
}
|
|
648
|
+
else {
|
|
649
|
+
this.selection.clear();
|
|
650
|
+
}
|
|
651
|
+
}
|
|
652
|
+
setDataSoure(tab) {
|
|
653
|
+
this.activeTab = tab;
|
|
654
|
+
this.selection.clear();
|
|
655
|
+
this.applyAllFilters();
|
|
656
|
+
}
|
|
657
|
+
applyAllFilters() {
|
|
658
|
+
let data = [...this.masterData];
|
|
659
|
+
if (this.activeTab === 'matched') {
|
|
660
|
+
data = data.filter(item => this.matchedDesignationSet.has(item.designation_name?.trim().toLowerCase()));
|
|
661
|
+
}
|
|
662
|
+
if (this.activeTab === 'unmatched') {
|
|
663
|
+
data = data.filter(item => !this.matchedDesignationSet.has(item.designation_name?.trim().toLowerCase()));
|
|
664
|
+
}
|
|
665
|
+
if (this.searchText.trim()) {
|
|
666
|
+
const terms = this.searchText.toLowerCase().split(/\s+/);
|
|
667
|
+
data = data.filter(item => {
|
|
668
|
+
const name = (item.designation_name || '').toLowerCase();
|
|
669
|
+
return terms.every(term => name.includes(term));
|
|
670
|
+
});
|
|
671
|
+
}
|
|
672
|
+
this.dataSource = new MatTableDataSource(data);
|
|
673
|
+
setTimeout(() => {
|
|
674
|
+
this.dataSource.paginator = this.paginator;
|
|
675
|
+
});
|
|
676
|
+
}
|
|
677
|
+
sendForApprovalForm() {
|
|
678
|
+
console.log('this.selection--', this.selection.selected);
|
|
679
|
+
if (this.selection.selected.length) {
|
|
680
|
+
const dialogRef = this.dialog.open(ApprovalRequestFormComponent, {
|
|
681
|
+
width: '600px',
|
|
682
|
+
data: this.selection.selected,
|
|
683
|
+
panelClass: 'view-cbp-plan-popup',
|
|
684
|
+
minHeight: '300px',
|
|
685
|
+
maxHeight: '80vh',
|
|
686
|
+
disableClose: true // Optional: prevent closing with outside click
|
|
687
|
+
});
|
|
688
|
+
dialogRef.afterClosed().subscribe(result => {
|
|
689
|
+
// if (result === 'saved') {
|
|
690
|
+
// console.log('Changes saved!');
|
|
691
|
+
// // Refresh data or show a toast here
|
|
692
|
+
// }
|
|
693
|
+
this.refreshRoleMappingData();
|
|
694
|
+
});
|
|
695
|
+
}
|
|
696
|
+
}
|
|
697
|
+
hasSelectableRows() {
|
|
698
|
+
return this.dataSource?.data?.some((row) => row?.cbp_plans?.length > 0);
|
|
699
|
+
}
|
|
700
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: RoleMappingListComponent, deps: [{ token: i1.SharedService }, { token: i2.MatDialog }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
701
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: RoleMappingListComponent, selector: "app-role-mapping-list", inputs: { formData: "formData" }, outputs: { moveToInitialScreen: "moveToInitialScreen" }, viewQueries: [{ propertyName: "paginator", first: true, predicate: MatPaginator, descendants: true }], ngImport: i0, template: "<div class=\"role-mapping-container\">\n <div class=\"container-fluid\">\n\n <mat-card class=\"mt-0 pt-0\">\n <div class=\"section-header\">\n\n </div>\n <div class=\"edit-section mt-4\">\n <div class=\"select-map-route-container\">\n <div class=\"select-map-flex-container\">\n <div class=\"select-map-flex\">\n <div class=\"selected-mapping-route\">\n <p>{{sharedService?.cbpPlanFinalObj?.ministry?.orgName}} <span\n *ngIf=\"sharedService?.cbpPlanFinalObj?.department_name\">\n / {{sharedService?.cbpPlanFinalObj?.department_name}}</span>\n </p>\n </div>\n <div class=\"edit-plan cursor-pointer\" (click)=\"moveToInitialScreenLayout('edit')\">\n <mat-icon>edit</mat-icon>Edit\n </div>\n <!-- <div class=\"cursor-pointer ml-10\">-->\n <!-- <button class=\"btn-active cursor-pointer\" (click)=\"moveToInitialScreenLayout('add')\">-->\n <!-- <mat-icon>add</mat-icon>-->\n <!-- Create New CBP-->\n <!-- </button>-->\n <!-- </div>-->\n </div>\n <div>\n <div class=\"view-final-cbp-plan\">\n <!-- <div class=\"view-final-cbp-plan-text cursor-pointer\" (click)=\"viewFinalCBPPlan('cbp')\">\n <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span><span>View\n Final CBP</span>\n </div> -->\n\n <div class=\"view-final-cbp-plan-text cursor-pointer\" (click)=\"viewFinalCBPPlan('acbp')\">\n <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span><span>View\n Final CBP</span>\n </div>\n\n </div>\n\n </div>\n\n </div>\n </div>\n </div>\n <div class=\"search-filter-section mt-2\">\n <div class=\"search flex margin-right-m search-flex\">\n <div class=\"mt-2\">\n <div class=\"search-container\">\n <div class=\"rsearch\">\n <mat-icon\n class=\"color-60 search-icon mat-icon notranslate material-icons mat-icon-no-color\">search</mat-icon>\n <input class=\"sinput color-60 w-full\" [(ngModel)]=\"searchText\" label=\"\"\n (input)=\"applyFilter()\" placeholder=\"Search by designation name\" type=\"Standard\">\n <mat-icon *ngIf=\"searchText.trim().length > 0\"\n class=\"color-60 clear-icon mat-icon notranslate material-icons mat-icon-no-color cursor-pointer\"\n (click)=\"clearSearch()\">clear</mat-icon>\n </div>\n <div class=\"pl-2 mt-2\">\n <input [disabled]=\"searchText.trim()?.length === 0\"\n [ngClass]=\"searchText.trim()?.length === 0 ? 'btn-disable':'btn-active'\"\n type=\"button\" value=\"Search\" (click)=\"applyFilter()\" />\n </div>\n </div>\n\n\n </div>\n\n\n </div>\n <div class=\"filter-section flex margin-top-15\">\n <!-- <div>\n <label class=\"label\">Filter by competency type</label>\n <div>\n <mat-form-field appearance=\"fill\"\n style=\"background: white; border-radius: 25px; padding: 0 12px;\">\n <mat-select [(value)]=\"selectedValue\" placeholder=\"Select Ministry\"\n style=\"border-radius: 25px; background: white;\">\n <mat-option [value]=\"'test'\">Test</mat-option>\n <mat-option [value]=\"'another'\">Another</mat-option>\n </mat-select>\n </mat-form-field>\n </div>\n </div> -->\n <div class=\"btn-group\">\n <div class=\"ml-2\">\n <input class=\"btn-active\" type=\"button\" value=\"Add More Designation\"\n (click)=\"addMoreDesignation()\" />\n </div>\n <!-- <div class=\"ml-2\">\n <button\n [ngClass]=\"selection.selected.length ? 'btn-active-outline' : 'btn-active-outline-disable'\"\n (click)=\"sendForApprovalForm()\">\n <mat-icon>send</mat-icon>\n Send For Approval\n <span *ngIf=\"selection.selected.length\">({{selection.selected.length}})</span>\n </button>\n </div> -->\n\n\n </div>\n </div>\n </div>\n <div class=\"role-mapping-tabs mt-3\">\n <button class=\"role-tab\" [class.active]=\"activeTab === 'matched'\" (click)=\"setDataSoure('matched')\">\n <span class=\"dot\"></span>\n Matched role mappings\n <span class=\"badge blue\">{{matchedRoleMapping}}</span>\n </button>\n\n <button class=\"role-tab table-body-unmatched\" [class.active]=\"activeTab === 'unmatched'\"\n (click)=\"setDataSoure('unmatched')\">\n <span class=\"dot red\"></span>\n Unmatched role mapping\n <span class=\"badge red\">{{unMatchedRoleMapping}}</span>\n </button>\n </div>\n <div class=\"nav-container\">\n <div class=\"sidenav-content\">\n <div class=\"table-class\">\n <ng-container *ngIf=\"dataSource?.filteredData?.length > 0\">\n <!-- <table mat-table [dataSource]=\"dataSource\">\n <ng-container matColumnDef=\"RequestId\">\n <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Request ID </th>\n <td mat-cell class=\"title-class\" *matCellDef=\"let element\">{{element?.demand_id}}\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"title\">\n <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Title </th>\n <td mat-cell class=\"title-class\" *matCellDef=\"let element\">{{element?.title}}</td>\n </ng-container>\n\n <ng-container matColumnDef=\"requestor\">\n <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Requestor </th>\n <td mat-cell class=\"title-class\" *matCellDef=\"let element\">{{element?.ownerName}}\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"requestType\">\n <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Request Type </th>\n <td mat-cell class=\"title-class\" *matCellDef=\"let element\">{{element?.requestType}}\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"requestStatus\">\n <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Request Status </th>\n\n <td mat-cell class=\"title-class\" *matCellDef=\"let element\">\n <span [ngClass]=\"getStatusClass(element?.status)\">{{element?.status ===\n statusKey.fullfill ? 'Fulfilled'\n : element?.status}}</span>\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"assignee\">\n <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Assignee </th>\n <td mat-cell class=\"title-class\" *matCellDef=\"let element\">\n {{element?.assignedProvider ?\n element?.assignedProvider : 'Not Assigned' }}</td>\n </ng-container>\n\n <ng-container matColumnDef=\"requestedOn\">\n <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Requested On </th>\n <td mat-cell class=\"title-class\" *matCellDef=\"let element\">{{element?.createdOn |\n date}}</td>\n </ng-container>\n\n <ng-container matColumnDef=\"interests\">\n <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Interests</th>\n <td mat-cell class=\"title-class\" *matCellDef=\"let element\">\n <a class=\"action-btn-view\" *ngIf=\"element?.interestCount!== 0\"\n href=\"javascript:void(0)\" [ngStyle]=\"getPointerEventsStyle(element)\">\n <span (click)=\"handleClick(element)\">\n {{element?.interestCount}}\n </span></a>\n <a class=\"\" *ngIf=\"element?.interestCount === 0\"\n href=\"javascript:void(0)\">{{element?.requestType ==\n 'Single' ? 'N/A' : element?.interestCount}}</a>\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"details\">\n <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Details</th>\n <td mat-cell *matCellDef=\"let element\">\n <mat-icon (click)=\"navigateToDetails(element?.demand_id)\"\n class=\"cursor-pointer\">visibility</mat-icon>\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"action\">\n <th mat-header-cell *matHeaderCellDef class=\"row-heading\"></th>\n <td mat-cell *matCellDef=\"let element\">\n\n\n <span>\n <button mat-icon-button [matMenuTriggerFor]=\"menu\"\n aria-label=\"Example icon-button with a menu\">\n <mat-icon>more_vert</mat-icon>\n </button>\n <mat-menu #menu=\"matMenu\">\n <button mat-menu-item (click)=\"onClickMenu(element,'viewContent')\">\n <span>View</span>\n </button>\n <button\n *ngIf=\"element?.status === statusKey.Unassigned && element?.status!== statusKey.Inprogress && element?.status!== statusKey.invalid \"\n mat-menu-item (click)=\"onClickMenu(element,'invalidContent')\">\n <span>Mark as invalid</span>\n </button>\n <button mat-menu-item\n *ngIf=\"element?.status!== statusKey.Assigned && element?.interestCount >0 && element?.status!== statusKey.Inprogress && element?.status!== statusKey.invalid && element?.status!==statusKey.fullfill\"\n (click)=\"onClickMenu(element,'assignContent')\">\n <span>Assign</span>\n </button>\n <button\n *ngIf=\"element?.status === statusKey.Assigned && element?.status!== statusKey.Inprogress && element?.status!== statusKey.invalid && element?.status!==statusKey.fullfill \"\n mat-menu-item (click)=\"onClickMenu(element,'reAssignContent')\">\n <span> Re-Assign</span>\n </button>\n <button mat-menu-item (click)=\"onClickMenu(element,'copyContent')\">\n <span>Copy</span>\n </button>\n </mat-menu>\n </span>\n </td>\n\n\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns\" class=\"table-row-data\"></tr>\n <tr mat-row *matRowDef=\"let row;columns:displayedColumns\"></tr>\n\n\n </table> -->\n <div class=\"table-container mt-4\" style=\"overflow: auto;\">\n <table mat-table [dataSource]=\"dataSource\" class=\"mat-elevation-z1\"\n [ngClass]=\"activeTab === 'matched'? 'table-body': 'table-body-unmatched'\">\n <!-- Selection Column -->\n <!-- <ng-container matColumnDef=\"select\">\n <th mat-header-cell *matHeaderCellDef [hidden]=\"activeTab !== 'matched'\">\n <mat-checkbox class=\"radio-style-checkbox\" (change)=\"toggleAllRows($event)\"\n [checked]=\"isAllSelected()\" [indeterminate]=\"isSomeSelected()\"\n [disabled]=\"!hasSelectableRows()\">\n </mat-checkbox>\n </th>\n\n <td mat-cell *matCellDef=\"let row\" [hidden]=\"activeTab !== 'matched'\">\n <span matTooltip=\"Please generate plan to request for approval\"\n [matTooltipDisabled]=\"row?.cbp_plans?.length > 0\">\n <mat-checkbox class=\"radio-style-checkbox\"\n (click)=\"$event.stopPropagation()\" (change)=\"toggleRow(row)\"\n [checked]=\"selection.isSelected(row)\"\n [disabled]=\"!row?.cbp_plans?.length\">\n </mat-checkbox>\n </span>\n </td>\n </ng-container> -->\n <!-- Designation Name -->\n <ng-container matColumnDef=\"designation_name\">\n <th [ngClass]=\"activeTab === 'matched'? 'table-header': 'table-header-unmatched'\"\n mat-header-cell *matHeaderCellDef> Designation\n </th>\n <td class=\"cursor-pointer\" mat-cell *matCellDef=\"let element\"\n (click)=\"viewCBPPlan(element)\">\n <div\n [ngClass]=\"activeTab === 'matched'? 'designation-text': 'designation-text-unmatched'\">\n <p class=\"designation\">{{ element?.designation_name }} </p>\n <p class=\"wing-text mt-2\">Wing/Division - {{\n element?.wing_division_section }} </p>\n </div>\n\n </td>\n </ng-container>\n\n <!-- Role & Responsibilities -->\n <ng-container matColumnDef=\"role_responsibilities\">\n <th [ngClass]=\"activeTab === 'matched'? 'table-header': 'table-header-unmatched'\"\n mat-header-cell *matHeaderCellDef> Role &\n Responsibilities </th>\n <td mat-cell *matCellDef=\"let element\">\n <ul>\n <li class=\"role-item\"\n *ngFor=\"let role of (isResponisbilityExpanded(element.id) ? element.role_responsibilities : element.role_responsibilities.slice(0, 2)); let i = index\">\n {{i+1}}. {{ role }}</li>\n <li *ngIf=\"element.role_responsibilities.length > 2\"\n class=\"view-more-less cursor-pointer\"\n (click)=\"openFullList(element, 'role_responsibilities')\">\n <span style=\"color: #1B4CA1;font-size: 16px;\">\n <!-- {{ isResponisbilityExpanded(element.id) ? 'View Less' : 'View More' }} -->\n View More\n </span>\n </li>\n </ul>\n </td>\n </ng-container>\n <!-- Activities -->\n <ng-container matColumnDef=\"activities\">\n <th [ngClass]=\"activeTab === 'matched'? 'table-header': 'table-header-unmatched'\"\n mat-header-cell *matHeaderCellDef> Activities </th>\n <td mat-cell *matCellDef=\"let element\">\n <ul>\n <li class=\"role-item\"\n *ngFor=\"let activity of (isActivityExpanded(element.id) ? element.activities : element.activities.slice(0, 2)); let i = index\">\n {{i+1}}. {{ activity }}</li>\n <li *ngIf=\"element.activities.length > 2\"\n class=\"view-more-less cursor-pointer\"\n (click)=\"openFullList(element, 'activity')\">\n <span style=\"color: #1B4CA1;font-size: 16px;\">\n View More\n </span>\n </li>\n </ul>\n </td>\n </ng-container>\n\n <!-- Behavioral Competencies -->\n <ng-container matColumnDef=\"behavioral\">\n <th [ngClass]=\"activeTab === 'matched'? 'table-header': 'table-header-unmatched'\"\n mat-header-cell *matHeaderCellDef> Behavioral\n Competencies </th>\n <td mat-cell *matCellDef=\"let element\">\n <ul class=\"competency-list\">\n <li class=\"behavioural-pill\"\n *ngFor=\"let comp of getCompetenciesByType(element.competencies, 'Behavioral')\">\n <span class=\"competency-text-behavioral\"> {{ comp.theme }} - {{\n comp.sub_theme }} </span>\n </li>\n </ul>\n </td>\n </ng-container>\n\n <!-- Functional Competencies -->\n <ng-container matColumnDef=\"functional\">\n <th [ngClass]=\"activeTab === 'matched'? 'table-header': 'table-header-unmatched'\"\n mat-header-cell *matHeaderCellDef> Functional\n Competencies </th>\n <td mat-cell *matCellDef=\"let element\">\n <ul class=\"competency-list\">\n <li class=\"functional-pill\"\n *ngFor=\"let comp of getCompetenciesByType(element.competencies, 'Functional')\">\n <span class=\"competency-text-functional\"> {{ comp.theme }} - {{\n comp.sub_theme }}</span>\n </li>\n </ul>\n </td>\n </ng-container>\n\n <!-- Domain Competencies -->\n <ng-container matColumnDef=\"domain\">\n <th [ngClass]=\"activeTab === 'matched'? 'table-header': 'table-header-unmatched'\"\n mat-header-cell *matHeaderCellDef> Domain\n Competencies </th>\n <td mat-cell *matCellDef=\"let element\">\n <ul class=\"competency-list\">\n <li class=\"domain-pill\"\n *ngFor=\"let comp of getCompetenciesByType(element.competencies, 'Domain')\">\n <span class=\"competency-text-domain\"> {{ comp.theme }} - {{\n comp.sub_theme }}</span>\n </li>\n </ul>\n </td>\n </ng-container>\n\n <!-- Actions -->\n <ng-container matColumnDef=\"action\">\n <th [ngClass]=\"activeTab === 'matched'? 'table-header': 'table-header-unmatched'\"\n mat-header-cell *matHeaderCellDef> Action </th>\n <td mat-cell *matCellDef=\"let element\">\n <button mat-icon-button [matMenuTriggerFor]=\"actionMenu\">\n <mat-icon>more_vert</mat-icon>\n </button>\n <mat-menu #actionMenu=\"matMenu\">\n <button mat-menu-item (click)=\"editRoleMapping(element)\">\n <mat-icon>edit</mat-icon>\n <span>Edit Role Mapping</span>\n </button>\n <button mat-menu-item (click)=\"viewCBPPlan(element)\">\n <mat-icon>visibility</mat-icon>\n <span>View Role Mapping</span>\n </button>\n <button mat-menu-item (click)=\"generateCourseRecommendation(element)\">\n <mat-icon>school</mat-icon>\n <span>Generate Course Recommendation</span>\n </button>\n <button mat-menu-item (click)=\"viewCourseRecommendation(element)\">\n <mat-icon>preview</mat-icon>\n <span>View Course Recommendation</span>\n </button>\n <button mat-menu-item (click)=\"deleteRoleMapping(element)\">\n <mat-icon>delete</mat-icon>\n <span>Delete Role Mapping</span>\n </button>\n </mat-menu>\n </td>\n </ng-container>\n\n <!-- Header & Rows -->\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\"></tr>\n </table>\n\n <!-- Pagination -->\n <mat-paginator [length]=\"dataSource?.data?.length || 0\" [pageSize]=\"5\"\n [pageSizeOptions]=\"[5, 10, 20]\" showFirstLastButtons>\n </mat-paginator>\n </div>\n\n </ng-container>\n\n <div class=\"no-cbp-data\" *ngIf=\"dataSource?.filteredData?.length === 0\">\n <!-- <div><img src=\"/mdo-assets/images/no-content-data.svg\" alt=\"no-content\"></div> -->\n <div class=\"sub-heading mt-4\">\n <p>No Data Found</p>\n </div>\n <!-- <div class=\" margin-top-m no-content-create\">\n <button mat-button type=\"button\" class=\"search-btns\"\n [routerLink]=\"['/app/home/create-request-form']\">Request Content</button>\n </div> -->\n\n </div>\n\n <!-- <mat-paginator *ngIf=\"dataSource?.filteredData?.length > 0\" [pageSize]=\"pageSize\"\n [length]=\"this.requestCount\" [pageSizeOptions]=\"[10,20,40]\"\n (page)=\"onChangePage($event)\"></mat-paginator> -->\n\n\n </div>\n\n\n\n </div>\n </div>\n </mat-card>\n </div>\n</div>\n\n\n<div class=\"overlay-loader\" *ngIf=\"loading\">\n <mat-spinner diameter=\"50\"></mat-spinner>\n</div>", styles: [".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:18px;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:18px;font-style:normal;font-weight:700;line-height:150%}:host ::ng-deep input.mat-form-field{background-color:#fff!important;border-radius:25px!important;padding-left:12px;padding-right:12px;height:42px;width:100%}:host ::ng-deep mat-select{border-radius:25px!important;background-color:#fff!important}:host ::ng-deep .mat-select-panel{background-color:#fff!important}:host ::ng-deep .mat-select-panel .mat-option{border-radius:0!important}:host ::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:#0006;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:10px}.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 .clear-icon{position:absolute;top:15px;font-size:20px;right:10px;color:#666}.search .clear-icon:hover{color:#333}.search .sinput{border-radius:32px;border:1px solid #d5d0d0;padding:15px 36px;font:400 14px Lato;width:600px}.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 10px;justify-content:center;align-items:center;gap:8px;border-radius:4px;background:#1b4ca129;color:#1b4ca1;font-family:Lato;font-size:17px;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}.outside-layer{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}.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}.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:4px 8px;justify-content:center;align-items:center;gap:6px;border-radius:8px;border:1px solid #F8B861;background:linear-gradient(0deg,#f8b86152 0% 100%),#fff;margin:5px 0}.functional-pill{display:flex;padding:4px 8px;justify-content:center;align-items:center;gap:6px;border-radius:8px;border:1px solid #E24577;background:linear-gradient(0deg,#e245773d 0% 100%),#fff;margin:5px 0}.domain-pill{display:flex;padding:4px 8px;justify-content:center;align-items:center;gap:6px;border-radius:8px;border:1px solid #7B47A4;background:linear-gradient(0deg,#7b47a43d 0% 100%),#fff;margin:5px 0}.competency-list{display:flex;flex-direction:row;gap:0px;flex-wrap:wrap}.competency-text{color:#000;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal}.competency-text-behavioral{color:#654321;font-family:Lato;font-size:14px;font-style:normal;line-height:normal;font-weight:550}.competency-text-functional{color:#b01669;font-family:Lato;font-size:14px;font-style:normal;line-height:normal;font-weight:550}.competency-text-domain{color:#301934;font-family:Lato;font-size:14px;font-style:normal;line-height:normal;font-weight:550}.designation{color:#1b4ca1;font-family:Lato;font-size:17px;font-style:normal;font-weight:700;line-height:normal;text-decoration-line:underline;text-decoration-style:solid;-webkit-text-decoration-skip-ink:none;text-decoration-skip-ink:none;text-decoration-thickness:auto;text-underline-offset:auto;text-underline-position:from-font}.wing-text{color:#000000e0;font-family:Lato;font-size:15px;font-style:normal;font-weight:400;line-height:normal}.role-item{color:#000000e0;font-family:Lato;font-size:16px;font-style:normal;font-weight:400;line-height:1.75}.view-final-cbp-plan{display:flex;justify-content:end;align-items:center;gap:8px}.view-final-cbp-plan-text{padding:4px 16px;border-radius:24px;border:2px solid #F3962F;background:var(--white-kb-white-100, #FFF);box-shadow:0 1px 10px #276de599;color:var(--Primary-KB-Primary-Light, #1B4CA1);font-family:Lato;font-size:16px;font-style:normal;font-weight:700;line-height:normal}.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}.cursor-pointer{cursor:pointer}.ml-10{margin-left:10px}.table-container{border-top-left-radius:16px;border-top-right-radius:16px;overflow:auto;background:#fff;max-height:70vh}:host ::ng-deep .mat-mdc-header-row{position:sticky;top:0;background:#fff;box-shadow:0 2px 4px #0000001a}:host ::ng-deep .mat-mdc-header-cell{background:#fff;font-weight:600;border-bottom:2px solid #e0e0e0}:host ::ng-deep th.mat-mdc-header-cell:not(:last-child){position:relative;border-right:none}:host ::ng-deep th.mat-mdc-header-cell:not(:last-child):after{content:\"\";position:absolute;top:12px;bottom:12px;right:0;width:1px;background-color:#e0e0e0}.table-header{font-size:16px;font-weight:600;background:#fff!important;color:#333}.table-header-unmatched{font-size:16px;font-weight:600;background:#f4dcde!important;color:#b42318}.table-body{background-color:#fff!important}.table-body-unmatched{background-color:#faf6f7!important}.designation-text-unmatched p{color:#b42318!important}.select-map-flex-container{display:flex;flex-direction:row;justify-content:space-between;width:100%}.select-map-flex{display:flex}.search-container-flex{display:flex;flex-direction:row;width:100%;justify-content:space-between;align-items:flex-start}.mt-6{margin-top:1.7rem}.mat-elevation-z1 .mat-mdc-cell{vertical-align:top!important;padding-top:8px;padding-bottom:8px}::ng-deep .radio-style-checkbox .mat-checkbox-frame{border-radius:50%}::ng-deep .radio-style-checkbox .mat-checkbox-background{border-radius:50%}.search-flex{display:flex;flex-direction:row;width:100%}.margin-top-15{margin-top:15px}.btn-active-outline{border-radius:10px;opacity:1;color:#1b4ca1;border:1px solid #1B4CA1!important;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;width:240px;border:none;background-color:transparent;cursor:pointer}.btn-active-outline-disable{border-radius:10px;opacity:.5;color:#1b4ca1;border:1px solid #1B4CA1!important;text-align:center;font-family:Lato;font-size:14px;font-style:normal;font-weight:700;line-height:normal;display:flex;height:32px;width:auto;padding:0 16px;justify-content:center;align-items:center;gap:8px;border:none;width:240px;background-color:transparent;cursor:not-allowed}.role-mapping-tabs{display:flex;gap:16px;align-items:center;font-family:Inter,sans-serif}.role-tab{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:24px;border:1px solid #d0d5dd;background-color:#f9fafb;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease-in-out}.role-tab.active{border-color:#1b4ca1;background-color:#eff6ff;color:#1b4ca1}.dot{width:10px;height:10px;border-radius:50%;background-color:#1b4ca1}.dot.red{background-color:#b42318}.badge{font-size:12px;font-weight:600;padding:2px 8px;border-radius:12px}.badge.blue{background-color:#dbeafe;color:#1b4ca1}.badge.red{background-color:#fee2e2;color:#b42318}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.MatLegacyCard, selector: "mat-card", exportAs: ["matCard"] }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.MatLegacyButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i7.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i8.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "component", type: i9.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i9.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i9.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i9.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i9.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i9.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i9.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i9.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i9.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i9.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "component", type: i10.MatPaginator, selector: "mat-paginator", inputs: ["disabled"], exportAs: ["matPaginator"] }, { kind: "component", type: i11.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i11.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i11.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }] }); }
|
|
702
|
+
}
|
|
703
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: RoleMappingListComponent, decorators: [{
|
|
704
|
+
type: Component,
|
|
705
|
+
args: [{ selector: 'app-role-mapping-list', template: "<div class=\"role-mapping-container\">\n <div class=\"container-fluid\">\n\n <mat-card class=\"mt-0 pt-0\">\n <div class=\"section-header\">\n\n </div>\n <div class=\"edit-section mt-4\">\n <div class=\"select-map-route-container\">\n <div class=\"select-map-flex-container\">\n <div class=\"select-map-flex\">\n <div class=\"selected-mapping-route\">\n <p>{{sharedService?.cbpPlanFinalObj?.ministry?.orgName}} <span\n *ngIf=\"sharedService?.cbpPlanFinalObj?.department_name\">\n / {{sharedService?.cbpPlanFinalObj?.department_name}}</span>\n </p>\n </div>\n <div class=\"edit-plan cursor-pointer\" (click)=\"moveToInitialScreenLayout('edit')\">\n <mat-icon>edit</mat-icon>Edit\n </div>\n <!-- <div class=\"cursor-pointer ml-10\">-->\n <!-- <button class=\"btn-active cursor-pointer\" (click)=\"moveToInitialScreenLayout('add')\">-->\n <!-- <mat-icon>add</mat-icon>-->\n <!-- Create New CBP-->\n <!-- </button>-->\n <!-- </div>-->\n </div>\n <div>\n <div class=\"view-final-cbp-plan\">\n <!-- <div class=\"view-final-cbp-plan-text cursor-pointer\" (click)=\"viewFinalCBPPlan('cbp')\">\n <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span><span>View\n Final CBP</span>\n </div> -->\n\n <div class=\"view-final-cbp-plan-text cursor-pointer\" (click)=\"viewFinalCBPPlan('acbp')\">\n <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span><span>View\n Final CBP</span>\n </div>\n\n </div>\n\n </div>\n\n </div>\n </div>\n </div>\n <div class=\"search-filter-section mt-2\">\n <div class=\"search flex margin-right-m search-flex\">\n <div class=\"mt-2\">\n <div class=\"search-container\">\n <div class=\"rsearch\">\n <mat-icon\n class=\"color-60 search-icon mat-icon notranslate material-icons mat-icon-no-color\">search</mat-icon>\n <input class=\"sinput color-60 w-full\" [(ngModel)]=\"searchText\" label=\"\"\n (input)=\"applyFilter()\" placeholder=\"Search by designation name\" type=\"Standard\">\n <mat-icon *ngIf=\"searchText.trim().length > 0\"\n class=\"color-60 clear-icon mat-icon notranslate material-icons mat-icon-no-color cursor-pointer\"\n (click)=\"clearSearch()\">clear</mat-icon>\n </div>\n <div class=\"pl-2 mt-2\">\n <input [disabled]=\"searchText.trim()?.length === 0\"\n [ngClass]=\"searchText.trim()?.length === 0 ? 'btn-disable':'btn-active'\"\n type=\"button\" value=\"Search\" (click)=\"applyFilter()\" />\n </div>\n </div>\n\n\n </div>\n\n\n </div>\n <div class=\"filter-section flex margin-top-15\">\n <!-- <div>\n <label class=\"label\">Filter by competency type</label>\n <div>\n <mat-form-field appearance=\"fill\"\n style=\"background: white; border-radius: 25px; padding: 0 12px;\">\n <mat-select [(value)]=\"selectedValue\" placeholder=\"Select Ministry\"\n style=\"border-radius: 25px; background: white;\">\n <mat-option [value]=\"'test'\">Test</mat-option>\n <mat-option [value]=\"'another'\">Another</mat-option>\n </mat-select>\n </mat-form-field>\n </div>\n </div> -->\n <div class=\"btn-group\">\n <div class=\"ml-2\">\n <input class=\"btn-active\" type=\"button\" value=\"Add More Designation\"\n (click)=\"addMoreDesignation()\" />\n </div>\n <!-- <div class=\"ml-2\">\n <button\n [ngClass]=\"selection.selected.length ? 'btn-active-outline' : 'btn-active-outline-disable'\"\n (click)=\"sendForApprovalForm()\">\n <mat-icon>send</mat-icon>\n Send For Approval\n <span *ngIf=\"selection.selected.length\">({{selection.selected.length}})</span>\n </button>\n </div> -->\n\n\n </div>\n </div>\n </div>\n <div class=\"role-mapping-tabs mt-3\">\n <button class=\"role-tab\" [class.active]=\"activeTab === 'matched'\" (click)=\"setDataSoure('matched')\">\n <span class=\"dot\"></span>\n Matched role mappings\n <span class=\"badge blue\">{{matchedRoleMapping}}</span>\n </button>\n\n <button class=\"role-tab table-body-unmatched\" [class.active]=\"activeTab === 'unmatched'\"\n (click)=\"setDataSoure('unmatched')\">\n <span class=\"dot red\"></span>\n Unmatched role mapping\n <span class=\"badge red\">{{unMatchedRoleMapping}}</span>\n </button>\n </div>\n <div class=\"nav-container\">\n <div class=\"sidenav-content\">\n <div class=\"table-class\">\n <ng-container *ngIf=\"dataSource?.filteredData?.length > 0\">\n <!-- <table mat-table [dataSource]=\"dataSource\">\n <ng-container matColumnDef=\"RequestId\">\n <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Request ID </th>\n <td mat-cell class=\"title-class\" *matCellDef=\"let element\">{{element?.demand_id}}\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"title\">\n <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Title </th>\n <td mat-cell class=\"title-class\" *matCellDef=\"let element\">{{element?.title}}</td>\n </ng-container>\n\n <ng-container matColumnDef=\"requestor\">\n <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Requestor </th>\n <td mat-cell class=\"title-class\" *matCellDef=\"let element\">{{element?.ownerName}}\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"requestType\">\n <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Request Type </th>\n <td mat-cell class=\"title-class\" *matCellDef=\"let element\">{{element?.requestType}}\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"requestStatus\">\n <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Request Status </th>\n\n <td mat-cell class=\"title-class\" *matCellDef=\"let element\">\n <span [ngClass]=\"getStatusClass(element?.status)\">{{element?.status ===\n statusKey.fullfill ? 'Fulfilled'\n : element?.status}}</span>\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"assignee\">\n <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Assignee </th>\n <td mat-cell class=\"title-class\" *matCellDef=\"let element\">\n {{element?.assignedProvider ?\n element?.assignedProvider : 'Not Assigned' }}</td>\n </ng-container>\n\n <ng-container matColumnDef=\"requestedOn\">\n <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Requested On </th>\n <td mat-cell class=\"title-class\" *matCellDef=\"let element\">{{element?.createdOn |\n date}}</td>\n </ng-container>\n\n <ng-container matColumnDef=\"interests\">\n <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Interests</th>\n <td mat-cell class=\"title-class\" *matCellDef=\"let element\">\n <a class=\"action-btn-view\" *ngIf=\"element?.interestCount!== 0\"\n href=\"javascript:void(0)\" [ngStyle]=\"getPointerEventsStyle(element)\">\n <span (click)=\"handleClick(element)\">\n {{element?.interestCount}}\n </span></a>\n <a class=\"\" *ngIf=\"element?.interestCount === 0\"\n href=\"javascript:void(0)\">{{element?.requestType ==\n 'Single' ? 'N/A' : element?.interestCount}}</a>\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"details\">\n <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Details</th>\n <td mat-cell *matCellDef=\"let element\">\n <mat-icon (click)=\"navigateToDetails(element?.demand_id)\"\n class=\"cursor-pointer\">visibility</mat-icon>\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"action\">\n <th mat-header-cell *matHeaderCellDef class=\"row-heading\"></th>\n <td mat-cell *matCellDef=\"let element\">\n\n\n <span>\n <button mat-icon-button [matMenuTriggerFor]=\"menu\"\n aria-label=\"Example icon-button with a menu\">\n <mat-icon>more_vert</mat-icon>\n </button>\n <mat-menu #menu=\"matMenu\">\n <button mat-menu-item (click)=\"onClickMenu(element,'viewContent')\">\n <span>View</span>\n </button>\n <button\n *ngIf=\"element?.status === statusKey.Unassigned && element?.status!== statusKey.Inprogress && element?.status!== statusKey.invalid \"\n mat-menu-item (click)=\"onClickMenu(element,'invalidContent')\">\n <span>Mark as invalid</span>\n </button>\n <button mat-menu-item\n *ngIf=\"element?.status!== statusKey.Assigned && element?.interestCount >0 && element?.status!== statusKey.Inprogress && element?.status!== statusKey.invalid && element?.status!==statusKey.fullfill\"\n (click)=\"onClickMenu(element,'assignContent')\">\n <span>Assign</span>\n </button>\n <button\n *ngIf=\"element?.status === statusKey.Assigned && element?.status!== statusKey.Inprogress && element?.status!== statusKey.invalid && element?.status!==statusKey.fullfill \"\n mat-menu-item (click)=\"onClickMenu(element,'reAssignContent')\">\n <span> Re-Assign</span>\n </button>\n <button mat-menu-item (click)=\"onClickMenu(element,'copyContent')\">\n <span>Copy</span>\n </button>\n </mat-menu>\n </span>\n </td>\n\n\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns\" class=\"table-row-data\"></tr>\n <tr mat-row *matRowDef=\"let row;columns:displayedColumns\"></tr>\n\n\n </table> -->\n <div class=\"table-container mt-4\" style=\"overflow: auto;\">\n <table mat-table [dataSource]=\"dataSource\" class=\"mat-elevation-z1\"\n [ngClass]=\"activeTab === 'matched'? 'table-body': 'table-body-unmatched'\">\n <!-- Selection Column -->\n <!-- <ng-container matColumnDef=\"select\">\n <th mat-header-cell *matHeaderCellDef [hidden]=\"activeTab !== 'matched'\">\n <mat-checkbox class=\"radio-style-checkbox\" (change)=\"toggleAllRows($event)\"\n [checked]=\"isAllSelected()\" [indeterminate]=\"isSomeSelected()\"\n [disabled]=\"!hasSelectableRows()\">\n </mat-checkbox>\n </th>\n\n <td mat-cell *matCellDef=\"let row\" [hidden]=\"activeTab !== 'matched'\">\n <span matTooltip=\"Please generate plan to request for approval\"\n [matTooltipDisabled]=\"row?.cbp_plans?.length > 0\">\n <mat-checkbox class=\"radio-style-checkbox\"\n (click)=\"$event.stopPropagation()\" (change)=\"toggleRow(row)\"\n [checked]=\"selection.isSelected(row)\"\n [disabled]=\"!row?.cbp_plans?.length\">\n </mat-checkbox>\n </span>\n </td>\n </ng-container> -->\n <!-- Designation Name -->\n <ng-container matColumnDef=\"designation_name\">\n <th [ngClass]=\"activeTab === 'matched'? 'table-header': 'table-header-unmatched'\"\n mat-header-cell *matHeaderCellDef> Designation\n </th>\n <td class=\"cursor-pointer\" mat-cell *matCellDef=\"let element\"\n (click)=\"viewCBPPlan(element)\">\n <div\n [ngClass]=\"activeTab === 'matched'? 'designation-text': 'designation-text-unmatched'\">\n <p class=\"designation\">{{ element?.designation_name }} </p>\n <p class=\"wing-text mt-2\">Wing/Division - {{\n element?.wing_division_section }} </p>\n </div>\n\n </td>\n </ng-container>\n\n <!-- Role & Responsibilities -->\n <ng-container matColumnDef=\"role_responsibilities\">\n <th [ngClass]=\"activeTab === 'matched'? 'table-header': 'table-header-unmatched'\"\n mat-header-cell *matHeaderCellDef> Role &\n Responsibilities </th>\n <td mat-cell *matCellDef=\"let element\">\n <ul>\n <li class=\"role-item\"\n *ngFor=\"let role of (isResponisbilityExpanded(element.id) ? element.role_responsibilities : element.role_responsibilities.slice(0, 2)); let i = index\">\n {{i+1}}. {{ role }}</li>\n <li *ngIf=\"element.role_responsibilities.length > 2\"\n class=\"view-more-less cursor-pointer\"\n (click)=\"openFullList(element, 'role_responsibilities')\">\n <span style=\"color: #1B4CA1;font-size: 16px;\">\n <!-- {{ isResponisbilityExpanded(element.id) ? 'View Less' : 'View More' }} -->\n View More\n </span>\n </li>\n </ul>\n </td>\n </ng-container>\n <!-- Activities -->\n <ng-container matColumnDef=\"activities\">\n <th [ngClass]=\"activeTab === 'matched'? 'table-header': 'table-header-unmatched'\"\n mat-header-cell *matHeaderCellDef> Activities </th>\n <td mat-cell *matCellDef=\"let element\">\n <ul>\n <li class=\"role-item\"\n *ngFor=\"let activity of (isActivityExpanded(element.id) ? element.activities : element.activities.slice(0, 2)); let i = index\">\n {{i+1}}. {{ activity }}</li>\n <li *ngIf=\"element.activities.length > 2\"\n class=\"view-more-less cursor-pointer\"\n (click)=\"openFullList(element, 'activity')\">\n <span style=\"color: #1B4CA1;font-size: 16px;\">\n View More\n </span>\n </li>\n </ul>\n </td>\n </ng-container>\n\n <!-- Behavioral Competencies -->\n <ng-container matColumnDef=\"behavioral\">\n <th [ngClass]=\"activeTab === 'matched'? 'table-header': 'table-header-unmatched'\"\n mat-header-cell *matHeaderCellDef> Behavioral\n Competencies </th>\n <td mat-cell *matCellDef=\"let element\">\n <ul class=\"competency-list\">\n <li class=\"behavioural-pill\"\n *ngFor=\"let comp of getCompetenciesByType(element.competencies, 'Behavioral')\">\n <span class=\"competency-text-behavioral\"> {{ comp.theme }} - {{\n comp.sub_theme }} </span>\n </li>\n </ul>\n </td>\n </ng-container>\n\n <!-- Functional Competencies -->\n <ng-container matColumnDef=\"functional\">\n <th [ngClass]=\"activeTab === 'matched'? 'table-header': 'table-header-unmatched'\"\n mat-header-cell *matHeaderCellDef> Functional\n Competencies </th>\n <td mat-cell *matCellDef=\"let element\">\n <ul class=\"competency-list\">\n <li class=\"functional-pill\"\n *ngFor=\"let comp of getCompetenciesByType(element.competencies, 'Functional')\">\n <span class=\"competency-text-functional\"> {{ comp.theme }} - {{\n comp.sub_theme }}</span>\n </li>\n </ul>\n </td>\n </ng-container>\n\n <!-- Domain Competencies -->\n <ng-container matColumnDef=\"domain\">\n <th [ngClass]=\"activeTab === 'matched'? 'table-header': 'table-header-unmatched'\"\n mat-header-cell *matHeaderCellDef> Domain\n Competencies </th>\n <td mat-cell *matCellDef=\"let element\">\n <ul class=\"competency-list\">\n <li class=\"domain-pill\"\n *ngFor=\"let comp of getCompetenciesByType(element.competencies, 'Domain')\">\n <span class=\"competency-text-domain\"> {{ comp.theme }} - {{\n comp.sub_theme }}</span>\n </li>\n </ul>\n </td>\n </ng-container>\n\n <!-- Actions -->\n <ng-container matColumnDef=\"action\">\n <th [ngClass]=\"activeTab === 'matched'? 'table-header': 'table-header-unmatched'\"\n mat-header-cell *matHeaderCellDef> Action </th>\n <td mat-cell *matCellDef=\"let element\">\n <button mat-icon-button [matMenuTriggerFor]=\"actionMenu\">\n <mat-icon>more_vert</mat-icon>\n </button>\n <mat-menu #actionMenu=\"matMenu\">\n <button mat-menu-item (click)=\"editRoleMapping(element)\">\n <mat-icon>edit</mat-icon>\n <span>Edit Role Mapping</span>\n </button>\n <button mat-menu-item (click)=\"viewCBPPlan(element)\">\n <mat-icon>visibility</mat-icon>\n <span>View Role Mapping</span>\n </button>\n <button mat-menu-item (click)=\"generateCourseRecommendation(element)\">\n <mat-icon>school</mat-icon>\n <span>Generate Course Recommendation</span>\n </button>\n <button mat-menu-item (click)=\"viewCourseRecommendation(element)\">\n <mat-icon>preview</mat-icon>\n <span>View Course Recommendation</span>\n </button>\n <button mat-menu-item (click)=\"deleteRoleMapping(element)\">\n <mat-icon>delete</mat-icon>\n <span>Delete Role Mapping</span>\n </button>\n </mat-menu>\n </td>\n </ng-container>\n\n <!-- Header & Rows -->\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\"></tr>\n </table>\n\n <!-- Pagination -->\n <mat-paginator [length]=\"dataSource?.data?.length || 0\" [pageSize]=\"5\"\n [pageSizeOptions]=\"[5, 10, 20]\" showFirstLastButtons>\n </mat-paginator>\n </div>\n\n </ng-container>\n\n <div class=\"no-cbp-data\" *ngIf=\"dataSource?.filteredData?.length === 0\">\n <!-- <div><img src=\"/mdo-assets/images/no-content-data.svg\" alt=\"no-content\"></div> -->\n <div class=\"sub-heading mt-4\">\n <p>No Data Found</p>\n </div>\n <!-- <div class=\" margin-top-m no-content-create\">\n <button mat-button type=\"button\" class=\"search-btns\"\n [routerLink]=\"['/app/home/create-request-form']\">Request Content</button>\n </div> -->\n\n </div>\n\n <!-- <mat-paginator *ngIf=\"dataSource?.filteredData?.length > 0\" [pageSize]=\"pageSize\"\n [length]=\"this.requestCount\" [pageSizeOptions]=\"[10,20,40]\"\n (page)=\"onChangePage($event)\"></mat-paginator> -->\n\n\n </div>\n\n\n\n </div>\n </div>\n </mat-card>\n </div>\n</div>\n\n\n<div class=\"overlay-loader\" *ngIf=\"loading\">\n <mat-spinner diameter=\"50\"></mat-spinner>\n</div>", styles: [".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:18px;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:18px;font-style:normal;font-weight:700;line-height:150%}:host ::ng-deep input.mat-form-field{background-color:#fff!important;border-radius:25px!important;padding-left:12px;padding-right:12px;height:42px;width:100%}:host ::ng-deep mat-select{border-radius:25px!important;background-color:#fff!important}:host ::ng-deep .mat-select-panel{background-color:#fff!important}:host ::ng-deep .mat-select-panel .mat-option{border-radius:0!important}:host ::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:#0006;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:10px}.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 .clear-icon{position:absolute;top:15px;font-size:20px;right:10px;color:#666}.search .clear-icon:hover{color:#333}.search .sinput{border-radius:32px;border:1px solid #d5d0d0;padding:15px 36px;font:400 14px Lato;width:600px}.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 10px;justify-content:center;align-items:center;gap:8px;border-radius:4px;background:#1b4ca129;color:#1b4ca1;font-family:Lato;font-size:17px;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}.outside-layer{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}.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}.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:4px 8px;justify-content:center;align-items:center;gap:6px;border-radius:8px;border:1px solid #F8B861;background:linear-gradient(0deg,#f8b86152 0% 100%),#fff;margin:5px 0}.functional-pill{display:flex;padding:4px 8px;justify-content:center;align-items:center;gap:6px;border-radius:8px;border:1px solid #E24577;background:linear-gradient(0deg,#e245773d 0% 100%),#fff;margin:5px 0}.domain-pill{display:flex;padding:4px 8px;justify-content:center;align-items:center;gap:6px;border-radius:8px;border:1px solid #7B47A4;background:linear-gradient(0deg,#7b47a43d 0% 100%),#fff;margin:5px 0}.competency-list{display:flex;flex-direction:row;gap:0px;flex-wrap:wrap}.competency-text{color:#000;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal}.competency-text-behavioral{color:#654321;font-family:Lato;font-size:14px;font-style:normal;line-height:normal;font-weight:550}.competency-text-functional{color:#b01669;font-family:Lato;font-size:14px;font-style:normal;line-height:normal;font-weight:550}.competency-text-domain{color:#301934;font-family:Lato;font-size:14px;font-style:normal;line-height:normal;font-weight:550}.designation{color:#1b4ca1;font-family:Lato;font-size:17px;font-style:normal;font-weight:700;line-height:normal;text-decoration-line:underline;text-decoration-style:solid;-webkit-text-decoration-skip-ink:none;text-decoration-skip-ink:none;text-decoration-thickness:auto;text-underline-offset:auto;text-underline-position:from-font}.wing-text{color:#000000e0;font-family:Lato;font-size:15px;font-style:normal;font-weight:400;line-height:normal}.role-item{color:#000000e0;font-family:Lato;font-size:16px;font-style:normal;font-weight:400;line-height:1.75}.view-final-cbp-plan{display:flex;justify-content:end;align-items:center;gap:8px}.view-final-cbp-plan-text{padding:4px 16px;border-radius:24px;border:2px solid #F3962F;background:var(--white-kb-white-100, #FFF);box-shadow:0 1px 10px #276de599;color:var(--Primary-KB-Primary-Light, #1B4CA1);font-family:Lato;font-size:16px;font-style:normal;font-weight:700;line-height:normal}.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}.cursor-pointer{cursor:pointer}.ml-10{margin-left:10px}.table-container{border-top-left-radius:16px;border-top-right-radius:16px;overflow:auto;background:#fff;max-height:70vh}:host ::ng-deep .mat-mdc-header-row{position:sticky;top:0;background:#fff;box-shadow:0 2px 4px #0000001a}:host ::ng-deep .mat-mdc-header-cell{background:#fff;font-weight:600;border-bottom:2px solid #e0e0e0}:host ::ng-deep th.mat-mdc-header-cell:not(:last-child){position:relative;border-right:none}:host ::ng-deep th.mat-mdc-header-cell:not(:last-child):after{content:\"\";position:absolute;top:12px;bottom:12px;right:0;width:1px;background-color:#e0e0e0}.table-header{font-size:16px;font-weight:600;background:#fff!important;color:#333}.table-header-unmatched{font-size:16px;font-weight:600;background:#f4dcde!important;color:#b42318}.table-body{background-color:#fff!important}.table-body-unmatched{background-color:#faf6f7!important}.designation-text-unmatched p{color:#b42318!important}.select-map-flex-container{display:flex;flex-direction:row;justify-content:space-between;width:100%}.select-map-flex{display:flex}.search-container-flex{display:flex;flex-direction:row;width:100%;justify-content:space-between;align-items:flex-start}.mt-6{margin-top:1.7rem}.mat-elevation-z1 .mat-mdc-cell{vertical-align:top!important;padding-top:8px;padding-bottom:8px}::ng-deep .radio-style-checkbox .mat-checkbox-frame{border-radius:50%}::ng-deep .radio-style-checkbox .mat-checkbox-background{border-radius:50%}.search-flex{display:flex;flex-direction:row;width:100%}.margin-top-15{margin-top:15px}.btn-active-outline{border-radius:10px;opacity:1;color:#1b4ca1;border:1px solid #1B4CA1!important;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;width:240px;border:none;background-color:transparent;cursor:pointer}.btn-active-outline-disable{border-radius:10px;opacity:.5;color:#1b4ca1;border:1px solid #1B4CA1!important;text-align:center;font-family:Lato;font-size:14px;font-style:normal;font-weight:700;line-height:normal;display:flex;height:32px;width:auto;padding:0 16px;justify-content:center;align-items:center;gap:8px;border:none;width:240px;background-color:transparent;cursor:not-allowed}.role-mapping-tabs{display:flex;gap:16px;align-items:center;font-family:Inter,sans-serif}.role-tab{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:24px;border:1px solid #d0d5dd;background-color:#f9fafb;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease-in-out}.role-tab.active{border-color:#1b4ca1;background-color:#eff6ff;color:#1b4ca1}.dot{width:10px;height:10px;border-radius:50%;background-color:#1b4ca1}.dot.red{background-color:#b42318}.badge{font-size:12px;font-weight:600;padding:2px 8px;border-radius:12px}.badge.blue{background-color:#dbeafe;color:#1b4ca1}.badge.red{background-color:#fee2e2;color:#b42318}\n"] }]
|
|
706
|
+
}], ctorParameters: function () { return [{ type: i1.SharedService }, { type: i2.MatDialog }]; }, propDecorators: { formData: [{
|
|
707
|
+
type: Input
|
|
708
|
+
}], paginator: [{
|
|
709
|
+
type: ViewChild,
|
|
710
|
+
args: [MatPaginator]
|
|
711
|
+
}], moveToInitialScreen: [{
|
|
712
|
+
type: Output
|
|
713
|
+
}] } });
|
|
714
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"role-mapping-list.component.js","sourceRoot":"","sources":["../../../../../../../library/sunbird-cb/cbp-ai/src/lib/components/role-mapping-list/role-mapping-list.component.ts","../../../../../../../library/sunbird-cb/cbp-ai/src/lib/components/role-mapping-list/role-mapping-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';\nimport { MatTableDataSource } from '@angular/material/table';\nimport { MatPaginator } from '@angular/material/paginator';\nimport { MatDialog } from '@angular/material/dialog';\nimport { ViewCbpPlanComponent } from '../view-cbp-plan/view-cbp-plan.component';\nimport { EditCbpPlanComponent } from '../edit-cbp-plan/edit-cbp-plan.component';\nimport { GenerateCourseRecommendationComponent } from '../generate-course-recommendation/generate-course-recommendation.component';\nimport { DeleteRoleMappingComponent } from '../delete-role-mapping/delete-role-mapping.component';\nimport { ViewCourseRecommendationComponent } from '../view-course-recommendation/view-course-recommendation.component';\nimport { ViewFinalCbpPlanComponent } from '../view-final-cbp-plan/view-final-cbp-plan.component';\nimport { ListPopupComponent } from '../list-popup/list-popup.component';\nimport { AddDesignationComponent } from '../add-designation/add-designation.component';\nimport { SelectionModel } from '@angular/cdk/collections';\nimport { ApprovalRequestFormComponent } from '../approval-request-form/approval-request-form.component';\nimport { SharedService } from '../../modules/shared/services/shared.service';\n@Component({\n  selector: 'app-role-mapping-list',\n  templateUrl: './role-mapping-list.component.html',\n  styleUrls: ['./role-mapping-list.component.scss']\n})\nexport class RoleMappingListComponent {\n  @Input() formData: any = {}\n  searchText = ''\n  selectedValue = ''\n  //'select'\n  displayedColumns: string[] = [\n    'designation_name',\n    'role_responsibilities',\n    'activities',\n    'behavioral',\n    'functional',\n    'domain',\n    'action'\n  ];\n  dataSource = new MatTableDataSource<any>([]);\n  originalDataSource = new MatTableDataSource<any>([]);\n  filteredData = [];\n  originalData: any[] = [];\n  searchResults: any[] = []; // Store search results for pagination\n  @ViewChild(MatPaginator) paginator!: MatPaginator;\n  expandedResponsibilityRows: { [id: string]: boolean } = {};\n  expandedActivityRows: { [id: string]: boolean } = {};\n  activeRowElement: any\n  cbpFinalObj: any = {}\n  loading = false\n  selection = new SelectionModel<any>(true, []); // true = multi-select\n  matchedRoleMapping = 0\n  unMatchedRoleMapping = 0\n  matchedRoleMappingIds = []\n  matchedDesignationNames: string[] = [];\n\n  @Output() moveToInitialScreen = new EventEmitter<any>()\n  activeTab: 'matched' | 'unmatched' = 'matched';\n\n  matchedDesignationSet = new Set<string>();\n  masterData: any[] = [];\n  tabFilteredData: any[] = [];   // after matched/unmatched filter\n  constructor(\n    public sharedService: SharedService,\n    private dialog: MatDialog) {\n\n  }\n\n  ngAfterViewInit() {\n    // this.dataSource.paginator = this.paginator;\n    // this.dataSource.sort = this.sort;\n  }\n\n  ngOnInit() {\n    console.log('haredService?.cbpPlanFinalObj', this.sharedService?.cbpPlanFinalObj)\n    this.sharedService.checkRoleMappingFormValidation.next(true)\n    this.sharedService.updateDesignationHierarchySubject.subscribe((data) => {\n      if (data) {\n        this.loadRoleMappingList()\n      }\n    })\n    this.loadRoleMappingList()\n\n\n  }\n\n  getCompetenciesByType(competencies: any[], type: string): any[] {\n    return competencies?.filter(c => c.type === type) || [];\n  }\n\n  viewDetails(element: any): void {\n    console.log('View clicked:', element);\n\n  }\n\n  deleteItem(element: any): void {\n    console.log('Delete clicked:', element);\n    // Optionally remove from dataSource\n    this.dataSource.data = this.dataSource.data.filter(item => item.id !== element.id);\n  }\n\n  searchData() {\n    this.applyFilter();\n  }\n\n  applyFilter() {\n    // if (this.searchText.trim()) {\n    //   // Search only in designation names\n    //   this.searchResults = this.filterByDesignationName(this.searchText);\n    //   this.dataSource = new MatTableDataSource(this.searchResults);\n    // } else {\n    //   // If search is cleared, restore original data\n    //   this.searchResults = [];\n    //   this.dataSource = new MatTableDataSource(this.originalData);\n    // }\n\n    // // Set up pagination for filtered results\n    // setTimeout(() => {\n    //   if (this.paginator) {\n    //     this.dataSource.paginator = this.paginator;\n    //     this.paginator.firstPage();\n    //   }\n    // }, 100);\n    this.applyAllFilters();\n  }\n\n  clearSearch() {\n    // this.searchText = '';\n    // this.searchResults = [];\n    // this.dataSource = new MatTableDataSource(this.originalData);\n\n    // setTimeout(() => {\n    //   if (this.paginator) {\n    //     this.dataSource.paginator = this.paginator;\n    //     this.paginator.firstPage();\n    //   }\n    // }, 100);\n    this.searchText = '';\n    this.applyAllFilters();\n  }\n\n  refreshRoleMappingData() {\n    console.log('Refreshing role mapping data...');\n    if (this.sharedService.cbpPlanFinalObj && this.sharedService.cbpPlanFinalObj.ministry && this.sharedService.cbpPlanFinalObj.ministry.identifier) {\n      const ministryType = this.sharedService.cbpPlanFinalObj.ministry.sbOrgType;\n      const ministryId = this.sharedService.cbpPlanFinalObj.ministry.identifier;\n\n      this.loading = true;\n\n      if (ministryType === 'ministry') {\n        if (this.sharedService.cbpPlanFinalObj.departments) {\n          const departmentId = this.sharedService.cbpPlanFinalObj.departments;\n          this.sharedService.getRoleMappingByStateCenterAndDepartment(ministryId, departmentId).subscribe({\n            next: (res) => {\n              this.loading = false;\n              console.log('State role mapping data refreshed:', res);\n              this.updateDataSource(res);\n            },\n            error: (error) => {\n              this.loading = false;\n              console.error('Error refreshing state role mapping data:', error);\n            }\n          });\n        } else {\n          this.sharedService.getRoleMappingByStateCenter(ministryId).subscribe({\n            next: (res) => {\n              this.loading = false;\n              console.log('Center role mapping data refreshed:', res);\n              this.updateDataSource(res);\n            },\n            error: (error) => {\n              this.loading = false;\n              console.error('Error refreshing center role mapping data:', error);\n            }\n          });\n        }\n\n      } else if (ministryType === 'state') {\n        const departmentId = this.sharedService.cbpPlanFinalObj.departments;\n        this.sharedService.getRoleMappingByStateCenterAndDepartment(ministryId, departmentId).subscribe({\n          next: (res) => {\n            this.loading = false;\n            console.log('State role mapping data refreshed:', res);\n            this.updateDataSource(res);\n          },\n          error: (error) => {\n            this.loading = false;\n            console.error('Error refreshing state role mapping data:', error);\n          }\n        });\n      }\n    }\n    this.loading = false\n  }\n\n  private updateDataSource(res: any[]) {\n    this.sharedService.cbpPlanFinalObj['role_mapping_generation'] = res;\n    this.dataSource = new MatTableDataSource(res);\n    this.originalData = res;\n    this.searchResults = []; // Clear search results when data is updated\n\n    setTimeout(() => {\n      this.dataSource.paginator = this.paginator;\n    }, 100);\n    console.log('DataSource updated:', this.dataSource);\n  }\n\n  editRoleMapping(element: any) {\n    this.activeRowElement = element\n    console.log('Edit Role Mapping clicked', element);\n    // Navigate or open modal\n    console.log('View CBP Plan clicked', element);\n    const dialogRef = this.dialog.open(EditCbpPlanComponent, {\n      width: '1000px',\n      data: element,\n      panelClass: 'view-cbp-plan-popup',\n      minHeight: '300px',          // Set minimum height\n      maxHeight: '80vh',           // Prevent it from going beyond viewport\n      disableClose: true // Optional: prevent closing with outside click\n    });\n\n    dialogRef.afterClosed().subscribe(result => {\n      // if (result === 'saved') {\n      //   console.log('Changes saved!');\n      //   // Refresh data or show a toast here\n\n      // }\n      this.refreshRoleMappingData();\n    });\n  }\n\n  viewCBPPlan(element: any) {\n    this.activeRowElement = element\n    console.log('View CBP Plan clicked', element);\n    const dialogRef = this.dialog.open(ViewCbpPlanComponent, {\n      width: '1000px',\n      data: element,\n      panelClass: 'view-cbp-plan-popup',\n      minHeight: '300px',          // Set minimum height\n      maxHeight: '80vh',           // Prevent it from going beyond viewport\n      disableClose: true // Optional: prevent closing with outside click\n    });\n\n    dialogRef.afterClosed().subscribe(result => {\n      if (result === 'saved') {\n        console.log('Changes saved!');\n        // Refresh data or show a toast here\n      }\n    });\n  }\n\n  generateCourseRecommendation(element: any) {\n    console.log('Generate Course Recommendation clicked', element);\n    this.activeRowElement = element\n    console.log('Edit Role Mapping clicked', element);\n    // Navigate or open modal\n    console.log('View CBP Plan clicked', element);\n    const dialogRef = this.dialog.open(GenerateCourseRecommendationComponent, {\n      width: '1100px',\n      data: element,\n      panelClass: 'view-cbp-plan-popup',\n      minHeight: '400px',          // Set minimum height\n      maxHeight: '90vh',           // Prevent it from going beyond viewport\n      disableClose: true // Optional: prevent closing with outside click\n    });\n\n    dialogRef.afterClosed().subscribe(result => {\n      if (result === 'saved') {\n        console.log('Changes saved!');\n        // Refresh data or show a toast here\n        console.log(this.sharedService.cbpPlanFinalObj)\n        \n        if (this.sharedService.cbpPlanFinalObj && this.sharedService.cbpPlanFinalObj.ministry && this.sharedService.cbpPlanFinalObj.ministry.identifier) {\n          if (this.sharedService.cbpPlanFinalObj.departments) {\n            this.loading = true\n            this.sharedService.getRoleMappingByStateCenter(this.sharedService.cbpPlanFinalObj.ministry.identifier).subscribe((res) => {\n              console.log('res', res)\n              this.selection.clear();\n              this.loadRoleMappingList()\n              this.loading = false\n            })\n          } else {\n            this.loading = true\n            this.sharedService.getRoleMappingByStateCenterAndDepartment(this.sharedService.cbpPlanFinalObj.ministry.identifier, this.sharedService.cbpPlanFinalObj.departments).subscribe((res) => {\n              console.log('res', res)\n              this.selection.clear();\n             this.loadRoleMappingList()\n              console.log('this.dataSource', this.dataSource)\n              this.loading = false\n            })\n          }\n\n\n        } else if (this.sharedService.cbpPlanFinalObj && this.sharedService.cbpPlanFinalObj.ministry && this.sharedService.cbpPlanFinalObj.ministry.identifier && this.sharedService.cbpPlanFinalObj.departments) {\n          {\n            this.loading = true\n            this.sharedService.getRoleMappingByStateCenterAndDepartment(this.sharedService.cbpPlanFinalObj.ministry.identifier, this.sharedService.cbpPlanFinalObj.departments).subscribe((res) => {\n              console.log('res', res)\n              this.selection.clear();\n             this.loadRoleMappingList()\n              console.log('this.dataSource', this.dataSource)\n              this.loading = false\n            })\n          }\n        }\n\n      }\n    });\n  }\n\n  viewCourseRecommendation(element: any) {\n    console.log('View Course Recommendation clicked', element);\n    this.activeRowElement = element\n    console.log('Edit Role Mapping clicked', element);\n    // Navigate or open modal\n    console.log('View CBP Plan clicked', element);\n    const dialogRef = this.dialog.open(ViewCourseRecommendationComponent, {\n      width: '1000px',\n      data: element,\n      panelClass: 'view-cbp-plan-popup',\n      minHeight: '400px',          // Set minimum height\n      maxHeight: '90vh',           // Prevent it from going beyond viewport\n      disableClose: true // Optional: prevent closing with outside click\n    });\n\n    dialogRef.afterClosed().subscribe(result => {\n      if (result === 'saved') {\n        console.log('Changes saved!');\n        // Refresh data or show a toast here\n        console.log(this.sharedService.cbpPlanFinalObj)\n        if (this.sharedService.cbpPlanFinalObj && this.sharedService.cbpPlanFinalObj.ministry && this.sharedService.cbpPlanFinalObj.ministry.id) {\n          this.sharedService.getRoleMappingByStateCenter(this.sharedService.cbpPlanFinalObj.ministry.id).subscribe((res) => {\n            console.log('res', res)\n            this.dataSource = new MatTableDataSource(res)\n            this.dataSource.paginator = this.paginator;\n            this.originalData = res;\n            console.log('this.dataSource', this.dataSource)\n          })\n        } else {\n\n        }\n\n      }\n    });\n  }\n\n  /**\n   * Filter data by designation name only\n   * Supports single and multiple word searches\n   */\n  filterByDesignationName(searchText: string): any[] {\n    const searchTerms = searchText.trim().toLowerCase().split(/\\s+/);\n\n    return this.originalData.filter(item => {\n      const designationName = (item.designation_name || '').toLowerCase();\n\n      // Check if all search terms are found in the designation name\n      return searchTerms.every(term => designationName.includes(term));\n    });\n  }\n\n  flattenObjectToString(obj: any): string {\n    let result = '';\n\n    for (const key in obj) {\n      const value = obj[key];\n\n      if (typeof value === 'string') {\n        result += ' ' + value;\n      } else if (Array.isArray(value)) {\n        value.forEach(val => {\n          if (typeof val === 'string') {\n            result += ' ' + val;\n          } else if (typeof val === 'object') {\n            result += ' ' + this.flattenObjectToString(val);\n          }\n        });\n      } else if (typeof value === 'object' && value !== null) {\n        result += ' ' + this.flattenObjectToString(value);\n      }\n    }\n\n    return result;\n  }\n\n  getSectors(sector) {\n    if (sector && sector.length) {\n      return Array.isArray(sector) ? sector.join('/ ') : ''\n    }\n\n  }\n\n  toggleResponsibilityExpand(id: string): void {\n    this.expandedResponsibilityRows[id] = !this.expandedResponsibilityRows[id];\n  }\n\n  isResponisbilityExpanded(id: string): boolean {\n\n\n    // const dialogRef = this.dialog.open(ListPopupComponent, {\n    //   width: '1000px',\n    //   data: this.activeRowElement,\n    //    panelClass: 'view-cbp-plan-popup',\n    //   minHeight: '400px',          // Set minimum height\n    //   maxHeight: '90vh',           // Prevent it from going beyond viewport\n    //   disableClose: true // Optional: prevent closing with outside click\n    // });\n\n    // dialogRef.afterClosed().subscribe(result => {\n    //   return false\n    // });\n    return this.expandedResponsibilityRows[id];\n  }\n\n  toggleActivityExpand(id: string): void {\n    this.expandedActivityRows[id] = !this.expandedActivityRows[id];\n  }\n\n  isActivityExpanded(id: string): boolean {\n    return this.expandedActivityRows[id];\n  }\n\n\n\n  addMoreDesignation() {\n    const dialogRef = this.dialog.open(AddDesignationComponent, {\n      width: '600px',\n      data: { state_center_id: '' },\n      panelClass: 'view-cbp-plan-popup',\n      minHeight: '300px',          // Set minimum height\n      maxHeight: '90vh',           // Prevent it from going beyond viewport\n      disableClose: true // Optional: prevent closing with outside click\n    });\n\n    dialogRef.afterClosed().subscribe(result => {\n      if (result === 'saved') {\n        console.log('Changes saved!');\n        // Refresh data or show a toast here\n        this.refreshRoleMappingData();\n      }\n    });\n  }\n\n  deleteRoleMapping(element) {\n    console.log('Generate Course Recommendation clicked', element);\n    this.activeRowElement = element\n    console.log('Edit Role Mapping clicked', element);\n    // Navigate or open modal\n    console.log('View CBP Plan clicked', element);\n    const dialogRef = this.dialog.open(DeleteRoleMappingComponent, {\n      width: '600px',\n      data: element,\n      panelClass: 'view-cbp-plan-popup',\n      minHeight: '300px',          // Set minimum height\n      maxHeight: '90vh',           // Prevent it from going beyond viewport\n      disableClose: true // Optional: prevent closing with outside click\n    });\n\n    dialogRef.afterClosed().subscribe(result => {\n      if (result === 'saved') {\n        console.log('Changes saved!');\n        // Refresh data or show a toast here\n        console.log(this.sharedService.cbpPlanFinalObj)\n        if (this.sharedService.cbpPlanFinalObj && this.sharedService.cbpPlanFinalObj.ministry && this.sharedService.cbpPlanFinalObj.ministry.identifier &&\n          this.sharedService.cbpPlanFinalObj.ministry?.sbOrgType === 'ministry'\n        ) {\n          if (this.sharedService.cbpPlanFinalObj.departments) {\n            this.sharedService.getRoleMappingByStateCenterAndDepartment(this.sharedService.cbpPlanFinalObj.ministry.identifier, this.sharedService.cbpPlanFinalObj.departments).subscribe((res) => {\n              console.log('res', res)\n              this.dataSource = new MatTableDataSource(res)\n              this.dataSource.paginator = this.paginator;\n              this.originalData = res;\n              console.log('this.dataSource', this.dataSource)\n            })\n          } else {\n            this.sharedService.getRoleMappingByStateCenter(this.sharedService.cbpPlanFinalObj.ministry.identifier).subscribe((res) => {\n              console.log('res', res)\n              this.dataSource = new MatTableDataSource(res)\n              this.dataSource.paginator = this.paginator;\n              this.originalData = res;\n              console.log('this.dataSource', this.dataSource)\n            })\n          }\n\n\n        } else {\n          this.sharedService.getRoleMappingByStateCenterAndDepartment(this.sharedService.cbpPlanFinalObj.ministry.identifier, this.sharedService.cbpPlanFinalObj.departments).subscribe((res) => {\n            console.log('res', res)\n            this.dataSource = new MatTableDataSource(res)\n            this.dataSource.paginator = this.paginator;\n            this.originalData = res;\n            console.log('this.dataSource', this.dataSource)\n          })\n        }\n\n      }\n    });\n  }\n\n  viewFinalCBPPlan(context: string) {\n    const dialogRef = this.dialog.open(ViewFinalCbpPlanComponent, {\n      width: '1100px',\n      data: {\n        payload: this.originalData,\n        openedFrom: context   // 👈 BEST PRACTICE\n      },\n      panelClass: 'view-cbp-plan-popup',\n      minHeight: '300px',          // Set minimum height\n      maxHeight: '90vh',           // Prevent it from going beyond viewport\n      disableClose: true // Optional: prevent closing with outside click\n    });\n\n    dialogRef.afterClosed().subscribe(result => {\n      if (result === 'saved') {\n        console.log('Changes saved!');\n        // Refresh data or show a toast here\n\n\n      }\n    });\n  }\n\n  moveToInitialScreenLayout(event) {\n    this.moveToInitialScreen.emit(event)\n  }\n\n  openFullList(element: any, type: 'role_responsibilities' | 'activities') {\n    const listToShow: string[] = element[type] || [];\n    const title = type === 'role_responsibilities' ? 'Role & Responsibilities' : 'Activities';\n\n    const dialogRef = this.dialog.open(ListPopupComponent, {\n      width: '600px',\n      data: { element: element, type: type },\n      disableClose: true,\n      maxHeight: '80vh'\n    });\n\n    dialogRef.afterClosed().subscribe(() => {\n      // No need to do anything special here to reset inline expanded state\n      // Because you're using dialog, not inline expand – view remains in initial (collapsed) state\n    });\n  }\n\n  loadRoleMappingList() {\n    this.cbpFinalObj = this.sharedService.getCBPPlanLocalStorage()\n    this.dataSource = new MatTableDataSource(this.cbpFinalObj?.role_mapping_generation)\n    this.originalDataSource = new MatTableDataSource(this.cbpFinalObj?.role_mapping_generation)\n    this.originalData = this.cbpFinalObj?.role_mapping_generation\n\n    if (this.cbpFinalObj && this.cbpFinalObj?.ministry && (this.cbpFinalObj?.ministry.sbOrgType)) {\n      this.sharedService.cbpPlanFinalObj = this.cbpFinalObj\n      if (this.cbpFinalObj?.ministry.sbOrgType === 'ministry') {\n        this.formData = {}\n        this.formData['value'] = {}\n        this.formData['value']['ministryType'] = this.cbpFinalObj?.ministry.sbOrgType\n        this.formData['value']['ministry'] = this.cbpFinalObj?.ministry?.identifier\n        this.formData['value']['departments'] = this.cbpFinalObj?.departments\n      } else if (this.cbpFinalObj?.ministry.sbOrgType === 'state') {\n        this.formData = {}\n        this.formData['value'] = {}\n        this.formData['value']['ministryType'] = this.cbpFinalObj?.ministry.sbOrgType\n        this.formData['value']['ministry'] = this.cbpFinalObj?.ministry?.identifier\n        this.formData['value']['departments'] = this.cbpFinalObj?.departments\n      }\n    }\n    console.log('this.formData', this.formData)\n    if (this.formData && this.formData.value && this.formData.value.ministryType === 'ministry') {\n\n      let state_center_id = this.formData.value.ministry\n      this.loading = true\n      if (this.formData.value.departments) {\n        let department_id = this.formData.value.departments\n        if (typeof department_id === 'string') {\n          this.sharedService.getRoleMappingByStateCenterAndDepartment(state_center_id, department_id).subscribe({\n            next: (res) => {\n              this.loading = false\n              this.sharedService.cbpPlanFinalObj['role_mapping_generation'] = res\n              localStorage.setItem('cbpPlanFinalObj', JSON.stringify(this.sharedService.cbpPlanFinalObj))\n              let obj = {\n                state_center_id: this.formData.value.ministry\n              }\n              if (this.formData.value.departments) {\n                obj['department_id'] = this.formData.value.departments\n              }\n              this.sharedService.getMatchedRoleMapping(obj).subscribe((matchedRoleMapping) => {\n                console.log('res', res)\n\n                console.log('matchedRoleMapping', matchedRoleMapping)\n                this.matchedRoleMapping = matchedRoleMapping?.matched_count\n                this.matchedDesignationNames =\n                  matchedRoleMapping?.matched_details?.map(\n                    x => x.igot_designation_name?.toLowerCase()\n                  ) || [];\n                const matchedNames =\n                  matchedRoleMapping?.matched_details?.map(x =>\n                    x.igot_designation_name?.trim().toLowerCase()\n                  ) || [];\n                this.matchedDesignationSet = new Set(matchedNames);\n\n                this.matchedRoleMapping = matchedNames.length;\n\n                this.unMatchedRoleMapping = this.masterData.length - this.matchedRoleMapping;\n                this.applyAllFilters();\n              })\n\n              this.dataSource = new MatTableDataSource(res)\n              this.originalDataSource = new MatTableDataSource(res)\n              setTimeout(() => {\n                this.dataSource.paginator = this.paginator;\n              }, 1000)\n              this.originalData = res;\n              this.masterData = res;\n\n              console.log('this.dataSource', this.dataSource)\n            },\n            error: () => {\n              this.loading = false\n            }\n          })\n        } else {\n          this.loading = false\n        }\n\n      } else {\n        this.sharedService.getRoleMappingByStateCenter(state_center_id).subscribe((res) => {\n          this.loading = false\n          console.log('res', res)\n          this.sharedService.cbpPlanFinalObj['role_mapping_generation'] = res\n          localStorage.setItem('cbpPlanFinalObj', JSON.stringify(this.sharedService.cbpPlanFinalObj))\n          let obj = {\n            state_center_id: this.formData.value.ministry\n          }\n          if (this.formData.value.departments) {\n            obj['department_id'] = this.formData.value.departments\n          }\n          this.sharedService.getMatchedRoleMapping(obj).subscribe((matchedRoleMapping) => {\n            console.log('res', res)\n            console.log('matchedRoleMapping', matchedRoleMapping)\n            this.matchedRoleMapping = matchedRoleMapping?.matched_count\n            this.matchedDesignationNames =\n              matchedRoleMapping?.matched_details?.map(\n                x => x.igot_designation_name?.toLowerCase()\n              ) || [];\n            const matchedNames =\n              matchedRoleMapping?.matched_details?.map(x =>\n                x.igot_designation_name?.trim().toLowerCase()\n              ) || [];\n            this.matchedDesignationSet = new Set(matchedNames);\n\n            this.matchedRoleMapping = matchedNames.length;\n\n            this.unMatchedRoleMapping = this.masterData.length - this.matchedRoleMapping;\n            this.applyAllFilters();\n          })\n          this.dataSource = new MatTableDataSource(res)\n          this.originalDataSource = new MatTableDataSource(res)\n          setTimeout(() => {\n            this.dataSource.paginator = this.paginator;\n          }, 1000)\n\n          this.originalData = res;\n          this.masterData = res;\n          console.log('this.dataSource', this.dataSource)\n        })\n      }\n\n    }\n    if (this.formData && this.formData.value && this.formData.value.ministryType === 'state') {\n      this.loading = true\n      console.log('this.formData', this.formData)\n      let state_center_id = this.formData.value.ministry\n      let department_id = this.formData.value.departments\n      this.sharedService.getRoleMappingByStateCenterAndDepartment(state_center_id, department_id).subscribe({\n        next: (res) => {\n          this.loading = false\n          this.sharedService.cbpPlanFinalObj['role_mapping_generation'] = res\n          localStorage.setItem('cbpPlanFinalObj', JSON.stringify(this.sharedService.cbpPlanFinalObj))\n          let obj = {\n            state_center_id: this.formData.value.ministry\n          }\n          if (this.formData.value.departments) {\n            obj['department_id'] = this.formData.value.departments\n          }\n          this.sharedService.getMatchedRoleMapping(obj).subscribe((matchedRoleMapping) => {\n            console.log('res', res)\n            console.log('matchedRoleMapping', matchedRoleMapping)\n            this.matchedRoleMapping = matchedRoleMapping?.matched_count\n            this.matchedDesignationNames =\n              matchedRoleMapping?.matched_details?.map(\n                x => x.igot_designation_name?.toLowerCase()\n              ) || [];\n            const matchedNames =\n              matchedRoleMapping?.matched_details?.map(x =>\n                x.igot_designation_name?.trim().toLowerCase()\n              ) || [];\n            this.matchedDesignationSet = new Set(matchedNames);\n\n            this.matchedRoleMapping = matchedNames.length;\n\n            this.unMatchedRoleMapping = this.masterData.length - this.matchedRoleMapping;\n            this.applyAllFilters();\n          })\n          this.dataSource = new MatTableDataSource(res)\n          this.originalDataSource = new MatTableDataSource(res)\n          setTimeout(() => {\n            this.dataSource.paginator = this.paginator;\n          }, 1000)\n          this.originalData = res;\n          this.masterData = res;\n          console.log('this.dataSource', this.dataSource)\n        },\n        error: () => {\n          this.loading = false\n        }\n      })\n\n\n\n    }\n\n  }\n\n  toggleRow(row: any) {\n    if (!row?.cbp_plans?.length) return;\n\n    this.selection.toggle(row);\n    console.log('Selected rows:', this.selection.selected);\n  }\n\n  isAllSelected() {\n    const numSelected = this.selection.selected.length;\n    const numRows = this.dataSource.data.length;\n    return numSelected === numRows;\n  }\n\n  isSomeSelected() {\n    const numSelected = this.selection.selected.length;\n    const numRows = this.dataSource.data.length;\n    return numSelected > 0 && numSelected < numRows;\n  }\n\n  toggleAllRows(event: any) {\n    if (event.checked) {\n      this.dataSource.data.forEach(row => this.selection.select(row));\n    } else {\n      this.selection.clear();\n    }\n  }\n\n  setDataSoure(tab?: 'matched' | 'unmatched') {\n\n    this.activeTab = tab;\n\n    this.selection.clear();\n\n    this.applyAllFilters();\n\n  }\n\n  applyAllFilters() {\n\n    let data = [...this.masterData];\n\n    if (this.activeTab === 'matched') {\n\n      data = data.filter(item =>\n        this.matchedDesignationSet.has(\n          item.designation_name?.trim().toLowerCase()\n        )\n      );\n\n    }\n\n    if (this.activeTab === 'unmatched') {\n\n      data = data.filter(item =>\n        !this.matchedDesignationSet.has(\n          item.designation_name?.trim().toLowerCase()\n        )\n      );\n\n    }\n\n    if (this.searchText.trim()) {\n\n      const terms = this.searchText.toLowerCase().split(/\\s+/);\n\n      data = data.filter(item => {\n        const name = (item.designation_name || '').toLowerCase();\n        return terms.every(term => name.includes(term));\n      });\n\n    }\n\n    this.dataSource = new MatTableDataSource(data);\n\n    setTimeout(() => {\n      this.dataSource.paginator = this.paginator;\n    });\n\n  }\n\n  sendForApprovalForm() {\n    console.log('this.selection--', this.selection.selected)\n    if (this.selection.selected.length) {\n      const dialogRef = this.dialog.open(ApprovalRequestFormComponent, {\n        width: '600px',\n        data: this.selection.selected,\n        panelClass: 'view-cbp-plan-popup',\n        minHeight: '300px',          // Set minimum height\n        maxHeight: '80vh',           // Prevent it from going beyond viewport\n        disableClose: true // Optional: prevent closing with outside click\n      });\n\n      dialogRef.afterClosed().subscribe(result => {\n        // if (result === 'saved') {\n        //   console.log('Changes saved!');\n        //   // Refresh data or show a toast here\n\n        // }\n        this.refreshRoleMappingData();\n      });\n    }\n\n  }\n\n  hasSelectableRows() {\n    return this.dataSource?.data?.some((row: any) => row?.cbp_plans?.length > 0);\n  }\n\n\n}\n","<div class=\"role-mapping-container\">\n    <div class=\"container-fluid\">\n\n        <mat-card class=\"mt-0 pt-0\">\n            <div class=\"section-header\">\n\n            </div>\n            <div class=\"edit-section mt-4\">\n                <div class=\"select-map-route-container\">\n                    <div class=\"select-map-flex-container\">\n                        <div class=\"select-map-flex\">\n                            <div class=\"selected-mapping-route\">\n                                <p>{{sharedService?.cbpPlanFinalObj?.ministry?.orgName}} <span\n                                        *ngIf=\"sharedService?.cbpPlanFinalObj?.department_name\">\n                                        / {{sharedService?.cbpPlanFinalObj?.department_name}}</span>\n                                </p>\n                            </div>\n                            <div class=\"edit-plan cursor-pointer\" (click)=\"moveToInitialScreenLayout('edit')\">\n                                <mat-icon>edit</mat-icon>Edit\n                            </div>\n                            <!--                            <div class=\"cursor-pointer ml-10\">-->\n                            <!--                                <button class=\"btn-active cursor-pointer\" (click)=\"moveToInitialScreenLayout('add')\">-->\n                            <!--                                    <mat-icon>add</mat-icon>-->\n                            <!--                                    Create New CBP-->\n                            <!--                                </button>-->\n                            <!--                            </div>-->\n                        </div>\n                        <div>\n                            <div class=\"view-final-cbp-plan\">\n                                <!-- <div class=\"view-final-cbp-plan-text cursor-pointer\" (click)=\"viewFinalCBPPlan('cbp')\">\n                                    <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span><span>View\n                                        Final CBP</span>\n                                </div> -->\n\n                                <div class=\"view-final-cbp-plan-text cursor-pointer\" (click)=\"viewFinalCBPPlan('acbp')\">\n                                    <span class=\"ai-loader-icon\"><img src=\"assets/icons/ai-loader.gif\"></span><span>View\n                                        Final CBP</span>\n                                </div>\n\n                            </div>\n\n                        </div>\n\n                    </div>\n                </div>\n            </div>\n            <div class=\"search-filter-section mt-2\">\n                <div class=\"search flex margin-right-m search-flex\">\n                    <div class=\"mt-2\">\n                        <div class=\"search-container\">\n                            <div class=\"rsearch\">\n                                <mat-icon\n                                    class=\"color-60 search-icon mat-icon notranslate material-icons mat-icon-no-color\">search</mat-icon>\n                                <input class=\"sinput color-60 w-full\" [(ngModel)]=\"searchText\" label=\"\"\n                                    (input)=\"applyFilter()\" placeholder=\"Search by designation name\" type=\"Standard\">\n                                <mat-icon *ngIf=\"searchText.trim().length > 0\"\n                                    class=\"color-60 clear-icon mat-icon notranslate material-icons mat-icon-no-color cursor-pointer\"\n                                    (click)=\"clearSearch()\">clear</mat-icon>\n                            </div>\n                            <div class=\"pl-2 mt-2\">\n                                <input [disabled]=\"searchText.trim()?.length === 0\"\n                                    [ngClass]=\"searchText.trim()?.length === 0 ? 'btn-disable':'btn-active'\"\n                                    type=\"button\" value=\"Search\" (click)=\"applyFilter()\" />\n                            </div>\n                        </div>\n\n\n                    </div>\n\n\n                </div>\n                <div class=\"filter-section flex margin-top-15\">\n                    <!-- <div>\n                        <label class=\"label\">Filter by competency type</label>\n                        <div>\n                            <mat-form-field appearance=\"fill\"\n                                style=\"background: white; border-radius: 25px; padding: 0 12px;\">\n                                <mat-select [(value)]=\"selectedValue\" placeholder=\"Select Ministry\"\n                                    style=\"border-radius: 25px; background: white;\">\n                                    <mat-option [value]=\"'test'\">Test</mat-option>\n                                    <mat-option [value]=\"'another'\">Another</mat-option>\n                                </mat-select>\n                            </mat-form-field>\n                        </div>\n                    </div> -->\n                    <div class=\"btn-group\">\n                        <div class=\"ml-2\">\n                            <input class=\"btn-active\" type=\"button\" value=\"Add More Designation\"\n                                (click)=\"addMoreDesignation()\" />\n                        </div>\n                        <!-- <div class=\"ml-2\">\n                            <button\n                                [ngClass]=\"selection.selected.length ? 'btn-active-outline' : 'btn-active-outline-disable'\"\n                                (click)=\"sendForApprovalForm()\">\n                                <mat-icon>send</mat-icon>\n                                Send For Approval\n                                <span *ngIf=\"selection.selected.length\">({{selection.selected.length}})</span>\n                            </button>\n                        </div> -->\n\n\n                    </div>\n                </div>\n            </div>\n            <div class=\"role-mapping-tabs mt-3\">\n                <button class=\"role-tab\" [class.active]=\"activeTab === 'matched'\" (click)=\"setDataSoure('matched')\">\n                    <span class=\"dot\"></span>\n                    Matched role mappings\n                    <span class=\"badge blue\">{{matchedRoleMapping}}</span>\n                </button>\n\n                <button class=\"role-tab table-body-unmatched\" [class.active]=\"activeTab === 'unmatched'\"\n                    (click)=\"setDataSoure('unmatched')\">\n                    <span class=\"dot red\"></span>\n                    Unmatched role mapping\n                    <span class=\"badge red\">{{unMatchedRoleMapping}}</span>\n                </button>\n            </div>\n            <div class=\"nav-container\">\n                <div class=\"sidenav-content\">\n                    <div class=\"table-class\">\n                        <ng-container *ngIf=\"dataSource?.filteredData?.length > 0\">\n                            <!-- <table mat-table [dataSource]=\"dataSource\">\n                                <ng-container matColumnDef=\"RequestId\">\n                                    <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Request ID </th>\n                                    <td mat-cell class=\"title-class\" *matCellDef=\"let element\">{{element?.demand_id}}\n                                    </td>\n                                </ng-container>\n\n                                <ng-container matColumnDef=\"title\">\n                                    <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Title </th>\n                                    <td mat-cell class=\"title-class\" *matCellDef=\"let element\">{{element?.title}}</td>\n                                </ng-container>\n\n                                <ng-container matColumnDef=\"requestor\">\n                                    <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Requestor </th>\n                                    <td mat-cell class=\"title-class\" *matCellDef=\"let element\">{{element?.ownerName}}\n                                    </td>\n                                </ng-container>\n\n                                <ng-container matColumnDef=\"requestType\">\n                                    <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Request Type </th>\n                                    <td mat-cell class=\"title-class\" *matCellDef=\"let element\">{{element?.requestType}}\n                                    </td>\n                                </ng-container>\n\n                                <ng-container matColumnDef=\"requestStatus\">\n                                    <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Request Status </th>\n\n                                    <td mat-cell class=\"title-class\" *matCellDef=\"let element\">\n                                        <span [ngClass]=\"getStatusClass(element?.status)\">{{element?.status ===\n                                            statusKey.fullfill ? 'Fulfilled'\n                                            : element?.status}}</span>\n                                    </td>\n                                </ng-container>\n\n                                <ng-container matColumnDef=\"assignee\">\n                                    <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Assignee </th>\n                                    <td mat-cell class=\"title-class\" *matCellDef=\"let element\">\n                                        {{element?.assignedProvider ?\n                                        element?.assignedProvider : 'Not Assigned' }}</td>\n                                </ng-container>\n\n                                <ng-container matColumnDef=\"requestedOn\">\n                                    <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Requested On </th>\n                                    <td mat-cell class=\"title-class\" *matCellDef=\"let element\">{{element?.createdOn |\n                                        date}}</td>\n                                </ng-container>\n\n                                <ng-container matColumnDef=\"interests\">\n                                    <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Interests</th>\n                                    <td mat-cell class=\"title-class\" *matCellDef=\"let element\">\n                                        <a class=\"action-btn-view\" *ngIf=\"element?.interestCount!== 0\"\n                                            href=\"javascript:void(0)\" [ngStyle]=\"getPointerEventsStyle(element)\">\n                                            <span (click)=\"handleClick(element)\">\n                                                {{element?.interestCount}}\n                                            </span></a>\n                                        <a class=\"\" *ngIf=\"element?.interestCount === 0\"\n                                            href=\"javascript:void(0)\">{{element?.requestType ==\n                                            'Single' ? 'N/A' : element?.interestCount}}</a>\n                                    </td>\n                                </ng-container>\n\n                                <ng-container matColumnDef=\"details\">\n                                    <th mat-header-cell *matHeaderCellDef class=\"row-heading\">Details</th>\n                                    <td mat-cell *matCellDef=\"let element\">\n                                        <mat-icon (click)=\"navigateToDetails(element?.demand_id)\"\n                                            class=\"cursor-pointer\">visibility</mat-icon>\n                                    </td>\n                                </ng-container>\n\n                                <ng-container matColumnDef=\"action\">\n                                    <th mat-header-cell *matHeaderCellDef class=\"row-heading\"></th>\n                                    <td mat-cell *matCellDef=\"let element\">\n\n\n                                        <span>\n                                            <button mat-icon-button [matMenuTriggerFor]=\"menu\"\n                                                aria-label=\"Example icon-button with a menu\">\n                                                <mat-icon>more_vert</mat-icon>\n                                            </button>\n                                            <mat-menu #menu=\"matMenu\">\n                                                <button mat-menu-item (click)=\"onClickMenu(element,'viewContent')\">\n                                                    <span>View</span>\n                                                </button>\n                                                <button\n                                                    *ngIf=\"element?.status === statusKey.Unassigned && element?.status!== statusKey.Inprogress &&  element?.status!== statusKey.invalid \"\n                                                    mat-menu-item (click)=\"onClickMenu(element,'invalidContent')\">\n                                                    <span>Mark as invalid</span>\n                                                </button>\n                                                <button mat-menu-item\n                                                    *ngIf=\"element?.status!== statusKey.Assigned && element?.interestCount >0 && element?.status!== statusKey.Inprogress &&  element?.status!== statusKey.invalid && element?.status!==statusKey.fullfill\"\n                                                    (click)=\"onClickMenu(element,'assignContent')\">\n                                                    <span>Assign</span>\n                                                </button>\n                                                <button\n                                                    *ngIf=\"element?.status === statusKey.Assigned && element?.status!== statusKey.Inprogress &&  element?.status!== statusKey.invalid && element?.status!==statusKey.fullfill \"\n                                                    mat-menu-item (click)=\"onClickMenu(element,'reAssignContent')\">\n                                                    <span> Re-Assign</span>\n                                                </button>\n                                                <button mat-menu-item (click)=\"onClickMenu(element,'copyContent')\">\n                                                    <span>Copy</span>\n                                                </button>\n                                            </mat-menu>\n                                        </span>\n                                    </td>\n\n\n                                </ng-container>\n\n                                <tr mat-header-row *matHeaderRowDef=\"displayedColumns\" class=\"table-row-data\"></tr>\n                                <tr mat-row *matRowDef=\"let row;columns:displayedColumns\"></tr>\n\n\n                            </table> -->\n                            <div class=\"table-container mt-4\" style=\"overflow: auto;\">\n                                <table mat-table [dataSource]=\"dataSource\" class=\"mat-elevation-z1\"\n                                    [ngClass]=\"activeTab === 'matched'? 'table-body': 'table-body-unmatched'\">\n                                    <!-- Selection Column -->\n                                    <!-- <ng-container matColumnDef=\"select\">\n                                        <th mat-header-cell *matHeaderCellDef [hidden]=\"activeTab !== 'matched'\">\n                                            <mat-checkbox class=\"radio-style-checkbox\" (change)=\"toggleAllRows($event)\"\n                                                [checked]=\"isAllSelected()\" [indeterminate]=\"isSomeSelected()\"\n                                                [disabled]=\"!hasSelectableRows()\">\n                                            </mat-checkbox>\n                                        </th>\n\n                                        <td mat-cell *matCellDef=\"let row\" [hidden]=\"activeTab !== 'matched'\">\n                                            <span matTooltip=\"Please generate plan to request for approval\"\n                                                [matTooltipDisabled]=\"row?.cbp_plans?.length > 0\">\n                                                <mat-checkbox class=\"radio-style-checkbox\"\n                                                    (click)=\"$event.stopPropagation()\" (change)=\"toggleRow(row)\"\n                                                    [checked]=\"selection.isSelected(row)\"\n                                                    [disabled]=\"!row?.cbp_plans?.length\">\n                                                </mat-checkbox>\n                                            </span>\n                                        </td>\n                                    </ng-container> -->\n                                    <!-- Designation Name -->\n                                    <ng-container matColumnDef=\"designation_name\">\n                                        <th [ngClass]=\"activeTab === 'matched'? 'table-header': 'table-header-unmatched'\"\n                                            mat-header-cell *matHeaderCellDef> Designation\n                                        </th>\n                                        <td class=\"cursor-pointer\" mat-cell *matCellDef=\"let element\"\n                                            (click)=\"viewCBPPlan(element)\">\n                                            <div\n                                                [ngClass]=\"activeTab === 'matched'? 'designation-text': 'designation-text-unmatched'\">\n                                                <p class=\"designation\">{{ element?.designation_name }} </p>\n                                                <p class=\"wing-text mt-2\">Wing/Division - {{\n                                                    element?.wing_division_section }} </p>\n                                            </div>\n\n                                        </td>\n                                    </ng-container>\n\n                                    <!-- Role & Responsibilities -->\n                                    <ng-container matColumnDef=\"role_responsibilities\">\n                                        <th [ngClass]=\"activeTab === 'matched'? 'table-header': 'table-header-unmatched'\"\n                                            mat-header-cell *matHeaderCellDef> Role &\n                                            Responsibilities </th>\n                                        <td mat-cell *matCellDef=\"let element\">\n                                            <ul>\n                                                <li class=\"role-item\"\n                                                    *ngFor=\"let role of (isResponisbilityExpanded(element.id) ? element.role_responsibilities : element.role_responsibilities.slice(0, 2)); let i = index\">\n                                                    {{i+1}}. {{ role }}</li>\n                                                <li *ngIf=\"element.role_responsibilities.length > 2\"\n                                                    class=\"view-more-less cursor-pointer\"\n                                                    (click)=\"openFullList(element, 'role_responsibilities')\">\n                                                    <span style=\"color: #1B4CA1;font-size: 16px;\">\n                                                        <!-- {{ isResponisbilityExpanded(element.id) ? 'View Less' : 'View More' }} -->\n                                                        View More\n                                                    </span>\n                                                </li>\n                                            </ul>\n                                        </td>\n                                    </ng-container>\n                                    <!-- Activities -->\n                                    <ng-container matColumnDef=\"activities\">\n                                        <th [ngClass]=\"activeTab === 'matched'? 'table-header': 'table-header-unmatched'\"\n                                            mat-header-cell *matHeaderCellDef> Activities </th>\n                                        <td mat-cell *matCellDef=\"let element\">\n                                            <ul>\n                                                <li class=\"role-item\"\n                                                    *ngFor=\"let activity of (isActivityExpanded(element.id) ? element.activities : element.activities.slice(0, 2)); let i = index\">\n                                                    {{i+1}}. {{ activity }}</li>\n                                                <li *ngIf=\"element.activities.length > 2\"\n                                                    class=\"view-more-less cursor-pointer\"\n                                                    (click)=\"openFullList(element, 'activity')\">\n                                                    <span style=\"color: #1B4CA1;font-size: 16px;\">\n                                                        View More\n                                                    </span>\n                                                </li>\n                                            </ul>\n                                        </td>\n                                    </ng-container>\n\n                                    <!-- Behavioral Competencies -->\n                                    <ng-container matColumnDef=\"behavioral\">\n                                        <th [ngClass]=\"activeTab === 'matched'? 'table-header': 'table-header-unmatched'\"\n                                            mat-header-cell *matHeaderCellDef> Behavioral\n                                            Competencies </th>\n                                        <td mat-cell *matCellDef=\"let element\">\n                                            <ul class=\"competency-list\">\n                                                <li class=\"behavioural-pill\"\n                                                    *ngFor=\"let comp of getCompetenciesByType(element.competencies, 'Behavioral')\">\n                                                    <span class=\"competency-text-behavioral\"> {{ comp.theme }} - {{\n                                                        comp.sub_theme }} </span>\n                                                </li>\n                                            </ul>\n                                        </td>\n                                    </ng-container>\n\n                                    <!-- Functional Competencies -->\n                                    <ng-container matColumnDef=\"functional\">\n                                        <th [ngClass]=\"activeTab === 'matched'? 'table-header': 'table-header-unmatched'\"\n                                            mat-header-cell *matHeaderCellDef> Functional\n                                            Competencies </th>\n                                        <td mat-cell *matCellDef=\"let element\">\n                                            <ul class=\"competency-list\">\n                                                <li class=\"functional-pill\"\n                                                    *ngFor=\"let comp of getCompetenciesByType(element.competencies, 'Functional')\">\n                                                    <span class=\"competency-text-functional\"> {{ comp.theme }} - {{\n                                                        comp.sub_theme }}</span>\n                                                </li>\n                                            </ul>\n                                        </td>\n                                    </ng-container>\n\n                                    <!-- Domain Competencies -->\n                                    <ng-container matColumnDef=\"domain\">\n                                        <th [ngClass]=\"activeTab === 'matched'? 'table-header': 'table-header-unmatched'\"\n                                            mat-header-cell *matHeaderCellDef> Domain\n                                            Competencies </th>\n                                        <td mat-cell *matCellDef=\"let element\">\n                                            <ul class=\"competency-list\">\n                                                <li class=\"domain-pill\"\n                                                    *ngFor=\"let comp of getCompetenciesByType(element.competencies, 'Domain')\">\n                                                    <span class=\"competency-text-domain\"> {{ comp.theme }} - {{\n                                                        comp.sub_theme }}</span>\n                                                </li>\n                                            </ul>\n                                        </td>\n                                    </ng-container>\n\n                                    <!-- Actions -->\n                                    <ng-container matColumnDef=\"action\">\n                                        <th [ngClass]=\"activeTab === 'matched'? 'table-header': 'table-header-unmatched'\"\n                                            mat-header-cell *matHeaderCellDef> Action </th>\n                                        <td mat-cell *matCellDef=\"let element\">\n                                            <button mat-icon-button [matMenuTriggerFor]=\"actionMenu\">\n                                                <mat-icon>more_vert</mat-icon>\n                                            </button>\n                                            <mat-menu #actionMenu=\"matMenu\">\n                                                <button mat-menu-item (click)=\"editRoleMapping(element)\">\n                                                    <mat-icon>edit</mat-icon>\n                                                    <span>Edit Role Mapping</span>\n                                                </button>\n                                                <button mat-menu-item (click)=\"viewCBPPlan(element)\">\n                                                    <mat-icon>visibility</mat-icon>\n                                                    <span>View Role Mapping</span>\n                                                </button>\n                                                <button mat-menu-item (click)=\"generateCourseRecommendation(element)\">\n                                                    <mat-icon>school</mat-icon>\n                                                    <span>Generate Course Recommendation</span>\n                                                </button>\n                                                <button mat-menu-item (click)=\"viewCourseRecommendation(element)\">\n                                                    <mat-icon>preview</mat-icon>\n                                                    <span>View Course Recommendation</span>\n                                                </button>\n                                                <button mat-menu-item (click)=\"deleteRoleMapping(element)\">\n                                                    <mat-icon>delete</mat-icon>\n                                                    <span>Delete Role Mapping</span>\n                                                </button>\n                                            </mat-menu>\n                                        </td>\n                                    </ng-container>\n\n                                    <!-- Header & Rows -->\n                                    <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n                                    <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\"></tr>\n                                </table>\n\n                                <!-- Pagination -->\n                                <mat-paginator [length]=\"dataSource?.data?.length || 0\" [pageSize]=\"5\"\n                                    [pageSizeOptions]=\"[5, 10, 20]\" showFirstLastButtons>\n                                </mat-paginator>\n                            </div>\n\n                        </ng-container>\n\n                        <div class=\"no-cbp-data\" *ngIf=\"dataSource?.filteredData?.length === 0\">\n                            <!-- <div><img src=\"/mdo-assets/images/no-content-data.svg\" alt=\"no-content\"></div> -->\n                            <div class=\"sub-heading mt-4\">\n                                <p>No Data Found</p>\n                            </div>\n                            <!-- <div class=\" margin-top-m no-content-create\">\n                                <button mat-button type=\"button\" class=\"search-btns\"\n                                    [routerLink]=\"['/app/home/create-request-form']\">Request Content</button>\n                            </div> -->\n\n                        </div>\n\n                        <!-- <mat-paginator *ngIf=\"dataSource?.filteredData?.length > 0\" [pageSize]=\"pageSize\"\n                            [length]=\"this.requestCount\" [pageSizeOptions]=\"[10,20,40]\"\n                            (page)=\"onChangePage($event)\"></mat-paginator> -->\n\n\n                    </div>\n\n\n\n                </div>\n            </div>\n        </mat-card>\n    </div>\n</div>\n\n\n<div class=\"overlay-loader\" *ngIf=\"loading\">\n    <mat-spinner diameter=\"50\"></mat-spinner>\n</div>"]}
|