@netgrif/components-core
Version:
Netgrif Application engine frontend core Angular library
172 lines • 20 kB
JavaScript
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
import 'hammerjs';
import { Breakpoints } from '@angular/cdk/layout';
import { BehaviorSubject } from 'rxjs';
import * as i0 from "@angular/core";
import * as i1 from "@angular/cdk/layout";
import * as i2 from "../../logger/services/logger.service";
import * as i3 from "../../user/services/user-preference.service";
const DRAWER_DEFAULT_MIN_WIDTH = 200;
const DRAWER_MAX_WIDTH = 450;
export class AbstractNavigationDrawerComponent {
breakpoint;
_log;
userPreferenceService;
showUser;
user;
showQuickPanel;
quickPanelItems; // QuickPanelItem
navigation;
openedChange;
resized;
_sideNav;
opened;
_fixed;
subBreakpoint;
width;
contentWidth;
_config = {
mode: 'over',
opened: true,
disableClose: false,
};
constructor(breakpoint, _log, userPreferenceService) {
this.breakpoint = breakpoint;
this._log = _log;
this.userPreferenceService = userPreferenceService;
this.openedChange = new EventEmitter();
this.resized = new EventEmitter();
this._fixed = true;
this.opened = true;
this.quickPanelItems = ['language', 'settings', 'logout', 'impersonation'];
if (this.userPreferenceService.drawerWidth !== undefined) {
this.contentWidth = new BehaviorSubject(this.userPreferenceService.drawerWidth);
}
else {
this.contentWidth = new BehaviorSubject(DRAWER_DEFAULT_MIN_WIDTH);
}
}
ngOnInit() {
this.resolveLayout(this._fixed);
this.subBreakpoint = this.breakpoint.observe([Breakpoints.HandsetLandscape]).subscribe(result => {
this._log.info('BreakpointObserver matches width of window: ' + this.breakpoint.isMatched('(max-width: 959.99px)'));
if (this.breakpoint.isMatched('(max-width: 959.99px)')) {
this.resolveLayout(false);
this.opened = this._config.opened;
}
else {
this.resolveLayout(this._fixed);
this.opened = this._config.opened;
}
});
this.opened = this._config.opened;
this.userPreferenceService.preferencesChanged$.subscribe(() => {
this.width = this.userPreferenceService.drawerWidth;
this.contentWidth.next(this.width);
});
// this.width = this.userPreferenceService.getDrawerWidth();
}
ngAfterViewInit() {
this.openedChange = this._sideNav.openedChange;
}
ngOnDestroy() {
this.subBreakpoint.unsubscribe();
this.openedChange.complete();
this.resized.complete();
}
get config() {
return this._config;
}
get fixed() {
return this._fixed;
}
set fixed(value) {
this._fixed = value;
this.resolveLayout(this._fixed);
}
open() {
if (!this._sideNav.opened) {
this._sideNav.open();
}
return Promise.resolve('open');
}
close() {
if (this._fixed) {
return Promise.resolve('close');
}
return this._sideNav.close();
}
toggle() {
if (this._fixed) {
return Promise.resolve('open');
}
return this._sideNav.toggle();
}
resolveLayout(bool) {
this._config = bool ? {
mode: 'side',
opened: true,
disableClose: true,
} : {
mode: 'over',
opened: false,
disableClose: false,
};
if (bool && this._sideNav) {
this._sideNav.open();
}
}
swipeRight() {
if (this.breakpoint.isMatched('(max-width: 959.99px)')) {
this._sideNav.open();
}
}
swipeLeft() {
if (this.breakpoint.isMatched('(max-width: 959.99px)')) {
this._sideNav.close();
}
}
onResizeEvent(event) {
if (event.rectangle.width > DRAWER_MAX_WIDTH) {
this.width = DRAWER_MAX_WIDTH;
}
else if (event.rectangle.width < DRAWER_DEFAULT_MIN_WIDTH) {
this.width = DRAWER_DEFAULT_MIN_WIDTH;
}
else {
this.width = event.rectangle.width;
}
this.userPreferenceService._drawerWidthChanged$.next(this.width);
this.contentWidth.next(this.width);
this.resized.emit({ width: this.width });
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractNavigationDrawerComponent, deps: [{ token: i1.BreakpointObserver }, { token: i2.LoggerService }, { token: i3.UserPreferenceService }], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AbstractNavigationDrawerComponent, selector: "ncc-abstract-navigation-drawer", inputs: { showUser: "showUser", user: "user", showQuickPanel: "showQuickPanel", quickPanelItems: "quickPanelItems", navigation: "navigation", fixed: "fixed" }, outputs: { openedChange: "openedChange", resized: "resized" }, viewQueries: [{ propertyName: "_sideNav", first: true, predicate: ["sidenav"], descendants: true }], ngImport: i0, template: '', isInline: true });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractNavigationDrawerComponent, decorators: [{
type: Component,
args: [{
selector: 'ncc-abstract-navigation-drawer',
template: '',
}]
}], ctorParameters: () => [{ type: i1.BreakpointObserver }, { type: i2.LoggerService }, { type: i3.UserPreferenceService }], propDecorators: { showUser: [{
type: Input
}], user: [{
type: Input
}], showQuickPanel: [{
type: Input
}], quickPanelItems: [{
type: Input
}], navigation: [{
type: Input
}], openedChange: [{
type: Output
}], resized: [{
type: Output
}], _sideNav: [{
type: ViewChild,
args: ['sidenav']
}], fixed: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-navigation-drawer.component.js","sourceRoot":"","sources":["../../../../../../projects/netgrif-components-core/src/lib/navigation/navigation-drawer/abstract-navigation-drawer.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, EventEmitter, Input, OnDestroy, OnInit, Output, ViewChild} from '@angular/core';\nimport {User} from '../../user/models/user';\nimport 'hammerjs';\nimport {BreakpointObserver, Breakpoints} from '@angular/cdk/layout';\nimport {MatDrawerToggleResult, MatSidenav} from '@angular/material/sidenav';\nimport {LoggerService} from '../../logger/services/logger.service';\nimport {BehaviorSubject, Subscription} from 'rxjs';\nimport {ResizeEvent} from 'angular-resizable-element';\nimport {UserPreferenceService} from '../../user/services/user-preference.service';\nimport {MenuResizeEvent} from '../model/navigation-menu-events';\n\nconst DRAWER_DEFAULT_MIN_WIDTH = 200;\nconst DRAWER_MAX_WIDTH = 450;\n\n@Component({\n    selector: 'ncc-abstract-navigation-drawer',\n    template: '',\n})\nexport abstract class AbstractNavigationDrawerComponent implements OnInit, AfterViewInit, OnDestroy {\n\n\n    @Input() public showUser: boolean;\n    @Input() public user: User;\n    @Input() public showQuickPanel: boolean;\n    @Input() public quickPanelItems: Array<any>; // QuickPanelItem\n    @Input() public navigation: boolean;\n\n    @Output() public openedChange: EventEmitter<boolean>;\n    @Output() public resized: EventEmitter<MenuResizeEvent>;\n\n    @ViewChild('sidenav') protected _sideNav: MatSidenav;\n\n    public opened: boolean;\n    protected _fixed: boolean;\n    protected subBreakpoint: Subscription;\n\n    public width: number;\n    public contentWidth: BehaviorSubject<number>;\n\n    protected _config = {\n        mode: 'over',\n        opened: true,\n        disableClose: false,\n    };\n\n    constructor(protected breakpoint: BreakpointObserver,\n                protected _log: LoggerService,\n                protected userPreferenceService: UserPreferenceService) {\n        this.openedChange = new EventEmitter<boolean>();\n        this.resized = new EventEmitter<MenuResizeEvent>();\n        this._fixed = true;\n        this.opened = true;\n        this.quickPanelItems = ['language', 'settings', 'logout', 'impersonation'];\n        if (this.userPreferenceService.drawerWidth !== undefined) {\n            this.contentWidth = new BehaviorSubject<number>(this.userPreferenceService.drawerWidth);\n        } else {\n            this.contentWidth = new BehaviorSubject<number>(DRAWER_DEFAULT_MIN_WIDTH);\n        }\n    }\n\n    ngOnInit(): void {\n        this.resolveLayout(this._fixed);\n        this.subBreakpoint = this.breakpoint.observe([Breakpoints.HandsetLandscape]).subscribe(result => {\n            this._log.info('BreakpointObserver matches width of window: ' + this.breakpoint.isMatched('(max-width: 959.99px)'));\n            if (this.breakpoint.isMatched('(max-width: 959.99px)')) {\n                this.resolveLayout(false);\n                this.opened = this._config.opened;\n            } else {\n                this.resolveLayout(this._fixed);\n                this.opened = this._config.opened;\n            }\n        });\n        this.opened = this._config.opened;\n        this.userPreferenceService.preferencesChanged$.subscribe(() => {\n            this.width = this.userPreferenceService.drawerWidth;\n            this.contentWidth.next(this.width);\n        });\n        // this.width = this.userPreferenceService.getDrawerWidth();\n    }\n\n    ngAfterViewInit(): void {\n        this.openedChange = this._sideNav.openedChange;\n    }\n\n    ngOnDestroy(): void {\n        this.subBreakpoint.unsubscribe();\n        this.openedChange.complete();\n        this.resized.complete();\n    }\n\n    get config() {\n        return this._config;\n    }\n\n    get fixed(): boolean {\n        return this._fixed;\n    }\n\n    @Input()\n    set fixed(value: boolean) {\n        this._fixed = value;\n        this.resolveLayout(this._fixed);\n    }\n\n    open(): Promise<MatDrawerToggleResult> {\n        if (!this._sideNav.opened) {\n            this._sideNav.open();\n        }\n        return Promise.resolve('open');\n    }\n\n    close(): Promise<MatDrawerToggleResult> {\n        if (this._fixed) {\n            return Promise.resolve('close');\n        }\n        return this._sideNav.close();\n    }\n\n    toggle(): Promise<MatDrawerToggleResult> {\n        if (this._fixed) {\n            return Promise.resolve('open');\n        }\n        return this._sideNav.toggle();\n    }\n\n    private resolveLayout(bool: boolean): void {\n        this._config = bool ? {\n            mode: 'side',\n            opened: true,\n            disableClose: true,\n        } : {\n            mode: 'over',\n            opened: false,\n            disableClose: false,\n        };\n        if (bool && this._sideNav) {\n            this._sideNav.open();\n        }\n    }\n\n    swipeRight() {\n        if (this.breakpoint.isMatched('(max-width: 959.99px)')) {\n            this._sideNav.open();\n        }\n    }\n\n    swipeLeft() {\n        if (this.breakpoint.isMatched('(max-width: 959.99px)')) {\n            this._sideNav.close();\n        }\n    }\n\n    onResizeEvent(event: ResizeEvent): void {\n        if (event.rectangle.width > DRAWER_MAX_WIDTH) {\n            this.width = DRAWER_MAX_WIDTH;\n        } else if (event.rectangle.width < DRAWER_DEFAULT_MIN_WIDTH) {\n            this.width = DRAWER_DEFAULT_MIN_WIDTH;\n        } else {\n            this.width = event.rectangle.width;\n        }\n        this.userPreferenceService._drawerWidthChanged$.next(this.width);\n        this.contentWidth.next(this.width);\n        this.resized.emit({width: this.width});\n    }\n}\n"]}