UNPKG

@agm/js-marker-clusterer

Version:

Angular Google Maps (AGM) extension for js-marker-clusterer support

145 lines 17.1 kB
import * as tslib_1 from "tslib"; import { Injectable, NgZone } from '@angular/core'; import { Observable } from 'rxjs'; import 'js-marker-clusterer'; import { AgmMarker, GoogleMapsAPIWrapper, MarkerManager } from '@agm/core'; let ClusterManager = class ClusterManager extends MarkerManager { constructor(_mapsWrapper, _zone) { super(_mapsWrapper, _zone); this._mapsWrapper = _mapsWrapper; this._zone = _zone; this._clustererInstance = new Promise((resolver) => { this._resolver = resolver; }); } init(options) { this._mapsWrapper.getNativeMap().then(map => { const clusterer = new MarkerClusterer(map, [], options); this._resolver(clusterer); }); } getClustererInstance() { return this._clustererInstance; } addMarker(marker) { const clusterPromise = this.getClustererInstance(); const markerPromise = this._mapsWrapper .createMarker({ position: { lat: marker.latitude, lng: marker.longitude, }, label: marker.label, draggable: marker.draggable, icon: marker.iconUrl, opacity: marker.opacity, visible: marker.visible, zIndex: marker.zIndex, title: marker.title, clickable: marker.clickable, }, false); Promise .all([clusterPromise, markerPromise]) .then(([cluster, marker]) => { return cluster.addMarker(marker); }); this._markers.set(marker, markerPromise); } deleteMarker(marker) { const m = this._markers.get(marker); if (m == null) { // marker already deleted return Promise.resolve(); } return m.then((m) => { this._zone.run(() => { m.setMap(null); this.getClustererInstance().then(cluster => { cluster.removeMarker(m); this._markers.delete(marker); }); }); }); } clearMarkers() { return this.getClustererInstance().then(cluster => { cluster.clearMarkers(); }); } setGridSize(c) { this.getClustererInstance().then(cluster => { cluster.setGridSize(c.gridSize); }); } setMaxZoom(c) { this.getClustererInstance().then(cluster => { cluster.setMaxZoom(c.maxZoom); }); } setStyles(c) { this.getClustererInstance().then(cluster => { cluster.setStyles(c.styles); }); } setZoomOnClick(c) { this.getClustererInstance().then(cluster => { if (c.zoomOnClick !== undefined) { cluster.zoomOnClick_ = c.zoomOnClick; } }); } setAverageCenter(c) { this.getClustererInstance().then(cluster => { if (c.averageCenter !== undefined) { cluster.averageCenter_ = c.averageCenter; } }); } setImagePath(c) { this.getClustererInstance().then(cluster => { if (c.imagePath !== undefined) { cluster.imagePath_ = c.imagePath; } }); } setMinimumClusterSize(c) { this.getClustererInstance().then(cluster => { if (c.minimumClusterSize !== undefined) { cluster.minimumClusterSize_ = c.minimumClusterSize; } }); } setImageExtension(c) { this.getClustererInstance().then(cluster => { if (c.imageExtension !== undefined) { cluster.imageExtension_ = c.imageExtension; } }); } createClusterEventObservable(eventName) { return Observable.create((observer) => { this._zone.runOutsideAngular(() => { this._clustererInstance.then((m) => { m.addListener(eventName, (e) => this._zone.run(() => observer.next(e))); }); }); }); } setCalculator(c) { this.getClustererInstance().then(cluster => { if (typeof c.calculator === 'function') { cluster.setCalculator(c.calculator); } }); } }; ClusterManager.ctorParameters = () => [ { type: GoogleMapsAPIWrapper }, { type: NgZone } ]; ClusterManager = tslib_1.__decorate([ Injectable(), tslib_1.__metadata("design:paramtypes", [GoogleMapsAPIWrapper, NgZone]) ], ClusterManager); export { ClusterManager }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cluster-manager.js","sourceRoot":"ng://@agm/js-marker-clusterer/","sources":["services/managers/cluster-manager.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, NgZone } from '@angular/core';\nimport { Observable, Observer } from 'rxjs';\n\nimport 'js-marker-clusterer';\n\nimport { AgmMarker, GoogleMapsAPIWrapper, MarkerManager } from '@agm/core';\nimport { Marker } from '@agm/core/services/google-maps-types';\nimport { AgmMarkerCluster } from '../../directives/marker-cluster';\nimport { ClusterOptions, MarkerClustererInstance } from '../google-clusterer-types';\n\ndeclare var MarkerClusterer: any;\n\n@Injectable()\nexport class ClusterManager extends MarkerManager {\n  private _clustererInstance: Promise<MarkerClustererInstance>;\n  private _resolver: Function;\n\n  constructor(protected _mapsWrapper: GoogleMapsAPIWrapper, protected _zone: NgZone) {\n    super(_mapsWrapper, _zone);\n    this._clustererInstance = new Promise<MarkerClustererInstance>((resolver) => {\n      this._resolver = resolver;\n    });\n  }\n\n  init(options: ClusterOptions): void {\n    this._mapsWrapper.getNativeMap().then(map => {\n      const clusterer = new MarkerClusterer(map, [], options);\n      this._resolver(clusterer);\n    });\n  }\n\n  getClustererInstance(): Promise<MarkerClustererInstance> {\n    return this._clustererInstance;\n  }\n\n  addMarker(marker: AgmMarker): void {\n    const clusterPromise: Promise<MarkerClustererInstance> = this.getClustererInstance();\n    const markerPromise = this._mapsWrapper\n      .createMarker({\n        position: {\n          lat: marker.latitude,\n          lng: marker.longitude,\n        },\n        label: marker.label,\n        draggable: marker.draggable,\n        icon: marker.iconUrl,\n        opacity: marker.opacity,\n        visible: marker.visible,\n        zIndex: marker.zIndex,\n        title: marker.title,\n        clickable: marker.clickable,\n      }, false);\n\n    Promise\n      .all([clusterPromise, markerPromise])\n      .then(([cluster, marker]) => {\n        return cluster.addMarker(marker);\n      });\n    this._markers.set(marker, markerPromise);\n  }\n\n  deleteMarker(marker: AgmMarker): Promise<void> {\n    const m = this._markers.get(marker);\n    if (m == null) {\n      // marker already deleted\n      return Promise.resolve();\n    }\n    return m.then((m: Marker) => {\n      this._zone.run(() => {\n        m.setMap(null);\n        this.getClustererInstance().then(cluster => {\n          cluster.removeMarker(m);\n          this._markers.delete(marker);\n        });\n      });\n    });\n  }\n\n  clearMarkers(): Promise<void> {\n    return this.getClustererInstance().then(cluster => {\n      cluster.clearMarkers();\n    });\n  }\n\n  setGridSize(c: AgmMarkerCluster): void {\n    this.getClustererInstance().then(cluster => {\n      cluster.setGridSize(c.gridSize);\n    });\n  }\n\n  setMaxZoom(c: AgmMarkerCluster): void {\n    this.getClustererInstance().then(cluster => {\n      cluster.setMaxZoom(c.maxZoom);\n    });\n  }\n\n  setStyles(c: AgmMarkerCluster): void {\n    this.getClustererInstance().then(cluster => {\n      cluster.setStyles(c.styles);\n    });\n  }\n\n  setZoomOnClick(c: AgmMarkerCluster): void {\n    this.getClustererInstance().then(cluster => {\n      if (c.zoomOnClick !== undefined) {\n        cluster.zoomOnClick_ = c.zoomOnClick;\n      }\n    });\n  }\n\n  setAverageCenter(c: AgmMarkerCluster): void {\n    this.getClustererInstance().then(cluster => {\n      if (c.averageCenter !== undefined) {\n        cluster.averageCenter_ = c.averageCenter;\n      }\n    });\n  }\n\n  setImagePath(c: AgmMarkerCluster): void {\n    this.getClustererInstance().then(cluster => {\n      if (c.imagePath !== undefined) {\n        cluster.imagePath_ = c.imagePath;\n      }\n    });\n  }\n\n  setMinimumClusterSize(c: AgmMarkerCluster): void {\n    this.getClustererInstance().then(cluster => {\n      if (c.minimumClusterSize !== undefined) {\n        cluster.minimumClusterSize_ = c.minimumClusterSize;\n      }\n    });\n  }\n\n  setImageExtension(c: AgmMarkerCluster): void {\n    this.getClustererInstance().then(cluster => {\n      if (c.imageExtension !== undefined) {\n        cluster.imageExtension_ = c.imageExtension;\n      }\n    });\n  }\n\n  createClusterEventObservable<T>(eventName: string): Observable<T> {\n    return Observable.create((observer: Observer<T>) => {\n      this._zone.runOutsideAngular(() => {\n        this._clustererInstance.then((m: MarkerClustererInstance) => {\n          m.addListener(eventName, (e: T) => this._zone.run(() => observer.next(e)));\n        });\n      });\n    });\n  }\n\n  setCalculator (c: AgmMarkerCluster): void {\n    this.getClustererInstance().then(cluster => {\n      if (typeof c.calculator === 'function') {\n        cluster.setCalculator(c.calculator);\n      }\n    });\n  }\n}\n"]}