UNPKG

@boldadmin/angular-google-maps

Version:
268 lines 21.1 kB
/** * @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"]}