@kando-env/kando-ui 1.2.414-alpha.4 → 1.2.414-alpha.6

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.
@@ -67,6 +67,15 @@ var Map = function Map(_ref) {
67
67
  setMapZoomLevel = _useState2[1];
68
68
  var _useSelectedItem = (0, _ListContext.useSelectedItem)(),
69
69
  selectedItem = _useSelectedItem.selectedItem;
70
+ var _useState3 = (0, _react.useState)(true),
71
+ _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
72
+ edgesCheckbox = _useState4[0],
73
+ setEdgesCheckbox = _useState4[1];
74
+ var _useState5 = (0, _react.useState)(false),
75
+ _useState6 = (0, _slicedToArray2.default)(_useState5, 2),
76
+ onlyMonitoredPoints = _useState6[0],
77
+ setOnlyMonitoredPoints = _useState6[1];
78
+ var edgesCheckboxRef = (0, _react.useRef)(edgesCheckbox);
70
79
  var hoveredEventPresent = (0, _react.useMemo)(function () {
71
80
  return hoveredEvent !== null && hoveredEvent !== undefined;
72
81
  }, [hoveredEvent]);
@@ -75,34 +84,30 @@ var Map = function Map(_ref) {
75
84
  }, [focusedEvent]);
76
85
 
77
86
  // Add parent layer group for all factories
78
- var _useState3 = (0, _react.useState)(L.layerGroup()),
79
- _useState4 = (0, _slicedToArray2.default)(_useState3, 1),
80
- factoriesParentGroup = _useState4[0];
81
- var _useState5 = (0, _react.useState)(L.layerGroup()),
82
- _useState6 = (0, _slicedToArray2.default)(_useState5, 1),
83
- unmonitoredFactoriesGroup = _useState6[0];
84
87
  var _useState7 = (0, _react.useState)(L.layerGroup()),
85
88
  _useState8 = (0, _slicedToArray2.default)(_useState7, 1),
86
- monitoredFactoriesGroup = _useState8[0];
89
+ factoriesParentGroup = _useState8[0];
87
90
  var _useState9 = (0, _react.useState)(L.layerGroup()),
88
91
  _useState10 = (0, _slicedToArray2.default)(_useState9, 1),
89
- unmonitoredEdgesGroup = _useState10[0];
92
+ unmonitoredFactoriesGroup = _useState10[0];
90
93
  var _useState11 = (0, _react.useState)(L.layerGroup()),
91
94
  _useState12 = (0, _slicedToArray2.default)(_useState11, 1),
92
- monitoredEdgesGroup = _useState12[0];
95
+ monitoredFactoriesGroup = _useState12[0];
93
96
  var _useState13 = (0, _react.useState)(L.layerGroup()),
94
97
  _useState14 = (0, _slicedToArray2.default)(_useState13, 1),
95
- wwtpsLayerGroup = _useState14[0];
98
+ unmonitoredEdgesGroup = _useState14[0];
96
99
  var _useState15 = (0, _react.useState)(L.layerGroup()),
97
100
  _useState16 = (0, _slicedToArray2.default)(_useState15, 1),
98
- collectorsLayerGroup = _useState16[0];
99
- var _useState17 = (0, _react.useState)(new L.FeatureGroup()),
101
+ monitoredEdgesGroup = _useState16[0];
102
+ var _useState17 = (0, _react.useState)(L.layerGroup()),
100
103
  _useState18 = (0, _slicedToArray2.default)(_useState17, 1),
101
- areasLayerGroup = _useState18[0];
102
- var _useState19 = (0, _react.useState)(true),
103
- _useState20 = (0, _slicedToArray2.default)(_useState19, 2),
104
- edgesCheckbox = _useState20[0],
105
- setEdgesCheckbox = _useState20[1];
104
+ wwtpsLayerGroup = _useState18[0];
105
+ var _useState19 = (0, _react.useState)(L.layerGroup()),
106
+ _useState20 = (0, _slicedToArray2.default)(_useState19, 1),
107
+ collectorsLayerGroup = _useState20[0];
108
+ var _useState21 = (0, _react.useState)(new L.FeatureGroup()),
109
+ _useState22 = (0, _slicedToArray2.default)(_useState21, 1),
110
+ areasLayerGroup = _useState22[0];
106
111
  var renderPointMarkers = function renderPointMarkers(filteredPoints, mapRef, props) {
107
112
  return mapRef.current !== null && points && /*#__PURE__*/_react.default.createElement(_PointMarkers.PointMarkers, Object.assign({
108
113
  map: mapRef.current,
@@ -142,24 +147,24 @@ var Map = function Map(_ref) {
142
147
  return renderEdges(monitoredEdges, mapRef, edgesCheckbox, {
143
148
  L: L,
144
149
  points: points,
145
- hideEdges: hideEdges,
150
+ hideEdges: false,
146
151
  hideArrows: true,
147
152
  allowUnmonitoredDescendants: includeUnmonitoredDescendantsForEdges,
148
153
  group: monitoredEdgesGroup
149
154
  });
150
- }, [mapRef.current, points, focusedEventPresent, mapZoomLevel]);
155
+ }, [points, edgesCheckbox, mapZoomLevel]);
151
156
  var memoizedUnmonitoredEdges = (0, _react.useMemo)(function () {
157
+ if (onlyMonitoredPoints) return null;
152
158
  var unmonitoredEdges = (0, _MapUtils.filterEdges)(edges, points, false);
153
159
  return renderEdges(unmonitoredEdges, mapRef, edgesCheckbox, {
154
160
  L: L,
155
161
  points: points,
156
- hideEdges: hideEdges,
162
+ hideEdges: false,
157
163
  hideArrows: true,
158
164
  allowUnmonitoredDescendants: includeUnmonitoredDescendantsForEdges,
159
- group: unmonitoredEdgesGroup,
160
- shouldntDraw: unmonitoredEdgesGroup.getLayers().length !== 0
165
+ group: unmonitoredEdgesGroup
161
166
  });
162
- }, [mapRef.current, points, focusedEventPresent, mapZoomLevel]);
167
+ }, [points, edgesCheckbox, mapZoomLevel]);
163
168
  var handleEdgesCheckboxChange = function handleEdgesCheckboxChange(isChecked) {
164
169
  setEdgesCheckbox(isChecked);
165
170
  };
@@ -168,6 +173,7 @@ var Map = function Map(_ref) {
168
173
  // It is used in two places in the code, so it is better to store it in one place
169
174
  var edgesZoomLevels = ['Small', 'Medium', 'MLarge', 'Large'];
170
175
  var handlePointsCheckboxChange = function handlePointsCheckboxChange(isChecked) {
176
+ setOnlyMonitoredPoints(isChecked);
171
177
  if (mapRef.current !== null) {
172
178
  var zoom = _MapUtils.zoomLevels[mapRef.current.getZoom()];
173
179
  if (isChecked) {
@@ -179,7 +185,7 @@ var Map = function Map(_ref) {
179
185
  factoriesParentGroup.addLayer(unmonitoredFactoriesGroup);
180
186
 
181
187
  // Show unmonitored edges if at appropriate zoom level
182
- if (edgesZoomLevels.includes(zoom)) {
188
+ if (edgesCheckboxRef.current && edgesZoomLevels.includes(zoom)) {
183
189
  unmonitoredEdgesGroup.addTo(mapRef.current);
184
190
  }
185
191
  }
@@ -202,10 +208,6 @@ var Map = function Map(_ref) {
202
208
  };
203
209
  var memoizedZoomControl = function memoizedZoomControl() {
204
210
  var payload = forEventsView ? zoomRulesForEventsView() : zoomRulesForDashaboardMaps();
205
- var checkbox = document.querySelector('#monitored-points-checkbox');
206
- if (checkbox) {
207
- handlePointsCheckboxChange(checkbox.checked);
208
- }
209
211
  return payload;
210
212
  };
211
213
  var memoizedEvent = function memoizedEvent() {
@@ -226,6 +228,9 @@ var Map = function Map(_ref) {
226
228
  includeNetwork: !hoveredEventPresent
227
229
  });
228
230
  };
231
+ (0, _react.useEffect)(function () {
232
+ edgesCheckboxRef.current = edgesCheckbox;
233
+ }, [edgesCheckbox]);
229
234
  (0, _react.useEffect)(function () {
230
235
  return function cleanup() {
231
236
  var _mapRef$current;
@@ -264,6 +269,14 @@ var Map = function Map(_ref) {
264
269
  (0, _react.useEffect)(function () {
265
270
  if (!mapRef.current) {
266
271
  (0, _MapUtils.initializeMap)(mapZoomLevel, mapBoxStyle, _theme.leafletMap.satellite, mapRef, dispatch, _MapUtils.isValidArea, areaToCenterBy, setMapZoomLevel, forWWTPDashboard, true, global_data.waterAuthorityId);
272
+
273
+ // Initialize parent factory group
274
+ if (mapRef.current) {
275
+ factoriesParentGroup.addTo(mapRef.current);
276
+ factoriesParentGroup.addLayer(monitoredFactoriesGroup);
277
+ factoriesParentGroup.addLayer(unmonitoredFactoriesGroup);
278
+ }
279
+ trackLayerbox();
267
280
  } else {
268
281
  setMapZoomLevel(mapRef.current.getZoom());
269
282
  if (!areaToCenterBy) {
@@ -274,7 +287,6 @@ var Map = function Map(_ref) {
274
287
  if (!forEventsView || !focusedEvent) {
275
288
  (0, _MapUtils.areaFocusLogic)(mapRef, _MapUtils.isValidArea, areaToCenterBy);
276
289
  }
277
- trackLayerbox();
278
290
  }
279
291
  }, [areaToCenterBy]);
280
292
  (0, _react.useEffect)(function () {
@@ -316,4 +328,4 @@ var Map = function Map(_ref) {
316
328
  }, renderAreas(), (0, _MapUtils.shoudLoadDependentMapObjects)(edges, areas, global_data, mapRef, points) && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, memoizedEvent(), memoizedZoomControl(), children)))));
317
329
  };
318
330
  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","_actions","_actions2","_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","cleanup","_mapRef$current","clearLayers","eventFilterParam","clearPoints","clearAreas","eachLayer","layer","TileLayer","waterAuthorityId","initializeMap","satellite","isValidArea","area","shape_data","flat","areaFocusLogic","_mapRef$current2","clicked","kando_object_id","isPopupOpen","Marker","fire","Polygon","renderAreas","shouldLoadMapObjects","AreaPolygons","mapZoom","featureGroup","className","concat","sidenavExpanded","id","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';\nimport { clearAreas } from 'src/store/areas/actions';\nimport { clearPoints } from 'src/store/points/actions';\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 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\n    if (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    return function cleanup() {\n      if (forEventsView && mapRef.current) {\n        dispatch(clearPoints());\n        dispatch(clearAreas());\n        wwtpsLayerGroup.clearLayers();\n        areasLayerGroup.clearLayers();\n        monitoredEdgesGroup.clearLayers();\n        collectorsLayerGroup.clearLayers();\n        unmonitoredEdgesGroup.clearLayers();\n        monitoredFactoriesGroup.clearLayers();\n        unmonitoredFactoriesGroup.clearLayers();\n        factoriesParentGroup.clearLayers();\n        mapRef.current.removeLayer(unmonitoredEdgesGroup);\n        mapRef.current.removeLayer(monitoredEdgesGroup);\n        mapRef.current.removeLayer(wwtpsLayerGroup);\n        mapRef.current.removeLayer(collectorsLayerGroup);\n        mapRef.current.removeLayer(areasLayerGroup);\n        mapRef.current.removeLayer(factoriesParentGroup);\n\n        mapRef.current.eachLayer((layer) => {\n          if (layer instanceof L.TileLayer) {\n            return;\n          }\n          mapRef.current.removeLayer(layer);\n        });\n      }\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        forWWTPDashboard,\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      if (!forEventsView || !focusedEvent) {\n        areaFocusLogic(mapRef, isValidArea, areaToCenterBy);\n      }\n\n      trackLayerbox();\n    }\n  }, [areaToCenterBy]);\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  const renderAreas = () => {\n    if (!shouldLoadMapObjects(global_data, mapRef, edges, points)) {\n      return null;\n    }\n\n    return (\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  };\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            {renderAreas()}\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":";;;;;;;;;AACA,IAAAA,CAAA,GAAAC,uBAAA,CAAAC,OAAA;AACAA,OAAA;AACAA,OAAA;AACAA,OAAA;AACAA,OAAA;AACA,IAAAC,MAAA,GAAAF,uBAAA,CAAAC,OAAA;AAOA,IAAAE,WAAA,GAAAF,OAAA;AAOA,IAAAG,cAAA,GAAAC,sBAAA,CAAAJ,OAAA;AACA,IAAAK,aAAA,GAAAL,OAAA;AACA,IAAAM,MAAA,GAAAF,sBAAA,CAAAJ,OAAA;AACAA,OAAA;AACAA,OAAA;AACA,IAAAO,aAAA,GAAAP,OAAA;AAEA,IAAAQ,MAAA,GAAAR,OAAA;AACA,IAAAS,SAAA,GAAAT,OAAA;AAWA,IAAAU,MAAA,GAAAV,OAAA;AACA,IAAAW,YAAA,GAAAX,OAAA;AACA,IAAAY,QAAA,GAAAZ,OAAA;AACA,IAAAa,SAAA,GAAAb,OAAA;AAAuD,SAAAc,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,SAAAhB,wBAAAoB,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;AA1CvD;;AAiBA;;AASA;;AAiBA1B,OAAO,CAAC,uBAAuB,CAAC;AAoBzB,IAAMqC,GAAuB,GAAG,SAA1BA,GAAuBA,CAAAC,IAAA,EAgB9B;EAAA,IAfJC,KAAK,GAAAD,IAAA,CAALC,KAAK;IACLC,KAAK,GAAAF,IAAA,CAALE,KAAK;IACLC,MAAM,GAAAH,IAAA,CAANG,MAAM;IACNC,WAAW,GAAAJ,IAAA,CAAXI,WAAW;IACXC,cAAc,GAAAL,IAAA,CAAdK,cAAc;IACdC,YAAY,GAAAN,IAAA,CAAZM,YAAY;IACZC,YAAY,GAAAP,IAAA,CAAZO,YAAY;IAAAC,cAAA,GAAAR,IAAA,CACZS,SAAS;IAATA,SAAS,GAAAD,cAAA,cAAG,KAAK,GAAAA,cAAA;IAAAE,gBAAA,GAAAV,IAAA,CACjBW,WAAW;IAAXA,WAAW,GAAAD,gBAAA,cAAGE,iBAAU,CAACC,UAAU,GAAAH,gBAAA;IACnCI,QAAQ,GAAAd,IAAA,CAARc,QAAQ;IAAAC,qBAAA,GAAAf,IAAA,CACRgB,wBAAwB;IAAxBA,wBAAwB,GAAAD,qBAAA,cAAG,IAAI,GAAAA,qBAAA;IAAAE,sBAAA,GAAAjB,IAAA,CAC/BkB,qCAAqC;IAArCA,qCAAqC,GAAAD,sBAAA,cAAG,KAAK,GAAAA,sBAAA;IAAAE,kBAAA,GAAAnB,IAAA,CAC7CoB,aAAa;IAAbA,aAAa,GAAAD,kBAAA,cAAG,KAAK,GAAAA,kBAAA;IAAAE,UAAA,GAAArB,IAAA,CACrBsB,KAAK;IAALA,KAAK,GAAAD,UAAA,cAAG,CAAC,CAAC,GAAAA,UAAA;IAAAE,qBAAA,GAAAvB,IAAA,CACVwB,gBAAgB;IAAhBA,gBAAgB,GAAAD,qBAAA,cAAG,KAAK,GAAAA,qBAAA;EAExB,IAAQE,GAAG,GAAKrB,WAAW,CAAnBqB,GAAG;EACX,IAAMC,MAAM,GAAG,IAAAC,aAAM,EAAe,IAAI,CAAC;EACzC,IAAMC,QAAQ,GAAG,IAAAC,uBAAW,EAAC,CAAC;EAC9B,IAAAC,SAAA,GAAwC,IAAAC,eAAQ,EAAC,CAAC,CAAC;IAAAC,UAAA,OAAAC,eAAA,CAAAjD,OAAA,EAAA8C,SAAA;IAA5CI,YAAY,GAAAF,UAAA;IAAEG,eAAe,GAAAH,UAAA;EACpC,IAAAI,gBAAA,GAAyB,IAAAC,4BAAe,EAAC,CAAC;IAAlCC,YAAY,GAAAF,gBAAA,CAAZE,YAAY;EACpB,IAAMC,mBAAmB,GAAG,IAAAC,cAAO,EAAC,YAAM;IACxC,OAAOjC,YAAY,KAAK,IAAI,IAAIA,YAAY,KAAKkC,SAAS;EAC5D,CAAC,EAAE,CAAClC,YAAY,CAAC,CAAC;EAElB,IAAMmC,mBAAmB,GAAG,IAAAF,cAAO,EAAC,YAAM;IACxC,OAAOlC,YAAY,KAAK,IAAI,IAAIA,YAAY,KAAKmC,SAAS;EAC5D,CAAC,EAAE,CAACnC,YAAY,CAAC,CAAC;;EAElB;EACA,IAAAqC,UAAA,GAA+B,IAAAZ,eAAQ,EAACvE,CAAC,CAACoF,UAAU,CAAC,CAAC,CAAC;IAAAC,UAAA,OAAAZ,eAAA,CAAAjD,OAAA,EAAA2D,UAAA;IAAhDG,oBAAoB,GAAAD,UAAA;EAC3B,IAAAE,UAAA,GAAoC,IAAAhB,eAAQ,EAACvE,CAAC,CAACoF,UAAU,CAAC,CAAC,CAAC;IAAAI,UAAA,OAAAf,eAAA,CAAAjD,OAAA,EAAA+D,UAAA;IAArDE,yBAAyB,GAAAD,UAAA;EAChC,IAAAE,UAAA,GAAkC,IAAAnB,eAAQ,EAACvE,CAAC,CAACoF,UAAU,CAAC,CAAC,CAAC;IAAAO,UAAA,OAAAlB,eAAA,CAAAjD,OAAA,EAAAkE,UAAA;IAAnDE,uBAAuB,GAAAD,UAAA;EAC9B,IAAAE,UAAA,GAAgC,IAAAtB,eAAQ,EAACvE,CAAC,CAACoF,UAAU,CAAC,CAAC,CAAC;IAAAU,WAAA,OAAArB,eAAA,CAAAjD,OAAA,EAAAqE,UAAA;IAAjDE,qBAAqB,GAAAD,WAAA;EAC5B,IAAAE,WAAA,GAA8B,IAAAzB,eAAQ,EAACvE,CAAC,CAACoF,UAAU,CAAC,CAAC,CAAC;IAAAa,WAAA,OAAAxB,eAAA,CAAAjD,OAAA,EAAAwE,WAAA;IAA/CE,mBAAmB,GAAAD,WAAA;EAC1B,IAAAE,WAAA,GAA0B,IAAA5B,eAAQ,EAACvE,CAAC,CAACoF,UAAU,CAAC,CAAC,CAAC;IAAAgB,WAAA,OAAA3B,eAAA,CAAAjD,OAAA,EAAA2E,WAAA;IAA3CE,eAAe,GAAAD,WAAA;EACtB,IAAAE,WAAA,GAA+B,IAAA/B,eAAQ,EAACvE,CAAC,CAACoF,UAAU,CAAC,CAAC,CAAC;IAAAmB,WAAA,OAAA9B,eAAA,CAAAjD,OAAA,EAAA8E,WAAA;IAAhDE,oBAAoB,GAAAD,WAAA;EAC3B,IAAAE,WAAA,GAA0B,IAAAlC,eAAQ,EAAC,IAAIvE,CAAC,CAAC0G,YAAY,CAAC,CAAC,CAAC;IAAAC,WAAA,OAAAlC,eAAA,CAAAjD,OAAA,EAAAiF,WAAA;IAAjDG,eAAe,GAAAD,WAAA;EACtB,IAAAE,WAAA,GAA0C,IAAAtC,eAAQ,EAAC,IAAI,CAAC;IAAAuC,WAAA,OAAArC,eAAA,CAAAjD,OAAA,EAAAqF,WAAA;IAAjDE,aAAa,GAAAD,WAAA;IAAEE,gBAAgB,GAAAF,WAAA;EACtC,IAAMG,kBAAkB,GAAG,SAArBA,kBAAkBA,CAAIC,cAAc,EAAEhD,MAAM,EAAEiD,KAAK;IAAA,OACvDjD,MAAM,CAACkD,OAAO,KAAK,IAAI,IACvBzE,MAAM,iBACJxC,MAAA,CAAAqB,OAAA,CAAA6F,aAAA,CAAC5G,aAAA,CAAA6G,YAAY,EAAAxF,MAAA,CAAAyF,MAAA;MAACtD,GAAG,EAAEC,MAAM,CAACkD,OAAQ;MAACzE,MAAM,EAAEuE;IAAe,GAAKC,KAAK,CAAG,CACxE;EAAA;EAEH,IAAMK,uBAAuB,GAAG,SAA1BA,uBAAuBA,CAAA,EAAS;IACpC,IAAMC,eAAe,GAAG,IAAAC,sBAAY,EAAC/E,MAAM,EAAE,IAAI,CAAC;IAClD,OAAOsE,kBAAkB,CAACQ,eAAe,EAAEvD,MAAM,EAAE;MACjDV,wBAAwB,EAAE,IAAI;MAC9BmE,QAAQ,EAAEC,oBAAU,CAAClD,YAAY,CAAC;MAClCmD,cAAc,EAAEjC,uBAAuB;MACvCkC,UAAU,EAAEzB,eAAe;MAC3B0B,eAAe,EAAEvB,oBAAoB;MACrC5C,aAAa,EAAEA;IACjB,CAAC,CAAC;EACJ,CAAC;EAED,IAAMoE,yBAAyB,GAAG,SAA5BA,yBAAyBA,CAAA,EAAS;IACtC,IAAMC,iBAAiB,GAAG,IAAAP,sBAAY,EAAC/E,MAAM,EAAE,KAAK,CAAC;IACrD,OAAOsE,kBAAkB,CAACgB,iBAAiB,EAAE/D,MAAM,EAAE;MACnDV,wBAAwB,EAAE,IAAI;MAC9BmE,QAAQ,EAAEC,oBAAU,CAAClD,YAAY,CAAC;MAClCmD,cAAc,EAAEpC,yBAAyB;MACzCqC,UAAU,EAAEzB,eAAe;MAC3B0B,eAAe,EAAEvB,oBAAoB;MACrC5C,aAAa,EAAEA;IACjB,CAAC,CAAC;EACJ,CAAC;EAED,IAAMsE,WAAW,GAAG,SAAdA,WAAWA,CAAIC,aAAa,EAAEjE,MAAM,EAAE6C,aAAa,EAAEI,KAAK;IAAA,OAC9DjD,MAAM,CAACkD,OAAO,KAAK,IAAI,IACvBL,aAAa,iBACX5G,MAAA,CAAAqB,OAAA,CAAA6F,aAAA,CAAC7G,MAAA,CAAAgB,OAAK,EAAAM,MAAA,CAAAyF,MAAA;MAAC7E,KAAK,EAAEyF,aAAc;MAAClE,GAAG,EAAEC,MAAM,CAACkD;IAAQ,GAAKD,KAAK,CAAG,CAC/D;EAAA;EAEH,IAAMiB,aAAa,GAAG,IAAApD,cAAO,EAAC,YAAM;IAClC,IAAMqD,cAAc,GAAG,IAAAC,qBAAW,EAAC5F,KAAK,EAAEC,MAAM,EAAE,IAAI,CAAC;IACvD,OAAOuF,WAAW,CAACG,cAAc,EAAEnE,MAAM,EAAE6C,aAAa,EAAE;MACxD/G,CAAC,EAADA,CAAC;MACD2C,MAAM,EAANA,MAAM;MACNM,SAAS,EAATA,SAAS;MACTsF,UAAU,EAAE,IAAI;MAChBC,2BAA2B,EAAE9E,qCAAqC;MAClE+E,KAAK,EAAEvC;IACT,CAAC,CAAC;EACJ,CAAC,EAAE,CAAChC,MAAM,CAACkD,OAAO,EAAEzE,MAAM,EAAEuC,mBAAmB,EAAER,YAAY,CAAC,CAAC;EAE/D,IAAMgE,wBAAwB,GAAG,IAAA1D,cAAO,EAAC,YAAM;IAC7C,IAAM2D,gBAAgB,GAAG,IAAAL,qBAAW,EAAC5F,KAAK,EAAEC,MAAM,EAAE,KAAK,CAAC;IAC1D,OAAOuF,WAAW,CAACS,gBAAgB,EAAEzE,MAAM,EAAE6C,aAAa,EAAE;MAC1D/G,CAAC,EAADA,CAAC;MACD2C,MAAM,EAANA,MAAM;MACNM,SAAS,EAATA,SAAS;MACTsF,UAAU,EAAE,IAAI;MAChBC,2BAA2B,EAAE9E,qCAAqC;MAClE+E,KAAK,EAAE1C,qBAAqB;MAC5B6C,YAAY,EAAE7C,qBAAqB,CAAC8C,SAAS,CAAC,CAAC,CAACC,MAAM,KAAK;IAC7D,CAAC,CAAC;EACJ,CAAC,EAAE,CAAC5E,MAAM,CAACkD,OAAO,EAAEzE,MAAM,EAAEuC,mBAAmB,EAAER,YAAY,CAAC,CAAC;EAE/D,IAAMqE,yBAAyB,GAAG,SAA5BA,yBAAyBA,CAAIC,SAAS,EAAK;IAC/ChC,gBAAgB,CAACgC,SAAS,CAAC;EAC7B,CAAC;;EAED;EACA;EACA,IAAMC,eAAe,GAAG,CAAC,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,OAAO,CAAC;EAE9D,IAAMC,0BAA0B,GAAG,SAA7BA,0BAA0BA,CAAIF,SAAS,EAAK;IAChD,IAAI9E,MAAM,CAACkD,OAAO,KAAK,IAAI,EAAE;MAC3B,IAAI+B,IAAI,GAAGvB,oBAAU,CAAC1D,MAAM,CAACkD,OAAO,CAACgC,OAAO,CAAC,CAAC,CAAC;MAE/C,IAAIJ,SAAS,EAAE;QACb;QACA1D,oBAAoB,CAAC+D,WAAW,CAAC5D,yBAAyB,CAAC;QAC3DM,qBAAqB,CAACuD,UAAU,CAACpF,MAAM,CAACkD,OAAO,CAAC;MAClD,CAAC,MAAM;QACL;QACA9B,oBAAoB,CAACiE,QAAQ,CAAC9D,yBAAyB,CAAC;;QAExD;QACA,IAAIwD,eAAe,CAACO,QAAQ,CAACL,IAAI,CAAC,EAAE;UAClCpD,qBAAqB,CAAC0D,KAAK,CAACvF,MAAM,CAACkD,OAAO,CAAC;QAC7C;MACF;IACF;EACF,CAAC;EAED,IAAMsC,aAAa,GAAG,SAAhBA,aAAaA,CAAA,EAAS;IAC1B,IAAAC,+BAAqB,EAAC,iBAAiB,EAAEZ,yBAAyB,CAAC;IACnE,IAAAY,+BAAqB,EACnB,4BAA4B,EAC5BT,0BACF,CAAC;EACH,CAAC;EAED,IAAMU,sBAAsB,GAAG,SAAzBA,sBAAsBA,CAAA,EAAS;IACnC,IAAMC,OAAO,gBACX1J,MAAA,CAAAqB,OAAA,CAAA6F,aAAA,CAAAlH,MAAA,CAAAqB,OAAA,CAAAsI,QAAA,QACG1B,aAAa,EACbM,wBAAwB,EACxBV,yBAAyB,CAAC,CAAC,EAC3BR,uBAAuB,CAAC,CACzB,CACH;IAED,OAAOqC,OAAO;EAChB,CAAC;EAED,IAAME,0BAA0B,GAAG,SAA7BA,0BAA0BA,CAAA,EAAS;IACvC,IAAIF,OAAO,gBACT1J,MAAA,CAAAqB,OAAA,CAAA6F,aAAA,CAAAlH,MAAA,CAAAqB,OAAA,CAAAsI,QAAA,QACG9B,yBAAyB,CAAC,CAAC,EAC3BR,uBAAuB,CAAC,CACzB,CACH;IAED,IAAIyB,eAAe,CAACO,QAAQ,CAAC5B,oBAAU,CAAClD,YAAY,CAAC,CAAC,EAAE;MACtDmF,OAAO,GAAGD,sBAAsB,CAAC,CAAC;IACpC;IAEA,OAAOC,OAAO;EAChB,CAAC;EAED,IAAMG,mBAAmB,GAAG,SAAtBA,mBAAmBA,CAAA,EAAS;IAChC,IAAMH,OAAO,GAAGjG,aAAa,GACzBgG,sBAAsB,CAAC,CAAC,GACxBG,0BAA0B,CAAC,CAAC;IAEhC,IAAME,QAAQ,GAAGC,QAAQ,CAACC,aAAa,CACrC,4BACF,CAAqB;IACrB,IAAIF,QAAQ,EAAE;MACZf,0BAA0B,CAACe,QAAQ,CAACG,OAAO,CAAC;IAC9C;IACA,OAAOP,OAAO;EAChB,CAAC;EAED,IAAMQ,aAAa,GAAG,SAAhBA,aAAaA,CAAA,EAAS;IAC1B,IAAInF,mBAAmB,EAAE;MACvBpC,YAAY,CAAEwH,OAAO,GAAGpF,mBAAmB;MAC3CpC,YAAY,CAAEyH,OAAO,GAAG,CAACrF,mBAAmB;IAC9C;IAEA,IAAIH,mBAAmB,EAAE;MACvBhC,YAAY,CAAEwH,OAAO,GAAGxF,mBAAmB;MAC3ChC,YAAY,CAAEuH,OAAO,GAAG,CAACvF,mBAAmB;IAC9C;IAEA,IAAI,CAACA,mBAAmB,IAAI,CAACG,mBAAmB,EAAE,oBAAO/E,MAAA,CAAAqB,OAAA,CAAA6F,aAAA,CAAAlH,MAAA,CAAAqB,OAAA,CAAAsI,QAAA,MAAI,CAAC;IAC9D,oBACE3J,MAAA,CAAAqB,OAAA,CAAA6F,aAAA,CAAC3G,MAAA,CAAA8J,KAAK;MACJC,KAAK,EAAE3H,YAAY,IAAKC,YAAc;MACtCkB,GAAG,EAAEA,GAAI;MACTvB,KAAK,EAAEA,KAAO;MACdC,MAAM,EAAEA,MAAQ;MAChB+H,cAAc,EAAE,CAAC3F;IAAoB,CACtC,CAAC;EAEN,CAAC;EAED,IAAA4F,gBAAS,EAAC,YAAM;IACd,OAAO,SAASC,OAAOA,CAAA,EAAG;MAAA,IAAAC,eAAA;MACxBrE,oBAAoB,CAACsE,WAAW,CAAC,CAAC;MAClC,CAAAD,eAAA,GAAA3G,MAAM,CAACkD,OAAO,cAAAyD,eAAA,uBAAdA,eAAA,CAAgBxB,WAAW,CAAC7C,oBAAoB,CAAC;IACnD,CAAC;EACH,CAAC,EAAE,CAAC1D,YAAY,EAAEC,YAAY,EAAEH,WAAW,CAACmI,gBAAgB,CAAC,CAAC;EAE9D,IAAAJ,gBAAS,EAAC,YAAM;IACd,OAAO,SAASC,OAAOA,CAAA,EAAG;MACxB,IAAIhH,aAAa,IAAIM,MAAM,CAACkD,OAAO,EAAE;QACnChD,QAAQ,CAAC,IAAA4G,qBAAW,EAAC,CAAC,CAAC;QACvB5G,QAAQ,CAAC,IAAA6G,mBAAU,EAAC,CAAC,CAAC;QACtB5E,eAAe,CAACyE,WAAW,CAAC,CAAC;QAC7BlE,eAAe,CAACkE,WAAW,CAAC,CAAC;QAC7B5E,mBAAmB,CAAC4E,WAAW,CAAC,CAAC;QACjCtE,oBAAoB,CAACsE,WAAW,CAAC,CAAC;QAClC/E,qBAAqB,CAAC+E,WAAW,CAAC,CAAC;QACnClF,uBAAuB,CAACkF,WAAW,CAAC,CAAC;QACrCrF,yBAAyB,CAACqF,WAAW,CAAC,CAAC;QACvCxF,oBAAoB,CAACwF,WAAW,CAAC,CAAC;QAClC5G,MAAM,CAACkD,OAAO,CAACiC,WAAW,CAACtD,qBAAqB,CAAC;QACjD7B,MAAM,CAACkD,OAAO,CAACiC,WAAW,CAACnD,mBAAmB,CAAC;QAC/ChC,MAAM,CAACkD,OAAO,CAACiC,WAAW,CAAChD,eAAe,CAAC;QAC3CnC,MAAM,CAACkD,OAAO,CAACiC,WAAW,CAAC7C,oBAAoB,CAAC;QAChDtC,MAAM,CAACkD,OAAO,CAACiC,WAAW,CAACzC,eAAe,CAAC;QAC3C1C,MAAM,CAACkD,OAAO,CAACiC,WAAW,CAAC/D,oBAAoB,CAAC;QAEhDpB,MAAM,CAACkD,OAAO,CAAC8D,SAAS,CAAC,UAACC,KAAK,EAAK;UAClC,IAAIA,KAAK,YAAYnL,CAAC,CAACoL,SAAS,EAAE;YAChC;UACF;UACAlH,MAAM,CAACkD,OAAO,CAACiC,WAAW,CAAC8B,KAAK,CAAC;QACnC,CAAC,CAAC;MACJ;IACF,CAAC;EACH,CAAC,EAAE,CAACvI,WAAW,CAACyI,gBAAgB,CAAC,CAAC;EAElC,IAAAV,gBAAS,EAAC,YAAM;IACd,IAAI,CAACzG,MAAM,CAACkD,OAAO,EAAE;MACnB,IAAAkE,uBAAa,EACX5G,YAAY,EACZvB,WAAW,EACXC,iBAAU,CAACmI,SAAS,EACpBrH,MAAM,EACNE,QAAQ,EACRoH,qBAAW,EACX3I,cAAc,EACd8B,eAAe,EACfX,gBAAgB,EAChB,IAAI,EACJpB,WAAW,CAACyI,gBACd,CAAC;IACH,CAAC,MAAM;MACL1G,eAAe,CAACT,MAAM,CAACkD,OAAO,CAACgC,OAAO,CAAC,CAAC,CAAC;MACzC,IAAI,CAACvG,cAAc,EAAE;QACnBA,cAAc,GAAGJ,KAAK,CAACwB,GAAG,CAAC,UAACwH,IAAI;UAAA,OAAKA,IAAI,CAACC,UAAU;QAAA,EAAC,CAACC,IAAI,CAAC,CAAC;MAC9D;MAEA,IAAI,CAAC/H,aAAa,IAAI,CAACd,YAAY,EAAE;QACnC,IAAA8I,wBAAc,EAAC1H,MAAM,EAAEsH,qBAAW,EAAE3I,cAAc,CAAC;MACrD;MAEA6G,aAAa,CAAC,CAAC;IACjB;EACF,CAAC,EAAE,CAAC7G,cAAc,CAAC,CAAC;EAEpB,IAAA8H,gBAAS,EAAC,YAAM;IAAA,IAAAkB,gBAAA;IACd,IAAIC,OAAO,GAAG,KAAK;IAEnB,CAAAD,gBAAA,GAAA3H,MAAM,CAACkD,OAAO,cAAAyE,gBAAA,uBAAdA,gBAAA,CAAgBX,SAAS,CAAC,UAACC,KAAK,EAAK;MACnC,IAAIW,OAAO,EAAE;MAEb,IACE,CAAAX,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEY,eAAe,MAAKjH,YAAY,IACvCqG,KAAK,CAACa,WAAW,CAAC,CAAC,KAAK,KAAK,EAC7B;QACA,IAAIb,KAAK,YAAYnL,CAAC,CAACiM,MAAM,EAAE;UAC7Bd,KAAK,CAACe,IAAI,CAAC,OAAO,CAAC;QACrB,CAAC,MAAM,IAAIf,KAAK,YAAYnL,CAAC,CAACmM,OAAO,EAAE;UACrChB,KAAK,CAACe,IAAI,CAAC,aAAa,CAAC;QAC3B;QACAJ,OAAO,GAAG,IAAI;MAChB;IACF,CAAC,CAAC;EACJ,CAAC,EAAE,CAAChH,YAAY,CAAC,CAAC;EAElB,IAAMsH,WAAW,GAAG,SAAdA,WAAWA,CAAA,EAAS;IACxB,IAAI,CAAC,IAAAC,8BAAoB,EAACzJ,WAAW,EAAEsB,MAAM,EAAExB,KAAK,EAAEC,MAAM,CAAC,EAAE;MAC7D,OAAO,IAAI;IACb;IAEA,oBACExC,MAAA,CAAAqB,OAAA,CAAA6F,aAAA,CAAC9G,aAAA,CAAA+L,YAAY;MACX7J,KAAK,EAAEA,KAAM;MACbwB,GAAG,EAAEC,MAAM,CAACkD,OAAQ;MACpBpH,CAAC,EAAEA,CAAE;MACL6C,cAAc,EAAEA,cAAe;MAC/B0J,OAAO,EAAE7H,YAAa;MACtB9B,WAAW,EAAEA,WAAY;MACzB4J,YAAY,EAAE5F;IAAgB,CAC/B,CAAC;EAEN,CAAC;EAED,oBACEzG,MAAA,CAAAqB,OAAA,CAAA6F,aAAA;IAAKoF,SAAS,EAAC,kBAAkB;IAAC3I,KAAK,EAAEA;EAAM,gBAC7C3D,MAAA,CAAAqB,OAAA,CAAA6F,aAAA;IACEoF,SAAS,oBAAAC,MAAA,CACP9J,WAAW,CAAC+J,eAAe,GAAG,EAAE,GAAG,kCAAkC;EACpE,gBAEHxM,MAAA,CAAAqB,OAAA,CAAA6F,aAAA,CAAChH,cAAA,CAAAmB,OAAa,qBACZrB,MAAA,CAAAqB,OAAA,CAAA6F,aAAA;IAAKuF,EAAE,EAAC;EAAK,GACVR,WAAW,CAAC,CAAC,EACb,IAAAS,sCAA4B,EAC3BnK,KAAK,EACLD,KAAK,EACLG,WAAW,EACXsB,MAAM,EACNvB,MACF,CAAC,iBACCxC,MAAA,CAAAqB,OAAA,CAAA6F,aAAA,CAAAlH,MAAA,CAAAqB,OAAA,CAAAsI,QAAA,QACGO,aAAa,CAAC,CAAC,EACfL,mBAAmB,CAAC,CAAC,EACrB1G,QACD,CAED,CACQ,CACZ,CACF,CAAC;AAEV,CAAC;AAACwJ,OAAA,CAAAvK,GAAA,GAAAA,GAAA"}
331
+ //# 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","_actions","_actions2","_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","_useState3","_useState4","edgesCheckbox","setEdgesCheckbox","_useState5","_useState6","onlyMonitoredPoints","setOnlyMonitoredPoints","edgesCheckboxRef","hoveredEventPresent","useMemo","undefined","focusedEventPresent","_useState7","layerGroup","_useState8","factoriesParentGroup","_useState9","_useState10","unmonitoredFactoriesGroup","_useState11","_useState12","monitoredFactoriesGroup","_useState13","_useState14","unmonitoredEdgesGroup","_useState15","_useState16","monitoredEdgesGroup","_useState17","_useState18","wwtpsLayerGroup","_useState19","_useState20","collectorsLayerGroup","_useState21","FeatureGroup","_useState22","areasLayerGroup","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","handleEdgesCheckboxChange","isChecked","edgesZoomLevels","handlePointsCheckboxChange","zoom","getZoom","removeLayer","removeFrom","addLayer","includes","addTo","trackLayerbox","setupCheckboxListener","zoomRulesForEventsView","payload","Fragment","zoomRulesForDashaboardMaps","memoizedZoomControl","memoizedEvent","focused","hovered","Event","event","includeNetwork","useEffect","cleanup","_mapRef$current","clearLayers","eventFilterParam","clearPoints","clearAreas","eachLayer","layer","TileLayer","waterAuthorityId","initializeMap","satellite","isValidArea","area","shape_data","flat","areaFocusLogic","_mapRef$current2","clicked","kando_object_id","isPopupOpen","Marker","fire","Polygon","renderAreas","shouldLoadMapObjects","AreaPolygons","mapZoom","featureGroup","className","concat","sidenavExpanded","id","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';\nimport { clearAreas } from 'src/store/areas/actions';\nimport { clearPoints } from 'src/store/points/actions';\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 [edgesCheckbox, setEdgesCheckbox] = useState(true);\n  const [onlyMonitoredPoints, setOnlyMonitoredPoints] = useState(false);\n  const edgesCheckboxRef = useRef(edgesCheckbox);\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\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: false,\n      hideArrows: true,\n      allowUnmonitoredDescendants: includeUnmonitoredDescendantsForEdges,\n      group: monitoredEdgesGroup,\n    });\n  }, [points, edgesCheckbox, mapZoomLevel]);\n\n  const memoizedUnmonitoredEdges = useMemo(() => {\n    if (onlyMonitoredPoints) return null;\n\n    const unmonitoredEdges = filterEdges(edges, points, false);\n    return renderEdges(unmonitoredEdges, mapRef, edgesCheckbox, {\n      L,\n      points,\n      hideEdges: false,\n      hideArrows: true,\n      allowUnmonitoredDescendants: includeUnmonitoredDescendantsForEdges,\n      group: unmonitoredEdgesGroup,\n    });\n  }, [points, edgesCheckbox, 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    setOnlyMonitoredPoints(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 (edgesCheckboxRef.current && 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\n    if (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    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    edgesCheckboxRef.current = edgesCheckbox;\n  }, [edgesCheckbox]);\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    return function cleanup() {\n      if (forEventsView && mapRef.current) {\n        dispatch(clearPoints());\n        dispatch(clearAreas());\n        wwtpsLayerGroup.clearLayers();\n        areasLayerGroup.clearLayers();\n        monitoredEdgesGroup.clearLayers();\n        collectorsLayerGroup.clearLayers();\n        unmonitoredEdgesGroup.clearLayers();\n        monitoredFactoriesGroup.clearLayers();\n        unmonitoredFactoriesGroup.clearLayers();\n        factoriesParentGroup.clearLayers();\n        mapRef.current.removeLayer(unmonitoredEdgesGroup);\n        mapRef.current.removeLayer(monitoredEdgesGroup);\n        mapRef.current.removeLayer(wwtpsLayerGroup);\n        mapRef.current.removeLayer(collectorsLayerGroup);\n        mapRef.current.removeLayer(areasLayerGroup);\n        mapRef.current.removeLayer(factoriesParentGroup);\n\n        mapRef.current.eachLayer((layer) => {\n          if (layer instanceof L.TileLayer) {\n            return;\n          }\n          mapRef.current.removeLayer(layer);\n        });\n      }\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        forWWTPDashboard,\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\n      trackLayerbox();\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  }, [areaToCenterBy]);\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  const renderAreas = () => {\n    if (!shouldLoadMapObjects(global_data, mapRef, edges, points)) {\n      return null;\n    }\n\n    return (\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  };\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            {renderAreas()}\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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"}
@@ -137,8 +137,6 @@ var PointMarker = function PointMarker(props) {
137
137
  (0, _PointUtils.createBubblePoint)(markerLocation, point, map, null, layerGroup, flowRateUnit, handleSelectItem);
138
138
  }
139
139
  };
140
-
141
- // blobal_data is used here to force markers re-render when in events view, going back from a focused event
142
140
  (0, _react.useEffect)(function () {
143
141
  renderLogic();
144
142
  }, [rerender]);
@@ -149,4 +147,4 @@ var _default = connectedMarker( /*#__PURE__*/_react.default.memo(PointMarker, fu
149
147
  return prevProps.events_data.focusedEvent === nextProps.events_data.focusedEvent;
150
148
  }));
151
149
  exports.default = _default;
152
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRedux","_PointUtils","_Widget","_reactDom","_interopRequireDefault","_utils","_ListContext","_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","mapStateToProps","state","events_data","areas_data","points_data","global_data","PointMarker","props","map","point","rerender","layerGroup","flowRateUnit","dispatch","useDispatch","_useSelectedItem","useSelectedItem","handleSelectItem","WWTPMode","useSelector","wwtp_dashboard","history","useHistory","WWTPMapLogic","markerLocation","wwtpPoint","_objectSpread2","forWWTPMap","markerOnMap","getLayers","find","layer","kando_object_id","id","args","wwtp","bubbleForWWTP","tooltipVisible","addTo","fetchDataAndShowPopup","_ref","_asyncToGenerator2","_regenerator","mark","_callee","widgetContainer","wrap","_callee$","_context","prev","next","document","createElement","createPopupForObject","renderedElement","marker","fetchCapacity","waterAuthorityId","then","listData","ReactDOM","render","Widget","object","points","items","areas","newAreas","isPopupOpen","openPopup","stop","apply","arguments","on","closePopup","sendAnalyticsEvent","point_id","point_name","name","setIcon","renderLogic","pointIsWWTP","createBubblePoint","useEffect","Fragment","connectedMarker","connect","_default","React","memo","prevProps","nextProps","focusedEvent","exports"],"sources":["../../../../src/Widgets/Map/points/PointMarker.tsx"],"sourcesContent":["import React, { useEffect } from 'react';\nimport { connect, ConnectedProps, useDispatch, useSelector } from 'react-redux';\nimport { IAppState } from 'src/models/IAppState';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport {\n  bubbleForWWTP,\n  createBubblePoint,\n  pointIsWWTP,\n  setIcon,\n} from './PointUtils';\nimport { Widget } from 'src/pages/DashboardMap/Widget';\nimport ReactDOM from 'react-dom';\nimport L, { LatLngTuple } from 'leaflet';\nimport {\n  createPopupForObject,\n  sendAnalyticsEvent,\n} from 'src/pages/DashboardMap/utils';\nimport { useSelectedItem } from 'src/pages/DashboardMap/ListContext';\nimport { fetchCapacity } from 'src/pages/DashboardMap/Capacity';\nimport { useHistory } from 'react-router-dom';\n\nfunction mapStateToProps(state: IAppState) {\n  const { events_data, areas_data, points_data, global_data } = state;\n\n  return {\n    events_data,\n    areas_data,\n    points_data,\n    global_data,\n  };\n}\n\ntype Props = ConnectedProps<typeof connectedMarker> & {\n  map: any;\n  point: IPoint;\n  rerender: string;\n  layerGroup: any;\n  flowRateUnit: string;\n};\n\nconst PointMarker: React.FC<Props> = (props) => {\n  const {\n    map,\n    point,\n    rerender,\n    layerGroup,\n    flowRateUnit,\n    points_data,\n    areas_data,\n    global_data,\n  } = props;\n  const dispatch = useDispatch();\n  const { handleSelectItem } = useSelectedItem();\n  const WWTPMode = useSelector((state) => state.wwtp_dashboard.map !== null);\n  const history = useHistory();\n\n  const WWTPMapLogic = (markerLocation) => {\n    const wwtpPoint = {\n      ...point,\n      forWWTPMap: true,\n    };\n    const markerOnMap = layerGroup\n      .getLayers()\n      .find((layer) => layer.kando_object_id === point.id);\n    let args = { markerLocation, wwtpPoint };\n    let wwtp: L.Marker = markerOnMap ? markerOnMap : bubbleForWWTP(args);\n    let tooltipVisible = false;\n\n    if (!markerOnMap) {\n      wwtp.addTo(layerGroup);\n    }\n\n    const fetchDataAndShowPopup = async () => {\n      const widgetContainer = document.createElement('span');\n\n      createPopupForObject({\n        renderedElement: widgetContainer,\n        marker: wwtp,\n      });\n\n      fetchCapacity('site', point.id, global_data.waterAuthorityId).then(\n        (listData) => {\n          ReactDOM.render(\n            <Widget\n              object={wwtpPoint}\n              dispatch={dispatch}\n              points={points_data.items}\n              areas={areas_data.newAreas}\n              map={map}\n              global_data={global_data}\n              listData={listData}\n              history={history}\n            />,\n            widgetContainer,\n          );\n        },\n      );\n\n      if (!wwtp.isPopupOpen()) {\n        wwtp.openPopup();\n      }\n    };\n\n    wwtp.on('click', () => {\n      wwtp.isPopupOpen() ? wwtp.closePopup() : fetchDataAndShowPopup();\n      sendAnalyticsEvent('Map View - WWTP clicked', 'map', {\n        point_id: point.id,\n        point_name: point.name,\n      });\n    });\n\n    wwtp.on('mouseover', () => {\n      if (tooltipVisible) return;\n\n      setIcon(wwtp, true, point);\n      tooltipVisible = true;\n    });\n\n    wwtp.on('mouseout', () => {\n      if (wwtp.isPopupOpen()) return;\n\n      setIcon(wwtp, false, point);\n      tooltipVisible = false;\n    });\n\n    wwtp.on('popupclose', () => {\n      setIcon(wwtp, false, point);\n      tooltipVisible = false;\n    });\n\n    wwtp.on('popupopen', () => {\n      setIcon(wwtp, true, point);\n      tooltipVisible = true;\n    });\n  };\n\n  const renderLogic = () => {\n    let markerLocation: LatLngTuple = [point['latitude'], point['longitude']];\n    if (markerLocation[0] === null) return;\n\n    if (pointIsWWTP(point) && WWTPMode === true) {\n      WWTPMapLogic(markerLocation);\n    } else {\n      createBubblePoint(\n        markerLocation,\n        point,\n        map,\n        null,\n        layerGroup,\n        flowRateUnit,\n        handleSelectItem,\n      );\n    }\n  };\n\n  // blobal_data is used here to force markers re-render when in events view, going back from a focused event\n  useEffect(() => {\n    renderLogic();\n  }, [rerender]);\n\n  return <></>;\n};\n\nconst connectedMarker = connect(mapStateToProps);\nexport default connectedMarker(\n  React.memo(PointMarker, (prevProps, nextProps) => {\n    return (\n      prevProps.events_data.focusedEvent === nextProps.events_data.focusedEvent\n    );\n  }),\n);\n"],"mappings":"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"}
150
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRedux","_PointUtils","_Widget","_reactDom","_interopRequireDefault","_utils","_ListContext","_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","mapStateToProps","state","events_data","areas_data","points_data","global_data","PointMarker","props","map","point","rerender","layerGroup","flowRateUnit","dispatch","useDispatch","_useSelectedItem","useSelectedItem","handleSelectItem","WWTPMode","useSelector","wwtp_dashboard","history","useHistory","WWTPMapLogic","markerLocation","wwtpPoint","_objectSpread2","forWWTPMap","markerOnMap","getLayers","find","layer","kando_object_id","id","args","wwtp","bubbleForWWTP","tooltipVisible","addTo","fetchDataAndShowPopup","_ref","_asyncToGenerator2","_regenerator","mark","_callee","widgetContainer","wrap","_callee$","_context","prev","next","document","createElement","createPopupForObject","renderedElement","marker","fetchCapacity","waterAuthorityId","then","listData","ReactDOM","render","Widget","object","points","items","areas","newAreas","isPopupOpen","openPopup","stop","apply","arguments","on","closePopup","sendAnalyticsEvent","point_id","point_name","name","setIcon","renderLogic","pointIsWWTP","createBubblePoint","useEffect","Fragment","connectedMarker","connect","_default","React","memo","prevProps","nextProps","focusedEvent","exports"],"sources":["../../../../src/Widgets/Map/points/PointMarker.tsx"],"sourcesContent":["import React, { useEffect } from 'react';\nimport { connect, ConnectedProps, useDispatch, useSelector } from 'react-redux';\nimport { IAppState } from 'src/models/IAppState';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport {\n  bubbleForWWTP,\n  createBubblePoint,\n  pointIsWWTP,\n  setIcon,\n} from './PointUtils';\nimport { Widget } from 'src/pages/DashboardMap/Widget';\nimport ReactDOM from 'react-dom';\nimport L, { LatLngTuple } from 'leaflet';\nimport {\n  createPopupForObject,\n  sendAnalyticsEvent,\n} from 'src/pages/DashboardMap/utils';\nimport { useSelectedItem } from 'src/pages/DashboardMap/ListContext';\nimport { fetchCapacity } from 'src/pages/DashboardMap/Capacity';\nimport { useHistory } from 'react-router-dom';\n\nfunction mapStateToProps(state: IAppState) {\n  const { events_data, areas_data, points_data, global_data } = state;\n\n  return {\n    events_data,\n    areas_data,\n    points_data,\n    global_data,\n  };\n}\n\ntype Props = ConnectedProps<typeof connectedMarker> & {\n  map: any;\n  point: IPoint;\n  rerender: string;\n  layerGroup: any;\n  flowRateUnit: string;\n};\n\nconst PointMarker: React.FC<Props> = (props) => {\n  const {\n    map,\n    point,\n    rerender,\n    layerGroup,\n    flowRateUnit,\n    points_data,\n    areas_data,\n    global_data,\n  } = props;\n  const dispatch = useDispatch();\n  const { handleSelectItem } = useSelectedItem();\n  const WWTPMode = useSelector((state) => state.wwtp_dashboard.map !== null);\n  const history = useHistory();\n\n  const WWTPMapLogic = (markerLocation) => {\n    const wwtpPoint = {\n      ...point,\n      forWWTPMap: true,\n    };\n    const markerOnMap = layerGroup\n      .getLayers()\n      .find((layer) => layer.kando_object_id === point.id);\n    let args = { markerLocation, wwtpPoint };\n    let wwtp: L.Marker = markerOnMap ? markerOnMap : bubbleForWWTP(args);\n    let tooltipVisible = false;\n\n    if (!markerOnMap) {\n      wwtp.addTo(layerGroup);\n    }\n\n    const fetchDataAndShowPopup = async () => {\n      const widgetContainer = document.createElement('span');\n\n      createPopupForObject({\n        renderedElement: widgetContainer,\n        marker: wwtp,\n      });\n\n      fetchCapacity('site', point.id, global_data.waterAuthorityId).then(\n        (listData) => {\n          ReactDOM.render(\n            <Widget\n              object={wwtpPoint}\n              dispatch={dispatch}\n              points={points_data.items}\n              areas={areas_data.newAreas}\n              map={map}\n              global_data={global_data}\n              listData={listData}\n              history={history}\n            />,\n            widgetContainer,\n          );\n        },\n      );\n\n      if (!wwtp.isPopupOpen()) {\n        wwtp.openPopup();\n      }\n    };\n\n    wwtp.on('click', () => {\n      wwtp.isPopupOpen() ? wwtp.closePopup() : fetchDataAndShowPopup();\n      sendAnalyticsEvent('Map View - WWTP clicked', 'map', {\n        point_id: point.id,\n        point_name: point.name,\n      });\n    });\n\n    wwtp.on('mouseover', () => {\n      if (tooltipVisible) return;\n\n      setIcon(wwtp, true, point);\n      tooltipVisible = true;\n    });\n\n    wwtp.on('mouseout', () => {\n      if (wwtp.isPopupOpen()) return;\n\n      setIcon(wwtp, false, point);\n      tooltipVisible = false;\n    });\n\n    wwtp.on('popupclose', () => {\n      setIcon(wwtp, false, point);\n      tooltipVisible = false;\n    });\n\n    wwtp.on('popupopen', () => {\n      setIcon(wwtp, true, point);\n      tooltipVisible = true;\n    });\n  };\n\n  const renderLogic = () => {\n    let markerLocation: LatLngTuple = [point['latitude'], point['longitude']];\n    if (markerLocation[0] === null) return;\n\n    if (pointIsWWTP(point) && WWTPMode === true) {\n      WWTPMapLogic(markerLocation);\n    } else {\n      createBubblePoint(\n        markerLocation,\n        point,\n        map,\n        null,\n        layerGroup,\n        flowRateUnit,\n        handleSelectItem,\n      );\n    }\n  };\n\n  useEffect(() => {\n    renderLogic();\n  }, [rerender]);\n\n  return <></>;\n};\n\nconst connectedMarker = connect(mapStateToProps);\nexport default connectedMarker(\n  React.memo(PointMarker, (prevProps, nextProps) => {\n    return (\n      prevProps.events_data.focusedEvent === nextProps.events_data.focusedEvent\n    );\n  }),\n);\n"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
 
3
- var packageJsonVersion = "1.2.414-alpha.4";
3
+ var packageJsonVersion = "1.2.414-alpha.6";
4
4
  if (typeof packageJsonVersion === 'string') {
5
5
  // eslint-disable-next-line no-console
6
6
  console.log("%c Kando UI %c v".concat(packageJsonVersion, " "), 'font-size: 15px; background-color: #fff; color: #e20f53;', 'font-weight: bold; font-size: 15px; background-color: #e20f53; color: #fff;', "with NODE_ENV=".concat(process.env.NODE_ENV));
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@kando-env/kando-ui",
3
- "version": "1.2.414-alpha.4",
3
+ "version": "1.2.414-alpha.6",
4
4
  "main": "lib/index.js",
5
5
  "author": "Nadav(Private) <nadavk72@gmail.com>",
6
6
  "scripts": {