@dereekb/dbx-web 9.3.3 → 9.5.1

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.
Files changed (51) hide show
  1. package/esm2020/lib/extension/calendar/calendar.component.mjs +2 -2
  2. package/esm2020/lib/extension/calendar/calendar.store.mjs +2 -2
  3. package/esm2020/lib/index.mjs +2 -1
  4. package/esm2020/lib/layout/bar/bar.mjs +1 -1
  5. package/esm2020/lib/layout/column/two/two.column.right.component.mjs +5 -3
  6. package/esm2020/lib/layout/style/index.mjs +2 -1
  7. package/esm2020/lib/layout/style/style.mjs +16 -0
  8. package/esm2020/lib/util/cdk.mjs +22 -0
  9. package/esm2020/lib/util/index.mjs +2 -0
  10. package/esm2020/mapbox/lib/index.mjs +4 -1
  11. package/esm2020/mapbox/lib/mapbox.layout.component.mjs +132 -0
  12. package/esm2020/mapbox/lib/mapbox.layout.drawer.component.mjs +24 -0
  13. package/esm2020/mapbox/lib/mapbox.menu.component.mjs +99 -0
  14. package/esm2020/mapbox/lib/mapbox.mjs +1 -1
  15. package/esm2020/mapbox/lib/mapbox.module.mjs +53 -6
  16. package/esm2020/mapbox/lib/mapbox.store.mjs +46 -6
  17. package/fesm2015/dereekb-dbx-web-mapbox.mjs +336 -14
  18. package/fesm2015/dereekb-dbx-web-mapbox.mjs.map +1 -1
  19. package/fesm2015/dereekb-dbx-web.mjs +60 -21
  20. package/fesm2015/dereekb-dbx-web.mjs.map +1 -1
  21. package/fesm2020/dereekb-dbx-web-mapbox.mjs +330 -14
  22. package/fesm2020/dereekb-dbx-web-mapbox.mjs.map +1 -1
  23. package/fesm2020/dereekb-dbx-web.mjs +60 -21
  24. package/fesm2020/dereekb-dbx-web.mjs.map +1 -1
  25. package/lib/index.d.ts +1 -0
  26. package/lib/layout/bar/bar.d.ts +2 -1
  27. package/lib/layout/column/two/two.column.right.component.d.ts +2 -1
  28. package/lib/layout/style/_style.scss +11 -0
  29. package/lib/layout/style/index.d.ts +1 -0
  30. package/lib/layout/style/style.d.ts +3 -0
  31. package/lib/util/cdk.d.ts +9 -0
  32. package/lib/util/index.d.ts +1 -0
  33. package/mapbox/esm2020/lib/index.mjs +4 -1
  34. package/mapbox/esm2020/lib/mapbox.layout.component.mjs +132 -0
  35. package/mapbox/esm2020/lib/mapbox.layout.drawer.component.mjs +24 -0
  36. package/mapbox/esm2020/lib/mapbox.menu.component.mjs +99 -0
  37. package/mapbox/esm2020/lib/mapbox.mjs +1 -1
  38. package/mapbox/esm2020/lib/mapbox.module.mjs +53 -6
  39. package/mapbox/esm2020/lib/mapbox.store.mjs +46 -6
  40. package/mapbox/fesm2015/dereekb-dbx-web-mapbox.mjs +336 -14
  41. package/mapbox/fesm2015/dereekb-dbx-web-mapbox.mjs.map +1 -1
  42. package/mapbox/fesm2020/dereekb-dbx-web-mapbox.mjs +330 -14
  43. package/mapbox/fesm2020/dereekb-dbx-web-mapbox.mjs.map +1 -1
  44. package/mapbox/lib/index.d.ts +3 -0
  45. package/mapbox/lib/mapbox.layout.component.d.ts +44 -0
  46. package/mapbox/lib/mapbox.layout.drawer.component.d.ts +12 -0
  47. package/mapbox/lib/mapbox.menu.component.d.ts +31 -0
  48. package/mapbox/lib/mapbox.module.d.ts +10 -2
  49. package/mapbox/lib/mapbox.store.d.ts +29 -0
  50. package/mapbox/package.json +5 -5
  51. package/package.json +3 -3
package/lib/index.d.ts CHANGED
@@ -8,4 +8,5 @@ export * from './loading';
8
8
  export * from './layout';
9
9
  export * from './router';
10
10
  export * from './screen';
11
+ export * from './util';
11
12
  export * from './dbx-web.module';
@@ -1 +1,2 @@
1
- export declare type DbxBarColor = 'primary' | 'accent' | 'warn' | 'background';
1
+ import { DbxThemeColor } from '../style/style';
2
+ export declare type DbxBarColor = DbxThemeColor;
@@ -12,6 +12,7 @@ import * as i0 from "@angular/core";
12
12
  export declare class DbxTwoColumnRightComponent implements AfterViewInit, OnDestroy {
13
13
  private readonly twoColumnsContextStore;
14
14
  header?: string;
15
+ block?: boolean;
15
16
  private _showBack;
16
17
  readonly ref$: Observable<Maybe<ClickableAnchor>>;
17
18
  readonly showBack$: Observable<boolean>;
@@ -26,5 +27,5 @@ export declare class DbxTwoColumnRightComponent implements AfterViewInit, OnDest
26
27
  set minRightWidth(minRightWidth: Maybe<number | ''>);
27
28
  backClicked(): void;
28
29
  static ɵfac: i0.ɵɵFactoryDeclaration<DbxTwoColumnRightComponent, never>;
29
- static ɵcmp: i0.ɵɵComponentDeclaration<DbxTwoColumnRightComponent, "dbx-two-column-right", never, { "header": "header"; "showBack": "showBack"; "minRightWidth": "minRightWidth"; }, {}, never, ["[nav]", "*"], false>;
30
+ static ɵcmp: i0.ɵɵComponentDeclaration<DbxTwoColumnRightComponent, "dbx-two-column-right", never, { "header": "header"; "block": "block"; "showBack": "showBack"; "minRightWidth": "minRightWidth"; }, {}, never, ["[nav]", "*"], false>;
30
31
  }
@@ -60,6 +60,8 @@
60
60
  $primary: map.get($color-config, 'primary');
61
61
  $accent: map.get($color-config, 'accent');
62
62
  $warn: map.get($color-config, 'warn');
63
+ $background: map.get($color-config, 'background');
64
+ $foreground: map.get($color-config, 'foreground');
63
65
 
64
66
  $primary-color: theming.get-color-from-palette($primary, 500);
65
67
  $primary-color-contrast: theming.get-color-from-palette($primary, '500-contrast');
@@ -70,6 +72,9 @@
70
72
  $warn-color: theming.get-color-from-palette($warn, 500);
71
73
  $warn-color-contrast: theming.get-color-from-palette($warn, '500-contrast');
72
74
 
75
+ $background-text-color: theming.get-color-from-palette($foreground, 'text');
76
+ $background-color: theming.get-color-from-palette($background, 'background');
77
+
73
78
  .dbx-primary {
74
79
  color: $primary-color;
75
80
  }
@@ -96,6 +101,12 @@
96
101
  background: $warn-color;
97
102
  color: $warn-color-contrast;
98
103
  }
104
+
105
+ .dbx-bg,
106
+ .dbx-background {
107
+ color: $background-text-color;
108
+ background: $background-color;
109
+ }
99
110
  }
100
111
 
101
112
  @mixin typography($typography-config) {
@@ -1,3 +1,4 @@
1
+ export * from './style';
1
2
  export * from './style.layout.module';
2
3
  export * from './spacer.directive';
3
4
  export * from './style.directive';
@@ -0,0 +1,3 @@
1
+ import { Maybe } from '@dereekb/util';
2
+ export declare type DbxThemeColor = 'primary' | 'accent' | 'warn' | 'background';
3
+ export declare function dbxColorBackground(color: Maybe<DbxThemeColor>): string;
@@ -0,0 +1,9 @@
1
+ import { DestroyFunction } from '@dereekb/util';
2
+ /**
3
+ * Disables the "contextmenu" from popping up in the cdk-overlay-container.
4
+ *
5
+ * @param classes
6
+ * @param onEvent
7
+ * @returns
8
+ */
9
+ export declare function disableRightClickInCdkBackdrop(classes?: string, onEvent?: (event: MouseEvent) => void): DestroyFunction;
@@ -0,0 +1 @@
1
+ export * from './cdk';
@@ -1,7 +1,10 @@
1
1
  export * from './mapbox.module';
2
+ export * from './mapbox.layout.component';
3
+ export * from './mapbox.layout.drawer.component';
4
+ export * from './mapbox.menu.component';
2
5
  export * from './mapbox.service';
3
6
  export * from './mapbox.store.map.directive';
4
7
  export * from './mapbox.store';
5
8
  export * from './mapbox';
6
9
  export * from './options';
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL21hcGJveC9zcmMvbGliL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxXQUFXLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL21hcGJveC5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9tYXBib3guc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL21hcGJveC5zdG9yZS5tYXAuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbWFwYm94LnN0b3JlJztcbmV4cG9ydCAqIGZyb20gJy4vbWFwYm94JztcbmV4cG9ydCAqIGZyb20gJy4vb3B0aW9ucyc7XG4iXX0=
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL21hcGJveC9zcmMvbGliL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxXQUFXLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL21hcGJveC5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9tYXBib3gubGF5b3V0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL21hcGJveC5sYXlvdXQuZHJhd2VyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL21hcGJveC5tZW51LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL21hcGJveC5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbWFwYm94LnN0b3JlLm1hcC5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9tYXBib3guc3RvcmUnO1xuZXhwb3J0ICogZnJvbSAnLi9tYXBib3gnO1xuZXhwb3J0ICogZnJvbSAnLi9vcHRpb25zJztcbiJdfQ==
@@ -0,0 +1,132 @@
1
+ import { skip, switchMap, first, startWith, shareReplay, throttleTime, map, distinctUntilChanged, BehaviorSubject, combineLatest, Subject } from 'rxjs';
2
+ import { Component, ElementRef, Input, ViewChild } from '@angular/core';
3
+ import { DbxMapboxMapStore } from './mapbox.store';
4
+ import { dbxColorBackground } from '@dereekb/dbx-web';
5
+ import { SubscriptionObject } from '@dereekb/rxjs';
6
+ import { MatDrawerContainer } from '@angular/material/sidenav';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "./mapbox.store";
9
+ import * as i2 from "@angular/common";
10
+ import * as i3 from "@angular/material/sidenav";
11
+ import * as i4 from "@angular/material/button";
12
+ import * as i5 from "@angular/material/icon";
13
+ import * as i6 from "angular-resize-event";
14
+ import * as i7 from "./mapbox.layout.drawer.component";
15
+ /**
16
+ * Responsive component meant to split a left and right column.
17
+ *
18
+ * The left column is smaller than the right column, which contains the primary content.
19
+ *
20
+ * Requires a TwoColumnsContextStore to be provided.
21
+ */
22
+ export class DbxMapboxLayoutComponent extends SubscriptionObject {
23
+ constructor(dbxMapboxMapStore) {
24
+ super();
25
+ this.dbxMapboxMapStore = dbxMapboxMapStore;
26
+ this._resized = new Subject();
27
+ this._updateMargins = new Subject();
28
+ this._side = new BehaviorSubject('right');
29
+ this._openToggle = new BehaviorSubject(true);
30
+ this._color = new BehaviorSubject(undefined);
31
+ this._toggleSub = new SubscriptionObject();
32
+ this.side$ = this._side.pipe(distinctUntilChanged(), shareReplay(1));
33
+ this.opened$ = combineLatest([this.dbxMapboxMapStore.hasContent$, this._openToggle]).pipe(map(([hasContent, open]) => hasContent && open), distinctUntilChanged(), shareReplay(1));
34
+ this.position$ = this.side$.pipe(map((x) => (x === 'right' ? 'end' : 'start')), distinctUntilChanged(), shareReplay(1));
35
+ this.drawerClasses$ = combineLatest([this.side$, this.dbxMapboxMapStore.hasContent$, this.opened$]).pipe(
36
+ //
37
+ map(([side, hasContent, open]) => (hasContent ? 'has-drawer-content' : 'no-drawer-content') + ` ${side}-drawer ` + (open ? 'open-drawer' : '')), distinctUntilChanged(), shareReplay(1));
38
+ this.drawerButtonClasses$ = combineLatest([this.dbxMapboxMapStore.hasContent$, this._color]).pipe(
39
+ //
40
+ map(([hasContent, color]) => dbxColorBackground(color)), distinctUntilChanged(), shareReplay(1));
41
+ this.buttonIcon$ = combineLatest([this.side$, this.opened$]).pipe(map(([side, opened]) => {
42
+ let icons = ['chevron_right', 'chevron_left'];
43
+ if (side === 'left') {
44
+ icons = icons.reverse();
45
+ }
46
+ return opened ? icons[0] : icons[1];
47
+ }));
48
+ }
49
+ ngOnInit() {
50
+ this.subscription = this.side$.pipe(switchMap(() => this._resized.pipe(throttleTime(100, undefined, { leading: true, trailing: true }), map(() => 'r'), startWith('s')))).subscribe((reason) => {
51
+ this.dbxMapboxMapStore.mapInstance$.subscribe((x) => {
52
+ x.resize();
53
+ // side changed
54
+ if (reason === 's') {
55
+ setTimeout(() => {
56
+ this._updateMargins.next();
57
+ });
58
+ }
59
+ });
60
+ });
61
+ this._toggleSub.subscription = combineLatest([this.opened$.pipe(distinctUntilChanged(), skip(1)), this._updateMargins]).subscribe(([opened]) => {
62
+ let { right } = this.container._contentMargins;
63
+ this.container.updateContentMargins();
64
+ setTimeout(() => {
65
+ const flip = opened ? 1 : -1;
66
+ if (opened) {
67
+ right = this.container._contentMargins.right;
68
+ }
69
+ right = (right || 0) * flip;
70
+ const element = this.content.nativeElement;
71
+ const width = element.clientWidth;
72
+ const easeTo = this.dbxMapboxMapStore
73
+ .calculateNextCenterOffsetWithScreenMarginChange({
74
+ leftMargin: 0,
75
+ rightMargin: right,
76
+ fullWidth: width
77
+ })
78
+ .pipe(first(), map((center) => ({ to: { center, duration: 3200, essential: false } })));
79
+ this.dbxMapboxMapStore.easeTo(easeTo);
80
+ });
81
+ });
82
+ }
83
+ ngOnDestroy() {
84
+ this._resized.complete();
85
+ this._updateMargins.complete();
86
+ this._side.complete();
87
+ this._openToggle.complete();
88
+ this._color.complete();
89
+ this._toggleSub.destroy();
90
+ }
91
+ toggleDrawer(open) {
92
+ if (open == null) {
93
+ open = !this._openToggle.value;
94
+ }
95
+ this._openToggle.next(open);
96
+ }
97
+ set side(side) {
98
+ if (side != null) {
99
+ this._side.next(side);
100
+ }
101
+ }
102
+ set opened(opened) {
103
+ if (opened != null) {
104
+ this._openToggle.next(opened);
105
+ }
106
+ }
107
+ set drawerColor(color) {
108
+ this._color.next(color);
109
+ }
110
+ onResized(event) {
111
+ this._resized.next();
112
+ }
113
+ }
114
+ DbxMapboxLayoutComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxMapboxLayoutComponent, deps: [{ token: i1.DbxMapboxMapStore }], target: i0.ɵɵFactoryTarget.Component });
115
+ DbxMapboxLayoutComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.2", type: DbxMapboxLayoutComponent, selector: "dbx-mapbox-layout", inputs: { side: "side", opened: "opened", drawerColor: "drawerColor" }, viewQueries: [{ propertyName: "container", 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 class=\"dbx-mapbox-layout-container\" [ngClass]=\"(drawerClasses$ | async) || ''\" [hasBackdrop]=\"false\">\n <mat-drawer class=\"dbx-mapbox-layout-drawer\" #drawer [opened]=\"opened$ | async\" mode=\"push\" [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-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" }] });
116
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxMapboxLayoutComponent, decorators: [{
117
+ type: Component,
118
+ args: [{ selector: 'dbx-mapbox-layout', template: "<mat-drawer-container class=\"dbx-mapbox-layout-container\" [ngClass]=\"(drawerClasses$ | async) || ''\" [hasBackdrop]=\"false\">\n <mat-drawer class=\"dbx-mapbox-layout-drawer\" #drawer [opened]=\"opened$ | async\" mode=\"push\" [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-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"] }]
119
+ }], ctorParameters: function () { return [{ type: i1.DbxMapboxMapStore }]; }, propDecorators: { container: [{
120
+ type: ViewChild,
121
+ args: [MatDrawerContainer]
122
+ }], content: [{
123
+ type: ViewChild,
124
+ args: ['content', { read: ElementRef, static: true }]
125
+ }], side: [{
126
+ type: Input
127
+ }], opened: [{
128
+ type: Input
129
+ }], drawerColor: [{
130
+ type: Input
131
+ }] } });
132
+ //# 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 { skip, 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\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)\n  readonly container!: MatDrawerContainer;\n\n  @ViewChild('content', { read: ElementRef, static: true })\n  readonly content!: ElementRef;\n\n  private _resized = new Subject<void>();\n  private _updateMargins = new Subject<void>();\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 side$ = this._side.pipe(distinctUntilChanged(), shareReplay(1));\n\n  readonly opened$ = combineLatest([this.dbxMapboxMapStore.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    this._toggleSub.subscription = combineLatest([this.opened$.pipe(distinctUntilChanged(), skip(1)), this._updateMargins]).subscribe(([opened]) => {\n      let { right } = this.container._contentMargins;\n\n      this.container.updateContentMargins();\n\n      setTimeout(() => {\n        const flip = opened ? 1 : -1;\n\n        if (opened) {\n          right = this.container._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 easeTo: Observable<MapboxEaseTo> = this.dbxMapboxMapStore\n          .calculateNextCenterOffsetWithScreenMarginChange({\n            leftMargin: 0,\n            rightMargin: right,\n            fullWidth: width\n          })\n          .pipe(\n            first(),\n            map((center) => ({ to: { center, duration: 3200, essential: false } } as MapboxEaseTo))\n          );\n\n        this.dbxMapboxMapStore.easeTo(easeTo);\n      });\n    });\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  }\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 opened(opened: Maybe<boolean>) {\n    if (opened != null) {\n      this._openToggle.next(opened);\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();\n  }\n}\n","<mat-drawer-container class=\"dbx-mapbox-layout-container\" [ngClass]=\"(drawerClasses$ | async) || ''\" [hasBackdrop]=\"false\">\n  <mat-drawer class=\"dbx-mapbox-layout-drawer\" #drawer [opened]=\"opened$ | async\" mode=\"push\" [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"]}
@@ -0,0 +1,24 @@
1
+ import { Component } from '@angular/core';
2
+ import { DbxMapboxMapStore } from './mapbox.store';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "./mapbox.store";
5
+ import * as i2 from "@dereekb/dbx-core";
6
+ import * as i3 from "@angular/common";
7
+ /**
8
+ * Content drawer that connects with DbxMapboxMapStore to
9
+ */
10
+ export class DbxMapboxLayoutDrawerComponent {
11
+ constructor(dbxMapboxMapStore) {
12
+ this.dbxMapboxMapStore = dbxMapboxMapStore;
13
+ this.config$ = this.dbxMapboxMapStore.content$;
14
+ }
15
+ }
16
+ DbxMapboxLayoutDrawerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxMapboxLayoutDrawerComponent, deps: [{ token: i1.DbxMapboxMapStore }], target: i0.ɵɵFactoryTarget.Component });
17
+ DbxMapboxLayoutDrawerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.2", type: DbxMapboxLayoutDrawerComponent, selector: "dbx-mapbox-layout-drawer", host: { classAttribute: "dbx-mapbox-layout-drawer" }, ngImport: i0, template: "<div>\n <dbx-injection [config]=\"config$ | async\"></dbx-injection>\n</div>\n", dependencies: [{ kind: "component", type: i2.DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }] });
18
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxMapboxLayoutDrawerComponent, decorators: [{
19
+ type: Component,
20
+ args: [{ selector: 'dbx-mapbox-layout-drawer', host: {
21
+ class: 'dbx-mapbox-layout-drawer'
22
+ }, template: "<div>\n <dbx-injection [config]=\"config$ | async\"></dbx-injection>\n</div>\n" }]
23
+ }], ctorParameters: function () { return [{ type: i1.DbxMapboxMapStore }]; } });
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwYm94LmxheW91dC5kcmF3ZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9tYXBib3gvc3JjL2xpYi9tYXBib3gubGF5b3V0LmRyYXdlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL21hcGJveC9zcmMvbGliL21hcGJveC5sYXlvdXQuZHJhd2VyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7Ozs7O0FBRW5EOztHQUVHO0FBUUgsTUFBTSxPQUFPLDhCQUE4QjtJQUd6QyxZQUFxQixpQkFBb0M7UUFBcEMsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFtQjtRQUZoRCxZQUFPLEdBQUcsSUFBSSxDQUFDLGlCQUFpQixDQUFDLFFBQVEsQ0FBQztJQUVTLENBQUM7OzJIQUhsRCw4QkFBOEI7K0dBQTlCLDhCQUE4QixzSENiM0MsaUZBR0E7MkZEVWEsOEJBQThCO2tCQVAxQyxTQUFTOytCQUNFLDBCQUEwQixRQUU5Qjt3QkFDSixLQUFLLEVBQUUsMEJBQTBCO3FCQUNsQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRGJ4TWFwYm94TWFwU3RvcmUgfSBmcm9tICcuL21hcGJveC5zdG9yZSc7XG5cbi8qKlxuICogQ29udGVudCBkcmF3ZXIgdGhhdCBjb25uZWN0cyB3aXRoIERieE1hcGJveE1hcFN0b3JlIHRvXG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2RieC1tYXBib3gtbGF5b3V0LWRyYXdlcicsXG4gIHRlbXBsYXRlVXJsOiAnLi9tYXBib3gubGF5b3V0LmRyYXdlci5jb21wb25lbnQuaHRtbCcsXG4gIGhvc3Q6IHtcbiAgICBjbGFzczogJ2RieC1tYXBib3gtbGF5b3V0LWRyYXdlcidcbiAgfVxufSlcbmV4cG9ydCBjbGFzcyBEYnhNYXBib3hMYXlvdXREcmF3ZXJDb21wb25lbnQge1xuICByZWFkb25seSBjb25maWckID0gdGhpcy5kYnhNYXBib3hNYXBTdG9yZS5jb250ZW50JDtcblxuICBjb25zdHJ1Y3RvcihyZWFkb25seSBkYnhNYXBib3hNYXBTdG9yZTogRGJ4TWFwYm94TWFwU3RvcmUpIHt9XG59XG4iLCI8ZGl2PlxuICA8ZGJ4LWluamVjdGlvbiBbY29uZmlnXT1cImNvbmZpZyQgfCBhc3luY1wiPjwvZGJ4LWluamVjdGlvbj5cbjwvZGl2PlxuIl19
@@ -0,0 +1,99 @@
1
+ import { SubscriptionObject } from '@dereekb/rxjs';
2
+ import { filter, switchMap, BehaviorSubject, of } from 'rxjs';
3
+ import { DbxMapboxMapStore } from './mapbox.store';
4
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Host, Input, NgZone } from '@angular/core';
5
+ import { DestroyFunctionObject } from '@dereekb/util';
6
+ import { MatMenuTrigger } from '@angular/material/menu';
7
+ import { AbstractSubscriptionDirective, safeMarkForCheck } from '@dereekb/dbx-core';
8
+ import { disableRightClickInCdkBackdrop } from '@dereekb/dbx-web';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "./mapbox.store";
11
+ import * as i2 from "@angular/material/menu";
12
+ /**
13
+ * Directive that connects a host MatMenuTrigger to a DbxMapboxMapStore and listens for right-clicks on the map.
14
+ *
15
+ * The map dissapears if the mouse scrolls anywhere else on the map.
16
+ */
17
+ export class DbxMapboxMenuComponent extends AbstractSubscriptionDirective {
18
+ constructor(dbxMapboxMapStore, matMenuTrigger, ngZone, cdRef) {
19
+ super();
20
+ this.dbxMapboxMapStore = dbxMapboxMapStore;
21
+ this.matMenuTrigger = matMenuTrigger;
22
+ this.ngZone = ngZone;
23
+ this.cdRef = cdRef;
24
+ this._pos = { x: `0`, y: `0` };
25
+ this._active = new BehaviorSubject(true);
26
+ this._menuCloseSub = new SubscriptionObject();
27
+ this._preventRightClick = new DestroyFunctionObject();
28
+ }
29
+ get pos() {
30
+ return this._pos;
31
+ }
32
+ ngOnInit() {
33
+ this.sub = this._active
34
+ .pipe(switchMap((active) => {
35
+ if (active) {
36
+ return this.dbxMapboxMapStore.rightClickEvent$;
37
+ }
38
+ else {
39
+ return of();
40
+ }
41
+ }), filter(Boolean))
42
+ .subscribe((event) => {
43
+ const menu = this.matMenuTrigger.menu;
44
+ const buttonEvent = event.originalEvent;
45
+ if (menu && buttonEvent) {
46
+ buttonEvent.preventDefault();
47
+ // update position of this component for menu to open at
48
+ this._pos = {
49
+ x: `${buttonEvent.x}px`,
50
+ y: `${buttonEvent.y}px`
51
+ };
52
+ safeMarkForCheck(this.cdRef);
53
+ // open menu
54
+ this.ngZone.run(() => this.matMenuTrigger.openMenu());
55
+ // prevent right clicks in the cdkOverlay while the menu is open
56
+ this._preventRightClick.destroy = disableRightClickInCdkBackdrop(undefined, () => {
57
+ this.ngZone.run(() => this.matMenuTrigger.closeMenu());
58
+ });
59
+ }
60
+ });
61
+ this._menuCloseSub.subscription = this.matMenuTrigger.menuClosed.subscribe(() => {
62
+ // destroy prevention when the menu is closed.
63
+ this._preventRightClick.destroy();
64
+ });
65
+ }
66
+ ngOnDestroy() {
67
+ super.ngOnDestroy();
68
+ this._active.complete();
69
+ this._preventRightClick.destroy();
70
+ this._menuCloseSub.destroy();
71
+ if (this.matMenuTrigger) {
72
+ this.matMenuTrigger.closeMenu();
73
+ }
74
+ }
75
+ set active(active) {
76
+ this._active.next(active ?? true);
77
+ }
78
+ }
79
+ DbxMapboxMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxMapboxMenuComponent, deps: [{ token: i1.DbxMapboxMapStore }, { token: i2.MatMenuTrigger, host: true }, { token: i0.NgZone }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
80
+ DbxMapboxMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.2", type: DbxMapboxMenuComponent, selector: "dbx-mapbox-menu", inputs: { active: ["dbxMapboxMenu", "active"] }, host: { properties: { "style.top": "pos.y", "style.left": "pos.x" }, styleAttribute: "visibility: hidden; position: fixed" }, usesInheritance: true, ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush });
81
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxMapboxMenuComponent, decorators: [{
82
+ type: Component,
83
+ args: [{
84
+ selector: 'dbx-mapbox-menu',
85
+ template: '',
86
+ host: {
87
+ style: 'visibility: hidden; position: fixed',
88
+ '[style.top]': 'pos.y',
89
+ '[style.left]': 'pos.x'
90
+ },
91
+ changeDetection: ChangeDetectionStrategy.OnPush
92
+ }]
93
+ }], ctorParameters: function () { return [{ type: i1.DbxMapboxMapStore }, { type: i2.MatMenuTrigger, decorators: [{
94
+ type: Host
95
+ }] }, { type: i0.NgZone }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { active: [{
96
+ type: Input,
97
+ args: ['dbxMapboxMenu']
98
+ }] } });
99
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mapbox.menu.component.js","sourceRoot":"","sources":["../../../../../../packages/dbx-web/mapbox/src/lib/mapbox.menu.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { SubscriptionObject } from '@dereekb/rxjs';\nimport { filter, switchMap, BehaviorSubject, of } from 'rxjs';\nimport { DbxMapboxService } from './mapbox.service';\nimport { DbxMapboxMapStore } from './mapbox.store';\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, Directive, Host, HostListener, Input, OnInit, Optional, OnDestroy, NgZone } from '@angular/core';\nimport { MapComponent, MapService } from 'ngx-mapbox-gl';\nimport { Vector, latLngPoint, Maybe, DestroyFunction, DestroyFunctionObject } from '@dereekb/util';\nimport { MatMenu, MatMenuTrigger } from '@angular/material/menu';\nimport { AbstractSubscriptionDirective, safeMarkForCheck } from '@dereekb/dbx-core';\nimport { disableRightClickInCdkBackdrop } from '@dereekb/dbx-web';\n\n/**\n * Directive that connects a host MatMenuTrigger to a DbxMapboxMapStore and listens for right-clicks on the map.\n *\n * The map dissapears if the mouse scrolls anywhere else on the map.\n */\n@Component({\n  selector: 'dbx-mapbox-menu',\n  template: '',\n  host: {\n    style: 'visibility: hidden; position: fixed',\n    '[style.top]': 'pos.y',\n    '[style.left]': 'pos.x'\n  },\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DbxMapboxMenuComponent extends AbstractSubscriptionDirective implements OnInit, OnDestroy {\n  private _pos = { x: `0`, y: `0` };\n  private _active = new BehaviorSubject<boolean>(true);\n\n  private _menuCloseSub = new SubscriptionObject();\n  private _preventRightClick = new DestroyFunctionObject();\n\n  get pos() {\n    return this._pos;\n  }\n\n  constructor(readonly dbxMapboxMapStore: DbxMapboxMapStore, @Host() readonly matMenuTrigger: MatMenuTrigger, readonly ngZone: NgZone, readonly cdRef: ChangeDetectorRef) {\n    super();\n  }\n\n  ngOnInit(): void {\n    this.sub = this._active\n      .pipe(\n        switchMap((active) => {\n          if (active) {\n            return this.dbxMapboxMapStore.rightClickEvent$;\n          } else {\n            return of();\n          }\n        }),\n        filter(Boolean)\n      )\n      .subscribe((event) => {\n        const menu = this.matMenuTrigger.menu;\n        const buttonEvent = event.originalEvent;\n\n        if (menu && buttonEvent) {\n          buttonEvent.preventDefault();\n\n          // update position of this component for menu to open at\n          this._pos = {\n            x: `${buttonEvent.x}px`,\n            y: `${buttonEvent.y}px`\n          };\n\n          safeMarkForCheck(this.cdRef);\n\n          // open menu\n          this.ngZone.run(() => this.matMenuTrigger.openMenu());\n\n          // prevent right clicks in the cdkOverlay while the menu is open\n          this._preventRightClick.destroy = disableRightClickInCdkBackdrop(undefined, () => {\n            this.ngZone.run(() => this.matMenuTrigger.closeMenu());\n          });\n        }\n      });\n\n    this._menuCloseSub.subscription = this.matMenuTrigger.menuClosed.subscribe(() => {\n      // destroy prevention when the menu is closed.\n      this._preventRightClick.destroy();\n    });\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._active.complete();\n    this._preventRightClick.destroy();\n    this._menuCloseSub.destroy();\n\n    if (this.matMenuTrigger) {\n      this.matMenuTrigger.closeMenu();\n    }\n  }\n\n  @Input('dbxMapboxMenu')\n  set active(active: Maybe<boolean>) {\n    this._active.next(active ?? true);\n  }\n}\n"]}
@@ -9,4 +9,4 @@ export const KNOWN_MAPBOX_STYLES = [
9
9
  'mapbox://styles/mapbox/navigation-day-v1',
10
10
  'mapbox://styles/mapbox/navigation-night-v1'
11
11
  ];
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwYm94LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9tYXBib3gvc3JjL2xpYi9tYXBib3gudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBS0EsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQXVCO0lBQ3JELEVBQUU7SUFDRixvQ0FBb0M7SUFDcEMscUNBQXFDO0lBQ3JDLGtDQUFrQztJQUNsQyxpQ0FBaUM7SUFDakMscUNBQXFDO0lBQ3JDLDhDQUE4QztJQUM5QywwQ0FBMEM7SUFDMUMsNENBQTRDO0NBQzdDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBMYXRMbmdQb2ludCwgTGF0TG5nUG9pbnRJbnB1dCwgTGF0TG5nQm91bmQsIExhdExuZ0JvdW5kSW5wdXQgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcbmltcG9ydCAqIGFzIE1hcGJveEdsIGZyb20gJ21hcGJveC1nbCc7XG5cbmV4cG9ydCB0eXBlIEtub3duTWFwYm94U3R5bGUgPSAnbWFwYm94Oi8vc3R5bGVzL21hcGJveC9zdHJlZXRzLXYxMScgfCAnbWFwYm94Oi8vc3R5bGVzL21hcGJveC9vdXRkb29ycy12MTEnIHwgJ21hcGJveDovL3N0eWxlcy9tYXBib3gvbGlnaHQtdjEwJyB8ICdtYXBib3g6Ly9zdHlsZXMvbWFwYm94L2RhcmstdjEwJyB8ICdtYXBib3g6Ly9zdHlsZXMvbWFwYm94L3NhdGVsbGl0ZS12OScgfCAnbWFwYm94Oi8vc3R5bGVzL21hcGJveC9zYXRlbGxpdGUtc3RyZWV0cy12MTEnIHwgJ21hcGJveDovL3N0eWxlcy9tYXBib3gvbmF2aWdhdGlvbi1kYXktdjEnIHwgJ21hcGJveDovL3N0eWxlcy9tYXBib3gvbmF2aWdhdGlvbi1uaWdodC12MSc7XG5cbmV4cG9ydCBjb25zdCBLTk9XTl9NQVBCT1hfU1RZTEVTOiBLbm93bk1hcGJveFN0eWxlW10gPSBbXG4gIC8vXG4gICdtYXBib3g6Ly9zdHlsZXMvbWFwYm94L3N0cmVldHMtdjExJyxcbiAgJ21hcGJveDovL3N0eWxlcy9tYXBib3gvb3V0ZG9vcnMtdjExJyxcbiAgJ21hcGJveDovL3N0eWxlcy9tYXBib3gvbGlnaHQtdjEwJyxcbiAgJ21hcGJveDovL3N0eWxlcy9tYXBib3gvZGFyay12MTAnLFxuICAnbWFwYm94Oi8vc3R5bGVzL21hcGJveC9zYXRlbGxpdGUtdjknLFxuICAnbWFwYm94Oi8vc3R5bGVzL21hcGJveC9zYXRlbGxpdGUtc3RyZWV0cy12MTEnLFxuICAnbWFwYm94Oi8vc3R5bGVzL21hcGJveC9uYXZpZ2F0aW9uLWRheS12MScsXG4gICdtYXBib3g6Ly9zdHlsZXMvbWFwYm94L25hdmlnYXRpb24tbmlnaHQtdjEnXG5dO1xuXG5leHBvcnQgdHlwZSBNYXBib3hab29tTGV2ZWwgPSBudW1iZXI7XG5leHBvcnQgdHlwZSBNYXBib3hQaXRjaCA9IG51bWJlcjtcbmV4cG9ydCB0eXBlIE1hcGJveEJlYXJpbmcgPSBudW1iZXI7XG5cbmV4cG9ydCB0eXBlIERieE1hcGJveENsaWNrRXZlbnQgPSBNYXBib3hHbC5NYXBNb3VzZUV2ZW50ICYgTWFwYm94R2wuRXZlbnREYXRhO1xuXG5leHBvcnQgaW50ZXJmYWNlIE1hcGJveFN0eWxlQ29uZmlnIHtcbiAgc3R5bGU6IE1hcGJveEdsLlN0eWxlIHwgc3RyaW5nO1xuICBvcHRpb25zPzoge1xuICAgIGRpZmY/OiBib29sZWFuIHwgdW5kZWZpbmVkO1xuICAgIGxvY2FsSWRlb2dyYXBoRm9udEZhbWlseT86IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgfTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNYXBib3hGaXRCb3VuZHMge1xuICBib3VuZHM6IExhdExuZ0JvdW5kSW5wdXQ7XG4gIG9wdGlvbnM/OiBtYXBib3hnbC5GaXRCb3VuZHNPcHRpb25zO1xuICBldmVudERhdGE/OiBtYXBib3hnbC5FdmVudERhdGE7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWFwYm94SnVtcFRvUG9zaXRpb25PcHRpb25zIGV4dGVuZHMgT21pdDxNYXBib3hHbC5DYW1lcmFPcHRpb25zLCAnY2VudGVyJz4ge1xuICBjZW50ZXI6IExhdExuZ1BvaW50SW5wdXQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWFwYm94SnVtcFRvIHtcbiAgY2VudGVyPzogTGF0TG5nUG9pbnRJbnB1dDtcbiAgdG8/OiBNYXBib3hKdW1wVG9Qb3NpdGlvbk9wdGlvbnM7XG4gIGV2ZW50RGF0YT86IG1hcGJveGdsLkV2ZW50RGF0YTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNYXBib3hFYXNlVG9Qb3NpdGlvbk9wdGlvbnMgZXh0ZW5kcyBPbWl0PE1hcGJveEdsLkVhc2VUb09wdGlvbnMsICdjZW50ZXInPiwgTWFwYm94SnVtcFRvUG9zaXRpb25PcHRpb25zIHt9XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWFwYm94RWFzZVRvIHtcbiAgY2VudGVyPzogTGF0TG5nUG9pbnRJbnB1dDtcbiAgdG8/OiBNYXBib3hFYXNlVG9Qb3NpdGlvbk9wdGlvbnM7XG4gIGV2ZW50RGF0YT86IG1hcGJveGdsLkV2ZW50RGF0YTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNYXBib3hGbHlUb1Bvc2l0aW9uT3B0aW9ucyBleHRlbmRzIE9taXQ8TWFwYm94R2wuRmx5VG9PcHRpb25zLCAnY2VudGVyJz4sIE1hcGJveEp1bXBUb1Bvc2l0aW9uT3B0aW9ucyB7fVxuXG5leHBvcnQgaW50ZXJmYWNlIE1hcGJveEZseVRvIHtcbiAgY2VudGVyPzogTGF0TG5nUG9pbnRJbnB1dDtcbiAgdG8/OiBNYXBib3hGbHlUb1Bvc2l0aW9uT3B0aW9ucztcbiAgZXZlbnREYXRhPzogbWFwYm94Z2wuRXZlbnREYXRhO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1hcGJveFJvdGF0ZVRvIHtcbiAgYmVhcmluZzogTWFwYm94QmVhcmluZztcbiAgb3B0aW9ucz86IG1hcGJveGdsLkFuaW1hdGlvbk9wdGlvbnM7XG4gIGV2ZW50RGF0YT86IG1hcGJveGdsLkV2ZW50RGF0YTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNYXBib3hSZXNldE5vcnRoIHtcbiAgb3B0aW9ucz86IG1hcGJveGdsLkFuaW1hdGlvbk9wdGlvbnM7XG4gIGV2ZW50RGF0YT86IG1hcGJveGdsLkV2ZW50RGF0YTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNYXBib3hSZXNldE5vcnRoUGl0Y2gge1xuICBvcHRpb25zPzogbWFwYm94Z2wuQW5pbWF0aW9uT3B0aW9ucztcbiAgZXZlbnREYXRhPzogbWFwYm94Z2wuRXZlbnREYXRhO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1hcGJveFNuYXBUb05vcnRoIHtcbiAgb3B0aW9ucz86IG1hcGJveGdsLkFuaW1hdGlvbk9wdGlvbnM7XG4gIGV2ZW50RGF0YT86IG1hcGJveGdsLkV2ZW50RGF0YTtcbn1cbiJdfQ==
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwYm94LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9tYXBib3gvc3JjL2xpYi9tYXBib3gudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBS0EsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQXVCO0lBQ3JELEVBQUU7SUFDRixvQ0FBb0M7SUFDcEMscUNBQXFDO0lBQ3JDLGtDQUFrQztJQUNsQyxpQ0FBaUM7SUFDakMscUNBQXFDO0lBQ3JDLDhDQUE4QztJQUM5QywwQ0FBMEM7SUFDMUMsNENBQTRDO0NBQzdDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBMYXRMbmdQb2ludElucHV0LCBMYXRMbmdCb3VuZElucHV0IH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5pbXBvcnQgKiBhcyBNYXBib3hHbCBmcm9tICdtYXBib3gtZ2wnO1xuXG5leHBvcnQgdHlwZSBLbm93bk1hcGJveFN0eWxlID0gJ21hcGJveDovL3N0eWxlcy9tYXBib3gvc3RyZWV0cy12MTEnIHwgJ21hcGJveDovL3N0eWxlcy9tYXBib3gvb3V0ZG9vcnMtdjExJyB8ICdtYXBib3g6Ly9zdHlsZXMvbWFwYm94L2xpZ2h0LXYxMCcgfCAnbWFwYm94Oi8vc3R5bGVzL21hcGJveC9kYXJrLXYxMCcgfCAnbWFwYm94Oi8vc3R5bGVzL21hcGJveC9zYXRlbGxpdGUtdjknIHwgJ21hcGJveDovL3N0eWxlcy9tYXBib3gvc2F0ZWxsaXRlLXN0cmVldHMtdjExJyB8ICdtYXBib3g6Ly9zdHlsZXMvbWFwYm94L25hdmlnYXRpb24tZGF5LXYxJyB8ICdtYXBib3g6Ly9zdHlsZXMvbWFwYm94L25hdmlnYXRpb24tbmlnaHQtdjEnO1xuXG5leHBvcnQgY29uc3QgS05PV05fTUFQQk9YX1NUWUxFUzogS25vd25NYXBib3hTdHlsZVtdID0gW1xuICAvL1xuICAnbWFwYm94Oi8vc3R5bGVzL21hcGJveC9zdHJlZXRzLXYxMScsXG4gICdtYXBib3g6Ly9zdHlsZXMvbWFwYm94L291dGRvb3JzLXYxMScsXG4gICdtYXBib3g6Ly9zdHlsZXMvbWFwYm94L2xpZ2h0LXYxMCcsXG4gICdtYXBib3g6Ly9zdHlsZXMvbWFwYm94L2RhcmstdjEwJyxcbiAgJ21hcGJveDovL3N0eWxlcy9tYXBib3gvc2F0ZWxsaXRlLXY5JyxcbiAgJ21hcGJveDovL3N0eWxlcy9tYXBib3gvc2F0ZWxsaXRlLXN0cmVldHMtdjExJyxcbiAgJ21hcGJveDovL3N0eWxlcy9tYXBib3gvbmF2aWdhdGlvbi1kYXktdjEnLFxuICAnbWFwYm94Oi8vc3R5bGVzL21hcGJveC9uYXZpZ2F0aW9uLW5pZ2h0LXYxJ1xuXTtcblxuZXhwb3J0IHR5cGUgTWFwYm94Wm9vbUxldmVsID0gbnVtYmVyO1xuZXhwb3J0IHR5cGUgTWFwYm94UGl0Y2ggPSBudW1iZXI7XG5leHBvcnQgdHlwZSBNYXBib3hCZWFyaW5nID0gbnVtYmVyO1xuXG5leHBvcnQgdHlwZSBEYnhNYXBib3hDbGlja0V2ZW50ID0gTWFwYm94R2wuTWFwTW91c2VFdmVudCAmIE1hcGJveEdsLkV2ZW50RGF0YTtcblxuZXhwb3J0IGludGVyZmFjZSBNYXBib3hTdHlsZUNvbmZpZyB7XG4gIHN0eWxlOiBNYXBib3hHbC5TdHlsZSB8IHN0cmluZztcbiAgb3B0aW9ucz86IHtcbiAgICBkaWZmPzogYm9vbGVhbiB8IHVuZGVmaW5lZDtcbiAgICBsb2NhbElkZW9ncmFwaEZvbnRGYW1pbHk/OiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gIH07XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWFwYm94Rml0Qm91bmRzIHtcbiAgYm91bmRzOiBMYXRMbmdCb3VuZElucHV0O1xuICBvcHRpb25zPzogbWFwYm94Z2wuRml0Qm91bmRzT3B0aW9ucztcbiAgZXZlbnREYXRhPzogbWFwYm94Z2wuRXZlbnREYXRhO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1hcGJveEp1bXBUb1Bvc2l0aW9uT3B0aW9ucyBleHRlbmRzIE9taXQ8TWFwYm94R2wuQ2FtZXJhT3B0aW9ucywgJ2NlbnRlcic+IHtcbiAgY2VudGVyOiBMYXRMbmdQb2ludElucHV0O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1hcGJveEp1bXBUbyB7XG4gIGNlbnRlcj86IExhdExuZ1BvaW50SW5wdXQ7XG4gIHRvPzogTWFwYm94SnVtcFRvUG9zaXRpb25PcHRpb25zO1xuICBldmVudERhdGE/OiBtYXBib3hnbC5FdmVudERhdGE7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWFwYm94RWFzZVRvUG9zaXRpb25PcHRpb25zIGV4dGVuZHMgT21pdDxNYXBib3hHbC5FYXNlVG9PcHRpb25zLCAnY2VudGVyJz4sIE1hcGJveEp1bXBUb1Bvc2l0aW9uT3B0aW9ucyB7fVxuXG5leHBvcnQgaW50ZXJmYWNlIE1hcGJveEVhc2VUbyB7XG4gIGNlbnRlcj86IExhdExuZ1BvaW50SW5wdXQ7XG4gIHRvPzogTWFwYm94RWFzZVRvUG9zaXRpb25PcHRpb25zO1xuICBldmVudERhdGE/OiBtYXBib3hnbC5FdmVudERhdGE7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWFwYm94Rmx5VG9Qb3NpdGlvbk9wdGlvbnMgZXh0ZW5kcyBPbWl0PE1hcGJveEdsLkZseVRvT3B0aW9ucywgJ2NlbnRlcic+LCBNYXBib3hKdW1wVG9Qb3NpdGlvbk9wdGlvbnMge31cblxuZXhwb3J0IGludGVyZmFjZSBNYXBib3hGbHlUbyB7XG4gIGNlbnRlcj86IExhdExuZ1BvaW50SW5wdXQ7XG4gIHRvPzogTWFwYm94Rmx5VG9Qb3NpdGlvbk9wdGlvbnM7XG4gIGV2ZW50RGF0YT86IG1hcGJveGdsLkV2ZW50RGF0YTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNYXBib3hSb3RhdGVUbyB7XG4gIGJlYXJpbmc6IE1hcGJveEJlYXJpbmc7XG4gIG9wdGlvbnM/OiBtYXBib3hnbC5BbmltYXRpb25PcHRpb25zO1xuICBldmVudERhdGE/OiBtYXBib3hnbC5FdmVudERhdGE7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWFwYm94UmVzZXROb3J0aCB7XG4gIG9wdGlvbnM/OiBtYXBib3hnbC5BbmltYXRpb25PcHRpb25zO1xuICBldmVudERhdGE/OiBtYXBib3hnbC5FdmVudERhdGE7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWFwYm94UmVzZXROb3J0aFBpdGNoIHtcbiAgb3B0aW9ucz86IG1hcGJveGdsLkFuaW1hdGlvbk9wdGlvbnM7XG4gIGV2ZW50RGF0YT86IG1hcGJveGdsLkV2ZW50RGF0YTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNYXBib3hTbmFwVG9Ob3J0aCB7XG4gIG9wdGlvbnM/OiBtYXBib3hnbC5BbmltYXRpb25PcHRpb25zO1xuICBldmVudERhdGE/OiBtYXBib3hnbC5FdmVudERhdGE7XG59XG4iXX0=
@@ -2,7 +2,22 @@ import { NgModule } from '@angular/core';
2
2
  import { CommonModule } from '@angular/common';
3
3
  import { DbxMapboxMapDirective } from './mapbox.store.map.directive';
4
4
  import { DbxMapboxConfig } from './mapbox.service';
5
+ import { DbxMapboxLayoutComponent } from './mapbox.layout.component';
6
+ import { MatSidenavModule } from '@angular/material/sidenav';
7
+ import { DbxMapboxLayoutDrawerComponent } from './mapbox.layout.drawer.component';
8
+ import { DbxInjectionComponentModule } from '@dereekb/dbx-core';
9
+ import { MatButtonModule } from '@angular/material/button';
10
+ import { MatIconModule } from '@angular/material/icon';
11
+ import { AngularResizeEventModule } from 'angular-resize-event';
12
+ import { DbxMapboxMenuComponent } from './mapbox.menu.component';
5
13
  import * as i0 from "@angular/core";
14
+ const declarations = [
15
+ //
16
+ DbxMapboxMapDirective,
17
+ DbxMapboxLayoutComponent,
18
+ DbxMapboxLayoutDrawerComponent,
19
+ DbxMapboxMenuComponent
20
+ ];
6
21
  export class DbxMapboxModule {
7
22
  static forRoot(config) {
8
23
  return {
@@ -17,14 +32,46 @@ export class DbxMapboxModule {
17
32
  }
18
33
  }
19
34
  DbxMapboxModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxMapboxModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
20
- DbxMapboxModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.1.2", ngImport: i0, type: DbxMapboxModule, declarations: [DbxMapboxMapDirective], imports: [CommonModule], exports: [DbxMapboxMapDirective] });
21
- DbxMapboxModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxMapboxModule, imports: [CommonModule] });
35
+ DbxMapboxModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.1.2", ngImport: i0, type: DbxMapboxModule, declarations: [
36
+ //
37
+ DbxMapboxMapDirective,
38
+ DbxMapboxLayoutComponent,
39
+ DbxMapboxLayoutDrawerComponent,
40
+ DbxMapboxMenuComponent], imports: [
41
+ //
42
+ CommonModule,
43
+ MatSidenavModule,
44
+ DbxInjectionComponentModule,
45
+ MatButtonModule,
46
+ MatIconModule,
47
+ AngularResizeEventModule], exports: [
48
+ //
49
+ DbxMapboxMapDirective,
50
+ DbxMapboxLayoutComponent,
51
+ DbxMapboxLayoutDrawerComponent,
52
+ DbxMapboxMenuComponent] });
53
+ DbxMapboxModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxMapboxModule, imports: [
54
+ //
55
+ CommonModule,
56
+ MatSidenavModule,
57
+ DbxInjectionComponentModule,
58
+ MatButtonModule,
59
+ MatIconModule,
60
+ AngularResizeEventModule] });
22
61
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxMapboxModule, decorators: [{
23
62
  type: NgModule,
24
63
  args: [{
25
- imports: [CommonModule],
26
- declarations: [DbxMapboxMapDirective],
27
- exports: [DbxMapboxMapDirective]
64
+ imports: [
65
+ //
66
+ CommonModule,
67
+ MatSidenavModule,
68
+ DbxInjectionComponentModule,
69
+ MatButtonModule,
70
+ MatIconModule,
71
+ AngularResizeEventModule
72
+ ],
73
+ declarations,
74
+ exports: declarations
28
75
  }]
29
76
  }] });
30
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwYm94Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvbWFwYm94L3NyYy9saWIvbWFwYm94Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXVCLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM5RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDckUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGtCQUFrQixDQUFDOztBQU9uRCxNQUFNLE9BQU8sZUFBZTtJQUMxQixNQUFNLENBQUMsT0FBTyxDQUFDLE1BQXVCO1FBQ3BDLE9BQU87WUFDTCxRQUFRLEVBQUUsZUFBZTtZQUN6QixTQUFTLEVBQUU7Z0JBQ1Q7b0JBQ0UsT0FBTyxFQUFFLGVBQWU7b0JBQ3hCLFFBQVEsRUFBRSxNQUFNO2lCQUNqQjthQUNGO1NBQ0YsQ0FBQztJQUNKLENBQUM7OzRHQVhVLGVBQWU7NkdBQWYsZUFBZSxpQkFIWCxxQkFBcUIsYUFEMUIsWUFBWSxhQUVaLHFCQUFxQjs2R0FFcEIsZUFBZSxZQUpoQixZQUFZOzJGQUlYLGVBQWU7a0JBTDNCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixZQUFZLEVBQUUsQ0FBQyxxQkFBcUIsQ0FBQztvQkFDckMsT0FBTyxFQUFFLENBQUMscUJBQXFCLENBQUM7aUJBQ2pDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTW9kdWxlV2l0aFByb3ZpZGVycywgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBEYnhNYXBib3hNYXBEaXJlY3RpdmUgfSBmcm9tICcuL21hcGJveC5zdG9yZS5tYXAuZGlyZWN0aXZlJztcbmltcG9ydCB7IERieE1hcGJveENvbmZpZyB9IGZyb20gJy4vbWFwYm94LnNlcnZpY2UnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgZGVjbGFyYXRpb25zOiBbRGJ4TWFwYm94TWFwRGlyZWN0aXZlXSxcbiAgZXhwb3J0czogW0RieE1hcGJveE1hcERpcmVjdGl2ZV1cbn0pXG5leHBvcnQgY2xhc3MgRGJ4TWFwYm94TW9kdWxlIHtcbiAgc3RhdGljIGZvclJvb3QoY29uZmlnOiBEYnhNYXBib3hDb25maWcpOiBNb2R1bGVXaXRoUHJvdmlkZXJzPERieE1hcGJveE1vZHVsZT4ge1xuICAgIHJldHVybiB7XG4gICAgICBuZ01vZHVsZTogRGJ4TWFwYm94TW9kdWxlLFxuICAgICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIHtcbiAgICAgICAgICBwcm92aWRlOiBEYnhNYXBib3hDb25maWcsXG4gICAgICAgICAgdXNlVmFsdWU6IGNvbmZpZ1xuICAgICAgICB9XG4gICAgICBdXG4gICAgfTtcbiAgfVxufVxuIl19
77
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwYm94Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvbWFwYm94L3NyYy9saWIvbWFwYm94Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXVCLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM5RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDckUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ25ELE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ3JFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzdELE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBQ2xGLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ2hFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDaEUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0seUJBQXlCLENBQUM7O0FBRWpFLE1BQU0sWUFBWSxHQUFHO0lBQ25CLEVBQUU7SUFDRixxQkFBcUI7SUFDckIsd0JBQXdCO0lBQ3hCLDhCQUE4QjtJQUM5QixzQkFBc0I7Q0FDdkIsQ0FBQztBQWVGLE1BQU0sT0FBTyxlQUFlO0lBQzFCLE1BQU0sQ0FBQyxPQUFPLENBQUMsTUFBdUI7UUFDcEMsT0FBTztZQUNMLFFBQVEsRUFBRSxlQUFlO1lBQ3pCLFNBQVMsRUFBRTtnQkFDVDtvQkFDRSxPQUFPLEVBQUUsZUFBZTtvQkFDeEIsUUFBUSxFQUFFLE1BQU07aUJBQ2pCO2FBQ0Y7U0FDRixDQUFDO0lBQ0osQ0FBQzs7NEdBWFUsZUFBZTs2R0FBZixlQUFlO1FBcEIxQixFQUFFO1FBQ0YscUJBQXFCO1FBQ3JCLHdCQUF3QjtRQUN4Qiw4QkFBOEI7UUFDOUIsc0JBQXNCO1FBS3BCLEVBQUU7UUFDRixZQUFZO1FBQ1osZ0JBQWdCO1FBQ2hCLDJCQUEyQjtRQUMzQixlQUFlO1FBQ2YsYUFBYTtRQUNiLHdCQUF3QjtRQWYxQixFQUFFO1FBQ0YscUJBQXFCO1FBQ3JCLHdCQUF3QjtRQUN4Qiw4QkFBOEI7UUFDOUIsc0JBQXNCOzZHQWdCWCxlQUFlO1FBWHhCLEVBQUU7UUFDRixZQUFZO1FBQ1osZ0JBQWdCO1FBQ2hCLDJCQUEyQjtRQUMzQixlQUFlO1FBQ2YsYUFBYTtRQUNiLHdCQUF3QjsyRkFLZixlQUFlO2tCQWIzQixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRTt3QkFDUCxFQUFFO3dCQUNGLFlBQVk7d0JBQ1osZ0JBQWdCO3dCQUNoQiwyQkFBMkI7d0JBQzNCLGVBQWU7d0JBQ2YsYUFBYTt3QkFDYix3QkFBd0I7cUJBQ3pCO29CQUNELFlBQVk7b0JBQ1osT0FBTyxFQUFFLFlBQVk7aUJBQ3RCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTW9kdWxlV2l0aFByb3ZpZGVycywgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBEYnhNYXBib3hNYXBEaXJlY3RpdmUgfSBmcm9tICcuL21hcGJveC5zdG9yZS5tYXAuZGlyZWN0aXZlJztcbmltcG9ydCB7IERieE1hcGJveENvbmZpZyB9IGZyb20gJy4vbWFwYm94LnNlcnZpY2UnO1xuaW1wb3J0IHsgRGJ4TWFwYm94TGF5b3V0Q29tcG9uZW50IH0gZnJvbSAnLi9tYXBib3gubGF5b3V0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBNYXRTaWRlbmF2TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc2lkZW5hdic7XG5pbXBvcnQgeyBEYnhNYXBib3hMYXlvdXREcmF3ZXJDb21wb25lbnQgfSBmcm9tICcuL21hcGJveC5sYXlvdXQuZHJhd2VyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEYnhJbmplY3Rpb25Db21wb25lbnRNb2R1bGUgfSBmcm9tICdAZGVyZWVrYi9kYngtY29yZSc7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHsgQW5ndWxhclJlc2l6ZUV2ZW50TW9kdWxlIH0gZnJvbSAnYW5ndWxhci1yZXNpemUtZXZlbnQnO1xuaW1wb3J0IHsgRGJ4TWFwYm94TWVudUNvbXBvbmVudCB9IGZyb20gJy4vbWFwYm94Lm1lbnUuY29tcG9uZW50JztcblxuY29uc3QgZGVjbGFyYXRpb25zID0gW1xuICAvL1xuICBEYnhNYXBib3hNYXBEaXJlY3RpdmUsXG4gIERieE1hcGJveExheW91dENvbXBvbmVudCxcbiAgRGJ4TWFwYm94TGF5b3V0RHJhd2VyQ29tcG9uZW50LFxuICBEYnhNYXBib3hNZW51Q29tcG9uZW50XG5dO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXG4gICAgLy9cbiAgICBDb21tb25Nb2R1bGUsXG4gICAgTWF0U2lkZW5hdk1vZHVsZSxcbiAgICBEYnhJbmplY3Rpb25Db21wb25lbnRNb2R1bGUsXG4gICAgTWF0QnV0dG9uTW9kdWxlLFxuICAgIE1hdEljb25Nb2R1bGUsXG4gICAgQW5ndWxhclJlc2l6ZUV2ZW50TW9kdWxlXG4gIF0sXG4gIGRlY2xhcmF0aW9ucyxcbiAgZXhwb3J0czogZGVjbGFyYXRpb25zXG59KVxuZXhwb3J0IGNsYXNzIERieE1hcGJveE1vZHVsZSB7XG4gIHN0YXRpYyBmb3JSb290KGNvbmZpZzogRGJ4TWFwYm94Q29uZmlnKTogTW9kdWxlV2l0aFByb3ZpZGVyczxEYnhNYXBib3hNb2R1bGU+IHtcbiAgICByZXR1cm4ge1xuICAgICAgbmdNb2R1bGU6IERieE1hcGJveE1vZHVsZSxcbiAgICAgIHByb3ZpZGVyczogW1xuICAgICAgICB7XG4gICAgICAgICAgcHJvdmlkZTogRGJ4TWFwYm94Q29uZmlnLFxuICAgICAgICAgIHVzZVZhbHVlOiBjb25maWdcbiAgICAgICAgfVxuICAgICAgXVxuICAgIH07XG4gIH1cbn1cbiJdfQ==