@rxap/layout 16.0.0-dev.4 → 16.0.0-dev.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +14 -0
- package/esm2022/index.mjs +5 -6
- package/esm2022/lib/app-url.service.mjs +64 -0
- package/esm2022/lib/footer/footer.component.mjs +3 -3
- package/esm2022/lib/header/apps-button/apps-button.component.mjs +30 -46
- package/esm2022/lib/header/header.component.mjs +41 -46
- package/esm2022/lib/header/language-selector/language-selector.component.mjs +10 -69
- package/esm2022/lib/header/navigation-progress-bar/navigation-progress-bar.component.mjs +6 -2
- package/esm2022/lib/header/sidenav-toggle-button/sidenav-toggle-button.component.mjs +6 -2
- package/esm2022/lib/header/sign-out/sign-out.component.mjs +14 -18
- package/esm2022/lib/header/user-profile-icon/user-profile-icon.component.mjs +28 -28
- package/esm2022/lib/i18n-check.guard.mjs +34 -0
- package/esm2022/lib/i18n.service.mjs +36 -0
- package/esm2022/lib/language-selector.service.mjs +34 -0
- package/esm2022/lib/layout/layout.component.mjs +46 -23
- package/esm2022/lib/layout/layout.component.service.mjs +2 -2
- package/esm2022/lib/navigation/navigation-item/navigation-item.component.mjs +49 -96
- package/esm2022/lib/navigation/navigation.component.mjs +24 -25
- package/esm2022/lib/sidenav/sidenav.component.mjs +1 -1
- package/esm2022/lib/types.mjs +1 -1
- package/fesm2022/rxap-layout.mjs +637 -667
- package/fesm2022/rxap-layout.mjs.map +1 -1
- package/index.d.ts +4 -3
- package/lib/app-url.service.d.ts +26 -0
- package/lib/header/apps-button/apps-button.component.d.ts +12 -20
- package/lib/header/header.component.d.ts +7 -10
- package/lib/header/language-selector/language-selector.component.d.ts +1 -16
- package/lib/header/sign-out/sign-out.component.d.ts +4 -4
- package/lib/header/user-profile-icon/user-profile-icon.component.d.ts +11 -7
- package/lib/i18n-check.guard.d.ts +14 -0
- package/lib/i18n.service.d.ts +12 -0
- package/lib/language-selector.service.d.ts +15 -0
- package/lib/layout/layout.component.d.ts +8 -4
- package/lib/navigation/navigation-item/navigation-item.component.d.ts +10 -17
- package/lib/navigation/navigation.component.d.ts +4 -4
- package/lib/types.d.ts +3 -2
- package/package.json +36 -21
- package/esm2022/lib/layout/layout.component.module.mjs +0 -30
- package/esm2022/lib/sidenav-content/sidenav-content.component.mjs +0 -27
- package/esm2022/lib/sidenav-content/sidenav-content.component.service.mjs +0 -36
- package/lib/layout/layout.component.module.d.ts +0 -10
- package/lib/sidenav-content/sidenav-content.component.d.ts +0 -10
- package/lib/sidenav-content/sidenav-content.component.service.d.ts +0 -15
- package/src/lib/navigation/_navigation.component.theme.scss +0 -33
- package/src/lib/navigation/navigation-item/_navigation-item.component.theme.scss +0 -45
|
@@ -1,42 +1,65 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, ViewChild, } from '@angular/core';
|
|
2
|
-
import { LayoutComponentService } from './layout.component.service';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Inject, ViewChild, } from '@angular/core';
|
|
3
2
|
import { MatSidenav, MatSidenavModule, } from '@angular/material/sidenav';
|
|
4
|
-
import {
|
|
5
|
-
import { FooterComponent } from '../footer/footer.component';
|
|
6
|
-
import { WindowContainerSidenavComponent } from '../window-container-sidenav/window-container-sidenav.component';
|
|
7
|
-
import { ToggleWindowSidenavButtonComponent } from '../toggle-window-sidenav-button/toggle-window-sidenav-button.component';
|
|
8
|
-
import { SidenavContentComponent } from '../sidenav-content/sidenav-content.component';
|
|
9
|
-
import { RouterLink } from '@angular/router';
|
|
10
|
-
import { SidenavHeaderDirective } from '../sidenav/sidenav-header.directive';
|
|
11
|
-
import { SidenavComponent } from '../sidenav/sidenav.component';
|
|
3
|
+
import { DetermineReleaseName, RXAP_ENVIRONMENT, } from '@rxap/environment';
|
|
12
4
|
import { HeaderComponent } from '../header/header.component';
|
|
5
|
+
import { AsyncPipe, NgIf, NgOptimizedImage, } from '@angular/common';
|
|
6
|
+
import { FlexLayoutModule } from '@angular/flex-layout';
|
|
7
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
8
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
9
|
+
import { RouterLink, RouterOutlet, } from '@angular/router';
|
|
10
|
+
import { MatMenuModule } from '@angular/material/menu';
|
|
11
|
+
import { FooterComponent } from '../footer/footer.component';
|
|
12
|
+
import { LayoutComponentService } from './layout.component.service';
|
|
13
|
+
import { NavigationComponent } from '../navigation/navigation.component';
|
|
13
14
|
import * as i0 from "@angular/core";
|
|
14
15
|
import * as i1 from "./layout.component.service";
|
|
15
16
|
import * as i2 from "@angular/material/sidenav";
|
|
17
|
+
import * as i3 from "@angular/flex-layout/extended";
|
|
18
|
+
import * as i4 from "@angular/material/icon";
|
|
19
|
+
import * as i5 from "@angular/material/button";
|
|
16
20
|
export class LayoutComponent {
|
|
17
|
-
constructor(layoutComponentService) {
|
|
21
|
+
constructor(layoutComponentService, environment) {
|
|
18
22
|
this.layoutComponentService = layoutComponentService;
|
|
19
|
-
this.
|
|
23
|
+
this.environment = environment;
|
|
24
|
+
this.sidenavMode = 'over';
|
|
20
25
|
}
|
|
21
|
-
|
|
22
|
-
|
|
26
|
+
get release() {
|
|
27
|
+
return DetermineReleaseName(this.environment);
|
|
28
|
+
}
|
|
29
|
+
toggleSidenavMode() {
|
|
30
|
+
if (this.sidenavMode === 'over') {
|
|
31
|
+
this.sidenavMode = 'side';
|
|
32
|
+
this.sidenav.open();
|
|
33
|
+
}
|
|
34
|
+
else {
|
|
35
|
+
this.sidenavMode = 'over';
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: LayoutComponent, deps: [{ token: i1.LayoutComponentService }, { token: RXAP_ENVIRONMENT }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
39
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.4", type: LayoutComponent, isStandalone: true, selector: "rxap-layout", viewQueries: [{ propertyName: "sidenav", first: true, predicate: MatSidenav, descendants: true, static: true }], ngImport: i0, template: "<div class=\"flex flex-col h-screen justify-between\">\n <rxap-header [sidenav]=\"sidenav\" class=\"z-10 w-full fixed top-0\"></rxap-header>\n <mat-sidenav-container class=\"grow mt-16 mb-16\">\n <mat-sidenav\n #matSidenav=\"matSidenav\"\n (mouseenter)=\"sidenavMode === 'over' && matSidenav.open()\"\n (mouseleave)=\"sidenavMode === 'over' && matSidenav.close()\"\n [fixedBottomGap]=\"64\"\n [fixedInViewport]=\"true\"\n [fixedTopGap]=\"64\"\n [mode]=\"sidenavMode\"\n [opened]=\"false\"\n class=\"sidenav\"\n >\n <div class=\"h-full py-2 flex flex-col items-center gap-y-5 justify-items-stretch\">\n\n <div (click)=\"toggleSidenavMode()\"\n class=\"pl-2 pr-1 self-stretch grow-0 flex flex-row justify-between items-center\">\n <span class=\"text-lg\" i18n>Navigation</span>\n <button mat-icon-button>\n <mat-icon *ngIf=\"sidenavMode === 'over'\">radio_button_unchecked</mat-icon>\n <mat-icon *ngIf=\"sidenavMode === 'side'\">radio_button_checked</mat-icon>\n </button>\n </div>\n\n <ul class=\"grow self-stretch\" root rxap-navigation></ul>\n\n <img\n [height]=\"layoutComponentService.logo.height ?? 128\"\n [ngSrc]=\"layoutComponentService.logo.src ?? 'https://via.placeholder.com/256x128px'\"\n [routerLink]=\"['/']\"\n [width]=\"layoutComponentService.logo.width ?? 256\"\n alt=\"logo\"\n class=\"grow-0\"\n />\n <div class=\"grow-0\">\n <span>{{release}}</span>\n </div>\n </div>\n </mat-sidenav>\n <mat-sidenav-content\n [ngClass]=\"{ opened: matSidenav.opened, side: sidenavMode === 'side' }\"\n class=\"ml-14 p-4\"\n >\n <router-outlet></router-outlet>\n </mat-sidenav-content>\n </mat-sidenav-container>\n <rxap-footer class=\"z-10 w-full fixed bottom-0\"></rxap-footer>\n</div>\n<!--<rxap-window-task-bar-container></rxap-window-task-bar-container>-->\n", styles: [".sidenav:not(.mat-drawer-opened){transform:translate(calc(-100% + 56px))!important;visibility:visible!important;box-shadow:inherit!important;transition-property:transform;transition-delay:.25s;display:flex;border-right:solid 1px rgba(0,0,0,.12)}.footer{position:fixed;bottom:0;left:0;right:0;z-index:100}.header{position:fixed;top:0;left:0;right:0;z-index:100}.task-bar{position:fixed;bottom:0;right:0;left:0;z-index:100}\n"], dependencies: [{ kind: "component", type: HeaderComponent, selector: "rxap-header", inputs: ["sidenav", "color"] }, { kind: "ngmodule", type: MatSidenavModule }, { kind: "component", type: i2.MatSidenav, selector: "mat-sidenav", inputs: ["fixedInViewport", "fixedTopGap", "fixedBottomGap"], exportAs: ["matSidenav"] }, { kind: "component", type: i2.MatSidenavContainer, selector: "mat-sidenav-container", exportAs: ["matSidenavContainer"] }, { kind: "component", type: i2.MatSidenavContent, selector: "mat-sidenav-content" }, { kind: "ngmodule", type: FlexLayoutModule }, { kind: "directive", type: i3.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"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i5.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: FooterComponent, selector: "rxap-footer" }, { kind: "ngmodule", type: MatMenuModule }, { kind: "directive", type: NgOptimizedImage, selector: "img[ngSrc]", inputs: ["ngSrc", "ngSrcset", "sizes", "width", "height", "loading", "priority", "loaderParams", "disableOptimizedSrcset", "fill", "src", "srcset"] }, { kind: "component", type: NavigationComponent, selector: "ul[rxap-navigation]", inputs: ["items", "level", "root"] }, { kind: "directive", type: RouterOutlet, selector: "router-outlet", inputs: ["name"], outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
23
40
|
}
|
|
24
41
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: LayoutComponent, decorators: [{
|
|
25
42
|
type: Component,
|
|
26
43
|
args: [{ selector: 'rxap-layout', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
|
|
27
44
|
HeaderComponent,
|
|
28
45
|
MatSidenavModule,
|
|
29
|
-
|
|
30
|
-
|
|
46
|
+
AsyncPipe,
|
|
47
|
+
FlexLayoutModule,
|
|
48
|
+
MatIconModule,
|
|
49
|
+
MatButtonModule,
|
|
31
50
|
RouterLink,
|
|
32
|
-
|
|
33
|
-
ToggleWindowSidenavButtonComponent,
|
|
34
|
-
WindowContainerSidenavComponent,
|
|
51
|
+
NgIf,
|
|
35
52
|
FooterComponent,
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
53
|
+
MatMenuModule,
|
|
54
|
+
NgOptimizedImage,
|
|
55
|
+
NavigationComponent,
|
|
56
|
+
RouterOutlet,
|
|
57
|
+
], template: "<div class=\"flex flex-col h-screen justify-between\">\n <rxap-header [sidenav]=\"sidenav\" class=\"z-10 w-full fixed top-0\"></rxap-header>\n <mat-sidenav-container class=\"grow mt-16 mb-16\">\n <mat-sidenav\n #matSidenav=\"matSidenav\"\n (mouseenter)=\"sidenavMode === 'over' && matSidenav.open()\"\n (mouseleave)=\"sidenavMode === 'over' && matSidenav.close()\"\n [fixedBottomGap]=\"64\"\n [fixedInViewport]=\"true\"\n [fixedTopGap]=\"64\"\n [mode]=\"sidenavMode\"\n [opened]=\"false\"\n class=\"sidenav\"\n >\n <div class=\"h-full py-2 flex flex-col items-center gap-y-5 justify-items-stretch\">\n\n <div (click)=\"toggleSidenavMode()\"\n class=\"pl-2 pr-1 self-stretch grow-0 flex flex-row justify-between items-center\">\n <span class=\"text-lg\" i18n>Navigation</span>\n <button mat-icon-button>\n <mat-icon *ngIf=\"sidenavMode === 'over'\">radio_button_unchecked</mat-icon>\n <mat-icon *ngIf=\"sidenavMode === 'side'\">radio_button_checked</mat-icon>\n </button>\n </div>\n\n <ul class=\"grow self-stretch\" root rxap-navigation></ul>\n\n <img\n [height]=\"layoutComponentService.logo.height ?? 128\"\n [ngSrc]=\"layoutComponentService.logo.src ?? 'https://via.placeholder.com/256x128px'\"\n [routerLink]=\"['/']\"\n [width]=\"layoutComponentService.logo.width ?? 256\"\n alt=\"logo\"\n class=\"grow-0\"\n />\n <div class=\"grow-0\">\n <span>{{release}}</span>\n </div>\n </div>\n </mat-sidenav>\n <mat-sidenav-content\n [ngClass]=\"{ opened: matSidenav.opened, side: sidenavMode === 'side' }\"\n class=\"ml-14 p-4\"\n >\n <router-outlet></router-outlet>\n </mat-sidenav-content>\n </mat-sidenav-container>\n <rxap-footer class=\"z-10 w-full fixed bottom-0\"></rxap-footer>\n</div>\n<!--<rxap-window-task-bar-container></rxap-window-task-bar-container>-->\n", styles: [".sidenav:not(.mat-drawer-opened){transform:translate(calc(-100% + 56px))!important;visibility:visible!important;box-shadow:inherit!important;transition-property:transform;transition-delay:.25s;display:flex;border-right:solid 1px rgba(0,0,0,.12)}.footer{position:fixed;bottom:0;left:0;right:0;z-index:100}.header{position:fixed;top:0;left:0;right:0;z-index:100}.task-bar{position:fixed;bottom:0;right:0;left:0;z-index:100}\n"] }]
|
|
58
|
+
}], ctorParameters: function () { return [{ type: i1.LayoutComponentService }, { type: undefined, decorators: [{
|
|
59
|
+
type: Inject,
|
|
60
|
+
args: [RXAP_ENVIRONMENT]
|
|
61
|
+
}] }]; }, propDecorators: { sidenav: [{
|
|
39
62
|
type: ViewChild,
|
|
40
63
|
args: [MatSidenav, { static: true }]
|
|
41
64
|
}] } });
|
|
42
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF5b3V0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FuZ3VsYXIvbGF5b3V0L3NyYy9saWIvbGF5b3V0L2xheW91dC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9hbmd1bGFyL2xheW91dC9zcmMvbGliL2xheW91dC9sYXlvdXQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsTUFBTSxFQUNOLFNBQVMsR0FDVixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBRUwsVUFBVSxFQUNWLGdCQUFnQixHQUNqQixNQUFNLDJCQUEyQixDQUFDO0FBQ25DLE9BQU8sRUFDTCxvQkFBb0IsRUFFcEIsZ0JBQWdCLEdBQ2pCLE1BQU0sbUJBQW1CLENBQUM7QUFDM0IsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQzdELE9BQU8sRUFDTCxTQUFTLEVBQ1QsSUFBSSxFQUNKLGdCQUFnQixHQUNqQixNQUFNLGlCQUFpQixDQUFDO0FBQ3pCLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUNMLFVBQVUsRUFDVixZQUFZLEdBQ2IsTUFBTSxpQkFBaUIsQ0FBQztBQUN6QixPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQzdELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ3BFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG9DQUFvQyxDQUFDOzs7Ozs7O0FBeUJ6RSxNQUFNLE9BQU8sZUFBZTtJQU0xQixZQUNrQixzQkFBOEMsRUFFN0MsV0FBd0I7UUFGekIsMkJBQXNCLEdBQXRCLHNCQUFzQixDQUF3QjtRQUU3QyxnQkFBVyxHQUFYLFdBQVcsQ0FBYTtRQVBwQyxnQkFBVyxHQUFrQixNQUFNLENBQUM7SUFReEMsQ0FBQztJQUVKLElBQVcsT0FBTztRQUNoQixPQUFPLG9CQUFvQixDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUNoRCxDQUFDO0lBRU0saUJBQWlCO1FBQ3RCLElBQUksSUFBSSxDQUFDLFdBQVcsS0FBSyxNQUFNLEVBQUU7WUFDL0IsSUFBSSxDQUFDLFdBQVcsR0FBRyxNQUFNLENBQUM7WUFDMUIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsQ0FBQztTQUNyQjthQUFNO1lBQ0wsSUFBSSxDQUFDLFdBQVcsR0FBRyxNQUFNLENBQUM7U0FDM0I7SUFDSCxDQUFDOzhHQXZCVSxlQUFlLHdEQVFoQixnQkFBZ0I7a0dBUmYsZUFBZSxnSEFJZixVQUFVLDhEQzdEdkIsZy9EQWtEQSxpZURSSSxlQUFlLHFGQUNmLGdCQUFnQiwwWUFFaEIsZ0JBQWdCLGlpQkFDaEIsYUFBYSxtTEFDYixlQUFlLDRMQUNmLFVBQVUsNE5BQ1YsSUFBSSw2RkFDSixlQUFlLHVEQUNmLGFBQWEsK0JBQ2IsZ0JBQWdCLDRNQUNoQixtQkFBbUIsb0dBQ25CLFlBQVk7OzJGQUdILGVBQWU7a0JBdEIzQixTQUFTOytCQUNFLGFBQWEsbUJBR04sdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxJQUFJLFdBQ1A7d0JBQ1AsZUFBZTt3QkFDZixnQkFBZ0I7d0JBQ2hCLFNBQVM7d0JBQ1QsZ0JBQWdCO3dCQUNoQixhQUFhO3dCQUNiLGVBQWU7d0JBQ2YsVUFBVTt3QkFDVixJQUFJO3dCQUNKLGVBQWU7d0JBQ2YsYUFBYTt3QkFDYixnQkFBZ0I7d0JBQ2hCLG1CQUFtQjt3QkFDbkIsWUFBWTtxQkFDYjs7MEJBVUUsTUFBTTsyQkFBQyxnQkFBZ0I7NENBSnNCLE9BQU87c0JBQXRELFNBQVM7dUJBQUMsVUFBVSxFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIEluamVjdCxcbiAgVmlld0NoaWxkLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gIE1hdERyYXdlck1vZGUsXG4gIE1hdFNpZGVuYXYsXG4gIE1hdFNpZGVuYXZNb2R1bGUsXG59IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3NpZGVuYXYnO1xuaW1wb3J0IHtcbiAgRGV0ZXJtaW5lUmVsZWFzZU5hbWUsXG4gIEVudmlyb25tZW50LFxuICBSWEFQX0VOVklST05NRU5ULFxufSBmcm9tICdAcnhhcC9lbnZpcm9ubWVudCc7XG5pbXBvcnQgeyBIZWFkZXJDb21wb25lbnQgfSBmcm9tICcuLi9oZWFkZXIvaGVhZGVyLmNvbXBvbmVudCc7XG5pbXBvcnQge1xuICBBc3luY1BpcGUsXG4gIE5nSWYsXG4gIE5nT3B0aW1pemVkSW1hZ2UsXG59IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBGbGV4TGF5b3V0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZmxleC1sYXlvdXQnO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHsgTWF0QnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcbmltcG9ydCB7XG4gIFJvdXRlckxpbmssXG4gIFJvdXRlck91dGxldCxcbn0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcbmltcG9ydCB7IE1hdE1lbnVNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9tZW51JztcbmltcG9ydCB7IEZvb3RlckNvbXBvbmVudCB9IGZyb20gJy4uL2Zvb3Rlci9mb290ZXIuY29tcG9uZW50JztcbmltcG9ydCB7IExheW91dENvbXBvbmVudFNlcnZpY2UgfSBmcm9tICcuL2xheW91dC5jb21wb25lbnQuc2VydmljZSc7XG5pbXBvcnQgeyBOYXZpZ2F0aW9uQ29tcG9uZW50IH0gZnJvbSAnLi4vbmF2aWdhdGlvbi9uYXZpZ2F0aW9uLmNvbXBvbmVudCc7XG5cblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncnhhcC1sYXlvdXQnLFxuICB0ZW1wbGF0ZVVybDogJy4vbGF5b3V0LmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbICcuL2xheW91dC5jb21wb25lbnQuc2NzcycgXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtcbiAgICBIZWFkZXJDb21wb25lbnQsXG4gICAgTWF0U2lkZW5hdk1vZHVsZSxcbiAgICBBc3luY1BpcGUsXG4gICAgRmxleExheW91dE1vZHVsZSxcbiAgICBNYXRJY29uTW9kdWxlLFxuICAgIE1hdEJ1dHRvbk1vZHVsZSxcbiAgICBSb3V0ZXJMaW5rLFxuICAgIE5nSWYsXG4gICAgRm9vdGVyQ29tcG9uZW50LFxuICAgIE1hdE1lbnVNb2R1bGUsXG4gICAgTmdPcHRpbWl6ZWRJbWFnZSxcbiAgICBOYXZpZ2F0aW9uQ29tcG9uZW50LFxuICAgIFJvdXRlck91dGxldCxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgTGF5b3V0Q29tcG9uZW50IHtcblxuICBwdWJsaWMgc2lkZW5hdk1vZGU6IE1hdERyYXdlck1vZGUgPSAnb3Zlcic7XG5cbiAgQFZpZXdDaGlsZChNYXRTaWRlbmF2LCB7IHN0YXRpYzogdHJ1ZSB9KSBwdWJsaWMgc2lkZW5hdiE6IE1hdFNpZGVuYXY7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHVibGljIHJlYWRvbmx5IGxheW91dENvbXBvbmVudFNlcnZpY2U6IExheW91dENvbXBvbmVudFNlcnZpY2UsXG4gICAgQEluamVjdChSWEFQX0VOVklST05NRU5UKVxuICAgIHByaXZhdGUgcmVhZG9ubHkgZW52aXJvbm1lbnQ6IEVudmlyb25tZW50LFxuICApIHt9XG5cbiAgcHVibGljIGdldCByZWxlYXNlKCkge1xuICAgIHJldHVybiBEZXRlcm1pbmVSZWxlYXNlTmFtZSh0aGlzLmVudmlyb25tZW50KTtcbiAgfVxuXG4gIHB1YmxpYyB0b2dnbGVTaWRlbmF2TW9kZSgpIHtcbiAgICBpZiAodGhpcy5zaWRlbmF2TW9kZSA9PT0gJ292ZXInKSB7XG4gICAgICB0aGlzLnNpZGVuYXZNb2RlID0gJ3NpZGUnO1xuICAgICAgdGhpcy5zaWRlbmF2Lm9wZW4oKTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5zaWRlbmF2TW9kZSA9ICdvdmVyJztcbiAgICB9XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJmbGV4IGZsZXgtY29sIGgtc2NyZWVuIGp1c3RpZnktYmV0d2VlblwiPlxuICA8cnhhcC1oZWFkZXIgW3NpZGVuYXZdPVwic2lkZW5hdlwiIGNsYXNzPVwiei0xMCB3LWZ1bGwgZml4ZWQgdG9wLTBcIj48L3J4YXAtaGVhZGVyPlxuICA8bWF0LXNpZGVuYXYtY29udGFpbmVyIGNsYXNzPVwiZ3JvdyBtdC0xNiBtYi0xNlwiPlxuICAgIDxtYXQtc2lkZW5hdlxuICAgICAgI21hdFNpZGVuYXY9XCJtYXRTaWRlbmF2XCJcbiAgICAgIChtb3VzZWVudGVyKT1cInNpZGVuYXZNb2RlID09PSAnb3ZlcicgJiYgbWF0U2lkZW5hdi5vcGVuKClcIlxuICAgICAgKG1vdXNlbGVhdmUpPVwic2lkZW5hdk1vZGUgPT09ICdvdmVyJyAmJiBtYXRTaWRlbmF2LmNsb3NlKClcIlxuICAgICAgW2ZpeGVkQm90dG9tR2FwXT1cIjY0XCJcbiAgICAgIFtmaXhlZEluVmlld3BvcnRdPVwidHJ1ZVwiXG4gICAgICBbZml4ZWRUb3BHYXBdPVwiNjRcIlxuICAgICAgW21vZGVdPVwic2lkZW5hdk1vZGVcIlxuICAgICAgW29wZW5lZF09XCJmYWxzZVwiXG4gICAgICBjbGFzcz1cInNpZGVuYXZcIlxuICAgID5cbiAgICAgIDxkaXYgY2xhc3M9XCJoLWZ1bGwgcHktMiBmbGV4IGZsZXgtY29sIGl0ZW1zLWNlbnRlciBnYXAteS01IGp1c3RpZnktaXRlbXMtc3RyZXRjaFwiPlxuXG4gICAgICAgIDxkaXYgKGNsaWNrKT1cInRvZ2dsZVNpZGVuYXZNb2RlKClcIlxuICAgICAgICAgICAgIGNsYXNzPVwicGwtMiBwci0xIHNlbGYtc3RyZXRjaCBncm93LTAgZmxleCBmbGV4LXJvdyBqdXN0aWZ5LWJldHdlZW4gaXRlbXMtY2VudGVyXCI+XG4gICAgICAgICAgPHNwYW4gY2xhc3M9XCJ0ZXh0LWxnXCIgaTE4bj5OYXZpZ2F0aW9uPC9zcGFuPlxuICAgICAgICAgIDxidXR0b24gbWF0LWljb24tYnV0dG9uPlxuICAgICAgICAgICAgPG1hdC1pY29uICpuZ0lmPVwic2lkZW5hdk1vZGUgPT09ICdvdmVyJ1wiPnJhZGlvX2J1dHRvbl91bmNoZWNrZWQ8L21hdC1pY29uPlxuICAgICAgICAgICAgPG1hdC1pY29uICpuZ0lmPVwic2lkZW5hdk1vZGUgPT09ICdzaWRlJ1wiPnJhZGlvX2J1dHRvbl9jaGVja2VkPC9tYXQtaWNvbj5cbiAgICAgICAgICA8L2J1dHRvbj5cbiAgICAgICAgPC9kaXY+XG5cbiAgICAgICAgPHVsIGNsYXNzPVwiZ3JvdyBzZWxmLXN0cmV0Y2hcIiByb290IHJ4YXAtbmF2aWdhdGlvbj48L3VsPlxuXG4gICAgICAgIDxpbWdcbiAgICAgICAgICBbaGVpZ2h0XT1cImxheW91dENvbXBvbmVudFNlcnZpY2UubG9nby5oZWlnaHQgPz8gMTI4XCJcbiAgICAgICAgICBbbmdTcmNdPVwibGF5b3V0Q29tcG9uZW50U2VydmljZS5sb2dvLnNyYyA/PyAnaHR0cHM6Ly92aWEucGxhY2Vob2xkZXIuY29tLzI1NngxMjhweCdcIlxuICAgICAgICAgIFtyb3V0ZXJMaW5rXT1cIlsnLyddXCJcbiAgICAgICAgICBbd2lkdGhdPVwibGF5b3V0Q29tcG9uZW50U2VydmljZS5sb2dvLndpZHRoID8/IDI1NlwiXG4gICAgICAgICAgYWx0PVwibG9nb1wiXG4gICAgICAgICAgY2xhc3M9XCJncm93LTBcIlxuICAgICAgICAvPlxuICAgICAgICA8ZGl2IGNsYXNzPVwiZ3Jvdy0wXCI+XG4gICAgICAgICAgPHNwYW4+e3tyZWxlYXNlfX08L3NwYW4+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgPC9tYXQtc2lkZW5hdj5cbiAgICA8bWF0LXNpZGVuYXYtY29udGVudFxuICAgICAgW25nQ2xhc3NdPVwieyBvcGVuZWQ6IG1hdFNpZGVuYXYub3BlbmVkLCBzaWRlOiBzaWRlbmF2TW9kZSA9PT0gJ3NpZGUnIH1cIlxuICAgICAgY2xhc3M9XCJtbC0xNCBwLTRcIlxuICAgID5cbiAgICAgIDxyb3V0ZXItb3V0bGV0Pjwvcm91dGVyLW91dGxldD5cbiAgICA8L21hdC1zaWRlbmF2LWNvbnRlbnQ+XG4gIDwvbWF0LXNpZGVuYXYtY29udGFpbmVyPlxuICA8cnhhcC1mb290ZXIgY2xhc3M9XCJ6LTEwIHctZnVsbCBmaXhlZCBib3R0b20tMFwiPjwvcnhhcC1mb290ZXI+XG48L2Rpdj5cbjwhLS08cnhhcC13aW5kb3ctdGFzay1iYXItY29udGFpbmVyPjwvcnhhcC13aW5kb3ctdGFzay1iYXItY29udGFpbmVyPi0tPlxuIl19
|
|
@@ -22,7 +22,7 @@ export class LayoutComponentService {
|
|
|
22
22
|
this.headerComponentService.update$.pipe(tap(() => this.fixedTopGap$.next(this.headerComponentService.countComponent * 64))).subscribe();
|
|
23
23
|
this.logo = logoConfig ?? {
|
|
24
24
|
src: '/assets/logo.png',
|
|
25
|
-
width:
|
|
25
|
+
width: 192,
|
|
26
26
|
};
|
|
27
27
|
}
|
|
28
28
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: LayoutComponentService, deps: [{ token: i1.FooterService }, { token: i1.HeaderService }, { token: RXAP_LOGO_CONFIG, optional: true }, { token: ConfigService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
@@ -40,4 +40,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.4", ngImpor
|
|
|
40
40
|
type: Inject,
|
|
41
41
|
args: [ConfigService]
|
|
42
42
|
}] }]; } });
|
|
43
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF5b3V0LmNvbXBvbmVudC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5ndWxhci9sYXlvdXQvc3JjL2xpYi9sYXlvdXQvbGF5b3V0LmNvbXBvbmVudC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxNQUFNLEVBQ04sVUFBVSxFQUNWLFFBQVEsR0FDVCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQ0wsZUFBZSxHQUVoQixNQUFNLE1BQU0sQ0FBQztBQUNkLE9BQU8sRUFDTCxHQUFHLEVBQ0gsR0FBRyxHQUNKLE1BQU0sZ0JBQWdCLENBQUM7QUFDeEIsT0FBTyxFQUNMLGFBQWEsRUFDYixhQUFhLEdBQ2QsTUFBTSxnQkFBZ0IsQ0FBQztBQUN4QixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFFN0MsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGNBQWMsQ0FBQzs7OztBQUk3QyxNQUFNLE9BQU8sc0JBQXNCO0lBUWpDLFlBQ2tCLHNCQUFxQyxFQUNyQyxzQkFBcUMsRUFDZixhQUFnQyxJQUFJLEVBRXpELE1BQXFCO1FBSnRCLDJCQUFzQixHQUF0QixzQkFBc0IsQ0FBZTtRQUNyQywyQkFBc0IsR0FBdEIsc0JBQXNCLENBQWU7UUFHcEMsV0FBTSxHQUFOLE1BQU0sQ0FBZTtRQVhqQyxZQUFPLEdBQUcsSUFBSSxlQUFlLENBQVUsSUFBSSxDQUFDLENBQUM7UUFDN0MsVUFBSyxHQUFHLElBQUksZUFBZSxDQUFnQixNQUFNLENBQUMsQ0FBQztRQUVuRCxpQkFBWSxHQUFHLElBQUksZUFBZSxDQUFTLEVBQUUsQ0FBQyxDQUFDO1FBVXBELElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLGlCQUFpQixFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztRQUN0RSxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7UUFDMUUsSUFBSSxDQUFDLGVBQWUsR0FBRyxJQUFJLENBQUMsc0JBQXNCLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxLQUFLLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUMvRixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsc0JBQXNCLENBQUMsY0FBYyxHQUFHLEVBQUUsQ0FBQyxDQUFDO1FBQ3hFLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUN0QyxHQUFHLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLHNCQUFzQixDQUFDLGNBQWMsR0FBRyxFQUFFLENBQUMsQ0FBQyxDQUNuRixDQUFDLFNBQVMsRUFBRSxDQUFDO1FBQ2QsSUFBSSxDQUFDLElBQUksR0FBRyxVQUFVLElBQUk7WUFDeEIsR0FBRyxFQUFFLGtCQUFrQjtZQUN2QixLQUFLLEVBQUUsR0FBRztTQUNYLENBQUM7SUFDSixDQUFDOzhHQTFCVSxzQkFBc0IsNEVBV1gsZ0JBQWdCLDZCQUM1QixhQUFhO2tIQVpaLHNCQUFzQixjQURULE1BQU07OzJGQUNuQixzQkFBc0I7a0JBRGxDLFVBQVU7bUJBQUMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFOzswQkFZN0IsUUFBUTs7MEJBQUksTUFBTTsyQkFBQyxnQkFBZ0I7OzBCQUNuQyxNQUFNOzJCQUFDLGFBQWEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBJbmplY3QsXG4gIEluamVjdGFibGUsXG4gIE9wdGlvbmFsLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gIEJlaGF2aW9yU3ViamVjdCxcbiAgT2JzZXJ2YWJsZSxcbn0gZnJvbSAncnhqcyc7XG5pbXBvcnQge1xuICBtYXAsXG4gIHRhcCxcbn0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuaW1wb3J0IHtcbiAgRm9vdGVyU2VydmljZSxcbiAgSGVhZGVyU2VydmljZSxcbn0gZnJvbSAnQHJ4YXAvc2VydmljZXMnO1xuaW1wb3J0IHsgUlhBUF9MT0dPX0NPTkZJRyB9IGZyb20gJy4uL3Rva2Vucyc7XG5pbXBvcnQgeyBMb2dvQ29uZmlnIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgQ29uZmlnU2VydmljZSB9IGZyb20gJ0ByeGFwL2NvbmZpZyc7XG5pbXBvcnQgeyBNYXREcmF3ZXJNb2RlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc2lkZW5hdic7XG5cbkBJbmplY3RhYmxlKHsgcHJvdmlkZWRJbjogJ3Jvb3QnIH0pXG5leHBvcnQgY2xhc3MgTGF5b3V0Q29tcG9uZW50U2VydmljZSB7XG5cbiAgcHVibGljIG9wZW5lZCQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PGJvb2xlYW4+KHRydWUpO1xuICBwdWJsaWMgbW9kZSQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PE1hdERyYXdlck1vZGU+KCdzaWRlJyk7XG4gIHB1YmxpYyBmaXhlZEJvdHRvbUdhcCQ6IE9ic2VydmFibGU8bnVtYmVyPjtcbiAgcHVibGljIGZpeGVkVG9wR2FwJCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8bnVtYmVyPig2NCk7XG4gIHB1YmxpYyBsb2dvOiBMb2dvQ29uZmlnO1xuXG4gIHB1YmxpYyBjb25zdHJ1Y3RvcihcbiAgICBwdWJsaWMgcmVhZG9ubHkgZm9vdGVyQ29tcG9uZW50U2VydmljZTogRm9vdGVyU2VydmljZSxcbiAgICBwdWJsaWMgcmVhZG9ubHkgaGVhZGVyQ29tcG9uZW50U2VydmljZTogSGVhZGVyU2VydmljZSxcbiAgICBAT3B0aW9uYWwoKSBASW5qZWN0KFJYQVBfTE9HT19DT05GSUcpIGxvZ29Db25maWc6IExvZ29Db25maWcgfCBudWxsID0gbnVsbCxcbiAgICBASW5qZWN0KENvbmZpZ1NlcnZpY2UpXG4gICAgcHJpdmF0ZSByZWFkb25seSBjb25maWc6IENvbmZpZ1NlcnZpY2UsXG4gICkge1xuICAgIHRoaXMubW9kZSQubmV4dCh0aGlzLmNvbmZpZy5nZXQoJ25hdmlnYXRpb24ubW9kZScsIHRoaXMubW9kZSQudmFsdWUpKTtcbiAgICB0aGlzLm9wZW5lZCQubmV4dCh0aGlzLmNvbmZpZy5nZXQoJ25hdmlnYXRpb24ub3BlbicsIHRoaXMub3BlbmVkJC52YWx1ZSkpO1xuICAgIHRoaXMuZml4ZWRCb3R0b21HYXAkID0gdGhpcy5mb290ZXJDb21wb25lbnRTZXJ2aWNlLnBvcnRhbENvdW50JC5waXBlKG1hcChjb3VudCA9PiBjb3VudCAqIDY0KSk7XG4gICAgdGhpcy5maXhlZFRvcEdhcCQubmV4dCh0aGlzLmhlYWRlckNvbXBvbmVudFNlcnZpY2UuY291bnRDb21wb25lbnQgKiA2NCk7XG4gICAgdGhpcy5oZWFkZXJDb21wb25lbnRTZXJ2aWNlLnVwZGF0ZSQucGlwZShcbiAgICAgIHRhcCgoKSA9PiB0aGlzLmZpeGVkVG9wR2FwJC5uZXh0KHRoaXMuaGVhZGVyQ29tcG9uZW50U2VydmljZS5jb3VudENvbXBvbmVudCAqIDY0KSksXG4gICAgKS5zdWJzY3JpYmUoKTtcbiAgICB0aGlzLmxvZ28gPSBsb2dvQ29uZmlnID8/IHtcbiAgICAgIHNyYzogJy9hc3NldHMvbG9nby5wbmcnLFxuICAgICAgd2lkdGg6IDE5MixcbiAgICB9O1xuICB9XG5cbn1cbiJdfQ==
|
|
@@ -1,29 +1,33 @@
|
|
|
1
1
|
import { __decorate, __metadata } from "tslib";
|
|
2
|
-
import { ChangeDetectionStrategy, Component, ElementRef,
|
|
3
|
-
import {
|
|
2
|
+
import { ChangeDetectionStrategy, Component, ElementRef, forwardRef, HostBinding, Inject, Input, Renderer2, signal, ViewChild, ViewContainerRef, ViewEncapsulation, } from '@angular/core';
|
|
3
|
+
import { Required } from '@rxap/utilities';
|
|
4
4
|
import { animate, style, transition, trigger, } from '@angular/animations';
|
|
5
5
|
import { NavigationEnd, Router, RouterLink, RouterLinkActive, } from '@angular/router';
|
|
6
|
-
import { Subscription } from 'rxjs';
|
|
7
|
-
import {
|
|
6
|
+
import { debounceTime, Subscription, } from 'rxjs';
|
|
7
|
+
import { filter, startWith, tap, } from 'rxjs/operators';
|
|
8
|
+
import { Overlay } from '@angular/cdk/overlay';
|
|
8
9
|
import { SidenavComponentService } from '../../sidenav/sidenav.component.service';
|
|
9
|
-
import { Overlay, } from '@angular/cdk/overlay';
|
|
10
|
-
import { TemplatePortal } from '@angular/cdk/portal';
|
|
11
|
-
import { FlexModule } from '@angular/flex-layout/flex';
|
|
12
10
|
import { NavigationComponent } from '../navigation.component';
|
|
11
|
+
import { MatDividerModule } from '@angular/material/divider';
|
|
13
12
|
import { IconDirective } from '@rxap/material-directives/icon';
|
|
14
13
|
import { MatIconModule } from '@angular/material/icon';
|
|
15
|
-
import { AsyncPipe, NgFor, NgIf, } from '@angular/common';
|
|
16
|
-
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
17
14
|
import { MatRippleModule } from '@angular/material/core';
|
|
15
|
+
import { NgClass, NgIf, } from '@angular/common';
|
|
18
16
|
import * as i0 from "@angular/core";
|
|
19
17
|
import * as i1 from "@angular/material/core";
|
|
20
|
-
import * as i2 from "@angular/material/
|
|
21
|
-
import * as i3 from "@angular/material/
|
|
22
|
-
import * as i4 from "@angular/
|
|
23
|
-
import * as i5 from "
|
|
24
|
-
import * as i6 from "
|
|
25
|
-
import * as i7 from "@angular/cdk/overlay";
|
|
18
|
+
import * as i2 from "@angular/material/icon";
|
|
19
|
+
import * as i3 from "@angular/material/divider";
|
|
20
|
+
import * as i4 from "@angular/router";
|
|
21
|
+
import * as i5 from "../../sidenav/sidenav.component.service";
|
|
22
|
+
import * as i6 from "@angular/cdk/overlay";
|
|
26
23
|
export class NavigationItemComponent {
|
|
24
|
+
get isActive() {
|
|
25
|
+
return this._isActive;
|
|
26
|
+
}
|
|
27
|
+
set isActive(value) {
|
|
28
|
+
this._isActive = value;
|
|
29
|
+
this.active.set(value);
|
|
30
|
+
}
|
|
27
31
|
constructor(router, sidenav, elementRef, renderer, overlay, viewContainerRef) {
|
|
28
32
|
this.router = router;
|
|
29
33
|
this.sidenav = sidenav;
|
|
@@ -31,14 +35,11 @@ export class NavigationItemComponent {
|
|
|
31
35
|
this.renderer = renderer;
|
|
32
36
|
this.overlay = overlay;
|
|
33
37
|
this.viewContainerRef = viewContainerRef;
|
|
34
|
-
this.children = null;
|
|
35
38
|
this.level = 0;
|
|
36
|
-
this.
|
|
39
|
+
this._isActive = false;
|
|
40
|
+
this.children = null;
|
|
41
|
+
this.active = signal(false);
|
|
37
42
|
this._subscription = new Subscription();
|
|
38
|
-
/**
|
|
39
|
-
* indicates the mouse is over the
|
|
40
|
-
*/
|
|
41
|
-
this.lockeOverlay = false;
|
|
42
43
|
}
|
|
43
44
|
ngOnChanges(changes) {
|
|
44
45
|
if (changes['item']) {
|
|
@@ -49,12 +50,20 @@ export class NavigationItemComponent {
|
|
|
49
50
|
}
|
|
50
51
|
ngAfterViewInit() {
|
|
51
52
|
this._subscription.add(this.router.events
|
|
52
|
-
.pipe(filter((event) => event instanceof NavigationEnd),
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
53
|
+
.pipe(filter((event) => event instanceof NavigationEnd), debounceTime(100), startWith(true), tap(() => {
|
|
54
|
+
let isActive = true;
|
|
55
|
+
const urlParts = this.router.url.split('/');
|
|
56
|
+
if (urlParts[0] === '') {
|
|
57
|
+
urlParts[0] = '/';
|
|
58
|
+
}
|
|
59
|
+
for (let i = 0; i < this.item.routerLink.length; i++) {
|
|
60
|
+
if (urlParts[i] !== this.item.routerLink[i]) {
|
|
61
|
+
isActive = false;
|
|
62
|
+
break;
|
|
57
63
|
}
|
|
64
|
+
}
|
|
65
|
+
this.isActive = isActive;
|
|
66
|
+
if (isActive) {
|
|
58
67
|
this.renderer.addClass(this.elementRef.nativeElement, 'active');
|
|
59
68
|
}
|
|
60
69
|
else {
|
|
@@ -63,45 +72,8 @@ export class NavigationItemComponent {
|
|
|
63
72
|
}))
|
|
64
73
|
.subscribe());
|
|
65
74
|
}
|
|
66
|
-
ngOnInit() {
|
|
67
|
-
// detach the navigation overlay if the sidenav collapsed
|
|
68
|
-
// state is changed
|
|
69
|
-
this._subscription.add(this.sidenav.collapsed$
|
|
70
|
-
.pipe(skip(1), distinctUntilChanged(), tap(() => this._overlayRef?.detach()))
|
|
71
|
-
.subscribe());
|
|
72
|
-
}
|
|
73
75
|
ngOnDestroy() {
|
|
74
76
|
this._subscription?.unsubscribe();
|
|
75
|
-
this._overlayRef?.dispose();
|
|
76
|
-
}
|
|
77
|
-
onMouseenter() {
|
|
78
|
-
if (this.children) {
|
|
79
|
-
if (!this.routerLinkActive.isActive || this.sidenav.collapsed$.value) {
|
|
80
|
-
if (!this._overlayRef) {
|
|
81
|
-
this._overlayRef = this.overlay.create({
|
|
82
|
-
positionStrategy: this.overlay
|
|
83
|
-
.position()
|
|
84
|
-
.flexibleConnectedTo(this.elementRef)
|
|
85
|
-
.withPositions([
|
|
86
|
-
{
|
|
87
|
-
originY: 'top',
|
|
88
|
-
originX: 'end',
|
|
89
|
-
overlayY: 'top',
|
|
90
|
-
overlayX: 'start',
|
|
91
|
-
},
|
|
92
|
-
]),
|
|
93
|
-
});
|
|
94
|
-
}
|
|
95
|
-
if (!this._overlayRef.hasAttached()) {
|
|
96
|
-
this._embeddedViewRef = this._overlayRef.attach(new TemplatePortal(this._navigationOverlay, this.viewContainerRef));
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
onMouseleave() {
|
|
102
|
-
if (!this.lockeOverlay) {
|
|
103
|
-
this._overlayRef?.detach();
|
|
104
|
-
}
|
|
105
77
|
}
|
|
106
78
|
// region type save item property
|
|
107
79
|
// required to check the type of the item property in the ngFor loop
|
|
@@ -118,7 +90,7 @@ export class NavigationItemComponent {
|
|
|
118
90
|
return item;
|
|
119
91
|
}
|
|
120
92
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: NavigationItemComponent, deps: [{ token: Router }, { token: SidenavComponentService }, { token: ElementRef }, { token: Renderer2 }, { token: Overlay }, { token: ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
121
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.4", type: NavigationItemComponent, isStandalone: true, selector: "li[rxap-navigation-item]", inputs: {
|
|
93
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.4", type: NavigationItemComponent, isStandalone: true, selector: "li[rxap-navigation-item]", inputs: { level: "level", item: "item" }, host: { properties: { "class.active": "this.isActive" } }, viewQueries: [{ propertyName: "routerLinkActive", first: true, predicate: RouterLinkActive, descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<div [ngClass]=\"{\n 'border-l-4 text-accent-400 border-accent-600': active(),\n }\">\n <a [routerLink]=\"item.routerLink\"\n class=\"h-12 px-4 flex flex-row justify-between items-center gap-x-4\"\n matRipple\n routerLinkActive\n\n >\n <span\n [ngClass]=\"{\n 'pl-0': level === 0,\n 'pl-4': level === 1,\n 'pl-8': level === 2,\n 'pl-12': level === 3\n }\"\n class=\"grow whitespace-nowrap\"\n >\n {{ item.label }}\n </span>\n <mat-icon *ngIf=\"item.icon\" [rxapIcon]=\"item.icon\"></mat-icon>\n </a>\n\n <ng-container *ngIf=\"item.children?.length && active()\">\n\n <mat-divider></mat-divider>\n\n <ul [@sub-nav]\n [items]=\"children ?? []\"\n [level]=\"level + 1\"\n rxap-navigation\n >\n </ul>\n\n <mat-divider></mat-divider>\n\n </ng-container>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i0.forwardRef(function () { return RouterLinkActive; }), selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "ariaCurrentWhenActive", "routerLinkActive"], outputs: ["isActiveChange"], exportAs: ["routerLinkActive"] }, { kind: "directive", type: i0.forwardRef(function () { return RouterLink; }), selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i0.forwardRef(function () { return NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: i0.forwardRef(function () { return MatRippleModule; }) }, { kind: "directive", type: i0.forwardRef(function () { return i1.MatRipple; }), selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }, { kind: "ngmodule", type: i0.forwardRef(function () { return MatIconModule; }) }, { kind: "component", type: i0.forwardRef(function () { return i2.MatIcon; }), selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i0.forwardRef(function () { return IconDirective; }), selector: "mat-icon[rxapIcon]", inputs: ["rxapIcon"] }, { kind: "ngmodule", type: i0.forwardRef(function () { return MatDividerModule; }) }, { kind: "component", type: i0.forwardRef(function () { return i3.MatDivider; }), selector: "mat-divider", inputs: ["vertical", "inset"] }, { kind: "component", type: i0.forwardRef(function () { return NavigationComponent; }), selector: "ul[rxap-navigation]", inputs: ["items", "level", "root"] }, { kind: "directive", type: i0.forwardRef(function () { return NgClass; }), selector: "[ngClass]", inputs: ["class", "ngClass"] }], animations: [
|
|
122
94
|
trigger('sub-nav', [
|
|
123
95
|
transition(':enter', [
|
|
124
96
|
style({
|
|
@@ -140,17 +112,9 @@ __decorate([
|
|
|
140
112
|
Required,
|
|
141
113
|
__metadata("design:type", Object)
|
|
142
114
|
], NavigationItemComponent.prototype, "item", void 0);
|
|
143
|
-
__decorate([
|
|
144
|
-
DebounceCall(100),
|
|
145
|
-
__metadata("design:type", Function),
|
|
146
|
-
__metadata("design:paramtypes", []),
|
|
147
|
-
__metadata("design:returntype", void 0)
|
|
148
|
-
], NavigationItemComponent.prototype, "onMouseleave", null);
|
|
149
115
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: NavigationItemComponent, decorators: [{
|
|
150
116
|
type: Component,
|
|
151
|
-
args: [{ selector: 'li[rxap-navigation-item]', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None,
|
|
152
|
-
class: 'rxap-navigation-item',
|
|
153
|
-
}, animations: [
|
|
117
|
+
args: [{ selector: 'li[rxap-navigation-item]', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, animations: [
|
|
154
118
|
trigger('sub-nav', [
|
|
155
119
|
transition(':enter', [
|
|
156
120
|
style({
|
|
@@ -168,21 +132,19 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.4", ngImpor
|
|
|
168
132
|
]),
|
|
169
133
|
], standalone: true, imports: [
|
|
170
134
|
RouterLinkActive,
|
|
171
|
-
MatRippleModule,
|
|
172
135
|
RouterLink,
|
|
173
|
-
MatTooltipModule,
|
|
174
136
|
NgIf,
|
|
137
|
+
MatRippleModule,
|
|
175
138
|
MatIconModule,
|
|
176
139
|
IconDirective,
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
}], ctorParameters: function () { return [{ type: i5.Router, decorators: [{
|
|
140
|
+
MatDividerModule,
|
|
141
|
+
forwardRef(() => NavigationComponent),
|
|
142
|
+
NgClass,
|
|
143
|
+
], template: "<div [ngClass]=\"{\n 'border-l-4 text-accent-400 border-accent-600': active(),\n }\">\n <a [routerLink]=\"item.routerLink\"\n class=\"h-12 px-4 flex flex-row justify-between items-center gap-x-4\"\n matRipple\n routerLinkActive\n\n >\n <span\n [ngClass]=\"{\n 'pl-0': level === 0,\n 'pl-4': level === 1,\n 'pl-8': level === 2,\n 'pl-12': level === 3\n }\"\n class=\"grow whitespace-nowrap\"\n >\n {{ item.label }}\n </span>\n <mat-icon *ngIf=\"item.icon\" [rxapIcon]=\"item.icon\"></mat-icon>\n </a>\n\n <ng-container *ngIf=\"item.children?.length && active()\">\n\n <mat-divider></mat-divider>\n\n <ul [@sub-nav]\n [items]=\"children ?? []\"\n [level]=\"level + 1\"\n rxap-navigation\n >\n </ul>\n\n <mat-divider></mat-divider>\n\n </ng-container>\n</div>\n" }]
|
|
144
|
+
}], ctorParameters: function () { return [{ type: i4.Router, decorators: [{
|
|
183
145
|
type: Inject,
|
|
184
146
|
args: [Router]
|
|
185
|
-
}] }, { type:
|
|
147
|
+
}] }, { type: i5.SidenavComponentService, decorators: [{
|
|
186
148
|
type: Inject,
|
|
187
149
|
args: [SidenavComponentService]
|
|
188
150
|
}] }, { type: i0.ElementRef, decorators: [{
|
|
@@ -191,30 +153,21 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.4", ngImpor
|
|
|
191
153
|
}] }, { type: i0.Renderer2, decorators: [{
|
|
192
154
|
type: Inject,
|
|
193
155
|
args: [Renderer2]
|
|
194
|
-
}] }, { type:
|
|
156
|
+
}] }, { type: i6.Overlay, decorators: [{
|
|
195
157
|
type: Inject,
|
|
196
158
|
args: [Overlay]
|
|
197
159
|
}] }, { type: i0.ViewContainerRef, decorators: [{
|
|
198
160
|
type: Inject,
|
|
199
161
|
args: [ViewContainerRef]
|
|
200
|
-
}] }]; }, propDecorators: {
|
|
162
|
+
}] }]; }, propDecorators: { level: [{
|
|
163
|
+
type: Input
|
|
164
|
+
}], routerLinkActive: [{
|
|
201
165
|
type: ViewChild,
|
|
202
166
|
args: [RouterLinkActive, { static: true }]
|
|
203
167
|
}], item: [{
|
|
204
168
|
type: Input
|
|
205
|
-
}], level: [{
|
|
206
|
-
type: Input
|
|
207
169
|
}], isActive: [{
|
|
208
170
|
type: HostBinding,
|
|
209
171
|
args: ['class.active']
|
|
210
|
-
}], _navigationOverlay: [{
|
|
211
|
-
type: ViewChild,
|
|
212
|
-
args: ['navigationOverlay']
|
|
213
|
-
}], onMouseenter: [{
|
|
214
|
-
type: HostListener,
|
|
215
|
-
args: ['mouseenter']
|
|
216
|
-
}], onMouseleave: [{
|
|
217
|
-
type: HostListener,
|
|
218
|
-
args: ['mouseleave']
|
|
219
172
|
}] } });
|
|
220
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navigation-item.component.js","sourceRoot":"","sources":["../../../../../../../../packages/angular/layout/src/lib/navigation/navigation-item/navigation-item.component.ts","../../../../../../../../packages/angular/layout/src/lib/navigation/navigation-item/navigation-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EmbeddedViewRef,\n  HostBinding,\n  HostListener,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Renderer2,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n  ViewContainerRef,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  DebounceCall,\n  Required,\n} from '@rxap/utilities';\nimport {\n  animate,\n  style,\n  transition,\n  trigger,\n} from '@angular/animations';\nimport {\n  Navigation,\n  NavigationDividerItem,\n  NavigationItem,\n} from '../navigation-item';\nimport {\n  NavigationEnd,\n  Router,\n  RouterLink,\n  RouterLinkActive,\n} from '@angular/router';\nimport { Subscription } from 'rxjs';\nimport {\n  delay,\n  distinctUntilChanged,\n  filter,\n  skip,\n  startWith,\n  tap,\n} from 'rxjs/operators';\nimport { SidenavComponentService } from '../../sidenav/sidenav.component.service';\nimport {\n  Overlay,\n  OverlayRef,\n} from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport { FlexModule } from '@angular/flex-layout/flex';\nimport { NavigationComponent } from '../navigation.component';\nimport { IconDirective } from '@rxap/material-directives/icon';\nimport { MatIconModule } from '@angular/material/icon';\nimport {\n  AsyncPipe,\n  NgFor,\n  NgIf,\n} from '@angular/common';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { MatRippleModule } from '@angular/material/core';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'li[rxap-navigation-item]',\n  templateUrl: './navigation-item.component.html',\n  styleUrls: [ './navigation-item.component.scss' ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  // eslint-disable-next-line @angular-eslint/no-host-metadata-property\n  host: {\n    class: 'rxap-navigation-item',\n  },\n  animations: [\n    trigger('sub-nav', [\n      transition(':enter', [\n        style({\n          display: 'block',\n          height: '0',\n          overflow: 'hidden',\n        }),\n        animate(150, style({ height: '*' })),\n      ]),\n      transition(':leave', [\n        style({ overflow: 'hidden' }),\n        animate(300, style({ height: '0' })),\n        style({ display: 'none' }),\n      ]),\n    ]),\n  ],\n  standalone: true,\n  imports: [\n    RouterLinkActive,\n    MatRippleModule,\n    RouterLink,\n    MatTooltipModule,\n    NgIf,\n    MatIconModule,\n    IconDirective,\n    NavigationComponent,\n    FlexModule,\n    NgFor,\n    AsyncPipe,\n  ],\n})\nexport class NavigationItemComponent\n  implements OnChanges, AfterViewInit, OnDestroy, OnInit {\n  public children: Navigation | null = null;\n\n  @ViewChild(RouterLinkActive, { static: true })\n  public routerLinkActive!: RouterLinkActive;\n\n  @Input()\n  @Required\n  public item!: NavigationItem;\n\n  @Input()\n  public level = 0;\n\n  @HostBinding('class.active')\n  public isActive = false;\n\n  @ViewChild('navigationOverlay')\n  private _navigationOverlay!: TemplateRef<any>;\n\n  private readonly _subscription = new Subscription();\n\n  private _overlayRef?: OverlayRef;\n  private _embeddedViewRef?: EmbeddedViewRef<any>;\n\n  /**\n   * indicates the mouse is over the\n   */\n  public lockeOverlay = false;\n\n  constructor(\n    @Inject(Router)\n    private readonly router: Router,\n    @Inject(SidenavComponentService)\n    public readonly sidenav: SidenavComponentService,\n    @Inject(ElementRef)\n    private readonly elementRef: ElementRef,\n    @Inject(Renderer2)\n    private readonly renderer: Renderer2,\n    @Inject(Overlay)\n    private readonly overlay: Overlay,\n    @Inject(ViewContainerRef)\n    private readonly viewContainerRef: ViewContainerRef,\n  ) {\n  }\n\n  public ngOnChanges(changes: SimpleChanges) {\n    if (changes['item']) {\n      const item: NavigationItem = changes['item'].currentValue;\n      this.children =\n        item.children && item.children.length ? item.children : null;\n    }\n  }\n\n  public ngAfterViewInit() {\n    this._subscription.add(\n      this.router.events\n          .pipe(\n            filter((event) => event instanceof NavigationEnd),\n            startWith(true),\n            delay(100),\n            tap(() => {\n              if (this.routerLinkActive.isActive) {\n                if (!this.sidenav.collapsed$.value) {\n                  // only close the overlay if sidenav collapsed\n                  this._overlayRef?.detach();\n                }\n                this.renderer.addClass(this.elementRef.nativeElement, 'active');\n              } else {\n                this.renderer.removeClass(\n                  this.elementRef.nativeElement,\n                  'active',\n                );\n              }\n            }),\n          )\n          .subscribe(),\n    );\n  }\n\n  public ngOnInit() {\n    // detach the navigation overlay if the sidenav collapsed\n    // state is changed\n    this._subscription.add(\n      this.sidenav.collapsed$\n          .pipe(\n            skip(1),\n            distinctUntilChanged(),\n            tap(() => this._overlayRef?.detach()),\n          )\n          .subscribe(),\n    );\n  }\n\n  public ngOnDestroy() {\n    this._subscription?.unsubscribe();\n    this._overlayRef?.dispose();\n  }\n\n  @HostListener('mouseenter')\n  public onMouseenter() {\n    if (this.children) {\n      if (!this.routerLinkActive.isActive || this.sidenav.collapsed$.value) {\n        if (!this._overlayRef) {\n          this._overlayRef = this.overlay.create({\n            positionStrategy: this.overlay\n                                  .position()\n                                  .flexibleConnectedTo(this.elementRef)\n                                  .withPositions([\n                                    {\n                                      originY: 'top',\n                                      originX: 'end',\n                                      overlayY: 'top',\n                                      overlayX: 'start',\n                                    },\n                                  ]),\n          });\n        }\n        if (!this._overlayRef.hasAttached()) {\n          this._embeddedViewRef = this._overlayRef.attach(\n            new TemplatePortal(this._navigationOverlay, this.viewContainerRef),\n          );\n        }\n      }\n    }\n  }\n\n  @HostListener('mouseleave')\n  @DebounceCall(100)\n  public onMouseleave() {\n    if (!this.lockeOverlay) {\n      this._overlayRef?.detach();\n    }\n  }\n\n  // region type save item property\n\n  // required to check the type of the item property in the ngFor loop\n\n  public isNavigationDividerItem(\n    item: NavigationItem | NavigationDividerItem,\n  ): item is NavigationDividerItem {\n    return (item as any)['divider'];\n  }\n\n  public isNavigationItem(\n    item: NavigationItem | NavigationDividerItem,\n  ): item is NavigationItem {\n    return !this.isNavigationDividerItem(item);\n  }\n\n  public asNavigationItem(\n    item: NavigationItem | NavigationDividerItem,\n  ): NavigationItem {\n    if (!this.isNavigationItem(item)) {\n      throw new Error('The item is not a NavigationItem');\n    }\n    return item;\n  }\n\n  // endregion\n}\n","<a [matTooltipDisabled]=\"(sidenav.collapsed$ | async) === false\"\n   [matTooltip]=\"item.label\"\n   [routerLink]=\"item.routerLink\"\n   class=\"navigation-link mat-body-2 mat-body-strong navigation-level-{{level}}\"\n   matRipple routerLinkActive=\"link-active\">\n  <mat-icon *ngIf=\"item.icon\" [rxapIcon]=\"item.icon\" class=\"icon\"></mat-icon>\n  <ng-template [ngIf]=\"(sidenav.collapsed$ | async) === false\">\n    <span class=\"label\">{{ item.label }}</span>\n  </ng-template>\n</a>\n\n<ul *ngIf=\"routerLinkActive.isActive && (sidenav.collapsed$ | async) === false && children\"\n    [@sub-nav]\n    [items]=\"children\"\n    [level]=\"level + 1\"\n    class=\"sub-items\"\n    fxFlex=\"nogrow\"\n    rxap-navigation\n>\n</ul>\n\n<ng-template #navigationOverlay>\n  <div (mouseenter)=\"lockeOverlay = true\"\n       (mouseleave)=\"lockeOverlay = false; onMouseleave()\" class=\"navigation-overlay-container mat-elevation-z1\">\n    <ul>\n      <li *ngFor=\"let child of children\">\n        <a *ngIf=\"isNavigationItem(child)\" [routerLink]=\"asNavigationItem(child).routerLink\"\n           class=\"navigation-link mat-subtitle-2 mat-body-strong\" matRipple>\n          <mat-icon *ngIf=\"asNavigationItem(child).icon\" [rxapIcon]=\"asNavigationItem(child).icon\"\n                    class=\"icon\"></mat-icon>\n          <span class=\"label\">{{ asNavigationItem(child).label }}</span>\n        </a>\n      </li>\n    </ul>\n  </div>\n</ng-template>\n"]}
|
|
173
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navigation-item.component.js","sourceRoot":"","sources":["../../../../../../../../packages/angular/layout/src/lib/navigation/navigation-item/navigation-item.component.ts","../../../../../../../../packages/angular/layout/src/lib/navigation/navigation-item/navigation-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  forwardRef,\n  HostBinding,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Renderer2,\n  signal,\n  SimpleChanges,\n  ViewChild,\n  ViewContainerRef,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { Required } from '@rxap/utilities';\nimport {\n  animate,\n  style,\n  transition,\n  trigger,\n} from '@angular/animations';\nimport {\n  NavigationEnd,\n  Router,\n  RouterLink,\n  RouterLinkActive,\n} from '@angular/router';\nimport {\n  debounceTime,\n  Subscription,\n} from 'rxjs';\nimport {\n  filter,\n  startWith,\n  tap,\n} from 'rxjs/operators';\nimport { Overlay } from '@angular/cdk/overlay';\nimport { SidenavComponentService } from '../../sidenav/sidenav.component.service';\nimport { NavigationComponent } from '../navigation.component';\nimport { MatDividerModule } from '@angular/material/divider';\nimport { IconDirective } from '@rxap/material-directives/icon';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatRippleModule } from '@angular/material/core';\nimport {\n  NgClass,\n  NgIf,\n} from '@angular/common';\nimport {\n  Navigation,\n  NavigationDividerItem,\n  NavigationItem,\n} from '../navigation-item';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'li[rxap-navigation-item]',\n  templateUrl: './navigation-item.component.html',\n  styleUrls: [ './navigation-item.component.scss' ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  animations: [\n    trigger('sub-nav', [\n      transition(':enter', [\n        style({\n          display: 'block',\n          height: '0',\n          overflow: 'hidden',\n        }),\n        animate(150, style({ height: '*' })),\n      ]),\n      transition(':leave', [\n        style({ overflow: 'hidden' }),\n        animate(300, style({ height: '0' })),\n        style({ display: 'none' }),\n      ]),\n    ]),\n  ],\n  standalone: true,\n  imports: [\n    RouterLinkActive,\n    RouterLink,\n    NgIf,\n    MatRippleModule,\n    MatIconModule,\n    IconDirective,\n    MatDividerModule,\n    forwardRef(() => NavigationComponent),\n    NgClass,\n  ],\n})\nexport class NavigationItemComponent\n  implements OnChanges, OnDestroy {\n\n  @Input()\n  public level = 0;\n\n  private _isActive = false;\n\n  public children: Navigation | null = null;\n\n  @ViewChild(RouterLinkActive, { static: true })\n  public routerLinkActive!: RouterLinkActive;\n\n  @Input()\n  @Required\n  public item!: NavigationItem;\n\n  public active = signal(false);\n\n  @HostBinding('class.active')\n  get isActive(): boolean {\n    return this._isActive;\n  }\n\n  set isActive(value: boolean) {\n    this._isActive = value;\n    this.active.set(value);\n  }\n\n  private readonly _subscription = new Subscription();\n\n  constructor(\n    @Inject(Router)\n    private readonly router: Router,\n    @Inject(SidenavComponentService)\n    public readonly sidenav: SidenavComponentService,\n    @Inject(ElementRef)\n    private readonly elementRef: ElementRef,\n    @Inject(Renderer2)\n    private readonly renderer: Renderer2,\n    @Inject(Overlay)\n    private readonly overlay: Overlay,\n    @Inject(ViewContainerRef)\n    private readonly viewContainerRef: ViewContainerRef,\n  ) {\n  }\n\n  public ngOnChanges(changes: SimpleChanges) {\n    if (changes['item']) {\n      const item: NavigationItem = changes['item'].currentValue;\n      this.children =\n        item.children && item.children.length ? item.children : null;\n    }\n  }\n\n  public ngAfterViewInit() {\n    this._subscription.add(\n      this.router.events\n          .pipe(\n            filter((event) => event instanceof NavigationEnd),\n            debounceTime(100),\n            startWith(true),\n            tap(() => {\n              let isActive = true;\n              const urlParts = this.router.url.split('/');\n              if (urlParts[0] === '') {\n                urlParts[0] = '/';\n              }\n              for (let i = 0; i < this.item.routerLink.length; i++) {\n                if (urlParts[i] !== this.item.routerLink[i]) {\n                  isActive = false;\n                  break;\n                }\n              }\n              this.isActive = isActive;\n              if (isActive) {\n                this.renderer.addClass(this.elementRef.nativeElement, 'active');\n              } else {\n                this.renderer.removeClass(this.elementRef.nativeElement, 'active');\n              }\n            }),\n          )\n          .subscribe(),\n    );\n  }\n\n  public ngOnDestroy() {\n    this._subscription?.unsubscribe();\n  }\n\n  // region type save item property\n\n  // required to check the type of the item property in the ngFor loop\n\n  public isNavigationDividerItem(\n    item: NavigationItem | NavigationDividerItem,\n  ): item is NavigationDividerItem {\n    return (item as any)['divider'];\n  }\n\n  public isNavigationItem(\n    item: NavigationItem | NavigationDividerItem,\n  ): item is NavigationItem {\n    return !this.isNavigationDividerItem(item);\n  }\n\n  public asNavigationItem(\n    item: NavigationItem | NavigationDividerItem,\n  ): NavigationItem {\n    if (!this.isNavigationItem(item)) {\n      throw new Error('The item is not a NavigationItem');\n    }\n    return item;\n  }\n\n  // endregion\n}\n","<div [ngClass]=\"{\n     'border-l-4 text-accent-400 border-accent-600': active(),\n     }\">\n  <a [routerLink]=\"item.routerLink\"\n     class=\"h-12 px-4 flex flex-row justify-between items-center gap-x-4\"\n     matRipple\n     routerLinkActive\n\n  >\n    <span\n      [ngClass]=\"{\n        'pl-0': level === 0,\n        'pl-4': level === 1,\n        'pl-8': level === 2,\n        'pl-12': level === 3\n      }\"\n      class=\"grow whitespace-nowrap\"\n    >\n      {{ item.label }}\n    </span>\n    <mat-icon *ngIf=\"item.icon\" [rxapIcon]=\"item.icon\"></mat-icon>\n  </a>\n\n  <ng-container *ngIf=\"item.children?.length && active()\">\n\n    <mat-divider></mat-divider>\n\n    <ul [@sub-nav]\n        [items]=\"children ?? []\"\n        [level]=\"level + 1\"\n        rxap-navigation\n    >\n    </ul>\n\n    <mat-divider></mat-divider>\n\n  </ng-container>\n</div>\n"]}
|