@kando-env/kando-ui 1.2.353-alpha.8 → 1.2.354-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.
@@ -181,7 +181,7 @@ const Map = _ref => {
181
181
  (0, _MapUtils.areaFocusLogic)(mapRef, _MapUtils.isValidArea, centerTo);
182
182
  }
183
183
  }
184
- }, [mapRef.current]);
184
+ }, [mapRef.current, areaToCenterBy]);
185
185
  (0, _react.useEffect)(() => {
186
186
  var _mapRef$current2;
187
187
  let clicked = false;
@@ -216,4 +216,4 @@ const Map = _ref => {
216
216
  }), (0, _MapUtils.shoudLoadDependentMapObjects)(edges, areas, global_data, mapRef, points) && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, memoizedEvent, memoizedZoomControl, children))));
217
217
  };
218
218
  exports.Map = Map;
219
- //# 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","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","hideEdges","mapBoxStyle","leafletMap","mapDefault","children","includeUnmonitoredPoints","includeUnmonitoredDescendantsForEdges","forEventsView","style","forWWTPDashboard","map","mapRef","useRef","dispatch","useDispatch","mapZoomLevel","setMapZoomLevel","useState","selectedItem","useSelectedItem","eventsData","useSelector","state","events_data","hoveredEventPresent","useMemo","undefined","focusedEventPresent","factoriesClusterGroup","window","customLeaflet","markerClusterGroup","spiderfyOnMaxZoom","showCoverageOnHover","zoomToBoundsOnClick","animate","disableClusteringAtZoom","removeOutsideVisibleBounds","chunkedLoading","iconCreateFunction","cluster","DivIcon","html","concat","_childCount","i18n","t","className","iconSize","Point","wwtpsLayerGroup","layerGroup","collectorsLayerGroup","areasLayerGroup","FeatureGroup","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","centerTo","length","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      const centerTo = areaToCenterBy\n        ? areaToCenterBy\n        : areas?.length >= 0\n        ? areas[0]\n        : undefined;\n      if (centerTo) {\n        areaFocusLogic(mapRef, isValidArea, centerTo);\n      }\n    }\n  }, [mapRef.current]);\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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"}
219
+ //# 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","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","hideEdges","mapBoxStyle","leafletMap","mapDefault","children","includeUnmonitoredPoints","includeUnmonitoredDescendantsForEdges","forEventsView","style","forWWTPDashboard","map","mapRef","useRef","dispatch","useDispatch","mapZoomLevel","setMapZoomLevel","useState","selectedItem","useSelectedItem","eventsData","useSelector","state","events_data","hoveredEventPresent","useMemo","undefined","focusedEventPresent","factoriesClusterGroup","window","customLeaflet","markerClusterGroup","spiderfyOnMaxZoom","showCoverageOnHover","zoomToBoundsOnClick","animate","disableClusteringAtZoom","removeOutsideVisibleBounds","chunkedLoading","iconCreateFunction","cluster","DivIcon","html","concat","_childCount","i18n","t","className","iconSize","Point","wwtpsLayerGroup","layerGroup","collectorsLayerGroup","areasLayerGroup","FeatureGroup","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","centerTo","length","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      const centerTo = areaToCenterBy\n        ? areaToCenterBy\n        : areas?.length >= 0\n        ? areas[0]\n        : undefined;\n      if (centerTo) {\n        areaFocusLogic(mapRef, isValidArea, centerTo);\n      }\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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"}
@@ -75,7 +75,7 @@ const AreaPolygon = props => {
75
75
  });
76
76
  return polygon;
77
77
  };
78
- const isPolygonChanged = (polygon, area) => {
78
+ const isPolygonChangedColor = (polygon, area) => {
79
79
  if (!polygon) return true;
80
80
  const areaColor = (0, _scoreToData.scoreToColor)(area.area_score);
81
81
  const polygonColor = polygon.options.color;
@@ -88,7 +88,7 @@ const AreaPolygon = props => {
88
88
  // This creates a flickering effect on the map which is not ideal
89
89
  // but it's the best solution we have for now and we might need to refactor this in the future.
90
90
  const existingPolygon = getPolygon(area.area_id);
91
- if (isPolygonChanged(existingPolygon, area)) {
91
+ if (isPolygonChangedColor(existingPolygon, area)) {
92
92
  const polygon = (0, _AreaUtils.createPolygon)(area, mapZoom, featureGroup, map, WWTPMapLogic);
93
93
  if (polygon) {
94
94
  let subAreas = area.sub_areas.map(subArea => subArea.area_id);
@@ -106,4 +106,4 @@ const AreaPolygon = props => {
106
106
  const connector = (0, _reactRedux.connect)(null);
107
107
  var _default = connector(AreaPolygon);
108
108
  exports.default = _default;
109
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_reactRedux","_AreaUtils","_reactDom","_Widget","_utils","_scoreToData","_Capacity","_reactRouterDom","AreaPolygon","props","map","area","mapZoom","global_data","featureGroup","points","useSelector","state","points_data","items","areas","areas_data","WWTPMode","wwtp_dashboard","capacity","waterAuthorityIsCapacity","dispatch","useDispatch","history","useHistory","WWTPMapLogic","polygon","fetchDataAndShowPopup","widgetContainer","document","createElement","createPopupForObject","renderedElement","marker","type","is_virtual","fetchCapacity","area_id","waterAuthorityId","then","listData","ReactDOM","render","default","Widget","object","isPopupOpen","openPopup","on","closePopup","openTooltip","subject","sendAnalyticsEvent","area_name","getPolygon","id","eachLayer","layer","kando_object_id","isPolygonChanged","areaColor","scoreToColor","area_score","polygonColor","options","color","existingPolygon","createPolygon","subAreas","sub_areas","subArea","length","removeLayer","fire","Fragment","connector","connect","_default","exports"],"sources":["../../../../src/Widgets/Map/areas/AreaPolygon.tsx"],"sourcesContent":["import React from 'react';\nimport { connect, useDispatch, useSelector } from 'react-redux';\nimport { IArea } from 'src/store/areas/models/IArea';\nimport { createPolygon } from './AreaUtils';\nimport ReactDOM from 'react-dom';\nimport { Widget } from 'src/pages/DashboardMap/Widget';\nimport {\n  createPopupForObject,\n  sendAnalyticsEvent,\n} from 'src/pages/DashboardMap/utils';\nimport { FeatureGroup } from 'leaflet';\nimport { scoreToColor } from 'src/utilities/scoreToData';\nimport { fetchCapacity } from 'src/pages/DashboardMap/Capacity';\nimport { useHistory } from 'react-router-dom';\n\ntype Props = {\n  map: any;\n  L: any;\n  area: IArea & { color?: string; showColorOnlyInBorders?: boolean };\n  mapZoom: number;\n  global_data: any;\n  bindPopup?: boolean;\n  featureGroup: FeatureGroup;\n};\n\nconst AreaPolygon: React.FC<Props> = (props) => {\n  const { map, area, mapZoom, global_data, featureGroup } = props;\n  const points = useSelector((state) => state.points_data.items);\n  const areas = useSelector((state) => state.areas_data.items);\n  const WWTPMode = useSelector((state) => state.wwtp_dashboard.map !== null);\n  const capacity = global_data.waterAuthorityIsCapacity;\n  const dispatch = useDispatch();\n  const history = useHistory();\n\n  const WWTPMapLogic = (polygon, area) => {\n    if (!WWTPMode || !capacity) return;\n\n    const fetchDataAndShowPopup = async () => {\n      const widgetContainer = document.createElement('span');\n\n      createPopupForObject({\n        renderedElement: widgetContainer,\n        marker: polygon,\n      });\n\n      const type = area?.is_virtual === true ? 'varea' : 'area';\n      fetchCapacity(type, area.area_id, global_data.waterAuthorityId).then(\n        (listData) => {\n          ReactDOM.render(\n            <Widget\n              object={area}\n              dispatch={dispatch}\n              areas={areas}\n              points={points}\n              map={map}\n              global_data={global_data}\n              listData={listData}\n              history={history}\n            />,\n            widgetContainer,\n          );\n        },\n      );\n\n      if (!polygon.isPopupOpen()) {\n        polygon.openPopup();\n      }\n    };\n\n    polygon.on('click-event', () => {\n      polygon.isPopupOpen() ? polygon.closePopup() : fetchDataAndShowPopup();\n      polygon.openTooltip();\n    });\n\n    polygon.on('click', () => {\n      fetchDataAndShowPopup();\n\n      const subject = 'Map View - Area clicked';\n      sendAnalyticsEvent(subject, 'map', {\n        area_id: area.area_id,\n        area_name: area.area_name,\n      });\n    });\n  };\n\n  const getPolygon = (id: string) => {\n    let polygon;\n    featureGroup.eachLayer((layer) => {\n      if (layer.kando_object_id === id) {\n        polygon = layer;\n      }\n    });\n    return polygon;\n  };\n\n  const isPolygonChanged = (polygon, area) => {\n    if (!polygon) return true;\n    const areaColor = scoreToColor(area.area_score);\n    const polygonColor = polygon.options.color;\n    return areaColor !== polygonColor;\n  };\n\n  // The following removes the existing layer and redraw it after.\n  // This is necessary so the featureGroup will hold only one polygon per area otherwise they are piling up.\n  // We replace them because the area's color might have changed.\n  // This creates a flickering effect on the map which is not ideal\n  // but it's the best solution we have for now and we might need to refactor this in the future.\n  const existingPolygon = getPolygon(area.area_id);\n  if (isPolygonChanged(existingPolygon, area)) {\n    const polygon = createPolygon(\n      area,\n      mapZoom,\n      featureGroup,\n      map,\n      WWTPMapLogic,\n    );\n    if (polygon) {\n      let subAreas = area.sub_areas.map((subArea) => subArea.area_id);\n      if (subAreas.length > 0) {\n        polygon['sub_areas'] = subAreas;\n      }\n    }\n    if (existingPolygon) {\n      featureGroup.removeLayer(existingPolygon);\n      map.fire('zoomend');\n    }\n  }\n  return <></>;\n};\n\nconst connector = connect(null);\nexport default connector(AreaPolygon);\n"],"mappings":"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"}
109
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_reactRedux","_AreaUtils","_reactDom","_Widget","_utils","_scoreToData","_Capacity","_reactRouterDom","AreaPolygon","props","map","area","mapZoom","global_data","featureGroup","points","useSelector","state","points_data","items","areas","areas_data","WWTPMode","wwtp_dashboard","capacity","waterAuthorityIsCapacity","dispatch","useDispatch","history","useHistory","WWTPMapLogic","polygon","fetchDataAndShowPopup","widgetContainer","document","createElement","createPopupForObject","renderedElement","marker","type","is_virtual","fetchCapacity","area_id","waterAuthorityId","then","listData","ReactDOM","render","default","Widget","object","isPopupOpen","openPopup","on","closePopup","openTooltip","subject","sendAnalyticsEvent","area_name","getPolygon","id","eachLayer","layer","kando_object_id","isPolygonChangedColor","areaColor","scoreToColor","area_score","polygonColor","options","color","existingPolygon","createPolygon","subAreas","sub_areas","subArea","length","removeLayer","fire","Fragment","connector","connect","_default","exports"],"sources":["../../../../src/Widgets/Map/areas/AreaPolygon.tsx"],"sourcesContent":["import React from 'react';\nimport { connect, useDispatch, useSelector } from 'react-redux';\nimport { IArea } from 'src/store/areas/models/IArea';\nimport { createPolygon } from './AreaUtils';\nimport ReactDOM from 'react-dom';\nimport { Widget } from 'src/pages/DashboardMap/Widget';\nimport {\n  createPopupForObject,\n  sendAnalyticsEvent,\n} from 'src/pages/DashboardMap/utils';\nimport { FeatureGroup } from 'leaflet';\nimport { scoreToColor } from 'src/utilities/scoreToData';\nimport { fetchCapacity } from 'src/pages/DashboardMap/Capacity';\nimport { useHistory } from 'react-router-dom';\n\ntype Props = {\n  map: any;\n  L: any;\n  area: IArea & { color?: string; showColorOnlyInBorders?: boolean };\n  mapZoom: number;\n  global_data: any;\n  bindPopup?: boolean;\n  featureGroup: FeatureGroup;\n};\n\nconst AreaPolygon: React.FC<Props> = (props) => {\n  const { map, area, mapZoom, global_data, featureGroup } = props;\n  const points = useSelector((state) => state.points_data.items);\n  const areas = useSelector((state) => state.areas_data.items);\n  const WWTPMode = useSelector((state) => state.wwtp_dashboard.map !== null);\n  const capacity = global_data.waterAuthorityIsCapacity;\n  const dispatch = useDispatch();\n  const history = useHistory();\n\n  const WWTPMapLogic = (polygon, area) => {\n    if (!WWTPMode || !capacity) return;\n\n    const fetchDataAndShowPopup = async () => {\n      const widgetContainer = document.createElement('span');\n\n      createPopupForObject({\n        renderedElement: widgetContainer,\n        marker: polygon,\n      });\n\n      const type = area?.is_virtual === true ? 'varea' : 'area';\n      fetchCapacity(type, area.area_id, global_data.waterAuthorityId).then(\n        (listData) => {\n          ReactDOM.render(\n            <Widget\n              object={area}\n              dispatch={dispatch}\n              areas={areas}\n              points={points}\n              map={map}\n              global_data={global_data}\n              listData={listData}\n              history={history}\n            />,\n            widgetContainer,\n          );\n        },\n      );\n\n      if (!polygon.isPopupOpen()) {\n        polygon.openPopup();\n      }\n    };\n\n    polygon.on('click-event', () => {\n      polygon.isPopupOpen() ? polygon.closePopup() : fetchDataAndShowPopup();\n      polygon.openTooltip();\n    });\n\n    polygon.on('click', () => {\n      fetchDataAndShowPopup();\n\n      const subject = 'Map View - Area clicked';\n      sendAnalyticsEvent(subject, 'map', {\n        area_id: area.area_id,\n        area_name: area.area_name,\n      });\n    });\n  };\n\n  const getPolygon = (id: string) => {\n    let polygon;\n    featureGroup.eachLayer((layer) => {\n      if (layer.kando_object_id === id) {\n        polygon = layer;\n      }\n    });\n    return polygon;\n  };\n\n  const isPolygonChangedColor = (polygon, area) => {\n    if (!polygon) return true;\n    const areaColor = scoreToColor(area.area_score);\n    const polygonColor = polygon.options.color;\n    return areaColor !== polygonColor;\n  };\n\n  // The following removes the existing layer and redraw it after.\n  // This is necessary so the featureGroup will hold only one polygon per area otherwise they are piling up.\n  // We replace them because the area's color might have changed.\n  // This creates a flickering effect on the map which is not ideal\n  // but it's the best solution we have for now and we might need to refactor this in the future.\n  const existingPolygon = getPolygon(area.area_id);\n  if (isPolygonChangedColor(existingPolygon, area)) {\n    const polygon = createPolygon(\n      area,\n      mapZoom,\n      featureGroup,\n      map,\n      WWTPMapLogic,\n    );\n    if (polygon) {\n      let subAreas = area.sub_areas.map((subArea) => subArea.area_id);\n      if (subAreas.length > 0) {\n        polygon['sub_areas'] = subAreas;\n      }\n    }\n    if (existingPolygon) {\n      featureGroup.removeLayer(existingPolygon);\n      map.fire('zoomend');\n    }\n  }\n  return <></>;\n};\n\nconst connector = connect(null);\nexport default connector(AreaPolygon);\n"],"mappings":"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"}
@@ -22,7 +22,7 @@ const AreaPolygons = props => {
22
22
 
23
23
  (0, _react.useEffect)(() => {
24
24
  featureGroup.addTo(map);
25
- }, []);
25
+ }, [areas]);
26
26
 
27
27
  // if (shouldFly) {
28
28
  // if (featureGroup.getLayers().length > 0 && !areaToCenterBy) {
@@ -45,4 +45,4 @@ const AreaPolygons = props => {
45
45
  }))));
46
46
  };
47
47
  exports.AreaPolygons = AreaPolygons;
48
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVXaWxkY2FyZCIsInJlcXVpcmUiLCJfQXJlYVBvbHlnb24iLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwiX2dldFJlcXVpcmVXaWxkY2FyZENhY2hlIiwibm9kZUludGVyb3AiLCJXZWFrTWFwIiwiY2FjaGVCYWJlbEludGVyb3AiLCJjYWNoZU5vZGVJbnRlcm9wIiwib2JqIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJjYWNoZSIsImhhcyIsImdldCIsIm5ld09iaiIsImhhc1Byb3BlcnR5RGVzY3JpcHRvciIsIk9iamVjdCIsImRlZmluZVByb3BlcnR5IiwiZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9yIiwia2V5IiwicHJvdG90eXBlIiwiaGFzT3duUHJvcGVydHkiLCJjYWxsIiwiZGVzYyIsInNldCIsIkFyZWFQb2x5Z29ucyIsInByb3BzIiwiTCIsImFyZWFzIiwibWFwIiwibWFwWm9vbSIsImdsb2JhbF9kYXRhIiwiZmVhdHVyZUdyb3VwIiwidXNlRWZmZWN0IiwiYWRkVG8iLCJjcmVhdGVFbGVtZW50IiwiRnJhZ21lbnQiLCJsZW5ndGgiLCJhcmVhIiwiYXJlYV9pZCIsImJpbmRQb3B1cCIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvV2lkZ2V0cy9NYXAvYXJlYXMvQXJlYVBvbHlnb25zLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0IH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgSUFyZWEgfSBmcm9tICdzcmMvc3RvcmUvYXJlYXMvbW9kZWxzL0lBcmVhJztcbmltcG9ydCBBcmVhUG9seWdvbiBmcm9tICcuL0FyZWFQb2x5Z29uJztcbmltcG9ydCB7IEZlYXR1cmVHcm91cCB9IGZyb20gJ2xlYWZsZXQnO1xuXG50eXBlIFByb3BzID0ge1xuICBtYXA6IGFueTtcbiAgTDogYW55O1xuICBhcmVhczogSUFyZWFbXTtcbiAgbWFwWm9vbTogbnVtYmVyO1xuICBhcmVhVG9DZW50ZXJCeT86IGFueTtcbiAgZ2xvYmFsX2RhdGE6IGFueTtcbiAgZmVhdHVyZUdyb3VwOiBGZWF0dXJlR3JvdXA7XG59O1xuXG5leHBvcnQgY29uc3QgQXJlYVBvbHlnb25zOiBSZWFjdC5GQzxQcm9wcz4gPSAocHJvcHMpID0+IHtcbiAgY29uc3QgeyBMLCBhcmVhcywgbWFwLCBtYXBab29tLCBnbG9iYWxfZGF0YSwgZmVhdHVyZUdyb3VwIH0gPSBwcm9wcztcbiAgLy8gY29uc3QgW3Nob3VsZEZseSwgc2V0U2hvdWxkRmx5XSA9IHVzZVN0YXRlKHRydWUpO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgZmVhdHVyZUdyb3VwLmFkZFRvKG1hcCk7XG4gIH0sIFtdKTtcblxuICAvLyBpZiAoc2hvdWxkRmx5KSB7XG4gIC8vICAgaWYgKGZlYXR1cmVHcm91cC5nZXRMYXllcnMoKS5sZW5ndGggPiAwICYmICFhcmVhVG9DZW50ZXJCeSkge1xuICAvLyAgICAgbWFwLmZpdEJvdW5kcyhmZWF0dXJlR3JvdXAuZ2V0Qm91bmRzKCksIHtcbiAgLy8gICAgICAgcGFkZGluZzogWzQyMCwgNDIwXSxcbiAgLy8gICAgIH0pO1xuICAvLyAgICAgc2V0U2hvdWxkRmx5KGZhbHNlKTtcbiAgLy8gICB9XG4gIC8vIH1cblxuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICB7YXJlYXM/Lmxlbmd0aCAhPT0gMCAmJlxuICAgICAgICBhcmVhcz8ubWFwKChhcmVhOiBJQXJlYSkgPT4gKFxuICAgICAgICAgIDxBcmVhUG9seWdvblxuICAgICAgICAgICAgYXJlYT17YXJlYX1cbiAgICAgICAgICAgIG1hcD17bWFwfVxuICAgICAgICAgICAgTD17TH1cbiAgICAgICAgICAgIGtleT17YXJlYS5hcmVhX2lkfVxuICAgICAgICAgICAgbWFwWm9vbT17bWFwWm9vbX1cbiAgICAgICAgICAgIGdsb2JhbF9kYXRhPXtnbG9iYWxfZGF0YX1cbiAgICAgICAgICAgIGJpbmRQb3B1cD17dHJ1ZX1cbiAgICAgICAgICAgIGZlYXR1cmVHcm91cD17ZmVhdHVyZUdyb3VwfVxuICAgICAgICAgIC8+XG4gICAgICAgICkpfVxuICAgIDwvPlxuICApO1xufTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBLElBQUFBLE1BQUEsR0FBQUMsdUJBQUEsQ0FBQUMsT0FBQTtBQUVBLElBQUFDLFlBQUEsR0FBQUMsc0JBQUEsQ0FBQUYsT0FBQTtBQUF3QyxTQUFBRyx5QkFBQUMsV0FBQSxlQUFBQyxPQUFBLGtDQUFBQyxpQkFBQSxPQUFBRCxPQUFBLFFBQUFFLGdCQUFBLE9BQUFGLE9BQUEsWUFBQUYsd0JBQUEsWUFBQUEsQ0FBQUMsV0FBQSxXQUFBQSxXQUFBLEdBQUFHLGdCQUFBLEdBQUFELGlCQUFBLEtBQUFGLFdBQUE7QUFBQSxTQUFBTCx3QkFBQVMsR0FBQSxFQUFBSixXQUFBLFNBQUFBLFdBQUEsSUFBQUksR0FBQSxJQUFBQSxHQUFBLENBQUFDLFVBQUEsV0FBQUQsR0FBQSxRQUFBQSxHQUFBLG9CQUFBQSxHQUFBLHdCQUFBQSxHQUFBLDRCQUFBRSxPQUFBLEVBQUFGLEdBQUEsVUFBQUcsS0FBQSxHQUFBUix3QkFBQSxDQUFBQyxXQUFBLE9BQUFPLEtBQUEsSUFBQUEsS0FBQSxDQUFBQyxHQUFBLENBQUFKLEdBQUEsWUFBQUcsS0FBQSxDQUFBRSxHQUFBLENBQUFMLEdBQUEsU0FBQU0sTUFBQSxXQUFBQyxxQkFBQSxHQUFBQyxNQUFBLENBQUFDLGNBQUEsSUFBQUQsTUFBQSxDQUFBRSx3QkFBQSxXQUFBQyxHQUFBLElBQUFYLEdBQUEsUUFBQVcsR0FBQSxrQkFBQUgsTUFBQSxDQUFBSSxTQUFBLENBQUFDLGNBQUEsQ0FBQUMsSUFBQSxDQUFBZCxHQUFBLEVBQUFXLEdBQUEsU0FBQUksSUFBQSxHQUFBUixxQkFBQSxHQUFBQyxNQUFBLENBQUFFLHdCQUFBLENBQUFWLEdBQUEsRUFBQVcsR0FBQSxjQUFBSSxJQUFBLEtBQUFBLElBQUEsQ0FBQVYsR0FBQSxJQUFBVSxJQUFBLENBQUFDLEdBQUEsS0FBQVIsTUFBQSxDQUFBQyxjQUFBLENBQUFILE1BQUEsRUFBQUssR0FBQSxFQUFBSSxJQUFBLFlBQUFULE1BQUEsQ0FBQUssR0FBQSxJQUFBWCxHQUFBLENBQUFXLEdBQUEsU0FBQUwsTUFBQSxDQUFBSixPQUFBLEdBQUFGLEdBQUEsTUFBQUcsS0FBQSxJQUFBQSxLQUFBLENBQUFhLEdBQUEsQ0FBQWhCLEdBQUEsRUFBQU0sTUFBQSxZQUFBQSxNQUFBO0FBYWpDLE1BQU1XLFlBQTZCLEdBQUlDLEtBQUssSUFBSztFQUN0RCxNQUFNO0lBQUVDLENBQUM7SUFBRUMsS0FBSztJQUFFQyxHQUFHO0lBQUVDLE9BQU87SUFBRUMsV0FBVztJQUFFQztFQUFhLENBQUMsR0FBR04sS0FBSztFQUNuRTs7RUFFQSxJQUFBTyxnQkFBUyxFQUFDLE1BQU07SUFDZEQsWUFBWSxDQUFDRSxLQUFLLENBQUNMLEdBQUcsQ0FBQztFQUN6QixDQUFDLEVBQUUsRUFBRSxDQUFDOztFQUVOO0VBQ0E7RUFDQTtFQUNBO0VBQ0E7RUFDQTtFQUNBO0VBQ0E7O0VBRUEsb0JBQ0UvQixNQUFBLENBQUFZLE9BQUEsQ0FBQXlCLGFBQUEsQ0FBQXJDLE1BQUEsQ0FBQVksT0FBQSxDQUFBMEIsUUFBQSxRQUNHLENBQUFSLEtBQUssYUFBTEEsS0FBSyx1QkFBTEEsS0FBSyxDQUFFUyxNQUFNLE1BQUssQ0FBQyxLQUNsQlQsS0FBSyxhQUFMQSxLQUFLLHVCQUFMQSxLQUFLLENBQUVDLEdBQUcsQ0FBRVMsSUFBVyxpQkFDckJ4QyxNQUFBLENBQUFZLE9BQUEsQ0FBQXlCLGFBQUEsQ0FBQ2xDLFlBQUEsQ0FBQVMsT0FBVztJQUNWNEIsSUFBSSxFQUFFQSxJQUFLO0lBQ1hULEdBQUcsRUFBRUEsR0FBSTtJQUNURixDQUFDLEVBQUVBLENBQUU7SUFDTFIsR0FBRyxFQUFFbUIsSUFBSSxDQUFDQyxPQUFRO0lBQ2xCVCxPQUFPLEVBQUVBLE9BQVE7SUFDakJDLFdBQVcsRUFBRUEsV0FBWTtJQUN6QlMsU0FBUyxFQUFFLElBQUs7SUFDaEJSLFlBQVksRUFBRUE7RUFBYSxDQUM1QixDQUNGLENBQUMsQ0FDSixDQUFDO0FBRVAsQ0FBQztBQUFDUyxPQUFBLENBQUFoQixZQUFBLEdBQUFBLFlBQUEifQ==
48
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVXaWxkY2FyZCIsInJlcXVpcmUiLCJfQXJlYVBvbHlnb24iLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwiX2dldFJlcXVpcmVXaWxkY2FyZENhY2hlIiwibm9kZUludGVyb3AiLCJXZWFrTWFwIiwiY2FjaGVCYWJlbEludGVyb3AiLCJjYWNoZU5vZGVJbnRlcm9wIiwib2JqIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJjYWNoZSIsImhhcyIsImdldCIsIm5ld09iaiIsImhhc1Byb3BlcnR5RGVzY3JpcHRvciIsIk9iamVjdCIsImRlZmluZVByb3BlcnR5IiwiZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9yIiwia2V5IiwicHJvdG90eXBlIiwiaGFzT3duUHJvcGVydHkiLCJjYWxsIiwiZGVzYyIsInNldCIsIkFyZWFQb2x5Z29ucyIsInByb3BzIiwiTCIsImFyZWFzIiwibWFwIiwibWFwWm9vbSIsImdsb2JhbF9kYXRhIiwiZmVhdHVyZUdyb3VwIiwidXNlRWZmZWN0IiwiYWRkVG8iLCJjcmVhdGVFbGVtZW50IiwiRnJhZ21lbnQiLCJsZW5ndGgiLCJhcmVhIiwiYXJlYV9pZCIsImJpbmRQb3B1cCIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvV2lkZ2V0cy9NYXAvYXJlYXMvQXJlYVBvbHlnb25zLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0IH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgSUFyZWEgfSBmcm9tICdzcmMvc3RvcmUvYXJlYXMvbW9kZWxzL0lBcmVhJztcbmltcG9ydCBBcmVhUG9seWdvbiBmcm9tICcuL0FyZWFQb2x5Z29uJztcbmltcG9ydCB7IEZlYXR1cmVHcm91cCB9IGZyb20gJ2xlYWZsZXQnO1xuXG50eXBlIFByb3BzID0ge1xuICBtYXA6IGFueTtcbiAgTDogYW55O1xuICBhcmVhczogSUFyZWFbXTtcbiAgbWFwWm9vbTogbnVtYmVyO1xuICBhcmVhVG9DZW50ZXJCeT86IGFueTtcbiAgZ2xvYmFsX2RhdGE6IGFueTtcbiAgZmVhdHVyZUdyb3VwOiBGZWF0dXJlR3JvdXA7XG59O1xuXG5leHBvcnQgY29uc3QgQXJlYVBvbHlnb25zOiBSZWFjdC5GQzxQcm9wcz4gPSAocHJvcHMpID0+IHtcbiAgY29uc3QgeyBMLCBhcmVhcywgbWFwLCBtYXBab29tLCBnbG9iYWxfZGF0YSwgZmVhdHVyZUdyb3VwIH0gPSBwcm9wcztcbiAgLy8gY29uc3QgW3Nob3VsZEZseSwgc2V0U2hvdWxkRmx5XSA9IHVzZVN0YXRlKHRydWUpO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgZmVhdHVyZUdyb3VwLmFkZFRvKG1hcCk7XG4gIH0sIFthcmVhc10pO1xuXG4gIC8vIGlmIChzaG91bGRGbHkpIHtcbiAgLy8gICBpZiAoZmVhdHVyZUdyb3VwLmdldExheWVycygpLmxlbmd0aCA+IDAgJiYgIWFyZWFUb0NlbnRlckJ5KSB7XG4gIC8vICAgICBtYXAuZml0Qm91bmRzKGZlYXR1cmVHcm91cC5nZXRCb3VuZHMoKSwge1xuICAvLyAgICAgICBwYWRkaW5nOiBbNDIwLCA0MjBdLFxuICAvLyAgICAgfSk7XG4gIC8vICAgICBzZXRTaG91bGRGbHkoZmFsc2UpO1xuICAvLyAgIH1cbiAgLy8gfVxuXG4gIHJldHVybiAoXG4gICAgPD5cbiAgICAgIHthcmVhcz8ubGVuZ3RoICE9PSAwICYmXG4gICAgICAgIGFyZWFzPy5tYXAoKGFyZWE6IElBcmVhKSA9PiAoXG4gICAgICAgICAgPEFyZWFQb2x5Z29uXG4gICAgICAgICAgICBhcmVhPXthcmVhfVxuICAgICAgICAgICAgbWFwPXttYXB9XG4gICAgICAgICAgICBMPXtMfVxuICAgICAgICAgICAga2V5PXthcmVhLmFyZWFfaWR9XG4gICAgICAgICAgICBtYXBab29tPXttYXBab29tfVxuICAgICAgICAgICAgZ2xvYmFsX2RhdGE9e2dsb2JhbF9kYXRhfVxuICAgICAgICAgICAgYmluZFBvcHVwPXt0cnVlfVxuICAgICAgICAgICAgZmVhdHVyZUdyb3VwPXtmZWF0dXJlR3JvdXB9XG4gICAgICAgICAgLz5cbiAgICAgICAgKSl9XG4gICAgPC8+XG4gICk7XG59O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUEsSUFBQUEsTUFBQSxHQUFBQyx1QkFBQSxDQUFBQyxPQUFBO0FBRUEsSUFBQUMsWUFBQSxHQUFBQyxzQkFBQSxDQUFBRixPQUFBO0FBQXdDLFNBQUFHLHlCQUFBQyxXQUFBLGVBQUFDLE9BQUEsa0NBQUFDLGlCQUFBLE9BQUFELE9BQUEsUUFBQUUsZ0JBQUEsT0FBQUYsT0FBQSxZQUFBRix3QkFBQSxZQUFBQSxDQUFBQyxXQUFBLFdBQUFBLFdBQUEsR0FBQUcsZ0JBQUEsR0FBQUQsaUJBQUEsS0FBQUYsV0FBQTtBQUFBLFNBQUFMLHdCQUFBUyxHQUFBLEVBQUFKLFdBQUEsU0FBQUEsV0FBQSxJQUFBSSxHQUFBLElBQUFBLEdBQUEsQ0FBQUMsVUFBQSxXQUFBRCxHQUFBLFFBQUFBLEdBQUEsb0JBQUFBLEdBQUEsd0JBQUFBLEdBQUEsNEJBQUFFLE9BQUEsRUFBQUYsR0FBQSxVQUFBRyxLQUFBLEdBQUFSLHdCQUFBLENBQUFDLFdBQUEsT0FBQU8sS0FBQSxJQUFBQSxLQUFBLENBQUFDLEdBQUEsQ0FBQUosR0FBQSxZQUFBRyxLQUFBLENBQUFFLEdBQUEsQ0FBQUwsR0FBQSxTQUFBTSxNQUFBLFdBQUFDLHFCQUFBLEdBQUFDLE1BQUEsQ0FBQUMsY0FBQSxJQUFBRCxNQUFBLENBQUFFLHdCQUFBLFdBQUFDLEdBQUEsSUFBQVgsR0FBQSxRQUFBVyxHQUFBLGtCQUFBSCxNQUFBLENBQUFJLFNBQUEsQ0FBQUMsY0FBQSxDQUFBQyxJQUFBLENBQUFkLEdBQUEsRUFBQVcsR0FBQSxTQUFBSSxJQUFBLEdBQUFSLHFCQUFBLEdBQUFDLE1BQUEsQ0FBQUUsd0JBQUEsQ0FBQVYsR0FBQSxFQUFBVyxHQUFBLGNBQUFJLElBQUEsS0FBQUEsSUFBQSxDQUFBVixHQUFBLElBQUFVLElBQUEsQ0FBQUMsR0FBQSxLQUFBUixNQUFBLENBQUFDLGNBQUEsQ0FBQUgsTUFBQSxFQUFBSyxHQUFBLEVBQUFJLElBQUEsWUFBQVQsTUFBQSxDQUFBSyxHQUFBLElBQUFYLEdBQUEsQ0FBQVcsR0FBQSxTQUFBTCxNQUFBLENBQUFKLE9BQUEsR0FBQUYsR0FBQSxNQUFBRyxLQUFBLElBQUFBLEtBQUEsQ0FBQWEsR0FBQSxDQUFBaEIsR0FBQSxFQUFBTSxNQUFBLFlBQUFBLE1BQUE7QUFhakMsTUFBTVcsWUFBNkIsR0FBSUMsS0FBSyxJQUFLO0VBQ3RELE1BQU07SUFBRUMsQ0FBQztJQUFFQyxLQUFLO0lBQUVDLEdBQUc7SUFBRUMsT0FBTztJQUFFQyxXQUFXO0lBQUVDO0VBQWEsQ0FBQyxHQUFHTixLQUFLO0VBQ25FOztFQUVBLElBQUFPLGdCQUFTLEVBQUMsTUFBTTtJQUNkRCxZQUFZLENBQUNFLEtBQUssQ0FBQ0wsR0FBRyxDQUFDO0VBQ3pCLENBQUMsRUFBRSxDQUFDRCxLQUFLLENBQUMsQ0FBQzs7RUFFWDtFQUNBO0VBQ0E7RUFDQTtFQUNBO0VBQ0E7RUFDQTtFQUNBOztFQUVBLG9CQUNFOUIsTUFBQSxDQUFBWSxPQUFBLENBQUF5QixhQUFBLENBQUFyQyxNQUFBLENBQUFZLE9BQUEsQ0FBQTBCLFFBQUEsUUFDRyxDQUFBUixLQUFLLGFBQUxBLEtBQUssdUJBQUxBLEtBQUssQ0FBRVMsTUFBTSxNQUFLLENBQUMsS0FDbEJULEtBQUssYUFBTEEsS0FBSyx1QkFBTEEsS0FBSyxDQUFFQyxHQUFHLENBQUVTLElBQVcsaUJBQ3JCeEMsTUFBQSxDQUFBWSxPQUFBLENBQUF5QixhQUFBLENBQUNsQyxZQUFBLENBQUFTLE9BQVc7SUFDVjRCLElBQUksRUFBRUEsSUFBSztJQUNYVCxHQUFHLEVBQUVBLEdBQUk7SUFDVEYsQ0FBQyxFQUFFQSxDQUFFO0lBQ0xSLEdBQUcsRUFBRW1CLElBQUksQ0FBQ0MsT0FBUTtJQUNsQlQsT0FBTyxFQUFFQSxPQUFRO0lBQ2pCQyxXQUFXLEVBQUVBLFdBQVk7SUFDekJTLFNBQVMsRUFBRSxJQUFLO0lBQ2hCUixZQUFZLEVBQUVBO0VBQWEsQ0FDNUIsQ0FDRixDQUFDLENBQ0osQ0FBQztBQUVQLENBQUM7QUFBQ1MsT0FBQSxDQUFBaEIsWUFBQSxHQUFBQSxZQUFBIn0=
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
 
3
- const packageJsonVersion = "1.2.353-alpha.8";
3
+ const packageJsonVersion = "1.2.354-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));
@@ -14,6 +14,7 @@ var _actions2 = require("store/edges/actions");
14
14
  var _actions3 = require("store/points/actions");
15
15
  var _List = require("./List");
16
16
  var _utils = require("./utils");
17
+ var _Loader = require("./Loader");
17
18
  var _reactRouterDom = require("react-router-dom");
18
19
  var _useQueryURL = _interopRequireDefault(require("../../hooks/useQueryURL"));
19
20
  var _WWTPDashboardSlice = require("../../store/WWTPDashboard/WWTPDashboardSlice");
@@ -22,8 +23,6 @@ var _reactBootstrap = require("react-bootstrap");
22
23
  var _Capacity = require("./Capacity");
23
24
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
24
25
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
25
- // import { Loader } from './Loader';
26
-
27
26
  const WWTPMap = props => {
28
27
  const searchQuery = (0, _useQueryURL.default)();
29
28
  const isMapTab = searchQuery.get('view') === 'map';
@@ -114,14 +113,12 @@ const WWTPMap = props => {
114
113
  }
115
114
  // focusMap(object, wwtp_dashboard.map);
116
115
  }, [wwtp_dashboard.map]);
117
- (0, _react.useEffect)(() => {
118
- if (!ReduxState.wwtp_dashboard.focusedArea || !wwtp_dashboard.map) return;
119
- (0, _utils.focusMap)(ReduxState.wwtp_dashboard.focusedArea, wwtp_dashboard.map);
120
- }, [ReduxState.wwtp_dashboard.focusedArea]);
116
+
117
+ // useEffect(() => {
118
+ // if (!ReduxState.wwtp_dashboard.focusedArea || !wwtp_dashboard.map) return;
119
+
121
120
  const showMap = () => {
122
121
  if (!dataExists() || !points || !areas) return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null);
123
- // eslint-disable-next-line no-console
124
- console.log('WWTMap');
125
122
  return /*#__PURE__*/_react.default.createElement(_Map.Map, {
126
123
  points: points,
127
124
  areas: areas,
@@ -133,6 +130,7 @@ const WWTPMap = props => {
133
130
  });
134
131
  };
135
132
  if (!isMapTab) return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null);
133
+ if (!dataExists() || !points || !areas) return /*#__PURE__*/_react.default.createElement(_Loader.Loader, null);
136
134
  return /*#__PURE__*/_react.default.createElement(_ListContext.SelectedItemProvider, null, /*#__PURE__*/_react.default.createElement(Container, props, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Row, {
137
135
  className: "no-gutters"
138
136
  }, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Col, {
@@ -155,4 +153,4 @@ const Container = _styledComponents.default.div.withConfig({
155
153
  })(["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;}}}"]);
156
154
  var _default = WWTPMap;
157
155
  exports.default = _default;
158
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_reactRedux","require","_react","_interopRequireWildcard","_Map","_actions","_actions2","_actions3","_List","_utils","_reactRouterDom","_useQueryURL","_interopRequireDefault","_WWTPDashboardSlice","_ListContext","_reactBootstrap","_Capacity","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","WWTPMap","props","searchQuery","useQueryURL","isMapTab","id","areaID","siteID","useParams","ReduxState","useSelector","state","dispatch","useDispatch","areas_data","global_data","points_data","edges_data","wwtp_dashboard","points","setPoints","useState","areas","setAreas","WWTPInfo","setWWTPInfo","point","area","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","focusMap","showMap","createElement","Fragment","console","log","Map","edges","includeUnmonitoredPoints","forEventsView","forWWTPDashboard","SelectedItemProvider","Container","Row","className","Col","xs","sm","List","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 {\n  calculateWWTPInfo,\n  focusMap,\n  initializeWWTPData,\n  sortAreas,\n} from './utils';\n// import { 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  const showMap = () => {\n    if (!dataExists() || !points || !areas) return <></>;\n    // eslint-disable-next-line no-console\n    console.log('WWTMap');\n    return (\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      />\n    );\n  };\n\n  if (!isMapTab) return <></>;\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            {showMap()}\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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"}
156
+ //# 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","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","WWTPMap","props","searchQuery","useQueryURL","isMapTab","id","areaID","siteID","useParams","ReduxState","useSelector","state","dispatch","useDispatch","areas_data","global_data","points_data","edges_data","wwtp_dashboard","points","setPoints","useState","areas","setAreas","WWTPInfo","setWWTPInfo","point","area","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","showMap","createElement","Fragment","Map","edges","includeUnmonitoredPoints","forEventsView","forWWTPDashboard","Loader","SelectedItemProvider","Container","Row","className","Col","xs","sm","List","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  const showMap = () => {\n    if (!dataExists() || !points || !areas) return <></>;\n\n    return (\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      />\n    );\n  };\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            {showMap()}\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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"}
@@ -28,12 +28,12 @@ const getAreasToCenterBy = (global_data, mappedAreas) => {
28
28
  return null;
29
29
  }
30
30
  const areaFilter = filters.find(filter => filter.type === 'AreaFilterItem');
31
- if (!areaFilter || areaFilter.selected_options.length > 1) {
32
- return null;
31
+ if (areaFilter && areaFilter.selected_options.length > 0) {
32
+ const areaIDs = areaFilter.selected_options.map(item => Number(item));
33
+ const areas = mappedAreas.filter(Area => areaIDs.includes(Area.area_id));
34
+ return areas === null || areas === void 0 ? void 0 : areas.map(area => area.shape_data).flat();
33
35
  }
34
- const areaID = areaFilter.selected_options[0];
35
- const area = mappedAreas.find(Area => Area.area_id === areaID);
36
- return area === null || area === void 0 ? void 0 : area.shape_data;
36
+ return mappedAreas === null || mappedAreas === void 0 ? void 0 : mappedAreas.map(area => area.shape_data).flat();
37
37
  };
38
38
  exports.getAreasToCenterBy = getAreasToCenterBy;
39
39
  const areasMapper = (areas_data, isTimeFilterNotSelected) => {
@@ -49,4 +49,4 @@ const areasMapper = (areas_data, isTimeFilterNotSelected) => {
49
49
  });
50
50
  };
51
51
  exports.areasMapper = areasMapper;
52
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJDb3VudEV2ZW50c1BlclNpdGVJRCIsImV2ZW50cyIsImV2ZW50c1BlclNpdGUiLCJyZWR1Y2UiLCJFdmVudHNQZXJTaXRlIiwiZXZlbnQiLCJwb2ludF9pZF9fZXZlbnRzIiwiZXhwb3J0cyIsImdldEZvY3VzZWRFdmVudE11c3RTZWVuU2l0ZXMiLCJmb2N1c2VkRXZlbnQiLCJwb2ludHNfaWRzIiwib2JzZXJ2YXRpb25zIiwiZm9yRWFjaCIsIm9ic2VydmF0aW9uIiwicG9pbnRfaWQiLCJnZXRBcmVhc1RvQ2VudGVyQnkiLCJnbG9iYWxfZGF0YSIsIm1hcHBlZEFyZWFzIiwiX2dsb2JhbF9kYXRhJGFjdGl2ZUZpIiwiZmlsdGVycyIsImFjdGl2ZUZpbHRlciIsImZpbHRlcl9pdGVtcyIsImxlbmd0aCIsImFyZWFGaWx0ZXIiLCJmaW5kIiwiZmlsdGVyIiwidHlwZSIsInNlbGVjdGVkX29wdGlvbnMiLCJhcmVhSUQiLCJhcmVhIiwiQXJlYSIsImFyZWFfaWQiLCJzaGFwZV9kYXRhIiwiYXJlYXNNYXBwZXIiLCJhcmVhc19kYXRhIiwiaXNUaW1lRmlsdGVyTm90U2VsZWN0ZWQiLCJuZXdBcmVhcyIsIm1hcCIsIm5ld0FyZWEiLCJzaG93Q29sb3JPbmx5SW5Cb3JkZXJzIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3BhZ2VzL0V2ZW50c1BhZ2UvRXZlbnRzTWFwQ29udGFpbmVyL0V2ZW50c01hcENvbnRhaW5lckhlbHBlcnMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSUV2ZW50IH0gZnJvbSAnc3JjL3N0b3JlL2V2ZW50cy9tb2RlbHMvSUV2ZW50JztcbmltcG9ydCB7IElHbG9iYWxTdGF0ZSB9IGZyb20gJ3NyYy9zdG9yZS9nbG9iYWwvbW9kZWxzL0lHbG9iYWxTdGF0ZSc7XG5cbnR5cGUgZXZlbnRzUGVyU2l0ZVR5cGUgPSB7IFtrZXk6IG51bWJlcl06IG51bWJlciB9O1xuY29uc3QgQ291bnRFdmVudHNQZXJTaXRlSUQgPSAoZXZlbnRzOiBJRXZlbnRbXSk6IGV2ZW50c1BlclNpdGVUeXBlID0+IHtcbiAgbGV0IGV2ZW50c1BlclNpdGUgPSB7fSBhcyBldmVudHNQZXJTaXRlVHlwZTtcblxuICBldmVudHMucmVkdWNlKChFdmVudHNQZXJTaXRlLCBldmVudCkgPT4ge1xuICAgIGV2ZW50c1BlclNpdGUgPSBldmVudC5wb2ludF9pZF9fZXZlbnRzO1xuICAgIHJldHVybiBldmVudC5wb2ludF9pZF9fZXZlbnRzO1xuICB9LCBldmVudHNQZXJTaXRlKTtcblxuICByZXR1cm4gZXZlbnRzUGVyU2l0ZTtcbn07XG5cbmNvbnN0IGdldEZvY3VzZWRFdmVudE11c3RTZWVuU2l0ZXMgPSAoXG4gIGZvY3VzZWRFdmVudDogSUV2ZW50IHwgbnVsbCxcbik6IHsgW2tleTogbnVtYmVyXTogYm9vbGVhbiB9ID0+IHtcbiAgY29uc3QgcG9pbnRzX2lkcyA9IHt9IGFzIHsgW2tleTogbnVtYmVyXTogYm9vbGVhbiB9O1xuICBpZiAoZm9jdXNlZEV2ZW50KSB7XG4gICAgZm9jdXNlZEV2ZW50Lm9ic2VydmF0aW9ucy5mb3JFYWNoKFxuICAgICAgKG9ic2VydmF0aW9uKSA9PiAocG9pbnRzX2lkc1tvYnNlcnZhdGlvbi5wb2ludF9pZF0gPSB0cnVlKSxcbiAgICApO1xuICB9XG4gIHJldHVybiBwb2ludHNfaWRzO1xufTtcblxuY29uc3QgZ2V0QXJlYXNUb0NlbnRlckJ5ID0gKGdsb2JhbF9kYXRhOiBJR2xvYmFsU3RhdGUsIG1hcHBlZEFyZWFzKSA9PiB7XG4gIGNvbnN0IGZpbHRlcnMgPSBnbG9iYWxfZGF0YT8uYWN0aXZlRmlsdGVyPy5maWx0ZXJfaXRlbXM7XG5cbiAgaWYgKCFmaWx0ZXJzIHx8IGZpbHRlcnMubGVuZ3RoIDwgMSkge1xuICAgIHJldHVybiBudWxsO1xuICB9XG5cbiAgY29uc3QgYXJlYUZpbHRlciA9IGZpbHRlcnMuZmluZCgoZmlsdGVyKSA9PiBmaWx0ZXIudHlwZSA9PT0gJ0FyZWFGaWx0ZXJJdGVtJyk7XG4gIGlmICghYXJlYUZpbHRlciB8fCBhcmVhRmlsdGVyLnNlbGVjdGVkX29wdGlvbnMubGVuZ3RoID4gMSkge1xuICAgIHJldHVybiBudWxsO1xuICB9XG4gIGNvbnN0IGFyZWFJRCA9IGFyZWFGaWx0ZXIuc2VsZWN0ZWRfb3B0aW9uc1swXTtcblxuICBjb25zdCBhcmVhID0gbWFwcGVkQXJlYXMuZmluZCgoQXJlYSkgPT4gQXJlYS5hcmVhX2lkID09PSBhcmVhSUQpO1xuXG4gIHJldHVybiBhcmVhPy5zaGFwZV9kYXRhO1xufTtcblxuY29uc3QgYXJlYXNNYXBwZXIgPSAoYXJlYXNfZGF0YSwgaXNUaW1lRmlsdGVyTm90U2VsZWN0ZWQpID0+IHtcbiAgcmV0dXJuIGFyZWFzX2RhdGEubmV3QXJlYXMubWFwKChhcmVhKSA9PiB7XG4gICAgY29uc3QgbmV3QXJlYSA9IHsgLi4uYXJlYSB9O1xuICAgIG5ld0FyZWEuc2hvd0NvbG9yT25seUluQm9yZGVycyA9IHRydWU7XG4gICAgLy8gaWYgKGlzVGltZUZpbHRlck5vdFNlbGVjdGVkKSB7XG4gICAgLy8gICBuZXdBcmVhLmNvbG9yID0gJyM3ZjdmN2YnO1xuICAgIC8vIH1cbiAgICByZXR1cm4gbmV3QXJlYTtcbiAgfSk7XG59O1xuXG5leHBvcnQge1xuICBhcmVhc01hcHBlcixcbiAgZ2V0QXJlYXNUb0NlbnRlckJ5LFxuICBnZXRGb2N1c2VkRXZlbnRNdXN0U2VlblNpdGVzLFxuICBDb3VudEV2ZW50c1BlclNpdGVJRCxcbn07XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUlBLE1BQU1BLG9CQUFvQixHQUFJQyxNQUFnQixJQUF3QjtFQUNwRSxJQUFJQyxhQUFhLEdBQUcsQ0FBQyxDQUFzQjtFQUUzQ0QsTUFBTSxDQUFDRSxNQUFNLENBQUMsQ0FBQ0MsYUFBYSxFQUFFQyxLQUFLLEtBQUs7SUFDdENILGFBQWEsR0FBR0csS0FBSyxDQUFDQyxnQkFBZ0I7SUFDdEMsT0FBT0QsS0FBSyxDQUFDQyxnQkFBZ0I7RUFDL0IsQ0FBQyxFQUFFSixhQUFhLENBQUM7RUFFakIsT0FBT0EsYUFBYTtBQUN0QixDQUFDO0FBQUNLLE9BQUEsQ0FBQVAsb0JBQUEsR0FBQUEsb0JBQUE7QUFFRixNQUFNUSw0QkFBNEIsR0FDaENDLFlBQTJCLElBQ0k7RUFDL0IsTUFBTUMsVUFBVSxHQUFHLENBQUMsQ0FBK0I7RUFDbkQsSUFBSUQsWUFBWSxFQUFFO0lBQ2hCQSxZQUFZLENBQUNFLFlBQVksQ0FBQ0MsT0FBTyxDQUM5QkMsV0FBVyxJQUFNSCxVQUFVLENBQUNHLFdBQVcsQ0FBQ0MsUUFBUSxDQUFDLEdBQUcsSUFDdkQsQ0FBQztFQUNIO0VBQ0EsT0FBT0osVUFBVTtBQUNuQixDQUFDO0FBQUNILE9BQUEsQ0FBQUMsNEJBQUEsR0FBQUEsNEJBQUE7QUFFRixNQUFNTyxrQkFBa0IsR0FBR0EsQ0FBQ0MsV0FBeUIsRUFBRUMsV0FBVyxLQUFLO0VBQUEsSUFBQUMscUJBQUE7RUFDckUsTUFBTUMsT0FBTyxHQUFHSCxXQUFXLGFBQVhBLFdBQVcsd0JBQUFFLHFCQUFBLEdBQVhGLFdBQVcsQ0FBRUksWUFBWSxjQUFBRixxQkFBQSx1QkFBekJBLHFCQUFBLENBQTJCRyxZQUFZO0VBRXZELElBQUksQ0FBQ0YsT0FBTyxJQUFJQSxPQUFPLENBQUNHLE1BQU0sR0FBRyxDQUFDLEVBQUU7SUFDbEMsT0FBTyxJQUFJO0VBQ2I7RUFFQSxNQUFNQyxVQUFVLEdBQUdKLE9BQU8sQ0FBQ0ssSUFBSSxDQUFFQyxNQUFNLElBQUtBLE1BQU0sQ0FBQ0MsSUFBSSxLQUFLLGdCQUFnQixDQUFDO0VBQzdFLElBQUksQ0FBQ0gsVUFBVSxJQUFJQSxVQUFVLENBQUNJLGdCQUFnQixDQUFDTCxNQUFNLEdBQUcsQ0FBQyxFQUFFO0lBQ3pELE9BQU8sSUFBSTtFQUNiO0VBQ0EsTUFBTU0sTUFBTSxHQUFHTCxVQUFVLENBQUNJLGdCQUFnQixDQUFDLENBQUMsQ0FBQztFQUU3QyxNQUFNRSxJQUFJLEdBQUdaLFdBQVcsQ0FBQ08sSUFBSSxDQUFFTSxJQUFJLElBQUtBLElBQUksQ0FBQ0MsT0FBTyxLQUFLSCxNQUFNLENBQUM7RUFFaEUsT0FBT0MsSUFBSSxhQUFKQSxJQUFJLHVCQUFKQSxJQUFJLENBQUVHLFVBQVU7QUFDekIsQ0FBQztBQUFDekIsT0FBQSxDQUFBUSxrQkFBQSxHQUFBQSxrQkFBQTtBQUVGLE1BQU1rQixXQUFXLEdBQUdBLENBQUNDLFVBQVUsRUFBRUMsdUJBQXVCLEtBQUs7RUFDM0QsT0FBT0QsVUFBVSxDQUFDRSxRQUFRLENBQUNDLEdBQUcsQ0FBRVIsSUFBSSxJQUFLO0lBQ3ZDLE1BQU1TLE9BQU8sR0FBRztNQUFFLEdBQUdUO0lBQUssQ0FBQztJQUMzQlMsT0FBTyxDQUFDQyxzQkFBc0IsR0FBRyxJQUFJO0lBQ3JDO0lBQ0E7SUFDQTtJQUNBLE9BQU9ELE9BQU87RUFDaEIsQ0FBQyxDQUFDO0FBQ0osQ0FBQztBQUFDL0IsT0FBQSxDQUFBMEIsV0FBQSxHQUFBQSxXQUFBIn0=
52
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJDb3VudEV2ZW50c1BlclNpdGVJRCIsImV2ZW50cyIsImV2ZW50c1BlclNpdGUiLCJyZWR1Y2UiLCJFdmVudHNQZXJTaXRlIiwiZXZlbnQiLCJwb2ludF9pZF9fZXZlbnRzIiwiZXhwb3J0cyIsImdldEZvY3VzZWRFdmVudE11c3RTZWVuU2l0ZXMiLCJmb2N1c2VkRXZlbnQiLCJwb2ludHNfaWRzIiwib2JzZXJ2YXRpb25zIiwiZm9yRWFjaCIsIm9ic2VydmF0aW9uIiwicG9pbnRfaWQiLCJnZXRBcmVhc1RvQ2VudGVyQnkiLCJnbG9iYWxfZGF0YSIsIm1hcHBlZEFyZWFzIiwiX2dsb2JhbF9kYXRhJGFjdGl2ZUZpIiwiZmlsdGVycyIsImFjdGl2ZUZpbHRlciIsImZpbHRlcl9pdGVtcyIsImxlbmd0aCIsImFyZWFGaWx0ZXIiLCJmaW5kIiwiZmlsdGVyIiwidHlwZSIsInNlbGVjdGVkX29wdGlvbnMiLCJhcmVhSURzIiwibWFwIiwiaXRlbSIsIk51bWJlciIsImFyZWFzIiwiQXJlYSIsImluY2x1ZGVzIiwiYXJlYV9pZCIsImFyZWEiLCJzaGFwZV9kYXRhIiwiZmxhdCIsImFyZWFzTWFwcGVyIiwiYXJlYXNfZGF0YSIsImlzVGltZUZpbHRlck5vdFNlbGVjdGVkIiwibmV3QXJlYXMiLCJuZXdBcmVhIiwic2hvd0NvbG9yT25seUluQm9yZGVycyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9wYWdlcy9FdmVudHNQYWdlL0V2ZW50c01hcENvbnRhaW5lci9FdmVudHNNYXBDb250YWluZXJIZWxwZXJzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElBcmVhIH0gZnJvbSAnc3JjL3N0b3JlL2FyZWFzL21vZGVscy9JQXJlYSc7XG5pbXBvcnQgeyBJRXZlbnQgfSBmcm9tICdzcmMvc3RvcmUvZXZlbnRzL21vZGVscy9JRXZlbnQnO1xuaW1wb3J0IHsgSUdsb2JhbFN0YXRlIH0gZnJvbSAnc3JjL3N0b3JlL2dsb2JhbC9tb2RlbHMvSUdsb2JhbFN0YXRlJztcblxudHlwZSBldmVudHNQZXJTaXRlVHlwZSA9IHsgW2tleTogbnVtYmVyXTogbnVtYmVyIH07XG5jb25zdCBDb3VudEV2ZW50c1BlclNpdGVJRCA9IChldmVudHM6IElFdmVudFtdKTogZXZlbnRzUGVyU2l0ZVR5cGUgPT4ge1xuICBsZXQgZXZlbnRzUGVyU2l0ZSA9IHt9IGFzIGV2ZW50c1BlclNpdGVUeXBlO1xuXG4gIGV2ZW50cy5yZWR1Y2UoKEV2ZW50c1BlclNpdGUsIGV2ZW50KSA9PiB7XG4gICAgZXZlbnRzUGVyU2l0ZSA9IGV2ZW50LnBvaW50X2lkX19ldmVudHM7XG4gICAgcmV0dXJuIGV2ZW50LnBvaW50X2lkX19ldmVudHM7XG4gIH0sIGV2ZW50c1BlclNpdGUpO1xuXG4gIHJldHVybiBldmVudHNQZXJTaXRlO1xufTtcblxuY29uc3QgZ2V0Rm9jdXNlZEV2ZW50TXVzdFNlZW5TaXRlcyA9IChcbiAgZm9jdXNlZEV2ZW50OiBJRXZlbnQgfCBudWxsLFxuKTogeyBba2V5OiBudW1iZXJdOiBib29sZWFuIH0gPT4ge1xuICBjb25zdCBwb2ludHNfaWRzID0ge30gYXMgeyBba2V5OiBudW1iZXJdOiBib29sZWFuIH07XG4gIGlmIChmb2N1c2VkRXZlbnQpIHtcbiAgICBmb2N1c2VkRXZlbnQub2JzZXJ2YXRpb25zLmZvckVhY2goXG4gICAgICAob2JzZXJ2YXRpb24pID0+IChwb2ludHNfaWRzW29ic2VydmF0aW9uLnBvaW50X2lkXSA9IHRydWUpLFxuICAgICk7XG4gIH1cbiAgcmV0dXJuIHBvaW50c19pZHM7XG59O1xuXG5jb25zdCBnZXRBcmVhc1RvQ2VudGVyQnkgPSAoXG4gIGdsb2JhbF9kYXRhOiBJR2xvYmFsU3RhdGUsXG4gIG1hcHBlZEFyZWFzOiBJQXJlYVtdLFxuKSA9PiB7XG4gIGNvbnN0IGZpbHRlcnMgPSBnbG9iYWxfZGF0YT8uYWN0aXZlRmlsdGVyPy5maWx0ZXJfaXRlbXM7XG5cbiAgaWYgKCFmaWx0ZXJzIHx8IGZpbHRlcnMubGVuZ3RoIDwgMSkge1xuICAgIHJldHVybiBudWxsO1xuICB9XG5cbiAgY29uc3QgYXJlYUZpbHRlciA9IGZpbHRlcnMuZmluZCgoZmlsdGVyKSA9PiBmaWx0ZXIudHlwZSA9PT0gJ0FyZWFGaWx0ZXJJdGVtJyk7XG5cbiAgaWYgKGFyZWFGaWx0ZXIgJiYgYXJlYUZpbHRlci5zZWxlY3RlZF9vcHRpb25zLmxlbmd0aCA+IDApIHtcbiAgICBjb25zdCBhcmVhSURzID0gYXJlYUZpbHRlci5zZWxlY3RlZF9vcHRpb25zLm1hcCgoaXRlbSkgPT4gTnVtYmVyKGl0ZW0pKTtcbiAgICBjb25zdCBhcmVhcyA9IG1hcHBlZEFyZWFzLmZpbHRlcigoQXJlYSkgPT4gYXJlYUlEcy5pbmNsdWRlcyhBcmVhLmFyZWFfaWQpKTtcblxuICAgIHJldHVybiBhcmVhcz8ubWFwKChhcmVhKSA9PiBhcmVhLnNoYXBlX2RhdGEpLmZsYXQoKTtcbiAgfVxuXG4gIHJldHVybiBtYXBwZWRBcmVhcz8ubWFwKChhcmVhKSA9PiBhcmVhLnNoYXBlX2RhdGEpLmZsYXQoKTtcbn07XG5cbmNvbnN0IGFyZWFzTWFwcGVyID0gKGFyZWFzX2RhdGEsIGlzVGltZUZpbHRlck5vdFNlbGVjdGVkKSA9PiB7XG4gIHJldHVybiBhcmVhc19kYXRhLm5ld0FyZWFzLm1hcCgoYXJlYSkgPT4ge1xuICAgIGNvbnN0IG5ld0FyZWEgPSB7IC4uLmFyZWEgfTtcbiAgICBuZXdBcmVhLnNob3dDb2xvck9ubHlJbkJvcmRlcnMgPSB0cnVlO1xuICAgIC8vIGlmIChpc1RpbWVGaWx0ZXJOb3RTZWxlY3RlZCkge1xuICAgIC8vICAgbmV3QXJlYS5jb2xvciA9ICcjN2Y3ZjdmJztcbiAgICAvLyB9XG4gICAgcmV0dXJuIG5ld0FyZWE7XG4gIH0pO1xufTtcblxuZXhwb3J0IHtcbiAgYXJlYXNNYXBwZXIsXG4gIGdldEFyZWFzVG9DZW50ZXJCeSxcbiAgZ2V0Rm9jdXNlZEV2ZW50TXVzdFNlZW5TaXRlcyxcbiAgQ291bnRFdmVudHNQZXJTaXRlSUQsXG59O1xuIl0sIm1hcHBpbmdzIjoi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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.353-alpha.8",
3
+ "version": "1.2.354-alpha.0",
4
4
  "main": "lib/index.js",
5
5
  "author": "Nadav(Private) <nadavk72@gmail.com>",
6
6
  "scripts": {
@@ -27,7 +27,7 @@
27
27
  },
28
28
  "proxy": "http://localhost:3000",
29
29
  "engines": {
30
- "node": "14"
30
+ "node": "*"
31
31
  },
32
32
  "dependencies": {
33
33
  "@babel/plugin-proposal-private-methods": "^7.18.6",