@angular/google-maps 16.0.0-next.4 → 16.0.0-rc.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/google-map/google-map.mjs +451 -0
- package/{esm2020 → esm2022}/google-maps-module.mjs +35 -35
- package/{esm2020 → esm2022}/map-base-layer.mjs +4 -4
- package/{esm2020 → esm2022}/map-bicycling-layer/map-bicycling-layer.mjs +4 -4
- package/esm2022/map-circle/map-circle.mjs +269 -0
- package/esm2022/map-directions-renderer/map-directions-renderer.mjs +139 -0
- package/{esm2020 → esm2022}/map-directions-renderer/map-directions-service.mjs +4 -4
- package/{esm2020 → esm2022}/map-geocoder/map-geocoder.mjs +4 -4
- package/esm2022/map-ground-overlay/map-ground-overlay.mjs +178 -0
- package/{esm2020 → esm2022}/map-heatmap-layer/map-heatmap-layer.mjs +4 -4
- package/esm2022/map-info-window/map-info-window.mjs +209 -0
- package/esm2022/map-kml-layer/map-kml-layer.mjs +171 -0
- package/esm2022/map-marker/map-marker.mjs +428 -0
- package/esm2022/map-marker-clusterer/map-marker-clusterer.mjs +406 -0
- package/esm2022/map-polygon/map-polygon.mjs +217 -0
- package/esm2022/map-polyline/map-polyline.mjs +208 -0
- package/esm2022/map-rectangle/map-rectangle.mjs +230 -0
- package/{esm2020 → esm2022}/map-traffic-layer/map-traffic-layer.mjs +4 -4
- package/{esm2020 → esm2022}/map-transit-layer/map-transit-layer.mjs +4 -4
- package/{fesm2020 → fesm2022}/google-maps.mjs +100 -130
- package/fesm2022/google-maps.mjs.map +1 -0
- package/index.d.ts +13 -13
- package/package.json +5 -11
- package/esm2020/google-map/google-map.mjs +0 -451
- package/esm2020/map-circle/map-circle.mjs +0 -269
- package/esm2020/map-directions-renderer/map-directions-renderer.mjs +0 -139
- package/esm2020/map-ground-overlay/map-ground-overlay.mjs +0 -178
- package/esm2020/map-info-window/map-info-window.mjs +0 -209
- package/esm2020/map-kml-layer/map-kml-layer.mjs +0 -171
- package/esm2020/map-marker/map-marker.mjs +0 -428
- package/esm2020/map-marker-clusterer/map-marker-clusterer.mjs +0 -406
- package/esm2020/map-polygon/map-polygon.mjs +0 -217
- package/esm2020/map-polyline/map-polyline.mjs +0 -208
- package/esm2020/map-rectangle/map-rectangle.mjs +0 -230
- package/fesm2015/google-maps.mjs +0 -3219
- package/fesm2015/google-maps.mjs.map +0 -1
- package/fesm2020/google-maps.mjs.map +0 -1
- /package/{esm2020 → esm2022}/google-maps_public_index.mjs +0 -0
- /package/{esm2020 → esm2022}/index.mjs +0 -0
- /package/{esm2020 → esm2022}/map-anchor-point.mjs +0 -0
- /package/{esm2020 → esm2022}/map-event-manager.mjs +0 -0
- /package/{esm2020 → esm2022}/map-marker-clusterer/marker-clusterer-types.mjs +0 -0
- /package/{esm2020 → esm2022}/public-api.mjs +0 -0
|
@@ -1,451 +0,0 @@
|
|
|
1
|
-
/// <reference types="google.maps" />
|
|
2
|
-
/**
|
|
3
|
-
* @license
|
|
4
|
-
* Copyright Google LLC All Rights Reserved.
|
|
5
|
-
*
|
|
6
|
-
* Use of this source code is governed by an MIT-style license that can be
|
|
7
|
-
* found in the LICENSE file at https://angular.io/license
|
|
8
|
-
*/
|
|
9
|
-
// Workaround for: https://github.com/bazelbuild/rules_nodejs/issues/1265
|
|
10
|
-
/// <reference types="google.maps" />
|
|
11
|
-
import { ChangeDetectionStrategy, Component, ElementRef, Input, Output, ViewEncapsulation, Inject, PLATFORM_ID, NgZone, EventEmitter, } from '@angular/core';
|
|
12
|
-
import { isPlatformBrowser } from '@angular/common';
|
|
13
|
-
import { Observable } from 'rxjs';
|
|
14
|
-
import { MapEventManager } from '../map-event-manager';
|
|
15
|
-
import * as i0 from "@angular/core";
|
|
16
|
-
/** default options set to the Googleplex */
|
|
17
|
-
export const DEFAULT_OPTIONS = {
|
|
18
|
-
center: { lat: 37.421995, lng: -122.084092 },
|
|
19
|
-
zoom: 17,
|
|
20
|
-
// Note: the type conversion here isn't necessary for our CI, but it resolves a g3 failure.
|
|
21
|
-
mapTypeId: 'roadmap',
|
|
22
|
-
};
|
|
23
|
-
/** Arbitrary default height for the map element */
|
|
24
|
-
export const DEFAULT_HEIGHT = '500px';
|
|
25
|
-
/** Arbitrary default width for the map element */
|
|
26
|
-
export const DEFAULT_WIDTH = '500px';
|
|
27
|
-
/**
|
|
28
|
-
* Angular component that renders a Google Map via the Google Maps JavaScript
|
|
29
|
-
* API.
|
|
30
|
-
* @see https://developers.google.com/maps/documentation/javascript/reference/
|
|
31
|
-
*/
|
|
32
|
-
class GoogleMap {
|
|
33
|
-
set center(center) {
|
|
34
|
-
this._center = center;
|
|
35
|
-
}
|
|
36
|
-
set zoom(zoom) {
|
|
37
|
-
this._zoom = zoom;
|
|
38
|
-
}
|
|
39
|
-
set options(options) {
|
|
40
|
-
this._options = options || DEFAULT_OPTIONS;
|
|
41
|
-
}
|
|
42
|
-
constructor(_elementRef, _ngZone, platformId) {
|
|
43
|
-
this._elementRef = _elementRef;
|
|
44
|
-
this._ngZone = _ngZone;
|
|
45
|
-
this._eventManager = new MapEventManager(this._ngZone);
|
|
46
|
-
/** Height of the map. Set this to `null` if you'd like to control the height through CSS. */
|
|
47
|
-
this.height = DEFAULT_HEIGHT;
|
|
48
|
-
/** Width of the map. Set this to `null` if you'd like to control the width through CSS. */
|
|
49
|
-
this.width = DEFAULT_WIDTH;
|
|
50
|
-
this._options = DEFAULT_OPTIONS;
|
|
51
|
-
/** Event emitted when the map is initialized. */
|
|
52
|
-
this.mapInitialized = new EventEmitter();
|
|
53
|
-
/**
|
|
54
|
-
* See
|
|
55
|
-
* https://developers.google.com/maps/documentation/javascript/events#auth-errors
|
|
56
|
-
*/
|
|
57
|
-
this.authFailure = new EventEmitter();
|
|
58
|
-
/**
|
|
59
|
-
* See
|
|
60
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.bounds_changed
|
|
61
|
-
*/
|
|
62
|
-
this.boundsChanged = this._eventManager.getLazyEmitter('bounds_changed');
|
|
63
|
-
/**
|
|
64
|
-
* See
|
|
65
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.center_changed
|
|
66
|
-
*/
|
|
67
|
-
this.centerChanged = this._eventManager.getLazyEmitter('center_changed');
|
|
68
|
-
/**
|
|
69
|
-
* See
|
|
70
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.click
|
|
71
|
-
*/
|
|
72
|
-
this.mapClick = this._eventManager.getLazyEmitter('click');
|
|
73
|
-
/**
|
|
74
|
-
* See
|
|
75
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.dblclick
|
|
76
|
-
*/
|
|
77
|
-
this.mapDblclick = this._eventManager.getLazyEmitter('dblclick');
|
|
78
|
-
/**
|
|
79
|
-
* See
|
|
80
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.drag
|
|
81
|
-
*/
|
|
82
|
-
this.mapDrag = this._eventManager.getLazyEmitter('drag');
|
|
83
|
-
/**
|
|
84
|
-
* See
|
|
85
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.dragend
|
|
86
|
-
*/
|
|
87
|
-
this.mapDragend = this._eventManager.getLazyEmitter('dragend');
|
|
88
|
-
/**
|
|
89
|
-
* See
|
|
90
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.dragstart
|
|
91
|
-
*/
|
|
92
|
-
this.mapDragstart = this._eventManager.getLazyEmitter('dragstart');
|
|
93
|
-
/**
|
|
94
|
-
* See
|
|
95
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.heading_changed
|
|
96
|
-
*/
|
|
97
|
-
this.headingChanged = this._eventManager.getLazyEmitter('heading_changed');
|
|
98
|
-
/**
|
|
99
|
-
* See
|
|
100
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.idle
|
|
101
|
-
*/
|
|
102
|
-
this.idle = this._eventManager.getLazyEmitter('idle');
|
|
103
|
-
/**
|
|
104
|
-
* See
|
|
105
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.maptypeid_changed
|
|
106
|
-
*/
|
|
107
|
-
this.maptypeidChanged = this._eventManager.getLazyEmitter('maptypeid_changed');
|
|
108
|
-
/**
|
|
109
|
-
* See
|
|
110
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.mousemove
|
|
111
|
-
*/
|
|
112
|
-
this.mapMousemove = this._eventManager.getLazyEmitter('mousemove');
|
|
113
|
-
/**
|
|
114
|
-
* See
|
|
115
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.mouseout
|
|
116
|
-
*/
|
|
117
|
-
this.mapMouseout = this._eventManager.getLazyEmitter('mouseout');
|
|
118
|
-
/**
|
|
119
|
-
* See
|
|
120
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.mouseover
|
|
121
|
-
*/
|
|
122
|
-
this.mapMouseover = this._eventManager.getLazyEmitter('mouseover');
|
|
123
|
-
/**
|
|
124
|
-
* See
|
|
125
|
-
* developers.google.com/maps/documentation/javascript/reference/map#Map.projection_changed
|
|
126
|
-
*/
|
|
127
|
-
this.projectionChanged = this._eventManager.getLazyEmitter('projection_changed');
|
|
128
|
-
/**
|
|
129
|
-
* See
|
|
130
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.rightclick
|
|
131
|
-
*/
|
|
132
|
-
this.mapRightclick = this._eventManager.getLazyEmitter('rightclick');
|
|
133
|
-
/**
|
|
134
|
-
* See
|
|
135
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.tilesloaded
|
|
136
|
-
*/
|
|
137
|
-
this.tilesloaded = this._eventManager.getLazyEmitter('tilesloaded');
|
|
138
|
-
/**
|
|
139
|
-
* See
|
|
140
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.tilt_changed
|
|
141
|
-
*/
|
|
142
|
-
this.tiltChanged = this._eventManager.getLazyEmitter('tilt_changed');
|
|
143
|
-
/**
|
|
144
|
-
* See
|
|
145
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.zoom_changed
|
|
146
|
-
*/
|
|
147
|
-
this.zoomChanged = this._eventManager.getLazyEmitter('zoom_changed');
|
|
148
|
-
this._isBrowser = isPlatformBrowser(platformId);
|
|
149
|
-
if (this._isBrowser) {
|
|
150
|
-
const googleMapsWindow = window;
|
|
151
|
-
if (!googleMapsWindow.google && (typeof ngDevMode === 'undefined' || ngDevMode)) {
|
|
152
|
-
throw Error('Namespace google not found, cannot construct embedded google ' +
|
|
153
|
-
'map. Please install the Google Maps JavaScript API: ' +
|
|
154
|
-
'https://developers.google.com/maps/documentation/javascript/' +
|
|
155
|
-
'tutorial#Loading_the_Maps_API');
|
|
156
|
-
}
|
|
157
|
-
this._existingAuthFailureCallback = googleMapsWindow.gm_authFailure;
|
|
158
|
-
googleMapsWindow.gm_authFailure = () => {
|
|
159
|
-
if (this._existingAuthFailureCallback) {
|
|
160
|
-
this._existingAuthFailureCallback();
|
|
161
|
-
}
|
|
162
|
-
this.authFailure.emit();
|
|
163
|
-
};
|
|
164
|
-
}
|
|
165
|
-
}
|
|
166
|
-
ngOnChanges(changes) {
|
|
167
|
-
if (changes['height'] || changes['width']) {
|
|
168
|
-
this._setSize();
|
|
169
|
-
}
|
|
170
|
-
const googleMap = this.googleMap;
|
|
171
|
-
if (googleMap) {
|
|
172
|
-
if (changes['options']) {
|
|
173
|
-
googleMap.setOptions(this._combineOptions());
|
|
174
|
-
}
|
|
175
|
-
if (changes['center'] && this._center) {
|
|
176
|
-
googleMap.setCenter(this._center);
|
|
177
|
-
}
|
|
178
|
-
// Note that the zoom can be zero.
|
|
179
|
-
if (changes['zoom'] && this._zoom != null) {
|
|
180
|
-
googleMap.setZoom(this._zoom);
|
|
181
|
-
}
|
|
182
|
-
if (changes['mapTypeId'] && this.mapTypeId) {
|
|
183
|
-
googleMap.setMapTypeId(this.mapTypeId);
|
|
184
|
-
}
|
|
185
|
-
}
|
|
186
|
-
}
|
|
187
|
-
ngOnInit() {
|
|
188
|
-
// It should be a noop during server-side rendering.
|
|
189
|
-
if (this._isBrowser) {
|
|
190
|
-
this._mapEl = this._elementRef.nativeElement.querySelector('.map-container');
|
|
191
|
-
this._setSize();
|
|
192
|
-
// Create the object outside the zone so its events don't trigger change detection.
|
|
193
|
-
// We'll bring it back in inside the `MapEventManager` only for the events that the
|
|
194
|
-
// user has subscribed to.
|
|
195
|
-
this._ngZone.runOutsideAngular(() => {
|
|
196
|
-
this.googleMap = new google.maps.Map(this._mapEl, this._combineOptions());
|
|
197
|
-
});
|
|
198
|
-
this._eventManager.setTarget(this.googleMap);
|
|
199
|
-
this.mapInitialized.emit(this.googleMap);
|
|
200
|
-
}
|
|
201
|
-
}
|
|
202
|
-
ngOnDestroy() {
|
|
203
|
-
this._eventManager.destroy();
|
|
204
|
-
if (this._isBrowser) {
|
|
205
|
-
const googleMapsWindow = window;
|
|
206
|
-
googleMapsWindow.gm_authFailure = this._existingAuthFailureCallback;
|
|
207
|
-
}
|
|
208
|
-
}
|
|
209
|
-
/**
|
|
210
|
-
* See
|
|
211
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.fitBounds
|
|
212
|
-
*/
|
|
213
|
-
fitBounds(bounds, padding) {
|
|
214
|
-
this._assertInitialized();
|
|
215
|
-
this.googleMap.fitBounds(bounds, padding);
|
|
216
|
-
}
|
|
217
|
-
/**
|
|
218
|
-
* See
|
|
219
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.panBy
|
|
220
|
-
*/
|
|
221
|
-
panBy(x, y) {
|
|
222
|
-
this._assertInitialized();
|
|
223
|
-
this.googleMap.panBy(x, y);
|
|
224
|
-
}
|
|
225
|
-
/**
|
|
226
|
-
* See
|
|
227
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.panTo
|
|
228
|
-
*/
|
|
229
|
-
panTo(latLng) {
|
|
230
|
-
this._assertInitialized();
|
|
231
|
-
this.googleMap.panTo(latLng);
|
|
232
|
-
}
|
|
233
|
-
/**
|
|
234
|
-
* See
|
|
235
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.panToBounds
|
|
236
|
-
*/
|
|
237
|
-
panToBounds(latLngBounds, padding) {
|
|
238
|
-
this._assertInitialized();
|
|
239
|
-
this.googleMap.panToBounds(latLngBounds, padding);
|
|
240
|
-
}
|
|
241
|
-
/**
|
|
242
|
-
* See
|
|
243
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.getBounds
|
|
244
|
-
*/
|
|
245
|
-
getBounds() {
|
|
246
|
-
this._assertInitialized();
|
|
247
|
-
return this.googleMap.getBounds() || null;
|
|
248
|
-
}
|
|
249
|
-
/**
|
|
250
|
-
* See
|
|
251
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.getCenter
|
|
252
|
-
*/
|
|
253
|
-
getCenter() {
|
|
254
|
-
this._assertInitialized();
|
|
255
|
-
return this.googleMap.getCenter();
|
|
256
|
-
}
|
|
257
|
-
/**
|
|
258
|
-
* See
|
|
259
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.getClickableIcons
|
|
260
|
-
*/
|
|
261
|
-
getClickableIcons() {
|
|
262
|
-
this._assertInitialized();
|
|
263
|
-
return this.googleMap.getClickableIcons();
|
|
264
|
-
}
|
|
265
|
-
/**
|
|
266
|
-
* See
|
|
267
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.getHeading
|
|
268
|
-
*/
|
|
269
|
-
getHeading() {
|
|
270
|
-
this._assertInitialized();
|
|
271
|
-
return this.googleMap.getHeading();
|
|
272
|
-
}
|
|
273
|
-
/**
|
|
274
|
-
* See
|
|
275
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.getMapTypeId
|
|
276
|
-
*/
|
|
277
|
-
getMapTypeId() {
|
|
278
|
-
this._assertInitialized();
|
|
279
|
-
return this.googleMap.getMapTypeId();
|
|
280
|
-
}
|
|
281
|
-
/**
|
|
282
|
-
* See
|
|
283
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.getProjection
|
|
284
|
-
*/
|
|
285
|
-
getProjection() {
|
|
286
|
-
this._assertInitialized();
|
|
287
|
-
return this.googleMap.getProjection() || null;
|
|
288
|
-
}
|
|
289
|
-
/**
|
|
290
|
-
* See
|
|
291
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.getStreetView
|
|
292
|
-
*/
|
|
293
|
-
getStreetView() {
|
|
294
|
-
this._assertInitialized();
|
|
295
|
-
return this.googleMap.getStreetView();
|
|
296
|
-
}
|
|
297
|
-
/**
|
|
298
|
-
* See
|
|
299
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.getTilt
|
|
300
|
-
*/
|
|
301
|
-
getTilt() {
|
|
302
|
-
this._assertInitialized();
|
|
303
|
-
return this.googleMap.getTilt();
|
|
304
|
-
}
|
|
305
|
-
/**
|
|
306
|
-
* See
|
|
307
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.getZoom
|
|
308
|
-
*/
|
|
309
|
-
getZoom() {
|
|
310
|
-
this._assertInitialized();
|
|
311
|
-
return this.googleMap.getZoom();
|
|
312
|
-
}
|
|
313
|
-
/**
|
|
314
|
-
* See
|
|
315
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.controls
|
|
316
|
-
*/
|
|
317
|
-
get controls() {
|
|
318
|
-
this._assertInitialized();
|
|
319
|
-
return this.googleMap.controls;
|
|
320
|
-
}
|
|
321
|
-
/**
|
|
322
|
-
* See
|
|
323
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.data
|
|
324
|
-
*/
|
|
325
|
-
get data() {
|
|
326
|
-
this._assertInitialized();
|
|
327
|
-
return this.googleMap.data;
|
|
328
|
-
}
|
|
329
|
-
/**
|
|
330
|
-
* See
|
|
331
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.mapTypes
|
|
332
|
-
*/
|
|
333
|
-
get mapTypes() {
|
|
334
|
-
this._assertInitialized();
|
|
335
|
-
return this.googleMap.mapTypes;
|
|
336
|
-
}
|
|
337
|
-
/**
|
|
338
|
-
* See
|
|
339
|
-
* https://developers.google.com/maps/documentation/javascript/reference/map#Map.overlayMapTypes
|
|
340
|
-
*/
|
|
341
|
-
get overlayMapTypes() {
|
|
342
|
-
this._assertInitialized();
|
|
343
|
-
return this.googleMap.overlayMapTypes;
|
|
344
|
-
}
|
|
345
|
-
_setSize() {
|
|
346
|
-
if (this._mapEl) {
|
|
347
|
-
const styles = this._mapEl.style;
|
|
348
|
-
styles.height =
|
|
349
|
-
this.height === null ? '' : coerceCssPixelValue(this.height) || DEFAULT_HEIGHT;
|
|
350
|
-
styles.width = this.width === null ? '' : coerceCssPixelValue(this.width) || DEFAULT_WIDTH;
|
|
351
|
-
}
|
|
352
|
-
}
|
|
353
|
-
/** Combines the center and zoom and the other map options into a single object */
|
|
354
|
-
_combineOptions() {
|
|
355
|
-
const options = this._options || {};
|
|
356
|
-
return {
|
|
357
|
-
...options,
|
|
358
|
-
// It's important that we set **some** kind of `center` and `zoom`, otherwise
|
|
359
|
-
// Google Maps will render a blank rectangle which looks broken.
|
|
360
|
-
center: this._center || options.center || DEFAULT_OPTIONS.center,
|
|
361
|
-
zoom: this._zoom ?? options.zoom ?? DEFAULT_OPTIONS.zoom,
|
|
362
|
-
// Passing in an undefined `mapTypeId` seems to break tile loading
|
|
363
|
-
// so make sure that we have some kind of default (see #22082).
|
|
364
|
-
mapTypeId: this.mapTypeId || options.mapTypeId || DEFAULT_OPTIONS.mapTypeId,
|
|
365
|
-
};
|
|
366
|
-
}
|
|
367
|
-
/** Asserts that the map has been initialized. */
|
|
368
|
-
_assertInitialized() {
|
|
369
|
-
if (!this.googleMap && (typeof ngDevMode === 'undefined' || ngDevMode)) {
|
|
370
|
-
throw Error('Cannot access Google Map information before the API has been initialized. ' +
|
|
371
|
-
'Please wait for the API to load before trying to interact with it.');
|
|
372
|
-
}
|
|
373
|
-
}
|
|
374
|
-
}
|
|
375
|
-
GoogleMap.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.2", ngImport: i0, type: GoogleMap, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Component });
|
|
376
|
-
GoogleMap.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0-next.2", type: GoogleMap, selector: "google-map", inputs: { height: "height", width: "width", mapTypeId: "mapTypeId", center: "center", zoom: "zoom", options: "options" }, outputs: { mapInitialized: "mapInitialized", authFailure: "authFailure", boundsChanged: "boundsChanged", centerChanged: "centerChanged", mapClick: "mapClick", mapDblclick: "mapDblclick", mapDrag: "mapDrag", mapDragend: "mapDragend", mapDragstart: "mapDragstart", headingChanged: "headingChanged", idle: "idle", maptypeidChanged: "maptypeidChanged", mapMousemove: "mapMousemove", mapMouseout: "mapMouseout", mapMouseover: "mapMouseover", projectionChanged: "projectionChanged", mapRightclick: "mapRightclick", tilesloaded: "tilesloaded", tiltChanged: "tiltChanged", zoomChanged: "zoomChanged" }, exportAs: ["googleMap"], usesOnChanges: true, ngImport: i0, template: '<div class="map-container"></div><ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
377
|
-
export { GoogleMap };
|
|
378
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.2", ngImport: i0, type: GoogleMap, decorators: [{
|
|
379
|
-
type: Component,
|
|
380
|
-
args: [{
|
|
381
|
-
selector: 'google-map',
|
|
382
|
-
exportAs: 'googleMap',
|
|
383
|
-
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
384
|
-
template: '<div class="map-container"></div><ng-content></ng-content>',
|
|
385
|
-
encapsulation: ViewEncapsulation.None,
|
|
386
|
-
}]
|
|
387
|
-
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.NgZone }, { type: Object, decorators: [{
|
|
388
|
-
type: Inject,
|
|
389
|
-
args: [PLATFORM_ID]
|
|
390
|
-
}] }]; }, propDecorators: { height: [{
|
|
391
|
-
type: Input
|
|
392
|
-
}], width: [{
|
|
393
|
-
type: Input
|
|
394
|
-
}], mapTypeId: [{
|
|
395
|
-
type: Input
|
|
396
|
-
}], center: [{
|
|
397
|
-
type: Input
|
|
398
|
-
}], zoom: [{
|
|
399
|
-
type: Input
|
|
400
|
-
}], options: [{
|
|
401
|
-
type: Input
|
|
402
|
-
}], mapInitialized: [{
|
|
403
|
-
type: Output
|
|
404
|
-
}], authFailure: [{
|
|
405
|
-
type: Output
|
|
406
|
-
}], boundsChanged: [{
|
|
407
|
-
type: Output
|
|
408
|
-
}], centerChanged: [{
|
|
409
|
-
type: Output
|
|
410
|
-
}], mapClick: [{
|
|
411
|
-
type: Output
|
|
412
|
-
}], mapDblclick: [{
|
|
413
|
-
type: Output
|
|
414
|
-
}], mapDrag: [{
|
|
415
|
-
type: Output
|
|
416
|
-
}], mapDragend: [{
|
|
417
|
-
type: Output
|
|
418
|
-
}], mapDragstart: [{
|
|
419
|
-
type: Output
|
|
420
|
-
}], headingChanged: [{
|
|
421
|
-
type: Output
|
|
422
|
-
}], idle: [{
|
|
423
|
-
type: Output
|
|
424
|
-
}], maptypeidChanged: [{
|
|
425
|
-
type: Output
|
|
426
|
-
}], mapMousemove: [{
|
|
427
|
-
type: Output
|
|
428
|
-
}], mapMouseout: [{
|
|
429
|
-
type: Output
|
|
430
|
-
}], mapMouseover: [{
|
|
431
|
-
type: Output
|
|
432
|
-
}], projectionChanged: [{
|
|
433
|
-
type: Output
|
|
434
|
-
}], mapRightclick: [{
|
|
435
|
-
type: Output
|
|
436
|
-
}], tilesloaded: [{
|
|
437
|
-
type: Output
|
|
438
|
-
}], tiltChanged: [{
|
|
439
|
-
type: Output
|
|
440
|
-
}], zoomChanged: [{
|
|
441
|
-
type: Output
|
|
442
|
-
}] } });
|
|
443
|
-
const cssUnitsPattern = /([A-Za-z%]+)$/;
|
|
444
|
-
/** Coerces a value to a CSS pixel value. */
|
|
445
|
-
function coerceCssPixelValue(value) {
|
|
446
|
-
if (value == null) {
|
|
447
|
-
return '';
|
|
448
|
-
}
|
|
449
|
-
return cssUnitsPattern.test(value) ? value : `${value}px`;
|
|
450
|
-
}
|
|
451
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"google-map.js","sourceRoot":"","sources":["../../../../../../src/google-maps/google-map/google-map.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n// Workaround for: https://github.com/bazelbuild/rules_nodejs/issues/1265\n/// <reference types=\"google.maps\" />\n\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewEncapsulation,\n  Inject,\n  PLATFORM_ID,\n  NgZone,\n  SimpleChanges,\n  EventEmitter,\n} from '@angular/core';\nimport {isPlatformBrowser} from '@angular/common';\nimport {Observable} from 'rxjs';\nimport {MapEventManager} from '../map-event-manager';\n\ninterface GoogleMapsWindow extends Window {\n  gm_authFailure?: () => void;\n  google?: typeof google;\n}\n\n/** default options set to the Googleplex */\nexport const DEFAULT_OPTIONS: google.maps.MapOptions = {\n  center: {lat: 37.421995, lng: -122.084092},\n  zoom: 17,\n  // Note: the type conversion here isn't necessary for our CI, but it resolves a g3 failure.\n  mapTypeId: 'roadmap' as unknown as google.maps.MapTypeId,\n};\n\n/** Arbitrary default height for the map element */\nexport const DEFAULT_HEIGHT = '500px';\n/** Arbitrary default width for the map element */\nexport const DEFAULT_WIDTH = '500px';\n\n/**\n * Angular component that renders a Google Map via the Google Maps JavaScript\n * API.\n * @see https://developers.google.com/maps/documentation/javascript/reference/\n */\n@Component({\n  selector: 'google-map',\n  exportAs: 'googleMap',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  template: '<div class=\"map-container\"></div><ng-content></ng-content>',\n  encapsulation: ViewEncapsulation.None,\n})\nexport class GoogleMap implements OnChanges, OnInit, OnDestroy {\n  private _eventManager: MapEventManager = new MapEventManager(this._ngZone);\n  private _mapEl: HTMLElement;\n  private _existingAuthFailureCallback: GoogleMapsWindow['gm_authFailure'];\n\n  /**\n   * The underlying google.maps.Map object\n   *\n   * See developers.google.com/maps/documentation/javascript/reference/map#Map\n   */\n  googleMap?: google.maps.Map;\n\n  /** Whether we're currently rendering inside a browser. */\n  _isBrowser: boolean;\n\n  /** Height of the map. Set this to `null` if you'd like to control the height through CSS. */\n  @Input() height: string | number | null = DEFAULT_HEIGHT;\n\n  /** Width of the map. Set this to `null` if you'd like to control the width through CSS. */\n  @Input() width: string | number | null = DEFAULT_WIDTH;\n\n  /**\n   * Type of map that should be rendered. E.g. hybrid map, terrain map etc.\n   * See: https://developers.google.com/maps/documentation/javascript/reference/map#MapTypeId\n   */\n  @Input() mapTypeId: google.maps.MapTypeId | undefined;\n\n  @Input()\n  set center(center: google.maps.LatLngLiteral | google.maps.LatLng) {\n    this._center = center;\n  }\n  private _center: google.maps.LatLngLiteral | google.maps.LatLng;\n\n  @Input()\n  set zoom(zoom: number) {\n    this._zoom = zoom;\n  }\n  private _zoom: number;\n\n  @Input()\n  set options(options: google.maps.MapOptions) {\n    this._options = options || DEFAULT_OPTIONS;\n  }\n  private _options = DEFAULT_OPTIONS;\n\n  /** Event emitted when the map is initialized. */\n  @Output() readonly mapInitialized: EventEmitter<google.maps.Map> =\n    new EventEmitter<google.maps.Map>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/events#auth-errors\n   */\n  @Output() readonly authFailure: EventEmitter<void> = new EventEmitter<void>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.bounds_changed\n   */\n  @Output() readonly boundsChanged: Observable<void> =\n    this._eventManager.getLazyEmitter<void>('bounds_changed');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.center_changed\n   */\n  @Output() readonly centerChanged: Observable<void> =\n    this._eventManager.getLazyEmitter<void>('center_changed');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.click\n   */\n  @Output() readonly mapClick: Observable<google.maps.MapMouseEvent | google.maps.IconMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent | google.maps.IconMouseEvent>(\n      'click',\n    );\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.dblclick\n   */\n  @Output() readonly mapDblclick: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('dblclick');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.drag\n   */\n  @Output() readonly mapDrag: Observable<void> = this._eventManager.getLazyEmitter<void>('drag');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.dragend\n   */\n  @Output() readonly mapDragend: Observable<void> =\n    this._eventManager.getLazyEmitter<void>('dragend');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.dragstart\n   */\n  @Output() readonly mapDragstart: Observable<void> =\n    this._eventManager.getLazyEmitter<void>('dragstart');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.heading_changed\n   */\n  @Output() readonly headingChanged: Observable<void> =\n    this._eventManager.getLazyEmitter<void>('heading_changed');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.idle\n   */\n  @Output() readonly idle: Observable<void> = this._eventManager.getLazyEmitter<void>('idle');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.maptypeid_changed\n   */\n  @Output() readonly maptypeidChanged: Observable<void> =\n    this._eventManager.getLazyEmitter<void>('maptypeid_changed');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.mousemove\n   */\n  @Output()\n  readonly mapMousemove: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('mousemove');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.mouseout\n   */\n  @Output() readonly mapMouseout: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('mouseout');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.mouseover\n   */\n  @Output() readonly mapMouseover: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('mouseover');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/map#Map.projection_changed\n   */\n  @Output() readonly projectionChanged: Observable<void> =\n    this._eventManager.getLazyEmitter<void>('projection_changed');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.rightclick\n   */\n  @Output() readonly mapRightclick: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('rightclick');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.tilesloaded\n   */\n  @Output() readonly tilesloaded: Observable<void> =\n    this._eventManager.getLazyEmitter<void>('tilesloaded');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.tilt_changed\n   */\n  @Output() readonly tiltChanged: Observable<void> =\n    this._eventManager.getLazyEmitter<void>('tilt_changed');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.zoom_changed\n   */\n  @Output() readonly zoomChanged: Observable<void> =\n    this._eventManager.getLazyEmitter<void>('zoom_changed');\n\n  constructor(\n    private readonly _elementRef: ElementRef,\n    private _ngZone: NgZone,\n    @Inject(PLATFORM_ID) platformId: Object,\n  ) {\n    this._isBrowser = isPlatformBrowser(platformId);\n\n    if (this._isBrowser) {\n      const googleMapsWindow: GoogleMapsWindow = window;\n      if (!googleMapsWindow.google && (typeof ngDevMode === 'undefined' || ngDevMode)) {\n        throw Error(\n          'Namespace google not found, cannot construct embedded google ' +\n            'map. Please install the Google Maps JavaScript API: ' +\n            'https://developers.google.com/maps/documentation/javascript/' +\n            'tutorial#Loading_the_Maps_API',\n        );\n      }\n\n      this._existingAuthFailureCallback = googleMapsWindow.gm_authFailure;\n      googleMapsWindow.gm_authFailure = () => {\n        if (this._existingAuthFailureCallback) {\n          this._existingAuthFailureCallback();\n        }\n        this.authFailure.emit();\n      };\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['height'] || changes['width']) {\n      this._setSize();\n    }\n\n    const googleMap = this.googleMap;\n\n    if (googleMap) {\n      if (changes['options']) {\n        googleMap.setOptions(this._combineOptions());\n      }\n\n      if (changes['center'] && this._center) {\n        googleMap.setCenter(this._center);\n      }\n\n      // Note that the zoom can be zero.\n      if (changes['zoom'] && this._zoom != null) {\n        googleMap.setZoom(this._zoom);\n      }\n\n      if (changes['mapTypeId'] && this.mapTypeId) {\n        googleMap.setMapTypeId(this.mapTypeId);\n      }\n    }\n  }\n\n  ngOnInit() {\n    // It should be a noop during server-side rendering.\n    if (this._isBrowser) {\n      this._mapEl = this._elementRef.nativeElement.querySelector('.map-container')!;\n      this._setSize();\n\n      // Create the object outside the zone so its events don't trigger change detection.\n      // We'll bring it back in inside the `MapEventManager` only for the events that the\n      // user has subscribed to.\n      this._ngZone.runOutsideAngular(() => {\n        this.googleMap = new google.maps.Map(this._mapEl, this._combineOptions());\n      });\n      this._eventManager.setTarget(this.googleMap);\n      this.mapInitialized.emit(this.googleMap);\n    }\n  }\n\n  ngOnDestroy() {\n    this._eventManager.destroy();\n\n    if (this._isBrowser) {\n      const googleMapsWindow: GoogleMapsWindow = window;\n      googleMapsWindow.gm_authFailure = this._existingAuthFailureCallback;\n    }\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.fitBounds\n   */\n  fitBounds(\n    bounds: google.maps.LatLngBounds | google.maps.LatLngBoundsLiteral,\n    padding?: number | google.maps.Padding,\n  ) {\n    this._assertInitialized();\n    this.googleMap.fitBounds(bounds, padding);\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.panBy\n   */\n  panBy(x: number, y: number) {\n    this._assertInitialized();\n    this.googleMap.panBy(x, y);\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.panTo\n   */\n  panTo(latLng: google.maps.LatLng | google.maps.LatLngLiteral) {\n    this._assertInitialized();\n    this.googleMap.panTo(latLng);\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.panToBounds\n   */\n  panToBounds(\n    latLngBounds: google.maps.LatLngBounds | google.maps.LatLngBoundsLiteral,\n    padding?: number | google.maps.Padding,\n  ) {\n    this._assertInitialized();\n    this.googleMap.panToBounds(latLngBounds, padding);\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getBounds\n   */\n  getBounds(): google.maps.LatLngBounds | null {\n    this._assertInitialized();\n    return this.googleMap.getBounds() || null;\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getCenter\n   */\n  getCenter(): google.maps.LatLng | undefined {\n    this._assertInitialized();\n    return this.googleMap.getCenter();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getClickableIcons\n   */\n  getClickableIcons(): boolean | undefined {\n    this._assertInitialized();\n    return this.googleMap.getClickableIcons();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getHeading\n   */\n  getHeading(): number | undefined {\n    this._assertInitialized();\n    return this.googleMap.getHeading();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getMapTypeId\n   */\n  getMapTypeId(): google.maps.MapTypeId | string | undefined {\n    this._assertInitialized();\n    return this.googleMap.getMapTypeId();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getProjection\n   */\n  getProjection(): google.maps.Projection | null {\n    this._assertInitialized();\n    return this.googleMap.getProjection() || null;\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getStreetView\n   */\n  getStreetView(): google.maps.StreetViewPanorama {\n    this._assertInitialized();\n    return this.googleMap.getStreetView();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getTilt\n   */\n  getTilt(): number | undefined {\n    this._assertInitialized();\n    return this.googleMap.getTilt();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getZoom\n   */\n  getZoom(): number | undefined {\n    this._assertInitialized();\n    return this.googleMap.getZoom();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.controls\n   */\n  get controls(): google.maps.MVCArray<Node>[] {\n    this._assertInitialized();\n    return this.googleMap.controls;\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.data\n   */\n  get data(): google.maps.Data {\n    this._assertInitialized();\n    return this.googleMap.data;\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.mapTypes\n   */\n  get mapTypes(): google.maps.MapTypeRegistry {\n    this._assertInitialized();\n    return this.googleMap.mapTypes;\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.overlayMapTypes\n   */\n  get overlayMapTypes(): google.maps.MVCArray<google.maps.MapType | null> {\n    this._assertInitialized();\n    return this.googleMap.overlayMapTypes;\n  }\n\n  private _setSize() {\n    if (this._mapEl) {\n      const styles = this._mapEl.style;\n      styles.height =\n        this.height === null ? '' : coerceCssPixelValue(this.height) || DEFAULT_HEIGHT;\n      styles.width = this.width === null ? '' : coerceCssPixelValue(this.width) || DEFAULT_WIDTH;\n    }\n  }\n\n  /** Combines the center and zoom and the other map options into a single object */\n  private _combineOptions(): google.maps.MapOptions {\n    const options = this._options || {};\n    return {\n      ...options,\n      // It's important that we set **some** kind of `center` and `zoom`, otherwise\n      // Google Maps will render a blank rectangle which looks broken.\n      center: this._center || options.center || DEFAULT_OPTIONS.center,\n      zoom: this._zoom ?? options.zoom ?? DEFAULT_OPTIONS.zoom,\n      // Passing in an undefined `mapTypeId` seems to break tile loading\n      // so make sure that we have some kind of default (see #22082).\n      mapTypeId: this.mapTypeId || options.mapTypeId || DEFAULT_OPTIONS.mapTypeId,\n    };\n  }\n\n  /** Asserts that the map has been initialized. */\n  private _assertInitialized(): asserts this is {googleMap: google.maps.Map} {\n    if (!this.googleMap && (typeof ngDevMode === 'undefined' || ngDevMode)) {\n      throw Error(\n        'Cannot access Google Map information before the API has been initialized. ' +\n          'Please wait for the API to load before trying to interact with it.',\n      );\n    }\n  }\n}\n\nconst cssUnitsPattern = /([A-Za-z%]+)$/;\n\n/** Coerces a value to a CSS pixel value. */\nfunction coerceCssPixelValue(value: any): string {\n  if (value == null) {\n    return '';\n  }\n\n  return cssUnitsPattern.test(value) ? value : `${value}px`;\n}\n"]}
|