gamma-app-controller 1.1.25 → 1.1.26
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/template-module/KpiCreationModule/create-kpi-tree.component.mjs +381 -0
- package/esm2020/lib/template-module/KpiCreationModule/createKpi.service.mjs +90 -0
- package/esm2020/lib/template-module/KpiCreationModule/kpiCreation.module.mjs +184 -0
- package/esm2020/lib/template-module/KpiCreationModule/treeview/animation.mjs +15 -0
- package/esm2020/lib/template-module/KpiCreationModule/treeview/animations/defaults.mjs +12 -0
- package/esm2020/lib/template-module/KpiCreationModule/treeview/animations/expand-collapse.mjs +16 -0
- package/esm2020/lib/template-module/KpiCreationModule/treeview/animations/fade.mjs +160 -0
- package/esm2020/lib/template-module/KpiCreationModule/treeview/animations/shake.mjs +58 -0
- package/esm2020/lib/template-module/KpiCreationModule/treeview/animations/slide.mjs +116 -0
- package/esm2020/lib/template-module/KpiCreationModule/treeview/animations/zoom.mjs +36 -0
- package/esm2020/lib/template-module/KpiCreationModule/treeview/components/aside/aside.component.mjs +85 -0
- package/esm2020/lib/template-module/KpiCreationModule/treeview/components/basic/basic.component.mjs +118 -0
- package/esm2020/lib/template-module/KpiCreationModule/treeview/components/collapsable/collapsable.component.mjs +159 -0
- package/esm2020/lib/template-module/KpiCreationModule/treeview/components/divider/divider.component.mjs +27 -0
- package/esm2020/lib/template-module/KpiCreationModule/treeview/components/group/group.component.mjs +37 -0
- package/esm2020/lib/template-module/KpiCreationModule/treeview/components/spacer/spacer.component.mjs +27 -0
- package/esm2020/lib/template-module/KpiCreationModule/treeview/moment-helper.mjs +4 -0
- package/esm2020/lib/template-module/KpiCreationModule/treeview/treeview-navigation.service.mjs +2 -0
- package/esm2020/lib/template-module/KpiCreationModule/treeview/treeview-shared.service.mjs +16 -0
- package/esm2020/lib/template-module/KpiCreationModule/treeview/treeview.component.mjs +134 -0
- package/esm2020/public-api.mjs +10 -1
- package/fesm2015/gamma-app-controller.mjs +1729 -176
- package/fesm2015/gamma-app-controller.mjs.map +1 -1
- package/fesm2020/gamma-app-controller.mjs +1727 -176
- package/fesm2020/gamma-app-controller.mjs.map +1 -1
- package/lib/template-module/KpiCreationModule/create-kpi-tree.component.d.ts +75 -0
- package/lib/template-module/KpiCreationModule/createKpi.service.d.ts +32 -0
- package/lib/template-module/KpiCreationModule/kpiCreation.module.d.ts +23 -0
- package/lib/template-module/KpiCreationModule/treeview/animation.d.ts +1 -0
- package/lib/template-module/KpiCreationModule/treeview/animations/defaults.d.ts +11 -0
- package/lib/template-module/KpiCreationModule/treeview/animations/expand-collapse.d.ts +2 -0
- package/lib/template-module/KpiCreationModule/treeview/animations/fade.d.ts +11 -0
- package/lib/template-module/KpiCreationModule/treeview/animations/shake.d.ts +2 -0
- package/lib/template-module/KpiCreationModule/treeview/animations/slide.d.ts +9 -0
- package/lib/template-module/KpiCreationModule/treeview/animations/zoom.d.ts +3 -0
- package/lib/template-module/KpiCreationModule/treeview/components/aside/aside.component.d.ts +26 -0
- package/lib/template-module/KpiCreationModule/treeview/components/basic/basic.component.d.ts +29 -0
- package/lib/template-module/KpiCreationModule/treeview/components/collapsable/collapsable.component.d.ts +37 -0
- package/lib/template-module/KpiCreationModule/treeview/components/divider/divider.component.d.ts +13 -0
- package/lib/template-module/KpiCreationModule/treeview/components/group/group.component.d.ts +17 -0
- package/lib/template-module/KpiCreationModule/treeview/components/spacer/spacer.component.d.ts +13 -0
- package/lib/template-module/KpiCreationModule/treeview/moment-helper.d.ts +3 -0
- package/lib/template-module/KpiCreationModule/treeview/treeview-navigation.service.d.ts +39 -0
- package/lib/template-module/KpiCreationModule/treeview/treeview-shared.service.d.ts +8 -0
- package/lib/template-module/KpiCreationModule/treeview/treeview.component.d.ts +52 -0
- package/package.json +1 -1
- package/public-api.d.ts +9 -0
|
@@ -0,0 +1,381 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "../../application-controller/common";
|
|
4
|
+
import * as i2 from "@angular/forms";
|
|
5
|
+
import * as i3 from "./createKpi.service";
|
|
6
|
+
import * as i4 from "ngx-toastr";
|
|
7
|
+
import * as i5 from "@angular/router";
|
|
8
|
+
import * as i6 from "@angular/common";
|
|
9
|
+
import * as i7 from "../../application-controller/shared/loading/loading.component";
|
|
10
|
+
import * as i8 from "devextreme-angular/ui/nested";
|
|
11
|
+
import * as i9 from "devextreme-angular/ui/check-box";
|
|
12
|
+
import * as i10 from "devextreme-angular/ui/html-editor";
|
|
13
|
+
import * as i11 from "devextreme-angular/ui/select-box";
|
|
14
|
+
import * as i12 from "devextreme-angular/ui/text-box";
|
|
15
|
+
import * as i13 from "./treeview/treeview.component";
|
|
16
|
+
export class CreateKpiTreeComponent {
|
|
17
|
+
constructor(commonService, formBuilder, service, toastr, router) {
|
|
18
|
+
this.commonService = commonService;
|
|
19
|
+
this.formBuilder = formBuilder;
|
|
20
|
+
this.service = service;
|
|
21
|
+
this.toastr = toastr;
|
|
22
|
+
this.router = router;
|
|
23
|
+
this.loadingModal = true;
|
|
24
|
+
this.keiParentDataSource = [];
|
|
25
|
+
this.tagType = ["parent", "child"];
|
|
26
|
+
this.kpi_constructor = [];
|
|
27
|
+
this.selected_p_kpi = {};
|
|
28
|
+
this.height = 90;
|
|
29
|
+
this.kpiData = [];
|
|
30
|
+
this.isFromEditable = false;
|
|
31
|
+
this.isNewKpiAdded = false;
|
|
32
|
+
this.isEditKpiAdded = false;
|
|
33
|
+
this.editable_desc = "";
|
|
34
|
+
this.editable_info = "";
|
|
35
|
+
this.kpi_visibility = false;
|
|
36
|
+
this.kpi_external = false;
|
|
37
|
+
this.isComponentUpdata = false;
|
|
38
|
+
}
|
|
39
|
+
ngOnInit() {
|
|
40
|
+
this.getAllKpiData();
|
|
41
|
+
this.getAppPageConfigs();
|
|
42
|
+
}
|
|
43
|
+
getAppPageConfigs() {
|
|
44
|
+
this.service.getAppPageConfigs().subscribe({
|
|
45
|
+
next: (data) => {
|
|
46
|
+
this.templateDataSource = data;
|
|
47
|
+
}, error: (err) => {
|
|
48
|
+
this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'Page ID');
|
|
49
|
+
}
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
getAllKpiData() {
|
|
53
|
+
this.loadingModal = false;
|
|
54
|
+
this.keiParentDataSource = [];
|
|
55
|
+
this.service.getlistKpiBrowser().subscribe((data) => {
|
|
56
|
+
this.kpiData = data;
|
|
57
|
+
this.prepareParentDataSource(data);
|
|
58
|
+
}, err => {
|
|
59
|
+
this.loadingModal = false;
|
|
60
|
+
this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'KPI Config');
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
prepareParentDataSource(data) {
|
|
64
|
+
data.forEach((result) => {
|
|
65
|
+
if (result.tag_type == 'parent') {
|
|
66
|
+
let node = {
|
|
67
|
+
"name": result.name,
|
|
68
|
+
"tid": result.tid
|
|
69
|
+
};
|
|
70
|
+
this.keiParentDataSource.push(node);
|
|
71
|
+
this.prepareParentDataSource(result.nodes);
|
|
72
|
+
}
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
makeNewKpi() {
|
|
76
|
+
if (this.selected_kpi_tid !== undefined && this.selected_kpi_tid.length > 0) {
|
|
77
|
+
this.getHeistId(this.kpiData, this.selected_kpi_tid);
|
|
78
|
+
this.createNewKpiWithTid();
|
|
79
|
+
}
|
|
80
|
+
else {
|
|
81
|
+
this.heistValue = (this.kpiData.length != 0) ? this.getHighestTid(this.kpiData) : 0;
|
|
82
|
+
let value = parseInt(this.heistValue) + 1;
|
|
83
|
+
let obj = {
|
|
84
|
+
"name": this.select_kpi_name,
|
|
85
|
+
"tid": value.toString(),
|
|
86
|
+
"isBookmarked": false,
|
|
87
|
+
"isAccessible": this.kpi_external,
|
|
88
|
+
"lastAccessTime": "",
|
|
89
|
+
"tag_type": this.select_tag_type,
|
|
90
|
+
"id": this.selected_id,
|
|
91
|
+
"pageId": this.selected_page_id,
|
|
92
|
+
"desc": this.selected_desc,
|
|
93
|
+
"isVisible": this.kpi_visibility,
|
|
94
|
+
"nodes": [],
|
|
95
|
+
"config": {}
|
|
96
|
+
};
|
|
97
|
+
this.kpiData.push(obj);
|
|
98
|
+
if (this.select_tag_type == 'parent') {
|
|
99
|
+
let obj = {
|
|
100
|
+
"name": this.select_kpi_name,
|
|
101
|
+
"tid": value.toString(),
|
|
102
|
+
};
|
|
103
|
+
this.keiParentDataSource.push(obj);
|
|
104
|
+
}
|
|
105
|
+
if (this.select_tag_type == 'child') {
|
|
106
|
+
let obj = {
|
|
107
|
+
"name": this.select_kpi_name,
|
|
108
|
+
"id": this.selected_id,
|
|
109
|
+
"pageId": this.selected_page_id,
|
|
110
|
+
"searchFilter": false,
|
|
111
|
+
"isSrvTypeOperator": false,
|
|
112
|
+
"operationLevels": [],
|
|
113
|
+
"fixOperationLevles": [],
|
|
114
|
+
"api_config": []
|
|
115
|
+
};
|
|
116
|
+
this.service.configureKpiBrowserConfig(obj).subscribe(data => {
|
|
117
|
+
console.log("kpi browser config created");
|
|
118
|
+
});
|
|
119
|
+
}
|
|
120
|
+
this.submitNewKpi();
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
createNewKpiWithTid() {
|
|
124
|
+
let auto_tid = this.autoIncrement(this.selected_kpi_tid, this.heistValue);
|
|
125
|
+
let obj = {
|
|
126
|
+
"name": this.select_kpi_name,
|
|
127
|
+
"tid": auto_tid,
|
|
128
|
+
"isBookmarked": false,
|
|
129
|
+
"isAccessible": this.kpi_external,
|
|
130
|
+
"lastAccessTime": "",
|
|
131
|
+
"tag_type": this.select_tag_type,
|
|
132
|
+
"id": this.selected_id,
|
|
133
|
+
"pageId": this.selected_page_id,
|
|
134
|
+
"desc": this.selected_desc,
|
|
135
|
+
"isVisible": this.kpi_visibility,
|
|
136
|
+
"nodes": [],
|
|
137
|
+
"config": {}
|
|
138
|
+
};
|
|
139
|
+
if (this.select_tag_type == 'parent') {
|
|
140
|
+
let obj = {
|
|
141
|
+
"name": this.select_kpi_name,
|
|
142
|
+
"tid": auto_tid
|
|
143
|
+
};
|
|
144
|
+
this.keiParentDataSource.push(obj);
|
|
145
|
+
}
|
|
146
|
+
if (this.select_tag_type == 'child') {
|
|
147
|
+
let obj = {
|
|
148
|
+
"name": this.select_kpi_name,
|
|
149
|
+
"id": this.selected_id,
|
|
150
|
+
"pageId": this.selected_page_id,
|
|
151
|
+
"searchFilter": false,
|
|
152
|
+
"isSrvTypeOperator": false,
|
|
153
|
+
"operationLevels": [],
|
|
154
|
+
"fixOperationLevles": [],
|
|
155
|
+
"api_config": []
|
|
156
|
+
};
|
|
157
|
+
this.service.configureKpiBrowserConfig(obj).subscribe(data => {
|
|
158
|
+
console.log("kpi browser config created");
|
|
159
|
+
});
|
|
160
|
+
}
|
|
161
|
+
this.setKpibyTid(this.kpiData, this.selected_kpi_tid, obj);
|
|
162
|
+
this.submitNewKpi();
|
|
163
|
+
}
|
|
164
|
+
getReseteKpi() {
|
|
165
|
+
this.select_kpi_name = '';
|
|
166
|
+
this.select_tag_type = '';
|
|
167
|
+
this.selected_id = '';
|
|
168
|
+
this.selected_page_id = '';
|
|
169
|
+
this.selected_kpi_tid = '';
|
|
170
|
+
this.selected_desc = '';
|
|
171
|
+
this.parante_kpi_name = '';
|
|
172
|
+
this.editable_kpi_name = '';
|
|
173
|
+
this.editable_tag_type = '';
|
|
174
|
+
this.editable_id = '';
|
|
175
|
+
this.editable_page_id = '';
|
|
176
|
+
this.editable_kpi_tid = '';
|
|
177
|
+
this.editable_desc = '';
|
|
178
|
+
this.editable_info = '';
|
|
179
|
+
this.parante_kpi_name = '';
|
|
180
|
+
this.kpi_external = false;
|
|
181
|
+
this.kpi_visibility = false;
|
|
182
|
+
this.isComponentUpdata = false;
|
|
183
|
+
}
|
|
184
|
+
getDeletKpi(tid) {
|
|
185
|
+
console.log(this.selected_p_kpi);
|
|
186
|
+
}
|
|
187
|
+
addTagtypeValue(e) {
|
|
188
|
+
this.select_tag_type = e.value;
|
|
189
|
+
}
|
|
190
|
+
getKpiItemValue(e) {
|
|
191
|
+
const kpi_data = this.keiParentDataSource.find((item) => item.tid === e.value);
|
|
192
|
+
this.selected_kpi_tid = kpi_data.tid;
|
|
193
|
+
}
|
|
194
|
+
autoIncrement(string1, string2) {
|
|
195
|
+
if (string2 === null) {
|
|
196
|
+
const numberPart = string1 + '.1';
|
|
197
|
+
return numberPart;
|
|
198
|
+
}
|
|
199
|
+
else {
|
|
200
|
+
const parts = string2.split('.');
|
|
201
|
+
let lastPart = parseInt(parts[parts.length - 1], 10);
|
|
202
|
+
let new_number = lastPart++;
|
|
203
|
+
parts[parts.length - 1] = lastPart.toString();
|
|
204
|
+
return parts.join(".");
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
setKpibyTid(data, tid, newKpiObj) {
|
|
208
|
+
data.forEach(result => {
|
|
209
|
+
if (result.nodes !== undefined) {
|
|
210
|
+
if (result.tid == tid) {
|
|
211
|
+
result.nodes.push(newKpiObj);
|
|
212
|
+
}
|
|
213
|
+
this.setKpibyTid(result.nodes, tid, newKpiObj);
|
|
214
|
+
}
|
|
215
|
+
});
|
|
216
|
+
}
|
|
217
|
+
getHeistId(data, tid) {
|
|
218
|
+
data.forEach((result) => {
|
|
219
|
+
if (result.tid === tid) {
|
|
220
|
+
if (result.nodes.length > 0) {
|
|
221
|
+
this.heistValue = this.getHighestTid(result.nodes);
|
|
222
|
+
}
|
|
223
|
+
else {
|
|
224
|
+
this.heistValue = null;
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
else if (result.nodes !== undefined && result.nodes.length > 0) {
|
|
228
|
+
this.getHeistId(result.nodes, tid);
|
|
229
|
+
}
|
|
230
|
+
});
|
|
231
|
+
}
|
|
232
|
+
getHighestTid(data) {
|
|
233
|
+
const highestTid = data.reduce((maxTid, currentItem) => {
|
|
234
|
+
const currentTidParts = currentItem.tid.split('.').map(part => parseInt(part, 10));
|
|
235
|
+
const maxTidParts = maxTid.split('.').map(part => parseInt(part, 10));
|
|
236
|
+
for (let i = 0; i < currentTidParts.length; i++) {
|
|
237
|
+
if (currentTidParts[i] > maxTidParts[i]) {
|
|
238
|
+
return currentItem.tid;
|
|
239
|
+
}
|
|
240
|
+
else if (currentTidParts[i] < maxTidParts[i]) {
|
|
241
|
+
return maxTid;
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
return maxTid;
|
|
245
|
+
}, data[0].tid);
|
|
246
|
+
return highestTid;
|
|
247
|
+
}
|
|
248
|
+
addNewKpi() {
|
|
249
|
+
this.isNewKpiAdded = true;
|
|
250
|
+
this.isEditKpiAdded = false;
|
|
251
|
+
}
|
|
252
|
+
cancelUpdate() {
|
|
253
|
+
this.isEditKpiAdded = false;
|
|
254
|
+
}
|
|
255
|
+
getEditableKpi(data) {
|
|
256
|
+
this.isComponentUpdata = false;
|
|
257
|
+
this.isEditKpiAdded = true;
|
|
258
|
+
this.isNewKpiAdded = false;
|
|
259
|
+
this.isFromEditable = true;
|
|
260
|
+
this.editable_desc = data.desc;
|
|
261
|
+
this.editable_info = (data.kpiInfo) ? data.kpiInfo : "";
|
|
262
|
+
this.editable_kpi_name = data.name;
|
|
263
|
+
this.editable_tag_type = data.tag_type;
|
|
264
|
+
this.editable_kpi_tid = data.tid;
|
|
265
|
+
this.editable_id = data.id;
|
|
266
|
+
this.editable_page_id = data.pageId;
|
|
267
|
+
this.kpi_visibility = data.isVisible;
|
|
268
|
+
this.kpi_external = data.isAccessible;
|
|
269
|
+
this.parante_kpi_name = this.getKpiParrentName(data.tid);
|
|
270
|
+
}
|
|
271
|
+
getKpiParrentName(input) {
|
|
272
|
+
const lastIndex = input.lastIndexOf('.');
|
|
273
|
+
if (lastIndex === -1) {
|
|
274
|
+
return input;
|
|
275
|
+
}
|
|
276
|
+
return input.substring(0, lastIndex);
|
|
277
|
+
}
|
|
278
|
+
getUpdateKpi() {
|
|
279
|
+
if (!this.isComponentUpdata) {
|
|
280
|
+
this.getUpdateKpiName(this.kpiData, this.editable_kpi_tid);
|
|
281
|
+
}
|
|
282
|
+
setTimeout(() => {
|
|
283
|
+
this.submitNewKpi();
|
|
284
|
+
this.toastr.success('KPI Updated Successfully');
|
|
285
|
+
this.reseteUpdateKpiForm();
|
|
286
|
+
this.isEditKpiAdded = false;
|
|
287
|
+
}, 500);
|
|
288
|
+
}
|
|
289
|
+
getDeleteKpi() {
|
|
290
|
+
this.getDeleteKpiName(this.kpiData, this.editable_kpi_tid);
|
|
291
|
+
setTimeout(() => {
|
|
292
|
+
this.submitNewKpi();
|
|
293
|
+
this.toastr.success('KPI Deleted Successfully');
|
|
294
|
+
this.reseteUpdateKpiForm();
|
|
295
|
+
this.isEditKpiAdded = false;
|
|
296
|
+
}, 500);
|
|
297
|
+
}
|
|
298
|
+
getUpdateKpiName(data, tid) {
|
|
299
|
+
data.forEach((result) => {
|
|
300
|
+
if (result.tid === tid) {
|
|
301
|
+
result.desc = this.editable_desc;
|
|
302
|
+
result.kpiInfo = this.editable_info;
|
|
303
|
+
result.name = this.editable_kpi_name;
|
|
304
|
+
result.id = this.editable_id;
|
|
305
|
+
result.pageId = this.editable_page_id;
|
|
306
|
+
result.tag_type = this.editable_tag_type;
|
|
307
|
+
result.isVisible = this.kpi_visibility;
|
|
308
|
+
result.isAccessible = this.kpi_external;
|
|
309
|
+
result.tid = this.editable_kpi_tid;
|
|
310
|
+
}
|
|
311
|
+
else if (result.nodes !== undefined && result.nodes.length > 0) {
|
|
312
|
+
this.getUpdateKpiName(result.nodes, tid);
|
|
313
|
+
}
|
|
314
|
+
});
|
|
315
|
+
}
|
|
316
|
+
getDeleteKpiName(data, tid) {
|
|
317
|
+
for (let i = data.length - 1; i >= 0; i--) {
|
|
318
|
+
const result = data[i];
|
|
319
|
+
if (result.tid === tid) {
|
|
320
|
+
data.splice(i, 1);
|
|
321
|
+
}
|
|
322
|
+
else if (result.nodes !== undefined && result.nodes.length > 0) {
|
|
323
|
+
this.getDeleteKpiName(result.nodes, tid);
|
|
324
|
+
}
|
|
325
|
+
}
|
|
326
|
+
}
|
|
327
|
+
reseteUpdateKpiForm() {
|
|
328
|
+
this.editable_desc = undefined;
|
|
329
|
+
this.editable_info = undefined;
|
|
330
|
+
this.editable_kpi_name = undefined;
|
|
331
|
+
this.editable_tag_type = undefined;
|
|
332
|
+
this.editable_kpi_tid = undefined;
|
|
333
|
+
this.editable_id = undefined;
|
|
334
|
+
this.editable_page_id = undefined;
|
|
335
|
+
}
|
|
336
|
+
submitNewKpi() {
|
|
337
|
+
this.loadingModal = true;
|
|
338
|
+
this.isEditKpiAdded = false;
|
|
339
|
+
let obj = { kpiConfigData: this.kpiData };
|
|
340
|
+
console.log(obj);
|
|
341
|
+
this.isComponentUpdata = false;
|
|
342
|
+
this.service.getCreateKpi(obj).subscribe(data => {
|
|
343
|
+
this.getAllKpiData();
|
|
344
|
+
this.getReseteKpi();
|
|
345
|
+
});
|
|
346
|
+
}
|
|
347
|
+
getNewParrentKpiItemValue(e) {
|
|
348
|
+
this.isComponentUpdata = true;
|
|
349
|
+
const kpi_data = this.keiParentDataSource.find((item) => item.tid === e.value);
|
|
350
|
+
this.getHeistId(this.kpiData, kpi_data.tid);
|
|
351
|
+
let auto_tid = this.autoIncrement(kpi_data.tid, this.heistValue);
|
|
352
|
+
let obj = {
|
|
353
|
+
"name": this.editable_kpi_name,
|
|
354
|
+
"tid": auto_tid,
|
|
355
|
+
"isBookmarked": false,
|
|
356
|
+
"isAccessible": this.kpi_external,
|
|
357
|
+
"lastAccessTime": "",
|
|
358
|
+
"tag_type": this.editable_tag_type,
|
|
359
|
+
"id": this.editable_id,
|
|
360
|
+
"pageId": this.editable_page_id,
|
|
361
|
+
"desc": this.editable_desc,
|
|
362
|
+
"kpiInfo": this.editable_info,
|
|
363
|
+
"isVisible": this.kpi_visibility,
|
|
364
|
+
"nodes": [],
|
|
365
|
+
"config": {}
|
|
366
|
+
};
|
|
367
|
+
this.getDeleteKpiName(this.kpiData, this.editable_kpi_tid);
|
|
368
|
+
this.setKpibyTid(this.kpiData, kpi_data.tid, obj);
|
|
369
|
+
this.editable_kpi_tid = kpi_data.tid;
|
|
370
|
+
}
|
|
371
|
+
routeToKpiConfig() {
|
|
372
|
+
this.router.navigate(['apps/controlPanel/kpiController/kpiConfig']);
|
|
373
|
+
}
|
|
374
|
+
}
|
|
375
|
+
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 });
|
|
376
|
+
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\"\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 <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_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\"\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.TreeviewComponent, selector: "treeview", inputs: ["autoCollapse", "inner", "navigation", "opened", "isEditIcon", "isSearchBox", "transparentOverlay", "treeListForSearchBox", "name", "openTreeId", "routeKey"], outputs: ["editableKpiData"] }] });
|
|
377
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CreateKpiTreeComponent, decorators: [{
|
|
378
|
+
type: Component,
|
|
379
|
+
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\"\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 <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_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\"\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"] }]
|
|
380
|
+
}], ctorParameters: function () { return [{ type: i1.CommonService }, { type: i2.FormBuilder }, { type: i3.CreateKpIService }, { type: i4.ToastrService }, { type: i5.Router }]; } });
|
|
381
|
+
//# 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  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  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\"\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                <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_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\"\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>"]}
|