@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.
- package/lib/Router.js +6 -1
- package/lib/Widgets/Map/Map.js +18 -15
- package/lib/Widgets/Map/MapUtils.js +5 -2
- package/lib/Widgets/PotentialImpactSummary/Icon.js +5 -5
- package/lib/components/Sector/Sector.js +19 -12
- package/lib/components/Sector/SectorIconsNew.js +112 -0
- package/lib/i18n/en.json +15 -0
- package/lib/macros/getVersion.js +2 -2
- package/lib/pages/DashboardMap/SeverityBadge.js +5 -6
- package/lib/pages/EventsPage/EventsMapContainer/EventsMapContainer.js +3 -3
- package/lib/pages/PollutionRiskAssessment/FactoryDetails.js +130 -0
- package/lib/pages/PollutionRiskAssessment/FilterBehaviors.js +64 -0
- package/lib/pages/PollutionRiskAssessment/FilterButton.js +36 -0
- package/lib/pages/PollutionRiskAssessment/Map.js +49 -0
- package/lib/pages/PollutionRiskAssessment/Map.scss +59 -0
- package/lib/pages/PollutionRiskAssessment/TotalSavings.js +51 -0
- package/lib/pages/PollutionRiskAssessment/UseCases.js +53 -0
- package/lib/pages/PollutionRiskAssessment/contact_us.svg +18 -0
- package/lib/pages/PollutionRiskAssessment/filter_button.svg +5 -0
- package/lib/pages/PollutionRiskAssessment/index.js +246 -0
- package/lib/pages/PollutionRiskAssessment/index.scss +45 -0
- package/lib/pages/PollutionRiskAssessment/pig.svg +3 -0
- package/lib/pages/PollutionRiskAssessment/useMap.js +132 -0
- package/lib/pages/PollutionRiskAssessment/use_cases.json +50 -0
- package/lib/store/points/models/IGeoPoint.js +6 -0
- package/lib/styles/theme/theme.js +2 -2
- package/lib/ui-kit/Checkbox/Checkbox.js +7 -2
- package/lib/ui-kit/KandoBottomSheet/KandoBottomSheet.js +44 -0
- package/lib/ui-kit/KandoBottomSheet/KandoBottomSheet.scss +18 -0
- package/lib/utilities/urls.js +6 -1
- 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":";;;;;;;;AAAA,IAAAA,QAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,MAAA,GAAAD,OAAA;AACA,IAAAE,UAAA,GAAAF,OAAA;AAEA,IAAAG,MAAA,GAAAH,OAAA;AACA,IAAAI,SAAA,GAAAJ,OAAA;AAEO,IAAMK,MAAM,GAAG,SAATA,MAAMA,CACjBC,MAAuC,EACvCC,MAAmB,EACnBC,mBAA2B,EAC3BC,OAAa,EACbC,aAAoC,EACd;EACtB,IAAAC,SAAA,GAAsB,IAAAC,eAAQ,EAAQ,CAAC;IAAAC,UAAA,OAAAC,eAAA,CAAAC,OAAA,EAAAJ,SAAA;IAAhCK,GAAG,GAAAH,UAAA;IAAEI,MAAM,GAAAJ,UAAA;EAClB,IAAAK,UAAA,GAAwC,IAAAN,eAAQ,EAAC,EAAE,CAAC;IAAAO,UAAA,OAAAL,eAAA,CAAAC,OAAA,EAAAG,UAAA;IAA7CE,YAAY,GAAAD,UAAA;IAAEE,eAAe,GAAAF,UAAA;EACpC,IAAMG,YAAY,GAAG,IAAAC,aAAM,EAAc,CAAC;EAC1C,IAAMC,cAAc,GAAG,IAAAD,aAAM,EAAe,CAAC;EAE7C,IAAAE,gBAAS,EAAC,YAAM;IACd,IAAI,CAACnB,MAAM,CAACoB,OAAO,EAAE;MACnB;IACF;IAEA,IAAMC,QAAQ,GAAG,IAAAC,kBAAQ,EAACC,iBAAU,CAACC,UAAU,EAAED,iBAAU,CAACE,SAAS,CAAC;IACtE,IAAMC,OAAO,GAAGC,gBAAC,CAACjB,GAAG,CAACV,MAAM,CAACoB,OAAO,EAAE,CAAC,CAAC,CAAC;IAEzCQ,MAAM,CAACC,MAAM,CAACR,QAAQ,CAAC,CAAC,CAAC,CAAC,CAACS,KAAK,CAACJ,OAAO,CAAC;IAEzCC,gBAAC,CAACI,OAAO,CAACC,MAAM,CAACX,QAAQ,EAAE,CAAC,CAAC,EAAE;MAAEY,QAAQ,EAAE;IAAW,CAAC,CAAC,CAACH,KAAK,CAACJ,OAAO,CAAC;;IAEvE;IACA,IAAIvB,OAAO,IAAIA,OAAO,CAAC+B,MAAM,KAAKC,SAAS,EAAE;MAC3C,IAAMC,YAAY,GAAGT,gBAAC,CAACU,OAAO,CAAClC,OAAO,EAAE;QACtCmC,KAAK,EAAE;UACLC,KAAK,EAAE,aAAa;UACpBC,SAAS,EAAE,aAAa;UACxBC,WAAW,EAAE;QACf;MACF,CAAC,CAAC,CAACX,KAAK,CAACJ,OAAO,CAAC;MACjBA,OAAO,CAACgB,SAAS,CAACN,YAAY,CAACO,SAAS,CAAC,CAAC,CAAC;IAC7C;IAEAjB,OAAO,CAACkB,EAAE,CAAC,SAAS,EAAE,YAAM;MAC1B7B,eAAe,CAACW,OAAO,CAACmB,OAAO,CAAC,CAAC,CAAC;IACpC,CAAC,CAAC;IAEFlC,MAAM,CAACe,OAAO,CAAC;IAEf,OAAO,YAAM;MACX,IAAI,CAACA,OAAO,EAAE;QACZ;MACF;MACAA,OAAO,CAACoB,GAAG,CAAC,CAAC;MACbpB,OAAO,CAACqB,MAAM,CAAC,CAAC;;MAEhB;MACA,IAAI/B,YAAY,CAACI,OAAO,EAAE;QACxBJ,YAAY,CAACI,OAAO,CAAC0B,GAAG,CAAC,CAAC;QAC1B9B,YAAY,CAACI,OAAO,CAAC2B,MAAM,CAAC,CAAC;QAC7B/B,YAAY,CAACI,OAAO,GAAG,IAAI;MAC7B;MACA,IAAIF,cAAc,CAACE,OAAO,EAAE;QAC1BF,cAAc,CAACE,OAAO,CAAC4B,WAAW,CAAC,CAAC;QACpC9B,cAAc,CAACE,OAAO,GAAG,IAAI;MAC/B;IACF,CAAC;EACH,CAAC,EAAE,EAAE,CAAC;;EAEN;EACA;EACA,IAAM6B,mBAAmB,GAAG,IAAAC,kBAAW,EAAC,YAAM;IAC5C,OAAOjD,MAAM,CACVS,GAAG,CAAC,UAACyC,KAAK,EAAK;MACd,IAAMC,cAAc,GAAGD,KAAK,CAACjD,mBAAmB,CAAC;MACjD,IAAI,OAAOkD,cAAc,KAAK,QAAQ,IAAI,CAACC,KAAK,CAACD,cAAc,CAAC,EAAE;QAChE,IAAME,SAAS,GAAGF,cAAc,GAAG,GAAG;QACtC,OAAO,CAACD,KAAK,CAACI,GAAG,EAAEJ,KAAK,CAACK,GAAG,EAAEF,SAAS,CAAC;MAC1C;MACA,OAAO,IAAI,CAAC,CAAC;IACf,CAAC,CAAC,CACDG,MAAM,CAACC,OAAO,CAAC,CAAC,CAAC;EACtB,CAAC,EAAE,CAACzD,MAAM,EAAEC,mBAAmB,CAAC,CAAC;EAEjC,IAAAiB,gBAAS,EAAC,YAAM;IACd,IAAI,CAACT,GAAG,IAAI,CAACT,MAAM,EAAE;MACnB;IACF;IAEA,IAAI,CAACe,YAAY,CAACI,OAAO,EAAE;MACzBJ,YAAY,CAACI,OAAO,GAAGO,gBAAC,CAACgC,SAAS,CAAC,EAAE,EAAE;QACrCC,MAAM,EAAE,EAAE;QACVC,IAAI,EAAE,EAAE;QACRC,OAAO,EAAE;MACX,CAAC,CAAC;IACJ;IAEA,IAAI,CAAC5C,cAAc,CAACE,OAAO,EAAE;MAC3BF,cAAc,CAACE,OAAO,GAAGO,gBAAC,CAACoC,UAAU,CAAC,CAAC;IACzC;IAEA,IAAIjD,YAAY,IAAI,EAAE,EAAE;MACtB,IAAI,CAACJ,GAAG,CAACsD,QAAQ,CAAChD,YAAY,CAACI,OAAO,CAAC,EAAE;QACvCV,GAAG,CAACuD,QAAQ,CAACjD,YAAY,CAACI,OAAO,CAAC;MACpC;MAEAJ,YAAY,CAACI,OAAO,CAAC8C,UAAU,CAACjB,mBAAmB,CAAC,CAAC,CAAC;MAEtD,IAAIvC,GAAG,CAACsD,QAAQ,CAAC9C,cAAc,CAACE,OAAO,CAAC,EAAE;QACxCV,GAAG,CAACyD,WAAW,CAACjD,cAAc,CAACE,OAAO,CAAC;MACzC;IACF,CAAC,MAAM;MACL,IAAI,CAACF,cAAc,CAACE,OAAO,CAACgD,SAAS,CAAC,CAAC,CAAClC,MAAM,EAAE;QAC9CjC,MAAM,CAACoE,OAAO,CAAC,UAAClB,KAAK,EAAK;UAAA,IAAAmB,qBAAA;UACxB,IAAMC,IAAI,GAAG,IAAAC,6BAAkB,EAC7B,iBAAiB,EACjBrB,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEsB,EAAE,CAACC,QAAQ,CAAC,CAAC,EACpB,EAAE,EACF,KAAK,EACL,IACF,CAAC;UACD,IAAMC,MAAM,GAAGhD,gBAAC,CAACgD,MAAM,CAAC,CAACxB,KAAK,CAACI,GAAG,EAAEJ,KAAK,CAACK,GAAG,CAAC,EAAE;YAC9Ce,IAAI,EAAJA;UACF,CAAC,CAAC;UACFI,MAAM,CAAC/B,EAAE,CAAC,OAAO,EAAE,YAAM;YACvB,IAAIxC,aAAa,EAAE;cACjBA,aAAa,CAAC+C,KAAK,CAACsB,EAAE,CAAC;YACzB;UACF,CAAC,CAAC;UACF,CAAAH,qBAAA,GAAApD,cAAc,CAACE,OAAO,cAAAkD,qBAAA,uBAAtBA,qBAAA,CAAwBL,QAAQ,CAACU,MAAM,CAAC;QAC1C,CAAC,CAAC;MACJ;MAEA,IAAI,CAACjE,GAAG,CAACsD,QAAQ,CAAC9C,cAAc,CAACE,OAAO,CAAC,EAAE;QACzCV,GAAG,CAACuD,QAAQ,CAAC/C,cAAc,CAACE,OAAO,CAAC;MACtC;MAEA,IAAIV,GAAG,CAACsD,QAAQ,CAAChD,YAAY,CAACI,OAAO,CAAC,EAAE;QACtCV,GAAG,CAACyD,WAAW,CAACnD,YAAY,CAACI,OAAO,CAAC;MACvC;IACF;EACF,CAAC,EAAE,CAACnB,MAAM,EAAES,GAAG,EAAEI,YAAY,EAAEZ,mBAAmB,EAAE+C,mBAAmB,CAAC,CAAC;EAEzE,OAAOvC,GAAG;AACZ,CAAC;AAACkE,OAAA,CAAA7E,MAAA,GAAAA,MAAA"}
|
|
@@ -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==
|