@rxap/layout 16.0.0-dev.27 → 16.0.0-dev.29
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/README.md +1 -1
- package/esm2022/lib/header/header.component.mjs +19 -15
- package/esm2022/lib/header/sidenav-toggle-button/sidenav-toggle-button.component.mjs +16 -13
- package/esm2022/lib/layout/layout.component.mjs +17 -16
- package/esm2022/lib/layout/layout.component.service.mjs +46 -11
- package/fesm2022/rxap-layout.mjs +163 -127
- package/fesm2022/rxap-layout.mjs.map +1 -1
- package/lib/header/header.component.d.ts +8 -6
- package/lib/header/sidenav-toggle-button/sidenav-toggle-button.component.d.ts +6 -3
- package/lib/layout/layout.component.d.ts +10 -3
- package/lib/layout/layout.component.service.d.ts +7 -2
- package/package.json +21 -9
- package/theme.css +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,20 @@
|
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
5
|
|
|
6
|
+
# [16.0.0-dev.29](https://gitlab.com/rxap/packages/compare/@rxap/layout@16.0.0-dev.28...@rxap/layout@16.0.0-dev.29) (2023-09-21)
|
|
7
|
+
|
|
8
|
+
### Bug Fixes
|
|
9
|
+
|
|
10
|
+
- close sidenav if change to collapsed mode ([7a35660](https://gitlab.com/rxap/packages/commit/7a356602e2228360f85bae8cb9346e3228e0fe29))
|
|
11
|
+
- only add margin to sidenav content if in collapsed mode ([c72febe](https://gitlab.com/rxap/packages/commit/c72febe141f8c11f126f99b3ef23b753599a5a47))
|
|
12
|
+
|
|
13
|
+
# [16.0.0-dev.28](https://gitlab.com/rxap/packages/compare/@rxap/layout@16.0.0-dev.27...@rxap/layout@16.0.0-dev.28) (2023-09-21)
|
|
14
|
+
|
|
15
|
+
### Bug Fixes
|
|
16
|
+
|
|
17
|
+
- move status infiltrator to layout component ([1d1f69b](https://gitlab.com/rxap/packages/commit/1d1f69b22ae171a9d69b7d6d9e3f4e9f2e0849ee))
|
|
18
|
+
- support advanced settings for layout sidenav ([65ff765](https://gitlab.com/rxap/packages/commit/65ff765b66f799de5089c954d34532bc9b4a7e77))
|
|
19
|
+
|
|
6
20
|
# [16.0.0-dev.27](https://gitlab.com/rxap/packages/compare/@rxap/layout@16.0.0-dev.26...@rxap/layout@16.0.0-dev.27) (2023-09-19)
|
|
7
21
|
|
|
8
22
|
### Bug Fixes
|
package/README.md
CHANGED
|
@@ -17,5 +17,5 @@ yarn add @rxap/layout
|
|
|
17
17
|
```
|
|
18
18
|
**Install peer dependencies:**
|
|
19
19
|
```bash
|
|
20
|
-
yarn add @angular/animations@^16.1.4 @angular/cdk@^16.1.4 @angular/common@^16.1.4 @angular/core@^16.1.4 @angular/flex-layout@^15.0.0-beta.42 @angular/forms@^16.1.4 @angular/material@^16.1.4 @angular/router@^16.1.4 @rxap/authentication@^16.0.0-dev.
|
|
20
|
+
yarn add @angular/animations@^16.1.4 @angular/cdk@^16.1.4 @angular/common@^16.1.4 @angular/core@^16.1.4 @angular/flex-layout@^15.0.0-beta.42 @angular/forms@^16.1.4 @angular/material@^16.1.4 @angular/router@^16.1.4 @rxap/authentication@^16.0.0-dev.15 @rxap/authorization@^16.0.0-dev.20 @rxap/browser-utilities@^0.0.2-dev.8 @rxap/config@^16.0.0-dev.16 @rxap/data-source@^16.0.0-dev.18 @rxap/directives@^16.0.0-dev.15 @rxap/environment@^16.0.0-dev.15 @rxap/icon@^16.0.0-dev.15 @rxap/material-directives@^16.0.0-dev.17 @rxap/ngx-changelog@^16.1.0-dev.1 @rxap/ngx-localize@^16.1.0-dev.0 @rxap/ngx-status-check@^16.1.0-dev.10 @rxap/ngx-user@^16.1.0-dev.1 @rxap/services@^16.0.0-dev.15 @rxap/utilities@^16.0.0-dev.18 rxjs@^7.8.0 tslib@2.6.2
|
|
21
21
|
```
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { AsyncPipe, NgClass, NgIf, } from '@angular/common';
|
|
2
2
|
import { ChangeDetectionStrategy, Component, Inject, Input, Optional, } from '@angular/core';
|
|
3
|
+
import { toSignal } from '@angular/core/rxjs-interop';
|
|
3
4
|
import { FormsModule } from '@angular/forms';
|
|
4
5
|
import { MatButtonModule } from '@angular/material/button';
|
|
5
6
|
import { MatOptionModule, } from '@angular/material/core';
|
|
@@ -7,30 +8,35 @@ import { MatFormFieldModule } from '@angular/material/form-field';
|
|
|
7
8
|
import { MatIconModule } from '@angular/material/icon';
|
|
8
9
|
import { MatMenuModule } from '@angular/material/menu';
|
|
9
10
|
import { MatSelectModule } from '@angular/material/select';
|
|
10
|
-
import { MatSidenav } from '@angular/material/sidenav';
|
|
11
11
|
import { MatSlideToggleModule } from '@angular/material/slide-toggle';
|
|
12
12
|
import { MatToolbarModule } from '@angular/material/toolbar';
|
|
13
13
|
import { DataSourceCollectionDirective } from '@rxap/data-source/directive';
|
|
14
14
|
import { StopPropagationDirective } from '@rxap/directives';
|
|
15
|
-
import { StatusIndicatorComponent } from '@rxap/ngx-status-check';
|
|
16
15
|
import { HeaderService } from '@rxap/services';
|
|
17
16
|
import { Subscription } from 'rxjs';
|
|
18
17
|
import { tap } from 'rxjs/operators';
|
|
18
|
+
import { LayoutComponentService } from '../layout/layout.component.service';
|
|
19
19
|
import { RXAP_HEADER_COMPONENT } from '../tokens';
|
|
20
20
|
import { AppsButtonComponent } from './apps-button/apps-button.component';
|
|
21
21
|
import { NavigationProgressBarComponent } from './navigation-progress-bar/navigation-progress-bar.component';
|
|
22
22
|
import { SettingsButtonComponent } from './settings-button/settings-button.component';
|
|
23
|
+
import { SidenavToggleButtonComponent } from './sidenav-toggle-button/sidenav-toggle-button.component';
|
|
23
24
|
import { UserProfileIconComponent } from './user-profile-icon/user-profile-icon.component';
|
|
24
25
|
import * as i0 from "@angular/core";
|
|
25
|
-
import * as i1 from "
|
|
26
|
-
import * as i2 from "@
|
|
26
|
+
import * as i1 from "../layout/layout.component.service";
|
|
27
|
+
import * as i2 from "@angular/material/toolbar";
|
|
28
|
+
import * as i3 from "@rxap/services";
|
|
27
29
|
export class HeaderComponent {
|
|
28
|
-
constructor(headerComponentService, headerComponent) {
|
|
30
|
+
constructor(headerComponentService, layoutComponentService, headerComponent) {
|
|
29
31
|
this.headerComponentService = headerComponentService;
|
|
32
|
+
this.layoutComponentService = layoutComponentService;
|
|
30
33
|
this.headerComponent = headerComponent;
|
|
31
34
|
this.components = [];
|
|
32
35
|
this.subscriptions = new Subscription();
|
|
33
36
|
this.color = undefined;
|
|
37
|
+
this.collapsable =
|
|
38
|
+
toSignal(layoutComponentService.collapsable$, { initialValue: layoutComponentService.collapsable$.value });
|
|
39
|
+
this.opened = toSignal(layoutComponentService.opened$, { initialValue: layoutComponentService.opened$.value });
|
|
34
40
|
}
|
|
35
41
|
ngOnInit() {
|
|
36
42
|
this.updateComponents();
|
|
@@ -44,8 +50,8 @@ export class HeaderComponent {
|
|
|
44
50
|
ngOnDestroy() {
|
|
45
51
|
this.subscriptions.unsubscribe();
|
|
46
52
|
}
|
|
47
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: HeaderComponent, deps: [{ token: HeaderService }, { token: RXAP_HEADER_COMPONENT, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
48
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.4", type: HeaderComponent, isStandalone: true, selector: "rxap-header", inputs: {
|
|
53
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: HeaderComponent, deps: [{ token: HeaderService }, { token: i1.LayoutComponentService }, { token: RXAP_HEADER_COMPONENT, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
54
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.4", type: HeaderComponent, isStandalone: true, selector: "rxap-header", inputs: { color: "color" }, ngImport: i0, template: "<mat-toolbar [color]=\"color\" [ngClass]=\"{ open: opened() }\" class=\"mat-elevation-z3 header\">\n <div class=\"w-full flex flex-row gap-x-4 justify-between items-center\">\n <rxap-sidenav-toggle-button *ngIf=\"!collapsable()\"></rxap-sidenav-toggle-button>\n <div class=\"grow\">\n <ng-content></ng-content>\n </div>\n <rxap-apps-button class=\"grow-0\"></rxap-apps-button>\n <rxap-settings-button class=\"grow-0\"></rxap-settings-button>\n <rxap-user-profile-icon class=\"grow-0\"></rxap-user-profile-icon>\n </div>\n</mat-toolbar>\n\n<rxap-navigation-progress-bar></rxap-navigation-progress-bar>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: MatToolbarModule }, { kind: "component", type: i2.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "ngmodule", type: MatMenuModule }, { kind: "ngmodule", type: MatIconModule }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: MatSelectModule }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: MatOptionModule }, { kind: "ngmodule", type: MatSlideToggleModule }, { kind: "component", type: NavigationProgressBarComponent, selector: "rxap-navigation-progress-bar" }, { kind: "component", type: UserProfileIconComponent, selector: "rxap-user-profile-icon" }, { kind: "component", type: AppsButtonComponent, selector: "rxap-apps-button" }, { kind: "component", type: SettingsButtonComponent, selector: "rxap-settings-button" }, { kind: "component", type: SidenavToggleButtonComponent, selector: "rxap-sidenav-toggle-button" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
49
55
|
}
|
|
50
56
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: HeaderComponent, decorators: [{
|
|
51
57
|
type: Component,
|
|
@@ -68,19 +74,17 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.4", ngImpor
|
|
|
68
74
|
UserProfileIconComponent,
|
|
69
75
|
AppsButtonComponent,
|
|
70
76
|
SettingsButtonComponent,
|
|
71
|
-
|
|
72
|
-
], template: "<mat-toolbar [color]=\"color\" [ngClass]=\"{ open:
|
|
73
|
-
}], ctorParameters: function () { return [{ type:
|
|
77
|
+
SidenavToggleButtonComponent,
|
|
78
|
+
], template: "<mat-toolbar [color]=\"color\" [ngClass]=\"{ open: opened() }\" class=\"mat-elevation-z3 header\">\n <div class=\"w-full flex flex-row gap-x-4 justify-between items-center\">\n <rxap-sidenav-toggle-button *ngIf=\"!collapsable()\"></rxap-sidenav-toggle-button>\n <div class=\"grow\">\n <ng-content></ng-content>\n </div>\n <rxap-apps-button class=\"grow-0\"></rxap-apps-button>\n <rxap-settings-button class=\"grow-0\"></rxap-settings-button>\n <rxap-user-profile-icon class=\"grow-0\"></rxap-user-profile-icon>\n </div>\n</mat-toolbar>\n\n<rxap-navigation-progress-bar></rxap-navigation-progress-bar>\n" }]
|
|
79
|
+
}], ctorParameters: function () { return [{ type: i3.HeaderService, decorators: [{
|
|
74
80
|
type: Inject,
|
|
75
81
|
args: [HeaderService]
|
|
76
|
-
}] }, { type: undefined, decorators: [{
|
|
82
|
+
}] }, { type: i1.LayoutComponentService }, { type: undefined, decorators: [{
|
|
77
83
|
type: Optional
|
|
78
84
|
}, {
|
|
79
85
|
type: Inject,
|
|
80
86
|
args: [RXAP_HEADER_COMPONENT]
|
|
81
|
-
}] }]; }, propDecorators: {
|
|
82
|
-
type: Input
|
|
83
|
-
}], color: [{
|
|
87
|
+
}] }]; }, propDecorators: { color: [{
|
|
84
88
|
type: Input
|
|
85
89
|
}] } });
|
|
86
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
90
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"header.component.js","sourceRoot":"","sources":["../../../../../../../packages/angular/layout/src/lib/header/header.component.ts","../../../../../../../packages/angular/layout/src/lib/header/header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AsyncPipe,\n  NgClass,\n  NgIf,\n} from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Signal,\n} from '@angular/core';\nimport { toSignal } from '@angular/core/rxjs-interop';\nimport { FormsModule } from '@angular/forms';\nimport { MatButtonModule } from '@angular/material/button';\nimport {\n  MatOptionModule,\n  ThemePalette,\n} from '@angular/material/core';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatMenuModule } from '@angular/material/menu';\nimport { MatSelectModule } from '@angular/material/select';\nimport { MatSlideToggleModule } from '@angular/material/slide-toggle';\nimport { MatToolbarModule } from '@angular/material/toolbar';\nimport { DataSourceCollectionDirective } from '@rxap/data-source/directive';\nimport { StopPropagationDirective } from '@rxap/directives';\nimport { HeaderService } from '@rxap/services';\nimport { Constructor } from '@rxap/utilities';\nimport { Subscription } from 'rxjs';\nimport { tap } from 'rxjs/operators';\nimport { LayoutComponentService } from '../layout/layout.component.service';\nimport { RXAP_HEADER_COMPONENT } from '../tokens';\nimport { AppsButtonComponent } from './apps-button/apps-button.component';\nimport { NavigationProgressBarComponent } from './navigation-progress-bar/navigation-progress-bar.component';\nimport { SettingsButtonComponent } from './settings-button/settings-button.component';\nimport { SidenavToggleButtonComponent } from './sidenav-toggle-button/sidenav-toggle-button.component';\nimport { UserProfileIconComponent } from './user-profile-icon/user-profile-icon.component';\n\n@Component({\n  selector: 'rxap-header',\n  templateUrl: './header.component.html',\n  styleUrls: [ './header.component.scss' ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    MatToolbarModule,\n    NgClass,\n    NgIf,\n    MatButtonModule,\n    MatMenuModule,\n    MatIconModule,\n    MatFormFieldModule,\n    StopPropagationDirective,\n    MatSelectModule,\n    FormsModule,\n    MatOptionModule,\n    DataSourceCollectionDirective,\n    MatSlideToggleModule,\n    AsyncPipe,\n    NavigationProgressBarComponent,\n    UserProfileIconComponent,\n    AppsButtonComponent,\n    SettingsButtonComponent,\n    SidenavToggleButtonComponent,\n  ],\n})\nexport class HeaderComponent implements OnInit, OnDestroy {\n\n  public components: Array<Constructor<any>> = [];\n\n  public subscriptions = new Subscription();\n\n  @Input()\n  public color: ThemePalette = undefined;\n\n  public readonly collapsable: Signal<boolean>;\n  public readonly opened: Signal<boolean>;\n\n  constructor(\n    @Inject(HeaderService)\n    public readonly headerComponentService: HeaderService,\n    public readonly layoutComponentService: LayoutComponentService,\n    @Optional() @Inject(RXAP_HEADER_COMPONENT) public headerComponent: any,\n  ) {\n    this.collapsable =\n      toSignal(layoutComponentService.collapsable$, { initialValue: layoutComponentService.collapsable$.value });\n    this.opened = toSignal(layoutComponentService.opened$, { initialValue: layoutComponentService.opened$.value });\n  }\n\n  public ngOnInit() {\n    this.updateComponents();\n    this.subscriptions.add(\n      this.headerComponentService.update$\n          .pipe(tap(() => this.updateComponents()))\n          .subscribe(),\n    );\n  }\n\n  public updateComponents(): void {\n    this.components = this.headerComponentService.getComponents();\n  }\n\n  public ngOnDestroy(): void {\n    this.subscriptions.unsubscribe();\n  }\n\n}\n","<mat-toolbar [color]=\"color\" [ngClass]=\"{ open: opened() }\" class=\"mat-elevation-z3 header\">\n  <div class=\"w-full flex flex-row gap-x-4 justify-between items-center\">\n    <rxap-sidenav-toggle-button *ngIf=\"!collapsable()\"></rxap-sidenav-toggle-button>\n    <div class=\"grow\">\n      <ng-content></ng-content>\n    </div>\n    <rxap-apps-button class=\"grow-0\"></rxap-apps-button>\n    <rxap-settings-button class=\"grow-0\"></rxap-settings-button>\n    <rxap-user-profile-icon class=\"grow-0\"></rxap-user-profile-icon>\n  </div>\n</mat-toolbar>\n\n<rxap-navigation-progress-bar></rxap-navigation-progress-bar>\n"]}
|
|
@@ -1,14 +1,20 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, Input, } from '@angular/core';
|
|
2
|
-
import { MatSidenav } from '@angular/material/sidenav';
|
|
3
|
-
import { MatIconModule } from '@angular/material/icon';
|
|
4
1
|
import { NgIf } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, } from '@angular/core';
|
|
3
|
+
import { toSignal } from '@angular/core/rxjs-interop';
|
|
5
4
|
import { MatButtonModule } from '@angular/material/button';
|
|
5
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
6
|
+
import { LayoutComponentService } from '../../layout/layout.component.service';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
|
-
import * as i1 from "
|
|
8
|
-
import * as i2 from "@angular/material/
|
|
8
|
+
import * as i1 from "../../layout/layout.component.service";
|
|
9
|
+
import * as i2 from "@angular/material/button";
|
|
10
|
+
import * as i3 from "@angular/material/icon";
|
|
9
11
|
export class SidenavToggleButtonComponent {
|
|
10
|
-
|
|
11
|
-
|
|
12
|
+
constructor(layoutComponentService) {
|
|
13
|
+
this.layoutComponentService = layoutComponentService;
|
|
14
|
+
this.opened = toSignal(layoutComponentService.opened$, { initialValue: layoutComponentService.opened$.value });
|
|
15
|
+
}
|
|
16
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: SidenavToggleButtonComponent, deps: [{ token: i1.LayoutComponentService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
17
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.4", type: SidenavToggleButtonComponent, isStandalone: true, selector: "rxap-sidenav-toggle-button", ngImport: i0, template: "<button (click)=\"layoutComponentService.toggleOpend()\" mat-icon-button>\n <mat-icon *ngIf=\"!opened()\">menu</mat-icon>\n <mat-icon *ngIf=\"opened()\">menu_open</mat-icon>\n</button>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i2.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
12
18
|
}
|
|
13
19
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: SidenavToggleButtonComponent, decorators: [{
|
|
14
20
|
type: Component,
|
|
@@ -16,9 +22,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.4", ngImpor
|
|
|
16
22
|
MatButtonModule,
|
|
17
23
|
NgIf,
|
|
18
24
|
MatIconModule,
|
|
19
|
-
], template: "<button (click)=\"
|
|
20
|
-
}],
|
|
21
|
-
|
|
22
|
-
args: [{ required: true }]
|
|
23
|
-
}] } });
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZW5hdi10b2dnbGUtYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FuZ3VsYXIvbGF5b3V0L3NyYy9saWIvaGVhZGVyL3NpZGVuYXYtdG9nZ2xlLWJ1dHRvbi9zaWRlbmF2LXRvZ2dsZS1idXR0b24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5ndWxhci9sYXlvdXQvc3JjL2xpYi9oZWFkZXIvc2lkZW5hdi10b2dnbGUtYnV0dG9uL3NpZGVuYXYtdG9nZ2xlLWJ1dHRvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxLQUFLLEdBQ04sTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBRXZELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDdkMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDOzs7O0FBYzNELE1BQU0sT0FBTyw0QkFBNEI7OEdBQTVCLDRCQUE0QjtrR0FBNUIsNEJBQTRCLHNIQ3ZCekMsc0xBSUEseUREY0ksZUFBZSw0TEFDZixJQUFJLDRGQUNKLGFBQWE7OzJGQUdKLDRCQUE0QjtrQkFaeEMsU0FBUzsrQkFDRSw0QkFBNEIsbUJBR3JCLHVCQUF1QixDQUFDLE1BQU0sY0FDbkMsSUFBSSxXQUNQO3dCQUNQLGVBQWU7d0JBQ2YsSUFBSTt3QkFDSixhQUFhO3FCQUNkOzhCQUtNLE9BQU87c0JBRGIsS0FBSzt1QkFBQyxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBJbnB1dCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNYXRTaWRlbmF2IH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc2lkZW5hdic7XG5pbXBvcnQgeyBSZXF1aXJlZCB9IGZyb20gJ0ByeGFwL3V0aWxpdGllcyc7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQgeyBOZ0lmIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3J4YXAtc2lkZW5hdi10b2dnbGUtYnV0dG9uJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3NpZGVuYXYtdG9nZ2xlLWJ1dHRvbi5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWyAnLi9zaWRlbmF2LXRvZ2dsZS1idXR0b24uY29tcG9uZW50LnNjc3MnIF0sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbXG4gICAgTWF0QnV0dG9uTW9kdWxlLFxuICAgIE5nSWYsXG4gICAgTWF0SWNvbk1vZHVsZSxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgU2lkZW5hdlRvZ2dsZUJ1dHRvbkNvbXBvbmVudCB7XG5cbiAgQElucHV0KHsgcmVxdWlyZWQ6IHRydWUgfSlcbiAgcHVibGljIHNpZGVuYXYhOiBNYXRTaWRlbmF2O1xuXG59XG4iLCI8YnV0dG9uIChjbGljayk9XCJzaWRlbmF2LnRvZ2dsZSgpXCIgbWF0LWljb24tYnV0dG9uPlxuICA8bWF0LWljb24gKm5nSWY9XCIhc2lkZW5hdi5vcGVuZWRcIj5tZW51PC9tYXQtaWNvbj5cbiAgPG1hdC1pY29uICpuZ0lmPVwic2lkZW5hdi5vcGVuZWRcIj5tZW51X29wZW48L21hdC1pY29uPlxuPC9idXR0b24+XG4iXX0=
|
|
25
|
+
], template: "<button (click)=\"layoutComponentService.toggleOpend()\" mat-icon-button>\n <mat-icon *ngIf=\"!opened()\">menu</mat-icon>\n <mat-icon *ngIf=\"opened()\">menu_open</mat-icon>\n</button>\n" }]
|
|
26
|
+
}], ctorParameters: function () { return [{ type: i1.LayoutComponentService }]; } });
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZW5hdi10b2dnbGUtYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FuZ3VsYXIvbGF5b3V0L3NyYy9saWIvaGVhZGVyL3NpZGVuYXYtdG9nZ2xlLWJ1dHRvbi9zaWRlbmF2LXRvZ2dsZS1idXR0b24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5ndWxhci9sYXlvdXQvc3JjL2xpYi9oZWFkZXIvc2lkZW5hdi10b2dnbGUtYnV0dG9uL3NpZGVuYXYtdG9nZ2xlLWJ1dHRvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDdkMsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEdBRVYsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ3RELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7Ozs7O0FBYy9FLE1BQU0sT0FBTyw0QkFBNEI7SUFJdkMsWUFBNEIsc0JBQThDO1FBQTlDLDJCQUFzQixHQUF0QixzQkFBc0IsQ0FBd0I7UUFDeEUsSUFBSSxDQUFDLE1BQU0sR0FBRyxRQUFRLENBQUMsc0JBQXNCLENBQUMsT0FBTyxFQUFFLEVBQUUsWUFBWSxFQUFFLHNCQUFzQixDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDO0lBQ2pILENBQUM7OEdBTlUsNEJBQTRCO2tHQUE1Qiw0QkFBNEIsc0ZDdkJ6Qyw4TEFJQSx5RERjSSxlQUFlLDRMQUNmLElBQUksNEZBQ0osYUFBYTs7MkZBR0osNEJBQTRCO2tCQVp4QyxTQUFTOytCQUNFLDRCQUE0QixtQkFHckIsdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxJQUFJLFdBQ1A7d0JBQ1AsZUFBZTt3QkFDZixJQUFJO3dCQUNKLGFBQWE7cUJBQ2QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ0lmIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIFNpZ25hbCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyB0b1NpZ25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUvcnhqcy1pbnRlcm9wJztcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQgeyBMYXlvdXRDb21wb25lbnRTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vbGF5b3V0L2xheW91dC5jb21wb25lbnQuc2VydmljZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3J4YXAtc2lkZW5hdi10b2dnbGUtYnV0dG9uJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3NpZGVuYXYtdG9nZ2xlLWJ1dHRvbi5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWyAnLi9zaWRlbmF2LXRvZ2dsZS1idXR0b24uY29tcG9uZW50LnNjc3MnIF0sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbXG4gICAgTWF0QnV0dG9uTW9kdWxlLFxuICAgIE5nSWYsXG4gICAgTWF0SWNvbk1vZHVsZSxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgU2lkZW5hdlRvZ2dsZUJ1dHRvbkNvbXBvbmVudCB7XG5cbiAgcHVibGljIHJlYWRvbmx5IG9wZW5lZDogU2lnbmFsPGJvb2xlYW4+O1xuXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyByZWFkb25seSBsYXlvdXRDb21wb25lbnRTZXJ2aWNlOiBMYXlvdXRDb21wb25lbnRTZXJ2aWNlKSB7XG4gICAgdGhpcy5vcGVuZWQgPSB0b1NpZ25hbChsYXlvdXRDb21wb25lbnRTZXJ2aWNlLm9wZW5lZCQsIHsgaW5pdGlhbFZhbHVlOiBsYXlvdXRDb21wb25lbnRTZXJ2aWNlLm9wZW5lZCQudmFsdWUgfSk7XG4gIH1cblxufVxuIiwiPGJ1dHRvbiAoY2xpY2spPVwibGF5b3V0Q29tcG9uZW50U2VydmljZS50b2dnbGVPcGVuZCgpXCIgbWF0LWljb24tYnV0dG9uPlxuICA8bWF0LWljb24gKm5nSWY9XCIhb3BlbmVkKClcIj5tZW51PC9tYXQtaWNvbj5cbiAgPG1hdC1pY29uICpuZ0lmPVwib3BlbmVkKClcIj5tZW51X29wZW48L21hdC1pY29uPlxuPC9idXR0b24+XG4iXX0=
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { AsyncPipe, NgIf, NgOptimizedImage, } from '@angular/common';
|
|
2
2
|
import { ChangeDetectionStrategy, Component, Inject, ViewChild, } from '@angular/core';
|
|
3
|
+
import { toSignal } from '@angular/core/rxjs-interop';
|
|
3
4
|
import { FlexLayoutModule } from '@angular/flex-layout';
|
|
4
5
|
import { MatButtonModule } from '@angular/material/button';
|
|
5
6
|
import { MatIconModule } from '@angular/material/icon';
|
|
@@ -8,6 +9,7 @@ import { MatSidenav, MatSidenavModule, } from '@angular/material/sidenav';
|
|
|
8
9
|
import { RouterLink, RouterOutlet, } from '@angular/router';
|
|
9
10
|
import { DetermineReleaseName, RXAP_ENVIRONMENT, } from '@rxap/environment';
|
|
10
11
|
import { IconLoaderService } from '@rxap/icon';
|
|
12
|
+
import { StatusIndicatorComponent } from '@rxap/ngx-status-check';
|
|
11
13
|
import { FooterComponent } from '../footer/footer.component';
|
|
12
14
|
import { HeaderComponent } from '../header/header.component';
|
|
13
15
|
import { NavigationComponent } from '../navigation/navigation.component';
|
|
@@ -23,23 +25,21 @@ export class LayoutComponent {
|
|
|
23
25
|
constructor(layoutComponentService, environment, iconLoaderService) {
|
|
24
26
|
this.layoutComponentService = layoutComponentService;
|
|
25
27
|
this.environment = environment;
|
|
26
|
-
this.sidenavMode = 'over';
|
|
27
28
|
iconLoaderService.load();
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
}
|
|
29
|
+
this.fixedBottomGap = toSignal(layoutComponentService.fixedBottomGap$, { initialValue: 0 });
|
|
30
|
+
this.fixedTopGap =
|
|
31
|
+
toSignal(layoutComponentService.fixedTopGap$, { initialValue: layoutComponentService.fixedTopGap$.value });
|
|
32
|
+
this.sidenavMode = toSignal(layoutComponentService.mode$, { initialValue: layoutComponentService.mode$.value });
|
|
33
|
+
this.pinned = toSignal(layoutComponentService.pinned$, { initialValue: layoutComponentService.pinned$.value });
|
|
34
|
+
this.collapsable =
|
|
35
|
+
toSignal(layoutComponentService.collapsable$, { initialValue: layoutComponentService.collapsable$.value });
|
|
36
|
+
this.opened = toSignal(layoutComponentService.opened$, { initialValue: layoutComponentService.opened$.value });
|
|
37
|
+
this.logoSrc = this.layoutComponentService.logo.src ?? 'https://via.placeholder.com/256x128px';
|
|
38
|
+
this.logoWidth = this.layoutComponentService.logo.width ?? 256;
|
|
39
|
+
this.release = DetermineReleaseName(this.environment);
|
|
40
40
|
}
|
|
41
41
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: LayoutComponent, deps: [{ token: i1.LayoutComponentService }, { token: RXAP_ENVIRONMENT }, { token: i2.IconLoaderService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
42
|
-
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
|
|
42
|
+
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: "<rxap-status-indicator class=\"fixed bottom-0 right-0 z-10\"></rxap-status-indicator>\n<div class=\"flex flex-col h-screen justify-between\">\n <rxap-header class=\"z-10 w-full fixed top-0\"></rxap-header>\n <mat-sidenav-container [ngClass]=\"{\n 'mb-16': fixedBottomGap() === 64,\n 'mb-32': fixedBottomGap() === 128,\n }\" class=\"grow mt-16\">\n <mat-sidenav\n #matSidenav=\"matSidenav\"\n [fixedBottomGap]=\"fixedBottomGap()\"\n [fixedInViewport]=\"true\"\n [fixedTopGap]=\"fixedTopGap()\"\n [mode]=\"sidenavMode()\"\n [ngClass]=\"{ collapsable: collapsable() }\"\n class=\"sidenav\"\n [opened]=\"opened()\"\n >\n <div class=\"h-full py-2 flex flex-col items-center gap-y-5 justify-items-stretch\">\n\n <div (click)=\"layoutComponentService.togglePinned()\" *ngIf=\"collapsable()\"\n class=\"pl-2 pr-2 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=\"!pinned()\">radio_button_unchecked</mat-icon>\n <mat-icon *ngIf=\"pinned()\">radio_button_checked</mat-icon>\n </button>\n </div>\n\n <ul\n (mouseenter)=\"collapsable() && !pinned() && matSidenav.open()\"\n (mouseleave)=\"collapsable() && !pinned() && matSidenav.close()\" class=\"grow self-stretch\"\n root\n rxap-navigation\n >\n </ul>\n\n <img\n [src]=\"logoSrc\"\n [routerLink]=\"['/']\"\n [width]=\"logoWidth\"\n alt=\"logo\"\n class=\"grow-0 mx-16\"\n />\n <div class=\"grow-0 px-16\">\n <span>{{release}}</span>\n </div>\n </div>\n </mat-sidenav>\n <mat-sidenav-content [ngClass]=\"{ 'ml-16': collapsable() }\" class=\"p-4\">\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: [":host .sidenav.collapsable:not(.mat-drawer-opened){transform:translate(calc(-100% + 64px))!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)}:host .sidenav.collapsable ::ng-deep .mat-drawer-inner-container::-webkit-scrollbar{display:none}\n"], dependencies: [{ kind: "component", type: HeaderComponent, selector: "rxap-header", inputs: ["color"] }, { kind: "ngmodule", type: MatSidenavModule }, { kind: "component", type: i3.MatSidenav, selector: "mat-sidenav", inputs: ["fixedInViewport", "fixedTopGap", "fixedBottomGap"], exportAs: ["matSidenav"] }, { kind: "component", type: i3.MatSidenavContainer, selector: "mat-sidenav-container", exportAs: ["matSidenavContainer"] }, { kind: "component", type: i3.MatSidenavContent, selector: "mat-sidenav-content" }, { kind: "ngmodule", type: FlexLayoutModule }, { kind: "directive", type: i4.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: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i6.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: "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"] }, { kind: "component", type: StatusIndicatorComponent, selector: "rxap-status-indicator" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
43
43
|
}
|
|
44
44
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: LayoutComponent, decorators: [{
|
|
45
45
|
type: Component,
|
|
@@ -57,7 +57,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.4", ngImpor
|
|
|
57
57
|
NgOptimizedImage,
|
|
58
58
|
NavigationComponent,
|
|
59
59
|
RouterOutlet,
|
|
60
|
-
|
|
60
|
+
StatusIndicatorComponent,
|
|
61
|
+
], template: "<rxap-status-indicator class=\"fixed bottom-0 right-0 z-10\"></rxap-status-indicator>\n<div class=\"flex flex-col h-screen justify-between\">\n <rxap-header class=\"z-10 w-full fixed top-0\"></rxap-header>\n <mat-sidenav-container [ngClass]=\"{\n 'mb-16': fixedBottomGap() === 64,\n 'mb-32': fixedBottomGap() === 128,\n }\" class=\"grow mt-16\">\n <mat-sidenav\n #matSidenav=\"matSidenav\"\n [fixedBottomGap]=\"fixedBottomGap()\"\n [fixedInViewport]=\"true\"\n [fixedTopGap]=\"fixedTopGap()\"\n [mode]=\"sidenavMode()\"\n [ngClass]=\"{ collapsable: collapsable() }\"\n class=\"sidenav\"\n [opened]=\"opened()\"\n >\n <div class=\"h-full py-2 flex flex-col items-center gap-y-5 justify-items-stretch\">\n\n <div (click)=\"layoutComponentService.togglePinned()\" *ngIf=\"collapsable()\"\n class=\"pl-2 pr-2 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=\"!pinned()\">radio_button_unchecked</mat-icon>\n <mat-icon *ngIf=\"pinned()\">radio_button_checked</mat-icon>\n </button>\n </div>\n\n <ul\n (mouseenter)=\"collapsable() && !pinned() && matSidenav.open()\"\n (mouseleave)=\"collapsable() && !pinned() && matSidenav.close()\" class=\"grow self-stretch\"\n root\n rxap-navigation\n >\n </ul>\n\n <img\n [src]=\"logoSrc\"\n [routerLink]=\"['/']\"\n [width]=\"logoWidth\"\n alt=\"logo\"\n class=\"grow-0 mx-16\"\n />\n <div class=\"grow-0 px-16\">\n <span>{{release}}</span>\n </div>\n </div>\n </mat-sidenav>\n <mat-sidenav-content [ngClass]=\"{ 'ml-16': collapsable() }\" class=\"p-4\">\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: [":host .sidenav.collapsable:not(.mat-drawer-opened){transform:translate(calc(-100% + 64px))!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)}:host .sidenav.collapsable ::ng-deep .mat-drawer-inner-container::-webkit-scrollbar{display:none}\n"] }]
|
|
61
62
|
}], ctorParameters: function () { return [{ type: i1.LayoutComponentService }, { type: undefined, decorators: [{
|
|
62
63
|
type: Inject,
|
|
63
64
|
args: [RXAP_ENVIRONMENT]
|
|
@@ -65,4 +66,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.4", ngImpor
|
|
|
65
66
|
type: ViewChild,
|
|
66
67
|
args: [MatSidenav, { static: true }]
|
|
67
68
|
}] } });
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"layout.component.js","sourceRoot":"","sources":["../../../../../../../packages/angular/layout/src/lib/layout/layout.component.ts","../../../../../../../packages/angular/layout/src/lib/layout/layout.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,IAAI,EACJ,gBAAgB,GACjB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AACxD,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAEL,UAAU,EACV,gBAAgB,GACjB,MAAM,2BAA2B,CAAC;AACnC,OAAO,EACL,UAAU,EACV,YAAY,GACb,MAAM,iBAAiB,CAAC;AACzB,OAAO,EACL,oBAAoB,EAEpB,gBAAgB,GACjB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAC/C,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,mBAAmB,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAC;;;;;;;;AAyBpE,MAAM,OAAO,eAAe;IAM1B,YACkB,sBAA8C,EAE7C,WAAwB,EACzC,iBAAoC;QAHpB,2BAAsB,GAAtB,sBAAsB,CAAwB;QAE7C,gBAAW,GAAX,WAAW,CAAa;QAPpC,gBAAW,GAAkB,MAAM,CAAC;QAUzC,iBAAiB,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAED,IAAW,OAAO;QAChB,OAAO,oBAAoB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IAChD,CAAC;IAEM,iBAAiB;QACtB,IAAI,IAAI,CAAC,WAAW,KAAK,MAAM,EAAE;YAC/B,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC;YAC1B,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;SACrB;aAAM;YACL,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC;SAC3B;IACH,CAAC;8GA1BU,eAAe,wDAQhB,gBAAgB;kGARf,eAAe,gHAIf,UAAU,8DC9DvB,6kEAiDA,4YDNI,eAAe,qFACf,gBAAgB,sYAChB,SAAS,6CACT,gBAAgB,iiBAChB,aAAa,mLACb,eAAe,4LACf,UAAU,4NACV,IAAI,6FACJ,eAAe,uDACf,aAAa,+BAEb,mBAAmB,oGACnB,YAAY;;2FAGH,eAAe;kBAtB3B,SAAS;+BACE,aAAa,mBAGN,uBAAuB,CAAC,MAAM,cACnC,IAAI,WACP;wBACP,eAAe;wBACf,gBAAgB;wBAChB,SAAS;wBACT,gBAAgB;wBAChB,aAAa;wBACb,eAAe;wBACf,UAAU;wBACV,IAAI;wBACJ,eAAe;wBACf,aAAa;wBACb,gBAAgB;wBAChB,mBAAmB;wBACnB,YAAY;qBACb;;0BAUE,MAAM;2BAAC,gBAAgB;4EAJsB,OAAO;sBAAtD,SAAS;uBAAC,UAAU,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["import {\n  AsyncPipe,\n  NgIf,\n  NgOptimizedImage,\n} from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Inject,\n  ViewChild,\n} from '@angular/core';\nimport { FlexLayoutModule } from '@angular/flex-layout';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatMenuModule } from '@angular/material/menu';\nimport {\n  MatDrawerMode,\n  MatSidenav,\n  MatSidenavModule,\n} from '@angular/material/sidenav';\nimport {\n  RouterLink,\n  RouterOutlet,\n} from '@angular/router';\nimport {\n  DetermineReleaseName,\n  Environment,\n  RXAP_ENVIRONMENT,\n} from '@rxap/environment';\nimport { IconLoaderService } from '@rxap/icon';\nimport { FooterComponent } from '../footer/footer.component';\nimport { HeaderComponent } from '../header/header.component';\nimport { NavigationComponent } from '../navigation/navigation.component';\nimport { LayoutComponentService } from './layout.component.service';\n\n\n@Component({\n  selector: 'rxap-layout',\n  templateUrl: './layout.component.html',\n  styleUrls: [ './layout.component.scss' ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    HeaderComponent,\n    MatSidenavModule,\n    AsyncPipe,\n    FlexLayoutModule,\n    MatIconModule,\n    MatButtonModule,\n    RouterLink,\n    NgIf,\n    FooterComponent,\n    MatMenuModule,\n    NgOptimizedImage,\n    NavigationComponent,\n    RouterOutlet,\n  ],\n})\nexport class LayoutComponent {\n\n  public sidenavMode: MatDrawerMode = 'over';\n\n  @ViewChild(MatSidenav, { static: true }) public sidenav!: MatSidenav;\n\n  constructor(\n    public readonly layoutComponentService: LayoutComponentService,\n    @Inject(RXAP_ENVIRONMENT)\n    private readonly environment: Environment,\n    iconLoaderService: IconLoaderService,\n  ) {\n    iconLoaderService.load();\n  }\n\n  public get release() {\n    return DetermineReleaseName(this.environment);\n  }\n\n  public toggleSidenavMode() {\n    if (this.sidenavMode === 'over') {\n      this.sidenavMode = 'side';\n      this.sidenav.open();\n    } else {\n      this.sidenavMode = 'over';\n    }\n  }\n}\n","<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 [ngClass]=\"{\n    'mb-16': (layoutComponentService.fixedBottomGap$ | async) === 64,\n    'mb-32': (layoutComponentService.fixedBottomGap$ | async) === 128,\n  }\" class=\"grow mt-16\">\n    <mat-sidenav\n      #matSidenav=\"matSidenav\"\n      (mouseenter)=\"sidenavMode === 'over' && matSidenav.open()\"\n      (mouseleave)=\"sidenavMode === 'over' && matSidenav.close()\"\n      [fixedBottomGap]=\"layoutComponentService.fixedBottomGap$ | async\"\n      [fixedInViewport]=\"true\"\n      [fixedTopGap]=\"layoutComponentService.fixedTopGap$ | async\"\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-2 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          [src]=\"layoutComponentService.logo.src ?? 'https://via.placeholder.com/256x128px'\"\n          [routerLink]=\"['/']\"\n          [width]=\"layoutComponentService.logo.width ?? 256\"\n          alt=\"logo\"\n          class=\"grow-0 mx-16\"\n        />\n        <div class=\"grow-0 px-16\">\n          <span>{{release}}</span>\n        </div>\n      </div>\n    </mat-sidenav>\n    <mat-sidenav-content class=\"ml-16 p-4\">\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"]}
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"layout.component.js","sourceRoot":"","sources":["../../../../../../../packages/angular/layout/src/lib/layout/layout.component.ts","../../../../../../../packages/angular/layout/src/lib/layout/layout.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AsyncPipe,\n  NgIf,\n  NgOptimizedImage,\n} from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Inject,\n  Signal,\n  ViewChild,\n} from '@angular/core';\nimport { toSignal } from '@angular/core/rxjs-interop';\nimport { FlexLayoutModule } from '@angular/flex-layout';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatMenuModule } from '@angular/material/menu';\nimport {\n  MatDrawerMode,\n  MatSidenav,\n  MatSidenavModule,\n} from '@angular/material/sidenav';\nimport {\n  RouterLink,\n  RouterOutlet,\n} from '@angular/router';\nimport {\n  DetermineReleaseName,\n  Environment,\n  RXAP_ENVIRONMENT,\n} from '@rxap/environment';\nimport { IconLoaderService } from '@rxap/icon';\nimport { StatusIndicatorComponent } from '@rxap/ngx-status-check';\nimport { FooterComponent } from '../footer/footer.component';\nimport { HeaderComponent } from '../header/header.component';\nimport { NavigationComponent } from '../navigation/navigation.component';\nimport { LayoutComponentService } from './layout.component.service';\n\n\n@Component({\n  selector: 'rxap-layout',\n  templateUrl: './layout.component.html',\n  styleUrls: [ './layout.component.scss' ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    HeaderComponent,\n    MatSidenavModule,\n    AsyncPipe,\n    FlexLayoutModule,\n    MatIconModule,\n    MatButtonModule,\n    RouterLink,\n    NgIf,\n    FooterComponent,\n    MatMenuModule,\n    NgOptimizedImage,\n    NavigationComponent,\n    RouterOutlet,\n    StatusIndicatorComponent,\n  ],\n})\nexport class LayoutComponent {\n\n  public readonly sidenavMode: Signal<MatDrawerMode>;\n  public readonly fixedBottomGap: Signal<number>;\n  public readonly fixedTopGap: Signal<number>;\n  public readonly pinned: Signal<boolean>;\n  public readonly collapsable: Signal<boolean>;\n  public readonly logoSrc: string;\n  public readonly logoWidth: number;\n  public readonly release: string;\n  public readonly opened: Signal<boolean>;\n\n  @ViewChild(MatSidenav, { static: true }) public sidenav!: MatSidenav;\n\n  constructor(\n    public readonly layoutComponentService: LayoutComponentService,\n    @Inject(RXAP_ENVIRONMENT)\n    private readonly environment: Environment,\n    iconLoaderService: IconLoaderService,\n  ) {\n    iconLoaderService.load();\n    this.fixedBottomGap = toSignal(layoutComponentService.fixedBottomGap$, { initialValue: 0 });\n    this.fixedTopGap =\n      toSignal(layoutComponentService.fixedTopGap$, { initialValue: layoutComponentService.fixedTopGap$.value });\n    this.sidenavMode = toSignal(layoutComponentService.mode$, { initialValue: layoutComponentService.mode$.value });\n    this.pinned = toSignal(layoutComponentService.pinned$, { initialValue: layoutComponentService.pinned$.value });\n    this.collapsable =\n      toSignal(layoutComponentService.collapsable$, { initialValue: layoutComponentService.collapsable$.value });\n    this.opened = toSignal(layoutComponentService.opened$, { initialValue: layoutComponentService.opened$.value });\n    this.logoSrc = this.layoutComponentService.logo.src ?? 'https://via.placeholder.com/256x128px';\n    this.logoWidth = this.layoutComponentService.logo.width ?? 256;\n    this.release = DetermineReleaseName(this.environment);\n  }\n\n}\n","<rxap-status-indicator class=\"fixed bottom-0 right-0 z-10\"></rxap-status-indicator>\n<div class=\"flex flex-col h-screen justify-between\">\n  <rxap-header class=\"z-10 w-full fixed top-0\"></rxap-header>\n  <mat-sidenav-container [ngClass]=\"{\n    'mb-16': fixedBottomGap() === 64,\n    'mb-32': fixedBottomGap() === 128,\n  }\" class=\"grow mt-16\">\n    <mat-sidenav\n      #matSidenav=\"matSidenav\"\n      [fixedBottomGap]=\"fixedBottomGap()\"\n      [fixedInViewport]=\"true\"\n      [fixedTopGap]=\"fixedTopGap()\"\n      [mode]=\"sidenavMode()\"\n      [ngClass]=\"{ collapsable: collapsable() }\"\n      class=\"sidenav\"\n      [opened]=\"opened()\"\n    >\n      <div class=\"h-full py-2 flex flex-col items-center gap-y-5 justify-items-stretch\">\n\n        <div (click)=\"layoutComponentService.togglePinned()\" *ngIf=\"collapsable()\"\n             class=\"pl-2 pr-2 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=\"!pinned()\">radio_button_unchecked</mat-icon>\n            <mat-icon *ngIf=\"pinned()\">radio_button_checked</mat-icon>\n          </button>\n        </div>\n\n        <ul\n          (mouseenter)=\"collapsable() && !pinned() && matSidenav.open()\"\n          (mouseleave)=\"collapsable() && !pinned() && matSidenav.close()\" class=\"grow self-stretch\"\n          root\n          rxap-navigation\n        >\n        </ul>\n\n        <img\n          [src]=\"logoSrc\"\n          [routerLink]=\"['/']\"\n          [width]=\"logoWidth\"\n          alt=\"logo\"\n          class=\"grow-0 mx-16\"\n        />\n        <div class=\"grow-0 px-16\">\n          <span>{{release}}</span>\n        </div>\n      </div>\n    </mat-sidenav>\n    <mat-sidenav-content [ngClass]=\"{ 'ml-16': collapsable() }\" class=\"p-4\">\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"]}
|
|
@@ -1,22 +1,31 @@
|
|
|
1
|
+
import { MediaMatcher } from '@angular/cdk/layout';
|
|
1
2
|
import { Inject, Injectable, Optional, } from '@angular/core';
|
|
2
3
|
import { ConfigService } from '@rxap/config';
|
|
3
4
|
import { FooterService, HeaderService, } from '@rxap/services';
|
|
4
|
-
import { BehaviorSubject, } from 'rxjs';
|
|
5
|
+
import { BehaviorSubject, skip, } from 'rxjs';
|
|
5
6
|
import { map, tap, } from 'rxjs/operators';
|
|
6
7
|
import { RXAP_LOGO_CONFIG } from '../tokens';
|
|
7
8
|
import * as i0 from "@angular/core";
|
|
8
9
|
import * as i1 from "@rxap/services";
|
|
9
|
-
import * as i2 from "@
|
|
10
|
+
import * as i2 from "@angular/cdk/layout";
|
|
11
|
+
import * as i3 from "@rxap/config";
|
|
10
12
|
export class LayoutComponentService {
|
|
11
|
-
constructor(footerComponentService, headerComponentService, logoConfig = null, config) {
|
|
13
|
+
constructor(footerComponentService, headerComponentService, logoConfig = null, config, mediaMatcher) {
|
|
12
14
|
this.footerComponentService = footerComponentService;
|
|
13
15
|
this.headerComponentService = headerComponentService;
|
|
14
16
|
this.config = config;
|
|
15
|
-
this.opened$ = new BehaviorSubject(true);
|
|
16
|
-
this.mode$ = new BehaviorSubject('side');
|
|
17
17
|
this.fixedTopGap$ = new BehaviorSubject(64);
|
|
18
|
-
|
|
19
|
-
|
|
18
|
+
const mobileQuery = mediaMatcher.matchMedia('(max-width: 959px)');
|
|
19
|
+
const mobile = mobileQuery.matches;
|
|
20
|
+
const initialCollapsable = this.config.get('navigation.collapsable', true);
|
|
21
|
+
const collapsable = initialCollapsable && !mobile;
|
|
22
|
+
const pinned = this.config.get('navigation.pinned', false);
|
|
23
|
+
const mode = this.config.get('navigation.mode', (collapsable && pinned) || !collapsable ? 'side' : 'over');
|
|
24
|
+
const opened = this.config.get('navigation.open', !collapsable || pinned);
|
|
25
|
+
this.mode$ = new BehaviorSubject(mode);
|
|
26
|
+
this.opened$ = new BehaviorSubject(opened);
|
|
27
|
+
this.pinned$ = new BehaviorSubject(pinned);
|
|
28
|
+
this.collapsable$ = new BehaviorSubject(collapsable);
|
|
20
29
|
this.fixedBottomGap$ = this.footerComponentService.portalCount$.pipe(map(count => count * 64));
|
|
21
30
|
this.fixedTopGap$.next(this.headerComponentService.countComponent * 64);
|
|
22
31
|
this.headerComponentService.update$.pipe(tap(() => this.fixedTopGap$.next(this.headerComponentService.countComponent * 64))).subscribe();
|
|
@@ -24,8 +33,34 @@ export class LayoutComponentService {
|
|
|
24
33
|
src: 'assets/logo.png',
|
|
25
34
|
width: 192,
|
|
26
35
|
};
|
|
36
|
+
mobileQuery.addEventListener('change', (event) => {
|
|
37
|
+
if (initialCollapsable) {
|
|
38
|
+
this.collapsable$.next(!event.matches);
|
|
39
|
+
if (this.collapsable$.value) {
|
|
40
|
+
if (!this.pinned$.value) {
|
|
41
|
+
this.opened$.next(false);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
});
|
|
46
|
+
this.pinned$.pipe(skip(1), tap(pinned => {
|
|
47
|
+
if (pinned) {
|
|
48
|
+
this.mode$.next('side');
|
|
49
|
+
this.opened$.next(true);
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
this.mode$.next('over');
|
|
53
|
+
this.opened$.next(false);
|
|
54
|
+
}
|
|
55
|
+
})).subscribe();
|
|
27
56
|
}
|
|
28
|
-
|
|
57
|
+
toggleOpend() {
|
|
58
|
+
this.opened$.next(!this.opened$.value);
|
|
59
|
+
}
|
|
60
|
+
togglePinned() {
|
|
61
|
+
this.pinned$.next(!this.pinned$.value);
|
|
62
|
+
}
|
|
63
|
+
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 }, { token: i2.MediaMatcher }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
29
64
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: LayoutComponentService, providedIn: 'root' }); }
|
|
30
65
|
}
|
|
31
66
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: LayoutComponentService, decorators: [{
|
|
@@ -36,8 +71,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.4", ngImpor
|
|
|
36
71
|
}, {
|
|
37
72
|
type: Inject,
|
|
38
73
|
args: [RXAP_LOGO_CONFIG]
|
|
39
|
-
}] }, { type:
|
|
74
|
+
}] }, { type: i3.ConfigService, decorators: [{
|
|
40
75
|
type: Inject,
|
|
41
76
|
args: [ConfigService]
|
|
42
|
-
}] }]; } });
|
|
43
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
77
|
+
}] }, { type: i2.MediaMatcher }]; } });
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"layout.component.service.js","sourceRoot":"","sources":["../../../../../../../packages/angular/layout/src/lib/layout/layout.component.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { MediaMatcher } from '@angular/cdk/layout';\nimport {\n  Inject,\n  Injectable,\n  Optional,\n} from '@angular/core';\nimport { MatDrawerMode } from '@angular/material/sidenav';\nimport { ConfigService } from '@rxap/config';\nimport {\n  FooterService,\n  HeaderService,\n} from '@rxap/services';\nimport {\n  BehaviorSubject,\n  Observable,\n  skip,\n} from 'rxjs';\nimport {\n  map,\n  tap,\n} from 'rxjs/operators';\nimport { RXAP_LOGO_CONFIG } from '../tokens';\nimport { LogoConfig } from '../types';\n\n@Injectable({ providedIn: 'root' })\nexport class LayoutComponentService {\n\n  public opened$: BehaviorSubject<boolean>;\n  public mode$: BehaviorSubject<MatDrawerMode>;\n  public pinned$: BehaviorSubject<boolean>;\n  public fixedBottomGap$: Observable<number>;\n  public fixedTopGap$ = new BehaviorSubject<number>(64);\n  public logo: LogoConfig;\n  public collapsable$: BehaviorSubject<boolean>;\n\n\n  public constructor(\n    public readonly footerComponentService: FooterService,\n    public readonly headerComponentService: HeaderService,\n    @Optional() @Inject(RXAP_LOGO_CONFIG) logoConfig: LogoConfig | null = null,\n    @Inject(ConfigService)\n    private readonly config: ConfigService,\n    mediaMatcher: MediaMatcher,\n  ) {\n    const mobileQuery = mediaMatcher.matchMedia('(max-width: 959px)');\n    const mobile = mobileQuery.matches;\n    const initialCollapsable = this.config.get('navigation.collapsable', true);\n    const collapsable = initialCollapsable && !mobile;\n    const pinned = this.config.get('navigation.pinned', false);\n    const mode = this.config.get('navigation.mode', (collapsable && pinned) || !collapsable ? 'side' : 'over');\n    const opened = this.config.get('navigation.open', !collapsable || pinned);\n    this.mode$ = new BehaviorSubject<MatDrawerMode>(mode);\n    this.opened$ = new BehaviorSubject<boolean>(opened);\n    this.pinned$ = new BehaviorSubject<boolean>(pinned);\n    this.collapsable$ = new BehaviorSubject<boolean>(collapsable);\n    this.fixedBottomGap$ = this.footerComponentService.portalCount$.pipe(map(count => count * 64));\n    this.fixedTopGap$.next(this.headerComponentService.countComponent * 64);\n    this.headerComponentService.update$.pipe(\n      tap(() => this.fixedTopGap$.next(this.headerComponentService.countComponent * 64)),\n    ).subscribe();\n    this.logo = logoConfig ?? {\n      src: 'assets/logo.png',\n      width: 192,\n    };\n    mobileQuery.addEventListener('change', (event) => {\n      if (initialCollapsable) {\n        this.collapsable$.next(!event.matches);\n        if (this.collapsable$.value) {\n          if (!this.pinned$.value) {\n            this.opened$.next(false);\n          }\n        }\n      }\n    });\n    this.pinned$.pipe(\n      skip(1),\n      tap(pinned => {\n        if (pinned) {\n          this.mode$.next('side');\n          this.opened$.next(true);\n        } else {\n          this.mode$.next('over');\n          this.opened$.next(false);\n        }\n      }),\n    ).subscribe();\n  }\n\n  public toggleOpend() {\n    this.opened$.next(!this.opened$.value);\n  }\n\n  public togglePinned() {\n    this.pinned$.next(!this.pinned$.value);\n  }\n\n}\n"]}
|