@dereekb/dbx-web 9.23.20 → 9.23.21
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/calendar/package.json +3 -3
- package/esm2020/lib/layout/style/style.mjs +7 -1
- package/esm2020/lib/router/layout/navbar/navbar.component.mjs +16 -6
- package/fesm2015/dereekb-dbx-web.mjs +20 -4
- package/fesm2015/dereekb-dbx-web.mjs.map +1 -1
- package/fesm2020/dereekb-dbx-web.mjs +20 -4
- package/fesm2020/dereekb-dbx-web.mjs.map +1 -1
- package/lib/layout/style/_style.scss +25 -0
- package/lib/layout/style/style.d.ts +1 -1
- package/lib/layout/text/_text.scss +5 -0
- package/lib/router/layout/navbar/navbar.component.d.ts +7 -1
- package/mapbox/package.json +3 -3
- package/package.json +3 -3
- package/table/package.json +3 -3
package/calendar/package.json
CHANGED
|
@@ -1,15 +1,15 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@dereekb/dbx-web/calendar",
|
|
3
|
-
"version": "9.23.
|
|
3
|
+
"version": "9.23.21",
|
|
4
4
|
"peerDependencies": {
|
|
5
5
|
"@angular/common": "^14.2.0",
|
|
6
6
|
"@angular/core": "^14.2.0",
|
|
7
7
|
"date-fns": "^2.29.0",
|
|
8
8
|
"rxjs": "^7.5.0",
|
|
9
9
|
"@angular/material": "^14.2.0",
|
|
10
|
-
"@dereekb/util": "9.23.
|
|
10
|
+
"@dereekb/util": "9.23.21",
|
|
11
11
|
"angular-calendar": "^0.30.1",
|
|
12
|
-
"@dereekb/dbx-web": "9.23.
|
|
12
|
+
"@dereekb/dbx-web": "9.23.21"
|
|
13
13
|
},
|
|
14
14
|
"dependencies": {
|
|
15
15
|
"tslib": "^2.3.0"
|
|
@@ -10,7 +10,13 @@ export function dbxColorBackground(color) {
|
|
|
10
10
|
case 'warn':
|
|
11
11
|
cssClass = 'dbx-warn-bg';
|
|
12
12
|
break;
|
|
13
|
+
case 'grey':
|
|
14
|
+
cssClass = 'dbx-grey-bg';
|
|
15
|
+
break;
|
|
16
|
+
case 'disabled':
|
|
17
|
+
cssClass = 'dbx-disabled-bg';
|
|
18
|
+
break;
|
|
13
19
|
}
|
|
14
20
|
return cssClass;
|
|
15
21
|
}
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3R5bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvbGF5b3V0L3N0eWxlL3N0eWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlBLE1BQU0sVUFBVSxrQkFBa0IsQ0FBQyxLQUFnQztJQUNqRSxJQUFJLFFBQVEsR0FBRyxRQUFRLENBQUM7SUFFeEIsUUFBUSxLQUFLLEVBQUU7UUFDYixLQUFLLFNBQVM7WUFDWixRQUFRLEdBQUcsZ0JBQWdCLENBQUM7WUFDNUIsTUFBTTtRQUNSLEtBQUssUUFBUTtZQUNYLFFBQVEsR0FBRyxlQUFlLENBQUM7WUFDM0IsTUFBTTtRQUNSLEtBQUssTUFBTTtZQUNULFFBQVEsR0FBRyxhQUFhLENBQUM7WUFDekIsTUFBTTtRQUNSLEtBQUssTUFBTTtZQUNULFFBQVEsR0FBRyxhQUFhLENBQUM7WUFDekIsTUFBTTtRQUNSLEtBQUssVUFBVTtZQUNiLFFBQVEsR0FBRyxpQkFBaUIsQ0FBQztZQUM3QixNQUFNO0tBQ1Q7SUFFRCxPQUFPLFFBQVEsQ0FBQztBQUNsQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWF5YmUgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcblxuZXhwb3J0IHR5cGUgRGJ4VGhlbWVDb2xvciA9ICdwcmltYXJ5JyB8ICdhY2NlbnQnIHwgJ3dhcm4nIHwgJ2JhY2tncm91bmQnIHwgJ2dyZXknIHwgJ2Rpc2FibGVkJztcblxuZXhwb3J0IGZ1bmN0aW9uIGRieENvbG9yQmFja2dyb3VuZChjb2xvcjogTWF5YmU8RGJ4VGhlbWVDb2xvciB8ICcnPik6IHN0cmluZyB7XG4gIGxldCBjc3NDbGFzcyA9ICdkYngtYmcnO1xuXG4gIHN3aXRjaCAoY29sb3IpIHtcbiAgICBjYXNlICdwcmltYXJ5JzpcbiAgICAgIGNzc0NsYXNzID0gJ2RieC1wcmltYXJ5LWJnJztcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgJ2FjY2VudCc6XG4gICAgICBjc3NDbGFzcyA9ICdkYngtYWNjZW50LWJnJztcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgJ3dhcm4nOlxuICAgICAgY3NzQ2xhc3MgPSAnZGJ4LXdhcm4tYmcnO1xuICAgICAgYnJlYWs7XG4gICAgY2FzZSAnZ3JleSc6XG4gICAgICBjc3NDbGFzcyA9ICdkYngtZ3JleS1iZyc7XG4gICAgICBicmVhaztcbiAgICBjYXNlICdkaXNhYmxlZCc6XG4gICAgICBjc3NDbGFzcyA9ICdkYngtZGlzYWJsZWQtYmcnO1xuICAgICAgYnJlYWs7XG4gIH1cblxuICByZXR1cm4gY3NzQ2xhc3M7XG59XG4iXX0=
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { BehaviorSubject, combineLatest, map, shareReplay, distinctUntilChanged } from 'rxjs';
|
|
1
|
+
import { BehaviorSubject, combineLatest, map, shareReplay, distinctUntilChanged, switchMap } from 'rxjs';
|
|
2
2
|
import { DbxScreenMediaService } from '../../../screen/screen.service';
|
|
3
|
-
import { applyBestFit } from '@dereekb/util';
|
|
3
|
+
import { applyBestFit, findNext } from '@dereekb/util';
|
|
4
4
|
import { Input, Component, ChangeDetectionStrategy, ChangeDetectorRef } from '@angular/core';
|
|
5
5
|
import { DbxRouterService, DbxRouterTransitionService, AbstractTransitionDirective, tapDetectChanges } from '@dereekb/dbx-core';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
@@ -26,6 +26,7 @@ export class DbxNavbarComponent extends AbstractTransitionDirective {
|
|
|
26
26
|
this._defaultIcon = new BehaviorSubject('menu');
|
|
27
27
|
this._defaultText = new BehaviorSubject(undefined);
|
|
28
28
|
this._inputMode = new BehaviorSubject(undefined);
|
|
29
|
+
this._buttonMode = new BehaviorSubject('menu');
|
|
29
30
|
this._breakpoint = new BehaviorSubject('large');
|
|
30
31
|
this._anchors = new BehaviorSubject([]);
|
|
31
32
|
this.isBreakpointActive$ = this._dbxScreenMediaService.isBreakpointActive(this._breakpoint);
|
|
@@ -42,9 +43,12 @@ export class DbxNavbarComponent extends AbstractTransitionDirective {
|
|
|
42
43
|
});
|
|
43
44
|
return applyBestFit(results, (x) => x.selected, (a, b) => this._dbxRouterService.comparePrecision(a.anchor, b.anchor), (nonBestFit) => ({ ...nonBestFit, selected: false }));
|
|
44
45
|
}), tapDetectChanges(this.cdRef), shareReplay(1));
|
|
46
|
+
this.buttonMode$ = this._buttonMode.pipe(distinctUntilChanged(), shareReplay(1));
|
|
45
47
|
this.selectedAnchor$ = this.anchors$.pipe(map((x) => x.find((y) => y.selected)));
|
|
48
|
+
this.nextRotateAnchor$ = this.anchors$.pipe(map((x) => findNext(x, (y) => y.selected) || x[0]));
|
|
46
49
|
this.hasNoAnchors$ = this.anchors$.pipe(map((x) => x.length === 0), distinctUntilChanged(), shareReplay(1));
|
|
47
|
-
this.
|
|
50
|
+
this.buttonNavAnchor$ = this.buttonMode$.pipe(switchMap((x) => (x === 'menu' ? this.selectedAnchor$ : this.nextRotateAnchor$)), distinctUntilChanged(), shareReplay(1));
|
|
51
|
+
this.buttonDisplay$ = combineLatest([this._defaultIcon, this._icon, this._defaultText, this.buttonNavAnchor$, this.mode$]).pipe(map(([defaultIcon, icon, defaultText, selectedAnchor, mode]) => {
|
|
48
52
|
let content;
|
|
49
53
|
if (icon) {
|
|
50
54
|
content = { icon, text: defaultText };
|
|
@@ -68,6 +72,7 @@ export class DbxNavbarComponent extends AbstractTransitionDirective {
|
|
|
68
72
|
this._defaultIcon.complete();
|
|
69
73
|
this._defaultText.complete();
|
|
70
74
|
this._inputMode.complete();
|
|
75
|
+
this._buttonMode.complete();
|
|
71
76
|
this._breakpoint.complete();
|
|
72
77
|
this._anchors.complete();
|
|
73
78
|
}
|
|
@@ -84,6 +89,9 @@ export class DbxNavbarComponent extends AbstractTransitionDirective {
|
|
|
84
89
|
set anchors(anchors) {
|
|
85
90
|
this._anchors.next(anchors ?? []);
|
|
86
91
|
}
|
|
92
|
+
set buttonMode(mode) {
|
|
93
|
+
this._buttonMode.next(mode ?? 'menu');
|
|
94
|
+
}
|
|
87
95
|
set mode(mode) {
|
|
88
96
|
this._inputMode.next(mode);
|
|
89
97
|
}
|
|
@@ -92,12 +100,12 @@ export class DbxNavbarComponent extends AbstractTransitionDirective {
|
|
|
92
100
|
}
|
|
93
101
|
}
|
|
94
102
|
DbxNavbarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxNavbarComponent, deps: [{ token: i1.DbxRouterTransitionService }, { token: i0.ChangeDetectorRef }, { token: i2.DbxScreenMediaService }, { token: i1.DbxRouterService }], target: i0.ɵɵFactoryTarget.Component });
|
|
95
|
-
DbxNavbarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxNavbarComponent, selector: "dbx-navbar", inputs: { navAlign: "navAlign", icon: "icon", defaultIcon: "defaultIcon", defaultText: "defaultText", anchors: "anchors", mode: "mode", breakpoint: "breakpoint" }, host: { classAttribute: "dbx-navbar" }, usesInheritance: true, ngImport: i0, template: "<ng-container [ngSwitch]=\"mode$ | async\">\n <!-- Button -->\n <ng-container *ngSwitchDefault>\n <dbx-icon-button class=\"nav-menu-button\" aria-label=\"open navigation\" [buttonDisplay]=\"buttonDisplay$ | async\" [matMenuTriggerFor]=\"menu\" [disabled]=\"hasNoAnchors$ | async\"></dbx-icon-button>\n
|
|
103
|
+
DbxNavbarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxNavbarComponent, selector: "dbx-navbar", inputs: { navAlign: "navAlign", icon: "icon", defaultIcon: "defaultIcon", defaultText: "defaultText", anchors: "anchors", buttonMode: "buttonMode", mode: "mode", breakpoint: "breakpoint" }, host: { classAttribute: "dbx-navbar" }, usesInheritance: true, ngImport: i0, template: "<ng-container [ngSwitch]=\"mode$ | async\">\n <!-- Button -->\n <ng-container *ngSwitchDefault>\n <ng-container [ngSwitch]=\"buttonMode$ | async\">\n <ng-container *ngSwitchCase=\"'menu'\">\n <dbx-icon-button class=\"nav-menu-button\" aria-label=\"open navigation\" [buttonDisplay]=\"buttonDisplay$ | async\" [matMenuTriggerFor]=\"menu\" [disabled]=\"hasNoAnchors$ | async\"></dbx-icon-button>\n <mat-menu #menu>\n <dbx-anchor *ngFor=\"let x of anchors$ | async\" [anchor]=\"x.anchor\">\n <button mat-menu-item [ngClass]=\"x.selected ? 'active' : ''\">\n <mat-icon *ngIf=\"x.anchor.icon\">{{ x.anchor.icon }}</mat-icon>\n {{ x.anchor.title }}\n </button>\n </dbx-anchor>\n </mat-menu>\n </ng-container>\n <ng-container *ngSwitchCase=\"'rotate'\">\n <dbx-anchor [anchor]=\"(nextRotateAnchor$ | async)?.anchor\">\n <dbx-icon-button class=\"nav-menu-button\" aria-label=\"open navigation\" [buttonDisplay]=\"buttonDisplay$ | async\" [disabled]=\"hasNoAnchors$ | async\"></dbx-icon-button>\n </dbx-anchor>\n </ng-container>\n </ng-container>\n </ng-container>\n <!-- Bar -->\n <nav *ngSwitchCase=\"'bar'\" mat-tab-nav-bar [attr.mat-align-tabs]=\"navAlign\">\n <dbx-anchor *ngFor=\"let x of anchors$ | async\" [anchor]=\"x.anchor\">\n <a mat-tab-link [active]=\"x.selected\">{{ x.anchor.title }}</a>\n </dbx-anchor>\n </nav>\n</ng-container>\n", dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i3.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "component", type: i4.DbxIconButtonComponent, selector: "dbx-icon-button" }, { kind: "component", type: i5.MatTabNav, selector: "[mat-tab-nav-bar]", inputs: ["color"], exportAs: ["matTabNavBar", "matTabNav"] }, { kind: "directive", type: i5.MatTabLink, selector: "[mat-tab-link], [matTabLink]", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matTabLink"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i7.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i7.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i7.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "component", type: i8.DbxAnchorComponent, selector: "dbx-anchor, [dbx-anchor]", inputs: ["block"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
96
104
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxNavbarComponent, decorators: [{
|
|
97
105
|
type: Component,
|
|
98
106
|
args: [{ selector: 'dbx-navbar', changeDetection: ChangeDetectionStrategy.OnPush, host: {
|
|
99
107
|
class: 'dbx-navbar'
|
|
100
|
-
}, template: "<ng-container [ngSwitch]=\"mode$ | async\">\n <!-- Button -->\n <ng-container *ngSwitchDefault>\n <dbx-icon-button class=\"nav-menu-button\" aria-label=\"open navigation\" [buttonDisplay]=\"buttonDisplay$ | async\" [matMenuTriggerFor]=\"menu\" [disabled]=\"hasNoAnchors$ | async\"></dbx-icon-button>\n
|
|
108
|
+
}, template: "<ng-container [ngSwitch]=\"mode$ | async\">\n <!-- Button -->\n <ng-container *ngSwitchDefault>\n <ng-container [ngSwitch]=\"buttonMode$ | async\">\n <ng-container *ngSwitchCase=\"'menu'\">\n <dbx-icon-button class=\"nav-menu-button\" aria-label=\"open navigation\" [buttonDisplay]=\"buttonDisplay$ | async\" [matMenuTriggerFor]=\"menu\" [disabled]=\"hasNoAnchors$ | async\"></dbx-icon-button>\n <mat-menu #menu>\n <dbx-anchor *ngFor=\"let x of anchors$ | async\" [anchor]=\"x.anchor\">\n <button mat-menu-item [ngClass]=\"x.selected ? 'active' : ''\">\n <mat-icon *ngIf=\"x.anchor.icon\">{{ x.anchor.icon }}</mat-icon>\n {{ x.anchor.title }}\n </button>\n </dbx-anchor>\n </mat-menu>\n </ng-container>\n <ng-container *ngSwitchCase=\"'rotate'\">\n <dbx-anchor [anchor]=\"(nextRotateAnchor$ | async)?.anchor\">\n <dbx-icon-button class=\"nav-menu-button\" aria-label=\"open navigation\" [buttonDisplay]=\"buttonDisplay$ | async\" [disabled]=\"hasNoAnchors$ | async\"></dbx-icon-button>\n </dbx-anchor>\n </ng-container>\n </ng-container>\n </ng-container>\n <!-- Bar -->\n <nav *ngSwitchCase=\"'bar'\" mat-tab-nav-bar [attr.mat-align-tabs]=\"navAlign\">\n <dbx-anchor *ngFor=\"let x of anchors$ | async\" [anchor]=\"x.anchor\">\n <a mat-tab-link [active]=\"x.selected\">{{ x.anchor.title }}</a>\n </dbx-anchor>\n </nav>\n</ng-container>\n" }]
|
|
101
109
|
}], ctorParameters: function () { return [{ type: i1.DbxRouterTransitionService }, { type: i0.ChangeDetectorRef }, { type: i2.DbxScreenMediaService }, { type: i1.DbxRouterService }]; }, propDecorators: { navAlign: [{
|
|
102
110
|
type: Input
|
|
103
111
|
}], icon: [{
|
|
@@ -108,9 +116,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
108
116
|
type: Input
|
|
109
117
|
}], anchors: [{
|
|
110
118
|
type: Input
|
|
119
|
+
}], buttonMode: [{
|
|
120
|
+
type: Input
|
|
111
121
|
}], mode: [{
|
|
112
122
|
type: Input
|
|
113
123
|
}], breakpoint: [{
|
|
114
124
|
type: Input
|
|
115
125
|
}] } });
|
|
116
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navbar.component.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-web/src/lib/router/layout/navbar/navbar.component.ts","../../../../../../../../packages/dbx-web/src/lib/router/layout/navbar/navbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Observable, BehaviorSubject, combineLatest, map, shareReplay, distinctUntilChanged } from 'rxjs';\nimport { ScreenMediaWidthType } from './../../../screen/screen';\nimport { DbxScreenMediaService } from '../../../screen/screen.service';\nimport { applyBestFit, Maybe } from '@dereekb/util';\nimport { Input, Component, OnDestroy, ChangeDetectionStrategy, ChangeDetectorRef } from '@angular/core';\nimport { ClickableAnchorLinkSegueRef, DbxRouterService, DbxRouterTransitionService, AbstractTransitionDirective, tapDetectChanges, DbxButtonDisplayContent } from '@dereekb/dbx-core';\nimport { HorizontalConnectionPos } from '@angular/cdk/overlay';\n\ninterface NavAnchorLink {\n  selected: boolean;\n  anchor: ClickableAnchorLinkSegueRef;\n}\n\nexport type NavBarContentAlign = 'center' | 'left' | 'right';\nexport type NavbarMode = 'bar' | 'button' | 'icon';\n\n/**\n * Component that displays a navbar.\n */\n@Component({\n  selector: 'dbx-navbar',\n  templateUrl: './navbar.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    class: 'dbx-navbar'\n  }\n})\nexport class DbxNavbarComponent extends AbstractTransitionDirective implements OnDestroy {\n  @Input()\n  navAlign: HorizontalConnectionPos = 'center';\n\n  private _icon = new BehaviorSubject<Maybe<string>>(undefined);\n  private _defaultIcon = new BehaviorSubject<Maybe<string>>('menu');\n  private _defaultText = new BehaviorSubject<Maybe<string>>(undefined);\n\n  private _inputMode = new BehaviorSubject<Maybe<NavbarMode>>(undefined);\n  private _breakpoint = new BehaviorSubject<ScreenMediaWidthType>('large');\n  private _anchors = new BehaviorSubject<ClickableAnchorLinkSegueRef[]>([]);\n\n  readonly isBreakpointActive$ = this._dbxScreenMediaService.isBreakpointActive(this._breakpoint);\n\n  readonly mode$ = combineLatest([this._inputMode, this.isBreakpointActive$]).pipe(\n    map(([inputMode, breakpointActive]) => {\n      return breakpointActive ? inputMode ?? 'bar' : 'button';\n    }),\n    distinctUntilChanged(),\n    tapDetectChanges(this.cdRef),\n    shareReplay(1)\n  );\n\n  readonly anchors$: Observable<NavAnchorLink[]> = combineLatest([this._anchors, this.initAndUpdateOnTransitionSuccess$]).pipe(\n    map(([anchors]) => {\n      const results = anchors.map((anchor) => {\n        const selected = this._dbxRouterService.isActive(anchor);\n\n        return {\n          selected,\n          anchor\n        };\n      });\n\n      return applyBestFit(\n        results,\n        (x) => x.selected,\n        (a, b) => this._dbxRouterService.comparePrecision(a.anchor, b.anchor),\n        (nonBestFit) => ({ ...nonBestFit, selected: false })\n      );\n    }),\n    tapDetectChanges(this.cdRef),\n    shareReplay(1)\n  );\n\n  readonly selectedAnchor$: Observable<Maybe<NavAnchorLink>> = this.anchors$.pipe(map((x) => x.find((y) => y.selected)));\n\n  readonly hasNoAnchors$ = this.anchors$.pipe(\n    map((x) => x.length === 0),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly buttonDisplay$: Observable<DbxButtonDisplayContent> = combineLatest([this._defaultIcon, this._icon, this._defaultText, this.selectedAnchor$, this.mode$]).pipe(\n    map(([defaultIcon, icon, defaultText, selectedAnchor, mode]) => {\n      let content: DbxButtonDisplayContent;\n\n      if (icon) {\n        content = { icon, text: defaultText };\n      } else if (selectedAnchor) {\n        content = { icon: selectedAnchor.anchor.icon ?? defaultIcon, text: selectedAnchor.anchor.title };\n      } else {\n        content = { icon: defaultIcon ?? 'menu', text: defaultText };\n      }\n\n      if (mode === 'icon') {\n        return { icon: content.icon };\n      } else {\n        return content;\n      }\n    }),\n    shareReplay(1)\n  );\n\n  constructor(dbxRouterTransitionService: DbxRouterTransitionService, private cdRef: ChangeDetectorRef, private readonly _dbxScreenMediaService: DbxScreenMediaService, private readonly _dbxRouterService: DbxRouterService) {\n    super(dbxRouterTransitionService);\n  }\n\n  ngOnDestroy(): void {\n    this._icon.complete();\n    this._defaultIcon.complete();\n    this._defaultText.complete();\n    this._inputMode.complete();\n    this._breakpoint.complete();\n    this._anchors.complete();\n  }\n\n  // MARK: Accessors\n  @Input()\n  public set icon(icon: Maybe<string>) {\n    this._icon.next(icon);\n  }\n\n  @Input()\n  public set defaultIcon(defaultIcon: Maybe<string>) {\n    this._defaultIcon.next(defaultIcon);\n  }\n\n  @Input()\n  public set defaultText(defaultText: Maybe<string>) {\n    this._defaultText.next(defaultText);\n  }\n\n  @Input()\n  public set anchors(anchors: Maybe<ClickableAnchorLinkSegueRef[]>) {\n    this._anchors.next(anchors ?? []);\n  }\n\n  @Input()\n  public set mode(mode: Maybe<NavbarMode>) {\n    this._inputMode.next(mode);\n  }\n\n  @Input()\n  public set breakpoint(breakpoint: ScreenMediaWidthType) {\n    this._breakpoint.next(breakpoint);\n  }\n}\n","<ng-container [ngSwitch]=\"mode$ | async\">\n  <!-- Button -->\n  <ng-container *ngSwitchDefault>\n    <dbx-icon-button class=\"nav-menu-button\" aria-label=\"open navigation\" [buttonDisplay]=\"buttonDisplay$ | async\" [matMenuTriggerFor]=\"menu\" [disabled]=\"hasNoAnchors$ | async\"></dbx-icon-button>\n    <mat-menu #menu>\n      <dbx-anchor *ngFor=\"let x of anchors$ | async\" [anchor]=\"x.anchor\">\n        <button mat-menu-item [ngClass]=\"x.selected ? 'active' : ''\">\n          <mat-icon *ngIf=\"x.anchor.icon\">{{ x.anchor.icon }}</mat-icon>\n          {{ x.anchor.title }}\n        </button>\n      </dbx-anchor>\n    </mat-menu>\n  </ng-container>\n  <!-- Bar -->\n  <nav *ngSwitchCase=\"'bar'\" mat-tab-nav-bar [attr.mat-align-tabs]=\"navAlign\">\n    <dbx-anchor *ngFor=\"let x of anchors$ | async\" [anchor]=\"x.anchor\">\n      <a mat-tab-link [active]=\"x.selected\">{{ x.anchor.title }}</a>\n    </dbx-anchor>\n  </nav>\n</ng-container>\n"]}
|
|
126
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navbar.component.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-web/src/lib/router/layout/navbar/navbar.component.ts","../../../../../../../../packages/dbx-web/src/lib/router/layout/navbar/navbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Observable, BehaviorSubject, combineLatest, map, shareReplay, distinctUntilChanged, switchMap } from 'rxjs';\nimport { ScreenMediaWidthType } from './../../../screen/screen';\nimport { DbxScreenMediaService } from '../../../screen/screen.service';\nimport { applyBestFit, findNext, Maybe } from '@dereekb/util';\nimport { Input, Component, OnDestroy, ChangeDetectionStrategy, ChangeDetectorRef } from '@angular/core';\nimport { ClickableAnchorLinkSegueRef, DbxRouterService, DbxRouterTransitionService, AbstractTransitionDirective, tapDetectChanges, DbxButtonDisplayContent } from '@dereekb/dbx-core';\nimport { HorizontalConnectionPos } from '@angular/cdk/overlay';\n\ninterface NavAnchorLink {\n  selected: boolean;\n  anchor: ClickableAnchorLinkSegueRef;\n}\n\nexport type NavBarContentAlign = 'center' | 'left' | 'right';\nexport type NavbarMode = 'bar' | 'button' | 'icon';\nexport type NavbarButtonMode = 'menu' | 'rotate';\n\n/**\n * Component that displays a navbar.\n */\n@Component({\n  selector: 'dbx-navbar',\n  templateUrl: './navbar.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    class: 'dbx-navbar'\n  }\n})\nexport class DbxNavbarComponent extends AbstractTransitionDirective implements OnDestroy {\n  @Input()\n  navAlign: HorizontalConnectionPos = 'center';\n\n  private _icon = new BehaviorSubject<Maybe<string>>(undefined);\n  private _defaultIcon = new BehaviorSubject<Maybe<string>>('menu');\n  private _defaultText = new BehaviorSubject<Maybe<string>>(undefined);\n\n  private _inputMode = new BehaviorSubject<Maybe<NavbarMode>>(undefined);\n  private _buttonMode = new BehaviorSubject<NavbarButtonMode>('menu');\n  private _breakpoint = new BehaviorSubject<ScreenMediaWidthType>('large');\n  private _anchors = new BehaviorSubject<ClickableAnchorLinkSegueRef[]>([]);\n\n  readonly isBreakpointActive$ = this._dbxScreenMediaService.isBreakpointActive(this._breakpoint);\n\n  readonly mode$ = combineLatest([this._inputMode, this.isBreakpointActive$]).pipe(\n    map(([inputMode, breakpointActive]) => {\n      return breakpointActive ? inputMode ?? 'bar' : 'button';\n    }),\n    distinctUntilChanged(),\n    tapDetectChanges(this.cdRef),\n    shareReplay(1)\n  );\n\n  readonly anchors$: Observable<NavAnchorLink[]> = combineLatest([this._anchors, this.initAndUpdateOnTransitionSuccess$]).pipe(\n    map(([anchors]) => {\n      const results = anchors.map((anchor) => {\n        const selected = this._dbxRouterService.isActive(anchor);\n\n        return {\n          selected,\n          anchor\n        };\n      });\n\n      return applyBestFit(\n        results,\n        (x) => x.selected,\n        (a, b) => this._dbxRouterService.comparePrecision(a.anchor, b.anchor),\n        (nonBestFit) => ({ ...nonBestFit, selected: false })\n      );\n    }),\n    tapDetectChanges(this.cdRef),\n    shareReplay(1)\n  );\n\n  readonly buttonMode$ = this._buttonMode.pipe(distinctUntilChanged(), shareReplay(1));\n\n  readonly selectedAnchor$: Observable<Maybe<NavAnchorLink>> = this.anchors$.pipe(map((x) => x.find((y) => y.selected)));\n  readonly nextRotateAnchor$: Observable<Maybe<NavAnchorLink>> = this.anchors$.pipe(map((x) => findNext(x, (y) => y.selected) || x[0]));\n\n  readonly hasNoAnchors$ = this.anchors$.pipe(\n    map((x) => x.length === 0),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly buttonNavAnchor$ = this.buttonMode$.pipe(\n    switchMap((x) => (x === 'menu' ? this.selectedAnchor$ : this.nextRotateAnchor$)),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly buttonDisplay$: Observable<DbxButtonDisplayContent> = combineLatest([this._defaultIcon, this._icon, this._defaultText, this.buttonNavAnchor$, this.mode$]).pipe(\n    map(([defaultIcon, icon, defaultText, selectedAnchor, mode]) => {\n      let content: DbxButtonDisplayContent;\n\n      if (icon) {\n        content = { icon, text: defaultText };\n      } else if (selectedAnchor) {\n        content = { icon: selectedAnchor.anchor.icon ?? defaultIcon, text: selectedAnchor.anchor.title };\n      } else {\n        content = { icon: defaultIcon ?? 'menu', text: defaultText };\n      }\n\n      if (mode === 'icon') {\n        return { icon: content.icon };\n      } else {\n        return content;\n      }\n    }),\n    shareReplay(1)\n  );\n\n  constructor(dbxRouterTransitionService: DbxRouterTransitionService, private cdRef: ChangeDetectorRef, private readonly _dbxScreenMediaService: DbxScreenMediaService, private readonly _dbxRouterService: DbxRouterService) {\n    super(dbxRouterTransitionService);\n  }\n\n  ngOnDestroy(): void {\n    this._icon.complete();\n    this._defaultIcon.complete();\n    this._defaultText.complete();\n    this._inputMode.complete();\n    this._buttonMode.complete();\n    this._breakpoint.complete();\n    this._anchors.complete();\n  }\n\n  // MARK: Accessors\n  @Input()\n  public set icon(icon: Maybe<string>) {\n    this._icon.next(icon);\n  }\n\n  @Input()\n  public set defaultIcon(defaultIcon: Maybe<string>) {\n    this._defaultIcon.next(defaultIcon);\n  }\n\n  @Input()\n  public set defaultText(defaultText: Maybe<string>) {\n    this._defaultText.next(defaultText);\n  }\n\n  @Input()\n  public set anchors(anchors: Maybe<ClickableAnchorLinkSegueRef[]>) {\n    this._anchors.next(anchors ?? []);\n  }\n\n  @Input()\n  public set buttonMode(mode: Maybe<NavbarButtonMode>) {\n    this._buttonMode.next(mode ?? 'menu');\n  }\n\n  @Input()\n  public set mode(mode: Maybe<NavbarMode>) {\n    this._inputMode.next(mode);\n  }\n\n  @Input()\n  public set breakpoint(breakpoint: ScreenMediaWidthType) {\n    this._breakpoint.next(breakpoint);\n  }\n}\n","<ng-container [ngSwitch]=\"mode$ | async\">\n  <!-- Button -->\n  <ng-container *ngSwitchDefault>\n    <ng-container [ngSwitch]=\"buttonMode$ | async\">\n      <ng-container *ngSwitchCase=\"'menu'\">\n        <dbx-icon-button class=\"nav-menu-button\" aria-label=\"open navigation\" [buttonDisplay]=\"buttonDisplay$ | async\" [matMenuTriggerFor]=\"menu\" [disabled]=\"hasNoAnchors$ | async\"></dbx-icon-button>\n        <mat-menu #menu>\n          <dbx-anchor *ngFor=\"let x of anchors$ | async\" [anchor]=\"x.anchor\">\n            <button mat-menu-item [ngClass]=\"x.selected ? 'active' : ''\">\n              <mat-icon *ngIf=\"x.anchor.icon\">{{ x.anchor.icon }}</mat-icon>\n              {{ x.anchor.title }}\n            </button>\n          </dbx-anchor>\n        </mat-menu>\n      </ng-container>\n      <ng-container *ngSwitchCase=\"'rotate'\">\n        <dbx-anchor [anchor]=\"(nextRotateAnchor$ | async)?.anchor\">\n          <dbx-icon-button class=\"nav-menu-button\" aria-label=\"open navigation\" [buttonDisplay]=\"buttonDisplay$ | async\" [disabled]=\"hasNoAnchors$ | async\"></dbx-icon-button>\n        </dbx-anchor>\n      </ng-container>\n    </ng-container>\n  </ng-container>\n  <!-- Bar -->\n  <nav *ngSwitchCase=\"'bar'\" mat-tab-nav-bar [attr.mat-align-tabs]=\"navAlign\">\n    <dbx-anchor *ngFor=\"let x of anchors$ | async\" [anchor]=\"x.anchor\">\n      <a mat-tab-link [active]=\"x.selected\">{{ x.anchor.title }}</a>\n    </dbx-anchor>\n  </nav>\n</ng-container>\n"]}
|
|
@@ -15,7 +15,7 @@ import * as i3 from '@angular/material/progress-spinner';
|
|
|
15
15
|
import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
|
|
16
16
|
import * as i2$1 from '@angular/material/icon';
|
|
17
17
|
import { MatIconModule } from '@angular/material/icon';
|
|
18
|
-
import { getValueFromGetter, mergeObjects, splitCommaSeparatedStringToSet, asPromise, objectHasNoKeys, modifier, combineMaps, addModifiers, removeModifiers, applyBestFit, filterMaybeValues, asArray, firstValue, filterUndefinedValues, isMaybeNot, isNotNullOrEmptyString, mapIterable, toReadableError, isDefaultReadableError, build, ServerErrorResponse, UnauthorizedServerErrorResponse, maybeModifierMapToFunction, ModelRelationUtility, encodeModelKeyTypePair, useIterableOrValue } from '@dereekb/util';
|
|
18
|
+
import { getValueFromGetter, mergeObjects, splitCommaSeparatedStringToSet, asPromise, objectHasNoKeys, modifier, combineMaps, addModifiers, removeModifiers, applyBestFit, findNext, filterMaybeValues, asArray, firstValue, filterUndefinedValues, isMaybeNot, isNotNullOrEmptyString, mapIterable, toReadableError, isDefaultReadableError, build, ServerErrorResponse, UnauthorizedServerErrorResponse, maybeModifierMapToFunction, ModelRelationUtility, encodeModelKeyTypePair, useIterableOrValue } from '@dereekb/util';
|
|
19
19
|
import * as i3$1 from '@angular/material/progress-bar';
|
|
20
20
|
import { MatProgressBarModule } from '@angular/material/progress-bar';
|
|
21
21
|
import * as i5 from '@angular/material/core';
|
|
@@ -1189,6 +1189,12 @@ function dbxColorBackground(color) {
|
|
|
1189
1189
|
case 'warn':
|
|
1190
1190
|
cssClass = 'dbx-warn-bg';
|
|
1191
1191
|
break;
|
|
1192
|
+
case 'grey':
|
|
1193
|
+
cssClass = 'dbx-grey-bg';
|
|
1194
|
+
break;
|
|
1195
|
+
case 'disabled':
|
|
1196
|
+
cssClass = 'dbx-disabled-bg';
|
|
1197
|
+
break;
|
|
1192
1198
|
}
|
|
1193
1199
|
return cssClass;
|
|
1194
1200
|
}
|
|
@@ -2877,6 +2883,7 @@ class DbxNavbarComponent extends AbstractTransitionDirective {
|
|
|
2877
2883
|
this._defaultIcon = new BehaviorSubject('menu');
|
|
2878
2884
|
this._defaultText = new BehaviorSubject(undefined);
|
|
2879
2885
|
this._inputMode = new BehaviorSubject(undefined);
|
|
2886
|
+
this._buttonMode = new BehaviorSubject('menu');
|
|
2880
2887
|
this._breakpoint = new BehaviorSubject('large');
|
|
2881
2888
|
this._anchors = new BehaviorSubject([]);
|
|
2882
2889
|
this.isBreakpointActive$ = this._dbxScreenMediaService.isBreakpointActive(this._breakpoint);
|
|
@@ -2893,9 +2900,12 @@ class DbxNavbarComponent extends AbstractTransitionDirective {
|
|
|
2893
2900
|
});
|
|
2894
2901
|
return applyBestFit(results, (x) => x.selected, (a, b) => this._dbxRouterService.comparePrecision(a.anchor, b.anchor), (nonBestFit) => (Object.assign(Object.assign({}, nonBestFit), { selected: false })));
|
|
2895
2902
|
}), tapDetectChanges(this.cdRef), shareReplay(1));
|
|
2903
|
+
this.buttonMode$ = this._buttonMode.pipe(distinctUntilChanged(), shareReplay(1));
|
|
2896
2904
|
this.selectedAnchor$ = this.anchors$.pipe(map((x) => x.find((y) => y.selected)));
|
|
2905
|
+
this.nextRotateAnchor$ = this.anchors$.pipe(map((x) => findNext(x, (y) => y.selected) || x[0]));
|
|
2897
2906
|
this.hasNoAnchors$ = this.anchors$.pipe(map((x) => x.length === 0), distinctUntilChanged(), shareReplay(1));
|
|
2898
|
-
this.
|
|
2907
|
+
this.buttonNavAnchor$ = this.buttonMode$.pipe(switchMap((x) => (x === 'menu' ? this.selectedAnchor$ : this.nextRotateAnchor$)), distinctUntilChanged(), shareReplay(1));
|
|
2908
|
+
this.buttonDisplay$ = combineLatest([this._defaultIcon, this._icon, this._defaultText, this.buttonNavAnchor$, this.mode$]).pipe(map(([defaultIcon, icon, defaultText, selectedAnchor, mode]) => {
|
|
2899
2909
|
var _a;
|
|
2900
2910
|
let content;
|
|
2901
2911
|
if (icon) {
|
|
@@ -2920,6 +2930,7 @@ class DbxNavbarComponent extends AbstractTransitionDirective {
|
|
|
2920
2930
|
this._defaultIcon.complete();
|
|
2921
2931
|
this._defaultText.complete();
|
|
2922
2932
|
this._inputMode.complete();
|
|
2933
|
+
this._buttonMode.complete();
|
|
2923
2934
|
this._breakpoint.complete();
|
|
2924
2935
|
this._anchors.complete();
|
|
2925
2936
|
}
|
|
@@ -2936,6 +2947,9 @@ class DbxNavbarComponent extends AbstractTransitionDirective {
|
|
|
2936
2947
|
set anchors(anchors) {
|
|
2937
2948
|
this._anchors.next(anchors !== null && anchors !== void 0 ? anchors : []);
|
|
2938
2949
|
}
|
|
2950
|
+
set buttonMode(mode) {
|
|
2951
|
+
this._buttonMode.next(mode !== null && mode !== void 0 ? mode : 'menu');
|
|
2952
|
+
}
|
|
2939
2953
|
set mode(mode) {
|
|
2940
2954
|
this._inputMode.next(mode);
|
|
2941
2955
|
}
|
|
@@ -2944,12 +2958,12 @@ class DbxNavbarComponent extends AbstractTransitionDirective {
|
|
|
2944
2958
|
}
|
|
2945
2959
|
}
|
|
2946
2960
|
DbxNavbarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxNavbarComponent, deps: [{ token: i1$2.DbxRouterTransitionService }, { token: i0.ChangeDetectorRef }, { token: DbxScreenMediaService }, { token: i1$2.DbxRouterService }], target: i0.ɵɵFactoryTarget.Component });
|
|
2947
|
-
DbxNavbarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxNavbarComponent, selector: "dbx-navbar", inputs: { navAlign: "navAlign", icon: "icon", defaultIcon: "defaultIcon", defaultText: "defaultText", anchors: "anchors", mode: "mode", breakpoint: "breakpoint" }, host: { classAttribute: "dbx-navbar" }, usesInheritance: true, ngImport: i0, template: "<ng-container [ngSwitch]=\"mode$ | async\">\n <!-- Button -->\n <ng-container *ngSwitchDefault>\n <dbx-icon-button class=\"nav-menu-button\" aria-label=\"open navigation\" [buttonDisplay]=\"buttonDisplay$ | async\" [matMenuTriggerFor]=\"menu\" [disabled]=\"hasNoAnchors$ | async\"></dbx-icon-button>\n
|
|
2961
|
+
DbxNavbarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxNavbarComponent, selector: "dbx-navbar", inputs: { navAlign: "navAlign", icon: "icon", defaultIcon: "defaultIcon", defaultText: "defaultText", anchors: "anchors", buttonMode: "buttonMode", mode: "mode", breakpoint: "breakpoint" }, host: { classAttribute: "dbx-navbar" }, usesInheritance: true, ngImport: i0, template: "<ng-container [ngSwitch]=\"mode$ | async\">\n <!-- Button -->\n <ng-container *ngSwitchDefault>\n <ng-container [ngSwitch]=\"buttonMode$ | async\">\n <ng-container *ngSwitchCase=\"'menu'\">\n <dbx-icon-button class=\"nav-menu-button\" aria-label=\"open navigation\" [buttonDisplay]=\"buttonDisplay$ | async\" [matMenuTriggerFor]=\"menu\" [disabled]=\"hasNoAnchors$ | async\"></dbx-icon-button>\n <mat-menu #menu>\n <dbx-anchor *ngFor=\"let x of anchors$ | async\" [anchor]=\"x.anchor\">\n <button mat-menu-item [ngClass]=\"x.selected ? 'active' : ''\">\n <mat-icon *ngIf=\"x.anchor.icon\">{{ x.anchor.icon }}</mat-icon>\n {{ x.anchor.title }}\n </button>\n </dbx-anchor>\n </mat-menu>\n </ng-container>\n <ng-container *ngSwitchCase=\"'rotate'\">\n <dbx-anchor [anchor]=\"(nextRotateAnchor$ | async)?.anchor\">\n <dbx-icon-button class=\"nav-menu-button\" aria-label=\"open navigation\" [buttonDisplay]=\"buttonDisplay$ | async\" [disabled]=\"hasNoAnchors$ | async\"></dbx-icon-button>\n </dbx-anchor>\n </ng-container>\n </ng-container>\n </ng-container>\n <!-- Bar -->\n <nav *ngSwitchCase=\"'bar'\" mat-tab-nav-bar [attr.mat-align-tabs]=\"navAlign\">\n <dbx-anchor *ngFor=\"let x of anchors$ | async\" [anchor]=\"x.anchor\">\n <a mat-tab-link [active]=\"x.selected\">{{ x.anchor.title }}</a>\n </dbx-anchor>\n </nav>\n</ng-container>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i1.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "component", type: DbxIconButtonComponent, selector: "dbx-icon-button" }, { kind: "component", type: i5$1.MatTabNav, selector: "[mat-tab-nav-bar]", inputs: ["color"], exportAs: ["matTabNavBar", "matTabNav"] }, { kind: "directive", type: i5$1.MatTabLink, selector: "[mat-tab-link], [matTabLink]", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matTabLink"] }, { kind: "component", type: i2$1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i4$2.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i4$2.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i4$2.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "component", type: DbxAnchorComponent, selector: "dbx-anchor, [dbx-anchor]", inputs: ["block"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
2948
2962
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxNavbarComponent, decorators: [{
|
|
2949
2963
|
type: Component,
|
|
2950
2964
|
args: [{ selector: 'dbx-navbar', changeDetection: ChangeDetectionStrategy.OnPush, host: {
|
|
2951
2965
|
class: 'dbx-navbar'
|
|
2952
|
-
}, template: "<ng-container [ngSwitch]=\"mode$ | async\">\n <!-- Button -->\n <ng-container *ngSwitchDefault>\n <dbx-icon-button class=\"nav-menu-button\" aria-label=\"open navigation\" [buttonDisplay]=\"buttonDisplay$ | async\" [matMenuTriggerFor]=\"menu\" [disabled]=\"hasNoAnchors$ | async\"></dbx-icon-button>\n
|
|
2966
|
+
}, template: "<ng-container [ngSwitch]=\"mode$ | async\">\n <!-- Button -->\n <ng-container *ngSwitchDefault>\n <ng-container [ngSwitch]=\"buttonMode$ | async\">\n <ng-container *ngSwitchCase=\"'menu'\">\n <dbx-icon-button class=\"nav-menu-button\" aria-label=\"open navigation\" [buttonDisplay]=\"buttonDisplay$ | async\" [matMenuTriggerFor]=\"menu\" [disabled]=\"hasNoAnchors$ | async\"></dbx-icon-button>\n <mat-menu #menu>\n <dbx-anchor *ngFor=\"let x of anchors$ | async\" [anchor]=\"x.anchor\">\n <button mat-menu-item [ngClass]=\"x.selected ? 'active' : ''\">\n <mat-icon *ngIf=\"x.anchor.icon\">{{ x.anchor.icon }}</mat-icon>\n {{ x.anchor.title }}\n </button>\n </dbx-anchor>\n </mat-menu>\n </ng-container>\n <ng-container *ngSwitchCase=\"'rotate'\">\n <dbx-anchor [anchor]=\"(nextRotateAnchor$ | async)?.anchor\">\n <dbx-icon-button class=\"nav-menu-button\" aria-label=\"open navigation\" [buttonDisplay]=\"buttonDisplay$ | async\" [disabled]=\"hasNoAnchors$ | async\"></dbx-icon-button>\n </dbx-anchor>\n </ng-container>\n </ng-container>\n </ng-container>\n <!-- Bar -->\n <nav *ngSwitchCase=\"'bar'\" mat-tab-nav-bar [attr.mat-align-tabs]=\"navAlign\">\n <dbx-anchor *ngFor=\"let x of anchors$ | async\" [anchor]=\"x.anchor\">\n <a mat-tab-link [active]=\"x.selected\">{{ x.anchor.title }}</a>\n </dbx-anchor>\n </nav>\n</ng-container>\n" }]
|
|
2953
2967
|
}], ctorParameters: function () { return [{ type: i1$2.DbxRouterTransitionService }, { type: i0.ChangeDetectorRef }, { type: DbxScreenMediaService }, { type: i1$2.DbxRouterService }]; }, propDecorators: { navAlign: [{
|
|
2954
2968
|
type: Input
|
|
2955
2969
|
}], icon: [{
|
|
@@ -2960,6 +2974,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
2960
2974
|
type: Input
|
|
2961
2975
|
}], anchors: [{
|
|
2962
2976
|
type: Input
|
|
2977
|
+
}], buttonMode: [{
|
|
2978
|
+
type: Input
|
|
2963
2979
|
}], mode: [{
|
|
2964
2980
|
type: Input
|
|
2965
2981
|
}], breakpoint: [{
|