@smartbit4all/ng-client 4.2.30 → 4.2.32

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -44,7 +44,7 @@ export class AbstractMap {
44
44
  else {
45
45
  toAdd.push({
46
46
  id: item.id,
47
- record: this.itemFactory(item, '#3388ff'),
47
+ record: this.itemFactory(item, { color: '#3388ff', draggable: false }),
48
48
  });
49
49
  }
50
50
  }
@@ -67,7 +67,7 @@ export class AbstractMap {
67
67
  (pendingItems[0].position != null && pendingItems[0].position.latitude != null)) {
68
68
  editingToAdd.push({
69
69
  id: pendingItems[0].id,
70
- record: this.itemFactory(pendingItems[0], '#ff0000'),
70
+ record: this.itemFactory(pendingItems[0], { color: '#ff0000', draggable: true }),
71
71
  });
72
72
  }
73
73
  editingPresent.forEach((id) => {
@@ -109,4 +109,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
109
109
  }], onEditingOverlayDrag: [{
110
110
  type: Output
111
111
  }] } });
112
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-map.js","sourceRoot":"","sources":["../../../../../projects/smart-ng-client/src/lib/smart-map/abstract-map.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  computed,\r\n  Directive,\r\n  effect,\r\n  EffectRef,\r\n  ElementRef,\r\n  EventEmitter,\r\n  input,\r\n  NgZone,\r\n  Output,\r\n  Signal,\r\n} from '@angular/core';\r\nimport {\r\n  GeoMapEditingSession,\r\n  GeoMapItem,\r\n  GeoMapItemKind,\r\n  GeoMapModel,\r\n  GeoMapOperationMode,\r\n} from './api';\r\nimport {\r\n  MapClickedEvent,\r\n  MapDraggedEvent,\r\n  MapEditingItemClickedEvent,\r\n  MapEditingItemDraggedEvent,\r\n  MapItemClickedEvent,\r\n  MapZoomChangedEvent,\r\n} from './smart-map.types';\r\n\r\nexport interface RecordWithId {\r\n  id: string;\r\n  record: any;\r\n}\r\n\r\nexport type GeoMapItemFactory = (it: GeoMapItem, color: string) => any;\r\n\r\n@Directive()\r\nexport abstract class AbstractMap {\r\n  readonly model = input.required<GeoMapModel>();\r\n  readonly items = input.required<Array<GeoMapItem>>();\r\n  readonly editingSession = input<GeoMapEditingSession>();\r\n  @Output() onMapClick: EventEmitter<MapClickedEvent> = new EventEmitter();\r\n  @Output() onOverlayClick: EventEmitter<MapItemClickedEvent> = new EventEmitter();\r\n  @Output() onMapDragEnd: EventEmitter<MapDraggedEvent> = new EventEmitter();\r\n  @Output() onZoomChanged: EventEmitter<MapZoomChangedEvent> = new EventEmitter();\r\n  @Output() onEditingOverlayClick: EventEmitter<MapEditingItemClickedEvent> = new EventEmitter();\r\n  @Output() onEditingOverlayDrag: EventEmitter<MapEditingItemDraggedEvent> = new EventEmitter();\r\n\r\n  selection: Signal<Array<string>> = computed(() =>\r\n    this.items()\r\n      .filter((it) => !!it.selected)\r\n      .map((it) => it.id!)\r\n  );\r\n\r\n  operationMode: Signal<GeoMapOperationMode> = computed(\r\n    () => this.model().viewState?.operationMode ?? GeoMapOperationMode.ACTION\r\n  );\r\n\r\n  protected readonly overlays: Map<string, any> = new Map();\r\n  protected readonly editingOverlays: Map<string, any> = new Map();\r\n  protected readonly onItemsChanged: EffectRef = this.initChangeEffect();\r\n  map: any;\r\n\r\n  protected constructor(\r\n    public el: ElementRef,\r\n    public cd: ChangeDetectorRef,\r\n    public zone: NgZone,\r\n    protected itemFactory: GeoMapItemFactory\r\n  ) {}\r\n\r\n  private initChangeEffect(): EffectRef {\r\n    return effect((onCleanup) => {\r\n      const items = this.items();\r\n      const editingSession = this.editingSession();\r\n      const present = new Set(this.overlays.keys());\r\n      const editingPresent = new Set(this.editingOverlays.keys());\r\n\r\n      const toAdd: Array<RecordWithId> = [];\r\n      const toRemove: Array<RecordWithId> = [];\r\n\r\n      const editingToAdd: Array<RecordWithId> = [];\r\n      const editingtoRemove: Array<RecordWithId> = [];\r\n      for (const item of items) {\r\n        if (!item.id) {\r\n          continue;\r\n        }\r\n\r\n        if (present.has(item.id)) {\r\n          present.delete(item.id);\r\n        } else {\r\n          toAdd.push({\r\n            id: item.id,\r\n            record: this.itemFactory(item, '#3388ff'),\r\n          });\r\n        }\r\n      }\r\n\r\n      present.forEach((id) => {\r\n        const record = this.overlays.get(id);\r\n        if (!record) {\r\n          return;\r\n        }\r\n\r\n        toRemove.push({ id, record });\r\n      });\r\n\r\n      this.handleItemChanges(toRemove, toAdd);\r\n\r\n      if (editingSession) {\r\n        editingSession.pendingItems;\r\n        const pendingValues = this.model()?.viewState?.editingSession?.pendingItems!;\r\n        const firstKey = Object.keys(pendingValues)[0];\r\n        const pendingItems = pendingValues[firstKey];\r\n\r\n        if (\r\n          (pendingItems[0].route != null &&\r\n            pendingItems[0].route.points != null &&\r\n            pendingItems[0].route.points.length > 0) ||\r\n          (pendingItems[0].position != null && pendingItems[0].position.latitude != null)\r\n        ) {\r\n          editingToAdd.push({\r\n            id: pendingItems[0].id!,\r\n            record: this.itemFactory(pendingItems[0], '#ff0000'),\r\n          });\r\n        }\r\n\r\n        editingPresent.forEach((id) => {\r\n          const record = this.editingOverlays.get(id);\r\n          if (!record) {\r\n            return;\r\n          }\r\n\r\n          editingtoRemove.push({ id, record });\r\n        });\r\n        this.handleEditingItemChanges(editingtoRemove, editingToAdd);\r\n      }\r\n\r\n      onCleanup(() => {\r\n        const remove: Array<RecordWithId> = [...this.overlays.entries()].map(([id, record]) => {\r\n          return { id, record };\r\n        });\r\n        this.handleItemChanges(remove, []);\r\n\r\n        const editingRemove: Array<RecordWithId> = [...this.editingOverlays.entries()].map(\r\n          ([id, record]) => {\r\n            return { id, record };\r\n          }\r\n        );\r\n        this.handleEditingItemChanges(editingRemove, []);\r\n      });\r\n    });\r\n  }\r\n\r\n  abstract handleItemChanges(toRemove: Array<RecordWithId>, toAdd: Array<RecordWithId>): void;\r\n\r\n  abstract handleEditingItemChanges(\r\n    toRemove: Array<RecordWithId>,\r\n    toAdd: Array<RecordWithId>\r\n  ): void;\r\n}\r\n"]}
112
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-map.js","sourceRoot":"","sources":["../../../../../projects/smart-ng-client/src/lib/smart-map/abstract-map.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  computed,\r\n  Directive,\r\n  effect,\r\n  EffectRef,\r\n  ElementRef,\r\n  EventEmitter,\r\n  input,\r\n  NgZone,\r\n  Output,\r\n  Signal,\r\n} from '@angular/core';\r\nimport {\r\n  GeoMapEditingSession,\r\n  GeoMapItem,\r\n  GeoMapItemKind,\r\n  GeoMapModel,\r\n  GeoMapOperationMode,\r\n} from './api';\r\nimport {\r\n  MapClickedEvent,\r\n  MapDraggedEvent,\r\n  MapEditingItemClickedEvent,\r\n  MapEditingItemDraggedEvent,\r\n  MapItemClickedEvent,\r\n  MapItemConfiguration,\r\n  MapZoomChangedEvent,\r\n} from './smart-map.types';\r\n\r\nexport interface RecordWithId {\r\n  id: string;\r\n  record: any;\r\n}\r\n\r\nexport type GeoMapItemFactory = (it: GeoMapItem, config: MapItemConfiguration) => any;\r\n\r\n@Directive()\r\nexport abstract class AbstractMap {\r\n  readonly model = input.required<GeoMapModel>();\r\n  readonly items = input.required<Array<GeoMapItem>>();\r\n  readonly editingSession = input<GeoMapEditingSession>();\r\n  @Output() onMapClick: EventEmitter<MapClickedEvent> = new EventEmitter();\r\n  @Output() onOverlayClick: EventEmitter<MapItemClickedEvent> = new EventEmitter();\r\n  @Output() onMapDragEnd: EventEmitter<MapDraggedEvent> = new EventEmitter();\r\n  @Output() onZoomChanged: EventEmitter<MapZoomChangedEvent> = new EventEmitter();\r\n  @Output() onEditingOverlayClick: EventEmitter<MapEditingItemClickedEvent> = new EventEmitter();\r\n  @Output() onEditingOverlayDrag: EventEmitter<MapEditingItemDraggedEvent> = new EventEmitter();\r\n\r\n  selection: Signal<Array<string>> = computed(() =>\r\n    this.items()\r\n      .filter((it) => !!it.selected)\r\n      .map((it) => it.id!)\r\n  );\r\n\r\n  operationMode: Signal<GeoMapOperationMode> = computed(\r\n    () => this.model().viewState?.operationMode ?? GeoMapOperationMode.ACTION\r\n  );\r\n\r\n  protected readonly overlays: Map<string, any> = new Map();\r\n  protected readonly editingOverlays: Map<string, any> = new Map();\r\n  protected readonly onItemsChanged: EffectRef = this.initChangeEffect();\r\n  map: any;\r\n\r\n  protected constructor(\r\n    public el: ElementRef,\r\n    public cd: ChangeDetectorRef,\r\n    public zone: NgZone,\r\n    protected itemFactory: GeoMapItemFactory\r\n  ) {}\r\n\r\n  private initChangeEffect(): EffectRef {\r\n    return effect((onCleanup) => {\r\n      const items = this.items();\r\n      const editingSession = this.editingSession();\r\n      const present = new Set(this.overlays.keys());\r\n      const editingPresent = new Set(this.editingOverlays.keys());\r\n\r\n      const toAdd: Array<RecordWithId> = [];\r\n      const toRemove: Array<RecordWithId> = [];\r\n\r\n      const editingToAdd: Array<RecordWithId> = [];\r\n      const editingtoRemove: Array<RecordWithId> = [];\r\n      for (const item of items) {\r\n        if (!item.id) {\r\n          continue;\r\n        }\r\n\r\n        if (present.has(item.id)) {\r\n          present.delete(item.id);\r\n        } else {\r\n          toAdd.push({\r\n            id: item.id,\r\n            record: this.itemFactory(item, { color: '#3388ff', draggable: false }),\r\n          });\r\n        }\r\n      }\r\n\r\n      present.forEach((id) => {\r\n        const record = this.overlays.get(id);\r\n        if (!record) {\r\n          return;\r\n        }\r\n\r\n        toRemove.push({ id, record });\r\n      });\r\n\r\n      this.handleItemChanges(toRemove, toAdd);\r\n\r\n      if (editingSession) {\r\n        editingSession.pendingItems;\r\n        const pendingValues = this.model()?.viewState?.editingSession?.pendingItems!;\r\n        const firstKey = Object.keys(pendingValues)[0];\r\n        const pendingItems = pendingValues[firstKey];\r\n\r\n        if (\r\n          (pendingItems[0].route != null &&\r\n            pendingItems[0].route.points != null &&\r\n            pendingItems[0].route.points.length > 0) ||\r\n          (pendingItems[0].position != null && pendingItems[0].position.latitude != null)\r\n        ) {\r\n          editingToAdd.push({\r\n            id: pendingItems[0].id!,\r\n            record: this.itemFactory(pendingItems[0], { color: '#ff0000', draggable: true }),\r\n          });\r\n        }\r\n\r\n        editingPresent.forEach((id) => {\r\n          const record = this.editingOverlays.get(id);\r\n          if (!record) {\r\n            return;\r\n          }\r\n\r\n          editingtoRemove.push({ id, record });\r\n        });\r\n        this.handleEditingItemChanges(editingtoRemove, editingToAdd);\r\n      }\r\n\r\n      onCleanup(() => {\r\n        const remove: Array<RecordWithId> = [...this.overlays.entries()].map(([id, record]) => {\r\n          return { id, record };\r\n        });\r\n        this.handleItemChanges(remove, []);\r\n\r\n        const editingRemove: Array<RecordWithId> = [...this.editingOverlays.entries()].map(\r\n          ([id, record]) => {\r\n            return { id, record };\r\n          }\r\n        );\r\n        this.handleEditingItemChanges(editingRemove, []);\r\n      });\r\n    });\r\n  }\r\n\r\n  abstract handleItemChanges(toRemove: Array<RecordWithId>, toAdd: Array<RecordWithId>): void;\r\n\r\n  abstract handleEditingItemChanges(\r\n    toRemove: Array<RecordWithId>,\r\n    toAdd: Array<RecordWithId>\r\n  ): void;\r\n}\r\n"]}
@@ -3,7 +3,7 @@ import { AbstractMap } from '../abstract-map';
3
3
  import { GeoMapItemKind } from '../api';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "@angular/common";
6
- function createGoogleMapsItem(item, color) {
6
+ function createGoogleMapsItem(item, config) {
7
7
  switch (item.kind) {
8
8
  case GeoMapItemKind.MARKER:
9
9
  return new google.maps.Marker({
@@ -55,7 +55,7 @@ export class GoogleMap extends AbstractMap {
55
55
  const items = this.items();
56
56
  const toAdd = items.map((it) => ({
57
57
  id: it.id,
58
- record: createGoogleMapsItem(it, '#3388ff'),
58
+ record: createGoogleMapsItem(it, { color: '#3388ff', draggable: false }),
59
59
  }));
60
60
  this.handleItemChanges([], toAdd);
61
61
  this.onMapReady.emit({
@@ -218,4 +218,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
218
218
  }], onMapReady: [{
219
219
  type: Output
220
220
  }] } });
221
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"google-map.js","sourceRoot":"","sources":["../../../../../../projects/smart-ng-client/src/lib/smart-map/impl/google-map.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewChecked,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  NgZone,\r\n  Output,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport { AbstractMap, RecordWithId } from '../abstract-map';\r\nimport { GeoMapItem, GeoMapItemKind, GeoMapViewport } from '../api';\r\n\r\ndeclare var google: any;\r\n\r\nfunction createGoogleMapsItem(item: GeoMapItem, color: string): any {\r\n  switch (item.kind) {\r\n    case GeoMapItemKind.MARKER:\r\n      return new google.maps.Marker({\r\n        position: {\r\n          lat: item.position!.latitude,\r\n          lng: item.position!.longitude,\r\n        },\r\n        title: item.label,\r\n      });\r\n    case GeoMapItemKind.LINE:\r\n      return new google.maps.Polyline({\r\n        path: item.route!.points.map((it) => {\r\n          return { lat: it.latitude, lng: it.longitude };\r\n        }),\r\n        geodesic: true,\r\n        strokeColor: '#FF0000',\r\n        strokeOpacity: 0.5,\r\n        strokeWeight: 2,\r\n      });\r\n    case GeoMapItemKind.POLYGON:\r\n      return new google.maps.Polygon({\r\n        path: item.route!.points.map((it) => {\r\n          return { lat: it.latitude, lng: it.longitude };\r\n        }),\r\n        strokeOpacity: 0.5,\r\n        storeWeight: 1,\r\n        fillColor: '#1976D2',\r\n        fillOpacity: 0.35,\r\n      });\r\n  }\r\n  return null;\r\n}\r\n\r\n@Component({\r\n  selector: 'google-map',\r\n  template: ` <div [ngStyle]=\"style\" [class]=\"styleClass\"></div>`,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  encapsulation: ViewEncapsulation.None,\r\n  host: {\r\n    class: 'p-element', // this is fancy, but can we use it actually?\r\n  },\r\n})\r\nexport class GoogleMap extends AbstractMap implements AfterViewChecked {\r\n  @Input() style?: any;\r\n  @Input() styleClass?: string;\r\n\r\n  @Output() onOverlayDblClick: EventEmitter<any> = new EventEmitter();\r\n  @Output() onOverlayDragStart: EventEmitter<any> = new EventEmitter();\r\n  @Output() onOverlayDrag: EventEmitter<any> = new EventEmitter();\r\n  @Output() onOverlayDragEnd: EventEmitter<any> = new EventEmitter();\r\n  @Output() onMapReady: EventEmitter<any> = new EventEmitter();\r\n\r\n  constructor(el: ElementRef, cd: ChangeDetectorRef, zone: NgZone) {\r\n    super(el, cd, zone, createGoogleMapsItem);\r\n  }\r\n\r\n  ngAfterViewChecked() {\r\n    if (!this.map && this.el.nativeElement.offsetParent) {\r\n      this.initialize();\r\n    }\r\n  }\r\n\r\n  private initialize(): void {\r\n    this.map = new google.maps.Map(\r\n      this.el.nativeElement.children[0],\r\n      this.createGoogleMapsOptions()\r\n    );\r\n    const items = this.items();\r\n    const toAdd: Array<RecordWithId> = items.map((it) => ({\r\n      id: it.id!,\r\n      record: createGoogleMapsItem(it, '#3388ff'),\r\n    }));\r\n    this.handleItemChanges([], toAdd);\r\n\r\n    this.onMapReady.emit({\r\n      map: this.map,\r\n    });\r\n\r\n    this.map.addListener('click', (event: any) => {\r\n      this.zone.run(() => {\r\n        const center = this.map.getCenter(); // FIXME get actual coordinates\r\n        this.onMapClick.emit({\r\n          coordinates: {\r\n            latitude: center.lat as number,\r\n            longitude: center.lng as number,\r\n          },\r\n          originalEvent: event,\r\n        });\r\n      });\r\n    });\r\n\r\n    this.map.addListener('dragend', (event: any) => {\r\n      this.zone.run(() => {\r\n        const center = this.map.getCenter();\r\n        const zoom = this.map.getZoom();\r\n        const bounds = this.map.getBounds();\r\n        const ne = bounds.getNorthEast();\r\n        const sw = bounds.getSouthWest();\r\n        this.onMapDragEnd.emit({\r\n          originalEvent: event,\r\n          viewport: {\r\n            center: {\r\n              latitude: center.lat as number,\r\n              longitude: center.lng as number,\r\n            },\r\n            zoomLevel: zoom as number,\r\n            bounds: [\r\n              { latitude: ne.lat, longitude: ne.lng },\r\n              { latitude: sw.lat, longitude: sw.lng },\r\n            ],\r\n          },\r\n        });\r\n      });\r\n    });\r\n\r\n    this.map.addListener('zoom_changed', (event: any) => {\r\n      this.zone.run(() => {\r\n        this.onZoomChanged.emit({\r\n          viewport: {\r\n            zoomLevel: this.map.getZoom() as number,\r\n            ...this.model().viewport!,\r\n          },\r\n          originalEvent: event,\r\n        });\r\n      });\r\n    });\r\n  }\r\n\r\n  private createGoogleMapsOptions(): any {\r\n    const viewport: GeoMapViewport = this.model().viewport!;\r\n    return {\r\n      center: {\r\n        lat: viewport.center?.latitude,\r\n        lng: viewport.center?.longitude,\r\n      },\r\n      zoom: viewport.zoomLevel,\r\n    };\r\n  }\r\n\r\n  override handleItemChanges(toRemove: Array<RecordWithId>, toAdd: Array<RecordWithId>): void {\r\n    if (!this.map) {\r\n      return;\r\n    }\r\n    toRemove.forEach((it: RecordWithId) => {\r\n      google.maps.event.clearInstanceListeners(it.record.item);\r\n      it.record.item.setMap(null);\r\n      this.overlays.delete(it.id);\r\n    });\r\n\r\n    toAdd.forEach((it: RecordWithId) => {\r\n      it.record.item.setMap(this.map);\r\n      it.record.item.addListener('click', (event: any) => {\r\n        this.zone.run(() => {\r\n          this.onOverlayClick.emit({\r\n            itemId: it.id,\r\n            originalEvent: {\r\n              originalEvent: event,\r\n              overlay: it.record.item,\r\n              map: this.map,\r\n            },\r\n          });\r\n        });\r\n      });\r\n      it.record.item.addListener('dblclick', (event: any) => {\r\n        this.zone.run(() => {\r\n          this.onOverlayDblClick.emit({\r\n            originalEvent: event,\r\n            overlay: it,\r\n            map: this.map,\r\n          });\r\n        });\r\n      });\r\n\r\n      if (it.record.item.getDraggable()) {\r\n        this.bindDragEvents(it.record.item);\r\n      }\r\n      this.overlays.set(it.id, it.record);\r\n    });\r\n  }\r\n\r\n  override handleEditingItemChanges(\r\n    toRemove: Array<RecordWithId>,\r\n    toAdd: Array<RecordWithId>\r\n  ): void {}\r\n\r\n  bindDragEvents(overlay: any) {\r\n    overlay.addListener('dragstart', (event: any) => {\r\n      this.zone.run(() => {\r\n        this.onOverlayDragStart.emit({\r\n          originalEvent: event,\r\n          overlay: overlay,\r\n          map: this.map,\r\n        });\r\n      });\r\n    });\r\n\r\n    overlay.addListener('drag', (event: any) => {\r\n      this.zone.run(() => {\r\n        this.onOverlayDrag.emit({\r\n          originalEvent: event,\r\n          overlay: overlay,\r\n          map: this.map,\r\n        });\r\n      });\r\n    });\r\n\r\n    overlay.addListener('dragend', (event: any) => {\r\n      this.zone.run(() => {\r\n        this.onOverlayDragEnd.emit({\r\n          originalEvent: event,\r\n          overlay: overlay,\r\n          map: this.map,\r\n        });\r\n      });\r\n    });\r\n  }\r\n\r\n  getMap() {\r\n    return this.map;\r\n  }\r\n}\r\n"]}
221
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"google-map.js","sourceRoot":"","sources":["../../../../../../projects/smart-ng-client/src/lib/smart-map/impl/google-map.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewChecked,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  NgZone,\r\n  Output,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport { AbstractMap, RecordWithId } from '../abstract-map';\r\nimport { GeoMapItem, GeoMapItemKind, GeoMapViewport } from '../api';\r\nimport { MapItemConfiguration } from '../smart-map.types';\r\n\r\ndeclare var google: any;\r\n\r\nfunction createGoogleMapsItem(item: GeoMapItem, config: MapItemConfiguration): any {\r\n  switch (item.kind) {\r\n    case GeoMapItemKind.MARKER:\r\n      return new google.maps.Marker({\r\n        position: {\r\n          lat: item.position!.latitude,\r\n          lng: item.position!.longitude,\r\n        },\r\n        title: item.label,\r\n      });\r\n    case GeoMapItemKind.LINE:\r\n      return new google.maps.Polyline({\r\n        path: item.route!.points.map((it) => {\r\n          return { lat: it.latitude, lng: it.longitude };\r\n        }),\r\n        geodesic: true,\r\n        strokeColor: '#FF0000',\r\n        strokeOpacity: 0.5,\r\n        strokeWeight: 2,\r\n      });\r\n    case GeoMapItemKind.POLYGON:\r\n      return new google.maps.Polygon({\r\n        path: item.route!.points.map((it) => {\r\n          return { lat: it.latitude, lng: it.longitude };\r\n        }),\r\n        strokeOpacity: 0.5,\r\n        storeWeight: 1,\r\n        fillColor: '#1976D2',\r\n        fillOpacity: 0.35,\r\n      });\r\n  }\r\n  return null;\r\n}\r\n\r\n@Component({\r\n  selector: 'google-map',\r\n  template: ` <div [ngStyle]=\"style\" [class]=\"styleClass\"></div>`,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  encapsulation: ViewEncapsulation.None,\r\n  host: {\r\n    class: 'p-element', // this is fancy, but can we use it actually?\r\n  },\r\n})\r\nexport class GoogleMap extends AbstractMap implements AfterViewChecked {\r\n  @Input() style?: any;\r\n  @Input() styleClass?: string;\r\n\r\n  @Output() onOverlayDblClick: EventEmitter<any> = new EventEmitter();\r\n  @Output() onOverlayDragStart: EventEmitter<any> = new EventEmitter();\r\n  @Output() onOverlayDrag: EventEmitter<any> = new EventEmitter();\r\n  @Output() onOverlayDragEnd: EventEmitter<any> = new EventEmitter();\r\n  @Output() onMapReady: EventEmitter<any> = new EventEmitter();\r\n\r\n  constructor(el: ElementRef, cd: ChangeDetectorRef, zone: NgZone) {\r\n    super(el, cd, zone, createGoogleMapsItem);\r\n  }\r\n\r\n  ngAfterViewChecked() {\r\n    if (!this.map && this.el.nativeElement.offsetParent) {\r\n      this.initialize();\r\n    }\r\n  }\r\n\r\n  private initialize(): void {\r\n    this.map = new google.maps.Map(\r\n      this.el.nativeElement.children[0],\r\n      this.createGoogleMapsOptions()\r\n    );\r\n    const items = this.items();\r\n    const toAdd: Array<RecordWithId> = items.map((it) => ({\r\n      id: it.id!,\r\n      record: createGoogleMapsItem(it, { color: '#3388ff', draggable: false }),\r\n    }));\r\n    this.handleItemChanges([], toAdd);\r\n\r\n    this.onMapReady.emit({\r\n      map: this.map,\r\n    });\r\n\r\n    this.map.addListener('click', (event: any) => {\r\n      this.zone.run(() => {\r\n        const center = this.map.getCenter(); // FIXME get actual coordinates\r\n        this.onMapClick.emit({\r\n          coordinates: {\r\n            latitude: center.lat as number,\r\n            longitude: center.lng as number,\r\n          },\r\n          originalEvent: event,\r\n        });\r\n      });\r\n    });\r\n\r\n    this.map.addListener('dragend', (event: any) => {\r\n      this.zone.run(() => {\r\n        const center = this.map.getCenter();\r\n        const zoom = this.map.getZoom();\r\n        const bounds = this.map.getBounds();\r\n        const ne = bounds.getNorthEast();\r\n        const sw = bounds.getSouthWest();\r\n        this.onMapDragEnd.emit({\r\n          originalEvent: event,\r\n          viewport: {\r\n            center: {\r\n              latitude: center.lat as number,\r\n              longitude: center.lng as number,\r\n            },\r\n            zoomLevel: zoom as number,\r\n            bounds: [\r\n              { latitude: ne.lat, longitude: ne.lng },\r\n              { latitude: sw.lat, longitude: sw.lng },\r\n            ],\r\n          },\r\n        });\r\n      });\r\n    });\r\n\r\n    this.map.addListener('zoom_changed', (event: any) => {\r\n      this.zone.run(() => {\r\n        this.onZoomChanged.emit({\r\n          viewport: {\r\n            zoomLevel: this.map.getZoom() as number,\r\n            ...this.model().viewport!,\r\n          },\r\n          originalEvent: event,\r\n        });\r\n      });\r\n    });\r\n  }\r\n\r\n  private createGoogleMapsOptions(): any {\r\n    const viewport: GeoMapViewport = this.model().viewport!;\r\n    return {\r\n      center: {\r\n        lat: viewport.center?.latitude,\r\n        lng: viewport.center?.longitude,\r\n      },\r\n      zoom: viewport.zoomLevel,\r\n    };\r\n  }\r\n\r\n  override handleItemChanges(toRemove: Array<RecordWithId>, toAdd: Array<RecordWithId>): void {\r\n    if (!this.map) {\r\n      return;\r\n    }\r\n    toRemove.forEach((it: RecordWithId) => {\r\n      google.maps.event.clearInstanceListeners(it.record.item);\r\n      it.record.item.setMap(null);\r\n      this.overlays.delete(it.id);\r\n    });\r\n\r\n    toAdd.forEach((it: RecordWithId) => {\r\n      it.record.item.setMap(this.map);\r\n      it.record.item.addListener('click', (event: any) => {\r\n        this.zone.run(() => {\r\n          this.onOverlayClick.emit({\r\n            itemId: it.id,\r\n            originalEvent: {\r\n              originalEvent: event,\r\n              overlay: it.record.item,\r\n              map: this.map,\r\n            },\r\n          });\r\n        });\r\n      });\r\n      it.record.item.addListener('dblclick', (event: any) => {\r\n        this.zone.run(() => {\r\n          this.onOverlayDblClick.emit({\r\n            originalEvent: event,\r\n            overlay: it,\r\n            map: this.map,\r\n          });\r\n        });\r\n      });\r\n\r\n      if (it.record.item.getDraggable()) {\r\n        this.bindDragEvents(it.record.item);\r\n      }\r\n      this.overlays.set(it.id, it.record);\r\n    });\r\n  }\r\n\r\n  override handleEditingItemChanges(\r\n    toRemove: Array<RecordWithId>,\r\n    toAdd: Array<RecordWithId>\r\n  ): void {}\r\n\r\n  bindDragEvents(overlay: any) {\r\n    overlay.addListener('dragstart', (event: any) => {\r\n      this.zone.run(() => {\r\n        this.onOverlayDragStart.emit({\r\n          originalEvent: event,\r\n          overlay: overlay,\r\n          map: this.map,\r\n        });\r\n      });\r\n    });\r\n\r\n    overlay.addListener('drag', (event: any) => {\r\n      this.zone.run(() => {\r\n        this.onOverlayDrag.emit({\r\n          originalEvent: event,\r\n          overlay: overlay,\r\n          map: this.map,\r\n        });\r\n      });\r\n    });\r\n\r\n    overlay.addListener('dragend', (event: any) => {\r\n      this.zone.run(() => {\r\n        this.onOverlayDragEnd.emit({\r\n          originalEvent: event,\r\n          overlay: overlay,\r\n          map: this.map,\r\n        });\r\n      });\r\n    });\r\n  }\r\n\r\n  getMap() {\r\n    return this.map;\r\n  }\r\n}\r\n"]}
@@ -2,30 +2,31 @@ import { Component } from '@angular/core';
2
2
  import { AbstractMap } from '../abstract-map';
3
3
  import { GeoMapItemKind } from '../api';
4
4
  import * as i0 from "@angular/core";
5
- function createLeafletMapItem(item, color) {
5
+ function createLeafletMapItem(item, config) {
6
6
  switch (item.kind) {
7
7
  case GeoMapItemKind.MARKER:
8
8
  return L.marker(L.latLng(item.position.latitude, item.position.longitude), {
9
9
  title: item.label,
10
+ interactive: config.draggable,
10
11
  });
11
12
  case GeoMapItemKind.POLYGON:
12
13
  const polygonRoutePoints = item.route.points;
13
14
  return L.layerGroup([
14
- L.polygon(polygonRoutePoints.map((p) => [p.latitude, p.longitude]), { title: item.label, color: color, interactive: true }),
15
+ L.polygon(polygonRoutePoints.map((p) => [p.latitude, p.longitude]), { title: item.label, color: config.color }),
15
16
  ...polygonRoutePoints.map((p) => L.marker([p.latitude, p.longitude], {
16
17
  title: item.label,
17
- markerColor: color,
18
- draggable: true,
18
+ markerColor: config.color,
19
+ draggable: config.draggable,
19
20
  })),
20
21
  ]);
21
22
  case GeoMapItemKind.LINE:
22
23
  const lineRoutePoints = item.route.points;
23
24
  return L.layerGroup([
24
- L.polyline(lineRoutePoints.map((p) => [p.latitude, p.longitude]), { title: item.label, color: color }),
25
+ L.polyline(lineRoutePoints.map((p) => [p.latitude, p.longitude]), { title: item.label, color: config.color }),
25
26
  ...lineRoutePoints.map((p) => L.marker([p.latitude, p.longitude], {
26
27
  title: item.label,
27
- color: color,
28
- draggable: true,
28
+ color: config.color,
29
+ draggable: config.draggable,
29
30
  })),
30
31
  ]);
31
32
  }
@@ -50,7 +51,7 @@ export class LeafletMap extends AbstractMap {
50
51
  const items = this.items();
51
52
  const toAdd = items.map((it) => ({
52
53
  id: it.id,
53
- record: createLeafletMapItem(it, '#ff0000'),
54
+ record: createLeafletMapItem(it, { color: '#3388ff', draggable: false }),
54
55
  }));
55
56
  this.handleItemChanges([], toAdd);
56
57
  const model = this.model();
@@ -134,18 +135,37 @@ export class LeafletMap extends AbstractMap {
134
135
  this.overlays.delete(it.id);
135
136
  });
136
137
  toAdd.forEach((it) => {
137
- it.record.on('click', (event) => {
138
- this.zone.run(() => {
139
- this.onOverlayClick.emit({
140
- itemId: it.id,
141
- originalEvent: {
142
- originalEvent: event,
143
- overlay: it.record,
144
- map: this.map,
145
- },
138
+ let record = it.record;
139
+ if (record instanceof L.LayerGroup) {
140
+ Object.values(record._layers).forEach((at) => {
141
+ at.on('click', (event) => {
142
+ this.zone.run(() => {
143
+ this.onOverlayClick.emit({
144
+ itemId: it.id,
145
+ originalEvent: {
146
+ originalEvent: event,
147
+ overlay: it.record,
148
+ map: this.map,
149
+ },
150
+ });
151
+ });
146
152
  });
147
153
  });
148
- });
154
+ }
155
+ else {
156
+ it.record.on('click', (event) => {
157
+ this.zone.run(() => {
158
+ this.onOverlayClick.emit({
159
+ itemId: it.id,
160
+ originalEvent: {
161
+ originalEvent: event,
162
+ overlay: it.record,
163
+ map: this.map,
164
+ },
165
+ });
166
+ });
167
+ });
168
+ }
149
169
  it.record.addTo(this.map);
150
170
  this.overlays.set(it.id, it.record);
151
171
  });
@@ -241,4 +261,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
241
261
  type: Component,
242
262
  args: [{ selector: 'leaflet-map', template: ` <div id="leaflet"></div>`, styles: ["#leaflet{height:720px}\n"] }]
243
263
  }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i0.NgZone }] });
244
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"leaflet-map.js","sourceRoot":"","sources":["../../../../../../projects/smart-ng-client/src/lib/smart-map/impl/leaflet-map.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewChecked, ChangeDetectorRef, Component, ElementRef, NgZone } from '@angular/core';\r\nimport { AbstractMap, RecordWithId } from '../abstract-map';\r\nimport { GeoMapItem, GeoMapItemKind, GeoMapViewport } from '../api';\r\nimport { Coord } from '../smart-map.types';\r\n\r\ndeclare var L: any;\r\n\r\ninterface LeafletMapOptions {\r\n  centre: Array<number>;\r\n  zoom: number;\r\n}\r\n\r\nfunction createLeafletMapItem(item: GeoMapItem, color: string): any {\r\n  switch (item.kind) {\r\n    case GeoMapItemKind.MARKER:\r\n      return L.marker(L.latLng(item.position!.latitude, item.position!.longitude), {\r\n        title: item.label,\r\n      });\r\n    case GeoMapItemKind.POLYGON:\r\n      const polygonRoutePoints = item.route!.points;\r\n      return L.layerGroup([\r\n        L.polygon(\r\n          polygonRoutePoints.map((p) => [p.latitude, p.longitude]),\r\n          { title: item.label, color: color, interactive: true }\r\n        ),\r\n        ...polygonRoutePoints.map((p) =>\r\n          L.marker([p.latitude, p.longitude], {\r\n            title: item.label,\r\n            markerColor: color,\r\n            draggable: true,\r\n          })\r\n        ),\r\n      ]);\r\n    case GeoMapItemKind.LINE:\r\n      const lineRoutePoints = item.route!.points;\r\n\r\n      return L.layerGroup([\r\n        L.polyline(\r\n          lineRoutePoints.map((p) => [p.latitude, p.longitude]),\r\n          { title: item.label, color: color }\r\n        ),\r\n        ...lineRoutePoints.map((p) =>\r\n          L.marker([p.latitude, p.longitude], {\r\n            title: item.label,\r\n            color: color,\r\n            draggable: true,\r\n          })\r\n        ),\r\n      ]);\r\n  }\r\n  throw new Error('Foo!');\r\n}\r\n\r\n@Component({\r\n  selector: 'leaflet-map',\r\n  template: ` <div id=\"leaflet\"></div>`,\r\n  styles: `\r\n      #leaflet {\r\n          height: 720px;\r\n      }`,\r\n})\r\nexport class LeafletMap extends AbstractMap implements AfterViewChecked {\r\n  originalLatLng: any;\r\n  constructor(el: ElementRef, cd: ChangeDetectorRef, zone: NgZone) {\r\n    super(el, cd, zone, createLeafletMapItem);\r\n  }\r\n\r\n  ngAfterViewChecked(): void {\r\n    if (!this.map && this.el.nativeElement.offsetParent) {\r\n      this.initialize();\r\n    }\r\n  }\r\n\r\n  private initialize(): void {\r\n    const options = this.createLeafletMapOptions();\r\n    this.map = L.map('leaflet').setView(options.centre, options.zoom);\r\n    L.tileLayer('https://tile.openstreetmap.org/{z}/{x}/{y}.png', {\r\n      maxZoom: 19,\r\n      attribution: '&copy; <a href=\"http://www.openstreetmap.org/copyright\">OpenStreetMap</a>',\r\n    }).addTo(this.map);\r\n\r\n    const items = this.items();\r\n    const toAdd: Array<RecordWithId> = items.map((it) => ({\r\n      id: it.id!,\r\n      record: createLeafletMapItem(it, '#ff0000'),\r\n    }));\r\n    this.handleItemChanges([], toAdd);\r\n    const model = this.model();\r\n    if (model.viewState?.fitToInitialItems) {\r\n      const datasetBounds = this.findDatasetBounds();\r\n      if (datasetBounds) {\r\n        const { a, b } = datasetBounds;\r\n        const pntA = L.latLng(a.x, a.y);\r\n        const pntB = L.latLng(b.x, b.y);\r\n        const bounds = L.latLngBounds(pntA, pntB);\r\n        this.zone.run(() => {\r\n          this.map.fitBounds(bounds);\r\n        });\r\n      }\r\n    }\r\n    this.map.on('click', (event: any) => {\r\n      this.zone.run(() => {\r\n        const pos = event.latlng;\r\n        this.onMapClick.emit({\r\n          coordinates: {\r\n            latitude: pos.lat as number,\r\n            longitude: pos.lng as number,\r\n          },\r\n          originalEvent: event,\r\n        });\r\n      });\r\n    });\r\n\r\n    this.map.on('moveend', (event: any) => {\r\n      this.zone.run(() => {\r\n        const viewport = this.getViewport();\r\n        this.onMapDragEnd.emit({\r\n          viewport,\r\n          originalEvent: event,\r\n        });\r\n      });\r\n    });\r\n\r\n    this.map.on('zoomend', (event: any) => {\r\n      this.zone.run(() => {\r\n        const viewport = this.getViewport();\r\n        this.onMapDragEnd.emit({\r\n          viewport,\r\n          originalEvent: event,\r\n        });\r\n      });\r\n    });\r\n  }\r\n\r\n  getViewport(): GeoMapViewport {\r\n    if (!this.map) {\r\n      throw new Error('Map is not yet initialised!');\r\n    }\r\n\r\n    const center = this.map.getCenter();\r\n    const zoomLevel = this.map.getZoom() as number;\r\n    const leafletBounds = this.map.getBounds();\r\n    const { lat: swLat, lng: swLng } = leafletBounds.getSouthWest();\r\n    const { lat: neLat, lng: neLng } = leafletBounds.getNorthEast();\r\n\r\n    return {\r\n      center: {\r\n        latitude: center.lat as number,\r\n        longitude: center.lng as number,\r\n      },\r\n      zoomLevel,\r\n      bounds: [\r\n        { latitude: swLat, longitude: swLng },\r\n        { latitude: neLat, longitude: neLng },\r\n      ],\r\n    };\r\n  }\r\n\r\n  private createLeafletMapOptions(): LeafletMapOptions {\r\n    const viewport: GeoMapViewport = this.model().viewport!;\r\n    return {\r\n      centre: [viewport.center!.latitude, viewport.center!.longitude],\r\n      zoom: viewport.zoomLevel!,\r\n    };\r\n  }\r\n\r\n  override handleItemChanges(toRemove: Array<RecordWithId>, toAdd: Array<RecordWithId>): void {\r\n    if (!this.map) {\r\n      return;\r\n    }\r\n\r\n    toRemove.forEach((it) => {\r\n      it.record.remove();\r\n      this.overlays.delete(it.id);\r\n    });\r\n\r\n    toAdd.forEach((it) => {\r\n      it.record.on('click', (event: any) => {\r\n        this.zone.run(() => {\r\n          this.onOverlayClick.emit({\r\n            itemId: it.id,\r\n            originalEvent: {\r\n              originalEvent: event,\r\n              overlay: it.record,\r\n              map: this.map,\r\n            },\r\n          });\r\n        });\r\n      });\r\n      it.record.addTo(this.map);\r\n      this.overlays.set(it.id, it.record);\r\n    });\r\n  }\r\n  override handleEditingItemChanges(\r\n    toRemove: Array<RecordWithId>,\r\n    toAdd: Array<RecordWithId>\r\n  ): void {\r\n    if (!this.map) {\r\n      return;\r\n    }\r\n\r\n    toRemove.forEach((it) => {\r\n      it.record.remove();\r\n      this.editingOverlays.delete(it.id);\r\n    });\r\n\r\n    toAdd.forEach((it) => {\r\n      let record = it.record;\r\n      if (record instanceof L.LayerGroup) {\r\n        Object.values(record._layers).forEach((at: any) => {\r\n          at.on('click', (event: any) => {\r\n            this.zone.run(() => {\r\n              this.onEditingOverlayClick.emit({\r\n                itemId: it.id,\r\n                coord: {\r\n                  x: event.latlng.lng,\r\n                  y: event.latlng.lat,\r\n                },\r\n              });\r\n            });\r\n          });\r\n          at.on('dragstart', (event: any) => {\r\n            this.originalLatLng = event.target.getLatLng();\r\n          });\r\n          at.on('dragend', (event: any) => {\r\n            this.zone.run(() => {\r\n              this.onEditingOverlayDrag.emit({\r\n                itemId: it.id,\r\n                startPosition: {\r\n                  x: this.originalLatLng.lng,\r\n                  y: this.originalLatLng.lat,\r\n                },\r\n                dragTo: {\r\n                  x: event.target.getLatLng().lng,\r\n                  y: event.target.getLatLng().lat,\r\n                },\r\n              });\r\n            });\r\n            this.originalLatLng = null;\r\n          });\r\n        });\r\n      } else {\r\n        it.record.on('click', (event: any) => {\r\n          this.zone.run(() => {\r\n            this.onEditingOverlayClick.emit({\r\n              itemId: it.id,\r\n              coord: {\r\n                x: event.latlng.lng,\r\n                y: event.latlng.lat,\r\n              },\r\n            });\r\n          });\r\n        });\r\n      }\r\n\r\n      it.record.addTo(this.map);\r\n      this.editingOverlays.set(it.id, it.record);\r\n    });\r\n  }\r\n\r\n  private findDatasetBounds(): { a: Coord; b: Coord } | null {\r\n    const items: Array<Coord> = this.items()\r\n      .flatMap((it) => (it.position ? [it.position] : []))\r\n      .map((it) => {\r\n        return { x: it.latitude, y: it.longitude };\r\n      });\r\n    if (!items || items.length === 0) {\r\n      return null;\r\n    }\r\n\r\n    let southwest: Coord = { x: items[0].x, y: items[0].y };\r\n    let northeast: Coord = { x: items[0].x, y: items[0].y };\r\n\r\n    items.forEach((it) => {\r\n      if (it.x < southwest.x) southwest.x = it.x;\r\n      if (it.y < southwest.y) southwest.y = it.y;\r\n\r\n      if (it.x > northeast.x) northeast.x = it.x;\r\n      if (it.y > northeast.y) northeast.y = it.y;\r\n    });\r\n\r\n    return { a: southwest, b: northeast };\r\n  }\r\n}\r\n"]}
264
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"leaflet-map.js","sourceRoot":"","sources":["../../../../../../projects/smart-ng-client/src/lib/smart-map/impl/leaflet-map.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewChecked, ChangeDetectorRef, Component, ElementRef, NgZone } from '@angular/core';\r\nimport { AbstractMap, RecordWithId } from '../abstract-map';\r\nimport { GeoMapItem, GeoMapItemKind, GeoMapViewport } from '../api';\r\nimport { Coord, MapItemConfiguration } from '../smart-map.types';\r\n\r\ndeclare var L: any;\r\n\r\ninterface LeafletMapOptions {\r\n  centre: Array<number>;\r\n  zoom: number;\r\n}\r\n\r\nfunction createLeafletMapItem(item: GeoMapItem, config: MapItemConfiguration): any {\r\n  switch (item.kind) {\r\n    case GeoMapItemKind.MARKER:\r\n      return L.marker(L.latLng(item.position!.latitude, item.position!.longitude), {\r\n        title: item.label,\r\n        interactive: config.draggable,\r\n      });\r\n    case GeoMapItemKind.POLYGON:\r\n      const polygonRoutePoints = item.route!.points;\r\n      return L.layerGroup([\r\n        L.polygon(\r\n          polygonRoutePoints.map((p) => [p.latitude, p.longitude]),\r\n          { title: item.label, color: config.color }\r\n        ),\r\n        ...polygonRoutePoints.map((p) =>\r\n          L.marker([p.latitude, p.longitude], {\r\n            title: item.label,\r\n            markerColor: config.color,\r\n            draggable: config.draggable,\r\n          })\r\n        ),\r\n      ]);\r\n    case GeoMapItemKind.LINE:\r\n      const lineRoutePoints = item.route!.points;\r\n\r\n      return L.layerGroup([\r\n        L.polyline(\r\n          lineRoutePoints.map((p) => [p.latitude, p.longitude]),\r\n          { title: item.label, color: config.color }\r\n        ),\r\n        ...lineRoutePoints.map((p) =>\r\n          L.marker([p.latitude, p.longitude], {\r\n            title: item.label,\r\n            color: config.color,\r\n            draggable: config.draggable,\r\n          })\r\n        ),\r\n      ]);\r\n  }\r\n  throw new Error('Foo!');\r\n}\r\n\r\n@Component({\r\n  selector: 'leaflet-map',\r\n  template: ` <div id=\"leaflet\"></div>`,\r\n  styles: `\r\n      #leaflet {\r\n          height: 720px;\r\n      }`,\r\n})\r\nexport class LeafletMap extends AbstractMap implements AfterViewChecked {\r\n  originalLatLng: any;\r\n  constructor(el: ElementRef, cd: ChangeDetectorRef, zone: NgZone) {\r\n    super(el, cd, zone, createLeafletMapItem);\r\n  }\r\n\r\n  ngAfterViewChecked(): void {\r\n    if (!this.map && this.el.nativeElement.offsetParent) {\r\n      this.initialize();\r\n    }\r\n  }\r\n\r\n  private initialize(): void {\r\n    const options = this.createLeafletMapOptions();\r\n    this.map = L.map('leaflet').setView(options.centre, options.zoom);\r\n    L.tileLayer('https://tile.openstreetmap.org/{z}/{x}/{y}.png', {\r\n      maxZoom: 19,\r\n      attribution: '&copy; <a href=\"http://www.openstreetmap.org/copyright\">OpenStreetMap</a>',\r\n    }).addTo(this.map);\r\n\r\n    const items = this.items();\r\n    const toAdd: Array<RecordWithId> = items.map((it) => ({\r\n      id: it.id!,\r\n      record: createLeafletMapItem(it, { color: '#3388ff', draggable: false }),\r\n    }));\r\n    this.handleItemChanges([], toAdd);\r\n    const model = this.model();\r\n    if (model.viewState?.fitToInitialItems) {\r\n      const datasetBounds = this.findDatasetBounds();\r\n      if (datasetBounds) {\r\n        const { a, b } = datasetBounds;\r\n        const pntA = L.latLng(a.x, a.y);\r\n        const pntB = L.latLng(b.x, b.y);\r\n        const bounds = L.latLngBounds(pntA, pntB);\r\n        this.zone.run(() => {\r\n          this.map.fitBounds(bounds);\r\n        });\r\n      }\r\n    }\r\n    this.map.on('click', (event: any) => {\r\n      this.zone.run(() => {\r\n        const pos = event.latlng;\r\n        this.onMapClick.emit({\r\n          coordinates: {\r\n            latitude: pos.lat as number,\r\n            longitude: pos.lng as number,\r\n          },\r\n          originalEvent: event,\r\n        });\r\n      });\r\n    });\r\n\r\n    this.map.on('moveend', (event: any) => {\r\n      this.zone.run(() => {\r\n        const viewport = this.getViewport();\r\n        this.onMapDragEnd.emit({\r\n          viewport,\r\n          originalEvent: event,\r\n        });\r\n      });\r\n    });\r\n\r\n    this.map.on('zoomend', (event: any) => {\r\n      this.zone.run(() => {\r\n        const viewport = this.getViewport();\r\n        this.onMapDragEnd.emit({\r\n          viewport,\r\n          originalEvent: event,\r\n        });\r\n      });\r\n    });\r\n  }\r\n\r\n  getViewport(): GeoMapViewport {\r\n    if (!this.map) {\r\n      throw new Error('Map is not yet initialised!');\r\n    }\r\n\r\n    const center = this.map.getCenter();\r\n    const zoomLevel = this.map.getZoom() as number;\r\n    const leafletBounds = this.map.getBounds();\r\n    const { lat: swLat, lng: swLng } = leafletBounds.getSouthWest();\r\n    const { lat: neLat, lng: neLng } = leafletBounds.getNorthEast();\r\n\r\n    return {\r\n      center: {\r\n        latitude: center.lat as number,\r\n        longitude: center.lng as number,\r\n      },\r\n      zoomLevel,\r\n      bounds: [\r\n        { latitude: swLat, longitude: swLng },\r\n        { latitude: neLat, longitude: neLng },\r\n      ],\r\n    };\r\n  }\r\n\r\n  private createLeafletMapOptions(): LeafletMapOptions {\r\n    const viewport: GeoMapViewport = this.model().viewport!;\r\n    return {\r\n      centre: [viewport.center!.latitude, viewport.center!.longitude],\r\n      zoom: viewport.zoomLevel!,\r\n    };\r\n  }\r\n\r\n  override handleItemChanges(toRemove: Array<RecordWithId>, toAdd: Array<RecordWithId>): void {\r\n    if (!this.map) {\r\n      return;\r\n    }\r\n\r\n    toRemove.forEach((it) => {\r\n      it.record.remove();\r\n      this.overlays.delete(it.id);\r\n    });\r\n\r\n    toAdd.forEach((it) => {\r\n      let record = it.record;\r\n      if (record instanceof L.LayerGroup) {\r\n        Object.values(record._layers).forEach((at: any) => {\r\n          at.on('click', (event: any) => {\r\n            this.zone.run(() => {\r\n              this.onOverlayClick.emit({\r\n                itemId: it.id,\r\n                originalEvent: {\r\n                  originalEvent: event,\r\n                  overlay: it.record,\r\n                  map: this.map,\r\n                },\r\n              });\r\n            });\r\n          });\r\n        });\r\n      } else {\r\n        it.record.on('click', (event: any) => {\r\n          this.zone.run(() => {\r\n            this.onOverlayClick.emit({\r\n              itemId: it.id,\r\n              originalEvent: {\r\n                originalEvent: event,\r\n                overlay: it.record,\r\n                map: this.map,\r\n              },\r\n            });\r\n          });\r\n        });\r\n      }\r\n      it.record.addTo(this.map);\r\n      this.overlays.set(it.id, it.record);\r\n    });\r\n  }\r\n  override handleEditingItemChanges(\r\n    toRemove: Array<RecordWithId>,\r\n    toAdd: Array<RecordWithId>\r\n  ): void {\r\n    if (!this.map) {\r\n      return;\r\n    }\r\n\r\n    toRemove.forEach((it) => {\r\n      it.record.remove();\r\n      this.editingOverlays.delete(it.id);\r\n    });\r\n\r\n    toAdd.forEach((it) => {\r\n      let record = it.record;\r\n      if (record instanceof L.LayerGroup) {\r\n        Object.values(record._layers).forEach((at: any) => {\r\n          at.on('click', (event: any) => {\r\n            this.zone.run(() => {\r\n              this.onEditingOverlayClick.emit({\r\n                itemId: it.id,\r\n                coord: {\r\n                  x: event.latlng.lng,\r\n                  y: event.latlng.lat,\r\n                },\r\n              });\r\n            });\r\n          });\r\n          at.on('dragstart', (event: any) => {\r\n            this.originalLatLng = event.target.getLatLng();\r\n          });\r\n          at.on('dragend', (event: any) => {\r\n            this.zone.run(() => {\r\n              this.onEditingOverlayDrag.emit({\r\n                itemId: it.id,\r\n                startPosition: {\r\n                  x: this.originalLatLng.lng,\r\n                  y: this.originalLatLng.lat,\r\n                },\r\n                dragTo: {\r\n                  x: event.target.getLatLng().lng,\r\n                  y: event.target.getLatLng().lat,\r\n                },\r\n              });\r\n            });\r\n            this.originalLatLng = null;\r\n          });\r\n        });\r\n      } else {\r\n        it.record.on('click', (event: any) => {\r\n          this.zone.run(() => {\r\n            this.onEditingOverlayClick.emit({\r\n              itemId: it.id,\r\n              coord: {\r\n                x: event.latlng.lng,\r\n                y: event.latlng.lat,\r\n              },\r\n            });\r\n          });\r\n        });\r\n      }\r\n\r\n      it.record.addTo(this.map);\r\n      this.editingOverlays.set(it.id, it.record);\r\n    });\r\n  }\r\n\r\n  private findDatasetBounds(): { a: Coord; b: Coord } | null {\r\n    const items: Array<Coord> = this.items()\r\n      .flatMap((it) => (it.position ? [it.position] : []))\r\n      .map((it) => {\r\n        return { x: it.latitude, y: it.longitude };\r\n      });\r\n    if (!items || items.length === 0) {\r\n      return null;\r\n    }\r\n\r\n    let southwest: Coord = { x: items[0].x, y: items[0].y };\r\n    let northeast: Coord = { x: items[0].x, y: items[0].y };\r\n\r\n    items.forEach((it) => {\r\n      if (it.x < southwest.x) southwest.x = it.x;\r\n      if (it.y < southwest.y) southwest.y = it.y;\r\n\r\n      if (it.x > northeast.x) northeast.x = it.x;\r\n      if (it.y > northeast.y) northeast.y = it.y;\r\n    });\r\n\r\n    return { a: southwest, b: northeast };\r\n  }\r\n}\r\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnQtbWFwLnR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc21hcnQtbmctY2xpZW50L3NyYy9saWIvc21hcnQtbWFwL3NtYXJ0LW1hcC50eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgR2VvTWFwVmlld3BvcnQsIEdQU1Bvc2l0aW9uIH0gZnJvbSAnLi9hcGknO1xyXG5cclxuZXhwb3J0IHR5cGUgTWFwRHJhZ2dlZEV2ZW50ID0ge1xyXG4gIHZpZXdwb3J0OiBHZW9NYXBWaWV3cG9ydDtcclxuICBvcmlnaW5hbEV2ZW50OiBhbnk7XHJcbn07XHJcblxyXG5leHBvcnQgdHlwZSBNYXBab29tQ2hhbmdlZEV2ZW50ID0ge1xyXG4gIHZpZXdwb3J0OiBHZW9NYXBWaWV3cG9ydDtcclxuICBvcmlnaW5hbEV2ZW50OiBhbnk7XHJcbn07XHJcblxyXG5leHBvcnQgdHlwZSBNYXBJdGVtQ2xpY2tlZEV2ZW50ID0ge1xyXG4gIGl0ZW1JZDogc3RyaW5nO1xyXG4gIG9yaWdpbmFsRXZlbnQ6IGFueTtcclxufTtcclxuZXhwb3J0IHR5cGUgTWFwRWRpdGluZ0l0ZW1DbGlja2VkRXZlbnQgPSB7XHJcbiAgaXRlbUlkOiBzdHJpbmc7XHJcbiAgY29vcmQ6IENvb3JkO1xyXG59O1xyXG5cclxuZXhwb3J0IHR5cGUgTWFwRWRpdGluZ0l0ZW1EcmFnZ2VkRXZlbnQgPSB7XHJcbiAgaXRlbUlkOiBzdHJpbmc7XHJcbiAgc3RhcnRQb3NpdGlvbj86IENvb3JkO1xyXG4gIGRyYWdUbzogQ29vcmQ7XHJcbn07XHJcblxyXG5leHBvcnQgdHlwZSBNYXBDbGlja2VkRXZlbnQgPSB7XHJcbiAgY29vcmRpbmF0ZXM6IEdQU1Bvc2l0aW9uO1xyXG4gIG9yaWdpbmFsRXZlbnQ6IGFueTtcclxufTtcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgQ29vcmQge1xyXG4gIHg6IG51bWJlcjtcclxuICB5OiBudW1iZXI7XHJcbn1cclxuIl19
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnQtbWFwLnR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc21hcnQtbmctY2xpZW50L3NyYy9saWIvc21hcnQtbWFwL3NtYXJ0LW1hcC50eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgR2VvTWFwVmlld3BvcnQsIEdQU1Bvc2l0aW9uIH0gZnJvbSAnLi9hcGknO1xyXG5cclxuZXhwb3J0IHR5cGUgTWFwRHJhZ2dlZEV2ZW50ID0ge1xyXG4gIHZpZXdwb3J0OiBHZW9NYXBWaWV3cG9ydDtcclxuICBvcmlnaW5hbEV2ZW50OiBhbnk7XHJcbn07XHJcblxyXG5leHBvcnQgdHlwZSBNYXBab29tQ2hhbmdlZEV2ZW50ID0ge1xyXG4gIHZpZXdwb3J0OiBHZW9NYXBWaWV3cG9ydDtcclxuICBvcmlnaW5hbEV2ZW50OiBhbnk7XHJcbn07XHJcblxyXG5leHBvcnQgdHlwZSBNYXBJdGVtQ2xpY2tlZEV2ZW50ID0ge1xyXG4gIGl0ZW1JZDogc3RyaW5nO1xyXG4gIG9yaWdpbmFsRXZlbnQ6IGFueTtcclxufTtcclxuZXhwb3J0IHR5cGUgTWFwRWRpdGluZ0l0ZW1DbGlja2VkRXZlbnQgPSB7XHJcbiAgaXRlbUlkOiBzdHJpbmc7XHJcbiAgY29vcmQ6IENvb3JkO1xyXG59O1xyXG5cclxuZXhwb3J0IHR5cGUgTWFwRWRpdGluZ0l0ZW1EcmFnZ2VkRXZlbnQgPSB7XHJcbiAgaXRlbUlkOiBzdHJpbmc7XHJcbiAgc3RhcnRQb3NpdGlvbj86IENvb3JkO1xyXG4gIGRyYWdUbzogQ29vcmQ7XHJcbn07XHJcblxyXG5leHBvcnQgdHlwZSBNYXBDbGlja2VkRXZlbnQgPSB7XHJcbiAgY29vcmRpbmF0ZXM6IEdQU1Bvc2l0aW9uO1xyXG4gIG9yaWdpbmFsRXZlbnQ6IGFueTtcclxufTtcclxuZXhwb3J0IHR5cGUgTWFwSXRlbUNvbmZpZ3VyYXRpb24gPSB7XHJcbiAgY29sb3I6IHN0cmluZztcclxuICBkcmFnZ2FibGU6IGJvb2xlYW47XHJcbn07XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIENvb3JkIHtcclxuICB4OiBudW1iZXI7XHJcbiAgeTogbnVtYmVyO1xyXG59XHJcbiJdfQ==
@@ -15216,7 +15216,7 @@ class AbstractMap {
15216
15216
  else {
15217
15217
  toAdd.push({
15218
15218
  id: item.id,
15219
- record: this.itemFactory(item, '#3388ff'),
15219
+ record: this.itemFactory(item, { color: '#3388ff', draggable: false }),
15220
15220
  });
15221
15221
  }
15222
15222
  }
@@ -15239,7 +15239,7 @@ class AbstractMap {
15239
15239
  (pendingItems[0].position != null && pendingItems[0].position.latitude != null)) {
15240
15240
  editingToAdd.push({
15241
15241
  id: pendingItems[0].id,
15242
- record: this.itemFactory(pendingItems[0], '#ff0000'),
15242
+ record: this.itemFactory(pendingItems[0], { color: '#ff0000', draggable: true }),
15243
15243
  });
15244
15244
  }
15245
15245
  editingPresent.forEach((id) => {
@@ -15282,7 +15282,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
15282
15282
  type: Output
15283
15283
  }] } });
15284
15284
 
15285
- function createGoogleMapsItem(item, color) {
15285
+ function createGoogleMapsItem(item, config) {
15286
15286
  switch (item.kind) {
15287
15287
  case GeoMapItemKind.MARKER:
15288
15288
  return new google.maps.Marker({
@@ -15334,7 +15334,7 @@ class GoogleMap extends AbstractMap {
15334
15334
  const items = this.items();
15335
15335
  const toAdd = items.map((it) => ({
15336
15336
  id: it.id,
15337
- record: createGoogleMapsItem(it, '#3388ff'),
15337
+ record: createGoogleMapsItem(it, { color: '#3388ff', draggable: false }),
15338
15338
  }));
15339
15339
  this.handleItemChanges([], toAdd);
15340
15340
  this.onMapReady.emit({
@@ -15498,30 +15498,31 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
15498
15498
  type: Output
15499
15499
  }] } });
15500
15500
 
15501
- function createLeafletMapItem(item, color) {
15501
+ function createLeafletMapItem(item, config) {
15502
15502
  switch (item.kind) {
15503
15503
  case GeoMapItemKind.MARKER:
15504
15504
  return L.marker(L.latLng(item.position.latitude, item.position.longitude), {
15505
15505
  title: item.label,
15506
+ interactive: config.draggable,
15506
15507
  });
15507
15508
  case GeoMapItemKind.POLYGON:
15508
15509
  const polygonRoutePoints = item.route.points;
15509
15510
  return L.layerGroup([
15510
- L.polygon(polygonRoutePoints.map((p) => [p.latitude, p.longitude]), { title: item.label, color: color, interactive: true }),
15511
+ L.polygon(polygonRoutePoints.map((p) => [p.latitude, p.longitude]), { title: item.label, color: config.color }),
15511
15512
  ...polygonRoutePoints.map((p) => L.marker([p.latitude, p.longitude], {
15512
15513
  title: item.label,
15513
- markerColor: color,
15514
- draggable: true,
15514
+ markerColor: config.color,
15515
+ draggable: config.draggable,
15515
15516
  })),
15516
15517
  ]);
15517
15518
  case GeoMapItemKind.LINE:
15518
15519
  const lineRoutePoints = item.route.points;
15519
15520
  return L.layerGroup([
15520
- L.polyline(lineRoutePoints.map((p) => [p.latitude, p.longitude]), { title: item.label, color: color }),
15521
+ L.polyline(lineRoutePoints.map((p) => [p.latitude, p.longitude]), { title: item.label, color: config.color }),
15521
15522
  ...lineRoutePoints.map((p) => L.marker([p.latitude, p.longitude], {
15522
15523
  title: item.label,
15523
- color: color,
15524
- draggable: true,
15524
+ color: config.color,
15525
+ draggable: config.draggable,
15525
15526
  })),
15526
15527
  ]);
15527
15528
  }
@@ -15546,7 +15547,7 @@ class LeafletMap extends AbstractMap {
15546
15547
  const items = this.items();
15547
15548
  const toAdd = items.map((it) => ({
15548
15549
  id: it.id,
15549
- record: createLeafletMapItem(it, '#ff0000'),
15550
+ record: createLeafletMapItem(it, { color: '#3388ff', draggable: false }),
15550
15551
  }));
15551
15552
  this.handleItemChanges([], toAdd);
15552
15553
  const model = this.model();
@@ -15630,18 +15631,37 @@ class LeafletMap extends AbstractMap {
15630
15631
  this.overlays.delete(it.id);
15631
15632
  });
15632
15633
  toAdd.forEach((it) => {
15633
- it.record.on('click', (event) => {
15634
- this.zone.run(() => {
15635
- this.onOverlayClick.emit({
15636
- itemId: it.id,
15637
- originalEvent: {
15638
- originalEvent: event,
15639
- overlay: it.record,
15640
- map: this.map,
15641
- },
15634
+ let record = it.record;
15635
+ if (record instanceof L.LayerGroup) {
15636
+ Object.values(record._layers).forEach((at) => {
15637
+ at.on('click', (event) => {
15638
+ this.zone.run(() => {
15639
+ this.onOverlayClick.emit({
15640
+ itemId: it.id,
15641
+ originalEvent: {
15642
+ originalEvent: event,
15643
+ overlay: it.record,
15644
+ map: this.map,
15645
+ },
15646
+ });
15647
+ });
15642
15648
  });
15643
15649
  });
15644
- });
15650
+ }
15651
+ else {
15652
+ it.record.on('click', (event) => {
15653
+ this.zone.run(() => {
15654
+ this.onOverlayClick.emit({
15655
+ itemId: it.id,
15656
+ originalEvent: {
15657
+ originalEvent: event,
15658
+ overlay: it.record,
15659
+ map: this.map,
15660
+ },
15661
+ });
15662
+ });
15663
+ });
15664
+ }
15645
15665
  it.record.addTo(this.map);
15646
15666
  this.overlays.set(it.id, it.record);
15647
15667
  });