@kando-env/kando-ui 1.2.398-alpha.9 → 1.2.399
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/lib/Widgets/Map/MapUtils.js +1 -2
- package/lib/Widgets/Map/points/PointIcon.js +2 -3
- package/lib/Widgets/Map/points/PointIcon.scss +0 -13
- package/lib/components/Sector/Sector.js +4 -1
- package/lib/i18n/en.json +1 -2
- package/lib/macros/getVersion.js +2 -2
- package/lib/pages/EventsPage/EventsMapContainer/EventsMapContainer.js +3 -3
- package/lib/pages/OperationsPage/LeftPanel.js +3 -34
- package/lib/pages/OperationsPage/Map/useMap.js +47 -69
- package/lib/pages/OperationsPage/OperationsPage.js +16 -8
- package/lib/pages/OperationsPage/OperationsPage.scss +18 -29
- package/lib/pages/OperationsPage/RightPanel.js +5 -13
- package/lib/pages/PollutionRiskAssessment/Map.scss +0 -14
- package/lib/pages/PollutionRiskAssessment/SearchButton.js +3 -3
- package/lib/store/points/actions.js +2 -10
- package/lib/store/points/models/IPoint.js +1 -1
- package/lib/utilities/map/icons.js +3 -7
- package/package.json +1 -1
- package/lib/store/points/models/IDevice.js +0 -6
|
@@ -20,14 +20,9 @@ var useMap = function useMap(mapRef, points, edges, areas, selectedPoint, update
|
|
|
20
20
|
_useState4 = (0, _slicedToArray2.default)(_useState3, 2),
|
|
21
21
|
focusedMarker = _useState4[0],
|
|
22
22
|
setFocusedMarker = _useState4[1];
|
|
23
|
-
var focusedMarkerRef = (0, _react.useRef)(null);
|
|
24
23
|
var pointsLayerRef = (0, _react.useRef)();
|
|
25
24
|
var edgesLayerRef = (0, _react.useRef)();
|
|
26
25
|
var areasLayerRef = (0, _react.useRef)();
|
|
27
|
-
(0, _react.useEffect)(function () {
|
|
28
|
-
focusedMarkerRef.current = focusedMarker;
|
|
29
|
-
resetAllOthers();
|
|
30
|
-
}, [focusedMarker]);
|
|
31
26
|
(0, _react.useEffect)(function () {
|
|
32
27
|
if (!mapRef.current) {
|
|
33
28
|
return;
|
|
@@ -49,27 +44,18 @@ var useMap = function useMap(mapRef, points, edges, areas, selectedPoint, update
|
|
|
49
44
|
mapTemp.remove();
|
|
50
45
|
};
|
|
51
46
|
}, []);
|
|
52
|
-
|
|
47
|
+
(0, _react.useEffect)(function () {
|
|
53
48
|
var _pointsLayerRef$curre;
|
|
49
|
+
if (focusedMarker) {
|
|
50
|
+
focusedMarker.fire('mouseout');
|
|
51
|
+
}
|
|
54
52
|
(_pointsLayerRef$curre = pointsLayerRef.current) === null || _pointsLayerRef$curre === void 0 ? void 0 : _pointsLayerRef$curre.eachLayer(function (marker) {
|
|
55
|
-
if (marker.options.kando_object_id
|
|
56
|
-
marker.fire('
|
|
53
|
+
if (selectedPoint && marker.options.kando_object_id === (selectedPoint === null || selectedPoint === void 0 ? void 0 : selectedPoint.id)) {
|
|
54
|
+
marker.fire('mouseover');
|
|
55
|
+
setFocusedMarker(marker);
|
|
56
|
+
return;
|
|
57
57
|
}
|
|
58
58
|
});
|
|
59
|
-
};
|
|
60
|
-
(0, _react.useEffect)(function () {
|
|
61
|
-
if (selectedPoint === null) {
|
|
62
|
-
setFocusedMarker(null);
|
|
63
|
-
} else {
|
|
64
|
-
var _pointsLayerRef$curre2;
|
|
65
|
-
(_pointsLayerRef$curre2 = pointsLayerRef.current) === null || _pointsLayerRef$curre2 === void 0 ? void 0 : _pointsLayerRef$curre2.eachLayer(function (marker) {
|
|
66
|
-
if (selectedPoint && marker.options.kando_object_id === (selectedPoint === null || selectedPoint === void 0 ? void 0 : selectedPoint.id)) {
|
|
67
|
-
marker.fire('mouseover');
|
|
68
|
-
setFocusedMarker(marker);
|
|
69
|
-
return;
|
|
70
|
-
}
|
|
71
|
-
});
|
|
72
|
-
}
|
|
73
59
|
}, [selectedPoint]);
|
|
74
60
|
var handleMarkerClick = function handleMarkerClick(point) {
|
|
75
61
|
updateSelectedPoint(point);
|
|
@@ -87,15 +73,14 @@ var useMap = function useMap(mapRef, points, edges, areas, selectedPoint, update
|
|
|
87
73
|
pointsLayerRef.current.addTo(map);
|
|
88
74
|
if (!pointsLayerRef.current.getLayers().length) {
|
|
89
75
|
points.forEach(function (point) {
|
|
90
|
-
var
|
|
91
|
-
var icon = (0, _PointIcon.getPointIconByType)(type, point.name, '', false, true);
|
|
92
|
-
var focusedIcon = (0, _PointIcon.getPointIconByType)(type, point.name, '', true, false);
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
var marker = getMarker(point);
|
|
76
|
+
var _pointsLayerRef$curre2;
|
|
77
|
+
var icon = (0, _PointIcon.getPointIconByType)(point.group.type, point.name, '', false, true);
|
|
78
|
+
var focusedIcon = (0, _PointIcon.getPointIconByType)(point.group.type, point.name, '', true, false);
|
|
79
|
+
var marker = getMarker(point);
|
|
80
|
+
if (marker instanceof _leaflet.default.Marker) {
|
|
96
81
|
marker.setIcon(icon);
|
|
97
82
|
// The use of marker._isInside is to overcome the issue that mouseover is endlessly triggered
|
|
98
|
-
// and we need it
|
|
83
|
+
// and we need it onley once
|
|
99
84
|
marker.on('mouseover', function () {
|
|
100
85
|
if (!marker._isInside) {
|
|
101
86
|
marker._isInside = true;
|
|
@@ -103,30 +88,37 @@ var useMap = function useMap(mapRef, points, edges, areas, selectedPoint, update
|
|
|
103
88
|
}
|
|
104
89
|
});
|
|
105
90
|
marker.on('mouseout', function () {
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
marker._isInside = false;
|
|
109
|
-
marker.setIcon(icon);
|
|
110
|
-
}
|
|
111
|
-
});
|
|
112
|
-
marker.on('click', function () {
|
|
113
|
-
var _focusedMarkerRef$cur2;
|
|
114
|
-
if ((focusedMarkerRef === null || focusedMarkerRef === void 0 ? void 0 : (_focusedMarkerRef$cur2 = focusedMarkerRef.current) === null || _focusedMarkerRef$cur2 === void 0 ? void 0 : _focusedMarkerRef$cur2._leaflet_id) === (marker === null || marker === void 0 ? void 0 : marker._leaflet_id)) {
|
|
115
|
-
setFocusedMarker(null);
|
|
116
|
-
handleMarkerClick(null);
|
|
117
|
-
} else {
|
|
118
|
-
handleMarkerClick(point);
|
|
119
|
-
}
|
|
91
|
+
marker._isInside = false;
|
|
92
|
+
marker.setIcon(icon);
|
|
120
93
|
});
|
|
121
|
-
(_pointsLayerRef$curre3 = pointsLayerRef.current) === null || _pointsLayerRef$curre3 === void 0 ? void 0 : _pointsLayerRef$curre3.addLayer(marker);
|
|
122
94
|
}
|
|
95
|
+
marker.on('click', function () {
|
|
96
|
+
handleMarkerClick(point);
|
|
97
|
+
});
|
|
98
|
+
(_pointsLayerRef$curre2 = pointsLayerRef.current) === null || _pointsLayerRef$curre2 === void 0 ? void 0 : _pointsLayerRef$curre2.addLayer(marker);
|
|
123
99
|
});
|
|
124
100
|
}
|
|
101
|
+
if (pointsLayerRef.current.getLayers().length) {
|
|
102
|
+
map.fitBounds(pointsLayerRef.current.getBounds());
|
|
103
|
+
} else {
|
|
104
|
+
map.setView([32.219157, 34.982481], 12);
|
|
105
|
+
}
|
|
125
106
|
};
|
|
126
107
|
var getMarker = function getMarker(point) {
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
108
|
+
if (point.has_device === true || point.group.type === 'Groups::WastewaterTreatmentPlant') {
|
|
109
|
+
return _leaflet.default.marker([point.latitude, point.longitude], {
|
|
110
|
+
kando_object_id: point.id
|
|
111
|
+
});
|
|
112
|
+
} else {
|
|
113
|
+
return _leaflet.default.circleMarker([point.latitude, point.longitude], {
|
|
114
|
+
radius: 4,
|
|
115
|
+
color: '#000000',
|
|
116
|
+
weight: 1,
|
|
117
|
+
fillColor: '#ffffff',
|
|
118
|
+
fillOpacity: 1,
|
|
119
|
+
kando_object_id: point.id
|
|
120
|
+
});
|
|
121
|
+
}
|
|
130
122
|
};
|
|
131
123
|
var addEdges = function addEdges() {
|
|
132
124
|
if (!map || !edges) {
|
|
@@ -144,7 +136,7 @@ var useMap = function useMap(mapRef, points, edges, areas, selectedPoint, update
|
|
|
144
136
|
edgesLayerRef.current = _leaflet.default.featureGroup();
|
|
145
137
|
edgesLayerRef.current.addTo(map);
|
|
146
138
|
edges.forEach(function (edge) {
|
|
147
|
-
var _edgesLayerRef$curren
|
|
139
|
+
var _edgesLayerRef$curren;
|
|
148
140
|
var sourcePoint = pointLookup.get(edge.source_point_id);
|
|
149
141
|
var targetPoint = pointLookup.get(edge.target_point_id);
|
|
150
142
|
if (!sourcePoint || !targetPoint) {
|
|
@@ -174,7 +166,7 @@ var useMap = function useMap(mapRef, points, edges, areas, selectedPoint, update
|
|
|
174
166
|
})
|
|
175
167
|
}]
|
|
176
168
|
});
|
|
177
|
-
|
|
169
|
+
decorator.addTo(map);
|
|
178
170
|
});
|
|
179
171
|
};
|
|
180
172
|
var addAreas = function addAreas() {
|
|
@@ -195,9 +187,7 @@ var useMap = function useMap(mapRef, points, edges, areas, selectedPoint, update
|
|
|
195
187
|
if (area.shape_data.length > 0) {
|
|
196
188
|
allAreas.push(area);
|
|
197
189
|
}
|
|
198
|
-
|
|
199
|
-
// If there are sub_areas, recurse and concatenate
|
|
200
|
-
if (Array.isArray(area.sub_areas) && area.sub_areas.length > 0) {
|
|
190
|
+
if (area.sub_areas.length > 0) {
|
|
201
191
|
allAreas = allAreas.concat(flattenAreas(area.sub_areas));
|
|
202
192
|
}
|
|
203
193
|
});
|
|
@@ -222,24 +212,12 @@ var useMap = function useMap(mapRef, points, edges, areas, selectedPoint, update
|
|
|
222
212
|
(_areasLayerRef$curren = areasLayerRef.current) === null || _areasLayerRef$curren === void 0 ? void 0 : _areasLayerRef$curren.addLayer(polygon);
|
|
223
213
|
});
|
|
224
214
|
};
|
|
225
|
-
var focusMap = function focusMap() {
|
|
226
|
-
if (map) {
|
|
227
|
-
if ((pointsLayerRef === null || pointsLayerRef === void 0 ? void 0 : pointsLayerRef.current) && Array.isArray(pointsLayerRef.current.getLayers()) && pointsLayerRef.current.getLayers().length > 0) {
|
|
228
|
-
map.fitBounds(pointsLayerRef.current.getBounds());
|
|
229
|
-
} else {
|
|
230
|
-
map.setView([32.219157, 34.982481], 12);
|
|
231
|
-
}
|
|
232
|
-
}
|
|
233
|
-
};
|
|
234
215
|
(0, _react.useEffect)(function () {
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
focusMap();
|
|
240
|
-
}
|
|
241
|
-
}, [points, areas, edges, map]);
|
|
216
|
+
addAreas();
|
|
217
|
+
addMarkers();
|
|
218
|
+
addEdges();
|
|
219
|
+
}, [points, map]);
|
|
242
220
|
return map;
|
|
243
221
|
};
|
|
244
222
|
exports.useMap = useMap;
|
|
245
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_leaflet","_interopRequireDefault","require","_react","_PointIcon","_theme","_MapUtils","useMap","mapRef","points","edges","areas","selectedPoint","updateSelectedPoint","_useState","useState","_useState2","_slicedToArray2","default","map","setMap","_useState3","_useState4","focusedMarker","setFocusedMarker","focusedMarkerRef","useRef","pointsLayerRef","edgesLayerRef","areasLayerRef","useEffect","current","resetAllOthers","mapTypes","baseMaps","leafletMap","mapDefault","satellite","mapTemp","L","renderer","canvas","Object","values","addTo","control","layers","position","off","remove","_pointsLayerRef$curre","eachLayer","marker","options","kando_object_id","id","_isInside","fire","_pointsLayerRef$curre2","handleMarkerClick","point","addMarkers","hasLayer","removeLayer","featureGroup","getLayers","length","forEach","type","has_device","group","icon","getPointIconByType","name","focusedIcon","latitude","longitude","_pointsLayerRef$curre3","getMarker","setIcon","on","_focusedMarkerRef$cur","_leaflet_id","_focusedMarkerRef$cur2","addLayer","addEdges","pointLookup","Map","p","set","edge","_edgesLayerRef$curren","_edgesLayerRef$curren2","sourcePoint","get","source_point_id","targetPoint","target_point_id","latlngs","polyline","color","weight","opacity","smoothFactor","decorator","polylineDecorator","patterns","offset","repeat","symbol","Symbol","arrowHead","pixelSize","polygon","pathOptions","stroke","addAreas","flattenAreas","arguments","undefined","allAreas","area","shape_data","push","Array","isArray","sub_areas","concat","_areasLayerRef$curren","interactive","area_id","bindTooltip","area_name","permanent","direction","className","focusMap","fitBounds","getBounds","setView","exports"],"sources":["../../../../src/pages/OperationsPage/Map/useMap.tsx"],"sourcesContent":["import L, { Marker } from 'leaflet';\nimport React, { useEffect, useRef, useState } from 'react';\nimport { getPointIconByType } from 'src/Widgets/Map/points/PointIcon';\nimport { leafletMap } from 'src/styles/theme/theme';\nimport { baseMaps } from 'src/Widgets/Map/MapUtils';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport { IEdge } from 'src/store/edges/models/IEdge';\nimport { IArea } from 'src/store/areas/models/IArea';\n\nexport const useMap = (\n  mapRef: React.RefObject<HTMLDivElement>,\n  points: IPoint[],\n  edges: IEdge[],\n  areas: IArea[],\n  selectedPoint: IPoint | null,\n  updateSelectedPoint: (point: IPoint) => void,\n): L.Map | undefined => {\n  const [map, setMap] = useState<L.Map>();\n  const [focusedMarker, setFocusedMarker] = useState<Marker | null>(null);\n  const focusedMarkerRef = useRef<Marker | null>(null);\n  const pointsLayerRef = useRef<L.FeatureGroup>();\n  const edgesLayerRef = useRef<L.FeatureGroup>();\n  const areasLayerRef = useRef<L.FeatureGroup>();\n\n  useEffect(() => {\n    focusedMarkerRef.current = focusedMarker;\n    resetAllOthers();\n  }, [focusedMarker]);\n\n  useEffect(() => {\n    if (!mapRef.current) {\n      return;\n    }\n\n    const mapTypes = baseMaps(leafletMap.mapDefault, leafletMap.satellite);\n    const mapTemp = L.map(mapRef.current, { renderer: L.canvas() });\n\n    Object.values(mapTypes)[0].addTo(mapTemp);\n\n    L.control.layers(mapTypes, {}, { position: 'bottomright' }).addTo(mapTemp);\n\n    setMap(mapTemp);\n\n    return () => {\n      if (!mapTemp) {\n        return;\n      }\n      mapTemp.off();\n      mapTemp.remove();\n    };\n  }, []);\n\n  const resetAllOthers = () => {\n    pointsLayerRef.current?.eachLayer((marker) => {\n      if (\n        marker.options.kando_object_id !== selectedPoint?.id &&\n        marker._isInside\n      ) {\n        marker.fire('mouseout');\n      }\n    });\n  };\n\n  useEffect(() => {\n    if (selectedPoint === null) {\n      setFocusedMarker(null);\n    } else {\n      pointsLayerRef.current?.eachLayer((marker) => {\n        if (\n          selectedPoint &&\n          marker.options.kando_object_id === selectedPoint?.id\n        ) {\n          marker.fire('mouseover');\n          setFocusedMarker(marker);\n          return;\n        }\n      });\n    }\n  }, [selectedPoint]);\n\n  const handleMarkerClick = (point) => {\n    updateSelectedPoint(point);\n  };\n\n  const addMarkers = () => {\n    if (!map || !points) {\n      return;\n    }\n\n    if (pointsLayerRef.current) {\n      if (map.hasLayer(pointsLayerRef.current)) {\n        map.removeLayer(pointsLayerRef.current);\n      }\n    }\n\n    pointsLayerRef.current = L.featureGroup();\n    pointsLayerRef.current.addTo(map);\n\n    if (!pointsLayerRef.current.getLayers().length) {\n      points.forEach((point) => {\n        const type =\n          point.has_device === true ||\n          point.group.type === 'Groups::WastewaterTreatmentPlant'\n            ? point.group.type\n            : 'Groups::default';\n        const icon = getPointIconByType(type, point.name, '', false, true);\n\n        const focusedIcon = getPointIconByType(\n          type,\n          point.name,\n          '',\n          true,\n          false,\n        );\n\n        if (point.latitude && point.longitude) {\n          let marker = getMarker(point);\n\n          marker.setIcon(icon);\n          // The use of marker._isInside is to overcome the issue that mouseover is endlessly triggered\n          // and we need it only once\n          marker.on('mouseover', () => {\n            if (!marker._isInside) {\n              marker._isInside = true;\n              marker.setIcon(focusedIcon);\n            }\n          });\n\n          marker.on('mouseout', () => {\n            if (\n              focusedMarkerRef?.current?._leaflet_id !== marker?._leaflet_id\n            ) {\n              marker._isInside = false;\n              marker.setIcon(icon);\n            }\n          });\n\n          marker.on('click', () => {\n            if (\n              focusedMarkerRef?.current?._leaflet_id === marker?._leaflet_id\n            ) {\n              setFocusedMarker(null);\n              handleMarkerClick(null);\n            } else {\n              handleMarkerClick(point);\n            }\n          });\n\n          pointsLayerRef.current?.addLayer(marker);\n        }\n      });\n    }\n  };\n\n  const getMarker = (point: IPoint) => {\n    return L.marker([point.latitude, point.longitude], {\n      kando_object_id: point.id,\n    });\n  };\n\n  const addEdges = () => {\n    if (!map || !edges) {\n      return;\n    }\n\n    const pointLookup = new Map();\n    points.forEach((p) => pointLookup.set(p.id, p));\n\n    if (edgesLayerRef.current) {\n      if (map.hasLayer(edgesLayerRef.current)) {\n        map.removeLayer(edgesLayerRef.current);\n      }\n    }\n\n    edgesLayerRef.current = L.featureGroup();\n    edgesLayerRef.current.addTo(map);\n\n    edges.forEach((edge) => {\n      const sourcePoint = pointLookup.get(edge.source_point_id);\n      const targetPoint = pointLookup.get(edge.target_point_id);\n\n      if (!sourcePoint || !targetPoint) {\n        return;\n      }\n\n      const latlngs = [\n        [sourcePoint?.latitude, sourcePoint?.longitude],\n        [targetPoint?.latitude, targetPoint?.longitude],\n      ];\n\n      const polyline = L.polyline(latlngs, {\n        color: 'black',\n        weight: 1,\n        opacity: 0.5,\n        smoothFactor: 1,\n      });\n\n      edgesLayerRef.current?.addLayer(polyline);\n\n      const decorator = L.polylineDecorator(polyline, {\n        patterns: [\n          {\n            offset: 20,\n            repeat: 60,\n            symbol: L.Symbol.arrowHead({\n              pixelSize: 4,\n              polygon: false,\n              pathOptions: {\n                stroke: true,\n                color: '#555',\n                weight: 1,\n                opacity: 0.8,\n              },\n            }),\n          },\n        ],\n      });\n\n      edgesLayerRef.current?.addLayer(decorator);\n    });\n  };\n\n  const addAreas = () => {\n    if (!map || !areas) {\n      return;\n    }\n\n    if (areasLayerRef.current) {\n      if (map.hasLayer(areasLayerRef.current)) {\n        map.removeLayer(areasLayerRef.current);\n      }\n    }\n\n    areasLayerRef.current = L.featureGroup();\n    areasLayerRef.current.addTo(map);\n\n    const flattenAreas = (areas: IArea[] = []): IArea[] => {\n      let allAreas: IArea[] = [];\n\n      areas.forEach((area: IArea) => {\n        if (area.shape_data.length > 0) {\n          allAreas.push(area);\n        }\n\n        // If there are sub_areas, recurse and concatenate\n        if (Array.isArray(area.sub_areas) && area.sub_areas.length > 0) {\n          allAreas = allAreas.concat(flattenAreas(area.sub_areas));\n        }\n      });\n\n      return allAreas;\n    };\n\n    const allAreas = flattenAreas(areas);\n\n    allAreas.forEach((area) => {\n      const polygon = L.polygon(area.shape_data, {\n        color: 'black',\n        weight: 1,\n        opacity: 0.8,\n        smoothFactor: 1,\n        interactive: false,\n        kando_object_id: area.area_id,\n      });\n\n      polygon.bindTooltip(area.area_name, {\n        permanent: true,\n        direction: 'center',\n        className: 'area-tooltip',\n      });\n\n      areasLayerRef.current?.addLayer(polygon);\n    });\n  };\n\n  const focusMap = () => {\n    if (map) {\n      if (\n        pointsLayerRef?.current &&\n        Array.isArray(pointsLayerRef.current.getLayers()) &&\n        pointsLayerRef.current.getLayers().length > 0\n      ) {\n        map.fitBounds(pointsLayerRef.current.getBounds());\n      } else {\n        map.setView([32.219157, 34.982481], 12);\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (map) {\n      addAreas();\n      addEdges();\n      addMarkers();\n      focusMap();\n    }\n  }, [points, areas, edges, map]);\n\n  return map;\n};\n"],"mappings":"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"}
|
|
223
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_leaflet","_interopRequireDefault","require","_react","_PointIcon","_theme","_MapUtils","useMap","mapRef","points","edges","areas","selectedPoint","updateSelectedPoint","_useState","useState","_useState2","_slicedToArray2","default","map","setMap","_useState3","_useState4","focusedMarker","setFocusedMarker","pointsLayerRef","useRef","edgesLayerRef","areasLayerRef","useEffect","current","mapTypes","baseMaps","leafletMap","mapDefault","satellite","mapTemp","L","renderer","canvas","Object","values","addTo","control","layers","position","off","remove","_pointsLayerRef$curre","fire","eachLayer","marker","options","kando_object_id","id","handleMarkerClick","point","addMarkers","hasLayer","removeLayer","featureGroup","getLayers","length","forEach","_pointsLayerRef$curre2","icon","getPointIconByType","group","type","name","focusedIcon","getMarker","Marker","setIcon","on","_isInside","addLayer","fitBounds","getBounds","setView","has_device","latitude","longitude","circleMarker","radius","color","weight","fillColor","fillOpacity","addEdges","pointLookup","Map","p","set","edge","_edgesLayerRef$curren","sourcePoint","get","source_point_id","targetPoint","target_point_id","latlngs","polyline","opacity","smoothFactor","decorator","polylineDecorator","patterns","offset","repeat","symbol","Symbol","arrowHead","pixelSize","polygon","pathOptions","stroke","addAreas","flattenAreas","arguments","undefined","allAreas","area","shape_data","push","sub_areas","concat","_areasLayerRef$curren","interactive","area_id","bindTooltip","area_name","permanent","direction","className","exports"],"sources":["../../../../src/pages/OperationsPage/Map/useMap.tsx"],"sourcesContent":["import L, { Marker } from 'leaflet';\nimport React, { useEffect, useRef, useState } from 'react';\nimport { getPointIconByType } from 'src/Widgets/Map/points/PointIcon';\nimport { leafletMap } from 'src/styles/theme/theme';\nimport { baseMaps } from 'src/Widgets/Map/MapUtils';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport { IEdge } from 'src/store/edges/models/IEdge';\nimport { IArea } from 'src/store/areas/models/IArea';\n\nexport const useMap = (\n  mapRef: React.RefObject<HTMLDivElement>,\n  points: IPoint[],\n  edges: IEdge[],\n  areas: IArea[],\n  selectedPoint: IPoint | null,\n  updateSelectedPoint: (point: IPoint) => void,\n): L.Map | undefined => {\n  const [map, setMap] = useState<L.Map>();\n  const [focusedMarker, setFocusedMarker] = useState<Marker | null>(null);\n  const pointsLayerRef = useRef<L.FeatureGroup>();\n  const edgesLayerRef = useRef<L.FeatureGroup>();\n  const areasLayerRef = useRef<L.FeatureGroup>();\n\n  useEffect(() => {\n    if (!mapRef.current) {\n      return;\n    }\n\n    const mapTypes = baseMaps(leafletMap.mapDefault, leafletMap.satellite);\n    const mapTemp = L.map(mapRef.current, { renderer: L.canvas() });\n\n    Object.values(mapTypes)[0].addTo(mapTemp);\n\n    L.control.layers(mapTypes, {}, { position: 'bottomright' }).addTo(mapTemp);\n\n    setMap(mapTemp);\n\n    return () => {\n      if (!mapTemp) {\n        return;\n      }\n      mapTemp.off();\n      mapTemp.remove();\n    };\n  }, []);\n\n  useEffect(() => {\n    if (focusedMarker) {\n      focusedMarker.fire('mouseout');\n    }\n\n    pointsLayerRef.current?.eachLayer((marker) => {\n      if (\n        selectedPoint &&\n        marker.options.kando_object_id === selectedPoint?.id\n      ) {\n        marker.fire('mouseover');\n        setFocusedMarker(marker);\n        return;\n      }\n    });\n  }, [selectedPoint]);\n\n  const handleMarkerClick = (point) => {\n    updateSelectedPoint(point);\n  };\n\n  const addMarkers = () => {\n    if (!map || !points) {\n      return;\n    }\n\n    if (pointsLayerRef.current) {\n      if (map.hasLayer(pointsLayerRef.current)) {\n        map.removeLayer(pointsLayerRef.current);\n      }\n    }\n\n    pointsLayerRef.current = L.featureGroup();\n    pointsLayerRef.current.addTo(map);\n\n    if (!pointsLayerRef.current.getLayers().length) {\n      points.forEach((point) => {\n        const icon = getPointIconByType(\n          point.group.type,\n          point.name,\n          '',\n          false,\n          true,\n        );\n\n        const focusedIcon = getPointIconByType(\n          point.group.type,\n          point.name,\n          '',\n          true,\n          false,\n        );\n\n        let marker = getMarker(point);\n\n        if (marker instanceof L.Marker) {\n          marker.setIcon(icon);\n          // The use of marker._isInside is to overcome the issue that mouseover is endlessly triggered\n          // and we need it onley once\n          marker.on('mouseover', () => {\n            if (!marker._isInside) {\n              marker._isInside = true;\n              marker.setIcon(focusedIcon);\n            }\n          });\n          marker.on('mouseout', () => {\n            marker._isInside = false;\n            marker.setIcon(icon);\n          });\n        }\n\n        marker.on('click', () => {\n          handleMarkerClick(point);\n        });\n\n        pointsLayerRef.current?.addLayer(marker);\n      });\n    }\n\n    if (pointsLayerRef.current.getLayers().length) {\n      map.fitBounds(pointsLayerRef.current.getBounds());\n    } else {\n      map.setView([32.219157, 34.982481], 12);\n    }\n  };\n\n  const getMarker = (point: IPoint) => {\n    if (\n      point.has_device === true ||\n      point.group.type === 'Groups::WastewaterTreatmentPlant'\n    ) {\n      return L.marker([point.latitude, point.longitude], {\n        kando_object_id: point.id,\n      });\n    } else {\n      return L.circleMarker([point.latitude, point.longitude], {\n        radius: 4,\n        color: '#000000',\n        weight: 1,\n        fillColor: '#ffffff',\n        fillOpacity: 1,\n        kando_object_id: point.id,\n      });\n    }\n  };\n\n  const addEdges = () => {\n    if (!map || !edges) {\n      return;\n    }\n\n    const pointLookup = new Map();\n    points.forEach((p) => pointLookup.set(p.id, p));\n\n    if (edgesLayerRef.current) {\n      if (map.hasLayer(edgesLayerRef.current)) {\n        map.removeLayer(edgesLayerRef.current);\n      }\n    }\n\n    edgesLayerRef.current = L.featureGroup();\n    edgesLayerRef.current.addTo(map);\n\n    edges.forEach((edge) => {\n      const sourcePoint = pointLookup.get(edge.source_point_id);\n      const targetPoint = pointLookup.get(edge.target_point_id);\n\n      if (!sourcePoint || !targetPoint) {\n        return;\n      }\n\n      const latlngs = [\n        [sourcePoint?.latitude, sourcePoint?.longitude],\n        [targetPoint?.latitude, targetPoint?.longitude],\n      ];\n\n      const polyline = L.polyline(latlngs, {\n        color: 'black',\n        weight: 1,\n        opacity: 0.5,\n        smoothFactor: 1,\n      });\n\n      edgesLayerRef.current?.addLayer(polyline);\n\n      const decorator = L.polylineDecorator(polyline, {\n        patterns: [\n          {\n            offset: 20,\n            repeat: 60,\n            symbol: L.Symbol.arrowHead({\n              pixelSize: 4,\n              polygon: false,\n              pathOptions: {\n                stroke: true,\n                color: '#555',\n                weight: 1,\n                opacity: 0.8,\n              },\n            }),\n          },\n        ],\n      });\n\n      decorator.addTo(map);\n    });\n  };\n\n  const addAreas = () => {\n    if (!map || !areas) {\n      return;\n    }\n\n    if (areasLayerRef.current) {\n      if (map.hasLayer(areasLayerRef.current)) {\n        map.removeLayer(areasLayerRef.current);\n      }\n    }\n\n    areasLayerRef.current = L.featureGroup();\n    areasLayerRef.current.addTo(map);\n\n    const flattenAreas = (areas: IArea[] = []): IArea[] => {\n      let allAreas: IArea[] = [];\n\n      areas.forEach((area: IArea) => {\n        if (area.shape_data.length > 0) {\n          allAreas.push(area);\n        }\n\n        if (area.sub_areas.length > 0) {\n          allAreas = allAreas.concat(flattenAreas(area.sub_areas));\n        }\n      });\n\n      return allAreas;\n    };\n\n    const allAreas = flattenAreas(areas);\n\n    allAreas.forEach((area) => {\n      const polygon = L.polygon(area.shape_data, {\n        color: 'black',\n        weight: 1,\n        opacity: 0.8,\n        smoothFactor: 1,\n        interactive: false,\n        kando_object_id: area.area_id,\n      });\n\n      polygon.bindTooltip(area.area_name, {\n        permanent: true,\n        direction: 'center',\n        className: 'area-tooltip',\n      });\n\n      areasLayerRef.current?.addLayer(polygon);\n    });\n  };\n\n  useEffect(() => {\n    addAreas();\n    addMarkers();\n    addEdges();\n  }, [points, map]);\n\n  return map;\n};\n"],"mappings":";;;;;;;;AAAA,IAAAA,QAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,MAAA,GAAAD,OAAA;AACA,IAAAE,UAAA,GAAAF,OAAA;AACA,IAAAG,MAAA,GAAAH,OAAA;AACA,IAAAI,SAAA,GAAAJ,OAAA;AAKO,IAAMK,MAAM,GAAG,SAATA,MAAMA,CACjBC,MAAuC,EACvCC,MAAgB,EAChBC,KAAc,EACdC,KAAc,EACdC,aAA4B,EAC5BC,mBAA4C,EACtB;EACtB,IAAAC,SAAA,GAAsB,IAAAC,eAAQ,EAAQ,CAAC;IAAAC,UAAA,OAAAC,eAAA,CAAAC,OAAA,EAAAJ,SAAA;IAAhCK,GAAG,GAAAH,UAAA;IAAEI,MAAM,GAAAJ,UAAA;EAClB,IAAAK,UAAA,GAA0C,IAAAN,eAAQ,EAAgB,IAAI,CAAC;IAAAO,UAAA,OAAAL,eAAA,CAAAC,OAAA,EAAAG,UAAA;IAAhEE,aAAa,GAAAD,UAAA;IAAEE,gBAAgB,GAAAF,UAAA;EACtC,IAAMG,cAAc,GAAG,IAAAC,aAAM,EAAiB,CAAC;EAC/C,IAAMC,aAAa,GAAG,IAAAD,aAAM,EAAiB,CAAC;EAC9C,IAAME,aAAa,GAAG,IAAAF,aAAM,EAAiB,CAAC;EAE9C,IAAAG,gBAAS,EAAC,YAAM;IACd,IAAI,CAACrB,MAAM,CAACsB,OAAO,EAAE;MACnB;IACF;IAEA,IAAMC,QAAQ,GAAG,IAAAC,kBAAQ,EAACC,iBAAU,CAACC,UAAU,EAAED,iBAAU,CAACE,SAAS,CAAC;IACtE,IAAMC,OAAO,GAAGC,gBAAC,CAAClB,GAAG,CAACX,MAAM,CAACsB,OAAO,EAAE;MAAEQ,QAAQ,EAAED,gBAAC,CAACE,MAAM,CAAC;IAAE,CAAC,CAAC;IAE/DC,MAAM,CAACC,MAAM,CAACV,QAAQ,CAAC,CAAC,CAAC,CAAC,CAACW,KAAK,CAACN,OAAO,CAAC;IAEzCC,gBAAC,CAACM,OAAO,CAACC,MAAM,CAACb,QAAQ,EAAE,CAAC,CAAC,EAAE;MAAEc,QAAQ,EAAE;IAAc,CAAC,CAAC,CAACH,KAAK,CAACN,OAAO,CAAC;IAE1EhB,MAAM,CAACgB,OAAO,CAAC;IAEf,OAAO,YAAM;MACX,IAAI,CAACA,OAAO,EAAE;QACZ;MACF;MACAA,OAAO,CAACU,GAAG,CAAC,CAAC;MACbV,OAAO,CAACW,MAAM,CAAC,CAAC;IAClB,CAAC;EACH,CAAC,EAAE,EAAE,CAAC;EAEN,IAAAlB,gBAAS,EAAC,YAAM;IAAA,IAAAmB,qBAAA;IACd,IAAIzB,aAAa,EAAE;MACjBA,aAAa,CAAC0B,IAAI,CAAC,UAAU,CAAC;IAChC;IAEA,CAAAD,qBAAA,GAAAvB,cAAc,CAACK,OAAO,cAAAkB,qBAAA,uBAAtBA,qBAAA,CAAwBE,SAAS,CAAC,UAACC,MAAM,EAAK;MAC5C,IACEvC,aAAa,IACbuC,MAAM,CAACC,OAAO,CAACC,eAAe,MAAKzC,aAAa,aAAbA,aAAa,uBAAbA,aAAa,CAAE0C,EAAE,GACpD;QACAH,MAAM,CAACF,IAAI,CAAC,WAAW,CAAC;QACxBzB,gBAAgB,CAAC2B,MAAM,CAAC;QACxB;MACF;IACF,CAAC,CAAC;EACJ,CAAC,EAAE,CAACvC,aAAa,CAAC,CAAC;EAEnB,IAAM2C,iBAAiB,GAAG,SAApBA,iBAAiBA,CAAIC,KAAK,EAAK;IACnC3C,mBAAmB,CAAC2C,KAAK,CAAC;EAC5B,CAAC;EAED,IAAMC,UAAU,GAAG,SAAbA,UAAUA,CAAA,EAAS;IACvB,IAAI,CAACtC,GAAG,IAAI,CAACV,MAAM,EAAE;MACnB;IACF;IAEA,IAAIgB,cAAc,CAACK,OAAO,EAAE;MAC1B,IAAIX,GAAG,CAACuC,QAAQ,CAACjC,cAAc,CAACK,OAAO,CAAC,EAAE;QACxCX,GAAG,CAACwC,WAAW,CAAClC,cAAc,CAACK,OAAO,CAAC;MACzC;IACF;IAEAL,cAAc,CAACK,OAAO,GAAGO,gBAAC,CAACuB,YAAY,CAAC,CAAC;IACzCnC,cAAc,CAACK,OAAO,CAACY,KAAK,CAACvB,GAAG,CAAC;IAEjC,IAAI,CAACM,cAAc,CAACK,OAAO,CAAC+B,SAAS,CAAC,CAAC,CAACC,MAAM,EAAE;MAC9CrD,MAAM,CAACsD,OAAO,CAAC,UAACP,KAAK,EAAK;QAAA,IAAAQ,sBAAA;QACxB,IAAMC,IAAI,GAAG,IAAAC,6BAAkB,EAC7BV,KAAK,CAACW,KAAK,CAACC,IAAI,EAChBZ,KAAK,CAACa,IAAI,EACV,EAAE,EACF,KAAK,EACL,IACF,CAAC;QAED,IAAMC,WAAW,GAAG,IAAAJ,6BAAkB,EACpCV,KAAK,CAACW,KAAK,CAACC,IAAI,EAChBZ,KAAK,CAACa,IAAI,EACV,EAAE,EACF,IAAI,EACJ,KACF,CAAC;QAED,IAAIlB,MAAM,GAAGoB,SAAS,CAACf,KAAK,CAAC;QAE7B,IAAIL,MAAM,YAAYd,gBAAC,CAACmC,MAAM,EAAE;UAC9BrB,MAAM,CAACsB,OAAO,CAACR,IAAI,CAAC;UACpB;UACA;UACAd,MAAM,CAACuB,EAAE,CAAC,WAAW,EAAE,YAAM;YAC3B,IAAI,CAACvB,MAAM,CAACwB,SAAS,EAAE;cACrBxB,MAAM,CAACwB,SAAS,GAAG,IAAI;cACvBxB,MAAM,CAACsB,OAAO,CAACH,WAAW,CAAC;YAC7B;UACF,CAAC,CAAC;UACFnB,MAAM,CAACuB,EAAE,CAAC,UAAU,EAAE,YAAM;YAC1BvB,MAAM,CAACwB,SAAS,GAAG,KAAK;YACxBxB,MAAM,CAACsB,OAAO,CAACR,IAAI,CAAC;UACtB,CAAC,CAAC;QACJ;QAEAd,MAAM,CAACuB,EAAE,CAAC,OAAO,EAAE,YAAM;UACvBnB,iBAAiB,CAACC,KAAK,CAAC;QAC1B,CAAC,CAAC;QAEF,CAAAQ,sBAAA,GAAAvC,cAAc,CAACK,OAAO,cAAAkC,sBAAA,uBAAtBA,sBAAA,CAAwBY,QAAQ,CAACzB,MAAM,CAAC;MAC1C,CAAC,CAAC;IACJ;IAEA,IAAI1B,cAAc,CAACK,OAAO,CAAC+B,SAAS,CAAC,CAAC,CAACC,MAAM,EAAE;MAC7C3C,GAAG,CAAC0D,SAAS,CAACpD,cAAc,CAACK,OAAO,CAACgD,SAAS,CAAC,CAAC,CAAC;IACnD,CAAC,MAAM;MACL3D,GAAG,CAAC4D,OAAO,CAAC,CAAC,SAAS,EAAE,SAAS,CAAC,EAAE,EAAE,CAAC;IACzC;EACF,CAAC;EAED,IAAMR,SAAS,GAAG,SAAZA,SAASA,CAAIf,KAAa,EAAK;IACnC,IACEA,KAAK,CAACwB,UAAU,KAAK,IAAI,IACzBxB,KAAK,CAACW,KAAK,CAACC,IAAI,KAAK,kCAAkC,EACvD;MACA,OAAO/B,gBAAC,CAACc,MAAM,CAAC,CAACK,KAAK,CAACyB,QAAQ,EAAEzB,KAAK,CAAC0B,SAAS,CAAC,EAAE;QACjD7B,eAAe,EAAEG,KAAK,CAACF;MACzB,CAAC,CAAC;IACJ,CAAC,MAAM;MACL,OAAOjB,gBAAC,CAAC8C,YAAY,CAAC,CAAC3B,KAAK,CAACyB,QAAQ,EAAEzB,KAAK,CAAC0B,SAAS,CAAC,EAAE;QACvDE,MAAM,EAAE,CAAC;QACTC,KAAK,EAAE,SAAS;QAChBC,MAAM,EAAE,CAAC;QACTC,SAAS,EAAE,SAAS;QACpBC,WAAW,EAAE,CAAC;QACdnC,eAAe,EAAEG,KAAK,CAACF;MACzB,CAAC,CAAC;IACJ;EACF,CAAC;EAED,IAAMmC,QAAQ,GAAG,SAAXA,QAAQA,CAAA,EAAS;IACrB,IAAI,CAACtE,GAAG,IAAI,CAACT,KAAK,EAAE;MAClB;IACF;IAEA,IAAMgF,WAAW,GAAG,IAAIC,GAAG,CAAC,CAAC;IAC7BlF,MAAM,CAACsD,OAAO,CAAC,UAAC6B,CAAC;MAAA,OAAKF,WAAW,CAACG,GAAG,CAACD,CAAC,CAACtC,EAAE,EAAEsC,CAAC,CAAC;IAAA,EAAC;IAE/C,IAAIjE,aAAa,CAACG,OAAO,EAAE;MACzB,IAAIX,GAAG,CAACuC,QAAQ,CAAC/B,aAAa,CAACG,OAAO,CAAC,EAAE;QACvCX,GAAG,CAACwC,WAAW,CAAChC,aAAa,CAACG,OAAO,CAAC;MACxC;IACF;IAEAH,aAAa,CAACG,OAAO,GAAGO,gBAAC,CAACuB,YAAY,CAAC,CAAC;IACxCjC,aAAa,CAACG,OAAO,CAACY,KAAK,CAACvB,GAAG,CAAC;IAEhCT,KAAK,CAACqD,OAAO,CAAC,UAAC+B,IAAI,EAAK;MAAA,IAAAC,qBAAA;MACtB,IAAMC,WAAW,GAAGN,WAAW,CAACO,GAAG,CAACH,IAAI,CAACI,eAAe,CAAC;MACzD,IAAMC,WAAW,GAAGT,WAAW,CAACO,GAAG,CAACH,IAAI,CAACM,eAAe,CAAC;MAEzD,IAAI,CAACJ,WAAW,IAAI,CAACG,WAAW,EAAE;QAChC;MACF;MAEA,IAAME,OAAO,GAAG,CACd,CAACL,WAAW,aAAXA,WAAW,uBAAXA,WAAW,CAAEf,QAAQ,EAAEe,WAAW,aAAXA,WAAW,uBAAXA,WAAW,CAAEd,SAAS,CAAC,EAC/C,CAACiB,WAAW,aAAXA,WAAW,uBAAXA,WAAW,CAAElB,QAAQ,EAAEkB,WAAW,aAAXA,WAAW,uBAAXA,WAAW,CAAEjB,SAAS,CAAC,CAChD;MAED,IAAMoB,QAAQ,GAAGjE,gBAAC,CAACiE,QAAQ,CAACD,OAAO,EAAE;QACnChB,KAAK,EAAE,OAAO;QACdC,MAAM,EAAE,CAAC;QACTiB,OAAO,EAAE,GAAG;QACZC,YAAY,EAAE;MAChB,CAAC,CAAC;MAEF,CAAAT,qBAAA,GAAApE,aAAa,CAACG,OAAO,cAAAiE,qBAAA,uBAArBA,qBAAA,CAAuBnB,QAAQ,CAAC0B,QAAQ,CAAC;MAEzC,IAAMG,SAAS,GAAGpE,gBAAC,CAACqE,iBAAiB,CAACJ,QAAQ,EAAE;QAC9CK,QAAQ,EAAE,CACR;UACEC,MAAM,EAAE,EAAE;UACVC,MAAM,EAAE,EAAE;UACVC,MAAM,EAAEzE,gBAAC,CAAC0E,MAAM,CAACC,SAAS,CAAC;YACzBC,SAAS,EAAE,CAAC;YACZC,OAAO,EAAE,KAAK;YACdC,WAAW,EAAE;cACXC,MAAM,EAAE,IAAI;cACZ/B,KAAK,EAAE,MAAM;cACbC,MAAM,EAAE,CAAC;cACTiB,OAAO,EAAE;YACX;UACF,CAAC;QACH,CAAC;MAEL,CAAC,CAAC;MAEFE,SAAS,CAAC/D,KAAK,CAACvB,GAAG,CAAC;IACtB,CAAC,CAAC;EACJ,CAAC;EAED,IAAMkG,QAAQ,GAAG,SAAXA,QAAQA,CAAA,EAAS;IACrB,IAAI,CAAClG,GAAG,IAAI,CAACR,KAAK,EAAE;MAClB;IACF;IAEA,IAAIiB,aAAa,CAACE,OAAO,EAAE;MACzB,IAAIX,GAAG,CAACuC,QAAQ,CAAC9B,aAAa,CAACE,OAAO,CAAC,EAAE;QACvCX,GAAG,CAACwC,WAAW,CAAC/B,aAAa,CAACE,OAAO,CAAC;MACxC;IACF;IAEAF,aAAa,CAACE,OAAO,GAAGO,gBAAC,CAACuB,YAAY,CAAC,CAAC;IACxChC,aAAa,CAACE,OAAO,CAACY,KAAK,CAACvB,GAAG,CAAC;IAEhC,IAAMmG,YAAY,GAAG,SAAfA,YAAYA,CAAA,EAAqC;MAAA,IAAjC3G,KAAc,GAAA4G,SAAA,CAAAzD,MAAA,QAAAyD,SAAA,QAAAC,SAAA,GAAAD,SAAA,MAAG,EAAE;MACvC,IAAIE,QAAiB,GAAG,EAAE;MAE1B9G,KAAK,CAACoD,OAAO,CAAC,UAAC2D,IAAW,EAAK;QAC7B,IAAIA,IAAI,CAACC,UAAU,CAAC7D,MAAM,GAAG,CAAC,EAAE;UAC9B2D,QAAQ,CAACG,IAAI,CAACF,IAAI,CAAC;QACrB;QAEA,IAAIA,IAAI,CAACG,SAAS,CAAC/D,MAAM,GAAG,CAAC,EAAE;UAC7B2D,QAAQ,GAAGA,QAAQ,CAACK,MAAM,CAACR,YAAY,CAACI,IAAI,CAACG,SAAS,CAAC,CAAC;QAC1D;MACF,CAAC,CAAC;MAEF,OAAOJ,QAAQ;IACjB,CAAC;IAED,IAAMA,QAAQ,GAAGH,YAAY,CAAC3G,KAAK,CAAC;IAEpC8G,QAAQ,CAAC1D,OAAO,CAAC,UAAC2D,IAAI,EAAK;MAAA,IAAAK,qBAAA;MACzB,IAAMb,OAAO,GAAG7E,gBAAC,CAAC6E,OAAO,CAACQ,IAAI,CAACC,UAAU,EAAE;QACzCtC,KAAK,EAAE,OAAO;QACdC,MAAM,EAAE,CAAC;QACTiB,OAAO,EAAE,GAAG;QACZC,YAAY,EAAE,CAAC;QACfwB,WAAW,EAAE,KAAK;QAClB3E,eAAe,EAAEqE,IAAI,CAACO;MACxB,CAAC,CAAC;MAEFf,OAAO,CAACgB,WAAW,CAACR,IAAI,CAACS,SAAS,EAAE;QAClCC,SAAS,EAAE,IAAI;QACfC,SAAS,EAAE,QAAQ;QACnBC,SAAS,EAAE;MACb,CAAC,CAAC;MAEF,CAAAP,qBAAA,GAAAnG,aAAa,CAACE,OAAO,cAAAiG,qBAAA,uBAArBA,qBAAA,CAAuBnD,QAAQ,CAACsC,OAAO,CAAC;IAC1C,CAAC,CAAC;EACJ,CAAC;EAED,IAAArF,gBAAS,EAAC,YAAM;IACdwF,QAAQ,CAAC,CAAC;IACV5D,UAAU,CAAC,CAAC;IACZgC,QAAQ,CAAC,CAAC;EACZ,CAAC,EAAE,CAAChF,MAAM,EAAEU,GAAG,CAAC,CAAC;EAEjB,OAAOA,GAAG;AACZ,CAAC;AAACoH,OAAA,CAAAhI,MAAA,GAAAA,MAAA"}
|
|
@@ -14,12 +14,11 @@ var _reactBootstrap = require("react-bootstrap");
|
|
|
14
14
|
var _actions = require("store/context/actions");
|
|
15
15
|
var _actions2 = require("store/points/actions");
|
|
16
16
|
var _actions3 = require("store/edges/actions");
|
|
17
|
-
var _actions4 = require("store/areas/actions");
|
|
18
17
|
var _Map = require("./Map/Map");
|
|
19
18
|
var _LeftPanel = _interopRequireDefault(require("./LeftPanel"));
|
|
20
19
|
var _RightPanel = _interopRequireDefault(require("./RightPanel"));
|
|
20
|
+
var _actions4 = require("store/areas/actions");
|
|
21
21
|
var _KandoAlert = require("ui-kit/Alert/KandoAlert");
|
|
22
|
-
var _Loader = require("../DashboardMap/Loader");
|
|
23
22
|
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
24
23
|
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
25
24
|
var OperationsPage = function OperationsPage() {
|
|
@@ -49,7 +48,7 @@ var OperationsPage = function OperationsPage() {
|
|
|
49
48
|
isSmallScreen = _useState6[0],
|
|
50
49
|
setIsSmallScreen = _useState6[1];
|
|
51
50
|
var handleSelectPoint = function handleSelectPoint(newPoint) {
|
|
52
|
-
if (
|
|
51
|
+
if (selectedPoint && newPoint.id === selectedPoint.id) {
|
|
53
52
|
setSelectedPoint(null);
|
|
54
53
|
} else {
|
|
55
54
|
setSelectedPoint(newPoint);
|
|
@@ -74,13 +73,12 @@ var OperationsPage = function OperationsPage() {
|
|
|
74
73
|
}, []);
|
|
75
74
|
(0, _react.useEffect)(function () {
|
|
76
75
|
if (global_data.waterAuthorityId) {
|
|
77
|
-
dispatch((0, _actions2.fetchPoints)(global_data.waterAuthorityId
|
|
76
|
+
dispatch((0, _actions2.fetchPoints)(global_data.waterAuthorityId));
|
|
78
77
|
dispatch((0, _actions3.fetchEdges)(global_data.waterAuthorityId));
|
|
79
78
|
dispatch((0, _actions4.fetchAreas)(global_data.waterAuthorityId));
|
|
80
79
|
}
|
|
81
80
|
return function () {
|
|
82
81
|
setSelectedPoint(null);
|
|
83
|
-
dispatch((0, _actions2.clearPoints)());
|
|
84
82
|
};
|
|
85
83
|
}, [global_data.waterAuthorityId]);
|
|
86
84
|
var points = (0, _react.useMemo)(function () {
|
|
@@ -98,7 +96,7 @@ var OperationsPage = function OperationsPage() {
|
|
|
98
96
|
return /*#__PURE__*/_react.default.createElement(_LeftPanel.default, {
|
|
99
97
|
points: monitoredPoints,
|
|
100
98
|
selectedPoint: selectedPoint,
|
|
101
|
-
setSelectedPoint:
|
|
99
|
+
setSelectedPoint: setSelectedPoint
|
|
102
100
|
});
|
|
103
101
|
}, [monitoredPoints, selectedPoint]);
|
|
104
102
|
(0, _react.useEffect)(function () {
|
|
@@ -111,6 +109,15 @@ var OperationsPage = function OperationsPage() {
|
|
|
111
109
|
var onRightPanelClose = function onRightPanelClose() {
|
|
112
110
|
setSelectedPoint(null);
|
|
113
111
|
};
|
|
112
|
+
var getDistance = function getDistance() {
|
|
113
|
+
if (selectedPoint && edges_data.items) {
|
|
114
|
+
var edge = edges_data.items.find(function (edge) {
|
|
115
|
+
return edge.source_point_id === selectedPoint.id;
|
|
116
|
+
});
|
|
117
|
+
return (edge === null || edge === void 0 ? void 0 : edge.distance) || 0;
|
|
118
|
+
}
|
|
119
|
+
return 0;
|
|
120
|
+
};
|
|
114
121
|
if (isSmallScreen) {
|
|
115
122
|
return /*#__PURE__*/_react.default.createElement(_KandoAlert.KandoAlert, {
|
|
116
123
|
variant: "success",
|
|
@@ -126,7 +133,7 @@ var OperationsPage = function OperationsPage() {
|
|
|
126
133
|
}, showLeftPanel), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Col, {
|
|
127
134
|
className: "map-column",
|
|
128
135
|
sm: 9
|
|
129
|
-
}, edges_data.isFetching
|
|
136
|
+
}, !edges_data.isFetching && !areas_data.isFetching && /*#__PURE__*/_react.default.createElement(_Map.Map, {
|
|
130
137
|
points: points,
|
|
131
138
|
edges: edges_data.items,
|
|
132
139
|
areas: areas_data.newAreas,
|
|
@@ -135,9 +142,10 @@ var OperationsPage = function OperationsPage() {
|
|
|
135
142
|
}), /*#__PURE__*/_react.default.createElement(_RightPanel.default, {
|
|
136
143
|
className: "right-panel ".concat(showRightPanel ? 'open' : ''),
|
|
137
144
|
point: selectedPoint,
|
|
145
|
+
distance: getDistance(),
|
|
138
146
|
onClose: onRightPanelClose
|
|
139
147
|
}))));
|
|
140
148
|
};
|
|
141
149
|
var _default = OperationsPage;
|
|
142
150
|
exports.default = _default;
|
|
143
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["require","_react","_interopRequireWildcard","_reactRedux","_reactBootstrap","_actions","_actions2","_actions3","_actions4","_Map","_LeftPanel","_interopRequireDefault","_RightPanel","_KandoAlert","_Loader","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","OperationsPage","dispatch","useDispatch","points_data","useSelector","state","edges_data","areas_data","global_data","_useState","useState","_useState2","_slicedToArray2","showRightPanel","setShowRightPanel","_useState3","_useState4","selectedPoint","setSelectedPoint","_useState5","_useState6","isSmallScreen","setIsSmallScreen","handleSelectPoint","newPoint","id","useEffect","updateNavContext","name","checkScreenSize","window","innerWidth","addEventListener","removeEventListener","waterAuthorityId","fetchPoints","fetchEdges","fetchAreas","clearPoints","points","useMemo","_points_data$items","items","filter","point","latitude","longitude","monitoredPoints","has_device","showLeftPanel","createElement","onRightPanelClose","KandoAlert","variant","header","Container","fluid","className","Row","Col","sm","isFetching","Loader","Map","edges","areas","newAreas","updateSelectedPoint","concat","onClose","_default","exports"],"sources":["../../../src/pages/OperationsPage/OperationsPage.tsx"],"sourcesContent":["import './OperationsPage.scss';\nimport React, { useEffect, useMemo, useState } from 'react';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { Col, Container, Row } from 'react-bootstrap';\nimport { updateNavContext } from 'src/store/context/actions';\nimport { clearPoints, fetchPoints } from 'src/store/points/actions';\nimport { fetchEdges } from 'src/store/edges/actions';\nimport { fetchAreas } from 'src/store/areas/actions';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport { Map } from './Map/Map';\nimport LeftPanel from './LeftPanel';\nimport RightPanel from './RightPanel';\nimport { KandoAlert } from 'src/ui-kit/Alert/KandoAlert';\nimport { Loader } from '../DashboardMap/Loader';\n\nconst OperationsPage: React.FC = () => {\n  const dispatch = useDispatch();\n  const points_data = useSelector((state) => state.points_data);\n  const edges_data = useSelector((state) => state.edges_data);\n  const areas_data = useSelector((state) => state.areas_data);\n  const global_data = useSelector((state) => state.global_data);\n  const [showRightPanel, setShowRightPanel] = useState(false);\n  const [selectedPoint, setSelectedPoint] = useState<IPoint | null>(null);\n  const [isSmallScreen, setIsSmallScreen] = useState(false);\n\n  const handleSelectPoint = (newPoint: IPoint) => {\n    if (newPoint === null || newPoint.id === selectedPoint?.id) {\n      setSelectedPoint(null);\n    } else {\n      setSelectedPoint(newPoint);\n    }\n  };\n\n  useEffect(() => {\n    dispatch(updateNavContext({ name: 'operations' }));\n\n    const checkScreenSize = () => {\n      setIsSmallScreen(window.innerWidth < 768); // or any breakpoint\n    };\n\n    // Run on mount:\n    checkScreenSize();\n\n    // Also update if the user resizes the browser:\n    window.addEventListener('resize', checkScreenSize);\n    return () => {\n      window.removeEventListener('resize', checkScreenSize);\n    };\n  }, []);\n\n  useEffect(() => {\n    if (global_data.waterAuthorityId) {\n      dispatch(fetchPoints(global_data.waterAuthorityId, '', true));\n      dispatch(fetchEdges(global_data.waterAuthorityId));\n      dispatch(fetchAreas(global_data.waterAuthorityId));\n    }\n\n    return () => {\n      setSelectedPoint(null);\n      dispatch(clearPoints());\n    };\n  }, [global_data.waterAuthorityId]);\n\n  const points = useMemo(() => {\n    return (\n      points_data.items?.filter(\n        (point: IPoint) => point.latitude && point.longitude,\n      ) || []\n    );\n  }, [points_data.items]);\n\n  const monitoredPoints = useMemo(() => {\n    return points.filter((point: IPoint) => point.has_device) || [];\n  }, [points]);\n\n  const showLeftPanel = useMemo(() => {\n    return (\n      <LeftPanel\n        points={monitoredPoints}\n        selectedPoint={selectedPoint}\n        setSelectedPoint={handleSelectPoint}\n      />\n    );\n  }, [monitoredPoints, selectedPoint]);\n\n  useEffect(() => {\n    if (selectedPoint) {\n      setShowRightPanel(true);\n    } else {\n      setShowRightPanel(false);\n    }\n  }, [selectedPoint]);\n\n  const onRightPanelClose = () => {\n    setSelectedPoint(null);\n  };\n\n  if (isSmallScreen) {\n    return (\n      <KandoAlert variant=\"success\" header=\"Notice\">\n        <h5>{'This page is not supported on small screens'}</h5>\n        <p>{'Please use a larger screen for the best experience.'}</p>\n      </KandoAlert>\n    );\n  }\n\n  return (\n    <Container fluid className=\"vh-90 p-0\">\n      <Row>\n        <Col sm={3} className=\"left-panel\">\n          {showLeftPanel}\n        </Col>\n        <Col className=\"map-column\" sm={9}>\n          {edges_data.isFetching || areas_data.isFetching ? (\n            <Loader />\n          ) : (\n            <Map\n              points={points}\n              edges={edges_data.items}\n              areas={areas_data.newAreas}\n              selectedPoint={selectedPoint}\n              updateSelectedPoint={handleSelectPoint}\n            />\n          )}\n          <RightPanel\n            className={`right-panel ${showRightPanel ? 'open' : ''}`}\n            point={selectedPoint}\n            onClose={onRightPanelClose}\n          />\n        </Col>\n      </Row>\n    </Container>\n  );\n};\n\nexport default OperationsPage;\n"],"mappings":"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"}
|
|
151
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["require","_react","_interopRequireWildcard","_reactRedux","_reactBootstrap","_actions","_actions2","_actions3","_Map","_LeftPanel","_interopRequireDefault","_RightPanel","_actions4","_KandoAlert","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","OperationsPage","dispatch","useDispatch","points_data","useSelector","state","edges_data","areas_data","global_data","_useState","useState","_useState2","_slicedToArray2","showRightPanel","setShowRightPanel","_useState3","_useState4","selectedPoint","setSelectedPoint","_useState5","_useState6","isSmallScreen","setIsSmallScreen","handleSelectPoint","newPoint","id","useEffect","updateNavContext","name","checkScreenSize","window","innerWidth","addEventListener","removeEventListener","waterAuthorityId","fetchPoints","fetchEdges","fetchAreas","points","useMemo","_points_data$items","items","filter","point","latitude","longitude","monitoredPoints","has_device","showLeftPanel","createElement","onRightPanelClose","getDistance","edge","find","source_point_id","distance","KandoAlert","variant","header","Container","fluid","className","Row","Col","sm","isFetching","Map","edges","areas","newAreas","updateSelectedPoint","concat","onClose","_default","exports"],"sources":["../../../src/pages/OperationsPage/OperationsPage.tsx"],"sourcesContent":["import './OperationsPage.scss';\nimport React, { useEffect, useMemo, useState } from 'react';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { Col, Container, Row } from 'react-bootstrap';\nimport { updateNavContext } from 'src/store/context/actions';\nimport { fetchPoints } from 'src/store/points/actions';\nimport { fetchEdges } from 'src/store/edges/actions';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport { Map } from './Map/Map';\nimport LeftPanel from './LeftPanel';\nimport RightPanel from './RightPanel';\nimport { fetchAreas } from 'src/store/areas/actions';\nimport { KandoAlert } from 'src/ui-kit/Alert/KandoAlert';\n\nconst OperationsPage: React.FC = () => {\n  const dispatch = useDispatch();\n  const points_data = useSelector((state) => state.points_data);\n  const edges_data = useSelector((state) => state.edges_data);\n  const areas_data = useSelector((state) => state.areas_data);\n  const global_data = useSelector((state) => state.global_data);\n  const [showRightPanel, setShowRightPanel] = useState(false);\n  const [selectedPoint, setSelectedPoint] = useState<IPoint | null>(null);\n  const [isSmallScreen, setIsSmallScreen] = useState(false);\n\n  const handleSelectPoint = (newPoint: IPoint) => {\n    if (selectedPoint && newPoint.id === selectedPoint.id) {\n      setSelectedPoint(null);\n    } else {\n      setSelectedPoint(newPoint);\n    }\n  };\n\n  useEffect(() => {\n    dispatch(updateNavContext({ name: 'operations' }));\n\n    const checkScreenSize = () => {\n      setIsSmallScreen(window.innerWidth < 768); // or any breakpoint\n    };\n\n    // Run on mount:\n    checkScreenSize();\n\n    // Also update if the user resizes the browser:\n    window.addEventListener('resize', checkScreenSize);\n    return () => {\n      window.removeEventListener('resize', checkScreenSize);\n    };\n  }, []);\n\n  useEffect(() => {\n    if (global_data.waterAuthorityId) {\n      dispatch(fetchPoints(global_data.waterAuthorityId));\n      dispatch(fetchEdges(global_data.waterAuthorityId));\n      dispatch(fetchAreas(global_data.waterAuthorityId));\n    }\n\n    return () => {\n      setSelectedPoint(null);\n    };\n  }, [global_data.waterAuthorityId]);\n\n  const points = useMemo(() => {\n    return (\n      points_data.items?.filter(\n        (point: IPoint) => point.latitude && point.longitude,\n      ) || []\n    );\n  }, [points_data.items]);\n\n  const monitoredPoints = useMemo(() => {\n    return points.filter((point: IPoint) => point.has_device) || [];\n  }, [points]);\n\n  const showLeftPanel = useMemo(() => {\n    return (\n      <LeftPanel\n        points={monitoredPoints}\n        selectedPoint={selectedPoint}\n        setSelectedPoint={setSelectedPoint}\n      />\n    );\n  }, [monitoredPoints, selectedPoint]);\n\n  useEffect(() => {\n    if (selectedPoint) {\n      setShowRightPanel(true);\n    } else {\n      setShowRightPanel(false);\n    }\n  }, [selectedPoint]);\n\n  const onRightPanelClose = () => {\n    setSelectedPoint(null);\n  };\n\n  const getDistance = () => {\n    if (selectedPoint && edges_data.items) {\n      const edge = edges_data.items.find(\n        (edge) => edge.source_point_id === selectedPoint.id,\n      );\n      return edge?.distance || 0;\n    }\n    return 0;\n  };\n\n  if (isSmallScreen) {\n    return (\n      <KandoAlert variant=\"success\" header=\"Notice\">\n        <h5>{'This page is not supported on small screens'}</h5>\n        <p>{'Please use a larger screen for the best experience.'}</p>\n      </KandoAlert>\n    );\n  }\n\n  return (\n    <Container fluid className=\"vh-90 p-0\">\n      <Row>\n        <Col sm={3} className=\"left-panel\">\n          {showLeftPanel}\n        </Col>\n        <Col className=\"map-column\" sm={9}>\n          {!edges_data.isFetching && !areas_data.isFetching && (\n            <Map\n              points={points}\n              edges={edges_data.items}\n              areas={areas_data.newAreas}\n              selectedPoint={selectedPoint}\n              updateSelectedPoint={handleSelectPoint}\n            />\n          )}\n          <RightPanel\n            className={`right-panel ${showRightPanel ? 'open' : ''}`}\n            point={selectedPoint}\n            distance={getDistance()}\n            onClose={onRightPanelClose}\n          />\n        </Col>\n      </Row>\n    </Container>\n  );\n};\n\nexport default OperationsPage;\n"],"mappings":"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"}
|
|
@@ -1,9 +1,19 @@
|
|
|
1
1
|
.map-column {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
2
|
+
position: relative;
|
|
3
|
+
.kd-map-container {
|
|
4
|
+
position: relative;
|
|
5
|
+
height: calc(100vh - 68px);
|
|
6
|
+
width: 100wh;
|
|
7
|
+
|
|
8
|
+
#map {
|
|
9
|
+
height: 100%;
|
|
10
|
+
width: 100%;
|
|
11
|
+
|
|
12
|
+
*,
|
|
13
|
+
*:focus,
|
|
14
|
+
*:hover {
|
|
15
|
+
outline: none;
|
|
16
|
+
}
|
|
7
17
|
}
|
|
8
18
|
}
|
|
9
19
|
|
|
@@ -34,38 +44,17 @@
|
|
|
34
44
|
background-color: #f5f5f5;
|
|
35
45
|
|
|
36
46
|
.list-item {
|
|
37
|
-
padding:
|
|
47
|
+
padding: 10px;
|
|
38
48
|
border-bottom: 1px solid #e0e0e0;
|
|
39
49
|
cursor: pointer;
|
|
40
|
-
transition: background-color 0.3s
|
|
41
|
-
display: flex;
|
|
42
|
-
align-items: center;
|
|
43
|
-
justify-content: space-between;
|
|
50
|
+
transition: background-color 0.3s;
|
|
44
51
|
|
|
45
52
|
&:hover {
|
|
46
53
|
background-color: #e0e0e0;
|
|
47
54
|
}
|
|
48
55
|
|
|
49
56
|
&.list-item-selected {
|
|
50
|
-
background-color: #
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
.icon-red {
|
|
54
|
-
color: #ff0000;
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
.icon-orange {
|
|
58
|
-
color: #ff9800;
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
.icon-yellow {
|
|
62
|
-
color: #ffeb3b;
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
.item-content {
|
|
66
|
-
margin-left: -10px;
|
|
67
|
-
display: flex;
|
|
68
|
-
align-items: center;
|
|
57
|
+
background-color: #e0e0e0;
|
|
69
58
|
}
|
|
70
59
|
}
|
|
71
60
|
}
|
|
@@ -9,17 +9,11 @@ var _react = _interopRequireDefault(require("react"));
|
|
|
9
9
|
var _Card = _interopRequireDefault(require("react-bootstrap/Card"));
|
|
10
10
|
var _ListGroup = _interopRequireDefault(require("react-bootstrap/ListGroup"));
|
|
11
11
|
var RightPanel = function RightPanel(_ref) {
|
|
12
|
-
var _point$
|
|
12
|
+
var _point$name, _point$description;
|
|
13
13
|
var point = _ref.point,
|
|
14
|
+
distance = _ref.distance,
|
|
14
15
|
className = _ref.className,
|
|
15
16
|
onClose = _ref.onClose;
|
|
16
|
-
var splitCamelCase = function splitCamelCase(str) {
|
|
17
|
-
if (!str) {
|
|
18
|
-
return '';
|
|
19
|
-
}
|
|
20
|
-
return str.replace(/([a-z])([A-Z])/g, '$1 $2'); // Add space before each capital letter
|
|
21
|
-
};
|
|
22
|
-
|
|
23
17
|
return /*#__PURE__*/_react.default.createElement("div", {
|
|
24
18
|
className: className
|
|
25
19
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
@@ -29,15 +23,13 @@ var RightPanel = function RightPanel(_ref) {
|
|
|
29
23
|
maxWidth: '600px',
|
|
30
24
|
margin: '0 auto'
|
|
31
25
|
}
|
|
32
|
-
}, /*#__PURE__*/_react.default.createElement(_Card.default.Header, null, '
|
|
26
|
+
}, /*#__PURE__*/_react.default.createElement(_Card.default.Header, null, 'Point Details', /*#__PURE__*/_react.default.createElement("button", {
|
|
33
27
|
className: "close",
|
|
34
28
|
onClick: onClose
|
|
35
29
|
}, /*#__PURE__*/_react.default.createElement("span", null, "\xD7"))), /*#__PURE__*/_react.default.createElement(_ListGroup.default, {
|
|
36
30
|
variant: "flush"
|
|
37
|
-
}, /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, null, /*#__PURE__*/_react.default.createElement("strong", null, 'Name:'), " ", point === null || point === void 0 ? void 0 : point.name), /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, null, /*#__PURE__*/_react.default.createElement("strong", null, 'Description:'), " ", point === null || point === void 0 ? void 0 : point.description), /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, null, /*#__PURE__*/_react.default.createElement("strong", null, 'Monitored:'), " ", (point === null || point === void 0 ? void 0 : point.has_device) ? 'Yes' : 'No'),
|
|
38
|
-
return issue;
|
|
39
|
-
}).join(', '))))));
|
|
31
|
+
}, /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, null, /*#__PURE__*/_react.default.createElement("strong", null, 'Name:'), " ", (_point$name = point === null || point === void 0 ? void 0 : point.name) !== null && _point$name !== void 0 ? _point$name : '-'), /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, null, /*#__PURE__*/_react.default.createElement("strong", null, 'Description:'), " ", (_point$description = point === null || point === void 0 ? void 0 : point.description) !== null && _point$description !== void 0 ? _point$description : '-'), /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, null, /*#__PURE__*/_react.default.createElement("strong", null, 'Monitored:'), " ", (point === null || point === void 0 ? void 0 : point.has_device) ? 'Yes' : 'No'), /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, null, /*#__PURE__*/_react.default.createElement("strong", null, 'Was Monitored:'), (point === null || point === void 0 ? void 0 : point.device_status) !== 'regular' ? 'Yes' : 'No'), /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, null, /*#__PURE__*/_react.default.createElement("strong", null, 'Sector:'), " ", point === null || point === void 0 ? void 0 : point.group.sector_name), /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, null, /*#__PURE__*/_react.default.createElement("strong", null, 'Type:'), " ", point === null || point === void 0 ? void 0 : point.group.type.split('::')[1]), /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, null, /*#__PURE__*/_react.default.createElement("strong", null, 'Water Discharge:'), ' ', point === null || point === void 0 ? void 0 : point.group.water_discharge), /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, null, /*#__PURE__*/_react.default.createElement("strong", null, 'Distance:'), " ", distance)))));
|
|
40
32
|
};
|
|
41
33
|
var _default = RightPanel;
|
|
42
34
|
exports.default = _default;
|
|
43
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9DYXJkIiwiX0xpc3RHcm91cCIsIlJpZ2h0UGFuZWwiLCJfcmVmIiwiX3BvaW50JG5hbWUiLCJfcG9pbnQkZGVzY3JpcHRpb24iLCJwb2ludCIsImRpc3RhbmNlIiwiY2xhc3NOYW1lIiwib25DbG9zZSIsImRlZmF1bHQiLCJjcmVhdGVFbGVtZW50Iiwic3R5bGUiLCJtYXhXaWR0aCIsIm1hcmdpbiIsIkhlYWRlciIsIm9uQ2xpY2siLCJ2YXJpYW50IiwiSXRlbSIsIm5hbWUiLCJkZXNjcmlwdGlvbiIsImhhc19kZXZpY2UiLCJkZXZpY2Vfc3RhdHVzIiwiZ3JvdXAiLCJzZWN0b3JfbmFtZSIsInR5cGUiLCJzcGxpdCIsIndhdGVyX2Rpc2NoYXJnZSIsIl9kZWZhdWx0IiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9wYWdlcy9PcGVyYXRpb25zUGFnZS9SaWdodFBhbmVsLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgSVBvaW50IH0gZnJvbSAnc3JjL3N0b3JlL3BvaW50cy9tb2RlbHMvSVBvaW50JztcbmltcG9ydCBDYXJkIGZyb20gJ3JlYWN0LWJvb3RzdHJhcC9DYXJkJztcbmltcG9ydCBMaXN0R3JvdXAgZnJvbSAncmVhY3QtYm9vdHN0cmFwL0xpc3RHcm91cCc7XG5cbnR5cGUgUmlnaHRQYW5lbFByb3BzID0ge1xuICBwb2ludDogSVBvaW50IHwgbnVsbDtcbiAgZGlzdGFuY2U6IG51bWJlcjtcbiAgY2xhc3NOYW1lPzogc3RyaW5nO1xuICBvbkNsb3NlPzogKCkgPT4gdm9pZDtcbn07XG5cbmNvbnN0IFJpZ2h0UGFuZWw6IFJlYWN0LkZDPFJpZ2h0UGFuZWxQcm9wcz4gPSAoe1xuICBwb2ludCxcbiAgZGlzdGFuY2UsXG4gIGNsYXNzTmFtZSxcbiAgb25DbG9zZSxcbn0pID0+IHtcbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNsYXNzTmFtZT17Y2xhc3NOYW1lfT5cbiAgICAgIDxkaXYgY2xhc3NOYW1lPVwiZHJhd2VyLWJvZHkgcC0zXCI+XG4gICAgICAgIDxDYXJkIHN0eWxlPXt7IG1heFdpZHRoOiAnNjAwcHgnLCBtYXJnaW46ICcwIGF1dG8nIH19PlxuICAgICAgICAgIDxDYXJkLkhlYWRlcj5cbiAgICAgICAgICAgIHsnUG9pbnQgRGV0YWlscyd9XG4gICAgICAgICAgICA8YnV0dG9uIGNsYXNzTmFtZT1cImNsb3NlXCIgb25DbGljaz17b25DbG9zZX0+XG4gICAgICAgICAgICAgIDxzcGFuPiZ0aW1lczs8L3NwYW4+XG4gICAgICAgICAgICA8L2J1dHRvbj5cbiAgICAgICAgICA8L0NhcmQuSGVhZGVyPlxuICAgICAgICAgIDxMaXN0R3JvdXAgdmFyaWFudD1cImZsdXNoXCI+XG4gICAgICAgICAgICA8TGlzdEdyb3VwLkl0ZW0+XG4gICAgICAgICAgICAgIDxzdHJvbmc+eydOYW1lOid9PC9zdHJvbmc+IHtwb2ludD8ubmFtZSA/PyAnLSd9XG4gICAgICAgICAgICA8L0xpc3RHcm91cC5JdGVtPlxuICAgICAgICAgICAgPExpc3RHcm91cC5JdGVtPlxuICAgICAgICAgICAgICA8c3Ryb25nPnsnRGVzY3JpcHRpb246J308L3N0cm9uZz4ge3BvaW50Py5kZXNjcmlwdGlvbiA/PyAnLSd9XG4gICAgICAgICAgICA8L0xpc3RHcm91cC5JdGVtPlxuICAgICAgICAgICAgPExpc3RHcm91cC5JdGVtPlxuICAgICAgICAgICAgICA8c3Ryb25nPnsnTW9uaXRvcmVkOid9PC9zdHJvbmc+IHtwb2ludD8uaGFzX2RldmljZSA/ICdZZXMnIDogJ05vJ31cbiAgICAgICAgICAgIDwvTGlzdEdyb3VwLkl0ZW0+XG4gICAgICAgICAgICA8TGlzdEdyb3VwLkl0ZW0+XG4gICAgICAgICAgICAgIDxzdHJvbmc+eydXYXMgTW9uaXRvcmVkOid9PC9zdHJvbmc+XG4gICAgICAgICAgICAgIHtwb2ludD8uZGV2aWNlX3N0YXR1cyAhPT0gJ3JlZ3VsYXInID8gJ1llcycgOiAnTm8nfVxuICAgICAgICAgICAgPC9MaXN0R3JvdXAuSXRlbT5cbiAgICAgICAgICAgIDxMaXN0R3JvdXAuSXRlbT5cbiAgICAgICAgICAgICAgPHN0cm9uZz57J1NlY3RvcjonfTwvc3Ryb25nPiB7cG9pbnQ/Lmdyb3VwLnNlY3Rvcl9uYW1lfVxuICAgICAgICAgICAgPC9MaXN0R3JvdXAuSXRlbT5cbiAgICAgICAgICAgIDxMaXN0R3JvdXAuSXRlbT5cbiAgICAgICAgICAgICAgPHN0cm9uZz57J1R5cGU6J308L3N0cm9uZz4ge3BvaW50Py5ncm91cC50eXBlLnNwbGl0KCc6OicpWzFdfVxuICAgICAgICAgICAgPC9MaXN0R3JvdXAuSXRlbT5cbiAgICAgICAgICAgIDxMaXN0R3JvdXAuSXRlbT5cbiAgICAgICAgICAgICAgPHN0cm9uZz57J1dhdGVyIERpc2NoYXJnZTonfTwvc3Ryb25nPnsnICd9XG4gICAgICAgICAgICAgIHtwb2ludD8uZ3JvdXAud2F0ZXJfZGlzY2hhcmdlfVxuICAgICAgICAgICAgPC9MaXN0R3JvdXAuSXRlbT5cbiAgICAgICAgICAgIDxMaXN0R3JvdXAuSXRlbT5cbiAgICAgICAgICAgICAgPHN0cm9uZz57J0Rpc3RhbmNlOid9PC9zdHJvbmc+IHtkaXN0YW5jZX1cbiAgICAgICAgICAgIDwvTGlzdEdyb3VwLkl0ZW0+XG4gICAgICAgICAgPC9MaXN0R3JvdXA+XG4gICAgICAgIDwvQ2FyZD5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgUmlnaHRQYW5lbDtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBLElBQUFBLE1BQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUVBLElBQUFDLEtBQUEsR0FBQUYsc0JBQUEsQ0FBQUMsT0FBQTtBQUNBLElBQUFFLFVBQUEsR0FBQUgsc0JBQUEsQ0FBQUMsT0FBQTtBQVNBLElBQU1HLFVBQXFDLEdBQUcsU0FB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
|