@guajiritos/map 0.0.10 → 0.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +159 -159
- package/esm2022/interfaces/interfaces.mjs +14 -0
- package/esm2022/lib/guajiritos-map.component.mjs +293 -0
- package/esm2022/public-api.mjs +3 -2
- package/fesm2022/guajiritos-map.mjs +155 -144
- package/fesm2022/guajiritos-map.mjs.map +1 -1
- package/interfaces/interfaces.d.ts +45 -0
- package/lib/guajiritos-map.component.d.ts +115 -0
- package/package.json +2 -2
- package/public-api.d.ts +2 -1
- package/esm2022/lib/map.component.mjs +0 -295
- package/lib/map.component.d.ts +0 -142
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
import { AfterViewInit, EventEmitter, OnInit, WritableSignal } from '@angular/core';
|
|
2
|
+
import * as L from 'leaflet';
|
|
3
|
+
import { LatLng } from 'leaflet';
|
|
4
|
+
import { ControlValueAccessor, UntypedFormGroup } from '@angular/forms';
|
|
5
|
+
import { FloatLabelType, MatFormFieldAppearance, SubscriptSizing } from '@angular/material/form-field';
|
|
6
|
+
import { ThemePalette } from '@angular/material/core';
|
|
7
|
+
import { CircleMap, Icon, MapOption, MarkerMap } from '../interfaces/interfaces';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
export declare class GuajiritosMap implements OnInit, AfterViewInit, ControlValueAccessor {
|
|
10
|
+
private static _observableSubject$;
|
|
11
|
+
private map;
|
|
12
|
+
private _layerGroup;
|
|
13
|
+
mapMarkers: WritableSignal<MarkerMap[]>;
|
|
14
|
+
options: WritableSignal<MapOption>;
|
|
15
|
+
circle: WritableSignal<CircleMap>;
|
|
16
|
+
form: UntypedFormGroup;
|
|
17
|
+
appearance: MatFormFieldAppearance;
|
|
18
|
+
color: ThemePalette;
|
|
19
|
+
floatLabel: FloatLabelType;
|
|
20
|
+
subscriptSizing: SubscriptSizing;
|
|
21
|
+
readonly: boolean;
|
|
22
|
+
hiddenForm: boolean;
|
|
23
|
+
/**
|
|
24
|
+
* Default map options
|
|
25
|
+
*/
|
|
26
|
+
set optionsMap(options: Partial<MapOption>);
|
|
27
|
+
/**
|
|
28
|
+
* Add a circle on the map
|
|
29
|
+
*/
|
|
30
|
+
set circleConfig(circle: CircleMap);
|
|
31
|
+
/**
|
|
32
|
+
* Default marker icon
|
|
33
|
+
*/
|
|
34
|
+
icon: Icon;
|
|
35
|
+
/**
|
|
36
|
+
* List of markers
|
|
37
|
+
* @param markers - Markers array
|
|
38
|
+
*/
|
|
39
|
+
set markers(markers: MarkerMap[]);
|
|
40
|
+
/**
|
|
41
|
+
* Se lanza cada vez que cambia un marcador
|
|
42
|
+
*/
|
|
43
|
+
markerDragend: EventEmitter<LatLng>;
|
|
44
|
+
/**
|
|
45
|
+
* Se lanza cada vez que se añade un marcador
|
|
46
|
+
*/
|
|
47
|
+
markerAdded: EventEmitter<MarkerMap>;
|
|
48
|
+
/**
|
|
49
|
+
* Draws the markers.
|
|
50
|
+
*/
|
|
51
|
+
private drawMarkers;
|
|
52
|
+
/**
|
|
53
|
+
* Main properties of the map
|
|
54
|
+
* @private
|
|
55
|
+
*/
|
|
56
|
+
private initMap;
|
|
57
|
+
/**
|
|
58
|
+
* Add marker to map
|
|
59
|
+
* @param center - center of the circle
|
|
60
|
+
* @param radius - radius of the circle in meters
|
|
61
|
+
* @private
|
|
62
|
+
*/
|
|
63
|
+
private addCircle;
|
|
64
|
+
/**
|
|
65
|
+
* Add marker to map
|
|
66
|
+
* @param marker - Point of the map
|
|
67
|
+
*/
|
|
68
|
+
private addMarker;
|
|
69
|
+
/**
|
|
70
|
+
* Put the map center on marker position
|
|
71
|
+
* @param marker - Point of the map
|
|
72
|
+
* @public
|
|
73
|
+
*/
|
|
74
|
+
changeCenter(marker: L.LatLng): void;
|
|
75
|
+
/**
|
|
76
|
+
* Propagates the change to other components.
|
|
77
|
+
*
|
|
78
|
+
* @param {any} _ - an arbitrary parameter.
|
|
79
|
+
*/
|
|
80
|
+
propagateChange(_: any): void;
|
|
81
|
+
/**
|
|
82
|
+
* Sets the callback function to be called when the value
|
|
83
|
+
* of the control changes.
|
|
84
|
+
*
|
|
85
|
+
* @param {any} fn - The callback function to be called
|
|
86
|
+
* when the value of the control changes.
|
|
87
|
+
*/
|
|
88
|
+
registerOnChange(fn: any): void;
|
|
89
|
+
/**
|
|
90
|
+
* Registers a callback function to be called when the form control is "touched".
|
|
91
|
+
*/
|
|
92
|
+
registerOnTouched(): void;
|
|
93
|
+
/**
|
|
94
|
+
* Sets the disabled state of the form.
|
|
95
|
+
*
|
|
96
|
+
* @param {boolean} isDisabled - Specifies whether the form should be disabled or not.
|
|
97
|
+
*/
|
|
98
|
+
setDisabledState(isDisabled: boolean): void;
|
|
99
|
+
/**
|
|
100
|
+
* Writes a value to the form.
|
|
101
|
+
*
|
|
102
|
+
* @param {any} data - The data to be written.
|
|
103
|
+
*/
|
|
104
|
+
writeValue(data: any): void;
|
|
105
|
+
/**
|
|
106
|
+
* Initializes the component and sets up a listener for changes in the form value.
|
|
107
|
+
*/
|
|
108
|
+
ngOnInit(): void;
|
|
109
|
+
/**
|
|
110
|
+
* Initializes the map after the view has been initialized.
|
|
111
|
+
*/
|
|
112
|
+
ngAfterViewInit(): void;
|
|
113
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<GuajiritosMap, never>;
|
|
114
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<GuajiritosMap, "guajiritos-map", never, { "appearance": { "alias": "appearance"; "required": false; }; "color": { "alias": "color"; "required": false; }; "floatLabel": { "alias": "floatLabel"; "required": false; }; "subscriptSizing": { "alias": "subscriptSizing"; "required": false; }; "readonly": { "alias": "readonly"; "required": false; }; "hiddenForm": { "alias": "hiddenForm"; "required": false; }; "optionsMap": { "alias": "optionsMap"; "required": false; }; "circleConfig": { "alias": "circleConfig"; "required": false; }; "icon": { "alias": "icon"; "required": false; }; "markers": { "alias": "markers"; "required": false; }; }, { "markerDragend": "markerDragend"; "markerAdded": "markerAdded"; }, never, never, true, never>;
|
|
115
|
+
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@guajiritos/map",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.1.1",
|
|
4
4
|
"peerDependencies": {
|
|
5
5
|
"@angular/cdk": "^16.0.0 || >16.0.0",
|
|
6
6
|
"@angular/common": "^16.0.0 || >16.0.0",
|
|
@@ -25,4 +25,4 @@
|
|
|
25
25
|
"default": "./fesm2022/guajiritos-map.mjs"
|
|
26
26
|
}
|
|
27
27
|
}
|
|
28
|
-
}
|
|
28
|
+
}
|
package/public-api.d.ts
CHANGED
|
@@ -1 +1,2 @@
|
|
|
1
|
-
export * from './
|
|
1
|
+
export * from './interfaces/interfaces';
|
|
2
|
+
export * from './lib/guajiritos-map.component';
|
|
@@ -1,295 +0,0 @@
|
|
|
1
|
-
import { Component, EventEmitter, forwardRef, Input, Output } from "@angular/core";
|
|
2
|
-
import { NgIf } from "@angular/common";
|
|
3
|
-
import * as L from "leaflet";
|
|
4
|
-
import { icon, LatLng, layerGroup, Marker } from "leaflet";
|
|
5
|
-
import { MatInputModule } from "@angular/material/input";
|
|
6
|
-
import { NG_VALUE_ACCESSOR, ReactiveFormsModule, UntypedFormControl, UntypedFormGroup, Validators } from "@angular/forms";
|
|
7
|
-
import { Subject, takeUntil } from "rxjs";
|
|
8
|
-
import { MatIconModule } from "@angular/material/icon";
|
|
9
|
-
import * as i0 from "@angular/core";
|
|
10
|
-
import * as i1 from "@angular/material/input";
|
|
11
|
-
import * as i2 from "@angular/material/form-field";
|
|
12
|
-
import * as i3 from "@angular/forms";
|
|
13
|
-
import * as i4 from "@angular/material/icon";
|
|
14
|
-
export const DEFAULT_MAP_OPTION = {
|
|
15
|
-
center: [23.130257185291036, -82.35626220703126],
|
|
16
|
-
draggable: true,
|
|
17
|
-
zoom: 8,
|
|
18
|
-
updateWithClick: false,
|
|
19
|
-
updateWithDoubleClick: false,
|
|
20
|
-
zoomControl: false,
|
|
21
|
-
borderRadius: '8px',
|
|
22
|
-
scrollWheelZoom: false
|
|
23
|
-
};
|
|
24
|
-
export class GuajiritosMap {
|
|
25
|
-
constructor() {
|
|
26
|
-
this._map = null;
|
|
27
|
-
this._layerGroup = new L.LayerGroup();
|
|
28
|
-
this._markersList = [];
|
|
29
|
-
this.form = new UntypedFormGroup({
|
|
30
|
-
latitude: new UntypedFormControl({ value: null, disabled: false }, [Validators.required]),
|
|
31
|
-
longitude: new UntypedFormControl({ value: null, disabled: false }, [Validators.required])
|
|
32
|
-
});
|
|
33
|
-
this.latLabel = '';
|
|
34
|
-
this.latPlaceholder = '';
|
|
35
|
-
this.lngLabel = '';
|
|
36
|
-
this.lngPlaceholder = '';
|
|
37
|
-
this.latError = '';
|
|
38
|
-
this.lngError = '';
|
|
39
|
-
this.appearance = 'outline';
|
|
40
|
-
this.color = 'accent';
|
|
41
|
-
this.readonly = false;
|
|
42
|
-
this.hidden = false;
|
|
43
|
-
/**
|
|
44
|
-
* Default map options
|
|
45
|
-
*/
|
|
46
|
-
this.options = {};
|
|
47
|
-
/**
|
|
48
|
-
* Default marker icon
|
|
49
|
-
*/
|
|
50
|
-
this.icon = {
|
|
51
|
-
iconSize: [25, 41],
|
|
52
|
-
iconAnchor: [13, 41],
|
|
53
|
-
iconUrl: 'marker-icon.png'
|
|
54
|
-
};
|
|
55
|
-
/**
|
|
56
|
-
* Se lanza cada vez que cambia un marcador
|
|
57
|
-
*/
|
|
58
|
-
this.markerDragend = new EventEmitter();
|
|
59
|
-
}
|
|
60
|
-
static { this._observableSubject$ = new Subject(); }
|
|
61
|
-
/**
|
|
62
|
-
* List of markers
|
|
63
|
-
* @param markers - Markers array
|
|
64
|
-
*/
|
|
65
|
-
set markers(markers) {
|
|
66
|
-
if (markers && markers.length > 0) {
|
|
67
|
-
this._markersList = markers;
|
|
68
|
-
setTimeout(() => {
|
|
69
|
-
this._layerGroup?.clearLayers();
|
|
70
|
-
markers.forEach((m) => {
|
|
71
|
-
this._addMarker(m);
|
|
72
|
-
});
|
|
73
|
-
this.changeCenter(this._createMarker(markers[0]));
|
|
74
|
-
}, 100);
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
/**
|
|
78
|
-
* Form initialization
|
|
79
|
-
* @param data - Initial data
|
|
80
|
-
*/
|
|
81
|
-
_initForm(data) {
|
|
82
|
-
this.form.patchValue({
|
|
83
|
-
latitude: data?.latitude,
|
|
84
|
-
longitude: data?.longitude,
|
|
85
|
-
});
|
|
86
|
-
}
|
|
87
|
-
/**
|
|
88
|
-
* Main properties of the map
|
|
89
|
-
* @private
|
|
90
|
-
*/
|
|
91
|
-
_initMap() {
|
|
92
|
-
this._map = L.map('map', {
|
|
93
|
-
center: this.options?.center ?? DEFAULT_MAP_OPTION.center,
|
|
94
|
-
dragging: this.options?.draggable ?? DEFAULT_MAP_OPTION.draggable,
|
|
95
|
-
zoom: this.options?.zoom ?? DEFAULT_MAP_OPTION.zoom,
|
|
96
|
-
zoomControl: this.options?.zoomControl || DEFAULT_MAP_OPTION.zoomControl,
|
|
97
|
-
scrollWheelZoom: this.options?.scrollWheelZoom || DEFAULT_MAP_OPTION.scrollWheelZoom,
|
|
98
|
-
maxZoom: 18,
|
|
99
|
-
minZoom: 3,
|
|
100
|
-
});
|
|
101
|
-
this._layerGroup = layerGroup().addTo(this._map);
|
|
102
|
-
L.tileLayer('http://{s}.tile.openstreetmap.fr/hot/{z}/{x}/{y}.png').addTo(this._map);
|
|
103
|
-
}
|
|
104
|
-
/**
|
|
105
|
-
* Add marker to map
|
|
106
|
-
* @param center - center of the circle
|
|
107
|
-
* @param radius - radius of the circle in meters
|
|
108
|
-
* @private
|
|
109
|
-
*/
|
|
110
|
-
_addCircle(center, radius) {
|
|
111
|
-
if (this._map && center) {
|
|
112
|
-
L.circleMarker([center?.lat, center?.lng], { radius }).addTo(this._map);
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
/**
|
|
116
|
-
* Add marker to map
|
|
117
|
-
* @param marker - Point of the map
|
|
118
|
-
*/
|
|
119
|
-
_addMarker(marker) {
|
|
120
|
-
if (this._map && marker) {
|
|
121
|
-
const markerAdd = L.marker({
|
|
122
|
-
lat: marker?.lat,
|
|
123
|
-
lng: marker?.lng
|
|
124
|
-
}, {
|
|
125
|
-
draggable: marker?.draggable ?? true,
|
|
126
|
-
autoPan: true
|
|
127
|
-
}).setIcon(icon({
|
|
128
|
-
iconSize: this.icon?.iconSize,
|
|
129
|
-
iconAnchor: this.icon?.iconAnchor,
|
|
130
|
-
iconUrl: this.icon?.iconUrl
|
|
131
|
-
})).addTo(this._layerGroup);
|
|
132
|
-
markerAdd.on('dragend', () => {
|
|
133
|
-
this.changeCenter(markerAdd);
|
|
134
|
-
this.markerDragend.emit(markerAdd.getLatLng());
|
|
135
|
-
});
|
|
136
|
-
}
|
|
137
|
-
}
|
|
138
|
-
/**
|
|
139
|
-
* Add a marker on the map
|
|
140
|
-
* @param marker - Point of the map
|
|
141
|
-
* @private
|
|
142
|
-
*/
|
|
143
|
-
_createMarker(marker) {
|
|
144
|
-
const markerCreate = new Marker(new LatLng(marker?.lat, marker?.lng), {
|
|
145
|
-
draggable: marker?.draggable ?? true,
|
|
146
|
-
autoPan: true
|
|
147
|
-
}).setIcon(icon({
|
|
148
|
-
iconSize: this.icon?.iconSize,
|
|
149
|
-
iconAnchor: this.icon?.iconAnchor,
|
|
150
|
-
iconUrl: this.icon?.iconUrl
|
|
151
|
-
}));
|
|
152
|
-
markerCreate.on('dragend', () => {
|
|
153
|
-
this.changeCenter(markerCreate);
|
|
154
|
-
this.markerDragend.emit(markerCreate.getLatLng());
|
|
155
|
-
});
|
|
156
|
-
return markerCreate;
|
|
157
|
-
}
|
|
158
|
-
/**
|
|
159
|
-
* Get latitude and longitude values if maker map is only one
|
|
160
|
-
* @private
|
|
161
|
-
*/
|
|
162
|
-
_getLatLng() {
|
|
163
|
-
if (this._markersList?.length === 1) {
|
|
164
|
-
this.form.patchValue({
|
|
165
|
-
latitude: this._markersList?.[0]?.lat,
|
|
166
|
-
longitude: this._markersList?.[0]?.lng
|
|
167
|
-
});
|
|
168
|
-
}
|
|
169
|
-
}
|
|
170
|
-
_latLngChangeCenter(marker) {
|
|
171
|
-
this._map?.setView({
|
|
172
|
-
lat: marker?.latitude,
|
|
173
|
-
lng: marker?.longitude
|
|
174
|
-
});
|
|
175
|
-
this._markersList[0].lat = parseFloat(marker?.latitude);
|
|
176
|
-
this._markersList[0].lng = parseFloat(marker?.longitude);
|
|
177
|
-
this._layerGroup?.clearLayers();
|
|
178
|
-
const markerAdd = L.marker({
|
|
179
|
-
lat: this._markersList?.[0]?.lat,
|
|
180
|
-
lng: this._markersList?.[0]?.lng,
|
|
181
|
-
}, {
|
|
182
|
-
draggable: marker?.draggable ?? true,
|
|
183
|
-
autoPan: true
|
|
184
|
-
}).addTo(this._layerGroup);
|
|
185
|
-
markerAdd.on('dragend', () => {
|
|
186
|
-
this.changeCenter(markerAdd);
|
|
187
|
-
this.markerDragend.emit(markerAdd.getLatLng());
|
|
188
|
-
});
|
|
189
|
-
}
|
|
190
|
-
/**
|
|
191
|
-
* Make visible/hide latitude and longitude inputs
|
|
192
|
-
* @public
|
|
193
|
-
*/
|
|
194
|
-
hideLatLng() {
|
|
195
|
-
return this._markersList?.length === 1;
|
|
196
|
-
}
|
|
197
|
-
/**
|
|
198
|
-
* Put the map center on marker position
|
|
199
|
-
* @param marker - Point of the map
|
|
200
|
-
* @public
|
|
201
|
-
*/
|
|
202
|
-
changeCenter(marker) {
|
|
203
|
-
this._map?.setView(marker?.getLatLng());
|
|
204
|
-
}
|
|
205
|
-
propagateChange(_) {
|
|
206
|
-
}
|
|
207
|
-
;
|
|
208
|
-
registerOnChange(fn) {
|
|
209
|
-
this.propagateChange = fn;
|
|
210
|
-
}
|
|
211
|
-
registerOnTouched() {
|
|
212
|
-
}
|
|
213
|
-
setDisabledState(isDisabled) {
|
|
214
|
-
if (isDisabled) {
|
|
215
|
-
this.form.disable();
|
|
216
|
-
}
|
|
217
|
-
else {
|
|
218
|
-
this.form.enable();
|
|
219
|
-
}
|
|
220
|
-
}
|
|
221
|
-
writeValue(form) {
|
|
222
|
-
if (form) {
|
|
223
|
-
this._initForm(form);
|
|
224
|
-
}
|
|
225
|
-
}
|
|
226
|
-
ngOnInit() {
|
|
227
|
-
this._getLatLng();
|
|
228
|
-
this.form.valueChanges
|
|
229
|
-
.pipe(takeUntil(GuajiritosMap._observableSubject$.asObservable()))
|
|
230
|
-
.subscribe(() => {
|
|
231
|
-
this.propagateChange(this.form.value);
|
|
232
|
-
this._latLngChangeCenter(this.form.value);
|
|
233
|
-
});
|
|
234
|
-
}
|
|
235
|
-
ngAfterViewInit() {
|
|
236
|
-
this._initMap();
|
|
237
|
-
if (this.circle) {
|
|
238
|
-
this._addCircle(this.circle?.center, this.circle?.radius);
|
|
239
|
-
}
|
|
240
|
-
}
|
|
241
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.8", ngImport: i0, type: GuajiritosMap, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
242
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.8", type: GuajiritosMap, isStandalone: true, selector: "guajiritos-map", inputs: { latLabel: "latLabel", latPlaceholder: "latPlaceholder", lngLabel: "lngLabel", lngPlaceholder: "lngPlaceholder", latError: "latError", lngError: "lngError", appearance: "appearance", color: "color", readonly: "readonly", hidden: "hidden", options: "options", circle: "circle", icon: "icon", markers: "markers" }, outputs: { markerDragend: "markerDragend" }, providers: [
|
|
243
|
-
{
|
|
244
|
-
provide: NG_VALUE_ACCESSOR,
|
|
245
|
-
useExisting: forwardRef(() => GuajiritosMap),
|
|
246
|
-
multi: true
|
|
247
|
-
}
|
|
248
|
-
], ngImport: i0, template: "<div class=\"map-container\">\n <div class=\"latLngInput\" [formGroup]=\"form\" *ngIf=\"hideLatLng() && !hidden\">\n <mat-form-field [appearance]=\"appearance\" [color]=\"color\" class='w-100'>\n <mat-label>{{latLabel}}</mat-label>\n <mat-icon matSuffix class=\"material-icons-outlined\" [color]=\"color\">place</mat-icon>\n <input matInput [placeholder]=\"latPlaceholder\" [readonly]=\"readonly\" formControlName=\"latitude\">\n <mat-error *ngIf=\"form.controls['latitude'].hasError('required')\">{{latError}}</mat-error>\n </mat-form-field>\n \n <mat-form-field [appearance]=\"appearance\" [color]=\"color\" class='w-100'>\n <mat-label>{{lngLabel}}</mat-label>\n <mat-icon matSuffix class=\"material-icons-outlined\" [color]=\"color\">place</mat-icon>\n <input matInput [placeholder]=\"lngPlaceholder\" [readonly]=\"readonly\" formControlName=\"longitude\">\n <mat-error *ngIf=\"form.controls['longitude'].hasError('required')\">{{lngError}}</mat-error>\n </mat-form-field>\n </div>\n \n <div id=\"map\" class=\"map\"></div>\n</div>\n", styles: [".map-container{display:flex;flex-direction:column;gap:2rem}.latLngInput{display:flex;flex-direction:row;gap:1rem}.map{min-height:400px;max-width:100%}\n"], dependencies: [{ kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i1.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: i2.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatLabel, selector: "mat-label" }, { kind: "directive", type: i2.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i2.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i3.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: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }] }); }
|
|
249
|
-
}
|
|
250
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.8", ngImport: i0, type: GuajiritosMap, decorators: [{
|
|
251
|
-
type: Component,
|
|
252
|
-
args: [{ selector: 'guajiritos-map', standalone: true, imports: [
|
|
253
|
-
MatInputModule,
|
|
254
|
-
ReactiveFormsModule,
|
|
255
|
-
NgIf,
|
|
256
|
-
MatIconModule
|
|
257
|
-
], providers: [
|
|
258
|
-
{
|
|
259
|
-
provide: NG_VALUE_ACCESSOR,
|
|
260
|
-
useExisting: forwardRef(() => GuajiritosMap),
|
|
261
|
-
multi: true
|
|
262
|
-
}
|
|
263
|
-
], template: "<div class=\"map-container\">\n <div class=\"latLngInput\" [formGroup]=\"form\" *ngIf=\"hideLatLng() && !hidden\">\n <mat-form-field [appearance]=\"appearance\" [color]=\"color\" class='w-100'>\n <mat-label>{{latLabel}}</mat-label>\n <mat-icon matSuffix class=\"material-icons-outlined\" [color]=\"color\">place</mat-icon>\n <input matInput [placeholder]=\"latPlaceholder\" [readonly]=\"readonly\" formControlName=\"latitude\">\n <mat-error *ngIf=\"form.controls['latitude'].hasError('required')\">{{latError}}</mat-error>\n </mat-form-field>\n \n <mat-form-field [appearance]=\"appearance\" [color]=\"color\" class='w-100'>\n <mat-label>{{lngLabel}}</mat-label>\n <mat-icon matSuffix class=\"material-icons-outlined\" [color]=\"color\">place</mat-icon>\n <input matInput [placeholder]=\"lngPlaceholder\" [readonly]=\"readonly\" formControlName=\"longitude\">\n <mat-error *ngIf=\"form.controls['longitude'].hasError('required')\">{{lngError}}</mat-error>\n </mat-form-field>\n </div>\n \n <div id=\"map\" class=\"map\"></div>\n</div>\n", styles: [".map-container{display:flex;flex-direction:column;gap:2rem}.latLngInput{display:flex;flex-direction:row;gap:1rem}.map{min-height:400px;max-width:100%}\n"] }]
|
|
264
|
-
}], ctorParameters: function () { return []; }, propDecorators: { latLabel: [{
|
|
265
|
-
type: Input
|
|
266
|
-
}], latPlaceholder: [{
|
|
267
|
-
type: Input
|
|
268
|
-
}], lngLabel: [{
|
|
269
|
-
type: Input
|
|
270
|
-
}], lngPlaceholder: [{
|
|
271
|
-
type: Input
|
|
272
|
-
}], latError: [{
|
|
273
|
-
type: Input
|
|
274
|
-
}], lngError: [{
|
|
275
|
-
type: Input
|
|
276
|
-
}], appearance: [{
|
|
277
|
-
type: Input
|
|
278
|
-
}], color: [{
|
|
279
|
-
type: Input
|
|
280
|
-
}], readonly: [{
|
|
281
|
-
type: Input
|
|
282
|
-
}], hidden: [{
|
|
283
|
-
type: Input
|
|
284
|
-
}], options: [{
|
|
285
|
-
type: Input
|
|
286
|
-
}], circle: [{
|
|
287
|
-
type: Input
|
|
288
|
-
}], icon: [{
|
|
289
|
-
type: Input
|
|
290
|
-
}], markers: [{
|
|
291
|
-
type: Input
|
|
292
|
-
}], markerDragend: [{
|
|
293
|
-
type: Output
|
|
294
|
-
}] } });
|
|
295
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2d1YWppcml0b3MtbWFwL3NyYy9saWIvbWFwLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uL3Byb2plY3RzL2d1YWppcml0b3MtbWFwL3NyYy9saWIvbWFwLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBZ0IsU0FBUyxFQUFFLFlBQVksRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN4RyxPQUFPLEVBQUMsSUFBSSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDckMsT0FBTyxLQUFLLENBQUMsTUFBTSxTQUFTLENBQUM7QUFDN0IsT0FBTyxFQUFDLElBQUksRUFBRSxNQUFNLEVBQW9CLFVBQVUsRUFBbUIsTUFBTSxFQUFDLE1BQU0sU0FBUyxDQUFDO0FBQzVGLE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUN2RCxPQUFPLEVBRUwsaUJBQWlCLEVBQ2pCLG1CQUFtQixFQUNuQixrQkFBa0IsRUFDbEIsZ0JBQWdCLEVBQUUsVUFBVSxFQUM3QixNQUFNLGdCQUFnQixDQUFDO0FBR3hCLE9BQU8sRUFBQyxPQUFPLEVBQUUsU0FBUyxFQUFDLE1BQU0sTUFBTSxDQUFDO0FBQ3hDLE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQzs7Ozs7O0FBZ0RyRCxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBYztJQUMzQyxNQUFNLEVBQUUsQ0FBQyxrQkFBa0IsRUFBRSxDQUFDLGlCQUFpQixDQUFDO0lBQ2hELFNBQVMsRUFBRSxJQUFJO0lBQ2YsSUFBSSxFQUFFLENBQUM7SUFDUCxlQUFlLEVBQUUsS0FBSztJQUN0QixxQkFBcUIsRUFBRSxLQUFLO0lBQzVCLFdBQVcsRUFBRSxLQUFLO0lBQ2xCLFlBQVksRUFBRSxLQUFLO0lB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LEtBQUs7Z0JBQ0csY0FBYztzQkFBdEIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csVUFBVTtzQkFBbEIsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUs7Z0JBSUcsT0FBTztzQkFBZixLQUFLO2dCQUlHLE1BQU07c0JBQWQsS0FBSztnQkFJRyxJQUFJO3NCQUFaLEtBQUs7Z0JBVU8sT0FBTztzQkFBbkIsS0FBSztnQkFnQkksYUFBYTtzQkFBdEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7QWZ0ZXJWaWV3SW5pdCwgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIGZvcndhcmRSZWYsIElucHV0LCBPbkluaXQsIE91dHB1dH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7TmdJZn0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xuaW1wb3J0ICogYXMgTCBmcm9tIFwibGVhZmxldFwiO1xuaW1wb3J0IHtpY29uLCBMYXRMbmcsIExhdExuZ0V4cHJlc3Npb24sIGxheWVyR3JvdXAsIExheWVyR3JvdXAsIE1hcCwgTWFya2VyfSBmcm9tIFwibGVhZmxldFwiO1xuaW1wb3J0IHtNYXRJbnB1dE1vZHVsZX0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL2lucHV0XCI7XG5pbXBvcnQge1xuICBDb250cm9sVmFsdWVBY2Nlc3NvcixcbiAgTkdfVkFMVUVfQUNDRVNTT1IsXG4gIFJlYWN0aXZlRm9ybXNNb2R1bGUsXG4gIFVudHlwZWRGb3JtQ29udHJvbCxcbiAgVW50eXBlZEZvcm1Hcm91cCwgVmFsaWRhdG9yc1xufSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcbmltcG9ydCB7TWF0Rm9ybUZpZWxkQXBwZWFyYW5jZX0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGRcIjtcbmltcG9ydCB7VGhlbWVQYWxldHRlfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZVwiO1xuaW1wb3J0IHtTdWJqZWN0LCB0YWtlVW50aWx9IGZyb20gXCJyeGpzXCI7XG5pbXBvcnQge01hdEljb25Nb2R1bGV9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9pY29uXCI7XG5cbi8qKlxuICogTWFwIG9wdGlvbnMgaW50ZXJmYWNlXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTWFwT3B0aW9uIHtcbiAgY2VudGVyPzogW251bWJlciwgbnVtYmVyXSxcbiAgZHJhZ2dhYmxlPzogYm9vbGVhbixcbiAgdXBkYXRlV2l0aENsaWNrPzogYm9vbGVhbixcbiAgdXBkYXRlV2l0aERvdWJsZUNsaWNrPzogYm9vbGVhbixcbiAgem9vbT86IG51bWJlcixcbiAgYm9yZGVyUmFkaXVzPzogc3RyaW5nLFxuICBzY3JvbGxhYmxlPzogYm9vbGVhbixcbiAgem9vbUNvbnRyb2w/OiBib29sZWFuLFxuICBzY3JvbGxXaGVlbFpvb20/OiBib29sZWFuLFxufVxuXG4vKipcbiAqIE1hcmtlciBpbnRlcmZhY2VcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBNYXJrZXJNYXAge1xuICBsYXQ6IG51bWJlcjtcbiAgbG5nOiBudW1iZXI7XG4gIGRyYWdnYWJsZT86IGJvb2xlYW47XG59XG5cbi8qKlxuICogSWNvbiBpbnRlcmZhY2VcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBJY29uIHtcbiAgaWNvblNpemU6IFtudW1iZXIsIG51bWJlcl07XG4gIGljb25BbmNob3I6IFtudW1iZXIsIG51bWJlcl07XG4gIGljb25Vcmw6IHN0cmluZztcbiAgaWNvblJldGluYVVybD86IHN0cmluZyxcbiAgc2hhZG93VXJsPzogc3RyaW5nLFxuICBwb3B1cEFuY2hvcj86IFtudW1iZXIsIG51bWJlcl0sXG4gIHRvb2x0aXBBbmNob3I/OiBbbnVtYmVyLCBudW1iZXJdLFxuICBzaGFkb3dTaXplPzogW251bWJlciwgbnVtYmVyXSxcbn1cblxuLyoqXG4gKiBDaXJjbGUgbWFwIGludGVyZmFjZVxuICovXG5leHBvcnQgaW50ZXJmYWNlIENpcmNsZU1hcCB7XG4gIGNlbnRlcjogTWFya2VyTWFwO1xuICByYWRpdXM6IG51bWJlcjtcbn1cblxuZXhwb3J0IGNvbnN0IERFRkFVTFRfTUFQX09QVElPTjogTWFwT3B0aW9uID0ge1xuICBjZW50ZXI6IFsyMy4xMzAyNTcxODUyOTEwMzYsIC04Mi4zNTYyNjIyMDcwMzEyNl0sXG4gIGRyYWdnYWJsZTogdHJ1ZSxcbiAgem9vbTogOCxcbiAgdXBkYXRlV2l0aENsaWNrOiBmYWxzZSxcbiAgdXBkYXRlV2l0aERvdWJsZUNsaWNrOiBmYWxzZSxcbiAgem9vbUNvbnRyb2w6IGZhbHNlLFxuICBib3JkZXJSYWRpdXM6ICc4cHgnLFxuICBzY3JvbGxXaGVlbFpvb206IGZhbHNlXG59O1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdndWFqaXJpdG9zLW1hcCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9tYXAuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9tYXAuY29tcG9uZW50LnNjc3MnXSxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW1xuICAgIE1hdElucHV0TW9kdWxlLFxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXG4gICAgTmdJZixcbiAgICBNYXRJY29uTW9kdWxlXG4gIF0sXG4gIHByb3ZpZGVyczogW1xuICAgIHtcbiAgICAgIHByb3ZpZGU6IE5HX1ZBTFVFX0FDQ0VTU09SLFxuICAgICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gR3VhamlyaXRvc01hcCksXG4gICAgICBtdWx0aTogdHJ1ZVxuICAgIH1cbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBHdWFqaXJpdG9zTWFwIGltcGxlbWVudHMgQWZ0ZXJWaWV3SW5pdCwgT25Jbml0LCBDb250cm9sVmFsdWVBY2Nlc3NvciB7XG4gIGNvbnN0cnVjdG9yKCkge1xuICB9XG4gIFxuICBwcml2YXRlIHN0YXRpYyBfb2JzZXJ2YWJsZVN1YmplY3QkOiBTdWJqZWN0PHZvaWQ+ID0gbmV3IFN1YmplY3QoKTtcbiAgcHJpdmF0ZSBfbWFwOiBNYXAgfCBudWxsID0gbnVsbDtcbiAgcHJpdmF0ZSBfbGF5ZXJHcm91cDogTGF5ZXJHcm91cCA9IG5ldyBMLkxheWVyR3JvdXAoKTtcbiAgcHJpdmF0ZSBfbWFya2Vyc0xpc3Q6IE1hcmtlck1hcFtdID0gW107XG4gIFxuICBwdWJsaWMgZm9ybTogVW50eXBlZEZvcm1Hcm91cCA9IG5ldyBVbnR5cGVkRm9ybUdyb3VwKHtcbiAgICBsYXRpdHVkZTogbmV3IFVudHlwZWRGb3JtQ29udHJvbCh7dmFsdWU6IG51bGwsIGRpc2FibGVkOiBmYWxzZX0sIFtWYWxpZGF0b3JzLnJlcXVpcmVkXSksXG4gICAgbG9uZ2l0dWRlOiBuZXcgVW50eXBlZEZvcm1Db250cm9sKHt2YWx1ZTogbnVsbCwgZGlzYWJsZWQ6IGZhbHNlfSwgW1ZhbGlkYXRvcnMucmVxdWlyZWRdKVxuICB9KTtcbiAgXG4gIEBJbnB1dCgpIGxhdExhYmVsOiBzdHJpbmcgPSAnJztcbiAgQElucHV0KCkgbGF0UGxhY2Vob2xkZXI6IHN0cmluZyA9ICcnO1xuICBASW5wdXQoKSBsbmdMYWJlbDogc3RyaW5nID0gJyc7XG4gIEBJbnB1dCgpIGxuZ1BsYWNlaG9sZGVyOiBzdHJpbmcgPSAnJztcbiAgQElucHV0KCkgbGF0RXJyb3I6IHN0cmluZyA9ICcnO1xuICBASW5wdXQoKSBsbmdFcnJvcjogc3RyaW5nID0gJyc7XG4gIEBJbnB1dCgpIGFwcGVhcmFuY2U6IE1hdEZvcm1GaWVsZEFwcGVhcmFuY2UgPSAnb3V0bGluZSc7XG4gIEBJbnB1dCgpIGNvbG9yOiBUaGVtZVBhbGV0dGUgPSAnYWNjZW50JztcbiAgQElucHV0KCkgcmVhZG9ubHk6IGJvb2xlYW4gPSBmYWxzZTtcbiAgQElucHV0KCkgaGlkZGVuOiBib29sZWFuID0gZmFsc2U7XG4gIC8qKlxuICAgKiBEZWZhdWx0IG1hcCBvcHRpb25zXG4gICAqL1xuICBASW5wdXQoKSBvcHRpb25zOiBNYXBPcHRpb24gPSB7fTtcbiAgLyoqXG4gICAqIEFkZCBhIGNpcmNsZSBvbiB0aGUgbWFwXG4gICAqL1xuICBASW5wdXQoKSBjaXJjbGUhOiBDaXJjbGVNYXA7XG4gIC8qKlxuICAgKiBEZWZhdWx0IG1hcmtlciBpY29uXG4gICAqL1xuICBASW5wdXQoKSBpY29uOiBJY29uID0ge1xuICAgIGljb25TaXplOiBbMjUsIDQxXSxcbiAgICBpY29uQW5jaG9yOiBbMTMsIDQxXSxcbiAgICBpY29uVXJsOiAnbWFya2VyLWljb24ucG5nJ1xuICB9O1xuICBcbiAgLyoqXG4gICAqIExpc3Qgb2YgbWFya2Vyc1xuICAgKiBAcGFyYW0gbWFya2VycyAtIE1hcmtlcnMgYXJyYXlcbiAgICovXG4gIEBJbnB1dCgpIHNldCBtYXJrZXJzKG1hcmtlcnM6IE1hcmtlck1hcFtdKSB7XG4gICAgaWYgKG1hcmtlcnMgJiYgbWFya2Vycy5sZW5ndGggPiAwKSB7XG4gICAgICB0aGlzLl9tYXJrZXJzTGlzdCA9IG1hcmtlcnM7XG4gICAgICBzZXRUaW1lb3V0KCgpOiB2b2lkID0+IHtcbiAgICAgICAgdGhpcy5fbGF5ZXJHcm91cD8uY2xlYXJMYXllcnMoKTtcbiAgICAgICAgbWFya2Vycy5mb3JFYWNoKChtOiBhbnkpOiB2b2lkID0+IHtcbiAgICAgICAgICB0aGlzLl9hZGRNYXJrZXIobSk7XG4gICAgICAgIH0pO1xuICAgICAgICB0aGlzLmNoYW5nZUNlbnRlcih0aGlzLl9jcmVhdGVNYXJrZXIobWFya2Vyc1swXSkpO1xuICAgICAgfSwgMTAwKTtcbiAgICB9XG4gIH1cbiAgXG4gIC8qKlxuICAgKiBTZSBsYW56YSBjYWRhIHZleiBxdWUgY2FtYmlhIHVuIG1hcmNhZG9yXG4gICAqL1xuICBAT3V0cHV0KCkgbWFya2VyRHJhZ2VuZDogRXZlbnRFbWl0dGVyPExhdExuZz4gPSBuZXcgRXZlbnRFbWl0dGVyKCk7XG4gIFxuICAvKipcbiAgICogRm9ybSBpbml0aWFsaXphdGlvblxuICAgKiBAcGFyYW0gZGF0YSAtIEluaXRpYWwgZGF0YVxuICAgKi9cbiAgcHJpdmF0ZSBfaW5pdEZvcm0oZGF0YTogYW55KTogdm9pZCB7XG4gICAgdGhpcy5mb3JtLnBhdGNoVmFsdWUoe1xuICAgICAgbGF0aXR1ZGU6IGRhdGE/LmxhdGl0dWRlLFxuICAgICAgbG9uZ2l0dWRlOiBkYXRhPy5sb25naXR1ZGUsXG4gICAgfSk7XG4gIH1cbiAgXG4gIC8qKlxuICAgKiBNYWluIHByb3BlcnRpZXMgb2YgdGhlIG1hcFxuICAgKiBAcHJpdmF0ZVxuICAgKi9cbiAgcHJpdmF0ZSBfaW5pdE1hcCgpOiB2b2lkIHtcbiAgICB0aGlzLl9tYXAgPSBMLm1hcCgnbWFwJywge1xuICAgICAgY2VudGVyOiB0aGlzLm9wdGlvbnM/LmNlbnRlciBhcyBMYXRMbmdFeHByZXNzaW9uID8/IERFRkFVTFRfTUFQX09QVElPTi5jZW50ZXIsXG4gICAgICBkcmFnZ2luZzogdGhpcy5vcHRpb25zPy5kcmFnZ2FibGUgPz8gREVGQVVMVF9NQVBfT1BUSU9OLmRyYWdnYWJsZSxcbiAgICAgIHpvb206IHRoaXMub3B0aW9ucz8uem9vbSA/PyBERUZBVUxUX01BUF9PUFRJT04uem9vbSxcbiAgICAgIHpvb21Db250cm9sOiB0aGlzLm9wdGlvbnM/Lnpvb21Db250cm9sIHx8IERFRkFVTFRfTUFQX09QVElPTi56b29tQ29udHJvbCxcbiAgICAgIHNjcm9sbFdoZWVsWm9vbTogdGhpcy5vcHRpb25zPy5zY3JvbGxXaGVlbFpvb20gfHwgREVGQVVMVF9NQVBfT1BUSU9OLnNjcm9sbFdoZWVsWm9vbSxcbiAgICAgIG1heFpvb206IDE4LFxuICAgICAgbWluWm9vbTogMyxcbiAgICB9KTtcbiAgICBcbiAgICB0aGlzLl9sYXllckdyb3VwID0gbGF5ZXJHcm91cCgpLmFkZFRvKHRoaXMuX21hcCk7XG4gICAgXG4gICAgTC50aWxlTGF5ZXIoJ2h0dHA6Ly97c30udGlsZS5vcGVuc3RyZWV0bWFwLmZyL2hvdC97en0ve3h9L3t5fS5wbmcnKS5hZGRUbyh0aGlzLl9tYXApO1xuICB9XG4gIFxuICAvKipcbiAgICogQWRkIG1hcmtlciB0byBtYXBcbiAgICogQHBhcmFtIGNlbnRlciAtIGNlbnRlciBvZiB0aGUgY2lyY2xlXG4gICAqIEBwYXJhbSByYWRpdXMgLSByYWRpdXMgb2YgdGhlIGNpcmNsZSBpbiBtZXRlcnNcbiAgICogQHByaXZhdGVcbiAgICovXG4gIHByaXZhdGUgX2FkZENpcmNsZShjZW50ZXI6IE1hcmtlck1hcCwgcmFkaXVzOiBudW1iZXIpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5fbWFwICYmIGNlbnRlcikge1xuICAgICAgTC5jaXJjbGVNYXJrZXIoW2NlbnRlcj8ubGF0LCBjZW50ZXI/LmxuZ10sIHtyYWRpdXN9KS5hZGRUbyh0aGlzLl9tYXApO1xuICAgIH1cbiAgfVxuICBcbiAgLyoqXG4gICAqIEFkZCBtYXJrZXIgdG8gbWFwXG4gICAqIEBwYXJhbSBtYXJrZXIgLSBQb2ludCBvZiB0aGUgbWFwXG4gICAqL1xuICBwcml2YXRlIF9hZGRNYXJrZXIobWFya2VyOiBNYXJrZXJNYXApOiB2b2lkIHtcbiAgICBpZiAodGhpcy5fbWFwICYmIG1hcmtlcikge1xuICAgICAgY29uc3QgbWFya2VyQWRkID0gTC5tYXJrZXIoe1xuICAgICAgICBsYXQ6IG1hcmtlcj8ubGF0LFxuICAgICAgICBsbmc6IG1hcmtlcj8ubG5nXG4gICAgICB9LCB7XG4gICAgICAgIGRyYWdnYWJsZTogbWFya2VyPy5kcmFnZ2FibGUgPz8gdHJ1ZSxcbiAgICAgICAgYXV0b1BhbjogdHJ1ZVxuICAgICAgfSkuc2V0SWNvbihcbiAgICAgICAgaWNvbih7XG4gICAgICAgICAgaWNvblNpemU6IHRoaXMuaWNvbj8uaWNvblNpemUsXG4gICAgICAgICAgaWNvbkFuY2hvcjogdGhpcy5pY29uPy5pY29uQW5jaG9yLFxuICAgICAgICAgIGljb25Vcmw6IHRoaXMuaWNvbj8uaWNvblVybFxuICAgICAgICB9KVxuICAgICAgKS5hZGRUbyh0aGlzLl9sYXllckdyb3VwKTtcbiAgICAgIFxuICAgICAgbWFya2VyQWRkLm9uKCdkcmFnZW5kJywgKCk6IHZvaWQgPT4ge1xuICAgICAgICB0aGlzLmNoYW5nZUNlbnRlcihtYXJrZXJBZGQpO1xuICAgICAgICB0aGlzLm1hcmtlckRyYWdlbmQuZW1pdChtYXJrZXJBZGQuZ2V0TGF0TG5nKCkpO1xuICAgICAgfSk7XG4gICAgfVxuICB9XG4gIFxuICAvKipcbiAgICogQWRkIGEgbWFya2VyIG9uIHRoZSBtYXBcbiAgICogQHBhcmFtIG1hcmtlciAtIFBvaW50IG9mIHRoZSBtYXBcbiAgICogQHByaXZhdGVcbiAgICovXG4gIHByaXZhdGUgX2NyZWF0ZU1hcmtlcihtYXJrZXI6IE1hcmtlck1hcCk6IE1hcmtlciB7XG4gICAgY29uc3QgbWFya2VyQ3JlYXRlOiBNYXJrZXI8TGF0TG5nPiA9IG5ldyBNYXJrZXIobmV3IExhdExuZyhcbiAgICAgIG1hcmtlcj8ubGF0LFxuICAgICAgbWFya2VyPy5sbmdcbiAgICApLCB7XG4gICAgICBkcmFnZ2FibGU6IG1hcmtlcj8uZHJhZ2dhYmxlID8/IHRydWUsXG4gICAgICBhdXRvUGFuOiB0cnVlXG4gICAgfSkuc2V0SWNvbihcbiAgICAgIGljb24oe1xuICAgICAgICBpY29uU2l6ZTogdGhpcy5pY29uPy5pY29uU2l6ZSxcbiAgICAgICAgaWNvbkFuY2hvcjogdGhpcy5pY29uPy5pY29uQW5jaG9yLFxuICAgICAgICBpY29uVXJsOiB0aGlzLmljb24/Lmljb25VcmxcbiAgICAgIH0pXG4gICAgKTtcbiAgICBcbiAgICBtYXJrZXJDcmVhdGUub24oJ2RyYWdlbmQnLCAoKTogdm9pZCA9PiB7XG4gICAgICB0aGlzLmNoYW5nZUNlbnRlcihtYXJrZXJDcmVhdGUpO1xuICAgICAgdGhpcy5tYXJrZXJEcmFnZW5kLmVtaXQobWFya2VyQ3JlYXRlLmdldExhdExuZygpKTtcbiAgICB9KTtcbiAgICBcbiAgICByZXR1cm4gbWFya2VyQ3JlYXRlO1xuICB9XG4gIFxuICAvKipcbiAgICogR2V0IGxhdGl0dWRlIGFuZCBsb25naXR1ZGUgdmFsdWVzIGlmIG1ha2VyIG1hcCBpcyBvbmx5IG9uZVxuICAgKiBAcHJpdmF0ZVxuICAgKi9cbiAgcHJpdmF0ZSBfZ2V0TGF0TG5nKCk6IHZvaWQge1xuICAgIGlmICh0aGlzLl9tYXJrZXJzTGlzdD8ubGVuZ3RoID09PSAxKSB7XG4gICAgICB0aGlzLmZvcm0ucGF0Y2hWYWx1ZSh7XG4gICAgICAgIGxhdGl0dWRlOiB0aGlzLl9tYXJrZXJzTGlzdD8uWzBdPy5sYXQsXG4gICAgICAgIGxvbmdpdHVkZTogdGhpcy5fbWFya2Vyc0xpc3Q/LlswXT8ubG5nXG4gICAgICB9KVxuICAgIH1cbiAgfVxuICBcbiAgcHJpdmF0ZSBfbGF0TG5nQ2hhbmdlQ2VudGVyKG1hcmtlcjogYW55KSB7XG4gICAgdGhpcy5fbWFwPy5zZXRWaWV3KHtcbiAgICAgIGxhdDogbWFya2VyPy5sYXRpdHVkZSxcbiAgICAgIGxuZzogbWFya2VyPy5sb25naXR1ZGVcbiAgICB9KTtcbiAgICBcbiAgICB0aGlzLl9tYXJrZXJzTGlzdFswXS5sYXQgPSBwYXJzZUZsb2F0KG1hcmtlcj8ubGF0aXR1ZGUpO1xuICAgIHRoaXMuX21hcmtlcnNMaXN0WzBdLmxuZyA9IHBhcnNlRmxvYXQobWFya2VyPy5sb25naXR1ZGUpO1xuICAgIFxuICAgIHRoaXMuX2xheWVyR3JvdXA/LmNsZWFyTGF5ZXJzKCk7XG4gICAgXG4gICAgY29uc3QgbWFya2VyQWRkID0gTC5tYXJrZXIoe1xuICAgICAgbGF0OiB0aGlzLl9tYXJrZXJzTGlzdD8uWzBdPy5sYXQsXG4gICAgICBsbmc6IHRoaXMuX21hcmtlcnNMaXN0Py5bMF0/LmxuZyxcbiAgICB9LCB7XG4gICAgICBkcmFnZ2FibGU6IG1hcmtlcj8uZHJhZ2dhYmxlID8/IHRydWUsXG4gICAgICBhdXRvUGFuOiB0cnVlXG4gICAgfSkuYWRkVG8odGhpcy5fbGF5ZXJHcm91cCk7XG4gICAgXG4gICAgbWFya2VyQWRkLm9uKCdkcmFnZW5kJywgKCk6IHZvaWQgPT4ge1xuICAgICAgdGhpcy5jaGFuZ2VDZW50ZXIobWFya2VyQWRkKTtcbiAgICAgIHRoaXMubWFya2VyRHJhZ2VuZC5lbWl0KG1hcmtlckFkZC5nZXRMYXRMbmcoKSk7XG4gICAgfSk7XG4gIH1cbiAgXG4gIC8qKlxuICAgKiBNYWtlIHZpc2libGUvaGlkZSBsYXRpdHVkZSBhbmQgbG9uZ2l0dWRlIGlucHV0c1xuICAgKiBAcHVibGljXG4gICAqL1xuICBwdWJsaWMgaGlkZUxhdExuZygpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5fbWFya2Vyc0xpc3Q/Lmxlbmd0aCA9PT0gMTtcbiAgfVxuICBcbiAgLyoqXG4gICAqIFB1dCB0aGUgbWFwIGNlbnRlciBvbiBtYXJrZXIgcG9zaXRpb25cbiAgICogQHBhcmFtIG1hcmtlciAtIFBvaW50IG9mIHRoZSBtYXBcbiAgICogQHB1YmxpY1xuICAgKi9cbiAgcHVibGljIGNoYW5nZUNlbnRlcihtYXJrZXI6IE1hcmtlcik6IHZvaWQge1xuICAgIHRoaXMuX21hcD8uc2V0VmlldyhtYXJrZXI/LmdldExhdExuZygpKTtcbiAgfVxuICBcbiAgcHJvcGFnYXRlQ2hhbmdlKF86IGFueSk6IHZvaWQge1xuICB9O1xuICBcbiAgcmVnaXN0ZXJPbkNoYW5nZShmbjogYW55KTogdm9pZCB7XG4gICAgdGhpcy5wcm9wYWdhdGVDaGFuZ2UgPSBmbjtcbiAgfVxuICBcbiAgcmVnaXN0ZXJPblRvdWNoZWQoKTogdm9pZCB7XG4gIH1cbiAgXG4gIHNldERpc2FibGVkU3RhdGUoaXNEaXNhYmxlZDogYm9vbGVhbik6IHZvaWQge1xuICAgIGlmIChpc0Rpc2FibGVkKSB7XG4gICAgICB0aGlzLmZvcm0uZGlzYWJsZSgpO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLmZvcm0uZW5hYmxlKCk7XG4gICAgfVxuICB9XG4gIFxuICB3cml0ZVZhbHVlKGZvcm06IGFueSk6IHZvaWQge1xuICAgIGlmIChmb3JtKSB7XG4gICAgICB0aGlzLl9pbml0Rm9ybShmb3JtKTtcbiAgICB9XG4gIH1cbiAgXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIHRoaXMuX2dldExhdExuZygpO1xuICAgIFxuICAgIHRoaXMuZm9ybS52YWx1ZUNoYW5nZXNcbiAgICAgIC5waXBlKHRha2VVbnRpbChHdWFqaXJpdG9zTWFwLl9vYnNlcnZhYmxlU3ViamVjdCQuYXNPYnNlcnZhYmxlKCkpKVxuICAgICAgLnN1YnNjcmliZSgoKTogdm9pZCA9PiB7XG4gICAgICAgIHRoaXMucHJvcGFnYXRlQ2hhbmdlKHRoaXMuZm9ybS52YWx1ZSk7XG4gICAgICAgIHRoaXMuX2xhdExuZ0NoYW5nZUNlbnRlcih0aGlzLmZvcm0udmFsdWUpO1xuICAgICAgfSlcbiAgfVxuICBcbiAgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xuICAgIHRoaXMuX2luaXRNYXAoKTtcbiAgICBcbiAgICBpZiAodGhpcy5jaXJjbGUpIHtcbiAgICAgIHRoaXMuX2FkZENpcmNsZSh0aGlzLmNpcmNsZT8uY2VudGVyLCB0aGlzLmNpcmNsZT8ucmFkaXVzKTtcbiAgICB9XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJtYXAtY29udGFpbmVyXCI+XG4gIDxkaXYgY2xhc3M9XCJsYXRMbmdJbnB1dFwiIFtmb3JtR3JvdXBdPVwiZm9ybVwiICpuZ0lmPVwiaGlkZUxhdExuZygpICYmICFoaWRkZW5cIj5cbiAgICA8bWF0LWZvcm0tZmllbGQgW2FwcGVhcmFuY2VdPVwiYXBwZWFyYW5jZVwiIFtjb2xvcl09XCJjb2xvclwiIGNsYXNzPSd3LTEwMCc+XG4gICAgICA8bWF0LWxhYmVsPnt7bGF0TGFiZWx9fTwvbWF0LWxhYmVsPlxuICAgICAgPG1hdC1pY29uIG1hdFN1ZmZpeCBjbGFzcz1cIm1hdGVyaWFsLWljb25zLW91dGxpbmVkXCIgW2NvbG9yXT1cImNvbG9yXCI+cGxhY2U8L21hdC1pY29uPlxuICAgICAgPGlucHV0IG1hdElucHV0IFtwbGFjZWhvbGRlcl09XCJsYXRQbGFjZWhvbGRlclwiIFtyZWFkb25seV09XCJyZWFkb25seVwiIGZvcm1Db250cm9sTmFtZT1cImxhdGl0dWRlXCI+XG4gICAgICA8bWF0LWVycm9yICpuZ0lmPVwiZm9ybS5jb250cm9sc1snbGF0aXR1ZGUnXS5oYXNFcnJvcigncmVxdWlyZWQnKVwiPnt7bGF0RXJyb3J9fTwvbWF0LWVycm9yPlxuICAgIDwvbWF0LWZvcm0tZmllbGQ+XG4gICAgXG4gICAgPG1hdC1mb3JtLWZpZWxkIFthcHBlYXJhbmNlXT1cImFwcGVhcmFuY2VcIiBbY29sb3JdPVwiY29sb3JcIiBjbGFzcz0ndy0xMDAnPlxuICAgICAgPG1hdC1sYWJlbD57e2xuZ0xhYmVsfX08L21hdC1sYWJlbD5cbiAgICAgIDxtYXQtaWNvbiBtYXRTdWZmaXggY2xhc3M9XCJtYXRlcmlhbC1pY29ucy1vdXRsaW5lZFwiIFtjb2xvcl09XCJjb2xvclwiPnBsYWNlPC9tYXQtaWNvbj5cbiAgICAgIDxpbnB1dCBtYXRJbnB1dCBbcGxhY2Vob2xkZXJdPVwibG5nUGxhY2Vob2xkZXJcIiBbcmVhZG9ubHldPVwicmVhZG9ubHlcIiBmb3JtQ29udHJvbE5hbWU9XCJsb25naXR1ZGVcIj5cbiAgICAgIDxtYXQtZXJyb3IgKm5nSWY9XCJmb3JtLmNvbnRyb2xzWydsb25naXR1ZGUnXS5oYXNFcnJvcigncmVxdWlyZWQnKVwiPnt7bG5nRXJyb3J9fTwvbWF0LWVycm9yPlxuICAgIDwvbWF0LWZvcm0tZmllbGQ+XG4gIDwvZGl2PlxuICBcbiAgPGRpdiBpZD1cIm1hcFwiIGNsYXNzPVwibWFwXCI+PC9kaXY+XG48L2Rpdj5cbiJdfQ==
|
package/lib/map.component.d.ts
DELETED
|
@@ -1,142 +0,0 @@
|
|
|
1
|
-
import { AfterViewInit, EventEmitter, OnInit } from "@angular/core";
|
|
2
|
-
import { LatLng, Marker } from "leaflet";
|
|
3
|
-
import { ControlValueAccessor, UntypedFormGroup } from "@angular/forms";
|
|
4
|
-
import { MatFormFieldAppearance } from "@angular/material/form-field";
|
|
5
|
-
import { ThemePalette } from "@angular/material/core";
|
|
6
|
-
import * as i0 from "@angular/core";
|
|
7
|
-
/**
|
|
8
|
-
* Map options interface
|
|
9
|
-
*/
|
|
10
|
-
export interface MapOption {
|
|
11
|
-
center?: [number, number];
|
|
12
|
-
draggable?: boolean;
|
|
13
|
-
updateWithClick?: boolean;
|
|
14
|
-
updateWithDoubleClick?: boolean;
|
|
15
|
-
zoom?: number;
|
|
16
|
-
borderRadius?: string;
|
|
17
|
-
scrollable?: boolean;
|
|
18
|
-
zoomControl?: boolean;
|
|
19
|
-
scrollWheelZoom?: boolean;
|
|
20
|
-
}
|
|
21
|
-
/**
|
|
22
|
-
* Marker interface
|
|
23
|
-
*/
|
|
24
|
-
export interface MarkerMap {
|
|
25
|
-
lat: number;
|
|
26
|
-
lng: number;
|
|
27
|
-
draggable?: boolean;
|
|
28
|
-
}
|
|
29
|
-
/**
|
|
30
|
-
* Icon interface
|
|
31
|
-
*/
|
|
32
|
-
export interface Icon {
|
|
33
|
-
iconSize: [number, number];
|
|
34
|
-
iconAnchor: [number, number];
|
|
35
|
-
iconUrl: string;
|
|
36
|
-
iconRetinaUrl?: string;
|
|
37
|
-
shadowUrl?: string;
|
|
38
|
-
popupAnchor?: [number, number];
|
|
39
|
-
tooltipAnchor?: [number, number];
|
|
40
|
-
shadowSize?: [number, number];
|
|
41
|
-
}
|
|
42
|
-
/**
|
|
43
|
-
* Circle map interface
|
|
44
|
-
*/
|
|
45
|
-
export interface CircleMap {
|
|
46
|
-
center: MarkerMap;
|
|
47
|
-
radius: number;
|
|
48
|
-
}
|
|
49
|
-
export declare const DEFAULT_MAP_OPTION: MapOption;
|
|
50
|
-
export declare class GuajiritosMap implements AfterViewInit, OnInit, ControlValueAccessor {
|
|
51
|
-
constructor();
|
|
52
|
-
private static _observableSubject$;
|
|
53
|
-
private _map;
|
|
54
|
-
private _layerGroup;
|
|
55
|
-
private _markersList;
|
|
56
|
-
form: UntypedFormGroup;
|
|
57
|
-
latLabel: string;
|
|
58
|
-
latPlaceholder: string;
|
|
59
|
-
lngLabel: string;
|
|
60
|
-
lngPlaceholder: string;
|
|
61
|
-
latError: string;
|
|
62
|
-
lngError: string;
|
|
63
|
-
appearance: MatFormFieldAppearance;
|
|
64
|
-
color: ThemePalette;
|
|
65
|
-
readonly: boolean;
|
|
66
|
-
hidden: boolean;
|
|
67
|
-
/**
|
|
68
|
-
* Default map options
|
|
69
|
-
*/
|
|
70
|
-
options: MapOption;
|
|
71
|
-
/**
|
|
72
|
-
* Add a circle on the map
|
|
73
|
-
*/
|
|
74
|
-
circle: CircleMap;
|
|
75
|
-
/**
|
|
76
|
-
* Default marker icon
|
|
77
|
-
*/
|
|
78
|
-
icon: Icon;
|
|
79
|
-
/**
|
|
80
|
-
* List of markers
|
|
81
|
-
* @param markers - Markers array
|
|
82
|
-
*/
|
|
83
|
-
set markers(markers: MarkerMap[]);
|
|
84
|
-
/**
|
|
85
|
-
* Se lanza cada vez que cambia un marcador
|
|
86
|
-
*/
|
|
87
|
-
markerDragend: EventEmitter<LatLng>;
|
|
88
|
-
/**
|
|
89
|
-
* Form initialization
|
|
90
|
-
* @param data - Initial data
|
|
91
|
-
*/
|
|
92
|
-
private _initForm;
|
|
93
|
-
/**
|
|
94
|
-
* Main properties of the map
|
|
95
|
-
* @private
|
|
96
|
-
*/
|
|
97
|
-
private _initMap;
|
|
98
|
-
/**
|
|
99
|
-
* Add marker to map
|
|
100
|
-
* @param center - center of the circle
|
|
101
|
-
* @param radius - radius of the circle in meters
|
|
102
|
-
* @private
|
|
103
|
-
*/
|
|
104
|
-
private _addCircle;
|
|
105
|
-
/**
|
|
106
|
-
* Add marker to map
|
|
107
|
-
* @param marker - Point of the map
|
|
108
|
-
*/
|
|
109
|
-
private _addMarker;
|
|
110
|
-
/**
|
|
111
|
-
* Add a marker on the map
|
|
112
|
-
* @param marker - Point of the map
|
|
113
|
-
* @private
|
|
114
|
-
*/
|
|
115
|
-
private _createMarker;
|
|
116
|
-
/**
|
|
117
|
-
* Get latitude and longitude values if maker map is only one
|
|
118
|
-
* @private
|
|
119
|
-
*/
|
|
120
|
-
private _getLatLng;
|
|
121
|
-
private _latLngChangeCenter;
|
|
122
|
-
/**
|
|
123
|
-
* Make visible/hide latitude and longitude inputs
|
|
124
|
-
* @public
|
|
125
|
-
*/
|
|
126
|
-
hideLatLng(): boolean;
|
|
127
|
-
/**
|
|
128
|
-
* Put the map center on marker position
|
|
129
|
-
* @param marker - Point of the map
|
|
130
|
-
* @public
|
|
131
|
-
*/
|
|
132
|
-
changeCenter(marker: Marker): void;
|
|
133
|
-
propagateChange(_: any): void;
|
|
134
|
-
registerOnChange(fn: any): void;
|
|
135
|
-
registerOnTouched(): void;
|
|
136
|
-
setDisabledState(isDisabled: boolean): void;
|
|
137
|
-
writeValue(form: any): void;
|
|
138
|
-
ngOnInit(): void;
|
|
139
|
-
ngAfterViewInit(): void;
|
|
140
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<GuajiritosMap, never>;
|
|
141
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<GuajiritosMap, "guajiritos-map", never, { "latLabel": { "alias": "latLabel"; "required": false; }; "latPlaceholder": { "alias": "latPlaceholder"; "required": false; }; "lngLabel": { "alias": "lngLabel"; "required": false; }; "lngPlaceholder": { "alias": "lngPlaceholder"; "required": false; }; "latError": { "alias": "latError"; "required": false; }; "lngError": { "alias": "lngError"; "required": false; }; "appearance": { "alias": "appearance"; "required": false; }; "color": { "alias": "color"; "required": false; }; "readonly": { "alias": "readonly"; "required": false; }; "hidden": { "alias": "hidden"; "required": false; }; "options": { "alias": "options"; "required": false; }; "circle": { "alias": "circle"; "required": false; }; "icon": { "alias": "icon"; "required": false; }; "markers": { "alias": "markers"; "required": false; }; }, { "markerDragend": "markerDragend"; }, never, never, true, never>;
|
|
142
|
-
}
|