@smartbit4all/ng-client 4.0.149 → 4.1.1
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-client/smart-component-api-client.mjs +32 -7
- package/esm2022/lib/smart-client/smart.component.mjs +12 -5
- package/esm2022/lib/smart-component-layout/smart-component-layout-utility.mjs +18 -1
- package/esm2022/lib/smart-component-layout/smart-component-layout.component.mjs +5 -2
- package/esm2022/lib/smart-map/abstract-map.mjs +74 -0
- package/esm2022/lib/smart-map/api/api/api.mjs +4 -0
- package/esm2022/lib/smart-map/api/api/geoMap.service.mjs +312 -0
- package/esm2022/lib/smart-map/api/api.module.mjs +40 -0
- package/esm2022/lib/smart-map/api/configuration.mjs +91 -0
- package/esm2022/lib/smart-map/api/encoder.mjs +19 -0
- package/esm2022/lib/smart-map/api/index.mjs +7 -0
- package/esm2022/lib/smart-map/api/model/gPSPosition.mjs +13 -0
- package/esm2022/lib/smart-map/api/model/geoMapChange.mjs +2 -0
- package/esm2022/lib/smart-map/api/model/geoMapDataLoadingMode.mjs +17 -0
- package/esm2022/lib/smart-map/api/model/geoMapDataSourceDescriptor.mjs +2 -0
- package/esm2022/lib/smart-map/api/model/geoMapDataSourceType.mjs +18 -0
- package/esm2022/lib/smart-map/api/model/geoMapInteraction.mjs +2 -0
- package/esm2022/lib/smart-map/api/model/geoMapItem.mjs +2 -0
- package/esm2022/lib/smart-map/api/model/geoMapItemKind.mjs +18 -0
- package/esm2022/lib/smart-map/api/model/geoMapLayer.mjs +2 -0
- package/esm2022/lib/smart-map/api/model/geoMapLayerChange.mjs +2 -0
- package/esm2022/lib/smart-map/api/model/geoMapLayerDescriptor.mjs +2 -0
- package/esm2022/lib/smart-map/api/model/geoMapModel.mjs +2 -0
- package/esm2022/lib/smart-map/api/model/geoMapOperationMode.mjs +18 -0
- package/esm2022/lib/smart-map/api/model/geoMapSelectionMode.mjs +18 -0
- package/esm2022/lib/smart-map/api/model/geoMapServerModel.mjs +2 -0
- package/esm2022/lib/smart-map/api/model/geoMapTextType.mjs +17 -0
- package/esm2022/lib/smart-map/api/model/geoMapViewState.mjs +2 -0
- package/esm2022/lib/smart-map/api/model/geoMapViewport.mjs +2 -0
- package/esm2022/lib/smart-map/api/model/models.mjs +19 -0
- package/esm2022/lib/smart-map/api/param.mjs +2 -0
- package/esm2022/lib/smart-map/api/variables.mjs +9 -0
- package/esm2022/lib/smart-map/api-default/api-default.mjs +2 -0
- package/esm2022/lib/smart-map/impl/google-map.mjs +220 -0
- package/esm2022/lib/smart-map/impl/leaflet-map.mjs +165 -0
- package/esm2022/lib/smart-map/projects.mjs +9 -0
- package/esm2022/lib/smart-map/smart-map.component.mjs +193 -0
- package/esm2022/lib/smart-map/smart-map.module.mjs +22 -0
- package/esm2022/lib/smart-map/smart-map.types.mjs +2 -0
- package/esm2022/projects.mjs +2 -1
- package/fesm2022/smartbit4all-ng-client.mjs +1415 -140
- package/fesm2022/smartbit4all-ng-client.mjs.map +1 -1
- package/lib/smart-client/smart-component-api-client.d.ts +9 -6
- package/lib/smart-client/smart.component.d.ts +7 -4
- package/lib/smart-component-layout/smart-component-layout-utility.d.ts +3 -1
- package/lib/smart-component-layout/smart-component-layout.component.d.ts +3 -0
- package/lib/smart-map/abstract-map.d.ts +32 -0
- package/lib/smart-map/api/api/api.d.ts +3 -0
- package/lib/smart-map/api/api/geoMap.service.d.ts +101 -0
- package/lib/smart-map/api/api.module.d.ts +11 -0
- package/lib/smart-map/api/configuration.d.ts +104 -0
- package/lib/smart-map/api/encoder.d.ts +11 -0
- package/lib/smart-map/api/index.d.ts +6 -0
- package/lib/smart-map/api/model/gPSPosition.d.ts +32 -0
- package/lib/smart-map/api/model/geoMapChange.d.ts +19 -0
- package/lib/smart-map/api/model/geoMapDataLoadingMode.d.ts +15 -0
- package/lib/smart-map/api/model/geoMapDataSourceDescriptor.d.ts +50 -0
- package/lib/smart-map/api/model/geoMapDataSourceType.d.ts +16 -0
- package/lib/smart-map/api/model/geoMapInteraction.d.ts +22 -0
- package/lib/smart-map/api/model/geoMapItem.d.ts +38 -0
- package/lib/smart-map/api/model/geoMapItemKind.d.ts +16 -0
- package/lib/smart-map/api/model/geoMapLayer.d.ts +19 -0
- package/lib/smart-map/api/model/geoMapLayerChange.d.ts +20 -0
- package/lib/smart-map/api/model/geoMapLayerDescriptor.d.ts +28 -0
- package/lib/smart-map/api/model/geoMapModel.d.ts +27 -0
- package/lib/smart-map/api/model/geoMapOperationMode.d.ts +16 -0
- package/lib/smart-map/api/model/geoMapSelectionMode.d.ts +16 -0
- package/lib/smart-map/api/model/geoMapServerModel.d.ts +28 -0
- package/lib/smart-map/api/model/geoMapTextType.d.ts +15 -0
- package/lib/smart-map/api/model/geoMapViewState.d.ts +25 -0
- package/lib/smart-map/api/model/geoMapViewport.d.ts +20 -0
- package/lib/smart-map/api/model/models.d.ts +18 -0
- package/lib/smart-map/api/param.d.ts +37 -0
- package/lib/smart-map/api/variables.d.ts +8 -0
- package/lib/smart-map/api-default/api-default.d.ts +2 -0
- package/lib/smart-map/impl/google-map.d.ts +21 -0
- package/lib/smart-map/impl/leaflet-map.d.ts +15 -0
- package/lib/smart-map/projects.d.ts +8 -0
- package/lib/smart-map/smart-map.component.d.ts +33 -0
- package/lib/smart-map/smart-map.module.d.ts +11 -0
- package/lib/smart-map/smart-map.types.d.ts +21 -0
- package/package.json +1 -1
- package/projects.d.ts +1 -0
- package/smartbit4all-ng-client-4.1.1.tgz +0 -0
- package/smartbit4all-ng-client-4.0.149.tgz +0 -0
|
@@ -0,0 +1,165 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import { AbstractMap } from '../abstract-map';
|
|
3
|
+
import { GeoMapItemKind } from '../api';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
function createLeafletMapItem(item) {
|
|
6
|
+
switch (item.kind) {
|
|
7
|
+
case GeoMapItemKind.MARKER:
|
|
8
|
+
return L.marker(L.latLng(item.position.latitude, item.position.longitude), {
|
|
9
|
+
title: item.label,
|
|
10
|
+
});
|
|
11
|
+
case GeoMapItemKind.POLYGON:
|
|
12
|
+
return L.polygon(item.bounds.map((p) => [p.latitude, p.longitude]), { title: item.label });
|
|
13
|
+
}
|
|
14
|
+
throw new Error('Foo!');
|
|
15
|
+
}
|
|
16
|
+
export class LeafletMap extends AbstractMap {
|
|
17
|
+
constructor(el, cd, zone) {
|
|
18
|
+
super(el, cd, zone, createLeafletMapItem);
|
|
19
|
+
}
|
|
20
|
+
ngAfterViewChecked() {
|
|
21
|
+
if (!this.map && this.el.nativeElement.offsetParent) {
|
|
22
|
+
this.initialize();
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
initialize() {
|
|
26
|
+
const options = this.createLeafletMapOptions();
|
|
27
|
+
this.map = L.map('leaflet').setView(options.centre, options.zoom);
|
|
28
|
+
L.tileLayer('https://tile.openstreetmap.org/{z}/{x}/{y}.png', {
|
|
29
|
+
maxZoom: 19,
|
|
30
|
+
attribution: '© <a href="http://www.openstreetmap.org/copyright">OpenStreetMap</a>',
|
|
31
|
+
}).addTo(this.map);
|
|
32
|
+
const items = this.items();
|
|
33
|
+
const toAdd = items.map((it) => ({
|
|
34
|
+
id: it.id,
|
|
35
|
+
record: createLeafletMapItem(it),
|
|
36
|
+
}));
|
|
37
|
+
this.handleItemChanges([], toAdd);
|
|
38
|
+
const model = this.model();
|
|
39
|
+
if (model.viewState?.fitToInitialItems) {
|
|
40
|
+
const datasetBounds = this.findDatasetBounds();
|
|
41
|
+
if (datasetBounds) {
|
|
42
|
+
const { a, b } = datasetBounds;
|
|
43
|
+
const pntA = L.latLng(a.x, a.y);
|
|
44
|
+
const pntB = L.latLng(b.x, b.y);
|
|
45
|
+
const bounds = L.latLngBounds(pntA, pntB);
|
|
46
|
+
this.zone.run(() => {
|
|
47
|
+
this.map.fitBounds(bounds);
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
this.map.on('click', (event) => {
|
|
52
|
+
this.zone.run(() => {
|
|
53
|
+
const pos = event.latlng;
|
|
54
|
+
this.onMapClick.emit({
|
|
55
|
+
coordinates: {
|
|
56
|
+
latitude: pos.lat,
|
|
57
|
+
longitude: pos.lng,
|
|
58
|
+
},
|
|
59
|
+
originalEvent: event,
|
|
60
|
+
});
|
|
61
|
+
});
|
|
62
|
+
});
|
|
63
|
+
this.map.on('moveend', (event) => {
|
|
64
|
+
this.zone.run(() => {
|
|
65
|
+
const viewport = this.getViewport();
|
|
66
|
+
this.onMapDragEnd.emit({
|
|
67
|
+
viewport,
|
|
68
|
+
originalEvent: event,
|
|
69
|
+
});
|
|
70
|
+
});
|
|
71
|
+
});
|
|
72
|
+
this.map.on('zoomend', (event) => {
|
|
73
|
+
this.zone.run(() => {
|
|
74
|
+
const viewport = this.getViewport();
|
|
75
|
+
this.onMapDragEnd.emit({
|
|
76
|
+
viewport,
|
|
77
|
+
originalEvent: event,
|
|
78
|
+
});
|
|
79
|
+
});
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
getViewport() {
|
|
83
|
+
if (!this.map) {
|
|
84
|
+
throw new Error('Map is not yet initialised!');
|
|
85
|
+
}
|
|
86
|
+
const center = this.map.getCenter();
|
|
87
|
+
const zoomLevel = this.map.getZoom();
|
|
88
|
+
const leafletBounds = this.map.getBounds();
|
|
89
|
+
const { lat: swLat, lng: swLng } = leafletBounds.getSouthWest();
|
|
90
|
+
const { lat: neLat, lng: neLng } = leafletBounds.getNorthEast();
|
|
91
|
+
return {
|
|
92
|
+
center: {
|
|
93
|
+
latitude: center.lat,
|
|
94
|
+
longitude: center.lng,
|
|
95
|
+
},
|
|
96
|
+
zoomLevel,
|
|
97
|
+
bounds: [
|
|
98
|
+
{ latitude: swLat, longitude: swLng },
|
|
99
|
+
{ latitude: neLat, longitude: neLng },
|
|
100
|
+
],
|
|
101
|
+
};
|
|
102
|
+
}
|
|
103
|
+
createLeafletMapOptions() {
|
|
104
|
+
const viewport = this.model().viewport;
|
|
105
|
+
return {
|
|
106
|
+
centre: [viewport.center.latitude, viewport.center.longitude],
|
|
107
|
+
zoom: viewport.zoomLevel,
|
|
108
|
+
};
|
|
109
|
+
}
|
|
110
|
+
handleItemChanges(toRemove, toAdd) {
|
|
111
|
+
if (!this.map) {
|
|
112
|
+
return;
|
|
113
|
+
}
|
|
114
|
+
toRemove.forEach((it) => {
|
|
115
|
+
it.record.remove();
|
|
116
|
+
this.overlays.delete(it.id);
|
|
117
|
+
});
|
|
118
|
+
toAdd.forEach((it) => {
|
|
119
|
+
it.record.on('click', (event) => {
|
|
120
|
+
this.zone.run(() => {
|
|
121
|
+
this.onOverlayClick.emit({
|
|
122
|
+
itemId: it.id,
|
|
123
|
+
originalEvent: {
|
|
124
|
+
originalEvent: event,
|
|
125
|
+
overlay: it.record,
|
|
126
|
+
map: this.map,
|
|
127
|
+
},
|
|
128
|
+
});
|
|
129
|
+
});
|
|
130
|
+
});
|
|
131
|
+
it.record.addTo(this.map);
|
|
132
|
+
this.overlays.set(it.id, it.record);
|
|
133
|
+
});
|
|
134
|
+
}
|
|
135
|
+
findDatasetBounds() {
|
|
136
|
+
const items = this.items()
|
|
137
|
+
.flatMap((it) => (it.position ? [it.position] : []))
|
|
138
|
+
.map((it) => {
|
|
139
|
+
return { x: it.latitude, y: it.longitude };
|
|
140
|
+
});
|
|
141
|
+
if (!items || items.length === 0) {
|
|
142
|
+
return null;
|
|
143
|
+
}
|
|
144
|
+
let southwest = { x: items[0].x, y: items[0].y };
|
|
145
|
+
let northeast = { x: items[0].x, y: items[0].y };
|
|
146
|
+
items.forEach((it) => {
|
|
147
|
+
if (it.x < southwest.x)
|
|
148
|
+
southwest.x = it.x;
|
|
149
|
+
if (it.y < southwest.y)
|
|
150
|
+
southwest.y = it.y;
|
|
151
|
+
if (it.x > northeast.x)
|
|
152
|
+
northeast.x = it.x;
|
|
153
|
+
if (it.y > northeast.y)
|
|
154
|
+
northeast.y = it.y;
|
|
155
|
+
});
|
|
156
|
+
return { a: southwest, b: northeast };
|
|
157
|
+
}
|
|
158
|
+
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 }); }
|
|
159
|
+
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}\n"] }); }
|
|
160
|
+
}
|
|
161
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: LeafletMap, decorators: [{
|
|
162
|
+
type: Component,
|
|
163
|
+
args: [{ selector: 'leaflet-map', template: ` <div id="leaflet"></div>`, styles: ["#leaflet{height:720px}\n"] }]
|
|
164
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i0.NgZone }] });
|
|
165
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"leaflet-map.js","sourceRoot":"","sources":["../../../../../../projects/smart-ng-client/src/lib/smart-map/impl/leaflet-map.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewChecked, ChangeDetectorRef, Component, ElementRef, NgZone } from '@angular/core';\r\nimport { AbstractMap, RecordWithId } from '../abstract-map';\r\nimport { GeoMapItem, GeoMapItemKind, GeoMapViewport } from '../api';\r\nimport { Coord } from '../smart-map.types';\r\n\r\ndeclare var L: any;\r\n\r\ninterface LeafletMapOptions {\r\n  centre: Array<number>;\r\n  zoom: number;\r\n}\r\n\r\nfunction createLeafletMapItem(item: GeoMapItem): any {\r\n  switch (item.kind) {\r\n    case GeoMapItemKind.MARKER:\r\n      return L.marker(L.latLng(item.position!.latitude, item.position!.longitude), {\r\n        title: item.label,\r\n      });\r\n    case GeoMapItemKind.POLYGON:\r\n      return L.polygon(\r\n        item.bounds!.map((p) => [p.latitude, p.longitude]),\r\n        { title: item.label }\r\n      );\r\n  }\r\n  throw new Error('Foo!');\r\n}\r\n\r\n@Component({\r\n  selector: 'leaflet-map',\r\n  template: ` <div id=\"leaflet\"></div>`,\r\n  styles: `\r\n      #leaflet {\r\n          height: 720px;\r\n      }`,\r\n})\r\nexport class LeafletMap extends AbstractMap implements AfterViewChecked {\r\n  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),\r\n    }));\r\n    this.handleItemChanges([], toAdd);\r\n    const model = this.model();\r\n    if (model.viewState?.fitToInitialItems) {\r\n      const datasetBounds = this.findDatasetBounds();\r\n      if (datasetBounds) {\r\n        const { a, b } = datasetBounds;\r\n        const pntA = L.latLng(a.x, a.y);\r\n        const pntB = L.latLng(b.x, b.y);\r\n        const bounds = L.latLngBounds(pntA, pntB);\r\n        this.zone.run(() => {\r\n          this.map.fitBounds(bounds);\r\n        });\r\n      }\r\n    }\r\n    this.map.on('click', (event: any) => {\r\n      this.zone.run(() => {\r\n        const pos = event.latlng;\r\n        this.onMapClick.emit({\r\n          coordinates: {\r\n            latitude: pos.lat as number,\r\n            longitude: pos.lng as number,\r\n          },\r\n          originalEvent: event,\r\n        });\r\n      });\r\n    });\r\n\r\n    this.map.on('moveend', (event: any) => {\r\n      this.zone.run(() => {\r\n        const viewport = this.getViewport();\r\n        this.onMapDragEnd.emit({\r\n          viewport,\r\n          originalEvent: event,\r\n        });\r\n      });\r\n    });\r\n\r\n    this.map.on('zoomend', (event: any) => {\r\n      this.zone.run(() => {\r\n        const viewport = this.getViewport();\r\n        this.onMapDragEnd.emit({\r\n          viewport,\r\n          originalEvent: event,\r\n        });\r\n      });\r\n    });\r\n  }\r\n\r\n  getViewport(): GeoMapViewport {\r\n    if (!this.map) {\r\n      throw new Error('Map is not yet initialised!');\r\n    }\r\n\r\n    const center = this.map.getCenter();\r\n    const zoomLevel = this.map.getZoom() as number;\r\n    const leafletBounds = this.map.getBounds();\r\n    const { lat: swLat, lng: swLng } = leafletBounds.getSouthWest();\r\n    const { lat: neLat, lng: neLng } = leafletBounds.getNorthEast();\r\n\r\n    return {\r\n      center: {\r\n        latitude: center.lat as number,\r\n        longitude: center.lng as number,\r\n      },\r\n      zoomLevel,\r\n      bounds: [\r\n        { latitude: swLat, longitude: swLng },\r\n        { latitude: neLat, longitude: neLng },\r\n      ],\r\n    };\r\n  }\r\n\r\n  private createLeafletMapOptions(): LeafletMapOptions {\r\n    const viewport: GeoMapViewport = this.model().viewport!;\r\n    return {\r\n      centre: [viewport.center!.latitude, viewport.center!.longitude],\r\n      zoom: viewport.zoomLevel!,\r\n    };\r\n  }\r\n\r\n  override handleItemChanges(toRemove: Array<RecordWithId>, toAdd: Array<RecordWithId>): void {\r\n    if (!this.map) {\r\n      return;\r\n    }\r\n\r\n    toRemove.forEach((it) => {\r\n      it.record.remove();\r\n      this.overlays.delete(it.id);\r\n    });\r\n\r\n    toAdd.forEach((it) => {\r\n      it.record.on('click', (event: any) => {\r\n        this.zone.run(() => {\r\n          this.onOverlayClick.emit({\r\n            itemId: it.id,\r\n            originalEvent: {\r\n              originalEvent: event,\r\n              overlay: it.record,\r\n              map: this.map,\r\n            },\r\n          });\r\n        });\r\n      });\r\n      it.record.addTo(this.map);\r\n      this.overlays.set(it.id, it.record);\r\n    });\r\n  }\r\n\r\n  private findDatasetBounds(): { a: Coord; b: Coord } | null {\r\n    const items: Array<Coord> = this.items()\r\n      .flatMap((it) => (it.position ? [it.position] : []))\r\n      .map((it) => {\r\n        return { x: it.latitude, y: it.longitude };\r\n      });\r\n    if (!items || items.length === 0) {\r\n      return null;\r\n    }\r\n\r\n    let southwest: Coord = { x: items[0].x, y: items[0].y };\r\n    let northeast: Coord = { x: items[0].x, y: items[0].y };\r\n\r\n    items.forEach((it) => {\r\n      if (it.x < southwest.x) southwest.x = it.x;\r\n      if (it.y < southwest.y) southwest.y = it.y;\r\n\r\n      if (it.x > northeast.x) northeast.x = it.x;\r\n      if (it.y > northeast.y) northeast.y = it.y;\r\n    });\r\n\r\n    return { a: southwest, b: northeast };\r\n  }\r\n}\r\n"]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export * from './smart-map.component';
|
|
2
|
+
export * from './smart-map.module';
|
|
3
|
+
export * from './impl/google-map';
|
|
4
|
+
export * from './impl/leaflet-map';
|
|
5
|
+
export * from './api/model/models';
|
|
6
|
+
export * from './smart-map.types';
|
|
7
|
+
export * from './abstract-map';
|
|
8
|
+
export * from './api-default/api-default';
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvamVjdHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zbWFydC1uZy1jbGllbnQvc3JjL2xpYi9zbWFydC1tYXAvcHJvamVjdHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLDJCQUEyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9zbWFydC1tYXAuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9zbWFydC1tYXAubW9kdWxlJztcclxuZXhwb3J0ICogZnJvbSAnLi9pbXBsL2dvb2dsZS1tYXAnO1xyXG5leHBvcnQgKiBmcm9tICcuL2ltcGwvbGVhZmxldC1tYXAnO1xyXG5leHBvcnQgKiBmcm9tICcuL2FwaS9tb2RlbC9tb2RlbHMnO1xyXG5leHBvcnQgKiBmcm9tICcuL3NtYXJ0LW1hcC50eXBlcyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vYWJzdHJhY3QtbWFwJztcclxuZXhwb3J0ICogZnJvbSAnLi9hcGktZGVmYXVsdC9hcGktZGVmYXVsdCc7XHJcbiJdfQ==
|
|
@@ -0,0 +1,193 @@
|
|
|
1
|
+
import { Component, computed, Inject, InjectionToken, Input, signal, } from '@angular/core';
|
|
2
|
+
import { lastValueFrom } from 'rxjs';
|
|
3
|
+
import { GeoMapItemKind, GeoMapOperationMode, } from './api';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "./api";
|
|
6
|
+
import * as i2 from "./impl/google-map";
|
|
7
|
+
import * as i3 from "./impl/leaflet-map";
|
|
8
|
+
export var MapEngine;
|
|
9
|
+
(function (MapEngine) {
|
|
10
|
+
MapEngine["GOOGLE"] = "GOOGLE";
|
|
11
|
+
MapEngine["LEAFLET"] = "LEAFLET";
|
|
12
|
+
})(MapEngine || (MapEngine = {}));
|
|
13
|
+
export const MAP_ENGINE = new InjectionToken('MAP_ENGINE');
|
|
14
|
+
const itemEq = (a, b) => {
|
|
15
|
+
const positions = new Set(a.map((it) => it.position));
|
|
16
|
+
b.forEach((it) => positions.delete(it.position));
|
|
17
|
+
return a.length === b.length && positions.size === 0;
|
|
18
|
+
};
|
|
19
|
+
export class SmartMapComponent {
|
|
20
|
+
constructor(mapEngine, api) {
|
|
21
|
+
this.mapEngine = mapEngine;
|
|
22
|
+
this.api = api;
|
|
23
|
+
this.MapEngine = MapEngine;
|
|
24
|
+
this.model = signal(undefined);
|
|
25
|
+
this.items = computed(() => {
|
|
26
|
+
const model = this.model();
|
|
27
|
+
return model?.layers.flatMap((l) => l.items ?? []) ?? [];
|
|
28
|
+
});
|
|
29
|
+
this.selection = computed(() => new Set(this.items()
|
|
30
|
+
.filter((it) => !!it.selected)
|
|
31
|
+
.map((it) => it.id)
|
|
32
|
+
.values()));
|
|
33
|
+
}
|
|
34
|
+
ngOnInit() {
|
|
35
|
+
// this.load();
|
|
36
|
+
}
|
|
37
|
+
ngAfterViewInit() {
|
|
38
|
+
this.load();
|
|
39
|
+
}
|
|
40
|
+
async load() {
|
|
41
|
+
const model = await lastValueFrom(this.api.load(this.uuid, this.identifier));
|
|
42
|
+
if (!model.viewport) {
|
|
43
|
+
throw new Error('GeoMapModel contains no viewport!');
|
|
44
|
+
}
|
|
45
|
+
this.model.update(() => model);
|
|
46
|
+
}
|
|
47
|
+
async move(viewport) {
|
|
48
|
+
this.model.update((it) => {
|
|
49
|
+
console.log('model update is running!');
|
|
50
|
+
if (it) {
|
|
51
|
+
it.viewport = viewport;
|
|
52
|
+
}
|
|
53
|
+
return it;
|
|
54
|
+
});
|
|
55
|
+
const change = await lastValueFrom(this.api.move(this.uuid, this.identifier, viewport));
|
|
56
|
+
this.handleChange(change);
|
|
57
|
+
}
|
|
58
|
+
async update(mapState) {
|
|
59
|
+
this.model.update((it) => {
|
|
60
|
+
if (it) {
|
|
61
|
+
it.viewState = mapState;
|
|
62
|
+
}
|
|
63
|
+
return it;
|
|
64
|
+
});
|
|
65
|
+
const change = await lastValueFrom(this.api.update(this.uuid, this.identifier, mapState));
|
|
66
|
+
this.handleChange(change);
|
|
67
|
+
}
|
|
68
|
+
handleChange(change) {
|
|
69
|
+
if (!change.items) {
|
|
70
|
+
return;
|
|
71
|
+
}
|
|
72
|
+
this.model.update((it) => {
|
|
73
|
+
const layersById = new Map();
|
|
74
|
+
if (!it) {
|
|
75
|
+
return it;
|
|
76
|
+
}
|
|
77
|
+
it.layers.forEach((layer) => layersById.set(layer.code, layer));
|
|
78
|
+
for (const layerChange of change.items) {
|
|
79
|
+
const layerId = layerChange.code;
|
|
80
|
+
const toAdd = layerChange.toAdd;
|
|
81
|
+
layersById.set(layerId, {
|
|
82
|
+
code: layerId,
|
|
83
|
+
items: toAdd,
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
return {
|
|
87
|
+
...it,
|
|
88
|
+
layers: [...layersById.values()],
|
|
89
|
+
};
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
handleMapClick(position) {
|
|
93
|
+
const operationMode = this.model()?.viewState?.operationMode ?? GeoMapOperationMode.ACTION;
|
|
94
|
+
switch (operationMode) {
|
|
95
|
+
case GeoMapOperationMode.ACTION:
|
|
96
|
+
// TODO: Fire action for layer, if applicable (maybe only on double click).
|
|
97
|
+
break;
|
|
98
|
+
case GeoMapOperationMode.SELECTION:
|
|
99
|
+
// no-op, can't select empty space.
|
|
100
|
+
break;
|
|
101
|
+
case GeoMapOperationMode.PLACEMENT:
|
|
102
|
+
lastValueFrom(this.api.interact(this.uuid, this.identifier, {
|
|
103
|
+
operationMode,
|
|
104
|
+
targetItem: {
|
|
105
|
+
kind: GeoMapItemKind.MARKER, // FIXME: We shall support more item kinds!
|
|
106
|
+
position,
|
|
107
|
+
icons: {},
|
|
108
|
+
bounds: [],
|
|
109
|
+
actions: [],
|
|
110
|
+
},
|
|
111
|
+
targetLayer: '',
|
|
112
|
+
inverse: false,
|
|
113
|
+
})).then((change) => {
|
|
114
|
+
if (!this.viewContextService) {
|
|
115
|
+
console.warn('Smart Map has no ViewContext Service set up!');
|
|
116
|
+
return null;
|
|
117
|
+
}
|
|
118
|
+
else {
|
|
119
|
+
return this.viewContextService.handlePerformActionResponse(change);
|
|
120
|
+
}
|
|
121
|
+
}, (err) => {
|
|
122
|
+
console.warn('Could not submit selection change! ', err);
|
|
123
|
+
});
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
handleItemClick(id) {
|
|
127
|
+
const operationMode = this.model()?.viewState?.operationMode ?? GeoMapOperationMode.ACTION;
|
|
128
|
+
const targetItem = this.items().find((it) => id === it.id);
|
|
129
|
+
if (!targetItem) {
|
|
130
|
+
console.warn('Selection item is seemingly missing from known items: ', id);
|
|
131
|
+
return;
|
|
132
|
+
}
|
|
133
|
+
switch (operationMode) {
|
|
134
|
+
case GeoMapOperationMode.ACTION:
|
|
135
|
+
// TODO: fire action!
|
|
136
|
+
break;
|
|
137
|
+
case GeoMapOperationMode.SELECTION:
|
|
138
|
+
lastValueFrom(this.api.interact(this.uuid, this.identifier, {
|
|
139
|
+
operationMode,
|
|
140
|
+
targetItem,
|
|
141
|
+
targetLayer: '',
|
|
142
|
+
inverse: this.selection().has(id),
|
|
143
|
+
})).then((change) => {
|
|
144
|
+
if (!this.viewContextService) {
|
|
145
|
+
console.warn('Smart Map has no ViewContext Service set up!');
|
|
146
|
+
return null;
|
|
147
|
+
}
|
|
148
|
+
else {
|
|
149
|
+
return this.viewContextService.handlePerformActionResponse(change);
|
|
150
|
+
}
|
|
151
|
+
}, (err) => {
|
|
152
|
+
console.warn('Could not submit selection change! ', err);
|
|
153
|
+
});
|
|
154
|
+
break;
|
|
155
|
+
case GeoMapOperationMode.PLACEMENT:
|
|
156
|
+
// clicking an item may remove it, if it's only a pending item. To reposition existing
|
|
157
|
+
// items, we shall react to dragEnd events only.
|
|
158
|
+
lastValueFrom(this.api.interact(this.uuid, this.identifier, {
|
|
159
|
+
operationMode,
|
|
160
|
+
targetItem,
|
|
161
|
+
targetLayer: '',
|
|
162
|
+
inverse: true,
|
|
163
|
+
})).then((change) => {
|
|
164
|
+
if (!this.viewContextService) {
|
|
165
|
+
console.warn('Smart Map has no ViewContext Service set up!');
|
|
166
|
+
return null;
|
|
167
|
+
}
|
|
168
|
+
else {
|
|
169
|
+
return this.viewContextService.handlePerformActionResponse(change);
|
|
170
|
+
}
|
|
171
|
+
}, (err) => {
|
|
172
|
+
console.warn('Could not submit placement change! ', err);
|
|
173
|
+
});
|
|
174
|
+
break;
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
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 }); }
|
|
178
|
+
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>\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 (onMapDragEnd)=\"move($event.viewport)\"\r\n (onZoomChanged)=\"move($event.viewport)\"\r\n (onMapClick)=\"handleMapClick($event.coordinates)\"\r\n (onOverlayClick)=\"handleItemClick($event.itemId)\"\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" }] }); }
|
|
179
|
+
}
|
|
180
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartMapComponent, decorators: [{
|
|
181
|
+
type: Component,
|
|
182
|
+
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>\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 (onMapDragEnd)=\"move($event.viewport)\"\r\n (onZoomChanged)=\"move($event.viewport)\"\r\n (onMapClick)=\"handleMapClick($event.coordinates)\"\r\n (onOverlayClick)=\"handleItemClick($event.itemId)\"\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" }]
|
|
183
|
+
}], ctorParameters: () => [{ type: MapEngine, decorators: [{
|
|
184
|
+
type: Inject,
|
|
185
|
+
args: [MAP_ENGINE]
|
|
186
|
+
}] }, { type: i1.GeoMapService }], propDecorators: { uuid: [{
|
|
187
|
+
type: Input
|
|
188
|
+
}], identifier: [{
|
|
189
|
+
type: Input
|
|
190
|
+
}], parent: [{
|
|
191
|
+
type: Input
|
|
192
|
+
}] } });
|
|
193
|
+
//# 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;AAEvB,OAAO,EAAE,aAAa,EAAE,MAAM,MAAM,CAAC;AACrC,OAAO,EAGL,cAAc,EAGd,mBAAmB,GAKpB,MAAM,OAAO,CAAC;;;;;AAIf,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;IAyB5B,YAES,SAAoB,EACnB,GAAkB;QADnB,cAAS,GAAT,SAAS,CAAW;QACnB,QAAG,GAAH,GAAG,CAAe;QA3B5B,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;QAEM,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,OAAO;gBACL,GAAG,EAAE;gBACL,MAAM,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC;aACjC,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAED,cAAc,CAAC,QAAqB;QAClC,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,EAAE,EAAE,SAAS,EAAE,aAAa,IAAI,mBAAmB,CAAC,MAAM,CAAC;QAC3F,QAAQ,aAAa,EAAE,CAAC;YACtB,KAAK,mBAAmB,CAAC,MAAM;gBAC7B,2EAA2E;gBAC3E,MAAM;YACR,KAAK,mBAAmB,CAAC,SAAS;gBAChC,mCAAmC;gBACnC,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,EAAE;wBACV,IAAI,EAAE,cAAc,CAAC,MAAM,EAAE,2CAA2C;wBACxE,QAAQ;wBACR,KAAK,EAAE,EAAE;wBACT,MAAM,EAAE,EAAE;wBACV,OAAO,EAAE,EAAE;qBACZ;oBACD,WAAW,EAAE,EAAE;oBACf,OAAO,EAAE,KAAK;iBACf,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;QACN,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,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;QAC3D,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;YACR,KAAK,mBAAmB,CAAC,SAAS;gBAChC,sFAAsF;gBACtF,gDAAgD;gBAChD,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;iBACd,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;+GAtMU,iBAAiB,kBA0BlB,UAAU;mGA1BT,iBAAiB,uHChD9B,i5BA2BA;;4FDqBa,iBAAiB;kBAL7B,SAAS;+BACE,WAAW;;0BA8BlB,MAAM;2BAAC,UAAU;qEAvBX,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 { SmartComponent } from '../smart-client/smart.component';\r\nimport { lastValueFrom } from 'rxjs';\r\nimport {\r\n  GeoMapChange,\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\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?: SmartComponent<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\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      return {\r\n        ...it,\r\n        layers: [...layersById.values()],\r\n      };\r\n    });\r\n  }\r\n\r\n  handleMapClick(position: GPSPosition): void {\r\n    const operationMode = this.model()?.viewState?.operationMode ?? GeoMapOperationMode.ACTION;\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      case GeoMapOperationMode.PLACEMENT:\r\n        lastValueFrom(\r\n          this.api.interact(this.uuid, this.identifier, {\r\n            operationMode,\r\n            targetItem: {\r\n              kind: GeoMapItemKind.MARKER, // FIXME: We shall support more item kinds!\r\n              position,\r\n              icons: {},\r\n              bounds: [],\r\n              actions: [],\r\n            },\r\n            targetLayer: '',\r\n            inverse: false,\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    }\r\n  }\r\n\r\n  handleItemClick(id: string): void {\r\n    const operationMode = this.model()?.viewState?.operationMode ?? GeoMapOperationMode.ACTION;\r\n    const targetItem = this.items().find((it) => id === it.id);\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      case GeoMapOperationMode.PLACEMENT:\r\n        // clicking an item may remove it, if it's only a pending item. To reposition existing\r\n        // items, we shall react to dragEnd events only.\r\n        lastValueFrom(\r\n          this.api.interact(this.uuid, this.identifier, {\r\n            operationMode,\r\n            targetItem,\r\n            targetLayer: '',\r\n            inverse: true,\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 placement change! ', err);\r\n          }\r\n        );\r\n        break;\r\n    }\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>\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  (onMapDragEnd)=\"move($event.viewport)\"\r\n  (onZoomChanged)=\"move($event.viewport)\"\r\n  (onMapClick)=\"handleMapClick($event.coordinates)\"\r\n  (onOverlayClick)=\"handleItemClick($event.itemId)\"\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"]}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { MAP_ENGINE, MapEngine, SmartMapComponent } from './smart-map.component';
|
|
3
|
+
import { BrowserModule } from '@angular/platform-browser';
|
|
4
|
+
import { CommonModule } from '@angular/common';
|
|
5
|
+
import { GoogleMap } from './impl/google-map';
|
|
6
|
+
import { LeafletMap } from './impl/leaflet-map';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
export class SmartMapModule {
|
|
9
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartMapModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
10
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.11", ngImport: i0, type: SmartMapModule, declarations: [SmartMapComponent, GoogleMap, LeafletMap], imports: [CommonModule, BrowserModule], exports: [SmartMapComponent, GoogleMap, LeafletMap] }); }
|
|
11
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartMapModule, providers: [{ provide: MAP_ENGINE, useValue: MapEngine.GOOGLE }], imports: [CommonModule, BrowserModule] }); }
|
|
12
|
+
}
|
|
13
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartMapModule, decorators: [{
|
|
14
|
+
type: NgModule,
|
|
15
|
+
args: [{
|
|
16
|
+
declarations: [SmartMapComponent, GoogleMap, LeafletMap],
|
|
17
|
+
imports: [CommonModule, BrowserModule],
|
|
18
|
+
providers: [{ provide: MAP_ENGINE, useValue: MapEngine.GOOGLE }],
|
|
19
|
+
exports: [SmartMapComponent, GoogleMap, LeafletMap],
|
|
20
|
+
}]
|
|
21
|
+
}] });
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnQtbWFwLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3NtYXJ0LW5nLWNsaWVudC9zcmMvbGliL3NtYXJ0LW1hcC9zbWFydC1tYXAubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFVBQVUsRUFBRSxTQUFTLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUNqRixPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDMUQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUM5QyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7O0FBUWhELE1BQU0sT0FBTyxjQUFjOytHQUFkLGNBQWM7Z0hBQWQsY0FBYyxpQkFMVixpQkFBaUIsRUFBRSxTQUFTLEVBQUUsVUFBVSxhQUM3QyxZQUFZLEVBQUUsYUFBYSxhQUUzQixpQkFBaUIsRUFBRSxTQUFTLEVBQUUsVUFBVTtnSEFFdkMsY0FBYyxhQUhkLENBQUMsRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFLFFBQVEsRUFBRSxTQUFTLENBQUMsTUFBTSxFQUFFLENBQUMsWUFEdEQsWUFBWSxFQUFFLGFBQWE7OzRGQUkxQixjQUFjO2tCQU4xQixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLGlCQUFpQixFQUFFLFNBQVMsRUFBRSxVQUFVLENBQUM7b0JBQ3hELE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxhQUFhLENBQUM7b0JBQ3RDLFNBQVMsRUFBRSxDQUFDLEVBQUUsT0FBTyxFQUFFLFVBQVUsRUFBRSxRQUFRLEVBQUUsU0FBUyxDQUFDLE1BQU0sRUFBRSxDQUFDO29CQUNoRSxPQUFPLEVBQUUsQ0FBQyxpQkFBaUIsRUFBRSxTQUFTLEVBQUUsVUFBVSxDQUFDO2lCQUNwRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE1BUF9FTkdJTkUsIE1hcEVuZ2luZSwgU21hcnRNYXBDb21wb25lbnQgfSBmcm9tICcuL3NtYXJ0LW1hcC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBCcm93c2VyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IEdvb2dsZU1hcCB9IGZyb20gJy4vaW1wbC9nb29nbGUtbWFwJztcclxuaW1wb3J0IHsgTGVhZmxldE1hcCB9IGZyb20gJy4vaW1wbC9sZWFmbGV0LW1hcCc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW1NtYXJ0TWFwQ29tcG9uZW50LCBHb29nbGVNYXAsIExlYWZsZXRNYXBdLFxyXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIEJyb3dzZXJNb2R1bGVdLFxyXG4gIHByb3ZpZGVyczogW3sgcHJvdmlkZTogTUFQX0VOR0lORSwgdXNlVmFsdWU6IE1hcEVuZ2luZS5HT09HTEUgfV0sXHJcbiAgZXhwb3J0czogW1NtYXJ0TWFwQ29tcG9uZW50LCBHb29nbGVNYXAsIExlYWZsZXRNYXBdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgU21hcnRNYXBNb2R1bGUge31cclxuIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnQtbWFwLnR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc21hcnQtbmctY2xpZW50L3NyYy9saWIvc21hcnQtbWFwL3NtYXJ0LW1hcC50eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgR2VvTWFwVmlld3BvcnQsIEdQU1Bvc2l0aW9uIH0gZnJvbSAnLi9hcGknO1xyXG5cclxuZXhwb3J0IHR5cGUgTWFwRHJhZ2dlZEV2ZW50ID0ge1xyXG4gIHZpZXdwb3J0OiBHZW9NYXBWaWV3cG9ydDtcclxuICBvcmlnaW5hbEV2ZW50OiBhbnk7XHJcbn07XHJcblxyXG5leHBvcnQgdHlwZSBNYXBab29tQ2hhbmdlZEV2ZW50ID0ge1xyXG4gIHZpZXdwb3J0OiBHZW9NYXBWaWV3cG9ydDtcclxuICBvcmlnaW5hbEV2ZW50OiBhbnk7XHJcbn07XHJcblxyXG5leHBvcnQgdHlwZSBNYXBJdGVtQ2xpY2tlZEV2ZW50ID0ge1xyXG4gIGl0ZW1JZDogc3RyaW5nO1xyXG4gIG9yaWdpbmFsRXZlbnQ6IGFueTtcclxufTtcclxuXHJcbmV4cG9ydCB0eXBlIE1hcENsaWNrZWRFdmVudCA9IHtcclxuICBjb29yZGluYXRlczogR1BTUG9zaXRpb247XHJcbiAgb3JpZ2luYWxFdmVudDogYW55O1xyXG59O1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBDb29yZCB7XHJcbiAgeDogbnVtYmVyO1xyXG4gIHk6IG51bWJlcjtcclxufVxyXG4iXX0=
|
package/esm2022/projects.mjs
CHANGED
|
@@ -23,4 +23,5 @@ export * from './lib/smart-tree/projects';
|
|
|
23
23
|
export * from './lib/view-context/projects';
|
|
24
24
|
export * from './lib/smart-filter-editor/project';
|
|
25
25
|
export * from './lib/shared/projects';
|
|
26
|
-
|
|
26
|
+
export * from './lib/smart-map/projects';
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvamVjdHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wcm9qZWN0cy9zbWFydC1uZy1jbGllbnQvc3JjL3Byb2plY3RzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsc0VBQXNFLENBQUM7QUFDckYsY0FBYyw2QkFBNkIsQ0FBQztBQUU1QyxjQUFjLDBDQUEwQyxDQUFDO0FBQ3pELGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLDBCQUEwQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIHNtYXJ0LW5nLWNsaWVudFxyXG4gKi9cclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NtYXJ0LW5nLWNsaWVudC5zZXJ2aWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvc21hcnQtbmctY2xpZW50Lm1vZHVsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NtYXJ0LWNsaWVudC9zbWFydC1maWxlLXVwbG9hZGVyL3NtYXJ0LWZpbGUtdXBsb2FkZXIuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvc21hcnQtY2xpZW50L3Byb2plY3RzJztcclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudC1mYWN0b3J5LXNlcnZpY2UvcHJvamVjdHMnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZXNzaW9uL3Byb2plY3RzJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvc21hcnQtY29tcG9uZW50LWxheW91dC9wcm9qZWN0cyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NtYXJ0LWRpYWxvZy9wcm9qZWN0cyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NtYXJ0LWV4cGFuZGFibGUtc2VjdGlvbi9wcm9qZWN0cyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NtYXJ0LWZpbHRlci9wcm9qZWN0cyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NtYXJ0LWZvcm0vcHJvamVjdHMnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zbWFydC1ncmlkL3Byb2plY3RzJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvc21hcnQtaWNvbi9wcm9qZWN0cyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NtYXJ0LW5hdmJhci9wcm9qZWN0cyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NtYXJ0LW5hdmlnYXRpb24vcHJvamVjdHMnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zbWFydC1zdWJqZWN0L3Byb2plY3RzJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvc21hcnQtdGFiLWdyb3VwL3Byb2plY3RzJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvc21hcnQtdGFibGUvcHJvamVjdHMnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zbWFydC10cmVlL3Byb2plY3RzJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvdmlldy1jb250ZXh0L3Byb2plY3RzJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvc21hcnQtZmlsdGVyLWVkaXRvci9wcm9qZWN0JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvc2hhcmVkL3Byb2plY3RzJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvc21hcnQtbWFwL3Byb2plY3RzJztcclxuIl19
|