@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.
- package/esm2020/mapbox/lib/field/index.mjs +2 -1
- package/esm2020/mapbox/lib/field/latlng/latlng.field.component.mjs +54 -26
- package/esm2020/mapbox/lib/field/latlng/latlng.field.mjs +8 -4
- package/esm2020/mapbox/lib/field/zoom/index.mjs +4 -0
- package/esm2020/mapbox/lib/field/zoom/zoom.field.component.mjs +126 -0
- package/esm2020/mapbox/lib/field/zoom/zoom.field.mjs +23 -0
- package/esm2020/mapbox/lib/field/zoom/zoom.module.mjs +57 -0
- package/esm2020/mapbox/lib/mapbox.module.mjs +5 -4
- package/fesm2015/dereekb-dbx-form-mapbox.mjs +243 -33
- package/fesm2015/dereekb-dbx-form-mapbox.mjs.map +1 -1
- package/fesm2020/dereekb-dbx-form-mapbox.mjs +242 -33
- package/fesm2020/dereekb-dbx-form-mapbox.mjs.map +1 -1
- package/mapbox/esm2020/lib/field/index.mjs +2 -1
- package/mapbox/esm2020/lib/field/latlng/latlng.field.component.mjs +54 -26
- package/mapbox/esm2020/lib/field/latlng/latlng.field.mjs +8 -4
- package/mapbox/esm2020/lib/field/zoom/index.mjs +4 -0
- package/mapbox/esm2020/lib/field/zoom/zoom.field.component.mjs +126 -0
- package/mapbox/esm2020/lib/field/zoom/zoom.field.mjs +23 -0
- package/mapbox/esm2020/lib/field/zoom/zoom.module.mjs +57 -0
- package/mapbox/esm2020/lib/mapbox.module.mjs +5 -4
- package/mapbox/fesm2015/dereekb-dbx-form-mapbox.mjs +243 -33
- package/mapbox/fesm2015/dereekb-dbx-form-mapbox.mjs.map +1 -1
- package/mapbox/fesm2020/dereekb-dbx-form-mapbox.mjs +242 -33
- package/mapbox/fesm2020/dereekb-dbx-form-mapbox.mjs.map +1 -1
- package/mapbox/lib/field/index.d.ts +1 -0
- package/mapbox/lib/field/latlng/latlng.field.component.d.ts +28 -8
- package/mapbox/lib/field/latlng/latlng.field.d.ts +2 -1
- package/mapbox/lib/field/zoom/index.d.ts +3 -0
- package/mapbox/lib/field/zoom/zoom.field.component.d.ts +63 -0
- package/mapbox/lib/field/zoom/zoom.field.d.ts +6 -0
- package/mapbox/lib/field/zoom/zoom.module.d.ts +16 -0
- package/mapbox/lib/mapbox.module.d.ts +2 -1
- package/mapbox/package.json +4 -4
- package/package.json +3 -3
|
@@ -1,2 +1,3 @@
|
|
|
1
1
|
export * from './latlng';
|
|
2
|
-
|
|
2
|
+
export * from './zoom';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtZm9ybS9tYXBib3gvc3JjL2xpYi9maWVsZC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLFVBQVUsQ0FBQztBQUN6QixjQUFjLFFBQVEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGF0bG5nJztcbmV4cG9ydCAqIGZyb20gJy4vem9vbSc7XG4iXX0=
|
|
@@ -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-
|
|
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
|
-
|
|
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.
|
|
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
|
-
|
|
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: [
|
|
89
|
-
<div class="dbx-mapbox-
|
|
90
|
-
<div class="dbx-mapbox-
|
|
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)="
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
110
|
-
<div class="dbx-mapbox-
|
|
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)="
|
|
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-
|
|
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-
|
|
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: [
|
|
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
|
|
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,
|
|
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":"AACA,OAAO,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AAC1E,OAAO,EAAE,SAAS,EAAE,MAAM,EAAqB,QAAQ,EAAE,MAAM,eAAe,CAAC;AAE/E,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAS,eAAe,EAAU,WAAW,EAAE,SAAS,EAAE,SAAS,EAAmB,MAAM,MAAM,CAAC;AAC1G,OAAO,EAAE,WAAW,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;AAChE,OAAO,EAA4D,WAAW,EAA8C,MAAM,eAAe,CAAC;AAGlJ,OAAO,EAAE,gBAAgB,EAAE,iBAAiB,EAAmB,uCAAuC,EAAE,eAAe,EAAE,qBAAqB,EAAE,qBAAqB,EAAE,MAAM,yBAAyB,CAAC;;;;;;;;;AA4CvM,MAAM,OAAO,+BAAuH,SAAQ,SAA6B;IAmBvK,YAAiC,OAA4B,EAAW,gBAAkC,EAAW,iBAAoC,EAAW,MAAc;QAChL,KAAK,EAAE,CAAC;QADuB,YAAO,GAAP,OAAO,CAAqB;QAAW,qBAAgB,GAAhB,gBAAgB,CAAkB;QAAW,sBAAiB,GAAjB,iBAAiB,CAAmB;QAAW,WAAM,GAAN,MAAM,CAAQ;QAlBzK,kBAAa,GAAG,iBAAiB,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE;YAC9D,OAAO,EAAE,gCAAgC;SAC1C,CAAC,CAAC;QAEK,SAAI,GAAG,IAAI,kBAAkB,EAAE,CAAC;QAChC,YAAO,GAAG,IAAI,eAAe,CAAqB,SAAS,CAAC,CAAC;QAE7D,oBAAe,GAAG,IAAI,eAAe,CAAyB,SAAS,CAAC,CAAC;QACxE,iBAAY,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;QAExD,WAAM,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CACtC,SAAS,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,EAC3E,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QAEO,UAAK,GAAgC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;QACrF,YAAO,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;IAIpD,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,IAAI,WAAW,CAAC,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC;IACrF,CAAC;IAED,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,KAAK,CAAC,GAAa,CAAC;IAClC,CAAC;IAED,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,IAAiB,CAAC;IAChC,CAAC;IAED,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC;IACjC,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC;IAChC,CAAC;IAED,IAAI,oBAAoB;QACtB,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC;IAC9C,CAAC;IAED,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO,IAAI,IAAI,CAAC;IAC1C,CAAC;IAED,IAAI,OAAO;QACT,OAAO,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO,IAAI,qBAAqB,CAAC,CAAC;IAC5E,CAAC;IAED,IAAI,OAAO;QACT,OAAO,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO,IAAI,qBAAqB,CAAC,CAAC;IAC5E,CAAC;IAED,IAAI,QAAQ;QACV,OAAO,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,IAAI,CAAC,CAAC,CAAC;IACzD,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC5C,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAE/B,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAE3C,uCAAuC;QACvC,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;SAChD;QAED,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE;YACvB,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;YAE3B,IAAI,IAAI,CAAC,OAAO,EAAE;gBAChB,IAAI,CAAC,iBAAiB,CAAC,eAAe,EAAE,CAAC;aAC1C;SACF;QAED,IAAI,CAAC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;YACvE,IAAI,CAAC,IAAI,CAAC,oBAAoB,EAAE;gBAC9B,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC;aAC5C;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEQ,WAAW;QAClB,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC;QAChC,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;QACxB,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;IACtB,CAAC;IAED,QAAQ,CAAC,IAAuB;QAC9B,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IAClC,CAAC;;4HAlGU,+BAA+B;gHAA/B,+BAA+B,uCAH/B,CAAC,uCAAuC,EAAE,CAAC,iDAb5C;;;;;;;;;;;;GAYT;2FAIU,+BAA+B;kBAjB3C,SAAS;+BACE;;;;;;;;;;;;GAYT,aACU,CAAC,uCAAuC,EAAE,CAAC;;0BAsBzC,QAAQ","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,
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwYm94Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC1mb3JtL21hcGJveC9zcmMvbGliL21hcGJveC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFDbEQsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sOEJBQThCLENBQUM7O0FBS3pFLE1BQU0sT0FBTyxtQkFBbUI7O2dIQUFuQixtQkFBbUI7aUhBQW5CLG1CQUFtQixZQUZwQix5QkFBeUIsRUFBRSx1QkFBdUI7aUhBRWpELG1CQUFtQixZQUZwQix5QkFBeUIsRUFBRSx1QkFBdUI7MkZBRWpELG1CQUFtQjtrQkFIL0IsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsQ0FBQyx5QkFBeUIsRUFBRSx1QkFBdUIsQ0FBQztpQkFDOUQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRGJ4Rm9ybU1hcGJveFpvb21Nb2R1bGUgfSBmcm9tICcuL2ZpZWxkJztcbmltcG9ydCB7IERieEZvcm1NYXBib3hMYXRMbmdNb2R1bGUgfSBmcm9tICcuL2ZpZWxkL2xhdGxuZy9sYXRsbmcubW9kdWxlJztcblxuQE5nTW9kdWxlKHtcbiAgZXhwb3J0czogW0RieEZvcm1NYXBib3hMYXRMbmdNb2R1bGUsIERieEZvcm1NYXBib3hab29tTW9kdWxlXVxufSlcbmV4cG9ydCBjbGFzcyBEYnhGb3JtTWFwYm94TW9kdWxlIHt9XG4iXX0=
|