@kando-env/kando-ui 1.2.398-alpha.6 → 1.2.398-alpha.9

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.
@@ -22,3 +22,17 @@
22
22
  .leaflet-control {
23
23
  z-index: 900;
24
24
  }
25
+
26
+ @keyframes blink {
27
+ 0%,
28
+ 100% {
29
+ opacity: 1;
30
+ }
31
+ 50% {
32
+ opacity: 0;
33
+ }
34
+ }
35
+
36
+ .blink {
37
+ animation: blink 0.5s step-end 5;
38
+ }
@@ -0,0 +1,36 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.default = void 0;
8
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
9
+ var _react = _interopRequireDefault(require("react"));
10
+ var _search_button = require("@svgr/webpack?&svgo=false&ref!./search_button.svg");
11
+ var FilterButton = function FilterButton(_ref) {
12
+ var onClick = _ref.onClick,
13
+ buttonState = _ref.buttonState;
14
+ var handleClick = function handleClick() {
15
+ onClick();
16
+ };
17
+ var renderButtonContent = function renderButtonContent() {
18
+ if (buttonState === '') {
19
+ return /*#__PURE__*/_react.default.createElement(_search_button.ReactComponent, null);
20
+ } else {
21
+ return /*#__PURE__*/_react.default.createElement(_search_button.ReactComponent, {
22
+ className: buttonState
23
+ });
24
+ }
25
+ };
26
+ return /*#__PURE__*/_react.default.createElement(Button, {
27
+ onClick: handleClick
28
+ }, renderButtonContent());
29
+ };
30
+ var Button = _styledComponents.default.button.withConfig({
31
+ displayName: "SearchButton__Button",
32
+ componentId: "sc-1y88igk-0"
33
+ })(["position:absolute;top:200px;right:12px;width:48px;height:48px;background-color:rgba(255,255,255,0);border-radius:50%;cursor:pointer;.filled{.lens-outline{fill:#000;stroke:#000;}line{stroke:#000;}.button-shape{fill:#ffffff;}}"]);
34
+ var _default = FilterButton;
35
+ exports.default = _default;
36
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9zZWFyY2hfYnV0dG9uIiwiRmlsdGVyQnV0dG9uIiwiX3JlZiIsIm9uQ2xpY2siLCJidXR0b25TdGF0ZSIsImhhbmRsZUNsaWNrIiwicmVuZGVyQnV0dG9uQ29udGVudCIsImRlZmF1bHQiLCJjcmVhdGVFbGVtZW50IiwiUmVhY3RDb21wb25lbnQiLCJjbGFzc05hbWUiLCJCdXR0b24iLCJzdHlsZWQiLCJidXR0b24iLCJ3aXRoQ29uZmlnIiwiZGlzcGxheU5hbWUiLCJjb21wb25lbnRJZCIsIl9kZWZhdWx0IiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9wYWdlcy9Qb2xsdXRpb25SaXNrQXNzZXNzbWVudC9TZWFyY2hCdXR0b24udHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBSZWFjdENvbXBvbmVudCBhcyBJY29uIH0gZnJvbSAnLi9zZWFyY2hfYnV0dG9uLnN2Zyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ3N0eWxlZC1jb21wb25lbnRzL21hY3JvJztcblxuaW50ZXJmYWNlIEZpbHRlckJ1dHRvblByb3BzIHtcbiAgb25DbGljazogKCkgPT4gdm9pZDtcbiAgYnV0dG9uU3RhdGU6IHN0cmluZztcbn1cblxuY29uc3QgRmlsdGVyQnV0dG9uOiBSZWFjdC5GQzxGaWx0ZXJCdXR0b25Qcm9wcz4gPSAoe1xuICBvbkNsaWNrLFxuICBidXR0b25TdGF0ZSxcbn0pID0+IHtcbiAgY29uc3QgaGFuZGxlQ2xpY2sgPSAoKSA9PiB7XG4gICAgb25DbGljaygpO1xuICB9O1xuXG4gIGNvbnN0IHJlbmRlckJ1dHRvbkNvbnRlbnQgPSAoKSA9PiB7XG4gICAgaWYgKGJ1dHRvblN0YXRlID09PSAnJykge1xuICAgICAgcmV0dXJuIDxJY29uIC8+O1xuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gPEljb24gY2xhc3NOYW1lPXtidXR0b25TdGF0ZX0gLz47XG4gICAgfVxuICB9O1xuXG4gIHJldHVybiA8QnV0dG9uIG9uQ2xpY2s9e2hhbmRsZUNsaWNrfT57cmVuZGVyQnV0dG9uQ29udGVudCgpfTwvQnV0dG9uPjtcbn07XG5cbmNvbnN0IEJ1dHRvbiA9IHN0eWxlZC5idXR0b25gXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgdG9wOiAyMDBweDtcbiAgcmlnaHQ6IDEycHg7XG4gIHdpZHRoOiA0OHB4O1xuICBoZWlnaHQ6IDQ4cHg7XG4gIGJhY2tncm91bmQtY29sb3I6IHJnYmEoMjU1LCAyNTUsIDI1NSwgMCk7XG4gIGJvcmRlci1yYWRpdXM6IDUwJTtcbiAgY3Vyc29yOiBwb2ludGVyO1xuXG4gIC5maWxsZWQge1xuICAgIC5sZW5zLW91dGxpbmUge1xuICAgICAgZmlsbDogIzAwMDtcbiAgICAgIHN0cm9rZTogIzAwMDtcbiAgICB9XG4gICAgbGluZSB7XG4gICAgICBzdHJva2U6ICMwMDA7XG4gICAgfVxuICAgIC5idXR0b24tc2hhcGUge1xuICAgICAgZmlsbDogI2ZmZmZmZjtcbiAgICB9XG4gIH1cbmA7XG5cbmV4cG9ydCBkZWZhdWx0IEZpbHRlckJ1dHRvbjtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFBQSxJQUFBQSxNQUFBLEdBQUFDLHNCQUFBLENBQUFDLE9BQUE7QUFBMEIsSUFBQUMsY0FBQSxHQUFBRCxPQUFBO0FBUzFCLElBQU1FLFlBQXlDLEdBQUcsU0FBNUNBLFlBQXlDQSxDQUFBQyxJQUFBLEVBR3pDO0VBQUEsSUFGSkMsT0FBTyxHQUFBRCxJQUFBLENBQVBDLE9BQU87SUFDUEMsV0FBVyxHQUFBRixJQUFBLENBQVhFLFdBQVc7RUFFWCxJQUFNQyxXQUFXLEdBQUcsU0FBZEEsV0FBV0EsQ0FBQSxFQUFTO0lBQ3hCRixPQUFPLENBQUMsQ0FBQztFQUNYLENBQUM7RUFFRCxJQUFNRyxtQkFBbUIsR0FBRyxTQUF0QkEsbUJBQW1CQSxDQUFBLEVBQVM7SUFDaEMsSUFBSUYsV0FBVyxLQUFLLEVBQUUsRUFBRTtNQUN0QixvQkFBT1AsTUFBQSxDQUFBVSxPQUFBLENBQUFDLGFBQUEsQ0FBQ1IsY0FBQSxDQUFBUyxjQUFJLE1BQUUsQ0FBQztJQUNqQixDQUFDLE1BQU07TUFDTCxvQkFBT1osTUFBQSxDQUFBVSxPQUFBLENBQUFDLGFBQUEsQ0FBQ1IsY0FBQSxDQUFBUyxjQUFJO1FBQUNDLFNBQVMsRUFBRU47TUFBWSxDQUFFLENBQUM7SUFDekM7RUFDRixDQUFDO0VBRUQsb0JBQU9QLE1BQUEsQ0FBQVUsT0FBQSxDQUFBQyxhQUFBLENBQUNHLE1BQU07SUFBQ1IsT0FBTyxFQUFFRTtFQUFZLEdBQUVDLG1CQUFtQixDQUFDLENBQVUsQ0FBQztBQUN2RSxDQUFDO0FBRUQsSUFBTUssTUFBTSxHQUFHQyx5QkFBTSxDQUFDQyxNQUFNLENBQUFDLFVBQUE7RUFBQUMsV0FBQTtFQUFBQyxXQUFBO0FBQUEsd09Bc0IzQjtBQUFDLElBQUFDLFFBQUEsR0FFYWhCLFlBQVk7QUFBQWlCLE9BQUEsQ0FBQVgsT0FBQSxHQUFBVSxRQUFBIn0=
@@ -0,0 +1,82 @@
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 _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/slicedToArray"));
10
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
11
+ var _react = _interopRequireWildcard(require("react"));
12
+ 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); }
13
+ 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; }
14
+ var SearchField = function SearchField(_ref) {
15
+ var suggestions = _ref.suggestions,
16
+ zoomToPoint = _ref.zoomToPoint,
17
+ clickOnMarker = _ref.clickOnMarker,
18
+ setIsSearchFieldVisible = _ref.setIsSearchFieldVisible;
19
+ var _useState = (0, _react.useState)(''),
20
+ _useState2 = (0, _slicedToArray2.default)(_useState, 2),
21
+ query = _useState2[0],
22
+ setQuery = _useState2[1];
23
+ var _useState3 = (0, _react.useState)([]),
24
+ _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
25
+ filteredSuggestions = _useState4[0],
26
+ setFilteredSuggestions = _useState4[1];
27
+ (0, _react.useEffect)(function () {
28
+ if (query.length > 0) {
29
+ var filtered = suggestions.filter(function (suggestion) {
30
+ return suggestion.name && suggestion.name.toLowerCase().includes(query.toLowerCase());
31
+ });
32
+ setFilteredSuggestions(filtered);
33
+ } else {
34
+ setFilteredSuggestions([]);
35
+ }
36
+ }, [query, suggestions]);
37
+ var handleInputChange = function handleInputChange(e) {
38
+ setQuery(e.target.value);
39
+ };
40
+ var handleSuggestionClick = function handleSuggestionClick(suggestion) {
41
+ setQuery('');
42
+ setFilteredSuggestions([]);
43
+ setIsSearchFieldVisible(false);
44
+ zoomToPoint(suggestion.lat, suggestion.lng);
45
+ // wrap with timeout to allow the map to zoom before clicking on the marker
46
+ setTimeout(function () {
47
+ clickOnMarker(suggestion.lat, suggestion.lng);
48
+ }, 300);
49
+ };
50
+ return /*#__PURE__*/_react.default.createElement(SearchFieldContainer, null, /*#__PURE__*/_react.default.createElement(SearchInput, {
51
+ type: "text",
52
+ value: query,
53
+ onChange: handleInputChange,
54
+ placeholder: "Search for Facilities..."
55
+ }), filteredSuggestions.length > 0 && /*#__PURE__*/_react.default.createElement(SuggestionsList, null, filteredSuggestions.map(function (suggestion) {
56
+ return /*#__PURE__*/_react.default.createElement(SuggestionItem, {
57
+ key: suggestion.id,
58
+ onClick: function onClick() {
59
+ return handleSuggestionClick(suggestion);
60
+ }
61
+ }, suggestion.name);
62
+ })));
63
+ };
64
+ var _default = SearchField;
65
+ exports.default = _default;
66
+ var SearchFieldContainer = _styledComponents.default.div.withConfig({
67
+ displayName: "SearchField__SearchFieldContainer",
68
+ componentId: "sc-1jccnxa-0"
69
+ })(["position:absolute;top:10px;left:50%;transform:translateX(-50%);z-index:2000;width:300px;background:rgba(255,255,255,0.7);border-radius:8px;padding:10px;box-shadow:0 4px 8px rgba(0,0,0,0.1);"]);
70
+ var SearchInput = _styledComponents.default.input.withConfig({
71
+ displayName: "SearchField__SearchInput",
72
+ componentId: "sc-1jccnxa-1"
73
+ })(["padding:5px;width:100%;border:none;background:transparent;color:#000;&:focus{outline:none;}"]);
74
+ var SuggestionsList = _styledComponents.default.ul.withConfig({
75
+ displayName: "SearchField__SuggestionsList",
76
+ componentId: "sc-1jccnxa-2"
77
+ })(["position:absolute;top:100%;left:0;right:0;background:rgba(255,255,255,0.8);border-radius:8px;max-height:200px;overflow-y:auto;list-style:none;padding:0;margin:0;z-index:1000;"]);
78
+ var SuggestionItem = _styledComponents.default.li.withConfig({
79
+ displayName: "SearchField__SuggestionItem",
80
+ componentId: "sc-1jccnxa-3"
81
+ })(["padding:10px;cursor:pointer;&:hover{background:rgba(0,0,0,0.1);}"]);
82
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","SearchField","_ref","suggestions","zoomToPoint","clickOnMarker","setIsSearchFieldVisible","_useState","useState","_useState2","_slicedToArray2","query","setQuery","_useState3","_useState4","filteredSuggestions","setFilteredSuggestions","useEffect","length","filtered","filter","suggestion","name","toLowerCase","includes","handleInputChange","e","target","value","handleSuggestionClick","lat","lng","setTimeout","createElement","SearchFieldContainer","SearchInput","type","onChange","placeholder","SuggestionsList","map","SuggestionItem","id","onClick","_default","exports","styled","div","withConfig","displayName","componentId","input","ul","li"],"sources":["../../../src/pages/PollutionRiskAssessment/SearchField.tsx"],"sourcesContent":["import React, { useState, useEffect } from 'react';\nimport styled from 'styled-components/macro';\nimport { IGeoPoint } from 'src/store/points/models/IGeoPoint';\n\ninterface SearchFieldProps {\n  suggestions: IGeoPoint[];\n  zoomToPoint: (lat: number, lng: number) => void;\n  clickOnMarker: (lat: number, lng: number) => void;\n  setIsSearchFieldVisible: (isVisible: boolean) => void;\n  closePopup: () => void;\n}\n\nconst SearchField: React.FC<SearchFieldProps> = ({\n  suggestions,\n  zoomToPoint,\n  clickOnMarker,\n  setIsSearchFieldVisible,\n}) => {\n  const [query, setQuery] = useState('');\n  const [filteredSuggestions, setFilteredSuggestions] = useState<IGeoPoint[]>(\n    [],\n  );\n\n  useEffect(() => {\n    if (query.length > 0) {\n      const filtered = suggestions.filter(\n        (suggestion) =>\n          suggestion.name &&\n          suggestion.name.toLowerCase().includes(query.toLowerCase()),\n      );\n      setFilteredSuggestions(filtered);\n    } else {\n      setFilteredSuggestions([]);\n    }\n  }, [query, suggestions]);\n\n  const handleInputChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n    setQuery(e.target.value);\n  };\n\n  const handleSuggestionClick = (suggestion: IGeoPoint) => {\n    setQuery('');\n    setFilteredSuggestions([]);\n    setIsSearchFieldVisible(false);\n    zoomToPoint(suggestion.lat, suggestion.lng);\n    // wrap with timeout to allow the map to zoom before clicking on the marker\n    setTimeout(() => {\n      clickOnMarker(suggestion.lat, suggestion.lng);\n    }, 300);\n  };\n\n  return (\n    <SearchFieldContainer>\n      <SearchInput\n        type=\"text\"\n        value={query}\n        onChange={handleInputChange}\n        placeholder=\"Search for Facilities...\"\n      />\n      {filteredSuggestions.length > 0 && (\n        <SuggestionsList>\n          {filteredSuggestions.map((suggestion) => (\n            <SuggestionItem\n              key={suggestion.id}\n              onClick={() => handleSuggestionClick(suggestion)}\n            >\n              {suggestion.name}\n            </SuggestionItem>\n          ))}\n        </SuggestionsList>\n      )}\n    </SearchFieldContainer>\n  );\n};\n\nexport default SearchField;\n\nconst SearchFieldContainer = styled.div`\n  position: absolute;\n  top: 10px;\n  left: 50%;\n  transform: translateX(-50%);\n  z-index: 2000;\n  width: 300px;\n  background: rgba(255, 255, 255, 0.7);\n  border-radius: 8px;\n  padding: 10px;\n  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);\n`;\n\nconst SearchInput = styled.input`\n  padding: 5px;\n  width: 100%;\n  border: none;\n  background: transparent;\n  color: #000;\n  &:focus {\n    outline: none;\n  }\n`;\n\nconst SuggestionsList = styled.ul`\n  position: absolute;\n  top: 100%;\n  left: 0;\n  right: 0;\n  background: rgba(255, 255, 255, 0.8);\n  border-radius: 8px;\n  max-height: 200px;\n  overflow-y: auto;\n  list-style: none;\n  padding: 0;\n  margin: 0;\n  z-index: 1000;\n`;\n\nconst SuggestionItem = styled.li`\n  padding: 10px;\n  cursor: pointer;\n  &:hover {\n    background: rgba(0, 0, 0, 0.1);\n  }\n`;\n"],"mappings":"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"}
@@ -10,12 +10,11 @@ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"))
10
10
  var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/asyncToGenerator"));
11
11
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/slicedToArray"));
12
12
  var _styledComponents = _interopRequireDefault(require("styled-components"));
13
- require("bootstrap/dist/css/bootstrap.min.css");
14
13
  var _react = _interopRequireWildcard(require("react"));
15
14
  var _reactRedux = require("react-redux");
16
15
  var _actions = require("store/context/actions");
17
16
  var _Analytics = require("../../utilities/Analytics");
18
- var _Map = require("./Map");
17
+ var _Map = _interopRequireDefault(require("./Map"));
19
18
  var _useNavContext2 = require("../../hooks/useNavContext");
20
19
  var _KandoBottomSheet = _interopRequireDefault(require("../../ui-kit/KandoBottomSheet/KandoBottomSheet"));
21
20
  var _urls = require("../../utilities/urls");
@@ -25,6 +24,8 @@ var _FilterBehaviors = require("./FilterBehaviors");
25
24
  var _FilterButton = _interopRequireDefault(require("./FilterButton"));
26
25
  var _use_cases = _interopRequireDefault(require("./use_cases.json"));
27
26
  var _KandoAlert = require("ui-kit/Alert/KandoAlert");
27
+ var _SearchField = _interopRequireDefault(require("./SearchField"));
28
+ var _SearchButton = _interopRequireDefault(require("./SearchButton"));
28
29
  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
30
  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
31
  var PollutionRiskAssessment = function PollutionRiskAssessment() {
@@ -60,6 +61,11 @@ var PollutionRiskAssessment = function PollutionRiskAssessment() {
60
61
  _useState12 = (0, _slicedToArray2.default)(_useState11, 2),
61
62
  mapBounds = _useState12[0],
62
63
  setMapBounds = _useState12[1];
64
+ var _useState13 = (0, _react.useState)(false),
65
+ _useState14 = (0, _slicedToArray2.default)(_useState13, 2),
66
+ isSearchFieldVisible = _useState14[0],
67
+ setIsSearchFieldVisible = _useState14[1];
68
+ var mapRef = (0, _react.useRef)(null);
63
69
  var handleDismiss = function handleDismiss() {
64
70
  setShownContent('total_savings');
65
71
  };
@@ -225,12 +231,35 @@ var PollutionRiskAssessment = function PollutionRiskAssessment() {
225
231
  return prevContent === 'filter_behaviors' ? 'total_savings' : 'filter_behaviors';
226
232
  });
227
233
  };
234
+ var searchButtonClick = function searchButtonClick() {
235
+ setIsSearchFieldVisible(function (prevVisible) {
236
+ return !prevVisible;
237
+ });
238
+ closePopup();
239
+ };
228
240
  var filterButtonState = (0, _react.useMemo)(function () {
229
241
  if (shownContent === 'filter_behaviors') {
230
242
  return 'filled';
231
243
  }
232
244
  return useCasesFilter !== '' ? 'filled-red' : '';
233
245
  }, [shownContent, useCasesFilter]);
246
+ var zoomToPoint = function zoomToPoint(lat, lng) {
247
+ if (mapRef.current) {
248
+ mapRef.current.zoomToPoint(lat, lng); // Set to max zoom level 18
249
+ }
250
+ };
251
+
252
+ var clickOnMarker = function clickOnMarker(lat, lng) {
253
+ if (mapRef.current) {
254
+ mapRef.current.clickOnMarker(lat, lng); // Set to max zoom level 18
255
+ }
256
+ };
257
+
258
+ var closePopup = function closePopup() {
259
+ if (mapRef.current) {
260
+ mapRef.current.closePopup();
261
+ }
262
+ };
234
263
  if (!pointsData || !polygonData) return null;
235
264
  if (!(polygonData === null || polygonData === void 0 ? void 0 : polygonData.id)) {
236
265
  return /*#__PURE__*/_react.default.createElement(_KandoAlert.KandoAlert, {
@@ -244,16 +273,25 @@ var PollutionRiskAssessment = function PollutionRiskAssessment() {
244
273
  className: "app-wrapper"
245
274
  }, /*#__PURE__*/_react.default.createElement(MapTableContainer, {
246
275
  isRtl: isRtl
247
- }, /*#__PURE__*/_react.default.createElement(_Map.Map, {
276
+ }, /*#__PURE__*/_react.default.createElement(_Map.default, {
277
+ ref: mapRef,
248
278
  filteredUseCase: useCase ? useCase : {
249
279
  code: 'to'
250
280
  },
251
281
  points: pointsData,
252
282
  polygon: getPolygonGeoJSON(polygonData),
253
283
  onBoundsChange: handleBoundsChange
254
- })), bottomSheet, /*#__PURE__*/_react.default.createElement(_FilterButton.default, {
284
+ }), isSearchFieldVisible && /*#__PURE__*/_react.default.createElement(SearchFieldContainer, null, /*#__PURE__*/_react.default.createElement(_SearchField.default, {
285
+ suggestions: pointsData,
286
+ zoomToPoint: zoomToPoint,
287
+ clickOnMarker: clickOnMarker,
288
+ setIsSearchFieldVisible: setIsSearchFieldVisible
289
+ }))), bottomSheet, /*#__PURE__*/_react.default.createElement(_FilterButton.default, {
255
290
  buttonState: filterButtonState,
256
291
  onClick: filterButtonClick
292
+ }), /*#__PURE__*/_react.default.createElement(_SearchButton.default, {
293
+ buttonState: isSearchFieldVisible ? 'filled' : '',
294
+ onClick: searchButtonClick
257
295
  }));
258
296
  };
259
297
  var _default = PollutionRiskAssessment;
@@ -262,4 +300,8 @@ var MapTableContainer = _styledComponents.default.div.withConfig({
262
300
  displayName: "PollutionRiskAssessment__MapTableContainer",
263
301
  componentId: "sc-peb1i1-0"
264
302
  })(["position:fixed;top:65px;height:calc(100vh - 20px);width:100vw;#map{height:100%;width:100%;*,*:focus,*:hover{outline:none;}}"]);
265
- //# 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","_KandoAlert","_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","maxIntervals","interval","intercomElement","setInterval","document","querySelector","style","display","clearInterval","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","KandoAlert","variant","header","href","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';\nimport { KandoAlert } from 'src/ui-kit/Alert/KandoAlert';\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 && waterAuthorityName) {\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, waterAuthorityName]);\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  useEffect(() => {\n    const maxIntervals = 5;\n    let interval = maxIntervals;\n    let intercomElement;\n\n    const id = setInterval(() => {\n      interval -= 1;\n      intercomElement = document.querySelector('.intercom-lightweight-app');\n      if (intercomElement) {\n        if (intercomElement.style.display === 'none') {\n          clearInterval(id);\n        } else {\n          intercomElement.style.display = 'none';\n        }\n      }\n\n      if (interval <= 0) {\n        clearInterval(id);\n      }\n    }, 300);\n\n    return () => {\n      if (intercomElement) {\n        intercomElement.style.display = '';\n      }\n    };\n  }, []);\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            164,\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  if (!polygonData?.id) {\n    return (\n      <KandoAlert variant=\"danger\" header={'Heads up!'}>\n        <p>\n          {'No saved city found.'}\n          <br />\n          {'If you need assistance, please '}\n          <a href=\"mailto:support@kando.eco\">{'send us a message.'}</a>\n        </p>\n      </KandoAlert>\n    );\n  }\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":";;;;;;;;;;;;AAAAA,OAAA;AACA,IAAAC,MAAA,GAAAC,uBAAA,CAAAF,OAAA;AACA,IAAAG,WAAA,GAAAH,OAAA;AACA,IAAAI,QAAA,GAAAJ,OAAA;AACA,IAAAK,UAAA,GAAAL,OAAA;AACA,IAAAM,IAAA,GAAAN,OAAA;AAEA,IAAAO,eAAA,GAAAP,OAAA;AACA,IAAAQ,iBAAA,GAAAC,sBAAA,CAAAT,OAAA;AACA,IAAAU,KAAA,GAAAV,OAAA;AAGAA,OAAA;AACA,IAAAW,aAAA,GAAAX,OAAA;AACA,IAAAY,gBAAA,GAAAZ,OAAA;AACA,IAAAa,aAAA,GAAAJ,sBAAA,CAAAT,OAAA;AACA,IAAAc,UAAA,GAAAL,sBAAA,CAAAT,OAAA;AACA,IAAAe,WAAA,GAAAf,OAAA;AAAyD,SAAAgB,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,SAAAf,wBAAAmB,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;AAEzD,IAAMW,uBAAiC,GAAG,SAApCA,uBAAiCA,CAAA,EAAS;EAC9C,IAAMC,kBAAkB,GAAG,IAAAC,uBAAW,EACpC,UAACC,KAAK;IAAA,OAAKA,KAAK,CAACC,WAAW,CAACH,kBAAkB;EAAA,CACjD,CAAC;EACD,IAAMI,gBAAgB,GAAG,IAAAH,uBAAW,EAClC,UAACC,KAAK;IAAA,OAAKA,KAAK,CAACC,WAAW,CAACC,gBAAgB;EAAA,CAC/C,CAAC;EACD,IAAAC,SAAA,GAAsC,IAAAC,eAAQ,EAAU,CAAC;IAAAC,UAAA,OAAAC,eAAA,CAAAxB,OAAA,EAAAqB,SAAA;IAAlDI,WAAW,GAAAF,UAAA;IAAEG,cAAc,GAAAH,UAAA;EAClC,IAAAI,UAAA,GAAoC,IAAAL,eAAQ,EAAc,CAAC;IAAAM,UAAA,OAAAJ,eAAA,CAAAxB,OAAA,EAAA2B,UAAA;IAApDE,UAAU,GAAAD,UAAA;IAAEE,aAAa,GAAAF,UAAA;EAChC,IAAAG,cAAA,GAAkB,IAAAC,6BAAa,EAAC,CAAC;IAAzBC,KAAK,GAAAF,cAAA,CAALE,KAAK;EACb,IAAAC,UAAA,GAAwC,IAAAZ,eAAQ,EAAC,eAAe,CAAC;IAAAa,UAAA,OAAAX,eAAA,CAAAxB,OAAA,EAAAkC,UAAA;IAA1DE,YAAY,GAAAD,UAAA;IAAEE,eAAe,GAAAF,UAAA;EACpC,IAAAG,UAAA,GAA0C,IAAAhB,eAAQ,EAAc,EAAE,CAAC;IAAAiB,UAAA,OAAAf,eAAA,CAAAxB,OAAA,EAAAsC,UAAA;IAA5DE,aAAa,GAAAD,UAAA;IAAEE,gBAAgB,GAAAF,UAAA;EACtC,IAAAG,UAAA,GAA4C,IAAApB,eAAQ,EAAC,EAAE,CAAC;IAAAqB,WAAA,OAAAnB,eAAA,CAAAxB,OAAA,EAAA0C,UAAA;IAAjDE,cAAc,GAAAD,WAAA;IAAEE,iBAAiB,GAAAF,WAAA;EACxC,IAAAG,WAAA,GAAkC,IAAAxB,eAAQ,EAAwB,IAAI,CAAC;IAAAyB,WAAA,OAAAvB,eAAA,CAAAxB,OAAA,EAAA8C,WAAA;IAAhEE,SAAS,GAAAD,WAAA;IAAEE,YAAY,GAAAF,WAAA;EAE9B,IAAMG,aAAa,GAAG,SAAhBA,aAAaA,CAAA,EAAS;IAC1Bb,eAAe,CAAC,eAAe,CAAC;EAClC,CAAC;EAED,IAAMc,QAAQ,GAAG,IAAAC,uBAAW,EAAC,CAAC;EAC9B,IAAMC,SAAS;IAAA,IAAAC,IAAA,OAAAC,kBAAA,CAAAvD,OAAA,gBAAAwD,YAAA,CAAAxD,OAAA,CAAAyD,IAAA,CAAG,SAAAC,QAChBC,GAAW,EACXC,OAAgD;MAAA,IAAAC,QAAA,EAAAC,MAAA;MAAA,OAAAN,YAAA,CAAAxD,OAAA,CAAA+D,IAAA,UAAAC,SAAAC,QAAA;QAAA;UAAA,QAAAA,QAAA,CAAAC,IAAA,GAAAD,QAAA,CAAAE,IAAA;YAAA;cAAAF,QAAA,CAAAC,IAAA;cAAAD,QAAA,CAAAE,IAAA;cAAA,OAGvBC,KAAK,CAACT,GAAG,CAAC;YAAA;cAA3BE,QAAQ,GAAAI,QAAA,CAAAI,IAAA;cAAAJ,QAAA,CAAAE,IAAA;cAAA,OACON,QAAQ,CAACS,IAAI,CAAC,CAAC;YAAA;cAA9BR,MAAM,GAAAG,QAAA,CAAAI,IAAA;cACZT,OAAO,CAACE,MAAM,CAAC;cAACG,QAAA,CAAAE,IAAA;cAAA;YAAA;cAAAF,QAAA,CAAAC,IAAA;cAAAD,QAAA,CAAAM,EAAA,GAAAN,QAAA;cAEhBO,OAAO,CAACC,KAAK,8BAAAC,MAAA,CAA8Bf,GAAG,QAAAM,QAAA,CAAAM,EAAU,CAAC;YAAC;YAAA;cAAA,OAAAN,QAAA,CAAAU,IAAA;UAAA;QAAA;MAAA,GAAAjB,OAAA;IAAA,CAE7D;IAAA,gBAXKL,SAASA,CAAAuB,EAAA,EAAAC,GAAA;MAAA,OAAAvB,IAAA,CAAAwB,KAAA,OAAAC,SAAA;IAAA;EAAA,GAWd;;EAED;EACA,IAAAC,gBAAS,EAAC,YAAM;IACdC,UAAU,CAAC,YAAM;MACf/B,aAAa,CAAC,CAAC;IACjB,CAAC,EAAE,GAAG,CAAC;EACT,CAAC,EAAE,CAACN,cAAc,CAAC,CAAC;EAEpB,IAAAoC,gBAAS,EAAC,YAAM;IACd,IAAI5D,gBAAgB,IAAIJ,kBAAkB,EAAE;MAC1C,IAAMkE,iBAAiB,GAAG,IAAAC,UAAI,EAAC;QAAE/D,gBAAgB,EAAhBA;MAAiB,CAAC,CAAC,CACjDL,uBAAuB,CAACqE,cAAc;MACzC/B,SAAS,CAAC6B,iBAAiB,EAAExD,cAAc,CAAC;MAE5C,IAAA2D,yBAAc,EAAC,uCAAuC,EAAE;QACtDC,YAAY,EAAEtE;MAChB,CAAC,CAAC;MACFmC,QAAQ,CAAC,IAAAoC,yBAAgB,EAAC;QAAEC,IAAI,EAAE;MAA4B,CAAC,CAAC,CAAC;IACnE;EACF,CAAC,EAAE,CAACpE,gBAAgB,EAAEJ,kBAAkB,CAAC,CAAC;EAE1C,IAAMyE,iBAAiB,GAAG,SAApBA,iBAAiBA,CAAIhE,WAAW,EAAK;IACzC,IAAI;MACF,OAAO,CAAAA,WAAW,aAAXA,WAAW,uBAAXA,WAAW,CAAEiE,OAAO,IAAGC,IAAI,CAACC,KAAK,CAACnE,WAAW,CAACiE,OAAO,CAAC,GAAG,EAAE;IACpE,CAAC,CAAC,OAAOjB,KAAK,EAAE;MACdD,OAAO,CAACC,KAAK,CAAC,+BAA+B,EAAEA,KAAK,CAAC;MACrD,OAAO,EAAE;IACX;EACF,CAAC;EAED,IAAAO,gBAAS,EAAC,YAAM;IACd,IAAI,CAACvD,WAAW,EAAE;IAElB,IAAMoE,YAAY,GAAG,IAAAV,UAAI,EAAC;MACxB/D,gBAAgB,EAAEA,gBAAgB;MAClC0E,EAAE,EAAErE,WAAW,aAAXA,WAAW,uBAAXA,WAAW,CAAEqE;IACnB,CAAC,CAAC,CAAC/E,uBAAuB,CAACgF,SAAS;IAEpC1C,SAAS,CAACwC,YAAY,EAAE/D,aAAa,CAAC;EACxC,CAAC,EAAE,CAACL,WAAW,CAAC,CAAC;EAEjB,IAAAuD,gBAAS,EAAC,YAAM;IACd,IAAMgB,YAAY,GAAG,CAAC;IACtB,IAAIC,QAAQ,GAAGD,YAAY;IAC3B,IAAIE,eAAe;IAEnB,IAAMJ,EAAE,GAAGK,WAAW,CAAC,YAAM;MAC3BF,QAAQ,IAAI,CAAC;MACbC,eAAe,GAAGE,QAAQ,CAACC,aAAa,CAAC,2BAA2B,CAAC;MACrE,IAAIH,eAAe,EAAE;QACnB,IAAIA,eAAe,CAACI,KAAK,CAACC,OAAO,KAAK,MAAM,EAAE;UAC5CC,aAAa,CAACV,EAAE,CAAC;QACnB,CAAC,MAAM;UACLI,eAAe,CAACI,KAAK,CAACC,OAAO,GAAG,MAAM;QACxC;MACF;MAEA,IAAIN,QAAQ,IAAI,CAAC,EAAE;QACjBO,aAAa,CAACV,EAAE,CAAC;MACnB;IACF,CAAC,EAAE,GAAG,CAAC;IAEP,OAAO,YAAM;MACX,IAAII,eAAe,EAAE;QACnBA,eAAe,CAACI,KAAK,CAACC,OAAO,GAAG,EAAE;MACpC;IACF,CAAC;EACH,CAAC,EAAE,EAAE,CAAC;EAEN,IAAME,OAAO,GAAGC,kBAAQ,CAACC,IAAI,CAAC,UAACF,OAAO;IAAA,OAAKA,OAAO,CAACX,EAAE,KAAKlD,cAAc;EAAA,EAAC;EAEzE,IAAMgE,oBAAoB,GAAG,SAAvBA,oBAAoBA,CAAA,EAAS;IACjC,QAAQxE,YAAY;MAClB,KAAK,eAAe;QAClB,OAAO;UACLyE,OAAO,eACLpI,MAAA,CAAAuB,OAAA,CAAA8G,aAAA,CAAC3H,aAAA,CAAA4H,YAAY;YAACC,MAAM,EAAExE,aAAc;YAACyE,eAAe,EAAER;UAAQ,CAAE,CACjE;UACDS,UAAU,EAAE,SAAAA,WAAAC,KAAA;YAAA,IAAGC,SAAS,GAAAD,KAAA,CAATC,SAAS;YAAA,OAA8B,CACpD,GAAG,EACHA,SAAS,GAAG,GAAG,CAChB;UAAA;UACDC,eAAe,EAAE;QACnB,CAAC;MACH,KAAK,kBAAkB;QACrB,OAAO;UACLR,OAAO,eACLpI,MAAA,CAAAuB,OAAA,CAAA8G,aAAA,CAAC1H,gBAAA,CAAAkI,eAAe;YACdC,YAAY,EAAE3E,cAAe;YAC7B4E,YAAY,EAAE3E;UAAkB,CACjC,CACF;UACDqE,UAAU,EAAE,SAAAA,WAAAO,KAAA;YAAA,IAAGL,SAAS,GAAAK,KAAA,CAATL,SAAS;YAAA,OAA8B,CACpDA,SAAS,GAAG,GAAG,CAChB;UAAA;UACDC,eAAe,EAAE;QACnB,CAAC;MACH;QACE,OAAO;UACLR,OAAO,EAAE,IAAI;UACbK,UAAU,EAAE,SAAAA,WAAA;YAAA,OAAM,CAAC,CAAC,CAAC;UAAA;UACrBG,eAAe,EAAE;QACnB,CAAC;IACL;EACF,CAAC;EAED,IAAAK,QAAA,GAAiD,IAAAC,cAAO,EACtDf,oBAAoB,EACpB,CAACxE,YAAY,EAAEQ,cAAc,EAAEJ,aAAa,CAC9C,CAAC;IAHOqE,OAAO,GAAAa,QAAA,CAAPb,OAAO;IAAEK,UAAU,GAAAQ,QAAA,CAAVR,UAAU;IAAEG,eAAe,GAAAK,QAAA,CAAfL,eAAe;EAK5C,IAAMO,WAAW,GAAG,IAAAD,cAAO,EAAC,YAAM;IAChC,oBACElJ,MAAA,CAAAuB,OAAA,CAAA8G,aAAA,CAAC9H,iBAAA,CAAAgB,OAAgB;MACfqH,eAAe,EAAEA,eAAgB;MACjCH,UAAU,EAAEA,UAAW;MACvBW,SAAS,EAAE3E,aAAc;MACzB4E,MAAM,EAAE;IAAK,GAEZjB,OACe,CAAC;EAEvB,CAAC,EAAE,CAACrE,aAAa,EAAEJ,YAAY,CAAC,CAAC;EAEjC,IAAA4C,gBAAS,EAAC,YAAM;IACd,IAAI,CAAChC,SAAS,IAAI,CAACnB,UAAU,EAAE;IAE/B,IAAMkG,cAAc,GAAGlG,UAAU,CAACmG,MAAM,CAAC,UAACC,KAAK,EAAK;MAClD,OACEA,KAAK,CAACC,GAAG,IAAIlF,SAAS,CAACmF,YAAY,CAAC,CAAC,CAACD,GAAG,IACzCD,KAAK,CAACC,GAAG,IAAIlF,SAAS,CAACoF,YAAY,CAAC,CAAC,CAACF,GAAG,IACzCD,KAAK,CAACI,GAAG,IAAIrF,SAAS,CAACmF,YAAY,CAAC,CAAC,CAACE,GAAG,IACzCJ,KAAK,CAACI,GAAG,IAAIrF,SAAS,CAACoF,YAAY,CAAC,CAAC,CAACC,GAAG;IAE7C,CAAC,CAAC;IAEF5F,gBAAgB,CAACsF,cAAc,CAAC;EAClC,CAAC,EAAE,CAAC/E,SAAS,EAAEnB,UAAU,CAAC,CAAC;EAE3B,IAAMyG,kBAAkB,GAAG,IAAAC,kBAAW,EAAC,UAACC,MAAM,EAAK;IACjDvF,YAAY,CAACuF,MAAM,CAAC;EACtB,CAAC,EAAE,EAAE,CAAC;EAEN,IAAMC,iBAAiB,GAAG,SAApBA,iBAAiBA,CAAA,EAAS;IAC9BpG,eAAe,CAAC,UAACqG,WAAW;MAAA,OAC1BA,WAAW,KAAK,kBAAkB,GAAG,eAAe,GAAG,kBAAkB;IAAA,CAC3E,CAAC;EACH,CAAC;EAED,IAAMC,iBAAiB,GAAG,IAAAhB,cAAO,EAAC,YAAM;IACtC,IAAIvF,YAAY,KAAK,kBAAkB,EAAE;MACvC,OAAO,QAAQ;IACjB;IACA,OAAOQ,cAAc,KAAK,EAAE,GAAG,YAAY,GAAG,EAAE;EAClD,CAAC,EAAE,CAACR,YAAY,EAAEQ,cAAc,CAAC,CAAC;EAElC,IAAI,CAACf,UAAU,IAAI,CAACJ,WAAW,EAAE,OAAO,IAAI;EAE5C,IAAI,EAACA,WAAW,aAAXA,WAAW,uBAAXA,WAAW,CAAEqE,EAAE,GAAE;IACpB,oBACErH,MAAA,CAAAuB,OAAA,CAAA8G,aAAA,CAACvH,WAAA,CAAAqJ,UAAU;MAACC,OAAO,EAAC,QAAQ;MAACC,MAAM,EAAE;IAAY,gBAC/CrK,MAAA,CAAAuB,OAAA,CAAA8G,aAAA,YACG,sBAAsB,eACvBrI,MAAA,CAAAuB,OAAA,CAAA8G,aAAA,WAAK,CAAC,EACL,iCAAiC,eAClCrI,MAAA,CAAAuB,OAAA,CAAA8G,aAAA;MAAGiC,IAAI,EAAC;IAA0B,GAAE,oBAAwB,CAC3D,CACO,CAAC;EAEjB;EAEA,oBACEtK,MAAA,CAAAuB,OAAA,CAAA8G,aAAA;IAAKkC,SAAS,EAAC;EAAa,gBAC1BvK,MAAA,CAAAuB,OAAA,CAAA8G,aAAA,CAACmC,iBAAiB;IAAChH,KAAK,EAAEA;EAAM,gBAC9BxD,MAAA,CAAAuB,OAAA,CAAA8G,aAAA,CAAChI,IAAA,CAAAoK,GAAG;IACFjC,eAAe,EAAER,OAAO,GAAGA,OAAO,GAAG;MAAE0C,IAAI,EAAE;IAAK,CAAE;IACpDnC,MAAM,EAAEnF,UAAW;IACnB6D,OAAO,EAAED,iBAAiB,CAAChE,WAAW,CAAE;IACxC2H,cAAc,EAAEd;EAAmB,CACpC,CACgB,CAAC,EACnBV,WAAW,eACZnJ,MAAA,CAAAuB,OAAA,CAAA8G,aAAA,CAACzH,aAAA,CAAAW,OAAY;IACXqJ,WAAW,EAAEV,iBAAkB;IAC/BW,OAAO,EAAEb;EAAkB,CAC5B,CACE,CAAC;AAEV,CAAC;AAAC,IAAAc,QAAA,GAEaxI,uBAAuB;AAAAyI,OAAA,CAAAxJ,OAAA,GAAAuJ,QAAA;AAEtC,IAAMN,iBAAiB,GAAGQ,yBAAM,CAACC,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,mIAgBnC"}
303
+ var SearchFieldContainer = _styledComponents.default.div.withConfig({
304
+ displayName: "PollutionRiskAssessment__SearchFieldContainer",
305
+ componentId: "sc-peb1i1-1"
306
+ })(["position:absolute;top:10px;left:50%;transform:translateX(-50%);z-index:2000;width:300px;background:rgba(255,255,255,0);border-radius:8px;padding:10px;"]);
307
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRedux","_actions","_Analytics","_Map","_interopRequireDefault","_useNavContext2","_KandoBottomSheet","_urls","_TotalSavings","_FilterBehaviors","_FilterButton","_use_cases","_KandoAlert","_SearchField","_SearchButton","_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","isSearchFieldVisible","setIsSearchFieldVisible","mapRef","useRef","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","maxIntervals","interval","intercomElement","setInterval","document","querySelector","style","display","clearInterval","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","searchButtonClick","prevVisible","closePopup","filterButtonState","zoomToPoint","current","clickOnMarker","KandoAlert","variant","header","href","className","MapTableContainer","ref","code","onBoundsChange","SearchFieldContainer","suggestions","buttonState","onClick","_default","exports","styled","div","withConfig","displayName","componentId"],"sources":["../../../src/pages/PollutionRiskAssessment/index.tsx"],"sourcesContent":["import React, {\n  useCallback,\n  useEffect,\n  useMemo,\n  useState,\n  useRef,\n} 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';\nimport { KandoAlert } from 'src/ui-kit/Alert/KandoAlert';\nimport SearchField from './SearchField';\nimport SearchButton from './SearchButton';\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 [isSearchFieldVisible, setIsSearchFieldVisible] = useState(false);\n  const mapRef = useRef<{\n    zoomToPoint: (lat: number, lng: number) => void;\n    clickOnMarker: (lat: number, lng: number) => void;\n    closePopup: () => void;\n  }>(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 && waterAuthorityName) {\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, waterAuthorityName]);\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  useEffect(() => {\n    const maxIntervals = 5;\n    let interval = maxIntervals;\n    let intercomElement;\n\n    const id = setInterval(() => {\n      interval -= 1;\n      intercomElement = document.querySelector('.intercom-lightweight-app');\n      if (intercomElement) {\n        if (intercomElement.style.display === 'none') {\n          clearInterval(id);\n        } else {\n          intercomElement.style.display = 'none';\n        }\n      }\n\n      if (interval <= 0) {\n        clearInterval(id);\n      }\n    }, 300);\n\n    return () => {\n      if (intercomElement) {\n        intercomElement.style.display = '';\n      }\n    };\n  }, []);\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            164,\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 searchButtonClick = () => {\n    setIsSearchFieldVisible((prevVisible) => !prevVisible);\n    closePopup();\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 zoomToPoint = (lat: number, lng: number) => {\n    if (mapRef.current) {\n      mapRef.current.zoomToPoint(lat, lng); // Set to max zoom level 18\n    }\n  };\n\n  const clickOnMarker = (lat: number, lng: number) => {\n    if (mapRef.current) {\n      mapRef.current.clickOnMarker(lat, lng); // Set to max zoom level 18\n    }\n  };\n\n  const closePopup = () => {\n    if (mapRef.current) {\n      mapRef.current.closePopup();\n    }\n  };\n\n  if (!pointsData || !polygonData) return null;\n\n  if (!polygonData?.id) {\n    return (\n      <KandoAlert variant=\"danger\" header={'Heads up!'}>\n        <p>\n          {'No saved city found.'}\n          <br />\n          {'If you need assistance, please '}\n          <a href=\"mailto:support@kando.eco\">{'send us a message.'}</a>\n        </p>\n      </KandoAlert>\n    );\n  }\n\n  return (\n    <div className=\"app-wrapper\">\n      <MapTableContainer isRtl={isRtl}>\n        <Map\n          ref={mapRef}\n          filteredUseCase={useCase ? useCase : { code: 'to' }}\n          points={pointsData}\n          polygon={getPolygonGeoJSON(polygonData)}\n          onBoundsChange={handleBoundsChange}\n        />\n        {isSearchFieldVisible && (\n          <SearchFieldContainer>\n            <SearchField\n              suggestions={pointsData}\n              zoomToPoint={zoomToPoint}\n              clickOnMarker={clickOnMarker}\n              setIsSearchFieldVisible={setIsSearchFieldVisible}\n            />\n          </SearchFieldContainer>\n        )}\n      </MapTableContainer>\n      {bottomSheet}\n      <FilterButton\n        buttonState={filterButtonState}\n        onClick={filterButtonClick}\n      />\n      <SearchButton\n        buttonState={isSearchFieldVisible ? 'filled' : ''}\n        onClick={searchButtonClick}\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\nconst SearchFieldContainer = styled.div`\n  position: absolute;\n  top: 10px;\n  left: 50%;\n  transform: translateX(-50%);\n  z-index: 2000;\n  width: 300px;\n  background: rgba(255, 255, 255, 0);\n  border-radius: 8px;\n  padding: 10px;\n  //box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);\n`;\n"],"mappings":"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"}
@@ -0,0 +1,31 @@
1
+ <svg
2
+ width="48"
3
+ height="48"
4
+ viewBox="0 0 48 48"
5
+ fill="none"
6
+ xmlns="http://www.w3.org/2000/svg"
7
+ >
8
+ <!-- Background circle (optional) -->
9
+ <circle class="button-shape" cx="24" cy="24" r="24" fill="rgba(255, 255, 255, 1)" />
10
+
11
+ <!-- Lens outline -->
12
+ <circle class="lens-outline"
13
+ cx="20"
14
+ cy="20"
15
+ r="7"
16
+ stroke="rgba(0, 0, 0, 1)"
17
+ stroke-width="2"
18
+ fill="none"
19
+ />
20
+
21
+ <!-- Handle outline -->
22
+ <line
23
+ x1="25"
24
+ y1="25"
25
+ x2="32"
26
+ y2="32"
27
+ stroke="rgba(0, 0, 0, 1)"
28
+ stroke-width="2"
29
+ stroke-linecap="round"
30
+ />
31
+ </svg>
@@ -32,6 +32,7 @@ var useMap = function useMap(mapRef, points, filteredUseCase, polygon) {
32
32
  setUseCaseCode = _useState6[1];
33
33
  var heatLayerRef = (0, _react.useRef)();
34
34
  var pointsLayerRef = (0, _react.useRef)();
35
+ var markersRef = (0, _react.useRef)([]);
35
36
  var waterAuthorityId = (0, _reactRedux.useSelector)(function (state) {
36
37
  return state.global_data.waterAuthorityId;
37
38
  });
@@ -133,7 +134,7 @@ var useMap = function useMap(mapRef, points, filteredUseCase, polygon) {
133
134
  }
134
135
  } else {
135
136
  if (!pointsLayerRef.current.getLayers().length) {
136
- points.forEach(function (point) {
137
+ markersRef.current = points.map(function (point) {
137
138
  var _pointsLayerRef$curre;
138
139
  var icon = (0, _PointIcon.getPointIconByType)('Groups::Factory', point === null || point === void 0 ? void 0 : point.id.toString(), '', false, true);
139
140
  var marker = _leaflet.default.marker([point.lat, point.lng], {
@@ -144,6 +145,7 @@ var useMap = function useMap(mapRef, points, filteredUseCase, polygon) {
144
145
  handleMarkerClick(point, map);
145
146
  });
146
147
  (_pointsLayerRef$curre = pointsLayerRef.current) === null || _pointsLayerRef$curre === void 0 ? void 0 : _pointsLayerRef$curre.addLayer(marker);
148
+ return marker;
147
149
  });
148
150
  } else {
149
151
  if (pointsLayerRef.current && filteredUseCase.code !== useCaseCode) {
@@ -173,7 +175,10 @@ var useMap = function useMap(mapRef, points, filteredUseCase, polygon) {
173
175
  }
174
176
  }
175
177
  }, [points, map, mapZoomLevel, filteredUseCase, calculateHeatPoints]);
176
- return map;
178
+ return {
179
+ map: map,
180
+ markers: markersRef.current
181
+ };
177
182
  };
178
183
  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"}
184
+ //# 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","markersRef","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","_pointsLayerRef$curre","icon","getPointIconByType","toString","marker","kando_id","forEach","_pointsLayerRef$curre2","existingMarker","find","layer","Marker","options","markers","exports"],"sources":["../../../src/pages/PollutionRiskAssessment/useMap.tsx"],"sourcesContent":["import L, { Marker } 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): {\n  map: L.Map | undefined;\n  markers: Marker[];\n} => {\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 markersRef = useRef<Marker[]>([]);\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        markersRef.current = points.map((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          return 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, markers: markersRef.current };\n};\n"],"mappings":"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"}
@@ -3,6 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
+ exports.clearPoints = clearPoints;
6
7
  exports.fetchPoints = fetchPoints;
7
8
  var _actionTypes = require("./actionTypes");
8
9
  function requestPoints() {
@@ -16,6 +17,12 @@ function receivePoints(json) {
16
17
  payload: json
17
18
  };
18
19
  }
20
+ function clearPoints() {
21
+ return {
22
+ type: _actionTypes.RECEIVE_POINTS,
23
+ payload: []
24
+ };
25
+ }
19
26
  function fetchPoints(waterAuthorityId) {
20
27
  var period = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '30';
21
28
  var forOperations = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
@@ -28,4 +35,4 @@ function fetchPoints(waterAuthorityId) {
28
35
  });
29
36
  };
30
37
  }
31
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfYWN0aW9uVHlwZXMiLCJyZXF1aXJlIiwicmVxdWVzdFBvaW50cyIsInR5cGUiLCJSRVFVRVNUX1BPSU5UUyIsInJlY2VpdmVQb2ludHMiLCJqc29uIiwiUkVDRUlWRV9QT0lOVFMiLCJwYXlsb2FkIiwiZmV0Y2hQb2ludHMiLCJ3YXRlckF1dGhvcml0eUlkIiwicGVyaW9kIiwiYXJndW1lbnRzIiwibGVuZ3RoIiwidW5kZWZpbmVkIiwiZm9yT3BlcmF0aW9ucyIsImRpc3BhdGNoIiwiZmV0Y2giLCJjb25jYXQiLCJ0aGVuIiwicmVzcG9uc2UiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvc3RvcmUvcG9pbnRzL2FjdGlvbnMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUkVRVUVTVF9QT0lOVFMsIFJFQ0VJVkVfUE9JTlRTIH0gZnJvbSAnLi9hY3Rpb25UeXBlcyc7XG5cbmZ1bmN0aW9uIHJlcXVlc3RQb2ludHMoKSB7XG4gIHJldHVybiB7XG4gICAgdHlwZTogUkVRVUVTVF9QT0lOVFMsXG4gIH07XG59XG5cbmZ1bmN0aW9uIHJlY2VpdmVQb2ludHMoanNvbjogYW55KSB7XG4gIHJldHVybiB7XG4gICAgdHlwZTogUkVDRUlWRV9QT0lOVFMsXG4gICAgcGF5bG9hZDoganNvbixcbiAgfTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGZldGNoUG9pbnRzKFxuICB3YXRlckF1dGhvcml0eUlkOiBudW1iZXIsXG4gIHBlcmlvZDogc3RyaW5nID0gJzMwJyxcbiAgZm9yT3BlcmF0aW9uczogYm9vbGVhbiA9IGZhbHNlLFxuKSB7XG4gIHJldHVybiAoZGlzcGF0Y2g6IChhcmcwOiBhbnkpID0+IHZvaWQpID0+IHtcbiAgICBkaXNwYXRjaChyZXF1ZXN0UG9pbnRzKCkpO1xuICAgIHJldHVybiBmZXRjaChcbiAgICAgIGAvcG9pbnRzLmpzb24/d2F0ZXJfYXV0aG9yaXR5X2lkPSR7d2F0ZXJBdXRob3JpdHlJZH0mcGVyaW9kPSR7cGVyaW9kfSR7XG4gICAgICAgIGZvck9wZXJhdGlvbnMgPyAnJmZvcl9vcGVyYXRpb25zPXRydWUnIDogJydcbiAgICAgIH1gLFxuICAgIClcbiAgICAgIC50aGVuKChyZXNwb25zZSkgPT4gcmVzcG9uc2UuanNvbigpKVxuICAgICAgLnRoZW4oKGpzb24pID0+IGRpc3BhdGNoKHJlY2VpdmVQb2ludHMoanNvbikpKTtcbiAgfTtcbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsSUFBQUEsWUFBQSxHQUFBQyxPQUFBO0FBRUEsU0FBU0MsYUFBYUEsQ0FBQSxFQUFHO0VBQ3ZCLE9BQU87SUFDTEMsSUFBSSxFQUFFQztFQUNSLENBQUM7QUFDSDtBQUVBLFNBQVNDLGFBQWFBLENBQUNDLElBQVMsRUFBRTtFQUNoQyxPQUFPO0lBQ0xILElBQUksRUFBRUksMkJBQWM7SUFDcEJDLE9BQU8sRUFBRUY7RUFDWCxDQUFDO0FBQ0g7QUFFTyxTQUFTRyxXQUFXQSxDQUN6QkMsZ0JBQXdCLEVBR3hCO0VBQUEsSUFGQUMsTUFBYyxHQUFBQyxTQUFBLENBQUFDLE1BQUEsUUFBQUQsU0FBQSxRQUFBRSxTQUFBLEdBQUFGLFNBQUEsTUFBRyxJQUFJO0VBQUEsSUFDckJHLGFBQXNCLEdBQUFILFNBQUEsQ0FBQUMsTUFBQSxRQUFBRCxTQUFBLFFBQUFFLFNBQUEsR0FBQUYsU0FBQSxNQUFHLEtBQUs7RUFFOUIsT0FBTyxVQUFDSSxRQUE2QixFQUFLO0lBQ3hDQSxRQUFRLENBQUNkLGFBQWEsQ0FBQyxDQUFDLENBQUM7SUFDekIsT0FBT2UsS0FBSyxvQ0FBQUMsTUFBQSxDQUN5QlIsZ0JBQWdCLGNBQUFRLE1BQUEsQ0FBV1AsTUFBTSxFQUFBTyxNQUFBLENBQ2xFSCxhQUFhLEdBQUcsc0JBQXNCLEdBQUcsRUFBRSxDQUUvQyxDQUFDLENBQ0VJLElBQUksQ0FBQyxVQUFDQyxRQUFRO01BQUEsT0FBS0EsUUFBUSxDQUFDZCxJQUFJLENBQUMsQ0FBQztJQUFBLEVBQUMsQ0FDbkNhLElBQUksQ0FBQyxVQUFDYixJQUFJO01BQUEsT0FBS1UsUUFBUSxDQUFDWCxhQUFhLENBQUNDLElBQUksQ0FBQyxDQUFDO0lBQUEsRUFBQztFQUNsRCxDQUFDO0FBQ0gifQ==
38
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfYWN0aW9uVHlwZXMiLCJyZXF1aXJlIiwicmVxdWVzdFBvaW50cyIsInR5cGUiLCJSRVFVRVNUX1BPSU5UUyIsInJlY2VpdmVQb2ludHMiLCJqc29uIiwiUkVDRUlWRV9QT0lOVFMiLCJwYXlsb2FkIiwiY2xlYXJQb2ludHMiLCJmZXRjaFBvaW50cyIsIndhdGVyQXV0aG9yaXR5SWQiLCJwZXJpb2QiLCJhcmd1bWVudHMiLCJsZW5ndGgiLCJ1bmRlZmluZWQiLCJmb3JPcGVyYXRpb25zIiwiZGlzcGF0Y2giLCJmZXRjaCIsImNvbmNhdCIsInRoZW4iLCJyZXNwb25zZSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9zdG9yZS9wb2ludHMvYWN0aW9ucy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSRVFVRVNUX1BPSU5UUywgUkVDRUlWRV9QT0lOVFMgfSBmcm9tICcuL2FjdGlvblR5cGVzJztcblxuZnVuY3Rpb24gcmVxdWVzdFBvaW50cygpIHtcbiAgcmV0dXJuIHtcbiAgICB0eXBlOiBSRVFVRVNUX1BPSU5UUyxcbiAgfTtcbn1cblxuZnVuY3Rpb24gcmVjZWl2ZVBvaW50cyhqc29uOiBhbnkpIHtcbiAgcmV0dXJuIHtcbiAgICB0eXBlOiBSRUNFSVZFX1BPSU5UUyxcbiAgICBwYXlsb2FkOiBqc29uLFxuICB9O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gY2xlYXJQb2ludHMoKSB7XG4gIHJldHVybiB7XG4gICAgdHlwZTogUkVDRUlWRV9QT0lOVFMsXG4gICAgcGF5bG9hZDogW10sXG4gIH07XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBmZXRjaFBvaW50cyhcbiAgd2F0ZXJBdXRob3JpdHlJZDogbnVtYmVyLFxuICBwZXJpb2Q6IHN0cmluZyA9ICczMCcsXG4gIGZvck9wZXJhdGlvbnM6IGJvb2xlYW4gPSBmYWxzZSxcbikge1xuICByZXR1cm4gKGRpc3BhdGNoOiAoYXJnMDogYW55KSA9PiB2b2lkKSA9PiB7XG4gICAgZGlzcGF0Y2gocmVxdWVzdFBvaW50cygpKTtcbiAgICByZXR1cm4gZmV0Y2goXG4gICAgICBgL3BvaW50cy5qc29uP3dhdGVyX2F1dGhvcml0eV9pZD0ke3dhdGVyQXV0aG9yaXR5SWR9JnBlcmlvZD0ke3BlcmlvZH0ke1xuICAgICAgICBmb3JPcGVyYXRpb25zID8gJyZmb3Jfb3BlcmF0aW9ucz10cnVlJyA6ICcnXG4gICAgICB9YCxcbiAgICApXG4gICAgICAudGhlbigocmVzcG9uc2UpID0+IHJlc3BvbnNlLmpzb24oKSlcbiAgICAgIC50aGVuKChqc29uKSA9PiBkaXNwYXRjaChyZWNlaXZlUG9pbnRzKGpzb24pKSk7XG4gIH07XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQSxJQUFBQSxZQUFBLEdBQUFDLE9BQUE7QUFFQSxTQUFTQyxhQUFhQSxDQUFBLEVBQUc7RUFDdkIsT0FBTztJQUNMQyxJQUFJLEVBQUVDO0VBQ1IsQ0FBQztBQUNIO0FBRUEsU0FBU0MsYUFBYUEsQ0FBQ0MsSUFBUyxFQUFFO0VBQ2hDLE9BQU87SUFDTEgsSUFBSSxFQUFFSSwyQkFBYztJQUNwQkMsT0FBTyxFQUFFRjtFQUNYLENBQUM7QUFDSDtBQUVPLFNBQVNHLFdBQVdBLENBQUEsRUFBRztFQUM1QixPQUFPO0lBQ0xOLElBQUksRUFBRUksMkJBQWM7SUFDcEJDLE9BQU8sRUFBRTtFQUNYLENBQUM7QUFDSDtBQUVPLFNBQVNFLFdBQVdBLENBQ3pCQyxnQkFBd0IsRUFHeEI7RUFBQSxJQUZBQyxNQUFjLEdBQUFDLFNBQUEsQ0FBQUMsTUFBQSxRQUFBRCxTQUFBLFFBQUFFLFNBQUEsR0FBQUYsU0FBQSxNQUFHLElBQUk7RUFBQSxJQUNyQkcsYUFBc0IsR0FBQUgsU0FBQSxDQUFBQyxNQUFBLFFBQUFELFNBQUEsUUFBQUUsU0FBQSxHQUFBRixTQUFBLE1BQUcsS0FBSztFQUU5QixPQUFPLFVBQUNJLFFBQTZCLEVBQUs7SUFDeENBLFFBQVEsQ0FBQ2YsYUFBYSxDQUFDLENBQUMsQ0FBQztJQUN6QixPQUFPZ0IsS0FBSyxvQ0FBQUMsTUFBQSxDQUN5QlIsZ0JBQWdCLGNBQUFRLE1BQUEsQ0FBV1AsTUFBTSxFQUFBTyxNQUFBLENBQ2xFSCxhQUFhLEdBQUcsc0JBQXNCLEdBQUcsRUFBRSxDQUUvQyxDQUFDLENBQ0VJLElBQUksQ0FBQyxVQUFDQyxRQUFRO01BQUEsT0FBS0EsUUFBUSxDQUFDZixJQUFJLENBQUMsQ0FBQztJQUFBLEVBQUMsQ0FDbkNjLElBQUksQ0FBQyxVQUFDZCxJQUFJO01BQUEsT0FBS1csUUFBUSxDQUFDWixhQUFhLENBQUNDLElBQUksQ0FBQyxDQUFDO0lBQUEsRUFBQztFQUNsRCxDQUFDO0FBQ0gifQ==
@@ -3,4 +3,4 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3N0b3JlL3BvaW50cy9tb2RlbHMvSUdlb1BvaW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgSUdlb1BvaW50IHtcbiAgaWQ6IG51bWJlcjtcbiAgbGF0OiBudW1iZXI7XG4gIGxuZzogbnVtYmVyO1xuICB0b3M6IG51bWJlcjtcbiAgdG9jOiBudW1iZXI7XG59XG4iXSwibWFwcGluZ3MiOiIifQ==
6
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3N0b3JlL3BvaW50cy9tb2RlbHMvSUdlb1BvaW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgSUdlb1BvaW50IHtcbiAgbmFtZTogc3RyaW5nO1xuICBpZDogbnVtYmVyO1xuICBsYXQ6IG51bWJlcjtcbiAgbG5nOiBudW1iZXI7XG4gIHRvczogbnVtYmVyO1xuICB0b2M6IG51bWJlcjtcbn1cbiJdLCJtYXBwaW5ncyI6IiJ9