@kando-env/kando-ui 1.2.412-alpha.7 → 1.2.412-alpha.9

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.
@@ -30,7 +30,8 @@ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj &&
30
30
 
31
31
  // import { storeMap } from 'src/store/global/actions';
32
32
 
33
- // import { addLayerGroup } from './points/PointUtils';
33
+ // import { appReducer } from '../../store/rootReducer';
34
+
34
35
  require('leaflet.markercluster');
35
36
  var Map = function Map(_ref) {
36
37
  var areas = _ref.areas,
@@ -64,47 +65,52 @@ var Map = function Map(_ref) {
64
65
  setMapZoomLevel = _useState2[1];
65
66
  var _useSelectedItem = (0, _ListContext.useSelectedItem)(),
66
67
  selectedItem = _useSelectedItem.selectedItem;
67
- var eventsData = (0, _reactRedux.useSelector)(function (state) {
68
- return state.events_data;
69
- });
68
+ // const eventsData = useSelector(
69
+ // (state: ReturnType<typeof appReducer>) => state.events_data,
70
+ // );
70
71
  var hoveredEventPresent = (0, _react.useMemo)(function () {
71
72
  return hoveredEvent !== null && hoveredEvent !== undefined;
72
73
  }, [hoveredEvent]);
73
74
  var focusedEventPresent = (0, _react.useMemo)(function () {
74
75
  return focusedEvent !== null && focusedEvent !== undefined;
75
76
  }, [focusedEvent]);
77
+
78
+ // Add parent layer group for all factories
76
79
  var _useState3 = (0, _react.useState)(L.layerGroup()),
77
80
  _useState4 = (0, _slicedToArray2.default)(_useState3, 1),
78
- unmonitoredFactoriesGroup = _useState4[0];
81
+ factoriesParentGroup = _useState4[0];
79
82
  var _useState5 = (0, _react.useState)(L.layerGroup()),
80
83
  _useState6 = (0, _slicedToArray2.default)(_useState5, 1),
81
- monitoredFactoriesGroup = _useState6[0];
84
+ unmonitoredFactoriesGroup = _useState6[0];
82
85
  var _useState7 = (0, _react.useState)(L.layerGroup()),
83
86
  _useState8 = (0, _slicedToArray2.default)(_useState7, 1),
84
- unmonitoredEdgesGroup = _useState8[0];
87
+ monitoredFactoriesGroup = _useState8[0];
85
88
  var _useState9 = (0, _react.useState)(L.layerGroup()),
86
89
  _useState10 = (0, _slicedToArray2.default)(_useState9, 1),
87
- monitoredEdgesGroup = _useState10[0];
90
+ unmonitoredEdgesGroup = _useState10[0];
88
91
  var _useState11 = (0, _react.useState)(L.layerGroup()),
89
92
  _useState12 = (0, _slicedToArray2.default)(_useState11, 1),
90
- wwtpsLayerGroup = _useState12[0];
93
+ monitoredEdgesGroup = _useState12[0];
91
94
  var _useState13 = (0, _react.useState)(L.layerGroup()),
92
95
  _useState14 = (0, _slicedToArray2.default)(_useState13, 1),
93
- collectorsLayerGroup = _useState14[0];
94
- var _useState15 = (0, _react.useState)(new L.FeatureGroup()),
96
+ wwtpsLayerGroup = _useState14[0];
97
+ var _useState15 = (0, _react.useState)(L.layerGroup()),
95
98
  _useState16 = (0, _slicedToArray2.default)(_useState15, 1),
96
- areasLayerGroup = _useState16[0];
97
- var _useState17 = (0, _react.useState)(true),
98
- _useState18 = (0, _slicedToArray2.default)(_useState17, 2),
99
- edgesCheckbox = _useState18[0],
100
- setEdgesCheckbox = _useState18[1];
99
+ collectorsLayerGroup = _useState16[0];
100
+ var _useState17 = (0, _react.useState)(new L.FeatureGroup()),
101
+ _useState18 = (0, _slicedToArray2.default)(_useState17, 1),
102
+ areasLayerGroup = _useState18[0];
103
+ var _useState19 = (0, _react.useState)(true),
104
+ _useState20 = (0, _slicedToArray2.default)(_useState19, 2),
105
+ edgesCheckbox = _useState20[0],
106
+ setEdgesCheckbox = _useState20[1];
101
107
  var renderPointMarkers = function renderPointMarkers(filteredPoints, mapRef, props) {
102
108
  return mapRef.current !== null && points && /*#__PURE__*/_react.default.createElement(_PointMarkers.PointMarkers, Object.assign({
103
109
  map: mapRef.current,
104
110
  points: filteredPoints
105
111
  }, props));
106
112
  };
107
- var memoizedMonitoredPoints = (0, _react.useMemo)(function () {
113
+ var memoizedMonitoredPoints = function memoizedMonitoredPoints() {
108
114
  var monitoredPoints = (0, _MapUtils.filterPoints)(points, true);
109
115
  return renderPointMarkers(monitoredPoints, mapRef, {
110
116
  includeUnmonitoredPoints: true,
@@ -114,8 +120,8 @@ var Map = function Map(_ref) {
114
120
  collectorsGroup: collectorsLayerGroup,
115
121
  forEventsView: forEventsView
116
122
  });
117
- }, [mapRef.current, points, focusedEventPresent, mapZoomLevel]);
118
- var memoizedUnmonitoredPoints = (0, _react.useMemo)(function () {
123
+ };
124
+ var memoizedUnmonitoredPoints = function memoizedUnmonitoredPoints() {
119
125
  var unmonitoredPoints = (0, _MapUtils.filterPoints)(points, false);
120
126
  return renderPointMarkers(unmonitoredPoints, mapRef, {
121
127
  includeUnmonitoredPoints: true,
@@ -125,7 +131,7 @@ var Map = function Map(_ref) {
125
131
  collectorsGroup: collectorsLayerGroup,
126
132
  forEventsView: forEventsView
127
133
  });
128
- }, [mapRef.current, points, focusedEventPresent, mapZoomLevel]);
134
+ };
129
135
  var renderEdges = function renderEdges(filteredEdges, mapRef, edgesCheckbox, props) {
130
136
  return mapRef.current !== null && edgesCheckbox && /*#__PURE__*/_react.default.createElement(_Edges.default, Object.assign({
131
137
  edges: filteredEdges,
@@ -167,15 +173,11 @@ var Map = function Map(_ref) {
167
173
  var zoom = _MapUtils.zoomLevels[mapRef.current.getZoom()];
168
174
  if (isChecked) {
169
175
  // Hide unmonitored points when "show only monitored" is checked
170
- unmonitoredFactoriesGroup.removeFrom(mapRef.current);
171
-
172
- // Hide unmonitored edges if at appropriate zoom level
173
- if (edgesZoomLevels.includes(zoom)) {
174
- unmonitoredEdgesGroup.removeFrom(mapRef.current);
175
- }
176
+ factoriesParentGroup.removeLayer(unmonitoredFactoriesGroup);
177
+ unmonitoredEdgesGroup.removeFrom(mapRef.current);
176
178
  } else {
177
179
  // Show all points when "show only monitored" is unchecked
178
- unmonitoredFactoriesGroup.addTo(mapRef.current);
180
+ factoriesParentGroup.addLayer(unmonitoredFactoriesGroup);
179
181
 
180
182
  // Show unmonitored edges if at appropriate zoom level
181
183
  if (edgesZoomLevels.includes(zoom)) {
@@ -189,25 +191,25 @@ var Map = function Map(_ref) {
189
191
  (0, _MapUtils.setupCheckboxListener)('#monitored-points-checkbox', handlePointsCheckboxChange);
190
192
  };
191
193
  var zoomRulesForEventsView = function zoomRulesForEventsView() {
192
- var payload = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, memoizedEdges, memoizedUnmonitoredEdges, memoizedUnmonitoredPoints, memoizedMonitoredPoints);
194
+ var payload = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, memoizedEdges, memoizedUnmonitoredEdges, memoizedUnmonitoredPoints(), memoizedMonitoredPoints());
193
195
  return payload;
194
196
  };
195
197
  var zoomRulesForDashaboardMaps = function zoomRulesForDashaboardMaps() {
196
- var payload = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, memoizedUnmonitoredPoints, " ", memoizedMonitoredPoints);
198
+ var payload = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, memoizedUnmonitoredPoints(), memoizedMonitoredPoints());
197
199
  if (forEventsView || edgesZoomLevels.includes(_MapUtils.zoomLevels[mapZoomLevel])) {
198
200
  payload = zoomRulesForEventsView();
199
201
  }
200
202
  return payload;
201
203
  };
202
- var memoizedZoomControl = (0, _react.useMemo)(function () {
204
+ var memoizedZoomControl = function memoizedZoomControl() {
203
205
  var payload = forEventsView ? zoomRulesForEventsView() : zoomRulesForDashaboardMaps();
204
206
  var checkbox = document.querySelector('#monitored-points-checkbox');
205
207
  if (checkbox) {
206
208
  handlePointsCheckboxChange(checkbox.checked);
207
209
  }
208
210
  return payload;
209
- }, [mapZoomLevel, eventsData.isFetching, focusedEvent, hoveredEvent, points, mapRef.current, edgesCheckbox, unmonitoredEdgesGroup]);
210
- var memoizedEvent = (0, _react.useMemo)(function () {
211
+ };
212
+ var memoizedEvent = function memoizedEvent() {
211
213
  if (focusedEventPresent) {
212
214
  focusedEvent.focused = focusedEventPresent;
213
215
  focusedEvent.hovered = !focusedEventPresent;
@@ -224,7 +226,7 @@ var Map = function Map(_ref) {
224
226
  points: points,
225
227
  includeNetwork: !hoveredEventPresent
226
228
  });
227
- }, [focusedEvent, hoveredEvent, global_data.eventFilterParam]);
229
+ };
228
230
 
229
231
  // useEffect(() => {
230
232
  // return function cleanup() {
@@ -264,24 +266,45 @@ var Map = function Map(_ref) {
264
266
  (0, _react.useEffect)(function () {
265
267
  if (!mapRef.current) {
266
268
  (0, _MapUtils.initializeMap)(mapZoomLevel, mapBoxStyle, _theme.leafletMap.satellite, mapRef, dispatch, _MapUtils.isValidArea, areaToCenterBy, setMapZoomLevel, true, global_data.waterAuthorityId);
269
+
270
+ // Initialize parent factory group
271
+ if (mapRef.current) {
272
+ factoriesParentGroup.addTo(mapRef.current);
273
+ factoriesParentGroup.addLayer(monitoredFactoriesGroup);
274
+ factoriesParentGroup.addLayer(unmonitoredFactoriesGroup);
275
+ }
267
276
  } else {
268
- setMapZoomLevel(mapRef.current.getZoom());
277
+ // setMapZoomLevel(mapRef.current.getZoom());
269
278
  if (!areaToCenterBy) {
270
279
  areaToCenterBy = areas.map(function (area) {
271
280
  return area.shape_data;
272
281
  }).flat();
273
282
  }
283
+ if (!forEventsView || !focusedEvent) {
284
+ (0, _MapUtils.areaFocusLogic)(mapRef, _MapUtils.isValidArea, areaToCenterBy);
285
+ }
286
+ trackLayerbox();
287
+ }
288
+ }, [mapRef.current, points]);
289
+ (0, _react.useEffect)(function () {
290
+ if (!mapRef.current) {
291
+ return;
292
+ }
274
293
 
275
- // Add layer groups to map after initialization
276
- // monitoredFactoriesGroup.addTo(mapRef.current);
277
- // unmonitoredFactoriesGroup.addTo(mapRef.current);
278
- // wwtpsLayerGroup.addTo(mapRef.current);
279
- // collectorsLayerGroup.addTo(mapRef.current);
294
+ // return () => {
295
+ // mapRef.current?.clearLayers();
296
+ // mapRef.current?.off();
297
+ // mapRef.current?.remove();
298
+ // mapRef.current = null;
299
+ // dispatch(storeMap(undefined));
300
+ // };
280
301
 
281
- (0, _MapUtils.areaFocusLogic)(mapRef, _MapUtils.isValidArea, areaToCenterBy);
282
- trackLayerbox();
302
+ if (_MapUtils.zoomLevels[mapZoomLevel] === 'XLarge') {
303
+ mapRef.current.removeLayer(factoriesParentGroup);
304
+ } else {
305
+ mapRef.current.addLayer(factoriesParentGroup);
283
306
  }
284
- }, [mapRef.current, areaToCenterBy, points, global_data.waterAuthorityId]);
307
+ }, [mapZoomLevel]);
285
308
  (0, _react.useEffect)(function () {
286
309
  var _mapRef$current;
287
310
  var clicked = false;
@@ -304,16 +327,15 @@ var Map = function Map(_ref) {
304
327
  className: " map-container ".concat(global_data.sidenavExpanded ? '' : 'map-container--sidenav-collapsed')
305
328
  }, /*#__PURE__*/_react.default.createElement(_ErrorBoundary.default, null, /*#__PURE__*/_react.default.createElement("div", {
306
329
  id: "map"
307
- }), (0, _MapUtils.shouldLoadMapObjects)(global_data, mapRef, edges, points) && /*#__PURE__*/_react.default.createElement(_AreaPolygons.AreaPolygons, {
330
+ }, (0, _MapUtils.shouldLoadMapObjects)(global_data, mapRef, edges, points) && /*#__PURE__*/_react.default.createElement(_AreaPolygons.AreaPolygons, {
308
331
  areas: areas,
309
332
  map: mapRef.current,
310
333
  L: L,
311
334
  areaToCenterBy: areaToCenterBy,
312
335
  mapZoom: mapZoomLevel,
313
- rerender: _MapUtils.zoomLevels[mapZoomLevel],
314
336
  global_data: global_data,
315
337
  featureGroup: areasLayerGroup
316
- }), (0, _MapUtils.shoudLoadDependentMapObjects)(edges, areas, global_data, mapRef, points) && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, memoizedEvent, memoizedZoomControl, children))));
338
+ }), (0, _MapUtils.shoudLoadDependentMapObjects)(edges, areas, global_data, mapRef, points) && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, memoizedEvent(), memoizedZoomControl(), children)))));
317
339
  };
318
340
  exports.Map = Map;
319
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["L","_interopRequireWildcard","require","_react","_reactRedux","_ErrorBoundary","_interopRequireDefault","_AreaPolygons","_Edges","_PointMarkers","_Event","_MapUtils","_theme","_ListContext","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","Map","_ref","areas","edges","points","global_data","areaToCenterBy","focusedEvent","hoveredEvent","_ref$hideEdges","hideEdges","_ref$mapBoxStyle","mapBoxStyle","leafletMap","mapDefault","children","_ref$includeUnmonitor","includeUnmonitoredPoints","_ref$includeUnmonitor2","includeUnmonitoredDescendantsForEdges","_ref$forEventsView","forEventsView","_ref$style","style","_ref$forWWTPDashboard","forWWTPDashboard","map","mapRef","useRef","dispatch","useDispatch","_useState","useState","_useState2","_slicedToArray2","mapZoomLevel","setMapZoomLevel","_useSelectedItem","useSelectedItem","selectedItem","eventsData","useSelector","state","events_data","hoveredEventPresent","useMemo","undefined","focusedEventPresent","_useState3","layerGroup","_useState4","unmonitoredFactoriesGroup","_useState5","_useState6","monitoredFactoriesGroup","_useState7","_useState8","unmonitoredEdgesGroup","_useState9","_useState10","monitoredEdgesGroup","_useState11","_useState12","wwtpsLayerGroup","_useState13","_useState14","collectorsLayerGroup","_useState15","FeatureGroup","_useState16","areasLayerGroup","_useState17","_useState18","edgesCheckbox","setEdgesCheckbox","renderPointMarkers","filteredPoints","props","current","createElement","PointMarkers","assign","memoizedMonitoredPoints","monitoredPoints","filterPoints","rerender","zoomLevels","factoriesGroup","wwtpsGroup","collectorsGroup","memoizedUnmonitoredPoints","unmonitoredPoints","renderEdges","filteredEdges","memoizedEdges","monitoredEdges","filterEdges","hideArrows","allowUnmonitoredDescendants","group","memoizedUnmonitoredEdges","unmonitoredEdges","shouldntDraw","getLayers","length","handleEdgesCheckboxChange","isChecked","edgesZoomLevels","handlePointsCheckboxChange","zoom","getZoom","removeFrom","includes","addTo","trackLayerbox","setupCheckboxListener","zoomRulesForEventsView","payload","Fragment","zoomRulesForDashaboardMaps","memoizedZoomControl","checkbox","document","querySelector","checked","isFetching","memoizedEvent","focused","hovered","Event","event","includeNetwork","eventFilterParam","useEffect","initializeMap","satellite","isValidArea","waterAuthorityId","area","shape_data","flat","areaFocusLogic","_mapRef$current","clicked","eachLayer","layer","kando_object_id","isPopupOpen","Marker","fire","Polygon","className","concat","sidenavExpanded","id","shouldLoadMapObjects","AreaPolygons","mapZoom","featureGroup","shoudLoadDependentMapObjects","exports"],"sources":["../../../src/Widgets/Map/Map.tsx"],"sourcesContent":["// @ts-ignore\nimport * as L from 'leaflet';\nimport 'src/utilities/polylinedecorator';\nimport 'leaflet.markercluster';\nimport 'leaflet.pattern';\nimport 'leaflet.heat';\nimport React, {\n  CSSProperties,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from 'react';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { IArea } from 'src/store/areas/models/IArea';\nimport { IEdge } from 'src/store/edges/models/IEdge';\nimport { IEvent } from 'src/store/events/models/IEvent';\n// import { storeMap } from 'src/store/global/actions';\nimport { IGlobalState } from 'src/store/global/models/IGlobalState';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport ErrorBoundary from 'src/utilities/ErrorBoundary';\nimport { AreaPolygons } from './areas/AreaPolygons';\nimport Edges from './edges/Edges';\nimport './Map.scss';\nimport './points/PointIcon.scss';\nimport { PointMarkers } from './points/PointMarkers';\nimport { appReducer } from '../../store/rootReducer';\nimport { Event } from './events/Event';\nimport {\n  areaFocusLogic,\n  filterEdges,\n  filterPoints,\n  initializeMap,\n  isValidArea,\n  setupCheckboxListener,\n  shoudLoadDependentMapObjects,\n  shouldLoadMapObjects,\n  zoomLevels,\n} from './MapUtils';\nimport { leafletMap } from '../../styles/theme/theme';\nimport { useSelectedItem } from 'src/pages/DashboardMap/ListContext';\n// import { addLayerGroup } from './points/PointUtils';\nrequire('leaflet.markercluster');\n\ninterface MapProps {\n  areas: IArea[];\n  edges?: IEdge[];\n  points?: IPoint[];\n  global_data: IGlobalState;\n  areaToCenterBy?: any;\n  focusedEvent?: IEvent | null;\n  hoveredEvent?: IEvent | null;\n  hideEdges?: boolean;\n  mapBoxStyle?: string;\n  children?: any;\n  style?: CSSProperties;\n  includeUnmonitoredPoints?: boolean;\n  includeUnmonitoredDescendantsForEdges?: boolean;\n  forEventsView: boolean;\n  forWWTPDashboard?: boolean;\n}\n\nexport const Map: React.FC<MapProps> = ({\n  areas,\n  edges,\n  points,\n  global_data,\n  areaToCenterBy,\n  focusedEvent,\n  hoveredEvent,\n  hideEdges = false,\n  mapBoxStyle = leafletMap.mapDefault,\n  children,\n  includeUnmonitoredPoints = true,\n  includeUnmonitoredDescendantsForEdges = false,\n  forEventsView = false,\n  style = {},\n  forWWTPDashboard = false,\n}) => {\n  const { map } = global_data;\n  const mapRef = useRef<L.Map | null>(null);\n  const dispatch = useDispatch();\n  const [mapZoomLevel, setMapZoomLevel] = useState(2);\n  const { selectedItem } = useSelectedItem();\n  const eventsData = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.events_data,\n  );\n  const hoveredEventPresent = useMemo(() => {\n    return hoveredEvent !== null && hoveredEvent !== undefined;\n  }, [hoveredEvent]);\n\n  const focusedEventPresent = useMemo(() => {\n    return focusedEvent !== null && focusedEvent !== undefined;\n  }, [focusedEvent]);\n\n  const [unmonitoredFactoriesGroup] = useState(L.layerGroup());\n  const [monitoredFactoriesGroup] = useState(L.layerGroup());\n  const [unmonitoredEdgesGroup] = useState(L.layerGroup());\n  const [monitoredEdgesGroup] = useState(L.layerGroup());\n  const [wwtpsLayerGroup] = useState(L.layerGroup());\n  const [collectorsLayerGroup] = useState(L.layerGroup());\n  const [areasLayerGroup] = useState(new L.FeatureGroup());\n  const [edgesCheckbox, setEdgesCheckbox] = useState(true);\n  const renderPointMarkers = (filteredPoints, mapRef, props) =>\n    mapRef.current !== null &&\n    points && (\n      <PointMarkers map={mapRef.current} points={filteredPoints} {...props} />\n    );\n\n  const memoizedMonitoredPoints = useMemo(() => {\n    const monitoredPoints = filterPoints(points, true);\n    return renderPointMarkers(monitoredPoints, mapRef, {\n      includeUnmonitoredPoints: true,\n      rerender: zoomLevels[mapZoomLevel],\n      factoriesGroup: monitoredFactoriesGroup,\n      wwtpsGroup: wwtpsLayerGroup,\n      collectorsGroup: collectorsLayerGroup,\n      forEventsView: forEventsView,\n    });\n  }, [mapRef.current, points, focusedEventPresent, mapZoomLevel]);\n\n  const memoizedUnmonitoredPoints = useMemo(() => {\n    const unmonitoredPoints = filterPoints(points, false);\n    return renderPointMarkers(unmonitoredPoints, mapRef, {\n      includeUnmonitoredPoints: true,\n      rerender: zoomLevels[mapZoomLevel],\n      factoriesGroup: unmonitoredFactoriesGroup,\n      wwtpsGroup: wwtpsLayerGroup,\n      collectorsGroup: collectorsLayerGroup,\n      forEventsView: forEventsView,\n    });\n  }, [mapRef.current, points, focusedEventPresent, mapZoomLevel]);\n\n  const renderEdges = (filteredEdges, mapRef, edgesCheckbox, props) =>\n    mapRef.current !== null &&\n    edgesCheckbox && (\n      <Edges edges={filteredEdges} map={mapRef.current} {...props} />\n    );\n\n  const memoizedEdges = useMemo(() => {\n    const monitoredEdges = filterEdges(edges, points, true);\n    return renderEdges(monitoredEdges, mapRef, edgesCheckbox, {\n      L,\n      points,\n      hideEdges,\n      hideArrows: true,\n      allowUnmonitoredDescendants: includeUnmonitoredDescendantsForEdges,\n      group: monitoredEdgesGroup,\n    });\n  }, [mapRef.current, points, focusedEventPresent, mapZoomLevel]);\n\n  const memoizedUnmonitoredEdges = useMemo(() => {\n    const unmonitoredEdges = filterEdges(edges, points, false);\n    return renderEdges(unmonitoredEdges, mapRef, edgesCheckbox, {\n      L,\n      points,\n      hideEdges,\n      hideArrows: true,\n      allowUnmonitoredDescendants: includeUnmonitoredDescendantsForEdges,\n      group: unmonitoredEdgesGroup,\n      shouldntDraw: unmonitoredEdgesGroup.getLayers().length !== 0,\n    });\n  }, [mapRef.current, points, focusedEventPresent, mapZoomLevel]);\n\n  const handleEdgesCheckboxChange = (isChecked) => {\n    setEdgesCheckbox(isChecked);\n  };\n\n  // This variable stores the zoom levels the edges are displayed\n  // It is used in two places in the code, so it is better to store it in one place\n  const edgesZoomLevels = ['Small', 'Medium', 'MLarge', 'Large'];\n\n  const handlePointsCheckboxChange = (isChecked) => {\n    if (mapRef.current !== null) {\n      let zoom = zoomLevels[mapRef.current.getZoom()];\n\n      if (isChecked) {\n        // Hide unmonitored points when \"show only monitored\" is checked\n        unmonitoredFactoriesGroup.removeFrom(mapRef.current);\n\n        // Hide unmonitored edges if at appropriate zoom level\n        if (edgesZoomLevels.includes(zoom)) {\n          unmonitoredEdgesGroup.removeFrom(mapRef.current);\n        }\n      } else {\n        // Show all points when \"show only monitored\" is unchecked\n        unmonitoredFactoriesGroup.addTo(mapRef.current);\n\n        // Show unmonitored edges if at appropriate zoom level\n        if (edgesZoomLevels.includes(zoom)) {\n          unmonitoredEdgesGroup.addTo(mapRef.current);\n        }\n      }\n    }\n  };\n\n  const trackLayerbox = () => {\n    setupCheckboxListener('#edges-checkbox', handleEdgesCheckboxChange);\n    setupCheckboxListener(\n      '#monitored-points-checkbox',\n      handlePointsCheckboxChange,\n    );\n  };\n\n  const zoomRulesForEventsView = () => {\n    const payload = (\n      <>\n        {memoizedEdges}\n        {memoizedUnmonitoredEdges}\n        {memoizedUnmonitoredPoints}\n        {memoizedMonitoredPoints}\n      </>\n    );\n\n    return payload;\n  };\n\n  const zoomRulesForDashaboardMaps = () => {\n    let payload = (\n      <>\n        {memoizedUnmonitoredPoints} {memoizedMonitoredPoints}\n      </>\n    );\n    if (forEventsView || edgesZoomLevels.includes(zoomLevels[mapZoomLevel])) {\n      payload = zoomRulesForEventsView();\n    }\n\n    return payload;\n  };\n\n  const memoizedZoomControl = useMemo(() => {\n    const payload = forEventsView\n      ? zoomRulesForEventsView()\n      : zoomRulesForDashaboardMaps();\n\n    const checkbox = document.querySelector(\n      '#monitored-points-checkbox',\n    ) as HTMLInputElement;\n    if (checkbox) {\n      handlePointsCheckboxChange(checkbox.checked);\n    }\n    return payload;\n  }, [\n    mapZoomLevel,\n    eventsData.isFetching,\n    focusedEvent,\n    hoveredEvent,\n    points,\n    mapRef.current,\n    edgesCheckbox,\n    unmonitoredEdgesGroup,\n  ]);\n\n  const memoizedEvent = useMemo(() => {\n    if (focusedEventPresent) {\n      focusedEvent!.focused = focusedEventPresent;\n      focusedEvent!.hovered = !focusedEventPresent;\n    }\n\n    if (hoveredEventPresent) {\n      hoveredEvent!.hovered = hoveredEventPresent;\n      hoveredEvent!.focused = !hoveredEventPresent;\n    }\n\n    if (!hoveredEventPresent && !focusedEventPresent) return <></>;\n    return (\n      <Event\n        event={focusedEvent! || hoveredEvent!}\n        map={map}\n        edges={edges!}\n        points={points!}\n        includeNetwork={!hoveredEventPresent}\n      />\n    );\n  }, [focusedEvent, hoveredEvent, global_data.eventFilterParam]);\n\n  // useEffect(() => {\n  //   return function cleanup() {\n  //     collectorsLayerGroup.clearLayers();\n  //     mapRef.current?.removeLayer(collectorsLayerGroup);\n  //   };\n  // }, [focusedEvent, hoveredEvent, global_data.eventFilterParam]);\n\n  // useEffect(() => {\n  //   initializeMap(\n  //     mapZoomLevel,\n  //     mapBoxStyle,\n  //     leafletMap.satellite,\n  //     mapRef,\n  //     dispatch,\n  //     isValidArea,\n  //     areaToCenterBy,\n  //     setMapZoomLevel,\n  //     forWWTPDashboard,\n  //     true,\n  //     global_data.waterAuthorityId,\n  //   );\n\n  //   return function cleanup() {\n  //     wwtpsLayerGroup.clearLayers();\n  //     collectorsLayerGroup.clearLayers();\n  //     areasLayerGroup.clearLayers();\n  //     mapRef.current?.removeLayer(wwtpsLayerGroup);\n  //     mapRef.current?.removeLayer(collectorsLayerGroup);\n  //     mapRef.current?.removeLayer(areasLayerGroup);\n  //     // @ts-ignore\n  //     mapRef.current.remove();\n  //     dispatch(storeMap(undefined));\n  //   };\n  // }, [global_data.waterAuthorityId]);\n\n  useEffect(() => {\n    if (!mapRef.current) {\n      initializeMap(\n        mapZoomLevel,\n        mapBoxStyle,\n        leafletMap.satellite,\n        mapRef,\n        dispatch,\n        isValidArea,\n        areaToCenterBy,\n        setMapZoomLevel,\n        true,\n        global_data.waterAuthorityId,\n      );\n    } else {\n      setMapZoomLevel(mapRef.current.getZoom());\n      if (!areaToCenterBy) {\n        areaToCenterBy = areas.map((area) => area.shape_data).flat();\n      }\n\n      // Add layer groups to map after initialization\n      // monitoredFactoriesGroup.addTo(mapRef.current);\n      // unmonitoredFactoriesGroup.addTo(mapRef.current);\n      // wwtpsLayerGroup.addTo(mapRef.current);\n      // collectorsLayerGroup.addTo(mapRef.current);\n\n      areaFocusLogic(mapRef, isValidArea, areaToCenterBy);\n      trackLayerbox();\n    }\n  }, [mapRef.current, areaToCenterBy, points, global_data.waterAuthorityId]);\n\n  useEffect(() => {\n    let clicked = false;\n\n    mapRef.current?.eachLayer((layer) => {\n      if (clicked) return;\n\n      if (\n        layer?.kando_object_id === selectedItem &&\n        layer.isPopupOpen() === false\n      ) {\n        if (layer instanceof L.Marker) {\n          layer.fire('click');\n        } else if (layer instanceof L.Polygon) {\n          layer.fire('click-event');\n        }\n        clicked = true;\n      }\n    });\n  }, [selectedItem]);\n\n  return (\n    <div className=\"kd-map-container\" style={style}>\n      <div\n        className={` map-container ${\n          global_data.sidenavExpanded ? '' : 'map-container--sidenav-collapsed'\n        }`}\n      >\n        <ErrorBoundary>\n          <div id=\"map\"></div>\n          {shouldLoadMapObjects(global_data, mapRef, edges, points) && (\n            <AreaPolygons\n              areas={areas}\n              map={mapRef.current}\n              L={L}\n              areaToCenterBy={areaToCenterBy}\n              mapZoom={mapZoomLevel}\n              rerender={zoomLevels[mapZoomLevel]}\n              global_data={global_data}\n              featureGroup={areasLayerGroup}\n            />\n          )}\n          {shoudLoadDependentMapObjects(\n            edges,\n            areas,\n            global_data,\n            mapRef,\n            points,\n          ) && (\n            <>\n              {memoizedEvent}\n              {memoizedZoomControl}\n              {children}\n            </>\n          )}\n        </ErrorBoundary>\n      </div>\n    </div>\n  );\n};\n"],"mappings":"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"}
341
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["L","_interopRequireWildcard","require","_react","_reactRedux","_ErrorBoundary","_interopRequireDefault","_AreaPolygons","_Edges","_PointMarkers","_Event","_MapUtils","_theme","_ListContext","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","Map","_ref","areas","edges","points","global_data","areaToCenterBy","focusedEvent","hoveredEvent","_ref$hideEdges","hideEdges","_ref$mapBoxStyle","mapBoxStyle","leafletMap","mapDefault","children","_ref$includeUnmonitor","includeUnmonitoredPoints","_ref$includeUnmonitor2","includeUnmonitoredDescendantsForEdges","_ref$forEventsView","forEventsView","_ref$style","style","_ref$forWWTPDashboard","forWWTPDashboard","map","mapRef","useRef","dispatch","useDispatch","_useState","useState","_useState2","_slicedToArray2","mapZoomLevel","setMapZoomLevel","_useSelectedItem","useSelectedItem","selectedItem","hoveredEventPresent","useMemo","undefined","focusedEventPresent","_useState3","layerGroup","_useState4","factoriesParentGroup","_useState5","_useState6","unmonitoredFactoriesGroup","_useState7","_useState8","monitoredFactoriesGroup","_useState9","_useState10","unmonitoredEdgesGroup","_useState11","_useState12","monitoredEdgesGroup","_useState13","_useState14","wwtpsLayerGroup","_useState15","_useState16","collectorsLayerGroup","_useState17","FeatureGroup","_useState18","areasLayerGroup","_useState19","_useState20","edgesCheckbox","setEdgesCheckbox","renderPointMarkers","filteredPoints","props","current","createElement","PointMarkers","assign","memoizedMonitoredPoints","monitoredPoints","filterPoints","rerender","zoomLevels","factoriesGroup","wwtpsGroup","collectorsGroup","memoizedUnmonitoredPoints","unmonitoredPoints","renderEdges","filteredEdges","memoizedEdges","monitoredEdges","filterEdges","hideArrows","allowUnmonitoredDescendants","group","memoizedUnmonitoredEdges","unmonitoredEdges","shouldntDraw","getLayers","length","handleEdgesCheckboxChange","isChecked","edgesZoomLevels","handlePointsCheckboxChange","zoom","getZoom","removeLayer","removeFrom","addLayer","includes","addTo","trackLayerbox","setupCheckboxListener","zoomRulesForEventsView","payload","Fragment","zoomRulesForDashaboardMaps","memoizedZoomControl","checkbox","document","querySelector","checked","memoizedEvent","focused","hovered","Event","event","includeNetwork","useEffect","initializeMap","satellite","isValidArea","waterAuthorityId","area","shape_data","flat","areaFocusLogic","_mapRef$current","clicked","eachLayer","layer","kando_object_id","isPopupOpen","Marker","fire","Polygon","className","concat","sidenavExpanded","id","shouldLoadMapObjects","AreaPolygons","mapZoom","featureGroup","shoudLoadDependentMapObjects","exports"],"sources":["../../../src/Widgets/Map/Map.tsx"],"sourcesContent":["// @ts-ignore\nimport * as L from 'leaflet';\nimport 'src/utilities/polylinedecorator';\nimport 'leaflet.markercluster';\nimport 'leaflet.pattern';\nimport 'leaflet.heat';\nimport React, {\n  CSSProperties,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from 'react';\nimport { useDispatch } from 'react-redux';\nimport { IArea } from 'src/store/areas/models/IArea';\nimport { IEdge } from 'src/store/edges/models/IEdge';\nimport { IEvent } from 'src/store/events/models/IEvent';\n// import { storeMap } from 'src/store/global/actions';\nimport { IGlobalState } from 'src/store/global/models/IGlobalState';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport ErrorBoundary from 'src/utilities/ErrorBoundary';\nimport { AreaPolygons } from './areas/AreaPolygons';\nimport Edges from './edges/Edges';\nimport './Map.scss';\nimport './points/PointIcon.scss';\nimport { PointMarkers } from './points/PointMarkers';\n// import { appReducer } from '../../store/rootReducer';\nimport { Event } from './events/Event';\nimport {\n  areaFocusLogic,\n  filterEdges,\n  filterPoints,\n  initializeMap,\n  isValidArea,\n  setupCheckboxListener,\n  shoudLoadDependentMapObjects,\n  shouldLoadMapObjects,\n  zoomLevels,\n} from './MapUtils';\nimport { leafletMap } from '../../styles/theme/theme';\nimport { useSelectedItem } from 'src/pages/DashboardMap/ListContext';\nrequire('leaflet.markercluster');\n\ninterface MapProps {\n  areas: IArea[];\n  edges?: IEdge[];\n  points?: IPoint[];\n  global_data: IGlobalState;\n  areaToCenterBy?: any;\n  focusedEvent?: IEvent | null;\n  hoveredEvent?: IEvent | null;\n  hideEdges?: boolean;\n  mapBoxStyle?: string;\n  children?: any;\n  style?: CSSProperties;\n  includeUnmonitoredPoints?: boolean;\n  includeUnmonitoredDescendantsForEdges?: boolean;\n  forEventsView: boolean;\n  forWWTPDashboard?: boolean;\n}\n\nexport const Map: React.FC<MapProps> = ({\n  areas,\n  edges,\n  points,\n  global_data,\n  areaToCenterBy,\n  focusedEvent,\n  hoveredEvent,\n  hideEdges = false,\n  mapBoxStyle = leafletMap.mapDefault,\n  children,\n  includeUnmonitoredPoints = true,\n  includeUnmonitoredDescendantsForEdges = false,\n  forEventsView = false,\n  style = {},\n  forWWTPDashboard = false,\n}) => {\n  const { map } = global_data;\n  const mapRef = useRef<L.Map | null>(null);\n  const dispatch = useDispatch();\n  const [mapZoomLevel, setMapZoomLevel] = useState(2);\n  const { selectedItem } = useSelectedItem();\n  // const eventsData = useSelector(\n  //   (state: ReturnType<typeof appReducer>) => state.events_data,\n  // );\n  const hoveredEventPresent = useMemo(() => {\n    return hoveredEvent !== null && hoveredEvent !== undefined;\n  }, [hoveredEvent]);\n\n  const focusedEventPresent = useMemo(() => {\n    return focusedEvent !== null && focusedEvent !== undefined;\n  }, [focusedEvent]);\n\n  // Add parent layer group for all factories\n  const [factoriesParentGroup] = useState(L.layerGroup());\n  const [unmonitoredFactoriesGroup] = useState(L.layerGroup());\n  const [monitoredFactoriesGroup] = useState(L.layerGroup());\n  const [unmonitoredEdgesGroup] = useState(L.layerGroup());\n  const [monitoredEdgesGroup] = useState(L.layerGroup());\n  const [wwtpsLayerGroup] = useState(L.layerGroup());\n  const [collectorsLayerGroup] = useState(L.layerGroup());\n  const [areasLayerGroup] = useState(new L.FeatureGroup());\n  const [edgesCheckbox, setEdgesCheckbox] = useState(true);\n  const renderPointMarkers = (filteredPoints, mapRef, props) =>\n    mapRef.current !== null &&\n    points && (\n      <PointMarkers map={mapRef.current} points={filteredPoints} {...props} />\n    );\n\n  const memoizedMonitoredPoints = () => {\n    const monitoredPoints = filterPoints(points, true);\n    return renderPointMarkers(monitoredPoints, mapRef, {\n      includeUnmonitoredPoints: true,\n      rerender: zoomLevels[mapZoomLevel],\n      factoriesGroup: monitoredFactoriesGroup,\n      wwtpsGroup: wwtpsLayerGroup,\n      collectorsGroup: collectorsLayerGroup,\n      forEventsView: forEventsView,\n    });\n  };\n\n  const memoizedUnmonitoredPoints = () => {\n    const unmonitoredPoints = filterPoints(points, false);\n    return renderPointMarkers(unmonitoredPoints, mapRef, {\n      includeUnmonitoredPoints: true,\n      rerender: zoomLevels[mapZoomLevel],\n      factoriesGroup: unmonitoredFactoriesGroup,\n      wwtpsGroup: wwtpsLayerGroup,\n      collectorsGroup: collectorsLayerGroup,\n      forEventsView: forEventsView,\n    });\n  };\n\n  const renderEdges = (filteredEdges, mapRef, edgesCheckbox, props) =>\n    mapRef.current !== null &&\n    edgesCheckbox && (\n      <Edges edges={filteredEdges} map={mapRef.current} {...props} />\n    );\n\n  const memoizedEdges = useMemo(() => {\n    const monitoredEdges = filterEdges(edges, points, true);\n    return renderEdges(monitoredEdges, mapRef, edgesCheckbox, {\n      L,\n      points,\n      hideEdges,\n      hideArrows: true,\n      allowUnmonitoredDescendants: includeUnmonitoredDescendantsForEdges,\n      group: monitoredEdgesGroup,\n    });\n  }, [mapRef.current, points, focusedEventPresent, mapZoomLevel]);\n\n  const memoizedUnmonitoredEdges = useMemo(() => {\n    const unmonitoredEdges = filterEdges(edges, points, false);\n    return renderEdges(unmonitoredEdges, mapRef, edgesCheckbox, {\n      L,\n      points,\n      hideEdges,\n      hideArrows: true,\n      allowUnmonitoredDescendants: includeUnmonitoredDescendantsForEdges,\n      group: unmonitoredEdgesGroup,\n      shouldntDraw: unmonitoredEdgesGroup.getLayers().length !== 0,\n    });\n  }, [mapRef.current, points, focusedEventPresent, mapZoomLevel]);\n\n  const handleEdgesCheckboxChange = (isChecked) => {\n    setEdgesCheckbox(isChecked);\n  };\n\n  // This variable stores the zoom levels the edges are displayed\n  // It is used in two places in the code, so it is better to store it in one place\n  const edgesZoomLevels = ['Small', 'Medium', 'MLarge', 'Large'];\n\n  const handlePointsCheckboxChange = (isChecked) => {\n    if (mapRef.current !== null) {\n      let zoom = zoomLevels[mapRef.current.getZoom()];\n\n      if (isChecked) {\n        // Hide unmonitored points when \"show only monitored\" is checked\n        factoriesParentGroup.removeLayer(unmonitoredFactoriesGroup);\n        unmonitoredEdgesGroup.removeFrom(mapRef.current);\n      } else {\n        // Show all points when \"show only monitored\" is unchecked\n        factoriesParentGroup.addLayer(unmonitoredFactoriesGroup);\n\n        // Show unmonitored edges if at appropriate zoom level\n        if (edgesZoomLevels.includes(zoom)) {\n          unmonitoredEdgesGroup.addTo(mapRef.current);\n        }\n      }\n    }\n  };\n\n  const trackLayerbox = () => {\n    setupCheckboxListener('#edges-checkbox', handleEdgesCheckboxChange);\n    setupCheckboxListener(\n      '#monitored-points-checkbox',\n      handlePointsCheckboxChange,\n    );\n  };\n\n  const zoomRulesForEventsView = () => {\n    const payload = (\n      <>\n        {memoizedEdges}\n        {memoizedUnmonitoredEdges}\n        {memoizedUnmonitoredPoints()}\n        {memoizedMonitoredPoints()}\n      </>\n    );\n\n    return payload;\n  };\n\n  const zoomRulesForDashaboardMaps = () => {\n    let payload = (\n      <>\n        {memoizedUnmonitoredPoints()}\n        {memoizedMonitoredPoints()}\n      </>\n    );\n    if (forEventsView || edgesZoomLevels.includes(zoomLevels[mapZoomLevel])) {\n      payload = zoomRulesForEventsView();\n    }\n\n    return payload;\n  };\n\n  const memoizedZoomControl = () => {\n    const payload = forEventsView\n      ? zoomRulesForEventsView()\n      : zoomRulesForDashaboardMaps();\n\n    const checkbox = document.querySelector(\n      '#monitored-points-checkbox',\n    ) as HTMLInputElement;\n    if (checkbox) {\n      handlePointsCheckboxChange(checkbox.checked);\n    }\n    return payload;\n  };\n\n  const memoizedEvent = () => {\n    if (focusedEventPresent) {\n      focusedEvent!.focused = focusedEventPresent;\n      focusedEvent!.hovered = !focusedEventPresent;\n    }\n\n    if (hoveredEventPresent) {\n      hoveredEvent!.hovered = hoveredEventPresent;\n      hoveredEvent!.focused = !hoveredEventPresent;\n    }\n\n    if (!hoveredEventPresent && !focusedEventPresent) return <></>;\n    return (\n      <Event\n        event={focusedEvent! || hoveredEvent!}\n        map={map}\n        edges={edges!}\n        points={points!}\n        includeNetwork={!hoveredEventPresent}\n      />\n    );\n  };\n\n  // useEffect(() => {\n  //   return function cleanup() {\n  //     collectorsLayerGroup.clearLayers();\n  //     mapRef.current?.removeLayer(collectorsLayerGroup);\n  //   };\n  // }, [focusedEvent, hoveredEvent, global_data.eventFilterParam]);\n\n  // useEffect(() => {\n  //   initializeMap(\n  //     mapZoomLevel,\n  //     mapBoxStyle,\n  //     leafletMap.satellite,\n  //     mapRef,\n  //     dispatch,\n  //     isValidArea,\n  //     areaToCenterBy,\n  //     setMapZoomLevel,\n  //     forWWTPDashboard,\n  //     true,\n  //     global_data.waterAuthorityId,\n  //   );\n\n  //   return function cleanup() {\n  //     wwtpsLayerGroup.clearLayers();\n  //     collectorsLayerGroup.clearLayers();\n  //     areasLayerGroup.clearLayers();\n  //     mapRef.current?.removeLayer(wwtpsLayerGroup);\n  //     mapRef.current?.removeLayer(collectorsLayerGroup);\n  //     mapRef.current?.removeLayer(areasLayerGroup);\n  //     // @ts-ignore\n  //     mapRef.current.remove();\n  //     dispatch(storeMap(undefined));\n  //   };\n  // }, [global_data.waterAuthorityId]);\n\n  useEffect(() => {\n    if (!mapRef.current) {\n      initializeMap(\n        mapZoomLevel,\n        mapBoxStyle,\n        leafletMap.satellite,\n        mapRef,\n        dispatch,\n        isValidArea,\n        areaToCenterBy,\n        setMapZoomLevel,\n        true,\n        global_data.waterAuthorityId,\n      );\n\n      // Initialize parent factory group\n      if (mapRef.current) {\n        factoriesParentGroup.addTo(mapRef.current);\n        factoriesParentGroup.addLayer(monitoredFactoriesGroup);\n        factoriesParentGroup.addLayer(unmonitoredFactoriesGroup);\n      }\n    } else {\n      // setMapZoomLevel(mapRef.current.getZoom());\n      if (!areaToCenterBy) {\n        areaToCenterBy = areas.map((area) => area.shape_data).flat();\n      }\n\n      if (!forEventsView || !focusedEvent) {\n        areaFocusLogic(mapRef, isValidArea, areaToCenterBy);\n      }\n\n      trackLayerbox();\n    }\n  }, [mapRef.current, points]);\n\n  useEffect(() => {\n    if (!mapRef.current) {\n      return;\n    }\n\n    // return () => {\n    //   mapRef.current?.clearLayers();\n    //   mapRef.current?.off();\n    //   mapRef.current?.remove();\n    //   mapRef.current = null;\n    //   dispatch(storeMap(undefined));\n    // };\n\n    if (zoomLevels[mapZoomLevel] === 'XLarge') {\n      mapRef.current.removeLayer(factoriesParentGroup);\n    } else {\n      mapRef.current.addLayer(factoriesParentGroup);\n    }\n  }, [mapZoomLevel]);\n\n  useEffect(() => {\n    let clicked = false;\n\n    mapRef.current?.eachLayer((layer) => {\n      if (clicked) return;\n\n      if (\n        layer?.kando_object_id === selectedItem &&\n        layer.isPopupOpen() === false\n      ) {\n        if (layer instanceof L.Marker) {\n          layer.fire('click');\n        } else if (layer instanceof L.Polygon) {\n          layer.fire('click-event');\n        }\n        clicked = true;\n      }\n    });\n  }, [selectedItem]);\n\n  return (\n    <div className=\"kd-map-container\" style={style}>\n      <div\n        className={` map-container ${\n          global_data.sidenavExpanded ? '' : 'map-container--sidenav-collapsed'\n        }`}\n      >\n        <ErrorBoundary>\n          <div id=\"map\">\n            {shouldLoadMapObjects(global_data, mapRef, edges, points) && (\n              <AreaPolygons\n                areas={areas}\n                map={mapRef.current}\n                L={L}\n                areaToCenterBy={areaToCenterBy}\n                mapZoom={mapZoomLevel}\n                global_data={global_data}\n                featureGroup={areasLayerGroup}\n              />\n            )}\n            {shoudLoadDependentMapObjects(\n              edges,\n              areas,\n              global_data,\n              mapRef,\n              points,\n            ) && (\n              <>\n                {memoizedEvent()}\n                {memoizedZoomControl()}\n                {children}\n              </>\n            )}\n          </div>\n        </ErrorBoundary>\n      </div>\n    </div>\n  );\n};\n"],"mappings":"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"}
@@ -102,7 +102,7 @@ var AreaPolygon = function AreaPolygon(props) {
102
102
  };
103
103
  var isPolygonChangedColor = function isPolygonChangedColor(polygon, area) {
104
104
  if (!polygon) return true;
105
- var areaColor = (0, _scoreToData.scoreToColor)(area.area_score);
105
+ var areaColor = (0, _scoreToData.objectToColor)(area);
106
106
  var polygonColor = polygon.options.color;
107
107
  return areaColor !== polygonColor;
108
108
  };
@@ -130,4 +130,4 @@ var AreaPolygon = function AreaPolygon(props) {
130
130
  var connector = (0, _reactRedux.connect)(null);
131
131
  var _default = connector(AreaPolygon);
132
132
  exports.default = _default;
133
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRedux","_AreaUtils","_reactDom","_interopRequireDefault","_Widget","_utils","_scoreToData","_Capacity","_reactRouterDom","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","AreaPolygon","props","map","area","mapZoom","global_data","featureGroup","points","useSelector","state","points_data","items","areas","areas_data","WWTPMode","wwtp_dashboard","capacity","waterAuthorityIsCapacity","dispatch","useDispatch","history","useHistory","WWTPMapLogic","polygon","fetchDataAndShowPopup","_ref","_asyncToGenerator2","_regenerator","mark","_callee","widgetContainer","type","wrap","_callee$","_context","prev","next","document","createElement","createPopupForObject","renderedElement","marker","is_virtual","fetchCapacity","area_id","waterAuthorityId","then","listData","ReactDOM","render","Widget","object","isPopupOpen","openPopup","stop","apply","arguments","on","closePopup","openTooltip","subject","sendAnalyticsEvent","area_name","getPolygon","id","eachLayer","layer","kando_object_id","isPolygonChangedColor","areaColor","scoreToColor","area_score","polygonColor","options","color","useEffect","getAreaId","existingPolygon","createPolygon","subAreas","sub_areas","subArea","length","removeLayer","fire","Fragment","connector","connect","_default","exports"],"sources":["../../../../src/Widgets/Map/areas/AreaPolygon.tsx"],"sourcesContent":["import React, { useEffect } from 'react';\nimport { connect, useDispatch, useSelector } from 'react-redux';\nimport { IArea } from 'src/store/areas/models/IArea';\nimport { createPolygon } from './AreaUtils';\nimport ReactDOM from 'react-dom';\nimport { Widget } from 'src/pages/DashboardMap/Widget';\nimport {\n  createPopupForObject,\n  sendAnalyticsEvent,\n} from 'src/pages/DashboardMap/utils';\nimport { FeatureGroup } from 'leaflet';\nimport { scoreToColor } from 'src/utilities/scoreToData';\nimport { fetchCapacity } from 'src/pages/DashboardMap/Capacity';\nimport { useHistory } from 'react-router-dom';\nimport { getAreaId } from './AreaUtils';\n\ntype Props = {\n  map: any;\n  L: any;\n  area: IArea & { color?: string; showColorOnlyInBorders?: boolean };\n  mapZoom: number;\n  global_data: any;\n  bindPopup?: boolean;\n  featureGroup: FeatureGroup;\n};\n\nconst AreaPolygon: React.FC<Props> = (props) => {\n  const { map, area, mapZoom, global_data, featureGroup } = props;\n  const points = useSelector((state) => state.points_data.items);\n  const areas = useSelector((state) => state.areas_data.items);\n  const WWTPMode = useSelector((state) => state.wwtp_dashboard.map !== null);\n  const capacity = global_data.waterAuthorityIsCapacity;\n  const dispatch = useDispatch();\n  const history = useHistory();\n\n  const WWTPMapLogic = (polygon, area) => {\n    if (!WWTPMode || !capacity) return;\n\n    const fetchDataAndShowPopup = async () => {\n      const widgetContainer = document.createElement('span');\n\n      createPopupForObject({\n        renderedElement: widgetContainer,\n        marker: polygon,\n      });\n\n      const type = area?.is_virtual === true ? 'varea' : 'area';\n      fetchCapacity(type, area.area_id, global_data.waterAuthorityId).then(\n        (listData) => {\n          ReactDOM.render(\n            <Widget\n              object={area}\n              dispatch={dispatch}\n              areas={areas}\n              points={points}\n              map={map}\n              global_data={global_data}\n              listData={listData}\n              history={history}\n            />,\n            widgetContainer,\n          );\n        },\n      );\n\n      if (!polygon.isPopupOpen()) {\n        polygon.openPopup();\n      }\n    };\n\n    polygon.on('click-event', () => {\n      polygon.isPopupOpen() ? polygon.closePopup() : fetchDataAndShowPopup();\n      polygon.openTooltip();\n    });\n\n    polygon.on('click', () => {\n      fetchDataAndShowPopup();\n\n      const subject = 'Map View - Area clicked';\n      sendAnalyticsEvent(subject, 'map', {\n        area_id: area.area_id,\n        area_name: area.area_name,\n      });\n    });\n  };\n\n  const getPolygon = (id: string) => {\n    let polygon;\n    featureGroup.eachLayer((layer) => {\n      if (layer.kando_object_id === id) {\n        polygon = layer;\n      }\n    });\n    return polygon;\n  };\n\n  const isPolygonChangedColor = (polygon, area) => {\n    if (!polygon) return true;\n    const areaColor = scoreToColor(area.area_score);\n    const polygonColor = polygon.options.color;\n    return areaColor !== polygonColor;\n  };\n\n  useEffect(() => {\n    const area_id = getAreaId(area);\n    const existingPolygon = getPolygon(area_id);\n\n    if (isPolygonChangedColor(existingPolygon, area)) {\n      const polygon = createPolygon(\n        area,\n        mapZoom,\n        featureGroup,\n        map,\n        WWTPMapLogic,\n      );\n\n      if (polygon) {\n        const subAreas = area.sub_areas.map((subArea) => subArea.area_id);\n        if (subAreas.length > 0) {\n          polygon['sub_areas'] = subAreas;\n        }\n      }\n\n      if (existingPolygon && featureGroup && map) {\n        featureGroup.removeLayer(existingPolygon);\n        map.fire('zoomend');\n      }\n    }\n  }, [area, mapZoom, map, featureGroup]);\n\n  return <></>;\n};\n\nconst connector = connect(null);\nexport default connector(AreaPolygon);\n"],"mappings":"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"}
133
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRedux","_AreaUtils","_reactDom","_interopRequireDefault","_Widget","_utils","_scoreToData","_Capacity","_reactRouterDom","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","AreaPolygon","props","map","area","mapZoom","global_data","featureGroup","points","useSelector","state","points_data","items","areas","areas_data","WWTPMode","wwtp_dashboard","capacity","waterAuthorityIsCapacity","dispatch","useDispatch","history","useHistory","WWTPMapLogic","polygon","fetchDataAndShowPopup","_ref","_asyncToGenerator2","_regenerator","mark","_callee","widgetContainer","type","wrap","_callee$","_context","prev","next","document","createElement","createPopupForObject","renderedElement","marker","is_virtual","fetchCapacity","area_id","waterAuthorityId","then","listData","ReactDOM","render","Widget","object","isPopupOpen","openPopup","stop","apply","arguments","on","closePopup","openTooltip","subject","sendAnalyticsEvent","area_name","getPolygon","id","eachLayer","layer","kando_object_id","isPolygonChangedColor","areaColor","objectToColor","polygonColor","options","color","useEffect","getAreaId","existingPolygon","createPolygon","subAreas","sub_areas","subArea","length","removeLayer","fire","Fragment","connector","connect","_default","exports"],"sources":["../../../../src/Widgets/Map/areas/AreaPolygon.tsx"],"sourcesContent":["import React, { useEffect } from 'react';\nimport { connect, useDispatch, useSelector } from 'react-redux';\nimport { IArea } from 'src/store/areas/models/IArea';\nimport { createPolygon } from './AreaUtils';\nimport ReactDOM from 'react-dom';\nimport { Widget } from 'src/pages/DashboardMap/Widget';\nimport {\n  createPopupForObject,\n  sendAnalyticsEvent,\n} from 'src/pages/DashboardMap/utils';\nimport { FeatureGroup } from 'leaflet';\nimport { objectToColor } from 'src/utilities/scoreToData';\nimport { fetchCapacity } from 'src/pages/DashboardMap/Capacity';\nimport { useHistory } from 'react-router-dom';\nimport { getAreaId } from './AreaUtils';\n\ntype Props = {\n  map: any;\n  L: any;\n  area: IArea & { color?: string; showColorOnlyInBorders?: boolean };\n  mapZoom: number;\n  global_data: any;\n  bindPopup?: boolean;\n  featureGroup: FeatureGroup;\n};\n\nconst AreaPolygon: React.FC<Props> = (props) => {\n  const { map, area, mapZoom, global_data, featureGroup } = props;\n  const points = useSelector((state) => state.points_data.items);\n  const areas = useSelector((state) => state.areas_data.items);\n  const WWTPMode = useSelector((state) => state.wwtp_dashboard.map !== null);\n  const capacity = global_data.waterAuthorityIsCapacity;\n  const dispatch = useDispatch();\n  const history = useHistory();\n\n  const WWTPMapLogic = (polygon, area) => {\n    if (!WWTPMode || !capacity) return;\n\n    const fetchDataAndShowPopup = async () => {\n      const widgetContainer = document.createElement('span');\n\n      createPopupForObject({\n        renderedElement: widgetContainer,\n        marker: polygon,\n      });\n\n      const type = area?.is_virtual === true ? 'varea' : 'area';\n      fetchCapacity(type, area.area_id, global_data.waterAuthorityId).then(\n        (listData) => {\n          ReactDOM.render(\n            <Widget\n              object={area}\n              dispatch={dispatch}\n              areas={areas}\n              points={points}\n              map={map}\n              global_data={global_data}\n              listData={listData}\n              history={history}\n            />,\n            widgetContainer,\n          );\n        },\n      );\n\n      if (!polygon.isPopupOpen()) {\n        polygon.openPopup();\n      }\n    };\n\n    polygon.on('click-event', () => {\n      polygon.isPopupOpen() ? polygon.closePopup() : fetchDataAndShowPopup();\n      polygon.openTooltip();\n    });\n\n    polygon.on('click', () => {\n      fetchDataAndShowPopup();\n\n      const subject = 'Map View - Area clicked';\n      sendAnalyticsEvent(subject, 'map', {\n        area_id: area.area_id,\n        area_name: area.area_name,\n      });\n    });\n  };\n\n  const getPolygon = (id: string) => {\n    let polygon;\n    featureGroup.eachLayer((layer) => {\n      if (layer.kando_object_id === id) {\n        polygon = layer;\n      }\n    });\n    return polygon;\n  };\n\n  const isPolygonChangedColor = (polygon, area) => {\n    if (!polygon) return true;\n    const areaColor = objectToColor(area);\n    const polygonColor = polygon.options.color;\n    return areaColor !== polygonColor;\n  };\n\n  useEffect(() => {\n    const area_id = getAreaId(area);\n    const existingPolygon = getPolygon(area_id);\n\n    if (isPolygonChangedColor(existingPolygon, area)) {\n      const polygon = createPolygon(\n        area,\n        mapZoom,\n        featureGroup,\n        map,\n        WWTPMapLogic,\n      );\n\n      if (polygon) {\n        const subAreas = area.sub_areas.map((subArea) => subArea.area_id);\n        if (subAreas.length > 0) {\n          polygon['sub_areas'] = subAreas;\n        }\n      }\n\n      if (existingPolygon && featureGroup && map) {\n        featureGroup.removeLayer(existingPolygon);\n        map.fire('zoomend');\n      }\n    }\n  }, [area, mapZoom, map, featureGroup]);\n\n  return <></>;\n};\n\nconst connector = connect(null);\nexport default connector(AreaPolygon);\n"],"mappings":"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"}
@@ -44,7 +44,7 @@ var Edge = function Edge(_ref) {
44
44
  if (sourcePoint[0] === undefined || targetPoint[0] === undefined) return;
45
45
  var polylineBack = L.polyline(latlngs, {
46
46
  color: 'rgb(227,227,227)',
47
- weight: hideEdges ? 0 : 6,
47
+ weight: hideEdges ? 0 : 1,
48
48
  opacity: hideEdges ? 0 : 1
49
49
  });
50
50
  polylineBack.bindPopup("Edge ID: ".concat(edge.id, ",<br>\n Source point: ").concat(sourcePoint[0].group.name, ",<br>\n Target point: ").concat(targetPoint[0].group.name, ",\n Distance: ").concat(edge.distance));
@@ -52,7 +52,7 @@ var Edge = function Edge(_ref) {
52
52
  polylineBack['kando_object'] = 'Edge';
53
53
  polylineBack.bringToFront();
54
54
  var polylineFront = L.polyline(latlngs, {
55
- color: 'rgb(157,157,157)',
55
+ color: '#555',
56
56
  weight: hideEdges ? 0 : 1,
57
57
  opacity: hideEdges ? 0 : 1
58
58
  });
@@ -65,16 +65,16 @@ var Edge = function Edge(_ref) {
65
65
  patterns: [
66
66
  // defines a pattern of 10px-wide dashes, repeated every 20px on the line
67
67
  {
68
- offset: 15,
69
- repeat: 25,
68
+ offset: 20,
69
+ repeat: 60,
70
70
  symbol: window.L.Symbol.arrowHead({
71
- pixelSize: 3,
71
+ pixelSize: 4,
72
72
  polygon: false,
73
73
  pathOptions: {
74
74
  stroke: true,
75
75
  color: 'rgb(148,148,148)',
76
76
  weight: hideEdges ? 0 : 1,
77
- opacity: hideEdges ? 0 : 1
77
+ opacity: hideEdges ? 0 : 0.8
78
78
  }
79
79
  })
80
80
  }]
@@ -106,4 +106,4 @@ var Edge = function Edge(_ref) {
106
106
  var connector = (0, _reactRedux.connect)(null);
107
107
  var _default = connector(Edge);
108
108
  exports.default = _default;
109
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRedux","_actions","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","Edge","_ref","L","map","edge","points","_ref$hideEdges","hideEdges","_ref$allowUnmonitored","allowUnmonitoredDescendants","specificEvent","group","dispatch","useDispatch","shapeDataExist","keys","shape_data","length","find","data","lat","lng","undefined","useEffect","latlngs","forEach","push","sourcePoint","filter","point","id","source_point_id","targetPoint","target_point_id","polylineBack","polyline","color","weight","opacity","bindPopup","concat","name","distance","bringToFront","polylineFront","tailDash","window","Symbol","polylineDecorator","_latlngs","patterns","offset","repeat","symbol","arrowHead","pixelSize","polygon","pathOptions","stroke","layer","addLayer","addTo","setHoveredEdgePaths","setTimeout","on","createElement","connector","connect","_default","exports"],"sources":["../../../../src/Widgets/Map/edges/Edge.tsx"],"sourcesContent":["import React, { useEffect } from 'react';\nimport { connect, ConnectedProps, useDispatch } from 'react-redux';\nimport { IEdge } from 'src/store/edges/models/IEdge';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport './Edge.scss';\nimport { IEvent } from '../../../store/events/models/IEvent';\nimport { setHoveredEdgePaths } from '../../../store/events/actions';\ntype Props = ConnectedProps<typeof connector> & {\n  map: any;\n  L: any;\n  edge: IEdge;\n  points: any;\n  hideEdges?: boolean;\n  specificEvent?: IEvent;\n  allowUnmonitoredDescendants?: boolean;\n  group: any;\n};\n\nconst Edge: React.FC<Props> = ({\n  L,\n  map,\n  edge,\n  points,\n  hideEdges = false,\n  allowUnmonitoredDescendants = false,\n  specificEvent,\n  group,\n}) => {\n  const dispatch = useDispatch();\n  const shapeDataExist = () => {\n    return (\n      Object.keys(edge.shape_data).length !== 0 &&\n      edge.shape_data.find(\n        (data: any) => data.lat === null || data.lng === null,\n      ) === undefined\n    );\n  };\n\n  useEffect(() => {\n    if (shapeDataExist()) {\n      let latlngs: any = [];\n      edge.shape_data.forEach((data: any) => {\n        latlngs.push([data.lat, data.lng]);\n      });\n\n      let sourcePoint = points.filter(\n        (point: IPoint) => point.id === edge.source_point_id,\n      );\n      let targetPoint = points.filter(\n        (point: IPoint) => point.id === edge.target_point_id,\n      );\n\n      if (points.length === 0) return;\n      if (sourcePoint[0] === undefined || targetPoint[0] === undefined) return;\n\n      let polylineBack: any = L.polyline(latlngs, {\n        color: 'rgb(227,227,227)',\n        weight: hideEdges ? 0 : 6,\n        opacity: hideEdges ? 0 : 1,\n      });\n\n      polylineBack.bindPopup(`Edge ID: ${edge.id},<br>\n                                  Source point: ${sourcePoint[0].group.name},<br>\n                                  Target point: ${targetPoint[0].group.name},\n                                  Distance: ${edge.distance}`);\n\n      polylineBack['kando_object_id'] = edge.id;\n      polylineBack['kando_object'] = 'Edge';\n\n      polylineBack.bringToFront();\n\n      let polylineFront: any = L.polyline(latlngs, {\n        color: 'rgb(157,157,157)',\n        weight: hideEdges ? 0 : 1,\n        opacity: hideEdges ? 0 : 1,\n      });\n\n      polylineFront['kando_object_id'] = edge.id;\n      polylineFront['kando_object'] = 'EdgeFront';\n      polylineFront.bringToFront();\n\n      let tailDash: any;\n      if (window.L.Symbol !== undefined) {\n        tailDash = window.L.polylineDecorator(polylineBack._latlngs, {\n          patterns: [\n            // defines a pattern of 10px-wide dashes, repeated every 20px on the line\n            {\n              offset: 15,\n              repeat: 25,\n              symbol: window.L.Symbol.arrowHead({\n                pixelSize: 3,\n                polygon: false,\n                pathOptions: {\n                  stroke: true,\n                  color: 'rgb(148,148,148)',\n                  weight: hideEdges ? 0 : 1,\n                  opacity: hideEdges ? 0 : 1,\n                },\n              }),\n            },\n          ],\n        });\n        tailDash['kando_object'] = 'Arrow';\n      }\n\n      [polylineBack, polylineFront, tailDash].forEach((layer) => {\n        group.addLayer(layer);\n      });\n      group.addTo(map);\n\n      if (specificEvent !== undefined) {\n        dispatch(setHoveredEdgePaths([polylineBack, polylineFront]));\n      }\n\n      const bringToFront = () => {\n        polylineBack.bringToFront();\n        polylineFront.bringToFront();\n        tailDash.bringToFront();\n      };\n\n      setTimeout(() => {\n        bringToFront();\n      }, 100);\n\n      map.on('zoomend', function () {\n        bringToFront();\n      });\n    }\n  }, [edge, specificEvent]);\n\n  return <div></div>;\n};\n\nconst connector = connect(null);\nexport default connector(Edge);\n"],"mappings":"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"}
109
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRedux","_actions","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","Edge","_ref","L","map","edge","points","_ref$hideEdges","hideEdges","_ref$allowUnmonitored","allowUnmonitoredDescendants","specificEvent","group","dispatch","useDispatch","shapeDataExist","keys","shape_data","length","find","data","lat","lng","undefined","useEffect","latlngs","forEach","push","sourcePoint","filter","point","id","source_point_id","targetPoint","target_point_id","polylineBack","polyline","color","weight","opacity","bindPopup","concat","name","distance","bringToFront","polylineFront","tailDash","window","Symbol","polylineDecorator","_latlngs","patterns","offset","repeat","symbol","arrowHead","pixelSize","polygon","pathOptions","stroke","layer","addLayer","addTo","setHoveredEdgePaths","setTimeout","on","createElement","connector","connect","_default","exports"],"sources":["../../../../src/Widgets/Map/edges/Edge.tsx"],"sourcesContent":["import React, { useEffect } from 'react';\nimport { connect, ConnectedProps, useDispatch } from 'react-redux';\nimport { IEdge } from 'src/store/edges/models/IEdge';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport './Edge.scss';\nimport { IEvent } from '../../../store/events/models/IEvent';\nimport { setHoveredEdgePaths } from '../../../store/events/actions';\ntype Props = ConnectedProps<typeof connector> & {\n  map: any;\n  L: any;\n  edge: IEdge;\n  points: any;\n  hideEdges?: boolean;\n  specificEvent?: IEvent;\n  allowUnmonitoredDescendants?: boolean;\n  group: any;\n};\n\nconst Edge: React.FC<Props> = ({\n  L,\n  map,\n  edge,\n  points,\n  hideEdges = false,\n  allowUnmonitoredDescendants = false,\n  specificEvent,\n  group,\n}) => {\n  const dispatch = useDispatch();\n  const shapeDataExist = () => {\n    return (\n      Object.keys(edge.shape_data).length !== 0 &&\n      edge.shape_data.find(\n        (data: any) => data.lat === null || data.lng === null,\n      ) === undefined\n    );\n  };\n\n  useEffect(() => {\n    if (shapeDataExist()) {\n      let latlngs: any = [];\n      edge.shape_data.forEach((data: any) => {\n        latlngs.push([data.lat, data.lng]);\n      });\n\n      let sourcePoint = points.filter(\n        (point: IPoint) => point.id === edge.source_point_id,\n      );\n      let targetPoint = points.filter(\n        (point: IPoint) => point.id === edge.target_point_id,\n      );\n\n      if (points.length === 0) return;\n      if (sourcePoint[0] === undefined || targetPoint[0] === undefined) return;\n\n      let polylineBack: any = L.polyline(latlngs, {\n        color: 'rgb(227,227,227)',\n        weight: hideEdges ? 0 : 1,\n        opacity: hideEdges ? 0 : 1,\n      });\n\n      polylineBack.bindPopup(`Edge ID: ${edge.id},<br>\n                                  Source point: ${sourcePoint[0].group.name},<br>\n                                  Target point: ${targetPoint[0].group.name},\n                                  Distance: ${edge.distance}`);\n\n      polylineBack['kando_object_id'] = edge.id;\n      polylineBack['kando_object'] = 'Edge';\n\n      polylineBack.bringToFront();\n\n      let polylineFront: any = L.polyline(latlngs, {\n        color: '#555',\n        weight: hideEdges ? 0 : 1,\n        opacity: hideEdges ? 0 : 1,\n      });\n\n      polylineFront['kando_object_id'] = edge.id;\n      polylineFront['kando_object'] = 'EdgeFront';\n      polylineFront.bringToFront();\n\n      let tailDash: any;\n      if (window.L.Symbol !== undefined) {\n        tailDash = window.L.polylineDecorator(polylineBack._latlngs, {\n          patterns: [\n            // defines a pattern of 10px-wide dashes, repeated every 20px on the line\n            {\n              offset: 20,\n              repeat: 60,\n              symbol: window.L.Symbol.arrowHead({\n                pixelSize: 4,\n                polygon: false,\n                pathOptions: {\n                  stroke: true,\n                  color: 'rgb(148,148,148)',\n                  weight: hideEdges ? 0 : 1,\n                  opacity: hideEdges ? 0 : 0.8,\n                },\n              }),\n            },\n          ],\n        });\n        tailDash['kando_object'] = 'Arrow';\n      }\n\n      [polylineBack, polylineFront, tailDash].forEach((layer) => {\n        group.addLayer(layer);\n      });\n      group.addTo(map);\n\n      if (specificEvent !== undefined) {\n        dispatch(setHoveredEdgePaths([polylineBack, polylineFront]));\n      }\n\n      const bringToFront = () => {\n        polylineBack.bringToFront();\n        polylineFront.bringToFront();\n        tailDash.bringToFront();\n      };\n\n      setTimeout(() => {\n        bringToFront();\n      }, 100);\n\n      map.on('zoomend', function () {\n        bringToFront();\n      });\n    }\n  }, [edge, specificEvent]);\n\n  return <div></div>;\n};\n\nconst connector = connect(null);\nexport default connector(Edge);\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,WAAA,GAAAD,OAAA;AAGAA,OAAA;AAEA,IAAAE,QAAA,GAAAF,OAAA;AAAoE,SAAAG,yBAAAC,WAAA,eAAAC,OAAA,kCAAAC,iBAAA,OAAAD,OAAA,QAAAE,gBAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,yBAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAAL,wBAAAS,GAAA,EAAAJ,WAAA,SAAAA,WAAA,IAAAI,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,aAAAE,OAAA,CAAAF,GAAA,yBAAAA,GAAA,4BAAAG,OAAA,EAAAH,GAAA,UAAAI,KAAA,GAAAT,wBAAA,CAAAC,WAAA,OAAAQ,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAL,GAAA,YAAAI,KAAA,CAAAE,GAAA,CAAAN,GAAA,SAAAO,MAAA,WAAAC,qBAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,GAAA,IAAAZ,GAAA,QAAAY,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAf,GAAA,EAAAY,GAAA,SAAAI,IAAA,GAAAR,qBAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAX,GAAA,EAAAY,GAAA,cAAAI,IAAA,KAAAA,IAAA,CAAAV,GAAA,IAAAU,IAAA,CAAAC,GAAA,KAAAR,MAAA,CAAAC,cAAA,CAAAH,MAAA,EAAAK,GAAA,EAAAI,IAAA,YAAAT,MAAA,CAAAK,GAAA,IAAAZ,GAAA,CAAAY,GAAA,SAAAL,MAAA,CAAAJ,OAAA,GAAAH,GAAA,MAAAI,KAAA,IAAAA,KAAA,CAAAa,GAAA,CAAAjB,GAAA,EAAAO,MAAA,YAAAA,MAAA;AAYpE,IAAMW,IAAqB,GAAG,SAAxBA,IAAqBA,CAAAC,IAAA,EASrB;EAAA,IARJC,CAAC,GAAAD,IAAA,CAADC,CAAC;IACDC,GAAG,GAAAF,IAAA,CAAHE,GAAG;IACHC,IAAI,GAAAH,IAAA,CAAJG,IAAI;IACJC,MAAM,GAAAJ,IAAA,CAANI,MAAM;IAAAC,cAAA,GAAAL,IAAA,CACNM,SAAS;IAATA,SAAS,GAAAD,cAAA,cAAG,KAAK,GAAAA,cAAA;IAAAE,qBAAA,GAAAP,IAAA,CACjBQ,2BAA2B;IAA3BA,2BAA2B,GAAAD,qBAAA,cAAG,KAAK,GAAAA,qBAAA;IACnCE,aAAa,GAAAT,IAAA,CAAbS,aAAa;IACbC,KAAK,GAAAV,IAAA,CAALU,KAAK;EAEL,IAAMC,QAAQ,GAAG,IAAAC,uBAAW,EAAC,CAAC;EAC9B,IAAMC,cAAc,GAAG,SAAjBA,cAAcA,CAAA,EAAS;IAC3B,OACEvB,MAAM,CAACwB,IAAI,CAACX,IAAI,CAACY,UAAU,CAAC,CAACC,MAAM,KAAK,CAAC,IACzCb,IAAI,CAACY,UAAU,CAACE,IAAI,CAClB,UAACC,IAAS;MAAA,OAAKA,IAAI,CAACC,GAAG,KAAK,IAAI,IAAID,IAAI,CAACE,GAAG,KAAK,IAAI;IAAA,CACvD,CAAC,KAAKC,SAAS;EAEnB,CAAC;EAED,IAAAC,gBAAS,EAAC,YAAM;IACd,IAAIT,cAAc,CAAC,CAAC,EAAE;MACpB,IAAIU,OAAY,GAAG,EAAE;MACrBpB,IAAI,CAACY,UAAU,CAACS,OAAO,CAAC,UAACN,IAAS,EAAK;QACrCK,OAAO,CAACE,IAAI,CAAC,CAACP,IAAI,CAACC,GAAG,EAAED,IAAI,CAACE,GAAG,CAAC,CAAC;MACpC,CAAC,CAAC;MAEF,IAAIM,WAAW,GAAGtB,MAAM,CAACuB,MAAM,CAC7B,UAACC,KAAa;QAAA,OAAKA,KAAK,CAACC,EAAE,KAAK1B,IAAI,CAAC2B,eAAe;MAAA,CACtD,CAAC;MACD,IAAIC,WAAW,GAAG3B,MAAM,CAACuB,MAAM,CAC7B,UAACC,KAAa;QAAA,OAAKA,KAAK,CAACC,EAAE,KAAK1B,IAAI,CAAC6B,eAAe;MAAA,CACtD,CAAC;MAED,IAAI5B,MAAM,CAACY,MAAM,KAAK,CAAC,EAAE;MACzB,IAAIU,WAAW,CAAC,CAAC,CAAC,KAAKL,SAAS,IAAIU,WAAW,CAAC,CAAC,CAAC,KAAKV,SAAS,EAAE;MAElE,IAAIY,YAAiB,GAAGhC,CAAC,CAACiC,QAAQ,CAACX,OAAO,EAAE;QAC1CY,KAAK,EAAE,kBAAkB;QACzBC,MAAM,EAAE9B,SAAS,GAAG,CAAC,GAAG,CAAC;QACzB+B,OAAO,EAAE/B,SAAS,GAAG,CAAC,GAAG;MAC3B,CAAC,CAAC;MAEF2B,YAAY,CAACK,SAAS,aAAAC,MAAA,CAAapC,IAAI,CAAC0B,EAAE,6DAAAU,MAAA,CACEb,WAAW,CAAC,CAAC,CAAC,CAAChB,KAAK,CAAC8B,IAAI,6DAAAD,MAAA,CACzBR,WAAW,CAAC,CAAC,CAAC,CAACrB,KAAK,CAAC8B,IAAI,qDAAAD,MAAA,CAC7BpC,IAAI,CAACsC,QAAQ,CAAE,CAAC;MAExDR,YAAY,CAAC,iBAAiB,CAAC,GAAG9B,IAAI,CAAC0B,EAAE;MACzCI,YAAY,CAAC,cAAc,CAAC,GAAG,MAAM;MAErCA,YAAY,CAACS,YAAY,CAAC,CAAC;MAE3B,IAAIC,aAAkB,GAAG1C,CAAC,CAACiC,QAAQ,CAACX,OAAO,EAAE;QAC3CY,KAAK,EAAE,MAAM;QACbC,MAAM,EAAE9B,SAAS,GAAG,CAAC,GAAG,CAAC;QACzB+B,OAAO,EAAE/B,SAAS,GAAG,CAAC,GAAG;MAC3B,CAAC,CAAC;MAEFqC,aAAa,CAAC,iBAAiB,CAAC,GAAGxC,IAAI,CAAC0B,EAAE;MAC1Cc,aAAa,CAAC,cAAc,CAAC,GAAG,WAAW;MAC3CA,aAAa,CAACD,YAAY,CAAC,CAAC;MAE5B,IAAIE,QAAa;MACjB,IAAIC,MAAM,CAAC5C,CAAC,CAAC6C,MAAM,KAAKzB,SAAS,EAAE;QACjCuB,QAAQ,GAAGC,MAAM,CAAC5C,CAAC,CAAC8C,iBAAiB,CAACd,YAAY,CAACe,QAAQ,EAAE;UAC3DC,QAAQ,EAAE;UACR;UACA;YACEC,MAAM,EAAE,EAAE;YACVC,MAAM,EAAE,EAAE;YACVC,MAAM,EAAEP,MAAM,CAAC5C,CAAC,CAAC6C,MAAM,CAACO,SAAS,CAAC;cAChCC,SAAS,EAAE,CAAC;cACZC,OAAO,EAAE,KAAK;cACdC,WAAW,EAAE;gBACXC,MAAM,EAAE,IAAI;gBACZtB,KAAK,EAAE,kBAAkB;gBACzBC,MAAM,EAAE9B,SAAS,GAAG,CAAC,GAAG,CAAC;gBACzB+B,OAAO,EAAE/B,SAAS,GAAG,CAAC,GAAG;cAC3B;YACF,CAAC;UACH,CAAC;QAEL,CAAC,CAAC;QACFsC,QAAQ,CAAC,cAAc,CAAC,GAAG,OAAO;MACpC;MAEA,CAACX,YAAY,EAAEU,aAAa,EAAEC,QAAQ,CAAC,CAACpB,OAAO,CAAC,UAACkC,KAAK,EAAK;QACzDhD,KAAK,CAACiD,QAAQ,CAACD,KAAK,CAAC;MACvB,CAAC,CAAC;MACFhD,KAAK,CAACkD,KAAK,CAAC1D,GAAG,CAAC;MAEhB,IAAIO,aAAa,KAAKY,SAAS,EAAE;QAC/BV,QAAQ,CAAC,IAAAkD,4BAAmB,EAAC,CAAC5B,YAAY,EAAEU,aAAa,CAAC,CAAC,CAAC;MAC9D;MAEA,IAAMD,YAAY,GAAG,SAAfA,YAAYA,CAAA,EAAS;QACzBT,YAAY,CAACS,YAAY,CAAC,CAAC;QAC3BC,aAAa,CAACD,YAAY,CAAC,CAAC;QAC5BE,QAAQ,CAACF,YAAY,CAAC,CAAC;MACzB,CAAC;MAEDoB,UAAU,CAAC,YAAM;QACfpB,YAAY,CAAC,CAAC;MAChB,CAAC,EAAE,GAAG,CAAC;MAEPxC,GAAG,CAAC6D,EAAE,CAAC,SAAS,EAAE,YAAY;QAC5BrB,YAAY,CAAC,CAAC;MAChB,CAAC,CAAC;IACJ;EACF,CAAC,EAAE,CAACvC,IAAI,EAAEM,aAAa,CAAC,CAAC;EAEzB,oBAAOtC,MAAA,CAAAa,OAAA,CAAAgF,aAAA,YAAU,CAAC;AACpB,CAAC;AAED,IAAMC,SAAS,GAAG,IAAAC,mBAAO,EAAC,IAAI,CAAC;AAAC,IAAAC,QAAA,GACjBF,SAAS,CAAClE,IAAI,CAAC;AAAAqE,OAAA,CAAApF,OAAA,GAAAmF,QAAA"}