UNPKG

@boldadmin/angular-google-maps

Version:
352 lines 23.9 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'; 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"]}