@dereekb/dbx-web 9.5.5 → 9.6.2

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 (33) hide show
  1. package/esm2020/mapbox/lib/index.mjs +3 -1
  2. package/esm2020/mapbox/lib/mapbox.layout.component.mjs +26 -10
  3. package/esm2020/mapbox/lib/mapbox.marker.component.mjs +97 -0
  4. package/esm2020/mapbox/lib/mapbox.mjs +6 -1
  5. package/esm2020/mapbox/lib/mapbox.module.mjs +23 -7
  6. package/esm2020/mapbox/lib/mapbox.service.mjs +2 -2
  7. package/esm2020/mapbox/lib/mapbox.store.mjs +96 -22
  8. package/esm2020/mapbox/lib/mapbox.store.provide.mjs +52 -0
  9. package/fesm2015/dereekb-dbx-web-mapbox.mjs +288 -40
  10. package/fesm2015/dereekb-dbx-web-mapbox.mjs.map +1 -1
  11. package/fesm2020/dereekb-dbx-web-mapbox.mjs +287 -40
  12. package/fesm2020/dereekb-dbx-web-mapbox.mjs.map +1 -1
  13. package/mapbox/esm2020/lib/index.mjs +3 -1
  14. package/mapbox/esm2020/lib/mapbox.layout.component.mjs +26 -10
  15. package/mapbox/esm2020/lib/mapbox.marker.component.mjs +97 -0
  16. package/mapbox/esm2020/lib/mapbox.mjs +6 -1
  17. package/mapbox/esm2020/lib/mapbox.module.mjs +23 -7
  18. package/mapbox/esm2020/lib/mapbox.service.mjs +2 -2
  19. package/mapbox/esm2020/lib/mapbox.store.mjs +96 -22
  20. package/mapbox/esm2020/lib/mapbox.store.provide.mjs +52 -0
  21. package/mapbox/fesm2015/dereekb-dbx-web-mapbox.mjs +288 -40
  22. package/mapbox/fesm2015/dereekb-dbx-web-mapbox.mjs.map +1 -1
  23. package/mapbox/fesm2020/dereekb-dbx-web-mapbox.mjs +287 -40
  24. package/mapbox/fesm2020/dereekb-dbx-web-mapbox.mjs.map +1 -1
  25. package/mapbox/lib/index.d.ts +2 -0
  26. package/mapbox/lib/mapbox.d.ts +5 -2
  27. package/mapbox/lib/mapbox.layout.component.d.ts +4 -1
  28. package/mapbox/lib/mapbox.marker.component.d.ts +51 -0
  29. package/mapbox/lib/mapbox.module.d.ts +11 -7
  30. package/mapbox/lib/mapbox.store.d.ts +17 -0
  31. package/mapbox/lib/mapbox.store.provide.d.ts +24 -0
  32. package/mapbox/package.json +3 -3
  33. package/package.json +3 -3
@@ -1,10 +1,12 @@
1
1
  export * from './mapbox.module';
2
2
  export * from './mapbox.layout.component';
3
3
  export * from './mapbox.layout.drawer.component';
4
+ export * from './mapbox.marker.component';
4
5
  export * from './mapbox.menu.component';
5
6
  export * from './mapbox.service';
6
7
  export * from './mapbox.store.map.directive';
7
8
  export * from './mapbox.store';
9
+ export * from './mapbox.store.provide';
8
10
  export * from './mapbox';
9
11
  export * from './options';
10
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL21hcGJveC9zcmMvbGliL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxXQUFXLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL21hcGJveC5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9tYXBib3gubGF5b3V0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL21hcGJveC5sYXlvdXQuZHJhd2VyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL21hcGJveC5tZW51LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL21hcGJveC5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbWFwYm94LnN0b3JlLm1hcC5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9tYXBib3guc3RvcmUnO1xuZXhwb3J0ICogZnJvbSAnLi9tYXBib3gnO1xuZXhwb3J0ICogZnJvbSAnLi9vcHRpb25zJztcbiJdfQ==
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL21hcGJveC9zcmMvbGliL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsV0FBVyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9tYXBib3gubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbWFwYm94LmxheW91dC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9tYXBib3gubGF5b3V0LmRyYXdlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9tYXBib3gubWFya2VyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL21hcGJveC5tZW51LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL21hcGJveC5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbWFwYm94LnN0b3JlLm1hcC5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9tYXBib3guc3RvcmUnO1xuZXhwb3J0ICogZnJvbSAnLi9tYXBib3guc3RvcmUucHJvdmlkZSc7XG5leHBvcnQgKiBmcm9tICcuL21hcGJveCc7XG5leHBvcnQgKiBmcm9tICcuL29wdGlvbnMnO1xuIl19
@@ -1,4 +1,4 @@
1
- import { skip, switchMap, first, startWith, shareReplay, throttleTime, map, distinctUntilChanged, BehaviorSubject, combineLatest, Subject } from 'rxjs';
1
+ import { switchMap, first, startWith, shareReplay, throttleTime, map, distinctUntilChanged, BehaviorSubject, combineLatest, Subject } from 'rxjs';
2
2
  import { Component, ElementRef, Input, ViewChild } from '@angular/core';
3
3
  import { DbxMapboxMapStore } from './mapbox.store';
4
4
  import { dbxColorBackground } from '@dereekb/dbx-web';
@@ -25,12 +25,14 @@ export class DbxMapboxLayoutComponent extends SubscriptionObject {
25
25
  this.dbxMapboxMapStore = dbxMapboxMapStore;
26
26
  this._resized = new Subject();
27
27
  this._updateMargins = new Subject();
28
+ this._forceHasContent = new BehaviorSubject(false);
28
29
  this._side = new BehaviorSubject('right');
29
30
  this._openToggle = new BehaviorSubject(true);
30
31
  this._color = new BehaviorSubject(undefined);
31
32
  this._toggleSub = new SubscriptionObject();
32
33
  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.hasContent$ = combineLatest([this._forceHasContent, this.dbxMapboxMapStore.hasContent$]).pipe(map(([hasContent, forceHasContent]) => hasContent || forceHasContent), distinctUntilChanged(), shareReplay(1));
35
+ this.opened$ = combineLatest([this.hasContent$, this._openToggle]).pipe(map(([hasContent, open]) => hasContent && open), distinctUntilChanged(), shareReplay(1));
34
36
  this.position$ = this.side$.pipe(map((x) => (x === 'right' ? 'end' : 'start')), distinctUntilChanged(), shareReplay(1));
35
37
  this.drawerClasses$ = combineLatest([this.side$, this.dbxMapboxMapStore.hasContent$, this.opened$]).pipe(
36
38
  //
@@ -58,7 +60,8 @@ export class DbxMapboxLayoutComponent extends SubscriptionObject {
58
60
  }
59
61
  });
60
62
  });
61
- this._toggleSub.subscription = combineLatest([this.opened$.pipe(distinctUntilChanged(), skip(1)), this._updateMargins]).subscribe(([opened]) => {
63
+ let init = false;
64
+ this._toggleSub.subscription = combineLatest([this.opened$.pipe(distinctUntilChanged()), this._updateMargins]).subscribe(([opened]) => {
62
65
  let { right } = this.container._contentMargins;
63
66
  this.container.updateContentMargins();
64
67
  setTimeout(() => {
@@ -69,14 +72,19 @@ export class DbxMapboxLayoutComponent extends SubscriptionObject {
69
72
  right = (right || 0) * flip;
70
73
  const element = this.content.nativeElement;
71
74
  const width = element.clientWidth;
72
- const easeTo = this.dbxMapboxMapStore
73
- .calculateNextCenterOffsetWithScreenMarginChange({
75
+ const margin = {
74
76
  leftMargin: 0,
75
77
  rightMargin: right,
76
78
  fullWidth: width
77
- })
78
- .pipe(first(), map((center) => ({ to: { center, duration: 3200, essential: false } })));
79
- this.dbxMapboxMapStore.easeTo(easeTo);
79
+ };
80
+ const easeTo = this.dbxMapboxMapStore.calculateNextCenterOffsetWithScreenMarginChange(margin).pipe(first(), map((center) => ({ to: { center, duration: 3200, essential: false } })));
81
+ this.dbxMapboxMapStore.setMargin(opened ? margin : undefined);
82
+ if (!init) {
83
+ this.dbxMapboxMapStore.easeTo(easeTo);
84
+ }
85
+ else {
86
+ init = true;
87
+ }
80
88
  });
81
89
  });
82
90
  }
@@ -87,6 +95,7 @@ export class DbxMapboxLayoutComponent extends SubscriptionObject {
87
95
  this._openToggle.complete();
88
96
  this._color.complete();
89
97
  this._toggleSub.destroy();
98
+ this._forceHasContent.complete();
90
99
  }
91
100
  toggleDrawer(open) {
92
101
  if (open == null) {
@@ -104,6 +113,11 @@ export class DbxMapboxLayoutComponent extends SubscriptionObject {
104
113
  this._openToggle.next(opened);
105
114
  }
106
115
  }
116
+ set hasContent(hasContent) {
117
+ if (hasContent != null) {
118
+ this._forceHasContent.next(hasContent);
119
+ }
120
+ }
107
121
  set drawerColor(color) {
108
122
  this._color.next(color);
109
123
  }
@@ -112,7 +126,7 @@ export class DbxMapboxLayoutComponent extends SubscriptionObject {
112
126
  }
113
127
  }
114
128
  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{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" }] });
129
+ DbxMapboxLayoutComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.2", type: DbxMapboxLayoutComponent, selector: "dbx-mapbox-layout", inputs: { side: "side", opened: "opened", hasContent: "hasContent", 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{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" }] });
116
130
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxMapboxLayoutComponent, decorators: [{
117
131
  type: Component,
118
132
  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{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"] }]
@@ -126,7 +140,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImpor
126
140
  type: Input
127
141
  }], opened: [{
128
142
  type: Input
143
+ }], hasContent: [{
144
+ type: Input
129
145
  }], drawerColor: [{
130
146
  type: Input
131
147
  }] } });
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"]}
148
+ //# 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":"AAAA,OAAO,EAAQ,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,WAAW,EAAE,YAAY,EAAE,GAAG,EAAE,oBAAoB,EAAE,eAAe,EAAE,aAAa,EAAE,OAAO,EAAc,MAAM,MAAM,CAAC;AACpK,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAqB,SAAS,EAAE,MAAM,eAAe,CAAC;AAC3F,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAEnD,OAAO,EAAE,kBAAkB,EAAiB,MAAM,kBAAkB,CAAC;AAErE,OAAO,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;;;;;;;;;AAK/D;;;;;;GAMG;AAMH,MAAM,OAAO,wBAAyB,SAAQ,kBAAkB;IA6D9D,YAAqB,iBAAoC;QACvD,KAAK,EAAE,CAAC;QADW,sBAAiB,GAAjB,iBAAiB,CAAmB;QAtDjD,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;QAC/B,mBAAc,GAAG,IAAI,OAAO,EAAQ,CAAC;QACrC,qBAAgB,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QACvD,UAAK,GAAG,IAAI,eAAe,CAAsB,OAAO,CAAC,CAAC;QAC1D,gBAAW,GAAG,IAAI,eAAe,CAAU,IAAI,CAAC,CAAC;QACjD,WAAM,GAAG,IAAI,eAAe,CAAuB,SAAS,CAAC,CAAC;QAC9D,eAAU,GAAG,IAAI,kBAAkB,EAAE,CAAC;QAErC,UAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,oBAAoB,EAAE,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;QAEhE,gBAAW,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CACpG,GAAG,CAAC,CAAC,CAAC,UAAU,EAAE,eAAe,CAAC,EAAE,EAAE,CAAC,UAAU,IAAI,eAAe,CAAC,EACrE,oBAAoB,EAAE,EACtB,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QAEO,YAAO,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CACzE,GAAG,CAAC,CAAC,CAAC,UAAU,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,UAAU,IAAI,IAAI,CAAC,EAC/C,oBAAoB,EAAE,EACtB,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QAEO,cAAS,GAAgC,IAAI,CAAC,KAAK,CAAC,IAAI,CAC/D,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,EAC7C,oBAAoB,EAAE,EACtB,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QAEO,mBAAc,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI;QAC1G,EAAE;QACF,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,UAAU,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,mBAAmB,CAAC,GAAG,IAAI,IAAI,UAAU,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAC/I,oBAAoB,EAAE,EACtB,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QAEO,yBAAoB,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI;QACnG,EAAE;QACF,GAAG,CAAC,CAAC,CAAC,UAAU,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC,EACvD,oBAAoB,EAAE,EACtB,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QAEO,gBAAW,GAAuB,aAAa,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CACvF,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,MAAM,CAAC,EAAE,EAAE;YACrB,IAAI,KAAK,GAAG,CAAC,eAAe,EAAE,cAAc,CAAC,CAAC;YAE9C,IAAI,IAAI,KAAK,MAAM,EAAE;gBACnB,KAAK,GAAG,KAAK,CAAC,OAAO,EAAE,CAAC;aACzB;YAED,OAAO,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACtC,CAAC,CAAC,CACH,CAAC;IAIF,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,YAAY,GACf,IAAI,CAAC,KAAK,CAAC,IAAI,CACb,SAAS,CAAC,GAAG,EAAE,CACb,IAAI,CAAC,QAAQ,CAAC,IAAI,CAChB,YAAY,CAAC,GAAG,EAAE,SAAS,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,EAC/D,GAAG,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,EACd,SAAS,CAAC,GAAG,CAAC,CACf,CACF,CAEJ,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YACrB,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;gBAClD,CAAC,CAAC,MAAM,EAAE,CAAC;gBAEX,eAAe;gBACf,IAAI,MAAM,KAAK,GAAG,EAAE;oBAClB,UAAU,CAAC,GAAG,EAAE;wBACd,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;oBAC7B,CAAC,CAAC,CAAC;iBACJ;YACH,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,IAAI,IAAI,GAAG,KAAK,CAAC;QAEjB,IAAI,CAAC,UAAU,CAAC,YAAY,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,oBAAoB,EAAE,CAAC,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,EAAE;YACpI,IAAI,EAAE,KAAK,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC;YAE/C,IAAI,CAAC,SAAS,CAAC,oBAAoB,EAAE,CAAC;YAEtC,UAAU,CAAC,GAAG,EAAE;gBACd,MAAM,IAAI,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBAE7B,IAAI,MAAM,EAAE;oBACV,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC,KAAK,CAAC;iBAC9C;gBAED,KAAK,GAAG,CAAC,KAAK,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC;gBAE5B,MAAM,OAAO,GAAgB,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC;gBACxD,MAAM,KAAK,GAAG,OAAO,CAAC,WAAW,CAAC;gBAElC,MAAM,MAAM,GAAG;oBACb,UAAU,EAAE,CAAC;oBACb,WAAW,EAAE,KAAK;oBAClB,SAAS,EAAE,KAAK;iBACjB,CAAC;gBAEF,MAAM,MAAM,GAA6B,IAAI,CAAC,iBAAiB,CAAC,+CAA+C,CAAC,MAAM,CAAC,CAAC,IAAI,CAC1H,KAAK,EAAE,EACP,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,EAAmB,CAAA,CAAC,CACxF,CAAC;gBAEF,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;gBAE9D,IAAI,CAAC,IAAI,EAAE;oBACT,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;iBACvC;qBAAM;oBACL,IAAI,GAAG,IAAI,CAAC;iBACb;YACH,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;QACzB,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAC;QAC/B,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;QACtB,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC;QAC5B,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;QACvB,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;QAC1B,IAAI,CAAC,gBAAgB,CAAC,QAAQ,EAAE,CAAC;IACnC,CAAC;IAED,YAAY,CAAC,IAAc;QACzB,IAAI,IAAI,IAAI,IAAI,EAAE;YAChB,IAAI,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;SAChC;QAED,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,IACI,IAAI,CAAC,IAAgC;QACvC,IAAI,IAAI,IAAI,IAAI,EAAE;YAChB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SACvB;IACH,CAAC;IAED,IACI,MAAM,CAAC,MAAsB;QAC/B,IAAI,MAAM,IAAI,IAAI,EAAE;YAClB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SAC/B;IACH,CAAC;IAED,IACI,UAAU,CAAC,UAA0B;QACvC,IAAI,UAAU,IAAI,IAAI,EAAE;YACtB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SACxC;IACH,CAAC;IAED,IACI,WAAW,CAAC,KAA2B;QACzC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC1B,CAAC;IAED,SAAS,CAAC,KAAmB;QAC3B,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;IACvB,CAAC;;qHAhLU,wBAAwB;yGAAxB,wBAAwB,sMACxB,kBAAkB,gHAGC,UAAU,kEC5B1C,g6BAcA;2FDUa,wBAAwB;kBALpC,SAAS;+BACE,mBAAmB;wGAMpB,SAAS;sBADjB,SAAS;uBAAC,kBAAkB;gBAIpB,OAAO;sBADf,SAAS;uBAAC,SAAS,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,IAAI,EAAE;gBAiJpD,IAAI;sBADP,KAAK;gBAQF,MAAM;sBADT,KAAK;gBAQF,UAAU;sBADb,KAAK;gBAQF,WAAW;sBADd,KAAK","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 _forceHasContent = new BehaviorSubject<boolean>(false);\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 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 = combineLatest([this.opened$.pipe(distinctUntilChanged()), 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 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\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 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();\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,97 @@
1
+ import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
2
+ import { getValueFromGetter } from '@dereekb/util';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/common";
5
+ import * as i2 from "@angular/material/icon";
6
+ import * as i3 from "@dereekb/dbx-web";
7
+ import * as i4 from "ngx-mapbox-gl";
8
+ export class DbxMapboxMarkerComponent {
9
+ constructor() { }
10
+ get marker() {
11
+ return this._marker;
12
+ }
13
+ set marker(marker) {
14
+ this._marker = marker;
15
+ }
16
+ get latLng() {
17
+ return this._marker?.latLng;
18
+ }
19
+ get anchor() {
20
+ return this._marker?.anchor;
21
+ }
22
+ get label() {
23
+ return this._marker?.label;
24
+ }
25
+ get icon() {
26
+ return this._marker?.icon;
27
+ }
28
+ get style() {
29
+ let width = 0;
30
+ let height = 0;
31
+ const size = this._marker?.size || 'medium';
32
+ if (typeof size === 'number') {
33
+ width = size;
34
+ }
35
+ else {
36
+ switch (size) {
37
+ case 'small':
38
+ width = 18;
39
+ break;
40
+ case 'medium':
41
+ width = 24;
42
+ break;
43
+ case 'large':
44
+ width = 32;
45
+ break;
46
+ case 'tall':
47
+ width = 24;
48
+ height = 32;
49
+ break;
50
+ }
51
+ }
52
+ if (!height) {
53
+ height = width;
54
+ }
55
+ const imageInput = this._marker?.image;
56
+ const image = imageInput ? (typeof imageInput === 'string' ? imageInput : getValueFromGetter(imageInput, width)) : undefined;
57
+ let style = {
58
+ ...this._marker?.style,
59
+ width: width + 'px',
60
+ height: height + 'px',
61
+ 'font-size': width + 'px',
62
+ 'background-image': image
63
+ };
64
+ return style;
65
+ }
66
+ }
67
+ DbxMapboxMarkerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxMapboxMarkerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
68
+ DbxMapboxMarkerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.2", type: DbxMapboxMarkerComponent, selector: "dbx-mapbox-marker", inputs: { marker: "marker" }, ngImport: i0, template: `
69
+ <mgl-marker *ngIf="marker" [lngLat]="latLng">
70
+ <dbx-anchor [anchor]="anchor">
71
+ <div class="dbx-mapbox-marker">
72
+ <div class="dbx-mapbox-marker-content" [ngStyle]="style">
73
+ <mat-icon *ngIf="icon">{{ icon }}</mat-icon>
74
+ </div>
75
+ <div class="dbx-mapbox-marker-label" *ngIf="label">{{ label }}</div>
76
+ </div>
77
+ </dbx-anchor>
78
+ </mgl-marker>
79
+ `, isInline: true, styles: [".dbx-mapbox-marker{display:flex;align-items:center;flex-direction:column;font-weight:700}.dbx-mapbox-marker .dbx-mapbox-marker-content{display:flex;align-items:center;justify-content:center}.dbx-mapbox-marker .dbx-mapbox-marker-content mat-icon{width:100%;height:100%;font-size:inherit}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i3.DbxAnchorComponent, selector: "dbx-anchor, [dbx-anchor]", inputs: ["block"] }, { kind: "component", type: i4.MarkerComponent, selector: "mgl-marker", inputs: ["offset", "anchor", "clickTolerance", "feature", "lngLat", "draggable", "popupShown", "className", "pitchAlignment", "rotationAlignment"], outputs: ["markerDragStart", "markerDragEnd", "markerDrag", "dragStart", "dragEnd", "drag"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
80
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxMapboxMarkerComponent, decorators: [{
81
+ type: Component,
82
+ args: [{ selector: 'dbx-mapbox-marker', template: `
83
+ <mgl-marker *ngIf="marker" [lngLat]="latLng">
84
+ <dbx-anchor [anchor]="anchor">
85
+ <div class="dbx-mapbox-marker">
86
+ <div class="dbx-mapbox-marker-content" [ngStyle]="style">
87
+ <mat-icon *ngIf="icon">{{ icon }}</mat-icon>
88
+ </div>
89
+ <div class="dbx-mapbox-marker-label" *ngIf="label">{{ label }}</div>
90
+ </div>
91
+ </dbx-anchor>
92
+ </mgl-marker>
93
+ `, changeDetection: ChangeDetectionStrategy.OnPush, styles: [".dbx-mapbox-marker{display:flex;align-items:center;flex-direction:column;font-weight:700}.dbx-mapbox-marker .dbx-mapbox-marker-content{display:flex;align-items:center;justify-content:center}.dbx-mapbox-marker .dbx-mapbox-marker-content mat-icon{width:100%;height:100%;font-size:inherit}\n"] }]
94
+ }], ctorParameters: function () { return []; }, propDecorators: { marker: [{
95
+ type: Input
96
+ }] } });
97
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwYm94Lm1hcmtlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL21hcGJveC9zcmMvbGliL21hcGJveC5tYXJrZXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTFFLE9BQU8sRUFBNEIsa0JBQWtCLEVBQWlDLE1BQU0sZUFBZSxDQUFDOzs7Ozs7QUFtRDVHLE1BQU0sT0FBTyx3QkFBd0I7SUFZbkMsZ0JBQWUsQ0FBQztJQVRoQixJQUNJLE1BQU07UUFDUixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUM7SUFDdEIsQ0FBQztJQUVELElBQUksTUFBTSxDQUFDLE1BQThCO1FBQ3ZDLElBQUksQ0FBQyxPQUFPLEdBQUcsTUFBTSxDQUFDO0lBQ3hCLENBQUM7SUFJRCxJQUFJLE1BQU07UUFDUixPQUFPLElBQUksQ0FBQyxPQUFPLEVBQUUsTUFBTSxDQUFDO0lBQzlCLENBQUM7SUFFRCxJQUFJLE1BQU07UUFDUixPQUFPLElBQUksQ0FBQyxPQUFPLEVBQUUsTUFBTSxDQUFDO0lBQzlCLENBQUM7SUFFRCxJQUFJLEtBQUs7UUFDUCxPQUFPLElBQUksQ0FBQyxPQUFPLEVBQUUsS0FBSyxDQUFDO0lBQzdCLENBQUM7SUFFRCxJQUFJLElBQUk7UUFDTixPQUFPLElBQUksQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDO0lBQzVCLENBQUM7SUFFRCxJQUFJLEtBQUs7UUFDUCxJQUFJLEtBQUssR0FBVyxDQUFDLENBQUM7UUFDdEIsSUFBSSxNQUFNLEdBQVcsQ0FBQyxDQUFDO1FBRXZCLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxPQUFPLEVBQUUsSUFBSSxJQUFJLFFBQVEsQ0FBQztRQUU1QyxJQUFJLE9BQU8sSUFBSSxLQUFLLFFBQVEsRUFBRTtZQUM1QixLQUFLLEdBQUcsSUFBSSxDQUFDO1NBQ2Q7YUFBTTtZQUNMLFFBQVEsSUFBSSxFQUFFO2dCQUNaLEtBQUssT0FBTztvQkFDVixLQUFLLEdBQUcsRUFBRSxDQUFDO29CQUNYLE1BQU07Z0JBQ1IsS0FBSyxRQUFRO29CQUNYLEtBQUssR0FBRyxFQUFFLENBQUM7b0JBQ1gsTUFBTTtnQkFDUixLQUFLLE9BQU87b0JBQ1YsS0FBSyxHQUFHLEVBQUUsQ0FBQztvQkFDWCxNQUFNO2dCQUNSLEtBQUssTUFBTTtvQkFDVCxLQUFLLEdBQUcsRUFBRSxDQUFDO29CQUNYLE1BQU0sR0FBRyxFQUFFLENBQUM7b0JBQ1osTUFBTTthQUNUO1NBQ0Y7UUFFRCxJQUFJLENBQUMsTUFBTSxFQUFFO1lBQ1gsTUFBTSxHQUFHLEtBQUssQ0FBQztTQUNoQjtRQUVELE1BQU0sVUFBVSxHQUFHLElBQUksQ0FBQyxPQUFPLEVBQUUsS0FBSyxDQUFDO1FBQ3ZDLE1BQU0sS0FBSyxHQUFHLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLFVBQVUsS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsa0JBQWtCLENBQUMsVUFBVSxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQztRQUU3SCxJQUFJLEtBQUssR0FBRztZQUNWLEdBQUcsSUFBSSxDQUFDLE9BQU8sRUFBRSxLQUFLO1lBQ3RCLEtBQUssRUFBRSxLQUFLLEdBQUcsSUFBSTtZQUNuQixNQUFNLEVBQUUsTUFBTSxHQUFHLElBQUk7WUFDckIsV0FBVyxFQUFFLEtBQUssR0FBRyxJQUFJO1lBQ3pCLGtCQUFrQixFQUFFLEtBQUs7U0FDMUIsQ0FBQztRQUVGLE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQzs7cUhBeEVVLHdCQUF3Qjt5R0FBeEIsd0JBQXdCLHVGQWZ6Qjs7Ozs7Ozs7Ozs7R0FXVDsyRkFJVSx3QkFBd0I7a0JBakJwQyxTQUFTOytCQUNFLG1CQUFtQixZQUNuQjs7Ozs7Ozs7Ozs7R0FXVCxtQkFFZ0IsdUJBQXVCLENBQUMsTUFBTTswRUFNM0MsTUFBTTtzQkFEVCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENsaWNrYWJsZUFuY2hvciB9IGZyb20gJ0BkZXJlZWtiL2RieC1jb3JlJztcbmltcG9ydCB7IEZhY3RvcnlXaXRoUmVxdWlyZWRJbnB1dCwgZ2V0VmFsdWVGcm9tR2V0dGVyLCBMYXRMbmdQb2ludFJlZiwgTWF5YmUsIFBpeGVscyB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuXG4vKipcbiAqIERieE1hcGJveE1hcmtlclNpemUuIE51bWJlcnMgYXJlIGNvbnZlcnRlZCB0byBwaXhlbHMuXG4gKi9cbmV4cG9ydCB0eXBlIERieE1hcGJveE1hcmtlclNpemUgPSAnc21hbGwnIHwgJ21lZGl1bScgfCAnbGFyZ2UnIHwgJ3RhbGwnIHwgUGl4ZWxzO1xuXG5leHBvcnQgaW50ZXJmYWNlIERieE1hcGJveE1hcmtlciBleHRlbmRzIExhdExuZ1BvaW50UmVmIHtcbiAgLyoqXG4gICAqIGljb25cbiAgICovXG4gIGljb24/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBsYWJlbFxuICAgKi9cbiAgbGFiZWw/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBJbWFnZSBVUkxcbiAgICovXG4gIGltYWdlPzogc3RyaW5nIHwgRmFjdG9yeVdpdGhSZXF1aXJlZElucHV0PHN0cmluZywgUGl4ZWxzPjtcbiAgLyoqXG4gICAqIFNpemUgb2YgdGhlIG1hcmtlci5cbiAgICovXG4gIHNpemU/OiBEYnhNYXBib3hNYXJrZXJTaXplO1xuICAvKipcbiAgICpcbiAgICovXG4gIGFuY2hvcj86IENsaWNrYWJsZUFuY2hvcjtcbiAgLyoqXG4gICAqIEFkZGl0aW9uYWwgb2JqZWN0IHN0eWxpbmdcbiAgICovXG4gIHN0eWxlPzogb2JqZWN0O1xufVxuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdkYngtbWFwYm94LW1hcmtlcicsXG4gIHRlbXBsYXRlOiBgXG4gICAgPG1nbC1tYXJrZXIgKm5nSWY9XCJtYXJrZXJcIiBbbG5nTGF0XT1cImxhdExuZ1wiPlxuICAgICAgPGRieC1hbmNob3IgW2FuY2hvcl09XCJhbmNob3JcIj5cbiAgICAgICAgPGRpdiBjbGFzcz1cImRieC1tYXBib3gtbWFya2VyXCI+XG4gICAgICAgICAgPGRpdiBjbGFzcz1cImRieC1tYXBib3gtbWFya2VyLWNvbnRlbnRcIiBbbmdTdHlsZV09XCJzdHlsZVwiPlxuICAgICAgICAgICAgPG1hdC1pY29uICpuZ0lmPVwiaWNvblwiPnt7IGljb24gfX08L21hdC1pY29uPlxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgIDxkaXYgY2xhc3M9XCJkYngtbWFwYm94LW1hcmtlci1sYWJlbFwiICpuZ0lmPVwibGFiZWxcIj57eyBsYWJlbCB9fTwvZGl2PlxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvZGJ4LWFuY2hvcj5cbiAgICA8L21nbC1tYXJrZXI+XG4gIGAsXG4gIHN0eWxlVXJsczogWycuL21hcGJveC5tYXJrZXIuY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgRGJ4TWFwYm94TWFya2VyQ29tcG9uZW50IHtcbiAgcHJpdmF0ZSBfbWFya2VyITogTWF5YmU8RGJ4TWFwYm94TWFya2VyPjtcblxuICBASW5wdXQoKVxuICBnZXQgbWFya2VyKCkge1xuICAgIHJldHVybiB0aGlzLl9tYXJrZXI7XG4gIH1cblxuICBzZXQgbWFya2VyKG1hcmtlcjogTWF5YmU8RGJ4TWFwYm94TWFya2VyPikge1xuICAgIHRoaXMuX21hcmtlciA9IG1hcmtlcjtcbiAgfVxuXG4gIGNvbnN0cnVjdG9yKCkge31cblxuICBnZXQgbGF0TG5nKCkge1xuICAgIHJldHVybiB0aGlzLl9tYXJrZXI/LmxhdExuZztcbiAgfVxuXG4gIGdldCBhbmNob3IoKSB7XG4gICAgcmV0dXJuIHRoaXMuX21hcmtlcj8uYW5jaG9yO1xuICB9XG5cbiAgZ2V0IGxhYmVsKCkge1xuICAgIHJldHVybiB0aGlzLl9tYXJrZXI/LmxhYmVsO1xuICB9XG5cbiAgZ2V0IGljb24oKSB7XG4gICAgcmV0dXJuIHRoaXMuX21hcmtlcj8uaWNvbjtcbiAgfVxuXG4gIGdldCBzdHlsZSgpIHtcbiAgICBsZXQgd2lkdGg6IG51bWJlciA9IDA7XG4gICAgbGV0IGhlaWdodDogbnVtYmVyID0gMDtcblxuICAgIGNvbnN0IHNpemUgPSB0aGlzLl9tYXJrZXI/LnNpemUgfHwgJ21lZGl1bSc7XG5cbiAgICBpZiAodHlwZW9mIHNpemUgPT09ICdudW1iZXInKSB7XG4gICAgICB3aWR0aCA9IHNpemU7XG4gICAgfSBlbHNlIHtcbiAgICAgIHN3aXRjaCAoc2l6ZSkge1xuICAgICAgICBjYXNlICdzbWFsbCc6XG4gICAgICAgICAgd2lkdGggPSAxODtcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSAnbWVkaXVtJzpcbiAgICAgICAgICB3aWR0aCA9IDI0O1xuICAgICAgICAgIGJyZWFrO1xuICAgICAgICBjYXNlICdsYXJnZSc6XG4gICAgICAgICAgd2lkdGggPSAzMjtcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSAndGFsbCc6XG4gICAgICAgICAgd2lkdGggPSAyNDtcbiAgICAgICAgICBoZWlnaHQgPSAzMjtcbiAgICAgICAgICBicmVhaztcbiAgICAgIH1cbiAgICB9XG5cbiAgICBpZiAoIWhlaWdodCkge1xuICAgICAgaGVpZ2h0ID0gd2lkdGg7XG4gICAgfVxuXG4gICAgY29uc3QgaW1hZ2VJbnB1dCA9IHRoaXMuX21hcmtlcj8uaW1hZ2U7XG4gICAgY29uc3QgaW1hZ2UgPSBpbWFnZUlucHV0ID8gKHR5cGVvZiBpbWFnZUlucHV0ID09PSAnc3RyaW5nJyA/IGltYWdlSW5wdXQgOiBnZXRWYWx1ZUZyb21HZXR0ZXIoaW1hZ2VJbnB1dCwgd2lkdGgpKSA6IHVuZGVmaW5lZDtcblxuICAgIGxldCBzdHlsZSA9IHtcbiAgICAgIC4uLnRoaXMuX21hcmtlcj8uc3R5bGUsXG4gICAgICB3aWR0aDogd2lkdGggKyAncHgnLFxuICAgICAgaGVpZ2h0OiBoZWlnaHQgKyAncHgnLFxuICAgICAgJ2ZvbnQtc2l6ZSc6IHdpZHRoICsgJ3B4JyxcbiAgICAgICdiYWNrZ3JvdW5kLWltYWdlJzogaW1hZ2VcbiAgICB9O1xuXG4gICAgcmV0dXJuIHN0eWxlO1xuICB9XG59XG4iXX0=
@@ -9,4 +9,9 @@ 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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwYm94LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9tYXBib3gvc3JjL2xpYi9tYXBib3gudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBS0EsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQXVCO0lBQ3JELEVBQUU7SUFDRixvQ0FBb0M7SUFDcEMscUNBQXFDO0lBQ3JDLGtDQUFrQztJQUNsQyxpQ0FBaUM7SUFDakMscUNBQXFDO0lBQ3JDLDhDQUE4QztJQUM5QywwQ0FBMEM7SUFDMUMsNENBQTRDO0NBQzdDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBMYXRMbmdQb2ludElucHV0LCBMYXRMbmdCb3VuZElucHV0IH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5pbXBvcnQgKiBhcyBNYXBib3hHbCBmcm9tICdtYXBib3gtZ2wnO1xuXG5leHBvcnQgdHlwZSBLbm93bk1hcGJveFN0eWxlID0gJ21hcGJveDovL3N0eWxlcy9tYXBib3gvc3RyZWV0cy12MTEnIHwgJ21hcGJveDovL3N0eWxlcy9tYXBib3gvb3V0ZG9vcnMtdjExJyB8ICdtYXBib3g6Ly9zdHlsZXMvbWFwYm94L2xpZ2h0LXYxMCcgfCAnbWFwYm94Oi8vc3R5bGVzL21hcGJveC9kYXJrLXYxMCcgfCAnbWFwYm94Oi8vc3R5bGVzL21hcGJveC9zYXRlbGxpdGUtdjknIHwgJ21hcGJveDovL3N0eWxlcy9tYXBib3gvc2F0ZWxsaXRlLXN0cmVldHMtdjExJyB8ICdtYXBib3g6Ly9zdHlsZXMvbWFwYm94L25hdmlnYXRpb24tZGF5LXYxJyB8ICdtYXBib3g6Ly9zdHlsZXMvbWFwYm94L25hdmlnYXRpb24tbmlnaHQtdjEnO1xuXG5leHBvcnQgY29uc3QgS05PV05fTUFQQk9YX1NUWUxFUzogS25vd25NYXBib3hTdHlsZVtdID0gW1xuICAvL1xuICAnbWFwYm94Oi8vc3R5bGVzL21hcGJveC9zdHJlZXRzLXYxMScsXG4gICdtYXBib3g6Ly9zdHlsZXMvbWFwYm94L291dGRvb3JzLXYxMScsXG4gICdtYXBib3g6Ly9zdHlsZXMvbWFwYm94L2xpZ2h0LXYxMCcsXG4gICdtYXBib3g6Ly9zdHlsZXMvbWFwYm94L2RhcmstdjEwJyxcbiAgJ21hcGJveDovL3N0eWxlcy9tYXBib3gvc2F0ZWxsaXRlLXY5JyxcbiAgJ21hcGJveDovL3N0eWxlcy9tYXBib3gvc2F0ZWxsaXRlLXN0cmVldHMtdjExJyxcbiAgJ21hcGJveDovL3N0eWxlcy9tYXBib3gvbmF2aWdhdGlvbi1kYXktdjEnLFxuICAnbWFwYm94Oi8vc3R5bGVzL21hcGJveC9uYXZpZ2F0aW9uLW5pZ2h0LXYxJ1xuXTtcblxuZXhwb3J0IHR5cGUgTWFwYm94Wm9vbUxldmVsID0gbnVtYmVyO1xuZXhwb3J0IHR5cGUgTWFwYm94UGl0Y2ggPSBudW1iZXI7XG5leHBvcnQgdHlwZSBNYXBib3hCZWFyaW5nID0gbnVtYmVyO1xuXG5leHBvcnQgdHlwZSBEYnhNYXBib3hDbGlja0V2ZW50ID0gTWFwYm94R2wuTWFwTW91c2VFdmVudCAmIE1hcGJveEdsLkV2ZW50RGF0YTtcblxuZXhwb3J0IGludGVyZmFjZSBNYXBib3hTdHlsZUNvbmZpZyB7XG4gIHN0eWxlOiBNYXBib3hHbC5TdHlsZSB8IHN0cmluZztcbiAgb3B0aW9ucz86IHtcbiAgICBkaWZmPzogYm9vbGVhbiB8IHVuZGVmaW5lZDtcbiAgICBsb2NhbElkZW9ncmFwaEZvbnRGYW1pbHk/OiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gIH07XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWFwYm94Rml0Qm91bmRzIHtcbiAgYm91bmRzOiBMYXRMbmdCb3VuZElucHV0O1xuICBvcHRpb25zPzogbWFwYm94Z2wuRml0Qm91bmRzT3B0aW9ucztcbiAgZXZlbnREYXRhPzogbWFwYm94Z2wuRXZlbnREYXRhO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1hcGJveEp1bXBUb1Bvc2l0aW9uT3B0aW9ucyBleHRlbmRzIE9taXQ8TWFwYm94R2wuQ2FtZXJhT3B0aW9ucywgJ2NlbnRlcic+IHtcbiAgY2VudGVyOiBMYXRMbmdQb2ludElucHV0O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1hcGJveEp1bXBUbyB7XG4gIGNlbnRlcj86IExhdExuZ1BvaW50SW5wdXQ7XG4gIHRvPzogTWFwYm94SnVtcFRvUG9zaXRpb25PcHRpb25zO1xuICBldmVudERhdGE/OiBtYXBib3hnbC5FdmVudERhdGE7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWFwYm94RWFzZVRvUG9zaXRpb25PcHRpb25zIGV4dGVuZHMgT21pdDxNYXBib3hHbC5FYXNlVG9PcHRpb25zLCAnY2VudGVyJz4sIE1hcGJveEp1bXBUb1Bvc2l0aW9uT3B0aW9ucyB7fVxuXG5leHBvcnQgaW50ZXJmYWNlIE1hcGJveEVhc2VUbyB7XG4gIGNlbnRlcj86IExhdExuZ1BvaW50SW5wdXQ7XG4gIHRvPzogTWFwYm94RWFzZVRvUG9zaXRpb25PcHRpb25zO1xuICBldmVudERhdGE/OiBtYXBib3hnbC5FdmVudERhdGE7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWFwYm94Rmx5VG9Qb3NpdGlvbk9wdGlvbnMgZXh0ZW5kcyBPbWl0PE1hcGJveEdsLkZseVRvT3B0aW9ucywgJ2NlbnRlcic+LCBNYXBib3hKdW1wVG9Qb3NpdGlvbk9wdGlvbnMge31cblxuZXhwb3J0IGludGVyZmFjZSBNYXBib3hGbHlUbyB7XG4gIGNlbnRlcj86IExhdExuZ1BvaW50SW5wdXQ7XG4gIHRvPzogTWFwYm94Rmx5VG9Qb3NpdGlvbk9wdGlvbnM7XG4gIGV2ZW50RGF0YT86IG1hcGJveGdsLkV2ZW50RGF0YTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNYXBib3hSb3RhdGVUbyB7XG4gIGJlYXJpbmc6IE1hcGJveEJlYXJpbmc7XG4gIG9wdGlvbnM/OiBtYXBib3hnbC5BbmltYXRpb25PcHRpb25zO1xuICBldmVudERhdGE/OiBtYXBib3hnbC5FdmVudERhdGE7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWFwYm94UmVzZXROb3J0aCB7XG4gIG9wdGlvbnM/OiBtYXBib3hnbC5BbmltYXRpb25PcHRpb25zO1xuICBldmVudERhdGE/OiBtYXBib3hnbC5FdmVudERhdGE7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWFwYm94UmVzZXROb3J0aFBpdGNoIHtcbiAgb3B0aW9ucz86IG1hcGJveGdsLkFuaW1hdGlvbk9wdGlvbnM7XG4gIGV2ZW50RGF0YT86IG1hcGJveGdsLkV2ZW50RGF0YTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNYXBib3hTbmFwVG9Ob3J0aCB7XG4gIG9wdGlvbnM/OiBtYXBib3hnbC5BbmltYXRpb25PcHRpb25zO1xuICBldmVudERhdGE/OiBtYXBib3hnbC5FdmVudERhdGE7XG59XG4iXX0=
12
+ export const MAPBOX_MIN_ZOOM_LEVEL = 0;
13
+ export const MAPBOX_MAX_ZOOM_LEVEL = 22;
14
+ export function mapboxZoomLevel(input) {
15
+ return Math.min(Math.max(input, MAPBOX_MIN_ZOOM_LEVEL), MAPBOX_MAX_ZOOM_LEVEL);
16
+ }
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwYm94LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9tYXBib3gvc3JjL2xpYi9tYXBib3gudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBS0EsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQXVCO0lBQ3JELEVBQUU7SUFDRixvQ0FBb0M7SUFDcEMscUNBQXFDO0lBQ3JDLGtDQUFrQztJQUNsQyxpQ0FBaUM7SUFDakMscUNBQXFDO0lBQ3JDLDhDQUE4QztJQUM5QywwQ0FBMEM7SUFDMUMsNENBQTRDO0NBQzdDLENBQUM7QUFJRixNQUFNLENBQUMsTUFBTSxxQkFBcUIsR0FBb0IsQ0FBQyxDQUFDO0FBQ3hELE1BQU0sQ0FBQyxNQUFNLHFCQUFxQixHQUFvQixFQUFFLENBQUM7QUFFekQsTUFBTSxVQUFVLGVBQWUsQ0FBQyxLQUFhO0lBQzNDLE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEtBQUssRUFBRSxxQkFBcUIsQ0FBQyxFQUFFLHFCQUFxQixDQUFDLENBQUM7QUFDakYsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IExhdExuZ1BvaW50SW5wdXQsIExhdExuZ0JvdW5kSW5wdXQsIFpvb21MZXZlbCB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuaW1wb3J0ICogYXMgTWFwYm94R2wgZnJvbSAnbWFwYm94LWdsJztcblxuZXhwb3J0IHR5cGUgS25vd25NYXBib3hTdHlsZSA9ICdtYXBib3g6Ly9zdHlsZXMvbWFwYm94L3N0cmVldHMtdjExJyB8ICdtYXBib3g6Ly9zdHlsZXMvbWFwYm94L291dGRvb3JzLXYxMScgfCAnbWFwYm94Oi8vc3R5bGVzL21hcGJveC9saWdodC12MTAnIHwgJ21hcGJveDovL3N0eWxlcy9tYXBib3gvZGFyay12MTAnIHwgJ21hcGJveDovL3N0eWxlcy9tYXBib3gvc2F0ZWxsaXRlLXY5JyB8ICdtYXBib3g6Ly9zdHlsZXMvbWFwYm94L3NhdGVsbGl0ZS1zdHJlZXRzLXYxMScgfCAnbWFwYm94Oi8vc3R5bGVzL21hcGJveC9uYXZpZ2F0aW9uLWRheS12MScgfCAnbWFwYm94Oi8vc3R5bGVzL21hcGJveC9uYXZpZ2F0aW9uLW5pZ2h0LXYxJztcblxuZXhwb3J0IGNvbnN0IEtOT1dOX01BUEJPWF9TVFlMRVM6IEtub3duTWFwYm94U3R5bGVbXSA9IFtcbiAgLy9cbiAgJ21hcGJveDovL3N0eWxlcy9tYXBib3gvc3RyZWV0cy12MTEnLFxuICAnbWFwYm94Oi8vc3R5bGVzL21hcGJveC9vdXRkb29ycy12MTEnLFxuICAnbWFwYm94Oi8vc3R5bGVzL21hcGJveC9saWdodC12MTAnLFxuICAnbWFwYm94Oi8vc3R5bGVzL21hcGJveC9kYXJrLXYxMCcsXG4gICdtYXBib3g6Ly9zdHlsZXMvbWFwYm94L3NhdGVsbGl0ZS12OScsXG4gICdtYXBib3g6Ly9zdHlsZXMvbWFwYm94L3NhdGVsbGl0ZS1zdHJlZXRzLXYxMScsXG4gICdtYXBib3g6Ly9zdHlsZXMvbWFwYm94L25hdmlnYXRpb24tZGF5LXYxJyxcbiAgJ21hcGJveDovL3N0eWxlcy9tYXBib3gvbmF2aWdhdGlvbi1uaWdodC12MSdcbl07XG5cbmV4cG9ydCB0eXBlIE1hcGJveFpvb21MZXZlbCA9IFpvb21MZXZlbDtcblxuZXhwb3J0IGNvbnN0IE1BUEJPWF9NSU5fWk9PTV9MRVZFTDogTWFwYm94Wm9vbUxldmVsID0gMDtcbmV4cG9ydCBjb25zdCBNQVBCT1hfTUFYX1pPT01fTEVWRUw6IE1hcGJveFpvb21MZXZlbCA9IDIyO1xuXG5leHBvcnQgZnVuY3Rpb24gbWFwYm94Wm9vbUxldmVsKGlucHV0OiBudW1iZXIpOiBNYXBib3hab29tTGV2ZWwge1xuICByZXR1cm4gTWF0aC5taW4oTWF0aC5tYXgoaW5wdXQsIE1BUEJPWF9NSU5fWk9PTV9MRVZFTCksIE1BUEJPWF9NQVhfWk9PTV9MRVZFTCk7XG59XG5cbmV4cG9ydCB0eXBlIE1hcGJveFBpdGNoID0gbnVtYmVyO1xuZXhwb3J0IHR5cGUgTWFwYm94QmVhcmluZyA9IG51bWJlcjtcblxuZXhwb3J0IHR5cGUgRGJ4TWFwYm94Q2xpY2tFdmVudCA9IE1hcGJveEdsLk1hcE1vdXNlRXZlbnQgJiBNYXBib3hHbC5FdmVudERhdGE7XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWFwYm94U3R5bGVDb25maWcge1xuICBzdHlsZTogTWFwYm94R2wuU3R5bGUgfCBzdHJpbmc7XG4gIG9wdGlvbnM/OiB7XG4gICAgZGlmZj86IGJvb2xlYW4gfCB1bmRlZmluZWQ7XG4gICAgbG9jYWxJZGVvZ3JhcGhGb250RmFtaWx5Pzogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICB9O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1hcGJveEZpdEJvdW5kcyB7XG4gIGJvdW5kczogTGF0TG5nQm91bmRJbnB1dDtcbiAgb3B0aW9ucz86IG1hcGJveGdsLkZpdEJvdW5kc09wdGlvbnM7XG4gIGV2ZW50RGF0YT86IG1hcGJveGdsLkV2ZW50RGF0YTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNYXBib3hKdW1wVG9Qb3NpdGlvbk9wdGlvbnMgZXh0ZW5kcyBPbWl0PE1hcGJveEdsLkNhbWVyYU9wdGlvbnMsICdjZW50ZXInPiB7XG4gIGNlbnRlcjogTGF0TG5nUG9pbnRJbnB1dDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNYXBib3hKdW1wVG8ge1xuICBjZW50ZXI/OiBMYXRMbmdQb2ludElucHV0O1xuICB0bz86IE1hcGJveEp1bXBUb1Bvc2l0aW9uT3B0aW9ucztcbiAgZXZlbnREYXRhPzogbWFwYm94Z2wuRXZlbnREYXRhO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1hcGJveEVhc2VUb1Bvc2l0aW9uT3B0aW9ucyBleHRlbmRzIE9taXQ8TWFwYm94R2wuRWFzZVRvT3B0aW9ucywgJ2NlbnRlcic+LCBNYXBib3hKdW1wVG9Qb3NpdGlvbk9wdGlvbnMge31cblxuZXhwb3J0IGludGVyZmFjZSBNYXBib3hFYXNlVG8ge1xuICBjZW50ZXI/OiBMYXRMbmdQb2ludElucHV0O1xuICB0bz86IE1hcGJveEVhc2VUb1Bvc2l0aW9uT3B0aW9ucztcbiAgZXZlbnREYXRhPzogbWFwYm94Z2wuRXZlbnREYXRhO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1hcGJveEZseVRvUG9zaXRpb25PcHRpb25zIGV4dGVuZHMgT21pdDxNYXBib3hHbC5GbHlUb09wdGlvbnMsICdjZW50ZXInPiwgTWFwYm94SnVtcFRvUG9zaXRpb25PcHRpb25zIHt9XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWFwYm94Rmx5VG8ge1xuICBjZW50ZXI/OiBMYXRMbmdQb2ludElucHV0O1xuICB0bz86IE1hcGJveEZseVRvUG9zaXRpb25PcHRpb25zO1xuICBldmVudERhdGE/OiBtYXBib3hnbC5FdmVudERhdGE7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWFwYm94Um90YXRlVG8ge1xuICBiZWFyaW5nOiBNYXBib3hCZWFyaW5nO1xuICBvcHRpb25zPzogbWFwYm94Z2wuQW5pbWF0aW9uT3B0aW9ucztcbiAgZXZlbnREYXRhPzogbWFwYm94Z2wuRXZlbnREYXRhO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1hcGJveFJlc2V0Tm9ydGgge1xuICBvcHRpb25zPzogbWFwYm94Z2wuQW5pbWF0aW9uT3B0aW9ucztcbiAgZXZlbnREYXRhPzogbWFwYm94Z2wuRXZlbnREYXRhO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1hcGJveFJlc2V0Tm9ydGhQaXRjaCB7XG4gIG9wdGlvbnM/OiBtYXBib3hnbC5BbmltYXRpb25PcHRpb25zO1xuICBldmVudERhdGE/OiBtYXBib3hnbC5FdmVudERhdGE7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWFwYm94U25hcFRvTm9ydGgge1xuICBvcHRpb25zPzogbWFwYm94Z2wuQW5pbWF0aW9uT3B0aW9ucztcbiAgZXZlbnREYXRhPzogbWFwYm94Z2wuRXZlbnREYXRhO1xufVxuIl19
@@ -10,13 +10,19 @@ import { MatButtonModule } from '@angular/material/button';
10
10
  import { MatIconModule } from '@angular/material/icon';
11
11
  import { AngularResizeEventModule } from 'angular-resize-event';
12
12
  import { DbxMapboxMenuComponent } from './mapbox.menu.component';
13
+ import { DbxMapboxMapStoreInjectionBlockDirective } from './mapbox.store.provide';
14
+ import { DbxMapboxMarkerComponent } from './mapbox.marker.component';
15
+ import { NgxMapboxGLModule } from 'ngx-mapbox-gl';
16
+ import { DbxRouterAnchorModule } from '@dereekb/dbx-web';
13
17
  import * as i0 from "@angular/core";
14
18
  const declarations = [
15
19
  //
16
20
  DbxMapboxMapDirective,
17
21
  DbxMapboxLayoutComponent,
18
22
  DbxMapboxLayoutDrawerComponent,
19
- DbxMapboxMenuComponent
23
+ DbxMapboxMenuComponent,
24
+ DbxMapboxMarkerComponent,
25
+ DbxMapboxMapStoreInjectionBlockDirective
20
26
  ];
21
27
  export class DbxMapboxModule {
22
28
  static forRoot(config) {
@@ -37,19 +43,25 @@ DbxMapboxModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version
37
43
  DbxMapboxMapDirective,
38
44
  DbxMapboxLayoutComponent,
39
45
  DbxMapboxLayoutDrawerComponent,
40
- DbxMapboxMenuComponent], imports: [
46
+ DbxMapboxMenuComponent,
47
+ DbxMapboxMarkerComponent,
48
+ DbxMapboxMapStoreInjectionBlockDirective], imports: [
41
49
  //
42
50
  CommonModule,
43
51
  MatSidenavModule,
44
52
  DbxInjectionComponentModule,
45
53
  MatButtonModule,
46
54
  MatIconModule,
47
- AngularResizeEventModule], exports: [
55
+ AngularResizeEventModule,
56
+ DbxRouterAnchorModule,
57
+ NgxMapboxGLModule], exports: [
48
58
  //
49
59
  DbxMapboxMapDirective,
50
60
  DbxMapboxLayoutComponent,
51
61
  DbxMapboxLayoutDrawerComponent,
52
- DbxMapboxMenuComponent] });
62
+ DbxMapboxMenuComponent,
63
+ DbxMapboxMarkerComponent,
64
+ DbxMapboxMapStoreInjectionBlockDirective] });
53
65
  DbxMapboxModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxMapboxModule, imports: [
54
66
  //
55
67
  CommonModule,
@@ -57,7 +69,9 @@ DbxMapboxModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version
57
69
  DbxInjectionComponentModule,
58
70
  MatButtonModule,
59
71
  MatIconModule,
60
- AngularResizeEventModule] });
72
+ AngularResizeEventModule,
73
+ DbxRouterAnchorModule,
74
+ NgxMapboxGLModule] });
61
75
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxMapboxModule, decorators: [{
62
76
  type: NgModule,
63
77
  args: [{
@@ -68,10 +82,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImpor
68
82
  DbxInjectionComponentModule,
69
83
  MatButtonModule,
70
84
  MatIconModule,
71
- AngularResizeEventModule
85
+ AngularResizeEventModule,
86
+ DbxRouterAnchorModule,
87
+ NgxMapboxGLModule
72
88
  ],
73
89
  declarations,
74
90
  exports: declarations
75
91
  }]
76
92
  }] });
77
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwYm94Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvbWFwYm94L3NyYy9saWIvbWFwYm94Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXVCLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM5RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDckUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ25ELE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ3JFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzdELE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBQ2xGLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ2hFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDaEUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0seUJBQXlCLENBQUM7O0FBRWpFLE1BQU0sWUFBWSxHQUFHO0lBQ25CLEVBQUU7SUFDRixxQkFBcUI7SUFDckIsd0JBQXdCO0lBQ3hCLDhCQUE4QjtJQUM5QixzQkFBc0I7Q0FDdkIsQ0FBQztBQWVGLE1BQU0sT0FBTyxlQUFlO0lBQzFCLE1BQU0sQ0FBQyxPQUFPLENBQUMsTUFBdUI7UUFDcEMsT0FBTztZQUNMLFFBQVEsRUFBRSxlQUFlO1lBQ3pCLFNBQVMsRUFBRTtnQkFDVDtvQkFDRSxPQUFPLEVBQUUsZUFBZTtvQkFDeEIsUUFBUSxFQUFFLE1BQU07aUJBQ2pCO2FBQ0Y7U0FDRixDQUFDO0lBQ0osQ0FBQzs7NEdBWFUsZUFBZTs2R0FBZixlQUFlO1FBcEIxQixFQUFFO1FBQ0YscUJBQXFCO1FBQ3JCLHdCQUF3QjtRQUN4Qiw4QkFBOEI7UUFDOUIsc0JBQXNCO1FBS3BCLEVBQUU7UUFDRixZQUFZO1FBQ1osZ0JBQWdCO1FBQ2hCLDJCQUEyQjtRQUMzQixlQUFlO1FBQ2YsYUFBYTtRQUNiLHdCQUF3QjtRQWYxQixFQUFFO1FBQ0YscUJBQXFCO1FBQ3JCLHdCQUF3QjtRQUN4Qiw4QkFBOEI7UUFDOUIsc0JBQXNCOzZHQWdCWCxlQUFlO1FBWHhCLEVBQUU7UUFDRixZQUFZO1FBQ1osZ0JBQWdCO1FBQ2hCLDJCQUEyQjtRQUMzQixlQUFlO1FBQ2YsYUFBYTtRQUNiLHdCQUF3QjsyRkFLZixlQUFlO2tCQWIzQixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRTt3QkFDUCxFQUFFO3dCQUNGLFlBQVk7d0JBQ1osZ0JBQWdCO3dCQUNoQiwyQkFBMkI7d0JBQzNCLGVBQWU7d0JBQ2YsYUFBYTt3QkFDYix3QkFBd0I7cUJBQ3pCO29CQUNELFlBQVk7b0JBQ1osT0FBTyxFQUFFLFlBQVk7aUJBQ3RCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTW9kdWxlV2l0aFByb3ZpZGVycywgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBEYnhNYXBib3hNYXBEaXJlY3RpdmUgfSBmcm9tICcuL21hcGJveC5zdG9yZS5tYXAuZGlyZWN0aXZlJztcbmltcG9ydCB7IERieE1hcGJveENvbmZpZyB9IGZyb20gJy4vbWFwYm94LnNlcnZpY2UnO1xuaW1wb3J0IHsgRGJ4TWFwYm94TGF5b3V0Q29tcG9uZW50IH0gZnJvbSAnLi9tYXBib3gubGF5b3V0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBNYXRTaWRlbmF2TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc2lkZW5hdic7XG5pbXBvcnQgeyBEYnhNYXBib3hMYXlvdXREcmF3ZXJDb21wb25lbnQgfSBmcm9tICcuL21hcGJveC5sYXlvdXQuZHJhd2VyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEYnhJbmplY3Rpb25Db21wb25lbnRNb2R1bGUgfSBmcm9tICdAZGVyZWVrYi9kYngtY29yZSc7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHsgQW5ndWxhclJlc2l6ZUV2ZW50TW9kdWxlIH0gZnJvbSAnYW5ndWxhci1yZXNpemUtZXZlbnQnO1xuaW1wb3J0IHsgRGJ4TWFwYm94TWVudUNvbXBvbmVudCB9IGZyb20gJy4vbWFwYm94Lm1lbnUuY29tcG9uZW50JztcblxuY29uc3QgZGVjbGFyYXRpb25zID0gW1xuICAvL1xuICBEYnhNYXBib3hNYXBEaXJlY3RpdmUsXG4gIERieE1hcGJveExheW91dENvbXBvbmVudCxcbiAgRGJ4TWFwYm94TGF5b3V0RHJhd2VyQ29tcG9uZW50LFxuICBEYnhNYXBib3hNZW51Q29tcG9uZW50XG5dO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXG4gICAgLy9cbiAgICBDb21tb25Nb2R1bGUsXG4gICAgTWF0U2lkZW5hdk1vZHVsZSxcbiAgICBEYnhJbmplY3Rpb25Db21wb25lbnRNb2R1bGUsXG4gICAgTWF0QnV0dG9uTW9kdWxlLFxuICAgIE1hdEljb25Nb2R1bGUsXG4gICAgQW5ndWxhclJlc2l6ZUV2ZW50TW9kdWxlXG4gIF0sXG4gIGRlY2xhcmF0aW9ucyxcbiAgZXhwb3J0czogZGVjbGFyYXRpb25zXG59KVxuZXhwb3J0IGNsYXNzIERieE1hcGJveE1vZHVsZSB7XG4gIHN0YXRpYyBmb3JSb290KGNvbmZpZzogRGJ4TWFwYm94Q29uZmlnKTogTW9kdWxlV2l0aFByb3ZpZGVyczxEYnhNYXBib3hNb2R1bGU+IHtcbiAgICByZXR1cm4ge1xuICAgICAgbmdNb2R1bGU6IERieE1hcGJveE1vZHVsZSxcbiAgICAgIHByb3ZpZGVyczogW1xuICAgICAgICB7XG4gICAgICAgICAgcHJvdmlkZTogRGJ4TWFwYm94Q29uZmlnLFxuICAgICAgICAgIHVzZVZhbHVlOiBjb25maWdcbiAgICAgICAgfVxuICAgICAgXVxuICAgIH07XG4gIH1cbn1cbiJdfQ==
93
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwYm94Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvbWFwYm94L3NyYy9saWIvbWFwYm94Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXVCLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM5RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDckUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ25ELE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ3JFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzdELE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBQ2xGLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ2hFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDaEUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDakUsT0FBTyxFQUFFLHdDQUF3QyxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDbEYsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDckUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLGtCQUFrQixDQUFDOztBQUV6RCxNQUFNLFlBQVksR0FBRztJQUNuQixFQUFFO0lBQ0YscUJBQXFCO0lBQ3JCLHdCQUF3QjtJQUN4Qiw4QkFBOEI7SUFDOUIsc0JBQXNCO0lBQ3RCLHdCQUF3QjtJQUN4Qix3Q0FBd0M7Q0FDekMsQ0FBQztBQWlCRixNQUFNLE9BQU8sZUFBZTtJQUMxQixNQUFNLENBQUMsT0FBTyxDQUFDLE1BQXVCO1FBQ3BDLE9BQU87WUFDTCxRQUFRLEVBQUUsZUFBZTtZQUN6QixTQUFTLEVBQUU7Z0JBQ1Q7b0JBQ0UsT0FBTyxFQUFFLGVBQWU7b0JBQ3hCLFFBQVEsRUFBRSxNQUFNO2lCQUNqQjthQUNGO1NBQ0YsQ0FBQztJQUNKLENBQUM7OzRHQVhVLGVBQWU7NkdBQWYsZUFBZTtRQXhCMUIsRUFBRTtRQUNGLHFCQUFxQjtRQUNyQix3QkFBd0I7UUFDeEIsOEJBQThCO1FBQzlCLHNCQUFzQjtRQUN0Qix3QkFBd0I7UUFDeEIsd0NBQXdDO1FBS3RDLEVBQUU7UUFDRixZQUFZO1FBQ1osZ0JBQWdCO1FBQ2hCLDJCQUEyQjtRQUMzQixlQUFlO1FBQ2YsYUFBYTtRQUNiLHdCQUF3QjtRQUN4QixxQkFBcUI7UUFDckIsaUJBQWlCO1FBbkJuQixFQUFFO1FBQ0YscUJBQXFCO1FBQ3JCLHdCQUF3QjtRQUN4Qiw4QkFBOEI7UUFDOUIsc0JBQXNCO1FBQ3RCLHdCQUF3QjtRQUN4Qix3Q0FBd0M7NkdBa0I3QixlQUFlO1FBYnhCLEVBQUU7UUFDRixZQUFZO1FBQ1osZ0JBQWdCO1FBQ2hCLDJCQUEyQjtRQUMzQixlQUFlO1FBQ2YsYUFBYTtRQUNiLHdCQUF3QjtRQUN4QixxQkFBcUI7UUFDckIsaUJBQWlCOzJGQUtSLGVBQWU7a0JBZjNCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFO3dCQUNQLEVBQUU7d0JBQ0YsWUFBWTt3QkFDWixnQkFBZ0I7d0JBQ2hCLDJCQUEyQjt3QkFDM0IsZUFBZTt3QkFDZixhQUFhO3dCQUNiLHdCQUF3Qjt3QkFDeEIscUJBQXFCO3dCQUNyQixpQkFBaUI7cUJBQ2xCO29CQUNELFlBQVk7b0JBQ1osT0FBTyxFQUFFLFlBQVk7aUJBQ3RCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTW9kdWxlV2l0aFByb3ZpZGVycywgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBEYnhNYXBib3hNYXBEaXJlY3RpdmUgfSBmcm9tICcuL21hcGJveC5zdG9yZS5tYXAuZGlyZWN0aXZlJztcbmltcG9ydCB7IERieE1hcGJveENvbmZpZyB9IGZyb20gJy4vbWFwYm94LnNlcnZpY2UnO1xuaW1wb3J0IHsgRGJ4TWFwYm94TGF5b3V0Q29tcG9uZW50IH0gZnJvbSAnLi9tYXBib3gubGF5b3V0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBNYXRTaWRlbmF2TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc2lkZW5hdic7XG5pbXBvcnQgeyBEYnhNYXBib3hMYXlvdXREcmF3ZXJDb21wb25lbnQgfSBmcm9tICcuL21hcGJveC5sYXlvdXQuZHJhd2VyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEYnhJbmplY3Rpb25Db21wb25lbnRNb2R1bGUgfSBmcm9tICdAZGVyZWVrYi9kYngtY29yZSc7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHsgQW5ndWxhclJlc2l6ZUV2ZW50TW9kdWxlIH0gZnJvbSAnYW5ndWxhci1yZXNpemUtZXZlbnQnO1xuaW1wb3J0IHsgRGJ4TWFwYm94TWVudUNvbXBvbmVudCB9IGZyb20gJy4vbWFwYm94Lm1lbnUuY29tcG9uZW50JztcbmltcG9ydCB7IERieE1hcGJveE1hcFN0b3JlSW5qZWN0aW9uQmxvY2tEaXJlY3RpdmUgfSBmcm9tICcuL21hcGJveC5zdG9yZS5wcm92aWRlJztcbmltcG9ydCB7IERieE1hcGJveE1hcmtlckNvbXBvbmVudCB9IGZyb20gJy4vbWFwYm94Lm1hcmtlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgTmd4TWFwYm94R0xNb2R1bGUgfSBmcm9tICduZ3gtbWFwYm94LWdsJztcbmltcG9ydCB7IERieFJvdXRlckFuY2hvck1vZHVsZSB9IGZyb20gJ0BkZXJlZWtiL2RieC13ZWInO1xuXG5jb25zdCBkZWNsYXJhdGlvbnMgPSBbXG4gIC8vXG4gIERieE1hcGJveE1hcERpcmVjdGl2ZSxcbiAgRGJ4TWFwYm94TGF5b3V0Q29tcG9uZW50LFxuICBEYnhNYXBib3hMYXlvdXREcmF3ZXJDb21wb25lbnQsXG4gIERieE1hcGJveE1lbnVDb21wb25lbnQsXG4gIERieE1hcGJveE1hcmtlckNvbXBvbmVudCxcbiAgRGJ4TWFwYm94TWFwU3RvcmVJbmplY3Rpb25CbG9ja0RpcmVjdGl2ZVxuXTtcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIC8vXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIE1hdFNpZGVuYXZNb2R1bGUsXG4gICAgRGJ4SW5qZWN0aW9uQ29tcG9uZW50TW9kdWxlLFxuICAgIE1hdEJ1dHRvbk1vZHVsZSxcbiAgICBNYXRJY29uTW9kdWxlLFxuICAgIEFuZ3VsYXJSZXNpemVFdmVudE1vZHVsZSxcbiAgICBEYnhSb3V0ZXJBbmNob3JNb2R1bGUsXG4gICAgTmd4TWFwYm94R0xNb2R1bGVcbiAgXSxcbiAgZGVjbGFyYXRpb25zLFxuICBleHBvcnRzOiBkZWNsYXJhdGlvbnNcbn0pXG5leHBvcnQgY2xhc3MgRGJ4TWFwYm94TW9kdWxlIHtcbiAgc3RhdGljIGZvclJvb3QoY29uZmlnOiBEYnhNYXBib3hDb25maWcpOiBNb2R1bGVXaXRoUHJvdmlkZXJzPERieE1hcGJveE1vZHVsZT4ge1xuICAgIHJldHVybiB7XG4gICAgICBuZ01vZHVsZTogRGJ4TWFwYm94TW9kdWxlLFxuICAgICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIHtcbiAgICAgICAgICBwcm92aWRlOiBEYnhNYXBib3hDb25maWcsXG4gICAgICAgICAgdXNlVmFsdWU6IGNvbmZpZ1xuICAgICAgICB9XG4gICAgICBdXG4gICAgfTtcbiAgfVxufVxuIl19
@@ -4,7 +4,7 @@ export class DbxMapboxConfig {
4
4
  }
5
5
  export const DEFAULT_MAPBOX_STYLE = 'mapbox://styles/mapbox/streets-v11';
6
6
  export const DEFAULT_MAPBOX_CENTER = [30.2690138665, -97.7408297965];
7
- export const DEFAULT_MAPBOX_ZOOM = 12;
7
+ export const DEFAULT_MAPBOX_ZOOM = 8;
8
8
  export const DEFAULT_MAPBOX_MAP_STORE_TIMER_REFRESH_PERIOD = 200;
9
9
  export class DbxMapboxService {
10
10
  constructor(config) {
@@ -33,4 +33,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImpor
33
33
  }], ctorParameters: function () { return [{ type: DbxMapboxConfig, decorators: [{
34
34
  type: Optional
35
35
  }] }]; } });
36
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwYm94LnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL21hcGJveC9zcmMvbGliL21hcGJveC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUtyRCxNQUFNLE9BQU8sZUFBZTtDQUszQjtBQUVELE1BQU0sQ0FBQyxNQUFNLG9CQUFvQixHQUFxQixvQ0FBb0MsQ0FBQztBQUMzRixNQUFNLENBQUMsTUFBTSxxQkFBcUIsR0FBcUIsQ0FBQyxhQUFhLEVBQUUsQ0FBQyxhQUFhLENBQUMsQ0FBQztBQUN2RixNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBb0IsRUFBRSxDQUFDO0FBQ3ZELE1BQU0sQ0FBQyxNQUFNLDZDQUE2QyxHQUFpQixHQUFHLENBQUM7QUFLL0UsTUFBTSxPQUFPLGdCQUFnQjtJQUczQixZQUF3QixNQUF1QjtRQUM3QyxJQUFJLENBQUMsT0FBTyxHQUFHLE1BQU0sSUFBSSxFQUFFLENBQUM7SUFDOUIsQ0FBQztJQUVELElBQUksWUFBWTtRQUNkLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxZQUFZLElBQUksb0JBQW9CLENBQUM7SUFDM0QsQ0FBQztJQUVELElBQUksV0FBVztRQUNiLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxXQUFXLElBQUksbUJBQW1CLENBQUM7SUFDekQsQ0FBQztJQUVELElBQUksYUFBYTtRQUNmLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLElBQUkscUJBQXFCLENBQUM7SUFDN0QsQ0FBQztJQUVELElBQUksZ0NBQWdDO1FBQ2xDLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyx5QkFBeUIsSUFBSSw2Q0FBNkMsQ0FBQztJQUNqRyxDQUFDOzs2R0FyQlUsZ0JBQWdCLGtCQUdLLGVBQWU7aUhBSHBDLGdCQUFnQixjQUZmLE1BQU07MkZBRVAsZ0JBQWdCO2tCQUg1QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQjswREFJaUMsZUFBZTswQkFBbEMsUUFBUSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIE9wdGlvbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBMYXRMbmdQb2ludElucHV0LCBNaWxsaXNlY29uZHMgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcbmltcG9ydCB7IE1hcGJveE9wdGlvbnMgfSBmcm9tICdtYXBib3gtZ2wnO1xuaW1wb3J0IHsgS25vd25NYXBib3hTdHlsZSwgTWFwYm94Wm9vbUxldmVsIH0gZnJvbSAnLi9tYXBib3gnO1xuXG5leHBvcnQgY2xhc3MgRGJ4TWFwYm94Q29uZmlnIHtcbiAgcmVhZG9ubHkgZGVmYXVsdFN0eWxlPzogTWFwYm94T3B0aW9uc1snc3R5bGUnXTtcbiAgcmVhZG9ubHkgZGVmYXVsdFpvb20/OiBNYXBib3hab29tTGV2ZWw7XG4gIHJlYWRvbmx5IGRlZmF1bHRDZW50ZXI/OiBMYXRMbmdQb2ludElucHV0O1xuICByZWFkb25seSBkZWZhdWx0U3RvcmVSZWZyZXNoUGVyaW9kPzogbnVtYmVyO1xufVxuXG5leHBvcnQgY29uc3QgREVGQVVMVF9NQVBCT1hfU1RZTEU6IEtub3duTWFwYm94U3R5bGUgPSAnbWFwYm94Oi8vc3R5bGVzL21hcGJveC9zdHJlZXRzLXYxMSc7XG5leHBvcnQgY29uc3QgREVGQVVMVF9NQVBCT1hfQ0VOVEVSOiBMYXRMbmdQb2ludElucHV0ID0gWzMwLjI2OTAxMzg2NjUsIC05Ny43NDA4Mjk3OTY1XTtcbmV4cG9ydCBjb25zdCBERUZBVUxUX01BUEJPWF9aT09NOiBNYXBib3hab29tTGV2ZWwgPSAxMjtcbmV4cG9ydCBjb25zdCBERUZBVUxUX01BUEJPWF9NQVBfU1RPUkVfVElNRVJfUkVGUkVTSF9QRVJJT0Q6IE1pbGxpc2Vjb25kcyA9IDIwMDtcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgRGJ4TWFwYm94U2VydmljZSB7XG4gIHByaXZhdGUgcmVhZG9ubHkgX2NvbmZpZzogRGJ4TWFwYm94Q29uZmlnO1xuXG4gIGNvbnN0cnVjdG9yKEBPcHRpb25hbCgpIGNvbmZpZzogRGJ4TWFwYm94Q29uZmlnKSB7XG4gICAgdGhpcy5fY29uZmlnID0gY29uZmlnID8/IHt9O1xuICB9XG5cbiAgZ2V0IGRlZmF1bHRTdHlsZSgpIHtcbiAgICByZXR1cm4gdGhpcy5fY29uZmlnLmRlZmF1bHRTdHlsZSA/PyBERUZBVUxUX01BUEJPWF9TVFlMRTtcbiAgfVxuXG4gIGdldCBkZWZhdWx0Wm9vbSgpOiBNYXBib3hab29tTGV2ZWwge1xuICAgIHJldHVybiB0aGlzLl9jb25maWcuZGVmYXVsdFpvb20gPz8gREVGQVVMVF9NQVBCT1hfWk9PTTtcbiAgfVxuXG4gIGdldCBkZWZhdWx0Q2VudGVyKCk6IExhdExuZ1BvaW50SW5wdXQge1xuICAgIHJldHVybiB0aGlzLl9jb25maWcuZGVmYXVsdENlbnRlciA/PyBERUZBVUxUX01BUEJPWF9DRU5URVI7XG4gIH1cblxuICBnZXQgbWFwYm94TWFwU3RvcmVUaW1lclJlZnJlc2hQZXJpb2QoKTogbnVtYmVyIHtcbiAgICByZXR1cm4gdGhpcy5fY29uZmlnLmRlZmF1bHRTdG9yZVJlZnJlc2hQZXJpb2QgPz8gREVGQVVMVF9NQVBCT1hfTUFQX1NUT1JFX1RJTUVSX1JFRlJFU0hfUEVSSU9EO1xuICB9XG59XG4iXX0=
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwYm94LnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL21hcGJveC9zcmMvbGliL21hcGJveC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUtyRCxNQUFNLE9BQU8sZUFBZTtDQUszQjtBQUVELE1BQU0sQ0FBQyxNQUFNLG9CQUFvQixHQUFxQixvQ0FBb0MsQ0FBQztBQUMzRixNQUFNLENBQUMsTUFBTSxxQkFBcUIsR0FBcUIsQ0FBQyxhQUFhLEVBQUUsQ0FBQyxhQUFhLENBQUMsQ0FBQztBQUN2RixNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBb0IsQ0FBQyxDQUFDO0FBQ3RELE1BQU0sQ0FBQyxNQUFNLDZDQUE2QyxHQUFpQixHQUFHLENBQUM7QUFLL0UsTUFBTSxPQUFPLGdCQUFnQjtJQUczQixZQUF3QixNQUF1QjtRQUM3QyxJQUFJLENBQUMsT0FBTyxHQUFHLE1BQU0sSUFBSSxFQUFFLENBQUM7SUFDOUIsQ0FBQztJQUVELElBQUksWUFBWTtRQUNkLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxZQUFZLElBQUksb0JBQW9CLENBQUM7SUFDM0QsQ0FBQztJQUVELElBQUksV0FBVztRQUNiLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxXQUFXLElBQUksbUJBQW1CLENBQUM7SUFDekQsQ0FBQztJQUVELElBQUksYUFBYTtRQUNmLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLElBQUkscUJBQXFCLENBQUM7SUFDN0QsQ0FBQztJQUVELElBQUksZ0NBQWdDO1FBQ2xDLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyx5QkFBeUIsSUFBSSw2Q0FBNkMsQ0FBQztJQUNqRyxDQUFDOzs2R0FyQlUsZ0JBQWdCLGtCQUdLLGVBQWU7aUhBSHBDLGdCQUFnQixjQUZmLE1BQU07MkZBRVAsZ0JBQWdCO2tCQUg1QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQjswREFJaUMsZUFBZTswQkFBbEMsUUFBUSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIE9wdGlvbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBMYXRMbmdQb2ludElucHV0LCBNaWxsaXNlY29uZHMgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcbmltcG9ydCB7IE1hcGJveE9wdGlvbnMgfSBmcm9tICdtYXBib3gtZ2wnO1xuaW1wb3J0IHsgS25vd25NYXBib3hTdHlsZSwgTWFwYm94Wm9vbUxldmVsIH0gZnJvbSAnLi9tYXBib3gnO1xuXG5leHBvcnQgY2xhc3MgRGJ4TWFwYm94Q29uZmlnIHtcbiAgcmVhZG9ubHkgZGVmYXVsdFN0eWxlPzogTWFwYm94T3B0aW9uc1snc3R5bGUnXTtcbiAgcmVhZG9ubHkgZGVmYXVsdFpvb20/OiBNYXBib3hab29tTGV2ZWw7XG4gIHJlYWRvbmx5IGRlZmF1bHRDZW50ZXI/OiBMYXRMbmdQb2ludElucHV0O1xuICByZWFkb25seSBkZWZhdWx0U3RvcmVSZWZyZXNoUGVyaW9kPzogbnVtYmVyO1xufVxuXG5leHBvcnQgY29uc3QgREVGQVVMVF9NQVBCT1hfU1RZTEU6IEtub3duTWFwYm94U3R5bGUgPSAnbWFwYm94Oi8vc3R5bGVzL21hcGJveC9zdHJlZXRzLXYxMSc7XG5leHBvcnQgY29uc3QgREVGQVVMVF9NQVBCT1hfQ0VOVEVSOiBMYXRMbmdQb2ludElucHV0ID0gWzMwLjI2OTAxMzg2NjUsIC05Ny43NDA4Mjk3OTY1XTtcbmV4cG9ydCBjb25zdCBERUZBVUxUX01BUEJPWF9aT09NOiBNYXBib3hab29tTGV2ZWwgPSA4O1xuZXhwb3J0IGNvbnN0IERFRkFVTFRfTUFQQk9YX01BUF9TVE9SRV9USU1FUl9SRUZSRVNIX1BFUklPRDogTWlsbGlzZWNvbmRzID0gMjAwO1xuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBEYnhNYXBib3hTZXJ2aWNlIHtcbiAgcHJpdmF0ZSByZWFkb25seSBfY29uZmlnOiBEYnhNYXBib3hDb25maWc7XG5cbiAgY29uc3RydWN0b3IoQE9wdGlvbmFsKCkgY29uZmlnOiBEYnhNYXBib3hDb25maWcpIHtcbiAgICB0aGlzLl9jb25maWcgPSBjb25maWcgPz8ge307XG4gIH1cblxuICBnZXQgZGVmYXVsdFN0eWxlKCkge1xuICAgIHJldHVybiB0aGlzLl9jb25maWcuZGVmYXVsdFN0eWxlID8/IERFRkFVTFRfTUFQQk9YX1NUWUxFO1xuICB9XG5cbiAgZ2V0IGRlZmF1bHRab29tKCk6IE1hcGJveFpvb21MZXZlbCB7XG4gICAgcmV0dXJuIHRoaXMuX2NvbmZpZy5kZWZhdWx0Wm9vbSA/PyBERUZBVUxUX01BUEJPWF9aT09NO1xuICB9XG5cbiAgZ2V0IGRlZmF1bHRDZW50ZXIoKTogTGF0TG5nUG9pbnRJbnB1dCB7XG4gICAgcmV0dXJuIHRoaXMuX2NvbmZpZy5kZWZhdWx0Q2VudGVyID8/IERFRkFVTFRfTUFQQk9YX0NFTlRFUjtcbiAgfVxuXG4gIGdldCBtYXBib3hNYXBTdG9yZVRpbWVyUmVmcmVzaFBlcmlvZCgpOiBudW1iZXIge1xuICAgIHJldHVybiB0aGlzLl9jb25maWcuZGVmYXVsdFN0b3JlUmVmcmVzaFBlcmlvZCA/PyBERUZBVUxUX01BUEJPWF9NQVBfU1RPUkVfVElNRVJfUkVGUkVTSF9QRVJJT0Q7XG4gIH1cbn1cbiJdfQ==