gamma-app-controller 1.1.24 → 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.
Files changed (49) hide show
  1. package/esm2020/lib/template-module/KpiCreationModule/create-kpi-tree.component.mjs +381 -0
  2. package/esm2020/lib/template-module/KpiCreationModule/createKpi.service.mjs +90 -0
  3. package/esm2020/lib/template-module/KpiCreationModule/kpiCreation.module.mjs +184 -0
  4. package/esm2020/lib/template-module/KpiCreationModule/treeview/animation.mjs +15 -0
  5. package/esm2020/lib/template-module/KpiCreationModule/treeview/animations/defaults.mjs +12 -0
  6. package/esm2020/lib/template-module/KpiCreationModule/treeview/animations/expand-collapse.mjs +16 -0
  7. package/esm2020/lib/template-module/KpiCreationModule/treeview/animations/fade.mjs +160 -0
  8. package/esm2020/lib/template-module/KpiCreationModule/treeview/animations/shake.mjs +58 -0
  9. package/esm2020/lib/template-module/KpiCreationModule/treeview/animations/slide.mjs +116 -0
  10. package/esm2020/lib/template-module/KpiCreationModule/treeview/animations/zoom.mjs +36 -0
  11. package/esm2020/lib/template-module/KpiCreationModule/treeview/components/aside/aside.component.mjs +85 -0
  12. package/esm2020/lib/template-module/KpiCreationModule/treeview/components/basic/basic.component.mjs +118 -0
  13. package/esm2020/lib/template-module/KpiCreationModule/treeview/components/collapsable/collapsable.component.mjs +159 -0
  14. package/esm2020/lib/template-module/KpiCreationModule/treeview/components/divider/divider.component.mjs +27 -0
  15. package/esm2020/lib/template-module/KpiCreationModule/treeview/components/group/group.component.mjs +37 -0
  16. package/esm2020/lib/template-module/KpiCreationModule/treeview/components/spacer/spacer.component.mjs +27 -0
  17. package/esm2020/lib/template-module/KpiCreationModule/treeview/moment-helper.mjs +4 -0
  18. package/esm2020/lib/template-module/KpiCreationModule/treeview/treeview-navigation.service.mjs +2 -0
  19. package/esm2020/lib/template-module/KpiCreationModule/treeview/treeview-shared.service.mjs +16 -0
  20. package/esm2020/lib/template-module/KpiCreationModule/treeview/treeview.component.mjs +134 -0
  21. package/esm2020/lib/template-module/cdrConfigModule/cdr-browser.service.mjs +4 -3
  22. package/esm2020/lib/template-module/exceptionConfigModule/exception-service.mjs +4 -3
  23. package/esm2020/public-api.mjs +10 -1
  24. package/fesm2015/gamma-app-controller.mjs +1735 -180
  25. package/fesm2015/gamma-app-controller.mjs.map +1 -1
  26. package/fesm2020/gamma-app-controller.mjs +1733 -180
  27. package/fesm2020/gamma-app-controller.mjs.map +1 -1
  28. package/lib/template-module/KpiCreationModule/create-kpi-tree.component.d.ts +75 -0
  29. package/lib/template-module/KpiCreationModule/createKpi.service.d.ts +32 -0
  30. package/lib/template-module/KpiCreationModule/kpiCreation.module.d.ts +23 -0
  31. package/lib/template-module/KpiCreationModule/treeview/animation.d.ts +1 -0
  32. package/lib/template-module/KpiCreationModule/treeview/animations/defaults.d.ts +11 -0
  33. package/lib/template-module/KpiCreationModule/treeview/animations/expand-collapse.d.ts +2 -0
  34. package/lib/template-module/KpiCreationModule/treeview/animations/fade.d.ts +11 -0
  35. package/lib/template-module/KpiCreationModule/treeview/animations/shake.d.ts +2 -0
  36. package/lib/template-module/KpiCreationModule/treeview/animations/slide.d.ts +9 -0
  37. package/lib/template-module/KpiCreationModule/treeview/animations/zoom.d.ts +3 -0
  38. package/lib/template-module/KpiCreationModule/treeview/components/aside/aside.component.d.ts +26 -0
  39. package/lib/template-module/KpiCreationModule/treeview/components/basic/basic.component.d.ts +29 -0
  40. package/lib/template-module/KpiCreationModule/treeview/components/collapsable/collapsable.component.d.ts +37 -0
  41. package/lib/template-module/KpiCreationModule/treeview/components/divider/divider.component.d.ts +13 -0
  42. package/lib/template-module/KpiCreationModule/treeview/components/group/group.component.d.ts +17 -0
  43. package/lib/template-module/KpiCreationModule/treeview/components/spacer/spacer.component.d.ts +13 -0
  44. package/lib/template-module/KpiCreationModule/treeview/moment-helper.d.ts +3 -0
  45. package/lib/template-module/KpiCreationModule/treeview/treeview-navigation.service.d.ts +39 -0
  46. package/lib/template-module/KpiCreationModule/treeview/treeview-shared.service.d.ts +8 -0
  47. package/lib/template-module/KpiCreationModule/treeview/treeview.component.d.ts +52 -0
  48. package/package.json +1 -1
  49. package/public-api.d.ts +9 -0
@@ -0,0 +1,116 @@
1
+ import { animate, state, style, transition, trigger } from '@angular/animations';
2
+ import { FuseAnimationCurves, FuseAnimationDurations } from './defaults';
3
+ const slideInTop = trigger('slideInTop', [
4
+ state('void', style({
5
+ transform: 'translate3d(0, -100%, 0)'
6
+ })),
7
+ state('*', style({
8
+ transform: 'translate3d(0, 0, 0)'
9
+ })),
10
+ transition('void => false', []),
11
+ transition('void => *', animate('{{timings}}'), {
12
+ params: {
13
+ timings: `${FuseAnimationDurations.entering} ${FuseAnimationCurves.deceleration}`
14
+ }
15
+ })
16
+ ]);
17
+ const slideInBottom = trigger('slideInBottom', [
18
+ state('void', style({
19
+ transform: 'translate3d(0, 100%, 0)'
20
+ })),
21
+ state('*', style({
22
+ transform: 'translate3d(0, 0, 0)'
23
+ })),
24
+ transition('void => false', []),
25
+ transition('void => *', animate('{{timings}}'), {
26
+ params: {
27
+ timings: `${FuseAnimationDurations.entering} ${FuseAnimationCurves.deceleration}`
28
+ }
29
+ })
30
+ ]);
31
+ const slideInLeft = trigger('slideInLeft', [
32
+ state('void', style({
33
+ transform: 'translate3d(-100%, 0, 0)'
34
+ })),
35
+ state('*', style({
36
+ transform: 'translate3d(0, 0, 0)'
37
+ })),
38
+ transition('void => false', []),
39
+ transition('void => *', animate('{{timings}}'), {
40
+ params: {
41
+ timings: `${FuseAnimationDurations.entering} ${FuseAnimationCurves.deceleration}`
42
+ }
43
+ })
44
+ ]);
45
+ const slideInRight = trigger('slideInRight', [
46
+ state('void', style({
47
+ transform: 'translate3d(100%, 0, 0)'
48
+ })),
49
+ state('*', style({
50
+ transform: 'translate3d(0, 0, 0)'
51
+ })),
52
+ transition('void => false', []),
53
+ transition('void => *', animate('{{timings}}'), {
54
+ params: {
55
+ timings: `${FuseAnimationDurations.entering} ${FuseAnimationCurves.deceleration}`
56
+ }
57
+ })
58
+ ]);
59
+ const slideOutTop = trigger('slideOutTop', [
60
+ state('*', style({
61
+ transform: 'translate3d(0, 0, 0)'
62
+ })),
63
+ state('void', style({
64
+ transform: 'translate3d(0, -100%, 0)'
65
+ })),
66
+ transition('false => void', []),
67
+ transition('* => void', animate('{{timings}}'), {
68
+ params: {
69
+ timings: `${FuseAnimationDurations.exiting} ${FuseAnimationCurves.acceleration}`
70
+ }
71
+ })
72
+ ]);
73
+ const slideOutBottom = trigger('slideOutBottom', [
74
+ state('*', style({
75
+ transform: 'translate3d(0, 0, 0)'
76
+ })),
77
+ state('void', style({
78
+ transform: 'translate3d(0, 100%, 0)'
79
+ })),
80
+ transition('false => void', []),
81
+ transition('* => void', animate('{{timings}}'), {
82
+ params: {
83
+ timings: `${FuseAnimationDurations.exiting} ${FuseAnimationCurves.acceleration}`
84
+ }
85
+ })
86
+ ]);
87
+ const slideOutLeft = trigger('slideOutLeft', [
88
+ state('*', style({
89
+ transform: 'translate3d(0, 0, 0)'
90
+ })),
91
+ state('void', style({
92
+ transform: 'translate3d(-100%, 0, 0)'
93
+ })),
94
+ transition('false => void', []),
95
+ transition('* => void', animate('{{timings}}'), {
96
+ params: {
97
+ timings: `${FuseAnimationDurations.exiting} ${FuseAnimationCurves.acceleration}`
98
+ }
99
+ })
100
+ ]);
101
+ const slideOutRight = trigger('slideOutRight', [
102
+ state('*', style({
103
+ transform: 'translate3d(0, 0, 0)'
104
+ })),
105
+ state('void', style({
106
+ transform: 'translate3d(100%, 0, 0)'
107
+ })),
108
+ transition('false => void', []),
109
+ transition('* => void', animate('{{timings}}'), {
110
+ params: {
111
+ timings: `${FuseAnimationDurations.exiting} ${FuseAnimationCurves.acceleration}`
112
+ }
113
+ })
114
+ ]);
115
+ export { slideInTop, slideInBottom, slideInLeft, slideInRight, slideOutTop, slideOutBottom, slideOutLeft, slideOutRight };
116
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slide.js","sourceRoot":"","sources":["../../../../../../../../projects/gamma-app-controller/src/lib/template-module/KpiCreationModule/treeview/animations/slide.ts"],"names":[],"mappings":"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","sourcesContent":["import { animate, state, style, transition, trigger } from '@angular/animations';\nimport { FuseAnimationCurves, FuseAnimationDurations } from './defaults';\n\n// -----------------------------------------------------------------------------------------------------\n// @ Slide in top\n// -----------------------------------------------------------------------------------------------------\nconst slideInTop = trigger('slideInTop',\n    [\n        state('void',\n            style({\n                transform: 'translate3d(0, -100%, 0)'\n            })\n        ),\n\n        state('*',\n            style({\n                transform: 'translate3d(0, 0, 0)'\n            })\n        ),\n\n        // Prevent the transition if the state is false\n        transition('void => false', []),\n\n        // Transition\n        transition('void => *', animate('{{timings}}'),\n            {\n                params: {\n                    timings: `${FuseAnimationDurations.entering} ${FuseAnimationCurves.deceleration}`\n                }\n            }\n        )\n    ]\n);\n\n// -----------------------------------------------------------------------------------------------------\n// @ Slide in bottom\n// -----------------------------------------------------------------------------------------------------\nconst slideInBottom = trigger('slideInBottom',\n    [\n        state('void',\n            style({\n                transform: 'translate3d(0, 100%, 0)'\n            })\n        ),\n\n        state('*',\n            style({\n                transform: 'translate3d(0, 0, 0)'\n            })\n        ),\n\n        // Prevent the transition if the state is false\n        transition('void => false', []),\n\n        // Transition\n        transition('void => *', animate('{{timings}}'),\n            {\n                params: {\n                    timings: `${FuseAnimationDurations.entering} ${FuseAnimationCurves.deceleration}`\n                }\n            }\n        )\n    ]\n);\n\n// -----------------------------------------------------------------------------------------------------\n// @ Slide in left\n// -----------------------------------------------------------------------------------------------------\nconst slideInLeft = trigger('slideInLeft',\n    [\n        state('void',\n            style({\n                transform: 'translate3d(-100%, 0, 0)'\n            })\n        ),\n\n        state('*',\n            style({\n                transform: 'translate3d(0, 0, 0)'\n            })\n        ),\n\n        // Prevent the transition if the state is false\n        transition('void => false', []),\n\n        // Transition\n        transition('void => *', animate('{{timings}}'),\n            {\n                params: {\n                    timings: `${FuseAnimationDurations.entering} ${FuseAnimationCurves.deceleration}`\n                }\n            }\n        )\n    ]\n);\n\n// -----------------------------------------------------------------------------------------------------\n// @ Slide in right\n// -----------------------------------------------------------------------------------------------------\nconst slideInRight = trigger('slideInRight',\n    [\n        state('void',\n            style({\n                transform: 'translate3d(100%, 0, 0)'\n            })\n        ),\n\n        state('*',\n            style({\n                transform: 'translate3d(0, 0, 0)'\n            })\n        ),\n\n        // Prevent the transition if the state is false\n        transition('void => false', []),\n\n        // Transition\n        transition('void => *', animate('{{timings}}'),\n            {\n                params: {\n                    timings: `${FuseAnimationDurations.entering} ${FuseAnimationCurves.deceleration}`\n                }\n            }\n        )\n    ]\n);\n\n// -----------------------------------------------------------------------------------------------------\n// @ Slide out top\n// -----------------------------------------------------------------------------------------------------\nconst slideOutTop = trigger('slideOutTop',\n    [\n        state('*',\n            style({\n                transform: 'translate3d(0, 0, 0)'\n            })\n        ),\n\n        state('void',\n            style({\n                transform: 'translate3d(0, -100%, 0)'\n            })\n        ),\n\n        // Prevent the transition if the state is false\n        transition('false => void', []),\n\n        // Transition\n        transition('* => void', animate('{{timings}}'),\n            {\n                params: {\n                    timings: `${FuseAnimationDurations.exiting} ${FuseAnimationCurves.acceleration}`\n                }\n            }\n        )\n    ]\n);\n\n// -----------------------------------------------------------------------------------------------------\n// @ Slide out bottom\n// -----------------------------------------------------------------------------------------------------\nconst slideOutBottom = trigger('slideOutBottom',\n    [\n        state('*',\n            style({\n                transform: 'translate3d(0, 0, 0)'\n            })\n        ),\n\n        state('void',\n            style({\n                transform: 'translate3d(0, 100%, 0)'\n            })\n        ),\n\n        // Prevent the transition if the state is false\n        transition('false => void', []),\n\n        // Transition\n        transition('* => void', animate('{{timings}}'),\n            {\n                params: {\n                    timings: `${FuseAnimationDurations.exiting} ${FuseAnimationCurves.acceleration}`\n                }\n            }\n        )\n    ]\n);\n\n// -----------------------------------------------------------------------------------------------------\n// @ Slide out left\n// -----------------------------------------------------------------------------------------------------\nconst slideOutLeft = trigger('slideOutLeft',\n    [\n        state('*',\n            style({\n                transform: 'translate3d(0, 0, 0)'\n            })\n        ),\n\n        state('void',\n            style({\n                transform: 'translate3d(-100%, 0, 0)'\n            })\n        ),\n\n        // Prevent the transition if the state is false\n        transition('false => void', []),\n\n        // Transition\n        transition('* => void', animate('{{timings}}'),\n            {\n                params: {\n                    timings: `${FuseAnimationDurations.exiting} ${FuseAnimationCurves.acceleration}`\n                }\n            }\n        )\n    ]\n);\n\n// -----------------------------------------------------------------------------------------------------\n// @ Slide out right\n// -----------------------------------------------------------------------------------------------------\nconst slideOutRight = trigger('slideOutRight',\n    [\n        state('*',\n            style({\n                transform: 'translate3d(0, 0, 0)'\n            })\n        ),\n\n        state('void',\n            style({\n                transform: 'translate3d(100%, 0, 0)'\n            })\n        ),\n\n        // Prevent the transition if the state is false\n        transition('false => void', []),\n\n        // Transition\n        transition('* => void', animate('{{timings}}'),\n            {\n                params: {\n                    timings: `${FuseAnimationDurations.exiting} ${FuseAnimationCurves.acceleration}`\n                }\n            }\n        )\n    ]\n);\n\nexport { slideInTop, slideInBottom, slideInLeft, slideInRight, slideOutTop, slideOutBottom, slideOutLeft, slideOutRight };\n"]}
@@ -0,0 +1,36 @@
1
+ import { animate, state, style, transition, trigger } from '@angular/animations';
2
+ import { FuseAnimationCurves, FuseAnimationDurations } from './defaults';
3
+ const zoomIn = trigger('zoomIn', [
4
+ state('void', style({
5
+ opacity: 0,
6
+ transform: 'scale(0.5)'
7
+ })),
8
+ state('*', style({
9
+ opacity: 1,
10
+ transform: 'scale(1)'
11
+ })),
12
+ transition('void => false', []),
13
+ transition('void => *', animate('{{timings}}'), {
14
+ params: {
15
+ timings: `${FuseAnimationDurations.entering} ${FuseAnimationCurves.deceleration}`
16
+ }
17
+ })
18
+ ]);
19
+ const zoomOut = trigger('zoomOut', [
20
+ state('*', style({
21
+ opacity: 1,
22
+ transform: 'scale(1)'
23
+ })),
24
+ state('void', style({
25
+ opacity: 0,
26
+ transform: 'scale(0.5)'
27
+ })),
28
+ transition('false => void', []),
29
+ transition('* => void', animate('{{timings}}'), {
30
+ params: {
31
+ timings: `${FuseAnimationDurations.exiting} ${FuseAnimationCurves.acceleration}`
32
+ }
33
+ })
34
+ ]);
35
+ export { zoomIn, zoomOut };
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiem9vbS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2dhbW1hLWFwcC1jb250cm9sbGVyL3NyYy9saWIvdGVtcGxhdGUtbW9kdWxlL0twaUNyZWF0aW9uTW9kdWxlL3RyZWV2aWV3L2FuaW1hdGlvbnMvem9vbS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsVUFBVSxFQUFFLE9BQU8sRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ2pGLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxzQkFBc0IsRUFBRSxNQUFNLFlBQVksQ0FBQztBQUt6RSxNQUFNLE1BQU0sR0FBRyxPQUFPLENBQUMsUUFBUSxFQUMzQjtJQUVJLEtBQUssQ0FBQyxNQUFNLEVBQ1IsS0FBSyxDQUFDO1FBQ0YsT0FBTyxFQUFFLENBQUM7UUFDVixTQUFTLEVBQUUsWUFBWTtLQUMxQixDQUFDLENBQ0w7SUFFRCxLQUFLLENBQUMsR0FBRyxFQUNMLEtBQUssQ0FBQztRQUNGLE9BQU8sRUFBRSxDQUFDO1FBQ1YsU0FBUyxFQUFFLFVBQVU7S0FDeEIsQ0FBQyxDQUNMO0lBR0QsVUFBVSxDQUFDLGVBQWUsRUFBRSxFQUFFLENBQUM7SUFHL0IsVUFBVSxDQUFDLFdBQVcsRUFBRSxPQUFPLENBQUMsYUFBYSxDQUFDLEVBQzFDO1FBQ0ksTUFBTSxFQUFFO1lBQ0osT0FBTyxFQUFFLEdBQUcsc0JBQXNCLENBQUMsUUFBUSxJQUFJLG1CQUFtQixDQUFDLFlBQVksRUFBRTtTQUNwRjtLQUNKLENBQ0o7Q0FDSixDQUNKLENBQUM7QUFLRixNQUFNLE9BQU8sR0FBRyxPQUFPLENBQUMsU0FBUyxFQUM3QjtJQUVJLEtBQUssQ0FBQyxHQUFHLEVBQ0wsS0FBSyxDQUFDO1FBQ0YsT0FBTyxFQUFFLENBQUM7UUFDVixTQUFTLEVBQUUsVUFBVTtLQUN4QixDQUFDLENBQ0w7SUFFRCxLQUFLLENBQUMsTUFBTSxFQUNSLEtBQUssQ0FBQztRQUNGLE9BQU8sRUFBRSxDQUFDO1FBQ1YsU0FBUyxFQUFFLFlBQVk7S0FDMUIsQ0FBQyxDQUNMO0lBR0QsVUFBVSxDQUFDLGVBQWUsRUFBRSxFQUFFLENBQUM7SUFHL0IsVUFBVSxDQUFDLFdBQVcsRUFBRSxPQUFPLENBQUMsYUFBYSxDQUFDLEVBQzFDO1FBQ0ksTUFBTSxFQUFFO1lBQ0osT0FBTyxFQUFFLEdBQUcsc0JBQXNCLENBQUMsT0FBTyxJQUFJLG1CQUFtQixDQUFDLFlBQVksRUFBRTtTQUNuRjtLQUNKLENBQ0o7Q0FDSixDQUNKLENBQUM7QUFFRixPQUFPLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYW5pbWF0ZSwgc3RhdGUsIHN0eWxlLCB0cmFuc2l0aW9uLCB0cmlnZ2VyIH0gZnJvbSAnQGFuZ3VsYXIvYW5pbWF0aW9ucyc7XG5pbXBvcnQgeyBGdXNlQW5pbWF0aW9uQ3VydmVzLCBGdXNlQW5pbWF0aW9uRHVyYXRpb25zIH0gZnJvbSAnLi9kZWZhdWx0cyc7XG5cbi8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tXG4vLyBAIFpvb20gaW5cbi8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tXG5jb25zdCB6b29tSW4gPSB0cmlnZ2VyKCd6b29tSW4nLFxuICAgIFtcblxuICAgICAgICBzdGF0ZSgndm9pZCcsXG4gICAgICAgICAgICBzdHlsZSh7XG4gICAgICAgICAgICAgICAgb3BhY2l0eTogMCxcbiAgICAgICAgICAgICAgICB0cmFuc2Zvcm06ICdzY2FsZSgwLjUpJ1xuICAgICAgICAgICAgfSlcbiAgICAgICAgKSxcblxuICAgICAgICBzdGF0ZSgnKicsXG4gICAgICAgICAgICBzdHlsZSh7XG4gICAgICAgICAgICAgICAgb3BhY2l0eTogMSxcbiAgICAgICAgICAgICAgICB0cmFuc2Zvcm06ICdzY2FsZSgxKSdcbiAgICAgICAgICAgIH0pXG4gICAgICAgICksXG5cbiAgICAgICAgLy8gUHJldmVudCB0aGUgdHJhbnNpdGlvbiBpZiB0aGUgc3RhdGUgaXMgZmFsc2VcbiAgICAgICAgdHJhbnNpdGlvbigndm9pZCA9PiBmYWxzZScsIFtdKSxcblxuICAgICAgICAvLyBUcmFuc2l0aW9uXG4gICAgICAgIHRyYW5zaXRpb24oJ3ZvaWQgPT4gKicsIGFuaW1hdGUoJ3t7dGltaW5nc319JyksXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgcGFyYW1zOiB7XG4gICAgICAgICAgICAgICAgICAgIHRpbWluZ3M6IGAke0Z1c2VBbmltYXRpb25EdXJhdGlvbnMuZW50ZXJpbmd9ICR7RnVzZUFuaW1hdGlvbkN1cnZlcy5kZWNlbGVyYXRpb259YFxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgKVxuICAgIF1cbik7XG5cbi8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tXG4vLyBAIFpvb20gb3V0XG4vLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLVxuY29uc3Qgem9vbU91dCA9IHRyaWdnZXIoJ3pvb21PdXQnLFxuICAgIFtcblxuICAgICAgICBzdGF0ZSgnKicsXG4gICAgICAgICAgICBzdHlsZSh7XG4gICAgICAgICAgICAgICAgb3BhY2l0eTogMSxcbiAgICAgICAgICAgICAgICB0cmFuc2Zvcm06ICdzY2FsZSgxKSdcbiAgICAgICAgICAgIH0pXG4gICAgICAgICksXG5cbiAgICAgICAgc3RhdGUoJ3ZvaWQnLFxuICAgICAgICAgICAgc3R5bGUoe1xuICAgICAgICAgICAgICAgIG9wYWNpdHk6IDAsXG4gICAgICAgICAgICAgICAgdHJhbnNmb3JtOiAnc2NhbGUoMC41KSdcbiAgICAgICAgICAgIH0pXG4gICAgICAgICksXG5cbiAgICAgICAgLy8gUHJldmVudCB0aGUgdHJhbnNpdGlvbiBpZiB0aGUgc3RhdGUgaXMgZmFsc2VcbiAgICAgICAgdHJhbnNpdGlvbignZmFsc2UgPT4gdm9pZCcsIFtdKSxcblxuICAgICAgICAvLyBUcmFuc2l0aW9uXG4gICAgICAgIHRyYW5zaXRpb24oJyogPT4gdm9pZCcsIGFuaW1hdGUoJ3t7dGltaW5nc319JyksXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgcGFyYW1zOiB7XG4gICAgICAgICAgICAgICAgICAgIHRpbWluZ3M6IGAke0Z1c2VBbmltYXRpb25EdXJhdGlvbnMuZXhpdGluZ30gJHtGdXNlQW5pbWF0aW9uQ3VydmVzLmFjY2VsZXJhdGlvbn1gXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICApXG4gICAgXVxuKTtcblxuZXhwb3J0IHsgem9vbUluLCB6b29tT3V0IH07XG5cbiJdfQ==
@@ -0,0 +1,85 @@
1
+ import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
2
+ import { NavigationEnd } from '@angular/router';
3
+ import { filter, Subject, takeUntil } from 'rxjs';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/router";
6
+ import * as i2 from "@angular/common";
7
+ import * as i3 from "@angular/material/icon";
8
+ import * as i4 from "@angular/material/tooltip";
9
+ import * as i5 from "../basic/basic.component";
10
+ import * as i6 from "../collapsable/collapsable.component";
11
+ import * as i7 from "../divider/divider.component";
12
+ import * as i8 from "../group/group.component";
13
+ import * as i9 from "../spacer/spacer.component";
14
+ export class TreeViewAsideItemComponent {
15
+ constructor(_changeDetectorRef, _router) {
16
+ this._changeDetectorRef = _changeDetectorRef;
17
+ this._router = _router;
18
+ this.active = false;
19
+ this._unsubscribeAll = new Subject();
20
+ }
21
+ ngOnChanges(changes) {
22
+ if ('activeItemId' in changes) {
23
+ this._markIfActive(this._router.url);
24
+ }
25
+ }
26
+ ngOnInit() {
27
+ this._markIfActive(this._router.url);
28
+ this._router.events
29
+ .pipe(filter((event) => event instanceof NavigationEnd), takeUntil(this._unsubscribeAll))
30
+ .subscribe((event) => {
31
+ this._markIfActive(event.urlAfterRedirects);
32
+ });
33
+ }
34
+ ngOnDestroy() {
35
+ this._unsubscribeAll.next(null);
36
+ this._unsubscribeAll.complete();
37
+ }
38
+ trackByFn(index, item) {
39
+ return item.id || index;
40
+ }
41
+ _hasActiveChild(item, currentUrl) {
42
+ const children = item.children;
43
+ if (!children) {
44
+ return false;
45
+ }
46
+ for (const child of children) {
47
+ if (child.children) {
48
+ if (this._hasActiveChild(child, currentUrl)) {
49
+ return true;
50
+ }
51
+ }
52
+ if (child.type !== 'basic') {
53
+ continue;
54
+ }
55
+ if (child.link && this._router.isActive(child.link, child.exactMatch || false)) {
56
+ return true;
57
+ }
58
+ }
59
+ return false;
60
+ }
61
+ _markIfActive(currentUrl) {
62
+ this.active = this.activeItemId === this.item.id;
63
+ if (this._hasActiveChild(this.item, currentUrl)) {
64
+ this.active = true;
65
+ }
66
+ this._changeDetectorRef.markForCheck();
67
+ }
68
+ }
69
+ TreeViewAsideItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TreeViewAsideItemComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.Router }], target: i0.ɵɵFactoryTarget.Component });
70
+ TreeViewAsideItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TreeViewAsideItemComponent, selector: "treeview-aside-item", inputs: { activeItemId: "activeItemId", autoCollapse: "autoCollapse", item: "item", name: "name", skipChildren: "skipChildren" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"treeview-item-wrapper\" [class.treeview-item-has-subtitle]=\"!!item.subtitle\"\n [ngClass]=\"item.classes?.wrapper\">\n\n <div class=\"treeview-item\" [ngClass]=\"{'treeview-item-active': active,\n 'treeview-item-disabled': item.disabled,\n 'treeview-item-active-forced': item.active}\" [matTooltip]=\"item.tooltip || ''\">\n\n <!-- Icon -->\n <ng-container *ngIf=\"item.icon\">\n <mat-icon class=\"treeview-item-icon\" [ngClass]=\"item.classes?.icon\" [svgIcon]=\"item.icon\">\n </mat-icon>\n </ng-container>\n\n <!-- Title & Subtitle -->\n <div class=\"treeview-item-title-wrapper\">\n <div class=\"treeview-item-title\">\n <span [ngClass]=\"item.classes?.title\">\n {{item.title}}\n </span>\n </div>\n <ng-container *ngIf=\"item.subtitle\">\n <div class=\"treeview-item-subtitle\">\n <span [ngClass]=\"item.classes?.subtitle\">\n {{item.subtitle}}\n </span>\n </div>\n </ng-container>\n </div>\n\n <!-- Badge -->\n <ng-container *ngIf=\"item.badge\">\n <div class=\"treeview-item-badge\">\n <div class=\"treeview-item-badge-content\" [ngClass]=\"item.badge.classes\">\n {{item.badge.title}}\n </div>\n </div>\n </ng-container>\n\n </div>\n\n</div>\n\n<ng-container *ngIf=\"!skipChildren\">\n\n <div class=\"treeview-item-children\">\n\n <ng-container *ngFor=\"let item of item.children; trackBy: trackByFn\">\n\n <!-- Skip the hidden items -->\n <ng-container *ngIf=\"(item.hidden && !item.hidden(item)) || !item.hidden\">\n\n <!-- Basic -->\n <ng-container *ngIf=\"item.type === 'basic'\">\n <treeview-basic-item [item]=\"item\" [name]=\"name\"></treeview-basic-item>\n </ng-container>\n\n <!-- Collapsable -->\n <ng-container *ngIf=\"item.type === 'collapsable'\">\n <treeview-collapsable-item [item]=\"item\" [name]=\"name\" [autoCollapse]=\"autoCollapse\">\n </treeview-collapsable-item>\n </ng-container>\n\n <!-- Divider -->\n <ng-container *ngIf=\"item.type === 'divider'\">\n <treeview-divider-item [item]=\"item\" [name]=\"name\"></treeview-divider-item>\n </ng-container>\n\n <!-- Group -->\n <ng-container *ngIf=\"item.type === 'group'\">\n <treeview-group-item [item]=\"item\" [name]=\"name\"></treeview-group-item>\n </ng-container>\n\n <!-- Spacer -->\n <ng-container *ngIf=\"item.type === 'spacer'\">\n <treeview-spacer-item [item]=\"item\" [name]=\"name\"></treeview-spacer-item>\n </ng-container>\n\n </ng-container>\n\n </ng-container>\n\n </div>\n\n</ng-container>", dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i5.TreeViewBasicItemComponent, selector: "treeview-basic-item", inputs: ["item", "name", "internalRoute", "isEditIcon", "treeId"], outputs: ["editableKpiBasicData"] }, { kind: "component", type: i6.TreeViewCollapsableItemComponent, selector: "treeview-collapsable-item", inputs: ["autoCollapse", "item", "name", "treeId", "internalRoute", "isEditIcon"], outputs: ["editableKpiData"] }, { kind: "component", type: i7.TreeViewDividerItemComponent, selector: "treeview-divider-item", inputs: ["item", "name"] }, { kind: "component", type: i8.TreeViewGroupItemComponent, selector: "treeview-group-item", inputs: ["autoCollapse", "item", "name"] }, { kind: "component", type: i9.TreeViewSpacerItemComponent, selector: "treeview-spacer-item", inputs: ["item", "name"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
71
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TreeViewAsideItemComponent, decorators: [{
72
+ type: Component,
73
+ args: [{ selector: 'treeview-aside-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"treeview-item-wrapper\" [class.treeview-item-has-subtitle]=\"!!item.subtitle\"\n [ngClass]=\"item.classes?.wrapper\">\n\n <div class=\"treeview-item\" [ngClass]=\"{'treeview-item-active': active,\n 'treeview-item-disabled': item.disabled,\n 'treeview-item-active-forced': item.active}\" [matTooltip]=\"item.tooltip || ''\">\n\n <!-- Icon -->\n <ng-container *ngIf=\"item.icon\">\n <mat-icon class=\"treeview-item-icon\" [ngClass]=\"item.classes?.icon\" [svgIcon]=\"item.icon\">\n </mat-icon>\n </ng-container>\n\n <!-- Title & Subtitle -->\n <div class=\"treeview-item-title-wrapper\">\n <div class=\"treeview-item-title\">\n <span [ngClass]=\"item.classes?.title\">\n {{item.title}}\n </span>\n </div>\n <ng-container *ngIf=\"item.subtitle\">\n <div class=\"treeview-item-subtitle\">\n <span [ngClass]=\"item.classes?.subtitle\">\n {{item.subtitle}}\n </span>\n </div>\n </ng-container>\n </div>\n\n <!-- Badge -->\n <ng-container *ngIf=\"item.badge\">\n <div class=\"treeview-item-badge\">\n <div class=\"treeview-item-badge-content\" [ngClass]=\"item.badge.classes\">\n {{item.badge.title}}\n </div>\n </div>\n </ng-container>\n\n </div>\n\n</div>\n\n<ng-container *ngIf=\"!skipChildren\">\n\n <div class=\"treeview-item-children\">\n\n <ng-container *ngFor=\"let item of item.children; trackBy: trackByFn\">\n\n <!-- Skip the hidden items -->\n <ng-container *ngIf=\"(item.hidden && !item.hidden(item)) || !item.hidden\">\n\n <!-- Basic -->\n <ng-container *ngIf=\"item.type === 'basic'\">\n <treeview-basic-item [item]=\"item\" [name]=\"name\"></treeview-basic-item>\n </ng-container>\n\n <!-- Collapsable -->\n <ng-container *ngIf=\"item.type === 'collapsable'\">\n <treeview-collapsable-item [item]=\"item\" [name]=\"name\" [autoCollapse]=\"autoCollapse\">\n </treeview-collapsable-item>\n </ng-container>\n\n <!-- Divider -->\n <ng-container *ngIf=\"item.type === 'divider'\">\n <treeview-divider-item [item]=\"item\" [name]=\"name\"></treeview-divider-item>\n </ng-container>\n\n <!-- Group -->\n <ng-container *ngIf=\"item.type === 'group'\">\n <treeview-group-item [item]=\"item\" [name]=\"name\"></treeview-group-item>\n </ng-container>\n\n <!-- Spacer -->\n <ng-container *ngIf=\"item.type === 'spacer'\">\n <treeview-spacer-item [item]=\"item\" [name]=\"name\"></treeview-spacer-item>\n </ng-container>\n\n </ng-container>\n\n </ng-container>\n\n </div>\n\n</ng-container>" }]
74
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.Router }]; }, propDecorators: { activeItemId: [{
75
+ type: Input
76
+ }], autoCollapse: [{
77
+ type: Input
78
+ }], item: [{
79
+ type: Input
80
+ }], name: [{
81
+ type: Input
82
+ }], skipChildren: [{
83
+ type: Input
84
+ }] } });
85
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aside.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/gamma-app-controller/src/lib/template-module/KpiCreationModule/treeview/components/aside/aside.component.ts","../../../../../../../../../projects/gamma-app-controller/src/lib/template-module/KpiCreationModule/treeview/components/aside/aside.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, OnChanges, OnDestroy, OnInit, SimpleChanges } from '@angular/core';\nimport { NavigationEnd, Router } from '@angular/router';\nimport { BooleanInput } from '@angular/cdk/coercion';\nimport { filter, Subject, takeUntil } from 'rxjs';\n\n@Component({\n    selector: 'treeview-aside-item',\n    templateUrl: './aside.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TreeViewAsideItemComponent implements OnChanges, OnInit, OnDestroy {\n    /* eslint-disable @typescript-eslint/naming-convention */\n    static ngAcceptInputType_autoCollapse: BooleanInput;\n    static ngAcceptInputType_skipChildren: BooleanInput;\n    /* eslint-enable @typescript-eslint/naming-convention */\n\n    @Input() activeItemId: string;\n    @Input() autoCollapse: boolean;\n    @Input() item: any;\n    @Input() name: string;\n    @Input() skipChildren: boolean;\n\n    active: boolean = false;\n    private _unsubscribeAll: Subject<any> = new Subject<any>();\n\n    /**\n     * Constructor\n     */\n    constructor(\n        private _changeDetectorRef: ChangeDetectorRef,\n        private _router: Router,\n        // private _fuseNavigationService: FuseNavigationService\n    ) {\n    }\n\n    // -----------------------------------------------------------------------------------------------------\n    // @ Lifecycle hooks\n    // -----------------------------------------------------------------------------------------------------\n\n    /**\n     * On changes\n     *\n     * @param changes\n     */\n    ngOnChanges(changes: SimpleChanges): void {\n        // Active item id\n        if ('activeItemId' in changes) {\n            // Mark if active\n            this._markIfActive(this._router.url);\n        }\n    }\n\n    /**\n     * On init\n     */\n    ngOnInit(): void {\n        // Mark if active\n        this._markIfActive(this._router.url);\n\n        // Attach a listener to the NavigationEnd event\n        this._router.events\n            .pipe(\n                filter((event): event is NavigationEnd => event instanceof NavigationEnd),\n                takeUntil(this._unsubscribeAll)\n            )\n            .subscribe((event: NavigationEnd) => {\n\n                // Mark if active\n                this._markIfActive(event.urlAfterRedirects);\n            });\n\n        // Get the parent navigation component\n        // this._treeviewComponent = this._fuseNavigationService.getComponent(this.name);\n\n        // // Subscribe to onRefreshed on the navigation component\n        // this._treeviewComponent.onRefreshed.pipe(\n        //     takeUntil(this._unsubscribeAll)\n        // ).subscribe(() => {\n\n        //     // Mark for check\n        //     this._changeDetectorRef.markForCheck();\n        // });\n    }\n\n    /**\n     * On destroy\n     */\n    ngOnDestroy(): void {\n        // Unsubscribe from all subscriptions\n        this._unsubscribeAll.next(null);\n        this._unsubscribeAll.complete();\n    }\n\n    // -----------------------------------------------------------------------------------------------------\n    // @ Public methods\n    // -----------------------------------------------------------------------------------------------------\n\n    /**\n     * Track by function for ngFor loops\n     *\n     * @param index\n     * @param item\n     */\n    trackByFn(index: number, item: any): any {\n        return item.id || index;\n    }\n\n    // -----------------------------------------------------------------------------------------------------\n    // @ Private methods\n    // -----------------------------------------------------------------------------------------------------\n\n    /**\n     * Check if the given item has the given url\n     * in one of its children\n     *\n     * @param item\n     * @param currentUrl\n     * @private\n     */\n    private _hasActiveChild(item: any, currentUrl: string): boolean {\n        const children = item.children;\n\n        if (!children) {\n            return false;\n        }\n\n        for (const child of children) {\n            if (child.children) {\n                if (this._hasActiveChild(child, currentUrl)) {\n                    return true;\n                }\n            }\n\n            // Skip items other than 'basic'\n            if (child.type !== 'basic') {\n                continue;\n            }\n\n            // Check if the child has a link and is active\n            if (child.link && this._router.isActive(child.link, child.exactMatch || false)) {\n                return true;\n            }\n        }\n\n        return false;\n    }\n\n    /**\n     * Decide and mark if the item is active\n     *\n     * @private\n     */\n    private _markIfActive(currentUrl: string): void {\n        // Check if the activeItemId is equals to this item id\n        this.active = this.activeItemId === this.item.id;\n\n        // If the aside has a children that is active,\n        // always mark it as active\n        if (this._hasActiveChild(this.item, currentUrl)) {\n            this.active = true;\n        }\n\n        // Mark for check\n        this._changeDetectorRef.markForCheck();\n    }\n}\n","<div class=\"treeview-item-wrapper\" [class.treeview-item-has-subtitle]=\"!!item.subtitle\"\n    [ngClass]=\"item.classes?.wrapper\">\n\n    <div class=\"treeview-item\" [ngClass]=\"{'treeview-item-active': active,\n                    'treeview-item-disabled': item.disabled,\n                    'treeview-item-active-forced': item.active}\" [matTooltip]=\"item.tooltip || ''\">\n\n        <!-- Icon -->\n        <ng-container *ngIf=\"item.icon\">\n            <mat-icon class=\"treeview-item-icon\" [ngClass]=\"item.classes?.icon\" [svgIcon]=\"item.icon\">\n            </mat-icon>\n        </ng-container>\n\n        <!-- Title & Subtitle -->\n        <div class=\"treeview-item-title-wrapper\">\n            <div class=\"treeview-item-title\">\n                <span [ngClass]=\"item.classes?.title\">\n                    {{item.title}}\n                </span>\n            </div>\n            <ng-container *ngIf=\"item.subtitle\">\n                <div class=\"treeview-item-subtitle\">\n                    <span [ngClass]=\"item.classes?.subtitle\">\n                        {{item.subtitle}}\n                    </span>\n                </div>\n            </ng-container>\n        </div>\n\n        <!-- Badge -->\n        <ng-container *ngIf=\"item.badge\">\n            <div class=\"treeview-item-badge\">\n                <div class=\"treeview-item-badge-content\" [ngClass]=\"item.badge.classes\">\n                    {{item.badge.title}}\n                </div>\n            </div>\n        </ng-container>\n\n    </div>\n\n</div>\n\n<ng-container *ngIf=\"!skipChildren\">\n\n    <div class=\"treeview-item-children\">\n\n        <ng-container *ngFor=\"let item of item.children; trackBy: trackByFn\">\n\n            <!-- Skip the hidden items -->\n            <ng-container *ngIf=\"(item.hidden && !item.hidden(item)) || !item.hidden\">\n\n                <!-- Basic -->\n                <ng-container *ngIf=\"item.type === 'basic'\">\n                    <treeview-basic-item [item]=\"item\" [name]=\"name\"></treeview-basic-item>\n                </ng-container>\n\n                <!-- Collapsable -->\n                <ng-container *ngIf=\"item.type === 'collapsable'\">\n                    <treeview-collapsable-item [item]=\"item\" [name]=\"name\" [autoCollapse]=\"autoCollapse\">\n                    </treeview-collapsable-item>\n                </ng-container>\n\n                <!-- Divider -->\n                <ng-container *ngIf=\"item.type === 'divider'\">\n                    <treeview-divider-item [item]=\"item\" [name]=\"name\"></treeview-divider-item>\n                </ng-container>\n\n                <!-- Group -->\n                <ng-container *ngIf=\"item.type === 'group'\">\n                    <treeview-group-item [item]=\"item\" [name]=\"name\"></treeview-group-item>\n                </ng-container>\n\n                <!-- Spacer -->\n                <ng-container *ngIf=\"item.type === 'spacer'\">\n                    <treeview-spacer-item [item]=\"item\" [name]=\"name\"></treeview-spacer-item>\n                </ng-container>\n\n            </ng-container>\n\n        </ng-container>\n\n    </div>\n\n</ng-container>"]}
@@ -0,0 +1,118 @@
1
+ import { ChangeDetectionStrategy, Output, Component, EventEmitter, Input } from '@angular/core';
2
+ import { Subject } from 'rxjs';
3
+ import moment from '../../moment-helper';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "../../../createKpi.service";
6
+ import * as i2 from "@angular/router";
7
+ import * as i3 from "@angular/common";
8
+ import * as i4 from "@angular/material/icon";
9
+ import * as i5 from "@angular/material/tooltip";
10
+ export class TreeViewBasicItemComponent {
11
+ constructor(_changeDetectorRef, _treeviewService, route) {
12
+ this._changeDetectorRef = _changeDetectorRef;
13
+ this._treeviewService = _treeviewService;
14
+ this.route = route;
15
+ this.isEditIcon = false;
16
+ this.editableKpiBasicData = new EventEmitter();
17
+ this._unsubscribeAll = new Subject();
18
+ }
19
+ ngOnInit() {
20
+ this._changeDetectorRef.markForCheck();
21
+ }
22
+ ngOnDestroy() {
23
+ this._unsubscribeAll.next(null);
24
+ this._unsubscribeAll.complete();
25
+ }
26
+ getKPIDataOnclick(kpiData, event) {
27
+ this._treeviewService.getSelectedKPiData(kpiData);
28
+ }
29
+ getNavigateToKpi(data) {
30
+ const kpiId = data['id'];
31
+ let startDate, endDate;
32
+ if (data.pageId && data.pageId !== "") {
33
+ this.getNavigateKpiByPageID(data, kpiId, data['pageId']);
34
+ }
35
+ else {
36
+ this._treeviewService.getKpiBrowserConfigById(kpiId).subscribe(kpiData => {
37
+ this._treeviewService.getFilterForKpi(kpiData);
38
+ const filteredObjects = kpiData[0]['api_config'].filter(kpi => kpi.kpiConfig.displayType === "filter");
39
+ console.log(filteredObjects);
40
+ if (filteredObjects && filteredObjects.length !== 0) {
41
+ const filterOptions = filteredObjects[0].kpiConfig.dataConfig.filterItems;
42
+ filterOptions.forEach(element => {
43
+ if (element.filterType == 'date' || element.filterType == 'datetime') {
44
+ if (element.defaultFilterType == "dynamic" && element.momentFunction !== "" && element.defaultFilterValue !== "" && element.momentFormate !== "") {
45
+ if (element.apiName == "startDate") {
46
+ let [count, unit] = element.defaultFilterValue.split(',');
47
+ startDate = moment()[element.momentFunction](parseInt(count), unit).format(element.momentFormate);
48
+ }
49
+ if (element.apiName == "endDate") {
50
+ let [count, unit] = element.defaultFilterValue.split(',');
51
+ endDate = moment()[element.momentFunction](parseInt(count), unit).format(element.momentFormate);
52
+ }
53
+ }
54
+ }
55
+ });
56
+ }
57
+ else {
58
+ startDate = moment().subtract('30', 'days').format('YYYY-MM-DD');
59
+ endDate = moment().subtract('1', 'days').format('YYYY-MM-DD');
60
+ }
61
+ this.getNavigateKpi(data, kpiId, startDate, endDate);
62
+ });
63
+ }
64
+ }
65
+ getNavigateKpi(data, kpiId, startDate, endDate) {
66
+ let navigation = {
67
+ queryParams: {
68
+ 'startDate': startDate,
69
+ 'endDate': endDate,
70
+ 'id': kpiId,
71
+ 'name': data['name']
72
+ }
73
+ };
74
+ if (data.isAccessible) {
75
+ this.route.navigate(['/apps/kpi/' + kpiId + '/'], navigation);
76
+ }
77
+ else {
78
+ this.route.navigate(['/apps/kpi/kpi_data'], navigation);
79
+ }
80
+ }
81
+ getNavigateKpiByPageID(data, kpiId, pageId) {
82
+ let navigation = {
83
+ queryParams: {
84
+ 'pageId': pageId,
85
+ 'id': kpiId,
86
+ 'name': data['name']
87
+ }
88
+ };
89
+ if (data.isAccessible) {
90
+ this.route.navigate(['/apps/kpi/' + kpiId + '/'], navigation);
91
+ }
92
+ else {
93
+ this.route.navigate(['/apps/kpi/kpiView'], navigation);
94
+ }
95
+ }
96
+ getEditTreeData(item) {
97
+ this.editableKpiBasicData.emit(item);
98
+ }
99
+ }
100
+ TreeViewBasicItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TreeViewBasicItemComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.CreateKpIService }, { token: i2.Router }], target: i0.ɵɵFactoryTarget.Component });
101
+ TreeViewBasicItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TreeViewBasicItemComponent, selector: "treeview-basic-item", inputs: { item: "item", name: "name", internalRoute: "internalRoute", isEditIcon: "isEditIcon", treeId: "treeId" }, outputs: { editableKpiBasicData: "editableKpiBasicData" }, ngImport: i0, template: "<!-- Item wrapper -->\n<div class=\"treeview-item-wrapper\" [class.treeview-item-has-subtitle]=\"!!item.subtitle\"\n [ngClass]=\"item.classes?.wrapper\" (click)=\"getKPIDataOnclick(item, $event)\" (dblclick)='getNavigateToKpi(item)' *ngIf=\"item.isVisible\">\n\n <!-- Item with an internal link -->\n <!-- <ng-container *ngIf=\"item.link && !item.externalLink && !item.function && !item.disabled\">\n <a class=\"treeview-item\" [ngClass]=\"{'treeview-item-active-forced': item.active}\" [routerLink]=\"[item.link]\"\n [fragment]=\"item.fragment ?? null\" [preserveFragment]=\"item.preserveFragment ?? false\"\n [queryParams]=\"item.queryParams ?? null\" [queryParamsHandling]=\"item.queryParamsHandling ?? null\"\n [routerLinkActive]=\"'treeview-item-active'\" [routerLinkActiveOptions]=\"isActiveMatchOptions\"\n [matTooltip]=\"item.tooltip || ''\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </a>\n </ng-container> -->\n\n\n <!-- Item with a no link and no function -->\n <ng-container *ngIf=\"!item.link && !item.function && !item.disabled\">\n <div class=\"treeview-item\" id=\"kpiId-{{item.tid}}\" [matTooltip]=\"item.tooltip || ''\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n </ng-container>\n\n</div>\n\n<!-- Item template -->\n<ng-template #itemTemplate>\n\n <!-- Icon -->\n <ng-container *ngIf=\"item.icon\">\n <mat-icon class=\"treeview-item-icon\" [ngClass]=\"item.classes?.icon\" [svgIcon]=\"item.icon\"></mat-icon>\n </ng-container>\n\n <!-- Title & Subtitle -->\n <div class=\"treeview-item-title-wrapper\">\n <div class=\"treeview-item-title capitalize\">\n <span [ngClass]=\"item.classes?.name\">\n <i class=\"fa fa-pencil text-sky-800 mx-2 hover:text-sky-400 cursor-pointer \"\n (click)=\"getEditTreeData(item)\" *ngIf=\"isEditIcon\"></i> {{item.name}}\n </span>\n </div>\n <ng-container *ngIf=\"item.subtitle\">\n <div class=\"treeview-item-subtitle\">\n <span [ngClass]=\"item.classes?.subtitle\">\n {{item.subtitle}}\n </span>\n </div>\n </ng-container>\n </div>\n\n <!-- Badge -->\n <ng-container *ngIf=\"item.badge\">\n <div class=\"treeview-item-badge\">\n <div class=\"treeview-item-badge-content\" [ngClass]=\"item.badge.classes\">\n {{item.badge.title}}\n </div>\n </div>\n </ng-container>\n\n</ng-template>", dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i5.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
102
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TreeViewBasicItemComponent, decorators: [{
103
+ type: Component,
104
+ args: [{ selector: 'treeview-basic-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<!-- Item wrapper -->\n<div class=\"treeview-item-wrapper\" [class.treeview-item-has-subtitle]=\"!!item.subtitle\"\n [ngClass]=\"item.classes?.wrapper\" (click)=\"getKPIDataOnclick(item, $event)\" (dblclick)='getNavigateToKpi(item)' *ngIf=\"item.isVisible\">\n\n <!-- Item with an internal link -->\n <!-- <ng-container *ngIf=\"item.link && !item.externalLink && !item.function && !item.disabled\">\n <a class=\"treeview-item\" [ngClass]=\"{'treeview-item-active-forced': item.active}\" [routerLink]=\"[item.link]\"\n [fragment]=\"item.fragment ?? null\" [preserveFragment]=\"item.preserveFragment ?? false\"\n [queryParams]=\"item.queryParams ?? null\" [queryParamsHandling]=\"item.queryParamsHandling ?? null\"\n [routerLinkActive]=\"'treeview-item-active'\" [routerLinkActiveOptions]=\"isActiveMatchOptions\"\n [matTooltip]=\"item.tooltip || ''\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </a>\n </ng-container> -->\n\n\n <!-- Item with a no link and no function -->\n <ng-container *ngIf=\"!item.link && !item.function && !item.disabled\">\n <div class=\"treeview-item\" id=\"kpiId-{{item.tid}}\" [matTooltip]=\"item.tooltip || ''\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n </ng-container>\n\n</div>\n\n<!-- Item template -->\n<ng-template #itemTemplate>\n\n <!-- Icon -->\n <ng-container *ngIf=\"item.icon\">\n <mat-icon class=\"treeview-item-icon\" [ngClass]=\"item.classes?.icon\" [svgIcon]=\"item.icon\"></mat-icon>\n </ng-container>\n\n <!-- Title & Subtitle -->\n <div class=\"treeview-item-title-wrapper\">\n <div class=\"treeview-item-title capitalize\">\n <span [ngClass]=\"item.classes?.name\">\n <i class=\"fa fa-pencil text-sky-800 mx-2 hover:text-sky-400 cursor-pointer \"\n (click)=\"getEditTreeData(item)\" *ngIf=\"isEditIcon\"></i> {{item.name}}\n </span>\n </div>\n <ng-container *ngIf=\"item.subtitle\">\n <div class=\"treeview-item-subtitle\">\n <span [ngClass]=\"item.classes?.subtitle\">\n {{item.subtitle}}\n </span>\n </div>\n </ng-container>\n </div>\n\n <!-- Badge -->\n <ng-container *ngIf=\"item.badge\">\n <div class=\"treeview-item-badge\">\n <div class=\"treeview-item-badge-content\" [ngClass]=\"item.badge.classes\">\n {{item.badge.title}}\n </div>\n </div>\n </ng-container>\n\n</ng-template>" }]
105
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.CreateKpIService }, { type: i2.Router }]; }, propDecorators: { item: [{
106
+ type: Input
107
+ }], name: [{
108
+ type: Input
109
+ }], internalRoute: [{
110
+ type: Input
111
+ }], isEditIcon: [{
112
+ type: Input
113
+ }], treeId: [{
114
+ type: Input
115
+ }], editableKpiBasicData: [{
116
+ type: Output
117
+ }] } });
118
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"basic.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/gamma-app-controller/src/lib/template-module/KpiCreationModule/treeview/components/basic/basic.component.ts","../../../../../../../../../projects/gamma-app-controller/src/lib/template-module/KpiCreationModule/treeview/components/basic/basic.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAqB,MAAM,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAqB,MAAM,eAAe,CAAC;AAEtI,OAAO,EAAE,OAAO,EAAa,MAAM,MAAM,CAAC;AAC1C,OAAO,MAAM,MAAM,qBAAqB,CAAC;;;;;;;AAOzC,MAAM,OAAO,0BAA0B;IAkBnC,YACY,kBAAqC,EACrC,gBAAkC,EAClC,KAAa;QAFb,uBAAkB,GAAlB,kBAAkB,CAAmB;QACrC,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,UAAK,GAAL,KAAK,CAAQ;QAjBhB,eAAU,GAAY,KAAK,CAAC;QAGpB,yBAAoB,GAAsB,IAAI,YAAY,EAAE,CAAC;QAItE,oBAAe,GAAiB,IAAI,OAAO,EAAO,CAAC;IAkB3D,CAAC;IASD,QAAQ;QAIJ,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;IAE3C,CAAC;IAKD,WAAW;QAGP,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAChC,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC;IACpC,CAAC;IAED,iBAAiB,CAAC,OAAY,EAAE,KAAU;QACtC,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC;IACtD,CAAC;IAED,gBAAgB,CAAC,IAAS;QACtB,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,SAAS,EAAE,OAAO,CAAC;QACvB,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,KAAK,EAAE,EAAE;YACnC,IAAI,CAAC,sBAAsB,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAA;SAC3D;aAAM;YACH,IAAI,CAAC,gBAAgB,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE;gBACrE,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;gBAC/C,MAAM,eAAe,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,SAAS,CAAC,WAAW,KAAK,QAAQ,CAAC,CAAC;gBACvG,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;gBAC7B,IAAI,eAAe,IAAI,eAAe,CAAC,MAAM,KAAK,CAAC,EAAE;oBACjD,MAAM,aAAa,GAAG,eAAe,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,UAAU,CAAC,WAAW,CAAC;oBAC1E,aAAa,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;wBAC5B,IAAI,OAAO,CAAC,UAAU,IAAI,MAAM,IAAI,OAAO,CAAC,UAAU,IAAI,UAAU,EAAE;4BAClE,IAAI,OAAO,CAAC,iBAAiB,IAAI,SAAS,IAAI,OAAO,CAAC,cAAc,KAAK,EAAE,IAAI,OAAO,CAAC,kBAAkB,KAAK,EAAE,IAAI,OAAO,CAAC,aAAa,KAAK,EAAE,EAAE;gCAC9I,IAAI,OAAO,CAAC,OAAO,IAAI,WAAW,EAAE;oCAChC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,OAAO,CAAC,kBAAkB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;oCAC1D,SAAS,GAAG,MAAM,EAAE,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,IAAI,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;iCACrG;gCACD,IAAI,OAAO,CAAC,OAAO,IAAI,SAAS,EAAE;oCAC9B,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,OAAO,CAAC,kBAAkB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;oCAC1D,OAAO,GAAG,MAAM,EAAE,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,IAAI,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;iCACnG;6BACJ;yBACJ;oBACL,CAAC,CAAC,CAAC;iBACN;qBAAM;oBACH,SAAS,GAAG,MAAM,EAAE,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;oBACjE,OAAO,GAAG,MAAM,EAAE,CAAC,QAAQ,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;iBACjE;gBAED,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,CAAA;YACxD,CAAC,CAAC,CAAA;SACL;IAGL,CAAC;IAED,cAAc,CAAC,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,OAAO;QAC1C,IAAI,UAAU,GAAqB;YAC/B,WAAW,EAAE;gBACT,WAAW,EAAE,SAAS;gBACtB,SAAS,EAAE,OAAO;gBAClB,IAAI,EAAE,KAAK;gBACX,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC;aACvB;SACJ,CAAC;QACF,IAAI,IAAI,CAAC,YAAY,EAAE;YACnB,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,YAAY,GAAG,KAAK,GAAG,GAAG,CAAC,EAAE,UAAU,CAAC,CAAC;SACjE;aAAM;YACH,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,oBAAoB,CAAC,EAAE,UAAU,CAAC,CAAC;SAC3D;IACL,CAAC;IAED,sBAAsB,CAAC,IAAI,EAAE,KAAK,EAAE,MAAM;QACtC,IAAI,UAAU,GAAqB;YAC/B,WAAW,EAAE;gBACT,QAAQ,EAAE,MAAM;gBAChB,IAAI,EAAE,KAAK;gBACX,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC;aACvB;SACJ,CAAC;QACF,IAAI,IAAI,CAAC,YAAY,EAAE;YACnB,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,YAAY,GAAG,KAAK,GAAG,GAAG,CAAC,EAAE,UAAU,CAAC,CAAC;SACjE;aAAM;YACH,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,mBAAmB,CAAC,EAAE,UAAU,CAAC,CAAC;SAC1D;IACL,CAAC;IAED,eAAe,CAAC,IAAS;QACrB,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACzC,CAAC;;uHAnIQ,0BAA0B;2GAA1B,0BAA0B,0OCVvC,4lFA2Dc;2FDjDD,0BAA0B;kBALtC,SAAS;+BACI,qBAAqB,mBAEd,uBAAuB,CAAC,MAAM;4JAGtC,IAAI;sBAAZ,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBAEW,oBAAoB;sBAApC,MAAM","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Output, Component, EventEmitter, Input, OnDestroy, OnInit } from '@angular/core';\nimport { IsActiveMatchOptions, NavigationExtras, Router } from '@angular/router';\nimport { Subject, takeUntil } from 'rxjs';\nimport moment from '../../moment-helper';\nimport { CreateKpIService } from '../../../createKpi.service';\n@Component({\n    selector: 'treeview-basic-item',\n    templateUrl: './basic.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TreeViewBasicItemComponent implements OnInit, OnDestroy {\n    @Input() item: any;\n    @Input() name: string | undefined;\n    @Input() internalRoute: string | undefined;\n    @Input() isEditIcon: boolean = false;\n    @Input() treeId: any;\n\n    @Output() public editableKpiBasicData: EventEmitter<any> = new EventEmitter();\n\n\n    isActiveMatchOptions: IsActiveMatchOptions;\n    private _unsubscribeAll: Subject<any> = new Subject<any>();\n\n    G_DEFAULT_START_DATE: any;\n    G_DEFAULT_END_DATE: any;\n    /**\n     * Constructor\n     */\n    constructor(\n        private _changeDetectorRef: ChangeDetectorRef,\n        private _treeviewService: CreateKpIService,\n        private route: Router,\n\n    ) {\n        // Set the equivalent of {exact: false} as default for active match options.\n        // We are not assigning the item.isActiveMatchOptions directly to the\n        // [routerLinkActiveOptions] because if it's \"undefined\" initially, the router\n        // will throw an error and stop working.\n\n    }\n\n    // -----------------------------------------------------------------------------------------------------\n    // @ Lifecycle hooks\n    // -----------------------------------------------------------------------------------------------------\n\n    /**\n     * On init\n     */\n    ngOnInit(): void {\n\n\n        // Mark for check\n        this._changeDetectorRef.markForCheck();\n\n    }\n\n    /**\n     * On destroy\n     */\n    ngOnDestroy(): void {\n        // Unsubscribe from all subscriptions\n\n        this._unsubscribeAll.next(null);\n        this._unsubscribeAll.complete();\n    }\n\n    getKPIDataOnclick(kpiData: any, event: any) {\n        this._treeviewService.getSelectedKPiData(kpiData);\n    }\n\n    getNavigateToKpi(data: any) {\n        const kpiId = data['id'];\n        let startDate, endDate;\n        if (data.pageId && data.pageId !== \"\") {\n            this.getNavigateKpiByPageID(data, kpiId, data['pageId'])\n        } else {\n            this._treeviewService.getKpiBrowserConfigById(kpiId).subscribe(kpiData => {\n                this._treeviewService.getFilterForKpi(kpiData);\n                const filteredObjects = kpiData[0]['api_config'].filter(kpi => kpi.kpiConfig.displayType === \"filter\");\n                console.log(filteredObjects);\n                if (filteredObjects && filteredObjects.length !== 0) {\n                    const filterOptions = filteredObjects[0].kpiConfig.dataConfig.filterItems;\n                    filterOptions.forEach(element => {\n                        if (element.filterType == 'date' || element.filterType == 'datetime') {\n                            if (element.defaultFilterType == \"dynamic\" && element.momentFunction !== \"\" && element.defaultFilterValue !== \"\" && element.momentFormate !== \"\") {\n                                if (element.apiName == \"startDate\") {\n                                    let [count, unit] = element.defaultFilterValue.split(',');\n                                    startDate = moment()[element.momentFunction](parseInt(count), unit).format(element.momentFormate);\n                                }\n                                if (element.apiName == \"endDate\") {\n                                    let [count, unit] = element.defaultFilterValue.split(',');\n                                    endDate = moment()[element.momentFunction](parseInt(count), unit).format(element.momentFormate);\n                                }\n                            }\n                        }\n                    });\n                } else {\n                    startDate = moment().subtract('30', 'days').format('YYYY-MM-DD');\n                    endDate = moment().subtract('1', 'days').format('YYYY-MM-DD');\n                }\n\n                this.getNavigateKpi(data, kpiId, startDate, endDate)\n            })\n        }\n\n\n    }\n\n    getNavigateKpi(data, kpiId, startDate, endDate) {\n        let navigation: NavigationExtras = {\n            queryParams: {\n                'startDate': startDate,\n                'endDate': endDate,\n                'id': kpiId,\n                'name': data['name']\n            }\n        };\n        if (data.isAccessible) {\n            this.route.navigate(['/apps/kpi/' + kpiId + '/'], navigation);\n        } else {\n            this.route.navigate(['/apps/kpi/kpi_data'], navigation);\n        }\n    }\n\n    getNavigateKpiByPageID(data, kpiId, pageId) {\n        let navigation: NavigationExtras = {\n            queryParams: {\n                'pageId': pageId,\n                'id': kpiId,\n                'name': data['name']\n            }\n        };\n        if (data.isAccessible) {\n            this.route.navigate(['/apps/kpi/' + kpiId + '/'], navigation);\n        } else {\n            this.route.navigate(['/apps/kpi/kpiView'], navigation);\n        }\n    }\n\n    getEditTreeData(item: any) {\n        this.editableKpiBasicData.emit(item);\n    }\n\n\n}\n","<!-- Item wrapper -->\n<div class=\"treeview-item-wrapper\" [class.treeview-item-has-subtitle]=\"!!item.subtitle\"\n    [ngClass]=\"item.classes?.wrapper\" (click)=\"getKPIDataOnclick(item, $event)\" (dblclick)='getNavigateToKpi(item)' *ngIf=\"item.isVisible\">\n\n    <!-- Item with an internal link -->\n    <!-- <ng-container *ngIf=\"item.link && !item.externalLink && !item.function && !item.disabled\">\n        <a class=\"treeview-item\" [ngClass]=\"{'treeview-item-active-forced': item.active}\" [routerLink]=\"[item.link]\"\n            [fragment]=\"item.fragment ?? null\" [preserveFragment]=\"item.preserveFragment ?? false\"\n            [queryParams]=\"item.queryParams ?? null\" [queryParamsHandling]=\"item.queryParamsHandling ?? null\"\n            [routerLinkActive]=\"'treeview-item-active'\" [routerLinkActiveOptions]=\"isActiveMatchOptions\"\n            [matTooltip]=\"item.tooltip || ''\">\n            <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n        </a>\n    </ng-container> -->\n\n\n    <!-- Item with a no link and no function -->\n    <ng-container *ngIf=\"!item.link && !item.function && !item.disabled\">\n        <div class=\"treeview-item\" id=\"kpiId-{{item.tid}}\" [matTooltip]=\"item.tooltip || ''\">\n            <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n        </div>\n    </ng-container>\n\n</div>\n\n<!-- Item template -->\n<ng-template #itemTemplate>\n\n    <!-- Icon -->\n    <ng-container *ngIf=\"item.icon\">\n        <mat-icon class=\"treeview-item-icon\" [ngClass]=\"item.classes?.icon\" [svgIcon]=\"item.icon\"></mat-icon>\n    </ng-container>\n\n    <!-- Title & Subtitle -->\n    <div class=\"treeview-item-title-wrapper\">\n        <div class=\"treeview-item-title capitalize\">\n            <span [ngClass]=\"item.classes?.name\">\n                <i class=\"fa fa-pencil text-sky-800 mx-2 hover:text-sky-400 cursor-pointer \"\n                    (click)=\"getEditTreeData(item)\" *ngIf=\"isEditIcon\"></i> {{item.name}}\n            </span>\n        </div>\n        <ng-container *ngIf=\"item.subtitle\">\n            <div class=\"treeview-item-subtitle\">\n                <span [ngClass]=\"item.classes?.subtitle\">\n                    {{item.subtitle}}\n                </span>\n            </div>\n        </ng-container>\n    </div>\n\n    <!-- Badge -->\n    <ng-container *ngIf=\"item.badge\">\n        <div class=\"treeview-item-badge\">\n            <div class=\"treeview-item-badge-content\" [ngClass]=\"item.badge.classes\">\n                {{item.badge.title}}\n            </div>\n        </div>\n    </ng-container>\n\n</ng-template>"]}