@sunbird-cb/cbp-ai 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (128) hide show
  1. package/README.md +24 -0
  2. package/esm2022/lib/ai-cbp-routing.module.mjs +56 -0
  3. package/esm2022/lib/ai-cbp.component.mjs +14 -0
  4. package/esm2022/lib/ai-cbp.module.mjs +263 -0
  5. package/esm2022/lib/ai-cbp.service.mjs +14 -0
  6. package/esm2022/lib/components/add-course/add-course.component.mjs +444 -0
  7. package/esm2022/lib/components/add-designation/add-designation.component.mjs +460 -0
  8. package/esm2022/lib/components/add-personalisation/add-personalisation.component.mjs +33 -0
  9. package/esm2022/lib/components/approval-request-form/approval-request-form.component.mjs +392 -0
  10. package/esm2022/lib/components/approval-requests/approval-requests.component.mjs +398 -0
  11. package/esm2022/lib/components/dashboard/dashboard.component.mjs +265 -0
  12. package/esm2022/lib/components/delete-role-mapping/delete-role-mapping.component.mjs +53 -0
  13. package/esm2022/lib/components/delete-role-mapping-popup/delete-role-mapping-popup.component.mjs +39 -0
  14. package/esm2022/lib/components/edit-cbp-plan/edit-cbp-plan.component.mjs +699 -0
  15. package/esm2022/lib/components/gap-analysis-recommended-course/gap-analysis-recommended-course.component.mjs +188 -0
  16. package/esm2022/lib/components/generate-course-recommendation/generate-course-recommendation.component.mjs +1949 -0
  17. package/esm2022/lib/components/list-popup/list-popup.component.mjs +32 -0
  18. package/esm2022/lib/components/review-request/review-request.component.mjs +138 -0
  19. package/esm2022/lib/components/role-mapping-generation/role-mapping-generation.component.mjs +1082 -0
  20. package/esm2022/lib/components/role-mapping-list/role-mapping-list.component.mjs +714 -0
  21. package/esm2022/lib/components/suggest-more-courses/suggest-more-courses.component.mjs +370 -0
  22. package/esm2022/lib/components/update-designation-hierarchy/update-designation-hierarchy.component.mjs +235 -0
  23. package/esm2022/lib/components/view-cbp-plan/view-cbp-plan.component.mjs +125 -0
  24. package/esm2022/lib/components/view-course-recommendation/view-course-recommendation.component.mjs +397 -0
  25. package/esm2022/lib/components/view-final-cbp-plan/view-final-cbp-plan.component.mjs +883 -0
  26. package/esm2022/lib/modules/initial-screen/initial-screen.component.mjs +127 -0
  27. package/esm2022/lib/modules/shared/constant/app.constant.mjs +2036 -0
  28. package/esm2022/lib/modules/shared/directives/clickoutside.directive.mjs +38 -0
  29. package/esm2022/lib/modules/shared/directives/directive.module.mjs +21 -0
  30. package/esm2022/lib/modules/shared/pipes/order-by-name.pipe.mjs +23 -0
  31. package/esm2022/lib/modules/shared/services/event.service.mjs +24 -0
  32. package/esm2022/lib/modules/shared/services/events.mjs +125 -0
  33. package/esm2022/lib/modules/shared/services/init.service.mjs +41 -0
  34. package/esm2022/lib/modules/shared/services/role-mapping.service.mjs +261 -0
  35. package/esm2022/lib/modules/shared/services/shared.service.mjs +869 -0
  36. package/esm2022/lib/modules/upload-document-page/progress-dialog/progress-dialog.component.mjs +53 -0
  37. package/esm2022/lib/modules/upload-document-page/upload-dialog/upload-dialog.component.mjs +186 -0
  38. package/esm2022/lib/modules/upload-document-page/upload-document-page.component.mjs +367 -0
  39. package/esm2022/lib/pipe-public-URL/pipe-public-URL.module.mjs +20 -0
  40. package/esm2022/lib/pipe-public-URL/pipe-public-URL.pipe.mjs +23 -0
  41. package/esm2022/public-api.mjs +14 -0
  42. package/esm2022/sunbird-cb-cbp-ai.mjs +5 -0
  43. package/fesm2022/sunbird-cb-cbp-ai.mjs +12952 -0
  44. package/fesm2022/sunbird-cb-cbp-ai.mjs.map +1 -0
  45. package/index.d.ts +6 -0
  46. package/lib/ai-cbp-routing.module.d.ts +8 -0
  47. package/lib/ai-cbp-routing.module.d.ts.map +1 -0
  48. package/lib/ai-cbp.component.d.ts +7 -0
  49. package/lib/ai-cbp.component.d.ts.map +1 -0
  50. package/lib/ai-cbp.module.d.ts +68 -0
  51. package/lib/ai-cbp.module.d.ts.map +1 -0
  52. package/lib/ai-cbp.service.d.ts +7 -0
  53. package/lib/ai-cbp.service.d.ts.map +1 -0
  54. package/lib/components/add-course/add-course.component.d.ts +67 -0
  55. package/lib/components/add-course/add-course.component.d.ts.map +1 -0
  56. package/lib/components/add-designation/add-designation.component.d.ts +52 -0
  57. package/lib/components/add-designation/add-designation.component.d.ts.map +1 -0
  58. package/lib/components/add-personalisation/add-personalisation.component.d.ts +16 -0
  59. package/lib/components/add-personalisation/add-personalisation.component.d.ts.map +1 -0
  60. package/lib/components/approval-request-form/approval-request-form.component.d.ts +48 -0
  61. package/lib/components/approval-request-form/approval-request-form.component.d.ts.map +1 -0
  62. package/lib/components/approval-requests/approval-requests.component.d.ts +80 -0
  63. package/lib/components/approval-requests/approval-requests.component.d.ts.map +1 -0
  64. package/lib/components/dashboard/dashboard.component.d.ts +55 -0
  65. package/lib/components/dashboard/dashboard.component.d.ts.map +1 -0
  66. package/lib/components/delete-role-mapping/delete-role-mapping.component.d.ts +18 -0
  67. package/lib/components/delete-role-mapping/delete-role-mapping.component.d.ts.map +1 -0
  68. package/lib/components/delete-role-mapping-popup/delete-role-mapping-popup.component.d.ts +18 -0
  69. package/lib/components/delete-role-mapping-popup/delete-role-mapping-popup.component.d.ts.map +1 -0
  70. package/lib/components/edit-cbp-plan/edit-cbp-plan.component.d.ts +94 -0
  71. package/lib/components/edit-cbp-plan/edit-cbp-plan.component.d.ts.map +1 -0
  72. package/lib/components/gap-analysis-recommended-course/gap-analysis-recommended-course.component.d.ts +35 -0
  73. package/lib/components/gap-analysis-recommended-course/gap-analysis-recommended-course.component.d.ts.map +1 -0
  74. package/lib/components/generate-course-recommendation/generate-course-recommendation.component.d.ts +198 -0
  75. package/lib/components/generate-course-recommendation/generate-course-recommendation.component.d.ts.map +1 -0
  76. package/lib/components/list-popup/list-popup.component.d.ts +13 -0
  77. package/lib/components/list-popup/list-popup.component.d.ts.map +1 -0
  78. package/lib/components/review-request/review-request.component.d.ts +39 -0
  79. package/lib/components/review-request/review-request.component.d.ts.map +1 -0
  80. package/lib/components/role-mapping-generation/role-mapping-generation.component.d.ts +99 -0
  81. package/lib/components/role-mapping-generation/role-mapping-generation.component.d.ts.map +1 -0
  82. package/lib/components/role-mapping-list/role-mapping-list.component.d.ts +83 -0
  83. package/lib/components/role-mapping-list/role-mapping-list.component.d.ts.map +1 -0
  84. package/lib/components/suggest-more-courses/suggest-more-courses.component.d.ts +48 -0
  85. package/lib/components/suggest-more-courses/suggest-more-courses.component.d.ts.map +1 -0
  86. package/lib/components/update-designation-hierarchy/update-designation-hierarchy.component.d.ts +41 -0
  87. package/lib/components/update-designation-hierarchy/update-designation-hierarchy.component.d.ts.map +1 -0
  88. package/lib/components/view-cbp-plan/view-cbp-plan.component.d.ts +29 -0
  89. package/lib/components/view-cbp-plan/view-cbp-plan.component.d.ts.map +1 -0
  90. package/lib/components/view-course-recommendation/view-course-recommendation.component.d.ts +49 -0
  91. package/lib/components/view-course-recommendation/view-course-recommendation.component.d.ts.map +1 -0
  92. package/lib/components/view-final-cbp-plan/view-final-cbp-plan.component.d.ts +73 -0
  93. package/lib/components/view-final-cbp-plan/view-final-cbp-plan.component.d.ts.map +1 -0
  94. package/lib/modules/initial-screen/initial-screen.component.d.ts +85 -0
  95. package/lib/modules/initial-screen/initial-screen.component.d.ts.map +1 -0
  96. package/lib/modules/shared/constant/app.constant.d.ts +457 -0
  97. package/lib/modules/shared/constant/app.constant.d.ts.map +1 -0
  98. package/lib/modules/shared/directives/clickoutside.directive.d.ts +13 -0
  99. package/lib/modules/shared/directives/clickoutside.directive.d.ts.map +1 -0
  100. package/lib/modules/shared/directives/directive.module.d.ts +8 -0
  101. package/lib/modules/shared/directives/directive.module.d.ts.map +1 -0
  102. package/lib/modules/shared/pipes/order-by-name.pipe.d.ts +8 -0
  103. package/lib/modules/shared/pipes/order-by-name.pipe.d.ts.map +1 -0
  104. package/lib/modules/shared/services/event.service.d.ts +12 -0
  105. package/lib/modules/shared/services/event.service.d.ts.map +1 -0
  106. package/lib/modules/shared/services/events.d.ts +200 -0
  107. package/lib/modules/shared/services/events.d.ts.map +1 -0
  108. package/lib/modules/shared/services/init.service.d.ts +13 -0
  109. package/lib/modules/shared/services/init.service.d.ts.map +1 -0
  110. package/lib/modules/shared/services/role-mapping.service.d.ts +21 -0
  111. package/lib/modules/shared/services/role-mapping.service.d.ts.map +1 -0
  112. package/lib/modules/shared/services/shared.service.d.ts +108 -0
  113. package/lib/modules/shared/services/shared.service.d.ts.map +1 -0
  114. package/lib/modules/upload-document-page/progress-dialog/progress-dialog.component.d.ts +14 -0
  115. package/lib/modules/upload-document-page/progress-dialog/progress-dialog.component.d.ts.map +1 -0
  116. package/lib/modules/upload-document-page/upload-dialog/upload-dialog.component.d.ts +29 -0
  117. package/lib/modules/upload-document-page/upload-dialog/upload-dialog.component.d.ts.map +1 -0
  118. package/lib/modules/upload-document-page/upload-document-page.component.d.ts +64 -0
  119. package/lib/modules/upload-document-page/upload-document-page.component.d.ts.map +1 -0
  120. package/lib/pipe-public-URL/pipe-public-URL.module.d.ts +9 -0
  121. package/lib/pipe-public-URL/pipe-public-URL.module.d.ts.map +1 -0
  122. package/lib/pipe-public-URL/pipe-public-URL.pipe.d.ts +11 -0
  123. package/lib/pipe-public-URL/pipe-public-URL.pipe.d.ts.map +1 -0
  124. package/package.json +28 -0
  125. package/public-api.d.ts +11 -0
  126. package/public-api.d.ts.map +1 -0
  127. package/sunbird-cb-cbp-ai-0.0.1.tgz +0 -0
  128. package/sunbird-cb-cbp-ai.d.ts.map +1 -0
@@ -0,0 +1,699 @@
1
+ import { MAT_DIALOG_DATA } from '@angular/material/dialog';
2
+ import { Component, ElementRef, Inject, ViewChild } from '@angular/core';
3
+ import { FormGroup, FormArray, Validators, FormControl } from '@angular/forms';
4
+ import { finalize } from 'rxjs/operators';
5
+ import _ from 'lodash';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@angular/material/dialog";
8
+ import * as i2 from "@angular/forms";
9
+ import * as i3 from "../../modules/shared/services/shared.service";
10
+ import * as i4 from "@angular/material/snack-bar";
11
+ import * as i5 from "@angular/common/http";
12
+ import * as i6 from "@angular/common";
13
+ import * as i7 from "@angular/material/legacy-form-field";
14
+ import * as i8 from "@angular/material/legacy-input";
15
+ import * as i9 from "@angular/material/icon";
16
+ import * as i10 from "@angular/material/legacy-select";
17
+ import * as i11 from "@angular/material/legacy-core";
18
+ import * as i12 from "@angular/material/progress-spinner";
19
+ export class EditCbpPlanComponent {
20
+ constructor(dialogRef, data, fb, cdRef, sharedService, snackBar, http) {
21
+ this.dialogRef = dialogRef;
22
+ this.data = data;
23
+ this.fb = fb;
24
+ this.cdRef = cdRef;
25
+ this.sharedService = sharedService;
26
+ this.snackBar = snackBar;
27
+ this.http = http;
28
+ this.selectedValue = '';
29
+ this.searchText = '';
30
+ this.competenciesCount = { total: 0, behavioral: 0, functional: 0, domain: 0 };
31
+ this.loading = false;
32
+ // Enhanced competency selection properties
33
+ this.competenciesData = [];
34
+ this.availableThemes = [];
35
+ this.availableSubThemes = [];
36
+ this.filteredThemes = [];
37
+ this.filteredSubThemes = [];
38
+ this.selectedCompetencyType = '';
39
+ this.selectedTheme = '';
40
+ this.selectedSubTheme = '';
41
+ this.manualTheme = '';
42
+ this.manualSubTheme = '';
43
+ this.themeSearchText = '';
44
+ this.subThemeSearchText = '';
45
+ this.editDomainCompetencyFlag = false;
46
+ this.editCompetencyIndex = -1;
47
+ this.originalCompetencyValueArr = [];
48
+ this.desigantionFilterEnable = false;
49
+ this.isLoadingMoreDesignations = false;
50
+ this.designationOffset = 0;
51
+ this.odcsDesignationCount = 0;
52
+ this.defaultSearchDesignationCount = 0;
53
+ this.designationListLoadCount = 50;
54
+ this.designationDefaultLoadCount = 50;
55
+ this.noMoreLegacyDesignations = false;
56
+ this.designationSearchText = '';
57
+ this.designationInitInProgress = false;
58
+ this.scrollListenerAttached = false;
59
+ this.masterData = {};
60
+ this.planData = data;
61
+ console.log('Received data:', data);
62
+ // this.planData.competencies.map((competencies:any)=>{
63
+ // this.competenciesCount['total'] = this.competenciesCount['total'] + 1
64
+ // if(competencies.type === 'Behavioral') {
65
+ // this.competenciesCount['behavioral'] = this.competenciesCount['behavioral'] +1
66
+ // }
67
+ // if(competencies.type === 'Functional') {
68
+ // this.competenciesCount['functional'] = this.competenciesCount['functional'] +1
69
+ // }
70
+ // if(competencies.type === 'Domain') {
71
+ // this.competenciesCount['domain'] = this.competenciesCount['domain'] +1
72
+ // }
73
+ // })
74
+ }
75
+ ngOnInit() {
76
+ this.loadCompetenciesData();
77
+ this.initializeForm();
78
+ this.updateCompetencyCounts();
79
+ }
80
+ loadCompetenciesData() {
81
+ this.sharedService.getCompetencyJson().subscribe({
82
+ next: (data) => {
83
+ this.competenciesData = data;
84
+ console.log('Competencies data loaded:', this.competenciesData);
85
+ },
86
+ error: (error) => {
87
+ console.error('Error loading competencies data:', error);
88
+ }
89
+ });
90
+ }
91
+ updateCompetencyCounts() {
92
+ const comps = this.competenciesArray.value;
93
+ this.competenciesCount = { total: 0, behavioral: 0, functional: 0, domain: 0 };
94
+ comps.forEach(c => {
95
+ this.competenciesCount.total++;
96
+ if (c.type.toLowerCase() === 'behavioral')
97
+ this.competenciesCount.behavioral++;
98
+ if (c.type.toLowerCase() === 'functional')
99
+ this.competenciesCount.functional++;
100
+ if (c.type.toLowerCase() === 'domain')
101
+ this.competenciesCount.domain++;
102
+ });
103
+ }
104
+ initializeForm() {
105
+ this.cbpForm = this.fb.group({
106
+ designation_name: [this.planData?.designation_name || '', Validators.required],
107
+ wing_division_section: [this.planData?.wing_division_section || '', Validators.required],
108
+ role_responsibilities_text: [this.planData?.role_responsibilities?.join('\n') || ''],
109
+ activities_text: [this.planData?.activities?.join('\n') || ''],
110
+ competencySearchText: [''],
111
+ competencyType: [''],
112
+ competencyTheme: [''],
113
+ competencySubTheme: [''],
114
+ manualThemeInput: [''],
115
+ manualSubThemeInput: [''],
116
+ themeSearch: [''],
117
+ subThemeSearch: [''],
118
+ competencies: this.fb.array(this.planData?.competencies || []),
119
+ searchDesignation: ['']
120
+ });
121
+ if (!this.masterData['designationBackup']) {
122
+ this.getDesignationSafe();
123
+ }
124
+ }
125
+ getDesignationSafe() {
126
+ if (this.designationInitInProgress || this.isLoadingMoreDesignations) {
127
+ return;
128
+ }
129
+ this.designationInitInProgress = true;
130
+ this.getDesignation();
131
+ }
132
+ get roleResponsibilities() {
133
+ return this.cbpForm.get('role_responsibilities');
134
+ }
135
+ searchData() {
136
+ }
137
+ applyFilter() {
138
+ }
139
+ getCompetenciesByType(type) {
140
+ return (this.cbpForm?.get('competencies')?.value || []).filter(c => c.type === type);
141
+ }
142
+ closeDialog() {
143
+ this.dialogRef.close();
144
+ }
145
+ saveRoleMapping() {
146
+ if (this.cbpForm.invalid)
147
+ return;
148
+ const formData = this.cbpForm.value;
149
+ console.log('Submitted Data:', formData);
150
+ let cbpPlanData = this.sharedService.cbpPlanFinalObj;
151
+ console.log('cbpPlanData', cbpPlanData);
152
+ const roleResponsibilitiesArray = this.cbpForm.value.role_responsibilities_text
153
+ .split('\n')
154
+ .map(line => line.trim())
155
+ .filter(line => line);
156
+ const activities = this.cbpForm.value.activities_text
157
+ .split('\n')
158
+ .map(line => line.trim())
159
+ .filter(line => line);
160
+ this.loading = true;
161
+ let req = {
162
+ "sector_name": cbpPlanData?.sectors?.join(","),
163
+ "instruction": cbpPlanData?.instruction ? cbpPlanData.instruction : '',
164
+ "designation_name": formData?.designation_name ? formData.designation_name : '',
165
+ "wing_division_section": formData?.wing_division_section,
166
+ "role_responsibilities": roleResponsibilitiesArray,
167
+ "activities": activities,
168
+ "competencies": formData.competencies
169
+ };
170
+ let role_mapping_id = this.planData.id;
171
+ this.sharedService.updateRoleMapping(role_mapping_id, req).subscribe({
172
+ next: (res) => {
173
+ // Success handling
174
+ console.log('Success:', res);
175
+ this.loading = false;
176
+ this.dialogRef.close('saved');
177
+ this.snackBar.open('Role Mapping Saved Successfully', 'X', {
178
+ duration: 3000,
179
+ panelClass: ['snackbar-success']
180
+ });
181
+ //this.successRoleMapping.emit(this.roleMappingForm)
182
+ },
183
+ error: (error) => {
184
+ console.log('error', error);
185
+ this.dialogRef.close();
186
+ // Handle 409 Conflict here
187
+ // alert('Conflict detected: The resource already exists or action conflicts.');
188
+ //this.get
189
+ // Or you can set a UI error message variable
190
+ this.snackBar.open(error?.error?.detail, 'X', {
191
+ duration: 3000,
192
+ panelClass: ['snackbar-error']
193
+ });
194
+ this.loading = false;
195
+ //this.alreadyAvailableRoleMapping.emit(this.roleMappingForm)
196
+ }
197
+ });
198
+ }
199
+ cancelForm() {
200
+ // Mark all controls as pristine and untouched without changing the values
201
+ this.cbpForm.markAsPristine();
202
+ this.cbpForm.markAsUntouched();
203
+ // this.competenciesArray.value = this.originalCompetencyValueArr
204
+ // console.log('this.competenciesArray',this.competenciesArray)
205
+ // Also, if you want to mark all child controls (FormControls / FormArrays / FormGroups) as pristine and untouched
206
+ this.markFormGroupPristineUntouched(this.cbpForm);
207
+ // if(this.editCompetencyIndex > -1) {
208
+ // this.competenciesArray.value[this.editCompetencyIndex]['type'] = this.originalCompetencyValueArr[this.editCompetencyIndex]['type']
209
+ // this.competenciesArray.value[this.editCompetencyIndex]['theme'] = this.originalCompetencyValueArr[this.editCompetencyIndex]['theme']
210
+ // this.competenciesArray.value[this.editCompetencyIndex]['sub_theme'] = this.originalCompetencyValueArr[this.editCompetencyIndex]['sub_theme']
211
+ // }
212
+ this.dialogRef.close();
213
+ }
214
+ markFormGroupPristineUntouched(formGroup) {
215
+ Object.keys(formGroup.controls).forEach(key => {
216
+ const control = formGroup.controls[key];
217
+ if (control instanceof FormControl) {
218
+ control.markAsPristine();
219
+ control.markAsUntouched();
220
+ }
221
+ else if (control instanceof FormGroup || control instanceof FormArray) {
222
+ this.markFormGroupPristineUntouched(control);
223
+ }
224
+ });
225
+ }
226
+ get competenciesArray() {
227
+ return this.cbpForm.get('competencies');
228
+ }
229
+ onCompetencyTypeChange(type) {
230
+ this.selectedCompetencyType = type;
231
+ this.selectedTheme = '';
232
+ this.selectedSubTheme = '';
233
+ this.manualTheme = '';
234
+ this.manualSubTheme = '';
235
+ this.availableThemes = [];
236
+ this.availableSubThemes = [];
237
+ this.filteredThemes = [];
238
+ this.filteredSubThemes = [];
239
+ this.themeSearchText = '';
240
+ this.subThemeSearchText = '';
241
+ // Reset form controls
242
+ this.cbpForm.patchValue({
243
+ competencyTheme: '',
244
+ competencySubTheme: '',
245
+ manualThemeInput: '',
246
+ manualSubThemeInput: '',
247
+ themeSearch: '',
248
+ subThemeSearch: ''
249
+ });
250
+ if (type === 'Behavioral' || type === 'Functional') {
251
+ // Load themes from JSON for Behavioral and Functional
252
+ const competencyCategory = this.competenciesData.find(cat => cat.name.toLowerCase() === type.toLowerCase() ||
253
+ (type === 'Behavioral' && cat.name === 'Behavioural'));
254
+ if (competencyCategory) {
255
+ this.availableThemes = competencyCategory.competency_theme || [];
256
+ this.filteredThemes = [...this.availableThemes];
257
+ }
258
+ }
259
+ // For Domain, no themes are loaded - user will enter manually
260
+ }
261
+ onThemeChange(themeName) {
262
+ this.selectedTheme = themeName;
263
+ this.selectedSubTheme = '';
264
+ this.availableSubThemes = [];
265
+ this.filteredSubThemes = [];
266
+ this.subThemeSearchText = '';
267
+ this.cbpForm.patchValue({
268
+ competencySubTheme: '',
269
+ subThemeSearch: ''
270
+ });
271
+ // Find the selected theme and load its sub-themes
272
+ const selectedThemeObj = this.availableThemes.find(theme => theme.name === themeName);
273
+ if (selectedThemeObj) {
274
+ this.availableSubThemes = selectedThemeObj.competency_sub_theme || [];
275
+ this.filteredSubThemes = [...this.availableSubThemes];
276
+ }
277
+ }
278
+ onSubThemeChange(subThemeName) {
279
+ this.selectedSubTheme = subThemeName;
280
+ }
281
+ addCompetency() {
282
+ let type = this.selectedCompetencyType;
283
+ let theme = '';
284
+ let subTheme = '';
285
+ if (type === 'Domain') {
286
+ // For Domain, use manual input
287
+ theme = this.cbpForm.value.manualThemeInput?.trim();
288
+ subTheme = this.cbpForm.value.manualSubThemeInput?.trim();
289
+ }
290
+ else {
291
+ // For Behavioral/Functional, use dropdown selections
292
+ theme = this.selectedTheme;
293
+ subTheme = this.selectedSubTheme;
294
+ }
295
+ if (type && theme && subTheme) {
296
+ const exists = this.competenciesArray.value.some(c => c.theme === theme && c.sub_theme === subTheme && c.type === type);
297
+ if (!exists) {
298
+ const newComp = this.fb.group({
299
+ type: [type],
300
+ theme: [theme],
301
+ sub_theme: [subTheme]
302
+ });
303
+ this.competenciesArray.push(newComp);
304
+ }
305
+ // Clear input fields after adding
306
+ this.resetCompetencyForm();
307
+ }
308
+ const currentValues = this.competenciesArray.value;
309
+ this.cbpForm.patchValue({ competencies: [...currentValues] });
310
+ this.updateCompetencyCounts();
311
+ this.cdRef.detectChanges();
312
+ console.log(this.cbpForm?.get('competencies')?.value);
313
+ }
314
+ resetCompetencyForm() {
315
+ this.selectedCompetencyType = '';
316
+ this.selectedTheme = '';
317
+ this.selectedSubTheme = '';
318
+ this.manualTheme = '';
319
+ this.manualSubTheme = '';
320
+ this.availableThemes = [];
321
+ this.availableSubThemes = [];
322
+ this.filteredThemes = [];
323
+ this.filteredSubThemes = [];
324
+ this.themeSearchText = '';
325
+ this.subThemeSearchText = '';
326
+ this.cbpForm.patchValue({
327
+ competencyType: '',
328
+ competencyTheme: '',
329
+ competencySubTheme: '',
330
+ manualThemeInput: '',
331
+ manualSubThemeInput: '',
332
+ themeSearch: '',
333
+ subThemeSearch: ''
334
+ });
335
+ }
336
+ filterThemes(searchText) {
337
+ this.themeSearchText = searchText;
338
+ if (!searchText.trim()) {
339
+ this.filteredThemes = [...this.availableThemes];
340
+ }
341
+ else {
342
+ this.filteredThemes = this.availableThemes.filter(theme => theme.name.toLowerCase().includes(searchText.toLowerCase()));
343
+ }
344
+ }
345
+ filterSubThemes(searchText) {
346
+ this.subThemeSearchText = searchText;
347
+ if (!searchText.trim()) {
348
+ this.filteredSubThemes = [...this.availableSubThemes];
349
+ }
350
+ else {
351
+ this.filteredSubThemes = this.availableSubThemes.filter(subTheme => subTheme.toLowerCase().includes(searchText.toLowerCase()));
352
+ }
353
+ }
354
+ canAddCompetency() {
355
+ if (!this.selectedCompetencyType)
356
+ return false;
357
+ if (this.selectedCompetencyType === 'Domain') {
358
+ const theme = this.cbpForm.value.manualThemeInput?.trim();
359
+ const subTheme = this.cbpForm.value.manualSubThemeInput?.trim();
360
+ return !!(theme && subTheme);
361
+ }
362
+ else {
363
+ return !!(this.selectedTheme && this.selectedSubTheme);
364
+ }
365
+ }
366
+ deleteCompetency(comp) {
367
+ const index = this.competenciesArray.controls.findIndex(control => control.value.theme === comp.theme && control.value.type === comp.type);
368
+ if (index !== -1) {
369
+ this.competenciesArray.removeAt(index);
370
+ }
371
+ this.updateCompetencyCounts();
372
+ this.cdRef.detectChanges();
373
+ }
374
+ editCompetency(comp) {
375
+ this.editDomainCompetencyFlag = true;
376
+ this.editCompetencyIndex = -1;
377
+ this.cbpForm.patchValue({
378
+ competencyType: 'Domain',
379
+ manualThemeInput: comp?.theme,
380
+ manualSubThemeInput: comp?.sub_theme
381
+ });
382
+ const index = this.competenciesArray.value.findIndex(c => c.theme === comp?.theme &&
383
+ c.sub_theme === comp?.sub_theme &&
384
+ c.type === "Domain");
385
+ if (index > -1) {
386
+ this.editCompetencyIndex = index;
387
+ }
388
+ this.selectedCompetencyType = 'Domain';
389
+ setTimeout(() => {
390
+ this.dialogContent.nativeElement.scrollTo({
391
+ top: 0,
392
+ behavior: 'smooth'
393
+ });
394
+ }, 500);
395
+ }
396
+ cancelUpdate() {
397
+ this.editDomainCompetencyFlag = false;
398
+ this.editCompetencyIndex = -1;
399
+ this.resetCompetencyForm();
400
+ }
401
+ updateCompetency() {
402
+ let type = this.selectedCompetencyType;
403
+ let theme = '';
404
+ let subTheme = '';
405
+ if (type === 'Domain') {
406
+ // For Domain, use manual input
407
+ theme = this.cbpForm.value.manualThemeInput?.trim();
408
+ subTheme = this.cbpForm.value.manualSubThemeInput?.trim();
409
+ this.originalCompetencyValueArr = JSON.parse(JSON.stringify(this.competenciesArray.value));
410
+ }
411
+ console.log(' this.competenciesArray', this.competenciesArray);
412
+ if (type && theme && subTheme) {
413
+ console.log('this.editCompetencyIndex--', this.editCompetencyIndex);
414
+ if (this.editCompetencyIndex > -1) {
415
+ this.competenciesArray.value[this.editCompetencyIndex]['type'] = type;
416
+ this.competenciesArray.value[this.editCompetencyIndex]['theme'] = theme;
417
+ this.competenciesArray.value[this.editCompetencyIndex]['sub_theme'] = subTheme;
418
+ }
419
+ // if (!exists) {
420
+ // const newComp = this.fb.group({
421
+ // type: [type],
422
+ // theme: [theme],
423
+ // sub_theme: [subTheme]
424
+ // });
425
+ // this.competenciesArray.push(newComp);
426
+ // }
427
+ // Clear input fields after adding
428
+ this.resetCompetencyForm();
429
+ console.log('this.originalCompetencyValueArr', this.originalCompetencyValueArr);
430
+ }
431
+ const currentValues = this.competenciesArray.value;
432
+ this.cbpForm.patchValue({ competencies: [...currentValues] });
433
+ this.updateCompetencyCounts();
434
+ this.cdRef.detectChanges();
435
+ console.log(this.cbpForm?.get('competencies')?.value);
436
+ }
437
+ getDesignation(searchText, offset) {
438
+ // clear any previous debug hooks
439
+ if (!searchText || searchText?.length === 0) {
440
+ // noop
441
+ }
442
+ const reqOffset = (typeof offset === 'number') ? offset : this.designationOffset;
443
+ let reqLimit = this.designationDefaultLoadCount;
444
+ const pageIndex = reqLimit > 0 ? Math.floor(reqOffset / reqLimit) : 0;
445
+ // if we're requesting from first page, clear the no-more-data guard
446
+ if (pageIndex === 0) {
447
+ this.noMoreLegacyDesignations = false;
448
+ reqLimit = 50;
449
+ }
450
+ const requestBody = {
451
+ filterCriteriaMap: {
452
+ status: 'Active'
453
+ },
454
+ requestedFields: [],
455
+ pageNumber: pageIndex,
456
+ pageSize: reqLimit,
457
+ };
458
+ if (searchText?.length) {
459
+ requestBody['searchString'] = searchText;
460
+ // when searching, start from first page
461
+ requestBody.pageNumber = 0;
462
+ // allow larger page for search if needed
463
+ requestBody.pageSize = pageIndex === 0 ? 50 : this.designationListLoadCount;
464
+ // reset guard when performing a fresh search
465
+ this.noMoreLegacyDesignations = false;
466
+ }
467
+ // indicate loading state so scroll handlers don't trigger parallel calls
468
+ this.isLoadingMoreDesignations = true;
469
+ this.sharedService.searchPublicDesignation(requestBody).pipe(finalize(() => {
470
+ this.isLoadingMoreDesignations = false;
471
+ this.designationInitInProgress = false;
472
+ }))
473
+ .subscribe({
474
+ next: (res) => {
475
+ const content = _.get(res, 'result.result.data', []);
476
+ const mapped = content.map((item) => ({
477
+ name: item?.designation || '',
478
+ status: item?.status || 'Active',
479
+ }));
480
+ // total count may be present in different keys depending on API version.
481
+ // Prefer 'result.result.totalcount' (legacy lower-case) then data.totalCount, then totalCount
482
+ const total = _.get(res, 'result.result.totalcount', _.get(res, 'result.result.data.totalCount', _.get(res, 'result.result.totalCount', 0)));
483
+ this.defaultSearchDesignationCount = total;
484
+ // If offset is zero (first page) replace backup, otherwise append + dedupe
485
+ if (!this.masterData['designationBackup'] || reqOffset === 0) {
486
+ this.masterData['designationBackup'] = mapped;
487
+ }
488
+ else {
489
+ const combined = (this.masterData['designationBackup'] || []).concat(mapped);
490
+ this.masterData['designationBackup'] = _.uniqBy(combined, (it) => (it?.name || '').toLowerCase());
491
+ }
492
+ // If server returned no new items, mark as no-more-data to stop further scroll requests
493
+ if (!mapped || mapped?.length === 0) {
494
+ this.noMoreLegacyDesignations = true;
495
+ }
496
+ // If we've loaded at least the total count, mark no-more-data
497
+ if (this.defaultSearchDesignationCount && (this.masterData['designationBackup'] || []).length >= this.defaultSearchDesignationCount) {
498
+ this.noMoreLegacyDesignations = true;
499
+ }
500
+ // Ensure visible list matches the requested display count
501
+ this.masterData['designation'] = (this.masterData['designationBackup'] || []).slice(0, this.designationListLoadCount);
502
+ // loading flag cleared in finalize()
503
+ this.ensureSelectedDesignationExists();
504
+ this.checkCurrentDesignationPresent();
505
+ },
506
+ error: () => {
507
+ // Stop further automatic calls on repeated errors to avoid tight loops
508
+ // loading flag cleared in finalize()
509
+ this.noMoreLegacyDesignations = true;
510
+ // this.matSnackBar.open('Unable to fetch designation details, please try again later!')
511
+ }
512
+ });
513
+ this.cbpForm.get('designation_name')?.setValue(this.planData?.designation_name || '');
514
+ }
515
+ ensureSelectedDesignationExists() {
516
+ const selected = this.planData?.designation_name;
517
+ if (!selected)
518
+ return;
519
+ const exists = this.masterData['designationBackup']?.some((d) => d.name?.toLowerCase() === selected.toLowerCase());
520
+ if (!exists) {
521
+ const customObj = {
522
+ name: selected,
523
+ status: 'Active',
524
+ igot_designation_name: "Principal Secretary",
525
+ igot_designation_id: "DESG-002314",
526
+ };
527
+ // ✅ Add at TOP so it's visible immediately
528
+ this.masterData['designationBackup'] = [
529
+ customObj,
530
+ ...(this.masterData['designationBackup'] || [])
531
+ ];
532
+ this.masterData['designation'] = [
533
+ customObj,
534
+ ...(this.masterData['designation'] || [])
535
+ ];
536
+ }
537
+ }
538
+ checkCurrentDesignationPresent() {
539
+ const selectedDesignations = this.cbpForm.get('designation_name')?.value || [];
540
+ if (!Array.isArray(selectedDesignations) || !selectedDesignations.length) {
541
+ return;
542
+ }
543
+ if (!this.masterData?.designation) {
544
+ return;
545
+ }
546
+ selectedDesignations.forEach((selectedName) => {
547
+ const exists = this.masterData.designation.some((item) => item?.name?.toLowerCase() === selectedName?.toLowerCase());
548
+ if (!exists) {
549
+ const newDesignation = {
550
+ name: selectedName,
551
+ status: 'Active',
552
+ id: 'custom-' + Date.now() + '-' + Math.random()
553
+ };
554
+ // Add to backup list as well
555
+ this.masterData.designationBackup =
556
+ this.masterData.designationBackup || [];
557
+ this.masterData.designationBackup.unshift(newDesignation);
558
+ // Also update visible list
559
+ this.masterData.designation.unshift(newDesignation);
560
+ }
561
+ });
562
+ }
563
+ onDesignationDropdownClosed() {
564
+ // Keep the designation value but clear the search input
565
+ const currentDesignation = this.cbpForm.get('designation_name').value;
566
+ setTimeout(() => {
567
+ if (this.cbpForm.get('searchDesignation')) {
568
+ this.cbpForm.get('searchDesignation').setValue('');
569
+ }
570
+ // Ensure the designation value remains selected
571
+ if (currentDesignation) {
572
+ const designationControl = this.cbpForm.get('designation_name');
573
+ if (designationControl) {
574
+ designationControl.setValue(currentDesignation);
575
+ }
576
+ }
577
+ }, 100);
578
+ }
579
+ designationSearch(evt) {
580
+ const searchText = evt?.target?.value;
581
+ const txt = (searchText || '').toString().trim();
582
+ if (this.isLoadingMoreDesignations)
583
+ return;
584
+ this.designationSearchText = txt;
585
+ if (txt?.length) {
586
+ this.desigantionFilterEnable = true;
587
+ this.isLoadingMoreDesignations = true;
588
+ this.getDesignation(txt, 0);
589
+ }
590
+ else if (this.masterData && this.masterData?.designationBackup) {
591
+ this.masterData.designation = this.masterData?.designationBackup.slice(0, this.designationDefaultLoadCount);
592
+ this.desigantionFilterEnable = false;
593
+ this.checkCurrentDesignationPresent();
594
+ }
595
+ }
596
+ setupScrollListener(opened) {
597
+ if (opened) {
598
+ if (!this.scrollListenerAttached) {
599
+ this.scrollListenerAttached = true;
600
+ this.desigantionFilterEnable = false;
601
+ this.designationListLoadCount = this.designationDefaultLoadCount;
602
+ this.designationOffset = 0;
603
+ this.isLoadingMoreDesignations = true;
604
+ this.getDesignation(undefined, 0);
605
+ // Clear search box once
606
+ if (this.cbpForm.get('searchDesignation')) {
607
+ this.cbpForm.get('searchDesignation').setValue('');
608
+ }
609
+ setTimeout(() => {
610
+ const searchInput = document.querySelector('.search-input');
611
+ if (searchInput) {
612
+ searchInput.focus();
613
+ }
614
+ }, 100);
615
+ // Attach scroll listener safely
616
+ setTimeout(() => {
617
+ const panel = document.querySelector('.mat-select-panel.search-panel');
618
+ if (panel) {
619
+ // align panel width to trigger
620
+ try {
621
+ const triggerEl = this.designationRef && this.designationRef.nativeElement;
622
+ if (triggerEl) {
623
+ const rect = triggerEl.getBoundingClientRect();
624
+ // set width and left so panel aligns exactly below the trigger
625
+ panel.style.width = `${Math.round(rect.width)}px`;
626
+ // leave left to overlay positioning but nudge if necessary
627
+ // compute left relative to viewport and apply to panel
628
+ const overlayLeft = rect.left;
629
+ panel.style.left = `${Math.round(overlayLeft)}px`;
630
+ }
631
+ }
632
+ catch (e) {
633
+ // ignore DOM errors in SSR or unexpected cases
634
+ }
635
+ const scrollHandler = this.onDesignationSelectScroll.bind(this);
636
+ panel.addEventListener('scroll', scrollHandler, { passive: true });
637
+ }
638
+ }, 150);
639
+ }
640
+ }
641
+ else {
642
+ // Dropdown closed — reset scroll flag so it can reattach next time
643
+ this.scrollListenerAttached = false;
644
+ }
645
+ }
646
+ onDesignationSelectScroll(event) {
647
+ const element = event?.target;
648
+ if (!this.desigantionFilterEnable) {
649
+ // Check if user has scrolled to the bottom (with a small threshold)
650
+ if (element.scrollTop + element?.clientHeight >= element?.scrollHeight - 5) {
651
+ // Only load more if not already loading and if there are potentially more items
652
+ if (!this.isLoadingMoreDesignations) {
653
+ // If org uses IGOT designation taxonomy, request more from the API by increasing the limit
654
+ if (this.masterData?.designationBackup?.length > this.masterData?.designation?.length) {
655
+ // Local pagination: expand the sliced list
656
+ this.isLoadingMoreDesignations = true;
657
+ this.designationListLoadCount += this.designationDefaultLoadCount;
658
+ // Update the filtered list with more items
659
+ setTimeout(() => {
660
+ this.masterData.designation = this.masterData?.designationBackup?.slice(0, this.designationListLoadCount);
661
+ this.checkCurrentDesignationPresent();
662
+ this.isLoadingMoreDesignations = false;
663
+ }, 500); // Small timeout to simulate loading and prevent multiple triggers
664
+ }
665
+ else {
666
+ // Legacy (server) pagination: request next page if total not reached
667
+ const loadedLegacy = (this.masterData?.designationBackup || []).length;
668
+ if (!this.noMoreLegacyDesignations && this.defaultSearchDesignationCount && loadedLegacy < this.defaultSearchDesignationCount) {
669
+ this.isLoadingMoreDesignations = true;
670
+ this.designationOffset = (this.designationOffset || 0) + this.designationDefaultLoadCount;
671
+ // increase display count to include newly fetched items
672
+ this.designationListLoadCount += this.designationDefaultLoadCount;
673
+ this.getDesignation(undefined, this.designationOffset);
674
+ }
675
+ }
676
+ }
677
+ }
678
+ }
679
+ }
680
+ get searchDesignationControl() {
681
+ return this.cbpForm.get('searchDesignation');
682
+ }
683
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EditCbpPlanComponent, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }, { token: i2.FormBuilder }, { token: i0.ChangeDetectorRef }, { token: i3.SharedService }, { token: i4.MatSnackBar }, { token: i5.HttpClient }], target: i0.ɵɵFactoryTarget.Component }); }
684
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EditCbpPlanComponent, selector: "app-edit-cbp-plan", viewQueries: [{ propertyName: "dialogContent", first: true, predicate: ["dialogContent"], descendants: true }, { propertyName: "designationRef", first: true, predicate: ["designation"], descendants: true, read: ElementRef }], ngImport: i0, template: "<div class=\"view-cbp-plan\" #dialogContent>\n <div class=\"popup-container\">\n <div class=\"popup-header\">\n <div>\n <div class=\"heading\">Edit Role Mapping</div>\n </div>\n <div class=\"cursor-pointer\" (click)=\"closeDialog()\">\n <mat-icon>close</mat-icon>\n </div>\n </div>\n <div class=\"section-container\" [formGroup]=\"cbpForm\">\n\n <!-- <div class=\"section-header mt-4\">\n <input type=\"text\" formControlName=\"designation_name\" [value]=\"planData?.designation_name\"\n style=\"border-radius: 25px; border: 1px solid #ccc; padding: 8px 12px; width: 100%;font-size: 14px;font-family: 'Lato';\">\n\n\n </div> -->\n\n <mat-form-field appearance=\"outline\" class=\"mt-4 margin-top-s w-full required-select\" style=\"border-radius: 25px; border: 1px solid #ccc; padding: 8px 12px; width: 100%;font-size: 14px;font-family: 'Lato';\">\n <mat-select #position formControlName=\"designation_name\" placeholder=\"Select designation\"\n (closed)=\"onDesignationDropdownClosed()\" panelClass=\"search-panel\"\n (openedChange)=\"setupScrollListener($event)\">\n\n <!-- Sticky search input container -->\n <div class=\"sticky-search-container\" (click)=\"$event.stopPropagation()\">\n <div class=\"search-input-wrapper\">\n <input type=\"text\" placeholder=\"Search designation\" style=\"width:100%\"\n formControlName=\"searchDesignation\" class=\"search-input\"\n (keydown)=\"$event.stopPropagation()\"\n (keydown.enter)=\"$event.preventDefault(); $event.stopPropagation()\"\n (keyup)=\"designationSearch($event)\" autocomplete=\"off\">\n <div *ngIf=\"searchDesignationControl?.value\" type=\"button\" class=\"clear-icon\"\n (click)=\"searchDesignationControl.setValue('')\">\n <mat-icon>close</mat-icon>\n </div>\n </div>\n </div>\n <!-- Options list -->\n <mat-option [value]=\"designation?.name\" *ngFor=\"let designation of masterData?.designation\">\n {{designation?.name}}\n </mat-option>\n <!-- Loading indicator -->\n <div *ngIf=\"isLoadingMoreDesignations\" class=\"loading-indicator\">\n Load More...\n </div>\n <!-- No results message -->\n <mat-option *ngIf=\"(masterData?.designation)?.length === 0\" disabled class=\"no-data-option\">\n\n Designation Not Found.\n\n </mat-option>\n </mat-select>\n <!-- <mat-error class=\"text-xs\"\n *ngIf=\"designationForm?.get('designation_name')?.touched && designationForm?.get('designation_name')?.invalid\">\n Please select at least one designation.\n </mat-error> -->\n </mat-form-field>\n\n <div class=\"competency-container mt-4\">\n <div class=\"outside-layer-total\">\n <div class=\"inside-layer\">\n Total Competencies\n </div>\n <div class=\"count\">\n {{competenciesCount?.total}}\n </div>\n </div>\n <div class=\"outside-layer-behavioral\">\n <div class=\"inside-layer\">\n Behavioral Competencies\n </div>\n <div class=\"count\">\n {{competenciesCount?.behavioral}}\n </div>\n </div>\n <div class=\"outside-layer-functional\">\n <div class=\"inside-layer\">\n Functional Competencies\n </div>\n <div class=\"count\">\n {{competenciesCount?.functional}}\n </div>\n </div>\n <div class=\"outside-layer-domain\">\n <div class=\"inside-layer\">\n Domain Competencies\n </div>\n <div class=\"count\">\n {{competenciesCount?.domain}}\n </div>\n </div>\n </div>\n <div class=\"mt-4 section\">\n <div class=\"sub-heading\">\n <p>Wing/Division</p>\n </div>\n <div class=\"mt-4\">\n <input type=\"text\" formControlName=\"wing_division_section\" [value]=\"planData?.wing_division_section\"\n style=\"border-radius: 25px; border: 1px solid #ccc; padding: 8px 12px; width:100%;font-size: 14px;font-family: 'Lato';\">\n </div>\n </div>\n <div class=\"mt-2 section\">\n <div class=\"sub-heading\">\n <p>Roles & Responsibilities</p>\n </div>\n <div class=\"mt-4 additional-details\">\n <textarea class=\"custom-textarea\" formControlName=\"role_responsibilities_text\" rows=\"5\"\n placeholder=\"Roles & Responsibilities\"\n [value]=\"planData?.role_responsibilities?.join('\\n')\"></textarea>\n </div>\n </div>\n <div class=\"mt-2 section\">\n <div class=\"sub-heading\">\n <p>Activities</p>\n </div>\n <div class=\"mt-4 additional-details\">\n <textarea class=\"custom-textarea\" formControlName=\"activities_text\" rows=\"5\"\n placeholder=\"Activities\" [value]=\"planData?.activities?.join('\\n')\"></textarea>\n </div>\n </div>\n <div class=\"mt-2 section\">\n <div class=\"sub-heading\">\n <p>Competency</p>\n </div>\n <div class=\"enhanced-competency-section mt-2\">\n <!-- Step 1: Select Competency Type -->\n <div class=\"competency-step\">\n <label class=\"step-label\">1. Select Core Competency Type</label>\n <div class=\"competency-dropdown-container\">\n <mat-form-field appearance=\"outline\" class=\"competency-dropdown\">\n <mat-select formControlName=\"competencyType\" placeholder=\"Select Competency Type\"\n (selectionChange)=\"onCompetencyTypeChange($event.value)\">\n <mat-option value=\"Behavioral\">Behavioral</mat-option>\n <mat-option value=\"Functional\">Functional</mat-option>\n <mat-option value=\"Domain\">Domain</mat-option>\n </mat-select>\n </mat-form-field>\n </div>\n </div>\n\n <!-- Step 2: Theme Selection (Behavioral/Functional from JSON, Domain manual) -->\n <div class=\"competency-step\" *ngIf=\"selectedCompetencyType\">\n <label class=\"step-label\">2. Select/Enter Theme</label>\n\n <!-- For Behavioral and Functional: Searchable Dropdown from JSON -->\n <div class=\"competency-dropdown-container\"\n *ngIf=\"selectedCompetencyType === 'Behavioral' || selectedCompetencyType === 'Functional'\">\n <mat-form-field appearance=\"outline\" class=\"competency-dropdown\">\n <mat-select formControlName=\"competencyTheme\" placeholder=\"Search and select theme\"\n (selectionChange)=\"onThemeChange($event.value)\">\n <!-- Search input inside dropdown -->\n <mat-option class=\"search-option\" disabled>\n <mat-form-field appearance=\"outline\" class=\"search-field\">\n <input matInput placeholder=\"Search themes...\" formControlName=\"themeSearch\"\n (input)=\"filterThemes($event.target.value)\"\n (click)=\"$event.stopPropagation()\" (keydown)=\"$event.stopPropagation()\">\n </mat-form-field>\n </mat-option>\n\n <!-- Theme options -->\n <mat-option *ngFor=\"let theme of filteredThemes\" [value]=\"theme.name\">\n {{theme.name}}\n </mat-option>\n\n <!-- No results message -->\n <mat-option *ngIf=\"filteredThemes.length === 0 && themeSearchText\" disabled>\n No themes found matching \"{{themeSearchText}}\"\n </mat-option>\n </mat-select>\n </mat-form-field>\n </div>\n\n <!-- For Domain: Manual input -->\n <div class=\"manual-input-container\" *ngIf=\"selectedCompetencyType === 'Domain'\">\n <input type=\"text\" formControlName=\"manualThemeInput\" placeholder=\"Enter Theme manually\"\n class=\"manual-input\" />\n </div>\n </div>\n\n <!-- Step 3: Sub-theme Selection -->\n <div class=\"competency-step\" *ngIf=\"selectedTheme || (selectedCompetencyType === 'Domain')\">\n <label class=\"step-label\">3. Select/Enter Sub-theme</label>\n\n <!-- For Behavioral and Functional: Searchable Dropdown based on selected theme -->\n <div class=\"competency-dropdown-container\"\n *ngIf=\"selectedCompetencyType === 'Behavioral' || selectedCompetencyType === 'Functional'\">\n <mat-form-field appearance=\"outline\" class=\"competency-dropdown\">\n <mat-select formControlName=\"competencySubTheme\"\n placeholder=\"Search and select sub-theme\"\n (selectionChange)=\"onSubThemeChange($event.value)\">\n <!-- Search input inside dropdown -->\n <mat-option class=\"search-option\" disabled>\n <mat-form-field appearance=\"outline\" class=\"search-field\">\n <input matInput placeholder=\"Search sub-themes...\"\n formControlName=\"subThemeSearch\"\n (input)=\"filterSubThemes($event.target.value)\"\n (click)=\"$event.stopPropagation()\" (keydown)=\"$event.stopPropagation()\">\n </mat-form-field>\n </mat-option>\n\n <!-- Sub-theme options -->\n <mat-option *ngFor=\"let subTheme of filteredSubThemes\" [value]=\"subTheme\">\n {{subTheme}}\n </mat-option>\n\n <!-- No results message -->\n <mat-option *ngIf=\"filteredSubThemes.length === 0 && subThemeSearchText\" disabled>\n No sub-themes found matching \"{{subThemeSearchText}}\"\n </mat-option>\n </mat-select>\n </mat-form-field>\n </div>\n\n <!-- For Domain: Manual input -->\n <div class=\"manual-input-container\" *ngIf=\"selectedCompetencyType === 'Domain'\">\n <input type=\"text\" formControlName=\"manualSubThemeInput\"\n placeholder=\"Enter Sub-theme manually\" class=\"manual-input\" />\n </div>\n </div>\n\n <!-- Add Button -->\n <div class=\"add-button-section\" *ngIf=\"selectedCompetencyType \">\n <button type=\"button\" *ngIf=\"!editDomainCompetencyFlag\" class=\"add-competency-btn\"\n [disabled]=\"!canAddCompetency()\"\n [ngClass]=\"canAddCompetency() ? 'btn-active' : 'btn-disable'\" (click)=\"addCompetency()\">\n Add Competency\n </button>\n <button type=\"button\" *ngIf=\"editDomainCompetencyFlag\" class=\"add-competency-btn btn-active\"\n (click)=\"updateCompetency()\">\n Update Competency\n </button>\n <button type=\"button\" *ngIf=\"editDomainCompetencyFlag\" class=\"add-competency-btn btn-active\"\n style=\"margin-left: 5px;\" (click)=\"cancelUpdate()\">\n Cancel </button>\n </div>\n </div>\n <div class=\"mt-4\">\n <div class=\"competency-sub-heading mt-2\" *ngIf=\"getCompetenciesByType('Behavioral')?.length\">\n Behavioral Competencies\n </div>\n\n <div class=\"competency-grid mt-2\">\n <div class=\"competency-item behavioural-pill\"\n *ngFor=\"let comp of getCompetenciesByType('Behavioral')\">\n <span class=\"competency-text-behavioral\">\n {{ comp.theme }} - {{ comp.sub_theme }}\n </span>\n <span class=\"cursor-pointer close\" (click)=\"deleteCompetency(comp)\">\n <mat-icon>close</mat-icon>\n </span>\n </div>\n </div>\n </div>\n <div class=\"mt-4\">\n <div class=\"competency-sub-heading mt-2\" *ngIf=\"getCompetenciesByType('Functional')?.length\">\n Functional Competencies</div>\n <div class=\"competency-grid mt-2\">\n <div class=\"competency-item functional-pill\"\n *ngFor=\"let comp of getCompetenciesByType('Functional')\">\n <span class=\"competency-text-functional\">\n {{ comp.theme }} - {{ comp.sub_theme }}\n </span>\n <span class=\"cursor-pointer close\" (click)=\"deleteCompetency(comp)\">\n <mat-icon>close</mat-icon>\n </span>\n </div>\n </div>\n </div>\n <div class=\"mt-4\">\n <div class=\"competency-sub-heading mt-2\">Domain Competencies</div>\n <div class=\"competency-grid mt-2\">\n <div class=\"competency-item domain-pill\" *ngFor=\"let comp of getCompetenciesByType('Domain')\">\n <span class=\"competency-text-domain\">\n {{ comp.theme }} - {{ comp.sub_theme }}\n </span>\n <span class=\"cursor-pointer edit\" (click)=\"editCompetency(comp)\">\n <mat-icon>edit</mat-icon>\n </span>\n <span class=\"cursor-pointer close\" (click)=\"deleteCompetency(comp)\">\n <mat-icon>close</mat-icon>\n </span>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"popup-footer\">\n <div>\n <input class=\"btn-active\" type=\"button\" value=\"Cancel\" (click)=\"cancelForm()\" />\n </div>\n <div>\n <input class=\"btn-active\" type=\"button\" value=\"Save\" (click)=\"saveRoleMapping()\" />\n </div>\n </div>\n </div>\n</div>\n\n<div class=\"overlay-loader\" *ngIf=\"loading\">\n <mat-spinner diameter=\"50\"></mat-spinner>\n</div>", styles: ["@charset \"UTF-8\";.container{margin:10px auto}.sub-heading p{color:#000;font-family:Montserrat;font-size:16px;font-style:normal;font-weight:600;line-height:normal}.radio-label{color:#000;font-family:Lato;font-size:16px;font-style:normal;font-weight:400;line-height:normal}.radio-btn-group{display:flex;width:32px;height:32px;padding:2px;gap:10px}.label{color:var(--Body-Text-Body-Color, #212529);font-family:Lato;font-size:14px;font-style:normal;font-weight:700;line-height:150%}::ng-deep .legacy-form-field{background-color:#fff!important;border-radius:25px!important;padding-left:12px;padding-right:12px;height:42px;width:100%}::ng-deep mat-select{border-radius:25px!important;background-color:#fff!important}::ng-deep .mat-select-panel{background-color:#fff!important}::ng-deep .mat-select-panel .mat-option{border-radius:0!important}::ng-deep mat-form-field .mat-form-field-underline{display:none!important}::ng-deep mat-select .mat-select-placeholder{color:#0006;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal}::ng-deep mat-select .mat-select-value-text{color:#000;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal;line-height:normal!important;padding-top:0!important;padding-bottom:0!important}::ng-deep mat-select .mat-select-value{display:flex!important;align-items:center!important;height:100%!important}.additional-details textarea{display:flex;padding:16px 16px 0;flex-direction:column;align-items:flex-start;gap:10px;flex:1 0 0;align-self:stretch;width:100%;color:#000;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal;resize:none}.section-header{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.btn-disable{border-radius:var(--Radius-Full-Round, 9999999px);opacity:.4;background:var(--Primary-KB-Primary-Light, #1B4CA1);color:var(--white-kb-white-100, #FFF);text-align:center;font-family:Lato;font-size:14px;font-style:normal;font-weight:700;line-height:normal;display:flex;height:32px;padding:0 16px;justify-content:center;align-items:center;gap:8px;border:none}.btn-group{display:flex;flex-direction:row;justify-content:space-between}.pl-2{padding-left:5px}.search-filter-section{display:flex;flex-direction:row;gap:10px}.legacy-search-filter{display:none}.search .rsearch{position:relative}.search .search-icon{position:absolute;top:10px;font-size:20px;left:10px}.search .sinput{border-radius:4px;border:1px solid #d5d0d0;padding:15px 36px;font:400 14px Lato}.select-map-route-container{display:flex;flex-direction:row}.selected-mapping-route p{color:#1b4ca1;font-family:Lato;font-size:20px;font-style:normal;font-weight:400;line-height:normal;text-decoration-line:underline;text-decoration-style:solid;-webkit-text-decoration-skip:ink;text-decoration-skip-ink:auto;text-decoration-thickness:auto;text-underline-offset:auto;text-underline-position:from-font}.edit-plan{display:flex;padding:4px;justify-content:center;align-items:center;gap:8px;border-radius:4px;background:#1b4ca129;color:#1b4ca1;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal;margin-left:10px}.search-container{display:flex;flex-direction:row}.course-container{display:flex;width:100%;padding:16px;flex-direction:column;align-items:flex-start;gap:24px;grid-row:2/span 1;grid-column:1/span 1;border-radius:12px;border:1px solid var(--borders-black-border-16-black, rgba(0, 0, 0, .16));background:#fff}.course-header{display:flex;flex-direction:row;justify-content:space-between;width:100%}.course-pill{display:flex;height:24px;padding:8px;align-items:center;gap:4px;border-radius:16px;border:1px solid var(--borders-border-fill-focussed-4-light-100, #EF951E);background:#fefaf4}.ai-recommened-pill{display:flex;padding:4px 8px;align-items:center;gap:8px;border-radius:var(--Radius-4, 4px);border:1px solid #1B4CA1;background:#1b4ca129}.igot-platform-pill{display:flex;padding:4px 8px;align-items:center;gap:8px;border-radius:var(--Radius-4, 4px);border:1px solid #EF951E;background:#ef951e29}.course-title{color:var(--Primary-KB-Primary-Light, #1B4CA1);font-family:Montserrat;font-size:20px;font-style:normal;font-weight:600;line-height:30px}.course-desc{color:#0009;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal}.relevancy,.competencies-matched{color:var(--accessbility-shades-with-opacity-kb-greys-black-60, rgba(0, 0, 0, .6));font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal;align-items:center}.percentage{color:#1d8923;font-family:Lato;font-size:14px;font-style:normal;font-weight:800;line-height:normal}.relevancy-container,.competencies-matched-container{display:flex;flex-direction:row;align-items:center}.dash{padding:0 5px}::ng-deep .mat-radio-checked .mat-radio-inner-circle{background:#1b4ca1!important}.course-list-container{display:flex;flex-wrap:wrap;gap:16px}.course-list-item{flex:0 0 48%;box-sizing:border-box;border:1px solid #ccc;padding:16px;background-color:#fff;border-radius:8px}.checked-course-container{display:flex}.ml-2{margin-left:8px}::ng-deep .mat-checkbox-checked .mat-checkbox-background{background:#1b4ca1!important}.ai-recommened-pill-text,.igot-platform-pill-text{color:#1b4ca1;font-family:Lato;font-size:12px;font-style:normal;font-weight:700;line-height:normal}.course-pill-text{color:var(--accessbility-shades-without-opacity-kb-greys-black-87, #212121);text-align:center;font-family:Poppins;font-size:12px;font-style:normal;font-weight:400;line-height:normal}.ai-loader-icon img,.igot-platform-icon img{width:15.714px;height:15.714px;flex-shrink:0}.competency-container{display:flex;justify-content:space-between;flex-direction:row}.outside-layer-total{display:flex;padding:4px 12px;justify-content:center;align-items:center;gap:16px;border-radius:12px;border-left:2px solid #1B4CA1;border-right:2px solid #1B4CA1;background:#edf1f8;margin:0 10px}.outside-layer-functional{display:flex;padding:4px 12px;justify-content:center;align-items:center;gap:16px;border-radius:12px;border-left:2px solid #E24577;border-right:2px solid #E24577;background:#f8d2de;margin:0 10px}.outside-layer-domain{display:flex;padding:4px 12px;justify-content:center;align-items:center;gap:16px;border-radius:12px;border-left:2px solid #7B47A4;border-right:2px solid #7B47A4;background:#dfd3e9;margin:0 10px}.outside-layer-behavioral{display:flex;padding:4px 12px;justify-content:center;align-items:center;gap:16px;border-radius:12px;border-left:2px solid #F8B861;border-right:2px solid #F8B861;background:#fde8cc;margin:0 10px}.inside-layer{color:#1b4ca1;font-family:Lato;font-size:18px;font-style:normal;font-weight:400;line-height:normal}.count{color:#1b4ca1;font-family:Montserrat;font-size:24px;font-style:normal;font-weight:600;line-height:normal}.suggest-courses-header{display:flex;flex-direction:row;justify-content:space-between}.suggest-course-control{display:flex;flex-direction:row}.course-card-container{width:172px;border-radius:3.307px;border:.827px solid var(--borders-border-8-black, rgba(0, 0, 0, .08));background-color:#fff}.highlight-ai{font-family:Montserrat;font-size:24px;font-style:normal;font-weight:600;line-height:normal;background:linear-gradient(90deg,#3b27ff,#2de3d6);background-clip:text;-webkit-background-clip:text;color:transparent;-webkit-text-fill-color:transparent;display:inline-block}.ai-loader-icon-medium img{width:40px;height:40px;flex-shrink:0}.heading{color:#000;font-family:Montserrat;font-size: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:2px 8px;justify-content:center;align-items:center;gap:10px;border-radius:8px;border:1px solid #F8B861;background:linear-gradient(0deg,#f8b86152 0% 100%),#fff;margin:5px 0}.functional-pill{display:flex;padding:2px 8px;justify-content:center;align-items:center;gap:10px;border-radius:8px;border:1px solid #E24577;background:linear-gradient(0deg,#e245773d 0% 100%),#fff;margin:5px 0}.domain-pill{display:flex;padding:2px 8px;justify-content:center;align-items:center;gap:10px;border-radius:8px;border:1px solid #7B47A4;background:linear-gradient(0deg,#7b47a43d 0% 100%),#fff;margin:5px 0}.popup-header{display:flex;flex-direction:row;justify-content:space-between}.popup-footer{display:flex;flex-direction:row;justify-content:end}.view-cbp-plan{margin:10px;padding:10px}.view-cbp-plan-popup{padding:24px;max-height:70vh;overflow-y:auto}.section{border-radius:8px;background:#1b4ca114;padding:16px}.popup-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #ddd;font-weight:700;flex-shrink:0}.popup-footer{display:flex;justify-content:flex-end;gap:16px;padding:16px 24px;border-top:1px solid #ddd;background-color:#fff;flex-shrink:0;position:sticky;bottom:0}.section-container{overflow-y:auto;flex:1 1 auto}.competency-list{display:flex;flex-direction:row;gap:6px}.competency-text{color:#000;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal;padding:5px}.competency-text-behavioral{color:#654321;font-family:Lato;font-size:14px;font-style:normal;line-height:normal;font-weight:550}.competency-text-functional{color:#b01669;font-family:Lato;font-size:14px;font-style:normal;line-height:normal;font-weight:550}.competency-text-domain{color:#301934;font-family:Lato;font-size:14px;font-style:normal;line-height:normal;font-weight:550}.competency-sub-heading{color:#1b4ca1;font-family:Montserrat;font-size:16px;font-style:normal;font-weight:600;line-height:normal}.cursor-pointer{cursor:pointer}.btn-active{border-radius:var(--Radius-Full-Round, 9999999px);opacity:1;background:var(--Primary-KB-Primary-Light, #1B4CA1);color:var(--white-kb-white-100, #FFF);text-align:center;font-family:Lato;font-size:14px;font-style:normal;font-weight:700;line-height:normal;display:flex;height:32px;padding:0 16px;justify-content:center;align-items:center;gap:8px;border:none}.custom-textarea{color:#000;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal}.overlay-loader{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#ffffffbf;z-index:9999;display:flex;justify-content:center;align-items:center}.close .mat-icon{height:18px!important;width:18px!important}.edit .mat-icon{height:24px!important;width:24px!important;overflow:visible;vertical-align:middle}:host ::ng-deep .mat-select-arrow-wrapper{height:6px!important}::ng-deep .filter-section .mat-form-field-appearance-fill .mat-form-field-flex{padding:.5em .75em 0!important}.competency-grid{display:flex;flex-wrap:wrap;gap:12px}.competency-item{flex:0 0 calc(33.333% - 12px);box-sizing:border-box;background-color:#f5f5f5;padding:4px 10px;border-radius:6px;display:flex;justify-content:space-between;align-items:center}.snackbar-success{background-color:#4caf50!important;color:#fff!important;font-weight:500;font-size:14px;border-radius:4px}.enhanced-competency-section{display:flex;flex-direction:column;gap:24px;padding:24px;background:linear-gradient(135deg,#1b4ca105,#1b4ca10f);border-radius:12px;border:1px solid rgba(27,76,161,.15);box-shadow:0 2px 8px #1b4ca114}.competency-step{display:flex;flex-direction:column;gap:12px}.step-label{color:#1b4ca1;font-family:Lato;font-size:15px;font-weight:600;margin-bottom:8px;display:flex;align-items:center}.step-label:before{content:\"\";width:4px;height:16px;background:#1b4ca1;border-radius:2px;margin-right:8px}.competency-dropdown-container,.manual-input-container{width:100%;position:relative}.competency-dropdown{width:100%}.competency-dropdown ::ng-deep .mat-form-field-wrapper{padding:0;margin:0}.competency-dropdown ::ng-deep .mat-form-field-flex{padding:0 16px 0 20px;height:48px;align-items:center;transition:all .3s ease;display:flex;justify-content:space-between}.competency-dropdown ::ng-deep .mat-form-field-flex:hover{border-color:#1b4ca1}.competency-dropdown ::ng-deep .mat-form-field-outline,.competency-dropdown ::ng-deep .mat-form-field-outline-start,.competency-dropdown ::ng-deep .mat-form-field-outline-gap,.competency-dropdown ::ng-deep .mat-form-field-outline-end{display:none}.competency-dropdown ::ng-deep .mat-form-field-infix{padding:0;border:none;height:48px;display:flex;align-items:center;flex:1;width:auto}.competency-dropdown ::ng-deep .mat-select{height:100%;display:flex;align-items:center;font-family:Lato;font-size:14px;color:#333;width:100%;flex:1}.competency-dropdown ::ng-deep .mat-select-value{display:flex;align-items:center;height:100%;color:#333;font-weight:400;flex:1;width:100%;justify-content:flex-start}.competency-dropdown ::ng-deep .mat-select-placeholder{color:#00000080;width:100%;display:flex;align-items:center}.competency-dropdown ::ng-deep .mat-select-value-text{width:100%;display:flex;align-items:center;font-weight:400}.competency-dropdown ::ng-deep .mat-select-arrow-wrapper{height:20px;display:flex;align-items:center;margin-left:8px;flex-shrink:0}.competency-dropdown ::ng-deep .mat-select-arrow-wrapper .mat-select-arrow{color:#1b4ca1;border-top-color:#1b4ca1;margin:0}.competency-dropdown ::ng-deep .mat-form-field-label{display:none}.competency-dropdown ::ng-deep .mat-focused .mat-form-field-flex{border-color:#1b4ca1;box-shadow:0 0 0 3px #1b4ca11a}.competency-dropdown ::ng-deep .mat-select-min-line{line-height:normal}.competency-dropdown ::ng-deep .mat-form-field-appearance-outline .mat-form-field-infix{padding:0}.competency-dropdown ::ng-deep .mat-form-field-appearance-outline .mat-form-field-wrapper{margin:0;padding:0}.search-option{pointer-events:auto!important;opacity:1!important}.search-option ::ng-deep .mat-option-text{width:100%;padding:0}.search-field{width:100%;margin:0}.search-field ::ng-deep .mat-form-field-wrapper{padding:0;margin:0}.search-field ::ng-deep .mat-form-field-flex{height:36px;padding:0 12px;align-items:center}.search-field ::ng-deep .mat-form-field-infix{padding:0;border:none;height:36px;display:flex;align-items:center}.search-field ::ng-deep .mat-form-field-underline,.search-field ::ng-deep .mat-form-field-outline{display:none}.search-field ::ng-deep input{font-family:Lato;font-size:13px;color:#495057}.search-field ::ng-deep input::placeholder{color:#6c757d}::ng-deep .mat-select-panel{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000001f;border:1px solid #e0e0e0;max-height:320px;margin-top:4px}::ng-deep .mat-select-panel .mat-option{font-family:Lato;font-size:14px;padding:14px 16px;line-height:1.4;transition:all .2s ease;border-bottom:1px solid rgba(0,0,0,.05)}::ng-deep .mat-select-panel .mat-option:last-child{border-bottom:none}::ng-deep .mat-select-panel .mat-option:hover{background-color:#1b4ca10f;color:#1b4ca1}::ng-deep .mat-select-panel .mat-option.mat-selected{background-color:#1b4ca11a;color:#1b4ca1;font-weight:500;position:relative}::ng-deep .mat-select-panel .mat-option.mat-selected:after{content:\"\\2713\";position:absolute;right:16px;color:#1b4ca1;font-weight:700}::ng-deep .mat-select-panel .mat-option.search-option{padding:12px;background-color:#f8f9fa;border-bottom:2px solid #e9ecef;position:sticky;top:0;z-index:10}::ng-deep .mat-select-panel .mat-option.search-option:hover{background-color:#f8f9fa}.enhanced-competency-section ::ng-deep mat-select{border-radius:0!important;background-color:transparent!important}.enhanced-competency-section ::ng-deep mat-form-field .mat-form-field-underline{display:none!important}.enhanced-competency-section ::ng-deep .mat-select-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;min-height:auto}.enhanced-competency-section ::ng-deep .mat-form-field-suffix{margin:0;padding:0;display:flex;align-items:center}.manual-input{border-radius:25px;border:2px solid #e0e0e0;padding:12px 16px;width:100%;font-size:14px;font-family:Lato;background:#fff;height:48px;box-sizing:border-box;transition:all .3s ease;box-shadow:0 2px 4px #0000000d}.manual-input::placeholder{color:#00000080;font-family:Lato;font-size:14px}.manual-input:focus{outline:none;border-color:#1b4ca1;box-shadow:0 0 0 3px #1b4ca11a}.manual-input:hover{border-color:#1b4ca1;box-shadow:0 4px 8px #1b4ca11a}.add-button-section{display:flex;justify-content:flex-start;margin-top:20px;padding-top:20px;border-top:2px solid rgba(27,76,161,.1)}.add-competency-btn{border-radius:25px;padding:12px 24px;font-family:Lato;font-size:14px;font-weight:600;border:none;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #0000001a;min-width:140px}.add-competency-btn.btn-active{background:linear-gradient(135deg,#1b4ca1,#164080);color:#fff}.add-competency-btn.btn-active:hover{background:linear-gradient(135deg,#164080,#0f2f5f);box-shadow:0 4px 16px #1b4ca14d;transform:translateY(-1px)}.add-competency-btn.btn-active:active{transform:translateY(0);box-shadow:0 2px 8px #1b4ca133}.add-competency-btn.btn-disable{background:#e9ecef;color:#6c757d;cursor:not-allowed;opacity:.7;box-shadow:none;border:1px solid #ccc}:host ::ng-deep .mat-select-panel.search-panel{max-height:300px!important;overflow-y:auto!important;box-sizing:border-box}::ng-deep .search-panel .sticky-search-container{position:sticky;top:0;z-index:100;background:#fff;padding:8px;border-bottom:1px solid #eee}:host ::ng-deep .search-panel .search-input-wrapper{display:flex;gap:8px;align-items:center}:host ::ng-deep .search-panel .search-input{width:100%;height:32px;padding:6px 10px}:host ::ng-deep .search-panel .mat-option{padding:8px 16px!important}:host ::ng-deep .search-panel .mat-pseudo-checkbox{margin-right:8px}:host ::ng-deep .search-panel .no-data-option{padding:10px 16px;font-size:14px;color:#f44336}::ng-deep .search-panel .no-data-option .mat-pseudo-checkbox{display:none!important}.search-input-wrapper{position:relative;width:100%;display:flex;align-items:center}.search-input{width:100%;padding-right:40px;height:40px;line-height:40px;box-sizing:border-box}.clear-icon{position:absolute;right:10px;cursor:pointer;font-size:20px;color:#666;display:flex;align-items:center;height:100%}.clear-icon:hover{color:#000}:host ::ng-deep .search-panel .mat-option:first-child{margin-top:0}:host ::ng-deep .mat-notched-outline{border-radius:25px!important}:host ::ng-deep .mat-form-field-appearance-outline .mat-form-field-outline{border-radius:25px!important}:host ::ng-deep .mat-form-field-appearance-outline .mat-form-field-outline-start,:host ::ng-deep .mat-form-field-appearance-outline .mat-form-field-outline-end{border-width:1px!important;min-width:0!important}:host ::ng-deep .mat-form-field-appearance-outline .mat-form-field-outline{color:transparent!important}:host ::ng-deep .mat-form-field-appearance-outline.mat-focused .mat-form-field-outline-thick{color:transparent!important}:host ::ng-deep .mat-form-field-appearance-outline .mat-form-field-flex{border-radius:25px;height:30px;align-items:center;padding:0 16px;background:#fff}\n"], dependencies: [{ kind: "directive", type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.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: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "component", type: i7.MatLegacyFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i8.MatLegacyInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", exportAs: ["matInput"] }, { kind: "component", type: i9.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i10.MatLegacySelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "component", type: i11.MatLegacyOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i12.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }] }); }
685
+ }
686
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EditCbpPlanComponent, decorators: [{
687
+ type: Component,
688
+ args: [{ selector: 'app-edit-cbp-plan', template: "<div class=\"view-cbp-plan\" #dialogContent>\n <div class=\"popup-container\">\n <div class=\"popup-header\">\n <div>\n <div class=\"heading\">Edit Role Mapping</div>\n </div>\n <div class=\"cursor-pointer\" (click)=\"closeDialog()\">\n <mat-icon>close</mat-icon>\n </div>\n </div>\n <div class=\"section-container\" [formGroup]=\"cbpForm\">\n\n <!-- <div class=\"section-header mt-4\">\n <input type=\"text\" formControlName=\"designation_name\" [value]=\"planData?.designation_name\"\n style=\"border-radius: 25px; border: 1px solid #ccc; padding: 8px 12px; width: 100%;font-size: 14px;font-family: 'Lato';\">\n\n\n </div> -->\n\n <mat-form-field appearance=\"outline\" class=\"mt-4 margin-top-s w-full required-select\" style=\"border-radius: 25px; border: 1px solid #ccc; padding: 8px 12px; width: 100%;font-size: 14px;font-family: 'Lato';\">\n <mat-select #position formControlName=\"designation_name\" placeholder=\"Select designation\"\n (closed)=\"onDesignationDropdownClosed()\" panelClass=\"search-panel\"\n (openedChange)=\"setupScrollListener($event)\">\n\n <!-- Sticky search input container -->\n <div class=\"sticky-search-container\" (click)=\"$event.stopPropagation()\">\n <div class=\"search-input-wrapper\">\n <input type=\"text\" placeholder=\"Search designation\" style=\"width:100%\"\n formControlName=\"searchDesignation\" class=\"search-input\"\n (keydown)=\"$event.stopPropagation()\"\n (keydown.enter)=\"$event.preventDefault(); $event.stopPropagation()\"\n (keyup)=\"designationSearch($event)\" autocomplete=\"off\">\n <div *ngIf=\"searchDesignationControl?.value\" type=\"button\" class=\"clear-icon\"\n (click)=\"searchDesignationControl.setValue('')\">\n <mat-icon>close</mat-icon>\n </div>\n </div>\n </div>\n <!-- Options list -->\n <mat-option [value]=\"designation?.name\" *ngFor=\"let designation of masterData?.designation\">\n {{designation?.name}}\n </mat-option>\n <!-- Loading indicator -->\n <div *ngIf=\"isLoadingMoreDesignations\" class=\"loading-indicator\">\n Load More...\n </div>\n <!-- No results message -->\n <mat-option *ngIf=\"(masterData?.designation)?.length === 0\" disabled class=\"no-data-option\">\n\n Designation Not Found.\n\n </mat-option>\n </mat-select>\n <!-- <mat-error class=\"text-xs\"\n *ngIf=\"designationForm?.get('designation_name')?.touched && designationForm?.get('designation_name')?.invalid\">\n Please select at least one designation.\n </mat-error> -->\n </mat-form-field>\n\n <div class=\"competency-container mt-4\">\n <div class=\"outside-layer-total\">\n <div class=\"inside-layer\">\n Total Competencies\n </div>\n <div class=\"count\">\n {{competenciesCount?.total}}\n </div>\n </div>\n <div class=\"outside-layer-behavioral\">\n <div class=\"inside-layer\">\n Behavioral Competencies\n </div>\n <div class=\"count\">\n {{competenciesCount?.behavioral}}\n </div>\n </div>\n <div class=\"outside-layer-functional\">\n <div class=\"inside-layer\">\n Functional Competencies\n </div>\n <div class=\"count\">\n {{competenciesCount?.functional}}\n </div>\n </div>\n <div class=\"outside-layer-domain\">\n <div class=\"inside-layer\">\n Domain Competencies\n </div>\n <div class=\"count\">\n {{competenciesCount?.domain}}\n </div>\n </div>\n </div>\n <div class=\"mt-4 section\">\n <div class=\"sub-heading\">\n <p>Wing/Division</p>\n </div>\n <div class=\"mt-4\">\n <input type=\"text\" formControlName=\"wing_division_section\" [value]=\"planData?.wing_division_section\"\n style=\"border-radius: 25px; border: 1px solid #ccc; padding: 8px 12px; width:100%;font-size: 14px;font-family: 'Lato';\">\n </div>\n </div>\n <div class=\"mt-2 section\">\n <div class=\"sub-heading\">\n <p>Roles & Responsibilities</p>\n </div>\n <div class=\"mt-4 additional-details\">\n <textarea class=\"custom-textarea\" formControlName=\"role_responsibilities_text\" rows=\"5\"\n placeholder=\"Roles & Responsibilities\"\n [value]=\"planData?.role_responsibilities?.join('\\n')\"></textarea>\n </div>\n </div>\n <div class=\"mt-2 section\">\n <div class=\"sub-heading\">\n <p>Activities</p>\n </div>\n <div class=\"mt-4 additional-details\">\n <textarea class=\"custom-textarea\" formControlName=\"activities_text\" rows=\"5\"\n placeholder=\"Activities\" [value]=\"planData?.activities?.join('\\n')\"></textarea>\n </div>\n </div>\n <div class=\"mt-2 section\">\n <div class=\"sub-heading\">\n <p>Competency</p>\n </div>\n <div class=\"enhanced-competency-section mt-2\">\n <!-- Step 1: Select Competency Type -->\n <div class=\"competency-step\">\n <label class=\"step-label\">1. Select Core Competency Type</label>\n <div class=\"competency-dropdown-container\">\n <mat-form-field appearance=\"outline\" class=\"competency-dropdown\">\n <mat-select formControlName=\"competencyType\" placeholder=\"Select Competency Type\"\n (selectionChange)=\"onCompetencyTypeChange($event.value)\">\n <mat-option value=\"Behavioral\">Behavioral</mat-option>\n <mat-option value=\"Functional\">Functional</mat-option>\n <mat-option value=\"Domain\">Domain</mat-option>\n </mat-select>\n </mat-form-field>\n </div>\n </div>\n\n <!-- Step 2: Theme Selection (Behavioral/Functional from JSON, Domain manual) -->\n <div class=\"competency-step\" *ngIf=\"selectedCompetencyType\">\n <label class=\"step-label\">2. Select/Enter Theme</label>\n\n <!-- For Behavioral and Functional: Searchable Dropdown from JSON -->\n <div class=\"competency-dropdown-container\"\n *ngIf=\"selectedCompetencyType === 'Behavioral' || selectedCompetencyType === 'Functional'\">\n <mat-form-field appearance=\"outline\" class=\"competency-dropdown\">\n <mat-select formControlName=\"competencyTheme\" placeholder=\"Search and select theme\"\n (selectionChange)=\"onThemeChange($event.value)\">\n <!-- Search input inside dropdown -->\n <mat-option class=\"search-option\" disabled>\n <mat-form-field appearance=\"outline\" class=\"search-field\">\n <input matInput placeholder=\"Search themes...\" formControlName=\"themeSearch\"\n (input)=\"filterThemes($event.target.value)\"\n (click)=\"$event.stopPropagation()\" (keydown)=\"$event.stopPropagation()\">\n </mat-form-field>\n </mat-option>\n\n <!-- Theme options -->\n <mat-option *ngFor=\"let theme of filteredThemes\" [value]=\"theme.name\">\n {{theme.name}}\n </mat-option>\n\n <!-- No results message -->\n <mat-option *ngIf=\"filteredThemes.length === 0 && themeSearchText\" disabled>\n No themes found matching \"{{themeSearchText}}\"\n </mat-option>\n </mat-select>\n </mat-form-field>\n </div>\n\n <!-- For Domain: Manual input -->\n <div class=\"manual-input-container\" *ngIf=\"selectedCompetencyType === 'Domain'\">\n <input type=\"text\" formControlName=\"manualThemeInput\" placeholder=\"Enter Theme manually\"\n class=\"manual-input\" />\n </div>\n </div>\n\n <!-- Step 3: Sub-theme Selection -->\n <div class=\"competency-step\" *ngIf=\"selectedTheme || (selectedCompetencyType === 'Domain')\">\n <label class=\"step-label\">3. Select/Enter Sub-theme</label>\n\n <!-- For Behavioral and Functional: Searchable Dropdown based on selected theme -->\n <div class=\"competency-dropdown-container\"\n *ngIf=\"selectedCompetencyType === 'Behavioral' || selectedCompetencyType === 'Functional'\">\n <mat-form-field appearance=\"outline\" class=\"competency-dropdown\">\n <mat-select formControlName=\"competencySubTheme\"\n placeholder=\"Search and select sub-theme\"\n (selectionChange)=\"onSubThemeChange($event.value)\">\n <!-- Search input inside dropdown -->\n <mat-option class=\"search-option\" disabled>\n <mat-form-field appearance=\"outline\" class=\"search-field\">\n <input matInput placeholder=\"Search sub-themes...\"\n formControlName=\"subThemeSearch\"\n (input)=\"filterSubThemes($event.target.value)\"\n (click)=\"$event.stopPropagation()\" (keydown)=\"$event.stopPropagation()\">\n </mat-form-field>\n </mat-option>\n\n <!-- Sub-theme options -->\n <mat-option *ngFor=\"let subTheme of filteredSubThemes\" [value]=\"subTheme\">\n {{subTheme}}\n </mat-option>\n\n <!-- No results message -->\n <mat-option *ngIf=\"filteredSubThemes.length === 0 && subThemeSearchText\" disabled>\n No sub-themes found matching \"{{subThemeSearchText}}\"\n </mat-option>\n </mat-select>\n </mat-form-field>\n </div>\n\n <!-- For Domain: Manual input -->\n <div class=\"manual-input-container\" *ngIf=\"selectedCompetencyType === 'Domain'\">\n <input type=\"text\" formControlName=\"manualSubThemeInput\"\n placeholder=\"Enter Sub-theme manually\" class=\"manual-input\" />\n </div>\n </div>\n\n <!-- Add Button -->\n <div class=\"add-button-section\" *ngIf=\"selectedCompetencyType \">\n <button type=\"button\" *ngIf=\"!editDomainCompetencyFlag\" class=\"add-competency-btn\"\n [disabled]=\"!canAddCompetency()\"\n [ngClass]=\"canAddCompetency() ? 'btn-active' : 'btn-disable'\" (click)=\"addCompetency()\">\n Add Competency\n </button>\n <button type=\"button\" *ngIf=\"editDomainCompetencyFlag\" class=\"add-competency-btn btn-active\"\n (click)=\"updateCompetency()\">\n Update Competency\n </button>\n <button type=\"button\" *ngIf=\"editDomainCompetencyFlag\" class=\"add-competency-btn btn-active\"\n style=\"margin-left: 5px;\" (click)=\"cancelUpdate()\">\n Cancel </button>\n </div>\n </div>\n <div class=\"mt-4\">\n <div class=\"competency-sub-heading mt-2\" *ngIf=\"getCompetenciesByType('Behavioral')?.length\">\n Behavioral Competencies\n </div>\n\n <div class=\"competency-grid mt-2\">\n <div class=\"competency-item behavioural-pill\"\n *ngFor=\"let comp of getCompetenciesByType('Behavioral')\">\n <span class=\"competency-text-behavioral\">\n {{ comp.theme }} - {{ comp.sub_theme }}\n </span>\n <span class=\"cursor-pointer close\" (click)=\"deleteCompetency(comp)\">\n <mat-icon>close</mat-icon>\n </span>\n </div>\n </div>\n </div>\n <div class=\"mt-4\">\n <div class=\"competency-sub-heading mt-2\" *ngIf=\"getCompetenciesByType('Functional')?.length\">\n Functional Competencies</div>\n <div class=\"competency-grid mt-2\">\n <div class=\"competency-item functional-pill\"\n *ngFor=\"let comp of getCompetenciesByType('Functional')\">\n <span class=\"competency-text-functional\">\n {{ comp.theme }} - {{ comp.sub_theme }}\n </span>\n <span class=\"cursor-pointer close\" (click)=\"deleteCompetency(comp)\">\n <mat-icon>close</mat-icon>\n </span>\n </div>\n </div>\n </div>\n <div class=\"mt-4\">\n <div class=\"competency-sub-heading mt-2\">Domain Competencies</div>\n <div class=\"competency-grid mt-2\">\n <div class=\"competency-item domain-pill\" *ngFor=\"let comp of getCompetenciesByType('Domain')\">\n <span class=\"competency-text-domain\">\n {{ comp.theme }} - {{ comp.sub_theme }}\n </span>\n <span class=\"cursor-pointer edit\" (click)=\"editCompetency(comp)\">\n <mat-icon>edit</mat-icon>\n </span>\n <span class=\"cursor-pointer close\" (click)=\"deleteCompetency(comp)\">\n <mat-icon>close</mat-icon>\n </span>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"popup-footer\">\n <div>\n <input class=\"btn-active\" type=\"button\" value=\"Cancel\" (click)=\"cancelForm()\" />\n </div>\n <div>\n <input class=\"btn-active\" type=\"button\" value=\"Save\" (click)=\"saveRoleMapping()\" />\n </div>\n </div>\n </div>\n</div>\n\n<div class=\"overlay-loader\" *ngIf=\"loading\">\n <mat-spinner diameter=\"50\"></mat-spinner>\n</div>", styles: ["@charset \"UTF-8\";.container{margin:10px auto}.sub-heading p{color:#000;font-family:Montserrat;font-size:16px;font-style:normal;font-weight:600;line-height:normal}.radio-label{color:#000;font-family:Lato;font-size:16px;font-style:normal;font-weight:400;line-height:normal}.radio-btn-group{display:flex;width:32px;height:32px;padding:2px;gap:10px}.label{color:var(--Body-Text-Body-Color, #212529);font-family:Lato;font-size:14px;font-style:normal;font-weight:700;line-height:150%}::ng-deep .legacy-form-field{background-color:#fff!important;border-radius:25px!important;padding-left:12px;padding-right:12px;height:42px;width:100%}::ng-deep mat-select{border-radius:25px!important;background-color:#fff!important}::ng-deep .mat-select-panel{background-color:#fff!important}::ng-deep .mat-select-panel .mat-option{border-radius:0!important}::ng-deep mat-form-field .mat-form-field-underline{display:none!important}::ng-deep mat-select .mat-select-placeholder{color:#0006;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal}::ng-deep mat-select .mat-select-value-text{color:#000;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal;line-height:normal!important;padding-top:0!important;padding-bottom:0!important}::ng-deep mat-select .mat-select-value{display:flex!important;align-items:center!important;height:100%!important}.additional-details textarea{display:flex;padding:16px 16px 0;flex-direction:column;align-items:flex-start;gap:10px;flex:1 0 0;align-self:stretch;width:100%;color:#000;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal;resize:none}.section-header{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.btn-disable{border-radius:var(--Radius-Full-Round, 9999999px);opacity:.4;background:var(--Primary-KB-Primary-Light, #1B4CA1);color:var(--white-kb-white-100, #FFF);text-align:center;font-family:Lato;font-size:14px;font-style:normal;font-weight:700;line-height:normal;display:flex;height:32px;padding:0 16px;justify-content:center;align-items:center;gap:8px;border:none}.btn-group{display:flex;flex-direction:row;justify-content:space-between}.pl-2{padding-left:5px}.search-filter-section{display:flex;flex-direction:row;gap:10px}.legacy-search-filter{display:none}.search .rsearch{position:relative}.search .search-icon{position:absolute;top:10px;font-size:20px;left:10px}.search .sinput{border-radius:4px;border:1px solid #d5d0d0;padding:15px 36px;font:400 14px Lato}.select-map-route-container{display:flex;flex-direction:row}.selected-mapping-route p{color:#1b4ca1;font-family:Lato;font-size:20px;font-style:normal;font-weight:400;line-height:normal;text-decoration-line:underline;text-decoration-style:solid;-webkit-text-decoration-skip:ink;text-decoration-skip-ink:auto;text-decoration-thickness:auto;text-underline-offset:auto;text-underline-position:from-font}.edit-plan{display:flex;padding:4px;justify-content:center;align-items:center;gap:8px;border-radius:4px;background:#1b4ca129;color:#1b4ca1;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal;margin-left:10px}.search-container{display:flex;flex-direction:row}.course-container{display:flex;width:100%;padding:16px;flex-direction:column;align-items:flex-start;gap:24px;grid-row:2/span 1;grid-column:1/span 1;border-radius:12px;border:1px solid var(--borders-black-border-16-black, rgba(0, 0, 0, .16));background:#fff}.course-header{display:flex;flex-direction:row;justify-content:space-between;width:100%}.course-pill{display:flex;height:24px;padding:8px;align-items:center;gap:4px;border-radius:16px;border:1px solid var(--borders-border-fill-focussed-4-light-100, #EF951E);background:#fefaf4}.ai-recommened-pill{display:flex;padding:4px 8px;align-items:center;gap:8px;border-radius:var(--Radius-4, 4px);border:1px solid #1B4CA1;background:#1b4ca129}.igot-platform-pill{display:flex;padding:4px 8px;align-items:center;gap:8px;border-radius:var(--Radius-4, 4px);border:1px solid #EF951E;background:#ef951e29}.course-title{color:var(--Primary-KB-Primary-Light, #1B4CA1);font-family:Montserrat;font-size:20px;font-style:normal;font-weight:600;line-height:30px}.course-desc{color:#0009;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal}.relevancy,.competencies-matched{color:var(--accessbility-shades-with-opacity-kb-greys-black-60, rgba(0, 0, 0, .6));font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal;align-items:center}.percentage{color:#1d8923;font-family:Lato;font-size:14px;font-style:normal;font-weight:800;line-height:normal}.relevancy-container,.competencies-matched-container{display:flex;flex-direction:row;align-items:center}.dash{padding:0 5px}::ng-deep .mat-radio-checked .mat-radio-inner-circle{background:#1b4ca1!important}.course-list-container{display:flex;flex-wrap:wrap;gap:16px}.course-list-item{flex:0 0 48%;box-sizing:border-box;border:1px solid #ccc;padding:16px;background-color:#fff;border-radius:8px}.checked-course-container{display:flex}.ml-2{margin-left:8px}::ng-deep .mat-checkbox-checked .mat-checkbox-background{background:#1b4ca1!important}.ai-recommened-pill-text,.igot-platform-pill-text{color:#1b4ca1;font-family:Lato;font-size:12px;font-style:normal;font-weight:700;line-height:normal}.course-pill-text{color:var(--accessbility-shades-without-opacity-kb-greys-black-87, #212121);text-align:center;font-family:Poppins;font-size:12px;font-style:normal;font-weight:400;line-height:normal}.ai-loader-icon img,.igot-platform-icon img{width:15.714px;height:15.714px;flex-shrink:0}.competency-container{display:flex;justify-content:space-between;flex-direction:row}.outside-layer-total{display:flex;padding:4px 12px;justify-content:center;align-items:center;gap:16px;border-radius:12px;border-left:2px solid #1B4CA1;border-right:2px solid #1B4CA1;background:#edf1f8;margin:0 10px}.outside-layer-functional{display:flex;padding:4px 12px;justify-content:center;align-items:center;gap:16px;border-radius:12px;border-left:2px solid #E24577;border-right:2px solid #E24577;background:#f8d2de;margin:0 10px}.outside-layer-domain{display:flex;padding:4px 12px;justify-content:center;align-items:center;gap:16px;border-radius:12px;border-left:2px solid #7B47A4;border-right:2px solid #7B47A4;background:#dfd3e9;margin:0 10px}.outside-layer-behavioral{display:flex;padding:4px 12px;justify-content:center;align-items:center;gap:16px;border-radius:12px;border-left:2px solid #F8B861;border-right:2px solid #F8B861;background:#fde8cc;margin:0 10px}.inside-layer{color:#1b4ca1;font-family:Lato;font-size:18px;font-style:normal;font-weight:400;line-height:normal}.count{color:#1b4ca1;font-family:Montserrat;font-size:24px;font-style:normal;font-weight:600;line-height:normal}.suggest-courses-header{display:flex;flex-direction:row;justify-content:space-between}.suggest-course-control{display:flex;flex-direction:row}.course-card-container{width:172px;border-radius:3.307px;border:.827px solid var(--borders-border-8-black, rgba(0, 0, 0, .08));background-color:#fff}.highlight-ai{font-family:Montserrat;font-size:24px;font-style:normal;font-weight:600;line-height:normal;background:linear-gradient(90deg,#3b27ff,#2de3d6);background-clip:text;-webkit-background-clip:text;color:transparent;-webkit-text-fill-color:transparent;display:inline-block}.ai-loader-icon-medium img{width:40px;height:40px;flex-shrink:0}.heading{color:#000;font-family:Montserrat;font-size: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:2px 8px;justify-content:center;align-items:center;gap:10px;border-radius:8px;border:1px solid #F8B861;background:linear-gradient(0deg,#f8b86152 0% 100%),#fff;margin:5px 0}.functional-pill{display:flex;padding:2px 8px;justify-content:center;align-items:center;gap:10px;border-radius:8px;border:1px solid #E24577;background:linear-gradient(0deg,#e245773d 0% 100%),#fff;margin:5px 0}.domain-pill{display:flex;padding:2px 8px;justify-content:center;align-items:center;gap:10px;border-radius:8px;border:1px solid #7B47A4;background:linear-gradient(0deg,#7b47a43d 0% 100%),#fff;margin:5px 0}.popup-header{display:flex;flex-direction:row;justify-content:space-between}.popup-footer{display:flex;flex-direction:row;justify-content:end}.view-cbp-plan{margin:10px;padding:10px}.view-cbp-plan-popup{padding:24px;max-height:70vh;overflow-y:auto}.section{border-radius:8px;background:#1b4ca114;padding:16px}.popup-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #ddd;font-weight:700;flex-shrink:0}.popup-footer{display:flex;justify-content:flex-end;gap:16px;padding:16px 24px;border-top:1px solid #ddd;background-color:#fff;flex-shrink:0;position:sticky;bottom:0}.section-container{overflow-y:auto;flex:1 1 auto}.competency-list{display:flex;flex-direction:row;gap:6px}.competency-text{color:#000;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal;padding:5px}.competency-text-behavioral{color:#654321;font-family:Lato;font-size:14px;font-style:normal;line-height:normal;font-weight:550}.competency-text-functional{color:#b01669;font-family:Lato;font-size:14px;font-style:normal;line-height:normal;font-weight:550}.competency-text-domain{color:#301934;font-family:Lato;font-size:14px;font-style:normal;line-height:normal;font-weight:550}.competency-sub-heading{color:#1b4ca1;font-family:Montserrat;font-size:16px;font-style:normal;font-weight:600;line-height:normal}.cursor-pointer{cursor:pointer}.btn-active{border-radius:var(--Radius-Full-Round, 9999999px);opacity:1;background:var(--Primary-KB-Primary-Light, #1B4CA1);color:var(--white-kb-white-100, #FFF);text-align:center;font-family:Lato;font-size:14px;font-style:normal;font-weight:700;line-height:normal;display:flex;height:32px;padding:0 16px;justify-content:center;align-items:center;gap:8px;border:none}.custom-textarea{color:#000;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal}.overlay-loader{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#ffffffbf;z-index:9999;display:flex;justify-content:center;align-items:center}.close .mat-icon{height:18px!important;width:18px!important}.edit .mat-icon{height:24px!important;width:24px!important;overflow:visible;vertical-align:middle}:host ::ng-deep .mat-select-arrow-wrapper{height:6px!important}::ng-deep .filter-section .mat-form-field-appearance-fill .mat-form-field-flex{padding:.5em .75em 0!important}.competency-grid{display:flex;flex-wrap:wrap;gap:12px}.competency-item{flex:0 0 calc(33.333% - 12px);box-sizing:border-box;background-color:#f5f5f5;padding:4px 10px;border-radius:6px;display:flex;justify-content:space-between;align-items:center}.snackbar-success{background-color:#4caf50!important;color:#fff!important;font-weight:500;font-size:14px;border-radius:4px}.enhanced-competency-section{display:flex;flex-direction:column;gap:24px;padding:24px;background:linear-gradient(135deg,#1b4ca105,#1b4ca10f);border-radius:12px;border:1px solid rgba(27,76,161,.15);box-shadow:0 2px 8px #1b4ca114}.competency-step{display:flex;flex-direction:column;gap:12px}.step-label{color:#1b4ca1;font-family:Lato;font-size:15px;font-weight:600;margin-bottom:8px;display:flex;align-items:center}.step-label:before{content:\"\";width:4px;height:16px;background:#1b4ca1;border-radius:2px;margin-right:8px}.competency-dropdown-container,.manual-input-container{width:100%;position:relative}.competency-dropdown{width:100%}.competency-dropdown ::ng-deep .mat-form-field-wrapper{padding:0;margin:0}.competency-dropdown ::ng-deep .mat-form-field-flex{padding:0 16px 0 20px;height:48px;align-items:center;transition:all .3s ease;display:flex;justify-content:space-between}.competency-dropdown ::ng-deep .mat-form-field-flex:hover{border-color:#1b4ca1}.competency-dropdown ::ng-deep .mat-form-field-outline,.competency-dropdown ::ng-deep .mat-form-field-outline-start,.competency-dropdown ::ng-deep .mat-form-field-outline-gap,.competency-dropdown ::ng-deep .mat-form-field-outline-end{display:none}.competency-dropdown ::ng-deep .mat-form-field-infix{padding:0;border:none;height:48px;display:flex;align-items:center;flex:1;width:auto}.competency-dropdown ::ng-deep .mat-select{height:100%;display:flex;align-items:center;font-family:Lato;font-size:14px;color:#333;width:100%;flex:1}.competency-dropdown ::ng-deep .mat-select-value{display:flex;align-items:center;height:100%;color:#333;font-weight:400;flex:1;width:100%;justify-content:flex-start}.competency-dropdown ::ng-deep .mat-select-placeholder{color:#00000080;width:100%;display:flex;align-items:center}.competency-dropdown ::ng-deep .mat-select-value-text{width:100%;display:flex;align-items:center;font-weight:400}.competency-dropdown ::ng-deep .mat-select-arrow-wrapper{height:20px;display:flex;align-items:center;margin-left:8px;flex-shrink:0}.competency-dropdown ::ng-deep .mat-select-arrow-wrapper .mat-select-arrow{color:#1b4ca1;border-top-color:#1b4ca1;margin:0}.competency-dropdown ::ng-deep .mat-form-field-label{display:none}.competency-dropdown ::ng-deep .mat-focused .mat-form-field-flex{border-color:#1b4ca1;box-shadow:0 0 0 3px #1b4ca11a}.competency-dropdown ::ng-deep .mat-select-min-line{line-height:normal}.competency-dropdown ::ng-deep .mat-form-field-appearance-outline .mat-form-field-infix{padding:0}.competency-dropdown ::ng-deep .mat-form-field-appearance-outline .mat-form-field-wrapper{margin:0;padding:0}.search-option{pointer-events:auto!important;opacity:1!important}.search-option ::ng-deep .mat-option-text{width:100%;padding:0}.search-field{width:100%;margin:0}.search-field ::ng-deep .mat-form-field-wrapper{padding:0;margin:0}.search-field ::ng-deep .mat-form-field-flex{height:36px;padding:0 12px;align-items:center}.search-field ::ng-deep .mat-form-field-infix{padding:0;border:none;height:36px;display:flex;align-items:center}.search-field ::ng-deep .mat-form-field-underline,.search-field ::ng-deep .mat-form-field-outline{display:none}.search-field ::ng-deep input{font-family:Lato;font-size:13px;color:#495057}.search-field ::ng-deep input::placeholder{color:#6c757d}::ng-deep .mat-select-panel{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000001f;border:1px solid #e0e0e0;max-height:320px;margin-top:4px}::ng-deep .mat-select-panel .mat-option{font-family:Lato;font-size:14px;padding:14px 16px;line-height:1.4;transition:all .2s ease;border-bottom:1px solid rgba(0,0,0,.05)}::ng-deep .mat-select-panel .mat-option:last-child{border-bottom:none}::ng-deep .mat-select-panel .mat-option:hover{background-color:#1b4ca10f;color:#1b4ca1}::ng-deep .mat-select-panel .mat-option.mat-selected{background-color:#1b4ca11a;color:#1b4ca1;font-weight:500;position:relative}::ng-deep .mat-select-panel .mat-option.mat-selected:after{content:\"\\2713\";position:absolute;right:16px;color:#1b4ca1;font-weight:700}::ng-deep .mat-select-panel .mat-option.search-option{padding:12px;background-color:#f8f9fa;border-bottom:2px solid #e9ecef;position:sticky;top:0;z-index:10}::ng-deep .mat-select-panel .mat-option.search-option:hover{background-color:#f8f9fa}.enhanced-competency-section ::ng-deep mat-select{border-radius:0!important;background-color:transparent!important}.enhanced-competency-section ::ng-deep mat-form-field .mat-form-field-underline{display:none!important}.enhanced-competency-section ::ng-deep .mat-select-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;min-height:auto}.enhanced-competency-section ::ng-deep .mat-form-field-suffix{margin:0;padding:0;display:flex;align-items:center}.manual-input{border-radius:25px;border:2px solid #e0e0e0;padding:12px 16px;width:100%;font-size:14px;font-family:Lato;background:#fff;height:48px;box-sizing:border-box;transition:all .3s ease;box-shadow:0 2px 4px #0000000d}.manual-input::placeholder{color:#00000080;font-family:Lato;font-size:14px}.manual-input:focus{outline:none;border-color:#1b4ca1;box-shadow:0 0 0 3px #1b4ca11a}.manual-input:hover{border-color:#1b4ca1;box-shadow:0 4px 8px #1b4ca11a}.add-button-section{display:flex;justify-content:flex-start;margin-top:20px;padding-top:20px;border-top:2px solid rgba(27,76,161,.1)}.add-competency-btn{border-radius:25px;padding:12px 24px;font-family:Lato;font-size:14px;font-weight:600;border:none;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #0000001a;min-width:140px}.add-competency-btn.btn-active{background:linear-gradient(135deg,#1b4ca1,#164080);color:#fff}.add-competency-btn.btn-active:hover{background:linear-gradient(135deg,#164080,#0f2f5f);box-shadow:0 4px 16px #1b4ca14d;transform:translateY(-1px)}.add-competency-btn.btn-active:active{transform:translateY(0);box-shadow:0 2px 8px #1b4ca133}.add-competency-btn.btn-disable{background:#e9ecef;color:#6c757d;cursor:not-allowed;opacity:.7;box-shadow:none;border:1px solid #ccc}:host ::ng-deep .mat-select-panel.search-panel{max-height:300px!important;overflow-y:auto!important;box-sizing:border-box}::ng-deep .search-panel .sticky-search-container{position:sticky;top:0;z-index:100;background:#fff;padding:8px;border-bottom:1px solid #eee}:host ::ng-deep .search-panel .search-input-wrapper{display:flex;gap:8px;align-items:center}:host ::ng-deep .search-panel .search-input{width:100%;height:32px;padding:6px 10px}:host ::ng-deep .search-panel .mat-option{padding:8px 16px!important}:host ::ng-deep .search-panel .mat-pseudo-checkbox{margin-right:8px}:host ::ng-deep .search-panel .no-data-option{padding:10px 16px;font-size:14px;color:#f44336}::ng-deep .search-panel .no-data-option .mat-pseudo-checkbox{display:none!important}.search-input-wrapper{position:relative;width:100%;display:flex;align-items:center}.search-input{width:100%;padding-right:40px;height:40px;line-height:40px;box-sizing:border-box}.clear-icon{position:absolute;right:10px;cursor:pointer;font-size:20px;color:#666;display:flex;align-items:center;height:100%}.clear-icon:hover{color:#000}:host ::ng-deep .search-panel .mat-option:first-child{margin-top:0}:host ::ng-deep .mat-notched-outline{border-radius:25px!important}:host ::ng-deep .mat-form-field-appearance-outline .mat-form-field-outline{border-radius:25px!important}:host ::ng-deep .mat-form-field-appearance-outline .mat-form-field-outline-start,:host ::ng-deep .mat-form-field-appearance-outline .mat-form-field-outline-end{border-width:1px!important;min-width:0!important}:host ::ng-deep .mat-form-field-appearance-outline .mat-form-field-outline{color:transparent!important}:host ::ng-deep .mat-form-field-appearance-outline.mat-focused .mat-form-field-outline-thick{color:transparent!important}:host ::ng-deep .mat-form-field-appearance-outline .mat-form-field-flex{border-radius:25px;height:30px;align-items:center;padding:0 16px;background:#fff}\n"] }]
689
+ }], ctorParameters: function () { return [{ type: i1.MatDialogRef }, { type: undefined, decorators: [{
690
+ type: Inject,
691
+ args: [MAT_DIALOG_DATA]
692
+ }] }, { type: i2.FormBuilder }, { type: i0.ChangeDetectorRef }, { type: i3.SharedService }, { type: i4.MatSnackBar }, { type: i5.HttpClient }]; }, propDecorators: { dialogContent: [{
693
+ type: ViewChild,
694
+ args: ['dialogContent']
695
+ }], designationRef: [{
696
+ type: ViewChild,
697
+ args: ['designation', { read: ElementRef }]
698
+ }] } });
699
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"edit-cbp-plan.component.js","sourceRoot":"","sources":["../../../../../../../library/sunbird-cb/cbp-ai/src/lib/components/edit-cbp-plan/edit-cbp-plan.component.ts","../../../../../../../library/sunbird-cb/cbp-ai/src/lib/components/edit-cbp-plan/edit-cbp-plan.component.html"],"names":[],"mappings":"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","sourcesContent":["import { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\nimport { ChangeDetectorRef, Component, ElementRef, Inject, OnInit, ViewChild } from '@angular/core';\nimport { FormBuilder, FormGroup, FormArray, Validators, FormControl } from '@angular/forms';\nimport { MatSnackBar } from '@angular/material/snack-bar';\nimport { HttpClient } from '@angular/common/http';\nimport { finalize } from 'rxjs/operators';\nimport  _ from 'lodash'\nimport { SharedService } from '../../modules/shared/services/shared.service';\n@Component({\n  selector: 'app-edit-cbp-plan',\n  templateUrl: './edit-cbp-plan.component.html',\n  styleUrls: ['./edit-cbp-plan.component.scss']\n})\nexport class EditCbpPlanComponent implements OnInit{\n\n  selectedValue = ''\n  searchText = ''\n  planData:any\n  competenciesCount = {total:0, behavioral:0, functional:0, domain:0}\n  cbpForm: FormGroup;\n  loading= false\n  \n  // Enhanced competency selection properties\n  competenciesData: any[] = [];\n  availableThemes: any[] = [];\n  availableSubThemes: any[] = [];\n  filteredThemes: any[] = [];\n  filteredSubThemes: string[] = [];\n  selectedCompetencyType = '';\n  selectedTheme = '';\n  selectedSubTheme = '';\n  manualTheme = '';\n  manualSubTheme = '';\n  themeSearchText = '';\n  subThemeSearchText = '';\n  editDomainCompetencyFlag = false\n  editCompetencyIndex = -1\n  originalCompetencyValueArr:any = []\n  desigantionFilterEnable = false\n  isLoadingMoreDesignations = false;\n  designationOffset = 0\n  odcsDesignationCount = 0\n  defaultSearchDesignationCount = 0\n  designationListLoadCount = 50\n  designationDefaultLoadCount = 50\n  noMoreLegacyDesignations = false\n  designationSearchText = ''\n  designationInitInProgress = false\n  scrollListenerAttached = false\n  @ViewChild('dialogContent') dialogContent!: ElementRef;\n  @ViewChild('designation', { read: ElementRef }) designationRef?: ElementRef\n  masterData: any = {}\n  constructor(\n    public dialogRef: MatDialogRef<EditCbpPlanComponent>,\n    @Inject(MAT_DIALOG_DATA) public data: any,\n    private fb: FormBuilder,\n    private cdRef: ChangeDetectorRef,\n    private sharedService:SharedService,\n    private snackBar: MatSnackBar,\n    private http: HttpClient\n  ) {\n    this.planData = data\n    console.log('Received data:', data);\n    // this.planData.competencies.map((competencies:any)=>{\n    //   this.competenciesCount['total'] = this.competenciesCount['total'] + 1 \n    //   if(competencies.type === 'Behavioral') {\n    //     this.competenciesCount['behavioral'] = this.competenciesCount['behavioral'] +1\n    //   }\n    //   if(competencies.type === 'Functional') {\n    //     this.competenciesCount['functional'] = this.competenciesCount['functional'] +1\n    //   }\n    //   if(competencies.type === 'Domain') {\n    //     this.competenciesCount['domain'] = this.competenciesCount['domain'] +1\n    //   }\n    // })\n  }\n\n\n  ngOnInit() {\n    this.loadCompetenciesData();\n    this.initializeForm();\n    this.updateCompetencyCounts()\n  }\n\n  loadCompetenciesData() {\n    this.sharedService.getCompetencyJson().subscribe({\n      next: (data) => {\n        this.competenciesData = data;\n        console.log('Competencies data loaded:', this.competenciesData);\n      },\n      error: (error) => {\n        console.error('Error loading competencies data:', error);\n      }\n    });\n  }\n\n  updateCompetencyCounts() {\n    const comps = this.competenciesArray.value;\n    this.competenciesCount = {total: 0, behavioral: 0, functional: 0, domain: 0};\n    comps.forEach(c => {\n      this.competenciesCount.total++;\n      if (c.type.toLowerCase() === 'behavioral') this.competenciesCount.behavioral++;\n      if (c.type.toLowerCase() === 'functional') this.competenciesCount.functional++;\n      if (c.type.toLowerCase() === 'domain') this.competenciesCount.domain++;\n    });\n  }\n\n  initializeForm() {\n    this.cbpForm = this.fb.group({\n      designation_name: [this.planData?.designation_name || '', Validators.required],\n      wing_division_section: [this.planData?.wing_division_section || '', Validators.required],\n      role_responsibilities_text: [this.planData?.role_responsibilities?.join('\\n') || ''],\n      activities_text: [this.planData?.activities?.join('\\n') || ''],\n      competencySearchText: [''],\n      competencyType: [''],\n      competencyTheme: [''],\n      competencySubTheme: [''],\n      manualThemeInput: [''],\n      manualSubThemeInput: [''],\n      themeSearch: [''],\n      subThemeSearch: [''],\n      competencies: this.fb.array(this.planData?.competencies || []), // optional customization,\n      searchDesignation: ['']\n    });\n\n     if (!this.masterData['designationBackup']) {\n      this.getDesignationSafe()\n    }\n  }\n\n   private getDesignationSafe(): void {\n    if (this.designationInitInProgress || this.isLoadingMoreDesignations) {\n      return\n    }\n    this.designationInitInProgress = true\n    this.getDesignation()\n  }\n\n\n  get roleResponsibilities(): FormArray {\n    return this.cbpForm.get('role_responsibilities') as FormArray;\n  }\n\n  searchData() {\n\n  }\n\n  applyFilter() {\n   \n  }\n\n  getCompetenciesByType(type: string): any[] {\n    return (this.cbpForm?.get('competencies')?.value || []).filter(c => c.type === type);\n  }\n\n  closeDialog() {\n    this.dialogRef.close(); \n  }\n\n  saveRoleMapping() {\n    if (this.cbpForm.invalid) return;\n\n  const formData = this.cbpForm.value;\n  console.log('Submitted Data:', formData);\n  let cbpPlanData:any = this.sharedService.cbpPlanFinalObj;\n  console.log('cbpPlanData',cbpPlanData)\n  const roleResponsibilitiesArray = this.cbpForm.value.role_responsibilities_text\n  .split('\\n')\n  .map(line => line.trim())\n  .filter(line => line); \n  const activities = this.cbpForm.value.activities_text\n  .split('\\n')\n  .map(line => line.trim())\n  .filter(line => line); \n  this.loading = true\n  let req = \n    {\n      \"sector_name\":cbpPlanData?.sectors?.join(\",\"),\n      \"instruction\": cbpPlanData?.instruction ? cbpPlanData.instruction:'',\n      \"designation_name\": formData?.designation_name ? formData.designation_name : '',\n      \"wing_division_section\": formData?.wing_division_section,\n      \"role_responsibilities\":roleResponsibilitiesArray,\n      \"activities\": activities,\n      \"competencies\": formData.competencies\n    }\n    let role_mapping_id = this.planData.id\n    \n    this.sharedService.updateRoleMapping(role_mapping_id,req).subscribe({\n      next: (res) => {\n        // Success handling\n        console.log('Success:', res);\n        this.loading = false\n        this.dialogRef.close('saved')\n        this.snackBar.open('Role Mapping Saved Successfully', 'X', {\n          duration: 3000,\n          panelClass: ['snackbar-success']\n        });\n        //this.successRoleMapping.emit(this.roleMappingForm)\n      },\n      error: (error) => {\n        console.log('error', error)\n        this.dialogRef.close()\n          // Handle 409 Conflict here\n          // alert('Conflict detected: The resource already exists or action conflicts.');\n          //this.get\n          // Or you can set a UI error message variable\n          this.snackBar.open(error?.error?.detail, 'X', {\n            duration: 3000,\n            panelClass: ['snackbar-error']\n          });\n          this.loading = false\n          //this.alreadyAvailableRoleMapping.emit(this.roleMappingForm)\n      }\n    });\n  }\n\n  cancelForm() {\n    // Mark all controls as pristine and untouched without changing the values\n    this.cbpForm.markAsPristine();\n    this.cbpForm.markAsUntouched();\n   // this.competenciesArray.value = this.originalCompetencyValueArr\n   // console.log('this.competenciesArray',this.competenciesArray)\n    // Also, if you want to mark all child controls (FormControls / FormArrays / FormGroups) as pristine and untouched\n    this.markFormGroupPristineUntouched(this.cbpForm);\n    // if(this.editCompetencyIndex > -1) {\n    //   this.competenciesArray.value[this.editCompetencyIndex]['type'] = this.originalCompetencyValueArr[this.editCompetencyIndex]['type']\n    //   this.competenciesArray.value[this.editCompetencyIndex]['theme'] = this.originalCompetencyValueArr[this.editCompetencyIndex]['theme']\n    //   this.competenciesArray.value[this.editCompetencyIndex]['sub_theme'] = this.originalCompetencyValueArr[this.editCompetencyIndex]['sub_theme']\n    // }\n    this.dialogRef.close()\n  }\n  \n  private markFormGroupPristineUntouched(formGroup: FormGroup | FormArray) {\n    Object.keys(formGroup.controls).forEach(key => {\n      const control = formGroup.controls[key];\n      if (control instanceof FormControl) {\n        control.markAsPristine();\n        control.markAsUntouched();\n      } else if (control instanceof FormGroup || control instanceof FormArray) {\n        this.markFormGroupPristineUntouched(control);\n      }\n    });\n  }\n\n  get competenciesArray(): any {\n    return this.cbpForm.get('competencies') as FormArray;\n  }\n\n  onCompetencyTypeChange(type: string) {\n    this.selectedCompetencyType = type;\n    this.selectedTheme = '';\n    this.selectedSubTheme = '';\n    this.manualTheme = '';\n    this.manualSubTheme = '';\n    this.availableThemes = [];\n    this.availableSubThemes = [];\n    this.filteredThemes = [];\n    this.filteredSubThemes = [];\n    this.themeSearchText = '';\n    this.subThemeSearchText = '';\n    \n    // Reset form controls\n    this.cbpForm.patchValue({\n      competencyTheme: '',\n      competencySubTheme: '',\n      manualThemeInput: '',\n      manualSubThemeInput: '',\n      themeSearch: '',\n      subThemeSearch: ''\n    });\n    \n    if (type === 'Behavioral' || type === 'Functional') {\n      // Load themes from JSON for Behavioral and Functional\n      const competencyCategory = this.competenciesData.find(cat => \n        cat.name.toLowerCase() === type.toLowerCase() || \n        (type === 'Behavioral' && cat.name === 'Behavioural')\n      );\n      \n      if (competencyCategory) {\n        this.availableThemes = competencyCategory.competency_theme || [];\n        this.filteredThemes = [...this.availableThemes];\n      }\n    }\n    // For Domain, no themes are loaded - user will enter manually\n  }\n  \n  onThemeChange(themeName: string) {\n    this.selectedTheme = themeName;\n    this.selectedSubTheme = '';\n    this.availableSubThemes = [];\n    this.filteredSubThemes = [];\n    this.subThemeSearchText = '';\n    \n    this.cbpForm.patchValue({\n      competencySubTheme: '',\n      subThemeSearch: ''\n    });\n    \n    // Find the selected theme and load its sub-themes\n    const selectedThemeObj = this.availableThemes.find(theme => theme.name === themeName);\n    if (selectedThemeObj) {\n      this.availableSubThemes = selectedThemeObj.competency_sub_theme || [];\n      this.filteredSubThemes = [...this.availableSubThemes];\n    }\n  }\n  \n  onSubThemeChange(subThemeName: string) {\n    this.selectedSubTheme = subThemeName;\n  }\n  \n  addCompetency() {\n    let type = this.selectedCompetencyType;\n    let theme = '';\n    let subTheme = '';\n    \n    if (type === 'Domain') {\n      // For Domain, use manual input\n      theme = this.cbpForm.value.manualThemeInput?.trim();\n      subTheme = this.cbpForm.value.manualSubThemeInput?.trim();\n    } else {\n      // For Behavioral/Functional, use dropdown selections\n      theme = this.selectedTheme;\n      subTheme = this.selectedSubTheme;\n    }\n    \n    if (type && theme && subTheme) {\n      const exists = this.competenciesArray.value.some(c => \n        c.theme === theme && c.sub_theme === subTheme && c.type === type\n      );\n      \n      if (!exists) {\n        const newComp = this.fb.group({\n          type: [type],\n          theme: [theme],\n          sub_theme: [subTheme]\n        });\n        this.competenciesArray.push(newComp);\n      }\n      \n      // Clear input fields after adding\n      this.resetCompetencyForm();\n    }\n    \n    const currentValues = this.competenciesArray.value;\n    this.cbpForm.patchValue({ competencies: [...currentValues] });\n    \n    this.updateCompetencyCounts();\n    this.cdRef.detectChanges();\n    console.log(this.cbpForm?.get('competencies')?.value);\n  }\n  \n  resetCompetencyForm() {\n    this.selectedCompetencyType = '';\n    this.selectedTheme = '';\n    this.selectedSubTheme = '';\n    this.manualTheme = '';\n    this.manualSubTheme = '';\n    this.availableThemes = [];\n    this.availableSubThemes = [];\n    this.filteredThemes = [];\n    this.filteredSubThemes = [];\n    this.themeSearchText = '';\n    this.subThemeSearchText = '';\n    \n    this.cbpForm.patchValue({\n      competencyType: '',\n      competencyTheme: '',\n      competencySubTheme: '',\n      manualThemeInput: '',\n      manualSubThemeInput: '',\n      themeSearch: '',\n      subThemeSearch: ''\n    });\n  }\n  \n  filterThemes(searchText: string) {\n    this.themeSearchText = searchText;\n    if (!searchText.trim()) {\n      this.filteredThemes = [...this.availableThemes];\n    } else {\n      this.filteredThemes = this.availableThemes.filter(theme => \n        theme.name.toLowerCase().includes(searchText.toLowerCase())\n      );\n    }\n  }\n  \n  filterSubThemes(searchText: string) {\n    this.subThemeSearchText = searchText;\n    if (!searchText.trim()) {\n      this.filteredSubThemes = [...this.availableSubThemes];\n    } else {\n      this.filteredSubThemes = this.availableSubThemes.filter(subTheme => \n        subTheme.toLowerCase().includes(searchText.toLowerCase())\n      );\n    }\n  }\n  \n  canAddCompetency(): boolean {\n    if (!this.selectedCompetencyType) return false;\n    \n    if (this.selectedCompetencyType === 'Domain') {\n      const theme = this.cbpForm.value.manualThemeInput?.trim();\n      const subTheme = this.cbpForm.value.manualSubThemeInput?.trim();\n      return !!(theme && subTheme);\n    } else {\n      return !!(this.selectedTheme && this.selectedSubTheme);\n    }\n  }\n\n  deleteCompetency(comp) {\n    const index = this.competenciesArray.controls.findIndex(\n      control => control.value.theme === comp.theme && control.value.type === comp.type\n    );\n  \n    if (index !== -1) {\n      this.competenciesArray.removeAt(index);\n    }\n    this.updateCompetencyCounts();\n    this.cdRef.detectChanges();\n  }\n\n  editCompetency(comp) {\n    this.editDomainCompetencyFlag = true\n    this.editCompetencyIndex = -1\n    this.cbpForm.patchValue({\n      competencyType: 'Domain',\n      manualThemeInput: comp?.theme,\n      manualSubThemeInput: comp?.sub_theme\n    });\n    const index = this.competenciesArray.value.findIndex(c => \n      c.theme === comp?.theme &&\n      c.sub_theme === comp?.sub_theme &&\n      c.type === \"Domain\"\n    );\n    if(index > -1) {\n      this.editCompetencyIndex = index\n    }\n    this.selectedCompetencyType = 'Domain'\n    setTimeout(() => {\n      this.dialogContent.nativeElement.scrollTo({\n        top: 0,\n        behavior: 'smooth'\n      });\n    }, 500)\n  }\n\n  cancelUpdate() {\n    this.editDomainCompetencyFlag = false\n    this.editCompetencyIndex = -1\n    this.resetCompetencyForm()\n  }\n\n  updateCompetency() {\n    let type = this.selectedCompetencyType;\n    let theme = '';\n    let subTheme = '';\n    \n    if (type === 'Domain') {\n      // For Domain, use manual input\n      theme = this.cbpForm.value.manualThemeInput?.trim();\n      subTheme = this.cbpForm.value.manualSubThemeInput?.trim();\n      this.originalCompetencyValueArr = JSON.parse(JSON.stringify(this.competenciesArray.value))\n    }\n    console.log(' this.competenciesArray',  this.competenciesArray)\n    if (type && theme && subTheme) {\n      \n      console.log('this.editCompetencyIndex--',this.editCompetencyIndex)\n      if(this.editCompetencyIndex > -1) {\n        this.competenciesArray.value[this.editCompetencyIndex]['type'] = type\n        this.competenciesArray.value[this.editCompetencyIndex]['theme'] = theme\n        this.competenciesArray.value[this.editCompetencyIndex]['sub_theme'] = subTheme\n      }\n      \n      // if (!exists) {\n      //   const newComp = this.fb.group({\n      //     type: [type],\n      //     theme: [theme],\n      //     sub_theme: [subTheme]\n      //   });\n      //   this.competenciesArray.push(newComp);\n      // }\n      \n      // Clear input fields after adding\n      this.resetCompetencyForm();\n      console.log('this.originalCompetencyValueArr', this.originalCompetencyValueArr)\n    }\n    \n    const currentValues = this.competenciesArray.value;\n    this.cbpForm.patchValue({ competencies: [...currentValues] });\n    \n    this.updateCompetencyCounts();\n    this.cdRef.detectChanges();\n    console.log(this.cbpForm?.get('competencies')?.value);\n  }\n\n  getDesignation(searchText?: string, offset?: number): void {\n  \n      // clear any previous debug hooks\n      if (!searchText || searchText?.length === 0) {\n        // noop\n      }\n  \n      const reqOffset = (typeof offset === 'number') ? offset : this.designationOffset\n      let reqLimit = this.designationDefaultLoadCount\n      const pageIndex = reqLimit > 0 ? Math.floor(reqOffset / reqLimit) : 0\n      // if we're requesting from first page, clear the no-more-data guard\n      if (pageIndex === 0) {\n        this.noMoreLegacyDesignations = false\n        reqLimit = 50\n      }\n      const requestBody: any = {\n        filterCriteriaMap: {\n          status: 'Active'\n        },\n        requestedFields: [],\n        pageNumber: pageIndex,\n        pageSize: reqLimit,\n      }\n      if (searchText?.length) {\n        requestBody['searchString'] = searchText\n        // when searching, start from first page\n        requestBody.pageNumber = 0\n        // allow larger page for search if needed\n        requestBody.pageSize = pageIndex === 0 ? 50 : this.designationListLoadCount\n        // reset guard when performing a fresh search\n        this.noMoreLegacyDesignations = false\n      }\n  \n      // indicate loading state so scroll handlers don't trigger parallel calls\n      this.isLoadingMoreDesignations = true\n  \n      this.sharedService.searchPublicDesignation(requestBody).pipe(finalize(() => {\n        this.isLoadingMoreDesignations = false\n        this.designationInitInProgress = false\n      }))\n        .subscribe({\n          next: (res: any) => {\n            const content = _.get(res, 'result.result.data', [])\n            const mapped = content.map((item: any) => ({\n              name: item?.designation || '',\n              status: item?.status || 'Active',\n            }))\n  \n            // total count may be present in different keys depending on API version.\n            // Prefer 'result.result.totalcount' (legacy lower-case) then data.totalCount, then totalCount\n            const total = _.get(res, 'result.result.totalcount', _.get(res, 'result.result.data.totalCount', _.get(res, 'result.result.totalCount', 0)))\n            this.defaultSearchDesignationCount = total\n  \n            // If offset is zero (first page) replace backup, otherwise append + dedupe\n            if (!this.masterData['designationBackup'] || reqOffset === 0) {\n              this.masterData['designationBackup'] = mapped\n            } else {\n              const combined = (this.masterData['designationBackup'] || []).concat(mapped)\n              this.masterData['designationBackup'] = _.uniqBy(combined, (it: any) => (it?.name || '').toLowerCase())\n            }\n  \n            // If server returned no new items, mark as no-more-data to stop further scroll requests\n            if (!mapped || mapped?.length === 0) {\n              this.noMoreLegacyDesignations = true\n            }\n  \n            // If we've loaded at least the total count, mark no-more-data\n            if (this.defaultSearchDesignationCount && (this.masterData['designationBackup'] || []).length >= this.defaultSearchDesignationCount) {\n              this.noMoreLegacyDesignations = true\n            }\n  \n            // Ensure visible list matches the requested display count\n            this.masterData['designation'] = (this.masterData['designationBackup'] || []).slice(0, this.designationListLoadCount)\n            // loading flag cleared in finalize()\n             this.ensureSelectedDesignationExists();\n            this.checkCurrentDesignationPresent()\n          },\n          error: () => {\n            // Stop further automatic calls on repeated errors to avoid tight loops\n            // loading flag cleared in finalize()\n            this.noMoreLegacyDesignations = true\n            // this.matSnackBar.open('Unable to fetch designation details, please try again later!')\n          }\n        })\n\n        this.cbpForm.get('designation_name')?.setValue(\n          this.planData?.designation_name || ''\n        );\n    }\n\n    ensureSelectedDesignationExists() {\n  const selected = this.planData?.designation_name;\n\n  if (!selected) return;\n\n  const exists = this.masterData['designationBackup']?.some(\n    (d: any) => d.name?.toLowerCase() === selected.toLowerCase()\n  );\n\n  if (!exists) {\n    const customObj = {\n      name: selected,\n      status: 'Active',\n      igot_designation_name: \"Principal Secretary\",\n      igot_designation_id: \"DESG-002314\",\n    };\n\n    // ✅ Add at TOP so it's visible immediately\n    this.masterData['designationBackup'] = [\n      customObj,\n      ...(this.masterData['designationBackup'] || [])\n    ];\n\n    this.masterData['designation'] = [\n      customObj,\n      ...(this.masterData['designation'] || [])\n    ];\n  }\n}\n\n    checkCurrentDesignationPresent() {\n      const selectedDesignations: string[] =\n        this.cbpForm.get('designation_name')?.value || [];\n  \n      if (!Array.isArray(selectedDesignations) || !selectedDesignations.length) {\n        return;\n      }\n  \n      if (!this.masterData?.designation) {\n        return;\n      }\n  \n      selectedDesignations.forEach((selectedName: string) => {\n        const exists = this.masterData.designation.some(\n          (item: any) =>\n            item?.name?.toLowerCase() === selectedName?.toLowerCase()\n        );\n  \n        if (!exists) {\n          const newDesignation = {\n            name: selectedName,\n            status: 'Active',\n            id: 'custom-' + Date.now() + '-' + Math.random()\n          };\n  \n          // Add to backup list as well\n          this.masterData.designationBackup =\n            this.masterData.designationBackup || [];\n  \n          this.masterData.designationBackup.unshift(newDesignation);\n  \n          // Also update visible list\n          this.masterData.designation.unshift(newDesignation);\n        }\n      });\n    }\n    onDesignationDropdownClosed(): void {\n      // Keep the designation value but clear the search input\n      const currentDesignation = this.cbpForm.get('designation_name')!.value\n      setTimeout(() => {\n        if (this.cbpForm.get('searchDesignation')) {\n          this.cbpForm.get('searchDesignation')!.setValue('')\n        }\n        // Ensure the designation value remains selected\n        if (currentDesignation) {\n          const designationControl = this.cbpForm.get('designation_name');\n          if (designationControl) {\n            designationControl.setValue(currentDesignation)\n          }\n        }\n      }, 100)\n    }\n  \n    designationSearch(evt: any) {\n      const searchText = evt?.target?.value\n      const txt = (searchText || '').toString().trim()\n      if (this.isLoadingMoreDesignations) return\n  \n      this.designationSearchText = txt\n      if (txt?.length) {\n        this.desigantionFilterEnable = true\n        this.isLoadingMoreDesignations = true\n        this.getDesignation(txt, 0)\n      } else if (this.masterData && this.masterData?.designationBackup) {\n        this.masterData.designation = this.masterData?.designationBackup.slice(0, this.designationDefaultLoadCount)\n        this.desigantionFilterEnable = false\n        this.checkCurrentDesignationPresent()\n      }\n    }\n    setupScrollListener(opened: boolean): void {\n      if (opened) {\n        if (!this.scrollListenerAttached) {\n          this.scrollListenerAttached = true\n  \n          this.desigantionFilterEnable = false\n          this.designationListLoadCount = this.designationDefaultLoadCount\n          this.designationOffset = 0\n  \n          this.isLoadingMoreDesignations = true\n          this.getDesignation(undefined, 0)\n  \n          // Clear search box once\n          if (this.cbpForm.get('searchDesignation')) {\n            this.cbpForm.get('searchDesignation')!.setValue('')\n          }\n  \n          setTimeout(() => {\n            const searchInput = document.querySelector('.search-input') as HTMLInputElement\n            if (searchInput) {\n              searchInput.focus()\n            }\n          }, 100)\n  \n          // Attach scroll listener safely\n          setTimeout(() => {\n            const panel = document.querySelector('.mat-select-panel.search-panel') as HTMLElement | null\n            if (panel) {\n              // align panel width to trigger\n              try {\n                const triggerEl = this.designationRef && this.designationRef.nativeElement as HTMLElement\n                if (triggerEl) {\n                  const rect = triggerEl.getBoundingClientRect()\n                  // set width and left so panel aligns exactly below the trigger\n                  panel.style.width = `${Math.round(rect.width)}px`\n                  // leave left to overlay positioning but nudge if necessary\n                  // compute left relative to viewport and apply to panel\n                  const overlayLeft = rect.left\n                  panel.style.left = `${Math.round(overlayLeft)}px`\n                }\n              } catch (e) {\n                // ignore DOM errors in SSR or unexpected cases\n              }\n  \n              const scrollHandler = this.onDesignationSelectScroll.bind(this)\n              panel.addEventListener('scroll', scrollHandler, { passive: true })\n            }\n          }, 150)\n        }\n      } else {\n        // Dropdown closed — reset scroll flag so it can reattach next time\n        this.scrollListenerAttached = false\n      }\n    }\n  \n    onDesignationSelectScroll(event: any): void {\n      const element = event?.target\n      if (!this.desigantionFilterEnable) {\n        // Check if user has scrolled to the bottom (with a small threshold)\n        if (element.scrollTop + element?.clientHeight >= element?.scrollHeight - 5) {\n          // Only load more if not already loading and if there are potentially more items\n          if (!this.isLoadingMoreDesignations) {\n            // If org uses IGOT designation taxonomy, request more from the API by increasing the limit\n            if (this.masterData?.designationBackup?.length > this.masterData?.designation?.length) {\n              // Local pagination: expand the sliced list\n              this.isLoadingMoreDesignations = true\n              this.designationListLoadCount += this.designationDefaultLoadCount\n              // Update the filtered list with more items\n              setTimeout(() => {\n                this.masterData.designation = this.masterData?.designationBackup?.slice(0, this.designationListLoadCount)\n                this.checkCurrentDesignationPresent()\n                this.isLoadingMoreDesignations = false\n              }, 500) // Small timeout to simulate loading and prevent multiple triggers\n            } else {\n              // Legacy (server) pagination: request next page if total not reached\n              const loadedLegacy = (this.masterData?.designationBackup || []).length\n              if (!this.noMoreLegacyDesignations && this.defaultSearchDesignationCount && loadedLegacy < this.defaultSearchDesignationCount) {\n                this.isLoadingMoreDesignations = true\n                this.designationOffset = (this.designationOffset || 0) + this.designationDefaultLoadCount\n                // increase display count to include newly fetched items\n                this.designationListLoadCount += this.designationDefaultLoadCount\n                this.getDesignation(undefined, this.designationOffset)\n              }\n            }\n          }\n        }\n      }\n    }\n  \n    get searchDesignationControl(): FormControl {\n      return this.cbpForm.get('searchDesignation') as FormControl;\n    }\n\n\n}\n","<div class=\"view-cbp-plan\" #dialogContent>\n    <div class=\"popup-container\">\n        <div class=\"popup-header\">\n            <div>\n                <div class=\"heading\">Edit Role Mapping</div>\n            </div>\n            <div class=\"cursor-pointer\" (click)=\"closeDialog()\">\n                <mat-icon>close</mat-icon>\n            </div>\n        </div>\n        <div class=\"section-container\" [formGroup]=\"cbpForm\">\n\n            <!-- <div class=\"section-header mt-4\">\n                <input type=\"text\" formControlName=\"designation_name\" [value]=\"planData?.designation_name\"\n                    style=\"border-radius: 25px; border: 1px solid #ccc; padding: 8px 12px; width: 100%;font-size: 14px;font-family: 'Lato';\">\n\n\n            </div> -->\n\n            <mat-form-field appearance=\"outline\" class=\"mt-4 margin-top-s w-full required-select\"  style=\"border-radius: 25px; border: 1px solid #ccc; padding: 8px 12px; width: 100%;font-size: 14px;font-family: 'Lato';\">\n                <mat-select #position formControlName=\"designation_name\" placeholder=\"Select designation\"\n                    (closed)=\"onDesignationDropdownClosed()\" panelClass=\"search-panel\"\n                    (openedChange)=\"setupScrollListener($event)\">\n\n                    <!-- Sticky search input container -->\n                    <div class=\"sticky-search-container\" (click)=\"$event.stopPropagation()\">\n                        <div class=\"search-input-wrapper\">\n                            <input type=\"text\" placeholder=\"Search designation\" style=\"width:100%\"\n                                formControlName=\"searchDesignation\" class=\"search-input\"\n                                (keydown)=\"$event.stopPropagation()\"\n                                (keydown.enter)=\"$event.preventDefault(); $event.stopPropagation()\"\n                                (keyup)=\"designationSearch($event)\" autocomplete=\"off\">\n                            <div *ngIf=\"searchDesignationControl?.value\" type=\"button\" class=\"clear-icon\"\n                                (click)=\"searchDesignationControl.setValue('')\">\n                                <mat-icon>close</mat-icon>\n                            </div>\n                        </div>\n                    </div>\n                    <!-- Options list -->\n                    <mat-option [value]=\"designation?.name\" *ngFor=\"let designation of masterData?.designation\">\n                        {{designation?.name}}\n                    </mat-option>\n                    <!-- Loading indicator -->\n                    <div *ngIf=\"isLoadingMoreDesignations\" class=\"loading-indicator\">\n                        Load More...\n                    </div>\n                    <!-- No results message -->\n                    <mat-option *ngIf=\"(masterData?.designation)?.length === 0\" disabled class=\"no-data-option\">\n\n                        Designation Not Found.\n\n                    </mat-option>\n                </mat-select>\n                <!-- <mat-error class=\"text-xs\"\n                            *ngIf=\"designationForm?.get('designation_name')?.touched && designationForm?.get('designation_name')?.invalid\">\n                            Please select at least one designation.\n                        </mat-error> -->\n            </mat-form-field>\n\n            <div class=\"competency-container mt-4\">\n                <div class=\"outside-layer-total\">\n                    <div class=\"inside-layer\">\n                        Total Competencies\n                    </div>\n                    <div class=\"count\">\n                        {{competenciesCount?.total}}\n                    </div>\n                </div>\n                <div class=\"outside-layer-behavioral\">\n                    <div class=\"inside-layer\">\n                        Behavioral Competencies\n                    </div>\n                    <div class=\"count\">\n                        {{competenciesCount?.behavioral}}\n                    </div>\n                </div>\n                <div class=\"outside-layer-functional\">\n                    <div class=\"inside-layer\">\n                        Functional Competencies\n                    </div>\n                    <div class=\"count\">\n                        {{competenciesCount?.functional}}\n                    </div>\n                </div>\n                <div class=\"outside-layer-domain\">\n                    <div class=\"inside-layer\">\n                        Domain Competencies\n                    </div>\n                    <div class=\"count\">\n                        {{competenciesCount?.domain}}\n                    </div>\n                </div>\n            </div>\n            <div class=\"mt-4 section\">\n                <div class=\"sub-heading\">\n                    <p>Wing/Division</p>\n                </div>\n                <div class=\"mt-4\">\n                    <input type=\"text\" formControlName=\"wing_division_section\" [value]=\"planData?.wing_division_section\"\n                        style=\"border-radius: 25px; border: 1px solid #ccc; padding: 8px 12px; width:100%;font-size: 14px;font-family: 'Lato';\">\n                </div>\n            </div>\n            <div class=\"mt-2 section\">\n                <div class=\"sub-heading\">\n                    <p>Roles & Responsibilities</p>\n                </div>\n                <div class=\"mt-4 additional-details\">\n                    <textarea class=\"custom-textarea\" formControlName=\"role_responsibilities_text\" rows=\"5\"\n                        placeholder=\"Roles & Responsibilities\"\n                        [value]=\"planData?.role_responsibilities?.join('\\n')\"></textarea>\n                </div>\n            </div>\n            <div class=\"mt-2 section\">\n                <div class=\"sub-heading\">\n                    <p>Activities</p>\n                </div>\n                <div class=\"mt-4 additional-details\">\n                    <textarea class=\"custom-textarea\" formControlName=\"activities_text\" rows=\"5\"\n                        placeholder=\"Activities\" [value]=\"planData?.activities?.join('\\n')\"></textarea>\n                </div>\n            </div>\n            <div class=\"mt-2 section\">\n                <div class=\"sub-heading\">\n                    <p>Competency</p>\n                </div>\n                <div class=\"enhanced-competency-section mt-2\">\n                    <!-- Step 1: Select Competency Type -->\n                    <div class=\"competency-step\">\n                        <label class=\"step-label\">1. Select Core Competency Type</label>\n                        <div class=\"competency-dropdown-container\">\n                            <mat-form-field appearance=\"outline\" class=\"competency-dropdown\">\n                                <mat-select formControlName=\"competencyType\" placeholder=\"Select Competency Type\"\n                                    (selectionChange)=\"onCompetencyTypeChange($event.value)\">\n                                    <mat-option value=\"Behavioral\">Behavioral</mat-option>\n                                    <mat-option value=\"Functional\">Functional</mat-option>\n                                    <mat-option value=\"Domain\">Domain</mat-option>\n                                </mat-select>\n                            </mat-form-field>\n                        </div>\n                    </div>\n\n                    <!-- Step 2: Theme Selection (Behavioral/Functional from JSON, Domain manual) -->\n                    <div class=\"competency-step\" *ngIf=\"selectedCompetencyType\">\n                        <label class=\"step-label\">2. Select/Enter Theme</label>\n\n                        <!-- For Behavioral and Functional: Searchable Dropdown from JSON -->\n                        <div class=\"competency-dropdown-container\"\n                            *ngIf=\"selectedCompetencyType === 'Behavioral' || selectedCompetencyType === 'Functional'\">\n                            <mat-form-field appearance=\"outline\" class=\"competency-dropdown\">\n                                <mat-select formControlName=\"competencyTheme\" placeholder=\"Search and select theme\"\n                                    (selectionChange)=\"onThemeChange($event.value)\">\n                                    <!-- Search input inside dropdown -->\n                                    <mat-option class=\"search-option\" disabled>\n                                        <mat-form-field appearance=\"outline\" class=\"search-field\">\n                                            <input matInput placeholder=\"Search themes...\" formControlName=\"themeSearch\"\n                                                (input)=\"filterThemes($event.target.value)\"\n                                                (click)=\"$event.stopPropagation()\" (keydown)=\"$event.stopPropagation()\">\n                                        </mat-form-field>\n                                    </mat-option>\n\n                                    <!-- Theme options -->\n                                    <mat-option *ngFor=\"let theme of filteredThemes\" [value]=\"theme.name\">\n                                        {{theme.name}}\n                                    </mat-option>\n\n                                    <!-- No results message -->\n                                    <mat-option *ngIf=\"filteredThemes.length === 0 && themeSearchText\" disabled>\n                                        No themes found matching \"{{themeSearchText}}\"\n                                    </mat-option>\n                                </mat-select>\n                            </mat-form-field>\n                        </div>\n\n                        <!-- For Domain: Manual input -->\n                        <div class=\"manual-input-container\" *ngIf=\"selectedCompetencyType === 'Domain'\">\n                            <input type=\"text\" formControlName=\"manualThemeInput\" placeholder=\"Enter Theme manually\"\n                                class=\"manual-input\" />\n                        </div>\n                    </div>\n\n                    <!-- Step 3: Sub-theme Selection -->\n                    <div class=\"competency-step\" *ngIf=\"selectedTheme || (selectedCompetencyType === 'Domain')\">\n                        <label class=\"step-label\">3. Select/Enter Sub-theme</label>\n\n                        <!-- For Behavioral and Functional: Searchable Dropdown based on selected theme -->\n                        <div class=\"competency-dropdown-container\"\n                            *ngIf=\"selectedCompetencyType === 'Behavioral' || selectedCompetencyType === 'Functional'\">\n                            <mat-form-field appearance=\"outline\" class=\"competency-dropdown\">\n                                <mat-select formControlName=\"competencySubTheme\"\n                                    placeholder=\"Search and select sub-theme\"\n                                    (selectionChange)=\"onSubThemeChange($event.value)\">\n                                    <!-- Search input inside dropdown -->\n                                    <mat-option class=\"search-option\" disabled>\n                                        <mat-form-field appearance=\"outline\" class=\"search-field\">\n                                            <input matInput placeholder=\"Search sub-themes...\"\n                                                formControlName=\"subThemeSearch\"\n                                                (input)=\"filterSubThemes($event.target.value)\"\n                                                (click)=\"$event.stopPropagation()\" (keydown)=\"$event.stopPropagation()\">\n                                        </mat-form-field>\n                                    </mat-option>\n\n                                    <!-- Sub-theme options -->\n                                    <mat-option *ngFor=\"let subTheme of filteredSubThemes\" [value]=\"subTheme\">\n                                        {{subTheme}}\n                                    </mat-option>\n\n                                    <!-- No results message -->\n                                    <mat-option *ngIf=\"filteredSubThemes.length === 0 && subThemeSearchText\" disabled>\n                                        No sub-themes found matching \"{{subThemeSearchText}}\"\n                                    </mat-option>\n                                </mat-select>\n                            </mat-form-field>\n                        </div>\n\n                        <!-- For Domain: Manual input -->\n                        <div class=\"manual-input-container\" *ngIf=\"selectedCompetencyType === 'Domain'\">\n                            <input type=\"text\" formControlName=\"manualSubThemeInput\"\n                                placeholder=\"Enter Sub-theme manually\" class=\"manual-input\" />\n                        </div>\n                    </div>\n\n                    <!-- Add Button -->\n                    <div class=\"add-button-section\" *ngIf=\"selectedCompetencyType \">\n                        <button type=\"button\" *ngIf=\"!editDomainCompetencyFlag\" class=\"add-competency-btn\"\n                            [disabled]=\"!canAddCompetency()\"\n                            [ngClass]=\"canAddCompetency() ? 'btn-active' : 'btn-disable'\" (click)=\"addCompetency()\">\n                            Add Competency\n                        </button>\n                        <button type=\"button\" *ngIf=\"editDomainCompetencyFlag\" class=\"add-competency-btn btn-active\"\n                            (click)=\"updateCompetency()\">\n                            Update Competency\n                        </button>\n                        <button type=\"button\" *ngIf=\"editDomainCompetencyFlag\" class=\"add-competency-btn btn-active\"\n                            style=\"margin-left: 5px;\" (click)=\"cancelUpdate()\">\n                            Cancel </button>\n                    </div>\n                </div>\n                <div class=\"mt-4\">\n                    <div class=\"competency-sub-heading mt-2\" *ngIf=\"getCompetenciesByType('Behavioral')?.length\">\n                        Behavioral Competencies\n                    </div>\n\n                    <div class=\"competency-grid mt-2\">\n                        <div class=\"competency-item behavioural-pill\"\n                            *ngFor=\"let comp of getCompetenciesByType('Behavioral')\">\n                            <span class=\"competency-text-behavioral\">\n                                {{ comp.theme }} - {{ comp.sub_theme }}\n                            </span>\n                            <span class=\"cursor-pointer close\" (click)=\"deleteCompetency(comp)\">\n                                <mat-icon>close</mat-icon>\n                            </span>\n                        </div>\n                    </div>\n                </div>\n                <div class=\"mt-4\">\n                    <div class=\"competency-sub-heading mt-2\" *ngIf=\"getCompetenciesByType('Functional')?.length\">\n                        Functional Competencies</div>\n                    <div class=\"competency-grid mt-2\">\n                        <div class=\"competency-item functional-pill\"\n                            *ngFor=\"let comp of getCompetenciesByType('Functional')\">\n                            <span class=\"competency-text-functional\">\n                                {{ comp.theme }} - {{ comp.sub_theme }}\n                            </span>\n                            <span class=\"cursor-pointer close\" (click)=\"deleteCompetency(comp)\">\n                                <mat-icon>close</mat-icon>\n                            </span>\n                        </div>\n                    </div>\n                </div>\n                <div class=\"mt-4\">\n                    <div class=\"competency-sub-heading mt-2\">Domain Competencies</div>\n                    <div class=\"competency-grid mt-2\">\n                        <div class=\"competency-item domain-pill\" *ngFor=\"let comp of getCompetenciesByType('Domain')\">\n                            <span class=\"competency-text-domain\">\n                                {{ comp.theme }} - {{ comp.sub_theme }}\n                            </span>\n                            <span class=\"cursor-pointer edit\" (click)=\"editCompetency(comp)\">\n                                <mat-icon>edit</mat-icon>\n                            </span>\n                            <span class=\"cursor-pointer close\" (click)=\"deleteCompetency(comp)\">\n                                <mat-icon>close</mat-icon>\n                            </span>\n                        </div>\n                    </div>\n                </div>\n            </div>\n        </div>\n        <div class=\"popup-footer\">\n            <div>\n                <input class=\"btn-active\" type=\"button\" value=\"Cancel\" (click)=\"cancelForm()\" />\n            </div>\n            <div>\n                <input class=\"btn-active\" type=\"button\" value=\"Save\" (click)=\"saveRoleMapping()\" />\n            </div>\n        </div>\n    </div>\n</div>\n\n<div class=\"overlay-loader\" *ngIf=\"loading\">\n    <mat-spinner diameter=\"50\"></mat-spinner>\n</div>"]}