UNPKG

@boldadmin/angular-google-maps

Version:
247 lines 21.7 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, Output } from '@angular/core'; import { EventPublisher } from '@boldadmin/event-publisher'; import * as moment from 'moment'; import { mapsText } from './angular-google-maps.constant'; import { AngularGoogleMapsBuilder } from './service/angular-google-maps-builder.service'; import { AngularGoogleMapsGeocoder } from './service/angular-google-maps-geocoder.service'; import { GoogleMapsFactory } from './service/google-maps-factory.service'; import { IconRegistry } from './service/icon-registry/icon-registry'; export class AngularGoogleMapsComponent { /** * @param {?} googleMapsFactory * @param {?} googleMapsBuilder * @param {?} googleMapsGeocoder * @param {?} eventPublisher * @param {?} iconRegistry */ constructor(googleMapsFactory, googleMapsBuilder, googleMapsGeocoder, eventPublisher, iconRegistry) { this.googleMapsFactory = googleMapsFactory; this.googleMapsBuilder = googleMapsBuilder; this.googleMapsGeocoder = googleMapsGeocoder; this.eventPublisher = eventPublisher; this.iconRegistry = iconRegistry; this.mapsText = mapsText; this.address = ''; this.mapOptions = { center: { lat: 0, lng: 0 }, mapTypeControlOptions: { mapTypeIds: ['roadmap', 'satellite'], position: this.googleMapsFactory.getGoogleMaps().ControlPosition.LEFT_BOTTOM }, zoom: 16, controlSize: 22, fullscreenControl: false }; this.markerOptions = { position: { lat: 0, lng: 0 }, draggable: true, animation: this.googleMapsFactory.getGoogleMaps().Animation.DROP }; this.circleOptions = { strokeColor: '#448aff', strokeOpacity: 0.8, strokeWeight: 2, fillColor: '#448aff', fillOpacity: 0.35, editable: true, radius: 70 }; this.previousMarkerIcon = { url: 'http://cdn.boldadmin.com.s3-website-eu-west-1.amazonaws.com/previous-marker.png' }; this.currentMarkerIcon = { url: 'http://cdn.boldadmin.com.s3-website-eu-west-1.amazonaws.com/current-marker.png' }; } /** * @return {?} */ ngOnInit() { this.eventPublisher.subscribe('addressReverseGeocoded', (/** * @param {?} address * @return {?} */ (address) => this.address = address)); this.iconRegistry.register('expand', './assets/expand.svg'); this.iconRegistry.register('collapse', './assets/collapse.svg'); } /** * @return {?} */ ngOnDestroy() { this.eventPublisher.unsubscribeAll('addressReverseGeocoded'); } /** * @param {?} focusLocation * @return {?} */ createMapByLocation(focusLocation) { this.googleMapsGeocoder.reverseGeocode(focusLocation.coordinates, (/** * @param {?} address * @return {?} */ (address) => this.address = address)); this.circleOptions.radius = focusLocation.radiusInMeters; this.changeMapCenter(focusLocation.coordinates); this.googleMapsBuilder .createMap(this.mapOptions) .addCenterMarker(this.markerOptions) .addCircle(this.circleOptions) .bindCircleToMarker() .addSearchBox(); } /** * @param {?} address * @return {?} */ createMapByAddress(address) { this.googleMapsGeocoder.geocode(address, (/** * @param {?} coordinates * @return {?} */ (coordinates) => { this.changeMapCenter(coordinates); this.googleMapsBuilder .createMap(this.mapOptions) .addCenterMarker(this.markerOptions) .addCircle(this.circleOptions) .bindCircleToMarker() .hideMarker() .hideCircle() .addSearchBox(); })); } /** * @return {?} */ notifyMapResize() { this.eventPublisher.notify('resizeMap'); } /** * @param {?} timestampCoordinatesList * @param {?} name * @return {?} */ addTravelPath(timestampCoordinatesList, name) { timestampCoordinatesList.forEach((/** * @param {?} timestampCoordinates * @param {?} index * @return {?} */ (timestampCoordinates, index) => { /** @type {?} */ const icon = index === 0 ? this.currentMarkerIcon : this.previousMarkerIcon; /** @type {?} */ const dateTime = moment.utc(timestampCoordinates.timestamp).format('YYYY.MM.DD HH:mm'); this.googleMapsBuilder.addMarker({ position: this.googleMapsFactory.createLatLng(timestampCoordinates.coordinates), title: `Name: ${name}, Time: ${dateTime}`, icon: icon }); })); /** @type {?} */ const latLngs = timestampCoordinatesList.map((/** * @param {?} value * @return {?} */ value => this.googleMapsFactory.createLatLng(value.coordinates))); this.addPolyline(latLngs, '#' + Math.random().toString(16).substr(2, 6)); } /** * @private * @param {?} path * @param {?} colorCode * @return {?} */ addPolyline(path, colorCode) { this.googleMapsBuilder.addPolyline({ geodesic: true, strokeOpacity: 0.8, strokeWeight: 1, path: path, strokeColor: colorCode }); } /** * @private * @param {?} coordinates * @return {?} */ changeMapCenter(coordinates) { this.mapOptions.center = { lat: coordinates.latitude, lng: coordinates.longitude }; } } AngularGoogleMapsComponent.decorators = [ { type: Component, args: [{ selector: 'google-maps', template: "<input id=\"search-input\" name=\"searchBox\" class=\"controls\" type=\"text\"\n placeholder=\"{{mapsText.searchBox}}\"\n [ngModelOptions]=\"{standalone: true}\"\n [(ngModel)]=\"address\"/>\n<mat-icon id=\"expand-icon\" class=\"resize-control\" svgIcon=\"expand\" (click)=\"notifyMapResize()\"></mat-icon>\n<mat-icon id=\"collapse-icon\" class=\"resize-control\" svgIcon=\"collapse\" (click)=\"notifyMapResize()\"></mat-icon>\n\n<div id=\"map\"></div>\n", providers: [AngularGoogleMapsBuilder] }] } ]; /** @nocollapse */ AngularGoogleMapsComponent.ctorParameters = () => [ { type: GoogleMapsFactory }, { type: AngularGoogleMapsBuilder }, { type: AngularGoogleMapsGeocoder }, { type: EventPublisher }, { type: IconRegistry } ]; AngularGoogleMapsComponent.propDecorators = { mapOptions: [{ type: Output }], markerOptions: [{ type: Output }], circleOptions: [{ type: Output }], previousMarkerIcon: [{ type: Output }], currentMarkerIcon: [{ type: Output }] }; if (false) { /** @type {?} */ AngularGoogleMapsComponent.prototype.mapsText; /** @type {?} */ AngularGoogleMapsComponent.prototype.address; /** @type {?} */ AngularGoogleMapsComponent.prototype.mapOptions; /** @type {?} */ AngularGoogleMapsComponent.prototype.markerOptions; /** @type {?} */ AngularGoogleMapsComponent.prototype.circleOptions; /** @type {?} */ AngularGoogleMapsComponent.prototype.previousMarkerIcon; /** @type {?} */ AngularGoogleMapsComponent.prototype.currentMarkerIcon; /** * @type {?} * @private */ AngularGoogleMapsComponent.prototype.googleMapsFactory; /** * @type {?} * @private */ AngularGoogleMapsComponent.prototype.googleMapsBuilder; /** * @type {?} * @private */ AngularGoogleMapsComponent.prototype.googleMapsGeocoder; /** * @type {?} * @private */ AngularGoogleMapsComponent.prototype.eventPublisher; /** * @type {?} * @private */ AngularGoogleMapsComponent.prototype.iconRegistry; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-google-maps.component.js","sourceRoot":"ng://@boldadmin/angular-google-maps/","sources":["angular-google-maps.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnDestroy, OnInit, Output } from '@angular/core'\nimport { EventPublisher } from '@boldadmin/event-publisher'\nimport * as moment from 'moment'\nimport { mapsText } from './angular-google-maps.constant'\nimport { AngularGoogleMapsBuilder } from './service/angular-google-maps-builder.service'\nimport { AngularGoogleMapsGeocoder } from './service/angular-google-maps-geocoder.service'\nimport { GoogleMapsFactory } from './service/google-maps-factory.service'\nimport { IconRegistry } from './service/icon-registry/icon-registry'\nimport { Coordinates } from './value-object/coordinates'\nimport { Location } from './value-object/location'\nimport { TimestampCoordinates } from './value-object/timestamp-coordinates'\nimport CircleOptions = google.maps.CircleOptions\nimport Icon = google.maps.Icon\nimport LatLng = google.maps.LatLng\nimport MapOptions = google.maps.MapOptions\nimport MarkerOptions = google.maps.MarkerOptions\n\n@Component({\n    selector: 'google-maps',\n    templateUrl: 'angular-google-maps.html',\n    providers: [AngularGoogleMapsBuilder]\n})\nexport class AngularGoogleMapsComponent implements OnInit, OnDestroy {\n\n    mapsText = mapsText\n    address = ''\n\n    @Output() mapOptions: MapOptions = {\n        center: {\n            lat: 0,\n            lng: 0\n        },\n        mapTypeControlOptions: {\n            mapTypeIds: ['roadmap', 'satellite'],\n            position: this.googleMapsFactory.getGoogleMaps().ControlPosition.LEFT_BOTTOM\n        },\n        zoom: 16,\n        controlSize: 22,\n        fullscreenControl: false\n    }\n\n    @Output() markerOptions: MarkerOptions = {\n        position: {\n            lat: 0,\n            lng: 0\n        },\n        draggable: true,\n        animation: this.googleMapsFactory.getGoogleMaps().Animation.DROP\n    }\n\n    @Output() circleOptions: CircleOptions = {\n        strokeColor: '#448aff',\n        strokeOpacity: 0.8,\n        strokeWeight: 2,\n        fillColor: '#448aff',\n        fillOpacity: 0.35,\n        editable: true,\n        radius: 70\n    }\n\n    @Output() previousMarkerIcon: Icon = {\n        url: 'http://cdn.boldadmin.com.s3-website-eu-west-1.amazonaws.com/previous-marker.png'\n    }\n\n    @Output() currentMarkerIcon: Icon = {\n        url: 'http://cdn.boldadmin.com.s3-website-eu-west-1.amazonaws.com/current-marker.png'\n    }\n\n    constructor(private googleMapsFactory: GoogleMapsFactory,\n                private googleMapsBuilder: AngularGoogleMapsBuilder,\n                private googleMapsGeocoder: AngularGoogleMapsGeocoder,\n                private eventPublisher: EventPublisher,\n                private iconRegistry: IconRegistry) {\n    }\n\n    ngOnInit() {\n        this.eventPublisher.subscribe('addressReverseGeocoded', (address: string) => this.address = address)\n        this.iconRegistry.register('expand', './assets/expand.svg')\n        this.iconRegistry.register('collapse', './assets/collapse.svg')\n    }\n\n    ngOnDestroy() {\n        this.eventPublisher.unsubscribeAll('addressReverseGeocoded')\n    }\n\n    createMapByLocation(focusLocation: Location) {\n        this.googleMapsGeocoder.reverseGeocode(focusLocation.coordinates, (address: string) => this.address = address)\n        this.circleOptions.radius = focusLocation.radiusInMeters\n        this.changeMapCenter(focusLocation.coordinates)\n        this.googleMapsBuilder\n            .createMap(this.mapOptions)\n            .addCenterMarker(this.markerOptions)\n            .addCircle(this.circleOptions)\n            .bindCircleToMarker()\n            .addSearchBox()\n    }\n\n    createMapByAddress(address: string) {\n        this.googleMapsGeocoder.geocode(address, (coordinates: Coordinates) => {\n                this.changeMapCenter(coordinates)\n                this.googleMapsBuilder\n                    .createMap(this.mapOptions)\n                    .addCenterMarker(this.markerOptions)\n                    .addCircle(this.circleOptions)\n                    .bindCircleToMarker()\n                    .hideMarker()\n                    .hideCircle()\n                    .addSearchBox()\n            }\n        )\n    }\n\n    notifyMapResize() {\n        this.eventPublisher.notify('resizeMap')\n    }\n\n    addTravelPath(timestampCoordinatesList: Array<TimestampCoordinates>, name: string) {\n        timestampCoordinatesList.forEach((timestampCoordinates: TimestampCoordinates, index: number) => {\n            const icon = index === 0 ? this.currentMarkerIcon : this.previousMarkerIcon\n            const dateTime = moment.utc(timestampCoordinates.timestamp).format('YYYY.MM.DD HH:mm')\n            this.googleMapsBuilder.addMarker({\n                position: this.googleMapsFactory.createLatLng(timestampCoordinates.coordinates),\n                title: `Name: ${name}, Time: ${dateTime}`,\n                icon: icon\n            })\n        })\n\n        const latLngs = timestampCoordinatesList.map(value => this.googleMapsFactory.createLatLng(value.coordinates))\n        this.addPolyline(latLngs, '#' + Math.random().toString(16).substr(2, 6))\n    }\n\n    private addPolyline(path: Array<LatLng>, colorCode: string) {\n        this.googleMapsBuilder.addPolyline({\n            geodesic: true,\n            strokeOpacity: 0.8,\n            strokeWeight: 1,\n            path: path,\n            strokeColor: colorCode\n        })\n    }\n\n    private changeMapCenter(coordinates: Coordinates) {\n        this.mapOptions.center = {lat: coordinates.latitude, lng: coordinates.longitude}\n    }\n}\n"]}