@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,240 +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 Rectangle via the Google Maps JavaScript API.
|
|
19
|
-
*
|
|
20
|
-
* See developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle
|
|
21
|
-
*/
|
|
22
|
-
export class MapRectangle {
|
|
23
|
-
set options(options) {
|
|
24
|
-
this._options.next(options || {});
|
|
25
|
-
}
|
|
26
|
-
set bounds(bounds) {
|
|
27
|
-
this._bounds.next(bounds);
|
|
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._bounds = new BehaviorSubject(undefined);
|
|
35
|
-
this._destroyed = new Subject();
|
|
36
|
-
/**
|
|
37
|
-
* See
|
|
38
|
-
* developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.boundsChanged
|
|
39
|
-
*/ this.boundsChanged = this._eventManager.getLazyEmitter('bounds_changed');
|
|
40
|
-
/**
|
|
41
|
-
* See
|
|
42
|
-
* developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.click
|
|
43
|
-
*/
|
|
44
|
-
this.rectangleClick = this._eventManager.getLazyEmitter('click');
|
|
45
|
-
/**
|
|
46
|
-
* See
|
|
47
|
-
* developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.dblclick
|
|
48
|
-
*/
|
|
49
|
-
this.rectangleDblclick = this._eventManager.getLazyEmitter('dblclick');
|
|
50
|
-
/**
|
|
51
|
-
* See
|
|
52
|
-
* developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.drag
|
|
53
|
-
*/
|
|
54
|
-
this.rectangleDrag = this._eventManager.getLazyEmitter('drag');
|
|
55
|
-
/**
|
|
56
|
-
* See
|
|
57
|
-
* developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.dragend
|
|
58
|
-
*/
|
|
59
|
-
this.rectangleDragend = this._eventManager.getLazyEmitter('dragend');
|
|
60
|
-
/**
|
|
61
|
-
* See
|
|
62
|
-
* developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.dragstart
|
|
63
|
-
*/
|
|
64
|
-
this.rectangleDragstart = this._eventManager.getLazyEmitter('dragstart');
|
|
65
|
-
/**
|
|
66
|
-
* See
|
|
67
|
-
* developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.mousedown
|
|
68
|
-
*/
|
|
69
|
-
this.rectangleMousedown = this._eventManager.getLazyEmitter('mousedown');
|
|
70
|
-
/**
|
|
71
|
-
* See
|
|
72
|
-
* developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.mousemove
|
|
73
|
-
*/
|
|
74
|
-
this.rectangleMousemove = this._eventManager.getLazyEmitter('mousemove');
|
|
75
|
-
/**
|
|
76
|
-
* See
|
|
77
|
-
* developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.mouseout
|
|
78
|
-
*/
|
|
79
|
-
this.rectangleMouseout = this._eventManager.getLazyEmitter('mouseout');
|
|
80
|
-
/**
|
|
81
|
-
* See
|
|
82
|
-
* developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.mouseover
|
|
83
|
-
*/
|
|
84
|
-
this.rectangleMouseover = this._eventManager.getLazyEmitter('mouseover');
|
|
85
|
-
/**
|
|
86
|
-
* See
|
|
87
|
-
* developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.mouseup
|
|
88
|
-
*/
|
|
89
|
-
this.rectangleMouseup = this._eventManager.getLazyEmitter('mouseup');
|
|
90
|
-
/**
|
|
91
|
-
* See
|
|
92
|
-
* developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.rightclick
|
|
93
|
-
*/
|
|
94
|
-
this.rectangleRightclick = this._eventManager.getLazyEmitter('rightclick');
|
|
95
|
-
/** Event emitted when the rectangle is initialized. */
|
|
96
|
-
this.rectangleInitialized = new EventEmitter();
|
|
97
|
-
}
|
|
98
|
-
ngOnInit() {
|
|
99
|
-
if (this._map._isBrowser) {
|
|
100
|
-
this._combineOptions()
|
|
101
|
-
.pipe(take(1))
|
|
102
|
-
.subscribe(options => {
|
|
103
|
-
if (google.maps.Rectangle && this._map.googleMap) {
|
|
104
|
-
this._initialize(this._map.googleMap, google.maps.Rectangle, options);
|
|
105
|
-
}
|
|
106
|
-
else {
|
|
107
|
-
this._ngZone.runOutsideAngular(() => {
|
|
108
|
-
Promise.all([this._map._resolveMap(), google.maps.importLibrary('maps')]).then(([map, lib]) => {
|
|
109
|
-
this._initialize(map, lib.Rectangle, options);
|
|
110
|
-
});
|
|
111
|
-
});
|
|
112
|
-
}
|
|
113
|
-
});
|
|
114
|
-
}
|
|
115
|
-
}
|
|
116
|
-
_initialize(map, rectangleConstructor, options) {
|
|
117
|
-
// Create the object outside the zone so its events don't trigger change detection.
|
|
118
|
-
// We'll bring it back in inside the `MapEventManager` only for the events that the
|
|
119
|
-
// user has subscribed to.
|
|
120
|
-
this._ngZone.runOutsideAngular(() => {
|
|
121
|
-
this.rectangle = new rectangleConstructor(options);
|
|
122
|
-
this._assertInitialized();
|
|
123
|
-
this.rectangle.setMap(map);
|
|
124
|
-
this._eventManager.setTarget(this.rectangle);
|
|
125
|
-
this.rectangleInitialized.emit(this.rectangle);
|
|
126
|
-
this._watchForOptionsChanges();
|
|
127
|
-
this._watchForBoundsChanges();
|
|
128
|
-
});
|
|
129
|
-
}
|
|
130
|
-
ngOnDestroy() {
|
|
131
|
-
this._eventManager.destroy();
|
|
132
|
-
this._destroyed.next();
|
|
133
|
-
this._destroyed.complete();
|
|
134
|
-
this.rectangle?.setMap(null);
|
|
135
|
-
}
|
|
136
|
-
/**
|
|
137
|
-
* See
|
|
138
|
-
* developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.getBounds
|
|
139
|
-
*/
|
|
140
|
-
getBounds() {
|
|
141
|
-
this._assertInitialized();
|
|
142
|
-
return this.rectangle.getBounds();
|
|
143
|
-
}
|
|
144
|
-
/**
|
|
145
|
-
* See
|
|
146
|
-
* developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.getDraggable
|
|
147
|
-
*/
|
|
148
|
-
getDraggable() {
|
|
149
|
-
this._assertInitialized();
|
|
150
|
-
return this.rectangle.getDraggable();
|
|
151
|
-
}
|
|
152
|
-
/**
|
|
153
|
-
* See
|
|
154
|
-
* developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.getEditable
|
|
155
|
-
*/
|
|
156
|
-
getEditable() {
|
|
157
|
-
this._assertInitialized();
|
|
158
|
-
return this.rectangle.getEditable();
|
|
159
|
-
}
|
|
160
|
-
/**
|
|
161
|
-
* See
|
|
162
|
-
* developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.getVisible
|
|
163
|
-
*/
|
|
164
|
-
getVisible() {
|
|
165
|
-
this._assertInitialized();
|
|
166
|
-
return this.rectangle.getVisible();
|
|
167
|
-
}
|
|
168
|
-
_combineOptions() {
|
|
169
|
-
return combineLatest([this._options, this._bounds]).pipe(map(([options, bounds]) => {
|
|
170
|
-
const combinedOptions = {
|
|
171
|
-
...options,
|
|
172
|
-
bounds: bounds || options.bounds,
|
|
173
|
-
};
|
|
174
|
-
return combinedOptions;
|
|
175
|
-
}));
|
|
176
|
-
}
|
|
177
|
-
_watchForOptionsChanges() {
|
|
178
|
-
this._options.pipe(takeUntil(this._destroyed)).subscribe(options => {
|
|
179
|
-
this._assertInitialized();
|
|
180
|
-
this.rectangle.setOptions(options);
|
|
181
|
-
});
|
|
182
|
-
}
|
|
183
|
-
_watchForBoundsChanges() {
|
|
184
|
-
this._bounds.pipe(takeUntil(this._destroyed)).subscribe(bounds => {
|
|
185
|
-
if (bounds) {
|
|
186
|
-
this._assertInitialized();
|
|
187
|
-
this.rectangle.setBounds(bounds);
|
|
188
|
-
}
|
|
189
|
-
});
|
|
190
|
-
}
|
|
191
|
-
_assertInitialized() {
|
|
192
|
-
if (typeof ngDevMode === 'undefined' || ngDevMode) {
|
|
193
|
-
if (!this.rectangle) {
|
|
194
|
-
throw Error('Cannot interact with a Google Map Rectangle before it has been initialized. ' +
|
|
195
|
-
'Please wait for the Rectangle to load before trying to interact with it.');
|
|
196
|
-
}
|
|
197
|
-
}
|
|
198
|
-
}
|
|
199
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0-next.2", ngImport: i0, type: MapRectangle, deps: [{ token: i1.GoogleMap }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
200
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.0-next.2", type: MapRectangle, isStandalone: true, selector: "map-rectangle", inputs: { options: "options", bounds: "bounds" }, outputs: { boundsChanged: "boundsChanged", rectangleClick: "rectangleClick", rectangleDblclick: "rectangleDblclick", rectangleDrag: "rectangleDrag", rectangleDragend: "rectangleDragend", rectangleDragstart: "rectangleDragstart", rectangleMousedown: "rectangleMousedown", rectangleMousemove: "rectangleMousemove", rectangleMouseout: "rectangleMouseout", rectangleMouseover: "rectangleMouseover", rectangleMouseup: "rectangleMouseup", rectangleRightclick: "rectangleRightclick", rectangleInitialized: "rectangleInitialized" }, exportAs: ["mapRectangle"], ngImport: i0 }); }
|
|
201
|
-
}
|
|
202
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0-next.2", ngImport: i0, type: MapRectangle, decorators: [{
|
|
203
|
-
type: Directive,
|
|
204
|
-
args: [{
|
|
205
|
-
selector: 'map-rectangle',
|
|
206
|
-
exportAs: 'mapRectangle',
|
|
207
|
-
standalone: true,
|
|
208
|
-
}]
|
|
209
|
-
}], ctorParameters: () => [{ type: i1.GoogleMap }, { type: i0.NgZone }], propDecorators: { options: [{
|
|
210
|
-
type: Input
|
|
211
|
-
}], bounds: [{
|
|
212
|
-
type: Input
|
|
213
|
-
}], boundsChanged: [{
|
|
214
|
-
type: Output
|
|
215
|
-
}], rectangleClick: [{
|
|
216
|
-
type: Output
|
|
217
|
-
}], rectangleDblclick: [{
|
|
218
|
-
type: Output
|
|
219
|
-
}], rectangleDrag: [{
|
|
220
|
-
type: Output
|
|
221
|
-
}], rectangleDragend: [{
|
|
222
|
-
type: Output
|
|
223
|
-
}], rectangleDragstart: [{
|
|
224
|
-
type: Output
|
|
225
|
-
}], rectangleMousedown: [{
|
|
226
|
-
type: Output
|
|
227
|
-
}], rectangleMousemove: [{
|
|
228
|
-
type: Output
|
|
229
|
-
}], rectangleMouseout: [{
|
|
230
|
-
type: Output
|
|
231
|
-
}], rectangleMouseover: [{
|
|
232
|
-
type: Output
|
|
233
|
-
}], rectangleMouseup: [{
|
|
234
|
-
type: Output
|
|
235
|
-
}], rectangleRightclick: [{
|
|
236
|
-
type: Output
|
|
237
|
-
}], rectangleInitialized: [{
|
|
238
|
-
type: Output
|
|
239
|
-
}] } });
|
|
240
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-rectangle.js","sourceRoot":"","sources":["../../../../../../src/google-maps/map-rectangle/map-rectangle.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 Rectangle via the Google Maps JavaScript API.\n *\n * See developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle\n */\n@Directive({\n  selector: 'map-rectangle',\n  exportAs: 'mapRectangle',\n  standalone: true,\n})\nexport class MapRectangle implements OnInit, OnDestroy {\n  private _eventManager = new MapEventManager(inject(NgZone));\n  private readonly _options = new BehaviorSubject<google.maps.RectangleOptions>({});\n  private readonly _bounds = new BehaviorSubject<\n    google.maps.LatLngBounds | google.maps.LatLngBoundsLiteral | undefined\n  >(undefined);\n\n  private readonly _destroyed = new Subject<void>();\n\n  /**\n   * The underlying google.maps.Rectangle object.\n   *\n   * See developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle\n   */\n  rectangle?: google.maps.Rectangle;\n\n  @Input()\n  set options(options: google.maps.RectangleOptions) {\n    this._options.next(options || {});\n  }\n\n  @Input()\n  set bounds(bounds: google.maps.LatLngBounds | google.maps.LatLngBoundsLiteral) {\n    this._bounds.next(bounds);\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.boundsChanged\n   */ @Output() readonly boundsChanged: Observable<void> =\n    this._eventManager.getLazyEmitter<void>('bounds_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.click\n   */\n  @Output() readonly rectangleClick: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('click');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.dblclick\n   */\n  @Output() readonly rectangleDblclick: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('dblclick');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.drag\n   */\n  @Output() readonly rectangleDrag: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('drag');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.dragend\n   */\n  @Output() readonly rectangleDragend: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('dragend');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.dragstart\n   */\n  @Output() readonly rectangleDragstart: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('dragstart');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.mousedown\n   */\n  @Output() readonly rectangleMousedown: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('mousedown');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.mousemove\n   */\n  @Output() readonly rectangleMousemove: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('mousemove');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.mouseout\n   */\n  @Output() readonly rectangleMouseout: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('mouseout');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.mouseover\n   */\n  @Output() readonly rectangleMouseover: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('mouseover');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.mouseup\n   */\n  @Output() readonly rectangleMouseup: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('mouseup');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.rightclick\n   */\n  @Output() readonly rectangleRightclick: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('rightclick');\n\n  /** Event emitted when the rectangle is initialized. */\n  @Output() readonly rectangleInitialized: EventEmitter<google.maps.Rectangle> =\n    new EventEmitter<google.maps.Rectangle>();\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.Rectangle && this._map.googleMap) {\n            this._initialize(this._map.googleMap, google.maps.Rectangle, 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).Rectangle, options);\n                },\n              );\n            });\n          }\n        });\n    }\n  }\n\n  private _initialize(\n    map: google.maps.Map,\n    rectangleConstructor: typeof google.maps.Rectangle,\n    options: google.maps.RectangleOptions,\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.rectangle = new rectangleConstructor(options);\n      this._assertInitialized();\n      this.rectangle.setMap(map);\n      this._eventManager.setTarget(this.rectangle);\n      this.rectangleInitialized.emit(this.rectangle);\n      this._watchForOptionsChanges();\n      this._watchForBoundsChanges();\n    });\n  }\n\n  ngOnDestroy() {\n    this._eventManager.destroy();\n    this._destroyed.next();\n    this._destroyed.complete();\n    this.rectangle?.setMap(null);\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.getBounds\n   */\n  getBounds(): google.maps.LatLngBounds | null {\n    this._assertInitialized();\n    return this.rectangle.getBounds();\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.getDraggable\n   */\n  getDraggable(): boolean {\n    this._assertInitialized();\n    return this.rectangle.getDraggable();\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.getEditable\n   */\n  getEditable(): boolean {\n    this._assertInitialized();\n    return this.rectangle.getEditable();\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Rectangle.getVisible\n   */\n  getVisible(): boolean {\n    this._assertInitialized();\n    return this.rectangle.getVisible();\n  }\n\n  private _combineOptions(): Observable<google.maps.RectangleOptions> {\n    return combineLatest([this._options, this._bounds]).pipe(\n      map(([options, bounds]) => {\n        const combinedOptions: google.maps.RectangleOptions = {\n          ...options,\n          bounds: bounds || options.bounds,\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.rectangle.setOptions(options);\n    });\n  }\n\n  private _watchForBoundsChanges() {\n    this._bounds.pipe(takeUntil(this._destroyed)).subscribe(bounds => {\n      if (bounds) {\n        this._assertInitialized();\n        this.rectangle.setBounds(bounds);\n      }\n    });\n  }\n\n  private _assertInitialized(): asserts this is {rectangle: google.maps.Rectangle} {\n    if (typeof ngDevMode === 'undefined' || ngDevMode) {\n      if (!this.rectangle) {\n        throw Error(\n          'Cannot interact with a Google Map Rectangle before it has been initialized. ' +\n            'Please wait for the Rectangle to load before trying to interact with it.',\n        );\n      }\n    }\n  }\n}\n"]}
|
|
@@ -1,103 +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, EventEmitter, Input, NgZone, Output } from '@angular/core';
|
|
11
|
-
import { BehaviorSubject, Subject } from 'rxjs';
|
|
12
|
-
import { map, take, takeUntil } from 'rxjs/operators';
|
|
13
|
-
import { GoogleMap } from '../google-map/google-map';
|
|
14
|
-
import * as i0 from "@angular/core";
|
|
15
|
-
import * as i1 from "../google-map/google-map";
|
|
16
|
-
/**
|
|
17
|
-
* Angular component that renders a Google Maps Traffic Layer via the Google Maps JavaScript API.
|
|
18
|
-
*
|
|
19
|
-
* See developers.google.com/maps/documentation/javascript/reference/map#TrafficLayer
|
|
20
|
-
*/
|
|
21
|
-
export class MapTrafficLayer {
|
|
22
|
-
/**
|
|
23
|
-
* Whether the traffic layer refreshes with updated information automatically.
|
|
24
|
-
*/
|
|
25
|
-
set autoRefresh(autoRefresh) {
|
|
26
|
-
this._autoRefresh.next(autoRefresh);
|
|
27
|
-
}
|
|
28
|
-
constructor(_map, _ngZone) {
|
|
29
|
-
this._map = _map;
|
|
30
|
-
this._ngZone = _ngZone;
|
|
31
|
-
this._autoRefresh = new BehaviorSubject(true);
|
|
32
|
-
this._destroyed = new Subject();
|
|
33
|
-
/** Event emitted when the traffic layer is initialized. */
|
|
34
|
-
this.trafficLayerInitialized = new EventEmitter();
|
|
35
|
-
}
|
|
36
|
-
ngOnInit() {
|
|
37
|
-
if (this._map._isBrowser) {
|
|
38
|
-
this._combineOptions()
|
|
39
|
-
.pipe(take(1))
|
|
40
|
-
.subscribe(options => {
|
|
41
|
-
if (google.maps.TrafficLayer && this._map.googleMap) {
|
|
42
|
-
this._initialize(this._map.googleMap, google.maps.TrafficLayer, options);
|
|
43
|
-
}
|
|
44
|
-
else {
|
|
45
|
-
this._ngZone.runOutsideAngular(() => {
|
|
46
|
-
Promise.all([this._map._resolveMap(), google.maps.importLibrary('maps')]).then(([map, lib]) => {
|
|
47
|
-
this._initialize(map, lib.TrafficLayer, options);
|
|
48
|
-
});
|
|
49
|
-
});
|
|
50
|
-
}
|
|
51
|
-
});
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
_initialize(map, layerConstructor, options) {
|
|
55
|
-
this._ngZone.runOutsideAngular(() => {
|
|
56
|
-
this.trafficLayer = new layerConstructor(options);
|
|
57
|
-
this._assertInitialized();
|
|
58
|
-
this.trafficLayer.setMap(map);
|
|
59
|
-
this.trafficLayerInitialized.emit(this.trafficLayer);
|
|
60
|
-
this._watchForAutoRefreshChanges();
|
|
61
|
-
});
|
|
62
|
-
}
|
|
63
|
-
ngOnDestroy() {
|
|
64
|
-
this._destroyed.next();
|
|
65
|
-
this._destroyed.complete();
|
|
66
|
-
this.trafficLayer?.setMap(null);
|
|
67
|
-
}
|
|
68
|
-
_combineOptions() {
|
|
69
|
-
return this._autoRefresh.pipe(map(autoRefresh => {
|
|
70
|
-
const combinedOptions = { autoRefresh };
|
|
71
|
-
return combinedOptions;
|
|
72
|
-
}));
|
|
73
|
-
}
|
|
74
|
-
_watchForAutoRefreshChanges() {
|
|
75
|
-
this._combineOptions()
|
|
76
|
-
.pipe(takeUntil(this._destroyed))
|
|
77
|
-
.subscribe(options => {
|
|
78
|
-
this._assertInitialized();
|
|
79
|
-
this.trafficLayer.setOptions(options);
|
|
80
|
-
});
|
|
81
|
-
}
|
|
82
|
-
_assertInitialized() {
|
|
83
|
-
if (!this.trafficLayer) {
|
|
84
|
-
throw Error('Cannot interact with a Google Map Traffic Layer before it has been initialized. ' +
|
|
85
|
-
'Please wait for the Traffic Layer to load before trying to interact with it.');
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0-next.2", ngImport: i0, type: MapTrafficLayer, deps: [{ token: i1.GoogleMap }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
89
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.0-next.2", type: MapTrafficLayer, isStandalone: true, selector: "map-traffic-layer", inputs: { autoRefresh: "autoRefresh" }, outputs: { trafficLayerInitialized: "trafficLayerInitialized" }, exportAs: ["mapTrafficLayer"], ngImport: i0 }); }
|
|
90
|
-
}
|
|
91
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0-next.2", ngImport: i0, type: MapTrafficLayer, decorators: [{
|
|
92
|
-
type: Directive,
|
|
93
|
-
args: [{
|
|
94
|
-
selector: 'map-traffic-layer',
|
|
95
|
-
exportAs: 'mapTrafficLayer',
|
|
96
|
-
standalone: true,
|
|
97
|
-
}]
|
|
98
|
-
}], ctorParameters: () => [{ type: i1.GoogleMap }, { type: i0.NgZone }], propDecorators: { autoRefresh: [{
|
|
99
|
-
type: Input
|
|
100
|
-
}], trafficLayerInitialized: [{
|
|
101
|
-
type: Output
|
|
102
|
-
}] } });
|
|
103
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-traffic-layer.js","sourceRoot":"","sources":["../../../../../../src/google-maps/map-traffic-layer/map-traffic-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=\"google.maps\" preserve=\"true\" />\n\nimport {Directive, EventEmitter, Input, NgZone, OnDestroy, OnInit, Output} from '@angular/core';\nimport {BehaviorSubject, Observable, Subject} from 'rxjs';\nimport {map, take, takeUntil} from 'rxjs/operators';\n\nimport {GoogleMap} from '../google-map/google-map';\n\n/**\n * Angular component that renders a Google Maps Traffic Layer via the Google Maps JavaScript API.\n *\n * See developers.google.com/maps/documentation/javascript/reference/map#TrafficLayer\n */\n@Directive({\n  selector: 'map-traffic-layer',\n  exportAs: 'mapTrafficLayer',\n  standalone: true,\n})\nexport class MapTrafficLayer implements OnInit, OnDestroy {\n  private readonly _autoRefresh = new BehaviorSubject<boolean>(true);\n  private readonly _destroyed = new Subject<void>();\n\n  /**\n   * The underlying google.maps.TrafficLayer object.\n   *\n   * See developers.google.com/maps/documentation/javascript/reference/map#TrafficLayer\n   */\n  trafficLayer?: google.maps.TrafficLayer;\n\n  /**\n   * Whether the traffic layer refreshes with updated information automatically.\n   */\n  @Input()\n  set autoRefresh(autoRefresh: boolean) {\n    this._autoRefresh.next(autoRefresh);\n  }\n\n  /** Event emitted when the traffic layer is initialized. */\n  @Output() readonly trafficLayerInitialized: EventEmitter<google.maps.TrafficLayer> =\n    new EventEmitter<google.maps.TrafficLayer>();\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.TrafficLayer && this._map.googleMap) {\n            this._initialize(this._map.googleMap, google.maps.TrafficLayer, 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).TrafficLayer, options);\n                },\n              );\n            });\n          }\n        });\n    }\n  }\n\n  private _initialize(\n    map: google.maps.Map,\n    layerConstructor: typeof google.maps.TrafficLayer,\n    options: google.maps.TrafficLayerOptions,\n  ) {\n    this._ngZone.runOutsideAngular(() => {\n      this.trafficLayer = new layerConstructor(options);\n      this._assertInitialized();\n      this.trafficLayer.setMap(map);\n      this.trafficLayerInitialized.emit(this.trafficLayer);\n      this._watchForAutoRefreshChanges();\n    });\n  }\n\n  ngOnDestroy() {\n    this._destroyed.next();\n    this._destroyed.complete();\n    this.trafficLayer?.setMap(null);\n  }\n\n  private _combineOptions(): Observable<google.maps.TrafficLayerOptions> {\n    return this._autoRefresh.pipe(\n      map(autoRefresh => {\n        const combinedOptions: google.maps.TrafficLayerOptions = {autoRefresh};\n        return combinedOptions;\n      }),\n    );\n  }\n\n  private _watchForAutoRefreshChanges() {\n    this._combineOptions()\n      .pipe(takeUntil(this._destroyed))\n      .subscribe(options => {\n        this._assertInitialized();\n        this.trafficLayer.setOptions(options);\n      });\n  }\n\n  private _assertInitialized(): asserts this is {trafficLayer: google.maps.TrafficLayer} {\n    if (!this.trafficLayer) {\n      throw Error(\n        'Cannot interact with a Google Map Traffic Layer before it has been initialized. ' +\n          'Please wait for the Traffic Layer to load before trying to interact with it.',\n      );\n    }\n  }\n}\n"]}
|
|
@@ -1,69 +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, EventEmitter, NgZone, Output, inject } from '@angular/core';
|
|
11
|
-
import { GoogleMap } from '../google-map/google-map';
|
|
12
|
-
import * as i0 from "@angular/core";
|
|
13
|
-
/**
|
|
14
|
-
* Angular component that renders a Google Maps Transit Layer via the Google Maps JavaScript API.
|
|
15
|
-
*
|
|
16
|
-
* See developers.google.com/maps/documentation/javascript/reference/map#TransitLayer
|
|
17
|
-
*/
|
|
18
|
-
export class MapTransitLayer {
|
|
19
|
-
constructor() {
|
|
20
|
-
this._map = inject(GoogleMap);
|
|
21
|
-
this._zone = inject(NgZone);
|
|
22
|
-
/** Event emitted when the transit layer is initialized. */
|
|
23
|
-
this.transitLayerInitialized = new EventEmitter();
|
|
24
|
-
}
|
|
25
|
-
ngOnInit() {
|
|
26
|
-
if (this._map._isBrowser) {
|
|
27
|
-
if (google.maps.TransitLayer && this._map.googleMap) {
|
|
28
|
-
this._initialize(this._map.googleMap, google.maps.TransitLayer);
|
|
29
|
-
}
|
|
30
|
-
else {
|
|
31
|
-
this._zone.runOutsideAngular(() => {
|
|
32
|
-
Promise.all([this._map._resolveMap(), google.maps.importLibrary('maps')]).then(([map, lib]) => {
|
|
33
|
-
this._initialize(map, lib.TransitLayer);
|
|
34
|
-
});
|
|
35
|
-
});
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
_initialize(map, layerConstructor) {
|
|
40
|
-
this._zone.runOutsideAngular(() => {
|
|
41
|
-
this.transitLayer = new layerConstructor();
|
|
42
|
-
this.transitLayerInitialized.emit(this.transitLayer);
|
|
43
|
-
this._assertLayerInitialized();
|
|
44
|
-
this.transitLayer.setMap(map);
|
|
45
|
-
});
|
|
46
|
-
}
|
|
47
|
-
ngOnDestroy() {
|
|
48
|
-
this.transitLayer?.setMap(null);
|
|
49
|
-
}
|
|
50
|
-
_assertLayerInitialized() {
|
|
51
|
-
if (!this.transitLayer) {
|
|
52
|
-
throw Error('Cannot interact with a Google Map Transit Layer before it has been initialized. ' +
|
|
53
|
-
'Please wait for the Transit Layer to load before trying to interact with it.');
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0-next.2", ngImport: i0, type: MapTransitLayer, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
57
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.0-next.2", type: MapTransitLayer, isStandalone: true, selector: "map-transit-layer", outputs: { transitLayerInitialized: "transitLayerInitialized" }, exportAs: ["mapTransitLayer"], ngImport: i0 }); }
|
|
58
|
-
}
|
|
59
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0-next.2", ngImport: i0, type: MapTransitLayer, decorators: [{
|
|
60
|
-
type: Directive,
|
|
61
|
-
args: [{
|
|
62
|
-
selector: 'map-transit-layer',
|
|
63
|
-
exportAs: 'mapTransitLayer',
|
|
64
|
-
standalone: true,
|
|
65
|
-
}]
|
|
66
|
-
}], propDecorators: { transitLayerInitialized: [{
|
|
67
|
-
type: Output
|
|
68
|
-
}] } });
|
|
69
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwLXRyYW5zaXQtbGF5ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvZ29vZ2xlLW1hcHMvbWFwLXRyYW5zaXQtbGF5ZXIvbWFwLXRyYW5zaXQtbGF5ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUgseUVBQXlFO0FBQ3pFLHFEQUFxRDtBQUVyRCxPQUFPLEVBQUMsU0FBUyxFQUFFLFlBQVksRUFBRSxNQUFNLEVBQXFCLE1BQU0sRUFBRSxNQUFNLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFFakcsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLDBCQUEwQixDQUFDOztBQUVuRDs7OztHQUlHO0FBTUgsTUFBTSxPQUFPLGVBQWU7SUFMNUI7UUFNVSxTQUFJLEdBQUcsTUFBTSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQ3pCLFVBQUssR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUM7UUFTL0IsMkRBQTJEO1FBQ3hDLDRCQUF1QixHQUN4QyxJQUFJLFlBQVksRUFBNEIsQ0FBQztLQXVDaEQ7SUFyQ0MsUUFBUTtRQUNOLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztZQUN6QixJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsWUFBWSxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7Z0JBQ3BELElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsTUFBTSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztZQUNsRSxDQUFDO2lCQUFNLENBQUM7Z0JBQ04sSUFBSSxDQUFDLEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxHQUFHLEVBQUU7b0JBQ2hDLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxFQUFFLE1BQU0sQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQzVFLENBQUMsQ0FBQyxHQUFHLEVBQUUsR0FBRyxDQUFDLEVBQUUsRUFBRTt3QkFDYixJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsRUFBRyxHQUErQixDQUFDLFlBQVksQ0FBQyxDQUFDO29CQUN2RSxDQUFDLENBQ0YsQ0FBQztnQkFDSixDQUFDLENBQUMsQ0FBQztZQUNMLENBQUM7UUFDSCxDQUFDO0lBQ0gsQ0FBQztJQUVPLFdBQVcsQ0FBQyxHQUFvQixFQUFFLGdCQUFpRDtRQUN6RixJQUFJLENBQUMsS0FBSyxDQUFDLGlCQUFpQixDQUFDLEdBQUcsRUFBRTtZQUNoQyxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksZ0JBQWdCLEVBQUUsQ0FBQztZQUMzQyxJQUFJLENBQUMsdUJBQXVCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztZQUNyRCxJQUFJLENBQUMsdUJBQXVCLEVBQUUsQ0FBQztZQUMvQixJQUFJLENBQUMsWUFBWSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUNoQyxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLFlBQVksRUFBRSxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDbEMsQ0FBQztJQUVPLHVCQUF1QjtRQUM3QixJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO1lBQ3ZCLE1BQU0sS0FBSyxDQUNULGtGQUFrRjtnQkFDaEYsOEVBQThFLENBQ2pGLENBQUM7UUFDSixDQUFDO0lBQ0gsQ0FBQztxSEFuRFUsZUFBZTt5R0FBZixlQUFlOztrR0FBZixlQUFlO2tCQUwzQixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxtQkFBbUI7b0JBQzdCLFFBQVEsRUFBRSxpQkFBaUI7b0JBQzNCLFVBQVUsRUFBRSxJQUFJO2lCQUNqQjs4QkFhb0IsdUJBQXVCO3NCQUF6QyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbi8vIFdvcmthcm91bmQgZm9yOiBodHRwczovL2dpdGh1Yi5jb20vYmF6ZWxidWlsZC9ydWxlc19ub2RlanMvaXNzdWVzLzEyNjVcbi8vLyA8cmVmZXJlbmNlIHR5cGVzPVwiZ29vZ2xlLm1hcHNcIiBwcmVzZXJ2ZT1cInRydWVcIiAvPlxuXG5pbXBvcnQge0RpcmVjdGl2ZSwgRXZlbnRFbWl0dGVyLCBOZ1pvbmUsIE9uRGVzdHJveSwgT25Jbml0LCBPdXRwdXQsIGluamVjdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7R29vZ2xlTWFwfSBmcm9tICcuLi9nb29nbGUtbWFwL2dvb2dsZS1tYXAnO1xuXG4vKipcbiAqIEFuZ3VsYXIgY29tcG9uZW50IHRoYXQgcmVuZGVycyBhIEdvb2dsZSBNYXBzIFRyYW5zaXQgTGF5ZXIgdmlhIHRoZSBHb29nbGUgTWFwcyBKYXZhU2NyaXB0IEFQSS5cbiAqXG4gKiBTZWUgZGV2ZWxvcGVycy5nb29nbGUuY29tL21hcHMvZG9jdW1lbnRhdGlvbi9qYXZhc2NyaXB0L3JlZmVyZW5jZS9tYXAjVHJhbnNpdExheWVyXG4gKi9cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ21hcC10cmFuc2l0LWxheWVyJyxcbiAgZXhwb3J0QXM6ICdtYXBUcmFuc2l0TGF5ZXInLFxuICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBNYXBUcmFuc2l0TGF5ZXIgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XG4gIHByaXZhdGUgX21hcCA9IGluamVjdChHb29nbGVNYXApO1xuICBwcml2YXRlIF96b25lID0gaW5qZWN0KE5nWm9uZSk7XG5cbiAgLyoqXG4gICAqIFRoZSB1bmRlcmx5aW5nIGdvb2dsZS5tYXBzLlRyYW5zaXRMYXllciBvYmplY3QuXG4gICAqXG4gICAqIFNlZSBkZXZlbG9wZXJzLmdvb2dsZS5jb20vbWFwcy9kb2N1bWVudGF0aW9uL2phdmFzY3JpcHQvcmVmZXJlbmNlL21hcCNUcmFuc2l0TGF5ZXJcbiAgICovXG4gIHRyYW5zaXRMYXllcj86IGdvb2dsZS5tYXBzLlRyYW5zaXRMYXllcjtcblxuICAvKiogRXZlbnQgZW1pdHRlZCB3aGVuIHRoZSB0cmFuc2l0IGxheWVyIGlzIGluaXRpYWxpemVkLiAqL1xuICBAT3V0cHV0KCkgcmVhZG9ubHkgdHJhbnNpdExheWVySW5pdGlhbGl6ZWQ6IEV2ZW50RW1pdHRlcjxnb29nbGUubWFwcy5UcmFuc2l0TGF5ZXI+ID1cbiAgICBuZXcgRXZlbnRFbWl0dGVyPGdvb2dsZS5tYXBzLlRyYW5zaXRMYXllcj4oKTtcblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5fbWFwLl9pc0Jyb3dzZXIpIHtcbiAgICAgIGlmIChnb29nbGUubWFwcy5UcmFuc2l0TGF5ZXIgJiYgdGhpcy5fbWFwLmdvb2dsZU1hcCkge1xuICAgICAgICB0aGlzLl9pbml0aWFsaXplKHRoaXMuX21hcC5nb29nbGVNYXAsIGdvb2dsZS5tYXBzLlRyYW5zaXRMYXllcik7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICB0aGlzLl96b25lLnJ1bk91dHNpZGVBbmd1bGFyKCgpID0+IHtcbiAgICAgICAgICBQcm9taXNlLmFsbChbdGhpcy5fbWFwLl9yZXNvbHZlTWFwKCksIGdvb2dsZS5tYXBzLmltcG9ydExpYnJhcnkoJ21hcHMnKV0pLnRoZW4oXG4gICAgICAgICAgICAoW21hcCwgbGliXSkgPT4ge1xuICAgICAgICAgICAgICB0aGlzLl9pbml0aWFsaXplKG1hcCwgKGxpYiBhcyBnb29nbGUubWFwcy5NYXBzTGlicmFyeSkuVHJhbnNpdExheWVyKTtcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgKTtcbiAgICAgICAgfSk7XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgcHJpdmF0ZSBfaW5pdGlhbGl6ZShtYXA6IGdvb2dsZS5tYXBzLk1hcCwgbGF5ZXJDb25zdHJ1Y3RvcjogdHlwZW9mIGdvb2dsZS5tYXBzLlRyYW5zaXRMYXllcikge1xuICAgIHRoaXMuX3pvbmUucnVuT3V0c2lkZUFuZ3VsYXIoKCkgPT4ge1xuICAgICAgdGhpcy50cmFuc2l0TGF5ZXIgPSBuZXcgbGF5ZXJDb25zdHJ1Y3RvcigpO1xuICAgICAgdGhpcy50cmFuc2l0TGF5ZXJJbml0aWFsaXplZC5lbWl0KHRoaXMudHJhbnNpdExheWVyKTtcbiAgICAgIHRoaXMuX2Fzc2VydExheWVySW5pdGlhbGl6ZWQoKTtcbiAgICAgIHRoaXMudHJhbnNpdExheWVyLnNldE1hcChtYXApO1xuICAgIH0pO1xuICB9XG5cbiAgbmdPbkRlc3Ryb3koKSB7XG4gICAgdGhpcy50cmFuc2l0TGF5ZXI/LnNldE1hcChudWxsKTtcbiAgfVxuXG4gIHByaXZhdGUgX2Fzc2VydExheWVySW5pdGlhbGl6ZWQoKTogYXNzZXJ0cyB0aGlzIGlzIHt0cmFuc2l0TGF5ZXI6IGdvb2dsZS5tYXBzLlRyYW5zaXRMYXllcn0ge1xuICAgIGlmICghdGhpcy50cmFuc2l0TGF5ZXIpIHtcbiAgICAgIHRocm93IEVycm9yKFxuICAgICAgICAnQ2Fubm90IGludGVyYWN0IHdpdGggYSBHb29nbGUgTWFwIFRyYW5zaXQgTGF5ZXIgYmVmb3JlIGl0IGhhcyBiZWVuIGluaXRpYWxpemVkLiAnICtcbiAgICAgICAgICAnUGxlYXNlIHdhaXQgZm9yIHRoZSBUcmFuc2l0IExheWVyIHRvIGxvYWQgYmVmb3JlIHRyeWluZyB0byBpbnRlcmFjdCB3aXRoIGl0LicsXG4gICAgICApO1xuICAgIH1cbiAgfVxufVxuIl19
|
package/esm2022/public-api.mjs
DELETED
|
@@ -1,29 +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
|
-
export { GoogleMap } from './google-map/google-map';
|
|
9
|
-
export { GoogleMapsModule } from './google-maps-module';
|
|
10
|
-
export { MapBaseLayer } from './map-base-layer';
|
|
11
|
-
export { MapBicyclingLayer } from './map-bicycling-layer/map-bicycling-layer';
|
|
12
|
-
export { MapCircle } from './map-circle/map-circle';
|
|
13
|
-
export { MapDirectionsRenderer } from './map-directions-renderer/map-directions-renderer';
|
|
14
|
-
export { MapDirectionsService, } from './map-directions-renderer/map-directions-service';
|
|
15
|
-
export { MapGroundOverlay } from './map-ground-overlay/map-ground-overlay';
|
|
16
|
-
export { MapInfoWindow } from './map-info-window/map-info-window';
|
|
17
|
-
export { MapKmlLayer } from './map-kml-layer/map-kml-layer';
|
|
18
|
-
export { MapMarker } from './map-marker/map-marker';
|
|
19
|
-
export { MapAdvancedMarker } from './map-advanced-marker/map-advanced-marker';
|
|
20
|
-
export { MapMarkerClusterer } from './map-marker-clusterer/map-marker-clusterer';
|
|
21
|
-
export { MapPolygon } from './map-polygon/map-polygon';
|
|
22
|
-
export { MapPolyline } from './map-polyline/map-polyline';
|
|
23
|
-
export { MapRectangle } from './map-rectangle/map-rectangle';
|
|
24
|
-
export { MapTrafficLayer } from './map-traffic-layer/map-traffic-layer';
|
|
25
|
-
export { MapTransitLayer } from './map-transit-layer/map-transit-layer';
|
|
26
|
-
export { MapHeatmapLayer } from './map-heatmap-layer/map-heatmap-layer';
|
|
27
|
-
export { MapGeocoder } from './map-geocoder/map-geocoder';
|
|
28
|
-
export { MapEventManager } from './map-event-manager';
|
|
29
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9nb29nbGUtbWFwcy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRztBQUVILE9BQU8sRUFBQyxTQUFTLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUNsRCxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUV0RCxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0sa0JBQWtCLENBQUM7QUFDOUMsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sMkNBQTJDLENBQUM7QUFDNUUsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ2xELE9BQU8sRUFBQyxxQkFBcUIsRUFBQyxNQUFNLG1EQUFtRCxDQUFDO0FBQ3hGLE9BQU8sRUFDTCxvQkFBb0IsR0FFckIsTUFBTSxrREFBa0QsQ0FBQztBQUMxRCxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSx5Q0FBeUMsQ0FBQztBQUN6RSxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDaEUsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLCtCQUErQixDQUFDO0FBQzFELE9BQU8sRUFBQyxTQUFTLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUNsRCxPQUFPLEVBQUMsaUJBQWlCLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQUM1RSxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSw2Q0FBNkMsQ0FBQztBQUMvRSxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sMkJBQTJCLENBQUM7QUFDckQsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLDZCQUE2QixDQUFDO0FBQ3hELE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSwrQkFBK0IsQ0FBQztBQUMzRCxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sdUNBQXVDLENBQUM7QUFDdEUsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLHVDQUF1QyxDQUFDO0FBQ3RFLE9BQU8sRUFBQyxlQUFlLEVBQWMsTUFBTSx1Q0FBdUMsQ0FBQztBQUNuRixPQUFPLEVBQUMsV0FBVyxFQUFzQixNQUFNLDZCQUE2QixDQUFDO0FBTzdFLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5leHBvcnQge0dvb2dsZU1hcH0gZnJvbSAnLi9nb29nbGUtbWFwL2dvb2dsZS1tYXAnO1xuZXhwb3J0IHtHb29nbGVNYXBzTW9kdWxlfSBmcm9tICcuL2dvb2dsZS1tYXBzLW1vZHVsZSc7XG5leHBvcnQge01hcEFuY2hvclBvaW50fSBmcm9tICcuL21hcC1hbmNob3ItcG9pbnQnO1xuZXhwb3J0IHtNYXBCYXNlTGF5ZXJ9IGZyb20gJy4vbWFwLWJhc2UtbGF5ZXInO1xuZXhwb3J0IHtNYXBCaWN5Y2xpbmdMYXllcn0gZnJvbSAnLi9tYXAtYmljeWNsaW5nLWxheWVyL21hcC1iaWN5Y2xpbmctbGF5ZXInO1xuZXhwb3J0IHtNYXBDaXJjbGV9IGZyb20gJy4vbWFwLWNpcmNsZS9tYXAtY2lyY2xlJztcbmV4cG9ydCB7TWFwRGlyZWN0aW9uc1JlbmRlcmVyfSBmcm9tICcuL21hcC1kaXJlY3Rpb25zLXJlbmRlcmVyL21hcC1kaXJlY3Rpb25zLXJlbmRlcmVyJztcbmV4cG9ydCB7XG4gIE1hcERpcmVjdGlvbnNTZXJ2aWNlLFxuICBNYXBEaXJlY3Rpb25zUmVzcG9uc2UsXG59IGZyb20gJy4vbWFwLWRpcmVjdGlvbnMtcmVuZGVyZXIvbWFwLWRpcmVjdGlvbnMtc2VydmljZSc7XG5leHBvcnQge01hcEdyb3VuZE92ZXJsYXl9IGZyb20gJy4vbWFwLWdyb3VuZC1vdmVybGF5L21hcC1ncm91bmQtb3ZlcmxheSc7XG5leHBvcnQge01hcEluZm9XaW5kb3d9IGZyb20gJy4vbWFwLWluZm8td2luZG93L21hcC1pbmZvLXdpbmRvdyc7XG5leHBvcnQge01hcEttbExheWVyfSBmcm9tICcuL21hcC1rbWwtbGF5ZXIvbWFwLWttbC1sYXllcic7XG5leHBvcnQge01hcE1hcmtlcn0gZnJvbSAnLi9tYXAtbWFya2VyL21hcC1tYXJrZXInO1xuZXhwb3J0IHtNYXBBZHZhbmNlZE1hcmtlcn0gZnJvbSAnLi9tYXAtYWR2YW5jZWQtbWFya2VyL21hcC1hZHZhbmNlZC1tYXJrZXInO1xuZXhwb3J0IHtNYXBNYXJrZXJDbHVzdGVyZXJ9IGZyb20gJy4vbWFwLW1hcmtlci1jbHVzdGVyZXIvbWFwLW1hcmtlci1jbHVzdGVyZXInO1xuZXhwb3J0IHtNYXBQb2x5Z29ufSBmcm9tICcuL21hcC1wb2x5Z29uL21hcC1wb2x5Z29uJztcbmV4cG9ydCB7TWFwUG9seWxpbmV9IGZyb20gJy4vbWFwLXBvbHlsaW5lL21hcC1wb2x5bGluZSc7XG5leHBvcnQge01hcFJlY3RhbmdsZX0gZnJvbSAnLi9tYXAtcmVjdGFuZ2xlL21hcC1yZWN0YW5nbGUnO1xuZXhwb3J0IHtNYXBUcmFmZmljTGF5ZXJ9IGZyb20gJy4vbWFwLXRyYWZmaWMtbGF5ZXIvbWFwLXRyYWZmaWMtbGF5ZXInO1xuZXhwb3J0IHtNYXBUcmFuc2l0TGF5ZXJ9IGZyb20gJy4vbWFwLXRyYW5zaXQtbGF5ZXIvbWFwLXRyYW5zaXQtbGF5ZXInO1xuZXhwb3J0IHtNYXBIZWF0bWFwTGF5ZXIsIEhlYXRtYXBEYXRhfSBmcm9tICcuL21hcC1oZWF0bWFwLWxheWVyL21hcC1oZWF0bWFwLWxheWVyJztcbmV4cG9ydCB7TWFwR2VvY29kZXIsIE1hcEdlb2NvZGVyUmVzcG9uc2V9IGZyb20gJy4vbWFwLWdlb2NvZGVyL21hcC1nZW9jb2Rlcic7XG5leHBvcnQge1xuICBNYXJrZXJDbHVzdGVyZXJPcHRpb25zLFxuICBDbHVzdGVySWNvblN0eWxlLFxuICBBcmlhTGFiZWxGbixcbiAgQ2FsY3VsYXRvcixcbn0gZnJvbSAnLi9tYXAtbWFya2VyLWNsdXN0ZXJlci9tYXJrZXItY2x1c3RlcmVyLXR5cGVzJztcbmV4cG9ydCB7TWFwRXZlbnRNYW5hZ2VyfSBmcm9tICcuL21hcC1ldmVudC1tYW5hZ2VyJztcbiJdfQ==
|