@kando-env/kando-ui 1.2.371-alpha.8 → 1.2.371

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.
Files changed (31) hide show
  1. package/lib/Widgets/Map/Map.js +43 -62
  2. package/lib/Widgets/Map/MapUtils.js +8 -40
  3. package/lib/Widgets/Map/points/PointUtils.js +1 -2
  4. package/lib/Widgets/MostPolluting/Areas/AreaBox/AreaBox.js +1 -2
  5. package/lib/Widgets/MostPolluting/Areas/AreaBox/Map/Map.js +19 -1
  6. package/lib/Widgets/MostPolluting/Areas/Areas.js +2 -2
  7. package/lib/Widgets/UtilityInformation/UtilityInformation.js +19 -9
  8. package/lib/components/Header/InfoBar/Breadcrumbs/Breadcrumbs.js +179 -82
  9. package/lib/i18n/en.json +0 -6
  10. package/lib/i18n/he.json +0 -2
  11. package/lib/macros/getVersion.js +2 -2
  12. package/lib/pages/DashboardMap/List.js +3 -12
  13. package/lib/pages/DashboardMap/WWTPMap.js +31 -40
  14. package/lib/pages/EventsPage/EventsMapContainer/EventsMapContainer.js +3 -3
  15. package/lib/pages/NotificationsPageV2/NotificationsPage.js +11 -20
  16. package/lib/pages/NotificationsPageV2/components/NotificationsForm/NotificationsFormContent.js +240 -105
  17. package/lib/pages/NotificationsPageV2/components/NotificationsSidebar.js +3 -5
  18. package/lib/pages/NotificationsPageV2/components/NotificationsUtils.js +2 -12
  19. package/lib/pages/NotificationsPageV2/notificationUtils.js +2 -3
  20. package/lib/pages/ProfilePage/ProfilePage.js +42 -71
  21. package/lib/pages/SitePage/SiteInformation/SiteInformation.js +1 -2
  22. package/lib/pages/UtilityDashboardPage/UtilityDashboardMapContainer/UtilityDashboardMapContainer.js +2 -2
  23. package/lib/styles/theme/theme.js +2 -2
  24. package/lib/utilities/scoreToData.js +2 -2
  25. package/package.json +1 -1
  26. package/lib/pages/NotificationsPageV2/components/NotificationsForm/EventType.js +0 -42
  27. package/lib/pages/NotificationsPageV2/components/NotificationsForm/NotificationSendVia.js +0 -64
  28. package/lib/pages/NotificationsPageV2/components/NotificationsForm/NotificationSensors.js +0 -58
  29. package/lib/pages/NotificationsPageV2/components/NotificationsForm/NotificationSources.js +0 -58
  30. package/lib/pages/NotificationsPageV2/components/NotificationsForm/NotificationTags.js +0 -59
  31. package/lib/pages/NotificationsPageV2/components/NotificationsForm/WaterAuthoritySelection.js +0 -59
@@ -49,15 +49,6 @@ var List = function List(props) {
49
49
  handleSelectItem(item);
50
50
  };
51
51
  var noDataMessage = _i18n.default.t('wwtpPage.no_data_for_site');
52
- var showedAreas = function showedAreas(focusedArea) {
53
- var allArray = focusedArea.sub_areas && (0, _utils.sortAreas)(focusedArea.sub_areas).filter(Boolean);
54
- if (focusedArea.area_id === null && focusedArea.area_name === '') {
55
- allArray = allArray.filter(function (area) {
56
- return area.top_level === true;
57
- });
58
- }
59
- return allArray;
60
- };
61
52
  var listDetails = (0, _react.useMemo)(function () {
62
53
  var _focusedArea$sub_area, _focusedArea$sub_area2;
63
54
  if (!siteID && !focusedArea) {
@@ -82,7 +73,7 @@ var List = function List(props) {
82
73
  }
83
74
  }
84
75
  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) {
85
- return showedAreas(focusedArea).map(function (area) {
76
+ return focusedArea.sub_areas && (0, _utils.sortAreas)(focusedArea.sub_areas).filter(Boolean).map(function (area) {
86
77
  return /*#__PURE__*/_react.default.createElement(_AreaCard.AreaCard, {
87
78
  key: area.area_id,
88
79
  object: area,
@@ -110,7 +101,7 @@ var List = function List(props) {
110
101
  });
111
102
  }
112
103
  }
113
- }, [selectedItem, focusedArea]);
104
+ }, [selectedItem, siteID, focusedArea]);
114
105
 
115
106
  // Update the list only if the score of at least one of the sub-areas has changed
116
107
  (0, _react.useEffect)(function () {
@@ -218,4 +209,4 @@ var ErrorMessage = _styledComponents.default.div.withConfig({
218
209
  displayName: "List__ErrorMessage",
219
210
  componentId: "sc-1f5wz2c-4"
220
211
  })(["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;"]);
221
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_theme","_reactRedux","_utils","_AreaCard","_FactoryCard","_OrganicCard","_interopRequireDefault","_PotentialSaving","_ListContext","_i18n","_DischargePattern","_QualitySummary","_LineChart","_WWTPDashboardSlice","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof3","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","List","props","_WWTPInfo$point","_WWTPInfo$point2","ReduxState","useSelector","state","areas_data","points_data","dispatch","useDispatch","_useSelectedItem","useSelectedItem","selectedItem","handleSelectItem","WWTPInfo","_useSelector","wwtp_dashboard","focusedArea","map","selectedRef","useRef","siteID","point","id","handleItemClick","item","noDataMessage","i18n","t","showedAreas","allArray","sub_areas","sortAreas","filter","Boolean","area_id","area_name","area","top_level","listDetails","useMemo","_focusedArea$sub_area","_focusedArea$sub_area2","is_no_areas","forWWTPMap","undefined","length","has_device","createElement","ListContainer","ErrorMessage","SummaryComponent","endpoint","concat","className","LineChartComponent","title","DischargePattern","Number","AreaCard","object","mapRef","onClick","selected","itemRef","factories","sortPoints","factory","FactoryCard","useEffect","isFetching","subAreasChanged","areasScoreChangedById","newAreas","focusedAreaWithUpdatedSubAreas","_objectSpread2","getUpdatedAreasById","setFocusedArea","_points_data$items","items","getPoints","arr1","arr2","_iterator","_createForOfIteratorHelper2","_step","_loop","item1","value","matchingItem","find","item2","area_score","v","s","n","done","_ret","_typeof2","err","e","f","array1","array2","updatedArray","obj2","some","obj1","_selectedRef$current","current","scrollIntoView","behavior","block","inline","group","type","clicked","WWTPDetails","style","overflow","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, getPoints, sortPoints } 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, points_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  const showedAreas = (focusedArea) => {\n    let allArray =\n      focusedArea.sub_areas && sortAreas(focusedArea.sub_areas).filter(Boolean);\n\n    if (focusedArea.area_id === null && focusedArea.area_name === '') {\n      allArray = allArray.filter((area) => area.top_level === true);\n    }\n\n    return allArray;\n  };\n\n  const 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 showedAreas(focusedArea).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    } else {\n      if (focusedArea?.factories) {\n        return sortPoints(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, 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?.isFetching === false\n    ) {\n      const subAreasChanged = areasScoreChangedById(\n        focusedArea.sub_areas,\n        areas_data.newAreas,\n      );\n      if (!subAreasChanged) return;\n\n      const focusedAreaWithUpdatedSubAreas = {\n        ...focusedArea,\n        sub_areas: getUpdatedAreasById(\n          focusedArea.sub_areas,\n          areas_data.newAreas,\n        ),\n      };\n      dispatch(setFocusedArea(focusedAreaWithUpdatedSubAreas));\n    }\n  }, [areas_data]);\n\n  useEffect(() => {\n    if (\n      !focusedArea ||\n      !focusedArea.factories ||\n      focusedArea.factories.length === 0 ||\n      points_data?.isFetching === true ||\n      points_data?.items?.length === 0\n    )\n      return;\n\n    dispatch(\n      setFocusedArea({\n        ...focusedArea,\n        factories: getPoints(focusedArea?.factories, points_data.items),\n      }),\n    );\n  }, [points_data]);\n\n  const areasScoreChangedById = (arr1, arr2) => {\n    // go over the 1st 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      // Return true if one matching item is found in the second array and their scores changed\n      if (matchingItem && item1.area_score !== matchingItem.area_score) {\n        return true;\n      }\n    }\n\n    // If all items matched and had the same score, return false\n    return false;\n  };\n\n  const getUpdatedAreasById = (array1, array2) => {\n    const updatedArray = array2.filter((obj2) =>\n      array1.some((obj1) => obj1.area_id === obj2.area_id),\n    );\n\n    return updatedArray?.length > 0 ? updatedArray : array1;\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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"}
212
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_theme","_reactRedux","_utils","_AreaCard","_FactoryCard","_OrganicCard","_interopRequireDefault","_PotentialSaving","_ListContext","_i18n","_DischargePattern","_QualitySummary","_LineChart","_WWTPDashboardSlice","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof3","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","List","props","_WWTPInfo$point","_WWTPInfo$point2","ReduxState","useSelector","state","areas_data","points_data","dispatch","useDispatch","_useSelectedItem","useSelectedItem","selectedItem","handleSelectItem","WWTPInfo","_useSelector","wwtp_dashboard","focusedArea","map","selectedRef","useRef","siteID","point","id","handleItemClick","item","noDataMessage","i18n","t","listDetails","useMemo","_focusedArea$sub_area","_focusedArea$sub_area2","is_no_areas","forWWTPMap","undefined","sub_areas","length","has_device","createElement","ListContainer","ErrorMessage","SummaryComponent","endpoint","concat","className","LineChartComponent","title","DischargePattern","Number","sortAreas","filter","Boolean","area","AreaCard","area_id","object","mapRef","onClick","selected","itemRef","factories","sortPoints","factory","FactoryCard","useEffect","isFetching","subAreasChanged","areasScoreChangedById","newAreas","focusedAreaWithUpdatedSubAreas","_objectSpread2","getUpdatedAreasById","setFocusedArea","_points_data$items","items","getPoints","arr1","arr2","_iterator","_createForOfIteratorHelper2","_step","_loop","item1","value","matchingItem","find","item2","area_score","v","s","n","done","_ret","_typeof2","err","e","f","array1","array2","updatedArray","obj2","some","obj1","_selectedRef$current","current","scrollIntoView","behavior","block","inline","group","type","clicked","WWTPDetails","style","overflow","name","area_name","exports","styled","div","withConfig","displayName","componentId","theme","WWTPMap","bg","QualitySummary","LineChart"],"sources":["../../../src/pages/DashboardMap/List.tsx"],"sourcesContent":["import { IArea } from '../../store/areas/models/IArea';\nimport React, { useEffect, useMemo, useRef } from 'react';\nimport styled from 'styled-components/macro';\nimport { theme } from 'src/styles/theme/theme';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { appReducer } from '../../store/rootReducer';\nimport { sortAreas, getPoints, sortPoints } 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, points_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 sortPoints(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?.isFetching === false\n    ) {\n      const subAreasChanged = areasScoreChangedById(\n        focusedArea.sub_areas,\n        areas_data.newAreas,\n      );\n      if (!subAreasChanged) return;\n\n      const focusedAreaWithUpdatedSubAreas = {\n        ...focusedArea,\n        sub_areas: getUpdatedAreasById(\n          focusedArea.sub_areas,\n          areas_data.newAreas,\n        ),\n      };\n      dispatch(setFocusedArea(focusedAreaWithUpdatedSubAreas));\n    }\n  }, [areas_data]);\n\n  useEffect(() => {\n    if (\n      !focusedArea ||\n      !focusedArea.factories ||\n      focusedArea.factories.length === 0 ||\n      points_data?.isFetching === true ||\n      points_data?.items?.length === 0\n    )\n      return;\n\n    dispatch(\n      setFocusedArea({\n        ...focusedArea,\n        factories: getPoints(focusedArea?.factories, points_data.items),\n      }),\n    );\n  }, [points_data]);\n\n  const areasScoreChangedById = (arr1, arr2) => {\n    // go over the 1st 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      // Return true if one matching item is found in the second array and their scores changed\n      if (matchingItem && item1.area_score !== matchingItem.area_score) {\n        return true;\n      }\n    }\n\n    // If all items matched and had the same score, return false\n    return false;\n  };\n\n  const getUpdatedAreasById = (array1, array2) => {\n    const updatedArray = array2.filter((obj2) =>\n      array1.some((obj1) => obj1.area_id === obj2.area_id),\n    );\n\n    return updatedArray?.length > 0 ? updatedArray : array1;\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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"}
@@ -26,6 +26,7 @@ var _Capacity = require("./Capacity");
26
26
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
27
27
  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; }
28
28
  var WWTPMap = function WWTPMap(props) {
29
+ var _ReduxState$wwtp_dash2;
29
30
  var searchQuery = (0, _useQueryURL.default)();
30
31
  var isMapTab = searchQuery.get('view') === 'map';
31
32
  var _useParams = (0, _reactRouterDom.useParams)(),
@@ -60,17 +61,14 @@ var WWTPMap = function WWTPMap(props) {
60
61
  var dataExists = function dataExists() {
61
62
  return areas_data.newAreas.length !== 0 || points_data.items.length !== 0 || edges_data.items.length !== 0;
62
63
  };
63
-
64
- // useEffect(() => {
65
- // if (global_data.waterAuthorityId) {
66
- // const period =
67
- // ReduxState.dashboard.period['range'] || ReduxState.dashboard.period;
68
- // dispatch(fetchPoints(global_data.waterAuthorityId, period));
69
- // dispatch(fetchEdges(global_data.waterAuthorityId));
70
- // dispatch(fetchAreas(global_data.waterAuthorityId, period, true));
71
- // }
72
- // }, [ReduxState.dashboard.period]);
73
-
64
+ (0, _react.useEffect)(function () {
65
+ if (global_data.waterAuthorityId) {
66
+ var period = ReduxState.dashboard.period['range'] || ReduxState.dashboard.period;
67
+ dispatch((0, _actions3.fetchPoints)(global_data.waterAuthorityId, period));
68
+ dispatch((0, _actions2.fetchEdges)(global_data.waterAuthorityId));
69
+ dispatch((0, _actions.fetchAreas)(global_data.waterAuthorityId, period, true));
70
+ }
71
+ }, [ReduxState.dashboard.period]);
74
72
  (0, _react.useEffect)(function () {
75
73
  (0, _utils.initializeWWTPData)({
76
74
  areas_data: areas_data,
@@ -82,10 +80,13 @@ var WWTPMap = function WWTPMap(props) {
82
80
  id: id
83
81
  });
84
82
  }, [areas_data]);
85
-
86
- // useEffect(() => {
87
- // setWWTPInfo(calculateWWTPInfo({ id, points_data, areas_data }));
88
- // }, [id]);
83
+ (0, _react.useEffect)(function () {
84
+ setWWTPInfo((0, _utils.calculateWWTPInfo)({
85
+ id: id,
86
+ points_data: points_data,
87
+ areas_data: areas_data
88
+ }));
89
+ }, [id]);
89
90
 
90
91
  // useEffect(() => {
91
92
  // focusMap(WWTPInfo.area || WWTPInfo.point, wwtp_dashboard.map);
@@ -94,17 +95,19 @@ var WWTPMap = function WWTPMap(props) {
94
95
  (0, _react.useEffect)(function () {
95
96
  if (global_data.waterAuthorityId) {
96
97
  var period = ReduxState.dashboard.period['range'] || ReduxState.dashboard.period;
97
- dispatch((0, _actions3.fetchPoints)(global_data.waterAuthorityId, period));
98
- dispatch((0, _actions2.fetchEdges)(global_data.waterAuthorityId));
99
- dispatch((0, _actions.fetchAreas)(global_data.waterAuthorityId, period, true));
98
+ points_data.items.length === 0 && dispatch((0, _actions3.fetchPoints)(global_data.waterAuthorityId, period));
99
+ edges_data.items.length === 0 && dispatch((0, _actions2.fetchEdges)(global_data.waterAuthorityId));
100
+ areas_data.items.length === 0 && dispatch((0, _actions.fetchAreas)(global_data.waterAuthorityId, period, true));
100
101
  }
101
-
102
- // return function cleanup() {
103
- // setPoints(null);
104
- // setAreas(null);
105
- // setWWTPInfo({ point: null, area: null });
106
- // };
107
- }, [global_data.waterAuthorityId, ReduxState.dashboard.period]);
102
+ return function cleanup() {
103
+ setPoints(null);
104
+ setAreas(null);
105
+ setWWTPInfo({
106
+ point: null,
107
+ area: null
108
+ });
109
+ };
110
+ }, [global_data.waterAuthorityId, id]);
108
111
  (0, _react.useEffect)(function () {
109
112
  var object = WWTPInfo.area || WWTPInfo.point;
110
113
  if (isMapTab && object) {
@@ -122,7 +125,7 @@ var WWTPMap = function WWTPMap(props) {
122
125
  (0, _Capacity.setFocusedItem)(undefined, null, points, utilityDirects, dispatch, _WWTPDashboardSlice.setFocusedArea, true);
123
126
  }
124
127
  // focusMap(object, wwtp_dashboard.map);
125
- }, [wwtp_dashboard.map]);
128
+ }, [wwtp_dashboard.map, id]);
126
129
 
127
130
  // useEffect(() => {
128
131
  // if (!ReduxState.wwtp_dashboard.focusedArea || !wwtp_dashboard.map) return;
@@ -130,18 +133,6 @@ var WWTPMap = function WWTPMap(props) {
130
133
  // //focusMap(ReduxState.wwtp_dashboard.focusedArea, wwtp_dashboard.map);
131
134
  // }, [ReduxState.wwtp_dashboard.focusedArea]);
132
135
 
133
- var getAreaToCenterBy = function getAreaToCenterBy() {
134
- var _ReduxState$wwtp_dash2, _ReduxState$wwtp_dash4, _ReduxState$wwtp_dash5;
135
- console.warn('focusedArea', ReduxState.wwtp_dashboard.focusedArea);
136
- console.warn('WWTPInfo', WWTPInfo);
137
- if ((_ReduxState$wwtp_dash2 = ReduxState.wwtp_dashboard.focusedArea) === null || _ReduxState$wwtp_dash2 === void 0 ? void 0 : _ReduxState$wwtp_dash2.shape_data) {
138
- var _ReduxState$wwtp_dash3;
139
- return (_ReduxState$wwtp_dash3 = ReduxState.wwtp_dashboard.focusedArea) === null || _ReduxState$wwtp_dash3 === void 0 ? void 0 : _ReduxState$wwtp_dash3.shape_data;
140
- }
141
- return (_ReduxState$wwtp_dash4 = ReduxState.wwtp_dashboard.focusedArea) === null || _ReduxState$wwtp_dash4 === void 0 ? void 0 : (_ReduxState$wwtp_dash5 = _ReduxState$wwtp_dash4.sub_areas) === null || _ReduxState$wwtp_dash5 === void 0 ? void 0 : _ReduxState$wwtp_dash5.map(function (area) {
142
- return area.shape_data;
143
- });
144
- };
145
136
  if (!isMapTab) return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null);
146
137
  if (!dataExists() || !points || !areas) return /*#__PURE__*/_react.default.createElement(_Loader.Loader, null);
147
138
  return /*#__PURE__*/_react.default.createElement(_ListContext.SelectedItemProvider, null, /*#__PURE__*/_react.default.createElement(Container, props, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Row, {
@@ -166,7 +157,7 @@ var WWTPMap = function WWTPMap(props) {
166
157
  includeUnmonitoredPoints: true,
167
158
  forEventsView: false,
168
159
  forWWTPDashboard: true,
169
- areaToCenterBy: getAreaToCenterBy()
160
+ areaToCenterBy: (_ReduxState$wwtp_dash2 = ReduxState.wwtp_dashboard.focusedArea) === null || _ReduxState$wwtp_dash2 === void 0 ? void 0 : _ReduxState$wwtp_dash2.shape_data
170
161
  })))));
171
162
  };
172
163
  var Container = _styledComponents.default.div.withConfig({
@@ -175,4 +166,4 @@ var Container = _styledComponents.default.div.withConfig({
175
166
  })(["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;}}}"]);
176
167
  var _default = WWTPMap;
177
168
  exports.default = _default;
178
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_reactRedux","require","_react","_interopRequireWildcard","_Map","_actions","_actions2","_actions3","_List","_utils","_Loader","_reactRouterDom","_useQueryURL","_interopRequireDefault","_WWTPDashboardSlice","_ListContext","_reactBootstrap","_Capacity","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","WWTPMap","props","searchQuery","useQueryURL","isMapTab","_useParams","useParams","id","areaID","siteID","ReduxState","useSelector","state","dispatch","useDispatch","areas_data","global_data","points_data","edges_data","wwtp_dashboard","_useState","useState","_useState2","_slicedToArray2","points","setPoints","_useState3","_useState4","areas","setAreas","_useState5","point","area","_useState6","WWTPInfo","setWWTPInfo","dataExists","newAreas","length","items","useEffect","initializeWWTPData","waterAuthorityId","period","dashboard","fetchPoints","fetchEdges","fetchAreas","object","_ReduxState$wwtp_dash","type","is_virtual","validObject","toString","area_id","parseInt","showExtra","focusedArea","fetchCapacity","then","response","setFocusedItem","data","setFocusedArea","utilityDirects","sortAreas","undefined","map","getAreaToCenterBy","_ReduxState$wwtp_dash2","_ReduxState$wwtp_dash4","_ReduxState$wwtp_dash5","console","warn","shape_data","_ReduxState$wwtp_dash3","sub_areas","createElement","Fragment","Loader","SelectedItemProvider","Container","Row","className","Col","xs","sm","List","Map","edges","includeUnmonitoredPoints","forEventsView","forWWTPDashboard","areaToCenterBy","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 { initializeWWTPData, sortAreas } from './utils';\nimport { Loader } from './Loader';\nimport { useParams } from 'react-router-dom';\nimport useQueryURL from '../../hooks/useQueryURL';\nimport { setFocusedArea } from '../../store/WWTPDashboard/WWTPDashboardSlice';\nimport { SelectedItemProvider } from './ListContext';\nimport { Row, Col } from 'react-bootstrap';\nimport { fetchCapacity, setFocusedItem } from './Capacity';\n\nexport interface CapacityMapContainerProps {\n  className: string;\n}\nconst WWTPMap: React.FC<CapacityMapContainerProps> = (props) => {\n  const searchQuery = useQueryURL();\n  const isMapTab = searchQuery.get('view') === 'map';\n  let { id, areaID, siteID } = useParams();\n  id = id || areaID || siteID;\n  const ReduxState = useSelector((state) => state);\n  const dispatch = useDispatch();\n  const { areas_data, global_data, points_data, edges_data, wwtp_dashboard } =\n    ReduxState;\n  const [points, setPoints] = useState<IPoint[] | null>(null);\n  const [areas, setAreas] = useState<IArea[] | null>(null);\n  const [WWTPInfo, setWWTPInfo] = useState<{\n    point: IPoint | null;\n    area: IArea | null;\n  }>({ point: null, area: null });\n  let dataExists = () => {\n    return (\n      areas_data.newAreas.length !== 0 ||\n      points_data.items.length !== 0 ||\n      edges_data.items.length !== 0\n    );\n  };\n\n  // useEffect(() => {\n  //   if (global_data.waterAuthorityId) {\n  //     const period =\n  //       ReduxState.dashboard.period['range'] || ReduxState.dashboard.period;\n  //     dispatch(fetchPoints(global_data.waterAuthorityId, period));\n  //     dispatch(fetchEdges(global_data.waterAuthorityId));\n  //     dispatch(fetchAreas(global_data.waterAuthorityId, period, true));\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      const period =\n        ReduxState.dashboard.period['range'] || ReduxState.dashboard.period;\n      dispatch(fetchPoints(global_data.waterAuthorityId, period));\n      dispatch(fetchEdges(global_data.waterAuthorityId));\n      dispatch(fetchAreas(global_data.waterAuthorityId, period, true));\n    }\n\n    // return function cleanup() {\n    //   setPoints(null);\n    //   setAreas(null);\n    //   setWWTPInfo({ point: null, area: null });\n    // };\n  }, [global_data.waterAuthorityId, ReduxState.dashboard.period]);\n\n  useEffect(() => {\n    const object = WWTPInfo.area || WWTPInfo.point;\n\n    if (isMapTab && object) {\n      const type = WWTPInfo.area\n        ? object.is_virtual === true\n          ? 'varea'\n          : 'area'\n        : 'site';\n\n      const validObject =\n        type === 'site'\n          ? object.id.toString() === id\n          : object.area_id === parseInt(id);\n\n      const showExtra = object.id === ReduxState.wwtp_dashboard.focusedArea?.id;\n\n      if (validObject) {\n        fetchCapacity(type, id, global_data.waterAuthorityId).then(\n          (response) => {\n            setFocusedItem(\n              object,\n              response.data,\n              points,\n              areas,\n              dispatch,\n              setFocusedArea,\n              showExtra,\n            );\n          },\n        );\n      }\n    } else {\n      const utilityDirects = sortAreas(areas);\n\n      setFocusedItem(\n        undefined,\n        null,\n        points,\n        utilityDirects,\n        dispatch,\n        setFocusedArea,\n        true,\n      );\n    }\n    // focusMap(object, wwtp_dashboard.map);\n  }, [wwtp_dashboard.map]);\n\n  // useEffect(() => {\n  //   if (!ReduxState.wwtp_dashboard.focusedArea || !wwtp_dashboard.map) return;\n\n  //   //focusMap(ReduxState.wwtp_dashboard.focusedArea, wwtp_dashboard.map);\n  // }, [ReduxState.wwtp_dashboard.focusedArea]);\n\n  const getAreaToCenterBy = () => {\n    console.warn('focusedArea', ReduxState.wwtp_dashboard.focusedArea);\n    console.warn('WWTPInfo', WWTPInfo);\n    if (ReduxState.wwtp_dashboard.focusedArea?.shape_data) {\n      return ReduxState.wwtp_dashboard.focusedArea?.shape_data;\n    }\n    return ReduxState.wwtp_dashboard.focusedArea?.sub_areas?.map(\n      (area) => area.shape_data,\n    );\n  };\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              areaToCenterBy={getAreaToCenterBy()}\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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"}
169
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_reactRedux","require","_react","_interopRequireWildcard","_Map","_actions","_actions2","_actions3","_List","_utils","_Loader","_reactRouterDom","_useQueryURL","_interopRequireDefault","_WWTPDashboardSlice","_ListContext","_reactBootstrap","_Capacity","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","WWTPMap","props","_ReduxState$wwtp_dash2","searchQuery","useQueryURL","isMapTab","_useParams","useParams","id","areaID","siteID","ReduxState","useSelector","state","dispatch","useDispatch","areas_data","global_data","points_data","edges_data","wwtp_dashboard","_useState","useState","_useState2","_slicedToArray2","points","setPoints","_useState3","_useState4","areas","setAreas","_useState5","point","area","_useState6","WWTPInfo","setWWTPInfo","dataExists","newAreas","length","items","useEffect","waterAuthorityId","period","dashboard","fetchPoints","fetchEdges","fetchAreas","initializeWWTPData","calculateWWTPInfo","cleanup","object","_ReduxState$wwtp_dash","type","is_virtual","validObject","toString","area_id","parseInt","showExtra","focusedArea","fetchCapacity","then","response","setFocusedItem","data","setFocusedArea","utilityDirects","sortAreas","undefined","map","createElement","Fragment","Loader","SelectedItemProvider","Container","Row","className","Col","xs","sm","List","Map","edges","includeUnmonitoredPoints","forEventsView","forWWTPDashboard","areaToCenterBy","shape_data","styled","div","withConfig","displayName","componentId","_default","exports"],"sources":["../../../src/pages/DashboardMap/WWTPMap.tsx"],"sourcesContent":["import { useDispatch, useSelector } from 'react-redux';\nimport React, { useEffect, useState } from 'react';\nimport { Map } from 'src/Widgets/Map/Map';\nimport { fetchAreas } from 'src/store/areas/actions';\nimport { fetchEdges } from 'src/store/edges/actions';\nimport { fetchPoints } from 'src/store/points/actions';\nimport styled from 'styled-components/macro';\nimport { List } from './List';\nimport { IPoint } from '../../store/points/models/IPoint';\nimport { IArea } from '../../store/areas/models/IArea';\nimport { calculateWWTPInfo, initializeWWTPData, sortAreas } from './utils';\nimport { Loader } from './Loader';\nimport { useParams } from 'react-router-dom';\nimport useQueryURL from '../../hooks/useQueryURL';\nimport { setFocusedArea } from '../../store/WWTPDashboard/WWTPDashboardSlice';\nimport { SelectedItemProvider } from './ListContext';\nimport { Row, Col } from 'react-bootstrap';\nimport { fetchCapacity, setFocusedItem } from './Capacity';\n\nexport interface CapacityMapContainerProps {\n  className: string;\n}\nconst WWTPMap: React.FC<CapacityMapContainerProps> = (props) => {\n  const searchQuery = useQueryURL();\n  const isMapTab = searchQuery.get('view') === 'map';\n  let { id, areaID, siteID } = useParams();\n  id = id || areaID || siteID;\n  const ReduxState = useSelector((state) => state);\n  const dispatch = useDispatch();\n  const { areas_data, global_data, points_data, edges_data, wwtp_dashboard } =\n    ReduxState;\n  const [points, setPoints] = useState<IPoint[] | null>(null);\n  const [areas, setAreas] = useState<IArea[] | null>(null);\n  const [WWTPInfo, setWWTPInfo] = useState<{\n    point: IPoint | null;\n    area: IArea | null;\n  }>({ point: null, area: null });\n  let dataExists = () => {\n    return (\n      areas_data.newAreas.length !== 0 ||\n      points_data.items.length !== 0 ||\n      edges_data.items.length !== 0\n    );\n  };\n\n  useEffect(() => {\n    if (global_data.waterAuthorityId) {\n      const period =\n        ReduxState.dashboard.period['range'] || ReduxState.dashboard.period;\n      dispatch(fetchPoints(global_data.waterAuthorityId, period));\n      dispatch(fetchEdges(global_data.waterAuthorityId));\n      dispatch(fetchAreas(global_data.waterAuthorityId, period, true));\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      const period =\n        ReduxState.dashboard.period['range'] || ReduxState.dashboard.period;\n      points_data.items.length === 0 &&\n        dispatch(fetchPoints(global_data.waterAuthorityId, period));\n      edges_data.items.length === 0 &&\n        dispatch(fetchEdges(global_data.waterAuthorityId));\n      areas_data.items.length === 0 &&\n        dispatch(fetchAreas(global_data.waterAuthorityId, period, true));\n    }\n\n    return function cleanup() {\n      setPoints(null);\n      setAreas(null);\n      setWWTPInfo({ point: null, area: null });\n    };\n  }, [global_data.waterAuthorityId, id]);\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, id]);\n\n  // useEffect(() => {\n  //   if (!ReduxState.wwtp_dashboard.focusedArea || !wwtp_dashboard.map) return;\n\n  //   //focusMap(ReduxState.wwtp_dashboard.focusedArea, wwtp_dashboard.map);\n  // }, [ReduxState.wwtp_dashboard.focusedArea]);\n\n  if (!isMapTab) return <></>;\n  if (!dataExists() || !points || !areas) return <Loader />;\n\n  return (\n    <SelectedItemProvider>\n      <Container {...props}>\n        <Row className=\"no-gutters\">\n          <Col xs=\"auto\" sm={4} className=\"d-none d-sm-flex\">\n            <List\n              global_data={global_data}\n              WWTPInfo={WWTPInfo}\n              dispatch={dispatch}\n            />\n          </Col>\n          <Col className=\"map-column\" xs={12} sm={8}>\n            <Map\n              points={points}\n              areas={areas}\n              global_data={global_data}\n              edges={edges_data.items}\n              includeUnmonitoredPoints={true}\n              forEventsView={false}\n              forWWTPDashboard={true}\n              areaToCenterBy={ReduxState.wwtp_dashboard.focusedArea?.shape_data}\n            />\n          </Col>\n        </Row>\n      </Container>\n    </SelectedItemProvider>\n  );\n};\n\nconst Container = styled.div`\n  width: 100vw;\n\n  .map-column {\n    z-index: 0;\n  }\n\n  .kd-map-container {\n    height: calc(100vh - 134px);\n    width: 100%;\n\n    @media (max-width: 1250px) {\n      height: calc(100vh - 125px);\n    }\n\n    #map {\n      height: 100%;\n      width: 100%;\n\n      *,\n      *:focus,\n      *:hover {\n        outline: none;\n      }\n\n      .leaflet-popup-close-button {\n        font-size: x-large;\n      }\n    }\n  }\n`;\n\nexport default WWTPMap;\n"],"mappings":"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"}
@@ -78,7 +78,7 @@ var EventsMapContainer = function EventsMapContainer(props) {
78
78
  var mappedPoints = (0, _react.useMemo)(function () {
79
79
  return points_data.items.map(function (point) {
80
80
  var newPoint = (0, _objectSpread2.default)({}, point);
81
- if (EventsPerSite === undefined || !EventsPerSite[point.id] || (0, _EventUtils.isCollectorUnmonitored)(point)) {
81
+ if (!EventsPerSite[point.id] || (0, _EventUtils.isCollectorUnmonitored)(point)) {
82
82
  newPoint.hide = true;
83
83
  }
84
84
  if (events_data.focusedEvent) {
@@ -94,7 +94,7 @@ var EventsMapContainer = function EventsMapContainer(props) {
94
94
  newPoint.hide = false;
95
95
  }
96
96
  }
97
- newPoint.relatedEventsAmount = EventsPerSite ? EventsPerSite[point.id] : 0;
97
+ newPoint.relatedEventsAmount = EventsPerSite[point.id] || 0;
98
98
  newPoint.eventsViewHovered = true;
99
99
  return newPoint;
100
100
  });
@@ -149,4 +149,4 @@ var EventsMapContainer = function EventsMapContainer(props) {
149
149
  }));
150
150
  };
151
151
  exports.EventsMapContainer = EventsMapContainer;
152
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRedux","_EventsMapContainerHelpers","_actions","_actions2","_actions3","_Map","_FloatingGraph","_interopRequireDefault","_GraphUtils","_actions4","_DragAndDropArea","_EventUtils","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","EventsMapContainer","props","_global_data$floating","_global_data$floating2","dispatch","useDispatch","ReduxState","useSelector","state","areas_data","global_data","points_data","events_data","edges_data","isTimeFilterNotSelected","useMemo","_global_data$activeFi","filters","activeFilter","filter_items","length","index","type","mappedAreas","areasMapper","getActiveTimeFilterPeriod","_global_data$activeFi2","items","activeTimeFilter","selected_options","JSON","parse","EventsPerSite","CountEventsPerSiteID","MustSeenSites","focusedEvent","getFocusedEventMustSeenSites","hoveredEvent","mappedPoints","map","point","newPoint","_objectSpread2","undefined","id","isCollectorUnmonitored","hide","relatedEventsAmount","eventsViewHovered","mappedEdges","filter","edge","descendants_has_device","descendants_has_none_collectors","areaToCenterBy","getAreasToCenterBy","useEffect","waterAuthorityId","period","fetchPoints","fetchEdges","fetchAreas","createElement","Map","assign","areas","points","edges","events","hideEdges","includeUnmonitoredPoints","includeUnmonitoredDescendantsForEdges","forEventsView","focusedEventPath","focusedEventPaths","floatingGraph","isOpen","open","customHighChartOptions","dndGraphInitOptions","closeGraphHandler","closeFloatingGraph","globalDataFloatingGraph","event_data","graphId","exports"],"sources":["../../../../src/pages/EventsPage/EventsMapContainer/EventsMapContainer.tsx"],"sourcesContent":["import React, { useEffect, useMemo } from 'react';\nimport { useDispatch, useSelector } from 'react-redux';\nimport {\n  areasMapper,\n  CountEventsPerSiteID,\n  getAreasToCenterBy,\n  getFocusedEventMustSeenSites,\n} from 'src/pages/EventsPage/EventsMapContainer/EventsMapContainerHelpers';\nimport { fetchAreas } from 'src/store/areas/actions';\nimport { fetchEdges } from 'src/store/edges/actions';\nimport { fetchPoints } from 'src/store/points/actions';\nimport { Map } from 'src/Widgets/Map/Map';\nimport FloatingGraph from 'src/pages/EventsPage/FloatingGraph/FloatingGraph';\nimport { dndGraphInitOptions } from 'src/Widgets/Map/GraphUtils';\nimport { closeFloatingGraph } from 'src/store/global/actions';\nimport DragAndDropArea from '../DragAndDropArea';\nimport { isCollectorUnmonitored } from 'src/Widgets/Map/events/EventUtils';\ninterface EventsMapContainerProps {\n  showSecondMap: boolean;\n}\nexport const EventsMapContainer: React.FC<EventsMapContainerProps> = (\n  props,\n) => {\n  const dispatch = useDispatch();\n  const ReduxState = useSelector((state) => state);\n  const { areas_data, global_data, points_data, events_data, edges_data } =\n    ReduxState;\n\n  const isTimeFilterNotSelected = useMemo(() => {\n    const filters = global_data?.activeFilter?.filter_items;\n\n    if (!filters || filters.length < 1) {\n      return true;\n    }\n\n    for (let index = 0; index < filters.length; index++) {\n      if (filters[index].type === 'TimeFilterItem') {\n        return false;\n      }\n    }\n\n    return true;\n  }, [global_data?.activeFilter]);\n\n  const mappedAreas = useMemo(\n    () => areasMapper(areas_data, isTimeFilterNotSelected),\n    [areas_data, isTimeFilterNotSelected],\n  );\n\n  const getActiveTimeFilterPeriod = () => {\n    const items = global_data?.activeFilter?.filter_items;\n    let activeTimeFilter = '1m';\n\n    if (!items || items.length < 1) {\n      return activeTimeFilter;\n    }\n\n    for (let index = 0; index < items.length; index++) {\n      if (items[index].type === 'TimeFilterItem') {\n        if (typeof items[index].selected_options === 'string')\n          items[index].selected_options = JSON.parse(\n            items[index].selected_options,\n          );\n\n        activeTimeFilter = items[index].selected_options[0];\n        break;\n      }\n    }\n    return activeTimeFilter;\n  };\n\n  const EventsPerSite = useMemo(\n    () => CountEventsPerSiteID(events_data.items),\n    [events_data.items],\n  );\n\n  const MustSeenSites = useMemo(() => {\n    if (events_data.focusedEvent) {\n      return getFocusedEventMustSeenSites(events_data.focusedEvent);\n    } else if (events_data.hoveredEvent) {\n      return getFocusedEventMustSeenSites(events_data.hoveredEvent);\n    }\n    return {};\n  }, [EventsPerSite, events_data.focusedEvent, events_data.hoveredEvent]);\n\n  const mappedPoints = useMemo(\n    () =>\n      points_data.items.map((point) => {\n        const newPoint = { ...point };\n\n        if (\n          EventsPerSite === undefined ||\n          !EventsPerSite[point.id] ||\n          isCollectorUnmonitored(point)\n        ) {\n          newPoint.hide = true;\n        }\n\n        if (events_data.focusedEvent) {\n          if (!MustSeenSites[point.id]) {\n            newPoint.hide = true;\n          } else {\n            newPoint.hide = false;\n          }\n        } else if (events_data.hoveredEvent) {\n          if (!MustSeenSites[point.id] && isCollectorUnmonitored(point)) {\n            newPoint.hide = true;\n          } else {\n            newPoint.hide = false;\n          }\n        }\n\n        newPoint.relatedEventsAmount = EventsPerSite\n          ? EventsPerSite[point.id]\n          : 0;\n        newPoint.eventsViewHovered = true;\n        return newPoint;\n      }),\n    [\n      points_data,\n      EventsPerSite,\n      events_data.items,\n      events_data.focusedEvent,\n      events_data.hoveredEvent,\n    ],\n  );\n\n  // eslint-disable-next-line\n  const mappedEdges = edges_data.items.filter(\n    (edge) =>\n      // (Number(EventsPerSite[edge.source_point_id]) > 0 ||\n      // Number(EventsPerSite[edge.target_point_id]) > 0)\n      //  &&\n      edge.descendants_has_device === true ||\n      edge.descendants_has_none_collectors === true,\n  );\n\n  const areaToCenterBy = useMemo(\n    () => getAreasToCenterBy(global_data, mappedAreas),\n    [global_data?.activeFilter, mappedAreas],\n  );\n\n  useEffect(() => {\n    if (global_data.waterAuthorityId) {\n      const period = getActiveTimeFilterPeriod();\n      dispatch(fetchPoints(global_data.waterAuthorityId, period));\n      dispatch(fetchEdges(global_data.waterAuthorityId));\n      dispatch(fetchAreas(global_data.waterAuthorityId, period, true));\n    }\n  }, [global_data.waterAuthorityId, global_data.activeFilter]);\n\n  return (\n    <Map\n      {...ReduxState}\n      areas={mappedAreas}\n      global_data={global_data}\n      points={mappedPoints}\n      edges={mappedEdges}\n      events={events_data.items}\n      focusedEvent={events_data.focusedEvent}\n      hoveredEvent={events_data.hoveredEvent}\n      areaToCenterBy={areaToCenterBy}\n      hideEdges={true}\n      includeUnmonitoredPoints={false}\n      includeUnmonitoredDescendantsForEdges={true}\n      forEventsView={true}\n      {...props}\n    >\n      {\n        <DragAndDropArea focusedEventPath={events_data?.focusedEventPaths}>\n          {{\n            floatingGraph: (\n              <FloatingGraph\n                isOpen={global_data?.floatingGraph.open}\n                customHighChartOptions={dndGraphInitOptions}\n                closeGraphHandler={() => {\n                  dispatch(closeFloatingGraph());\n                }}\n                globalDataFloatingGraph={global_data.floatingGraph}\n                event_data={events_data?.focusedEvent}\n                graphId={global_data?.floatingGraph?.point?.id}\n              />\n            ),\n          }}\n        </DragAndDropArea>\n      }\n    </Map>\n  );\n};\n"],"mappings":"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"}
152
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRedux","_EventsMapContainerHelpers","_actions","_actions2","_actions3","_Map","_FloatingGraph","_interopRequireDefault","_GraphUtils","_actions4","_DragAndDropArea","_EventUtils","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","EventsMapContainer","props","_global_data$floating","_global_data$floating2","dispatch","useDispatch","ReduxState","useSelector","state","areas_data","global_data","points_data","events_data","edges_data","isTimeFilterNotSelected","useMemo","_global_data$activeFi","filters","activeFilter","filter_items","length","index","type","mappedAreas","areasMapper","getActiveTimeFilterPeriod","_global_data$activeFi2","items","activeTimeFilter","selected_options","JSON","parse","EventsPerSite","CountEventsPerSiteID","MustSeenSites","focusedEvent","getFocusedEventMustSeenSites","hoveredEvent","mappedPoints","map","point","newPoint","_objectSpread2","id","isCollectorUnmonitored","hide","relatedEventsAmount","eventsViewHovered","mappedEdges","filter","edge","descendants_has_device","descendants_has_none_collectors","areaToCenterBy","getAreasToCenterBy","useEffect","waterAuthorityId","period","fetchPoints","fetchEdges","fetchAreas","createElement","Map","assign","areas","points","edges","events","hideEdges","includeUnmonitoredPoints","includeUnmonitoredDescendantsForEdges","forEventsView","focusedEventPath","focusedEventPaths","floatingGraph","isOpen","open","customHighChartOptions","dndGraphInitOptions","closeGraphHandler","closeFloatingGraph","globalDataFloatingGraph","event_data","graphId","exports"],"sources":["../../../../src/pages/EventsPage/EventsMapContainer/EventsMapContainer.tsx"],"sourcesContent":["import React, { useEffect, useMemo } from 'react';\nimport { useDispatch, useSelector } from 'react-redux';\nimport {\n  areasMapper,\n  CountEventsPerSiteID,\n  getAreasToCenterBy,\n  getFocusedEventMustSeenSites,\n} from 'src/pages/EventsPage/EventsMapContainer/EventsMapContainerHelpers';\nimport { fetchAreas } from 'src/store/areas/actions';\nimport { fetchEdges } from 'src/store/edges/actions';\nimport { fetchPoints } from 'src/store/points/actions';\nimport { Map } from 'src/Widgets/Map/Map';\nimport FloatingGraph from 'src/pages/EventsPage/FloatingGraph/FloatingGraph';\nimport { dndGraphInitOptions } from 'src/Widgets/Map/GraphUtils';\nimport { closeFloatingGraph } from 'src/store/global/actions';\nimport DragAndDropArea from '../DragAndDropArea';\nimport { isCollectorUnmonitored } from 'src/Widgets/Map/events/EventUtils';\ninterface EventsMapContainerProps {\n  showSecondMap: boolean;\n}\nexport const EventsMapContainer: React.FC<EventsMapContainerProps> = (\n  props,\n) => {\n  const dispatch = useDispatch();\n  const ReduxState = useSelector((state) => state);\n  const { areas_data, global_data, points_data, events_data, edges_data } =\n    ReduxState;\n\n  const isTimeFilterNotSelected = useMemo(() => {\n    const filters = global_data?.activeFilter?.filter_items;\n\n    if (!filters || filters.length < 1) {\n      return true;\n    }\n\n    for (let index = 0; index < filters.length; index++) {\n      if (filters[index].type === 'TimeFilterItem') {\n        return false;\n      }\n    }\n\n    return true;\n  }, [global_data?.activeFilter]);\n\n  const mappedAreas = useMemo(\n    () => areasMapper(areas_data, isTimeFilterNotSelected),\n    [areas_data, isTimeFilterNotSelected],\n  );\n\n  const getActiveTimeFilterPeriod = () => {\n    const items = global_data?.activeFilter?.filter_items;\n    let activeTimeFilter = '1m';\n\n    if (!items || items.length < 1) {\n      return activeTimeFilter;\n    }\n\n    for (let index = 0; index < items.length; index++) {\n      if (items[index].type === 'TimeFilterItem') {\n        if (typeof items[index].selected_options === 'string')\n          items[index].selected_options = JSON.parse(\n            items[index].selected_options,\n          );\n\n        activeTimeFilter = items[index].selected_options[0];\n        break;\n      }\n    }\n    return activeTimeFilter;\n  };\n\n  const EventsPerSite = useMemo(\n    () => CountEventsPerSiteID(events_data.items),\n    [events_data.items],\n  );\n\n  const MustSeenSites = useMemo(() => {\n    if (events_data.focusedEvent) {\n      return getFocusedEventMustSeenSites(events_data.focusedEvent);\n    } else if (events_data.hoveredEvent) {\n      return getFocusedEventMustSeenSites(events_data.hoveredEvent);\n    }\n    return {};\n  }, [EventsPerSite, events_data.focusedEvent, events_data.hoveredEvent]);\n\n  const mappedPoints = useMemo(\n    () =>\n      points_data.items.map((point) => {\n        const newPoint = { ...point };\n\n        if (!EventsPerSite[point.id] || isCollectorUnmonitored(point)) {\n          newPoint.hide = true;\n        }\n\n        if (events_data.focusedEvent) {\n          if (!MustSeenSites[point.id]) {\n            newPoint.hide = true;\n          } else {\n            newPoint.hide = false;\n          }\n        } else if (events_data.hoveredEvent) {\n          if (!MustSeenSites[point.id] && isCollectorUnmonitored(point)) {\n            newPoint.hide = true;\n          } else {\n            newPoint.hide = false;\n          }\n        }\n\n        newPoint.relatedEventsAmount = EventsPerSite[point.id] || 0;\n        newPoint.eventsViewHovered = true;\n        return newPoint;\n      }),\n    [\n      points_data,\n      EventsPerSite,\n      events_data.items,\n      events_data.focusedEvent,\n      events_data.hoveredEvent,\n    ],\n  );\n\n  // eslint-disable-next-line\n  const mappedEdges = edges_data.items.filter(\n    (edge) =>\n      // (Number(EventsPerSite[edge.source_point_id]) > 0 ||\n      // Number(EventsPerSite[edge.target_point_id]) > 0)\n      //  &&\n      edge.descendants_has_device === true ||\n      edge.descendants_has_none_collectors === true,\n  );\n\n  const areaToCenterBy = useMemo(\n    () => getAreasToCenterBy(global_data, mappedAreas),\n    [global_data?.activeFilter, mappedAreas],\n  );\n\n  useEffect(() => {\n    if (global_data.waterAuthorityId) {\n      const period = getActiveTimeFilterPeriod();\n      dispatch(fetchPoints(global_data.waterAuthorityId, period));\n      dispatch(fetchEdges(global_data.waterAuthorityId));\n      dispatch(fetchAreas(global_data.waterAuthorityId, period, true));\n    }\n  }, [global_data.waterAuthorityId, global_data.activeFilter]);\n\n  return (\n    <Map\n      {...ReduxState}\n      areas={mappedAreas}\n      global_data={global_data}\n      points={mappedPoints}\n      edges={mappedEdges}\n      events={events_data.items}\n      focusedEvent={events_data.focusedEvent}\n      hoveredEvent={events_data.hoveredEvent}\n      areaToCenterBy={areaToCenterBy}\n      hideEdges={true}\n      includeUnmonitoredPoints={false}\n      includeUnmonitoredDescendantsForEdges={true}\n      forEventsView={true}\n      {...props}\n    >\n      {\n        <DragAndDropArea focusedEventPath={events_data?.focusedEventPaths}>\n          {{\n            floatingGraph: (\n              <FloatingGraph\n                isOpen={global_data?.floatingGraph.open}\n                customHighChartOptions={dndGraphInitOptions}\n                closeGraphHandler={() => {\n                  dispatch(closeFloatingGraph());\n                }}\n                globalDataFloatingGraph={global_data.floatingGraph}\n                event_data={events_data?.focusedEvent}\n                graphId={global_data?.floatingGraph?.point?.id}\n              />\n            ),\n          }}\n        </DragAndDropArea>\n      }\n    </Map>\n  );\n};\n"],"mappings":"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"}