@boldadmin/angular-google-maps
Version:
Google Maps adapter for Angular Framework
268 lines • 21.1 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';
export class AngularGoogleMapsBuilder {
/**
* @param {?} googleMapsFactory
* @param {?} geocoder
* @param {?} eventPublisher
*/
constructor(googleMapsFactory, geocoder, eventPublisher) {
this.googleMapsFactory = googleMapsFactory;
this.geocoder = geocoder;
this.eventPublisher = eventPublisher;
}
/**
* @template THIS
* @this {THIS}
* @param {?} mapOptions
* @return {THIS}
*/
createMap(mapOptions) {
(/** @type {?} */ (this)).map = (/** @type {?} */ (this)).googleMapsFactory.createMap(mapOptions);
return (/** @type {?} */ (this));
}
/**
* @template THIS
* @this {THIS}
* @param {?} markerOptions
* @return {THIS}
*/
addCenterMarker(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}
*/
addCircle(circleOptions) {
(/** @type {?} */ (this)).circle = (/** @type {?} */ (this)).googleMapsFactory.createCircle(circleOptions);
(/** @type {?} */ (this)).circle.setMap((/** @type {?} */ (this)).map);
(/** @type {?} */ (this)).circle.addListener('radius_changed', (/**
* @return {?}
*/
() => (/** @type {?} */ (this)).notifyLocationChange()));
return (/** @type {?} */ (this));
}
/**
* @template THIS
* @this {THIS}
* @param {?} polylineOptions
* @return {THIS}
*/
addPolyline(polylineOptions) {
/** @type {?} */
const polyline = (/** @type {?} */ (this)).googleMapsFactory.createPolyline(polylineOptions);
polyline.setMap((/** @type {?} */ (this)).map);
return (/** @type {?} */ (this));
}
/**
* @template THIS
* @this {THIS}
* @param {?} markerOptions
* @return {THIS}
*/
addMarker(markerOptions) {
/** @type {?} */
const marker = (/** @type {?} */ (this)).googleMapsFactory.createMarker(markerOptions);
marker.setMap((/** @type {?} */ (this)).map);
return (/** @type {?} */ (this));
}
/**
* @template THIS
* @this {THIS}
* @return {THIS}
*/
bindCircleToMarker() {
(/** @type {?} */ (this)).circle.bindTo('center', (/** @type {?} */ (this)).marker, 'position');
return (/** @type {?} */ (this));
}
/**
* @template THIS
* @this {THIS}
* @return {THIS}
*/
hideMarker() {
(/** @type {?} */ (this)).marker.setMap(null);
return (/** @type {?} */ (this));
}
/**
* @template THIS
* @this {THIS}
* @return {THIS}
*/
hideCircle() {
(/** @type {?} */ (this)).circle.setMap(null);
return (/** @type {?} */ (this));
}
/**
* @template THIS
* @this {THIS}
* @return {THIS}
*/
addSearchBox() {
/** @type {?} */
const box = (/** @type {?} */ (this)).googleMapsFactory.createSearchBox();
box.addListener('places_changed', (/**
* @return {?}
*/
() => {
/** @type {?} */
const places = box.getPlaces();
if (places[0]) {
(/** @type {?} */ (this)).changeMapLocationAndZoom(places[0].geometry.location);
(/** @type {?} */ (this)).changeMarkerLocation(places[0].geometry.location);
/** @type {?} */
const loc = places[0].geometry.location;
/** @type {?} */
const coordinates = new Coordinates(loc.lat(), loc.lng());
(/** @type {?} */ (this)).eventPublisher.notify('locationChanged', new Location(coordinates, (/** @type {?} */ (this)).circle.getRadius()));
}
}));
return (/** @type {?} */ (this));
}
/**
* @private
* @return {?}
*/
addMarkerListeners() {
this.marker.addListener('dragend', (/**
* @return {?}
*/
() => this.notifyLocationChange()));
this.marker.addListener('dragend', (/**
* @param {?} mouseEvent
* @return {?}
*/
mouseEvent => this.reverseGeocode(mouseEvent)));
this.map.addListener('click', (/**
* @param {?} mouseEvent
* @return {?}
*/
mouseEvent => this.changeMarkerLocation(mouseEvent.latLng)));
this.map.addListener('click', (/**
* @return {?}
*/
() => this.notifyLocationChange()));
this.map.addListener('click', (/**
* @param {?} mouseEvent
* @return {?}
*/
mouseEvent => this.reverseGeocode(mouseEvent)));
}
/**
* @private
* @return {?}
*/
notifyLocationChange() {
this.eventPublisher.notify('locationChanged', new Location(this.getCoordinates(), this.getRadius()));
}
/**
* @private
* @return {?}
*/
getRadius() {
/** @type {?} */
let radiusInMeters = 0;
if (this.circle !== undefined)
radiusInMeters = this.circle.getRadius();
return radiusInMeters;
}
/**
* @private
* @return {?}
*/
getCoordinates() {
/** @type {?} */
let 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 {?}
*/
changeMapLocationAndZoom(location) {
this.map.panTo(location);
this.map.setZoom(16);
}
/**
* @private
* @param {?} location
* @return {?}
*/
changeMarkerLocation(location) {
this.circle.setMap(this.map);
this.marker.setMap(this.map);
this.marker.setPosition(location);
}
/**
* @private
* @param {?} e
* @return {?}
*/
reverseGeocode(e) {
this.geocoder.reverseGeocode(new Coordinates(e.latLng.lat(), e.latLng.lng()), (/**
* @param {?} address
* @return {?}
*/
(address) => this.eventPublisher.notify('addressReverseGeocoded', address)));
}
}
AngularGoogleMapsBuilder.decorators = [
{ type: Injectable }
];
/** @nocollapse */
AngularGoogleMapsBuilder.ctorParameters = () => [
{ type: GoogleMapsFactory },
{ type: AngularGoogleMapsGeocoder },
{ type: EventPublisher }
];
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"]}