@kando-env/kando-ui 1.2.371-alpha.2 → 1.2.371-alpha.21

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.
@@ -83,17 +83,26 @@ var Map = function Map(_ref) {
83
83
  monitoredFactoriesClusterGroup = _useState8[0];
84
84
  var _useState9 = (0, _react.useState)(L.layerGroup()),
85
85
  _useState10 = (0, _slicedToArray2.default)(_useState9, 1),
86
- wwtpsLayerGroup = _useState10[0];
86
+ unmonitoredEdgesGroup = _useState10[0];
87
87
  var _useState11 = (0, _react.useState)(L.layerGroup()),
88
88
  _useState12 = (0, _slicedToArray2.default)(_useState11, 1),
89
- collectorsLayerGroup = _useState12[0];
90
- var _useState13 = (0, _react.useState)(new L.FeatureGroup()),
89
+ hiddenUnmonitoredEdgesGroup = _useState12[0];
90
+ var _useState13 = (0, _react.useState)(L.layerGroup()),
91
91
  _useState14 = (0, _slicedToArray2.default)(_useState13, 1),
92
- areasLayerGroup = _useState14[0];
93
- var _useState15 = (0, _react.useState)(true),
94
- _useState16 = (0, _slicedToArray2.default)(_useState15, 2),
95
- edgesCheckbox = _useState16[0],
96
- setEdgesCheckbox = _useState16[1];
92
+ monitoredEdgesGroup = _useState14[0];
93
+ var _useState15 = (0, _react.useState)(L.layerGroup()),
94
+ _useState16 = (0, _slicedToArray2.default)(_useState15, 1),
95
+ wwtpsLayerGroup = _useState16[0];
96
+ var _useState17 = (0, _react.useState)(L.layerGroup()),
97
+ _useState18 = (0, _slicedToArray2.default)(_useState17, 1),
98
+ collectorsLayerGroup = _useState18[0];
99
+ var _useState19 = (0, _react.useState)(new L.FeatureGroup()),
100
+ _useState20 = (0, _slicedToArray2.default)(_useState19, 1),
101
+ areasLayerGroup = _useState20[0];
102
+ var _useState21 = (0, _react.useState)(true),
103
+ _useState22 = (0, _slicedToArray2.default)(_useState21, 2),
104
+ edgesCheckbox = _useState22[0],
105
+ setEdgesCheckbox = _useState22[1];
97
106
  var memoizedMonitoredPoints = (0, _react.useMemo)(function () {
98
107
  var monitoredPoints = points.filter(function (point) {
99
108
  return point.has_device;
@@ -124,6 +133,51 @@ var Map = function Map(_ref) {
124
133
  forEventsView: false
125
134
  });
126
135
  }, [mapRef.current, points, focusedEventPresent, mapZoomLevel]);
136
+ var memoizedEdges = (0, _react.useMemo)(function () {
137
+ var monitoredEdges = edges.filter(function (edge) {
138
+ var sourcePoint = points.find(function (point) {
139
+ return point.id === edge.source_point_id && point.descendants_has_device;
140
+ });
141
+ var parentPoint = points.find(function (point) {
142
+ return point.id === edge.target_point_id && point.descendants_has_device;
143
+ });
144
+
145
+ // Only keep edges where both source and parent points exist in points array and have has_device as true
146
+ return sourcePoint || parentPoint;
147
+ });
148
+ return mapRef.current !== null && edgesCheckbox && /*#__PURE__*/_react.default.createElement(_Edges.default, {
149
+ edges: monitoredEdges,
150
+ map: mapRef.current,
151
+ L: L,
152
+ points: points,
153
+ hideEdges: hideEdges,
154
+ hideArrows: true,
155
+ allowUnmonitoredDescendants: includeUnmonitoredDescendantsForEdges,
156
+ group: monitoredEdgesGroup
157
+ });
158
+ }, [mapRef.current, points, focusedEventPresent, mapZoomLevel]);
159
+ var memoizedUnmonitoredEdges = (0, _react.useMemo)(function () {
160
+ var unmonitoredEdges = edges.filter(function (edge) {
161
+ var sourcePoint = points.find(function (point) {
162
+ return point.id === edge.source_point_id && !point.descendants_has_device;
163
+ });
164
+ var parentPoint = points.find(function (point) {
165
+ return point.id === edge.target_point_id && !point.descendants_has_device;
166
+ });
167
+ return sourcePoint && parentPoint;
168
+ });
169
+ return mapRef.current !== null && edgesCheckbox && /*#__PURE__*/_react.default.createElement(_Edges.default, {
170
+ edges: unmonitoredEdges,
171
+ map: mapRef.current,
172
+ L: L,
173
+ points: points,
174
+ hideEdges: hideEdges,
175
+ hideArrows: true,
176
+ allowUnmonitoredDescendants: includeUnmonitoredDescendantsForEdges,
177
+ group: unmonitoredEdgesGroup,
178
+ shouldntDraw: hiddenUnmonitoredEdgesGroup.getLayers().length !== 0
179
+ });
180
+ }, [mapRef.current, points, focusedEventPresent, mapZoomLevel]);
127
181
  var setupCheckboxListener = function setupCheckboxListener(selector, onChange) {
128
182
  var checkbox = document.querySelector(selector);
129
183
  if (checkbox === null) return;
@@ -135,12 +189,23 @@ var Map = function Map(_ref) {
135
189
  setEdgesCheckbox(isChecked);
136
190
  };
137
191
  var handlePointsCheckboxChange = function handlePointsCheckboxChange(isChecked) {
192
+ var zoom = _MapUtils.zoomLevels[mapRef.current.getZoom()];
138
193
  if (isChecked) {
139
194
  hiddenFactoriesClusterGroup.addLayer(unmonitoredFactoriesClusterGroup);
140
195
  unmonitoredFactoriesClusterGroup.clearLayers();
196
+ if (zoom === 'Medium' || zoom === 'Small') {
197
+ hiddenUnmonitoredEdgesGroup.addLayer(unmonitoredEdgesGroup);
198
+ unmonitoredEdgesGroup.removeFrom(mapRef.current);
199
+ }
141
200
  } else {
142
201
  unmonitoredFactoriesClusterGroup.addLayer(hiddenFactoriesClusterGroup);
143
202
  hiddenFactoriesClusterGroup.clearLayers();
203
+ if (zoom === 'Medium' || zoom === 'Small') {
204
+ unmonitoredEdgesGroup.addLayer(hiddenUnmonitoredEdgesGroup);
205
+ hiddenUnmonitoredEdgesGroup.removeFrom(mapRef.current);
206
+ hiddenUnmonitoredEdgesGroup.clearLayers();
207
+ unmonitoredEdgesGroup.addTo(mapRef.current);
208
+ }
144
209
  }
145
210
  };
146
211
  var trackLayerbox = function trackLayerbox() {
@@ -148,15 +213,7 @@ var Map = function Map(_ref) {
148
213
  setupCheckboxListener('#monitored-points-checkbox', handlePointsCheckboxChange);
149
214
  };
150
215
  var zoomRulesForEventsView = function zoomRulesForEventsView() {
151
- var payload = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, edgesCheckbox && /*#__PURE__*/_react.default.createElement(_Edges.default, {
152
- edges: edges,
153
- map: mapRef.current,
154
- L: L,
155
- points: points,
156
- hideEdges: hideEdges,
157
- hideArrows: true,
158
- allowUnmonitoredDescendants: includeUnmonitoredDescendantsForEdges
159
- }), memoizedUnmonitoredPoints, memoizedMonitoredPoints);
216
+ var payload = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, memoizedEdges, memoizedUnmonitoredEdges, memoizedUnmonitoredPoints, memoizedMonitoredPoints);
160
217
  return payload;
161
218
  };
162
219
  var zoomRulesForDashaboardMaps = function zoomRulesForDashaboardMaps() {
@@ -179,7 +236,7 @@ var Map = function Map(_ref) {
179
236
  var memoizedZoomControl = (0, _react.useMemo)(function () {
180
237
  var payload = forEventsView ? zoomRulesForEventsView() : zoomRulesForDashaboardMaps();
181
238
  return payload;
182
- }, [mapZoomLevel, eventsData.isFetching, focusedEvent, hoveredEvent, points, mapRef.current, edgesCheckbox]);
239
+ }, [mapZoomLevel, eventsData.isFetching, focusedEvent, hoveredEvent, points, mapRef.current, edgesCheckbox, unmonitoredEdgesGroup]);
183
240
  var memoizedEvent = (0, _react.useMemo)(function () {
184
241
  if (focusedEventPresent) {
185
242
  focusedEvent.focused = focusedEventPresent;
@@ -269,4 +326,4 @@ var Map = function Map(_ref) {
269
326
  }), (0, _MapUtils.shoudLoadDependentMapObjects)(edges, areas, global_data, mapRef, points) && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, memoizedEvent, memoizedZoomControl, children))));
270
327
  };
271
328
  exports.Map = Map;
272
- //# 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","window","customLeaflet","markerClusterGroup","clusterGroupOptions","_useState4","hiddenFactoriesClusterGroup","_useState5","_useState6","unmonitoredFactoriesClusterGroup","_useState7","_useState8","monitoredFactoriesClusterGroup","_useState9","layerGroup","_useState10","wwtpsLayerGroup","_useState11","_useState12","collectorsLayerGroup","_useState13","FeatureGroup","_useState14","areasLayerGroup","_useState15","_useState16","edgesCheckbox","setEdgesCheckbox","memoizedMonitoredPoints","monitoredPoints","filter","point","has_device","current","createElement","PointMarkers","rerender","zoomLevels","factoriesGroup","wwtpsGroup","collectorsGroup","memoizedUnmonitoredPoints","unmonitoredPoints","setupCheckboxListener","selector","onChange","checkbox","document","querySelector","addEventListener","checked","handleEdgesCheckboxChange","isChecked","handlePointsCheckboxChange","addLayer","clearLayers","trackLayerbox","zoomRulesForEventsView","payload","Fragment","hideArrows","allowUnmonitoredDescendants","zoomRulesForDashaboardMaps","memoizedZoomControl","isFetching","memoizedEvent","focused","hovered","Event","event","includeNetwork","eventFilterParam","useEffect","cleanup","_mapRef$current","removeLayer","initializeMap","satellite","isValidArea","waterAuthorityId","remove","getZoom","area","shape_data","flat","areaFocusLogic","_mapRef$current2","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 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  clusterGroupOptions,\n  initializeMap,\n  isValidArea,\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');\nrequire('src/utilities/polylinedecorator');\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 [hiddenFactoriesClusterGroup] = useState(\n    window.customLeaflet.markerClusterGroup(clusterGroupOptions),\n  );\n\n  const [unmonitoredFactoriesClusterGroup] = useState(\n    window.customLeaflet.markerClusterGroup(clusterGroupOptions),\n  );\n\n  const [monitoredFactoriesClusterGroup] = useState(\n    window.customLeaflet.markerClusterGroup(clusterGroupOptions),\n  );\n\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 memoizedMonitoredPoints = useMemo(() => {\n    let monitoredPoints = points.filter((point) => point.has_device);\n\n    return (\n      mapRef.current !== null &&\n      points && (\n        <PointMarkers\n          map={mapRef.current}\n          points={monitoredPoints}\n          includeUnmonitoredPoints={includeUnmonitoredPoints}\n          rerender={zoomLevels[mapZoomLevel]}\n          factoriesGroup={monitoredFactoriesClusterGroup}\n          wwtpsGroup={wwtpsLayerGroup}\n          collectorsGroup={collectorsLayerGroup}\n          forEventsView={false}\n        />\n      )\n    );\n  }, [mapRef.current, points, focusedEventPresent, mapZoomLevel]);\n\n  const memoizedUnmonitoredPoints = useMemo(() => {\n    let unmonitoredPoints = points.filter(\n      (point) => point.has_device === false,\n    );\n\n    return (\n      mapRef.current !== null &&\n      points && (\n        <PointMarkers\n          map={mapRef.current}\n          points={unmonitoredPoints}\n          includeUnmonitoredPoints={includeUnmonitoredPoints}\n          rerender={zoomLevels[mapZoomLevel]}\n          factoriesGroup={unmonitoredFactoriesClusterGroup}\n          wwtpsGroup={wwtpsLayerGroup}\n          collectorsGroup={collectorsLayerGroup}\n          forEventsView={false}\n        />\n      )\n    );\n  }, [mapRef.current, points, focusedEventPresent, mapZoomLevel]);\n\n  const setupCheckboxListener = (selector, onChange) => {\n    const checkbox = document.querySelector(selector);\n    if (checkbox === null) return;\n    checkbox.addEventListener('change', () => onChange(checkbox.checked));\n  };\n\n  const handleEdgesCheckboxChange = (isChecked) => {\n    setEdgesCheckbox(isChecked);\n  };\n\n  const handlePointsCheckboxChange = (isChecked) => {\n    if (isChecked) {\n      hiddenFactoriesClusterGroup.addLayer(unmonitoredFactoriesClusterGroup);\n      unmonitoredFactoriesClusterGroup.clearLayers();\n    } else {\n      unmonitoredFactoriesClusterGroup.addLayer(hiddenFactoriesClusterGroup);\n      hiddenFactoriesClusterGroup.clearLayers();\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        {edgesCheckbox && (\n          <Edges\n            edges={edges!}\n            map={mapRef.current}\n            L={L}\n            points={points!}\n            hideEdges={hideEdges}\n            hideArrows={true}\n            allowUnmonitoredDescendants={includeUnmonitoredDescendantsForEdges}\n          />\n        )}\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    switch (zoomLevels[mapZoomLevel]) {\n      case 'Small':\n      case 'Medium':\n        payload = zoomRulesForEventsView();\n        break;\n      // case 'MLarge':\n      // case 'Large':\n      // case 'XLarge':\n      // default:\n      //   payload = <>{memoizedPoints}</>;\n      //   break;\n    }\n\n    return payload;\n  };\n\n  const memoizedZoomControl = useMemo(() => {\n    const payload = forEventsView\n      ? zoomRulesForEventsView()\n      : zoomRulesForDashaboardMaps();\n\n    return payload;\n  }, [\n    mapZoomLevel,\n    eventsData.isFetching,\n    focusedEvent,\n    hoveredEvent,\n    points,\n    mapRef.current,\n    edgesCheckbox,\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      // factoriesClusterGroup.clearLayers();\n      // wwtpsLayerGroup.clearLayers();\n      // collectorsLayerGroup.clearLayers();\n      // areasLayerGroup.clearLayers();\n      // mapRef.current?.removeLayer(factoriesClusterGroup);\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      areaFocusLogic(mapRef, isValidArea, areaToCenterBy);\n      trackLayerbox();\n    }\n  }, [mapRef.current, 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  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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"}
329
+ //# 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","window","customLeaflet","markerClusterGroup","clusterGroupOptions","_useState4","hiddenFactoriesClusterGroup","_useState5","_useState6","unmonitoredFactoriesClusterGroup","_useState7","_useState8","monitoredFactoriesClusterGroup","_useState9","layerGroup","_useState10","unmonitoredEdgesGroup","_useState11","_useState12","hiddenUnmonitoredEdgesGroup","_useState13","_useState14","monitoredEdgesGroup","_useState15","_useState16","wwtpsLayerGroup","_useState17","_useState18","collectorsLayerGroup","_useState19","FeatureGroup","_useState20","areasLayerGroup","_useState21","_useState22","edgesCheckbox","setEdgesCheckbox","memoizedMonitoredPoints","monitoredPoints","filter","point","has_device","current","createElement","PointMarkers","rerender","zoomLevels","factoriesGroup","wwtpsGroup","collectorsGroup","memoizedUnmonitoredPoints","unmonitoredPoints","memoizedEdges","monitoredEdges","edge","sourcePoint","find","id","source_point_id","descendants_has_device","parentPoint","target_point_id","hideArrows","allowUnmonitoredDescendants","group","memoizedUnmonitoredEdges","unmonitoredEdges","shouldntDraw","getLayers","length","setupCheckboxListener","selector","onChange","checkbox","document","querySelector","addEventListener","checked","handleEdgesCheckboxChange","isChecked","handlePointsCheckboxChange","zoom","getZoom","addLayer","clearLayers","removeFrom","addTo","trackLayerbox","zoomRulesForEventsView","payload","Fragment","zoomRulesForDashaboardMaps","memoizedZoomControl","isFetching","memoizedEvent","focused","hovered","Event","event","includeNetwork","eventFilterParam","useEffect","cleanup","_mapRef$current","removeLayer","initializeMap","satellite","isValidArea","waterAuthorityId","remove","area","shape_data","flat","areaFocusLogic","_mapRef$current2","clicked","eachLayer","layer","kando_object_id","isPopupOpen","Marker","fire","Polygon","className","concat","sidenavExpanded","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 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  clusterGroupOptions,\n  initializeMap,\n  isValidArea,\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');\nrequire('src/utilities/polylinedecorator');\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 [hiddenFactoriesClusterGroup] = useState(\n    window.customLeaflet.markerClusterGroup(clusterGroupOptions),\n  );\n\n  const [unmonitoredFactoriesClusterGroup] = useState(\n    window.customLeaflet.markerClusterGroup(clusterGroupOptions),\n  );\n\n  const [monitoredFactoriesClusterGroup] = useState(\n    window.customLeaflet.markerClusterGroup(clusterGroupOptions),\n  );\n\n  const [unmonitoredEdgesGroup] = useState(L.layerGroup());\n  const [hiddenUnmonitoredEdgesGroup] = 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 memoizedMonitoredPoints = useMemo(() => {\n    let monitoredPoints = points.filter((point) => point.has_device);\n\n    return (\n      mapRef.current !== null &&\n      points && (\n        <PointMarkers\n          map={mapRef.current}\n          points={monitoredPoints}\n          includeUnmonitoredPoints={includeUnmonitoredPoints}\n          rerender={zoomLevels[mapZoomLevel]}\n          factoriesGroup={monitoredFactoriesClusterGroup}\n          wwtpsGroup={wwtpsLayerGroup}\n          collectorsGroup={collectorsLayerGroup}\n          forEventsView={false}\n        />\n      )\n    );\n  }, [mapRef.current, points, focusedEventPresent, mapZoomLevel]);\n\n  const memoizedUnmonitoredPoints = useMemo(() => {\n    let unmonitoredPoints = points.filter(\n      (point) => point.has_device === false,\n    );\n\n    return (\n      mapRef.current !== null &&\n      points && (\n        <PointMarkers\n          map={mapRef.current}\n          points={unmonitoredPoints}\n          includeUnmonitoredPoints={includeUnmonitoredPoints}\n          rerender={zoomLevels[mapZoomLevel]}\n          factoriesGroup={unmonitoredFactoriesClusterGroup}\n          wwtpsGroup={wwtpsLayerGroup}\n          collectorsGroup={collectorsLayerGroup}\n          forEventsView={false}\n        />\n      )\n    );\n  }, [mapRef.current, points, focusedEventPresent, mapZoomLevel]);\n\n  const memoizedEdges = useMemo(() => {\n    const monitoredEdges = edges.filter((edge) => {\n      const sourcePoint = points.find(\n        (point) =>\n          point.id === edge.source_point_id && point.descendants_has_device,\n      );\n      const parentPoint = points.find(\n        (point) =>\n          point.id === edge.target_point_id && point.descendants_has_device,\n      );\n\n      // Only keep edges where both source and parent points exist in points array and have has_device as true\n      return sourcePoint || parentPoint;\n    });\n\n    return (\n      mapRef.current !== null &&\n      edgesCheckbox && (\n        <Edges\n          edges={monitoredEdges!}\n          map={mapRef.current}\n          L={L}\n          points={points!}\n          hideEdges={hideEdges}\n          hideArrows={true}\n          allowUnmonitoredDescendants={includeUnmonitoredDescendantsForEdges}\n          group={monitoredEdgesGroup}\n        />\n      )\n    );\n  }, [mapRef.current, points, focusedEventPresent, mapZoomLevel]);\n\n  const memoizedUnmonitoredEdges = useMemo(() => {\n    const unmonitoredEdges = edges.filter((edge) => {\n      const sourcePoint = points.find(\n        (point) =>\n          point.id === edge.source_point_id && !point.descendants_has_device,\n      );\n      const parentPoint = points.find(\n        (point) =>\n          point.id === edge.target_point_id && !point.descendants_has_device,\n      );\n\n      return sourcePoint && parentPoint;\n    });\n\n    return (\n      mapRef.current !== null &&\n      edgesCheckbox && (\n        <Edges\n          edges={unmonitoredEdges!}\n          map={mapRef.current}\n          L={L}\n          points={points!}\n          hideEdges={hideEdges}\n          hideArrows={true}\n          allowUnmonitoredDescendants={includeUnmonitoredDescendantsForEdges}\n          group={unmonitoredEdgesGroup}\n          shouldntDraw={hiddenUnmonitoredEdgesGroup.getLayers().length !== 0}\n        />\n      )\n    );\n  }, [mapRef.current, points, focusedEventPresent, mapZoomLevel]);\n\n  const setupCheckboxListener = (selector, onChange) => {\n    const checkbox = document.querySelector(selector);\n    if (checkbox === null) return;\n    checkbox.addEventListener('change', () => onChange(checkbox.checked));\n  };\n\n  const handleEdgesCheckboxChange = (isChecked) => {\n    setEdgesCheckbox(isChecked);\n  };\n\n  const handlePointsCheckboxChange = (isChecked) => {\n    let zoom = zoomLevels[mapRef.current.getZoom()];\n\n    if (isChecked) {\n      hiddenFactoriesClusterGroup.addLayer(unmonitoredFactoriesClusterGroup);\n      unmonitoredFactoriesClusterGroup.clearLayers();\n\n      if (zoom === 'Medium' || zoom === 'Small') {\n        hiddenUnmonitoredEdgesGroup.addLayer(unmonitoredEdgesGroup);\n        unmonitoredEdgesGroup.removeFrom(mapRef.current);\n      }\n    } else {\n      unmonitoredFactoriesClusterGroup.addLayer(hiddenFactoriesClusterGroup);\n      hiddenFactoriesClusterGroup.clearLayers();\n\n      if (zoom === 'Medium' || zoom === 'Small') {\n        unmonitoredEdgesGroup.addLayer(hiddenUnmonitoredEdgesGroup);\n        hiddenUnmonitoredEdgesGroup.removeFrom(mapRef.current);\n        hiddenUnmonitoredEdgesGroup.clearLayers();\n        unmonitoredEdgesGroup.addTo(mapRef.current);\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    switch (zoomLevels[mapZoomLevel]) {\n      case 'Small':\n      case 'Medium':\n        payload = zoomRulesForEventsView();\n        break;\n      // case 'MLarge':\n      // case 'Large':\n      // case 'XLarge':\n      // default:\n      //   payload = <>{memoizedPoints}</>;\n      //   break;\n    }\n\n    return payload;\n  };\n\n  const memoizedZoomControl = useMemo(() => {\n    const payload = forEventsView\n      ? zoomRulesForEventsView()\n      : zoomRulesForDashaboardMaps();\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      // factoriesClusterGroup.clearLayers();\n      // wwtpsLayerGroup.clearLayers();\n      // collectorsLayerGroup.clearLayers();\n      // areasLayerGroup.clearLayers();\n      // mapRef.current?.removeLayer(factoriesClusterGroup);\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      areaFocusLogic(mapRef, isValidArea, areaToCenterBy);\n      trackLayerbox();\n    }\n  }, [mapRef.current, 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  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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"}
@@ -20,7 +20,8 @@ var Edge = function Edge(_ref) {
20
20
  hideEdges = _ref$hideEdges === void 0 ? false : _ref$hideEdges,
21
21
  _ref$allowUnmonitored = _ref.allowUnmonitoredDescendants,
22
22
  allowUnmonitoredDescendants = _ref$allowUnmonitored === void 0 ? false : _ref$allowUnmonitored,
23
- specificEvent = _ref.specificEvent;
23
+ specificEvent = _ref.specificEvent,
24
+ group = _ref.group;
24
25
  var dispatch = (0, _reactRedux.useDispatch)();
25
26
  var shapeDataExist = function shapeDataExist() {
26
27
  return Object.keys(edge.shape_data).length !== 0 && edge.shape_data.find(function (data) {
@@ -45,7 +46,7 @@ var Edge = function Edge(_ref) {
45
46
  color: 'rgb(227,227,227)',
46
47
  weight: hideEdges ? 0 : 6,
47
48
  opacity: hideEdges ? 0 : 1
48
- }).addTo(map);
49
+ });
49
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));
50
51
  polylineBack['kando_object_id'] = edge.id;
51
52
  polylineBack['kando_object'] = 'Edge';
@@ -54,7 +55,7 @@ var Edge = function Edge(_ref) {
54
55
  color: 'rgb(157,157,157)',
55
56
  weight: hideEdges ? 0 : 1,
56
57
  opacity: hideEdges ? 0 : 1
57
- }).addTo(map);
58
+ });
58
59
  polylineFront['kando_object_id'] = edge.id;
59
60
  polylineFront['kando_object'] = 'EdgeFront';
60
61
  polylineFront.bringToFront();
@@ -77,9 +78,13 @@ var Edge = function Edge(_ref) {
77
78
  }
78
79
  })
79
80
  }]
80
- }).addTo(map);
81
+ });
81
82
  tailDash['kando_object'] = 'Arrow';
82
83
  }
84
+ [polylineBack, polylineFront, tailDash].forEach(function (layer) {
85
+ group.addLayer(layer);
86
+ });
87
+ group.addTo(map);
83
88
  if (specificEvent !== undefined) {
84
89
  dispatch((0, _actions.setHoveredEdgePaths)([polylineBack, polylineFront]));
85
90
  }
@@ -101,4 +106,4 @@ var Edge = function Edge(_ref) {
101
106
  var connector = (0, _reactRedux.connect)(null);
102
107
  var _default = connector(Edge);
103
108
  exports.default = _default;
104
- //# 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","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","addTo","bindPopup","concat","group","name","distance","bringToFront","polylineFront","tailDash","window","Symbol","polylineDecorator","_latlngs","patterns","offset","repeat","symbol","arrowHead","pixelSize","polygon","pathOptions","stroke","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};\n\nconst Edge: React.FC<Props> = ({\n  L,\n  map,\n  edge,\n  points,\n  hideEdges = false,\n  allowUnmonitoredDescendants = false,\n  specificEvent,\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      }).addTo(map);\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      }).addTo(map);\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        }).addTo(map);\n        tailDash['kando_object'] = 'Arrow';\n      }\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 : 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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"}
@@ -22,7 +22,10 @@ var Edges = function Edges(_ref) {
22
22
  hideArrows = _ref$hideArrows === void 0 ? false : _ref$hideArrows,
23
23
  _ref$allowUnmonitored = _ref.allowUnmonitoredDescendants,
24
24
  allowUnmonitoredDescendants = _ref$allowUnmonitored === void 0 ? false : _ref$allowUnmonitored,
25
- specificEvent = _ref.specificEvent;
25
+ specificEvent = _ref.specificEvent,
26
+ group = _ref.group,
27
+ _ref$shouldntDraw = _ref.shouldntDraw,
28
+ shouldntDraw = _ref$shouldntDraw === void 0 ? false : _ref$shouldntDraw;
26
29
  (0, _react.useEffect)(function () {
27
30
  return function cleanup() {
28
31
  for (var property in map._layers) {
@@ -38,6 +41,7 @@ var Edges = function Edges(_ref) {
38
41
  });
39
42
  };
40
43
  edges = shownEdges();
44
+ if (shouldntDraw) return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null);
41
45
  return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, edges.length !== 0 && edges.map(function (edge) {
42
46
  return /*#__PURE__*/_react.default.createElement(_Edge.default, {
43
47
  L: L,
@@ -47,7 +51,8 @@ var Edges = function Edges(_ref) {
47
51
  points: points,
48
52
  hideEdges: hideEdges,
49
53
  specificEvent: specificEvent,
50
- allowUnmonitoredDescendants: allowUnmonitoredDescendants
54
+ allowUnmonitoredDescendants: allowUnmonitoredDescendants,
55
+ group: group
51
56
  });
52
57
  }), !hideEdges && !hideArrows && edges.length !== 0 && /*#__PURE__*/_react.default.createElement(_Arrows.Arrows, {
53
58
  map: map,
@@ -58,4 +63,4 @@ var Edges = function Edges(_ref) {
58
63
  };
59
64
  var _default = Edges;
60
65
  exports.default = _default;
61
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVXaWxkY2FyZCIsInJlcXVpcmUiLCJfQXJyb3dzIiwiX0VkZ2UiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwiX2dldFJlcXVpcmVXaWxkY2FyZENhY2hlIiwibm9kZUludGVyb3AiLCJXZWFrTWFwIiwiY2FjaGVCYWJlbEludGVyb3AiLCJjYWNoZU5vZGVJbnRlcm9wIiwib2JqIiwiX19lc01vZHVsZSIsIl90eXBlb2YiLCJkZWZhdWx0IiwiY2FjaGUiLCJoYXMiLCJnZXQiLCJuZXdPYmoiLCJoYXNQcm9wZXJ0eURlc2NyaXB0b3IiLCJPYmplY3QiLCJkZWZpbmVQcm9wZXJ0eSIsImdldE93blByb3BlcnR5RGVzY3JpcHRvciIsImtleSIsInByb3RvdHlwZSIsImhhc093blByb3BlcnR5IiwiY2FsbCIsImRlc2MiLCJzZXQiLCJFZGdlcyIsIl9yZWYiLCJMIiwiZWRnZXMiLCJtYXAiLCJwb2ludHMiLCJfcmVmJGhpZGVFZGdlcyIsImhpZGVFZGdlcyIsIl9yZWYkaGlkZUFycm93cyIsImhpZGVBcnJvd3MiLCJfcmVmJGFsbG93VW5tb25pdG9yZWQiLCJhbGxvd1VubW9uaXRvcmVkRGVzY2VuZGFudHMiLCJzcGVjaWZpY0V2ZW50IiwidXNlRWZmZWN0IiwiY2xlYW51cCIsInByb3BlcnR5IiwiX2xheWVycyIsImthbmRvX29iamVjdCIsInJlbW92ZUxheWVyIiwic2hvd25FZGdlcyIsImZpbHRlciIsImVkZ2UiLCJkZXNjZW5kYW50c19oYXNfZGV2aWNlIiwiZGVzY2VuZGFudHNfaGFzX25vbmVfY29sbGVjdG9ycyIsImNyZWF0ZUVsZW1lbnQiLCJGcmFnbWVudCIsImxlbmd0aCIsImlkIiwiQXJyb3dzIiwiX2RlZmF1bHQiLCJleHBvcnRzIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL1dpZGdldHMvTWFwL2VkZ2VzL0VkZ2VzLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0IH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgQXJyb3dzIH0gZnJvbSAnLi9hcnJvd3MvQXJyb3dzJztcbmltcG9ydCB7IElFZGdlIH0gZnJvbSAnc3JjL3N0b3JlL2VkZ2VzL21vZGVscy9JRWRnZSc7XG5pbXBvcnQgeyBJUG9pbnQgfSBmcm9tICdzcmMvc3RvcmUvcG9pbnRzL21vZGVscy9JUG9pbnQnO1xuaW1wb3J0IEVkZ2UgZnJvbSAnLi9FZGdlJztcbmltcG9ydCB7IElFdmVudCB9IGZyb20gJy4uLy4uLy4uL3N0b3JlL2V2ZW50cy9tb2RlbHMvSUV2ZW50JztcblxuaW50ZXJmYWNlIEVkZ2VzUHJvcHMge1xuICBtYXA6IGFueTtcbiAgTDogYW55O1xuICBlZGdlczogSUVkZ2VbXTtcbiAgcG9pbnRzOiBJUG9pbnRbXTtcbiAgaGlkZUVkZ2VzPzogYm9vbGVhbjtcbiAgaGlkZUFycm93cz86IGJvb2xlYW47XG4gIHNwZWNpZmljRXZlbnQ/OiBJRXZlbnQ7XG4gIGFsbG93VW5tb25pdG9yZWREZXNjZW5kYW50cz86IGJvb2xlYW47XG59XG5cbmNvbnN0IEVkZ2VzOiBSZWFjdC5GQzxFZGdlc1Byb3BzPiA9ICh7XG4gIEwsXG4gIGVkZ2VzLFxuICBtYXAsXG4gIHBvaW50cyxcbiAgaGlkZUVkZ2VzID0gZmFsc2UsXG4gIGhpZGVBcnJvd3MgPSBmYWxzZSxcbiAgYWxsb3dVbm1vbml0b3JlZERlc2NlbmRhbnRzID0gZmFsc2UsXG4gIHNwZWNpZmljRXZlbnQsXG59KSA9PiB7XG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgcmV0dXJuIGZ1bmN0aW9uIGNsZWFudXAoKSB7XG4gICAgICBmb3IgKGNvbnN0IHByb3BlcnR5IGluIG1hcC5fbGF5ZXJzKSB7XG4gICAgICAgIGlmIChcbiAgICAgICAgICBtYXAuX2xheWVyc1twcm9wZXJ0eV0ua2FuZG9fb2JqZWN0ID09PSAnRWRnZScgfHxcbiAgICAgICAgICBtYXAuX2xheWVyc1twcm9wZXJ0eV0ua2FuZG9fb2JqZWN0ID09PSAnRWRnZUZyb250JyB8fFxuICAgICAgICAgIG1hcC5fbGF5ZXJzW3Byb3BlcnR5XS5rYW5kb19vYmplY3QgPT09ICdBcnJvdydcbiAgICAgICAgKSB7XG4gICAgICAgICAgbWFwLnJlbW92ZUxheWVyKG1hcC5fbGF5ZXJzW3Byb3BlcnR5XSk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9O1xuICB9LCBbXSk7XG5cbiAgY29uc3Qgc2hvd25FZGdlcyA9ICgpID0+IHtcbiAgICByZXR1cm4gZWRnZXMuZmlsdGVyKFxuICAgICAgKGVkZ2UpID0+XG4gICAgICAgIGVkZ2UuZGVzY2VuZGFudHNfaGFzX2RldmljZSA9PT0gdHJ1ZSB8fFxuICAgICAgICBlZGdlLmRlc2NlbmRhbnRzX2hhc19ub25lX2NvbGxlY3RvcnMgPT09IHRydWUsXG4gICAgKTtcbiAgfTtcblxuICBlZGdlcyA9IHNob3duRWRnZXMoKTtcblxuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICB7ZWRnZXMubGVuZ3RoICE9PSAwICYmXG4gICAgICAgIGVkZ2VzLm1hcCgoZWRnZTogSUVkZ2UpID0+IHtcbiAgICAgICAgICByZXR1cm4gKFxuICAgICAgICAgICAgPEVkZ2VcbiAgICAgICAgICAgICAgTD17TH1cbiAgICAgICAgICAgICAgZWRnZT17ZWRnZX1cbiAgICAgICAgICAgICAgbWFwPXttYXB9XG4gICAgICAgICAgICAgIGtleT17ZWRnZS5pZH1cbiAgICAgICAgICAgICAgcG9pbnRzPXtwb2ludHN9XG4gICAgICAgICAgICAgIGhpZGVFZGdlcz17aGlkZUVkZ2VzfVxuICAgICAgICAgICAgICBzcGVjaWZpY0V2ZW50PXtzcGVjaWZpY0V2ZW50fVxuICAgICAgICAgICAgICBhbGxvd1VubW9uaXRvcmVkRGVzY2VuZGFudHM9e2FsbG93VW5tb25pdG9yZWREZXNjZW5kYW50c31cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKTtcbiAgICAgICAgfSl9XG4gICAgICB7IWhpZGVFZGdlcyAmJiAhaGlkZUFycm93cyAmJiBlZGdlcy5sZW5ndGggIT09IDAgJiYgKFxuICAgICAgICA8QXJyb3dzIG1hcD17bWFwfSBMPXtMfSBlZGdlcz17ZWRnZXN9IHBvaW50cz17cG9pbnRzfSAvPlxuICAgICAgKX1cbiAgICA8Lz5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IEVkZ2VzO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7OztBQUFBLElBQUFBLE1BQUEsR0FBQUMsdUJBQUEsQ0FBQUMsT0FBQTtBQUNBLElBQUFDLE9BQUEsR0FBQUQsT0FBQTtBQUdBLElBQUFFLEtBQUEsR0FBQUMsc0JBQUEsQ0FBQUgsT0FBQTtBQUEwQixTQUFBSSx5QkFBQUMsV0FBQSxlQUFBQyxPQUFBLGtDQUFBQyxpQkFBQSxPQUFBRCxPQUFBLFFBQUFFLGdCQUFBLE9BQUFGLE9BQUEsWUFBQUYsd0JBQUEsWUFBQUEseUJBQUFDLFdBQUEsV0FBQUEsV0FBQSxHQUFBRyxnQkFBQSxHQUFBRCxpQkFBQSxLQUFBRixXQUFBO0FBQUEsU0FBQU4sd0JBQUFVLEdBQUEsRUFBQUosV0FBQSxTQUFBQSxXQUFBLElBQUFJLEdBQUEsSUFBQUEsR0FBQSxDQUFBQyxVQUFBLFdBQUFELEdBQUEsUUFBQUEsR0FBQSxhQUFBRSxPQUFBLENBQUFGLEdBQUEseUJBQUFBLEdBQUEsNEJBQUFHLE9BQUEsRUFBQUgsR0FBQSxVQUFBSSxLQUFBLEdBQUFULHdCQUFBLENBQUFDLFdBQUEsT0FBQVEsS0FBQSxJQUFBQSxLQUFBLENBQUFDLEdBQUEsQ0FBQUwsR0FBQSxZQUFBSSxLQUFBLENBQUFFLEdBQUEsQ0FBQU4sR0FBQSxTQUFBTyxNQUFBLFdBQUFDLHFCQUFBLEdBQUFDLE1BQUEsQ0FBQUMsY0FBQSxJQUFBRCxNQUFBLENBQUFFLHdCQUFBLFdBQUFDLEdBQUEsSUFBQVosR0FBQSxRQUFBWSxHQUFBLGtCQUFBSCxNQUFBLENBQUFJLFNBQUEsQ0FBQUMsY0FBQSxDQUFBQyxJQUFBLENBQUFmLEdBQUEsRUFBQVksR0FBQSxTQUFBSSxJQUFBLEdBQUFSLHFCQUFBLEdBQUFDLE1BQUEsQ0FBQUUsd0JBQUEs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
66
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_Arrows","_Edge","_interopRequireDefault","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","Edges","_ref","L","edges","map","points","_ref$hideEdges","hideEdges","_ref$hideArrows","hideArrows","_ref$allowUnmonitored","allowUnmonitoredDescendants","specificEvent","group","_ref$shouldntDraw","shouldntDraw","useEffect","cleanup","property","_layers","kando_object","removeLayer","shownEdges","filter","edge","descendants_has_device","descendants_has_none_collectors","createElement","Fragment","length","id","Arrows","_default","exports"],"sources":["../../../../src/Widgets/Map/edges/Edges.tsx"],"sourcesContent":["import React, { useEffect } from 'react';\nimport { Arrows } from './arrows/Arrows';\nimport { IEdge } from 'src/store/edges/models/IEdge';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport Edge from './Edge';\nimport { IEvent } from '../../../store/events/models/IEvent';\n\ninterface EdgesProps {\n  map: any;\n  L: any;\n  edges: IEdge[];\n  points: IPoint[];\n  hideEdges?: boolean;\n  hideArrows?: boolean;\n  specificEvent?: IEvent;\n  allowUnmonitoredDescendants?: boolean;\n  group: any;\n}\n\nconst Edges: React.FC<EdgesProps> = ({\n  L,\n  edges,\n  map,\n  points,\n  hideEdges = false,\n  hideArrows = false,\n  allowUnmonitoredDescendants = false,\n  specificEvent,\n  group,\n  shouldntDraw = false,\n}) => {\n  useEffect(() => {\n    return function cleanup() {\n      for (const property in map._layers) {\n        if (\n          map._layers[property].kando_object === 'Edge' ||\n          map._layers[property].kando_object === 'EdgeFront' ||\n          map._layers[property].kando_object === 'Arrow'\n        ) {\n          map.removeLayer(map._layers[property]);\n        }\n      }\n    };\n  }, []);\n\n  const shownEdges = () => {\n    return edges.filter(\n      (edge) =>\n        edge.descendants_has_device === true ||\n        edge.descendants_has_none_collectors === true,\n    );\n  };\n\n  edges = shownEdges();\n\n  if (shouldntDraw) return <></>;\n  return (\n    <>\n      {edges.length !== 0 &&\n        edges.map((edge: IEdge) => {\n          return (\n            <Edge\n              L={L}\n              edge={edge}\n              map={map}\n              key={edge.id}\n              points={points}\n              hideEdges={hideEdges}\n              specificEvent={specificEvent}\n              allowUnmonitoredDescendants={allowUnmonitoredDescendants}\n              group={group}\n            />\n          );\n        })}\n      {!hideEdges && !hideArrows && edges.length !== 0 && (\n        <Arrows map={map} L={L} edges={edges} points={points} />\n      )}\n    </>\n  );\n};\n\nexport default Edges;\n"],"mappings":"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"}
@@ -148,6 +148,7 @@ var AreaBox = function AreaBox(_ref) {
148
148
  })) : /*#__PURE__*/_react.default.createElement("div", {
149
149
  className: "kd-front"
150
150
  }, /*#__PURE__*/_react.default.createElement(_Map.Map, {
151
+ key: Date.now(),
151
152
  color: mapColor,
152
153
  points: area.shape_data,
153
154
  markers: area.main_collectors
@@ -159,4 +160,4 @@ var AlignCenter = _styledComponents.default.div.withConfig({
159
160
  displayName: "AreaBox__AlignCenter",
160
161
  componentId: "sc-teh2e3-0"
161
162
  })(["display:flex;flex-direction:column;align-items:space-between;justify-content:space-between;font-size:14px;"]);
162
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRedux","_StyledLink","_i18n","_interopRequireDefault","_scoreToData","_Truncate","_Analytics","_PollutionScorePercent","_PotentialImpact","_Map","_PieChart","_styles","_InfoTooltip","_reactRouterDom","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","AreaBox","_ref","_area$use_cases","area","showInfoTooltip","titleRef","useRef","_useState","useState","_useState2","_slicedToArray2","showPieChart","setShowPieChart","_useState3","_useState4","enableToolTip","setEnableTooltip","_useState5","_useState6","showAll","setShowAll","waterAuthorityName","useSelector","state","global_data","permissions","utilities_dashboard","enable_area_links","up","pollution","polluted_percent_change","scoreText","i18n","t","areaScore","parseFloat","area_score","mapColor","areaScoreToColor","show_use_cases","use_cases","length","location","useLocation","isUndefined","is_sub_area","main_collectors","tooltipData","togglePotentialImpactStates","event","analyticsTrack","selection","page_name","pathname","utility_name","stopPropagation","preventDefault","useEffect","current","offsetWidth","scrollWidth","createElement","StyledLink","className","to","dashboard_url","onClick","area_name","Box","area_id","concat","ref","characters","inheritTextAlign","total_factories","InfoTooltip","title","data","Fragment","PollutionScorePercent","change","areaLength","PotentialImpact","show_state","toggleShow","onMouseEnter","onMouseLeave","PieChart","quality","type_distribution","Map","color","points","shape_data","markers","exports","AlignCenter","styled","div","withConfig","displayName","componentId"],"sources":["../../../../../src/Widgets/MostPolluting/Areas/AreaBox/AreaBox.tsx"],"sourcesContent":["import React, { useEffect, useRef, useState } from 'react';\nimport { useSelector } from 'react-redux';\nimport { StyledLink } from 'src/components/Links/StyledLink/StyledLink';\nimport i18n from 'src/utilities/i18n';\nimport { areaScoreToColor } from 'src/utilities/scoreToData';\nimport Truncate from 'src/utilities/Truncate';\nimport styled from 'styled-components/macro';\nimport { analyticsTrack } from 'src/utilities/Analytics';\nimport { PollutionScorePercent } from '../../components/PollutionScorePercent';\nimport { PotentialImpact } from '../../components/PotentialImpact';\nimport { Area } from '../areasResponse.interface';\nimport { Map } from './Map/Map';\nimport { PieChart } from './PieChart/PieChart';\nimport { Box } from './styles';\nimport { InfoTooltip } from 'src/ui-kit/InfoTooltip/InfoTooltip';\nimport { useLocation } from 'react-router-dom';\n\ninterface AreaBoxProps {\n  area: Area;\n  showInfoTooltip: boolean;\n}\n\nexport const AreaBox: React.FC<AreaBoxProps> = ({ area, showInfoTooltip }) => {\n  const titleRef: any = useRef(null);\n  const [showPieChart, setShowPieChart] = useState<boolean>(false);\n  const [enableToolTip, setEnableTooltip] = useState<boolean>(false);\n  const [showAll, setShowAll] = useState<boolean>(false);\n  const waterAuthorityName = useSelector(\n    (state) => state.global_data.waterAuthorityName,\n  );\n  const permissions = useSelector(\n    (state) => state.permissions.utilities_dashboard.enable_area_links,\n  );\n\n  const up = area.pollution.polluted_percent_change >= 0;\n  let scoreText = i18n.t(\n    'dashboard_v2.utility_dashboard.topbar.quality-summary.low',\n  );\n  const areaScore = parseFloat(area.area_score);\n  let mapColor = areaScoreToColor(area);\n  const show_use_cases = area.use_cases?.length > 0;\n\n  const location = useLocation();\n  const isUndefined =\n    areaScore === -1 || (area.is_sub_area && area.main_collectors.length === 0);\n\n  const tooltipData =\n    i18n.t('helpers.info_tooltip.pollution_score.main') +\n    i18n.t('helpers.info_tooltip.pollution_score.sub') +\n    i18n.t('helpers.info_tooltip.pollution_score.sub1');\n\n  const togglePotentialImpactStates = (event) => {\n    analyticsTrack('Potential Impact Clicked', {\n      selection: showAll ? 'Show Less' : 'Show All',\n      page_name: location.pathname,\n      utility_name: waterAuthorityName,\n    });\n    setShowAll(!showAll);\n    event.stopPropagation();\n    event.preventDefault();\n  };\n\n  if (areaScore && areaScore >= 30) {\n    if (areaScore < 50) {\n      scoreText = i18n.t(\n        'dashboard_v2.utility_dashboard.topbar.quality-summary.medium',\n      );\n    } else if (areaScore < 70) {\n      scoreText = i18n.t(\n        'dashboard_v2.utility_dashboard.topbar.quality-summary.high',\n      );\n    } else if (areaScore >= 70) {\n      scoreText = i18n.t(\n        'dashboard_v2.utility_dashboard.topbar.quality-summary.extreme',\n      );\n    }\n  } else if (isUndefined) {\n    scoreText = i18n.t(\n      'dashboard_v2.utility_dashboard.topbar.quality-summary.undefined',\n    );\n  }\n\n  useEffect(() => {\n    if (titleRef) {\n      //check if we want to enable tooltip\n      setEnableTooltip(\n        titleRef.current.offsetWidth < titleRef.current.scrollWidth,\n      );\n    }\n  }, [titleRef]);\n\n  return (\n    <StyledLink\n      className={!permissions && 'disabled-link'}\n      to={area.dashboard_url}\n      onClick={() => {\n        analyticsTrack('Area card clicked', {\n          area_name: area.area_name,\n          utility_name: waterAuthorityName,\n        });\n      }}\n    >\n      <Box up={up} data-area-id={area.area_id}>\n        <div\n          className={`kd-top ${\n            // eslint-disable-next-line no-constant-condition\n            false && enableToolTip ? ' kd-tooltip' : ''\n          }`}\n          data-text={area.area_name}\n        >\n          <div className=\"kd-box-main-title\">\n            <div className=\"kd-title\" ref={titleRef}>\n              <Truncate characters={0} inheritTextAlign={true}>\n                <span>{area.area_name}</span>\n              </Truncate>\n            </div>\n          </div>\n          <div className=\"kd-factories\">\n            {i18n.t('dashboard_v2.utility_dashboard.most-polluting.factories')}\n            <span className=\"factories-num\">\n              {' '}\n              {area.total_factories}\n              {''}\n            </span>\n          </div>\n        </div>\n        <div className=\"kd-content\">\n          <div className=\"kd-percent\">\n            {!showAll && (\n              <div className=\"score-holder\">\n                <div className=\"title\">\n                  {i18n.t(\n                    'dashboard_v2.utility_dashboard.topbar.quality-summary.pollution-score',\n                  )}\n                  {showInfoTooltip && (\n                    <InfoTooltip\n                      title={i18n.t(\n                        'dashboard_v2.utility_dashboard.topbar.quality-summary.pollution-score',\n                      )}\n                      data={tooltipData}\n                    >\n                      <></>\n                    </InfoTooltip>\n                  )}\n                </div>\n                <div className=\"pollution-holder\">\n                  <PollutionScorePercent\n                    change={area.pollution.polluted_percent_change}\n                    areaLength={\n                      area.is_sub_area ? area.main_collectors.length : 1\n                    }\n                    scoreText={scoreText}\n                    areaScore={isUndefined ? -1 : areaScore}\n                  />\n                </div>\n              </div>\n            )}\n            <>\n              {show_use_cases && (\n                <PotentialImpact\n                  use_cases={area.use_cases}\n                  show_state={showAll}\n                  toggleShow={togglePotentialImpactStates}\n                ></PotentialImpact>\n              )}\n            </>\n          </div>\n          <div\n            className=\"map-holder\"\n            onMouseEnter={() => setShowPieChart(true)}\n            onMouseLeave={() => setShowPieChart(false)}\n          >\n            {showPieChart ? (\n              <span className=\"back\">\n                <PieChart quality={area.pollution.type_distribution} />\n              </span>\n            ) : (\n              <div className=\"kd-front\">\n                <Map\n                  color={mapColor}\n                  points={area.shape_data}\n                  markers={area.main_collectors}\n                />\n              </div>\n            )}\n          </div>\n        </div>\n      </Box>\n    </StyledLink>\n  );\n};\n//eslint-disable-next-line\nconst AlignCenter = styled.div`\n  display: flex;\n  flex-direction: column;\n  align-items: space-between;\n  justify-content: space-between;\n  font-size: 14px;\n`;\n"],"mappings":"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"}
163
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRedux","_StyledLink","_i18n","_interopRequireDefault","_scoreToData","_Truncate","_Analytics","_PollutionScorePercent","_PotentialImpact","_Map","_PieChart","_styles","_InfoTooltip","_reactRouterDom","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","AreaBox","_ref","_area$use_cases","area","showInfoTooltip","titleRef","useRef","_useState","useState","_useState2","_slicedToArray2","showPieChart","setShowPieChart","_useState3","_useState4","enableToolTip","setEnableTooltip","_useState5","_useState6","showAll","setShowAll","waterAuthorityName","useSelector","state","global_data","permissions","utilities_dashboard","enable_area_links","up","pollution","polluted_percent_change","scoreText","i18n","t","areaScore","parseFloat","area_score","mapColor","areaScoreToColor","show_use_cases","use_cases","length","location","useLocation","isUndefined","is_sub_area","main_collectors","tooltipData","togglePotentialImpactStates","event","analyticsTrack","selection","page_name","pathname","utility_name","stopPropagation","preventDefault","useEffect","current","offsetWidth","scrollWidth","createElement","StyledLink","className","to","dashboard_url","onClick","area_name","Box","area_id","concat","ref","characters","inheritTextAlign","total_factories","InfoTooltip","title","data","Fragment","PollutionScorePercent","change","areaLength","PotentialImpact","show_state","toggleShow","onMouseEnter","onMouseLeave","PieChart","quality","type_distribution","Map","Date","now","color","points","shape_data","markers","exports","AlignCenter","styled","div","withConfig","displayName","componentId"],"sources":["../../../../../src/Widgets/MostPolluting/Areas/AreaBox/AreaBox.tsx"],"sourcesContent":["import React, { useEffect, useRef, useState } from 'react';\nimport { useSelector } from 'react-redux';\nimport { StyledLink } from 'src/components/Links/StyledLink/StyledLink';\nimport i18n from 'src/utilities/i18n';\nimport { areaScoreToColor } from 'src/utilities/scoreToData';\nimport Truncate from 'src/utilities/Truncate';\nimport styled from 'styled-components/macro';\nimport { analyticsTrack } from 'src/utilities/Analytics';\nimport { PollutionScorePercent } from '../../components/PollutionScorePercent';\nimport { PotentialImpact } from '../../components/PotentialImpact';\nimport { Area } from '../areasResponse.interface';\nimport { Map } from './Map/Map';\nimport { PieChart } from './PieChart/PieChart';\nimport { Box } from './styles';\nimport { InfoTooltip } from 'src/ui-kit/InfoTooltip/InfoTooltip';\nimport { useLocation } from 'react-router-dom';\n\ninterface AreaBoxProps {\n  area: Area;\n  showInfoTooltip: boolean;\n}\n\nexport const AreaBox: React.FC<AreaBoxProps> = ({ area, showInfoTooltip }) => {\n  const titleRef: any = useRef(null);\n  const [showPieChart, setShowPieChart] = useState<boolean>(false);\n  const [enableToolTip, setEnableTooltip] = useState<boolean>(false);\n  const [showAll, setShowAll] = useState<boolean>(false);\n  const waterAuthorityName = useSelector(\n    (state) => state.global_data.waterAuthorityName,\n  );\n  const permissions = useSelector(\n    (state) => state.permissions.utilities_dashboard.enable_area_links,\n  );\n\n  const up = area.pollution.polluted_percent_change >= 0;\n  let scoreText = i18n.t(\n    'dashboard_v2.utility_dashboard.topbar.quality-summary.low',\n  );\n  const areaScore = parseFloat(area.area_score);\n  let mapColor = areaScoreToColor(area);\n  const show_use_cases = area.use_cases?.length > 0;\n\n  const location = useLocation();\n  const isUndefined =\n    areaScore === -1 || (area.is_sub_area && area.main_collectors.length === 0);\n\n  const tooltipData =\n    i18n.t('helpers.info_tooltip.pollution_score.main') +\n    i18n.t('helpers.info_tooltip.pollution_score.sub') +\n    i18n.t('helpers.info_tooltip.pollution_score.sub1');\n\n  const togglePotentialImpactStates = (event) => {\n    analyticsTrack('Potential Impact Clicked', {\n      selection: showAll ? 'Show Less' : 'Show All',\n      page_name: location.pathname,\n      utility_name: waterAuthorityName,\n    });\n    setShowAll(!showAll);\n    event.stopPropagation();\n    event.preventDefault();\n  };\n\n  if (areaScore && areaScore >= 30) {\n    if (areaScore < 50) {\n      scoreText = i18n.t(\n        'dashboard_v2.utility_dashboard.topbar.quality-summary.medium',\n      );\n    } else if (areaScore < 70) {\n      scoreText = i18n.t(\n        'dashboard_v2.utility_dashboard.topbar.quality-summary.high',\n      );\n    } else if (areaScore >= 70) {\n      scoreText = i18n.t(\n        'dashboard_v2.utility_dashboard.topbar.quality-summary.extreme',\n      );\n    }\n  } else if (isUndefined) {\n    scoreText = i18n.t(\n      'dashboard_v2.utility_dashboard.topbar.quality-summary.undefined',\n    );\n  }\n\n  useEffect(() => {\n    if (titleRef) {\n      //check if we want to enable tooltip\n      setEnableTooltip(\n        titleRef.current.offsetWidth < titleRef.current.scrollWidth,\n      );\n    }\n  }, [titleRef]);\n\n  return (\n    <StyledLink\n      className={!permissions && 'disabled-link'}\n      to={area.dashboard_url}\n      onClick={() => {\n        analyticsTrack('Area card clicked', {\n          area_name: area.area_name,\n          utility_name: waterAuthorityName,\n        });\n      }}\n    >\n      <Box up={up} data-area-id={area.area_id}>\n        <div\n          className={`kd-top ${\n            // eslint-disable-next-line no-constant-condition\n            false && enableToolTip ? ' kd-tooltip' : ''\n          }`}\n          data-text={area.area_name}\n        >\n          <div className=\"kd-box-main-title\">\n            <div className=\"kd-title\" ref={titleRef}>\n              <Truncate characters={0} inheritTextAlign={true}>\n                <span>{area.area_name}</span>\n              </Truncate>\n            </div>\n          </div>\n          <div className=\"kd-factories\">\n            {i18n.t('dashboard_v2.utility_dashboard.most-polluting.factories')}\n            <span className=\"factories-num\">\n              {' '}\n              {area.total_factories}\n              {''}\n            </span>\n          </div>\n        </div>\n        <div className=\"kd-content\">\n          <div className=\"kd-percent\">\n            {!showAll && (\n              <div className=\"score-holder\">\n                <div className=\"title\">\n                  {i18n.t(\n                    'dashboard_v2.utility_dashboard.topbar.quality-summary.pollution-score',\n                  )}\n                  {showInfoTooltip && (\n                    <InfoTooltip\n                      title={i18n.t(\n                        'dashboard_v2.utility_dashboard.topbar.quality-summary.pollution-score',\n                      )}\n                      data={tooltipData}\n                    >\n                      <></>\n                    </InfoTooltip>\n                  )}\n                </div>\n                <div className=\"pollution-holder\">\n                  <PollutionScorePercent\n                    change={area.pollution.polluted_percent_change}\n                    areaLength={\n                      area.is_sub_area ? area.main_collectors.length : 1\n                    }\n                    scoreText={scoreText}\n                    areaScore={isUndefined ? -1 : areaScore}\n                  />\n                </div>\n              </div>\n            )}\n            <>\n              {show_use_cases && (\n                <PotentialImpact\n                  use_cases={area.use_cases}\n                  show_state={showAll}\n                  toggleShow={togglePotentialImpactStates}\n                ></PotentialImpact>\n              )}\n            </>\n          </div>\n          <div\n            className=\"map-holder\"\n            onMouseEnter={() => setShowPieChart(true)}\n            onMouseLeave={() => setShowPieChart(false)}\n          >\n            {showPieChart ? (\n              <span className=\"back\">\n                <PieChart quality={area.pollution.type_distribution} />\n              </span>\n            ) : (\n              <div className=\"kd-front\">\n                <Map\n                  key={Date.now()}\n                  color={mapColor}\n                  points={area.shape_data}\n                  markers={area.main_collectors}\n                />\n              </div>\n            )}\n          </div>\n        </div>\n      </Box>\n    </StyledLink>\n  );\n};\n//eslint-disable-next-line\nconst AlignCenter = styled.div`\n  display: flex;\n  flex-direction: column;\n  align-items: space-between;\n  justify-content: space-between;\n  font-size: 14px;\n`;\n"],"mappings":"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"}