gamma-app-controller 2.0.25 → 4.0.0

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 (56) hide show
  1. package/esm2020/lib/application-controller/application-content.service.mjs +36 -36
  2. package/esm2020/lib/application-controller/application-controller.module.mjs +6 -1
  3. package/esm2020/lib/application-controller/application-dataset-component/create-dataset/create-dataset.component.mjs +2 -2
  4. package/esm2020/lib/application-controller/application-menu-controller/application-create-menu/application-create-menu.component.mjs +10 -27
  5. package/esm2020/lib/application-controller/application-view-components/create-comp-view/create-comp-view.component.mjs +6 -3
  6. package/esm2020/lib/application-controller/page-controller/page-config/page-config.component.mjs +3 -3
  7. package/esm2020/lib/application-controller/support-components/dash-chart/dash-chart.component.mjs +32 -167
  8. package/esm2020/lib/application-controller/support-components/dash-table/dash-table.component.mjs +4 -3
  9. package/esm2020/lib/application-controller/support-components/geo-map/geo-map.component.mjs +12 -228
  10. package/esm2020/lib/application-controller/support-components/single-card/single-card.component.mjs +24 -34
  11. package/esm2020/lib/shared/advanced-component/gamm-single-number-card/gamm-single-number-card.component.mjs +3 -4
  12. package/esm2020/lib/shared/advanced-component/gamma-advance-chart/gamma-advance-chart.component.mjs +39 -109
  13. package/esm2020/lib/shared/advanced-component/gamma-advance-operator-table/gamma-advance-operator-table.component.mjs +15 -2
  14. package/esm2020/lib/shared/advanced-component/gamma-geo-chart/gamma-geo-chart.component.mjs +7 -272
  15. package/esm2020/lib/shared/advanced-component/gamma-heatmap/gamma-heatmap.component.mjs +3 -3
  16. package/esm2020/lib/shared/advanced-component/google-geo-map/google-geo-map.component.mjs +439 -0
  17. package/esm2020/lib/shared/gamma-bread-crumbs/bread-crumbs.component.mjs +57 -51
  18. package/esm2020/lib/shared/permission-helper.mjs +4 -35
  19. package/esm2020/lib/shared/template-dataset-call-service.mjs +5 -1
  20. package/esm2020/lib/shared/user-access/user-access.component.mjs +5 -5
  21. package/esm2020/lib/template-module/KpiCreationModule/create-kpi-tree.component.mjs +275 -153
  22. package/esm2020/lib/template-module/KpiCreationModule/createKpi.service.mjs +6 -37
  23. package/esm2020/lib/template-module/KpiCreationModule/treeview/components/basic/basic.component.mjs +3 -3
  24. package/esm2020/lib/template-module/KpiCreationModule/treeview/components/collapsable/collapsable.component.mjs +15 -4
  25. package/esm2020/lib/template-module/KpiCreationModule/treeview/treeview.component.mjs +6 -4
  26. package/esm2020/lib/template-module/bookmarked-template/bookmarked-layout.service.mjs +8 -8
  27. package/esm2020/lib/template-module/cdrConfigModule/cdr-browser.service.mjs +2 -2
  28. package/esm2020/lib/template-module/defaulLandingComponent/landing-component.component.mjs +2 -1
  29. package/esm2020/lib/template-module/defaulLandingComponent/landing-component.service.mjs +8 -8
  30. package/esm2020/lib/template-module/defaulLandingMultiLayoutComponent/defaulLandingMultiLayout.service.mjs +8 -8
  31. package/esm2020/lib/template-module/kpiWithMultiLayout/kpi-multi-layout.service.mjs +8 -8
  32. package/esm2020/lib/template-module/kpiWithSingleLayout/kpi-single-layout.service.mjs +8 -16
  33. package/esm2020/lib/template-module/kpiWithSingleLayout/kpi-with-dataset.component.mjs +6 -10
  34. package/esm2020/public-api.mjs +3 -1
  35. package/fesm2015/gamma-app-controller.mjs +8672 -8850
  36. package/fesm2015/gamma-app-controller.mjs.map +1 -1
  37. package/fesm2020/gamma-app-controller.mjs +8427 -8617
  38. package/fesm2020/gamma-app-controller.mjs.map +1 -1
  39. package/lib/application-controller/application-content.service.d.ts +1 -1
  40. package/lib/application-controller/application-controller.module.d.ts +26 -25
  41. package/lib/application-controller/application-menu-controller/application-create-menu/application-create-menu.component.d.ts +0 -2
  42. package/lib/application-controller/support-components/dash-chart/dash-chart.component.d.ts +3 -18
  43. package/lib/application-controller/support-components/geo-map/geo-map.component.d.ts +2 -46
  44. package/lib/application-controller/support-components/single-card/single-card.component.d.ts +2 -5
  45. package/lib/shared/advanced-component/gamm-single-number-card/gamm-single-number-card.component.d.ts +0 -1
  46. package/lib/shared/advanced-component/gamma-advance-chart/gamma-advance-chart.component.d.ts +1 -3
  47. package/lib/shared/advanced-component/gamma-advance-operator-table/gamma-advance-operator-table.component.d.ts +1 -0
  48. package/lib/shared/advanced-component/gamma-geo-chart/gamma-geo-chart.component.d.ts +0 -40
  49. package/lib/shared/advanced-component/google-geo-map/google-geo-map.component.d.ts +62 -0
  50. package/lib/shared/gamma-bread-crumbs/bread-crumbs.component.d.ts +0 -2
  51. package/lib/shared/permission-helper.d.ts +0 -1
  52. package/lib/template-module/KpiCreationModule/create-kpi-tree.component.d.ts +15 -11
  53. package/lib/template-module/KpiCreationModule/createKpi.service.d.ts +0 -4
  54. package/lib/template-module/kpiWithSingleLayout/kpi-single-layout.service.d.ts +0 -1
  55. package/package.json +1 -1
  56. package/public-api.d.ts +2 -0
@@ -11,10 +11,9 @@ import * as i8 from "devextreme-angular/ui/nested";
11
11
  import * as i9 from "devextreme-angular/ui/check-box";
12
12
  import * as i10 from "devextreme-angular/ui/html-editor";
13
13
  import * as i11 from "devextreme-angular/ui/select-box";
14
- import * as i12 from "devextreme-angular/ui/tag-box";
15
- import * as i13 from "devextreme-angular/ui/text-box";
16
- import * as i14 from "../../shared/user-access/user-access.component";
17
- import * as i15 from "./treeview/treeview.component";
14
+ import * as i12 from "devextreme-angular/ui/text-box";
15
+ import * as i13 from "../../shared/user-access/user-access.component";
16
+ import * as i14 from "./treeview/treeview.component";
18
17
  export class CreateKpiTreeComponent {
19
18
  constructor(commonService, formBuilder, service, toastr, router) {
20
19
  this.commonService = commonService;
@@ -38,9 +37,6 @@ export class CreateKpiTreeComponent {
38
37
  this.kpi_external = false;
39
38
  this.isComponentUpdata = false;
40
39
  this.userOptionContainer = [];
41
- this.selected_aliases = [];
42
- this.isKpiTreePrepared = false;
43
- this.kpiConfigDataSource = [];
44
40
  }
45
41
  ngOnInit() {
46
42
  this.getAllKpiData();
@@ -56,12 +52,10 @@ export class CreateKpiTreeComponent {
56
52
  });
57
53
  }
58
54
  getAllKpiData() {
55
+ this.loadingModal = false;
59
56
  this.keiParentDataSource = [];
60
- this.service.listKpiEntryConfigs().subscribe((data) => {
61
- const userName = "admin";
62
- this.kpiConfigDataSource = data;
63
- this.kpiData = this.buildMenuTree(userName, data);
64
- this.loadingModal = false;
57
+ this.service.getlistKpiBrowser().subscribe((data) => {
58
+ this.kpiData = data;
65
59
  this.prepareParentDataSource(data);
66
60
  }, err => {
67
61
  this.loadingModal = false;
@@ -70,97 +64,104 @@ export class CreateKpiTreeComponent {
70
64
  }
71
65
  prepareParentDataSource(data) {
72
66
  data.forEach((result) => {
73
- if (result.tagType == 'parent') {
74
- this.keiParentDataSource.push(result);
67
+ if (result.tag_type == 'parent') {
68
+ let node = {
69
+ "name": result.name,
70
+ "tid": result.tid
71
+ };
72
+ this.keiParentDataSource.push(node);
73
+ this.prepareParentDataSource(result.nodes);
75
74
  }
76
75
  });
77
76
  }
78
- makeNewKpiWithUserEntity() {
79
- const pageData = (this.selected_page_id) ? this.templateDataSource.find((item) => item.pageId === this.selected_page_id) : null;
80
- let kpiObj = {
81
- "kpiId": this.selected_id,
82
- "kpiName": this.select_kpi_name,
83
- "aliases": this.selected_aliases,
84
- "pageId": this.selected_page_id,
85
- "description": this.selected_desc,
86
- "kpiInfo": "",
87
- "tagType": this.select_tag_type,
88
- "active": true,
89
- "visibility": this.kpi_visibility,
90
- "externalKpi": this.kpi_external,
91
- "target": "",
92
- "icon": "",
93
- "url": pageData ? pageData.pageUrl : "",
94
- "kpiType": this.select_tag_type == "parent" ? "collapsable" : "basic",
95
- "parentTid": this.selected_kpi_tid,
96
- "childTid": this.selected_kpi_child_tid,
97
- "permissions": this.userOptionContainer,
98
- };
99
- this.service.createKpiEntryConfig(kpiObj).subscribe(data => {
100
- this.toastr.success('KPI Created Successfully');
101
- this.getAllKpiData();
102
- this.getReseteKpi();
103
- }, err => {
104
- this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'KPI Config');
105
- });
106
- console.log("KPI with User Entity Obj:", kpiObj);
107
- }
108
- getEditableKpi(kpi) {
109
- const data = this.kpiConfigDataSource.find((item) => item.kpiId === kpi.id);
110
- const tidKey = data.tagType === 'child' && data.childTid && data.childTid.length > 3 ? 'childTid' : 'parentTid';
111
- const parentName = this.keiParentDataSource.find((item) => item[tidKey] == data["parentTid"]);
112
- this.parante_kpi_name = parentName ? parentName['kpiId'] : null;
113
- this.selected_id = data["kpiId"];
114
- this.select_kpi_name = data["kpiName"];
115
- this.selected_aliases = data["aliases"];
116
- this.selected_page_id = data["pageId"];
117
- this.selected_desc = data["description"];
118
- this.select_tag_type = data["tagType"];
119
- this.kpi_visibility = data["visibility"];
120
- this.kpi_external = data["externalKpi"];
121
- this.selected_kpi_tid = data["parentTid"];
122
- this.selected_kpi_child_tid = data["childTid"];
123
- this.userOptionContainer = (data["permissions"] && data["permissions"].length > 0) ? data["permissions"] : [];
124
- this.isEditKpiAdded = true;
77
+ makeNewKpi() {
78
+ if (this.selected_kpi_tid !== undefined && this.selected_kpi_tid.length > 0) {
79
+ this.getHeistId(this.kpiData, this.selected_kpi_tid);
80
+ this.createNewKpiWithTid();
81
+ }
82
+ else {
83
+ this.heistValue = (this.kpiData.length != 0) ? this.getHighestTid(this.kpiData) : 0;
84
+ let value = parseInt(this.heistValue) + 1;
85
+ let obj = {
86
+ "name": this.select_kpi_name,
87
+ "tid": value.toString(),
88
+ "isBookmarked": false,
89
+ "isAccessible": this.kpi_external,
90
+ "lastAccessTime": "",
91
+ "tag_type": this.select_tag_type,
92
+ "id": this.selected_id,
93
+ "pageId": this.selected_page_id,
94
+ "desc": this.selected_desc,
95
+ "isVisible": this.kpi_visibility,
96
+ "nodes": [],
97
+ "config": {}
98
+ };
99
+ this.kpiData.push(obj);
100
+ if (this.select_tag_type == 'parent') {
101
+ let obj = {
102
+ "name": this.select_kpi_name,
103
+ "tid": value.toString(),
104
+ };
105
+ this.keiParentDataSource.push(obj);
106
+ }
107
+ if (this.select_tag_type == 'child') {
108
+ let obj = {
109
+ "name": this.select_kpi_name,
110
+ "id": this.selected_id,
111
+ "pageId": this.selected_page_id,
112
+ "searchFilter": false,
113
+ "isSrvTypeOperator": false,
114
+ "operationLevels": [],
115
+ "fixOperationLevles": [],
116
+ "api_config": []
117
+ };
118
+ this.service.configureKpiBrowserConfig(obj).subscribe(data => {
119
+ console.log("kpi browser config created");
120
+ });
121
+ }
122
+ this.submitNewKpi();
123
+ }
125
124
  }
126
- getUpdateKpi() {
127
- const pageData = (this.selected_page_id) ? this.templateDataSource.find((item) => item.pageId === this.selected_page_id) : null;
128
- let kpiObj = {
129
- "kpiId": this.selected_id,
130
- "kpiName": this.select_kpi_name,
131
- "aliases": this.selected_aliases,
125
+ createNewKpiWithTid() {
126
+ let auto_tid = this.autoIncrement(this.selected_kpi_tid, this.heistValue);
127
+ let obj = {
128
+ "name": this.select_kpi_name,
129
+ "tid": auto_tid,
130
+ "isBookmarked": false,
131
+ "isAccessible": this.kpi_external,
132
+ "lastAccessTime": "",
133
+ "tag_type": this.select_tag_type,
134
+ "id": this.selected_id,
132
135
  "pageId": this.selected_page_id,
133
- "description": this.selected_desc,
134
- "kpiInfo": "",
135
- "tagType": this.select_tag_type,
136
- "active": true,
137
- "visibility": this.kpi_visibility,
138
- "externalKpi": this.kpi_external,
139
- "target": "",
140
- "icon": "",
141
- "url": pageData ? pageData.pageUrl : "",
142
- "kpiType": this.select_tag_type == "parent" ? "collapsable" : "basic",
143
- "parentTid": this.selected_kpi_tid,
144
- "childTid": this.selected_kpi_child_tid,
145
- "permissions": this.userOptionContainer,
136
+ "desc": this.selected_desc,
137
+ "isVisible": this.kpi_visibility,
138
+ "nodes": [],
139
+ "config": {}
146
140
  };
147
- this.service.updateKpiEntryConfig(kpiObj).subscribe(data => {
148
- this.toastr.success('KPI Updated Successfully');
149
- this.getAllKpiData();
150
- this.getReseteKpi();
151
- this.isEditKpiAdded = false;
152
- }, err => {
153
- this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'KPI Config');
154
- });
155
- console.log("KPI with User Entity Obj:", kpiObj);
156
- }
157
- onCustomDimentionCreating(args) {
158
- const newValue = args.text;
159
- args.customItem = newValue;
160
- const isItemInDataSource = this.selected_aliases.some((item) => item === newValue);
161
- if (!isItemInDataSource) {
162
- this.selected_aliases.unshift(newValue);
141
+ if (this.select_tag_type == 'parent') {
142
+ let obj = {
143
+ "name": this.select_kpi_name,
144
+ "tid": auto_tid
145
+ };
146
+ this.keiParentDataSource.push(obj);
163
147
  }
148
+ if (this.select_tag_type == 'child') {
149
+ let obj = {
150
+ "name": this.select_kpi_name,
151
+ "id": this.selected_id,
152
+ "pageId": this.selected_page_id,
153
+ "searchFilter": false,
154
+ "isSrvTypeOperator": false,
155
+ "operationLevels": [],
156
+ "fixOperationLevles": [],
157
+ "api_config": []
158
+ };
159
+ this.service.configureKpiBrowserConfig(obj).subscribe(data => {
160
+ console.log("kpi browser config created");
161
+ });
162
+ }
163
+ this.setKpibyTid(this.kpiData, this.selected_kpi_tid, obj);
164
+ this.submitNewKpi();
164
165
  }
165
166
  getReseteKpi() {
166
167
  this.select_kpi_name = '';
@@ -178,38 +179,73 @@ export class CreateKpiTreeComponent {
178
179
  this.editable_desc = '';
179
180
  this.editable_info = '';
180
181
  this.parante_kpi_name = '';
181
- this.selected_kpi_child_tid = '';
182
- this.selected_aliases = [];
183
182
  this.kpi_external = false;
184
183
  this.kpi_visibility = false;
185
184
  this.isComponentUpdata = false;
186
- this.isEditKpiAdded = false;
185
+ }
186
+ getDeletKpi(tid) {
187
+ console.log(this.selected_p_kpi);
187
188
  }
188
189
  addTagtypeValue(e) {
189
190
  this.select_tag_type = e.value;
190
191
  }
191
192
  getKpiItemValue(e) {
192
- if (e.event) {
193
- const kpi_data = this.keiParentDataSource.find((item) => item.kpiId === e.value);
194
- if (this.isEditKpiAdded) {
195
- const tidKey = this.select_tag_type === 'child' && this.isEditKpiAdded ? 'childTid' : 'parentTid';
196
- this.selected_kpi_tid = kpi_data[tidKey];
193
+ const kpi_data = this.keiParentDataSource.find((item) => item.tid === e.value);
194
+ this.selected_kpi_tid = kpi_data.tid;
195
+ }
196
+ autoIncrement(string1, string2) {
197
+ if (string2 === null) {
198
+ const numberPart = string1 + '.1';
199
+ return numberPart;
200
+ }
201
+ else {
202
+ const parts = string2.split('.');
203
+ let lastPart = parseInt(parts[parts.length - 1], 10);
204
+ let new_number = lastPart++;
205
+ parts[parts.length - 1] = lastPart.toString();
206
+ return parts.join(".");
207
+ }
208
+ }
209
+ setKpibyTid(data, tid, newKpiObj) {
210
+ data.forEach(result => {
211
+ if (result.nodes !== undefined) {
212
+ if (result.tid == tid) {
213
+ result.nodes.push(newKpiObj);
214
+ }
215
+ this.setKpibyTid(result.nodes, tid, newKpiObj);
216
+ }
217
+ });
218
+ }
219
+ getHeistId(data, tid) {
220
+ data.forEach((result) => {
221
+ if (result.tid === tid) {
222
+ if (result.nodes.length > 0) {
223
+ this.heistValue = this.getHighestTid(result.nodes);
224
+ }
225
+ else {
226
+ this.heistValue = null;
227
+ }
197
228
  }
198
- else {
199
- const tidKey = kpi_data.childTid && kpi_data.childTid.length > 1 ? 'childTid' : 'parentTid';
200
- this.selected_kpi_tid = kpi_data[tidKey];
201
- this.selected_kpi_child_tid = this.getNextChildTid(this.selected_kpi_tid, this.kpiConfigDataSource);
229
+ else if (result.nodes !== undefined && result.nodes.length > 0) {
230
+ this.getHeistId(result.nodes, tid);
202
231
  }
203
- }
232
+ });
204
233
  }
205
- getNextChildTid(parentTid, kpiConfigDataSource) {
206
- const children = kpiConfigDataSource.filter(item => item.parentTid === parentTid && item.childTid);
207
- const maxChildNumber = children.reduce((max, item) => {
208
- const parts = item.childTid.split('.');
209
- const lastNumber = Number(parts[parts.length - 1]);
210
- return lastNumber > max ? lastNumber : max;
211
- }, 0);
212
- return `${parentTid}.${maxChildNumber + 1}`;
234
+ getHighestTid(data) {
235
+ const highestTid = data.reduce((maxTid, currentItem) => {
236
+ const currentTidParts = currentItem.tid.split('.').map(part => parseInt(part, 10));
237
+ const maxTidParts = maxTid.split('.').map(part => parseInt(part, 10));
238
+ for (let i = 0; i < currentTidParts.length; i++) {
239
+ if (currentTidParts[i] > maxTidParts[i]) {
240
+ return currentItem.tid;
241
+ }
242
+ else if (currentTidParts[i] < maxTidParts[i]) {
243
+ return maxTid;
244
+ }
245
+ }
246
+ return maxTid;
247
+ }, data[0].tid);
248
+ return highestTid;
213
249
  }
214
250
  addNewKpi() {
215
251
  this.isNewKpiAdded = true;
@@ -218,6 +254,22 @@ export class CreateKpiTreeComponent {
218
254
  cancelUpdate() {
219
255
  this.isEditKpiAdded = false;
220
256
  }
257
+ getEditableKpi(data) {
258
+ this.isComponentUpdata = false;
259
+ this.isEditKpiAdded = true;
260
+ this.isNewKpiAdded = false;
261
+ this.isFromEditable = true;
262
+ this.editable_desc = data.desc;
263
+ this.editable_info = (data.kpiInfo) ? data.kpiInfo : "";
264
+ this.editable_kpi_name = data.name;
265
+ this.editable_tag_type = data.tag_type;
266
+ this.editable_kpi_tid = data.tid;
267
+ this.editable_id = data.id;
268
+ this.editable_page_id = data.pageId;
269
+ this.kpi_visibility = data.isVisible;
270
+ this.kpi_external = data.isAccessible;
271
+ this.parante_kpi_name = this.getKpiParrentName(data.tid);
272
+ }
221
273
  getKpiParrentName(input) {
222
274
  const lastIndex = input.lastIndexOf('.');
223
275
  if (lastIndex === -1) {
@@ -225,15 +277,55 @@ export class CreateKpiTreeComponent {
225
277
  }
226
278
  return input.substring(0, lastIndex);
227
279
  }
228
- getDeletKpi() {
229
- this.service.deleteKpiEntryConfig(this.selected_id).subscribe(data => {
280
+ getUpdateKpi() {
281
+ if (!this.isComponentUpdata) {
282
+ this.getUpdateKpiName(this.kpiData, this.editable_kpi_tid);
283
+ }
284
+ setTimeout(() => {
285
+ this.submitNewKpi();
286
+ this.toastr.success('KPI Updated Successfully');
287
+ this.reseteUpdateKpiForm();
288
+ this.isEditKpiAdded = false;
289
+ }, 500);
290
+ }
291
+ getDeleteKpi() {
292
+ this.getDeleteKpiName(this.kpiData, this.editable_kpi_tid);
293
+ setTimeout(() => {
294
+ this.submitNewKpi();
230
295
  this.toastr.success('KPI Deleted Successfully');
231
- this.getAllKpiData();
232
- this.getReseteKpi();
233
- }, err => {
234
- this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'KPI Config');
296
+ this.reseteUpdateKpiForm();
297
+ this.isEditKpiAdded = false;
298
+ }, 500);
299
+ }
300
+ getUpdateKpiName(data, tid) {
301
+ data.forEach((result) => {
302
+ if (result.tid === tid) {
303
+ result.desc = this.editable_desc;
304
+ result.kpiInfo = this.editable_info;
305
+ result.name = this.editable_kpi_name;
306
+ result.id = this.editable_id;
307
+ result.pageId = this.editable_page_id;
308
+ result.tag_type = this.editable_tag_type;
309
+ result.isVisible = this.kpi_visibility;
310
+ result.isAccessible = this.kpi_external;
311
+ result.tid = this.editable_kpi_tid;
312
+ }
313
+ else if (result.nodes !== undefined && result.nodes.length > 0) {
314
+ this.getUpdateKpiName(result.nodes, tid);
315
+ }
235
316
  });
236
317
  }
318
+ getDeleteKpiName(data, tid) {
319
+ for (let i = data.length - 1; i >= 0; i--) {
320
+ const result = data[i];
321
+ if (result.tid === tid) {
322
+ data.splice(i, 1);
323
+ }
324
+ else if (result.nodes !== undefined && result.nodes.length > 0) {
325
+ this.getDeleteKpiName(result.nodes, tid);
326
+ }
327
+ }
328
+ }
237
329
  reseteUpdateKpiForm() {
238
330
  this.editable_desc = undefined;
239
331
  this.editable_info = undefined;
@@ -254,40 +346,70 @@ export class CreateKpiTreeComponent {
254
346
  this.getReseteKpi();
255
347
  });
256
348
  }
257
- buildMenuTree(userName, kpiData) {
258
- let filteredMenus = kpiData;
259
- const menuMap = new Map();
260
- const menuTree = [];
261
- filteredMenus.forEach(menu => {
262
- menuMap.set(menu.childTid || menu.parentTid, {
263
- id: menu.kpiId,
264
- title: menu.kpiName,
265
- icon: menu.icon,
266
- type: menu.kpiType,
267
- tagType: menu.tagType,
268
- visibility: true,
269
- ...(menu.link && { link: menu.link.replace(/^\/+/, '') }),
270
- children: []
271
- });
272
- });
273
- filteredMenus.forEach(kpi => {
274
- if (kpi.parentTid && kpi.childTid) {
275
- const parent = menuMap.get(kpi.parentTid);
276
- if (parent) {
277
- parent.children.push(menuMap.get(kpi.childTid));
278
- }
279
- }
280
- else {
281
- menuTree.push(menuMap.get(kpi.parentTid));
282
- }
349
+ getNewParrentKpiItemValue(e) {
350
+ this.isComponentUpdata = true;
351
+ const kpi_data = this.keiParentDataSource.find((item) => item.tid === e.value);
352
+ this.getHeistId(this.kpiData, kpi_data.tid);
353
+ let auto_tid = this.autoIncrement(kpi_data.tid, this.heistValue);
354
+ let obj = {
355
+ "name": this.editable_kpi_name,
356
+ "tid": auto_tid,
357
+ "isBookmarked": false,
358
+ "isAccessible": this.kpi_external,
359
+ "lastAccessTime": "",
360
+ "tag_type": this.editable_tag_type,
361
+ "id": this.editable_id,
362
+ "pageId": this.editable_page_id,
363
+ "desc": this.editable_desc,
364
+ "kpiInfo": this.editable_info,
365
+ "isVisible": this.kpi_visibility,
366
+ "nodes": [],
367
+ "config": {}
368
+ };
369
+ this.getDeleteKpiName(this.kpiData, this.editable_kpi_tid);
370
+ this.setKpibyTid(this.kpiData, kpi_data.tid, obj);
371
+ this.editable_kpi_tid = kpi_data.tid;
372
+ }
373
+ makeNewKpiWithUserEntity() {
374
+ this.userOptionContainer.forEach(element => {
375
+ let att_value = element.attributeValues.split(",");
376
+ element.attributeValues = att_value;
283
377
  });
284
- return menuTree;
378
+ if (this.selected_kpi_tid !== undefined && this.selected_kpi_tid.length > 0) {
379
+ this.getHeistId(this.kpiData, this.selected_kpi_tid);
380
+ }
381
+ else {
382
+ this.heistValue = (this.kpiData.length != 0) ? this.getHighestTid(this.kpiData) : 0;
383
+ let value = parseInt(this.heistValue) + 1;
384
+ }
385
+ let kpiObj = {
386
+ "kpiId": this.selected_id,
387
+ "pageId": this.selected_page_id,
388
+ "title": this.select_kpi_name,
389
+ "description": this.selected_desc,
390
+ "kpiInfo": this.selected_info,
391
+ "tagType": this.select_tag_type,
392
+ "active": true,
393
+ "visibility": this.kpi_visibility,
394
+ "externalKpi": this.kpi_external,
395
+ "target": "",
396
+ "icon": "",
397
+ "url": "",
398
+ "kpiType": "",
399
+ "parentTid": this.selected_kpi_tid,
400
+ "childTid": "",
401
+ "measures": this.userOptionContainer,
402
+ };
403
+ console.log("KPI with User Entity Obj:", kpiObj);
404
+ }
405
+ routeToKpiConfig() {
406
+ this.router.navigate(['apps/controlPanel/kpiController/kpiConfig']);
285
407
  }
286
408
  }
287
409
  CreateKpiTreeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CreateKpiTreeComponent, deps: [{ token: i1.CommonService }, { token: i2.FormBuilder }, { token: i3.CreateKpIService }, { token: i4.ToastrService }, { token: i5.Router }], target: i0.ɵɵFactoryTarget.Component });
288
- CreateKpiTreeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: CreateKpiTreeComponent, selector: "app-create-kpi", ngImport: i0, template: "<app-loading *ngIf=\"loadingModal\"></app-loading>\n<div class=\"p-4 flex flex-row w-full\" *ngIf=\"!loadingModal\">\n <div class=\"mx-2 bg-white dark:bg-transparent border-r\">\n <!-- <ng-container *ngIf=\"isKpiTreePrepared\"> -->\n <treeview class=\"dark bg-gray-900 dark:bg-transparent\" [name]=\"'mainNavigation'\" [routeKey]=\"'raKpi'\"\n [navigation]=\"kpiData\" [isSearchBox]=\"false\" [isEditIcon]=\"true\"\n (editableKpiData)=\"getEditableKpi($event)\">\n </treeview>\n <!-- </ng-container> -->\n\n </div>\n <div class=\"mx-2 w-full\">\n <!-- <div class=\"flex flex-row item-center justify-center my-8\">\n <button class=\"{{commonService.btn_warning_md}}\" (click)=\"addNewKpi()\">Add New KPI</button>\n <button class=\"{{commonService.btn_primary_md}}\" (click)=\"routeToKpiConfig()\"\n routerLinkActive=\"router-link-active\">Configure KPI</button>\n </div> -->\n <!-- <ng-container *ngIf=\"isNewKpiAdded\"> -->\n <!-- <div class=\"px-2 w-full\"> -->\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">Name</p>\n <dx-text-box [(ngModel)]=\"select_kpi_name\"></dx-text-box>\n </div>\n </div>\n <div class=\"flex flex-row w-full\">\n <div class=\"m-1 w-1/3\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\"> Tag Type</p>\n <dx-select-box [dataSource]=\"tagType\" [(ngModel)]=\"select_tag_type\"\n (onValueChanged)=\"addTagtypeValue($event)\"></dx-select-box>\n </div>\n </div>\n <!-- (onCustomItemCreating)=\"onCustomDimentionCreating($event)\" -->\n <div class=\"m-1 w-full\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">Aliases</p>\n <dx-tag-box [acceptCustomValue]=\"true\" [(ngModel)]=\"selected_aliases\"></dx-tag-box>\n </div>\n </div>\n </div>\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">Page ID</p>\n <!-- <dx-text-box [(ngModel)]=\"selected_page_id\"></dx-text-box> -->\n <dx-select-box [items]=\"templateDataSource\" valueExpr=\"pageId\" displayExpr=\"pageName\"\n [searchEnabled]=\"true\" [(ngModel)]=\"selected_page_id\"></dx-select-box>\n </div>\n </div>\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">Description</p>\n <dx-html-editor height=\"'auto'\" [(ngModel)]=\"selected_desc\">\n <dxo-toolbar [multiline]=\"false\">\n\n <dxi-item name=\"size\" [acceptedValues]=\"['8pt', '10pt', '12pt', '14pt', '18pt', '24pt', '36pt']\"\n [options]=\"{ inputAttr: { 'aria-label': 'Font size' } }\"></dxi-item>\n <dxi-item name=\"font\" [acceptedValues]=\"[\n 'Arial',\n 'Courier New',\n 'Georgia',\n 'Impact',\n 'Lucida Console',\n 'Tahoma',\n 'Times New Roman',\n 'Verdana'\n ]\" [options]=\"{ inputAttr: { 'aria-label': 'Font family' } }\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"bold\"></dxi-item>\n <dxi-item name=\"italic\"></dxi-item>\n <dxi-item name=\"underline\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"alignLeft\"></dxi-item>\n <dxi-item name=\"alignCenter\"></dxi-item>\n <dxi-item name=\"alignRight\"></dxi-item>\n <dxi-item name=\"alignJustify\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"orderedList\"></dxi-item>\n <dxi-item name=\"bulletList\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"header\" [acceptedValues]=\"[false, 1, 2, 3, 4, 5]\"\n [options]=\"{ inputAttr: { 'aria-label': 'Header' } }\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"color\"></dxi-item>\n <dxi-item name=\"background\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"link\"></dxi-item>\n <dxi-item name=\"image\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"clear\"></dxi-item>\n <dxi-item name=\"codeBlock\"></dxi-item>\n </dxo-toolbar>\n <dxo-media-resizing [enabled]=\"true\"> </dxo-media-resizing>\n <dxo-image-upload [tabs]=\"['file', 'url']\" fileUploadMode=\"base64\">\n </dxo-image-upload>\n </dx-html-editor>\n </div>\n </div>\n\n\n <div class=\"flex flex-row w-full\">\n <div class=\"m-1 w-full\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\"> Parent Component </p>\n <dx-select-box [items]=\"keiParentDataSource\" displayExpr=\"kpiName\" valueExpr=\"kpiId\"\n (onValueChanged)=\"getKpiItemValue($event)\" [(ngModel)]=\"parante_kpi_name\"></dx-select-box>\n </div>\n </div>\n <div class=\"m-1 w-full\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">Parent TID</p>\n <dx-text-box [(ngModel)]=\"selected_kpi_tid\" [readOnly]=\"false\"></dx-text-box>\n </div>\n </div>\n <div class=\"m-1 w-full\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">TID</p>\n <dx-text-box [(ngModel)]=\"selected_kpi_child_tid\" [readOnly]=\"false\"></dx-text-box>\n </div>\n </div>\n </div>\n\n <div class=\"flex flex-row justify-between mt-3\">\n <div class=\"px-2 pt-1 w-full\">\n <dx-check-box [(ngModel)]=\"kpi_visibility\" text=\"Visibility\"></dx-check-box>\n </div>\n <div class=\"px-2 pt-1 w-full\">\n <dx-check-box [(ngModel)]=\"kpi_external\" text=\"External KPI\"></dx-check-box>\n </div>\n </div>\n <!-- <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">KPI Info</p>\n <dx-html-editor height=\"'auto'\" [(ngModel)]=\"selected_info\">\n <dxo-toolbar [multiline]=\"false\">\n\n <dxi-item name=\"size\"\n [acceptedValues]=\"['8pt', '10pt', '12pt', '14pt', '18pt', '24pt', '36pt']\"\n [options]=\"{ inputAttr: { 'aria-label': 'Font size' } }\"></dxi-item>\n <dxi-item name=\"font\" [acceptedValues]=\"[\n 'Arial',\n 'Courier New',\n 'Georgia',\n 'Impact',\n 'Lucida Console',\n 'Tahoma',\n 'Times New Roman',\n 'Verdana'\n ]\"\n [options]=\"{ inputAttr: { 'aria-label': 'Font family' } }\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"bold\"></dxi-item>\n <dxi-item name=\"italic\"></dxi-item>\n <dxi-item name=\"underline\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"alignLeft\"></dxi-item>\n <dxi-item name=\"alignCenter\"></dxi-item>\n <dxi-item name=\"alignRight\"></dxi-item>\n <dxi-item name=\"alignJustify\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"orderedList\"></dxi-item>\n <dxi-item name=\"bulletList\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"header\" [acceptedValues]=\"[false, 1, 2, 3, 4, 5]\"\n [options]=\"{ inputAttr: { 'aria-label': 'Header' } }\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"color\"></dxi-item>\n <dxi-item name=\"background\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"link\"></dxi-item>\n <dxi-item name=\"image\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"clear\"></dxi-item>\n <dxi-item name=\"codeBlock\"></dxi-item>\n </dxo-toolbar>\n <dxo-media-resizing [enabled]=\"true\"> </dxo-media-resizing>\n <dxo-image-upload [tabs]=\"['file', 'url']\" fileUploadMode=\"base64\">\n </dxo-image-upload>\n </dx-html-editor>\n </div>\n </div> -->\n\n <app-user-access [(userOptionContainer)]=\"userOptionContainer\">\n </app-user-access>\n\n <div class=\"flex flex-auto mt-5 justify-end\">\n <button class=\"{{commonService.btn_success_md}}\" (click)=\"getUpdateKpi()\" *ngIf=\"isEditKpiAdded\">Update KPI\n </button>\n <button class=\"{{commonService.btn_danger_md}}\" (click)=\"getDeletKpi()\" *ngIf=\"isEditKpiAdded\">Delete KPI\n </button>\n <button class=\"{{commonService.btn_success_md}}\" (click)=\"makeNewKpiWithUserEntity()\" *ngIf=\"!isEditKpiAdded\">Create KPI\n </button>\n <button class=\"{{commonService.btn_warning_md}}\" (click)=\"getReseteKpi()\">Reset</button>\n\n </div>\n <!-- </div> -->\n <!-- </ng-container> -->\n </div>\n\n\n\n\n</div>", styles: [":host ::ng-deep treeview .treeview-wrapper{width:100%!important}\n"], dependencies: [{ kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i7.LoadingComponent, selector: "app-loading" }, { kind: "component", type: i8.DxiItemComponent, selector: "dxi-item", inputs: ["disabled", "html", "icon", "template", "text", "title", "visible", "onClick", "stylingMode", "type", "baseSize", "box", "ratio", "shrink", "elementAttr", "hint", "beginGroup", "closeMenuOnClick", "items", "selectable", "selected", "colSpan", "cssClass", "dataField", "editorOptions", "editorType", "helpText", "isRequired", "itemType", "label", "name", "validationRules", "visibleIndex", "alignItemLabels", "caption", "colCount", "colCountByScreen", "tabPanelOptions", "tabs", "badge", "tabTemplate", "buttonOptions", "horizontalAlignment", "verticalAlignment", "locateInMenu", "location", "menuItemTemplate", "options", "showText", "widget", "height", "width", "imageAlt", "imageSrc", "acceptedValues", "formatName", "formatValues", "key", "showChevron", "menuTemplate", "heightRatio", "widthRatio", "expanded", "hasItems", "id", "parentId"] }, { kind: "component", type: i9.DxCheckBoxComponent, selector: "dx-check-box", inputs: ["accessKey", "activeStateEnabled", "disabled", "elementAttr", "focusStateEnabled", "height", "hint", "hoverStateEnabled", "iconSize", "isValid", "name", "readOnly", "rtlEnabled", "tabIndex", "text", "validationError", "validationErrors", "validationMessageMode", "validationStatus", "value", "visible", "width"], outputs: ["onContentReady", "onDisposing", "onInitialized", "onOptionChanged", "onValueChanged", "accessKeyChange", "activeStateEnabledChange", "disabledChange", "elementAttrChange", "focusStateEnabledChange", "heightChange", "hintChange", "hoverStateEnabledChange", "iconSizeChange", "isValidChange", "nameChange", "readOnlyChange", "rtlEnabledChange", "tabIndexChange", "textChange", "validationErrorChange", "validationErrorsChange", "validationMessageModeChange", "validationStatusChange", "valueChange", "visibleChange", "widthChange", "onBlur"] }, { kind: "component", type: i8.DxoToolbarComponent, selector: "dxo-toolbar", inputs: ["disabled", "items", "visible", "fileSelectionItems", "container", "multiline"] }, { kind: "component", type: i10.DxHtmlEditorComponent, selector: "dx-html-editor", inputs: ["accessKey", "activeStateEnabled", "allowSoftLineBreak", "customizeModules", "disabled", "elementAttr", "focusStateEnabled", "height", "hint", "hoverStateEnabled", "imageUpload", "isValid", "mediaResizing", "mentions", "name", "placeholder", "readOnly", "rtlEnabled", "stylingMode", "tabIndex", "tableContextMenu", "tableResizing", "toolbar", "validationError", "validationErrors", "validationMessageMode", "validationStatus", "value", "valueType", "variables", "visible", "width"], outputs: ["onContentReady", "onDisposing", "onFocusIn", "onFocusOut", "onInitialized", "onOptionChanged", "onValueChanged", "accessKeyChange", "activeStateEnabledChange", "allowSoftLineBreakChange", "customizeModulesChange", "disabledChange", "elementAttrChange", "focusStateEnabledChange", "heightChange", "hintChange", "hoverStateEnabledChange", "imageUploadChange", "isValidChange", "mediaResizingChange", "mentionsChange", "nameChange", "placeholderChange", "readOnlyChange", "rtlEnabledChange", "stylingModeChange", "tabIndexChange", "tableContextMenuChange", "tableResizingChange", "toolbarChange", "validationErrorChange", "validationErrorsChange", "validationMessageModeChange", "validationStatusChange", "valueChange", "valueTypeChange", "variablesChange", "visibleChange", "widthChange", "onBlur"] }, { kind: "component", type: i8.DxoImageUploadComponent, selector: "dxo-image-upload", inputs: ["fileUploaderOptions", "fileUploadMode", "tabs", "uploadDirectory", "uploadUrl"] }, { kind: "component", type: i8.DxoMediaResizingComponent, selector: "dxo-media-resizing", inputs: ["allowedTargets", "enabled"] }, { kind: "component", type: i11.DxSelectBoxComponent, selector: "dx-select-box", inputs: ["acceptCustomValue", "accessKey", "activeStateEnabled", "buttons", "dataSource", "deferRendering", "disabled", "displayExpr", "displayValue", "dropDownButtonTemplate", "dropDownOptions", "elementAttr", "fieldTemplate", "focusStateEnabled", "grouped", "groupTemplate", "height", "hint", "hoverStateEnabled", "inputAttr", "isValid", "items", "itemTemplate", "label", "labelMode", "maxLength", "minSearchLength", "name", "noDataText", "opened", "openOnFieldClick", "placeholder", "readOnly", "rtlEnabled", "searchEnabled", "searchExpr", "searchMode", "searchTimeout", "selectedItem", "showClearButton", "showDataBeforeSearch", "showDropDownButton", "showSelectionControls", "spellcheck", "stylingMode", "tabIndex", "text", "useItemTextAsTitle", "validationError", "validationErrors", "validationMessageMode", "validationStatus", "value", "valueChangeEvent", "valueExpr", "visible", "width", "wrapItemText"], outputs: ["onChange", "onClosed", "onContentReady", "onCopy", "onCustomItemCreating", "onCut", "onDisposing", "onEnterKey", "onFocusIn", "onFocusOut", "onInitialized", "onInput", "onItemClick", "onKeyDown", "onKeyUp", "onOpened", "onOptionChanged", "onPaste", "onSelectionChanged", "onValueChanged", "acceptCustomValueChange", "accessKeyChange", "activeStateEnabledChange", "buttonsChange", "dataSourceChange", "deferRenderingChange", "disabledChange", "displayExprChange", "displayValueChange", "dropDownButtonTemplateChange", "dropDownOptionsChange", "elementAttrChange", "fieldTemplateChange", "focusStateEnabledChange", "groupedChange", "groupTemplateChange", "heightChange", "hintChange", "hoverStateEnabledChange", "inputAttrChange", "isValidChange", "itemsChange", "itemTemplateChange", "labelChange", "labelModeChange", "maxLengthChange", "minSearchLengthChange", "nameChange", "noDataTextChange", "openedChange", "openOnFieldClickChange", "placeholderChange", "readOnlyChange", "rtlEnabledChange", "searchEnabledChange", "searchExprChange", "searchModeChange", "searchTimeoutChange", "selectedItemChange", "showClearButtonChange", "showDataBeforeSearchChange", "showDropDownButtonChange", "showSelectionControlsChange", "spellcheckChange", "stylingModeChange", "tabIndexChange", "textChange", "useItemTextAsTitleChange", "validationErrorChange", "validationErrorsChange", "validationMessageModeChange", "validationStatusChange", "valueChange", "valueChangeEventChange", "valueExprChange", "visibleChange", "widthChange", "wrapItemTextChange", "onBlur"] }, { kind: "component", type: i12.DxTagBoxComponent, selector: "dx-tag-box", inputs: ["acceptCustomValue", "accessKey", "activeStateEnabled", "applyValueMode", "buttons", "dataSource", "deferRendering", "disabled", "displayExpr", "dropDownButtonTemplate", "dropDownOptions", "elementAttr", "fieldTemplate", "focusStateEnabled", "grouped", "groupTemplate", "height", "hideSelectedItems", "hint", "hoverStateEnabled", "inputAttr", "isValid", "items", "itemTemplate", "label", "labelMode", "maxDisplayedTags", "maxFilterQueryLength", "maxLength", "minSearchLength", "multiline", "name", "noDataText", "opened", "openOnFieldClick", "placeholder", "readOnly", "rtlEnabled", "searchEnabled", "searchExpr", "searchMode", "searchTimeout", "selectAllMode", "selectAllText", "selectedItems", "showClearButton", "showDataBeforeSearch", "showDropDownButton", "showMultiTagOnly", "showSelectionControls", "stylingMode", "tabIndex", "tagTemplate", "text", "useItemTextAsTitle", "validationError", "validationErrors", "validationMessageMode", "validationStatus", "value", "valueExpr", "visible", "width", "wrapItemText"], outputs: ["onChange", "onClosed", "onContentReady", "onCustomItemCreating", "onDisposing", "onEnterKey", "onFocusIn", "onFocusOut", "onInitialized", "onInput", "onItemClick", "onKeyDown", "onKeyUp", "onMultiTagPreparing", "onOpened", "onOptionChanged", "onSelectAllValueChanged", "onSelectionChanged", "onValueChanged", "acceptCustomValueChange", "accessKeyChange", "activeStateEnabledChange", "applyValueModeChange", "buttonsChange", "dataSourceChange", "deferRenderingChange", "disabledChange", "displayExprChange", "dropDownButtonTemplateChange", "dropDownOptionsChange", "elementAttrChange", "fieldTemplateChange", "focusStateEnabledChange", "groupedChange", "groupTemplateChange", "heightChange", "hideSelectedItemsChange", "hintChange", "hoverStateEnabledChange", "inputAttrChange", "isValidChange", "itemsChange", "itemTemplateChange", "labelChange", "labelModeChange", "maxDisplayedTagsChange", "maxFilterQueryLengthChange", "maxLengthChange", "minSearchLengthChange", "multilineChange", "nameChange", "noDataTextChange", "openedChange", "openOnFieldClickChange", "placeholderChange", "readOnlyChange", "rtlEnabledChange", "searchEnabledChange", "searchExprChange", "searchModeChange", "searchTimeoutChange", "selectAllModeChange", "selectAllTextChange", "selectedItemsChange", "showClearButtonChange", "showDataBeforeSearchChange", "showDropDownButtonChange", "showMultiTagOnlyChange", "showSelectionControlsChange", "stylingModeChange", "tabIndexChange", "tagTemplateChange", "textChange", "useItemTextAsTitleChange", "validationErrorChange", "validationErrorsChange", "validationMessageModeChange", "validationStatusChange", "valueChange", "valueExprChange", "visibleChange", "widthChange", "wrapItemTextChange", "onBlur"] }, { kind: "component", type: i13.DxTextBoxComponent, selector: "dx-text-box", inputs: ["accessKey", "activeStateEnabled", "buttons", "disabled", "elementAttr", "focusStateEnabled", "height", "hint", "hoverStateEnabled", "inputAttr", "isValid", "label", "labelMode", "mask", "maskChar", "maskInvalidMessage", "maskRules", "maxLength", "mode", "name", "placeholder", "readOnly", "rtlEnabled", "showClearButton", "showMaskMode", "spellcheck", "stylingMode", "tabIndex", "text", "useMaskedValue", "validationError", "validationErrors", "validationMessageMode", "validationStatus", "value", "valueChangeEvent", "visible", "width"], outputs: ["onChange", "onContentReady", "onCopy", "onCut", "onDisposing", "onEnterKey", "onFocusIn", "onFocusOut", "onInitialized", "onInput", "onKeyDown", "onKeyUp", "onOptionChanged", "onPaste", "onValueChanged", "accessKeyChange", "activeStateEnabledChange", "buttonsChange", "disabledChange", "elementAttrChange", "focusStateEnabledChange", "heightChange", "hintChange", "hoverStateEnabledChange", "inputAttrChange", "isValidChange", "labelChange", "labelModeChange", "maskChange", "maskCharChange", "maskInvalidMessageChange", "maskRulesChange", "maxLengthChange", "modeChange", "nameChange", "placeholderChange", "readOnlyChange", "rtlEnabledChange", "showClearButtonChange", "showMaskModeChange", "spellcheckChange", "stylingModeChange", "tabIndexChange", "textChange", "useMaskedValueChange", "validationErrorChange", "validationErrorsChange", "validationMessageModeChange", "validationStatusChange", "valueChange", "valueChangeEventChange", "visibleChange", "widthChange", "onBlur"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i14.UserAccessComponent, selector: "app-user-access", inputs: ["userOptionContainer"], outputs: ["userOptionContainerChange"] }, { kind: "component", type: i15.TreeviewComponent, selector: "treeview", inputs: ["autoCollapse", "inner", "navigation", "opened", "isEditIcon", "isSearchBox", "transparentOverlay", "treeListForSearchBox", "name", "openTreeId", "routeKey"], outputs: ["editableKpiData"] }] });
410
+ CreateKpiTreeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: CreateKpiTreeComponent, selector: "app-create-kpi", ngImport: i0, template: "<app-loading *ngIf=\"loadingModal\"></app-loading>\n<div class=\"p-4 flex flex-row w-full\">\n <div class=\"mx-2 bg-white dark:bg-transparent border-r\">\n\n <treeview class=\"dark bg-gray-900 dark:bg-transparent\" [name]=\"'mainNavigation'\" [routeKey]=\"'raKpi'\"\n [navigation]=\"kpiData\" [isSearchBox]=\"false\" [isEditIcon]=\"true\" (editableKpiData)=\"getEditableKpi($event)\">\n </treeview>\n </div>\n <div class=\"mx-2 w-full\">\n <div class=\"flex flex-row item-center justify-center my-8\">\n <button class=\"{{commonService.btn_warning_md}}\" (click)=\"addNewKpi()\">Add New KPI</button>\n <button class=\"{{commonService.btn_primary_md}}\" (click)=\"routeToKpiConfig()\"\n routerLinkActive=\"router-link-active\">Configure KPI</button>\n </div>\n <ng-container *ngIf=\"isNewKpiAdded\">\n <div class=\"px-2 w-full\">\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">Name</p>\n <dx-text-box [(ngModel)]=\"select_kpi_name\"></dx-text-box>\n </div>\n </div>\n\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\"> Tag Type</p>\n <dx-select-box [dataSource]=\"tagType\" [(ngModel)]=\"select_tag_type\"\n (onValueChanged)=\"addTagtypeValue($event)\"></dx-select-box>\n </div>\n </div>\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">ID</p>\n <dx-text-box [(ngModel)]=\"selected_id\"></dx-text-box>\n </div>\n </div>\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">Page ID</p>\n <!-- <dx-text-box [(ngModel)]=\"selected_page_id\"></dx-text-box> -->\n <dx-select-box [items]=\"templateDataSource\" valueExpr=\"pageId\" displayExpr=\"pageName\" [searchEnabled]=\"true\"\n [(ngModel)]=\"selected_page_id\"></dx-select-box>\n </div>\n </div>\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">Description</p>\n <dx-html-editor height=\"'auto'\" [(ngModel)]=\"selected_desc\">\n <dxo-toolbar [multiline]=\"false\">\n\n <dxi-item name=\"size\"\n [acceptedValues]=\"['8pt', '10pt', '12pt', '14pt', '18pt', '24pt', '36pt']\"\n [options]=\"{ inputAttr: { 'aria-label': 'Font size' } }\"></dxi-item>\n <dxi-item name=\"font\" [acceptedValues]=\"[\n 'Arial',\n 'Courier New',\n 'Georgia',\n 'Impact',\n 'Lucida Console',\n 'Tahoma',\n 'Times New Roman',\n 'Verdana'\n ]\" [options]=\"{ inputAttr: { 'aria-label': 'Font family' } }\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"bold\"></dxi-item>\n <dxi-item name=\"italic\"></dxi-item>\n <dxi-item name=\"underline\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"alignLeft\"></dxi-item>\n <dxi-item name=\"alignCenter\"></dxi-item>\n <dxi-item name=\"alignRight\"></dxi-item>\n <dxi-item name=\"alignJustify\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"orderedList\"></dxi-item>\n <dxi-item name=\"bulletList\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"header\" [acceptedValues]=\"[false, 1, 2, 3, 4, 5]\"\n [options]=\"{ inputAttr: { 'aria-label': 'Header' } }\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"color\"></dxi-item>\n <dxi-item name=\"background\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"link\"></dxi-item>\n <dxi-item name=\"image\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"clear\"></dxi-item>\n <dxi-item name=\"codeBlock\"></dxi-item>\n </dxo-toolbar>\n <dxo-media-resizing [enabled]=\"true\"> </dxo-media-resizing>\n <dxo-image-upload [tabs]=\"['file', 'url']\" fileUploadMode=\"base64\">\n </dxo-image-upload>\n </dx-html-editor>\n </div>\n </div>\n\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\"> Parent Component </p>\n <dx-select-box [dataSource]=\"keiParentDataSource\" displayExpr=\"name\" valueExpr=\"tid\"\n (onValueChanged)=\"getKpiItemValue($event)\" [value]=\"parante_kpi_name\"></dx-select-box>\n </div>\n </div>\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">TID</p>\n <dx-text-box [(ngModel)]=\"selected_kpi_tid\" [readOnly]=\"true\"></dx-text-box>\n </div>\n </div>\n <div class=\"flex flex-row justify-between mt-3\">\n <div class=\"px-2 pt-1 w-full\">\n <dx-check-box [(ngModel)]=\"kpi_visibility\" text=\"Visibility\"></dx-check-box>\n </div>\n <div class=\"px-2 pt-1 w-full\">\n <dx-check-box [(ngModel)]=\"kpi_external\" text=\"External KPI\"></dx-check-box>\n </div>\n </div>\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">KPI Info</p>\n <dx-html-editor height=\"'auto'\" [(ngModel)]=\"selected_info\">\n <dxo-toolbar [multiline]=\"false\">\n\n <dxi-item name=\"size\"\n [acceptedValues]=\"['8pt', '10pt', '12pt', '14pt', '18pt', '24pt', '36pt']\"\n [options]=\"{ inputAttr: { 'aria-label': 'Font size' } }\"></dxi-item>\n <dxi-item name=\"font\" [acceptedValues]=\"[\n 'Arial',\n 'Courier New',\n 'Georgia',\n 'Impact',\n 'Lucida Console',\n 'Tahoma',\n 'Times New Roman',\n 'Verdana'\n ]\"\n [options]=\"{ inputAttr: { 'aria-label': 'Font family' } }\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"bold\"></dxi-item>\n <dxi-item name=\"italic\"></dxi-item>\n <dxi-item name=\"underline\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"alignLeft\"></dxi-item>\n <dxi-item name=\"alignCenter\"></dxi-item>\n <dxi-item name=\"alignRight\"></dxi-item>\n <dxi-item name=\"alignJustify\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"orderedList\"></dxi-item>\n <dxi-item name=\"bulletList\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"header\" [acceptedValues]=\"[false, 1, 2, 3, 4, 5]\"\n [options]=\"{ inputAttr: { 'aria-label': 'Header' } }\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"color\"></dxi-item>\n <dxi-item name=\"background\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"link\"></dxi-item>\n <dxi-item name=\"image\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"clear\"></dxi-item>\n <dxi-item name=\"codeBlock\"></dxi-item>\n </dxo-toolbar>\n <dxo-media-resizing [enabled]=\"true\"> </dxo-media-resizing>\n <dxo-image-upload [tabs]=\"['file', 'url']\" fileUploadMode=\"base64\">\n </dxo-image-upload>\n </dx-html-editor>\n </div>\n </div>\n\n <app-user-access [(userOptionContainer)]=\"userOptionContainer\">\n </app-user-access>\n\n <div class=\"flex flex-auto mt-5 justify-end\">\n <button class=\"{{commonService.btn_primary_md}}\" (click)=\"makeNewKpi()\">Create\n </button>\n <button class=\"{{commonService.btn_primary_md}}\" (click)=\"makeNewKpiWithUserEntity()\">Create With User Privilege\n </button>\n <button class=\"{{commonService.btn_warning_md}}\" (click)=\"getReseteKpi()\">Reset</button>\n\n </div>\n </div>\n </ng-container>\n <ng-container *ngIf=\"isEditKpiAdded\">\n <div class=\"px-2 w-full\">\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mb-2\">Name</p>\n <dx-text-box [(ngModel)]=\"editable_kpi_name\"></dx-text-box>\n </div>\n </div>\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\"> Tag Type</p>\n <dx-select-box [dataSource]=\"tagType\" [(ngModel)]=\"editable_tag_type\"\n (onValueChanged)=\"addTagtypeValue($event)\" [readOnly]=\"isFromEditable\"></dx-select-box>\n </div>\n </div>\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">ID</p>\n <dx-text-box [(ngModel)]=\"editable_id\"></dx-text-box>\n </div>\n </div>\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">Page ID</p>\n <!-- <dx-text-box [(ngModel)]=\"editable_page_id\"></dx-text-box> -->\n <dx-select-box [items]=\"templateDataSource\" valueExpr=\"pageId\" displayExpr=\"pageName\" [searchEnabled]=\"true\"\n [(ngModel)]=\"editable_page_id\"></dx-select-box>\n\n </div>\n </div>\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">Description</p>\n <dx-html-editor height=\"'auto'\" [(ngModel)]=\"editable_desc\">\n <dxo-toolbar [multiline]=\"true\">\n <dxi-item name=\"undo\"></dxi-item>\n <dxi-item name=\"redo\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"size\"\n [acceptedValues]=\"['8pt', '10pt', '12pt', '14pt', '18pt', '24pt', '36pt']\"\n [options]=\"{ inputAttr: { 'aria-label': 'Font size' } }\"></dxi-item>\n <dxi-item name=\"font\" [acceptedValues]=\"[\n 'Arial',\n 'Courier New',\n 'Georgia',\n 'Impact',\n 'Lucida Console',\n 'Tahoma',\n 'Times New Roman',\n 'Verdana'\n ]\"\n [options]=\"{ inputAttr: { 'aria-label': 'Font family' } }\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"bold\"></dxi-item>\n <dxi-item name=\"italic\"></dxi-item>\n <dxi-item name=\"underline\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"alignLeft\"></dxi-item>\n <dxi-item name=\"alignCenter\"></dxi-item>\n <dxi-item name=\"alignRight\"></dxi-item>\n <dxi-item name=\"alignJustify\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"orderedList\"></dxi-item>\n <dxi-item name=\"bulletList\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"header\" [acceptedValues]=\"[false, 1, 2, 3, 4, 5]\"\n [options]=\"{ inputAttr: { 'aria-label': 'Header' } }\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"color\"></dxi-item>\n <dxi-item name=\"background\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"link\"></dxi-item>\n <dxi-item name=\"image\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"clear\"></dxi-item>\n <dxi-item name=\"blockquote\"></dxi-item>\n\n </dxo-toolbar>\n <dxo-media-resizing [enabled]=\"true\"> </dxo-media-resizing>\n <dxo-image-upload [tabs]=\"['file', 'url']\" fileUploadMode=\"base64\">\n </dxo-image-upload>\n </dx-html-editor>\n </div>\n </div>\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\"> Parent Component </p>\n <dx-select-box [searchEnabled]=\"true\" [readOnly]=\"editable_tag_type == 'parent'\"\n [dataSource]=\"keiParentDataSource\" displayExpr=\"name\" valueExpr=\"tid\"\n (onValueChanged)=\"getNewParrentKpiItemValue($event)\"\n [value]=\"parante_kpi_name\"></dx-select-box>\n </div>\n </div>\n\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">TID</p>\n <dx-text-box [(ngModel)]=\"editable_kpi_tid\" [readOnly]=\"false\"></dx-text-box>\n </div>\n </div>\n <div class=\"flex flex-row justify-between mt-3\">\n\n <div class=\"px-2 pt-1 w-full\">\n <dx-check-box [(ngModel)]=\"kpi_visibility\" text=\"Visibility\"></dx-check-box>\n </div>\n\n <div class=\"px-2 pt-1 w-full\">\n <dx-check-box [(ngModel)]=\"kpi_external\" text=\"External KPI\"></dx-check-box>\n </div>\n </div>\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">KPI Info</p>\n <dx-html-editor height=\"'auto'\" [(ngModel)]=\"editable_info\">\n <dxo-toolbar [multiline]=\"false\">\n\n <dxi-item name=\"size\"\n [acceptedValues]=\"['8pt', '10pt', '12pt', '14pt', '18pt', '24pt', '36pt']\"\n [options]=\"{ inputAttr: { 'aria-label': 'Font size' } }\"></dxi-item>\n <dxi-item name=\"font\" [acceptedValues]=\"[\n 'Arial',\n 'Courier New',\n 'Georgia',\n 'Impact',\n 'Lucida Console',\n 'Tahoma',\n 'Times New Roman',\n 'Verdana'\n ]\"\n [options]=\"{ inputAttr: { 'aria-label': 'Font family' } }\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"bold\"></dxi-item>\n <dxi-item name=\"italic\"></dxi-item>\n <dxi-item name=\"underline\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"alignLeft\"></dxi-item>\n <dxi-item name=\"alignCenter\"></dxi-item>\n <dxi-item name=\"alignRight\"></dxi-item>\n <dxi-item name=\"alignJustify\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"orderedList\"></dxi-item>\n <dxi-item name=\"bulletList\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"header\" [acceptedValues]=\"[false, 1, 2, 3, 4, 5]\"\n [options]=\"{ inputAttr: { 'aria-label': 'Header' } }\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"color\"></dxi-item>\n <dxi-item name=\"background\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"link\"></dxi-item>\n <dxi-item name=\"image\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"clear\"></dxi-item>\n <dxi-item name=\"codeBlock\"></dxi-item>\n </dxo-toolbar>\n <dxo-media-resizing [enabled]=\"true\"> </dxo-media-resizing>\n <dxo-image-upload [tabs]=\"['file', 'url']\" fileUploadMode=\"base64\">\n </dxo-image-upload>\n </dx-html-editor>\n </div>\n </div>\n <div class=\"flex flex-auto mt-3 justify-end\">\n <button class=\"{{commonService.btn_primary_md}}\" (click)=\"getUpdateKpi()\">Update\n </button>\n <button class=\"{{commonService.btn_danger_md}}\" (click)=\"getDeleteKpi()\">Delete\n </button>\n <!-- <button class=\"{{commonService.btn_danger_md}}\" (click)=\"cancelUpdate()\">Cancle</button> -->\n\n </div>\n </div>\n </ng-container>\n </div>\n\n\n\n\n</div>", styles: [":host ::ng-deep treeview .treeview-wrapper{width:100%!important}\n"], dependencies: [{ kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i7.LoadingComponent, selector: "app-loading" }, { kind: "component", type: i8.DxiItemComponent, selector: "dxi-item", inputs: ["disabled", "html", "icon", "template", "text", "title", "visible", "onClick", "stylingMode", "type", "baseSize", "box", "ratio", "shrink", "elementAttr", "hint", "beginGroup", "closeMenuOnClick", "items", "selectable", "selected", "colSpan", "cssClass", "dataField", "editorOptions", "editorType", "helpText", "isRequired", "itemType", "label", "name", "validationRules", "visibleIndex", "alignItemLabels", "caption", "colCount", "colCountByScreen", "tabPanelOptions", "tabs", "badge", "tabTemplate", "buttonOptions", "horizontalAlignment", "verticalAlignment", "locateInMenu", "location", "menuItemTemplate", "options", "showText", "widget", "height", "width", "imageAlt", "imageSrc", "acceptedValues", "formatName", "formatValues", "key", "showChevron", "menuTemplate", "heightRatio", "widthRatio", "expanded", "hasItems", "id", "parentId"] }, { kind: "component", type: i9.DxCheckBoxComponent, selector: "dx-check-box", inputs: ["accessKey", "activeStateEnabled", "disabled", "elementAttr", "focusStateEnabled", "height", "hint", "hoverStateEnabled", "iconSize", "isValid", "name", "readOnly", "rtlEnabled", "tabIndex", "text", "validationError", "validationErrors", "validationMessageMode", "validationStatus", "value", "visible", "width"], outputs: ["onContentReady", "onDisposing", "onInitialized", "onOptionChanged", "onValueChanged", "accessKeyChange", "activeStateEnabledChange", "disabledChange", "elementAttrChange", "focusStateEnabledChange", "heightChange", "hintChange", "hoverStateEnabledChange", "iconSizeChange", "isValidChange", "nameChange", "readOnlyChange", "rtlEnabledChange", "tabIndexChange", "textChange", "validationErrorChange", "validationErrorsChange", "validationMessageModeChange", "validationStatusChange", "valueChange", "visibleChange", "widthChange", "onBlur"] }, { kind: "component", type: i8.DxoToolbarComponent, selector: "dxo-toolbar", inputs: ["disabled", "items", "visible", "fileSelectionItems", "container", "multiline"] }, { kind: "component", type: i10.DxHtmlEditorComponent, selector: "dx-html-editor", inputs: ["accessKey", "activeStateEnabled", "allowSoftLineBreak", "customizeModules", "disabled", "elementAttr", "focusStateEnabled", "height", "hint", "hoverStateEnabled", "imageUpload", "isValid", "mediaResizing", "mentions", "name", "placeholder", "readOnly", "rtlEnabled", "stylingMode", "tabIndex", "tableContextMenu", "tableResizing", "toolbar", "validationError", "validationErrors", "validationMessageMode", "validationStatus", "value", "valueType", "variables", "visible", "width"], outputs: ["onContentReady", "onDisposing", "onFocusIn", "onFocusOut", "onInitialized", "onOptionChanged", "onValueChanged", "accessKeyChange", "activeStateEnabledChange", "allowSoftLineBreakChange", "customizeModulesChange", "disabledChange", "elementAttrChange", "focusStateEnabledChange", "heightChange", "hintChange", "hoverStateEnabledChange", "imageUploadChange", "isValidChange", "mediaResizingChange", "mentionsChange", "nameChange", "placeholderChange", "readOnlyChange", "rtlEnabledChange", "stylingModeChange", "tabIndexChange", "tableContextMenuChange", "tableResizingChange", "toolbarChange", "validationErrorChange", "validationErrorsChange", "validationMessageModeChange", "validationStatusChange", "valueChange", "valueTypeChange", "variablesChange", "visibleChange", "widthChange", "onBlur"] }, { kind: "component", type: i8.DxoImageUploadComponent, selector: "dxo-image-upload", inputs: ["fileUploaderOptions", "fileUploadMode", "tabs", "uploadDirectory", "uploadUrl"] }, { kind: "component", type: i8.DxoMediaResizingComponent, selector: "dxo-media-resizing", inputs: ["allowedTargets", "enabled"] }, { kind: "component", type: i11.DxSelectBoxComponent, selector: "dx-select-box", inputs: ["acceptCustomValue", "accessKey", "activeStateEnabled", "buttons", "dataSource", "deferRendering", "disabled", "displayExpr", "displayValue", "dropDownButtonTemplate", "dropDownOptions", "elementAttr", "fieldTemplate", "focusStateEnabled", "grouped", "groupTemplate", "height", "hint", "hoverStateEnabled", "inputAttr", "isValid", "items", "itemTemplate", "label", "labelMode", "maxLength", "minSearchLength", "name", "noDataText", "opened", "openOnFieldClick", "placeholder", "readOnly", "rtlEnabled", "searchEnabled", "searchExpr", "searchMode", "searchTimeout", "selectedItem", "showClearButton", "showDataBeforeSearch", "showDropDownButton", "showSelectionControls", "spellcheck", "stylingMode", "tabIndex", "text", "useItemTextAsTitle", "validationError", "validationErrors", "validationMessageMode", "validationStatus", "value", "valueChangeEvent", "valueExpr", "visible", "width", "wrapItemText"], outputs: ["onChange", "onClosed", "onContentReady", "onCopy", "onCustomItemCreating", "onCut", "onDisposing", "onEnterKey", "onFocusIn", "onFocusOut", "onInitialized", "onInput", "onItemClick", "onKeyDown", "onKeyUp", "onOpened", "onOptionChanged", "onPaste", "onSelectionChanged", "onValueChanged", "acceptCustomValueChange", "accessKeyChange", "activeStateEnabledChange", "buttonsChange", "dataSourceChange", "deferRenderingChange", "disabledChange", "displayExprChange", "displayValueChange", "dropDownButtonTemplateChange", "dropDownOptionsChange", "elementAttrChange", "fieldTemplateChange", "focusStateEnabledChange", "groupedChange", "groupTemplateChange", "heightChange", "hintChange", "hoverStateEnabledChange", "inputAttrChange", "isValidChange", "itemsChange", "itemTemplateChange", "labelChange", "labelModeChange", "maxLengthChange", "minSearchLengthChange", "nameChange", "noDataTextChange", "openedChange", "openOnFieldClickChange", "placeholderChange", "readOnlyChange", "rtlEnabledChange", "searchEnabledChange", "searchExprChange", "searchModeChange", "searchTimeoutChange", "selectedItemChange", "showClearButtonChange", "showDataBeforeSearchChange", "showDropDownButtonChange", "showSelectionControlsChange", "spellcheckChange", "stylingModeChange", "tabIndexChange", "textChange", "useItemTextAsTitleChange", "validationErrorChange", "validationErrorsChange", "validationMessageModeChange", "validationStatusChange", "valueChange", "valueChangeEventChange", "valueExprChange", "visibleChange", "widthChange", "wrapItemTextChange", "onBlur"] }, { kind: "component", type: i12.DxTextBoxComponent, selector: "dx-text-box", inputs: ["accessKey", "activeStateEnabled", "buttons", "disabled", "elementAttr", "focusStateEnabled", "height", "hint", "hoverStateEnabled", "inputAttr", "isValid", "label", "labelMode", "mask", "maskChar", "maskInvalidMessage", "maskRules", "maxLength", "mode", "name", "placeholder", "readOnly", "rtlEnabled", "showClearButton", "showMaskMode", "spellcheck", "stylingMode", "tabIndex", "text", "useMaskedValue", "validationError", "validationErrors", "validationMessageMode", "validationStatus", "value", "valueChangeEvent", "visible", "width"], outputs: ["onChange", "onContentReady", "onCopy", "onCut", "onDisposing", "onEnterKey", "onFocusIn", "onFocusOut", "onInitialized", "onInput", "onKeyDown", "onKeyUp", "onOptionChanged", "onPaste", "onValueChanged", "accessKeyChange", "activeStateEnabledChange", "buttonsChange", "disabledChange", "elementAttrChange", "focusStateEnabledChange", "heightChange", "hintChange", "hoverStateEnabledChange", "inputAttrChange", "isValidChange", "labelChange", "labelModeChange", "maskChange", "maskCharChange", "maskInvalidMessageChange", "maskRulesChange", "maxLengthChange", "modeChange", "nameChange", "placeholderChange", "readOnlyChange", "rtlEnabledChange", "showClearButtonChange", "showMaskModeChange", "spellcheckChange", "stylingModeChange", "tabIndexChange", "textChange", "useMaskedValueChange", "validationErrorChange", "validationErrorsChange", "validationMessageModeChange", "validationStatusChange", "valueChange", "valueChangeEventChange", "visibleChange", "widthChange", "onBlur"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i13.UserAccessComponent, selector: "app-user-access", inputs: ["userOptionContainer"], outputs: ["userOptionContainerChange"] }, { kind: "component", type: i14.TreeviewComponent, selector: "treeview", inputs: ["autoCollapse", "inner", "navigation", "opened", "isEditIcon", "isSearchBox", "transparentOverlay", "treeListForSearchBox", "name", "openTreeId", "routeKey"], outputs: ["editableKpiData"] }] });
289
411
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CreateKpiTreeComponent, decorators: [{
290
412
  type: Component,
291
- args: [{ selector: 'app-create-kpi', template: "<app-loading *ngIf=\"loadingModal\"></app-loading>\n<div class=\"p-4 flex flex-row w-full\" *ngIf=\"!loadingModal\">\n <div class=\"mx-2 bg-white dark:bg-transparent border-r\">\n <!-- <ng-container *ngIf=\"isKpiTreePrepared\"> -->\n <treeview class=\"dark bg-gray-900 dark:bg-transparent\" [name]=\"'mainNavigation'\" [routeKey]=\"'raKpi'\"\n [navigation]=\"kpiData\" [isSearchBox]=\"false\" [isEditIcon]=\"true\"\n (editableKpiData)=\"getEditableKpi($event)\">\n </treeview>\n <!-- </ng-container> -->\n\n </div>\n <div class=\"mx-2 w-full\">\n <!-- <div class=\"flex flex-row item-center justify-center my-8\">\n <button class=\"{{commonService.btn_warning_md}}\" (click)=\"addNewKpi()\">Add New KPI</button>\n <button class=\"{{commonService.btn_primary_md}}\" (click)=\"routeToKpiConfig()\"\n routerLinkActive=\"router-link-active\">Configure KPI</button>\n </div> -->\n <!-- <ng-container *ngIf=\"isNewKpiAdded\"> -->\n <!-- <div class=\"px-2 w-full\"> -->\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">Name</p>\n <dx-text-box [(ngModel)]=\"select_kpi_name\"></dx-text-box>\n </div>\n </div>\n <div class=\"flex flex-row w-full\">\n <div class=\"m-1 w-1/3\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\"> Tag Type</p>\n <dx-select-box [dataSource]=\"tagType\" [(ngModel)]=\"select_tag_type\"\n (onValueChanged)=\"addTagtypeValue($event)\"></dx-select-box>\n </div>\n </div>\n <!-- (onCustomItemCreating)=\"onCustomDimentionCreating($event)\" -->\n <div class=\"m-1 w-full\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">Aliases</p>\n <dx-tag-box [acceptCustomValue]=\"true\" [(ngModel)]=\"selected_aliases\"></dx-tag-box>\n </div>\n </div>\n </div>\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">Page ID</p>\n <!-- <dx-text-box [(ngModel)]=\"selected_page_id\"></dx-text-box> -->\n <dx-select-box [items]=\"templateDataSource\" valueExpr=\"pageId\" displayExpr=\"pageName\"\n [searchEnabled]=\"true\" [(ngModel)]=\"selected_page_id\"></dx-select-box>\n </div>\n </div>\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">Description</p>\n <dx-html-editor height=\"'auto'\" [(ngModel)]=\"selected_desc\">\n <dxo-toolbar [multiline]=\"false\">\n\n <dxi-item name=\"size\" [acceptedValues]=\"['8pt', '10pt', '12pt', '14pt', '18pt', '24pt', '36pt']\"\n [options]=\"{ inputAttr: { 'aria-label': 'Font size' } }\"></dxi-item>\n <dxi-item name=\"font\" [acceptedValues]=\"[\n 'Arial',\n 'Courier New',\n 'Georgia',\n 'Impact',\n 'Lucida Console',\n 'Tahoma',\n 'Times New Roman',\n 'Verdana'\n ]\" [options]=\"{ inputAttr: { 'aria-label': 'Font family' } }\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"bold\"></dxi-item>\n <dxi-item name=\"italic\"></dxi-item>\n <dxi-item name=\"underline\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"alignLeft\"></dxi-item>\n <dxi-item name=\"alignCenter\"></dxi-item>\n <dxi-item name=\"alignRight\"></dxi-item>\n <dxi-item name=\"alignJustify\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"orderedList\"></dxi-item>\n <dxi-item name=\"bulletList\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"header\" [acceptedValues]=\"[false, 1, 2, 3, 4, 5]\"\n [options]=\"{ inputAttr: { 'aria-label': 'Header' } }\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"color\"></dxi-item>\n <dxi-item name=\"background\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"link\"></dxi-item>\n <dxi-item name=\"image\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"clear\"></dxi-item>\n <dxi-item name=\"codeBlock\"></dxi-item>\n </dxo-toolbar>\n <dxo-media-resizing [enabled]=\"true\"> </dxo-media-resizing>\n <dxo-image-upload [tabs]=\"['file', 'url']\" fileUploadMode=\"base64\">\n </dxo-image-upload>\n </dx-html-editor>\n </div>\n </div>\n\n\n <div class=\"flex flex-row w-full\">\n <div class=\"m-1 w-full\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\"> Parent Component </p>\n <dx-select-box [items]=\"keiParentDataSource\" displayExpr=\"kpiName\" valueExpr=\"kpiId\"\n (onValueChanged)=\"getKpiItemValue($event)\" [(ngModel)]=\"parante_kpi_name\"></dx-select-box>\n </div>\n </div>\n <div class=\"m-1 w-full\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">Parent TID</p>\n <dx-text-box [(ngModel)]=\"selected_kpi_tid\" [readOnly]=\"false\"></dx-text-box>\n </div>\n </div>\n <div class=\"m-1 w-full\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">TID</p>\n <dx-text-box [(ngModel)]=\"selected_kpi_child_tid\" [readOnly]=\"false\"></dx-text-box>\n </div>\n </div>\n </div>\n\n <div class=\"flex flex-row justify-between mt-3\">\n <div class=\"px-2 pt-1 w-full\">\n <dx-check-box [(ngModel)]=\"kpi_visibility\" text=\"Visibility\"></dx-check-box>\n </div>\n <div class=\"px-2 pt-1 w-full\">\n <dx-check-box [(ngModel)]=\"kpi_external\" text=\"External KPI\"></dx-check-box>\n </div>\n </div>\n <!-- <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">KPI Info</p>\n <dx-html-editor height=\"'auto'\" [(ngModel)]=\"selected_info\">\n <dxo-toolbar [multiline]=\"false\">\n\n <dxi-item name=\"size\"\n [acceptedValues]=\"['8pt', '10pt', '12pt', '14pt', '18pt', '24pt', '36pt']\"\n [options]=\"{ inputAttr: { 'aria-label': 'Font size' } }\"></dxi-item>\n <dxi-item name=\"font\" [acceptedValues]=\"[\n 'Arial',\n 'Courier New',\n 'Georgia',\n 'Impact',\n 'Lucida Console',\n 'Tahoma',\n 'Times New Roman',\n 'Verdana'\n ]\"\n [options]=\"{ inputAttr: { 'aria-label': 'Font family' } }\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"bold\"></dxi-item>\n <dxi-item name=\"italic\"></dxi-item>\n <dxi-item name=\"underline\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"alignLeft\"></dxi-item>\n <dxi-item name=\"alignCenter\"></dxi-item>\n <dxi-item name=\"alignRight\"></dxi-item>\n <dxi-item name=\"alignJustify\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"orderedList\"></dxi-item>\n <dxi-item name=\"bulletList\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"header\" [acceptedValues]=\"[false, 1, 2, 3, 4, 5]\"\n [options]=\"{ inputAttr: { 'aria-label': 'Header' } }\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"color\"></dxi-item>\n <dxi-item name=\"background\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"link\"></dxi-item>\n <dxi-item name=\"image\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"clear\"></dxi-item>\n <dxi-item name=\"codeBlock\"></dxi-item>\n </dxo-toolbar>\n <dxo-media-resizing [enabled]=\"true\"> </dxo-media-resizing>\n <dxo-image-upload [tabs]=\"['file', 'url']\" fileUploadMode=\"base64\">\n </dxo-image-upload>\n </dx-html-editor>\n </div>\n </div> -->\n\n <app-user-access [(userOptionContainer)]=\"userOptionContainer\">\n </app-user-access>\n\n <div class=\"flex flex-auto mt-5 justify-end\">\n <button class=\"{{commonService.btn_success_md}}\" (click)=\"getUpdateKpi()\" *ngIf=\"isEditKpiAdded\">Update KPI\n </button>\n <button class=\"{{commonService.btn_danger_md}}\" (click)=\"getDeletKpi()\" *ngIf=\"isEditKpiAdded\">Delete KPI\n </button>\n <button class=\"{{commonService.btn_success_md}}\" (click)=\"makeNewKpiWithUserEntity()\" *ngIf=\"!isEditKpiAdded\">Create KPI\n </button>\n <button class=\"{{commonService.btn_warning_md}}\" (click)=\"getReseteKpi()\">Reset</button>\n\n </div>\n <!-- </div> -->\n <!-- </ng-container> -->\n </div>\n\n\n\n\n</div>", styles: [":host ::ng-deep treeview .treeview-wrapper{width:100%!important}\n"] }]
413
+ args: [{ selector: 'app-create-kpi', template: "<app-loading *ngIf=\"loadingModal\"></app-loading>\n<div class=\"p-4 flex flex-row w-full\">\n <div class=\"mx-2 bg-white dark:bg-transparent border-r\">\n\n <treeview class=\"dark bg-gray-900 dark:bg-transparent\" [name]=\"'mainNavigation'\" [routeKey]=\"'raKpi'\"\n [navigation]=\"kpiData\" [isSearchBox]=\"false\" [isEditIcon]=\"true\" (editableKpiData)=\"getEditableKpi($event)\">\n </treeview>\n </div>\n <div class=\"mx-2 w-full\">\n <div class=\"flex flex-row item-center justify-center my-8\">\n <button class=\"{{commonService.btn_warning_md}}\" (click)=\"addNewKpi()\">Add New KPI</button>\n <button class=\"{{commonService.btn_primary_md}}\" (click)=\"routeToKpiConfig()\"\n routerLinkActive=\"router-link-active\">Configure KPI</button>\n </div>\n <ng-container *ngIf=\"isNewKpiAdded\">\n <div class=\"px-2 w-full\">\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">Name</p>\n <dx-text-box [(ngModel)]=\"select_kpi_name\"></dx-text-box>\n </div>\n </div>\n\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\"> Tag Type</p>\n <dx-select-box [dataSource]=\"tagType\" [(ngModel)]=\"select_tag_type\"\n (onValueChanged)=\"addTagtypeValue($event)\"></dx-select-box>\n </div>\n </div>\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">ID</p>\n <dx-text-box [(ngModel)]=\"selected_id\"></dx-text-box>\n </div>\n </div>\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">Page ID</p>\n <!-- <dx-text-box [(ngModel)]=\"selected_page_id\"></dx-text-box> -->\n <dx-select-box [items]=\"templateDataSource\" valueExpr=\"pageId\" displayExpr=\"pageName\" [searchEnabled]=\"true\"\n [(ngModel)]=\"selected_page_id\"></dx-select-box>\n </div>\n </div>\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">Description</p>\n <dx-html-editor height=\"'auto'\" [(ngModel)]=\"selected_desc\">\n <dxo-toolbar [multiline]=\"false\">\n\n <dxi-item name=\"size\"\n [acceptedValues]=\"['8pt', '10pt', '12pt', '14pt', '18pt', '24pt', '36pt']\"\n [options]=\"{ inputAttr: { 'aria-label': 'Font size' } }\"></dxi-item>\n <dxi-item name=\"font\" [acceptedValues]=\"[\n 'Arial',\n 'Courier New',\n 'Georgia',\n 'Impact',\n 'Lucida Console',\n 'Tahoma',\n 'Times New Roman',\n 'Verdana'\n ]\" [options]=\"{ inputAttr: { 'aria-label': 'Font family' } }\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"bold\"></dxi-item>\n <dxi-item name=\"italic\"></dxi-item>\n <dxi-item name=\"underline\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"alignLeft\"></dxi-item>\n <dxi-item name=\"alignCenter\"></dxi-item>\n <dxi-item name=\"alignRight\"></dxi-item>\n <dxi-item name=\"alignJustify\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"orderedList\"></dxi-item>\n <dxi-item name=\"bulletList\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"header\" [acceptedValues]=\"[false, 1, 2, 3, 4, 5]\"\n [options]=\"{ inputAttr: { 'aria-label': 'Header' } }\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"color\"></dxi-item>\n <dxi-item name=\"background\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"link\"></dxi-item>\n <dxi-item name=\"image\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"clear\"></dxi-item>\n <dxi-item name=\"codeBlock\"></dxi-item>\n </dxo-toolbar>\n <dxo-media-resizing [enabled]=\"true\"> </dxo-media-resizing>\n <dxo-image-upload [tabs]=\"['file', 'url']\" fileUploadMode=\"base64\">\n </dxo-image-upload>\n </dx-html-editor>\n </div>\n </div>\n\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\"> Parent Component </p>\n <dx-select-box [dataSource]=\"keiParentDataSource\" displayExpr=\"name\" valueExpr=\"tid\"\n (onValueChanged)=\"getKpiItemValue($event)\" [value]=\"parante_kpi_name\"></dx-select-box>\n </div>\n </div>\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">TID</p>\n <dx-text-box [(ngModel)]=\"selected_kpi_tid\" [readOnly]=\"true\"></dx-text-box>\n </div>\n </div>\n <div class=\"flex flex-row justify-between mt-3\">\n <div class=\"px-2 pt-1 w-full\">\n <dx-check-box [(ngModel)]=\"kpi_visibility\" text=\"Visibility\"></dx-check-box>\n </div>\n <div class=\"px-2 pt-1 w-full\">\n <dx-check-box [(ngModel)]=\"kpi_external\" text=\"External KPI\"></dx-check-box>\n </div>\n </div>\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">KPI Info</p>\n <dx-html-editor height=\"'auto'\" [(ngModel)]=\"selected_info\">\n <dxo-toolbar [multiline]=\"false\">\n\n <dxi-item name=\"size\"\n [acceptedValues]=\"['8pt', '10pt', '12pt', '14pt', '18pt', '24pt', '36pt']\"\n [options]=\"{ inputAttr: { 'aria-label': 'Font size' } }\"></dxi-item>\n <dxi-item name=\"font\" [acceptedValues]=\"[\n 'Arial',\n 'Courier New',\n 'Georgia',\n 'Impact',\n 'Lucida Console',\n 'Tahoma',\n 'Times New Roman',\n 'Verdana'\n ]\"\n [options]=\"{ inputAttr: { 'aria-label': 'Font family' } }\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"bold\"></dxi-item>\n <dxi-item name=\"italic\"></dxi-item>\n <dxi-item name=\"underline\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"alignLeft\"></dxi-item>\n <dxi-item name=\"alignCenter\"></dxi-item>\n <dxi-item name=\"alignRight\"></dxi-item>\n <dxi-item name=\"alignJustify\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"orderedList\"></dxi-item>\n <dxi-item name=\"bulletList\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"header\" [acceptedValues]=\"[false, 1, 2, 3, 4, 5]\"\n [options]=\"{ inputAttr: { 'aria-label': 'Header' } }\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"color\"></dxi-item>\n <dxi-item name=\"background\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"link\"></dxi-item>\n <dxi-item name=\"image\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"clear\"></dxi-item>\n <dxi-item name=\"codeBlock\"></dxi-item>\n </dxo-toolbar>\n <dxo-media-resizing [enabled]=\"true\"> </dxo-media-resizing>\n <dxo-image-upload [tabs]=\"['file', 'url']\" fileUploadMode=\"base64\">\n </dxo-image-upload>\n </dx-html-editor>\n </div>\n </div>\n\n <app-user-access [(userOptionContainer)]=\"userOptionContainer\">\n </app-user-access>\n\n <div class=\"flex flex-auto mt-5 justify-end\">\n <button class=\"{{commonService.btn_primary_md}}\" (click)=\"makeNewKpi()\">Create\n </button>\n <button class=\"{{commonService.btn_primary_md}}\" (click)=\"makeNewKpiWithUserEntity()\">Create With User Privilege\n </button>\n <button class=\"{{commonService.btn_warning_md}}\" (click)=\"getReseteKpi()\">Reset</button>\n\n </div>\n </div>\n </ng-container>\n <ng-container *ngIf=\"isEditKpiAdded\">\n <div class=\"px-2 w-full\">\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mb-2\">Name</p>\n <dx-text-box [(ngModel)]=\"editable_kpi_name\"></dx-text-box>\n </div>\n </div>\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\"> Tag Type</p>\n <dx-select-box [dataSource]=\"tagType\" [(ngModel)]=\"editable_tag_type\"\n (onValueChanged)=\"addTagtypeValue($event)\" [readOnly]=\"isFromEditable\"></dx-select-box>\n </div>\n </div>\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">ID</p>\n <dx-text-box [(ngModel)]=\"editable_id\"></dx-text-box>\n </div>\n </div>\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">Page ID</p>\n <!-- <dx-text-box [(ngModel)]=\"editable_page_id\"></dx-text-box> -->\n <dx-select-box [items]=\"templateDataSource\" valueExpr=\"pageId\" displayExpr=\"pageName\" [searchEnabled]=\"true\"\n [(ngModel)]=\"editable_page_id\"></dx-select-box>\n\n </div>\n </div>\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">Description</p>\n <dx-html-editor height=\"'auto'\" [(ngModel)]=\"editable_desc\">\n <dxo-toolbar [multiline]=\"true\">\n <dxi-item name=\"undo\"></dxi-item>\n <dxi-item name=\"redo\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"size\"\n [acceptedValues]=\"['8pt', '10pt', '12pt', '14pt', '18pt', '24pt', '36pt']\"\n [options]=\"{ inputAttr: { 'aria-label': 'Font size' } }\"></dxi-item>\n <dxi-item name=\"font\" [acceptedValues]=\"[\n 'Arial',\n 'Courier New',\n 'Georgia',\n 'Impact',\n 'Lucida Console',\n 'Tahoma',\n 'Times New Roman',\n 'Verdana'\n ]\"\n [options]=\"{ inputAttr: { 'aria-label': 'Font family' } }\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"bold\"></dxi-item>\n <dxi-item name=\"italic\"></dxi-item>\n <dxi-item name=\"underline\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"alignLeft\"></dxi-item>\n <dxi-item name=\"alignCenter\"></dxi-item>\n <dxi-item name=\"alignRight\"></dxi-item>\n <dxi-item name=\"alignJustify\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"orderedList\"></dxi-item>\n <dxi-item name=\"bulletList\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"header\" [acceptedValues]=\"[false, 1, 2, 3, 4, 5]\"\n [options]=\"{ inputAttr: { 'aria-label': 'Header' } }\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"color\"></dxi-item>\n <dxi-item name=\"background\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"link\"></dxi-item>\n <dxi-item name=\"image\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"clear\"></dxi-item>\n <dxi-item name=\"blockquote\"></dxi-item>\n\n </dxo-toolbar>\n <dxo-media-resizing [enabled]=\"true\"> </dxo-media-resizing>\n <dxo-image-upload [tabs]=\"['file', 'url']\" fileUploadMode=\"base64\">\n </dxo-image-upload>\n </dx-html-editor>\n </div>\n </div>\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\"> Parent Component </p>\n <dx-select-box [searchEnabled]=\"true\" [readOnly]=\"editable_tag_type == 'parent'\"\n [dataSource]=\"keiParentDataSource\" displayExpr=\"name\" valueExpr=\"tid\"\n (onValueChanged)=\"getNewParrentKpiItemValue($event)\"\n [value]=\"parante_kpi_name\"></dx-select-box>\n </div>\n </div>\n\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">TID</p>\n <dx-text-box [(ngModel)]=\"editable_kpi_tid\" [readOnly]=\"false\"></dx-text-box>\n </div>\n </div>\n <div class=\"flex flex-row justify-between mt-3\">\n\n <div class=\"px-2 pt-1 w-full\">\n <dx-check-box [(ngModel)]=\"kpi_visibility\" text=\"Visibility\"></dx-check-box>\n </div>\n\n <div class=\"px-2 pt-1 w-full\">\n <dx-check-box [(ngModel)]=\"kpi_external\" text=\"External KPI\"></dx-check-box>\n </div>\n </div>\n <div class=\"m-1\">\n <div class=\"px-2 pt-1 w-full\">\n <p class=\"text-lg mt-2\">KPI Info</p>\n <dx-html-editor height=\"'auto'\" [(ngModel)]=\"editable_info\">\n <dxo-toolbar [multiline]=\"false\">\n\n <dxi-item name=\"size\"\n [acceptedValues]=\"['8pt', '10pt', '12pt', '14pt', '18pt', '24pt', '36pt']\"\n [options]=\"{ inputAttr: { 'aria-label': 'Font size' } }\"></dxi-item>\n <dxi-item name=\"font\" [acceptedValues]=\"[\n 'Arial',\n 'Courier New',\n 'Georgia',\n 'Impact',\n 'Lucida Console',\n 'Tahoma',\n 'Times New Roman',\n 'Verdana'\n ]\"\n [options]=\"{ inputAttr: { 'aria-label': 'Font family' } }\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"bold\"></dxi-item>\n <dxi-item name=\"italic\"></dxi-item>\n <dxi-item name=\"underline\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"alignLeft\"></dxi-item>\n <dxi-item name=\"alignCenter\"></dxi-item>\n <dxi-item name=\"alignRight\"></dxi-item>\n <dxi-item name=\"alignJustify\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"orderedList\"></dxi-item>\n <dxi-item name=\"bulletList\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"header\" [acceptedValues]=\"[false, 1, 2, 3, 4, 5]\"\n [options]=\"{ inputAttr: { 'aria-label': 'Header' } }\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"color\"></dxi-item>\n <dxi-item name=\"background\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"link\"></dxi-item>\n <dxi-item name=\"image\"></dxi-item>\n <dxi-item name=\"separator\"></dxi-item>\n <dxi-item name=\"clear\"></dxi-item>\n <dxi-item name=\"codeBlock\"></dxi-item>\n </dxo-toolbar>\n <dxo-media-resizing [enabled]=\"true\"> </dxo-media-resizing>\n <dxo-image-upload [tabs]=\"['file', 'url']\" fileUploadMode=\"base64\">\n </dxo-image-upload>\n </dx-html-editor>\n </div>\n </div>\n <div class=\"flex flex-auto mt-3 justify-end\">\n <button class=\"{{commonService.btn_primary_md}}\" (click)=\"getUpdateKpi()\">Update\n </button>\n <button class=\"{{commonService.btn_danger_md}}\" (click)=\"getDeleteKpi()\">Delete\n </button>\n <!-- <button class=\"{{commonService.btn_danger_md}}\" (click)=\"cancelUpdate()\">Cancle</button> -->\n\n </div>\n </div>\n </ng-container>\n </div>\n\n\n\n\n</div>", styles: [":host ::ng-deep treeview .treeview-wrapper{width:100%!important}\n"] }]
292
414
  }], ctorParameters: function () { return [{ type: i1.CommonService }, { type: i2.FormBuilder }, { type: i3.CreateKpIService }, { type: i4.ToastrService }, { type: i5.Router }]; } });
293
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-kpi-tree.component.js","sourceRoot":"","sources":["../../../../../../projects/gamma-app-controller/src/lib/template-module/KpiCreationModule/create-kpi-tree.component.ts","../../../../../../projects/gamma-app-controller/src/lib/template-module/KpiCreationModule/create-kpi-tree.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit } from '@angular/core';\nimport { FormBuilder, FormGroup, FormArray, FormControl } from '@angular/forms';\nimport { ToastrService } from 'ngx-toastr';\nimport { Router, RouterModule } from '@angular/router';\nimport { CreateKpIService } from './createKpi.service';\nimport { CommonService } from '../../application-controller/common';\n\n\n@Component({\n  selector: 'app-create-kpi',\n  templateUrl: './create-kpi-tree.component.html',\n  styleUrls: ['./create-kpi-tree.component.scss']\n})\nexport class CreateKpiTreeComponent implements OnInit {\n  loadingModal: boolean = true;\n  keiParentDataSource: any = [];\n  myForm: FormGroup;\n  tagType = [\"parent\", \"child\"];\n  kpi_constructor = [];\n  selected_p_kpi: any = {};\n\n  select_kpi_name: any;\n  select_tag_type: any;\n  selected_id: any;\n  selected_page_id: any;\n  selected_nested_name: any;\n  selected_kpi_tid: any;\n  selected_desc: any;\n  selected_info: any;\n\n  height = 90;\n  kpiData: any = [];\n  heistValue: any;\n  isFromEditable: boolean = false;\n  isNewKpiAdded: boolean = false;\n  isEditKpiAdded: boolean = false;\n\n  editable_desc = \"\";\n  editable_info = \"\";\n  editable_id;\n  editable_page_id;\n  editable_tag_type;\n  editable_kpi_name;\n  editable_kpi_tid;\n  selected_kpi_child_tid;\n  kpi_visibility: boolean = false;\n  kpi_external: boolean = false;\n  parante_kpi_name: any;\n  isComponentUpdata: boolean = false;\n  templateDataSource: any;\n  // kpiDataJson:any;\n  userOptionContainer: any = [];\n\n  selected_aliases: any = [];\n  isKpiTreePrepared: boolean = false;\n\n  kpiConfigDataSource: any = [];\n\n  constructor(\n    public commonService: CommonService, private formBuilder: FormBuilder,\n    private service: CreateKpIService, private toastr: ToastrService,\n    private router: Router) {\n\n  }\n\n  ngOnInit() {\n\n    this.getAllKpiData();\n    this.getAppPageConfigs();\n  }\n\n  getAppPageConfigs() {\n    this.service.getAppPageConfigs().subscribe({\n      next: (data: any) => {\n        this.templateDataSource = data;\n      }, error: (err: any) => {\n        this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'Page ID')\n\n      }\n    })\n  }\n\n  getAllKpiData() {\n\n    this.keiParentDataSource = [];\n    this.service.listKpiEntryConfigs().subscribe((data: any) => {\n      const userName = \"admin\";\n      this.kpiConfigDataSource = data;\n      this.kpiData = this.buildMenuTree(userName, data);\n      this.loadingModal = false;\n      //  this.keiParentDataSource = data;\n      this.prepareParentDataSource(data)\n\n    }, err => {\n      this.loadingModal = false;\n      this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'KPI Config')\n    })\n  }\n\n  prepareParentDataSource(data) {\n    data.forEach((result: any) => {\n      if (result.tagType == 'parent') {\n        // const tidKey = data.tagType === 'child' ? 'childTid' : 'parentTid';\n        //  let node = {\n        //   \"kpiName\": result.kpiName,\n        //   \"tid\": result[tidKey],\n        //   \"kpiId\": result.kpiId\n        // }\n        this.keiParentDataSource.push(result);\n      }\n    });\n  }\n\n\n  makeNewKpiWithUserEntity() {\n    const pageData = (this.selected_page_id) ? this.templateDataSource.find((item: any) => item.pageId === this.selected_page_id) : null;\n\n    let kpiObj = {\n      \"kpiId\": this.selected_id,\n      \"kpiName\": this.select_kpi_name,\n      \"aliases\": this.selected_aliases,\n      \"pageId\": this.selected_page_id,\n      \"description\": this.selected_desc,\n      \"kpiInfo\": \"\",\n      \"tagType\": this.select_tag_type,\n      \"active\": true,\n      \"visibility\": this.kpi_visibility,\n      \"externalKpi\": this.kpi_external,\n      \"target\": \"\",\n      \"icon\": \"\",\n      \"url\": pageData ? pageData.pageUrl : \"\",\n      \"kpiType\": this.select_tag_type == \"parent\" ? \"collapsable\" : \"basic\",\n      \"parentTid\": this.selected_kpi_tid,\n      \"childTid\": this.selected_kpi_child_tid,\n      \"permissions\": this.userOptionContainer,\n    }\n\n    this.service.createKpiEntryConfig(kpiObj).subscribe(data => {\n      this.toastr.success('KPI Created Successfully')\n      this.getAllKpiData();\n      this.getReseteKpi();\n    }, err => {\n      this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'KPI Config')\n    })\n\n    console.log(\"KPI with User Entity Obj:\", kpiObj);\n  }\n\n  getEditableKpi(kpi: any) {\n\n    const data = this.kpiConfigDataSource.find((item: any) => item.kpiId === kpi.id);\n\n    // const parentName = this.keiParentDataSource.find((item: any) => item.parentTid == data[\"parentTid\"]);\n\n\n    const tidKey = data.tagType === 'child' && data.childTid && data.childTid.length > 3 ? 'childTid' : 'parentTid';\n    const parentName = this.keiParentDataSource.find(\n      (item: any) => item[tidKey] == data[\"parentTid\"]\n    );\n    this.parante_kpi_name = parentName ? parentName['kpiId'] : null;\n\n\n    this.selected_id = data[\"kpiId\"];\n    this.select_kpi_name = data[\"kpiName\"];\n    this.selected_aliases = data[\"aliases\"];\n    this.selected_page_id = data[\"pageId\"];\n    this.selected_desc = data[\"description\"];\n    this.select_tag_type = data[\"tagType\"];\n    this.kpi_visibility = data[\"visibility\"];\n    this.kpi_external = data[\"externalKpi\"];\n    this.selected_kpi_tid = data[\"parentTid\"];\n    this.selected_kpi_child_tid = data[\"childTid\"];\n    this.userOptionContainer = (data[\"permissions\"] && data[\"permissions\"].length > 0) ? data[\"permissions\"] : [];\n    this.isEditKpiAdded = true;\n\n  }\n\n  getUpdateKpi() {\n    const pageData = (this.selected_page_id) ? this.templateDataSource.find((item: any) => item.pageId === this.selected_page_id) : null;\n\n    let kpiObj = {\n      \"kpiId\": this.selected_id,\n      \"kpiName\": this.select_kpi_name,\n      \"aliases\": this.selected_aliases,\n      \"pageId\": this.selected_page_id,\n      \"description\": this.selected_desc,\n      \"kpiInfo\": \"\",\n      \"tagType\": this.select_tag_type,\n      \"active\": true,\n      \"visibility\": this.kpi_visibility,\n      \"externalKpi\": this.kpi_external,\n      \"target\": \"\",\n      \"icon\": \"\",\n      \"url\": pageData ? pageData.pageUrl : \"\",\n      \"kpiType\": this.select_tag_type == \"parent\" ? \"collapsable\" : \"basic\",\n      \"parentTid\": this.selected_kpi_tid,\n      \"childTid\": this.selected_kpi_child_tid,\n      \"permissions\": this.userOptionContainer,\n    }\n\n    this.service.updateKpiEntryConfig(kpiObj).subscribe(data => {\n      this.toastr.success('KPI Updated Successfully')\n      this.getAllKpiData();\n      this.getReseteKpi();\n      this.isEditKpiAdded = false;\n\n    }, err => {\n      this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'KPI Config')\n    })\n\n    console.log(\"KPI with User Entity Obj:\", kpiObj);\n  }\n\n  onCustomDimentionCreating(args) {\n    const newValue = args.text;\n    args.customItem = newValue;\n    const isItemInDataSource = this.selected_aliases.some((item) => item === newValue);\n    if (!isItemInDataSource) {\n      this.selected_aliases.unshift(newValue);\n    }\n  }\n\n\n\n  getReseteKpi() {\n    this.select_kpi_name = '';\n    this.select_tag_type = '';\n    this.selected_id = '';\n    this.selected_page_id = '';\n    this.selected_kpi_tid = '';\n    this.selected_desc = '';\n    this.parante_kpi_name = '';\n    this.editable_kpi_name = '';\n    this.editable_tag_type = '';\n    this.editable_id = '';\n    this.editable_page_id = '';\n    this.editable_kpi_tid = '';\n    this.editable_desc = '';\n    this.editable_info = '';\n    this.parante_kpi_name = '';\n    this.selected_kpi_child_tid = '';\n    this.selected_aliases = [];\n    this.kpi_external = false;\n    this.kpi_visibility = false;\n    this.isComponentUpdata = false;\n    this.isEditKpiAdded = false;\n  }\n\n\n  addTagtypeValue(e) {\n    this.select_tag_type = e.value;\n  }\n\n  getKpiItemValue(e) {\n    if (e.event) {\n      const kpi_data = this.keiParentDataSource.find((item: any) => item.kpiId === e.value);\n      if (this.isEditKpiAdded) {\n        const tidKey = this.select_tag_type === 'child' && this.isEditKpiAdded ? 'childTid' : 'parentTid';\n        this.selected_kpi_tid = kpi_data[tidKey];\n        // this.selected_kpi_child_tid = this.getNextChildTid(this.selected_kpi_tid, this.kpiConfigDataSource);\n\n      } else {\n\n        const tidKey = kpi_data.childTid && kpi_data.childTid.length > 1 ? 'childTid' : 'parentTid';\n        this.selected_kpi_tid = kpi_data[tidKey];\n        this.selected_kpi_child_tid = this.getNextChildTid(this.selected_kpi_tid, this.kpiConfigDataSource);\n\n      }\n\n     \n\n    }\n\n  }\n\n   getNextChildTid(parentTid: string, kpiConfigDataSource: any[]): string {\n        // 1. Filter by parentTid\n        const children = kpiConfigDataSource.filter(\n          item => item.parentTid === parentTid && item.childTid\n        );\n\n        // 2. Extract last numeric part of childTid\n        const maxChildNumber = children.reduce((max, item) => {\n          const parts = item.childTid.split('.');\n          const lastNumber = Number(parts[parts.length - 1]);\n          return lastNumber > max ? lastNumber : max;\n        }, 0);\n\n        // 3. Return next childTid\n        return `${parentTid}.${maxChildNumber + 1}`;\n      }\n\n\n  addNewKpi() {\n    this.isNewKpiAdded = true;\n    this.isEditKpiAdded = false;\n  }\n  cancelUpdate() {\n    this.isEditKpiAdded = false;\n  }\n\n\n\n  getKpiParrentName(input) {\n    const lastIndex = input.lastIndexOf('.');\n    if (lastIndex === -1) {\n      return input;\n    }\n    return input.substring(0, lastIndex);\n  }\n\n\n  getDeletKpi() {\n    this.service.deleteKpiEntryConfig(this.selected_id).subscribe(data => {\n      this.toastr.success('KPI Deleted Successfully')\n      this.getAllKpiData();\n      this.getReseteKpi();\n    }, err => {\n      this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'KPI Config')\n    })\n  }\n\n\n  reseteUpdateKpiForm() {\n    this.editable_desc = undefined;\n    this.editable_info = undefined;\n    this.editable_kpi_name = undefined;\n    this.editable_tag_type = undefined;\n    this.editable_kpi_tid = undefined;\n    this.editable_id = undefined;\n    this.editable_page_id = undefined;\n  }\n\n  submitNewKpi() {\n    this.loadingModal = true;\n    this.isEditKpiAdded = false;\n    let obj = { kpiConfigData: this.kpiData }\n    console.log(obj);\n    this.isComponentUpdata = false;\n    this.service.getCreateKpi(obj).subscribe(data => {\n      this.getAllKpiData();\n      this.getReseteKpi();\n    })\n  }\n\n\n  buildMenuTree(userName: string, kpiData: any[]): any[] {\n    // let filteredMenus = menuData.filter(menu =>\n    //   !userName || (menu.permissions && menu.permissions.some(perm => perm.entityValues.includes(userName)))\n    // );\n\n    let filteredMenus = kpiData;\n\n    const menuMap = new Map();\n    const menuTree: any[] = [];\n\n    filteredMenus.forEach(menu => {\n      menuMap.set(menu.childTid || menu.parentTid, {\n        id: menu.kpiId,\n        title: menu.kpiName,\n        icon: menu.icon,\n        type: menu.kpiType,\n        tagType: menu.tagType,\n        visibility: true,\n        ...(menu.link && { link: menu.link.replace(/^\\/+/, '') }),\n        children: []\n      });\n    });\n\n    filteredMenus.forEach(kpi => {\n      if (kpi.parentTid && kpi.childTid) {\n        const parent = menuMap.get(kpi.parentTid);\n        if (parent) {\n          parent.children.push(menuMap.get(kpi.childTid));\n        }\n      } else {\n        menuTree.push(menuMap.get(kpi.parentTid));\n      }\n    });\n\n    return menuTree;\n  }\n\n}\n","<app-loading *ngIf=\"loadingModal\"></app-loading>\n<div class=\"p-4 flex flex-row w-full\" *ngIf=\"!loadingModal\">\n    <div class=\"mx-2 bg-white dark:bg-transparent border-r\">\n        <!-- <ng-container *ngIf=\"isKpiTreePrepared\"> -->\n            <treeview class=\"dark bg-gray-900 dark:bg-transparent\" [name]=\"'mainNavigation'\" [routeKey]=\"'raKpi'\"\n                [navigation]=\"kpiData\" [isSearchBox]=\"false\" [isEditIcon]=\"true\"\n                (editableKpiData)=\"getEditableKpi($event)\">\n            </treeview>\n        <!-- </ng-container> -->\n\n    </div>\n    <div class=\"mx-2 w-full\">\n        <!-- <div class=\"flex flex-row item-center justify-center my-8\">\n            <button class=\"{{commonService.btn_warning_md}}\" (click)=\"addNewKpi()\">Add New KPI</button>\n            <button class=\"{{commonService.btn_primary_md}}\" (click)=\"routeToKpiConfig()\"\n                routerLinkActive=\"router-link-active\">Configure KPI</button>\n        </div> -->\n        <!-- <ng-container *ngIf=\"isNewKpiAdded\"> -->\n        <!-- <div class=\"px-2 w-full\"> -->\n        <div class=\"m-1\">\n            <div class=\"px-2 pt-1 w-full\">\n                <p class=\"text-lg mt-2\">Name</p>\n                <dx-text-box [(ngModel)]=\"select_kpi_name\"></dx-text-box>\n            </div>\n        </div>\n        <div class=\"flex flex-row w-full\">\n            <div class=\"m-1 w-1/3\">\n                <div class=\"px-2 pt-1  w-full\">\n                    <p class=\"text-lg mt-2\"> Tag Type</p>\n                    <dx-select-box [dataSource]=\"tagType\" [(ngModel)]=\"select_tag_type\"\n                        (onValueChanged)=\"addTagtypeValue($event)\"></dx-select-box>\n                </div>\n            </div>\n            <!-- (onCustomItemCreating)=\"onCustomDimentionCreating($event)\" -->\n            <div class=\"m-1 w-full\">\n                <div class=\"px-2 pt-1  w-full\">\n                    <p class=\"text-lg mt-2\">Aliases</p>\n                    <dx-tag-box [acceptCustomValue]=\"true\" [(ngModel)]=\"selected_aliases\"></dx-tag-box>\n                </div>\n            </div>\n        </div>\n        <div class=\"m-1\">\n            <div class=\"px-2 pt-1  w-full\">\n                <p class=\"text-lg mt-2\">Page ID</p>\n                <!-- <dx-text-box [(ngModel)]=\"selected_page_id\"></dx-text-box> -->\n                <dx-select-box [items]=\"templateDataSource\" valueExpr=\"pageId\" displayExpr=\"pageName\"\n                    [searchEnabled]=\"true\" [(ngModel)]=\"selected_page_id\"></dx-select-box>\n            </div>\n        </div>\n        <div class=\"m-1\">\n            <div class=\"px-2 pt-1  w-full\">\n                <p class=\"text-lg mt-2\">Description</p>\n                <dx-html-editor height=\"'auto'\" [(ngModel)]=\"selected_desc\">\n                    <dxo-toolbar [multiline]=\"false\">\n\n                        <dxi-item name=\"size\" [acceptedValues]=\"['8pt', '10pt', '12pt', '14pt', '18pt', '24pt', '36pt']\"\n                            [options]=\"{ inputAttr: { 'aria-label': 'Font size' } }\"></dxi-item>\n                        <dxi-item name=\"font\" [acceptedValues]=\"[\n                                    'Arial',\n                                    'Courier New',\n                                    'Georgia',\n                                    'Impact',\n                                    'Lucida Console',\n                                    'Tahoma',\n                                    'Times New Roman',\n                                    'Verdana'\n                                  ]\" [options]=\"{ inputAttr: { 'aria-label': 'Font family' } }\"></dxi-item>\n                        <dxi-item name=\"separator\"></dxi-item>\n                        <dxi-item name=\"bold\"></dxi-item>\n                        <dxi-item name=\"italic\"></dxi-item>\n                        <dxi-item name=\"underline\"></dxi-item>\n                        <dxi-item name=\"separator\"></dxi-item>\n                        <dxi-item name=\"alignLeft\"></dxi-item>\n                        <dxi-item name=\"alignCenter\"></dxi-item>\n                        <dxi-item name=\"alignRight\"></dxi-item>\n                        <dxi-item name=\"alignJustify\"></dxi-item>\n                        <dxi-item name=\"separator\"></dxi-item>\n                        <dxi-item name=\"orderedList\"></dxi-item>\n                        <dxi-item name=\"bulletList\"></dxi-item>\n                        <dxi-item name=\"separator\"></dxi-item>\n                        <dxi-item name=\"header\" [acceptedValues]=\"[false, 1, 2, 3, 4, 5]\"\n                            [options]=\"{ inputAttr: { 'aria-label': 'Header' } }\"></dxi-item>\n                        <dxi-item name=\"separator\"></dxi-item>\n                        <dxi-item name=\"color\"></dxi-item>\n                        <dxi-item name=\"background\"></dxi-item>\n                        <dxi-item name=\"separator\"></dxi-item>\n                        <dxi-item name=\"link\"></dxi-item>\n                        <dxi-item name=\"image\"></dxi-item>\n                        <dxi-item name=\"separator\"></dxi-item>\n                        <dxi-item name=\"clear\"></dxi-item>\n                        <dxi-item name=\"codeBlock\"></dxi-item>\n                    </dxo-toolbar>\n                    <dxo-media-resizing [enabled]=\"true\"> </dxo-media-resizing>\n                    <dxo-image-upload [tabs]=\"['file', 'url']\" fileUploadMode=\"base64\">\n                    </dxo-image-upload>\n                </dx-html-editor>\n            </div>\n        </div>\n\n\n        <div class=\"flex flex-row w-full\">\n            <div class=\"m-1 w-full\">\n                <div class=\"px-2 pt-1 w-full\">\n                    <p class=\"text-lg mt-2\"> Parent Component </p>\n                    <dx-select-box [items]=\"keiParentDataSource\" displayExpr=\"kpiName\" valueExpr=\"kpiId\"\n                        (onValueChanged)=\"getKpiItemValue($event)\" [(ngModel)]=\"parante_kpi_name\"></dx-select-box>\n                </div>\n            </div>\n            <div class=\"m-1 w-full\">\n                <div class=\"px-2 pt-1  w-full\">\n                    <p class=\"text-lg mt-2\">Parent TID</p>\n                    <dx-text-box [(ngModel)]=\"selected_kpi_tid\" [readOnly]=\"false\"></dx-text-box>\n                </div>\n            </div>\n            <div class=\"m-1 w-full\">\n                <div class=\"px-2 pt-1  w-full\">\n                    <p class=\"text-lg mt-2\">TID</p>\n                    <dx-text-box [(ngModel)]=\"selected_kpi_child_tid\" [readOnly]=\"false\"></dx-text-box>\n                </div>\n            </div>\n        </div>\n\n        <div class=\"flex flex-row justify-between mt-3\">\n            <div class=\"px-2 pt-1  w-full\">\n                <dx-check-box [(ngModel)]=\"kpi_visibility\" text=\"Visibility\"></dx-check-box>\n            </div>\n            <div class=\"px-2 pt-1  w-full\">\n                <dx-check-box [(ngModel)]=\"kpi_external\" text=\"External KPI\"></dx-check-box>\n            </div>\n        </div>\n        <!-- <div class=\"m-1\">\n                    <div class=\"px-2 pt-1  w-full\">\n                        <p class=\"text-lg mt-2\">KPI Info</p>\n                        <dx-html-editor height=\"'auto'\" [(ngModel)]=\"selected_info\">\n                            <dxo-toolbar [multiline]=\"false\">\n\n                                <dxi-item name=\"size\"\n                                    [acceptedValues]=\"['8pt', '10pt', '12pt', '14pt', '18pt', '24pt', '36pt']\"\n                                    [options]=\"{ inputAttr: { 'aria-label': 'Font size' } }\"></dxi-item>\n                                <dxi-item name=\"font\" [acceptedValues]=\"[\n                                                    'Arial',\n                                                    'Courier New',\n                                                    'Georgia',\n                                                    'Impact',\n                                                    'Lucida Console',\n                                                    'Tahoma',\n                                                    'Times New Roman',\n                                                    'Verdana'\n                                                  ]\"\n                                    [options]=\"{ inputAttr: { 'aria-label': 'Font family' } }\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"bold\"></dxi-item>\n                                <dxi-item name=\"italic\"></dxi-item>\n                                <dxi-item name=\"underline\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"alignLeft\"></dxi-item>\n                                <dxi-item name=\"alignCenter\"></dxi-item>\n                                <dxi-item name=\"alignRight\"></dxi-item>\n                                <dxi-item name=\"alignJustify\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"orderedList\"></dxi-item>\n                                <dxi-item name=\"bulletList\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"header\" [acceptedValues]=\"[false, 1, 2, 3, 4, 5]\"\n                                    [options]=\"{ inputAttr: { 'aria-label': 'Header' } }\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"color\"></dxi-item>\n                                <dxi-item name=\"background\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"link\"></dxi-item>\n                                <dxi-item name=\"image\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"clear\"></dxi-item>\n                                <dxi-item name=\"codeBlock\"></dxi-item>\n                            </dxo-toolbar>\n                            <dxo-media-resizing [enabled]=\"true\"> </dxo-media-resizing>\n                            <dxo-image-upload [tabs]=\"['file', 'url']\" fileUploadMode=\"base64\">\n                            </dxo-image-upload>\n                        </dx-html-editor>\n                    </div>\n                </div> -->\n\n        <app-user-access [(userOptionContainer)]=\"userOptionContainer\">\n        </app-user-access>\n\n        <div class=\"flex flex-auto mt-5 justify-end\">\n            <button class=\"{{commonService.btn_success_md}}\" (click)=\"getUpdateKpi()\" *ngIf=\"isEditKpiAdded\">Update KPI\n                    </button>\n            <button class=\"{{commonService.btn_danger_md}}\" (click)=\"getDeletKpi()\" *ngIf=\"isEditKpiAdded\">Delete KPI\n                    </button>\n            <button class=\"{{commonService.btn_success_md}}\" (click)=\"makeNewKpiWithUserEntity()\" *ngIf=\"!isEditKpiAdded\">Create KPI\n            </button>\n            <button class=\"{{commonService.btn_warning_md}}\" (click)=\"getReseteKpi()\">Reset</button>\n\n        </div>\n        <!-- </div> -->\n        <!-- </ng-container> -->\n    </div>\n\n\n\n\n</div>"]}
415
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-kpi-tree.component.js","sourceRoot":"","sources":["../../../../../../projects/gamma-app-controller/src/lib/template-module/KpiCreationModule/create-kpi-tree.component.ts","../../../../../../projects/gamma-app-controller/src/lib/template-module/KpiCreationModule/create-kpi-tree.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit } from '@angular/core';\nimport { FormBuilder, FormGroup, FormArray, FormControl } from '@angular/forms';\nimport { ToastrService } from 'ngx-toastr';\nimport { Router, RouterModule } from '@angular/router';\nimport { CreateKpIService } from './createKpi.service';\nimport { CommonService } from '../../application-controller/common';\n\n\n@Component({\n  selector: 'app-create-kpi',\n  templateUrl: './create-kpi-tree.component.html',\n  styleUrls: ['./create-kpi-tree.component.scss']\n})\nexport class CreateKpiTreeComponent implements OnInit {\n  loadingModal: boolean = true;\n  keiParentDataSource: any = [];\n  myForm: FormGroup;\n  tagType = [\"parent\", \"child\"];\n  kpi_constructor = [];\n  selected_p_kpi: any = {};\n\n  select_kpi_name: any;\n  select_tag_type: any;\n  selected_id: any;\n  selected_page_id: any;\n  selected_nested_name: any;\n  selected_kpi_tid: any;\n  selected_desc: any;\n  selected_info: any;\n\n  height = 90;\n  kpiData: any = [];\n  heistValue: any;\n  isFromEditable: boolean = false;\n  isNewKpiAdded: boolean = false;\n  isEditKpiAdded: boolean = false;\n\n  editable_desc = \"\";\n  editable_info = \"\";\n  editable_id;\n  editable_page_id;\n  editable_tag_type;\n  editable_kpi_name;\n  editable_kpi_tid;\n  kpi_visibility: boolean = false;\n  kpi_external: boolean = false;\n  parante_kpi_name: any;\n  isComponentUpdata: boolean = false;\n  templateDataSource: any;\n  // kpiDataJson:any;\n  userOptionContainer: any = [];\n\n  constructor(\n    public commonService: CommonService, private formBuilder: FormBuilder,\n    private service: CreateKpIService, private toastr: ToastrService,\n    private router: Router) {\n\n  }\n\n  ngOnInit() {\n\n    this.getAllKpiData();\n    this.getAppPageConfigs();\n  }\n\n  getAppPageConfigs() {\n    this.service.getAppPageConfigs().subscribe({\n      next: (data: any) => {\n        this.templateDataSource = data;\n      }, error: (err: any) => {\n        this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'Page ID')\n\n      }\n    })\n  }\n\n  getAllKpiData() {\n    this.loadingModal = false;\n\n    this.keiParentDataSource = [];\n    this.service.getlistKpiBrowser().subscribe((data: any) => {\n      this.kpiData = data\n      this.prepareParentDataSource(data)\n\n    }, err => {\n      this.loadingModal = false;\n      this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'KPI Config')\n    })\n  }\n\n  prepareParentDataSource(data) {\n    data.forEach((result: any) => {\n      if (result.tag_type == 'parent') {\n        let node = {\n          \"name\": result.name,\n          \"tid\": result.tid\n        }\n        this.keiParentDataSource.push(node);\n        this.prepareParentDataSource(result.nodes);\n      }\n    });\n\n\n\n  }\n\n\n  makeNewKpi() {\n\n    if (this.selected_kpi_tid !== undefined && this.selected_kpi_tid.length > 0) {\n      this.getHeistId(this.kpiData, this.selected_kpi_tid);\n      this.createNewKpiWithTid();\n    } else {\n\n      this.heistValue = (this.kpiData.length != 0) ? this.getHighestTid(this.kpiData) : 0;\n      let value = parseInt(this.heistValue) + 1;\n\n      let obj = {\n        \"name\": this.select_kpi_name,\n        \"tid\": value.toString(),\n        \"isBookmarked\": false,\n        \"isAccessible\": this.kpi_external,\n        \"lastAccessTime\": \"\",\n        \"tag_type\": this.select_tag_type,\n        \"id\": this.selected_id,\n        \"pageId\": this.selected_page_id,\n        \"desc\": this.selected_desc,\n        \"isVisible\": this.kpi_visibility,\n        \"nodes\": [],\n        \"config\": {}\n      }\n      this.kpiData.push(obj)\n      if (this.select_tag_type == 'parent') {\n        let obj = {\n          \"name\": this.select_kpi_name,\n          \"tid\": value.toString(),\n        }\n        this.keiParentDataSource.push(obj)\n      }\n      if (this.select_tag_type == 'child') {\n        let obj = {\n          \"name\": this.select_kpi_name,\n          \"id\": this.selected_id,\n          \"pageId\": this.selected_page_id,\n          \"searchFilter\": false,\n          \"isSrvTypeOperator\": false,\n          \"operationLevels\": [],\n          \"fixOperationLevles\": [],\n          \"api_config\": []\n\n        }\n        this.service.configureKpiBrowserConfig(obj).subscribe(data => {\n          console.log(\"kpi browser config created\")\n        })\n      }\n\n      this.submitNewKpi();\n\n    }\n\n  }\n\n  createNewKpiWithTid() {\n\n    let auto_tid = this.autoIncrement(this.selected_kpi_tid, this.heistValue);\n    let obj = {\n      \"name\": this.select_kpi_name,\n      \"tid\": auto_tid,\n      \"isBookmarked\": false,\n      \"isAccessible\": this.kpi_external,\n      \"lastAccessTime\": \"\",\n      \"tag_type\": this.select_tag_type,\n      \"id\": this.selected_id,\n      \"pageId\": this.selected_page_id,\n      \"desc\": this.selected_desc,\n      \"isVisible\": this.kpi_visibility,\n      \"nodes\": [],\n      \"config\": {}\n    }\n\n    if (this.select_tag_type == 'parent') {\n      let obj = {\n        \"name\": this.select_kpi_name,\n        \"tid\": auto_tid\n      }\n      this.keiParentDataSource.push(obj)\n    }\n    if (this.select_tag_type == 'child') {\n      let obj = {\n        \"name\": this.select_kpi_name,\n        \"id\": this.selected_id,\n        \"pageId\": this.selected_page_id,\n        \"searchFilter\": false,\n        \"isSrvTypeOperator\": false,\n        \"operationLevels\": [],\n        \"fixOperationLevles\": [],\n        \"api_config\": []\n\n      }\n      this.service.configureKpiBrowserConfig(obj).subscribe(data => {\n        console.log(\"kpi browser config created\")\n      })\n    }\n\n    this.setKpibyTid(this.kpiData, this.selected_kpi_tid, obj)\n    this.submitNewKpi();\n  }\n\n  getReseteKpi() {\n    this.select_kpi_name = '';\n    this.select_tag_type = '';\n    this.selected_id = '';\n    this.selected_page_id = '';\n    this.selected_kpi_tid = '';\n    this.selected_desc = '';\n    this.parante_kpi_name = '';\n    this.editable_kpi_name = '';\n    this.editable_tag_type = '';\n    this.editable_id = '';\n    this.editable_page_id = '';\n    this.editable_kpi_tid = '';\n    this.editable_desc = '';\n    this.editable_info = '';\n    this.parante_kpi_name = '';\n    this.kpi_external = false;\n    this.kpi_visibility = false;\n    this.isComponentUpdata = false;\n  }\n\n  getDeletKpi(tid) {\n    console.log(this.selected_p_kpi)\n\n  }\n\n  addTagtypeValue(e) {\n    this.select_tag_type = e.value;\n  }\n\n  getKpiItemValue(e) {\n    const kpi_data = this.keiParentDataSource.find((item: any) => item.tid === e.value);\n    this.selected_kpi_tid = kpi_data.tid;\n  }\n\n  autoIncrement(string1: string, string2: string | null): string {\n\n    if (string2 === null) {\n      const numberPart = string1 + '.1';\n      return numberPart;\n    } else {\n      const parts = string2.split('.');\n      let lastPart = parseInt(parts[parts.length - 1], 10);\n      let new_number = lastPart++;\n      parts[parts.length - 1] = lastPart.toString();\n      return parts.join(\".\");\n    }\n  }\n\n  setKpibyTid(data, tid, newKpiObj) {\n    data.forEach(result => {\n      if (result.nodes !== undefined) {\n        if (result.tid == tid) {\n\n          result.nodes.push(newKpiObj)\n        }\n        this.setKpibyTid(result.nodes, tid, newKpiObj);\n      }\n    });\n  }\n  getHeistId(data: any, tid: string): any {\n\n    data.forEach((result: any) => {\n      if (result.tid === tid) {\n        if (result.nodes.length > 0) {\n\n          this.heistValue = this.getHighestTid(result.nodes);\n        } else {\n          this.heistValue = null;\n        }\n      } else if (result.nodes !== undefined && result.nodes.length > 0) {\n        this.getHeistId(result.nodes, tid);\n      }\n    });\n\n\n  }\n\n  getHighestTid(data) {\n    const highestTid = data.reduce((maxTid, currentItem) => {\n      const currentTidParts = currentItem.tid.split('.').map(part => parseInt(part, 10));\n      const maxTidParts = maxTid.split('.').map(part => parseInt(part, 10));\n\n      for (let i = 0; i < currentTidParts.length; i++) {\n        if (currentTidParts[i] > maxTidParts[i]) {\n          return currentItem.tid;\n        } else if (currentTidParts[i] < maxTidParts[i]) {\n          return maxTid;\n        }\n      }\n      return maxTid;\n    }, data[0].tid);\n    return highestTid;\n  }\n\n  addNewKpi() {\n    this.isNewKpiAdded = true;\n    this.isEditKpiAdded = false;\n  }\n  cancelUpdate() {\n    this.isEditKpiAdded = false;\n  }\n\n  getEditableKpi(data: any) {\n    this.isComponentUpdata = false;\n    this.isEditKpiAdded = true;\n    this.isNewKpiAdded = false;\n    this.isFromEditable = true;\n    this.editable_desc = data.desc;\n    this.editable_info = (data.kpiInfo) ? data.kpiInfo : \"\";\n    this.editable_kpi_name = data.name;\n    this.editable_tag_type = data.tag_type;\n    this.editable_kpi_tid = data.tid;\n    this.editable_id = data.id;\n    this.editable_page_id = data.pageId;\n    this.kpi_visibility = data.isVisible;\n    this.kpi_external = data.isAccessible;\n    this.parante_kpi_name = this.getKpiParrentName(data.tid)\n\n\n  }\n\n  getKpiParrentName(input) {\n    const lastIndex = input.lastIndexOf('.');\n    if (lastIndex === -1) {\n      return input;\n    }\n    return input.substring(0, lastIndex);\n  }\n\n  getUpdateKpi() {\n\n    if (!this.isComponentUpdata) {\n      this.getUpdateKpiName(this.kpiData, this.editable_kpi_tid)\n    }\n\n\n    setTimeout(() => {\n      this.submitNewKpi();\n      this.toastr.success('KPI Updated Successfully')\n      this.reseteUpdateKpiForm();\n      this.isEditKpiAdded = false;\n    }, 500);\n\n  }\n\n  getDeleteKpi() {\n    this.getDeleteKpiName(this.kpiData, this.editable_kpi_tid)\n    setTimeout(() => {\n      this.submitNewKpi();\n      this.toastr.success('KPI Deleted Successfully')\n      this.reseteUpdateKpiForm();\n      this.isEditKpiAdded = false;\n    }, 500);\n  }\n\n\n  getUpdateKpiName(data: any, tid: string): any {\n\n    data.forEach((result: any) => {\n      if (result.tid === tid) {\n        result.desc = this.editable_desc;\n        result.kpiInfo = this.editable_info;\n        result.name = this.editable_kpi_name;\n        result.id = this.editable_id;\n        result.pageId = this.editable_page_id;\n        result.tag_type = this.editable_tag_type;\n        result.isVisible = this.kpi_visibility;\n        result.isAccessible = this.kpi_external;\n        result.tid = this.editable_kpi_tid;\n\n        // this.service.configureKpiBrowserConfig(result.config).subscribe(data => {\n        //   console.log(\"kpi browser config created\")\n        // })\n\n      } else if (result.nodes !== undefined && result.nodes.length > 0) {\n        this.getUpdateKpiName(result.nodes, tid);\n      }\n    });\n\n  }\n\n  getDeleteKpiName(data: any, tid: string): any {\n    for (let i = data.length - 1; i >= 0; i--) {\n      const result = data[i];\n      if (result.tid === tid) {\n        data.splice(i, 1);\n      } else if (result.nodes !== undefined && result.nodes.length > 0) {\n        this.getDeleteKpiName(result.nodes, tid);\n      }\n    }\n  }\n\n  reseteUpdateKpiForm() {\n    this.editable_desc = undefined;\n    this.editable_info = undefined;\n    this.editable_kpi_name = undefined;\n    this.editable_tag_type = undefined;\n    this.editable_kpi_tid = undefined;\n    this.editable_id = undefined;\n    this.editable_page_id = undefined;\n  }\n\n  submitNewKpi() {\n    this.loadingModal = true;\n    this.isEditKpiAdded = false;\n    let obj = { kpiConfigData: this.kpiData }\n    console.log(obj);\n    this.isComponentUpdata = false;\n    this.service.getCreateKpi(obj).subscribe(data => {\n      this.getAllKpiData();\n      this.getReseteKpi();\n    })\n  }\n\n  getNewParrentKpiItemValue(e) {\n    this.isComponentUpdata = true;\n    const kpi_data = this.keiParentDataSource.find((item: any) => item.tid === e.value);\n    this.getHeistId(this.kpiData, kpi_data.tid);\n    let auto_tid = this.autoIncrement(kpi_data.tid, this.heistValue);\n\n    let obj = {\n      \"name\": this.editable_kpi_name,\n      \"tid\": auto_tid,\n      \"isBookmarked\": false,\n      \"isAccessible\": this.kpi_external,\n      \"lastAccessTime\": \"\",\n      \"tag_type\": this.editable_tag_type,\n      \"id\": this.editable_id,\n      \"pageId\": this.editable_page_id,\n      \"desc\": this.editable_desc,\n      \"kpiInfo\": this.editable_info,\n      \"isVisible\": this.kpi_visibility,\n      \"nodes\": [],\n      \"config\": {}\n    }\n    this.getDeleteKpiName(this.kpiData, this.editable_kpi_tid)\n    this.setKpibyTid(this.kpiData, kpi_data.tid, obj)\n    this.editable_kpi_tid = kpi_data.tid;\n    // this.submitNewKpi();\n    // this.editable_kpi_tid = kpi_data.tid;\n    // this.getUpdateKpiName(this.kpiData, e.value)\n  }\n\n\n\n  makeNewKpiWithUserEntity() {\n\n    this.userOptionContainer.forEach(element => {\n      let att_value = element.attributeValues.split(\",\");\n      element.attributeValues = att_value;\n    });\n    if (this.selected_kpi_tid !== undefined && this.selected_kpi_tid.length > 0) {\n      this.getHeistId(this.kpiData, this.selected_kpi_tid);\n    } else {\n\n      this.heistValue = (this.kpiData.length != 0) ? this.getHighestTid(this.kpiData) : 0;\n      let value = parseInt(this.heistValue) + 1;\n\n    }\n    let kpiObj = {\n      \"kpiId\": this.selected_id,\n      \"pageId\": this.selected_page_id,\n      \"title\": this.select_kpi_name,\n      \"description\": this.selected_desc,\n      \"kpiInfo\": this.selected_info,\n      \"tagType\": this.select_tag_type,\n      \"active\": true,\n      \"visibility\": this.kpi_visibility,\n      \"externalKpi\": this.kpi_external,\n      \"target\": \"\",\n      \"icon\": \"\",\n      \"url\": \"\",\n      \"kpiType\": \"\",\n      \"parentTid\": this.selected_kpi_tid,\n      \"childTid\": \"\",\n      \"measures\": this.userOptionContainer,\n    }\n\n    console.log(\"KPI with User Entity Obj:\", kpiObj);\n  }\n\n\n\n\n  routeToKpiConfig() {\n    this.router.navigate(['apps/controlPanel/kpiController/kpiConfig'])\n  }\n\n}\n","<app-loading *ngIf=\"loadingModal\"></app-loading>\n<div class=\"p-4 flex flex-row w-full\">\n    <div class=\"mx-2 bg-white dark:bg-transparent border-r\">\n\n        <treeview class=\"dark bg-gray-900 dark:bg-transparent\" [name]=\"'mainNavigation'\" [routeKey]=\"'raKpi'\"\n            [navigation]=\"kpiData\" [isSearchBox]=\"false\" [isEditIcon]=\"true\" (editableKpiData)=\"getEditableKpi($event)\">\n        </treeview>\n    </div>\n    <div class=\"mx-2 w-full\">\n        <div class=\"flex flex-row item-center justify-center my-8\">\n            <button class=\"{{commonService.btn_warning_md}}\" (click)=\"addNewKpi()\">Add New KPI</button>\n            <button class=\"{{commonService.btn_primary_md}}\" (click)=\"routeToKpiConfig()\"\n                routerLinkActive=\"router-link-active\">Configure KPI</button>\n        </div>\n        <ng-container *ngIf=\"isNewKpiAdded\">\n            <div class=\"px-2 w-full\">\n                <div class=\"m-1\">\n                    <div class=\"px-2 pt-1 w-full\">\n                        <p class=\"text-lg mt-2\">Name</p>\n                        <dx-text-box [(ngModel)]=\"select_kpi_name\"></dx-text-box>\n                    </div>\n                </div>\n\n                <div class=\"m-1\">\n                    <div class=\"px-2 pt-1  w-full\">\n                        <p class=\"text-lg mt-2\"> Tag Type</p>\n                        <dx-select-box [dataSource]=\"tagType\" [(ngModel)]=\"select_tag_type\"\n                            (onValueChanged)=\"addTagtypeValue($event)\"></dx-select-box>\n                    </div>\n                </div>\n                <div class=\"m-1\">\n                    <div class=\"px-2 pt-1  w-full\">\n                        <p class=\"text-lg mt-2\">ID</p>\n                        <dx-text-box [(ngModel)]=\"selected_id\"></dx-text-box>\n                    </div>\n                </div>\n                <div class=\"m-1\">\n                    <div class=\"px-2 pt-1  w-full\">\n                        <p class=\"text-lg mt-2\">Page ID</p>\n                        <!-- <dx-text-box [(ngModel)]=\"selected_page_id\"></dx-text-box> -->\n                        <dx-select-box [items]=\"templateDataSource\" valueExpr=\"pageId\" displayExpr=\"pageName\" [searchEnabled]=\"true\"\n                            [(ngModel)]=\"selected_page_id\"></dx-select-box>\n                    </div>\n                </div>\n                <div class=\"m-1\">\n                    <div class=\"px-2 pt-1  w-full\">\n                        <p class=\"text-lg mt-2\">Description</p>\n                        <dx-html-editor height=\"'auto'\" [(ngModel)]=\"selected_desc\">\n                            <dxo-toolbar [multiline]=\"false\">\n\n                                <dxi-item name=\"size\"\n                                    [acceptedValues]=\"['8pt', '10pt', '12pt', '14pt', '18pt', '24pt', '36pt']\"\n                                    [options]=\"{ inputAttr: { 'aria-label': 'Font size' } }\"></dxi-item>\n                                <dxi-item name=\"font\" [acceptedValues]=\"[\n                                    'Arial',\n                                    'Courier New',\n                                    'Georgia',\n                                    'Impact',\n                                    'Lucida Console',\n                                    'Tahoma',\n                                    'Times New Roman',\n                                    'Verdana'\n                                  ]\" [options]=\"{ inputAttr: { 'aria-label': 'Font family' } }\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"bold\"></dxi-item>\n                                <dxi-item name=\"italic\"></dxi-item>\n                                <dxi-item name=\"underline\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"alignLeft\"></dxi-item>\n                                <dxi-item name=\"alignCenter\"></dxi-item>\n                                <dxi-item name=\"alignRight\"></dxi-item>\n                                <dxi-item name=\"alignJustify\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"orderedList\"></dxi-item>\n                                <dxi-item name=\"bulletList\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"header\" [acceptedValues]=\"[false, 1, 2, 3, 4, 5]\"\n                                    [options]=\"{ inputAttr: { 'aria-label': 'Header' } }\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"color\"></dxi-item>\n                                <dxi-item name=\"background\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"link\"></dxi-item>\n                                <dxi-item name=\"image\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"clear\"></dxi-item>\n                                <dxi-item name=\"codeBlock\"></dxi-item>\n                            </dxo-toolbar>\n                            <dxo-media-resizing [enabled]=\"true\"> </dxo-media-resizing>\n                            <dxo-image-upload [tabs]=\"['file', 'url']\" fileUploadMode=\"base64\">\n                            </dxo-image-upload>\n                        </dx-html-editor>\n                    </div>\n                </div>\n\n                <div class=\"m-1\">\n                    <div class=\"px-2 pt-1 w-full\">\n                        <p class=\"text-lg mt-2\"> Parent Component </p>\n                        <dx-select-box [dataSource]=\"keiParentDataSource\" displayExpr=\"name\" valueExpr=\"tid\"\n                            (onValueChanged)=\"getKpiItemValue($event)\" [value]=\"parante_kpi_name\"></dx-select-box>\n                    </div>\n                </div>\n                <div class=\"m-1\">\n                    <div class=\"px-2 pt-1  w-full\">\n                        <p class=\"text-lg mt-2\">TID</p>\n                        <dx-text-box [(ngModel)]=\"selected_kpi_tid\" [readOnly]=\"true\"></dx-text-box>\n                    </div>\n                </div>\n                <div class=\"flex flex-row justify-between mt-3\">\n                    <div class=\"px-2 pt-1  w-full\">\n                        <dx-check-box [(ngModel)]=\"kpi_visibility\" text=\"Visibility\"></dx-check-box>\n                    </div>\n                    <div class=\"px-2 pt-1  w-full\">\n                        <dx-check-box [(ngModel)]=\"kpi_external\" text=\"External KPI\"></dx-check-box>\n                    </div>\n                </div>\n                <div class=\"m-1\">\n                    <div class=\"px-2 pt-1  w-full\">\n                        <p class=\"text-lg mt-2\">KPI Info</p>\n                        <dx-html-editor height=\"'auto'\" [(ngModel)]=\"selected_info\">\n                            <dxo-toolbar [multiline]=\"false\">\n\n                                <dxi-item name=\"size\"\n                                    [acceptedValues]=\"['8pt', '10pt', '12pt', '14pt', '18pt', '24pt', '36pt']\"\n                                    [options]=\"{ inputAttr: { 'aria-label': 'Font size' } }\"></dxi-item>\n                                <dxi-item name=\"font\" [acceptedValues]=\"[\n                                                    'Arial',\n                                                    'Courier New',\n                                                    'Georgia',\n                                                    'Impact',\n                                                    'Lucida Console',\n                                                    'Tahoma',\n                                                    'Times New Roman',\n                                                    'Verdana'\n                                                  ]\"\n                                    [options]=\"{ inputAttr: { 'aria-label': 'Font family' } }\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"bold\"></dxi-item>\n                                <dxi-item name=\"italic\"></dxi-item>\n                                <dxi-item name=\"underline\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"alignLeft\"></dxi-item>\n                                <dxi-item name=\"alignCenter\"></dxi-item>\n                                <dxi-item name=\"alignRight\"></dxi-item>\n                                <dxi-item name=\"alignJustify\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"orderedList\"></dxi-item>\n                                <dxi-item name=\"bulletList\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"header\" [acceptedValues]=\"[false, 1, 2, 3, 4, 5]\"\n                                    [options]=\"{ inputAttr: { 'aria-label': 'Header' } }\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"color\"></dxi-item>\n                                <dxi-item name=\"background\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"link\"></dxi-item>\n                                <dxi-item name=\"image\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"clear\"></dxi-item>\n                                <dxi-item name=\"codeBlock\"></dxi-item>\n                            </dxo-toolbar>\n                            <dxo-media-resizing [enabled]=\"true\"> </dxo-media-resizing>\n                            <dxo-image-upload [tabs]=\"['file', 'url']\" fileUploadMode=\"base64\">\n                            </dxo-image-upload>\n                        </dx-html-editor>\n                    </div>\n                </div>\n\n                 <app-user-access [(userOptionContainer)]=\"userOptionContainer\">\n                </app-user-access>\n\n                <div class=\"flex flex-auto mt-5 justify-end\">\n                    <button class=\"{{commonService.btn_primary_md}}\" (click)=\"makeNewKpi()\">Create\n                    </button>\n                    <button class=\"{{commonService.btn_primary_md}}\" (click)=\"makeNewKpiWithUserEntity()\">Create With User Privilege\n                    </button>\n                    <button class=\"{{commonService.btn_warning_md}}\" (click)=\"getReseteKpi()\">Reset</button>\n\n                </div>\n            </div>\n        </ng-container>\n        <ng-container *ngIf=\"isEditKpiAdded\">\n            <div class=\"px-2 w-full\">\n                <div class=\"m-1\">\n                    <div class=\"px-2 pt-1 w-full\">\n                        <p class=\"text-lg mb-2\">Name</p>\n                        <dx-text-box [(ngModel)]=\"editable_kpi_name\"></dx-text-box>\n                    </div>\n                </div>\n                <div class=\"m-1\">\n                    <div class=\"px-2 pt-1  w-full\">\n                        <p class=\"text-lg mt-2\"> Tag Type</p>\n                        <dx-select-box [dataSource]=\"tagType\" [(ngModel)]=\"editable_tag_type\"\n                            (onValueChanged)=\"addTagtypeValue($event)\" [readOnly]=\"isFromEditable\"></dx-select-box>\n                    </div>\n                </div>\n                <div class=\"m-1\">\n                    <div class=\"px-2 pt-1  w-full\">\n                        <p class=\"text-lg mt-2\">ID</p>\n                        <dx-text-box [(ngModel)]=\"editable_id\"></dx-text-box>\n                    </div>\n                </div>\n                <div class=\"m-1\">\n                    <div class=\"px-2 pt-1  w-full\">\n                        <p class=\"text-lg mt-2\">Page ID</p>\n                        <!-- <dx-text-box [(ngModel)]=\"editable_page_id\"></dx-text-box> -->\n                        <dx-select-box [items]=\"templateDataSource\" valueExpr=\"pageId\" displayExpr=\"pageName\" [searchEnabled]=\"true\"\n                            [(ngModel)]=\"editable_page_id\"></dx-select-box>\n\n                    </div>\n                </div>\n                <div class=\"m-1\">\n                    <div class=\"px-2 pt-1  w-full\">\n                        <p class=\"text-lg mt-2\">Description</p>\n                        <dx-html-editor height=\"'auto'\" [(ngModel)]=\"editable_desc\">\n                            <dxo-toolbar [multiline]=\"true\">\n                                <dxi-item name=\"undo\"></dxi-item>\n                                <dxi-item name=\"redo\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"size\"\n                                    [acceptedValues]=\"['8pt', '10pt', '12pt', '14pt', '18pt', '24pt', '36pt']\"\n                                    [options]=\"{ inputAttr: { 'aria-label': 'Font size' } }\"></dxi-item>\n                                <dxi-item name=\"font\" [acceptedValues]=\"[\n                                                                'Arial',\n                                                                'Courier New',\n                                                                'Georgia',\n                                                                'Impact',\n                                                                'Lucida Console',\n                                                                'Tahoma',\n                                                                'Times New Roman',\n                                                                'Verdana'\n                                                              ]\"\n                                    [options]=\"{ inputAttr: { 'aria-label': 'Font family' } }\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"bold\"></dxi-item>\n                                <dxi-item name=\"italic\"></dxi-item>\n                                <dxi-item name=\"underline\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"alignLeft\"></dxi-item>\n                                <dxi-item name=\"alignCenter\"></dxi-item>\n                                <dxi-item name=\"alignRight\"></dxi-item>\n                                <dxi-item name=\"alignJustify\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"orderedList\"></dxi-item>\n                                <dxi-item name=\"bulletList\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"header\" [acceptedValues]=\"[false, 1, 2, 3, 4, 5]\"\n                                    [options]=\"{ inputAttr: { 'aria-label': 'Header' } }\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"color\"></dxi-item>\n                                <dxi-item name=\"background\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"link\"></dxi-item>\n                                <dxi-item name=\"image\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"clear\"></dxi-item>\n                                <dxi-item name=\"blockquote\"></dxi-item>\n\n                            </dxo-toolbar>\n                            <dxo-media-resizing [enabled]=\"true\"> </dxo-media-resizing>\n                            <dxo-image-upload [tabs]=\"['file', 'url']\" fileUploadMode=\"base64\">\n                            </dxo-image-upload>\n                        </dx-html-editor>\n                    </div>\n                </div>\n                <div class=\"m-1\">\n                    <div class=\"px-2 pt-1 w-full\">\n                        <p class=\"text-lg mt-2\"> Parent Component </p>\n                        <dx-select-box [searchEnabled]=\"true\" [readOnly]=\"editable_tag_type == 'parent'\"\n                            [dataSource]=\"keiParentDataSource\" displayExpr=\"name\" valueExpr=\"tid\"\n                            (onValueChanged)=\"getNewParrentKpiItemValue($event)\"\n                            [value]=\"parante_kpi_name\"></dx-select-box>\n                    </div>\n                </div>\n\n                <div class=\"m-1\">\n                    <div class=\"px-2 pt-1  w-full\">\n                        <p class=\"text-lg mt-2\">TID</p>\n                        <dx-text-box [(ngModel)]=\"editable_kpi_tid\" [readOnly]=\"false\"></dx-text-box>\n                    </div>\n                </div>\n                <div class=\"flex flex-row justify-between mt-3\">\n\n                    <div class=\"px-2 pt-1 w-full\">\n                        <dx-check-box [(ngModel)]=\"kpi_visibility\" text=\"Visibility\"></dx-check-box>\n                    </div>\n\n                    <div class=\"px-2 pt-1 w-full\">\n                        <dx-check-box [(ngModel)]=\"kpi_external\" text=\"External KPI\"></dx-check-box>\n                    </div>\n                </div>\n                <div class=\"m-1\">\n                    <div class=\"px-2 pt-1  w-full\">\n                        <p class=\"text-lg mt-2\">KPI Info</p>\n                        <dx-html-editor height=\"'auto'\" [(ngModel)]=\"editable_info\">\n                            <dxo-toolbar [multiline]=\"false\">\n\n                                <dxi-item name=\"size\"\n                                    [acceptedValues]=\"['8pt', '10pt', '12pt', '14pt', '18pt', '24pt', '36pt']\"\n                                    [options]=\"{ inputAttr: { 'aria-label': 'Font size' } }\"></dxi-item>\n                                <dxi-item name=\"font\" [acceptedValues]=\"[\n                                                    'Arial',\n                                                    'Courier New',\n                                                    'Georgia',\n                                                    'Impact',\n                                                    'Lucida Console',\n                                                    'Tahoma',\n                                                    'Times New Roman',\n                                                    'Verdana'\n                                                  ]\"\n                                    [options]=\"{ inputAttr: { 'aria-label': 'Font family' } }\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"bold\"></dxi-item>\n                                <dxi-item name=\"italic\"></dxi-item>\n                                <dxi-item name=\"underline\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"alignLeft\"></dxi-item>\n                                <dxi-item name=\"alignCenter\"></dxi-item>\n                                <dxi-item name=\"alignRight\"></dxi-item>\n                                <dxi-item name=\"alignJustify\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"orderedList\"></dxi-item>\n                                <dxi-item name=\"bulletList\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"header\" [acceptedValues]=\"[false, 1, 2, 3, 4, 5]\"\n                                    [options]=\"{ inputAttr: { 'aria-label': 'Header' } }\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"color\"></dxi-item>\n                                <dxi-item name=\"background\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"link\"></dxi-item>\n                                <dxi-item name=\"image\"></dxi-item>\n                                <dxi-item name=\"separator\"></dxi-item>\n                                <dxi-item name=\"clear\"></dxi-item>\n                                <dxi-item name=\"codeBlock\"></dxi-item>\n                            </dxo-toolbar>\n                            <dxo-media-resizing [enabled]=\"true\"> </dxo-media-resizing>\n                            <dxo-image-upload [tabs]=\"['file', 'url']\" fileUploadMode=\"base64\">\n                            </dxo-image-upload>\n                        </dx-html-editor>\n                    </div>\n                </div>\n                <div class=\"flex flex-auto mt-3 justify-end\">\n                    <button class=\"{{commonService.btn_primary_md}}\" (click)=\"getUpdateKpi()\">Update\n                    </button>\n                    <button class=\"{{commonService.btn_danger_md}}\" (click)=\"getDeleteKpi()\">Delete\n                    </button>\n                    <!-- <button class=\"{{commonService.btn_danger_md}}\" (click)=\"cancelUpdate()\">Cancle</button> -->\n\n                </div>\n            </div>\n        </ng-container>\n    </div>\n\n\n\n\n</div>"]}