@dereekb/dbx-form 9.23.18 → 9.23.19
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/latlng/index.mjs +2 -1
- package/esm2020/mapbox/lib/field/latlng/latlng.field.component.mjs +87 -29
- package/esm2020/mapbox/lib/field/latlng/latlng.field.marker.component.mjs +34 -0
- package/esm2020/mapbox/lib/field/latlng/latlng.field.mjs +6 -3
- package/esm2020/mapbox/lib/field/latlng/latlng.module.mjs +6 -4
- package/fesm2015/dereekb-dbx-form-mapbox.mjs +128 -38
- package/fesm2015/dereekb-dbx-form-mapbox.mjs.map +1 -1
- package/fesm2020/dereekb-dbx-form-mapbox.mjs +126 -38
- package/fesm2020/dereekb-dbx-form-mapbox.mjs.map +1 -1
- package/mapbox/esm2020/lib/field/latlng/index.mjs +2 -1
- package/mapbox/esm2020/lib/field/latlng/latlng.field.component.mjs +87 -29
- package/mapbox/esm2020/lib/field/latlng/latlng.field.marker.component.mjs +34 -0
- package/mapbox/esm2020/lib/field/latlng/latlng.field.mjs +6 -3
- package/mapbox/esm2020/lib/field/latlng/latlng.module.mjs +6 -4
- package/mapbox/fesm2015/dereekb-dbx-form-mapbox.mjs +128 -38
- package/mapbox/fesm2015/dereekb-dbx-form-mapbox.mjs.map +1 -1
- package/mapbox/fesm2020/dereekb-dbx-form-mapbox.mjs +126 -38
- package/mapbox/fesm2020/dereekb-dbx-form-mapbox.mjs.map +1 -1
- package/mapbox/lib/field/latlng/index.d.ts +1 -0
- package/mapbox/lib/field/latlng/latlng.field.component.d.ts +45 -5
- package/mapbox/lib/field/latlng/latlng.field.d.ts +1 -1
- package/mapbox/lib/field/latlng/latlng.field.marker.component.d.ts +12 -0
- package/mapbox/lib/field/latlng/latlng.module.d.ts +11 -10
- package/mapbox/package.json +4 -4
- package/package.json +4 -4
|
@@ -1,15 +1,16 @@
|
|
|
1
1
|
import { CompactContextStore, mapCompactModeObs } from '@dereekb/dbx-web';
|
|
2
|
-
import { Component, NgZone, Optional } from '@angular/core';
|
|
2
|
+
import { Component, Injector, NgZone, Optional } from '@angular/core';
|
|
3
3
|
import { FieldType } from '@ngx-formly/material';
|
|
4
|
-
import { skip, first, BehaviorSubject, filter, shareReplay, startWith, switchMap, map, throttleTime, skipWhile } from 'rxjs';
|
|
5
|
-
import { filterMaybe, SubscriptionObject } from '@dereekb/rxjs';
|
|
6
|
-
import { latLngStringFunction, latLngPointFunction, isDefaultLatLngPoint, isValidLatLngPoint } from '@dereekb/util';
|
|
4
|
+
import { skip, first, BehaviorSubject, filter, shareReplay, startWith, switchMap, map, throttleTime, skipWhile, of, distinctUntilChanged } from 'rxjs';
|
|
5
|
+
import { asObservableFromGetter, filterMaybe, SubscriptionObject } from '@dereekb/rxjs';
|
|
6
|
+
import { latLngStringFunction, latLngPointFunction, isDefaultLatLngPoint, isValidLatLngPoint, isSameLatLngPoint } from '@dereekb/util';
|
|
7
7
|
import { GeolocationService } from '@ng-web-apis/geolocation';
|
|
8
|
-
import { DbxMapboxMapStore, provideMapboxStoreIfParentIsUnavailable } from '@dereekb/dbx-web/mapbox';
|
|
8
|
+
import { DbxMapboxInjectionStore, DbxMapboxMapStore, provideMapboxStoreIfParentIsUnavailable } from '@dereekb/dbx-web/mapbox';
|
|
9
|
+
import { DbxFormMapboxLatLngFieldMarkerComponent } from './latlng.field.marker.component';
|
|
9
10
|
import * as i0 from "@angular/core";
|
|
10
11
|
import * as i1 from "@dereekb/dbx-web";
|
|
11
|
-
import * as i2 from "@
|
|
12
|
-
import * as i3 from "@
|
|
12
|
+
import * as i2 from "@dereekb/dbx-web/mapbox";
|
|
13
|
+
import * as i3 from "@ng-web-apis/geolocation";
|
|
13
14
|
import * as i4 from "@angular/common";
|
|
14
15
|
import * as i5 from "@angular/material/icon";
|
|
15
16
|
import * as i6 from "@angular/material/button";
|
|
@@ -17,13 +18,27 @@ import * as i7 from "@angular/forms";
|
|
|
17
18
|
import * as i8 from "@angular/material/form-field";
|
|
18
19
|
import * as i9 from "@angular/material/input";
|
|
19
20
|
import * as i10 from "ngx-mapbox-gl";
|
|
21
|
+
export const DEFAULT_DBX_FORM_MAPBOX_LAT_LNG_FIELD_INJECTION_KEY = 'DbxFormMapboxLatLngFieldComponent';
|
|
22
|
+
export const DEFAULT_DBX_FORM_MAPBOX_LAT_LNG_MARKER_CONFIG = {
|
|
23
|
+
icon: 'pin_drop'
|
|
24
|
+
};
|
|
25
|
+
/*
|
|
26
|
+
TODO: Re-add menu for picking a new location, including using the current location.
|
|
27
|
+
<button mat-icon-button (click)="useCurrentLocation()" [disabled]="isReadonlyOrDisabled || (useCurrentLocationDisabled$ | async)">
|
|
28
|
+
<mat-icon>my_location</mat-icon>
|
|
29
|
+
</button>
|
|
30
|
+
*/
|
|
20
31
|
export class DbxFormMapboxLatLngFieldComponent extends FieldType {
|
|
21
|
-
constructor(
|
|
32
|
+
constructor(
|
|
33
|
+
//
|
|
34
|
+
compact, dbxMapboxInjectionStore, geolocation$, dbxMapboxMapStore, ngZone, injector) {
|
|
22
35
|
super();
|
|
23
36
|
this.compact = compact;
|
|
37
|
+
this.dbxMapboxInjectionStore = dbxMapboxInjectionStore;
|
|
24
38
|
this.geolocation$ = geolocation$;
|
|
25
39
|
this.dbxMapboxMapStore = dbxMapboxMapStore;
|
|
26
40
|
this.ngZone = ngZone;
|
|
41
|
+
this.injector = injector;
|
|
27
42
|
this.compactClass$ = mapCompactModeObs(this.compact?.mode$, {
|
|
28
43
|
compact: 'dbx-mapbox-input-field-compact'
|
|
29
44
|
});
|
|
@@ -32,13 +47,15 @@ export class DbxFormMapboxLatLngFieldComponent extends FieldType {
|
|
|
32
47
|
this._sub = new SubscriptionObject();
|
|
33
48
|
this._geoSub = new SubscriptionObject();
|
|
34
49
|
this._centerSub = new SubscriptionObject();
|
|
50
|
+
this._flyToCenterSub = new SubscriptionObject();
|
|
35
51
|
this._clickSub = new SubscriptionObject();
|
|
36
52
|
this._zoom = new BehaviorSubject(12);
|
|
53
|
+
this._markerConfig = new BehaviorSubject(of(DEFAULT_DBX_FORM_MAPBOX_LAT_LNG_MARKER_CONFIG));
|
|
37
54
|
this._formControlObs = new BehaviorSubject(undefined);
|
|
38
55
|
this.formControl$ = this._formControlObs.pipe(filterMaybe());
|
|
39
56
|
this.value$ = this.formControl$.pipe(switchMap((control) => control.valueChanges.pipe(startWith(control.value))), shareReplay(1));
|
|
40
|
-
this.latLng$ = this.value$.pipe(filterMaybe(), map((x) => this._latLngPointFunction(x)), shareReplay(1));
|
|
41
|
-
this.
|
|
57
|
+
this.latLng$ = this.value$.pipe(filterMaybe(), map((x) => this._latLngPointFunction(x)), distinctUntilChanged(isSameLatLngPoint), shareReplay(1));
|
|
58
|
+
this.nonZeroLatLng$ = this.latLng$.pipe(
|
|
42
59
|
/**
|
|
43
60
|
* Center observable passed to the store. Do not pass invalid points.
|
|
44
61
|
*
|
|
@@ -46,6 +63,7 @@ export class DbxFormMapboxLatLngFieldComponent extends FieldType {
|
|
|
46
63
|
*/
|
|
47
64
|
skipWhile(isDefaultLatLngPoint), filter(isValidLatLngPoint));
|
|
48
65
|
this.zoom$ = this._zoom.asObservable();
|
|
66
|
+
this.markerConfig$ = this._markerConfig.asObservable().pipe(switchMap((x) => x), shareReplay(1));
|
|
49
67
|
}
|
|
50
68
|
get zoom() {
|
|
51
69
|
return Math.min(this.field.props.zoom || 12, 18);
|
|
@@ -68,43 +86,63 @@ export class DbxFormMapboxLatLngFieldComponent extends FieldType {
|
|
|
68
86
|
get showMap() {
|
|
69
87
|
return this.field.props.showMap ?? true;
|
|
70
88
|
}
|
|
89
|
+
get selectLocationOnMapDrag() {
|
|
90
|
+
return this.field.props.selectLocationOnMapDrag ?? true;
|
|
91
|
+
}
|
|
71
92
|
get selectLocationOnMapClick() {
|
|
72
93
|
return this.field.props.selectLocationOnMapClick ?? false;
|
|
73
94
|
}
|
|
95
|
+
get setCenterOnLocationSet() {
|
|
96
|
+
return this.field.props.setCenterOnLocationSet ?? true;
|
|
97
|
+
}
|
|
98
|
+
get showCenterButton() {
|
|
99
|
+
return !this.selectLocationOnMapDrag && this.props.showCenterButton !== false;
|
|
100
|
+
}
|
|
74
101
|
get recenterTime() {
|
|
75
102
|
return this.field.props.recenterTime || 10 * 1000;
|
|
76
103
|
}
|
|
77
104
|
get useCurrentLocationDisabled() {
|
|
78
105
|
return this._useCurrentLocationDisabled;
|
|
79
106
|
}
|
|
107
|
+
get mapInjectionKey() {
|
|
108
|
+
return this.field.props.mapInjectionKey;
|
|
109
|
+
}
|
|
110
|
+
get markerConfig() {
|
|
111
|
+
return this.field.props.markerConfig;
|
|
112
|
+
}
|
|
80
113
|
ngOnInit() {
|
|
81
114
|
const latLngPointConfig = { ...this.field.props.latLngConfig, wrap: this.field.props.latLngConfig?.wrap || false, validate: this.field.props.latLngConfig?.validate || false, precisionRounding: this.field.props.latLngConfig?.precisionRounding ?? 'round' };
|
|
82
115
|
this._latLngStringFunction = latLngStringFunction(latLngPointConfig);
|
|
83
116
|
this._latLngPointFunction = latLngPointFunction(latLngPointConfig);
|
|
84
117
|
this._formControlObs.next(this.formControl);
|
|
85
118
|
this._zoom.next(this.zoom);
|
|
86
|
-
|
|
119
|
+
if (this.setCenterOnLocationSet) {
|
|
120
|
+
this._centerSub.subscription = this.dbxMapboxMapStore.setCenter(this.nonZeroLatLng$);
|
|
121
|
+
}
|
|
87
122
|
if (this.showMap) {
|
|
88
123
|
// Set zoom only if showMap is true
|
|
89
124
|
this.dbxMapboxMapStore.setZoom(this.zoom$);
|
|
90
125
|
// recenter periodically
|
|
91
126
|
if (this.recenterTime > 0) {
|
|
92
|
-
this.
|
|
93
|
-
this.
|
|
127
|
+
this._flyToCenterSub.subscription = this.dbxMapboxMapStore.center$.pipe(skip(1), throttleTime(this.recenterTime, undefined, { leading: false, trailing: true })).subscribe(() => {
|
|
128
|
+
this.flyToMarker();
|
|
94
129
|
});
|
|
95
130
|
}
|
|
96
131
|
}
|
|
97
132
|
else {
|
|
98
133
|
// use the center of the map to set locations
|
|
99
|
-
|
|
100
|
-
this.dbxMapboxMapStore.
|
|
101
|
-
|
|
102
|
-
this.
|
|
103
|
-
this.
|
|
104
|
-
|
|
105
|
-
|
|
134
|
+
if (this.selectLocationOnMapDrag) {
|
|
135
|
+
this._sub.subscription = this.dbxMapboxMapStore.center$.subscribe((center) => {
|
|
136
|
+
this.dbxMapboxMapStore.centerGivenMargin$.pipe(first()).subscribe(() => {
|
|
137
|
+
if (!this.isReadonlyOrDisabled) {
|
|
138
|
+
this.ngZone.run(() => {
|
|
139
|
+
this.setValue(center);
|
|
140
|
+
});
|
|
141
|
+
}
|
|
142
|
+
});
|
|
106
143
|
});
|
|
107
|
-
}
|
|
144
|
+
}
|
|
145
|
+
// enable selecting the location on a map click
|
|
108
146
|
if (this.selectLocationOnMapClick) {
|
|
109
147
|
this._clickSub.subscription = this.dbxMapboxMapStore.clickEvent$.subscribe((x) => {
|
|
110
148
|
if (x?.type === 'click') {
|
|
@@ -116,16 +154,34 @@ export class DbxFormMapboxLatLngFieldComponent extends FieldType {
|
|
|
116
154
|
if (this.props.readonly) {
|
|
117
155
|
this.formControl.disable();
|
|
118
156
|
}
|
|
157
|
+
// Add the marker to the injection store for display
|
|
158
|
+
if (this.dbxMapboxInjectionStore) {
|
|
159
|
+
if (this.markerConfig) {
|
|
160
|
+
this._markerConfig.next(asObservableFromGetter(this.markerConfig, this));
|
|
161
|
+
}
|
|
162
|
+
this.dbxMapboxInjectionStore.addInjectionConfig({
|
|
163
|
+
key: this.mapInjectionKey || DEFAULT_DBX_FORM_MAPBOX_LAT_LNG_FIELD_INJECTION_KEY,
|
|
164
|
+
injectionConfig: {
|
|
165
|
+
componentClass: DbxFormMapboxLatLngFieldMarkerComponent,
|
|
166
|
+
providers: [{ provide: DbxFormMapboxLatLngFieldComponent, useValue: this }]
|
|
167
|
+
}
|
|
168
|
+
});
|
|
169
|
+
}
|
|
119
170
|
}
|
|
120
171
|
ngOnDestroy() {
|
|
121
172
|
super.ngOnDestroy();
|
|
122
|
-
this._sub.destroy();
|
|
123
|
-
this._geoSub.destroy();
|
|
124
173
|
this._zoom.complete();
|
|
174
|
+
this._markerConfig.complete();
|
|
125
175
|
this._formControlObs.complete();
|
|
176
|
+
this._sub.destroy();
|
|
177
|
+
this._geoSub.destroy();
|
|
126
178
|
this._centerSub.destroy();
|
|
179
|
+
this._flyToCenterSub.destroy();
|
|
127
180
|
this._clickSub.destroy();
|
|
128
181
|
}
|
|
182
|
+
flyToMarker() {
|
|
183
|
+
this.dbxMapboxMapStore.easeTo(this.nonZeroLatLng$.pipe(first(), map((x) => ({ center: x }))));
|
|
184
|
+
}
|
|
129
185
|
useCurrentLocation() {
|
|
130
186
|
this._geoSub.subscription = this.geolocation$.pipe(first()).subscribe({
|
|
131
187
|
next: (position) => {
|
|
@@ -148,7 +204,7 @@ export class DbxFormMapboxLatLngFieldComponent extends FieldType {
|
|
|
148
204
|
this.formControl.markAsDirty();
|
|
149
205
|
}
|
|
150
206
|
}
|
|
151
|
-
DbxFormMapboxLatLngFieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxFormMapboxLatLngFieldComponent, deps: [{ token: i1.CompactContextStore, optional: true }, { token: i2.
|
|
207
|
+
DbxFormMapboxLatLngFieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxFormMapboxLatLngFieldComponent, deps: [{ token: i1.CompactContextStore, optional: true }, { token: i2.DbxMapboxInjectionStore, optional: true }, { token: i3.GeolocationService }, { token: i2.DbxMapboxMapStore }, { token: i0.NgZone }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
|
|
152
208
|
DbxFormMapboxLatLngFieldComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxFormMapboxLatLngFieldComponent, selector: "ng-component", providers: [provideMapboxStoreIfParentIsUnavailable()], usesInheritance: true, ngImport: i0, template: `
|
|
153
209
|
<div class="dbx-mapbox-input-field" [ngClass]="(compactClass$ | async) ?? ''" [formGroup]="formGroup">
|
|
154
210
|
<div *ngIf="showMap" class="dbx-mapbox-input-field-map">
|
|
@@ -157,7 +213,7 @@ DbxFormMapboxLatLngFieldComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion
|
|
|
157
213
|
</mgl-map>
|
|
158
214
|
</div>
|
|
159
215
|
<div class="dbx-mapbox-input-field-input">
|
|
160
|
-
<button mat-icon-button (click)="
|
|
216
|
+
<button *ngIf="showCenterButton" mat-icon-button (click)="flyToMarker()">
|
|
161
217
|
<mat-icon>my_location</mat-icon>
|
|
162
218
|
</button>
|
|
163
219
|
<mat-form-field class="dbx-mapbox-input-field-input-field" appearance="standard">
|
|
@@ -167,7 +223,7 @@ DbxFormMapboxLatLngFieldComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion
|
|
|
167
223
|
</mat-form-field>
|
|
168
224
|
</div>
|
|
169
225
|
</div>
|
|
170
|
-
`, 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:
|
|
226
|
+
`, 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: i2.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.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { 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" }] });
|
|
171
227
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxFormMapboxLatLngFieldComponent, decorators: [{
|
|
172
228
|
type: Component,
|
|
173
229
|
args: [{ template: `
|
|
@@ -178,7 +234,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
178
234
|
</mgl-map>
|
|
179
235
|
</div>
|
|
180
236
|
<div class="dbx-mapbox-input-field-input">
|
|
181
|
-
<button mat-icon-button (click)="
|
|
237
|
+
<button *ngIf="showCenterButton" mat-icon-button (click)="flyToMarker()">
|
|
182
238
|
<mat-icon>my_location</mat-icon>
|
|
183
239
|
</button>
|
|
184
240
|
<mat-form-field class="dbx-mapbox-input-field-input-field" appearance="standard">
|
|
@@ -191,5 +247,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
191
247
|
`, 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"] }]
|
|
192
248
|
}], ctorParameters: function () { return [{ type: i1.CompactContextStore, decorators: [{
|
|
193
249
|
type: Optional
|
|
194
|
-
}] }, { type: i2.
|
|
195
|
-
//# 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, skipWhile } from 'rxjs';\nimport { filterMaybe, SubscriptionObject } from '@dereekb/rxjs';\nimport { Maybe, LatLngPoint, LatLngPointFunctionConfig, LatLngStringFunction, latLngStringFunction, Milliseconds, latLngPointFunction, isDefaultLatLngPoint, isValidLatLngPoint, LatLngPointFunction, isDefaultLatLngPointValue } 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   * Whether or not to enable clicking the map to select the location. Defaults to false.\n   *\n   * Only applicable when showMap is false.\n   */\n  selectLocationOnMapClick?: 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 || (useCurrentLocationDisabled$ | async)\">\n          <mat-icon>my_location</mat-icon>\n        </button>\n        <mat-form-field class=\"dbx-mapbox-input-field-input-field\" appearance=\"standard\">\n          <mat-label>Coordinates</mat-label>\n          <input type=\"text\" matInput [placeholder]=\"placeholder\" [formControl]=\"formControl\" />\n          <mat-hint class=\"dbx-hint dbx-warn\" *ngIf=\"useCurrentLocationDisabled$ | async\">Could not access your current location.</mat-hint>\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  private _latLngPointFunction!: LatLngPointFunction;\n\n  readonly compactClass$ = mapCompactModeObs(this.compact?.mode$, {\n    compact: 'dbx-mapbox-input-field-compact'\n  });\n\n  private _useCurrentLocationDisabled = new BehaviorSubject<boolean>(false);\n  readonly useCurrentLocationDisabled$ = this._useCurrentLocationDisabled.asObservable();\n\n  private _sub = new SubscriptionObject();\n  private _geoSub = new SubscriptionObject();\n  private _centerSub = new SubscriptionObject();\n  private _clickSub = 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) => this._latLngPointFunction(x)),\n    shareReplay(1)\n  );\n\n  readonly center$: Observable<LatLngPoint> = this.latLng$.pipe(\n    /**\n     * Center observable passed to the store. Do not pass invalid points.\n     *\n     * Also skip any initial 0,0 values so the center doesn't potentially \"whip\" from 0,0 to a final loaded value.\n     */\n    skipWhile<LatLngPoint>(isDefaultLatLngPoint),\n    filter(isValidLatLngPoint)\n  );\n\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 selectLocationOnMapClick(): boolean {\n    return this.field.props.selectLocationOnMapClick ?? false;\n  }\n\n  get recenterTime(): Milliseconds {\n    return this.field.props.recenterTime || 10 * 1000;\n  }\n\n  get useCurrentLocationDisabled() {\n    return this._useCurrentLocationDisabled;\n  }\n\n  ngOnInit(): void {\n    const latLngPointConfig = { ...this.field.props.latLngConfig, wrap: this.field.props.latLngConfig?.wrap || false, validate: this.field.props.latLngConfig?.validate || false, precisionRounding: this.field.props.latLngConfig?.precisionRounding ?? 'round' };\n    this._latLngStringFunction = latLngStringFunction(latLngPointConfig);\n    this._latLngPointFunction = latLngPointFunction(latLngPointConfig);\n\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        this.dbxMapboxMapStore.centerGivenMargin$.pipe(first()).subscribe(() => {\n          if (!this.isReadonlyOrDisabled) {\n            this.ngZone.run(() => {\n              this.setValue(center);\n            });\n          }\n        });\n      });\n\n      if (this.selectLocationOnMapClick) {\n        this._clickSub.subscription = this.dbxMapboxMapStore.clickEvent$.subscribe((x) => {\n          if (x?.type === 'click') {\n            this.setValue(x.lngLat);\n          }\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    this._clickSub.destroy();\n  }\n\n  useCurrentLocation() {\n    this._geoSub.subscription = this.geolocation$.pipe(first()).subscribe({\n      next: (position) => {\n        if (position) {\n          const { latitude: lat, longitude: lng } = position.coords;\n          this.setValue({ lat, lng });\n        }\n      },\n      error: () => {\n        this._useCurrentLocationDisabled.next(true);\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    this.formControl.markAsTouched();\n    this.formControl.markAsDirty();\n  }\n}\n"]}
|
|
250
|
+
}] }, { type: i2.DbxMapboxInjectionStore, decorators: [{
|
|
251
|
+
type: Optional
|
|
252
|
+
}] }, { type: i3.GeolocationService }, { type: i2.DbxMapboxMapStore }, { type: i0.NgZone }, { type: i0.Injector }]; } });
|
|
253
|
+
//# 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, Injector, 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, skipWhile, of, distinctUntilChanged } from 'rxjs';\nimport { asObservableFromGetter, filterMaybe, ObservableFactoryWithRequiredInput, ObservableOrValueGetter, SubscriptionObject } from '@dereekb/rxjs';\nimport { Maybe, LatLngPoint, LatLngPointFunctionConfig, LatLngStringFunction, latLngStringFunction, Milliseconds, latLngPointFunction, isDefaultLatLngPoint, isValidLatLngPoint, LatLngPointFunction, isDefaultLatLngPointValue, FactoryWithInput, isSameLatLngPoint } from '@dereekb/util';\nimport { GeolocationService } from '@ng-web-apis/geolocation';\nimport { Marker } from 'mapbox-gl';\nimport { dbxMapboxColoredDotStyle, DbxMapboxInjectionStore, DbxMapboxMapStore, DbxMapboxMarkerDisplayConfig, DbxMapboxMarkerPresentation, MapboxEaseTo, MapboxZoomLevel, provideMapboxStoreIfParentIsUnavailable } from '@dereekb/dbx-web/mapbox';\nimport { DbxFormMapboxLatLngFieldMarkerComponent } from './latlng.field.marker.component';\n\nexport const DEFAULT_DBX_FORM_MAPBOX_LAT_LNG_FIELD_INJECTION_KEY = 'DbxFormMapboxLatLngFieldComponent';\n\nexport const DEFAULT_DBX_FORM_MAPBOX_LAT_LNG_MARKER_CONFIG: DbxMapboxMarkerDisplayConfig = {\n  icon: 'pin_drop'\n};\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   * Whether or not to display the center button. Is set to false if selectLocationOnMapDrag is true.\n   */\n  showCenterButton?: boolean;\n  /**\n   * Whether or not to set the center of the map on the location when set. Defaults to true.\n   */\n  setCenterOnLocationSet?: boolean;\n  /**\n   * Whether or not to enable dragging the map to select the location. Defaults to true.\n   *\n   * Only applicable when showMap is false.\n   */\n  selectLocationOnMapDrag?: boolean;\n  /**\n   * Whether or not to enable clicking the map to select the location. Defaults to false.\n   *\n   * Only applicable when showMap is false.\n   */\n  selectLocationOnMapClick?: 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   * Unique injection key.\n   *\n   * If not defined, the default key will be used.\n   *\n   * If false is passed, the marker will not be configured in the injection store.\n   */\n  mapInjectionKey?: Maybe<string | false>;\n  /**\n   * Marker configuration or factory. If false is passed, the marker will not be displayed.\n   */\n  markerConfig?: ObservableFactoryWithRequiredInput<DbxMapboxMarkerDisplayConfig | false, DbxFormMapboxLatLngFieldComponent>;\n}\n\n/*\n  TODO: Re-add menu for picking a new location, including using the current location.\n <button mat-icon-button (click)=\"useCurrentLocation()\" [disabled]=\"isReadonlyOrDisabled || (useCurrentLocationDisabled$ | async)\">\n          <mat-icon>my_location</mat-icon>\n        </button>\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 *ngIf=\"showCenterButton\" mat-icon-button (click)=\"flyToMarker()\">\n          <mat-icon>my_location</mat-icon>\n        </button>\n        <mat-form-field class=\"dbx-mapbox-input-field-input-field\" appearance=\"standard\">\n          <mat-label>Coordinates</mat-label>\n          <input type=\"text\" matInput [placeholder]=\"placeholder\" [formControl]=\"formControl\" />\n          <mat-hint class=\"dbx-hint dbx-warn\" *ngIf=\"useCurrentLocationDisabled$ | async\">Could not access your current location.</mat-hint>\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  private _latLngPointFunction!: LatLngPointFunction;\n\n  readonly compactClass$ = mapCompactModeObs(this.compact?.mode$, {\n    compact: 'dbx-mapbox-input-field-compact'\n  });\n\n  private _useCurrentLocationDisabled = new BehaviorSubject<boolean>(false);\n  readonly useCurrentLocationDisabled$ = this._useCurrentLocationDisabled.asObservable();\n\n  private _sub = new SubscriptionObject();\n  private _geoSub = new SubscriptionObject();\n  private _centerSub = new SubscriptionObject();\n  private _flyToCenterSub = new SubscriptionObject();\n  private _clickSub = new SubscriptionObject();\n  private _zoom = new BehaviorSubject<MapboxZoomLevel>(12);\n  private _markerConfig = new BehaviorSubject<Observable<DbxMapboxMarkerDisplayConfig | false>>(of(DEFAULT_DBX_FORM_MAPBOX_LAT_LNG_MARKER_CONFIG));\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) => this._latLngPointFunction(x)),\n    distinctUntilChanged<LatLngPoint>(isSameLatLngPoint),\n    shareReplay(1)\n  );\n\n  readonly nonZeroLatLng$: Observable<LatLngPoint> = this.latLng$.pipe(\n    /**\n     * Center observable passed to the store. Do not pass invalid points.\n     *\n     * Also skip any initial 0,0 values so the center doesn't potentially \"whip\" from 0,0 to a final loaded value.\n     */\n    skipWhile<LatLngPoint>(isDefaultLatLngPoint),\n    filter(isValidLatLngPoint)\n  );\n\n  readonly zoom$ = this._zoom.asObservable();\n  readonly markerConfig$ = this._markerConfig.asObservable().pipe(\n    switchMap((x) => x),\n    shareReplay(1)\n  );\n\n  constructor(\n    //\n    @Optional() readonly compact: CompactContextStore,\n    @Optional() readonly dbxMapboxInjectionStore: DbxMapboxInjectionStore,\n    private readonly geolocation$: GeolocationService,\n    readonly dbxMapboxMapStore: DbxMapboxMapStore,\n    readonly ngZone: NgZone,\n    readonly injector: Injector\n  ) {\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 selectLocationOnMapDrag(): boolean {\n    return this.field.props.selectLocationOnMapDrag ?? true;\n  }\n\n  get selectLocationOnMapClick(): boolean {\n    return this.field.props.selectLocationOnMapClick ?? false;\n  }\n\n  get setCenterOnLocationSet() {\n    return this.field.props.setCenterOnLocationSet ?? true;\n  }\n\n  get showCenterButton() {\n    return !this.selectLocationOnMapDrag && this.props.showCenterButton !== false;\n  }\n\n  get recenterTime(): Milliseconds {\n    return this.field.props.recenterTime || 10 * 1000;\n  }\n\n  get useCurrentLocationDisabled() {\n    return this._useCurrentLocationDisabled;\n  }\n\n  get mapInjectionKey() {\n    return this.field.props.mapInjectionKey;\n  }\n\n  get markerConfig() {\n    return this.field.props.markerConfig;\n  }\n\n  ngOnInit(): void {\n    const latLngPointConfig = { ...this.field.props.latLngConfig, wrap: this.field.props.latLngConfig?.wrap || false, validate: this.field.props.latLngConfig?.validate || false, precisionRounding: this.field.props.latLngConfig?.precisionRounding ?? 'round' };\n    this._latLngStringFunction = latLngStringFunction(latLngPointConfig);\n    this._latLngPointFunction = latLngPointFunction(latLngPointConfig);\n\n    this._formControlObs.next(this.formControl);\n    this._zoom.next(this.zoom);\n\n    if (this.setCenterOnLocationSet) {\n      this._centerSub.subscription = this.dbxMapboxMapStore.setCenter(this.nonZeroLatLng$);\n    }\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._flyToCenterSub.subscription = this.dbxMapboxMapStore.center$.pipe(skip(1), throttleTime(this.recenterTime, undefined, { leading: false, trailing: true })).subscribe(() => {\n          this.flyToMarker();\n        });\n      }\n    } else {\n      // use the center of the map to set locations\n      if (this.selectLocationOnMapDrag) {\n        this._sub.subscription = this.dbxMapboxMapStore.center$.subscribe((center) => {\n          this.dbxMapboxMapStore.centerGivenMargin$.pipe(first()).subscribe(() => {\n            if (!this.isReadonlyOrDisabled) {\n              this.ngZone.run(() => {\n                this.setValue(center);\n              });\n            }\n          });\n        });\n      }\n\n      // enable selecting the location on a map click\n      if (this.selectLocationOnMapClick) {\n        this._clickSub.subscription = this.dbxMapboxMapStore.clickEvent$.subscribe((x) => {\n          if (x?.type === 'click') {\n            this.setValue(x.lngLat);\n          }\n        });\n      }\n    }\n\n    if (this.props.readonly) {\n      this.formControl.disable();\n    }\n\n    // Add the marker to the injection store for display\n    if (this.dbxMapboxInjectionStore) {\n      if (this.markerConfig) {\n        this._markerConfig.next(asObservableFromGetter(this.markerConfig, this));\n      }\n\n      this.dbxMapboxInjectionStore.addInjectionConfig({\n        key: this.mapInjectionKey || DEFAULT_DBX_FORM_MAPBOX_LAT_LNG_FIELD_INJECTION_KEY,\n        injectionConfig: {\n          componentClass: DbxFormMapboxLatLngFieldMarkerComponent,\n          providers: [{ provide: DbxFormMapboxLatLngFieldComponent, useValue: this }]\n        }\n      });\n    }\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._zoom.complete();\n    this._markerConfig.complete();\n    this._formControlObs.complete();\n    this._sub.destroy();\n    this._geoSub.destroy();\n    this._centerSub.destroy();\n    this._flyToCenterSub.destroy();\n    this._clickSub.destroy();\n  }\n\n  flyToMarker() {\n    this.dbxMapboxMapStore.easeTo(\n      this.nonZeroLatLng$.pipe(\n        first(),\n        map((x) => ({ center: x } as MapboxEaseTo))\n      )\n    );\n  }\n\n  useCurrentLocation() {\n    this._geoSub.subscription = this.geolocation$.pipe(first()).subscribe({\n      next: (position) => {\n        if (position) {\n          const { latitude: lat, longitude: lng } = position.coords;\n          this.setValue({ lat, lng });\n        }\n      },\n      error: () => {\n        this._useCurrentLocationDisabled.next(true);\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    this.formControl.markAsTouched();\n    this.formControl.markAsDirty();\n  }\n}\n"]}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
+
import { shareReplay, map, combineLatest } from 'rxjs';
|
|
3
|
+
import { DbxFormMapboxLatLngFieldComponent } from './latlng.field.component';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "./latlng.field.component";
|
|
6
|
+
import * as i2 from "@dereekb/dbx-web/mapbox";
|
|
7
|
+
import * as i3 from "@angular/common";
|
|
8
|
+
export class DbxFormMapboxLatLngFieldMarkerComponent {
|
|
9
|
+
constructor(fieldComponent) {
|
|
10
|
+
this.fieldComponent = fieldComponent;
|
|
11
|
+
this.marker$ = combineLatest([this.fieldComponent.latLng$, this.fieldComponent.markerConfig$]).pipe(map(([latLng, markerConfig]) => {
|
|
12
|
+
if (markerConfig !== false) {
|
|
13
|
+
return { latLng, ...markerConfig };
|
|
14
|
+
}
|
|
15
|
+
else {
|
|
16
|
+
return undefined;
|
|
17
|
+
}
|
|
18
|
+
}), shareReplay(1));
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
DbxFormMapboxLatLngFieldMarkerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxFormMapboxLatLngFieldMarkerComponent, deps: [{ token: i1.DbxFormMapboxLatLngFieldComponent }], target: i0.ɵɵFactoryTarget.Component });
|
|
22
|
+
DbxFormMapboxLatLngFieldMarkerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxFormMapboxLatLngFieldMarkerComponent, selector: "ng-component", ngImport: i0, template: `
|
|
23
|
+
<dbx-mapbox-marker [marker]="marker$ | async"></dbx-mapbox-marker>
|
|
24
|
+
`, isInline: true, dependencies: [{ kind: "component", type: i2.DbxMapboxMarkerComponent, selector: "dbx-mapbox-marker", inputs: ["marker"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
25
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxFormMapboxLatLngFieldMarkerComponent, decorators: [{
|
|
26
|
+
type: Component,
|
|
27
|
+
args: [{
|
|
28
|
+
template: `
|
|
29
|
+
<dbx-mapbox-marker [marker]="marker$ | async"></dbx-mapbox-marker>
|
|
30
|
+
`,
|
|
31
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
32
|
+
}]
|
|
33
|
+
}], ctorParameters: function () { return [{ type: i1.DbxFormMapboxLatLngFieldComponent }]; } });
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF0bG5nLmZpZWxkLm1hcmtlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtZm9ybS9tYXBib3gvc3JjL2xpYi9maWVsZC9sYXRsbmcvbGF0bG5nLmZpZWxkLm1hcmtlci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRSxPQUFPLEVBQUUsV0FBVyxFQUFFLEdBQUcsRUFBYyxhQUFhLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFFbkUsT0FBTyxFQUFFLGlDQUFpQyxFQUFFLE1BQU0sMEJBQTBCLENBQUM7Ozs7O0FBUzdFLE1BQU0sT0FBTyx1Q0FBdUM7SUFZbEQsWUFBcUIsY0FBaUQ7UUFBakQsbUJBQWMsR0FBZCxjQUFjLENBQW1DO1FBWDdELFlBQU8sR0FBdUMsYUFBYSxDQUFDLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLGNBQWMsQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FDekksR0FBRyxDQUFDLENBQUMsQ0FBQyxNQUFNLEVBQUUsWUFBWSxDQUFDLEVBQUUsRUFBRTtZQUM3QixJQUFJLFlBQVksS0FBSyxLQUFLLEVBQUU7Z0JBQzFCLE9BQU8sRUFBRSxNQUFNLEVBQUUsR0FBRyxZQUFZLEVBQUUsQ0FBQzthQUNwQztpQkFBTTtnQkFDTCxPQUFPLFNBQVMsQ0FBQzthQUNsQjtRQUNILENBQUMsQ0FBQyxFQUNGLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FDZixDQUFDO0lBRXVFLENBQUM7O3FJQVovRCx1Q0FBdUM7eUhBQXZDLHVDQUF1QyxvREFMeEM7O0dBRVQ7NEZBR1UsdUNBQXVDO2tCQU5uRCxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRTs7R0FFVDtvQkFDRCxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDaEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBzaGFyZVJlcGxheSwgbWFwLCBPYnNlcnZhYmxlLCBjb21iaW5lTGF0ZXN0IH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBEYnhNYXBib3hNYXJrZXIgfSBmcm9tICdAZGVyZWVrYi9kYngtd2ViL21hcGJveCc7XG5pbXBvcnQgeyBEYnhGb3JtTWFwYm94TGF0TG5nRmllbGRDb21wb25lbnQgfSBmcm9tICcuL2xhdGxuZy5maWVsZC5jb21wb25lbnQnO1xuaW1wb3J0IHsgTWF5YmUgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcblxuQENvbXBvbmVudCh7XG4gIHRlbXBsYXRlOiBgXG4gICAgPGRieC1tYXBib3gtbWFya2VyIFttYXJrZXJdPVwibWFya2VyJCB8IGFzeW5jXCI+PC9kYngtbWFwYm94LW1hcmtlcj5cbiAgYCxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgRGJ4Rm9ybU1hcGJveExhdExuZ0ZpZWxkTWFya2VyQ29tcG9uZW50IHtcbiAgcmVhZG9ubHkgbWFya2VyJDogT2JzZXJ2YWJsZTxNYXliZTxEYnhNYXBib3hNYXJrZXI+PiA9IGNvbWJpbmVMYXRlc3QoW3RoaXMuZmllbGRDb21wb25lbnQubGF0TG5nJCwgdGhpcy5maWVsZENvbXBvbmVudC5tYXJrZXJDb25maWckXSkucGlwZShcbiAgICBtYXAoKFtsYXRMbmcsIG1hcmtlckNvbmZpZ10pID0+IHtcbiAgICAgIGlmIChtYXJrZXJDb25maWcgIT09IGZhbHNlKSB7XG4gICAgICAgIHJldHVybiB7IGxhdExuZywgLi4ubWFya2VyQ29uZmlnIH07XG4gICAgICB9IGVsc2Uge1xuICAgICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgICAgfVxuICAgIH0pLFxuICAgIHNoYXJlUmVwbGF5KDEpXG4gICk7XG5cbiAgY29uc3RydWN0b3IocmVhZG9ubHkgZmllbGRDb21wb25lbnQ6IERieEZvcm1NYXBib3hMYXRMbmdGaWVsZENvbXBvbmVudCkge31cbn1cbiJdfQ==
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { DEFAULT_LAT_LNG_TEXT_FIELD_PATTERN_MESSAGE, DEFAULT_LAT_LNG_TEXT_FIELD_PLACEHOLDER, formlyField, propsAndConfigForFieldConfig, 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', latLngConfig, showMap, zoom, recenterTime, selectLocationOnMapClick } = config;
|
|
4
|
+
const { key = 'latLng', latLngConfig, showMap, zoom, recenterTime, showCenterButton, setCenterOnLocationSet, selectLocationOnMapDrag, selectLocationOnMapClick } = config;
|
|
5
5
|
const fieldConfig = {
|
|
6
6
|
...formlyField({
|
|
7
7
|
key,
|
|
@@ -15,7 +15,10 @@ export function mapboxLatLngField(config = {}) {
|
|
|
15
15
|
zoom,
|
|
16
16
|
latLngConfig,
|
|
17
17
|
recenterTime,
|
|
18
|
-
|
|
18
|
+
selectLocationOnMapDrag,
|
|
19
|
+
selectLocationOnMapClick,
|
|
20
|
+
showCenterButton,
|
|
21
|
+
setCenterOnLocationSet
|
|
19
22
|
})
|
|
20
23
|
}),
|
|
21
24
|
...validatorsForFieldConfig({
|
|
@@ -28,4 +31,4 @@ export function mapboxLatLngField(config = {}) {
|
|
|
28
31
|
classGetter: 'dbx-mat-form-field-disable-underline'
|
|
29
32
|
});
|
|
30
33
|
}
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF0bG5nLmZpZWxkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LWZvcm0vbWFwYm94L3NyYy9saWIvZmllbGQvbGF0bG5nL2xhdGxuZy5maWVsZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsMENBQTBDLEVBQUUsc0NBQXNDLEVBQXVDLFdBQVcsRUFBc0IsNEJBQTRCLEVBQUUsWUFBWSxFQUFFLHdCQUF3QixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDblEsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQU1oRCxNQUFNLFVBQVUsaUJBQWlCLENBQUMsU0FBa0MsRUFBRTtJQUNwRSxNQUFNLEVBQUUsR0FBRyxHQUFHLFFBQVEsRUFBRSxZQUFZLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBRSxZQUFZLEVBQUUsZ0JBQWdCLEVBQUUsc0JBQXNCLEVBQUUsdUJBQXVCLEVBQUUsd0JBQXdCLEVBQUUsR0FBRyxNQUFNLENBQUM7SUFDMUssTUFBTSxXQUFXLEdBQXNCO1FBQ3JDLEdBQUcsV0FBVyxDQUFDO1lBQ2IsR0FBRztZQUNILElBQUksRUFBRSxzQkFBc0I7WUFDNUIsR0FBRyw0QkFBNEIsQ0FBQyxNQUFNLEVBQUU7Z0JBQ3RDLEtBQUssRUFBRSxNQUFNLENBQUMsS0FBSyxJQUFJLFVBQVU7Z0JBQ2pDLFdBQVcsRUFBRSxzQ0FBc0M7Z0JBQ25ELE9BQU8sRUFBRSxlQUFlO2dCQUN4QixZQUFZLEVBQUUsS0FBSztnQkFDbkIsT0FBTztnQkFDUCxJQUFJO2dCQUNKLFlBQVk7Z0JBQ1osWUFBWTtnQkFDWix1QkFBdUI7Z0JBQ3ZCLHdCQUF3QjtnQkFDeEIsZ0JBQWdCO2dCQUNoQixzQkFBc0I7YUFDdkIsQ0FBQztTQUNILENBQUM7UUFDRixHQUFHLHdCQUF3QixDQUFDO1lBQzFCLFFBQVEsRUFBRTtnQkFDUixPQUFPLEVBQUUsMENBQTBDO2FBQ3BEO1NBQ0YsQ0FBQztLQUNILENBQUM7SUFFRixPQUFPLFlBQVksQ0FBQyxXQUFXLEVBQUU7UUFDL0IsV0FBVyxFQUFFLHNDQUFzQztLQUNwRCxDQUFDLENBQUM7QUFDTCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgREVGQVVMVF9MQVRfTE5HX1RFWFRfRklFTERfUEFUVEVSTl9NRVNTQUdFLCBERUZBVUxUX0xBVF9MTkdfVEVYVF9GSUVMRF9QTEFDRUhPTERFUiwgRGVzY3JpcHRpb25GaWVsZENvbmZpZywgRmllbGRDb25maWcsIGZvcm1seUZpZWxkLCBMYWJlbGVkRmllbGRDb25maWcsIHByb3BzQW5kQ29uZmlnRm9yRmllbGRDb25maWcsIHN0eWxlV3JhcHBlciwgdmFsaWRhdG9yc0ZvckZpZWxkQ29uZmlnIH0gZnJvbSAnQGRlcmVla2IvZGJ4LWZvcm0nO1xuaW1wb3J0IHsgTEFUX0xOR19QQVRURVJOIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5pbXBvcnQgeyBGb3JtbHlGaWVsZENvbmZpZyB9IGZyb20gJ0BuZ3gtZm9ybWx5L2NvcmUnO1xuaW1wb3J0IHsgRGJ4Rm9ybU1hcGJveExhdExuZ0NvbXBvbmVudEZpZWxkUHJvcHMgfSBmcm9tICcuL2xhdGxuZy5maWVsZC5jb21wb25lbnQnO1xuXG5leHBvcnQgaW50ZXJmYWNlIE1hcGJveExhdExuZ0ZpZWxkQ29uZmlnIGV4dGVuZHMgT21pdDxMYWJlbGVkRmllbGRDb25maWcsICdrZXknPiwgRGVzY3JpcHRpb25GaWVsZENvbmZpZywgUGFydGlhbDxGaWVsZENvbmZpZz4sIFBpY2s8RGJ4Rm9ybU1hcGJveExhdExuZ0NvbXBvbmVudEZpZWxkUHJvcHMsICdzaG93TWFwJyB8ICd6b29tJyB8ICdsYXRMbmdDb25maWcnIHwgJ3JlY2VudGVyVGltZScgfCAnc2V0Q2VudGVyT25Mb2NhdGlvblNldCcgfCAnc2hvd0NlbnRlckJ1dHRvbicgfCAnc2VsZWN0TG9jYXRpb25Pbk1hcERyYWcnIHwgJ3NlbGVjdExvY2F0aW9uT25NYXBDbGljayc+IHt9XG5cbmV4cG9ydCBmdW5jdGlvbiBtYXBib3hMYXRMbmdGaWVsZChjb25maWc6IE1hcGJveExhdExuZ0ZpZWxkQ29uZmlnID0ge30pOiBGb3JtbHlGaWVsZENvbmZpZyB7XG4gIGNvbnN0IHsga2V5ID0gJ2xhdExuZycsIGxhdExuZ0NvbmZpZywgc2hvd01hcCwgem9vbSwgcmVjZW50ZXJUaW1lLCBzaG93Q2VudGVyQnV0dG9uLCBzZXRDZW50ZXJPbkxvY2F0aW9uU2V0LCBzZWxlY3RMb2NhdGlvbk9uTWFwRHJhZywgc2VsZWN0TG9jYXRpb25Pbk1hcENsaWNrIH0gPSBjb25maWc7XG4gIGNvbnN0IGZpZWxkQ29uZmlnOiBGb3JtbHlGaWVsZENvbmZpZyA9IHtcbiAgICAuLi5mb3JtbHlGaWVsZCh7XG4gICAgICBrZXksXG4gICAgICB0eXBlOiAnbWFwYm94LWxhdGxuZy1waWNrZXInLFxuICAgICAgLi4ucHJvcHNBbmRDb25maWdGb3JGaWVsZENvbmZpZyhjb25maWcsIHtcbiAgICAgICAgbGFiZWw6IGNvbmZpZy5sYWJlbCA/PyAnTG9jYXRpb24nLFxuICAgICAgICBwbGFjZWhvbGRlcjogREVGQVVMVF9MQVRfTE5HX1RFWFRfRklFTERfUExBQ0VIT0xERVIsXG4gICAgICAgIHBhdHRlcm46IExBVF9MTkdfUEFUVEVSTixcbiAgICAgICAgYXV0b2NvbXBsZXRlOiBmYWxzZSxcbiAgICAgICAgc2hvd01hcCxcbiAgICAgICAgem9vbSxcbiAgICAgICAgbGF0TG5nQ29uZmlnLFxuICAgICAgICByZWNlbnRlclRpbWUsXG4gICAgICAgIHNlbGVjdExvY2F0aW9uT25NYXBEcmFnLFxuICAgICAgICBzZWxlY3RMb2NhdGlvbk9uTWFwQ2xpY2ssXG4gICAgICAgIHNob3dDZW50ZXJCdXR0b24sXG4gICAgICAgIHNldENlbnRlck9uTG9jYXRpb25TZXRcbiAgICAgIH0pXG4gICAgfSksXG4gICAgLi4udmFsaWRhdG9yc0ZvckZpZWxkQ29uZmlnKHtcbiAgICAgIG1lc3NhZ2VzOiB7XG4gICAgICAgIHBhdHRlcm46IERFRkFVTFRfTEFUX0xOR19URVhUX0ZJRUxEX1BBVFRFUk5fTUVTU0FHRVxuICAgICAgfVxuICAgIH0pXG4gIH07XG5cbiAgcmV0dXJuIHN0eWxlV3JhcHBlcihmaWVsZENvbmZpZywge1xuICAgIGNsYXNzR2V0dGVyOiAnZGJ4LW1hdC1mb3JtLWZpZWxkLWRpc2FibGUtdW5kZXJsaW5lJ1xuICB9KTtcbn1cbiJdfQ==
|
|
@@ -9,19 +9,20 @@ import { NgxMapboxGLModule } from 'ngx-mapbox-gl';
|
|
|
9
9
|
import { MatIconModule } from '@angular/material/icon';
|
|
10
10
|
import { MatButtonModule } from '@angular/material/button';
|
|
11
11
|
import { DbxMapboxModule } from '@dereekb/dbx-web/mapbox';
|
|
12
|
+
import { DbxFormMapboxLatLngFieldMarkerComponent } from './latlng.field.marker.component';
|
|
12
13
|
import * as i0 from "@angular/core";
|
|
13
14
|
import * as i1 from "@ngx-formly/core";
|
|
14
15
|
export class DbxFormMapboxLatLngModule {
|
|
15
16
|
}
|
|
16
17
|
DbxFormMapboxLatLngModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxFormMapboxLatLngModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
17
|
-
DbxFormMapboxLatLngModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.12", ngImport: i0, type: DbxFormMapboxLatLngModule, declarations: [DbxFormMapboxLatLngFieldComponent], imports: [CommonModule,
|
|
18
|
+
DbxFormMapboxLatLngModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.12", ngImport: i0, type: DbxFormMapboxLatLngModule, declarations: [DbxFormMapboxLatLngFieldComponent, DbxFormMapboxLatLngFieldMarkerComponent], imports: [CommonModule,
|
|
18
19
|
MatIconModule,
|
|
19
20
|
MatButtonModule,
|
|
20
21
|
DbxTextModule,
|
|
21
22
|
DbxMapboxModule,
|
|
22
23
|
FormsModule,
|
|
23
24
|
ReactiveFormsModule,
|
|
24
|
-
MatInputModule, i1.FormlyModule, NgxMapboxGLModule] });
|
|
25
|
+
MatInputModule, i1.FormlyModule, NgxMapboxGLModule], exports: [DbxFormMapboxLatLngFieldMarkerComponent] });
|
|
25
26
|
DbxFormMapboxLatLngModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxFormMapboxLatLngModule, imports: [CommonModule,
|
|
26
27
|
MatIconModule,
|
|
27
28
|
MatButtonModule,
|
|
@@ -51,7 +52,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
51
52
|
}),
|
|
52
53
|
NgxMapboxGLModule
|
|
53
54
|
],
|
|
54
|
-
declarations: [DbxFormMapboxLatLngFieldComponent]
|
|
55
|
+
declarations: [DbxFormMapboxLatLngFieldComponent, DbxFormMapboxLatLngFieldMarkerComponent],
|
|
56
|
+
exports: [DbxFormMapboxLatLngFieldMarkerComponent]
|
|
55
57
|
}]
|
|
56
58
|
}] });
|
|
57
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
59
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF0bG5nLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC1mb3JtL21hcGJveC9zcmMvbGliL2ZpZWxkL2xhdGxuZy9sYXRsbmcubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxpQ0FBaUMsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzdFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNoRCxPQUFPLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNqRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbEQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDMUQsT0FBTyxFQUFFLHVDQUF1QyxFQUFFLE1BQU0saUNBQWlDLENBQUM7OztBQW9CMUYsTUFBTSxPQUFPLHlCQUF5Qjs7dUhBQXpCLHlCQUF5Qjt3SEFBekIseUJBQXlCLGlCQUhyQixpQ0FBaUMsRUFBRSx1Q0FBdUMsYUFidkYsWUFBWTtRQUNaLGFBQWE7UUFDYixlQUFlO1FBQ2YsYUFBYTtRQUNiLGVBQWU7UUFDZixXQUFXO1FBQ1gsbUJBQW1CO1FBQ25CLGNBQWMsbUJBSWQsaUJBQWlCLGFBR1QsdUNBQXVDO3dIQUV0Qyx5QkFBeUIsWUFoQmxDLFlBQVk7UUFDWixhQUFhO1FBQ2IsZUFBZTtRQUNmLGFBQWE7UUFDYixlQUFlO1FBQ2YsV0FBVztRQUNYLG1CQUFtQjtRQUNuQixjQUFjO1FBQ2QsWUFBWSxDQUFDLFFBQVEsQ0FBQztZQUNwQixLQUFLLEVBQUUsQ0FBQyxFQUFFLElBQUksRUFBRSxzQkFBc0IsRUFBRSxTQUFTLEVBQUUsaUNBQWlDLEVBQUUsUUFBUSxFQUFFLENBQUMsT0FBTyxFQUFFLFlBQVksQ0FBQyxFQUFFLENBQUM7U0FDM0gsQ0FBQztRQUNGLGlCQUFpQjs0RkFLUix5QkFBeUI7a0JBbEJyQyxRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLGFBQWE7d0JBQ2IsZUFBZTt3QkFDZixhQUFhO3dCQUNiLGVBQWU7d0JBQ2YsV0FBVzt3QkFDWCxtQkFBbUI7d0JBQ25CLGNBQWM7d0JBQ2QsWUFBWSxDQUFDLFFBQVEsQ0FBQzs0QkFDcEIsS0FBSyxFQUFFLENBQUMsRUFBRSxJQUFJLEVBQUUsc0JBQXNCLEVBQUUsU0FBUyxFQUFFLGlDQUFpQyxFQUFFLFFBQVEsRUFBRSxDQUFDLE9BQU8sRUFBRSxZQUFZLENBQUMsRUFBRSxDQUFDO3lCQUMzSCxDQUFDO3dCQUNGLGlCQUFpQjtxQkFDbEI7b0JBQ0QsWUFBWSxFQUFFLENBQUMsaUNBQWlDLEVBQUUsdUNBQXVDLENBQUM7b0JBQzFGLE9BQU8sRUFBRSxDQUFDLHVDQUF1QyxDQUFDO2lCQUNuRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgRGJ4Rm9ybU1hcGJveExhdExuZ0ZpZWxkQ29tcG9uZW50IH0gZnJvbSAnLi9sYXRsbmcuZmllbGQuY29tcG9uZW50JztcbmltcG9ydCB7IEZvcm1seU1vZHVsZSB9IGZyb20gJ0BuZ3gtZm9ybWx5L2NvcmUnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBNYXRJbnB1dE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2lucHV0JztcbmltcG9ydCB7IERieFRleHRNb2R1bGUgfSBmcm9tICdAZGVyZWVrYi9kYngtd2ViJztcbmltcG9ydCB7IE5neE1hcGJveEdMTW9kdWxlIH0gZnJvbSAnbmd4LW1hcGJveC1nbCc7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgRGJ4TWFwYm94TW9kdWxlIH0gZnJvbSAnQGRlcmVla2IvZGJ4LXdlYi9tYXBib3gnO1xuaW1wb3J0IHsgRGJ4Rm9ybU1hcGJveExhdExuZ0ZpZWxkTWFya2VyQ29tcG9uZW50IH0gZnJvbSAnLi9sYXRsbmcuZmllbGQubWFya2VyLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgTWF0SWNvbk1vZHVsZSxcbiAgICBNYXRCdXR0b25Nb2R1bGUsXG4gICAgRGJ4VGV4dE1vZHVsZSxcbiAgICBEYnhNYXBib3hNb2R1bGUsXG4gICAgRm9ybXNNb2R1bGUsXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcbiAgICBNYXRJbnB1dE1vZHVsZSxcbiAgICBGb3JtbHlNb2R1bGUuZm9yQ2hpbGQoe1xuICAgICAgdHlwZXM6IFt7IG5hbWU6ICdtYXBib3gtbGF0bG5nLXBpY2tlcicsIGNvbXBvbmVudDogRGJ4Rm9ybU1hcGJveExhdExuZ0ZpZWxkQ29tcG9uZW50LCB3cmFwcGVyczogWydzdHlsZScsICdmb3JtLWZpZWxkJ10gfV1cbiAgICB9KSxcbiAgICBOZ3hNYXBib3hHTE1vZHVsZVxuICBdLFxuICBkZWNsYXJhdGlvbnM6IFtEYnhGb3JtTWFwYm94TGF0TG5nRmllbGRDb21wb25lbnQsIERieEZvcm1NYXBib3hMYXRMbmdGaWVsZE1hcmtlckNvbXBvbmVudF0sXG4gIGV4cG9ydHM6IFtEYnhGb3JtTWFwYm94TGF0TG5nRmllbGRNYXJrZXJDb21wb25lbnRdXG59KVxuZXhwb3J0IGNsYXNzIERieEZvcm1NYXBib3hMYXRMbmdNb2R1bGUge31cbiJdfQ==
|