@kando-env/kando-ui 1.2.345 → 1.2.346

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.
@@ -59,9 +59,7 @@ const InfoBar = _ref => {
59
59
  isRtl
60
60
  } = (0, _useNavContext.useNavContext)();
61
61
  const history = (0, _reactRouterDom.useHistory)();
62
- const {
63
- focusedArea
64
- } = (0, _reactRedux.useSelector)(state => state.wwtp_dashboard);
62
+ const focusedArea = (0, _reactRedux.useSelector)(state => state.wwtp_dashboard.focusedArea);
65
63
  const isArea = focusedArea === null || focusedArea === void 0 ? void 0 : focusedArea.area_id;
66
64
  const dashboardName = isArea ? (focusedArea === null || focusedArea === void 0 ? void 0 : focusedArea.is_virtual) ? 'Varea' : 'Area' : 'Site';
67
65
  const breadcrumbsUrl = (0, _urls.urls)({
@@ -82,14 +80,14 @@ const InfoBar = _ref => {
82
80
  }
83
81
  };
84
82
  (0, _react.useEffect)(() => {
85
- if (focusedArea && focusedArea.area_id) {
83
+ if ((focusedArea === null || focusedArea === void 0 ? void 0 : focusedArea.id) || (focusedArea === null || focusedArea === void 0 ? void 0 : focusedArea.area_id)) {
86
84
  fetchAreaData(breadcrumbsUrl).catch(e => {
87
85
  console.error('Request error: ' + e.message);
88
86
  });
89
87
  } else {
90
88
  setPartList(parts);
91
89
  }
92
- }, [focusedArea]);
90
+ }, [focusedArea === null || focusedArea === void 0 ? void 0 : focusedArea.id, focusedArea === null || focusedArea === void 0 ? void 0 : focusedArea.area_id]);
93
91
  (0, _react.useEffect)(() => {
94
92
  setPartList(parts);
95
93
  }, [parts]);
@@ -175,4 +173,4 @@ const NavItem = (0, _styledComponents.default)(_reactBootstrap.Nav.Link).withCon
175
173
  } = _ref5;
176
174
  return is_active ? theme.colorScheme.natural.n90 : theme.colorScheme.natural.n60;
177
175
  });
178
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_Breadcrumbs","_Search","_interopRequireDefault","_reactBootstrap","_Navbar","_TimeFilter","_dots","_TopNavbar","_Analytics","_reactRedux","_reactI18next","_useNavContext","_useQueryURL","_reactRouterDom","_urls","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","classNamesTabs","dashboard","map_active","map","dashboard_active","InfoBar","_ref","parts","mapDisable","partList","setPartList","useState","queryURL","useQueryURL","activeTab","waterAuthorityName","waterAuthorityId","useSelector","_ref2","global_data","views","includes","isRtl","useNavContext","history","useHistory","focusedArea","state","wwtp_dashboard","isArea","area_id","dashboardName","is_virtual","breadcrumbsUrl","urls","areaID","siteID","id","name","fetchAreaData","url","response","fetch","ok","data","json","link","breadcrumbs","Error","concat","status","useEffect","catch","e","console","error","message","setNav","navKey","analyticsTrack","selection","page_name","window","location","pathname","utility_name","push","createElement","expand","className","Toggle","ReactComponent","Col","md","sm","xs","Collapse","Nav","Text","Breadcrumbs","NavItem","is_active","onClick","disabled","MapSvg","MapActiveSvg","Trans","i18nKey","placement","DashboardSvg","DashboardActiveSvg","exports","styled","Link","withConfig","displayName","componentId","_ref3","theme","colorScheme","natural","n90","n60","_ref4","primary","p1","_ref5"],"sources":["../../../../src/components/Header/InfoBar/InfoBar.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react';\nimport { Breadcrumbs } from './Breadcrumbs/Breadcrumbs';\nimport Search from './Search';\nimport { Col, Nav } from 'react-bootstrap';\nimport Navbar from 'react-bootstrap/Navbar';\nimport TimeFilter from './TimeFilter';\nimport { ReactComponent as ToggleIconSvg } from 'src/assets/icons/3-dots.svg';\nimport {\n  DashboardActiveSvg,\n  DashboardSvg,\n  MapActiveSvg,\n  MapSvg,\n} from 'src/assets/icons/TopNavbar';\nimport { analyticsTrack } from 'src/utilities/Analytics';\nimport { useSelector } from 'react-redux';\nimport { Trans } from 'react-i18next';\nimport styled from 'styled-components/macro';\nimport { useNavContext } from 'src/hooks/useNavContext';\nimport useQueryURL from 'src/hooks/useQueryURL';\nimport { useHistory } from 'react-router-dom';\nimport { urls } from 'src/utilities/urls';\nimport { Part } from './types';\n\ninterface InfoBarProps {\n  parts: Part[];\n  mapDisable?: boolean;\n}\nconst classNamesTabs = {\n  dashboard: { dashboard: 'd-none', map_active: 'd-none' },\n  map: { dashboard_active: 'd-none', map: 'd-none' },\n};\nexport const InfoBar: React.FC<InfoBarProps> = ({\n  parts,\n  mapDisable = true,\n}) => {\n  const [partList, setPartList] = useState(parts);\n  const queryURL = useQueryURL();\n  let activeTab = mapDisable\n    ? 'dashboard'\n    : queryURL.get('view') || 'dashboard';\n  const { waterAuthorityName, waterAuthorityId } = useSelector(\n    ({ global_data }) => global_data,\n  );\n  const views = ['map', 'dashboard'];\n  if (!views.includes(activeTab)) {\n    activeTab = 'dashboard';\n    queryURL.set('view', 'dashboard');\n  }\n  const { isRtl } = useNavContext();\n  const history = useHistory();\n  const { focusedArea } = useSelector((state) => state.wwtp_dashboard);\n  const isArea = focusedArea?.area_id;\n  const dashboardName = isArea\n    ? focusedArea?.is_virtual\n      ? 'Varea'\n      : 'Area'\n    : 'Site';\n  const breadcrumbsUrl = urls({\n    areaID: focusedArea?.area_id,\n    siteID: focusedArea?.id,\n    waterAuthorityId,\n  }).dashboard[dashboardName].name;\n\n  const fetchAreaData = async (url: string) => {\n    const response = await fetch(url);\n    if (response.ok) {\n      const data = await response.json();\n      setPartList([\n        {\n          link: '/dashboard_v2/index',\n          name: waterAuthorityName,\n        },\n        ...data.data.breadcrumbs,\n      ]);\n    } else {\n      throw new Error(`HTTP error! status: ${response.status}`);\n    }\n  };\n  useEffect(() => {\n    if (focusedArea && focusedArea.area_id) {\n      fetchAreaData(breadcrumbsUrl).catch((e) => {\n        console.error('Request error: ' + e.message);\n      });\n    } else {\n      setPartList(parts);\n    }\n  }, [focusedArea]);\n\n  useEffect(() => {\n    setPartList(parts);\n  }, [parts]);\n\n  const setNav = (navKey) => {\n    if (activeTab === navKey) {\n      return;\n    }\n    queryURL.set('view', navKey);\n    analyticsTrack('Click top bar nav switch', {\n      selection: navKey,\n      page_name: window.location.pathname,\n      utility_name: waterAuthorityName,\n    });\n    history.push(`${window.location.pathname}?${queryURL}`);\n  };\n  return (\n    <Navbar\n      expand=\"md\"\n      className=\"bg-white mt-5 pt-3 pb-0 p-md-0 mt-md-1 my-md-0 border-bottom border-top\"\n    >\n      <Navbar.Toggle\n        aria-controls=\"basic-navbar-nav\"\n        className={'p-2 me-2 my-auto border-0'}\n      >\n        <ToggleIconSvg />\n      </Navbar.Toggle>\n      <Col md={'auto'} sm={'auto'} xs={'auto'}>\n        <Navbar.Collapse id=\"basic-navbar-nav\">\n          <Nav\n            className={`${\n              isRtl ? 'border-left' : 'border-right'\n            } py-md-1 mx-md-0 px-1`}\n          >\n            <Navbar.Text className={'me-2'}>\n              <Search />\n            </Navbar.Text>\n            <Navbar.Text className={'me-2'}>\n              <TimeFilter />\n            </Navbar.Text>\n          </Nav>\n        </Navbar.Collapse>\n      </Col>\n      {partList && (\n        <Navbar.Text\n          className={`d-none d-md-block my-auto mx-1 ${\n            isRtl ? 'ml-auto' : 'mr-auto'\n          }`}\n        >\n          <Breadcrumbs parts={partList} />\n        </Navbar.Text>\n      )}\n      <NavItem\n        is_active={activeTab === 'map'}\n        onClick={() => setNav('map')}\n        disabled={mapDisable}\n        className={'mb-n1'}\n      >\n        <MapSvg className={`${classNamesTabs[activeTab].map} me-2`} />\n        <MapActiveSvg\n          className={`${classNamesTabs[activeTab].map_active} me-2`}\n        />\n        <Trans i18nKey={'header.map'} />\n      </NavItem>\n      <NavItem\n        placement=\"end\"\n        is_active={activeTab === 'dashboard'}\n        disabled={mapDisable}\n        className={'mb-n1'}\n        onClick={() => setNav('dashboard')}\n      >\n        <DashboardSvg\n          className={`${classNamesTabs[activeTab].dashboard} me-2`}\n        />\n        <DashboardActiveSvg\n          className={`${classNamesTabs[activeTab].dashboard_active} me-2`}\n        />\n        <Trans i18nKey={'header.dashboard'} />\n      </NavItem>\n    </Navbar>\n  );\n};\n\nconst NavItem = styled(Nav.Link)<{ is_active: boolean }>`\n  padding-left: 20px;\n  padding-right: 20px;\n  margin-top: 12px;\n  color: ${({ theme, is_active }) =>\n    is_active ? theme.colorScheme.natural.n90 : theme.colorScheme.natural.n60};\n  ${({ theme, is_active }) =>\n    is_active && `border-bottom: 2px solid ${theme.colorScheme.primary.p1};`}\n  &:hover {\n    color: ${({ theme, is_active }) =>\n      is_active\n        ? theme.colorScheme.natural.n90\n        : theme.colorScheme.natural.n60};\n  }\n`;\n"],"mappings":"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"}
176
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_Breadcrumbs","_Search","_interopRequireDefault","_reactBootstrap","_Navbar","_TimeFilter","_dots","_TopNavbar","_Analytics","_reactRedux","_reactI18next","_useNavContext","_useQueryURL","_reactRouterDom","_urls","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","classNamesTabs","dashboard","map_active","map","dashboard_active","InfoBar","_ref","parts","mapDisable","partList","setPartList","useState","queryURL","useQueryURL","activeTab","waterAuthorityName","waterAuthorityId","useSelector","_ref2","global_data","views","includes","isRtl","useNavContext","history","useHistory","focusedArea","state","wwtp_dashboard","isArea","area_id","dashboardName","is_virtual","breadcrumbsUrl","urls","areaID","siteID","id","name","fetchAreaData","url","response","fetch","ok","data","json","link","breadcrumbs","Error","concat","status","useEffect","catch","e","console","error","message","setNav","navKey","analyticsTrack","selection","page_name","window","location","pathname","utility_name","push","createElement","expand","className","Toggle","ReactComponent","Col","md","sm","xs","Collapse","Nav","Text","Breadcrumbs","NavItem","is_active","onClick","disabled","MapSvg","MapActiveSvg","Trans","i18nKey","placement","DashboardSvg","DashboardActiveSvg","exports","styled","Link","withConfig","displayName","componentId","_ref3","theme","colorScheme","natural","n90","n60","_ref4","primary","p1","_ref5"],"sources":["../../../../src/components/Header/InfoBar/InfoBar.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react';\nimport { Breadcrumbs } from './Breadcrumbs/Breadcrumbs';\nimport Search from './Search';\nimport { Col, Nav } from 'react-bootstrap';\nimport Navbar from 'react-bootstrap/Navbar';\nimport TimeFilter from './TimeFilter';\nimport { ReactComponent as ToggleIconSvg } from 'src/assets/icons/3-dots.svg';\nimport {\n  DashboardActiveSvg,\n  DashboardSvg,\n  MapActiveSvg,\n  MapSvg,\n} from 'src/assets/icons/TopNavbar';\nimport { analyticsTrack } from 'src/utilities/Analytics';\nimport { useSelector } from 'react-redux';\nimport { Trans } from 'react-i18next';\nimport styled from 'styled-components/macro';\nimport { useNavContext } from 'src/hooks/useNavContext';\nimport useQueryURL from 'src/hooks/useQueryURL';\nimport { useHistory } from 'react-router-dom';\nimport { urls } from 'src/utilities/urls';\nimport { Part } from './types';\n\ninterface InfoBarProps {\n  parts: Part[];\n  mapDisable?: boolean;\n}\nconst classNamesTabs = {\n  dashboard: { dashboard: 'd-none', map_active: 'd-none' },\n  map: { dashboard_active: 'd-none', map: 'd-none' },\n};\nexport const InfoBar: React.FC<InfoBarProps> = ({\n  parts,\n  mapDisable = true,\n}) => {\n  const [partList, setPartList] = useState(parts);\n  const queryURL = useQueryURL();\n  let activeTab = mapDisable\n    ? 'dashboard'\n    : queryURL.get('view') || 'dashboard';\n  const { waterAuthorityName, waterAuthorityId } = useSelector(\n    ({ global_data }) => global_data,\n  );\n  const views = ['map', 'dashboard'];\n  if (!views.includes(activeTab)) {\n    activeTab = 'dashboard';\n    queryURL.set('view', 'dashboard');\n  }\n  const { isRtl } = useNavContext();\n  const history = useHistory();\n  const focusedArea = useSelector((state) => state.wwtp_dashboard.focusedArea);\n  const isArea = focusedArea?.area_id;\n  const dashboardName = isArea\n    ? focusedArea?.is_virtual\n      ? 'Varea'\n      : 'Area'\n    : 'Site';\n  const breadcrumbsUrl = urls({\n    areaID: focusedArea?.area_id,\n    siteID: focusedArea?.id,\n    waterAuthorityId,\n  }).dashboard[dashboardName].name;\n\n  const fetchAreaData = async (url: string) => {\n    const response = await fetch(url);\n    if (response.ok) {\n      const data = await response.json();\n      setPartList([\n        {\n          link: '/dashboard_v2/index',\n          name: waterAuthorityName,\n        },\n        ...data.data.breadcrumbs,\n      ]);\n    } else {\n      throw new Error(`HTTP error! status: ${response.status}`);\n    }\n  };\n  useEffect(() => {\n    if (focusedArea?.id || focusedArea?.area_id) {\n      fetchAreaData(breadcrumbsUrl).catch((e) => {\n        console.error('Request error: ' + e.message);\n      });\n    } else {\n      setPartList(parts);\n    }\n  }, [focusedArea?.id, focusedArea?.area_id]);\n\n  useEffect(() => {\n    setPartList(parts);\n  }, [parts]);\n\n  const setNav = (navKey) => {\n    if (activeTab === navKey) {\n      return;\n    }\n    queryURL.set('view', navKey);\n    analyticsTrack('Click top bar nav switch', {\n      selection: navKey,\n      page_name: window.location.pathname,\n      utility_name: waterAuthorityName,\n    });\n    history.push(`${window.location.pathname}?${queryURL}`);\n  };\n  return (\n    <Navbar\n      expand=\"md\"\n      className=\"bg-white mt-5 pt-3 pb-0 p-md-0 mt-md-1 my-md-0 border-bottom border-top\"\n    >\n      <Navbar.Toggle\n        aria-controls=\"basic-navbar-nav\"\n        className={'p-2 me-2 my-auto border-0'}\n      >\n        <ToggleIconSvg />\n      </Navbar.Toggle>\n      <Col md={'auto'} sm={'auto'} xs={'auto'}>\n        <Navbar.Collapse id=\"basic-navbar-nav\">\n          <Nav\n            className={`${\n              isRtl ? 'border-left' : 'border-right'\n            } py-md-1 mx-md-0 px-1`}\n          >\n            <Navbar.Text className={'me-2'}>\n              <Search />\n            </Navbar.Text>\n            <Navbar.Text className={'me-2'}>\n              <TimeFilter />\n            </Navbar.Text>\n          </Nav>\n        </Navbar.Collapse>\n      </Col>\n      {partList && (\n        <Navbar.Text\n          className={`d-none d-md-block my-auto mx-1 ${\n            isRtl ? 'ml-auto' : 'mr-auto'\n          }`}\n        >\n          <Breadcrumbs parts={partList} />\n        </Navbar.Text>\n      )}\n      <NavItem\n        is_active={activeTab === 'map'}\n        onClick={() => setNav('map')}\n        disabled={mapDisable}\n        className={'mb-n1'}\n      >\n        <MapSvg className={`${classNamesTabs[activeTab].map} me-2`} />\n        <MapActiveSvg\n          className={`${classNamesTabs[activeTab].map_active} me-2`}\n        />\n        <Trans i18nKey={'header.map'} />\n      </NavItem>\n      <NavItem\n        placement=\"end\"\n        is_active={activeTab === 'dashboard'}\n        disabled={mapDisable}\n        className={'mb-n1'}\n        onClick={() => setNav('dashboard')}\n      >\n        <DashboardSvg\n          className={`${classNamesTabs[activeTab].dashboard} me-2`}\n        />\n        <DashboardActiveSvg\n          className={`${classNamesTabs[activeTab].dashboard_active} me-2`}\n        />\n        <Trans i18nKey={'header.dashboard'} />\n      </NavItem>\n    </Navbar>\n  );\n};\n\nconst NavItem = styled(Nav.Link)<{ is_active: boolean }>`\n  padding-left: 20px;\n  padding-right: 20px;\n  margin-top: 12px;\n  color: ${({ theme, is_active }) =>\n    is_active ? theme.colorScheme.natural.n90 : theme.colorScheme.natural.n60};\n  ${({ theme, is_active }) =>\n    is_active && `border-bottom: 2px solid ${theme.colorScheme.primary.p1};`}\n  &:hover {\n    color: ${({ theme, is_active }) =>\n      is_active\n        ? theme.colorScheme.natural.n90\n        : theme.colorScheme.natural.n60};\n  }\n`;\n"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
 
3
- const packageJsonVersion = "1.2.345";
3
+ const packageJsonVersion = "1.2.346";
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));
@@ -77,4 +77,4 @@ const fetchCapacity = async (type, id, waterAuthorityId) => {
77
77
  return await fetchData(type, id, waterAuthorityId);
78
78
  };
79
79
  exports.fetchCapacity = fetchCapacity;
80
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_utils","require","fetchData","type","id","waterAuthorityId","response","fetch","concat","data","json","error","console","getPoints","list","points_data","returnedPoints","map","item","find","point","exports","getAreas","areaIds","areas","length","returnedAreas","correspondingArea","area","area_id","setFocusedItem","object","listItems","points","dispatch","setFocusedArea","showExtra","arguments","undefined","utility","sub_areas","filter","has_parent","area_name","forWWTPMap","subAreas","focusedPoint","factories","shape_data","latitude","longitude","focusedArea","_focusedArea$sub_area","sortAreas","fetchCapacity"],"sources":["../../../src/pages/DashboardMap/Capacity.ts"],"sourcesContent":["import { IArea } from 'src/store/areas/models/IArea';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport { sortAreas } from './utils';\n\nconst fetchData = async (\n  type: string,\n  id: number,\n  waterAuthorityId: number,\n) => {\n  try {\n    const response = await fetch(\n      `/api_ui/wwtp_page/${type}/${id}/capacity?&water_authority_id=${waterAuthorityId}`,\n    );\n    const data = await response.json();\n    return data;\n  } catch (error) {\n    console.error('Error fetching capacity data:', error);\n    throw error;\n  }\n};\n\nexport const getPoints = (list: any[], points_data: IPoint[]) => {\n  const returnedPoints = list.map((item) => {\n    return points_data.find((point) => point.id === item.id);\n  });\n  return returnedPoints;\n};\n\nexport const getAreas = (areaIds: any[], areas: IArea[]) => {\n  if (areaIds.length === 0 || !areas) return [];\n\n  const returnedAreas = areaIds.map((id) => {\n    const correspondingArea = areas.find((area) => area.area_id === id);\n    return correspondingArea;\n  });\n\n  return returnedAreas;\n};\n\nexport const setFocusedItem = (\n  object,\n  listItems,\n  points,\n  areas,\n  dispatch,\n  setFocusedArea,\n  showExtra = false,\n) => {\n  if (!object && areas && areas.length > 0) {\n    const utility = {\n      sub_areas: areas?.filter((area) => area.has_parent === false),\n      area_id: null,\n      area_name: '',\n    };\n    dispatch(setFocusedArea(utility));\n  } else {\n    if (!listItems) {\n      return;\n    }\n\n    if (object.forWWTPMap) {\n      const areaIds = listItems.map((item) => item.id);\n      const subAreas = getAreas(areaIds, areas);\n      const focusedPoint = {\n        ...object,\n        factories: subAreas.length > 0 ? [] : getPoints(listItems, points),\n        sub_areas: subAreas,\n        shape_data: [[object.latitude, object.longitude]],\n        showExtra: showExtra,\n      };\n      dispatch(setFocusedArea(focusedPoint));\n    } else {\n      let focusedArea = object;\n      if (listItems && listItems.length > 0) {\n        const sub_areas = sortAreas(focusedArea?.sub_areas);\n        const area = {\n          ...focusedArea,\n          sub_areas: sub_areas,\n          factories:\n            focusedArea?.sub_areas?.length > 0\n              ? []\n              : getPoints(listItems, points),\n        };\n        dispatch(setFocusedArea(area));\n      } else {\n        dispatch(setFocusedArea(focusedArea));\n      }\n    }\n  }\n};\n\nexport const fetchCapacity = async (\n  type: string,\n  id: number,\n  waterAuthorityId: number,\n) => {\n  return await fetchData(type, id, waterAuthorityId);\n};\n"],"mappings":"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"}
80
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_utils","require","fetchData","type","id","waterAuthorityId","response","fetch","concat","data","json","error","console","getPoints","list","points_data","returnedPoints","map","item","find","point","exports","getAreas","areaIds","areas","length","returnedAreas","correspondingArea","area","area_id","setFocusedItem","object","listItems","points","dispatch","setFocusedArea","showExtra","arguments","undefined","utility","sub_areas","filter","has_parent","area_name","forWWTPMap","subAreas","focusedPoint","factories","shape_data","latitude","longitude","focusedArea","_focusedArea$sub_area","sortAreas","fetchCapacity"],"sources":["../../../src/pages/DashboardMap/Capacity.ts"],"sourcesContent":["import { IArea } from 'src/store/areas/models/IArea';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport { sortAreas } from './utils';\n\nconst fetchData = async (\n  type: string,\n  id: number,\n  waterAuthorityId: number,\n) => {\n  try {\n    const response = await fetch(\n      `/api_ui/wwtp_page/${type}/${id}/capacity?&water_authority_id=${waterAuthorityId}`,\n    );\n    const data = await response.json();\n    return data;\n  } catch (error) {\n    console.error('Error fetching capacity data:', error);\n    throw error;\n  }\n};\n\nexport const getPoints = (list: any[], points_data: IPoint[]) => {\n  const returnedPoints = list.map((item) => {\n    return points_data.find((point) => point.id === item.id);\n  });\n  return returnedPoints;\n};\n\nexport const getAreas = (areaIds: any[], areas: IArea[]) => {\n  if (areaIds.length === 0 || !areas) return [];\n\n  const returnedAreas = areaIds.map((id) => {\n    const correspondingArea = areas.find((area) => area.area_id === id);\n    return correspondingArea;\n  });\n\n  return returnedAreas;\n};\n\nexport const setFocusedItem = (\n  object,\n  listItems,\n  points,\n  areas,\n  dispatch,\n  setFocusedArea,\n  showExtra = false,\n) => {\n  if (!object && areas && areas.length > 0) {\n    const utility = {\n      sub_areas: areas?.filter((area) => area.has_parent === false),\n      area_id: null,\n      area_name: '',\n    };\n    dispatch(setFocusedArea(utility));\n  } else {\n    if (!listItems) {\n      return;\n    }\n    if (object.forWWTPMap) {\n      const areaIds = listItems.map((item) => item.id);\n      const subAreas = getAreas(areaIds, areas);\n      const focusedPoint = {\n        ...object,\n        factories: subAreas.length > 0 ? [] : getPoints(listItems, points),\n        sub_areas: subAreas,\n        shape_data: [[object.latitude, object.longitude]],\n        showExtra: showExtra,\n      };\n      dispatch(setFocusedArea(focusedPoint));\n    } else {\n      let focusedArea = object;\n      if (listItems && listItems.length > 0) {\n        const sub_areas = sortAreas(focusedArea?.sub_areas);\n        const area = {\n          ...focusedArea,\n          sub_areas: sub_areas,\n          factories:\n            focusedArea?.sub_areas?.length > 0\n              ? []\n              : getPoints(listItems, points),\n        };\n        dispatch(setFocusedArea(area));\n      } else {\n        dispatch(setFocusedArea(focusedArea));\n      }\n    }\n  }\n};\n\nexport const fetchCapacity = async (\n  type: string,\n  id: number,\n  waterAuthorityId: number,\n) => {\n  return await fetchData(type, id, waterAuthorityId);\n};\n"],"mappings":"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"}
@@ -19,15 +19,16 @@ var _i18n = _interopRequireDefault(require("utilities/i18n"));
19
19
  var _DischargePattern = require("../SitePage/DischargePattern/DischargePattern");
20
20
  var _QualitySummary = require("Widgets/QualitySummary/QualitySummary");
21
21
  var _LineChart = require("pages/AreaPage/Dashboard/LineChart/LineChart");
22
+ var _WWTPDashboardSlice = require("store/WWTPDashboard/WWTPDashboardSlice");
22
23
  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); }
23
24
  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; }
24
25
  const List = props => {
25
26
  var _WWTPInfo$point, _WWTPInfo$point2;
26
27
  const ReduxState = (0, _reactRedux.useSelector)(state => state);
27
28
  const {
28
- areas_data,
29
- points_data
29
+ areas_data
30
30
  } = ReduxState;
31
+ const dispatch = (0, _reactRedux.useDispatch)();
31
32
  const {
32
33
  selectedItem,
33
34
  handleSelectItem
@@ -39,18 +40,20 @@ const List = props => {
39
40
  focusedArea,
40
41
  map
41
42
  } = (0, _reactRedux.useSelector)(state => state.wwtp_dashboard);
42
- const [areas, setAreas] = (0, _react.useState)(null);
43
43
  const selectedRef = (0, _react.useRef)(null);
44
44
  const siteID = (_WWTPInfo$point = WWTPInfo.point) === null || _WWTPInfo$point === void 0 ? void 0 : _WWTPInfo$point.id;
45
45
  const handleItemClick = item => {
46
46
  handleSelectItem(item);
47
47
  };
48
48
  const noDataMessage = _i18n.default.t('wwtpPage.no_data_for_site');
49
- let areaDetails = (0, _react.useMemo)(() => {
50
- var _focusedArea$sub_area;
51
- const is_no_areas = focusedArea && (focusedArea === null || focusedArea === void 0 ? void 0 : focusedArea.forWWTPMap) === true && (!areas || areas.length === 0);
49
+ let listDetails = (0, _react.useMemo)(() => {
50
+ var _focusedArea$sub_area, _focusedArea$sub_area2;
51
+ if (!siteID && !focusedArea) {
52
+ return;
53
+ }
54
+ const is_no_areas = focusedArea && (focusedArea === null || focusedArea === void 0 ? void 0 : focusedArea.forWWTPMap) === true && siteID !== undefined && ((_focusedArea$sub_area = focusedArea.sub_areas) === null || _focusedArea$sub_area === void 0 ? void 0 : _focusedArea$sub_area.length) === 0;
52
55
  if (is_no_areas) {
53
- if ((focusedArea === null || focusedArea === void 0 ? void 0 : focusedArea.has_device) === false || !siteID) {
56
+ if ((focusedArea === null || focusedArea === void 0 ? void 0 : focusedArea.clicked) === undefined || (focusedArea === null || focusedArea === void 0 ? void 0 : focusedArea.has_device) === false || !siteID) {
54
57
  return /*#__PURE__*/_react.default.createElement(ListContainer, null, /*#__PURE__*/_react.default.createElement(ErrorMessage, null, noDataMessage));
55
58
  } else {
56
59
  return /*#__PURE__*/_react.default.createElement(ListContainer, null, /*#__PURE__*/_react.default.createElement(SummaryComponent, {
@@ -64,8 +67,8 @@ const List = props => {
64
67
  }));
65
68
  }
66
69
  }
67
- if ((focusedArea === null || focusedArea === void 0 ? void 0 : (_focusedArea$sub_area = focusedArea.sub_areas) === null || _focusedArea$sub_area === void 0 ? void 0 : _focusedArea$sub_area.length) !== 0) {
68
- return areas && (0, _utils.sortAreas)(areas).filter(Boolean).map(area => /*#__PURE__*/_react.default.createElement(_AreaCard.AreaCard, {
70
+ if (focusedArea && (focusedArea === null || focusedArea === void 0 ? void 0 : (_focusedArea$sub_area2 = focusedArea.sub_areas) === null || _focusedArea$sub_area2 === void 0 ? void 0 : _focusedArea$sub_area2.length) > 0) {
71
+ return focusedArea.sub_areas && (0, _utils.sortAreas)(focusedArea.sub_areas).filter(Boolean).map(area => /*#__PURE__*/_react.default.createElement(_AreaCard.AreaCard, {
69
72
  key: area.area_id,
70
73
  object: area,
71
74
  mapRef: map,
@@ -84,27 +87,41 @@ const List = props => {
84
87
  itemRef: selectedItem === factory.id ? selectedRef : null
85
88
  }));
86
89
  }
87
- return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null);
88
90
  }
89
- }, [selectedItem, areas]);
90
- (0, _react.useEffect)(() => {
91
- setAreas(areas_data.newAreas);
92
- }, [areas_data, points_data]);
91
+ }, [selectedItem, siteID, focusedArea]);
92
+
93
+ // Update the list only if the score of at least one of the sub-areas has changed
93
94
  (0, _react.useEffect)(() => {
94
- // the map layers is an object but before the map is loaded it is a zero lengthed array
95
- if (focusedArea != null && map !== null && typeof map._layers === 'object' && map._layers.length === undefined) {
96
- const isAPoint = focusedArea.forWWTPMap !== undefined;
97
- const WWTPInfo = {
98
- point: isAPoint ? focusedArea : undefined,
99
- area: !isAPoint ? focusedArea : undefined
95
+ if (focusedArea && focusedArea.sub_areas && focusedArea.sub_areas.length > 0 && areas_data && focusedArea.sub_areas.length === areas_data.newAreas.length) {
96
+ const isSubAreasEqual = compareArraysByIdAndScore(areas_data.newAreas, focusedArea.sub_areas);
97
+ if (isSubAreasEqual) return;
98
+ const focusedAreaWithUpdatedSubAreas = {
99
+ ...focusedArea,
100
+ sub_areas: areas_data.newAreas
100
101
  };
101
- (0, _utils.areaFocusLogic)({
102
- WWTPInfo,
103
- setAreas,
104
- map
105
- });
102
+ dispatch((0, _WWTPDashboardSlice.setFocusedArea)(focusedAreaWithUpdatedSubAreas));
106
103
  }
107
- }, [focusedArea]);
104
+ }, [areas_data]);
105
+ function compareArraysByIdAndScore(arr1, arr2) {
106
+ // Iterate over each object in the first array
107
+ for (let item1 of arr1) {
108
+ // Find the object with the same id in the second array
109
+ let matchingItem = arr2.find(item2 => item2.area_id === item1.area_id);
110
+
111
+ // If no matching item is found in the second array, return false
112
+ if (!matchingItem) {
113
+ return false;
114
+ }
115
+
116
+ // If the scores don't match, return false
117
+ if (item1.area_score !== matchingItem.area_score) {
118
+ return false;
119
+ }
120
+ }
121
+
122
+ // If all items matched and had the same score, return true
123
+ return true;
124
+ }
108
125
  (0, _react.useEffect)(() => {
109
126
  var _selectedRef$current;
110
127
  (_selectedRef$current = selectedRef.current) === null || _selectedRef$current === void 0 ? void 0 : _selectedRef$current.scrollIntoView({
@@ -113,7 +130,7 @@ const List = props => {
113
130
  inline: 'center'
114
131
  });
115
132
  }, [selectedItem]);
116
- if ((focusedArea === null || focusedArea === void 0 ? void 0 : focusedArea.group) && focusedArea.group.type === 'Groups::WastewaterTreatmentPlant' && (focusedArea === null || focusedArea === void 0 ? void 0 : focusedArea.clicked) === undefined && (focusedArea === null || focusedArea === void 0 ? void 0 : focusedArea.showExtra) === false) return /*#__PURE__*/_react.default.createElement(WWTPDetails, {
133
+ if ((focusedArea === null || focusedArea === void 0 ? void 0 : focusedArea.group) && focusedArea.group.type === 'Groups::WastewaterTreatmentPlant' && (focusedArea === null || focusedArea === void 0 ? void 0 : focusedArea.clicked) === undefined) return /*#__PURE__*/_react.default.createElement(WWTPDetails, {
117
134
  className: "p-3",
118
135
  style: {
119
136
  overflow: 'scroll'
@@ -130,7 +147,7 @@ const List = props => {
130
147
  }
131
148
  }, /*#__PURE__*/_react.default.createElement("h3", null, (focusedArea === null || focusedArea === void 0 ? void 0 : focusedArea.area_name) || (focusedArea === null || focusedArea === void 0 ? void 0 : focusedArea.name)), /*#__PURE__*/_react.default.createElement("ul", {
132
149
  className: 'mx-n3'
133
- }, areaDetails));
150
+ }, listDetails));
134
151
  };
135
152
  exports.List = List;
136
153
  const WWTPDetails = _styledComponents.default.div.withConfig({
@@ -153,4 +170,4 @@ const ErrorMessage = _styledComponents.default.div.withConfig({
153
170
  displayName: "List__ErrorMessage",
154
171
  componentId: "sc-1f5wz2c-4"
155
172
  })(["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;"]);
156
- //# 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","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","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","points_data","selectedItem","handleSelectItem","useSelectedItem","WWTPInfo","focusedArea","map","wwtp_dashboard","areas","setAreas","useState","selectedRef","useRef","siteID","point","id","handleItemClick","item","noDataMessage","i18n","t","areaDetails","useMemo","_focusedArea$sub_area","is_no_areas","forWWTPMap","length","has_device","createElement","ListContainer","ErrorMessage","SummaryComponent","endpoint","concat","className","LineChartComponent","title","DischargePattern","Number","sub_areas","sortAreas","filter","Boolean","area","AreaCard","area_id","object","mapRef","onClick","selected","itemRef","factories","factory","FactoryCard","Fragment","useEffect","newAreas","_layers","undefined","isAPoint","areaFocusLogic","_selectedRef$current","current","scrollIntoView","behavior","block","inline","group","type","clicked","showExtra","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 { IPoint } from '../../store/points/models/IPoint';\nimport React, { useEffect, useMemo, useState, useRef } from 'react';\nimport styled from 'styled-components/macro';\nimport { theme } from 'src/styles/theme/theme';\nimport { useSelector } from 'react-redux';\nimport { appReducer } from '../../store/rootReducer';\nimport { areaFocusLogic, 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';\n\ntype IProps = {\n  global_data: any;\n  areas: IArea[] | null;\n  points: IPoint[] | null;\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, points_data } = ReduxState;\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 [areas, setAreas] = useState<IArea[] | null>(null);\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 areaDetails = useMemo(() => {\n    const is_no_areas =\n      focusedArea &&\n      focusedArea?.forWWTPMap === true &&\n      (!areas || areas.length === 0);\n\n    if (is_no_areas) {\n      if (focusedArea?.has_device === false || !siteID) {\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?.sub_areas?.length !== 0) {\n      return (\n        areas &&\n        sortAreas(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      return <></>;\n    }\n  }, [selectedItem, areas]);\n\n  useEffect(() => {\n    setAreas(areas_data.newAreas);\n  }, [areas_data, points_data]);\n\n  useEffect(() => {\n    // the map layers is an object but before the map is loaded it is a zero lengthed array\n    if (\n      focusedArea != null &&\n      map !== null &&\n      typeof map._layers === 'object' &&\n      map._layers.length === undefined\n    ) {\n      const isAPoint = focusedArea.forWWTPMap !== undefined;\n\n      const WWTPInfo = {\n        point: isAPoint ? focusedArea : undefined,\n        area: !isAPoint ? focusedArea : undefined,\n      };\n      areaFocusLogic({ WWTPInfo, setAreas, map });\n    }\n  }, [focusedArea]);\n\n  useEffect(() => {\n    selectedRef.current?.scrollIntoView({\n      behavior: 'smooth',\n      block: 'center',\n      inline: 'center',\n    });\n  }, [selectedItem]);\n  if (\n    focusedArea?.group &&\n    focusedArea.group.type === 'Groups::WastewaterTreatmentPlant' &&\n    focusedArea?.clicked === undefined &&\n    focusedArea?.showExtra === false\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'}>{areaDetails}</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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"}
173
+ //# 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","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","selectedItem","handleSelectItem","useSelectedItem","WWTPInfo","focusedArea","map","wwtp_dashboard","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","clicked","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","setFocusedArea","arr1","arr2","item1","matchingItem","find","item2","area_score","_selectedRef$current","current","scrollIntoView","behavior","block","inline","group","type","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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"}
@@ -115,9 +115,6 @@ const WWTPMap = props => {
115
115
  }, [wwtp_dashboard.map]);
116
116
  (0, _react.useEffect)(() => {
117
117
  if (!ReduxState.wwtp_dashboard.focusedArea || !wwtp_dashboard.map) return;
118
- // const map = {current: wwtp_dashboard.map};
119
-
120
- // areaFocusLogic(map, isValidArea, ReduxState.wwtp_dashboard.focusedArea);
121
118
  (0, _utils.focusMap)(ReduxState.wwtp_dashboard.focusedArea, wwtp_dashboard.map);
122
119
  }, [ReduxState.wwtp_dashboard.focusedArea]);
123
120
  if (!isMapTab) return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null);
@@ -130,8 +127,6 @@ const WWTPMap = props => {
130
127
  className: "d-none d-sm-flex"
131
128
  }, /*#__PURE__*/_react.default.createElement(_List.List, {
132
129
  global_data: global_data,
133
- areas: areas,
134
- points: points,
135
130
  WWTPInfo: WWTPInfo,
136
131
  dispatch: dispatch
137
132
  })), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Col, {
@@ -154,4 +149,4 @@ const Container = _styledComponents.default.div.withConfig({
154
149
  })(["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;}}}"]);
155
150
  var _default = WWTPMap;
156
151
  exports.default = _default;
157
- //# 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","focusMap","createElement","Fragment","Loader","SelectedItemProvider","Container","Row","className","Col","xs","sm","List","Map","edges","includeUnmonitoredPoints","forEventsView","forWWTPDashboard","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';\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    // const map = {current: wwtp_dashboard.map};\n\n    // areaFocusLogic(map, isValidArea, ReduxState.wwtp_dashboard.focusedArea);\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  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              areas={areas}\n              points={points}\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            />\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;AAMA,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,CAAAC,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,oBAAAA,GAAA,wBAAAA,GAAA,4BAAAE,OAAA,EAAAF,GAAA,UAAAG,KAAA,GAAAR,wBAAA,CAAAC,WAAA,OAAAO,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAJ,GAAA,YAAAG,KAAA,CAAAE,GAAA,CAAAL,GAAA,SAAAM,MAAA,WAAAC,qBAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,GAAA,IAAAX,GAAA,QAAAW,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAd,GAAA,EAAAW,GAAA,SAAAI,IAAA,GAAAR,qBAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAV,GAAA,EAAAW,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,IAAAX,GAAA,CAAAW,GAAA,SAAAL,MAAA,CAAAJ,OAAA,GAAAF,GAAA,MAAAG,KAAA,IAAAA,KAAA,CAAAa,GAAA,CAAAhB,GAAA,EAAAM,MAAA,YAAAA,MAAA;AAK3D,MAAMW,OAA4C,GAAIC,KAAK,IAAK;EAC9D,MAAMC,WAAW,GAAG,IAAAC,oBAAW,EAAC,CAAC;EACjC,MAAMC,QAAQ,GAAGF,WAAW,CAACd,GAAG,CAAC,MAAM,CAAC,KAAK,KAAK;EAClD,IAAI;IAAEiB,EAAE;IAAEC,MAAM;IAAEC;EAAO,CAAC,GAAG,IAAAC,yBAAS,EAAC,CAAC;EACxCH,EAAE,GAAGA,EAAE,IAAIC,MAAM,IAAIC,MAAM;EAC3B,MAAME,UAAU,GAAG,IAAAC,uBAAW,EAAEC,KAAK,IAAKA,KAAK,CAAC;EAChD,MAAMC,QAAQ,GAAG,IAAAC,uBAAW,EAAC,CAAC;EAC9B,MAAM;IAAEC,UAAU;IAAEC,WAAW;IAAEC,WAAW;IAAEC,UAAU;IAAEC;EAAe,CAAC,GACxET,UAAU;EACZ,MAAM,CAACU,MAAM,EAAEC,SAAS,CAAC,GAAG,IAAAC,eAAQ,EAAkB,IAAI,CAAC;EAC3D,MAAM,CAACC,KAAK,EAAEC,QAAQ,CAAC,GAAG,IAAAF,eAAQ,EAAiB,IAAI,CAAC;EACxD,MAAM,CAACG,QAAQ,EAAEC,WAAW,CAAC,GAAG,IAAAJ,eAAQ,EAGrC;IAAEK,KAAK,EAAE,IAAI;IAAEC,IAAI,EAAE;EAAK,CAAC,CAAC;EAC/B,IAAIC,UAAU,GAAGA,CAAA,KAAM;IACrB,OACEd,UAAU,CAACe,QAAQ,CAACC,MAAM,KAAK,CAAC,IAChCd,WAAW,CAACe,KAAK,CAACD,MAAM,KAAK,CAAC,IAC9Bb,UAAU,CAACc,KAAK,CAACD,MAAM,KAAK,CAAC;EAEjC,CAAC;EAED,IAAAE,gBAAS,EAAC,MAAM;IACd,IAAIjB,WAAW,CAACkB,gBAAgB,EAAE;MAChCrB,QAAQ,CAAC,IAAAsB,qBAAW,EAACnB,WAAW,CAACkB,gBAAgB,CAAC,CAAC;MACnDrB,QAAQ,CAAC,IAAAuB,oBAAU,EAACpB,WAAW,CAACkB,gBAAgB,CAAC,CAAC;MAClDrB,QAAQ,CACN,IAAAwB,mBAAU,EACRrB,WAAW,CAACkB,gBAAgB,EAC5BxB,UAAU,CAAC4B,SAAS,CAACC,MAAM,EAC3B,IACF,CACF,CAAC;IACH;EACF,CAAC,EAAE,CAAC7B,UAAU,CAAC4B,SAAS,CAACC,MAAM,CAAC,CAAC;EAEjC,IAAAN,gBAAS,EAAC,MAAM;IACd,IAAAO,yBAAkB,EAAC;MACjBzB,UAAU;MACVE,WAAW;MACXI,SAAS;MACTG,QAAQ;MACRE,WAAW;MACXG,UAAU;MACVvB;IACF,CAAC,CAAC;EACJ,CAAC,EAAE,CAACS,UAAU,CAAC,CAAC;EAEhB,IAAAkB,gBAAS,EAAC,MAAM;IACdP,WAAW,CAAC,IAAAe,wBAAiB,EAAC;MAAEnC,EAAE;MAAEW,WAAW;MAAEF;IAAW,CAAC,CAAC,CAAC;EACjE,CAAC,EAAE,CAACT,EAAE,CAAC,CAAC;;EAER;EACA;EACA;;EAEA,IAAA2B,gBAAS,EAAC,MAAM;IACd,IAAIjB,WAAW,CAACkB,gBAAgB,EAAE;MAChCjB,WAAW,CAACe,KAAK,CAACD,MAAM,KAAK,CAAC,IAC5BlB,QAAQ,CAAC,IAAAsB,qBAAW,EAACnB,WAAW,CAACkB,gBAAgB,CAAC,CAAC;MACrDhB,UAAU,CAACc,KAAK,CAACD,MAAM,KAAK,CAAC,IAC3BlB,QAAQ,CAAC,IAAAuB,oBAAU,EAACpB,WAAW,CAACkB,gBAAgB,CAAC,CAAC;MACpDnB,UAAU,CAACiB,KAAK,CAACD,MAAM,KAAK,CAAC,IAC3BlB,QAAQ,CACN,IAAAwB,mBAAU,EACRrB,WAAW,CAACkB,gBAAgB,EAC5BxB,UAAU,CAAC4B,SAAS,CAACC,MAAM,EAC3B,IACF,CACF,CAAC;IACL;IAEA,OAAO,SAASG,OAAOA,CAAA,EAAG;MACxBrB,SAAS,CAAC,IAAI,CAAC;MACfG,QAAQ,CAAC,IAAI,CAAC;MACdE,WAAW,CAAC;QAAEC,KAAK,EAAE,IAAI;QAAEC,IAAI,EAAE;MAAK,CAAC,CAAC;IAC1C,CAAC;EACH,CAAC,EAAE,CAACZ,WAAW,CAACkB,gBAAgB,CAAC,CAAC;EAElC,IAAAD,gBAAS,EAAC,MAAM;IACd,MAAMU,MAAM,GAAGlB,QAAQ,CAACG,IAAI,IAAIH,QAAQ,CAACE,KAAK;IAE9C,IAAItB,QAAQ,IAAIsC,MAAM,EAAE;MAAA,IAAAC,qBAAA;MACtB,MAAMC,IAAI,GAAGpB,QAAQ,CAACG,IAAI,GACtBe,MAAM,CAACG,UAAU,KAAK,IAAI,GACxB,OAAO,GACP,MAAM,GACR,MAAM;MAEV,MAAMC,WAAW,GACfF,IAAI,KAAK,MAAM,GACXF,MAAM,CAACrC,EAAE,CAAC0C,QAAQ,CAAC,CAAC,KAAK1C,EAAE,GAC3BqC,MAAM,CAACM,OAAO,KAAKC,QAAQ,CAAC5C,EAAE,CAAC;MAErC,MAAM6C,SAAS,GAAGR,MAAM,CAACrC,EAAE,OAAAsC,qBAAA,GAAKlC,UAAU,CAACS,cAAc,CAACiC,WAAW,cAAAR,qBAAA,uBAArCA,qBAAA,CAAuCtC,EAAE;MAEzE,IAAIyC,WAAW,EAAE;QACf,IAAAM,uBAAa,EAACR,IAAI,EAAEvC,EAAE,EAAEU,WAAW,CAACkB,gBAAgB,CAAC,CAACoB,IAAI,CACvDC,QAAQ,IAAK;UACZ,IAAAC,wBAAc,EACZb,MAAM,EACNY,QAAQ,CAACE,IAAI,EACbrC,MAAM,EACNG,KAAK,EACLV,QAAQ,EACR6C,kCAAc,EACdP,SACF,CAAC;QACH,CACF,CAAC;MACH;IACF,CAAC,MAAM;MACL,MAAMQ,cAAc,GAAG,IAAAC,gBAAS,EAACrC,KAAK,CAAC;MAEvC,IAAAiC,wBAAc,EACZK,SAAS,EACT,IAAI,EACJzC,MAAM,EACNuC,cAAc,EACd9C,QAAQ,EACR6C,kCAAc,EACd,IACF,CAAC;IACH;IACA;EACF,CAAC,EAAE,CAACvC,cAAc,CAAC2C,GAAG,CAAC,CAAC;EAExB,IAAA7B,gBAAS,EAAC,MAAM;IACd,IAAI,CAACvB,UAAU,CAACS,cAAc,CAACiC,WAAW,IAAI,CAACjC,cAAc,CAAC2C,GAAG,EAAE;IACnE;;IAEA;IACA,IAAAC,eAAQ,EAACrD,UAAU,CAACS,cAAc,CAACiC,WAAW,EAAEjC,cAAc,CAAC2C,GAAG,CAAC;EACrE,CAAC,EAAE,CAACpD,UAAU,CAACS,cAAc,CAACiC,WAAW,CAAC,CAAC;EAE3C,IAAI,CAAC/C,QAAQ,EAAE,oBAAO1C,MAAA,CAAAuB,OAAA,CAAA8E,aAAA,CAAArG,MAAA,CAAAuB,OAAA,CAAA+E,QAAA,MAAI,CAAC;EAC3B,IAAI,CAACpC,UAAU,CAAC,CAAC,IAAI,CAACT,MAAM,IAAI,CAACG,KAAK,EAAE,oBAAO5D,MAAA,CAAAuB,OAAA,CAAA8E,aAAA,CAAC7F,OAAA,CAAA+F,MAAM,MAAE,CAAC;EACzD,oBACEvG,MAAA,CAAAuB,OAAA,CAAA8E,aAAA,CAACxF,YAAA,CAAA2F,oBAAoB,qBACnBxG,MAAA,CAAAuB,OAAA,CAAA8E,aAAA,CAACI,SAAS,EAAKlE,KAAK,eAClBvC,MAAA,CAAAuB,OAAA,CAAA8E,aAAA,CAACvF,eAAA,CAAA4F,GAAG;IAACC,SAAS,EAAC;EAAY,gBACzB3G,MAAA,CAAAuB,OAAA,CAAA8E,aAAA,CAACvF,eAAA,CAAA8F,GAAG;IAACC,EAAE,EAAC,MAAM;IAACC,EAAE,EAAE,CAAE;IAACH,SAAS,EAAC;EAAkB,gBAChD3G,MAAA,CAAAuB,OAAA,CAAA8E,aAAA,CAAC/F,KAAA,CAAAyG,IAAI;IACH1D,WAAW,EAAEA,WAAY;IACzBO,KAAK,EAAEA,KAAM;IACbH,MAAM,EAAEA,MAAO;IACfK,QAAQ,EAAEA,QAAS;IACnBZ,QAAQ,EAAEA;EAAS,CACpB,CACE,CAAC,eACNlD,MAAA,CAAAuB,OAAA,CAAA8E,aAAA,CAACvF,eAAA,CAAA8F,GAAG;IAACD,SAAS,EAAC,YAAY;IAACE,EAAE,EAAE,EAAG;IAACC,EAAE,EAAE;EAAE,gBACxC9G,MAAA,CAAAuB,OAAA,CAAA8E,aAAA,CAACnG,IAAA,CAAA8G,GAAG;IACFvD,MAAM,EAAEA,MAAO;IACfG,KAAK,EAAEA,KAAM;IACbP,WAAW,EAAEA,WAAY;IACzB4D,KAAK,EAAE1D,UAAU,CAACc,KAAM;IACxB6C,wBAAwB,EAAE,IAAK;IAC/BC,aAAa,EAAE,KAAM;IACrBC,gBAAgB,EAAE;EAAK,CACxB,CACE,CACF,CACI,CACS,CAAC;AAE3B,CAAC;AAED,MAAMX,SAAS,GAAGY,yBAAM,CAACC,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,sQA8B3B;AAAC,IAAAC,QAAA,GAEapF,OAAO;AAAAqF,OAAA,CAAApG,OAAA,GAAAmG,QAAA"}
152
+ //# 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","focusMap","createElement","Fragment","Loader","SelectedItemProvider","Container","Row","className","Col","xs","sm","List","Map","edges","includeUnmonitoredPoints","forEventsView","forWWTPDashboard","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';\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  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            />\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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"}
@@ -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.updateHistory = exports.sortAreas = exports.simpleTruncate = exports.sendAnalyticsEvent = exports.initializeWWTPData = exports.focusMap = exports.createPopupForObject = exports.calculateWWTPInfo = exports.areaFocusLogic = exports.CardContainer = void 0;
7
+ exports.updateHistory = exports.sortAreas = exports.simpleTruncate = exports.sendAnalyticsEvent = exports.initializeWWTPData = exports.focusMap = exports.createPopupForObject = exports.calculateWWTPInfo = exports.CardContainer = void 0;
8
8
  var _styledComponents = _interopRequireDefault(require("styled-components"));
9
9
  var _jquery = _interopRequireDefault(require("jquery"));
10
10
  var _Analytics = require("utilities/Analytics");
@@ -81,18 +81,6 @@ const createPopupForObject = args => {
81
81
  });
82
82
  };
83
83
  exports.createPopupForObject = createPopupForObject;
84
- const areaFocusLogic = args => {
85
- var _object$sub_areas;
86
- const object = args.WWTPInfo.area || args.WWTPInfo.point;
87
- const map = args.map;
88
- if (object === null || map === null) return;
89
- if ((object === null || object === void 0 ? void 0 : (_object$sub_areas = object.sub_areas) === null || _object$sub_areas === void 0 ? void 0 : _object$sub_areas.length) > 0) {
90
- args.setAreas(object.sub_areas);
91
- } else {
92
- args.setAreas(object.factories);
93
- }
94
- };
95
- exports.areaFocusLogic = areaFocusLogic;
96
84
  const focusMap = (object, map) => {
97
85
  if (object === null || map === null) return;
98
86
  let latlngs = [];
@@ -160,4 +148,4 @@ const sendAnalyticsEvent = (subject, selection, eventFields) => {
160
148
  (0, _Analytics.analyticsTrack)(subject, data);
161
149
  };
162
150
  exports.sendAnalyticsEvent = sendAnalyticsEvent;
163
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_jquery","_interopRequireDefault","require","_Analytics","initializeWWTPData","payload","dataExists","wwtpInfp","calculateWWTPInfo","setWWTPInfo","setPoints","points_data","items","setAreas","areas_data","newAreas","exports","sortAreas","areas","temp","sortedAreas","sort","a","b","is_assessment","area_score","updateHistory","object","history","area","area_id","point","id","type","group","push","concat","location","search","is_virtual","_ref","WWTP","find","parseInt","undefined","_points_data$items","WWTPArea","forWWTPMap","createPopupForObject","args","marker","bindPopup","maxWidth","minWidth","maxHeight","minHeight","on","setTimeout","$","contents","length","append","renderedElement","unbindPopup","areaFocusLogic","_object$sub_areas","WWTPInfo","map","sub_areas","factories","focusMap","latlngs","property","_layers","kando_object","_bounds","forEach","sub_area","shape_data","latlng","inlets","inlet","latitude","longitude","fitBounds","simpleTruncate","str","Error","substring","CardContainer","styled","div","withConfig","displayName","componentId","sendAnalyticsEvent","subject","selection","eventFields","data","page_name","window","pathname","analyticsTrack"],"sources":["../../../src/pages/DashboardMap/utils.ts"],"sourcesContent":["import { IPoint } from '../../store/points/models/IPoint';\nimport { IArea } from '../../store/areas/models/IArea';\nimport $ from 'jquery';\nimport styled from 'styled-components/macro';\nimport { analyticsTrack } from 'src/utilities/Analytics';\n\nexport const initializeWWTPData = (payload) => {\n  if (payload.dataExists()) {\n    const wwtpInfp = calculateWWTPInfo(payload);\n    payload.setWWTPInfo(wwtpInfp);\n    payload.setPoints(payload.points_data.items);\n    payload.setAreas(payload.areas_data.newAreas);\n  }\n};\n\nexport const sortAreas = (areas) => {\n  if (!areas) return areas;\n\n  const temp = [...areas];\n  const sortedAreas = temp\n    .sort((a, b) =>\n      a.is_assessment === b.is_assessment ? 0 : a.is_assessment ? -1 : 1,\n    )\n    .sort((a, b) => b.area_score - a.area_score);\n\n  return sortedAreas;\n};\n\nexport const updateHistory = (object, history) => {\n  const area = object.area_id ? object : null;\n  const point = object.id ? object : null;\n\n  if (point) {\n    const type =\n      point.group.type === 'Groups::WastewaterTreatmentPlant' ? 'wwtp' : 'site';\n    history.push(`/dashboard_v2/${type}/${point.id}${history.location.search}`);\n  } else {\n    if (area) {\n      const type = area.is_virtual ? 'varea' : 'area';\n      history.push(\n        `/dashboard_v2/${type}/${area.area_id}${history.location.search}`,\n      );\n    }\n  }\n};\n\nexport const calculateWWTPInfo = ({ id, points_data, areas_data }) => {\n  let WWTP: IPoint = points_data.items.find(\n    (point: IPoint) => point.id === parseInt(id),\n  );\n\n  if (WWTP === undefined) {\n    WWTP = points_data.items?.find(\n      (point: IPoint) => point.group.area_id === parseInt(id),\n    );\n  }\n\n  let WWTPArea: IArea = areas_data.newAreas.find(\n    (area: IArea) => parseInt(id) === area.area_id,\n  );\n\n  if (WWTP !== undefined) {\n    WWTP = {\n      ...WWTP,\n      forWWTPMap: true,\n    };\n  }\n\n  return { point: WWTP, area: WWTPArea };\n};\n\nexport const createPopupForObject = (args) => {\n  args.marker.bindPopup(`<div class=\"widget-container\"></div>`, {\n    maxWidth: 400,\n    minWidth: 400,\n    maxHeight: 400,\n    minHeight: 400,\n  });\n\n  args.marker.on('popupopen', function () {\n    setTimeout(() => {\n      if ($('.widget-container').contents().length <= 0) {\n        $('.widget-container').append(args.renderedElement);\n      }\n    }, 200);\n  });\n\n  args.marker.on('popupclose', function () {\n    args.marker.unbindPopup();\n  });\n};\n\nexport const areaFocusLogic = (args) => {\n  const object = args.WWTPInfo.area || args.WWTPInfo.point;\n  const map = args.map;\n\n  if (object === null || map === null) return;\n\n  if (object?.sub_areas?.length > 0) {\n    args.setAreas(object.sub_areas);\n  } else {\n    args.setAreas(object.factories);\n  }\n};\n\nexport const focusMap = (object, map) => {\n  if (object === null || map === null) return;\n\n  let latlngs: any = [];\n  if (object === undefined) {\n    for (const property in map._layers) {\n      if (\n        map._layers[property].kando_object === 'Area' ||\n        map._layers[property].kando_object === 'Point'\n      ) {\n        latlngs.push(map._layers[property]._bounds);\n      }\n    }\n  } else {\n    if (object.sub_areas && object.sub_areas.length > 0) {\n      object.sub_areas.forEach((sub_area) => {\n        if (sub_area?.shape_data !== undefined) {\n          sub_area.shape_data.forEach((latlng) => {\n            latlngs.push(latlng);\n          });\n        }\n      });\n    } else {\n      if (object.inlets && object.inlets.length > 0) {\n        object.inlets.forEach((inlet) => {\n          latlngs.push([inlet.latitude, inlet.longitude]);\n        });\n      } else {\n        if (object?.shape_data !== undefined) {\n          object.shape_data.forEach((latlng) => {\n            latlngs.push(latlng);\n          });\n        } else {\n          latlngs.push([object.latitude, object.longitude]);\n        }\n      }\n    }\n  }\n  latlngs.length > 0 &&\n    map !== null &&\n    typeof map._layers === 'object' &&\n    map._layers.length === undefined &&\n    map.fitBounds(latlngs);\n};\n\nexport const simpleTruncate = (str, length) => {\n  if (typeof str !== 'string' || typeof length !== 'number') {\n    throw new Error('Invalid arguments. Please provide a string and a number.');\n  }\n\n  if (str.length <= length) {\n    return str;\n  } else {\n    return str.substring(0, length) + '...';\n  }\n};\n\nexport const CardContainer = styled.div`\n  .card {\n    transition: 0.1s ease-in-out;\n    box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.2);\n\n    &:hover {\n      transition: 0.2s ease-in-out;\n      box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.2);\n      cursor: pointer;\n    }\n  }\n`;\n\n// Send analytics events from several places in wwtpmap.\n// subject is the name of the event\n// selection is the object that was selected\n// specificFields is an object with event fields to send which are combined with the rest of the fields\nexport const sendAnalyticsEvent = (\n  subject: string,\n  selection: string,\n  eventFields: Object,\n) => {\n  const data = {\n    selection: selection,\n    page_name: window.location.pathname,\n    ...eventFields,\n  };\n  analyticsTrack(subject, data);\n};\n"],"mappings":"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"}
151
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_jquery","_interopRequireDefault","require","_Analytics","initializeWWTPData","payload","dataExists","wwtpInfp","calculateWWTPInfo","setWWTPInfo","setPoints","points_data","items","setAreas","areas_data","newAreas","exports","sortAreas","areas","temp","sortedAreas","sort","a","b","is_assessment","area_score","updateHistory","object","history","area","area_id","point","id","type","group","push","concat","location","search","is_virtual","_ref","WWTP","find","parseInt","undefined","_points_data$items","WWTPArea","forWWTPMap","createPopupForObject","args","marker","bindPopup","maxWidth","minWidth","maxHeight","minHeight","on","setTimeout","$","contents","length","append","renderedElement","unbindPopup","focusMap","map","latlngs","property","_layers","kando_object","_bounds","sub_areas","forEach","sub_area","shape_data","latlng","inlets","inlet","latitude","longitude","fitBounds","simpleTruncate","str","Error","substring","CardContainer","styled","div","withConfig","displayName","componentId","sendAnalyticsEvent","subject","selection","eventFields","data","page_name","window","pathname","analyticsTrack"],"sources":["../../../src/pages/DashboardMap/utils.ts"],"sourcesContent":["import { IPoint } from '../../store/points/models/IPoint';\nimport { IArea } from '../../store/areas/models/IArea';\nimport $ from 'jquery';\nimport styled from 'styled-components/macro';\nimport { analyticsTrack } from 'src/utilities/Analytics';\n\nexport const initializeWWTPData = (payload) => {\n  if (payload.dataExists()) {\n    const wwtpInfp = calculateWWTPInfo(payload);\n    payload.setWWTPInfo(wwtpInfp);\n    payload.setPoints(payload.points_data.items);\n    payload.setAreas(payload.areas_data.newAreas);\n  }\n};\n\nexport const sortAreas = (areas) => {\n  if (!areas) return areas;\n\n  const temp = [...areas];\n  const sortedAreas = temp\n    .sort((a, b) =>\n      a.is_assessment === b.is_assessment ? 0 : a.is_assessment ? -1 : 1,\n    )\n    .sort((a, b) => b.area_score - a.area_score);\n\n  return sortedAreas;\n};\n\nexport const updateHistory = (object, history) => {\n  const area = object.area_id ? object : null;\n  const point = object.id ? object : null;\n\n  if (point) {\n    const type =\n      point.group.type === 'Groups::WastewaterTreatmentPlant' ? 'wwtp' : 'site';\n    history.push(`/dashboard_v2/${type}/${point.id}${history.location.search}`);\n  } else {\n    if (area) {\n      const type = area.is_virtual ? 'varea' : 'area';\n      history.push(\n        `/dashboard_v2/${type}/${area.area_id}${history.location.search}`,\n      );\n    }\n  }\n};\n\nexport const calculateWWTPInfo = ({ id, points_data, areas_data }) => {\n  let WWTP: IPoint = points_data.items.find(\n    (point: IPoint) => point.id === parseInt(id),\n  );\n\n  if (WWTP === undefined) {\n    WWTP = points_data.items?.find(\n      (point: IPoint) => point.group.area_id === parseInt(id),\n    );\n  }\n\n  let WWTPArea: IArea = areas_data.newAreas.find(\n    (area: IArea) => parseInt(id) === area.area_id,\n  );\n\n  if (WWTP !== undefined) {\n    WWTP = {\n      ...WWTP,\n      forWWTPMap: true,\n    };\n  }\n\n  return { point: WWTP, area: WWTPArea };\n};\n\nexport const createPopupForObject = (args) => {\n  args.marker.bindPopup(`<div class=\"widget-container\"></div>`, {\n    maxWidth: 400,\n    minWidth: 400,\n    maxHeight: 400,\n    minHeight: 400,\n  });\n\n  args.marker.on('popupopen', function () {\n    setTimeout(() => {\n      if ($('.widget-container').contents().length <= 0) {\n        $('.widget-container').append(args.renderedElement);\n      }\n    }, 200);\n  });\n\n  args.marker.on('popupclose', function () {\n    args.marker.unbindPopup();\n  });\n};\n\nexport const focusMap = (object, map) => {\n  if (object === null || map === null) return;\n\n  let latlngs: any = [];\n  if (object === undefined) {\n    for (const property in map._layers) {\n      if (\n        map._layers[property].kando_object === 'Area' ||\n        map._layers[property].kando_object === 'Point'\n      ) {\n        latlngs.push(map._layers[property]._bounds);\n      }\n    }\n  } else {\n    if (object.sub_areas && object.sub_areas.length > 0) {\n      object.sub_areas.forEach((sub_area) => {\n        if (sub_area?.shape_data !== undefined) {\n          sub_area.shape_data.forEach((latlng) => {\n            latlngs.push(latlng);\n          });\n        }\n      });\n    } else {\n      if (object.inlets && object.inlets.length > 0) {\n        object.inlets.forEach((inlet) => {\n          latlngs.push([inlet.latitude, inlet.longitude]);\n        });\n      } else {\n        if (object?.shape_data !== undefined) {\n          object.shape_data.forEach((latlng) => {\n            latlngs.push(latlng);\n          });\n        } else {\n          latlngs.push([object.latitude, object.longitude]);\n        }\n      }\n    }\n  }\n  latlngs.length > 0 &&\n    map !== null &&\n    typeof map._layers === 'object' &&\n    map._layers.length === undefined &&\n    map.fitBounds(latlngs);\n};\n\nexport const simpleTruncate = (str, length) => {\n  if (typeof str !== 'string' || typeof length !== 'number') {\n    throw new Error('Invalid arguments. Please provide a string and a number.');\n  }\n\n  if (str.length <= length) {\n    return str;\n  } else {\n    return str.substring(0, length) + '...';\n  }\n};\n\nexport const CardContainer = styled.div`\n  .card {\n    transition: 0.1s ease-in-out;\n    box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.2);\n\n    &:hover {\n      transition: 0.2s ease-in-out;\n      box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.2);\n      cursor: pointer;\n    }\n  }\n`;\n\n// Send analytics events from several places in wwtpmap.\n// subject is the name of the event\n// selection is the object that was selected\n// specificFields is an object with event fields to send which are combined with the rest of the fields\nexport const sendAnalyticsEvent = (\n  subject: string,\n  selection: string,\n  eventFields: Object,\n) => {\n  const data = {\n    selection: selection,\n    page_name: window.location.pathname,\n    ...eventFields,\n  };\n  analyticsTrack(subject, data);\n};\n"],"mappings":"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"}
@@ -57,12 +57,16 @@ const SitePage = () => {
57
57
  waterAuthorityId
58
58
  }).dashboard.Site.name;
59
59
  (0, _react.useEffect)(() => {
60
- if (siteID) {
60
+ if (siteID && waterAuthorityId) {
61
+ const siteDataUrl = (0, _urls.urls)({
62
+ siteID,
63
+ waterAuthorityId: waterAuthorityId
64
+ }).dashboard.Site.name;
61
65
  fetchSiteData(siteDataUrl, setSiteData).catch(e => {
62
66
  console.error('Request error: ' + e.message);
63
67
  });
64
68
  }
65
- }, [siteID]);
69
+ }, [siteID, waterAuthorityId]);
66
70
  if (!siteData) {
67
71
  return null;
68
72
  }
@@ -123,4 +127,4 @@ const Sampling = (0, _styledComponents.default)(_SamplingParameters.SamplingPara
123
127
  displayName: "SitePage__Sampling",
124
128
  componentId: "sc-kaw87v-4"
125
129
  })(["grid-area:sites;min-height:100%;"]);
126
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRedux","_reactRouter","_SiteInformation","_QualitySummary","_i18n","_interopRequireDefault","_PotentialImpactSummary","_LineChart","_DischargePattern","_SamplingParameters","_EventsRow","_Analytics","_InfoTooltip","_urls","_Dashboard","_PollutionContributor","_PointUtils","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","fetchSiteData","url","setData","response","fetch","ok","data","json","Error","concat","status","SitePage","waterAuthorityName","waterAuthorityId","useSelector","state","global_data","siteData","setSiteData","useState","siteID","useParams","period","dashboard","eventParams","useMemo","valuesFromKQL","useEffect","analyticsTrack","utility_name","siteDataUrl","urls","Site","name","catch","e","console","error","message","isFactory","isFactoryType","site_type","createElement","breadcrumbs","pageName","Container","className","site_name","SiteInformation","isShowMap","SummaryComponent","endpoint","CommonComponent","LineChartComponent","title","i18n","t","DischargePattern","Number","InfoTooltip","EventsRow","Sampling","exports","styled","div","withConfig","displayName","componentId","QualitySummary","PotentialImpactSummary","LineChart","SamplingParameters"],"sources":["../../../src/pages/SitePage/SitePage.tsx"],"sourcesContent":["import React, { useEffect, useMemo, useState } from 'react';\nimport { useSelector } from 'react-redux';\nimport { useParams } from 'react-router';\nimport { ISiteInformation } from 'src/pages/OldSitePage/IDashboardData';\nimport { SiteInformation } from 'src/pages/SitePage/SiteInformation/SiteInformation';\nimport { QualitySummary } from 'src/Widgets/QualitySummary/QualitySummary';\nimport styled from 'styled-components/macro';\nimport { appReducer } from '../../store/rootReducer';\nimport i18n from '../../utilities/i18n';\nimport { PotentialImpactSummary } from '../../Widgets/PotentialImpactSummary';\nimport { LineChart } from '../AreaPage/Dashboard/LineChart/LineChart';\nimport { DischargePattern } from './DischargePattern/DischargePattern';\nimport { SamplingParameters } from './SamplingParameters/SamplingParameters';\nimport { EventsRow } from 'src/Widgets/EventsRow/EventsRow';\nimport { analyticsTrack } from '../../utilities/Analytics';\nimport { InfoTooltip } from 'src/ui-kit/InfoTooltip/InfoTooltip';\nimport { urls } from 'src/utilities/urls';\nimport PageContainer from '../../ui-kit/Dashboard/Dashboard';\nimport PollutionContributor from './PollutionContributor';\nimport { isFactoryType } from 'src/Widgets/Map/points/PointUtils';\n\nconst fetchSiteData = async (url: string, setData: Function) => {\n  const response = await fetch(url);\n  if (response.ok) {\n    const data = await response.json();\n    setData(data.data);\n  } else {\n    throw new Error(`HTTP error! status: ${response.status}`);\n  }\n};\n\nexport const SitePage = () => {\n  // eslint-disable-next-line\n  const [waterAuthorityName, waterAuthorityId] = useSelector(\n    (state: ReturnType<typeof appReducer>) => [\n      state.global_data.waterAuthorityName,\n      state.global_data.waterAuthorityId,\n    ],\n  );\n\n  const [siteData, setSiteData] = useState<ISiteInformation>();\n\n  type hasSiteID = { siteID?: string };\n  const { siteID } = useParams() as hasSiteID;\n\n  const period = useSelector(\n    (state: ReturnType<typeof appReducer>) =>\n      state.dashboard.period['range'] || state.dashboard.period,\n  );\n\n  const eventParams = useMemo(() => {\n    return {\n      valuesFromKQL: `InterestPointFilterItem IN ( ${siteID} ) SeverityFilterItem IN ( 1 2 ) TimeFilterItem IN ( ${period} ) ORDER_BY severity`,\n    };\n  }, [siteID, period]);\n\n  useEffect(() => {\n    analyticsTrack('Viewed Site Page', {\n      utility_name: waterAuthorityName,\n    });\n  }, []);\n\n  const siteDataUrl = urls({ siteID, waterAuthorityId }).dashboard.Site.name;\n\n  useEffect(() => {\n    if (siteID) {\n      fetchSiteData(siteDataUrl, setSiteData).catch((e) => {\n        console.error('Request error: ' + e.message);\n      });\n    }\n  }, [siteID]);\n\n  if (!siteData) {\n    return null;\n  }\n  const isFactory = isFactoryType(siteData.site_type);\n\n  return (\n    <PageContainer breadcrumbs={siteData?.breadcrumbs} pageName={'Site'}>\n      <Container>\n        <h1 className=\"title\">{siteData.site_name}</h1>\n        <div className={`dashboard ${isFactory ? 'factory' : ''}`}>\n          <SiteInformation siteData={siteData} isShowMap={isFactory} />\n          <SummaryComponent\n            endpoint={`/data/events-component-data/${siteID}`}\n          />\n          <CommonComponent endpoint={siteDataUrl} />\n          {!isFactory && <PollutionContributor />}\n          <LineChartComponent\n            title={i18n.t('area_dashboard.trend')}\n            endpoint={`/points/${siteID}/trend-graph`}\n          />\n          <DischargePattern siteID={Number(siteID)} />\n\n          <div className=\"significant-events\">\n            <div className=\"title\">\n              <InfoTooltip\n                title={i18n.t('area_dashboard.most-significant-events')}\n                data={i18n.t('helpers.info_tooltip.most_significant_events')}\n              >\n                {i18n.t('area_dashboard.most-significant-events')}\n              </InfoTooltip>\n            </div>\n            <EventsRow endpoint={`/events.json`} eventParams={eventParams} />\n          </div>\n\n          <div className=\"sites\">\n            <Sampling endpoint={`/sites/${siteID}/sampling-data.json`} />\n          </div>\n        </div>\n      </Container>\n    </PageContainer>\n  );\n};\n\nconst Container = styled.div`\n  padding: 16px;\n\n  > .title {\n    font-size: 36px;\n    font-weight: 700;\n  }\n  .dashboard {\n    display: grid;\n    width: 100%;\n    grid-template-columns: 1fr 1fr 1fr 1fr;\n    grid-template-rows: 250px 340px 300px auto;\n    grid-gap: 44px 24px;\n    color: #1d1d1d;\n    overflow-x: hidden;\n    > .sites {\n      grid-area: sites;\n      overflow-x: hidden;\n      overflow-y: visible;\n      @media (max-width: 996px) {\n        padding-top: 50px;\n      }\n      @media (max-width: 780px) {\n        height: 0;\n        visibility: hidden;\n      }\n    }\n    grid-template-areas:\n      'info  summary summary common'\n      'pollution_contributor  graph graph pattern'\n      'events events events events'\n      'sites sites sites sites'\n      'sites sites sites sites';\n\n    &.factory {\n      grid-template-areas:\n        'info  summary summary common'\n        'info  graph graph pattern'\n        'events events events events'\n        'sites sites sites sites'\n        'sites sites sites sites';\n    }\n    @media (max-width: 1500px) {\n      grid-template-rows: 250px 300px 250px 300px auto;\n    }\n    @media (max-width: 1250px) {\n      grid-template-rows: 250px 300px 300px 350px auto;\n\n      grid-gap: 10px;\n      grid-template-areas:\n        'info info summary  summary'\n        'pollution_contributor pollution_contributor common common'\n        'events events pattern pattern'\n        'graph graph graph graph'\n        'sites sites sites sites';\n      &.factory {\n        grid-template-areas:\n          'info info summary  summary'\n          'info info common common'\n          'events events pattern pattern'\n          'graph graph graph graph'\n          'sites sites sites sites';\n      }\n    }\n\n    @media (max-width: 996px) {\n      grid-gap: 10px;\n      grid-template-columns: 1fr;\n      grid-template-rows: unset;\n      grid-template-rows: 250px 250px 250px 300px 300px 280px 300px auto;\n\n      grid-template-areas:\n        'info '\n        'summary  '\n        'common'\n        'pollution_contributor'\n        'graph'\n        'events'\n        'pattern'\n        'sites ';\n      &.factory {\n        grid-template-rows: 400px 250px 250px 300px 280px 300px auto;\n\n        grid-template-areas:\n          'info '\n          'summary  '\n          'common'\n          'graph'\n          'events'\n          'pattern'\n          'sites ';\n      }\n    }\n\n    @media (max-width: 600px) {\n      grid-gap: 20px;\n\n      grid-template-rows: 250px 350px 250px 280px 280px auto 300px;\n\n      &.factory {\n        grid-template-rows: 400px 400px 250px 280px auto 300px;\n      }\n    }\n    .graph {\n      grid-area: graph;\n    }\n    .significant-events {\n      > .title {\n        font-size: 24px;\n\n        margin-bottom: 14px;\n        @media (min-width: 1200px) {\n          @media (max-width: 1450px) {\n            font-size: 20px;\n            @media (max-width: 1250px) {\n              font-size: 16px;\n            }\n          }\n        }\n\n        @media (max-width: 400px) {\n          font-size: 16px;\n        }\n      }\n    }\n\n    .significant-events {\n      grid-area: events;\n    }\n\n    .map-box {\n      flex: 1;\n      padding: 20px;\n      width: 100%;\n    }\n  }\n`;\n\nconst SummaryComponent = styled(QualitySummary)`\n  grid-area: summary;\n`;\n\nconst CommonComponent = styled(PotentialImpactSummary)`\n  grid-area: common;\n`;\n\nconst LineChartComponent = styled(LineChart)`\n  grid-area: graph;\n`;\n\nconst Sampling = styled(SamplingParameters)`\n  grid-area: sites;\n  min-height: 100%;\n`;\n"],"mappings":";;;;;;;;AAAA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,WAAA,GAAAD,OAAA;AACA,IAAAE,YAAA,GAAAF,OAAA;AAEA,IAAAG,gBAAA,GAAAH,OAAA;AACA,IAAAI,eAAA,GAAAJ,OAAA;AAGA,IAAAK,KAAA,GAAAC,sBAAA,CAAAN,OAAA;AACA,IAAAO,uBAAA,GAAAP,OAAA;AACA,IAAAQ,UAAA,GAAAR,OAAA;AACA,IAAAS,iBAAA,GAAAT,OAAA;AACA,IAAAU,mBAAA,GAAAV,OAAA;AACA,IAAAW,UAAA,GAAAX,OAAA;AACA,IAAAY,UAAA,GAAAZ,OAAA;AACA,IAAAa,YAAA,GAAAb,OAAA;AACA,IAAAc,KAAA,GAAAd,OAAA;AACA,IAAAe,UAAA,GAAAT,sBAAA,CAAAN,OAAA;AACA,IAAAgB,qBAAA,GAAAV,sBAAA,CAAAN,OAAA;AACA,IAAAiB,WAAA,GAAAjB,OAAA;AAAkE,SAAAkB,yBAAAC,WAAA,eAAAC,OAAA,kCAAAC,iBAAA,OAAAD,OAAA,QAAAE,gBAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAApB,wBAAAwB,GAAA,EAAAJ,WAAA,SAAAA,WAAA,IAAAI,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,oBAAAA,GAAA,wBAAAA,GAAA,4BAAAE,OAAA,EAAAF,GAAA,UAAAG,KAAA,GAAAR,wBAAA,CAAAC,WAAA,OAAAO,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAJ,GAAA,YAAAG,KAAA,CAAAE,GAAA,CAAAL,GAAA,SAAAM,MAAA,WAAAC,qBAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,GAAA,IAAAX,GAAA,QAAAW,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAd,GAAA,EAAAW,GAAA,SAAAI,IAAA,GAAAR,qBAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAV,GAAA,EAAAW,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,IAAAX,GAAA,CAAAW,GAAA,SAAAL,MAAA,CAAAJ,OAAA,GAAAF,GAAA,MAAAG,KAAA,IAAAA,KAAA,CAAAa,GAAA,CAAAhB,GAAA,EAAAM,MAAA,YAAAA,MAAA;AAElE,MAAMW,aAAa,GAAG,MAAAA,CAAOC,GAAW,EAAEC,OAAiB,KAAK;EAC9D,MAAMC,QAAQ,GAAG,MAAMC,KAAK,CAACH,GAAG,CAAC;EACjC,IAAIE,QAAQ,CAACE,EAAE,EAAE;IACf,MAAMC,IAAI,GAAG,MAAMH,QAAQ,CAACI,IAAI,CAAC,CAAC;IAClCL,OAAO,CAACI,IAAI,CAACA,IAAI,CAAC;EACpB,CAAC,MAAM;IACL,MAAM,IAAIE,KAAK,wBAAAC,MAAA,CAAwBN,QAAQ,CAACO,MAAM,CAAE,CAAC;EAC3D;AACF,CAAC;AAEM,MAAMC,QAAQ,GAAGA,CAAA,KAAM;EAC5B;EACA,MAAM,CAACC,kBAAkB,EAAEC,gBAAgB,CAAC,GAAG,IAAAC,uBAAW,EACvDC,KAAoC,IAAK,CACxCA,KAAK,CAACC,WAAW,CAACJ,kBAAkB,EACpCG,KAAK,CAACC,WAAW,CAACH,gBAAgB,CAEtC,CAAC;EAED,MAAM,CAACI,QAAQ,EAAEC,WAAW,CAAC,GAAG,IAAAC,eAAQ,EAAmB,CAAC;EAG5D,MAAM;IAAEC;EAAO,CAAC,GAAG,IAAAC,sBAAS,EAAC,CAAc;EAE3C,MAAMC,MAAM,GAAG,IAAAR,uBAAW,EACvBC,KAAoC,IACnCA,KAAK,CAACQ,SAAS,CAACD,MAAM,CAAC,OAAO,CAAC,IAAIP,KAAK,CAACQ,SAAS,CAACD,MACvD,CAAC;EAED,MAAME,WAAW,GAAG,IAAAC,cAAO,EAAC,MAAM;IAChC,OAAO;MACLC,aAAa,kCAAAjB,MAAA,CAAkCW,MAAM,2DAAAX,MAAA,CAAwDa,MAAM;IACrH,CAAC;EACH,CAAC,EAAE,CAACF,MAAM,EAAEE,MAAM,CAAC,CAAC;EAEpB,IAAAK,gBAAS,EAAC,MAAM;IACd,IAAAC,yBAAc,EAAC,kBAAkB,EAAE;MACjCC,YAAY,EAAEjB;IAChB,CAAC,CAAC;EACJ,CAAC,EAAE,EAAE,CAAC;EAEN,MAAMkB,WAAW,GAAG,IAAAC,UAAI,EAAC;IAAEX,MAAM;IAAEP;EAAiB,CAAC,CAAC,CAACU,SAAS,CAACS,IAAI,CAACC,IAAI;EAE1E,IAAAN,gBAAS,EAAC,MAAM;IACd,IAAIP,MAAM,EAAE;MACVpB,aAAa,CAAC8B,WAAW,EAAEZ,WAAW,CAAC,CAACgB,KAAK,CAAEC,CAAC,IAAK;QACnDC,OAAO,CAACC,KAAK,CAAC,iBAAiB,GAAGF,CAAC,CAACG,OAAO,CAAC;MAC9C,CAAC,CAAC;IACJ;EACF,CAAC,EAAE,CAAClB,MAAM,CAAC,CAAC;EAEZ,IAAI,CAACH,QAAQ,EAAE;IACb,OAAO,IAAI;EACb;EACA,MAAMsB,SAAS,GAAG,IAAAC,yBAAa,EAACvB,QAAQ,CAACwB,SAAS,CAAC;EAEnD,oBACEnF,MAAA,CAAA2B,OAAA,CAAAyD,aAAA,CAACnE,UAAA,CAAAU,OAAa;IAAC0D,WAAW,EAAE1B,QAAQ,aAARA,QAAQ,uBAARA,QAAQ,CAAE0B,WAAY;IAACC,QAAQ,EAAE;EAAO,gBAClEtF,MAAA,CAAA2B,OAAA,CAAAyD,aAAA,CAACG,SAAS,qBACRvF,MAAA,CAAA2B,OAAA,CAAAyD,aAAA;IAAII,SAAS,EAAC;EAAO,GAAE7B,QAAQ,CAAC8B,SAAc,CAAC,eAC/CzF,MAAA,CAAA2B,OAAA,CAAAyD,aAAA;IAAKI,SAAS,eAAArC,MAAA,CAAe8B,SAAS,GAAG,SAAS,GAAG,EAAE;EAAG,gBACxDjF,MAAA,CAAA2B,OAAA,CAAAyD,aAAA,CAAC/E,gBAAA,CAAAqF,eAAe;IAAC/B,QAAQ,EAAEA,QAAS;IAACgC,SAAS,EAAEV;EAAU,CAAE,CAAC,eAC7DjF,MAAA,CAAA2B,OAAA,CAAAyD,aAAA,CAACQ,gBAAgB;IACfC,QAAQ,iCAAA1C,MAAA,CAAiCW,MAAM;EAAG,CACnD,CAAC,eACF9D,MAAA,CAAA2B,OAAA,CAAAyD,aAAA,CAACU,eAAe;IAACD,QAAQ,EAAErB;EAAY,CAAE,CAAC,EACzC,CAACS,SAAS,iBAAIjF,MAAA,CAAA2B,OAAA,CAAAyD,aAAA,CAAClE,qBAAA,CAAAS,OAAoB,MAAE,CAAC,eACvC3B,MAAA,CAAA2B,OAAA,CAAAyD,aAAA,CAACW,kBAAkB;IACjBC,KAAK,EAAEC,aAAI,CAACC,CAAC,CAAC,sBAAsB,CAAE;IACtCL,QAAQ,aAAA1C,MAAA,CAAaW,MAAM;EAAe,CAC3C,CAAC,eACF9D,MAAA,CAAA2B,OAAA,CAAAyD,aAAA,CAACzE,iBAAA,CAAAwF,gBAAgB;IAACrC,MAAM,EAAEsC,MAAM,CAACtC,MAAM;EAAE,CAAE,CAAC,eAE5C9D,MAAA,CAAA2B,OAAA,CAAAyD,aAAA;IAAKI,SAAS,EAAC;EAAoB,gBACjCxF,MAAA,CAAA2B,OAAA,CAAAyD,aAAA;IAAKI,SAAS,EAAC;EAAO,gBACpBxF,MAAA,CAAA2B,OAAA,CAAAyD,aAAA,CAACrE,YAAA,CAAAsF,WAAW;IACVL,KAAK,EAAEC,aAAI,CAACC,CAAC,CAAC,wCAAwC,CAAE;IACxDlD,IAAI,EAAEiD,aAAI,CAACC,CAAC,CAAC,8CAA8C;EAAE,GAE5DD,aAAI,CAACC,CAAC,CAAC,wCAAwC,CACrC,CACV,CAAC,eACNlG,MAAA,CAAA2B,OAAA,CAAAyD,aAAA,CAACvE,UAAA,CAAAyF,SAAS;IAACT,QAAQ,gBAAiB;IAAC3B,WAAW,EAAEA;EAAY,CAAE,CAC7D,CAAC,eAENlE,MAAA,CAAA2B,OAAA,CAAAyD,aAAA;IAAKI,SAAS,EAAC;EAAO,gBACpBxF,MAAA,CAAA2B,OAAA,CAAAyD,aAAA,CAACmB,QAAQ;IAACV,QAAQ,YAAA1C,MAAA,CAAYW,MAAM;EAAsB,CAAE,CACzD,CACF,CACI,CACE,CAAC;AAEpB,CAAC;AAAC0C,OAAA,CAAAnD,QAAA,GAAAA,QAAA;AAEF,MAAMkC,SAAS,GAAGkB,yBAAM,CAACC,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,4nEAwI3B;AAED,MAAMjB,gBAAgB,GAAG,IAAAa,yBAAM,EAACK,8BAAc,CAAC,CAAAH,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,0BAE9C;AAED,MAAMf,eAAe,GAAG,IAAAW,yBAAM,EAACM,8CAAsB,CAAC,CAAAJ,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,yBAErD;AAED,MAAMd,kBAAkB,GAAG,IAAAU,yBAAM,EAACO,oBAAS,CAAC,CAAAL,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,wBAE3C;AAED,MAAMN,QAAQ,GAAG,IAAAE,yBAAM,EAACQ,sCAAkB,CAAC,CAAAN,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,wCAG1C"}
130
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRedux","_reactRouter","_SiteInformation","_QualitySummary","_i18n","_interopRequireDefault","_PotentialImpactSummary","_LineChart","_DischargePattern","_SamplingParameters","_EventsRow","_Analytics","_InfoTooltip","_urls","_Dashboard","_PollutionContributor","_PointUtils","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","fetchSiteData","url","setData","response","fetch","ok","data","json","Error","concat","status","SitePage","waterAuthorityName","waterAuthorityId","useSelector","state","global_data","siteData","setSiteData","useState","siteID","useParams","period","dashboard","eventParams","useMemo","valuesFromKQL","useEffect","analyticsTrack","utility_name","siteDataUrl","urls","Site","name","catch","e","console","error","message","isFactory","isFactoryType","site_type","createElement","breadcrumbs","pageName","Container","className","site_name","SiteInformation","isShowMap","SummaryComponent","endpoint","CommonComponent","LineChartComponent","title","i18n","t","DischargePattern","Number","InfoTooltip","EventsRow","Sampling","exports","styled","div","withConfig","displayName","componentId","QualitySummary","PotentialImpactSummary","LineChart","SamplingParameters"],"sources":["../../../src/pages/SitePage/SitePage.tsx"],"sourcesContent":["import React, { useEffect, useMemo, useState } from 'react';\nimport { useSelector } from 'react-redux';\nimport { useParams } from 'react-router';\nimport { ISiteInformation } from 'src/pages/OldSitePage/IDashboardData';\nimport { SiteInformation } from 'src/pages/SitePage/SiteInformation/SiteInformation';\nimport { QualitySummary } from 'src/Widgets/QualitySummary/QualitySummary';\nimport styled from 'styled-components/macro';\nimport { appReducer } from '../../store/rootReducer';\nimport i18n from '../../utilities/i18n';\nimport { PotentialImpactSummary } from '../../Widgets/PotentialImpactSummary';\nimport { LineChart } from '../AreaPage/Dashboard/LineChart/LineChart';\nimport { DischargePattern } from './DischargePattern/DischargePattern';\nimport { SamplingParameters } from './SamplingParameters/SamplingParameters';\nimport { EventsRow } from 'src/Widgets/EventsRow/EventsRow';\nimport { analyticsTrack } from '../../utilities/Analytics';\nimport { InfoTooltip } from 'src/ui-kit/InfoTooltip/InfoTooltip';\nimport { urls } from 'src/utilities/urls';\nimport PageContainer from '../../ui-kit/Dashboard/Dashboard';\nimport PollutionContributor from './PollutionContributor';\nimport { isFactoryType } from 'src/Widgets/Map/points/PointUtils';\n\nconst fetchSiteData = async (url: string, setData: Function) => {\n  const response = await fetch(url);\n  if (response.ok) {\n    const data = await response.json();\n    setData(data.data);\n  } else {\n    throw new Error(`HTTP error! status: ${response.status}`);\n  }\n};\n\nexport const SitePage = () => {\n  // eslint-disable-next-line\n  const [waterAuthorityName, waterAuthorityId] = useSelector(\n    (state: ReturnType<typeof appReducer>) => [\n      state.global_data.waterAuthorityName,\n      state.global_data.waterAuthorityId,\n    ],\n  );\n\n  const [siteData, setSiteData] = useState<ISiteInformation>();\n\n  type hasSiteID = { siteID?: string };\n  const { siteID } = useParams() as hasSiteID;\n\n  const period = useSelector(\n    (state: ReturnType<typeof appReducer>) =>\n      state.dashboard.period['range'] || state.dashboard.period,\n  );\n\n  const eventParams = useMemo(() => {\n    return {\n      valuesFromKQL: `InterestPointFilterItem IN ( ${siteID} ) SeverityFilterItem IN ( 1 2 ) TimeFilterItem IN ( ${period} ) ORDER_BY severity`,\n    };\n  }, [siteID, period]);\n\n  useEffect(() => {\n    analyticsTrack('Viewed Site Page', {\n      utility_name: waterAuthorityName,\n    });\n  }, []);\n\n  const siteDataUrl = urls({ siteID, waterAuthorityId }).dashboard.Site.name;\n\n  useEffect(() => {\n    if (siteID && waterAuthorityId) {\n      const siteDataUrl = urls({ siteID, waterAuthorityId: waterAuthorityId })\n        .dashboard.Site.name;\n      fetchSiteData(siteDataUrl, setSiteData).catch((e) => {\n        console.error('Request error: ' + e.message);\n      });\n    }\n  }, [siteID, waterAuthorityId]);\n\n  if (!siteData) {\n    return null;\n  }\n  const isFactory = isFactoryType(siteData.site_type);\n\n  return (\n    <PageContainer breadcrumbs={siteData?.breadcrumbs} pageName={'Site'}>\n      <Container>\n        <h1 className=\"title\">{siteData.site_name}</h1>\n        <div className={`dashboard ${isFactory ? 'factory' : ''}`}>\n          <SiteInformation siteData={siteData} isShowMap={isFactory} />\n          <SummaryComponent\n            endpoint={`/data/events-component-data/${siteID}`}\n          />\n          <CommonComponent endpoint={siteDataUrl} />\n          {!isFactory && <PollutionContributor />}\n          <LineChartComponent\n            title={i18n.t('area_dashboard.trend')}\n            endpoint={`/points/${siteID}/trend-graph`}\n          />\n          <DischargePattern siteID={Number(siteID)} />\n\n          <div className=\"significant-events\">\n            <div className=\"title\">\n              <InfoTooltip\n                title={i18n.t('area_dashboard.most-significant-events')}\n                data={i18n.t('helpers.info_tooltip.most_significant_events')}\n              >\n                {i18n.t('area_dashboard.most-significant-events')}\n              </InfoTooltip>\n            </div>\n            <EventsRow endpoint={`/events.json`} eventParams={eventParams} />\n          </div>\n\n          <div className=\"sites\">\n            <Sampling endpoint={`/sites/${siteID}/sampling-data.json`} />\n          </div>\n        </div>\n      </Container>\n    </PageContainer>\n  );\n};\n\nconst Container = styled.div`\n  padding: 16px;\n\n  > .title {\n    font-size: 36px;\n    font-weight: 700;\n  }\n  .dashboard {\n    display: grid;\n    width: 100%;\n    grid-template-columns: 1fr 1fr 1fr 1fr;\n    grid-template-rows: 250px 340px 300px auto;\n    grid-gap: 44px 24px;\n    color: #1d1d1d;\n    overflow-x: hidden;\n    > .sites {\n      grid-area: sites;\n      overflow-x: hidden;\n      overflow-y: visible;\n      @media (max-width: 996px) {\n        padding-top: 50px;\n      }\n      @media (max-width: 780px) {\n        height: 0;\n        visibility: hidden;\n      }\n    }\n    grid-template-areas:\n      'info  summary summary common'\n      'pollution_contributor  graph graph pattern'\n      'events events events events'\n      'sites sites sites sites'\n      'sites sites sites sites';\n\n    &.factory {\n      grid-template-areas:\n        'info  summary summary common'\n        'info  graph graph pattern'\n        'events events events events'\n        'sites sites sites sites'\n        'sites sites sites sites';\n    }\n    @media (max-width: 1500px) {\n      grid-template-rows: 250px 300px 250px 300px auto;\n    }\n    @media (max-width: 1250px) {\n      grid-template-rows: 250px 300px 300px 350px auto;\n\n      grid-gap: 10px;\n      grid-template-areas:\n        'info info summary  summary'\n        'pollution_contributor pollution_contributor common common'\n        'events events pattern pattern'\n        'graph graph graph graph'\n        'sites sites sites sites';\n      &.factory {\n        grid-template-areas:\n          'info info summary  summary'\n          'info info common common'\n          'events events pattern pattern'\n          'graph graph graph graph'\n          'sites sites sites sites';\n      }\n    }\n\n    @media (max-width: 996px) {\n      grid-gap: 10px;\n      grid-template-columns: 1fr;\n      grid-template-rows: unset;\n      grid-template-rows: 250px 250px 250px 300px 300px 280px 300px auto;\n\n      grid-template-areas:\n        'info '\n        'summary  '\n        'common'\n        'pollution_contributor'\n        'graph'\n        'events'\n        'pattern'\n        'sites ';\n      &.factory {\n        grid-template-rows: 400px 250px 250px 300px 280px 300px auto;\n\n        grid-template-areas:\n          'info '\n          'summary  '\n          'common'\n          'graph'\n          'events'\n          'pattern'\n          'sites ';\n      }\n    }\n\n    @media (max-width: 600px) {\n      grid-gap: 20px;\n\n      grid-template-rows: 250px 350px 250px 280px 280px auto 300px;\n\n      &.factory {\n        grid-template-rows: 400px 400px 250px 280px auto 300px;\n      }\n    }\n    .graph {\n      grid-area: graph;\n    }\n    .significant-events {\n      > .title {\n        font-size: 24px;\n\n        margin-bottom: 14px;\n        @media (min-width: 1200px) {\n          @media (max-width: 1450px) {\n            font-size: 20px;\n            @media (max-width: 1250px) {\n              font-size: 16px;\n            }\n          }\n        }\n\n        @media (max-width: 400px) {\n          font-size: 16px;\n        }\n      }\n    }\n\n    .significant-events {\n      grid-area: events;\n    }\n\n    .map-box {\n      flex: 1;\n      padding: 20px;\n      width: 100%;\n    }\n  }\n`;\n\nconst SummaryComponent = styled(QualitySummary)`\n  grid-area: summary;\n`;\n\nconst CommonComponent = styled(PotentialImpactSummary)`\n  grid-area: common;\n`;\n\nconst LineChartComponent = styled(LineChart)`\n  grid-area: graph;\n`;\n\nconst Sampling = styled(SamplingParameters)`\n  grid-area: sites;\n  min-height: 100%;\n`;\n"],"mappings":"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"}
@@ -36,6 +36,7 @@ const UtilityDashboard = _ref => {
36
36
  const name = (0, _reactRedux.useSelector)(state => state.global_data.waterAuthorityName);
37
37
  const locale = (0, _reactRedux.useSelector)(state => state.nav_context_data.navContext.locale);
38
38
  const global_data = (0, _reactRedux.useSelector)(state => state.global_data);
39
+ const dashboard = (0, _reactRedux.useSelector)(state => state.dashboard);
39
40
  const dispatch = (0, _reactRedux.useDispatch)();
40
41
  (0, _react.useEffect)(() => {
41
42
  if (!global_data.waterAuthorityId) {
@@ -46,7 +47,7 @@ const UtilityDashboard = _ref => {
46
47
  });
47
48
  dispatch((0, _actions.fetchPoints)(global_data.waterAuthorityId));
48
49
  dispatch((0, _actions2.fetchEdges)(global_data.waterAuthorityId, true));
49
- dispatch((0, _actions3.fetchAreas)(global_data.waterAuthorityId));
50
+ dispatch((0, _actions3.fetchAreas)(global_data.waterAuthorityId, dashboard.period));
50
51
  dispatch((0, _actions4.moreInfo)(false, {}));
51
52
  dispatch((0, _actions4.setCurrentTime)(Date.now() / 1000 | 0));
52
53
  //
@@ -72,4 +73,4 @@ const UtilityDashboard = _ref => {
72
73
  }));
73
74
  };
74
75
  exports.UtilityDashboard = UtilityDashboard;
75
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_MostPolluting","_TopBar","_reactRedux","_actions","_actions2","_actions3","_MostSevereEvents","_actions4","_rootActions","_Analytics","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","Container","styled","div","withConfig","displayName","componentId","SpinnerHolder","exports","UtilityDashboard","_ref","dashboardItem","dashboardName","name","useSelector","state","global_data","waterAuthorityName","locale","nav_context_data","navContext","dispatch","useDispatch","useEffect","waterAuthorityId","analyticsTrack","concat","utility_name","fetchPoints","fetchEdges","fetchAreas","moreInfo","setCurrentTime","Date","now","cleanup","resetStore","createElement","dir","className","TopBar","MostPolluting","MostSevereEvents"],"sources":["../../../src/pages/UtilityDashboardPage/UtilityDashboard.tsx"],"sourcesContent":["import React, { useEffect } from 'react';\nimport styled from 'styled-components/macro';\n\nimport { MostPolluting } from 'src/Widgets/MostPolluting/MostPolluting';\nimport { TopBar } from './TopBar/TopBar';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { appReducer } from 'src/store/rootReducer';\nimport { fetchPoints } from 'src/store/points/actions';\nimport { fetchEdges } from 'src/store/edges/actions';\nimport { fetchAreas } from 'src/store/areas/actions';\nimport { MostSevereEvents } from './MostSevereEvents/MostSevereEvents';\nimport { moreInfo, setCurrentTime } from 'src/store/global/actions';\nimport { resetStore } from 'src/store/rootActions';\nimport { analyticsTrack } from '../../utilities/Analytics';\n\nconst Container = styled.div`\n  [dir='rtl'] & {\n    text-align: right;\n  }\n  max-width: 1920px;\n  margin: 0 auto;\n  padding: 50px 30px;\n  width: 100%;\n  overflow-x: hidden;\n\n  @media (max-width: 768px) {\n    padding: 25px 5px;\n  }\n\n  > .title {\n    font-family: Gilroy, Arial;\n    font-size: 2.25rem;\n    font-weight: 700;\n    line-height: 1;\n    color: #1d1d1d;\n    margin-bottom: 25px;\n  }\n  > .top-bar {\n    margin-bottom: 45px;\n  }\n  > .most-polluting {\n    margin-bottom: 45px;\n  }\n`;\n\nexport const SpinnerHolder = styled.div`\n  > .spinner-container {\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n  }\n`;\n\ninterface UtilityDashboardProps {\n  period?: string;\n  dashboardItem?: string;\n  dashboardName?: string;\n}\n\nexport const UtilityDashboard: React.FC<UtilityDashboardProps> = ({\n  dashboardItem = 'Utility',\n  dashboardName,\n}) => {\n  const name = useSelector(\n    (state: ReturnType<typeof appReducer>) =>\n      state.global_data.waterAuthorityName,\n  );\n\n  const locale = useSelector(\n    (state: ReturnType<typeof appReducer>) =>\n      state.nav_context_data.navContext.locale,\n  );\n\n  const global_data = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.global_data,\n  );\n  const dispatch = useDispatch();\n  useEffect(() => {\n    if (!global_data.waterAuthorityId) {\n      return;\n    }\n    analyticsTrack(`${dashboardItem} Dashboard`, {\n      utility_name: name,\n    });\n    dispatch(fetchPoints(global_data.waterAuthorityId));\n    dispatch(fetchEdges(global_data.waterAuthorityId, true));\n    dispatch(fetchAreas(global_data.waterAuthorityId));\n    dispatch(moreInfo(false, {}));\n    dispatch(setCurrentTime((Date.now() / 1000) | 0));\n    //\n    return function cleanup() {\n      dispatch(resetStore());\n      dispatch(setCurrentTime(0));\n    };\n  }, [global_data.waterAuthorityId]);\n  return (\n    <Container dir={locale === 'he' ? 'rtl' : 'ltr'}>\n      <div className=\"title\">{dashboardName || name}</div>\n      <div className=\"top-bar\">\n        <TopBar dashboardItem={dashboardItem} />\n      </div>\n\n      <div className=\"most-polluting\">\n        <MostPolluting dashboardItem={dashboardItem} />\n      </div>\n\n      <MostSevereEvents dashboardItem={dashboardItem} />\n    </Container>\n  );\n};\n"],"mappings":"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"}
76
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_MostPolluting","_TopBar","_reactRedux","_actions","_actions2","_actions3","_MostSevereEvents","_actions4","_rootActions","_Analytics","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","Container","styled","div","withConfig","displayName","componentId","SpinnerHolder","exports","UtilityDashboard","_ref","dashboardItem","dashboardName","name","useSelector","state","global_data","waterAuthorityName","locale","nav_context_data","navContext","dashboard","dispatch","useDispatch","useEffect","waterAuthorityId","analyticsTrack","concat","utility_name","fetchPoints","fetchEdges","fetchAreas","period","moreInfo","setCurrentTime","Date","now","cleanup","resetStore","createElement","dir","className","TopBar","MostPolluting","MostSevereEvents"],"sources":["../../../src/pages/UtilityDashboardPage/UtilityDashboard.tsx"],"sourcesContent":["import React, { useEffect } from 'react';\nimport styled from 'styled-components/macro';\n\nimport { MostPolluting } from 'src/Widgets/MostPolluting/MostPolluting';\nimport { TopBar } from './TopBar/TopBar';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { appReducer } from 'src/store/rootReducer';\nimport { fetchPoints } from 'src/store/points/actions';\nimport { fetchEdges } from 'src/store/edges/actions';\nimport { fetchAreas } from 'src/store/areas/actions';\nimport { MostSevereEvents } from './MostSevereEvents/MostSevereEvents';\nimport { moreInfo, setCurrentTime } from 'src/store/global/actions';\nimport { resetStore } from 'src/store/rootActions';\nimport { analyticsTrack } from '../../utilities/Analytics';\n\nconst Container = styled.div`\n  [dir='rtl'] & {\n    text-align: right;\n  }\n  max-width: 1920px;\n  margin: 0 auto;\n  padding: 50px 30px;\n  width: 100%;\n  overflow-x: hidden;\n\n  @media (max-width: 768px) {\n    padding: 25px 5px;\n  }\n\n  > .title {\n    font-family: Gilroy, Arial;\n    font-size: 2.25rem;\n    font-weight: 700;\n    line-height: 1;\n    color: #1d1d1d;\n    margin-bottom: 25px;\n  }\n  > .top-bar {\n    margin-bottom: 45px;\n  }\n  > .most-polluting {\n    margin-bottom: 45px;\n  }\n`;\n\nexport const SpinnerHolder = styled.div`\n  > .spinner-container {\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n  }\n`;\n\ninterface UtilityDashboardProps {\n  period?: string;\n  dashboardItem?: string;\n  dashboardName?: string;\n}\n\nexport const UtilityDashboard: React.FC<UtilityDashboardProps> = ({\n  dashboardItem = 'Utility',\n  dashboardName,\n}) => {\n  const name = useSelector(\n    (state: ReturnType<typeof appReducer>) =>\n      state.global_data.waterAuthorityName,\n  );\n\n  const locale = useSelector(\n    (state: ReturnType<typeof appReducer>) =>\n      state.nav_context_data.navContext.locale,\n  );\n\n  const global_data = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.global_data,\n  );\n  const dashboard = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.dashboard,\n  );\n  const dispatch = useDispatch();\n  useEffect(() => {\n    if (!global_data.waterAuthorityId) {\n      return;\n    }\n    analyticsTrack(`${dashboardItem} Dashboard`, {\n      utility_name: name,\n    });\n    dispatch(fetchPoints(global_data.waterAuthorityId));\n    dispatch(fetchEdges(global_data.waterAuthorityId, true));\n    dispatch(fetchAreas(global_data.waterAuthorityId, dashboard.period));\n    dispatch(moreInfo(false, {}));\n    dispatch(setCurrentTime((Date.now() / 1000) | 0));\n    //\n    return function cleanup() {\n      dispatch(resetStore());\n      dispatch(setCurrentTime(0));\n    };\n  }, [global_data.waterAuthorityId]);\n  return (\n    <Container dir={locale === 'he' ? 'rtl' : 'ltr'}>\n      <div className=\"title\">{dashboardName || name}</div>\n      <div className=\"top-bar\">\n        <TopBar dashboardItem={dashboardItem} />\n      </div>\n\n      <div className=\"most-polluting\">\n        <MostPolluting dashboardItem={dashboardItem} />\n      </div>\n\n      <MostSevereEvents dashboardItem={dashboardItem} />\n    </Container>\n  );\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.345",
3
+ "version": "1.2.346",
4
4
  "main": "lib/index.js",
5
5
  "author": "Nadav(Private) <nadavk72@gmail.com>",
6
6
  "scripts": {