@thetradeengineorg1/snova-shell-module 1.0.0 → 1.0.2
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/bundles/thetradeengineorg1-snova-shell-module.umd.js +680 -1159
- package/bundles/thetradeengineorg1-snova-shell-module.umd.js.map +1 -1
- package/esm2015/lib/shell-components/components/admin-layout/admin-layout.component.js +11 -14
- package/esm2015/lib/shell-components/components/header-side/header-side.component.js +180 -511
- package/esm2015/lib/shell-components/components/menu/menu.component.js +33 -234
- package/esm2015/lib/shell-components/components/sidenav/side-bar.component.js +189 -93
- package/fesm2015/thetradeengineorg1-snova-shell-module.js +590 -1015
- package/fesm2015/thetradeengineorg1-snova-shell-module.js.map +1 -1
- package/lib/shell-components/components/sidenav/side-bar.component.d.ts +14 -24
- package/package.json +1 -1
|
@@ -1,126 +1,225 @@
|
|
|
1
|
-
import { Component
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import { tap } from
|
|
5
|
-
import * as sharedModuleReducers from
|
|
6
|
-
import { GetAllMenuItemsTriggered } from
|
|
7
|
-
import { MenuCategories } from
|
|
8
|
-
import { LocalStorageProperties } from '../../../globaldependencies/constants/localstorage-properties';
|
|
9
|
-
import * as bootstrap from 'bootstrap';
|
|
1
|
+
import { Component } from "@angular/core";
|
|
2
|
+
import { NavigationEnd } from "@angular/router";
|
|
3
|
+
import { select } from "@ngrx/store";
|
|
4
|
+
import { tap } from "rxjs/operators";
|
|
5
|
+
import * as sharedModuleReducers from "./../../store/reducers/index";
|
|
6
|
+
import { GetAllMenuItemsTriggered } from "../../store/actions/menuitems.actions";
|
|
7
|
+
import { MenuCategories } from "../../constants/menu-categories";
|
|
10
8
|
import * as i0 from "@angular/core";
|
|
11
9
|
import * as i1 from "@ngrx/store";
|
|
12
10
|
import * as i2 from "@angular/router";
|
|
13
|
-
import * as i3 from "
|
|
14
|
-
import * as i4 from "@angular/
|
|
15
|
-
import * as i5 from "@angular/
|
|
16
|
-
import * as i6 from "
|
|
17
|
-
|
|
18
|
-
function
|
|
19
|
-
|
|
11
|
+
import * as i3 from "@angular/common";
|
|
12
|
+
import * as i4 from "@angular/flex-layout/extended";
|
|
13
|
+
import * as i5 from "@angular/material/icon";
|
|
14
|
+
import * as i6 from "../../../globaldependencies/pipes/softlabels.pipes";
|
|
15
|
+
import * as i7 from "@ngx-translate/core";
|
|
16
|
+
function SideBarComponent_div_9_ng_container_3_Template(rf, ctx) { if (rf & 1) {
|
|
17
|
+
i0.ɵɵelementContainerStart(0);
|
|
18
|
+
i0.ɵɵelementStart(1, "mat-icon", 5);
|
|
19
|
+
i0.ɵɵtext(2);
|
|
20
|
+
i0.ɵɵelementEnd();
|
|
21
|
+
i0.ɵɵelementStart(3, "h6", 6);
|
|
22
|
+
i0.ɵɵtext(4);
|
|
23
|
+
i0.ɵɵpipe(5, "softLabelsPipe");
|
|
24
|
+
i0.ɵɵpipe(6, "translate");
|
|
25
|
+
i0.ɵɵelementEnd();
|
|
26
|
+
i0.ɵɵelementContainerEnd();
|
|
27
|
+
} if (rf & 2) {
|
|
28
|
+
const item_r1 = i0.ɵɵnextContext().$implicit;
|
|
29
|
+
const ctx_r3 = i0.ɵɵnextContext();
|
|
30
|
+
i0.ɵɵadvance(2);
|
|
31
|
+
i0.ɵɵtextInterpolate(item_r1.icon);
|
|
32
|
+
i0.ɵɵadvance(2);
|
|
33
|
+
i0.ɵɵtextInterpolate1(" ", item_r1.menu ? i0.ɵɵpipeBind2(5, 2, item_r1.menu, ctx_r3.softLabels) : i0.ɵɵpipeBind1(6, 5, item_r1.name), " ");
|
|
34
|
+
} }
|
|
35
|
+
function SideBarComponent_div_9_ng_container_4_Template(rf, ctx) { if (rf & 1) {
|
|
36
|
+
i0.ɵɵelementContainerStart(0);
|
|
37
|
+
i0.ɵɵelementStart(1, "a", 12);
|
|
38
|
+
i0.ɵɵelementStart(2, "mat-icon", 5);
|
|
39
|
+
i0.ɵɵtext(3);
|
|
40
|
+
i0.ɵɵelementEnd();
|
|
41
|
+
i0.ɵɵelementStart(4, "h6", 6);
|
|
42
|
+
i0.ɵɵtext(5);
|
|
43
|
+
i0.ɵɵpipe(6, "softLabelsPipe");
|
|
44
|
+
i0.ɵɵpipe(7, "translate");
|
|
45
|
+
i0.ɵɵelementEnd();
|
|
46
|
+
i0.ɵɵelementEnd();
|
|
47
|
+
i0.ɵɵelementContainerEnd();
|
|
48
|
+
} if (rf & 2) {
|
|
49
|
+
const item_r1 = i0.ɵɵnextContext().$implicit;
|
|
50
|
+
const ctx_r4 = i0.ɵɵnextContext();
|
|
51
|
+
i0.ɵɵadvance(1);
|
|
52
|
+
i0.ɵɵproperty("href", item_r1.state, i0.ɵɵsanitizeUrl);
|
|
53
|
+
i0.ɵɵadvance(2);
|
|
54
|
+
i0.ɵɵtextInterpolate(item_r1.icon);
|
|
55
|
+
i0.ɵɵadvance(2);
|
|
56
|
+
i0.ɵɵtextInterpolate1(" ", item_r1.menu ? i0.ɵɵpipeBind2(6, 3, item_r1.menu, ctx_r4.softLabels) : i0.ɵɵpipeBind1(7, 6, item_r1.name), " ");
|
|
57
|
+
} }
|
|
58
|
+
function SideBarComponent_div_9_div_5_Template(rf, ctx) { if (rf & 1) {
|
|
59
|
+
const _r12 = i0.ɵɵgetCurrentView();
|
|
60
|
+
i0.ɵɵelementStart(0, "div", 13);
|
|
61
|
+
i0.ɵɵlistener("click", function SideBarComponent_div_9_div_5_Template_div_click_0_listener() { i0.ɵɵrestoreView(_r12); const item_r1 = i0.ɵɵnextContext().$implicit; const ctx_r10 = i0.ɵɵnextContext(); return ctx_r10.toggleDropdown(item_r1); });
|
|
62
|
+
i0.ɵɵelementStart(1, "mat-icon", 5);
|
|
63
|
+
i0.ɵɵtext(2);
|
|
64
|
+
i0.ɵɵelementEnd();
|
|
65
|
+
i0.ɵɵelementStart(3, "h6", 6);
|
|
66
|
+
i0.ɵɵtext(4);
|
|
67
|
+
i0.ɵɵpipe(5, "softLabelsPipe");
|
|
68
|
+
i0.ɵɵpipe(6, "translate");
|
|
69
|
+
i0.ɵɵelementEnd();
|
|
70
|
+
i0.ɵɵelementStart(7, "mat-icon", 14);
|
|
71
|
+
i0.ɵɵtext(8);
|
|
72
|
+
i0.ɵɵelementEnd();
|
|
73
|
+
i0.ɵɵelementEnd();
|
|
74
|
+
} if (rf & 2) {
|
|
75
|
+
const item_r1 = i0.ɵɵnextContext().$implicit;
|
|
76
|
+
const ctx_r5 = i0.ɵɵnextContext();
|
|
77
|
+
i0.ɵɵadvance(2);
|
|
78
|
+
i0.ɵɵtextInterpolate(item_r1.icon);
|
|
79
|
+
i0.ɵɵadvance(2);
|
|
80
|
+
i0.ɵɵtextInterpolate1(" ", item_r1.menu ? i0.ɵɵpipeBind2(5, 3, item_r1.menu, ctx_r5.softLabels) : i0.ɵɵpipeBind1(6, 6, item_r1.name), " ");
|
|
81
|
+
i0.ɵɵadvance(4);
|
|
82
|
+
i0.ɵɵtextInterpolate1(" ", item_r1.open ? "expand_less" : "expand_more", " ");
|
|
83
|
+
} }
|
|
84
|
+
const _c0 = function (a0) { return { background: a0 }; };
|
|
85
|
+
function SideBarComponent_div_9_div_6_span_1_Template(rf, ctx) { if (rf & 1) {
|
|
86
|
+
i0.ɵɵelementStart(0, "span", 17);
|
|
87
|
+
i0.ɵɵtext(1);
|
|
88
|
+
i0.ɵɵelementEnd();
|
|
89
|
+
} if (rf & 2) {
|
|
90
|
+
const badge_r15 = ctx.$implicit;
|
|
91
|
+
i0.ɵɵproperty("ngStyle", i0.ɵɵpureFunction1(2, _c0, badge_r15.color));
|
|
92
|
+
i0.ɵɵadvance(1);
|
|
93
|
+
i0.ɵɵtextInterpolate1(" ", badge_r15.value, " ");
|
|
94
|
+
} }
|
|
95
|
+
function SideBarComponent_div_9_div_6_Template(rf, ctx) { if (rf & 1) {
|
|
96
|
+
i0.ɵɵelementStart(0, "div", 15);
|
|
97
|
+
i0.ɵɵtemplate(1, SideBarComponent_div_9_div_6_span_1_Template, 2, 4, "span", 16);
|
|
98
|
+
i0.ɵɵelementEnd();
|
|
99
|
+
} if (rf & 2) {
|
|
100
|
+
const item_r1 = i0.ɵɵnextContext().$implicit;
|
|
101
|
+
i0.ɵɵadvance(1);
|
|
102
|
+
i0.ɵɵproperty("ngForOf", item_r1.badges);
|
|
103
|
+
} }
|
|
104
|
+
function SideBarComponent_div_9_div_7_div_1_Template(rf, ctx) { if (rf & 1) {
|
|
105
|
+
const _r21 = i0.ɵɵgetCurrentView();
|
|
20
106
|
i0.ɵɵelementStart(0, "div", 2);
|
|
21
|
-
i0.ɵɵelementStart(1, "div",
|
|
22
|
-
i0.ɵɵlistener("
|
|
107
|
+
i0.ɵɵelementStart(1, "div", 19);
|
|
108
|
+
i0.ɵɵlistener("click", function SideBarComponent_div_9_div_7_div_1_Template_div_click_1_listener() { const restoredCtx = i0.ɵɵrestoreView(_r21); const itemLvL2_r18 = restoredCtx.$implicit; const ctx_r20 = i0.ɵɵnextContext(2); const i_r2 = ctx_r20.index; const item_r1 = ctx_r20.$implicit; const ctx_r19 = i0.ɵɵnextContext(); return ctx_r19.selectMenu(i_r2, "/" + item_r1.state + "/" + itemLvL2_r18.state); });
|
|
23
109
|
i0.ɵɵelementStart(2, "div", 4);
|
|
24
110
|
i0.ɵɵelementStart(3, "mat-icon", 5);
|
|
25
111
|
i0.ɵɵtext(4);
|
|
26
112
|
i0.ɵɵelementEnd();
|
|
27
113
|
i0.ɵɵelementStart(5, "h6", 6);
|
|
28
114
|
i0.ɵɵtext(6);
|
|
115
|
+
i0.ɵɵpipe(7, "softLabelsPipe");
|
|
116
|
+
i0.ɵɵpipe(8, "translate");
|
|
117
|
+
i0.ɵɵelementEnd();
|
|
118
|
+
i0.ɵɵelementEnd();
|
|
119
|
+
i0.ɵɵelementEnd();
|
|
120
|
+
i0.ɵɵelementEnd();
|
|
121
|
+
} if (rf & 2) {
|
|
122
|
+
const itemLvL2_r18 = ctx.$implicit;
|
|
123
|
+
const ctx_r17 = i0.ɵɵnextContext(3);
|
|
124
|
+
i0.ɵɵadvance(4);
|
|
125
|
+
i0.ɵɵtextInterpolate(itemLvL2_r18.icon);
|
|
126
|
+
i0.ɵɵadvance(2);
|
|
127
|
+
i0.ɵɵtextInterpolate1(" ", itemLvL2_r18.menu ? i0.ɵɵpipeBind2(7, 2, itemLvL2_r18.menu, ctx_r17.softLabels) : i0.ɵɵpipeBind1(8, 5, itemLvL2_r18.name), " ");
|
|
128
|
+
} }
|
|
129
|
+
function SideBarComponent_div_9_div_7_Template(rf, ctx) { if (rf & 1) {
|
|
130
|
+
i0.ɵɵelementStart(0, "div", 18);
|
|
131
|
+
i0.ɵɵtemplate(1, SideBarComponent_div_9_div_7_div_1_Template, 9, 7, "div", 7);
|
|
29
132
|
i0.ɵɵelementEnd();
|
|
133
|
+
} if (rf & 2) {
|
|
134
|
+
const item_r1 = i0.ɵɵnextContext().$implicit;
|
|
135
|
+
i0.ɵɵadvance(1);
|
|
136
|
+
i0.ɵɵproperty("ngForOf", item_r1.sub);
|
|
137
|
+
} }
|
|
138
|
+
const _c1 = function () { return { "background-color": "#DBEAFE", "border-image": "linear-gradient(135deg,#5de0e6,#004aad) 1", "box-shadow": "0 4px 15px rgba(0,0,0,0.15)" }; };
|
|
139
|
+
function SideBarComponent_div_9_Template(rf, ctx) { if (rf & 1) {
|
|
140
|
+
const _r24 = i0.ɵɵgetCurrentView();
|
|
141
|
+
i0.ɵɵelementStart(0, "div", 2);
|
|
142
|
+
i0.ɵɵelementStart(1, "div", 3);
|
|
143
|
+
i0.ɵɵlistener("mouseenter", function SideBarComponent_div_9_Template_div_mouseenter_1_listener() { const restoredCtx = i0.ɵɵrestoreView(_r24); const i_r2 = restoredCtx.index; const ctx_r23 = i0.ɵɵnextContext(); return ctx_r23.enter(i_r2); })("mouseleave", function SideBarComponent_div_9_Template_div_mouseleave_1_listener() { const restoredCtx = i0.ɵɵrestoreView(_r24); const i_r2 = restoredCtx.index; const ctx_r25 = i0.ɵɵnextContext(); return ctx_r25.leave(i_r2); })("click", function SideBarComponent_div_9_Template_div_click_1_listener() { const restoredCtx = i0.ɵɵrestoreView(_r24); const i_r2 = restoredCtx.index; const item_r1 = restoredCtx.$implicit; const ctx_r26 = i0.ɵɵnextContext(); return ctx_r26.selectMenu(i_r2, item_r1.state); });
|
|
144
|
+
i0.ɵɵelementStart(2, "div", 4);
|
|
145
|
+
i0.ɵɵtemplate(3, SideBarComponent_div_9_ng_container_3_Template, 7, 7, "ng-container", 8);
|
|
146
|
+
i0.ɵɵtemplate(4, SideBarComponent_div_9_ng_container_4_Template, 8, 8, "ng-container", 8);
|
|
147
|
+
i0.ɵɵtemplate(5, SideBarComponent_div_9_div_5_Template, 9, 8, "div", 9);
|
|
148
|
+
i0.ɵɵtemplate(6, SideBarComponent_div_9_div_6_Template, 2, 1, "div", 10);
|
|
30
149
|
i0.ɵɵelementEnd();
|
|
31
150
|
i0.ɵɵelementEnd();
|
|
151
|
+
i0.ɵɵtemplate(7, SideBarComponent_div_9_div_7_Template, 2, 1, "div", 11);
|
|
32
152
|
i0.ɵɵelementEnd();
|
|
33
153
|
} if (rf & 2) {
|
|
34
154
|
const item_r1 = ctx.$implicit;
|
|
35
155
|
const i_r2 = ctx.index;
|
|
36
156
|
const ctx_r0 = i0.ɵɵnextContext();
|
|
37
157
|
i0.ɵɵadvance(1);
|
|
38
|
-
i0.ɵɵproperty("ngStyle",
|
|
39
|
-
i0.ɵɵadvance(3);
|
|
40
|
-
i0.ɵɵtextInterpolate(item_r1.icon);
|
|
158
|
+
i0.ɵɵproperty("ngStyle", (ctx_r0.selectedRowIndex == i_r2 || ctx_r0.showBackGroundColor == i_r2) && i0.ɵɵpureFunction0(6, _c1));
|
|
41
159
|
i0.ɵɵadvance(2);
|
|
42
|
-
i0.ɵɵ
|
|
160
|
+
i0.ɵɵproperty("ngIf", item_r1.type === "link" || item_r1.type === "applicationlink");
|
|
161
|
+
i0.ɵɵadvance(1);
|
|
162
|
+
i0.ɵɵproperty("ngIf", item_r1.type === "extLink");
|
|
163
|
+
i0.ɵɵadvance(1);
|
|
164
|
+
i0.ɵɵproperty("ngIf", item_r1.type === "dropDown");
|
|
165
|
+
i0.ɵɵadvance(1);
|
|
166
|
+
i0.ɵɵproperty("ngIf", item_r1.badges == null ? null : item_r1.badges.length);
|
|
167
|
+
i0.ɵɵadvance(1);
|
|
168
|
+
i0.ɵɵproperty("ngIf", item_r1.open && item_r1.type === "dropDown");
|
|
43
169
|
} }
|
|
44
170
|
export class SideBarComponent {
|
|
45
|
-
constructor(store, router
|
|
171
|
+
constructor(store, router) {
|
|
46
172
|
this.store = store;
|
|
47
173
|
this.router = router;
|
|
48
|
-
this.recentSearchService = recentSearchService;
|
|
49
|
-
this.hasIconMenu = false;
|
|
50
|
-
this.iconMenuTitle = 'Menu';
|
|
51
|
-
this.menuItems = [];
|
|
52
|
-
this.items = [];
|
|
53
|
-
this.selectedRowIndex = null;
|
|
54
174
|
this.showBackGroundColor = null;
|
|
55
175
|
}
|
|
56
176
|
ngOnInit() {
|
|
57
|
-
|
|
58
|
-
this.
|
|
59
|
-
//
|
|
177
|
+
// load soft labels
|
|
178
|
+
this.softLabels = JSON.parse(localStorage.getItem("SoftLabels"));
|
|
179
|
+
// get menu items from store
|
|
180
|
+
this.menuItems$ = this.store.pipe(select(sharedModuleReducers.getCurrentActiveMenuCategoryMenuItems), tap(menuList => this.routerActive(menuList)));
|
|
181
|
+
// trigger menu load
|
|
182
|
+
this.store.dispatch(new GetAllMenuItemsTriggered(MenuCategories.Main));
|
|
183
|
+
// listen to route changes
|
|
60
184
|
this.router.events.subscribe(event => {
|
|
61
185
|
if (event instanceof NavigationEnd) {
|
|
62
|
-
this.
|
|
186
|
+
this.menuItems$.subscribe(list => this.routerActive(list));
|
|
63
187
|
}
|
|
64
188
|
});
|
|
65
189
|
}
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
190
|
+
routerActive(menuList) {
|
|
191
|
+
if (menuList && menuList.length > 0) {
|
|
192
|
+
const index = menuList.findIndex(i => this.router.url == "/" + i.state);
|
|
193
|
+
this.selectedRowIndex = index;
|
|
194
|
+
if (this.router.url.includes("/dashboard-management")) {
|
|
195
|
+
this.selectedRowIndex = 99;
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
enter(i) {
|
|
200
|
+
this.showBackGroundColor = i;
|
|
69
201
|
}
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
if (stored)
|
|
73
|
-
this.softLabels = JSON.parse(stored);
|
|
202
|
+
leave(i) {
|
|
203
|
+
this.showBackGroundColor = null;
|
|
74
204
|
}
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
this.menuItems$ = this.store.pipe(select(sharedModuleReducers.getCurrentActiveMenuCategoryMenuItems), tap(menuList => console.log('NgRx menu:', menuList)));
|
|
78
|
-
this.store.dispatch(new GetAllMenuItemsTriggered(MenuCategories.Main));
|
|
79
|
-
// Fallback: load from localStorage / service
|
|
80
|
-
const storedItems = JSON.parse(localStorage.getItem(LocalStorageProperties.SideBarMenuItems));
|
|
81
|
-
if (storedItems && storedItems.length) {
|
|
82
|
-
this.menuItems = storedItems;
|
|
83
|
-
this.items = this.menuItems.filter(i => i.type !== 'dropDown');
|
|
84
|
-
}
|
|
85
|
-
else {
|
|
86
|
-
this.recentSearchService.searchMenuData(false).subscribe((res) => {
|
|
87
|
-
var _a;
|
|
88
|
-
if (res.success && ((_a = res.data) === null || _a === void 0 ? void 0 : _a.menuItems)) {
|
|
89
|
-
this.menuItems = res.data.menuItems;
|
|
90
|
-
localStorage.setItem(LocalStorageProperties.SideBarMenuItems, JSON.stringify(this.menuItems));
|
|
91
|
-
this.items = this.menuItems.filter(i => i.type !== 'dropDown');
|
|
92
|
-
}
|
|
93
|
-
});
|
|
94
|
-
}
|
|
205
|
+
toggleDropdown(item) {
|
|
206
|
+
item.open = !item.open;
|
|
95
207
|
}
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
this.selectedRowIndex = 99;
|
|
208
|
+
// ✅ NEW: unified method
|
|
209
|
+
selectMenu(index, link) {
|
|
210
|
+
this.selectedRowIndex = index;
|
|
211
|
+
if (link) {
|
|
212
|
+
this.router.navigate([link]);
|
|
102
213
|
}
|
|
103
214
|
}
|
|
104
|
-
// Hover events
|
|
105
|
-
enter(i) { this.showBackGroundColor = i; }
|
|
106
|
-
leave(i) { this.showBackGroundColor = null; }
|
|
107
|
-
// Click event to set active menu
|
|
108
|
-
selectMenu(i) { this.selectedRowIndex = i; }
|
|
109
|
-
// Navigate and keep active
|
|
110
|
-
openMenu(link) {
|
|
111
|
-
this.router.navigate([link]);
|
|
112
|
-
const index = this.items.findIndex(item => item.state === link);
|
|
113
|
-
if (index >= 0)
|
|
114
|
-
this.selectMenu(index);
|
|
115
|
-
}
|
|
116
215
|
}
|
|
117
|
-
SideBarComponent.ɵfac = function SideBarComponent_Factory(t) { return new (t || SideBarComponent)(i0.ɵɵdirectiveInject(i1.Store), i0.ɵɵdirectiveInject(i2.Router)
|
|
118
|
-
SideBarComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: SideBarComponent, selectors: [["app-sidebar"]],
|
|
216
|
+
SideBarComponent.ɵfac = function SideBarComponent_Factory(t) { return new (t || SideBarComponent)(i0.ɵɵdirectiveInject(i1.Store), i0.ɵɵdirectiveInject(i2.Router)); };
|
|
217
|
+
SideBarComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: SideBarComponent, selectors: [["app-sidebar"]], decls: 11, vars: 5, consts: [[1, "d-flex", "flex-column", "justify-content-center", "align-items-center", 2, "width", "100vw", "height", "calc(100vh - 60px)", "background-color", "#F9FAFB", "padding", "30px", "overflow", "auto"], [1, "row", "justify-content-center", "align-items-center", 2, "height", "auto"], [1, "col-6", "col-md-3", "mb-4"], [1, "card", "cursor-pointer", 2, "height", "150px", "border-radius", "12px", "transition", "all 0.3s ease", "background", "#fff", "box-shadow", "0 2px 6px rgba(0,0,0,0.08)", "border", "2px solid transparent", 3, "ngStyle", "mouseenter", "mouseleave", "click"], [1, "card-body", "d-flex", "flex-column", "align-items-center", "justify-content-center"], [2, "font-size", "40px", "margin-bottom", "10px", "width", "48px", "height", "48px", "display", "flex", "align-items", "center", "justify-content", "center", "background", "linear-gradient(135deg,#5de0e6,#004aad)", "-webkit-background-clip", "text", "-webkit-text-fill-color", "transparent", "background-clip", "text", "text-fill-color", "transparent"], [2, "font-size", "14px", "margin", "0", "color", "#111827", "text-align", "center"], ["class", "col-6 col-md-3 mb-4", 4, "ngFor", "ngForOf"], [4, "ngIf"], ["class", "w-100 d-flex flex-column align-items-center cursor-pointer", 3, "click", 4, "ngIf"], ["class", "mt-2", 4, "ngIf"], ["class", "row w-100 mt-2", 4, "ngIf"], ["target", "_blank", 1, "w-100", "d-flex", "flex-column", "align-items-center", 3, "href"], [1, "w-100", "d-flex", "flex-column", "align-items-center", "cursor-pointer", 3, "click"], [2, "font-size", "24px", "margin-top", "5px", "width", "32px", "height", "32px", "background", "linear-gradient(135deg,#5de0e6,#004aad)", "-webkit-background-clip", "text", "-webkit-text-fill-color", "transparent", "background-clip", "text", "text-fill-color", "transparent"], [1, "mt-2"], ["class", "badge rounded-pill", 3, "ngStyle", 4, "ngFor", "ngForOf"], [1, "badge", "rounded-pill", 3, "ngStyle"], [1, "row", "w-100", "mt-2"], [1, "card", "cursor-pointer", 2, "height", "150px", "border-radius", "12px", "transition", "all 0.3s ease", "background", "#fff", "box-shadow", "0 2px 6px rgba(0,0,0,0.08)", "border", "2px solid transparent", 3, "click"]], template: function SideBarComponent_Template(rf, ctx) { if (rf & 1) {
|
|
119
218
|
i0.ɵɵelementStart(0, "div", 0);
|
|
120
219
|
i0.ɵɵelementStart(1, "div", 1);
|
|
121
220
|
i0.ɵɵelementStart(2, "div", 2);
|
|
122
221
|
i0.ɵɵelementStart(3, "div", 3);
|
|
123
|
-
i0.ɵɵlistener("mouseenter", function SideBarComponent_Template_div_mouseenter_3_listener() { return ctx.enter(99); })("mouseleave", function SideBarComponent_Template_div_mouseleave_3_listener() { return ctx.leave(99); })("click", function SideBarComponent_Template_div_click_3_listener() { return ctx.selectMenu(99); });
|
|
222
|
+
i0.ɵɵlistener("mouseenter", function SideBarComponent_Template_div_mouseenter_3_listener() { return ctx.enter(99); })("mouseleave", function SideBarComponent_Template_div_mouseleave_3_listener() { return ctx.leave(99); })("click", function SideBarComponent_Template_div_click_3_listener() { return ctx.selectMenu(99, "/dashboard-management"); });
|
|
124
223
|
i0.ɵɵelementStart(4, "div", 4);
|
|
125
224
|
i0.ɵɵelementStart(5, "mat-icon", 5);
|
|
126
225
|
i0.ɵɵtext(6, "home");
|
|
@@ -131,24 +230,21 @@ SideBarComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: SideBarCom
|
|
|
131
230
|
i0.ɵɵelementEnd();
|
|
132
231
|
i0.ɵɵelementEnd();
|
|
133
232
|
i0.ɵɵelementEnd();
|
|
134
|
-
i0.ɵɵtemplate(9, SideBarComponent_div_9_Template,
|
|
233
|
+
i0.ɵɵtemplate(9, SideBarComponent_div_9_Template, 8, 7, "div", 7);
|
|
234
|
+
i0.ɵɵpipe(10, "async");
|
|
135
235
|
i0.ɵɵelementEnd();
|
|
136
236
|
i0.ɵɵelementEnd();
|
|
137
237
|
} if (rf & 2) {
|
|
138
238
|
i0.ɵɵadvance(3);
|
|
139
|
-
i0.ɵɵproperty("ngStyle",
|
|
239
|
+
i0.ɵɵproperty("ngStyle", (ctx.selectedRowIndex == 99 || ctx.showBackGroundColor == 99) && i0.ɵɵpureFunction0(4, _c1));
|
|
140
240
|
i0.ɵɵadvance(6);
|
|
141
|
-
i0.ɵɵproperty("ngForOf", ctx.
|
|
142
|
-
} }, directives: [
|
|
241
|
+
i0.ɵɵproperty("ngForOf", i0.ɵɵpipeBind1(10, 2, ctx.menuItems$));
|
|
242
|
+
} }, directives: [i3.NgStyle, i4.DefaultStyleDirective, i5.MatIcon, i3.NgForOf, i3.NgIf], pipes: [i3.AsyncPipe, i6.SoftLabelPipe, i7.TranslatePipe], encapsulation: 2 });
|
|
143
243
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SideBarComponent, [{
|
|
144
244
|
type: Component,
|
|
145
245
|
args: [{
|
|
146
|
-
selector:
|
|
147
|
-
templateUrl:
|
|
246
|
+
selector: "app-sidebar",
|
|
247
|
+
templateUrl: "./side-bar.component.html"
|
|
148
248
|
}]
|
|
149
|
-
}], function () { return [{ type: i1.Store }, { type: i2.Router }
|
|
150
|
-
type: Input
|
|
151
|
-
}], iconMenuTitle: [{
|
|
152
|
-
type: Input
|
|
153
|
-
}] }); })();
|
|
154
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side-bar.component.js","sourceRoot":"","sources":["../../../../../../../shell-module-components/shell-components/src/lib/shell-components/components/sidenav/side-bar.component.ts","../../../../../../../shell-module-components/shell-components/src/lib/shell-components/components/sidenav/side-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, AfterViewInit } from '@angular/core';\r\nimport { Store, select } from '@ngrx/store';\r\nimport { Router, NavigationEnd } from '@angular/router';\r\nimport { Observable } from 'rxjs';\r\nimport { tap } from 'rxjs/operators';\r\nimport * as sharedModuleReducers from '../../store/reducers/index';\r\nimport { State } from '../../store/reducers/index';\r\nimport { GetAllMenuItemsTriggered } from '../../store/actions/menuitems.actions';\r\nimport { IMenuItem } from '../../models/IMenuItem';\r\nimport { MenuCategories } from '../../constants/menu-categories';\r\nimport { RecentSearchService } from '../../services/recentSearch.service';\r\nimport { LocalStorageProperties } from '../../../globaldependencies/constants/localstorage-properties';\r\nimport { SoftLabelConfigurationModel } from '../../models/softlabels-model';\r\nimport * as bootstrap from 'bootstrap';\r\n\r\n@Component({\r\n    selector: 'app-sidebar',\r\n    templateUrl: './side-bar.component.html'\r\n})\r\nexport class SideBarComponent implements AfterViewInit {\r\n    @Input() hasIconMenu: boolean = false;\r\n    @Input() iconMenuTitle: string = 'Menu';\r\n\r\n    menuItems$: Observable<IMenuItem[]>;\r\n    menuItems: IMenuItem[] = [];\r\n    items: IMenuItem[] = [];\r\n    softLabels: SoftLabelConfigurationModel[];\r\n    selectedRowIndex: number = null;\r\n    showBackGroundColor: number = null;\r\n\r\n    constructor(\r\n        private store: Store<State>,\r\n        private router: Router,\r\n        private recentSearchService: RecentSearchService\r\n    ) { }\r\n\r\n    ngOnInit() {\r\n        this.loadSoftLabels();\r\n        this.loadMenuItems();\r\n\r\n        // Listen to route changes to update active menu\r\n        this.router.events.subscribe(event => {\r\n            if (event instanceof NavigationEnd) {\r\n                this.updateActiveRow();\r\n            }\r\n        });\r\n    }\r\n\r\n    ngAfterViewInit() {\r\n        const tooltipTriggerList = Array.from(document.querySelectorAll('[data-bs-toggle=\"tooltip\"]'));\r\n        tooltipTriggerList.forEach(el => new bootstrap.Tooltip(el));\r\n    }\r\n\r\n    loadSoftLabels() {\r\n        const stored = localStorage.getItem('SoftLabels');\r\n        if (stored) this.softLabels = JSON.parse(stored);\r\n    }\r\n\r\n    loadMenuItems() {\r\n        // Try NgRx store first\r\n        this.menuItems$ = this.store.pipe(\r\n            select(sharedModuleReducers.getCurrentActiveMenuCategoryMenuItems),\r\n            tap(menuList => console.log('NgRx menu:', menuList))\r\n        );\r\n\r\n        this.store.dispatch(new GetAllMenuItemsTriggered(MenuCategories.Main));\r\n\r\n        // Fallback: load from localStorage / service\r\n        const storedItems = JSON.parse(localStorage.getItem(LocalStorageProperties.SideBarMenuItems));\r\n        if (storedItems && storedItems.length) {\r\n            this.menuItems = storedItems;\r\n            this.items = this.menuItems.filter(i => i.type !== 'dropDown');\r\n        } else {\r\n            this.recentSearchService.searchMenuData(false).subscribe((res: any) => {\r\n                if (res.success && res.data?.menuItems) {\r\n                    this.menuItems = res.data.menuItems;\r\n                    localStorage.setItem(LocalStorageProperties.SideBarMenuItems, JSON.stringify(this.menuItems));\r\n                    this.items = this.menuItems.filter(i => i.type !== 'dropDown');\r\n                }\r\n            });\r\n        }\r\n    }\r\n\r\n    updateActiveRow() {\r\n        if (this.items && this.items.length) {\r\n            const index = this.items.findIndex(i => this.router.url === '/' + i.state);\r\n            this.selectedRowIndex = index >= 0 ? index : null;\r\n            if (this.router.url.includes('/dashboard-management')) this.selectedRowIndex = 99;\r\n        }\r\n    }\r\n\r\n    // Hover events\r\n    enter(i: number) { this.showBackGroundColor = i; }\r\n    leave(i: number) { this.showBackGroundColor = null; }\r\n\r\n    // Click event to set active menu\r\n    selectMenu(i: number) { this.selectedRowIndex = i; }\r\n\r\n    // Navigate and keep active\r\n    openMenu(link: string) {\r\n        this.router.navigate([link]);\r\n        const index = this.items.findIndex(item => item.state === link);\r\n        if (index >= 0) this.selectMenu(index);\r\n    }\r\n}\r\n","<!-- full-page-menu.component.html -->\r\n<div class=\"d-flex flex-column justify-content-center align-items-center\"\r\n    style=\"width:100vw; height:calc(100vh - 60px); background-color:#F9FAFB; padding:30px; overflow:auto;\">\r\n\r\n    <div class=\"row justify-content-center align-items-center\" style=\"height:auto;\">\r\n\r\n        <!-- Fixed Home Card -->\r\n        <div class=\"col-6 col-md-3 mb-4\">\r\n            <div class=\"card h-100 cursor-pointer\" (mouseenter)=\"enter(99)\" (mouseleave)=\"leave(99)\"\r\n                (click)=\"selectMenu(99)\" [ngStyle]=\"{\r\n                    'background-color': (selectedRowIndex == 99 || showBackGroundColor == 99) ? '#DBEAFE' : '#FFFFFF',\r\n                    'border': (selectedRowIndex == 99 || showBackGroundColor == 99) ? '2px solid #09555c' : '1px solid #E5E7EB',\r\n                    'box-shadow': (selectedRowIndex == 99 || showBackGroundColor == 99) ? '0 4px 15px rgba(0,0,0,0.15)' : '0 2px 6px rgba(0,0,0,0.08)',\r\n                    'border-radius': '12px',\r\n                    'transition': 'all 0.3s ease'\r\n                 }\" routerLink=\"/dashboard-management\">\r\n                <div class=\"card-body d-flex flex-column align-items-center justify-content-center\">\r\n                    <mat-icon style=\"font-size:40px; color:#09555c; margin-bottom:10px;\">home</mat-icon>\r\n                    <h6 style=\"font-size:14px; margin:0; color:#111827;\">Home</h6>\r\n                </div>\r\n            </div>\r\n        </div>\r\n\r\n        <!-- Dynamic Cards -->\r\n        <div class=\"col-6 col-md-3 mb-4\" *ngFor=\"let item of items; let i = index;\">\r\n            <div class=\"card h-100 cursor-pointer\" (mouseenter)=\"enter(i)\" (mouseleave)=\"leave(i)\"\r\n                (click)=\"selectMenu(i)\" [ngStyle]=\"{\r\n                    'background-color': (selectedRowIndex == i || showBackGroundColor == i) ? '#DBEAFE' : '#FFFFFF',\r\n                    'border': (selectedRowIndex == i || showBackGroundColor == i) ? '2px solid #09555c' : '1px solid #E5E7EB',\r\n                    'box-shadow': (selectedRowIndex == i || showBackGroundColor == i) ? '0 4px 15px rgba(0,0,0,0.15)' : '0 2px 6px rgba(0,0,0,0.08)',\r\n                    'border-radius': '12px',\r\n                    'transition': 'all 0.3s ease'\r\n                 }\" [routerLink]=\"item.state\">\r\n                <div class=\"card-body d-flex flex-column align-items-center justify-content-center\">\r\n                    <mat-icon style=\"font-size:40px; color:#09555c; margin-bottom:10px;\">{{ item.icon }}</mat-icon>\r\n                    <h6 style=\"font-size:14px; margin:0; color:#111827;\">{{ item.menu }}</h6>\r\n                </div>\r\n            </div>\r\n        </div>\r\n\r\n    </div>\r\n</div>"]}
|
|
249
|
+
}], function () { return [{ type: i1.Store }, { type: i2.Router }]; }, null); })();
|
|
250
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side-bar.component.js","sourceRoot":"","sources":["../../../../../../../shell-module-components/shell-components/src/lib/shell-components/components/sidenav/side-bar.component.ts","../../../../../../../shell-module-components/shell-components/src/lib/shell-components/components/sidenav/side-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component } from \"@angular/core\";\r\nimport { Router, NavigationEnd } from \"@angular/router\";\r\nimport { Store, select } from \"@ngrx/store\";\r\nimport { Observable } from \"rxjs\";\r\nimport { tap } from \"rxjs/operators\";\r\n\r\nimport { State } from \"./../../store/reducers/index\";\r\nimport * as sharedModuleReducers from \"./../../store/reducers/index\";\r\nimport { GetAllMenuItemsTriggered } from \"../../store/actions/menuitems.actions\";\r\nimport { IMenuItem } from \"../../models/IMenuItem\";\r\nimport { MenuCategories } from \"../../constants/menu-categories\";\r\nimport { SoftLabelConfigurationModel } from \"../../models/softlabels-model\";\r\n\r\n@Component({\r\n    selector: \"app-sidebar\",\r\n    templateUrl: \"./side-bar.component.html\"\r\n})\r\nexport class SideBarComponent {\r\n    public menuItems$: Observable<IMenuItem[]>;\r\n    public selectedRowIndex: number;\r\n    public showBackGroundColor: number | null = null;\r\n    public softLabels: SoftLabelConfigurationModel[];\r\n\r\n    constructor(private store: Store<State>, private router: Router) { }\r\n\r\n    ngOnInit() {\r\n        // load soft labels\r\n        this.softLabels = JSON.parse(localStorage.getItem(\"SoftLabels\"));\r\n\r\n        // get menu items from store\r\n        this.menuItems$ = this.store.pipe(\r\n            select(sharedModuleReducers.getCurrentActiveMenuCategoryMenuItems),\r\n            tap(menuList => this.routerActive(menuList))\r\n        );\r\n\r\n        // trigger menu load\r\n        this.store.dispatch(new GetAllMenuItemsTriggered(MenuCategories.Main));\r\n\r\n        // listen to route changes\r\n        this.router.events.subscribe(event => {\r\n            if (event instanceof NavigationEnd) {\r\n                this.menuItems$.subscribe(list => this.routerActive(list));\r\n            }\r\n        });\r\n    }\r\n\r\n    routerActive(menuList: IMenuItem[]) {\r\n        if (menuList && menuList.length > 0) {\r\n            const index = menuList.findIndex(i => this.router.url == \"/\" + i.state);\r\n            this.selectedRowIndex = index;\r\n            if (this.router.url.includes(\"/dashboard-management\")) {\r\n                this.selectedRowIndex = 99;\r\n            }\r\n        }\r\n    }\r\n\r\n    enter(i: number) {\r\n        this.showBackGroundColor = i;\r\n    }\r\n\r\n    leave(i: number) {\r\n        this.showBackGroundColor = null;\r\n    }\r\n\r\n    toggleDropdown(item: any) {\r\n        item.open = !item.open;\r\n    }\r\n\r\n    // ✅ NEW: unified method\r\n    selectMenu(index: number, link?: string) {\r\n        this.selectedRowIndex = index;\r\n        if (link) {\r\n            this.router.navigate([link]);\r\n        }\r\n    }\r\n}\r\n","<div class=\"d-flex flex-column justify-content-center align-items-center\"\r\n    style=\"width:100vw; height:calc(100vh - 60px); background-color:#F9FAFB; padding:30px; overflow:auto;\">\r\n\r\n    <div class=\"row justify-content-center align-items-center\" style=\"height:auto;\">\r\n\r\n        <!-- Fixed Home Card -->\r\n        <div class=\"col-6 col-md-3 mb-4\">\r\n            <div class=\"card cursor-pointer\" style=\"height:150px; border-radius:12px; transition:all 0.3s ease; background:#fff; \r\n                 box-shadow:0 2px 6px rgba(0,0,0,0.08); border:2px solid transparent;\" (mouseenter)=\"enter(99)\"\r\n                (mouseleave)=\"leave(99)\" (click)=\"selectMenu(99, '/dashboard-management')\" [ngStyle]=\"(selectedRowIndex == 99 || showBackGroundColor == 99) && {\r\n              'background-color':'#DBEAFE',\r\n              'border-image':'linear-gradient(135deg,#5de0e6,#004aad) 1',\r\n              'box-shadow':'0 4px 15px rgba(0,0,0,0.15)'\r\n          }\">\r\n                <div class=\"card-body d-flex flex-column align-items-center justify-content-center\">\r\n                    <mat-icon style=\"font-size:40px; margin-bottom:10px; width:48px; height:48px;\r\n              display:flex; align-items:center; justify-content:center;\r\n              background:linear-gradient(135deg,#5de0e6,#004aad);\r\n              -webkit-background-clip:text; -webkit-text-fill-color:transparent;\r\n              background-clip:text; text-fill-color:transparent;\">home</mat-icon>\r\n                    <h6 style=\"font-size:14px; margin:0; color:#111827; text-align:center;\">Home</h6>\r\n                </div>\r\n            </div>\r\n        </div>\r\n\r\n        <!-- Dynamic Menu Cards -->\r\n        <div class=\"col-6 col-md-3 mb-4\" *ngFor=\"let item of (menuItems$ | async); let i = index;\">\r\n            <div class=\"card cursor-pointer\" style=\"height:150px; border-radius:12px; transition:all 0.3s ease; background:#fff;\r\n                 box-shadow:0 2px 6px rgba(0,0,0,0.08); border:2px solid transparent;\" (mouseenter)=\"enter(i)\"\r\n                (mouseleave)=\"leave(i)\" (click)=\"selectMenu(i, item.state)\" [ngStyle]=\"(selectedRowIndex == i || showBackGroundColor == i) && {\r\n              'background-color':'#DBEAFE',\r\n              'border-image':'linear-gradient(135deg,#5de0e6,#004aad) 1',\r\n              'box-shadow':'0 4px 15px rgba(0,0,0,0.15)'\r\n          }\">\r\n\r\n                <div class=\"card-body d-flex flex-column align-items-center justify-content-center\">\r\n\r\n                    <!-- Normal link / application link -->\r\n                    <ng-container *ngIf=\"item.type === 'link' || item.type === 'applicationlink'\">\r\n                        <mat-icon style=\"font-size:40px; margin-bottom:10px; width:48px; height:48px;\r\n                display:flex; align-items:center; justify-content:center;\r\n                background:linear-gradient(135deg,#5de0e6,#004aad);\r\n                -webkit-background-clip:text; -webkit-text-fill-color:transparent;\r\n                background-clip:text; text-fill-color:transparent;\">{{ item.icon }}</mat-icon>\r\n                        <h6 style=\"font-size:14px; margin:0; color:#111827; text-align:center;\">\r\n                            {{ item.menu ? (item.menu | softLabelsPipe : softLabels) : (item.name | translate) }}\r\n                        </h6>\r\n                    </ng-container>\r\n\r\n                    <!-- External link -->\r\n                    <ng-container *ngIf=\"item.type === 'extLink'\">\r\n                        <a [href]=\"item.state\" target=\"_blank\" class=\"w-100 d-flex flex-column align-items-center\">\r\n                            <mat-icon style=\"font-size:40px; margin-bottom:10px; width:48px; height:48px;\r\n                  display:flex; align-items:center; justify-content:center;\r\n                  background:linear-gradient(135deg,#5de0e6,#004aad);\r\n                  -webkit-background-clip:text; -webkit-text-fill-color:transparent;\r\n                  background-clip:text; text-fill-color:transparent;\">{{ item.icon }}</mat-icon>\r\n                            <h6 style=\"font-size:14px; margin:0; color:#111827; text-align:center;\">\r\n                                {{ item.menu ? (item.menu | softLabelsPipe : softLabels) : (item.name | translate) }}\r\n                            </h6>\r\n                        </a>\r\n                    </ng-container>\r\n\r\n                    <!-- Dropdown (parent) -->\r\n                    <div *ngIf=\"item.type === 'dropDown'\"\r\n                        class=\"w-100 d-flex flex-column align-items-center cursor-pointer\"\r\n                        (click)=\"toggleDropdown(item)\">\r\n                        <mat-icon style=\"font-size:40px; margin-bottom:10px; width:48px; height:48px;\r\n                display:flex; align-items:center; justify-content:center;\r\n                background:linear-gradient(135deg,#5de0e6,#004aad);\r\n                -webkit-background-clip:text; -webkit-text-fill-color:transparent;\r\n                background-clip:text; text-fill-color:transparent;\">{{ item.icon }}</mat-icon>\r\n                        <h6 style=\"font-size:14px; margin:0; color:#111827; text-align:center;\">\r\n                            {{ item.menu ? (item.menu | softLabelsPipe : softLabels) : (item.name | translate) }}\r\n                        </h6>\r\n                        <mat-icon style=\"font-size:24px; margin-top:5px; width:32px; height:32px;\r\n                background:linear-gradient(135deg,#5de0e6,#004aad);\r\n                -webkit-background-clip:text; -webkit-text-fill-color:transparent;\r\n                background-clip:text; text-fill-color:transparent;\">\r\n                            {{ item.open ? 'expand_less' : 'expand_more' }}\r\n                        </mat-icon>\r\n                    </div>\r\n\r\n                    <!-- Badges -->\r\n                    <div *ngIf=\"item.badges?.length\" class=\"mt-2\">\r\n                        <span *ngFor=\"let badge of item.badges\" class=\"badge rounded-pill\"\r\n                            [ngStyle]=\"{ background: badge.color }\">\r\n                            {{ badge.value }}\r\n                        </span>\r\n                    </div>\r\n\r\n                </div>\r\n            </div>\r\n\r\n            <!-- Dropdown submenu as uniform cards -->\r\n            <div class=\"row w-100 mt-2\" *ngIf=\"item.open && item.type === 'dropDown'\">\r\n                <div class=\"col-6 col-md-3 mb-4\" *ngFor=\"let itemLvL2 of item.sub\">\r\n                    <div class=\"card cursor-pointer\" style=\"height:150px; border-radius:12px; transition:all 0.3s ease; background:#fff;\r\n                     box-shadow:0 2px 6px rgba(0,0,0,0.08); border:2px solid transparent;\"\r\n                        (click)=\"selectMenu(i, '/' + item.state + '/' + itemLvL2.state)\">\r\n                        <div class=\"card-body d-flex flex-column align-items-center justify-content-center\">\r\n                            <mat-icon style=\"font-size:40px; margin-bottom:10px; width:48px; height:48px;\r\n                  display:flex; align-items:center; justify-content:center;\r\n                  background:linear-gradient(135deg,#5de0e6,#004aad);\r\n                  -webkit-background-clip:text; -webkit-text-fill-color:transparent;\r\n                  background-clip:text; text-fill-color:transparent;\">{{ itemLvL2.icon }}</mat-icon>\r\n                            <h6 style=\"font-size:14px; margin:0; color:#111827; text-align:center;\">\r\n                                {{ itemLvL2.menu ? (itemLvL2.menu | softLabelsPipe : softLabels) : (itemLvL2.name |\r\n                                translate) }}\r\n                            </h6>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n\r\n        </div>\r\n    </div>\r\n</div>"]}
|