@sunbird-cb/cbp-ai 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +24 -0
- package/esm2022/lib/ai-cbp-routing.module.mjs +56 -0
- package/esm2022/lib/ai-cbp.component.mjs +14 -0
- package/esm2022/lib/ai-cbp.module.mjs +263 -0
- package/esm2022/lib/ai-cbp.service.mjs +14 -0
- package/esm2022/lib/components/add-course/add-course.component.mjs +444 -0
- package/esm2022/lib/components/add-designation/add-designation.component.mjs +460 -0
- package/esm2022/lib/components/add-personalisation/add-personalisation.component.mjs +33 -0
- package/esm2022/lib/components/approval-request-form/approval-request-form.component.mjs +392 -0
- package/esm2022/lib/components/approval-requests/approval-requests.component.mjs +398 -0
- package/esm2022/lib/components/dashboard/dashboard.component.mjs +265 -0
- package/esm2022/lib/components/delete-role-mapping/delete-role-mapping.component.mjs +53 -0
- package/esm2022/lib/components/delete-role-mapping-popup/delete-role-mapping-popup.component.mjs +39 -0
- package/esm2022/lib/components/edit-cbp-plan/edit-cbp-plan.component.mjs +699 -0
- package/esm2022/lib/components/gap-analysis-recommended-course/gap-analysis-recommended-course.component.mjs +188 -0
- package/esm2022/lib/components/generate-course-recommendation/generate-course-recommendation.component.mjs +1949 -0
- package/esm2022/lib/components/list-popup/list-popup.component.mjs +32 -0
- package/esm2022/lib/components/review-request/review-request.component.mjs +138 -0
- package/esm2022/lib/components/role-mapping-generation/role-mapping-generation.component.mjs +1082 -0
- package/esm2022/lib/components/role-mapping-list/role-mapping-list.component.mjs +714 -0
- package/esm2022/lib/components/suggest-more-courses/suggest-more-courses.component.mjs +370 -0
- package/esm2022/lib/components/update-designation-hierarchy/update-designation-hierarchy.component.mjs +235 -0
- package/esm2022/lib/components/view-cbp-plan/view-cbp-plan.component.mjs +125 -0
- package/esm2022/lib/components/view-course-recommendation/view-course-recommendation.component.mjs +397 -0
- package/esm2022/lib/components/view-final-cbp-plan/view-final-cbp-plan.component.mjs +883 -0
- package/esm2022/lib/modules/initial-screen/initial-screen.component.mjs +127 -0
- package/esm2022/lib/modules/shared/constant/app.constant.mjs +2036 -0
- package/esm2022/lib/modules/shared/directives/clickoutside.directive.mjs +38 -0
- package/esm2022/lib/modules/shared/directives/directive.module.mjs +21 -0
- package/esm2022/lib/modules/shared/pipes/order-by-name.pipe.mjs +23 -0
- package/esm2022/lib/modules/shared/services/event.service.mjs +24 -0
- package/esm2022/lib/modules/shared/services/events.mjs +125 -0
- package/esm2022/lib/modules/shared/services/init.service.mjs +41 -0
- package/esm2022/lib/modules/shared/services/role-mapping.service.mjs +261 -0
- package/esm2022/lib/modules/shared/services/shared.service.mjs +869 -0
- package/esm2022/lib/modules/upload-document-page/progress-dialog/progress-dialog.component.mjs +53 -0
- package/esm2022/lib/modules/upload-document-page/upload-dialog/upload-dialog.component.mjs +186 -0
- package/esm2022/lib/modules/upload-document-page/upload-document-page.component.mjs +367 -0
- package/esm2022/lib/pipe-public-URL/pipe-public-URL.module.mjs +20 -0
- package/esm2022/lib/pipe-public-URL/pipe-public-URL.pipe.mjs +23 -0
- package/esm2022/public-api.mjs +14 -0
- package/esm2022/sunbird-cb-cbp-ai.mjs +5 -0
- package/fesm2022/sunbird-cb-cbp-ai.mjs +12952 -0
- package/fesm2022/sunbird-cb-cbp-ai.mjs.map +1 -0
- package/index.d.ts +6 -0
- package/lib/ai-cbp-routing.module.d.ts +8 -0
- package/lib/ai-cbp-routing.module.d.ts.map +1 -0
- package/lib/ai-cbp.component.d.ts +7 -0
- package/lib/ai-cbp.component.d.ts.map +1 -0
- package/lib/ai-cbp.module.d.ts +68 -0
- package/lib/ai-cbp.module.d.ts.map +1 -0
- package/lib/ai-cbp.service.d.ts +7 -0
- package/lib/ai-cbp.service.d.ts.map +1 -0
- package/lib/components/add-course/add-course.component.d.ts +67 -0
- package/lib/components/add-course/add-course.component.d.ts.map +1 -0
- package/lib/components/add-designation/add-designation.component.d.ts +52 -0
- package/lib/components/add-designation/add-designation.component.d.ts.map +1 -0
- package/lib/components/add-personalisation/add-personalisation.component.d.ts +16 -0
- package/lib/components/add-personalisation/add-personalisation.component.d.ts.map +1 -0
- package/lib/components/approval-request-form/approval-request-form.component.d.ts +48 -0
- package/lib/components/approval-request-form/approval-request-form.component.d.ts.map +1 -0
- package/lib/components/approval-requests/approval-requests.component.d.ts +80 -0
- package/lib/components/approval-requests/approval-requests.component.d.ts.map +1 -0
- package/lib/components/dashboard/dashboard.component.d.ts +55 -0
- package/lib/components/dashboard/dashboard.component.d.ts.map +1 -0
- package/lib/components/delete-role-mapping/delete-role-mapping.component.d.ts +18 -0
- package/lib/components/delete-role-mapping/delete-role-mapping.component.d.ts.map +1 -0
- package/lib/components/delete-role-mapping-popup/delete-role-mapping-popup.component.d.ts +18 -0
- package/lib/components/delete-role-mapping-popup/delete-role-mapping-popup.component.d.ts.map +1 -0
- package/lib/components/edit-cbp-plan/edit-cbp-plan.component.d.ts +94 -0
- package/lib/components/edit-cbp-plan/edit-cbp-plan.component.d.ts.map +1 -0
- package/lib/components/gap-analysis-recommended-course/gap-analysis-recommended-course.component.d.ts +35 -0
- package/lib/components/gap-analysis-recommended-course/gap-analysis-recommended-course.component.d.ts.map +1 -0
- package/lib/components/generate-course-recommendation/generate-course-recommendation.component.d.ts +198 -0
- package/lib/components/generate-course-recommendation/generate-course-recommendation.component.d.ts.map +1 -0
- package/lib/components/list-popup/list-popup.component.d.ts +13 -0
- package/lib/components/list-popup/list-popup.component.d.ts.map +1 -0
- package/lib/components/review-request/review-request.component.d.ts +39 -0
- package/lib/components/review-request/review-request.component.d.ts.map +1 -0
- package/lib/components/role-mapping-generation/role-mapping-generation.component.d.ts +99 -0
- package/lib/components/role-mapping-generation/role-mapping-generation.component.d.ts.map +1 -0
- package/lib/components/role-mapping-list/role-mapping-list.component.d.ts +83 -0
- package/lib/components/role-mapping-list/role-mapping-list.component.d.ts.map +1 -0
- package/lib/components/suggest-more-courses/suggest-more-courses.component.d.ts +48 -0
- package/lib/components/suggest-more-courses/suggest-more-courses.component.d.ts.map +1 -0
- package/lib/components/update-designation-hierarchy/update-designation-hierarchy.component.d.ts +41 -0
- package/lib/components/update-designation-hierarchy/update-designation-hierarchy.component.d.ts.map +1 -0
- package/lib/components/view-cbp-plan/view-cbp-plan.component.d.ts +29 -0
- package/lib/components/view-cbp-plan/view-cbp-plan.component.d.ts.map +1 -0
- package/lib/components/view-course-recommendation/view-course-recommendation.component.d.ts +49 -0
- package/lib/components/view-course-recommendation/view-course-recommendation.component.d.ts.map +1 -0
- package/lib/components/view-final-cbp-plan/view-final-cbp-plan.component.d.ts +73 -0
- package/lib/components/view-final-cbp-plan/view-final-cbp-plan.component.d.ts.map +1 -0
- package/lib/modules/initial-screen/initial-screen.component.d.ts +85 -0
- package/lib/modules/initial-screen/initial-screen.component.d.ts.map +1 -0
- package/lib/modules/shared/constant/app.constant.d.ts +457 -0
- package/lib/modules/shared/constant/app.constant.d.ts.map +1 -0
- package/lib/modules/shared/directives/clickoutside.directive.d.ts +13 -0
- package/lib/modules/shared/directives/clickoutside.directive.d.ts.map +1 -0
- package/lib/modules/shared/directives/directive.module.d.ts +8 -0
- package/lib/modules/shared/directives/directive.module.d.ts.map +1 -0
- package/lib/modules/shared/pipes/order-by-name.pipe.d.ts +8 -0
- package/lib/modules/shared/pipes/order-by-name.pipe.d.ts.map +1 -0
- package/lib/modules/shared/services/event.service.d.ts +12 -0
- package/lib/modules/shared/services/event.service.d.ts.map +1 -0
- package/lib/modules/shared/services/events.d.ts +200 -0
- package/lib/modules/shared/services/events.d.ts.map +1 -0
- package/lib/modules/shared/services/init.service.d.ts +13 -0
- package/lib/modules/shared/services/init.service.d.ts.map +1 -0
- package/lib/modules/shared/services/role-mapping.service.d.ts +21 -0
- package/lib/modules/shared/services/role-mapping.service.d.ts.map +1 -0
- package/lib/modules/shared/services/shared.service.d.ts +108 -0
- package/lib/modules/shared/services/shared.service.d.ts.map +1 -0
- package/lib/modules/upload-document-page/progress-dialog/progress-dialog.component.d.ts +14 -0
- package/lib/modules/upload-document-page/progress-dialog/progress-dialog.component.d.ts.map +1 -0
- package/lib/modules/upload-document-page/upload-dialog/upload-dialog.component.d.ts +29 -0
- package/lib/modules/upload-document-page/upload-dialog/upload-dialog.component.d.ts.map +1 -0
- package/lib/modules/upload-document-page/upload-document-page.component.d.ts +64 -0
- package/lib/modules/upload-document-page/upload-document-page.component.d.ts.map +1 -0
- package/lib/pipe-public-URL/pipe-public-URL.module.d.ts +9 -0
- package/lib/pipe-public-URL/pipe-public-URL.module.d.ts.map +1 -0
- package/lib/pipe-public-URL/pipe-public-URL.pipe.d.ts +11 -0
- package/lib/pipe-public-URL/pipe-public-URL.pipe.d.ts.map +1 -0
- package/package.json +28 -0
- package/public-api.d.ts +11 -0
- package/public-api.d.ts.map +1 -0
- package/sunbird-cb-cbp-ai-0.0.1.tgz +0 -0
- package/sunbird-cb-cbp-ai.d.ts.map +1 -0
|
@@ -0,0 +1,444 @@
|
|
|
1
|
+
import { Component, Inject } from '@angular/core';
|
|
2
|
+
import { Validators } from '@angular/forms';
|
|
3
|
+
import { MAT_DIALOG_DATA } from '@angular/material/dialog';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/material/dialog";
|
|
6
|
+
import * as i2 from "../../modules/shared/services/shared.service";
|
|
7
|
+
import * as i3 from "@angular/forms";
|
|
8
|
+
import * as i4 from "@angular/material/snack-bar";
|
|
9
|
+
import * as i5 from "@angular/common/http";
|
|
10
|
+
import * as i6 from "@angular/common";
|
|
11
|
+
import * as i7 from "@angular/material/legacy-form-field";
|
|
12
|
+
import * as i8 from "@angular/material/legacy-input";
|
|
13
|
+
import * as i9 from "@angular/material/icon";
|
|
14
|
+
import * as i10 from "@angular/material/legacy-select";
|
|
15
|
+
import * as i11 from "@angular/material/legacy-core";
|
|
16
|
+
import * as i12 from "@angular/material/progress-spinner";
|
|
17
|
+
export class AddCourseComponent {
|
|
18
|
+
constructor(dialogRef, data, sharedService, fb, snackBar, http, cdRef) {
|
|
19
|
+
this.dialogRef = dialogRef;
|
|
20
|
+
this.data = data;
|
|
21
|
+
this.sharedService = sharedService;
|
|
22
|
+
this.fb = fb;
|
|
23
|
+
this.snackBar = snackBar;
|
|
24
|
+
this.http = http;
|
|
25
|
+
this.cdRef = cdRef;
|
|
26
|
+
this.loading = false;
|
|
27
|
+
// Enhanced competency selection properties
|
|
28
|
+
this.competenciesData = [];
|
|
29
|
+
this.availableThemes = [];
|
|
30
|
+
this.availableSubThemes = [];
|
|
31
|
+
this.filteredThemes = [];
|
|
32
|
+
this.filteredSubThemes = [];
|
|
33
|
+
this.selectedCompetencyType = '';
|
|
34
|
+
this.selectedTheme = '';
|
|
35
|
+
this.selectedSubTheme = '';
|
|
36
|
+
this.manualTheme = '';
|
|
37
|
+
this.manualSubTheme = '';
|
|
38
|
+
this.themeSearchText = '';
|
|
39
|
+
this.subThemeSearchText = '';
|
|
40
|
+
this.competenciesCount = { total: 0, behavioral: 0, functional: 0, domain: 0 };
|
|
41
|
+
// Prefill properties
|
|
42
|
+
this.isCompetencyPrefilled = false;
|
|
43
|
+
this.prefilledCompetencyType = '';
|
|
44
|
+
this.prefilledTheme = '';
|
|
45
|
+
this.prefilledSubTheme = '';
|
|
46
|
+
this.planData = data;
|
|
47
|
+
this.initializeForm();
|
|
48
|
+
}
|
|
49
|
+
ngOnInit() {
|
|
50
|
+
this.loadCompetenciesData();
|
|
51
|
+
this.updateCompetencyCounts();
|
|
52
|
+
this.checkForPrefilledData();
|
|
53
|
+
}
|
|
54
|
+
checkForPrefilledData() {
|
|
55
|
+
console.log('=== CheckForPrefilledData ===');
|
|
56
|
+
console.log('Full data object:', this.data);
|
|
57
|
+
if (this.data && this.data.prefillCompetency) {
|
|
58
|
+
console.log('✅ Prefill competency data found:', this.data.prefillCompetency);
|
|
59
|
+
this.isCompetencyPrefilled = true;
|
|
60
|
+
this.prefilledCompetencyType = this.data.prefillCompetency.type;
|
|
61
|
+
this.prefilledTheme = this.data.prefillCompetency.theme;
|
|
62
|
+
this.prefilledSubTheme = this.data.prefillCompetency.subTheme || '';
|
|
63
|
+
console.log('Processed prefill data:', {
|
|
64
|
+
isCompetencyPrefilled: this.isCompetencyPrefilled,
|
|
65
|
+
prefilledCompetencyType: this.prefilledCompetencyType,
|
|
66
|
+
prefilledTheme: this.prefilledTheme,
|
|
67
|
+
prefilledSubTheme: this.prefilledSubTheme
|
|
68
|
+
});
|
|
69
|
+
// Set the competency type and trigger the theme loading
|
|
70
|
+
this.selectedCompetencyType = this.prefilledCompetencyType;
|
|
71
|
+
this.courseForm.patchValue({
|
|
72
|
+
competencyType: this.prefilledCompetencyType
|
|
73
|
+
});
|
|
74
|
+
console.log('Form updated with competency type:', this.prefilledCompetencyType);
|
|
75
|
+
// For Domain competencies, set manual theme and subtheme inputs and auto-add
|
|
76
|
+
if (this.prefilledCompetencyType === 'Domain') {
|
|
77
|
+
console.log('Setting Domain manual inputs...');
|
|
78
|
+
this.courseForm.patchValue({
|
|
79
|
+
manualThemeInput: this.prefilledTheme,
|
|
80
|
+
manualSubThemeInput: this.prefilledSubTheme
|
|
81
|
+
});
|
|
82
|
+
console.log('Domain form values set:', {
|
|
83
|
+
manualThemeInput: this.prefilledTheme,
|
|
84
|
+
manualSubThemeInput: this.prefilledSubTheme
|
|
85
|
+
});
|
|
86
|
+
// Auto-add the domain competency
|
|
87
|
+
setTimeout(() => {
|
|
88
|
+
console.log('Adding prefilled Domain competency...');
|
|
89
|
+
this.addPrefilledCompetency();
|
|
90
|
+
}, 100);
|
|
91
|
+
}
|
|
92
|
+
else {
|
|
93
|
+
console.log('Will handle Behavioral/Functional after competencies data loads...');
|
|
94
|
+
// For Behavioral/Functional, wait for competencies data to load
|
|
95
|
+
// The theme and subtheme will be set in loadCompetenciesData after data is available
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
else {
|
|
99
|
+
console.log('❌ No prefill competency data found');
|
|
100
|
+
console.log('data.prefillCompetency:', this.data?.prefillCompetency);
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
loadCompetenciesData() {
|
|
104
|
+
this.sharedService.getCompetencyJson().subscribe({
|
|
105
|
+
next: (data) => {
|
|
106
|
+
this.competenciesData = data;
|
|
107
|
+
console.log('Competencies data loaded:', this.competenciesData);
|
|
108
|
+
// Handle prefilled data after competencies are loaded
|
|
109
|
+
if (this.isCompetencyPrefilled && this.prefilledCompetencyType !== 'Domain') {
|
|
110
|
+
this.handlePrefilledBehavioralFunctional();
|
|
111
|
+
}
|
|
112
|
+
},
|
|
113
|
+
error: (error) => {
|
|
114
|
+
console.error('Error loading competencies data:', error);
|
|
115
|
+
}
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
handlePrefilledBehavioralFunctional() {
|
|
119
|
+
console.log('=== HandlePrefilledBehavioralFunctional ===');
|
|
120
|
+
console.log('Prefilled competency type:', this.prefilledCompetencyType);
|
|
121
|
+
console.log('Prefilled theme:', this.prefilledTheme);
|
|
122
|
+
console.log('Prefilled subTheme:', this.prefilledSubTheme);
|
|
123
|
+
// Load themes for the prefilled competency type
|
|
124
|
+
this.onCompetencyTypeChange(this.prefilledCompetencyType);
|
|
125
|
+
// Find and set the theme if it exists in the data
|
|
126
|
+
setTimeout(() => {
|
|
127
|
+
console.log('Available themes:', this.availableThemes);
|
|
128
|
+
const matchingTheme = this.availableThemes.find(theme => theme.name.toLowerCase() === this.prefilledTheme.toLowerCase());
|
|
129
|
+
console.log('Matching theme found:', matchingTheme);
|
|
130
|
+
if (matchingTheme) {
|
|
131
|
+
this.selectedTheme = matchingTheme.name;
|
|
132
|
+
this.courseForm.patchValue({
|
|
133
|
+
competencyTheme: matchingTheme.name
|
|
134
|
+
});
|
|
135
|
+
this.onThemeChange(matchingTheme.name);
|
|
136
|
+
console.log('Theme set successfully:', matchingTheme.name);
|
|
137
|
+
// If subTheme is provided, try to set it after themes are loaded
|
|
138
|
+
if (this.prefilledSubTheme) {
|
|
139
|
+
setTimeout(() => {
|
|
140
|
+
console.log('Available subThemes:', this.availableSubThemes);
|
|
141
|
+
const matchingSubTheme = this.availableSubThemes.find(subTheme => subTheme.toLowerCase() === this.prefilledSubTheme.toLowerCase());
|
|
142
|
+
console.log('Matching subTheme found:', matchingSubTheme);
|
|
143
|
+
if (matchingSubTheme) {
|
|
144
|
+
this.selectedSubTheme = matchingSubTheme;
|
|
145
|
+
this.courseForm.patchValue({
|
|
146
|
+
competencySubTheme: matchingSubTheme
|
|
147
|
+
});
|
|
148
|
+
console.log('SubTheme set successfully:', matchingSubTheme);
|
|
149
|
+
}
|
|
150
|
+
else {
|
|
151
|
+
console.log('⚠️ SubTheme not found in available options');
|
|
152
|
+
}
|
|
153
|
+
// Add the prefilled competency with the specified theme and sub-theme
|
|
154
|
+
setTimeout(() => {
|
|
155
|
+
console.log('Adding prefilled competency with theme and subtheme...');
|
|
156
|
+
this.addPrefilledCompetency();
|
|
157
|
+
}, 100);
|
|
158
|
+
}, 300);
|
|
159
|
+
}
|
|
160
|
+
else {
|
|
161
|
+
// Automatically add the prefilled competency with just the theme
|
|
162
|
+
setTimeout(() => {
|
|
163
|
+
console.log('Adding prefilled competency with theme only...');
|
|
164
|
+
this.addPrefilledCompetency();
|
|
165
|
+
}, 200);
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
else {
|
|
169
|
+
console.log('⚠️ Theme not found in available options');
|
|
170
|
+
}
|
|
171
|
+
}, 100);
|
|
172
|
+
}
|
|
173
|
+
addPrefilledCompetency() {
|
|
174
|
+
// For prefilled competencies, use the theme name as the sub-theme
|
|
175
|
+
// This ensures the competency gap is addressed
|
|
176
|
+
const exists = this.competenciesArray.value.some(c => c.theme === this.prefilledTheme && c.type === this.prefilledCompetencyType);
|
|
177
|
+
if (!exists) {
|
|
178
|
+
const newComp = this.fb.group({
|
|
179
|
+
type: [this.prefilledCompetencyType],
|
|
180
|
+
theme: [this.prefilledTheme],
|
|
181
|
+
sub_theme: [this.prefilledTheme] // Use theme as sub_theme for gap filling
|
|
182
|
+
});
|
|
183
|
+
this.competenciesArray.push(newComp);
|
|
184
|
+
this.updateCompetencyCounts();
|
|
185
|
+
this.cdRef.detectChanges();
|
|
186
|
+
console.log('Auto-added prefilled competency:', {
|
|
187
|
+
type: this.prefilledCompetencyType,
|
|
188
|
+
theme: this.prefilledTheme,
|
|
189
|
+
sub_theme: this.prefilledTheme
|
|
190
|
+
});
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
initializeForm() {
|
|
194
|
+
this.courseForm = this.fb.group({
|
|
195
|
+
courseName: ['', Validators.required],
|
|
196
|
+
summary: [''],
|
|
197
|
+
platformName: ['', Validators.required],
|
|
198
|
+
courseUrl: ['', Validators.required],
|
|
199
|
+
competencyType: [''],
|
|
200
|
+
competencyTheme: [''],
|
|
201
|
+
competencySubTheme: [''],
|
|
202
|
+
manualThemeInput: [''],
|
|
203
|
+
manualSubThemeInput: [''],
|
|
204
|
+
themeSearch: [''],
|
|
205
|
+
subThemeSearch: [''],
|
|
206
|
+
competencies: this.fb.array([])
|
|
207
|
+
});
|
|
208
|
+
// Listen to form changes to trigger validation updates
|
|
209
|
+
this.courseForm.valueChanges.subscribe(() => {
|
|
210
|
+
this.cdRef.detectChanges();
|
|
211
|
+
});
|
|
212
|
+
}
|
|
213
|
+
cancelForm() {
|
|
214
|
+
this.dialogRef.close();
|
|
215
|
+
}
|
|
216
|
+
get competenciesArray() {
|
|
217
|
+
return this.courseForm.get('competencies');
|
|
218
|
+
}
|
|
219
|
+
updateCompetencyCounts() {
|
|
220
|
+
const comps = this.competenciesArray.value;
|
|
221
|
+
this.competenciesCount = { total: 0, behavioral: 0, functional: 0, domain: 0 };
|
|
222
|
+
comps.forEach(c => {
|
|
223
|
+
this.competenciesCount.total++;
|
|
224
|
+
if (c.type.toLowerCase() === 'behavioral')
|
|
225
|
+
this.competenciesCount.behavioral++;
|
|
226
|
+
if (c.type.toLowerCase() === 'functional')
|
|
227
|
+
this.competenciesCount.functional++;
|
|
228
|
+
if (c.type.toLowerCase() === 'domain')
|
|
229
|
+
this.competenciesCount.domain++;
|
|
230
|
+
});
|
|
231
|
+
}
|
|
232
|
+
onCompetencyTypeChange(type) {
|
|
233
|
+
this.selectedCompetencyType = type;
|
|
234
|
+
this.selectedTheme = '';
|
|
235
|
+
this.selectedSubTheme = '';
|
|
236
|
+
this.manualTheme = '';
|
|
237
|
+
this.manualSubTheme = '';
|
|
238
|
+
this.availableThemes = [];
|
|
239
|
+
this.availableSubThemes = [];
|
|
240
|
+
this.filteredThemes = [];
|
|
241
|
+
this.filteredSubThemes = [];
|
|
242
|
+
this.themeSearchText = '';
|
|
243
|
+
this.subThemeSearchText = '';
|
|
244
|
+
// Reset form controls
|
|
245
|
+
this.courseForm.patchValue({
|
|
246
|
+
competencyTheme: '',
|
|
247
|
+
competencySubTheme: '',
|
|
248
|
+
manualThemeInput: '',
|
|
249
|
+
manualSubThemeInput: '',
|
|
250
|
+
themeSearch: '',
|
|
251
|
+
subThemeSearch: ''
|
|
252
|
+
});
|
|
253
|
+
if (type === 'Behavioral' || type === 'Functional') {
|
|
254
|
+
// Load themes from JSON for Behavioral and Functional
|
|
255
|
+
const competencyCategory = this.competenciesData.find(cat => cat.name.toLowerCase() === type.toLowerCase() ||
|
|
256
|
+
(type === 'Behavioral' && cat.name === 'Behavioural'));
|
|
257
|
+
if (competencyCategory) {
|
|
258
|
+
this.availableThemes = competencyCategory.competency_theme || [];
|
|
259
|
+
this.filteredThemes = [...this.availableThemes];
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
// For Domain, no themes are loaded - user will enter manually
|
|
263
|
+
}
|
|
264
|
+
onThemeChange(themeName) {
|
|
265
|
+
this.selectedTheme = themeName;
|
|
266
|
+
this.selectedSubTheme = '';
|
|
267
|
+
this.availableSubThemes = [];
|
|
268
|
+
this.filteredSubThemes = [];
|
|
269
|
+
this.subThemeSearchText = '';
|
|
270
|
+
this.courseForm.patchValue({
|
|
271
|
+
competencySubTheme: '',
|
|
272
|
+
subThemeSearch: ''
|
|
273
|
+
});
|
|
274
|
+
// Find the selected theme and load its sub-themes
|
|
275
|
+
const selectedThemeObj = this.availableThemes.find(theme => theme.name === themeName);
|
|
276
|
+
if (selectedThemeObj) {
|
|
277
|
+
this.availableSubThemes = selectedThemeObj.competency_sub_theme || [];
|
|
278
|
+
this.filteredSubThemes = [...this.availableSubThemes];
|
|
279
|
+
}
|
|
280
|
+
}
|
|
281
|
+
onSubThemeChange(subThemeName) {
|
|
282
|
+
this.selectedSubTheme = subThemeName;
|
|
283
|
+
}
|
|
284
|
+
filterThemes(searchText) {
|
|
285
|
+
this.themeSearchText = searchText;
|
|
286
|
+
if (!searchText.trim()) {
|
|
287
|
+
this.filteredThemes = [...this.availableThemes];
|
|
288
|
+
}
|
|
289
|
+
else {
|
|
290
|
+
this.filteredThemes = this.availableThemes.filter(theme => theme.name.toLowerCase().includes(searchText.toLowerCase()));
|
|
291
|
+
}
|
|
292
|
+
}
|
|
293
|
+
filterSubThemes(searchText) {
|
|
294
|
+
this.subThemeSearchText = searchText;
|
|
295
|
+
if (!searchText.trim()) {
|
|
296
|
+
this.filteredSubThemes = [...this.availableSubThemes];
|
|
297
|
+
}
|
|
298
|
+
else {
|
|
299
|
+
this.filteredSubThemes = this.availableSubThemes.filter(subTheme => subTheme.toLowerCase().includes(searchText.toLowerCase()));
|
|
300
|
+
}
|
|
301
|
+
}
|
|
302
|
+
addCompetency() {
|
|
303
|
+
let type = this.selectedCompetencyType;
|
|
304
|
+
let theme = '';
|
|
305
|
+
let subTheme = '';
|
|
306
|
+
if (type === 'Domain') {
|
|
307
|
+
// For Domain, use manual input
|
|
308
|
+
theme = this.courseForm.value.manualThemeInput?.trim();
|
|
309
|
+
subTheme = this.courseForm.value.manualSubThemeInput?.trim();
|
|
310
|
+
}
|
|
311
|
+
else {
|
|
312
|
+
// For Behavioral/Functional, use dropdown selections
|
|
313
|
+
theme = this.selectedTheme;
|
|
314
|
+
subTheme = this.selectedSubTheme;
|
|
315
|
+
}
|
|
316
|
+
if (type && theme && subTheme) {
|
|
317
|
+
const exists = this.competenciesArray.value.some(c => c.theme === theme && c.sub_theme === subTheme && c.type === type);
|
|
318
|
+
if (!exists) {
|
|
319
|
+
const newComp = this.fb.group({
|
|
320
|
+
type: [type],
|
|
321
|
+
theme: [theme],
|
|
322
|
+
sub_theme: [subTheme]
|
|
323
|
+
});
|
|
324
|
+
this.competenciesArray.push(newComp);
|
|
325
|
+
}
|
|
326
|
+
// Clear input fields after adding
|
|
327
|
+
this.resetCompetencyForm();
|
|
328
|
+
}
|
|
329
|
+
const currentValues = this.competenciesArray.value;
|
|
330
|
+
this.courseForm.patchValue({ competencies: [...currentValues] });
|
|
331
|
+
this.updateCompetencyCounts();
|
|
332
|
+
this.cdRef.detectChanges(); // Trigger validation update
|
|
333
|
+
console.log(this.courseForm?.get('competencies')?.value);
|
|
334
|
+
}
|
|
335
|
+
resetCompetencyForm() {
|
|
336
|
+
this.selectedCompetencyType = '';
|
|
337
|
+
this.selectedTheme = '';
|
|
338
|
+
this.selectedSubTheme = '';
|
|
339
|
+
this.manualTheme = '';
|
|
340
|
+
this.manualSubTheme = '';
|
|
341
|
+
this.availableThemes = [];
|
|
342
|
+
this.availableSubThemes = [];
|
|
343
|
+
this.filteredThemes = [];
|
|
344
|
+
this.filteredSubThemes = [];
|
|
345
|
+
this.themeSearchText = '';
|
|
346
|
+
this.subThemeSearchText = '';
|
|
347
|
+
this.courseForm.patchValue({
|
|
348
|
+
competencyType: '',
|
|
349
|
+
competencyTheme: '',
|
|
350
|
+
competencySubTheme: '',
|
|
351
|
+
manualThemeInput: '',
|
|
352
|
+
manualSubThemeInput: '',
|
|
353
|
+
themeSearch: '',
|
|
354
|
+
subThemeSearch: ''
|
|
355
|
+
});
|
|
356
|
+
}
|
|
357
|
+
canAddCompetency() {
|
|
358
|
+
if (!this.selectedCompetencyType)
|
|
359
|
+
return false;
|
|
360
|
+
if (this.selectedCompetencyType === 'Domain') {
|
|
361
|
+
const theme = this.courseForm.value.manualThemeInput?.trim();
|
|
362
|
+
const subTheme = this.courseForm.value.manualSubThemeInput?.trim();
|
|
363
|
+
return !!(theme && subTheme);
|
|
364
|
+
}
|
|
365
|
+
else {
|
|
366
|
+
return !!(this.selectedTheme && this.selectedSubTheme);
|
|
367
|
+
}
|
|
368
|
+
}
|
|
369
|
+
canSaveCourse() {
|
|
370
|
+
// Check if required fields are filled
|
|
371
|
+
const courseName = this.courseForm.value.courseName?.trim();
|
|
372
|
+
const platformName = this.courseForm.value.platformName?.trim();
|
|
373
|
+
const courseUrl = this.courseForm.value.courseUrl?.trim();
|
|
374
|
+
// Check if at least one competency is added
|
|
375
|
+
const hasCompetencies = this.competenciesArray.length > 0;
|
|
376
|
+
return !!(courseName && platformName && courseUrl && hasCompetencies);
|
|
377
|
+
}
|
|
378
|
+
getCompetenciesByType(type) {
|
|
379
|
+
return (this.courseForm?.get('competencies')?.value || []).filter(c => c.type === type);
|
|
380
|
+
}
|
|
381
|
+
deleteCompetency(comp) {
|
|
382
|
+
const index = this.competenciesArray.controls.findIndex(control => control.value.theme === comp.theme && control.value.type === comp.type);
|
|
383
|
+
if (index !== -1) {
|
|
384
|
+
this.competenciesArray.removeAt(index);
|
|
385
|
+
}
|
|
386
|
+
this.updateCompetencyCounts();
|
|
387
|
+
this.cdRef.detectChanges(); // Trigger validation update
|
|
388
|
+
}
|
|
389
|
+
saveCourse() {
|
|
390
|
+
this.loading = true;
|
|
391
|
+
// Transform competencies to the required API format
|
|
392
|
+
const competencies = this.competenciesArray.value.map(comp => ({
|
|
393
|
+
"competencyAreaName": comp.type,
|
|
394
|
+
"competencyThemeName": comp.theme,
|
|
395
|
+
"competencySubThemeName": comp.sub_theme
|
|
396
|
+
}));
|
|
397
|
+
let reqBody = {
|
|
398
|
+
"role_mapping_id": this.planData.id,
|
|
399
|
+
"name": this.courseForm.value.courseName,
|
|
400
|
+
"platform": this.courseForm.value.platformName,
|
|
401
|
+
"public_link": this.courseForm.value.courseUrl,
|
|
402
|
+
"rationale": this.courseForm.value.summary,
|
|
403
|
+
"competencies": competencies
|
|
404
|
+
};
|
|
405
|
+
console.log('Request body:', reqBody);
|
|
406
|
+
// this.sharedService.addUserCourse(reqBody).subscribe(()=>{
|
|
407
|
+
// this.loading = false
|
|
408
|
+
// this.snackBar.open('Course Added Successfully', 'X', {
|
|
409
|
+
// duration: 3000,
|
|
410
|
+
// panelClass: ['snackbar-success']
|
|
411
|
+
// });
|
|
412
|
+
// })
|
|
413
|
+
this.sharedService.addUserCourse(reqBody).subscribe({
|
|
414
|
+
next: () => {
|
|
415
|
+
this.loading = false;
|
|
416
|
+
this.snackBar.open('Course Added Successfully', 'X', {
|
|
417
|
+
duration: 3000,
|
|
418
|
+
panelClass: ['snackbar-success']
|
|
419
|
+
});
|
|
420
|
+
},
|
|
421
|
+
error: (error) => {
|
|
422
|
+
this.loading = false;
|
|
423
|
+
this.snackBar.open(error?.error?.detail, 'X', {
|
|
424
|
+
duration: 3000,
|
|
425
|
+
panelClass: ['snackbar-error']
|
|
426
|
+
});
|
|
427
|
+
}
|
|
428
|
+
});
|
|
429
|
+
this.dialogRef.close('saved');
|
|
430
|
+
}
|
|
431
|
+
closeDialog() {
|
|
432
|
+
this.dialogRef.close();
|
|
433
|
+
}
|
|
434
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AddCourseComponent, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }, { token: i2.SharedService }, { token: i3.FormBuilder }, { token: i4.MatSnackBar }, { token: i5.HttpClient }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
435
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AddCourseComponent, selector: "app-add-course", ngImport: i0, template: "<div class=\"view-cbp-plan\">\n <div class=\"popup-container\">\n <div class=\"popup-header\">\n <div>\n <div class=\"heading\">Add Course</div>\n </div>\n <div class=\"cursor-pointer\" (click)=\"closeDialog()\">\n <mat-icon>close</mat-icon>\n </div>\n </div>\n </div>\n <div class=\"section-container\" [formGroup]=\"courseForm\">\n\n <div class=\"mt-2 section\">\n <div class=\"sub-heading\">\n <p>Course Name</p>\n </div>\n <div class=\"mt-4 additional-details\">\n <input type=\"text\" placeholder=\"Enter Course Name\" formControlName=\"courseName\" [value]=\"\"\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>Summary / Rationale:</p>\n </div>\n <div class=\"mt-4 additional-details\">\n <textarea class=\"custom-textarea\" formControlName=\"summary\" rows=\"5\" placeholder=\"Enter Summary\"\n [value]=\"\"></textarea>\n </div>\n </div>\n <div class=\"mt-2 section\">\n <div class=\"sub-heading\">\n <p>Platform Name</p>\n </div>\n <div class=\"mt-4 additional-details\">\n <input type=\"text\" placeholder=\"Enter Platform Name\" formControlName=\"platformName\" [value]=\"\"\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>Course URL</p>\n </div>\n <div class=\"mt-4 additional-details\">\n <input type=\"text\" placeholder=\"Enter Course Url\" formControlName=\"courseUrl\" [value]=\"\"\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\n\n\n\n\n <div class=\"mt-2 section\">\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=\"sub-heading mt-4\">\n <p>Competency</p>\n </div>\n <div class=\"enhanced-competency-section mt-4\">\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\"\n placeholder=\"Select Competency Type\"\n [disabled]=\"isCompetencyPrefilled\"\n (selectionChange)=\"onCompetencyTypeChange($event.value)\">\n <mat-option value=\"Behavioral\">Behavioural</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 *ngIf=\"isCompetencyPrefilled\" class=\"prefill-info\">\n <small class=\"text-muted\">\n <mat-icon class=\"info-icon\">info</mat-icon>\n Core competency type is pre-selected based on gap analysis\n </small>\n </div>\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\"\n placeholder=\"Search and select theme\"\n [disabled]=\"isCompetencyPrefilled\"\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\n placeholder=\"Search themes...\"\n formControlName=\"themeSearch\"\n (input)=\"filterThemes($event.target.value)\"\n (click)=\"$event.stopPropagation()\"\n (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 *ngIf=\"isCompetencyPrefilled\" class=\"prefill-info\">\n <small class=\"text-muted\">\n <mat-icon class=\"info-icon\">info</mat-icon>\n Theme is pre-selected based on gap analysis\n </small>\n </div>\n </div>\n\n <!-- For Domain: Manual input -->\n <div class=\"manual-input-container\" *ngIf=\"selectedCompetencyType === 'Domain'\">\n <input type=\"text\"\n formControlName=\"manualThemeInput\"\n placeholder=\"Enter Theme manually\"\n [disabled]=\"isCompetencyPrefilled\"\n class=\"manual-input\" />\n <div *ngIf=\"isCompetencyPrefilled\" class=\"prefill-info\">\n <small class=\"text-muted\">\n <mat-icon class=\"info-icon\">info</mat-icon>\n Theme is pre-selected based on gap analysis\n </small>\n </div>\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 [disabled]=\"isCompetencyPrefilled\"\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\n placeholder=\"Search sub-themes...\"\n formControlName=\"subThemeSearch\"\n (input)=\"filterSubThemes($event.target.value)\"\n (click)=\"$event.stopPropagation()\"\n (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 *ngIf=\"isCompetencyPrefilled\" class=\"prefill-info\">\n <small class=\"text-muted\">\n <mat-icon class=\"info-icon\">info</mat-icon>\n Sub-theme is pre-selected based on gap analysis\n </small>\n </div>\n </div>\n\n <!-- For Domain: Manual input -->\n <div class=\"manual-input-container\" *ngIf=\"selectedCompetencyType === 'Domain'\">\n <input type=\"text\"\n formControlName=\"manualSubThemeInput\"\n placeholder=\"Enter Sub-theme manually\"\n [disabled]=\"isCompetencyPrefilled\"\n class=\"manual-input\" />\n <div *ngIf=\"isCompetencyPrefilled\" class=\"prefill-info\">\n <small class=\"text-muted\">\n <mat-icon class=\"info-icon\">info</mat-icon>\n Sub-theme is pre-selected based on gap analysis\n </small>\n </div>\n </div>\n </div>\n\n <!-- Add Button -->\n <div class=\"add-button-section\" *ngIf=\"selectedCompetencyType\">\n <button type=\"button\"\n class=\"add-competency-btn\"\n [disabled]=\"!canAddCompetency()\"\n [ngClass]=\"canAddCompetency() ? 'btn-active' : 'btn-disable'\"\n (click)=\"addCompetency()\">\n Add Competency\n </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\" *ngIf=\"getCompetenciesByType('Domain')?.length\">Domain Competencies</div>\n <div class=\"competency-grid mt-2\">\n <div class=\"competency-item domain-pill\"\n *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 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]=\"canSaveCourse() ? 'btn-active' : 'btn-disable'\" \n type=\"button\" \n value=\"Save\" \n [disabled]=\"!canSaveCourse()\"\n (click)=\"canSaveCourse() && saveCourse()\" />\n </div>\n </div>\n</div>\n<div class=\"overlay-loader\" *ngIf=\"loading\">\n <mat-spinner diameter=\"50\"></mat-spinner>\n</div>", styles: ["@charset \"UTF-8\";.container{margin:10px auto}.sub-heading p{color:#000;font-family:Montserrat;font-size:16px;font-style:normal;font-weight:600;line-height:normal}.radio-label{color:#000;font-family:Lato;font-size:16px;font-style:normal;font-weight:400;line-height:normal}.radio-btn-group{display:flex;width:32px;height:32px;padding:2px;gap:10px}.label{color:var(--Body-Text-Body-Color, #212529);font-family:Lato;font-size:14px;font-style:normal;font-weight:700;line-height:150%}::ng-deep mat-form-field{background-color:#fff!important;border-radius:25px!important;padding-left:12px;padding-right:12px;height:42px;width:100%}::ng-deep mat-select{border-radius:25px!important;background-color:#fff!important}::ng-deep .mat-select-panel{background-color:#fff!important}::ng-deep .mat-select-panel .mat-option{border-radius:0!important}::ng-deep mat-form-field .mat-form-field-underline{display:none!important}::ng-deep mat-select .mat-select-placeholder{color:#0006;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal}::ng-deep mat-select .mat-select-value-text{color:#000;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal;line-height:normal!important;padding-top:0!important;padding-bottom:0!important}::ng-deep mat-select .mat-select-value{display:flex!important;align-items:center!important;height:100%!important}.additional-details textarea{display:flex;padding:16px 16px 0;flex-direction:column;align-items:flex-start;gap:10px;flex:1 0 0;align-self:stretch;width:100%;color:#000;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal;resize:none}.section-header{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.btn-disable{border-radius:var(--Radius-Full-Round, 9999999px);opacity:.4;background:var(--Primary-KB-Primary-Light, #1B4CA1);color:var(--white-kb-white-100, #FFF);text-align:center;font-family:Lato;font-size:14px;font-style:normal;font-weight:700;line-height:normal;display:flex;height:32px;padding:0 16px;justify-content:center;align-items:center;gap:8px;border:none}.btn-group{display:flex;flex-direction:row;justify-content:space-between}.pl-2{padding-left:5px}.search-filter-section{display:flex;flex-direction:row;gap:10px}.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:flex-start;flex-direction:row;flex-wrap:wrap;gap:32px;width:100%;overflow-x:auto}@media (max-width: 768px){.competency-container{flex-direction:column;align-items:stretch;gap:12px}.outside-layer-total,.outside-layer-behavioral,.outside-layer-functional,.outside-layer-domain{width:100%;justify-content:space-between}}@media (max-width: 1024px) and (min-width: 769px){.competency-container{gap:6px}.outside-layer-total,.outside-layer-behavioral,.outside-layer-functional,.outside-layer-domain{padding:3px 8px;gap:12px}.inside-layer{font-size:16px}.count{font-size:20px}}.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;flex-shrink:0;width:20%}.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;flex-shrink:0;width:20%}.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;flex-shrink:0;width:20%}.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;flex-shrink:0;width:20%}.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}: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-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;border:1px solid #ccc;cursor:not-allowed;opacity:.7;box-shadow:none}.prefill-info{margin-top:8px;padding:8px 12px;background:#1b4ca10d;border:1px solid rgba(27,76,161,.2);border-radius:8px}.prefill-info .text-muted{color:#6c757d;font-family:Lato;font-size:12px;display:flex;align-items:center;gap:6px}.prefill-info .text-muted .info-icon{font-size:16px;color:#1b4ca1}.competency-dropdown[disabled] ::ng-deep .mat-form-field-flex{opacity:.7}.competency-dropdown[disabled] ::ng-deep .mat-select{color:#6c757d!important}.manual-input:disabled{background:#f8f9fa!important;border-color:#e9ecef!important;color:#6c757d!important;opacity:.7;cursor:not-allowed}\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: i3.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: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.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: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.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"] }] }); }
|
|
436
|
+
}
|
|
437
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AddCourseComponent, decorators: [{
|
|
438
|
+
type: Component,
|
|
439
|
+
args: [{ selector: 'app-add-course', template: "<div class=\"view-cbp-plan\">\n <div class=\"popup-container\">\n <div class=\"popup-header\">\n <div>\n <div class=\"heading\">Add Course</div>\n </div>\n <div class=\"cursor-pointer\" (click)=\"closeDialog()\">\n <mat-icon>close</mat-icon>\n </div>\n </div>\n </div>\n <div class=\"section-container\" [formGroup]=\"courseForm\">\n\n <div class=\"mt-2 section\">\n <div class=\"sub-heading\">\n <p>Course Name</p>\n </div>\n <div class=\"mt-4 additional-details\">\n <input type=\"text\" placeholder=\"Enter Course Name\" formControlName=\"courseName\" [value]=\"\"\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>Summary / Rationale:</p>\n </div>\n <div class=\"mt-4 additional-details\">\n <textarea class=\"custom-textarea\" formControlName=\"summary\" rows=\"5\" placeholder=\"Enter Summary\"\n [value]=\"\"></textarea>\n </div>\n </div>\n <div class=\"mt-2 section\">\n <div class=\"sub-heading\">\n <p>Platform Name</p>\n </div>\n <div class=\"mt-4 additional-details\">\n <input type=\"text\" placeholder=\"Enter Platform Name\" formControlName=\"platformName\" [value]=\"\"\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>Course URL</p>\n </div>\n <div class=\"mt-4 additional-details\">\n <input type=\"text\" placeholder=\"Enter Course Url\" formControlName=\"courseUrl\" [value]=\"\"\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\n\n\n\n\n <div class=\"mt-2 section\">\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=\"sub-heading mt-4\">\n <p>Competency</p>\n </div>\n <div class=\"enhanced-competency-section mt-4\">\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\"\n placeholder=\"Select Competency Type\"\n [disabled]=\"isCompetencyPrefilled\"\n (selectionChange)=\"onCompetencyTypeChange($event.value)\">\n <mat-option value=\"Behavioral\">Behavioural</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 *ngIf=\"isCompetencyPrefilled\" class=\"prefill-info\">\n <small class=\"text-muted\">\n <mat-icon class=\"info-icon\">info</mat-icon>\n Core competency type is pre-selected based on gap analysis\n </small>\n </div>\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\"\n placeholder=\"Search and select theme\"\n [disabled]=\"isCompetencyPrefilled\"\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\n placeholder=\"Search themes...\"\n formControlName=\"themeSearch\"\n (input)=\"filterThemes($event.target.value)\"\n (click)=\"$event.stopPropagation()\"\n (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 *ngIf=\"isCompetencyPrefilled\" class=\"prefill-info\">\n <small class=\"text-muted\">\n <mat-icon class=\"info-icon\">info</mat-icon>\n Theme is pre-selected based on gap analysis\n </small>\n </div>\n </div>\n\n <!-- For Domain: Manual input -->\n <div class=\"manual-input-container\" *ngIf=\"selectedCompetencyType === 'Domain'\">\n <input type=\"text\"\n formControlName=\"manualThemeInput\"\n placeholder=\"Enter Theme manually\"\n [disabled]=\"isCompetencyPrefilled\"\n class=\"manual-input\" />\n <div *ngIf=\"isCompetencyPrefilled\" class=\"prefill-info\">\n <small class=\"text-muted\">\n <mat-icon class=\"info-icon\">info</mat-icon>\n Theme is pre-selected based on gap analysis\n </small>\n </div>\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 [disabled]=\"isCompetencyPrefilled\"\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\n placeholder=\"Search sub-themes...\"\n formControlName=\"subThemeSearch\"\n (input)=\"filterSubThemes($event.target.value)\"\n (click)=\"$event.stopPropagation()\"\n (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 *ngIf=\"isCompetencyPrefilled\" class=\"prefill-info\">\n <small class=\"text-muted\">\n <mat-icon class=\"info-icon\">info</mat-icon>\n Sub-theme is pre-selected based on gap analysis\n </small>\n </div>\n </div>\n\n <!-- For Domain: Manual input -->\n <div class=\"manual-input-container\" *ngIf=\"selectedCompetencyType === 'Domain'\">\n <input type=\"text\"\n formControlName=\"manualSubThemeInput\"\n placeholder=\"Enter Sub-theme manually\"\n [disabled]=\"isCompetencyPrefilled\"\n class=\"manual-input\" />\n <div *ngIf=\"isCompetencyPrefilled\" class=\"prefill-info\">\n <small class=\"text-muted\">\n <mat-icon class=\"info-icon\">info</mat-icon>\n Sub-theme is pre-selected based on gap analysis\n </small>\n </div>\n </div>\n </div>\n\n <!-- Add Button -->\n <div class=\"add-button-section\" *ngIf=\"selectedCompetencyType\">\n <button type=\"button\"\n class=\"add-competency-btn\"\n [disabled]=\"!canAddCompetency()\"\n [ngClass]=\"canAddCompetency() ? 'btn-active' : 'btn-disable'\"\n (click)=\"addCompetency()\">\n Add Competency\n </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\" *ngIf=\"getCompetenciesByType('Domain')?.length\">Domain Competencies</div>\n <div class=\"competency-grid mt-2\">\n <div class=\"competency-item domain-pill\"\n *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 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]=\"canSaveCourse() ? 'btn-active' : 'btn-disable'\" \n type=\"button\" \n value=\"Save\" \n [disabled]=\"!canSaveCourse()\"\n (click)=\"canSaveCourse() && saveCourse()\" />\n </div>\n </div>\n</div>\n<div class=\"overlay-loader\" *ngIf=\"loading\">\n <mat-spinner diameter=\"50\"></mat-spinner>\n</div>", styles: ["@charset \"UTF-8\";.container{margin:10px auto}.sub-heading p{color:#000;font-family:Montserrat;font-size:16px;font-style:normal;font-weight:600;line-height:normal}.radio-label{color:#000;font-family:Lato;font-size:16px;font-style:normal;font-weight:400;line-height:normal}.radio-btn-group{display:flex;width:32px;height:32px;padding:2px;gap:10px}.label{color:var(--Body-Text-Body-Color, #212529);font-family:Lato;font-size:14px;font-style:normal;font-weight:700;line-height:150%}::ng-deep mat-form-field{background-color:#fff!important;border-radius:25px!important;padding-left:12px;padding-right:12px;height:42px;width:100%}::ng-deep mat-select{border-radius:25px!important;background-color:#fff!important}::ng-deep .mat-select-panel{background-color:#fff!important}::ng-deep .mat-select-panel .mat-option{border-radius:0!important}::ng-deep mat-form-field .mat-form-field-underline{display:none!important}::ng-deep mat-select .mat-select-placeholder{color:#0006;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal}::ng-deep mat-select .mat-select-value-text{color:#000;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal;line-height:normal!important;padding-top:0!important;padding-bottom:0!important}::ng-deep mat-select .mat-select-value{display:flex!important;align-items:center!important;height:100%!important}.additional-details textarea{display:flex;padding:16px 16px 0;flex-direction:column;align-items:flex-start;gap:10px;flex:1 0 0;align-self:stretch;width:100%;color:#000;font-family:Lato;font-size:14px;font-style:normal;font-weight:400;line-height:normal;resize:none}.section-header{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.btn-disable{border-radius:var(--Radius-Full-Round, 9999999px);opacity:.4;background:var(--Primary-KB-Primary-Light, #1B4CA1);color:var(--white-kb-white-100, #FFF);text-align:center;font-family:Lato;font-size:14px;font-style:normal;font-weight:700;line-height:normal;display:flex;height:32px;padding:0 16px;justify-content:center;align-items:center;gap:8px;border:none}.btn-group{display:flex;flex-direction:row;justify-content:space-between}.pl-2{padding-left:5px}.search-filter-section{display:flex;flex-direction:row;gap:10px}.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:flex-start;flex-direction:row;flex-wrap:wrap;gap:32px;width:100%;overflow-x:auto}@media (max-width: 768px){.competency-container{flex-direction:column;align-items:stretch;gap:12px}.outside-layer-total,.outside-layer-behavioral,.outside-layer-functional,.outside-layer-domain{width:100%;justify-content:space-between}}@media (max-width: 1024px) and (min-width: 769px){.competency-container{gap:6px}.outside-layer-total,.outside-layer-behavioral,.outside-layer-functional,.outside-layer-domain{padding:3px 8px;gap:12px}.inside-layer{font-size:16px}.count{font-size:20px}}.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;flex-shrink:0;width:20%}.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;flex-shrink:0;width:20%}.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;flex-shrink:0;width:20%}.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;flex-shrink:0;width:20%}.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}: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-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;border:1px solid #ccc;cursor:not-allowed;opacity:.7;box-shadow:none}.prefill-info{margin-top:8px;padding:8px 12px;background:#1b4ca10d;border:1px solid rgba(27,76,161,.2);border-radius:8px}.prefill-info .text-muted{color:#6c757d;font-family:Lato;font-size:12px;display:flex;align-items:center;gap:6px}.prefill-info .text-muted .info-icon{font-size:16px;color:#1b4ca1}.competency-dropdown[disabled] ::ng-deep .mat-form-field-flex{opacity:.7}.competency-dropdown[disabled] ::ng-deep .mat-select{color:#6c757d!important}.manual-input:disabled{background:#f8f9fa!important;border-color:#e9ecef!important;color:#6c757d!important;opacity:.7;cursor:not-allowed}\n"] }]
|
|
440
|
+
}], ctorParameters: function () { return [{ type: i1.MatDialogRef }, { type: undefined, decorators: [{
|
|
441
|
+
type: Inject,
|
|
442
|
+
args: [MAT_DIALOG_DATA]
|
|
443
|
+
}] }, { type: i2.SharedService }, { type: i3.FormBuilder }, { type: i4.MatSnackBar }, { type: i5.HttpClient }, { type: i0.ChangeDetectorRef }]; } });
|
|
444
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-course.component.js","sourceRoot":"","sources":["../../../../../../../library/sunbird-cb/cbp-ai/src/lib/components/add-course/add-course.component.ts","../../../../../../../library/sunbird-cb/cbp-ai/src/lib/components/add-course/add-course.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, ChangeDetectorRef, OnInit } from '@angular/core';\nimport { FormBuilder, FormGroup, Validators, FormArray } from '@angular/forms';\nimport { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\nimport { MatSnackBar } from '@angular/material/snack-bar';\nimport { HttpClient } from '@angular/common/http';\nimport { SharedService } from '../../modules/shared/services/shared.service';\n\n@Component({\n  selector: 'app-add-course',\n  templateUrl: './add-course.component.html',\n  styleUrls: ['./add-course.component.scss']\n})\nexport class AddCourseComponent implements OnInit {\n  courseForm: FormGroup;\n  loading = false\n  planData:any\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  competenciesCount = {total:0, behavioral:0, functional:0, domain:0};\n  \n  // Prefill properties\n  isCompetencyPrefilled = false;\n  prefilledCompetencyType = '';\n  prefilledTheme = '';\n  prefilledSubTheme = '';\n  constructor(public dialogRef: MatDialogRef<AddCourseComponent>,\n    @Inject(MAT_DIALOG_DATA) public data: any,\n    public sharedService: SharedService,\n    private fb: FormBuilder,\n    public snackBar: MatSnackBar,\n    private http: HttpClient,\n    private cdRef: ChangeDetectorRef) {\n      this.planData = data\n      this.initializeForm();\n  }\n  \n  ngOnInit() {\n    this.loadCompetenciesData();\n    this.updateCompetencyCounts();\n    this.checkForPrefilledData();\n  }\n  \n  checkForPrefilledData() {\n    console.log('=== CheckForPrefilledData ===');\n    console.log('Full data object:', this.data);\n    \n    if (this.data && this.data.prefillCompetency) {\n      console.log('✅ Prefill competency data found:', this.data.prefillCompetency);\n      \n      this.isCompetencyPrefilled = true;\n      this.prefilledCompetencyType = this.data.prefillCompetency.type;\n      this.prefilledTheme = this.data.prefillCompetency.theme;\n      this.prefilledSubTheme = this.data.prefillCompetency.subTheme || '';\n      \n      console.log('Processed prefill data:', {\n        isCompetencyPrefilled: this.isCompetencyPrefilled,\n        prefilledCompetencyType: this.prefilledCompetencyType,\n        prefilledTheme: this.prefilledTheme,\n        prefilledSubTheme: this.prefilledSubTheme\n      });\n      \n      // Set the competency type and trigger the theme loading\n      this.selectedCompetencyType = this.prefilledCompetencyType;\n      this.courseForm.patchValue({\n        competencyType: this.prefilledCompetencyType\n      });\n      \n      console.log('Form updated with competency type:', this.prefilledCompetencyType);\n      \n      // For Domain competencies, set manual theme and subtheme inputs and auto-add\n      if (this.prefilledCompetencyType === 'Domain') {\n        console.log('Setting Domain manual inputs...');\n        this.courseForm.patchValue({\n          manualThemeInput: this.prefilledTheme,\n          manualSubThemeInput: this.prefilledSubTheme\n        });\n        console.log('Domain form values set:', {\n          manualThemeInput: this.prefilledTheme,\n          manualSubThemeInput: this.prefilledSubTheme\n        });\n        \n        // Auto-add the domain competency\n        setTimeout(() => {\n          console.log('Adding prefilled Domain competency...');\n          this.addPrefilledCompetency();\n        }, 100);\n      } else {\n        console.log('Will handle Behavioral/Functional after competencies data loads...');\n        // For Behavioral/Functional, wait for competencies data to load\n        // The theme and subtheme will be set in loadCompetenciesData after data is available\n      }\n    } else {\n      console.log('❌ No prefill competency data found');\n      console.log('data.prefillCompetency:', this.data?.prefillCompetency);\n    }\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        // Handle prefilled data after competencies are loaded\n        if (this.isCompetencyPrefilled && this.prefilledCompetencyType !== 'Domain') {\n          this.handlePrefilledBehavioralFunctional();\n        }\n      },\n      error: (error) => {\n        console.error('Error loading competencies data:', error);\n      }\n    });\n  }\n  \n  handlePrefilledBehavioralFunctional() {\n    console.log('=== HandlePrefilledBehavioralFunctional ===');\n    console.log('Prefilled competency type:', this.prefilledCompetencyType);\n    console.log('Prefilled theme:', this.prefilledTheme);\n    console.log('Prefilled subTheme:', this.prefilledSubTheme);\n    \n    // Load themes for the prefilled competency type\n    this.onCompetencyTypeChange(this.prefilledCompetencyType);\n    \n    // Find and set the theme if it exists in the data\n    setTimeout(() => {\n      console.log('Available themes:', this.availableThemes);\n      \n      const matchingTheme = this.availableThemes.find(theme => \n        theme.name.toLowerCase() === this.prefilledTheme.toLowerCase()\n      );\n      \n      console.log('Matching theme found:', matchingTheme);\n      \n      if (matchingTheme) {\n        this.selectedTheme = matchingTheme.name;\n        this.courseForm.patchValue({\n          competencyTheme: matchingTheme.name\n        });\n        this.onThemeChange(matchingTheme.name);\n        \n        console.log('Theme set successfully:', matchingTheme.name);\n        \n        // If subTheme is provided, try to set it after themes are loaded\n        if (this.prefilledSubTheme) {\n          setTimeout(() => {\n            console.log('Available subThemes:', this.availableSubThemes);\n            \n            const matchingSubTheme = this.availableSubThemes.find(subTheme => \n              subTheme.toLowerCase() === this.prefilledSubTheme.toLowerCase()\n            );\n            \n            console.log('Matching subTheme found:', matchingSubTheme);\n            \n            if (matchingSubTheme) {\n              this.selectedSubTheme = matchingSubTheme;\n              this.courseForm.patchValue({\n                competencySubTheme: matchingSubTheme\n              });\n              console.log('SubTheme set successfully:', matchingSubTheme);\n            } else {\n              console.log('⚠️ SubTheme not found in available options');\n            }\n            \n            // Add the prefilled competency with the specified theme and sub-theme\n            setTimeout(() => {\n              console.log('Adding prefilled competency with theme and subtheme...');\n              this.addPrefilledCompetency();\n            }, 100);\n          }, 300);\n        } else {\n          // Automatically add the prefilled competency with just the theme\n          setTimeout(() => {\n            console.log('Adding prefilled competency with theme only...');\n            this.addPrefilledCompetency();\n          }, 200);\n        }\n      } else {\n        console.log('⚠️ Theme not found in available options');\n      }\n    }, 100);\n  }\n  \n  addPrefilledCompetency() {\n    // For prefilled competencies, use the theme name as the sub-theme\n    // This ensures the competency gap is addressed\n    const exists = this.competenciesArray.value.some(c => \n      c.theme === this.prefilledTheme && c.type === this.prefilledCompetencyType\n    );\n    \n    if (!exists) {\n      const newComp = this.fb.group({\n        type: [this.prefilledCompetencyType],\n        theme: [this.prefilledTheme],\n        sub_theme: [this.prefilledTheme] // Use theme as sub_theme for gap filling\n      });\n      this.competenciesArray.push(newComp);\n      this.updateCompetencyCounts();\n      this.cdRef.detectChanges();\n      \n      console.log('Auto-added prefilled competency:', {\n        type: this.prefilledCompetencyType,\n        theme: this.prefilledTheme,\n        sub_theme: this.prefilledTheme\n      });\n    }\n  }\n  \n  initializeForm() {\n    this.courseForm = this.fb.group({\n      courseName: ['', Validators.required],\n      summary: [''],\n      platformName: ['', Validators.required],\n      courseUrl: ['', Validators.required],\n      competencyType: [''],\n      competencyTheme: [''],\n      competencySubTheme: [''],\n      manualThemeInput: [''],\n      manualSubThemeInput: [''],\n      themeSearch: [''],\n      subThemeSearch: [''],\n      competencies: this.fb.array([])\n    });\n\n    // Listen to form changes to trigger validation updates\n    this.courseForm.valueChanges.subscribe(() => {\n      this.cdRef.detectChanges();\n    });\n  }\n  cancelForm() {\n    this.dialogRef.close()\n  }\n\n  get competenciesArray(): FormArray {\n    return this.courseForm.get('competencies') as FormArray;\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  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.courseForm.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.courseForm.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  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  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.courseForm.value.manualThemeInput?.trim();\n      subTheme = this.courseForm.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.courseForm.patchValue({ competencies: [...currentValues] });\n    \n    this.updateCompetencyCounts();\n    this.cdRef.detectChanges(); // Trigger validation update\n    console.log(this.courseForm?.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.courseForm.patchValue({\n      competencyType: '',\n      competencyTheme: '',\n      competencySubTheme: '',\n      manualThemeInput: '',\n      manualSubThemeInput: '',\n      themeSearch: '',\n      subThemeSearch: ''\n    });\n  }\n  \n  canAddCompetency(): boolean {\n    if (!this.selectedCompetencyType) return false;\n    \n    if (this.selectedCompetencyType === 'Domain') {\n      const theme = this.courseForm.value.manualThemeInput?.trim();\n      const subTheme = this.courseForm.value.manualSubThemeInput?.trim();\n      return !!(theme && subTheme);\n    } else {\n      return !!(this.selectedTheme && this.selectedSubTheme);\n    }\n  }\n\n  canSaveCourse(): boolean {\n    // Check if required fields are filled\n    const courseName = this.courseForm.value.courseName?.trim();\n    const platformName = this.courseForm.value.platformName?.trim();\n    const courseUrl = this.courseForm.value.courseUrl?.trim();\n    \n    // Check if at least one competency is added\n    const hasCompetencies = this.competenciesArray.length > 0;\n    \n    return !!(courseName && platformName && courseUrl && hasCompetencies);\n  }\n  \n  getCompetenciesByType(type: string): any[] {\n    return (this.courseForm?.get('competencies')?.value || []).filter(c => c.type === type);\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(); // Trigger validation update\n  }\n  \n  saveCourse() {\n    this.loading = true\n    \n    // Transform competencies to the required API format\n    const competencies = this.competenciesArray.value.map(comp => ({\n      \"competencyAreaName\": comp.type,\n      \"competencyThemeName\": comp.theme,\n      \"competencySubThemeName\": comp.sub_theme\n    }));\n    \n    let reqBody = {\n      \"role_mapping_id\": this.planData.id,\n      \"name\": this.courseForm.value.courseName,\n      \"platform\": this.courseForm.value.platformName,\n      \"public_link\": this.courseForm.value.courseUrl,\n      \"rationale\": this.courseForm.value.summary,\n      \"competencies\": competencies\n    }\n    \n    console.log('Request body:', reqBody);\n    \n    // this.sharedService.addUserCourse(reqBody).subscribe(()=>{\n    //   this.loading = false\n    //   this.snackBar.open('Course Added Successfully', 'X', {\n    //     duration: 3000,\n    //     panelClass: ['snackbar-success']\n    //   });\n    // })\n\n    this.sharedService.addUserCourse(reqBody).subscribe({\n      next: () => {\n        this.loading = false\n        this.snackBar.open('Course Added Successfully', 'X', {\n          duration: 3000,\n          panelClass: ['snackbar-success']\n        });\n      },\n      error: (error) => {\n        this.loading = false\n        this.snackBar.open(error?.error?.detail, 'X', {\n          duration: 3000,\n          panelClass: ['snackbar-error']\n        });\n      }\n    });\n    this.dialogRef.close('saved')\n  }\n\n  closeDialog() {\n    this.dialogRef.close()\n  }\n}\n","<div class=\"view-cbp-plan\">\n    <div class=\"popup-container\">\n        <div class=\"popup-header\">\n            <div>\n                <div class=\"heading\">Add Course</div>\n            </div>\n            <div class=\"cursor-pointer\" (click)=\"closeDialog()\">\n                <mat-icon>close</mat-icon>\n            </div>\n        </div>\n    </div>\n    <div class=\"section-container\" [formGroup]=\"courseForm\">\n\n        <div class=\"mt-2 section\">\n            <div class=\"sub-heading\">\n                <p>Course Name</p>\n            </div>\n            <div class=\"mt-4 additional-details\">\n                <input type=\"text\" placeholder=\"Enter Course Name\" formControlName=\"courseName\" [value]=\"\"\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>Summary / Rationale:</p>\n            </div>\n            <div class=\"mt-4 additional-details\">\n                <textarea class=\"custom-textarea\" formControlName=\"summary\" rows=\"5\" placeholder=\"Enter Summary\"\n                    [value]=\"\"></textarea>\n            </div>\n        </div>\n        <div class=\"mt-2 section\">\n            <div class=\"sub-heading\">\n                <p>Platform Name</p>\n            </div>\n            <div class=\"mt-4 additional-details\">\n                <input type=\"text\" placeholder=\"Enter Platform Name\" formControlName=\"platformName\" [value]=\"\"\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>Course URL</p>\n            </div>\n            <div class=\"mt-4 additional-details\">\n                <input type=\"text\" placeholder=\"Enter Course Url\" formControlName=\"courseUrl\" [value]=\"\"\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\n\n\n\n\n        <div class=\"mt-2 section\">\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=\"sub-heading mt-4\">\n                <p>Competency</p>\n            </div>\n            <div class=\"enhanced-competency-section mt-4\">\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\"\n                                    placeholder=\"Select Competency Type\"\n                                    [disabled]=\"isCompetencyPrefilled\"\n                                    (selectionChange)=\"onCompetencyTypeChange($event.value)\">\n                                <mat-option value=\"Behavioral\">Behavioural</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 *ngIf=\"isCompetencyPrefilled\" class=\"prefill-info\">\n                            <small class=\"text-muted\">\n                                <mat-icon class=\"info-icon\">info</mat-icon>\n                                Core competency type is pre-selected based on gap analysis\n                            </small>\n                        </div>\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\"\n                                    placeholder=\"Search and select theme\"\n                                    [disabled]=\"isCompetencyPrefilled\"\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\n                                               placeholder=\"Search themes...\"\n                                               formControlName=\"themeSearch\"\n                                               (input)=\"filterThemes($event.target.value)\"\n                                               (click)=\"$event.stopPropagation()\"\n                                               (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 *ngIf=\"isCompetencyPrefilled\" class=\"prefill-info\">\n                            <small class=\"text-muted\">\n                                <mat-icon class=\"info-icon\">info</mat-icon>\n                                Theme is pre-selected based on gap analysis\n                            </small>\n                        </div>\n                    </div>\n\n                    <!-- For Domain: Manual input -->\n                    <div class=\"manual-input-container\" *ngIf=\"selectedCompetencyType === 'Domain'\">\n                        <input type=\"text\"\n                               formControlName=\"manualThemeInput\"\n                               placeholder=\"Enter Theme manually\"\n                               [disabled]=\"isCompetencyPrefilled\"\n                               class=\"manual-input\" />\n                        <div *ngIf=\"isCompetencyPrefilled\" class=\"prefill-info\">\n                            <small class=\"text-muted\">\n                                <mat-icon class=\"info-icon\">info</mat-icon>\n                                Theme is pre-selected based on gap analysis\n                            </small>\n                        </div>\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                                    [disabled]=\"isCompetencyPrefilled\"\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\n                                               placeholder=\"Search sub-themes...\"\n                                               formControlName=\"subThemeSearch\"\n                                               (input)=\"filterSubThemes($event.target.value)\"\n                                               (click)=\"$event.stopPropagation()\"\n                                               (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 *ngIf=\"isCompetencyPrefilled\" class=\"prefill-info\">\n                            <small class=\"text-muted\">\n                                <mat-icon class=\"info-icon\">info</mat-icon>\n                                Sub-theme is pre-selected based on gap analysis\n                            </small>\n                        </div>\n                    </div>\n\n                    <!-- For Domain: Manual input -->\n                    <div class=\"manual-input-container\" *ngIf=\"selectedCompetencyType === 'Domain'\">\n                        <input type=\"text\"\n                               formControlName=\"manualSubThemeInput\"\n                               placeholder=\"Enter Sub-theme manually\"\n                               [disabled]=\"isCompetencyPrefilled\"\n                               class=\"manual-input\" />\n                        <div *ngIf=\"isCompetencyPrefilled\" class=\"prefill-info\">\n                            <small class=\"text-muted\">\n                                <mat-icon class=\"info-icon\">info</mat-icon>\n                                Sub-theme is pre-selected based on gap analysis\n                            </small>\n                        </div>\n                    </div>\n                </div>\n\n                <!-- Add Button -->\n                <div class=\"add-button-section\" *ngIf=\"selectedCompetencyType\">\n                    <button type=\"button\"\n                            class=\"add-competency-btn\"\n                            [disabled]=\"!canAddCompetency()\"\n                            [ngClass]=\"canAddCompetency() ? 'btn-active' : 'btn-disable'\"\n                            (click)=\"addCompetency()\">\n                        Add Competency\n                    </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\" *ngIf=\"getCompetenciesByType('Domain')?.length\">Domain Competencies</div>\n                <div class=\"competency-grid mt-2\">\n                    <div class=\"competency-item domain-pill\"\n                        *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 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]=\"canSaveCourse() ? 'btn-active' : 'btn-disable'\" \n                   type=\"button\" \n                   value=\"Save\" \n                   [disabled]=\"!canSaveCourse()\"\n                   (click)=\"canSaveCourse() && saveCourse()\" />\n        </div>\n    </div>\n</div>\n<div class=\"overlay-loader\" *ngIf=\"loading\">\n    <mat-spinner diameter=\"50\"></mat-spinner>\n</div>"]}
|