@dereekb/dbx-form 9.5.3 → 9.6.0

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 (34) hide show
  1. package/esm2020/mapbox/lib/field/index.mjs +2 -1
  2. package/esm2020/mapbox/lib/field/latlng/latlng.field.component.mjs +54 -26
  3. package/esm2020/mapbox/lib/field/latlng/latlng.field.mjs +8 -4
  4. package/esm2020/mapbox/lib/field/zoom/index.mjs +4 -0
  5. package/esm2020/mapbox/lib/field/zoom/zoom.field.component.mjs +126 -0
  6. package/esm2020/mapbox/lib/field/zoom/zoom.field.mjs +23 -0
  7. package/esm2020/mapbox/lib/field/zoom/zoom.module.mjs +57 -0
  8. package/esm2020/mapbox/lib/mapbox.module.mjs +5 -4
  9. package/fesm2015/dereekb-dbx-form-mapbox.mjs +243 -33
  10. package/fesm2015/dereekb-dbx-form-mapbox.mjs.map +1 -1
  11. package/fesm2020/dereekb-dbx-form-mapbox.mjs +242 -33
  12. package/fesm2020/dereekb-dbx-form-mapbox.mjs.map +1 -1
  13. package/mapbox/esm2020/lib/field/index.mjs +2 -1
  14. package/mapbox/esm2020/lib/field/latlng/latlng.field.component.mjs +54 -26
  15. package/mapbox/esm2020/lib/field/latlng/latlng.field.mjs +8 -4
  16. package/mapbox/esm2020/lib/field/zoom/index.mjs +4 -0
  17. package/mapbox/esm2020/lib/field/zoom/zoom.field.component.mjs +126 -0
  18. package/mapbox/esm2020/lib/field/zoom/zoom.field.mjs +23 -0
  19. package/mapbox/esm2020/lib/field/zoom/zoom.module.mjs +57 -0
  20. package/mapbox/esm2020/lib/mapbox.module.mjs +5 -4
  21. package/mapbox/fesm2015/dereekb-dbx-form-mapbox.mjs +243 -33
  22. package/mapbox/fesm2015/dereekb-dbx-form-mapbox.mjs.map +1 -1
  23. package/mapbox/fesm2020/dereekb-dbx-form-mapbox.mjs +242 -33
  24. package/mapbox/fesm2020/dereekb-dbx-form-mapbox.mjs.map +1 -1
  25. package/mapbox/lib/field/index.d.ts +1 -0
  26. package/mapbox/lib/field/latlng/latlng.field.component.d.ts +28 -8
  27. package/mapbox/lib/field/latlng/latlng.field.d.ts +2 -1
  28. package/mapbox/lib/field/zoom/index.d.ts +3 -0
  29. package/mapbox/lib/field/zoom/zoom.field.component.d.ts +63 -0
  30. package/mapbox/lib/field/zoom/zoom.field.d.ts +6 -0
  31. package/mapbox/lib/field/zoom/zoom.module.d.ts +16 -0
  32. package/mapbox/lib/mapbox.module.d.ts +2 -1
  33. package/mapbox/package.json +4 -4
  34. package/package.json +3 -3
@@ -1,11 +1,11 @@
1
1
  import { CompactContextStore, mapCompactModeObs } from '@dereekb/dbx-web';
2
- import { Component, Optional } from '@angular/core';
2
+ import { Component, NgZone, Optional } from '@angular/core';
3
3
  import { FieldType } from '@ngx-formly/material';
4
- import { first, BehaviorSubject, filter, shareReplay, startWith, switchMap, map } from 'rxjs';
4
+ import { skip, first, BehaviorSubject, filter, shareReplay, startWith, switchMap, map, throttleTime } from 'rxjs';
5
5
  import { filterMaybe, SubscriptionObject } from '@dereekb/rxjs';
6
6
  import { latLngPoint, latLngStringFunction } from '@dereekb/util';
7
7
  import { GeolocationService } from '@ng-web-apis/geolocation';
8
- import { DbxMapboxMapStore } from '@dereekb/dbx-web/mapbox';
8
+ import { DbxMapboxMapStore, provideMapboxStoreIfParentIsUnavailable } from '@dereekb/dbx-web/mapbox';
9
9
  import * as i0 from "@angular/core";
10
10
  import * as i1 from "@dereekb/dbx-web";
11
11
  import * as i2 from "@ng-web-apis/geolocation";
@@ -18,15 +18,18 @@ import * as i8 from "@angular/material/form-field";
18
18
  import * as i9 from "@angular/material/input";
19
19
  import * as i10 from "ngx-mapbox-gl";
20
20
  export class DbxFormMapboxLatLngFieldComponent extends FieldType {
21
- constructor(compact, geolocation$, dbxMapboxMapStore) {
21
+ constructor(compact, geolocation$, dbxMapboxMapStore, ngZone) {
22
22
  super();
23
23
  this.compact = compact;
24
24
  this.geolocation$ = geolocation$;
25
25
  this.dbxMapboxMapStore = dbxMapboxMapStore;
26
+ this.ngZone = ngZone;
26
27
  this.compactClass$ = mapCompactModeObs(this.compact?.mode$, {
27
- compact: 'dbx-texteditor-field-compact'
28
+ compact: 'dbx-mapbox-input-field-compact'
28
29
  });
29
30
  this._sub = new SubscriptionObject();
31
+ this._geoSub = new SubscriptionObject();
32
+ this._centerSub = new SubscriptionObject();
30
33
  this._zoom = new BehaviorSubject(12);
31
34
  this._formControlObs = new BehaviorSubject(undefined);
32
35
  this.formControl$ = this._formControlObs.pipe(filterMaybe());
@@ -53,77 +56,102 @@ export class DbxFormMapboxLatLngFieldComponent extends FieldType {
53
56
  get isReadonlyOrDisabled() {
54
57
  return this.props.readonly || this.disabled;
55
58
  }
59
+ get showMap() {
60
+ return this.field.props.showMap ?? true;
61
+ }
62
+ get recenterTime() {
63
+ return this.field.props.recenterTime || 10 * 1000;
64
+ }
56
65
  ngOnInit() {
57
66
  this._latLngStringFunction = latLngStringFunction(this.field.props.latLngConfig);
58
67
  this._formControlObs.next(this.formControl);
59
68
  this._zoom.next(this.zoom);
60
69
  this.dbxMapboxMapStore.setCenter(this.center$);
61
- this.dbxMapboxMapStore.setZoom(this.zoom$);
70
+ if (this.showMap) {
71
+ // Set zoom only if showMap is true
72
+ this.dbxMapboxMapStore.setZoom(this.zoom$);
73
+ // recenter periodically
74
+ if (this.recenterTime > 0) {
75
+ this._centerSub.subscription = this.dbxMapboxMapStore.center$.pipe(skip(1), throttleTime(this.recenterTime, undefined, { leading: false, trailing: true })).subscribe(() => {
76
+ this.dbxMapboxMapStore.easeTo(this.center$.pipe(first(), map((x) => ({ center: x }))));
77
+ });
78
+ }
79
+ }
80
+ else {
81
+ // use the center of the map to set locations
82
+ this._sub.subscription = this.dbxMapboxMapStore.center$.subscribe((center) => {
83
+ if (!this.isReadonlyOrDisabled) {
84
+ this.ngZone.run(() => this.setValue(center));
85
+ }
86
+ });
87
+ }
62
88
  if (this.props.readonly) {
63
89
  this.formControl.disable();
64
90
  }
65
91
  }
66
92
  ngOnDestroy() {
67
93
  super.ngOnDestroy();
68
- this._formControlObs.complete();
69
- this._zoom.complete();
70
94
  this._sub.destroy();
95
+ this._geoSub.destroy();
96
+ this._zoom.complete();
97
+ this._formControlObs.complete();
98
+ this._centerSub.destroy();
71
99
  }
72
100
  useCurrentLocation() {
73
- this._sub.subscription = this.geolocation$.pipe(first()).subscribe((position) => {
101
+ this._geoSub.subscription = this.geolocation$.pipe(first()).subscribe((position) => {
74
102
  if (position) {
75
103
  const { latitude: lat, longitude: lng } = position.coords;
76
104
  this.setValue({ lat, lng });
77
105
  }
78
106
  });
79
107
  }
80
- onDragEnd(marker) {
108
+ onMarkerDragEnd(marker) {
81
109
  this.setValue(marker.getLngLat());
82
110
  }
83
111
  setValue(latLng) {
84
112
  this.formControl.setValue(latLng ? this._latLngStringFunction(latLng) : latLng);
85
113
  }
86
114
  }
87
- DbxFormMapboxLatLngFieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxFormMapboxLatLngFieldComponent, deps: [{ token: i1.CompactContextStore, optional: true }, { token: i2.GeolocationService }, { token: i3.DbxMapboxMapStore }], target: i0.ɵɵFactoryTarget.Component });
88
- DbxFormMapboxLatLngFieldComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.2", type: DbxFormMapboxLatLngFieldComponent, selector: "ng-component", providers: [DbxMapboxMapStore], usesInheritance: true, ngImport: i0, template: `
89
- <div class="dbx-mapbox-latlng-field" [ngClass]="(compactClass$ | async) ?? ''" [formGroup]="formGroup">
90
- <div class="dbx-mapbox-latlng-field-map">
115
+ DbxFormMapboxLatLngFieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxFormMapboxLatLngFieldComponent, deps: [{ token: i1.CompactContextStore, optional: true }, { token: i2.GeolocationService }, { token: i3.DbxMapboxMapStore }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
116
+ DbxFormMapboxLatLngFieldComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.2", type: DbxFormMapboxLatLngFieldComponent, selector: "ng-component", providers: [provideMapboxStoreIfParentIsUnavailable()], usesInheritance: true, ngImport: i0, template: `
117
+ <div class="dbx-mapbox-input-field" [ngClass]="(compactClass$ | async) ?? ''" [formGroup]="formGroup">
118
+ <div *ngIf="showMap" class="dbx-mapbox-input-field-map">
91
119
  <mgl-map dbxMapboxMap>
92
- <mgl-marker [lngLat]="(latLng$ | async) || [0, 0]" [draggable]="!isReadonlyOrDisabled" (markerDragEnd)="onDragEnd($event)"></mgl-marker>
120
+ <mgl-marker [lngLat]="(latLng$ | async) || [0, 0]" [draggable]="!isReadonlyOrDisabled" (markerDragEnd)="onMarkerDragEnd($event)"></mgl-marker>
93
121
  </mgl-map>
94
122
  </div>
95
- <div class="dbx-mapbox-latlng-field-input">
123
+ <div class="dbx-mapbox-input-field-input">
96
124
  <button mat-icon-button (click)="useCurrentLocation()" [disabled]="isReadonlyOrDisabled">
97
125
  <mat-icon>my_location</mat-icon>
98
126
  </button>
99
- <mat-form-field class="dbx-mapbox-latlng-field-input-field">
127
+ <mat-form-field class="dbx-mapbox-input-field-input-field">
100
128
  <mat-label>Coordinates</mat-label>
101
129
  <input type="text" matInput [placeholder]="placeholder" [formControl]="formControl" />
102
130
  </mat-form-field>
103
131
  </div>
104
132
  </div>
105
- `, isInline: true, styles: [".dbx-mapbox-latlng-field .dbx-mapbox-latlng-field-map{height:220px;width:100%}.dbx-mapbox-latlng-field .dbx-mapbox-latlng-field-map mgl-map{height:100%;width:100%}.dbx-mapbox-latlng-field .dbx-mapbox-latlng-field-input{display:flex;align-items:center}.dbx-mapbox-latlng-field .dbx-mapbox-latlng-field-input .dbx-mapbox-latlng-field-input-field{width:calc(100% - 40px)}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i6.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: "directive", type: i3.DbxMapboxMapDirective, selector: "[dbxMapboxMap]" }, { kind: "directive", type: i7.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i7.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i7.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i7.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i8.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i8.MatLabel, selector: "mat-label" }, { kind: "directive", type: i9.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i10.MapComponent, selector: "mgl-map", inputs: ["accessToken", "collectResourceTiming", "crossSourceCollisions", "customMapboxApiUrl", "fadeDuration", "hash", "refreshExpiredTiles", "failIfMajorPerformanceCaveat", "bearingSnap", "interactive", "pitchWithRotate", "clickTolerance", "attributionControl", "logoPosition", "maxTileCacheSize", "localIdeographFontFamily", "preserveDrawingBuffer", "trackResize", "transformRequest", "bounds", "antialias", "locale", "minZoom", "maxZoom", "minPitch", "maxPitch", "scrollZoom", "dragRotate", "touchPitch", "touchZoomRotate", "doubleClickZoom", "keyboard", "dragPan", "boxZoom", "style", "center", "maxBounds", "zoom", "bearing", "pitch", "fitBoundsOptions", "renderWorldCopies", "projection", "movingMethod", "movingOptions", "fitBounds", "fitScreenCoordinates", "centerWithPanTo", "panToOptions", "cursorStyle"], outputs: ["mapResize", "mapRemove", "mapMouseDown", "mapMouseUp", "mapMouseMove", "mapClick", "mapDblClick", "mapMouseOver", "mapMouseOut", "mapContextMenu", "mapTouchStart", "mapTouchEnd", "mapTouchMove", "mapTouchCancel", "mapWheel", "moveStart", "move", "moveEnd", "mapDragStart", "mapDrag", "mapDragEnd", "zoomStart", "zoomEvt", "zoomEnd", "rotateStart", "rotate", "rotateEnd", "pitchStart", "pitchEvt", "pitchEnd", "boxZoomStart", "boxZoomEnd", "boxZoomCancel", "webGlContextLost", "webGlContextRestored", "mapLoad", "idle", "render", "mapError", "data", "styleData", "sourceData", "dataLoading", "styleDataLoading", "sourceDataLoading", "styleImageMissing", "resize", "remove", "mouseDown", "mouseUp", "mouseMove", "click", "dblClick", "mouseOver", "mouseOut", "contextMenu", "touchStart", "touchEnd", "touchMove", "touchCancel", "wheel", "dragStart", "drag", "dragEnd", "load", "error"] }, { kind: "component", type: i10.MarkerComponent, selector: "mgl-marker", inputs: ["offset", "anchor", "clickTolerance", "feature", "lngLat", "draggable", "popupShown", "className", "pitchAlignment", "rotationAlignment"], outputs: ["markerDragStart", "markerDragEnd", "markerDrag", "dragStart", "dragEnd", "drag"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }] });
133
+ `, isInline: true, styles: [".dbx-mapbox-input-field .dbx-mapbox-input-field-map{height:220px;width:100%}.dbx-mapbox-input-field .dbx-mapbox-input-field-map mgl-map{height:100%;width:100%}.dbx-mapbox-input-field .dbx-mapbox-input-field-input{display:flex;align-items:center}.dbx-mapbox-input-field .dbx-mapbox-input-field-input .dbx-mapbox-input-field-input-field{width:calc(100% - 40px)}.dbx-mapbox-input-field-compact .dbx-latlng-field-input{min-height:120px;height:300px;max-height:calc(var(--vh100) * .5)}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i6.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: "directive", type: i3.DbxMapboxMapDirective, selector: "[dbxMapboxMap]" }, { kind: "directive", type: i7.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i7.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i7.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i7.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i8.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i8.MatLabel, selector: "mat-label" }, { kind: "directive", type: i9.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i10.MapComponent, selector: "mgl-map", inputs: ["accessToken", "collectResourceTiming", "crossSourceCollisions", "customMapboxApiUrl", "fadeDuration", "hash", "refreshExpiredTiles", "failIfMajorPerformanceCaveat", "bearingSnap", "interactive", "pitchWithRotate", "clickTolerance", "attributionControl", "logoPosition", "maxTileCacheSize", "localIdeographFontFamily", "preserveDrawingBuffer", "trackResize", "transformRequest", "bounds", "antialias", "locale", "minZoom", "maxZoom", "minPitch", "maxPitch", "scrollZoom", "dragRotate", "touchPitch", "touchZoomRotate", "doubleClickZoom", "keyboard", "dragPan", "boxZoom", "style", "center", "maxBounds", "zoom", "bearing", "pitch", "fitBoundsOptions", "renderWorldCopies", "projection", "movingMethod", "movingOptions", "fitBounds", "fitScreenCoordinates", "centerWithPanTo", "panToOptions", "cursorStyle"], outputs: ["mapResize", "mapRemove", "mapMouseDown", "mapMouseUp", "mapMouseMove", "mapClick", "mapDblClick", "mapMouseOver", "mapMouseOut", "mapContextMenu", "mapTouchStart", "mapTouchEnd", "mapTouchMove", "mapTouchCancel", "mapWheel", "moveStart", "move", "moveEnd", "mapDragStart", "mapDrag", "mapDragEnd", "zoomStart", "zoomEvt", "zoomEnd", "rotateStart", "rotate", "rotateEnd", "pitchStart", "pitchEvt", "pitchEnd", "boxZoomStart", "boxZoomEnd", "boxZoomCancel", "webGlContextLost", "webGlContextRestored", "mapLoad", "idle", "render", "mapError", "data", "styleData", "sourceData", "dataLoading", "styleDataLoading", "sourceDataLoading", "styleImageMissing", "resize", "remove", "mouseDown", "mouseUp", "mouseMove", "click", "dblClick", "mouseOver", "mouseOut", "contextMenu", "touchStart", "touchEnd", "touchMove", "touchCancel", "wheel", "dragStart", "drag", "dragEnd", "load", "error"] }, { kind: "component", type: i10.MarkerComponent, selector: "mgl-marker", inputs: ["offset", "anchor", "clickTolerance", "feature", "lngLat", "draggable", "popupShown", "className", "pitchAlignment", "rotationAlignment"], outputs: ["markerDragStart", "markerDragEnd", "markerDrag", "dragStart", "dragEnd", "drag"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }] });
106
134
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxFormMapboxLatLngFieldComponent, decorators: [{
107
135
  type: Component,
108
136
  args: [{ template: `
109
- <div class="dbx-mapbox-latlng-field" [ngClass]="(compactClass$ | async) ?? ''" [formGroup]="formGroup">
110
- <div class="dbx-mapbox-latlng-field-map">
137
+ <div class="dbx-mapbox-input-field" [ngClass]="(compactClass$ | async) ?? ''" [formGroup]="formGroup">
138
+ <div *ngIf="showMap" class="dbx-mapbox-input-field-map">
111
139
  <mgl-map dbxMapboxMap>
112
- <mgl-marker [lngLat]="(latLng$ | async) || [0, 0]" [draggable]="!isReadonlyOrDisabled" (markerDragEnd)="onDragEnd($event)"></mgl-marker>
140
+ <mgl-marker [lngLat]="(latLng$ | async) || [0, 0]" [draggable]="!isReadonlyOrDisabled" (markerDragEnd)="onMarkerDragEnd($event)"></mgl-marker>
113
141
  </mgl-map>
114
142
  </div>
115
- <div class="dbx-mapbox-latlng-field-input">
143
+ <div class="dbx-mapbox-input-field-input">
116
144
  <button mat-icon-button (click)="useCurrentLocation()" [disabled]="isReadonlyOrDisabled">
117
145
  <mat-icon>my_location</mat-icon>
118
146
  </button>
119
- <mat-form-field class="dbx-mapbox-latlng-field-input-field">
147
+ <mat-form-field class="dbx-mapbox-input-field-input-field">
120
148
  <mat-label>Coordinates</mat-label>
121
149
  <input type="text" matInput [placeholder]="placeholder" [formControl]="formControl" />
122
150
  </mat-form-field>
123
151
  </div>
124
152
  </div>
125
- `, providers: [DbxMapboxMapStore], styles: [".dbx-mapbox-latlng-field .dbx-mapbox-latlng-field-map{height:220px;width:100%}.dbx-mapbox-latlng-field .dbx-mapbox-latlng-field-map mgl-map{height:100%;width:100%}.dbx-mapbox-latlng-field .dbx-mapbox-latlng-field-input{display:flex;align-items:center}.dbx-mapbox-latlng-field .dbx-mapbox-latlng-field-input .dbx-mapbox-latlng-field-input-field{width:calc(100% - 40px)}\n"] }]
153
+ `, providers: [provideMapboxStoreIfParentIsUnavailable()], styles: [".dbx-mapbox-input-field .dbx-mapbox-input-field-map{height:220px;width:100%}.dbx-mapbox-input-field .dbx-mapbox-input-field-map mgl-map{height:100%;width:100%}.dbx-mapbox-input-field .dbx-mapbox-input-field-input{display:flex;align-items:center}.dbx-mapbox-input-field .dbx-mapbox-input-field-input .dbx-mapbox-input-field-input-field{width:calc(100% - 40px)}.dbx-mapbox-input-field-compact .dbx-latlng-field-input{min-height:120px;height:300px;max-height:calc(var(--vh100) * .5)}\n"] }]
126
154
  }], ctorParameters: function () { return [{ type: i1.CompactContextStore, decorators: [{
127
155
  type: Optional
128
- }] }, { type: i2.GeolocationService }, { type: i3.DbxMapboxMapStore }]; } });
129
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"latlng.field.component.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-form/mapbox/src/lib/field/latlng/latlng.field.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl, FormGroup } from '@angular/forms';\nimport { CompactContextStore, mapCompactModeObs } from '@dereekb/dbx-web';\nimport { Component, OnDestroy, OnInit, Optional } from '@angular/core';\nimport { FieldTypeConfig, FormlyFieldProps } from '@ngx-formly/core';\nimport { FieldType } from '@ngx-formly/material';\nimport { first, BehaviorSubject, filter, shareReplay, startWith, switchMap, map, Observable } from 'rxjs';\nimport { filterMaybe, SubscriptionObject } from '@dereekb/rxjs';\nimport { Maybe, LatLngPoint, LatLngPointFunctionConfig, latLngPoint, LatLngStringFunction, latLngStringFunction } from '@dereekb/util';\nimport { GeolocationService } from '@ng-web-apis/geolocation';\nimport { Marker } from 'mapbox-gl';\nimport { DbxMapboxMapStore } from '@dereekb/dbx-web/mapbox';\n\nexport interface DbxFormMapboxLatLngComponentFieldProps extends FormlyFieldProps {\n  zoom?: number;\n  latLngConfig?: LatLngPointFunctionConfig;\n}\n\n@Component({\n  template: `\n    <div class=\"dbx-mapbox-latlng-field\" [ngClass]=\"(compactClass$ | async) ?? ''\" [formGroup]=\"formGroup\">\n      <div class=\"dbx-mapbox-latlng-field-map\">\n        <mgl-map dbxMapboxMap>\n          <mgl-marker [lngLat]=\"(latLng$ | async) || [0, 0]\" [draggable]=\"!isReadonlyOrDisabled\" (markerDragEnd)=\"onDragEnd($event)\"></mgl-marker>\n        </mgl-map>\n      </div>\n      <div class=\"dbx-mapbox-latlng-field-input\">\n        <button mat-icon-button (click)=\"useCurrentLocation()\" [disabled]=\"isReadonlyOrDisabled\">\n          <mat-icon>my_location</mat-icon>\n        </button>\n        <mat-form-field class=\"dbx-mapbox-latlng-field-input-field\">\n          <mat-label>Coordinates</mat-label>\n          <input type=\"text\" matInput [placeholder]=\"placeholder\" [formControl]=\"formControl\" />\n        </mat-form-field>\n      </div>\n    </div>\n  `,\n  providers: [DbxMapboxMapStore],\n  styleUrls: ['./latlng.field.component.scss']\n})\nexport class DbxFormMapboxLatLngFieldComponent<T extends DbxFormMapboxLatLngComponentFieldProps = DbxFormMapboxLatLngComponentFieldProps> extends FieldType<FieldTypeConfig<T>> implements OnInit, OnDestroy {\n  private _latLngStringFunction!: LatLngStringFunction;\n\n  readonly compactClass$ = mapCompactModeObs(this.compact?.mode$, {\n    compact: 'dbx-texteditor-field-compact'\n  });\n\n  private _sub = new SubscriptionObject();\n  private _zoom = new BehaviorSubject<number>(12);\n\n  private _formControlObs = new BehaviorSubject<Maybe<AbstractControl>>(undefined);\n  readonly formControl$ = this._formControlObs.pipe(filterMaybe());\n\n  readonly value$ = this.formControl$.pipe(\n    switchMap((control) => control.valueChanges.pipe(startWith(control.value))),\n    shareReplay(1)\n  );\n\n  readonly latLng$: Observable<LatLngPoint> = this.value$.pipe(\n    filterMaybe(),\n    map((x) => latLngPoint(x)),\n    filter((x) => x.lat !== 0 && x.lng !== 0),\n    shareReplay(1)\n  );\n\n  readonly center$ = this.latLng$;\n  readonly zoom$ = this._zoom.asObservable();\n\n  constructor(@Optional() readonly compact: CompactContextStore, private readonly geolocation$: GeolocationService, readonly dbxMapboxMapStore: DbxMapboxMapStore) {\n    super();\n  }\n\n  get zoom(): number {\n    return Math.min(this.field.props.zoom || 12, 18);\n  }\n\n  get formGroupName(): string {\n    return this.field.key as string;\n  }\n\n  get formGroup(): FormGroup {\n    return this.form as FormGroup;\n  }\n\n  get label(): Maybe<string> {\n    return this.field.props?.label;\n  }\n\n  get description(): Maybe<string> {\n    return this.props.description;\n  }\n\n  get isReadonlyOrDisabled() {\n    return this.props.readonly || this.disabled;\n  }\n\n  ngOnInit(): void {\n    this._latLngStringFunction = latLngStringFunction(this.field.props.latLngConfig);\n    this._formControlObs.next(this.formControl);\n    this._zoom.next(this.zoom);\n\n    this.dbxMapboxMapStore.setCenter(this.center$);\n    this.dbxMapboxMapStore.setZoom(this.zoom$);\n\n    if (this.props.readonly) {\n      this.formControl.disable();\n    }\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._formControlObs.complete();\n    this._zoom.complete();\n    this._sub.destroy();\n  }\n\n  useCurrentLocation() {\n    this._sub.subscription = this.geolocation$.pipe(first()).subscribe((position) => {\n      if (position) {\n        const { latitude: lat, longitude: lng } = position.coords;\n        this.setValue({ lat, lng });\n      }\n    });\n  }\n\n  onDragEnd(marker: Marker) {\n    this.setValue(marker.getLngLat());\n  }\n\n  setValue(latLng?: Maybe<LatLngPoint>) {\n    this.formControl.setValue(latLng ? this._latLngStringFunction(latLng) : latLng);\n  }\n}\n"]}
156
+ }] }, { type: i2.GeolocationService }, { type: i3.DbxMapboxMapStore }, { type: i0.NgZone }]; } });
157
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"latlng.field.component.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-form/mapbox/src/lib/field/latlng/latlng.field.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl, FormGroup } from '@angular/forms';\nimport { CompactContextStore, mapCompactModeObs } from '@dereekb/dbx-web';\nimport { Component, NgZone, OnDestroy, OnInit, Optional } from '@angular/core';\nimport { FieldTypeConfig, FormlyFieldProps } from '@ngx-formly/core';\nimport { FieldType } from '@ngx-formly/material';\nimport { skip, first, BehaviorSubject, filter, shareReplay, startWith, switchMap, map, Observable, throttleTime } from 'rxjs';\nimport { filterMaybe, SubscriptionObject } from '@dereekb/rxjs';\nimport { Maybe, LatLngPoint, LatLngPointFunctionConfig, latLngPoint, LatLngStringFunction, latLngStringFunction, Milliseconds } from '@dereekb/util';\nimport { GeolocationService } from '@ng-web-apis/geolocation';\nimport { Marker } from 'mapbox-gl';\nimport { DbxMapboxMapStore, MapboxEaseTo, MapboxZoomLevel, provideMapboxStoreIfParentIsUnavailable } from '@dereekb/dbx-web/mapbox';\n\nexport interface DbxFormMapboxLatLngComponentFieldProps extends FormlyFieldProps {\n  /**\n   * (Optional) Whether or not the show the map. If the map is not shown, relies on the center of the parent map to determine position.\n   *\n   * Defaults to true.\n   *\n   * Cases where this would be set false is if another map is being used.\n   */\n  showMap?: boolean;\n  /**\n   * (Optional) Zoom to start the map at. Ignored if the showMap is false.\n   */\n  zoom?: MapboxZoomLevel;\n  /**\n   * Time until recentering on the marker. If the time is 0 then the recentering is disabled.\n   */\n  recenterTime?: Milliseconds;\n  latLngConfig?: LatLngPointFunctionConfig;\n}\n\n@Component({\n  template: `\n    <div class=\"dbx-mapbox-input-field\" [ngClass]=\"(compactClass$ | async) ?? ''\" [formGroup]=\"formGroup\">\n      <div *ngIf=\"showMap\" class=\"dbx-mapbox-input-field-map\">\n        <mgl-map dbxMapboxMap>\n          <mgl-marker [lngLat]=\"(latLng$ | async) || [0, 0]\" [draggable]=\"!isReadonlyOrDisabled\" (markerDragEnd)=\"onMarkerDragEnd($event)\"></mgl-marker>\n        </mgl-map>\n      </div>\n      <div class=\"dbx-mapbox-input-field-input\">\n        <button mat-icon-button (click)=\"useCurrentLocation()\" [disabled]=\"isReadonlyOrDisabled\">\n          <mat-icon>my_location</mat-icon>\n        </button>\n        <mat-form-field class=\"dbx-mapbox-input-field-input-field\">\n          <mat-label>Coordinates</mat-label>\n          <input type=\"text\" matInput [placeholder]=\"placeholder\" [formControl]=\"formControl\" />\n        </mat-form-field>\n      </div>\n    </div>\n  `,\n  providers: [provideMapboxStoreIfParentIsUnavailable()],\n  styleUrls: ['../mapbox.field.component.scss']\n})\nexport class DbxFormMapboxLatLngFieldComponent<T extends DbxFormMapboxLatLngComponentFieldProps = DbxFormMapboxLatLngComponentFieldProps> extends FieldType<FieldTypeConfig<T>> implements OnInit, OnDestroy {\n  private _latLngStringFunction!: LatLngStringFunction;\n\n  readonly compactClass$ = mapCompactModeObs(this.compact?.mode$, {\n    compact: 'dbx-mapbox-input-field-compact'\n  });\n\n  private _sub = new SubscriptionObject();\n  private _geoSub = new SubscriptionObject();\n  private _centerSub = new SubscriptionObject();\n  private _zoom = new BehaviorSubject<MapboxZoomLevel>(12);\n\n  private _formControlObs = new BehaviorSubject<Maybe<AbstractControl>>(undefined);\n  readonly formControl$ = this._formControlObs.pipe(filterMaybe());\n\n  readonly value$ = this.formControl$.pipe(\n    switchMap((control) => control.valueChanges.pipe(startWith(control.value))),\n    shareReplay(1)\n  );\n\n  readonly latLng$: Observable<LatLngPoint> = this.value$.pipe(\n    filterMaybe(),\n    map((x) => latLngPoint(x)),\n    filter((x) => x.lat !== 0 && x.lng !== 0),\n    shareReplay(1)\n  );\n\n  readonly center$ = this.latLng$;\n  readonly zoom$ = this._zoom.asObservable();\n\n  constructor(@Optional() readonly compact: CompactContextStore, private readonly geolocation$: GeolocationService, readonly dbxMapboxMapStore: DbxMapboxMapStore, readonly ngZone: NgZone) {\n    super();\n  }\n\n  get zoom(): MapboxZoomLevel {\n    return Math.min(this.field.props.zoom || 12, 18);\n  }\n\n  get formGroupName(): string {\n    return this.field.key as string;\n  }\n\n  get formGroup(): FormGroup {\n    return this.form as FormGroup;\n  }\n\n  get label(): Maybe<string> {\n    return this.field.props?.label;\n  }\n\n  get description(): Maybe<string> {\n    return this.props.description;\n  }\n\n  get isReadonlyOrDisabled() {\n    return this.props.readonly || this.disabled;\n  }\n\n  get showMap(): boolean {\n    return this.field.props.showMap ?? true;\n  }\n\n  get recenterTime(): Milliseconds {\n    return this.field.props.recenterTime || 10 * 1000;\n  }\n\n  ngOnInit(): void {\n    this._latLngStringFunction = latLngStringFunction(this.field.props.latLngConfig);\n    this._formControlObs.next(this.formControl);\n    this._zoom.next(this.zoom);\n\n    this.dbxMapboxMapStore.setCenter(this.center$);\n\n    if (this.showMap) {\n      // Set zoom only if showMap is true\n      this.dbxMapboxMapStore.setZoom(this.zoom$);\n\n      // recenter periodically\n      if (this.recenterTime > 0) {\n        this._centerSub.subscription = this.dbxMapboxMapStore.center$.pipe(skip(1), throttleTime(this.recenterTime, undefined, { leading: false, trailing: true })).subscribe(() => {\n          this.dbxMapboxMapStore.easeTo(\n            this.center$.pipe(\n              first(),\n              map((x) => ({ center: x } as MapboxEaseTo))\n            )\n          );\n        });\n      }\n    } else {\n      // use the center of the map to set locations\n      this._sub.subscription = this.dbxMapboxMapStore.center$.subscribe((center) => {\n        if (!this.isReadonlyOrDisabled) {\n          this.ngZone.run(() => this.setValue(center));\n        }\n      });\n    }\n\n    if (this.props.readonly) {\n      this.formControl.disable();\n    }\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._sub.destroy();\n    this._geoSub.destroy();\n    this._zoom.complete();\n    this._formControlObs.complete();\n    this._centerSub.destroy();\n  }\n\n  useCurrentLocation() {\n    this._geoSub.subscription = this.geolocation$.pipe(first()).subscribe((position) => {\n      if (position) {\n        const { latitude: lat, longitude: lng } = position.coords;\n        this.setValue({ lat, lng });\n      }\n    });\n  }\n\n  onMarkerDragEnd(marker: Marker) {\n    this.setValue(marker.getLngLat());\n  }\n\n  setValue(latLng?: Maybe<LatLngPoint>) {\n    this.formControl.setValue(latLng ? this._latLngStringFunction(latLng) : latLng);\n  }\n}\n"]}
@@ -1,16 +1,20 @@
1
1
  import { DEFAULT_LAT_LNG_TEXT_FIELD_PATTERN_MESSAGE, DEFAULT_LAT_LNG_TEXT_FIELD_PLACEHOLDER, formlyField, propsForFieldConfig, styleWrapper, validatorsForFieldConfig } from '@dereekb/dbx-form';
2
2
  import { LAT_LNG_PATTERN } from '@dereekb/util';
3
3
  export function mapboxLatLngField(config = {}) {
4
- const { key = 'latLng' } = config;
4
+ const { key = 'latLng', latLngConfig, showMap, zoom, recenterTime } = config;
5
5
  const fieldConfig = {
6
6
  ...formlyField({
7
7
  key,
8
8
  type: 'mapbox-latlng-picker',
9
9
  ...propsForFieldConfig(config, {
10
- label: config.label ?? 'Location Picker',
10
+ label: config.label ?? 'Location',
11
11
  placeholder: DEFAULT_LAT_LNG_TEXT_FIELD_PLACEHOLDER,
12
12
  pattern: LAT_LNG_PATTERN,
13
- autocomplete: false
13
+ autocomplete: false,
14
+ showMap,
15
+ zoom,
16
+ latLngConfig,
17
+ recenterTime
14
18
  })
15
19
  }),
16
20
  ...validatorsForFieldConfig({
@@ -23,4 +27,4 @@ export function mapboxLatLngField(config = {}) {
23
27
  classGetter: 'dbx-mat-form-field-disable-underline'
24
28
  });
25
29
  }
26
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF0bG5nLmZpZWxkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LWZvcm0vbWFwYm94L3NyYy9saWIvZmllbGQvbGF0bG5nL2xhdGxuZy5maWVsZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsMENBQTBDLEVBQUUsc0NBQXNDLEVBQXVDLFdBQVcsRUFBc0IsbUJBQW1CLEVBQUUsWUFBWSxFQUFFLHdCQUF3QixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDMVAsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUtoRCxNQUFNLFVBQVUsaUJBQWlCLENBQUMsU0FBa0MsRUFBRTtJQUNwRSxNQUFNLEVBQUUsR0FBRyxHQUFHLFFBQVEsRUFBRSxHQUFHLE1BQU0sQ0FBQztJQUNsQyxNQUFNLFdBQVcsR0FBc0I7UUFDckMsR0FBRyxXQUFXLENBQUM7WUFDYixHQUFHO1lBQ0gsSUFBSSxFQUFFLHNCQUFzQjtZQUM1QixHQUFHLG1CQUFtQixDQUFDLE1BQU0sRUFBRTtnQkFDN0IsS0FBSyxFQUFFLE1BQU0sQ0FBQyxLQUFLLElBQUksaUJBQWlCO2dCQUN4QyxXQUFXLEVBQUUsc0NBQXNDO2dCQUNuRCxPQUFPLEVBQUUsZUFBZTtnQkFDeEIsWUFBWSxFQUFFLEtBQUs7YUFDcEIsQ0FBQztTQUNILENBQUM7UUFDRixHQUFHLHdCQUF3QixDQUFDO1lBQzFCLFFBQVEsRUFBRTtnQkFDUixPQUFPLEVBQUUsMENBQTBDO2FBQ3BEO1NBQ0YsQ0FBQztLQUNILENBQUM7SUFFRixPQUFPLFlBQVksQ0FBQyxXQUFXLEVBQUU7UUFDL0IsV0FBVyxFQUFFLHNDQUFzQztLQUNwRCxDQUFDLENBQUM7QUFDTCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgREVGQVVMVF9MQVRfTE5HX1RFWFRfRklFTERfUEFUVEVSTl9NRVNTQUdFLCBERUZBVUxUX0xBVF9MTkdfVEVYVF9GSUVMRF9QTEFDRUhPTERFUiwgRGVzY3JpcHRpb25GaWVsZENvbmZpZywgRmllbGRDb25maWcsIGZvcm1seUZpZWxkLCBMYWJlbGVkRmllbGRDb25maWcsIHByb3BzRm9yRmllbGRDb25maWcsIHN0eWxlV3JhcHBlciwgdmFsaWRhdG9yc0ZvckZpZWxkQ29uZmlnIH0gZnJvbSAnQGRlcmVla2IvZGJ4LWZvcm0nO1xuaW1wb3J0IHsgTEFUX0xOR19QQVRURVJOIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5pbXBvcnQgeyBGb3JtbHlGaWVsZENvbmZpZyB9IGZyb20gJ0BuZ3gtZm9ybWx5L2NvcmUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIE1hcGJveExhdExuZ0ZpZWxkQ29uZmlnIGV4dGVuZHMgT21pdDxMYWJlbGVkRmllbGRDb25maWcsICdrZXknPiwgRGVzY3JpcHRpb25GaWVsZENvbmZpZywgUGFydGlhbDxGaWVsZENvbmZpZz4ge31cblxuZXhwb3J0IGZ1bmN0aW9uIG1hcGJveExhdExuZ0ZpZWxkKGNvbmZpZzogTWFwYm94TGF0TG5nRmllbGRDb25maWcgPSB7fSk6IEZvcm1seUZpZWxkQ29uZmlnIHtcbiAgY29uc3QgeyBrZXkgPSAnbGF0TG5nJyB9ID0gY29uZmlnO1xuICBjb25zdCBmaWVsZENvbmZpZzogRm9ybWx5RmllbGRDb25maWcgPSB7XG4gICAgLi4uZm9ybWx5RmllbGQoe1xuICAgICAga2V5LFxuICAgICAgdHlwZTogJ21hcGJveC1sYXRsbmctcGlja2VyJyxcbiAgICAgIC4uLnByb3BzRm9yRmllbGRDb25maWcoY29uZmlnLCB7XG4gICAgICAgIGxhYmVsOiBjb25maWcubGFiZWwgPz8gJ0xvY2F0aW9uIFBpY2tlcicsXG4gICAgICAgIHBsYWNlaG9sZGVyOiBERUZBVUxUX0xBVF9MTkdfVEVYVF9GSUVMRF9QTEFDRUhPTERFUixcbiAgICAgICAgcGF0dGVybjogTEFUX0xOR19QQVRURVJOLFxuICAgICAgICBhdXRvY29tcGxldGU6IGZhbHNlXG4gICAgICB9KVxuICAgIH0pLFxuICAgIC4uLnZhbGlkYXRvcnNGb3JGaWVsZENvbmZpZyh7XG4gICAgICBtZXNzYWdlczoge1xuICAgICAgICBwYXR0ZXJuOiBERUZBVUxUX0xBVF9MTkdfVEVYVF9GSUVMRF9QQVRURVJOX01FU1NBR0VcbiAgICAgIH1cbiAgICB9KVxuICB9O1xuXG4gIHJldHVybiBzdHlsZVdyYXBwZXIoZmllbGRDb25maWcsIHtcbiAgICBjbGFzc0dldHRlcjogJ2RieC1tYXQtZm9ybS1maWVsZC1kaXNhYmxlLXVuZGVybGluZSdcbiAgfSk7XG59XG4iXX0=
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF0bG5nLmZpZWxkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LWZvcm0vbWFwYm94L3NyYy9saWIvZmllbGQvbGF0bG5nL2xhdGxuZy5maWVsZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsMENBQTBDLEVBQUUsc0NBQXNDLEVBQXVDLFdBQVcsRUFBc0IsbUJBQW1CLEVBQUUsWUFBWSxFQUFFLHdCQUF3QixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDMVAsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQU1oRCxNQUFNLFVBQVUsaUJBQWlCLENBQUMsU0FBa0MsRUFBRTtJQUNwRSxNQUFNLEVBQUUsR0FBRyxHQUFHLFFBQVEsRUFBRSxZQUFZLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBRSxZQUFZLEVBQUUsR0FBRyxNQUFNLENBQUM7SUFDN0UsTUFBTSxXQUFXLEdBQXNCO1FBQ3JDLEdBQUcsV0FBVyxDQUFDO1lBQ2IsR0FBRztZQUNILElBQUksRUFBRSxzQkFBc0I7WUFDNUIsR0FBRyxtQkFBbUIsQ0FBQyxNQUFNLEVBQUU7Z0JBQzdCLEtBQUssRUFBRSxNQUFNLENBQUMsS0FBSyxJQUFJLFVBQVU7Z0JBQ2pDLFdBQVcsRUFBRSxzQ0FBc0M7Z0JBQ25ELE9BQU8sRUFBRSxlQUFlO2dCQUN4QixZQUFZLEVBQUUsS0FBSztnQkFDbkIsT0FBTztnQkFDUCxJQUFJO2dCQUNKLFlBQVk7Z0JBQ1osWUFBWTthQUNiLENBQUM7U0FDSCxDQUFDO1FBQ0YsR0FBRyx3QkFBd0IsQ0FBQztZQUMxQixRQUFRLEVBQUU7Z0JBQ1IsT0FBTyxFQUFFLDBDQUEwQzthQUNwRDtTQUNGLENBQUM7S0FDSCxDQUFDO0lBRUYsT0FBTyxZQUFZLENBQUMsV0FBVyxFQUFFO1FBQy9CLFdBQVcsRUFBRSxzQ0FBc0M7S0FDcEQsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERFRkFVTFRfTEFUX0xOR19URVhUX0ZJRUxEX1BBVFRFUk5fTUVTU0FHRSwgREVGQVVMVF9MQVRfTE5HX1RFWFRfRklFTERfUExBQ0VIT0xERVIsIERlc2NyaXB0aW9uRmllbGRDb25maWcsIEZpZWxkQ29uZmlnLCBmb3JtbHlGaWVsZCwgTGFiZWxlZEZpZWxkQ29uZmlnLCBwcm9wc0ZvckZpZWxkQ29uZmlnLCBzdHlsZVdyYXBwZXIsIHZhbGlkYXRvcnNGb3JGaWVsZENvbmZpZyB9IGZyb20gJ0BkZXJlZWtiL2RieC1mb3JtJztcbmltcG9ydCB7IExBVF9MTkdfUEFUVEVSTiB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuaW1wb3J0IHsgRm9ybWx5RmllbGRDb25maWcgfSBmcm9tICdAbmd4LWZvcm1seS9jb3JlJztcbmltcG9ydCB7IERieEZvcm1NYXBib3hMYXRMbmdDb21wb25lbnRGaWVsZFByb3BzIH0gZnJvbSAnLi9sYXRsbmcuZmllbGQuY29tcG9uZW50JztcblxuZXhwb3J0IGludGVyZmFjZSBNYXBib3hMYXRMbmdGaWVsZENvbmZpZyBleHRlbmRzIE9taXQ8TGFiZWxlZEZpZWxkQ29uZmlnLCAna2V5Jz4sIERlc2NyaXB0aW9uRmllbGRDb25maWcsIFBhcnRpYWw8RmllbGRDb25maWc+LCBQaWNrPERieEZvcm1NYXBib3hMYXRMbmdDb21wb25lbnRGaWVsZFByb3BzLCAnc2hvd01hcCcgfCAnem9vbScgfCAnbGF0TG5nQ29uZmlnJyB8ICdyZWNlbnRlclRpbWUnPiB7fVxuXG5leHBvcnQgZnVuY3Rpb24gbWFwYm94TGF0TG5nRmllbGQoY29uZmlnOiBNYXBib3hMYXRMbmdGaWVsZENvbmZpZyA9IHt9KTogRm9ybWx5RmllbGRDb25maWcge1xuICBjb25zdCB7IGtleSA9ICdsYXRMbmcnLCBsYXRMbmdDb25maWcsIHNob3dNYXAsIHpvb20sIHJlY2VudGVyVGltZSB9ID0gY29uZmlnO1xuICBjb25zdCBmaWVsZENvbmZpZzogRm9ybWx5RmllbGRDb25maWcgPSB7XG4gICAgLi4uZm9ybWx5RmllbGQoe1xuICAgICAga2V5LFxuICAgICAgdHlwZTogJ21hcGJveC1sYXRsbmctcGlja2VyJyxcbiAgICAgIC4uLnByb3BzRm9yRmllbGRDb25maWcoY29uZmlnLCB7XG4gICAgICAgIGxhYmVsOiBjb25maWcubGFiZWwgPz8gJ0xvY2F0aW9uJyxcbiAgICAgICAgcGxhY2Vob2xkZXI6IERFRkFVTFRfTEFUX0xOR19URVhUX0ZJRUxEX1BMQUNFSE9MREVSLFxuICAgICAgICBwYXR0ZXJuOiBMQVRfTE5HX1BBVFRFUk4sXG4gICAgICAgIGF1dG9jb21wbGV0ZTogZmFsc2UsXG4gICAgICAgIHNob3dNYXAsXG4gICAgICAgIHpvb20sXG4gICAgICAgIGxhdExuZ0NvbmZpZyxcbiAgICAgICAgcmVjZW50ZXJUaW1lXG4gICAgICB9KVxuICAgIH0pLFxuICAgIC4uLnZhbGlkYXRvcnNGb3JGaWVsZENvbmZpZyh7XG4gICAgICBtZXNzYWdlczoge1xuICAgICAgICBwYXR0ZXJuOiBERUZBVUxUX0xBVF9MTkdfVEVYVF9GSUVMRF9QQVRURVJOX01FU1NBR0VcbiAgICAgIH1cbiAgICB9KVxuICB9O1xuXG4gIHJldHVybiBzdHlsZVdyYXBwZXIoZmllbGRDb25maWcsIHtcbiAgICBjbGFzc0dldHRlcjogJ2RieC1tYXQtZm9ybS1maWVsZC1kaXNhYmxlLXVuZGVybGluZSdcbiAgfSk7XG59XG4iXX0=
@@ -0,0 +1,4 @@
1
+ export * from './zoom.field';
2
+ export * from './zoom.field.component';
3
+ export * from './zoom.module';
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtZm9ybS9tYXBib3gvc3JjL2xpYi9maWVsZC96b29tL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyxlQUFlLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3pvb20uZmllbGQnO1xuZXhwb3J0ICogZnJvbSAnLi96b29tLmZpZWxkLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3pvb20ubW9kdWxlJztcbiJdfQ==
@@ -0,0 +1,126 @@
1
+ import { CompactContextStore, mapCompactModeObs } from '@dereekb/dbx-web';
2
+ import { Component, NgZone, Optional } from '@angular/core';
3
+ import { FieldType } from '@ngx-formly/material';
4
+ import { BehaviorSubject, shareReplay, startWith, switchMap } from 'rxjs';
5
+ import { filterMaybe, SubscriptionObject } from '@dereekb/rxjs';
6
+ import { latLngPoint } from '@dereekb/util';
7
+ import { DbxMapboxService, DbxMapboxMapStore, provideMapboxStoreIfParentIsUnavailable, mapboxZoomLevel, MAPBOX_MAX_ZOOM_LEVEL, MAPBOX_MIN_ZOOM_LEVEL } from '@dereekb/dbx-web/mapbox';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "@dereekb/dbx-web";
10
+ import * as i2 from "@dereekb/dbx-web/mapbox";
11
+ import * as i3 from "@angular/common";
12
+ import * as i4 from "@angular/forms";
13
+ import * as i5 from "@angular/material/form-field";
14
+ import * as i6 from "@angular/material/input";
15
+ import * as i7 from "ngx-mapbox-gl";
16
+ export class DbxFormMapboxZoomFieldComponent extends FieldType {
17
+ constructor(compact, dbxMapboxService, dbxMapboxMapStore, ngZone) {
18
+ super();
19
+ this.compact = compact;
20
+ this.dbxMapboxService = dbxMapboxService;
21
+ this.dbxMapboxMapStore = dbxMapboxMapStore;
22
+ this.ngZone = ngZone;
23
+ this.compactClass$ = mapCompactModeObs(this.compact?.mode$, {
24
+ compact: 'dbx-mapbox-input-field-compact'
25
+ });
26
+ this._sub = new SubscriptionObject();
27
+ this._center = new BehaviorSubject(undefined);
28
+ this._formControlObs = new BehaviorSubject(undefined);
29
+ this.formControl$ = this._formControlObs.pipe(filterMaybe());
30
+ this.value$ = this.formControl$.pipe(switchMap((control) => control.valueChanges.pipe(startWith(control.value))), shareReplay(1));
31
+ this.zoom$ = this.value$.pipe(filterMaybe(), shareReplay(1));
32
+ this.center$ = this._center.pipe(filterMaybe());
33
+ }
34
+ get center() {
35
+ return this.field.props.center || latLngPoint(this.dbxMapboxService.defaultCenter);
36
+ }
37
+ get formGroupName() {
38
+ return this.field.key;
39
+ }
40
+ get formGroup() {
41
+ return this.form;
42
+ }
43
+ get label() {
44
+ return this.field.props?.label;
45
+ }
46
+ get description() {
47
+ return this.props.description;
48
+ }
49
+ get isReadonlyOrDisabled() {
50
+ return this.props.readonly || this.disabled;
51
+ }
52
+ get showMap() {
53
+ return this.field.props.showMap ?? true;
54
+ }
55
+ get minZoom() {
56
+ return mapboxZoomLevel(this.field.props.minZoom || MAPBOX_MIN_ZOOM_LEVEL);
57
+ }
58
+ get maxZoom() {
59
+ return mapboxZoomLevel(this.field.props.maxZoom || MAPBOX_MAX_ZOOM_LEVEL);
60
+ }
61
+ get zoomStep() {
62
+ return mapboxZoomLevel(this.field.props.zoomStep || 1);
63
+ }
64
+ ngOnInit() {
65
+ this._formControlObs.next(this.formControl);
66
+ this._center.next(this.center);
67
+ this.dbxMapboxMapStore.setZoom(this.zoom$);
68
+ // Set center only if showMap is false.
69
+ if (this.showMap) {
70
+ this.dbxMapboxMapStore.setCenter(this.center$);
71
+ }
72
+ if (this.props.readonly) {
73
+ this.formControl.disable();
74
+ if (this.showMap) {
75
+ this.dbxMapboxMapStore.setZoomDisabled();
76
+ }
77
+ }
78
+ this._sub.subscription = this.dbxMapboxMapStore.zoom$.subscribe((zoom) => {
79
+ if (!this.isReadonlyOrDisabled) {
80
+ this.ngZone.run(() => this.setValue(zoom));
81
+ }
82
+ });
83
+ }
84
+ ngOnDestroy() {
85
+ super.ngOnDestroy();
86
+ this._formControlObs.complete();
87
+ this._center.complete();
88
+ this._sub.destroy();
89
+ }
90
+ setValue(zoom) {
91
+ this.formControl.setValue(zoom);
92
+ }
93
+ }
94
+ DbxFormMapboxZoomFieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxFormMapboxZoomFieldComponent, deps: [{ token: i1.CompactContextStore, optional: true }, { token: i2.DbxMapboxService }, { token: i2.DbxMapboxMapStore }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
95
+ DbxFormMapboxZoomFieldComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.2", type: DbxFormMapboxZoomFieldComponent, selector: "ng-component", providers: [provideMapboxStoreIfParentIsUnavailable()], usesInheritance: true, ngImport: i0, template: `
96
+ <div class="dbx-mapbox-input-field" [ngClass]="(compactClass$ | async) ?? ''" [formGroup]="formGroup">
97
+ <div *ngIf="showMap" class="dbx-mapbox-input-field-map">
98
+ <mgl-map dbxMapboxMap></mgl-map>
99
+ </div>
100
+ <div class="dbx-mapbox-input-field-input">
101
+ <mat-form-field class="dbx-mapbox-input-field-input-field">
102
+ <mat-label>Zoom Level</mat-label>
103
+ <input type="number" matInput [min]="minZoom" [max]="maxZoom" [step]="zoomStep" [placeholder]="placeholder" [formControl]="formControl" />
104
+ </mat-form-field>
105
+ </div>
106
+ </div>
107
+ `, isInline: true, styles: [".dbx-mapbox-input-field .dbx-mapbox-input-field-map{height:220px;width:100%}.dbx-mapbox-input-field .dbx-mapbox-input-field-map mgl-map{height:100%;width:100%}.dbx-mapbox-input-field .dbx-mapbox-input-field-input{display:flex;align-items:center}.dbx-mapbox-input-field .dbx-mapbox-input-field-input .dbx-mapbox-input-field-input-field{width:calc(100% - 40px)}.dbx-mapbox-input-field-compact .dbx-latlng-field-input{min-height:120px;height:300px;max-height:calc(var(--vh100) * .5)}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DbxMapboxMapDirective, selector: "[dbxMapboxMap]" }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i4.MinValidator, selector: "input[type=number][min][formControlName],input[type=number][min][formControl],input[type=number][min][ngModel]", inputs: ["min"] }, { kind: "directive", type: i4.MaxValidator, selector: "input[type=number][max][formControlName],input[type=number][max][formControl],input[type=number][max][ngModel]", inputs: ["max"] }, { kind: "directive", type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i5.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i5.MatLabel, selector: "mat-label" }, { kind: "directive", type: i6.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i7.MapComponent, selector: "mgl-map", inputs: ["accessToken", "collectResourceTiming", "crossSourceCollisions", "customMapboxApiUrl", "fadeDuration", "hash", "refreshExpiredTiles", "failIfMajorPerformanceCaveat", "bearingSnap", "interactive", "pitchWithRotate", "clickTolerance", "attributionControl", "logoPosition", "maxTileCacheSize", "localIdeographFontFamily", "preserveDrawingBuffer", "trackResize", "transformRequest", "bounds", "antialias", "locale", "minZoom", "maxZoom", "minPitch", "maxPitch", "scrollZoom", "dragRotate", "touchPitch", "touchZoomRotate", "doubleClickZoom", "keyboard", "dragPan", "boxZoom", "style", "center", "maxBounds", "zoom", "bearing", "pitch", "fitBoundsOptions", "renderWorldCopies", "projection", "movingMethod", "movingOptions", "fitBounds", "fitScreenCoordinates", "centerWithPanTo", "panToOptions", "cursorStyle"], outputs: ["mapResize", "mapRemove", "mapMouseDown", "mapMouseUp", "mapMouseMove", "mapClick", "mapDblClick", "mapMouseOver", "mapMouseOut", "mapContextMenu", "mapTouchStart", "mapTouchEnd", "mapTouchMove", "mapTouchCancel", "mapWheel", "moveStart", "move", "moveEnd", "mapDragStart", "mapDrag", "mapDragEnd", "zoomStart", "zoomEvt", "zoomEnd", "rotateStart", "rotate", "rotateEnd", "pitchStart", "pitchEvt", "pitchEnd", "boxZoomStart", "boxZoomEnd", "boxZoomCancel", "webGlContextLost", "webGlContextRestored", "mapLoad", "idle", "render", "mapError", "data", "styleData", "sourceData", "dataLoading", "styleDataLoading", "sourceDataLoading", "styleImageMissing", "resize", "remove", "mouseDown", "mouseUp", "mouseMove", "click", "dblClick", "mouseOver", "mouseOut", "contextMenu", "touchStart", "touchEnd", "touchMove", "touchCancel", "wheel", "dragStart", "drag", "dragEnd", "load", "error"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }] });
108
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxFormMapboxZoomFieldComponent, decorators: [{
109
+ type: Component,
110
+ args: [{ template: `
111
+ <div class="dbx-mapbox-input-field" [ngClass]="(compactClass$ | async) ?? ''" [formGroup]="formGroup">
112
+ <div *ngIf="showMap" class="dbx-mapbox-input-field-map">
113
+ <mgl-map dbxMapboxMap></mgl-map>
114
+ </div>
115
+ <div class="dbx-mapbox-input-field-input">
116
+ <mat-form-field class="dbx-mapbox-input-field-input-field">
117
+ <mat-label>Zoom Level</mat-label>
118
+ <input type="number" matInput [min]="minZoom" [max]="maxZoom" [step]="zoomStep" [placeholder]="placeholder" [formControl]="formControl" />
119
+ </mat-form-field>
120
+ </div>
121
+ </div>
122
+ `, providers: [provideMapboxStoreIfParentIsUnavailable()], styles: [".dbx-mapbox-input-field .dbx-mapbox-input-field-map{height:220px;width:100%}.dbx-mapbox-input-field .dbx-mapbox-input-field-map mgl-map{height:100%;width:100%}.dbx-mapbox-input-field .dbx-mapbox-input-field-input{display:flex;align-items:center}.dbx-mapbox-input-field .dbx-mapbox-input-field-input .dbx-mapbox-input-field-input-field{width:calc(100% - 40px)}.dbx-mapbox-input-field-compact .dbx-latlng-field-input{min-height:120px;height:300px;max-height:calc(var(--vh100) * .5)}\n"] }]
123
+ }], ctorParameters: function () { return [{ type: i1.CompactContextStore, decorators: [{
124
+ type: Optional
125
+ }] }, { type: i2.DbxMapboxService }, { type: i2.DbxMapboxMapStore }, { type: i0.NgZone }]; } });
126
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"zoom.field.component.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-form/mapbox/src/lib/field/zoom/zoom.field.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl, FormGroup } from '@angular/forms';\nimport { CompactContextStore, mapCompactModeObs } from '@dereekb/dbx-web';\nimport { Component, NgZone, OnDestroy, OnInit, Optional } from '@angular/core';\nimport { FieldTypeConfig, FormlyFieldProps } from '@ngx-formly/core';\nimport { FieldType } from '@ngx-formly/material';\nimport { first, BehaviorSubject, filter, shareReplay, startWith, switchMap, map, Observable } from 'rxjs';\nimport { filterMaybe, SubscriptionObject } from '@dereekb/rxjs';\nimport { ZoomLevel, Maybe, LatLngPoint, LatLngPointFunctionConfig, latLngPoint, LatLngStringFunction, latLngStringFunction } from '@dereekb/util';\nimport { GeolocationService } from '@ng-web-apis/geolocation';\nimport { Marker } from 'mapbox-gl';\nimport { DbxMapboxService, DbxMapboxMapStore, MapboxZoomLevel, provideMapboxStoreIfParentIsUnavailable, mapboxZoomLevel, MAPBOX_MAX_ZOOM_LEVEL, MAPBOX_MIN_ZOOM_LEVEL } from '@dereekb/dbx-web/mapbox';\n\nexport interface DbxFormMapboxZoomComponentFieldProps extends FormlyFieldProps {\n  /**\n   * (Optional) Whether or not the show the map. Cases where this would be set false is if another map is being used.\n   *\n   * Defaults to true.\n   */\n  showMap?: boolean;\n  /**\n   * Default center\n   */\n  center?: LatLngPoint;\n  /**\n   * Min zoom level allowed\n   */\n  minZoom?: MapboxZoomLevel;\n  /**\n   * Max zoom level allowed.\n   */\n  maxZoom?: MapboxZoomLevel;\n  /**\n   * Step size when using arrow keys.\n   */\n  zoomStep?: number;\n}\n\n@Component({\n  template: `\n    <div class=\"dbx-mapbox-input-field\" [ngClass]=\"(compactClass$ | async) ?? ''\" [formGroup]=\"formGroup\">\n      <div *ngIf=\"showMap\" class=\"dbx-mapbox-input-field-map\">\n        <mgl-map dbxMapboxMap></mgl-map>\n      </div>\n      <div class=\"dbx-mapbox-input-field-input\">\n        <mat-form-field class=\"dbx-mapbox-input-field-input-field\">\n          <mat-label>Zoom Level</mat-label>\n          <input type=\"number\" matInput [min]=\"minZoom\" [max]=\"maxZoom\" [step]=\"zoomStep\" [placeholder]=\"placeholder\" [formControl]=\"formControl\" />\n        </mat-form-field>\n      </div>\n    </div>\n  `,\n  providers: [provideMapboxStoreIfParentIsUnavailable()],\n  styleUrls: ['../mapbox.field.component.scss']\n})\nexport class DbxFormMapboxZoomFieldComponent<T extends DbxFormMapboxZoomComponentFieldProps = DbxFormMapboxZoomComponentFieldProps> extends FieldType<FieldTypeConfig<T>> implements OnInit, OnDestroy {\n  readonly compactClass$ = mapCompactModeObs(this.compact?.mode$, {\n    compact: 'dbx-mapbox-input-field-compact'\n  });\n\n  private _sub = new SubscriptionObject();\n  private _center = new BehaviorSubject<Maybe<LatLngPoint>>(undefined);\n\n  private _formControlObs = new BehaviorSubject<Maybe<AbstractControl>>(undefined);\n  readonly formControl$ = this._formControlObs.pipe(filterMaybe());\n\n  readonly value$ = this.formControl$.pipe(\n    switchMap((control) => control.valueChanges.pipe(startWith(control.value))),\n    shareReplay(1)\n  );\n\n  readonly zoom$: Observable<MapboxZoomLevel> = this.value$.pipe(filterMaybe(), shareReplay(1));\n  readonly center$ = this._center.pipe(filterMaybe());\n\n  constructor(@Optional() readonly compact: CompactContextStore, readonly dbxMapboxService: DbxMapboxService, readonly dbxMapboxMapStore: DbxMapboxMapStore, readonly ngZone: NgZone) {\n    super();\n  }\n\n  get center(): LatLngPoint {\n    return this.field.props.center || latLngPoint(this.dbxMapboxService.defaultCenter);\n  }\n\n  get formGroupName(): string {\n    return this.field.key as string;\n  }\n\n  get formGroup(): FormGroup {\n    return this.form as FormGroup;\n  }\n\n  get label(): Maybe<string> {\n    return this.field.props?.label;\n  }\n\n  get description(): Maybe<string> {\n    return this.props.description;\n  }\n\n  get isReadonlyOrDisabled() {\n    return this.props.readonly || this.disabled;\n  }\n\n  get showMap(): boolean {\n    return this.field.props.showMap ?? true;\n  }\n\n  get minZoom(): MapboxZoomLevel {\n    return mapboxZoomLevel(this.field.props.minZoom || MAPBOX_MIN_ZOOM_LEVEL);\n  }\n\n  get maxZoom(): MapboxZoomLevel {\n    return mapboxZoomLevel(this.field.props.maxZoom || MAPBOX_MAX_ZOOM_LEVEL);\n  }\n\n  get zoomStep(): number {\n    return mapboxZoomLevel(this.field.props.zoomStep || 1);\n  }\n\n  ngOnInit(): void {\n    this._formControlObs.next(this.formControl);\n    this._center.next(this.center);\n\n    this.dbxMapboxMapStore.setZoom(this.zoom$);\n\n    // Set center only if showMap is false.\n    if (this.showMap) {\n      this.dbxMapboxMapStore.setCenter(this.center$);\n    }\n\n    if (this.props.readonly) {\n      this.formControl.disable();\n\n      if (this.showMap) {\n        this.dbxMapboxMapStore.setZoomDisabled();\n      }\n    }\n\n    this._sub.subscription = this.dbxMapboxMapStore.zoom$.subscribe((zoom) => {\n      if (!this.isReadonlyOrDisabled) {\n        this.ngZone.run(() => this.setValue(zoom));\n      }\n    });\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._formControlObs.complete();\n    this._center.complete();\n    this._sub.destroy();\n  }\n\n  setValue(zoom?: Maybe<ZoomLevel>) {\n    this.formControl.setValue(zoom);\n  }\n}\n"]}
@@ -0,0 +1,23 @@
1
+ import { formlyField, propsForFieldConfig, styleWrapper } from '@dereekb/dbx-form';
2
+ export function mapboxZoomField(config = {}) {
3
+ const { key = 'zoom', showMap, center, minZoom, maxZoom, zoomStep } = config;
4
+ const fieldConfig = {
5
+ ...formlyField({
6
+ key,
7
+ type: 'mapbox-zoom-picker',
8
+ ...propsForFieldConfig(config, {
9
+ label: config.label ?? 'Zoom',
10
+ autocomplete: false,
11
+ showMap,
12
+ center,
13
+ minZoom,
14
+ maxZoom,
15
+ zoomStep
16
+ })
17
+ })
18
+ };
19
+ return styleWrapper(fieldConfig, {
20
+ classGetter: 'dbx-mat-form-field-disable-underline'
21
+ });
22
+ }
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiem9vbS5maWVsZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC1mb3JtL21hcGJveC9zcmMvbGliL2ZpZWxkL3pvb20vem9vbS5maWVsZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQTJILFdBQVcsRUFBc0IsbUJBQW1CLEVBQUUsWUFBWSxFQUE0QixNQUFNLG1CQUFtQixDQUFDO0FBUTFQLE1BQU0sVUFBVSxlQUFlLENBQUMsU0FBZ0MsRUFBRTtJQUNoRSxNQUFNLEVBQUUsR0FBRyxHQUFHLE1BQU0sRUFBRSxPQUFPLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxPQUFPLEVBQUUsUUFBUSxFQUFFLEdBQUcsTUFBTSxDQUFDO0lBQzdFLE1BQU0sV0FBVyxHQUFzQjtRQUNyQyxHQUFHLFdBQVcsQ0FBQztZQUNiLEdBQUc7WUFDSCxJQUFJLEVBQUUsb0JBQW9CO1lBQzFCLEdBQUcsbUJBQW1CLENBQUMsTUFBTSxFQUFFO2dCQUM3QixLQUFLLEVBQUUsTUFBTSxDQUFDLEtBQUssSUFBSSxNQUFNO2dCQUM3QixZQUFZLEVBQUUsS0FBSztnQkFDbkIsT0FBTztnQkFDUCxNQUFNO2dCQUNOLE9BQU87Z0JBQ1AsT0FBTztnQkFDUCxRQUFRO2FBQ1QsQ0FBQztTQUNILENBQUM7S0FDSCxDQUFDO0lBRUYsT0FBTyxZQUFZLENBQUMsV0FBVyxFQUFFO1FBQy9CLFdBQVcsRUFBRSxzQ0FBc0M7S0FDcEQsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERFRkFVTFRfTEFUX0xOR19URVhUX0ZJRUxEX1BBVFRFUk5fTUVTU0FHRSwgREVGQVVMVF9MQVRfTE5HX1RFWFRfRklFTERfUExBQ0VIT0xERVIsIERlc2NyaXB0aW9uRmllbGRDb25maWcsIEZpZWxkQ29uZmlnLCBmb3JtbHlGaWVsZCwgTGFiZWxlZEZpZWxkQ29uZmlnLCBwcm9wc0ZvckZpZWxkQ29uZmlnLCBzdHlsZVdyYXBwZXIsIHZhbGlkYXRvcnNGb3JGaWVsZENvbmZpZyB9IGZyb20gJ0BkZXJlZWtiL2RieC1mb3JtJztcbmltcG9ydCB7IE1BUEJPWF9NQVhfWk9PTV9MRVZFTCB9IGZyb20gJ0BkZXJlZWtiL2RieC13ZWIvbWFwYm94JztcbmltcG9ydCB7IExBVF9MTkdfUEFUVEVSTiB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuaW1wb3J0IHsgRm9ybWx5RmllbGRDb25maWcgfSBmcm9tICdAbmd4LWZvcm1seS9jb3JlJztcbmltcG9ydCB7IERieEZvcm1NYXBib3hab29tQ29tcG9uZW50RmllbGRQcm9wcyB9IGZyb20gJy4vem9vbS5maWVsZC5jb21wb25lbnQnO1xuXG5leHBvcnQgaW50ZXJmYWNlIE1hcGJveFpvb21GaWVsZENvbmZpZyBleHRlbmRzIE9taXQ8TGFiZWxlZEZpZWxkQ29uZmlnLCAna2V5Jz4sIERlc2NyaXB0aW9uRmllbGRDb25maWcsIFBhcnRpYWw8RmllbGRDb25maWc+LCBQaWNrPERieEZvcm1NYXBib3hab29tQ29tcG9uZW50RmllbGRQcm9wcywgJ3Nob3dNYXAnIHwgJ2NlbnRlcicgfCAnbWluWm9vbScgfCAnbWF4Wm9vbScgfCAnem9vbVN0ZXAnPiB7fVxuXG5leHBvcnQgZnVuY3Rpb24gbWFwYm94Wm9vbUZpZWxkKGNvbmZpZzogTWFwYm94Wm9vbUZpZWxkQ29uZmlnID0ge30pOiBGb3JtbHlGaWVsZENvbmZpZyB7XG4gIGNvbnN0IHsga2V5ID0gJ3pvb20nLCBzaG93TWFwLCBjZW50ZXIsIG1pblpvb20sIG1heFpvb20sIHpvb21TdGVwIH0gPSBjb25maWc7XG4gIGNvbnN0IGZpZWxkQ29uZmlnOiBGb3JtbHlGaWVsZENvbmZpZyA9IHtcbiAgICAuLi5mb3JtbHlGaWVsZCh7XG4gICAgICBrZXksXG4gICAgICB0eXBlOiAnbWFwYm94LXpvb20tcGlja2VyJyxcbiAgICAgIC4uLnByb3BzRm9yRmllbGRDb25maWcoY29uZmlnLCB7XG4gICAgICAgIGxhYmVsOiBjb25maWcubGFiZWwgPz8gJ1pvb20nLFxuICAgICAgICBhdXRvY29tcGxldGU6IGZhbHNlLFxuICAgICAgICBzaG93TWFwLFxuICAgICAgICBjZW50ZXIsXG4gICAgICAgIG1pblpvb20sXG4gICAgICAgIG1heFpvb20sXG4gICAgICAgIHpvb21TdGVwXG4gICAgICB9KVxuICAgIH0pXG4gIH07XG5cbiAgcmV0dXJuIHN0eWxlV3JhcHBlcihmaWVsZENvbmZpZywge1xuICAgIGNsYXNzR2V0dGVyOiAnZGJ4LW1hdC1mb3JtLWZpZWxkLWRpc2FibGUtdW5kZXJsaW5lJ1xuICB9KTtcbn1cbiJdfQ==
@@ -0,0 +1,57 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { DbxFormMapboxZoomFieldComponent } from './zoom.field.component';
4
+ import { FormlyModule } from '@ngx-formly/core';
5
+ import { FormsModule, ReactiveFormsModule } from '@angular/forms';
6
+ import { MatInputModule } from '@angular/material/input';
7
+ import { DbxTextModule } from '@dereekb/dbx-web';
8
+ import { NgxMapboxGLModule } from 'ngx-mapbox-gl';
9
+ import { MatIconModule } from '@angular/material/icon';
10
+ import { MatButtonModule } from '@angular/material/button';
11
+ import { DbxMapboxModule } from '@dereekb/dbx-web/mapbox';
12
+ import * as i0 from "@angular/core";
13
+ import * as i1 from "@ngx-formly/core";
14
+ export class DbxFormMapboxZoomModule {
15
+ }
16
+ DbxFormMapboxZoomModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxFormMapboxZoomModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
17
+ DbxFormMapboxZoomModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.1.2", ngImport: i0, type: DbxFormMapboxZoomModule, declarations: [DbxFormMapboxZoomFieldComponent], imports: [CommonModule,
18
+ MatIconModule,
19
+ MatButtonModule,
20
+ DbxTextModule,
21
+ DbxMapboxModule,
22
+ FormsModule,
23
+ ReactiveFormsModule,
24
+ MatInputModule, i1.FormlyModule, NgxMapboxGLModule] });
25
+ DbxFormMapboxZoomModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxFormMapboxZoomModule, imports: [CommonModule,
26
+ MatIconModule,
27
+ MatButtonModule,
28
+ DbxTextModule,
29
+ DbxMapboxModule,
30
+ FormsModule,
31
+ ReactiveFormsModule,
32
+ MatInputModule,
33
+ FormlyModule.forChild({
34
+ types: [{ name: 'mapbox-zoom-picker', component: DbxFormMapboxZoomFieldComponent, wrappers: ['style', 'form-field'] }]
35
+ }),
36
+ NgxMapboxGLModule] });
37
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxFormMapboxZoomModule, decorators: [{
38
+ type: NgModule,
39
+ args: [{
40
+ imports: [
41
+ CommonModule,
42
+ MatIconModule,
43
+ MatButtonModule,
44
+ DbxTextModule,
45
+ DbxMapboxModule,
46
+ FormsModule,
47
+ ReactiveFormsModule,
48
+ MatInputModule,
49
+ FormlyModule.forChild({
50
+ types: [{ name: 'mapbox-zoom-picker', component: DbxFormMapboxZoomFieldComponent, wrappers: ['style', 'form-field'] }]
51
+ }),
52
+ NgxMapboxGLModule
53
+ ],
54
+ declarations: [DbxFormMapboxZoomFieldComponent]
55
+ }]
56
+ }] });
57
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiem9vbS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtZm9ybS9tYXBib3gvc3JjL2xpYi9maWVsZC96b29tL3pvb20ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSwrQkFBK0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3pFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNoRCxPQUFPLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNqRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbEQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0seUJBQXlCLENBQUM7OztBQW1CMUQsTUFBTSxPQUFPLHVCQUF1Qjs7b0hBQXZCLHVCQUF1QjtxSEFBdkIsdUJBQXVCLGlCQUZuQiwrQkFBK0IsYUFiNUMsWUFBWTtRQUNaLGFBQWE7UUFDYixlQUFlO1FBQ2YsYUFBYTtRQUNiLGVBQWU7UUFDZixXQUFXO1FBQ1gsbUJBQW1CO1FBQ25CLGNBQWMsbUJBSWQsaUJBQWlCO3FIQUlSLHVCQUF1QixZQWZoQyxZQUFZO1FBQ1osYUFBYTtRQUNiLGVBQWU7UUFDZixhQUFhO1FBQ2IsZUFBZTtRQUNmLFdBQVc7UUFDWCxtQkFBbUI7UUFDbkIsY0FBYztRQUNkLFlBQVksQ0FBQyxRQUFRLENBQUM7WUFDcEIsS0FBSyxFQUFFLENBQUMsRUFBRSxJQUFJLEVBQUUsb0JBQW9CLEVBQUUsU0FBUyxFQUFFLCtCQUErQixFQUFFLFFBQVEsRUFBRSxDQUFDLE9BQU8sRUFBRSxZQUFZLENBQUMsRUFBRSxDQUFDO1NBQ3ZILENBQUM7UUFDRixpQkFBaUI7MkZBSVIsdUJBQXVCO2tCQWpCbkMsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixhQUFhO3dCQUNiLGVBQWU7d0JBQ2YsYUFBYTt3QkFDYixlQUFlO3dCQUNmLFdBQVc7d0JBQ1gsbUJBQW1CO3dCQUNuQixjQUFjO3dCQUNkLFlBQVksQ0FBQyxRQUFRLENBQUM7NEJBQ3BCLEtBQUssRUFBRSxDQUFDLEVBQUUsSUFBSSxFQUFFLG9CQUFvQixFQUFFLFNBQVMsRUFBRSwrQkFBK0IsRUFBRSxRQUFRLEVBQUUsQ0FBQyxPQUFPLEVBQUUsWUFBWSxDQUFDLEVBQUUsQ0FBQzt5QkFDdkgsQ0FBQzt3QkFDRixpQkFBaUI7cUJBQ2xCO29CQUNELFlBQVksRUFBRSxDQUFDLCtCQUErQixDQUFDO2lCQUNoRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgRGJ4Rm9ybU1hcGJveFpvb21GaWVsZENvbXBvbmVudCB9IGZyb20gJy4vem9vbS5maWVsZC5jb21wb25lbnQnO1xuaW1wb3J0IHsgRm9ybWx5TW9kdWxlIH0gZnJvbSAnQG5neC1mb3JtbHkvY29yZSc7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IE1hdElucHV0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaW5wdXQnO1xuaW1wb3J0IHsgRGJ4VGV4dE1vZHVsZSB9IGZyb20gJ0BkZXJlZWtiL2RieC13ZWInO1xuaW1wb3J0IHsgTmd4TWFwYm94R0xNb2R1bGUgfSBmcm9tICduZ3gtbWFwYm94LWdsJztcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQgeyBEYnhNYXBib3hNb2R1bGUgfSBmcm9tICdAZGVyZWVrYi9kYngtd2ViL21hcGJveCc7XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgTWF0SWNvbk1vZHVsZSxcbiAgICBNYXRCdXR0b25Nb2R1bGUsXG4gICAgRGJ4VGV4dE1vZHVsZSxcbiAgICBEYnhNYXBib3hNb2R1bGUsXG4gICAgRm9ybXNNb2R1bGUsXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcbiAgICBNYXRJbnB1dE1vZHVsZSxcbiAgICBGb3JtbHlNb2R1bGUuZm9yQ2hpbGQoe1xuICAgICAgdHlwZXM6IFt7IG5hbWU6ICdtYXBib3gtem9vbS1waWNrZXInLCBjb21wb25lbnQ6IERieEZvcm1NYXBib3hab29tRmllbGRDb21wb25lbnQsIHdyYXBwZXJzOiBbJ3N0eWxlJywgJ2Zvcm0tZmllbGQnXSB9XVxuICAgIH0pLFxuICAgIE5neE1hcGJveEdMTW9kdWxlXG4gIF0sXG4gIGRlY2xhcmF0aW9uczogW0RieEZvcm1NYXBib3hab29tRmllbGRDb21wb25lbnRdXG59KVxuZXhwb3J0IGNsYXNzIERieEZvcm1NYXBib3hab29tTW9kdWxlIHt9XG4iXX0=
@@ -1,15 +1,16 @@
1
1
  import { NgModule } from '@angular/core';
2
+ import { DbxFormMapboxZoomModule } from './field';
2
3
  import { DbxFormMapboxLatLngModule } from './field/latlng/latlng.module';
3
4
  import * as i0 from "@angular/core";
4
5
  export class DbxFormMapboxModule {
5
6
  }
6
7
  DbxFormMapboxModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxFormMapboxModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
7
- DbxFormMapboxModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.1.2", ngImport: i0, type: DbxFormMapboxModule, exports: [DbxFormMapboxLatLngModule] });
8
- DbxFormMapboxModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxFormMapboxModule, imports: [DbxFormMapboxLatLngModule] });
8
+ DbxFormMapboxModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.1.2", ngImport: i0, type: DbxFormMapboxModule, exports: [DbxFormMapboxLatLngModule, DbxFormMapboxZoomModule] });
9
+ DbxFormMapboxModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxFormMapboxModule, imports: [DbxFormMapboxLatLngModule, DbxFormMapboxZoomModule] });
9
10
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxFormMapboxModule, decorators: [{
10
11
  type: NgModule,
11
12
  args: [{
12
- exports: [DbxFormMapboxLatLngModule]
13
+ exports: [DbxFormMapboxLatLngModule, DbxFormMapboxZoomModule]
13
14
  }]
14
15
  }] });
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwYm94Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC1mb3JtL21hcGJveC9zcmMvbGliL21hcGJveC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQzs7QUFLekUsTUFBTSxPQUFPLG1CQUFtQjs7Z0hBQW5CLG1CQUFtQjtpSEFBbkIsbUJBQW1CLFlBRnBCLHlCQUF5QjtpSEFFeEIsbUJBQW1CLFlBRnBCLHlCQUF5QjsyRkFFeEIsbUJBQW1CO2tCQUgvQixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLHlCQUF5QixDQUFDO2lCQUNyQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEYnhGb3JtTWFwYm94TGF0TG5nTW9kdWxlIH0gZnJvbSAnLi9maWVsZC9sYXRsbmcvbGF0bG5nLm1vZHVsZSc7XG5cbkBOZ01vZHVsZSh7XG4gIGV4cG9ydHM6IFtEYnhGb3JtTWFwYm94TGF0TG5nTW9kdWxlXVxufSlcbmV4cG9ydCBjbGFzcyBEYnhGb3JtTWFwYm94TW9kdWxlIHt9XG4iXX0=
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwYm94Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC1mb3JtL21hcGJveC9zcmMvbGliL21hcGJveC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFDbEQsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sOEJBQThCLENBQUM7O0FBS3pFLE1BQU0sT0FBTyxtQkFBbUI7O2dIQUFuQixtQkFBbUI7aUhBQW5CLG1CQUFtQixZQUZwQix5QkFBeUIsRUFBRSx1QkFBdUI7aUhBRWpELG1CQUFtQixZQUZwQix5QkFBeUIsRUFBRSx1QkFBdUI7MkZBRWpELG1CQUFtQjtrQkFIL0IsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsQ0FBQyx5QkFBeUIsRUFBRSx1QkFBdUIsQ0FBQztpQkFDOUQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRGJ4Rm9ybU1hcGJveFpvb21Nb2R1bGUgfSBmcm9tICcuL2ZpZWxkJztcbmltcG9ydCB7IERieEZvcm1NYXBib3hMYXRMbmdNb2R1bGUgfSBmcm9tICcuL2ZpZWxkL2xhdGxuZy9sYXRsbmcubW9kdWxlJztcblxuQE5nTW9kdWxlKHtcbiAgZXhwb3J0czogW0RieEZvcm1NYXBib3hMYXRMbmdNb2R1bGUsIERieEZvcm1NYXBib3hab29tTW9kdWxlXVxufSlcbmV4cG9ydCBjbGFzcyBEYnhGb3JtTWFwYm94TW9kdWxlIHt9XG4iXX0=