@kando-env/kando-ui 1.2.384 → 1.2.385-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (31) hide show
  1. package/lib/Router.js +6 -1
  2. package/lib/Widgets/Map/Map.js +18 -15
  3. package/lib/Widgets/Map/MapUtils.js +5 -2
  4. package/lib/Widgets/PotentialImpactSummary/Icon.js +5 -5
  5. package/lib/components/Sector/Sector.js +19 -12
  6. package/lib/components/Sector/SectorIconsNew.js +112 -0
  7. package/lib/i18n/en.json +15 -0
  8. package/lib/macros/getVersion.js +2 -2
  9. package/lib/pages/DashboardMap/SeverityBadge.js +5 -6
  10. package/lib/pages/EventsPage/EventsMapContainer/EventsMapContainer.js +3 -3
  11. package/lib/pages/PollutionRiskAssessment/FactoryDetails.js +130 -0
  12. package/lib/pages/PollutionRiskAssessment/FilterBehaviors.js +64 -0
  13. package/lib/pages/PollutionRiskAssessment/FilterButton.js +36 -0
  14. package/lib/pages/PollutionRiskAssessment/Map.js +49 -0
  15. package/lib/pages/PollutionRiskAssessment/Map.scss +59 -0
  16. package/lib/pages/PollutionRiskAssessment/TotalSavings.js +51 -0
  17. package/lib/pages/PollutionRiskAssessment/UseCases.js +53 -0
  18. package/lib/pages/PollutionRiskAssessment/contact_us.svg +18 -0
  19. package/lib/pages/PollutionRiskAssessment/filter_button.svg +5 -0
  20. package/lib/pages/PollutionRiskAssessment/index.js +246 -0
  21. package/lib/pages/PollutionRiskAssessment/index.scss +45 -0
  22. package/lib/pages/PollutionRiskAssessment/pig.svg +3 -0
  23. package/lib/pages/PollutionRiskAssessment/useMap.js +132 -0
  24. package/lib/pages/PollutionRiskAssessment/use_cases.json +50 -0
  25. package/lib/store/points/models/IGeoPoint.js +6 -0
  26. package/lib/styles/theme/theme.js +2 -2
  27. package/lib/ui-kit/Checkbox/Checkbox.js +7 -2
  28. package/lib/ui-kit/KandoBottomSheet/KandoBottomSheet.js +44 -0
  29. package/lib/ui-kit/KandoBottomSheet/KandoBottomSheet.scss +18 -0
  30. package/lib/utilities/urls.js +6 -1
  31. package/package.json +3 -1
@@ -0,0 +1,246 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.default = void 0;
9
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
10
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/asyncToGenerator"));
11
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/slicedToArray"));
12
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
13
+ require("bootstrap/dist/css/bootstrap.min.css");
14
+ var _react = _interopRequireWildcard(require("react"));
15
+ var _reactRedux = require("react-redux");
16
+ var _actions = require("store/context/actions");
17
+ var _Analytics = require("../../utilities/Analytics");
18
+ var _Map = require("./Map");
19
+ var _useNavContext2 = require("../../hooks/useNavContext");
20
+ var _KandoBottomSheet = _interopRequireDefault(require("../../ui-kit/KandoBottomSheet/KandoBottomSheet"));
21
+ var _urls = require("../../utilities/urls");
22
+ require("./index.scss");
23
+ var _TotalSavings = require("./TotalSavings");
24
+ var _FilterBehaviors = require("./FilterBehaviors");
25
+ var _FactoryDetails = require("./FactoryDetails");
26
+ var _FilterButton = _interopRequireDefault(require("./FilterButton"));
27
+ var _use_cases = _interopRequireDefault(require("./use_cases.json"));
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); }
29
+ 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; }
30
+ var PollutionRiskAssessment = function PollutionRiskAssessment() {
31
+ var waterAuthorityName = (0, _reactRedux.useSelector)(function (state) {
32
+ return state.global_data.waterAuthorityName;
33
+ });
34
+ var waterAuthorityId = (0, _reactRedux.useSelector)(function (state) {
35
+ return state.global_data.waterAuthorityId;
36
+ });
37
+ var _useState = (0, _react.useState)(),
38
+ _useState2 = (0, _slicedToArray2.default)(_useState, 2),
39
+ polygonData = _useState2[0],
40
+ setPolygonData = _useState2[1];
41
+ var _useState3 = (0, _react.useState)(),
42
+ _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
43
+ pointsData = _useState4[0],
44
+ setPointsData = _useState4[1];
45
+ var _useNavContext = (0, _useNavContext2.useNavContext)(),
46
+ isRtl = _useNavContext.isRtl;
47
+ var _useState5 = (0, _react.useState)('total_savings'),
48
+ _useState6 = (0, _slicedToArray2.default)(_useState5, 2),
49
+ shownContent = _useState6[0],
50
+ setShownContent = _useState6[1];
51
+ var _useState7 = (0, _react.useState)([]),
52
+ _useState8 = (0, _slicedToArray2.default)(_useState7, 2),
53
+ visiblePoints = _useState8[0],
54
+ setVisiblePoints = _useState8[1];
55
+ var _useState9 = (0, _react.useState)(''),
56
+ _useState10 = (0, _slicedToArray2.default)(_useState9, 2),
57
+ useCasesFilter = _useState10[0],
58
+ setUseCasesFilter = _useState10[1];
59
+ var _useState11 = (0, _react.useState)(null),
60
+ _useState12 = (0, _slicedToArray2.default)(_useState11, 2),
61
+ mapBounds = _useState12[0],
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];
67
+ var handleDismiss = function handleDismiss() {
68
+ setShownContent('total_savings');
69
+ };
70
+ var dispatch = (0, _reactRedux.useDispatch)();
71
+ var fetchData = /*#__PURE__*/function () {
72
+ var _ref = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(url, setData) {
73
+ var response, result;
74
+ return _regenerator.default.wrap(function _callee$(_context) {
75
+ while (1) {
76
+ switch (_context.prev = _context.next) {
77
+ case 0:
78
+ _context.prev = 0;
79
+ _context.next = 3;
80
+ return fetch(url);
81
+ case 3:
82
+ response = _context.sent;
83
+ _context.next = 6;
84
+ return response.json();
85
+ case 6:
86
+ result = _context.sent;
87
+ setData(result);
88
+ _context.next = 13;
89
+ break;
90
+ case 10:
91
+ _context.prev = 10;
92
+ _context.t0 = _context["catch"](0);
93
+ console.error("Failed to fetch data from ".concat(url, ":"), _context.t0);
94
+ case 13:
95
+ case "end":
96
+ return _context.stop();
97
+ }
98
+ }
99
+ }, _callee, null, [[0, 10]]);
100
+ }));
101
+ return function fetchData(_x, _x2) {
102
+ return _ref.apply(this, arguments);
103
+ };
104
+ }();
105
+ (0, _react.useEffect)(function () {
106
+ if (waterAuthorityId) {
107
+ var currentGeoAreaUrl = (0, _urls.urls)({
108
+ waterAuthorityId: waterAuthorityId
109
+ }).PollutionRiskAssessment.currentGeoArea;
110
+ fetchData(currentGeoAreaUrl, setPolygonData);
111
+ (0, _Analytics.analyticsTrack)('Viewed Pollution Risk Assessment Page', {
112
+ utility_name: waterAuthorityName
113
+ });
114
+ dispatch((0, _actions.updateNavContext)({
115
+ name: 'pollution_risk_assessment'
116
+ }));
117
+ }
118
+ }, [waterAuthorityId]);
119
+ var getPolygonGeoJSON = function getPolygonGeoJSON(polygonData) {
120
+ try {
121
+ return (polygonData === null || polygonData === void 0 ? void 0 : polygonData.polygon) ? JSON.parse(polygonData.polygon) : [];
122
+ } catch (error) {
123
+ console.error('Failed to parse polygon data:', error);
124
+ return [];
125
+ }
126
+ };
127
+ (0, _react.useEffect)(function () {
128
+ if (!polygonData) return;
129
+ var allPointsUrl = (0, _urls.urls)({
130
+ waterAuthorityId: waterAuthorityId,
131
+ id: polygonData === null || polygonData === void 0 ? void 0 : polygonData.id
132
+ }).PollutionRiskAssessment.allPoints;
133
+ fetchData(allPointsUrl, setPointsData);
134
+ }, [polygonData]);
135
+ var useCase = _use_cases.default.find(function (useCase) {
136
+ return useCase.id === useCasesFilter;
137
+ });
138
+ var getBottomSheetConfig = function getBottomSheetConfig() {
139
+ switch (shownContent) {
140
+ case 'total_savings':
141
+ return {
142
+ content: /*#__PURE__*/_react.default.createElement(_TotalSavings.TotalSavings, {
143
+ points: visiblePoints,
144
+ filteredUseCase: useCase
145
+ }),
146
+ snapPoints: function snapPoints(_ref2) {
147
+ var maxHeight = _ref2.maxHeight;
148
+ return [78, maxHeight - 100];
149
+ },
150
+ backgroundColor: '#000'
151
+ };
152
+ case 'filter_behaviors':
153
+ return {
154
+ content: /*#__PURE__*/_react.default.createElement(_FilterBehaviors.FilterBehaviors, {
155
+ selectedItem: useCasesFilter,
156
+ handleChange: setUseCasesFilter
157
+ }),
158
+ snapPoints: function snapPoints(_ref3) {
159
+ var maxHeight = _ref3.maxHeight;
160
+ return [maxHeight - 300, maxHeight - 300];
161
+ },
162
+ backgroundColor: '#fff'
163
+ };
164
+ case 'factory_details':
165
+ return {
166
+ content: /*#__PURE__*/_react.default.createElement(_FactoryDetails.FactoryDetails, {
167
+ point_id: clickedPointId
168
+ }),
169
+ snapPoints: function snapPoints(_ref4) {
170
+ var maxHeight = _ref4.maxHeight;
171
+ return [maxHeight - 500, maxHeight - 500];
172
+ },
173
+ backgroundColor: '#fff'
174
+ };
175
+ default:
176
+ return {
177
+ content: null,
178
+ snapPoints: function snapPoints() {
179
+ return [0];
180
+ },
181
+ backgroundColor: '#000'
182
+ };
183
+ }
184
+ };
185
+ var _useMemo = (0, _react.useMemo)(getBottomSheetConfig, [shownContent, useCasesFilter, visiblePoints, clickedPointId]),
186
+ content = _useMemo.content,
187
+ snapPoints = _useMemo.snapPoints,
188
+ backgroundColor = _useMemo.backgroundColor;
189
+ var bottomSheet = (0, _react.useMemo)(function () {
190
+ return /*#__PURE__*/_react.default.createElement(_KandoBottomSheet.default, {
191
+ backgroundColor: backgroundColor,
192
+ snapPoints: snapPoints,
193
+ onDismiss: handleDismiss,
194
+ isOpen: true
195
+ }, content);
196
+ }, [visiblePoints, shownContent, clickedPointId]);
197
+ (0, _react.useEffect)(function () {
198
+ if (!mapBounds || !pointsData) return;
199
+ var filteredPoints = pointsData.filter(function (point) {
200
+ return point.lat >= mapBounds.getSouthWest().lat && point.lat <= mapBounds.getNorthEast().lat && point.lng >= mapBounds.getSouthWest().lng && point.lng <= mapBounds.getNorthEast().lng;
201
+ });
202
+ setVisiblePoints(filteredPoints);
203
+ }, [mapBounds, pointsData]);
204
+ var handleBoundsChange = (0, _react.useCallback)(function (bounds) {
205
+ setMapBounds(bounds);
206
+ }, []);
207
+ var filterButtonClick = function filterButtonClick() {
208
+ setShownContent(function (prevContent) {
209
+ return prevContent === 'filter_behaviors' ? 'total_savings' : 'filter_behaviors';
210
+ });
211
+ };
212
+ var filterButtonState = (0, _react.useMemo)(function () {
213
+ if (shownContent === 'filter_behaviors') {
214
+ return 'filled';
215
+ }
216
+ return useCasesFilter !== '' ? 'filled-red' : '';
217
+ }, [shownContent, useCasesFilter]);
218
+ var markerClicked = function markerClicked(id) {
219
+ setClickedPointId(id);
220
+ if (shownContent !== 'factory_details') {
221
+ setShownContent('factory_details');
222
+ }
223
+ };
224
+ if (!pointsData || !polygonData) return null;
225
+ return /*#__PURE__*/_react.default.createElement("div", {
226
+ className: "app-wrapper"
227
+ }, /*#__PURE__*/_react.default.createElement(MapTableContainer, {
228
+ isRtl: isRtl
229
+ }, /*#__PURE__*/_react.default.createElement(_Map.Map, {
230
+ filteredUseCaseCode: (useCase ? useCase.code : 'to') + 's',
231
+ points: pointsData,
232
+ polygon: getPolygonGeoJSON(polygonData),
233
+ onBoundsChange: handleBoundsChange,
234
+ onMarkerClick: markerClicked
235
+ })), bottomSheet, /*#__PURE__*/_react.default.createElement(_FilterButton.default, {
236
+ buttonState: filterButtonState,
237
+ onClick: filterButtonClick
238
+ }));
239
+ };
240
+ var _default = PollutionRiskAssessment;
241
+ exports.default = _default;
242
+ var MapTableContainer = _styledComponents.default.div.withConfig({
243
+ displayName: "PollutionRiskAssessment__MapTableContainer",
244
+ componentId: "sc-peb1i1-0"
245
+ })(["position:fixed;top:65px;height:calc(100vh - 20px);width:100vw;#map{height:100%;width:100%;*,*:focus,*:hover{outline:none;}}"]);
246
+ //# 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","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  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            78,\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 - 300,\n            maxHeight - 300,\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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"}
@@ -0,0 +1,45 @@
1
+ .map-heights {
2
+ height: 100%;
3
+ width: 100%;
4
+
5
+ *,
6
+ *:focus,
7
+ *:hover {
8
+ outline: none;
9
+ }
10
+ }
11
+
12
+ .assessment-page {
13
+ height: 100%;
14
+ width: 100%;
15
+ left: 0;
16
+ top: 0;
17
+
18
+ #map {
19
+ height: 100%;
20
+ width: 100%;
21
+
22
+ .leaflet-popup-close-button {
23
+ font-size: x-large;
24
+ }
25
+ }
26
+
27
+ .btn-group {
28
+ display: flex;
29
+ justify-content: center;
30
+ margin-top: 20px;
31
+
32
+ button {
33
+ margin: 0 10px;
34
+ }
35
+ }
36
+
37
+ .use-case-icon {
38
+ width: 24px;
39
+ height: 24px;
40
+ }
41
+
42
+ svg path {
43
+ fill: white !important;
44
+ }
45
+ }
@@ -0,0 +1,3 @@
1
+ <svg width="22" height="22" viewBox="0 0 22 22" fill="none" xmlns="http://www.w3.org/2000/svg">
2
+ <path d="M15.4627 10.3134C15.7358 10.3134 15.9686 10.2172 16.161 10.0248C16.3534 9.83241 16.4496 9.59963 16.4496 9.32644C16.4496 9.05325 16.3534 8.82047 16.161 8.62809C15.9686 8.43571 15.7358 8.33952 15.4627 8.33952C15.1895 8.33952 14.9567 8.43571 14.7643 8.62809C14.5719 8.82047 14.4757 9.05325 14.4757 9.32644C14.4757 9.59963 14.5719 9.83241 14.7643 10.0248C14.9567 10.2172 15.1895 10.3134 15.4627 10.3134ZM6.53734 7.93183H12.1157V6.25839H6.53734V7.93183ZM3.05092 21.0409C2.46162 19.0069 1.87268 16.983 1.2841 14.9691C0.695508 12.9552 0.401215 10.8884 0.401215 8.76861C0.401215 7.21527 0.9426 5.89722 2.02537 4.81447C3.10812 3.7317 4.42617 3.19031 5.97951 3.19031H11.8368C12.3474 2.5195 12.9599 1.97991 13.6744 1.57154C14.3888 1.16317 15.1709 0.958984 16.0205 0.958984C16.328 0.958984 16.5908 1.06805 16.8089 1.28618C17.0271 1.50429 17.1361 1.76711 17.1361 2.07462C17.1361 2.15043 17.1258 2.22624 17.105 2.30205C17.0843 2.37784 17.0625 2.44792 17.0396 2.5123C16.9366 2.78121 16.849 3.05655 16.7767 3.33833C16.7045 3.62011 16.6426 3.90476 16.5912 4.19226L19.4941 7.09514H21.5988V13.9114L18.5543 14.9112L16.7178 21.0409H11.5579V18.8096H8.21081V21.0409H3.05092ZM4.30601 19.3674H6.53734V17.1361H13.2313V19.3674H15.4627L17.1919 13.6217L19.9253 12.7013V8.76861H18.8097L14.9048 4.86378C14.9048 4.49189 14.9281 4.13395 14.9746 3.78996C15.021 3.44596 15.0979 3.10089 15.2052 2.75476C14.666 2.90351 14.1954 3.16276 13.7935 3.53249C13.3915 3.90224 13.0833 4.346 12.8687 4.86378H5.97951C4.90103 4.86378 3.98061 5.24497 3.21824 6.00734C2.45587 6.76971 2.07468 7.69013 2.07468 8.76861C2.07468 10.5909 2.32571 12.3713 2.82776 14.1099C3.32981 15.8484 3.82256 17.601 4.30601 19.3674Z" fill="white"/>
3
+ </svg>
@@ -0,0 +1,132 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.useMap = void 0;
8
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/slicedToArray"));
9
+ var _leaflet = _interopRequireDefault(require("leaflet"));
10
+ var _react = require("react");
11
+ var _PointIcon = require("Widgets/Map/points/PointIcon");
12
+ var _theme = require("styles/theme/theme");
13
+ var _MapUtils = require("Widgets/Map/MapUtils");
14
+ var useMap = function useMap(mapRef, points, filteredUseCaseCode, polygon, onMarkerClick) {
15
+ var _useState = (0, _react.useState)(),
16
+ _useState2 = (0, _slicedToArray2.default)(_useState, 2),
17
+ map = _useState2[0],
18
+ setMap = _useState2[1];
19
+ var _useState3 = (0, _react.useState)(15),
20
+ _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
21
+ mapZoomLevel = _useState4[0],
22
+ setMapZoomLevel = _useState4[1];
23
+ var heatLayerRef = (0, _react.useRef)();
24
+ var pointsLayerRef = (0, _react.useRef)();
25
+ (0, _react.useEffect)(function () {
26
+ if (!mapRef.current) {
27
+ return;
28
+ }
29
+ var mapTypes = (0, _MapUtils.baseMaps)(_theme.leafletMap.mapDefault, _theme.leafletMap.satellite);
30
+ var mapTemp = _leaflet.default.map(mapRef.current, {});
31
+ Object.values(mapTypes)[0].addTo(mapTemp);
32
+ _leaflet.default.control.layers(mapTypes, {}, {
33
+ position: 'topright'
34
+ }).addTo(mapTemp);
35
+
36
+ // The colors are transparent so the map will fit the polygon bounds but it won't be visible
37
+ if (polygon && polygon.length === undefined) {
38
+ var geoJSONLayer = _leaflet.default.geoJSON(polygon, {
39
+ style: {
40
+ color: 'transparent',
41
+ fillColor: 'transparent',
42
+ fillOpacity: 0
43
+ }
44
+ }).addTo(mapTemp);
45
+ mapTemp.fitBounds(geoJSONLayer.getBounds());
46
+ }
47
+ mapTemp.on('zoomend', function () {
48
+ setMapZoomLevel(mapTemp.getZoom());
49
+ });
50
+ setMap(mapTemp);
51
+ return function () {
52
+ if (!mapTemp) {
53
+ return;
54
+ }
55
+ mapTemp.off();
56
+ mapTemp.remove();
57
+
58
+ // Clean up layers
59
+ if (heatLayerRef.current) {
60
+ heatLayerRef.current.off();
61
+ heatLayerRef.current.remove();
62
+ heatLayerRef.current = null;
63
+ }
64
+ if (pointsLayerRef.current) {
65
+ pointsLayerRef.current.clearLayers();
66
+ pointsLayerRef.current = null;
67
+ }
68
+ };
69
+ }, []);
70
+
71
+ // The heat map plugin expects an array of arrays with the lat, lng and intensity
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
73
+ var calculateHeatPoints = (0, _react.useCallback)(function () {
74
+ return points.map(function (point) {
75
+ var intensityValue = point[filteredUseCaseCode];
76
+ if (typeof intensityValue === 'number' && !isNaN(intensityValue)) {
77
+ var intensity = intensityValue / 100;
78
+ return [point.lat, point.lng, intensity];
79
+ }
80
+ return null; // Exclude invalid points
81
+ }).filter(Boolean); // Remove null values
82
+ }, [points, filteredUseCaseCode]);
83
+ (0, _react.useEffect)(function () {
84
+ if (!map || !points) {
85
+ return;
86
+ }
87
+ if (!heatLayerRef.current) {
88
+ heatLayerRef.current = _leaflet.default.heatLayer([], {
89
+ radius: 25,
90
+ blur: 15,
91
+ maxZoom: 15
92
+ });
93
+ }
94
+ if (!pointsLayerRef.current) {
95
+ pointsLayerRef.current = _leaflet.default.layerGroup();
96
+ }
97
+ if (mapZoomLevel <= 15) {
98
+ if (!map.hasLayer(heatLayerRef.current)) {
99
+ map.addLayer(heatLayerRef.current);
100
+ }
101
+ heatLayerRef.current.setLatLngs(calculateHeatPoints());
102
+ if (map.hasLayer(pointsLayerRef.current)) {
103
+ map.removeLayer(pointsLayerRef.current);
104
+ }
105
+ } else {
106
+ if (!pointsLayerRef.current.getLayers().length) {
107
+ points.forEach(function (point) {
108
+ var _pointsLayerRef$curre;
109
+ var icon = (0, _PointIcon.getPointIconByType)('Groups::Factory', point === null || point === void 0 ? void 0 : point.id.toString(), '', false, true);
110
+ var marker = _leaflet.default.marker([point.lat, point.lng], {
111
+ icon: icon
112
+ });
113
+ marker.on('click', function () {
114
+ if (onMarkerClick) {
115
+ onMarkerClick(point.id);
116
+ }
117
+ });
118
+ (_pointsLayerRef$curre = pointsLayerRef.current) === null || _pointsLayerRef$curre === void 0 ? void 0 : _pointsLayerRef$curre.addLayer(marker);
119
+ });
120
+ }
121
+ if (!map.hasLayer(pointsLayerRef.current)) {
122
+ map.addLayer(pointsLayerRef.current);
123
+ }
124
+ if (map.hasLayer(heatLayerRef.current)) {
125
+ map.removeLayer(heatLayerRef.current);
126
+ }
127
+ }
128
+ }, [points, map, mapZoomLevel, filteredUseCaseCode, calculateHeatPoints]);
129
+ return map;
130
+ };
131
+ exports.useMap = useMap;
132
+ //# 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","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      });\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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"}
@@ -0,0 +1,50 @@
1
+ [
2
+ {
3
+ "id": "additional_opex",
4
+ "name": "additional_opex",
5
+ "icon": "wwtp_cost",
6
+ "code": "ao"
7
+ },
8
+ {
9
+ "id": "agriculture_irrigation",
10
+ "name": "agriculture_irrigation",
11
+ "icon": "shorten_collection_lifetime",
12
+ "code": "ai"
13
+ },
14
+ {
15
+ "id": "biosolids_land_application",
16
+ "name": "biosolids_land_application",
17
+ "icon": "shorten_collection_lifetime",
18
+ "code": "bl"
19
+ },
20
+ {
21
+ "id": "pipeline_corrosion",
22
+ "name": "pipeline_corrosion",
23
+ "icon": "pipes_pumps_blockage",
24
+ "code": "pc"
25
+ },
26
+ {
27
+ "id": "pipeline_blockages",
28
+ "name": "pipeline_blockages",
29
+ "icon": "pipes_pumps_blockage",
30
+ "code": "pb"
31
+ },
32
+ {
33
+ "id": "process_interference",
34
+ "name": "process_interference",
35
+ "icon": "shorten_collection_lifetime",
36
+ "code": "pi"
37
+ },
38
+ {
39
+ "id": "sludge_for_landfill",
40
+ "name": "sludge_for_landfill",
41
+ "icon": "sludge_treatment",
42
+ "code": "sl"
43
+ },
44
+ {
45
+ "id": "surface_water_pollution",
46
+ "name": "surface_water_pollution",
47
+ "icon": "water_reuse",
48
+ "code": "sw"
49
+ }
50
+ ]
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3N0b3JlL3BvaW50cy9tb2RlbHMvSUdlb1BvaW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgSUdlb1BvaW50IHtcbiAgaWQ6IG51bWJlcjtcbiAgbGF0OiBudW1iZXI7XG4gIGxuZzogbnVtYmVyO1xuICB0b3M6IG51bWJlcjtcbiAgdG9jOiBudW1iZXI7XG59XG4iXSwibWFwcGluZ3MiOiIifQ==