@boldadmin/angular-google-maps
Version:
Google Maps adapter for Angular Framework
352 lines • 23.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Injectable } from '@angular/core';
import { EventPublisher } from '@boldadmin/event-publisher';
import { Coordinates } from '../value-object/coordinates';
import { Location } from '../value-object/location';
import { AngularGoogleMapsGeocoder } from './angular-google-maps-geocoder.service';
import { GoogleMapsFactory } from './google-maps-factory.service';
var AngularGoogleMapsBuilder = /** @class */ (function () {
function AngularGoogleMapsBuilder(googleMapsFactory, geocoder, eventPublisher) {
this.googleMapsFactory = googleMapsFactory;
this.geocoder = geocoder;
this.eventPublisher = eventPublisher;
}
/**
* @template THIS
* @this {THIS}
* @param {?} mapOptions
* @return {THIS}
*/
AngularGoogleMapsBuilder.prototype.createMap = /**
* @template THIS
* @this {THIS}
* @param {?} mapOptions
* @return {THIS}
*/
function (mapOptions) {
(/** @type {?} */ (this)).map = (/** @type {?} */ (this)).googleMapsFactory.createMap(mapOptions);
return (/** @type {?} */ (this));
};
/**
* @template THIS
* @this {THIS}
* @param {?} markerOptions
* @return {THIS}
*/
AngularGoogleMapsBuilder.prototype.addCenterMarker = /**
* @template THIS
* @this {THIS}
* @param {?} markerOptions
* @return {THIS}
*/
function (markerOptions) {
(/** @type {?} */ (this)).marker = (/** @type {?} */ (this)).googleMapsFactory.createMarker(markerOptions);
(/** @type {?} */ (this)).marker.setPosition((/** @type {?} */ (this)).map.getCenter());
(/** @type {?} */ (this)).marker.setMap((/** @type {?} */ (this)).map);
(/** @type {?} */ (this)).addMarkerListeners();
return (/** @type {?} */ (this));
};
/**
* @template THIS
* @this {THIS}
* @param {?} circleOptions
* @return {THIS}
*/
AngularGoogleMapsBuilder.prototype.addCircle = /**
* @template THIS
* @this {THIS}
* @param {?} circleOptions
* @return {THIS}
*/
function (circleOptions) {
var _this = this;
(/** @type {?} */ (this)).circle = (/** @type {?} */ (this)).googleMapsFactory.createCircle(circleOptions);
(/** @type {?} */ (this)).circle.setMap((/** @type {?} */ (this)).map);
(/** @type {?} */ (this)).circle.addListener('radius_changed', (/**
* @return {?}
*/
function () { return (/** @type {?} */ (_this)).notifyLocationChange(); }));
return (/** @type {?} */ (this));
};
/**
* @template THIS
* @this {THIS}
* @param {?} polylineOptions
* @return {THIS}
*/
AngularGoogleMapsBuilder.prototype.addPolyline = /**
* @template THIS
* @this {THIS}
* @param {?} polylineOptions
* @return {THIS}
*/
function (polylineOptions) {
/** @type {?} */
var polyline = (/** @type {?} */ (this)).googleMapsFactory.createPolyline(polylineOptions);
polyline.setMap((/** @type {?} */ (this)).map);
return (/** @type {?} */ (this));
};
/**
* @template THIS
* @this {THIS}
* @param {?} markerOptions
* @return {THIS}
*/
AngularGoogleMapsBuilder.prototype.addMarker = /**
* @template THIS
* @this {THIS}
* @param {?} markerOptions
* @return {THIS}
*/
function (markerOptions) {
/** @type {?} */
var marker = (/** @type {?} */ (this)).googleMapsFactory.createMarker(markerOptions);
marker.setMap((/** @type {?} */ (this)).map);
return (/** @type {?} */ (this));
};
/**
* @template THIS
* @this {THIS}
* @return {THIS}
*/
AngularGoogleMapsBuilder.prototype.bindCircleToMarker = /**
* @template THIS
* @this {THIS}
* @return {THIS}
*/
function () {
(/** @type {?} */ (this)).circle.bindTo('center', (/** @type {?} */ (this)).marker, 'position');
return (/** @type {?} */ (this));
};
/**
* @template THIS
* @this {THIS}
* @return {THIS}
*/
AngularGoogleMapsBuilder.prototype.hideMarker = /**
* @template THIS
* @this {THIS}
* @return {THIS}
*/
function () {
(/** @type {?} */ (this)).marker.setMap(null);
return (/** @type {?} */ (this));
};
/**
* @template THIS
* @this {THIS}
* @return {THIS}
*/
AngularGoogleMapsBuilder.prototype.hideCircle = /**
* @template THIS
* @this {THIS}
* @return {THIS}
*/
function () {
(/** @type {?} */ (this)).circle.setMap(null);
return (/** @type {?} */ (this));
};
/**
* @template THIS
* @this {THIS}
* @return {THIS}
*/
AngularGoogleMapsBuilder.prototype.addSearchBox = /**
* @template THIS
* @this {THIS}
* @return {THIS}
*/
function () {
var _this = this;
/** @type {?} */
var box = (/** @type {?} */ (this)).googleMapsFactory.createSearchBox();
box.addListener('places_changed', (/**
* @return {?}
*/
function () {
/** @type {?} */
var places = box.getPlaces();
if (places[0]) {
(/** @type {?} */ (_this)).changeMapLocationAndZoom(places[0].geometry.location);
(/** @type {?} */ (_this)).changeMarkerLocation(places[0].geometry.location);
/** @type {?} */
var loc = places[0].geometry.location;
/** @type {?} */
var coordinates = new Coordinates(loc.lat(), loc.lng());
(/** @type {?} */ (_this)).eventPublisher.notify('locationChanged', new Location(coordinates, (/** @type {?} */ (_this)).circle.getRadius()));
}
}));
return (/** @type {?} */ (this));
};
/**
* @private
* @return {?}
*/
AngularGoogleMapsBuilder.prototype.addMarkerListeners = /**
* @private
* @return {?}
*/
function () {
var _this = this;
this.marker.addListener('dragend', (/**
* @return {?}
*/
function () { return _this.notifyLocationChange(); }));
this.marker.addListener('dragend', (/**
* @param {?} mouseEvent
* @return {?}
*/
function (mouseEvent) { return _this.reverseGeocode(mouseEvent); }));
this.map.addListener('click', (/**
* @param {?} mouseEvent
* @return {?}
*/
function (mouseEvent) { return _this.changeMarkerLocation(mouseEvent.latLng); }));
this.map.addListener('click', (/**
* @return {?}
*/
function () { return _this.notifyLocationChange(); }));
this.map.addListener('click', (/**
* @param {?} mouseEvent
* @return {?}
*/
function (mouseEvent) { return _this.reverseGeocode(mouseEvent); }));
};
/**
* @private
* @return {?}
*/
AngularGoogleMapsBuilder.prototype.notifyLocationChange = /**
* @private
* @return {?}
*/
function () {
this.eventPublisher.notify('locationChanged', new Location(this.getCoordinates(), this.getRadius()));
};
/**
* @private
* @return {?}
*/
AngularGoogleMapsBuilder.prototype.getRadius = /**
* @private
* @return {?}
*/
function () {
/** @type {?} */
var radiusInMeters = 0;
if (this.circle !== undefined)
radiusInMeters = this.circle.getRadius();
return radiusInMeters;
};
/**
* @private
* @return {?}
*/
AngularGoogleMapsBuilder.prototype.getCoordinates = /**
* @private
* @return {?}
*/
function () {
/** @type {?} */
var coordinates = new Coordinates(0, 0);
if (this.marker !== undefined)
coordinates = new Coordinates(this.marker.getPosition().lat(), this.marker.getPosition().lng());
return coordinates;
};
/**
* @private
* @param {?} location
* @return {?}
*/
AngularGoogleMapsBuilder.prototype.changeMapLocationAndZoom = /**
* @private
* @param {?} location
* @return {?}
*/
function (location) {
this.map.panTo(location);
this.map.setZoom(16);
};
/**
* @private
* @param {?} location
* @return {?}
*/
AngularGoogleMapsBuilder.prototype.changeMarkerLocation = /**
* @private
* @param {?} location
* @return {?}
*/
function (location) {
this.circle.setMap(this.map);
this.marker.setMap(this.map);
this.marker.setPosition(location);
};
/**
* @private
* @param {?} e
* @return {?}
*/
AngularGoogleMapsBuilder.prototype.reverseGeocode = /**
* @private
* @param {?} e
* @return {?}
*/
function (e) {
var _this = this;
this.geocoder.reverseGeocode(new Coordinates(e.latLng.lat(), e.latLng.lng()), (/**
* @param {?} address
* @return {?}
*/
function (address) {
return _this.eventPublisher.notify('addressReverseGeocoded', address);
}));
};
AngularGoogleMapsBuilder.decorators = [
{ type: Injectable }
];
/** @nocollapse */
AngularGoogleMapsBuilder.ctorParameters = function () { return [
{ type: GoogleMapsFactory },
{ type: AngularGoogleMapsGeocoder },
{ type: EventPublisher }
]; };
return AngularGoogleMapsBuilder;
}());
export { AngularGoogleMapsBuilder };
if (false) {
/**
* @type {?}
* @private
*/
AngularGoogleMapsBuilder.prototype.map;
/**
* @type {?}
* @private
*/
AngularGoogleMapsBuilder.prototype.marker;
/**
* @type {?}
* @private
*/
AngularGoogleMapsBuilder.prototype.circle;
/**
* @type {?}
* @private
*/
AngularGoogleMapsBuilder.prototype.googleMapsFactory;
/**
* @type {?}
* @private
*/
AngularGoogleMapsBuilder.prototype.geocoder;
/**
* @type {?}
* @private
*/
AngularGoogleMapsBuilder.prototype.eventPublisher;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-google-maps-builder.service.js","sourceRoot":"ng://@boldadmin/angular-google-maps/","sources":["service/angular-google-maps-builder.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core'\nimport { EventPublisher } from '@boldadmin/event-publisher'\nimport { Coordinates } from '../value-object/coordinates'\nimport { Location } from '../value-object/location'\nimport { AngularGoogleMapsGeocoder } from './angular-google-maps-geocoder.service'\nimport { GoogleMapsFactory } from './google-maps-factory.service'\nimport Circle = google.maps.Circle\nimport CircleOptions = google.maps.CircleOptions\nimport LatLng = google.maps.LatLng\nimport Map = google.maps.Map\nimport MapOptions = google.maps.MapOptions\nimport Marker = google.maps.Marker\nimport MarkerOptions = google.maps.MarkerOptions\nimport MouseEvent = google.maps.MouseEvent\nimport PolylineOptions = google.maps.PolylineOptions\n\n\n@Injectable()\nexport class AngularGoogleMapsBuilder {\n\n    private map: Map\n    private marker: Marker\n    private circle: Circle\n\n    constructor(private googleMapsFactory: GoogleMapsFactory,\n                private geocoder: AngularGoogleMapsGeocoder,\n                private eventPublisher: EventPublisher\n    ) {}\n\n    createMap(mapOptions: MapOptions) {\n        this.map = this.googleMapsFactory.createMap(mapOptions)\n\n        return this\n    }\n\n    addCenterMarker(markerOptions: MarkerOptions) {\n        this.marker = this.googleMapsFactory.createMarker(markerOptions)\n        this.marker.setPosition(this.map.getCenter())\n        this.marker.setMap(this.map)\n        this.addMarkerListeners()\n        return this\n    }\n\n    addCircle(circleOptions: CircleOptions) {\n        this.circle = this.googleMapsFactory.createCircle(circleOptions)\n        this.circle.setMap(this.map)\n        this.circle.addListener('radius_changed', () => this.notifyLocationChange())\n        return this\n    }\n\n    addPolyline(polylineOptions: PolylineOptions) {\n        const polyline = this.googleMapsFactory.createPolyline(polylineOptions)\n        polyline.setMap(this.map)\n        return this\n    }\n\n    addMarker(markerOptions: MarkerOptions) {\n        const marker = this.googleMapsFactory.createMarker(markerOptions)\n        marker.setMap(this.map)\n        return this\n    }\n\n    bindCircleToMarker() {\n        this.circle.bindTo('center', this.marker, 'position')\n        return this\n    }\n\n    hideMarker() {\n        this.marker.setMap(null)\n        return this\n    }\n\n    hideCircle() {\n        this.circle.setMap(null)\n        return this\n    }\n\n    addSearchBox() {\n        const box = this.googleMapsFactory.createSearchBox()\n\n        box.addListener('places_changed', () => {\n            const places = box.getPlaces()\n            if (places[0]) {\n                this.changeMapLocationAndZoom(places[0].geometry.location)\n                this.changeMarkerLocation(places[0].geometry.location)\n                const loc = places[0].geometry.location\n                const coordinates = new Coordinates(loc.lat(), loc.lng())\n                this.eventPublisher.notify('locationChanged', new Location(coordinates, this.circle.getRadius()))\n            }\n        })\n        return this\n    }\n\n    private addMarkerListeners() {\n        this.marker.addListener('dragend', () => this.notifyLocationChange())\n        this.marker.addListener('dragend', mouseEvent => this.reverseGeocode(mouseEvent))\n        this.map.addListener('click', mouseEvent => this.changeMarkerLocation(mouseEvent.latLng))\n        this.map.addListener('click', () => this.notifyLocationChange())\n        this.map.addListener('click', mouseEvent => this.reverseGeocode(mouseEvent))\n    }\n\n    private notifyLocationChange() {\n        this.eventPublisher.notify('locationChanged', new Location(this.getCoordinates(), this.getRadius()))\n    }\n\n    private getRadius() {\n        let radiusInMeters = 0\n        if (this.circle !== undefined)\n            radiusInMeters = this.circle.getRadius()\n\n        return radiusInMeters\n    }\n\n    private getCoordinates() {\n        let coordinates = new Coordinates(0, 0)\n        if (this.marker !== undefined)\n            coordinates = new Coordinates(this.marker.getPosition().lat(), this.marker.getPosition().lng())\n\n        return coordinates\n    }\n\n    private changeMapLocationAndZoom(location: LatLng) {\n        this.map.panTo(location)\n        this.map.setZoom(16)\n    }\n\n    private changeMarkerLocation(location: LatLng) {\n        this.circle.setMap(this.map)\n        this.marker.setMap(this.map)\n        this.marker.setPosition(location)\n    }\n    private reverseGeocode(e: MouseEvent) {\n        this.geocoder.reverseGeocode(new Coordinates(e.latLng.lat(), e.latLng.lng()), (address: string) =>\n            this.eventPublisher.notify('addressReverseGeocoded', address)\n        )\n    }\n}\n"]}