aril 1.0.50 → 1.0.52

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 (68) hide show
  1. package/boot/host/src/app.component.d.ts +5 -1
  2. package/esm2022/boot/host/src/app.component.mjs +28 -4
  3. package/esm2022/theme/layout/app/expandableMenu/expandable-menu.component.mjs +30 -33
  4. package/esm2022/theme/layout/app/layout/app.layout.component.mjs +31 -36
  5. package/esm2022/theme/layout/app/site-map/site-map-sidebar.component.mjs +3 -3
  6. package/esm2022/theme/layout/app/static-sidebar/static-sidebar.component.mjs +171 -0
  7. package/esm2022/theme/layout/app/topbar/app.topbar.component.mjs +1 -4
  8. package/esm2022/theme/layout/service/app.layout.service.mjs +110 -39
  9. package/esm2022/ui/charts/index.mjs +7 -1
  10. package/esm2022/ui/charts/src/highCharts/area/area-chart.component.mjs +114 -0
  11. package/esm2022/ui/charts/src/highCharts/gauge/solid-gauge.component.mjs +180 -0
  12. package/esm2022/ui/charts/src/highCharts/heatmap/heatMap-chart.component.mjs +252 -0
  13. package/esm2022/ui/charts/src/highCharts/line/line-chart-datetime-axis.component.mjs +187 -0
  14. package/esm2022/ui/charts/src/highCharts/line/line-chart-series.component.mjs +89 -0
  15. package/esm2022/ui/charts/src/highCharts/line/line-chart.component.mjs +82 -0
  16. package/esm2022/ui/lib/src/input/value-accessor.directive.mjs +7 -26
  17. package/esm2022/ui/text/src/text.component.mjs +10 -3
  18. package/esm2022/util/pub-sub/src/pub-sub.service.mjs +3 -2
  19. package/fesm2022/{aril-app.component-ZRi2TVtr.mjs → aril-app.component-CZalL4tu.mjs} +5 -5
  20. package/fesm2022/aril-app.component-CZalL4tu.mjs.map +1 -0
  21. package/fesm2022/aril-boot-host.mjs +27 -3
  22. package/fesm2022/aril-boot-host.mjs.map +1 -1
  23. package/fesm2022/aril-theme-layout.mjs +371 -557
  24. package/fesm2022/aril-theme-layout.mjs.map +1 -1
  25. package/fesm2022/aril-ui-charts.mjs +881 -5
  26. package/fesm2022/aril-ui-charts.mjs.map +1 -1
  27. package/fesm2022/aril-ui-lib.mjs +6 -25
  28. package/fesm2022/aril-ui-lib.mjs.map +1 -1
  29. package/fesm2022/aril-ui-text.mjs +9 -2
  30. package/fesm2022/aril-ui-text.mjs.map +1 -1
  31. package/fesm2022/aril-util-pub-sub.mjs +2 -1
  32. package/fesm2022/aril-util-pub-sub.mjs.map +1 -1
  33. package/fesm2022/aril.mjs +28 -4
  34. package/fesm2022/aril.mjs.map +1 -1
  35. package/package.json +66 -66
  36. package/theme/layout/app/expandableMenu/expandable-menu.component.d.ts +3 -5
  37. package/theme/layout/app/expandableMenu/expandable-menu.component.ts +35 -40
  38. package/theme/layout/app/layout/app.layout.component.d.ts +4 -11
  39. package/theme/layout/app/layout/app.layout.component.html +6 -3
  40. package/theme/layout/app/layout/app.layout.component.ts +26 -42
  41. package/theme/layout/app/site-map/site-map-sidebar.component.html +1 -1
  42. package/theme/layout/app/static-sidebar/static-sidebar.component.d.ts +44 -0
  43. package/theme/layout/app/static-sidebar/static-sidebar.component.html +60 -0
  44. package/theme/layout/app/static-sidebar/static-sidebar.component.scss +223 -0
  45. package/theme/layout/app/static-sidebar/static-sidebar.component.ts +198 -0
  46. package/theme/layout/app/topbar/app.topbar.component.d.ts +0 -1
  47. package/theme/layout/app/topbar/app.topbar.component.ts +0 -4
  48. package/theme/layout/service/app.layout.service.d.ts +20 -18
  49. package/theme/layout/service/app.layout.service.ts +137 -53
  50. package/theme/styles/layout/_content.scss +18 -0
  51. package/theme/styles/layout/_responsive.scss +41 -2
  52. package/theme/styles/layout/_topbar.scss +6 -0
  53. package/theme/styles/theme/light/custom/theme.scss +5 -0
  54. package/ui/charts/index.d.ts +6 -0
  55. package/ui/charts/src/highCharts/area/area-chart.component.d.ts +20 -0
  56. package/ui/charts/src/highCharts/gauge/solid-gauge.component.d.ts +38 -0
  57. package/ui/charts/src/highCharts/heatmap/heatMap-chart.component.d.ts +32 -0
  58. package/ui/charts/src/highCharts/line/line-chart-datetime-axis.component.d.ts +24 -0
  59. package/ui/charts/src/highCharts/line/line-chart-series.component.d.ts +21 -0
  60. package/ui/charts/src/highCharts/line/line-chart.component.d.ts +21 -0
  61. package/ui/lib/src/input/value-accessor.directive.d.ts +0 -5
  62. package/ui/text/src/text.component.d.ts +1 -0
  63. package/util/pub-sub/src/pub-sub.service.d.ts +1 -0
  64. package/esm2022/theme/layout/app/menu/app.menu.component.mjs +0 -376
  65. package/esm2022/theme/layout/app/sidebar/app.sidebar.component.mjs +0 -41
  66. package/fesm2022/aril-app.component-ZRi2TVtr.mjs.map +0 -1
  67. package/theme/layout/app/menu/app.menu.component.d.ts +0 -48
  68. package/theme/layout/app/sidebar/app.sidebar.component.d.ts +0 -15
@@ -1,6 +1,10 @@
1
+ import { LayoutService } from 'aril/theme/layout';
2
+ import { PubSubService } from 'aril/util/pub-sub';
1
3
  import * as i0 from "@angular/core";
2
4
  export declare class AppComponent {
3
- constructor();
5
+ private layoutService;
6
+ private pubSubService;
7
+ constructor(layoutService: LayoutService, pubSubService: PubSubService);
4
8
  static ɵfac: i0.ɵɵFactoryDeclaration<AppComponent, never>;
5
9
  static ɵcmp: i0.ɵɵComponentDeclaration<AppComponent, "aril-root", never, {}, {}, never, never, true, never>;
6
10
  }
@@ -3,13 +3,37 @@ import { Component, NgZone, inject } from '@angular/core';
3
3
  import { AppLayoutComponent } from 'aril/theme/layout';
4
4
  import { appName } from './bootstrap';
5
5
  import * as i0 from "@angular/core";
6
+ import * as i1 from "aril/theme/layout";
7
+ import * as i2 from "aril/util/pub-sub";
6
8
  export class AppComponent {
7
- constructor() {
9
+ constructor(layoutService, pubSubService) {
10
+ this.layoutService = layoutService;
11
+ this.pubSubService = pubSubService;
8
12
  globalThis.activeHost = appName;
9
13
  globalThis.ngZone = inject(NgZone);
10
14
  globalThis.isHostMode = true;
15
+ this.pubSubService.subscribe('menuModeChanged', (data) => {
16
+ const menuMode = data?.custom;
17
+ if (menuMode && (menuMode === 'static' || menuMode === 'expandable')) {
18
+ this.layoutService.config.update((config) => {
19
+ const newConfig = {
20
+ ...config,
21
+ menuMode: menuMode
22
+ };
23
+ return newConfig;
24
+ });
25
+ if (menuMode === 'static') {
26
+ this.layoutService.state.staticSidebarVisible = true;
27
+ }
28
+ else if (menuMode === 'expandable') {
29
+ this.layoutService.state.staticSidebarVisible = false;
30
+ }
31
+ // Always close mobile menu on mode change
32
+ this.layoutService.state.staticMenuMobileActive = false;
33
+ }
34
+ });
11
35
  }
12
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: AppComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
36
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: AppComponent, deps: [{ token: i1.LayoutService }, { token: i2.PubSubService }], target: i0.ɵɵFactoryTarget.Component }); }
13
37
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: AppComponent, isStandalone: true, selector: "aril-root", ngImport: i0, template: ` <app-layout></app-layout> `, isInline: true, dependencies: [{ kind: "component", type: AppLayoutComponent, selector: "app-layout" }] }); }
14
38
  }
15
39
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: AppComponent, decorators: [{
@@ -20,5 +44,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
20
44
  template: ` <app-layout></app-layout> `,
21
45
  imports: [AppLayoutComponent]
22
46
  }]
23
- }], ctorParameters: () => [] });
24
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FyaWwvYm9vdC9ob3N0L3NyYy9hcHAuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLHVEQUF1RDtBQUN2RCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFMUQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFFdkQsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGFBQWEsQ0FBQzs7QUFRdEMsTUFBTSxPQUFPLFlBQVk7SUFDeEI7UUFDTyxVQUFXLENBQUMsVUFBVSxHQUFHLE9BQU8sQ0FBQztRQUNqQyxVQUFXLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNwQyxVQUFXLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQztJQUNyQyxDQUFDOzhHQUxXLFlBQVk7a0dBQVosWUFBWSxxRUFIZCw2QkFBNkIsNERBQzdCLGtCQUFrQjs7MkZBRWhCLFlBQVk7a0JBTnhCLFNBQVM7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSxXQUFXO29CQUNyQixRQUFRLEVBQUUsNkJBQTZCO29CQUN2QyxPQUFPLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQztpQkFDN0IiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55ICovXHJcbmltcG9ydCB7IENvbXBvbmVudCwgTmdab25lLCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmltcG9ydCB7IEFwcExheW91dENvbXBvbmVudCB9IGZyb20gJ2FyaWwvdGhlbWUvbGF5b3V0JztcclxuXHJcbmltcG9ydCB7IGFwcE5hbWUgfSBmcm9tICcuL2Jvb3RzdHJhcCc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuXHRzdGFuZGFsb25lOiB0cnVlLFxyXG5cdHNlbGVjdG9yOiAnYXJpbC1yb290JyxcclxuXHR0ZW1wbGF0ZTogYCA8YXBwLWxheW91dD48L2FwcC1sYXlvdXQ+IGAsXHJcblx0aW1wb3J0czogW0FwcExheW91dENvbXBvbmVudF1cclxufSlcclxuZXhwb3J0IGNsYXNzIEFwcENvbXBvbmVudCB7XHJcblx0Y29uc3RydWN0b3IoKSB7XHJcblx0XHQoPGFueT5nbG9iYWxUaGlzKS5hY3RpdmVIb3N0ID0gYXBwTmFtZTtcclxuXHRcdCg8YW55Pmdsb2JhbFRoaXMpLm5nWm9uZSA9IGluamVjdChOZ1pvbmUpO1xyXG5cdFx0KDxhbnk+Z2xvYmFsVGhpcykuaXNIb3N0TW9kZSA9IHRydWU7XHJcblx0fVxyXG59XHJcbiJdfQ==
47
+ }], ctorParameters: () => [{ type: i1.LayoutService }, { type: i2.PubSubService }] });
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FyaWwvYm9vdC9ob3N0L3NyYy9hcHAuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLHVEQUF1RDtBQUN2RCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFMUQsT0FBTyxFQUFHLGtCQUFrQixFQUFpQixNQUFNLG1CQUFtQixDQUFDO0FBR3ZFLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxhQUFhLENBQUM7Ozs7QUFVdEMsTUFBTSxPQUFPLFlBQVk7SUFDeEIsWUFDUyxhQUE0QixFQUM1QixhQUE0QjtRQUQ1QixrQkFBYSxHQUFiLGFBQWEsQ0FBZTtRQUM1QixrQkFBYSxHQUFiLGFBQWEsQ0FBZTtRQUU5QixVQUFXLENBQUMsVUFBVSxHQUFHLE9BQU8sQ0FBQztRQUNqQyxVQUFXLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNwQyxVQUFXLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQztRQUVwQyxJQUFJLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxpQkFBaUIsRUFBRSxDQUFDLElBQUksRUFBRSxFQUFFO1lBQ3hELE1BQU0sUUFBUSxHQUFHLElBQUksRUFBRSxNQUFNLENBQUM7WUFFOUIsSUFBSSxRQUFRLElBQUksQ0FBQyxRQUFRLEtBQUssUUFBUSxJQUFJLFFBQVEsS0FBSyxZQUFZLENBQUMsRUFBRSxDQUFDO2dCQUN0RSxJQUFJLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRTtvQkFDM0MsTUFBTSxTQUFTLEdBQUc7d0JBQ2pCLEdBQUcsTUFBTTt3QkFDVCxRQUFRLEVBQUUsUUFBb0I7cUJBQzlCLENBQUM7b0JBQ0YsT0FBTyxTQUFTLENBQUM7Z0JBQ2xCLENBQUMsQ0FBQyxDQUFDO2dCQUVILElBQUksUUFBUSxLQUFLLFFBQVEsRUFBRSxDQUFDO29CQUMzQixJQUFJLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxvQkFBb0IsR0FBRyxJQUFJLENBQUM7Z0JBQ3RELENBQUM7cUJBQU0sSUFBSSxRQUFRLEtBQUssWUFBWSxFQUFFLENBQUM7b0JBQ3RDLElBQUksQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLG9CQUFvQixHQUFHLEtBQUssQ0FBQztnQkFDdkQsQ0FBQztnQkFFRCwwQ0FBMEM7Z0JBQzFDLElBQUksQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLHNCQUFzQixHQUFHLEtBQUssQ0FBQztZQUV6RCxDQUFDO1FBQ0YsQ0FBQyxDQUFDLENBQUM7SUFDSixDQUFDOzhHQWhDVyxZQUFZO2tHQUFaLFlBQVkscUVBSGQsNkJBQTZCLDREQUM3QixrQkFBa0I7OzJGQUVoQixZQUFZO2tCQU54QixTQUFTO21CQUFDO29CQUNWLFVBQVUsRUFBRSxJQUFJO29CQUNoQixRQUFRLEVBQUUsV0FBVztvQkFDckIsUUFBUSxFQUFFLDZCQUE2QjtvQkFDdkMsT0FBTyxFQUFFLENBQUMsa0JBQWtCLENBQUM7aUJBQzdCIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueSAqL1xyXG5pbXBvcnQgeyBDb21wb25lbnQsIE5nWm9uZSwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5pbXBvcnQgeyAgQXBwTGF5b3V0Q29tcG9uZW50LCBMYXlvdXRTZXJ2aWNlIH0gZnJvbSAnYXJpbC90aGVtZS9sYXlvdXQnO1xyXG5pbXBvcnQgeyBQdWJTdWJTZXJ2aWNlIH0gZnJvbSAnYXJpbC91dGlsL3B1Yi1zdWInO1xyXG5cclxuaW1wb3J0IHsgYXBwTmFtZSB9IGZyb20gJy4vYm9vdHN0cmFwJztcclxuXHRcclxudHlwZSBNZW51TW9kZSA9ICdzdGF0aWMnIHwgJ2V4cGFuZGFibGUnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcblx0c3RhbmRhbG9uZTogdHJ1ZSxcclxuXHRzZWxlY3RvcjogJ2FyaWwtcm9vdCcsXHJcblx0dGVtcGxhdGU6IGAgPGFwcC1sYXlvdXQ+PC9hcHAtbGF5b3V0PiBgLFxyXG5cdGltcG9ydHM6IFtBcHBMYXlvdXRDb21wb25lbnRdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBcHBDb21wb25lbnQge1xyXG5cdGNvbnN0cnVjdG9yKFxyXG5cdFx0cHJpdmF0ZSBsYXlvdXRTZXJ2aWNlOiBMYXlvdXRTZXJ2aWNlLFxyXG5cdFx0cHJpdmF0ZSBwdWJTdWJTZXJ2aWNlOiBQdWJTdWJTZXJ2aWNlXHJcblx0KSB7XHJcblx0XHQoPGFueT5nbG9iYWxUaGlzKS5hY3RpdmVIb3N0ID0gYXBwTmFtZTtcclxuXHRcdCg8YW55Pmdsb2JhbFRoaXMpLm5nWm9uZSA9IGluamVjdChOZ1pvbmUpO1xyXG5cdFx0KDxhbnk+Z2xvYmFsVGhpcykuaXNIb3N0TW9kZSA9IHRydWU7XHJcblxyXG5cdFx0dGhpcy5wdWJTdWJTZXJ2aWNlLnN1YnNjcmliZSgnbWVudU1vZGVDaGFuZ2VkJywgKGRhdGEpID0+IHtcclxuXHRcdFx0Y29uc3QgbWVudU1vZGUgPSBkYXRhPy5jdXN0b207XHJcblx0XHRcdFxyXG5cdFx0XHRpZiAobWVudU1vZGUgJiYgKG1lbnVNb2RlID09PSAnc3RhdGljJyB8fCBtZW51TW9kZSA9PT0gJ2V4cGFuZGFibGUnKSkge1x0XHRcdFx0XHJcblx0XHRcdFx0dGhpcy5sYXlvdXRTZXJ2aWNlLmNvbmZpZy51cGRhdGUoKGNvbmZpZykgPT4ge1xyXG5cdFx0XHRcdFx0Y29uc3QgbmV3Q29uZmlnID0ge1xyXG5cdFx0XHRcdFx0XHQuLi5jb25maWcsXHJcblx0XHRcdFx0XHRcdG1lbnVNb2RlOiBtZW51TW9kZSBhcyBNZW51TW9kZVxyXG5cdFx0XHRcdFx0fTtcclxuXHRcdFx0XHRcdHJldHVybiBuZXdDb25maWc7XHJcblx0XHRcdFx0fSk7XHJcblx0XHRcdFx0XHRcdFx0XHRcclxuXHRcdFx0XHRpZiAobWVudU1vZGUgPT09ICdzdGF0aWMnKSB7XHJcblx0XHRcdFx0XHR0aGlzLmxheW91dFNlcnZpY2Uuc3RhdGUuc3RhdGljU2lkZWJhclZpc2libGUgPSB0cnVlO1xyXG5cdFx0XHRcdH0gZWxzZSBpZiAobWVudU1vZGUgPT09ICdleHBhbmRhYmxlJykge1xyXG5cdFx0XHRcdFx0dGhpcy5sYXlvdXRTZXJ2aWNlLnN0YXRlLnN0YXRpY1NpZGViYXJWaXNpYmxlID0gZmFsc2U7XHJcblx0XHRcdFx0fVxyXG5cdFx0XHRcdFxyXG5cdFx0XHRcdC8vIEFsd2F5cyBjbG9zZSBtb2JpbGUgbWVudSBvbiBtb2RlIGNoYW5nZVxyXG5cdFx0XHRcdHRoaXMubGF5b3V0U2VydmljZS5zdGF0ZS5zdGF0aWNNZW51TW9iaWxlQWN0aXZlID0gZmFsc2U7XHJcblx0XHRcdFx0XHJcblx0XHRcdH1cclxuXHRcdH0pO1xyXG5cdH1cclxufVxyXG4iXX0=
@@ -25,14 +25,10 @@ export class ExpandableMenuComponent {
25
25
  this.overlayMenuOpenSubscription = null;
26
26
  this.routerSubscription = null;
27
27
  this.username = this.keycloak.getUsername().charAt(0).toUpperCase();
28
- this.sidebarIsLocked = false;
29
28
  this.isHostMode = globalThis.isHostMode;
30
29
  this.hostMenuItems = globalThis.hostMenuItems;
31
30
  this.cachedMenuItems = [];
32
- // Track selected main menu item
33
- this.selectedMainItem = null;
34
31
  this.selectedMainMenuItem = null;
35
- this.secondarySidebarExpanded = false;
36
32
  this.tooltipText = {
37
33
  toggleButton: {
38
34
  expanded: {
@@ -61,6 +57,16 @@ export class ExpandableMenuComponent {
61
57
  tertiary: 20
62
58
  };
63
59
  }
60
+ // Getter for layout service states
61
+ get selectedMainItem() {
62
+ return this.layoutService.state.selectedMainItem;
63
+ }
64
+ get secondarySidebarExpanded() {
65
+ return this.layoutService.state.secondarySidebarExpanded;
66
+ }
67
+ get sidebarIsLocked() {
68
+ return this.layoutService.state.sidebarIsLocked;
69
+ }
64
70
  // Check if text is truncated and needs tooltip
65
71
  isTextTruncated(label, lang, menuType = 'secondary') {
66
72
  if (!label || !lang || !label[lang])
@@ -95,7 +101,6 @@ export class ExpandableMenuComponent {
95
101
  ngOnInit() {
96
102
  this.updateMenuItems();
97
103
  this.initializeMenu();
98
- this.loadSidebarLockState();
99
104
  this.updateActiveMenuFromCurrentRoute();
100
105
  // Subscribe to route changes to handle secondary sidebar closing
101
106
  this.routerSubscription = this.router.events
@@ -105,13 +110,13 @@ export class ExpandableMenuComponent {
105
110
  this.updateActiveMenuFromCurrentRoute();
106
111
  // Close secondary sidebar on navigation if not locked
107
112
  if (!this.sidebarIsLocked) {
108
- this.secondarySidebarExpanded = false;
113
+ this.layoutService.setSecondarySidebarExpanded(false);
109
114
  }
110
115
  });
111
116
  // Subscribe to overlay menu open notifications
112
117
  this.overlayMenuOpenSubscription = this.layoutService.overlayOpen$.subscribe(() => {
113
118
  if (this.layoutService.state.staticMenuMobileActive) {
114
- this.secondarySidebarExpanded = true;
119
+ this.layoutService.setSecondarySidebarExpanded(true);
115
120
  }
116
121
  });
117
122
  }
@@ -123,22 +128,14 @@ export class ExpandableMenuComponent {
123
128
  this.routerSubscription.unsubscribe();
124
129
  }
125
130
  }
126
- loadSidebarLockState() {
127
- const storedState = localStorage.getItem('sidebarIsLocked');
128
- this.sidebarIsLocked = storedState === 'true';
129
- }
130
- saveSidebarLockState() {
131
- localStorage.setItem('sidebarIsLocked', this.sidebarIsLocked.toString());
132
- }
133
131
  toggleSidebarLock() {
134
- this.sidebarIsLocked = !this.sidebarIsLocked;
135
- this.saveSidebarLockState();
132
+ this.layoutService.toggleSidebarLock();
136
133
  }
137
134
  // Initialize the menu with proper active state
138
135
  initializeMenu() {
139
- this.selectedMainItem = null;
136
+ this.layoutService.setSelectedMainItem(null);
140
137
  this.selectedMainMenuItem = null;
141
- this.secondarySidebarExpanded = false;
138
+ this.layoutService.setSecondarySidebarExpanded(false);
142
139
  this.updateMenuItems();
143
140
  }
144
141
  updateMenuFromRootKey(index) {
@@ -147,9 +144,9 @@ export class ExpandableMenuComponent {
147
144
  if (index >= 0 && index < menuItems.length) {
148
145
  const item = menuItems[index];
149
146
  if (!item.separator) {
150
- this.selectedMainItem = index;
147
+ this.layoutService.setSelectedMainItem(index);
151
148
  this.selectedMainMenuItem = item;
152
- this.secondarySidebarExpanded = true;
149
+ this.layoutService.setSecondarySidebarExpanded(true);
153
150
  }
154
151
  }
155
152
  }
@@ -161,24 +158,24 @@ export class ExpandableMenuComponent {
161
158
  }
162
159
  selectMainItem(index, item) {
163
160
  if (item.routerLink && (!item.items || item.items.length === 0)) {
164
- this.secondarySidebarExpanded = false;
165
- this.selectedMainItem = index;
161
+ this.layoutService.setSecondarySidebarExpanded(false);
162
+ this.layoutService.setSelectedMainItem(index);
166
163
  this.selectedMainMenuItem = item;
167
164
  this.router.navigate([item.routerLink]);
168
165
  return;
169
166
  }
170
167
  // Handle regular menu items with submenu
171
168
  if (this.selectedMainItem === index) {
172
- this.secondarySidebarExpanded = !this.secondarySidebarExpanded;
169
+ this.layoutService.toggleSecondarySidebar();
173
170
  }
174
171
  else {
175
- this.selectedMainItem = index;
172
+ this.layoutService.setSelectedMainItem(index);
176
173
  this.selectedMainMenuItem = item;
177
174
  if (item.items && item.items.length > 0) {
178
- this.secondarySidebarExpanded = true;
175
+ this.layoutService.setSecondarySidebarExpanded(true);
179
176
  }
180
177
  else {
181
- this.secondarySidebarExpanded = false;
178
+ this.layoutService.setSecondarySidebarExpanded(false);
182
179
  }
183
180
  }
184
181
  // For mobile devices, ensure the menu stays open
@@ -187,15 +184,15 @@ export class ExpandableMenuComponent {
187
184
  }
188
185
  }
189
186
  toggleSecondarySidebar() {
190
- this.secondarySidebarExpanded = !this.secondarySidebarExpanded;
187
+ this.layoutService.toggleSecondarySidebar();
191
188
  }
192
189
  isMobile() {
193
190
  return this.layoutService.isMobile();
194
191
  }
195
- // Listen for resize events to handle responsive behavior for mobile
192
+ // Listen for resize events - now handled more efficiently by layout service
196
193
  onResize() {
197
194
  if (!this.isMobile() && this.layoutService.state.staticMenuMobileActive) {
198
- this.layoutService.state.staticMenuMobileActive = false;
195
+ this.layoutService.closeMobileMenu();
199
196
  }
200
197
  }
201
198
  updateActiveMenuFromCurrentRoute() {
@@ -203,15 +200,15 @@ export class ExpandableMenuComponent {
203
200
  for (let i = 0; i < menuItems.length; i++) {
204
201
  const menuItem = menuItems[i];
205
202
  if (this.isActiveRoute(menuItem)) {
206
- this.selectedMainItem = i;
203
+ this.layoutService.setSelectedMainItem(i);
207
204
  this.selectedMainMenuItem = menuItem;
208
205
  if (menuItem.items && menuItem.items.length > 0) {
209
206
  if (!this.isMobile() && !this.secondarySidebarExpanded && !this.layoutService.state.staticMenuMobileActive) {
210
- this.secondarySidebarExpanded = true;
207
+ this.layoutService.setSecondarySidebarExpanded(true);
211
208
  }
212
209
  }
213
210
  else {
214
- this.secondarySidebarExpanded = false;
211
+ this.layoutService.setSecondarySidebarExpanded(false);
215
212
  }
216
213
  return;
217
214
  }
@@ -245,4 +242,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
245
242
  type: HostListener,
246
243
  args: ['window:resize']
247
244
  }] } });
248
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"expandable-menu.component.js","sourceRoot":"","sources":["../../../../../../projects/aril/theme/layout/app/expandableMenu/expandable-menu.component.ts","../../../../../../projects/aril/theme/layout/app/expandableMenu/expandable-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass } from '@angular/common';\r\nimport { Component, HostListener, OnDestroy, OnInit } from '@angular/core';\r\nimport { toSignal } from '@angular/core/rxjs-interop';\r\nimport { NavigationEnd, Router, RouterLink } from '@angular/router';\r\n\r\nimport { TooltipModule } from 'primeng/tooltip';\r\n\r\nimport { TranslocoService } from '@ngneat/transloco';\r\nimport { KeycloakService } from 'keycloak-angular';\r\nimport { Subscription, filter } from 'rxjs';\r\n\r\nimport { PluginMenuItem } from 'aril/boot/config/apps';\r\nimport { TranslateJsonPipe } from 'aril/util/pipes';\r\n\r\nimport { LayoutService } from '../../service/app.layout.service';\r\nimport { AppMenuService } from '../../service/app.menu.service';\r\n\r\n@Component({\r\n\tstandalone: true,\r\n\tselector: 'app-expandable-menu',\r\n\timports: [RouterLink, NgClass, TooltipModule],\r\n\ttemplateUrl: 'expandable-menu.component.html',\r\n\tproviders: [TranslateJsonPipe]\r\n})\r\nexport class ExpandableMenuComponent implements OnInit, OnDestroy {\r\n\r\n\tactiveLang = toSignal(this.translocoService.langChanges$, { initialValue: 'tr' });\r\n\toverlayMenuOpenSubscription: Subscription | null = null;\r\n\trouterSubscription: Subscription | null = null;\r\n\tusername = this.keycloak.getUsername().charAt(0).toUpperCase();\r\n\tsidebarIsLocked = false;\r\n\r\n  isHostMode = (<any>globalThis).isHostMode;\r\n\thostMenuItems = (<any>globalThis).hostMenuItems;\r\n\tcachedMenuItems: PluginMenuItem[] = [];\r\n\r\n\r\n\t// Track selected main menu item\r\n\tselectedMainItem: number | null = null;\r\n\tselectedMainMenuItem: PluginMenuItem | null = null;\r\n\tsecondarySidebarExpanded = false;\r\n\r\n\ttooltipText = {\r\n\t\ttoggleButton: {\r\n\t\t\texpanded: {\r\n\t\t\t\ttr: 'Menüyü Gizle',\r\n\t\t\t\ten: 'Hide Menu'\r\n\t\t\t},\r\n\t\t\tcollapsed: {\r\n\t\t\t\ttr: 'Menüyü Göster',\r\n\t\t\t\ten: 'Show Menu'\r\n\t\t\t}\r\n\t\t},\r\n\t\tlockButton: {\r\n\t\t\tlocked: {\r\n\t\t\t\ttr: 'Otomatik Kapanmayı Aç',\r\n\t\t\t\ten: 'Enable Auto-Close'\r\n\t\t\t},\r\n\t\t\tunlocked: {\r\n\t\t\t\ttr: 'Menüyü Kilitle',\r\n\t\t\t\ten: 'Lock Menu'\r\n\t\t\t}\r\n\t\t}\r\n\t};\r\n\r\n\tprivate readonly MAX_LENGTH = {\r\n\t\tmain: 8, \r\n\t\tsecondary: 20,\r\n\t\ttertiary: 20 \r\n\t};\r\n\r\n\tconstructor(\r\n\t\tprivate translateJsonPipe: TranslateJsonPipe,\r\n\t\tprivate menuService: AppMenuService,\r\n\t\tprivate router: Router,\r\n\t\tprivate keycloak: KeycloakService,\r\n\t\tprivate translocoService: TranslocoService,\r\n\t\tprivate layoutService: LayoutService\r\n\t) {}\r\n\r\n\t// Check if text is truncated and needs tooltip\r\n\tisTextTruncated(\r\n\t\tlabel: any,\r\n\t\tlang: string | null,\r\n\t\tmenuType: 'main' | 'secondary' | 'tertiary' | 'nested' = 'secondary'\r\n\t): boolean {\r\n\t\tif (!label || !lang || !label[lang]) return false;\r\n\r\n\t\tconst text = label[lang];\r\n\t\tconst textLength = text.length;\r\n\t\tconst maxLength = menuType === 'nested' ? this.MAX_LENGTH.tertiary : this.MAX_LENGTH[menuType];\r\n\t\treturn textLength > maxLength;\r\n\t}\r\n\r\n\t// Recursively check if a menu item or its children match the current route\r\n\tisActiveRoute(menuItem: PluginMenuItem): boolean {\r\n\t\tif (!menuItem || !menuItem.routerLink) return false;\r\n\r\n\t\t// Get current URL path after the hash\r\n\t\tconst currentUrl = this.router.url;\r\n\t\tconst hashUrl = currentUrl.indexOf('#') > -1 ? currentUrl.split('#')[1] : currentUrl;\r\n\r\n\t\t// Check for exact match first\r\n\t\tif (hashUrl === menuItem.routerLink || hashUrl === '/' + menuItem.routerLink) {\r\n\t\t\treturn true;\r\n\t\t}\r\n\r\n\t\t// Check if current URL starts with the routerLink (handles child routes)\r\n\t\tif (\r\n\t\t\tmenuItem.routerLink !== '/' &&\r\n\t\t\t(hashUrl.startsWith(menuItem.routerLink + '/') || hashUrl.startsWith('/' + menuItem.routerLink + '/'))\r\n\t\t) {\r\n\t\t\treturn true;\r\n\t\t}\r\n\r\n\t\t// Check child items if they exist\r\n\t\tif (menuItem.items && menuItem.items.length > 0) {\r\n\t\t\treturn menuItem.items.some((childItem) => this.isActiveRoute(childItem));\r\n\t\t}\r\n\r\n\t\treturn false;\r\n\t}\r\n\r\n\tngOnInit() {\r\n\r\n\t\tthis.updateMenuItems();\r\n\t\tthis.initializeMenu();\r\n\r\n\t\tthis.loadSidebarLockState();\r\n\t\tthis.updateActiveMenuFromCurrentRoute();\r\n\r\n\t\t// Subscribe to route changes to handle secondary sidebar closing\r\n\t\tthis.routerSubscription = this.router.events\r\n\t\t\t.pipe(filter((event) => event instanceof NavigationEnd))\r\n\t\t\t.subscribe(() => {\r\n\t\t\t\t// Update active menu based on the new route\r\n\t\t\t\tthis.updateActiveMenuFromCurrentRoute();\r\n\r\n\t\t\t\t// Close secondary sidebar on navigation if not locked\r\n\t\t\t\tif (!this.sidebarIsLocked) {\r\n\t\t\t\t\tthis.secondarySidebarExpanded = false;\r\n\t\t\t\t}\r\n\t\t\t});\r\n\r\n\t\t// Subscribe to overlay menu open notifications\r\n\t\tthis.overlayMenuOpenSubscription = this.layoutService.overlayOpen$.subscribe(() => {\r\n\t\t\tif (this.layoutService.state.staticMenuMobileActive) {\r\n\t\t\t\tthis.secondarySidebarExpanded = true;\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\tngOnDestroy() {\r\n\t\tif (this.overlayMenuOpenSubscription) {\r\n\t\t\tthis.overlayMenuOpenSubscription.unsubscribe();\r\n\t\t}\r\n\r\n\t\tif (this.routerSubscription) {\r\n\t\t\tthis.routerSubscription.unsubscribe();\r\n\t\t}\r\n\t}\r\n\r\n\tloadSidebarLockState(): void {\r\n\t\tconst storedState = localStorage.getItem('sidebarIsLocked');\r\n\t\tthis.sidebarIsLocked = storedState === 'true';\r\n\t}\r\n\r\n\tsaveSidebarLockState(): void {\r\n\t\tlocalStorage.setItem('sidebarIsLocked', this.sidebarIsLocked.toString());\r\n\t}\r\n\r\n\ttoggleSidebarLock(): void {\r\n\t\tthis.sidebarIsLocked = !this.sidebarIsLocked;\r\n\t\tthis.saveSidebarLockState();\r\n\t}\r\n\r\n\t// Initialize the menu with proper active state\r\n\tinitializeMenu() {\r\n\t\tthis.selectedMainItem = null;\r\n\t\tthis.selectedMainMenuItem = null;\r\n\t\tthis.secondarySidebarExpanded = false;\r\n\t\tthis.updateMenuItems();\r\n\t}\r\n\r\n\tupdateMenuFromRootKey(index: number): void {\r\n\t\tthis.updateMenuItems(); \r\n\t\tconst menuItems = this.getMenuItems();\r\n\r\n\t\tif (index >= 0 && index < menuItems.length) {\r\n\t\t\tconst item = menuItems[index];\r\n\t\t\tif (!item.separator) {\r\n\t\t\t\tthis.selectedMainItem = index;\r\n\t\t\t\tthis.selectedMainMenuItem = item;\r\n\t\t\t\tthis.secondarySidebarExpanded = true;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tupdateMenuItems(): void {\r\n\t\tthis.cachedMenuItems = this.isHostMode ? this.hostMenuItems() : this.menuService.menuItems();\r\n\t}\r\n\r\n\tgetMenuItems(): PluginMenuItem[] {\r\n\t\treturn this.cachedMenuItems;\r\n\t}\r\n\r\n\tselectMainItem(index: number, item: PluginMenuItem): void {\r\n\t\tif (item.routerLink && (!item.items || item.items.length === 0)) {\r\n\t\t\tthis.secondarySidebarExpanded = false;\r\n\t\t\tthis.selectedMainItem = index;\r\n\t\t\tthis.selectedMainMenuItem = item;\r\n\t\t\tthis.router.navigate([item.routerLink]);\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\t// Handle regular menu items with submenu\r\n\t\tif (this.selectedMainItem === index) {\r\n\t\t\tthis.secondarySidebarExpanded = !this.secondarySidebarExpanded;\r\n\t\t} else {\r\n\t\t\tthis.selectedMainItem = index;\r\n\t\t\tthis.selectedMainMenuItem = item;\r\n\r\n      if (item.items && item.items.length > 0) {\r\n\t\t\t\tthis.secondarySidebarExpanded = true;\r\n\t\t\t} else {\r\n\t\t\t\tthis.secondarySidebarExpanded = false;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t// For mobile devices, ensure the menu stays open\r\n\t\tif (this.isMobile()) {\r\n\t\t\tthis.layoutService.state.staticMenuMobileActive = true;\r\n\t\t}\r\n\t}\r\n\r\n\ttoggleSecondarySidebar(): void {\r\n\t\tthis.secondarySidebarExpanded = !this.secondarySidebarExpanded;\r\n\t}\r\n\r\n\tisMobile(): boolean {\r\n\t\treturn this.layoutService.isMobile();\r\n\t}\r\n\r\n\t// Listen for resize events to handle responsive behavior for mobile\r\n\t@HostListener('window:resize')\r\n\tonResize() {\r\n\t\tif (!this.isMobile() && this.layoutService.state.staticMenuMobileActive) {\r\n\t\t\tthis.layoutService.state.staticMenuMobileActive = false;\r\n\t\t}\r\n\t}\r\n\r\n\tupdateActiveMenuFromCurrentRoute(): void {\r\n\t\tconst menuItems = this.getMenuItems();\r\n\r\n\t\tfor (let i = 0; i < menuItems.length; i++) {\r\n\t\t\tconst menuItem = menuItems[i];\r\n\t\t\tif (this.isActiveRoute(menuItem)) {\r\n\t\t\t\tthis.selectedMainItem = i;\r\n\t\t\t\tthis.selectedMainMenuItem = menuItem;\r\n\r\n\t\t\t\tif (menuItem.items && menuItem.items.length > 0) {\r\n\t\t\t\t\tif (!this.isMobile() && !this.secondarySidebarExpanded && !this.layoutService.state.staticMenuMobileActive) {\r\n\t\t\t\t\t\tthis.secondarySidebarExpanded = true;\r\n\t\t\t\t\t}\r\n\t\t\t\t} else {\r\n\t\t\t\t\tthis.secondarySidebarExpanded = false;\r\n\t\t\t\t}\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tisHaveSelectedChildItem(item: PluginMenuItem): boolean {\r\n\t\tif (!item || !item.items || item.items.length === 0) return false;\r\n\r\n\t\tfor (const child of item.items) {\r\n\t\t\tif (this.isActiveRoute(child)) {\r\n\t\t\t\treturn true;\r\n\t\t\t}\r\n\r\n      if (child.items && child.items.length > 0) {\r\n\t\t\t\tif (this.isHaveSelectedChildItem(child)) {\r\n\t\t\t\t\treturn true;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\treturn false;\r\n\t}\r\n\r\n\tgetLocalText(text: any): string {\r\n\t\treturn this.translateJsonPipe.transform(text);\r\n\t}\r\n}\r\n","<div class=\"new-layout-sidebar\">\r\n\t<!-- Main sidebar (first level) -->\r\n\t<div class=\"main-sidebar\">\r\n\t\t<div class=\"main-sidebar-header\">\r\n\t\t\t<div class=\"user-avatar\">\r\n\t\t\t\t<span>{{ username }}</span>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t\t<div class=\"main-sidebar-content\">\r\n\t\t\t<ul class=\"main-menu\">\r\n\t\t\t\t@for(item of getMenuItems(); track item; let i = $index){\r\n\t\t\t\t\t@if(!item.separator){\r\n\t\t\t\t\t\t<li\r\n\t\t\t\t\t\t[ngClass]=\"{'active': isActiveRoute(item) || isHaveSelectedChildItem(item)}\"\r\n\t\t\t\t\t\t(click)=\"selectMainItem(i, item)\"\r\n\t\t\t\t\t\t[pTooltip]=\"!isMobile() && isTextTruncated(item.label, activeLang(), 'main') ? (item.label && activeLang() ? item.label[activeLang()!] || '' : '') : ''\"\r\n\t\t\t\t\t\ttooltipPosition=\"right\">\r\n\t\t\t\t\t\t<div class=\"main-menu-item\">\r\n\t\t\t\t\t\t\t<i [ngClass]=\"item.icon\" class=\"menu-icon\"></i>\r\n\t\t\t\t\t\t\t<small class=\"menu-label\">{{ item.label && activeLang() ? item.label[activeLang()!] || '' : '' }}</small>\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t</li>\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t</ul>\r\n\t\t</div>\r\n\t\t<!-- Toggle button at the bottom of main sidebar -->\r\n\t\t<div class=\"main-sidebar-footer\">\r\n\t\t\t<button class=\"sidebar-toggle-button\" (click)=\"toggleSecondarySidebar()\" \r\n\t\t\t\t[pTooltip]=\"!isMobile() ? (secondarySidebarExpanded ? getLocalText(tooltipText.toggleButton.expanded) : getLocalText(tooltipText.toggleButton.collapsed)) : ''\" \r\n\t\t\t\ttooltipPosition=\"right\">\r\n\t\t\t\t<i class=\"pi\" [ngClass]=\"secondarySidebarExpanded ? 'pi-angle-left' : 'pi-angle-right'\"></i>\r\n\t\t\t</button>\r\n\t\t</div>\r\n\t</div>\r\n\r\n\t<!-- Secondary sidebar (second level) -->\r\n\t<div class=\"secondary-sidebar\" [ngClass]=\"{'expanded': secondarySidebarExpanded}\">\r\n\t\t<!-- Content container wrapper to prevent jumps during transitions -->\r\n\t\t<div class=\"secondary-content-wrapper\">\r\n\t\t\t<!-- Secondary sidebar header -->\r\n\t\t\t<div class=\"secondary-sidebar-header\">\r\n\t\t\t\t<div class=\"secondary-header-content\">\r\n\t\t\t\t\t@if(selectedMainMenuItem){\r\n\t\t\t\t\t\t<h3 class=\"section-title\">\r\n\t\t\t\t\t\t\t<i [ngClass]=\"selectedMainMenuItem.icon\" class=\"section-icon\"></i>\r\n\t\t\t\t\t\t\t<span>{{ selectedMainMenuItem.label && activeLang() ? selectedMainMenuItem.label[activeLang()!] || '' : '' }}</span>\r\n\t\t\t\t\t\t</h3>\r\n\t\t\t\t\t}\r\n\t\t\t\t\t<button class=\"sidebar-lock-button\" (click)=\"toggleSidebarLock()\" \r\n\t\t\t\t\t\t[pTooltip]=\"sidebarIsLocked ? getLocalText(tooltipText.lockButton.locked) : getLocalText(tooltipText.lockButton.unlocked)\" \r\n\t\t\t\t\t\ttooltipPosition=\"left\">\r\n\t\t\t\t\t\t<i class=\"pi\" [ngClass]=\"sidebarIsLocked ? 'pi-lock' : 'pi-lock-open'\"></i>\r\n\t\t\t\t\t</button>\r\n\t\t\t\t</div>\r\n\t\t\t</div>\r\n\t\t\t\r\n\t\t\t<!-- Secondary sidebar content -->\r\n\t\t\t<div class=\"secondary-sidebar-content\">\r\n\t\t\t\t@if(selectedMainMenuItem){\r\n\t\t\t\t\t<ul class=\"secondary-menu\">\r\n\t\t\t\t\t\t@for(subItem of selectedMainMenuItem.items; track subItem; let i = $index){\r\n\t\t\t\t\t\t\t\t<!-- Create menu item -->\r\n\t\t\t\t\t\t\t\t<li class=\"secondary-menu-item\" [ngClass]=\"{'active': isActiveRoute(subItem)}\">\r\n\t\t\t\t\t\t\t\t\t<a [routerLink]=\"subItem.routerLink\" \r\n\t\t\t\t\t\t\t\t\t\tclass=\"secondary-menu-link\"\r\n\t\t\t\t\t\t\t\t\t\t[pTooltip]=\"!isMobile() && isTextTruncated(subItem.label, activeLang(), 'secondary') ? (subItem.label && activeLang() ? subItem.label[activeLang()!] || '' : '') : ''\"\r\n\t\t\t\t\t\t\t\t\t\ttooltipPosition=\"right\">\r\n\t\t\t\t\t\t\t\t\t\t<i [ngClass]=\"subItem.icon\" class=\"submenu-icon\"></i>\r\n\t\t\t\t\t\t\t\t\t\t<span class=\"submenu-label\">{{ subItem.label && activeLang() ? subItem.label[activeLang()!] || '' : '' }}</span>\r\n\t\t\t\t\t\t\t\t\t</a>\r\n\t\t\t\t\t\t\t\t\t<!-- Always render submenu if it exists -->\r\n\t\t\t\t\t\t\t\t\t @if(subItem.items && subItem.items.length > 0){\r\n\t\t\t\t\t\t\t\t\t\t <ul class=\"tertiary-menu always-open\">\r\n\t\t\t\t\t\t\t\t\t\t\t@for(childItem of subItem.items; track childItem; let i = $index){\r\n\t\t\t\t\t\t\t\t\t\t\t\t<li class=\"tertiary-menu-item\" [ngClass]=\"{'active': isActiveRoute(childItem)}\">\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t<a [routerLink]=\"childItem.routerLink\" \r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tclass=\"tertiary-menu-link\"\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t[pTooltip]=\"!isMobile() && isTextTruncated(childItem.label, activeLang(), 'tertiary') ? (childItem.label && activeLang() ? childItem.label[activeLang()!] || '' : '') : ''\"\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\ttooltipPosition=\"right\">\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t<span class=\"tertiary-label\">{{ childItem.label && activeLang() ? childItem.label[activeLang()!] || '' : '' }}</span>\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t</a>\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t<!-- Always render deeper levels if they exist, also visible by default -->\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t@if(childItem.items && childItem.items.length > 0){\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t<ul class=\"nested-menu always-open\">\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t@for(nestedItem of childItem.items; track nestedItem; let i = $index){\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t<li \r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tclass=\"nested-menu-item\"\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t[ngClass]=\"{'active': isActiveRoute(nestedItem)}\">\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t<a [routerLink]=\"nestedItem.routerLink\" \r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tclass=\"nested-menu-link\"\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t[pTooltip]=\"!isMobile() && isTextTruncated(nestedItem.label, activeLang(), 'nested') ? (nestedItem.label && activeLang() ? nestedItem.label[activeLang()!] || '' : '') : ''\"\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttooltipPosition=\"right\">\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t<span class=\"nested-label\">{{ nestedItem.label && activeLang() ? nestedItem.label[activeLang()!] || '' : '' }}</span>\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t</a>\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t</li>\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t</ul>\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\t\t\t\t\t</li>\r\n\t\t\t\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\t\t\t </ul>\r\n\t\t\t\t\t\t\t\t\t }\r\n\t\t\t\t\t\t\t\t</li>\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t</ul>\r\n\t\t\t\t}\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t</div>\r\n\t\r\n</div>\r\n"]}
245
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"expandable-menu.component.js","sourceRoot":"","sources":["../../../../../../projects/aril/theme/layout/app/expandableMenu/expandable-menu.component.ts","../../../../../../projects/aril/theme/layout/app/expandableMenu/expandable-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass } from '@angular/common';\r\nimport { Component, HostListener, OnDestroy, OnInit } from '@angular/core';\r\nimport { toSignal } from '@angular/core/rxjs-interop';\r\nimport { NavigationEnd, Router, RouterLink } from '@angular/router';\r\n\r\nimport { TooltipModule } from 'primeng/tooltip';\r\n\r\nimport { TranslocoService } from '@ngneat/transloco';\r\nimport { KeycloakService } from 'keycloak-angular';\r\nimport { Subscription, filter } from 'rxjs';\r\n\r\nimport { PluginMenuItem } from 'aril/boot/config/apps';\r\nimport { TranslateJsonPipe } from 'aril/util/pipes';\r\n\r\nimport { LayoutService } from '../../service/app.layout.service';\r\nimport { AppMenuService } from '../../service/app.menu.service';\r\n\r\n@Component({\r\n\tstandalone: true,\r\n\tselector: 'app-expandable-menu',\r\n\timports: [RouterLink, NgClass, TooltipModule],\r\n\ttemplateUrl: 'expandable-menu.component.html',\r\n\tproviders: [TranslateJsonPipe]\r\n})\r\nexport class ExpandableMenuComponent implements OnInit, OnDestroy {\r\n\r\n\tactiveLang = toSignal(this.translocoService.langChanges$, { initialValue: 'tr' });\r\n\toverlayMenuOpenSubscription: Subscription | null = null;\r\n\trouterSubscription: Subscription | null = null;\r\n\tusername = this.keycloak.getUsername().charAt(0).toUpperCase();\r\n\r\n\tisHostMode = (<any>globalThis).isHostMode;\r\n\thostMenuItems = (<any>globalThis).hostMenuItems;\r\n\tcachedMenuItems: PluginMenuItem[] = [];\r\n\r\n\tselectedMainMenuItem: PluginMenuItem | null = null;\r\n\r\n\ttooltipText = {\r\n\t\ttoggleButton: {\r\n\t\t\texpanded: {\r\n\t\t\t\ttr: 'Menüyü Gizle',\r\n\t\t\t\ten: 'Hide Menu'\r\n\t\t\t},\r\n\t\t\tcollapsed: {\r\n\t\t\t\ttr: 'Menüyü Göster',\r\n\t\t\t\ten: 'Show Menu'\r\n\t\t\t}\r\n\t\t},\r\n\t\tlockButton: {\r\n\t\t\tlocked: {\r\n\t\t\t\ttr: 'Otomatik Kapanmayı Aç',\r\n\t\t\t\ten: 'Enable Auto-Close'\r\n\t\t\t},\r\n\t\t\tunlocked: {\r\n\t\t\t\ttr: 'Menüyü Kilitle',\r\n\t\t\t\ten: 'Lock Menu'\r\n\t\t\t}\r\n\t\t}\r\n\t};\r\n\r\n\tprivate readonly MAX_LENGTH = {\r\n\t\tmain: 8, \r\n\t\tsecondary: 20,\r\n\t\ttertiary: 20 \r\n\t};\r\n\r\n\tconstructor(\r\n\t\tprivate translateJsonPipe: TranslateJsonPipe,\r\n\t\tprivate menuService: AppMenuService,\r\n\t\tprivate router: Router,\r\n\t\tprivate keycloak: KeycloakService,\r\n\t\tprivate translocoService: TranslocoService,\r\n\t\tprivate layoutService: LayoutService\r\n\t) {}\r\n\r\n\t// Getter for layout service states\r\n\tget selectedMainItem(): number | null {\r\n\t\treturn this.layoutService.state.selectedMainItem;\r\n\t}\r\n\r\n\tget secondarySidebarExpanded(): boolean {\r\n\t\treturn this.layoutService.state.secondarySidebarExpanded;\r\n\t}\r\n\r\n\tget sidebarIsLocked(): boolean {\r\n\t\treturn this.layoutService.state.sidebarIsLocked;\r\n\t}\r\n\r\n\t// Check if text is truncated and needs tooltip\r\n\tisTextTruncated(\r\n\t\tlabel: any,\r\n\t\tlang: string | null,\r\n\t\tmenuType: 'main' | 'secondary' | 'tertiary' | 'nested' = 'secondary'\r\n\t): boolean {\r\n\t\tif (!label || !lang || !label[lang]) return false;\r\n\r\n\t\tconst text = label[lang];\r\n\t\tconst textLength = text.length;\r\n\t\tconst maxLength = menuType === 'nested' ? this.MAX_LENGTH.tertiary : this.MAX_LENGTH[menuType];\r\n\t\treturn textLength > maxLength;\r\n\t}\r\n\r\n\t// Recursively check if a menu item or its children match the current route\r\n\tisActiveRoute(menuItem: PluginMenuItem): boolean {\r\n\t\tif (!menuItem || !menuItem.routerLink) return false;\r\n\r\n\t\t// Get current URL path after the hash\r\n\t\tconst currentUrl = this.router.url;\r\n\t\tconst hashUrl = currentUrl.indexOf('#') > -1 ? currentUrl.split('#')[1] : currentUrl;\r\n\r\n\t\t// Check for exact match first\r\n\t\tif (hashUrl === menuItem.routerLink || hashUrl === '/' + menuItem.routerLink) {\r\n\t\t\treturn true;\r\n\t\t}\r\n\r\n\t\t// Check if current URL starts with the routerLink (handles child routes)\r\n\t\tif (\r\n\t\t\tmenuItem.routerLink !== '/' &&\r\n\t\t\t(hashUrl.startsWith(menuItem.routerLink + '/') || hashUrl.startsWith('/' + menuItem.routerLink + '/'))\r\n\t\t) {\r\n\t\t\treturn true;\r\n\t\t}\r\n\r\n\t\t// Check child items if they exist\r\n\t\tif (menuItem.items && menuItem.items.length > 0) {\r\n\t\t\treturn menuItem.items.some((childItem) => this.isActiveRoute(childItem));\r\n\t\t}\r\n\r\n\t\treturn false;\r\n\t}\r\n\r\n\tngOnInit() {\r\n\t\tthis.updateMenuItems();\r\n\t\tthis.initializeMenu();\r\n\t\tthis.updateActiveMenuFromCurrentRoute();\r\n\r\n\t\t// Subscribe to route changes to handle secondary sidebar closing\r\n\t\tthis.routerSubscription = this.router.events\r\n\t\t\t.pipe(filter((event) => event instanceof NavigationEnd))\r\n\t\t\t.subscribe(() => {\r\n\t\t\t\t// Update active menu based on the new route\r\n\t\t\t\tthis.updateActiveMenuFromCurrentRoute();\r\n\r\n\t\t\t\t// Close secondary sidebar on navigation if not locked\r\n\t\t\t\tif (!this.sidebarIsLocked) {\r\n\t\t\t\t\tthis.layoutService.setSecondarySidebarExpanded(false);\r\n\t\t\t\t}\r\n\t\t\t});\r\n\r\n\t\t// Subscribe to overlay menu open notifications\r\n\t\tthis.overlayMenuOpenSubscription = this.layoutService.overlayOpen$.subscribe(() => {\r\n\t\t\tif (this.layoutService.state.staticMenuMobileActive) {\r\n\t\t\t\tthis.layoutService.setSecondarySidebarExpanded(true);\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\tngOnDestroy() {\r\n\t\tif (this.overlayMenuOpenSubscription) {\r\n\t\t\tthis.overlayMenuOpenSubscription.unsubscribe();\r\n\t\t}\r\n\r\n\t\tif (this.routerSubscription) {\r\n\t\t\tthis.routerSubscription.unsubscribe();\r\n\t\t}\r\n\t}\r\n\r\n\ttoggleSidebarLock(): void {\r\n\t\tthis.layoutService.toggleSidebarLock();\r\n\t}\r\n\r\n\t// Initialize the menu with proper active state\r\n\tinitializeMenu() {\r\n\t\tthis.layoutService.setSelectedMainItem(null);\r\n\t\tthis.selectedMainMenuItem = null;\r\n\t\tthis.layoutService.setSecondarySidebarExpanded(false);\r\n\t\tthis.updateMenuItems();\r\n\t}\r\n\r\n\tupdateMenuFromRootKey(index: number): void {\r\n\t\tthis.updateMenuItems(); \r\n\t\tconst menuItems = this.getMenuItems();\r\n\r\n\t\tif (index >= 0 && index < menuItems.length) {\r\n\t\t\tconst item = menuItems[index];\r\n\t\t\tif (!item.separator) {\r\n\t\t\t\tthis.layoutService.setSelectedMainItem(index);\r\n\t\t\t\tthis.selectedMainMenuItem = item;\r\n\t\t\t\tthis.layoutService.setSecondarySidebarExpanded(true);\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tupdateMenuItems(): void {\r\n\t\tthis.cachedMenuItems = this.isHostMode ? this.hostMenuItems() : this.menuService.menuItems();\r\n\t}\r\n\r\n\tgetMenuItems(): PluginMenuItem[] {\r\n\t\treturn this.cachedMenuItems;\r\n\t}\r\n\r\n\tselectMainItem(index: number, item: PluginMenuItem): void {\r\n\t\tif (item.routerLink && (!item.items || item.items.length === 0)) {\r\n\t\t\tthis.layoutService.setSecondarySidebarExpanded(false);\r\n\t\t\tthis.layoutService.setSelectedMainItem(index);\r\n\t\t\tthis.selectedMainMenuItem = item;\r\n\t\t\tthis.router.navigate([item.routerLink]);\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\t// Handle regular menu items with submenu\r\n\t\tif (this.selectedMainItem === index) {\r\n\t\t\tthis.layoutService.toggleSecondarySidebar();\r\n\t\t} else {\r\n\t\t\tthis.layoutService.setSelectedMainItem(index);\r\n\t\t\tthis.selectedMainMenuItem = item;\r\n\r\n\t\t\tif (item.items && item.items.length > 0) {\r\n\t\t\t\tthis.layoutService.setSecondarySidebarExpanded(true);\r\n\t\t\t} else {\r\n\t\t\t\tthis.layoutService.setSecondarySidebarExpanded(false);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t// For mobile devices, ensure the menu stays open\r\n\t\tif (this.isMobile()) {\r\n\t\t\tthis.layoutService.state.staticMenuMobileActive = true;\r\n\t\t}\r\n\t}\r\n\r\n\ttoggleSecondarySidebar(): void {\r\n\t\tthis.layoutService.toggleSecondarySidebar();\r\n\t}\r\n\r\n\tisMobile(): boolean {\r\n\t\treturn this.layoutService.isMobile();\r\n\t}\r\n\r\n\t// Listen for resize events - now handled more efficiently by layout service\r\n\t@HostListener('window:resize')\r\n\tonResize() {\r\n\t\tif (!this.isMobile() && this.layoutService.state.staticMenuMobileActive) {\r\n\t\t\tthis.layoutService.closeMobileMenu();\r\n\t\t}\r\n\t}\r\n\r\n\tupdateActiveMenuFromCurrentRoute(): void {\r\n\t\tconst menuItems = this.getMenuItems();\r\n\r\n\t\tfor (let i = 0; i < menuItems.length; i++) {\r\n\t\t\tconst menuItem = menuItems[i];\r\n\t\t\tif (this.isActiveRoute(menuItem)) {\r\n\t\t\t\tthis.layoutService.setSelectedMainItem(i);\r\n\t\t\t\tthis.selectedMainMenuItem = menuItem;\r\n\r\n\t\t\t\tif (menuItem.items && menuItem.items.length > 0) {\r\n\t\t\t\t\tif (!this.isMobile() && !this.secondarySidebarExpanded && !this.layoutService.state.staticMenuMobileActive) {\r\n\t\t\t\t\t\tthis.layoutService.setSecondarySidebarExpanded(true);\r\n\t\t\t\t\t}\r\n\t\t\t\t} else {\r\n\t\t\t\t\tthis.layoutService.setSecondarySidebarExpanded(false);\r\n\t\t\t\t}\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tisHaveSelectedChildItem(item: PluginMenuItem): boolean {\r\n\t\tif (!item || !item.items || item.items.length === 0) return false;\r\n\r\n\t\tfor (const child of item.items) {\r\n\t\t\tif (this.isActiveRoute(child)) {\r\n\t\t\t\treturn true;\r\n\t\t\t}\r\n\r\n\t\t\tif (child.items && child.items.length > 0) {\r\n\t\t\t\tif (this.isHaveSelectedChildItem(child)) {\r\n\t\t\t\t\treturn true;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\treturn false;\r\n\t}\r\n\r\n\tgetLocalText(text: any): string {\r\n\t\treturn this.translateJsonPipe.transform(text);\r\n\t}\r\n}\r\n","<div class=\"new-layout-sidebar\">\r\n\t<!-- Main sidebar (first level) -->\r\n\t<div class=\"main-sidebar\">\r\n\t\t<div class=\"main-sidebar-header\">\r\n\t\t\t<div class=\"user-avatar\">\r\n\t\t\t\t<span>{{ username }}</span>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t\t<div class=\"main-sidebar-content\">\r\n\t\t\t<ul class=\"main-menu\">\r\n\t\t\t\t@for(item of getMenuItems(); track item; let i = $index){\r\n\t\t\t\t\t@if(!item.separator){\r\n\t\t\t\t\t\t<li\r\n\t\t\t\t\t\t[ngClass]=\"{'active': isActiveRoute(item) || isHaveSelectedChildItem(item)}\"\r\n\t\t\t\t\t\t(click)=\"selectMainItem(i, item)\"\r\n\t\t\t\t\t\t[pTooltip]=\"!isMobile() && isTextTruncated(item.label, activeLang(), 'main') ? (item.label && activeLang() ? item.label[activeLang()!] || '' : '') : ''\"\r\n\t\t\t\t\t\ttooltipPosition=\"right\">\r\n\t\t\t\t\t\t<div class=\"main-menu-item\">\r\n\t\t\t\t\t\t\t<i [ngClass]=\"item.icon\" class=\"menu-icon\"></i>\r\n\t\t\t\t\t\t\t<small class=\"menu-label\">{{ item.label && activeLang() ? item.label[activeLang()!] || '' : '' }}</small>\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t</li>\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t</ul>\r\n\t\t</div>\r\n\t\t<!-- Toggle button at the bottom of main sidebar -->\r\n\t\t<div class=\"main-sidebar-footer\">\r\n\t\t\t<button class=\"sidebar-toggle-button\" (click)=\"toggleSecondarySidebar()\" \r\n\t\t\t\t[pTooltip]=\"!isMobile() ? (secondarySidebarExpanded ? getLocalText(tooltipText.toggleButton.expanded) : getLocalText(tooltipText.toggleButton.collapsed)) : ''\" \r\n\t\t\t\ttooltipPosition=\"right\">\r\n\t\t\t\t<i class=\"pi\" [ngClass]=\"secondarySidebarExpanded ? 'pi-angle-left' : 'pi-angle-right'\"></i>\r\n\t\t\t</button>\r\n\t\t</div>\r\n\t</div>\r\n\r\n\t<!-- Secondary sidebar (second level) -->\r\n\t<div class=\"secondary-sidebar\" [ngClass]=\"{'expanded': secondarySidebarExpanded}\">\r\n\t\t<!-- Content container wrapper to prevent jumps during transitions -->\r\n\t\t<div class=\"secondary-content-wrapper\">\r\n\t\t\t<!-- Secondary sidebar header -->\r\n\t\t\t<div class=\"secondary-sidebar-header\">\r\n\t\t\t\t<div class=\"secondary-header-content\">\r\n\t\t\t\t\t@if(selectedMainMenuItem){\r\n\t\t\t\t\t\t<h3 class=\"section-title\">\r\n\t\t\t\t\t\t\t<i [ngClass]=\"selectedMainMenuItem.icon\" class=\"section-icon\"></i>\r\n\t\t\t\t\t\t\t<span>{{ selectedMainMenuItem.label && activeLang() ? selectedMainMenuItem.label[activeLang()!] || '' : '' }}</span>\r\n\t\t\t\t\t\t</h3>\r\n\t\t\t\t\t}\r\n\t\t\t\t\t<button class=\"sidebar-lock-button\" (click)=\"toggleSidebarLock()\" \r\n\t\t\t\t\t\t[pTooltip]=\"sidebarIsLocked ? getLocalText(tooltipText.lockButton.locked) : getLocalText(tooltipText.lockButton.unlocked)\" \r\n\t\t\t\t\t\ttooltipPosition=\"left\">\r\n\t\t\t\t\t\t<i class=\"pi\" [ngClass]=\"sidebarIsLocked ? 'pi-lock' : 'pi-lock-open'\"></i>\r\n\t\t\t\t\t</button>\r\n\t\t\t\t</div>\r\n\t\t\t</div>\r\n\t\t\t\r\n\t\t\t<!-- Secondary sidebar content -->\r\n\t\t\t<div class=\"secondary-sidebar-content\">\r\n\t\t\t\t@if(selectedMainMenuItem){\r\n\t\t\t\t\t<ul class=\"secondary-menu\">\r\n\t\t\t\t\t\t@for(subItem of selectedMainMenuItem.items; track subItem; let i = $index){\r\n\t\t\t\t\t\t\t\t<!-- Create menu item -->\r\n\t\t\t\t\t\t\t\t<li class=\"secondary-menu-item\" [ngClass]=\"{'active': isActiveRoute(subItem)}\">\r\n\t\t\t\t\t\t\t\t\t<a [routerLink]=\"subItem.routerLink\" \r\n\t\t\t\t\t\t\t\t\t\tclass=\"secondary-menu-link\"\r\n\t\t\t\t\t\t\t\t\t\t[pTooltip]=\"!isMobile() && isTextTruncated(subItem.label, activeLang(), 'secondary') ? (subItem.label && activeLang() ? subItem.label[activeLang()!] || '' : '') : ''\"\r\n\t\t\t\t\t\t\t\t\t\ttooltipPosition=\"right\">\r\n\t\t\t\t\t\t\t\t\t\t<i [ngClass]=\"subItem.icon\" class=\"submenu-icon\"></i>\r\n\t\t\t\t\t\t\t\t\t\t<span class=\"submenu-label\">{{ subItem.label && activeLang() ? subItem.label[activeLang()!] || '' : '' }}</span>\r\n\t\t\t\t\t\t\t\t\t</a>\r\n\t\t\t\t\t\t\t\t\t<!-- Always render submenu if it exists -->\r\n\t\t\t\t\t\t\t\t\t @if(subItem.items && subItem.items.length > 0){\r\n\t\t\t\t\t\t\t\t\t\t <ul class=\"tertiary-menu always-open\">\r\n\t\t\t\t\t\t\t\t\t\t\t@for(childItem of subItem.items; track childItem; let i = $index){\r\n\t\t\t\t\t\t\t\t\t\t\t\t<li class=\"tertiary-menu-item\" [ngClass]=\"{'active': isActiveRoute(childItem)}\">\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t<a [routerLink]=\"childItem.routerLink\" \r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tclass=\"tertiary-menu-link\"\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t[pTooltip]=\"!isMobile() && isTextTruncated(childItem.label, activeLang(), 'tertiary') ? (childItem.label && activeLang() ? childItem.label[activeLang()!] || '' : '') : ''\"\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\ttooltipPosition=\"right\">\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t<span class=\"tertiary-label\">{{ childItem.label && activeLang() ? childItem.label[activeLang()!] || '' : '' }}</span>\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t</a>\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t<!-- Always render deeper levels if they exist, also visible by default -->\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t@if(childItem.items && childItem.items.length > 0){\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t<ul class=\"nested-menu always-open\">\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t@for(nestedItem of childItem.items; track nestedItem; let i = $index){\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t<li \r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tclass=\"nested-menu-item\"\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t[ngClass]=\"{'active': isActiveRoute(nestedItem)}\">\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t<a [routerLink]=\"nestedItem.routerLink\" \r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tclass=\"nested-menu-link\"\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t[pTooltip]=\"!isMobile() && isTextTruncated(nestedItem.label, activeLang(), 'nested') ? (nestedItem.label && activeLang() ? nestedItem.label[activeLang()!] || '' : '') : ''\"\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttooltipPosition=\"right\">\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t<span class=\"nested-label\">{{ nestedItem.label && activeLang() ? nestedItem.label[activeLang()!] || '' : '' }}</span>\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t</a>\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t</li>\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t</ul>\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\t\t\t\t\t</li>\r\n\t\t\t\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\t\t\t </ul>\r\n\t\t\t\t\t\t\t\t\t }\r\n\t\t\t\t\t\t\t\t</li>\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t</ul>\r\n\t\t\t\t}\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t</div>\r\n\t\r\n</div>\r\n"]}