@kando-env/kando-ui 1.2.357 → 1.2.358-alpha.0

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.
@@ -10,6 +10,7 @@ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm
10
10
  var L = _interopRequireWildcard(require("leaflet"));
11
11
  require("leaflet.markercluster");
12
12
  require("leaflet.pattern");
13
+ require("utilities/polylinedecorator");
13
14
  var _react = _interopRequireWildcard(require("react"));
14
15
  var _reactRedux = require("react-redux");
15
16
  var _ErrorBoundary = _interopRequireDefault(require("utilities/ErrorBoundary"));
@@ -99,6 +100,10 @@ var Map = function Map(_ref) {
99
100
  var _useState9 = (0, _react.useState)(new L.FeatureGroup()),
100
101
  _useState10 = (0, _slicedToArray2.default)(_useState9, 1),
101
102
  areasLayerGroup = _useState10[0];
103
+ var _useState11 = (0, _react.useState)(false),
104
+ _useState12 = (0, _slicedToArray2.default)(_useState11, 2),
105
+ edgesCheckbox = _useState12[0],
106
+ setEdgesCheckbox = _useState12[1];
102
107
  var memoizedPoints = (0, _react.useMemo)(function () {
103
108
  return mapRef.current !== null && points && /*#__PURE__*/_react.default.createElement(_PointMarkers.PointMarkers, {
104
109
  map: mapRef.current,
@@ -116,13 +121,20 @@ var Map = function Map(_ref) {
116
121
  // mapRef.current !== null && iconZoomControl(mapRef.current);
117
122
  // }, [mapRef.current, points, focusedEventPresent]);
118
123
 
124
+ var trackLayerbox = function trackLayerbox() {
125
+ var checkbox = document.querySelector('#edges-checkbox');
126
+ checkbox.addEventListener('change', function () {
127
+ setEdgesCheckbox(checkbox.checked);
128
+ });
129
+ };
119
130
  var zoomRulesForEventsView = function zoomRulesForEventsView() {
120
- var payload = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_Edges.default, {
131
+ var payload = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, edgesCheckbox && /*#__PURE__*/_react.default.createElement(_Edges.default, {
121
132
  edges: edges,
122
133
  map: mapRef.current,
123
134
  L: L,
124
135
  points: points,
125
136
  hideEdges: hideEdges,
137
+ hideArrows: true,
126
138
  allowUnmonitoredDescendants: includeUnmonitoredDescendantsForEdges
127
139
  }), memoizedPoints);
128
140
  return payload;
@@ -147,7 +159,7 @@ var Map = function Map(_ref) {
147
159
  var memoizedZoomControl = (0, _react.useMemo)(function () {
148
160
  var payload = forEventsView ? zoomRulesForEventsView() : zoomRulesForDashaboardMaps();
149
161
  return payload;
150
- }, [mapZoomLevel, eventsData.isFetching, focusedEvent, hoveredEvent, points, mapRef.current]);
162
+ }, [mapZoomLevel, eventsData.isFetching, focusedEvent, hoveredEvent, points, mapRef.current, edgesCheckbox]);
151
163
  var memoizedEvent = (0, _react.useMemo)(function () {
152
164
  if (focusedEventPresent) {
153
165
  focusedEvent.focused = focusedEventPresent;
@@ -174,7 +186,7 @@ var Map = function Map(_ref) {
174
186
  };
175
187
  }, [focusedEvent, hoveredEvent, global_data.eventFilterParam]);
176
188
  (0, _react.useEffect)(function () {
177
- (0, _MapUtils.initializeMap)(mapZoomLevel, mapBoxStyle, _theme.leafletMap.satellite, mapRef, dispatch, _MapUtils.isValidArea, areaToCenterBy, setMapZoomLevel, forWWTPDashboard);
189
+ (0, _MapUtils.initializeMap)(mapZoomLevel, mapBoxStyle, _theme.leafletMap.satellite, mapRef, dispatch, _MapUtils.isValidArea, areaToCenterBy, setMapZoomLevel, forWWTPDashboard, forEventsView);
178
190
  return function cleanup() {
179
191
  // factoriesClusterGroup.clearLayers();
180
192
  // wwtpsLayerGroup.clearLayers();
@@ -200,6 +212,7 @@ var Map = function Map(_ref) {
200
212
  }).flat();
201
213
  }
202
214
  (0, _MapUtils.areaFocusLogic)(mapRef, _MapUtils.isValidArea, areaToCenterBy);
215
+ trackLayerbox();
203
216
  }
204
217
  }, [mapRef.current, areaToCenterBy]);
205
218
  (0, _react.useEffect)(function () {
@@ -236,4 +249,4 @@ var Map = function Map(_ref) {
236
249
  }), (0, _MapUtils.shoudLoadDependentMapObjects)(edges, areas, global_data, mapRef, points) && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, memoizedEvent, memoizedZoomControl, children))));
237
250
  };
238
251
  exports.Map = Map;
239
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["L","_interopRequireWildcard","require","_react","_reactRedux","_ErrorBoundary","_interopRequireDefault","_AreaPolygons","_Edges","_PointMarkers","_Event","_MapUtils","_theme","_i18n","_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","spiderfyOnMaxZoom","showCoverageOnHover","zoomToBoundsOnClick","animate","disableClusteringAtZoom","removeOutsideVisibleBounds","chunkedLoading","iconCreateFunction","cluster","DivIcon","html","concat","_childCount","i18n","t","className","iconSize","Point","_useState4","factoriesClusterGroup","_useState5","layerGroup","_useState6","wwtpsLayerGroup","_useState7","_useState8","collectorsLayerGroup","_useState9","FeatureGroup","_useState10","areasLayerGroup","memoizedPoints","current","createElement","PointMarkers","rerender","zoomLevels","factoriesGroup","wwtpsGroup","collectorsGroup","zoomRulesForEventsView","payload","Fragment","allowUnmonitoredDescendants","zoomRulesForDashaboardMaps","memoizedZoomControl","isFetching","memoizedEvent","focused","hovered","Event","event","includeNetwork","eventFilterParam","useEffect","cleanup","_mapRef$current","clearLayers","removeLayer","initializeMap","satellite","isValidArea","remove","waterAuthorityId","getZoom","area","shape_data","flat","areaFocusLogic","_mapRef$current2","clicked","eachLayer","layer","kando_object_id","isPopupOpen","Marker","fire","Polygon","sidenavExpanded","id","shouldLoadMapObjects","AreaPolygons","mapZoom","featureGroup","shoudLoadDependentMapObjects","exports"],"sources":["../../../src/Widgets/Map/Map.tsx"],"sourcesContent":["// @ts-ignore\nimport * as L from 'leaflet';\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  initializeMap,\n  isValidArea,\n  shoudLoadDependentMapObjects,\n  shouldLoadMapObjects,\n  zoomLevels,\n} from './MapUtils';\nimport { leafletMap } from '../../styles/theme/theme';\nimport i18n from '../../utilities/i18n';\nimport { useSelectedItem } from 'src/pages/DashboardMap/ListContext';\nrequire('leaflet.markercluster');\n\ninterface MapProps {\n  areas: IArea[];\n  edges?: IEdge[];\n  points?: IPoint[];\n  global_data: IGlobalState;\n  areaToCenterBy?: any;\n  focusedEvent?: IEvent | null;\n  hoveredEvent?: IEvent | null;\n  hideEdges?: boolean;\n  mapBoxStyle?: string;\n  children?: any;\n  style?: CSSProperties;\n  includeUnmonitoredPoints?: boolean;\n  includeUnmonitoredDescendantsForEdges?: boolean;\n  forEventsView: boolean;\n  forWWTPDashboard?: boolean;\n}\n\nexport const Map: React.FC<MapProps> = ({\n  areas,\n  edges,\n  points,\n  global_data,\n  areaToCenterBy,\n  focusedEvent,\n  hoveredEvent,\n  hideEdges = false,\n  mapBoxStyle = leafletMap.mapDefault,\n  children,\n  includeUnmonitoredPoints = true,\n  includeUnmonitoredDescendantsForEdges = false,\n  forEventsView = false,\n  style = {},\n  forWWTPDashboard = false,\n}) => {\n  const { map } = global_data;\n  const mapRef = useRef<L.Map | null>(null);\n  const dispatch = useDispatch();\n  const [mapZoomLevel, setMapZoomLevel] = useState(2);\n  const { selectedItem } = useSelectedItem();\n  const eventsData = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.events_data,\n  );\n  const hoveredEventPresent = useMemo(() => {\n    return hoveredEvent !== null && hoveredEvent !== undefined;\n  }, [hoveredEvent]);\n\n  const focusedEventPresent = useMemo(() => {\n    return focusedEvent !== null && focusedEvent !== undefined;\n  }, [focusedEvent]);\n\n  const [factoriesClusterGroup] = useState(\n    window.customLeaflet.markerClusterGroup({\n      spiderfyOnMaxZoom: false,\n      showCoverageOnHover: false,\n      zoomToBoundsOnClick: true,\n      animate: true,\n      disableClusteringAtZoom: 15,\n      removeOutsideVisibleBounds: false,\n      chunkedLoading: true,\n      iconCreateFunction: function (cluster) {\n        return new L.DivIcon({\n          html: `<div><span>${\n            cluster._childCount\n          }</span></div><div class='marker-cluster-name'>${i18n.t(\n            'industries',\n          )}</div>`,\n          className: 'marker-cluster',\n          iconSize: new L.Point(40, 40),\n        });\n      },\n    }),\n  );\n\n  const [wwtpsLayerGroup] = useState(L.layerGroup());\n  const [collectorsLayerGroup] = useState(L.layerGroup());\n  //const [factoriesLayerGroup] = useState(L.layerGroup());\n  const [areasLayerGroup] = useState(new L.FeatureGroup());\n\n  const memoizedPoints = useMemo(() => {\n    return (\n      mapRef.current !== null &&\n      points && (\n        <PointMarkers\n          map={mapRef.current}\n          points={points}\n          includeUnmonitoredPoints={includeUnmonitoredPoints}\n          rerender={zoomLevels[mapZoomLevel]}\n          factoriesGroup={factoriesClusterGroup}\n          wwtpsGroup={wwtpsLayerGroup}\n          collectorsGroup={collectorsLayerGroup}\n          forEventsView={false}\n        />\n      )\n    );\n  }, [mapRef.current, points, focusedEventPresent, mapZoomLevel]);\n\n  // const activateZoomControlForIcons = useMemo(() => {\n  //   mapRef.current !== null && iconZoomControl(mapRef.current);\n  // }, [mapRef.current, points, focusedEventPresent]);\n\n  const zoomRulesForEventsView = () => {\n    const payload = (\n      <>\n        <Edges\n          edges={edges!}\n          map={mapRef.current}\n          L={L}\n          points={points!}\n          hideEdges={hideEdges}\n          allowUnmonitoredDescendants={includeUnmonitoredDescendantsForEdges}\n        />\n        {memoizedPoints}\n      </>\n    );\n\n    return payload;\n  };\n\n  const zoomRulesForDashaboardMaps = () => {\n    let payload = <>{memoizedPoints}</>;\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  ]);\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    );\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        forWWTPDashboard,\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    }\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":";;;;;;;;;AACA,IAAAA,CAAA,GAAAC,uBAAA,CAAAC,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;AAQA,IAAAU,MAAA,GAAAV,OAAA;AACA,IAAAW,KAAA,GAAAP,sBAAA,CAAAJ,OAAA;AACA,IAAAY,YAAA,GAAAZ,OAAA;AAAqE,SAAAa,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,SAAAf,wBAAAmB,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;AApCrE;;AAeA;;AAsBAzB,OAAO,CAAC,uBAAuB,CAAC;AAoBzB,IAAMoC,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,UAAU,GAAG,IAAAC,uBAAW,EAC5B,UAACC,KAAoC;IAAA,OAAKA,KAAK,CAACC,WAAW;EAAA,CAC7D,CAAC;EACD,IAAMC,mBAAmB,GAAG,IAAAC,cAAO,EAAC,YAAM;IACxC,OAAOrC,YAAY,KAAK,IAAI,IAAIA,YAAY,KAAKsC,SAAS;EAC5D,CAAC,EAAE,CAACtC,YAAY,CAAC,CAAC;EAElB,IAAMuC,mBAAmB,GAAG,IAAAF,cAAO,EAAC,YAAM;IACxC,OAAOtC,YAAY,KAAK,IAAI,IAAIA,YAAY,KAAKuC,SAAS;EAC5D,CAAC,EAAE,CAACvC,YAAY,CAAC,CAAC;EAElB,IAAAyC,UAAA,GAAgC,IAAAhB,eAAQ,EACtCiB,MAAM,CAACC,aAAa,CAACC,kBAAkB,CAAC;MACtCC,iBAAiB,EAAE,KAAK;MACxBC,mBAAmB,EAAE,KAAK;MAC1BC,mBAAmB,EAAE,IAAI;MACzBC,OAAO,EAAE,IAAI;MACbC,uBAAuB,EAAE,EAAE;MAC3BC,0BAA0B,EAAE,KAAK;MACjCC,cAAc,EAAE,IAAI;MACpBC,kBAAkB,EAAE,SAAAA,mBAAUC,OAAO,EAAE;QACrC,OAAO,IAAIlG,CAAC,CAACmG,OAAO,CAAC;UACnBC,IAAI,gBAAAC,MAAA,CACFH,OAAO,CAACI,WAAW,oDAAAD,MAAA,CAC4BE,aAAI,CAACC,CAAC,CACrD,YACF,CAAC,WAAQ;UACTC,SAAS,EAAE,gBAAgB;UAC3BC,QAAQ,EAAE,IAAI1G,CAAC,CAAC2G,KAAK,CAAC,EAAE,EAAE,EAAE;QAC9B,CAAC,CAAC;MACJ;IACF,CAAC,CACH,CAAC;IAAAC,UAAA,OAAApC,eAAA,CAAAjD,OAAA,EAAA+D,UAAA;IArBMuB,qBAAqB,GAAAD,UAAA;EAuB5B,IAAAE,UAAA,GAA0B,IAAAxC,eAAQ,EAACtE,CAAC,CAAC+G,UAAU,CAAC,CAAC,CAAC;IAAAC,UAAA,OAAAxC,eAAA,CAAAjD,OAAA,EAAAuF,UAAA;IAA3CG,eAAe,GAAAD,UAAA;EACtB,IAAAE,UAAA,GAA+B,IAAA5C,eAAQ,EAACtE,CAAC,CAAC+G,UAAU,CAAC,CAAC,CAAC;IAAAI,UAAA,OAAA3C,eAAA,CAAAjD,OAAA,EAAA2F,UAAA;IAAhDE,oBAAoB,GAAAD,UAAA;EAC3B;EACA,IAAAE,UAAA,GAA0B,IAAA/C,eAAQ,EAAC,IAAItE,CAAC,CAACsH,YAAY,CAAC,CAAC,CAAC;IAAAC,WAAA,OAAA/C,eAAA,CAAAjD,OAAA,EAAA8F,UAAA;IAAjDG,eAAe,GAAAD,WAAA;EAEtB,IAAME,cAAc,GAAG,IAAAtC,cAAO,EAAC,YAAM;IACnC,OACElB,MAAM,CAACyD,OAAO,KAAK,IAAI,IACvBhF,MAAM,iBACJvC,MAAA,CAAAoB,OAAA,CAAAoG,aAAA,CAAClH,aAAA,CAAAmH,YAAY;MACX5D,GAAG,EAAEC,MAAM,CAACyD,OAAQ;MACpBhF,MAAM,EAAEA,MAAO;MACfa,wBAAwB,EAAEA,wBAAyB;MACnDsE,QAAQ,EAAEC,oBAAU,CAACrD,YAAY,CAAE;MACnCsD,cAAc,EAAElB,qBAAsB;MACtCmB,UAAU,EAAEf,eAAgB;MAC5BgB,eAAe,EAAEb,oBAAqB;MACtCzD,aAAa,EAAE;IAAM,CACtB,CACF;EAEL,CAAC,EAAE,CAACM,MAAM,CAACyD,OAAO,EAAEhF,MAAM,EAAE2C,mBAAmB,EAAEZ,YAAY,CAAC,CAAC;;EAE/D;EACA;EACA;;EAEA,IAAMyD,sBAAsB,GAAG,SAAzBA,sBAAsBA,CAAA,EAAS;IACnC,IAAMC,OAAO,gBACXhI,MAAA,CAAAoB,OAAA,CAAAoG,aAAA,CAAAxH,MAAA,CAAAoB,OAAA,CAAA6G,QAAA,qBACEjI,MAAA,CAAAoB,OAAA,CAAAoG,aAAA,CAACnH,MAAA,CAAAe,OAAK;MACJkB,KAAK,EAAEA,KAAO;MACduB,GAAG,EAAEC,MAAM,CAACyD,OAAQ;MACpB1H,CAAC,EAAEA,CAAE;MACL0C,MAAM,EAAEA,MAAQ;MAChBM,SAAS,EAAEA,SAAU;MACrBqF,2BAA2B,EAAE5E;IAAsC,CACpE,CAAC,EACDgE,cACD,CACH;IAED,OAAOU,OAAO;EAChB,CAAC;EAED,IAAMG,0BAA0B,GAAG,SAA7BA,0BAA0BA,CAAA,EAAS;IACvC,IAAIH,OAAO,gBAAGhI,MAAA,CAAAoB,OAAA,CAAAoG,aAAA,CAAAxH,MAAA,CAAAoB,OAAA,CAAA6G,QAAA,QAAGX,cAAiB,CAAC;IACnC,QAAQK,oBAAU,CAACrD,YAAY,CAAC;MAC9B,KAAK,OAAO;MACZ,KAAK,QAAQ;QACX0D,OAAO,GAAGD,sBAAsB,CAAC,CAAC;QAClC;MACF;MACA;MACA;MACA;MACA;MACA;IACF;;IAEA,OAAOC,OAAO;EAChB,CAAC;EAED,IAAMI,mBAAmB,GAAG,IAAApD,cAAO,EAAC,YAAM;IACxC,IAAMgD,OAAO,GAAGxE,aAAa,GACzBuE,sBAAsB,CAAC,CAAC,GACxBI,0BAA0B,CAAC,CAAC;IAEhC,OAAOH,OAAO;EAChB,CAAC,EAAE,CACD1D,YAAY,EACZK,UAAU,CAAC0D,UAAU,EACrB3F,YAAY,EACZC,YAAY,EACZJ,MAAM,EACNuB,MAAM,CAACyD,OAAO,CACf,CAAC;EAEF,IAAMe,aAAa,GAAG,IAAAtD,cAAO,EAAC,YAAM;IAClC,IAAIE,mBAAmB,EAAE;MACvBxC,YAAY,CAAE6F,OAAO,GAAGrD,mBAAmB;MAC3CxC,YAAY,CAAE8F,OAAO,GAAG,CAACtD,mBAAmB;IAC9C;IAEA,IAAIH,mBAAmB,EAAE;MACvBpC,YAAY,CAAE6F,OAAO,GAAGzD,mBAAmB;MAC3CpC,YAAY,CAAE4F,OAAO,GAAG,CAACxD,mBAAmB;IAC9C;IAEA,IAAI,CAACA,mBAAmB,IAAI,CAACG,mBAAmB,EAAE,oBAAOlF,MAAA,CAAAoB,OAAA,CAAAoG,aAAA,CAAAxH,MAAA,CAAAoB,OAAA,CAAA6G,QAAA,MAAI,CAAC;IAC9D,oBACEjI,MAAA,CAAAoB,OAAA,CAAAoG,aAAA,CAACjH,MAAA,CAAAkI,KAAK;MACJC,KAAK,EAAEhG,YAAY,IAAKC,YAAc;MACtCkB,GAAG,EAAEA,GAAI;MACTvB,KAAK,EAAEA,KAAO;MACdC,MAAM,EAAEA,MAAQ;MAChBoG,cAAc,EAAE,CAAC5D;IAAoB,CACtC,CAAC;EAEN,CAAC,EAAE,CAACrC,YAAY,EAAEC,YAAY,EAAEH,WAAW,CAACoG,gBAAgB,CAAC,CAAC;EAE9D,IAAAC,gBAAS,EAAC,YAAM;IACd,OAAO,SAASC,OAAOA,CAAA,EAAG;MAAA,IAAAC,eAAA;MACxB9B,oBAAoB,CAAC+B,WAAW,CAAC,CAAC;MAClC,CAAAD,eAAA,GAAAjF,MAAM,CAACyD,OAAO,cAAAwB,eAAA,uBAAdA,eAAA,CAAgBE,WAAW,CAAChC,oBAAoB,CAAC;IACnD,CAAC;EACH,CAAC,EAAE,CAACvE,YAAY,EAAEC,YAAY,EAAEH,WAAW,CAACoG,gBAAgB,CAAC,CAAC;EAE9D,IAAAC,gBAAS,EAAC,YAAM;IACd,IAAAK,uBAAa,EACX5E,YAAY,EACZvB,WAAW,EACXC,iBAAU,CAACmG,SAAS,EACpBrF,MAAM,EACNE,QAAQ,EACRoF,qBAAW,EACX3G,cAAc,EACd8B,eAAe,EACfX,gBACF,CAAC;IAED,OAAO,SAASkF,OAAOA,CAAA,EAAG;MACxB;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACAhF,MAAM,CAACyD,OAAO,CAAC8B,MAAM,CAAC,CAAC;MACvB;IACF,CAAC;EACH,CAAC,EAAE,CAAC7G,WAAW,CAAC8G,gBAAgB,CAAC,CAAC;EAElC,IAAAT,gBAAS,EAAC,YAAM;IACd,IAAI,CAAC/E,MAAM,CAACyD,OAAO,EAAE;MACnB,IAAA2B,uBAAa,EACX5E,YAAY,EACZvB,WAAW,EACXC,iBAAU,CAACmG,SAAS,EACpBrF,MAAM,EACNE,QAAQ,EACRoF,qBAAW,EACX3G,cAAc,EACd8B,eAAe,EACfX,gBACF,CAAC;IACH,CAAC,MAAM;MACLW,eAAe,CAACT,MAAM,CAACyD,OAAO,CAACgC,OAAO,CAAC,CAAC,CAAC;MACzC,IAAI,CAAC9G,cAAc,EAAE;QACnBA,cAAc,GAAGJ,KAAK,CAACwB,GAAG,CAAC,UAAC2F,IAAI;UAAA,OAAKA,IAAI,CAACC,UAAU;QAAA,EAAC,CAACC,IAAI,CAAC,CAAC;MAC9D;MAEA,IAAAC,wBAAc,EAAC7F,MAAM,EAAEsF,qBAAW,EAAE3G,cAAc,CAAC;IACrD;EACF,CAAC,EAAE,CAACqB,MAAM,CAACyD,OAAO,EAAE9E,cAAc,CAAC,CAAC;EAEpC,IAAAoG,gBAAS,EAAC,YAAM;IAAA,IAAAe,gBAAA;IACd,IAAIC,OAAO,GAAG,KAAK;IAEnB,CAAAD,gBAAA,GAAA9F,MAAM,CAACyD,OAAO,cAAAqC,gBAAA,uBAAdA,gBAAA,CAAgBE,SAAS,CAAC,UAACC,KAAK,EAAK;MACnC,IAAIF,OAAO,EAAE;MAEb,IACE,CAAAE,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEC,eAAe,MAAKtF,YAAY,IACvCqF,KAAK,CAACE,WAAW,CAAC,CAAC,KAAK,KAAK,EAC7B;QACA,IAAIF,KAAK,YAAYlK,CAAC,CAACqK,MAAM,EAAE;UAC7BH,KAAK,CAACI,IAAI,CAAC,OAAO,CAAC;QACrB,CAAC,MAAM,IAAIJ,KAAK,YAAYlK,CAAC,CAACuK,OAAO,EAAE;UACrCL,KAAK,CAACI,IAAI,CAAC,aAAa,CAAC;QAC3B;QACAN,OAAO,GAAG,IAAI;MAChB;IACF,CAAC,CAAC;EACJ,CAAC,EAAE,CAACnF,YAAY,CAAC,CAAC;EAElB,oBACE1E,MAAA,CAAAoB,OAAA,CAAAoG,aAAA;IAAKlB,SAAS,EAAC,kBAAkB;IAAC5C,KAAK,EAAEA;EAAM,gBAC7C1D,MAAA,CAAAoB,OAAA,CAAAoG,aAAA;IACElB,SAAS,oBAAAJ,MAAA,CACP1D,WAAW,CAAC6H,eAAe,GAAG,EAAE,GAAG,kCAAkC;EACpE,gBAEHrK,MAAA,CAAAoB,OAAA,CAAAoG,aAAA,CAACtH,cAAA,CAAAkB,OAAa,qBACZpB,MAAA,CAAAoB,OAAA,CAAAoG,aAAA;IAAK8C,EAAE,EAAC;EAAK,CAAM,CAAC,EACnB,IAAAC,8BAAoB,EAAC/H,WAAW,EAAEsB,MAAM,EAAExB,KAAK,EAAEC,MAAM,CAAC,iBACvDvC,MAAA,CAAAoB,OAAA,CAAAoG,aAAA,CAACpH,aAAA,CAAAoK,YAAY;IACXnI,KAAK,EAAEA,KAAM;IACbwB,GAAG,EAAEC,MAAM,CAACyD,OAAQ;IACpB1H,CAAC,EAAEA,CAAE;IACL4C,cAAc,EAAEA,cAAe;IAC/BgI,OAAO,EAAEnG,YAAa;IACtBoD,QAAQ,EAAEC,oBAAU,CAACrD,YAAY,CAAE;IACnC9B,WAAW,EAAEA,WAAY;IACzBkI,YAAY,EAAErD;EAAgB,CAC/B,CACF,EACA,IAAAsD,sCAA4B,EAC3BrI,KAAK,EACLD,KAAK,EACLG,WAAW,EACXsB,MAAM,EACNvB,MACF,CAAC,iBACCvC,MAAA,CAAAoB,OAAA,CAAAoG,aAAA,CAAAxH,MAAA,CAAAoB,OAAA,CAAA6G,QAAA,QACGK,aAAa,EACbF,mBAAmB,EACnBlF,QACD,CAES,CACZ,CACF,CAAC;AAEV,CAAC;AAAC0H,OAAA,CAAAzI,GAAA,GAAAA,GAAA"}
252
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["L","_interopRequireWildcard","require","_react","_reactRedux","_ErrorBoundary","_interopRequireDefault","_AreaPolygons","_Edges","_PointMarkers","_Event","_MapUtils","_theme","_i18n","_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","spiderfyOnMaxZoom","showCoverageOnHover","zoomToBoundsOnClick","animate","disableClusteringAtZoom","removeOutsideVisibleBounds","chunkedLoading","iconCreateFunction","cluster","DivIcon","html","concat","_childCount","i18n","t","className","iconSize","Point","_useState4","factoriesClusterGroup","_useState5","layerGroup","_useState6","wwtpsLayerGroup","_useState7","_useState8","collectorsLayerGroup","_useState9","FeatureGroup","_useState10","areasLayerGroup","_useState11","_useState12","edgesCheckbox","setEdgesCheckbox","memoizedPoints","current","createElement","PointMarkers","rerender","zoomLevels","factoriesGroup","wwtpsGroup","collectorsGroup","trackLayerbox","checkbox","document","querySelector","addEventListener","checked","zoomRulesForEventsView","payload","Fragment","hideArrows","allowUnmonitoredDescendants","zoomRulesForDashaboardMaps","memoizedZoomControl","isFetching","memoizedEvent","focused","hovered","Event","event","includeNetwork","eventFilterParam","useEffect","cleanup","_mapRef$current","clearLayers","removeLayer","initializeMap","satellite","isValidArea","remove","waterAuthorityId","getZoom","area","shape_data","flat","areaFocusLogic","_mapRef$current2","clicked","eachLayer","layer","kando_object_id","isPopupOpen","Marker","fire","Polygon","sidenavExpanded","id","shouldLoadMapObjects","AreaPolygons","mapZoom","featureGroup","shoudLoadDependentMapObjects","exports"],"sources":["../../../src/Widgets/Map/Map.tsx"],"sourcesContent":["// @ts-ignore\nimport * as L from 'leaflet';\nimport 'leaflet.markercluster';\nimport 'leaflet.pattern';\nimport 'src/utilities/polylinedecorator';\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  initializeMap,\n  isValidArea,\n  shoudLoadDependentMapObjects,\n  shouldLoadMapObjects,\n  zoomLevels,\n} from './MapUtils';\nimport { leafletMap } from '../../styles/theme/theme';\nimport i18n from '../../utilities/i18n';\nimport { useSelectedItem } from 'src/pages/DashboardMap/ListContext';\nrequire('leaflet.markercluster');\n\ninterface MapProps {\n  areas: IArea[];\n  edges?: IEdge[];\n  points?: IPoint[];\n  global_data: IGlobalState;\n  areaToCenterBy?: any;\n  focusedEvent?: IEvent | null;\n  hoveredEvent?: IEvent | null;\n  hideEdges?: boolean;\n  mapBoxStyle?: string;\n  children?: any;\n  style?: CSSProperties;\n  includeUnmonitoredPoints?: boolean;\n  includeUnmonitoredDescendantsForEdges?: boolean;\n  forEventsView: boolean;\n  forWWTPDashboard?: boolean;\n}\n\nexport const Map: React.FC<MapProps> = ({\n  areas,\n  edges,\n  points,\n  global_data,\n  areaToCenterBy,\n  focusedEvent,\n  hoveredEvent,\n  hideEdges = false,\n  mapBoxStyle = leafletMap.mapDefault,\n  children,\n  includeUnmonitoredPoints = true,\n  includeUnmonitoredDescendantsForEdges = false,\n  forEventsView = false,\n  style = {},\n  forWWTPDashboard = false,\n}) => {\n  const { map } = global_data;\n  const mapRef = useRef<L.Map | null>(null);\n  const dispatch = useDispatch();\n  const [mapZoomLevel, setMapZoomLevel] = useState(2);\n  const { selectedItem } = useSelectedItem();\n  const eventsData = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.events_data,\n  );\n  const hoveredEventPresent = useMemo(() => {\n    return hoveredEvent !== null && hoveredEvent !== undefined;\n  }, [hoveredEvent]);\n\n  const focusedEventPresent = useMemo(() => {\n    return focusedEvent !== null && focusedEvent !== undefined;\n  }, [focusedEvent]);\n\n  const [factoriesClusterGroup] = useState(\n    window.customLeaflet.markerClusterGroup({\n      spiderfyOnMaxZoom: false,\n      showCoverageOnHover: false,\n      zoomToBoundsOnClick: true,\n      animate: true,\n      disableClusteringAtZoom: 15,\n      removeOutsideVisibleBounds: false,\n      chunkedLoading: true,\n      iconCreateFunction: function (cluster) {\n        return new L.DivIcon({\n          html: `<div><span>${\n            cluster._childCount\n          }</span></div><div class='marker-cluster-name'>${i18n.t(\n            'industries',\n          )}</div>`,\n          className: 'marker-cluster',\n          iconSize: new L.Point(40, 40),\n        });\n      },\n    }),\n  );\n\n  const [wwtpsLayerGroup] = useState(L.layerGroup());\n  const [collectorsLayerGroup] = useState(L.layerGroup());\n  //const [factoriesLayerGroup] = useState(L.layerGroup());\n  const [areasLayerGroup] = useState(new L.FeatureGroup());\n  const [edgesCheckbox, setEdgesCheckbox] = useState(false);\n\n  const memoizedPoints = useMemo(() => {\n    return (\n      mapRef.current !== null &&\n      points && (\n        <PointMarkers\n          map={mapRef.current}\n          points={points}\n          includeUnmonitoredPoints={includeUnmonitoredPoints}\n          rerender={zoomLevels[mapZoomLevel]}\n          factoriesGroup={factoriesClusterGroup}\n          wwtpsGroup={wwtpsLayerGroup}\n          collectorsGroup={collectorsLayerGroup}\n          forEventsView={false}\n        />\n      )\n    );\n  }, [mapRef.current, points, focusedEventPresent, mapZoomLevel]);\n\n  // const activateZoomControlForIcons = useMemo(() => {\n  //   mapRef.current !== null && iconZoomControl(mapRef.current);\n  // }, [mapRef.current, points, focusedEventPresent]);\n\n  const trackLayerbox = () => {\n    let checkbox = document.querySelector('#edges-checkbox');\n    checkbox.addEventListener('change', () => {\n      setEdgesCheckbox(checkbox.checked);\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        {memoizedPoints}\n      </>\n    );\n\n    return payload;\n  };\n\n  const zoomRulesForDashaboardMaps = () => {\n    let payload = <>{memoizedPoints}</>;\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      forEventsView,\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        forWWTPDashboard,\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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"}
@@ -4,7 +4,7 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
4
4
  Object.defineProperty(exports, "__esModule", {
5
5
  value: true
6
6
  });
7
- exports.zoomLevels = exports.topIconOptions = exports.shouldLoadMapObjects = exports.shoudLoadDependentMapObjects = exports.multipleLayeredIcons = exports.middleIconOptions = exports.isValidArea = exports.initializeMap = exports.iconZoomControl = exports.findSpecificLayersFromMap = exports.eventsCounterIcons = exports.eventsCountIcon = exports.bubbleIconOptions = exports.areaFocusLogic = void 0;
7
+ exports.zoomLevels = exports.topIconOptions = exports.toggleEdgesVisibility = exports.shouldLoadMapObjects = exports.shoudLoadDependentMapObjects = exports.multipleLayeredIcons = exports.middleIconOptions = exports.isValidArea = exports.initializeMap = exports.iconZoomControl = exports.findSpecificLayersFromMap = exports.eventsCounterIcons = exports.eventsCountIcon = exports.edgesSpecificLogic = exports.customFunctionalityForMapLayers = exports.bubbleIconOptions = exports.areaFocusLogic = void 0;
8
8
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/defineProperty"));
9
9
  var _leaflet = _interopRequireDefault(require("leaflet"));
10
10
  var _actions = require("../../store/global/actions");
@@ -197,7 +197,74 @@ var baseMaps = function baseMaps(mapBoxStyle, mapBoxSatelliteStyle) {
197
197
  var satellite = _i18n.default.t('map.layers.satellite');
198
198
  return _ref = {}, (0, _defineProperty2.default)(_ref, defaultMap, mapStyle(mapBoxStyle)), (0, _defineProperty2.default)(_ref, satellite, mapStyle(mapBoxSatelliteStyle)), _ref;
199
199
  };
200
- var initializeMap = function initializeMap(mapZoomLevel, mapBoxStyle, mapBoxSatelliteStyle, mapRef, dispatch, isValidArea, areaToCenterBy, setMapZoomLevel, forWWTPDashboard) {
200
+ var toggleEdgesVisibility = function toggleEdgesVisibility(visible, map) {
201
+ map.eachLayer(function (layer) {
202
+ if (layer instanceof _leaflet.default.Polyline && layer.kando_object !== 'Area' || layer instanceof _leaflet.default.Symbol.arrowHead) {
203
+ layer.setStyle({
204
+ opacity: visible ? 1 : 0
205
+ });
206
+ }
207
+ });
208
+ };
209
+ exports.toggleEdgesVisibility = toggleEdgesVisibility;
210
+ var edgesSpecificLogic = function edgesSpecificLogic(defaultOn, map) {
211
+ var checkbox = document.querySelector('#edges-checkbox');
212
+ checkbox.checked = defaultOn;
213
+ checkbox.checked = defaultOn;
214
+ };
215
+ exports.edgesSpecificLogic = edgesSpecificLogic;
216
+ var customControls = function customControls(map) {
217
+ return [{
218
+ label: _i18n.default.t('map.layers.network_lines'),
219
+ id: 'edges-checkbox',
220
+ inputType: 'checkbox',
221
+ onChange: function onChange(isChecked) {
222
+ return toggleEdgesVisibility(isChecked, map);
223
+ }
224
+ }
225
+
226
+ // {
227
+ // label: 'Another custom feature',
228
+ // id: 'custom-feature-checkbox',
229
+ // inputType: 'checkbox',
230
+ // onChange: (isChecked) => console.log(`Another feature is now ${isChecked ? 'enabled' : 'disabled'}`),
231
+ // },
232
+ ];
233
+ };
234
+
235
+ var appendCustomCheckboxToLeafletsLayerBox = function appendCustomCheckboxToLeafletsLayerBox(leafletsContainer, customContainer) {
236
+ _leaflet.default.DomEvent.on(leafletsContainer, 'mouseover', function () {
237
+ customContainer.style.display = 'block';
238
+ });
239
+ _leaflet.default.DomEvent.on(leafletsContainer, 'mouseout', function () {
240
+ customContainer.style.display = 'none';
241
+ });
242
+ };
243
+ var createCustomControl = function createCustomControl(control, container) {
244
+ var controlContainer = document.createElement('div');
245
+ controlContainer.className = 'leaflet-control-layers-overlays';
246
+ controlContainer.innerHTML = "\n <label>\n <input type=\"".concat(control.inputType, "\" id=\"").concat(control.id, "\" /> ").concat(control.label, "\n </label>\n ");
247
+ controlContainer.querySelector("#".concat(control.id)).addEventListener('change', function (e) {
248
+ var isChecked = e.target.checked;
249
+ control.onChange(isChecked);
250
+ });
251
+ controlContainer.style.display = 'none';
252
+ container === null || container === void 0 ? void 0 : container.appendChild(controlContainer);
253
+ appendCustomCheckboxToLeafletsLayerBox(container, controlContainer);
254
+ };
255
+ var customFunctionalityForMapLayers = function customFunctionalityForMapLayers(map, mapTypes) {
256
+ var defaultOn = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
257
+ var controller = _leaflet.default.control.layers(mapTypes, {}, {
258
+ position: 'bottomright'
259
+ }).addTo(map);
260
+ var container = controller.getContainer();
261
+ customControls(map).forEach(function (control) {
262
+ createCustomControl(control, container);
263
+ edgesSpecificLogic(defaultOn, map);
264
+ });
265
+ };
266
+ exports.customFunctionalityForMapLayers = customFunctionalityForMapLayers;
267
+ var initializeMap = function initializeMap(mapZoomLevel, mapBoxStyle, mapBoxSatelliteStyle, mapRef, dispatch, isValidArea, areaToCenterBy, setMapZoomLevel, forWWTPDashboard, showEdgesByDefault) {
201
268
  // @ts-ignore
202
269
  mapRef.current = new _leaflet.default.Map('map', {
203
270
  center: [0, 0],
@@ -210,9 +277,7 @@ var initializeMap = function initializeMap(mapZoomLevel, mapBoxStyle, mapBoxSate
210
277
  mapRef.current.whenReady(function () {
211
278
  var map = mapRef.current;
212
279
  var mapTypes = baseMaps(mapBoxStyle, mapBoxSatelliteStyle);
213
- _leaflet.default.control.layers(mapTypes, {}, {
214
- position: 'bottomright'
215
- }).addTo(map);
280
+ customFunctionalityForMapLayers(map, mapTypes, showEdgesByDefault);
216
281
 
217
282
  // The name of the layer changes between languages so there was a need to get to the first layer
218
283
  Object.values(mapTypes)[0].addTo(map);
@@ -268,4 +333,4 @@ var zoomLevels = {
268
333
  18: 'Small'
269
334
  };
270
335
  exports.zoomLevels = zoomLevels;
271
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_leaflet","_interopRequireDefault","require","_actions","_i18n","_WWTPDashboardSlice","areaFocusLogic","mapRef","isValidArea","areaToCenterBy","mapInstance","current","fitBounds","padding","group","property","_layers","kando_object","push","Object","keys","L","featureGroup","getBounds","length","exports","area","shouldLoadMapObjects","global_data","points","edges","map","undefined","shoudLoadDependentMapObjects","areas","global","findSpecificLayersFromMap","layersToFind","currentLayer","includes","kando_point_type","eventsCounterIcons","layer","zoomLevel","icon","options","iconSize","eventsCountIcon","iconAnchor","setIcon","setOpacity","multipleLayeredIcons","isAFewLayerIcon","kando_few_layer_icon","miniIcon","present","kando_secondary","kando_third","secondary","third","kando_index_object","bubbleIconOptions","oneLayerIconOptions","middleIconOptions","topIconOptions","iconZoomControl","layers","_zoom","mapStyle","mapBoxStyle","tileLayer","concat","attribution","maxZoom","minZoom","id","tileSize","zoomOffset","updateWhenZooming","updateWhenIdle","baseMaps","mapBoxSatelliteStyle","_ref","defaultMap","i18n","t","satellite","_defineProperty2","default","initializeMap","mapZoomLevel","dispatch","setMapZoomLevel","forWWTPDashboard","Map","center","zoomSnap","zoom","attributionControl","preferCanvas","setMap","whenReady","mapTypes","control","position","addTo","values","setTimeout","invalidateSize","err","console","error","storeMap","sideNavExpanded","on","event","originalEvent","key","closePopup","document","body","focus","e","getZoom","zoomLevels"],"sources":["../../../src/Widgets/Map/MapUtils.ts"],"sourcesContent":["import L, { PointTuple } from 'leaflet';\nimport { sideNavExpanded, storeMap } from '../../store/global/actions';\nimport i18n from 'src/utilities/i18n';\nimport { setMap } from '../../store/WWTPDashboard/WWTPDashboardSlice';\n\nexport const areaFocusLogic = (mapRef, isValidArea, areaToCenterBy) => {\n  let mapInstance: any = mapRef.current;\n  if (isValidArea(areaToCenterBy)) {\n    mapInstance.fitBounds(areaToCenterBy, { padding: [0, 0] });\n  } else {\n    const group: any[] = [];\n\n    for (const property in mapInstance._layers) {\n      if (\n        mapInstance._layers[property].kando_object === 'Area' ||\n        mapInstance._layers[property].kando_object === 'Point'\n      ) {\n        group.push(mapInstance._layers[property]);\n      }\n    }\n\n    if (Object.keys(L.featureGroup(group).getBounds()).length !== 0) {\n      mapInstance.fitBounds(L.featureGroup(group).getBounds(), {\n        padding: [100, 100],\n      });\n    }\n  }\n  // mapInstance.invalidateSize(true);\n};\n\nexport const isValidArea = (area) => {\n  return area && area.length > 0 && Object.keys(area[0]).length > 0;\n};\n\nexport const shouldLoadMapObjects = (global_data, mapRef, points, edges) => {\n  return (\n    global_data.map !== undefined &&\n    mapRef.current !== null &&\n    edges !== undefined &&\n    points !== undefined\n  );\n};\n\nexport const shoudLoadDependentMapObjects = (\n  edges,\n  areas,\n  global,\n  mapRef,\n  points,\n) => {\n  return (\n    global.map !== undefined &&\n    mapRef.current !== null &&\n    // edges.length !== 0 &&\n    // areas.length !== 0 &&\n    points.length !== 0\n  );\n};\n\nexport const findSpecificLayersFromMap = (\n  layersToFind: string[],\n  currentLayer,\n) => {\n  return (\n    layersToFind.includes(currentLayer.kando_object) &&\n    currentLayer.kando_point_type !== 'Manhole'\n  );\n};\n\nexport const eventsCounterIcons = (layer, zoomLevel) => {\n  let icon = layer.options.icon;\n  icon.options.iconSize = eventsCountIcon(zoomLevel).iconSize;\n  icon.options.iconAnchor = eventsCountIcon(zoomLevel).iconAnchor;\n  layer.setIcon(icon);\n  layer.setOpacity(1);\n};\n\nexport const multipleLayeredIcons = (layer, zoomLevel) => {\n  let icon = layer.options.icon;\n  let isAFewLayerIcon = layer.kando_few_layer_icon;\n  let miniIcon = {\n    present: layer.kando_secondary || layer.kando_third,\n    secondary: layer.kando_secondary,\n    third: layer.kando_third,\n  };\n\n  if (layer.kando_index_object === 0) {\n    if (isAFewLayerIcon) {\n      icon.options.iconSize = bubbleIconOptions(zoomLevel, miniIcon).iconSize;\n      icon.options.iconAnchor = bubbleIconOptions(\n        zoomLevel,\n        miniIcon,\n      ).iconAnchor;\n    } else {\n      icon.options.iconSize = oneLayerIconOptions(zoomLevel).iconSize;\n      icon.options.iconAnchor = oneLayerIconOptions(zoomLevel).iconAnchor;\n    }\n  } else {\n    if (layer.kando_index_object === 1) {\n      icon.options.iconSize = middleIconOptions(zoomLevel, miniIcon).iconSize;\n      icon.options.iconAnchor = middleIconOptions(\n        zoomLevel,\n        miniIcon,\n      ).iconAnchor;\n    } else {\n      icon.options.iconSize = topIconOptions(zoomLevel, miniIcon).iconSize;\n      icon.options.iconAnchor = topIconOptions(zoomLevel, miniIcon).iconAnchor;\n    }\n  }\n\n  layer.setIcon(icon);\n};\n\nconst oneLayerIconOptions = (zoomLevel) => {\n  return {\n    iconSize: [zoomLevel * 3.3, zoomLevel * 3.3] as PointTuple,\n    iconAnchor: [zoomLevel * 1.7, zoomLevel * 3.7] as PointTuple,\n  };\n};\n\nexport const eventsCountIcon = (zoomLevel) => {\n  return {\n    iconSize: [zoomLevel * 2.5, zoomLevel * 2.5] as PointTuple,\n    iconAnchor: [zoomLevel * 0, zoomLevel * 4] as PointTuple,\n  };\n};\n\nexport const bubbleIconOptions = (zoomLevel, miniIcon) => {\n  if (miniIcon.present) {\n    if (miniIcon.secondary) {\n      return {\n        iconSize: [zoomLevel * 1.98, zoomLevel * 2.3] as PointTuple,\n        iconAnchor: [zoomLevel * 0, zoomLevel * 4] as PointTuple,\n      };\n    } else {\n      return {\n        iconSize: [zoomLevel * 1.98, zoomLevel * 2.3] as PointTuple,\n        iconAnchor: [zoomLevel * 0, zoomLevel * 2] as PointTuple,\n      };\n    }\n  } else {\n    return {\n      iconSize: [zoomLevel * 3.98, zoomLevel * 4.3] as PointTuple,\n      iconAnchor: [zoomLevel * 2, zoomLevel * 4] as PointTuple,\n    };\n  }\n};\n\nexport const middleIconOptions = (zoomLevel, miniIcon) => {\n  if (miniIcon.present) {\n    if (miniIcon.secondary) {\n      return {\n        iconSize: [zoomLevel * 1.1, zoomLevel * 1.1],\n        iconAnchor: [zoomLevel * -0.45, zoomLevel * 3.5],\n      };\n    } else {\n      return {\n        iconSize: [zoomLevel * 1.1, zoomLevel * 1.1],\n        iconAnchor: [zoomLevel * -0.45, zoomLevel * 1.5],\n      };\n    }\n  } else {\n    return {\n      iconSize: [zoomLevel * 2.5, zoomLevel * 2.5],\n      iconAnchor: [zoomLevel * 1.295, zoomLevel * 3.35],\n    };\n  }\n};\n\nexport const topIconOptions = (zoomLevel, miniIcon) => {\n  if (miniIcon.present) {\n    if (miniIcon.secondary) {\n      return {\n        iconSize: [zoomLevel * 0.9, zoomLevel * 1.8],\n        iconAnchor: [zoomLevel * -0.5, zoomLevel * 3.8],\n      };\n    } else {\n      return {\n        iconSize: [zoomLevel * 1.6, zoomLevel * 2.5],\n        iconAnchor: [zoomLevel * -0.2, zoomLevel * 2.1],\n      };\n    }\n  } else {\n    return {\n      iconSize: [zoomLevel * 3.9, zoomLevel * 3.8],\n      iconAnchor: [zoomLevel * 2, zoomLevel * 3.8],\n    };\n  }\n};\n\nexport const iconZoomControl = (map) => {\n  let layers = map._layers;\n  let zoomLevel = map._zoom;\n\n  for (const property in layers) {\n    if (findSpecificLayersFromMap(['IconNumber'], layers[property])) {\n      eventsCounterIcons(layers[property], zoomLevel);\n    }\n\n    if (findSpecificLayersFromMap(['Point', 'Icon'], layers[property])) {\n      multipleLayeredIcons(layers[property], zoomLevel);\n    }\n\n    if (\n      findSpecificLayersFromMap(['Sampling', 'Observation'], layers[property])\n    ) {\n      multipleLayeredIcons(layers[property], zoomLevel);\n    }\n  }\n};\n\nconst mapStyle = (mapBoxStyle) => {\n  return L.tileLayer(\n    `https://api.mapbox.com/styles/v1/nadav-kando/${mapBoxStyle}/tiles/256/{z}/{x}/{y}@2x?access_token=pk.eyJ1IjoibmFkYXYta2FuZG8iLCJhIjoiY2pveHprdGRxMHlmdDN4bDg0dzJxOXc4dSJ9.J-2ohq7j4yKNbm4N_-P6qw`,\n    {\n      attribution:\n        'Map data &copy; <a href=\"https://www.openstreetmap.org/\">OpenStreetMap</a> contributors, <a href=\"https://creativecommons.org/licenses/by-sa/2.0/\">CC-BY-SA</a>, Imagery © <a href=\"https://www.mapbox.com/\">Mapbox</a>',\n      maxZoom: 18,\n      minZoom: 2,\n      id: 'mapbox/streets-v11',\n      tileSize: 512,\n      zoomOffset: -1,\n      updateWhenZooming: false,\n      updateWhenIdle: false,\n    },\n  );\n};\nconst baseMaps = (mapBoxStyle, mapBoxSatelliteStyle) => {\n  let defaultMap = i18n.t('map.layers.default');\n  let satellite = i18n.t('map.layers.satellite');\n  return {\n    [defaultMap]: mapStyle(mapBoxStyle),\n    [satellite]: mapStyle(mapBoxSatelliteStyle),\n  };\n};\n\nexport const initializeMap = (\n  mapZoomLevel,\n  mapBoxStyle,\n  mapBoxSatelliteStyle,\n  mapRef,\n  dispatch,\n  isValidArea,\n  areaToCenterBy,\n  setMapZoomLevel,\n  forWWTPDashboard,\n) => {\n  // @ts-ignore\n  mapRef.current = new L.Map('map', {\n    center: [0, 0],\n    zoomSnap: 1,\n    zoom: mapZoomLevel,\n    attributionControl: false,\n    preferCanvas: false,\n  });\n\n  if (forWWTPDashboard) dispatch(setMap(mapRef.current));\n\n  mapRef.current.whenReady(() => {\n    let map = mapRef.current;\n    const mapTypes = baseMaps(mapBoxStyle, mapBoxSatelliteStyle);\n\n    L.control.layers(mapTypes, {}, { position: 'bottomright' }).addTo(map);\n\n    // The name of the layer changes between languages so there was a need to get to the first layer\n    Object.values(mapTypes)[0].addTo(map);\n\n    setTimeout(() => {\n      if (!mapRef.current) {\n        return;\n      }\n\n      try {\n        mapRef.current.invalidateSize(true);\n      } catch (err) {\n        console.error('err', err);\n      }\n\n      dispatch(storeMap(mapRef.current));\n      dispatch(sideNavExpanded(true));\n\n      map.on('keydown', (event) => {\n        if (event.originalEvent.key === 'Escape') {\n          map.closePopup();\n          document.body.focus();\n        }\n      });\n    }, 0);\n    if (mapRef.current && isValidArea(areaToCenterBy)) {\n      mapRef.current.fitBounds(areaToCenterBy);\n    }\n  });\n\n  mapRef.current.on('zoomend', function (e) {\n    if (!mapRef.current) {\n      return;\n    }\n    let zoom = mapRef.current.getZoom();\n    setMapZoomLevel(zoom);\n  });\n};\n\nexport const zoomLevels = {\n  1: 'XLarge',\n  2: 'XLarge',\n  3: 'XLarge',\n  4: 'XLarge',\n  5: 'XLarge',\n  6: 'XLarge',\n  7: 'Large',\n  8: 'Large',\n  9: 'Large',\n  10: 'Large',\n  11: 'MLarge',\n  12: 'MLarge',\n  13: 'MLarge',\n  14: 'MLarge',\n  15: 'Medium',\n  16: 'Medium',\n  17: 'Small',\n  18: 'Small',\n};\n"],"mappings":";;;;;;;;AAAA,IAAAA,QAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,QAAA,GAAAD,OAAA;AACA,IAAAE,KAAA,GAAAH,sBAAA,CAAAC,OAAA;AACA,IAAAG,mBAAA,GAAAH,OAAA;AAEO,IAAMI,cAAc,GAAG,SAAjBA,cAAcA,CAAIC,MAAM,EAAEC,WAAW,EAAEC,cAAc,EAAK;EACrE,IAAIC,WAAgB,GAAGH,MAAM,CAACI,OAAO;EACrC,IAAIH,WAAW,CAACC,cAAc,CAAC,EAAE;IAC/BC,WAAW,CAACE,SAAS,CAACH,cAAc,EAAE;MAAEI,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC;IAAE,CAAC,CAAC;EAC5D,CAAC,MAAM;IACL,IAAMC,KAAY,GAAG,EAAE;IAEvB,KAAK,IAAMC,QAAQ,IAAIL,WAAW,CAACM,OAAO,EAAE;MAC1C,IACEN,WAAW,CAACM,OAAO,CAACD,QAAQ,CAAC,CAACE,YAAY,KAAK,MAAM,IACrDP,WAAW,CAACM,OAAO,CAACD,QAAQ,CAAC,CAACE,YAAY,KAAK,OAAO,EACtD;QACAH,KAAK,CAACI,IAAI,CAACR,WAAW,CAACM,OAAO,CAACD,QAAQ,CAAC,CAAC;MAC3C;IACF;IAEA,IAAII,MAAM,CAACC,IAAI,CAACC,gBAAC,CAACC,YAAY,CAACR,KAAK,CAAC,CAACS,SAAS,CAAC,CAAC,CAAC,CAACC,MAAM,KAAK,CAAC,EAAE;MAC/Dd,WAAW,CAACE,SAAS,CAACS,gBAAC,CAACC,YAAY,CAACR,KAAK,CAAC,CAACS,SAAS,CAAC,CAAC,EAAE;QACvDV,OAAO,EAAE,CAAC,GAAG,EAAE,GAAG;MACpB,CAAC,CAAC;IACJ;EACF;EACA;AACF,CAAC;AAACY,OAAA,CAAAnB,cAAA,GAAAA,cAAA;AAEK,IAAME,WAAW,GAAG,SAAdA,WAAWA,CAAIkB,IAAI,EAAK;EACnC,OAAOA,IAAI,IAAIA,IAAI,CAACF,MAAM,GAAG,CAAC,IAAIL,MAAM,CAACC,IAAI,CAACM,IAAI,CAAC,CAAC,CAAC,CAAC,CAACF,MAAM,GAAG,CAAC;AACnE,CAAC;AAACC,OAAA,CAAAjB,WAAA,GAAAA,WAAA;AAEK,IAAMmB,oBAAoB,GAAG,SAAvBA,oBAAoBA,CAAIC,WAAW,EAAErB,MAAM,EAAEsB,MAAM,EAAEC,KAAK,EAAK;EAC1E,OACEF,WAAW,CAACG,GAAG,KAAKC,SAAS,IAC7BzB,MAAM,CAACI,OAAO,KAAK,IAAI,IACvBmB,KAAK,KAAKE,SAAS,IACnBH,MAAM,KAAKG,SAAS;AAExB,CAAC;AAACP,OAAA,CAAAE,oBAAA,GAAAA,oBAAA;AAEK,IAAMM,4BAA4B,GAAG,SAA/BA,4BAA4BA,CACvCH,KAAK,EACLI,KAAK,EACLC,MAAM,EACN5B,MAAM,EACNsB,MAAM,EACH;EACH,OACEM,MAAM,CAACJ,GAAG,KAAKC,SAAS,IACxBzB,MAAM,CAACI,OAAO,KAAK,IAAI;EACvB;EACA;EACAkB,MAAM,CAACL,MAAM,KAAK,CAAC;AAEvB,CAAC;AAACC,OAAA,CAAAQ,4BAAA,GAAAA,4BAAA;AAEK,IAAMG,yBAAyB,GAAG,SAA5BA,yBAAyBA,CACpCC,YAAsB,EACtBC,YAAY,EACT;EACH,OACED,YAAY,CAACE,QAAQ,CAACD,YAAY,CAACrB,YAAY,CAAC,IAChDqB,YAAY,CAACE,gBAAgB,KAAK,SAAS;AAE/C,CAAC;AAACf,OAAA,CAAAW,yBAAA,GAAAA,yBAAA;AAEK,IAAMK,kBAAkB,GAAG,SAArBA,kBAAkBA,CAAIC,KAAK,EAAEC,SAAS,EAAK;EACtD,IAAIC,IAAI,GAAGF,KAAK,CAACG,OAAO,CAACD,IAAI;EAC7BA,IAAI,CAACC,OAAO,CAACC,QAAQ,GAAGC,eAAe,CAACJ,SAAS,CAAC,CAACG,QAAQ;EAC3DF,IAAI,CAACC,OAAO,CAACG,UAAU,GAAGD,eAAe,CAACJ,SAAS,CAAC,CAACK,UAAU;EAC/DN,KAAK,CAACO,OAAO,CAACL,IAAI,CAAC;EACnBF,KAAK,CAACQ,UAAU,CAAC,CAAC,CAAC;AACrB,CAAC;AAACzB,OAAA,CAAAgB,kBAAA,GAAAA,kBAAA;AAEK,IAAMU,oBAAoB,GAAG,SAAvBA,oBAAoBA,CAAIT,KAAK,EAAEC,SAAS,EAAK;EACxD,IAAIC,IAAI,GAAGF,KAAK,CAACG,OAAO,CAACD,IAAI;EAC7B,IAAIQ,eAAe,GAAGV,KAAK,CAACW,oBAAoB;EAChD,IAAIC,QAAQ,GAAG;IACbC,OAAO,EAAEb,KAAK,CAACc,eAAe,IAAId,KAAK,CAACe,WAAW;IACnDC,SAAS,EAAEhB,KAAK,CAACc,eAAe;IAChCG,KAAK,EAAEjB,KAAK,CAACe;EACf,CAAC;EAED,IAAIf,KAAK,CAACkB,kBAAkB,KAAK,CAAC,EAAE;IAClC,IAAIR,eAAe,EAAE;MACnBR,IAAI,CAACC,OAAO,CAACC,QAAQ,GAAGe,iBAAiB,CAAClB,SAAS,EAAEW,QAAQ,CAAC,CAACR,QAAQ;MACvEF,IAAI,CAACC,OAAO,CAACG,UAAU,GAAGa,iBAAiB,CACzClB,SAAS,EACTW,QACF,CAAC,CAACN,UAAU;IACd,CAAC,MAAM;MACLJ,IAAI,CAACC,OAAO,CAACC,QAAQ,GAAGgB,mBAAmB,CAACnB,SAAS,CAAC,CAACG,QAAQ;MAC/DF,IAAI,CAACC,OAAO,CAACG,UAAU,GAAGc,mBAAmB,CAACnB,SAAS,CAAC,CAACK,UAAU;IACrE;EACF,CAAC,MAAM;IACL,IAAIN,KAAK,CAACkB,kBAAkB,KAAK,CAAC,EAAE;MAClChB,IAAI,CAACC,OAAO,CAACC,QAAQ,GAAGiB,iBAAiB,CAACpB,SAAS,EAAEW,QAAQ,CAAC,CAACR,QAAQ;MACvEF,IAAI,CAACC,OAAO,CAACG,UAAU,GAAGe,iBAAiB,CACzCpB,SAAS,EACTW,QACF,CAAC,CAACN,UAAU;IACd,CAAC,MAAM;MACLJ,IAAI,CAACC,OAAO,CAACC,QAAQ,GAAGkB,cAAc,CAACrB,SAAS,EAAEW,QAAQ,CAAC,CAACR,QAAQ;MACpEF,IAAI,CAACC,OAAO,CAACG,UAAU,GAAGgB,cAAc,CAACrB,SAAS,EAAEW,QAAQ,CAAC,CAACN,UAAU;IAC1E;EACF;EAEAN,KAAK,CAACO,OAAO,CAACL,IAAI,CAAC;AACrB,CAAC;AAACnB,OAAA,CAAA0B,oBAAA,GAAAA,oBAAA;AAEF,IAAMW,mBAAmB,GAAG,SAAtBA,mBAAmBA,CAAInB,SAAS,EAAK;EACzC,OAAO;IACLG,QAAQ,EAAE,CAACH,SAAS,GAAG,GAAG,EAAEA,SAAS,GAAG,GAAG,CAAe;IAC1DK,UAAU,EAAE,CAACL,SAAS,GAAG,GAAG,EAAEA,SAAS,GAAG,GAAG;EAC/C,CAAC;AACH,CAAC;AAEM,IAAMI,eAAe,GAAG,SAAlBA,eAAeA,CAAIJ,SAAS,EAAK;EAC5C,OAAO;IACLG,QAAQ,EAAE,CAACH,SAAS,GAAG,GAAG,EAAEA,SAAS,GAAG,GAAG,CAAe;IAC1DK,UAAU,EAAE,CAACL,SAAS,GAAG,CAAC,EAAEA,SAAS,GAAG,CAAC;EAC3C,CAAC;AACH,CAAC;AAAClB,OAAA,CAAAsB,eAAA,GAAAA,eAAA;AAEK,IAAMc,iBAAiB,GAAG,SAApBA,iBAAiBA,CAAIlB,SAAS,EAAEW,QAAQ,EAAK;EACxD,IAAIA,QAAQ,CAACC,OAAO,EAAE;IACpB,IAAID,QAAQ,CAACI,SAAS,EAAE;MACtB,OAAO;QACLZ,QAAQ,EAAE,CAACH,SAAS,GAAG,IAAI,EAAEA,SAAS,GAAG,GAAG,CAAe;QAC3DK,UAAU,EAAE,CAACL,SAAS,GAAG,CAAC,EAAEA,SAAS,GAAG,CAAC;MAC3C,CAAC;IACH,CAAC,MAAM;MACL,OAAO;QACLG,QAAQ,EAAE,CAACH,SAAS,GAAG,IAAI,EAAEA,SAAS,GAAG,GAAG,CAAe;QAC3DK,UAAU,EAAE,CAACL,SAAS,GAAG,CAAC,EAAEA,SAAS,GAAG,CAAC;MAC3C,CAAC;IACH;EACF,CAAC,MAAM;IACL,OAAO;MACLG,QAAQ,EAAE,CAACH,SAAS,GAAG,IAAI,EAAEA,SAAS,GAAG,GAAG,CAAe;MAC3DK,UAAU,EAAE,CAACL,SAAS,GAAG,CAAC,EAAEA,SAAS,GAAG,CAAC;IAC3C,CAAC;EACH;AACF,CAAC;AAAClB,OAAA,CAAAoC,iBAAA,GAAAA,iBAAA;AAEK,IAAME,iBAAiB,GAAG,SAApBA,iBAAiBA,CAAIpB,SAAS,EAAEW,QAAQ,EAAK;EACxD,IAAIA,QAAQ,CAACC,OAAO,EAAE;IACpB,IAAID,QAAQ,CAACI,SAAS,EAAE;MACtB,OAAO;QACLZ,QAAQ,EAAE,CAACH,SAAS,GAAG,GAAG,EAAEA,SAAS,GAAG,GAAG,CAAC;QAC5CK,UAAU,EAAE,CAACL,SAAS,GAAG,CAAC,IAAI,EAAEA,SAAS,GAAG,GAAG;MACjD,CAAC;IACH,CAAC,MAAM;MACL,OAAO;QACLG,QAAQ,EAAE,CAACH,SAAS,GAAG,GAAG,EAAEA,SAAS,GAAG,GAAG,CAAC;QAC5CK,UAAU,EAAE,CAACL,SAAS,GAAG,CAAC,IAAI,EAAEA,SAAS,GAAG,GAAG;MACjD,CAAC;IACH;EACF,CAAC,MAAM;IACL,OAAO;MACLG,QAAQ,EAAE,CAACH,SAAS,GAAG,GAAG,EAAEA,SAAS,GAAG,GAAG,CAAC;MAC5CK,UAAU,EAAE,CAACL,SAAS,GAAG,KAAK,EAAEA,SAAS,GAAG,IAAI;IAClD,CAAC;EACH;AACF,CAAC;AAAClB,OAAA,CAAAsC,iBAAA,GAAAA,iBAAA;AAEK,IAAMC,cAAc,GAAG,SAAjBA,cAAcA,CAAIrB,SAAS,EAAEW,QAAQ,EAAK;EACrD,IAAIA,QAAQ,CAACC,OAAO,EAAE;IACpB,IAAID,QAAQ,CAACI,SAAS,EAAE;MACtB,OAAO;QACLZ,QAAQ,EAAE,CAACH,SAAS,GAAG,GAAG,EAAEA,SAAS,GAAG,GAAG,CAAC;QAC5CK,UAAU,EAAE,CAACL,SAAS,GAAG,CAAC,GAAG,EAAEA,SAAS,GAAG,GAAG;MAChD,CAAC;IACH,CAAC,MAAM;MACL,OAAO;QACLG,QAAQ,EAAE,CAACH,SAAS,GAAG,GAAG,EAAEA,SAAS,GAAG,GAAG,CAAC;QAC5CK,UAAU,EAAE,CAACL,SAAS,GAAG,CAAC,GAAG,EAAEA,SAAS,GAAG,GAAG;MAChD,CAAC;IACH;EACF,CAAC,MAAM;IACL,OAAO;MACLG,QAAQ,EAAE,CAACH,SAAS,GAAG,GAAG,EAAEA,SAAS,GAAG,GAAG,CAAC;MAC5CK,UAAU,EAAE,CAACL,SAAS,GAAG,CAAC,EAAEA,SAAS,GAAG,GAAG;IAC7C,CAAC;EACH;AACF,CAAC;AAAClB,OAAA,CAAAuC,cAAA,GAAAA,cAAA;AAEK,IAAMC,eAAe,GAAG,SAAlBA,eAAeA,CAAIlC,GAAG,EAAK;EACtC,IAAImC,MAAM,GAAGnC,GAAG,CAACf,OAAO;EACxB,IAAI2B,SAAS,GAAGZ,GAAG,CAACoC,KAAK;EAEzB,KAAK,IAAMpD,QAAQ,IAAImD,MAAM,EAAE;IAC7B,IAAI9B,yBAAyB,CAAC,CAAC,YAAY,CAAC,EAAE8B,MAAM,CAACnD,QAAQ,CAAC,CAAC,EAAE;MAC/D0B,kBAAkB,CAACyB,MAAM,CAACnD,QAAQ,CAAC,EAAE4B,SAAS,CAAC;IACjD;IAEA,IAAIP,yBAAyB,CAAC,CAAC,OAAO,EAAE,MAAM,CAAC,EAAE8B,MAAM,CAACnD,QAAQ,CAAC,CAAC,EAAE;MAClEoC,oBAAoB,CAACe,MAAM,CAACnD,QAAQ,CAAC,EAAE4B,SAAS,CAAC;IACnD;IAEA,IACEP,yBAAyB,CAAC,CAAC,UAAU,EAAE,aAAa,CAAC,EAAE8B,MAAM,CAACnD,QAAQ,CAAC,CAAC,EACxE;MACAoC,oBAAoB,CAACe,MAAM,CAACnD,QAAQ,CAAC,EAAE4B,SAAS,CAAC;IACnD;EACF;AACF,CAAC;AAAClB,OAAA,CAAAwC,eAAA,GAAAA,eAAA;AAEF,IAAMG,QAAQ,GAAG,SAAXA,QAAQA,CAAIC,WAAW,EAAK;EAChC,OAAOhD,gBAAC,CAACiD,SAAS,iDAAAC,MAAA,CACgCF,WAAW,4IAC3D;IACEG,WAAW,EACT,yNAAyN;IAC3NC,OAAO,EAAE,EAAE;IACXC,OAAO,EAAE,CAAC;IACVC,EAAE,EAAE,oBAAoB;IACxBC,QAAQ,EAAE,GAAG;IACbC,UAAU,EAAE,CAAC,CAAC;IACdC,iBAAiB,EAAE,KAAK;IACxBC,cAAc,EAAE;EAClB,CACF,CAAC;AACH,CAAC;AACD,IAAMC,QAAQ,GAAG,SAAXA,QAAQA,CAAIX,WAAW,EAAEY,oBAAoB,EAAK;EAAA,IAAAC,IAAA;EACtD,IAAIC,UAAU,GAAGC,aAAI,CAACC,CAAC,CAAC,oBAAoB,CAAC;EAC7C,IAAIC,SAAS,GAAGF,aAAI,CAACC,CAAC,CAAC,sBAAsB,CAAC;EAC9C,OAAAH,IAAA,WAAAK,gBAAA,CAAAC,OAAA,EAAAN,IAAA,EACGC,UAAU,EAAGf,QAAQ,CAACC,WAAW,CAAC,OAAAkB,gBAAA,CAAAC,OAAA,EAAAN,IAAA,EAClCI,SAAS,EAAGlB,QAAQ,CAACa,oBAAoB,CAAC,GAAAC,IAAA;AAE/C,CAAC;AAEM,IAAMO,aAAa,GAAG,SAAhBA,aAAaA,CACxBC,YAAY,EACZrB,WAAW,EACXY,oBAAoB,EACpB1E,MAAM,EACNoF,QAAQ,EACRnF,WAAW,EACXC,cAAc,EACdmF,eAAe,EACfC,gBAAgB,EACb;EACH;EACAtF,MAAM,CAACI,OAAO,GAAG,IAAIU,gBAAC,CAACyE,GAAG,CAAC,KAAK,EAAE;IAChCC,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;IACdC,QAAQ,EAAE,CAAC;IACXC,IAAI,EAAEP,YAAY;IAClBQ,kBAAkB,EAAE,KAAK;IACzBC,YAAY,EAAE;EAChB,CAAC,CAAC;EAEF,IAAIN,gBAAgB,EAAEF,QAAQ,CAAC,IAAAS,0BAAM,EAAC7F,MAAM,CAACI,OAAO,CAAC,CAAC;EAEtDJ,MAAM,CAACI,OAAO,CAAC0F,SAAS,CAAC,YAAM;IAC7B,IAAItE,GAAG,GAAGxB,MAAM,CAACI,OAAO;IACxB,IAAM2F,QAAQ,GAAGtB,QAAQ,CAACX,WAAW,EAAEY,oBAAoB,CAAC;IAE5D5D,gBAAC,CAACkF,OAAO,CAACrC,MAAM,CAACoC,QAAQ,EAAE,CAAC,CAAC,EAAE;MAAEE,QAAQ,EAAE;IAAc,CAAC,CAAC,CAACC,KAAK,CAAC1E,GAAG,CAAC;;IAEtE;IACAZ,MAAM,CAACuF,MAAM,CAACJ,QAAQ,CAAC,CAAC,CAAC,CAAC,CAACG,KAAK,CAAC1E,GAAG,CAAC;IAErC4E,UAAU,CAAC,YAAM;MACf,IAAI,CAACpG,MAAM,CAACI,OAAO,EAAE;QACnB;MACF;MAEA,IAAI;QACFJ,MAAM,CAACI,OAAO,CAACiG,cAAc,CAAC,IAAI,CAAC;MACrC,CAAC,CAAC,OAAOC,GAAG,EAAE;QACZC,OAAO,CAACC,KAAK,CAAC,KAAK,EAAEF,GAAG,CAAC;MAC3B;MAEAlB,QAAQ,CAAC,IAAAqB,iBAAQ,EAACzG,MAAM,CAACI,OAAO,CAAC,CAAC;MAClCgF,QAAQ,CAAC,IAAAsB,wBAAe,EAAC,IAAI,CAAC,CAAC;MAE/BlF,GAAG,CAACmF,EAAE,CAAC,SAAS,EAAE,UAACC,KAAK,EAAK;QAC3B,IAAIA,KAAK,CAACC,aAAa,CAACC,GAAG,KAAK,QAAQ,EAAE;UACxCtF,GAAG,CAACuF,UAAU,CAAC,CAAC;UAChBC,QAAQ,CAACC,IAAI,CAACC,KAAK,CAAC,CAAC;QACvB;MACF,CAAC,CAAC;IACJ,CAAC,EAAE,CAAC,CAAC;IACL,IAAIlH,MAAM,CAACI,OAAO,IAAIH,WAAW,CAACC,cAAc,CAAC,EAAE;MACjDF,MAAM,CAACI,OAAO,CAACC,SAAS,CAACH,cAAc,CAAC;IAC1C;EACF,CAAC,CAAC;EAEFF,MAAM,CAACI,OAAO,CAACuG,EAAE,CAAC,SAAS,EAAE,UAAUQ,CAAC,EAAE;IACxC,IAAI,CAACnH,MAAM,CAACI,OAAO,EAAE;MACnB;IACF;IACA,IAAIsF,IAAI,GAAG1F,MAAM,CAACI,OAAO,CAACgH,OAAO,CAAC,CAAC;IACnC/B,eAAe,CAACK,IAAI,CAAC;EACvB,CAAC,CAAC;AACJ,CAAC;AAACxE,OAAA,CAAAgE,aAAA,GAAAA,aAAA;AAEK,IAAMmC,UAAU,GAAG;EACxB,CAAC,EAAE,QAAQ;EACX,CAAC,EAAE,QAAQ;EACX,CAAC,EAAE,QAAQ;EACX,CAAC,EAAE,QAAQ;EACX,CAAC,EAAE,QAAQ;EACX,CAAC,EAAE,QAAQ;EACX,CAAC,EAAE,OAAO;EACV,CAAC,EAAE,OAAO;EACV,CAAC,EAAE,OAAO;EACV,EAAE,EAAE,OAAO;EACX,EAAE,EAAE,QAAQ;EACZ,EAAE,EAAE,QAAQ;EACZ,EAAE,EAAE,QAAQ;EACZ,EAAE,EAAE,QAAQ;EACZ,EAAE,EAAE,QAAQ;EACZ,EAAE,EAAE,QAAQ;EACZ,EAAE,EAAE,OAAO;EACX,EAAE,EAAE;AACN,CAAC;AAACnG,OAAA,CAAAmG,UAAA,GAAAA,UAAA"}
336
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_leaflet","_interopRequireDefault","require","_actions","_i18n","_WWTPDashboardSlice","areaFocusLogic","mapRef","isValidArea","areaToCenterBy","mapInstance","current","fitBounds","padding","group","property","_layers","kando_object","push","Object","keys","L","featureGroup","getBounds","length","exports","area","shouldLoadMapObjects","global_data","points","edges","map","undefined","shoudLoadDependentMapObjects","areas","global","findSpecificLayersFromMap","layersToFind","currentLayer","includes","kando_point_type","eventsCounterIcons","layer","zoomLevel","icon","options","iconSize","eventsCountIcon","iconAnchor","setIcon","setOpacity","multipleLayeredIcons","isAFewLayerIcon","kando_few_layer_icon","miniIcon","present","kando_secondary","kando_third","secondary","third","kando_index_object","bubbleIconOptions","oneLayerIconOptions","middleIconOptions","topIconOptions","iconZoomControl","layers","_zoom","mapStyle","mapBoxStyle","tileLayer","concat","attribution","maxZoom","minZoom","id","tileSize","zoomOffset","updateWhenZooming","updateWhenIdle","baseMaps","mapBoxSatelliteStyle","_ref","defaultMap","i18n","t","satellite","_defineProperty2","default","toggleEdgesVisibility","visible","eachLayer","Polyline","Symbol","arrowHead","setStyle","opacity","edgesSpecificLogic","defaultOn","checkbox","document","querySelector","checked","customControls","label","inputType","onChange","isChecked","appendCustomCheckboxToLeafletsLayerBox","leafletsContainer","customContainer","DomEvent","on","style","display","createCustomControl","control","container","controlContainer","createElement","className","innerHTML","addEventListener","e","target","appendChild","customFunctionalityForMapLayers","mapTypes","arguments","controller","position","addTo","getContainer","forEach","initializeMap","mapZoomLevel","dispatch","setMapZoomLevel","forWWTPDashboard","showEdgesByDefault","Map","center","zoomSnap","zoom","attributionControl","preferCanvas","setMap","whenReady","values","setTimeout","invalidateSize","err","console","error","storeMap","sideNavExpanded","event","originalEvent","key","closePopup","body","focus","getZoom","zoomLevels"],"sources":["../../../src/Widgets/Map/MapUtils.ts"],"sourcesContent":["import L, { PointTuple } from 'leaflet';\nimport { sideNavExpanded, storeMap } from '../../store/global/actions';\nimport i18n from 'src/utilities/i18n';\nimport { setMap } from '../../store/WWTPDashboard/WWTPDashboardSlice';\n\nexport const areaFocusLogic = (mapRef, isValidArea, areaToCenterBy) => {\n  let mapInstance: any = mapRef.current;\n  if (isValidArea(areaToCenterBy)) {\n    mapInstance.fitBounds(areaToCenterBy, { padding: [0, 0] });\n  } else {\n    const group: any[] = [];\n\n    for (const property in mapInstance._layers) {\n      if (\n        mapInstance._layers[property].kando_object === 'Area' ||\n        mapInstance._layers[property].kando_object === 'Point'\n      ) {\n        group.push(mapInstance._layers[property]);\n      }\n    }\n\n    if (Object.keys(L.featureGroup(group).getBounds()).length !== 0) {\n      mapInstance.fitBounds(L.featureGroup(group).getBounds(), {\n        padding: [100, 100],\n      });\n    }\n  }\n  // mapInstance.invalidateSize(true);\n};\n\nexport const isValidArea = (area) => {\n  return area && area.length > 0 && Object.keys(area[0]).length > 0;\n};\n\nexport const shouldLoadMapObjects = (global_data, mapRef, points, edges) => {\n  return (\n    global_data.map !== undefined &&\n    mapRef.current !== null &&\n    edges !== undefined &&\n    points !== undefined\n  );\n};\n\nexport const shoudLoadDependentMapObjects = (\n  edges,\n  areas,\n  global,\n  mapRef,\n  points,\n) => {\n  return (\n    global.map !== undefined &&\n    mapRef.current !== null &&\n    // edges.length !== 0 &&\n    // areas.length !== 0 &&\n    points.length !== 0\n  );\n};\n\nexport const findSpecificLayersFromMap = (\n  layersToFind: string[],\n  currentLayer,\n) => {\n  return (\n    layersToFind.includes(currentLayer.kando_object) &&\n    currentLayer.kando_point_type !== 'Manhole'\n  );\n};\n\nexport const eventsCounterIcons = (layer, zoomLevel) => {\n  let icon = layer.options.icon;\n  icon.options.iconSize = eventsCountIcon(zoomLevel).iconSize;\n  icon.options.iconAnchor = eventsCountIcon(zoomLevel).iconAnchor;\n  layer.setIcon(icon);\n  layer.setOpacity(1);\n};\n\nexport const multipleLayeredIcons = (layer, zoomLevel) => {\n  let icon = layer.options.icon;\n  let isAFewLayerIcon = layer.kando_few_layer_icon;\n  let miniIcon = {\n    present: layer.kando_secondary || layer.kando_third,\n    secondary: layer.kando_secondary,\n    third: layer.kando_third,\n  };\n\n  if (layer.kando_index_object === 0) {\n    if (isAFewLayerIcon) {\n      icon.options.iconSize = bubbleIconOptions(zoomLevel, miniIcon).iconSize;\n      icon.options.iconAnchor = bubbleIconOptions(\n        zoomLevel,\n        miniIcon,\n      ).iconAnchor;\n    } else {\n      icon.options.iconSize = oneLayerIconOptions(zoomLevel).iconSize;\n      icon.options.iconAnchor = oneLayerIconOptions(zoomLevel).iconAnchor;\n    }\n  } else {\n    if (layer.kando_index_object === 1) {\n      icon.options.iconSize = middleIconOptions(zoomLevel, miniIcon).iconSize;\n      icon.options.iconAnchor = middleIconOptions(\n        zoomLevel,\n        miniIcon,\n      ).iconAnchor;\n    } else {\n      icon.options.iconSize = topIconOptions(zoomLevel, miniIcon).iconSize;\n      icon.options.iconAnchor = topIconOptions(zoomLevel, miniIcon).iconAnchor;\n    }\n  }\n\n  layer.setIcon(icon);\n};\n\nconst oneLayerIconOptions = (zoomLevel) => {\n  return {\n    iconSize: [zoomLevel * 3.3, zoomLevel * 3.3] as PointTuple,\n    iconAnchor: [zoomLevel * 1.7, zoomLevel * 3.7] as PointTuple,\n  };\n};\n\nexport const eventsCountIcon = (zoomLevel) => {\n  return {\n    iconSize: [zoomLevel * 2.5, zoomLevel * 2.5] as PointTuple,\n    iconAnchor: [zoomLevel * 0, zoomLevel * 4] as PointTuple,\n  };\n};\n\nexport const bubbleIconOptions = (zoomLevel, miniIcon) => {\n  if (miniIcon.present) {\n    if (miniIcon.secondary) {\n      return {\n        iconSize: [zoomLevel * 1.98, zoomLevel * 2.3] as PointTuple,\n        iconAnchor: [zoomLevel * 0, zoomLevel * 4] as PointTuple,\n      };\n    } else {\n      return {\n        iconSize: [zoomLevel * 1.98, zoomLevel * 2.3] as PointTuple,\n        iconAnchor: [zoomLevel * 0, zoomLevel * 2] as PointTuple,\n      };\n    }\n  } else {\n    return {\n      iconSize: [zoomLevel * 3.98, zoomLevel * 4.3] as PointTuple,\n      iconAnchor: [zoomLevel * 2, zoomLevel * 4] as PointTuple,\n    };\n  }\n};\n\nexport const middleIconOptions = (zoomLevel, miniIcon) => {\n  if (miniIcon.present) {\n    if (miniIcon.secondary) {\n      return {\n        iconSize: [zoomLevel * 1.1, zoomLevel * 1.1],\n        iconAnchor: [zoomLevel * -0.45, zoomLevel * 3.5],\n      };\n    } else {\n      return {\n        iconSize: [zoomLevel * 1.1, zoomLevel * 1.1],\n        iconAnchor: [zoomLevel * -0.45, zoomLevel * 1.5],\n      };\n    }\n  } else {\n    return {\n      iconSize: [zoomLevel * 2.5, zoomLevel * 2.5],\n      iconAnchor: [zoomLevel * 1.295, zoomLevel * 3.35],\n    };\n  }\n};\n\nexport const topIconOptions = (zoomLevel, miniIcon) => {\n  if (miniIcon.present) {\n    if (miniIcon.secondary) {\n      return {\n        iconSize: [zoomLevel * 0.9, zoomLevel * 1.8],\n        iconAnchor: [zoomLevel * -0.5, zoomLevel * 3.8],\n      };\n    } else {\n      return {\n        iconSize: [zoomLevel * 1.6, zoomLevel * 2.5],\n        iconAnchor: [zoomLevel * -0.2, zoomLevel * 2.1],\n      };\n    }\n  } else {\n    return {\n      iconSize: [zoomLevel * 3.9, zoomLevel * 3.8],\n      iconAnchor: [zoomLevel * 2, zoomLevel * 3.8],\n    };\n  }\n};\n\nexport const iconZoomControl = (map) => {\n  let layers = map._layers;\n  let zoomLevel = map._zoom;\n\n  for (const property in layers) {\n    if (findSpecificLayersFromMap(['IconNumber'], layers[property])) {\n      eventsCounterIcons(layers[property], zoomLevel);\n    }\n\n    if (findSpecificLayersFromMap(['Point', 'Icon'], layers[property])) {\n      multipleLayeredIcons(layers[property], zoomLevel);\n    }\n\n    if (\n      findSpecificLayersFromMap(['Sampling', 'Observation'], layers[property])\n    ) {\n      multipleLayeredIcons(layers[property], zoomLevel);\n    }\n  }\n};\n\nconst mapStyle = (mapBoxStyle) => {\n  return L.tileLayer(\n    `https://api.mapbox.com/styles/v1/nadav-kando/${mapBoxStyle}/tiles/256/{z}/{x}/{y}@2x?access_token=pk.eyJ1IjoibmFkYXYta2FuZG8iLCJhIjoiY2pveHprdGRxMHlmdDN4bDg0dzJxOXc4dSJ9.J-2ohq7j4yKNbm4N_-P6qw`,\n    {\n      attribution:\n        'Map data &copy; <a href=\"https://www.openstreetmap.org/\">OpenStreetMap</a> contributors, <a href=\"https://creativecommons.org/licenses/by-sa/2.0/\">CC-BY-SA</a>, Imagery © <a href=\"https://www.mapbox.com/\">Mapbox</a>',\n      maxZoom: 18,\n      minZoom: 2,\n      id: 'mapbox/streets-v11',\n      tileSize: 512,\n      zoomOffset: -1,\n      updateWhenZooming: false,\n      updateWhenIdle: false,\n    },\n  );\n};\nconst baseMaps = (mapBoxStyle, mapBoxSatelliteStyle) => {\n  let defaultMap = i18n.t('map.layers.default');\n  let satellite = i18n.t('map.layers.satellite');\n  return {\n    [defaultMap]: mapStyle(mapBoxStyle),\n    [satellite]: mapStyle(mapBoxSatelliteStyle),\n  };\n};\n\nexport const toggleEdgesVisibility = (visible, map) => {\n  map.eachLayer((layer) => {\n    if (\n      (layer instanceof L.Polyline && layer.kando_object !== 'Area') ||\n      layer instanceof L.Symbol.arrowHead\n    ) {\n      layer.setStyle({ opacity: visible ? 1 : 0 });\n    }\n  });\n};\n\nexport const edgesSpecificLogic = (defaultOn, map) => {\n  let checkbox = document.querySelector('#edges-checkbox');\n  checkbox.checked = defaultOn;\n  checkbox.checked = defaultOn;\n};\n\nconst customControls = (map) => {\n  return [\n    {\n      label: i18n.t('map.layers.network_lines'),\n      id: 'edges-checkbox',\n      inputType: 'checkbox',\n      onChange: (isChecked) => toggleEdgesVisibility(isChecked, map),\n    },\n\n    // {\n    //   label: 'Another custom feature',\n    //   id: 'custom-feature-checkbox',\n    //   inputType: 'checkbox',\n    //   onChange: (isChecked) => console.log(`Another feature is now ${isChecked ? 'enabled' : 'disabled'}`),\n    // },\n  ];\n};\n\nconst appendCustomCheckboxToLeafletsLayerBox = (\n  leafletsContainer,\n  customContainer,\n) => {\n  L.DomEvent.on(leafletsContainer, 'mouseover', function () {\n    customContainer.style.display = 'block';\n  });\n\n  L.DomEvent.on(leafletsContainer, 'mouseout', function () {\n    customContainer.style.display = 'none';\n  });\n};\n\nconst createCustomControl = (control, container) => {\n  let controlContainer = document.createElement('div');\n  controlContainer.className = 'leaflet-control-layers-overlays';\n  controlContainer.innerHTML = `\n      <label>\n        <input type=\"${control.inputType}\" id=\"${control.id}\" /> ${control.label}\n      </label>\n    `;\n\n  controlContainer\n    .querySelector(`#${control.id}`)\n    .addEventListener('change', function (e) {\n      const isChecked = e.target.checked;\n      control.onChange(isChecked);\n    });\n\n  controlContainer.style.display = 'none';\n  container?.appendChild(controlContainer);\n\n  appendCustomCheckboxToLeafletsLayerBox(container, controlContainer);\n};\n\nexport const customFunctionalityForMapLayers = (\n  map,\n  mapTypes,\n  defaultOn = false,\n) => {\n  let controller = L.control\n    .layers(mapTypes, {}, { position: 'bottomright' })\n    .addTo(map);\n  let container = controller.getContainer();\n\n  customControls(map).forEach((control) => {\n    createCustomControl(control, container);\n    edgesSpecificLogic(defaultOn, map);\n  });\n};\n\nexport const initializeMap = (\n  mapZoomLevel,\n  mapBoxStyle,\n  mapBoxSatelliteStyle,\n  mapRef,\n  dispatch,\n  isValidArea,\n  areaToCenterBy,\n  setMapZoomLevel,\n  forWWTPDashboard,\n  showEdgesByDefault,\n) => {\n  // @ts-ignore\n  mapRef.current = new L.Map('map', {\n    center: [0, 0],\n    zoomSnap: 1,\n    zoom: mapZoomLevel,\n    attributionControl: false,\n    preferCanvas: false,\n  });\n\n  if (forWWTPDashboard) dispatch(setMap(mapRef.current));\n\n  mapRef.current.whenReady(() => {\n    let map = mapRef.current;\n    const mapTypes = baseMaps(mapBoxStyle, mapBoxSatelliteStyle);\n\n    customFunctionalityForMapLayers(map, mapTypes, showEdgesByDefault);\n\n    // The name of the layer changes between languages so there was a need to get to the first layer\n    Object.values(mapTypes)[0].addTo(map);\n\n    setTimeout(() => {\n      if (!mapRef.current) {\n        return;\n      }\n\n      try {\n        mapRef.current.invalidateSize(true);\n      } catch (err) {\n        console.error('err', err);\n      }\n\n      dispatch(storeMap(mapRef.current));\n      dispatch(sideNavExpanded(true));\n\n      map.on('keydown', (event) => {\n        if (event.originalEvent.key === 'Escape') {\n          map.closePopup();\n          document.body.focus();\n        }\n      });\n    }, 0);\n    if (mapRef.current && isValidArea(areaToCenterBy)) {\n      mapRef.current.fitBounds(areaToCenterBy);\n    }\n  });\n\n  mapRef.current.on('zoomend', function (e) {\n    if (!mapRef.current) {\n      return;\n    }\n    let zoom = mapRef.current.getZoom();\n    setMapZoomLevel(zoom);\n  });\n};\n\nexport const zoomLevels = {\n  1: 'XLarge',\n  2: 'XLarge',\n  3: 'XLarge',\n  4: 'XLarge',\n  5: 'XLarge',\n  6: 'XLarge',\n  7: 'Large',\n  8: 'Large',\n  9: 'Large',\n  10: 'Large',\n  11: 'MLarge',\n  12: 'MLarge',\n  13: 'MLarge',\n  14: 'MLarge',\n  15: 'Medium',\n  16: 'Medium',\n  17: 'Small',\n  18: 'Small',\n};\n"],"mappings":"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"}
@@ -44,7 +44,7 @@ var Edge = function Edge(_ref) {
44
44
  if (sourcePoint[0] === undefined || targetPoint[0] === undefined) return;
45
45
  var polylineBack = L.polyline(latlngs, {
46
46
  color: 'rgb(227,227,227)',
47
- weight: 6,
47
+ weight: hideEdges ? 0 : 6,
48
48
  opacity: hideEdges ? 0 : 1
49
49
  }).addTo(map);
50
50
  polylineBack.bindPopup("Edge ID: ".concat(edge.id, ",<br>\n Source point: ").concat(sourcePoint[0].group.name, ",<br>\n Target point: ").concat(targetPoint[0].group.name, ",\n Distance: ").concat(edge.distance));
@@ -52,13 +52,36 @@ var Edge = function Edge(_ref) {
52
52
  polylineBack['kando_object'] = 'Edge';
53
53
  polylineBack.bringToFront();
54
54
  var polylineFront = L.polyline(latlngs, {
55
- color: 'rgb(29,29,29)',
55
+ color: 'rgb(157,157,157)',
56
56
  weight: hideEdges ? 0 : 1,
57
57
  opacity: hideEdges ? 0 : 1
58
58
  }).addTo(map);
59
59
  polylineFront['kando_object_id'] = edge.id;
60
60
  polylineFront['kando_object'] = 'EdgeFront';
61
61
  polylineFront.bringToFront();
62
+ console.warn('L.Symbol', L.Symbol);
63
+ console.warn('L', L);
64
+ // let tailDash = L.polylineDecorator(polylineBack._latlngs, {
65
+ // patterns: [
66
+ // // defines a pattern of 10px-wide dashes, repeated every 20px on the line
67
+ // {
68
+ // offset: 15,
69
+ // repeat: 25,
70
+ // symbol: L.Symbol.arrowHead({
71
+ // pixelSize: 3,
72
+ // polygon: false,
73
+ // pathOptions: {
74
+ // stroke: true,
75
+ // color: 'rgb(148,148,148)',
76
+ // weight: hideEdges ? 0 : 1,
77
+ // opacity: hideEdges ? 0 : 1,
78
+ // },
79
+ // }),
80
+ // },
81
+ // ],
82
+ // }).addTo(map);
83
+ // tailDash['kando_object'] = 'Arrow';
84
+
62
85
  if (specificEvent !== undefined) {
63
86
  dispatch((0, _actions.setHoveredEdgePaths)([polylineBack, polylineFront]));
64
87
  }
@@ -69,4 +92,4 @@ var Edge = function Edge(_ref) {
69
92
  var connector = (0, _reactRedux.connect)(null);
70
93
  var _default = connector(Edge);
71
94
  exports.default = _default;
72
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["require","_react","_interopRequireWildcard","_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","setHoveredEdgePaths","createElement","connector","connect","_default","exports"],"sources":["../../../../src/Widgets/Map/edges/Edge.tsx"],"sourcesContent":["import 'src/utilities/polylinedecorator';\nimport 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: 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(29,29,29)',\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\n      polylineFront.bringToFront();\n      if (specificEvent !== undefined) {\n        dispatch(setHoveredEdgePaths([polylineBack, polylineFront]));\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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"}
95
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["require","_react","_interopRequireWildcard","_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","console","warn","Symbol","setHoveredEdgePaths","createElement","connector","connect","_default","exports"],"sources":["../../../../src/Widgets/Map/edges/Edge.tsx"],"sourcesContent":["import 'src/utilities/polylinedecorator';\nimport 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      console.warn('L.Symbol', L.Symbol);\n      console.warn('L', L);\n      // let tailDash = 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: 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      if (specificEvent !== undefined) {\n        dispatch(setHoveredEdgePaths([polylineBack, polylineFront]));\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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"}
package/lib/i18n/en.json CHANGED
@@ -1261,7 +1261,8 @@
1261
1261
  "statistics": "Statistics",
1262
1262
  "layers": {
1263
1263
  "default": "Map",
1264
- "satellite": "Satellite"
1264
+ "satellite": "Satellite",
1265
+ "network_lines": "Show Network Lines"
1265
1266
  }
1266
1267
  },
1267
1268
  "control_room": {
package/lib/i18n/he.json CHANGED
@@ -2874,7 +2874,8 @@
2874
2874
  "map": {
2875
2875
  "layers": {
2876
2876
  "default": "מפה",
2877
- "satellite": "לווין"
2877
+ "satellite": "לווין",
2878
+ "network_lines": "הצג קווי רשת"
2878
2879
  }
2879
2880
  },
2880
2881
  "events_overview": {
@@ -1,10 +1,10 @@
1
1
  "use strict";
2
2
 
3
- var packageJsonVersion = "1.2.357";
3
+ var packageJsonVersion = "1.2.358-alpha.0";
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));
7
7
  } else {
8
8
  console.error('getVersion.js got bad version from package.json, expected string.');
9
9
  }
10
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJwYWNrYWdlSnNvblZlcnNpb24iLCJjb25zb2xlIiwibG9nIiwiY29uY2F0IiwicHJvY2VzcyIsImVudiIsIk5PREVfRU5WIiwiZXJyb3IiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvbWFjcm9zL2dldFZlcnNpb24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHByZXZhbCBmcm9tICdwcmV2YWwubWFjcm8nO1xuXG5jb25zdCBwYWNrYWdlSnNvblZlcnNpb24gPSBwcmV2YWxgbW9kdWxlLmV4cG9ydHMgPSByZXF1aXJlKCcuLi8uLi9iaW4vZ2V0VmVyc2lvbkZyb21QYWNrYWdlSnNvbi5qcycpYDtcbmlmICh0eXBlb2YgcGFja2FnZUpzb25WZXJzaW9uID09PSAnc3RyaW5nJykge1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc29sZVxuICBjb25zb2xlLmxvZyhcbiAgICBgJWMgS2FuZG8gVUkgJWMgdiR7cGFja2FnZUpzb25WZXJzaW9ufSBgLFxuICAgICdmb250LXNpemU6IDE1cHg7IGJhY2tncm91bmQtY29sb3I6ICNmZmY7IGNvbG9yOiAjZTIwZjUzOycsXG4gICAgJ2ZvbnQtd2VpZ2h0OiBib2xkOyBmb250LXNpemU6IDE1cHg7IGJhY2tncm91bmQtY29sb3I6ICNlMjBmNTM7IGNvbG9yOiAjZmZmOycsXG4gICAgYHdpdGggTk9ERV9FTlY9JHtwcm9jZXNzLmVudi5OT0RFX0VOVn1gLFxuICApO1xufSBlbHNlIHtcbiAgY29uc29sZS5lcnJvcihcbiAgICAnZ2V0VmVyc2lvbi5qcyBnb3QgYmFkIHZlcnNpb24gZnJvbSBwYWNrYWdlLmpzb24sIGV4cGVjdGVkIHN0cmluZy4nLFxuICApO1xufVxuIl0sIm1hcHBpbmdzIjoiOztBQUVBLElBQU1BLGtCQUFrQixZQUE2RTtBQUNyRyxJQUFJLE9BQU9BLGtCQUFrQixLQUFLLFFBQVEsRUFBRTtFQUMxQztFQUNBQyxPQUFPLENBQUNDLEdBQUcsb0JBQUFDLE1BQUEsQ0FDVUgsa0JBQWtCLFFBQ3JDLDBEQUEwRCxFQUMxRCw2RUFBNkUsbUJBQUFHLE1BQUEsQ0FDNURDLE9BQU8sQ0FBQ0MsR0FBRyxDQUFDQyxRQUFRLENBQ3ZDLENBQUM7QUFDSCxDQUFDLE1BQU07RUFDTEwsT0FBTyxDQUFDTSxLQUFLLENBQ1gsbUVBQ0YsQ0FBQztBQUNIIn0=
10
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJwYWNrYWdlSnNvblZlcnNpb24iLCJjb25zb2xlIiwibG9nIiwiY29uY2F0IiwicHJvY2VzcyIsImVudiIsIk5PREVfRU5WIiwiZXJyb3IiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvbWFjcm9zL2dldFZlcnNpb24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHByZXZhbCBmcm9tICdwcmV2YWwubWFjcm8nO1xuXG5jb25zdCBwYWNrYWdlSnNvblZlcnNpb24gPSBwcmV2YWxgbW9kdWxlLmV4cG9ydHMgPSByZXF1aXJlKCcuLi8uLi9iaW4vZ2V0VmVyc2lvbkZyb21QYWNrYWdlSnNvbi5qcycpYDtcbmlmICh0eXBlb2YgcGFja2FnZUpzb25WZXJzaW9uID09PSAnc3RyaW5nJykge1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc29sZVxuICBjb25zb2xlLmxvZyhcbiAgICBgJWMgS2FuZG8gVUkgJWMgdiR7cGFja2FnZUpzb25WZXJzaW9ufSBgLFxuICAgICdmb250LXNpemU6IDE1cHg7IGJhY2tncm91bmQtY29sb3I6ICNmZmY7IGNvbG9yOiAjZTIwZjUzOycsXG4gICAgJ2ZvbnQtd2VpZ2h0OiBib2xkOyBmb250LXNpemU6IDE1cHg7IGJhY2tncm91bmQtY29sb3I6ICNlMjBmNTM7IGNvbG9yOiAjZmZmOycsXG4gICAgYHdpdGggTk9ERV9FTlY9JHtwcm9jZXNzLmVudi5OT0RFX0VOVn1gLFxuICApO1xufSBlbHNlIHtcbiAgY29uc29sZS5lcnJvcihcbiAgICAnZ2V0VmVyc2lvbi5qcyBnb3QgYmFkIHZlcnNpb24gZnJvbSBwYWNrYWdlLmpzb24sIGV4cGVjdGVkIHN0cmluZy4nLFxuICApO1xufVxuIl0sIm1hcHBpbmdzIjoiOztBQUVBLElBQU1BLGtCQUFrQixvQkFBNkU7QUFDckcsSUFBSSxPQUFPQSxrQkFBa0IsS0FBSyxRQUFRLEVBQUU7RUFDMUM7RUFDQUMsT0FBTyxDQUFDQyxHQUFHLG9CQUFBQyxNQUFBLENBQ1VILGtCQUFrQixRQUNyQywwREFBMEQsRUFDMUQsNkVBQTZFLG1CQUFBRyxNQUFBLENBQzVEQyxPQUFPLENBQUNDLEdBQUcsQ0FBQ0MsUUFBUSxDQUN2QyxDQUFDO0FBQ0gsQ0FBQyxNQUFNO0VBQ0xMLE9BQU8sQ0FBQ00sS0FBSyxDQUNYLG1FQUNGLENBQUM7QUFDSCJ9
@@ -200,4 +200,4 @@ var ErrorMessage = _styledComponents.default.div.withConfig({
200
200
  displayName: "List__ErrorMessage",
201
201
  componentId: "sc-1f5wz2c-4"
202
202
  })(["display:flex;height:100%;font-size:20px;justify-content:center;box-shadow:-0.9px -0.5px 5px 0 rgba(0,0,0,0.06);border:solid 1px #ebebeb;padding:20px;"]);
203
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_theme","_reactRedux","_utils","_AreaCard","_FactoryCard","_OrganicCard","_interopRequireDefault","_PotentialSaving","_ListContext","_i18n","_DischargePattern","_QualitySummary","_LineChart","_WWTPDashboardSlice","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof3","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","List","props","_WWTPInfo$point","_WWTPInfo$point2","ReduxState","useSelector","state","areas_data","dispatch","useDispatch","_useSelectedItem","useSelectedItem","selectedItem","handleSelectItem","WWTPInfo","_useSelector","wwtp_dashboard","focusedArea","map","selectedRef","useRef","siteID","point","id","handleItemClick","item","noDataMessage","i18n","t","listDetails","useMemo","_focusedArea$sub_area","_focusedArea$sub_area2","is_no_areas","forWWTPMap","undefined","sub_areas","length","has_device","createElement","ListContainer","ErrorMessage","SummaryComponent","endpoint","concat","className","LineChartComponent","title","DischargePattern","Number","sortAreas","filter","Boolean","area","AreaCard","area_id","object","mapRef","onClick","selected","itemRef","factories","factory","FactoryCard","useEffect","newAreas","isSubAreasEqual","compareArraysByIdAndScore","focusedAreaWithUpdatedSubAreas","_objectSpread2","setFocusedArea","arr1","arr2","_iterator","_createForOfIteratorHelper2","_step","_loop","item1","value","matchingItem","find","item2","v","area_score","s","n","done","_ret","_typeof2","err","e","f","_selectedRef$current","current","scrollIntoView","behavior","block","inline","group","type","clicked","WWTPDetails","style","overflow","name","area_name","exports","styled","div","withConfig","displayName","componentId","theme","WWTPMap","bg","QualitySummary","LineChart"],"sources":["../../../src/pages/DashboardMap/List.tsx"],"sourcesContent":["import { IArea } from '../../store/areas/models/IArea';\nimport React, { useEffect, useMemo, useRef } from 'react';\nimport styled from 'styled-components/macro';\nimport { theme } from 'src/styles/theme/theme';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { appReducer } from '../../store/rootReducer';\nimport { sortAreas } from './utils';\nimport { AreaCard } from './AreaCard';\nimport { FactoryCard } from './FactoryCard';\nimport OrganicCard from '../WwtpPage/OrganicCard';\nimport ImpactCard from '../WwtpPage/PotentialSaving';\nimport { useSelectedItem } from './ListContext';\nimport i18n from 'src/utilities/i18n';\nimport { DischargePattern } from '../SitePage/DischargePattern/DischargePattern';\nimport { QualitySummary } from 'src/Widgets/QualitySummary/QualitySummary';\nimport { LineChart } from 'src/pages/AreaPage/Dashboard/LineChart/LineChart';\nimport { setFocusedArea } from 'src/store/WWTPDashboard/WWTPDashboardSlice';\n\ntype IProps = {\n  global_data: any;\n  WWTPInfo: any;\n  dispatch: any;\n};\n\nexport const List: React.FC<IProps> = (props) => {\n  const ReduxState = useSelector((state) => state);\n  const { areas_data } = ReduxState;\n  const dispatch = useDispatch();\n  const { selectedItem, handleSelectItem } = useSelectedItem();\n  const { WWTPInfo } = props;\n  const { focusedArea, map } = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.wwtp_dashboard,\n  );\n  const selectedRef = useRef(null);\n  const siteID = WWTPInfo.point?.id;\n\n  const handleItemClick = (item) => {\n    handleSelectItem(item);\n  };\n\n  const noDataMessage = i18n.t('wwtpPage.no_data_for_site');\n\n  let listDetails = useMemo(() => {\n    if (!siteID && !focusedArea) {\n      return;\n    }\n\n    const is_no_areas =\n      focusedArea &&\n      focusedArea?.forWWTPMap === true &&\n      siteID !== undefined &&\n      focusedArea.sub_areas?.length === 0;\n\n    if (is_no_areas) {\n      if (\n        // focusedArea?.clicked === undefined ||\n        focusedArea?.has_device === false ||\n        !siteID\n      ) {\n        return (\n          <ListContainer>\n            <ErrorMessage>{noDataMessage}</ErrorMessage>\n          </ListContainer>\n        );\n      } else {\n        return (\n          <ListContainer>\n            <SummaryComponent\n              endpoint={`/data/events-component-data/${siteID}`}\n              className=\"summary-component\"\n            />\n            <LineChartComponent\n              title={i18n.t('area_dashboard.trend')}\n              endpoint={`/points/${siteID}/trend-graph`}\n            />\n            <DischargePattern siteID={Number(siteID)} />\n          </ListContainer>\n        );\n      }\n    }\n\n    if (focusedArea && focusedArea?.sub_areas?.length > 0) {\n      return (\n        focusedArea.sub_areas &&\n        sortAreas(focusedArea.sub_areas)\n          .filter(Boolean)\n          .map((area: IArea) => (\n            <AreaCard\n              key={area.area_id}\n              object={area}\n              mapRef={map}\n              onClick={() => handleItemClick(area.area_id)}\n              selected={selectedItem === area.area_id}\n              itemRef={selectedItem === area.area_id ? selectedRef : null}\n            />\n          ))\n      );\n    } else {\n      if (focusedArea?.factories) {\n        return focusedArea.factories\n          .filter(Boolean)\n          .map((factory) => (\n            <FactoryCard\n              key={factory.id}\n              object={factory}\n              mapRef={map}\n              onClick={() => handleItemClick(factory.id)}\n              selected={selectedItem === factory.id}\n              itemRef={selectedItem === factory.id ? selectedRef : null}\n            />\n          ));\n      }\n    }\n  }, [selectedItem, siteID, focusedArea]);\n\n  // Update the list only if the score of at least one of the sub-areas has changed\n  useEffect(() => {\n    if (\n      focusedArea &&\n      focusedArea.sub_areas &&\n      focusedArea.sub_areas.length > 0 &&\n      areas_data &&\n      focusedArea.sub_areas.length === areas_data.newAreas.length\n    ) {\n      const isSubAreasEqual = compareArraysByIdAndScore(\n        areas_data.newAreas,\n        focusedArea.sub_areas,\n      );\n      if (isSubAreasEqual) return;\n\n      const focusedAreaWithUpdatedSubAreas = {\n        ...focusedArea,\n        sub_areas: areas_data.newAreas,\n      };\n      dispatch(setFocusedArea(focusedAreaWithUpdatedSubAreas));\n    }\n  }, [areas_data]);\n\n  function compareArraysByIdAndScore(arr1, arr2) {\n    // Iterate over each object in the first array\n    for (let item1 of arr1) {\n      // Find the object with the same id in the second array\n      let matchingItem = arr2.find((item2) => item2.area_id === item1.area_id);\n\n      // If no matching item is found in the second array, return false\n      if (!matchingItem) {\n        return false;\n      }\n\n      // If the scores don't match, return false\n      if (item1.area_score !== matchingItem.area_score) {\n        return false;\n      }\n    }\n\n    // If all items matched and had the same score, return true\n    return true;\n  }\n\n  useEffect(() => {\n    selectedRef.current?.scrollIntoView({\n      behavior: 'smooth',\n      block: 'center',\n      inline: 'center',\n    });\n  }, [selectedItem]);\n\n  if (\n    focusedArea?.group &&\n    focusedArea.group.type === 'Groups::WastewaterTreatmentPlant' &&\n    focusedArea?.clicked === undefined\n  )\n    return (\n      <WWTPDetails className=\"p-3\" style={{ overflow: 'scroll' }}>\n        <h3>{WWTPInfo.point?.name}</h3>\n        <div className={'h-auto my-4'}>\n          <OrganicCard />\n        </div>\n        <div className={'h-auto mt-2'}>\n          <ImpactCard />\n        </div>\n      </WWTPDetails>\n    );\n\n  return (\n    <WWTPDetails className=\"p-3\" style={{ overflow: 'scroll' }}>\n      <h3>{focusedArea?.area_name || focusedArea?.name}</h3>\n      <ul className={'mx-n3'}>{listDetails}</ul>\n    </WWTPDetails>\n  );\n};\n\nconst WWTPDetails = styled.div`\n  width: 100%;\n  height: calc(100vh - 134px);\n  background: ${theme.WWTPMap.bg};\n`;\n\nconst SummaryComponent = styled(QualitySummary)`\n  grid-area: summary;\n\n  summary-component {\n    background-color: blue;\n  }\n`;\n\nconst LineChartComponent = styled(LineChart)`\n  grid-area: graph;\n`;\n\nconst ListContainer = styled.div`\n  display: flex;\n  flex-direction: column;\n  justify-content: space-between;\n  height: 100%;\n  padding: 20px;\n  gap: 30px;\n`;\n\nconst ErrorMessage = styled.div`\n  display: flex;\n  height: 100%;\n  font-size: 20px;\n  justify-content: center;\n  box-shadow: -0.9px -0.5px 5px 0 rgba(0, 0, 0, 0.06);\n  border: solid 1px #ebebeb;\n  padding: 20px;\n`;\n"],"mappings":"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"}
203
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_theme","_reactRedux","_utils","_AreaCard","_FactoryCard","_OrganicCard","_interopRequireDefault","_PotentialSaving","_ListContext","_i18n","_DischargePattern","_QualitySummary","_LineChart","_WWTPDashboardSlice","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof3","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","List","props","_WWTPInfo$point","_WWTPInfo$point2","ReduxState","useSelector","state","areas_data","dispatch","useDispatch","_useSelectedItem","useSelectedItem","selectedItem","handleSelectItem","WWTPInfo","_useSelector","wwtp_dashboard","focusedArea","map","selectedRef","useRef","siteID","point","id","handleItemClick","item","noDataMessage","i18n","t","listDetails","useMemo","_focusedArea$sub_area","_focusedArea$sub_area2","is_no_areas","forWWTPMap","undefined","sub_areas","length","has_device","createElement","ListContainer","ErrorMessage","SummaryComponent","endpoint","concat","className","LineChartComponent","title","DischargePattern","Number","sortAreas","filter","Boolean","area","AreaCard","area_id","object","mapRef","onClick","selected","itemRef","factories","factory","FactoryCard","useEffect","newAreas","isSubAreasEqual","compareArraysByIdAndScore","focusedAreaWithUpdatedSubAreas","_objectSpread2","setFocusedArea","arr1","arr2","_iterator","_createForOfIteratorHelper2","_step","_loop","item1","value","matchingItem","find","item2","v","area_score","s","n","done","_ret","_typeof2","err","e","f","_selectedRef$current","current","scrollIntoView","behavior","block","inline","group","type","clicked","WWTPDetails","style","overflow","name","area_name","exports","styled","div","withConfig","displayName","componentId","theme","WWTPMap","bg","QualitySummary","LineChart"],"sources":["../../../src/pages/DashboardMap/List.tsx"],"sourcesContent":["import { IArea } from '../../store/areas/models/IArea';\nimport React, { useEffect, useMemo, useRef } from 'react';\nimport styled from 'styled-components/macro';\nimport { theme } from 'src/styles/theme/theme';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { appReducer } from '../../store/rootReducer';\nimport { sortAreas } from './utils';\nimport { AreaCard } from './AreaCard';\nimport { FactoryCard } from './FactoryCard';\nimport OrganicCard from '../WwtpPage/OrganicCard';\nimport ImpactCard from '../WwtpPage/PotentialSaving';\nimport { useSelectedItem } from './ListContext';\nimport i18n from 'src/utilities/i18n';\nimport { DischargePattern } from '../SitePage/DischargePattern/DischargePattern';\nimport { QualitySummary } from 'src/Widgets/QualitySummary/QualitySummary';\nimport { LineChart } from 'src/pages/AreaPage/Dashboard/LineChart/LineChart';\nimport { setFocusedArea } from 'src/store/WWTPDashboard/WWTPDashboardSlice';\n\ntype IProps = {\n  global_data: any;\n  WWTPInfo: any;\n};\n\nexport const List: React.FC<IProps> = (props) => {\n  const ReduxState = useSelector((state) => state);\n  const { areas_data } = ReduxState;\n  const dispatch = useDispatch();\n  const { selectedItem, handleSelectItem } = useSelectedItem();\n  const { WWTPInfo } = props;\n  const { focusedArea, map } = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.wwtp_dashboard,\n  );\n  const selectedRef = useRef(null);\n  const siteID = WWTPInfo.point?.id;\n\n  const handleItemClick = (item) => {\n    handleSelectItem(item);\n  };\n\n  const noDataMessage = i18n.t('wwtpPage.no_data_for_site');\n\n  let listDetails = useMemo(() => {\n    if (!siteID && !focusedArea) {\n      return;\n    }\n\n    const is_no_areas =\n      focusedArea &&\n      focusedArea?.forWWTPMap === true &&\n      siteID !== undefined &&\n      focusedArea.sub_areas?.length === 0;\n\n    if (is_no_areas) {\n      if (\n        // focusedArea?.clicked === undefined ||\n        focusedArea?.has_device === false ||\n        !siteID\n      ) {\n        return (\n          <ListContainer>\n            <ErrorMessage>{noDataMessage}</ErrorMessage>\n          </ListContainer>\n        );\n      } else {\n        return (\n          <ListContainer>\n            <SummaryComponent\n              endpoint={`/data/events-component-data/${siteID}`}\n              className=\"summary-component\"\n            />\n            <LineChartComponent\n              title={i18n.t('area_dashboard.trend')}\n              endpoint={`/points/${siteID}/trend-graph`}\n            />\n            <DischargePattern siteID={Number(siteID)} />\n          </ListContainer>\n        );\n      }\n    }\n\n    if (focusedArea && focusedArea?.sub_areas?.length > 0) {\n      return (\n        focusedArea.sub_areas &&\n        sortAreas(focusedArea.sub_areas)\n          .filter(Boolean)\n          .map((area: IArea) => (\n            <AreaCard\n              key={area.area_id}\n              object={area}\n              mapRef={map}\n              onClick={() => handleItemClick(area.area_id)}\n              selected={selectedItem === area.area_id}\n              itemRef={selectedItem === area.area_id ? selectedRef : null}\n            />\n          ))\n      );\n    } else {\n      if (focusedArea?.factories) {\n        return focusedArea.factories\n          .filter(Boolean)\n          .map((factory) => (\n            <FactoryCard\n              key={factory.id}\n              object={factory}\n              mapRef={map}\n              onClick={() => handleItemClick(factory.id)}\n              selected={selectedItem === factory.id}\n              itemRef={selectedItem === factory.id ? selectedRef : null}\n            />\n          ));\n      }\n    }\n  }, [selectedItem, siteID, focusedArea]);\n\n  // Update the list only if the score of at least one of the sub-areas has changed\n  useEffect(() => {\n    if (\n      focusedArea &&\n      focusedArea.sub_areas &&\n      focusedArea.sub_areas.length > 0 &&\n      areas_data &&\n      focusedArea.sub_areas.length === areas_data.newAreas.length\n    ) {\n      const isSubAreasEqual = compareArraysByIdAndScore(\n        areas_data.newAreas,\n        focusedArea.sub_areas,\n      );\n      if (isSubAreasEqual) return;\n\n      const focusedAreaWithUpdatedSubAreas = {\n        ...focusedArea,\n        sub_areas: areas_data.newAreas,\n      };\n      dispatch(setFocusedArea(focusedAreaWithUpdatedSubAreas));\n    }\n  }, [areas_data]);\n\n  function compareArraysByIdAndScore(arr1, arr2) {\n    // Iterate over each object in the first array\n    for (let item1 of arr1) {\n      // Find the object with the same id in the second array\n      let matchingItem = arr2.find((item2) => item2.area_id === item1.area_id);\n\n      // If no matching item is found in the second array, return false\n      if (!matchingItem) {\n        return false;\n      }\n\n      // If the scores don't match, return false\n      if (item1.area_score !== matchingItem.area_score) {\n        return false;\n      }\n    }\n\n    // If all items matched and had the same score, return true\n    return true;\n  }\n\n  useEffect(() => {\n    selectedRef.current?.scrollIntoView({\n      behavior: 'smooth',\n      block: 'center',\n      inline: 'center',\n    });\n  }, [selectedItem]);\n\n  if (\n    focusedArea?.group &&\n    focusedArea.group.type === 'Groups::WastewaterTreatmentPlant' &&\n    focusedArea?.clicked === undefined\n  )\n    return (\n      <WWTPDetails className=\"p-3\" style={{ overflow: 'scroll' }}>\n        <h3>{WWTPInfo.point?.name}</h3>\n        <div className={'h-auto my-4'}>\n          <OrganicCard />\n        </div>\n        <div className={'h-auto mt-2'}>\n          <ImpactCard />\n        </div>\n      </WWTPDetails>\n    );\n\n  return (\n    <WWTPDetails className=\"p-3\" style={{ overflow: 'scroll' }}>\n      <h3>{focusedArea?.area_name || focusedArea?.name}</h3>\n      <ul className={'mx-n3'}>{listDetails}</ul>\n    </WWTPDetails>\n  );\n};\n\nconst WWTPDetails = styled.div`\n  width: 100%;\n  height: calc(100vh - 134px);\n  background: ${theme.WWTPMap.bg};\n`;\n\nconst SummaryComponent = styled(QualitySummary)`\n  grid-area: summary;\n\n  summary-component {\n    background-color: blue;\n  }\n`;\n\nconst LineChartComponent = styled(LineChart)`\n  grid-area: graph;\n`;\n\nconst ListContainer = styled.div`\n  display: flex;\n  flex-direction: column;\n  justify-content: space-between;\n  height: 100%;\n  padding: 20px;\n  gap: 30px;\n`;\n\nconst ErrorMessage = styled.div`\n  display: flex;\n  height: 100%;\n  font-size: 20px;\n  justify-content: center;\n  box-shadow: -0.9px -0.5px 5px 0 rgba(0, 0, 0, 0.06);\n  border: solid 1px #ebebeb;\n  padding: 20px;\n`;\n"],"mappings":"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"}
@@ -128,9 +128,6 @@ var WWTPMap = function WWTPMap(props) {
128
128
  // useEffect(() => {
129
129
  // if (!ReduxState.wwtp_dashboard.focusedArea || !wwtp_dashboard.map) return;
130
130
 
131
- // //focusMap(ReduxState.wwtp_dashboard.focusedArea, wwtp_dashboard.map);
132
- // }, [ReduxState.wwtp_dashboard.focusedArea]);
133
-
134
131
  if (!isMapTab) return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null);
135
132
  if (!dataExists() || !points || !areas) return /*#__PURE__*/_react.default.createElement(_Loader.Loader, null);
136
133
  return /*#__PURE__*/_react.default.createElement(_ListContext.SelectedItemProvider, null, /*#__PURE__*/_react.default.createElement(Container, props, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Row, {
@@ -164,4 +161,4 @@ var Container = _styledComponents.default.div.withConfig({
164
161
  })(["width:100vw;.map-column{z-index:0;}.kd-map-container{height:calc(100vh - 134px);width:100%;@media (max-width:1250px){height:calc(100vh - 125px);}#map{height:100%;width:100%;*,*:focus,*:hover{outline:none;}.leaflet-popup-close-button{font-size:x-large;}}}"]);
165
162
  var _default = WWTPMap;
166
163
  exports.default = _default;
167
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_reactRedux","require","_react","_interopRequireWildcard","_Map","_actions","_actions2","_actions3","_List","_utils","_Loader","_reactRouterDom","_useQueryURL","_interopRequireDefault","_WWTPDashboardSlice","_ListContext","_reactBootstrap","_Capacity","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","WWTPMap","props","_ReduxState$wwtp_dash2","searchQuery","useQueryURL","isMapTab","_useParams","useParams","id","areaID","siteID","ReduxState","useSelector","state","dispatch","useDispatch","areas_data","global_data","points_data","edges_data","wwtp_dashboard","_useState","useState","_useState2","_slicedToArray2","points","setPoints","_useState3","_useState4","areas","setAreas","_useState5","point","area","_useState6","WWTPInfo","setWWTPInfo","dataExists","newAreas","length","items","useEffect","waterAuthorityId","fetchPoints","fetchEdges","fetchAreas","dashboard","period","initializeWWTPData","calculateWWTPInfo","cleanup","object","_ReduxState$wwtp_dash","type","is_virtual","validObject","toString","area_id","parseInt","showExtra","focusedArea","fetchCapacity","then","response","setFocusedItem","data","setFocusedArea","utilityDirects","sortAreas","undefined","map","createElement","Fragment","Loader","SelectedItemProvider","Container","Row","className","Col","xs","sm","List","Map","edges","includeUnmonitoredPoints","forEventsView","forWWTPDashboard","areaToCenterBy","shape_data","styled","div","withConfig","displayName","componentId","_default","exports"],"sources":["../../../src/pages/DashboardMap/WWTPMap.tsx"],"sourcesContent":["import { useDispatch, useSelector } from 'react-redux';\nimport React, { useEffect, useState } from 'react';\nimport { Map } from 'src/Widgets/Map/Map';\nimport { fetchAreas } from 'src/store/areas/actions';\nimport { fetchEdges } from 'src/store/edges/actions';\nimport { fetchPoints } from 'src/store/points/actions';\nimport styled from 'styled-components/macro';\nimport { List } from './List';\nimport { IPoint } from '../../store/points/models/IPoint';\nimport { IArea } from '../../store/areas/models/IArea';\nimport { calculateWWTPInfo, initializeWWTPData, sortAreas } from './utils';\nimport { Loader } from './Loader';\nimport { useParams } from 'react-router-dom';\nimport useQueryURL from '../../hooks/useQueryURL';\nimport { setFocusedArea } from '../../store/WWTPDashboard/WWTPDashboardSlice';\nimport { SelectedItemProvider } from './ListContext';\nimport { Row, Col } from 'react-bootstrap';\nimport { fetchCapacity, setFocusedItem } from './Capacity';\n\nexport interface CapacityMapContainerProps {\n  className: string;\n}\nconst WWTPMap: React.FC<CapacityMapContainerProps> = (props) => {\n  const searchQuery = useQueryURL();\n  const isMapTab = searchQuery.get('view') === 'map';\n  let { id, areaID, siteID } = useParams();\n  id = id || areaID || siteID;\n  const ReduxState = useSelector((state) => state);\n  const dispatch = useDispatch();\n  const { areas_data, global_data, points_data, edges_data, wwtp_dashboard } =\n    ReduxState;\n  const [points, setPoints] = useState<IPoint[] | null>(null);\n  const [areas, setAreas] = useState<IArea[] | null>(null);\n  const [WWTPInfo, setWWTPInfo] = useState<{\n    point: IPoint | null;\n    area: IArea | null;\n  }>({ point: null, area: null });\n  let dataExists = () => {\n    return (\n      areas_data.newAreas.length !== 0 ||\n      points_data.items.length !== 0 ||\n      edges_data.items.length !== 0\n    );\n  };\n\n  useEffect(() => {\n    if (global_data.waterAuthorityId) {\n      dispatch(fetchPoints(global_data.waterAuthorityId));\n      dispatch(fetchEdges(global_data.waterAuthorityId));\n      dispatch(\n        fetchAreas(\n          global_data.waterAuthorityId,\n          ReduxState.dashboard.period,\n          true,\n        ),\n      );\n    }\n  }, [ReduxState.dashboard.period]);\n\n  useEffect(() => {\n    initializeWWTPData({\n      areas_data,\n      points_data,\n      setPoints,\n      setAreas,\n      setWWTPInfo,\n      dataExists,\n      id,\n    });\n  }, [areas_data]);\n\n  useEffect(() => {\n    setWWTPInfo(calculateWWTPInfo({ id, points_data, areas_data }));\n  }, [id]);\n\n  // useEffect(() => {\n  //   focusMap(WWTPInfo.area || WWTPInfo.point, wwtp_dashboard.map);\n  // }, [WWTPInfo]);\n\n  useEffect(() => {\n    if (global_data.waterAuthorityId) {\n      points_data.items.length === 0 &&\n        dispatch(fetchPoints(global_data.waterAuthorityId));\n      edges_data.items.length === 0 &&\n        dispatch(fetchEdges(global_data.waterAuthorityId));\n      areas_data.items.length === 0 &&\n        dispatch(\n          fetchAreas(\n            global_data.waterAuthorityId,\n            ReduxState.dashboard.period,\n            true,\n          ),\n        );\n    }\n\n    return function cleanup() {\n      setPoints(null);\n      setAreas(null);\n      setWWTPInfo({ point: null, area: null });\n    };\n  }, [global_data.waterAuthorityId]);\n\n  useEffect(() => {\n    const object = WWTPInfo.area || WWTPInfo.point;\n\n    if (isMapTab && object) {\n      const type = WWTPInfo.area\n        ? object.is_virtual === true\n          ? 'varea'\n          : 'area'\n        : 'site';\n\n      const validObject =\n        type === 'site'\n          ? object.id.toString() === id\n          : object.area_id === parseInt(id);\n\n      const showExtra = object.id === ReduxState.wwtp_dashboard.focusedArea?.id;\n\n      if (validObject) {\n        fetchCapacity(type, id, global_data.waterAuthorityId).then(\n          (response) => {\n            setFocusedItem(\n              object,\n              response.data,\n              points,\n              areas,\n              dispatch,\n              setFocusedArea,\n              showExtra,\n            );\n          },\n        );\n      }\n    } else {\n      const utilityDirects = sortAreas(areas);\n\n      setFocusedItem(\n        undefined,\n        null,\n        points,\n        utilityDirects,\n        dispatch,\n        setFocusedArea,\n        true,\n      );\n    }\n    // focusMap(object, wwtp_dashboard.map);\n  }, [wwtp_dashboard.map]);\n\n  // useEffect(() => {\n  //   if (!ReduxState.wwtp_dashboard.focusedArea || !wwtp_dashboard.map) return;\n\n  //   //focusMap(ReduxState.wwtp_dashboard.focusedArea, wwtp_dashboard.map);\n  // }, [ReduxState.wwtp_dashboard.focusedArea]);\n\n  if (!isMapTab) return <></>;\n  if (!dataExists() || !points || !areas) return <Loader />;\n\n  return (\n    <SelectedItemProvider>\n      <Container {...props}>\n        <Row className=\"no-gutters\">\n          <Col xs=\"auto\" sm={4} className=\"d-none d-sm-flex\">\n            <List\n              global_data={global_data}\n              WWTPInfo={WWTPInfo}\n              dispatch={dispatch}\n            />\n          </Col>\n          <Col className=\"map-column\" xs={12} sm={8}>\n            <Map\n              points={points}\n              areas={areas}\n              global_data={global_data}\n              edges={edges_data.items}\n              includeUnmonitoredPoints={true}\n              forEventsView={false}\n              forWWTPDashboard={true}\n              areaToCenterBy={ReduxState.wwtp_dashboard.focusedArea?.shape_data}\n            />\n          </Col>\n        </Row>\n      </Container>\n    </SelectedItemProvider>\n  );\n};\n\nconst Container = styled.div`\n  width: 100vw;\n\n  .map-column {\n    z-index: 0;\n  }\n\n  .kd-map-container {\n    height: calc(100vh - 134px);\n    width: 100%;\n\n    @media (max-width: 1250px) {\n      height: calc(100vh - 125px);\n    }\n\n    #map {\n      height: 100%;\n      width: 100%;\n\n      *,\n      *:focus,\n      *:hover {\n        outline: none;\n      }\n\n      .leaflet-popup-close-button {\n        font-size: x-large;\n      }\n    }\n  }\n`;\n\nexport default WWTPMap;\n"],"mappings":"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"}
164
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_reactRedux","require","_react","_interopRequireWildcard","_Map","_actions","_actions2","_actions3","_List","_utils","_Loader","_reactRouterDom","_useQueryURL","_interopRequireDefault","_WWTPDashboardSlice","_ListContext","_reactBootstrap","_Capacity","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","WWTPMap","props","_ReduxState$wwtp_dash2","searchQuery","useQueryURL","isMapTab","_useParams","useParams","id","areaID","siteID","ReduxState","useSelector","state","dispatch","useDispatch","areas_data","global_data","points_data","edges_data","wwtp_dashboard","_useState","useState","_useState2","_slicedToArray2","points","setPoints","_useState3","_useState4","areas","setAreas","_useState5","point","area","_useState6","WWTPInfo","setWWTPInfo","dataExists","newAreas","length","items","useEffect","waterAuthorityId","fetchPoints","fetchEdges","fetchAreas","dashboard","period","initializeWWTPData","calculateWWTPInfo","cleanup","object","_ReduxState$wwtp_dash","type","is_virtual","validObject","toString","area_id","parseInt","showExtra","focusedArea","fetchCapacity","then","response","setFocusedItem","data","setFocusedArea","utilityDirects","sortAreas","undefined","map","createElement","Fragment","Loader","SelectedItemProvider","Container","Row","className","Col","xs","sm","List","Map","edges","includeUnmonitoredPoints","forEventsView","forWWTPDashboard","areaToCenterBy","shape_data","styled","div","withConfig","displayName","componentId","_default","exports"],"sources":["../../../src/pages/DashboardMap/WWTPMap.tsx"],"sourcesContent":["import { useDispatch, useSelector } from 'react-redux';\nimport React, { useEffect, useState } from 'react';\nimport { Map } from 'src/Widgets/Map/Map';\nimport { fetchAreas } from 'src/store/areas/actions';\nimport { fetchEdges } from 'src/store/edges/actions';\nimport { fetchPoints } from 'src/store/points/actions';\nimport styled from 'styled-components/macro';\nimport { List } from './List';\nimport { IPoint } from '../../store/points/models/IPoint';\nimport { IArea } from '../../store/areas/models/IArea';\nimport { calculateWWTPInfo, initializeWWTPData, sortAreas } from './utils';\nimport { Loader } from './Loader';\nimport { useParams } from 'react-router-dom';\nimport useQueryURL from '../../hooks/useQueryURL';\nimport { setFocusedArea } from '../../store/WWTPDashboard/WWTPDashboardSlice';\nimport { SelectedItemProvider } from './ListContext';\nimport { Row, Col } from 'react-bootstrap';\nimport { fetchCapacity, setFocusedItem } from './Capacity';\n\nexport interface CapacityMapContainerProps {\n  className: string;\n}\nconst WWTPMap: React.FC<CapacityMapContainerProps> = (props) => {\n  const searchQuery = useQueryURL();\n  const isMapTab = searchQuery.get('view') === 'map';\n  let { id, areaID, siteID } = useParams();\n  id = id || areaID || siteID;\n  const ReduxState = useSelector((state) => state);\n  const dispatch = useDispatch();\n  const { areas_data, global_data, points_data, edges_data, wwtp_dashboard } =\n    ReduxState;\n  const [points, setPoints] = useState<IPoint[] | null>(null);\n  const [areas, setAreas] = useState<IArea[] | null>(null);\n  const [WWTPInfo, setWWTPInfo] = useState<{\n    point: IPoint | null;\n    area: IArea | null;\n  }>({ point: null, area: null });\n  let dataExists = () => {\n    return (\n      areas_data.newAreas.length !== 0 ||\n      points_data.items.length !== 0 ||\n      edges_data.items.length !== 0\n    );\n  };\n\n  useEffect(() => {\n    if (global_data.waterAuthorityId) {\n      dispatch(fetchPoints(global_data.waterAuthorityId));\n      dispatch(fetchEdges(global_data.waterAuthorityId));\n      dispatch(\n        fetchAreas(\n          global_data.waterAuthorityId,\n          ReduxState.dashboard.period,\n          true,\n        ),\n      );\n    }\n  }, [ReduxState.dashboard.period]);\n\n  useEffect(() => {\n    initializeWWTPData({\n      areas_data,\n      points_data,\n      setPoints,\n      setAreas,\n      setWWTPInfo,\n      dataExists,\n      id,\n    });\n  }, [areas_data]);\n\n  useEffect(() => {\n    setWWTPInfo(calculateWWTPInfo({ id, points_data, areas_data }));\n  }, [id]);\n\n  // useEffect(() => {\n  //   focusMap(WWTPInfo.area || WWTPInfo.point, wwtp_dashboard.map);\n  // }, [WWTPInfo]);\n\n  useEffect(() => {\n    if (global_data.waterAuthorityId) {\n      points_data.items.length === 0 &&\n        dispatch(fetchPoints(global_data.waterAuthorityId));\n      edges_data.items.length === 0 &&\n        dispatch(fetchEdges(global_data.waterAuthorityId));\n      areas_data.items.length === 0 &&\n        dispatch(\n          fetchAreas(\n            global_data.waterAuthorityId,\n            ReduxState.dashboard.period,\n            true,\n          ),\n        );\n    }\n\n    return function cleanup() {\n      setPoints(null);\n      setAreas(null);\n      setWWTPInfo({ point: null, area: null });\n    };\n  }, [global_data.waterAuthorityId]);\n\n  useEffect(() => {\n    const object = WWTPInfo.area || WWTPInfo.point;\n\n    if (isMapTab && object) {\n      const type = WWTPInfo.area\n        ? object.is_virtual === true\n          ? 'varea'\n          : 'area'\n        : 'site';\n\n      const validObject =\n        type === 'site'\n          ? object.id.toString() === id\n          : object.area_id === parseInt(id);\n\n      const showExtra = object.id === ReduxState.wwtp_dashboard.focusedArea?.id;\n\n      if (validObject) {\n        fetchCapacity(type, id, global_data.waterAuthorityId).then(\n          (response) => {\n            setFocusedItem(\n              object,\n              response.data,\n              points,\n              areas,\n              dispatch,\n              setFocusedArea,\n              showExtra,\n            );\n          },\n        );\n      }\n    } else {\n      const utilityDirects = sortAreas(areas);\n\n      setFocusedItem(\n        undefined,\n        null,\n        points,\n        utilityDirects,\n        dispatch,\n        setFocusedArea,\n        true,\n      );\n    }\n    // focusMap(object, wwtp_dashboard.map);\n  }, [wwtp_dashboard.map]);\n\n  // useEffect(() => {\n  //   if (!ReduxState.wwtp_dashboard.focusedArea || !wwtp_dashboard.map) return;\n\n  if (!isMapTab) return <></>;\n  if (!dataExists() || !points || !areas) return <Loader />;\n\n  return (\n    <SelectedItemProvider>\n      <Container {...props}>\n        <Row className=\"no-gutters\">\n          <Col xs=\"auto\" sm={4} className=\"d-none d-sm-flex\">\n            <List\n              global_data={global_data}\n              WWTPInfo={WWTPInfo}\n              dispatch={dispatch}\n            />\n          </Col>\n          <Col className=\"map-column\" xs={12} sm={8}>\n            <Map\n              points={points}\n              areas={areas}\n              global_data={global_data}\n              edges={edges_data.items}\n              includeUnmonitoredPoints={true}\n              forEventsView={false}\n              forWWTPDashboard={true}\n              areaToCenterBy={ReduxState.wwtp_dashboard.focusedArea?.shape_data}\n            />\n          </Col>\n        </Row>\n      </Container>\n    </SelectedItemProvider>\n  );\n};\n\nconst Container = styled.div`\n  width: 100vw;\n\n  .map-column {\n    z-index: 0;\n  }\n\n  .kd-map-container {\n    height: calc(100vh - 134px);\n    width: 100%;\n\n    @media (max-width: 1250px) {\n      height: calc(100vh - 125px);\n    }\n\n    #map {\n      height: 100%;\n      width: 100%;\n\n      *,\n      *:focus,\n      *:hover {\n        outline: none;\n      }\n\n      .leaflet-popup-close-button {\n        font-size: x-large;\n      }\n    }\n  }\n`;\n\nexport default WWTPMap;\n"],"mappings":";;;;;;;;;;AAAA,IAAAA,WAAA,GAAAC,OAAA;AACA,IAAAC,MAAA,GAAAC,uBAAA,CAAAF,OAAA;AACA,IAAAG,IAAA,GAAAH,OAAA;AACA,IAAAI,QAAA,GAAAJ,OAAA;AACA,IAAAK,SAAA,GAAAL,OAAA;AACA,IAAAM,SAAA,GAAAN,OAAA;AAEA,IAAAO,KAAA,GAAAP,OAAA;AAGA,IAAAQ,MAAA,GAAAR,OAAA;AACA,IAAAS,OAAA,GAAAT,OAAA;AACA,IAAAU,eAAA,GAAAV,OAAA;AACA,IAAAW,YAAA,GAAAC,sBAAA,CAAAZ,OAAA;AACA,IAAAa,mBAAA,GAAAb,OAAA;AACA,IAAAc,YAAA,GAAAd,OAAA;AACA,IAAAe,eAAA,GAAAf,OAAA;AACA,IAAAgB,SAAA,GAAAhB,OAAA;AAA2D,SAAAiB,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;AAK3D,IAAMW,OAA4C,GAAG,SAA/CA,OAA4CA,CAAIC,KAAK,EAAK;EAAA,IAAAC,sBAAA;EAC9D,IAAMC,WAAW,GAAG,IAAAC,oBAAW,EAAC,CAAC;EACjC,IAAMC,QAAQ,GAAGF,WAAW,CAACf,GAAG,CAAC,MAAM,CAAC,KAAK,KAAK;EAClD,IAAAkB,UAAA,GAA6B,IAAAC,yBAAS,EAAC,CAAC;IAAlCC,EAAE,GAAAF,UAAA,CAAFE,EAAE;IAAEC,MAAM,GAAAH,UAAA,CAANG,MAAM;IAAEC,MAAM,GAAAJ,UAAA,CAANI,MAAM;EACxBF,EAAE,GAAGA,EAAE,IAAIC,MAAM,IAAIC,MAAM;EAC3B,IAAMC,UAAU,GAAG,IAAAC,uBAAW,EAAC,UAACC,KAAK;IAAA,OAAKA,KAAK;EAAA,EAAC;EAChD,IAAMC,QAAQ,GAAG,IAAAC,uBAAW,EAAC,CAAC;EAC9B,IAAQC,UAAU,GAChBL,UAAU,CADJK,UAAU;IAAEC,WAAW,GAC7BN,UAAU,CADQM,WAAW;IAAEC,WAAW,GAC1CP,UAAU,CADqBO,WAAW;IAAEC,UAAU,GACtDR,UAAU,CADkCQ,UAAU;IAAEC,cAAc,GACtET,UAAU,CAD8CS,cAAc;EAExE,IAAAC,SAAA,GAA4B,IAAAC,eAAQ,EAAkB,IAAI,CAAC;IAAAC,UAAA,OAAAC,eAAA,CAAAvC,OAAA,EAAAoC,SAAA;IAApDI,MAAM,GAAAF,UAAA;IAAEG,SAAS,GAAAH,UAAA;EACxB,IAAAI,UAAA,GAA0B,IAAAL,eAAQ,EAAiB,IAAI,CAAC;IAAAM,UAAA,OAAAJ,eAAA,CAAAvC,OAAA,EAAA0C,UAAA;IAAjDE,KAAK,GAAAD,UAAA;IAAEE,QAAQ,GAAAF,UAAA;EACtB,IAAAG,UAAA,GAAgC,IAAAT,eAAQ,EAGrC;MAAEU,KAAK,EAAE,IAAI;MAAEC,IAAI,EAAE;IAAK,CAAC,CAAC;IAAAC,UAAA,OAAAV,eAAA,CAAAvC,OAAA,EAAA8C,UAAA;IAHxBI,QAAQ,GAAAD,UAAA;IAAEE,WAAW,GAAAF,UAAA;EAI5B,IAAIG,UAAU,GAAG,SAAbA,UAAUA,CAAA,EAAS;IACrB,OACErB,UAAU,CAACsB,QAAQ,CAACC,MAAM,KAAK,CAAC,IAChCrB,WAAW,CAACsB,KAAK,CAACD,MAAM,KAAK,CAAC,IAC9BpB,UAAU,CAACqB,KAAK,CAACD,MAAM,KAAK,CAAC;EAEjC,CAAC;EAED,IAAAE,gBAAS,EAAC,YAAM;IACd,IAAIxB,WAAW,CAACyB,gBAAgB,EAAE;MAChC5B,QAAQ,CAAC,IAAA6B,qBAAW,EAAC1B,WAAW,CAACyB,gBAAgB,CAAC,CAAC;MACnD5B,QAAQ,CAAC,IAAA8B,oBAAU,EAAC3B,WAAW,CAACyB,gBAAgB,CAAC,CAAC;MAClD5B,QAAQ,CACN,IAAA+B,mBAAU,EACR5B,WAAW,CAACyB,gBAAgB,EAC5B/B,UAAU,CAACmC,SAAS,CAACC,MAAM,EAC3B,IACF,CACF,CAAC;IACH;EACF,CAAC,EAAE,CAACpC,UAAU,CAACmC,SAAS,CAACC,MAAM,CAAC,CAAC;EAEjC,IAAAN,gBAAS,EAAC,YAAM;IACd,IAAAO,yBAAkB,EAAC;MACjBhC,UAAU,EAAVA,UAAU;MACVE,WAAW,EAAXA,WAAW;MACXQ,SAAS,EAATA,SAAS;MACTI,QAAQ,EAARA,QAAQ;MACRM,WAAW,EAAXA,WAAW;MACXC,UAAU,EAAVA,UAAU;MACV7B,EAAE,EAAFA;IACF,CAAC,CAAC;EACJ,CAAC,EAAE,CAACQ,UAAU,CAAC,CAAC;EAEhB,IAAAyB,gBAAS,EAAC,YAAM;IACdL,WAAW,CAAC,IAAAa,wBAAiB,EAAC;MAAEzC,EAAE,EAAFA,EAAE;MAAEU,WAAW,EAAXA,WAAW;MAAEF,UAAU,EAAVA;IAAW,CAAC,CAAC,CAAC;EACjE,CAAC,EAAE,CAACR,EAAE,CAAC,CAAC;;EAER;EACA;EACA;;EAEA,IAAAiC,gBAAS,EAAC,YAAM;IACd,IAAIxB,WAAW,CAACyB,gBAAgB,EAAE;MAChCxB,WAAW,CAACsB,KAAK,CAACD,MAAM,KAAK,CAAC,IAC5BzB,QAAQ,CAAC,IAAA6B,qBAAW,EAAC1B,WAAW,CAACyB,gBAAgB,CAAC,CAAC;MACrDvB,UAAU,CAACqB,KAAK,CAACD,MAAM,KAAK,CAAC,IAC3BzB,QAAQ,CAAC,IAAA8B,oBAAU,EAAC3B,WAAW,CAACyB,gBAAgB,CAAC,CAAC;MACpD1B,UAAU,CAACwB,KAAK,CAACD,MAAM,KAAK,CAAC,IAC3BzB,QAAQ,CACN,IAAA+B,mBAAU,EACR5B,WAAW,CAACyB,gBAAgB,EAC5B/B,UAAU,CAACmC,SAAS,CAACC,MAAM,EAC3B,IACF,CACF,CAAC;IACL;IAEA,OAAO,SAASG,OAAOA,CAAA,EAAG;MACxBxB,SAAS,CAAC,IAAI,CAAC;MACfI,QAAQ,CAAC,IAAI,CAAC;MACdM,WAAW,CAAC;QAAEJ,KAAK,EAAE,IAAI;QAAEC,IAAI,EAAE;MAAK,CAAC,CAAC;IAC1C,CAAC;EACH,CAAC,EAAE,CAAChB,WAAW,CAACyB,gBAAgB,CAAC,CAAC;EAElC,IAAAD,gBAAS,EAAC,YAAM;IACd,IAAMU,MAAM,GAAGhB,QAAQ,CAACF,IAAI,IAAIE,QAAQ,CAACH,KAAK;IAE9C,IAAI3B,QAAQ,IAAI8C,MAAM,EAAE;MAAA,IAAAC,qBAAA;MACtB,IAAMC,IAAI,GAAGlB,QAAQ,CAACF,IAAI,GACtBkB,MAAM,CAACG,UAAU,KAAK,IAAI,GACxB,OAAO,GACP,MAAM,GACR,MAAM;MAEV,IAAMC,WAAW,GACfF,IAAI,KAAK,MAAM,GACXF,MAAM,CAAC3C,EAAE,CAACgD,QAAQ,CAAC,CAAC,KAAKhD,EAAE,GAC3B2C,MAAM,CAACM,OAAO,KAAKC,QAAQ,CAAClD,EAAE,CAAC;MAErC,IAAMmD,SAAS,GAAGR,MAAM,CAAC3C,EAAE,OAAA4C,qBAAA,GAAKzC,UAAU,CAACS,cAAc,CAACwC,WAAW,cAAAR,qBAAA,uBAArCA,qBAAA,CAAuC5C,EAAE;MAEzE,IAAI+C,WAAW,EAAE;QACf,IAAAM,uBAAa,EAACR,IAAI,EAAE7C,EAAE,EAAES,WAAW,CAACyB,gBAAgB,CAAC,CAACoB,IAAI,CACxD,UAACC,QAAQ,EAAK;UACZ,IAAAC,wBAAc,EACZb,MAAM,EACNY,QAAQ,CAACE,IAAI,EACbxC,MAAM,EACNI,KAAK,EACLf,QAAQ,EACRoD,kCAAc,EACdP,SACF,CAAC;QACH,CACF,CAAC;MACH;IACF,CAAC,MAAM;MACL,IAAMQ,cAAc,GAAG,IAAAC,gBAAS,EAACvC,KAAK,CAAC;MAEvC,IAAAmC,wBAAc,EACZK,SAAS,EACT,IAAI,EACJ5C,MAAM,EACN0C,cAAc,EACdrD,QAAQ,EACRoD,kCAAc,EACd,IACF,CAAC;IACH;IACA;EACF,CAAC,EAAE,CAAC9C,cAAc,CAACkD,GAAG,CAAC,CAAC;;EAExB;EACA;;EAEA,IAAI,CAACjE,QAAQ,EAAE,oBAAO5C,MAAA,CAAAwB,OAAA,CAAAsF,aAAA,CAAA9G,MAAA,CAAAwB,OAAA,CAAAuF,QAAA,MAAI,CAAC;EAC3B,IAAI,CAACnC,UAAU,CAAC,CAAC,IAAI,CAACZ,MAAM,IAAI,CAACI,KAAK,EAAE,oBAAOpE,MAAA,CAAAwB,OAAA,CAAAsF,aAAA,CAACtG,OAAA,CAAAwG,MAAM,MAAE,CAAC;EAEzD,oBACEhH,MAAA,CAAAwB,OAAA,CAAAsF,aAAA,CAACjG,YAAA,CAAAoG,oBAAoB,qBACnBjH,MAAA,CAAAwB,OAAA,CAAAsF,aAAA,CAACI,SAAS,EAAK1E,KAAK,eAClBxC,MAAA,CAAAwB,OAAA,CAAAsF,aAAA,CAAChG,eAAA,CAAAqG,GAAG;IAACC,SAAS,EAAC;EAAY,gBACzBpH,MAAA,CAAAwB,OAAA,CAAAsF,aAAA,CAAChG,eAAA,CAAAuG,GAAG;IAACC,EAAE,EAAC,MAAM;IAACC,EAAE,EAAE,CAAE;IAACH,SAAS,EAAC;EAAkB,gBAChDpH,MAAA,CAAAwB,OAAA,CAAAsF,aAAA,CAACxG,KAAA,CAAAkH,IAAI;IACHhE,WAAW,EAAEA,WAAY;IACzBkB,QAAQ,EAAEA,QAAS;IACnBrB,QAAQ,EAAEA;EAAS,CACpB,CACE,CAAC,eACNrD,MAAA,CAAAwB,OAAA,CAAAsF,aAAA,CAAChG,eAAA,CAAAuG,GAAG;IAACD,SAAS,EAAC,YAAY;IAACE,EAAE,EAAE,EAAG;IAACC,EAAE,EAAE;EAAE,gBACxCvH,MAAA,CAAAwB,OAAA,CAAAsF,aAAA,CAAC5G,IAAA,CAAAuH,GAAG;IACFzD,MAAM,EAAEA,MAAO;IACfI,KAAK,EAAEA,KAAM;IACbZ,WAAW,EAAEA,WAAY;IACzBkE,KAAK,EAAEhE,UAAU,CAACqB,KAAM;IACxB4C,wBAAwB,EAAE,IAAK;IAC/BC,aAAa,EAAE,KAAM;IACrBC,gBAAgB,EAAE,IAAK;IACvBC,cAAc,GAAArF,sBAAA,GAAES,UAAU,CAACS,cAAc,CAACwC,WAAW,cAAA1D,sBAAA,uBAArCA,sBAAA,CAAuCsF;EAAW,CACnE,CACE,CACF,CACI,CACS,CAAC;AAE3B,CAAC;AAED,IAAMb,SAAS,GAAGc,yBAAM,CAACC,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,sQA8B3B;AAAC,IAAAC,QAAA,GAEa9F,OAAO;AAAA+F,OAAA,CAAA9G,OAAA,GAAA6G,QAAA"}
@@ -77,7 +77,7 @@ var EventsMapContainer = function EventsMapContainer(props) {
77
77
  var mappedPoints = (0, _react.useMemo)(function () {
78
78
  return points_data.items.map(function (point) {
79
79
  var newPoint = (0, _objectSpread2.default)({}, point);
80
- if (!EventsPerSite[point.id] || (0, _EventUtils.isCollectorUnmonitored)(point)) {
80
+ if (EventsPerSite === undefined || !EventsPerSite[point.id] || (0, _EventUtils.isCollectorUnmonitored)(point)) {
81
81
  newPoint.hide = true;
82
82
  }
83
83
  if (events_data.focusedEvent) {
@@ -93,7 +93,7 @@ var EventsMapContainer = function EventsMapContainer(props) {
93
93
  newPoint.hide = false;
94
94
  }
95
95
  }
96
- newPoint.relatedEventsAmount = EventsPerSite[point.id] || 0;
96
+ newPoint.relatedEventsAmount = EventsPerSite ? EventsPerSite[point.id] : 0;
97
97
  newPoint.eventsViewHovered = true;
98
98
  return newPoint;
99
99
  });
@@ -147,4 +147,4 @@ var EventsMapContainer = function EventsMapContainer(props) {
147
147
  }));
148
148
  };
149
149
  exports.EventsMapContainer = EventsMapContainer;
150
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRedux","_EventsMapContainerHelpers","_actions","_actions2","_actions3","_Map","_FloatingGraph","_interopRequireDefault","_GraphUtils","_actions4","_DragAndDropArea","_EventUtils","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","EventsMapContainer","props","_global_data$floating","_global_data$floating2","dispatch","useDispatch","ReduxState","useSelector","state","areas_data","global_data","points_data","events_data","edges_data","isTimeFilterNotSelected","useMemo","_global_data$activeFi","filters","activeFilter","filter_items","length","index","type","mappedAreas","areasMapper","getActiveTimeFilterPeriod","_global_data$activeFi2","items","activeTimeFilter","selected_options","EventsPerSite","CountEventsPerSiteID","MustSeenSites","focusedEvent","getFocusedEventMustSeenSites","hoveredEvent","mappedPoints","map","point","newPoint","_objectSpread2","id","isCollectorUnmonitored","hide","relatedEventsAmount","eventsViewHovered","mappedEdges","filter","edge","descendants_has_device","descendants_has_none_collectors","areaToCenterBy","getAreasToCenterBy","useEffect","waterAuthorityId","fetchPoints","fetchEdges","fetchAreas","createElement","Map","assign","areas","points","edges","events","hideEdges","includeUnmonitoredPoints","includeUnmonitoredDescendantsForEdges","forEventsView","focusedEventPath","focusedEventPaths","floatingGraph","isOpen","open","customHighChartOptions","dndGraphInitOptions","closeGraphHandler","closeFloatingGraph","globalDataFloatingGraph","event_data","graphId","exports"],"sources":["../../../../src/pages/EventsPage/EventsMapContainer/EventsMapContainer.tsx"],"sourcesContent":["import React, { useEffect, useMemo } from 'react';\nimport { useDispatch, useSelector } from 'react-redux';\nimport {\n  areasMapper,\n  CountEventsPerSiteID,\n  getAreasToCenterBy,\n  getFocusedEventMustSeenSites,\n} from 'src/pages/EventsPage/EventsMapContainer/EventsMapContainerHelpers';\nimport { fetchAreas } from 'src/store/areas/actions';\nimport { fetchEdges } from 'src/store/edges/actions';\nimport { fetchPoints } from 'src/store/points/actions';\nimport { Map } from 'src/Widgets/Map/Map';\nimport FloatingGraph from 'src/pages/EventsPage/FloatingGraph/FloatingGraph';\nimport { dndGraphInitOptions } from 'src/Widgets/Map/GraphUtils';\nimport { closeFloatingGraph } from 'src/store/global/actions';\nimport DragAndDropArea from '../DragAndDropArea';\nimport { isCollectorUnmonitored } from 'src/Widgets/Map/events/EventUtils';\ninterface EventsMapContainerProps {\n  showSecondMap: boolean;\n}\nexport const EventsMapContainer: React.FC<EventsMapContainerProps> = (\n  props,\n) => {\n  const dispatch = useDispatch();\n  const ReduxState = useSelector((state) => state);\n  const { areas_data, global_data, points_data, events_data, edges_data } =\n    ReduxState;\n\n  const isTimeFilterNotSelected = useMemo(() => {\n    const filters = global_data?.activeFilter?.filter_items;\n\n    if (!filters || filters.length < 1) {\n      return true;\n    }\n\n    for (let index = 0; index < filters.length; index++) {\n      if (filters[index].type === 'TimeFilterItem') {\n        return false;\n      }\n    }\n\n    return true;\n  }, [global_data?.activeFilter]);\n\n  const mappedAreas = useMemo(\n    () => areasMapper(areas_data, isTimeFilterNotSelected),\n    [areas_data, isTimeFilterNotSelected],\n  );\n\n  const getActiveTimeFilterPeriod = () => {\n    const items = global_data?.activeFilter?.filter_items;\n    let activeTimeFilter = '1m';\n\n    if (!items || items.length < 1) {\n      return activeTimeFilter;\n    }\n\n    for (let index = 0; index < items.length; index++) {\n      if (items[index].type === 'TimeFilterItem') {\n        activeTimeFilter = items[index].selected_options[0];\n        break;\n      }\n    }\n    return activeTimeFilter;\n  };\n\n  const EventsPerSite = useMemo(\n    () => CountEventsPerSiteID(events_data.items),\n    [events_data.items],\n  );\n\n  const MustSeenSites = useMemo(() => {\n    if (events_data.focusedEvent) {\n      return getFocusedEventMustSeenSites(events_data.focusedEvent);\n    } else if (events_data.hoveredEvent) {\n      return getFocusedEventMustSeenSites(events_data.hoveredEvent);\n    }\n    return {};\n  }, [EventsPerSite, events_data.focusedEvent, events_data.hoveredEvent]);\n\n  const mappedPoints = useMemo(\n    () =>\n      points_data.items.map((point) => {\n        const newPoint = { ...point };\n\n        if (!EventsPerSite[point.id] || isCollectorUnmonitored(point)) {\n          newPoint.hide = true;\n        }\n\n        if (events_data.focusedEvent) {\n          if (!MustSeenSites[point.id]) {\n            newPoint.hide = true;\n          } else {\n            newPoint.hide = false;\n          }\n        } else if (events_data.hoveredEvent) {\n          if (!MustSeenSites[point.id] && isCollectorUnmonitored(point)) {\n            newPoint.hide = true;\n          } else {\n            newPoint.hide = false;\n          }\n        }\n\n        newPoint.relatedEventsAmount = EventsPerSite[point.id] || 0;\n        newPoint.eventsViewHovered = true;\n        return newPoint;\n      }),\n    [\n      points_data,\n      EventsPerSite,\n      events_data.items,\n      events_data.focusedEvent,\n      events_data.hoveredEvent,\n    ],\n  );\n\n  // eslint-disable-next-line\n  const mappedEdges = edges_data.items.filter(\n    (edge) =>\n      // (Number(EventsPerSite[edge.source_point_id]) > 0 ||\n      // Number(EventsPerSite[edge.target_point_id]) > 0)\n      //  &&\n      edge.descendants_has_device === true ||\n      edge.descendants_has_none_collectors === true,\n  );\n\n  const areaToCenterBy = useMemo(\n    () => getAreasToCenterBy(global_data, mappedAreas),\n    [global_data?.activeFilter, mappedAreas],\n  );\n\n  useEffect(() => {\n    if (global_data.waterAuthorityId) {\n      dispatch(fetchPoints(global_data.waterAuthorityId));\n      dispatch(fetchEdges(global_data.waterAuthorityId));\n      dispatch(\n        fetchAreas(\n          global_data.waterAuthorityId,\n          getActiveTimeFilterPeriod(),\n          true,\n        ),\n      );\n    }\n  }, [global_data.waterAuthorityId, global_data.activeFilter]);\n\n  return (\n    <Map\n      {...ReduxState}\n      areas={mappedAreas}\n      global_data={global_data}\n      points={mappedPoints}\n      edges={mappedEdges}\n      events={events_data.items}\n      focusedEvent={events_data.focusedEvent}\n      hoveredEvent={events_data.hoveredEvent}\n      areaToCenterBy={areaToCenterBy}\n      hideEdges={true}\n      includeUnmonitoredPoints={false}\n      includeUnmonitoredDescendantsForEdges={true}\n      forEventsView={true}\n      {...props}\n    >\n      {\n        <DragAndDropArea focusedEventPath={events_data?.focusedEventPaths}>\n          {{\n            floatingGraph: (\n              <FloatingGraph\n                isOpen={global_data?.floatingGraph.open}\n                customHighChartOptions={dndGraphInitOptions}\n                closeGraphHandler={() => {\n                  dispatch(closeFloatingGraph());\n                }}\n                globalDataFloatingGraph={global_data.floatingGraph}\n                event_data={events_data?.focusedEvent}\n                graphId={global_data?.floatingGraph?.point?.id}\n              />\n            ),\n          }}\n        </DragAndDropArea>\n      }\n    </Map>\n  );\n};\n"],"mappings":"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"}
150
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRedux","_EventsMapContainerHelpers","_actions","_actions2","_actions3","_Map","_FloatingGraph","_interopRequireDefault","_GraphUtils","_actions4","_DragAndDropArea","_EventUtils","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","EventsMapContainer","props","_global_data$floating","_global_data$floating2","dispatch","useDispatch","ReduxState","useSelector","state","areas_data","global_data","points_data","events_data","edges_data","isTimeFilterNotSelected","useMemo","_global_data$activeFi","filters","activeFilter","filter_items","length","index","type","mappedAreas","areasMapper","getActiveTimeFilterPeriod","_global_data$activeFi2","items","activeTimeFilter","selected_options","EventsPerSite","CountEventsPerSiteID","MustSeenSites","focusedEvent","getFocusedEventMustSeenSites","hoveredEvent","mappedPoints","map","point","newPoint","_objectSpread2","undefined","id","isCollectorUnmonitored","hide","relatedEventsAmount","eventsViewHovered","mappedEdges","filter","edge","descendants_has_device","descendants_has_none_collectors","areaToCenterBy","getAreasToCenterBy","useEffect","waterAuthorityId","fetchPoints","fetchEdges","fetchAreas","createElement","Map","assign","areas","points","edges","events","hideEdges","includeUnmonitoredPoints","includeUnmonitoredDescendantsForEdges","forEventsView","focusedEventPath","focusedEventPaths","floatingGraph","isOpen","open","customHighChartOptions","dndGraphInitOptions","closeGraphHandler","closeFloatingGraph","globalDataFloatingGraph","event_data","graphId","exports"],"sources":["../../../../src/pages/EventsPage/EventsMapContainer/EventsMapContainer.tsx"],"sourcesContent":["import React, { useEffect, useMemo } from 'react';\nimport { useDispatch, useSelector } from 'react-redux';\nimport {\n  areasMapper,\n  CountEventsPerSiteID,\n  getAreasToCenterBy,\n  getFocusedEventMustSeenSites,\n} from 'src/pages/EventsPage/EventsMapContainer/EventsMapContainerHelpers';\nimport { fetchAreas } from 'src/store/areas/actions';\nimport { fetchEdges } from 'src/store/edges/actions';\nimport { fetchPoints } from 'src/store/points/actions';\nimport { Map } from 'src/Widgets/Map/Map';\nimport FloatingGraph from 'src/pages/EventsPage/FloatingGraph/FloatingGraph';\nimport { dndGraphInitOptions } from 'src/Widgets/Map/GraphUtils';\nimport { closeFloatingGraph } from 'src/store/global/actions';\nimport DragAndDropArea from '../DragAndDropArea';\nimport { isCollectorUnmonitored } from 'src/Widgets/Map/events/EventUtils';\ninterface EventsMapContainerProps {\n  showSecondMap: boolean;\n}\nexport const EventsMapContainer: React.FC<EventsMapContainerProps> = (\n  props,\n) => {\n  const dispatch = useDispatch();\n  const ReduxState = useSelector((state) => state);\n  const { areas_data, global_data, points_data, events_data, edges_data } =\n    ReduxState;\n\n  const isTimeFilterNotSelected = useMemo(() => {\n    const filters = global_data?.activeFilter?.filter_items;\n\n    if (!filters || filters.length < 1) {\n      return true;\n    }\n\n    for (let index = 0; index < filters.length; index++) {\n      if (filters[index].type === 'TimeFilterItem') {\n        return false;\n      }\n    }\n\n    return true;\n  }, [global_data?.activeFilter]);\n\n  const mappedAreas = useMemo(\n    () => areasMapper(areas_data, isTimeFilterNotSelected),\n    [areas_data, isTimeFilterNotSelected],\n  );\n\n  const getActiveTimeFilterPeriod = () => {\n    const items = global_data?.activeFilter?.filter_items;\n    let activeTimeFilter = '1m';\n\n    if (!items || items.length < 1) {\n      return activeTimeFilter;\n    }\n\n    for (let index = 0; index < items.length; index++) {\n      if (items[index].type === 'TimeFilterItem') {\n        activeTimeFilter = items[index].selected_options[0];\n        break;\n      }\n    }\n    return activeTimeFilter;\n  };\n\n  const EventsPerSite = useMemo(\n    () => CountEventsPerSiteID(events_data.items),\n    [events_data.items],\n  );\n\n  const MustSeenSites = useMemo(() => {\n    if (events_data.focusedEvent) {\n      return getFocusedEventMustSeenSites(events_data.focusedEvent);\n    } else if (events_data.hoveredEvent) {\n      return getFocusedEventMustSeenSites(events_data.hoveredEvent);\n    }\n    return {};\n  }, [EventsPerSite, events_data.focusedEvent, events_data.hoveredEvent]);\n\n  const mappedPoints = useMemo(\n    () =>\n      points_data.items.map((point) => {\n        const newPoint = { ...point };\n\n        if (\n          EventsPerSite === undefined ||\n          !EventsPerSite[point.id] ||\n          isCollectorUnmonitored(point)\n        ) {\n          newPoint.hide = true;\n        }\n\n        if (events_data.focusedEvent) {\n          if (!MustSeenSites[point.id]) {\n            newPoint.hide = true;\n          } else {\n            newPoint.hide = false;\n          }\n        } else if (events_data.hoveredEvent) {\n          if (!MustSeenSites[point.id] && isCollectorUnmonitored(point)) {\n            newPoint.hide = true;\n          } else {\n            newPoint.hide = false;\n          }\n        }\n\n        newPoint.relatedEventsAmount = EventsPerSite\n          ? EventsPerSite[point.id]\n          : 0;\n        newPoint.eventsViewHovered = true;\n        return newPoint;\n      }),\n    [\n      points_data,\n      EventsPerSite,\n      events_data.items,\n      events_data.focusedEvent,\n      events_data.hoveredEvent,\n    ],\n  );\n\n  // eslint-disable-next-line\n  const mappedEdges = edges_data.items.filter(\n    (edge) =>\n      // (Number(EventsPerSite[edge.source_point_id]) > 0 ||\n      // Number(EventsPerSite[edge.target_point_id]) > 0)\n      //  &&\n      edge.descendants_has_device === true ||\n      edge.descendants_has_none_collectors === true,\n  );\n\n  const areaToCenterBy = useMemo(\n    () => getAreasToCenterBy(global_data, mappedAreas),\n    [global_data?.activeFilter, mappedAreas],\n  );\n\n  useEffect(() => {\n    if (global_data.waterAuthorityId) {\n      dispatch(fetchPoints(global_data.waterAuthorityId));\n      dispatch(fetchEdges(global_data.waterAuthorityId));\n      dispatch(\n        fetchAreas(\n          global_data.waterAuthorityId,\n          getActiveTimeFilterPeriod(),\n          true,\n        ),\n      );\n    }\n  }, [global_data.waterAuthorityId, global_data.activeFilter]);\n\n  return (\n    <Map\n      {...ReduxState}\n      areas={mappedAreas}\n      global_data={global_data}\n      points={mappedPoints}\n      edges={mappedEdges}\n      events={events_data.items}\n      focusedEvent={events_data.focusedEvent}\n      hoveredEvent={events_data.hoveredEvent}\n      areaToCenterBy={areaToCenterBy}\n      hideEdges={true}\n      includeUnmonitoredPoints={false}\n      includeUnmonitoredDescendantsForEdges={true}\n      forEventsView={true}\n      {...props}\n    >\n      {\n        <DragAndDropArea focusedEventPath={events_data?.focusedEventPaths}>\n          {{\n            floatingGraph: (\n              <FloatingGraph\n                isOpen={global_data?.floatingGraph.open}\n                customHighChartOptions={dndGraphInitOptions}\n                closeGraphHandler={() => {\n                  dispatch(closeFloatingGraph());\n                }}\n                globalDataFloatingGraph={global_data.floatingGraph}\n                event_data={events_data?.focusedEvent}\n                graphId={global_data?.floatingGraph?.point?.id}\n              />\n            ),\n          }}\n        </DragAndDropArea>\n      }\n    </Map>\n  );\n};\n"],"mappings":"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"}
@@ -67,6 +67,9 @@ var WbeDashboardPage = function WbeDashboardPage() {
67
67
  return 'city';
68
68
  };
69
69
  var query = (0, _useQueryURL.default)();
70
+ var getPathogenName = function getPathogenName(pathogen) {
71
+ return pathogen === 'Covid Hach' ? 'SARS-CoV-2' : pathogen;
72
+ };
70
73
  var getPathogen = function getPathogen() {
71
74
  return query.get('pathogen') || 'covid';
72
75
  };
@@ -342,8 +345,8 @@ var WbeDashboardPage = function WbeDashboardPage() {
342
345
  var pathogenTitle = !isFetchingPathogens && (pathogens === null || pathogens === void 0 ? void 0 : pathogens.find(function (item) {
343
346
  return item.toLowerCase() === selectedPathogen.toLowerCase();
344
347
  })) || '';
345
- var dropDownTitle = pathogenTitle || _i18n.default.t('components.wbe_dashboard.pathogen_not_found');
346
- return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(Content, null, /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("h1", null, "".concat(_i18n.default.t('components.wbe_dashboard.table_name'), " (").concat(pathogenTitle || getPathogen(), ")")), !isFetchingPathogens && pathogens.length === 0 && /*#__PURE__*/_react.default.createElement("h3", null, _i18n.default.t('components.wbe_dashboard.pathogen_not_found')), /*#__PURE__*/_react.default.createElement(ActionsContainer, null, !isFetchingPathogens && pathogens.length > 1 && /*#__PURE__*/_react.default.createElement(_DropdownButton.default, {
348
+ var dropDownTitle = getPathogenName(pathogenTitle) || _i18n.default.t('components.wbe_dashboard.pathogen_not_found');
349
+ return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(Content, null, /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("h1", null, "".concat(_i18n.default.t('components.wbe_dashboard.table_name'), " (").concat(getPathogenName(pathogenTitle) || getPathogenName(getPathogen()), ")")), !isFetchingPathogens && pathogens.length === 0 && /*#__PURE__*/_react.default.createElement("h3", null, _i18n.default.t('components.wbe_dashboard.pathogen_not_found')), /*#__PURE__*/_react.default.createElement(ActionsContainer, null, !isFetchingPathogens && pathogens.length > 1 && /*#__PURE__*/_react.default.createElement(_DropdownButton.default, {
347
350
  id: "dropdown-basic-button",
348
351
  className: 'button button--sort',
349
352
  title: dropDownTitle + ' ',
@@ -358,7 +361,7 @@ var WbeDashboardPage = function WbeDashboardPage() {
358
361
  style: {
359
362
  textAlign: navContext.locale === 'he' ? 'right' : 'left'
360
363
  }
361
- }, pathogen);
364
+ }, getPathogenName(pathogen));
362
365
  })))), /*#__PURE__*/_react.default.createElement(FirstSection, null, /*#__PURE__*/_react.default.createElement(_WbeSummaryBar.WbeSummaryBar, {
363
366
  pathogen: selectedPathogen,
364
367
  waterAuthorityId: waterAuthorityId,
@@ -423,4 +426,4 @@ var Content = _styledComponents.default.div.withConfig({
423
426
  displayName: "WbeDashboardPage__Content",
424
427
  componentId: "sc-14f81cv-5"
425
428
  })(["@media (max-width:576px){padding:20px;}h1{font-weight:bold;}padding:60px 60px;"]);
426
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_i18n","_interopRequireDefault","_reactRedux","_reactRouterDom","_Analytics","_SearchInput","_reactFontawesome","_GraphWrapper","_freeSolidSvgIcons","_actions","_ThousandsToK","_DrillDownIcon","_BaseLevel","_reactDataTableComponent","_nvlStatusHelper","_Map","_KandoTable","_Tabs","_useKandoFetch2","_useQueryURL","_Dropdown","_DropdownButton","_axios","_Truncate","_ExpandableComponent","_Spinner","_WbeSummaryBar","_ErrorBoundary","_theme","_useKandoFetch3","_urls","_useUserTimeZone","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","TABLE_ROWS_PER_PAGE","MAPBOX_WBE_DASHBOARD_STYLE","WbeDashboardPage","getWAId","query","fetchUrl","firstParam","concat","selectedPathogen","pathogensUrl","urls","waterAuthorityId","wbeDashboard","pathogens","url","DEFAULT_TABS","i18n","t","convertTabNameToParam","tab_name","useQueryURL","getPathogen","_useState","useState","_useState2","_slicedToArray2","currentData","setCurrentData","_useState3","_useState4","mapAreas","setMapAreas","_useState5","_useState6","mapZoom","setMapZoom","_useState7","_useState8","rows","setRows","_useState9","_useState10","tabs","setTabs","_useState11","_useState12","selectedTab","setSelectedTab","_useState13","_useState14","setSelectedPathogen","_useKandoFetch","useKandoFetch","data","isFetching","setFetching","_UseKandoFetch","UseKandoFetch","isFetchingPathogens","dispatch","useDispatch","navContext","useSelector","state","nav_context_data","globalData","global_data","isRtl","locale","colorForRow","row","quality","sample_active","isInfected","nvl","userFormat","useUserSelectedDateFormat","columns","React","useMemo","name","selector","sortable","cell","createElement","RowName","className","onClick","handleAreaClick","has_children","ReactComponent","characters","inheritTextAlign","nvl_change","style","direction","color","margin","FontAwesomeIcon","icon","faChevronUp","faChevronDown","last_updated","dayFormatFromTime","GraphWrapper","id","water_authority_id","pathogen","population","kFormatter","parseInt","initializeMapAreas","areas","mappedWithColor","map","a","wbe_dashboard_name","showColorOnlyInBorders","theme","colorScheme","natural","n60","R100","G100","zoomToArea","area","shape_data","undefined","zoomAllAreas","shapeData","datum","levelNVL","history","useHistory","dir","Direction","RTL","LTR","filterResultsAndSetRows","text","results","filter","el","toLowerCase","includes","handleOnRowExpand","expanded","waterAuthorityName","handleSelectPathogenClick","analyticsTrack","utility_name","push","fetchForTabSelection","tab","axios","then","response","responseData","handleTabSelectionClick","initializeDrilledArea","_toConsumableArray2","initializeComponent","updateNavContext","useEffect","pathogenTitle","find","item","dropDownTitle","Fragment","Content","length","ActionsContainer","title","variant","Item","href","textAlign","FirstSection","WbeSummaryBar","SecondSection","SearchInput","onChangeBehavior","Tabs","handleOnClick","MapTableContainer","Spinner","Map","areaToCenterBy","edges","points","mapBoxStyle","KandoTable","onRowExpandToggled","expandableRows","paginationPerPage","rowComponent","ExpandedComponent","expandableRowsComponentProps","defaultSortFieldId","exports","styled","div","withConfig","displayName","componentId","p"],"sources":["../../../src/pages/WbeDashboard/WbeDashboardPage.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react';\nimport i18n from 'src/utilities/i18n';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { useHistory } from 'react-router-dom';\nimport { analyticsTrack } from '../../utilities/Analytics';\nimport { SearchInput } from './SearchInput';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { GraphWrapper } from './GraphWrapper';\nimport { faChevronDown, faChevronUp } from '@fortawesome/free-solid-svg-icons';\nimport { appReducer } from '../../store/rootReducer';\nimport { updateNavContext } from '../../store/context/actions';\nimport { kFormatter } from '../../utilities/ThousandsToK';\nimport { ReactComponent as DrillDownIcon } from './DrillDownIcon.svg';\nimport { ReactComponent as BaseLevel } from './BaseLevel.svg';\nimport { Direction } from 'react-data-table-component';\nimport { levelNVL } from '../CovidPage/components/nvlStatusHelper';\nimport { Map } from '../../Widgets/Map/Map';\nimport { KandoTable } from 'src/ui-kit/KandoTable/KandoTable';\nimport { Tabs } from './Tabs';\nimport useKandoFetch from '../../hooks/useKandoFetch';\nimport useQueryURL from '../../hooks/useQueryURL';\nimport styled from 'styled-components/macro';\nimport Dropdown from 'react-bootstrap/cjs/Dropdown';\nimport DropdownButton from 'react-bootstrap/cjs/DropdownButton';\nimport axios from 'axios';\nimport Truncate from '../../utilities/Truncate';\nimport { ExpandedComponent } from './ExpandableComponent';\nimport { Spinner } from '../../components/Spinner/Spinner';\nimport { WbeSummaryBar } from './WbeSummaryBar';\nimport ErrorBoundary from '../../utilities/ErrorBoundary';\nimport { theme } from '../../styles/theme/theme';\nimport UseKandoFetch from 'src/hooks/useKandoFetch';\nimport { urls } from 'src/utilities/urls';\nimport {\n  dayFormatFromTime,\n  useUserSelectedDateFormat,\n} from 'src/hooks/useUserTimeZone';\nconst TABLE_ROWS_PER_PAGE = 25;\nconst MAPBOX_WBE_DASHBOARD_STYLE = 'ckzzkjsi7005f14o9im0mczs9';\n\nexport const WbeDashboardPage = () => {\n  const getWAId = () => {\n    return query.get('water_authority_id');\n  };\n  const fetchUrl = (firstParam) => {\n    return `/api_ui/wbe_dashboard/${selectedPathogen}/${firstParam}?water_authority_id=${getWAId()}`;\n  };\n  const pathogensUrl = () =>\n    urls({ waterAuthorityId: getWAId() }).wbeDashboard.pathogens.url;\n  const DEFAULT_TABS = [\n    i18n.t('components.wbe_dashboard.cities'),\n    i18n.t('components.wbe_dashboard.monitored_areas'),\n  ];\n  const convertTabNameToParam = (tab_name: string) => {\n    if (tab_name === i18n.t('components.wbe_dashboard.cities')) {\n      return 'city';\n    } else if (\n      tab_name === i18n.t('components.wbe_dashboard.monitored_areas')\n    ) {\n      return 'monitored';\n    }\n\n    return 'city';\n  };\n  const query = useQueryURL();\n  const getPathogen = () => {\n    return query.get('pathogen') || 'covid';\n  };\n\n  const [currentData, setCurrentData] = useState([]);\n  const [mapAreas, setMapAreas] = useState<any[]>([]);\n  const [mapZoom, setMapZoom] = useState<any[]>([]);\n  const [rows, setRows] = useState<any>([]);\n  const [tabs, setTabs] = useState<string[]>(DEFAULT_TABS);\n  const [selectedTab, setSelectedTab] = useState<string>(tabs[0]);\n  const [selectedPathogen, setSelectedPathogen] = useState<string>(\n    getPathogen(),\n  );\n  const { data, isFetching, setFetching } = useKandoFetch(\n    fetchUrl(convertTabNameToParam(selectedTab)),\n  );\n  const { data: pathogens, isFetching: isFetchingPathogens } = UseKandoFetch(\n    pathogensUrl(),\n  );\n\n  const dispatch = useDispatch();\n  const navContext = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.nav_context_data.navContext,\n  );\n  const globalData = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.global_data,\n  );\n  const isRtl: boolean = navContext.locale === 'he' ? true : false;\n  const colorForRow = (row) => {\n    let quality;\n    if (!row.sample_active) {\n      quality = 'inactive-sampling';\n    } else if (isInfected(row.nvl)) {\n      quality = 'infected';\n    } else {\n      quality = 'clean';\n    }\n\n    return `row_name--${quality}`;\n  };\n\n  const userFormat = useUserSelectedDateFormat();\n  const columns: any = React.useMemo(\n    () => [\n      {\n        name: i18n.t('components.wbe_dashboard.name'),\n        selector: (row) => row.name,\n        sortable: true,\n        cell: (row: { name: string; nvl: number; has_children: boolean }) => (\n          <RowName isRtl={isRtl}>\n            <div\n              data-tag=\"allowRowEvents\"\n              className={`row_name ${colorForRow(row)}`}\n              onClick={() => {\n                handleAreaClick(row);\n              }}\n            >\n              <div className={'expandable-icon'}>\n                <span>\n                  {row.has_children && <DrillDownIcon />}\n                  {!row.has_children && <BaseLevel />}\n                </span>\n              </div>\n              <span className={'name'}>\n                <Truncate characters={3} inheritTextAlign={true}>\n                  {row.name}\n                </Truncate>\n              </span>\n            </div>\n          </RowName>\n        ),\n      },\n      {\n        name: i18n.t('components.wbe_dashboard.nvl_score'),\n        selector: (row) => row.nvl,\n        sortable: true,\n        cell: (row: { nvl: number }) => (\n          <div data-tag=\"allowRowEvents\">{row.nvl}</div>\n        ),\n      },\n      {\n        name: i18n.t('components.wbe_dashboard.percentage_from_last_sampling'),\n        selector: (row) => row.nvl_change,\n        sortable: true,\n        cell: (row: { nvl_change: number }) => (\n          <div\n            data-tag=\"allowRowEvents\"\n            style={{\n              direction: 'ltr',\n            }}\n          >\n            <span style={{ color: '#000000', margin: '0 6px' }}>\n              {row.nvl_change}%\n            </span>\n\n            {\n              <FontAwesomeIcon\n                icon={row.nvl_change > 0 ? faChevronUp : faChevronDown}\n              />\n            }\n          </div>\n        ),\n      },\n      {\n        name: i18n.t('components.wbe_dashboard.last_sampled'),\n        selector: 'last_sampled',\n        sortable: (row) => row.last_updated,\n        cell: (row: { last_updated: string }) => (\n          <div data-tag=\"allowRowEvents\">\n            {row.last_updated === null\n              ? '-'\n              : dayFormatFromTime(row.last_updated, userFormat)}\n          </div>\n        ),\n      },\n      {\n        name: i18n.t('components.wbe_dashboard.trend_graph'),\n        selector: 'trend_graph',\n        sortable: true,\n        cell: (row: { id: number }) => (\n          <div data-tag=\"allowRowEvents\">\n            <GraphWrapper\n              key={row.id}\n              row={row}\n              water_authority_id={getWAId()}\n              pathogen={selectedPathogen}\n            />\n          </div>\n        ),\n      },\n      {\n        name: i18n.t('components.wbe_dashboard.population'),\n        selector: (row) => row.population,\n        sortable: true,\n        cell: (row: { population: string }) => (\n          <div data-tag=\"allowRowEvents\">\n            {kFormatter(parseInt(row.population))}\n          </div>\n        ),\n      },\n    ],\n    [isRtl, selectedPathogen, userFormat],\n  );\n\n  const initializeMapAreas = (areas) => {\n    const mappedWithColor = areas.map((a: any) => {\n      a.wbe_dashboard_name = a.name;\n      a.showColorOnlyInBorders = true;\n\n      if (!a.sample_active) {\n        a.color = theme.colorScheme.natural.n60;\n        return a;\n      }\n\n      if (isInfected(a.nvl)) {\n        a.color = theme.colorScheme.data.R100;\n        return a;\n      } else {\n        a.color = theme.colorScheme.data.G100;\n        return a;\n      }\n    });\n\n    setMapAreas(mappedWithColor);\n  };\n\n  const zoomToArea = (area) => {\n    area.shape_data !== undefined && setMapZoom(area.shape_data);\n  };\n\n  const zoomAllAreas = (data) => {\n    const shapeData = data.map((datum) => {\n      return datum.shape_data;\n    });\n\n    setMapZoom(shapeData);\n  };\n\n  const isInfected = (nvl: number) => {\n    if (levelNVL(nvl) === 'clean') {\n      return false;\n    } else if (\n      levelNVL(nvl) === 'low' ||\n      levelNVL(nvl) === 'medium' ||\n      levelNVL(nvl) === 'high'\n    ) {\n      return true;\n    }\n\n    return;\n  };\n  const history = useHistory();\n  const waterAuthorityId = useSelector(\n    (state: ReturnType<typeof appReducer>) =>\n      state.global_data.waterAuthorityId,\n  );\n\n  const dir: Direction =\n    navContext.locale === 'he' ? Direction.RTL : Direction.LTR;\n\n  const filterResultsAndSetRows = (text: string) => {\n    let results = currentData.filter(function (el: any) {\n      return el.name.toLowerCase().includes(text.toLowerCase());\n    });\n\n    setRows(results);\n  };\n\n  const handleOnRowExpand = (expanded, row) => {\n    expanded && zoomToArea(row);\n    !expanded && zoomAllAreas(data);\n  };\n\n  const waterAuthorityName = useSelector(\n    (state) => state.global_data.waterAuthorityName,\n  );\n\n  const handleSelectPathogenClick = (pathogen) => {\n    analyticsTrack('WBE Status Report - Pathogen change clicked', {\n      pathogen: pathogen,\n      utility_name: waterAuthorityName,\n    });\n    setSelectedPathogen(pathogen);\n    history.push(\n      `/wbe_dashboard/index?locale=${navContext.locale}&water_authority_id=${waterAuthorityId}&pathogen=${pathogen}`,\n    );\n  };\n\n  const fetchForTabSelection = (tab) => {\n    setFetching(true);\n    axios.get(fetchUrl(tab)).then((response) => {\n      let responseData = response.data.data;\n\n      setFetching(false);\n      setTabs(DEFAULT_TABS);\n      setRows(responseData);\n      setCurrentData(responseData);\n      initializeMapAreas(responseData);\n      zoomAllAreas(responseData);\n    });\n  };\n\n  const handleTabSelectionClick = (tab) => {\n    if (!isFetching) {\n      setSelectedTab(tab);\n\n      if (tab !== i18n.t('components.wbe_dashboard.custom')) {\n        tab =\n          tab === i18n.t('components.wbe_dashboard.cities')\n            ? 'city'\n            : tab === i18n.t('components.wbe_dashboard.monitored_areas')\n            ? 'monitored'\n            : '';\n\n        fetchForTabSelection(tab);\n      }\n    }\n  };\n\n  const initializeDrilledArea = (response) => {\n    let data = response.data.data;\n    setRows(data);\n    setCurrentData(data);\n    initializeMapAreas(data);\n    zoomAllAreas(data);\n  };\n\n  const handleAreaClick = (area) => {\n    zoomToArea(area);\n\n    if (area.has_children) {\n      setTabs([...tabs, i18n.t('components.wbe_dashboard.custom')]);\n      setSelectedTab(i18n.t('components.wbe_dashboard.custom'));\n\n      axios.get(fetchUrl(area.id)).then((response) => {\n        initializeDrilledArea(response);\n      });\n    }\n  };\n\n  const initializeComponent = () => {\n    setCurrentData(data);\n    setRows(data);\n    analyticsTrack('WBE Status Report', {\n      utility_name: waterAuthorityName,\n    });\n    dispatch(updateNavContext({ name: 'wbe_dashboard' }));\n\n    axios.get(fetchUrl('monitored')).then((response) => {\n      let data = response.data.data;\n\n      initializeMapAreas(data);\n      zoomAllAreas(data);\n    });\n  };\n\n  useEffect(() => {\n    if (!isFetching && data !== null) {\n      initializeComponent();\n    }\n  }, [isFetching, selectedPathogen, data]);\n\n  const pathogenTitle =\n    (!isFetchingPathogens &&\n      pathogens?.find(\n        (item) => item.toLowerCase() === selectedPathogen.toLowerCase(),\n      )) ||\n    '';\n  const dropDownTitle =\n    pathogenTitle || i18n.t('components.wbe_dashboard.pathogen_not_found');\n\n  return (\n    <>\n      <Content>\n        <div>\n          <h1>\n            {`${i18n.t('components.wbe_dashboard.table_name')} (${\n              pathogenTitle || getPathogen()\n            })`}\n          </h1>\n          {!isFetchingPathogens && pathogens.length === 0 && (\n            <h3>{i18n.t('components.wbe_dashboard.pathogen_not_found')}</h3>\n          )}\n          <ActionsContainer>\n            {!isFetchingPathogens && pathogens.length > 1 && (\n              <DropdownButton\n                id=\"dropdown-basic-button\"\n                className={'button button--sort'}\n                title={dropDownTitle + ' '}\n                variant=\"secondary\"\n              >\n                {pathogens.map((pathogen) => {\n                  return (\n                    <Dropdown.Item\n                      key={pathogen}\n                      href=\"#\"\n                      onClick={() => handleSelectPathogenClick(pathogen)}\n                      style={{\n                        textAlign:\n                          navContext.locale === 'he' ? 'right' : 'left',\n                      }}\n                    >\n                      {pathogen}\n                    </Dropdown.Item>\n                  );\n                })}\n              </DropdownButton>\n            )}\n          </ActionsContainer>\n        </div>\n        <FirstSection>\n          <WbeSummaryBar\n            pathogen={selectedPathogen}\n            waterAuthorityId={waterAuthorityId}\n            isRtl={isRtl}\n          />\n        </FirstSection>\n\n        <SecondSection>\n          <SearchInput onChangeBehavior={filterResultsAndSetRows} />\n          <div className={'tabs-container'}>\n            <Tabs\n              tabs={tabs}\n              selectedTab={selectedTab}\n              handleOnClick={handleTabSelectionClick}\n            />\n          </div>\n          <MapTableContainer isRtl={isRtl}>\n            {isFetching && <Spinner />}\n            <div className={'map-container'}>\n              {!isFetching && rows !== null && mapZoom !== null && (\n                <ErrorBoundary>\n                  <Map\n                    areas={mapAreas}\n                    areaToCenterBy={mapZoom}\n                    edges={[]}\n                    points={[]}\n                    global_data={globalData}\n                    mapBoxStyle={MAPBOX_WBE_DASHBOARD_STYLE}\n                  />\n                </ErrorBoundary>\n              )}\n            </div>\n            {!isFetching && rows !== null && (\n              <KandoTable\n                onRowExpandToggled={handleOnRowExpand}\n                data={rows}\n                columns={columns}\n                direction={dir}\n                expandableRows={true}\n                paginationPerPage={TABLE_ROWS_PER_PAGE}\n                rowComponent={ExpandedComponent}\n                expandableRowsComponentProps={{ pathogen: selectedPathogen }}\n                defaultSortFieldId={3}\n              />\n            )}\n          </MapTableContainer>\n        </SecondSection>\n      </Content>\n    </>\n  );\n};\n\nconst RowName = styled.div<{ isRtl: boolean }>`\n    width: 100%;\n      \n    .row_name {\n      .expandable-icon {\n        width: 30px;\n        height: 30px;\n        transition: .2s ease-in;      \n        border-radius: 4px;\n        display: flex;\n        align-items: center;\n        padding: 0 4px;\n        \n        span {\n          margin-inline-start: 2px;\n        }\n      }\n        \n        &--clean {\n         color: #27a63a; \n         .expandable-icon {\n            background: #27a63a;        \n          }\n        }\n        \n        &--infected {\n          color: #e10036;\n          .expandable-icon {\n            background: #e10036;        \n          }\n        }\n        \n        &--inactive-sampling {\n          color: ${theme.colorScheme.natural.n60};\n          .expandable-icon {\n            background: ${theme.colorScheme.natural.n60};        \n          }\n        }\n        \n        .name {\n          position: absolute;\n          font-weight: 100;\n          ${(p) => (p.isRtl ? 'right: 51px;' : 'left: 51px;')}\n          top: 16px;\n          width: 7.5em;\n          margin-inline-start: 3px;\n        }\n      }\n    }\n  `;\n\nconst ActionsContainer = styled.div`\n  display: flex;\n  justify-content: start;\n  align-items: center;\n`;\n\nconst FirstSection = styled.div`\n  margin: 85px 0 20px 0;\n`;\n\nconst SecondSection = styled.div`\n  padding: 20px;\n  background: #fcfcfc;\n  border: 1px solid #e7e7e7;\n  border-radius: 6px;\n`;\n\nconst MapTableContainer = styled.div<{ isRtl: boolean }>`\n  display: flex;\n  justify-content: start;\n  flex-direction: row-reverse;\n  .map-container {\n    width: unset !important;\n    .event-timerange {\n      display: none;\n    }\n    #map {\n      height: 69vh;\n      width: 30vw;\n    }\n  }\n  [data-testid='kando-table'] {\n    width: 100%;\n  }\n  [data-column-id='1'] {\n    justify-content: flex-start !important;\n    overflow: visible;\n    position: relative;\n    cursor: pointer;\n    &:hover {\n      .name {\n        color: white !important;\n      }\n      .expandable-icon {\n        width: calc(120px + 1vw);\n        transition: 0.2s cubic-bezier(0.65, 0.05, 0.36, 1);\n      }\n    }\n  }\n\n  .spinner-container {\n    width: 100%;\n    display: flex;\n    justify-content: center;\n  }\n`;\n\nconst Content = styled.div`\n  @media (max-width: 576px) {\n    padding: 20px;\n  }\n\n  h1 {\n    font-weight: bold;\n  }\n\n  padding: 60px 60px;\n`;\n"],"mappings":"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"}
429
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_i18n","_interopRequireDefault","_reactRedux","_reactRouterDom","_Analytics","_SearchInput","_reactFontawesome","_GraphWrapper","_freeSolidSvgIcons","_actions","_ThousandsToK","_DrillDownIcon","_BaseLevel","_reactDataTableComponent","_nvlStatusHelper","_Map","_KandoTable","_Tabs","_useKandoFetch2","_useQueryURL","_Dropdown","_DropdownButton","_axios","_Truncate","_ExpandableComponent","_Spinner","_WbeSummaryBar","_ErrorBoundary","_theme","_useKandoFetch3","_urls","_useUserTimeZone","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","TABLE_ROWS_PER_PAGE","MAPBOX_WBE_DASHBOARD_STYLE","WbeDashboardPage","getWAId","query","fetchUrl","firstParam","concat","selectedPathogen","pathogensUrl","urls","waterAuthorityId","wbeDashboard","pathogens","url","DEFAULT_TABS","i18n","t","convertTabNameToParam","tab_name","useQueryURL","getPathogenName","pathogen","getPathogen","_useState","useState","_useState2","_slicedToArray2","currentData","setCurrentData","_useState3","_useState4","mapAreas","setMapAreas","_useState5","_useState6","mapZoom","setMapZoom","_useState7","_useState8","rows","setRows","_useState9","_useState10","tabs","setTabs","_useState11","_useState12","selectedTab","setSelectedTab","_useState13","_useState14","setSelectedPathogen","_useKandoFetch","useKandoFetch","data","isFetching","setFetching","_UseKandoFetch","UseKandoFetch","isFetchingPathogens","dispatch","useDispatch","navContext","useSelector","state","nav_context_data","globalData","global_data","isRtl","locale","colorForRow","row","quality","sample_active","isInfected","nvl","userFormat","useUserSelectedDateFormat","columns","React","useMemo","name","selector","sortable","cell","createElement","RowName","className","onClick","handleAreaClick","has_children","ReactComponent","characters","inheritTextAlign","nvl_change","style","direction","color","margin","FontAwesomeIcon","icon","faChevronUp","faChevronDown","last_updated","dayFormatFromTime","GraphWrapper","id","water_authority_id","population","kFormatter","parseInt","initializeMapAreas","areas","mappedWithColor","map","a","wbe_dashboard_name","showColorOnlyInBorders","theme","colorScheme","natural","n60","R100","G100","zoomToArea","area","shape_data","undefined","zoomAllAreas","shapeData","datum","levelNVL","history","useHistory","dir","Direction","RTL","LTR","filterResultsAndSetRows","text","results","filter","el","toLowerCase","includes","handleOnRowExpand","expanded","waterAuthorityName","handleSelectPathogenClick","analyticsTrack","utility_name","push","fetchForTabSelection","tab","axios","then","response","responseData","handleTabSelectionClick","initializeDrilledArea","_toConsumableArray2","initializeComponent","updateNavContext","useEffect","pathogenTitle","find","item","dropDownTitle","Fragment","Content","length","ActionsContainer","title","variant","Item","href","textAlign","FirstSection","WbeSummaryBar","SecondSection","SearchInput","onChangeBehavior","Tabs","handleOnClick","MapTableContainer","Spinner","Map","areaToCenterBy","edges","points","mapBoxStyle","KandoTable","onRowExpandToggled","expandableRows","paginationPerPage","rowComponent","ExpandedComponent","expandableRowsComponentProps","defaultSortFieldId","exports","styled","div","withConfig","displayName","componentId","p"],"sources":["../../../src/pages/WbeDashboard/WbeDashboardPage.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react';\nimport i18n from 'src/utilities/i18n';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { useHistory } from 'react-router-dom';\nimport { analyticsTrack } from '../../utilities/Analytics';\nimport { SearchInput } from './SearchInput';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { GraphWrapper } from './GraphWrapper';\nimport { faChevronDown, faChevronUp } from '@fortawesome/free-solid-svg-icons';\nimport { appReducer } from '../../store/rootReducer';\nimport { updateNavContext } from '../../store/context/actions';\nimport { kFormatter } from '../../utilities/ThousandsToK';\nimport { ReactComponent as DrillDownIcon } from './DrillDownIcon.svg';\nimport { ReactComponent as BaseLevel } from './BaseLevel.svg';\nimport { Direction } from 'react-data-table-component';\nimport { levelNVL } from '../CovidPage/components/nvlStatusHelper';\nimport { Map } from '../../Widgets/Map/Map';\nimport { KandoTable } from 'src/ui-kit/KandoTable/KandoTable';\nimport { Tabs } from './Tabs';\nimport useKandoFetch from '../../hooks/useKandoFetch';\nimport useQueryURL from '../../hooks/useQueryURL';\nimport styled from 'styled-components/macro';\nimport Dropdown from 'react-bootstrap/cjs/Dropdown';\nimport DropdownButton from 'react-bootstrap/cjs/DropdownButton';\nimport axios from 'axios';\nimport Truncate from '../../utilities/Truncate';\nimport { ExpandedComponent } from './ExpandableComponent';\nimport { Spinner } from '../../components/Spinner/Spinner';\nimport { WbeSummaryBar } from './WbeSummaryBar';\nimport ErrorBoundary from '../../utilities/ErrorBoundary';\nimport { theme } from '../../styles/theme/theme';\nimport UseKandoFetch from 'src/hooks/useKandoFetch';\nimport { urls } from 'src/utilities/urls';\nimport {\n  dayFormatFromTime,\n  useUserSelectedDateFormat,\n} from 'src/hooks/useUserTimeZone';\nconst TABLE_ROWS_PER_PAGE = 25;\nconst MAPBOX_WBE_DASHBOARD_STYLE = 'ckzzkjsi7005f14o9im0mczs9';\n\nexport const WbeDashboardPage = () => {\n  const getWAId = () => {\n    return query.get('water_authority_id');\n  };\n  const fetchUrl = (firstParam) => {\n    return `/api_ui/wbe_dashboard/${selectedPathogen}/${firstParam}?water_authority_id=${getWAId()}`;\n  };\n  const pathogensUrl = () =>\n    urls({ waterAuthorityId: getWAId() }).wbeDashboard.pathogens.url;\n  const DEFAULT_TABS = [\n    i18n.t('components.wbe_dashboard.cities'),\n    i18n.t('components.wbe_dashboard.monitored_areas'),\n  ];\n  const convertTabNameToParam = (tab_name: string) => {\n    if (tab_name === i18n.t('components.wbe_dashboard.cities')) {\n      return 'city';\n    } else if (\n      tab_name === i18n.t('components.wbe_dashboard.monitored_areas')\n    ) {\n      return 'monitored';\n    }\n\n    return 'city';\n  };\n  const query = useQueryURL();\n\n  const getPathogenName = (pathogen) => {\n    return pathogen === 'Covid Hach' ? 'SARS-CoV-2' : pathogen;\n  };\n\n  const getPathogen = () => {\n    return query.get('pathogen') || 'covid';\n  };\n\n  const [currentData, setCurrentData] = useState([]);\n  const [mapAreas, setMapAreas] = useState<any[]>([]);\n  const [mapZoom, setMapZoom] = useState<any[]>([]);\n  const [rows, setRows] = useState<any>([]);\n  const [tabs, setTabs] = useState<string[]>(DEFAULT_TABS);\n  const [selectedTab, setSelectedTab] = useState<string>(tabs[0]);\n  const [selectedPathogen, setSelectedPathogen] = useState<string>(\n    getPathogen(),\n  );\n  const { data, isFetching, setFetching } = useKandoFetch(\n    fetchUrl(convertTabNameToParam(selectedTab)),\n  );\n  const { data: pathogens, isFetching: isFetchingPathogens } = UseKandoFetch(\n    pathogensUrl(),\n  );\n\n  const dispatch = useDispatch();\n  const navContext = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.nav_context_data.navContext,\n  );\n  const globalData = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.global_data,\n  );\n  const isRtl: boolean = navContext.locale === 'he' ? true : false;\n  const colorForRow = (row) => {\n    let quality;\n    if (!row.sample_active) {\n      quality = 'inactive-sampling';\n    } else if (isInfected(row.nvl)) {\n      quality = 'infected';\n    } else {\n      quality = 'clean';\n    }\n\n    return `row_name--${quality}`;\n  };\n\n  const userFormat = useUserSelectedDateFormat();\n  const columns: any = React.useMemo(\n    () => [\n      {\n        name: i18n.t('components.wbe_dashboard.name'),\n        selector: (row) => row.name,\n        sortable: true,\n        cell: (row: { name: string; nvl: number; has_children: boolean }) => (\n          <RowName isRtl={isRtl}>\n            <div\n              data-tag=\"allowRowEvents\"\n              className={`row_name ${colorForRow(row)}`}\n              onClick={() => {\n                handleAreaClick(row);\n              }}\n            >\n              <div className={'expandable-icon'}>\n                <span>\n                  {row.has_children && <DrillDownIcon />}\n                  {!row.has_children && <BaseLevel />}\n                </span>\n              </div>\n              <span className={'name'}>\n                <Truncate characters={3} inheritTextAlign={true}>\n                  {row.name}\n                </Truncate>\n              </span>\n            </div>\n          </RowName>\n        ),\n      },\n      {\n        name: i18n.t('components.wbe_dashboard.nvl_score'),\n        selector: (row) => row.nvl,\n        sortable: true,\n        cell: (row: { nvl: number }) => (\n          <div data-tag=\"allowRowEvents\">{row.nvl}</div>\n        ),\n      },\n      {\n        name: i18n.t('components.wbe_dashboard.percentage_from_last_sampling'),\n        selector: (row) => row.nvl_change,\n        sortable: true,\n        cell: (row: { nvl_change: number }) => (\n          <div\n            data-tag=\"allowRowEvents\"\n            style={{\n              direction: 'ltr',\n            }}\n          >\n            <span style={{ color: '#000000', margin: '0 6px' }}>\n              {row.nvl_change}%\n            </span>\n\n            {\n              <FontAwesomeIcon\n                icon={row.nvl_change > 0 ? faChevronUp : faChevronDown}\n              />\n            }\n          </div>\n        ),\n      },\n      {\n        name: i18n.t('components.wbe_dashboard.last_sampled'),\n        selector: 'last_sampled',\n        sortable: (row) => row.last_updated,\n        cell: (row: { last_updated: string }) => (\n          <div data-tag=\"allowRowEvents\">\n            {row.last_updated === null\n              ? '-'\n              : dayFormatFromTime(row.last_updated, userFormat)}\n          </div>\n        ),\n      },\n      {\n        name: i18n.t('components.wbe_dashboard.trend_graph'),\n        selector: 'trend_graph',\n        sortable: true,\n        cell: (row: { id: number }) => (\n          <div data-tag=\"allowRowEvents\">\n            <GraphWrapper\n              key={row.id}\n              row={row}\n              water_authority_id={getWAId()}\n              pathogen={selectedPathogen}\n            />\n          </div>\n        ),\n      },\n      {\n        name: i18n.t('components.wbe_dashboard.population'),\n        selector: (row) => row.population,\n        sortable: true,\n        cell: (row: { population: string }) => (\n          <div data-tag=\"allowRowEvents\">\n            {kFormatter(parseInt(row.population))}\n          </div>\n        ),\n      },\n    ],\n    [isRtl, selectedPathogen, userFormat],\n  );\n\n  const initializeMapAreas = (areas) => {\n    const mappedWithColor = areas.map((a: any) => {\n      a.wbe_dashboard_name = a.name;\n      a.showColorOnlyInBorders = true;\n\n      if (!a.sample_active) {\n        a.color = theme.colorScheme.natural.n60;\n        return a;\n      }\n\n      if (isInfected(a.nvl)) {\n        a.color = theme.colorScheme.data.R100;\n        return a;\n      } else {\n        a.color = theme.colorScheme.data.G100;\n        return a;\n      }\n    });\n\n    setMapAreas(mappedWithColor);\n  };\n\n  const zoomToArea = (area) => {\n    area.shape_data !== undefined && setMapZoom(area.shape_data);\n  };\n\n  const zoomAllAreas = (data) => {\n    const shapeData = data.map((datum) => {\n      return datum.shape_data;\n    });\n\n    setMapZoom(shapeData);\n  };\n\n  const isInfected = (nvl: number) => {\n    if (levelNVL(nvl) === 'clean') {\n      return false;\n    } else if (\n      levelNVL(nvl) === 'low' ||\n      levelNVL(nvl) === 'medium' ||\n      levelNVL(nvl) === 'high'\n    ) {\n      return true;\n    }\n\n    return;\n  };\n  const history = useHistory();\n  const waterAuthorityId = useSelector(\n    (state: ReturnType<typeof appReducer>) =>\n      state.global_data.waterAuthorityId,\n  );\n\n  const dir: Direction =\n    navContext.locale === 'he' ? Direction.RTL : Direction.LTR;\n\n  const filterResultsAndSetRows = (text: string) => {\n    let results = currentData.filter(function (el: any) {\n      return el.name.toLowerCase().includes(text.toLowerCase());\n    });\n\n    setRows(results);\n  };\n\n  const handleOnRowExpand = (expanded, row) => {\n    expanded && zoomToArea(row);\n    !expanded && zoomAllAreas(data);\n  };\n\n  const waterAuthorityName = useSelector(\n    (state) => state.global_data.waterAuthorityName,\n  );\n\n  const handleSelectPathogenClick = (pathogen) => {\n    analyticsTrack('WBE Status Report - Pathogen change clicked', {\n      pathogen: pathogen,\n      utility_name: waterAuthorityName,\n    });\n    setSelectedPathogen(pathogen);\n    history.push(\n      `/wbe_dashboard/index?locale=${navContext.locale}&water_authority_id=${waterAuthorityId}&pathogen=${pathogen}`,\n    );\n  };\n\n  const fetchForTabSelection = (tab) => {\n    setFetching(true);\n    axios.get(fetchUrl(tab)).then((response) => {\n      let responseData = response.data.data;\n\n      setFetching(false);\n      setTabs(DEFAULT_TABS);\n      setRows(responseData);\n      setCurrentData(responseData);\n      initializeMapAreas(responseData);\n      zoomAllAreas(responseData);\n    });\n  };\n\n  const handleTabSelectionClick = (tab) => {\n    if (!isFetching) {\n      setSelectedTab(tab);\n\n      if (tab !== i18n.t('components.wbe_dashboard.custom')) {\n        tab =\n          tab === i18n.t('components.wbe_dashboard.cities')\n            ? 'city'\n            : tab === i18n.t('components.wbe_dashboard.monitored_areas')\n            ? 'monitored'\n            : '';\n\n        fetchForTabSelection(tab);\n      }\n    }\n  };\n\n  const initializeDrilledArea = (response) => {\n    let data = response.data.data;\n    setRows(data);\n    setCurrentData(data);\n    initializeMapAreas(data);\n    zoomAllAreas(data);\n  };\n\n  const handleAreaClick = (area) => {\n    zoomToArea(area);\n\n    if (area.has_children) {\n      setTabs([...tabs, i18n.t('components.wbe_dashboard.custom')]);\n      setSelectedTab(i18n.t('components.wbe_dashboard.custom'));\n\n      axios.get(fetchUrl(area.id)).then((response) => {\n        initializeDrilledArea(response);\n      });\n    }\n  };\n\n  const initializeComponent = () => {\n    setCurrentData(data);\n    setRows(data);\n    analyticsTrack('WBE Status Report', {\n      utility_name: waterAuthorityName,\n    });\n    dispatch(updateNavContext({ name: 'wbe_dashboard' }));\n\n    axios.get(fetchUrl('monitored')).then((response) => {\n      let data = response.data.data;\n\n      initializeMapAreas(data);\n      zoomAllAreas(data);\n    });\n  };\n\n  useEffect(() => {\n    if (!isFetching && data !== null) {\n      initializeComponent();\n    }\n  }, [isFetching, selectedPathogen, data]);\n\n  const pathogenTitle =\n    (!isFetchingPathogens &&\n      pathogens?.find(\n        (item) => item.toLowerCase() === selectedPathogen.toLowerCase(),\n      )) ||\n    '';\n  const dropDownTitle =\n    getPathogenName(pathogenTitle) ||\n    i18n.t('components.wbe_dashboard.pathogen_not_found');\n\n  return (\n    <>\n      <Content>\n        <div>\n          <h1>\n            {`${i18n.t('components.wbe_dashboard.table_name')} (${\n              getPathogenName(pathogenTitle) || getPathogenName(getPathogen())\n            })`}\n          </h1>\n          {!isFetchingPathogens && pathogens.length === 0 && (\n            <h3>{i18n.t('components.wbe_dashboard.pathogen_not_found')}</h3>\n          )}\n          <ActionsContainer>\n            {!isFetchingPathogens && pathogens.length > 1 && (\n              <DropdownButton\n                id=\"dropdown-basic-button\"\n                className={'button button--sort'}\n                title={dropDownTitle + ' '}\n                variant=\"secondary\"\n              >\n                {pathogens.map((pathogen) => {\n                  return (\n                    <Dropdown.Item\n                      key={pathogen}\n                      href=\"#\"\n                      onClick={() => handleSelectPathogenClick(pathogen)}\n                      style={{\n                        textAlign:\n                          navContext.locale === 'he' ? 'right' : 'left',\n                      }}\n                    >\n                      {getPathogenName(pathogen)}\n                    </Dropdown.Item>\n                  );\n                })}\n              </DropdownButton>\n            )}\n          </ActionsContainer>\n        </div>\n        <FirstSection>\n          <WbeSummaryBar\n            pathogen={selectedPathogen}\n            waterAuthorityId={waterAuthorityId}\n            isRtl={isRtl}\n          />\n        </FirstSection>\n\n        <SecondSection>\n          <SearchInput onChangeBehavior={filterResultsAndSetRows} />\n          <div className={'tabs-container'}>\n            <Tabs\n              tabs={tabs}\n              selectedTab={selectedTab}\n              handleOnClick={handleTabSelectionClick}\n            />\n          </div>\n          <MapTableContainer isRtl={isRtl}>\n            {isFetching && <Spinner />}\n            <div className={'map-container'}>\n              {!isFetching && rows !== null && mapZoom !== null && (\n                <ErrorBoundary>\n                  <Map\n                    areas={mapAreas}\n                    areaToCenterBy={mapZoom}\n                    edges={[]}\n                    points={[]}\n                    global_data={globalData}\n                    mapBoxStyle={MAPBOX_WBE_DASHBOARD_STYLE}\n                  />\n                </ErrorBoundary>\n              )}\n            </div>\n            {!isFetching && rows !== null && (\n              <KandoTable\n                onRowExpandToggled={handleOnRowExpand}\n                data={rows}\n                columns={columns}\n                direction={dir}\n                expandableRows={true}\n                paginationPerPage={TABLE_ROWS_PER_PAGE}\n                rowComponent={ExpandedComponent}\n                expandableRowsComponentProps={{ pathogen: selectedPathogen }}\n                defaultSortFieldId={3}\n              />\n            )}\n          </MapTableContainer>\n        </SecondSection>\n      </Content>\n    </>\n  );\n};\n\nconst RowName = styled.div<{ isRtl: boolean }>`\n    width: 100%;\n      \n    .row_name {\n      .expandable-icon {\n        width: 30px;\n        height: 30px;\n        transition: .2s ease-in;      \n        border-radius: 4px;\n        display: flex;\n        align-items: center;\n        padding: 0 4px;\n        \n        span {\n          margin-inline-start: 2px;\n        }\n      }\n        \n        &--clean {\n         color: #27a63a; \n         .expandable-icon {\n            background: #27a63a;        \n          }\n        }\n        \n        &--infected {\n          color: #e10036;\n          .expandable-icon {\n            background: #e10036;        \n          }\n        }\n        \n        &--inactive-sampling {\n          color: ${theme.colorScheme.natural.n60};\n          .expandable-icon {\n            background: ${theme.colorScheme.natural.n60};        \n          }\n        }\n        \n        .name {\n          position: absolute;\n          font-weight: 100;\n          ${(p) => (p.isRtl ? 'right: 51px;' : 'left: 51px;')}\n          top: 16px;\n          width: 7.5em;\n          margin-inline-start: 3px;\n        }\n      }\n    }\n  `;\n\nconst ActionsContainer = styled.div`\n  display: flex;\n  justify-content: start;\n  align-items: center;\n`;\n\nconst FirstSection = styled.div`\n  margin: 85px 0 20px 0;\n`;\n\nconst SecondSection = styled.div`\n  padding: 20px;\n  background: #fcfcfc;\n  border: 1px solid #e7e7e7;\n  border-radius: 6px;\n`;\n\nconst MapTableContainer = styled.div<{ isRtl: boolean }>`\n  display: flex;\n  justify-content: start;\n  flex-direction: row-reverse;\n  .map-container {\n    width: unset !important;\n    .event-timerange {\n      display: none;\n    }\n    #map {\n      height: 69vh;\n      width: 30vw;\n    }\n  }\n  [data-testid='kando-table'] {\n    width: 100%;\n  }\n  [data-column-id='1'] {\n    justify-content: flex-start !important;\n    overflow: visible;\n    position: relative;\n    cursor: pointer;\n    &:hover {\n      .name {\n        color: white !important;\n      }\n      .expandable-icon {\n        width: calc(120px + 1vw);\n        transition: 0.2s cubic-bezier(0.65, 0.05, 0.36, 1);\n      }\n    }\n  }\n\n  .spinner-container {\n    width: 100%;\n    display: flex;\n    justify-content: center;\n  }\n`;\n\nconst Content = styled.div`\n  @media (max-width: 576px) {\n    padding: 20px;\n  }\n\n  h1 {\n    font-weight: bold;\n  }\n\n  padding: 60px 60px;\n`;\n"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@kando-env/kando-ui",
3
- "version": "1.2.357",
3
+ "version": "1.2.358-alpha.0",
4
4
  "main": "lib/index.js",
5
5
  "author": "Nadav(Private) <nadavk72@gmail.com>",
6
6
  "scripts": {