@kando-env/kando-ui 1.2.386-alpha.49 → 1.2.386-alpha.5

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 (56) hide show
  1. package/lib/Router.js +2 -2
  2. package/lib/Widgets/Map/graphDNDArea/GraphDNDArea.js +1 -1
  3. package/lib/Widgets/MostPolluting/assets/index.js +6 -6
  4. package/lib/Widgets/PotentialImpactSummary/Icon.js +11 -31
  5. package/lib/Widgets/QualitySummary/PieChart/PieChart.js +1 -1
  6. package/lib/Widgets/QualitySummary/PollutedLine/PollutedLine.js +1 -1
  7. package/lib/assets/icons/TopNavbar/index.js +6 -6
  8. package/lib/assets/icons/index.js +14 -14
  9. package/lib/assets/icons/kandoStepper/index.js +5 -5
  10. package/lib/assets/icons/siteTypes/index.js +1 -1
  11. package/lib/components/CustomInputs/PasswordInput/PasswordInput.js +1 -1
  12. package/lib/components/Header/InfoBar/Breadcrumbs/Breadcrumbs.js +1 -1
  13. package/lib/components/Header/InfoBar/InfoBar.js +1 -1
  14. package/lib/components/Header/Toolbar/CustomerMenu/CustomerMenu.js +2 -2
  15. package/lib/components/Header/Toolbar/MenuCreator/MenuCreator.js +1 -1
  16. package/lib/components/Header/Toolbar/SearchDropdown/SearchDropdown.js +1 -1
  17. package/lib/components/Header/Toolbar/Toolbar.js +2 -4
  18. package/lib/components/Sector/Sector.js +1 -1
  19. package/lib/components/Sector/SectorIconsNew.js +40 -42
  20. package/lib/components/SevereEvent/SevereEvent.js +2 -2
  21. package/lib/components/Tabs/assets/index.js +5 -5
  22. package/lib/i18n/en.json +2 -4
  23. package/lib/macros/getVersion.js +2 -2
  24. package/lib/pages/EventsPage/events/event_info/EventPath/EventPath.js +6 -6
  25. package/lib/pages/EventsPage/events/events_list/EventsList.js +1 -1
  26. package/lib/pages/EventsPage/events/events_list/Filter/Filter.js +1 -1
  27. package/lib/pages/EventsPage/events/events_list/Filter/FilterContainer.js +2 -2
  28. package/lib/pages/NotificationsPage/assets/index.js +9 -9
  29. package/lib/pages/NotificationsPageV2/components/NotificationsCard.js +4 -4
  30. package/lib/pages/NotificationsPageV2/components/NotificationsSidebar.js +1 -1
  31. package/lib/pages/OldSitePage/SamplingParameters/NoResults/NoResults.js +1 -1
  32. package/lib/pages/PollutionRiskAssessment/FactoryDetails.js +30 -57
  33. package/lib/pages/PollutionRiskAssessment/FilterBehaviors.js +4 -6
  34. package/lib/pages/PollutionRiskAssessment/FilterButton.js +3 -3
  35. package/lib/pages/PollutionRiskAssessment/Map.js +6 -4
  36. package/lib/pages/PollutionRiskAssessment/Map.scss +47 -12
  37. package/lib/pages/PollutionRiskAssessment/TotalSavings.js +13 -29
  38. package/lib/pages/PollutionRiskAssessment/UseCases.js +8 -4
  39. package/lib/pages/PollutionRiskAssessment/contact_us.svg +17 -2
  40. package/lib/pages/PollutionRiskAssessment/index.js +30 -9
  41. package/lib/pages/PollutionRiskAssessment/index.scss +4 -4
  42. package/lib/pages/PollutionRiskAssessment/useMap.js +11 -53
  43. package/lib/pages/PollutionRiskAssessment/utils.js +7 -9
  44. package/lib/pages/ProfilePage/ProfilePage.js +2 -2
  45. package/lib/pages/ProfilePage/TelegramModal/TelegramModal.js +1 -1
  46. package/lib/pages/SamplingsPage/ActionsDropDown/SamplingActionDropdown.js +1 -1
  47. package/lib/pages/SamplingsPage/SamplingProperties/ImageUpload.js +1 -1
  48. package/lib/pages/SamplingsPage/SamplingProperties/SamplingPropertiesHead.js +1 -1
  49. package/lib/pages/SamplingsPage/SamplingProperties/SamplingPropertiesHeadMobile.js +1 -1
  50. package/lib/pages/SitePage/SiteInformation/EmptyState.js +1 -1
  51. package/lib/pages/UtilityDashboardPage/MostSevereEvents/SevereEvent/SevereEvent.js +1 -1
  52. package/lib/pages/WbeDashboard/WbeDashboardPage.js +2 -2
  53. package/lib/ui-kit/KandoBottomSheet/KandoBottomSheet.js +16 -5
  54. package/lib/ui-kit/KandoBottomSheet/KandoBottomSheet.scss +10 -18
  55. package/lib/utilities/urls.js +2 -2
  56. package/package.json +1 -1
@@ -22,6 +22,7 @@ var _urls = require("../../utilities/urls");
22
22
  require("./index.scss");
23
23
  var _TotalSavings = require("./TotalSavings");
24
24
  var _FilterBehaviors = require("./FilterBehaviors");
25
+ var _FactoryDetails = require("./FactoryDetails");
25
26
  var _FilterButton = _interopRequireDefault(require("./FilterButton"));
26
27
  var _use_cases = _interopRequireDefault(require("./use_cases.json"));
27
28
  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); }
@@ -59,6 +60,10 @@ var PollutionRiskAssessment = function PollutionRiskAssessment() {
59
60
  _useState12 = (0, _slicedToArray2.default)(_useState11, 2),
60
61
  mapBounds = _useState12[0],
61
62
  setMapBounds = _useState12[1];
63
+ var _useState13 = (0, _react.useState)(),
64
+ _useState14 = (0, _slicedToArray2.default)(_useState13, 2),
65
+ clickedPointId = _useState14[0],
66
+ setClickedPointId = _useState14[1];
62
67
  var handleDismiss = function handleDismiss() {
63
68
  setShownContent('total_savings');
64
69
  };
@@ -114,7 +119,7 @@ var PollutionRiskAssessment = function PollutionRiskAssessment() {
114
119
  utility_name: waterAuthorityName
115
120
  });
116
121
  dispatch((0, _actions.updateNavContext)({
117
- name: 'pollution-risk-assessment'
122
+ name: 'pollution_risk_assessment'
118
123
  }));
119
124
  }
120
125
  }, [waterAuthorityId]);
@@ -147,7 +152,7 @@ var PollutionRiskAssessment = function PollutionRiskAssessment() {
147
152
  }),
148
153
  snapPoints: function snapPoints(_ref2) {
149
154
  var maxHeight = _ref2.maxHeight;
150
- return [168, maxHeight - 100];
155
+ return [90, maxHeight - 100];
151
156
  },
152
157
  backgroundColor: '#000'
153
158
  };
@@ -163,6 +168,17 @@ var PollutionRiskAssessment = function PollutionRiskAssessment() {
163
168
  },
164
169
  backgroundColor: '#fff'
165
170
  };
171
+ case 'factory_details':
172
+ return {
173
+ content: /*#__PURE__*/_react.default.createElement(_FactoryDetails.FactoryDetails, {
174
+ point_id: clickedPointId
175
+ }),
176
+ snapPoints: function snapPoints(_ref4) {
177
+ var maxHeight = _ref4.maxHeight;
178
+ return [maxHeight - 500, maxHeight - 500];
179
+ },
180
+ backgroundColor: '#fff'
181
+ };
166
182
  default:
167
183
  return {
168
184
  content: null,
@@ -173,7 +189,7 @@ var PollutionRiskAssessment = function PollutionRiskAssessment() {
173
189
  };
174
190
  }
175
191
  };
176
- var _useMemo = (0, _react.useMemo)(getBottomSheetConfig, [shownContent, useCasesFilter, visiblePoints]),
192
+ var _useMemo = (0, _react.useMemo)(getBottomSheetConfig, [shownContent, useCasesFilter, visiblePoints, clickedPointId]),
177
193
  content = _useMemo.content,
178
194
  snapPoints = _useMemo.snapPoints,
179
195
  backgroundColor = _useMemo.backgroundColor;
@@ -184,7 +200,7 @@ var PollutionRiskAssessment = function PollutionRiskAssessment() {
184
200
  onDismiss: handleDismiss,
185
201
  isOpen: true
186
202
  }, content);
187
- }, [visiblePoints, shownContent]);
203
+ }, [visiblePoints, shownContent, clickedPointId]);
188
204
  (0, _react.useEffect)(function () {
189
205
  if (!mapBounds || !pointsData) return;
190
206
  var filteredPoints = pointsData.filter(function (point) {
@@ -206,18 +222,23 @@ var PollutionRiskAssessment = function PollutionRiskAssessment() {
206
222
  }
207
223
  return useCasesFilter !== '' ? 'filled-red' : '';
208
224
  }, [shownContent, useCasesFilter]);
225
+ var markerClicked = function markerClicked(id) {
226
+ setClickedPointId(id);
227
+ if (shownContent !== 'factory_details') {
228
+ setShownContent('factory_details');
229
+ }
230
+ };
209
231
  if (!pointsData || !polygonData) return null;
210
232
  return /*#__PURE__*/_react.default.createElement("div", {
211
233
  className: "app-wrapper"
212
234
  }, /*#__PURE__*/_react.default.createElement(MapTableContainer, {
213
235
  isRtl: isRtl
214
236
  }, /*#__PURE__*/_react.default.createElement(_Map.Map, {
215
- filteredUseCase: useCase ? useCase : {
216
- code: 'to'
217
- },
237
+ filteredUseCaseCode: (useCase ? useCase.code : 'to') + 's',
218
238
  points: pointsData,
219
239
  polygon: getPolygonGeoJSON(polygonData),
220
- onBoundsChange: handleBoundsChange
240
+ onBoundsChange: handleBoundsChange,
241
+ onMarkerClick: markerClicked
221
242
  })), bottomSheet, /*#__PURE__*/_react.default.createElement(_FilterButton.default, {
222
243
  buttonState: filterButtonState,
223
244
  onClick: filterButtonClick
@@ -229,4 +250,4 @@ var MapTableContainer = _styledComponents.default.div.withConfig({
229
250
  displayName: "PollutionRiskAssessment__MapTableContainer",
230
251
  componentId: "sc-peb1i1-0"
231
252
  })(["position:fixed;top:65px;height:calc(100vh - 20px);width:100vw;#map{height:100%;width:100%;*,*:focus,*:hover{outline:none;}}"]);
232
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["require","_react","_interopRequireWildcard","_reactRedux","_actions","_Analytics","_Map","_useNavContext2","_KandoBottomSheet","_interopRequireDefault","_urls","_TotalSavings","_FilterBehaviors","_FilterButton","_use_cases","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","PollutionRiskAssessment","waterAuthorityName","useSelector","state","global_data","waterAuthorityId","_useState","useState","_useState2","_slicedToArray2","polygonData","setPolygonData","_useState3","_useState4","pointsData","setPointsData","_useNavContext","useNavContext","isRtl","_useState5","_useState6","shownContent","setShownContent","_useState7","_useState8","visiblePoints","setVisiblePoints","_useState9","_useState10","useCasesFilter","setUseCasesFilter","_useState11","_useState12","mapBounds","setMapBounds","handleDismiss","dispatch","useDispatch","fetchData","_ref","_asyncToGenerator2","_regenerator","mark","_callee","url","setData","response","result","wrap","_callee$","_context","prev","next","fetch","sent","json","t0","console","error","concat","stop","_x","_x2","apply","arguments","useEffect","setTimeout","currentGeoAreaUrl","urls","currentGeoArea","analyticsTrack","utility_name","updateNavContext","name","getPolygonGeoJSON","polygon","JSON","parse","allPointsUrl","id","allPoints","useCase","useCases","find","getBottomSheetConfig","content","createElement","TotalSavings","points","filteredUseCase","snapPoints","_ref2","maxHeight","backgroundColor","FilterBehaviors","selectedItem","handleChange","_ref3","_useMemo","useMemo","bottomSheet","onDismiss","isOpen","filteredPoints","filter","point","lat","getSouthWest","getNorthEast","lng","handleBoundsChange","useCallback","bounds","filterButtonClick","prevContent","filterButtonState","className","MapTableContainer","Map","code","onBoundsChange","buttonState","onClick","_default","exports","styled","div","withConfig","displayName","componentId"],"sources":["../../../src/pages/PollutionRiskAssessment/index.tsx"],"sourcesContent":["import 'bootstrap/dist/css/bootstrap.min.css';\nimport React, { useCallback, useEffect, useMemo, useState } from 'react';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { updateNavContext } from 'src/store/context/actions';\nimport { analyticsTrack } from '../../utilities/Analytics';\nimport { Map } from './Map';\nimport styled from 'styled-components/macro';\nimport { useNavContext } from '../../hooks/useNavContext';\nimport KandoBottomSheet from '../../ui-kit/KandoBottomSheet/KandoBottomSheet';\nimport { urls } from '../../utilities/urls';\nimport { IGeoPoint } from 'src/store/points/models/IGeoPoint';\nimport L, { GeoJSON } from 'leaflet';\nimport './index.scss';\nimport { TotalSavings } from './TotalSavings';\nimport { FilterBehaviors } from './FilterBehaviors';\nimport FilterButton from './FilterButton';\nimport useCases from './use_cases.json';\n\nconst PollutionRiskAssessment: React.FC = () => {\n  const waterAuthorityName = useSelector(\n    (state) => state.global_data.waterAuthorityName,\n  );\n  const waterAuthorityId = useSelector(\n    (state) => state.global_data.waterAuthorityId,\n  );\n  const [polygonData, setPolygonData] = useState<GeoJSON>();\n  const [pointsData, setPointsData] = useState<IGeoPoint[]>();\n  const { isRtl } = useNavContext();\n  const [shownContent, setShownContent] = useState('total_savings');\n  const [visiblePoints, setVisiblePoints] = useState<IGeoPoint[]>([]);\n  const [useCasesFilter, setUseCasesFilter] = useState('');\n  const [mapBounds, setMapBounds] = useState<L.LatLngBounds | null>(null);\n\n  const handleDismiss = () => {\n    setShownContent('total_savings');\n  };\n\n  const dispatch = useDispatch();\n  const fetchData = async <T,>(\n    url: string,\n    setData: React.Dispatch<React.SetStateAction<T>>,\n  ) => {\n    try {\n      const response = await fetch(url);\n      const result = await response.json();\n      setData(result);\n    } catch (error) {\n      console.error(`Failed to fetch data from ${url}:`, error);\n    }\n  };\n\n  // Close the bottom sheet after 300ms when the filter is changed by the user click\n  useEffect(() => {\n    setTimeout(() => {\n      handleDismiss();\n    }, 300);\n  }, [useCasesFilter]);\n\n  useEffect(() => {\n    if (waterAuthorityId) {\n      const currentGeoAreaUrl = urls({ waterAuthorityId })\n        .PollutionRiskAssessment.currentGeoArea;\n      fetchData(currentGeoAreaUrl, setPolygonData);\n\n      analyticsTrack('Viewed Pollution Risk Assessment Page', {\n        utility_name: waterAuthorityName,\n      });\n      dispatch(updateNavContext({ name: 'pollution-risk-assessment' }));\n    }\n  }, [waterAuthorityId]);\n\n  const getPolygonGeoJSON = (polygonData) => {\n    try {\n      return polygonData?.polygon ? JSON.parse(polygonData.polygon) : [];\n    } catch (error) {\n      console.error('Failed to parse polygon data:', error);\n      return [];\n    }\n  };\n\n  useEffect(() => {\n    if (!polygonData) return;\n\n    const allPointsUrl = urls({\n      waterAuthorityId: waterAuthorityId,\n      id: polygonData?.id,\n    }).PollutionRiskAssessment.allPoints;\n\n    fetchData(allPointsUrl, setPointsData);\n  }, [polygonData]);\n\n  const useCase = useCases.find((useCase) => useCase.id === useCasesFilter);\n\n  const getBottomSheetConfig = () => {\n    switch (shownContent) {\n      case 'total_savings':\n        return {\n          content: (\n            <TotalSavings points={visiblePoints} filteredUseCase={useCase} />\n          ),\n          snapPoints: ({ maxHeight }: { maxHeight: number }) => [\n            168,\n            maxHeight - 100,\n          ],\n          backgroundColor: '#000',\n        };\n      case 'filter_behaviors':\n        return {\n          content: (\n            <FilterBehaviors\n              selectedItem={useCasesFilter}\n              handleChange={setUseCasesFilter}\n            />\n          ),\n          snapPoints: ({ maxHeight }: { maxHeight: number }) => [\n            maxHeight - 100,\n          ],\n          backgroundColor: '#fff',\n        };\n      default:\n        return {\n          content: null,\n          snapPoints: () => [0],\n          backgroundColor: '#000',\n        };\n    }\n  };\n\n  const { content, snapPoints, backgroundColor } = useMemo(\n    getBottomSheetConfig,\n    [shownContent, useCasesFilter, visiblePoints],\n  );\n\n  const bottomSheet = useMemo(() => {\n    return (\n      <KandoBottomSheet\n        backgroundColor={backgroundColor}\n        snapPoints={snapPoints}\n        onDismiss={handleDismiss}\n        isOpen={true}\n      >\n        {content}\n      </KandoBottomSheet>\n    );\n  }, [visiblePoints, shownContent]);\n\n  useEffect(() => {\n    if (!mapBounds || !pointsData) return;\n\n    const filteredPoints = pointsData.filter((point) => {\n      return (\n        point.lat >= mapBounds.getSouthWest().lat &&\n        point.lat <= mapBounds.getNorthEast().lat &&\n        point.lng >= mapBounds.getSouthWest().lng &&\n        point.lng <= mapBounds.getNorthEast().lng\n      );\n    });\n\n    setVisiblePoints(filteredPoints);\n  }, [mapBounds, pointsData]);\n\n  const handleBoundsChange = useCallback((bounds) => {\n    setMapBounds(bounds);\n  }, []);\n\n  const filterButtonClick = () => {\n    setShownContent((prevContent) =>\n      prevContent === 'filter_behaviors' ? 'total_savings' : 'filter_behaviors',\n    );\n  };\n\n  const filterButtonState = useMemo(() => {\n    if (shownContent === 'filter_behaviors') {\n      return 'filled';\n    }\n    return useCasesFilter !== '' ? 'filled-red' : '';\n  }, [shownContent, useCasesFilter]);\n\n  if (!pointsData || !polygonData) return null;\n\n  return (\n    <div className=\"app-wrapper\">\n      <MapTableContainer isRtl={isRtl}>\n        <Map\n          filteredUseCase={useCase ? useCase : { code: 'to' }}\n          points={pointsData}\n          polygon={getPolygonGeoJSON(polygonData)}\n          onBoundsChange={handleBoundsChange}\n        />\n      </MapTableContainer>\n      {bottomSheet}\n      <FilterButton\n        buttonState={filterButtonState}\n        onClick={filterButtonClick}\n      />\n    </div>\n  );\n};\n\nexport default PollutionRiskAssessment;\n\nconst MapTableContainer = styled.div<{ isRtl: boolean }>`\n  position: fixed;\n  top: 65px;\n  height: calc(100vh - 20px);\n  width: 100vw;\n\n  #map {\n    height: 100%;\n    width: 100%;\n\n    *,\n    *:focus,\n    *:hover {\n      outline: none;\n    }\n  }\n`;\n"],"mappings":"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"}
253
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["require","_react","_interopRequireWildcard","_reactRedux","_actions","_Analytics","_Map","_useNavContext2","_KandoBottomSheet","_interopRequireDefault","_urls","_TotalSavings","_FilterBehaviors","_FactoryDetails","_FilterButton","_use_cases","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","PollutionRiskAssessment","waterAuthorityName","useSelector","state","global_data","waterAuthorityId","_useState","useState","_useState2","_slicedToArray2","polygonData","setPolygonData","_useState3","_useState4","pointsData","setPointsData","_useNavContext","useNavContext","isRtl","_useState5","_useState6","shownContent","setShownContent","_useState7","_useState8","visiblePoints","setVisiblePoints","_useState9","_useState10","useCasesFilter","setUseCasesFilter","_useState11","_useState12","mapBounds","setMapBounds","_useState13","_useState14","clickedPointId","setClickedPointId","handleDismiss","dispatch","useDispatch","fetchData","_ref","_asyncToGenerator2","_regenerator","mark","_callee","url","setData","response","result","wrap","_callee$","_context","prev","next","fetch","sent","json","t0","console","error","concat","stop","_x","_x2","apply","arguments","useEffect","setTimeout","currentGeoAreaUrl","urls","currentGeoArea","analyticsTrack","utility_name","updateNavContext","name","getPolygonGeoJSON","polygon","JSON","parse","allPointsUrl","id","allPoints","useCase","useCases","find","getBottomSheetConfig","content","createElement","TotalSavings","points","filteredUseCase","snapPoints","_ref2","maxHeight","backgroundColor","FilterBehaviors","selectedItem","handleChange","_ref3","FactoryDetails","point_id","_ref4","_useMemo","useMemo","bottomSheet","onDismiss","isOpen","filteredPoints","filter","point","lat","getSouthWest","getNorthEast","lng","handleBoundsChange","useCallback","bounds","filterButtonClick","prevContent","filterButtonState","markerClicked","className","MapTableContainer","Map","filteredUseCaseCode","code","onBoundsChange","onMarkerClick","buttonState","onClick","_default","exports","styled","div","withConfig","displayName","componentId"],"sources":["../../../src/pages/PollutionRiskAssessment/index.tsx"],"sourcesContent":["import 'bootstrap/dist/css/bootstrap.min.css';\nimport React, { useCallback, useEffect, useMemo, useState } from 'react';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { updateNavContext } from 'src/store/context/actions';\nimport { analyticsTrack } from '../../utilities/Analytics';\nimport { Map } from './Map';\nimport styled from 'styled-components/macro';\nimport { useNavContext } from '../../hooks/useNavContext';\nimport KandoBottomSheet from '../../ui-kit/KandoBottomSheet/KandoBottomSheet';\nimport { urls } from '../../utilities/urls';\nimport { IGeoPoint } from 'src/store/points/models/IGeoPoint';\nimport L, { GeoJSON } from 'leaflet';\nimport './index.scss';\nimport { TotalSavings } from './TotalSavings';\nimport { FilterBehaviors } from './FilterBehaviors';\nimport { FactoryDetails } from './FactoryDetails';\nimport FilterButton from './FilterButton';\nimport useCases from './use_cases.json';\n\nconst PollutionRiskAssessment: React.FC = () => {\n  const waterAuthorityName = useSelector(\n    (state) => state.global_data.waterAuthorityName,\n  );\n  const waterAuthorityId = useSelector(\n    (state) => state.global_data.waterAuthorityId,\n  );\n  const [polygonData, setPolygonData] = useState<GeoJSON>();\n  const [pointsData, setPointsData] = useState<IGeoPoint[]>();\n  const { isRtl } = useNavContext();\n  const [shownContent, setShownContent] = useState('total_savings');\n  const [visiblePoints, setVisiblePoints] = useState<IGeoPoint[]>([]);\n  const [useCasesFilter, setUseCasesFilter] = useState('');\n  const [mapBounds, setMapBounds] = useState<L.LatLngBounds | null>(null);\n  const [clickedPointId, setClickedPointId] = useState<number>();\n\n  const handleDismiss = () => {\n    setShownContent('total_savings');\n  };\n\n  const dispatch = useDispatch();\n  const fetchData = async <T,>(\n    url: string,\n    setData: React.Dispatch<React.SetStateAction<T>>,\n  ) => {\n    try {\n      const response = await fetch(url);\n      const result = await response.json();\n      setData(result);\n    } catch (error) {\n      console.error(`Failed to fetch data from ${url}:`, error);\n    }\n  };\n\n  // Close the bottom sheet after 300ms when the filter is changed by the user click\n  useEffect(() => {\n    setTimeout(() => {\n      handleDismiss();\n    }, 300);\n  }, [useCasesFilter]);\n\n  useEffect(() => {\n    if (waterAuthorityId) {\n      const currentGeoAreaUrl = urls({ waterAuthorityId })\n        .PollutionRiskAssessment.currentGeoArea;\n      fetchData(currentGeoAreaUrl, setPolygonData);\n\n      analyticsTrack('Viewed Pollution Risk Assessment Page', {\n        utility_name: waterAuthorityName,\n      });\n      dispatch(updateNavContext({ name: 'pollution_risk_assessment' }));\n    }\n  }, [waterAuthorityId]);\n\n  const getPolygonGeoJSON = (polygonData) => {\n    try {\n      return polygonData?.polygon ? JSON.parse(polygonData.polygon) : [];\n    } catch (error) {\n      console.error('Failed to parse polygon data:', error);\n      return [];\n    }\n  };\n\n  useEffect(() => {\n    if (!polygonData) return;\n\n    const allPointsUrl = urls({\n      waterAuthorityId: waterAuthorityId,\n      id: polygonData?.id,\n    }).PollutionRiskAssessment.allPoints;\n\n    fetchData(allPointsUrl, setPointsData);\n  }, [polygonData]);\n\n  const useCase = useCases.find((useCase) => useCase.id === useCasesFilter);\n\n  const getBottomSheetConfig = () => {\n    switch (shownContent) {\n      case 'total_savings':\n        return {\n          content: (\n            <TotalSavings points={visiblePoints} filteredUseCase={useCase} />\n          ),\n          snapPoints: ({ maxHeight }: { maxHeight: number }) => [\n            90,\n            maxHeight - 100,\n          ],\n          backgroundColor: '#000',\n        };\n      case 'filter_behaviors':\n        return {\n          content: (\n            <FilterBehaviors\n              selectedItem={useCasesFilter}\n              handleChange={setUseCasesFilter}\n            />\n          ),\n          snapPoints: ({ maxHeight }: { maxHeight: number }) => [\n            maxHeight - 100,\n          ],\n          backgroundColor: '#fff',\n        };\n      case 'factory_details':\n        return {\n          content: <FactoryDetails point_id={clickedPointId} />,\n          snapPoints: ({ maxHeight }: { maxHeight: number }) => [\n            maxHeight - 500,\n            maxHeight - 500,\n          ],\n          backgroundColor: '#fff',\n        };\n      default:\n        return {\n          content: null,\n          snapPoints: () => [0],\n          backgroundColor: '#000',\n        };\n    }\n  };\n\n  const { content, snapPoints, backgroundColor } = useMemo(\n    getBottomSheetConfig,\n    [shownContent, useCasesFilter, visiblePoints, clickedPointId],\n  );\n\n  const bottomSheet = useMemo(() => {\n    return (\n      <KandoBottomSheet\n        backgroundColor={backgroundColor}\n        snapPoints={snapPoints}\n        onDismiss={handleDismiss}\n        isOpen={true}\n      >\n        {content}\n      </KandoBottomSheet>\n    );\n  }, [visiblePoints, shownContent, clickedPointId]);\n\n  useEffect(() => {\n    if (!mapBounds || !pointsData) return;\n\n    const filteredPoints = pointsData.filter((point) => {\n      return (\n        point.lat >= mapBounds.getSouthWest().lat &&\n        point.lat <= mapBounds.getNorthEast().lat &&\n        point.lng >= mapBounds.getSouthWest().lng &&\n        point.lng <= mapBounds.getNorthEast().lng\n      );\n    });\n\n    setVisiblePoints(filteredPoints);\n  }, [mapBounds, pointsData]);\n\n  const handleBoundsChange = useCallback((bounds) => {\n    setMapBounds(bounds);\n  }, []);\n\n  const filterButtonClick = () => {\n    setShownContent((prevContent) =>\n      prevContent === 'filter_behaviors' ? 'total_savings' : 'filter_behaviors',\n    );\n  };\n\n  const filterButtonState = useMemo(() => {\n    if (shownContent === 'filter_behaviors') {\n      return 'filled';\n    }\n    return useCasesFilter !== '' ? 'filled-red' : '';\n  }, [shownContent, useCasesFilter]);\n\n  const markerClicked = (id: number) => {\n    setClickedPointId(id);\n    if (shownContent !== 'factory_details') {\n      setShownContent('factory_details');\n    }\n  };\n\n  if (!pointsData || !polygonData) return null;\n\n  return (\n    <div className=\"app-wrapper\">\n      <MapTableContainer isRtl={isRtl}>\n        <Map\n          filteredUseCaseCode={(useCase ? useCase.code : 'to') + 's'}\n          points={pointsData}\n          polygon={getPolygonGeoJSON(polygonData)}\n          onBoundsChange={handleBoundsChange}\n          onMarkerClick={markerClicked}\n        />\n      </MapTableContainer>\n      {bottomSheet}\n      <FilterButton\n        buttonState={filterButtonState}\n        onClick={filterButtonClick}\n      />\n    </div>\n  );\n};\n\nexport default PollutionRiskAssessment;\n\nconst MapTableContainer = styled.div<{ isRtl: boolean }>`\n  position: fixed;\n  top: 65px;\n  height: calc(100vh - 20px);\n  width: 100vw;\n\n  #map {\n    height: 100%;\n    width: 100%;\n\n    *,\n    *:focus,\n    *:hover {\n      outline: none;\n    }\n  }\n`;\n"],"mappings":"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"}
@@ -18,6 +18,10 @@
18
18
  #map {
19
19
  height: 100%;
20
20
  width: 100%;
21
+
22
+ .leaflet-popup-close-button {
23
+ font-size: x-large;
24
+ }
21
25
  }
22
26
 
23
27
  .btn-group {
@@ -39,7 +43,3 @@
39
43
  fill: white !important;
40
44
  }
41
45
  }
42
-
43
- .intercom-lightweight-app {
44
- display: none !important;
45
- }
@@ -1,23 +1,17 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
- var _typeof = require("@babel/runtime/helpers/typeof");
5
4
  Object.defineProperty(exports, "__esModule", {
6
5
  value: true
7
6
  });
8
7
  exports.useMap = void 0;
9
8
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/slicedToArray"));
10
9
  var _leaflet = _interopRequireDefault(require("leaflet"));
11
- var _react = _interopRequireWildcard(require("react"));
10
+ var _react = require("react");
12
11
  var _PointIcon = require("Widgets/Map/points/PointIcon");
13
12
  var _theme = require("styles/theme/theme");
14
13
  var _MapUtils = require("Widgets/Map/MapUtils");
15
- var _FactoryDetails = require("./FactoryDetails");
16
- var _reactDom = _interopRequireDefault(require("react-dom"));
17
- var _reactRedux = require("react-redux");
18
- 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); }
19
- 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; }
20
- var useMap = function useMap(mapRef, points, filteredUseCase, polygon) {
14
+ var useMap = function useMap(mapRef, points, filteredUseCaseCode, polygon, onMarkerClick) {
21
15
  var _useState = (0, _react.useState)(),
22
16
  _useState2 = (0, _slicedToArray2.default)(_useState, 2),
23
17
  map = _useState2[0],
@@ -26,23 +20,14 @@ var useMap = function useMap(mapRef, points, filteredUseCase, polygon) {
26
20
  _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
27
21
  mapZoomLevel = _useState4[0],
28
22
  setMapZoomLevel = _useState4[1];
29
- var _useState5 = (0, _react.useState)(filteredUseCase.code),
30
- _useState6 = (0, _slicedToArray2.default)(_useState5, 2),
31
- useCaseCode = _useState6[0],
32
- setUseCaseCode = _useState6[1];
33
23
  var heatLayerRef = (0, _react.useRef)();
34
24
  var pointsLayerRef = (0, _react.useRef)();
35
- var waterAuthorityId = (0, _reactRedux.useSelector)(function (state) {
36
- return state.global_data.waterAuthorityId;
37
- });
38
25
  (0, _react.useEffect)(function () {
39
26
  if (!mapRef.current) {
40
27
  return;
41
28
  }
42
29
  var mapTypes = (0, _MapUtils.baseMaps)(_theme.leafletMap.mapDefault, _theme.leafletMap.satellite);
43
- var mapTemp = _leaflet.default.map(mapRef.current, {
44
- renderer: _leaflet.default.canvas()
45
- });
30
+ var mapTemp = _leaflet.default.map(mapRef.current, {});
46
31
  Object.values(mapTypes)[0].addTo(mapTemp);
47
32
  _leaflet.default.control.layers(mapTypes, {}, {
48
33
  position: 'topright'
@@ -82,28 +67,19 @@ var useMap = function useMap(mapRef, points, filteredUseCase, polygon) {
82
67
  }
83
68
  };
84
69
  }, []);
85
- var handleMarkerClick = (0, _react.useCallback)(function (point, map) {
86
- var container = document.createElement('div');
87
- _reactDom.default.render( /*#__PURE__*/_react.default.createElement(_FactoryDetails.FactoryDetails, {
88
- point_id: point.id,
89
- waterAuthorityId: waterAuthorityId,
90
- use_case_code: filteredUseCase.code
91
- }), container);
92
- _leaflet.default.popup().setContent(container).setLatLng([point.lat, point.lng]).openOn(map);
93
- }, [filteredUseCase]);
94
70
 
95
71
  // The heat map plugin expects an array of arrays with the lat, lng and intensity
96
72
  // The intensity is the value of the point's total score (tos) divided by 100 because the intensity should be between 0 and 1
97
73
  var calculateHeatPoints = (0, _react.useCallback)(function () {
98
74
  return points.map(function (point) {
99
- var intensityValue = point["".concat(filteredUseCase.code, "s")];
75
+ var intensityValue = point[filteredUseCaseCode];
100
76
  if (typeof intensityValue === 'number' && !isNaN(intensityValue)) {
101
77
  var intensity = intensityValue / 100;
102
78
  return [point.lat, point.lng, intensity];
103
79
  }
104
80
  return null; // Exclude invalid points
105
81
  }).filter(Boolean); // Remove null values
106
- }, [points, filteredUseCase.code]);
82
+ }, [points, filteredUseCaseCode]);
107
83
  (0, _react.useEffect)(function () {
108
84
  if (!map || !points) {
109
85
  return;
@@ -137,33 +113,15 @@ var useMap = function useMap(mapRef, points, filteredUseCase, polygon) {
137
113
  var _pointsLayerRef$curre;
138
114
  var icon = (0, _PointIcon.getPointIconByType)('Groups::Factory', point === null || point === void 0 ? void 0 : point.id.toString(), '', false, true);
139
115
  var marker = _leaflet.default.marker([point.lat, point.lng], {
140
- icon: icon,
141
- kando_id: point.id
116
+ icon: icon
142
117
  });
143
118
  marker.on('click', function () {
144
- handleMarkerClick(point, map);
119
+ if (onMarkerClick) {
120
+ onMarkerClick(point.id);
121
+ }
145
122
  });
146
123
  (_pointsLayerRef$curre = pointsLayerRef.current) === null || _pointsLayerRef$curre === void 0 ? void 0 : _pointsLayerRef$curre.addLayer(marker);
147
124
  });
148
- } else {
149
- if (pointsLayerRef.current && filteredUseCase.code !== useCaseCode) {
150
- setUseCaseCode(filteredUseCase.code);
151
- points.forEach(function (point) {
152
- var _pointsLayerRef$curre2;
153
- var existingMarker = (_pointsLayerRef$curre2 = pointsLayerRef.current) === null || _pointsLayerRef$curre2 === void 0 ? void 0 : _pointsLayerRef$curre2.getLayers().find(function (layer) {
154
- if (layer instanceof _leaflet.default.Marker) {
155
- return layer.options.kando_id === point.id;
156
- }
157
- return false;
158
- });
159
- if (existingMarker && existingMarker instanceof _leaflet.default.Marker) {
160
- existingMarker.off('click'); // Remove old handler
161
- existingMarker.on('click', function () {
162
- return handleMarkerClick(point, map);
163
- });
164
- }
165
- });
166
- }
167
125
  }
168
126
  if (!map.hasLayer(pointsLayerRef.current)) {
169
127
  map.addLayer(pointsLayerRef.current);
@@ -172,8 +130,8 @@ var useMap = function useMap(mapRef, points, filteredUseCase, polygon) {
172
130
  map.removeLayer(heatLayerRef.current);
173
131
  }
174
132
  }
175
- }, [points, map, mapZoomLevel, filteredUseCase, calculateHeatPoints]);
133
+ }, [points, map, mapZoomLevel, filteredUseCaseCode, calculateHeatPoints]);
176
134
  return map;
177
135
  };
178
136
  exports.useMap = useMap;
179
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_leaflet","_interopRequireDefault","require","_react","_interopRequireWildcard","_PointIcon","_theme","_MapUtils","_FactoryDetails","_reactDom","_reactRedux","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","useMap","mapRef","points","filteredUseCase","polygon","_useState","useState","_useState2","_slicedToArray2","map","setMap","_useState3","_useState4","mapZoomLevel","setMapZoomLevel","_useState5","code","_useState6","useCaseCode","setUseCaseCode","heatLayerRef","useRef","pointsLayerRef","waterAuthorityId","useSelector","state","global_data","useEffect","current","mapTypes","baseMaps","leafletMap","mapDefault","satellite","mapTemp","L","renderer","canvas","values","addTo","control","layers","position","length","undefined","geoJSONLayer","geoJSON","style","color","fillColor","fillOpacity","fitBounds","getBounds","on","getZoom","off","remove","clearLayers","handleMarkerClick","useCallback","point","container","document","createElement","ReactDOM","render","FactoryDetails","point_id","id","use_case_code","popup","setContent","setLatLng","lat","lng","openOn","calculateHeatPoints","intensityValue","concat","isNaN","intensity","filter","Boolean","heatLayer","radius","blur","maxZoom","gradient","layerGroup","hasLayer","addLayer","setLatLngs","removeLayer","getLayers","forEach","_pointsLayerRef$curre","icon","getPointIconByType","toString","marker","kando_id","_pointsLayerRef$curre2","existingMarker","find","layer","Marker","options","exports"],"sources":["../../../src/pages/PollutionRiskAssessment/useMap.tsx"],"sourcesContent":["import L from 'leaflet';\nimport React, { useCallback, useEffect, useRef, useState } from 'react';\nimport { getPointIconByType } from 'src/Widgets/Map/points/PointIcon';\nimport { IGeoPoint } from 'src/store/points/models/IGeoPoint';\nimport { leafletMap } from 'src/styles/theme/theme';\nimport { baseMaps } from 'src/Widgets/Map/MapUtils';\nimport { FactoryDetails } from './FactoryDetails';\nimport ReactDOM from 'react-dom';\nimport { useSelector } from 'react-redux';\n\nexport const useMap = (\n  mapRef: React.RefObject<HTMLDivElement>,\n  points: IGeoPoint[],\n  filteredUseCase: any,\n  polygon?: any,\n): L.Map | undefined => {\n  const [map, setMap] = useState<L.Map>();\n  const [mapZoomLevel, setMapZoomLevel] = useState(15);\n  const [useCaseCode, setUseCaseCode] = useState(filteredUseCase.code);\n  const heatLayerRef = useRef<L.HeatLayer>();\n  const pointsLayerRef = useRef<L.LayerGroup>();\n  const waterAuthorityId = useSelector(\n    (state) => state.global_data.waterAuthorityId,\n  );\n\n  useEffect(() => {\n    if (!mapRef.current) {\n      return;\n    }\n\n    const mapTypes = baseMaps(leafletMap.mapDefault, leafletMap.satellite);\n    const mapTemp = L.map(mapRef.current, { renderer: L.canvas() });\n\n    Object.values(mapTypes)[0].addTo(mapTemp);\n\n    L.control.layers(mapTypes, {}, { position: 'topright' }).addTo(mapTemp);\n\n    // The colors are transparent so the map will fit the polygon bounds but it won't be visible\n    if (polygon && polygon.length === undefined) {\n      const geoJSONLayer = L.geoJSON(polygon, {\n        style: {\n          color: 'transparent',\n          fillColor: 'transparent',\n          fillOpacity: 0,\n        },\n      }).addTo(mapTemp);\n      mapTemp.fitBounds(geoJSONLayer.getBounds());\n    }\n\n    mapTemp.on('zoomend', () => {\n      setMapZoomLevel(mapTemp.getZoom());\n    });\n\n    setMap(mapTemp);\n\n    return () => {\n      if (!mapTemp) {\n        return;\n      }\n      mapTemp.off();\n      mapTemp.remove();\n\n      // Clean up layers\n      if (heatLayerRef.current) {\n        heatLayerRef.current.off();\n        heatLayerRef.current.remove();\n        heatLayerRef.current = null;\n      }\n      if (pointsLayerRef.current) {\n        pointsLayerRef.current.clearLayers();\n        pointsLayerRef.current = null;\n      }\n    };\n  }, []);\n\n  const handleMarkerClick = useCallback(\n    (point: IGeoPoint, map) => {\n      const container = document.createElement('div');\n      ReactDOM.render(\n        <FactoryDetails\n          point_id={point.id}\n          waterAuthorityId={waterAuthorityId}\n          use_case_code={filteredUseCase.code}\n        />,\n        container,\n      );\n\n      L.popup()\n        .setContent(container)\n        .setLatLng([point.lat, point.lng])\n        .openOn(map);\n    },\n    [filteredUseCase],\n  );\n\n  // The heat map plugin expects an array of arrays with the lat, lng and intensity\n  // The intensity is the value of the point's total score (tos) divided by 100 because the intensity should be between 0 and 1\n  const calculateHeatPoints = useCallback(() => {\n    return points\n      .map((point) => {\n        const intensityValue = point[`${filteredUseCase.code}s`];\n\n        if (typeof intensityValue === 'number' && !isNaN(intensityValue)) {\n          const intensity = intensityValue / 100;\n          return [point.lat, point.lng, intensity];\n        }\n        return null; // Exclude invalid points\n      })\n      .filter(Boolean); // Remove null values\n  }, [points, filteredUseCase.code]);\n\n  useEffect(() => {\n    if (!map || !points) {\n      return;\n    }\n\n    if (!heatLayerRef.current) {\n      heatLayerRef.current = L.heatLayer([], {\n        radius: 25,\n        blur: 15,\n        maxZoom: 15,\n        gradient: {\n          0.0: '#006400',\n          0.5: 'yellow',\n          1.0: 'red',\n        },\n      });\n    }\n\n    if (!pointsLayerRef.current) {\n      pointsLayerRef.current = L.layerGroup();\n    }\n\n    if (mapZoomLevel <= 15) {\n      if (!map.hasLayer(heatLayerRef.current)) {\n        map.addLayer(heatLayerRef.current);\n      }\n\n      heatLayerRef.current.setLatLngs(calculateHeatPoints());\n\n      if (map.hasLayer(pointsLayerRef.current)) {\n        map.removeLayer(pointsLayerRef.current);\n      }\n    } else {\n      if (!pointsLayerRef.current.getLayers().length) {\n        points.forEach((point) => {\n          const icon = getPointIconByType(\n            'Groups::Factory',\n            point?.id.toString(),\n            '',\n            false,\n            true,\n          );\n          const marker = L.marker([point.lat, point.lng], {\n            icon,\n            kando_id: point.id,\n          });\n          marker.on('click', () => {\n            handleMarkerClick(point, map);\n          });\n          pointsLayerRef.current?.addLayer(marker);\n        });\n      } else {\n        if (pointsLayerRef.current && filteredUseCase.code !== useCaseCode) {\n          setUseCaseCode(filteredUseCase.code);\n\n          points.forEach((point) => {\n            const existingMarker = pointsLayerRef.current\n              ?.getLayers()\n              .find((layer) => {\n                if (layer instanceof L.Marker) {\n                  return layer.options.kando_id === point.id;\n                }\n                return false;\n              });\n\n            if (existingMarker && existingMarker instanceof L.Marker) {\n              existingMarker.off('click'); // Remove old handler\n              existingMarker.on('click', () => handleMarkerClick(point, map));\n            }\n          });\n        }\n      }\n\n      if (!map.hasLayer(pointsLayerRef.current)) {\n        map.addLayer(pointsLayerRef.current);\n      }\n\n      if (map.hasLayer(heatLayerRef.current)) {\n        map.removeLayer(heatLayerRef.current);\n      }\n    }\n  }, [points, map, mapZoomLevel, filteredUseCase, calculateHeatPoints]);\n\n  return map;\n};\n"],"mappings":";;;;;;;;;AAAA,IAAAA,QAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,MAAA,GAAAC,uBAAA,CAAAF,OAAA;AACA,IAAAG,UAAA,GAAAH,OAAA;AAEA,IAAAI,MAAA,GAAAJ,OAAA;AACA,IAAAK,SAAA,GAAAL,OAAA;AACA,IAAAM,eAAA,GAAAN,OAAA;AACA,IAAAO,SAAA,GAAAR,sBAAA,CAAAC,OAAA;AACA,IAAAQ,WAAA,GAAAR,OAAA;AAA0C,SAAAS,yBAAAC,WAAA,eAAAC,OAAA,kCAAAC,iBAAA,OAAAD,OAAA,QAAAE,gBAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,yBAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAAR,wBAAAY,GAAA,EAAAJ,WAAA,SAAAA,WAAA,IAAAI,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,aAAAE,OAAA,CAAAF,GAAA,yBAAAA,GAAA,4BAAAG,OAAA,EAAAH,GAAA,UAAAI,KAAA,GAAAT,wBAAA,CAAAC,WAAA,OAAAQ,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAL,GAAA,YAAAI,KAAA,CAAAE,GAAA,CAAAN,GAAA,SAAAO,MAAA,WAAAC,qBAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,GAAA,IAAAZ,GAAA,QAAAY,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAf,GAAA,EAAAY,GAAA,SAAAI,IAAA,GAAAR,qBAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAX,GAAA,EAAAY,GAAA,cAAAI,IAAA,KAAAA,IAAA,CAAAV,GAAA,IAAAU,IAAA,CAAAC,GAAA,KAAAR,MAAA,CAAAC,cAAA,CAAAH,MAAA,EAAAK,GAAA,EAAAI,IAAA,YAAAT,MAAA,CAAAK,GAAA,IAAAZ,GAAA,CAAAY,GAAA,SAAAL,MAAA,CAAAJ,OAAA,GAAAH,GAAA,MAAAI,KAAA,IAAAA,KAAA,CAAAa,GAAA,CAAAjB,GAAA,EAAAO,MAAA,YAAAA,MAAA;AAEnC,IAAMW,MAAM,GAAG,SAATA,MAAMA,CACjBC,MAAuC,EACvCC,MAAmB,EACnBC,eAAoB,EACpBC,OAAa,EACS;EACtB,IAAAC,SAAA,GAAsB,IAAAC,eAAQ,EAAQ,CAAC;IAAAC,UAAA,OAAAC,eAAA,CAAAvB,OAAA,EAAAoB,SAAA;IAAhCI,GAAG,GAAAF,UAAA;IAAEG,MAAM,GAAAH,UAAA;EAClB,IAAAI,UAAA,GAAwC,IAAAL,eAAQ,EAAC,EAAE,CAAC;IAAAM,UAAA,OAAAJ,eAAA,CAAAvB,OAAA,EAAA0B,UAAA;IAA7CE,YAAY,GAAAD,UAAA;IAAEE,eAAe,GAAAF,UAAA;EACpC,IAAAG,UAAA,GAAsC,IAAAT,eAAQ,EAACH,eAAe,CAACa,IAAI,CAAC;IAAAC,UAAA,OAAAT,eAAA,CAAAvB,OAAA,EAAA8B,UAAA;IAA7DG,WAAW,GAAAD,UAAA;IAAEE,cAAc,GAAAF,UAAA;EAClC,IAAMG,YAAY,GAAG,IAAAC,aAAM,EAAc,CAAC;EAC1C,IAAMC,cAAc,GAAG,IAAAD,aAAM,EAAe,CAAC;EAC7C,IAAME,gBAAgB,GAAG,IAAAC,uBAAW,EAClC,UAACC,KAAK;IAAA,OAAKA,KAAK,CAACC,WAAW,CAACH,gBAAgB;EAAA,CAC/C,CAAC;EAED,IAAAI,gBAAS,EAAC,YAAM;IACd,IAAI,CAAC1B,MAAM,CAAC2B,OAAO,EAAE;MACnB;IACF;IAEA,IAAMC,QAAQ,GAAG,IAAAC,kBAAQ,EAACC,iBAAU,CAACC,UAAU,EAAED,iBAAU,CAACE,SAAS,CAAC;IACtE,IAAMC,OAAO,GAAGC,gBAAC,CAAC1B,GAAG,CAACR,MAAM,CAAC2B,OAAO,EAAE;MAAEQ,QAAQ,EAAED,gBAAC,CAACE,MAAM,CAAC;IAAE,CAAC,CAAC;IAE/D9C,MAAM,CAAC+C,MAAM,CAACT,QAAQ,CAAC,CAAC,CAAC,CAAC,CAACU,KAAK,CAACL,OAAO,CAAC;IAEzCC,gBAAC,CAACK,OAAO,CAACC,MAAM,CAACZ,QAAQ,EAAE,CAAC,CAAC,EAAE;MAAEa,QAAQ,EAAE;IAAW,CAAC,CAAC,CAACH,KAAK,CAACL,OAAO,CAAC;;IAEvE;IACA,IAAI9B,OAAO,IAAIA,OAAO,CAACuC,MAAM,KAAKC,SAAS,EAAE;MAC3C,IAAMC,YAAY,GAAGV,gBAAC,CAACW,OAAO,CAAC1C,OAAO,EAAE;QACtC2C,KAAK,EAAE;UACLC,KAAK,EAAE,aAAa;UACpBC,SAAS,EAAE,aAAa;UACxBC,WAAW,EAAE;QACf;MACF,CAAC,CAAC,CAACX,KAAK,CAACL,OAAO,CAAC;MACjBA,OAAO,CAACiB,SAAS,CAACN,YAAY,CAACO,SAAS,CAAC,CAAC,CAAC;IAC7C;IAEAlB,OAAO,CAACmB,EAAE,CAAC,SAAS,EAAE,YAAM;MAC1BvC,eAAe,CAACoB,OAAO,CAACoB,OAAO,CAAC,CAAC,CAAC;IACpC,CAAC,CAAC;IAEF5C,MAAM,CAACwB,OAAO,CAAC;IAEf,OAAO,YAAM;MACX,IAAI,CAACA,OAAO,EAAE;QACZ;MACF;MACAA,OAAO,CAACqB,GAAG,CAAC,CAAC;MACbrB,OAAO,CAACsB,MAAM,CAAC,CAAC;;MAEhB;MACA,IAAIpC,YAAY,CAACQ,OAAO,EAAE;QACxBR,YAAY,CAACQ,OAAO,CAAC2B,GAAG,CAAC,CAAC;QAC1BnC,YAAY,CAACQ,OAAO,CAAC4B,MAAM,CAAC,CAAC;QAC7BpC,YAAY,CAACQ,OAAO,GAAG,IAAI;MAC7B;MACA,IAAIN,cAAc,CAACM,OAAO,EAAE;QAC1BN,cAAc,CAACM,OAAO,CAAC6B,WAAW,CAAC,CAAC;QACpCnC,cAAc,CAACM,OAAO,GAAG,IAAI;MAC/B;IACF,CAAC;EACH,CAAC,EAAE,EAAE,CAAC;EAEN,IAAM8B,iBAAiB,GAAG,IAAAC,kBAAW,EACnC,UAACC,KAAgB,EAAEnD,GAAG,EAAK;IACzB,IAAMoD,SAAS,GAAGC,QAAQ,CAACC,aAAa,CAAC,KAAK,CAAC;IAC/CC,iBAAQ,CAACC,MAAM,eACbhG,MAAA,CAAAgB,OAAA,CAAA8E,aAAA,CAACzF,eAAA,CAAA4F,cAAc;MACbC,QAAQ,EAAEP,KAAK,CAACQ,EAAG;MACnB7C,gBAAgB,EAAEA,gBAAiB;MACnC8C,aAAa,EAAElE,eAAe,CAACa;IAAK,CACrC,CAAC,EACF6C,SACF,CAAC;IAED1B,gBAAC,CAACmC,KAAK,CAAC,CAAC,CACNC,UAAU,CAACV,SAAS,CAAC,CACrBW,SAAS,CAAC,CAACZ,KAAK,CAACa,GAAG,EAAEb,KAAK,CAACc,GAAG,CAAC,CAAC,CACjCC,MAAM,CAAClE,GAAG,CAAC;EAChB,CAAC,EACD,CAACN,eAAe,CAClB,CAAC;;EAED;EACA;EACA,IAAMyE,mBAAmB,GAAG,IAAAjB,kBAAW,EAAC,YAAM;IAC5C,OAAOzD,MAAM,CACVO,GAAG,CAAC,UAACmD,KAAK,EAAK;MACd,IAAMiB,cAAc,GAAGjB,KAAK,IAAAkB,MAAA,CAAI3E,eAAe,CAACa,IAAI,OAAI;MAExD,IAAI,OAAO6D,cAAc,KAAK,QAAQ,IAAI,CAACE,KAAK,CAACF,cAAc,CAAC,EAAE;QAChE,IAAMG,SAAS,GAAGH,cAAc,GAAG,GAAG;QACtC,OAAO,CAACjB,KAAK,CAACa,GAAG,EAAEb,KAAK,CAACc,GAAG,EAAEM,SAAS,CAAC;MAC1C;MACA,OAAO,IAAI,CAAC,CAAC;IACf,CAAC,CAAC,CACDC,MAAM,CAACC,OAAO,CAAC,CAAC,CAAC;EACtB,CAAC,EAAE,CAAChF,MAAM,EAAEC,eAAe,CAACa,IAAI,CAAC,CAAC;EAElC,IAAAW,gBAAS,EAAC,YAAM;IACd,IAAI,CAAClB,GAAG,IAAI,CAACP,MAAM,EAAE;MACnB;IACF;IAEA,IAAI,CAACkB,YAAY,CAACQ,OAAO,EAAE;MACzBR,YAAY,CAACQ,OAAO,GAAGO,gBAAC,CAACgD,SAAS,CAAC,EAAE,EAAE;QACrCC,MAAM,EAAE,EAAE;QACVC,IAAI,EAAE,EAAE;QACRC,OAAO,EAAE,EAAE;QACXC,QAAQ,EAAE;UACR,GAAG,EAAE,SAAS;UACd,GAAG,EAAE,QAAQ;UACb,GAAG,EAAE;QACP;MACF,CAAC,CAAC;IACJ;IAEA,IAAI,CAACjE,cAAc,CAACM,OAAO,EAAE;MAC3BN,cAAc,CAACM,OAAO,GAAGO,gBAAC,CAACqD,UAAU,CAAC,CAAC;IACzC;IAEA,IAAI3E,YAAY,IAAI,EAAE,EAAE;MACtB,IAAI,CAACJ,GAAG,CAACgF,QAAQ,CAACrE,YAAY,CAACQ,OAAO,CAAC,EAAE;QACvCnB,GAAG,CAACiF,QAAQ,CAACtE,YAAY,CAACQ,OAAO,CAAC;MACpC;MAEAR,YAAY,CAACQ,OAAO,CAAC+D,UAAU,CAACf,mBAAmB,CAAC,CAAC,CAAC;MAEtD,IAAInE,GAAG,CAACgF,QAAQ,CAACnE,cAAc,CAACM,OAAO,CAAC,EAAE;QACxCnB,GAAG,CAACmF,WAAW,CAACtE,cAAc,CAACM,OAAO,CAAC;MACzC;IACF,CAAC,MAAM;MACL,IAAI,CAACN,cAAc,CAACM,OAAO,CAACiE,SAAS,CAAC,CAAC,CAAClD,MAAM,EAAE;QAC9CzC,MAAM,CAAC4F,OAAO,CAAC,UAAClC,KAAK,EAAK;UAAA,IAAAmC,qBAAA;UACxB,IAAMC,IAAI,GAAG,IAAAC,6BAAkB,EAC7B,iBAAiB,EACjBrC,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEQ,EAAE,CAAC8B,QAAQ,CAAC,CAAC,EACpB,EAAE,EACF,KAAK,EACL,IACF,CAAC;UACD,IAAMC,MAAM,GAAGhE,gBAAC,CAACgE,MAAM,CAAC,CAACvC,KAAK,CAACa,GAAG,EAAEb,KAAK,CAACc,GAAG,CAAC,EAAE;YAC9CsB,IAAI,EAAJA,IAAI;YACJI,QAAQ,EAAExC,KAAK,CAACQ;UAClB,CAAC,CAAC;UACF+B,MAAM,CAAC9C,EAAE,CAAC,OAAO,EAAE,YAAM;YACvBK,iBAAiB,CAACE,KAAK,EAAEnD,GAAG,CAAC;UAC/B,CAAC,CAAC;UACF,CAAAsF,qBAAA,GAAAzE,cAAc,CAACM,OAAO,cAAAmE,qBAAA,uBAAtBA,qBAAA,CAAwBL,QAAQ,CAACS,MAAM,CAAC;QAC1C,CAAC,CAAC;MACJ,CAAC,MAAM;QACL,IAAI7E,cAAc,CAACM,OAAO,IAAIzB,eAAe,CAACa,IAAI,KAAKE,WAAW,EAAE;UAClEC,cAAc,CAAChB,eAAe,CAACa,IAAI,CAAC;UAEpCd,MAAM,CAAC4F,OAAO,CAAC,UAAClC,KAAK,EAAK;YAAA,IAAAyC,sBAAA;YACxB,IAAMC,cAAc,IAAAD,sBAAA,GAAG/E,cAAc,CAACM,OAAO,cAAAyE,sBAAA,uBAAtBA,sBAAA,CACnBR,SAAS,CAAC,CAAC,CACZU,IAAI,CAAC,UAACC,KAAK,EAAK;cACf,IAAIA,KAAK,YAAYrE,gBAAC,CAACsE,MAAM,EAAE;gBAC7B,OAAOD,KAAK,CAACE,OAAO,CAACN,QAAQ,KAAKxC,KAAK,CAACQ,EAAE;cAC5C;cACA,OAAO,KAAK;YACd,CAAC,CAAC;YAEJ,IAAIkC,cAAc,IAAIA,cAAc,YAAYnE,gBAAC,CAACsE,MAAM,EAAE;cACxDH,cAAc,CAAC/C,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC;cAC7B+C,cAAc,CAACjD,EAAE,CAAC,OAAO,EAAE;gBAAA,OAAMK,iBAAiB,CAACE,KAAK,EAAEnD,GAAG,CAAC;cAAA,EAAC;YACjE;UACF,CAAC,CAAC;QACJ;MACF;MAEA,IAAI,CAACA,GAAG,CAACgF,QAAQ,CAACnE,cAAc,CAACM,OAAO,CAAC,EAAE;QACzCnB,GAAG,CAACiF,QAAQ,CAACpE,cAAc,CAACM,OAAO,CAAC;MACtC;MAEA,IAAInB,GAAG,CAACgF,QAAQ,CAACrE,YAAY,CAACQ,OAAO,CAAC,EAAE;QACtCnB,GAAG,CAACmF,WAAW,CAACxE,YAAY,CAACQ,OAAO,CAAC;MACvC;IACF;EACF,CAAC,EAAE,CAAC1B,MAAM,EAAEO,GAAG,EAAEI,YAAY,EAAEV,eAAe,EAAEyE,mBAAmB,CAAC,CAAC;EAErE,OAAOnE,GAAG;AACZ,CAAC;AAACkG,OAAA,CAAA3G,MAAA,GAAAA,MAAA"}
137
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_leaflet","_interopRequireDefault","require","_react","_PointIcon","_theme","_MapUtils","useMap","mapRef","points","filteredUseCaseCode","polygon","onMarkerClick","_useState","useState","_useState2","_slicedToArray2","default","map","setMap","_useState3","_useState4","mapZoomLevel","setMapZoomLevel","heatLayerRef","useRef","pointsLayerRef","useEffect","current","mapTypes","baseMaps","leafletMap","mapDefault","satellite","mapTemp","L","Object","values","addTo","control","layers","position","length","undefined","geoJSONLayer","geoJSON","style","color","fillColor","fillOpacity","fitBounds","getBounds","on","getZoom","off","remove","clearLayers","calculateHeatPoints","useCallback","point","intensityValue","isNaN","intensity","lat","lng","filter","Boolean","heatLayer","radius","blur","maxZoom","gradient","layerGroup","hasLayer","addLayer","setLatLngs","removeLayer","getLayers","forEach","_pointsLayerRef$curre","icon","getPointIconByType","id","toString","marker","exports"],"sources":["../../../src/pages/PollutionRiskAssessment/useMap.tsx"],"sourcesContent":["import L from 'leaflet';\nimport React, { useCallback, useEffect, useRef, useState } from 'react';\nimport { getPointIconByType } from 'src/Widgets/Map/points/PointIcon';\nimport { IGeoPoint } from 'src/store/points/models/IGeoPoint';\nimport { leafletMap } from 'src/styles/theme/theme';\nimport { baseMaps } from 'src/Widgets/Map/MapUtils';\n\nexport const useMap = (\n  mapRef: React.RefObject<HTMLDivElement>,\n  points: IGeoPoint[],\n  filteredUseCaseCode: string,\n  polygon?: any,\n  onMarkerClick?: (id: number) => void,\n): L.Map | undefined => {\n  const [map, setMap] = useState<L.Map>();\n  const [mapZoomLevel, setMapZoomLevel] = useState(15);\n  const heatLayerRef = useRef<L.HeatLayer>();\n  const pointsLayerRef = useRef<L.LayerGroup>();\n\n  useEffect(() => {\n    if (!mapRef.current) {\n      return;\n    }\n\n    const mapTypes = baseMaps(leafletMap.mapDefault, leafletMap.satellite);\n    const mapTemp = L.map(mapRef.current, {});\n\n    Object.values(mapTypes)[0].addTo(mapTemp);\n\n    L.control.layers(mapTypes, {}, { position: 'topright' }).addTo(mapTemp);\n\n    // The colors are transparent so the map will fit the polygon bounds but it won't be visible\n    if (polygon && polygon.length === undefined) {\n      const geoJSONLayer = L.geoJSON(polygon, {\n        style: {\n          color: 'transparent',\n          fillColor: 'transparent',\n          fillOpacity: 0,\n        },\n      }).addTo(mapTemp);\n      mapTemp.fitBounds(geoJSONLayer.getBounds());\n    }\n\n    mapTemp.on('zoomend', () => {\n      setMapZoomLevel(mapTemp.getZoom());\n    });\n\n    setMap(mapTemp);\n\n    return () => {\n      if (!mapTemp) {\n        return;\n      }\n      mapTemp.off();\n      mapTemp.remove();\n\n      // Clean up layers\n      if (heatLayerRef.current) {\n        heatLayerRef.current.off();\n        heatLayerRef.current.remove();\n        heatLayerRef.current = null;\n      }\n      if (pointsLayerRef.current) {\n        pointsLayerRef.current.clearLayers();\n        pointsLayerRef.current = null;\n      }\n    };\n  }, []);\n\n  // The heat map plugin expects an array of arrays with the lat, lng and intensity\n  // The intensity is the value of the point's total score (tos) divided by 100 because the intensity should be between 0 and 1\n  const calculateHeatPoints = useCallback(() => {\n    return points\n      .map((point) => {\n        const intensityValue = point[filteredUseCaseCode];\n        if (typeof intensityValue === 'number' && !isNaN(intensityValue)) {\n          const intensity = intensityValue / 100;\n          return [point.lat, point.lng, intensity];\n        }\n        return null; // Exclude invalid points\n      })\n      .filter(Boolean); // Remove null values\n  }, [points, filteredUseCaseCode]);\n\n  useEffect(() => {\n    if (!map || !points) {\n      return;\n    }\n\n    if (!heatLayerRef.current) {\n      heatLayerRef.current = L.heatLayer([], {\n        radius: 25,\n        blur: 15,\n        maxZoom: 15,\n        gradient: {\n          0.0: '#006400',\n          0.5: 'yellow',\n          1.0: 'red',\n        },\n      });\n    }\n\n    if (!pointsLayerRef.current) {\n      pointsLayerRef.current = L.layerGroup();\n    }\n\n    if (mapZoomLevel <= 15) {\n      if (!map.hasLayer(heatLayerRef.current)) {\n        map.addLayer(heatLayerRef.current);\n      }\n\n      heatLayerRef.current.setLatLngs(calculateHeatPoints());\n\n      if (map.hasLayer(pointsLayerRef.current)) {\n        map.removeLayer(pointsLayerRef.current);\n      }\n    } else {\n      if (!pointsLayerRef.current.getLayers().length) {\n        points.forEach((point) => {\n          const icon = getPointIconByType(\n            'Groups::Factory',\n            point?.id.toString(),\n            '',\n            false,\n            true,\n          );\n          const marker = L.marker([point.lat, point.lng], {\n            icon,\n          });\n          marker.on('click', () => {\n            if (onMarkerClick) {\n              onMarkerClick(point.id);\n            }\n          });\n          pointsLayerRef.current?.addLayer(marker);\n        });\n      }\n\n      if (!map.hasLayer(pointsLayerRef.current)) {\n        map.addLayer(pointsLayerRef.current);\n      }\n\n      if (map.hasLayer(heatLayerRef.current)) {\n        map.removeLayer(heatLayerRef.current);\n      }\n    }\n  }, [points, map, mapZoomLevel, filteredUseCaseCode, calculateHeatPoints]);\n\n  return map;\n};\n"],"mappings":"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"}
@@ -7,16 +7,14 @@ exports.formatCost = void 0;
7
7
  var formatCost = function formatCost(cost) {
8
8
  if (cost === 0) return '0'; // Return 0 without units if cost is 0
9
9
 
10
- var milions = cost >= 1000000;
11
- var thousands = cost >= 1000 && !milions;
12
- var unit = milions ? 'M' : thousands ? 'K' : '';
13
- cost = milions ? cost / 1000000 : thousands ? cost / 1000 : cost;
14
- var maximumFractionDigits = milions ? 2 : 0;
15
- var formattedCost = cost.toLocaleString(undefined, {
10
+ var unit = cost >= 1000 ? 'M' : cost >= 1 ? 'K' : ''; // Determine the unit
11
+ var scaledCost = cost >= 1000 ? cost / 1000 : cost; // Scale to millions if necessary
12
+ var formattedCost = scaledCost.toLocaleString(undefined, {
16
13
  minimumFractionDigits: 0,
17
- maximumFractionDigits: maximumFractionDigits
18
- });
14
+ maximumFractionDigits: 2
15
+ }); // Format the number
16
+
19
17
  return formattedCost + unit; // Combine the formatted cost and unit
20
18
  };
21
19
  exports.formatCost = formatCost;
22
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJmb3JtYXRDb3N0IiwiY29zdCIsIm1pbGlvbnMiLCJ0aG91c2FuZHMiLCJ1bml0IiwibWF4aW11bUZyYWN0aW9uRGlnaXRzIiwiZm9ybWF0dGVkQ29zdCIsInRvTG9jYWxlU3RyaW5nIiwidW5kZWZpbmVkIiwibWluaW11bUZyYWN0aW9uRGlnaXRzIiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9wYWdlcy9Qb2xsdXRpb25SaXNrQXNzZXNzbWVudC91dGlscy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgZm9ybWF0Q29zdCA9IChjb3N0OiBudW1iZXIpID0+IHtcbiAgaWYgKGNvc3QgPT09IDApIHJldHVybiAnMCc7IC8vIFJldHVybiAwIHdpdGhvdXQgdW5pdHMgaWYgY29zdCBpcyAwXG5cbiAgY29uc3QgbWlsaW9ucyA9IGNvc3QgPj0gMTAwMDAwMDtcbiAgY29uc3QgdGhvdXNhbmRzID0gY29zdCA+PSAxMDAwICYmICFtaWxpb25zO1xuICBjb25zdCB1bml0ID0gbWlsaW9ucyA/ICdNJyA6IHRob3VzYW5kcyA/ICdLJyA6ICcnO1xuICBjb3N0ID0gbWlsaW9ucyA/IGNvc3QgLyAxMDAwMDAwIDogdGhvdXNhbmRzID8gY29zdCAvIDEwMDAgOiBjb3N0O1xuICBjb25zdCBtYXhpbXVtRnJhY3Rpb25EaWdpdHMgPSBtaWxpb25zID8gMiA6IDA7XG4gIGNvbnN0IGZvcm1hdHRlZENvc3QgPSBjb3N0LnRvTG9jYWxlU3RyaW5nKHVuZGVmaW5lZCwge1xuICAgIG1pbmltdW1GcmFjdGlvbkRpZ2l0czogMCxcbiAgICBtYXhpbXVtRnJhY3Rpb25EaWdpdHM6IG1heGltdW1GcmFjdGlvbkRpZ2l0cyxcbiAgfSk7XG5cbiAgcmV0dXJuIGZvcm1hdHRlZENvc3QgKyB1bml0OyAvLyBDb21iaW5lIHRoZSBmb3JtYXR0ZWQgY29zdCBhbmQgdW5pdFxufTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQU8sSUFBTUEsVUFBVSxHQUFHLFNBQWJBLFVBQVVBLENBQUlDLElBQVksRUFBSztFQUMxQyxJQUFJQSxJQUFJLEtBQUssQ0FBQyxFQUFFLE9BQU8sR0FBRyxDQUFDLENBQUM7O0VBRTVCLElBQU1DLE9BQU8sR0FBR0QsSUFBSSxJQUFJLE9BQU87RUFDL0IsSUFBTUUsU0FBUyxHQUFHRixJQUFJLElBQUksSUFBSSxJQUFJLENBQUNDLE9BQU87RUFDMUMsSUFBTUUsSUFBSSxHQUFHRixPQUFPLEdBQUcsR0FBRyxHQUFHQyxTQUFTLEdBQUcsR0FBRyxHQUFHLEVBQUU7RUFDakRGLElBQUksR0FBR0MsT0FBTyxHQUFHRCxJQUFJLEdBQUcsT0FBTyxHQUFHRSxTQUFTLEdBQUdGLElBQUksR0FBRyxJQUFJLEdBQUdBLElBQUk7RUFDaEUsSUFBTUkscUJBQXFCLEdBQUdILE9BQU8sR0FBRyxDQUFDLEdBQUcsQ0FBQztFQUM3QyxJQUFNSSxhQUFhLEdBQUdMLElBQUksQ0FBQ00sY0FBYyxDQUFDQyxTQUFTLEVBQUU7SUFDbkRDLHFCQUFxQixFQUFFLENBQUM7SUFDeEJKLHFCQUFxQixFQUFFQTtFQUN6QixDQUFDLENBQUM7RUFFRixPQUFPQyxhQUFhLEdBQUdGLElBQUksQ0FBQyxDQUFDO0FBQy9CLENBQUM7QUFBQ00sT0FBQSxDQUFBVixVQUFBLEdBQUFBLFVBQUEifQ==
20
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJmb3JtYXRDb3N0IiwiY29zdCIsInVuaXQiLCJzY2FsZWRDb3N0IiwiZm9ybWF0dGVkQ29zdCIsInRvTG9jYWxlU3RyaW5nIiwidW5kZWZpbmVkIiwibWluaW11bUZyYWN0aW9uRGlnaXRzIiwibWF4aW11bUZyYWN0aW9uRGlnaXRzIiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9wYWdlcy9Qb2xsdXRpb25SaXNrQXNzZXNzbWVudC91dGlscy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgZm9ybWF0Q29zdCA9IChjb3N0OiBudW1iZXIpID0+IHtcbiAgaWYgKGNvc3QgPT09IDApIHJldHVybiAnMCc7IC8vIFJldHVybiAwIHdpdGhvdXQgdW5pdHMgaWYgY29zdCBpcyAwXG5cbiAgY29uc3QgdW5pdCA9IGNvc3QgPj0gMTAwMCA/ICdNJyA6IGNvc3QgPj0gMSA/ICdLJyA6ICcnOyAvLyBEZXRlcm1pbmUgdGhlIHVuaXRcbiAgY29uc3Qgc2NhbGVkQ29zdCA9IGNvc3QgPj0gMTAwMCA/IGNvc3QgLyAxMDAwIDogY29zdDsgLy8gU2NhbGUgdG8gbWlsbGlvbnMgaWYgbmVjZXNzYXJ5XG4gIGNvbnN0IGZvcm1hdHRlZENvc3QgPSBzY2FsZWRDb3N0LnRvTG9jYWxlU3RyaW5nKHVuZGVmaW5lZCwge1xuICAgIG1pbmltdW1GcmFjdGlvbkRpZ2l0czogMCxcbiAgICBtYXhpbXVtRnJhY3Rpb25EaWdpdHM6IDIsXG4gIH0pOyAvLyBGb3JtYXQgdGhlIG51bWJlclxuXG4gIHJldHVybiBmb3JtYXR0ZWRDb3N0ICsgdW5pdDsgLy8gQ29tYmluZSB0aGUgZm9ybWF0dGVkIGNvc3QgYW5kIHVuaXRcbn07XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFPLElBQU1BLFVBQVUsR0FBRyxTQUFiQSxVQUFVQSxDQUFJQyxJQUFZLEVBQUs7RUFDMUMsSUFBSUEsSUFBSSxLQUFLLENBQUMsRUFBRSxPQUFPLEdBQUcsQ0FBQyxDQUFDOztFQUU1QixJQUFNQyxJQUFJLEdBQUdELElBQUksSUFBSSxJQUFJLEdBQUcsR0FBRyxHQUFHQSxJQUFJLElBQUksQ0FBQyxHQUFHLEdBQUcsR0FBRyxFQUFFLENBQUMsQ0FBQztFQUN4RCxJQUFNRSxVQUFVLEdBQUdGLElBQUksSUFBSSxJQUFJLEdBQUdBLElBQUksR0FBRyxJQUFJLEdBQUdBLElBQUksQ0FBQyxDQUFDO0VBQ3RELElBQU1HLGFBQWEsR0FBR0QsVUFBVSxDQUFDRSxjQUFjLENBQUNDLFNBQVMsRUFBRTtJQUN6REMscUJBQXFCLEVBQUUsQ0FBQztJQUN4QkMscUJBQXFCLEVBQUU7RUFDekIsQ0FBQyxDQUFDLENBQUMsQ0FBQzs7RUFFSixPQUFPSixhQUFhLEdBQUdGLElBQUksQ0FBQyxDQUFDO0FBQy9CLENBQUM7QUFBQ08sT0FBQSxDQUFBVCxVQUFBLEdBQUFBLFVBQUEifQ==
@@ -13,8 +13,8 @@ var _react = _interopRequireWildcard(require("react"));
13
13
  var _Select = require("components/CustomInputs/Select/Select");
14
14
  var _i18n = _interopRequireDefault(require("utilities/i18n"));
15
15
  var _PasswordModal = require("./PasswordModal/PasswordModal");
16
- var _pen = require("@svgr/webpack?&svgo=false&ref!./pen.svg");
17
- var _cancel = require("@svgr/webpack?&svgo=false&ref!./cancel.svg");
16
+ var _pen = require("@svgr/webpack?-svgo!./pen.svg");
17
+ var _cancel = require("@svgr/webpack?-svgo!./cancel.svg");
18
18
  var _reactPhoneInput = _interopRequireDefault(require("react-phone-input-2"));
19
19
  require("react-phone-input-2/lib/style.css");
20
20
  var _TelegramModal = require("./TelegramModal/TelegramModal");
@@ -11,7 +11,7 @@ var _styledComponents = _interopRequireDefault(require("styled-components"));
11
11
  var _react = _interopRequireWildcard(require("react"));
12
12
  var _PopupModal = require("components/PopupModal/PopupModal");
13
13
  var _i18n = _interopRequireDefault(require("../../../utilities/i18n"));
14
- var _device = require("@svgr/webpack?&svgo=false&ref!../device.svg");
14
+ var _device = require("@svgr/webpack?-svgo!../device.svg");
15
15
  var _axios = _interopRequireDefault(require("axios"));
16
16
  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); }
17
17
  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; }
@@ -12,7 +12,7 @@ var _react = _interopRequireWildcard(require("react"));
12
12
  var _reactRedux = require("react-redux");
13
13
  var _ViewLabResult = _interopRequireDefault(require("./ViewLabResult"));
14
14
  var _SamplingActionContainer = _interopRequireDefault(require("./SamplingActionContainer"));
15
- var _dotsGen = require("@svgr/webpack?&svgo=false&ref!../../../assets/icons/3-dots-gen.svg");
15
+ var _dotsGen = require("@svgr/webpack?-svgo!../../../assets/icons/3-dots-gen.svg");
16
16
  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); }
17
17
  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; }
18
18
  var SamplingActionDropdown = function SamplingActionDropdown(props) {
@@ -13,7 +13,7 @@ var _styledComponents = _interopRequireDefault(require("styled-components"));
13
13
  var _photoPreview = _interopRequireDefault(require("assets/icons/photo-preview.svg"));
14
14
  var _uiKit = require("ui-kit");
15
15
  var _ImagePreviewModal = _interopRequireDefault(require("./ImagePreviewModal"));
16
- var _Trash_Icon = require("@svgr/webpack?&svgo=false&ref!./Trash_Icon.svg");
16
+ var _Trash_Icon = require("@svgr/webpack?-svgo!./Trash_Icon.svg");
17
17
  var _ImageDeleteModal = _interopRequireDefault(require("./ImageDeleteModal"));
18
18
  var _reactDeviceDetect = require("react-device-detect");
19
19
  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); }
@@ -14,7 +14,7 @@ var _reactDeviceDetect = require("react-device-detect");
14
14
  var _samplingPropertiesPhone = _interopRequireDefault(require("assets/icons/sampling-properties-phone.svg"));
15
15
  var _SamplingStatus = _interopRequireDefault(require("ui-kit/SamplingStatus/SamplingStatus"));
16
16
  var _i18n = _interopRequireDefault(require("utilities/i18n"));
17
- var _imageMissing = require("@svgr/webpack?&svgo=false&ref!assets/image-missing.svg");
17
+ var _imageMissing = require("@svgr/webpack?-svgo!assets/image-missing.svg");
18
18
  var _styleModule = _interopRequireDefault(require("./style.module.scss"));
19
19
  var _samplingPropertiesUtils = require("./samplingPropertiesUtils");
20
20
  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); }
@@ -15,7 +15,7 @@ var _reactDeviceDetect = require("react-device-detect");
15
15
  var _samplingPropertiesPhone = _interopRequireDefault(require("assets/icons/sampling-properties-phone.svg"));
16
16
  var _SamplingStatus = _interopRequireDefault(require("ui-kit/SamplingStatus/SamplingStatus"));
17
17
  var _i18n = _interopRequireDefault(require("utilities/i18n"));
18
- var _imageMissing = require("@svgr/webpack?&svgo=false&ref!assets/image-missing.svg");
18
+ var _imageMissing = require("@svgr/webpack?-svgo!assets/image-missing.svg");
19
19
  var _samplingPropertiesUtils = require("./samplingPropertiesUtils");
20
20
  var _ManholeImageMobile = _interopRequireDefault(require("./ManholeImageMobile"));
21
21
  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); }
@@ -8,7 +8,7 @@ exports.default = void 0;
8
8
  var _styledComponents = _interopRequireDefault(require("styled-components"));
9
9
  var _i18n = _interopRequireDefault(require("utilities/i18n"));
10
10
  var _react = _interopRequireDefault(require("react"));
11
- var _i_Icon = require("@svgr/webpack?&svgo=false&ref!assets/icons/informationTooltip/i_Icon.svg");
11
+ var _i_Icon = require("@svgr/webpack?-svgo!assets/icons/informationTooltip/i_Icon.svg");
12
12
  var EmptyState = function EmptyState(_ref) {
13
13
  var text_key = _ref.text_key;
14
14
  return /*#__PURE__*/_react.default.createElement(EmptyStateHolder, null, /*#__PURE__*/_react.default.createElement(_i_Icon.ReactComponent, {
@@ -8,7 +8,7 @@ exports.SevereEvent = void 0;
8
8
  var _react = _interopRequireDefault(require("react"));
9
9
  var _i18n = _interopRequireDefault(require("utilities/i18n"));
10
10
  var _TimeFormat = _interopRequireDefault(require("utilities/TimeFormat"));
11
- var _info = require("@svgr/webpack?&svgo=false&ref!./assets/info.svg");
11
+ var _info = require("@svgr/webpack?-svgo!./assets/info.svg");
12
12
  var _Eta = _interopRequireDefault(require("./Eta/Eta"));
13
13
  require("components/SevereEvent/SevereEvent.scss");
14
14
  var SevereEvent = function SevereEvent(_ref) {
@@ -20,8 +20,8 @@ var _GraphWrapper = require("./GraphWrapper");
20
20
  var _freeSolidSvgIcons = require("@fortawesome/free-solid-svg-icons");
21
21
  var _actions = require("../../store/context/actions");
22
22
  var _ThousandsToK = require("../../utilities/ThousandsToK");
23
- var _DrillDownIcon = require("@svgr/webpack?&svgo=false&ref!./DrillDownIcon.svg");
24
- var _BaseLevel = require("@svgr/webpack?&svgo=false&ref!./BaseLevel.svg");
23
+ var _DrillDownIcon = require("@svgr/webpack?-svgo!./DrillDownIcon.svg");
24
+ var _BaseLevel = require("@svgr/webpack?-svgo!./BaseLevel.svg");
25
25
  var _reactDataTableComponent = require("react-data-table-component");
26
26
  var _nvlStatusHelper = require("../CovidPage/components/nvlStatusHelper");
27
27
  var _Map = require("../../Widgets/Map/Map");