@sunbird-cb/tree-hierarchy 0.0.1-cbrelease-4.8.29 → 0.0.2-ang-17-20

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (122) hide show
  1. package/fesm2022/sunbird-cb-tree-hierarchy.mjs +770 -200
  2. package/fesm2022/sunbird-cb-tree-hierarchy.mjs.map +1 -1
  3. package/index.d.ts +1052 -3
  4. package/index.d.ts.map +1 -0
  5. package/package.json +14 -16
  6. package/sunbird-cb-tree-hierarchy-0.0.2-ang-17-20.tgz +0 -0
  7. package/esm2022/lib/components/action-bar/action-bar.component.mjs +0 -41
  8. package/esm2022/lib/components/approval/approval.component.mjs +0 -19
  9. package/esm2022/lib/components/approve-view/approve-view.component.mjs +0 -64
  10. package/esm2022/lib/components/categories-preview/categories-preview.component.mjs +0 -44
  11. package/esm2022/lib/components/category-edit/category-edit-module/category-edit-module.component.mjs +0 -55
  12. package/esm2022/lib/components/conforamtion-popup/conforamtion-popup.component.mjs +0 -74
  13. package/esm2022/lib/components/connector/connector.component.mjs +0 -59
  14. package/esm2022/lib/components/create-categories/create-categories.component.mjs +0 -83
  15. package/esm2022/lib/components/create-term/create-term.component.mjs +0 -847
  16. package/esm2022/lib/components/create-term-from-framework/create-term-from-framework.component.mjs +0 -824
  17. package/esm2022/lib/components/org-hierarchy-add-modal/org-hierarchy-add-modal.component.mjs +0 -223
  18. package/esm2022/lib/components/pending-approval/pending-approval.component.mjs +0 -64
  19. package/esm2022/lib/components/term-card/term-card.component.mjs +0 -340
  20. package/esm2022/lib/components/tree-column-view/tree-column-view.component.mjs +0 -354
  21. package/esm2022/lib/components/tree-view/tree-view.component.mjs +0 -826
  22. package/esm2022/lib/constants/app-constant.mjs +0 -40
  23. package/esm2022/lib/constants/data.mjs +0 -6972
  24. package/esm2022/lib/containers/config-framework/config-framework.component.mjs +0 -92
  25. package/esm2022/lib/containers/dashboard/dashboard.component.mjs +0 -14
  26. package/esm2022/lib/labels/strings.mjs +0 -40
  27. package/esm2022/lib/models/approval.model.mjs +0 -2
  28. package/esm2022/lib/models/connection-type.model.mjs +0 -2
  29. package/esm2022/lib/models/connection.model.mjs +0 -2
  30. package/esm2022/lib/models/framework.model.mjs +0 -2
  31. package/esm2022/lib/models/variable-type.model.mjs +0 -2
  32. package/esm2022/lib/pipes/order-by.pipe.mjs +0 -35
  33. package/esm2022/lib/services/approval.service.mjs +0 -47
  34. package/esm2022/lib/services/connection.service.mjs +0 -3
  35. package/esm2022/lib/services/connector.service.mjs +0 -286
  36. package/esm2022/lib/services/framework.service.mjs +0 -525
  37. package/esm2022/lib/services/local-connection.service.mjs +0 -75
  38. package/esm2022/lib/services/odcs.service.mjs +0 -23
  39. package/esm2022/lib/tree-hierarchy-routing.module.mjs +0 -43
  40. package/esm2022/lib/tree-hierarchy.component.mjs +0 -24
  41. package/esm2022/lib/tree-hierarchy.module.mjs +0 -145
  42. package/esm2022/lib/tree-hierarchy.service.mjs +0 -57
  43. package/esm2022/material.module.mjs +0 -199
  44. package/esm2022/public-api.mjs +0 -9
  45. package/esm2022/sunbird-cb-tree-hierarchy.mjs +0 -2
  46. package/lib/components/action-bar/action-bar.component.d.ts +0 -17
  47. package/lib/components/action-bar/action-bar.component.d.ts.map +0 -1
  48. package/lib/components/approval/approval.component.d.ts +0 -10
  49. package/lib/components/approval/approval.component.d.ts.map +0 -1
  50. package/lib/components/approve-view/approve-view.component.d.ts +0 -27
  51. package/lib/components/approve-view/approve-view.component.d.ts.map +0 -1
  52. package/lib/components/categories-preview/categories-preview.component.d.ts +0 -14
  53. package/lib/components/categories-preview/categories-preview.component.d.ts.map +0 -1
  54. package/lib/components/category-edit/category-edit-module/category-edit-module.component.d.ts +0 -18
  55. package/lib/components/category-edit/category-edit-module/category-edit-module.component.d.ts.map +0 -1
  56. package/lib/components/conforamtion-popup/conforamtion-popup.component.d.ts +0 -20
  57. package/lib/components/conforamtion-popup/conforamtion-popup.component.d.ts.map +0 -1
  58. package/lib/components/connector/connector.component.d.ts +0 -23
  59. package/lib/components/connector/connector.component.d.ts.map +0 -1
  60. package/lib/components/create-categories/create-categories.component.d.ts +0 -26
  61. package/lib/components/create-categories/create-categories.component.d.ts.map +0 -1
  62. package/lib/components/create-term/create-term.component.d.ts +0 -148
  63. package/lib/components/create-term/create-term.component.d.ts.map +0 -1
  64. package/lib/components/create-term-from-framework/create-term-from-framework.component.d.ts +0 -105
  65. package/lib/components/create-term-from-framework/create-term-from-framework.component.d.ts.map +0 -1
  66. package/lib/components/org-hierarchy-add-modal/org-hierarchy-add-modal.component.d.ts +0 -46
  67. package/lib/components/org-hierarchy-add-modal/org-hierarchy-add-modal.component.d.ts.map +0 -1
  68. package/lib/components/pending-approval/pending-approval.component.d.ts +0 -21
  69. package/lib/components/pending-approval/pending-approval.component.d.ts.map +0 -1
  70. package/lib/components/term-card/term-card.component.d.ts +0 -53
  71. package/lib/components/term-card/term-card.component.d.ts.map +0 -1
  72. package/lib/components/tree-column-view/tree-column-view.component.d.ts +0 -56
  73. package/lib/components/tree-column-view/tree-column-view.component.d.ts.map +0 -1
  74. package/lib/components/tree-view/tree-view.component.d.ts +0 -102
  75. package/lib/components/tree-view/tree-view.component.d.ts.map +0 -1
  76. package/lib/constants/app-constant.d.ts +0 -44
  77. package/lib/constants/app-constant.d.ts.map +0 -1
  78. package/lib/constants/data.d.ts +0 -117
  79. package/lib/constants/data.d.ts.map +0 -1
  80. package/lib/containers/config-framework/config-framework.component.d.ts +0 -32
  81. package/lib/containers/config-framework/config-framework.component.d.ts.map +0 -1
  82. package/lib/containers/dashboard/dashboard.component.d.ts +0 -9
  83. package/lib/containers/dashboard/dashboard.component.d.ts.map +0 -1
  84. package/lib/labels/strings.d.ts +0 -40
  85. package/lib/labels/strings.d.ts.map +0 -1
  86. package/lib/models/approval.model.d.ts +0 -11
  87. package/lib/models/approval.model.d.ts.map +0 -1
  88. package/lib/models/connection-type.model.d.ts +0 -6
  89. package/lib/models/connection-type.model.d.ts.map +0 -1
  90. package/lib/models/connection.model.d.ts +0 -7
  91. package/lib/models/connection.model.d.ts.map +0 -1
  92. package/lib/models/framework.model.d.ts +0 -89
  93. package/lib/models/framework.model.d.ts.map +0 -1
  94. package/lib/models/variable-type.model.d.ts +0 -46
  95. package/lib/models/variable-type.model.d.ts.map +0 -1
  96. package/lib/pipes/order-by.pipe.d.ts +0 -10
  97. package/lib/pipes/order-by.pipe.d.ts.map +0 -1
  98. package/lib/services/approval.service.d.ts +0 -21
  99. package/lib/services/approval.service.d.ts.map +0 -1
  100. package/lib/services/connection.service.d.ts +0 -4
  101. package/lib/services/connection.service.d.ts.map +0 -1
  102. package/lib/services/connector.service.d.ts +0 -18
  103. package/lib/services/connector.service.d.ts.map +0 -1
  104. package/lib/services/framework.service.d.ts +0 -89
  105. package/lib/services/framework.service.d.ts.map +0 -1
  106. package/lib/services/local-connection.service.d.ts +0 -18
  107. package/lib/services/local-connection.service.d.ts.map +0 -1
  108. package/lib/services/odcs.service.d.ts +0 -11
  109. package/lib/services/odcs.service.d.ts.map +0 -1
  110. package/lib/tree-hierarchy-routing.module.d.ts +0 -8
  111. package/lib/tree-hierarchy-routing.module.d.ts.map +0 -1
  112. package/lib/tree-hierarchy.component.d.ts +0 -13
  113. package/lib/tree-hierarchy.component.d.ts.map +0 -1
  114. package/lib/tree-hierarchy.module.d.ts +0 -33
  115. package/lib/tree-hierarchy.module.d.ts.map +0 -1
  116. package/lib/tree-hierarchy.service.d.ts +0 -21
  117. package/lib/tree-hierarchy.service.d.ts.map +0 -1
  118. package/material.module.d.ts +0 -52
  119. package/material.module.d.ts.map +0 -1
  120. package/public-api.d.ts +0 -9
  121. package/public-api.d.ts.map +0 -1
  122. package/sunbird-cb-tree-hierarchy.d.ts.map +0 -1
@@ -1,847 +0,0 @@
1
- import { Component, Inject } from '@angular/core';
2
- import { MAT_LEGACY_DIALOG_DATA as MAT_DIALOG_DATA } from '@angular/material/legacy-dialog';
3
- import { startWith, map } from 'rxjs/operators';
4
- import { Validators } from '@angular/forms';
5
- import * as appConstants from '../../constants/app-constant';
6
- import { labels } from '../../labels/strings';
7
- import * as _ from 'lodash';
8
- import * as i0 from "@angular/core";
9
- import * as i1 from "@angular/material/legacy-dialog";
10
- import * as i2 from "../../services/framework.service";
11
- import * as i3 from "@angular/forms";
12
- import * as i4 from "../../services/odcs.service";
13
- import * as i5 from "@angular/material/legacy-snack-bar";
14
- import * as i6 from "@angular/common";
15
- import * as i7 from "@angular/material/autocomplete";
16
- import * as i8 from "@angular/material/core";
17
- import * as i9 from "@angular/material/button";
18
- import * as i10 from "@angular/material/dialog";
19
- import * as i11 from "@angular/material/expansion";
20
- import * as i12 from "@angular/material/icon";
21
- import * as i13 from "@angular/material/input";
22
- import * as i14 from "@angular/material/form-field";
23
- import * as i15 from "@angular/cdk/text-field";
24
- import * as i16 from "@angular/material/progress-spinner";
25
- import * as i17 from "@angular/material/radio";
26
- import * as i18 from "@angular/material/select";
27
- import * as i19 from "@angular/material/tooltip";
28
- export class CreateTermComponent {
29
- constructor(dialogRef, data, frameWorkService, fb, odcsService, _snackBar, cdr) {
30
- this.dialogRef = dialogRef;
31
- this.data = data;
32
- this.frameWorkService = frameWorkService;
33
- this.fb = fb;
34
- this.odcsService = odcsService;
35
- this._snackBar = _snackBar;
36
- this.cdr = cdr;
37
- this.name = '';
38
- this.termLists = [];
39
- this.createThemeForm = this.fb.group({});
40
- this.createThemeFormMulti = this.fb.group({});
41
- this.disableCreate = false;
42
- this.disableUpdate = false;
43
- this.disableMultiCreate = false;
44
- this.isTermExist = false;
45
- this.selectedTerm = {};
46
- this.app_strings = labels;
47
- this.colCode = '';
48
- this.savedDesignations = [];
49
- this.addedDesignationCount = 0;
50
- this.designationsList = [];
51
- this.panelOpenState = [];
52
- this.allCompetency = [];
53
- this.allCompetencyTheme = [];
54
- this.filteredallCompetencyTheme = [];
55
- this.allCompetencySubtheme = [];
56
- this.filteredallCompetencySubTheme = [];
57
- this.competencyForm = this.fb.group({});
58
- this.compLabeltext = '';
59
- this.masterList = [];
60
- this.filteredMasterList = [];
61
- this.expansionTitle = '';
62
- this.debounceDelay = 500;
63
- this.values = '';
64
- this.toolTipText = `You can customize this display name for learners to see, as it's what they will view.`;
65
- this.previousCategoryCode = '';
66
- this.previousTermCode = '';
67
- this.previousCatCode = '';
68
- this.previousTermCatCode = '';
69
- this.selectedTermArray = [];
70
- this.getKcmSearch();
71
- }
72
- ngOnInit() {
73
- this.termLists = this.data.columnInfo.children;
74
- this.compLabeltext = this.data.columnInfo.config.labelName;
75
- this.initTermForm();
76
- }
77
- ngAfterViewInit() {
78
- this.cdr.detectChanges();
79
- }
80
- initTermForm() {
81
- this.createTermForm = this.fb.group({
82
- name: ['', [Validators.required]],
83
- description: ['']
84
- });
85
- this.createThemeForm = this.fb.group({
86
- name: ['', [Validators.required]],
87
- dname: [{ value: '', disabled: true }, [Validators.required]],
88
- description: ['']
89
- });
90
- this.createThemeFormMulti = this.fb.group({
91
- themeFields: this.fb.array([this.createThemeFields()])
92
- });
93
- this.filtedTermLists = this.createTermForm.get('name').valueChanges.pipe(startWith(''), map(value => {
94
- if (value && this.createTermForm.controls.dname) {
95
- this.createTermForm.controls.dname.enable();
96
- }
97
- else if (this.createTermForm.controls.dname) {
98
- this.createTermForm.controls.dname.disable();
99
- }
100
- return this._filter(value || '');
101
- }));
102
- if (this.data &&
103
- (this.data.mode === 'view')) {
104
- switch (this.data.columnInfo.code) {
105
- case 'theme':
106
- this.updateFormView(this.createThemeForm, this.data);
107
- break;
108
- case 'subtheme':
109
- this.updateFormView(this.createThemeForm, this.data);
110
- break;
111
- default:
112
- this.updateFormView(this.createThemeForm, this.data);
113
- break;
114
- }
115
- this.disableCreate = true;
116
- }
117
- else if (this.data &&
118
- (this.data.mode === 'edit')) {
119
- switch (this.data.columnInfo.code) {
120
- case 'theme':
121
- this.updateFormEdit(this.createThemeForm, this.data);
122
- break;
123
- case 'subtheme':
124
- this.updateFormEdit(this.createThemeForm, this.data);
125
- break;
126
- default:
127
- this.updateFormEdit(this.createThemeForm, this.data);
128
- break;
129
- }
130
- }
131
- else if (this.data &&
132
- (this.data.mode === 'multi-create')) {
133
- }
134
- }
135
- getComptencyData() {
136
- }
137
- get themeFields() {
138
- return this.createThemeFormMulti.get('themeFields');
139
- }
140
- get themeFieldsControls() {
141
- const themeFields = this.createThemeFormMulti.get('themeFields');
142
- return themeFields['controls'];
143
- }
144
- createThemeFields() {
145
- return this.fb.group({
146
- name: ['', [Validators.required]],
147
- dname: [{ value: '', disabled: true }, [Validators.required]],
148
- description: ['',]
149
- });
150
- }
151
- addThemeFields() {
152
- this.values = '';
153
- this.filteredMasterList = [...this.masterList];
154
- if (this.data.mode === 'multi-create') {
155
- this.themeFields.insert(0, this.createThemeFields());
156
- }
157
- }
158
- removeThemeFields(index) {
159
- if (this.data.mode === 'multi-create') {
160
- this.themeFields.removeAt(index);
161
- }
162
- }
163
- getCreateName(name) {
164
- switch (name) {
165
- case 'Theme':
166
- return `Add Competency ${name}`;
167
- case 'Sub Theme':
168
- return `Add Competency ${name}`;
169
- default:
170
- return `Add ${name}`;
171
- }
172
- }
173
- getCategoryName(categoryName, term) {
174
- this.previousCategoryCode = categoryName;
175
- this.previousTermCode = term.code;
176
- switch (categoryName) {
177
- case 'competencyarea':
178
- return 'Competency Area';
179
- case 'theme':
180
- return 'Competency Theme';
181
- case 'subtheme':
182
- return 'Competency Sub Theme';
183
- default:
184
- return categoryName;
185
- }
186
- }
187
- getName(item) {
188
- return item.toUpperCase();
189
- }
190
- getLabelName(labelName) {
191
- switch (labelName) {
192
- case 'Theme':
193
- return `Competency ${labelName} name`;
194
- case 'Sub Theme':
195
- return `Competency ${labelName} name`;
196
- default:
197
- return labelName;
198
- }
199
- }
200
- createCompThemeFields() {
201
- return this.fb.group({
202
- competencyTheme: ['', [Validators.required]],
203
- competencySubTheme: ['', [Validators.required]]
204
- });
205
- }
206
- addCompetencyTheme() {
207
- if (this.data.mode === 'multi-create') {
208
- this.compThemeFields.push(this.createCompThemeFields());
209
- }
210
- }
211
- removeCompFields(index) {
212
- if (this.data.mode === 'multi-create') {
213
- this.compThemeFields.removeAt(index);
214
- }
215
- }
216
- get compThemeFields() {
217
- return this.competencyForm.get('compThemeFields');
218
- }
219
- updateFormView(form, data) {
220
- if (data && data.childrenData && data.childrenData.additionalProperties && data.childrenData.additionalProperties.displayName) {
221
- form.get('dname').patchValue(data.childrenData.additionalProperties.displayName);
222
- }
223
- form.get('description').patchValue(data.childrenData.description);
224
- if (data.childrenData.name && this.masterList.length) {
225
- const assignName = this.masterList.find(option => data.childrenData.refId === option.id);
226
- if (assignName) {
227
- form.controls['name'].setValue(assignName);
228
- }
229
- }
230
- setTimeout(() => {
231
- form.get('name').disable();
232
- form.get('dname').disable();
233
- form.get('description').disable();
234
- });
235
- }
236
- updateFormEdit(form, data) {
237
- form.get('dname').patchValue(data.childrenData.additionalProperties.displayName);
238
- form.get('description').patchValue(data.childrenData.description);
239
- if (data.childrenData.name && this.masterList.length) {
240
- const assignName = this.masterList.find(option => data.childrenData.name === option.title);
241
- if (assignName) {
242
- form.controls['name'].setValue(assignName);
243
- }
244
- }
245
- setTimeout(() => {
246
- form.get('name').disable();
247
- form.get('dname').enable();
248
- });
249
- }
250
- onKey(event) {
251
- clearTimeout(this.debounceTimeout);
252
- this.debounceTimeout = setTimeout(() => {
253
- this.values = event.target.value.toLowerCase();
254
- this.filteredMasterList = this.filterOrgValues(this.values, this.masterList);
255
- }, this.debounceDelay);
256
- }
257
- filterOrgValues(searchValue, array) {
258
- return array.filter((value) => value.title.toLowerCase().includes(searchValue.toLowerCase()));
259
- }
260
- getKcmSearch() {
261
- const requestObj = {
262
- filterCriteriaMap: {
263
- status: "Live",
264
- isActive: true
265
- },
266
- requestedFields: [],
267
- pageNumber: 0,
268
- pageSize: 1000
269
- };
270
- this.frameWorkService.getKcmSearchList(requestObj, this.data.columnInfo.code).subscribe((response) => {
271
- if (response.data && response.data.length) {
272
- this.masterList = response.data;
273
- this.filteredMasterList = [...this.masterList];
274
- setTimeout(() => {
275
- if (this.data &&
276
- (this.data.mode === 'edit')) {
277
- this.updateFormEdit(this.createThemeForm, this.data);
278
- }
279
- else if (this.data &&
280
- (this.data.mode === 'view')) {
281
- this.updateFormView(this.createThemeForm, this.data);
282
- }
283
- }, 1000);
284
- }
285
- });
286
- }
287
- onDisableTheme(option) {
288
- let parentCol;
289
- const parentColumnConfigData = this.frameWorkService.getPreviousCategory(this.data.columnInfo.code);
290
- if (parentColumnConfigData) {
291
- parentCol = this.frameWorkService.selectionList.get(parentColumnConfigData.code);
292
- }
293
- let result = -1;
294
- if (parentCol && parentCol.children && parentCol.children.length) {
295
- result = parentCol.children.findIndex((ele) => {
296
- if ((ele.refType === 'theme' || ele.refType === 'subtheme')) {
297
- return ele.name.toLowerCase() === option.title.toLowerCase();
298
- }
299
- return false;
300
- });
301
- }
302
- if (result < 0) {
303
- let formArray = this.createThemeFormMulti.get('themeFields');
304
- result = formArray.value.findIndex((formEle) => {
305
- if (formEle.name && formEle.name.id) {
306
- return formEle.name.id === option.id;
307
- }
308
- return false;
309
- });
310
- }
311
- return result >= 0 ? true : false;
312
- }
313
- multiCreate(form, _data) {
314
- this.disableMultiCreate = true;
315
- let counter = 0;
316
- let createdTerms = [];
317
- if (form.valid) {
318
- const themeFields = form && form.value && form.value.themeFields;
319
- if (themeFields && themeFields.length) {
320
- themeFields.forEach((val, _i) => {
321
- const term = {
322
- code: this.frameWorkService.getUuid(),
323
- name: _.get(val, 'name.title'),
324
- description: val.description,
325
- category: this.data.columnInfo.code,
326
- status: appConstants.LIVE,
327
- refId: val.name.id,
328
- refType: this.data.columnInfo.code,
329
- parents: [
330
- { identifier: `${this.data.frameworkId.toLowerCase()}_${this.data.columnInfo.code}` }
331
- ],
332
- additionalProperties: {
333
- displayName: val.dname,
334
- timeStamp: new Date().getTime(),
335
- }
336
- };
337
- const requestBody = {
338
- request: {
339
- term: term
340
- }
341
- };
342
- this.frameWorkService.createTerm(this.data.frameworkId, this.data.columnInfo.code, requestBody).subscribe((res) => {
343
- requestBody.request.term['identifier'] = res.result.node_id[0];
344
- createdTerms.push(requestBody.request.term);
345
- counter++;
346
- if (counter === themeFields.length) {
347
- const parentColumn = this.frameWorkService.getPreviousCategory(this.data.columnInfo.code);
348
- let parentCol = this.frameWorkService.selectionList.get(parentColumn.code);
349
- this.updateTermAssociationsMultiV2(createdTerms, parentCol);
350
- }
351
- });
352
- });
353
- this.disableMultiCreate = true;
354
- }
355
- }
356
- }
357
- async updateTermAssociationsMulti(createdTerms) {
358
- let parent;
359
- if (createdTerms && createdTerms.length) {
360
- let createdTermsCounter = 0;
361
- for (let createdTerm of createdTerms) {
362
- this.selectedTerm = createdTerm;
363
- let associations = [];
364
- let temp;
365
- let counter = 0;
366
- for (const [value] of this.frameWorkService.selectionList) {
367
- parent = value;
368
- counter++;
369
- temp = parent.children ? parent.children.filter((child) => child.identifier === this.selectedTerm.identifier) : null;
370
- associations = parent.children ? parent.children.map((c) => {
371
- return c.identifier ? { identifier: c.identifier } : null;
372
- }) : [];
373
- if (temp && temp.length) {
374
- this.isTermExist = true;
375
- return;
376
- }
377
- else {
378
- associations.push({ identifier: this.selectedTerm.identifier });
379
- this.isTermExist = false;
380
- const reguestBody = {
381
- request: {
382
- term: {
383
- ...(associations && associations.length) ? { associations: [...associations] } : null,
384
- }
385
- }
386
- };
387
- await this.callUpdateAssociations(counter, parent, reguestBody);
388
- }
389
- }
390
- createdTermsCounter++;
391
- if (createdTermsCounter === createdTerms.length) {
392
- this.frameWorkService.updateFrameworkList(this.data.columnInfo.code, parent, createdTerms);
393
- this.dialogClose({ term: [this.selectedTerm], created: true, multi: true });
394
- this.disableMultiCreate = false;
395
- if (createdTerms[0].category === 'theme') {
396
- this._snackBar.open(`Competency ${createdTerms[0].category} created successfully.`);
397
- }
398
- if (createdTerms[0].category === 'subtheme') {
399
- this._snackBar.open(`Competency ${createdTerms[0].category} created successfully.`);
400
- }
401
- }
402
- }
403
- }
404
- }
405
- callUpdateAssociations(counter, parent, reguestBody) {
406
- return new Promise((resolve) => {
407
- this.frameWorkService.updateTerm(this.data.frameworkId, parent.category, parent.code, reguestBody).subscribe(() => {
408
- parent['children'] = parent && parent.children ? [...parent.children, ...[this.selectedTerm]] : [this.selectedTerm];
409
- if (counter === this.frameWorkService.selectionList.size) {
410
- this.disableUpdate = false;
411
- resolve(true);
412
- }
413
- else {
414
- return resolve(true);
415
- }
416
- }, (_err) => {
417
- console.error(`Edit ${this.data.columnInfo.name} failed, please try again later`);
418
- });
419
- });
420
- }
421
- updateDname(_name, _form, _i) {
422
- }
423
- change(event, form, i) {
424
- if (this.data && this.data.mode) {
425
- if (this.data.mode === 'create') {
426
- form.get('dname').patchValue(event.source.value.title);
427
- this.expansionTitle = event.source.value.title;
428
- this.cdr.detectChanges();
429
- }
430
- if (this.data.mode === 'multi-create') {
431
- const formToUpdate = form.controls.themeFields.controls[i];
432
- formToUpdate.controls['dname'].patchValue(event.source.value.title);
433
- this.expansionTitle = event.source.value.title;
434
- this.cdr.detectChanges();
435
- if (formToUpdate.controls.name.valid && formToUpdate.controls.dname) {
436
- formToUpdate.controls.dname.enable();
437
- }
438
- else if (formToUpdate.controls.dname) {
439
- formToUpdate.controls.dname.disable();
440
- }
441
- }
442
- }
443
- }
444
- getExpansionTitle(form) {
445
- const details = form.get('name').value;
446
- return _.get(details, 'title', '');
447
- }
448
- get designationControls() {
449
- return this.createThemeForm.get('designations').controls;
450
- }
451
- loadDesignations() {
452
- this.odcsService.getDesignations({}).subscribe((data) => {
453
- this.designationsList = data.responseData;
454
- }, (_err) => {
455
- });
456
- }
457
- getFilteredDesignationList(index) {
458
- const filterKey = this.createThemeForm.value.designations[index].name.toLowerCase();
459
- if (filterKey && this.designationsList) {
460
- const filteredList = this.designationsList.filter((designation) => designation.name.toLowerCase().includes(filterKey));
461
- return filteredList;
462
- }
463
- return [];
464
- }
465
- addDesignation() {
466
- const newDesignation = this.fb.group({
467
- name: ['', Validators.required],
468
- id: [null, Validators.required],
469
- designationDescription: ['', [Validators.required, Validators.maxLength(600)]],
470
- isSaved: [false],
471
- creationId: this.addedDesignationCount
472
- });
473
- this.addedDesignationCount = this.addedDesignationCount + 1;
474
- this.createThemeForm.get('designations').insert(0, newDesignation);
475
- this.panelOpenState.splice(0, 0, true);
476
- }
477
- clearSelectedDesignaionOnChange(index, event) {
478
- const selectedName = this.createThemeForm.value.designations[index].name;
479
- if (selectedName !== event.value) {
480
- const designationsToReset = this.designationControls[index];
481
- designationsToReset.get('id').reset();
482
- }
483
- }
484
- deleteDesignation(index) {
485
- const reovedCreationId = this.designationControls[index].value.creationId;
486
- this.createThemeForm.get('designations').removeAt(index);
487
- this.savedDesignations = this.savedDesignations.filter((savedDesignation) => savedDesignation.creationId !== reovedCreationId);
488
- }
489
- saveDesignation(index) {
490
- const designations = this.designationControls;
491
- const designationToSave = designations[index];
492
- if (designationToSave.valid) {
493
- designationToSave.value.isSaved = true;
494
- const savedDesignationIndex = this.savedDesignations.findIndex((e) => e.creationId === designationToSave.value.creationId);
495
- if (savedDesignationIndex >= 0) {
496
- this.savedDesignations[savedDesignationIndex] = designationToSave.value;
497
- }
498
- else {
499
- this.savedDesignations.push(designationToSave.value);
500
- }
501
- }
502
- }
503
- submitDesignation() {
504
- }
505
- cancel() {
506
- this.dialogRef.close();
507
- }
508
- get enableAddBtn() {
509
- if (this.colCode === 'designation') {
510
- return this.designationControls.length > 0 ? true : false;
511
- }
512
- return false;
513
- }
514
- _filter(searchTxt) {
515
- let isExist;
516
- this.disableCreate = false;
517
- this.isTermExist = false;
518
- this.createTermForm.get('description').enable();
519
- const filterValue = typeof (searchTxt) === 'object' ? this._normalizeValue(searchTxt.name) : this._normalizeValue(searchTxt);
520
- isExist = this.termLists.filter((term) => this._normalizeValue(term.name).includes(filterValue));
521
- return isExist;
522
- }
523
- _normalizeValue(value) {
524
- return value.toLowerCase().replace(/\s/g, '');
525
- }
526
- onSelectionArea(option) {
527
- this.allCompetency.forEach((val) => {
528
- if (option.name === val.name) {
529
- this.seletedCompetencyArea = val;
530
- this.allCompetencyTheme = val.children;
531
- this.filteredallCompetencyTheme = this.allCompetencyTheme;
532
- }
533
- });
534
- }
535
- OnThemeSelection(event) {
536
- const selectedTheme = event.source.value;
537
- this.filteredallCompetencyTheme.forEach((val) => {
538
- if (selectedTheme.name === val.name) {
539
- this.allCompetencySubtheme = val.children;
540
- this.filteredallCompetencySubTheme = this.allCompetencySubtheme;
541
- }
542
- });
543
- }
544
- onSelect(term, form) {
545
- switch (this.colCode) {
546
- case 'designation':
547
- form.get('name').patchValue(term.value.name);
548
- form.get('id').patchValue(term.value.id);
549
- break;
550
- default:
551
- this.selectedTerm = term.value;
552
- form.get('name').patchValue(term.value.name);
553
- form.get('dname').patch(term.value.dname);
554
- form.get('description').patchValue(term.value.description);
555
- form.get('description').disable();
556
- this.disableCreate = true;
557
- }
558
- }
559
- saveTerm() {
560
- if (this._filter(this.createTermForm.value.name).length > 0) {
561
- this.isTermExist = true;
562
- return;
563
- }
564
- if (this.createTermForm.valid) {
565
- const term = {
566
- code: this.frameWorkService.getUuid(),
567
- name: this.createTermForm.value.name,
568
- description: this.createTermForm.value.description,
569
- category: this.data.columnInfo.code,
570
- status: appConstants.LIVE,
571
- parents: [
572
- { identifier: `${this.data.frameworkId.toLowerCase()}_${this.data.columnInfo.code}` }
573
- ],
574
- additionalProperties: {
575
- displayName: this.createTermForm.value.dname,
576
- timeStamp: new Date().getTime(),
577
- }
578
- };
579
- const requestBody = {
580
- request: {
581
- term: term
582
- }
583
- };
584
- this.frameWorkService.createTerm(this.data.frameworkId, this.data.columnInfo.code, requestBody).subscribe((res) => {
585
- requestBody.request.term['identifier'] = res.result.node_id[0];
586
- this.dialogClose({ term: requestBody.request.term, created: true });
587
- this.selectedTerm = requestBody.request.term;
588
- this.updateTermAssociations();
589
- });
590
- }
591
- }
592
- updateTermData(form, data) {
593
- let additionalProperties = data.childrenData.additionalProperties;
594
- additionalProperties['displayName'] = this.createThemeForm.value.dname;
595
- form.value.additionalProperties = additionalProperties;
596
- form.value.displayName = form.value.dname;
597
- this.disableUpdate = true;
598
- const formData = {
599
- ...form.value,
600
- };
601
- const updateData = {
602
- formData,
603
- updateTermData: data.childrenData
604
- };
605
- this.updateTermDataAssociations(updateData);
606
- }
607
- updateTermDataAssociations(updateData) {
608
- this.disableMultiCreate = true;
609
- let selectionData = this.frameWorkService.selectionList.get(this.data.columnInfo.code);
610
- if (!selectionData) {
611
- selectionData = this.data.childrenData;
612
- }
613
- const listThme = this.frameWorkService.list.get(this.data.columnInfo.code);
614
- let themAssociations;
615
- if (listThme && listThme.children && listThme.children.length) {
616
- const data = listThme.children.find((c) => c.identifier === selectionData.identifier);
617
- themAssociations = data.associations ? data.associations.map((c) => {
618
- return c.identifier ? { identifier: c.identifier } : null;
619
- }) : [];
620
- }
621
- const reguestBody = {
622
- request: {
623
- term: {
624
- ...updateData.formData,
625
- ...(themAssociations && themAssociations.length) ? { associations: themAssociations } : null,
626
- }
627
- }
628
- };
629
- this.frameWorkService.updateTerm(this.data.frameworkId, selectionData.category, selectionData.code, reguestBody).subscribe(() => {
630
- const value = (this.selectedTerm && this.selectedTerm.identifier) ? this.selectedTerm : (updateData) ? { ...updateData.updateTermData, ...updateData.formData } : {};
631
- this.disableUpdate = false;
632
- selectionData['description'] = reguestBody.request.term.description;
633
- selectionData['additionalProperties'] = reguestBody.request.term.additionalProperties;
634
- selectionData['associations'] = themAssociations;
635
- this._snackBar.open(`Competency ${value.category} updated successfully`);
636
- this.dialogClose({ term: { ...value }, created: true });
637
- this.disableMultiCreate = false;
638
- this.frameWorkService.updateFullTermDataLocalMap(this.data.columnInfo.code, selectionData);
639
- }, (_err) => {
640
- console.error(`Edit ${this.data.columnInfo.name} failed, please try again later`);
641
- });
642
- }
643
- updateTermAssociations(updateData) {
644
- let associations = [];
645
- let temp;
646
- let counter = 0;
647
- this.frameWorkService.selectionList.forEach((parent) => {
648
- counter++;
649
- temp = parent.children ? parent.children.filter((child) => child.identifier === this.selectedTerm.identifier) : null;
650
- associations = parent.children ? parent.children.map((c) => {
651
- return c.identifier ? { identifier: c.identifier } : null;
652
- }) : [];
653
- if (temp && temp.length) {
654
- this.isTermExist = true;
655
- return;
656
- }
657
- else {
658
- if (this.selectedTerm && this.selectedTerm.identifier) {
659
- associations.push({ identifier: this.selectedTerm.identifier });
660
- }
661
- this.isTermExist = false;
662
- const reguestBody = {
663
- request: {
664
- term: {
665
- ...(updateData && updateData.formData && updateData.updateTermData.code === parent.code) ? { ...updateData.formData } : null,
666
- ...(associations && associations.length) ? { associations: [...associations] } : null,
667
- }
668
- }
669
- };
670
- this.frameWorkService.updateTerm(this.data.frameworkId, parent.category, parent.code, reguestBody).subscribe(() => {
671
- if (counter === this.frameWorkService.selectionList.size) {
672
- const value = (this.selectedTerm && this.selectedTerm.identifier) ? this.selectedTerm : (updateData) ? { ...updateData.updateTermData, ...updateData.formData } : {};
673
- this.disableUpdate = false;
674
- this._snackBar.open(`Competency ${value.category} updated successfully`);
675
- this.dialogClose({ term: { ...value }, created: true });
676
- }
677
- }, (_err) => {
678
- console.error(`Edit ${this.data.columnInfo.name} failed, please try again later`);
679
- });
680
- }
681
- });
682
- }
683
- saveThemeTerm() {
684
- if (this._filter(this.createThemeForm.value.name).length > 0) {
685
- this.isTermExist = true;
686
- return;
687
- }
688
- if (this.createThemeForm.valid) {
689
- const term = {
690
- code: this.frameWorkService.getUuid(),
691
- name: this.createThemeForm.value.name,
692
- description: this.createThemeForm.value.description,
693
- category: this.data.columnInfo.code,
694
- status: appConstants.LIVE,
695
- parents: [
696
- { identifier: `${this.data.frameworkId.toLowerCase()}_${this.data.columnInfo.code}` }
697
- ],
698
- additionalProperties: {
699
- displayName: this.createTermForm.value.dname,
700
- timeStamp: new Date().getTime(),
701
- }
702
- };
703
- const requestBody = {
704
- request: {
705
- term: term
706
- }
707
- };
708
- this.frameWorkService.createTerm(this.data.frameworkId, this.data.columnInfo.code, requestBody).subscribe((res) => {
709
- requestBody.request.term['identifier'] = res.result.node_id[0];
710
- this.dialogClose({ term: requestBody.request.term, created: true });
711
- this.selectedTerm = requestBody.request.term;
712
- this.updateTermAssociations();
713
- }, (_err) => {
714
- console.error(`Create ${this.data.columnInfo.name} failed, please try again later`);
715
- });
716
- }
717
- }
718
- dialogClose(term) {
719
- this.frameWorkService.publishFramework().subscribe(() => {
720
- this.dialogRef.close(term);
721
- });
722
- }
723
- async updateTermAssociationsMultiV2(createdTerms, parentSelectedTerm) {
724
- this.selectedTermArray = [];
725
- let createdTermsIdentifiers = [];
726
- this.selectedTermArray = createdTerms;
727
- this.selectedTerm = createdTerms[createdTerms.length - 1];
728
- for (let createdTerm of createdTerms) {
729
- createdTermsIdentifiers.push({ identifier: createdTerm.identifier });
730
- }
731
- let associations = [];
732
- let counter = 0;
733
- if (createdTerms && createdTerms.length) {
734
- let parent;
735
- let createdTermsCounter = 0;
736
- if (!parentSelectedTerm) {
737
- for (let createdTerm of createdTerms) {
738
- this.selectedTerm = createdTerm;
739
- let temp;
740
- for (const [value] of this.frameWorkService.selectionList) {
741
- parent = value;
742
- counter++;
743
- temp = parent.children ? parent.children.filter((child) => child.identifier === this.selectedTerm.identifier) : null;
744
- associations = parent.children ? parent.children.map((c) => {
745
- return c.identifier ? { identifier: c.identifier } : null;
746
- }) : [];
747
- if (temp && temp.length) {
748
- this.isTermExist = true;
749
- return;
750
- }
751
- else {
752
- associations.push({ identifier: this.selectedTerm.identifier });
753
- this.isTermExist = false;
754
- const reguestBody = {
755
- request: {
756
- term: {
757
- ...(associations && associations.length) ? { associations: [...associations] } : null,
758
- }
759
- }
760
- };
761
- await this.callUpdateAssociations(counter, parent, reguestBody);
762
- }
763
- }
764
- createdTermsCounter++;
765
- if (createdTermsCounter === createdTerms.length) {
766
- this.frameWorkService.updateFrameworkList(this.data.columnInfo.code, parent, createdTerms);
767
- this.dialogClose({ term: [this.selectedTerm], created: true, multi: true });
768
- this.disableMultiCreate = false;
769
- if (createdTerms[0].category === 'theme') {
770
- this._snackBar.open(`Competency ${createdTerms[0].category} created successfully.`);
771
- }
772
- if (createdTerms[0].category === 'subtheme') {
773
- this._snackBar.open(`Competency ${createdTerms[0].category} created successfully.`);
774
- }
775
- }
776
- }
777
- }
778
- else {
779
- const parent = parentSelectedTerm;
780
- associations = parent.children ? parent.children.map((c) => {
781
- return c.identifier ? { identifier: c.identifier } : null;
782
- }) : [];
783
- associations = [...associations, ...createdTermsIdentifiers];
784
- this.isTermExist = false;
785
- const reguestBody = {
786
- request: {
787
- term: {
788
- ...(associations && associations.length) ? { associations: [...associations] } : null,
789
- }
790
- }
791
- };
792
- await this.callUpdateAssociationsV2(counter, parent, reguestBody);
793
- this.frameWorkService.updateFrameworkList(this.data.columnInfo.code, parent, createdTerms);
794
- this.dialogClose({ term: this.selectedTermArray, created: true, multi: true });
795
- this.disableMultiCreate = false;
796
- if (createdTerms[0].category === 'theme') {
797
- this._snackBar.open(`Competency ${createdTerms[0].category} created successfully.`);
798
- }
799
- if (createdTerms[0].category === 'subtheme') {
800
- this._snackBar.open(`Competency ${createdTerms[0].category} created successfully.`);
801
- }
802
- }
803
- }
804
- }
805
- async callUpdateAssociationsV2(counter, parent, reguestBody) {
806
- return new Promise((resolve) => {
807
- this.frameWorkService.updateTerm(this.data.frameworkId, parent.category, parent.code, reguestBody).subscribe(async () => {
808
- parent['children'] = parent && parent.children ? [...parent.children, ...this.selectedTermArray] : this.selectedTermArray;
809
- let listData = this.frameWorkService.list.get(this.data.columnInfo.code);
810
- let differenceData = [];
811
- if (listData && listData.children && listData.children.length) {
812
- differenceData = _.differenceBy(this.selectedTermArray, listData.children, 'identifier');
813
- }
814
- else {
815
- differenceData = this.selectedTermArray;
816
- }
817
- listData['associations'] = listData && listData.associations ? [...listData.associations, ...differenceData] : differenceData;
818
- listData['children'] = listData && listData.children ? [...listData.children, ...differenceData] : differenceData;
819
- this.frameWorkService.selectionList.forEach((selectedData) => {
820
- let listData = this.frameWorkService.list.get(selectedData.category);
821
- if (listData && listData.children && listData.children.length) {
822
- this.frameWorkService.updateLocalList(listData, parent, this.selectedTermArray, 'create');
823
- }
824
- });
825
- if (counter === this.frameWorkService.selectionList.size) {
826
- this.disableUpdate = false;
827
- resolve(true);
828
- }
829
- else {
830
- return resolve(true);
831
- }
832
- }, (_err) => {
833
- console.error(`Edit ${this.data.columnInfo.name} failed, please try again later`);
834
- });
835
- });
836
- }
837
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CreateTermComponent, deps: [{ token: i1.MatLegacyDialogRef }, { token: MAT_DIALOG_DATA }, { token: i2.FrameworkService }, { token: i3.UntypedFormBuilder }, { token: i4.OdcsService }, { token: i5.MatLegacySnackBar }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
838
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CreateTermComponent, selector: "lib-create-term", ngImport: i0, template: "<ng-container [ngSwitch]=\"data?.columnInfo?.code || 'defaultCreate'\">\n <ng-container *ngIf=\"disableMultiCreate\">\n <div class=\"flex flex-col flex-1 w-100 absolute loader-bg items-center pt-5 text-center\">\n <mat-spinner class=\"display-inline-block mb-5\" [diameter]=\"50\" [strokeWidth]=\"3\"></mat-spinner>\n <!-- <p>{{loaderMsg}}</p> -->\n </div>\n </ng-container>\n <ng-container *ngSwitchDefault [ngTemplateOutlet]=\"themeCreate\"></ng-container>\n <ng-container *ngSwitchCase=\"'theme'\" [ngTemplateOutlet]=\"themeCreate\"></ng-container>\n <ng-container *ngSwitchCase=\"'subtheme'\" [ngTemplateOutlet]=\"themeCreate\"></ng-container>\n <ng-container *ngSwitchCase=\"'designation'\" [ngTemplateOutlet]=\"themeDesignation\"></ng-container>\n <ng-container *ngSwitchCase=\"'competency'\" [ngTemplateOutlet]=\"compTheme\"></ng-container>\n</ng-container>\n\n<ng-template #modalTitle>\n <!-- <ng-container *ngIf=\"data?.mode === 'create' || data?.mode === 'multi-create'\">\n <div class=\"dialog-title\" mat-dialog-title>{{data.columnInfo.name === 'Theme' ? app_strings.addCompetency : app_strings.createNew}} {{data.columnInfo.name}}</div>\n </ng-container> -->\n <ng-container *ngIf=\"data?.mode === 'create' || data?.mode === 'multi-create'\">\n <div class=\"dialog-title\" mat-dialog-title>Add {{data?.columnInfo?.config?.categoryDisplayName || data.columnInfo.name }} </div>\n </ng-container>\n <ng-container *ngIf=\"data?.mode === 'view'\">\n <div class=\"dialog-title\" mat-dialog-title></div>\n </ng-container>\n <ng-container *ngIf=\"data?.mode === 'edit'\">\n <div class=\"dialog-title\" mat-dialog-title>{{app_strings.edit}} {{data?.columnInfo?.config?.categoryDisplayName || data.columnInfo.name}}</div>\n </ng-container>\n</ng-template>\n\n<ng-template #defaultCreate>\n <div class=\"dialog\">\n <ng-container [ngTemplateOutlet]=\"modalTitle\"></ng-container>\n <form [formGroup]=\"createTermForm\" novalidate (ngSubmit)=\"disableCreate?updateTermAssociations():saveTerm()\"\n class=\"defaultForm\">\n <mat-form-field appearance=\"outline\">\n <!-- <mat-label>Enter {{data.name}} name</mat-label> -->\n <input matInput formControlName=\"name\" placeholder=\"{{app_strings.name}}\" [matAutocomplete]=\"auto\">\n <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"onSelect($event.option, createTermForm)\">\n <mat-option *ngFor=\"let option of filtedTermLists | async\" [value]=\"option\">\n {{option.name }}\n </mat-option>\n </mat-autocomplete>\n <mat-error *ngIf=\"isTermExist\">{{app_strings.alreadyExist}}</mat-error>\n </mat-form-field>\n <mat-form-field appearance=\"outline\">\n <!-- <mat-label>Enter {{data.name}} name</mat-label> -->\n <textarea matInput formControlName=\"description\" placeholder=\"{{app_strings.description}}\" maxlength=\"2000\"></textarea>\n </mat-form-field>\n <footer class=\"actions\">\n <button mat-raised-button color=\"default\" type=\"reset\"\n (click)=\"dialogClose('')\">{{app_strings.cancel}}</button>\n <button mat-raised-button color=\"primary\" type=\"submit\" cdkFocusInitial\n *ngIf=\"!disableCreate || disableMultiCreate\">{{app_strings.create}}</button>\n <button mat-raised-button color=\"primary\" type=\"submit\" cdkFocusInitial\n *ngIf=\"disableCreate\">{{app_strings.update}}</button>\n </footer>\n </form>\n </div>\n</ng-template>\n\n<ng-template #themeCreate >\n <div class=\"dialogNew\" [ngClass]=\"{'disabled-div': disableMultiCreate}\" >\n <ng-container [ngTemplateOutlet]=\"modalTitle\"></ng-container>\n <div class=\"flex gap-4\">\n <ng-container *ngFor=\"let term of data?.selectedParentTerms\">\n <div class=\"flex-1 flex-col\">\n <label for=\"name\" class=\"margin-remove-bottom form-label\" aria-label=\"First name label\">\n {{getCategoryName(term.category,term)}}\n </label>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <input matInput name=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n [value]=\"term.name\" disabled>\n </mat-form-field>\n </div>\n </ng-container>\n </div>\n <div class=\"row-divider\"></div>\n <ng-container *ngIf=\"data?.mode !== 'multi-create'\">\n <form class=\"themeForm\" [formGroup]=\"createThemeForm\" novalidate\n (ngSubmit)=\"disableCreate?updateTermAssociations():saveThemeTerm()\">\n <div class=\"input-column\">\n <div class=\"input-wrapper margin-top-s\">\n <div class=\"flex gap-4 \" *ngIf=\"data.columnInfo?.code !== 'competencyarea' && data.mode === 'view'\">\n <div class=\"flex-1 flex-col\">\n <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n aria-label=\"First name label\">\n Name\n </label>\n \n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <mat-select placeholder=\"{{app_strings?.name}}\" formControlName=\"name\" id=\"name\" #name (selectionChange)=\"change($event,createThemeForm)\">\n <input #search autocomplete=\"off\" placeholder=\"Search\" class=\"assigneeSearch\"\n (keydown.space)=\"$event.stopPropagation()\" (keyup)=\"onKey($event)\" matInput>\n <mat-option *ngFor=\"let option of filteredMasterList\" (blur)=\"updateDname(option?.title, createThemeForm)\" [disabled]=\"onDisableTheme(option)\" [value]=\"option\">{{option.title}}</mat-option>\n <mat-option *ngIf=\"filteredMasterList.length === 0\" disabled>\n No results found!\n </mat-option>\n </mat-select>\n\n <!-- <input matInput formControlName=\"name\" id=\"name\" #name\n placeholder=\"{{app_strings.name}}\"\n (blur)=\"updateDname(name.value, createThemeForm)\" maxlength=\"70\"> -->\n <!-- <input matInput formControlName=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n [matAutocomplete]=\"auto\">\n <mat-autocomplete #auto=\"matAutocomplete\"\n (optionSelected)=\"onSelect($event.option, createThemeForm)\">\n <mat-option *ngFor=\"let option of filtedTermLists | async\" [value]=\"option\">\n {{option.name}}\n </mat-option>\n </mat-autocomplete> -->\n </mat-form-field>\n <mat-error *ngIf=\"isTermExist\">{{app_strings.alreadyExist}}</mat-error>\n </div>\n <div class=\"flex-1 flex-col\">\n \n <div class=\"flex\">\n\n <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n aria-label=\"First name label\">\n Display Name\n </label>\n <mat-icon class=\"info-icon cursor-pointer\" [matTooltip]=\"toolTipText\" \n matTooltipClass=\"tooltip-sec\">info_outline</mat-icon>\n \n </div>\n \n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <input matInput formControlName=\"dname\" id=\"dname\" #dname \n placeholder=\"Field automatically generated from the name field.\" maxlength=\"70\" >\n <!-- <input matInput formControlName=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n [matAutocomplete]=\"auto\"> -->\n <!-- <mat-autocomplete #auto=\"matAutocomplete\"\n (optionSelected)=\"onSelect($event.option, createThemeForm)\">\n <mat-option *ngFor=\"let option of filtedTermLists | async\" [value]=\"option\">\n {{option.name}}\n </mat-option>\n </mat-autocomplete> -->\n <!-- <mat-error *ngIf=\"isTermExist\">{{app_strings.alreadyExist}}</mat-error> -->\n </mat-form-field>\n </div>\n </div>\n <div class=\"flex gap-4 \" *ngIf=\"data.columnInfo?.code === 'competencyarea' && data.mode === 'view'\">\n <div class=\"flex-1 flex-col\">\n <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n aria-label=\"First name label\">\n Name\n </label>\n \n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <input autocomplete=\"off\" \n matInput [value]=\"data?.childrenData?.name\" disabled>\n </mat-form-field>\n </div>\n </div>\n\n <div class=\"flex-col mt-2\">\n <label for=\"fname\" class=\"margin-remove-bottom form-label\"\n i18n=\"First Name label|Label which explains the user to enter first name\"\n i18n-aria-label aria-label=\"First name label\">\n Description\n </label>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <!-- <mat-label>Enter {{data.name}} name</mat-label> -->\n <textarea matInput [cdkTextareaAutosize] [cdkAutosizeMaxRows]=\"10\"\n [cdkAutosizeMinRows]=\"3\" formControlName=\"description\"\n placeholder=\"{{app_strings.description}}\" maxlength=\"2000\"></textarea>\n </mat-form-field>\n </div>\n </div>\n </div>\n <footer class=\"actions\">\n <button mat-raised-button color=\"default\" type=\"reset\"\n (click)=\"dialogClose('')\">{{app_strings.cancel}}</button>\n <ng-container *ngIf=\"data?.mode === 'create'\">\n <button mat-raised-button color=\"primary\" type=\"submit\" cdkFocusInitial\n [disabled]=\"createThemeForm?.invalid\" *ngIf=\"!disableCreate\">{{app_strings.create}}</button>\n </ng-container>\n <ng-container *ngIf=\"data?.mode === 'edit'\">\n <button mat-raised-button color=\"primary\" type=\"button\" cdkFocusInitial\n (click)=\"updateTermData(createThemeForm, data)\" [disabled]=\"createThemeForm?.invalid || disableUpdate\"\n *ngIf=\"!disableCreate\">{{app_strings.update}}</button>\n </ng-container>\n </footer>\n </form>\n </ng-container>\n <ng-container *ngIf=\"data?.mode === 'multi-create'\">\n <form class=\"themeForm\" [formGroup]=\"createThemeFormMulti\" novalidate\n (ngSubmit)=\"disableCreate?updateTermAssociations():saveThemeTerm()\">\n <div class=\"flex flex-end mb-4\">\n <button type=\"button\" class=\"mat-button flex items-center \" *ngIf=\"data.mode === 'multi-create'\" (click)=\"addThemeFields()\">\n <mat-icon class=\"mr-2 mat-icon-custom \">add_circle_outline</mat-icon>\n Add more\n </button>\n </div>\n <mat-accordion formArrayName=\"themeFields\">\n <mat-expansion-panel #mep=\"matExpansionPanel\" *ngFor=\"let field of themeFieldsControls; let i = index; let isFirst = first\" \n class=\"margin-bottom-l\" [formGroupName]=\"i\" [expanded]=\"isFirst\">\n <mat-expansion-panel-header>\n <mat-panel-title>\n {{getExpansionTitle(field)}} \n </mat-panel-title>\n <button mat-button type=\"button\" *ngIf=\"data.mode === 'multi-create'\"\n (click)=\"removeThemeFields(i)\">\n <mat-icon class=\"mat-icon-custom \">delete</mat-icon>\n </button>\n </mat-expansion-panel-header>\n <div class=\"input-column\">\n <div class=\"input-wrapper margin-top-s\">\n <div class=\"flex gap-4 \">\n <div class=\"flex-1 flex-col\">\n <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n aria-label=\"First name label\">\n Name\n </label>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <!-- <input matInput formControlName=\"name\" id=\"name\" #name\n placeholder=\"{{app_strings.name}}\"\n (blur)=\"updateDname(name.value, createThemeFormMulti, i)\" maxlength=\"70\"> -->\n <!-- <input matInput formControlName=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n [matAutocomplete]=\"auto\">\n <mat-autocomplete #auto=\"matAutocomplete\"\n (optionSelected)=\"onSelect($event.option, createThemeForm)\">\n <mat-option *ngFor=\"let option of filtedTermLists | async\" [value]=\"option\">\n {{option.name}}\n </mat-option>\n </mat-autocomplete> -->\n \n <mat-select placeholder=\"{{app_strings?.name}}\" formControlName=\"name\" id=\"name\" #name (selectionChange)=\"change($event,createThemeFormMulti, i )\">\n <input #search autocomplete=\"off\" placeholder=\"Search\" class=\"assigneeSearch\"\n (keydown.space)=\"$event.stopPropagation()\" (keyup)=\"onKey($event)\" matInput>\n <mat-option *ngFor=\"let option of filteredMasterList\" (blur)=\"updateDname(option?.title, createThemeFormMulti, i)\" [disabled]=\"onDisableTheme(option)\" [value]=\"option\">{{option.title}} </mat-option>\n <mat-option *ngIf=\"filteredMasterList.length === 0\" disabled>\n No results found!\n </mat-option>\n \n </mat-select>\n \n </mat-form-field>\n <mat-error *ngIf=\"isTermExist\">{{app_strings?.alreadyExist}}</mat-error>\n </div>\n <div class=\"flex-1 flex-col\">\n <div class=\"flex\">\n <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n aria-label=\"First name label\">\n Display Name\n </label>\n \n \n <mat-icon class=\"info-icon cursor-pointer\" [matTooltip]=\"toolTipText\" \n matTooltipClass=\"tooltip-sec\">info_outline</mat-icon>\n \n \n \n \n \n </div>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <input matInput formControlName=\"dname\" id=\"dname\" #dname\n placeholder=\"Field automatically generated from the name field.\" maxlength=\"70\" [disabled]=\"name?.value?.length === 0\">\n <!-- <input matInput formControlName=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n [matAutocomplete]=\"auto\"> -->\n <!-- <mat-autocomplete #auto=\"matAutocomplete\"\n (optionSelected)=\"onSelect($event.option, createThemeForm)\">\n <mat-option *ngFor=\"let option of filtedTermLists | async\" [value]=\"option\">\n {{option.name}}\n </mat-option>\n </mat-autocomplete> -->\n <!-- <mat-error *ngIf=\"isTermExist\">{{app_strings.alreadyExist}}</mat-error> -->\n </mat-form-field>\n </div>\n </div>\n\n <div class=\"flex-col mt-2\">\n <label for=\"fname\" class=\"margin-remove-bottom form-label\"\n i18n=\"First Name label|Label which explains the user to enter first name\"\n i18n-aria-label aria-label=\"First name label\">\n Description\n </label>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <!-- <mat-label>Enter {{data.name}} name</mat-label> -->\n <textarea matInput [cdkTextareaAutosize] [cdkAutosizeMaxRows]=\"10\"\n [cdkAutosizeMinRows]=\"3\" formControlName=\"description\"\n placeholder=\"{{app_strings.description}}\" maxlength=\"2000\"></textarea>\n </mat-form-field>\n </div>\n </div>\n </div>\n <div class=\"flex flex-end\">\n <button mat-raised-button color=\"primary\" type=\"button\" (click)=\"mep.expanded = false\"\n [disabled]=\"createThemeFormMulti?.get('themeFields')['controls'][i].invalid\">\n Save\n </button>\n </div>\n </mat-expansion-panel>\n </mat-accordion>\n <footer class=\"actions\">\n <button mat-raised-button color=\"default\" type=\"reset\"\n (click)=\"dialogClose('')\">{{app_strings.cancel}}</button>\n <ng-container *ngIf=\"data?.mode === 'create'\">\n <button mat-raised-button color=\"primary\" type=\"submit\" cdkFocusInitial\n [disabled]=\"createThemeForm?.invalid\" *ngIf=\"!disableCreate\">{{app_strings.add_btn}}</button>\n </ng-container>\n <ng-container *ngIf=\"data?.mode === 'multi-create'\">\n <button mat-raised-button color=\"primary\" type=\"button\" cdkFocusInitial\n [disabled]=\"createThemeFormMulti.invalid || disableMultiCreate\" *ngIf=\"!disableCreate\" (click)=\"multiCreate(createThemeFormMulti, data)\">\n {{app_strings.add_btn}}\n </button>\n </ng-container>\n <ng-container *ngIf=\"data?.mode === 'edit'\">\n <button mat-raised-button color=\"primary\" type=\"button\" cdkFocusInitial\n (click)=\"updateTermData(createThemeForm, data)\"\n [disabled]=\"createThemeForm?.invalid || disableUpdate\"\n *ngIf=\"!disableCreate\">{{app_strings.update}}</button>\n </ng-container>\n </footer>\n </form>\n </ng-container>\n </div>\n</ng-template>\n\n<ng-template #themeDesignation>\n <div class=\"themDesignation\">\n <div class=\"dialogNew\">\n <ng-container [ngTemplateOutlet]=\"modalTitle\"></ng-container>\n <div class=\"mb-2\">\n <span class=\"organisation\">Organisation</span>\n <div class=\"org-name pl-4 flex items-center\">\n <!-- <span>Department of Fisheries</span> -->\n <span>{{data?.columnInfo?.name}}</span>\n </div>\n </div>\n <div class=\"row-divider\"></div>\n <div class=\"flex w-full items-center justify-end mt-4\">\n <a class=\"add-designation flex justify-center items-center\" (click)=\"addDesignation()\">\n <mat-icon class=\"add-icon mr-2\">add_circle_outline</mat-icon>\n <span>Add Designations</span>\n </a>\n </div>\n <div class=\"mt-5\">\n <form [formGroup]=\"createThemeForm\">\n <mat-accordion class=\"flex flex-col gap-2\" formArrayName=\"designations\">\n <ng-container *ngFor=\"let designation of designationControls; let i = index\">\n <mat-expansion-panel [formGroupName]=\"i\" class=\"designation-panel\" [expanded]=\"panelOpenState[i]\">\n <mat-expansion-panel-header>\n <div class=\"flex w-full items-center justify-end\">\n <mat-icon class=\"deletDesignation mr-4\" (click)=\"deleteDesignation(i)\">delete</mat-icon>\n </div>\n </mat-expansion-panel-header>\n <div class=\"flex flex-col gap-2 \">\n <div class=\"w-full\">\n <label for=\"name\" class=\"margin-remove-bottom form-label required\">\n Designation Name <mat-icon class=\"info-icon\">info</mat-icon>\n </label>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <input matInput formControlName=\"name\" placeholder=\"Type here\" [matAutocomplete]=\"auto\" (change)=\"clearSelectedDesignaionOnChange(i, $event)\">\n <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"onSelect($event.option, designation)\">\n <mat-option *ngFor=\"let option of getFilteredDesignationList(i)\" [value]=\"option\">\n {{option.name}}\n </mat-option>\n </mat-autocomplete>\n <!-- <mat-error *ngIf=\"isTermExist\">{{app_strings.alreadyExist}}</mat-error> -->\n </mat-form-field>\n <!-- <mat-error>{{app_strings.alreadyExist}}</mat-error> -->\n </div>\n <div class=\"w-full\">\n <label for=\"name\" class=\"margin-remove-bottom form-label required\">\n Description <mat-icon class=\"info-icon\">info</mat-icon>\n </label>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <textarea matInput formControlName=\"designationDescription\"\n placeholder=\"Type the decription in fewer than 600 characters\"></textarea>\n </mat-form-field>\n </div>\n \n <div class=\"w-full flex justify-end items-center\">\n <button mat-raised-button class=\"saveDesignaton flex justify-center items-center\"\n (click)=\"saveDesignation(i)\">Save</button>\n </div>\n </div>\n </mat-expansion-panel>\n </ng-container>\n </mat-accordion>\n </form>\n </div>\n </div>\n <div class=\"flex justify-end items-center gap-4 mt-5 designation-footer\">\n <button mat-raised-button class=\"cancel flex justify-center items-center\"\n (click)=\"cancel()\">Cancel</button>\n <button mat-raised-button [disabled]=\"!enableAddBtn\" class=\"addBtn flex justify-center items-center\" (click)=\"submitDesignation()\">Add</button>\n </div>\n </div>\n</ng-template>\n<ng-template #compTheme>\n <div class=\"dialogNew\">\n <ng-container [ngTemplateOutlet]=\"modalTitle\"></ng-container>\n <div class=\"flex gap-4\">\n <ng-container *ngFor=\"let term of data?.selectedParentTerms\">\n <div class=\"flex-1 flex-col\">\n <label for=\"name\" class=\"margin-remove-bottom form-label\" aria-label=\"First name label\">\n {{term.category}}\n </label>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <input matInput name=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n [value]=\"term.name\" disabled>\n </mat-form-field>\n </div>\n </ng-container>\n </div>\n <div class=\"row-divider\"></div>\n <form [formGroup]=\"competencyForm\">\n <div class=\"title-text\">\n <label for=\"name\" class=\"margin-remove-bottom form-label\" aria-label=\"First name label\">\n {{'Select Area'}}\n </label>\n <div class=\"mt-5\">\n <mat-radio-group aria-label=\"Select an option\" formControlName=\"compArea\">\n <mat-radio-button class=\"learning-section\" *ngFor=\"let item of allCompetency\" [value]=\"item\" (change)=\"onSelectionArea(item)\">{{item.name}}</mat-radio-button>\n \n </mat-radio-group>\n </div>\n </div>\n \n <ng-container *ngIf=\"data?.mode !== 'multi-create'\">\n <form class=\"themeForm\" [formGroup]=\"createThemeForm\" novalidate\n (ngSubmit)=\"disableCreate?updateTermAssociations():saveThemeTerm()\">\n <div class=\"input-column\">\n <div class=\"input-wrapper margin-top-s\">\n <div class=\"flex gap-4 \">\n <div class=\"flex-1 flex-col\">\n <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n aria-label=\"First name label\">\n Add Name\n </label>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <input matInput formControlName=\"name\" id=\"name\" #name\n placeholder=\"{{app_strings.name}}\"\n (blur)=\"updateDname(name.value, createThemeForm)\">\n <!-- <input matInput formControlName=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n [matAutocomplete]=\"auto\">\n <mat-autocomplete #auto=\"matAutocomplete\"\n (optionSelected)=\"onSelect($event.option, createThemeForm)\">\n <mat-option *ngFor=\"let option of filtedTermLists | async\" [value]=\"option\">\n {{option.name}}\n </mat-option>\n </mat-autocomplete> -->\n </mat-form-field>\n <mat-error *ngIf=\"isTermExist\">{{app_strings.alreadyExist}}</mat-error>\n </div>\n <div class=\"flex-1 flex-col\">\n <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n aria-label=\"First name label\">\n Display Name\n </label>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <input matInput formControlName=\"dname\" id=\"dname\" #dname\n placeholder=\"Competency display name\">\n <!-- <input matInput formControlName=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n [matAutocomplete]=\"auto\"> -->\n <!-- <mat-autocomplete #auto=\"matAutocomplete\"\n (optionSelected)=\"onSelect($event.option, createThemeForm)\">\n <mat-option *ngFor=\"let option of filtedTermLists | async\" [value]=\"option\">\n {{option.name}}\n </mat-option>\n </mat-autocomplete> -->\n <!-- <mat-error *ngIf=\"isTermExist\">{{app_strings.alreadyExist}}</mat-error> -->\n </mat-form-field>\n </div>\n </div>\n\n <div class=\"flex-col mt-2\">\n <label for=\"fname\" class=\"margin-remove-bottom form-label required\"\n i18n=\"First Name label|Label which explains the user to enter first name\"\n i18n-aria-label aria-label=\"First name label\">\n Description\n </label>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <!-- <mat-label>Enter {{data.name}} name</mat-label> -->\n <textarea matInput [cdkTextareaAutosize] [cdkAutosizeMaxRows]=\"10\"\n [cdkAutosizeMinRows]=\"3\" formControlName=\"description\"\n placeholder=\"{{app_strings.description}}\"></textarea>\n </mat-form-field>\n </div>\n </div>\n </div>\n <footer class=\"actions\">\n <button mat-raised-button color=\"default\" type=\"reset\"\n (click)=\"dialogClose('')\">{{app_strings.cancel}}</button>\n <ng-container *ngIf=\"data?.mode === 'create'\">\n <button mat-raised-button color=\"primary\" type=\"submit\" cdkFocusInitial\n [disabled]=\"createThemeForm?.invalid\" *ngIf=\"!disableCreate\">{{app_strings.create}}</button>\n </ng-container>\n <ng-container *ngIf=\"data?.mode === 'edit'\">\n <button mat-raised-button color=\"primary\" type=\"button\" cdkFocusInitial\n (click)=\"updateTermData(createThemeForm, data)\" [disabled]=\"createThemeForm?.invalid\"\n *ngIf=\"!disableCreate\">{{app_strings.update}}</button>\n </ng-container>\n </footer>\n </form>\n </ng-container>\n <ng-container *ngIf=\"data?.mode === 'multi-create'\">\n \n <div class=\"flex flex-end mb-4\">\n <button type=\"button\" class=\"mat-button flex items-center \" *ngIf=\"data.mode === 'multi-create'\" (click)=\"addCompetencyTheme()\">\n <mat-icon class=\"mr-2 mat-icon-custom \">add_circle_outline</mat-icon>\n Add {{data.columnInfo.name}}\n </button>\n </div>\n <mat-accordion formArrayName=\"compThemeFields\">\n <mat-expansion-panel *ngFor=\"let field of competencyForm?.get('compThemeFields')['controls']; let i = index; let isFirst = first\" \n class=\"margin-bottom-l\" [formGroupName]=\"i\" [expanded]=\"isFirst\">\n <mat-expansion-panel-header>\n <mat-panel-title>\n <!-- {{name?.value}} -->\n </mat-panel-title>\n <button mat-button type=\"button\" *ngIf=\"data.mode === 'multi-create'\"\n (click)=\"removeCompFields(i)\">\n <mat-icon class=\"mat-icon-custom \">delete</mat-icon>\n </button>\n </mat-expansion-panel-header>\n <div class=\"input-column\">\n <div class=\"input-wrapper margin-top-s\">\n <div class=\"flex gap-4 \">\n <div class=\"flex-1 flex-col\">\n <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n aria-label=\"First name label\">\n Select Competency Theme\n </label>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <mat-select placeholder=\"Choose the Competency Theme\" formControlName=\"competencyTheme\">\n <!-- <input #search autocomplete=\"off\" placeholder=\"Search\" class=\"assigneeSearch\"\n (keydown.space)=\"$event.stopPropagation()\" formControlName=\"assigneeText\" matInput> -->\n <mat-option *ngFor=\"let option of filteredallCompetencyTheme\" [value]=\"option\" (onSelectionChange)=\"OnThemeSelection($event)\" >{{option.name}}</mat-option>\n </mat-select>\n <!-- <input matInput formControlName=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n [matAutocomplete]=\"auto\">\n <mat-autocomplete #auto=\"matAutocomplete\"\n (optionSelected)=\"onSelect($event.option, createThemeForm)\">\n <mat-option *ngFor=\"let option of filtedTermLists | async\" [value]=\"option\">\n {{option.name}}\n </mat-option>\n </mat-autocomplete> -->\n </mat-form-field>\n <mat-error *ngIf=\"isTermExist\">{{app_strings.alreadyExist}}</mat-error>\n </div>\n <!-- <div class=\"flex-1 flex-col\">\n <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n aria-label=\"First name label\">\n Display Name\n </label>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <input matInput formControlName=\"dname\" id=\"dname\" #dname\n placeholder=\"Competency display name\">\n </mat-form-field>\n </div> -->\n </div>\n\n <div class=\"flex-col mt-2\">\n <label for=\"fname\" class=\"margin-remove-bottom form-label required\"\n i18n=\"First Name label|Label which explains the user to enter first name\"\n i18n-aria-label aria-label=\"First name label\">\n Select Competency Sub-Theme\n </label>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <!-- <mat-label>Enter {{data.name}} name</mat-label> -->\n <mat-select placeholder=\"Choose the Competency Theme\" formControlName=\"competencySubTheme\">\n <!-- <input #search autocomplete=\"off\" placeholder=\"Search\" class=\"assigneeSearch\"\n (keydown.space)=\"$event.stopPropagation()\" formControlName=\"assigneeText\" matInput> -->\n <mat-option *ngFor=\"let option of filteredallCompetencySubTheme\" [value]=\"option\">{{option.name}}</mat-option>\n </mat-select>\n </mat-form-field>\n </div>\n </div>\n </div>\n </mat-expansion-panel>\n </mat-accordion>\n <footer class=\"actions\">\n <button mat-raised-button color=\"default\" type=\"reset\"\n (click)=\"dialogClose('')\">{{app_strings.cancel}}</button>\n <ng-container *ngIf=\"data?.mode === 'create'\">\n <button mat-raised-button color=\"primary\" type=\"submit\" cdkFocusInitial\n [disabled]=\"createThemeForm?.invalid\" *ngIf=\"!disableCreate\">{{app_strings.create}}</button>\n </ng-container>\n <ng-container *ngIf=\"data?.mode === 'multi-create'\">\n <button mat-raised-button color=\"primary\" type=\"button\" cdkFocusInitial\n [disabled]=\"createThemeFormMulti.invalid\" *ngIf=\"!disableCreate\" (click)=\"multiCreate(createThemeFormMulti, data)\">\n {{app_strings.create}}\n </button>\n </ng-container>\n <ng-container *ngIf=\"data?.mode === 'edit'\">\n <button mat-raised-button color=\"primary\" type=\"button\" cdkFocusInitial\n (click)=\"updateTermData(createThemeForm, data)\"\n [disabled]=\"createThemeForm?.invalid || disableUpdate\"\n *ngIf=\"!disableCreate\">{{app_strings.update}}</button>\n </ng-container>\n </footer>\n </ng-container>\n </form>\n \n </div>\n</ng-template>", styles: [".gap-3{gap:1.25rem}.gap-4{gap:1.5rem}.row-divider{width:100%;border-top:1px solid rgba(0,0,0,.08);margin:1rem 0}.defaultForm{padding:16px;display:flex;gap:16px;flex-direction:column}.theme-actions{display:flex;justify-content:right;padding:1em 0;gap:16px;margin-top:30px;border-top:1px solid rgba(0,0,0,.0784313725)}.dialog .mat-dialog-title{padding:1em;margin-bottom:0;background:#00000014}.dialog .mat-form-field{padding:0;background:#fff;border-radius:2px}.dialog .mat-form-field ::ng-deep .mat-form-field-wrapper{padding-bottom:0}.dialog .mat-form-field ::ng-deep .mat-form-field-wrapper .mat-form-field-infix{padding:15px;margin-top:0;border-top:0}.dialog .mat-form-field ::ng-deep .mat-form-field-wrapper .mat-form-field-infix textarea{resize:none}.dialog .mat-form-field-disabled{background:#00000014}.dialog .actions{display:flex;flex-direction:row;justify-content:space-between;padding:0 1em 1em}.dialog .mat-error{padding:0 25px;margin-top:-10px}.dialogNew{padding:0 1rem}.dialogNew .mat-dialog-title{padding:1em;margin-bottom:0}.dialogNew .actions{display:flex;justify-content:right;padding:1em 0;gap:16px;margin-top:16px;border-top:1px solid rgba(0,0,0,.0784313725)}.dialogNew .mat-error{margin-top:-10px}.dialog-title{align-items:center;display:flex}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.mr-5{margin-right:1.5rem}.flex-1{flex:1 1}.margin-remove-bottom{margin-bottom:0}::ng-deep .custom-dialog-container{max-height:90vh}::ng-deep .custom-dialog-container .mat-dialog-container{padding:0;border-radius:0;background:#00000014}@media only screen and (max-width: 1024px){::ng-deep .cdk-overlay-pane{width:40%!important}}@media only screen and (max-width: 992px){::ng-deep .cdk-overlay-pane{width:45%!important}}@media only screen and (max-width: 1024px){.dialog{font-size:12px}.dialog .dialog-title{font-size:24px;height:1em}.dialog button{font-size:12px;line-height:3.5em}.dialog .mat-raised-button{padding:0 3em}}.flex-align{align-items:center;justify-content:flex-start}::ng-deep mat-form-field .mat-form-field-infix .mat-form-field-label,::ng-deep mat-form-field .mat-form-field-infix .mat-select-value{line-height:normal!important}ws-widget-btn-page-back-admin{margin-left:-270px}.max-wid{max-width:400px}::ng-deep .mat-form-field.mat-focused .mat-form-field-label{color:#333232!important}.margin-right-10{margin-right:10px!important}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}::ng-deep .mat-tab-header{margin:0 3rem}.heading{color:#222}.heading.mt-10{margin-top:2.5rem!important}.img-column{flex:100px 0 0}.input-column{flex:auto}.radio-toolbar input[type=radio]{opacity:0;position:fixed;width:0}.radio-toolbar{padding:10px 0}.radio-toolbar label{display:inline-block;padding:7px 21px;font-size:14px;background:#fff 0% 0% no-repeat padding-box;border:1px solid #5F5F5F;border-radius:4px;margin:0 10px 10px 0;color:#5f5f5f;cursor:pointer;transition:all .125s ease-in-out}.radio-toolbar input[type=radio]:checked+label{background:#0074b6 0% 0% no-repeat padding-box;border-radius:6px;border-color:#0074b6;color:#fff}.radio-toolbar input[type=radio]:focus+label{background:#0074b6 0% 0% no-repeat padding-box;border-radius:6px;border-color:#0074b6;color:#fff}.mar{margin-left:30px;min-width:175px}.radio-toolbar label:hover{background:none;border-color:#0074b6;color:#0074b6}::ng-deep .mat-form-field{width:100%}::ng-deep .mat-form-field.full-width{max-width:100%}::ng-deep .mat-form-field.no-pb .mat-form-field-wrapper{padding-bottom:0}.combined-field{width:100%}.w-full-imp{width:100%!important}.btn-success{background-color:#0075b7!important;border-radius:4px;width:240px;box-shadow:none;margin-right:16px}.btn-success.btn-responsive{width:100%}.btn-success:disabled,.btn-success[disabled]{opacity:.6}.btn-danger{height:30px;width:30px}.color-danger{font-size:30px;height:30px;width:30px;color:#e44}::ng-deep .mat-form-field-outline{min-height:40px;background:#fff;border-radius:4px}::ng-deep .mat-form-field-outline .mat-form-field-outline-start{border:1px solid rgba(112,112,112,.4117647059);border-radius:4px 0 0 4px;min-width:8px;border-right-style:none}::ng-deep .mat-form-field-outline .mat-form-field-outline-gap{border:1px solid currentColor;border-radius:82px;border-left-style:none;border-right-style:none}::ng-deep .mat-form-field-outline .mat-form-field-outline-end{border:1px solid rgba(112,112,112,.4117647059);border-left-style:none;border-radius:0 4px 4px 0}::ng-deep .mat-form-field-outline.mat-form-field-outline-thick{min-height:40px;background:#fff;border-radius:4px}::ng-deep .mat-form-field-outline.mat-form-field-outline-thick .mat-form-field-outline-start{border-radius:4px 0 0 4px;min-width:8px;border:1px solid currentColor;border-right-style:none}::ng-deep .mat-form-field-outline.mat-form-field-outline-thick .mat-form-field-outline-gap{border-width:1px;border:1px solid currentColor;border-radius:4px;border-left-style:none;border-right-style:none}::ng-deep .mat-form-field-outline.mat-form-field-outline-thick .mat-form-field-outline-end{border-width:1px;border-radius:0 4px 4px 0;border:1px solid currentColor;border-left-style:none}::ng-deep .mat-form-field-disabled .mat-form-field-outline{background:#ebebeb!important}::ng-deep .mat-form-field-infix{padding:0;margin:0;border:none}::ng-deep .mat-form-field-flex{min-height:40px;align-items:center}::ng-deep .mat-form-field-infix{padding:0;margin:8px 0 0;border:none}.form-label{color:#222;font-size:14px;margin-bottom:.5rem;font-weight:700;font-family:Lato}.form-input{font-size:14px;font-weight:400;font-family:Lato}input.mat-input-element{color:#5f5f5f}::ng-deep .mat-radio-group{padding-bottom:1.34375em}::ng-deep .mat-chip-list-wrapper{margin:0!important}::ng-deep .mat-chip{font-weight:400;background:#f1f9ff 0% 0% no-repeat padding-box!important;border-radius:12px!important;color:#0074b6!important}::ng-deep .mat-chip:hover{filter:brightness(90%)}::ng-deep .mat-chip .mat-chip-remove{opacity:1!important;color:#0074b6!important;border-radius:50%}::ng-deeptextarea .mat-input-element{padding:8px 0}::ng-deep .mat-checkbox-checked.mat-accent .mat-checkbox-background{background:#0074b6 0% 0% no-repeat padding-box!important;border-radius:4px}::ng-deep .mat-checkbox .mat-checkbox-frame{border-radius:4px!important}::ng-deep .mat-form-field-appearance-outline .mat-select-arrow-wrapper{transform:none!important}::ng-deep .mat-tab-label-container .mat-tab-list .mat-tab-labels .mat-tab-label{font-size:18px;color:#222}::ng-deep .mat-tab-label-container .mat-tab-list .mat-tab-labels .mat-tab-label-active .mat-tab-label-content{color:#0074b6}::ng-deep .mat-tab-label-container .mat-tab-list .mat-ink-bar{height:3px;background-color:#0074b6!important}.form-control{background:#fff 0% 0% no-repeat padding-box;border:1px solid rgba(112,112,112,.4117647059);border-radius:4px;display:block}.form-control::placeholder{color:#bebebe;font-size:14px}.form-control:focus{border:2px solid #0074b6;outline:none}.input-wrapper{flex:1;display:flex;flex-wrap:wrap;flex-direction:column}::ng-deep .mat-checkbox-inner-container{height:23px!important;width:23px!important}.flex-expand{flex:1!important}.heading{font-weight:600;font-family:Montserrat;font-size:1.25rem;display:block;padding:0px 0px 1rem 0}::ng-deep .multiselect-dropdown{margin-bottom:20px}::ng-deep .multiselect-dropdown .dropdown-btn{border:1px solid #ccc!important;width:92%!important}::ng-deep .multiselect-dropdown .dropdown-list .filter-textbox input{width:90%!important}.organisation{color:#212529;font-weight:700;font-size:14px;font-family:Lato}.org-name{height:50px;border:1px solid #e2e2e2;border-radius:5px;background-color:#ebebeb;font-size:14px}.add-designation{height:25px;color:#1b4ca1!important;font-weight:500;font-size:14px;font-family:Lato;cursor:pointer}.add-designation .add-icon{color:#1b4ca1!important;height:24px;width:24px;font-size:24px}.info-icon{width:14px;height:14px;font-size:14px;color:#a7a9ae!important}.themDesignation{max-height:90vh;overflow-y:auto}.designation-panel{margin-bottom:0!important;background-color:#eef1f7!important;border:1px solid #DBE0E9;box-shadow:none!important}.designation-panel .deletDesignation{font-size:18px;width:14px;height:14px;color:#5f6063}.designation-panel .saveDesignaton{color:#fff;height:40px;width:80px;background-color:#1b4ca1;border:1px solid #1B4CA1;font-weight:700;font-size:14px;font-family:Lato}.designation-footer{padding:1rem;border-top:1px solid #efefef}.cancel{width:93px;height:40px;font-weight:700;font-size:14px;font-family:Lato;border:1px solid #eee;color:#363636}.addBtn{color:#fff!important;height:40px;width:80px;background-color:#1b4ca1!important;border:1px solid #1B4CA1;font-weight:700;font-size:14px;font-family:Lato}.info-icon{color:#0009;font-size:19px;position:relative;top:3px}::ng-deep .tooltip-sec{background-color:0!important;font-size:12px!important;font-family:500!important;color:#fff!important}.assigneeSearch{height:50px!important;font-size:15px;padding-left:12px;box-sizing:border-box}.disabled-div{pointer-events:none;opacity:.5;background-color:#f9f9f9}.loader-bg{background:#ffffffcf;inset:0;transform:translate(-50% -50%);pointer-events:unset;z-index:999999;display:flex;align-items:center;justify-content:center}\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: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i6.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i6.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i6.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "component", type: i7.MatAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple", "hideSingleSelectionIndicator"], exportAs: ["matAutocomplete"] }, { kind: "component", type: i8.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "directive", type: i7.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { kind: "component", type: i9.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i10.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i11.MatAccordion, selector: "mat-accordion", inputs: ["multi", "hideToggle", "displayMode", "togglePosition"], exportAs: ["matAccordion"] }, { kind: "component", type: i11.MatExpansionPanel, selector: "mat-expansion-panel", inputs: ["disabled", "expanded", "hideToggle", "togglePosition"], outputs: ["opened", "closed", "expandedChange", "afterExpand", "afterCollapse"], exportAs: ["matExpansionPanel"] }, { kind: "component", type: i11.MatExpansionPanelHeader, selector: "mat-expansion-panel-header", inputs: ["tabIndex", "expandedHeight", "collapsedHeight"] }, { kind: "directive", type: i11.MatExpansionPanelTitle, selector: "mat-panel-title" }, { kind: "component", type: i12.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i13.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i14.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i14.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i15.CdkTextareaAutosize, selector: "textarea[cdkTextareaAutosize]", inputs: ["cdkAutosizeMinRows", "cdkAutosizeMaxRows", "cdkTextareaAutosize", "placeholder"], exportAs: ["cdkTextareaAutosize"] }, { kind: "component", type: i16.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "directive", type: i17.MatRadioGroup, selector: "mat-radio-group", exportAs: ["matRadioGroup"] }, { kind: "component", type: i17.MatRadioButton, selector: "mat-radio-button", inputs: ["disableRipple", "tabIndex"], exportAs: ["matRadioButton"] }, { kind: "component", type: i18.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex", "panelWidth", "hideSingleSelectionIndicator"], exportAs: ["matSelect"] }, { kind: "directive", type: i19.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { 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: "directive", type: i3.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { 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: "directive", type: i3.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { kind: "directive", type: i3.FormArrayName, selector: "[formArrayName]", inputs: ["formArrayName"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }] }); }
839
- }
840
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CreateTermComponent, decorators: [{
841
- type: Component,
842
- args: [{ selector: 'lib-create-term', template: "<ng-container [ngSwitch]=\"data?.columnInfo?.code || 'defaultCreate'\">\n <ng-container *ngIf=\"disableMultiCreate\">\n <div class=\"flex flex-col flex-1 w-100 absolute loader-bg items-center pt-5 text-center\">\n <mat-spinner class=\"display-inline-block mb-5\" [diameter]=\"50\" [strokeWidth]=\"3\"></mat-spinner>\n <!-- <p>{{loaderMsg}}</p> -->\n </div>\n </ng-container>\n <ng-container *ngSwitchDefault [ngTemplateOutlet]=\"themeCreate\"></ng-container>\n <ng-container *ngSwitchCase=\"'theme'\" [ngTemplateOutlet]=\"themeCreate\"></ng-container>\n <ng-container *ngSwitchCase=\"'subtheme'\" [ngTemplateOutlet]=\"themeCreate\"></ng-container>\n <ng-container *ngSwitchCase=\"'designation'\" [ngTemplateOutlet]=\"themeDesignation\"></ng-container>\n <ng-container *ngSwitchCase=\"'competency'\" [ngTemplateOutlet]=\"compTheme\"></ng-container>\n</ng-container>\n\n<ng-template #modalTitle>\n <!-- <ng-container *ngIf=\"data?.mode === 'create' || data?.mode === 'multi-create'\">\n <div class=\"dialog-title\" mat-dialog-title>{{data.columnInfo.name === 'Theme' ? app_strings.addCompetency : app_strings.createNew}} {{data.columnInfo.name}}</div>\n </ng-container> -->\n <ng-container *ngIf=\"data?.mode === 'create' || data?.mode === 'multi-create'\">\n <div class=\"dialog-title\" mat-dialog-title>Add {{data?.columnInfo?.config?.categoryDisplayName || data.columnInfo.name }} </div>\n </ng-container>\n <ng-container *ngIf=\"data?.mode === 'view'\">\n <div class=\"dialog-title\" mat-dialog-title></div>\n </ng-container>\n <ng-container *ngIf=\"data?.mode === 'edit'\">\n <div class=\"dialog-title\" mat-dialog-title>{{app_strings.edit}} {{data?.columnInfo?.config?.categoryDisplayName || data.columnInfo.name}}</div>\n </ng-container>\n</ng-template>\n\n<ng-template #defaultCreate>\n <div class=\"dialog\">\n <ng-container [ngTemplateOutlet]=\"modalTitle\"></ng-container>\n <form [formGroup]=\"createTermForm\" novalidate (ngSubmit)=\"disableCreate?updateTermAssociations():saveTerm()\"\n class=\"defaultForm\">\n <mat-form-field appearance=\"outline\">\n <!-- <mat-label>Enter {{data.name}} name</mat-label> -->\n <input matInput formControlName=\"name\" placeholder=\"{{app_strings.name}}\" [matAutocomplete]=\"auto\">\n <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"onSelect($event.option, createTermForm)\">\n <mat-option *ngFor=\"let option of filtedTermLists | async\" [value]=\"option\">\n {{option.name }}\n </mat-option>\n </mat-autocomplete>\n <mat-error *ngIf=\"isTermExist\">{{app_strings.alreadyExist}}</mat-error>\n </mat-form-field>\n <mat-form-field appearance=\"outline\">\n <!-- <mat-label>Enter {{data.name}} name</mat-label> -->\n <textarea matInput formControlName=\"description\" placeholder=\"{{app_strings.description}}\" maxlength=\"2000\"></textarea>\n </mat-form-field>\n <footer class=\"actions\">\n <button mat-raised-button color=\"default\" type=\"reset\"\n (click)=\"dialogClose('')\">{{app_strings.cancel}}</button>\n <button mat-raised-button color=\"primary\" type=\"submit\" cdkFocusInitial\n *ngIf=\"!disableCreate || disableMultiCreate\">{{app_strings.create}}</button>\n <button mat-raised-button color=\"primary\" type=\"submit\" cdkFocusInitial\n *ngIf=\"disableCreate\">{{app_strings.update}}</button>\n </footer>\n </form>\n </div>\n</ng-template>\n\n<ng-template #themeCreate >\n <div class=\"dialogNew\" [ngClass]=\"{'disabled-div': disableMultiCreate}\" >\n <ng-container [ngTemplateOutlet]=\"modalTitle\"></ng-container>\n <div class=\"flex gap-4\">\n <ng-container *ngFor=\"let term of data?.selectedParentTerms\">\n <div class=\"flex-1 flex-col\">\n <label for=\"name\" class=\"margin-remove-bottom form-label\" aria-label=\"First name label\">\n {{getCategoryName(term.category,term)}}\n </label>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <input matInput name=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n [value]=\"term.name\" disabled>\n </mat-form-field>\n </div>\n </ng-container>\n </div>\n <div class=\"row-divider\"></div>\n <ng-container *ngIf=\"data?.mode !== 'multi-create'\">\n <form class=\"themeForm\" [formGroup]=\"createThemeForm\" novalidate\n (ngSubmit)=\"disableCreate?updateTermAssociations():saveThemeTerm()\">\n <div class=\"input-column\">\n <div class=\"input-wrapper margin-top-s\">\n <div class=\"flex gap-4 \" *ngIf=\"data.columnInfo?.code !== 'competencyarea' && data.mode === 'view'\">\n <div class=\"flex-1 flex-col\">\n <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n aria-label=\"First name label\">\n Name\n </label>\n \n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <mat-select placeholder=\"{{app_strings?.name}}\" formControlName=\"name\" id=\"name\" #name (selectionChange)=\"change($event,createThemeForm)\">\n <input #search autocomplete=\"off\" placeholder=\"Search\" class=\"assigneeSearch\"\n (keydown.space)=\"$event.stopPropagation()\" (keyup)=\"onKey($event)\" matInput>\n <mat-option *ngFor=\"let option of filteredMasterList\" (blur)=\"updateDname(option?.title, createThemeForm)\" [disabled]=\"onDisableTheme(option)\" [value]=\"option\">{{option.title}}</mat-option>\n <mat-option *ngIf=\"filteredMasterList.length === 0\" disabled>\n No results found!\n </mat-option>\n </mat-select>\n\n <!-- <input matInput formControlName=\"name\" id=\"name\" #name\n placeholder=\"{{app_strings.name}}\"\n (blur)=\"updateDname(name.value, createThemeForm)\" maxlength=\"70\"> -->\n <!-- <input matInput formControlName=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n [matAutocomplete]=\"auto\">\n <mat-autocomplete #auto=\"matAutocomplete\"\n (optionSelected)=\"onSelect($event.option, createThemeForm)\">\n <mat-option *ngFor=\"let option of filtedTermLists | async\" [value]=\"option\">\n {{option.name}}\n </mat-option>\n </mat-autocomplete> -->\n </mat-form-field>\n <mat-error *ngIf=\"isTermExist\">{{app_strings.alreadyExist}}</mat-error>\n </div>\n <div class=\"flex-1 flex-col\">\n \n <div class=\"flex\">\n\n <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n aria-label=\"First name label\">\n Display Name\n </label>\n <mat-icon class=\"info-icon cursor-pointer\" [matTooltip]=\"toolTipText\" \n matTooltipClass=\"tooltip-sec\">info_outline</mat-icon>\n \n </div>\n \n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <input matInput formControlName=\"dname\" id=\"dname\" #dname \n placeholder=\"Field automatically generated from the name field.\" maxlength=\"70\" >\n <!-- <input matInput formControlName=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n [matAutocomplete]=\"auto\"> -->\n <!-- <mat-autocomplete #auto=\"matAutocomplete\"\n (optionSelected)=\"onSelect($event.option, createThemeForm)\">\n <mat-option *ngFor=\"let option of filtedTermLists | async\" [value]=\"option\">\n {{option.name}}\n </mat-option>\n </mat-autocomplete> -->\n <!-- <mat-error *ngIf=\"isTermExist\">{{app_strings.alreadyExist}}</mat-error> -->\n </mat-form-field>\n </div>\n </div>\n <div class=\"flex gap-4 \" *ngIf=\"data.columnInfo?.code === 'competencyarea' && data.mode === 'view'\">\n <div class=\"flex-1 flex-col\">\n <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n aria-label=\"First name label\">\n Name\n </label>\n \n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <input autocomplete=\"off\" \n matInput [value]=\"data?.childrenData?.name\" disabled>\n </mat-form-field>\n </div>\n </div>\n\n <div class=\"flex-col mt-2\">\n <label for=\"fname\" class=\"margin-remove-bottom form-label\"\n i18n=\"First Name label|Label which explains the user to enter first name\"\n i18n-aria-label aria-label=\"First name label\">\n Description\n </label>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <!-- <mat-label>Enter {{data.name}} name</mat-label> -->\n <textarea matInput [cdkTextareaAutosize] [cdkAutosizeMaxRows]=\"10\"\n [cdkAutosizeMinRows]=\"3\" formControlName=\"description\"\n placeholder=\"{{app_strings.description}}\" maxlength=\"2000\"></textarea>\n </mat-form-field>\n </div>\n </div>\n </div>\n <footer class=\"actions\">\n <button mat-raised-button color=\"default\" type=\"reset\"\n (click)=\"dialogClose('')\">{{app_strings.cancel}}</button>\n <ng-container *ngIf=\"data?.mode === 'create'\">\n <button mat-raised-button color=\"primary\" type=\"submit\" cdkFocusInitial\n [disabled]=\"createThemeForm?.invalid\" *ngIf=\"!disableCreate\">{{app_strings.create}}</button>\n </ng-container>\n <ng-container *ngIf=\"data?.mode === 'edit'\">\n <button mat-raised-button color=\"primary\" type=\"button\" cdkFocusInitial\n (click)=\"updateTermData(createThemeForm, data)\" [disabled]=\"createThemeForm?.invalid || disableUpdate\"\n *ngIf=\"!disableCreate\">{{app_strings.update}}</button>\n </ng-container>\n </footer>\n </form>\n </ng-container>\n <ng-container *ngIf=\"data?.mode === 'multi-create'\">\n <form class=\"themeForm\" [formGroup]=\"createThemeFormMulti\" novalidate\n (ngSubmit)=\"disableCreate?updateTermAssociations():saveThemeTerm()\">\n <div class=\"flex flex-end mb-4\">\n <button type=\"button\" class=\"mat-button flex items-center \" *ngIf=\"data.mode === 'multi-create'\" (click)=\"addThemeFields()\">\n <mat-icon class=\"mr-2 mat-icon-custom \">add_circle_outline</mat-icon>\n Add more\n </button>\n </div>\n <mat-accordion formArrayName=\"themeFields\">\n <mat-expansion-panel #mep=\"matExpansionPanel\" *ngFor=\"let field of themeFieldsControls; let i = index; let isFirst = first\" \n class=\"margin-bottom-l\" [formGroupName]=\"i\" [expanded]=\"isFirst\">\n <mat-expansion-panel-header>\n <mat-panel-title>\n {{getExpansionTitle(field)}} \n </mat-panel-title>\n <button mat-button type=\"button\" *ngIf=\"data.mode === 'multi-create'\"\n (click)=\"removeThemeFields(i)\">\n <mat-icon class=\"mat-icon-custom \">delete</mat-icon>\n </button>\n </mat-expansion-panel-header>\n <div class=\"input-column\">\n <div class=\"input-wrapper margin-top-s\">\n <div class=\"flex gap-4 \">\n <div class=\"flex-1 flex-col\">\n <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n aria-label=\"First name label\">\n Name\n </label>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <!-- <input matInput formControlName=\"name\" id=\"name\" #name\n placeholder=\"{{app_strings.name}}\"\n (blur)=\"updateDname(name.value, createThemeFormMulti, i)\" maxlength=\"70\"> -->\n <!-- <input matInput formControlName=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n [matAutocomplete]=\"auto\">\n <mat-autocomplete #auto=\"matAutocomplete\"\n (optionSelected)=\"onSelect($event.option, createThemeForm)\">\n <mat-option *ngFor=\"let option of filtedTermLists | async\" [value]=\"option\">\n {{option.name}}\n </mat-option>\n </mat-autocomplete> -->\n \n <mat-select placeholder=\"{{app_strings?.name}}\" formControlName=\"name\" id=\"name\" #name (selectionChange)=\"change($event,createThemeFormMulti, i )\">\n <input #search autocomplete=\"off\" placeholder=\"Search\" class=\"assigneeSearch\"\n (keydown.space)=\"$event.stopPropagation()\" (keyup)=\"onKey($event)\" matInput>\n <mat-option *ngFor=\"let option of filteredMasterList\" (blur)=\"updateDname(option?.title, createThemeFormMulti, i)\" [disabled]=\"onDisableTheme(option)\" [value]=\"option\">{{option.title}} </mat-option>\n <mat-option *ngIf=\"filteredMasterList.length === 0\" disabled>\n No results found!\n </mat-option>\n \n </mat-select>\n \n </mat-form-field>\n <mat-error *ngIf=\"isTermExist\">{{app_strings?.alreadyExist}}</mat-error>\n </div>\n <div class=\"flex-1 flex-col\">\n <div class=\"flex\">\n <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n aria-label=\"First name label\">\n Display Name\n </label>\n \n \n <mat-icon class=\"info-icon cursor-pointer\" [matTooltip]=\"toolTipText\" \n matTooltipClass=\"tooltip-sec\">info_outline</mat-icon>\n \n \n \n \n \n </div>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <input matInput formControlName=\"dname\" id=\"dname\" #dname\n placeholder=\"Field automatically generated from the name field.\" maxlength=\"70\" [disabled]=\"name?.value?.length === 0\">\n <!-- <input matInput formControlName=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n [matAutocomplete]=\"auto\"> -->\n <!-- <mat-autocomplete #auto=\"matAutocomplete\"\n (optionSelected)=\"onSelect($event.option, createThemeForm)\">\n <mat-option *ngFor=\"let option of filtedTermLists | async\" [value]=\"option\">\n {{option.name}}\n </mat-option>\n </mat-autocomplete> -->\n <!-- <mat-error *ngIf=\"isTermExist\">{{app_strings.alreadyExist}}</mat-error> -->\n </mat-form-field>\n </div>\n </div>\n\n <div class=\"flex-col mt-2\">\n <label for=\"fname\" class=\"margin-remove-bottom form-label\"\n i18n=\"First Name label|Label which explains the user to enter first name\"\n i18n-aria-label aria-label=\"First name label\">\n Description\n </label>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <!-- <mat-label>Enter {{data.name}} name</mat-label> -->\n <textarea matInput [cdkTextareaAutosize] [cdkAutosizeMaxRows]=\"10\"\n [cdkAutosizeMinRows]=\"3\" formControlName=\"description\"\n placeholder=\"{{app_strings.description}}\" maxlength=\"2000\"></textarea>\n </mat-form-field>\n </div>\n </div>\n </div>\n <div class=\"flex flex-end\">\n <button mat-raised-button color=\"primary\" type=\"button\" (click)=\"mep.expanded = false\"\n [disabled]=\"createThemeFormMulti?.get('themeFields')['controls'][i].invalid\">\n Save\n </button>\n </div>\n </mat-expansion-panel>\n </mat-accordion>\n <footer class=\"actions\">\n <button mat-raised-button color=\"default\" type=\"reset\"\n (click)=\"dialogClose('')\">{{app_strings.cancel}}</button>\n <ng-container *ngIf=\"data?.mode === 'create'\">\n <button mat-raised-button color=\"primary\" type=\"submit\" cdkFocusInitial\n [disabled]=\"createThemeForm?.invalid\" *ngIf=\"!disableCreate\">{{app_strings.add_btn}}</button>\n </ng-container>\n <ng-container *ngIf=\"data?.mode === 'multi-create'\">\n <button mat-raised-button color=\"primary\" type=\"button\" cdkFocusInitial\n [disabled]=\"createThemeFormMulti.invalid || disableMultiCreate\" *ngIf=\"!disableCreate\" (click)=\"multiCreate(createThemeFormMulti, data)\">\n {{app_strings.add_btn}}\n </button>\n </ng-container>\n <ng-container *ngIf=\"data?.mode === 'edit'\">\n <button mat-raised-button color=\"primary\" type=\"button\" cdkFocusInitial\n (click)=\"updateTermData(createThemeForm, data)\"\n [disabled]=\"createThemeForm?.invalid || disableUpdate\"\n *ngIf=\"!disableCreate\">{{app_strings.update}}</button>\n </ng-container>\n </footer>\n </form>\n </ng-container>\n </div>\n</ng-template>\n\n<ng-template #themeDesignation>\n <div class=\"themDesignation\">\n <div class=\"dialogNew\">\n <ng-container [ngTemplateOutlet]=\"modalTitle\"></ng-container>\n <div class=\"mb-2\">\n <span class=\"organisation\">Organisation</span>\n <div class=\"org-name pl-4 flex items-center\">\n <!-- <span>Department of Fisheries</span> -->\n <span>{{data?.columnInfo?.name}}</span>\n </div>\n </div>\n <div class=\"row-divider\"></div>\n <div class=\"flex w-full items-center justify-end mt-4\">\n <a class=\"add-designation flex justify-center items-center\" (click)=\"addDesignation()\">\n <mat-icon class=\"add-icon mr-2\">add_circle_outline</mat-icon>\n <span>Add Designations</span>\n </a>\n </div>\n <div class=\"mt-5\">\n <form [formGroup]=\"createThemeForm\">\n <mat-accordion class=\"flex flex-col gap-2\" formArrayName=\"designations\">\n <ng-container *ngFor=\"let designation of designationControls; let i = index\">\n <mat-expansion-panel [formGroupName]=\"i\" class=\"designation-panel\" [expanded]=\"panelOpenState[i]\">\n <mat-expansion-panel-header>\n <div class=\"flex w-full items-center justify-end\">\n <mat-icon class=\"deletDesignation mr-4\" (click)=\"deleteDesignation(i)\">delete</mat-icon>\n </div>\n </mat-expansion-panel-header>\n <div class=\"flex flex-col gap-2 \">\n <div class=\"w-full\">\n <label for=\"name\" class=\"margin-remove-bottom form-label required\">\n Designation Name <mat-icon class=\"info-icon\">info</mat-icon>\n </label>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <input matInput formControlName=\"name\" placeholder=\"Type here\" [matAutocomplete]=\"auto\" (change)=\"clearSelectedDesignaionOnChange(i, $event)\">\n <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"onSelect($event.option, designation)\">\n <mat-option *ngFor=\"let option of getFilteredDesignationList(i)\" [value]=\"option\">\n {{option.name}}\n </mat-option>\n </mat-autocomplete>\n <!-- <mat-error *ngIf=\"isTermExist\">{{app_strings.alreadyExist}}</mat-error> -->\n </mat-form-field>\n <!-- <mat-error>{{app_strings.alreadyExist}}</mat-error> -->\n </div>\n <div class=\"w-full\">\n <label for=\"name\" class=\"margin-remove-bottom form-label required\">\n Description <mat-icon class=\"info-icon\">info</mat-icon>\n </label>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <textarea matInput formControlName=\"designationDescription\"\n placeholder=\"Type the decription in fewer than 600 characters\"></textarea>\n </mat-form-field>\n </div>\n \n <div class=\"w-full flex justify-end items-center\">\n <button mat-raised-button class=\"saveDesignaton flex justify-center items-center\"\n (click)=\"saveDesignation(i)\">Save</button>\n </div>\n </div>\n </mat-expansion-panel>\n </ng-container>\n </mat-accordion>\n </form>\n </div>\n </div>\n <div class=\"flex justify-end items-center gap-4 mt-5 designation-footer\">\n <button mat-raised-button class=\"cancel flex justify-center items-center\"\n (click)=\"cancel()\">Cancel</button>\n <button mat-raised-button [disabled]=\"!enableAddBtn\" class=\"addBtn flex justify-center items-center\" (click)=\"submitDesignation()\">Add</button>\n </div>\n </div>\n</ng-template>\n<ng-template #compTheme>\n <div class=\"dialogNew\">\n <ng-container [ngTemplateOutlet]=\"modalTitle\"></ng-container>\n <div class=\"flex gap-4\">\n <ng-container *ngFor=\"let term of data?.selectedParentTerms\">\n <div class=\"flex-1 flex-col\">\n <label for=\"name\" class=\"margin-remove-bottom form-label\" aria-label=\"First name label\">\n {{term.category}}\n </label>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <input matInput name=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n [value]=\"term.name\" disabled>\n </mat-form-field>\n </div>\n </ng-container>\n </div>\n <div class=\"row-divider\"></div>\n <form [formGroup]=\"competencyForm\">\n <div class=\"title-text\">\n <label for=\"name\" class=\"margin-remove-bottom form-label\" aria-label=\"First name label\">\n {{'Select Area'}}\n </label>\n <div class=\"mt-5\">\n <mat-radio-group aria-label=\"Select an option\" formControlName=\"compArea\">\n <mat-radio-button class=\"learning-section\" *ngFor=\"let item of allCompetency\" [value]=\"item\" (change)=\"onSelectionArea(item)\">{{item.name}}</mat-radio-button>\n \n </mat-radio-group>\n </div>\n </div>\n \n <ng-container *ngIf=\"data?.mode !== 'multi-create'\">\n <form class=\"themeForm\" [formGroup]=\"createThemeForm\" novalidate\n (ngSubmit)=\"disableCreate?updateTermAssociations():saveThemeTerm()\">\n <div class=\"input-column\">\n <div class=\"input-wrapper margin-top-s\">\n <div class=\"flex gap-4 \">\n <div class=\"flex-1 flex-col\">\n <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n aria-label=\"First name label\">\n Add Name\n </label>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <input matInput formControlName=\"name\" id=\"name\" #name\n placeholder=\"{{app_strings.name}}\"\n (blur)=\"updateDname(name.value, createThemeForm)\">\n <!-- <input matInput formControlName=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n [matAutocomplete]=\"auto\">\n <mat-autocomplete #auto=\"matAutocomplete\"\n (optionSelected)=\"onSelect($event.option, createThemeForm)\">\n <mat-option *ngFor=\"let option of filtedTermLists | async\" [value]=\"option\">\n {{option.name}}\n </mat-option>\n </mat-autocomplete> -->\n </mat-form-field>\n <mat-error *ngIf=\"isTermExist\">{{app_strings.alreadyExist}}</mat-error>\n </div>\n <div class=\"flex-1 flex-col\">\n <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n aria-label=\"First name label\">\n Display Name\n </label>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <input matInput formControlName=\"dname\" id=\"dname\" #dname\n placeholder=\"Competency display name\">\n <!-- <input matInput formControlName=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n [matAutocomplete]=\"auto\"> -->\n <!-- <mat-autocomplete #auto=\"matAutocomplete\"\n (optionSelected)=\"onSelect($event.option, createThemeForm)\">\n <mat-option *ngFor=\"let option of filtedTermLists | async\" [value]=\"option\">\n {{option.name}}\n </mat-option>\n </mat-autocomplete> -->\n <!-- <mat-error *ngIf=\"isTermExist\">{{app_strings.alreadyExist}}</mat-error> -->\n </mat-form-field>\n </div>\n </div>\n\n <div class=\"flex-col mt-2\">\n <label for=\"fname\" class=\"margin-remove-bottom form-label required\"\n i18n=\"First Name label|Label which explains the user to enter first name\"\n i18n-aria-label aria-label=\"First name label\">\n Description\n </label>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <!-- <mat-label>Enter {{data.name}} name</mat-label> -->\n <textarea matInput [cdkTextareaAutosize] [cdkAutosizeMaxRows]=\"10\"\n [cdkAutosizeMinRows]=\"3\" formControlName=\"description\"\n placeholder=\"{{app_strings.description}}\"></textarea>\n </mat-form-field>\n </div>\n </div>\n </div>\n <footer class=\"actions\">\n <button mat-raised-button color=\"default\" type=\"reset\"\n (click)=\"dialogClose('')\">{{app_strings.cancel}}</button>\n <ng-container *ngIf=\"data?.mode === 'create'\">\n <button mat-raised-button color=\"primary\" type=\"submit\" cdkFocusInitial\n [disabled]=\"createThemeForm?.invalid\" *ngIf=\"!disableCreate\">{{app_strings.create}}</button>\n </ng-container>\n <ng-container *ngIf=\"data?.mode === 'edit'\">\n <button mat-raised-button color=\"primary\" type=\"button\" cdkFocusInitial\n (click)=\"updateTermData(createThemeForm, data)\" [disabled]=\"createThemeForm?.invalid\"\n *ngIf=\"!disableCreate\">{{app_strings.update}}</button>\n </ng-container>\n </footer>\n </form>\n </ng-container>\n <ng-container *ngIf=\"data?.mode === 'multi-create'\">\n \n <div class=\"flex flex-end mb-4\">\n <button type=\"button\" class=\"mat-button flex items-center \" *ngIf=\"data.mode === 'multi-create'\" (click)=\"addCompetencyTheme()\">\n <mat-icon class=\"mr-2 mat-icon-custom \">add_circle_outline</mat-icon>\n Add {{data.columnInfo.name}}\n </button>\n </div>\n <mat-accordion formArrayName=\"compThemeFields\">\n <mat-expansion-panel *ngFor=\"let field of competencyForm?.get('compThemeFields')['controls']; let i = index; let isFirst = first\" \n class=\"margin-bottom-l\" [formGroupName]=\"i\" [expanded]=\"isFirst\">\n <mat-expansion-panel-header>\n <mat-panel-title>\n <!-- {{name?.value}} -->\n </mat-panel-title>\n <button mat-button type=\"button\" *ngIf=\"data.mode === 'multi-create'\"\n (click)=\"removeCompFields(i)\">\n <mat-icon class=\"mat-icon-custom \">delete</mat-icon>\n </button>\n </mat-expansion-panel-header>\n <div class=\"input-column\">\n <div class=\"input-wrapper margin-top-s\">\n <div class=\"flex gap-4 \">\n <div class=\"flex-1 flex-col\">\n <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n aria-label=\"First name label\">\n Select Competency Theme\n </label>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <mat-select placeholder=\"Choose the Competency Theme\" formControlName=\"competencyTheme\">\n <!-- <input #search autocomplete=\"off\" placeholder=\"Search\" class=\"assigneeSearch\"\n (keydown.space)=\"$event.stopPropagation()\" formControlName=\"assigneeText\" matInput> -->\n <mat-option *ngFor=\"let option of filteredallCompetencyTheme\" [value]=\"option\" (onSelectionChange)=\"OnThemeSelection($event)\" >{{option.name}}</mat-option>\n </mat-select>\n <!-- <input matInput formControlName=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n [matAutocomplete]=\"auto\">\n <mat-autocomplete #auto=\"matAutocomplete\"\n (optionSelected)=\"onSelect($event.option, createThemeForm)\">\n <mat-option *ngFor=\"let option of filtedTermLists | async\" [value]=\"option\">\n {{option.name}}\n </mat-option>\n </mat-autocomplete> -->\n </mat-form-field>\n <mat-error *ngIf=\"isTermExist\">{{app_strings.alreadyExist}}</mat-error>\n </div>\n <!-- <div class=\"flex-1 flex-col\">\n <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n aria-label=\"First name label\">\n Display Name\n </label>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <input matInput formControlName=\"dname\" id=\"dname\" #dname\n placeholder=\"Competency display name\">\n </mat-form-field>\n </div> -->\n </div>\n\n <div class=\"flex-col mt-2\">\n <label for=\"fname\" class=\"margin-remove-bottom form-label required\"\n i18n=\"First Name label|Label which explains the user to enter first name\"\n i18n-aria-label aria-label=\"First name label\">\n Select Competency Sub-Theme\n </label>\n <mat-form-field appearance=\"outline\" class=\"flex-1\">\n <!-- <mat-label>Enter {{data.name}} name</mat-label> -->\n <mat-select placeholder=\"Choose the Competency Theme\" formControlName=\"competencySubTheme\">\n <!-- <input #search autocomplete=\"off\" placeholder=\"Search\" class=\"assigneeSearch\"\n (keydown.space)=\"$event.stopPropagation()\" formControlName=\"assigneeText\" matInput> -->\n <mat-option *ngFor=\"let option of filteredallCompetencySubTheme\" [value]=\"option\">{{option.name}}</mat-option>\n </mat-select>\n </mat-form-field>\n </div>\n </div>\n </div>\n </mat-expansion-panel>\n </mat-accordion>\n <footer class=\"actions\">\n <button mat-raised-button color=\"default\" type=\"reset\"\n (click)=\"dialogClose('')\">{{app_strings.cancel}}</button>\n <ng-container *ngIf=\"data?.mode === 'create'\">\n <button mat-raised-button color=\"primary\" type=\"submit\" cdkFocusInitial\n [disabled]=\"createThemeForm?.invalid\" *ngIf=\"!disableCreate\">{{app_strings.create}}</button>\n </ng-container>\n <ng-container *ngIf=\"data?.mode === 'multi-create'\">\n <button mat-raised-button color=\"primary\" type=\"button\" cdkFocusInitial\n [disabled]=\"createThemeFormMulti.invalid\" *ngIf=\"!disableCreate\" (click)=\"multiCreate(createThemeFormMulti, data)\">\n {{app_strings.create}}\n </button>\n </ng-container>\n <ng-container *ngIf=\"data?.mode === 'edit'\">\n <button mat-raised-button color=\"primary\" type=\"button\" cdkFocusInitial\n (click)=\"updateTermData(createThemeForm, data)\"\n [disabled]=\"createThemeForm?.invalid || disableUpdate\"\n *ngIf=\"!disableCreate\">{{app_strings.update}}</button>\n </ng-container>\n </footer>\n </ng-container>\n </form>\n \n </div>\n</ng-template>", styles: [".gap-3{gap:1.25rem}.gap-4{gap:1.5rem}.row-divider{width:100%;border-top:1px solid rgba(0,0,0,.08);margin:1rem 0}.defaultForm{padding:16px;display:flex;gap:16px;flex-direction:column}.theme-actions{display:flex;justify-content:right;padding:1em 0;gap:16px;margin-top:30px;border-top:1px solid rgba(0,0,0,.0784313725)}.dialog .mat-dialog-title{padding:1em;margin-bottom:0;background:#00000014}.dialog .mat-form-field{padding:0;background:#fff;border-radius:2px}.dialog .mat-form-field ::ng-deep .mat-form-field-wrapper{padding-bottom:0}.dialog .mat-form-field ::ng-deep .mat-form-field-wrapper .mat-form-field-infix{padding:15px;margin-top:0;border-top:0}.dialog .mat-form-field ::ng-deep .mat-form-field-wrapper .mat-form-field-infix textarea{resize:none}.dialog .mat-form-field-disabled{background:#00000014}.dialog .actions{display:flex;flex-direction:row;justify-content:space-between;padding:0 1em 1em}.dialog .mat-error{padding:0 25px;margin-top:-10px}.dialogNew{padding:0 1rem}.dialogNew .mat-dialog-title{padding:1em;margin-bottom:0}.dialogNew .actions{display:flex;justify-content:right;padding:1em 0;gap:16px;margin-top:16px;border-top:1px solid rgba(0,0,0,.0784313725)}.dialogNew .mat-error{margin-top:-10px}.dialog-title{align-items:center;display:flex}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.mr-5{margin-right:1.5rem}.flex-1{flex:1 1}.margin-remove-bottom{margin-bottom:0}::ng-deep .custom-dialog-container{max-height:90vh}::ng-deep .custom-dialog-container .mat-dialog-container{padding:0;border-radius:0;background:#00000014}@media only screen and (max-width: 1024px){::ng-deep .cdk-overlay-pane{width:40%!important}}@media only screen and (max-width: 992px){::ng-deep .cdk-overlay-pane{width:45%!important}}@media only screen and (max-width: 1024px){.dialog{font-size:12px}.dialog .dialog-title{font-size:24px;height:1em}.dialog button{font-size:12px;line-height:3.5em}.dialog .mat-raised-button{padding:0 3em}}.flex-align{align-items:center;justify-content:flex-start}::ng-deep mat-form-field .mat-form-field-infix .mat-form-field-label,::ng-deep mat-form-field .mat-form-field-infix .mat-select-value{line-height:normal!important}ws-widget-btn-page-back-admin{margin-left:-270px}.max-wid{max-width:400px}::ng-deep .mat-form-field.mat-focused .mat-form-field-label{color:#333232!important}.margin-right-10{margin-right:10px!important}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}::ng-deep .mat-tab-header{margin:0 3rem}.heading{color:#222}.heading.mt-10{margin-top:2.5rem!important}.img-column{flex:100px 0 0}.input-column{flex:auto}.radio-toolbar input[type=radio]{opacity:0;position:fixed;width:0}.radio-toolbar{padding:10px 0}.radio-toolbar label{display:inline-block;padding:7px 21px;font-size:14px;background:#fff 0% 0% no-repeat padding-box;border:1px solid #5F5F5F;border-radius:4px;margin:0 10px 10px 0;color:#5f5f5f;cursor:pointer;transition:all .125s ease-in-out}.radio-toolbar input[type=radio]:checked+label{background:#0074b6 0% 0% no-repeat padding-box;border-radius:6px;border-color:#0074b6;color:#fff}.radio-toolbar input[type=radio]:focus+label{background:#0074b6 0% 0% no-repeat padding-box;border-radius:6px;border-color:#0074b6;color:#fff}.mar{margin-left:30px;min-width:175px}.radio-toolbar label:hover{background:none;border-color:#0074b6;color:#0074b6}::ng-deep .mat-form-field{width:100%}::ng-deep .mat-form-field.full-width{max-width:100%}::ng-deep .mat-form-field.no-pb .mat-form-field-wrapper{padding-bottom:0}.combined-field{width:100%}.w-full-imp{width:100%!important}.btn-success{background-color:#0075b7!important;border-radius:4px;width:240px;box-shadow:none;margin-right:16px}.btn-success.btn-responsive{width:100%}.btn-success:disabled,.btn-success[disabled]{opacity:.6}.btn-danger{height:30px;width:30px}.color-danger{font-size:30px;height:30px;width:30px;color:#e44}::ng-deep .mat-form-field-outline{min-height:40px;background:#fff;border-radius:4px}::ng-deep .mat-form-field-outline .mat-form-field-outline-start{border:1px solid rgba(112,112,112,.4117647059);border-radius:4px 0 0 4px;min-width:8px;border-right-style:none}::ng-deep .mat-form-field-outline .mat-form-field-outline-gap{border:1px solid currentColor;border-radius:82px;border-left-style:none;border-right-style:none}::ng-deep .mat-form-field-outline .mat-form-field-outline-end{border:1px solid rgba(112,112,112,.4117647059);border-left-style:none;border-radius:0 4px 4px 0}::ng-deep .mat-form-field-outline.mat-form-field-outline-thick{min-height:40px;background:#fff;border-radius:4px}::ng-deep .mat-form-field-outline.mat-form-field-outline-thick .mat-form-field-outline-start{border-radius:4px 0 0 4px;min-width:8px;border:1px solid currentColor;border-right-style:none}::ng-deep .mat-form-field-outline.mat-form-field-outline-thick .mat-form-field-outline-gap{border-width:1px;border:1px solid currentColor;border-radius:4px;border-left-style:none;border-right-style:none}::ng-deep .mat-form-field-outline.mat-form-field-outline-thick .mat-form-field-outline-end{border-width:1px;border-radius:0 4px 4px 0;border:1px solid currentColor;border-left-style:none}::ng-deep .mat-form-field-disabled .mat-form-field-outline{background:#ebebeb!important}::ng-deep .mat-form-field-infix{padding:0;margin:0;border:none}::ng-deep .mat-form-field-flex{min-height:40px;align-items:center}::ng-deep .mat-form-field-infix{padding:0;margin:8px 0 0;border:none}.form-label{color:#222;font-size:14px;margin-bottom:.5rem;font-weight:700;font-family:Lato}.form-input{font-size:14px;font-weight:400;font-family:Lato}input.mat-input-element{color:#5f5f5f}::ng-deep .mat-radio-group{padding-bottom:1.34375em}::ng-deep .mat-chip-list-wrapper{margin:0!important}::ng-deep .mat-chip{font-weight:400;background:#f1f9ff 0% 0% no-repeat padding-box!important;border-radius:12px!important;color:#0074b6!important}::ng-deep .mat-chip:hover{filter:brightness(90%)}::ng-deep .mat-chip .mat-chip-remove{opacity:1!important;color:#0074b6!important;border-radius:50%}::ng-deeptextarea .mat-input-element{padding:8px 0}::ng-deep .mat-checkbox-checked.mat-accent .mat-checkbox-background{background:#0074b6 0% 0% no-repeat padding-box!important;border-radius:4px}::ng-deep .mat-checkbox .mat-checkbox-frame{border-radius:4px!important}::ng-deep .mat-form-field-appearance-outline .mat-select-arrow-wrapper{transform:none!important}::ng-deep .mat-tab-label-container .mat-tab-list .mat-tab-labels .mat-tab-label{font-size:18px;color:#222}::ng-deep .mat-tab-label-container .mat-tab-list .mat-tab-labels .mat-tab-label-active .mat-tab-label-content{color:#0074b6}::ng-deep .mat-tab-label-container .mat-tab-list .mat-ink-bar{height:3px;background-color:#0074b6!important}.form-control{background:#fff 0% 0% no-repeat padding-box;border:1px solid rgba(112,112,112,.4117647059);border-radius:4px;display:block}.form-control::placeholder{color:#bebebe;font-size:14px}.form-control:focus{border:2px solid #0074b6;outline:none}.input-wrapper{flex:1;display:flex;flex-wrap:wrap;flex-direction:column}::ng-deep .mat-checkbox-inner-container{height:23px!important;width:23px!important}.flex-expand{flex:1!important}.heading{font-weight:600;font-family:Montserrat;font-size:1.25rem;display:block;padding:0px 0px 1rem 0}::ng-deep .multiselect-dropdown{margin-bottom:20px}::ng-deep .multiselect-dropdown .dropdown-btn{border:1px solid #ccc!important;width:92%!important}::ng-deep .multiselect-dropdown .dropdown-list .filter-textbox input{width:90%!important}.organisation{color:#212529;font-weight:700;font-size:14px;font-family:Lato}.org-name{height:50px;border:1px solid #e2e2e2;border-radius:5px;background-color:#ebebeb;font-size:14px}.add-designation{height:25px;color:#1b4ca1!important;font-weight:500;font-size:14px;font-family:Lato;cursor:pointer}.add-designation .add-icon{color:#1b4ca1!important;height:24px;width:24px;font-size:24px}.info-icon{width:14px;height:14px;font-size:14px;color:#a7a9ae!important}.themDesignation{max-height:90vh;overflow-y:auto}.designation-panel{margin-bottom:0!important;background-color:#eef1f7!important;border:1px solid #DBE0E9;box-shadow:none!important}.designation-panel .deletDesignation{font-size:18px;width:14px;height:14px;color:#5f6063}.designation-panel .saveDesignaton{color:#fff;height:40px;width:80px;background-color:#1b4ca1;border:1px solid #1B4CA1;font-weight:700;font-size:14px;font-family:Lato}.designation-footer{padding:1rem;border-top:1px solid #efefef}.cancel{width:93px;height:40px;font-weight:700;font-size:14px;font-family:Lato;border:1px solid #eee;color:#363636}.addBtn{color:#fff!important;height:40px;width:80px;background-color:#1b4ca1!important;border:1px solid #1B4CA1;font-weight:700;font-size:14px;font-family:Lato}.info-icon{color:#0009;font-size:19px;position:relative;top:3px}::ng-deep .tooltip-sec{background-color:0!important;font-size:12px!important;font-family:500!important;color:#fff!important}.assigneeSearch{height:50px!important;font-size:15px;padding-left:12px;box-sizing:border-box}.disabled-div{pointer-events:none;opacity:.5;background-color:#f9f9f9}.loader-bg{background:#ffffffcf;inset:0;transform:translate(-50% -50%);pointer-events:unset;z-index:999999;display:flex;align-items:center;justify-content:center}\n"] }]
843
- }], ctorParameters: function () { return [{ type: i1.MatLegacyDialogRef }, { type: undefined, decorators: [{
844
- type: Inject,
845
- args: [MAT_DIALOG_DATA]
846
- }] }, { type: i2.FrameworkService }, { type: i3.UntypedFormBuilder }, { type: i4.OdcsService }, { type: i5.MatLegacySnackBar }, { type: i0.ChangeDetectorRef }]; } });
847
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-term.component.js","sourceRoot":"","sources":["../../../../../../../library/sunbird-cb/tree-hierarchy/src/lib/components/create-term/create-term.component.ts","../../../../../../../library/sunbird-cb/tree-hierarchy/src/lib/components/create-term/create-term.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectorRef, Component, Inject, OnInit } from '@angular/core';\nimport { MatLegacyDialogRef as MatDialogRef, MAT_LEGACY_DIALOG_DATA as MAT_DIALOG_DATA } from '@angular/material/legacy-dialog';\nimport { FrameworkService } from '../../services/framework.service';\nimport { startWith, map } from 'rxjs/operators';\nimport { UntypedFormArray, UntypedFormBuilder, UntypedFormGroup, Validators } from '@angular/forms';\n// import { Identifiers } from '@angular/compiler';\nimport { NSFramework } from '../../models/framework.model';\nimport * as appConstants from '../../constants/app-constant';\nimport { labels } from '../../labels/strings';\nimport { Card } from '../../models/variable-type.model';\nimport { OdcsService } from '../../services/odcs.service';\nimport { MatLegacySnackBar as MatSnackBar } from '@angular/material/legacy-snack-bar';\nimport * as _ from 'lodash'\n\n@Component({\n  selector: 'lib-create-term',\n  templateUrl: './create-term.component.html',\n  styleUrls: ['./create-term.component.scss']\n})\n\nexport class CreateTermComponent implements OnInit, AfterViewInit {\n  name: string = '';\n  termLists: Array<Card> = [];\n  filtedTermLists: any;\n  createTermForm: any\n  createThemeForm: UntypedFormGroup = this.fb.group({});\n  createThemeFormMulti: UntypedFormGroup = this.fb.group({});\n  disableCreate: boolean = false;\n  disableUpdate: boolean = false;\n  disableMultiCreate: boolean = false;\n  isTermExist: boolean = false;\n  selectedTerm: Card = {};\n  app_strings = labels;\n  colCode = ''\n  savedDesignations: any = []\n  addedDesignationCount = 0\n  designationsList = []\n  panelOpenState: any[] = [];\n  allCompetency:any[]=[]\n  seletedCompetencyArea: any\n  allCompetencyTheme:any[]=[]\n  filteredallCompetencyTheme:any[]=[]\n  allCompetencySubtheme:any[]=[]\n  filteredallCompetencySubTheme:any[]=[]\n  competencyForm: UntypedFormGroup = this.fb.group({})\n  compLabeltext:string = ''\n  masterList:any[]=[];\n  filteredMasterList:any[]=[];\n  expansionTitle:string = ''\n  private debounceTimeout: any;\n  private debounceDelay: number = 500;\n  values= ''\n  toolTipText = `You can customize this display name for learners to see, as it's what they will view.`\n  previousCategoryCode:string = '';\n  previousTermCode:string = '';\n  previousCatCode:string = '';\n  previousTermCatCode:string=''\n  selectedTermArray: any= []\n\n\n  constructor(\n    public dialogRef: MatDialogRef<CreateTermComponent>,\n    @Inject(MAT_DIALOG_DATA) public data: any,\n    private frameWorkService: FrameworkService,\n    private fb: UntypedFormBuilder,\n    private odcsService: OdcsService,\n    private _snackBar: MatSnackBar,\n    private cdr:ChangeDetectorRef\n  ) { \n    this.getKcmSearch()\n  }\n\n  ngOnInit() {\n    \n    this.termLists = this.data.columnInfo.children\n    this.compLabeltext = this.data.columnInfo.config.labelName\n    \n    this.initTermForm()\n    \n  }\n\n  ngAfterViewInit(): void {\n    this.cdr.detectChanges()\n  }\n\n  initTermForm() {\n    this.createTermForm = this.fb.group({\n      name: ['', [Validators.required]],\n      description: ['']\n    })\n    this.createThemeForm = this.fb.group({\n      name: ['', [Validators.required]],\n      dname: [{value: '', disabled: true}, [Validators.required]],\n      description: ['']\n    })\n    // this.createThemeForm.controls['dname'].disable()\n    // this.createThemeForm.controls['name'].valueChanges.subscribe((value)=>{\n    //   if(value.length){\n    //    this.createThemeForm.controls['dname'].enable()\n    //   }\n    // })\n    this.createThemeFormMulti = this.fb.group({\n      themeFields:this.fb.array([this.createThemeFields()])\n    })\n    // this.initializeValueChanges()\n    this.filtedTermLists = this.createTermForm.get('name').valueChanges.pipe(\n      startWith(''),\n      map(value => {\n        if (value && this.createTermForm.controls.dname) {\n          this.createTermForm.controls.dname.enable()\n        } else if (this.createTermForm.controls.dname) {\n          this.createTermForm.controls.dname.disable()\n        }\n        return this._filter(value || '')\n      }),\n    );\n\n    // if mode is \"view\" then check for which type of form has to be used and then append the values in form\n    if (\n      this.data &&\n      (this.data.mode === 'view')\n    ) {\n      switch (this.data.columnInfo.code) {\n        case 'theme': this.updateFormView(this.createThemeForm, this.data)\n          break\n        case 'subtheme': this.updateFormView(this.createThemeForm, this.data)\n          break\n        default: this.updateFormView(this.createThemeForm, this.data)\n          break\n      }\n      this.disableCreate = true\n    } else if (this.data &&\n      (this.data.mode === 'edit')) {\n      switch (this.data.columnInfo.code) {\n        case 'theme': this.updateFormEdit(this.createThemeForm, this.data)\n          break\n        case 'subtheme': this.updateFormEdit(this.createThemeForm, this.data)\n          break\n        default: this.updateFormEdit(this.createThemeForm, this.data)\n          break\n      }\n    } else if (this.data &&\n      (this.data.mode === 'multi-create')) {\n      // switch (this.data.columnInfo.code) {\n      //   case 'theme': this.updateFormEdit(this.createThemeForm, this.data)\n      //     break\n      //   case 'subtheme': this.updateFormEdit(this.createThemeForm, this.data)\n      //     break\n      //   default: this.updateFormEdit(this.createThemeForm, this.data)\n      //     break\n      // }\n    }\n  }\n\n  getComptencyData(){\n    // const filterObj = {\n    //   search: {\n    //     type: 'Competency Area',\n    //   },\n    //   filter: {\n    //     isDetail: true,\n    //   },\n    // }\n    // this.frameWorkService.getFilterEntity(filterObj).subscribe((data)=>{\n    \n    //  if(data && data.length){\n    //   this.allCompetency = data\n    //  }\n    // })\n  }\n  // initializeValueChanges() {\n  //   this.themeFields.controls.forEach((group: FormGroup) => {\n  //     this.setUpValueChanges(group);\n  //   });\n  // }\n\n  // setUpValueChanges(group: FormGroup) {\n  //   group.controls['name'].valueChanges.subscribe(value => {\n  //     const dnameControl = group.controls['dname'];\n  //     dnameControl.disable();\n  //     if (value.trim().length) {\n  //       dnameControl.enable();\n  //     } else {\n  //       dnameControl.disable();\n  //     }\n  //   });\n  // }\n\n  get themeFields(): UntypedFormArray {\n    return this.createThemeFormMulti.get('themeFields') as UntypedFormArray;\n  }\n\n  get themeFieldsControls() {\n    const themeFields = this.createThemeFormMulti.get('themeFields')\n    return (<any>themeFields)['controls']\n  }\n\n  createThemeFields(): UntypedFormGroup {\n    return this.fb.group({\n      name: ['', [Validators.required]],\n      dname: [{value: '', disabled: true}, [Validators.required]],\n      description: ['',]\n    });\n  }\n\n  addThemeFields() {\n    this.values = ''\n    this.filteredMasterList = [...this.masterList]\n    if (this.data.mode === 'multi-create') {\n      // this.themeFields.push(this.createThemeFields());\n      this.themeFields.insert(0, this.createThemeFields());\n    }\n  }\n\n  removeThemeFields(index: number) {\n    if (this.data.mode === 'multi-create') {\n      this.themeFields.removeAt(index);\n    }\n  }\n  getCreateName(name: string): string {\n   switch(name){\n    case 'Theme':\n      return `Add Competency ${name}`;\n    case 'Sub Theme':\n      return `Add Competency ${name}`;\n    default:\n      return `Add ${name}`;\n   }\n  }\n\n  getCategoryName(categoryName:any, term:any){\n    this.previousCategoryCode = categoryName;\n    this.previousTermCode = term.code\n    \n    switch(categoryName){\n      case 'competencyarea':\n        return 'Competency Area';\n      case 'theme':\n        return 'Competency Theme';\n      case 'subtheme':\n        return 'Competency Sub Theme';\n      default:\n        return categoryName; // Default return to handle any unmatched case\n     }\n  }\n\n\n  getName(item:any){\n  return item.toUpperCase()\n  }\n\n  getLabelName(labelName:string): string {\n    \n   switch(labelName){\n    case 'Theme':\n      return `Competency ${labelName} name`;\n      case 'Sub Theme':\n      return `Competency ${labelName} name`\n      default:\n        return labelName; // Default return to handle any unmatched case\n   }\n  }\n\n \n\n  createCompThemeFields():UntypedFormGroup {\n    return this.fb.group({\n      competencyTheme:['', [Validators.required]],\n      competencySubTheme:['', [Validators.required]]\n    })\n  }\n\n  addCompetencyTheme(){\n    if (this.data.mode === 'multi-create') {\n      this.compThemeFields.push(this.createCompThemeFields());\n    }\n  }\n\n  removeCompFields(index: number) {\n    if (this.data.mode === 'multi-create') {\n      this.compThemeFields.removeAt(index);\n    }\n  }\n\n  get compThemeFields(): UntypedFormArray {\n    return this.competencyForm.get('compThemeFields') as UntypedFormArray;\n  }\n\n  // get compThemeFieldsControls() {\n  //   const createCompThemeFields = this.competencyForm.get('createCompThemeFields')\n  //   return (<any>createCompThemeFields)['controls']\n  // }\n\n\n  updateFormView(form:any, data:any) {\n    if(data && data.childrenData && data.childrenData.additionalProperties && data.childrenData.additionalProperties.displayName){\n      form.get('dname').patchValue(data.childrenData.additionalProperties.displayName)\n    }\n    form.get('description').patchValue(data.childrenData.description)    \n    \n      if (data.childrenData.name && this.masterList.length) {\n        const assignName = this.masterList.find(option =>\n          data.childrenData.refId === option.id\n        )\n        if (assignName) {\n          form.controls['name'].setValue(assignName)\n        }\n        \n      }\n  \n    \n    // form.get('name').patchValue(data.childrenData.name)\n    \n    setTimeout(() => {\n      form.get('name').disable()\n      form.get('dname').disable()\n      form.get('description').disable()\n      \n      \n    })\n  }\n\n  updateFormEdit(form:any, data:any) {\n    form.get('dname').patchValue(data.childrenData.additionalProperties.displayName)\n    form.get('description').patchValue(data.childrenData.description)\n    if (data.childrenData.name && this.masterList.length) {\n      const assignName = this.masterList.find(option =>\n        data.childrenData.name === option.title\n      )\n      if (assignName) {\n        form.controls['name'].setValue(assignName)\n      }\n      \n    }\n    // form.get('name').patchValue(data.childrenData.name)\n   \n    setTimeout(() => {\n      form.get('name').disable()\n      form.get('dname').enable()\n    })\n  }\n\n  onKey(event:any){\n    //  this.values = event.target.value.toLowerCase();\n    //  this.filteredMasterList = this.filterOrgValues(this.values, this.masterList)\n\n     clearTimeout(this.debounceTimeout);\n    \n     // Set the new timeout\n     this.debounceTimeout = setTimeout(() => {\n       this.values = event.target.value.toLowerCase();\n       this.filteredMasterList = this.filterOrgValues(this.values, this.masterList);\n     }, this.debounceDelay);\n  }\n\n \n\n  filterOrgValues(searchValue: string, array: any) {\n    return array.filter((value: any) =>\n      value.title.toLowerCase().includes(searchValue.toLowerCase()))\n  }\n\n  getKcmSearch(){\n    const requestObj = {\n      filterCriteriaMap: {\n        status: \"Live\",\n        isActive: true\n    },\n    requestedFields: [],\n    pageNumber: 0,\n    pageSize:1000\n    }\n    this.frameWorkService.getKcmSearchList(requestObj,this.data.columnInfo.code).subscribe((response:any)=>{\n      if(response.data && response.data.length){\n        this.masterList = response.data;\n        this.filteredMasterList = [...this.masterList]\n        setTimeout(()=>{\n          if(this.data &&\n            (this.data.mode === 'edit')){\n              this.updateFormEdit(this.createThemeForm, this.data)\n            }\n            else if(this.data &&\n              (this.data.mode === 'view')){\n                this.updateFormView(this.createThemeForm, this.data)\n            }\n\n          \n        },1000)\n       \n\n      }\n    })\n   \n    \n  }\n\n  onDisableTheme(option: any){\n    let parentCol\n    const parentColumnConfigData = this.frameWorkService.getPreviousCategory(this.data.columnInfo.code)\n    if(parentColumnConfigData) {\n      parentCol = this.frameWorkService.selectionList.get(parentColumnConfigData.code)\n    }\n    let result = -1\n    if(parentCol && parentCol.children && parentCol.children.length){\n      result = parentCol.children.findIndex((ele: any) => {\n        if( (ele.refType === 'theme'|| ele.refType === 'subtheme') ) {\n          return ele.name.toLowerCase() === option.title.toLowerCase();\n        }\n        return false;\n      })\n      \n   \n      \n    }\n    if(result < 0){\n      let formArray = this.createThemeFormMulti.get('themeFields') as UntypedFormArray;\n      result = formArray.value.findIndex((formEle: any) => {\n        if(formEle.name && formEle.name.id){\n          return formEle.name.id === option.id;\n        }\n        return false;\n      });\n     }\n    //\n    \n    return result >= 0 ? true: false\n  }\n\n  multiCreate(form:any, _data:any) {\n    this.disableMultiCreate = true\n    let counter = 0\n    let createdTerms:any = []\n    if(form.valid) {\n      \n      const themeFields = form && form.value && form.value.themeFields\n      \n      if(themeFields && themeFields.length) {\n        themeFields.forEach((val:any, _i:any) =>{\n          const term: NSFramework.ICreateTerm = {\n            code: this.frameWorkService.getUuid(),\n            name: _.get(val, 'name.title'),\n            description: val.description,\n            category: this.data.columnInfo.code,\n            status: appConstants.LIVE,\n            refId:val.name.id,\n            refType:this.data.columnInfo.code,\n            // framework:this.data.frameworkId,\n            // approvalStatus:appConstants.DRAFT,\n            parents: [\n              { identifier: `${this.data.frameworkId.toLowerCase()}_${this.data.columnInfo.code}` }\n            ],\n            additionalProperties: {\n              displayName:val.dname,\n              timeStamp: new Date().getTime(),\n            }\n          }\n          const requestBody: any = {\n            request: {\n              term: term\n            }\n          }\n    \n          this.frameWorkService.createTerm(this.data.frameworkId, this.data.columnInfo.code, requestBody).subscribe((res: any) => {\n            requestBody.request.term['identifier'] = res.result.node_id[0]\n            createdTerms.push(requestBody.request.term)\n            \n            counter++\n            \n            if(counter === themeFields.length){\n\n\n              const parentColumn:any = this.frameWorkService.getPreviousCategory(this.data.columnInfo.code)\n              let parentCol: any = this.frameWorkService.selectionList.get(parentColumn.code)\n              this.updateTermAssociationsMultiV2(createdTerms , parentCol)\n              // this.updateTermAssociationsMulti(createdTerms)\n              // this.dialogClose({ term: createdTerms, created: true, multi:true })\n            }\n          })\n        })\n        this.disableMultiCreate = true\n      }\n    }\n  }\n\n  async updateTermAssociationsMulti(createdTerms: any[]) {\n     let parent: any\n    if(createdTerms && createdTerms.length) {\n      let createdTermsCounter = 0\n      for(let createdTerm of createdTerms) {\n        this.selectedTerm = createdTerm\n        let associations = []\n        let temp\n        let counter = 0\n        for(const [value] of this.frameWorkService.selectionList){\n           parent = value\n          counter++\n          temp = parent.children ? parent.children.filter((child: any) => child.identifier === this.selectedTerm.identifier) : null\n          associations = parent.children ? parent.children.map((c:any) => {\n            // return { identifier: c.identifier, approvalStatus: c.associationProperties?c.associationProperties.approvalStatus: 'Draft' }\n            return c.identifier ?  { identifier: c.identifier } : null\n          }) : []\n          if (temp && temp.length) {\n            this.isTermExist = true\n            return\n          } else {\n              associations.push({ identifier: this.selectedTerm.identifier })\n              this.isTermExist = false\n              // if(createdTermsCounter === (createdTerms.length-1)) {\n                const reguestBody = {\n                  request: {\n                    term: {\n                      ...(associations && associations.length) ? {associations: [...associations]} : null,\n                    }\n                  }\n                }\n                // this.dialogClose({ term: this.selectedTerm, created: true })\n                await this.callUpdateAssociations(counter, parent, reguestBody)\n                \n              // }\n          }\n        }\n        createdTermsCounter++\n        if(createdTermsCounter === createdTerms.length) {\n          this.frameWorkService.updateFrameworkList(this.data.columnInfo.code, parent, createdTerms )\n          this.dialogClose({ term: [this.selectedTerm], created: true, multi:true })\n          this.disableMultiCreate =false;\n          if(createdTerms[0].category === 'theme'){\n            this._snackBar.open(`Competency ${createdTerms[0].category} created successfully.`)\n          }\n          if(createdTerms[0].category === 'subtheme'){\n            this._snackBar.open(`Competency ${createdTerms[0].category} created successfully.`)\n          }\n        }\n      }\n    }\n  }\n\n  callUpdateAssociations(counter:any, parent:any, reguestBody:any): Promise<any>{\n    return new Promise((resolve) => {\n      this.frameWorkService.updateTerm(this.data.frameworkId, parent.category, parent.code, reguestBody).subscribe(() => {\n        parent['children'] = parent && parent.children ?[...parent.children, ...[this.selectedTerm]]:[this.selectedTerm]\n\n        if (counter === this.frameWorkService.selectionList.size) {\n          // this.selectedTerm['associationProperties']['approvalStatus'] = 'Draft';\n  \n          // this value is for selected term in case of create scenario, in case of edit scenario this won't be avaiable \n          // so term is set from childdata which is received from params in updateData\n          // const value = (this.selectedTerm && this.selectedTerm.identifier) ? this.selectedTerm : {}\n          // const found = parent.children ? parent.children.find(c=> c.identifier === this.selectedTerm.identifier) : false\n          // if(!found) {\n          //   parent.children ? parent.children.push(this.selectedTerm) : parent['children'] = [this.selectedTerm]\n          // }\n          this.disableUpdate = false\n          // this.frameWorkService.publishFramework().subscribe(res => {\n          //   // this.dialogRef.close(term)\n          \n          //   return resolve(true)\n          // });\n          resolve(true)\n        } else {\n          return resolve(true)\n        }\n      }, (_err: any) => {\n        console.error(`Edit ${this.data.columnInfo.name} failed, please try again later`)\n      })\n    })\n  }\n\n  updateDname(_name: any, _form:any, _i?:any) {\n    // if(this.data.mode === 'create' && !form.controls['dname'].value.trim().length){\n    //   form.get('dname').patchValue(name)\n    // }\n    // if(this.data.mode === 'multi-create' && !form.controls.themeFields.controls[i].controls['dname'].value.trim().length){\n    //   form.controls.themeFields.controls[i].controls['dname'].patchValue(name)\n    // }\n  }\n  change(event: any,form: any, i?: any){\n    if(this.data && this.data.mode) { \n      if(this.data.mode === 'create'){\n        form.get('dname').patchValue(event.source.value.title)\n        this.expansionTitle = event.source.value.title\n        this.cdr.detectChanges()\n\n      }\n      if(this.data.mode === 'multi-create'){\n        const formToUpdate = form.controls.themeFields.controls[i]\n        formToUpdate.controls['dname'].patchValue(event.source.value.title)\n        this.expansionTitle = event.source.value.title\n        this.cdr.detectChanges()\n        if(formToUpdate.controls.name.valid && formToUpdate.controls.dname) {\n          formToUpdate.controls.dname.enable()\n        } else if(formToUpdate.controls.dname) {\n          formToUpdate.controls.dname.disable()\n        }\n      }\n    }\n   \n  }\n\n  getExpansionTitle(form: any) {\n    const details = form.get('name').value\n    return _.get(details, 'title', '')\n  }\n  \n\n  //#region (designations)\n\n  get designationControls() {\n    return (this.createThemeForm.get('designations') as UntypedFormArray).controls;\n  }\n\n  loadDesignations() {\n    this.odcsService.getDesignations({}).subscribe(\n      (data: any) => {\n        this.designationsList = data.responseData\n      },\n      (_err: any) => {\n      })\n  }\n\n  getFilteredDesignationList(index: string) {\n    const filterKey = this.createThemeForm.value.designations[index].name.toLowerCase()\n    if(filterKey && this.designationsList) {\n      const filteredList = this.designationsList.filter((designation: any) => designation.name.toLowerCase().includes(filterKey))\n      return filteredList\n    }\n\n    return []\n  }\n\n  addDesignation() {\n    const newDesignation = this.fb.group({\n      name: ['', Validators.required],\n      id:[null, Validators.required],\n      designationDescription: ['', [Validators.required, Validators.maxLength(600)]],\n      isSaved: [false], // isSaved can be used to change button text from save to update if needed\n      creationId: this.addedDesignationCount // creationId is created to use locally to give unique id to added records\n    });\n    this.addedDesignationCount = this.addedDesignationCount + 1;\n    (this.createThemeForm.get('designations') as UntypedFormArray).insert(0, newDesignation);\n    // this.panelOpenState.insert(0, true)\n    this.panelOpenState.splice(0, 0, true);\n  }\n\n  clearSelectedDesignaionOnChange(index:any, event:any) {\n    const selectedName = this.createThemeForm.value.designations[index].name\n    if(selectedName !== event.value) {\n      const designationsToReset:any = this.designationControls[index]\n      designationsToReset.get('id').reset()\n    }\n  }\n\n  deleteDesignation(index: number) {\n    const reovedCreationId = this.designationControls[index].value.creationId;\n    (this.createThemeForm.get('designations') as UntypedFormArray).removeAt(index);\n    this.savedDesignations = this.savedDesignations.filter((savedDesignation: any) => savedDesignation.creationId !== reovedCreationId)\n  }\n\n  saveDesignation(index: number) {\n    const designations = this.designationControls\n    const designationToSave = designations[index]\n    if (designationToSave.valid) {\n      designationToSave.value.isSaved = true\n      const savedDesignationIndex = this.savedDesignations.findIndex((e:any) => e.creationId === designationToSave.value.creationId)\n      if (savedDesignationIndex >= 0) {\n        this.savedDesignations[savedDesignationIndex] = designationToSave.value\n      } else {\n        this.savedDesignations.push(designationToSave.value)\n      }\n    }\n  }\n\n  submitDesignation() {\n    \n  }\n\n  cancel() {\n    this.dialogRef.close()\n  }\n\n  get enableAddBtn() {\n    if(this.colCode === 'designation') {\n      return this.designationControls.length > 0 ? true : false\n    }\n    return false\n  }\n\n  //#endregion\n  \n  private _filter(searchTxt: any): Card[] {\n    let isExist;\n    this.disableCreate = false\n    this.isTermExist = false\n    this.createTermForm.get('description').enable()\n    // this.createTermForm.get('description').patchValue('')\n    const filterValue = typeof (searchTxt) === 'object' ? this._normalizeValue(searchTxt.name) : this._normalizeValue(searchTxt);\n    isExist = this.termLists.filter((term:any) => this._normalizeValue(term.name).includes(filterValue));\n    return isExist\n  }\n\n  private _normalizeValue(value: string): string {\n    return value.toLowerCase().replace(/\\s/g, '');\n  }\n\n  onSelectionArea(option:any){\n    this.allCompetency.forEach((val:any)=>{\n      if (option.name === val.name) {\n        this.seletedCompetencyArea = val\n        this.allCompetencyTheme = val.children\n        this.filteredallCompetencyTheme = this.allCompetencyTheme\n\n      }\n    })\n   \n  }\n\n  OnThemeSelection(event:any) {\n    \n    const selectedTheme = event.source.value\n    this.filteredallCompetencyTheme.forEach((val: any) => {\n      if (selectedTheme.name === val.name) {\n        this.allCompetencySubtheme = val.children\n        this.filteredallCompetencySubTheme = this.allCompetencySubtheme\n      }\n\n    })\n\n\n  }\n\n  // compAreaSelected(option: any) {\n  //   this.resetCompSubfields()\n  //   this.allCompetencies.forEach((val: any) => {\n  //     if (option.name === val.name) {\n  //       this.seletedCompetencyArea = val\n  //       this.allCompetencyTheme = val.children\n  //       this.filteredallCompetencyTheme = this.allCompetencyTheme\n  \n  //     }\n  //   })\n  // }\n\n  onSelect(term:any, form:any) {\n    switch (this.colCode) {\n      case 'designation':\n        form.get('name').patchValue(term.value.name)\n        form.get('id').patchValue(term.value.id)\n        break;\n      default:\n        this.selectedTerm = term.value\n        form.get('name').patchValue(term.value.name)\n        form.get('dname').patch(term.value.dname)\n        form.get('description').patchValue(term.value.description)\n        form.get('description').disable()\n        this.disableCreate = true\n    }\n  }\n\n  saveTerm() {\n    if (this._filter(this.createTermForm.value.name).length > 0) {\n      this.isTermExist = true\n      \n      return\n    }\n    if (this.createTermForm.valid) {\n      const term: NSFramework.ICreateTerm = {\n        code: this.frameWorkService.getUuid(),\n        name: this.createTermForm.value.name,\n        description: this.createTermForm.value.description,\n        category: this.data.columnInfo.code,\n        status: appConstants.LIVE,\n        // framework:this.data.frameworkId,\n        // approvalStatus:appConstants.DRAFT,\n        parents: [\n          { identifier: `${this.data.frameworkId.toLowerCase()}_${this.data.columnInfo.code}` }\n        ],\n        additionalProperties: {\n          displayName: this.createTermForm.value.dname,\n          timeStamp: new Date().getTime(),\n        }\n      }\n      const requestBody:any = {\n        request: {\n          term: term\n        }\n      }\n\n      this.frameWorkService.createTerm(this.data.frameworkId, this.data.columnInfo.code, requestBody).subscribe((res: any) => {\n        requestBody.request.term['identifier'] = res.result.node_id[0]\n        this.dialogClose({ term: requestBody.request.term, created: true })\n        this.selectedTerm = requestBody.request.term\n        this.updateTermAssociations()\n      })\n    }\n  }\n\n  updateTermData(form:any, data:any) {\n    let additionalProperties =  data.childrenData.additionalProperties\n    additionalProperties['displayName'] = this.createThemeForm.value.dname\n    form.value.additionalProperties = additionalProperties\n    \n    form.value.displayName = form.value.dname\n    \n    this.disableUpdate = true\n    const formData = {\n      // use this if you need disabled field values : form.getRawValue()\n      ...form.value,\n      // displayName:{...form.value.dname}\n    }\n    const updateData = {\n      formData,\n      updateTermData: data.childrenData\n    }\n    this.updateTermDataAssociations(updateData)\n  }\n\n\n  updateTermDataAssociations(updateData:any) {\n    this.disableMultiCreate = true\n    let selectionData = this.frameWorkService.selectionList.get(this.data.columnInfo.code)\n    if(!selectionData ) {\n      selectionData = this.data.childrenData\n    }\n    const listThme = this.frameWorkService.list.get(this.data.columnInfo.code)\n    let themAssociations: any\n    if(listThme && listThme.children && listThme.children.length) {\n      const data = listThme.children.find((c) => c.identifier === selectionData.identifier)\n      themAssociations = data.associations ? data.associations.map((c:any) => {\n        // return { identifier: c.identifier, approvalStatus: c.associationProperties?c.associationProperties.approvalStatus: 'Draft' }\n        return c.identifier ?  { identifier: c.identifier } : null\n      }) : []\n    }\n    const reguestBody = {\n      request: {\n        term: {\n          ...updateData.formData,\n          ...(themAssociations && themAssociations.length) ? {associations: themAssociations} : null,\n        }\n      }\n    }\n    this.frameWorkService.updateTerm(this.data.frameworkId, selectionData.category, selectionData.code, reguestBody).subscribe(() => {\n        // this.selectedTerm['associationProperties']['approvalStatus'] = 'Draft';\n\n        // this value is for selected term in case of create scenario, in case of edit scenario this won't be avaiable \n        // so term is set from childdata which is received from params in updateData\n        const value = (this.selectedTerm && this.selectedTerm.identifier) ? this.selectedTerm : (updateData) ? {...updateData.updateTermData, ...updateData.formData} : {}\n        \n        this.disableUpdate = false\n        \n        // const selectionData = this.frameWorkService.selectionList.get(this.data.columnInfo.code)\n        selectionData['description'] = reguestBody.request.term.description\n        selectionData['additionalProperties'] = reguestBody.request.term.additionalProperties\n        selectionData['associations'] = themAssociations\n        \n\n        this._snackBar.open(`Competency ${value.category} updated successfully`)\n        this.dialogClose({ term: { ...value }, created: true })\n        this.disableMultiCreate = false;\n        this.frameWorkService.updateFullTermDataLocalMap(this.data.columnInfo.code, selectionData)\n    }, (_err: any) => {\n      console.error(`Edit ${this.data.columnInfo.name} failed, please try again later`)\n    })\n  }\n\n  updateTermAssociations(updateData?: any) {\n    let associations = []\n    let temp\n    let counter = 0\n    // let localIsExist = false\n    this.frameWorkService.selectionList.forEach((parent) => {\n      counter++\n      temp = parent.children ? parent.children.filter((child:any) => child.identifier === this.selectedTerm.identifier) : null\n      associations = parent.children ? parent.children.map((c:any) => {\n        // return { identifier: c.identifier, approvalStatus: c.associationProperties?c.associationProperties.approvalStatus: 'Draft' }\n        return c.identifier ?  { identifier: c.identifier } : null\n      }) : []\n      if (temp && temp.length) {\n        this.isTermExist = true\n        return\n      } else {\n        // associations.push({ identifier: this.selectedTerm.identifier, approvalStatus: appConstants.DRAFT })\n        if(this.selectedTerm && this.selectedTerm.identifier) {\n          associations.push({ identifier: this.selectedTerm.identifier })\n        }\n        this.isTermExist = false\n        const reguestBody = {\n          request: {\n            term: {\n              ...(updateData && updateData.formData && updateData.updateTermData.code === parent.code) ? {...updateData.formData}: null,\n              ...(associations && associations.length) ? {associations: [...associations]} : null,\n            }\n          }\n        }\n        \n        // this.dialogClose({ term: this.selectedTerm, created: true })\n        this.frameWorkService.updateTerm(this.data.frameworkId, parent.category, parent.code, reguestBody).subscribe(() => {\n          if (counter === this.frameWorkService.selectionList.size) {\n            // this.selectedTerm['associationProperties']['approvalStatus'] = 'Draft';\n\n            // this value is for selected term in case of create scenario, in case of edit scenario this won't be avaiable \n            // so term is set from childdata which is received from params in updateData\n            const value = (this.selectedTerm && this.selectedTerm.identifier) ? this.selectedTerm : (updateData) ? {...updateData.updateTermData, ...updateData.formData} : {}\n            \n            this.disableUpdate = false\n            this._snackBar.open(`Competency ${value.category} updated successfully`)\n            this.dialogClose({ term: { ...value }, created: true })\n          }\n        }, (_err: any) => {\n          console.error(`Edit ${this.data.columnInfo.name} failed, please try again later`)\n        })\n      }\n    })\n  }\n\n  saveThemeTerm() {\n    if (this._filter(this.createThemeForm.value.name).length > 0) {\n      this.isTermExist = true\n      return\n    }\n    if (this.createThemeForm.valid) {\n      const term: NSFramework.ICreateTerm = {\n        code: this.frameWorkService.getUuid(),\n        name: this.createThemeForm.value.name,\n        description: this.createThemeForm.value.description,\n       \n        category: this.data.columnInfo.code,\n        status: appConstants.LIVE,\n        // approvalStatus:appConstants.DRAFT,\n        parents: [\n          { identifier: `${this.data.frameworkId.toLowerCase()}_${this.data.columnInfo.code}` }\n        ],\n        additionalProperties: {\n          displayName:this.createTermForm.value.dname,\n          timeStamp: new Date().getTime(),\n        }\n      }\n      const requestBody:any = {\n        request: {\n          term: term\n        }\n      }\n\n      this.frameWorkService.createTerm(this.data.frameworkId, this.data.columnInfo.code, requestBody).subscribe((res: any) => {\n        requestBody.request.term['identifier'] = res.result.node_id[0]\n        this.dialogClose({ term: requestBody.request.term, created: true })\n        this.selectedTerm = requestBody.request.term\n        this.updateTermAssociations()\n      }, (_err: any) => {\n        console.error(`Create ${this.data.columnInfo.name} failed, please try again later`)\n      })\n    }\n  }\n\n  dialogClose(term: any) {\n    this.frameWorkService.publishFramework().subscribe(() => {\n      this.dialogRef.close(term)\n    });\n  }\n\n\n  async updateTermAssociationsMultiV2(createdTerms: any[], parentSelectedTerm?:any) {\n   \n    this.selectedTermArray = []\n    // let createdTermsCounter = 0\n    let createdTermsIdentifiers = []\n    this.selectedTermArray = createdTerms\n    this.selectedTerm = createdTerms[createdTerms.length -1]\n    for(let createdTerm of createdTerms) {\n      createdTermsIdentifiers.push({ identifier: createdTerm.identifier })\n    }\n    let associations = []\n    let counter = 0\n   if(createdTerms && createdTerms.length) {\n      let parent: any\n     let createdTermsCounter = 0\n     if(!parentSelectedTerm) {\n      for(let createdTerm of createdTerms) {\n        this.selectedTerm = createdTerm\n        let temp\n        for(const [value] of this.frameWorkService.selectionList){\n           parent = value\n          counter++\n          temp = parent.children ? parent.children.filter((child: any) => child.identifier === this.selectedTerm.identifier) : null\n          associations = parent.children ? parent.children.map((c: any) => {\n            // return { identifier: c.identifier, approvalStatus: c.associationProperties?c.associationProperties.approvalStatus: 'Draft' }\n            return c.identifier ?  { identifier: c.identifier } : null\n          }) : []\n          if (temp && temp.length) {\n            this.isTermExist = true\n            return\n          } else {\n              associations.push({ identifier: this.selectedTerm.identifier })\n              this.isTermExist = false\n              // if(createdTermsCounter === (createdTerms.length-1)) {\n                const reguestBody = {\n                  request: {\n                    term: {\n                      ...(associations && associations.length) ? {associations: [...associations]} : null,\n                    }\n                  }\n                }\n                // this.dialogClose({ term: this.selectedTerm, created: true })\n                await this.callUpdateAssociations(counter, parent, reguestBody)\n                \n              // }\n          }\n        }\n        createdTermsCounter++\n        if(createdTermsCounter === createdTerms.length) {\n          this.frameWorkService.updateFrameworkList(this.data.columnInfo.code, parent, createdTerms )\n          this.dialogClose({ term: [this.selectedTerm], created: true, multi:true })\n          this.disableMultiCreate =false;\n          if(createdTerms[0].category === 'theme'){\n            this._snackBar.open(`Competency ${createdTerms[0].category} created successfully.`)\n          }\n          if(createdTerms[0].category === 'subtheme'){\n            this._snackBar.open(`Competency ${createdTerms[0].category} created successfully.`)\n          }\n        }\n      }\n     } else {\n      const parent = parentSelectedTerm\n      associations = parent.children ? parent.children.map((c:any) => {\n        return c.identifier ?  { identifier: c.identifier } : null\n      }) : []\n        associations = [...associations, ...createdTermsIdentifiers]\n        this.isTermExist = false\n        const reguestBody = {\n          request: {\n            term: {\n              ...(associations && associations.length) ? {associations: [...associations]} : null,\n            }\n          }\n        }\n        await this.callUpdateAssociationsV2(counter, parent, reguestBody)\n\n          this.frameWorkService.updateFrameworkList(this.data.columnInfo.code, parent, createdTerms )\n          this.dialogClose({ term: this.selectedTermArray, created: true, multi:true })\n          this.disableMultiCreate =false;\n          if(createdTerms[0].category === 'theme'){\n            this._snackBar.open(`Competency ${createdTerms[0].category} created successfully.`)\n          }\n          if(createdTerms[0].category === 'subtheme'){\n            this._snackBar.open(`Competency ${createdTerms[0].category} created successfully.`)\n          }\n     }\n   }\n }\n\n async callUpdateAssociationsV2(counter:any, parent:any, reguestBody :any): Promise<any>{\n   return new Promise((resolve) => {\n    this.frameWorkService.updateTerm(this.data.frameworkId, parent.category, parent.code, reguestBody).subscribe(async () => {\n      parent['children'] = parent && parent.children ?[...parent.children, ...this.selectedTermArray]:this.selectedTermArray\n        let listData : any = this.frameWorkService.list.get(this.data.columnInfo.code)\n        let differenceData = []\n        if(listData && listData.children && listData.children.length) {\n          differenceData  = _.differenceBy(this.selectedTermArray,listData.children, 'identifier');\n        } else {\n          differenceData = this.selectedTermArray\n        }\n        listData['associations'] = listData && listData.associations ?[...listData.associations, ...differenceData]:differenceData\n        listData['children'] = listData && listData.children ?[...listData.children, ...differenceData]:differenceData\n\n        this.frameWorkService.selectionList.forEach((selectedData: any)=> {\n          let listData : any = this.frameWorkService.list.get(selectedData.category)\n          if(listData && listData.children && listData.children.length) {\n            this.frameWorkService.updateLocalList(listData,parent, this.selectedTermArray, 'create')\n          }\n        }) \n       if (counter === this.frameWorkService.selectionList.size) {\n         // this.selectedTerm['associationProperties']['approvalStatus'] = 'Draft';\n \n         // this value is for selected term in case of create scenario, in case of edit scenario this won't be avaiable \n         // so term is set from childdata which is received from params in updateData\n        //  const value = (this.selectedTerm && this.selectedTerm.identifier) ? this.selectedTerm : {}\n        //  const found = parent.children ? parent.children.find(c=> c.identifier === this.selectedTerm.identifier) : false\n         // if(!found) {\n         //   parent.children ? parent.children.push(this.selectedTerm) : parent['children'] = [this.selectedTerm]\n         // }\n         this.disableUpdate = false\n         // this.frameWorkService.publishFramework().subscribe(res => {\n         //   // this.dialogRef.close(term)\n         //   return resolve(true)\n         // });\n         resolve(true)\n       } else {\n         return resolve(true)\n       }\n     }, (_err: any) => {\n       console.error(`Edit ${this.data.columnInfo.name} failed, please try again later`)\n     })\n   })\n  }\n\n}","<ng-container [ngSwitch]=\"data?.columnInfo?.code || 'defaultCreate'\">\n    <ng-container *ngIf=\"disableMultiCreate\">\n        <div class=\"flex flex-col flex-1 w-100 absolute loader-bg items-center pt-5 text-center\">\n          <mat-spinner class=\"display-inline-block mb-5\" [diameter]=\"50\" [strokeWidth]=\"3\"></mat-spinner>\n          <!-- <p>{{loaderMsg}}</p> -->\n        </div>\n      </ng-container>\n    <ng-container *ngSwitchDefault [ngTemplateOutlet]=\"themeCreate\"></ng-container>\n    <ng-container *ngSwitchCase=\"'theme'\" [ngTemplateOutlet]=\"themeCreate\"></ng-container>\n    <ng-container *ngSwitchCase=\"'subtheme'\" [ngTemplateOutlet]=\"themeCreate\"></ng-container>\n    <ng-container *ngSwitchCase=\"'designation'\" [ngTemplateOutlet]=\"themeDesignation\"></ng-container>\n    <ng-container *ngSwitchCase=\"'competency'\" [ngTemplateOutlet]=\"compTheme\"></ng-container>\n</ng-container>\n\n<ng-template #modalTitle>\n    <!-- <ng-container *ngIf=\"data?.mode === 'create' || data?.mode === 'multi-create'\">\n        <div class=\"dialog-title\" mat-dialog-title>{{data.columnInfo.name === 'Theme' ? app_strings.addCompetency : app_strings.createNew}} {{data.columnInfo.name}}</div>\n    </ng-container> -->\n    <ng-container *ngIf=\"data?.mode === 'create' || data?.mode === 'multi-create'\">\n        <div class=\"dialog-title\" mat-dialog-title>Add {{data?.columnInfo?.config?.categoryDisplayName || data.columnInfo.name }} </div>\n    </ng-container>\n    <ng-container *ngIf=\"data?.mode === 'view'\">\n        <div class=\"dialog-title\" mat-dialog-title></div>\n    </ng-container>\n    <ng-container *ngIf=\"data?.mode === 'edit'\">\n        <div class=\"dialog-title\" mat-dialog-title>{{app_strings.edit}} {{data?.columnInfo?.config?.categoryDisplayName || data.columnInfo.name}}</div>\n    </ng-container>\n</ng-template>\n\n<ng-template #defaultCreate>\n    <div class=\"dialog\">\n        <ng-container [ngTemplateOutlet]=\"modalTitle\"></ng-container>\n        <form [formGroup]=\"createTermForm\" novalidate (ngSubmit)=\"disableCreate?updateTermAssociations():saveTerm()\"\n            class=\"defaultForm\">\n            <mat-form-field appearance=\"outline\">\n                <!-- <mat-label>Enter {{data.name}} name</mat-label> -->\n                <input matInput formControlName=\"name\" placeholder=\"{{app_strings.name}}\" [matAutocomplete]=\"auto\">\n                <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"onSelect($event.option, createTermForm)\">\n                    <mat-option *ngFor=\"let option of filtedTermLists | async\" [value]=\"option\">\n                        {{option.name }}\n                    </mat-option>\n                </mat-autocomplete>\n                <mat-error *ngIf=\"isTermExist\">{{app_strings.alreadyExist}}</mat-error>\n            </mat-form-field>\n            <mat-form-field appearance=\"outline\">\n                <!-- <mat-label>Enter {{data.name}} name</mat-label> -->\n                <textarea matInput formControlName=\"description\" placeholder=\"{{app_strings.description}}\" maxlength=\"2000\"></textarea>\n            </mat-form-field>\n            <footer class=\"actions\">\n                <button mat-raised-button color=\"default\" type=\"reset\"\n                    (click)=\"dialogClose('')\">{{app_strings.cancel}}</button>\n                <button mat-raised-button color=\"primary\" type=\"submit\" cdkFocusInitial\n                    *ngIf=\"!disableCreate || disableMultiCreate\">{{app_strings.create}}</button>\n                <button mat-raised-button color=\"primary\" type=\"submit\" cdkFocusInitial\n                    *ngIf=\"disableCreate\">{{app_strings.update}}</button>\n            </footer>\n        </form>\n    </div>\n</ng-template>\n\n<ng-template #themeCreate >\n    <div class=\"dialogNew\" [ngClass]=\"{'disabled-div': disableMultiCreate}\" >\n        <ng-container [ngTemplateOutlet]=\"modalTitle\"></ng-container>\n        <div class=\"flex gap-4\">\n            <ng-container *ngFor=\"let term of data?.selectedParentTerms\">\n                <div class=\"flex-1 flex-col\">\n                    <label for=\"name\" class=\"margin-remove-bottom form-label\" aria-label=\"First name label\">\n                        {{getCategoryName(term.category,term)}}\n                    </label>\n                    <mat-form-field appearance=\"outline\" class=\"flex-1\">\n                        <input matInput name=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n                            [value]=\"term.name\" disabled>\n                    </mat-form-field>\n                </div>\n            </ng-container>\n        </div>\n        <div class=\"row-divider\"></div>\n        <ng-container *ngIf=\"data?.mode !== 'multi-create'\">\n            <form class=\"themeForm\" [formGroup]=\"createThemeForm\" novalidate\n                (ngSubmit)=\"disableCreate?updateTermAssociations():saveThemeTerm()\">\n                <div class=\"input-column\">\n                    <div class=\"input-wrapper margin-top-s\">\n                        <div class=\"flex gap-4 \" *ngIf=\"data.columnInfo?.code !== 'competencyarea' && data.mode === 'view'\">\n                            <div class=\"flex-1 flex-col\">\n                                <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n                                    aria-label=\"First name label\">\n                                     Name\n                                </label>\n                                \n                                <mat-form-field appearance=\"outline\" class=\"flex-1\">\n                                    <mat-select placeholder=\"{{app_strings?.name}}\" formControlName=\"name\" id=\"name\" #name (selectionChange)=\"change($event,createThemeForm)\">\n                                        <input #search autocomplete=\"off\" placeholder=\"Search\" class=\"assigneeSearch\"\n                                          (keydown.space)=\"$event.stopPropagation()\"  (keyup)=\"onKey($event)\" matInput>\n                                        <mat-option *ngFor=\"let option of filteredMasterList\"    (blur)=\"updateDname(option?.title, createThemeForm)\" [disabled]=\"onDisableTheme(option)\" [value]=\"option\">{{option.title}}</mat-option>\n                                        <mat-option *ngIf=\"filteredMasterList.length === 0\" disabled>\n                                            No results found!\n                                          </mat-option>\n                                        </mat-select>\n\n                                    <!-- <input matInput formControlName=\"name\" id=\"name\" #name\n                                        placeholder=\"{{app_strings.name}}\"\n                                        (blur)=\"updateDname(name.value, createThemeForm)\" maxlength=\"70\"> -->\n                                    <!-- <input matInput formControlName=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n                            [matAutocomplete]=\"auto\">\n                            <mat-autocomplete #auto=\"matAutocomplete\"\n                            (optionSelected)=\"onSelect($event.option, createThemeForm)\">\n                            <mat-option *ngFor=\"let option of filtedTermLists | async\" [value]=\"option\">\n                                {{option.name}}\n                            </mat-option>\n                            </mat-autocomplete> -->\n                                </mat-form-field>\n                                <mat-error *ngIf=\"isTermExist\">{{app_strings.alreadyExist}}</mat-error>\n                            </div>\n                            <div class=\"flex-1 flex-col\">\n                               \n                                <div class=\"flex\">\n\n                                    <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n                                    aria-label=\"First name label\">\n                                    Display Name\n                                </label>\n                                        <mat-icon class=\"info-icon cursor-pointer\" [matTooltip]=\"toolTipText\" \n                                        matTooltipClass=\"tooltip-sec\">info_outline</mat-icon>\n                \n                                </div>\n                              \n                                <mat-form-field appearance=\"outline\" class=\"flex-1\">\n                                    <input matInput formControlName=\"dname\" id=\"dname\" #dname \n                                        placeholder=\"Field automatically generated from the name field.\" maxlength=\"70\" >\n                                    <!-- <input matInput formControlName=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n                            [matAutocomplete]=\"auto\"> -->\n                                    <!-- <mat-autocomplete #auto=\"matAutocomplete\"\n                            (optionSelected)=\"onSelect($event.option, createThemeForm)\">\n                            <mat-option *ngFor=\"let option of filtedTermLists | async\" [value]=\"option\">\n                                {{option.name}}\n                            </mat-option>\n                        </mat-autocomplete> -->\n                                    <!-- <mat-error *ngIf=\"isTermExist\">{{app_strings.alreadyExist}}</mat-error> -->\n                                </mat-form-field>\n                            </div>\n                        </div>\n                        <div class=\"flex gap-4 \" *ngIf=\"data.columnInfo?.code === 'competencyarea' && data.mode === 'view'\">\n                            <div class=\"flex-1 flex-col\">\n                                <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n                                    aria-label=\"First name label\">\n                                     Name\n                                </label>\n                                \n                                <mat-form-field appearance=\"outline\" class=\"flex-1\">\n                                        <input  autocomplete=\"off\" \n                                           matInput [value]=\"data?.childrenData?.name\" disabled>\n                                </mat-form-field>\n                            </div>\n                        </div>\n\n                        <div class=\"flex-col mt-2\">\n                            <label for=\"fname\" class=\"margin-remove-bottom form-label\"\n                                i18n=\"First Name label|Label which explains the user to enter first name\"\n                                i18n-aria-label aria-label=\"First name label\">\n                                Description\n                            </label>\n                            <mat-form-field appearance=\"outline\" class=\"flex-1\">\n                                <!-- <mat-label>Enter {{data.name}} name</mat-label> -->\n                                <textarea matInput [cdkTextareaAutosize] [cdkAutosizeMaxRows]=\"10\"\n                                    [cdkAutosizeMinRows]=\"3\" formControlName=\"description\"\n                                    placeholder=\"{{app_strings.description}}\" maxlength=\"2000\"></textarea>\n                            </mat-form-field>\n                        </div>\n                    </div>\n                </div>\n                <footer class=\"actions\">\n                    <button mat-raised-button color=\"default\" type=\"reset\"\n                        (click)=\"dialogClose('')\">{{app_strings.cancel}}</button>\n                    <ng-container *ngIf=\"data?.mode === 'create'\">\n                        <button mat-raised-button color=\"primary\" type=\"submit\" cdkFocusInitial\n                            [disabled]=\"createThemeForm?.invalid\" *ngIf=\"!disableCreate\">{{app_strings.create}}</button>\n                    </ng-container>\n                    <ng-container *ngIf=\"data?.mode === 'edit'\">\n                        <button mat-raised-button color=\"primary\" type=\"button\" cdkFocusInitial\n                            (click)=\"updateTermData(createThemeForm, data)\" [disabled]=\"createThemeForm?.invalid || disableUpdate\"\n                            *ngIf=\"!disableCreate\">{{app_strings.update}}</button>\n                    </ng-container>\n                </footer>\n            </form>\n        </ng-container>\n        <ng-container *ngIf=\"data?.mode === 'multi-create'\">\n            <form class=\"themeForm\" [formGroup]=\"createThemeFormMulti\" novalidate\n                (ngSubmit)=\"disableCreate?updateTermAssociations():saveThemeTerm()\">\n                <div class=\"flex flex-end mb-4\">\n                    <button type=\"button\" class=\"mat-button flex items-center \" *ngIf=\"data.mode === 'multi-create'\" (click)=\"addThemeFields()\">\n                        <mat-icon class=\"mr-2 mat-icon-custom \">add_circle_outline</mat-icon>\n                        Add more\n                    </button>\n                </div>\n                <mat-accordion formArrayName=\"themeFields\">\n                    <mat-expansion-panel #mep=\"matExpansionPanel\" *ngFor=\"let field of themeFieldsControls; let i = index; let isFirst = first\" \n                    class=\"margin-bottom-l\" [formGroupName]=\"i\" [expanded]=\"isFirst\">\n                        <mat-expansion-panel-header>\n                            <mat-panel-title>\n                                {{getExpansionTitle(field)}} \n                            </mat-panel-title>\n                            <button mat-button type=\"button\" *ngIf=\"data.mode === 'multi-create'\"\n                                    (click)=\"removeThemeFields(i)\">\n                                    <mat-icon class=\"mat-icon-custom \">delete</mat-icon>\n                            </button>\n                        </mat-expansion-panel-header>\n                        <div class=\"input-column\">\n                            <div class=\"input-wrapper margin-top-s\">\n                                <div class=\"flex gap-4 \">\n                                    <div class=\"flex-1 flex-col\">\n                                        <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n                                            aria-label=\"First name label\">\n                                             Name\n                                        </label>\n                                        <mat-form-field appearance=\"outline\" class=\"flex-1\">\n                                            <!-- <input matInput formControlName=\"name\" id=\"name\" #name\n                                                placeholder=\"{{app_strings.name}}\"\n                                                (blur)=\"updateDname(name.value, createThemeFormMulti, i)\" maxlength=\"70\"> -->\n                                            <!-- <input matInput formControlName=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n                                        [matAutocomplete]=\"auto\">\n                                        <mat-autocomplete #auto=\"matAutocomplete\"\n                                        (optionSelected)=\"onSelect($event.option, createThemeForm)\">\n                                        <mat-option *ngFor=\"let option of filtedTermLists | async\" [value]=\"option\">\n                                            {{option.name}}\n                                        </mat-option>\n                                        </mat-autocomplete> -->\n                                        \n                                        <mat-select placeholder=\"{{app_strings?.name}}\" formControlName=\"name\" id=\"name\" #name (selectionChange)=\"change($event,createThemeFormMulti, i )\">\n                                            <input #search autocomplete=\"off\" placeholder=\"Search\" class=\"assigneeSearch\"\n                                              (keydown.space)=\"$event.stopPropagation()\"   (keyup)=\"onKey($event)\" matInput>\n                                            <mat-option *ngFor=\"let option of filteredMasterList\"    (blur)=\"updateDname(option?.title, createThemeFormMulti, i)\" [disabled]=\"onDisableTheme(option)\"  [value]=\"option\">{{option.title}} </mat-option>\n                                            <mat-option *ngIf=\"filteredMasterList.length === 0\" disabled>\n                                                No results found!\n                                              </mat-option>\n                                            \n                                          </mat-select>\n                                          \n                                        </mat-form-field>\n                                        <mat-error *ngIf=\"isTermExist\">{{app_strings?.alreadyExist}}</mat-error>\n                                    </div>\n                                    <div class=\"flex-1 flex-col\">\n                                        <div class=\"flex\">\n                                            <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n                                            aria-label=\"First name label\">\n                                             Display Name\n                                        </label>\n        \n                                        \n                                            <mat-icon class=\"info-icon cursor-pointer\" [matTooltip]=\"toolTipText\" \n                                            matTooltipClass=\"tooltip-sec\">info_outline</mat-icon>\n                                          \n                                                \n                                            \n                                            \n                                            \n                                        </div>\n                                        <mat-form-field appearance=\"outline\" class=\"flex-1\">\n                                            <input matInput formControlName=\"dname\" id=\"dname\" #dname\n                                                placeholder=\"Field automatically generated from the name field.\" maxlength=\"70\" [disabled]=\"name?.value?.length === 0\">\n                                            <!-- <input matInput formControlName=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n                                        [matAutocomplete]=\"auto\"> -->\n                                            <!-- <mat-autocomplete #auto=\"matAutocomplete\"\n                                        (optionSelected)=\"onSelect($event.option, createThemeForm)\">\n                                        <mat-option *ngFor=\"let option of filtedTermLists | async\" [value]=\"option\">\n                                            {{option.name}}\n                                        </mat-option>\n                                    </mat-autocomplete> -->\n                                            <!-- <mat-error *ngIf=\"isTermExist\">{{app_strings.alreadyExist}}</mat-error> -->\n                                        </mat-form-field>\n                                    </div>\n                                </div>\n\n                                <div class=\"flex-col mt-2\">\n                                    <label for=\"fname\" class=\"margin-remove-bottom form-label\"\n                                        i18n=\"First Name label|Label which explains the user to enter first name\"\n                                        i18n-aria-label aria-label=\"First name label\">\n                                        Description\n                                    </label>\n                                    <mat-form-field appearance=\"outline\" class=\"flex-1\">\n                                        <!-- <mat-label>Enter {{data.name}} name</mat-label> -->\n                                        <textarea matInput [cdkTextareaAutosize] [cdkAutosizeMaxRows]=\"10\"\n                                            [cdkAutosizeMinRows]=\"3\" formControlName=\"description\"\n                                            placeholder=\"{{app_strings.description}}\" maxlength=\"2000\"></textarea>\n                                    </mat-form-field>\n                                </div>\n                            </div>\n                        </div>\n                        <div class=\"flex flex-end\">\n                            <button mat-raised-button color=\"primary\" type=\"button\" (click)=\"mep.expanded = false\"\n                            [disabled]=\"createThemeFormMulti?.get('themeFields')['controls'][i].invalid\">\n                                Save\n                            </button>\n                        </div>\n                    </mat-expansion-panel>\n                </mat-accordion>\n                <footer class=\"actions\">\n                    <button mat-raised-button color=\"default\" type=\"reset\"\n                        (click)=\"dialogClose('')\">{{app_strings.cancel}}</button>\n                    <ng-container *ngIf=\"data?.mode === 'create'\">\n                        <button mat-raised-button color=\"primary\" type=\"submit\" cdkFocusInitial\n                            [disabled]=\"createThemeForm?.invalid\" *ngIf=\"!disableCreate\">{{app_strings.add_btn}}</button>\n                    </ng-container>\n                    <ng-container *ngIf=\"data?.mode === 'multi-create'\">\n                        <button mat-raised-button color=\"primary\" type=\"button\" cdkFocusInitial\n                            [disabled]=\"createThemeFormMulti.invalid || disableMultiCreate\" *ngIf=\"!disableCreate\" (click)=\"multiCreate(createThemeFormMulti, data)\">\n                            {{app_strings.add_btn}}\n                        </button>\n                    </ng-container>\n                    <ng-container *ngIf=\"data?.mode === 'edit'\">\n                        <button mat-raised-button color=\"primary\" type=\"button\" cdkFocusInitial\n                            (click)=\"updateTermData(createThemeForm, data)\"\n                            [disabled]=\"createThemeForm?.invalid || disableUpdate\"\n                            *ngIf=\"!disableCreate\">{{app_strings.update}}</button>\n                    </ng-container>\n                </footer>\n            </form>\n        </ng-container>\n    </div>\n</ng-template>\n\n<ng-template #themeDesignation>\n    <div class=\"themDesignation\">\n        <div class=\"dialogNew\">\n            <ng-container [ngTemplateOutlet]=\"modalTitle\"></ng-container>\n            <div class=\"mb-2\">\n                <span class=\"organisation\">Organisation</span>\n                <div class=\"org-name pl-4 flex items-center\">\n                    <!-- <span>Department of Fisheries</span> -->\n                    <span>{{data?.columnInfo?.name}}</span>\n                </div>\n            </div>\n            <div class=\"row-divider\"></div>\n            <div class=\"flex w-full items-center justify-end mt-4\">\n                <a class=\"add-designation flex justify-center items-center\" (click)=\"addDesignation()\">\n                    <mat-icon class=\"add-icon mr-2\">add_circle_outline</mat-icon>\n                    <span>Add Designations</span>\n                </a>\n            </div>\n            <div class=\"mt-5\">\n                <form  [formGroup]=\"createThemeForm\">\n                    <mat-accordion class=\"flex flex-col gap-2\" formArrayName=\"designations\">\n                        <ng-container *ngFor=\"let designation of designationControls; let i = index\">\n                            <mat-expansion-panel [formGroupName]=\"i\"  class=\"designation-panel\" [expanded]=\"panelOpenState[i]\">\n                                <mat-expansion-panel-header>\n                                    <div class=\"flex w-full items-center justify-end\">\n                                        <mat-icon class=\"deletDesignation mr-4\" (click)=\"deleteDesignation(i)\">delete</mat-icon>\n                                    </div>\n                                </mat-expansion-panel-header>\n                                <div class=\"flex flex-col gap-2 \">\n                                    <div class=\"w-full\">\n                                        <label for=\"name\" class=\"margin-remove-bottom form-label required\">\n                                            Designation Name <mat-icon class=\"info-icon\">info</mat-icon>\n                                        </label>\n                                        <mat-form-field appearance=\"outline\" class=\"flex-1\">\n                                            <input matInput formControlName=\"name\" placeholder=\"Type here\" [matAutocomplete]=\"auto\" (change)=\"clearSelectedDesignaionOnChange(i, $event)\">\n                                            <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"onSelect($event.option, designation)\">\n                                                <mat-option *ngFor=\"let option of getFilteredDesignationList(i)\" [value]=\"option\">\n                                                    {{option.name}}\n                                                </mat-option>\n                                            </mat-autocomplete>\n                                            <!-- <mat-error *ngIf=\"isTermExist\">{{app_strings.alreadyExist}}</mat-error> -->\n                                        </mat-form-field>\n                                        <!-- <mat-error>{{app_strings.alreadyExist}}</mat-error> -->\n                                    </div>\n                                    <div class=\"w-full\">\n                                        <label for=\"name\" class=\"margin-remove-bottom form-label required\">\n                                            Description <mat-icon class=\"info-icon\">info</mat-icon>\n                                        </label>\n                                        <mat-form-field appearance=\"outline\" class=\"flex-1\">\n                                            <textarea matInput formControlName=\"designationDescription\"\n                                                placeholder=\"Type the decription in fewer than 600 characters\"></textarea>\n                                        </mat-form-field>\n                                    </div>\n                                \n                                    <div class=\"w-full flex justify-end items-center\">\n                                        <button mat-raised-button class=\"saveDesignaton flex justify-center items-center\"\n                                            (click)=\"saveDesignation(i)\">Save</button>\n                                    </div>\n                                </div>\n                            </mat-expansion-panel>\n                        </ng-container>\n                    </mat-accordion>\n                </form>\n            </div>\n        </div>\n        <div class=\"flex justify-end items-center gap-4 mt-5 designation-footer\">\n            <button mat-raised-button class=\"cancel flex justify-center items-center\"\n                (click)=\"cancel()\">Cancel</button>\n            <button mat-raised-button [disabled]=\"!enableAddBtn\" class=\"addBtn flex justify-center items-center\" (click)=\"submitDesignation()\">Add</button>\n        </div>\n    </div>\n</ng-template>\n<ng-template #compTheme>\n    <div class=\"dialogNew\">\n        <ng-container [ngTemplateOutlet]=\"modalTitle\"></ng-container>\n        <div class=\"flex gap-4\">\n            <ng-container *ngFor=\"let term of data?.selectedParentTerms\">\n                <div class=\"flex-1 flex-col\">\n                    <label for=\"name\" class=\"margin-remove-bottom form-label\" aria-label=\"First name label\">\n                        {{term.category}}\n                    </label>\n                    <mat-form-field appearance=\"outline\" class=\"flex-1\">\n                        <input matInput name=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n                            [value]=\"term.name\" disabled>\n                    </mat-form-field>\n                </div>\n            </ng-container>\n        </div>\n        <div class=\"row-divider\"></div>\n        <form [formGroup]=\"competencyForm\">\n        <div class=\"title-text\">\n            <label for=\"name\" class=\"margin-remove-bottom form-label\" aria-label=\"First name label\">\n                {{'Select Area'}}\n            </label>\n            <div class=\"mt-5\">\n            <mat-radio-group aria-label=\"Select an option\" formControlName=\"compArea\">\n                <mat-radio-button class=\"learning-section\"  *ngFor=\"let item of allCompetency\" [value]=\"item\" (change)=\"onSelectionArea(item)\">{{item.name}}</mat-radio-button>\n            \n              </mat-radio-group>\n            </div>\n        </div>\n       \n        <ng-container *ngIf=\"data?.mode !== 'multi-create'\">\n            <form class=\"themeForm\" [formGroup]=\"createThemeForm\" novalidate\n                (ngSubmit)=\"disableCreate?updateTermAssociations():saveThemeTerm()\">\n                <div class=\"input-column\">\n                    <div class=\"input-wrapper margin-top-s\">\n                        <div class=\"flex gap-4 \">\n                            <div class=\"flex-1 flex-col\">\n                                <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n                                    aria-label=\"First name label\">\n                                    Add Name\n                                </label>\n                                <mat-form-field appearance=\"outline\" class=\"flex-1\">\n                                    <input matInput formControlName=\"name\" id=\"name\" #name\n                                        placeholder=\"{{app_strings.name}}\"\n                                        (blur)=\"updateDname(name.value, createThemeForm)\">\n                                    <!-- <input matInput formControlName=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n                            [matAutocomplete]=\"auto\">\n                            <mat-autocomplete #auto=\"matAutocomplete\"\n                            (optionSelected)=\"onSelect($event.option, createThemeForm)\">\n                            <mat-option *ngFor=\"let option of filtedTermLists | async\" [value]=\"option\">\n                                {{option.name}}\n                            </mat-option>\n                            </mat-autocomplete> -->\n                                </mat-form-field>\n                                <mat-error *ngIf=\"isTermExist\">{{app_strings.alreadyExist}}</mat-error>\n                            </div>\n                            <div class=\"flex-1 flex-col\">\n                                <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n                                    aria-label=\"First name label\">\n                                    Display Name\n                                </label>\n                                <mat-form-field appearance=\"outline\" class=\"flex-1\">\n                                    <input matInput formControlName=\"dname\" id=\"dname\" #dname\n                                        placeholder=\"Competency display name\">\n                                    <!-- <input matInput formControlName=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n                            [matAutocomplete]=\"auto\"> -->\n                                    <!-- <mat-autocomplete #auto=\"matAutocomplete\"\n                            (optionSelected)=\"onSelect($event.option, createThemeForm)\">\n                            <mat-option *ngFor=\"let option of filtedTermLists | async\" [value]=\"option\">\n                                {{option.name}}\n                            </mat-option>\n                        </mat-autocomplete> -->\n                                    <!-- <mat-error *ngIf=\"isTermExist\">{{app_strings.alreadyExist}}</mat-error> -->\n                                </mat-form-field>\n                            </div>\n                        </div>\n\n                        <div class=\"flex-col mt-2\">\n                            <label for=\"fname\" class=\"margin-remove-bottom form-label required\"\n                                i18n=\"First Name label|Label which explains the user to enter first name\"\n                                i18n-aria-label aria-label=\"First name label\">\n                                Description\n                            </label>\n                            <mat-form-field appearance=\"outline\" class=\"flex-1\">\n                                <!-- <mat-label>Enter {{data.name}} name</mat-label> -->\n                                <textarea matInput [cdkTextareaAutosize] [cdkAutosizeMaxRows]=\"10\"\n                                    [cdkAutosizeMinRows]=\"3\" formControlName=\"description\"\n                                    placeholder=\"{{app_strings.description}}\"></textarea>\n                            </mat-form-field>\n                        </div>\n                    </div>\n                </div>\n                <footer class=\"actions\">\n                    <button mat-raised-button color=\"default\" type=\"reset\"\n                        (click)=\"dialogClose('')\">{{app_strings.cancel}}</button>\n                    <ng-container *ngIf=\"data?.mode === 'create'\">\n                        <button mat-raised-button color=\"primary\" type=\"submit\" cdkFocusInitial\n                            [disabled]=\"createThemeForm?.invalid\" *ngIf=\"!disableCreate\">{{app_strings.create}}</button>\n                    </ng-container>\n                    <ng-container *ngIf=\"data?.mode === 'edit'\">\n                        <button mat-raised-button color=\"primary\" type=\"button\" cdkFocusInitial\n                            (click)=\"updateTermData(createThemeForm, data)\" [disabled]=\"createThemeForm?.invalid\"\n                            *ngIf=\"!disableCreate\">{{app_strings.update}}</button>\n                    </ng-container>\n                </footer>\n            </form>\n        </ng-container>\n        <ng-container *ngIf=\"data?.mode === 'multi-create'\">\n           \n                <div class=\"flex flex-end mb-4\">\n                    <button type=\"button\" class=\"mat-button flex items-center \" *ngIf=\"data.mode === 'multi-create'\" (click)=\"addCompetencyTheme()\">\n                        <mat-icon class=\"mr-2 mat-icon-custom \">add_circle_outline</mat-icon>\n                        Add {{data.columnInfo.name}}\n                    </button>\n                </div>\n                <mat-accordion formArrayName=\"compThemeFields\">\n                    <mat-expansion-panel *ngFor=\"let field of competencyForm?.get('compThemeFields')['controls']; let i = index; let isFirst = first\" \n                    class=\"margin-bottom-l\" [formGroupName]=\"i\" [expanded]=\"isFirst\">\n                        <mat-expansion-panel-header>\n                            <mat-panel-title>\n                                <!-- {{name?.value}}  -->\n                            </mat-panel-title>\n                            <button mat-button type=\"button\" *ngIf=\"data.mode === 'multi-create'\"\n                                    (click)=\"removeCompFields(i)\">\n                                    <mat-icon class=\"mat-icon-custom \">delete</mat-icon>\n                            </button>\n                        </mat-expansion-panel-header>\n                        <div class=\"input-column\">\n                            <div class=\"input-wrapper margin-top-s\">\n                                <div class=\"flex gap-4 \">\n                                    <div class=\"flex-1 flex-col\">\n                                        <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n                                            aria-label=\"First name label\">\n                                            Select Competency Theme\n                                        </label>\n                                        <mat-form-field appearance=\"outline\" class=\"flex-1\">\n                                            <mat-select placeholder=\"Choose the Competency Theme\" formControlName=\"competencyTheme\">\n                                                <!-- <input #search autocomplete=\"off\" placeholder=\"Search\" class=\"assigneeSearch\"\n                                                  (keydown.space)=\"$event.stopPropagation()\"  formControlName=\"assigneeText\" matInput> -->\n                                                <mat-option *ngFor=\"let option of filteredallCompetencyTheme\" [value]=\"option\" (onSelectionChange)=\"OnThemeSelection($event)\"  >{{option.name}}</mat-option>\n                                            </mat-select>\n                                            <!-- <input matInput formControlName=\"name\" id=\"name\" #name placeholder=\"{{app_strings.name}}\"\n                                        [matAutocomplete]=\"auto\">\n                                        <mat-autocomplete #auto=\"matAutocomplete\"\n                                        (optionSelected)=\"onSelect($event.option, createThemeForm)\">\n                                        <mat-option *ngFor=\"let option of filtedTermLists | async\" [value]=\"option\">\n                                            {{option.name}}\n                                        </mat-option>\n                                        </mat-autocomplete> -->\n                                        </mat-form-field>\n                                        <mat-error *ngIf=\"isTermExist\">{{app_strings.alreadyExist}}</mat-error>\n                                    </div>\n                                    <!-- <div class=\"flex-1 flex-col\">\n                                        <label for=\"name\" class=\"margin-remove-bottom form-label required\"\n                                            aria-label=\"First name label\">\n                                            Display Name\n                                        </label>\n                                        <mat-form-field appearance=\"outline\" class=\"flex-1\">\n                                            <input matInput formControlName=\"dname\" id=\"dname\" #dname\n                                                placeholder=\"Competency display name\">\n                                        </mat-form-field>\n                                    </div> -->\n                                </div>\n\n                                <div class=\"flex-col mt-2\">\n                                    <label for=\"fname\" class=\"margin-remove-bottom form-label required\"\n                                        i18n=\"First Name label|Label which explains the user to enter first name\"\n                                        i18n-aria-label aria-label=\"First name label\">\n                                        Select Competency Sub-Theme\n                                    </label>\n                                    <mat-form-field appearance=\"outline\" class=\"flex-1\">\n                                        <!-- <mat-label>Enter {{data.name}} name</mat-label> -->\n                                        <mat-select placeholder=\"Choose the Competency Theme\" formControlName=\"competencySubTheme\">\n                                            <!-- <input #search autocomplete=\"off\" placeholder=\"Search\" class=\"assigneeSearch\"\n                                              (keydown.space)=\"$event.stopPropagation()\"  formControlName=\"assigneeText\" matInput> -->\n                                            <mat-option *ngFor=\"let option of filteredallCompetencySubTheme\" [value]=\"option\">{{option.name}}</mat-option>\n                                        </mat-select>\n                                    </mat-form-field>\n                                </div>\n                            </div>\n                        </div>\n                    </mat-expansion-panel>\n                </mat-accordion>\n                <footer class=\"actions\">\n                    <button mat-raised-button color=\"default\" type=\"reset\"\n                        (click)=\"dialogClose('')\">{{app_strings.cancel}}</button>\n                    <ng-container *ngIf=\"data?.mode === 'create'\">\n                        <button mat-raised-button color=\"primary\" type=\"submit\" cdkFocusInitial\n                            [disabled]=\"createThemeForm?.invalid\" *ngIf=\"!disableCreate\">{{app_strings.create}}</button>\n                    </ng-container>\n                    <ng-container *ngIf=\"data?.mode === 'multi-create'\">\n                        <button mat-raised-button color=\"primary\" type=\"button\" cdkFocusInitial\n                            [disabled]=\"createThemeFormMulti.invalid\" *ngIf=\"!disableCreate\" (click)=\"multiCreate(createThemeFormMulti, data)\">\n                            {{app_strings.create}}\n                        </button>\n                    </ng-container>\n                    <ng-container *ngIf=\"data?.mode === 'edit'\">\n                        <button mat-raised-button color=\"primary\" type=\"button\" cdkFocusInitial\n                            (click)=\"updateTermData(createThemeForm, data)\"\n                            [disabled]=\"createThemeForm?.invalid || disableUpdate\"\n                            *ngIf=\"!disableCreate\">{{app_strings.update}}</button>\n                    </ng-container>\n                </footer>\n            </ng-container>\n        </form>\n        \n    </div>\n</ng-template>"]}