UNPKG

@c8y/ngx-components

Version:

Angular modules for Cumulocity IoT applications

187 lines 28.7 kB
import { Component, Input, ViewChild } from '@angular/core'; import { MapComponent, MapService, defaultMapConfig, getC8yMarker } from '@c8y/ngx-components/map'; import { FormGroup } from '@angular/forms'; import { ActivatedRoute } from '@angular/router'; import { toggleFullscreen } from '../fullscreen.util'; import { isNumber } from 'lodash-es'; import * as i0 from "@angular/core"; import * as i1 from "@angular/router"; import * as i2 from "@c8y/ngx-components/map"; import * as i3 from "@c8y/ngx-components"; // Düsseldorf export const defaultMapLocation = { lat: defaultMapConfig.center[0], lng: defaultMapConfig.center[1] }; export class AssetLocationComponent { constructor(activatedRouter, mapService) { this.activatedRouter = activatedRouter; this.mapService = mapService; this.config = { center: defaultMapConfig.center, zoomLevel: 13, color: 'green', icon: 'c8y-icon-location' }; this.isMarkerDraggable = false; this.isMapClickable = false; this.showMap = true; } async ngOnInit() { const leaflet = await this.mapService.getLeaflet(); if (leaflet) { const { contextData } = !this.activatedRouter.parent || this.activatedRouter.snapshot.data.context ? this.activatedRouter.snapshot.data : this.activatedRouter.parent.snapshot.data; this.assets = contextData ? contextData : this.locationMO; if (this.assets.c8y_Position.lat && this.assets.c8y_Position.lng) this.config.center = [this.assets.c8y_Position.lat, this.assets.c8y_Position.lng]; this.setView(this.assets.c8y_Position.lat, this.assets.c8y_Position.lng); } } ngOnChanges(changes) { if (changes.isEdit?.currentValue) { this.showMap = true; this.isMarkerDraggable = true; this.isMapClickable = true; queueMicrotask(() => this.mapView?.map.invalidateSize()); this.mapView?.map.on('click', event => { this.onClickOfMap(event); this.updateMarker(event.latlng.lat, event.latlng.lng); }); this.formSubscription = this.form?.valueChanges.subscribe(value => { this.updateMarker(value.c8y_Position.lat, value.c8y_Position.lng); this.setView(value.c8y_Position.lat, value.c8y_Position.lng); }); return; } if (!changes.isEdit?.currentValue) { const isAnyValueMissing = this.checkIfAnyValueIsMissing(this.locationMO?.c8y_Position.lat, this.locationMO?.c8y_Position.lng); if (isAnyValueMissing) { this.showMap = false; return; } this.isMarkerDraggable = false; this.isMapClickable = false; this.updateMarker(this.locationMO?.c8y_Position.lat, this.locationMO?.c8y_Position.lng); this.setView(this.locationMO?.c8y_Position.lat, this.locationMO?.c8y_Position.lng); } } ngOnDestroy() { this.formSubscription?.unsubscribe(); if (this.mapView?.markers && this.dragListener) { this.mapView?.markers.forEach(marker => { marker.off('drag', this.dragListener); }); } } /** * This command is used to prefill the latitude and longitude values in the form when the marker is dragged. */ onMarkerDrag(event) { if (this.form) { const properties = this.form.get('c8y_Position'); properties?.get('lat').patchValue(event.target._latlng.lat); properties?.get('lng').patchValue(event.target._latlng.lng); } } /** * This method is used to update the marker with the specified values and if any one of the values is not availble, sets * showWarning to true. * @param latitude - The latitude of the marker * @param longitude - The longitude of the marker */ updateMarker(latitude, longitude) { const isAnyValueMissing = this.checkIfAnyValueIsMissing(latitude, longitude); if (!isAnyValueMissing) { [latitude, longitude] = this.setLatLngValues(latitude, longitude); const asset = { c8y_Position: { latitude, longitude } }; if (this.mapView) { const icon = this.mapView.getAssetIcon(this.assets); const leafletMarker = this.mapView.leaflet.marker([latitude, longitude], { icon: icon, draggable: this.isMarkerDraggable }); if (this.isMarkerDraggable) { this.dragListener = event => { this.onMarkerDrag(event); }; leafletMarker.on('dragend', this.dragListener); } this.mapView.clearMarkers(); const marker = getC8yMarker(leafletMarker, asset); this.mapView.addMarkerToMap(marker); this.setView(latitude, longitude); } return; } this.mapView.clearMarkers(); } /** * This command is used to prefill the latitude and longitude values in the form on click of map. */ onClickOfMap(event) { if (this.form) { const properties = this.form.get('c8y_Position'); properties?.get('lat').patchValue(event.latlng.lat); properties?.get('lng').patchValue(event.latlng.lng); this.form.markAsDirty(); } } /** * Used to enable full screen of the map. */ enableFullscreen() { toggleFullscreen(this.mapView.mapElement.nativeElement); } /** * Checks if any one of the values i.e., latitude/longitude is undefined or null. * @param latitude Latitude value of the position * @param longitude Longitude value of the position * @returns returns true if any one of the values are both the values are missing else it returns false. */ checkIfAnyValueIsMissing(latitude, longitude) { return this.isNullOrUndefined(latitude) || this.isNullOrUndefined(longitude); } /** * Sets the view of the map based on the position of marker. * @param latitude - Latitude of the marker * @param longitude Longitude of the marker */ setView(latitude, longitude) { if (isNumber(latitude) && isNumber(longitude) && this.mapView) { [latitude, longitude] = this.setLatLngValues(latitude, longitude); this.config.center = [latitude, longitude]; this.mapView.center(); } } setLatLngValues(latitude, longitude) { latitude = this.isNullOrUndefined(latitude) ? defaultMapLocation.lat : latitude; longitude = this.isNullOrUndefined(longitude) ? defaultMapLocation.lng : longitude; return [latitude, longitude]; } isNullOrUndefined(value) { return value === null || value === undefined; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AssetLocationComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.MapService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: AssetLocationComponent, selector: "c8y-asset-location", inputs: { isEdit: "isEdit", locationMO: "locationMO", form: "form" }, viewQueries: [{ propertyName: "mapView", first: true, predicate: MapComponent, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div [hidden]=\"!showMap\">\n <div class=\"row\">\n <button\n class=\"btn btn-link pull-right\"\n style=\"margin-right: 12px\"\n title=\"Full screen\"\n type=\"button\"\n data-cy=\"asset-location-full-screen\"\n (click)=\"enableFullscreen()\"\n >\n <i c8yIcon=\"expand\"></i>\n </button>\n </div>\n <div style=\"width: 100%; height: 400px\">\n <c8y-map\n #map\n [assets]=\"assets\"\n [config]=\"config\"\n ></c8y-map>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i3.IconDirective, selector: "[c8yIcon]", inputs: ["c8yIcon"] }, { kind: "component", type: i2.MapComponent, selector: "c8y-map", inputs: ["config", "assets", "polyline$", "polylineOptions"], outputs: ["onRealtimeUpdate", "onMove", "onMoveEnd", "onZoomStart", "onZoomEnd", "onMap", "onInit"] }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AssetLocationComponent, decorators: [{ type: Component, args: [{ selector: 'c8y-asset-location', template: "<div [hidden]=\"!showMap\">\n <div class=\"row\">\n <button\n class=\"btn btn-link pull-right\"\n style=\"margin-right: 12px\"\n title=\"Full screen\"\n type=\"button\"\n data-cy=\"asset-location-full-screen\"\n (click)=\"enableFullscreen()\"\n >\n <i c8yIcon=\"expand\"></i>\n </button>\n </div>\n <div style=\"width: 100%; height: 400px\">\n <c8y-map\n #map\n [assets]=\"assets\"\n [config]=\"config\"\n ></c8y-map>\n </div>\n</div>\n" }] }], ctorParameters: () => [{ type: i1.ActivatedRoute }, { type: i2.MapService }], propDecorators: { mapView: [{ type: ViewChild, args: [MapComponent] }], isEdit: [{ type: Input }], locationMO: [{ type: Input }], form: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asset-location.component.js","sourceRoot":"","sources":["../../../../sub-assets/location/asset-location.component.ts","../../../../sub-assets/location/asset-location.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport * as L from 'leaflet';\nimport {\n  MapComponent,\n  MapConfig,\n  MapService,\n  PositionManagedObject,\n  defaultMapConfig,\n  getC8yMarker\n} from '@c8y/ngx-components/map';\nimport { FormArray, FormGroup } from '@angular/forms';\nimport { IManagedObject } from '@c8y/client';\nimport { ActivatedRoute } from '@angular/router';\nimport { Subscription } from 'rxjs';\nimport { toggleFullscreen } from '../fullscreen.util';\nimport { isNumber } from 'lodash-es';\n\n// Düsseldorf\nexport const defaultMapLocation = {\n  lat: defaultMapConfig.center[0],\n  lng: defaultMapConfig.center[1]\n} as const;\n\n@Component({\n  selector: 'c8y-asset-location',\n  templateUrl: './asset-location.component.html'\n})\nexport class AssetLocationComponent implements OnInit, OnChanges, OnDestroy {\n  @ViewChild(MapComponent)\n  mapView: MapComponent;\n  @Input() isEdit: boolean;\n  @Input() locationMO: IManagedObject;\n  @Input() form: FormGroup;\n  config: MapConfig = {\n    center: defaultMapConfig.center,\n    zoomLevel: 13,\n    color: 'green',\n    icon: 'c8y-icon-location'\n  };\n  assets: PositionManagedObject;\n  isMarkerDraggable = false;\n  isMapClickable = false;\n  dragListener: L.LeafletEventHandlerFn;\n  formSubscription: Subscription;\n  showMap = true;\n\n  constructor(\n    private activatedRouter: ActivatedRoute,\n    private mapService: MapService\n  ) {}\n\n  async ngOnInit() {\n    const leaflet = await this.mapService.getLeaflet();\n    if (leaflet) {\n      const { contextData } =\n        !this.activatedRouter.parent || this.activatedRouter.snapshot.data.context\n          ? this.activatedRouter.snapshot.data\n          : this.activatedRouter.parent.snapshot.data;\n      this.assets = contextData ? contextData : this.locationMO;\n      if (this.assets.c8y_Position.lat && this.assets.c8y_Position.lng)\n        this.config.center = [this.assets.c8y_Position.lat, this.assets.c8y_Position.lng];\n      this.setView(this.assets.c8y_Position.lat, this.assets.c8y_Position.lng);\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.isEdit?.currentValue) {\n      this.showMap = true;\n      this.isMarkerDraggable = true;\n      this.isMapClickable = true;\n      queueMicrotask(() => this.mapView?.map.invalidateSize());\n      this.mapView?.map.on('click', event => {\n        this.onClickOfMap(event);\n        this.updateMarker(event.latlng.lat, event.latlng.lng);\n      });\n      this.formSubscription = this.form?.valueChanges.subscribe(value => {\n        this.updateMarker(value.c8y_Position.lat, value.c8y_Position.lng);\n        this.setView(value.c8y_Position.lat, value.c8y_Position.lng);\n      });\n      return;\n    }\n    if (!changes.isEdit?.currentValue) {\n      const isAnyValueMissing = this.checkIfAnyValueIsMissing(\n        this.locationMO?.c8y_Position.lat,\n        this.locationMO?.c8y_Position.lng\n      );\n      if (isAnyValueMissing) {\n        this.showMap = false;\n        return;\n      }\n      this.isMarkerDraggable = false;\n      this.isMapClickable = false;\n      this.updateMarker(this.locationMO?.c8y_Position.lat, this.locationMO?.c8y_Position.lng);\n      this.setView(this.locationMO?.c8y_Position.lat, this.locationMO?.c8y_Position.lng);\n    }\n  }\n\n  ngOnDestroy() {\n    this.formSubscription?.unsubscribe();\n    if (this.mapView?.markers && this.dragListener) {\n      this.mapView?.markers.forEach(marker => {\n        marker.off('drag', this.dragListener);\n      });\n    }\n  }\n\n  /**\n   * This command is used to prefill the latitude and longitude values in the form when the marker is dragged.\n   */\n  onMarkerDrag(event: L.LeafletEvent) {\n    if (this.form) {\n      const properties = this.form.get('c8y_Position') as FormArray;\n      properties?.get('lat').patchValue(event.target._latlng.lat);\n      properties?.get('lng').patchValue(event.target._latlng.lng);\n    }\n  }\n\n  /**\n   * This method is used to update the marker with the specified values and if any one of the values is not availble, sets\n   * showWarning to true.\n   * @param latitude - The latitude of the marker\n   * @param longitude - The longitude of the marker\n   */\n  updateMarker(latitude: number, longitude: number) {\n    const isAnyValueMissing = this.checkIfAnyValueIsMissing(latitude, longitude);\n    if (!isAnyValueMissing) {\n      [latitude, longitude] = this.setLatLngValues(latitude, longitude);\n      const asset: any = {\n        c8y_Position: {\n          latitude,\n          longitude\n        }\n      };\n\n      if (this.mapView) {\n        const icon = this.mapView.getAssetIcon(this.assets);\n        const leafletMarker = this.mapView.leaflet.marker([latitude, longitude], {\n          icon: icon,\n          draggable: this.isMarkerDraggable\n        });\n        if (this.isMarkerDraggable) {\n          this.dragListener = event => {\n            this.onMarkerDrag(event);\n          };\n          leafletMarker.on('dragend', this.dragListener);\n        }\n        this.mapView.clearMarkers();\n        const marker = getC8yMarker(leafletMarker, asset);\n        this.mapView.addMarkerToMap(marker);\n        this.setView(latitude, longitude);\n      }\n      return;\n    }\n    this.mapView.clearMarkers();\n  }\n\n  /**\n   * This command is used to prefill the latitude and longitude values in the form on click of map.\n   */\n  onClickOfMap(event: L.LeafletMouseEvent) {\n    if (this.form) {\n      const properties = this.form.get('c8y_Position') as FormArray;\n      properties?.get('lat').patchValue(event.latlng.lat);\n      properties?.get('lng').patchValue(event.latlng.lng);\n      this.form.markAsDirty();\n    }\n  }\n\n  /**\n   * Used to enable full screen of the map.\n   */\n  enableFullscreen() {\n    toggleFullscreen(this.mapView.mapElement.nativeElement);\n  }\n\n  /**\n   * Checks if any one of the values i.e., latitude/longitude is undefined or null.\n   * @param latitude Latitude value of the position\n   * @param longitude Longitude value of the position\n   * @returns returns true if any one of the values are both the values are missing else it returns false.\n   */\n  checkIfAnyValueIsMissing(latitude: number, longitude: number) {\n    return this.isNullOrUndefined(latitude) || this.isNullOrUndefined(longitude);\n  }\n\n  /**\n   * Sets the view of the map based on the position of marker.\n   * @param latitude - Latitude of the marker\n   * @param longitude Longitude of the marker\n   */\n  setView(latitude: number, longitude: number) {\n    if (isNumber(latitude) && isNumber(longitude) && this.mapView) {\n      [latitude, longitude] = this.setLatLngValues(latitude, longitude);\n      this.config.center = [latitude, longitude];\n      this.mapView.center();\n    }\n  }\n\n  setLatLngValues(latitude: number, longitude: number): [number, number] {\n    latitude = this.isNullOrUndefined(latitude) ? defaultMapLocation.lat : latitude;\n    longitude = this.isNullOrUndefined(longitude) ? defaultMapLocation.lng : longitude;\n    return [latitude, longitude];\n  }\n\n  private isNullOrUndefined(value): boolean {\n    return value === null || value === undefined;\n  }\n}\n","<div [hidden]=\"!showMap\">\n  <div class=\"row\">\n    <button\n      class=\"btn btn-link pull-right\"\n      style=\"margin-right: 12px\"\n      title=\"Full screen\"\n      type=\"button\"\n      data-cy=\"asset-location-full-screen\"\n      (click)=\"enableFullscreen()\"\n    >\n    <i c8yIcon=\"expand\"></i>\n    </button>\n  </div>\n  <div style=\"width: 100%; height: 400px\">\n    <c8y-map\n      #map\n      [assets]=\"assets\"\n      [config]=\"config\"\n    ></c8y-map>\n  </div>\n</div>\n"]}