@angular/google-maps 19.0.0-next.0 → 19.0.0-next.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/package.json +1 -3
- package/esm2022/google-map/google-map.mjs +0 -473
- package/esm2022/google-maps-module.mjs +0 -90
- package/esm2022/google-maps_public_index.mjs +0 -5
- package/esm2022/index.mjs +0 -9
- package/esm2022/map-advanced-marker/map-advanced-marker.mjs +0 -217
- package/esm2022/map-anchor-point.mjs +0 -10
- package/esm2022/map-base-layer.mjs +0 -51
- package/esm2022/map-bicycling-layer/map-bicycling-layer.mjs +0 -69
- package/esm2022/map-circle/map-circle.mjs +0 -280
- package/esm2022/map-directions-renderer/map-directions-renderer.mjs +0 -149
- package/esm2022/map-directions-renderer/map-directions-service.mjs +0 -61
- package/esm2022/map-event-manager.mjs +0 -73
- package/esm2022/map-geocoder/map-geocoder.mjs +0 -57
- package/esm2022/map-ground-overlay/map-ground-overlay.mjs +0 -193
- package/esm2022/map-heatmap-layer/map-heatmap-layer.mjs +0 -151
- package/esm2022/map-info-window/map-info-window.mjs +0 -238
- package/esm2022/map-kml-layer/map-kml-layer.mjs +0 -183
- package/esm2022/map-marker/map-marker.mjs +0 -447
- package/esm2022/map-marker-clusterer/map-marker-clusterer.mjs +0 -421
- package/esm2022/map-marker-clusterer/marker-clusterer-types.mjs +0 -10
- package/esm2022/map-polygon/map-polygon.mjs +0 -227
- package/esm2022/map-polyline/map-polyline.mjs +0 -220
- package/esm2022/map-rectangle/map-rectangle.mjs +0 -240
- package/esm2022/map-traffic-layer/map-traffic-layer.mjs +0 -103
- package/esm2022/map-transit-layer/map-transit-layer.mjs +0 -69
- package/esm2022/public-api.mjs +0 -29
|
@@ -1,227 +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="google.maps" preserve="true" />
|
|
10
|
-
import { Directive, Input, Output, NgZone, inject, EventEmitter, } 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
|
-
import * as i0 from "@angular/core";
|
|
16
|
-
import * as i1 from "../google-map/google-map";
|
|
17
|
-
/**
|
|
18
|
-
* Angular component that renders a Google Maps Polygon via the Google Maps JavaScript API.
|
|
19
|
-
*
|
|
20
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon
|
|
21
|
-
*/
|
|
22
|
-
export class MapPolygon {
|
|
23
|
-
set options(options) {
|
|
24
|
-
this._options.next(options || {});
|
|
25
|
-
}
|
|
26
|
-
set paths(paths) {
|
|
27
|
-
this._paths.next(paths);
|
|
28
|
-
}
|
|
29
|
-
constructor(_map, _ngZone) {
|
|
30
|
-
this._map = _map;
|
|
31
|
-
this._ngZone = _ngZone;
|
|
32
|
-
this._eventManager = new MapEventManager(inject(NgZone));
|
|
33
|
-
this._options = new BehaviorSubject({});
|
|
34
|
-
this._paths = new BehaviorSubject(undefined);
|
|
35
|
-
this._destroyed = new Subject();
|
|
36
|
-
/**
|
|
37
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.click
|
|
38
|
-
*/
|
|
39
|
-
this.polygonClick = this._eventManager.getLazyEmitter('click');
|
|
40
|
-
/**
|
|
41
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.dblclick
|
|
42
|
-
*/
|
|
43
|
-
this.polygonDblclick = this._eventManager.getLazyEmitter('dblclick');
|
|
44
|
-
/**
|
|
45
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.drag
|
|
46
|
-
*/
|
|
47
|
-
this.polygonDrag = this._eventManager.getLazyEmitter('drag');
|
|
48
|
-
/**
|
|
49
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.dragend
|
|
50
|
-
*/
|
|
51
|
-
this.polygonDragend = this._eventManager.getLazyEmitter('dragend');
|
|
52
|
-
/**
|
|
53
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.dragstart
|
|
54
|
-
*/
|
|
55
|
-
this.polygonDragstart = this._eventManager.getLazyEmitter('dragstart');
|
|
56
|
-
/**
|
|
57
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.mousedown
|
|
58
|
-
*/
|
|
59
|
-
this.polygonMousedown = this._eventManager.getLazyEmitter('mousedown');
|
|
60
|
-
/**
|
|
61
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.mousemove
|
|
62
|
-
*/
|
|
63
|
-
this.polygonMousemove = this._eventManager.getLazyEmitter('mousemove');
|
|
64
|
-
/**
|
|
65
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.mouseout
|
|
66
|
-
*/
|
|
67
|
-
this.polygonMouseout = this._eventManager.getLazyEmitter('mouseout');
|
|
68
|
-
/**
|
|
69
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.mouseover
|
|
70
|
-
*/
|
|
71
|
-
this.polygonMouseover = this._eventManager.getLazyEmitter('mouseover');
|
|
72
|
-
/**
|
|
73
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.mouseup
|
|
74
|
-
*/
|
|
75
|
-
this.polygonMouseup = this._eventManager.getLazyEmitter('mouseup');
|
|
76
|
-
/**
|
|
77
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.rightclick
|
|
78
|
-
*/
|
|
79
|
-
this.polygonRightclick = this._eventManager.getLazyEmitter('rightclick');
|
|
80
|
-
/** Event emitted when the polygon is initialized. */
|
|
81
|
-
this.polygonInitialized = new EventEmitter();
|
|
82
|
-
}
|
|
83
|
-
ngOnInit() {
|
|
84
|
-
if (this._map._isBrowser) {
|
|
85
|
-
this._combineOptions()
|
|
86
|
-
.pipe(take(1))
|
|
87
|
-
.subscribe(options => {
|
|
88
|
-
if (google.maps.Polygon && this._map.googleMap) {
|
|
89
|
-
this._initialize(this._map.googleMap, google.maps.Polygon, options);
|
|
90
|
-
}
|
|
91
|
-
else {
|
|
92
|
-
this._ngZone.runOutsideAngular(() => {
|
|
93
|
-
Promise.all([this._map._resolveMap(), google.maps.importLibrary('maps')]).then(([map, lib]) => {
|
|
94
|
-
this._initialize(map, lib.Polygon, options);
|
|
95
|
-
});
|
|
96
|
-
});
|
|
97
|
-
}
|
|
98
|
-
});
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
_initialize(map, polygonConstructor, options) {
|
|
102
|
-
// Create the object outside the zone so its events don't trigger change detection.
|
|
103
|
-
// We'll bring it back in inside the `MapEventManager` only for the events that the
|
|
104
|
-
// user has subscribed to.
|
|
105
|
-
this._ngZone.runOutsideAngular(() => {
|
|
106
|
-
this.polygon = new polygonConstructor(options);
|
|
107
|
-
this._assertInitialized();
|
|
108
|
-
this.polygon.setMap(map);
|
|
109
|
-
this._eventManager.setTarget(this.polygon);
|
|
110
|
-
this.polygonInitialized.emit(this.polygon);
|
|
111
|
-
this._watchForOptionsChanges();
|
|
112
|
-
this._watchForPathChanges();
|
|
113
|
-
});
|
|
114
|
-
}
|
|
115
|
-
ngOnDestroy() {
|
|
116
|
-
this._eventManager.destroy();
|
|
117
|
-
this._destroyed.next();
|
|
118
|
-
this._destroyed.complete();
|
|
119
|
-
this.polygon?.setMap(null);
|
|
120
|
-
}
|
|
121
|
-
/**
|
|
122
|
-
* See
|
|
123
|
-
* developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.getDraggable
|
|
124
|
-
*/
|
|
125
|
-
getDraggable() {
|
|
126
|
-
this._assertInitialized();
|
|
127
|
-
return this.polygon.getDraggable();
|
|
128
|
-
}
|
|
129
|
-
/**
|
|
130
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.getEditable
|
|
131
|
-
*/
|
|
132
|
-
getEditable() {
|
|
133
|
-
this._assertInitialized();
|
|
134
|
-
return this.polygon.getEditable();
|
|
135
|
-
}
|
|
136
|
-
/**
|
|
137
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.getPath
|
|
138
|
-
*/
|
|
139
|
-
getPath() {
|
|
140
|
-
this._assertInitialized();
|
|
141
|
-
return this.polygon.getPath();
|
|
142
|
-
}
|
|
143
|
-
/**
|
|
144
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.getPaths
|
|
145
|
-
*/
|
|
146
|
-
getPaths() {
|
|
147
|
-
this._assertInitialized();
|
|
148
|
-
return this.polygon.getPaths();
|
|
149
|
-
}
|
|
150
|
-
/**
|
|
151
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.getVisible
|
|
152
|
-
*/
|
|
153
|
-
getVisible() {
|
|
154
|
-
this._assertInitialized();
|
|
155
|
-
return this.polygon.getVisible();
|
|
156
|
-
}
|
|
157
|
-
_combineOptions() {
|
|
158
|
-
return combineLatest([this._options, this._paths]).pipe(map(([options, paths]) => {
|
|
159
|
-
const combinedOptions = {
|
|
160
|
-
...options,
|
|
161
|
-
paths: paths || options.paths,
|
|
162
|
-
};
|
|
163
|
-
return combinedOptions;
|
|
164
|
-
}));
|
|
165
|
-
}
|
|
166
|
-
_watchForOptionsChanges() {
|
|
167
|
-
this._options.pipe(takeUntil(this._destroyed)).subscribe(options => {
|
|
168
|
-
this._assertInitialized();
|
|
169
|
-
this.polygon.setOptions(options);
|
|
170
|
-
});
|
|
171
|
-
}
|
|
172
|
-
_watchForPathChanges() {
|
|
173
|
-
this._paths.pipe(takeUntil(this._destroyed)).subscribe(paths => {
|
|
174
|
-
if (paths) {
|
|
175
|
-
this._assertInitialized();
|
|
176
|
-
this.polygon.setPaths(paths);
|
|
177
|
-
}
|
|
178
|
-
});
|
|
179
|
-
}
|
|
180
|
-
_assertInitialized() {
|
|
181
|
-
if (typeof ngDevMode === 'undefined' || ngDevMode) {
|
|
182
|
-
if (!this.polygon) {
|
|
183
|
-
throw Error('Cannot interact with a Google Map Polygon before it has been ' +
|
|
184
|
-
'initialized. Please wait for the Polygon to load before trying to interact with it.');
|
|
185
|
-
}
|
|
186
|
-
}
|
|
187
|
-
}
|
|
188
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0-next.2", ngImport: i0, type: MapPolygon, deps: [{ token: i1.GoogleMap }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
189
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.0-next.2", type: MapPolygon, isStandalone: true, selector: "map-polygon", inputs: { options: "options", paths: "paths" }, outputs: { polygonClick: "polygonClick", polygonDblclick: "polygonDblclick", polygonDrag: "polygonDrag", polygonDragend: "polygonDragend", polygonDragstart: "polygonDragstart", polygonMousedown: "polygonMousedown", polygonMousemove: "polygonMousemove", polygonMouseout: "polygonMouseout", polygonMouseover: "polygonMouseover", polygonMouseup: "polygonMouseup", polygonRightclick: "polygonRightclick", polygonInitialized: "polygonInitialized" }, exportAs: ["mapPolygon"], ngImport: i0 }); }
|
|
190
|
-
}
|
|
191
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0-next.2", ngImport: i0, type: MapPolygon, decorators: [{
|
|
192
|
-
type: Directive,
|
|
193
|
-
args: [{
|
|
194
|
-
selector: 'map-polygon',
|
|
195
|
-
exportAs: 'mapPolygon',
|
|
196
|
-
standalone: true,
|
|
197
|
-
}]
|
|
198
|
-
}], ctorParameters: () => [{ type: i1.GoogleMap }, { type: i0.NgZone }], propDecorators: { options: [{
|
|
199
|
-
type: Input
|
|
200
|
-
}], paths: [{
|
|
201
|
-
type: Input
|
|
202
|
-
}], polygonClick: [{
|
|
203
|
-
type: Output
|
|
204
|
-
}], polygonDblclick: [{
|
|
205
|
-
type: Output
|
|
206
|
-
}], polygonDrag: [{
|
|
207
|
-
type: Output
|
|
208
|
-
}], polygonDragend: [{
|
|
209
|
-
type: Output
|
|
210
|
-
}], polygonDragstart: [{
|
|
211
|
-
type: Output
|
|
212
|
-
}], polygonMousedown: [{
|
|
213
|
-
type: Output
|
|
214
|
-
}], polygonMousemove: [{
|
|
215
|
-
type: Output
|
|
216
|
-
}], polygonMouseout: [{
|
|
217
|
-
type: Output
|
|
218
|
-
}], polygonMouseover: [{
|
|
219
|
-
type: Output
|
|
220
|
-
}], polygonMouseup: [{
|
|
221
|
-
type: Output
|
|
222
|
-
}], polygonRightclick: [{
|
|
223
|
-
type: Output
|
|
224
|
-
}], polygonInitialized: [{
|
|
225
|
-
type: Output
|
|
226
|
-
}] } });
|
|
227
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-polygon.js","sourceRoot":"","sources":["../../../../../../src/google-maps/map-polygon/map-polygon.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\" preserve=\"true\" />\n\nimport {\n  Directive,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  NgZone,\n  inject,\n  EventEmitter,\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 Polygon via the Google Maps JavaScript API.\n *\n * See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon\n */\n@Directive({\n  selector: 'map-polygon',\n  exportAs: 'mapPolygon',\n  standalone: true,\n})\nexport class MapPolygon implements OnInit, OnDestroy {\n  private _eventManager = new MapEventManager(inject(NgZone));\n  private readonly _options = new BehaviorSubject<google.maps.PolygonOptions>({});\n  private readonly _paths = new BehaviorSubject<\n    | google.maps.MVCArray<google.maps.MVCArray<google.maps.LatLng>>\n    | google.maps.MVCArray<google.maps.LatLng>\n    | google.maps.LatLng[]\n    | google.maps.LatLngLiteral[]\n    | undefined\n  >(undefined);\n\n  private readonly _destroyed = new Subject<void>();\n\n  /**\n   * The underlying google.maps.Polygon object.\n   *\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon\n   */\n  polygon?: google.maps.Polygon;\n\n  @Input()\n  set options(options: google.maps.PolygonOptions) {\n    this._options.next(options || {});\n  }\n\n  @Input()\n  set paths(\n    paths:\n      | google.maps.MVCArray<google.maps.MVCArray<google.maps.LatLng>>\n      | google.maps.MVCArray<google.maps.LatLng>\n      | google.maps.LatLng[]\n      | google.maps.LatLngLiteral[],\n  ) {\n    this._paths.next(paths);\n  }\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.click\n   */\n  @Output() readonly polygonClick: Observable<google.maps.PolyMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.PolyMouseEvent>('click');\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.dblclick\n   */\n  @Output() readonly polygonDblclick: Observable<google.maps.PolyMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.PolyMouseEvent>('dblclick');\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.drag\n   */\n  @Output() readonly polygonDrag: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('drag');\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.dragend\n   */\n  @Output() readonly polygonDragend: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('dragend');\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.dragstart\n   */\n  @Output() readonly polygonDragstart: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('dragstart');\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.mousedown\n   */\n  @Output() readonly polygonMousedown: Observable<google.maps.PolyMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.PolyMouseEvent>('mousedown');\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.mousemove\n   */\n  @Output() readonly polygonMousemove: Observable<google.maps.PolyMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.PolyMouseEvent>('mousemove');\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.mouseout\n   */\n  @Output() readonly polygonMouseout: Observable<google.maps.PolyMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.PolyMouseEvent>('mouseout');\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.mouseover\n   */\n  @Output() readonly polygonMouseover: Observable<google.maps.PolyMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.PolyMouseEvent>('mouseover');\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.mouseup\n   */\n  @Output() readonly polygonMouseup: Observable<google.maps.PolyMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.PolyMouseEvent>('mouseup');\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.rightclick\n   */\n  @Output() readonly polygonRightclick: Observable<google.maps.PolyMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.PolyMouseEvent>('rightclick');\n\n  /** Event emitted when the polygon is initialized. */\n  @Output() readonly polygonInitialized: EventEmitter<google.maps.Polygon> =\n    new EventEmitter<google.maps.Polygon>();\n\n  constructor(\n    private readonly _map: GoogleMap,\n    private readonly _ngZone: NgZone,\n  ) {}\n\n  ngOnInit() {\n    if (this._map._isBrowser) {\n      this._combineOptions()\n        .pipe(take(1))\n        .subscribe(options => {\n          if (google.maps.Polygon && this._map.googleMap) {\n            this._initialize(this._map.googleMap, google.maps.Polygon, options);\n          } else {\n            this._ngZone.runOutsideAngular(() => {\n              Promise.all([this._map._resolveMap(), google.maps.importLibrary('maps')]).then(\n                ([map, lib]) => {\n                  this._initialize(map, (lib as google.maps.MapsLibrary).Polygon, options);\n                },\n              );\n            });\n          }\n        });\n    }\n  }\n\n  private _initialize(\n    map: google.maps.Map,\n    polygonConstructor: typeof google.maps.Polygon,\n    options: google.maps.PolygonOptions,\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.polygon = new polygonConstructor(options);\n      this._assertInitialized();\n      this.polygon.setMap(map);\n      this._eventManager.setTarget(this.polygon);\n      this.polygonInitialized.emit(this.polygon);\n      this._watchForOptionsChanges();\n      this._watchForPathChanges();\n    });\n  }\n\n  ngOnDestroy() {\n    this._eventManager.destroy();\n    this._destroyed.next();\n    this._destroyed.complete();\n    this.polygon?.setMap(null);\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.getDraggable\n   */\n  getDraggable(): boolean {\n    this._assertInitialized();\n    return this.polygon.getDraggable();\n  }\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.getEditable\n   */\n  getEditable(): boolean {\n    this._assertInitialized();\n    return this.polygon.getEditable();\n  }\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.getPath\n   */\n  getPath(): google.maps.MVCArray<google.maps.LatLng> {\n    this._assertInitialized();\n    return this.polygon.getPath();\n  }\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.getPaths\n   */\n  getPaths(): google.maps.MVCArray<google.maps.MVCArray<google.maps.LatLng>> {\n    this._assertInitialized();\n    return this.polygon.getPaths();\n  }\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polygon.getVisible\n   */\n  getVisible(): boolean {\n    this._assertInitialized();\n    return this.polygon.getVisible();\n  }\n\n  private _combineOptions(): Observable<google.maps.PolygonOptions> {\n    return combineLatest([this._options, this._paths]).pipe(\n      map(([options, paths]) => {\n        const combinedOptions: google.maps.PolygonOptions = {\n          ...options,\n          paths: paths || options.paths,\n        };\n        return combinedOptions;\n      }),\n    );\n  }\n\n  private _watchForOptionsChanges() {\n    this._options.pipe(takeUntil(this._destroyed)).subscribe(options => {\n      this._assertInitialized();\n      this.polygon.setOptions(options);\n    });\n  }\n\n  private _watchForPathChanges() {\n    this._paths.pipe(takeUntil(this._destroyed)).subscribe(paths => {\n      if (paths) {\n        this._assertInitialized();\n        this.polygon.setPaths(paths);\n      }\n    });\n  }\n\n  private _assertInitialized(): asserts this is {polygon: google.maps.Polygon} {\n    if (typeof ngDevMode === 'undefined' || ngDevMode) {\n      if (!this.polygon) {\n        throw Error(\n          'Cannot interact with a Google Map Polygon before it has been ' +\n            'initialized. Please wait for the Polygon to load before trying to interact with it.',\n        );\n      }\n    }\n  }\n}\n"]}
|
|
@@ -1,220 +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="google.maps" preserve="true" />
|
|
10
|
-
import { Directive, Input, Output, NgZone, inject, EventEmitter, } 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
|
-
import * as i0 from "@angular/core";
|
|
16
|
-
import * as i1 from "../google-map/google-map";
|
|
17
|
-
/**
|
|
18
|
-
* Angular component that renders a Google Maps Polyline via the Google Maps JavaScript API.
|
|
19
|
-
*
|
|
20
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline
|
|
21
|
-
*/
|
|
22
|
-
export class MapPolyline {
|
|
23
|
-
set options(options) {
|
|
24
|
-
this._options.next(options || {});
|
|
25
|
-
}
|
|
26
|
-
set path(path) {
|
|
27
|
-
this._path.next(path);
|
|
28
|
-
}
|
|
29
|
-
constructor(_map, _ngZone) {
|
|
30
|
-
this._map = _map;
|
|
31
|
-
this._ngZone = _ngZone;
|
|
32
|
-
this._eventManager = new MapEventManager(inject(NgZone));
|
|
33
|
-
this._options = new BehaviorSubject({});
|
|
34
|
-
this._path = new BehaviorSubject(undefined);
|
|
35
|
-
this._destroyed = new Subject();
|
|
36
|
-
/**
|
|
37
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.click
|
|
38
|
-
*/
|
|
39
|
-
this.polylineClick = this._eventManager.getLazyEmitter('click');
|
|
40
|
-
/**
|
|
41
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.dblclick
|
|
42
|
-
*/
|
|
43
|
-
this.polylineDblclick = this._eventManager.getLazyEmitter('dblclick');
|
|
44
|
-
/**
|
|
45
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.drag
|
|
46
|
-
*/
|
|
47
|
-
this.polylineDrag = this._eventManager.getLazyEmitter('drag');
|
|
48
|
-
/**
|
|
49
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.dragend
|
|
50
|
-
*/
|
|
51
|
-
this.polylineDragend = this._eventManager.getLazyEmitter('dragend');
|
|
52
|
-
/**
|
|
53
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.dragstart
|
|
54
|
-
*/
|
|
55
|
-
this.polylineDragstart = this._eventManager.getLazyEmitter('dragstart');
|
|
56
|
-
/**
|
|
57
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mousedown
|
|
58
|
-
*/
|
|
59
|
-
this.polylineMousedown = this._eventManager.getLazyEmitter('mousedown');
|
|
60
|
-
/**
|
|
61
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mousemove
|
|
62
|
-
*/
|
|
63
|
-
this.polylineMousemove = this._eventManager.getLazyEmitter('mousemove');
|
|
64
|
-
/**
|
|
65
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mouseout
|
|
66
|
-
*/
|
|
67
|
-
this.polylineMouseout = this._eventManager.getLazyEmitter('mouseout');
|
|
68
|
-
/**
|
|
69
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mouseover
|
|
70
|
-
*/
|
|
71
|
-
this.polylineMouseover = this._eventManager.getLazyEmitter('mouseover');
|
|
72
|
-
/**
|
|
73
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mouseup
|
|
74
|
-
*/
|
|
75
|
-
this.polylineMouseup = this._eventManager.getLazyEmitter('mouseup');
|
|
76
|
-
/**
|
|
77
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.rightclick
|
|
78
|
-
*/
|
|
79
|
-
this.polylineRightclick = this._eventManager.getLazyEmitter('rightclick');
|
|
80
|
-
/** Event emitted when the polyline is initialized. */
|
|
81
|
-
this.polylineInitialized = new EventEmitter();
|
|
82
|
-
}
|
|
83
|
-
ngOnInit() {
|
|
84
|
-
if (this._map._isBrowser) {
|
|
85
|
-
this._combineOptions()
|
|
86
|
-
.pipe(take(1))
|
|
87
|
-
.subscribe(options => {
|
|
88
|
-
if (google.maps.Polyline && this._map.googleMap) {
|
|
89
|
-
this._initialize(this._map.googleMap, google.maps.Polyline, options);
|
|
90
|
-
}
|
|
91
|
-
else {
|
|
92
|
-
this._ngZone.runOutsideAngular(() => {
|
|
93
|
-
Promise.all([this._map._resolveMap(), google.maps.importLibrary('maps')]).then(([map, lib]) => {
|
|
94
|
-
this._initialize(map, lib.Polyline, options);
|
|
95
|
-
});
|
|
96
|
-
});
|
|
97
|
-
}
|
|
98
|
-
});
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
_initialize(map, polylineConstructor, options) {
|
|
102
|
-
// Create the object outside the zone so its events don't trigger change detection.
|
|
103
|
-
// We'll bring it back in inside the `MapEventManager` only for the events that the
|
|
104
|
-
// user has subscribed to.
|
|
105
|
-
this._ngZone.runOutsideAngular(() => {
|
|
106
|
-
this.polyline = new polylineConstructor(options);
|
|
107
|
-
this._assertInitialized();
|
|
108
|
-
this.polyline.setMap(map);
|
|
109
|
-
this._eventManager.setTarget(this.polyline);
|
|
110
|
-
this.polylineInitialized.emit(this.polyline);
|
|
111
|
-
this._watchForOptionsChanges();
|
|
112
|
-
this._watchForPathChanges();
|
|
113
|
-
});
|
|
114
|
-
}
|
|
115
|
-
ngOnDestroy() {
|
|
116
|
-
this._eventManager.destroy();
|
|
117
|
-
this._destroyed.next();
|
|
118
|
-
this._destroyed.complete();
|
|
119
|
-
this.polyline?.setMap(null);
|
|
120
|
-
}
|
|
121
|
-
/**
|
|
122
|
-
* See
|
|
123
|
-
* developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.getDraggable
|
|
124
|
-
*/
|
|
125
|
-
getDraggable() {
|
|
126
|
-
this._assertInitialized();
|
|
127
|
-
return this.polyline.getDraggable();
|
|
128
|
-
}
|
|
129
|
-
/**
|
|
130
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.getEditable
|
|
131
|
-
*/
|
|
132
|
-
getEditable() {
|
|
133
|
-
this._assertInitialized();
|
|
134
|
-
return this.polyline.getEditable();
|
|
135
|
-
}
|
|
136
|
-
/**
|
|
137
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.getPath
|
|
138
|
-
*/
|
|
139
|
-
getPath() {
|
|
140
|
-
this._assertInitialized();
|
|
141
|
-
return this.polyline.getPath();
|
|
142
|
-
}
|
|
143
|
-
/**
|
|
144
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.getVisible
|
|
145
|
-
*/
|
|
146
|
-
getVisible() {
|
|
147
|
-
this._assertInitialized();
|
|
148
|
-
return this.polyline.getVisible();
|
|
149
|
-
}
|
|
150
|
-
_combineOptions() {
|
|
151
|
-
return combineLatest([this._options, this._path]).pipe(map(([options, path]) => {
|
|
152
|
-
const combinedOptions = {
|
|
153
|
-
...options,
|
|
154
|
-
path: path || options.path,
|
|
155
|
-
};
|
|
156
|
-
return combinedOptions;
|
|
157
|
-
}));
|
|
158
|
-
}
|
|
159
|
-
_watchForOptionsChanges() {
|
|
160
|
-
this._options.pipe(takeUntil(this._destroyed)).subscribe(options => {
|
|
161
|
-
this._assertInitialized();
|
|
162
|
-
this.polyline.setOptions(options);
|
|
163
|
-
});
|
|
164
|
-
}
|
|
165
|
-
_watchForPathChanges() {
|
|
166
|
-
this._path.pipe(takeUntil(this._destroyed)).subscribe(path => {
|
|
167
|
-
if (path) {
|
|
168
|
-
this._assertInitialized();
|
|
169
|
-
this.polyline.setPath(path);
|
|
170
|
-
}
|
|
171
|
-
});
|
|
172
|
-
}
|
|
173
|
-
_assertInitialized() {
|
|
174
|
-
if (typeof ngDevMode === 'undefined' || ngDevMode) {
|
|
175
|
-
if (!this.polyline) {
|
|
176
|
-
throw Error('Cannot interact with a Google Map Polyline before it has been ' +
|
|
177
|
-
'initialized. Please wait for the Polyline to load before trying to interact with it.');
|
|
178
|
-
}
|
|
179
|
-
}
|
|
180
|
-
}
|
|
181
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0-next.2", ngImport: i0, type: MapPolyline, deps: [{ token: i1.GoogleMap }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
182
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.0-next.2", type: MapPolyline, isStandalone: true, selector: "map-polyline", inputs: { options: "options", path: "path" }, outputs: { polylineClick: "polylineClick", polylineDblclick: "polylineDblclick", polylineDrag: "polylineDrag", polylineDragend: "polylineDragend", polylineDragstart: "polylineDragstart", polylineMousedown: "polylineMousedown", polylineMousemove: "polylineMousemove", polylineMouseout: "polylineMouseout", polylineMouseover: "polylineMouseover", polylineMouseup: "polylineMouseup", polylineRightclick: "polylineRightclick", polylineInitialized: "polylineInitialized" }, exportAs: ["mapPolyline"], ngImport: i0 }); }
|
|
183
|
-
}
|
|
184
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0-next.2", ngImport: i0, type: MapPolyline, decorators: [{
|
|
185
|
-
type: Directive,
|
|
186
|
-
args: [{
|
|
187
|
-
selector: 'map-polyline',
|
|
188
|
-
exportAs: 'mapPolyline',
|
|
189
|
-
standalone: true,
|
|
190
|
-
}]
|
|
191
|
-
}], ctorParameters: () => [{ type: i1.GoogleMap }, { type: i0.NgZone }], propDecorators: { options: [{
|
|
192
|
-
type: Input
|
|
193
|
-
}], path: [{
|
|
194
|
-
type: Input
|
|
195
|
-
}], polylineClick: [{
|
|
196
|
-
type: Output
|
|
197
|
-
}], polylineDblclick: [{
|
|
198
|
-
type: Output
|
|
199
|
-
}], polylineDrag: [{
|
|
200
|
-
type: Output
|
|
201
|
-
}], polylineDragend: [{
|
|
202
|
-
type: Output
|
|
203
|
-
}], polylineDragstart: [{
|
|
204
|
-
type: Output
|
|
205
|
-
}], polylineMousedown: [{
|
|
206
|
-
type: Output
|
|
207
|
-
}], polylineMousemove: [{
|
|
208
|
-
type: Output
|
|
209
|
-
}], polylineMouseout: [{
|
|
210
|
-
type: Output
|
|
211
|
-
}], polylineMouseover: [{
|
|
212
|
-
type: Output
|
|
213
|
-
}], polylineMouseup: [{
|
|
214
|
-
type: Output
|
|
215
|
-
}], polylineRightclick: [{
|
|
216
|
-
type: Output
|
|
217
|
-
}], polylineInitialized: [{
|
|
218
|
-
type: Output
|
|
219
|
-
}] } });
|
|
220
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-polyline.js","sourceRoot":"","sources":["../../../../../../src/google-maps/map-polyline/map-polyline.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\" preserve=\"true\" />\n\nimport {\n  Directive,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  NgZone,\n  inject,\n  EventEmitter,\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 Polyline via the Google Maps JavaScript API.\n *\n * See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline\n */\n@Directive({\n  selector: 'map-polyline',\n  exportAs: 'mapPolyline',\n  standalone: true,\n})\nexport class MapPolyline implements OnInit, OnDestroy {\n  private _eventManager = new MapEventManager(inject(NgZone));\n  private readonly _options = new BehaviorSubject<google.maps.PolylineOptions>({});\n  private readonly _path = new BehaviorSubject<\n    | google.maps.MVCArray<google.maps.LatLng>\n    | google.maps.LatLng[]\n    | google.maps.LatLngLiteral[]\n    | undefined\n  >(undefined);\n\n  private readonly _destroyed = new Subject<void>();\n\n  /**\n   * The underlying google.maps.Polyline object.\n   *\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline\n   */\n  polyline?: google.maps.Polyline;\n\n  @Input()\n  set options(options: google.maps.PolylineOptions) {\n    this._options.next(options || {});\n  }\n\n  @Input()\n  set path(\n    path:\n      | google.maps.MVCArray<google.maps.LatLng>\n      | google.maps.LatLng[]\n      | google.maps.LatLngLiteral[],\n  ) {\n    this._path.next(path);\n  }\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.click\n   */\n  @Output() readonly polylineClick: Observable<google.maps.PolyMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.PolyMouseEvent>('click');\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.dblclick\n   */\n  @Output() readonly polylineDblclick: Observable<google.maps.PolyMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.PolyMouseEvent>('dblclick');\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.drag\n   */\n  @Output() readonly polylineDrag: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('drag');\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.dragend\n   */\n  @Output() readonly polylineDragend: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('dragend');\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.dragstart\n   */\n  @Output() readonly polylineDragstart: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('dragstart');\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mousedown\n   */\n  @Output() readonly polylineMousedown: Observable<google.maps.PolyMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.PolyMouseEvent>('mousedown');\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mousemove\n   */\n  @Output() readonly polylineMousemove: Observable<google.maps.PolyMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.PolyMouseEvent>('mousemove');\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mouseout\n   */\n  @Output() readonly polylineMouseout: Observable<google.maps.PolyMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.PolyMouseEvent>('mouseout');\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mouseover\n   */\n  @Output() readonly polylineMouseover: Observable<google.maps.PolyMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.PolyMouseEvent>('mouseover');\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mouseup\n   */\n  @Output() readonly polylineMouseup: Observable<google.maps.PolyMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.PolyMouseEvent>('mouseup');\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.rightclick\n   */\n  @Output() readonly polylineRightclick: Observable<google.maps.PolyMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.PolyMouseEvent>('rightclick');\n\n  /** Event emitted when the polyline is initialized. */\n  @Output() readonly polylineInitialized: EventEmitter<google.maps.Polyline> =\n    new EventEmitter<google.maps.Polyline>();\n\n  constructor(\n    private readonly _map: GoogleMap,\n    private _ngZone: NgZone,\n  ) {}\n\n  ngOnInit() {\n    if (this._map._isBrowser) {\n      this._combineOptions()\n        .pipe(take(1))\n        .subscribe(options => {\n          if (google.maps.Polyline && this._map.googleMap) {\n            this._initialize(this._map.googleMap, google.maps.Polyline, options);\n          } else {\n            this._ngZone.runOutsideAngular(() => {\n              Promise.all([this._map._resolveMap(), google.maps.importLibrary('maps')]).then(\n                ([map, lib]) => {\n                  this._initialize(map, (lib as google.maps.MapsLibrary).Polyline, options);\n                },\n              );\n            });\n          }\n        });\n    }\n  }\n\n  private _initialize(\n    map: google.maps.Map,\n    polylineConstructor: typeof google.maps.Polyline,\n    options: google.maps.PolygonOptions,\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.polyline = new polylineConstructor(options);\n      this._assertInitialized();\n      this.polyline.setMap(map);\n      this._eventManager.setTarget(this.polyline);\n      this.polylineInitialized.emit(this.polyline);\n      this._watchForOptionsChanges();\n      this._watchForPathChanges();\n    });\n  }\n\n  ngOnDestroy() {\n    this._eventManager.destroy();\n    this._destroyed.next();\n    this._destroyed.complete();\n    this.polyline?.setMap(null);\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.getDraggable\n   */\n  getDraggable(): boolean {\n    this._assertInitialized();\n    return this.polyline.getDraggable();\n  }\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.getEditable\n   */\n  getEditable(): boolean {\n    this._assertInitialized();\n    return this.polyline.getEditable();\n  }\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.getPath\n   */\n  getPath(): google.maps.MVCArray<google.maps.LatLng> {\n    this._assertInitialized();\n    return this.polyline.getPath();\n  }\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.getVisible\n   */\n  getVisible(): boolean {\n    this._assertInitialized();\n    return this.polyline.getVisible();\n  }\n\n  private _combineOptions(): Observable<google.maps.PolylineOptions> {\n    return combineLatest([this._options, this._path]).pipe(\n      map(([options, path]) => {\n        const combinedOptions: google.maps.PolylineOptions = {\n          ...options,\n          path: path || options.path,\n        };\n        return combinedOptions;\n      }),\n    );\n  }\n\n  private _watchForOptionsChanges() {\n    this._options.pipe(takeUntil(this._destroyed)).subscribe(options => {\n      this._assertInitialized();\n      this.polyline.setOptions(options);\n    });\n  }\n\n  private _watchForPathChanges() {\n    this._path.pipe(takeUntil(this._destroyed)).subscribe(path => {\n      if (path) {\n        this._assertInitialized();\n        this.polyline.setPath(path);\n      }\n    });\n  }\n\n  private _assertInitialized(): asserts this is {polyline: google.maps.Polyline} {\n    if (typeof ngDevMode === 'undefined' || ngDevMode) {\n      if (!this.polyline) {\n        throw Error(\n          'Cannot interact with a Google Map Polyline before it has been ' +\n            'initialized. Please wait for the Polyline to load before trying to interact with it.',\n        );\n      }\n    }\n  }\n}\n"]}
|