Socket
Socket
Sign inDemoInstall

@angular/google-maps

Package Overview
Dependencies
6
Maintainers
2
Versions
366
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

Comparing version 9.0.0-rc.4 to 9.0.0-rc.5

esm2015/map-event-manager.js

717

bundles/google-maps.umd.js

@@ -14,2 +14,73 @@ (function (global, factory) {

*/
/** Manages event on a Google Maps object, ensuring that events are added only when necessary. */
var MapEventManager = /** @class */ (function () {
function MapEventManager() {
/** Pending listeners that were added before the target was set. */
this._pending = [];
this._listeners = [];
}
/** Clears all currently-registered event listeners. */
MapEventManager.prototype._clearListeners = function () {
var e_1, _a;
try {
for (var _b = tslib.__values(this._listeners), _c = _b.next(); !_c.done; _c = _b.next()) {
var listener = _c.value;
listener.remove();
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_1) throw e_1.error; }
}
this._listeners = [];
};
/** Gets an observable that adds an event listener to the map when a consumer subscribes to it. */
MapEventManager.prototype.getLazyEmitter = function (name) {
var _this = this;
var observable = new rxjs.Observable(function (observer) {
// If the target hasn't been initialized yet, cache the observer so it can be added later.
if (!_this._target) {
_this._pending.push({ observable: observable, observer: observer });
return undefined;
}
var listener = _this._target.addListener(name, function (event) { return observer.next(event); });
_this._listeners.push(listener);
return function () { return listener.remove(); };
});
return observable;
};
/** Sets the current target that the manager should bind events to. */
MapEventManager.prototype.setTarget = function (target) {
if (target === this._target) {
return;
}
// Clear the listeners from the pre-existing target.
if (this._target) {
this._clearListeners();
this._pending = [];
}
this._target = target;
// Add the listeners that were bound before the map was initialized.
this._pending.forEach(function (subscriber) { return subscriber.observable.subscribe(subscriber.observer); });
this._pending = [];
};
/** Destroys the manager and clears the event listeners. */
MapEventManager.prototype.destroy = function () {
this._clearListeners();
this._pending = [];
this._target = undefined;
};
return MapEventManager;
}());
/**
* @license
* Copyright Google LLC All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://angular.io/license
*/
/** default options set to the Googleplex */

@@ -37,2 +108,7 @@ var DEFAULT_OPTIONS = {

this._elementRef = _elementRef;
this._eventManager = new MapEventManager();
this._options = new rxjs.BehaviorSubject(DEFAULT_OPTIONS);
this._center = new rxjs.BehaviorSubject(undefined);
this._zoom = new rxjs.BehaviorSubject(undefined);
this._destroy = new rxjs.Subject();
this.height = DEFAULT_HEIGHT;

@@ -44,3 +120,3 @@ this.width = DEFAULT_WIDTH;

*/
this.boundsChanged = new core.EventEmitter();
this.boundsChanged = this._eventManager.getLazyEmitter('bounds_changed');
/**

@@ -50,3 +126,3 @@ * See

*/
this.centerChanged = new core.EventEmitter();
this.centerChanged = this._eventManager.getLazyEmitter('center_changed');
/**

@@ -56,3 +132,3 @@ * See

*/
this.mapClick = new core.EventEmitter();
this.mapClick = this._eventManager.getLazyEmitter('click');
/**

@@ -62,3 +138,3 @@ * See

*/
this.mapDblclick = new core.EventEmitter();
this.mapDblclick = this._eventManager.getLazyEmitter('dblclick');
/**

@@ -68,3 +144,3 @@ * See

*/
this.mapDrag = new core.EventEmitter();
this.mapDrag = this._eventManager.getLazyEmitter('drag');
/**

@@ -74,3 +150,3 @@ * See

*/
this.mapDragend = new core.EventEmitter();
this.mapDragend = this._eventManager.getLazyEmitter('dragend');
/**

@@ -80,3 +156,3 @@ * See

*/
this.mapDragstart = new core.EventEmitter();
this.mapDragstart = this._eventManager.getLazyEmitter('dragstart');
/**

@@ -86,3 +162,3 @@ * See

*/
this.headingChanged = new core.EventEmitter();
this.headingChanged = this._eventManager.getLazyEmitter('heading_changed');
/**

@@ -92,3 +168,3 @@ * See

*/
this.idle = new core.EventEmitter();
this.idle = this._eventManager.getLazyEmitter('idle');
/**

@@ -98,3 +174,3 @@ * See

*/
this.maptypeidChanged = new core.EventEmitter();
this.maptypeidChanged = this._eventManager.getLazyEmitter('maptypeid_changed');
/**

@@ -104,3 +180,3 @@ * See

*/
this.mapMousemove = new core.EventEmitter();
this.mapMousemove = this._eventManager.getLazyEmitter('mousemove');
/**

@@ -110,3 +186,3 @@ * See

*/
this.mapMouseout = new core.EventEmitter();
this.mapMouseout = this._eventManager.getLazyEmitter('mouseout');
/**

@@ -116,3 +192,3 @@ * See

*/
this.mapMouseover = new core.EventEmitter();
this.mapMouseover = this._eventManager.getLazyEmitter('mouseover');
/**

@@ -122,3 +198,3 @@ * See

*/
this.projectionChanged = new core.EventEmitter();
this.projectionChanged = this._eventManager.getLazyEmitter('projection_changed');
/**

@@ -128,3 +204,3 @@ * See

*/
this.mapRightclick = new core.EventEmitter();
this.mapRightclick = this._eventManager.getLazyEmitter('rightclick');
/**

@@ -134,3 +210,3 @@ * See

*/
this.tilesloaded = new core.EventEmitter();
this.tilesloaded = this._eventManager.getLazyEmitter('tilesloaded');
/**

@@ -140,3 +216,3 @@ * See

*/
this.tiltChanged = new core.EventEmitter();
this.tiltChanged = this._eventManager.getLazyEmitter('tilt_changed');
/**

@@ -146,8 +222,3 @@ * See

*/
this.zoomChanged = new core.EventEmitter();
this._listeners = [];
this._options = new rxjs.BehaviorSubject(DEFAULT_OPTIONS);
this._center = new rxjs.BehaviorSubject(undefined);
this._zoom = new rxjs.BehaviorSubject(undefined);
this._destroy = new rxjs.Subject();
this.zoomChanged = this._eventManager.getLazyEmitter('zoomChanged');
// @breaking-change 10.0.0 Remove null check for `platformId`.

@@ -196,7 +267,6 @@ this._isBrowser =

this._setSize();
var combinedOptionsChanges = this._combineOptions();
this._googleMapChanges = this._initializeMap(combinedOptionsChanges);
this._googleMapChanges = this._initializeMap(this._combineOptions());
this._googleMapChanges.subscribe(function (googleMap) {
_this._googleMap = googleMap;
_this._initializeEventHandlers();
_this._eventManager.setTarget(_this._googleMap);
});

@@ -209,5 +279,5 @@ this._watchForOptionsChanges();

GoogleMap.prototype.ngOnDestroy = function () {
this._eventManager.destroy();
this._destroy.next();
this._destroy.complete();
this._clearListeners();
};

@@ -219,2 +289,3 @@ /**

GoogleMap.prototype.fitBounds = function (bounds, padding) {
this._assertInitialized();
this._googleMap.fitBounds(bounds, padding);

@@ -227,2 +298,3 @@ };

GoogleMap.prototype.panBy = function (x, y) {
this._assertInitialized();
this._googleMap.panBy(x, y);

@@ -235,2 +307,3 @@ };

GoogleMap.prototype.panTo = function (latLng) {
this._assertInitialized();
this._googleMap.panTo(latLng);

@@ -243,2 +316,3 @@ };

GoogleMap.prototype.panToBounds = function (latLngBounds, padding) {
this._assertInitialized();
this._googleMap.panToBounds(latLngBounds, padding);

@@ -251,2 +325,3 @@ };

GoogleMap.prototype.getBounds = function () {
this._assertInitialized();
return this._googleMap.getBounds() || null;

@@ -259,2 +334,3 @@ };

GoogleMap.prototype.getCenter = function () {
this._assertInitialized();
return this._googleMap.getCenter();

@@ -267,2 +343,3 @@ };

GoogleMap.prototype.getClickableIcons = function () {
this._assertInitialized();
return this._googleMap.getClickableIcons();

@@ -275,2 +352,3 @@ };

GoogleMap.prototype.getHeading = function () {
this._assertInitialized();
return this._googleMap.getHeading();

@@ -283,2 +361,3 @@ };

GoogleMap.prototype.getMapTypeId = function () {
this._assertInitialized();
return this._googleMap.getMapTypeId();

@@ -291,2 +370,3 @@ };

GoogleMap.prototype.getProjection = function () {
this._assertInitialized();
return this._googleMap.getProjection();

@@ -299,2 +379,3 @@ };

GoogleMap.prototype.getStreetView = function () {
this._assertInitialized();
return this._googleMap.getStreetView();

@@ -307,2 +388,3 @@ };

GoogleMap.prototype.getTilt = function () {
this._assertInitialized();
return this._googleMap.getTilt();

@@ -315,2 +397,3 @@ };

GoogleMap.prototype.getZoom = function () {
this._assertInitialized();
return this._googleMap.getZoom();

@@ -324,2 +407,3 @@ };

get: function () {
this._assertInitialized();
return this._googleMap.controls;

@@ -336,2 +420,3 @@ },

get: function () {
this._assertInitialized();
return this._googleMap.data;

@@ -348,2 +433,3 @@ },

get: function () {
this._assertInitialized();
return this._googleMap.mapTypes;

@@ -360,2 +446,3 @@ },

get: function () {
this._assertInitialized();
return this._googleMap.overlayMapTypes;

@@ -383,5 +470,3 @@ },

var _this = this;
return optionsChanges.pipe(operators.take(1), operators.map(function (options) {
return new google.maps.Map(_this._mapEl, options);
}), operators.shareReplay(1));
return optionsChanges.pipe(operators.take(1), operators.map(function (options) { return new google.maps.Map(_this._mapEl, options); }), operators.shareReplay(1));
};

@@ -416,65 +501,9 @@ GoogleMap.prototype._watchForOptionsChanges = function () {

};
GoogleMap.prototype._initializeEventHandlers = function () {
var _this = this;
// Ensure that we don't leak if called multiple times.
this._clearListeners();
var eventHandlers = new Map([
['bounds_changed', this.boundsChanged],
['center_changed', this.centerChanged],
['drag', this.mapDrag],
['dragend', this.mapDragend],
['dragstart', this.mapDragstart],
['heading_changed', this.headingChanged],
['idle', this.idle],
['maptypeid_changed', this.maptypeidChanged],
['projection_changed', this.projectionChanged],
['tilesloaded', this.tilesloaded],
['tilt_changed', this.tiltChanged],
['zoomChanged', this.zoomChanged],
]);
var mouseEventHandlers = new Map([
['dblclick', this.mapDblclick],
['mousemove', this.mapMousemove],
['mouseout', this.mapMouseout],
['mouseover', this.mapMouseover],
['rightclick', this.mapRightclick],
]);
eventHandlers.forEach(function (eventHandler, name) {
if (eventHandler.observers.length > 0) {
_this._listeners.push(_this._googleMap.addListener(name, function () {
eventHandler.emit();
}));
}
});
mouseEventHandlers.forEach(function (eventHandler, name) {
if (eventHandler.observers.length > 0) {
_this._listeners.push(_this._googleMap.addListener(name, function (event) {
eventHandler.emit(event);
}));
}
});
if (this.mapClick.observers.length > 0) {
this._listeners.push(this._googleMap.addListener('click', function (event) {
_this.mapClick.emit(event);
}));
/** Asserts that the map has been initialized. */
GoogleMap.prototype._assertInitialized = function () {
if (!this._googleMap) {
throw Error('Cannot access Google Map information before the API has been initialized. ' +
'Please wait for the API to load before trying to interact with it.');
}
};
/** Clears all currently-registered event listeners. */
GoogleMap.prototype._clearListeners = function () {
var e_1, _a;
try {
for (var _b = tslib.__values(this._listeners), _c = _b.next(); !_c.done; _c = _b.next()) {
var listener = _c.value;
listener.remove();
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_1) throw e_1.error; }
}
this._listeners = [];
};
GoogleMap.decorators = [

@@ -529,2 +558,154 @@ { type: core.Component, args: [{

/**
* Angular component that renders a Google Maps info window via the Google Maps JavaScript API.
* @see developers.google.com/maps/documentation/javascript/reference/info-window
*/
var MapInfoWindow = /** @class */ (function () {
function MapInfoWindow(_googleMap, _elementRef) {
this._googleMap = _googleMap;
this._elementRef = _elementRef;
this._eventManager = new MapEventManager();
this._options = new rxjs.BehaviorSubject({});
this._position = new rxjs.BehaviorSubject(undefined);
this._destroy = new rxjs.Subject();
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.closeclick
*/
this.closeclick = this._eventManager.getLazyEmitter('closeclick');
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.content_changed
*/
this.contentChanged = this._eventManager.getLazyEmitter('content_changed');
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.domready
*/
this.domready = this._eventManager.getLazyEmitter('domready');
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.position_changed
*/
this.positionChanged = this._eventManager.getLazyEmitter('position_changed');
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.zindex_changed
*/
this.zindexChanged = this._eventManager.getLazyEmitter('zindex_changed');
}
Object.defineProperty(MapInfoWindow.prototype, "options", {
set: function (options) {
this._options.next(options || {});
},
enumerable: true,
configurable: true
});
Object.defineProperty(MapInfoWindow.prototype, "position", {
set: function (position) {
this._position.next(position);
},
enumerable: true,
configurable: true
});
MapInfoWindow.prototype.ngOnInit = function () {
var _this = this;
this._combineOptions().pipe(operators.takeUntil(this._destroy)).subscribe(function (options) {
if (_this._infoWindow) {
_this._infoWindow.setOptions(options);
}
else {
_this._infoWindow = new google.maps.InfoWindow(options);
_this._eventManager.setTarget(_this._infoWindow);
}
});
};
MapInfoWindow.prototype.ngOnDestroy = function () {
this._eventManager.destroy();
this._destroy.next();
this._destroy.complete();
this.close();
};
/**
* See developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.close
*/
MapInfoWindow.prototype.close = function () {
if (this._infoWindow) {
this._infoWindow.close();
}
};
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.getContent
*/
MapInfoWindow.prototype.getContent = function () {
return this._infoWindow.getContent();
};
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.getPosition
*/
MapInfoWindow.prototype.getPosition = function () {
return this._infoWindow.getPosition() || null;
};
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.getZIndex
*/
MapInfoWindow.prototype.getZIndex = function () {
return this._infoWindow.getZIndex();
};
/**
* Opens the MapInfoWindow using the provided MapMarker as the anchor. If the anchor is not set,
* then the position property of the options input is used instead.
*/
MapInfoWindow.prototype.open = function (anchor) {
var marker = anchor ? anchor._marker : undefined;
if (this._googleMap._googleMap) {
this._elementRef.nativeElement.style.display = '';
this._infoWindow.open(this._googleMap._googleMap, marker);
}
};
MapInfoWindow.prototype._combineOptions = function () {
var _this = this;
return rxjs.combineLatest([this._options, this._position]).pipe(operators.map(function (_a) {
var _b = tslib.__read(_a, 2), options = _b[0], position = _b[1];
var combinedOptions = tslib.__assign(tslib.__assign({}, options), { position: position || options.position, content: _this._elementRef.nativeElement });
return combinedOptions;
}));
};
MapInfoWindow.decorators = [
{ type: core.Directive, args: [{
selector: 'map-info-window',
host: { 'style': 'display: none' },
},] }
];
/** @nocollapse */
MapInfoWindow.ctorParameters = function () { return [
{ type: GoogleMap },
{ type: core.ElementRef }
]; };
MapInfoWindow.propDecorators = {
options: [{ type: core.Input }],
position: [{ type: core.Input }],
closeclick: [{ type: core.Output }],
contentChanged: [{ type: core.Output }],
domready: [{ type: core.Output }],
positionChanged: [{ type: core.Output }],
zindexChanged: [{ type: core.Output }]
};
return MapInfoWindow;
}());
/**
* @license
* Copyright Google LLC All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://angular.io/license
*/
/**
* Default options for the Google Maps marker component. Displays a marker

@@ -543,2 +724,9 @@ * at the Googleplex.

this._googleMap = _googleMap;
this._eventManager = new MapEventManager();
this._options = new rxjs.BehaviorSubject(DEFAULT_MARKER_OPTIONS);
this._title = new rxjs.BehaviorSubject(undefined);
this._position = new rxjs.BehaviorSubject(undefined);
this._label = new rxjs.BehaviorSubject(undefined);
this._clickable = new rxjs.BehaviorSubject(undefined);
this._destroy = new rxjs.Subject();
/**

@@ -548,3 +736,3 @@ * See

*/
this.animationChanged = new core.EventEmitter();
this.animationChanged = this._eventManager.getLazyEmitter('animation_changed');
/**

@@ -554,3 +742,3 @@ * See

*/
this.mapClick = new core.EventEmitter();
this.mapClick = this._eventManager.getLazyEmitter('click');
/**

@@ -560,3 +748,3 @@ * See

*/
this.clickableChanged = new core.EventEmitter();
this.clickableChanged = this._eventManager.getLazyEmitter('clickable_changed');
/**

@@ -566,3 +754,3 @@ * See

*/
this.cursorChanged = new core.EventEmitter();
this.cursorChanged = this._eventManager.getLazyEmitter('cursor_changed');
/**

@@ -572,3 +760,3 @@ * See

*/
this.mapDblclick = new core.EventEmitter();
this.mapDblclick = this._eventManager.getLazyEmitter('dblclick');
/**

@@ -578,3 +766,3 @@ * See

*/
this.mapDrag = new core.EventEmitter();
this.mapDrag = this._eventManager.getLazyEmitter('drag');
/**

@@ -584,3 +772,3 @@ * See

*/
this.mapDragend = new core.EventEmitter();
this.mapDragend = this._eventManager.getLazyEmitter('dragend');
/**

@@ -590,3 +778,3 @@ * See

*/
this.draggableChanged = new core.EventEmitter();
this.draggableChanged = this._eventManager.getLazyEmitter('draggable_changed');
/**

@@ -596,3 +784,3 @@ * See

*/
this.mapDragstart = new core.EventEmitter();
this.mapDragstart = this._eventManager.getLazyEmitter('dragstart');
/**

@@ -602,3 +790,3 @@ * See

*/
this.flatChanged = new core.EventEmitter();
this.flatChanged = this._eventManager.getLazyEmitter('flat_changed');
/**

@@ -608,3 +796,3 @@ * See

*/
this.iconChanged = new core.EventEmitter();
this.iconChanged = this._eventManager.getLazyEmitter('icon_changed');
/**

@@ -614,3 +802,3 @@ * See

*/
this.mapMousedown = new core.EventEmitter();
this.mapMousedown = this._eventManager.getLazyEmitter('mousedown');
/**

@@ -620,3 +808,3 @@ * See

*/
this.mapMouseout = new core.EventEmitter();
this.mapMouseout = this._eventManager.getLazyEmitter('mouseout');
/**

@@ -626,3 +814,3 @@ * See

*/
this.mapMouseover = new core.EventEmitter();
this.mapMouseover = this._eventManager.getLazyEmitter('mouseover');
/**

@@ -632,3 +820,3 @@ * See

*/
this.mapMouseup = new core.EventEmitter();
this.mapMouseup = this._eventManager.getLazyEmitter('mouseup');
/**

@@ -638,3 +826,3 @@ * See

*/
this.positionChanged = new core.EventEmitter();
this.positionChanged = this._eventManager.getLazyEmitter('position_changed');
/**

@@ -644,3 +832,3 @@ * See

*/
this.mapRightclick = new core.EventEmitter();
this.mapRightclick = this._eventManager.getLazyEmitter('rightclick');
/**

@@ -650,3 +838,3 @@ * See

*/
this.shapeChanged = new core.EventEmitter();
this.shapeChanged = this._eventManager.getLazyEmitter('shape_changed');
/**

@@ -656,3 +844,3 @@ * See

*/
this.titleChanged = new core.EventEmitter();
this.titleChanged = this._eventManager.getLazyEmitter('title_changed');
/**

@@ -662,3 +850,3 @@ * See

*/
this.visibleChanged = new core.EventEmitter();
this.visibleChanged = this._eventManager.getLazyEmitter('visible_changed');
/**

@@ -668,10 +856,3 @@ * See

*/
this.zindexChanged = new core.EventEmitter();
this._options = new rxjs.BehaviorSubject(DEFAULT_MARKER_OPTIONS);
this._title = new rxjs.BehaviorSubject(undefined);
this._position = new rxjs.BehaviorSubject(undefined);
this._label = new rxjs.BehaviorSubject(undefined);
this._clickable = new rxjs.BehaviorSubject(undefined);
this._destroy = new rxjs.Subject();
this._listeners = [];
this.zindexChanged = this._eventManager.getLazyEmitter('zindex_changed');
}

@@ -719,3 +900,3 @@ Object.defineProperty(MapMarker.prototype, "options", {

_this._marker.setMap(_this._googleMap._googleMap);
_this._initializeEventHandlers();
_this._eventManager.setTarget(_this._marker);
});

@@ -731,3 +912,3 @@ this._watchForOptionsChanges();

this._destroy.complete();
this._clearListeners();
this._eventManager.destroy();
if (this._marker) {

@@ -870,64 +1051,2 @@ this._marker.setMap(null);

};
MapMarker.prototype._initializeEventHandlers = function () {
var _this = this;
// Ensure that we don't leak if called multiple times.
this._clearListeners();
var eventHandlers = new Map([
['animation_changed', this.animationChanged],
['clickable_changed', this.clickableChanged],
['cursor_changed', this.cursorChanged],
['draggable_changed', this.draggableChanged],
['flat_changed', this.flatChanged],
['icon_changed', this.iconChanged],
['position_changed', this.positionChanged],
['shape_changed', this.shapeChanged],
['title_changed', this.titleChanged],
['visible_changed', this.visibleChanged],
['zindex_changed', this.zindexChanged],
]);
var mouseEventHandlers = new Map([
['click', this.mapClick],
['dblclick', this.mapDblclick],
['drag', this.mapDrag],
['dragend', this.mapDragend],
['dragstart', this.mapDragstart],
['mousedown', this.mapMousedown],
['mouseout', this.mapMouseout],
['mouseover', this.mapMouseover],
['mouseup', this.mapMouseup],
['rightclick', this.mapRightclick],
]);
eventHandlers.forEach(function (eventHandler, name) {
if (eventHandler.observers.length > 0) {
_this._listeners.push(_this._marker.addListener(name, function () {
eventHandler.emit();
}));
}
});
mouseEventHandlers.forEach(function (eventHandler, name) {
if (eventHandler.observers.length > 0) {
_this._listeners.push(_this._marker.addListener(name, function (event) {
eventHandler.emit(event);
}));
}
});
};
/** Clears all currently-registered event listeners. */
MapMarker.prototype._clearListeners = function () {
var e_1, _a;
try {
for (var _b = tslib.__values(this._listeners), _c = _b.next(); !_c.done; _c = _b.next()) {
var listener = _c.value;
listener.remove();
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_1) throw e_1.error; }
}
this._listeners = [];
};
MapMarker.decorators = [

@@ -984,43 +1103,59 @@ { type: core.Component, args: [{

/**
* Angular component that renders a Google Maps info window via the Google Maps JavaScript API.
* @see developers.google.com/maps/documentation/javascript/reference/info-window
* Angular component that renders a Google Maps Polyline via the Google Maps JavaScript API.
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline
*/
var MapInfoWindow = /** @class */ (function () {
function MapInfoWindow(_googleMap, _elementRef) {
this._googleMap = _googleMap;
this._elementRef = _elementRef;
var MapPolyline = /** @class */ (function () {
function MapPolyline(_map) {
this._map = _map;
this._eventManager = new MapEventManager();
this._options = new rxjs.BehaviorSubject({});
this._path = new rxjs.BehaviorSubject(undefined);
this._destroyed = new rxjs.Subject();
this._listeners = [];
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.closeclick
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.click
*/
this.closeclick = new core.EventEmitter();
this.polylineClick = this._eventManager.getLazyEmitter('click');
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.content_changed
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.dblclick
*/
this.contentChanged = new core.EventEmitter();
this.polylineDblclick = this._eventManager.getLazyEmitter('dblclick');
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.domready
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.drag
*/
this.domready = new core.EventEmitter();
this.polylineDrag = this._eventManager.getLazyEmitter('drag');
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.position_changed
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.dragend
*/
this.positionChanged = new core.EventEmitter();
this.polylineDragend = this._eventManager.getLazyEmitter('dragend');
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.zindex_changed
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.dragstart
*/
this.zindexChanged = new core.EventEmitter();
this._options = new rxjs.BehaviorSubject({});
this._position = new rxjs.BehaviorSubject(undefined);
this._listeners = [];
this._destroy = new rxjs.Subject();
this.polylineDragstart = this._eventManager.getLazyEmitter('dragstart');
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mousedown
*/
this.polylineMousedown = this._eventManager.getLazyEmitter('mousedown');
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mousemove
*/
this.polylineMousemove = this._eventManager.getLazyEmitter('mousemove');
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mouseout
*/
this.polylineMouseout = this._eventManager.getLazyEmitter('mouseout');
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mouseover
*/
this.polylineMouseover = this._eventManager.getLazyEmitter('mouseover');
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mouseup
*/
this.polylineMouseup = this._eventManager.getLazyEmitter('mouseup');
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.rightclick
*/
this.polylineRightclick = this._eventManager.getLazyEmitter('rightclick');
}
Object.defineProperty(MapInfoWindow.prototype, "options", {
Object.defineProperty(MapPolyline.prototype, "options", {
set: function (options) {

@@ -1032,5 +1167,5 @@ this._options.next(options || {});

});
Object.defineProperty(MapInfoWindow.prototype, "position", {
set: function (position) {
this._position.next(position);
Object.defineProperty(MapPolyline.prototype, "path", {
set: function (path) {
this._path.next(path);
},

@@ -1040,18 +1175,18 @@ enumerable: true,

});
MapInfoWindow.prototype.ngOnInit = function () {
MapPolyline.prototype.ngOnInit = function () {
var _this = this;
this._combineOptions().pipe(operators.takeUntil(this._destroy)).subscribe(function (options) {
if (_this._infoWindow) {
_this._infoWindow.setOptions(options);
}
else {
_this._infoWindow = new google.maps.InfoWindow(options);
_this._initializeEventHandlers();
}
var combinedOptionsChanges = this._combineOptions();
combinedOptionsChanges.pipe(operators.take(1)).subscribe(function (options) {
_this._polyline = new google.maps.Polyline(options);
_this._polyline.setMap(_this._map._googleMap);
_this._eventManager.setTarget(_this._polyline);
});
this._watchForOptionsChanges();
this._watchForPathChanges();
};
MapInfoWindow.prototype.ngOnDestroy = function () {
MapPolyline.prototype.ngOnDestroy = function () {
var e_1, _a;
this._destroy.next();
this._destroy.complete();
this._eventManager.destroy();
this._destroyed.next();
this._destroyed.complete();
try {

@@ -1070,111 +1205,75 @@ for (var _b = tslib.__values(this._listeners), _c = _b.next(); !_c.done; _c = _b.next()) {

}
this.close();
this._polyline.setMap(null);
};
/**
* See developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.close
* @see
* developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.getDraggable
*/
MapInfoWindow.prototype.close = function () {
if (this._infoWindow) {
this._infoWindow.close();
}
MapPolyline.prototype.getDraggable = function () {
return this._polyline.getDraggable();
};
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.getContent
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.getEditable
*/
MapInfoWindow.prototype.getContent = function () {
return this._infoWindow.getContent();
MapPolyline.prototype.getEditable = function () {
return this._polyline.getEditable();
};
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.getPosition
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.getPath
*/
MapInfoWindow.prototype.getPosition = function () {
return this._infoWindow.getPosition() || null;
MapPolyline.prototype.getPath = function () {
return this._polyline.getPath();
};
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.getZIndex
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.getVisible
*/
MapInfoWindow.prototype.getZIndex = function () {
return this._infoWindow.getZIndex();
MapPolyline.prototype.getVisible = function () {
return this._polyline.getVisible();
};
/**
* Opens the MapInfoWindow using the provided MapMarker as the anchor. If the anchor is not set,
* then the position property of the options input is used instead.
*/
MapInfoWindow.prototype.open = function (anchor) {
var marker = anchor ? anchor._marker : undefined;
if (this._googleMap._googleMap) {
this._elementRef.nativeElement.style.display = '';
this._infoWindow.open(this._googleMap._googleMap, marker);
}
};
MapInfoWindow.prototype._combineOptions = function () {
var _this = this;
return rxjs.combineLatest([this._options, this._position]).pipe(operators.map(function (_a) {
var _b = tslib.__read(_a, 2), options = _b[0], position = _b[1];
var combinedOptions = tslib.__assign(tslib.__assign({}, options), { position: position || options.position, content: _this._elementRef.nativeElement });
MapPolyline.prototype._combineOptions = function () {
return rxjs.combineLatest([this._options, this._path]).pipe(operators.map(function (_a) {
var _b = tslib.__read(_a, 2), options = _b[0], path = _b[1];
var combinedOptions = tslib.__assign(tslib.__assign({}, options), { path: path || options.path });
return combinedOptions;
}));
};
MapInfoWindow.prototype._initializeEventHandlers = function () {
MapPolyline.prototype._watchForOptionsChanges = function () {
var _this = this;
// Ensure that we don't leak if called multiple times.
this._clearListeners();
var eventHandlers = new Map([
['closeclick', this.closeclick],
['content_changed', this.contentChanged],
['domready', this.domready],
['position_changed', this.positionChanged],
['zindex_changed', this.zindexChanged],
]);
eventHandlers.forEach(function (eventHandler, name) {
if (eventHandler.observers.length > 0) {
_this._listeners.push(_this._infoWindow.addListener(name, function () {
eventHandler.emit();
}));
}
this._options.pipe(operators.takeUntil(this._destroyed)).subscribe(function (options) {
_this._polyline.setOptions(options);
});
};
/** Clears all currently-registered event listeners. */
MapInfoWindow.prototype._clearListeners = function () {
var e_2, _a;
try {
for (var _b = tslib.__values(this._listeners), _c = _b.next(); !_c.done; _c = _b.next()) {
var listener = _c.value;
listener.remove();
MapPolyline.prototype._watchForPathChanges = function () {
var _this = this;
this._path.pipe(operators.takeUntil(this._destroyed)).subscribe(function (path) {
if (path) {
_this._polyline.setPath(path);
}
}
catch (e_2_1) { e_2 = { error: e_2_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_2) throw e_2.error; }
}
this._listeners = [];
});
};
MapInfoWindow.decorators = [
MapPolyline.decorators = [
{ type: core.Directive, args: [{
selector: 'map-info-window',
host: { 'style': 'display: none' },
selector: 'map-polyline',
},] }
];
/** @nocollapse */
MapInfoWindow.ctorParameters = function () { return [
{ type: GoogleMap },
{ type: core.ElementRef }
MapPolyline.ctorParameters = function () { return [
{ type: GoogleMap }
]; };
MapInfoWindow.propDecorators = {
MapPolyline.propDecorators = {
options: [{ type: core.Input }],
position: [{ type: core.Input }],
closeclick: [{ type: core.Output }],
contentChanged: [{ type: core.Output }],
domready: [{ type: core.Output }],
positionChanged: [{ type: core.Output }],
zindexChanged: [{ type: core.Output }]
path: [{ type: core.Input }],
polylineClick: [{ type: core.Output }],
polylineDblclick: [{ type: core.Output }],
polylineDrag: [{ type: core.Output }],
polylineDragend: [{ type: core.Output }],
polylineDragstart: [{ type: core.Output }],
polylineMousedown: [{ type: core.Output }],
polylineMousemove: [{ type: core.Output }],
polylineMouseout: [{ type: core.Output }],
polylineMouseover: [{ type: core.Output }],
polylineMouseup: [{ type: core.Output }],
polylineRightclick: [{ type: core.Output }]
};
return MapInfoWindow;
return MapPolyline;
}());

@@ -1193,2 +1292,3 @@

MapMarker,
MapPolyline,
];

@@ -1223,2 +1323,3 @@ var GoogleMapsModule = /** @class */ (function () {

exports.MapMarker = MapMarker;
exports.MapPolyline = MapPolyline;

@@ -1225,0 +1326,0 @@ Object.defineProperty(exports, '__esModule', { value: true });

@@ -1,2 +0,2 @@

!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("tslib"),require("@angular/core"),require("@angular/common"),require("rxjs"),require("rxjs/operators")):"function"==typeof define&&define.amd?define("@angular/google-maps",["exports","tslib","@angular/core","@angular/common","rxjs","rxjs/operators"],e):e(((t=t||self).ng=t.ng||{},t.ng.googleMaps={}),t.tslib,t.ng.core,t.ng.common,t.rxjs,t.rxjs.operators)}(this,(function(t,e,n,i,o,r){"use strict";
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("tslib"),require("@angular/core"),require("@angular/common"),require("rxjs"),require("rxjs/operators")):"function"==typeof define&&define.amd?define("@angular/google-maps",["exports","tslib","@angular/core","@angular/common","rxjs","rxjs/operators"],e):e(((t=t||self).ng=t.ng||{},t.ng.googleMaps={}),t.tslib,t.ng.core,t.ng.common,t.rxjs,t.rxjs.operators)}(this,(function(t,e,i,n,o,a){"use strict";
/**

@@ -8,3 +8,3 @@ * @license

* found in the LICENSE file at https://angular.io/license
*/var s={center:{lat:37.421995,lng:-122.084092},zoom:17},a="500px",p="500px",h=function(){function t(t,e){if(this._elementRef=t,this.height=a,this.width=p,this.boundsChanged=new n.EventEmitter,this.centerChanged=new n.EventEmitter,this.mapClick=new n.EventEmitter,this.mapDblclick=new n.EventEmitter,this.mapDrag=new n.EventEmitter,this.mapDragend=new n.EventEmitter,this.mapDragstart=new n.EventEmitter,this.headingChanged=new n.EventEmitter,this.idle=new n.EventEmitter,this.maptypeidChanged=new n.EventEmitter,this.mapMousemove=new n.EventEmitter,this.mapMouseout=new n.EventEmitter,this.mapMouseover=new n.EventEmitter,this.projectionChanged=new n.EventEmitter,this.mapRightclick=new n.EventEmitter,this.tilesloaded=new n.EventEmitter,this.tiltChanged=new n.EventEmitter,this.zoomChanged=new n.EventEmitter,this._listeners=[],this._options=new o.BehaviorSubject(s),this._center=new o.BehaviorSubject(void 0),this._zoom=new o.BehaviorSubject(void 0),this._destroy=new o.Subject,this._isBrowser=e?i.isPlatformBrowser(e):"object"==typeof window&&!!window,this._isBrowser&&!window.google)throw Error("Namespace google not found, cannot construct embedded google map. Please install the Google Maps JavaScript API: https://developers.google.com/maps/documentation/javascript/tutorial#Loading_the_Maps_API")}return Object.defineProperty(t.prototype,"center",{set:function(t){this._center.next(t)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"zoom",{set:function(t){this._zoom.next(t)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"options",{set:function(t){this._options.next(t||s)},enumerable:!0,configurable:!0}),t.prototype.ngOnChanges=function(){this._setSize()},t.prototype.ngOnInit=function(){var t=this;if(this._isBrowser){this._mapEl=this._elementRef.nativeElement.querySelector(".map-container"),this._setSize();var e=this._combineOptions();this._googleMapChanges=this._initializeMap(e),this._googleMapChanges.subscribe((function(e){t._googleMap=e,t._initializeEventHandlers()})),this._watchForOptionsChanges(),this._watchForCenterChanges(),this._watchForZoomChanges()}},t.prototype.ngOnDestroy=function(){this._destroy.next(),this._destroy.complete(),this._clearListeners()},t.prototype.fitBounds=function(t,e){this._googleMap.fitBounds(t,e)},t.prototype.panBy=function(t,e){this._googleMap.panBy(t,e)},t.prototype.panTo=function(t){this._googleMap.panTo(t)},t.prototype.panToBounds=function(t,e){this._googleMap.panToBounds(t,e)},t.prototype.getBounds=function(){return this._googleMap.getBounds()||null},t.prototype.getCenter=function(){return this._googleMap.getCenter()},t.prototype.getClickableIcons=function(){return this._googleMap.getClickableIcons()},t.prototype.getHeading=function(){return this._googleMap.getHeading()},t.prototype.getMapTypeId=function(){return this._googleMap.getMapTypeId()},t.prototype.getProjection=function(){return this._googleMap.getProjection()},t.prototype.getStreetView=function(){return this._googleMap.getStreetView()},t.prototype.getTilt=function(){return this._googleMap.getTilt()},t.prototype.getZoom=function(){return this._googleMap.getZoom()},Object.defineProperty(t.prototype,"controls",{get:function(){return this._googleMap.controls},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"data",{get:function(){return this._googleMap.data},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"mapTypes",{get:function(){return this._googleMap.mapTypes},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"overlayMapTypes",{get:function(){return this._googleMap.overlayMapTypes},enumerable:!0,configurable:!0}),t.prototype._setSize=function(){this._mapEl&&(this._mapEl.style.height=this.height||a,this._mapEl.style.width=this.width||p)},t.prototype._combineOptions=function(){return o.combineLatest([this._options,this._center,this._zoom]).pipe(r.map((function(t){var n=e.__read(t,3),i=n[0],o=n[1],r=n[2];return e.__assign(e.__assign({},i),{center:o||i.center,zoom:void 0!==r?r:i.zoom})})))},t.prototype._initializeMap=function(t){var e=this;return t.pipe(r.take(1),r.map((function(t){return new google.maps.Map(e._mapEl,t)})),r.shareReplay(1))},t.prototype._watchForOptionsChanges=function(){o.combineLatest([this._googleMapChanges,this._options]).pipe(r.takeUntil(this._destroy)).subscribe((function(t){var n=e.__read(t,2);n[0].setOptions(n[1])}))},t.prototype._watchForCenterChanges=function(){o.combineLatest([this._googleMapChanges,this._center]).pipe(r.takeUntil(this._destroy)).subscribe((function(t){var n=e.__read(t,2),i=n[1];i&&n[0].setCenter(i)}))},t.prototype._watchForZoomChanges=function(){o.combineLatest([this._googleMapChanges,this._zoom]).pipe(r.takeUntil(this._destroy)).subscribe((function(t){var n=e.__read(t,2),i=n[1];void 0!==i&&n[0].setZoom(i)}))},t.prototype._initializeEventHandlers=function(){var t=this;this._clearListeners();var e=new Map([["bounds_changed",this.boundsChanged],["center_changed",this.centerChanged],["drag",this.mapDrag],["dragend",this.mapDragend],["dragstart",this.mapDragstart],["heading_changed",this.headingChanged],["idle",this.idle],["maptypeid_changed",this.maptypeidChanged],["projection_changed",this.projectionChanged],["tilesloaded",this.tilesloaded],["tilt_changed",this.tiltChanged],["zoomChanged",this.zoomChanged]]),n=new Map([["dblclick",this.mapDblclick],["mousemove",this.mapMousemove],["mouseout",this.mapMouseout],["mouseover",this.mapMouseover],["rightclick",this.mapRightclick]]);e.forEach((function(e,n){e.observers.length>0&&t._listeners.push(t._googleMap.addListener(n,(function(){e.emit()})))})),n.forEach((function(e,n){e.observers.length>0&&t._listeners.push(t._googleMap.addListener(n,(function(t){e.emit(t)})))})),this.mapClick.observers.length>0&&this._listeners.push(this._googleMap.addListener("click",(function(e){t.mapClick.emit(e)})))},t.prototype._clearListeners=function(){var t,n;try{for(var i=e.__values(this._listeners),o=i.next();!o.done;o=i.next())o.value.remove()}catch(e){t={error:e}}finally{try{o&&!o.done&&(n=i.return)&&n.call(i)}finally{if(t)throw t.error}}this._listeners=[]},t.decorators=[{type:n.Component,args:[{selector:"google-map",changeDetection:n.ChangeDetectionStrategy.OnPush,template:'<div class="map-container"></div><ng-content></ng-content>',encapsulation:n.ViewEncapsulation.None}]}],t.ctorParameters=function(){return[{type:n.ElementRef},{type:Object,decorators:[{type:n.Optional},{type:n.Inject,args:[n.PLATFORM_ID]}]}]},t.propDecorators={height:[{type:n.Input}],width:[{type:n.Input}],center:[{type:n.Input}],zoom:[{type:n.Input}],options:[{type:n.Input}],boundsChanged:[{type:n.Output}],centerChanged:[{type:n.Output}],mapClick:[{type:n.Output}],mapDblclick:[{type:n.Output}],mapDrag:[{type:n.Output}],mapDragend:[{type:n.Output}],mapDragstart:[{type:n.Output}],headingChanged:[{type:n.Output}],idle:[{type:n.Output}],maptypeidChanged:[{type:n.Output}],mapMousemove:[{type:n.Output}],mapMouseout:[{type:n.Output}],mapMouseover:[{type:n.Output}],projectionChanged:[{type:n.Output}],mapRightclick:[{type:n.Output}],tilesloaded:[{type:n.Output}],tiltChanged:[{type:n.Output}],zoomChanged:[{type:n.Output}]},t}(),c={position:{lat:37.421995,lng:-122.084092}},u=function(){function t(t){this._googleMap=t,this.animationChanged=new n.EventEmitter,this.mapClick=new n.EventEmitter,this.clickableChanged=new n.EventEmitter,this.cursorChanged=new n.EventEmitter,this.mapDblclick=new n.EventEmitter,this.mapDrag=new n.EventEmitter,this.mapDragend=new n.EventEmitter,this.draggableChanged=new n.EventEmitter,this.mapDragstart=new n.EventEmitter,this.flatChanged=new n.EventEmitter,this.iconChanged=new n.EventEmitter,this.mapMousedown=new n.EventEmitter,this.mapMouseout=new n.EventEmitter,this.mapMouseover=new n.EventEmitter,this.mapMouseup=new n.EventEmitter,this.positionChanged=new n.EventEmitter,this.mapRightclick=new n.EventEmitter,this.shapeChanged=new n.EventEmitter,this.titleChanged=new n.EventEmitter,this.visibleChanged=new n.EventEmitter,this.zindexChanged=new n.EventEmitter,this._options=new o.BehaviorSubject(c),this._title=new o.BehaviorSubject(void 0),this._position=new o.BehaviorSubject(void 0),this._label=new o.BehaviorSubject(void 0),this._clickable=new o.BehaviorSubject(void 0),this._destroy=new o.Subject,this._listeners=[]}return Object.defineProperty(t.prototype,"options",{set:function(t){this._options.next(t||c)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"title",{set:function(t){this._title.next(t)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"position",{set:function(t){this._position.next(t)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"label",{set:function(t){this._label.next(t)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"clickable",{set:function(t){this._clickable.next(t)},enumerable:!0,configurable:!0}),t.prototype.ngOnInit=function(){var t=this;this._combineOptions().pipe(r.take(1)).subscribe((function(e){t._marker=new google.maps.Marker(e),t._marker.setMap(t._googleMap._googleMap),t._initializeEventHandlers()})),this._watchForOptionsChanges(),this._watchForTitleChanges(),this._watchForPositionChanges(),this._watchForLabelChanges(),this._watchForClickableChanges()},t.prototype.ngOnDestroy=function(){this._destroy.next(),this._destroy.complete(),this._clearListeners(),this._marker&&this._marker.setMap(null)},t.prototype.getAnimation=function(){return this._marker.getAnimation()||null},t.prototype.getClickable=function(){return this._marker.getClickable()},t.prototype.getCursor=function(){return this._marker.getCursor()||null},t.prototype.getDraggable=function(){return!!this._marker.getDraggable()},t.prototype.getIcon=function(){return this._marker.getIcon()||null},t.prototype.getLabel=function(){return this._marker.getLabel()||null},t.prototype.getOpacity=function(){return this._marker.getOpacity()||null},t.prototype.getPosition=function(){return this._marker.getPosition()||null},t.prototype.getShape=function(){return this._marker.getShape()||null},t.prototype.getTitle=function(){return this._marker.getTitle()||null},t.prototype.getVisible=function(){return this._marker.getVisible()},t.prototype.getZIndex=function(){return this._marker.getZIndex()||null},t.prototype._combineOptions=function(){var t=this;return o.combineLatest([this._options,this._title,this._position,this._label,this._clickable]).pipe(r.map((function(n){var i=e.__read(n,5),o=i[0],r=i[1],s=i[2],a=i[3],p=i[4];return e.__assign(e.__assign({},o),{title:r||o.title,position:s||o.position,label:a||o.label,clickable:void 0!==p?p:o.clickable,map:t._googleMap._googleMap||null})})))},t.prototype._watchForOptionsChanges=function(){var t=this;this._options.pipe(r.takeUntil(this._destroy)).subscribe((function(e){t._marker&&t._marker.setOptions(e)}))},t.prototype._watchForTitleChanges=function(){var t=this;this._title.pipe(r.takeUntil(this._destroy)).subscribe((function(e){t._marker&&void 0!==e&&t._marker.setTitle(e)}))},t.prototype._watchForPositionChanges=function(){var t=this;this._position.pipe(r.takeUntil(this._destroy)).subscribe((function(e){t._marker&&e&&t._marker.setPosition(e)}))},t.prototype._watchForLabelChanges=function(){var t=this;this._label.pipe(r.takeUntil(this._destroy)).subscribe((function(e){t._marker&&void 0!==e&&t._marker.setLabel(e)}))},t.prototype._watchForClickableChanges=function(){var t=this;this._clickable.pipe(r.takeUntil(this._destroy)).subscribe((function(e){t._marker&&void 0!==e&&t._marker.setClickable(e)}))},t.prototype._initializeEventHandlers=function(){var t=this;this._clearListeners();var e=new Map([["animation_changed",this.animationChanged],["clickable_changed",this.clickableChanged],["cursor_changed",this.cursorChanged],["draggable_changed",this.draggableChanged],["flat_changed",this.flatChanged],["icon_changed",this.iconChanged],["position_changed",this.positionChanged],["shape_changed",this.shapeChanged],["title_changed",this.titleChanged],["visible_changed",this.visibleChanged],["zindex_changed",this.zindexChanged]]),n=new Map([["click",this.mapClick],["dblclick",this.mapDblclick],["drag",this.mapDrag],["dragend",this.mapDragend],["dragstart",this.mapDragstart],["mousedown",this.mapMousedown],["mouseout",this.mapMouseout],["mouseover",this.mapMouseover],["mouseup",this.mapMouseup],["rightclick",this.mapRightclick]]);e.forEach((function(e,n){e.observers.length>0&&t._listeners.push(t._marker.addListener(n,(function(){e.emit()})))})),n.forEach((function(e,n){e.observers.length>0&&t._listeners.push(t._marker.addListener(n,(function(t){e.emit(t)})))}))},t.prototype._clearListeners=function(){var t,n;try{for(var i=e.__values(this._listeners),o=i.next();!o.done;o=i.next())o.value.remove()}catch(e){t={error:e}}finally{try{o&&!o.done&&(n=i.return)&&n.call(i)}finally{if(t)throw t.error}}this._listeners=[]},t.decorators=[{type:n.Component,args:[{selector:"map-marker",template:"<ng-content></ng-content>",changeDetection:n.ChangeDetectionStrategy.OnPush,encapsulation:n.ViewEncapsulation.None}]}],t.ctorParameters=function(){return[{type:h}]},t.propDecorators={options:[{type:n.Input}],title:[{type:n.Input}],position:[{type:n.Input}],label:[{type:n.Input}],clickable:[{type:n.Input}],animationChanged:[{type:n.Output}],mapClick:[{type:n.Output}],clickableChanged:[{type:n.Output}],cursorChanged:[{type:n.Output}],mapDblclick:[{type:n.Output}],mapDrag:[{type:n.Output}],mapDragend:[{type:n.Output}],draggableChanged:[{type:n.Output}],mapDragstart:[{type:n.Output}],flatChanged:[{type:n.Output}],iconChanged:[{type:n.Output}],mapMousedown:[{type:n.Output}],mapMouseout:[{type:n.Output}],mapMouseover:[{type:n.Output}],mapMouseup:[{type:n.Output}],positionChanged:[{type:n.Output}],mapRightclick:[{type:n.Output}],shapeChanged:[{type:n.Output}],titleChanged:[{type:n.Output}],visibleChanged:[{type:n.Output}],zindexChanged:[{type:n.Output}]},t}(),l=function(){function t(t,e){this._googleMap=t,this._elementRef=e,this.closeclick=new n.EventEmitter,this.contentChanged=new n.EventEmitter,this.domready=new n.EventEmitter,this.positionChanged=new n.EventEmitter,this.zindexChanged=new n.EventEmitter,this._options=new o.BehaviorSubject({}),this._position=new o.BehaviorSubject(void 0),this._listeners=[],this._destroy=new o.Subject}return Object.defineProperty(t.prototype,"options",{set:function(t){this._options.next(t||{})},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"position",{set:function(t){this._position.next(t)},enumerable:!0,configurable:!0}),t.prototype.ngOnInit=function(){var t=this;this._combineOptions().pipe(r.takeUntil(this._destroy)).subscribe((function(e){t._infoWindow?t._infoWindow.setOptions(e):(t._infoWindow=new google.maps.InfoWindow(e),t._initializeEventHandlers())}))},t.prototype.ngOnDestroy=function(){var t,n;this._destroy.next(),this._destroy.complete();try{for(var i=e.__values(this._listeners),o=i.next();!o.done;o=i.next())o.value.remove()}catch(e){t={error:e}}finally{try{o&&!o.done&&(n=i.return)&&n.call(i)}finally{if(t)throw t.error}}this.close()},t.prototype.close=function(){this._infoWindow&&this._infoWindow.close()},t.prototype.getContent=function(){return this._infoWindow.getContent()},t.prototype.getPosition=function(){return this._infoWindow.getPosition()||null},t.prototype.getZIndex=function(){return this._infoWindow.getZIndex()},t.prototype.open=function(t){var e=t?t._marker:void 0;this._googleMap._googleMap&&(this._elementRef.nativeElement.style.display="",this._infoWindow.open(this._googleMap._googleMap,e))},t.prototype._combineOptions=function(){var t=this;return o.combineLatest([this._options,this._position]).pipe(r.map((function(n){var i=e.__read(n,2),o=i[0],r=i[1];return e.__assign(e.__assign({},o),{position:r||o.position,content:t._elementRef.nativeElement})})))},t.prototype._initializeEventHandlers=function(){var t=this;this._clearListeners(),new Map([["closeclick",this.closeclick],["content_changed",this.contentChanged],["domready",this.domready],["position_changed",this.positionChanged],["zindex_changed",this.zindexChanged]]).forEach((function(e,n){e.observers.length>0&&t._listeners.push(t._infoWindow.addListener(n,(function(){e.emit()})))}))},t.prototype._clearListeners=function(){var t,n;try{for(var i=e.__values(this._listeners),o=i.next();!o.done;o=i.next())o.value.remove()}catch(e){t={error:e}}finally{try{o&&!o.done&&(n=i.return)&&n.call(i)}finally{if(t)throw t.error}}this._listeners=[]},t.decorators=[{type:n.Directive,args:[{selector:"map-info-window",host:{style:"display: none"}}]}],t.ctorParameters=function(){return[{type:h},{type:n.ElementRef}]},t.propDecorators={options:[{type:n.Input}],position:[{type:n.Input}],closeclick:[{type:n.Output}],contentChanged:[{type:n.Output}],domready:[{type:n.Output}],positionChanged:[{type:n.Output}],zindexChanged:[{type:n.Output}]},t}(),g=[h,l,u],d=function(){function t(){}return t.decorators=[{type:n.NgModule,args:[{declarations:g,exports:g}]}],t}();
*/var r=function(){function t(){this._pending=[],this._listeners=[]}return t.prototype._clearListeners=function(){var t,i;try{for(var n=e.__values(this._listeners),o=n.next();!o.done;o=n.next())o.value.remove()}catch(e){t={error:e}}finally{try{o&&!o.done&&(i=n.return)&&i.call(n)}finally{if(t)throw t.error}}this._listeners=[]},t.prototype.getLazyEmitter=function(t){var e=this,i=new o.Observable((function(n){if(e._target){var o=e._target.addListener(t,(function(t){return n.next(t)}));return e._listeners.push(o),function(){return o.remove()}}e._pending.push({observable:i,observer:n})}));return i},t.prototype.setTarget=function(t){t!==this._target&&(this._target&&(this._clearListeners(),this._pending=[]),this._target=t,this._pending.forEach((function(t){return t.observable.subscribe(t.observer)})),this._pending=[])},t.prototype.destroy=function(){this._clearListeners(),this._pending=[],this._target=void 0},t}(),s={center:{lat:37.421995,lng:-122.084092},zoom:17},p="500px",g="500px",h=function(){function t(t,e){if(this._elementRef=t,this._eventManager=new r,this._options=new o.BehaviorSubject(s),this._center=new o.BehaviorSubject(void 0),this._zoom=new o.BehaviorSubject(void 0),this._destroy=new o.Subject,this.height=p,this.width=g,this.boundsChanged=this._eventManager.getLazyEmitter("bounds_changed"),this.centerChanged=this._eventManager.getLazyEmitter("center_changed"),this.mapClick=this._eventManager.getLazyEmitter("click"),this.mapDblclick=this._eventManager.getLazyEmitter("dblclick"),this.mapDrag=this._eventManager.getLazyEmitter("drag"),this.mapDragend=this._eventManager.getLazyEmitter("dragend"),this.mapDragstart=this._eventManager.getLazyEmitter("dragstart"),this.headingChanged=this._eventManager.getLazyEmitter("heading_changed"),this.idle=this._eventManager.getLazyEmitter("idle"),this.maptypeidChanged=this._eventManager.getLazyEmitter("maptypeid_changed"),this.mapMousemove=this._eventManager.getLazyEmitter("mousemove"),this.mapMouseout=this._eventManager.getLazyEmitter("mouseout"),this.mapMouseover=this._eventManager.getLazyEmitter("mouseover"),this.projectionChanged=this._eventManager.getLazyEmitter("projection_changed"),this.mapRightclick=this._eventManager.getLazyEmitter("rightclick"),this.tilesloaded=this._eventManager.getLazyEmitter("tilesloaded"),this.tiltChanged=this._eventManager.getLazyEmitter("tilt_changed"),this.zoomChanged=this._eventManager.getLazyEmitter("zoomChanged"),this._isBrowser=e?n.isPlatformBrowser(e):"object"==typeof window&&!!window,this._isBrowser&&!window.google)throw Error("Namespace google not found, cannot construct embedded google map. Please install the Google Maps JavaScript API: https://developers.google.com/maps/documentation/javascript/tutorial#Loading_the_Maps_API")}return Object.defineProperty(t.prototype,"center",{set:function(t){this._center.next(t)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"zoom",{set:function(t){this._zoom.next(t)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"options",{set:function(t){this._options.next(t||s)},enumerable:!0,configurable:!0}),t.prototype.ngOnChanges=function(){this._setSize()},t.prototype.ngOnInit=function(){var t=this;this._isBrowser&&(this._mapEl=this._elementRef.nativeElement.querySelector(".map-container"),this._setSize(),this._googleMapChanges=this._initializeMap(this._combineOptions()),this._googleMapChanges.subscribe((function(e){t._googleMap=e,t._eventManager.setTarget(t._googleMap)})),this._watchForOptionsChanges(),this._watchForCenterChanges(),this._watchForZoomChanges())},t.prototype.ngOnDestroy=function(){this._eventManager.destroy(),this._destroy.next(),this._destroy.complete()},t.prototype.fitBounds=function(t,e){this._assertInitialized(),this._googleMap.fitBounds(t,e)},t.prototype.panBy=function(t,e){this._assertInitialized(),this._googleMap.panBy(t,e)},t.prototype.panTo=function(t){this._assertInitialized(),this._googleMap.panTo(t)},t.prototype.panToBounds=function(t,e){this._assertInitialized(),this._googleMap.panToBounds(t,e)},t.prototype.getBounds=function(){return this._assertInitialized(),this._googleMap.getBounds()||null},t.prototype.getCenter=function(){return this._assertInitialized(),this._googleMap.getCenter()},t.prototype.getClickableIcons=function(){return this._assertInitialized(),this._googleMap.getClickableIcons()},t.prototype.getHeading=function(){return this._assertInitialized(),this._googleMap.getHeading()},t.prototype.getMapTypeId=function(){return this._assertInitialized(),this._googleMap.getMapTypeId()},t.prototype.getProjection=function(){return this._assertInitialized(),this._googleMap.getProjection()},t.prototype.getStreetView=function(){return this._assertInitialized(),this._googleMap.getStreetView()},t.prototype.getTilt=function(){return this._assertInitialized(),this._googleMap.getTilt()},t.prototype.getZoom=function(){return this._assertInitialized(),this._googleMap.getZoom()},Object.defineProperty(t.prototype,"controls",{get:function(){return this._assertInitialized(),this._googleMap.controls},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"data",{get:function(){return this._assertInitialized(),this._googleMap.data},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"mapTypes",{get:function(){return this._assertInitialized(),this._googleMap.mapTypes},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"overlayMapTypes",{get:function(){return this._assertInitialized(),this._googleMap.overlayMapTypes},enumerable:!0,configurable:!0}),t.prototype._setSize=function(){this._mapEl&&(this._mapEl.style.height=this.height||p,this._mapEl.style.width=this.width||g)},t.prototype._combineOptions=function(){return o.combineLatest([this._options,this._center,this._zoom]).pipe(a.map((function(t){var i=e.__read(t,3),n=i[0],o=i[1],a=i[2];return e.__assign(e.__assign({},n),{center:o||n.center,zoom:void 0!==a?a:n.zoom})})))},t.prototype._initializeMap=function(t){var e=this;return t.pipe(a.take(1),a.map((function(t){return new google.maps.Map(e._mapEl,t)})),a.shareReplay(1))},t.prototype._watchForOptionsChanges=function(){o.combineLatest([this._googleMapChanges,this._options]).pipe(a.takeUntil(this._destroy)).subscribe((function(t){var i=e.__read(t,2);i[0].setOptions(i[1])}))},t.prototype._watchForCenterChanges=function(){o.combineLatest([this._googleMapChanges,this._center]).pipe(a.takeUntil(this._destroy)).subscribe((function(t){var i=e.__read(t,2),n=i[1];n&&i[0].setCenter(n)}))},t.prototype._watchForZoomChanges=function(){o.combineLatest([this._googleMapChanges,this._zoom]).pipe(a.takeUntil(this._destroy)).subscribe((function(t){var i=e.__read(t,2),n=i[1];void 0!==n&&i[0].setZoom(n)}))},t.prototype._assertInitialized=function(){if(!this._googleMap)throw Error("Cannot access Google Map information before the API has been initialized. Please wait for the API to load before trying to interact with it.")},t.decorators=[{type:i.Component,args:[{selector:"google-map",changeDetection:i.ChangeDetectionStrategy.OnPush,template:'<div class="map-container"></div><ng-content></ng-content>',encapsulation:i.ViewEncapsulation.None}]}],t.ctorParameters=function(){return[{type:i.ElementRef},{type:Object,decorators:[{type:i.Optional},{type:i.Inject,args:[i.PLATFORM_ID]}]}]},t.propDecorators={height:[{type:i.Input}],width:[{type:i.Input}],center:[{type:i.Input}],zoom:[{type:i.Input}],options:[{type:i.Input}],boundsChanged:[{type:i.Output}],centerChanged:[{type:i.Output}],mapClick:[{type:i.Output}],mapDblclick:[{type:i.Output}],mapDrag:[{type:i.Output}],mapDragend:[{type:i.Output}],mapDragstart:[{type:i.Output}],headingChanged:[{type:i.Output}],idle:[{type:i.Output}],maptypeidChanged:[{type:i.Output}],mapMousemove:[{type:i.Output}],mapMouseout:[{type:i.Output}],mapMouseover:[{type:i.Output}],projectionChanged:[{type:i.Output}],mapRightclick:[{type:i.Output}],tilesloaded:[{type:i.Output}],tiltChanged:[{type:i.Output}],zoomChanged:[{type:i.Output}]},t}(),u=function(){function t(t,e){this._googleMap=t,this._elementRef=e,this._eventManager=new r,this._options=new o.BehaviorSubject({}),this._position=new o.BehaviorSubject(void 0),this._destroy=new o.Subject,this.closeclick=this._eventManager.getLazyEmitter("closeclick"),this.contentChanged=this._eventManager.getLazyEmitter("content_changed"),this.domready=this._eventManager.getLazyEmitter("domready"),this.positionChanged=this._eventManager.getLazyEmitter("position_changed"),this.zindexChanged=this._eventManager.getLazyEmitter("zindex_changed")}return Object.defineProperty(t.prototype,"options",{set:function(t){this._options.next(t||{})},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"position",{set:function(t){this._position.next(t)},enumerable:!0,configurable:!0}),t.prototype.ngOnInit=function(){var t=this;this._combineOptions().pipe(a.takeUntil(this._destroy)).subscribe((function(e){t._infoWindow?t._infoWindow.setOptions(e):(t._infoWindow=new google.maps.InfoWindow(e),t._eventManager.setTarget(t._infoWindow))}))},t.prototype.ngOnDestroy=function(){this._eventManager.destroy(),this._destroy.next(),this._destroy.complete(),this.close()},t.prototype.close=function(){this._infoWindow&&this._infoWindow.close()},t.prototype.getContent=function(){return this._infoWindow.getContent()},t.prototype.getPosition=function(){return this._infoWindow.getPosition()||null},t.prototype.getZIndex=function(){return this._infoWindow.getZIndex()},t.prototype.open=function(t){var e=t?t._marker:void 0;this._googleMap._googleMap&&(this._elementRef.nativeElement.style.display="",this._infoWindow.open(this._googleMap._googleMap,e))},t.prototype._combineOptions=function(){var t=this;return o.combineLatest([this._options,this._position]).pipe(a.map((function(i){var n=e.__read(i,2),o=n[0],a=n[1];return e.__assign(e.__assign({},o),{position:a||o.position,content:t._elementRef.nativeElement})})))},t.decorators=[{type:i.Directive,args:[{selector:"map-info-window",host:{style:"display: none"}}]}],t.ctorParameters=function(){return[{type:h},{type:i.ElementRef}]},t.propDecorators={options:[{type:i.Input}],position:[{type:i.Input}],closeclick:[{type:i.Output}],contentChanged:[{type:i.Output}],domready:[{type:i.Output}],positionChanged:[{type:i.Output}],zindexChanged:[{type:i.Output}]},t}(),l={position:{lat:37.421995,lng:-122.084092}},c=function(){function t(t){this._googleMap=t,this._eventManager=new r,this._options=new o.BehaviorSubject(l),this._title=new o.BehaviorSubject(void 0),this._position=new o.BehaviorSubject(void 0),this._label=new o.BehaviorSubject(void 0),this._clickable=new o.BehaviorSubject(void 0),this._destroy=new o.Subject,this.animationChanged=this._eventManager.getLazyEmitter("animation_changed"),this.mapClick=this._eventManager.getLazyEmitter("click"),this.clickableChanged=this._eventManager.getLazyEmitter("clickable_changed"),this.cursorChanged=this._eventManager.getLazyEmitter("cursor_changed"),this.mapDblclick=this._eventManager.getLazyEmitter("dblclick"),this.mapDrag=this._eventManager.getLazyEmitter("drag"),this.mapDragend=this._eventManager.getLazyEmitter("dragend"),this.draggableChanged=this._eventManager.getLazyEmitter("draggable_changed"),this.mapDragstart=this._eventManager.getLazyEmitter("dragstart"),this.flatChanged=this._eventManager.getLazyEmitter("flat_changed"),this.iconChanged=this._eventManager.getLazyEmitter("icon_changed"),this.mapMousedown=this._eventManager.getLazyEmitter("mousedown"),this.mapMouseout=this._eventManager.getLazyEmitter("mouseout"),this.mapMouseover=this._eventManager.getLazyEmitter("mouseover"),this.mapMouseup=this._eventManager.getLazyEmitter("mouseup"),this.positionChanged=this._eventManager.getLazyEmitter("position_changed"),this.mapRightclick=this._eventManager.getLazyEmitter("rightclick"),this.shapeChanged=this._eventManager.getLazyEmitter("shape_changed"),this.titleChanged=this._eventManager.getLazyEmitter("title_changed"),this.visibleChanged=this._eventManager.getLazyEmitter("visible_changed"),this.zindexChanged=this._eventManager.getLazyEmitter("zindex_changed")}return Object.defineProperty(t.prototype,"options",{set:function(t){this._options.next(t||l)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"title",{set:function(t){this._title.next(t)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"position",{set:function(t){this._position.next(t)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"label",{set:function(t){this._label.next(t)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"clickable",{set:function(t){this._clickable.next(t)},enumerable:!0,configurable:!0}),t.prototype.ngOnInit=function(){var t=this;this._combineOptions().pipe(a.take(1)).subscribe((function(e){t._marker=new google.maps.Marker(e),t._marker.setMap(t._googleMap._googleMap),t._eventManager.setTarget(t._marker)})),this._watchForOptionsChanges(),this._watchForTitleChanges(),this._watchForPositionChanges(),this._watchForLabelChanges(),this._watchForClickableChanges()},t.prototype.ngOnDestroy=function(){this._destroy.next(),this._destroy.complete(),this._eventManager.destroy(),this._marker&&this._marker.setMap(null)},t.prototype.getAnimation=function(){return this._marker.getAnimation()||null},t.prototype.getClickable=function(){return this._marker.getClickable()},t.prototype.getCursor=function(){return this._marker.getCursor()||null},t.prototype.getDraggable=function(){return!!this._marker.getDraggable()},t.prototype.getIcon=function(){return this._marker.getIcon()||null},t.prototype.getLabel=function(){return this._marker.getLabel()||null},t.prototype.getOpacity=function(){return this._marker.getOpacity()||null},t.prototype.getPosition=function(){return this._marker.getPosition()||null},t.prototype.getShape=function(){return this._marker.getShape()||null},t.prototype.getTitle=function(){return this._marker.getTitle()||null},t.prototype.getVisible=function(){return this._marker.getVisible()},t.prototype.getZIndex=function(){return this._marker.getZIndex()||null},t.prototype._combineOptions=function(){var t=this;return o.combineLatest([this._options,this._title,this._position,this._label,this._clickable]).pipe(a.map((function(i){var n=e.__read(i,5),o=n[0],a=n[1],r=n[2],s=n[3],p=n[4];return e.__assign(e.__assign({},o),{title:a||o.title,position:r||o.position,label:s||o.label,clickable:void 0!==p?p:o.clickable,map:t._googleMap._googleMap||null})})))},t.prototype._watchForOptionsChanges=function(){var t=this;this._options.pipe(a.takeUntil(this._destroy)).subscribe((function(e){t._marker&&t._marker.setOptions(e)}))},t.prototype._watchForTitleChanges=function(){var t=this;this._title.pipe(a.takeUntil(this._destroy)).subscribe((function(e){t._marker&&void 0!==e&&t._marker.setTitle(e)}))},t.prototype._watchForPositionChanges=function(){var t=this;this._position.pipe(a.takeUntil(this._destroy)).subscribe((function(e){t._marker&&e&&t._marker.setPosition(e)}))},t.prototype._watchForLabelChanges=function(){var t=this;this._label.pipe(a.takeUntil(this._destroy)).subscribe((function(e){t._marker&&void 0!==e&&t._marker.setLabel(e)}))},t.prototype._watchForClickableChanges=function(){var t=this;this._clickable.pipe(a.takeUntil(this._destroy)).subscribe((function(e){t._marker&&void 0!==e&&t._marker.setClickable(e)}))},t.decorators=[{type:i.Component,args:[{selector:"map-marker",template:"<ng-content></ng-content>",changeDetection:i.ChangeDetectionStrategy.OnPush,encapsulation:i.ViewEncapsulation.None}]}],t.ctorParameters=function(){return[{type:h}]},t.propDecorators={options:[{type:i.Input}],title:[{type:i.Input}],position:[{type:i.Input}],label:[{type:i.Input}],clickable:[{type:i.Input}],animationChanged:[{type:i.Output}],mapClick:[{type:i.Output}],clickableChanged:[{type:i.Output}],cursorChanged:[{type:i.Output}],mapDblclick:[{type:i.Output}],mapDrag:[{type:i.Output}],mapDragend:[{type:i.Output}],draggableChanged:[{type:i.Output}],mapDragstart:[{type:i.Output}],flatChanged:[{type:i.Output}],iconChanged:[{type:i.Output}],mapMousedown:[{type:i.Output}],mapMouseout:[{type:i.Output}],mapMouseover:[{type:i.Output}],mapMouseup:[{type:i.Output}],positionChanged:[{type:i.Output}],mapRightclick:[{type:i.Output}],shapeChanged:[{type:i.Output}],titleChanged:[{type:i.Output}],visibleChanged:[{type:i.Output}],zindexChanged:[{type:i.Output}]},t}(),_=function(){function t(t){this._map=t,this._eventManager=new r,this._options=new o.BehaviorSubject({}),this._path=new o.BehaviorSubject(void 0),this._destroyed=new o.Subject,this._listeners=[],this.polylineClick=this._eventManager.getLazyEmitter("click"),this.polylineDblclick=this._eventManager.getLazyEmitter("dblclick"),this.polylineDrag=this._eventManager.getLazyEmitter("drag"),this.polylineDragend=this._eventManager.getLazyEmitter("dragend"),this.polylineDragstart=this._eventManager.getLazyEmitter("dragstart"),this.polylineMousedown=this._eventManager.getLazyEmitter("mousedown"),this.polylineMousemove=this._eventManager.getLazyEmitter("mousemove"),this.polylineMouseout=this._eventManager.getLazyEmitter("mouseout"),this.polylineMouseover=this._eventManager.getLazyEmitter("mouseover"),this.polylineMouseup=this._eventManager.getLazyEmitter("mouseup"),this.polylineRightclick=this._eventManager.getLazyEmitter("rightclick")}return Object.defineProperty(t.prototype,"options",{set:function(t){this._options.next(t||{})},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"path",{set:function(t){this._path.next(t)},enumerable:!0,configurable:!0}),t.prototype.ngOnInit=function(){var t=this;this._combineOptions().pipe(a.take(1)).subscribe((function(e){t._polyline=new google.maps.Polyline(e),t._polyline.setMap(t._map._googleMap),t._eventManager.setTarget(t._polyline)})),this._watchForOptionsChanges(),this._watchForPathChanges()},t.prototype.ngOnDestroy=function(){var t,i;this._eventManager.destroy(),this._destroyed.next(),this._destroyed.complete();try{for(var n=e.__values(this._listeners),o=n.next();!o.done;o=n.next())o.value.remove()}catch(e){t={error:e}}finally{try{o&&!o.done&&(i=n.return)&&i.call(n)}finally{if(t)throw t.error}}this._polyline.setMap(null)},t.prototype.getDraggable=function(){return this._polyline.getDraggable()},t.prototype.getEditable=function(){return this._polyline.getEditable()},t.prototype.getPath=function(){return this._polyline.getPath()},t.prototype.getVisible=function(){return this._polyline.getVisible()},t.prototype._combineOptions=function(){return o.combineLatest([this._options,this._path]).pipe(a.map((function(t){var i=e.__read(t,2),n=i[0],o=i[1];return e.__assign(e.__assign({},n),{path:o||n.path})})))},t.prototype._watchForOptionsChanges=function(){var t=this;this._options.pipe(a.takeUntil(this._destroyed)).subscribe((function(e){t._polyline.setOptions(e)}))},t.prototype._watchForPathChanges=function(){var t=this;this._path.pipe(a.takeUntil(this._destroyed)).subscribe((function(e){e&&t._polyline.setPath(e)}))},t.decorators=[{type:i.Directive,args:[{selector:"map-polyline"}]}],t.ctorParameters=function(){return[{type:h}]},t.propDecorators={options:[{type:i.Input}],path:[{type:i.Input}],polylineClick:[{type:i.Output}],polylineDblclick:[{type:i.Output}],polylineDrag:[{type:i.Output}],polylineDragend:[{type:i.Output}],polylineDragstart:[{type:i.Output}],polylineMousedown:[{type:i.Output}],polylineMousemove:[{type:i.Output}],polylineMouseout:[{type:i.Output}],polylineMouseover:[{type:i.Output}],polylineMouseup:[{type:i.Output}],polylineRightclick:[{type:i.Output}]},t}(),y=[h,u,c,_],d=function(){function t(){}return t.decorators=[{type:i.NgModule,args:[{declarations:y,exports:y}]}],t}();
/**

@@ -17,2 +17,9 @@ * @license

*/
t.GoogleMap=h,t.GoogleMapsModule=d,t.MapInfoWindow=l,t.MapMarker=u,Object.defineProperty(t,"__esModule",{value:!0})}));
/**
* @license
* Copyright Google LLC All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://angular.io/license
*/
t.GoogleMap=h,t.GoogleMapsModule=d,t.MapInfoWindow=u,t.MapMarker=c,t.MapPolyline=_,Object.defineProperty(t,"__esModule",{value:!0})}));
/**
* @fileoverview added by tsickle
* Generated from: src/google-maps/google-map/google-map.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc

@@ -15,6 +16,7 @@ */

/// <reference types="googlemaps" />
import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, Input, Output, ViewEncapsulation, Optional, Inject, PLATFORM_ID, } from '@angular/core';
import { ChangeDetectionStrategy, Component, ElementRef, Input, Output, ViewEncapsulation, Optional, Inject, PLATFORM_ID, } from '@angular/core';
import { isPlatformBrowser } from '@angular/common';
import { BehaviorSubject, combineLatest, Subject } from 'rxjs';
import { BehaviorSubject, combineLatest, Observable, Subject } from 'rxjs';
import { map, shareReplay, take, takeUntil } from 'rxjs/operators';
import { MapEventManager } from '../map-event-manager';
/**

@@ -73,2 +75,7 @@ * @record

this._elementRef = _elementRef;
this._eventManager = new MapEventManager();
this._options = new BehaviorSubject(DEFAULT_OPTIONS);
this._center = new BehaviorSubject(undefined);
this._zoom = new BehaviorSubject(undefined);
this._destroy = new Subject();
this.height = DEFAULT_HEIGHT;

@@ -80,3 +87,3 @@ this.width = DEFAULT_WIDTH;

*/
this.boundsChanged = new EventEmitter();
this.boundsChanged = this._eventManager.getLazyEmitter('bounds_changed');
/**

@@ -86,3 +93,3 @@ * See

*/
this.centerChanged = new EventEmitter();
this.centerChanged = this._eventManager.getLazyEmitter('center_changed');
/**

@@ -92,3 +99,3 @@ * See

*/
this.mapClick = new EventEmitter();
this.mapClick = this._eventManager.getLazyEmitter('click');
/**

@@ -98,3 +105,3 @@ * See

*/
this.mapDblclick = new EventEmitter();
this.mapDblclick = this._eventManager.getLazyEmitter('dblclick');
/**

@@ -104,3 +111,3 @@ * See

*/
this.mapDrag = new EventEmitter();
this.mapDrag = this._eventManager.getLazyEmitter('drag');
/**

@@ -110,3 +117,3 @@ * See

*/
this.mapDragend = new EventEmitter();
this.mapDragend = this._eventManager.getLazyEmitter('dragend');
/**

@@ -116,3 +123,3 @@ * See

*/
this.mapDragstart = new EventEmitter();
this.mapDragstart = this._eventManager.getLazyEmitter('dragstart');
/**

@@ -122,3 +129,3 @@ * See

*/
this.headingChanged = new EventEmitter();
this.headingChanged = this._eventManager.getLazyEmitter('heading_changed');
/**

@@ -128,3 +135,3 @@ * See

*/
this.idle = new EventEmitter();
this.idle = this._eventManager.getLazyEmitter('idle');
/**

@@ -134,3 +141,3 @@ * See

*/
this.maptypeidChanged = new EventEmitter();
this.maptypeidChanged = this._eventManager.getLazyEmitter('maptypeid_changed');
/**

@@ -140,3 +147,3 @@ * See

*/
this.mapMousemove = new EventEmitter();
this.mapMousemove = this._eventManager.getLazyEmitter('mousemove');
/**

@@ -146,3 +153,3 @@ * See

*/
this.mapMouseout = new EventEmitter();
this.mapMouseout = this._eventManager.getLazyEmitter('mouseout');
/**

@@ -152,3 +159,3 @@ * See

*/
this.mapMouseover = new EventEmitter();
this.mapMouseover = this._eventManager.getLazyEmitter('mouseover');
/**

@@ -158,3 +165,3 @@ * See

*/
this.projectionChanged = new EventEmitter();
this.projectionChanged = this._eventManager.getLazyEmitter('projection_changed');
/**

@@ -164,3 +171,3 @@ * See

*/
this.mapRightclick = new EventEmitter();
this.mapRightclick = this._eventManager.getLazyEmitter('rightclick');
/**

@@ -170,3 +177,3 @@ * See

*/
this.tilesloaded = new EventEmitter();
this.tilesloaded = this._eventManager.getLazyEmitter('tilesloaded');
/**

@@ -176,3 +183,3 @@ * See

*/
this.tiltChanged = new EventEmitter();
this.tiltChanged = this._eventManager.getLazyEmitter('tilt_changed');
/**

@@ -182,8 +189,3 @@ * See

*/
this.zoomChanged = new EventEmitter();
this._listeners = [];
this._options = new BehaviorSubject(DEFAULT_OPTIONS);
this._center = new BehaviorSubject(undefined);
this._zoom = new BehaviorSubject(undefined);
this._destroy = new Subject();
this.zoomChanged = this._eventManager.getLazyEmitter('zoomChanged');
// @breaking-change 10.0.0 Remove null check for `platformId`.

@@ -238,5 +240,3 @@ this._isBrowser =

this._setSize();
/** @type {?} */
const combinedOptionsChanges = this._combineOptions();
this._googleMapChanges = this._initializeMap(combinedOptionsChanges);
this._googleMapChanges = this._initializeMap(this._combineOptions());
this._googleMapChanges.subscribe((/**

@@ -248,3 +248,3 @@ * @param {?} googleMap

this._googleMap = (/** @type {?} */ (googleMap));
this._initializeEventHandlers();
this._eventManager.setTarget(this._googleMap);
}));

@@ -260,5 +260,5 @@ this._watchForOptionsChanges();

ngOnDestroy() {
this._eventManager.destroy();
this._destroy.next();
this._destroy.complete();
this._clearListeners();
}

@@ -273,2 +273,3 @@ /**

fitBounds(bounds, padding) {
this._assertInitialized();
this._googleMap.fitBounds(bounds, padding);

@@ -284,2 +285,3 @@ }

panBy(x, y) {
this._assertInitialized();
this._googleMap.panBy(x, y);

@@ -294,2 +296,3 @@ }

panTo(latLng) {
this._assertInitialized();
this._googleMap.panTo(latLng);

@@ -305,2 +308,3 @@ }

panToBounds(latLngBounds, padding) {
this._assertInitialized();
this._googleMap.panToBounds(latLngBounds, padding);

@@ -314,2 +318,3 @@ }

getBounds() {
this._assertInitialized();
return this._googleMap.getBounds() || null;

@@ -323,2 +328,3 @@ }

getCenter() {
this._assertInitialized();
return this._googleMap.getCenter();

@@ -332,2 +338,3 @@ }

getClickableIcons() {
this._assertInitialized();
return this._googleMap.getClickableIcons();

@@ -341,2 +348,3 @@ }

getHeading() {
this._assertInitialized();
return this._googleMap.getHeading();

@@ -350,2 +358,3 @@ }

getMapTypeId() {
this._assertInitialized();
return this._googleMap.getMapTypeId();

@@ -359,2 +368,3 @@ }

getProjection() {
this._assertInitialized();
return this._googleMap.getProjection();

@@ -368,2 +378,3 @@ }

getStreetView() {
this._assertInitialized();
return this._googleMap.getStreetView();

@@ -377,2 +388,3 @@ }

getTilt() {
this._assertInitialized();
return this._googleMap.getTilt();

@@ -386,2 +398,3 @@ }

getZoom() {
this._assertInitialized();
return this._googleMap.getZoom();

@@ -395,2 +408,3 @@ }

get controls() {
this._assertInitialized();
return this._googleMap.controls;

@@ -404,2 +418,3 @@ }

get data() {
this._assertInitialized();
return this._googleMap.data;

@@ -413,2 +428,3 @@ }

get mapTypes() {
this._assertInitialized();
return this._googleMap.mapTypes;

@@ -422,2 +438,3 @@ }

get overlayMapTypes() {
this._assertInitialized();
return this._googleMap.overlayMapTypes;

@@ -462,5 +479,3 @@ }

*/
options => {
return new google.maps.Map(this._mapEl, options);
})), shareReplay(1));
options => new google.maps.Map(this._mapEl, options))), shareReplay(1));
}

@@ -517,83 +532,12 @@ /**

/**
* Asserts that the map has been initialized.
* @private
* @return {?}
*/
_initializeEventHandlers() {
// Ensure that we don't leak if called multiple times.
this._clearListeners();
/** @type {?} */
const eventHandlers = new Map([
['bounds_changed', this.boundsChanged],
['center_changed', this.centerChanged],
['drag', this.mapDrag],
['dragend', this.mapDragend],
['dragstart', this.mapDragstart],
['heading_changed', this.headingChanged],
['idle', this.idle],
['maptypeid_changed', this.maptypeidChanged],
['projection_changed', this.projectionChanged],
['tilesloaded', this.tilesloaded],
['tilt_changed', this.tiltChanged],
['zoomChanged', this.zoomChanged],
]);
/** @type {?} */
const mouseEventHandlers = new Map([
['dblclick', this.mapDblclick],
['mousemove', this.mapMousemove],
['mouseout', this.mapMouseout],
['mouseover', this.mapMouseover],
['rightclick', this.mapRightclick],
]);
eventHandlers.forEach((/**
* @param {?} eventHandler
* @param {?} name
* @return {?}
*/
(eventHandler, name) => {
if (eventHandler.observers.length > 0) {
this._listeners.push(this._googleMap.addListener(name, (/**
* @return {?}
*/
() => {
eventHandler.emit();
})));
}
}));
mouseEventHandlers.forEach((/**
* @param {?} eventHandler
* @param {?} name
* @return {?}
*/
(eventHandler, name) => {
if (eventHandler.observers.length > 0) {
this._listeners.push(this._googleMap.addListener(name, (/**
* @param {?} event
* @return {?}
*/
(event) => {
eventHandler.emit(event);
})));
}
}));
if (this.mapClick.observers.length > 0) {
this._listeners.push(this._googleMap.addListener('click', (/**
* @param {?} event
* @return {?}
*/
(event) => {
this.mapClick.emit(event);
})));
_assertInitialized() {
if (!this._googleMap) {
throw Error('Cannot access Google Map information before the API has been initialized. ' +
'Please wait for the API to load before trying to interact with it.');
}
}
/**
* Clears all currently-registered event listeners.
* @private
* @return {?}
*/
_clearListeners() {
for (let listener of this._listeners) {
listener.remove();
}
this._listeners = [];
}
}

@@ -639,3 +583,46 @@ GoogleMap.decorators = [

if (false) {
/**
* @type {?}
* @private
*/
GoogleMap.prototype._eventManager;
/**
* Whether we're currently rendering inside a browser.
* @type {?}
* @private
*/
GoogleMap.prototype._isBrowser;
/**
* @type {?}
* @private
*/
GoogleMap.prototype._googleMapChanges;
/**
* @type {?}
* @private
*/
GoogleMap.prototype._options;
/**
* @type {?}
* @private
*/
GoogleMap.prototype._center;
/**
* @type {?}
* @private
*/
GoogleMap.prototype._zoom;
/**
* @type {?}
* @private
*/
GoogleMap.prototype._destroy;
/**
* @type {?}
* @private
*/
GoogleMap.prototype._mapEl;
/** @type {?} */
GoogleMap.prototype._googleMap;
/** @type {?} */
GoogleMap.prototype.height;

@@ -756,47 +743,4 @@ /** @type {?} */

*/
GoogleMap.prototype._mapEl;
/** @type {?} */
GoogleMap.prototype._googleMap;
/**
* Whether we're currently rendering inside a browser.
* @type {?}
* @private
*/
GoogleMap.prototype._isBrowser;
/**
* @type {?}
* @private
*/
GoogleMap.prototype._googleMapChanges;
/**
* @type {?}
* @private
*/
GoogleMap.prototype._listeners;
/**
* @type {?}
* @private
*/
GoogleMap.prototype._options;
/**
* @type {?}
* @private
*/
GoogleMap.prototype._center;
/**
* @type {?}
* @private
*/
GoogleMap.prototype._zoom;
/**
* @type {?}
* @private
*/
GoogleMap.prototype._destroy;
/**
* @type {?}
* @private
*/
GoogleMap.prototype._elementRef;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"google-map.js","sourceRoot":"","sources":["../../../../../../src/google-maps/google-map/google-map.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n// Workaround for: https://github.com/bazelbuild/rules_nodejs/issues/1265\n/// <reference types=\"googlemaps\" />\n\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewEncapsulation,\n  Optional,\n  Inject,\n  PLATFORM_ID,\n} from '@angular/core';\nimport {isPlatformBrowser} from '@angular/common';\nimport {BehaviorSubject, combineLatest, Observable, Subject} from 'rxjs';\nimport {map, shareReplay, take, takeUntil} from 'rxjs/operators';\n\ninterface GoogleMapsWindow extends Window {\n  google?: typeof google;\n}\n\n// TODO(mbehrlich): Update this to use original map after updating DefinitelyTyped\n/**\n * Extends the Google Map interface due to the Definitely Typed implementation\n * missing \"getClickableIcons\".\n */\nexport interface UpdatedGoogleMap extends google.maps.Map {\n  getClickableIcons: () => boolean;\n}\n\n/** default options set to the Googleplex */\nexport const DEFAULT_OPTIONS: google.maps.MapOptions = {\n  center: {lat: 37.421995, lng: -122.084092},\n  zoom: 17,\n};\n\n/** Arbitrary default height for the map element */\nexport const DEFAULT_HEIGHT = '500px';\n/** Arbitrary default width for the map element */\nexport const DEFAULT_WIDTH = '500px';\n\n/**\n * Angular component that renders a Google Map via the Google Maps JavaScript\n * API.\n * @see https://developers.google.com/maps/documentation/javascript/reference/\n */\n@Component({\n  selector: 'google-map',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  template: '<div class=\"map-container\"></div><ng-content></ng-content>',\n  encapsulation: ViewEncapsulation.None,\n})\nexport class GoogleMap implements OnChanges, OnInit, OnDestroy {\n  @Input() height = DEFAULT_HEIGHT;\n\n  @Input() width = DEFAULT_WIDTH;\n\n  @Input()\n  set center(center: google.maps.LatLngLiteral|google.maps.LatLng) {\n    this._center.next(center);\n  }\n  @Input()\n  set zoom(zoom: number) {\n    this._zoom.next(zoom);\n  }\n  @Input()\n  set options(options: google.maps.MapOptions) {\n    this._options.next(options || DEFAULT_OPTIONS);\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.bounds_changed\n   */\n  @Output() boundsChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.center_changed\n   */\n  @Output() centerChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.click\n   */\n  @Output() mapClick = new EventEmitter<google.maps.MouseEvent|google.maps.IconMouseEvent>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.dblclick\n   */\n  @Output() mapDblclick = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.drag\n   */\n  @Output() mapDrag = new EventEmitter<void>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.dragend\n   */\n  @Output() mapDragend = new EventEmitter<void>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.dragstart\n   */\n  @Output() mapDragstart = new EventEmitter<void>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.heading_changed\n   */\n  @Output() headingChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.idle\n   */\n  @Output() idle = new EventEmitter<void>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.maptypeid_changed\n   */\n  @Output() maptypeidChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.mousemove\n   */\n  @Output() mapMousemove = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.mouseout\n   */\n  @Output() mapMouseout = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.mouseover\n   */\n  @Output() mapMouseover = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/map#Map.projection_changed\n   */\n  @Output() projectionChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.rightclick\n   */\n  @Output() mapRightclick = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.tilesloaded\n   */\n  @Output() tilesloaded = new EventEmitter<void>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.tilt_changed\n   */\n  @Output() tiltChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.zoom_changed\n   */\n  @Output() zoomChanged = new EventEmitter<void>();\n\n  private _mapEl: HTMLElement;\n  _googleMap!: UpdatedGoogleMap;\n\n  /** Whether we're currently rendering inside a browser. */\n  private _isBrowser: boolean;\n  private _googleMapChanges!: Observable<google.maps.Map>;\n\n  private _listeners: google.maps.MapsEventListener[] = [];\n\n  private readonly _options = new BehaviorSubject<google.maps.MapOptions>(DEFAULT_OPTIONS);\n  private readonly _center =\n      new BehaviorSubject<google.maps.LatLngLiteral|google.maps.LatLng|undefined>(undefined);\n  private readonly _zoom = new BehaviorSubject<number|undefined>(undefined);\n\n  private readonly _destroy = new Subject<void>();\n\n  constructor(\n    private readonly _elementRef: ElementRef,\n    /**\n     * @deprecated `platformId` parameter to become required.\n     * @breaking-change 10.0.0\n     */\n    @Optional() @Inject(PLATFORM_ID) platformId?: Object) {\n\n    // @breaking-change 10.0.0 Remove null check for `platformId`.\n    this._isBrowser =\n        platformId ? isPlatformBrowser(platformId) : typeof window === 'object' && !!window;\n\n    if (this._isBrowser) {\n      const googleMapsWindow: GoogleMapsWindow = window;\n      if (!googleMapsWindow.google) {\n        throw Error(\n            'Namespace google not found, cannot construct embedded google ' +\n            'map. Please install the Google Maps JavaScript API: ' +\n            'https://developers.google.com/maps/documentation/javascript/' +\n            'tutorial#Loading_the_Maps_API');\n      }\n    }\n  }\n\n  ngOnChanges() {\n    this._setSize();\n  }\n\n  ngOnInit() {\n    // It should be a noop during server-side rendering.\n    if (this._isBrowser) {\n      this._mapEl = this._elementRef.nativeElement.querySelector('.map-container')!;\n      this._setSize();\n\n      const combinedOptionsChanges = this._combineOptions();\n\n      this._googleMapChanges = this._initializeMap(combinedOptionsChanges);\n      this._googleMapChanges.subscribe((googleMap: google.maps.Map) => {\n        this._googleMap = googleMap as UpdatedGoogleMap;\n\n        this._initializeEventHandlers();\n      });\n\n      this._watchForOptionsChanges();\n      this._watchForCenterChanges();\n      this._watchForZoomChanges();\n    }\n  }\n\n  ngOnDestroy() {\n    this._destroy.next();\n    this._destroy.complete();\n    this._clearListeners();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.fitBounds\n   */\n  fitBounds(\n      bounds: google.maps.LatLngBounds|google.maps.LatLngBoundsLiteral,\n      padding?: number|google.maps.Padding) {\n    this._googleMap.fitBounds(bounds, padding);\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.panBy\n   */\n  panBy(x: number, y: number) {\n    this._googleMap.panBy(x, y);\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.panTo\n   */\n  panTo(latLng: google.maps.LatLng|google.maps.LatLngLiteral) {\n    this._googleMap.panTo(latLng);\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.panToBounds\n   */\n  panToBounds(\n      latLngBounds: google.maps.LatLngBounds|google.maps.LatLngBoundsLiteral,\n      padding?: number|google.maps.Padding) {\n    this._googleMap.panToBounds(latLngBounds, padding);\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getBounds\n   */\n  getBounds(): google.maps.LatLngBounds|null {\n    return this._googleMap.getBounds() || null;\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getCenter\n   */\n  getCenter(): google.maps.LatLng {\n    return this._googleMap.getCenter();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getClickableIcons\n   */\n  getClickableIcons(): boolean {\n    return this._googleMap.getClickableIcons();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getHeading\n   */\n  getHeading(): number {\n    return this._googleMap.getHeading();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getMapTypeId\n   */\n  getMapTypeId(): google.maps.MapTypeId|string {\n    return this._googleMap.getMapTypeId();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getProjection\n   */\n  getProjection(): google.maps.Projection|null {\n    return this._googleMap.getProjection();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getStreetView\n   */\n  getStreetView(): google.maps.StreetViewPanorama {\n    return this._googleMap.getStreetView();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getTilt\n   */\n  getTilt(): number {\n    return this._googleMap.getTilt();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getZoom\n   */\n  getZoom(): number {\n    return this._googleMap.getZoom();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.controls\n   */\n  get controls(): Array<google.maps.MVCArray<Node>> {\n    return this._googleMap.controls;\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.data\n   */\n  get data(): google.maps.Data {\n    return this._googleMap.data;\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.mapTypes\n   */\n  get mapTypes(): google.maps.MapTypeRegistry {\n    return this._googleMap.mapTypes;\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.overlayMapTypes\n   */\n  get overlayMapTypes(): google.maps.MVCArray<google.maps.MapType> {\n    return this._googleMap.overlayMapTypes;\n  }\n\n  private _setSize() {\n    if (this._mapEl) {\n      this._mapEl.style.height = this.height || DEFAULT_HEIGHT;\n      this._mapEl.style.width = this.width || DEFAULT_WIDTH;\n    }\n  }\n\n  /** Combines the center and zoom and the other map options into a single object */\n  private _combineOptions(): Observable<google.maps.MapOptions> {\n    return combineLatest([this._options, this._center, this._zoom])\n        .pipe(map(([options, center, zoom]) => {\n          const combinedOptions: google.maps.MapOptions = {\n            ...options,\n            center: center || options.center,\n            zoom: zoom !== undefined ? zoom : options.zoom,\n          };\n          return combinedOptions;\n        }));\n  }\n\n  private _initializeMap(optionsChanges: Observable<google.maps.MapOptions>):\n      Observable<google.maps.Map> {\n    return optionsChanges.pipe(\n        take(1), map(options => {\n          return new google.maps.Map(this._mapEl, options);\n        }),\n        shareReplay(1));\n  }\n\n  private _watchForOptionsChanges() {\n    combineLatest([this._googleMapChanges, this._options])\n        .pipe(takeUntil(this._destroy))\n        .subscribe(([googleMap, options]) => {\n          googleMap.setOptions(options);\n        });\n  }\n\n  private _watchForCenterChanges() {\n    combineLatest([this._googleMapChanges, this._center])\n        .pipe(takeUntil(this._destroy))\n        .subscribe(([googleMap, center]) => {\n          if (center) {\n            googleMap.setCenter(center);\n          }\n        });\n  }\n\n  private _watchForZoomChanges() {\n    combineLatest([this._googleMapChanges, this._zoom])\n        .pipe(takeUntil(this._destroy))\n        .subscribe(([googleMap, zoom]) => {\n          if (zoom !== undefined) {\n            googleMap.setZoom(zoom);\n          }\n        });\n  }\n\n  private _initializeEventHandlers() {\n    // Ensure that we don't leak if called multiple times.\n    this._clearListeners();\n\n    const eventHandlers = new Map<string, EventEmitter<void>>([\n      ['bounds_changed', this.boundsChanged],\n      ['center_changed', this.centerChanged],\n      ['drag', this.mapDrag],\n      ['dragend', this.mapDragend],\n      ['dragstart', this.mapDragstart],\n      ['heading_changed', this.headingChanged],\n      ['idle', this.idle],\n      ['maptypeid_changed', this.maptypeidChanged],\n      ['projection_changed', this.projectionChanged],\n      ['tilesloaded', this.tilesloaded],\n      ['tilt_changed', this.tiltChanged],\n      ['zoomChanged', this.zoomChanged],\n    ]);\n    const mouseEventHandlers = new Map<string, EventEmitter<google.maps.MouseEvent>>([\n      ['dblclick', this.mapDblclick],\n      ['mousemove', this.mapMousemove],\n      ['mouseout', this.mapMouseout],\n      ['mouseover', this.mapMouseover],\n      ['rightclick', this.mapRightclick],\n    ]);\n    eventHandlers.forEach((eventHandler: EventEmitter<void>, name: string) => {\n      if (eventHandler.observers.length > 0) {\n        this._listeners.push(this._googleMap.addListener(name, () => {\n          eventHandler.emit();\n        }));\n      }\n    });\n    mouseEventHandlers.forEach(\n        (eventHandler: EventEmitter<google.maps.MouseEvent>, name: string) => {\n          if (eventHandler.observers.length > 0) {\n            this._listeners.push(\n                this._googleMap.addListener(name, (event: google.maps.MouseEvent) => {\n                  eventHandler.emit(event);\n                }));\n          }\n        });\n    if (this.mapClick.observers.length > 0) {\n      this._listeners.push(this._googleMap.addListener(\n          'click', (event: google.maps.MouseEvent|google.maps.IconMouseEvent) => {\n            this.mapClick.emit(event);\n          }));\n    }\n  }\n\n  /** Clears all currently-registered event listeners. */\n  private _clearListeners() {\n    for (let listener of this._listeners) {\n      listener.remove();\n    }\n\n    this._listeners = [];\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"google-map.js","sourceRoot":"","sources":["../../../../../../src/google-maps/google-map/google-map.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n// Workaround for: https://github.com/bazelbuild/rules_nodejs/issues/1265\n/// <reference types=\"googlemaps\" />\n\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewEncapsulation,\n  Optional,\n  Inject,\n  PLATFORM_ID,\n} from '@angular/core';\nimport {isPlatformBrowser} from '@angular/common';\nimport {BehaviorSubject, combineLatest, Observable, Subject} from 'rxjs';\nimport {map, shareReplay, take, takeUntil} from 'rxjs/operators';\nimport {MapEventManager} from '../map-event-manager';\n\ninterface GoogleMapsWindow extends Window {\n  google?: typeof google;\n}\n\n// TODO(mbehrlich): Update this to use original map after updating DefinitelyTyped\n/**\n * Extends the Google Map interface due to the Definitely Typed implementation\n * missing \"getClickableIcons\".\n */\nexport interface UpdatedGoogleMap extends google.maps.Map {\n  getClickableIcons: () => boolean;\n}\n\n/** default options set to the Googleplex */\nexport const DEFAULT_OPTIONS: google.maps.MapOptions = {\n  center: {lat: 37.421995, lng: -122.084092},\n  zoom: 17,\n};\n\n/** Arbitrary default height for the map element */\nexport const DEFAULT_HEIGHT = '500px';\n/** Arbitrary default width for the map element */\nexport const DEFAULT_WIDTH = '500px';\n\n/**\n * Angular component that renders a Google Map via the Google Maps JavaScript\n * API.\n * @see https://developers.google.com/maps/documentation/javascript/reference/\n */\n@Component({\n  selector: 'google-map',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  template: '<div class=\"map-container\"></div><ng-content></ng-content>',\n  encapsulation: ViewEncapsulation.None,\n})\nexport class GoogleMap implements OnChanges, OnInit, OnDestroy {\n  private _eventManager = new MapEventManager();\n\n  /** Whether we're currently rendering inside a browser. */\n  private _isBrowser: boolean;\n  private _googleMapChanges: Observable<google.maps.Map>;\n\n  private readonly _options = new BehaviorSubject<google.maps.MapOptions>(DEFAULT_OPTIONS);\n  private readonly _center =\n      new BehaviorSubject<google.maps.LatLngLiteral|google.maps.LatLng|undefined>(undefined);\n  private readonly _zoom = new BehaviorSubject<number|undefined>(undefined);\n  private readonly _destroy = new Subject<void>();\n  private _mapEl: HTMLElement;\n  _googleMap: UpdatedGoogleMap;\n\n  @Input() height = DEFAULT_HEIGHT;\n\n  @Input() width = DEFAULT_WIDTH;\n\n  @Input()\n  set center(center: google.maps.LatLngLiteral|google.maps.LatLng) {\n    this._center.next(center);\n  }\n  @Input()\n  set zoom(zoom: number) {\n    this._zoom.next(zoom);\n  }\n  @Input()\n  set options(options: google.maps.MapOptions) {\n    this._options.next(options || DEFAULT_OPTIONS);\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.bounds_changed\n   */\n  @Output()\n  boundsChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('bounds_changed');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.center_changed\n   */\n  @Output()\n  centerChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('center_changed');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.click\n   */\n  @Output()\n  mapClick: Observable<google.maps.MouseEvent|google.maps.IconMouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent|google.maps.IconMouseEvent>('click');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.dblclick\n   */\n  @Output()\n  mapDblclick: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('dblclick');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.drag\n   */\n  @Output() mapDrag: Observable<void> = this._eventManager.getLazyEmitter<void>('drag');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.dragend\n   */\n  @Output() mapDragend: Observable<void> = this._eventManager.getLazyEmitter<void>('dragend');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.dragstart\n   */\n  @Output() mapDragstart: Observable<void> = this._eventManager.getLazyEmitter<void>('dragstart');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.heading_changed\n   */\n  @Output()\n  headingChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('heading_changed');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.idle\n   */\n  @Output() idle: Observable<void> = this._eventManager.getLazyEmitter<void>('idle');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.maptypeid_changed\n   */\n  @Output()\n  maptypeidChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('maptypeid_changed');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.mousemove\n   */\n  @Output()\n  mapMousemove: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('mousemove');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.mouseout\n   */\n  @Output()\n  mapMouseout: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('mouseout');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.mouseover\n   */\n  @Output()\n  mapMouseover: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('mouseover');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/map#Map.projection_changed\n   */\n  @Output()\n  projectionChanged: Observable<void> =\n      this._eventManager.getLazyEmitter<void>('projection_changed');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.rightclick\n   */\n  @Output()\n  mapRightclick: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('rightclick');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.tilesloaded\n   */\n  @Output() tilesloaded: Observable<void> = this._eventManager.getLazyEmitter<void>('tilesloaded');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.tilt_changed\n   */\n  @Output() tiltChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('tilt_changed');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.zoom_changed\n   */\n  @Output() zoomChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('zoomChanged');\n\n  constructor(\n    private readonly _elementRef: ElementRef,\n    /**\n     * @deprecated `platformId` parameter to become required.\n     * @breaking-change 10.0.0\n     */\n    @Optional() @Inject(PLATFORM_ID) platformId?: Object) {\n\n    // @breaking-change 10.0.0 Remove null check for `platformId`.\n    this._isBrowser =\n        platformId ? isPlatformBrowser(platformId) : typeof window === 'object' && !!window;\n\n    if (this._isBrowser) {\n      const googleMapsWindow: GoogleMapsWindow = window;\n      if (!googleMapsWindow.google) {\n        throw Error(\n            'Namespace google not found, cannot construct embedded google ' +\n            'map. Please install the Google Maps JavaScript API: ' +\n            'https://developers.google.com/maps/documentation/javascript/' +\n            'tutorial#Loading_the_Maps_API');\n      }\n    }\n  }\n\n  ngOnChanges() {\n    this._setSize();\n  }\n\n  ngOnInit() {\n    // It should be a noop during server-side rendering.\n    if (this._isBrowser) {\n      this._mapEl = this._elementRef.nativeElement.querySelector('.map-container')!;\n      this._setSize();\n      this._googleMapChanges = this._initializeMap(this._combineOptions());\n      this._googleMapChanges.subscribe((googleMap: google.maps.Map) => {\n        this._googleMap = googleMap as UpdatedGoogleMap;\n        this._eventManager.setTarget(this._googleMap);\n      });\n\n      this._watchForOptionsChanges();\n      this._watchForCenterChanges();\n      this._watchForZoomChanges();\n    }\n  }\n\n  ngOnDestroy() {\n    this._eventManager.destroy();\n    this._destroy.next();\n    this._destroy.complete();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.fitBounds\n   */\n  fitBounds(\n      bounds: google.maps.LatLngBounds|google.maps.LatLngBoundsLiteral,\n      padding?: number|google.maps.Padding) {\n    this._assertInitialized();\n    this._googleMap.fitBounds(bounds, padding);\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.panBy\n   */\n  panBy(x: number, y: number) {\n    this._assertInitialized();\n    this._googleMap.panBy(x, y);\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.panTo\n   */\n  panTo(latLng: google.maps.LatLng|google.maps.LatLngLiteral) {\n    this._assertInitialized();\n    this._googleMap.panTo(latLng);\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.panToBounds\n   */\n  panToBounds(\n      latLngBounds: google.maps.LatLngBounds|google.maps.LatLngBoundsLiteral,\n      padding?: number|google.maps.Padding) {\n    this._assertInitialized();\n    this._googleMap.panToBounds(latLngBounds, padding);\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getBounds\n   */\n  getBounds(): google.maps.LatLngBounds|null {\n    this._assertInitialized();\n    return this._googleMap.getBounds() || null;\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getCenter\n   */\n  getCenter(): google.maps.LatLng {\n    this._assertInitialized();\n    return this._googleMap.getCenter();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getClickableIcons\n   */\n  getClickableIcons(): boolean {\n    this._assertInitialized();\n    return this._googleMap.getClickableIcons();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getHeading\n   */\n  getHeading(): number {\n    this._assertInitialized();\n    return this._googleMap.getHeading();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getMapTypeId\n   */\n  getMapTypeId(): google.maps.MapTypeId|string {\n    this._assertInitialized();\n    return this._googleMap.getMapTypeId();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getProjection\n   */\n  getProjection(): google.maps.Projection|null {\n    this._assertInitialized();\n    return this._googleMap.getProjection();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getStreetView\n   */\n  getStreetView(): google.maps.StreetViewPanorama {\n    this._assertInitialized();\n    return this._googleMap.getStreetView();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getTilt\n   */\n  getTilt(): number {\n    this._assertInitialized();\n    return this._googleMap.getTilt();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getZoom\n   */\n  getZoom(): number {\n    this._assertInitialized();\n    return this._googleMap.getZoom();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.controls\n   */\n  get controls(): Array<google.maps.MVCArray<Node>> {\n    this._assertInitialized();\n    return this._googleMap.controls;\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.data\n   */\n  get data(): google.maps.Data {\n    this._assertInitialized();\n    return this._googleMap.data;\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.mapTypes\n   */\n  get mapTypes(): google.maps.MapTypeRegistry {\n    this._assertInitialized();\n    return this._googleMap.mapTypes;\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.overlayMapTypes\n   */\n  get overlayMapTypes(): google.maps.MVCArray<google.maps.MapType> {\n    this._assertInitialized();\n    return this._googleMap.overlayMapTypes;\n  }\n\n  private _setSize() {\n    if (this._mapEl) {\n      this._mapEl.style.height = this.height || DEFAULT_HEIGHT;\n      this._mapEl.style.width = this.width || DEFAULT_WIDTH;\n    }\n  }\n\n  /** Combines the center and zoom and the other map options into a single object */\n  private _combineOptions(): Observable<google.maps.MapOptions> {\n    return combineLatest([this._options, this._center, this._zoom])\n        .pipe(map(([options, center, zoom]) => {\n          const combinedOptions: google.maps.MapOptions = {\n            ...options,\n            center: center || options.center,\n            zoom: zoom !== undefined ? zoom : options.zoom,\n          };\n          return combinedOptions;\n        }));\n  }\n\n  private _initializeMap(optionsChanges: Observable<google.maps.MapOptions>):\n      Observable<google.maps.Map> {\n    return optionsChanges.pipe(\n        take(1),\n        map(options => new google.maps.Map(this._mapEl, options)),\n        shareReplay(1));\n  }\n\n  private _watchForOptionsChanges() {\n    combineLatest([this._googleMapChanges, this._options])\n        .pipe(takeUntil(this._destroy))\n        .subscribe(([googleMap, options]) => {\n          googleMap.setOptions(options);\n        });\n  }\n\n  private _watchForCenterChanges() {\n    combineLatest([this._googleMapChanges, this._center])\n        .pipe(takeUntil(this._destroy))\n        .subscribe(([googleMap, center]) => {\n          if (center) {\n            googleMap.setCenter(center);\n          }\n        });\n  }\n\n  private _watchForZoomChanges() {\n    combineLatest([this._googleMapChanges, this._zoom])\n        .pipe(takeUntil(this._destroy))\n        .subscribe(([googleMap, zoom]) => {\n          if (zoom !== undefined) {\n            googleMap.setZoom(zoom);\n          }\n        });\n  }\n\n  /** Asserts that the map has been initialized. */\n  private _assertInitialized() {\n    if (!this._googleMap) {\n      throw Error('Cannot access Google Map information before the API has been initialized. ' +\n                  'Please wait for the API to load before trying to interact with it.');\n    }\n  }\n}\n"]}
/**
* @fileoverview added by tsickle
* Generated from: src/google-maps/google-maps-module.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc

@@ -16,2 +17,3 @@ */

import { MapMarker } from './map-marker/map-marker';
import { MapPolyline } from './map-polyline/map-polyline';
/** @type {?} */

@@ -22,2 +24,3 @@ const COMPONENTS = [

MapMarker,
MapPolyline,
];

@@ -32,2 +35,2 @@ export class GoogleMapsModule {

];
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ29vZ2xlLW1hcHMtbW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2dvb2dsZS1tYXBzL2dvb2dsZS1tYXBzLW1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQVFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFFdkMsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ2xELE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQUNoRSxPQUFPLEVBQUMsU0FBUyxFQUFDLE1BQU0seUJBQXlCLENBQUM7O01BRTVDLFVBQVUsR0FBRztJQUNqQixTQUFTO0lBQ1QsYUFBYTtJQUNiLFNBQVM7Q0FDVjtBQU1ELE1BQU0sT0FBTyxnQkFBZ0I7OztZQUo1QixRQUFRLFNBQUM7Z0JBQ1IsWUFBWSxFQUFFLFVBQVU7Z0JBQ3hCLE9BQU8sRUFBRSxVQUFVO2FBQ3BCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQge0dvb2dsZU1hcH0gZnJvbSAnLi9nb29nbGUtbWFwL2dvb2dsZS1tYXAnO1xuaW1wb3J0IHtNYXBJbmZvV2luZG93fSBmcm9tICcuL21hcC1pbmZvLXdpbmRvdy9tYXAtaW5mby13aW5kb3cnO1xuaW1wb3J0IHtNYXBNYXJrZXJ9IGZyb20gJy4vbWFwLW1hcmtlci9tYXAtbWFya2VyJztcblxuY29uc3QgQ09NUE9ORU5UUyA9IFtcbiAgR29vZ2xlTWFwLFxuICBNYXBJbmZvV2luZG93LFxuICBNYXBNYXJrZXIsXG5dO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IENPTVBPTkVOVFMsXG4gIGV4cG9ydHM6IENPTVBPTkVOVFMsXG59KVxuZXhwb3J0IGNsYXNzIEdvb2dsZU1hcHNNb2R1bGUge1xufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ29vZ2xlLW1hcHMtbW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2dvb2dsZS1tYXBzL2dvb2dsZS1tYXBzLW1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7QUFRQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRXZDLE9BQU8sRUFBQyxTQUFTLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUNsRCxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDaEUsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ2xELE9BQU8sRUFBQyxXQUFXLEVBQUMsTUFBTSw2QkFBNkIsQ0FBQzs7TUFFbEQsVUFBVSxHQUFHO0lBQ2pCLFNBQVM7SUFDVCxhQUFhO0lBQ2IsU0FBUztJQUNULFdBQVc7Q0FDWjtBQU1ELE1BQU0sT0FBTyxnQkFBZ0I7OztZQUo1QixRQUFRLFNBQUM7Z0JBQ1IsWUFBWSxFQUFFLFVBQVU7Z0JBQ3hCLE9BQU8sRUFBRSxVQUFVO2FBQ3BCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQge0dvb2dsZU1hcH0gZnJvbSAnLi9nb29nbGUtbWFwL2dvb2dsZS1tYXAnO1xuaW1wb3J0IHtNYXBJbmZvV2luZG93fSBmcm9tICcuL21hcC1pbmZvLXdpbmRvdy9tYXAtaW5mby13aW5kb3cnO1xuaW1wb3J0IHtNYXBNYXJrZXJ9IGZyb20gJy4vbWFwLW1hcmtlci9tYXAtbWFya2VyJztcbmltcG9ydCB7TWFwUG9seWxpbmV9IGZyb20gJy4vbWFwLXBvbHlsaW5lL21hcC1wb2x5bGluZSc7XG5cbmNvbnN0IENPTVBPTkVOVFMgPSBbXG4gIEdvb2dsZU1hcCxcbiAgTWFwSW5mb1dpbmRvdyxcbiAgTWFwTWFya2VyLFxuICBNYXBQb2x5bGluZSxcbl07XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogQ09NUE9ORU5UUyxcbiAgZXhwb3J0czogQ09NUE9ORU5UUyxcbn0pXG5leHBvcnQgY2xhc3MgR29vZ2xlTWFwc01vZHVsZSB7XG59XG4iXX0=
/**
* @fileoverview added by tsickle
* Generated from: src/google-maps/map-info-window/map-info-window.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc

@@ -15,6 +16,7 @@ */

/// <reference types="googlemaps" />
import { Directive, ElementRef, EventEmitter, Input, Output, } from '@angular/core';
import { BehaviorSubject, combineLatest, Subject } from 'rxjs';
import { Directive, ElementRef, Input, Output, } from '@angular/core';
import { BehaviorSubject, combineLatest, Observable, Subject } from 'rxjs';
import { map, takeUntil } from 'rxjs/operators';
import { GoogleMap } from '../google-map/google-map';
import { MapEventManager } from '../map-event-manager';
/**

@@ -32,2 +34,6 @@ * Angular component that renders a Google Maps info window via the Google Maps JavaScript API.

this._elementRef = _elementRef;
this._eventManager = new MapEventManager();
this._options = new BehaviorSubject({});
this._position = new BehaviorSubject(undefined);
this._destroy = new Subject();
/**

@@ -37,3 +43,3 @@ * See

*/
this.closeclick = new EventEmitter();
this.closeclick = this._eventManager.getLazyEmitter('closeclick');
/**

@@ -44,3 +50,3 @@ * See

*/
this.contentChanged = new EventEmitter();
this.contentChanged = this._eventManager.getLazyEmitter('content_changed');
/**

@@ -50,3 +56,3 @@ * See

*/
this.domready = new EventEmitter();
this.domready = this._eventManager.getLazyEmitter('domready');
/**

@@ -57,3 +63,3 @@ * See

*/
this.positionChanged = new EventEmitter();
this.positionChanged = this._eventManager.getLazyEmitter('position_changed');
/**

@@ -64,7 +70,3 @@ * See

*/
this.zindexChanged = new EventEmitter();
this._options = new BehaviorSubject({});
this._position = new BehaviorSubject(undefined);
this._listeners = [];
this._destroy = new Subject();
this.zindexChanged = this._eventManager.getLazyEmitter('zindex_changed');
}

@@ -99,3 +101,3 @@ /**

this._infoWindow = new google.maps.InfoWindow(options);
this._initializeEventHandlers();
this._eventManager.setTarget(this._infoWindow);
}

@@ -108,7 +110,5 @@ }));

ngOnDestroy() {
this._eventManager.destroy();
this._destroy.next();
this._destroy.complete();
for (let listener of this._listeners) {
listener.remove();
}
this.close();

@@ -179,44 +179,2 @@ }

}
/**
* @private
* @return {?}
*/
_initializeEventHandlers() {
// Ensure that we don't leak if called multiple times.
this._clearListeners();
/** @type {?} */
const eventHandlers = new Map([
['closeclick', this.closeclick],
['content_changed', this.contentChanged],
['domready', this.domready],
['position_changed', this.positionChanged],
['zindex_changed', this.zindexChanged],
]);
eventHandlers.forEach((/**
* @param {?} eventHandler
* @param {?} name
* @return {?}
*/
(eventHandler, name) => {
if (eventHandler.observers.length > 0) {
this._listeners.push((/** @type {?} */ (this._infoWindow)).addListener(name, (/**
* @return {?}
*/
() => {
eventHandler.emit();
})));
}
}));
}
/**
* Clears all currently-registered event listeners.
* @private
* @return {?}
*/
_clearListeners() {
for (let listener of this._listeners) {
listener.remove();
}
this._listeners = [];
}
}

@@ -245,2 +203,27 @@ MapInfoWindow.decorators = [

/**
* @type {?}
* @private
*/
MapInfoWindow.prototype._eventManager;
/**
* @type {?}
* @private
*/
MapInfoWindow.prototype._options;
/**
* @type {?}
* @private
*/
MapInfoWindow.prototype._position;
/**
* @type {?}
* @private
*/
MapInfoWindow.prototype._destroy;
/**
* @type {?}
* @private
*/
MapInfoWindow.prototype._infoWindow;
/**
* See

@@ -282,27 +265,2 @@ * developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.closeclick

*/
MapInfoWindow.prototype._options;
/**
* @type {?}
* @private
*/
MapInfoWindow.prototype._position;
/**
* @type {?}
* @private
*/
MapInfoWindow.prototype._listeners;
/**
* @type {?}
* @private
*/
MapInfoWindow.prototype._destroy;
/**
* @type {?}
* @private
*/
MapInfoWindow.prototype._infoWindow;
/**
* @type {?}
* @private
*/
MapInfoWindow.prototype._googleMap;

@@ -315,2 +273,2 @@ /**

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-info-window.js","sourceRoot":"","sources":["../../../../../../src/google-maps/map-info-window/map-info-window.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n// Workaround for: https://github.com/bazelbuild/rules_nodejs/issues/1265\n/// <reference types=\"googlemaps\" />\n\nimport {\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n} from '@angular/core';\nimport {BehaviorSubject, combineLatest, Observable, Subject} from 'rxjs';\nimport {map, takeUntil} from 'rxjs/operators';\n\nimport {GoogleMap} from '../google-map/google-map';\nimport {MapMarker} from '../map-marker/map-marker';\n\n/**\n * Angular component that renders a Google Maps info window via the Google Maps JavaScript API.\n * @see developers.google.com/maps/documentation/javascript/reference/info-window\n */\n@Directive({\n  selector: 'map-info-window',\n  host: {'style': 'display: none'},\n})\nexport class MapInfoWindow implements OnInit, OnDestroy {\n  @Input()\n  set options(options: google.maps.InfoWindowOptions) {\n    this._options.next(options || {});\n  }\n\n  @Input()\n  set position(position: google.maps.LatLngLiteral|google.maps.LatLng) {\n    this._position.next(position);\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.closeclick\n   */\n  @Output() closeclick = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window\n   * #InfoWindow.content_changed\n   */\n  @Output() contentChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.domready\n   */\n  @Output() domready = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window\n   * #InfoWindow.position_changed\n   */\n  @Output() positionChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window\n   * #InfoWindow.zindex_changed\n   */\n  @Output() zindexChanged = new EventEmitter<void>();\n\n  private readonly _options = new BehaviorSubject<google.maps.InfoWindowOptions>({});\n  private readonly _position =\n      new BehaviorSubject<google.maps.LatLngLiteral|google.maps.LatLng|undefined>(undefined);\n\n  private _listeners: google.maps.MapsEventListener[] = [];\n\n  private readonly _destroy = new Subject<void>();\n\n  private _infoWindow?: google.maps.InfoWindow;\n\n  constructor(private readonly _googleMap: GoogleMap,\n              private _elementRef: ElementRef<HTMLElement>) {}\n\n  ngOnInit() {\n    this._combineOptions().pipe(takeUntil(this._destroy)).subscribe(options => {\n      if (this._infoWindow) {\n        this._infoWindow.setOptions(options);\n      } else {\n        this._infoWindow = new google.maps.InfoWindow(options);\n        this._initializeEventHandlers();\n      }\n    });\n  }\n\n  ngOnDestroy() {\n    this._destroy.next();\n    this._destroy.complete();\n    for (let listener of this._listeners) {\n      listener.remove();\n    }\n    this.close();\n  }\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.close\n   */\n  close() {\n    if (this._infoWindow) {\n      this._infoWindow.close();\n    }\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.getContent\n   */\n  getContent(): string|Node {\n    return this._infoWindow!.getContent();\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window\n   * #InfoWindow.getPosition\n   */\n  getPosition(): google.maps.LatLng|null {\n    return this._infoWindow!.getPosition() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.getZIndex\n   */\n  getZIndex(): number {\n    return this._infoWindow!.getZIndex();\n  }\n\n  /**\n   * Opens the MapInfoWindow using the provided MapMarker as the anchor. If the anchor is not set,\n   * then the position property of the options input is used instead.\n   */\n  open(anchor?: MapMarker) {\n    const marker = anchor ? anchor._marker : undefined;\n    if (this._googleMap._googleMap) {\n      this._elementRef.nativeElement.style.display = '';\n      this._infoWindow!.open(this._googleMap._googleMap, marker);\n    }\n  }\n\n  private _combineOptions(): Observable<google.maps.InfoWindowOptions> {\n    return combineLatest([this._options, this._position]).pipe(map(([options, position]) => {\n      const combinedOptions: google.maps.InfoWindowOptions = {\n        ...options,\n        position: position || options.position,\n        content: this._elementRef.nativeElement,\n      };\n      return combinedOptions;\n    }));\n  }\n\n  private _initializeEventHandlers() {\n    // Ensure that we don't leak if called multiple times.\n    this._clearListeners();\n\n    const eventHandlers = new Map<string, EventEmitter<void>>([\n      ['closeclick', this.closeclick],\n      ['content_changed', this.contentChanged],\n      ['domready', this.domready],\n      ['position_changed', this.positionChanged],\n      ['zindex_changed', this.zindexChanged],\n    ]);\n    eventHandlers.forEach((eventHandler: EventEmitter<void>, name: string) => {\n      if (eventHandler.observers.length > 0) {\n        this._listeners.push(this._infoWindow!.addListener(name, () => {\n          eventHandler.emit();\n        }));\n      }\n    });\n  }\n\n  /** Clears all currently-registered event listeners. */\n  private _clearListeners() {\n    for (let listener of this._listeners) {\n      listener.remove();\n    }\n\n    this._listeners = [];\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-info-window.js","sourceRoot":"","sources":["../../../../../../src/google-maps/map-info-window/map-info-window.ts"],"names":[],"mappings":";;;;;AASA,oCAAoC;;;;;;;;;;AAEpC,OAAO,EACL,SAAS,EACT,UAAU,EACV,KAAK,EAGL,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,eAAe,EAAE,aAAa,EAAE,UAAU,EAAE,OAAO,EAAC,MAAM,MAAM,CAAC;AACzE,OAAO,EAAC,GAAG,EAAE,SAAS,EAAC,MAAM,gBAAgB,CAAC;AAE9C,OAAO,EAAC,SAAS,EAAC,MAAM,0BAA0B,CAAC;AAEnD,OAAO,EAAC,eAAe,EAAC,MAAM,sBAAsB,CAAC;;;;;AAUrD,MAAM,OAAO,aAAa;;;;;IAsDxB,YAA6B,UAAqB,EAC9B,WAAoC;QAD3B,eAAU,GAAV,UAAU,CAAW;QAC9B,gBAAW,GAAX,WAAW,CAAyB;QAtDhD,kBAAa,GAAG,IAAI,eAAe,EAAE,CAAC;QAC7B,aAAQ,GAAG,IAAI,eAAe,CAAgC,EAAE,CAAC,CAAC;QAClE,cAAS,GACtB,IAAI,eAAe,CAAyD,SAAS,CAAC,CAAC;QAC1E,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;;;;;QAiBtC,eAAU,GAAqB,IAAI,CAAC,aAAa,CAAC,cAAc,CAAO,YAAY,CAAC,CAAC;;;;;;QAQ/F,mBAAc,GAAqB,IAAI,CAAC,aAAa,CAAC,cAAc,CAAO,iBAAiB,CAAC,CAAC;;;;;QAMpF,aAAQ,GAAqB,IAAI,CAAC,aAAa,CAAC,cAAc,CAAO,UAAU,CAAC,CAAC;;;;;;QAQ3F,oBAAe,GAAqB,IAAI,CAAC,aAAa,CAAC,cAAc,CAAO,kBAAkB,CAAC,CAAC;;;;;;QAQhG,kBAAa,GAAqB,IAAI,CAAC,aAAa,CAAC,cAAc,CAAO,gBAAgB,CAAC,CAAC;IAGjC,CAAC;;;;;IA/C5D,IACI,OAAO,CAAC,OAAsC;QAChD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC;IACpC,CAAC;;;;;IAED,IACI,QAAQ,CAAC,QAAsD;QACjE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAChC,CAAC;;;;IAyCD,QAAQ;QACN,IAAI,CAAC,eAAe,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS;;;;QAAC,OAAO,CAAC,EAAE;YACxE,IAAI,IAAI,CAAC,WAAW,EAAE;gBACpB,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;aACtC;iBAAM;gBACL,IAAI,CAAC,WAAW,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;gBACvD,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;aAChD;QACH,CAAC,EAAC,CAAC;IACL,CAAC;;;;IAED,WAAW;QACT,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC;QAC7B,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;QACzB,IAAI,CAAC,KAAK,EAAE,CAAC;IACf,CAAC;;;;;IAKD,KAAK;QACH,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;SAC1B;IACH,CAAC;;;;;;IAMD,UAAU;QACR,OAAO,mBAAA,IAAI,CAAC,WAAW,EAAC,CAAC,UAAU,EAAE,CAAC;IACxC,CAAC;;;;;;;IAOD,WAAW;QACT,OAAO,mBAAA,IAAI,CAAC,WAAW,EAAC,CAAC,WAAW,EAAE,IAAI,IAAI,CAAC;IACjD,CAAC;;;;;;IAMD,SAAS;QACP,OAAO,mBAAA,IAAI,CAAC,WAAW,EAAC,CAAC,SAAS,EAAE,CAAC;IACvC,CAAC;;;;;;;IAMD,IAAI,CAAC,MAAkB;;cACf,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS;QAClD,IAAI,IAAI,CAAC,UAAU,CAAC,UAAU,EAAE;YAC9B,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,OAAO,GAAG,EAAE,CAAC;YAClD,mBAAA,IAAI,CAAC,WAAW,EAAC,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;SAC5D;IACH,CAAC;;;;;IAEO,eAAe;QACrB,OAAO,aAAa,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG;;;;QAAC,CAAC,CAAC,OAAO,EAAE,QAAQ,CAAC,EAAE,EAAE;;kBAC/E,eAAe,mCAChB,OAAO,KACV,QAAQ,EAAE,QAAQ,IAAI,OAAO,CAAC,QAAQ,EACtC,OAAO,EAAE,IAAI,CAAC,WAAW,CAAC,aAAa,GACxC;YACD,OAAO,eAAe,CAAC;QACzB,CAAC,EAAC,CAAC,CAAC;IACN,CAAC;;;YAtIF,SAAS,SAAC;gBACT,QAAQ,EAAE,iBAAiB;gBAC3B,IAAI,EAAE,EAAC,OAAO,EAAE,eAAe,EAAC;aACjC;;;;YAXO,SAAS;YATf,UAAU;;;sBA6BT,KAAK;uBAKL,KAAK;yBASL,MAAM;6BAON,MAAM;uBAON,MAAM;8BAON,MAAM;4BAQN,MAAM;;;;;;;IAlDP,sCAA8C;;;;;IAC9C,iCAAmF;;;;;IACnF,kCAC2F;;;;;IAC3F,iCAAgD;;;;;IAChD,oCAA6C;;;;;;IAgB7C,mCAA+F;;;;;;;IAO/F,uCAC8F;;;;;;IAM9F,iCAA2F;;;;;;;IAO3F,wCACgG;;;;;;;IAOhG,sCAC4F;;;;;IAEhF,mCAAsC;;;;;IACtC,oCAA4C","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n// Workaround for: https://github.com/bazelbuild/rules_nodejs/issues/1265\n/// <reference types=\"googlemaps\" />\n\nimport {\n  Directive,\n  ElementRef,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n} from '@angular/core';\nimport {BehaviorSubject, combineLatest, Observable, Subject} from 'rxjs';\nimport {map, takeUntil} from 'rxjs/operators';\n\nimport {GoogleMap} from '../google-map/google-map';\nimport {MapMarker} from '../map-marker/map-marker';\nimport {MapEventManager} from '../map-event-manager';\n\n/**\n * Angular component that renders a Google Maps info window via the Google Maps JavaScript API.\n * @see developers.google.com/maps/documentation/javascript/reference/info-window\n */\n@Directive({\n  selector: 'map-info-window',\n  host: {'style': 'display: none'},\n})\nexport class MapInfoWindow implements OnInit, OnDestroy {\n  private _eventManager = new MapEventManager();\n  private readonly _options = new BehaviorSubject<google.maps.InfoWindowOptions>({});\n  private readonly _position =\n      new BehaviorSubject<google.maps.LatLngLiteral|google.maps.LatLng|undefined>(undefined);\n  private readonly _destroy = new Subject<void>();\n  private _infoWindow?: google.maps.InfoWindow;\n\n  @Input()\n  set options(options: google.maps.InfoWindowOptions) {\n    this._options.next(options || {});\n  }\n\n  @Input()\n  set position(position: google.maps.LatLngLiteral|google.maps.LatLng) {\n    this._position.next(position);\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.closeclick\n   */\n  @Output() closeclick: Observable<void> = this._eventManager.getLazyEmitter<void>('closeclick');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window\n   * #InfoWindow.content_changed\n   */\n  @Output()\n  contentChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('content_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.domready\n   */\n  @Output() domready: Observable<void> = this._eventManager.getLazyEmitter<void>('domready');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window\n   * #InfoWindow.position_changed\n   */\n  @Output()\n  positionChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('position_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window\n   * #InfoWindow.zindex_changed\n   */\n  @Output()\n  zindexChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('zindex_changed');\n\n  constructor(private readonly _googleMap: GoogleMap,\n              private _elementRef: ElementRef<HTMLElement>) {}\n\n  ngOnInit() {\n    this._combineOptions().pipe(takeUntil(this._destroy)).subscribe(options => {\n      if (this._infoWindow) {\n        this._infoWindow.setOptions(options);\n      } else {\n        this._infoWindow = new google.maps.InfoWindow(options);\n        this._eventManager.setTarget(this._infoWindow);\n      }\n    });\n  }\n\n  ngOnDestroy() {\n    this._eventManager.destroy();\n    this._destroy.next();\n    this._destroy.complete();\n    this.close();\n  }\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.close\n   */\n  close() {\n    if (this._infoWindow) {\n      this._infoWindow.close();\n    }\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.getContent\n   */\n  getContent(): string|Node {\n    return this._infoWindow!.getContent();\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window\n   * #InfoWindow.getPosition\n   */\n  getPosition(): google.maps.LatLng|null {\n    return this._infoWindow!.getPosition() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.getZIndex\n   */\n  getZIndex(): number {\n    return this._infoWindow!.getZIndex();\n  }\n\n  /**\n   * Opens the MapInfoWindow using the provided MapMarker as the anchor. If the anchor is not set,\n   * then the position property of the options input is used instead.\n   */\n  open(anchor?: MapMarker) {\n    const marker = anchor ? anchor._marker : undefined;\n    if (this._googleMap._googleMap) {\n      this._elementRef.nativeElement.style.display = '';\n      this._infoWindow!.open(this._googleMap._googleMap, marker);\n    }\n  }\n\n  private _combineOptions(): Observable<google.maps.InfoWindowOptions> {\n    return combineLatest([this._options, this._position]).pipe(map(([options, position]) => {\n      const combinedOptions: google.maps.InfoWindowOptions = {\n        ...options,\n        position: position || options.position,\n        content: this._elementRef.nativeElement,\n      };\n      return combinedOptions;\n    }));\n  }\n}\n"]}
/**
* @fileoverview added by tsickle
* Generated from: src/google-maps/map-marker/map-marker.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc

@@ -15,6 +16,7 @@ */

/// <reference types="googlemaps" />
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core';
import { BehaviorSubject, combineLatest, Subject } from 'rxjs';
import { ChangeDetectionStrategy, Component, Input, Output, ViewEncapsulation } from '@angular/core';
import { BehaviorSubject, combineLatest, Observable, Subject } from 'rxjs';
import { map, take, takeUntil } from 'rxjs/operators';
import { GoogleMap } from '../google-map/google-map';
import { MapEventManager } from '../map-event-manager';
/**

@@ -38,2 +40,9 @@ * Default options for the Google Maps marker component. Displays a marker

this._googleMap = _googleMap;
this._eventManager = new MapEventManager();
this._options = new BehaviorSubject(DEFAULT_MARKER_OPTIONS);
this._title = new BehaviorSubject(undefined);
this._position = new BehaviorSubject(undefined);
this._label = new BehaviorSubject(undefined);
this._clickable = new BehaviorSubject(undefined);
this._destroy = new Subject();
/**

@@ -43,3 +52,3 @@ * See

*/
this.animationChanged = new EventEmitter();
this.animationChanged = this._eventManager.getLazyEmitter('animation_changed');
/**

@@ -49,3 +58,3 @@ * See

*/
this.mapClick = new EventEmitter();
this.mapClick = this._eventManager.getLazyEmitter('click');
/**

@@ -55,3 +64,3 @@ * See

*/
this.clickableChanged = new EventEmitter();
this.clickableChanged = this._eventManager.getLazyEmitter('clickable_changed');
/**

@@ -61,3 +70,3 @@ * See

*/
this.cursorChanged = new EventEmitter();
this.cursorChanged = this._eventManager.getLazyEmitter('cursor_changed');
/**

@@ -67,3 +76,3 @@ * See

*/
this.mapDblclick = new EventEmitter();
this.mapDblclick = this._eventManager.getLazyEmitter('dblclick');
/**

@@ -73,3 +82,3 @@ * See

*/
this.mapDrag = new EventEmitter();
this.mapDrag = this._eventManager.getLazyEmitter('drag');
/**

@@ -79,3 +88,3 @@ * See

*/
this.mapDragend = new EventEmitter();
this.mapDragend = this._eventManager.getLazyEmitter('dragend');
/**

@@ -85,3 +94,3 @@ * See

*/
this.draggableChanged = new EventEmitter();
this.draggableChanged = this._eventManager.getLazyEmitter('draggable_changed');
/**

@@ -91,3 +100,3 @@ * See

*/
this.mapDragstart = new EventEmitter();
this.mapDragstart = this._eventManager.getLazyEmitter('dragstart');
/**

@@ -97,3 +106,3 @@ * See

*/
this.flatChanged = new EventEmitter();
this.flatChanged = this._eventManager.getLazyEmitter('flat_changed');
/**

@@ -103,3 +112,3 @@ * See

*/
this.iconChanged = new EventEmitter();
this.iconChanged = this._eventManager.getLazyEmitter('icon_changed');
/**

@@ -109,3 +118,3 @@ * See

*/
this.mapMousedown = new EventEmitter();
this.mapMousedown = this._eventManager.getLazyEmitter('mousedown');
/**

@@ -115,3 +124,3 @@ * See

*/
this.mapMouseout = new EventEmitter();
this.mapMouseout = this._eventManager.getLazyEmitter('mouseout');
/**

@@ -121,3 +130,3 @@ * See

*/
this.mapMouseover = new EventEmitter();
this.mapMouseover = this._eventManager.getLazyEmitter('mouseover');
/**

@@ -127,3 +136,3 @@ * See

*/
this.mapMouseup = new EventEmitter();
this.mapMouseup = this._eventManager.getLazyEmitter('mouseup');
/**

@@ -133,3 +142,3 @@ * See

*/
this.positionChanged = new EventEmitter();
this.positionChanged = this._eventManager.getLazyEmitter('position_changed');
/**

@@ -139,3 +148,3 @@ * See

*/
this.mapRightclick = new EventEmitter();
this.mapRightclick = this._eventManager.getLazyEmitter('rightclick');
/**

@@ -145,3 +154,3 @@ * See

*/
this.shapeChanged = new EventEmitter();
this.shapeChanged = this._eventManager.getLazyEmitter('shape_changed');
/**

@@ -151,3 +160,3 @@ * See

*/
this.titleChanged = new EventEmitter();
this.titleChanged = this._eventManager.getLazyEmitter('title_changed');
/**

@@ -157,3 +166,3 @@ * See

*/
this.visibleChanged = new EventEmitter();
this.visibleChanged = this._eventManager.getLazyEmitter('visible_changed');
/**

@@ -163,10 +172,3 @@ * See

*/
this.zindexChanged = new EventEmitter();
this._options = new BehaviorSubject(DEFAULT_MARKER_OPTIONS);
this._title = new BehaviorSubject(undefined);
this._position = new BehaviorSubject(undefined);
this._label = new BehaviorSubject(undefined);
this._clickable = new BehaviorSubject(undefined);
this._destroy = new Subject();
this._listeners = [];
this.zindexChanged = this._eventManager.getLazyEmitter('zindex_changed');
}

@@ -221,3 +223,3 @@ /**

this._marker.setMap(this._googleMap._googleMap);
this._initializeEventHandlers();
this._eventManager.setTarget(this._marker);
}));

@@ -236,3 +238,3 @@ this._watchForOptionsChanges();

this._destroy.complete();
this._clearListeners();
this._eventManager.destroy();
if (this._marker) {

@@ -429,79 +431,2 @@ this._marker.setMap(null);

}
/**
* @private
* @return {?}
*/
_initializeEventHandlers() {
// Ensure that we don't leak if called multiple times.
this._clearListeners();
/** @type {?} */
const eventHandlers = new Map([
['animation_changed', this.animationChanged],
['clickable_changed', this.clickableChanged],
['cursor_changed', this.cursorChanged],
['draggable_changed', this.draggableChanged],
['flat_changed', this.flatChanged],
['icon_changed', this.iconChanged],
['position_changed', this.positionChanged],
['shape_changed', this.shapeChanged],
['title_changed', this.titleChanged],
['visible_changed', this.visibleChanged],
['zindex_changed', this.zindexChanged],
]);
/** @type {?} */
const mouseEventHandlers = new Map([
['click', this.mapClick],
['dblclick', this.mapDblclick],
['drag', this.mapDrag],
['dragend', this.mapDragend],
['dragstart', this.mapDragstart],
['mousedown', this.mapMousedown],
['mouseout', this.mapMouseout],
['mouseover', this.mapMouseover],
['mouseup', this.mapMouseup],
['rightclick', this.mapRightclick],
]);
eventHandlers.forEach((/**
* @param {?} eventHandler
* @param {?} name
* @return {?}
*/
(eventHandler, name) => {
if (eventHandler.observers.length > 0) {
this._listeners.push((/** @type {?} */ (this._marker)).addListener(name, (/**
* @return {?}
*/
() => {
eventHandler.emit();
})));
}
}));
mouseEventHandlers.forEach((/**
* @param {?} eventHandler
* @param {?} name
* @return {?}
*/
(eventHandler, name) => {
if (eventHandler.observers.length > 0) {
this._listeners.push((/** @type {?} */ (this._marker)).addListener(name, (/**
* @param {?} event
* @return {?}
*/
(event) => {
eventHandler.emit(event);
})));
}
}));
}
/**
* Clears all currently-registered event listeners.
* @private
* @return {?}
*/
_clearListeners() {
for (let listener of this._listeners) {
listener.remove();
}
this._listeners = [];
}
}

@@ -550,2 +475,37 @@ MapMarker.decorators = [

/**
* @type {?}
* @private
*/
MapMarker.prototype._eventManager;
/**
* @type {?}
* @private
*/
MapMarker.prototype._options;
/**
* @type {?}
* @private
*/
MapMarker.prototype._title;
/**
* @type {?}
* @private
*/
MapMarker.prototype._position;
/**
* @type {?}
* @private
*/
MapMarker.prototype._label;
/**
* @type {?}
* @private
*/
MapMarker.prototype._clickable;
/**
* @type {?}
* @private
*/
MapMarker.prototype._destroy;
/**
* See

@@ -676,37 +636,2 @@ * developers.google.com/maps/documentation/javascript/reference/marker#Marker.animation_changed

MapMarker.prototype.zindexChanged;
/**
* @type {?}
* @private
*/
MapMarker.prototype._options;
/**
* @type {?}
* @private
*/
MapMarker.prototype._title;
/**
* @type {?}
* @private
*/
MapMarker.prototype._position;
/**
* @type {?}
* @private
*/
MapMarker.prototype._label;
/**
* @type {?}
* @private
*/
MapMarker.prototype._clickable;
/**
* @type {?}
* @private
*/
MapMarker.prototype._destroy;
/**
* @type {?}
* @private
*/
MapMarker.prototype._listeners;
/** @type {?} */

@@ -720,2 +645,2 @@ MapMarker.prototype._marker;

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-marker.js","sourceRoot":"","sources":["../../../../../../src/google-maps/map-marker/map-marker.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n// Workaround for: https://github.com/bazelbuild/rules_nodejs/issues/1265\n/// <reference types=\"googlemaps\" />\n\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewEncapsulation\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';\n\n/**\n * Default options for the Google Maps marker component. Displays a marker\n * at the Googleplex.\n */\nexport const DEFAULT_MARKER_OPTIONS = {\n  position: {lat: 37.421995, lng: -122.084092},\n};\n\n/**\n * Angular component that renders a Google Maps marker via the Google Maps JavaScript API.\n * @see developers.google.com/maps/documentation/javascript/reference/marker\n */\n@Component({\n  selector: 'map-marker',\n  template: '<ng-content></ng-content>',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class MapMarker implements OnInit, OnDestroy {\n  @Input()\n  set options(options: google.maps.MarkerOptions) {\n    this._options.next(options || DEFAULT_MARKER_OPTIONS);\n  }\n\n  @Input()\n  set title(title: string) {\n    this._title.next(title);\n  }\n\n  @Input()\n  set position(position: google.maps.LatLngLiteral|google.maps.LatLng) {\n    this._position.next(position);\n  }\n\n  @Input()\n  set label(label: string|google.maps.MarkerLabel) {\n    this._label.next(label);\n  }\n\n  @Input()\n  set clickable(clickable: boolean) {\n    this._clickable.next(clickable);\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.animation_changed\n   */\n  @Output() animationChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.click\n   */\n  @Output() mapClick = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.clickable_changed\n   */\n  @Output() clickableChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.cursor_changed\n   */\n  @Output() cursorChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.dblclick\n   */\n  @Output() mapDblclick = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.drag\n   */\n  @Output() mapDrag = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.dragend\n   */\n  @Output() mapDragend = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.draggable_changed\n   */\n  @Output() draggableChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.dragstart\n   */\n  @Output() mapDragstart = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.flat_changed\n   */\n  @Output() flatChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.icon_changed\n   */\n  @Output() iconChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.mousedown\n   */\n  @Output() mapMousedown = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.mouseout\n   */\n  @Output() mapMouseout = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.mouseover\n   */\n  @Output() mapMouseover = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.mouseup\n   */\n  @Output() mapMouseup = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.position_changed\n   */\n  @Output() positionChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.rightclick\n   */\n  @Output() mapRightclick = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.shape_changed\n   */\n  @Output() shapeChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.title_changed\n   */\n  @Output() titleChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.visible_changed\n   */\n  @Output() visibleChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.zindex_changed\n   */\n  @Output() zindexChanged = new EventEmitter<void>();\n\n  private readonly _options =\n      new BehaviorSubject<google.maps.MarkerOptions>(DEFAULT_MARKER_OPTIONS);\n  private readonly _title = new BehaviorSubject<string|undefined>(undefined);\n  private readonly _position =\n      new BehaviorSubject<google.maps.LatLngLiteral|google.maps.LatLng|undefined>(undefined);\n  private readonly _label =\n      new BehaviorSubject<string|google.maps.MarkerLabel|undefined>(undefined);\n  private readonly _clickable = new BehaviorSubject<boolean|undefined>(undefined);\n\n  private readonly _destroy = new Subject<void>();\n\n  private _listeners: google.maps.MapsEventListener[] = [];\n\n  _marker?: google.maps.Marker;\n\n  constructor(private readonly _googleMap: GoogleMap) {}\n\n  ngOnInit() {\n    const combinedOptionsChanges = this._combineOptions();\n\n    combinedOptionsChanges.pipe(take(1)).subscribe(options => {\n      this._marker = new google.maps.Marker(options);\n      this._marker.setMap(this._googleMap._googleMap);\n      this._initializeEventHandlers();\n    });\n\n    this._watchForOptionsChanges();\n    this._watchForTitleChanges();\n    this._watchForPositionChanges();\n    this._watchForLabelChanges();\n    this._watchForClickableChanges();\n  }\n\n  ngOnDestroy() {\n    this._destroy.next();\n    this._destroy.complete();\n    this._clearListeners();\n    if (this._marker) {\n      this._marker.setMap(null);\n    }\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getAnimation\n   */\n  getAnimation(): google.maps.Animation|null {\n    return this._marker!.getAnimation() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getClickable\n   */\n  getClickable(): boolean {\n    return this._marker!.getClickable();\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getCursor\n   */\n  getCursor(): string|null {\n    return this._marker!.getCursor() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getDraggable\n   */\n  getDraggable(): boolean {\n    return !!this._marker!.getDraggable();\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getIcon\n   */\n  getIcon(): string|google.maps.Icon|google.maps.Symbol|null {\n    return this._marker!.getIcon() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getLabel\n   */\n  getLabel(): google.maps.MarkerLabel|null {\n    return this._marker!.getLabel() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getOpacity\n   */\n  getOpacity(): number|null {\n    return this._marker!.getOpacity() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getPosition\n   */\n  getPosition(): google.maps.LatLng|null {\n    return this._marker!.getPosition() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getShape\n   */\n  getShape(): google.maps.MarkerShape|null {\n    return this._marker!.getShape() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getTitle\n   */\n  getTitle(): string|null {\n    return this._marker!.getTitle() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getVisible\n   */\n  getVisible(): boolean {\n    return this._marker!.getVisible();\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getZIndex\n   */\n  getZIndex(): number|null {\n    return this._marker!.getZIndex() || null;\n  }\n\n  private _combineOptions(): Observable<google.maps.MarkerOptions> {\n    return combineLatest([this._options, this._title, this._position, this._label, this._clickable])\n        .pipe(map(([options, title, position, label, clickable]) => {\n          const combinedOptions: google.maps.MarkerOptions = {\n            ...options,\n            title: title || options.title,\n            position: position || options.position,\n            label: label || options.label,\n            clickable: clickable !== undefined ? clickable : options.clickable,\n            map: this._googleMap._googleMap || null,\n          };\n          return combinedOptions;\n        }));\n  }\n\n  private _watchForOptionsChanges() {\n    this._options.pipe(takeUntil(this._destroy)).subscribe(options => {\n      if (this._marker) {\n        this._marker.setOptions(options);\n      }\n    });\n  }\n\n  private _watchForTitleChanges() {\n    this._title.pipe(takeUntil(this._destroy)).subscribe(title => {\n      if (this._marker && title !== undefined) {\n        this._marker.setTitle(title);\n      }\n    });\n  }\n\n  private _watchForPositionChanges() {\n    this._position.pipe(takeUntil(this._destroy)).subscribe(position => {\n      if (this._marker && position) {\n        this._marker.setPosition(position);\n      }\n    });\n  }\n\n  private _watchForLabelChanges() {\n    this._label.pipe(takeUntil(this._destroy)).subscribe(label => {\n      if (this._marker && label !== undefined) {\n        this._marker.setLabel(label);\n      }\n    });\n  }\n\n  private _watchForClickableChanges() {\n    this._clickable.pipe(takeUntil(this._destroy)).subscribe(clickable => {\n      if (this._marker && clickable !== undefined) {\n        this._marker.setClickable(clickable);\n      }\n    });\n  }\n\n  private _initializeEventHandlers() {\n    // Ensure that we don't leak if called multiple times.\n    this._clearListeners();\n\n    const eventHandlers = new Map<string, EventEmitter<void>>([\n      ['animation_changed', this.animationChanged],\n      ['clickable_changed', this.clickableChanged],\n      ['cursor_changed', this.cursorChanged],\n      ['draggable_changed', this.draggableChanged],\n      ['flat_changed', this.flatChanged],\n      ['icon_changed', this.iconChanged],\n      ['position_changed', this.positionChanged],\n      ['shape_changed', this.shapeChanged],\n      ['title_changed', this.titleChanged],\n      ['visible_changed', this.visibleChanged],\n      ['zindex_changed', this.zindexChanged],\n    ]);\n    const mouseEventHandlers = new Map<string, EventEmitter<google.maps.MouseEvent>>([\n      ['click', this.mapClick],\n      ['dblclick', this.mapDblclick],\n      ['drag', this.mapDrag],\n      ['dragend', this.mapDragend],\n      ['dragstart', this.mapDragstart],\n      ['mousedown', this.mapMousedown],\n      ['mouseout', this.mapMouseout],\n      ['mouseover', this.mapMouseover],\n      ['mouseup', this.mapMouseup],\n      ['rightclick', this.mapRightclick],\n    ]);\n\n    eventHandlers.forEach((eventHandler: EventEmitter<void>, name: string) => {\n      if (eventHandler.observers.length > 0) {\n        this._listeners.push(this._marker!.addListener(name, () => {\n          eventHandler.emit();\n        }));\n      }\n    });\n    mouseEventHandlers.forEach(\n        (eventHandler: EventEmitter<google.maps.MouseEvent>, name: string) => {\n          if (eventHandler.observers.length > 0) {\n            this._listeners.push(\n                this._marker!.addListener(name, (event: google.maps.MouseEvent) => {\n                  eventHandler.emit(event);\n                }));\n          }\n        });\n  }\n\n  /** Clears all currently-registered event listeners. */\n  private _clearListeners() {\n    for (let listener of this._listeners) {\n      listener.remove();\n    }\n\n    this._listeners = [];\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-marker.js","sourceRoot":"","sources":["../../../../../../src/google-maps/map-marker/map-marker.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n// Workaround for: https://github.com/bazelbuild/rules_nodejs/issues/1265\n/// <reference types=\"googlemaps\" />\n\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewEncapsulation\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 * Default options for the Google Maps marker component. Displays a marker\n * at the Googleplex.\n */\nexport const DEFAULT_MARKER_OPTIONS = {\n  position: {lat: 37.421995, lng: -122.084092},\n};\n\n/**\n * Angular component that renders a Google Maps marker via the Google Maps JavaScript API.\n * @see developers.google.com/maps/documentation/javascript/reference/marker\n */\n@Component({\n  selector: 'map-marker',\n  template: '<ng-content></ng-content>',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class MapMarker implements OnInit, OnDestroy {\n  private _eventManager = new MapEventManager();\n  private readonly _options =\n      new BehaviorSubject<google.maps.MarkerOptions>(DEFAULT_MARKER_OPTIONS);\n  private readonly _title = new BehaviorSubject<string|undefined>(undefined);\n  private readonly _position =\n      new BehaviorSubject<google.maps.LatLngLiteral|google.maps.LatLng|undefined>(undefined);\n  private readonly _label =\n      new BehaviorSubject<string|google.maps.MarkerLabel|undefined>(undefined);\n  private readonly _clickable = new BehaviorSubject<boolean|undefined>(undefined);\n  private readonly _destroy = new Subject<void>();\n\n  @Input()\n  set options(options: google.maps.MarkerOptions) {\n    this._options.next(options || DEFAULT_MARKER_OPTIONS);\n  }\n\n  @Input()\n  set title(title: string) {\n    this._title.next(title);\n  }\n\n  @Input()\n  set position(position: google.maps.LatLngLiteral|google.maps.LatLng) {\n    this._position.next(position);\n  }\n\n  @Input()\n  set label(label: string|google.maps.MarkerLabel) {\n    this._label.next(label);\n  }\n\n  @Input()\n  set clickable(clickable: boolean) {\n    this._clickable.next(clickable);\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.animation_changed\n   */\n  @Output()\n  animationChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('animation_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.click\n   */\n  @Output()\n  mapClick: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('click');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.clickable_changed\n   */\n  @Output()\n  clickableChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('clickable_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.cursor_changed\n   */\n  @Output()\n  cursorChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('cursor_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.dblclick\n   */\n  @Output()\n  mapDblclick: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('dblclick');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.drag\n   */\n  @Output()\n  mapDrag: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('drag');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.dragend\n   */\n  @Output()\n  mapDragend: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('dragend');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.draggable_changed\n   */\n  @Output()\n  draggableChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('draggable_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.dragstart\n   */\n  @Output()\n  mapDragstart: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('dragstart');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.flat_changed\n   */\n  @Output() flatChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('flat_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.icon_changed\n   */\n  @Output() iconChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('icon_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.mousedown\n   */\n  @Output()\n  mapMousedown: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('mousedown');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.mouseout\n   */\n  @Output()\n  mapMouseout: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('mouseout');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.mouseover\n   */\n  @Output()\n  mapMouseover: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('mouseover');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.mouseup\n   */\n  @Output()\n  mapMouseup: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('mouseup');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.position_changed\n   */\n  @Output()\n  positionChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('position_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.rightclick\n   */\n  @Output()\n  mapRightclick: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('rightclick');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.shape_changed\n   */\n  @Output() shapeChanged:\n  Observable<void> = this._eventManager.getLazyEmitter<void>('shape_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.title_changed\n   */\n  @Output()\n  titleChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('title_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.visible_changed\n   */\n  @Output()\n  visibleChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('visible_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.zindex_changed\n   */\n  @Output()\n  zindexChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('zindex_changed');\n\n  _marker?: google.maps.Marker;\n\n  constructor(private readonly _googleMap: GoogleMap) {}\n\n  ngOnInit() {\n    const combinedOptionsChanges = this._combineOptions();\n\n    combinedOptionsChanges.pipe(take(1)).subscribe(options => {\n      this._marker = new google.maps.Marker(options);\n      this._marker.setMap(this._googleMap._googleMap);\n      this._eventManager.setTarget(this._marker);\n    });\n\n    this._watchForOptionsChanges();\n    this._watchForTitleChanges();\n    this._watchForPositionChanges();\n    this._watchForLabelChanges();\n    this._watchForClickableChanges();\n  }\n\n  ngOnDestroy() {\n    this._destroy.next();\n    this._destroy.complete();\n    this._eventManager.destroy();\n    if (this._marker) {\n      this._marker.setMap(null);\n    }\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getAnimation\n   */\n  getAnimation(): google.maps.Animation|null {\n    return this._marker!.getAnimation() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getClickable\n   */\n  getClickable(): boolean {\n    return this._marker!.getClickable();\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getCursor\n   */\n  getCursor(): string|null {\n    return this._marker!.getCursor() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getDraggable\n   */\n  getDraggable(): boolean {\n    return !!this._marker!.getDraggable();\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getIcon\n   */\n  getIcon(): string|google.maps.Icon|google.maps.Symbol|null {\n    return this._marker!.getIcon() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getLabel\n   */\n  getLabel(): google.maps.MarkerLabel|null {\n    return this._marker!.getLabel() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getOpacity\n   */\n  getOpacity(): number|null {\n    return this._marker!.getOpacity() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getPosition\n   */\n  getPosition(): google.maps.LatLng|null {\n    return this._marker!.getPosition() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getShape\n   */\n  getShape(): google.maps.MarkerShape|null {\n    return this._marker!.getShape() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getTitle\n   */\n  getTitle(): string|null {\n    return this._marker!.getTitle() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getVisible\n   */\n  getVisible(): boolean {\n    return this._marker!.getVisible();\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getZIndex\n   */\n  getZIndex(): number|null {\n    return this._marker!.getZIndex() || null;\n  }\n\n  private _combineOptions(): Observable<google.maps.MarkerOptions> {\n    return combineLatest([this._options, this._title, this._position, this._label, this._clickable])\n        .pipe(map(([options, title, position, label, clickable]) => {\n          const combinedOptions: google.maps.MarkerOptions = {\n            ...options,\n            title: title || options.title,\n            position: position || options.position,\n            label: label || options.label,\n            clickable: clickable !== undefined ? clickable : options.clickable,\n            map: this._googleMap._googleMap || null,\n          };\n          return combinedOptions;\n        }));\n  }\n\n  private _watchForOptionsChanges() {\n    this._options.pipe(takeUntil(this._destroy)).subscribe(options => {\n      if (this._marker) {\n        this._marker.setOptions(options);\n      }\n    });\n  }\n\n  private _watchForTitleChanges() {\n    this._title.pipe(takeUntil(this._destroy)).subscribe(title => {\n      if (this._marker && title !== undefined) {\n        this._marker.setTitle(title);\n      }\n    });\n  }\n\n  private _watchForPositionChanges() {\n    this._position.pipe(takeUntil(this._destroy)).subscribe(position => {\n      if (this._marker && position) {\n        this._marker.setPosition(position);\n      }\n    });\n  }\n\n  private _watchForLabelChanges() {\n    this._label.pipe(takeUntil(this._destroy)).subscribe(label => {\n      if (this._marker && label !== undefined) {\n        this._marker.setLabel(label);\n      }\n    });\n  }\n\n  private _watchForClickableChanges() {\n    this._clickable.pipe(takeUntil(this._destroy)).subscribe(clickable => {\n      if (this._marker && clickable !== undefined) {\n        this._marker.setClickable(clickable);\n      }\n    });\n  }\n}\n"]}
/**
* @fileoverview added by tsickle
* Generated from: src/google-maps/public-api.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc

@@ -13,5 +14,6 @@ */

export { GoogleMap } from './google-map/google-map';
export { MapMarker } from './map-marker/map-marker';
export { GoogleMapsModule } from './google-maps-module';
export { MapInfoWindow } from './map-info-window/map-info-window';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9nb29nbGUtbWFwcy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0FBUUEsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ2xELE9BQU8sRUFBQyxTQUFTLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUNsRCxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUN0RCxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sbUNBQW1DLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuZXhwb3J0IHtHb29nbGVNYXB9IGZyb20gJy4vZ29vZ2xlLW1hcC9nb29nbGUtbWFwJztcbmV4cG9ydCB7TWFwTWFya2VyfSBmcm9tICcuL21hcC1tYXJrZXIvbWFwLW1hcmtlcic7XG5leHBvcnQge0dvb2dsZU1hcHNNb2R1bGV9IGZyb20gJy4vZ29vZ2xlLW1hcHMtbW9kdWxlJztcbmV4cG9ydCB7TWFwSW5mb1dpbmRvd30gZnJvbSAnLi9tYXAtaW5mby13aW5kb3cvbWFwLWluZm8td2luZG93JztcbiJdfQ==
export { MapMarker } from './map-marker/map-marker';
export { MapPolyline } from './map-polyline/map-polyline';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9nb29nbGUtbWFwcy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztBQVFBLE9BQU8sRUFBQyxTQUFTLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUNsRCxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUN0RCxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDaEUsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ2xELE9BQU8sRUFBQyxXQUFXLEVBQUMsTUFBTSw2QkFBNkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5leHBvcnQge0dvb2dsZU1hcH0gZnJvbSAnLi9nb29nbGUtbWFwL2dvb2dsZS1tYXAnO1xuZXhwb3J0IHtHb29nbGVNYXBzTW9kdWxlfSBmcm9tICcuL2dvb2dsZS1tYXBzLW1vZHVsZSc7XG5leHBvcnQge01hcEluZm9XaW5kb3d9IGZyb20gJy4vbWFwLWluZm8td2luZG93L21hcC1pbmZvLXdpbmRvdyc7XG5leHBvcnQge01hcE1hcmtlcn0gZnJvbSAnLi9tYXAtbWFya2VyL21hcC1tYXJrZXInO1xuZXhwb3J0IHtNYXBQb2x5bGluZX0gZnJvbSAnLi9tYXAtcG9seWxpbmUvbWFwLXBvbHlsaW5lJztcbiJdfQ==

@@ -8,9 +8,10 @@ /**

*/
import { __assign, __read, __values } from "tslib";
import { __assign, __read } from "tslib";
// Workaround for: https://github.com/bazelbuild/rules_nodejs/issues/1265
/// <reference types="googlemaps" />
import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, Input, Output, ViewEncapsulation, Optional, Inject, PLATFORM_ID, } from '@angular/core';
import { ChangeDetectionStrategy, Component, ElementRef, Input, Output, ViewEncapsulation, Optional, Inject, PLATFORM_ID, } from '@angular/core';
import { isPlatformBrowser } from '@angular/common';
import { BehaviorSubject, combineLatest, Subject } from 'rxjs';
import { BehaviorSubject, combineLatest, Observable, Subject } from 'rxjs';
import { map, shareReplay, take, takeUntil } from 'rxjs/operators';
import { MapEventManager } from '../map-event-manager';
/** default options set to the Googleplex */

@@ -38,2 +39,7 @@ export var DEFAULT_OPTIONS = {

this._elementRef = _elementRef;
this._eventManager = new MapEventManager();
this._options = new BehaviorSubject(DEFAULT_OPTIONS);
this._center = new BehaviorSubject(undefined);
this._zoom = new BehaviorSubject(undefined);
this._destroy = new Subject();
this.height = DEFAULT_HEIGHT;

@@ -45,3 +51,3 @@ this.width = DEFAULT_WIDTH;

*/
this.boundsChanged = new EventEmitter();
this.boundsChanged = this._eventManager.getLazyEmitter('bounds_changed');
/**

@@ -51,3 +57,3 @@ * See

*/
this.centerChanged = new EventEmitter();
this.centerChanged = this._eventManager.getLazyEmitter('center_changed');
/**

@@ -57,3 +63,3 @@ * See

*/
this.mapClick = new EventEmitter();
this.mapClick = this._eventManager.getLazyEmitter('click');
/**

@@ -63,3 +69,3 @@ * See

*/
this.mapDblclick = new EventEmitter();
this.mapDblclick = this._eventManager.getLazyEmitter('dblclick');
/**

@@ -69,3 +75,3 @@ * See

*/
this.mapDrag = new EventEmitter();
this.mapDrag = this._eventManager.getLazyEmitter('drag');
/**

@@ -75,3 +81,3 @@ * See

*/
this.mapDragend = new EventEmitter();
this.mapDragend = this._eventManager.getLazyEmitter('dragend');
/**

@@ -81,3 +87,3 @@ * See

*/
this.mapDragstart = new EventEmitter();
this.mapDragstart = this._eventManager.getLazyEmitter('dragstart');
/**

@@ -87,3 +93,3 @@ * See

*/
this.headingChanged = new EventEmitter();
this.headingChanged = this._eventManager.getLazyEmitter('heading_changed');
/**

@@ -93,3 +99,3 @@ * See

*/
this.idle = new EventEmitter();
this.idle = this._eventManager.getLazyEmitter('idle');
/**

@@ -99,3 +105,3 @@ * See

*/
this.maptypeidChanged = new EventEmitter();
this.maptypeidChanged = this._eventManager.getLazyEmitter('maptypeid_changed');
/**

@@ -105,3 +111,3 @@ * See

*/
this.mapMousemove = new EventEmitter();
this.mapMousemove = this._eventManager.getLazyEmitter('mousemove');
/**

@@ -111,3 +117,3 @@ * See

*/
this.mapMouseout = new EventEmitter();
this.mapMouseout = this._eventManager.getLazyEmitter('mouseout');
/**

@@ -117,3 +123,3 @@ * See

*/
this.mapMouseover = new EventEmitter();
this.mapMouseover = this._eventManager.getLazyEmitter('mouseover');
/**

@@ -123,3 +129,3 @@ * See

*/
this.projectionChanged = new EventEmitter();
this.projectionChanged = this._eventManager.getLazyEmitter('projection_changed');
/**

@@ -129,3 +135,3 @@ * See

*/
this.mapRightclick = new EventEmitter();
this.mapRightclick = this._eventManager.getLazyEmitter('rightclick');
/**

@@ -135,3 +141,3 @@ * See

*/
this.tilesloaded = new EventEmitter();
this.tilesloaded = this._eventManager.getLazyEmitter('tilesloaded');
/**

@@ -141,3 +147,3 @@ * See

*/
this.tiltChanged = new EventEmitter();
this.tiltChanged = this._eventManager.getLazyEmitter('tilt_changed');
/**

@@ -147,8 +153,3 @@ * See

*/
this.zoomChanged = new EventEmitter();
this._listeners = [];
this._options = new BehaviorSubject(DEFAULT_OPTIONS);
this._center = new BehaviorSubject(undefined);
this._zoom = new BehaviorSubject(undefined);
this._destroy = new Subject();
this.zoomChanged = this._eventManager.getLazyEmitter('zoomChanged');
// @breaking-change 10.0.0 Remove null check for `platformId`.

@@ -197,7 +198,6 @@ this._isBrowser =

this._setSize();
var combinedOptionsChanges = this._combineOptions();
this._googleMapChanges = this._initializeMap(combinedOptionsChanges);
this._googleMapChanges = this._initializeMap(this._combineOptions());
this._googleMapChanges.subscribe(function (googleMap) {
_this._googleMap = googleMap;
_this._initializeEventHandlers();
_this._eventManager.setTarget(_this._googleMap);
});

@@ -210,5 +210,5 @@ this._watchForOptionsChanges();

GoogleMap.prototype.ngOnDestroy = function () {
this._eventManager.destroy();
this._destroy.next();
this._destroy.complete();
this._clearListeners();
};

@@ -220,2 +220,3 @@ /**

GoogleMap.prototype.fitBounds = function (bounds, padding) {
this._assertInitialized();
this._googleMap.fitBounds(bounds, padding);

@@ -228,2 +229,3 @@ };

GoogleMap.prototype.panBy = function (x, y) {
this._assertInitialized();
this._googleMap.panBy(x, y);

@@ -236,2 +238,3 @@ };

GoogleMap.prototype.panTo = function (latLng) {
this._assertInitialized();
this._googleMap.panTo(latLng);

@@ -244,2 +247,3 @@ };

GoogleMap.prototype.panToBounds = function (latLngBounds, padding) {
this._assertInitialized();
this._googleMap.panToBounds(latLngBounds, padding);

@@ -252,2 +256,3 @@ };

GoogleMap.prototype.getBounds = function () {
this._assertInitialized();
return this._googleMap.getBounds() || null;

@@ -260,2 +265,3 @@ };

GoogleMap.prototype.getCenter = function () {
this._assertInitialized();
return this._googleMap.getCenter();

@@ -268,2 +274,3 @@ };

GoogleMap.prototype.getClickableIcons = function () {
this._assertInitialized();
return this._googleMap.getClickableIcons();

@@ -276,2 +283,3 @@ };

GoogleMap.prototype.getHeading = function () {
this._assertInitialized();
return this._googleMap.getHeading();

@@ -284,2 +292,3 @@ };

GoogleMap.prototype.getMapTypeId = function () {
this._assertInitialized();
return this._googleMap.getMapTypeId();

@@ -292,2 +301,3 @@ };

GoogleMap.prototype.getProjection = function () {
this._assertInitialized();
return this._googleMap.getProjection();

@@ -300,2 +310,3 @@ };

GoogleMap.prototype.getStreetView = function () {
this._assertInitialized();
return this._googleMap.getStreetView();

@@ -308,2 +319,3 @@ };

GoogleMap.prototype.getTilt = function () {
this._assertInitialized();
return this._googleMap.getTilt();

@@ -316,2 +328,3 @@ };

GoogleMap.prototype.getZoom = function () {
this._assertInitialized();
return this._googleMap.getZoom();

@@ -325,2 +338,3 @@ };

get: function () {
this._assertInitialized();
return this._googleMap.controls;

@@ -337,2 +351,3 @@ },

get: function () {
this._assertInitialized();
return this._googleMap.data;

@@ -349,2 +364,3 @@ },

get: function () {
this._assertInitialized();
return this._googleMap.mapTypes;

@@ -361,2 +377,3 @@ },

get: function () {
this._assertInitialized();
return this._googleMap.overlayMapTypes;

@@ -384,5 +401,3 @@ },

var _this = this;
return optionsChanges.pipe(take(1), map(function (options) {
return new google.maps.Map(_this._mapEl, options);
}), shareReplay(1));
return optionsChanges.pipe(take(1), map(function (options) { return new google.maps.Map(_this._mapEl, options); }), shareReplay(1));
};

@@ -417,65 +432,9 @@ GoogleMap.prototype._watchForOptionsChanges = function () {

};
GoogleMap.prototype._initializeEventHandlers = function () {
var _this = this;
// Ensure that we don't leak if called multiple times.
this._clearListeners();
var eventHandlers = new Map([
['bounds_changed', this.boundsChanged],
['center_changed', this.centerChanged],
['drag', this.mapDrag],
['dragend', this.mapDragend],
['dragstart', this.mapDragstart],
['heading_changed', this.headingChanged],
['idle', this.idle],
['maptypeid_changed', this.maptypeidChanged],
['projection_changed', this.projectionChanged],
['tilesloaded', this.tilesloaded],
['tilt_changed', this.tiltChanged],
['zoomChanged', this.zoomChanged],
]);
var mouseEventHandlers = new Map([
['dblclick', this.mapDblclick],
['mousemove', this.mapMousemove],
['mouseout', this.mapMouseout],
['mouseover', this.mapMouseover],
['rightclick', this.mapRightclick],
]);
eventHandlers.forEach(function (eventHandler, name) {
if (eventHandler.observers.length > 0) {
_this._listeners.push(_this._googleMap.addListener(name, function () {
eventHandler.emit();
}));
}
});
mouseEventHandlers.forEach(function (eventHandler, name) {
if (eventHandler.observers.length > 0) {
_this._listeners.push(_this._googleMap.addListener(name, function (event) {
eventHandler.emit(event);
}));
}
});
if (this.mapClick.observers.length > 0) {
this._listeners.push(this._googleMap.addListener('click', function (event) {
_this.mapClick.emit(event);
}));
/** Asserts that the map has been initialized. */
GoogleMap.prototype._assertInitialized = function () {
if (!this._googleMap) {
throw Error('Cannot access Google Map information before the API has been initialized. ' +
'Please wait for the API to load before trying to interact with it.');
}
};
/** Clears all currently-registered event listeners. */
GoogleMap.prototype._clearListeners = function () {
var e_1, _a;
try {
for (var _b = __values(this._listeners), _c = _b.next(); !_c.done; _c = _b.next()) {
var listener = _c.value;
listener.remove();
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_1) throw e_1.error; }
}
this._listeners = [];
};
GoogleMap.decorators = [

@@ -522,2 +481,2 @@ { type: Component, args: [{

export { GoogleMap };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"google-map.js","sourceRoot":"","sources":["../../../../../../../../../src/google-maps/google-map/google-map.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n// Workaround for: https://github.com/bazelbuild/rules_nodejs/issues/1265\n/// <reference types=\"googlemaps\" />\n\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewEncapsulation,\n  Optional,\n  Inject,\n  PLATFORM_ID,\n} from '@angular/core';\nimport {isPlatformBrowser} from '@angular/common';\nimport {BehaviorSubject, combineLatest, Observable, Subject} from 'rxjs';\nimport {map, shareReplay, take, takeUntil} from 'rxjs/operators';\n\ninterface GoogleMapsWindow extends Window {\n  google?: typeof google;\n}\n\n// TODO(mbehrlich): Update this to use original map after updating DefinitelyTyped\n/**\n * Extends the Google Map interface due to the Definitely Typed implementation\n * missing \"getClickableIcons\".\n */\nexport interface UpdatedGoogleMap extends google.maps.Map {\n  getClickableIcons: () => boolean;\n}\n\n/** default options set to the Googleplex */\nexport const DEFAULT_OPTIONS: google.maps.MapOptions = {\n  center: {lat: 37.421995, lng: -122.084092},\n  zoom: 17,\n};\n\n/** Arbitrary default height for the map element */\nexport const DEFAULT_HEIGHT = '500px';\n/** Arbitrary default width for the map element */\nexport const DEFAULT_WIDTH = '500px';\n\n/**\n * Angular component that renders a Google Map via the Google Maps JavaScript\n * API.\n * @see https://developers.google.com/maps/documentation/javascript/reference/\n */\n@Component({\n  selector: 'google-map',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  template: '<div class=\"map-container\"></div><ng-content></ng-content>',\n  encapsulation: ViewEncapsulation.None,\n})\nexport class GoogleMap implements OnChanges, OnInit, OnDestroy {\n  @Input() height = DEFAULT_HEIGHT;\n\n  @Input() width = DEFAULT_WIDTH;\n\n  @Input()\n  set center(center: google.maps.LatLngLiteral|google.maps.LatLng) {\n    this._center.next(center);\n  }\n  @Input()\n  set zoom(zoom: number) {\n    this._zoom.next(zoom);\n  }\n  @Input()\n  set options(options: google.maps.MapOptions) {\n    this._options.next(options || DEFAULT_OPTIONS);\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.bounds_changed\n   */\n  @Output() boundsChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.center_changed\n   */\n  @Output() centerChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.click\n   */\n  @Output() mapClick = new EventEmitter<google.maps.MouseEvent|google.maps.IconMouseEvent>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.dblclick\n   */\n  @Output() mapDblclick = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.drag\n   */\n  @Output() mapDrag = new EventEmitter<void>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.dragend\n   */\n  @Output() mapDragend = new EventEmitter<void>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.dragstart\n   */\n  @Output() mapDragstart = new EventEmitter<void>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.heading_changed\n   */\n  @Output() headingChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.idle\n   */\n  @Output() idle = new EventEmitter<void>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.maptypeid_changed\n   */\n  @Output() maptypeidChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.mousemove\n   */\n  @Output() mapMousemove = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.mouseout\n   */\n  @Output() mapMouseout = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.mouseover\n   */\n  @Output() mapMouseover = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/map#Map.projection_changed\n   */\n  @Output() projectionChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.rightclick\n   */\n  @Output() mapRightclick = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.tilesloaded\n   */\n  @Output() tilesloaded = new EventEmitter<void>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.tilt_changed\n   */\n  @Output() tiltChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.zoom_changed\n   */\n  @Output() zoomChanged = new EventEmitter<void>();\n\n  private _mapEl: HTMLElement;\n  _googleMap!: UpdatedGoogleMap;\n\n  /** Whether we're currently rendering inside a browser. */\n  private _isBrowser: boolean;\n  private _googleMapChanges!: Observable<google.maps.Map>;\n\n  private _listeners: google.maps.MapsEventListener[] = [];\n\n  private readonly _options = new BehaviorSubject<google.maps.MapOptions>(DEFAULT_OPTIONS);\n  private readonly _center =\n      new BehaviorSubject<google.maps.LatLngLiteral|google.maps.LatLng|undefined>(undefined);\n  private readonly _zoom = new BehaviorSubject<number|undefined>(undefined);\n\n  private readonly _destroy = new Subject<void>();\n\n  constructor(\n    private readonly _elementRef: ElementRef,\n    /**\n     * @deprecated `platformId` parameter to become required.\n     * @breaking-change 10.0.0\n     */\n    @Optional() @Inject(PLATFORM_ID) platformId?: Object) {\n\n    // @breaking-change 10.0.0 Remove null check for `platformId`.\n    this._isBrowser =\n        platformId ? isPlatformBrowser(platformId) : typeof window === 'object' && !!window;\n\n    if (this._isBrowser) {\n      const googleMapsWindow: GoogleMapsWindow = window;\n      if (!googleMapsWindow.google) {\n        throw Error(\n            'Namespace google not found, cannot construct embedded google ' +\n            'map. Please install the Google Maps JavaScript API: ' +\n            'https://developers.google.com/maps/documentation/javascript/' +\n            'tutorial#Loading_the_Maps_API');\n      }\n    }\n  }\n\n  ngOnChanges() {\n    this._setSize();\n  }\n\n  ngOnInit() {\n    // It should be a noop during server-side rendering.\n    if (this._isBrowser) {\n      this._mapEl = this._elementRef.nativeElement.querySelector('.map-container')!;\n      this._setSize();\n\n      const combinedOptionsChanges = this._combineOptions();\n\n      this._googleMapChanges = this._initializeMap(combinedOptionsChanges);\n      this._googleMapChanges.subscribe((googleMap: google.maps.Map) => {\n        this._googleMap = googleMap as UpdatedGoogleMap;\n\n        this._initializeEventHandlers();\n      });\n\n      this._watchForOptionsChanges();\n      this._watchForCenterChanges();\n      this._watchForZoomChanges();\n    }\n  }\n\n  ngOnDestroy() {\n    this._destroy.next();\n    this._destroy.complete();\n    this._clearListeners();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.fitBounds\n   */\n  fitBounds(\n      bounds: google.maps.LatLngBounds|google.maps.LatLngBoundsLiteral,\n      padding?: number|google.maps.Padding) {\n    this._googleMap.fitBounds(bounds, padding);\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.panBy\n   */\n  panBy(x: number, y: number) {\n    this._googleMap.panBy(x, y);\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.panTo\n   */\n  panTo(latLng: google.maps.LatLng|google.maps.LatLngLiteral) {\n    this._googleMap.panTo(latLng);\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.panToBounds\n   */\n  panToBounds(\n      latLngBounds: google.maps.LatLngBounds|google.maps.LatLngBoundsLiteral,\n      padding?: number|google.maps.Padding) {\n    this._googleMap.panToBounds(latLngBounds, padding);\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getBounds\n   */\n  getBounds(): google.maps.LatLngBounds|null {\n    return this._googleMap.getBounds() || null;\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getCenter\n   */\n  getCenter(): google.maps.LatLng {\n    return this._googleMap.getCenter();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getClickableIcons\n   */\n  getClickableIcons(): boolean {\n    return this._googleMap.getClickableIcons();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getHeading\n   */\n  getHeading(): number {\n    return this._googleMap.getHeading();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getMapTypeId\n   */\n  getMapTypeId(): google.maps.MapTypeId|string {\n    return this._googleMap.getMapTypeId();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getProjection\n   */\n  getProjection(): google.maps.Projection|null {\n    return this._googleMap.getProjection();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getStreetView\n   */\n  getStreetView(): google.maps.StreetViewPanorama {\n    return this._googleMap.getStreetView();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getTilt\n   */\n  getTilt(): number {\n    return this._googleMap.getTilt();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getZoom\n   */\n  getZoom(): number {\n    return this._googleMap.getZoom();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.controls\n   */\n  get controls(): Array<google.maps.MVCArray<Node>> {\n    return this._googleMap.controls;\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.data\n   */\n  get data(): google.maps.Data {\n    return this._googleMap.data;\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.mapTypes\n   */\n  get mapTypes(): google.maps.MapTypeRegistry {\n    return this._googleMap.mapTypes;\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.overlayMapTypes\n   */\n  get overlayMapTypes(): google.maps.MVCArray<google.maps.MapType> {\n    return this._googleMap.overlayMapTypes;\n  }\n\n  private _setSize() {\n    if (this._mapEl) {\n      this._mapEl.style.height = this.height || DEFAULT_HEIGHT;\n      this._mapEl.style.width = this.width || DEFAULT_WIDTH;\n    }\n  }\n\n  /** Combines the center and zoom and the other map options into a single object */\n  private _combineOptions(): Observable<google.maps.MapOptions> {\n    return combineLatest([this._options, this._center, this._zoom])\n        .pipe(map(([options, center, zoom]) => {\n          const combinedOptions: google.maps.MapOptions = {\n            ...options,\n            center: center || options.center,\n            zoom: zoom !== undefined ? zoom : options.zoom,\n          };\n          return combinedOptions;\n        }));\n  }\n\n  private _initializeMap(optionsChanges: Observable<google.maps.MapOptions>):\n      Observable<google.maps.Map> {\n    return optionsChanges.pipe(\n        take(1), map(options => {\n          return new google.maps.Map(this._mapEl, options);\n        }),\n        shareReplay(1));\n  }\n\n  private _watchForOptionsChanges() {\n    combineLatest([this._googleMapChanges, this._options])\n        .pipe(takeUntil(this._destroy))\n        .subscribe(([googleMap, options]) => {\n          googleMap.setOptions(options);\n        });\n  }\n\n  private _watchForCenterChanges() {\n    combineLatest([this._googleMapChanges, this._center])\n        .pipe(takeUntil(this._destroy))\n        .subscribe(([googleMap, center]) => {\n          if (center) {\n            googleMap.setCenter(center);\n          }\n        });\n  }\n\n  private _watchForZoomChanges() {\n    combineLatest([this._googleMapChanges, this._zoom])\n        .pipe(takeUntil(this._destroy))\n        .subscribe(([googleMap, zoom]) => {\n          if (zoom !== undefined) {\n            googleMap.setZoom(zoom);\n          }\n        });\n  }\n\n  private _initializeEventHandlers() {\n    // Ensure that we don't leak if called multiple times.\n    this._clearListeners();\n\n    const eventHandlers = new Map<string, EventEmitter<void>>([\n      ['bounds_changed', this.boundsChanged],\n      ['center_changed', this.centerChanged],\n      ['drag', this.mapDrag],\n      ['dragend', this.mapDragend],\n      ['dragstart', this.mapDragstart],\n      ['heading_changed', this.headingChanged],\n      ['idle', this.idle],\n      ['maptypeid_changed', this.maptypeidChanged],\n      ['projection_changed', this.projectionChanged],\n      ['tilesloaded', this.tilesloaded],\n      ['tilt_changed', this.tiltChanged],\n      ['zoomChanged', this.zoomChanged],\n    ]);\n    const mouseEventHandlers = new Map<string, EventEmitter<google.maps.MouseEvent>>([\n      ['dblclick', this.mapDblclick],\n      ['mousemove', this.mapMousemove],\n      ['mouseout', this.mapMouseout],\n      ['mouseover', this.mapMouseover],\n      ['rightclick', this.mapRightclick],\n    ]);\n    eventHandlers.forEach((eventHandler: EventEmitter<void>, name: string) => {\n      if (eventHandler.observers.length > 0) {\n        this._listeners.push(this._googleMap.addListener(name, () => {\n          eventHandler.emit();\n        }));\n      }\n    });\n    mouseEventHandlers.forEach(\n        (eventHandler: EventEmitter<google.maps.MouseEvent>, name: string) => {\n          if (eventHandler.observers.length > 0) {\n            this._listeners.push(\n                this._googleMap.addListener(name, (event: google.maps.MouseEvent) => {\n                  eventHandler.emit(event);\n                }));\n          }\n        });\n    if (this.mapClick.observers.length > 0) {\n      this._listeners.push(this._googleMap.addListener(\n          'click', (event: google.maps.MouseEvent|google.maps.IconMouseEvent) => {\n            this.mapClick.emit(event);\n          }));\n    }\n  }\n\n  /** Clears all currently-registered event listeners. */\n  private _clearListeners() {\n    for (let listener of this._listeners) {\n      listener.remove();\n    }\n\n    this._listeners = [];\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"google-map.js","sourceRoot":"","sources":["../../../../../../../../../src/google-maps/google-map/google-map.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n// Workaround for: https://github.com/bazelbuild/rules_nodejs/issues/1265\n/// <reference types=\"googlemaps\" />\n\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewEncapsulation,\n  Optional,\n  Inject,\n  PLATFORM_ID,\n} from '@angular/core';\nimport {isPlatformBrowser} from '@angular/common';\nimport {BehaviorSubject, combineLatest, Observable, Subject} from 'rxjs';\nimport {map, shareReplay, take, takeUntil} from 'rxjs/operators';\nimport {MapEventManager} from '../map-event-manager';\n\ninterface GoogleMapsWindow extends Window {\n  google?: typeof google;\n}\n\n// TODO(mbehrlich): Update this to use original map after updating DefinitelyTyped\n/**\n * Extends the Google Map interface due to the Definitely Typed implementation\n * missing \"getClickableIcons\".\n */\nexport interface UpdatedGoogleMap extends google.maps.Map {\n  getClickableIcons: () => boolean;\n}\n\n/** default options set to the Googleplex */\nexport const DEFAULT_OPTIONS: google.maps.MapOptions = {\n  center: {lat: 37.421995, lng: -122.084092},\n  zoom: 17,\n};\n\n/** Arbitrary default height for the map element */\nexport const DEFAULT_HEIGHT = '500px';\n/** Arbitrary default width for the map element */\nexport const DEFAULT_WIDTH = '500px';\n\n/**\n * Angular component that renders a Google Map via the Google Maps JavaScript\n * API.\n * @see https://developers.google.com/maps/documentation/javascript/reference/\n */\n@Component({\n  selector: 'google-map',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  template: '<div class=\"map-container\"></div><ng-content></ng-content>',\n  encapsulation: ViewEncapsulation.None,\n})\nexport class GoogleMap implements OnChanges, OnInit, OnDestroy {\n  private _eventManager = new MapEventManager();\n\n  /** Whether we're currently rendering inside a browser. */\n  private _isBrowser: boolean;\n  private _googleMapChanges: Observable<google.maps.Map>;\n\n  private readonly _options = new BehaviorSubject<google.maps.MapOptions>(DEFAULT_OPTIONS);\n  private readonly _center =\n      new BehaviorSubject<google.maps.LatLngLiteral|google.maps.LatLng|undefined>(undefined);\n  private readonly _zoom = new BehaviorSubject<number|undefined>(undefined);\n  private readonly _destroy = new Subject<void>();\n  private _mapEl: HTMLElement;\n  _googleMap: UpdatedGoogleMap;\n\n  @Input() height = DEFAULT_HEIGHT;\n\n  @Input() width = DEFAULT_WIDTH;\n\n  @Input()\n  set center(center: google.maps.LatLngLiteral|google.maps.LatLng) {\n    this._center.next(center);\n  }\n  @Input()\n  set zoom(zoom: number) {\n    this._zoom.next(zoom);\n  }\n  @Input()\n  set options(options: google.maps.MapOptions) {\n    this._options.next(options || DEFAULT_OPTIONS);\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.bounds_changed\n   */\n  @Output()\n  boundsChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('bounds_changed');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.center_changed\n   */\n  @Output()\n  centerChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('center_changed');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.click\n   */\n  @Output()\n  mapClick: Observable<google.maps.MouseEvent|google.maps.IconMouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent|google.maps.IconMouseEvent>('click');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.dblclick\n   */\n  @Output()\n  mapDblclick: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('dblclick');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.drag\n   */\n  @Output() mapDrag: Observable<void> = this._eventManager.getLazyEmitter<void>('drag');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.dragend\n   */\n  @Output() mapDragend: Observable<void> = this._eventManager.getLazyEmitter<void>('dragend');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.dragstart\n   */\n  @Output() mapDragstart: Observable<void> = this._eventManager.getLazyEmitter<void>('dragstart');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.heading_changed\n   */\n  @Output()\n  headingChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('heading_changed');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.idle\n   */\n  @Output() idle: Observable<void> = this._eventManager.getLazyEmitter<void>('idle');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.maptypeid_changed\n   */\n  @Output()\n  maptypeidChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('maptypeid_changed');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.mousemove\n   */\n  @Output()\n  mapMousemove: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('mousemove');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.mouseout\n   */\n  @Output()\n  mapMouseout: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('mouseout');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.mouseover\n   */\n  @Output()\n  mapMouseover: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('mouseover');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/map#Map.projection_changed\n   */\n  @Output()\n  projectionChanged: Observable<void> =\n      this._eventManager.getLazyEmitter<void>('projection_changed');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.rightclick\n   */\n  @Output()\n  mapRightclick: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('rightclick');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.tilesloaded\n   */\n  @Output() tilesloaded: Observable<void> = this._eventManager.getLazyEmitter<void>('tilesloaded');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.tilt_changed\n   */\n  @Output() tiltChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('tilt_changed');\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.zoom_changed\n   */\n  @Output() zoomChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('zoomChanged');\n\n  constructor(\n    private readonly _elementRef: ElementRef,\n    /**\n     * @deprecated `platformId` parameter to become required.\n     * @breaking-change 10.0.0\n     */\n    @Optional() @Inject(PLATFORM_ID) platformId?: Object) {\n\n    // @breaking-change 10.0.0 Remove null check for `platformId`.\n    this._isBrowser =\n        platformId ? isPlatformBrowser(platformId) : typeof window === 'object' && !!window;\n\n    if (this._isBrowser) {\n      const googleMapsWindow: GoogleMapsWindow = window;\n      if (!googleMapsWindow.google) {\n        throw Error(\n            'Namespace google not found, cannot construct embedded google ' +\n            'map. Please install the Google Maps JavaScript API: ' +\n            'https://developers.google.com/maps/documentation/javascript/' +\n            'tutorial#Loading_the_Maps_API');\n      }\n    }\n  }\n\n  ngOnChanges() {\n    this._setSize();\n  }\n\n  ngOnInit() {\n    // It should be a noop during server-side rendering.\n    if (this._isBrowser) {\n      this._mapEl = this._elementRef.nativeElement.querySelector('.map-container')!;\n      this._setSize();\n      this._googleMapChanges = this._initializeMap(this._combineOptions());\n      this._googleMapChanges.subscribe((googleMap: google.maps.Map) => {\n        this._googleMap = googleMap as UpdatedGoogleMap;\n        this._eventManager.setTarget(this._googleMap);\n      });\n\n      this._watchForOptionsChanges();\n      this._watchForCenterChanges();\n      this._watchForZoomChanges();\n    }\n  }\n\n  ngOnDestroy() {\n    this._eventManager.destroy();\n    this._destroy.next();\n    this._destroy.complete();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.fitBounds\n   */\n  fitBounds(\n      bounds: google.maps.LatLngBounds|google.maps.LatLngBoundsLiteral,\n      padding?: number|google.maps.Padding) {\n    this._assertInitialized();\n    this._googleMap.fitBounds(bounds, padding);\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.panBy\n   */\n  panBy(x: number, y: number) {\n    this._assertInitialized();\n    this._googleMap.panBy(x, y);\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.panTo\n   */\n  panTo(latLng: google.maps.LatLng|google.maps.LatLngLiteral) {\n    this._assertInitialized();\n    this._googleMap.panTo(latLng);\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.panToBounds\n   */\n  panToBounds(\n      latLngBounds: google.maps.LatLngBounds|google.maps.LatLngBoundsLiteral,\n      padding?: number|google.maps.Padding) {\n    this._assertInitialized();\n    this._googleMap.panToBounds(latLngBounds, padding);\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getBounds\n   */\n  getBounds(): google.maps.LatLngBounds|null {\n    this._assertInitialized();\n    return this._googleMap.getBounds() || null;\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getCenter\n   */\n  getCenter(): google.maps.LatLng {\n    this._assertInitialized();\n    return this._googleMap.getCenter();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getClickableIcons\n   */\n  getClickableIcons(): boolean {\n    this._assertInitialized();\n    return this._googleMap.getClickableIcons();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getHeading\n   */\n  getHeading(): number {\n    this._assertInitialized();\n    return this._googleMap.getHeading();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getMapTypeId\n   */\n  getMapTypeId(): google.maps.MapTypeId|string {\n    this._assertInitialized();\n    return this._googleMap.getMapTypeId();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getProjection\n   */\n  getProjection(): google.maps.Projection|null {\n    this._assertInitialized();\n    return this._googleMap.getProjection();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getStreetView\n   */\n  getStreetView(): google.maps.StreetViewPanorama {\n    this._assertInitialized();\n    return this._googleMap.getStreetView();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getTilt\n   */\n  getTilt(): number {\n    this._assertInitialized();\n    return this._googleMap.getTilt();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.getZoom\n   */\n  getZoom(): number {\n    this._assertInitialized();\n    return this._googleMap.getZoom();\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.controls\n   */\n  get controls(): Array<google.maps.MVCArray<Node>> {\n    this._assertInitialized();\n    return this._googleMap.controls;\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.data\n   */\n  get data(): google.maps.Data {\n    this._assertInitialized();\n    return this._googleMap.data;\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.mapTypes\n   */\n  get mapTypes(): google.maps.MapTypeRegistry {\n    this._assertInitialized();\n    return this._googleMap.mapTypes;\n  }\n\n  /**\n   * See\n   * https://developers.google.com/maps/documentation/javascript/reference/map#Map.overlayMapTypes\n   */\n  get overlayMapTypes(): google.maps.MVCArray<google.maps.MapType> {\n    this._assertInitialized();\n    return this._googleMap.overlayMapTypes;\n  }\n\n  private _setSize() {\n    if (this._mapEl) {\n      this._mapEl.style.height = this.height || DEFAULT_HEIGHT;\n      this._mapEl.style.width = this.width || DEFAULT_WIDTH;\n    }\n  }\n\n  /** Combines the center and zoom and the other map options into a single object */\n  private _combineOptions(): Observable<google.maps.MapOptions> {\n    return combineLatest([this._options, this._center, this._zoom])\n        .pipe(map(([options, center, zoom]) => {\n          const combinedOptions: google.maps.MapOptions = {\n            ...options,\n            center: center || options.center,\n            zoom: zoom !== undefined ? zoom : options.zoom,\n          };\n          return combinedOptions;\n        }));\n  }\n\n  private _initializeMap(optionsChanges: Observable<google.maps.MapOptions>):\n      Observable<google.maps.Map> {\n    return optionsChanges.pipe(\n        take(1),\n        map(options => new google.maps.Map(this._mapEl, options)),\n        shareReplay(1));\n  }\n\n  private _watchForOptionsChanges() {\n    combineLatest([this._googleMapChanges, this._options])\n        .pipe(takeUntil(this._destroy))\n        .subscribe(([googleMap, options]) => {\n          googleMap.setOptions(options);\n        });\n  }\n\n  private _watchForCenterChanges() {\n    combineLatest([this._googleMapChanges, this._center])\n        .pipe(takeUntil(this._destroy))\n        .subscribe(([googleMap, center]) => {\n          if (center) {\n            googleMap.setCenter(center);\n          }\n        });\n  }\n\n  private _watchForZoomChanges() {\n    combineLatest([this._googleMapChanges, this._zoom])\n        .pipe(takeUntil(this._destroy))\n        .subscribe(([googleMap, zoom]) => {\n          if (zoom !== undefined) {\n            googleMap.setZoom(zoom);\n          }\n        });\n  }\n\n  /** Asserts that the map has been initialized. */\n  private _assertInitialized() {\n    if (!this._googleMap) {\n      throw Error('Cannot access Google Map information before the API has been initialized. ' +\n                  'Please wait for the API to load before trying to interact with it.');\n    }\n  }\n}\n"]}

@@ -12,2 +12,3 @@ /**

import { MapMarker } from './map-marker/map-marker';
import { MapPolyline } from './map-polyline/map-polyline';
var COMPONENTS = [

@@ -17,2 +18,3 @@ GoogleMap,

MapMarker,
MapPolyline,
];

@@ -31,2 +33,2 @@ var GoogleMapsModule = /** @class */ (function () {

export { GoogleMapsModule };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ29vZ2xlLW1hcHMtbW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2dvb2dsZS1tYXBzL2dvb2dsZS1tYXBzLW1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFFSCxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRXZDLE9BQU8sRUFBQyxTQUFTLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUNsRCxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDaEUsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBRWxELElBQU0sVUFBVSxHQUFHO0lBQ2pCLFNBQVM7SUFDVCxhQUFhO0lBQ2IsU0FBUztDQUNWLENBQUM7QUFFRjtJQUFBO0lBS0EsQ0FBQzs7Z0JBTEEsUUFBUSxTQUFDO29CQUNSLFlBQVksRUFBRSxVQUFVO29CQUN4QixPQUFPLEVBQUUsVUFBVTtpQkFDcEI7O0lBRUQsdUJBQUM7Q0FBQSxBQUxELElBS0M7U0FEWSxnQkFBZ0IiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7R29vZ2xlTWFwfSBmcm9tICcuL2dvb2dsZS1tYXAvZ29vZ2xlLW1hcCc7XG5pbXBvcnQge01hcEluZm9XaW5kb3d9IGZyb20gJy4vbWFwLWluZm8td2luZG93L21hcC1pbmZvLXdpbmRvdyc7XG5pbXBvcnQge01hcE1hcmtlcn0gZnJvbSAnLi9tYXAtbWFya2VyL21hcC1tYXJrZXInO1xuXG5jb25zdCBDT01QT05FTlRTID0gW1xuICBHb29nbGVNYXAsXG4gIE1hcEluZm9XaW5kb3csXG4gIE1hcE1hcmtlcixcbl07XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogQ09NUE9ORU5UUyxcbiAgZXhwb3J0czogQ09NUE9ORU5UUyxcbn0pXG5leHBvcnQgY2xhc3MgR29vZ2xlTWFwc01vZHVsZSB7XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ29vZ2xlLW1hcHMtbW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2dvb2dsZS1tYXBzL2dvb2dsZS1tYXBzLW1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFFSCxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRXZDLE9BQU8sRUFBQyxTQUFTLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUNsRCxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDaEUsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ2xELE9BQU8sRUFBQyxXQUFXLEVBQUMsTUFBTSw2QkFBNkIsQ0FBQztBQUV4RCxJQUFNLFVBQVUsR0FBRztJQUNqQixTQUFTO0lBQ1QsYUFBYTtJQUNiLFNBQVM7SUFDVCxXQUFXO0NBQ1osQ0FBQztBQUVGO0lBQUE7SUFLQSxDQUFDOztnQkFMQSxRQUFRLFNBQUM7b0JBQ1IsWUFBWSxFQUFFLFVBQVU7b0JBQ3hCLE9BQU8sRUFBRSxVQUFVO2lCQUNwQjs7SUFFRCx1QkFBQztDQUFBLEFBTEQsSUFLQztTQURZLGdCQUFnQiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5pbXBvcnQge05nTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHtHb29nbGVNYXB9IGZyb20gJy4vZ29vZ2xlLW1hcC9nb29nbGUtbWFwJztcbmltcG9ydCB7TWFwSW5mb1dpbmRvd30gZnJvbSAnLi9tYXAtaW5mby13aW5kb3cvbWFwLWluZm8td2luZG93JztcbmltcG9ydCB7TWFwTWFya2VyfSBmcm9tICcuL21hcC1tYXJrZXIvbWFwLW1hcmtlcic7XG5pbXBvcnQge01hcFBvbHlsaW5lfSBmcm9tICcuL21hcC1wb2x5bGluZS9tYXAtcG9seWxpbmUnO1xuXG5jb25zdCBDT01QT05FTlRTID0gW1xuICBHb29nbGVNYXAsXG4gIE1hcEluZm9XaW5kb3csXG4gIE1hcE1hcmtlcixcbiAgTWFwUG9seWxpbmUsXG5dO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IENPTVBPTkVOVFMsXG4gIGV4cG9ydHM6IENPTVBPTkVOVFMsXG59KVxuZXhwb3J0IGNsYXNzIEdvb2dsZU1hcHNNb2R1bGUge1xufVxuIl19

@@ -8,9 +8,10 @@ /**

*/
import { __assign, __read, __values } from "tslib";
import { __assign, __read } from "tslib";
// Workaround for: https://github.com/bazelbuild/rules_nodejs/issues/1265
/// <reference types="googlemaps" />
import { Directive, ElementRef, EventEmitter, Input, Output, } from '@angular/core';
import { BehaviorSubject, combineLatest, Subject } from 'rxjs';
import { Directive, ElementRef, Input, Output, } from '@angular/core';
import { BehaviorSubject, combineLatest, Observable, Subject } from 'rxjs';
import { map, takeUntil } from 'rxjs/operators';
import { GoogleMap } from '../google-map/google-map';
import { MapEventManager } from '../map-event-manager';
/**

@@ -24,2 +25,6 @@ * Angular component that renders a Google Maps info window via the Google Maps JavaScript API.

this._elementRef = _elementRef;
this._eventManager = new MapEventManager();
this._options = new BehaviorSubject({});
this._position = new BehaviorSubject(undefined);
this._destroy = new Subject();
/**

@@ -29,3 +34,3 @@ * See

*/
this.closeclick = new EventEmitter();
this.closeclick = this._eventManager.getLazyEmitter('closeclick');
/**

@@ -36,3 +41,3 @@ * See

*/
this.contentChanged = new EventEmitter();
this.contentChanged = this._eventManager.getLazyEmitter('content_changed');
/**

@@ -42,3 +47,3 @@ * See

*/
this.domready = new EventEmitter();
this.domready = this._eventManager.getLazyEmitter('domready');
/**

@@ -49,3 +54,3 @@ * See

*/
this.positionChanged = new EventEmitter();
this.positionChanged = this._eventManager.getLazyEmitter('position_changed');
/**

@@ -56,7 +61,3 @@ * See

*/
this.zindexChanged = new EventEmitter();
this._options = new BehaviorSubject({});
this._position = new BehaviorSubject(undefined);
this._listeners = [];
this._destroy = new Subject();
this.zindexChanged = this._eventManager.getLazyEmitter('zindex_changed');
}

@@ -85,3 +86,3 @@ Object.defineProperty(MapInfoWindow.prototype, "options", {

_this._infoWindow = new google.maps.InfoWindow(options);
_this._initializeEventHandlers();
_this._eventManager.setTarget(_this._infoWindow);
}

@@ -91,18 +92,5 @@ });

MapInfoWindow.prototype.ngOnDestroy = function () {
var e_1, _a;
this._eventManager.destroy();
this._destroy.next();
this._destroy.complete();
try {
for (var _b = __values(this._listeners), _c = _b.next(); !_c.done; _c = _b.next()) {
var listener = _c.value;
listener.remove();
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_1) throw e_1.error; }
}
this.close();

@@ -159,39 +147,2 @@ };

};
MapInfoWindow.prototype._initializeEventHandlers = function () {
var _this = this;
// Ensure that we don't leak if called multiple times.
this._clearListeners();
var eventHandlers = new Map([
['closeclick', this.closeclick],
['content_changed', this.contentChanged],
['domready', this.domready],
['position_changed', this.positionChanged],
['zindex_changed', this.zindexChanged],
]);
eventHandlers.forEach(function (eventHandler, name) {
if (eventHandler.observers.length > 0) {
_this._listeners.push(_this._infoWindow.addListener(name, function () {
eventHandler.emit();
}));
}
});
};
/** Clears all currently-registered event listeners. */
MapInfoWindow.prototype._clearListeners = function () {
var e_2, _a;
try {
for (var _b = __values(this._listeners), _c = _b.next(); !_c.done; _c = _b.next()) {
var listener = _c.value;
listener.remove();
}
}
catch (e_2_1) { e_2 = { error: e_2_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_2) throw e_2.error; }
}
this._listeners = [];
};
MapInfoWindow.decorators = [

@@ -220,2 +171,2 @@ { type: Directive, args: [{

export { MapInfoWindow };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-info-window.js","sourceRoot":"","sources":["../../../../../../../../../src/google-maps/map-info-window/map-info-window.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;AAEH,yEAAyE;AACzE,oCAAoC;AAEpC,OAAO,EACL,SAAS,EACT,UAAU,EACV,YAAY,EACZ,KAAK,EAGL,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,eAAe,EAAE,aAAa,EAAc,OAAO,EAAC,MAAM,MAAM,CAAC;AACzE,OAAO,EAAC,GAAG,EAAE,SAAS,EAAC,MAAM,gBAAgB,CAAC;AAE9C,OAAO,EAAC,SAAS,EAAC,MAAM,0BAA0B,CAAC;AAGnD;;;GAGG;AACH;IA0DE,uBAA6B,UAAqB,EAC9B,WAAoC;QAD3B,eAAU,GAAV,UAAU,CAAW;QAC9B,gBAAW,GAAX,WAAW,CAAyB;QA5CxD;;;WAGG;QACO,eAAU,GAAG,IAAI,YAAY,EAAQ,CAAC;QAEhD;;;;WAIG;QACO,mBAAc,GAAG,IAAI,YAAY,EAAQ,CAAC;QAEpD;;;WAGG;QACO,aAAQ,GAAG,IAAI,YAAY,EAAQ,CAAC;QAE9C;;;;WAIG;QACO,oBAAe,GAAG,IAAI,YAAY,EAAQ,CAAC;QAErD;;;;WAIG;QACO,kBAAa,GAAG,IAAI,YAAY,EAAQ,CAAC;QAElC,aAAQ,GAAG,IAAI,eAAe,CAAgC,EAAE,CAAC,CAAC;QAClE,cAAS,GACtB,IAAI,eAAe,CAAyD,SAAS,CAAC,CAAC;QAEnF,eAAU,GAAoC,EAAE,CAAC;QAExC,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;IAKW,CAAC;IAtD5D,sBACI,kCAAO;aADX,UACY,OAAsC;YAChD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC;QACpC,CAAC;;;OAAA;IAED,sBACI,mCAAQ;aADZ,UACa,QAAsD;YACjE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAChC,CAAC;;;OAAA;IAgDD,gCAAQ,GAAR;QAAA,iBASC;QARC,IAAI,CAAC,eAAe,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,UAAA,OAAO;YACrE,IAAI,KAAI,CAAC,WAAW,EAAE;gBACpB,KAAI,CAAC,WAAW,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;aACtC;iBAAM;gBACL,KAAI,CAAC,WAAW,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;gBACvD,KAAI,CAAC,wBAAwB,EAAE,CAAC;aACjC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,mCAAW,GAAX;;QACE,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;;YACzB,KAAqB,IAAA,KAAA,SAAA,IAAI,CAAC,UAAU,CAAA,gBAAA,4BAAE;gBAAjC,IAAI,QAAQ,WAAA;gBACf,QAAQ,CAAC,MAAM,EAAE,CAAC;aACnB;;;;;;;;;QACD,IAAI,CAAC,KAAK,EAAE,CAAC;IACf,CAAC;IAED;;OAEG;IACH,6BAAK,GAAL;QACE,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;SAC1B;IACH,CAAC;IAED;;;OAGG;IACH,kCAAU,GAAV;QACE,OAAO,IAAI,CAAC,WAAY,CAAC,UAAU,EAAE,CAAC;IACxC,CAAC;IAED;;;;OAIG;IACH,mCAAW,GAAX;QACE,OAAO,IAAI,CAAC,WAAY,CAAC,WAAW,EAAE,IAAI,IAAI,CAAC;IACjD,CAAC;IAED;;;OAGG;IACH,iCAAS,GAAT;QACE,OAAO,IAAI,CAAC,WAAY,CAAC,SAAS,EAAE,CAAC;IACvC,CAAC;IAED;;;OAGG;IACH,4BAAI,GAAJ,UAAK,MAAkB;QACrB,IAAM,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC;QACnD,IAAI,IAAI,CAAC,UAAU,CAAC,UAAU,EAAE;YAC9B,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,OAAO,GAAG,EAAE,CAAC;YAClD,IAAI,CAAC,WAAY,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;SAC5D;IACH,CAAC;IAEO,uCAAe,GAAvB;QAAA,iBASC;QARC,OAAO,aAAa,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,UAAC,EAAmB;gBAAnB,kBAAmB,EAAlB,eAAO,EAAE,gBAAQ;YAChF,IAAM,eAAe,yBAChB,OAAO,KACV,QAAQ,EAAE,QAAQ,IAAI,OAAO,CAAC,QAAQ,EACtC,OAAO,EAAE,KAAI,CAAC,WAAW,CAAC,aAAa,GACxC,CAAC;YACF,OAAO,eAAe,CAAC;QACzB,CAAC,CAAC,CAAC,CAAC;IACN,CAAC;IAEO,gDAAwB,GAAhC;QAAA,iBAkBC;QAjBC,sDAAsD;QACtD,IAAI,CAAC,eAAe,EAAE,CAAC;QAEvB,IAAM,aAAa,GAAG,IAAI,GAAG,CAA6B;YACxD,CAAC,YAAY,EAAE,IAAI,CAAC,UAAU,CAAC;YAC/B,CAAC,iBAAiB,EAAE,IAAI,CAAC,cAAc,CAAC;YACxC,CAAC,UAAU,EAAE,IAAI,CAAC,QAAQ,CAAC;YAC3B,CAAC,kBAAkB,EAAE,IAAI,CAAC,eAAe,CAAC;YAC1C,CAAC,gBAAgB,EAAE,IAAI,CAAC,aAAa,CAAC;SACvC,CAAC,CAAC;QACH,aAAa,CAAC,OAAO,CAAC,UAAC,YAAgC,EAAE,IAAY;YACnE,IAAI,YAAY,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE;gBACrC,KAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAI,CAAC,WAAY,CAAC,WAAW,CAAC,IAAI,EAAE;oBACvD,YAAY,CAAC,IAAI,EAAE,CAAC;gBACtB,CAAC,CAAC,CAAC,CAAC;aACL;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,uDAAuD;IAC/C,uCAAe,GAAvB;;;YACE,KAAqB,IAAA,KAAA,SAAA,IAAI,CAAC,UAAU,CAAA,gBAAA,4BAAE;gBAAjC,IAAI,QAAQ,WAAA;gBACf,QAAQ,CAAC,MAAM,EAAE,CAAC;aACnB;;;;;;;;;QAED,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;IACvB,CAAC;;gBArKF,SAAS,SAAC;oBACT,QAAQ,EAAE,iBAAiB;oBAC3B,IAAI,EAAE,EAAC,OAAO,EAAE,eAAe,EAAC;iBACjC;;;;gBAVO,SAAS;gBAVf,UAAU;;;0BAsBT,KAAK;2BAKL,KAAK;6BASL,MAAM;iCAON,MAAM;2BAMN,MAAM;kCAON,MAAM;gCAON,MAAM;;IAwHT,oBAAC;CAAA,AAtKD,IAsKC;SAlKY,aAAa","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n// Workaround for: https://github.com/bazelbuild/rules_nodejs/issues/1265\n/// <reference types=\"googlemaps\" />\n\nimport {\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n} from '@angular/core';\nimport {BehaviorSubject, combineLatest, Observable, Subject} from 'rxjs';\nimport {map, takeUntil} from 'rxjs/operators';\n\nimport {GoogleMap} from '../google-map/google-map';\nimport {MapMarker} from '../map-marker/map-marker';\n\n/**\n * Angular component that renders a Google Maps info window via the Google Maps JavaScript API.\n * @see developers.google.com/maps/documentation/javascript/reference/info-window\n */\n@Directive({\n  selector: 'map-info-window',\n  host: {'style': 'display: none'},\n})\nexport class MapInfoWindow implements OnInit, OnDestroy {\n  @Input()\n  set options(options: google.maps.InfoWindowOptions) {\n    this._options.next(options || {});\n  }\n\n  @Input()\n  set position(position: google.maps.LatLngLiteral|google.maps.LatLng) {\n    this._position.next(position);\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.closeclick\n   */\n  @Output() closeclick = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window\n   * #InfoWindow.content_changed\n   */\n  @Output() contentChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.domready\n   */\n  @Output() domready = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window\n   * #InfoWindow.position_changed\n   */\n  @Output() positionChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window\n   * #InfoWindow.zindex_changed\n   */\n  @Output() zindexChanged = new EventEmitter<void>();\n\n  private readonly _options = new BehaviorSubject<google.maps.InfoWindowOptions>({});\n  private readonly _position =\n      new BehaviorSubject<google.maps.LatLngLiteral|google.maps.LatLng|undefined>(undefined);\n\n  private _listeners: google.maps.MapsEventListener[] = [];\n\n  private readonly _destroy = new Subject<void>();\n\n  private _infoWindow?: google.maps.InfoWindow;\n\n  constructor(private readonly _googleMap: GoogleMap,\n              private _elementRef: ElementRef<HTMLElement>) {}\n\n  ngOnInit() {\n    this._combineOptions().pipe(takeUntil(this._destroy)).subscribe(options => {\n      if (this._infoWindow) {\n        this._infoWindow.setOptions(options);\n      } else {\n        this._infoWindow = new google.maps.InfoWindow(options);\n        this._initializeEventHandlers();\n      }\n    });\n  }\n\n  ngOnDestroy() {\n    this._destroy.next();\n    this._destroy.complete();\n    for (let listener of this._listeners) {\n      listener.remove();\n    }\n    this.close();\n  }\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.close\n   */\n  close() {\n    if (this._infoWindow) {\n      this._infoWindow.close();\n    }\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.getContent\n   */\n  getContent(): string|Node {\n    return this._infoWindow!.getContent();\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window\n   * #InfoWindow.getPosition\n   */\n  getPosition(): google.maps.LatLng|null {\n    return this._infoWindow!.getPosition() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.getZIndex\n   */\n  getZIndex(): number {\n    return this._infoWindow!.getZIndex();\n  }\n\n  /**\n   * Opens the MapInfoWindow using the provided MapMarker as the anchor. If the anchor is not set,\n   * then the position property of the options input is used instead.\n   */\n  open(anchor?: MapMarker) {\n    const marker = anchor ? anchor._marker : undefined;\n    if (this._googleMap._googleMap) {\n      this._elementRef.nativeElement.style.display = '';\n      this._infoWindow!.open(this._googleMap._googleMap, marker);\n    }\n  }\n\n  private _combineOptions(): Observable<google.maps.InfoWindowOptions> {\n    return combineLatest([this._options, this._position]).pipe(map(([options, position]) => {\n      const combinedOptions: google.maps.InfoWindowOptions = {\n        ...options,\n        position: position || options.position,\n        content: this._elementRef.nativeElement,\n      };\n      return combinedOptions;\n    }));\n  }\n\n  private _initializeEventHandlers() {\n    // Ensure that we don't leak if called multiple times.\n    this._clearListeners();\n\n    const eventHandlers = new Map<string, EventEmitter<void>>([\n      ['closeclick', this.closeclick],\n      ['content_changed', this.contentChanged],\n      ['domready', this.domready],\n      ['position_changed', this.positionChanged],\n      ['zindex_changed', this.zindexChanged],\n    ]);\n    eventHandlers.forEach((eventHandler: EventEmitter<void>, name: string) => {\n      if (eventHandler.observers.length > 0) {\n        this._listeners.push(this._infoWindow!.addListener(name, () => {\n          eventHandler.emit();\n        }));\n      }\n    });\n  }\n\n  /** Clears all currently-registered event listeners. */\n  private _clearListeners() {\n    for (let listener of this._listeners) {\n      listener.remove();\n    }\n\n    this._listeners = [];\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-info-window.js","sourceRoot":"","sources":["../../../../../../../../../src/google-maps/map-info-window/map-info-window.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n// Workaround for: https://github.com/bazelbuild/rules_nodejs/issues/1265\n/// <reference types=\"googlemaps\" />\n\nimport {\n  Directive,\n  ElementRef,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n} from '@angular/core';\nimport {BehaviorSubject, combineLatest, Observable, Subject} from 'rxjs';\nimport {map, takeUntil} from 'rxjs/operators';\n\nimport {GoogleMap} from '../google-map/google-map';\nimport {MapMarker} from '../map-marker/map-marker';\nimport {MapEventManager} from '../map-event-manager';\n\n/**\n * Angular component that renders a Google Maps info window via the Google Maps JavaScript API.\n * @see developers.google.com/maps/documentation/javascript/reference/info-window\n */\n@Directive({\n  selector: 'map-info-window',\n  host: {'style': 'display: none'},\n})\nexport class MapInfoWindow implements OnInit, OnDestroy {\n  private _eventManager = new MapEventManager();\n  private readonly _options = new BehaviorSubject<google.maps.InfoWindowOptions>({});\n  private readonly _position =\n      new BehaviorSubject<google.maps.LatLngLiteral|google.maps.LatLng|undefined>(undefined);\n  private readonly _destroy = new Subject<void>();\n  private _infoWindow?: google.maps.InfoWindow;\n\n  @Input()\n  set options(options: google.maps.InfoWindowOptions) {\n    this._options.next(options || {});\n  }\n\n  @Input()\n  set position(position: google.maps.LatLngLiteral|google.maps.LatLng) {\n    this._position.next(position);\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.closeclick\n   */\n  @Output() closeclick: Observable<void> = this._eventManager.getLazyEmitter<void>('closeclick');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window\n   * #InfoWindow.content_changed\n   */\n  @Output()\n  contentChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('content_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.domready\n   */\n  @Output() domready: Observable<void> = this._eventManager.getLazyEmitter<void>('domready');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window\n   * #InfoWindow.position_changed\n   */\n  @Output()\n  positionChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('position_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window\n   * #InfoWindow.zindex_changed\n   */\n  @Output()\n  zindexChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('zindex_changed');\n\n  constructor(private readonly _googleMap: GoogleMap,\n              private _elementRef: ElementRef<HTMLElement>) {}\n\n  ngOnInit() {\n    this._combineOptions().pipe(takeUntil(this._destroy)).subscribe(options => {\n      if (this._infoWindow) {\n        this._infoWindow.setOptions(options);\n      } else {\n        this._infoWindow = new google.maps.InfoWindow(options);\n        this._eventManager.setTarget(this._infoWindow);\n      }\n    });\n  }\n\n  ngOnDestroy() {\n    this._eventManager.destroy();\n    this._destroy.next();\n    this._destroy.complete();\n    this.close();\n  }\n\n  /**\n   * See developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.close\n   */\n  close() {\n    if (this._infoWindow) {\n      this._infoWindow.close();\n    }\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.getContent\n   */\n  getContent(): string|Node {\n    return this._infoWindow!.getContent();\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window\n   * #InfoWindow.getPosition\n   */\n  getPosition(): google.maps.LatLng|null {\n    return this._infoWindow!.getPosition() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.getZIndex\n   */\n  getZIndex(): number {\n    return this._infoWindow!.getZIndex();\n  }\n\n  /**\n   * Opens the MapInfoWindow using the provided MapMarker as the anchor. If the anchor is not set,\n   * then the position property of the options input is used instead.\n   */\n  open(anchor?: MapMarker) {\n    const marker = anchor ? anchor._marker : undefined;\n    if (this._googleMap._googleMap) {\n      this._elementRef.nativeElement.style.display = '';\n      this._infoWindow!.open(this._googleMap._googleMap, marker);\n    }\n  }\n\n  private _combineOptions(): Observable<google.maps.InfoWindowOptions> {\n    return combineLatest([this._options, this._position]).pipe(map(([options, position]) => {\n      const combinedOptions: google.maps.InfoWindowOptions = {\n        ...options,\n        position: position || options.position,\n        content: this._elementRef.nativeElement,\n      };\n      return combinedOptions;\n    }));\n  }\n}\n"]}

@@ -8,9 +8,10 @@ /**

*/
import { __assign, __read, __values } from "tslib";
import { __assign, __read } from "tslib";
// Workaround for: https://github.com/bazelbuild/rules_nodejs/issues/1265
/// <reference types="googlemaps" />
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core';
import { BehaviorSubject, combineLatest, Subject } from 'rxjs';
import { ChangeDetectionStrategy, Component, Input, Output, ViewEncapsulation } from '@angular/core';
import { BehaviorSubject, combineLatest, Observable, Subject } from 'rxjs';
import { map, take, takeUntil } from 'rxjs/operators';
import { GoogleMap } from '../google-map/google-map';
import { MapEventManager } from '../map-event-manager';
/**

@@ -30,2 +31,9 @@ * Default options for the Google Maps marker component. Displays a marker

this._googleMap = _googleMap;
this._eventManager = new MapEventManager();
this._options = new BehaviorSubject(DEFAULT_MARKER_OPTIONS);
this._title = new BehaviorSubject(undefined);
this._position = new BehaviorSubject(undefined);
this._label = new BehaviorSubject(undefined);
this._clickable = new BehaviorSubject(undefined);
this._destroy = new Subject();
/**

@@ -35,3 +43,3 @@ * See

*/
this.animationChanged = new EventEmitter();
this.animationChanged = this._eventManager.getLazyEmitter('animation_changed');
/**

@@ -41,3 +49,3 @@ * See

*/
this.mapClick = new EventEmitter();
this.mapClick = this._eventManager.getLazyEmitter('click');
/**

@@ -47,3 +55,3 @@ * See

*/
this.clickableChanged = new EventEmitter();
this.clickableChanged = this._eventManager.getLazyEmitter('clickable_changed');
/**

@@ -53,3 +61,3 @@ * See

*/
this.cursorChanged = new EventEmitter();
this.cursorChanged = this._eventManager.getLazyEmitter('cursor_changed');
/**

@@ -59,3 +67,3 @@ * See

*/
this.mapDblclick = new EventEmitter();
this.mapDblclick = this._eventManager.getLazyEmitter('dblclick');
/**

@@ -65,3 +73,3 @@ * See

*/
this.mapDrag = new EventEmitter();
this.mapDrag = this._eventManager.getLazyEmitter('drag');
/**

@@ -71,3 +79,3 @@ * See

*/
this.mapDragend = new EventEmitter();
this.mapDragend = this._eventManager.getLazyEmitter('dragend');
/**

@@ -77,3 +85,3 @@ * See

*/
this.draggableChanged = new EventEmitter();
this.draggableChanged = this._eventManager.getLazyEmitter('draggable_changed');
/**

@@ -83,3 +91,3 @@ * See

*/
this.mapDragstart = new EventEmitter();
this.mapDragstart = this._eventManager.getLazyEmitter('dragstart');
/**

@@ -89,3 +97,3 @@ * See

*/
this.flatChanged = new EventEmitter();
this.flatChanged = this._eventManager.getLazyEmitter('flat_changed');
/**

@@ -95,3 +103,3 @@ * See

*/
this.iconChanged = new EventEmitter();
this.iconChanged = this._eventManager.getLazyEmitter('icon_changed');
/**

@@ -101,3 +109,3 @@ * See

*/
this.mapMousedown = new EventEmitter();
this.mapMousedown = this._eventManager.getLazyEmitter('mousedown');
/**

@@ -107,3 +115,3 @@ * See

*/
this.mapMouseout = new EventEmitter();
this.mapMouseout = this._eventManager.getLazyEmitter('mouseout');
/**

@@ -113,3 +121,3 @@ * See

*/
this.mapMouseover = new EventEmitter();
this.mapMouseover = this._eventManager.getLazyEmitter('mouseover');
/**

@@ -119,3 +127,3 @@ * See

*/
this.mapMouseup = new EventEmitter();
this.mapMouseup = this._eventManager.getLazyEmitter('mouseup');
/**

@@ -125,3 +133,3 @@ * See

*/
this.positionChanged = new EventEmitter();
this.positionChanged = this._eventManager.getLazyEmitter('position_changed');
/**

@@ -131,3 +139,3 @@ * See

*/
this.mapRightclick = new EventEmitter();
this.mapRightclick = this._eventManager.getLazyEmitter('rightclick');
/**

@@ -137,3 +145,3 @@ * See

*/
this.shapeChanged = new EventEmitter();
this.shapeChanged = this._eventManager.getLazyEmitter('shape_changed');
/**

@@ -143,3 +151,3 @@ * See

*/
this.titleChanged = new EventEmitter();
this.titleChanged = this._eventManager.getLazyEmitter('title_changed');
/**

@@ -149,3 +157,3 @@ * See

*/
this.visibleChanged = new EventEmitter();
this.visibleChanged = this._eventManager.getLazyEmitter('visible_changed');
/**

@@ -155,10 +163,3 @@ * See

*/
this.zindexChanged = new EventEmitter();
this._options = new BehaviorSubject(DEFAULT_MARKER_OPTIONS);
this._title = new BehaviorSubject(undefined);
this._position = new BehaviorSubject(undefined);
this._label = new BehaviorSubject(undefined);
this._clickable = new BehaviorSubject(undefined);
this._destroy = new Subject();
this._listeners = [];
this.zindexChanged = this._eventManager.getLazyEmitter('zindex_changed');
}

@@ -206,3 +207,3 @@ Object.defineProperty(MapMarker.prototype, "options", {

_this._marker.setMap(_this._googleMap._googleMap);
_this._initializeEventHandlers();
_this._eventManager.setTarget(_this._marker);
});

@@ -218,3 +219,3 @@ this._watchForOptionsChanges();

this._destroy.complete();
this._clearListeners();
this._eventManager.destroy();
if (this._marker) {

@@ -357,64 +358,2 @@ this._marker.setMap(null);

};
MapMarker.prototype._initializeEventHandlers = function () {
var _this = this;
// Ensure that we don't leak if called multiple times.
this._clearListeners();
var eventHandlers = new Map([
['animation_changed', this.animationChanged],
['clickable_changed', this.clickableChanged],
['cursor_changed', this.cursorChanged],
['draggable_changed', this.draggableChanged],
['flat_changed', this.flatChanged],
['icon_changed', this.iconChanged],
['position_changed', this.positionChanged],
['shape_changed', this.shapeChanged],
['title_changed', this.titleChanged],
['visible_changed', this.visibleChanged],
['zindex_changed', this.zindexChanged],
]);
var mouseEventHandlers = new Map([
['click', this.mapClick],
['dblclick', this.mapDblclick],
['drag', this.mapDrag],
['dragend', this.mapDragend],
['dragstart', this.mapDragstart],
['mousedown', this.mapMousedown],
['mouseout', this.mapMouseout],
['mouseover', this.mapMouseover],
['mouseup', this.mapMouseup],
['rightclick', this.mapRightclick],
]);
eventHandlers.forEach(function (eventHandler, name) {
if (eventHandler.observers.length > 0) {
_this._listeners.push(_this._marker.addListener(name, function () {
eventHandler.emit();
}));
}
});
mouseEventHandlers.forEach(function (eventHandler, name) {
if (eventHandler.observers.length > 0) {
_this._listeners.push(_this._marker.addListener(name, function (event) {
eventHandler.emit(event);
}));
}
});
};
/** Clears all currently-registered event listeners. */
MapMarker.prototype._clearListeners = function () {
var e_1, _a;
try {
for (var _b = __values(this._listeners), _c = _b.next(); !_c.done; _c = _b.next()) {
var listener = _c.value;
listener.remove();
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_1) throw e_1.error; }
}
this._listeners = [];
};
MapMarker.decorators = [

@@ -463,2 +402,2 @@ { type: Component, args: [{

export { MapMarker };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-marker.js","sourceRoot":"","sources":["../../../../../../../../../src/google-maps/map-marker/map-marker.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n// Workaround for: https://github.com/bazelbuild/rules_nodejs/issues/1265\n/// <reference types=\"googlemaps\" />\n\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewEncapsulation\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';\n\n/**\n * Default options for the Google Maps marker component. Displays a marker\n * at the Googleplex.\n */\nexport const DEFAULT_MARKER_OPTIONS = {\n  position: {lat: 37.421995, lng: -122.084092},\n};\n\n/**\n * Angular component that renders a Google Maps marker via the Google Maps JavaScript API.\n * @see developers.google.com/maps/documentation/javascript/reference/marker\n */\n@Component({\n  selector: 'map-marker',\n  template: '<ng-content></ng-content>',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class MapMarker implements OnInit, OnDestroy {\n  @Input()\n  set options(options: google.maps.MarkerOptions) {\n    this._options.next(options || DEFAULT_MARKER_OPTIONS);\n  }\n\n  @Input()\n  set title(title: string) {\n    this._title.next(title);\n  }\n\n  @Input()\n  set position(position: google.maps.LatLngLiteral|google.maps.LatLng) {\n    this._position.next(position);\n  }\n\n  @Input()\n  set label(label: string|google.maps.MarkerLabel) {\n    this._label.next(label);\n  }\n\n  @Input()\n  set clickable(clickable: boolean) {\n    this._clickable.next(clickable);\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.animation_changed\n   */\n  @Output() animationChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.click\n   */\n  @Output() mapClick = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.clickable_changed\n   */\n  @Output() clickableChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.cursor_changed\n   */\n  @Output() cursorChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.dblclick\n   */\n  @Output() mapDblclick = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.drag\n   */\n  @Output() mapDrag = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.dragend\n   */\n  @Output() mapDragend = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.draggable_changed\n   */\n  @Output() draggableChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.dragstart\n   */\n  @Output() mapDragstart = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.flat_changed\n   */\n  @Output() flatChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.icon_changed\n   */\n  @Output() iconChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.mousedown\n   */\n  @Output() mapMousedown = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.mouseout\n   */\n  @Output() mapMouseout = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.mouseover\n   */\n  @Output() mapMouseover = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.mouseup\n   */\n  @Output() mapMouseup = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.position_changed\n   */\n  @Output() positionChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.rightclick\n   */\n  @Output() mapRightclick = new EventEmitter<google.maps.MouseEvent>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.shape_changed\n   */\n  @Output() shapeChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.title_changed\n   */\n  @Output() titleChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.visible_changed\n   */\n  @Output() visibleChanged = new EventEmitter<void>();\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.zindex_changed\n   */\n  @Output() zindexChanged = new EventEmitter<void>();\n\n  private readonly _options =\n      new BehaviorSubject<google.maps.MarkerOptions>(DEFAULT_MARKER_OPTIONS);\n  private readonly _title = new BehaviorSubject<string|undefined>(undefined);\n  private readonly _position =\n      new BehaviorSubject<google.maps.LatLngLiteral|google.maps.LatLng|undefined>(undefined);\n  private readonly _label =\n      new BehaviorSubject<string|google.maps.MarkerLabel|undefined>(undefined);\n  private readonly _clickable = new BehaviorSubject<boolean|undefined>(undefined);\n\n  private readonly _destroy = new Subject<void>();\n\n  private _listeners: google.maps.MapsEventListener[] = [];\n\n  _marker?: google.maps.Marker;\n\n  constructor(private readonly _googleMap: GoogleMap) {}\n\n  ngOnInit() {\n    const combinedOptionsChanges = this._combineOptions();\n\n    combinedOptionsChanges.pipe(take(1)).subscribe(options => {\n      this._marker = new google.maps.Marker(options);\n      this._marker.setMap(this._googleMap._googleMap);\n      this._initializeEventHandlers();\n    });\n\n    this._watchForOptionsChanges();\n    this._watchForTitleChanges();\n    this._watchForPositionChanges();\n    this._watchForLabelChanges();\n    this._watchForClickableChanges();\n  }\n\n  ngOnDestroy() {\n    this._destroy.next();\n    this._destroy.complete();\n    this._clearListeners();\n    if (this._marker) {\n      this._marker.setMap(null);\n    }\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getAnimation\n   */\n  getAnimation(): google.maps.Animation|null {\n    return this._marker!.getAnimation() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getClickable\n   */\n  getClickable(): boolean {\n    return this._marker!.getClickable();\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getCursor\n   */\n  getCursor(): string|null {\n    return this._marker!.getCursor() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getDraggable\n   */\n  getDraggable(): boolean {\n    return !!this._marker!.getDraggable();\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getIcon\n   */\n  getIcon(): string|google.maps.Icon|google.maps.Symbol|null {\n    return this._marker!.getIcon() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getLabel\n   */\n  getLabel(): google.maps.MarkerLabel|null {\n    return this._marker!.getLabel() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getOpacity\n   */\n  getOpacity(): number|null {\n    return this._marker!.getOpacity() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getPosition\n   */\n  getPosition(): google.maps.LatLng|null {\n    return this._marker!.getPosition() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getShape\n   */\n  getShape(): google.maps.MarkerShape|null {\n    return this._marker!.getShape() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getTitle\n   */\n  getTitle(): string|null {\n    return this._marker!.getTitle() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getVisible\n   */\n  getVisible(): boolean {\n    return this._marker!.getVisible();\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getZIndex\n   */\n  getZIndex(): number|null {\n    return this._marker!.getZIndex() || null;\n  }\n\n  private _combineOptions(): Observable<google.maps.MarkerOptions> {\n    return combineLatest([this._options, this._title, this._position, this._label, this._clickable])\n        .pipe(map(([options, title, position, label, clickable]) => {\n          const combinedOptions: google.maps.MarkerOptions = {\n            ...options,\n            title: title || options.title,\n            position: position || options.position,\n            label: label || options.label,\n            clickable: clickable !== undefined ? clickable : options.clickable,\n            map: this._googleMap._googleMap || null,\n          };\n          return combinedOptions;\n        }));\n  }\n\n  private _watchForOptionsChanges() {\n    this._options.pipe(takeUntil(this._destroy)).subscribe(options => {\n      if (this._marker) {\n        this._marker.setOptions(options);\n      }\n    });\n  }\n\n  private _watchForTitleChanges() {\n    this._title.pipe(takeUntil(this._destroy)).subscribe(title => {\n      if (this._marker && title !== undefined) {\n        this._marker.setTitle(title);\n      }\n    });\n  }\n\n  private _watchForPositionChanges() {\n    this._position.pipe(takeUntil(this._destroy)).subscribe(position => {\n      if (this._marker && position) {\n        this._marker.setPosition(position);\n      }\n    });\n  }\n\n  private _watchForLabelChanges() {\n    this._label.pipe(takeUntil(this._destroy)).subscribe(label => {\n      if (this._marker && label !== undefined) {\n        this._marker.setLabel(label);\n      }\n    });\n  }\n\n  private _watchForClickableChanges() {\n    this._clickable.pipe(takeUntil(this._destroy)).subscribe(clickable => {\n      if (this._marker && clickable !== undefined) {\n        this._marker.setClickable(clickable);\n      }\n    });\n  }\n\n  private _initializeEventHandlers() {\n    // Ensure that we don't leak if called multiple times.\n    this._clearListeners();\n\n    const eventHandlers = new Map<string, EventEmitter<void>>([\n      ['animation_changed', this.animationChanged],\n      ['clickable_changed', this.clickableChanged],\n      ['cursor_changed', this.cursorChanged],\n      ['draggable_changed', this.draggableChanged],\n      ['flat_changed', this.flatChanged],\n      ['icon_changed', this.iconChanged],\n      ['position_changed', this.positionChanged],\n      ['shape_changed', this.shapeChanged],\n      ['title_changed', this.titleChanged],\n      ['visible_changed', this.visibleChanged],\n      ['zindex_changed', this.zindexChanged],\n    ]);\n    const mouseEventHandlers = new Map<string, EventEmitter<google.maps.MouseEvent>>([\n      ['click', this.mapClick],\n      ['dblclick', this.mapDblclick],\n      ['drag', this.mapDrag],\n      ['dragend', this.mapDragend],\n      ['dragstart', this.mapDragstart],\n      ['mousedown', this.mapMousedown],\n      ['mouseout', this.mapMouseout],\n      ['mouseover', this.mapMouseover],\n      ['mouseup', this.mapMouseup],\n      ['rightclick', this.mapRightclick],\n    ]);\n\n    eventHandlers.forEach((eventHandler: EventEmitter<void>, name: string) => {\n      if (eventHandler.observers.length > 0) {\n        this._listeners.push(this._marker!.addListener(name, () => {\n          eventHandler.emit();\n        }));\n      }\n    });\n    mouseEventHandlers.forEach(\n        (eventHandler: EventEmitter<google.maps.MouseEvent>, name: string) => {\n          if (eventHandler.observers.length > 0) {\n            this._listeners.push(\n                this._marker!.addListener(name, (event: google.maps.MouseEvent) => {\n                  eventHandler.emit(event);\n                }));\n          }\n        });\n  }\n\n  /** Clears all currently-registered event listeners. */\n  private _clearListeners() {\n    for (let listener of this._listeners) {\n      listener.remove();\n    }\n\n    this._listeners = [];\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-marker.js","sourceRoot":"","sources":["../../../../../../../../../src/google-maps/map-marker/map-marker.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n// Workaround for: https://github.com/bazelbuild/rules_nodejs/issues/1265\n/// <reference types=\"googlemaps\" />\n\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewEncapsulation\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 * Default options for the Google Maps marker component. Displays a marker\n * at the Googleplex.\n */\nexport const DEFAULT_MARKER_OPTIONS = {\n  position: {lat: 37.421995, lng: -122.084092},\n};\n\n/**\n * Angular component that renders a Google Maps marker via the Google Maps JavaScript API.\n * @see developers.google.com/maps/documentation/javascript/reference/marker\n */\n@Component({\n  selector: 'map-marker',\n  template: '<ng-content></ng-content>',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class MapMarker implements OnInit, OnDestroy {\n  private _eventManager = new MapEventManager();\n  private readonly _options =\n      new BehaviorSubject<google.maps.MarkerOptions>(DEFAULT_MARKER_OPTIONS);\n  private readonly _title = new BehaviorSubject<string|undefined>(undefined);\n  private readonly _position =\n      new BehaviorSubject<google.maps.LatLngLiteral|google.maps.LatLng|undefined>(undefined);\n  private readonly _label =\n      new BehaviorSubject<string|google.maps.MarkerLabel|undefined>(undefined);\n  private readonly _clickable = new BehaviorSubject<boolean|undefined>(undefined);\n  private readonly _destroy = new Subject<void>();\n\n  @Input()\n  set options(options: google.maps.MarkerOptions) {\n    this._options.next(options || DEFAULT_MARKER_OPTIONS);\n  }\n\n  @Input()\n  set title(title: string) {\n    this._title.next(title);\n  }\n\n  @Input()\n  set position(position: google.maps.LatLngLiteral|google.maps.LatLng) {\n    this._position.next(position);\n  }\n\n  @Input()\n  set label(label: string|google.maps.MarkerLabel) {\n    this._label.next(label);\n  }\n\n  @Input()\n  set clickable(clickable: boolean) {\n    this._clickable.next(clickable);\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.animation_changed\n   */\n  @Output()\n  animationChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('animation_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.click\n   */\n  @Output()\n  mapClick: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('click');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.clickable_changed\n   */\n  @Output()\n  clickableChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('clickable_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.cursor_changed\n   */\n  @Output()\n  cursorChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('cursor_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.dblclick\n   */\n  @Output()\n  mapDblclick: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('dblclick');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.drag\n   */\n  @Output()\n  mapDrag: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('drag');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.dragend\n   */\n  @Output()\n  mapDragend: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('dragend');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.draggable_changed\n   */\n  @Output()\n  draggableChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('draggable_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.dragstart\n   */\n  @Output()\n  mapDragstart: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('dragstart');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.flat_changed\n   */\n  @Output() flatChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('flat_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.icon_changed\n   */\n  @Output() iconChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('icon_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.mousedown\n   */\n  @Output()\n  mapMousedown: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('mousedown');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.mouseout\n   */\n  @Output()\n  mapMouseout: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('mouseout');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.mouseover\n   */\n  @Output()\n  mapMouseover: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('mouseover');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.mouseup\n   */\n  @Output()\n  mapMouseup: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('mouseup');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.position_changed\n   */\n  @Output()\n  positionChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('position_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.rightclick\n   */\n  @Output()\n  mapRightclick: Observable<google.maps.MouseEvent> =\n      this._eventManager.getLazyEmitter<google.maps.MouseEvent>('rightclick');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.shape_changed\n   */\n  @Output() shapeChanged:\n  Observable<void> = this._eventManager.getLazyEmitter<void>('shape_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.title_changed\n   */\n  @Output()\n  titleChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('title_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.visible_changed\n   */\n  @Output()\n  visibleChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('visible_changed');\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.zindex_changed\n   */\n  @Output()\n  zindexChanged: Observable<void> = this._eventManager.getLazyEmitter<void>('zindex_changed');\n\n  _marker?: google.maps.Marker;\n\n  constructor(private readonly _googleMap: GoogleMap) {}\n\n  ngOnInit() {\n    const combinedOptionsChanges = this._combineOptions();\n\n    combinedOptionsChanges.pipe(take(1)).subscribe(options => {\n      this._marker = new google.maps.Marker(options);\n      this._marker.setMap(this._googleMap._googleMap);\n      this._eventManager.setTarget(this._marker);\n    });\n\n    this._watchForOptionsChanges();\n    this._watchForTitleChanges();\n    this._watchForPositionChanges();\n    this._watchForLabelChanges();\n    this._watchForClickableChanges();\n  }\n\n  ngOnDestroy() {\n    this._destroy.next();\n    this._destroy.complete();\n    this._eventManager.destroy();\n    if (this._marker) {\n      this._marker.setMap(null);\n    }\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getAnimation\n   */\n  getAnimation(): google.maps.Animation|null {\n    return this._marker!.getAnimation() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getClickable\n   */\n  getClickable(): boolean {\n    return this._marker!.getClickable();\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getCursor\n   */\n  getCursor(): string|null {\n    return this._marker!.getCursor() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getDraggable\n   */\n  getDraggable(): boolean {\n    return !!this._marker!.getDraggable();\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getIcon\n   */\n  getIcon(): string|google.maps.Icon|google.maps.Symbol|null {\n    return this._marker!.getIcon() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getLabel\n   */\n  getLabel(): google.maps.MarkerLabel|null {\n    return this._marker!.getLabel() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getOpacity\n   */\n  getOpacity(): number|null {\n    return this._marker!.getOpacity() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getPosition\n   */\n  getPosition(): google.maps.LatLng|null {\n    return this._marker!.getPosition() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getShape\n   */\n  getShape(): google.maps.MarkerShape|null {\n    return this._marker!.getShape() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getTitle\n   */\n  getTitle(): string|null {\n    return this._marker!.getTitle() || null;\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getVisible\n   */\n  getVisible(): boolean {\n    return this._marker!.getVisible();\n  }\n\n  /**\n   * See\n   * developers.google.com/maps/documentation/javascript/reference/marker#Marker.getZIndex\n   */\n  getZIndex(): number|null {\n    return this._marker!.getZIndex() || null;\n  }\n\n  private _combineOptions(): Observable<google.maps.MarkerOptions> {\n    return combineLatest([this._options, this._title, this._position, this._label, this._clickable])\n        .pipe(map(([options, title, position, label, clickable]) => {\n          const combinedOptions: google.maps.MarkerOptions = {\n            ...options,\n            title: title || options.title,\n            position: position || options.position,\n            label: label || options.label,\n            clickable: clickable !== undefined ? clickable : options.clickable,\n            map: this._googleMap._googleMap || null,\n          };\n          return combinedOptions;\n        }));\n  }\n\n  private _watchForOptionsChanges() {\n    this._options.pipe(takeUntil(this._destroy)).subscribe(options => {\n      if (this._marker) {\n        this._marker.setOptions(options);\n      }\n    });\n  }\n\n  private _watchForTitleChanges() {\n    this._title.pipe(takeUntil(this._destroy)).subscribe(title => {\n      if (this._marker && title !== undefined) {\n        this._marker.setTitle(title);\n      }\n    });\n  }\n\n  private _watchForPositionChanges() {\n    this._position.pipe(takeUntil(this._destroy)).subscribe(position => {\n      if (this._marker && position) {\n        this._marker.setPosition(position);\n      }\n    });\n  }\n\n  private _watchForLabelChanges() {\n    this._label.pipe(takeUntil(this._destroy)).subscribe(label => {\n      if (this._marker && label !== undefined) {\n        this._marker.setLabel(label);\n      }\n    });\n  }\n\n  private _watchForClickableChanges() {\n    this._clickable.pipe(takeUntil(this._destroy)).subscribe(clickable => {\n      if (this._marker && clickable !== undefined) {\n        this._marker.setClickable(clickable);\n      }\n    });\n  }\n}\n"]}

@@ -9,5 +9,6 @@ /**

export { GoogleMap } from './google-map/google-map';
export { MapMarker } from './map-marker/map-marker';
export { GoogleMapsModule } from './google-maps-module';
export { MapInfoWindow } from './map-info-window/map-info-window';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYy9nb29nbGUtbWFwcy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRztBQUVILE9BQU8sRUFBQyxTQUFTLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUNsRCxPQUFPLEVBQUMsU0FBUyxFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFDbEQsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFDdEQsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLG1DQUFtQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmV4cG9ydCB7R29vZ2xlTWFwfSBmcm9tICcuL2dvb2dsZS1tYXAvZ29vZ2xlLW1hcCc7XG5leHBvcnQge01hcE1hcmtlcn0gZnJvbSAnLi9tYXAtbWFya2VyL21hcC1tYXJrZXInO1xuZXhwb3J0IHtHb29nbGVNYXBzTW9kdWxlfSBmcm9tICcuL2dvb2dsZS1tYXBzLW1vZHVsZSc7XG5leHBvcnQge01hcEluZm9XaW5kb3d9IGZyb20gJy4vbWFwLWluZm8td2luZG93L21hcC1pbmZvLXdpbmRvdyc7XG4iXX0=
export { MapMarker } from './map-marker/map-marker';
export { MapPolyline } from './map-polyline/map-polyline';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYy9nb29nbGUtbWFwcy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRztBQUVILE9BQU8sRUFBQyxTQUFTLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUNsRCxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUN0RCxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDaEUsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ2xELE9BQU8sRUFBQyxXQUFXLEVBQUMsTUFBTSw2QkFBNkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5leHBvcnQge0dvb2dsZU1hcH0gZnJvbSAnLi9nb29nbGUtbWFwL2dvb2dsZS1tYXAnO1xuZXhwb3J0IHtHb29nbGVNYXBzTW9kdWxlfSBmcm9tICcuL2dvb2dsZS1tYXBzLW1vZHVsZSc7XG5leHBvcnQge01hcEluZm9XaW5kb3d9IGZyb20gJy4vbWFwLWluZm8td2luZG93L21hcC1pbmZvLXdpbmRvdyc7XG5leHBvcnQge01hcE1hcmtlcn0gZnJvbSAnLi9tYXAtbWFya2VyL21hcC1tYXJrZXInO1xuZXhwb3J0IHtNYXBQb2x5bGluZX0gZnJvbSAnLi9tYXAtcG9seWxpbmUvbWFwLXBvbHlsaW5lJztcbiJdfQ==

@@ -1,4 +0,4 @@

import { EventEmitter, Component, ChangeDetectionStrategy, ViewEncapsulation, ElementRef, Optional, Inject, PLATFORM_ID, Input, Output, Directive, NgModule } from '@angular/core';
import { Component, ChangeDetectionStrategy, ViewEncapsulation, ElementRef, Optional, Inject, PLATFORM_ID, Input, Output, Directive, NgModule } from '@angular/core';
import { isPlatformBrowser } from '@angular/common';
import { BehaviorSubject, Subject, combineLatest } from 'rxjs';
import { Observable, BehaviorSubject, Subject, combineLatest } from 'rxjs';
import { map, take, shareReplay, takeUntil } from 'rxjs/operators';

@@ -8,5 +8,117 @@

* @fileoverview added by tsickle
* Generated from: src/google-maps/map-event-manager.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* Manages event on a Google Maps object, ensuring that events are added only when necessary.
*/
class MapEventManager {
constructor() {
/**
* Pending listeners that were added before the target was set.
*/
this._pending = [];
this._listeners = [];
}
/**
* Clears all currently-registered event listeners.
* @private
* @return {?}
*/
_clearListeners() {
for (let listener of this._listeners) {
listener.remove();
}
this._listeners = [];
}
/**
* Gets an observable that adds an event listener to the map when a consumer subscribes to it.
* @template T
* @param {?} name
* @return {?}
*/
getLazyEmitter(name) {
/** @type {?} */
const observable = new Observable((/**
* @param {?} observer
* @return {?}
*/
observer => {
// If the target hasn't been initialized yet, cache the observer so it can be added later.
if (!this._target) {
this._pending.push({ observable, observer });
return undefined;
}
/** @type {?} */
const listener = this._target.addListener(name, (/**
* @param {?} event
* @return {?}
*/
(event) => observer.next(event)));
this._listeners.push(listener);
return (/**
* @return {?}
*/
() => listener.remove());
}));
return observable;
}
/**
* Sets the current target that the manager should bind events to.
* @param {?} target
* @return {?}
*/
setTarget(target) {
if (target === this._target) {
return;
}
// Clear the listeners from the pre-existing target.
if (this._target) {
this._clearListeners();
this._pending = [];
}
this._target = target;
// Add the listeners that were bound before the map was initialized.
this._pending.forEach((/**
* @param {?} subscriber
* @return {?}
*/
subscriber => subscriber.observable.subscribe(subscriber.observer)));
this._pending = [];
}
/**
* Destroys the manager and clears the event listeners.
* @return {?}
*/
destroy() {
this._clearListeners();
this._pending = [];
this._target = undefined;
}
}
if (false) {
/**
* Pending listeners that were added before the target was set.
* @type {?}
* @private
*/
MapEventManager.prototype._pending;
/**
* @type {?}
* @private
*/
MapEventManager.prototype._listeners;
/**
* @type {?}
* @private
*/
MapEventManager.prototype._target;
}
/**
* @fileoverview added by tsickle
* Generated from: src/google-maps/google-map/google-map.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @record

@@ -64,2 +176,7 @@ */

this._elementRef = _elementRef;
this._eventManager = new MapEventManager();
this._options = new BehaviorSubject(DEFAULT_OPTIONS);
this._center = new BehaviorSubject(undefined);
this._zoom = new BehaviorSubject(undefined);
this._destroy = new Subject();
this.height = DEFAULT_HEIGHT;

@@ -71,3 +188,3 @@ this.width = DEFAULT_WIDTH;

*/
this.boundsChanged = new EventEmitter();
this.boundsChanged = this._eventManager.getLazyEmitter('bounds_changed');
/**

@@ -77,3 +194,3 @@ * See

*/
this.centerChanged = new EventEmitter();
this.centerChanged = this._eventManager.getLazyEmitter('center_changed');
/**

@@ -83,3 +200,3 @@ * See

*/
this.mapClick = new EventEmitter();
this.mapClick = this._eventManager.getLazyEmitter('click');
/**

@@ -89,3 +206,3 @@ * See

*/
this.mapDblclick = new EventEmitter();
this.mapDblclick = this._eventManager.getLazyEmitter('dblclick');
/**

@@ -95,3 +212,3 @@ * See

*/
this.mapDrag = new EventEmitter();
this.mapDrag = this._eventManager.getLazyEmitter('drag');
/**

@@ -101,3 +218,3 @@ * See

*/
this.mapDragend = new EventEmitter();
this.mapDragend = this._eventManager.getLazyEmitter('dragend');
/**

@@ -107,3 +224,3 @@ * See

*/
this.mapDragstart = new EventEmitter();
this.mapDragstart = this._eventManager.getLazyEmitter('dragstart');
/**

@@ -113,3 +230,3 @@ * See

*/
this.headingChanged = new EventEmitter();
this.headingChanged = this._eventManager.getLazyEmitter('heading_changed');
/**

@@ -119,3 +236,3 @@ * See

*/
this.idle = new EventEmitter();
this.idle = this._eventManager.getLazyEmitter('idle');
/**

@@ -125,3 +242,3 @@ * See

*/
this.maptypeidChanged = new EventEmitter();
this.maptypeidChanged = this._eventManager.getLazyEmitter('maptypeid_changed');
/**

@@ -131,3 +248,3 @@ * See

*/
this.mapMousemove = new EventEmitter();
this.mapMousemove = this._eventManager.getLazyEmitter('mousemove');
/**

@@ -137,3 +254,3 @@ * See

*/
this.mapMouseout = new EventEmitter();
this.mapMouseout = this._eventManager.getLazyEmitter('mouseout');
/**

@@ -143,3 +260,3 @@ * See

*/
this.mapMouseover = new EventEmitter();
this.mapMouseover = this._eventManager.getLazyEmitter('mouseover');
/**

@@ -149,3 +266,3 @@ * See

*/
this.projectionChanged = new EventEmitter();
this.projectionChanged = this._eventManager.getLazyEmitter('projection_changed');
/**

@@ -155,3 +272,3 @@ * See

*/
this.mapRightclick = new EventEmitter();
this.mapRightclick = this._eventManager.getLazyEmitter('rightclick');
/**

@@ -161,3 +278,3 @@ * See

*/
this.tilesloaded = new EventEmitter();
this.tilesloaded = this._eventManager.getLazyEmitter('tilesloaded');
/**

@@ -167,3 +284,3 @@ * See

*/
this.tiltChanged = new EventEmitter();
this.tiltChanged = this._eventManager.getLazyEmitter('tilt_changed');
/**

@@ -173,8 +290,3 @@ * See

*/
this.zoomChanged = new EventEmitter();
this._listeners = [];
this._options = new BehaviorSubject(DEFAULT_OPTIONS);
this._center = new BehaviorSubject(undefined);
this._zoom = new BehaviorSubject(undefined);
this._destroy = new Subject();
this.zoomChanged = this._eventManager.getLazyEmitter('zoomChanged');
// @breaking-change 10.0.0 Remove null check for `platformId`.

@@ -229,5 +341,3 @@ this._isBrowser =

this._setSize();
/** @type {?} */
const combinedOptionsChanges = this._combineOptions();
this._googleMapChanges = this._initializeMap(combinedOptionsChanges);
this._googleMapChanges = this._initializeMap(this._combineOptions());
this._googleMapChanges.subscribe((/**

@@ -239,3 +349,3 @@ * @param {?} googleMap

this._googleMap = (/** @type {?} */ (googleMap));
this._initializeEventHandlers();
this._eventManager.setTarget(this._googleMap);
}));

@@ -251,5 +361,5 @@ this._watchForOptionsChanges();

ngOnDestroy() {
this._eventManager.destroy();
this._destroy.next();
this._destroy.complete();
this._clearListeners();
}

@@ -264,2 +374,3 @@ /**

fitBounds(bounds, padding) {
this._assertInitialized();
this._googleMap.fitBounds(bounds, padding);

@@ -275,2 +386,3 @@ }

panBy(x, y) {
this._assertInitialized();
this._googleMap.panBy(x, y);

@@ -285,2 +397,3 @@ }

panTo(latLng) {
this._assertInitialized();
this._googleMap.panTo(latLng);

@@ -296,2 +409,3 @@ }

panToBounds(latLngBounds, padding) {
this._assertInitialized();
this._googleMap.panToBounds(latLngBounds, padding);

@@ -305,2 +419,3 @@ }

getBounds() {
this._assertInitialized();
return this._googleMap.getBounds() || null;

@@ -314,2 +429,3 @@ }

getCenter() {
this._assertInitialized();
return this._googleMap.getCenter();

@@ -323,2 +439,3 @@ }

getClickableIcons() {
this._assertInitialized();
return this._googleMap.getClickableIcons();

@@ -332,2 +449,3 @@ }

getHeading() {
this._assertInitialized();
return this._googleMap.getHeading();

@@ -341,2 +459,3 @@ }

getMapTypeId() {
this._assertInitialized();
return this._googleMap.getMapTypeId();

@@ -350,2 +469,3 @@ }

getProjection() {
this._assertInitialized();
return this._googleMap.getProjection();

@@ -359,2 +479,3 @@ }

getStreetView() {
this._assertInitialized();
return this._googleMap.getStreetView();

@@ -368,2 +489,3 @@ }

getTilt() {
this._assertInitialized();
return this._googleMap.getTilt();

@@ -377,2 +499,3 @@ }

getZoom() {
this._assertInitialized();
return this._googleMap.getZoom();

@@ -386,2 +509,3 @@ }

get controls() {
this._assertInitialized();
return this._googleMap.controls;

@@ -395,2 +519,3 @@ }

get data() {
this._assertInitialized();
return this._googleMap.data;

@@ -404,2 +529,3 @@ }

get mapTypes() {
this._assertInitialized();
return this._googleMap.mapTypes;

@@ -413,2 +539,3 @@ }

get overlayMapTypes() {
this._assertInitialized();
return this._googleMap.overlayMapTypes;

@@ -453,5 +580,3 @@ }

*/
options => {
return new google.maps.Map(this._mapEl, options);
})), shareReplay(1));
options => new google.maps.Map(this._mapEl, options))), shareReplay(1));
}

@@ -508,83 +633,12 @@ /**

/**
* Asserts that the map has been initialized.
* @private
* @return {?}
*/
_initializeEventHandlers() {
// Ensure that we don't leak if called multiple times.
this._clearListeners();
/** @type {?} */
const eventHandlers = new Map([
['bounds_changed', this.boundsChanged],
['center_changed', this.centerChanged],
['drag', this.mapDrag],
['dragend', this.mapDragend],
['dragstart', this.mapDragstart],
['heading_changed', this.headingChanged],
['idle', this.idle],
['maptypeid_changed', this.maptypeidChanged],
['projection_changed', this.projectionChanged],
['tilesloaded', this.tilesloaded],
['tilt_changed', this.tiltChanged],
['zoomChanged', this.zoomChanged],
]);
/** @type {?} */
const mouseEventHandlers = new Map([
['dblclick', this.mapDblclick],
['mousemove', this.mapMousemove],
['mouseout', this.mapMouseout],
['mouseover', this.mapMouseover],
['rightclick', this.mapRightclick],
]);
eventHandlers.forEach((/**
* @param {?} eventHandler
* @param {?} name
* @return {?}
*/
(eventHandler, name) => {
if (eventHandler.observers.length > 0) {
this._listeners.push(this._googleMap.addListener(name, (/**
* @return {?}
*/
() => {
eventHandler.emit();
})));
}
}));
mouseEventHandlers.forEach((/**
* @param {?} eventHandler
* @param {?} name
* @return {?}
*/
(eventHandler, name) => {
if (eventHandler.observers.length > 0) {
this._listeners.push(this._googleMap.addListener(name, (/**
* @param {?} event
* @return {?}
*/
(event) => {
eventHandler.emit(event);
})));
}
}));
if (this.mapClick.observers.length > 0) {
this._listeners.push(this._googleMap.addListener('click', (/**
* @param {?} event
* @return {?}
*/
(event) => {
this.mapClick.emit(event);
})));
_assertInitialized() {
if (!this._googleMap) {
throw Error('Cannot access Google Map information before the API has been initialized. ' +
'Please wait for the API to load before trying to interact with it.');
}
}
/**
* Clears all currently-registered event listeners.
* @private
* @return {?}
*/
_clearListeners() {
for (let listener of this._listeners) {
listener.remove();
}
this._listeners = [];
}
}

@@ -630,3 +684,46 @@ GoogleMap.decorators = [

if (false) {
/**
* @type {?}
* @private
*/
GoogleMap.prototype._eventManager;
/**
* Whether we're currently rendering inside a browser.
* @type {?}
* @private
*/
GoogleMap.prototype._isBrowser;
/**
* @type {?}
* @private
*/
GoogleMap.prototype._googleMapChanges;
/**
* @type {?}
* @private
*/
GoogleMap.prototype._options;
/**
* @type {?}
* @private
*/
GoogleMap.prototype._center;
/**
* @type {?}
* @private
*/
GoogleMap.prototype._zoom;
/**
* @type {?}
* @private
*/
GoogleMap.prototype._destroy;
/**
* @type {?}
* @private
*/
GoogleMap.prototype._mapEl;
/** @type {?} */
GoogleMap.prototype._googleMap;
/** @type {?} */
GoogleMap.prototype.height;

@@ -747,11 +844,181 @@ /** @type {?} */

*/
GoogleMap.prototype._mapEl;
/** @type {?} */
GoogleMap.prototype._googleMap;
GoogleMap.prototype._elementRef;
}
/**
* @fileoverview added by tsickle
* Generated from: src/google-maps/map-info-window/map-info-window.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* Angular component that renders a Google Maps info window via the Google Maps JavaScript API.
* @see developers.google.com/maps/documentation/javascript/reference/info-window
*/
class MapInfoWindow {
/**
* Whether we're currently rendering inside a browser.
* @type {?}
* @param {?} _googleMap
* @param {?} _elementRef
*/
constructor(_googleMap, _elementRef) {
this._googleMap = _googleMap;
this._elementRef = _elementRef;
this._eventManager = new MapEventManager();
this._options = new BehaviorSubject({});
this._position = new BehaviorSubject(undefined);
this._destroy = new Subject();
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.closeclick
*/
this.closeclick = this._eventManager.getLazyEmitter('closeclick');
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.content_changed
*/
this.contentChanged = this._eventManager.getLazyEmitter('content_changed');
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.domready
*/
this.domready = this._eventManager.getLazyEmitter('domready');
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.position_changed
*/
this.positionChanged = this._eventManager.getLazyEmitter('position_changed');
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.zindex_changed
*/
this.zindexChanged = this._eventManager.getLazyEmitter('zindex_changed');
}
/**
* @param {?} options
* @return {?}
*/
set options(options) {
this._options.next(options || {});
}
/**
* @param {?} position
* @return {?}
*/
set position(position) {
this._position.next(position);
}
/**
* @return {?}
*/
ngOnInit() {
this._combineOptions().pipe(takeUntil(this._destroy)).subscribe((/**
* @param {?} options
* @return {?}
*/
options => {
if (this._infoWindow) {
this._infoWindow.setOptions(options);
}
else {
this._infoWindow = new google.maps.InfoWindow(options);
this._eventManager.setTarget(this._infoWindow);
}
}));
}
/**
* @return {?}
*/
ngOnDestroy() {
this._eventManager.destroy();
this._destroy.next();
this._destroy.complete();
this.close();
}
/**
* See developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.close
* @return {?}
*/
close() {
if (this._infoWindow) {
this._infoWindow.close();
}
}
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.getContent
* @return {?}
*/
getContent() {
return (/** @type {?} */ (this._infoWindow)).getContent();
}
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.getPosition
* @return {?}
*/
getPosition() {
return (/** @type {?} */ (this._infoWindow)).getPosition() || null;
}
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.getZIndex
* @return {?}
*/
getZIndex() {
return (/** @type {?} */ (this._infoWindow)).getZIndex();
}
/**
* Opens the MapInfoWindow using the provided MapMarker as the anchor. If the anchor is not set,
* then the position property of the options input is used instead.
* @param {?=} anchor
* @return {?}
*/
open(anchor) {
/** @type {?} */
const marker = anchor ? anchor._marker : undefined;
if (this._googleMap._googleMap) {
this._elementRef.nativeElement.style.display = '';
(/** @type {?} */ (this._infoWindow)).open(this._googleMap._googleMap, marker);
}
}
/**
* @private
* @return {?}
*/
GoogleMap.prototype._isBrowser;
_combineOptions() {
return combineLatest([this._options, this._position]).pipe(map((/**
* @param {?} __0
* @return {?}
*/
([options, position]) => {
/** @type {?} */
const combinedOptions = Object.assign(Object.assign({}, options), { position: position || options.position, content: this._elementRef.nativeElement });
return combinedOptions;
})));
}
}
MapInfoWindow.decorators = [
{ type: Directive, args: [{
selector: 'map-info-window',
host: { 'style': 'display: none' },
},] }
];
/** @nocollapse */
MapInfoWindow.ctorParameters = () => [
{ type: GoogleMap },
{ type: ElementRef }
];
MapInfoWindow.propDecorators = {
options: [{ type: Input }],
position: [{ type: Input }],
closeclick: [{ type: Output }],
contentChanged: [{ type: Output }],
domready: [{ type: Output }],
positionChanged: [{ type: Output }],
zindexChanged: [{ type: Output }]
};
if (false) {
/**

@@ -761,3 +1028,3 @@ * @type {?}

*/
GoogleMap.prototype._googleMapChanges;
MapInfoWindow.prototype._eventManager;
/**

@@ -767,3 +1034,3 @@ * @type {?}

*/
GoogleMap.prototype._listeners;
MapInfoWindow.prototype._options;
/**

@@ -773,3 +1040,3 @@ * @type {?}

*/
GoogleMap.prototype._options;
MapInfoWindow.prototype._position;
/**

@@ -779,3 +1046,3 @@ * @type {?}

*/
GoogleMap.prototype._center;
MapInfoWindow.prototype._destroy;
/**

@@ -785,8 +1052,41 @@ * @type {?}

*/
GoogleMap.prototype._zoom;
MapInfoWindow.prototype._infoWindow;
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.closeclick
* @type {?}
*/
MapInfoWindow.prototype.closeclick;
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.content_changed
* @type {?}
*/
MapInfoWindow.prototype.contentChanged;
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.domready
* @type {?}
*/
MapInfoWindow.prototype.domready;
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.position_changed
* @type {?}
*/
MapInfoWindow.prototype.positionChanged;
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.zindex_changed
* @type {?}
*/
MapInfoWindow.prototype.zindexChanged;
/**
* @type {?}
* @private
*/
GoogleMap.prototype._destroy;
MapInfoWindow.prototype._googleMap;
/**

@@ -796,3 +1096,3 @@ * @type {?}

*/
GoogleMap.prototype._elementRef;
MapInfoWindow.prototype._elementRef;
}

@@ -802,2 +1102,3 @@

* @fileoverview added by tsickle
* Generated from: src/google-maps/map-marker/map-marker.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc

@@ -823,2 +1124,9 @@ */

this._googleMap = _googleMap;
this._eventManager = new MapEventManager();
this._options = new BehaviorSubject(DEFAULT_MARKER_OPTIONS);
this._title = new BehaviorSubject(undefined);
this._position = new BehaviorSubject(undefined);
this._label = new BehaviorSubject(undefined);
this._clickable = new BehaviorSubject(undefined);
this._destroy = new Subject();
/**

@@ -828,3 +1136,3 @@ * See

*/
this.animationChanged = new EventEmitter();
this.animationChanged = this._eventManager.getLazyEmitter('animation_changed');
/**

@@ -834,3 +1142,3 @@ * See

*/
this.mapClick = new EventEmitter();
this.mapClick = this._eventManager.getLazyEmitter('click');
/**

@@ -840,3 +1148,3 @@ * See

*/
this.clickableChanged = new EventEmitter();
this.clickableChanged = this._eventManager.getLazyEmitter('clickable_changed');
/**

@@ -846,3 +1154,3 @@ * See

*/
this.cursorChanged = new EventEmitter();
this.cursorChanged = this._eventManager.getLazyEmitter('cursor_changed');
/**

@@ -852,3 +1160,3 @@ * See

*/
this.mapDblclick = new EventEmitter();
this.mapDblclick = this._eventManager.getLazyEmitter('dblclick');
/**

@@ -858,3 +1166,3 @@ * See

*/
this.mapDrag = new EventEmitter();
this.mapDrag = this._eventManager.getLazyEmitter('drag');
/**

@@ -864,3 +1172,3 @@ * See

*/
this.mapDragend = new EventEmitter();
this.mapDragend = this._eventManager.getLazyEmitter('dragend');
/**

@@ -870,3 +1178,3 @@ * See

*/
this.draggableChanged = new EventEmitter();
this.draggableChanged = this._eventManager.getLazyEmitter('draggable_changed');
/**

@@ -876,3 +1184,3 @@ * See

*/
this.mapDragstart = new EventEmitter();
this.mapDragstart = this._eventManager.getLazyEmitter('dragstart');
/**

@@ -882,3 +1190,3 @@ * See

*/
this.flatChanged = new EventEmitter();
this.flatChanged = this._eventManager.getLazyEmitter('flat_changed');
/**

@@ -888,3 +1196,3 @@ * See

*/
this.iconChanged = new EventEmitter();
this.iconChanged = this._eventManager.getLazyEmitter('icon_changed');
/**

@@ -894,3 +1202,3 @@ * See

*/
this.mapMousedown = new EventEmitter();
this.mapMousedown = this._eventManager.getLazyEmitter('mousedown');
/**

@@ -900,3 +1208,3 @@ * See

*/
this.mapMouseout = new EventEmitter();
this.mapMouseout = this._eventManager.getLazyEmitter('mouseout');
/**

@@ -906,3 +1214,3 @@ * See

*/
this.mapMouseover = new EventEmitter();
this.mapMouseover = this._eventManager.getLazyEmitter('mouseover');
/**

@@ -912,3 +1220,3 @@ * See

*/
this.mapMouseup = new EventEmitter();
this.mapMouseup = this._eventManager.getLazyEmitter('mouseup');
/**

@@ -918,3 +1226,3 @@ * See

*/
this.positionChanged = new EventEmitter();
this.positionChanged = this._eventManager.getLazyEmitter('position_changed');
/**

@@ -924,3 +1232,3 @@ * See

*/
this.mapRightclick = new EventEmitter();
this.mapRightclick = this._eventManager.getLazyEmitter('rightclick');
/**

@@ -930,3 +1238,3 @@ * See

*/
this.shapeChanged = new EventEmitter();
this.shapeChanged = this._eventManager.getLazyEmitter('shape_changed');
/**

@@ -936,3 +1244,3 @@ * See

*/
this.titleChanged = new EventEmitter();
this.titleChanged = this._eventManager.getLazyEmitter('title_changed');
/**

@@ -942,3 +1250,3 @@ * See

*/
this.visibleChanged = new EventEmitter();
this.visibleChanged = this._eventManager.getLazyEmitter('visible_changed');
/**

@@ -948,10 +1256,3 @@ * See

*/
this.zindexChanged = new EventEmitter();
this._options = new BehaviorSubject(DEFAULT_MARKER_OPTIONS);
this._title = new BehaviorSubject(undefined);
this._position = new BehaviorSubject(undefined);
this._label = new BehaviorSubject(undefined);
this._clickable = new BehaviorSubject(undefined);
this._destroy = new Subject();
this._listeners = [];
this.zindexChanged = this._eventManager.getLazyEmitter('zindex_changed');
}

@@ -1006,3 +1307,3 @@ /**

this._marker.setMap(this._googleMap._googleMap);
this._initializeEventHandlers();
this._eventManager.setTarget(this._marker);
}));

@@ -1021,3 +1322,3 @@ this._watchForOptionsChanges();

this._destroy.complete();
this._clearListeners();
this._eventManager.destroy();
if (this._marker) {

@@ -1214,79 +1515,2 @@ this._marker.setMap(null);

}
/**
* @private
* @return {?}
*/
_initializeEventHandlers() {
// Ensure that we don't leak if called multiple times.
this._clearListeners();
/** @type {?} */
const eventHandlers = new Map([
['animation_changed', this.animationChanged],
['clickable_changed', this.clickableChanged],
['cursor_changed', this.cursorChanged],
['draggable_changed', this.draggableChanged],
['flat_changed', this.flatChanged],
['icon_changed', this.iconChanged],
['position_changed', this.positionChanged],
['shape_changed', this.shapeChanged],
['title_changed', this.titleChanged],
['visible_changed', this.visibleChanged],
['zindex_changed', this.zindexChanged],
]);
/** @type {?} */
const mouseEventHandlers = new Map([
['click', this.mapClick],
['dblclick', this.mapDblclick],
['drag', this.mapDrag],
['dragend', this.mapDragend],
['dragstart', this.mapDragstart],
['mousedown', this.mapMousedown],
['mouseout', this.mapMouseout],
['mouseover', this.mapMouseover],
['mouseup', this.mapMouseup],
['rightclick', this.mapRightclick],
]);
eventHandlers.forEach((/**
* @param {?} eventHandler
* @param {?} name
* @return {?}
*/
(eventHandler, name) => {
if (eventHandler.observers.length > 0) {
this._listeners.push((/** @type {?} */ (this._marker)).addListener(name, (/**
* @return {?}
*/
() => {
eventHandler.emit();
})));
}
}));
mouseEventHandlers.forEach((/**
* @param {?} eventHandler
* @param {?} name
* @return {?}
*/
(eventHandler, name) => {
if (eventHandler.observers.length > 0) {
this._listeners.push((/** @type {?} */ (this._marker)).addListener(name, (/**
* @param {?} event
* @return {?}
*/
(event) => {
eventHandler.emit(event);
})));
}
}));
}
/**
* Clears all currently-registered event listeners.
* @private
* @return {?}
*/
_clearListeners() {
for (let listener of this._listeners) {
listener.remove();
}
this._listeners = [];
}
}

@@ -1335,2 +1559,37 @@ MapMarker.decorators = [

/**
* @type {?}
* @private
*/
MapMarker.prototype._eventManager;
/**
* @type {?}
* @private
*/
MapMarker.prototype._options;
/**
* @type {?}
* @private
*/
MapMarker.prototype._title;
/**
* @type {?}
* @private
*/
MapMarker.prototype._position;
/**
* @type {?}
* @private
*/
MapMarker.prototype._label;
/**
* @type {?}
* @private
*/
MapMarker.prototype._clickable;
/**
* @type {?}
* @private
*/
MapMarker.prototype._destroy;
/**
* See

@@ -1461,37 +1720,2 @@ * developers.google.com/maps/documentation/javascript/reference/marker#Marker.animation_changed

MapMarker.prototype.zindexChanged;
/**
* @type {?}
* @private
*/
MapMarker.prototype._options;
/**
* @type {?}
* @private
*/
MapMarker.prototype._title;
/**
* @type {?}
* @private
*/
MapMarker.prototype._position;
/**
* @type {?}
* @private
*/
MapMarker.prototype._label;
/**
* @type {?}
* @private
*/
MapMarker.prototype._clickable;
/**
* @type {?}
* @private
*/
MapMarker.prototype._destroy;
/**
* @type {?}
* @private
*/
MapMarker.prototype._listeners;
/** @type {?} */

@@ -1508,49 +1732,66 @@ MapMarker.prototype._marker;

* @fileoverview added by tsickle
* Generated from: src/google-maps/map-polyline/map-polyline.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* Angular component that renders a Google Maps info window via the Google Maps JavaScript API.
* @see developers.google.com/maps/documentation/javascript/reference/info-window
* Angular component that renders a Google Maps Polyline via the Google Maps JavaScript API.
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline
*/
class MapInfoWindow {
class MapPolyline {
/**
* @param {?} _googleMap
* @param {?} _elementRef
* @param {?} _map
*/
constructor(_googleMap, _elementRef) {
this._googleMap = _googleMap;
this._elementRef = _elementRef;
constructor(_map) {
this._map = _map;
this._eventManager = new MapEventManager();
this._options = new BehaviorSubject({});
this._path = new BehaviorSubject(undefined);
this._destroyed = new Subject();
this._listeners = [];
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.closeclick
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.click
*/
this.closeclick = new EventEmitter();
this.polylineClick = this._eventManager.getLazyEmitter('click');
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.content_changed
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.dblclick
*/
this.contentChanged = new EventEmitter();
this.polylineDblclick = this._eventManager.getLazyEmitter('dblclick');
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.domready
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.drag
*/
this.domready = new EventEmitter();
this.polylineDrag = this._eventManager.getLazyEmitter('drag');
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.position_changed
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.dragend
*/
this.positionChanged = new EventEmitter();
this.polylineDragend = this._eventManager.getLazyEmitter('dragend');
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.zindex_changed
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.dragstart
*/
this.zindexChanged = new EventEmitter();
this._options = new BehaviorSubject({});
this._position = new BehaviorSubject(undefined);
this._listeners = [];
this._destroy = new Subject();
this.polylineDragstart = this._eventManager.getLazyEmitter('dragstart');
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mousedown
*/
this.polylineMousedown = this._eventManager.getLazyEmitter('mousedown');
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mousemove
*/
this.polylineMousemove = this._eventManager.getLazyEmitter('mousemove');
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mouseout
*/
this.polylineMouseout = this._eventManager.getLazyEmitter('mouseout');
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mouseover
*/
this.polylineMouseover = this._eventManager.getLazyEmitter('mouseover');
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mouseup
*/
this.polylineMouseup = this._eventManager.getLazyEmitter('mouseup');
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.rightclick
*/
this.polylineRightclick = this._eventManager.getLazyEmitter('rightclick');
}
// initialized in ngOnInit
/**

@@ -1564,7 +1805,7 @@ * @param {?} options

/**
* @param {?} position
* @param {?} path
* @return {?}
*/
set position(position) {
this._position.next(position);
set path(path) {
this._path.next(path);
}

@@ -1575,3 +1816,5 @@ /**

ngOnInit() {
this._combineOptions().pipe(takeUntil(this._destroy)).subscribe((/**
/** @type {?} */
const combinedOptionsChanges = this._combineOptions();
combinedOptionsChanges.pipe(take(1)).subscribe((/**
* @param {?} options

@@ -1581,10 +1824,8 @@ * @return {?}

options => {
if (this._infoWindow) {
this._infoWindow.setOptions(options);
}
else {
this._infoWindow = new google.maps.InfoWindow(options);
this._initializeEventHandlers();
}
this._polyline = new google.maps.Polyline(options);
this._polyline.setMap(this._map._googleMap);
this._eventManager.setTarget(this._polyline);
}));
this._watchForOptionsChanges();
this._watchForPathChanges();
}

@@ -1595,58 +1836,40 @@ /**

ngOnDestroy() {
this._destroy.next();
this._destroy.complete();
this._eventManager.destroy();
this._destroyed.next();
this._destroyed.complete();
for (let listener of this._listeners) {
listener.remove();
}
this.close();
this._polyline.setMap(null);
}
/**
* See developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.close
* @see
* developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.getDraggable
* @return {?}
*/
close() {
if (this._infoWindow) {
this._infoWindow.close();
}
getDraggable() {
return this._polyline.getDraggable();
}
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.getContent
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.getEditable
* @return {?}
*/
getContent() {
return (/** @type {?} */ (this._infoWindow)).getContent();
getEditable() {
return this._polyline.getEditable();
}
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.getPosition
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.getPath
* @return {?}
*/
getPosition() {
return (/** @type {?} */ (this._infoWindow)).getPosition() || null;
getPath() {
return this._polyline.getPath();
}
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.getZIndex
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.getVisible
* @return {?}
*/
getZIndex() {
return (/** @type {?} */ (this._infoWindow)).getZIndex();
getVisible() {
return this._polyline.getVisible();
}
/**
* Opens the MapInfoWindow using the provided MapMarker as the anchor. If the anchor is not set,
* then the position property of the options input is used instead.
* @param {?=} anchor
* @return {?}
*/
open(anchor) {
/** @type {?} */
const marker = anchor ? anchor._marker : undefined;
if (this._googleMap._googleMap) {
this._elementRef.nativeElement.style.display = '';
(/** @type {?} */ (this._infoWindow)).open(this._googleMap._googleMap, marker);
}
}
/**
* @private

@@ -1656,9 +1879,9 @@ * @return {?}

_combineOptions() {
return combineLatest([this._options, this._position]).pipe(map((/**
return combineLatest([this._options, this._path]).pipe(map((/**
* @param {?} __0
* @return {?}
*/
([options, position]) => {
([options, path]) => {
/** @type {?} */
const combinedOptions = Object.assign(Object.assign({}, options), { position: position || options.position, content: this._elementRef.nativeElement });
const combinedOptions = Object.assign(Object.assign({}, options), { path: path || options.path });
return combinedOptions;

@@ -1671,130 +1894,139 @@ })));

*/
_initializeEventHandlers() {
// Ensure that we don't leak if called multiple times.
this._clearListeners();
/** @type {?} */
const eventHandlers = new Map([
['closeclick', this.closeclick],
['content_changed', this.contentChanged],
['domready', this.domready],
['position_changed', this.positionChanged],
['zindex_changed', this.zindexChanged],
]);
eventHandlers.forEach((/**
* @param {?} eventHandler
* @param {?} name
_watchForOptionsChanges() {
this._options.pipe(takeUntil(this._destroyed)).subscribe((/**
* @param {?} options
* @return {?}
*/
(eventHandler, name) => {
if (eventHandler.observers.length > 0) {
this._listeners.push((/** @type {?} */ (this._infoWindow)).addListener(name, (/**
* @return {?}
*/
() => {
eventHandler.emit();
})));
}
options => {
this._polyline.setOptions(options);
}));
}
/**
* Clears all currently-registered event listeners.
* @private
* @return {?}
*/
_clearListeners() {
for (let listener of this._listeners) {
listener.remove();
}
this._listeners = [];
_watchForPathChanges() {
this._path.pipe(takeUntil(this._destroyed)).subscribe((/**
* @param {?} path
* @return {?}
*/
path => {
if (path) {
this._polyline.setPath(path);
}
}));
}
}
MapInfoWindow.decorators = [
MapPolyline.decorators = [
{ type: Directive, args: [{
selector: 'map-info-window',
host: { 'style': 'display: none' },
selector: 'map-polyline',
},] }
];
/** @nocollapse */
MapInfoWindow.ctorParameters = () => [
{ type: GoogleMap },
{ type: ElementRef }
MapPolyline.ctorParameters = () => [
{ type: GoogleMap }
];
MapInfoWindow.propDecorators = {
MapPolyline.propDecorators = {
options: [{ type: Input }],
position: [{ type: Input }],
closeclick: [{ type: Output }],
contentChanged: [{ type: Output }],
domready: [{ type: Output }],
positionChanged: [{ type: Output }],
zindexChanged: [{ type: Output }]
path: [{ type: Input }],
polylineClick: [{ type: Output }],
polylineDblclick: [{ type: Output }],
polylineDrag: [{ type: Output }],
polylineDragend: [{ type: Output }],
polylineDragstart: [{ type: Output }],
polylineMousedown: [{ type: Output }],
polylineMousemove: [{ type: Output }],
polylineMouseout: [{ type: Output }],
polylineMouseover: [{ type: Output }],
polylineMouseup: [{ type: Output }],
polylineRightclick: [{ type: Output }]
};
if (false) {
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.closeclick
* @type {?}
* @private
*/
MapInfoWindow.prototype.closeclick;
MapPolyline.prototype._eventManager;
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.content_changed
* @type {?}
* @private
*/
MapInfoWindow.prototype.contentChanged;
MapPolyline.prototype._options;
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.domready
* @type {?}
* @private
*/
MapInfoWindow.prototype.domready;
MapPolyline.prototype._path;
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.position_changed
* @type {?}
* @private
*/
MapInfoWindow.prototype.positionChanged;
MapPolyline.prototype._destroyed;
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.zindex_changed
* @type {?}
* @private
*/
MapInfoWindow.prototype.zindexChanged;
MapPolyline.prototype._listeners;
/** @type {?} */
MapPolyline.prototype._polyline;
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.click
* @type {?}
* @private
*/
MapInfoWindow.prototype._options;
MapPolyline.prototype.polylineClick;
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.dblclick
* @type {?}
* @private
*/
MapInfoWindow.prototype._position;
MapPolyline.prototype.polylineDblclick;
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.drag
* @type {?}
* @private
*/
MapInfoWindow.prototype._listeners;
MapPolyline.prototype.polylineDrag;
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.dragend
* @type {?}
* @private
*/
MapInfoWindow.prototype._destroy;
MapPolyline.prototype.polylineDragend;
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.dragstart
* @type {?}
* @private
*/
MapInfoWindow.prototype._infoWindow;
MapPolyline.prototype.polylineDragstart;
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mousedown
* @type {?}
* @private
*/
MapInfoWindow.prototype._googleMap;
MapPolyline.prototype.polylineMousedown;
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mousemove
* @type {?}
*/
MapPolyline.prototype.polylineMousemove;
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mouseout
* @type {?}
*/
MapPolyline.prototype.polylineMouseout;
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mouseover
* @type {?}
*/
MapPolyline.prototype.polylineMouseover;
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mouseup
* @type {?}
*/
MapPolyline.prototype.polylineMouseup;
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.rightclick
* @type {?}
*/
MapPolyline.prototype.polylineRightclick;
/**
* @type {?}
* @private
*/
MapInfoWindow.prototype._elementRef;
MapPolyline.prototype._map;
}

@@ -1804,2 +2036,3 @@

* @fileoverview added by tsickle
* Generated from: src/google-maps/google-maps-module.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc

@@ -1812,2 +2045,3 @@ */

MapMarker,
MapPolyline,
];

@@ -1825,2 +2059,3 @@ class GoogleMapsModule {

* @fileoverview added by tsickle
* Generated from: src/google-maps/public-api.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc

@@ -1833,3 +2068,3 @@ */

export { GoogleMap, GoogleMapsModule, MapInfoWindow, MapMarker };
export { GoogleMap, GoogleMapsModule, MapInfoWindow, MapMarker, MapPolyline };
//# sourceMappingURL=google-maps.js.map

@@ -1,5 +0,5 @@

import { __read, __assign, __values } from 'tslib';
import { EventEmitter, Component, ChangeDetectionStrategy, ViewEncapsulation, ElementRef, Optional, Inject, PLATFORM_ID, Input, Output, Directive, NgModule } from '@angular/core';
import { __values, __read, __assign } from 'tslib';
import { Component, ChangeDetectionStrategy, ViewEncapsulation, ElementRef, Optional, Inject, PLATFORM_ID, Input, Output, Directive, NgModule } from '@angular/core';
import { isPlatformBrowser } from '@angular/common';
import { BehaviorSubject, Subject, combineLatest } from 'rxjs';
import { Observable, BehaviorSubject, Subject, combineLatest } from 'rxjs';
import { map, take, shareReplay, takeUntil } from 'rxjs/operators';

@@ -14,2 +14,73 @@

*/
/** Manages event on a Google Maps object, ensuring that events are added only when necessary. */
var MapEventManager = /** @class */ (function () {
function MapEventManager() {
/** Pending listeners that were added before the target was set. */
this._pending = [];
this._listeners = [];
}
/** Clears all currently-registered event listeners. */
MapEventManager.prototype._clearListeners = function () {
var e_1, _a;
try {
for (var _b = __values(this._listeners), _c = _b.next(); !_c.done; _c = _b.next()) {
var listener = _c.value;
listener.remove();
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_1) throw e_1.error; }
}
this._listeners = [];
};
/** Gets an observable that adds an event listener to the map when a consumer subscribes to it. */
MapEventManager.prototype.getLazyEmitter = function (name) {
var _this = this;
var observable = new Observable(function (observer) {
// If the target hasn't been initialized yet, cache the observer so it can be added later.
if (!_this._target) {
_this._pending.push({ observable: observable, observer: observer });
return undefined;
}
var listener = _this._target.addListener(name, function (event) { return observer.next(event); });
_this._listeners.push(listener);
return function () { return listener.remove(); };
});
return observable;
};
/** Sets the current target that the manager should bind events to. */
MapEventManager.prototype.setTarget = function (target) {
if (target === this._target) {
return;
}
// Clear the listeners from the pre-existing target.
if (this._target) {
this._clearListeners();
this._pending = [];
}
this._target = target;
// Add the listeners that were bound before the map was initialized.
this._pending.forEach(function (subscriber) { return subscriber.observable.subscribe(subscriber.observer); });
this._pending = [];
};
/** Destroys the manager and clears the event listeners. */
MapEventManager.prototype.destroy = function () {
this._clearListeners();
this._pending = [];
this._target = undefined;
};
return MapEventManager;
}());
/**
* @license
* Copyright Google LLC All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://angular.io/license
*/
/** default options set to the Googleplex */

@@ -37,2 +108,7 @@ var DEFAULT_OPTIONS = {

this._elementRef = _elementRef;
this._eventManager = new MapEventManager();
this._options = new BehaviorSubject(DEFAULT_OPTIONS);
this._center = new BehaviorSubject(undefined);
this._zoom = new BehaviorSubject(undefined);
this._destroy = new Subject();
this.height = DEFAULT_HEIGHT;

@@ -44,3 +120,3 @@ this.width = DEFAULT_WIDTH;

*/
this.boundsChanged = new EventEmitter();
this.boundsChanged = this._eventManager.getLazyEmitter('bounds_changed');
/**

@@ -50,3 +126,3 @@ * See

*/
this.centerChanged = new EventEmitter();
this.centerChanged = this._eventManager.getLazyEmitter('center_changed');
/**

@@ -56,3 +132,3 @@ * See

*/
this.mapClick = new EventEmitter();
this.mapClick = this._eventManager.getLazyEmitter('click');
/**

@@ -62,3 +138,3 @@ * See

*/
this.mapDblclick = new EventEmitter();
this.mapDblclick = this._eventManager.getLazyEmitter('dblclick');
/**

@@ -68,3 +144,3 @@ * See

*/
this.mapDrag = new EventEmitter();
this.mapDrag = this._eventManager.getLazyEmitter('drag');
/**

@@ -74,3 +150,3 @@ * See

*/
this.mapDragend = new EventEmitter();
this.mapDragend = this._eventManager.getLazyEmitter('dragend');
/**

@@ -80,3 +156,3 @@ * See

*/
this.mapDragstart = new EventEmitter();
this.mapDragstart = this._eventManager.getLazyEmitter('dragstart');
/**

@@ -86,3 +162,3 @@ * See

*/
this.headingChanged = new EventEmitter();
this.headingChanged = this._eventManager.getLazyEmitter('heading_changed');
/**

@@ -92,3 +168,3 @@ * See

*/
this.idle = new EventEmitter();
this.idle = this._eventManager.getLazyEmitter('idle');
/**

@@ -98,3 +174,3 @@ * See

*/
this.maptypeidChanged = new EventEmitter();
this.maptypeidChanged = this._eventManager.getLazyEmitter('maptypeid_changed');
/**

@@ -104,3 +180,3 @@ * See

*/
this.mapMousemove = new EventEmitter();
this.mapMousemove = this._eventManager.getLazyEmitter('mousemove');
/**

@@ -110,3 +186,3 @@ * See

*/
this.mapMouseout = new EventEmitter();
this.mapMouseout = this._eventManager.getLazyEmitter('mouseout');
/**

@@ -116,3 +192,3 @@ * See

*/
this.mapMouseover = new EventEmitter();
this.mapMouseover = this._eventManager.getLazyEmitter('mouseover');
/**

@@ -122,3 +198,3 @@ * See

*/
this.projectionChanged = new EventEmitter();
this.projectionChanged = this._eventManager.getLazyEmitter('projection_changed');
/**

@@ -128,3 +204,3 @@ * See

*/
this.mapRightclick = new EventEmitter();
this.mapRightclick = this._eventManager.getLazyEmitter('rightclick');
/**

@@ -134,3 +210,3 @@ * See

*/
this.tilesloaded = new EventEmitter();
this.tilesloaded = this._eventManager.getLazyEmitter('tilesloaded');
/**

@@ -140,3 +216,3 @@ * See

*/
this.tiltChanged = new EventEmitter();
this.tiltChanged = this._eventManager.getLazyEmitter('tilt_changed');
/**

@@ -146,8 +222,3 @@ * See

*/
this.zoomChanged = new EventEmitter();
this._listeners = [];
this._options = new BehaviorSubject(DEFAULT_OPTIONS);
this._center = new BehaviorSubject(undefined);
this._zoom = new BehaviorSubject(undefined);
this._destroy = new Subject();
this.zoomChanged = this._eventManager.getLazyEmitter('zoomChanged');
// @breaking-change 10.0.0 Remove null check for `platformId`.

@@ -196,7 +267,6 @@ this._isBrowser =

this._setSize();
var combinedOptionsChanges = this._combineOptions();
this._googleMapChanges = this._initializeMap(combinedOptionsChanges);
this._googleMapChanges = this._initializeMap(this._combineOptions());
this._googleMapChanges.subscribe(function (googleMap) {
_this._googleMap = googleMap;
_this._initializeEventHandlers();
_this._eventManager.setTarget(_this._googleMap);
});

@@ -209,5 +279,5 @@ this._watchForOptionsChanges();

GoogleMap.prototype.ngOnDestroy = function () {
this._eventManager.destroy();
this._destroy.next();
this._destroy.complete();
this._clearListeners();
};

@@ -219,2 +289,3 @@ /**

GoogleMap.prototype.fitBounds = function (bounds, padding) {
this._assertInitialized();
this._googleMap.fitBounds(bounds, padding);

@@ -227,2 +298,3 @@ };

GoogleMap.prototype.panBy = function (x, y) {
this._assertInitialized();
this._googleMap.panBy(x, y);

@@ -235,2 +307,3 @@ };

GoogleMap.prototype.panTo = function (latLng) {
this._assertInitialized();
this._googleMap.panTo(latLng);

@@ -243,2 +316,3 @@ };

GoogleMap.prototype.panToBounds = function (latLngBounds, padding) {
this._assertInitialized();
this._googleMap.panToBounds(latLngBounds, padding);

@@ -251,2 +325,3 @@ };

GoogleMap.prototype.getBounds = function () {
this._assertInitialized();
return this._googleMap.getBounds() || null;

@@ -259,2 +334,3 @@ };

GoogleMap.prototype.getCenter = function () {
this._assertInitialized();
return this._googleMap.getCenter();

@@ -267,2 +343,3 @@ };

GoogleMap.prototype.getClickableIcons = function () {
this._assertInitialized();
return this._googleMap.getClickableIcons();

@@ -275,2 +352,3 @@ };

GoogleMap.prototype.getHeading = function () {
this._assertInitialized();
return this._googleMap.getHeading();

@@ -283,2 +361,3 @@ };

GoogleMap.prototype.getMapTypeId = function () {
this._assertInitialized();
return this._googleMap.getMapTypeId();

@@ -291,2 +370,3 @@ };

GoogleMap.prototype.getProjection = function () {
this._assertInitialized();
return this._googleMap.getProjection();

@@ -299,2 +379,3 @@ };

GoogleMap.prototype.getStreetView = function () {
this._assertInitialized();
return this._googleMap.getStreetView();

@@ -307,2 +388,3 @@ };

GoogleMap.prototype.getTilt = function () {
this._assertInitialized();
return this._googleMap.getTilt();

@@ -315,2 +397,3 @@ };

GoogleMap.prototype.getZoom = function () {
this._assertInitialized();
return this._googleMap.getZoom();

@@ -324,2 +407,3 @@ };

get: function () {
this._assertInitialized();
return this._googleMap.controls;

@@ -336,2 +420,3 @@ },

get: function () {
this._assertInitialized();
return this._googleMap.data;

@@ -348,2 +433,3 @@ },

get: function () {
this._assertInitialized();
return this._googleMap.mapTypes;

@@ -360,2 +446,3 @@ },

get: function () {
this._assertInitialized();
return this._googleMap.overlayMapTypes;

@@ -383,5 +470,3 @@ },

var _this = this;
return optionsChanges.pipe(take(1), map(function (options) {
return new google.maps.Map(_this._mapEl, options);
}), shareReplay(1));
return optionsChanges.pipe(take(1), map(function (options) { return new google.maps.Map(_this._mapEl, options); }), shareReplay(1));
};

@@ -416,65 +501,9 @@ GoogleMap.prototype._watchForOptionsChanges = function () {

};
GoogleMap.prototype._initializeEventHandlers = function () {
var _this = this;
// Ensure that we don't leak if called multiple times.
this._clearListeners();
var eventHandlers = new Map([
['bounds_changed', this.boundsChanged],
['center_changed', this.centerChanged],
['drag', this.mapDrag],
['dragend', this.mapDragend],
['dragstart', this.mapDragstart],
['heading_changed', this.headingChanged],
['idle', this.idle],
['maptypeid_changed', this.maptypeidChanged],
['projection_changed', this.projectionChanged],
['tilesloaded', this.tilesloaded],
['tilt_changed', this.tiltChanged],
['zoomChanged', this.zoomChanged],
]);
var mouseEventHandlers = new Map([
['dblclick', this.mapDblclick],
['mousemove', this.mapMousemove],
['mouseout', this.mapMouseout],
['mouseover', this.mapMouseover],
['rightclick', this.mapRightclick],
]);
eventHandlers.forEach(function (eventHandler, name) {
if (eventHandler.observers.length > 0) {
_this._listeners.push(_this._googleMap.addListener(name, function () {
eventHandler.emit();
}));
}
});
mouseEventHandlers.forEach(function (eventHandler, name) {
if (eventHandler.observers.length > 0) {
_this._listeners.push(_this._googleMap.addListener(name, function (event) {
eventHandler.emit(event);
}));
}
});
if (this.mapClick.observers.length > 0) {
this._listeners.push(this._googleMap.addListener('click', function (event) {
_this.mapClick.emit(event);
}));
/** Asserts that the map has been initialized. */
GoogleMap.prototype._assertInitialized = function () {
if (!this._googleMap) {
throw Error('Cannot access Google Map information before the API has been initialized. ' +
'Please wait for the API to load before trying to interact with it.');
}
};
/** Clears all currently-registered event listeners. */
GoogleMap.prototype._clearListeners = function () {
var e_1, _a;
try {
for (var _b = __values(this._listeners), _c = _b.next(); !_c.done; _c = _b.next()) {
var listener = _c.value;
listener.remove();
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_1) throw e_1.error; }
}
this._listeners = [];
};
GoogleMap.decorators = [

@@ -529,2 +558,154 @@ { type: Component, args: [{

/**
* Angular component that renders a Google Maps info window via the Google Maps JavaScript API.
* @see developers.google.com/maps/documentation/javascript/reference/info-window
*/
var MapInfoWindow = /** @class */ (function () {
function MapInfoWindow(_googleMap, _elementRef) {
this._googleMap = _googleMap;
this._elementRef = _elementRef;
this._eventManager = new MapEventManager();
this._options = new BehaviorSubject({});
this._position = new BehaviorSubject(undefined);
this._destroy = new Subject();
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.closeclick
*/
this.closeclick = this._eventManager.getLazyEmitter('closeclick');
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.content_changed
*/
this.contentChanged = this._eventManager.getLazyEmitter('content_changed');
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.domready
*/
this.domready = this._eventManager.getLazyEmitter('domready');
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.position_changed
*/
this.positionChanged = this._eventManager.getLazyEmitter('position_changed');
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.zindex_changed
*/
this.zindexChanged = this._eventManager.getLazyEmitter('zindex_changed');
}
Object.defineProperty(MapInfoWindow.prototype, "options", {
set: function (options) {
this._options.next(options || {});
},
enumerable: true,
configurable: true
});
Object.defineProperty(MapInfoWindow.prototype, "position", {
set: function (position) {
this._position.next(position);
},
enumerable: true,
configurable: true
});
MapInfoWindow.prototype.ngOnInit = function () {
var _this = this;
this._combineOptions().pipe(takeUntil(this._destroy)).subscribe(function (options) {
if (_this._infoWindow) {
_this._infoWindow.setOptions(options);
}
else {
_this._infoWindow = new google.maps.InfoWindow(options);
_this._eventManager.setTarget(_this._infoWindow);
}
});
};
MapInfoWindow.prototype.ngOnDestroy = function () {
this._eventManager.destroy();
this._destroy.next();
this._destroy.complete();
this.close();
};
/**
* See developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.close
*/
MapInfoWindow.prototype.close = function () {
if (this._infoWindow) {
this._infoWindow.close();
}
};
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.getContent
*/
MapInfoWindow.prototype.getContent = function () {
return this._infoWindow.getContent();
};
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.getPosition
*/
MapInfoWindow.prototype.getPosition = function () {
return this._infoWindow.getPosition() || null;
};
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.getZIndex
*/
MapInfoWindow.prototype.getZIndex = function () {
return this._infoWindow.getZIndex();
};
/**
* Opens the MapInfoWindow using the provided MapMarker as the anchor. If the anchor is not set,
* then the position property of the options input is used instead.
*/
MapInfoWindow.prototype.open = function (anchor) {
var marker = anchor ? anchor._marker : undefined;
if (this._googleMap._googleMap) {
this._elementRef.nativeElement.style.display = '';
this._infoWindow.open(this._googleMap._googleMap, marker);
}
};
MapInfoWindow.prototype._combineOptions = function () {
var _this = this;
return combineLatest([this._options, this._position]).pipe(map(function (_a) {
var _b = __read(_a, 2), options = _b[0], position = _b[1];
var combinedOptions = __assign(__assign({}, options), { position: position || options.position, content: _this._elementRef.nativeElement });
return combinedOptions;
}));
};
MapInfoWindow.decorators = [
{ type: Directive, args: [{
selector: 'map-info-window',
host: { 'style': 'display: none' },
},] }
];
/** @nocollapse */
MapInfoWindow.ctorParameters = function () { return [
{ type: GoogleMap },
{ type: ElementRef }
]; };
MapInfoWindow.propDecorators = {
options: [{ type: Input }],
position: [{ type: Input }],
closeclick: [{ type: Output }],
contentChanged: [{ type: Output }],
domready: [{ type: Output }],
positionChanged: [{ type: Output }],
zindexChanged: [{ type: Output }]
};
return MapInfoWindow;
}());
/**
* @license
* Copyright Google LLC All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://angular.io/license
*/
/**
* Default options for the Google Maps marker component. Displays a marker

@@ -543,2 +724,9 @@ * at the Googleplex.

this._googleMap = _googleMap;
this._eventManager = new MapEventManager();
this._options = new BehaviorSubject(DEFAULT_MARKER_OPTIONS);
this._title = new BehaviorSubject(undefined);
this._position = new BehaviorSubject(undefined);
this._label = new BehaviorSubject(undefined);
this._clickable = new BehaviorSubject(undefined);
this._destroy = new Subject();
/**

@@ -548,3 +736,3 @@ * See

*/
this.animationChanged = new EventEmitter();
this.animationChanged = this._eventManager.getLazyEmitter('animation_changed');
/**

@@ -554,3 +742,3 @@ * See

*/
this.mapClick = new EventEmitter();
this.mapClick = this._eventManager.getLazyEmitter('click');
/**

@@ -560,3 +748,3 @@ * See

*/
this.clickableChanged = new EventEmitter();
this.clickableChanged = this._eventManager.getLazyEmitter('clickable_changed');
/**

@@ -566,3 +754,3 @@ * See

*/
this.cursorChanged = new EventEmitter();
this.cursorChanged = this._eventManager.getLazyEmitter('cursor_changed');
/**

@@ -572,3 +760,3 @@ * See

*/
this.mapDblclick = new EventEmitter();
this.mapDblclick = this._eventManager.getLazyEmitter('dblclick');
/**

@@ -578,3 +766,3 @@ * See

*/
this.mapDrag = new EventEmitter();
this.mapDrag = this._eventManager.getLazyEmitter('drag');
/**

@@ -584,3 +772,3 @@ * See

*/
this.mapDragend = new EventEmitter();
this.mapDragend = this._eventManager.getLazyEmitter('dragend');
/**

@@ -590,3 +778,3 @@ * See

*/
this.draggableChanged = new EventEmitter();
this.draggableChanged = this._eventManager.getLazyEmitter('draggable_changed');
/**

@@ -596,3 +784,3 @@ * See

*/
this.mapDragstart = new EventEmitter();
this.mapDragstart = this._eventManager.getLazyEmitter('dragstart');
/**

@@ -602,3 +790,3 @@ * See

*/
this.flatChanged = new EventEmitter();
this.flatChanged = this._eventManager.getLazyEmitter('flat_changed');
/**

@@ -608,3 +796,3 @@ * See

*/
this.iconChanged = new EventEmitter();
this.iconChanged = this._eventManager.getLazyEmitter('icon_changed');
/**

@@ -614,3 +802,3 @@ * See

*/
this.mapMousedown = new EventEmitter();
this.mapMousedown = this._eventManager.getLazyEmitter('mousedown');
/**

@@ -620,3 +808,3 @@ * See

*/
this.mapMouseout = new EventEmitter();
this.mapMouseout = this._eventManager.getLazyEmitter('mouseout');
/**

@@ -626,3 +814,3 @@ * See

*/
this.mapMouseover = new EventEmitter();
this.mapMouseover = this._eventManager.getLazyEmitter('mouseover');
/**

@@ -632,3 +820,3 @@ * See

*/
this.mapMouseup = new EventEmitter();
this.mapMouseup = this._eventManager.getLazyEmitter('mouseup');
/**

@@ -638,3 +826,3 @@ * See

*/
this.positionChanged = new EventEmitter();
this.positionChanged = this._eventManager.getLazyEmitter('position_changed');
/**

@@ -644,3 +832,3 @@ * See

*/
this.mapRightclick = new EventEmitter();
this.mapRightclick = this._eventManager.getLazyEmitter('rightclick');
/**

@@ -650,3 +838,3 @@ * See

*/
this.shapeChanged = new EventEmitter();
this.shapeChanged = this._eventManager.getLazyEmitter('shape_changed');
/**

@@ -656,3 +844,3 @@ * See

*/
this.titleChanged = new EventEmitter();
this.titleChanged = this._eventManager.getLazyEmitter('title_changed');
/**

@@ -662,3 +850,3 @@ * See

*/
this.visibleChanged = new EventEmitter();
this.visibleChanged = this._eventManager.getLazyEmitter('visible_changed');
/**

@@ -668,10 +856,3 @@ * See

*/
this.zindexChanged = new EventEmitter();
this._options = new BehaviorSubject(DEFAULT_MARKER_OPTIONS);
this._title = new BehaviorSubject(undefined);
this._position = new BehaviorSubject(undefined);
this._label = new BehaviorSubject(undefined);
this._clickable = new BehaviorSubject(undefined);
this._destroy = new Subject();
this._listeners = [];
this.zindexChanged = this._eventManager.getLazyEmitter('zindex_changed');
}

@@ -719,3 +900,3 @@ Object.defineProperty(MapMarker.prototype, "options", {

_this._marker.setMap(_this._googleMap._googleMap);
_this._initializeEventHandlers();
_this._eventManager.setTarget(_this._marker);
});

@@ -731,3 +912,3 @@ this._watchForOptionsChanges();

this._destroy.complete();
this._clearListeners();
this._eventManager.destroy();
if (this._marker) {

@@ -870,64 +1051,2 @@ this._marker.setMap(null);

};
MapMarker.prototype._initializeEventHandlers = function () {
var _this = this;
// Ensure that we don't leak if called multiple times.
this._clearListeners();
var eventHandlers = new Map([
['animation_changed', this.animationChanged],
['clickable_changed', this.clickableChanged],
['cursor_changed', this.cursorChanged],
['draggable_changed', this.draggableChanged],
['flat_changed', this.flatChanged],
['icon_changed', this.iconChanged],
['position_changed', this.positionChanged],
['shape_changed', this.shapeChanged],
['title_changed', this.titleChanged],
['visible_changed', this.visibleChanged],
['zindex_changed', this.zindexChanged],
]);
var mouseEventHandlers = new Map([
['click', this.mapClick],
['dblclick', this.mapDblclick],
['drag', this.mapDrag],
['dragend', this.mapDragend],
['dragstart', this.mapDragstart],
['mousedown', this.mapMousedown],
['mouseout', this.mapMouseout],
['mouseover', this.mapMouseover],
['mouseup', this.mapMouseup],
['rightclick', this.mapRightclick],
]);
eventHandlers.forEach(function (eventHandler, name) {
if (eventHandler.observers.length > 0) {
_this._listeners.push(_this._marker.addListener(name, function () {
eventHandler.emit();
}));
}
});
mouseEventHandlers.forEach(function (eventHandler, name) {
if (eventHandler.observers.length > 0) {
_this._listeners.push(_this._marker.addListener(name, function (event) {
eventHandler.emit(event);
}));
}
});
};
/** Clears all currently-registered event listeners. */
MapMarker.prototype._clearListeners = function () {
var e_1, _a;
try {
for (var _b = __values(this._listeners), _c = _b.next(); !_c.done; _c = _b.next()) {
var listener = _c.value;
listener.remove();
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_1) throw e_1.error; }
}
this._listeners = [];
};
MapMarker.decorators = [

@@ -984,43 +1103,59 @@ { type: Component, args: [{

/**
* Angular component that renders a Google Maps info window via the Google Maps JavaScript API.
* @see developers.google.com/maps/documentation/javascript/reference/info-window
* Angular component that renders a Google Maps Polyline via the Google Maps JavaScript API.
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline
*/
var MapInfoWindow = /** @class */ (function () {
function MapInfoWindow(_googleMap, _elementRef) {
this._googleMap = _googleMap;
this._elementRef = _elementRef;
var MapPolyline = /** @class */ (function () {
function MapPolyline(_map) {
this._map = _map;
this._eventManager = new MapEventManager();
this._options = new BehaviorSubject({});
this._path = new BehaviorSubject(undefined);
this._destroyed = new Subject();
this._listeners = [];
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.closeclick
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.click
*/
this.closeclick = new EventEmitter();
this.polylineClick = this._eventManager.getLazyEmitter('click');
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.content_changed
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.dblclick
*/
this.contentChanged = new EventEmitter();
this.polylineDblclick = this._eventManager.getLazyEmitter('dblclick');
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.domready
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.drag
*/
this.domready = new EventEmitter();
this.polylineDrag = this._eventManager.getLazyEmitter('drag');
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.position_changed
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.dragend
*/
this.positionChanged = new EventEmitter();
this.polylineDragend = this._eventManager.getLazyEmitter('dragend');
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.zindex_changed
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.dragstart
*/
this.zindexChanged = new EventEmitter();
this._options = new BehaviorSubject({});
this._position = new BehaviorSubject(undefined);
this._listeners = [];
this._destroy = new Subject();
this.polylineDragstart = this._eventManager.getLazyEmitter('dragstart');
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mousedown
*/
this.polylineMousedown = this._eventManager.getLazyEmitter('mousedown');
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mousemove
*/
this.polylineMousemove = this._eventManager.getLazyEmitter('mousemove');
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mouseout
*/
this.polylineMouseout = this._eventManager.getLazyEmitter('mouseout');
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mouseover
*/
this.polylineMouseover = this._eventManager.getLazyEmitter('mouseover');
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.mouseup
*/
this.polylineMouseup = this._eventManager.getLazyEmitter('mouseup');
/**
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.rightclick
*/
this.polylineRightclick = this._eventManager.getLazyEmitter('rightclick');
}
Object.defineProperty(MapInfoWindow.prototype, "options", {
Object.defineProperty(MapPolyline.prototype, "options", {
set: function (options) {

@@ -1032,5 +1167,5 @@ this._options.next(options || {});

});
Object.defineProperty(MapInfoWindow.prototype, "position", {
set: function (position) {
this._position.next(position);
Object.defineProperty(MapPolyline.prototype, "path", {
set: function (path) {
this._path.next(path);
},

@@ -1040,18 +1175,18 @@ enumerable: true,

});
MapInfoWindow.prototype.ngOnInit = function () {
MapPolyline.prototype.ngOnInit = function () {
var _this = this;
this._combineOptions().pipe(takeUntil(this._destroy)).subscribe(function (options) {
if (_this._infoWindow) {
_this._infoWindow.setOptions(options);
}
else {
_this._infoWindow = new google.maps.InfoWindow(options);
_this._initializeEventHandlers();
}
var combinedOptionsChanges = this._combineOptions();
combinedOptionsChanges.pipe(take(1)).subscribe(function (options) {
_this._polyline = new google.maps.Polyline(options);
_this._polyline.setMap(_this._map._googleMap);
_this._eventManager.setTarget(_this._polyline);
});
this._watchForOptionsChanges();
this._watchForPathChanges();
};
MapInfoWindow.prototype.ngOnDestroy = function () {
MapPolyline.prototype.ngOnDestroy = function () {
var e_1, _a;
this._destroy.next();
this._destroy.complete();
this._eventManager.destroy();
this._destroyed.next();
this._destroyed.complete();
try {

@@ -1070,111 +1205,75 @@ for (var _b = __values(this._listeners), _c = _b.next(); !_c.done; _c = _b.next()) {

}
this.close();
this._polyline.setMap(null);
};
/**
* See developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.close
* @see
* developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.getDraggable
*/
MapInfoWindow.prototype.close = function () {
if (this._infoWindow) {
this._infoWindow.close();
}
MapPolyline.prototype.getDraggable = function () {
return this._polyline.getDraggable();
};
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.getContent
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.getEditable
*/
MapInfoWindow.prototype.getContent = function () {
return this._infoWindow.getContent();
MapPolyline.prototype.getEditable = function () {
return this._polyline.getEditable();
};
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window
* #InfoWindow.getPosition
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.getPath
*/
MapInfoWindow.prototype.getPosition = function () {
return this._infoWindow.getPosition() || null;
MapPolyline.prototype.getPath = function () {
return this._polyline.getPath();
};
/**
* See
* developers.google.com/maps/documentation/javascript/reference/info-window#InfoWindow.getZIndex
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.getVisible
*/
MapInfoWindow.prototype.getZIndex = function () {
return this._infoWindow.getZIndex();
MapPolyline.prototype.getVisible = function () {
return this._polyline.getVisible();
};
/**
* Opens the MapInfoWindow using the provided MapMarker as the anchor. If the anchor is not set,
* then the position property of the options input is used instead.
*/
MapInfoWindow.prototype.open = function (anchor) {
var marker = anchor ? anchor._marker : undefined;
if (this._googleMap._googleMap) {
this._elementRef.nativeElement.style.display = '';
this._infoWindow.open(this._googleMap._googleMap, marker);
}
};
MapInfoWindow.prototype._combineOptions = function () {
var _this = this;
return combineLatest([this._options, this._position]).pipe(map(function (_a) {
var _b = __read(_a, 2), options = _b[0], position = _b[1];
var combinedOptions = __assign(__assign({}, options), { position: position || options.position, content: _this._elementRef.nativeElement });
MapPolyline.prototype._combineOptions = function () {
return combineLatest([this._options, this._path]).pipe(map(function (_a) {
var _b = __read(_a, 2), options = _b[0], path = _b[1];
var combinedOptions = __assign(__assign({}, options), { path: path || options.path });
return combinedOptions;
}));
};
MapInfoWindow.prototype._initializeEventHandlers = function () {
MapPolyline.prototype._watchForOptionsChanges = function () {
var _this = this;
// Ensure that we don't leak if called multiple times.
this._clearListeners();
var eventHandlers = new Map([
['closeclick', this.closeclick],
['content_changed', this.contentChanged],
['domready', this.domready],
['position_changed', this.positionChanged],
['zindex_changed', this.zindexChanged],
]);
eventHandlers.forEach(function (eventHandler, name) {
if (eventHandler.observers.length > 0) {
_this._listeners.push(_this._infoWindow.addListener(name, function () {
eventHandler.emit();
}));
}
this._options.pipe(takeUntil(this._destroyed)).subscribe(function (options) {
_this._polyline.setOptions(options);
});
};
/** Clears all currently-registered event listeners. */
MapInfoWindow.prototype._clearListeners = function () {
var e_2, _a;
try {
for (var _b = __values(this._listeners), _c = _b.next(); !_c.done; _c = _b.next()) {
var listener = _c.value;
listener.remove();
MapPolyline.prototype._watchForPathChanges = function () {
var _this = this;
this._path.pipe(takeUntil(this._destroyed)).subscribe(function (path) {
if (path) {
_this._polyline.setPath(path);
}
}
catch (e_2_1) { e_2 = { error: e_2_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_2) throw e_2.error; }
}
this._listeners = [];
});
};
MapInfoWindow.decorators = [
MapPolyline.decorators = [
{ type: Directive, args: [{
selector: 'map-info-window',
host: { 'style': 'display: none' },
selector: 'map-polyline',
},] }
];
/** @nocollapse */
MapInfoWindow.ctorParameters = function () { return [
{ type: GoogleMap },
{ type: ElementRef }
MapPolyline.ctorParameters = function () { return [
{ type: GoogleMap }
]; };
MapInfoWindow.propDecorators = {
MapPolyline.propDecorators = {
options: [{ type: Input }],
position: [{ type: Input }],
closeclick: [{ type: Output }],
contentChanged: [{ type: Output }],
domready: [{ type: Output }],
positionChanged: [{ type: Output }],
zindexChanged: [{ type: Output }]
path: [{ type: Input }],
polylineClick: [{ type: Output }],
polylineDblclick: [{ type: Output }],
polylineDrag: [{ type: Output }],
polylineDragend: [{ type: Output }],
polylineDragstart: [{ type: Output }],
polylineMousedown: [{ type: Output }],
polylineMousemove: [{ type: Output }],
polylineMouseout: [{ type: Output }],
polylineMouseover: [{ type: Output }],
polylineMouseup: [{ type: Output }],
polylineRightclick: [{ type: Output }]
};
return MapInfoWindow;
return MapPolyline;
}());

@@ -1193,2 +1292,3 @@

MapMarker,
MapPolyline,
];

@@ -1219,3 +1319,3 @@ var GoogleMapsModule = /** @class */ (function () {

export { GoogleMap, GoogleMapsModule, MapInfoWindow, MapMarker };
export { GoogleMap, GoogleMapsModule, MapInfoWindow, MapMarker, MapPolyline };
//# sourceMappingURL=google-maps.js.map

@@ -9,3 +9,4 @@ /**

/// <reference types="googlemaps" />
import { ElementRef, EventEmitter, OnChanges, OnDestroy, OnInit } from '@angular/core';
import { ElementRef, OnChanges, OnDestroy, OnInit } from '@angular/core';
import { Observable } from 'rxjs';
/**

@@ -31,2 +32,12 @@ * Extends the Google Map interface due to the Definitely Typed implementation

private readonly _elementRef;
private _eventManager;
/** Whether we're currently rendering inside a browser. */
private _isBrowser;
private _googleMapChanges;
private readonly _options;
private readonly _center;
private readonly _zoom;
private readonly _destroy;
private _mapEl;
_googleMap: UpdatedGoogleMap;
height: string;

@@ -41,3 +52,3 @@ width: string;

*/
boundsChanged: EventEmitter<void>;
boundsChanged: Observable<void>;
/**

@@ -47,3 +58,3 @@ * See

*/
centerChanged: EventEmitter<void>;
centerChanged: Observable<void>;
/**

@@ -53,3 +64,3 @@ * See

*/
mapClick: EventEmitter<google.maps.MouseEvent | google.maps.IconMouseEvent>;
mapClick: Observable<google.maps.MouseEvent | google.maps.IconMouseEvent>;
/**

@@ -59,3 +70,3 @@ * See

*/
mapDblclick: EventEmitter<google.maps.MouseEvent>;
mapDblclick: Observable<google.maps.MouseEvent>;
/**

@@ -65,3 +76,3 @@ * See

*/
mapDrag: EventEmitter<void>;
mapDrag: Observable<void>;
/**

@@ -71,3 +82,3 @@ * See

*/
mapDragend: EventEmitter<void>;
mapDragend: Observable<void>;
/**

@@ -77,3 +88,3 @@ * See

*/
mapDragstart: EventEmitter<void>;
mapDragstart: Observable<void>;
/**

@@ -83,3 +94,3 @@ * See

*/
headingChanged: EventEmitter<void>;
headingChanged: Observable<void>;
/**

@@ -89,3 +100,3 @@ * See

*/
idle: EventEmitter<void>;
idle: Observable<void>;
/**

@@ -95,3 +106,3 @@ * See

*/
maptypeidChanged: EventEmitter<void>;
maptypeidChanged: Observable<void>;
/**

@@ -101,3 +112,3 @@ * See

*/
mapMousemove: EventEmitter<google.maps.MouseEvent>;
mapMousemove: Observable<google.maps.MouseEvent>;
/**

@@ -107,3 +118,3 @@ * See

*/
mapMouseout: EventEmitter<google.maps.MouseEvent>;
mapMouseout: Observable<google.maps.MouseEvent>;
/**

@@ -113,3 +124,3 @@ * See

*/
mapMouseover: EventEmitter<google.maps.MouseEvent>;
mapMouseover: Observable<google.maps.MouseEvent>;
/**

@@ -119,3 +130,3 @@ * See

*/
projectionChanged: EventEmitter<void>;
projectionChanged: Observable<void>;
/**

@@ -125,3 +136,3 @@ * See

*/
mapRightclick: EventEmitter<google.maps.MouseEvent>;
mapRightclick: Observable<google.maps.MouseEvent>;
/**

@@ -131,3 +142,3 @@ * See

*/
tilesloaded: EventEmitter<void>;
tilesloaded: Observable<void>;
/**

@@ -137,3 +148,3 @@ * See

*/
tiltChanged: EventEmitter<void>;
tiltChanged: Observable<void>;
/**

@@ -143,13 +154,3 @@ * See

*/
zoomChanged: EventEmitter<void>;
private _mapEl;
_googleMap: UpdatedGoogleMap;
/** Whether we're currently rendering inside a browser. */
private _isBrowser;
private _googleMapChanges;
private _listeners;
private readonly _options;
private readonly _center;
private readonly _zoom;
private readonly _destroy;
zoomChanged: Observable<void>;
constructor(_elementRef: ElementRef,

@@ -256,5 +257,4 @@ /**

private _watchForZoomChanges;
private _initializeEventHandlers;
/** Clears all currently-registered event listeners. */
private _clearListeners;
/** Asserts that the map has been initialized. */
private _assertInitialized;
}

@@ -1,1 +0,1 @@

{"__symbolic":"module","version":4,"metadata":{"GoogleMap":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":59,"character":1},"arguments":[{"selector":"google-map","changeDetection":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectionStrategy","line":61,"character":19},"member":"OnPush"},"template":"<div class=\"map-container\"></div><ng-content></ng-content>","encapsulation":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewEncapsulation","line":63,"character":17},"member":"None"}}]}],"members":{"height":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":66,"character":3}}]}],"width":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":68,"character":3}}]}],"center":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":70,"character":3}}]}],"zoom":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":74,"character":3}}]}],"options":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":78,"character":3}}]}],"boundsChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":87,"character":3}}]}],"centerChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":93,"character":3}}]}],"mapClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":99,"character":3}}]}],"mapDblclick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":105,"character":3}}]}],"mapDrag":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":111,"character":3}}]}],"mapDragend":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":117,"character":3}}]}],"mapDragstart":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":123,"character":3}}]}],"headingChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":129,"character":3}}]}],"idle":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":135,"character":3}}]}],"maptypeidChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":141,"character":3}}]}],"mapMousemove":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":147,"character":3}}]}],"mapMouseout":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":153,"character":3}}]}],"mapMouseover":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":159,"character":3}}]}],"projectionChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":165,"character":3}}]}],"mapRightclick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":171,"character":3}}]}],"tilesloaded":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":177,"character":3}}]}],"tiltChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":183,"character":3}}]}],"zoomChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":189,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":213,"character":5}},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":213,"character":17},"arguments":[{"__symbolic":"reference","module":"@angular/core","name":"PLATFORM_ID","line":213,"character":24}]}]],"parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":208,"character":34},{"__symbolic":"reference","name":"Object"}]}],"ngOnChanges":[{"__symbolic":"method"}],"ngOnInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"fitBounds":[{"__symbolic":"method"}],"panBy":[{"__symbolic":"method"}],"panTo":[{"__symbolic":"method"}],"panToBounds":[{"__symbolic":"method"}],"getBounds":[{"__symbolic":"method"}],"getCenter":[{"__symbolic":"method"}],"getClickableIcons":[{"__symbolic":"method"}],"getHeading":[{"__symbolic":"method"}],"getMapTypeId":[{"__symbolic":"method"}],"getProjection":[{"__symbolic":"method"}],"getStreetView":[{"__symbolic":"method"}],"getTilt":[{"__symbolic":"method"}],"getZoom":[{"__symbolic":"method"}],"_setSize":[{"__symbolic":"method"}],"_combineOptions":[{"__symbolic":"method"}],"_initializeMap":[{"__symbolic":"method"}],"_watchForOptionsChanges":[{"__symbolic":"method"}],"_watchForCenterChanges":[{"__symbolic":"method"}],"_watchForZoomChanges":[{"__symbolic":"method"}],"_initializeEventHandlers":[{"__symbolic":"method"}],"_clearListeners":[{"__symbolic":"method"}]}},"MapMarker":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":38,"character":1},"arguments":[{"selector":"map-marker","template":"<ng-content></ng-content>","changeDetection":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectionStrategy","line":41,"character":19},"member":"OnPush"},"encapsulation":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewEncapsulation","line":42,"character":17},"member":"None"}}]}],"members":{"options":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":45,"character":3}}]}],"title":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":50,"character":3}}]}],"position":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":55,"character":3}}]}],"label":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":60,"character":3}}]}],"clickable":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":65,"character":3}}]}],"animationChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":74,"character":3}}]}],"mapClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":80,"character":3}}]}],"clickableChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":86,"character":3}}]}],"cursorChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":92,"character":3}}]}],"mapDblclick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":98,"character":3}}]}],"mapDrag":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":104,"character":3}}]}],"mapDragend":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":110,"character":3}}]}],"draggableChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":116,"character":3}}]}],"mapDragstart":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":122,"character":3}}]}],"flatChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":128,"character":3}}]}],"iconChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":134,"character":3}}]}],"mapMousedown":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":140,"character":3}}]}],"mapMouseout":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":146,"character":3}}]}],"mapMouseover":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":152,"character":3}}]}],"mapMouseup":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":158,"character":3}}]}],"positionChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":164,"character":3}}]}],"mapRightclick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":170,"character":3}}]}],"shapeChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":176,"character":3}}]}],"titleChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":182,"character":3}}]}],"visibleChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":188,"character":3}}]}],"zindexChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":194,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"GoogleMap"}]}],"ngOnInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"getAnimation":[{"__symbolic":"method"}],"getClickable":[{"__symbolic":"method"}],"getCursor":[{"__symbolic":"method"}],"getDraggable":[{"__symbolic":"method"}],"getIcon":[{"__symbolic":"method"}],"getLabel":[{"__symbolic":"method"}],"getOpacity":[{"__symbolic":"method"}],"getPosition":[{"__symbolic":"method"}],"getShape":[{"__symbolic":"method"}],"getTitle":[{"__symbolic":"method"}],"getVisible":[{"__symbolic":"method"}],"getZIndex":[{"__symbolic":"method"}],"_combineOptions":[{"__symbolic":"method"}],"_watchForOptionsChanges":[{"__symbolic":"method"}],"_watchForTitleChanges":[{"__symbolic":"method"}],"_watchForPositionChanges":[{"__symbolic":"method"}],"_watchForLabelChanges":[{"__symbolic":"method"}],"_watchForClickableChanges":[{"__symbolic":"method"}],"_initializeEventHandlers":[{"__symbolic":"method"}],"_clearListeners":[{"__symbolic":"method"}]}},"GoogleMapsModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":20,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"GoogleMap"},{"__symbolic":"reference","name":"MapInfoWindow"},{"__symbolic":"reference","name":"MapMarker"}],"exports":[{"__symbolic":"reference","name":"GoogleMap"},{"__symbolic":"reference","name":"MapInfoWindow"},{"__symbolic":"reference","name":"MapMarker"}]}]}],"members":{}},"MapInfoWindow":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":30,"character":1},"arguments":[{"selector":"map-info-window","host":{"style":"display: none","$quoted$":["style"]}}]}],"members":{"options":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":35,"character":3}}]}],"position":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":40,"character":3}}]}],"closeclick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":49,"character":3}}]}],"contentChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":56,"character":3}}]}],"domready":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":62,"character":3}}]}],"positionChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":69,"character":3}}]}],"zindexChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":76,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"GoogleMap"},{"__symbolic":"reference","name":"ElementRef","module":"@angular/core","arguments":[{"__symbolic":"error","message":"Could not resolve type","line":89,"character":46,"context":{"typeName":"HTMLElement"},"module":"./map-info-window/map-info-window"}]}]}],"ngOnInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"close":[{"__symbolic":"method"}],"getContent":[{"__symbolic":"method"}],"getPosition":[{"__symbolic":"method"}],"getZIndex":[{"__symbolic":"method"}],"open":[{"__symbolic":"method"}],"_combineOptions":[{"__symbolic":"method"}],"_initializeEventHandlers":[{"__symbolic":"method"}],"_clearListeners":[{"__symbolic":"method"}]}}},"origins":{"GoogleMap":"./google-map/google-map","MapMarker":"./map-marker/map-marker","GoogleMapsModule":"./google-maps-module","MapInfoWindow":"./map-info-window/map-info-window"},"importAs":"@angular/google-maps"}
{"__symbolic":"module","version":4,"metadata":{"GoogleMap":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":59,"character":1},"arguments":[{"selector":"google-map","changeDetection":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectionStrategy","line":61,"character":19},"member":"OnPush"},"template":"<div class=\"map-container\"></div><ng-content></ng-content>","encapsulation":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewEncapsulation","line":63,"character":17},"member":"None"}}]}],"members":{"height":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":80,"character":3}}]}],"width":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":82,"character":3}}]}],"center":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":84,"character":3}}]}],"zoom":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":88,"character":3}}]}],"options":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":92,"character":3}}]}],"boundsChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":101,"character":3}}]}],"centerChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":108,"character":3}}]}],"mapClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":115,"character":3}}]}],"mapDblclick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":123,"character":3}}]}],"mapDrag":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":131,"character":3}}]}],"mapDragend":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":137,"character":3}}]}],"mapDragstart":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":143,"character":3}}]}],"headingChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":149,"character":3}}]}],"idle":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":156,"character":3}}]}],"maptypeidChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":162,"character":3}}]}],"mapMousemove":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":169,"character":3}}]}],"mapMouseout":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":177,"character":3}}]}],"mapMouseover":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":185,"character":3}}]}],"projectionChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":193,"character":3}}]}],"mapRightclick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":201,"character":3}}]}],"tilesloaded":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":209,"character":3}}]}],"tiltChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":215,"character":3}}]}],"zoomChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":221,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":229,"character":5}},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":229,"character":17},"arguments":[{"__symbolic":"reference","module":"@angular/core","name":"PLATFORM_ID","line":229,"character":24}]}]],"parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":224,"character":34},{"__symbolic":"reference","name":"Object"}]}],"ngOnChanges":[{"__symbolic":"method"}],"ngOnInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"fitBounds":[{"__symbolic":"method"}],"panBy":[{"__symbolic":"method"}],"panTo":[{"__symbolic":"method"}],"panToBounds":[{"__symbolic":"method"}],"getBounds":[{"__symbolic":"method"}],"getCenter":[{"__symbolic":"method"}],"getClickableIcons":[{"__symbolic":"method"}],"getHeading":[{"__symbolic":"method"}],"getMapTypeId":[{"__symbolic":"method"}],"getProjection":[{"__symbolic":"method"}],"getStreetView":[{"__symbolic":"method"}],"getTilt":[{"__symbolic":"method"}],"getZoom":[{"__symbolic":"method"}],"_setSize":[{"__symbolic":"method"}],"_combineOptions":[{"__symbolic":"method"}],"_initializeMap":[{"__symbolic":"method"}],"_watchForOptionsChanges":[{"__symbolic":"method"}],"_watchForCenterChanges":[{"__symbolic":"method"}],"_watchForZoomChanges":[{"__symbolic":"method"}],"_assertInitialized":[{"__symbolic":"method"}]}},"GoogleMapsModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":22,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"GoogleMap"},{"__symbolic":"reference","name":"MapInfoWindow"},{"__symbolic":"reference","name":"MapMarker"},{"__symbolic":"reference","name":"MapPolyline"}],"exports":[{"__symbolic":"reference","name":"GoogleMap"},{"__symbolic":"reference","name":"MapInfoWindow"},{"__symbolic":"reference","name":"MapMarker"},{"__symbolic":"reference","name":"MapPolyline"}]}]}],"members":{}},"MapInfoWindow":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":30,"character":1},"arguments":[{"selector":"map-info-window","host":{"style":"display: none","$quoted$":["style"]}}]}],"members":{"options":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":42,"character":3}}]}],"position":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":47,"character":3}}]}],"closeclick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":56,"character":3}}]}],"contentChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":63,"character":3}}]}],"domready":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":70,"character":3}}]}],"positionChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":77,"character":3}}]}],"zindexChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":85,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"GoogleMap"},{"__symbolic":"reference","name":"ElementRef","module":"@angular/core","arguments":[{"__symbolic":"error","message":"Could not resolve type","line":89,"character":46,"context":{"typeName":"HTMLElement"},"module":"./map-info-window/map-info-window"}]}]}],"ngOnInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"close":[{"__symbolic":"method"}],"getContent":[{"__symbolic":"method"}],"getPosition":[{"__symbolic":"method"}],"getZIndex":[{"__symbolic":"method"}],"open":[{"__symbolic":"method"}],"_combineOptions":[{"__symbolic":"method"}]}},"MapMarker":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":38,"character":1},"arguments":[{"selector":"map-marker","template":"<ng-content></ng-content>","changeDetection":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectionStrategy","line":41,"character":19},"member":"OnPush"},"encapsulation":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewEncapsulation","line":42,"character":17},"member":"None"}}]}],"members":{"options":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":56,"character":3}}]}],"title":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":61,"character":3}}]}],"position":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":66,"character":3}}]}],"label":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":71,"character":3}}]}],"clickable":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":76,"character":3}}]}],"animationChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":85,"character":3}}]}],"mapClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":92,"character":3}}]}],"clickableChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":100,"character":3}}]}],"cursorChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":107,"character":3}}]}],"mapDblclick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":114,"character":3}}]}],"mapDrag":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":122,"character":3}}]}],"mapDragend":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":130,"character":3}}]}],"draggableChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":138,"character":3}}]}],"mapDragstart":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":145,"character":3}}]}],"flatChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":153,"character":3}}]}],"iconChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":159,"character":3}}]}],"mapMousedown":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":165,"character":3}}]}],"mapMouseout":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":173,"character":3}}]}],"mapMouseover":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":181,"character":3}}]}],"mapMouseup":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":189,"character":3}}]}],"positionChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":197,"character":3}}]}],"mapRightclick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":204,"character":3}}]}],"shapeChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":212,"character":3}}]}],"titleChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":219,"character":3}}]}],"visibleChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":226,"character":3}}]}],"zindexChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":233,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"GoogleMap"}]}],"ngOnInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"getAnimation":[{"__symbolic":"method"}],"getClickable":[{"__symbolic":"method"}],"getCursor":[{"__symbolic":"method"}],"getDraggable":[{"__symbolic":"method"}],"getIcon":[{"__symbolic":"method"}],"getLabel":[{"__symbolic":"method"}],"getOpacity":[{"__symbolic":"method"}],"getPosition":[{"__symbolic":"method"}],"getShape":[{"__symbolic":"method"}],"getTitle":[{"__symbolic":"method"}],"getVisible":[{"__symbolic":"method"}],"getZIndex":[{"__symbolic":"method"}],"_combineOptions":[{"__symbolic":"method"}],"_watchForOptionsChanges":[{"__symbolic":"method"}],"_watchForTitleChanges":[{"__symbolic":"method"}],"_watchForPositionChanges":[{"__symbolic":"method"}],"_watchForLabelChanges":[{"__symbolic":"method"}],"_watchForClickableChanges":[{"__symbolic":"method"}]}},"MapPolyline":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":28,"character":1},"arguments":[{"selector":"map-polyline"}]}],"members":{"options":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":43,"character":3}}]}],"path":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":48,"character":3}}]}],"polylineClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":57,"character":3}}]}],"polylineDblclick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":64,"character":3}}]}],"polylineDrag":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":71,"character":3}}]}],"polylineDragend":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":78,"character":3}}]}],"polylineDragstart":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":85,"character":3}}]}],"polylineMousedown":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":92,"character":3}}]}],"polylineMousemove":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":99,"character":3}}]}],"polylineMouseout":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":106,"character":3}}]}],"polylineMouseover":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":113,"character":3}}]}],"polylineMouseup":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":120,"character":3}}]}],"polylineRightclick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":127,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"GoogleMap"}]}],"ngOnInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"getDraggable":[{"__symbolic":"method"}],"getEditable":[{"__symbolic":"method"}],"getPath":[{"__symbolic":"method"}],"getVisible":[{"__symbolic":"method"}],"_combineOptions":[{"__symbolic":"method"}],"_watchForOptionsChanges":[{"__symbolic":"method"}],"_watchForPathChanges":[{"__symbolic":"method"}]}}},"origins":{"GoogleMap":"./google-map/google-map","GoogleMapsModule":"./google-maps-module","MapInfoWindow":"./map-info-window/map-info-window","MapMarker":"./map-marker/map-marker","MapPolyline":"./map-polyline/map-polyline"},"importAs":"@angular/google-maps"}

@@ -9,3 +9,4 @@ /**

/// <reference types="googlemaps" />
import { ElementRef, EventEmitter, OnDestroy, OnInit } from '@angular/core';
import { ElementRef, OnDestroy, OnInit } from '@angular/core';
import { Observable } from 'rxjs';
import { GoogleMap } from '../google-map/google-map';

@@ -20,2 +21,7 @@ import { MapMarker } from '../map-marker/map-marker';

private _elementRef;
private _eventManager;
private readonly _options;
private readonly _position;
private readonly _destroy;
private _infoWindow?;
options: google.maps.InfoWindowOptions;

@@ -27,3 +33,3 @@ position: google.maps.LatLngLiteral | google.maps.LatLng;

*/
closeclick: EventEmitter<void>;
closeclick: Observable<void>;
/**

@@ -34,3 +40,3 @@ * See

*/
contentChanged: EventEmitter<void>;
contentChanged: Observable<void>;
/**

@@ -40,3 +46,3 @@ * See

*/
domready: EventEmitter<void>;
domready: Observable<void>;
/**

@@ -47,3 +53,3 @@ * See

*/
positionChanged: EventEmitter<void>;
positionChanged: Observable<void>;
/**

@@ -54,8 +60,3 @@ * See

*/
zindexChanged: EventEmitter<void>;
private readonly _options;
private readonly _position;
private _listeners;
private readonly _destroy;
private _infoWindow?;
zindexChanged: Observable<void>;
constructor(_googleMap: GoogleMap, _elementRef: ElementRef<HTMLElement>);

@@ -90,5 +91,2 @@ ngOnInit(): void;

private _combineOptions;
private _initializeEventHandlers;
/** Clears all currently-registered event listeners. */
private _clearListeners;
}

@@ -9,3 +9,4 @@ /**

/// <reference types="googlemaps" />
import { EventEmitter, OnDestroy, OnInit } from '@angular/core';
import { OnDestroy, OnInit } from '@angular/core';
import { Observable } from 'rxjs';
import { GoogleMap } from '../google-map/google-map';

@@ -28,2 +29,9 @@ /**

private readonly _googleMap;
private _eventManager;
private readonly _options;
private readonly _title;
private readonly _position;
private readonly _label;
private readonly _clickable;
private readonly _destroy;
options: google.maps.MarkerOptions;

@@ -38,3 +46,3 @@ title: string;

*/
animationChanged: EventEmitter<void>;
animationChanged: Observable<void>;
/**

@@ -44,3 +52,3 @@ * See

*/
mapClick: EventEmitter<google.maps.MouseEvent>;
mapClick: Observable<google.maps.MouseEvent>;
/**

@@ -50,3 +58,3 @@ * See

*/
clickableChanged: EventEmitter<void>;
clickableChanged: Observable<void>;
/**

@@ -56,3 +64,3 @@ * See

*/
cursorChanged: EventEmitter<void>;
cursorChanged: Observable<void>;
/**

@@ -62,3 +70,3 @@ * See

*/
mapDblclick: EventEmitter<google.maps.MouseEvent>;
mapDblclick: Observable<google.maps.MouseEvent>;
/**

@@ -68,3 +76,3 @@ * See

*/
mapDrag: EventEmitter<google.maps.MouseEvent>;
mapDrag: Observable<google.maps.MouseEvent>;
/**

@@ -74,3 +82,3 @@ * See

*/
mapDragend: EventEmitter<google.maps.MouseEvent>;
mapDragend: Observable<google.maps.MouseEvent>;
/**

@@ -80,3 +88,3 @@ * See

*/
draggableChanged: EventEmitter<void>;
draggableChanged: Observable<void>;
/**

@@ -86,3 +94,3 @@ * See

*/
mapDragstart: EventEmitter<google.maps.MouseEvent>;
mapDragstart: Observable<google.maps.MouseEvent>;
/**

@@ -92,3 +100,3 @@ * See

*/
flatChanged: EventEmitter<void>;
flatChanged: Observable<void>;
/**

@@ -98,3 +106,3 @@ * See

*/
iconChanged: EventEmitter<void>;
iconChanged: Observable<void>;
/**

@@ -104,3 +112,3 @@ * See

*/
mapMousedown: EventEmitter<google.maps.MouseEvent>;
mapMousedown: Observable<google.maps.MouseEvent>;
/**

@@ -110,3 +118,3 @@ * See

*/
mapMouseout: EventEmitter<google.maps.MouseEvent>;
mapMouseout: Observable<google.maps.MouseEvent>;
/**

@@ -116,3 +124,3 @@ * See

*/
mapMouseover: EventEmitter<google.maps.MouseEvent>;
mapMouseover: Observable<google.maps.MouseEvent>;
/**

@@ -122,3 +130,3 @@ * See

*/
mapMouseup: EventEmitter<google.maps.MouseEvent>;
mapMouseup: Observable<google.maps.MouseEvent>;
/**

@@ -128,3 +136,3 @@ * See

*/
positionChanged: EventEmitter<void>;
positionChanged: Observable<void>;
/**

@@ -134,3 +142,3 @@ * See

*/
mapRightclick: EventEmitter<google.maps.MouseEvent>;
mapRightclick: Observable<google.maps.MouseEvent>;
/**

@@ -140,3 +148,3 @@ * See

*/
shapeChanged: EventEmitter<void>;
shapeChanged: Observable<void>;
/**

@@ -146,3 +154,3 @@ * See

*/
titleChanged: EventEmitter<void>;
titleChanged: Observable<void>;
/**

@@ -152,3 +160,3 @@ * See

*/
visibleChanged: EventEmitter<void>;
visibleChanged: Observable<void>;
/**

@@ -158,10 +166,3 @@ * See

*/
zindexChanged: EventEmitter<void>;
private readonly _options;
private readonly _title;
private readonly _position;
private readonly _label;
private readonly _clickable;
private readonly _destroy;
private _listeners;
zindexChanged: Observable<void>;
_marker?: google.maps.Marker;

@@ -237,5 +238,2 @@ constructor(_googleMap: GoogleMap);

private _watchForClickableChanges;
private _initializeEventHandlers;
/** Clears all currently-registered event listeners. */
private _clearListeners;
}
{
"name": "@angular/google-maps",
"version": "9.0.0-rc.4",
"version": "9.0.0-rc.5",
"description": "Angular Google Maps",

@@ -5,0 +5,0 @@ "main": "./bundles/google-maps.umd.js",

@@ -9,4 +9,5 @@ /**

export { GoogleMap } from './google-map/google-map';
export { MapMarker } from './map-marker/map-marker';
export { GoogleMapsModule } from './google-maps-module';
export { MapInfoWindow } from './map-info-window/map-info-window';
export { MapMarker } from './map-marker/map-marker';
export { MapPolyline } from './map-polyline/map-polyline';

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc