@thetradeengineorg1/snova-shell-module 0.0.262 → 1.0.1

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 (67) hide show
  1. package/bundles/thetradeengineorg1-snova-shell-module.umd.js +4522 -1014
  2. package/bundles/thetradeengineorg1-snova-shell-module.umd.js.map +1 -1
  3. package/esm2015/lib/globaldependencies/components/componentbase.js +9 -9
  4. package/esm2015/lib/globaldependencies/helpers/dom.helper.js +2 -1
  5. package/esm2015/lib/globaldependencies/helpers/moment-utc-date-adapter.js +11 -11
  6. package/esm2015/lib/globaldependencies/intercepter/jwt.interceptor.js +6 -6
  7. package/esm2015/lib/globaldependencies/pipes/fetchSizedAndCachedImage.pipe.js +11 -11
  8. package/esm2015/lib/globaldependencies/pipes/highLightText.pipe.js +13 -13
  9. package/esm2015/lib/globaldependencies/pipes/orderby-pipe.js +11 -11
  10. package/esm2015/lib/globaldependencies/pipes/removeSpecialCharacters.pipe.js +11 -11
  11. package/esm2015/lib/globaldependencies/pipes/sanitize.pipe.js +13 -13
  12. package/esm2015/lib/globaldependencies/pipes/softlabels.pipes.js +13 -13
  13. package/esm2015/lib/globaldependencies/pipes/utctolocaltime.pipe.js +11 -11
  14. package/esm2015/lib/globaldependencies/pipes/utctolocaltimewithdate.pipe.js +11 -11
  15. package/esm2015/lib/globaldependencies/pipes/workflowstatus.pipes.js +11 -11
  16. package/esm2015/lib/shell-components/components/Payments/account.component.js +91 -20
  17. package/esm2015/lib/shell-components/components/Payments/company-information.js +322 -26
  18. package/esm2015/lib/shell-components/components/Payments/company-plans.component.js +509 -11
  19. package/esm2015/lib/shell-components/components/Payments/document.component.js +90 -18
  20. package/esm2015/lib/shell-components/components/Payments/payment-method.component.js +76 -18
  21. package/esm2015/lib/shell-components/components/Payments/product-service.component.js +317 -22
  22. package/esm2015/lib/shell-components/components/Payments/purchase-more-licenses.js +119 -22
  23. package/esm2015/lib/shell-components/components/Payments/transactions.component.js +132 -20
  24. package/esm2015/lib/shell-components/components/admin-layout/admin-layout.component.js +79 -22
  25. package/esm2015/lib/shell-components/components/all-work-items-dialog/all-work-items-dialog.component.js +29 -16
  26. package/esm2015/lib/shell-components/components/confirmation-dialog/confirmation-dialog.component.js +55 -19
  27. package/esm2015/lib/shell-components/components/export-import-configuration/export-configuration.component.js +174 -29
  28. package/esm2015/lib/shell-components/components/feed-time/feed-time-dialog.component.js +29 -16
  29. package/esm2015/lib/shell-components/components/feed-time/feed-time.component.js +20 -16
  30. package/esm2015/lib/shell-components/components/header-side/header-side.component.js +443 -102
  31. package/esm2015/lib/shell-components/components/header-top/header-top.component.js +143 -22
  32. package/esm2015/lib/shell-components/components/lives/lives-welcome-page.js +39 -10
  33. package/esm2015/lib/shell-components/components/menu/menu.component.js +182 -83
  34. package/esm2015/lib/shell-components/components/notifications/announcement-dialog.component.js +57 -20
  35. package/esm2015/lib/shell-components/components/notifications/notifications.component.js +99 -14
  36. package/esm2015/lib/shell-components/components/sidebar-top/sidebar-top.component.js +19 -13
  37. package/esm2015/lib/shell-components/components/sidenav/side-bar.component.js +226 -57
  38. package/esm2015/lib/shell-components/components/sidenav/sidenav.component.js +419 -23
  39. package/esm2015/lib/shell-components/components/submit-feedback/submit-feedback.component.js +17 -13
  40. package/esm2015/lib/shell-components/services/authentication.service.js +7 -7
  41. package/esm2015/lib/shell-components/services/chat.service.js +9 -9
  42. package/esm2015/lib/shell-components/services/common-used.service.js +7 -7
  43. package/esm2015/lib/shell-components/services/feature.service.js +7 -7
  44. package/esm2015/lib/shell-components/services/google-analytics.service.js +6 -6
  45. package/esm2015/lib/shell-components/services/layout.service.js +6 -6
  46. package/esm2015/lib/shell-components/services/payment.service.js +7 -7
  47. package/esm2015/lib/shell-components/services/recentSearch.service.js +9 -9
  48. package/esm2015/lib/shell-components/services/shell.modules.service.js +11 -11
  49. package/esm2015/lib/shell-components/services/signalr.service.js +9 -9
  50. package/esm2015/lib/shell-components/services/theme.service.js +115 -182
  51. package/esm2015/lib/shell-components/shell.module.js +190 -201
  52. package/esm2015/lib/shell-components/store/effects/authentication.effects.js +9 -9
  53. package/esm2015/lib/shell-components/store/effects/chat.effects.js +6 -6
  54. package/esm2015/lib/shell-components/store/effects/menuitems.effects.js +6 -6
  55. package/esm2015/lib/shell-components/store/effects/notification-validator.effects.js +6 -6
  56. package/esm2015/lib/shell-components/store/effects/notifications.effects.js +6 -6
  57. package/esm2015/public-api.js +1 -3
  58. package/fesm2015/thetradeengineorg1-snova-shell-module.js +4208 -1238
  59. package/fesm2015/thetradeengineorg1-snova-shell-module.js.map +1 -1
  60. package/lib/shell-components/components/Payments/document.component.d.ts +1 -1
  61. package/lib/shell-components/components/header-side/header-side.component.d.ts +2 -6
  62. package/lib/shell-components/components/sidenav/side-bar.component.d.ts +16 -15
  63. package/lib/shell-components/shell.module.d.ts +42 -44
  64. package/package.json +5 -2
  65. package/public-api.d.ts +0 -2
  66. package/esm2015/lib/globaldependencies/components/avatar.component.js +0 -28
  67. package/lib/globaldependencies/components/avatar.component.d.ts +0 -10
@@ -1,8 +1,8 @@
1
1
  import { Component } from "@angular/core";
2
2
  import * as i0 from "@angular/core";
3
- import * as i1 from "../sidenav/sidenav.component";
4
- import * as i2 from "@angular/flex-layout/flex";
5
- import * as i3 from "ngx-perfect-scrollbar";
3
+ import * as i1 from "@angular/flex-layout/flex";
4
+ import * as i2 from "ngx-perfect-scrollbar";
5
+ import * as i3 from "../sidenav/sidenav.component";
6
6
  // import PerfectScrollbar from 'perfect-scrollbar';
7
7
  export class SidebarTopComponent {
8
8
  // private sidebarPS: PerfectScrollbar;
@@ -21,13 +21,19 @@ export class SidebarTopComponent {
21
21
  // }
22
22
  }
23
23
  }
24
- SidebarTopComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.1", ngImport: i0, type: SidebarTopComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
25
- SidebarTopComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.1", type: SidebarTopComponent, selector: "app-sidebar-top", ngImport: i0, template: "<div class=\"sidebar-panel\">\r\n <div id=\"sidebar-top-scroll-area\" [perfectScrollbar] class=\"navigation-hold\" fxLayout=\"column\">\r\n <app-sidenav></app-sidenav>\r\n </div>\r\n</div>", components: [{ type: i1.SidenavComponent, selector: "app-sidenav", inputs: ["hasIconMenu", "iconMenuTitle"] }], directives: [{ type: i2.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { type: i3.PerfectScrollbarDirective, selector: "[perfectScrollbar]", inputs: ["disabled", "perfectScrollbar"], outputs: ["psScrollY", "psScrollX", "psScrollUp", "psScrollDown", "psScrollLeft", "psScrollRight", "psYReachEnd", "psYReachStart", "psXReachEnd", "psXReachStart"], exportAs: ["ngxPerfectScrollbar"] }] });
26
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.1", ngImport: i0, type: SidebarTopComponent, decorators: [{
27
- type: Component,
28
- args: [{
29
- selector: "app-sidebar-top",
30
- templateUrl: "./sidebar-top.component.html"
31
- }]
32
- }], ctorParameters: function () { return []; } });
33
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZWJhci10b3AuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vc2hlbGwtbW9kdWxlLWNvbXBvbmVudHMvc2hlbGwtY29tcG9uZW50cy9zcmMvbGliL3NoZWxsLWNvbXBvbmVudHMvY29tcG9uZW50cy9zaWRlYmFyLXRvcC9zaWRlYmFyLXRvcC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zaGVsbC1tb2R1bGUtY29tcG9uZW50cy9zaGVsbC1jb21wb25lbnRzL3NyYy9saWIvc2hlbGwtY29tcG9uZW50cy9jb21wb25lbnRzL3NpZGViYXItdG9wL3NpZGViYXItdG9wLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQW9DLE1BQU0sZUFBZSxDQUFDOzs7OztBQUM1RSxvREFBb0Q7QUFPcEQsTUFBTSxPQUFPLG1CQUFtQjtJQUM5Qix1Q0FBdUM7SUFDdkMsZ0JBQWUsQ0FBQztJQUVoQixRQUFRLEtBQUksQ0FBQztJQUViLGVBQWU7UUFDYixxQkFBcUI7UUFDckIsd0VBQXdFO1FBQ3hFLDRCQUE0QjtRQUM1QixPQUFPO1FBQ1AsS0FBSztJQUNQLENBQUM7SUFFRCxXQUFXO1FBQ1QsdUJBQXVCO1FBQ3ZCLDhCQUE4QjtRQUM5QixJQUFJO0lBQ04sQ0FBQzs7Z0hBbEJVLG1CQUFtQjtvR0FBbkIsbUJBQW1CLHVEQ1JoQyxtTUFJTTsyRkRJTyxtQkFBbUI7a0JBTC9CLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGlCQUFpQjtvQkFDM0IsV0FBVyxFQUFFLDhCQUE4QjtpQkFDNUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCwgT25EZXN0cm95LCBBZnRlclZpZXdJbml0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuLy8gaW1wb3J0IFBlcmZlY3RTY3JvbGxiYXIgZnJvbSAncGVyZmVjdC1zY3JvbGxiYXInO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6IFwiYXBwLXNpZGViYXItdG9wXCIsXHJcbiAgdGVtcGxhdGVVcmw6IFwiLi9zaWRlYmFyLXRvcC5jb21wb25lbnQuaHRtbFwiXHJcbn0pXHJcblxyXG5leHBvcnQgY2xhc3MgU2lkZWJhclRvcENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95LCBBZnRlclZpZXdJbml0IHtcclxuICAvLyBwcml2YXRlIHNpZGViYXJQUzogUGVyZmVjdFNjcm9sbGJhcjtcclxuICBjb25zdHJ1Y3RvcigpIHt9XHJcblxyXG4gIG5nT25Jbml0KCkge31cclxuXHJcbiAgbmdBZnRlclZpZXdJbml0KCkge1xyXG4gICAgLy8gc2V0VGltZW91dCgoKSA9PiB7XHJcbiAgICAvLyAgIHRoaXMuc2lkZWJhclBTID0gbmV3IFBlcmZlY3RTY3JvbGxiYXIoJyNzaWRlYmFyLXRvcC1zY3JvbGwtYXJlYScsIHtcclxuICAgIC8vICAgICBzdXBwcmVzc1Njcm9sbFg6IHRydWVcclxuICAgIC8vICAgfSlcclxuICAgIC8vIH0pXHJcbiAgfVxyXG5cclxuICBuZ09uRGVzdHJveSgpIHtcclxuICAgIC8vIGlmKHRoaXMuc2lkZWJhclBTKSB7XHJcbiAgICAvLyAgIHRoaXMuc2lkZWJhclBTLmRlc3Ryb3koKTtcclxuICAgIC8vIH1cclxuICB9XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cInNpZGViYXItcGFuZWxcIj5cclxuICA8ZGl2IGlkPVwic2lkZWJhci10b3Atc2Nyb2xsLWFyZWFcIiBbcGVyZmVjdFNjcm9sbGJhcl0gY2xhc3M9XCJuYXZpZ2F0aW9uLWhvbGRcIiBmeExheW91dD1cImNvbHVtblwiPlxyXG4gICAgPGFwcC1zaWRlbmF2PjwvYXBwLXNpZGVuYXY+XHJcbiAgPC9kaXY+XHJcbjwvZGl2PiJdfQ==
24
+ SidebarTopComponent.ɵfac = function SidebarTopComponent_Factory(t) { return new (t || SidebarTopComponent)(); };
25
+ SidebarTopComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: SidebarTopComponent, selectors: [["app-sidebar-top"]], decls: 3, vars: 0, consts: [[1, "sidebar-panel"], ["id", "sidebar-top-scroll-area", "fxLayout", "column", 1, "navigation-hold", 3, "perfectScrollbar"]], template: function SidebarTopComponent_Template(rf, ctx) { if (rf & 1) {
26
+ i0.ɵɵelementStart(0, "div", 0);
27
+ i0.ɵɵelementStart(1, "div", 1);
28
+ i0.ɵɵelement(2, "app-sidenav");
29
+ i0.ɵɵelementEnd();
30
+ i0.ɵɵelementEnd();
31
+ } }, directives: [i1.DefaultLayoutDirective, i2.PerfectScrollbarDirective, i3.SidenavComponent], encapsulation: 2 });
32
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SidebarTopComponent, [{
33
+ type: Component,
34
+ args: [{
35
+ selector: "app-sidebar-top",
36
+ templateUrl: "./sidebar-top.component.html"
37
+ }]
38
+ }], function () { return []; }, null); })();
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZWJhci10b3AuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vc2hlbGwtbW9kdWxlLWNvbXBvbmVudHMvc2hlbGwtY29tcG9uZW50cy9zcmMvbGliL3NoZWxsLWNvbXBvbmVudHMvY29tcG9uZW50cy9zaWRlYmFyLXRvcC9zaWRlYmFyLXRvcC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zaGVsbC1tb2R1bGUtY29tcG9uZW50cy9zaGVsbC1jb21wb25lbnRzL3NyYy9saWIvc2hlbGwtY29tcG9uZW50cy9jb21wb25lbnRzL3NpZGViYXItdG9wL3NpZGViYXItdG9wLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQW9DLE1BQU0sZUFBZSxDQUFDOzs7OztBQUM1RSxvREFBb0Q7QUFPcEQsTUFBTSxPQUFPLG1CQUFtQjtJQUM5Qix1Q0FBdUM7SUFDdkMsZ0JBQWUsQ0FBQztJQUVoQixRQUFRLEtBQUksQ0FBQztJQUViLGVBQWU7UUFDYixxQkFBcUI7UUFDckIsd0VBQXdFO1FBQ3hFLDRCQUE0QjtRQUM1QixPQUFPO1FBQ1AsS0FBSztJQUNQLENBQUM7SUFFRCxXQUFXO1FBQ1QsdUJBQXVCO1FBQ3ZCLDhCQUE4QjtRQUM5QixJQUFJO0lBQ04sQ0FBQzs7c0ZBbEJVLG1CQUFtQjtzRUFBbkIsbUJBQW1CO1FDUmhDLDhCQUEyQjtRQUN6Qiw4QkFBK0Y7UUFDN0YsOEJBQTJCO1FBQzdCLGlCQUFNO1FBQ1IsaUJBQU07O3VGRElPLG1CQUFtQjtjQUwvQixTQUFTO2VBQUM7Z0JBQ1QsUUFBUSxFQUFFLGlCQUFpQjtnQkFDM0IsV0FBVyxFQUFFLDhCQUE4QjthQUM1QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0LCBPbkRlc3Ryb3ksIEFmdGVyVmlld0luaXQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG4vLyBpbXBvcnQgUGVyZmVjdFNjcm9sbGJhciBmcm9tICdwZXJmZWN0LXNjcm9sbGJhcic7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogXCJhcHAtc2lkZWJhci10b3BcIixcclxuICB0ZW1wbGF0ZVVybDogXCIuL3NpZGViYXItdG9wLmNvbXBvbmVudC5odG1sXCJcclxufSlcclxuXHJcbmV4cG9ydCBjbGFzcyBTaWRlYmFyVG9wQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3ksIEFmdGVyVmlld0luaXQge1xyXG4gIC8vIHByaXZhdGUgc2lkZWJhclBTOiBQZXJmZWN0U2Nyb2xsYmFyO1xyXG4gIGNvbnN0cnVjdG9yKCkge31cclxuXHJcbiAgbmdPbkluaXQoKSB7fVxyXG5cclxuICBuZ0FmdGVyVmlld0luaXQoKSB7XHJcbiAgICAvLyBzZXRUaW1lb3V0KCgpID0+IHtcclxuICAgIC8vICAgdGhpcy5zaWRlYmFyUFMgPSBuZXcgUGVyZmVjdFNjcm9sbGJhcignI3NpZGViYXItdG9wLXNjcm9sbC1hcmVhJywge1xyXG4gICAgLy8gICAgIHN1cHByZXNzU2Nyb2xsWDogdHJ1ZVxyXG4gICAgLy8gICB9KVxyXG4gICAgLy8gfSlcclxuICB9XHJcblxyXG4gIG5nT25EZXN0cm95KCkge1xyXG4gICAgLy8gaWYodGhpcy5zaWRlYmFyUFMpIHtcclxuICAgIC8vICAgdGhpcy5zaWRlYmFyUFMuZGVzdHJveSgpO1xyXG4gICAgLy8gfVxyXG4gIH1cclxufVxyXG4iLCI8ZGl2IGNsYXNzPVwic2lkZWJhci1wYW5lbFwiPlxyXG4gIDxkaXYgaWQ9XCJzaWRlYmFyLXRvcC1zY3JvbGwtYXJlYVwiIFtwZXJmZWN0U2Nyb2xsYmFyXSBjbGFzcz1cIm5hdmlnYXRpb24taG9sZFwiIGZ4TGF5b3V0PVwiY29sdW1uXCI+XHJcbiAgICA8YXBwLXNpZGVuYXY+PC9hcHAtc2lkZW5hdj5cclxuICA8L2Rpdj5cclxuPC9kaXY+Il19
@@ -1,60 +1,197 @@
1
- import { Component } from '@angular/core';
2
- import { NavigationEnd } from '@angular/router';
3
- import { LocalStorageProperties } from '../../../globaldependencies/constants/localstorage-properties';
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";
4
8
  import * as i0 from "@angular/core";
5
- import * as i1 from "../../services/recentSearch.service";
9
+ import * as i1 from "@ngrx/store";
6
10
  import * as i2 from "@angular/router";
7
- import * as i3 from "@angular/material/icon";
8
- import * as i4 from "@angular/common";
9
- import * as i5 from "@angular/flex-layout/extended";
11
+ import * as i3 from "@angular/common";
12
+ import * as i4 from "@angular/flex-layout/extended";
13
+ import * as i5 from "@angular/material/icon";
10
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();
106
+ i0.ɵɵelementStart(0, "div", 2);
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); });
109
+ i0.ɵɵelementStart(2, "div", 4);
110
+ i0.ɵɵelementStart(3, "mat-icon", 5);
111
+ i0.ɵɵtext(4);
112
+ i0.ɵɵelementEnd();
113
+ i0.ɵɵelementStart(5, "h6", 6);
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);
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);
149
+ i0.ɵɵelementEnd();
150
+ i0.ɵɵelementEnd();
151
+ i0.ɵɵtemplate(7, SideBarComponent_div_9_div_7_Template, 2, 1, "div", 11);
152
+ i0.ɵɵelementEnd();
153
+ } if (rf & 2) {
154
+ const item_r1 = ctx.$implicit;
155
+ const i_r2 = ctx.index;
156
+ const ctx_r0 = i0.ɵɵnextContext();
157
+ i0.ɵɵadvance(1);
158
+ i0.ɵɵproperty("ngStyle", (ctx_r0.selectedRowIndex == i_r2 || ctx_r0.showBackGroundColor == i_r2) && i0.ɵɵpureFunction0(6, _c1));
159
+ i0.ɵɵadvance(2);
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");
169
+ } }
11
170
  export class SideBarComponent {
12
- constructor(recentSearchService, router) {
13
- this.recentSearchService = recentSearchService;
171
+ constructor(store, router) {
172
+ this.store = store;
14
173
  this.router = router;
15
- this.menuItem = [];
16
- this.items = [];
174
+ this.showBackGroundColor = null;
17
175
  }
18
176
  ngOnInit() {
19
- this.router.events
20
- .subscribe((event) => {
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
184
+ this.router.events.subscribe(event => {
21
185
  if (event instanceof NavigationEnd) {
22
- this.routerActive();
186
+ this.menuItems$.subscribe(list => this.routerActive(list));
23
187
  }
24
188
  });
25
- this.getSoftLabelConfigurations();
26
- this.getMenuItems();
27
- }
28
- getSoftLabelConfigurations() {
29
- this.softLabels = JSON.parse(localStorage.getItem('SoftLabels'));
30
189
  }
31
- getMenuItems() {
32
- var retrieveDashboards = false;
33
- this.menuItem = JSON.parse(localStorage.getItem(LocalStorageProperties.SideBarMenuItems));
34
- if (!this.menuItem) {
35
- this.recentSearchService.searchMenuData(retrieveDashboards).subscribe((response) => {
36
- if (response.success) {
37
- let data = response.data;
38
- var menuItems = data ? data.menuItems : null;
39
- if (menuItems && menuItems != null) {
40
- this.menuItem = menuItems;
41
- localStorage.setItem(LocalStorageProperties.SideBarMenuItems, JSON.stringify(this.menuItem));
42
- this.items = this.menuItem.filter(item => item.type != "dropDown");
43
- this.routerActive();
44
- }
45
- }
46
- });
47
- }
48
- else {
49
- this.items = this.menuItem.filter(item => item.type != "dropDown");
50
- this.routerActive();
51
- }
52
- }
53
- routerActive() {
54
- if (this.items && this.items.length > 0) {
55
- var index = this.items.findIndex(i => this.router.url == "/" + i.state);
190
+ routerActive(menuList) {
191
+ if (menuList && menuList.length > 0) {
192
+ const index = menuList.findIndex(i => this.router.url == "/" + i.state);
56
193
  this.selectedRowIndex = index;
57
- if (this.router.url.includes('/dashboard-management')) {
194
+ if (this.router.url.includes("/dashboard-management")) {
58
195
  this.selectedRowIndex = 99;
59
196
  }
60
197
  }
@@ -65,17 +202,49 @@ export class SideBarComponent {
65
202
  leave(i) {
66
203
  this.showBackGroundColor = null;
67
204
  }
68
- openMenu(link) {
69
- this.router.navigate([link]);
205
+ toggleDropdown(item) {
206
+ item.open = !item.open;
207
+ }
208
+ // ✅ NEW: unified method
209
+ selectMenu(index, link) {
210
+ this.selectedRowIndex = index;
211
+ if (link) {
212
+ this.router.navigate([link]);
213
+ }
70
214
  }
71
215
  }
72
- SideBarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.1", ngImport: i0, type: SideBarComponent, deps: [{ token: i1.RecentSearchService }, { token: i2.Router }], target: i0.ɵɵFactoryTarget.Component });
73
- SideBarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.1", type: SideBarComponent, selector: "app-sidebar", ngImport: i0, template: "<ul appDropdown class=\"sidenav\" style=\"padding-left: 0px;width: 62px;\">\r\n <li appDropdownLink routerLinkActive=\"open\" class=\"li-menu\" style=\"list-style: none;\"\r\n (mouseenter)=\"enter(99)\" (mouseleave)=\"leave(99)\" [ngClass]=\"(selectedRowIndex == 99 || showBackGroundColor == 99) ? 'menu-highlight' : ''\"\r\n [style.background-color]=\"(selectedRowIndex == 99 || showBackGroundColor == 99) ? '#70C8C1' : ''\">\r\n <div routerLink=\"/dashboard-management\" class=\"cursor-pointer div-menu\">\r\n <a appDropdownToggle matRipple style=\"font-size: 15px;\">\r\n <mat-icon class=\"mat-icon-color\"\r\n style=\"text-align: center;margin-right: 3px;height: 36px;width: 36px;line-height: 36px;border-left: 18px solid;border-color: transparent;\">\r\n home</mat-icon>\r\n <div style=\"font-size: 11px !important;text-align: center;\" class=\"menu-text-color\">Home</div>\r\n </a>\r\n </div>\r\n </li>\r\n <li *ngFor=\"let item of items; let i = index;\" appDropdownLink routerLinkActive=\"open\" [routerLinkActiveOptions]=\"{exact:\r\n true}\" class=\"li-menu\"\r\n style=\"list-style: none;\" [ngClass]=\"(selectedRowIndex == i || showBackGroundColor == i) ? 'menu-highlight' : ''\"\r\n [style.background-color]=\"(selectedRowIndex == i || showBackGroundColor == i) ? '#70C8C1' : ''\">\r\n <div *ngIf=\"item.type == 'link' || item.type == 'applicationlink'\" (mouseenter)=\"enter(i)\" [routerLink]=\"item.state\"\r\n (mouseleave)=\"leave(i)\" class=\"cursor-pointer div-menu\" (click)=\"openMenu(item.state)\">\r\n <a appDropdownToggle matRipple *ngIf=\"item.type === 'link'\"\r\n style=\"font-size: 15px;\">\r\n <mat-icon class=\"mat-icon-color\"\r\n style=\"text-align: center;margin-right: 3px;height: 36px;width: 36px;line-height: 36px;border-left: 18px solid;border-color: transparent;\">\r\n {{ item.icon }}</mat-icon>\r\n <div style=\"font-size: 11px !important;text-align: center;\" class=\"menu-text-color\">\r\n {{item.menu | softLabelsPipe : softLabels}}</div>\r\n </a>\r\n </div>\r\n </li>\r\n</ul>\r\n<!-- <div [style.background-color]=\"(selectedRowIndex == i || showBackGroundColor == i) ? 'rgba(0,0,0,0.4)' : themeBaseColor\"></div> -->", components: [{ type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i2.RouterLinkActive, selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "routerLinkActive"], exportAs: ["routerLinkActive"] }, { type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i5.DefaultClassDirective, selector: " [ngClass], [ngClass.xs], [ngClass.sm], [ngClass.md], [ngClass.lg], [ngClass.xl], [ngClass.lt-sm], [ngClass.lt-md], [ngClass.lt-lg], [ngClass.lt-xl], [ngClass.gt-xs], [ngClass.gt-sm], [ngClass.gt-md], [ngClass.gt-lg]", inputs: ["ngClass", "ngClass.xs", "ngClass.sm", "ngClass.md", "ngClass.lg", "ngClass.xl", "ngClass.lt-sm", "ngClass.lt-md", "ngClass.lt-lg", "ngClass.lt-xl", "ngClass.gt-xs", "ngClass.gt-sm", "ngClass.gt-md", "ngClass.gt-lg"] }, { type: i2.RouterLink, selector: ":not(a):not(area)[routerLink]", inputs: ["routerLink", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo"] }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "softLabelsPipe": i6.SoftLabelPipe } });
74
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.1", ngImport: i0, type: SideBarComponent, decorators: [{
75
- type: Component,
76
- args: [{
77
- selector: "app-sidebar",
78
- templateUrl: "./side-bar.component.html"
79
- }]
80
- }], ctorParameters: function () { return [{ type: i1.RecentSearchService }, { type: i2.Router }]; } });
81
- //# 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 { NavigationEnd, Router } from '@angular/router';\r\nimport { LocalStorageProperties } from '../../../globaldependencies/constants/localstorage-properties';\r\nimport { SoftLabelConfigurationModel } from '../../models/softlabels-model';\r\nimport { RecentSearchService } from '../../services/recentSearch.service';\r\n\r\n@Component({\r\n    selector: \"app-sidebar\",\r\n    templateUrl: \"./side-bar.component.html\"\r\n})\r\n\r\nexport class SideBarComponent {\r\n    menuItem: any[] = [];\r\n    items: any[] = [];\r\n    selectedRowIndex: any;\r\n    showBackGroundColor: number;\r\n    softLabels: SoftLabelConfigurationModel[];\r\n\r\n    constructor(private recentSearchService: RecentSearchService, private router: Router) {\r\n\r\n    }\r\n\r\n    ngOnInit() {\r\n        this.router.events\r\n      .subscribe(\r\n        (event: any) => {\r\n          if (event instanceof NavigationEnd) {\r\n            this.routerActive();\r\n          }\r\n        });\r\n        this.getSoftLabelConfigurations();\r\n        this.getMenuItems();\r\n    }\r\n\r\n    getSoftLabelConfigurations() {\r\n        this.softLabels = JSON.parse(localStorage.getItem('SoftLabels'));\r\n      }\r\n\r\n    getMenuItems() {\r\n        var retrieveDashboards = false\r\n        this.menuItem = JSON.parse(localStorage.getItem(LocalStorageProperties.SideBarMenuItems));\r\n\r\n        if (!this.menuItem) {\r\n            this.recentSearchService.searchMenuData(retrieveDashboards).subscribe((response: any) => {\r\n                if (response.success) {\r\n                    let data = response.data;\r\n                    var menuItems = data ? data.menuItems : null;\r\n                    if (menuItems && menuItems != null) {\r\n                        this.menuItem = menuItems;\r\n                        localStorage.setItem(LocalStorageProperties.SideBarMenuItems, JSON.stringify(this.menuItem));\r\n                        this.items = this.menuItem.filter(item => item.type != \"dropDown\");\r\n                        this.routerActive();\r\n                    }\r\n                }\r\n            });\r\n        }\r\n        else {\r\n            this.items = this.menuItem.filter(item => item.type != \"dropDown\");\r\n            this.routerActive();\r\n        }\r\n    }\r\n\r\n    routerActive() {\r\n        if (this.items && this.items.length > 0) {\r\n            var index = this.items.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) {\r\n        this.showBackGroundColor = i;\r\n    }\r\n\r\n    leave(i) {\r\n        this.showBackGroundColor = null;\r\n    }\r\n\r\n    openMenu(link){\r\n        this.router.navigate([link]);\r\n    }\r\n    \r\n}\r\n","<ul appDropdown class=\"sidenav\" style=\"padding-left: 0px;width: 62px;\">\r\n    <li appDropdownLink routerLinkActive=\"open\" class=\"li-menu\" style=\"list-style: none;\"\r\n        (mouseenter)=\"enter(99)\" (mouseleave)=\"leave(99)\" [ngClass]=\"(selectedRowIndex == 99 || showBackGroundColor == 99) ? 'menu-highlight' : ''\"\r\n        [style.background-color]=\"(selectedRowIndex == 99 || showBackGroundColor == 99) ? '#70C8C1' : ''\">\r\n        <div routerLink=\"/dashboard-management\" class=\"cursor-pointer div-menu\">\r\n            <a appDropdownToggle matRipple style=\"font-size: 15px;\">\r\n                <mat-icon class=\"mat-icon-color\"\r\n                    style=\"text-align: center;margin-right: 3px;height: 36px;width: 36px;line-height: 36px;border-left: 18px solid;border-color: transparent;\">\r\n                    home</mat-icon>\r\n                <div style=\"font-size: 11px !important;text-align: center;\" class=\"menu-text-color\">Home</div>\r\n            </a>\r\n        </div>\r\n    </li>\r\n    <li *ngFor=\"let item of items; let i = index;\" appDropdownLink routerLinkActive=\"open\" [routerLinkActiveOptions]=\"{exact:\r\n        true}\" class=\"li-menu\"\r\n        style=\"list-style: none;\" [ngClass]=\"(selectedRowIndex == i || showBackGroundColor == i) ? 'menu-highlight' : ''\"\r\n        [style.background-color]=\"(selectedRowIndex == i || showBackGroundColor == i) ? '#70C8C1' : ''\">\r\n        <div *ngIf=\"item.type == 'link' || item.type == 'applicationlink'\" (mouseenter)=\"enter(i)\" [routerLink]=\"item.state\"\r\n            (mouseleave)=\"leave(i)\" class=\"cursor-pointer div-menu\" (click)=\"openMenu(item.state)\">\r\n            <a appDropdownToggle matRipple *ngIf=\"item.type === 'link'\"\r\n                style=\"font-size: 15px;\">\r\n                <mat-icon class=\"mat-icon-color\"\r\n                    style=\"text-align: center;margin-right: 3px;height: 36px;width: 36px;line-height: 36px;border-left: 18px solid;border-color: transparent;\">\r\n                    {{ item.icon }}</mat-icon>\r\n                <div style=\"font-size: 11px !important;text-align: center;\" class=\"menu-text-color\">\r\n                    {{item.menu | softLabelsPipe : softLabels}}</div>\r\n            </a>\r\n        </div>\r\n    </li>\r\n</ul>\r\n<!-- <div [style.background-color]=\"(selectedRowIndex == i || showBackGroundColor == i) ? 'rgba(0,0,0,0.4)' : themeBaseColor\"></div> -->"]}
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) {
218
+ i0.ɵɵelementStart(0, "div", 0);
219
+ i0.ɵɵelementStart(1, "div", 1);
220
+ i0.ɵɵelementStart(2, "div", 2);
221
+ i0.ɵɵelementStart(3, "div", 3);
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"); });
223
+ i0.ɵɵelementStart(4, "div", 4);
224
+ i0.ɵɵelementStart(5, "mat-icon", 5);
225
+ i0.ɵɵtext(6, "home");
226
+ i0.ɵɵelementEnd();
227
+ i0.ɵɵelementStart(7, "h6", 6);
228
+ i0.ɵɵtext(8, "Home");
229
+ i0.ɵɵelementEnd();
230
+ i0.ɵɵelementEnd();
231
+ i0.ɵɵelementEnd();
232
+ i0.ɵɵelementEnd();
233
+ i0.ɵɵtemplate(9, SideBarComponent_div_9_Template, 8, 7, "div", 7);
234
+ i0.ɵɵpipe(10, "async");
235
+ i0.ɵɵelementEnd();
236
+ i0.ɵɵelementEnd();
237
+ } if (rf & 2) {
238
+ i0.ɵɵadvance(3);
239
+ i0.ɵɵproperty("ngStyle", (ctx.selectedRowIndex == 99 || ctx.showBackGroundColor == 99) && i0.ɵɵpureFunction0(4, _c1));
240
+ i0.ɵɵadvance(6);
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 });
243
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SideBarComponent, [{
244
+ type: Component,
245
+ args: [{
246
+ selector: "app-sidebar",
247
+ templateUrl: "./side-bar.component.html"
248
+ }]
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>"]}