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