@smartbit4all/ng-client 4.2.36 → 4.2.37
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.
- package/esm2022/lib/smart-map/abstract-map.mjs +1 -1
- package/esm2022/lib/smart-map/impl/google-map.mjs +4 -1
- package/esm2022/lib/smart-map/impl/leaflet-map.mjs +43 -7
- package/esm2022/lib/smart-map/smart-map.component.mjs +11 -7
- package/fesm2022/smartbit4all-ng-client.mjs +54 -11
- package/fesm2022/smartbit4all-ng-client.mjs.map +1 -1
- package/lib/smart-map/abstract-map.d.ts +1 -0
- package/lib/smart-map/impl/google-map.d.ts +1 -0
- package/lib/smart-map/impl/leaflet-map.d.ts +2 -0
- package/lib/smart-map/smart-map.component.d.ts +3 -0
- package/package.json +1 -1
- package/smartbit4all-ng-client-4.2.37.tgz +0 -0
- package/smartbit4all-ng-client-4.2.36.tgz +0 -0
|
@@ -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  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"]}
|
|
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  abstract toBase64(): Promise<string>;\r\n}\r\n"]}
|
|
@@ -189,6 +189,9 @@ export class GoogleMap extends AbstractMap {
|
|
|
189
189
|
getMap() {
|
|
190
190
|
return this.map;
|
|
191
191
|
}
|
|
192
|
+
toBase64() {
|
|
193
|
+
throw new Error('Method not implemented.');
|
|
194
|
+
}
|
|
192
195
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: GoogleMap, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
193
196
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: GoogleMap, selector: "google-map", inputs: { style: "style", styleClass: "styleClass" }, outputs: { onOverlayDblClick: "onOverlayDblClick", onOverlayDragStart: "onOverlayDragStart", onOverlayDrag: "onOverlayDrag", onOverlayDragEnd: "onOverlayDragEnd", onMapReady: "onMapReady" }, host: { classAttribute: "p-element" }, usesInheritance: true, ngImport: i0, template: ` <div [ngStyle]="style" [class]="styleClass"></div>`, isInline: true, dependencies: [{ kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
194
197
|
}
|
|
@@ -218,4 +221,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
218
221
|
}], onMapReady: [{
|
|
219
222
|
type: Output
|
|
220
223
|
}] } });
|
|
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"]}
|
|
224
|
+
//# 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  override toBase64(): Promise<string> {\r\n    throw new Error('Method not implemented.');\r\n  }\r\n}\r\n"]}
|
|
@@ -48,7 +48,7 @@ export class LeafletMap extends AbstractMap {
|
|
|
48
48
|
}
|
|
49
49
|
initialize() {
|
|
50
50
|
const options = this.createLeafletMapOptions();
|
|
51
|
-
this.map = L.map('leaflet').setView(options.centre, options.zoom);
|
|
51
|
+
this.map = L.map('leaflet', { preferCanvas: true }).setView(options.centre, options.zoom);
|
|
52
52
|
L.tileLayer('https://tile.openstreetmap.org/{z}/{x}/{y}.png', {
|
|
53
53
|
maxZoom: 19,
|
|
54
54
|
attribution: '© <a href="http://www.openstreetmap.org/copyright">OpenStreetMap</a>',
|
|
@@ -182,11 +182,7 @@ export class LeafletMap extends AbstractMap {
|
|
|
182
182
|
});
|
|
183
183
|
let group = markerGroups.get(it.record.getLatLng().lat.toFixed(6) + ',' + it.record.getLatLng().lng.toFixed(6));
|
|
184
184
|
if (group && group.length > 1) {
|
|
185
|
-
const icon =
|
|
186
|
-
className: 'custom-cluster-icon',
|
|
187
|
-
html: `<div class="marker-count">${group.length}</div>`,
|
|
188
|
-
iconSize: [30, 30],
|
|
189
|
-
});
|
|
185
|
+
const icon = this.createNumberedIcon(group.length);
|
|
190
186
|
const clusterMarker = L.marker(group[0].originalLatLng, { icon }).addTo(this.map);
|
|
191
187
|
it.record.on('mouseover', (_event) => {
|
|
192
188
|
toAdd.forEach((item, index) => {
|
|
@@ -305,6 +301,46 @@ export class LeafletMap extends AbstractMap {
|
|
|
305
301
|
});
|
|
306
302
|
return { a: southwest, b: northeast };
|
|
307
303
|
}
|
|
304
|
+
toBase64() {
|
|
305
|
+
return new Promise((resolve, reject) => {
|
|
306
|
+
leafletImage(this.map, (err, canvas) => {
|
|
307
|
+
if (err) {
|
|
308
|
+
console.error('Leaflet image capture error', err);
|
|
309
|
+
reject(err);
|
|
310
|
+
}
|
|
311
|
+
resolve(canvas.toDataURL('image/png'));
|
|
312
|
+
});
|
|
313
|
+
});
|
|
314
|
+
}
|
|
315
|
+
createNumberedIcon(number) {
|
|
316
|
+
const size = 35;
|
|
317
|
+
const scaleFactor = 15;
|
|
318
|
+
const scaledSize = size * scaleFactor;
|
|
319
|
+
const canvas = document.createElement('canvas');
|
|
320
|
+
canvas.width = scaledSize;
|
|
321
|
+
canvas.height = scaledSize;
|
|
322
|
+
canvas.style.width = canvas.style.height = '35px';
|
|
323
|
+
const ctx = canvas.getContext('2d');
|
|
324
|
+
ctx.scale(scaleFactor, scaleFactor);
|
|
325
|
+
ctx.beginPath();
|
|
326
|
+
ctx.arc(size / 2, size / 2, size / 2 - 2, 0, 2 * Math.PI, false);
|
|
327
|
+
ctx.fillStyle = '#0078d4';
|
|
328
|
+
ctx.fill();
|
|
329
|
+
ctx.lineWidth = 2;
|
|
330
|
+
ctx.strokeStyle = '#ffffff';
|
|
331
|
+
ctx.stroke();
|
|
332
|
+
ctx.fillStyle = '#ffffff';
|
|
333
|
+
ctx.font = 'bold 16px sans-serif';
|
|
334
|
+
ctx.textAlign = 'center';
|
|
335
|
+
ctx.textBaseline = 'middle';
|
|
336
|
+
ctx.fillText(number.toString(), size / 2, size / 2);
|
|
337
|
+
return L.icon({
|
|
338
|
+
iconUrl: canvas.toDataURL(),
|
|
339
|
+
iconSize: [size, size],
|
|
340
|
+
iconAnchor: [size / 2, size / 2],
|
|
341
|
+
popupAnchor: [0, -size / 2],
|
|
342
|
+
});
|
|
343
|
+
}
|
|
308
344
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: LeafletMap, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
309
345
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: LeafletMap, selector: "leaflet-map", usesInheritance: true, ngImport: i0, template: ` <div id="leaflet"></div>`, isInline: true, styles: ["#leaflet{height:720px}::ng-deep .marker-count{background-color:#0078d4;color:#fff;font-weight:700;border-radius:50%;width:30px;height:30px;line-height:30px;text-align:center;border:2px solid white;box-shadow:0 0 4px #0006}::ng-deep .custom-cluster-icon{pointer-events:auto!important}\n"] }); }
|
|
310
346
|
}
|
|
@@ -312,4 +348,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
312
348
|
type: Component,
|
|
313
349
|
args: [{ selector: 'leaflet-map', template: ` <div id="leaflet"></div>`, styles: ["#leaflet{height:720px}::ng-deep .marker-count{background-color:#0078d4;color:#fff;font-weight:700;border-radius:50%;width:30px;height:30px;line-height:30px;text-align:center;border:2px solid white;box-shadow:0 0 4px #0006}::ng-deep .custom-cluster-icon{pointer-events:auto!important}\n"] }]
|
|
314
350
|
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i0.NgZone }] });
|
|
315
|
-
//# 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      let marker = L.marker(L.latLng(item.position!.latitude, item.position!.longitude), {\r\n        draggable: config.draggable,\r\n      }).bindTooltip(item.label, {\r\n        permanent: false,\r\n        direction: 'auto',\r\n      });\r\n      marker.originalLatLng = L.latLng(item.position!.latitude, item.position!.longitude); //\r\n      return marker;\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     ::ng-deep .marker-count {\r\n          background-color: #0078d4;\r\n          color: white;\r\n          font-weight: bold;\r\n          border-radius: 50%;\r\n          width: 30px;\r\n          height: 30px;\r\n          line-height: 30px;\r\n          text-align: center;\r\n          border: 2px solid white;\r\n          box-shadow: 0 0 4px rgba(0,0,0,0.4);\r\n    }\r\n     ::ng-deep .custom-cluster-icon {\r\n          pointer-events: auto !important;\r\n    }`,\r\n})\r\nexport class LeafletMap extends AbstractMap implements AfterViewChecked {\r\n  originalLatLng: any;\r\n  offsetDistance = 0.00004;\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    const markerGroups: Map<string, any[]> = new Map();\r\n\r\n    toAdd.forEach((item) => {\r\n      if (item.record instanceof L.Marker) {\r\n        const key =\r\n          item.record.getLatLng().lat.toFixed(6) + ',' + item.record.getLatLng().lng.toFixed(6);\r\n        if (!markerGroups.get(key)) {\r\n          markerGroups.set(key, []);\r\n        }\r\n        markerGroups.get(key)!.push(item.record);\r\n      }\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, index) => {\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        let group = markerGroups.get(\r\n          it.record.getLatLng().lat.toFixed(6) + ',' + it.record.getLatLng().lng.toFixed(6)\r\n        );\r\n        if (group && group.length > 1) {\r\n          const icon = L.divIcon({\r\n            className: 'custom-cluster-icon',\r\n            html: `<div class=\"marker-count\">${group.length}</div>`,\r\n            iconSize: [30, 30],\r\n          });\r\n          const clusterMarker = L.marker(group[0].originalLatLng, { icon }).addTo(this.map);\r\n          it.record.on('mouseover', (_event: any) => {\r\n            toAdd.forEach((item, index) => {\r\n              if (\r\n                item.record instanceof L.Marker &&\r\n                item.record.originalLatLng.lat == it.record.originalLatLng.lat &&\r\n                item.record.originalLatLng.lng == it.record.originalLatLng.lng\r\n              ) {\r\n                it.record.setZIndexOffset(1000);\r\n                const angle = ((360 / toAdd.length) * index * Math.PI) / 180;\r\n                const newLat =\r\n                  item.record.originalLatLng.lat + this.offsetDistance * Math.cos(angle);\r\n                const newLng =\r\n                  item.record.originalLatLng.lng + this.offsetDistance * Math.sin(angle);\r\n                item.record.setLatLng([newLat, newLng]);\r\n              }\r\n            });\r\n            if (this.map.hasLayer(clusterMarker)) {\r\n              this.map.removeLayer(clusterMarker);\r\n            }\r\n          });\r\n          it.record.on('mouseout', (_event: any) => {\r\n            toAdd.forEach((item, _index) => {\r\n              if (item.record instanceof L.Marker) {\r\n                item.record.setLatLng(item.record.originalLatLng);\r\n                it.record.setZIndexOffset(0);\r\n              }\r\n            });\r\n            if (!this.map.hasLayer(clusterMarker)) {\r\n              clusterMarker.addTo(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] : it.route ? it.route.points : []))\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"]}
|
|
351
|
+
//# 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\ndeclare const leafletImage: 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      let marker = L.marker(L.latLng(item.position!.latitude, item.position!.longitude), {\r\n        draggable: config.draggable,\r\n      }).bindTooltip(item.label, {\r\n        permanent: false,\r\n        direction: 'auto',\r\n      });\r\n      marker.originalLatLng = L.latLng(item.position!.latitude, item.position!.longitude); //\r\n      return marker;\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     ::ng-deep .marker-count {\r\n          background-color: #0078d4;\r\n          color: white;\r\n          font-weight: bold;\r\n          border-radius: 50%;\r\n          width: 30px;\r\n          height: 30px;\r\n          line-height: 30px;\r\n          text-align: center;\r\n          border: 2px solid white;\r\n          box-shadow: 0 0 4px rgba(0,0,0,0.4);\r\n    }\r\n     ::ng-deep .custom-cluster-icon {\r\n          pointer-events: auto !important;\r\n    }`,\r\n})\r\nexport class LeafletMap extends AbstractMap implements AfterViewChecked {\r\n  originalLatLng: any;\r\n  offsetDistance = 0.00004;\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', { preferCanvas: true }).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    const markerGroups: Map<string, any[]> = new Map();\r\n\r\n    toAdd.forEach((item) => {\r\n      if (item.record instanceof L.Marker) {\r\n        const key =\r\n          item.record.getLatLng().lat.toFixed(6) + ',' + item.record.getLatLng().lng.toFixed(6);\r\n        if (!markerGroups.get(key)) {\r\n          markerGroups.set(key, []);\r\n        }\r\n        markerGroups.get(key)!.push(item.record);\r\n      }\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, index) => {\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        let group = markerGroups.get(\r\n          it.record.getLatLng().lat.toFixed(6) + ',' + it.record.getLatLng().lng.toFixed(6)\r\n        );\r\n        if (group && group.length > 1) {\r\n          const icon = this.createNumberedIcon(group.length);\r\n          const clusterMarker = L.marker(group[0].originalLatLng, { icon }).addTo(this.map);\r\n          it.record.on('mouseover', (_event: any) => {\r\n            toAdd.forEach((item, index) => {\r\n              if (\r\n                item.record instanceof L.Marker &&\r\n                item.record.originalLatLng.lat == it.record.originalLatLng.lat &&\r\n                item.record.originalLatLng.lng == it.record.originalLatLng.lng\r\n              ) {\r\n                it.record.setZIndexOffset(1000);\r\n                const angle = ((360 / toAdd.length) * index * Math.PI) / 180;\r\n                const newLat =\r\n                  item.record.originalLatLng.lat + this.offsetDistance * Math.cos(angle);\r\n                const newLng =\r\n                  item.record.originalLatLng.lng + this.offsetDistance * Math.sin(angle);\r\n                item.record.setLatLng([newLat, newLng]);\r\n              }\r\n            });\r\n            if (this.map.hasLayer(clusterMarker)) {\r\n              this.map.removeLayer(clusterMarker);\r\n            }\r\n          });\r\n          it.record.on('mouseout', (_event: any) => {\r\n            toAdd.forEach((item, _index) => {\r\n              if (item.record instanceof L.Marker) {\r\n                item.record.setLatLng(item.record.originalLatLng);\r\n                it.record.setZIndexOffset(0);\r\n              }\r\n            });\r\n            if (!this.map.hasLayer(clusterMarker)) {\r\n              clusterMarker.addTo(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] : it.route ? it.route.points : []))\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  override toBase64(): Promise<string> {\r\n    return new Promise((resolve, reject) => {\r\n      leafletImage(this.map, (err: any, canvas: HTMLCanvasElement) => {\r\n        if (err) {\r\n          console.error('Leaflet image capture error', err);\r\n          reject(err);\r\n        }\r\n        resolve(canvas.toDataURL('image/png'));\r\n      });\r\n    });\r\n  }\r\n\r\n  createNumberedIcon(number: number) {\r\n    const size = 35;\r\n    const scaleFactor = 15;\r\n    const scaledSize = size * scaleFactor;\r\n\r\n    const canvas = document.createElement('canvas');\r\n    canvas.width = scaledSize;\r\n    canvas.height = scaledSize;\r\n    canvas.style.width = canvas.style.height = '35px';\r\n    const ctx = canvas.getContext('2d')!;\r\n    ctx.scale(scaleFactor, scaleFactor);\r\n\r\n    ctx.beginPath();\r\n    ctx.arc(size / 2, size / 2, size / 2 - 2, 0, 2 * Math.PI, false);\r\n    ctx.fillStyle = '#0078d4';\r\n    ctx.fill();\r\n    ctx.lineWidth = 2;\r\n    ctx.strokeStyle = '#ffffff';\r\n    ctx.stroke();\r\n\r\n    ctx.fillStyle = '#ffffff';\r\n    ctx.font = 'bold 16px sans-serif';\r\n    ctx.textAlign = 'center';\r\n    ctx.textBaseline = 'middle';\r\n    ctx.fillText(number.toString(), size / 2, size / 2);\r\n\r\n    return L.icon({\r\n      iconUrl: canvas.toDataURL(),\r\n      iconSize: [size, size],\r\n      iconAnchor: [size / 2, size / 2],\r\n      popupAnchor: [0, -size / 2],\r\n    });\r\n  }\r\n}\r\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, computed, Inject, InjectionToken, Input, signal, } from '@angular/core';
|
|
1
|
+
import { Component, computed, Inject, InjectionToken, Input, signal, ViewChild, } from '@angular/core';
|
|
2
2
|
import { lastValueFrom } from 'rxjs';
|
|
3
3
|
import { GeoMapItemKind, GeoMapOperationMode, } from './api';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
@@ -32,9 +32,7 @@ export class SmartMapComponent {
|
|
|
32
32
|
.map((it) => it.id)
|
|
33
33
|
.values()));
|
|
34
34
|
}
|
|
35
|
-
ngOnInit() {
|
|
36
|
-
// this.load();
|
|
37
|
-
}
|
|
35
|
+
ngOnInit() { }
|
|
38
36
|
ngAfterViewInit() {
|
|
39
37
|
this.load();
|
|
40
38
|
}
|
|
@@ -199,12 +197,15 @@ export class SmartMapComponent {
|
|
|
199
197
|
}
|
|
200
198
|
this.update(viewState);
|
|
201
199
|
}
|
|
200
|
+
toBase64() {
|
|
201
|
+
return this.mapComponent.toBase64();
|
|
202
|
+
}
|
|
202
203
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartMapComponent, deps: [{ token: MAP_ENGINE }, { token: i1.GeoMapService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
203
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.11", type: SmartMapComponent, selector: "smart-map", inputs: { uuid: "uuid", identifier: "identifier", parent: "parent" }, ngImport: i0, template: "@if (model()) { @if (mapEngine === MapEngine.GOOGLE) {\r\n<google-map\r\n [model]=\"model()!\"\r\n [items]=\"items()\"\r\n [style]=\"{ width: '100%', height: '320px' }\"\r\n (onMapDragEnd)=\"move($event.viewport)\"\r\n (onZoomChanged)=\"move($event.viewport)\"\r\n (onMapClick)=\"handleMapClick($event.coordinates)\"\r\n (onOverlayClick)=\"handleItemClick($event.itemId)\"\r\n (onEditingOverlayClick)=\"handleEditingItemClick($event.itemId, $event)\"\r\n>\r\n</google-map>\r\n} @else if (mapEngine === MapEngine.LEAFLET) {\r\n<leaflet-map\r\n [model]=\"model()!\"\r\n [items]=\"items()\"\r\n [editingSession]=\"editingSession()\"\r\n (onMapDragEnd)=\"move($event.viewport)\"\r\n (onZoomChanged)=\"move($event.viewport)\"\r\n (onMapClick)=\"handleMapClick($event.coordinates)\"\r\n (onOverlayClick)=\"handleItemClick($event.itemId)\"\r\n (onEditingOverlayClick)=\"handleEditingItemClick($event.itemId, $event)\"\r\n (onEditingOverlayDrag)=\"handleEditingItemDrag($event.itemId, $event)\"\r\n>\r\n</leaflet-map>\r\n} @else {\r\n<p>\r\n <strong>Not recognised map engine: [ {{ mapEngine }} ]</strong>\r\n</p>\r\n<p>Please provide a valid choice of map engine!</p>\r\n} }\r\n", styles: [""], dependencies: [{ kind: "component", type: i2.GoogleMap, selector: "google-map", inputs: ["style", "styleClass"], outputs: ["onOverlayDblClick", "onOverlayDragStart", "onOverlayDrag", "onOverlayDragEnd", "onMapReady"] }, { kind: "component", type: i3.LeafletMap, selector: "leaflet-map" }] }); }
|
|
204
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.11", type: SmartMapComponent, selector: "smart-map", inputs: { uuid: "uuid", identifier: "identifier", parent: "parent" }, viewQueries: [{ propertyName: "mapComponent", first: true, predicate: ["mapComponent"], descendants: true }], ngImport: i0, template: "@if (model()) { @if (mapEngine === MapEngine.GOOGLE) {\r\n<google-map\r\n #mapComponent\r\n [model]=\"model()!\"\r\n [items]=\"items()\"\r\n [style]=\"{ width: '100%', height: '320px' }\"\r\n (onMapDragEnd)=\"move($event.viewport)\"\r\n (onZoomChanged)=\"move($event.viewport)\"\r\n (onMapClick)=\"handleMapClick($event.coordinates)\"\r\n (onOverlayClick)=\"handleItemClick($event.itemId)\"\r\n (onEditingOverlayClick)=\"handleEditingItemClick($event.itemId, $event)\"\r\n>\r\n</google-map>\r\n} @else if (mapEngine === MapEngine.LEAFLET) {\r\n<leaflet-map\r\n #mapComponent\r\n [model]=\"model()!\"\r\n [items]=\"items()\"\r\n [editingSession]=\"editingSession()\"\r\n (onMapDragEnd)=\"move($event.viewport)\"\r\n (onZoomChanged)=\"move($event.viewport)\"\r\n (onMapClick)=\"handleMapClick($event.coordinates)\"\r\n (onOverlayClick)=\"handleItemClick($event.itemId)\"\r\n (onEditingOverlayClick)=\"handleEditingItemClick($event.itemId, $event)\"\r\n (onEditingOverlayDrag)=\"handleEditingItemDrag($event.itemId, $event)\"\r\n>\r\n</leaflet-map>\r\n} @else {\r\n<p>\r\n <strong>Not recognised map engine: [ {{ mapEngine }} ]</strong>\r\n</p>\r\n<p>Please provide a valid choice of map engine!</p>\r\n} }\r\n", styles: [""], dependencies: [{ kind: "component", type: i2.GoogleMap, selector: "google-map", inputs: ["style", "styleClass"], outputs: ["onOverlayDblClick", "onOverlayDragStart", "onOverlayDrag", "onOverlayDragEnd", "onMapReady"] }, { kind: "component", type: i3.LeafletMap, selector: "leaflet-map" }] }); }
|
|
204
205
|
}
|
|
205
206
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartMapComponent, decorators: [{
|
|
206
207
|
type: Component,
|
|
207
|
-
args: [{ selector: 'smart-map', template: "@if (model()) { @if (mapEngine === MapEngine.GOOGLE) {\r\n<google-map\r\n [model]=\"model()!\"\r\n [items]=\"items()\"\r\n [style]=\"{ width: '100%', height: '320px' }\"\r\n (onMapDragEnd)=\"move($event.viewport)\"\r\n (onZoomChanged)=\"move($event.viewport)\"\r\n (onMapClick)=\"handleMapClick($event.coordinates)\"\r\n (onOverlayClick)=\"handleItemClick($event.itemId)\"\r\n (onEditingOverlayClick)=\"handleEditingItemClick($event.itemId, $event)\"\r\n>\r\n</google-map>\r\n} @else if (mapEngine === MapEngine.LEAFLET) {\r\n<leaflet-map\r\n [model]=\"model()!\"\r\n [items]=\"items()\"\r\n [editingSession]=\"editingSession()\"\r\n (onMapDragEnd)=\"move($event.viewport)\"\r\n (onZoomChanged)=\"move($event.viewport)\"\r\n (onMapClick)=\"handleMapClick($event.coordinates)\"\r\n (onOverlayClick)=\"handleItemClick($event.itemId)\"\r\n (onEditingOverlayClick)=\"handleEditingItemClick($event.itemId, $event)\"\r\n (onEditingOverlayDrag)=\"handleEditingItemDrag($event.itemId, $event)\"\r\n>\r\n</leaflet-map>\r\n} @else {\r\n<p>\r\n <strong>Not recognised map engine: [ {{ mapEngine }} ]</strong>\r\n</p>\r\n<p>Please provide a valid choice of map engine!</p>\r\n} }\r\n" }]
|
|
208
|
+
args: [{ selector: 'smart-map', template: "@if (model()) { @if (mapEngine === MapEngine.GOOGLE) {\r\n<google-map\r\n #mapComponent\r\n [model]=\"model()!\"\r\n [items]=\"items()\"\r\n [style]=\"{ width: '100%', height: '320px' }\"\r\n (onMapDragEnd)=\"move($event.viewport)\"\r\n (onZoomChanged)=\"move($event.viewport)\"\r\n (onMapClick)=\"handleMapClick($event.coordinates)\"\r\n (onOverlayClick)=\"handleItemClick($event.itemId)\"\r\n (onEditingOverlayClick)=\"handleEditingItemClick($event.itemId, $event)\"\r\n>\r\n</google-map>\r\n} @else if (mapEngine === MapEngine.LEAFLET) {\r\n<leaflet-map\r\n #mapComponent\r\n [model]=\"model()!\"\r\n [items]=\"items()\"\r\n [editingSession]=\"editingSession()\"\r\n (onMapDragEnd)=\"move($event.viewport)\"\r\n (onZoomChanged)=\"move($event.viewport)\"\r\n (onMapClick)=\"handleMapClick($event.coordinates)\"\r\n (onOverlayClick)=\"handleItemClick($event.itemId)\"\r\n (onEditingOverlayClick)=\"handleEditingItemClick($event.itemId, $event)\"\r\n (onEditingOverlayDrag)=\"handleEditingItemDrag($event.itemId, $event)\"\r\n>\r\n</leaflet-map>\r\n} @else {\r\n<p>\r\n <strong>Not recognised map engine: [ {{ mapEngine }} ]</strong>\r\n</p>\r\n<p>Please provide a valid choice of map engine!</p>\r\n} }\r\n" }]
|
|
208
209
|
}], ctorParameters: () => [{ type: MapEngine, decorators: [{
|
|
209
210
|
type: Inject,
|
|
210
211
|
args: [MAP_ENGINE]
|
|
@@ -214,5 +215,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
214
215
|
type: Input
|
|
215
216
|
}], parent: [{
|
|
216
217
|
type: Input
|
|
218
|
+
}], mapComponent: [{
|
|
219
|
+
type: ViewChild,
|
|
220
|
+
args: ['mapComponent']
|
|
217
221
|
}] } });
|
|
218
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart-map.component.js","sourceRoot":"","sources":["../../../../../projects/smart-ng-client/src/lib/smart-map/smart-map.component.ts","../../../../../projects/smart-ng-client/src/lib/smart-map/smart-map.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EACT,QAAQ,EACR,MAAM,EACN,cAAc,EACd,KAAK,EAGL,MAAM,GAGP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,aAAa,EAAE,MAAM,MAAM,CAAC;AACrC,OAAO,EAIL,cAAc,EAGd,mBAAmB,GAKpB,MAAM,OAAO,CAAC;;;;;AAKf,MAAM,CAAN,IAAY,SAGX;AAHD,WAAY,SAAS;IACnB,8BAAiB,CAAA;IACjB,gCAAmB,CAAA;AACrB,CAAC,EAHW,SAAS,KAAT,SAAS,QAGpB;AAED,MAAM,CAAC,MAAM,UAAU,GAAG,IAAI,cAAc,CAAY,YAAY,CAAC,CAAC;AAEtE,MAAM,MAAM,GAAuC,CAAC,CAAoB,EAAE,CAAoB,EAAE,EAAE;IAChG,MAAM,SAAS,GAAG,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAc,EAAE,EAAE,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC;IAClE,CAAC,CAAC,OAAO,CAAC,CAAC,EAAc,EAAE,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC;IAC7D,OAAO,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,MAAM,IAAI,SAAS,CAAC,IAAI,KAAK,CAAC,CAAC;AACvD,CAAC,CAAC;AAOF,MAAM,OAAO,iBAAiB;IA4B5B,YAES,SAAoB,EACnB,GAAkB;QADnB,cAAS,GAAT,SAAS,CAAW;QACnB,QAAG,GAAH,GAAG,CAAe;QA9B5B,cAAS,GAAG,SAAS,CAAC;QAMb,UAAK,GAA4C,MAAM,CAAC,SAAS,CAAC,CAAC;QACnE,UAAK,GAA8B,QAAQ,CAAC,GAAG,EAAE;YACxD,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;YAC3B,OAAO,KAAK,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC;QAC3D,CAAC,CAAC,CAAC;QACM,mBAAc,GAA6C,QAAQ,CAC1E,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,EAAE,SAAS,EAAE,cAAc,CAC9C,CAAC;QAEO,cAAS,GAAwB,QAAQ,CAChD,GAAG,EAAE,CACH,IAAI,GAAG,CACL,IAAI,CAAC,KAAK,EAAE;aACT,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,QAAQ,CAAC;aAC7B,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAG,CAAC;aACnB,MAAM,EAAE,CACZ,CACJ,CAAC;IAQC,CAAC;IAEJ,QAAQ;QACN,eAAe;IACjB,CAAC;IAED,eAAe;QACb,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,KAAK,CAAC,IAAI;QACR,MAAM,KAAK,GAAgB,MAAM,aAAa,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;QAC1F,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;YACpB,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAC;QACvD,CAAC;QACD,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,QAAwB;QACjC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE;YACvB,OAAO,CAAC,GAAG,CAAC,0BAA0B,CAAC,CAAC;YACxC,IAAI,EAAE,EAAE,CAAC;gBACP,EAAE,CAAC,QAAQ,GAAG,QAAQ,CAAC;YACzB,CAAC;YACD,OAAO,EAAE,CAAC;QACZ,CAAC,CAAC,CAAC;QACH,MAAM,MAAM,GAAiB,MAAM,aAAa,CAC9C,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,UAAU,EAAE,QAAQ,CAAC,CACpD,CAAC;QACF,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;IAC5B,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,QAAyB;QACpC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE;YACvB,IAAI,EAAE,EAAE,CAAC;gBACP,EAAE,CAAC,SAAS,GAAG,QAAQ,CAAC;YAC1B,CAAC;YACD,OAAO,EAAE,CAAC;QACZ,CAAC,CAAC,CAAC;QACH,MAAM,MAAM,GAAiB,MAAM,aAAa,CAC9C,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,UAAU,EAAE,QAAQ,CAAC,CACtD,CAAC;QACF,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;IAC5B,CAAC;IAEO,YAAY,CAAC,MAAoB;QACvC,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;YAClB,OAAO;QACT,CAAC;QAED,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE;YACvB,MAAM,UAAU,GAA6B,IAAI,GAAG,EAAE,CAAC;YACvD,IAAI,CAAC,EAAE,EAAE,CAAC;gBACR,OAAO,EAAE,CAAC;YACZ,CAAC;YACD,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC,IAAK,EAAE,KAAK,CAAC,CAAC,CAAC;YACjE,KAAK,MAAM,WAAW,IAAI,MAAM,CAAC,KAAK,EAAE,CAAC;gBACvC,MAAM,OAAO,GAAG,WAAW,CAAC,IAAK,CAAC;gBAClC,MAAM,KAAK,GAAG,WAAW,CAAC,KAAK,CAAC;gBAChC,UAAU,CAAC,GAAG,CAAC,OAAO,EAAE;oBACtB,IAAI,EAAE,OAAO;oBACb,KAAK,EAAE,KAAK;iBACb,CAAC,CAAC;YACL,CAAC;YACD,EAAE,CAAC,SAAU,CAAC,cAAc,GAAG,MAAM,CAAC,cAAc,CAAC;YACrD,OAAO;gBACL,GAAG,EAAE;gBACL,MAAM,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC;gBAChC,SAAS,EAAE,EAAE,CAAC,SAAS;aACxB,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAED,cAAc,CAAC,QAAqB;QAClC,IAAI,SAAS,GAAG,IAAI,CAAC,KAAK,EAAE,EAAE,SAAU,CAAC;QACzC,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,EAAE,EAAE,SAAS,EAAE,aAAa,IAAI,mBAAmB,CAAC,MAAM,CAAC;QAE3F,QAAQ,aAAa,EAAE,CAAC;YACtB,KAAK,mBAAmB,CAAC,MAAM;gBAC7B,2EAA2E;gBAC3E,MAAM;YACR,KAAK,mBAAmB,CAAC,SAAS;gBAChC,mCAAmC;gBACnC,MAAM;QACV,CAAC;QACD,IACE,SAAS,CAAC,cAAc;YACxB,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,cAAc,EAAE,YAAa,CAAC,CAAC,MAAM,GAAG,CAAC,EAC/D,CAAC;YACD,MAAM,YAAY,GAAG,SAAS,CAAC,cAAc,CAAC,YAAa,CAAC;YAC5D,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;YAC9C,MAAM,WAAW,GAAG,YAAY,CAAC,QAAQ,CAAC,CAAC;YAC3C,IAAI,WAAW,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC1C,MAAM,WAAW,GAAe,WAAW,CAAC,CAAC,CAAC,CAAC;gBAE/C,IAAI,WAAW,CAAC,IAAI,KAAK,cAAc,CAAC,MAAM,EAAE,CAAC;oBAC/C,WAAW,CAAC,QAAQ,GAAG,QAAQ,CAAC;gBAClC,CAAC;qBAAM,CAAC;oBACN,WAAW,CAAC,KAAM,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBAC3C,CAAC;YACH,CAAC;YACD,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QACzB,CAAC;IACH,CAAC;IAED,eAAe,CAAC,EAAU;QACxB,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,EAAE,EAAE,SAAS,EAAE,aAAa,IAAI,mBAAmB,CAAC,MAAM,CAAC;QAC3F,IAAI,UAAU,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;QAEzD,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,OAAO,CAAC,IAAI,CAAC,wDAAwD,EAAE,EAAE,CAAC,CAAC;YAC3E,OAAO;QACT,CAAC;QAED,QAAQ,aAAa,EAAE,CAAC;YACtB,KAAK,mBAAmB,CAAC,MAAM;gBAC7B,qBAAqB;gBACrB,MAAM;YACR,KAAK,mBAAmB,CAAC,SAAS;gBAChC,aAAa,CACX,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,UAAU,EAAE;oBAC5C,aAAa;oBACb,UAAU;oBACV,WAAW,EAAE,EAAE;oBACf,OAAO,EAAE,IAAI,CAAC,SAAS,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC;iBAClC,CAAC,CACH,CAAC,IAAI,CACJ,CAAC,MAAyB,EAAE,EAAE;oBAC5B,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC;wBAC7B,OAAO,CAAC,IAAI,CAAC,8CAA8C,CAAC,CAAC;wBAC7D,OAAO,IAAI,CAAC;oBACd,CAAC;yBAAM,CAAC;wBACN,OAAO,IAAI,CAAC,kBAAkB,CAAC,2BAA2B,CAAC,MAAM,CAAC,CAAC;oBACrE,CAAC;gBACH,CAAC,EACD,CAAC,GAAQ,EAAE,EAAE;oBACX,OAAO,CAAC,IAAI,CAAC,qCAAqC,EAAE,GAAG,CAAC,CAAC;gBAC3D,CAAC,CACF,CAAC;gBACF,MAAM;QACV,CAAC;IACH,CAAC;IAED,sBAAsB,CAAC,EAAU,EAAE,KAAiC;QAClE,IAAI,SAAS,GAAoB,IAAI,CAAC,KAAK,EAAE,EAAE,SAAU,CAAC;QAC1D,MAAM,aAAa,GAAG,SAAS,EAAE,cAAc,EAAE,YAAa,CAAC;QAC/D,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;QAC/C,MAAM,YAAY,GAAG,aAAa,CAAC,QAAQ,CAAC,CAAC;QAC7C,IAAI,UAAU,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;QACjC,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,OAAO,CAAC,IAAI,CAAC,wDAAwD,EAAE,EAAE,CAAC,CAAC;YAC3E,OAAO;QACT,CAAC;QACD,IAAI,UAAU,CAAC,IAAI,KAAK,cAAc,CAAC,MAAM,EAAE,CAAC;YAC9C,UAAU,CAAC,QAAQ,GAAG,SAAS,CAAC;YAChC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QACzB,CAAC;aAAM,CAAC;YACN,MAAM,MAAM,GAAG,UAAU,CAAC,KAAM,CAAC,MAAM,CAAC;YACxC,MAAM,KAAK,GAAG,MAAM,CAAC,SAAS,CAC5B,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,QAAQ,KAAK,KAAK,CAAC,KAAK,CAAC,CAAC,IAAI,KAAK,CAAC,SAAS,KAAK,KAAK,CAAC,KAAK,CAAC,CAAC,CACjF,CAAC;YAEF,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE,CAAC;gBACjB,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;YAC1B,CAAC;QACH,CAAC;QAED,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;IACzB,CAAC;IACD,qBAAqB,CAAC,EAAU,EAAE,KAAiC;QACjE,IAAI,SAAS,GAAoB,IAAI,CAAC,KAAK,EAAE,EAAE,SAAU,CAAC;QAC1D,MAAM,aAAa,GAAG,SAAS,EAAE,cAAc,EAAE,YAAa,CAAC;QAC/D,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;QAC/C,MAAM,YAAY,GAAG,aAAa,CAAC,QAAQ,CAAC,CAAC;QAC7C,IAAI,UAAU,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;QACjC,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,OAAO,CAAC,IAAI,CAAC,wDAAwD,EAAE,EAAE,CAAC,CAAC;YAC3E,OAAO;QACT,CAAC;QACD,IAAI,UAAU,CAAC,IAAI,KAAK,cAAc,CAAC,MAAM,EAAE,CAAC;YAC9C,UAAU,CAAC,QAAS,CAAC,QAAS,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;YAChD,UAAU,CAAC,QAAS,CAAC,SAAU,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;QACnD,CAAC;aAAM,CAAC;YACN,MAAM,MAAM,GAAG,UAAU,CAAC,KAAM,CAAC,MAAM,CAAC;YACxC,MAAM,KAAK,GAAG,MAAM,CAAC,SAAS,CAC5B,CAAC,KAAK,EAAE,EAAE,CACR,KAAK,CAAC,QAAQ,KAAK,KAAK,CAAC,aAAc,CAAC,CAAC,IAAI,KAAK,CAAC,SAAS,KAAK,KAAK,CAAC,aAAc,CAAC,CAAC,CAC1F,CAAC;YACF,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE,CAAC;gBACjB,MAAM,CAAC,KAAK,CAAC,CAAC,QAAQ,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;gBACxC,MAAM,CAAC,KAAK,CAAC,CAAC,SAAS,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;YAC3C,CAAC;YACD,UAAU,CAAC,KAAM,CAAC,MAAO,GAAG,MAAM,CAAC;QACrC,CAAC;QAED,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;IACzB,CAAC;+GApOU,iBAAiB,kBA6BlB,UAAU;mGA7BT,iBAAiB,uHCjD9B,uqCA+BA;;4FDkBa,iBAAiB;kBAL7B,SAAS;+BACE,WAAW;;0BAiClB,MAAM;2BAAC,UAAU;qEA1BX,IAAI;sBAAZ,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,MAAM;sBAAd,KAAK","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  computed,\r\n  Inject,\r\n  InjectionToken,\r\n  Input,\r\n  OnInit,\r\n  Signal,\r\n  signal,\r\n  ValueEqualityFn,\r\n  WritableSignal,\r\n} from '@angular/core';\r\nimport { lastValueFrom } from 'rxjs';\r\nimport {\r\n  GeoMapChange,\r\n  GeoMapEditingSession,\r\n  GeoMapItem,\r\n  GeoMapItemKind,\r\n  GeoMapLayer,\r\n  GeoMapModel,\r\n  GeoMapOperationMode,\r\n  GeoMapService,\r\n  GeoMapViewport,\r\n  GeoMapViewState,\r\n  GPSPosition,\r\n} from './api';\r\nimport { ViewContextChange } from '../view-context/api';\r\nimport { SmartViewContextService } from '../view-context/smart-view-context.service';\r\nimport { MapEditingItemClickedEvent, MapEditingItemDraggedEvent } from './smart-map.types';\r\n\r\nexport enum MapEngine {\r\n  GOOGLE = 'GOOGLE',\r\n  LEAFLET = 'LEAFLET',\r\n}\r\n\r\nexport const MAP_ENGINE = new InjectionToken<MapEngine>('MAP_ENGINE');\r\n\r\nconst itemEq: ValueEqualityFn<Array<GeoMapItem>> = (a: Array<GeoMapItem>, b: Array<GeoMapItem>) => {\r\n  const positions = new Set(a.map((it: GeoMapItem) => it.position));\r\n  b.forEach((it: GeoMapItem) => positions.delete(it.position));\r\n  return a.length === b.length && positions.size === 0;\r\n};\r\n\r\n@Component({\r\n  selector: 'smart-map',\r\n  templateUrl: './smart-map.component.html',\r\n  styleUrl: './smart-map.component.css',\r\n})\r\nexport class SmartMapComponent implements OnInit, AfterViewInit {\r\n  MapEngine = MapEngine;\r\n\r\n  @Input() uuid!: string;\r\n  @Input() identifier!: string;\r\n  @Input() parent?: any;\r\n\r\n  readonly model: WritableSignal<GeoMapModel | undefined> = signal(undefined);\r\n  readonly items: Signal<Array<GeoMapItem>> = computed(() => {\r\n    const model = this.model();\r\n    return model?.layers.flatMap((l) => l.items ?? []) ?? [];\r\n  });\r\n  readonly editingSession: Signal<GeoMapEditingSession | undefined> = computed(\r\n    () => this.model()?.viewState?.editingSession\r\n  );\r\n\r\n  readonly selection: Signal<Set<string>> = computed(\r\n    () =>\r\n      new Set(\r\n        this.items()\r\n          .filter((it) => !!it.selected)\r\n          .map((it) => it.id!)\r\n          .values()\r\n      )\r\n  );\r\n\r\n  viewContextService?: SmartViewContextService;\r\n\r\n  constructor(\r\n    @Inject(MAP_ENGINE)\r\n    public mapEngine: MapEngine,\r\n    private api: GeoMapService\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    // this.load();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.load();\r\n  }\r\n\r\n  async load(): Promise<void> {\r\n    const model: GeoMapModel = await lastValueFrom(this.api.load(this.uuid, this.identifier));\r\n    if (!model.viewport) {\r\n      throw new Error('GeoMapModel contains no viewport!');\r\n    }\r\n    this.model.update(() => model);\r\n  }\r\n\r\n  async move(viewport: GeoMapViewport): Promise<void> {\r\n    this.model.update((it) => {\r\n      console.log('model update is running!');\r\n      if (it) {\r\n        it.viewport = viewport;\r\n      }\r\n      return it;\r\n    });\r\n    const change: GeoMapChange = await lastValueFrom(\r\n      this.api.move(this.uuid, this.identifier, viewport)\r\n    );\r\n    this.handleChange(change);\r\n  }\r\n\r\n  async update(mapState: GeoMapViewState): Promise<void> {\r\n    this.model.update((it) => {\r\n      if (it) {\r\n        it.viewState = mapState;\r\n      }\r\n      return it;\r\n    });\r\n    const change: GeoMapChange = await lastValueFrom(\r\n      this.api.update(this.uuid, this.identifier, mapState)\r\n    );\r\n    this.handleChange(change);\r\n  }\r\n\r\n  private handleChange(change: GeoMapChange): void {\r\n    if (!change.items) {\r\n      return;\r\n    }\r\n\r\n    this.model.update((it) => {\r\n      const layersById: Map<string, GeoMapLayer> = new Map();\r\n      if (!it) {\r\n        return it;\r\n      }\r\n      it.layers.forEach((layer) => layersById.set(layer.code!, layer));\r\n      for (const layerChange of change.items) {\r\n        const layerId = layerChange.code!;\r\n        const toAdd = layerChange.toAdd;\r\n        layersById.set(layerId, {\r\n          code: layerId,\r\n          items: toAdd,\r\n        });\r\n      }\r\n      it.viewState!.editingSession = change.editingSession;\r\n      return {\r\n        ...it,\r\n        layers: [...layersById.values()],\r\n        viewState: it.viewState,\r\n      };\r\n    });\r\n  }\r\n\r\n  handleMapClick(position: GPSPosition): void {\r\n    let viewState = this.model()?.viewState!;\r\n    const operationMode = this.model()?.viewState?.operationMode ?? GeoMapOperationMode.ACTION;\r\n\r\n    switch (operationMode) {\r\n      case GeoMapOperationMode.ACTION:\r\n        // TODO: Fire action for layer, if applicable (maybe only on double click).\r\n        break;\r\n      case GeoMapOperationMode.SELECTION:\r\n        // no-op, can't select empty space.\r\n        break;\r\n    }\r\n    if (\r\n      viewState.editingSession &&\r\n      Object.keys(viewState.editingSession?.pendingItems!).length > 0\r\n    ) {\r\n      const pendingItems = viewState.editingSession.pendingItems!;\r\n      const firstKey = Object.keys(pendingItems)[0];\r\n      const pendingItem = pendingItems[firstKey];\r\n      if (pendingItem && pendingItem.length > 0) {\r\n        const editingItem: GeoMapItem = pendingItem[0];\r\n\r\n        if (editingItem.kind === GeoMapItemKind.MARKER) {\r\n          editingItem.position = position;\r\n        } else {\r\n          editingItem.route!.points.push(position);\r\n        }\r\n      }\r\n      this.update(viewState);\r\n    }\r\n  }\r\n\r\n  handleItemClick(id: string): void {\r\n    const operationMode = this.model()?.viewState?.operationMode ?? GeoMapOperationMode.ACTION;\r\n    let targetItem = this.items().find((it) => id === it.id);\r\n\r\n    if (!targetItem) {\r\n      console.warn('Selection item is seemingly missing from known items: ', id);\r\n      return;\r\n    }\r\n\r\n    switch (operationMode) {\r\n      case GeoMapOperationMode.ACTION:\r\n        // TODO: fire action!\r\n        break;\r\n      case GeoMapOperationMode.SELECTION:\r\n        lastValueFrom(\r\n          this.api.interact(this.uuid, this.identifier, {\r\n            operationMode,\r\n            targetItem,\r\n            targetLayer: '',\r\n            inverse: this.selection().has(id),\r\n          })\r\n        ).then(\r\n          (change: ViewContextChange) => {\r\n            if (!this.viewContextService) {\r\n              console.warn('Smart Map has no ViewContext Service set up!');\r\n              return null;\r\n            } else {\r\n              return this.viewContextService.handlePerformActionResponse(change);\r\n            }\r\n          },\r\n          (err: any) => {\r\n            console.warn('Could not submit selection change! ', err);\r\n          }\r\n        );\r\n        break;\r\n    }\r\n  }\r\n\r\n  handleEditingItemClick(id: string, event: MapEditingItemClickedEvent) {\r\n    let viewState: GeoMapViewState = this.model()?.viewState!;\r\n    const pendingValues = viewState?.editingSession?.pendingItems!;\r\n    const firstKey = Object.keys(pendingValues)[0];\r\n    const pendingItems = pendingValues[firstKey];\r\n    let targetItem = pendingItems[0];\r\n    if (!targetItem) {\r\n      console.warn('Selection item is seemingly missing from known items: ', id);\r\n      return;\r\n    }\r\n    if (targetItem.kind === GeoMapItemKind.MARKER) {\r\n      targetItem.position = undefined;\r\n      this.update(viewState);\r\n    } else {\r\n      const points = targetItem.route!.points;\r\n      const index = points.findIndex(\r\n        (point) => point.latitude === event.coord.y && point.longitude === event.coord.x\r\n      );\r\n\r\n      if (index !== -1) {\r\n        points.splice(index, 1);\r\n      }\r\n    }\r\n\r\n    this.update(viewState);\r\n  }\r\n  handleEditingItemDrag(id: string, event: MapEditingItemDraggedEvent) {\r\n    let viewState: GeoMapViewState = this.model()?.viewState!;\r\n    const pendingValues = viewState?.editingSession?.pendingItems!;\r\n    const firstKey = Object.keys(pendingValues)[0];\r\n    const pendingItems = pendingValues[firstKey];\r\n    let targetItem = pendingItems[0];\r\n    if (!targetItem) {\r\n      console.warn('Selection item is seemingly missing from known items: ', id);\r\n      return;\r\n    }\r\n    if (targetItem.kind === GeoMapItemKind.MARKER) {\r\n      targetItem.position!.latitude! = event.dragTo.y;\r\n      targetItem.position!.longitude! = event.dragTo.x;\r\n    } else {\r\n      const points = targetItem.route!.points;\r\n      const index = points.findIndex(\r\n        (point) =>\r\n          point.latitude === event.startPosition!.y && point.longitude === event.startPosition!.x\r\n      );\r\n      if (index !== -1) {\r\n        points[index].latitude = event.dragTo.y;\r\n        points[index].longitude = event.dragTo.x;\r\n      }\r\n      targetItem.route!.points! = points;\r\n    }\r\n\r\n    this.update(viewState);\r\n  }\r\n}\r\n","@if (model()) { @if (mapEngine === MapEngine.GOOGLE) {\r\n<google-map\r\n  [model]=\"model()!\"\r\n  [items]=\"items()\"\r\n  [style]=\"{ width: '100%', height: '320px' }\"\r\n  (onMapDragEnd)=\"move($event.viewport)\"\r\n  (onZoomChanged)=\"move($event.viewport)\"\r\n  (onMapClick)=\"handleMapClick($event.coordinates)\"\r\n  (onOverlayClick)=\"handleItemClick($event.itemId)\"\r\n  (onEditingOverlayClick)=\"handleEditingItemClick($event.itemId, $event)\"\r\n>\r\n</google-map>\r\n} @else if (mapEngine === MapEngine.LEAFLET) {\r\n<leaflet-map\r\n  [model]=\"model()!\"\r\n  [items]=\"items()\"\r\n  [editingSession]=\"editingSession()\"\r\n  (onMapDragEnd)=\"move($event.viewport)\"\r\n  (onZoomChanged)=\"move($event.viewport)\"\r\n  (onMapClick)=\"handleMapClick($event.coordinates)\"\r\n  (onOverlayClick)=\"handleItemClick($event.itemId)\"\r\n  (onEditingOverlayClick)=\"handleEditingItemClick($event.itemId, $event)\"\r\n  (onEditingOverlayDrag)=\"handleEditingItemDrag($event.itemId, $event)\"\r\n>\r\n</leaflet-map>\r\n} @else {\r\n<p>\r\n  <strong>Not recognised map engine: [ {{ mapEngine }} ]</strong>\r\n</p>\r\n<p>Please provide a valid choice of map engine!</p>\r\n} }\r\n"]}
|
|
222
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart-map.component.js","sourceRoot":"","sources":["../../../../../projects/smart-ng-client/src/lib/smart-map/smart-map.component.ts","../../../../../projects/smart-ng-client/src/lib/smart-map/smart-map.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  computed,\r\n  Inject,\r\n  InjectionToken,\r\n  Input,\r\n  OnInit,\r\n  Signal,\r\n  signal,\r\n  ValueEqualityFn,\r\n  ViewChild,\r\n  WritableSignal,\r\n} from '@angular/core';\r\nimport { lastValueFrom } from 'rxjs';\r\nimport {\r\n  GeoMapChange,\r\n  GeoMapEditingSession,\r\n  GeoMapItem,\r\n  GeoMapItemKind,\r\n  GeoMapLayer,\r\n  GeoMapModel,\r\n  GeoMapOperationMode,\r\n  GeoMapService,\r\n  GeoMapViewport,\r\n  GeoMapViewState,\r\n  GPSPosition,\r\n} from './api';\r\nimport { ViewContextChange } from '../view-context/api';\r\nimport { SmartViewContextService } from '../view-context/smart-view-context.service';\r\nimport { MapEditingItemClickedEvent, MapEditingItemDraggedEvent } from './smart-map.types';\r\nimport { AbstractMap } from './abstract-map';\r\n\r\nexport enum MapEngine {\r\n  GOOGLE = 'GOOGLE',\r\n  LEAFLET = 'LEAFLET',\r\n}\r\n\r\nexport const MAP_ENGINE = new InjectionToken<MapEngine>('MAP_ENGINE');\r\n\r\nconst itemEq: ValueEqualityFn<Array<GeoMapItem>> = (a: Array<GeoMapItem>, b: Array<GeoMapItem>) => {\r\n  const positions = new Set(a.map((it: GeoMapItem) => it.position));\r\n  b.forEach((it: GeoMapItem) => positions.delete(it.position));\r\n  return a.length === b.length && positions.size === 0;\r\n};\r\n\r\n@Component({\r\n  selector: 'smart-map',\r\n  templateUrl: './smart-map.component.html',\r\n  styleUrl: './smart-map.component.css',\r\n})\r\nexport class SmartMapComponent implements OnInit, AfterViewInit {\r\n  MapEngine = MapEngine;\r\n\r\n  @Input() uuid!: string;\r\n  @Input() identifier!: string;\r\n  @Input() parent?: any;\r\n\r\n  @ViewChild('mapComponent') mapComponent!: AbstractMap;\r\n\r\n  readonly model: WritableSignal<GeoMapModel | undefined> = signal(undefined);\r\n  readonly items: Signal<Array<GeoMapItem>> = computed(() => {\r\n    const model = this.model();\r\n    return model?.layers.flatMap((l) => l.items ?? []) ?? [];\r\n  });\r\n  readonly editingSession: Signal<GeoMapEditingSession | undefined> = computed(\r\n    () => this.model()?.viewState?.editingSession\r\n  );\r\n\r\n  readonly selection: Signal<Set<string>> = computed(\r\n    () =>\r\n      new Set(\r\n        this.items()\r\n          .filter((it) => !!it.selected)\r\n          .map((it) => it.id!)\r\n          .values()\r\n      )\r\n  );\r\n\r\n  viewContextService?: SmartViewContextService;\r\n\r\n  constructor(\r\n    @Inject(MAP_ENGINE)\r\n    public mapEngine: MapEngine,\r\n    private api: GeoMapService\r\n  ) {}\r\n\r\n  ngOnInit(): void {}\r\n\r\n  ngAfterViewInit() {\r\n    this.load();\r\n  }\r\n\r\n  async load(): Promise<void> {\r\n    const model: GeoMapModel = await lastValueFrom(this.api.load(this.uuid, this.identifier));\r\n    if (!model.viewport) {\r\n      throw new Error('GeoMapModel contains no viewport!');\r\n    }\r\n    this.model.update(() => model);\r\n  }\r\n\r\n  async move(viewport: GeoMapViewport): Promise<void> {\r\n    this.model.update((it) => {\r\n      console.log('model update is running!');\r\n      if (it) {\r\n        it.viewport = viewport;\r\n      }\r\n      return it;\r\n    });\r\n    const change: GeoMapChange = await lastValueFrom(\r\n      this.api.move(this.uuid, this.identifier, viewport)\r\n    );\r\n    this.handleChange(change);\r\n  }\r\n\r\n  async update(mapState: GeoMapViewState): Promise<void> {\r\n    this.model.update((it) => {\r\n      if (it) {\r\n        it.viewState = mapState;\r\n      }\r\n      return it;\r\n    });\r\n    const change: GeoMapChange = await lastValueFrom(\r\n      this.api.update(this.uuid, this.identifier, mapState)\r\n    );\r\n    this.handleChange(change);\r\n  }\r\n\r\n  private handleChange(change: GeoMapChange): void {\r\n    if (!change.items) {\r\n      return;\r\n    }\r\n\r\n    this.model.update((it) => {\r\n      const layersById: Map<string, GeoMapLayer> = new Map();\r\n      if (!it) {\r\n        return it;\r\n      }\r\n      it.layers.forEach((layer) => layersById.set(layer.code!, layer));\r\n      for (const layerChange of change.items) {\r\n        const layerId = layerChange.code!;\r\n        const toAdd = layerChange.toAdd;\r\n        layersById.set(layerId, {\r\n          code: layerId,\r\n          items: toAdd,\r\n        });\r\n      }\r\n      it.viewState!.editingSession = change.editingSession;\r\n      return {\r\n        ...it,\r\n        layers: [...layersById.values()],\r\n        viewState: it.viewState,\r\n      };\r\n    });\r\n  }\r\n\r\n  handleMapClick(position: GPSPosition): void {\r\n    let viewState = this.model()?.viewState!;\r\n    const operationMode = this.model()?.viewState?.operationMode ?? GeoMapOperationMode.ACTION;\r\n\r\n    switch (operationMode) {\r\n      case GeoMapOperationMode.ACTION:\r\n        // TODO: Fire action for layer, if applicable (maybe only on double click).\r\n        break;\r\n      case GeoMapOperationMode.SELECTION:\r\n        // no-op, can't select empty space.\r\n        break;\r\n    }\r\n    if (\r\n      viewState.editingSession &&\r\n      Object.keys(viewState.editingSession?.pendingItems!).length > 0\r\n    ) {\r\n      const pendingItems = viewState.editingSession.pendingItems!;\r\n      const firstKey = Object.keys(pendingItems)[0];\r\n      const pendingItem = pendingItems[firstKey];\r\n      if (pendingItem && pendingItem.length > 0) {\r\n        const editingItem: GeoMapItem = pendingItem[0];\r\n\r\n        if (editingItem.kind === GeoMapItemKind.MARKER) {\r\n          editingItem.position = position;\r\n        } else {\r\n          editingItem.route!.points.push(position);\r\n        }\r\n      }\r\n      this.update(viewState);\r\n    }\r\n  }\r\n\r\n  handleItemClick(id: string): void {\r\n    const operationMode = this.model()?.viewState?.operationMode ?? GeoMapOperationMode.ACTION;\r\n    let targetItem = this.items().find((it) => id === it.id);\r\n\r\n    if (!targetItem) {\r\n      console.warn('Selection item is seemingly missing from known items: ', id);\r\n      return;\r\n    }\r\n\r\n    switch (operationMode) {\r\n      case GeoMapOperationMode.ACTION:\r\n        // TODO: fire action!\r\n        break;\r\n      case GeoMapOperationMode.SELECTION:\r\n        lastValueFrom(\r\n          this.api.interact(this.uuid, this.identifier, {\r\n            operationMode,\r\n            targetItem,\r\n            targetLayer: '',\r\n            inverse: this.selection().has(id),\r\n          })\r\n        ).then(\r\n          (change: ViewContextChange) => {\r\n            if (!this.viewContextService) {\r\n              console.warn('Smart Map has no ViewContext Service set up!');\r\n              return null;\r\n            } else {\r\n              return this.viewContextService.handlePerformActionResponse(change);\r\n            }\r\n          },\r\n          (err: any) => {\r\n            console.warn('Could not submit selection change! ', err);\r\n          }\r\n        );\r\n        break;\r\n    }\r\n  }\r\n\r\n  handleEditingItemClick(id: string, event: MapEditingItemClickedEvent) {\r\n    let viewState: GeoMapViewState = this.model()?.viewState!;\r\n    const pendingValues = viewState?.editingSession?.pendingItems!;\r\n    const firstKey = Object.keys(pendingValues)[0];\r\n    const pendingItems = pendingValues[firstKey];\r\n    let targetItem = pendingItems[0];\r\n    if (!targetItem) {\r\n      console.warn('Selection item is seemingly missing from known items: ', id);\r\n      return;\r\n    }\r\n    if (targetItem.kind === GeoMapItemKind.MARKER) {\r\n      targetItem.position = undefined;\r\n      this.update(viewState);\r\n    } else {\r\n      const points = targetItem.route!.points;\r\n      const index = points.findIndex(\r\n        (point) => point.latitude === event.coord.y && point.longitude === event.coord.x\r\n      );\r\n\r\n      if (index !== -1) {\r\n        points.splice(index, 1);\r\n      }\r\n    }\r\n\r\n    this.update(viewState);\r\n  }\r\n  handleEditingItemDrag(id: string, event: MapEditingItemDraggedEvent) {\r\n    let viewState: GeoMapViewState = this.model()?.viewState!;\r\n    const pendingValues = viewState?.editingSession?.pendingItems!;\r\n    const firstKey = Object.keys(pendingValues)[0];\r\n    const pendingItems = pendingValues[firstKey];\r\n    let targetItem = pendingItems[0];\r\n    if (!targetItem) {\r\n      console.warn('Selection item is seemingly missing from known items: ', id);\r\n      return;\r\n    }\r\n    if (targetItem.kind === GeoMapItemKind.MARKER) {\r\n      targetItem.position!.latitude! = event.dragTo.y;\r\n      targetItem.position!.longitude! = event.dragTo.x;\r\n    } else {\r\n      const points = targetItem.route!.points;\r\n      const index = points.findIndex(\r\n        (point) =>\r\n          point.latitude === event.startPosition!.y && point.longitude === event.startPosition!.x\r\n      );\r\n      if (index !== -1) {\r\n        points[index].latitude = event.dragTo.y;\r\n        points[index].longitude = event.dragTo.x;\r\n      }\r\n      targetItem.route!.points! = points;\r\n    }\r\n\r\n    this.update(viewState);\r\n  }\r\n\r\n  toBase64(): Promise<string> {\r\n    return this.mapComponent!.toBase64();\r\n  }\r\n}\r\n","@if (model()) { @if (mapEngine === MapEngine.GOOGLE) {\r\n<google-map\r\n  #mapComponent\r\n  [model]=\"model()!\"\r\n  [items]=\"items()\"\r\n  [style]=\"{ width: '100%', height: '320px' }\"\r\n  (onMapDragEnd)=\"move($event.viewport)\"\r\n  (onZoomChanged)=\"move($event.viewport)\"\r\n  (onMapClick)=\"handleMapClick($event.coordinates)\"\r\n  (onOverlayClick)=\"handleItemClick($event.itemId)\"\r\n  (onEditingOverlayClick)=\"handleEditingItemClick($event.itemId, $event)\"\r\n>\r\n</google-map>\r\n} @else if (mapEngine === MapEngine.LEAFLET) {\r\n<leaflet-map\r\n  #mapComponent\r\n  [model]=\"model()!\"\r\n  [items]=\"items()\"\r\n  [editingSession]=\"editingSession()\"\r\n  (onMapDragEnd)=\"move($event.viewport)\"\r\n  (onZoomChanged)=\"move($event.viewport)\"\r\n  (onMapClick)=\"handleMapClick($event.coordinates)\"\r\n  (onOverlayClick)=\"handleItemClick($event.itemId)\"\r\n  (onEditingOverlayClick)=\"handleEditingItemClick($event.itemId, $event)\"\r\n  (onEditingOverlayDrag)=\"handleEditingItemDrag($event.itemId, $event)\"\r\n>\r\n</leaflet-map>\r\n} @else {\r\n<p>\r\n  <strong>Not recognised map engine: [ {{ mapEngine }} ]</strong>\r\n</p>\r\n<p>Please provide a valid choice of map engine!</p>\r\n} }\r\n"]}
|