@angular/google-maps 13.0.0-next.7 → 13.0.0-rc.2
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/google-map/google-map.mjs +445 -0
- package/esm2020/google-maps-module.mjs +86 -0
- package/esm2020/google-maps_public_index.mjs +5 -0
- package/esm2020/index.mjs +9 -0
- package/{esm2015/map-anchor-point.js → esm2020/map-anchor-point.mjs} +2 -2
- package/esm2020/map-base-layer.mjs +51 -0
- package/esm2020/map-bicycling-layer/map-bicycling-layer.mjs +48 -0
- package/esm2020/map-circle/map-circle.mjs +268 -0
- package/esm2020/map-directions-renderer/map-directions-renderer.mjs +138 -0
- package/esm2020/map-directions-renderer/map-directions-service.mjs +51 -0
- package/esm2020/map-event-manager.mjs +67 -0
- package/esm2020/map-geocoder/map-geocoder.mjs +47 -0
- package/esm2020/map-ground-overlay/map-ground-overlay.mjs +177 -0
- package/esm2020/map-heatmap-layer/map-heatmap-layer.mjs +135 -0
- package/esm2020/map-info-window/map-info-window.mjs +203 -0
- package/esm2020/map-kml-layer/map-kml-layer.mjs +170 -0
- package/esm2020/map-marker/map-marker.mjs +427 -0
- package/esm2020/map-marker-clusterer/map-marker-clusterer.mjs +407 -0
- package/esm2020/map-marker-clusterer/marker-clusterer-types.mjs +9 -0
- package/esm2020/map-polygon/map-polygon.mjs +216 -0
- package/esm2020/map-polyline/map-polyline.mjs +207 -0
- package/esm2020/map-rectangle/map-rectangle.mjs +229 -0
- package/esm2020/map-traffic-layer/map-traffic-layer.mjs +93 -0
- package/esm2020/map-transit-layer/map-transit-layer.mjs +48 -0
- package/{esm2015/public-api.js → esm2020/public-api.mjs} +0 -0
- package/fesm2015/{google-maps.js → google-maps.mjs} +590 -518
- package/fesm2015/google-maps.mjs.map +1 -0
- package/fesm2020/google-maps.mjs +3257 -0
- package/fesm2020/google-maps.mjs.map +1 -0
- package/google-map/google-map.d.ts +10 -7
- package/google-maps-module.d.ts +20 -7
- package/google-maps_public_index.d.ts +4 -0
- package/index.d.ts +5 -1
- package/map-anchor-point.d.ts +1 -1
- package/map-base-layer.d.ts +3 -0
- package/map-bicycling-layer/map-bicycling-layer.d.ts +4 -8
- package/map-circle/map-circle.d.ts +6 -3
- package/map-directions-renderer/map-directions-renderer.d.ts +6 -3
- package/map-directions-renderer/map-directions-service.d.ts +4 -1
- package/map-event-manager.d.ts +1 -1
- package/map-geocoder/map-geocoder.d.ts +4 -1
- package/map-ground-overlay/map-ground-overlay.d.ts +5 -2
- package/map-heatmap-layer/map-heatmap-layer.d.ts +4 -1
- package/map-info-window/map-info-window.d.ts +5 -2
- package/map-kml-layer/map-kml-layer.d.ts +6 -3
- package/map-marker/map-marker.d.ts +4 -1
- package/map-marker-clusterer/map-marker-clusterer.d.ts +5 -2
- package/map-marker-clusterer/marker-clusterer-types.d.ts +1 -1
- package/map-polygon/map-polygon.d.ts +4 -1
- package/map-polyline/map-polyline.d.ts +4 -1
- package/map-rectangle/map-rectangle.d.ts +5 -2
- package/map-traffic-layer/map-traffic-layer.d.ts +4 -1
- package/map-transit-layer/map-transit-layer.d.ts +4 -8
- package/package.json +23 -9
- package/bundles/google-maps.umd.js +0 -3757
- package/bundles/google-maps.umd.js.map +0 -1
- package/esm2015/google-map/google-map.js +0 -418
- package/esm2015/google-maps-module.js +0 -51
- package/esm2015/google-maps.externs.js +0 -6
- package/esm2015/index.js +0 -5
- package/esm2015/map-base-layer.js +0 -49
- package/esm2015/map-bicycling-layer/map-bicycling-layer.js +0 -43
- package/esm2015/map-circle/map-circle.js +0 -247
- package/esm2015/map-directions-renderer/map-directions-renderer.js +0 -131
- package/esm2015/map-directions-renderer/map-directions-service.js +0 -52
- package/esm2015/map-event-manager.js +0 -67
- package/esm2015/map-geocoder/map-geocoder.js +0 -47
- package/esm2015/map-ground-overlay/map-ground-overlay.js +0 -171
- package/esm2015/map-heatmap-layer/map-heatmap-layer.js +0 -130
- package/esm2015/map-info-window/map-info-window.js +0 -193
- package/esm2015/map-kml-layer/map-kml-layer.js +0 -160
- package/esm2015/map-marker/map-marker.js +0 -391
- package/esm2015/map-marker-clusterer/map-marker-clusterer.js +0 -360
- package/esm2015/map-marker-clusterer/marker-clusterer-types.js +0 -9
- package/esm2015/map-polygon/map-polygon.js +0 -198
- package/esm2015/map-polyline/map-polyline.js +0 -189
- package/esm2015/map-rectangle/map-rectangle.js +0 -210
- package/esm2015/map-traffic-layer/map-traffic-layer.js +0 -88
- package/esm2015/map-transit-layer/map-transit-layer.js +0 -43
- package/fesm2015/google-maps.js.map +0 -1
- package/index.metadata.json +0 -1
|
@@ -1,160 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright Google LLC All Rights Reserved.
|
|
4
|
-
*
|
|
5
|
-
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
-
* found in the LICENSE file at https://angular.io/license
|
|
7
|
-
*/
|
|
8
|
-
// Workaround for: https://github.com/bazelbuild/rules_nodejs/issues/1265
|
|
9
|
-
/// <reference types="googlemaps" />
|
|
10
|
-
import { Directive, Input, NgZone, Output, } from '@angular/core';
|
|
11
|
-
import { BehaviorSubject, combineLatest, Observable, Subject } from 'rxjs';
|
|
12
|
-
import { map, take, takeUntil } from 'rxjs/operators';
|
|
13
|
-
import { GoogleMap } from '../google-map/google-map';
|
|
14
|
-
import { MapEventManager } from '../map-event-manager';
|
|
15
|
-
/**
|
|
16
|
-
* Angular component that renders a Google Maps KML Layer via the Google Maps JavaScript API.
|
|
17
|
-
*
|
|
18
|
-
* See developers.google.com/maps/documentation/javascript/reference/kml#KmlLayer
|
|
19
|
-
*/
|
|
20
|
-
export class MapKmlLayer {
|
|
21
|
-
constructor(_map, _ngZone) {
|
|
22
|
-
this._map = _map;
|
|
23
|
-
this._ngZone = _ngZone;
|
|
24
|
-
this._eventManager = new MapEventManager(this._ngZone);
|
|
25
|
-
this._options = new BehaviorSubject({});
|
|
26
|
-
this._url = new BehaviorSubject('');
|
|
27
|
-
this._destroyed = new Subject();
|
|
28
|
-
/**
|
|
29
|
-
* See developers.google.com/maps/documentation/javascript/reference/kml#KmlLayer.click
|
|
30
|
-
*/
|
|
31
|
-
this.kmlClick = this._eventManager.getLazyEmitter('click');
|
|
32
|
-
/**
|
|
33
|
-
* See
|
|
34
|
-
* developers.google.com/maps/documentation/javascript/reference/kml
|
|
35
|
-
* #KmlLayer.defaultviewport_changed
|
|
36
|
-
*/
|
|
37
|
-
this.defaultviewportChanged = this._eventManager.getLazyEmitter('defaultviewport_changed');
|
|
38
|
-
/**
|
|
39
|
-
* See developers.google.com/maps/documentation/javascript/reference/kml#KmlLayer.status_changed
|
|
40
|
-
*/
|
|
41
|
-
this.statusChanged = this._eventManager.getLazyEmitter('status_changed');
|
|
42
|
-
}
|
|
43
|
-
set options(options) {
|
|
44
|
-
this._options.next(options || {});
|
|
45
|
-
}
|
|
46
|
-
set url(url) {
|
|
47
|
-
this._url.next(url);
|
|
48
|
-
}
|
|
49
|
-
ngOnInit() {
|
|
50
|
-
if (this._map._isBrowser) {
|
|
51
|
-
this._combineOptions().pipe(take(1)).subscribe(options => {
|
|
52
|
-
// Create the object outside the zone so its events don't trigger change detection.
|
|
53
|
-
// We'll bring it back in inside the `MapEventManager` only for the events that the
|
|
54
|
-
// user has subscribed to.
|
|
55
|
-
this._ngZone.runOutsideAngular(() => this.kmlLayer = new google.maps.KmlLayer(options));
|
|
56
|
-
this._assertInitialized();
|
|
57
|
-
this.kmlLayer.setMap(this._map.googleMap);
|
|
58
|
-
this._eventManager.setTarget(this.kmlLayer);
|
|
59
|
-
});
|
|
60
|
-
this._watchForOptionsChanges();
|
|
61
|
-
this._watchForUrlChanges();
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
ngOnDestroy() {
|
|
65
|
-
this._eventManager.destroy();
|
|
66
|
-
this._destroyed.next();
|
|
67
|
-
this._destroyed.complete();
|
|
68
|
-
if (this.kmlLayer) {
|
|
69
|
-
this.kmlLayer.setMap(null);
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
/**
|
|
73
|
-
* See
|
|
74
|
-
* developers.google.com/maps/documentation/javascript/reference/kml#KmlLayer.getDefaultViewport
|
|
75
|
-
*/
|
|
76
|
-
getDefaultViewport() {
|
|
77
|
-
this._assertInitialized();
|
|
78
|
-
return this.kmlLayer.getDefaultViewport();
|
|
79
|
-
}
|
|
80
|
-
/**
|
|
81
|
-
* See developers.google.com/maps/documentation/javascript/reference/kml#KmlLayer.getMetadata
|
|
82
|
-
*/
|
|
83
|
-
getMetadata() {
|
|
84
|
-
this._assertInitialized();
|
|
85
|
-
return this.kmlLayer.getMetadata();
|
|
86
|
-
}
|
|
87
|
-
/**
|
|
88
|
-
* See developers.google.com/maps/documentation/javascript/reference/kml#KmlLayer.getStatus
|
|
89
|
-
*/
|
|
90
|
-
getStatus() {
|
|
91
|
-
this._assertInitialized();
|
|
92
|
-
return this.kmlLayer.getStatus();
|
|
93
|
-
}
|
|
94
|
-
/**
|
|
95
|
-
* See developers.google.com/maps/documentation/javascript/reference/kml#KmlLayer.getUrl
|
|
96
|
-
*/
|
|
97
|
-
getUrl() {
|
|
98
|
-
this._assertInitialized();
|
|
99
|
-
return this.kmlLayer.getUrl();
|
|
100
|
-
}
|
|
101
|
-
/**
|
|
102
|
-
* See developers.google.com/maps/documentation/javascript/reference/kml#KmlLayer.getZIndex
|
|
103
|
-
*/
|
|
104
|
-
getZIndex() {
|
|
105
|
-
this._assertInitialized();
|
|
106
|
-
return this.kmlLayer.getZIndex();
|
|
107
|
-
}
|
|
108
|
-
_combineOptions() {
|
|
109
|
-
return combineLatest([this._options, this._url]).pipe(map(([options, url]) => {
|
|
110
|
-
const combinedOptions = Object.assign(Object.assign({}, options), { url: url || options.url });
|
|
111
|
-
return combinedOptions;
|
|
112
|
-
}));
|
|
113
|
-
}
|
|
114
|
-
_watchForOptionsChanges() {
|
|
115
|
-
this._options.pipe(takeUntil(this._destroyed)).subscribe(options => {
|
|
116
|
-
if (this.kmlLayer) {
|
|
117
|
-
this._assertInitialized();
|
|
118
|
-
this.kmlLayer.setOptions(options);
|
|
119
|
-
}
|
|
120
|
-
});
|
|
121
|
-
}
|
|
122
|
-
_watchForUrlChanges() {
|
|
123
|
-
this._url.pipe(takeUntil(this._destroyed)).subscribe(url => {
|
|
124
|
-
if (url && this.kmlLayer) {
|
|
125
|
-
this._assertInitialized();
|
|
126
|
-
this.kmlLayer.setUrl(url);
|
|
127
|
-
}
|
|
128
|
-
});
|
|
129
|
-
}
|
|
130
|
-
_assertInitialized() {
|
|
131
|
-
if (typeof ngDevMode === 'undefined' || ngDevMode) {
|
|
132
|
-
if (!this._map.googleMap) {
|
|
133
|
-
throw Error('Cannot access Google Map information before the API has been initialized. ' +
|
|
134
|
-
'Please wait for the API to load before trying to interact with it.');
|
|
135
|
-
}
|
|
136
|
-
if (!this.kmlLayer) {
|
|
137
|
-
throw Error('Cannot interact with a Google Map KmlLayer before it has been ' +
|
|
138
|
-
'initialized. Please wait for the KmlLayer to load before trying to interact with it.');
|
|
139
|
-
}
|
|
140
|
-
}
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
MapKmlLayer.decorators = [
|
|
144
|
-
{ type: Directive, args: [{
|
|
145
|
-
selector: 'map-kml-layer',
|
|
146
|
-
exportAs: 'mapKmlLayer',
|
|
147
|
-
},] }
|
|
148
|
-
];
|
|
149
|
-
MapKmlLayer.ctorParameters = () => [
|
|
150
|
-
{ type: GoogleMap },
|
|
151
|
-
{ type: NgZone }
|
|
152
|
-
];
|
|
153
|
-
MapKmlLayer.propDecorators = {
|
|
154
|
-
options: [{ type: Input }],
|
|
155
|
-
url: [{ type: Input }],
|
|
156
|
-
kmlClick: [{ type: Output }],
|
|
157
|
-
defaultviewportChanged: [{ type: Output }],
|
|
158
|
-
statusChanged: [{ type: Output }]
|
|
159
|
-
};
|
|
160
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-kml-layer.js","sourceRoot":"","sources":["../../../../../../src/google-maps/map-kml-layer/map-kml-layer.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=\"googlemaps\" />\n\nimport {\n  Directive,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Output,\n} from '@angular/core';\nimport {BehaviorSubject, combineLatest, Observable, Subject} from 'rxjs';\nimport {map, take, takeUntil} from 'rxjs/operators';\n\nimport {GoogleMap} from '../google-map/google-map';\nimport {MapEventManager} from '../map-event-manager';\n\n/**\n * Angular component that renders a Google Maps KML Layer via the Google Maps JavaScript API.\n *\n * See developers.google.com/maps/documentation/javascript/reference/kml#KmlLayer\n */\n@Directive({\n  selector: 'map-kml-layer',\n  exportAs: 'mapKmlLayer',\n})\nexport class MapKmlLayer implements OnInit, OnDestroy {\n  private _eventManager = new MapEventManager(this._ngZone);\n  private readonly _options = new BehaviorSubject<google.maps.KmlLayerOptions>({});\n  private readonly _url = new BehaviorSubject<string>('');\n\n  private readonly _destroyed = new Subject<void>();\n\n  /**\n   * The underlying google.maps.KmlLayer object.\n   *\n   * See developers.google.com/maps/documentation/javascript/reference/kml#KmlLayer\n   */\n  kmlLayer?: google.maps.KmlLayer;\n\n  @Input()\n  set options(options: google.maps.KmlLayerOptions) {\n    this._options.next(options || {});\n  }\n\n  @Input()\n  set url(url: string) {\n    this._url.next(url);\n  }\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/kml#KmlLayer.click\n   */\n  @Output() readonly kmlClick: Observable<google.maps.KmlMouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.KmlMouseEvent>('click');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/kml\n   * #KmlLayer.defaultviewport_changed\n   */\n  @Output() readonly defaultviewportChanged: Observable<void> =\n      this._eventManager.getLazyEmitter<void>('defaultviewport_changed');\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/kml#KmlLayer.status_changed\n   */\n  @Output() readonly statusChanged: Observable<void> =\n      this._eventManager.getLazyEmitter<void>('status_changed');\n\n  constructor(private readonly _map: GoogleMap, private _ngZone: NgZone) {}\n\n  ngOnInit() {\n    if (this._map._isBrowser) {\n      this._combineOptions().pipe(take(1)).subscribe(options => {\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(() => this.kmlLayer = new google.maps.KmlLayer(options));\n        this._assertInitialized();\n        this.kmlLayer.setMap(this._map.googleMap!);\n        this._eventManager.setTarget(this.kmlLayer);\n      });\n\n      this._watchForOptionsChanges();\n      this._watchForUrlChanges();\n    }\n  }\n\n  ngOnDestroy() {\n    this._eventManager.destroy();\n    this._destroyed.next();\n    this._destroyed.complete();\n    if (this.kmlLayer) {\n      this.kmlLayer.setMap(null);\n    }\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/kml#KmlLayer.getDefaultViewport\n   */\n  getDefaultViewport(): google.maps.LatLngBounds {\n    this._assertInitialized();\n    return this.kmlLayer.getDefaultViewport();\n  }\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/kml#KmlLayer.getMetadata\n   */\n  getMetadata(): google.maps.KmlLayerMetadata {\n    this._assertInitialized();\n    return this.kmlLayer.getMetadata();\n  }\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/kml#KmlLayer.getStatus\n   */\n  getStatus(): google.maps.KmlLayerStatus {\n    this._assertInitialized();\n    return this.kmlLayer.getStatus();\n  }\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/kml#KmlLayer.getUrl\n   */\n  getUrl(): string {\n    this._assertInitialized();\n    return this.kmlLayer.getUrl();\n  }\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/kml#KmlLayer.getZIndex\n   */\n  getZIndex(): number {\n    this._assertInitialized();\n    return this.kmlLayer.getZIndex();\n  }\n\n  private _combineOptions(): Observable<google.maps.KmlLayerOptions> {\n    return combineLatest([this._options, this._url]).pipe(map(([options, url]) => {\n      const combinedOptions: google.maps.KmlLayerOptions = {\n        ...options,\n        url: url || options.url,\n      };\n      return combinedOptions;\n    }));\n  }\n\n  private _watchForOptionsChanges() {\n    this._options.pipe(takeUntil(this._destroyed)).subscribe(options => {\n      if (this.kmlLayer) {\n        this._assertInitialized();\n        this.kmlLayer.setOptions(options);\n      }\n    });\n  }\n\n  private _watchForUrlChanges() {\n    this._url.pipe(takeUntil(this._destroyed)).subscribe(url => {\n      if (url && this.kmlLayer) {\n        this._assertInitialized();\n        this.kmlLayer.setUrl(url);\n      }\n    });\n  }\n\n  private _assertInitialized(): asserts this is { kmlLayer: google.maps.KmlLayer } {\n    if (typeof ngDevMode === 'undefined' || ngDevMode) {\n      if (!this._map.googleMap) {\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      if (!this.kmlLayer) {\n        throw Error(\n            'Cannot interact with a Google Map KmlLayer before it has been ' +\n            'initialized. Please wait for the KmlLayer to load before trying to interact with it.');\n      }\n    }\n  }\n}\n"]}
|
|
@@ -1,391 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright Google LLC All Rights Reserved.
|
|
4
|
-
*
|
|
5
|
-
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
-
* found in the LICENSE file at https://angular.io/license
|
|
7
|
-
*/
|
|
8
|
-
// Workaround for: https://github.com/bazelbuild/rules_nodejs/issues/1265
|
|
9
|
-
/// <reference types="googlemaps" />
|
|
10
|
-
import { Input, Output, NgZone, Directive, } from '@angular/core';
|
|
11
|
-
import { Observable } from 'rxjs';
|
|
12
|
-
import { GoogleMap } from '../google-map/google-map';
|
|
13
|
-
import { MapEventManager } from '../map-event-manager';
|
|
14
|
-
/**
|
|
15
|
-
* Default options for the Google Maps marker component. Displays a marker
|
|
16
|
-
* at the Googleplex.
|
|
17
|
-
*/
|
|
18
|
-
export const DEFAULT_MARKER_OPTIONS = {
|
|
19
|
-
position: { lat: 37.421995, lng: -122.084092 },
|
|
20
|
-
};
|
|
21
|
-
/**
|
|
22
|
-
* Angular component that renders a Google Maps marker via the Google Maps JavaScript API.
|
|
23
|
-
*
|
|
24
|
-
* See developers.google.com/maps/documentation/javascript/reference/marker
|
|
25
|
-
*/
|
|
26
|
-
export class MapMarker {
|
|
27
|
-
constructor(_googleMap, _ngZone) {
|
|
28
|
-
this._googleMap = _googleMap;
|
|
29
|
-
this._ngZone = _ngZone;
|
|
30
|
-
this._eventManager = new MapEventManager(this._ngZone);
|
|
31
|
-
/**
|
|
32
|
-
* See
|
|
33
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.animation_changed
|
|
34
|
-
*/
|
|
35
|
-
this.animationChanged = this._eventManager.getLazyEmitter('animation_changed');
|
|
36
|
-
/**
|
|
37
|
-
* See
|
|
38
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.click
|
|
39
|
-
*/
|
|
40
|
-
this.mapClick = this._eventManager.getLazyEmitter('click');
|
|
41
|
-
/**
|
|
42
|
-
* See
|
|
43
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.clickable_changed
|
|
44
|
-
*/
|
|
45
|
-
this.clickableChanged = this._eventManager.getLazyEmitter('clickable_changed');
|
|
46
|
-
/**
|
|
47
|
-
* See
|
|
48
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.cursor_changed
|
|
49
|
-
*/
|
|
50
|
-
this.cursorChanged = this._eventManager.getLazyEmitter('cursor_changed');
|
|
51
|
-
/**
|
|
52
|
-
* See
|
|
53
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.dblclick
|
|
54
|
-
*/
|
|
55
|
-
this.mapDblclick = this._eventManager.getLazyEmitter('dblclick');
|
|
56
|
-
/**
|
|
57
|
-
* See
|
|
58
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.drag
|
|
59
|
-
*/
|
|
60
|
-
this.mapDrag = this._eventManager.getLazyEmitter('drag');
|
|
61
|
-
/**
|
|
62
|
-
* See
|
|
63
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.dragend
|
|
64
|
-
*/
|
|
65
|
-
this.mapDragend = this._eventManager.getLazyEmitter('dragend');
|
|
66
|
-
/**
|
|
67
|
-
* See
|
|
68
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.draggable_changed
|
|
69
|
-
*/
|
|
70
|
-
this.draggableChanged = this._eventManager.getLazyEmitter('draggable_changed');
|
|
71
|
-
/**
|
|
72
|
-
* See
|
|
73
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.dragstart
|
|
74
|
-
*/
|
|
75
|
-
this.mapDragstart = this._eventManager.getLazyEmitter('dragstart');
|
|
76
|
-
/**
|
|
77
|
-
* See
|
|
78
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.flat_changed
|
|
79
|
-
*/
|
|
80
|
-
this.flatChanged = this._eventManager.getLazyEmitter('flat_changed');
|
|
81
|
-
/**
|
|
82
|
-
* See
|
|
83
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.icon_changed
|
|
84
|
-
*/
|
|
85
|
-
this.iconChanged = this._eventManager.getLazyEmitter('icon_changed');
|
|
86
|
-
/**
|
|
87
|
-
* See
|
|
88
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.mousedown
|
|
89
|
-
*/
|
|
90
|
-
this.mapMousedown = this._eventManager.getLazyEmitter('mousedown');
|
|
91
|
-
/**
|
|
92
|
-
* See
|
|
93
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.mouseout
|
|
94
|
-
*/
|
|
95
|
-
this.mapMouseout = this._eventManager.getLazyEmitter('mouseout');
|
|
96
|
-
/**
|
|
97
|
-
* See
|
|
98
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.mouseover
|
|
99
|
-
*/
|
|
100
|
-
this.mapMouseover = this._eventManager.getLazyEmitter('mouseover');
|
|
101
|
-
/**
|
|
102
|
-
* See
|
|
103
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.mouseup
|
|
104
|
-
*/
|
|
105
|
-
this.mapMouseup = this._eventManager.getLazyEmitter('mouseup');
|
|
106
|
-
/**
|
|
107
|
-
* See
|
|
108
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.position_changed
|
|
109
|
-
*/
|
|
110
|
-
this.positionChanged = this._eventManager.getLazyEmitter('position_changed');
|
|
111
|
-
/**
|
|
112
|
-
* See
|
|
113
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.rightclick
|
|
114
|
-
*/
|
|
115
|
-
this.mapRightclick = this._eventManager.getLazyEmitter('rightclick');
|
|
116
|
-
/**
|
|
117
|
-
* See
|
|
118
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.shape_changed
|
|
119
|
-
*/
|
|
120
|
-
this.shapeChanged = this._eventManager.getLazyEmitter('shape_changed');
|
|
121
|
-
/**
|
|
122
|
-
* See
|
|
123
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.title_changed
|
|
124
|
-
*/
|
|
125
|
-
this.titleChanged = this._eventManager.getLazyEmitter('title_changed');
|
|
126
|
-
/**
|
|
127
|
-
* See
|
|
128
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.visible_changed
|
|
129
|
-
*/
|
|
130
|
-
this.visibleChanged = this._eventManager.getLazyEmitter('visible_changed');
|
|
131
|
-
/**
|
|
132
|
-
* See
|
|
133
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.zindex_changed
|
|
134
|
-
*/
|
|
135
|
-
this.zindexChanged = this._eventManager.getLazyEmitter('zindex_changed');
|
|
136
|
-
}
|
|
137
|
-
/**
|
|
138
|
-
* Title of the marker.
|
|
139
|
-
* See: developers.google.com/maps/documentation/javascript/reference/marker#MarkerOptions.title
|
|
140
|
-
*/
|
|
141
|
-
set title(title) {
|
|
142
|
-
this._title = title;
|
|
143
|
-
}
|
|
144
|
-
/**
|
|
145
|
-
* Position of the marker. See:
|
|
146
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#MarkerOptions.position
|
|
147
|
-
*/
|
|
148
|
-
set position(position) {
|
|
149
|
-
this._position = position;
|
|
150
|
-
}
|
|
151
|
-
/**
|
|
152
|
-
* Label for the marker.
|
|
153
|
-
* See: developers.google.com/maps/documentation/javascript/reference/marker#MarkerOptions.label
|
|
154
|
-
*/
|
|
155
|
-
set label(label) {
|
|
156
|
-
this._label = label;
|
|
157
|
-
}
|
|
158
|
-
/**
|
|
159
|
-
* Whether the marker is clickable. See:
|
|
160
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#MarkerOptions.clickable
|
|
161
|
-
*/
|
|
162
|
-
set clickable(clickable) {
|
|
163
|
-
this._clickable = clickable;
|
|
164
|
-
}
|
|
165
|
-
/**
|
|
166
|
-
* Options used to configure the marker.
|
|
167
|
-
* See: developers.google.com/maps/documentation/javascript/reference/marker#MarkerOptions
|
|
168
|
-
*/
|
|
169
|
-
set options(options) {
|
|
170
|
-
this._options = options;
|
|
171
|
-
}
|
|
172
|
-
/**
|
|
173
|
-
* Icon to be used for the marker.
|
|
174
|
-
* See: https://developers.google.com/maps/documentation/javascript/reference/marker#Icon
|
|
175
|
-
*/
|
|
176
|
-
set icon(icon) {
|
|
177
|
-
this._icon = icon;
|
|
178
|
-
}
|
|
179
|
-
/**
|
|
180
|
-
* Whether the marker is visible.
|
|
181
|
-
* See: developers.google.com/maps/documentation/javascript/reference/marker#MarkerOptions.visible
|
|
182
|
-
*/
|
|
183
|
-
set visible(value) {
|
|
184
|
-
this._visible = value;
|
|
185
|
-
}
|
|
186
|
-
ngOnInit() {
|
|
187
|
-
if (this._googleMap._isBrowser) {
|
|
188
|
-
// Create the object outside the zone so its events don't trigger change detection.
|
|
189
|
-
// We'll bring it back in inside the `MapEventManager` only for the events that the
|
|
190
|
-
// user has subscribed to.
|
|
191
|
-
this._ngZone.runOutsideAngular(() => {
|
|
192
|
-
this.marker = new google.maps.Marker(this._combineOptions());
|
|
193
|
-
});
|
|
194
|
-
this._assertInitialized();
|
|
195
|
-
this.marker.setMap(this._googleMap.googleMap);
|
|
196
|
-
this._eventManager.setTarget(this.marker);
|
|
197
|
-
}
|
|
198
|
-
}
|
|
199
|
-
ngOnChanges(changes) {
|
|
200
|
-
const { marker, _title, _position, _label, _clickable, _icon, _visible } = this;
|
|
201
|
-
if (marker) {
|
|
202
|
-
if (changes['options']) {
|
|
203
|
-
marker.setOptions(this._combineOptions());
|
|
204
|
-
}
|
|
205
|
-
if (changes['title'] && _title !== undefined) {
|
|
206
|
-
marker.setTitle(_title);
|
|
207
|
-
}
|
|
208
|
-
if (changes['position'] && _position) {
|
|
209
|
-
marker.setPosition(_position);
|
|
210
|
-
}
|
|
211
|
-
if (changes['label'] && _label !== undefined) {
|
|
212
|
-
marker.setLabel(_label);
|
|
213
|
-
}
|
|
214
|
-
if (changes['clickable'] && _clickable !== undefined) {
|
|
215
|
-
marker.setClickable(_clickable);
|
|
216
|
-
}
|
|
217
|
-
if (changes['icon'] && _icon) {
|
|
218
|
-
marker.setIcon(_icon);
|
|
219
|
-
}
|
|
220
|
-
if (changes['visible'] && _visible !== undefined) {
|
|
221
|
-
marker.setVisible(_visible);
|
|
222
|
-
}
|
|
223
|
-
}
|
|
224
|
-
}
|
|
225
|
-
ngOnDestroy() {
|
|
226
|
-
this._eventManager.destroy();
|
|
227
|
-
if (this.marker) {
|
|
228
|
-
this.marker.setMap(null);
|
|
229
|
-
}
|
|
230
|
-
}
|
|
231
|
-
/**
|
|
232
|
-
* See
|
|
233
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.getAnimation
|
|
234
|
-
*/
|
|
235
|
-
getAnimation() {
|
|
236
|
-
this._assertInitialized();
|
|
237
|
-
return this.marker.getAnimation() || null;
|
|
238
|
-
}
|
|
239
|
-
/**
|
|
240
|
-
* See
|
|
241
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.getClickable
|
|
242
|
-
*/
|
|
243
|
-
getClickable() {
|
|
244
|
-
this._assertInitialized();
|
|
245
|
-
return this.marker.getClickable();
|
|
246
|
-
}
|
|
247
|
-
/**
|
|
248
|
-
* See
|
|
249
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.getCursor
|
|
250
|
-
*/
|
|
251
|
-
getCursor() {
|
|
252
|
-
this._assertInitialized();
|
|
253
|
-
return this.marker.getCursor() || null;
|
|
254
|
-
}
|
|
255
|
-
/**
|
|
256
|
-
* See
|
|
257
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.getDraggable
|
|
258
|
-
*/
|
|
259
|
-
getDraggable() {
|
|
260
|
-
this._assertInitialized();
|
|
261
|
-
return !!this.marker.getDraggable();
|
|
262
|
-
}
|
|
263
|
-
/**
|
|
264
|
-
* See
|
|
265
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.getIcon
|
|
266
|
-
*/
|
|
267
|
-
getIcon() {
|
|
268
|
-
this._assertInitialized();
|
|
269
|
-
return this.marker.getIcon() || null;
|
|
270
|
-
}
|
|
271
|
-
/**
|
|
272
|
-
* See
|
|
273
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.getLabel
|
|
274
|
-
*/
|
|
275
|
-
getLabel() {
|
|
276
|
-
this._assertInitialized();
|
|
277
|
-
return this.marker.getLabel() || null;
|
|
278
|
-
}
|
|
279
|
-
/**
|
|
280
|
-
* See
|
|
281
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.getOpacity
|
|
282
|
-
*/
|
|
283
|
-
getOpacity() {
|
|
284
|
-
this._assertInitialized();
|
|
285
|
-
return this.marker.getOpacity() || null;
|
|
286
|
-
}
|
|
287
|
-
/**
|
|
288
|
-
* See
|
|
289
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.getPosition
|
|
290
|
-
*/
|
|
291
|
-
getPosition() {
|
|
292
|
-
this._assertInitialized();
|
|
293
|
-
return this.marker.getPosition() || null;
|
|
294
|
-
}
|
|
295
|
-
/**
|
|
296
|
-
* See
|
|
297
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.getShape
|
|
298
|
-
*/
|
|
299
|
-
getShape() {
|
|
300
|
-
this._assertInitialized();
|
|
301
|
-
return this.marker.getShape() || null;
|
|
302
|
-
}
|
|
303
|
-
/**
|
|
304
|
-
* See
|
|
305
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.getTitle
|
|
306
|
-
*/
|
|
307
|
-
getTitle() {
|
|
308
|
-
this._assertInitialized();
|
|
309
|
-
return this.marker.getTitle() || null;
|
|
310
|
-
}
|
|
311
|
-
/**
|
|
312
|
-
* See
|
|
313
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.getVisible
|
|
314
|
-
*/
|
|
315
|
-
getVisible() {
|
|
316
|
-
this._assertInitialized();
|
|
317
|
-
return this.marker.getVisible();
|
|
318
|
-
}
|
|
319
|
-
/**
|
|
320
|
-
* See
|
|
321
|
-
* developers.google.com/maps/documentation/javascript/reference/marker#Marker.getZIndex
|
|
322
|
-
*/
|
|
323
|
-
getZIndex() {
|
|
324
|
-
this._assertInitialized();
|
|
325
|
-
return this.marker.getZIndex() || null;
|
|
326
|
-
}
|
|
327
|
-
/** Gets the anchor point that can be used to attach other Google Maps objects. */
|
|
328
|
-
getAnchor() {
|
|
329
|
-
this._assertInitialized();
|
|
330
|
-
return this.marker;
|
|
331
|
-
}
|
|
332
|
-
/** Creates a combined options object using the passed-in options and the individual inputs. */
|
|
333
|
-
_combineOptions() {
|
|
334
|
-
var _a, _b;
|
|
335
|
-
const options = this._options || DEFAULT_MARKER_OPTIONS;
|
|
336
|
-
return Object.assign(Object.assign({}, options), { title: this._title || options.title, position: this._position || options.position, label: this._label || options.label, clickable: (_a = this._clickable) !== null && _a !== void 0 ? _a : options.clickable, map: this._googleMap.googleMap, icon: this._icon || options.icon, visible: (_b = this._visible) !== null && _b !== void 0 ? _b : options.visible });
|
|
337
|
-
}
|
|
338
|
-
_assertInitialized() {
|
|
339
|
-
if (typeof ngDevMode === 'undefined' || ngDevMode) {
|
|
340
|
-
if (!this._googleMap.googleMap) {
|
|
341
|
-
throw Error('Cannot access Google Map information before the API has been initialized. ' +
|
|
342
|
-
'Please wait for the API to load before trying to interact with it.');
|
|
343
|
-
}
|
|
344
|
-
if (!this.marker) {
|
|
345
|
-
throw Error('Cannot interact with a Google Map Marker before it has been ' +
|
|
346
|
-
'initialized. Please wait for the Marker to load before trying to interact with it.');
|
|
347
|
-
}
|
|
348
|
-
}
|
|
349
|
-
}
|
|
350
|
-
}
|
|
351
|
-
MapMarker.decorators = [
|
|
352
|
-
{ type: Directive, args: [{
|
|
353
|
-
selector: 'map-marker',
|
|
354
|
-
exportAs: 'mapMarker',
|
|
355
|
-
},] }
|
|
356
|
-
];
|
|
357
|
-
MapMarker.ctorParameters = () => [
|
|
358
|
-
{ type: GoogleMap },
|
|
359
|
-
{ type: NgZone }
|
|
360
|
-
];
|
|
361
|
-
MapMarker.propDecorators = {
|
|
362
|
-
title: [{ type: Input }],
|
|
363
|
-
position: [{ type: Input }],
|
|
364
|
-
label: [{ type: Input }],
|
|
365
|
-
clickable: [{ type: Input }],
|
|
366
|
-
options: [{ type: Input }],
|
|
367
|
-
icon: [{ type: Input }],
|
|
368
|
-
visible: [{ type: Input }],
|
|
369
|
-
animationChanged: [{ type: Output }],
|
|
370
|
-
mapClick: [{ type: Output }],
|
|
371
|
-
clickableChanged: [{ type: Output }],
|
|
372
|
-
cursorChanged: [{ type: Output }],
|
|
373
|
-
mapDblclick: [{ type: Output }],
|
|
374
|
-
mapDrag: [{ type: Output }],
|
|
375
|
-
mapDragend: [{ type: Output }],
|
|
376
|
-
draggableChanged: [{ type: Output }],
|
|
377
|
-
mapDragstart: [{ type: Output }],
|
|
378
|
-
flatChanged: [{ type: Output }],
|
|
379
|
-
iconChanged: [{ type: Output }],
|
|
380
|
-
mapMousedown: [{ type: Output }],
|
|
381
|
-
mapMouseout: [{ type: Output }],
|
|
382
|
-
mapMouseover: [{ type: Output }],
|
|
383
|
-
mapMouseup: [{ type: Output }],
|
|
384
|
-
positionChanged: [{ type: Output }],
|
|
385
|
-
mapRightclick: [{ type: Output }],
|
|
386
|
-
shapeChanged: [{ type: Output }],
|
|
387
|
-
titleChanged: [{ type: Output }],
|
|
388
|
-
visibleChanged: [{ type: Output }],
|
|
389
|
-
zindexChanged: [{ type: Output }]
|
|
390
|
-
};
|
|
391
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-marker.js","sourceRoot":"","sources":["../../../../../../src/google-maps/map-marker/map-marker.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=\"googlemaps\" />\n\nimport {\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  NgZone,\n  Directive,\n  OnChanges,\n  SimpleChanges,\n} from '@angular/core';\nimport {Observable} from 'rxjs';\n\nimport {GoogleMap} from '../google-map/google-map';\nimport {MapEventManager} from '../map-event-manager';\nimport {MapAnchorPoint} from '../map-anchor-point';\n\n/**\n * Default options for the Google Maps marker component. Displays a marker\n * at the Googleplex.\n */\nexport const DEFAULT_MARKER_OPTIONS = {\n  position: {lat: 37.421995, lng: -122.084092},\n};\n\n/**\n * Angular component that renders a Google Maps marker via the Google Maps JavaScript API.\n *\n * See developers.google.com/maps/documentation/javascript/reference/marker\n */\n@Directive({\n  selector: 'map-marker',\n  exportAs: 'mapMarker',\n})\nexport class MapMarker implements OnInit, OnChanges, OnDestroy, MapAnchorPoint {\n  private _eventManager = new MapEventManager(this._ngZone);\n\n  /**\n   * Title of the marker.\n   * See: developers.google.com/maps/documentation/javascript/reference/marker#MarkerOptions.title\n   */\n  @Input()\n  set title(title: string) {\n    this._title = title;\n  }\n  private _title: string;\n\n  /**\n   * Position of the marker. See:\n   * developers.google.com/maps/documentation/javascript/reference/marker#MarkerOptions.position\n   */\n  @Input()\n  set position(position: google.maps.LatLngLiteral|google.maps.LatLng) {\n    this._position = position;\n  }\n  private _position: google.maps.LatLngLiteral|google.maps.LatLng;\n\n  /**\n   * Label for the marker.\n   * See: developers.google.com/maps/documentation/javascript/reference/marker#MarkerOptions.label\n   */\n  @Input()\n  set label(label: string|google.maps.MarkerLabel) {\n    this._label = label;\n  }\n  private _label: string|google.maps.MarkerLabel;\n\n  /**\n   * Whether the marker is clickable. See:\n   * developers.google.com/maps/documentation/javascript/reference/marker#MarkerOptions.clickable\n   */\n  @Input()\n  set clickable(clickable: boolean) {\n    this._clickable = clickable;\n  }\n  private _clickable: boolean;\n\n  /**\n   * Options used to configure the marker.\n   * See: developers.google.com/maps/documentation/javascript/reference/marker#MarkerOptions\n   */\n  @Input()\n  set options(options: google.maps.MarkerOptions) {\n    this._options = options;\n  }\n  private _options: google.maps.MarkerOptions;\n\n  /**\n   * Icon to be used for the marker.\n   * See: https://developers.google.com/maps/documentation/javascript/reference/marker#Icon\n   */\n  @Input()\n  set icon(icon: string | google.maps.Icon | google.maps.Symbol) {\n    this._icon = icon;\n  }\n  private _icon: string | google.maps.Icon | google.maps.Symbol;\n\n  /**\n   * Whether the marker is visible.\n   * See: developers.google.com/maps/documentation/javascript/reference/marker#MarkerOptions.visible\n   */\n  @Input()\n  set visible(value: boolean) {\n    this._visible = value;\n  }\n  private _visible: boolean;\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.animation_changed\n   */\n  @Output() readonly animationChanged: Observable<void> =\n      this._eventManager.getLazyEmitter<void>('animation_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.click\n   */\n  @Output() readonly mapClick: Observable<google.maps.MapMouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('click');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.clickable_changed\n   */\n  @Output() readonly clickableChanged: Observable<void> =\n      this._eventManager.getLazyEmitter<void>('clickable_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.cursor_changed\n   */\n  @Output() readonly cursorChanged: Observable<void> =\n      this._eventManager.getLazyEmitter<void>('cursor_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.dblclick\n   */\n  @Output() readonly mapDblclick: Observable<google.maps.MapMouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('dblclick');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.drag\n   */\n  @Output() readonly mapDrag: Observable<google.maps.MapMouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('drag');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.dragend\n   */\n  @Output() readonly mapDragend: Observable<google.maps.MapMouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('dragend');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.draggable_changed\n   */\n  @Output() readonly draggableChanged: Observable<void> =\n      this._eventManager.getLazyEmitter<void>('draggable_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.dragstart\n   */\n  @Output() readonly mapDragstart: Observable<google.maps.MapMouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('dragstart');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.flat_changed\n   */\n  @Output() readonly flatChanged: Observable<void> =\n      this._eventManager.getLazyEmitter<void>('flat_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.icon_changed\n   */\n  @Output() readonly iconChanged: Observable<void> =\n      this._eventManager.getLazyEmitter<void>('icon_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.mousedown\n   */\n  @Output() readonly mapMousedown: Observable<google.maps.MapMouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('mousedown');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.mouseout\n   */\n  @Output() readonly mapMouseout: Observable<google.maps.MapMouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('mouseout');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.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/marker#Marker.mouseup\n   */\n  @Output() readonly mapMouseup: Observable<google.maps.MapMouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('mouseup');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.position_changed\n   */\n  @Output() readonly positionChanged: Observable<void> =\n      this._eventManager.getLazyEmitter<void>('position_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.rightclick\n   */\n  @Output() readonly mapRightclick: Observable<google.maps.MapMouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('rightclick');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.shape_changed\n   */\n  @Output() readonly shapeChanged: Observable<void> =\n      this._eventManager.getLazyEmitter<void>('shape_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.title_changed\n   */\n  @Output() readonly titleChanged: Observable<void> =\n      this._eventManager.getLazyEmitter<void>('title_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.visible_changed\n   */\n  @Output() readonly visibleChanged: Observable<void> =\n      this._eventManager.getLazyEmitter<void>('visible_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.zindex_changed\n   */\n  @Output() readonly zindexChanged: Observable<void> =\n      this._eventManager.getLazyEmitter<void>('zindex_changed');\n\n  /**\n   * The underlying google.maps.Marker object.\n   *\n   * See developers.google.com/maps/documentation/javascript/reference/marker#Marker\n   */\n  marker?: google.maps.Marker;\n\n  constructor(\n    private readonly _googleMap: GoogleMap,\n    private _ngZone: NgZone) {}\n\n  ngOnInit() {\n    if (this._googleMap._isBrowser) {\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.marker = new google.maps.Marker(this._combineOptions());\n      });\n      this._assertInitialized();\n      this.marker.setMap(this._googleMap.googleMap!);\n      this._eventManager.setTarget(this.marker);\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const {marker, _title, _position, _label, _clickable, _icon, _visible} = this;\n\n    if (marker) {\n      if (changes['options']) {\n        marker.setOptions(this._combineOptions());\n      }\n\n      if (changes['title'] && _title !== undefined) {\n        marker.setTitle(_title);\n      }\n\n      if (changes['position'] && _position) {\n        marker.setPosition(_position);\n      }\n\n      if (changes['label'] && _label !== undefined) {\n        marker.setLabel(_label);\n      }\n\n      if (changes['clickable'] && _clickable !== undefined) {\n        marker.setClickable(_clickable);\n      }\n\n      if (changes['icon'] && _icon) {\n        marker.setIcon(_icon);\n      }\n\n      if (changes['visible'] && _visible !== undefined) {\n        marker.setVisible(_visible);\n      }\n    }\n  }\n\n  ngOnDestroy() {\n    this._eventManager.destroy();\n    if (this.marker) {\n      this.marker.setMap(null);\n    }\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getAnimation\n   */\n  getAnimation(): google.maps.Animation|null {\n    this._assertInitialized();\n    return this.marker.getAnimation() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getClickable\n   */\n  getClickable(): boolean {\n    this._assertInitialized();\n    return this.marker.getClickable();\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getCursor\n   */\n  getCursor(): string|null {\n    this._assertInitialized();\n    return this.marker.getCursor() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getDraggable\n   */\n  getDraggable(): boolean {\n    this._assertInitialized();\n    return !!this.marker.getDraggable();\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getIcon\n   */\n  getIcon(): string|google.maps.Icon|google.maps.Symbol|null {\n    this._assertInitialized();\n    return this.marker.getIcon() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getLabel\n   */\n  getLabel(): google.maps.MarkerLabel|null {\n    this._assertInitialized();\n    return this.marker.getLabel() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getOpacity\n   */\n  getOpacity(): number|null {\n    this._assertInitialized();\n    return this.marker.getOpacity() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getPosition\n   */\n  getPosition(): google.maps.LatLng|null {\n    this._assertInitialized();\n    return this.marker.getPosition() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getShape\n   */\n  getShape(): google.maps.MarkerShape|null {\n    this._assertInitialized();\n    return this.marker.getShape() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getTitle\n   */\n  getTitle(): string|null {\n    this._assertInitialized();\n    return this.marker.getTitle() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getVisible\n   */\n  getVisible(): boolean {\n    this._assertInitialized();\n    return this.marker.getVisible();\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getZIndex\n   */\n  getZIndex(): number|null {\n    this._assertInitialized();\n    return this.marker.getZIndex() || null;\n  }\n\n  /** Gets the anchor point that can be used to attach other Google Maps objects. */\n  getAnchor(): google.maps.MVCObject {\n    this._assertInitialized();\n    return this.marker;\n  }\n\n  /** Creates a combined options object using the passed-in options and the individual inputs. */\n  private _combineOptions(): google.maps.MarkerOptions {\n    const options = this._options || DEFAULT_MARKER_OPTIONS;\n    return {\n      ...options,\n      title: this._title || options.title,\n      position: this._position || options.position,\n      label: this._label || options.label,\n      clickable: this._clickable ?? options.clickable,\n      map: this._googleMap.googleMap,\n      icon: this._icon || options.icon,\n      visible: this._visible ?? options.visible\n    };\n  }\n\n  private _assertInitialized(): asserts this is {marker: google.maps.Marker} {\n    if (typeof ngDevMode === 'undefined' || ngDevMode) {\n      if (!this._googleMap.googleMap) {\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      if (!this.marker) {\n        throw Error(\n            'Cannot interact with a Google Map Marker before it has been ' +\n            'initialized. Please wait for the Marker to load before trying to interact with it.');\n      }\n    }\n  }\n}\n"]}
|