@smartbit4all/ng-client 4.2.38 → 4.2.39
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/impl/leaflet-map.mjs +80 -9
- package/fesm2022/smartbit4all-ng-client.mjs +79 -8
- package/fesm2022/smartbit4all-ng-client.mjs.map +1 -1
- package/lib/smart-map/impl/leaflet-map.d.ts +2 -0
- package/package.json +1 -1
- package/smartbit4all-ng-client-4.2.39.tgz +0 -0
- package/smartbit4all-ng-client-4.2.38.tgz +0 -0
|
@@ -21,6 +21,7 @@ function createLeafletMapItem(item, config) {
|
|
|
21
21
|
title: item.label,
|
|
22
22
|
markerColor: config.color,
|
|
23
23
|
draggable: config.draggable,
|
|
24
|
+
icon: getIcon(config.color),
|
|
24
25
|
})),
|
|
25
26
|
]);
|
|
26
27
|
case GeoMapItemKind.LINE:
|
|
@@ -31,6 +32,7 @@ function createLeafletMapItem(item, config) {
|
|
|
31
32
|
title: item.label,
|
|
32
33
|
color: config.color,
|
|
33
34
|
draggable: config.draggable,
|
|
35
|
+
icon: getIcon(config.color),
|
|
34
36
|
})),
|
|
35
37
|
]);
|
|
36
38
|
}
|
|
@@ -40,6 +42,7 @@ export class LeafletMap extends AbstractMap {
|
|
|
40
42
|
constructor(el, cd, zone) {
|
|
41
43
|
super(el, cd, zone, createLeafletMapItem);
|
|
42
44
|
this.offsetDistance = 0.00004;
|
|
45
|
+
this.markers = [];
|
|
43
46
|
}
|
|
44
47
|
ngAfterViewChecked() {
|
|
45
48
|
if (!this.map && this.el.nativeElement.offsetParent) {
|
|
@@ -135,6 +138,7 @@ export class LeafletMap extends AbstractMap {
|
|
|
135
138
|
if (!this.map) {
|
|
136
139
|
return;
|
|
137
140
|
}
|
|
141
|
+
this.markers = [];
|
|
138
142
|
const markerGroups = new Map();
|
|
139
143
|
toAdd.forEach((item) => {
|
|
140
144
|
if (item.record instanceof L.Marker) {
|
|
@@ -183,7 +187,16 @@ export class LeafletMap extends AbstractMap {
|
|
|
183
187
|
let group = markerGroups.get(it.record.getLatLng().lat.toFixed(6) + ',' + it.record.getLatLng().lng.toFixed(6));
|
|
184
188
|
if (group && group.length > 1) {
|
|
185
189
|
const icon = this.createNumberedIcon(group.length);
|
|
186
|
-
const
|
|
190
|
+
const label = this.createLabel(group);
|
|
191
|
+
const extraMarker = L.marker(group[0].originalLatLng, { icon });
|
|
192
|
+
if (!extraMarker._tooltip) {
|
|
193
|
+
extraMarker.bindTooltip(label, {
|
|
194
|
+
permanent: false,
|
|
195
|
+
direction: 'auto',
|
|
196
|
+
});
|
|
197
|
+
this.markers.push(extraMarker);
|
|
198
|
+
}
|
|
199
|
+
const clusterMarker = extraMarker.addTo(this.map);
|
|
187
200
|
it.record.on('mouseover', (_event) => {
|
|
188
201
|
toAdd.forEach((item, index) => {
|
|
189
202
|
if (item.record instanceof L.Marker &&
|
|
@@ -212,6 +225,9 @@ export class LeafletMap extends AbstractMap {
|
|
|
212
225
|
}
|
|
213
226
|
});
|
|
214
227
|
}
|
|
228
|
+
else {
|
|
229
|
+
this.markers.push(it.record);
|
|
230
|
+
}
|
|
215
231
|
}
|
|
216
232
|
it.record.addTo(this.map);
|
|
217
233
|
this.overlays.set(it.id, it.record);
|
|
@@ -303,15 +319,49 @@ export class LeafletMap extends AbstractMap {
|
|
|
303
319
|
}
|
|
304
320
|
toBase64() {
|
|
305
321
|
return new Promise((resolve, reject) => {
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
322
|
+
setTimeout(() => {
|
|
323
|
+
leafletImage(this.map, (err, canvas) => {
|
|
324
|
+
if (err) {
|
|
325
|
+
console.error('Leaflet image capture error', err);
|
|
326
|
+
reject(err);
|
|
327
|
+
return;
|
|
328
|
+
}
|
|
329
|
+
const ctx = canvas.getContext('2d');
|
|
330
|
+
if (!ctx) {
|
|
331
|
+
reject('No context');
|
|
332
|
+
return;
|
|
333
|
+
}
|
|
334
|
+
this.markers.forEach((marker) => {
|
|
335
|
+
const tooltip = marker.getTooltip();
|
|
336
|
+
if (!tooltip) {
|
|
337
|
+
return;
|
|
338
|
+
}
|
|
339
|
+
const latLng = marker.getLatLng();
|
|
340
|
+
const point = this.map.latLngToContainerPoint(latLng);
|
|
341
|
+
const text = tooltip.getContent();
|
|
342
|
+
// Tooltip szöveg megjelenítése
|
|
343
|
+
ctx.font = 'bold 14px sans-serif';
|
|
344
|
+
ctx.fillStyle = 'black';
|
|
345
|
+
ctx.strokeStyle = 'white';
|
|
346
|
+
ctx.lineWidth = 4;
|
|
347
|
+
ctx.textAlign = 'center';
|
|
348
|
+
ctx.textBaseline = 'bottom';
|
|
349
|
+
ctx.strokeText(text, point.x, point.y + 10); // fehér kontúr
|
|
350
|
+
ctx.fillText(text, point.x, point.y + 10); // fekete szöveg
|
|
351
|
+
});
|
|
352
|
+
resolve(canvas.toDataURL('image/png'));
|
|
353
|
+
});
|
|
354
|
+
}, 300);
|
|
313
355
|
});
|
|
314
356
|
}
|
|
357
|
+
createLabel(group) {
|
|
358
|
+
let label = '';
|
|
359
|
+
group.forEach((item) => {
|
|
360
|
+
label += item._tooltip._content + ', ';
|
|
361
|
+
item._tooltip.permanent = false;
|
|
362
|
+
});
|
|
363
|
+
return label;
|
|
364
|
+
}
|
|
315
365
|
createNumberedIcon(number) {
|
|
316
366
|
const size = 35;
|
|
317
367
|
const scaleFactor = 15;
|
|
@@ -348,4 +398,25 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
348
398
|
type: Component,
|
|
349
399
|
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"] }]
|
|
350
400
|
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i0.NgZone }] });
|
|
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"]}
|
|
401
|
+
function getIcon(color) {
|
|
402
|
+
const size = 12;
|
|
403
|
+
const scaleFactor = 12;
|
|
404
|
+
const scaledSize = size * scaleFactor;
|
|
405
|
+
const canvas = document.createElement('canvas');
|
|
406
|
+
canvas.width = scaledSize;
|
|
407
|
+
canvas.height = scaledSize;
|
|
408
|
+
canvas.style.width = canvas.style.height = `${size}px`;
|
|
409
|
+
const ctx = canvas.getContext('2d');
|
|
410
|
+
ctx.scale(scaleFactor, scaleFactor);
|
|
411
|
+
ctx.beginPath();
|
|
412
|
+
ctx.arc(size / 2, size / 2, size / 2, 0, 2 * Math.PI, false);
|
|
413
|
+
ctx.fillStyle = color;
|
|
414
|
+
ctx.fill();
|
|
415
|
+
return L.icon({
|
|
416
|
+
iconUrl: canvas.toDataURL(),
|
|
417
|
+
iconSize: [size, size],
|
|
418
|
+
iconAnchor: [size / 2, size / 2],
|
|
419
|
+
popupAnchor: [0, -size / 2],
|
|
420
|
+
});
|
|
421
|
+
}
|
|
422
|
+
//# 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\nimport { I } from '@angular/cdk/keycodes';\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            icon: getIcon(config.color),\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            icon: getIcon(config.color),\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  markers: any = [];\r\n  constructor(el: ElementRef, cd: ChangeDetectorRef, zone: NgZone) {\r\n    super(el, cd, zone, createLeafletMapItem);\r\n  }\r\n\r\n  ngAfterViewChecked(): void {\r\n    if (!this.map && this.el.nativeElement.offsetParent) {\r\n      this.initialize();\r\n    }\r\n  }\r\n\r\n  private initialize(): void {\r\n    const options = this.createLeafletMapOptions();\r\n    this.map = L.map('leaflet', { 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    this.markers = [];\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 label = this.createLabel(group);\r\n          const extraMarker = L.marker(group[0].originalLatLng, { icon });\r\n\r\n          if (!extraMarker._tooltip) {\r\n            extraMarker.bindTooltip(label, {\r\n              permanent: false,\r\n              direction: 'auto',\r\n            });\r\n            this.markers.push(extraMarker);\r\n          }\r\n          const clusterMarker = extraMarker.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        } else {\r\n          this.markers.push(it.record);\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      setTimeout(() => {\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            return;\r\n          }\r\n\r\n          const ctx = canvas.getContext('2d');\r\n          if (!ctx) {\r\n            reject('No context');\r\n            return;\r\n          }\r\n\r\n          this.markers.forEach((marker: { getTooltip: () => any; getLatLng: () => any }) => {\r\n            const tooltip = marker.getTooltip();\r\n            if (!tooltip) {\r\n              return;\r\n            }\r\n            const latLng = marker.getLatLng();\r\n            const point = this.map.latLngToContainerPoint(latLng);\r\n            const text = tooltip.getContent();\r\n\r\n            // Tooltip szöveg megjelenítése\r\n            ctx.font = 'bold 14px sans-serif';\r\n            ctx.fillStyle = 'black';\r\n            ctx.strokeStyle = 'white';\r\n            ctx.lineWidth = 4;\r\n            ctx.textAlign = 'center';\r\n            ctx.textBaseline = 'bottom';\r\n            ctx.strokeText(text, point.x, point.y + 10); // fehér kontúr\r\n            ctx.fillText(text, point.x, point.y + 10); // fekete szöveg\r\n          });\r\n\r\n          resolve(canvas.toDataURL('image/png'));\r\n        });\r\n      }, 300);\r\n    });\r\n  }\r\n\r\n  createLabel(group: any[]) {\r\n    let label: string = '';\r\n    group.forEach((item) => {\r\n      label += item._tooltip._content + ', ';\r\n      item._tooltip.permanent = false;\r\n    });\r\n    return label;\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\nfunction getIcon(color: string) {\r\n  const size = 12;\r\n  const scaleFactor = 12;\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 = `${size}px`;\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, 0, 2 * Math.PI, false);\r\n  ctx.fillStyle = color;\r\n  ctx.fill();\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"]}
|
|
@@ -15525,6 +15525,7 @@ function createLeafletMapItem(item, config) {
|
|
|
15525
15525
|
title: item.label,
|
|
15526
15526
|
markerColor: config.color,
|
|
15527
15527
|
draggable: config.draggable,
|
|
15528
|
+
icon: getIcon(config.color),
|
|
15528
15529
|
})),
|
|
15529
15530
|
]);
|
|
15530
15531
|
case GeoMapItemKind.LINE:
|
|
@@ -15535,6 +15536,7 @@ function createLeafletMapItem(item, config) {
|
|
|
15535
15536
|
title: item.label,
|
|
15536
15537
|
color: config.color,
|
|
15537
15538
|
draggable: config.draggable,
|
|
15539
|
+
icon: getIcon(config.color),
|
|
15538
15540
|
})),
|
|
15539
15541
|
]);
|
|
15540
15542
|
}
|
|
@@ -15544,6 +15546,7 @@ class LeafletMap extends AbstractMap {
|
|
|
15544
15546
|
constructor(el, cd, zone) {
|
|
15545
15547
|
super(el, cd, zone, createLeafletMapItem);
|
|
15546
15548
|
this.offsetDistance = 0.00004;
|
|
15549
|
+
this.markers = [];
|
|
15547
15550
|
}
|
|
15548
15551
|
ngAfterViewChecked() {
|
|
15549
15552
|
if (!this.map && this.el.nativeElement.offsetParent) {
|
|
@@ -15639,6 +15642,7 @@ class LeafletMap extends AbstractMap {
|
|
|
15639
15642
|
if (!this.map) {
|
|
15640
15643
|
return;
|
|
15641
15644
|
}
|
|
15645
|
+
this.markers = [];
|
|
15642
15646
|
const markerGroups = new Map();
|
|
15643
15647
|
toAdd.forEach((item) => {
|
|
15644
15648
|
if (item.record instanceof L.Marker) {
|
|
@@ -15687,7 +15691,16 @@ class LeafletMap extends AbstractMap {
|
|
|
15687
15691
|
let group = markerGroups.get(it.record.getLatLng().lat.toFixed(6) + ',' + it.record.getLatLng().lng.toFixed(6));
|
|
15688
15692
|
if (group && group.length > 1) {
|
|
15689
15693
|
const icon = this.createNumberedIcon(group.length);
|
|
15690
|
-
const
|
|
15694
|
+
const label = this.createLabel(group);
|
|
15695
|
+
const extraMarker = L.marker(group[0].originalLatLng, { icon });
|
|
15696
|
+
if (!extraMarker._tooltip) {
|
|
15697
|
+
extraMarker.bindTooltip(label, {
|
|
15698
|
+
permanent: false,
|
|
15699
|
+
direction: 'auto',
|
|
15700
|
+
});
|
|
15701
|
+
this.markers.push(extraMarker);
|
|
15702
|
+
}
|
|
15703
|
+
const clusterMarker = extraMarker.addTo(this.map);
|
|
15691
15704
|
it.record.on('mouseover', (_event) => {
|
|
15692
15705
|
toAdd.forEach((item, index) => {
|
|
15693
15706
|
if (item.record instanceof L.Marker &&
|
|
@@ -15716,6 +15729,9 @@ class LeafletMap extends AbstractMap {
|
|
|
15716
15729
|
}
|
|
15717
15730
|
});
|
|
15718
15731
|
}
|
|
15732
|
+
else {
|
|
15733
|
+
this.markers.push(it.record);
|
|
15734
|
+
}
|
|
15719
15735
|
}
|
|
15720
15736
|
it.record.addTo(this.map);
|
|
15721
15737
|
this.overlays.set(it.id, it.record);
|
|
@@ -15807,14 +15823,48 @@ class LeafletMap extends AbstractMap {
|
|
|
15807
15823
|
}
|
|
15808
15824
|
toBase64() {
|
|
15809
15825
|
return new Promise((resolve, reject) => {
|
|
15810
|
-
|
|
15811
|
-
|
|
15812
|
-
|
|
15813
|
-
|
|
15814
|
-
|
|
15815
|
-
|
|
15816
|
-
|
|
15826
|
+
setTimeout(() => {
|
|
15827
|
+
leafletImage(this.map, (err, canvas) => {
|
|
15828
|
+
if (err) {
|
|
15829
|
+
console.error('Leaflet image capture error', err);
|
|
15830
|
+
reject(err);
|
|
15831
|
+
return;
|
|
15832
|
+
}
|
|
15833
|
+
const ctx = canvas.getContext('2d');
|
|
15834
|
+
if (!ctx) {
|
|
15835
|
+
reject('No context');
|
|
15836
|
+
return;
|
|
15837
|
+
}
|
|
15838
|
+
this.markers.forEach((marker) => {
|
|
15839
|
+
const tooltip = marker.getTooltip();
|
|
15840
|
+
if (!tooltip) {
|
|
15841
|
+
return;
|
|
15842
|
+
}
|
|
15843
|
+
const latLng = marker.getLatLng();
|
|
15844
|
+
const point = this.map.latLngToContainerPoint(latLng);
|
|
15845
|
+
const text = tooltip.getContent();
|
|
15846
|
+
// Tooltip szöveg megjelenítése
|
|
15847
|
+
ctx.font = 'bold 14px sans-serif';
|
|
15848
|
+
ctx.fillStyle = 'black';
|
|
15849
|
+
ctx.strokeStyle = 'white';
|
|
15850
|
+
ctx.lineWidth = 4;
|
|
15851
|
+
ctx.textAlign = 'center';
|
|
15852
|
+
ctx.textBaseline = 'bottom';
|
|
15853
|
+
ctx.strokeText(text, point.x, point.y + 10); // fehér kontúr
|
|
15854
|
+
ctx.fillText(text, point.x, point.y + 10); // fekete szöveg
|
|
15855
|
+
});
|
|
15856
|
+
resolve(canvas.toDataURL('image/png'));
|
|
15857
|
+
});
|
|
15858
|
+
}, 300);
|
|
15859
|
+
});
|
|
15860
|
+
}
|
|
15861
|
+
createLabel(group) {
|
|
15862
|
+
let label = '';
|
|
15863
|
+
group.forEach((item) => {
|
|
15864
|
+
label += item._tooltip._content + ', ';
|
|
15865
|
+
item._tooltip.permanent = false;
|
|
15817
15866
|
});
|
|
15867
|
+
return label;
|
|
15818
15868
|
}
|
|
15819
15869
|
createNumberedIcon(number) {
|
|
15820
15870
|
const size = 35;
|
|
@@ -15852,6 +15902,27 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
15852
15902
|
type: Component,
|
|
15853
15903
|
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"] }]
|
|
15854
15904
|
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i0.NgZone }] });
|
|
15905
|
+
function getIcon(color) {
|
|
15906
|
+
const size = 12;
|
|
15907
|
+
const scaleFactor = 12;
|
|
15908
|
+
const scaledSize = size * scaleFactor;
|
|
15909
|
+
const canvas = document.createElement('canvas');
|
|
15910
|
+
canvas.width = scaledSize;
|
|
15911
|
+
canvas.height = scaledSize;
|
|
15912
|
+
canvas.style.width = canvas.style.height = `${size}px`;
|
|
15913
|
+
const ctx = canvas.getContext('2d');
|
|
15914
|
+
ctx.scale(scaleFactor, scaleFactor);
|
|
15915
|
+
ctx.beginPath();
|
|
15916
|
+
ctx.arc(size / 2, size / 2, size / 2, 0, 2 * Math.PI, false);
|
|
15917
|
+
ctx.fillStyle = color;
|
|
15918
|
+
ctx.fill();
|
|
15919
|
+
return L.icon({
|
|
15920
|
+
iconUrl: canvas.toDataURL(),
|
|
15921
|
+
iconSize: [size, size],
|
|
15922
|
+
iconAnchor: [size / 2, size / 2],
|
|
15923
|
+
popupAnchor: [0, -size / 2],
|
|
15924
|
+
});
|
|
15925
|
+
}
|
|
15855
15926
|
|
|
15856
15927
|
var MapEngine;
|
|
15857
15928
|
(function (MapEngine) {
|