@boldadmin/angular-google-maps
Version:
Google Maps adapter for Angular Framework
247 lines • 21.7 kB
JavaScript
/**
* @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":";;;;AAAA,OAAO,EAAE,SAAS,EAAqB,MAAM,EAAE,MAAM,eAAe,CAAA;AACpE,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAA;AAC3D,OAAO,KAAK,MAAM,MAAM,QAAQ,CAAA;AAChC,OAAO,EAAE,QAAQ,EAAE,MAAM,gCAAgC,CAAA;AACzD,OAAO,EAAE,wBAAwB,EAAE,MAAM,+CAA+C,CAAA;AACxF,OAAO,EAAE,yBAAyB,EAAE,MAAM,gDAAgD,CAAA;AAC1F,OAAO,EAAE,iBAAiB,EAAE,MAAM,uCAAuC,CAAA;AACzE,OAAO,EAAE,YAAY,EAAE,MAAM,uCAAuC,CAAA;AAepE,MAAM,OAAO,0BAA0B;;;;;;;;IA8CnC,YAAoB,iBAAoC,EACpC,iBAA2C,EAC3C,kBAA6C,EAC7C,cAA8B,EAC9B,YAA0B;QAJ1B,sBAAiB,GAAjB,iBAAiB,CAAmB;QACpC,sBAAiB,GAAjB,iBAAiB,CAA0B;QAC3C,uBAAkB,GAAlB,kBAAkB,CAA2B;QAC7C,mBAAc,GAAd,cAAc,CAAgB;QAC9B,iBAAY,GAAZ,YAAY,CAAc;QAhD9C,aAAQ,GAAG,QAAQ,CAAA;QACnB,YAAO,GAAG,EAAE,CAAA;QAEF,eAAU,GAAe;YAC/B,MAAM,EAAE;gBACJ,GAAG,EAAE,CAAC;gBACN,GAAG,EAAE,CAAC;aACT;YACD,qBAAqB,EAAE;gBACnB,UAAU,EAAE,CAAC,SAAS,EAAE,WAAW,CAAC;gBACpC,QAAQ,EAAE,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC,eAAe,CAAC,WAAW;aAC/E;YACD,IAAI,EAAE,EAAE;YACR,WAAW,EAAE,EAAE;YACf,iBAAiB,EAAE,KAAK;SAC3B,CAAA;QAES,kBAAa,GAAkB;YACrC,QAAQ,EAAE;gBACN,GAAG,EAAE,CAAC;gBACN,GAAG,EAAE,CAAC;aACT;YACD,SAAS,EAAE,IAAI;YACf,SAAS,EAAE,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC,SAAS,CAAC,IAAI;SACnE,CAAA;QAES,kBAAa,GAAkB;YACrC,WAAW,EAAE,SAAS;YACtB,aAAa,EAAE,GAAG;YAClB,YAAY,EAAE,CAAC;YACf,SAAS,EAAE,SAAS;YACpB,WAAW,EAAE,IAAI;YACjB,QAAQ,EAAE,IAAI;YACd,MAAM,EAAE,EAAE;SACb,CAAA;QAES,uBAAkB,GAAS;YACjC,GAAG,EAAE,iFAAiF;SACzF,CAAA;QAES,sBAAiB,GAAS;YAChC,GAAG,EAAE,gFAAgF;SACxF,CAAA;IAOD,CAAC;;;;IAED,QAAQ;QACJ,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,wBAAwB;;;;QAAE,CAAC,OAAe,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,GAAG,OAAO,EAAC,CAAA;QACpG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,QAAQ,EAAE,qBAAqB,CAAC,CAAA;QAC3D,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,UAAU,EAAE,uBAAuB,CAAC,CAAA;IACnE,CAAC;;;;IAED,WAAW;QACP,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,wBAAwB,CAAC,CAAA;IAChE,CAAC;;;;;IAED,mBAAmB,CAAC,aAAuB;QACvC,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC,aAAa,CAAC,WAAW;;;;QAAE,CAAC,OAAe,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,GAAG,OAAO,EAAC,CAAA;QAC9G,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,aAAa,CAAC,cAAc,CAAA;QACxD,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,WAAW,CAAC,CAAA;QAC/C,IAAI,CAAC,iBAAiB;aACjB,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC;aAC1B,eAAe,CAAC,IAAI,CAAC,aAAa,CAAC;aACnC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC;aAC7B,kBAAkB,EAAE;aACpB,YAAY,EAAE,CAAA;IACvB,CAAC;;;;;IAED,kBAAkB,CAAC,OAAe;QAC9B,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,OAAO;;;;QAAE,CAAC,WAAwB,EAAE,EAAE;YAC9D,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,CAAA;YACjC,IAAI,CAAC,iBAAiB;iBACjB,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC;iBAC1B,eAAe,CAAC,IAAI,CAAC,aAAa,CAAC;iBACnC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC;iBAC7B,kBAAkB,EAAE;iBACpB,UAAU,EAAE;iBACZ,UAAU,EAAE;iBACZ,YAAY,EAAE,CAAA;QACvB,CAAC,EACJ,CAAA;IACL,CAAC;;;;IAED,eAAe;QACX,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,WAAW,CAAC,CAAA;IAC3C,CAAC;;;;;;IAED,aAAa,CAAC,wBAAqD,EAAE,IAAY;QAC7E,wBAAwB,CAAC,OAAO;;;;;QAAC,CAAC,oBAA0C,EAAE,KAAa,EAAE,EAAE;;kBACrF,IAAI,GAAG,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAI,CAAC,kBAAkB;;kBACrE,QAAQ,GAAG,MAAM,CAAC,GAAG,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,kBAAkB,CAAC;YACtF,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC;gBAC7B,QAAQ,EAAE,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,oBAAoB,CAAC,WAAW,CAAC;gBAC/E,KAAK,EAAE,SAAS,IAAI,WAAW,QAAQ,EAAE;gBACzC,IAAI,EAAE,IAAI;aACb,CAAC,CAAA;QACN,CAAC,EAAC,CAAA;;cAEI,OAAO,GAAG,wBAAwB,CAAC,GAAG;;;;QAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,KAAK,CAAC,WAAW,CAAC,EAAC;QAC7G,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,GAAG,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAA;IAC5E,CAAC;;;;;;;IAEO,WAAW,CAAC,IAAmB,EAAE,SAAiB;QACtD,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC;YAC/B,QAAQ,EAAE,IAAI;YACd,aAAa,EAAE,GAAG;YAClB,YAAY,EAAE,CAAC;YACf,IAAI,EAAE,IAAI;YACV,WAAW,EAAE,SAAS;SACzB,CAAC,CAAA;IACN,CAAC;;;;;;IAEO,eAAe,CAAC,WAAwB;QAC5C,IAAI,CAAC,UAAU,CAAC,MAAM,GAAG,EAAC,GAAG,EAAE,WAAW,CAAC,QAAQ,EAAE,GAAG,EAAE,WAAW,CAAC,SAAS,EAAC,CAAA;IACpF,CAAC;;;YA9HJ,SAAS,SAAC;gBACP,QAAQ,EAAE,aAAa;gBACvB,meAAuC;gBACvC,SAAS,EAAE,CAAC,wBAAwB,CAAC;aACxC;;;;YAfQ,iBAAiB;YAFjB,wBAAwB;YACxB,yBAAyB;YAJzB,cAAc;YAMd,YAAY;;;yBAoBhB,MAAM;4BAcN,MAAM;4BASN,MAAM;iCAUN,MAAM;gCAIN,MAAM;;;;IAxCP,8CAAmB;;IACnB,6CAAY;;IAEZ,gDAYC;;IAED,mDAOC;;IAED,mDAQC;;IAED,wDAEC;;IAED,uDAEC;;;;;IAEW,uDAA4C;;;;;IAC5C,uDAAmD;;;;;IACnD,wDAAqD;;;;;IACrD,oDAAsC;;;;;IACtC,kDAAkC","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"]}