@thetradeengineorg1/snova-shell-module 1.0.7 → 1.0.8

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.
@@ -63,6 +63,9 @@ export class SideBarComponent {
63
63
  if (this.router.url.startsWith("/dashboard-management/dashboard")) {
64
64
  this.selectedRowIndex = 99;
65
65
  }
66
+ else {
67
+ this.selectedRowIndex = null; // ensures no preselected Report card
68
+ }
66
69
  }
67
70
  /** hover enter */
68
71
  enter(index) {
@@ -105,4 +108,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.1", ngImpor
105
108
  templateUrl: "./side-bar.component.html"
106
109
  }]
107
110
  }], ctorParameters: function () { return [{ type: i1.Store }, { type: i2.Router }]; } });
108
- //# 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, OnInit } from \"@angular/core\";\r\nimport { Router, NavigationEnd } from \"@angular/router\";\r\nimport { Store, select } from \"@ngrx/store\";\r\nimport { Observable } from \"rxjs\";\r\nimport { map, tap } from \"rxjs/operators\";\r\n\r\nimport { State } from \"../../store/reducers\";\r\nimport * as sharedReducers from \"../../store/reducers\";\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 implements OnInit {\r\n    /** menu items observable */\r\n    menuItems$: Observable<IMenuItem[]>;\r\n    /** index of selected card */\r\n    selectedRowIndex: number | null = null;\r\n    /** index of hovered card */\r\n    showBackGroundColor: number | null = null;\r\n    /** soft labels for translations */\r\n    softLabels: SoftLabelConfigurationModel[] = [];\r\n\r\n    constructor(private store: Store<State>, private router: Router) { }\r\n\r\n    ngOnInit(): void {\r\n        // load soft label translations\r\n        const storedLabels = localStorage.getItem(\"SoftLabels\");\r\n        this.softLabels = storedLabels ? JSON.parse(storedLabels) : [];\r\n\r\n        // select & filter sidebar menu items from store\r\n        this.menuItems$ = this.store.pipe(\r\n            select(sharedReducers.getCurrentActiveMenuCategoryMenuItems),\r\n            map((list) =>\r\n                list.filter((item) => {\r\n                    const menuLabel = (item as any).menu?.toLowerCase() || \"\";\r\n                    const state = item.state?.toLowerCase() || \"\";\r\n\r\n                    // Exclude HR, tracker or unwanted items\r\n                    if (menuLabel === \"hr\" || state.startsWith(\"hrmanagment/employeelist\")) return false;\r\n                    if (menuLabel.includes(\"hr managment\") || menuLabel.includes(\"hr management\")) return false;\r\n                    if (state.startsWith(\"hrmanagment\") || state.startsWith(\"hrmdetails\")) return false;\r\n                    if (menuLabel.includes(\"activity tracker\") || state.startsWith(\"activitytracker\")) return false;\r\n                    return true;\r\n                })\r\n            ),\r\n            tap((menuList) => this.routerActive(menuList))\r\n        );\r\n\r\n        // dispatch load event\r\n        this.store.dispatch(new GetAllMenuItemsTriggered(MenuCategories.Main));\r\n\r\n        // listen for route changes to update highlight\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    /** highlights the active card according to current route */\r\n    private routerActive(menuList: IMenuItem[]): void {\r\n        if (!menuList?.length) return;\r\n\r\n        const foundIndex = menuList.findIndex((i) => this.router.url === \"/\" + i.state);\r\n        this.selectedRowIndex = foundIndex >= 0 ? foundIndex : null;\r\n\r\n        // Highlight report card when inside any dashboard route\r\n        if (this.router.url.startsWith(\"/dashboard-management/dashboard\")) {\r\n            this.selectedRowIndex = 99;\r\n        }\r\n    }\r\n\r\n    /** hover enter */\r\n    enter(index: number): void {\r\n        this.showBackGroundColor = index;\r\n    }\r\n\r\n    /** hover leave */\r\n    leave(index: number): void {\r\n        if (this.showBackGroundColor === index) {\r\n            this.showBackGroundColor = null;\r\n        }\r\n    }\r\n\r\n    /** when clicking on dynamic menu card */\r\n    selectMenu(index: number, link?: string): void {\r\n        this.selectedRowIndex = index;\r\n        if (link) {\r\n            // ensure forward slash\r\n            const path = link.startsWith(\"/\") ? link : \"/\" + link;\r\n            this.router.navigate([path]);\r\n        }\r\n    }\r\n\r\n    /** open report dashboard-management/dashboard/:id or root */\r\n    goToReport(): void {\r\n        this.selectedRowIndex = 99;\r\n\r\n        const stored = localStorage.getItem(\"DefaultDashboard\");\r\n        const defaultDashboardId = stored ? JSON.parse(stored) : null;\r\n\r\n        if (defaultDashboardId) {\r\n            this.router.navigate([`/dashboard-management/dashboard/${defaultDashboardId}`]);\r\n        } else {\r\n            this.router.navigate([\"/dashboard-management\"]);\r\n        }\r\n    }\r\n}\r\n","<div class=\"d-flex flex-column justify-content-center align-items-center\" style=\"width:100vw; height:calc(100vh - 60px); padding:30px; overflow:auto;\r\n            background: linear-gradient(rgba(255,255,255,0.7), rgba(255,255,255,0.7));\">\r\n\r\n    <div class=\"row justify-content-center align-items-center\" style=\"height:auto;\">\r\n\r\n        <!-- Fixed Report 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;\r\n                      background:#fff; box-shadow:0 2px 6px rgba(0,0,0,0.08);\r\n                      border:2px solid rgba(241, 88, 12, 0.25);\" (mouseenter)=\"enter(99)\" (mouseleave)=\"leave(99)\"\r\n                (click)=\"goToReport()\" [ngStyle]=\"(selectedRowIndex == 99 || showBackGroundColor == 99) && {\r\n                 'background-color':'#fff',\r\n                 'border':'2px solid #f1580c',\r\n                 'box-shadow':'0 6px 20px rgba(241, 88, 12, 0.35), 0 0 10px rgba(241, 88, 12, 0.25)'\r\n               }\">\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,#f79a6b,#f1580c);\r\n                               -webkit-background-clip:text; -webkit-text-fill-color:transparent;\r\n                               background-clip:text; text-fill-color:transparent;\">\r\n                        assessment\r\n                    </mat-icon>\r\n                    <h6 style=\"font-size:14px; margin:0; color:#111827; text-align:center;\">Report</h6>\r\n                </div>\r\n            </div>\r\n        </div>\r\n\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;\r\n                  background:#fff; box-shadow:0 2px 6px rgba(0,0,0,0.08);\r\n                  border:2px solid rgba(241, 88, 12, 0.25);\" (mouseenter)=\"enter(i)\" (mouseleave)=\"leave(i)\"\r\n                (click)=\"selectMenu(i, item.state)\" [ngStyle]=\"(selectedRowIndex == i || showBackGroundColor == i) && {\r\n              'background-color':'#fff',\r\n              'border':'2px solid #f1580c',\r\n              'box-shadow':'0 6px 20px rgba(241, 88, 12, 0.35), 0 0 10px rgba(241, 88, 12, 0.25)'\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,#f79a6b,#f1580c);\r\n                             -webkit-background-clip:text; -webkit-text-fill-color:transparent;\r\n                             background-clip:text; text-fill-color:transparent;\">\r\n                            {{ item.icon }}\r\n                        </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,#f79a6b,#f1580c);\r\n                               -webkit-background-clip:text; -webkit-text-fill-color:transparent;\r\n                               background-clip:text; text-fill-color:transparent;\">\r\n                                {{ item.icon }}\r\n                            </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                    <!-- 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        </div>\r\n    </div>\r\n</div>"]}
111
+ //# 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, OnInit } from \"@angular/core\";\r\nimport { Router, NavigationEnd } from \"@angular/router\";\r\nimport { Store, select } from \"@ngrx/store\";\r\nimport { Observable } from \"rxjs\";\r\nimport { map, tap } from \"rxjs/operators\";\r\n\r\nimport { State } from \"../../store/reducers\";\r\nimport * as sharedReducers from \"../../store/reducers\";\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 implements OnInit {\r\n    /** menu items observable */\r\n    menuItems$: Observable<IMenuItem[]>;\r\n    /** index of selected card */\r\n    selectedRowIndex: number | null = null;\r\n    /** index of hovered card */\r\n    showBackGroundColor: number | null = null;\r\n    /** soft labels for translations */\r\n    softLabels: SoftLabelConfigurationModel[] = [];\r\n\r\n    constructor(private store: Store<State>, private router: Router) { }\r\n\r\n    ngOnInit(): void {\r\n        // load soft label translations\r\n        const storedLabels = localStorage.getItem(\"SoftLabels\");\r\n        this.softLabels = storedLabels ? JSON.parse(storedLabels) : [];\r\n\r\n        // select & filter sidebar menu items from store\r\n        this.menuItems$ = this.store.pipe(\r\n            select(sharedReducers.getCurrentActiveMenuCategoryMenuItems),\r\n            map((list) =>\r\n                list.filter((item) => {\r\n                    const menuLabel = (item as any).menu?.toLowerCase() || \"\";\r\n                    const state = item.state?.toLowerCase() || \"\";\r\n\r\n                    // Exclude HR, tracker or unwanted items\r\n                    if (menuLabel === \"hr\" || state.startsWith(\"hrmanagment/employeelist\")) return false;\r\n                    if (menuLabel.includes(\"hr managment\") || menuLabel.includes(\"hr management\")) return false;\r\n                    if (state.startsWith(\"hrmanagment\") || state.startsWith(\"hrmdetails\")) return false;\r\n                    if (menuLabel.includes(\"activity tracker\") || state.startsWith(\"activitytracker\")) return false;\r\n                    return true;\r\n                })\r\n            ),\r\n            tap((menuList) => this.routerActive(menuList))\r\n        );\r\n\r\n        // dispatch load event\r\n        this.store.dispatch(new GetAllMenuItemsTriggered(MenuCategories.Main));\r\n\r\n        // listen for route changes to update highlight\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    /** highlights the active card according to current route */\r\n    private routerActive(menuList: IMenuItem[]): void {\r\n        if (!menuList?.length) return;\r\n\r\n        const foundIndex = menuList.findIndex((i) => this.router.url === \"/\" + i.state);\r\n        this.selectedRowIndex = foundIndex >= 0 ? foundIndex : null;\r\n\r\n        // Highlight report card when inside any dashboard route\r\n        if (this.router.url.startsWith(\"/dashboard-management/dashboard\")) {\r\n            this.selectedRowIndex = 99;\r\n        } else {\r\n            this.selectedRowIndex = null; // ensures no preselected Report card\r\n        }\r\n\r\n    }\r\n\r\n    /** hover enter */\r\n    enter(index: number): void {\r\n        this.showBackGroundColor = index;\r\n    }\r\n\r\n    /** hover leave */\r\n    leave(index: number): void {\r\n        if (this.showBackGroundColor === index) {\r\n            this.showBackGroundColor = null;\r\n        }\r\n    }\r\n\r\n    /** when clicking on dynamic menu card */\r\n    selectMenu(index: number, link?: string): void {\r\n        this.selectedRowIndex = index;\r\n        if (link) {\r\n            // ensure forward slash\r\n            const path = link.startsWith(\"/\") ? link : \"/\" + link;\r\n            this.router.navigate([path]);\r\n        }\r\n    }\r\n\r\n    /** open report dashboard-management/dashboard/:id or root */\r\n    goToReport(): void {\r\n        this.selectedRowIndex = 99;\r\n\r\n        const stored = localStorage.getItem(\"DefaultDashboard\");\r\n        const defaultDashboardId = stored ? JSON.parse(stored) : null;\r\n\r\n        if (defaultDashboardId) {\r\n            this.router.navigate([`/dashboard-management/dashboard/${defaultDashboardId}`]);\r\n        } else {\r\n            this.router.navigate([\"/dashboard-management\"]);\r\n        }\r\n    }\r\n}\r\n","<div class=\"d-flex flex-column justify-content-center align-items-center\" style=\"width:100vw; height:calc(100vh - 60px); padding:30px; overflow:auto;\r\n            background: linear-gradient(rgba(255,255,255,0.7), rgba(255,255,255,0.7));\">\r\n\r\n    <div class=\"row justify-content-center align-items-center\" style=\"height:auto;\">\r\n\r\n        <!-- Fixed Report 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;\r\n                      background:#fff; box-shadow:0 2px 6px rgba(0,0,0,0.08);\r\n                      border:2px solid rgba(241, 88, 12, 0.25);\" (mouseenter)=\"enter(99)\" (mouseleave)=\"leave(99)\"\r\n                (click)=\"goToReport()\" [ngStyle]=\"(selectedRowIndex == 99 || showBackGroundColor == 99) && {\r\n                 'background-color':'#fff',\r\n                 'border':'2px solid #f1580c',\r\n                 'box-shadow':'0 6px 20px rgba(241, 88, 12, 0.35), 0 0 10px rgba(241, 88, 12, 0.25)'\r\n               }\">\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,#f79a6b,#f1580c);\r\n                               -webkit-background-clip:text; -webkit-text-fill-color:transparent;\r\n                               background-clip:text; text-fill-color:transparent;\">\r\n                        assessment\r\n                    </mat-icon>\r\n                    <h6 style=\"font-size:14px; margin:0; color:#111827; text-align:center;\">Report</h6>\r\n                </div>\r\n            </div>\r\n        </div>\r\n\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;\r\n                  background:#fff; box-shadow:0 2px 6px rgba(0,0,0,0.08);\r\n                  border:2px solid rgba(241, 88, 12, 0.25);\" (mouseenter)=\"enter(i)\" (mouseleave)=\"leave(i)\"\r\n                (click)=\"selectMenu(i, item.state)\" [ngStyle]=\"(selectedRowIndex == i || showBackGroundColor == i) && {\r\n              'background-color':'#fff',\r\n              'border':'2px solid #f1580c',\r\n              'box-shadow':'0 6px 20px rgba(241, 88, 12, 0.35), 0 0 10px rgba(241, 88, 12, 0.25)'\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,#f79a6b,#f1580c);\r\n                             -webkit-background-clip:text; -webkit-text-fill-color:transparent;\r\n                             background-clip:text; text-fill-color:transparent;\">\r\n                            {{ item.icon }}\r\n                        </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,#f79a6b,#f1580c);\r\n                               -webkit-background-clip:text; -webkit-text-fill-color:transparent;\r\n                               background-clip:text; text-fill-color:transparent;\">\r\n                                {{ item.icon }}\r\n                            </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                    <!-- 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        </div>\r\n    </div>\r\n</div>"]}
@@ -11112,6 +11112,9 @@ class SideBarComponent {
11112
11112
  if (this.router.url.startsWith("/dashboard-management/dashboard")) {
11113
11113
  this.selectedRowIndex = 99;
11114
11114
  }
11115
+ else {
11116
+ this.selectedRowIndex = null; // ensures no preselected Report card
11117
+ }
11115
11118
  }
11116
11119
  /** hover enter */
11117
11120
  enter(index) {