@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.
@@ -1,126 +1,225 @@
1
- import { Component, Input } from '@angular/core';
2
- import { select } from '@ngrx/store';
3
- import { NavigationEnd } from '@angular/router';
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';
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 "../../services/recentSearch.service";
14
- import * as i4 from "@angular/common";
15
- import * as i5 from "@angular/flex-layout/extended";
16
- import * as i6 from "@angular/material/icon";
17
- const _c0 = function (a0, a1, a2) { return { "background-color": a0, "border": a1, "box-shadow": a2, "border-radius": "12px", "transition": "all 0.3s ease" }; };
18
- function SideBarComponent_div_9_Template(rf, ctx) { if (rf & 1) {
19
- const _r4 = i0.ɵɵgetCurrentView();
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", 8);
22
- i0.ɵɵlistener("mouseenter", function SideBarComponent_div_9_Template_div_mouseenter_1_listener() { const restoredCtx = i0.ɵɵrestoreView(_r4); const i_r2 = restoredCtx.index; const ctx_r3 = i0.ɵɵnextContext(); return ctx_r3.enter(i_r2); })("mouseleave", function SideBarComponent_div_9_Template_div_mouseleave_1_listener() { const restoredCtx = i0.ɵɵrestoreView(_r4); const i_r2 = restoredCtx.index; const ctx_r5 = i0.ɵɵnextContext(); return ctx_r5.leave(i_r2); })("click", function SideBarComponent_div_9_Template_div_click_1_listener() { const restoredCtx = i0.ɵɵrestoreView(_r4); const i_r2 = restoredCtx.index; const ctx_r6 = i0.ɵɵnextContext(); return ctx_r6.selectMenu(i_r2); });
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", i0.ɵɵpureFunction3(4, _c0, ctx_r0.selectedRowIndex == i_r2 || ctx_r0.showBackGroundColor == i_r2 ? "#DBEAFE" : "#FFFFFF", ctx_r0.selectedRowIndex == i_r2 || ctx_r0.showBackGroundColor == i_r2 ? "2px solid #09555c" : "1px solid #E5E7EB", ctx_r0.selectedRowIndex == i_r2 || ctx_r0.showBackGroundColor == i_r2 ? "0 4px 15px rgba(0,0,0,0.15)" : "0 2px 6px rgba(0,0,0,0.08)"))("routerLink", item_r1.state);
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.ɵɵtextInterpolate(item_r1.menu);
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, recentSearchService) {
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
- this.loadSoftLabels();
58
- this.loadMenuItems();
59
- // Listen to route changes to update active menu
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.updateActiveRow();
186
+ this.menuItems$.subscribe(list => this.routerActive(list));
63
187
  }
64
188
  });
65
189
  }
66
- ngAfterViewInit() {
67
- const tooltipTriggerList = Array.from(document.querySelectorAll('[data-bs-toggle="tooltip"]'));
68
- tooltipTriggerList.forEach(el => new bootstrap.Tooltip(el));
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
- loadSoftLabels() {
71
- const stored = localStorage.getItem('SoftLabels');
72
- if (stored)
73
- this.softLabels = JSON.parse(stored);
202
+ leave(i) {
203
+ this.showBackGroundColor = null;
74
204
  }
75
- loadMenuItems() {
76
- // Try NgRx store first
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
- updateActiveRow() {
97
- if (this.items && this.items.length) {
98
- const index = this.items.findIndex(i => this.router.url === '/' + i.state);
99
- this.selectedRowIndex = index >= 0 ? index : null;
100
- if (this.router.url.includes('/dashboard-management'))
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), i0.ɵɵdirectiveInject(i3.RecentSearchService)); };
118
- SideBarComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: SideBarComponent, selectors: [["app-sidebar"]], inputs: { hasIconMenu: "hasIconMenu", iconMenuTitle: "iconMenuTitle" }, decls: 10, vars: 6, 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"], ["routerLink", "/dashboard-management", 1, "card", "h-100", "cursor-pointer", 3, "ngStyle", "mouseenter", "mouseleave", "click"], [1, "card-body", "d-flex", "flex-column", "align-items-center", "justify-content-center"], [2, "font-size", "40px", "color", "#09555c", "margin-bottom", "10px"], [2, "font-size", "14px", "margin", "0", "color", "#111827"], ["class", "col-6 col-md-3 mb-4", 4, "ngFor", "ngForOf"], [1, "card", "h-100", "cursor-pointer", 3, "ngStyle", "routerLink", "mouseenter", "mouseleave", "click"]], template: function SideBarComponent_Template(rf, ctx) { if (rf & 1) {
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, 7, 8, "div", 7);
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", i0.ɵɵpureFunction3(2, _c0, ctx.selectedRowIndex == 99 || ctx.showBackGroundColor == 99 ? "#DBEAFE" : "#FFFFFF", ctx.selectedRowIndex == 99 || ctx.showBackGroundColor == 99 ? "2px solid #09555c" : "1px solid #E5E7EB", ctx.selectedRowIndex == 99 || ctx.showBackGroundColor == 99 ? "0 4px 15px rgba(0,0,0,0.15)" : "0 2px 6px rgba(0,0,0,0.08)"));
239
+ i0.ɵɵproperty("ngStyle", (ctx.selectedRowIndex == 99 || ctx.showBackGroundColor == 99) && i0.ɵɵpureFunction0(4, _c1));
140
240
  i0.ɵɵadvance(6);
141
- i0.ɵɵproperty("ngForOf", ctx.items);
142
- } }, directives: [i2.RouterLink, i4.NgStyle, i5.DefaultStyleDirective, i6.MatIcon, i4.NgForOf], encapsulation: 2 });
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: 'app-sidebar',
147
- templateUrl: './side-bar.component.html'
246
+ selector: "app-sidebar",
247
+ templateUrl: "./side-bar.component.html"
148
248
  }]
149
- }], function () { return [{ type: i1.Store }, { type: i2.Router }, { type: i3.RecentSearchService }]; }, { hasIconMenu: [{
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>"]}