@dereekb/dbx-web 9.24.21 → 9.24.22
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 +2 -2
- package/esm2020/mapbox/lib/mapbox.layout.component.mjs +31 -15
- package/esm2020/mapbox/lib/mapbox.layout.drawer.component.mjs +2 -2
- package/fesm2015/dereekb-dbx-web-mapbox.mjs +31 -15
- package/fesm2015/dereekb-dbx-web-mapbox.mjs.map +1 -1
- package/fesm2020/dereekb-dbx-web-mapbox.mjs +31 -15
- package/fesm2020/dereekb-dbx-web-mapbox.mjs.map +1 -1
- package/lib/layout/style/_style.scss +13 -10
- package/lib/layout/text/_text.scss +3 -2
- package/mapbox/esm2020/lib/mapbox.layout.component.mjs +31 -15
- package/mapbox/esm2020/lib/mapbox.layout.drawer.component.mjs +2 -2
- package/mapbox/fesm2015/dereekb-dbx-web-mapbox.mjs +31 -15
- package/mapbox/fesm2015/dereekb-dbx-web-mapbox.mjs.map +1 -1
- package/mapbox/fesm2020/dereekb-dbx-web-mapbox.mjs +31 -15
- package/mapbox/fesm2020/dereekb-dbx-web-mapbox.mjs.map +1 -1
- package/mapbox/lib/mapbox.layout.component.d.ts +11 -4
- package/mapbox/lib/mapbox.layout.drawer.component.d.ts +1 -1
- package/mapbox/package.json +3 -3
- package/package.json +3 -3
- package/table/package.json +3 -3
package/calendar/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@dereekb/dbx-web/calendar",
|
|
3
|
-
"version": "9.24.
|
|
3
|
+
"version": "9.24.22",
|
|
4
4
|
"peerDependencies": {
|
|
5
5
|
"@angular/common": "^14.2.0",
|
|
6
6
|
"@angular/core": "^14.2.0",
|
|
@@ -8,7 +8,7 @@
|
|
|
8
8
|
"rxjs": "^7.5.0",
|
|
9
9
|
"@angular/material": "^14.2.0",
|
|
10
10
|
"angular-calendar": "^0.30.1",
|
|
11
|
-
"@dereekb/dbx-web": "9.24.
|
|
11
|
+
"@dereekb/dbx-web": "9.24.22"
|
|
12
12
|
},
|
|
13
13
|
"dependencies": {
|
|
14
14
|
"tslib": "^2.3.0"
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { tap, switchMap, first, startWith, shareReplay, throttleTime, map, distinctUntilChanged, BehaviorSubject, combineLatest, Subject } from 'rxjs';
|
|
2
|
-
import { Component, ElementRef, Input, ViewChild } from '@angular/core';
|
|
2
|
+
import { Component, ElementRef, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
3
3
|
import { DbxMapboxMapStore } from './mapbox.store';
|
|
4
4
|
import { dbxColorBackground } from '@dereekb/dbx-web';
|
|
5
5
|
import { SubscriptionObject } from '@dereekb/rxjs';
|
|
@@ -23,33 +23,40 @@ export class DbxMapboxLayoutComponent extends SubscriptionObject {
|
|
|
23
23
|
constructor(dbxMapboxMapStore) {
|
|
24
24
|
super();
|
|
25
25
|
this.dbxMapboxMapStore = dbxMapboxMapStore;
|
|
26
|
+
this.openedChange = new EventEmitter();
|
|
26
27
|
this._resized = new Subject();
|
|
27
28
|
this._updateMargins = new Subject();
|
|
28
29
|
this._forceHasContent = new BehaviorSubject(false);
|
|
29
30
|
this._mode = new BehaviorSubject('side');
|
|
30
31
|
this._side = new BehaviorSubject('right');
|
|
31
|
-
this.
|
|
32
|
+
this._isOpen = new BehaviorSubject(true);
|
|
32
33
|
this._color = new BehaviorSubject(undefined);
|
|
33
34
|
this._toggleSub = new SubscriptionObject();
|
|
34
35
|
this.resized$ = this._resized.asObservable();
|
|
35
36
|
this.side$ = this._side.pipe(distinctUntilChanged(), shareReplay(1));
|
|
36
37
|
this.mode$ = this._mode.pipe(distinctUntilChanged(), shareReplay(1));
|
|
37
38
|
this.hasContent$ = combineLatest([this._forceHasContent, this.dbxMapboxMapStore.hasContent$]).pipe(map(([hasContent, forceHasContent]) => hasContent || forceHasContent), distinctUntilChanged(), shareReplay(1));
|
|
38
|
-
this.
|
|
39
|
+
this.isOpen$ = this._isOpen.asObservable();
|
|
40
|
+
this.isOpenAndHasContent$ = combineLatest([this.hasContent$, this._isOpen]).pipe(map(([hasContent, open]) => hasContent && open), distinctUntilChanged(), shareReplay(1));
|
|
39
41
|
this.position$ = this.side$.pipe(map((x) => (x === 'right' ? 'end' : 'start')), distinctUntilChanged(), shareReplay(1));
|
|
40
|
-
this.drawerClasses$ = combineLatest([this.side$, this.dbxMapboxMapStore.hasContent$, this.
|
|
42
|
+
this.drawerClasses$ = combineLatest([this.side$, this.dbxMapboxMapStore.hasContent$, this.isOpenAndHasContent$]).pipe(
|
|
41
43
|
//
|
|
42
44
|
map(([side, hasContent, open]) => (hasContent ? 'has-drawer-content' : 'no-drawer-content') + ` ${side}-drawer ` + (open ? 'open-drawer' : '')), distinctUntilChanged(), shareReplay(1));
|
|
43
45
|
this.drawerButtonClasses$ = combineLatest([this.dbxMapboxMapStore.hasContent$, this._color]).pipe(
|
|
44
46
|
//
|
|
45
47
|
map(([hasContent, color]) => dbxColorBackground(color)), distinctUntilChanged(), shareReplay(1));
|
|
46
|
-
this.buttonIcon$ = combineLatest([this.side$, this.
|
|
48
|
+
this.buttonIcon$ = combineLatest([this.side$, this.isOpenAndHasContent$]).pipe(map(([side, opened]) => {
|
|
47
49
|
let icons = ['chevron_right', 'chevron_left'];
|
|
48
50
|
if (side === 'left') {
|
|
49
51
|
icons = icons.reverse();
|
|
50
52
|
}
|
|
51
53
|
return opened ? icons[0] : icons[1];
|
|
52
54
|
}));
|
|
55
|
+
// MARK: Compat
|
|
56
|
+
/**
|
|
57
|
+
* @deprecated use isOpenAndHasContent$ instead.
|
|
58
|
+
*/
|
|
59
|
+
this.opened$ = this.isOpenAndHasContent$;
|
|
53
60
|
}
|
|
54
61
|
ngOnInit() {
|
|
55
62
|
this.subscription = this.side$.pipe(switchMap(() => this._resized.pipe(throttleTime(100, undefined, { leading: true, trailing: true }), map(() => 'r'), startWith('s')))).subscribe((reason) => {
|
|
@@ -68,7 +75,7 @@ export class DbxMapboxLayoutComponent extends SubscriptionObject {
|
|
|
68
75
|
.pipe(switchMap((mode) => {
|
|
69
76
|
let obs;
|
|
70
77
|
if (mode === 'push') {
|
|
71
|
-
obs = combineLatest([this.
|
|
78
|
+
obs = combineLatest([this.isOpenAndHasContent$.pipe(distinctUntilChanged()), this._updateMargins]).pipe(tap(([opened]) => {
|
|
72
79
|
let { right } = this.drawerContainer._contentMargins;
|
|
73
80
|
this.drawerContainer.updateContentMargins();
|
|
74
81
|
setTimeout(() => {
|
|
@@ -96,7 +103,7 @@ export class DbxMapboxLayoutComponent extends SubscriptionObject {
|
|
|
96
103
|
}));
|
|
97
104
|
}
|
|
98
105
|
else {
|
|
99
|
-
obs = combineLatest([this.
|
|
106
|
+
obs = combineLatest([this.isOpenAndHasContent$.pipe(distinctUntilChanged()), this._updateMargins]).pipe(switchMap((_) => this.dbxMapboxMapStore.mapInstance$), tap((x) => {
|
|
100
107
|
this.drawerContainer.updateContentMargins();
|
|
101
108
|
x.triggerRepaint();
|
|
102
109
|
}));
|
|
@@ -106,19 +113,20 @@ export class DbxMapboxLayoutComponent extends SubscriptionObject {
|
|
|
106
113
|
.subscribe();
|
|
107
114
|
}
|
|
108
115
|
ngOnDestroy() {
|
|
116
|
+
this.openedChange.complete();
|
|
109
117
|
this._resized.complete();
|
|
110
118
|
this._updateMargins.complete();
|
|
111
119
|
this._side.complete();
|
|
112
|
-
this.
|
|
120
|
+
this._isOpen.complete();
|
|
113
121
|
this._color.complete();
|
|
114
122
|
this._toggleSub.destroy();
|
|
115
123
|
this._forceHasContent.complete();
|
|
116
124
|
}
|
|
117
125
|
toggleDrawer(open) {
|
|
118
126
|
if (open == null) {
|
|
119
|
-
open = !this.
|
|
127
|
+
open = !this._isOpen.value;
|
|
120
128
|
}
|
|
121
|
-
this.
|
|
129
|
+
this._isOpen.next(open);
|
|
122
130
|
}
|
|
123
131
|
set side(side) {
|
|
124
132
|
if (side != null) {
|
|
@@ -132,7 +140,7 @@ export class DbxMapboxLayoutComponent extends SubscriptionObject {
|
|
|
132
140
|
}
|
|
133
141
|
set opened(opened) {
|
|
134
142
|
if (opened != null) {
|
|
135
|
-
this.
|
|
143
|
+
this._isOpen.next(opened);
|
|
136
144
|
}
|
|
137
145
|
}
|
|
138
146
|
set hasContent(hasContent) {
|
|
@@ -146,13 +154,21 @@ export class DbxMapboxLayoutComponent extends SubscriptionObject {
|
|
|
146
154
|
onResized(event) {
|
|
147
155
|
this._resized.next(event);
|
|
148
156
|
}
|
|
157
|
+
onOpened(opened) {
|
|
158
|
+
this.openedChange.next(opened);
|
|
159
|
+
if (this._isOpen.value !== opened) {
|
|
160
|
+
this.openedChange.next(opened);
|
|
161
|
+
}
|
|
162
|
+
}
|
|
149
163
|
}
|
|
150
164
|
DbxMapboxLayoutComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxMapboxLayoutComponent, deps: [{ token: i1.DbxMapboxMapStore }], target: i0.ɵɵFactoryTarget.Component });
|
|
151
|
-
DbxMapboxLayoutComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxMapboxLayoutComponent, selector: "dbx-mapbox-layout", inputs: { side: "side", mode: "mode", opened: "opened", hasContent: "hasContent", drawerColor: "drawerColor" }, viewQueries: [{ propertyName: "containerElement", first: true, predicate: MatDrawerContainer, descendants: true, read: ElementRef }, { propertyName: "drawerContainer", first: true, predicate: MatDrawerContainer, descendants: true }, { propertyName: "content", first: true, predicate: ["content"], descendants: true, read: ElementRef, static: true }], usesInheritance: true, ngImport: i0, template: "<mat-drawer-container #containerElement class=\"dbx-mapbox-layout-container\" [ngClass]=\"(drawerClasses$ | async) || ''\" [hasBackdrop]=\"false\">\n <mat-drawer class=\"dbx-mapbox-layout-drawer\" #drawer [opened]=\"
|
|
165
|
+
DbxMapboxLayoutComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxMapboxLayoutComponent, selector: "dbx-mapbox-layout", inputs: { side: "side", mode: "mode", opened: "opened", hasContent: "hasContent", drawerColor: "drawerColor" }, outputs: { openedChange: "openedChange" }, viewQueries: [{ propertyName: "containerElement", first: true, predicate: MatDrawerContainer, descendants: true, read: ElementRef }, { propertyName: "drawerContainer", first: true, predicate: MatDrawerContainer, descendants: true }, { propertyName: "content", first: true, predicate: ["content"], descendants: true, read: ElementRef, static: true }], usesInheritance: true, ngImport: i0, template: "<mat-drawer-container #containerElement class=\"dbx-mapbox-layout-container\" [ngClass]=\"(drawerClasses$ | async) || ''\" [hasBackdrop]=\"false\">\n <mat-drawer class=\"dbx-mapbox-layout-drawer\" #drawer (openedChange)=\"onOpened($event)\" [opened]=\"isOpenAndHasContent$ | async\" [mode]=\"(mode$ | async) || 'side'\" [position]=\"(position$ | async) || 'end'\">\n <div class=\"dbx-mapbox-layout-drawer-content\" [ngClass]=\"(drawerButtonClasses$ | async) || ''\">\n <ng-content select=\"[drawer]\"></ng-content>\n <dbx-mapbox-layout-drawer></dbx-mapbox-layout-drawer>\n </div>\n </mat-drawer>\n <mat-drawer-content #content class=\"dbx-mapbox-layout-content\" (resized)=\"onResized($event)\">\n <button mat-icon-button (click)=\"toggleDrawer()\" class=\"dbx-mapbox-layout-drawer-button\" [ngClass]=\"(drawerButtonClasses$ | async) || ''\">\n <mat-icon>{{ buttonIcon$ | async }}</mat-icon>\n </button>\n <ng-content></ng-content>\n </mat-drawer-content>\n</mat-drawer-container>\n", styles: [".dbx-mapbox-layout-container{height:100%;max-width:100%}.dbx-mapbox-layout-container .mat-drawer-container{height:100%}.dbx-mapbox-layout-container .dbx-mapbox-layout-drawer{max-width:calc(100% - var(--dbx-mapbox-min-width-var, 60px))}.dbx-mapbox-layout-container .dbx-mapbox-layout-drawer-content{height:100%;width:100%;overflow:hidden}.dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button{position:absolute;z-index:2;top:40%;border:none;display:flex;overflow:hidden}.left-drawer .dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button{left:0;border-radius:0 20px 20px 0}.right-drawer .dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button{right:0;border-radius:20px 0 0 20px}.has-drawer-content .dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button{width:35px}.has-drawer-content.open-drawer .dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button{width:35px}.no-drawer-content .dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button{width:0px}.dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button mat-icon{padding-left:8px}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i3.MatDrawer, selector: "mat-drawer", inputs: ["position", "mode", "disableClose", "autoFocus", "opened"], outputs: ["openedChange", "opened", "openedStart", "closed", "closedStart", "positionChanged"], exportAs: ["matDrawer"] }, { kind: "component", type: i3.MatDrawerContainer, selector: "mat-drawer-container", inputs: ["autosize", "hasBackdrop"], outputs: ["backdropClick"], exportAs: ["matDrawerContainer"] }, { kind: "component", type: i3.MatDrawerContent, selector: "mat-drawer-content" }, { kind: "component", type: i4.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i6.ResizedDirective, selector: "[resized]", outputs: ["resized"] }, { kind: "component", type: i7.DbxMapboxLayoutDrawerComponent, selector: "dbx-mapbox-layout-drawer" }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }] });
|
|
152
166
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxMapboxLayoutComponent, decorators: [{
|
|
153
167
|
type: Component,
|
|
154
|
-
args: [{ selector: 'dbx-mapbox-layout', template: "<mat-drawer-container #containerElement class=\"dbx-mapbox-layout-container\" [ngClass]=\"(drawerClasses$ | async) || ''\" [hasBackdrop]=\"false\">\n <mat-drawer class=\"dbx-mapbox-layout-drawer\" #drawer [opened]=\"
|
|
155
|
-
}], ctorParameters: function () { return [{ type: i1.DbxMapboxMapStore }]; }, propDecorators: {
|
|
168
|
+
args: [{ selector: 'dbx-mapbox-layout', template: "<mat-drawer-container #containerElement class=\"dbx-mapbox-layout-container\" [ngClass]=\"(drawerClasses$ | async) || ''\" [hasBackdrop]=\"false\">\n <mat-drawer class=\"dbx-mapbox-layout-drawer\" #drawer (openedChange)=\"onOpened($event)\" [opened]=\"isOpenAndHasContent$ | async\" [mode]=\"(mode$ | async) || 'side'\" [position]=\"(position$ | async) || 'end'\">\n <div class=\"dbx-mapbox-layout-drawer-content\" [ngClass]=\"(drawerButtonClasses$ | async) || ''\">\n <ng-content select=\"[drawer]\"></ng-content>\n <dbx-mapbox-layout-drawer></dbx-mapbox-layout-drawer>\n </div>\n </mat-drawer>\n <mat-drawer-content #content class=\"dbx-mapbox-layout-content\" (resized)=\"onResized($event)\">\n <button mat-icon-button (click)=\"toggleDrawer()\" class=\"dbx-mapbox-layout-drawer-button\" [ngClass]=\"(drawerButtonClasses$ | async) || ''\">\n <mat-icon>{{ buttonIcon$ | async }}</mat-icon>\n </button>\n <ng-content></ng-content>\n </mat-drawer-content>\n</mat-drawer-container>\n", styles: [".dbx-mapbox-layout-container{height:100%;max-width:100%}.dbx-mapbox-layout-container .mat-drawer-container{height:100%}.dbx-mapbox-layout-container .dbx-mapbox-layout-drawer{max-width:calc(100% - var(--dbx-mapbox-min-width-var, 60px))}.dbx-mapbox-layout-container .dbx-mapbox-layout-drawer-content{height:100%;width:100%;overflow:hidden}.dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button{position:absolute;z-index:2;top:40%;border:none;display:flex;overflow:hidden}.left-drawer .dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button{left:0;border-radius:0 20px 20px 0}.right-drawer .dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button{right:0;border-radius:20px 0 0 20px}.has-drawer-content .dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button{width:35px}.has-drawer-content.open-drawer .dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button{width:35px}.no-drawer-content .dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button{width:0px}.dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button mat-icon{padding-left:8px}\n"] }]
|
|
169
|
+
}], ctorParameters: function () { return [{ type: i1.DbxMapboxMapStore }]; }, propDecorators: { openedChange: [{
|
|
170
|
+
type: Output
|
|
171
|
+
}], containerElement: [{
|
|
156
172
|
type: ViewChild,
|
|
157
173
|
args: [MatDrawerContainer, { read: ElementRef }]
|
|
158
174
|
}], drawerContainer: [{
|
|
@@ -172,4 +188,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
172
188
|
}], drawerColor: [{
|
|
173
189
|
type: Input
|
|
174
190
|
}] } });
|
|
175
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mapbox.layout.component.js","sourceRoot":"","sources":["../../../../../../packages/dbx-web/mapbox/src/lib/mapbox.layout.component.ts","../../../../../../packages/dbx-web/mapbox/src/lib/mapbox.layout.component.html"],"names":[],"mappings":"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","sourcesContent":["import { tap, switchMap, first, startWith, shareReplay, throttleTime, map, distinctUntilChanged, BehaviorSubject, combineLatest, Subject, Observable } from 'rxjs';\nimport { Component, ElementRef, Input, OnDestroy, OnInit, ViewChild } from '@angular/core';\nimport { DbxMapboxMapStore } from './mapbox.store';\nimport { Maybe } from '@dereekb/util';\nimport { dbxColorBackground, DbxThemeColor } from '@dereekb/dbx-web';\nimport { ResizedEvent } from 'angular-resize-event';\nimport { SubscriptionObject } from '@dereekb/rxjs';\nimport { MatDrawerContainer } from '@angular/material/sidenav';\nimport { MapboxEaseTo } from './mapbox';\n\nexport type DbxMapboxLayoutSide = 'left' | 'right';\n\nexport type DbxMapboxLayoutMode = 'side' | 'push';\n\n/**\n * Responsive component meant to split a left and right column.\n *\n * The left column is smaller than the right column, which contains the primary content.\n *\n * Requires a TwoColumnsContextStore to be provided.\n */\n@Component({\n  selector: 'dbx-mapbox-layout',\n  templateUrl: './mapbox.layout.component.html',\n  styleUrls: ['./mapbox.layout.component.scss']\n})\nexport class DbxMapboxLayoutComponent extends SubscriptionObject implements OnInit, OnDestroy {\n  @ViewChild(MatDrawerContainer, { read: ElementRef })\n  readonly containerElement!: ElementRef;\n\n  @ViewChild(MatDrawerContainer)\n  readonly drawerContainer!: MatDrawerContainer;\n\n  @ViewChild('content', { read: ElementRef, static: true })\n  readonly content!: ElementRef;\n\n  private _resized = new Subject<ResizedEvent>();\n  private _updateMargins = new Subject<void>();\n  private _forceHasContent = new BehaviorSubject<boolean>(false);\n  private _mode = new BehaviorSubject<DbxMapboxLayoutMode>('side');\n  private _side = new BehaviorSubject<DbxMapboxLayoutSide>('right');\n  private _openToggle = new BehaviorSubject<boolean>(true);\n  private _color = new BehaviorSubject<Maybe<DbxThemeColor>>(undefined);\n  private _toggleSub = new SubscriptionObject();\n\n  readonly resized$ = this._resized.asObservable();\n  readonly side$ = this._side.pipe(distinctUntilChanged(), shareReplay(1));\n  readonly mode$: Observable<DbxMapboxLayoutMode> = this._mode.pipe(distinctUntilChanged(), shareReplay(1));\n\n  readonly hasContent$ = combineLatest([this._forceHasContent, this.dbxMapboxMapStore.hasContent$]).pipe(\n    map(([hasContent, forceHasContent]) => hasContent || forceHasContent),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly opened$ = combineLatest([this.hasContent$, this._openToggle]).pipe(\n    map(([hasContent, open]) => hasContent && open),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly position$: Observable<'start' | 'end'> = this.side$.pipe(\n    map((x) => (x === 'right' ? 'end' : 'start')),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly drawerClasses$ = combineLatest([this.side$, this.dbxMapboxMapStore.hasContent$, this.opened$]).pipe(\n    //\n    map(([side, hasContent, open]) => (hasContent ? 'has-drawer-content' : 'no-drawer-content') + ` ${side}-drawer ` + (open ? 'open-drawer' : '')),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly drawerButtonClasses$ = combineLatest([this.dbxMapboxMapStore.hasContent$, this._color]).pipe(\n    //\n    map(([hasContent, color]) => dbxColorBackground(color)),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly buttonIcon$: Observable<string> = combineLatest([this.side$, this.opened$]).pipe(\n    map(([side, opened]) => {\n      let icons = ['chevron_right', 'chevron_left'];\n\n      if (side === 'left') {\n        icons = icons.reverse();\n      }\n\n      return opened ? icons[0] : icons[1];\n    })\n  );\n\n  constructor(readonly dbxMapboxMapStore: DbxMapboxMapStore) {\n    super();\n  }\n\n  ngOnInit(): void {\n    this.subscription = (\n      this.side$.pipe(\n        switchMap(() =>\n          this._resized.pipe(\n            throttleTime(100, undefined, { leading: true, trailing: true }),\n            map(() => 'r'),\n            startWith('s')\n          )\n        )\n      ) as Observable<'s' | 'r'>\n    ).subscribe((reason) => {\n      this.dbxMapboxMapStore.mapInstance$.subscribe((x) => {\n        x.resize();\n\n        // side changed\n        if (reason === 's') {\n          setTimeout(() => {\n            this._updateMargins.next();\n          });\n        }\n      });\n    });\n\n    let init = false;\n\n    this._toggleSub.subscription = this.mode$\n      .pipe(\n        switchMap((mode) => {\n          let obs: Observable<unknown>;\n\n          if (mode === 'push') {\n            obs = combineLatest([this.opened$.pipe(distinctUntilChanged()), this._updateMargins]).pipe(\n              tap(([opened]) => {\n                let { right } = this.drawerContainer._contentMargins;\n\n                this.drawerContainer.updateContentMargins();\n\n                setTimeout(() => {\n                  const flip = opened ? 1 : -1;\n\n                  if (opened) {\n                    right = this.drawerContainer._contentMargins.right;\n                  }\n\n                  right = (right || 0) * flip;\n\n                  const element: HTMLElement = this.content.nativeElement;\n                  const width = element.clientWidth;\n\n                  const margin = {\n                    leftMargin: 0,\n                    rightMargin: right,\n                    fullWidth: width\n                  };\n\n                  const easeTo: Observable<MapboxEaseTo> = this.dbxMapboxMapStore.calculateNextCenterOffsetWithScreenMarginChange(margin).pipe(\n                    first(),\n                    map((center) => ({ to: { center, duration: 3200, essential: false } } as MapboxEaseTo))\n                  );\n\n                  this.dbxMapboxMapStore.setMargin(opened ? margin : undefined);\n\n                  if (!init) {\n                    this.dbxMapboxMapStore.easeTo(easeTo);\n                  } else {\n                    init = true;\n                  }\n                });\n              })\n            );\n          } else {\n            obs = combineLatest([this.opened$.pipe(distinctUntilChanged()), this._updateMargins]).pipe(\n              switchMap((_) => this.dbxMapboxMapStore.mapInstance$),\n              tap((x) => {\n                this.drawerContainer.updateContentMargins();\n                x.triggerRepaint();\n              })\n            );\n          }\n\n          return obs;\n        })\n      )\n      .subscribe();\n  }\n\n  ngOnDestroy(): void {\n    this._resized.complete();\n    this._updateMargins.complete();\n    this._side.complete();\n    this._openToggle.complete();\n    this._color.complete();\n    this._toggleSub.destroy();\n    this._forceHasContent.complete();\n  }\n\n  toggleDrawer(open?: boolean) {\n    if (open == null) {\n      open = !this._openToggle.value;\n    }\n\n    this._openToggle.next(open);\n  }\n\n  @Input()\n  set side(side: Maybe<DbxMapboxLayoutSide>) {\n    if (side != null) {\n      this._side.next(side);\n    }\n  }\n\n  @Input()\n  set mode(mode: Maybe<DbxMapboxLayoutMode>) {\n    if (mode != null) {\n      this._mode.next(mode);\n    }\n  }\n\n  @Input()\n  set opened(opened: Maybe<boolean>) {\n    if (opened != null) {\n      this._openToggle.next(opened);\n    }\n  }\n\n  @Input()\n  set hasContent(hasContent: Maybe<boolean>) {\n    if (hasContent != null) {\n      this._forceHasContent.next(hasContent);\n    }\n  }\n\n  @Input()\n  set drawerColor(color: Maybe<DbxThemeColor>) {\n    this._color.next(color);\n  }\n\n  onResized(event: ResizedEvent): void {\n    this._resized.next(event);\n  }\n}\n","<mat-drawer-container #containerElement class=\"dbx-mapbox-layout-container\" [ngClass]=\"(drawerClasses$ | async) || ''\" [hasBackdrop]=\"false\">\n  <mat-drawer class=\"dbx-mapbox-layout-drawer\" #drawer [opened]=\"opened$ | async\" [mode]=\"(mode$ | async) || 'side'\" [position]=\"(position$ | async) || 'end'\">\n    <div class=\"dbx-mapbox-layout-drawer-content\" [ngClass]=\"(drawerButtonClasses$ | async) || ''\">\n      <ng-content select=\"[drawer]\"></ng-content>\n      <dbx-mapbox-layout-drawer></dbx-mapbox-layout-drawer>\n    </div>\n  </mat-drawer>\n  <mat-drawer-content #content class=\"dbx-mapbox-layout-content\" (resized)=\"onResized($event)\">\n    <button mat-icon-button (click)=\"toggleDrawer()\" class=\"dbx-mapbox-layout-drawer-button\" [ngClass]=\"(drawerButtonClasses$ | async) || ''\">\n      <mat-icon>{{ buttonIcon$ | async }}</mat-icon>\n    </button>\n    <ng-content></ng-content>\n  </mat-drawer-content>\n</mat-drawer-container>\n"]}
|
|
191
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mapbox.layout.component.js","sourceRoot":"","sources":["../../../../../../packages/dbx-web/mapbox/src/lib/mapbox.layout.component.ts","../../../../../../packages/dbx-web/mapbox/src/lib/mapbox.layout.component.html"],"names":[],"mappings":"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","sourcesContent":["import { tap, switchMap, first, startWith, shareReplay, throttleTime, map, distinctUntilChanged, BehaviorSubject, combineLatest, Subject, Observable } from 'rxjs';\nimport { Component, ElementRef, EventEmitter, Input, OnDestroy, OnInit, Output, ViewChild } from '@angular/core';\nimport { DbxMapboxMapStore } from './mapbox.store';\nimport { Maybe } from '@dereekb/util';\nimport { dbxColorBackground, DbxThemeColor } from '@dereekb/dbx-web';\nimport { ResizedEvent } from 'angular-resize-event';\nimport { SubscriptionObject } from '@dereekb/rxjs';\nimport { MatDrawerContainer } from '@angular/material/sidenav';\nimport { MapboxEaseTo } from './mapbox';\n\nexport type DbxMapboxLayoutSide = 'left' | 'right';\n\nexport type DbxMapboxLayoutMode = 'side' | 'push';\n\n/**\n * Responsive component meant to split a left and right column.\n *\n * The left column is smaller than the right column, which contains the primary content.\n *\n * Requires a TwoColumnsContextStore to be provided.\n */\n@Component({\n  selector: 'dbx-mapbox-layout',\n  templateUrl: './mapbox.layout.component.html',\n  styleUrls: ['./mapbox.layout.component.scss']\n})\nexport class DbxMapboxLayoutComponent extends SubscriptionObject implements OnInit, OnDestroy {\n  @Output()\n  readonly openedChange = new EventEmitter<boolean>();\n\n  @ViewChild(MatDrawerContainer, { read: ElementRef })\n  readonly containerElement!: ElementRef;\n\n  @ViewChild(MatDrawerContainer)\n  readonly drawerContainer!: MatDrawerContainer;\n\n  @ViewChild('content', { read: ElementRef, static: true })\n  readonly content!: ElementRef;\n\n  private _resized = new Subject<ResizedEvent>();\n  private _updateMargins = new Subject<void>();\n  private _forceHasContent = new BehaviorSubject<boolean>(false);\n  private _mode = new BehaviorSubject<DbxMapboxLayoutMode>('side');\n  private _side = new BehaviorSubject<DbxMapboxLayoutSide>('right');\n  private _isOpen = new BehaviorSubject<boolean>(true);\n  private _color = new BehaviorSubject<Maybe<DbxThemeColor>>(undefined);\n  private _toggleSub = new SubscriptionObject();\n\n  readonly resized$ = this._resized.asObservable();\n  readonly side$ = this._side.pipe(distinctUntilChanged(), shareReplay(1));\n  readonly mode$: Observable<DbxMapboxLayoutMode> = this._mode.pipe(distinctUntilChanged(), shareReplay(1));\n\n  readonly hasContent$ = combineLatest([this._forceHasContent, this.dbxMapboxMapStore.hasContent$]).pipe(\n    map(([hasContent, forceHasContent]) => hasContent || forceHasContent),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly isOpen$ = this._isOpen.asObservable();\n\n  readonly isOpenAndHasContent$ = combineLatest([this.hasContent$, this._isOpen]).pipe(\n    map(([hasContent, open]) => hasContent && open),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly position$: Observable<'start' | 'end'> = this.side$.pipe(\n    map((x) => (x === 'right' ? 'end' : 'start')),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly drawerClasses$ = combineLatest([this.side$, this.dbxMapboxMapStore.hasContent$, this.isOpenAndHasContent$]).pipe(\n    //\n    map(([side, hasContent, open]) => (hasContent ? 'has-drawer-content' : 'no-drawer-content') + ` ${side}-drawer ` + (open ? 'open-drawer' : '')),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly drawerButtonClasses$ = combineLatest([this.dbxMapboxMapStore.hasContent$, this._color]).pipe(\n    //\n    map(([hasContent, color]) => dbxColorBackground(color)),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly buttonIcon$: Observable<string> = combineLatest([this.side$, this.isOpenAndHasContent$]).pipe(\n    map(([side, opened]) => {\n      let icons = ['chevron_right', 'chevron_left'];\n\n      if (side === 'left') {\n        icons = icons.reverse();\n      }\n\n      return opened ? icons[0] : icons[1];\n    })\n  );\n\n  constructor(readonly dbxMapboxMapStore: DbxMapboxMapStore) {\n    super();\n  }\n\n  ngOnInit(): void {\n    this.subscription = (\n      this.side$.pipe(\n        switchMap(() =>\n          this._resized.pipe(\n            throttleTime(100, undefined, { leading: true, trailing: true }),\n            map(() => 'r'),\n            startWith('s')\n          )\n        )\n      ) as Observable<'s' | 'r'>\n    ).subscribe((reason) => {\n      this.dbxMapboxMapStore.mapInstance$.subscribe((x) => {\n        x.resize();\n\n        // side changed\n        if (reason === 's') {\n          setTimeout(() => {\n            this._updateMargins.next();\n          });\n        }\n      });\n    });\n\n    let init = false;\n\n    this._toggleSub.subscription = this.mode$\n      .pipe(\n        switchMap((mode) => {\n          let obs: Observable<unknown>;\n\n          if (mode === 'push') {\n            obs = combineLatest([this.isOpenAndHasContent$.pipe(distinctUntilChanged()), this._updateMargins]).pipe(\n              tap(([opened]) => {\n                let { right } = this.drawerContainer._contentMargins;\n\n                this.drawerContainer.updateContentMargins();\n\n                setTimeout(() => {\n                  const flip = opened ? 1 : -1;\n\n                  if (opened) {\n                    right = this.drawerContainer._contentMargins.right;\n                  }\n\n                  right = (right || 0) * flip;\n\n                  const element: HTMLElement = this.content.nativeElement;\n                  const width = element.clientWidth;\n\n                  const margin = {\n                    leftMargin: 0,\n                    rightMargin: right,\n                    fullWidth: width\n                  };\n\n                  const easeTo: Observable<MapboxEaseTo> = this.dbxMapboxMapStore.calculateNextCenterOffsetWithScreenMarginChange(margin).pipe(\n                    first(),\n                    map((center) => ({ to: { center, duration: 3200, essential: false } } as MapboxEaseTo))\n                  );\n\n                  this.dbxMapboxMapStore.setMargin(opened ? margin : undefined);\n\n                  if (!init) {\n                    this.dbxMapboxMapStore.easeTo(easeTo);\n                  } else {\n                    init = true;\n                  }\n                });\n              })\n            );\n          } else {\n            obs = combineLatest([this.isOpenAndHasContent$.pipe(distinctUntilChanged()), this._updateMargins]).pipe(\n              switchMap((_) => this.dbxMapboxMapStore.mapInstance$),\n              tap((x) => {\n                this.drawerContainer.updateContentMargins();\n                x.triggerRepaint();\n              })\n            );\n          }\n\n          return obs;\n        })\n      )\n      .subscribe();\n  }\n\n  ngOnDestroy(): void {\n    this.openedChange.complete();\n    this._resized.complete();\n    this._updateMargins.complete();\n    this._side.complete();\n    this._isOpen.complete();\n    this._color.complete();\n    this._toggleSub.destroy();\n    this._forceHasContent.complete();\n  }\n\n  toggleDrawer(open?: boolean) {\n    if (open == null) {\n      open = !this._isOpen.value;\n    }\n\n    this._isOpen.next(open);\n  }\n\n  @Input()\n  set side(side: Maybe<DbxMapboxLayoutSide>) {\n    if (side != null) {\n      this._side.next(side);\n    }\n  }\n\n  @Input()\n  set mode(mode: Maybe<DbxMapboxLayoutMode>) {\n    if (mode != null) {\n      this._mode.next(mode);\n    }\n  }\n\n  @Input()\n  set opened(opened: Maybe<boolean>) {\n    if (opened != null) {\n      this._isOpen.next(opened);\n    }\n  }\n\n  @Input()\n  set hasContent(hasContent: Maybe<boolean>) {\n    if (hasContent != null) {\n      this._forceHasContent.next(hasContent);\n    }\n  }\n\n  @Input()\n  set drawerColor(color: Maybe<DbxThemeColor>) {\n    this._color.next(color);\n  }\n\n  onResized(event: ResizedEvent): void {\n    this._resized.next(event);\n  }\n\n  onOpened(opened: boolean) {\n    this.openedChange.next(opened);\n\n    if (this._isOpen.value !== opened) {\n      this.openedChange.next(opened);\n    }\n  }\n\n  // MARK: Compat\n  /**\n   * @deprecated use isOpenAndHasContent$ instead.\n   */\n  readonly opened$ = this.isOpenAndHasContent$;\n}\n","<mat-drawer-container #containerElement class=\"dbx-mapbox-layout-container\" [ngClass]=\"(drawerClasses$ | async) || ''\" [hasBackdrop]=\"false\">\n  <mat-drawer class=\"dbx-mapbox-layout-drawer\" #drawer (openedChange)=\"onOpened($event)\" [opened]=\"isOpenAndHasContent$ | async\" [mode]=\"(mode$ | async) || 'side'\" [position]=\"(position$ | async) || 'end'\">\n    <div class=\"dbx-mapbox-layout-drawer-content\" [ngClass]=\"(drawerButtonClasses$ | async) || ''\">\n      <ng-content select=\"[drawer]\"></ng-content>\n      <dbx-mapbox-layout-drawer></dbx-mapbox-layout-drawer>\n    </div>\n  </mat-drawer>\n  <mat-drawer-content #content class=\"dbx-mapbox-layout-content\" (resized)=\"onResized($event)\">\n    <button mat-icon-button (click)=\"toggleDrawer()\" class=\"dbx-mapbox-layout-drawer-button\" [ngClass]=\"(drawerButtonClasses$ | async) || ''\">\n      <mat-icon>{{ buttonIcon$ | async }}</mat-icon>\n    </button>\n    <ng-content></ng-content>\n  </mat-drawer-content>\n</mat-drawer-container>\n"]}
|
|
@@ -5,7 +5,7 @@ import * as i1 from "./mapbox.store";
|
|
|
5
5
|
import * as i2 from "@dereekb/dbx-core";
|
|
6
6
|
import * as i3 from "@angular/common";
|
|
7
7
|
/**
|
|
8
|
-
* Content drawer that connects with DbxMapboxMapStore to
|
|
8
|
+
* Content drawer that connects with DbxMapboxMapStore to show the content.
|
|
9
9
|
*/
|
|
10
10
|
export class DbxMapboxLayoutDrawerComponent {
|
|
11
11
|
constructor(dbxMapboxMapStore) {
|
|
@@ -21,4 +21,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
21
21
|
class: 'dbx-mapbox-layout-drawer'
|
|
22
22
|
}, template: "<div>\n <dbx-injection [config]=\"config$ | async\"></dbx-injection>\n</div>\n" }]
|
|
23
23
|
}], ctorParameters: function () { return [{ type: i1.DbxMapboxMapStore }]; } });
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwYm94LmxheW91dC5kcmF3ZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9tYXBib3gvc3JjL2xpYi9tYXBib3gubGF5b3V0LmRyYXdlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL21hcGJveC9zcmMvbGliL21hcGJveC5sYXlvdXQuZHJhd2VyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7Ozs7O0FBRW5EOztHQUVHO0FBUUgsTUFBTSxPQUFPLDhCQUE4QjtJQUd6QyxZQUFxQixpQkFBb0M7UUFBcEMsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFtQjtRQUZoRCxZQUFPLEdBQUcsSUFBSSxDQUFDLGlCQUFpQixDQUFDLFFBQVEsQ0FBQztJQUVTLENBQUM7OzRIQUhsRCw4QkFBOEI7Z0hBQTlCLDhCQUE4QixzSENiM0MsaUZBR0E7NEZEVWEsOEJBQThCO2tCQVAxQyxTQUFTOytCQUNFLDBCQUEwQixRQUU5Qjt3QkFDSixLQUFLLEVBQUUsMEJBQTBCO3FCQUNsQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRGJ4TWFwYm94TWFwU3RvcmUgfSBmcm9tICcuL21hcGJveC5zdG9yZSc7XG5cbi8qKlxuICogQ29udGVudCBkcmF3ZXIgdGhhdCBjb25uZWN0cyB3aXRoIERieE1hcGJveE1hcFN0b3JlIHRvIHNob3cgdGhlIGNvbnRlbnQuXG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2RieC1tYXBib3gtbGF5b3V0LWRyYXdlcicsXG4gIHRlbXBsYXRlVXJsOiAnLi9tYXBib3gubGF5b3V0LmRyYXdlci5jb21wb25lbnQuaHRtbCcsXG4gIGhvc3Q6IHtcbiAgICBjbGFzczogJ2RieC1tYXBib3gtbGF5b3V0LWRyYXdlcidcbiAgfVxufSlcbmV4cG9ydCBjbGFzcyBEYnhNYXBib3hMYXlvdXREcmF3ZXJDb21wb25lbnQge1xuICByZWFkb25seSBjb25maWckID0gdGhpcy5kYnhNYXBib3hNYXBTdG9yZS5jb250ZW50JDtcblxuICBjb25zdHJ1Y3RvcihyZWFkb25seSBkYnhNYXBib3hNYXBTdG9yZTogRGJ4TWFwYm94TWFwU3RvcmUpIHt9XG59XG4iLCI8ZGl2PlxuICA8ZGJ4LWluamVjdGlvbiBbY29uZmlnXT1cImNvbmZpZyQgfCBhc3luY1wiPjwvZGJ4LWluamVjdGlvbj5cbjwvZGl2PlxuIl19
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { Injectable, Host, Optional, Inject, Component, ChangeDetectionStrategy, SkipSelf, Directive, Injector, ElementRef, ViewChild, Input, NgModule } from '@angular/core';
|
|
2
|
+
import { Injectable, Host, Optional, Inject, Component, ChangeDetectionStrategy, SkipSelf, Directive, Injector, EventEmitter, ElementRef, Output, ViewChild, Input, NgModule } from '@angular/core';
|
|
3
3
|
import * as i2 from '@dereekb/dbx-core';
|
|
4
4
|
import { safeMarkForCheck, safeDetectChanges, AbstractSubscriptionDirective, DbxInjectionComponentModule } from '@dereekb/dbx-core';
|
|
5
5
|
import { asObservable, cleanup, filterMaybe, onTrueToFalse, SubscriptionObject, distinctUntilMapHasDifferentKeys } from '@dereekb/rxjs';
|
|
@@ -828,7 +828,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
828
828
|
} });
|
|
829
829
|
|
|
830
830
|
/**
|
|
831
|
-
* Content drawer that connects with DbxMapboxMapStore to
|
|
831
|
+
* Content drawer that connects with DbxMapboxMapStore to show the content.
|
|
832
832
|
*/
|
|
833
833
|
class DbxMapboxLayoutDrawerComponent {
|
|
834
834
|
constructor(dbxMapboxMapStore) {
|
|
@@ -856,33 +856,40 @@ class DbxMapboxLayoutComponent extends SubscriptionObject {
|
|
|
856
856
|
constructor(dbxMapboxMapStore) {
|
|
857
857
|
super();
|
|
858
858
|
this.dbxMapboxMapStore = dbxMapboxMapStore;
|
|
859
|
+
this.openedChange = new EventEmitter();
|
|
859
860
|
this._resized = new Subject();
|
|
860
861
|
this._updateMargins = new Subject();
|
|
861
862
|
this._forceHasContent = new BehaviorSubject(false);
|
|
862
863
|
this._mode = new BehaviorSubject('side');
|
|
863
864
|
this._side = new BehaviorSubject('right');
|
|
864
|
-
this.
|
|
865
|
+
this._isOpen = new BehaviorSubject(true);
|
|
865
866
|
this._color = new BehaviorSubject(undefined);
|
|
866
867
|
this._toggleSub = new SubscriptionObject();
|
|
867
868
|
this.resized$ = this._resized.asObservable();
|
|
868
869
|
this.side$ = this._side.pipe(distinctUntilChanged(), shareReplay(1));
|
|
869
870
|
this.mode$ = this._mode.pipe(distinctUntilChanged(), shareReplay(1));
|
|
870
871
|
this.hasContent$ = combineLatest([this._forceHasContent, this.dbxMapboxMapStore.hasContent$]).pipe(map(([hasContent, forceHasContent]) => hasContent || forceHasContent), distinctUntilChanged(), shareReplay(1));
|
|
871
|
-
this.
|
|
872
|
+
this.isOpen$ = this._isOpen.asObservable();
|
|
873
|
+
this.isOpenAndHasContent$ = combineLatest([this.hasContent$, this._isOpen]).pipe(map(([hasContent, open]) => hasContent && open), distinctUntilChanged(), shareReplay(1));
|
|
872
874
|
this.position$ = this.side$.pipe(map((x) => (x === 'right' ? 'end' : 'start')), distinctUntilChanged(), shareReplay(1));
|
|
873
|
-
this.drawerClasses$ = combineLatest([this.side$, this.dbxMapboxMapStore.hasContent$, this.
|
|
875
|
+
this.drawerClasses$ = combineLatest([this.side$, this.dbxMapboxMapStore.hasContent$, this.isOpenAndHasContent$]).pipe(
|
|
874
876
|
//
|
|
875
877
|
map(([side, hasContent, open]) => (hasContent ? 'has-drawer-content' : 'no-drawer-content') + ` ${side}-drawer ` + (open ? 'open-drawer' : '')), distinctUntilChanged(), shareReplay(1));
|
|
876
878
|
this.drawerButtonClasses$ = combineLatest([this.dbxMapboxMapStore.hasContent$, this._color]).pipe(
|
|
877
879
|
//
|
|
878
880
|
map(([hasContent, color]) => dbxColorBackground(color)), distinctUntilChanged(), shareReplay(1));
|
|
879
|
-
this.buttonIcon$ = combineLatest([this.side$, this.
|
|
881
|
+
this.buttonIcon$ = combineLatest([this.side$, this.isOpenAndHasContent$]).pipe(map(([side, opened]) => {
|
|
880
882
|
let icons = ['chevron_right', 'chevron_left'];
|
|
881
883
|
if (side === 'left') {
|
|
882
884
|
icons = icons.reverse();
|
|
883
885
|
}
|
|
884
886
|
return opened ? icons[0] : icons[1];
|
|
885
887
|
}));
|
|
888
|
+
// MARK: Compat
|
|
889
|
+
/**
|
|
890
|
+
* @deprecated use isOpenAndHasContent$ instead.
|
|
891
|
+
*/
|
|
892
|
+
this.opened$ = this.isOpenAndHasContent$;
|
|
886
893
|
}
|
|
887
894
|
ngOnInit() {
|
|
888
895
|
this.subscription = this.side$.pipe(switchMap(() => this._resized.pipe(throttleTime(100, undefined, { leading: true, trailing: true }), map(() => 'r'), startWith('s')))).subscribe((reason) => {
|
|
@@ -901,7 +908,7 @@ class DbxMapboxLayoutComponent extends SubscriptionObject {
|
|
|
901
908
|
.pipe(switchMap((mode) => {
|
|
902
909
|
let obs;
|
|
903
910
|
if (mode === 'push') {
|
|
904
|
-
obs = combineLatest([this.
|
|
911
|
+
obs = combineLatest([this.isOpenAndHasContent$.pipe(distinctUntilChanged()), this._updateMargins]).pipe(tap(([opened]) => {
|
|
905
912
|
let { right } = this.drawerContainer._contentMargins;
|
|
906
913
|
this.drawerContainer.updateContentMargins();
|
|
907
914
|
setTimeout(() => {
|
|
@@ -929,7 +936,7 @@ class DbxMapboxLayoutComponent extends SubscriptionObject {
|
|
|
929
936
|
}));
|
|
930
937
|
}
|
|
931
938
|
else {
|
|
932
|
-
obs = combineLatest([this.
|
|
939
|
+
obs = combineLatest([this.isOpenAndHasContent$.pipe(distinctUntilChanged()), this._updateMargins]).pipe(switchMap((_) => this.dbxMapboxMapStore.mapInstance$), tap((x) => {
|
|
933
940
|
this.drawerContainer.updateContentMargins();
|
|
934
941
|
x.triggerRepaint();
|
|
935
942
|
}));
|
|
@@ -939,19 +946,20 @@ class DbxMapboxLayoutComponent extends SubscriptionObject {
|
|
|
939
946
|
.subscribe();
|
|
940
947
|
}
|
|
941
948
|
ngOnDestroy() {
|
|
949
|
+
this.openedChange.complete();
|
|
942
950
|
this._resized.complete();
|
|
943
951
|
this._updateMargins.complete();
|
|
944
952
|
this._side.complete();
|
|
945
|
-
this.
|
|
953
|
+
this._isOpen.complete();
|
|
946
954
|
this._color.complete();
|
|
947
955
|
this._toggleSub.destroy();
|
|
948
956
|
this._forceHasContent.complete();
|
|
949
957
|
}
|
|
950
958
|
toggleDrawer(open) {
|
|
951
959
|
if (open == null) {
|
|
952
|
-
open = !this.
|
|
960
|
+
open = !this._isOpen.value;
|
|
953
961
|
}
|
|
954
|
-
this.
|
|
962
|
+
this._isOpen.next(open);
|
|
955
963
|
}
|
|
956
964
|
set side(side) {
|
|
957
965
|
if (side != null) {
|
|
@@ -965,7 +973,7 @@ class DbxMapboxLayoutComponent extends SubscriptionObject {
|
|
|
965
973
|
}
|
|
966
974
|
set opened(opened) {
|
|
967
975
|
if (opened != null) {
|
|
968
|
-
this.
|
|
976
|
+
this._isOpen.next(opened);
|
|
969
977
|
}
|
|
970
978
|
}
|
|
971
979
|
set hasContent(hasContent) {
|
|
@@ -979,13 +987,21 @@ class DbxMapboxLayoutComponent extends SubscriptionObject {
|
|
|
979
987
|
onResized(event) {
|
|
980
988
|
this._resized.next(event);
|
|
981
989
|
}
|
|
990
|
+
onOpened(opened) {
|
|
991
|
+
this.openedChange.next(opened);
|
|
992
|
+
if (this._isOpen.value !== opened) {
|
|
993
|
+
this.openedChange.next(opened);
|
|
994
|
+
}
|
|
995
|
+
}
|
|
982
996
|
}
|
|
983
997
|
DbxMapboxLayoutComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxMapboxLayoutComponent, deps: [{ token: DbxMapboxMapStore }], target: i0.ɵɵFactoryTarget.Component });
|
|
984
|
-
DbxMapboxLayoutComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxMapboxLayoutComponent, selector: "dbx-mapbox-layout", inputs: { side: "side", mode: "mode", opened: "opened", hasContent: "hasContent", drawerColor: "drawerColor" }, viewQueries: [{ propertyName: "containerElement", first: true, predicate: MatDrawerContainer, descendants: true, read: ElementRef }, { propertyName: "drawerContainer", first: true, predicate: MatDrawerContainer, descendants: true }, { propertyName: "content", first: true, predicate: ["content"], descendants: true, read: ElementRef, static: true }], usesInheritance: true, ngImport: i0, template: "<mat-drawer-container #containerElement class=\"dbx-mapbox-layout-container\" [ngClass]=\"(drawerClasses$ | async) || ''\" [hasBackdrop]=\"false\">\n <mat-drawer class=\"dbx-mapbox-layout-drawer\" #drawer [opened]=\"
|
|
998
|
+
DbxMapboxLayoutComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxMapboxLayoutComponent, selector: "dbx-mapbox-layout", inputs: { side: "side", mode: "mode", opened: "opened", hasContent: "hasContent", drawerColor: "drawerColor" }, outputs: { openedChange: "openedChange" }, viewQueries: [{ propertyName: "containerElement", first: true, predicate: MatDrawerContainer, descendants: true, read: ElementRef }, { propertyName: "drawerContainer", first: true, predicate: MatDrawerContainer, descendants: true }, { propertyName: "content", first: true, predicate: ["content"], descendants: true, read: ElementRef, static: true }], usesInheritance: true, ngImport: i0, template: "<mat-drawer-container #containerElement class=\"dbx-mapbox-layout-container\" [ngClass]=\"(drawerClasses$ | async) || ''\" [hasBackdrop]=\"false\">\n <mat-drawer class=\"dbx-mapbox-layout-drawer\" #drawer (openedChange)=\"onOpened($event)\" [opened]=\"isOpenAndHasContent$ | async\" [mode]=\"(mode$ | async) || 'side'\" [position]=\"(position$ | async) || 'end'\">\n <div class=\"dbx-mapbox-layout-drawer-content\" [ngClass]=\"(drawerButtonClasses$ | async) || ''\">\n <ng-content select=\"[drawer]\"></ng-content>\n <dbx-mapbox-layout-drawer></dbx-mapbox-layout-drawer>\n </div>\n </mat-drawer>\n <mat-drawer-content #content class=\"dbx-mapbox-layout-content\" (resized)=\"onResized($event)\">\n <button mat-icon-button (click)=\"toggleDrawer()\" class=\"dbx-mapbox-layout-drawer-button\" [ngClass]=\"(drawerButtonClasses$ | async) || ''\">\n <mat-icon>{{ buttonIcon$ | async }}</mat-icon>\n </button>\n <ng-content></ng-content>\n </mat-drawer-content>\n</mat-drawer-container>\n", styles: [".dbx-mapbox-layout-container{height:100%;max-width:100%}.dbx-mapbox-layout-container .mat-drawer-container{height:100%}.dbx-mapbox-layout-container .dbx-mapbox-layout-drawer{max-width:calc(100% - var(--dbx-mapbox-min-width-var, 60px))}.dbx-mapbox-layout-container .dbx-mapbox-layout-drawer-content{height:100%;width:100%;overflow:hidden}.dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button{position:absolute;z-index:2;top:40%;border:none;display:flex;overflow:hidden}.left-drawer .dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button{left:0;border-radius:0 20px 20px 0}.right-drawer .dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button{right:0;border-radius:20px 0 0 20px}.has-drawer-content .dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button{width:35px}.has-drawer-content.open-drawer .dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button{width:35px}.no-drawer-content .dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button{width:0px}.dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button mat-icon{padding-left:8px}\n"], dependencies: [{ kind: "directive", type: i2$1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i3.MatDrawer, selector: "mat-drawer", inputs: ["position", "mode", "disableClose", "autoFocus", "opened"], outputs: ["openedChange", "opened", "openedStart", "closed", "closedStart", "positionChanged"], exportAs: ["matDrawer"] }, { kind: "component", type: i3.MatDrawerContainer, selector: "mat-drawer-container", inputs: ["autosize", "hasBackdrop"], outputs: ["backdropClick"], exportAs: ["matDrawerContainer"] }, { kind: "component", type: i3.MatDrawerContent, selector: "mat-drawer-content" }, { kind: "component", type: i4.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i6.ResizedDirective, selector: "[resized]", outputs: ["resized"] }, { kind: "component", type: DbxMapboxLayoutDrawerComponent, selector: "dbx-mapbox-layout-drawer" }, { kind: "pipe", type: i2$1.AsyncPipe, name: "async" }] });
|
|
985
999
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxMapboxLayoutComponent, decorators: [{
|
|
986
1000
|
type: Component,
|
|
987
|
-
args: [{ selector: 'dbx-mapbox-layout', template: "<mat-drawer-container #containerElement class=\"dbx-mapbox-layout-container\" [ngClass]=\"(drawerClasses$ | async) || ''\" [hasBackdrop]=\"false\">\n <mat-drawer class=\"dbx-mapbox-layout-drawer\" #drawer [opened]=\"
|
|
988
|
-
}], ctorParameters: function () { return [{ type: DbxMapboxMapStore }]; }, propDecorators: {
|
|
1001
|
+
args: [{ selector: 'dbx-mapbox-layout', template: "<mat-drawer-container #containerElement class=\"dbx-mapbox-layout-container\" [ngClass]=\"(drawerClasses$ | async) || ''\" [hasBackdrop]=\"false\">\n <mat-drawer class=\"dbx-mapbox-layout-drawer\" #drawer (openedChange)=\"onOpened($event)\" [opened]=\"isOpenAndHasContent$ | async\" [mode]=\"(mode$ | async) || 'side'\" [position]=\"(position$ | async) || 'end'\">\n <div class=\"dbx-mapbox-layout-drawer-content\" [ngClass]=\"(drawerButtonClasses$ | async) || ''\">\n <ng-content select=\"[drawer]\"></ng-content>\n <dbx-mapbox-layout-drawer></dbx-mapbox-layout-drawer>\n </div>\n </mat-drawer>\n <mat-drawer-content #content class=\"dbx-mapbox-layout-content\" (resized)=\"onResized($event)\">\n <button mat-icon-button (click)=\"toggleDrawer()\" class=\"dbx-mapbox-layout-drawer-button\" [ngClass]=\"(drawerButtonClasses$ | async) || ''\">\n <mat-icon>{{ buttonIcon$ | async }}</mat-icon>\n </button>\n <ng-content></ng-content>\n </mat-drawer-content>\n</mat-drawer-container>\n", styles: [".dbx-mapbox-layout-container{height:100%;max-width:100%}.dbx-mapbox-layout-container .mat-drawer-container{height:100%}.dbx-mapbox-layout-container .dbx-mapbox-layout-drawer{max-width:calc(100% - var(--dbx-mapbox-min-width-var, 60px))}.dbx-mapbox-layout-container .dbx-mapbox-layout-drawer-content{height:100%;width:100%;overflow:hidden}.dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button{position:absolute;z-index:2;top:40%;border:none;display:flex;overflow:hidden}.left-drawer .dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button{left:0;border-radius:0 20px 20px 0}.right-drawer .dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button{right:0;border-radius:20px 0 0 20px}.has-drawer-content .dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button{width:35px}.has-drawer-content.open-drawer .dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button{width:35px}.no-drawer-content .dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button{width:0px}.dbx-mapbox-layout-content>.dbx-mapbox-layout-drawer-button mat-icon{padding-left:8px}\n"] }]
|
|
1002
|
+
}], ctorParameters: function () { return [{ type: DbxMapboxMapStore }]; }, propDecorators: { openedChange: [{
|
|
1003
|
+
type: Output
|
|
1004
|
+
}], containerElement: [{
|
|
989
1005
|
type: ViewChild,
|
|
990
1006
|
args: [MatDrawerContainer, { read: ElementRef }]
|
|
991
1007
|
}], drawerContainer: [{
|