@kando-env/kando-ui 1.2.414 → 1.2.416

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.
@@ -0,0 +1,55 @@
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 _ImportFileWizard = _interopRequireDefault(require("pages/ImportFileWizard"));
9
+ var _urls = require("utilities/urls");
10
+ var _reactRedux = require("react-redux");
11
+ var _react = _interopRequireDefault(require("react"));
12
+ var _uiKit = require("ui-kit");
13
+ var _i18n = _interopRequireDefault(require("utilities/i18n"));
14
+ var _actionsCreator = require("store/ImportGis/actionsCreator");
15
+ var _reactBootstrap = require("react-bootstrap");
16
+ var ImportSiteProcess = function ImportSiteProcess() {
17
+ var dispatch = (0, _reactRedux.useDispatch)();
18
+ var waterAuthorityId = (0, _reactRedux.useSelector)(function (state) {
19
+ return state.global_data.waterAuthorityId;
20
+ });
21
+ var _useSelector = (0, _reactRedux.useSelector)(function (state) {
22
+ return state.importGis;
23
+ }),
24
+ uploadingFile = _useSelector.uploadingFile;
25
+ var submitURL = (0, _urls.urls)({
26
+ waterAuthorityId: waterAuthorityId
27
+ }).importSiteFile.newFile.url;
28
+ var validationURL = (0, _urls.urls)({
29
+ waterAuthorityId: waterAuthorityId
30
+ }).importSiteFile.validateFile.url;
31
+ var fileTitleChangedHandler = function fileTitleChangedHandler(event) {
32
+ dispatch((0, _actionsCreator.setFileTitle)(event.target.value));
33
+ };
34
+ return /*#__PURE__*/_react.default.createElement(_ImportFileWizard.default, {
35
+ acceptType: 'csv',
36
+ title: 'import_site_process.title',
37
+ navContext: 'import_site_process',
38
+ validationURL: validationURL,
39
+ submitURL: submitURL
40
+ }, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Alert, {
41
+ variant: "info"
42
+ }, /*#__PURE__*/_react.default.createElement("h4", null, 'Upload a csv file with the following columns'), /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("b", null, 'Mandatory fields: '), 'Kando_tree', /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("u", null, 'For location:(One of the following options)'), /*#__PURE__*/_react.default.createElement("br", null), '1. Lat_loc - latitude, Lng_loc - longitude', /*#__PURE__*/_react.default.createElement("br", null), '2. address - location name', /*#__PURE__*/_react.default.createElement("br", null), '3. split address: street, street_number, city, zipcode, country(At least city)'), /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("b", null, 'Optional fields: '), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("u", null, 'For sector:'), /*#__PURE__*/_react.default.createElement("br", null), '1. activity - factory activity', /*#__PURE__*/_react.default.createElement("br", null), '2. nace - nace code', /*#__PURE__*/_react.default.createElement("br", null), '3. naics - naics code', /*#__PURE__*/_react.default.createElement("br", null), '4. sic - SIC code', /*#__PURE__*/_react.default.createElement("br", null), '5. Sector - for the exact kando sector name', /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("u", null, 'For site type: (default Factory)'), /*#__PURE__*/_react.default.createElement("br", null), 'site_type(WWTP, Factory, Pipe, Collectors, PumpStation, WaterLevel)', /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("u", null, 'Extra data:'), /*#__PURE__*/_react.default.createElement("br", null), 'd_water_c, water_discharge, Diameter, Slop, Depth, Width, pop_size')), /*#__PURE__*/_react.default.createElement(_uiKit.MobileInput, {
43
+ isInvalid: false,
44
+ handleChange: fileTitleChangedHandler,
45
+ inputTitle: _i18n.default.t('import_gis_process.title_input_label'),
46
+ placeholder: _i18n.default.t('import_gis_process.title_input_placeholder'),
47
+ value: uploadingFile.fileTitle,
48
+ type: "text",
49
+ name: "fileTitle",
50
+ mandatory: true
51
+ }));
52
+ };
53
+ var _default = ImportSiteProcess;
54
+ exports.default = _default;
55
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_ImportFileWizard","_interopRequireDefault","require","_urls","_reactRedux","_react","_uiKit","_i18n","_actionsCreator","_reactBootstrap","ImportSiteProcess","dispatch","useDispatch","waterAuthorityId","useSelector","state","global_data","_useSelector","importGis","uploadingFile","submitURL","urls","importSiteFile","newFile","url","validationURL","validateFile","fileTitleChangedHandler","event","setFileTitle","target","value","default","createElement","acceptType","title","navContext","Alert","variant","MobileInput","isInvalid","handleChange","inputTitle","i18n","t","placeholder","fileTitle","type","name","mandatory","_default","exports"],"sources":["../../../src/pages/ImportSiteProcess/index.tsx"],"sourcesContent":["import ImportFile from 'src/pages/ImportFileWizard';\nimport { urls } from 'src/utilities/urls';\nimport { useDispatch, useSelector } from 'react-redux';\nimport React from 'react';\nimport { MobileInput } from 'src/ui-kit';\nimport i18n from 'src/utilities/i18n';\nimport { setFileTitle } from 'src/store/ImportGis/actionsCreator';\nimport { appReducer } from 'src/store/rootReducer';\nimport { Alert } from 'react-bootstrap';\n\nconst ImportSiteProcess = () => {\n  const dispatch = useDispatch();\n  const waterAuthorityId = useSelector(\n    (state) => state.global_data.waterAuthorityId,\n  );\n  const { uploadingFile } = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.importGis,\n  );\n  const submitURL = urls({ waterAuthorityId }).importSiteFile.newFile.url;\n  const validationURL = urls({ waterAuthorityId }).importSiteFile.validateFile\n    .url;\n  const fileTitleChangedHandler = (event) => {\n    dispatch(setFileTitle(event.target.value));\n  };\n  return (\n    <ImportFile\n      acceptType={'csv'}\n      title={'import_site_process.title'}\n      navContext={'import_site_process'}\n      validationURL={validationURL}\n      submitURL={submitURL}\n    >\n      <Alert variant=\"info\">\n        <h4>{'Upload a csv file with the following columns'}</h4>\n        <div>\n          <b>{'Mandatory fields: '}</b>\n          {'Kando_tree'}\n          <br />\n          <u>{'For location:(One of the following options)'}</u>\n          <br />\n          {'1. Lat_loc - latitude, Lng_loc - longitude'}\n          <br />\n          {'2. address - location name'}\n          <br />\n          {\n            '3. split address: street, street_number, city, zipcode, country(At least city)'\n          }\n        </div>\n        <div>\n          <b>{'Optional fields: '}</b>\n          <br />\n          <u>{'For sector:'}</u>\n          <br />\n          {'1. activity - factory activity'}\n          <br />\n          {'2. nace - nace code'}\n          <br />\n          {'3. naics - naics code'}\n          <br />\n          {'4. sic - SIC code'}\n          <br />\n          {'5. Sector - for the exact kando sector name'}\n          <br />\n          <u>{'For site type: (default Factory)'}</u>\n          <br />\n          {\n            'site_type(WWTP, Factory, Pipe, Collectors, PumpStation, WaterLevel)'\n          }\n          <br />\n          <u>{'Extra data:'}</u>\n          <br />\n          {'d_water_c, water_discharge, Diameter, Slop, Depth, Width, pop_size'}\n        </div>\n      </Alert>\n      <MobileInput\n        isInvalid={false}\n        handleChange={fileTitleChangedHandler}\n        inputTitle={i18n.t('import_gis_process.title_input_label')}\n        placeholder={i18n.t('import_gis_process.title_input_placeholder')}\n        value={uploadingFile.fileTitle}\n        type=\"text\"\n        name=\"fileTitle\"\n        mandatory={true}\n      />\n    </ImportFile>\n  );\n};\n\nexport default ImportSiteProcess;\n"],"mappings":"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"}
@@ -18,7 +18,10 @@ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj &&
18
18
  var LeftPanel = function LeftPanel(_ref) {
19
19
  var points = _ref.points,
20
20
  selectedPoint = _ref.selectedPoint,
21
- setSelectedPoint = _ref.setSelectedPoint;
21
+ setSelectedPoint = _ref.setSelectedPoint,
22
+ _ref$onlyMonitored = _ref.onlyMonitored,
23
+ onlyMonitored = _ref$onlyMonitored === void 0 ? true : _ref$onlyMonitored,
24
+ filterOptions = _ref.filterOptions;
22
25
  var _useState = (0, _react.useState)([]),
23
26
  _useState2 = (0, _slicedToArray2.default)(_useState, 2),
24
27
  selectedFilters = _useState2[0],
@@ -50,22 +53,6 @@ var LeftPanel = function LeftPanel(_ref) {
50
53
  var sortedPoints = points.sort(function (a, b) {
51
54
  return b.issues.length - a.issues.length;
52
55
  });
53
- var filterOptions = [{
54
- value: 'installation_height',
55
- label: 'Installation Height'
56
- }, {
57
- value: 'distance',
58
- label: 'Distance'
59
- }, {
60
- value: 'no_parent',
61
- label: 'No Parent'
62
- }, {
63
- value: 'diameter',
64
- label: 'Diameter'
65
- }, {
66
- value: 'water_consumption',
67
- label: 'Water Consumption'
68
- }];
69
56
  (0, _react.useEffect)(function () {
70
57
  setFilteredPoints(sortedPoints);
71
58
  }, [sortedPoints]);
@@ -85,7 +72,7 @@ var LeftPanel = function LeftPanel(_ref) {
85
72
  }, [selectedFilters]);
86
73
  return /*#__PURE__*/_react.default.createElement(_reactBootstrap.Container, {
87
74
  className: "mt-4 pl-3 pr-2"
88
- }, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Row, null, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Col, null, /*#__PURE__*/_react.default.createElement("h4", null, "Monitored Manholes(".concat(filteredPoints.length, ")")))), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Row, {
75
+ }, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Row, null, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Col, null, /*#__PURE__*/_react.default.createElement("h4", null, "".concat(onlyMonitored ? 'Monitored ' : '', "Manholes(").concat(filteredPoints.length, ")")))), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Row, {
89
76
  className: "mt-3 mb-3"
90
77
  }, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Col, null, /*#__PURE__*/_react.default.createElement(_KandoFilter.default, {
91
78
  filterOptions: filterOptions,
@@ -112,4 +99,4 @@ var LeftPanel = function LeftPanel(_ref) {
112
99
  };
113
100
  var _default = LeftPanel;
114
101
  exports.default = _default;
115
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactBootstrap","_reactFontawesome","_freeSolidSvgIcons","_Sector","_interopRequireDefault","_KandoFilter","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","LeftPanel","_ref","points","selectedPoint","setSelectedPoint","_useState","useState","_useState2","_slicedToArray2","selectedFilters","setSelectedFilters","_useState3","_useState4","filteredPoints","setFilteredPoints","maxIssues","issuesIconColor","length","showIssues","point","issuesLength","issues","createElement","FontAwesomeIcon","icon","faExclamationTriangle","className","sortedPoints","sort","a","b","filterOptions","value","label","useEffect","filter","some","issue","type","Container","Row","Col","concat","ListGroup","map","Item","id","onClick","sectorIconName","group","sector_icon_name","sectorName","sector_name","showLabel","withTooltip","name","_default","exports"],"sources":["../../../src/pages/OperationsPage/LeftPanel.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react';\nimport { Container, Row, Col, ListGroup } from 'react-bootstrap';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faExclamationTriangle } from '@fortawesome/free-solid-svg-icons';\nimport Sector from 'src/components/Sector';\nimport KandoFilter from 'src/ui-kit/KandoFilter/KandoFilter';\n\nexport interface LeftPanelProps {\n  points: IPoint[];\n  selectedPoint: IPoint | null;\n  setSelectedPoint: (point: IPoint) => void;\n}\n\nconst LeftPanel: React.FC<LeftPanelProps> = ({\n  points,\n  selectedPoint,\n  setSelectedPoint,\n}) => {\n  const [selectedFilters, setSelectedFilters] = useState([]);\n  const [filteredPoints, setFilteredPoints] = useState<IPoint[]>([]);\n  const maxIssues = 3;\n  const issuesIconColor = (length) => {\n    if (length % maxIssues === 0) {\n      return 'icon-red';\n    } else if (length % maxIssues === 2) {\n      return 'icon-orange';\n    } else {\n      return 'icon-yellow';\n    }\n  };\n\n  const showIssues = (point) => {\n    const issuesLength = point?.issues.length;\n    if (issuesLength > 0) {\n      return (\n        <FontAwesomeIcon\n          icon={faExclamationTriangle}\n          className={issuesIconColor(issuesLength)}\n        />\n      );\n    }\n    return '';\n  };\n\n  const sortedPoints = points.sort((a, b) => b.issues.length - a.issues.length);\n\n  const filterOptions = [\n    { value: 'installation_height', label: 'Installation Height' },\n    { value: 'distance', label: 'Distance' },\n    { value: 'no_parent', label: 'No Parent' },\n    { value: 'diameter', label: 'Diameter' },\n    { value: 'water_consumption', label: 'Water Consumption' },\n  ];\n\n  useEffect(() => {\n    setFilteredPoints(sortedPoints);\n  }, [sortedPoints]);\n\n  useEffect(() => {\n    const filteredPoints = sortedPoints.filter((point) => {\n      if (selectedFilters.length === 0) {\n        return true; // Show all points if no filters are selected\n      }\n\n      return selectedFilters.some((filter) =>\n        point.issues.some((issue) => issue.type === filter.value),\n      );\n    });\n    setFilteredPoints(filteredPoints);\n  }, [selectedFilters]);\n\n  return (\n    <Container className=\"mt-4 pl-3 pr-2\">\n      <Row>\n        <Col>\n          <h4>{`Monitored Manholes(${filteredPoints.length})`}</h4>\n        </Col>\n      </Row>\n      <Row className=\"mt-3 mb-3\">\n        <Col>\n          <KandoFilter\n            filterOptions={filterOptions}\n            selectedFilters={selectedFilters}\n            setSelectedFilters={setSelectedFilters}\n          ></KandoFilter>\n        </Col>\n      </Row>\n      <Row>\n        <Col>\n          <div className=\"scrollable-list\">\n            <ListGroup>\n              {points.length > 0 &&\n                filteredPoints.map((point) => (\n                  <ListGroup.Item\n                    className={\n                      selectedPoint?.id === point.id\n                        ? 'list-item list-item-selected'\n                        : 'list-item'\n                    }\n                    key={point.id}\n                    onClick={() => setSelectedPoint(point)}\n                  >\n                    <div className=\"item-content\">\n                      <Sector\n                        sectorIconName={point.group.sector_icon_name}\n                        sectorName={point.group.sector_name}\n                        showLabel={false}\n                        withTooltip={true}\n                      ></Sector>\n                      <span>{point.name}</span>\n                    </div>\n                    {showIssues(point)}\n                  </ListGroup.Item>\n                ))}\n            </ListGroup>\n          </div>\n        </Col>\n      </Row>\n    </Container>\n  );\n};\n\nexport default LeftPanel;\n"],"mappings":"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"}
102
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactBootstrap","_reactFontawesome","_freeSolidSvgIcons","_Sector","_interopRequireDefault","_KandoFilter","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","LeftPanel","_ref","points","selectedPoint","setSelectedPoint","_ref$onlyMonitored","onlyMonitored","filterOptions","_useState","useState","_useState2","_slicedToArray2","selectedFilters","setSelectedFilters","_useState3","_useState4","filteredPoints","setFilteredPoints","maxIssues","issuesIconColor","length","showIssues","point","issuesLength","issues","createElement","FontAwesomeIcon","icon","faExclamationTriangle","className","sortedPoints","sort","a","b","useEffect","filter","some","issue","type","value","Container","Row","Col","concat","ListGroup","map","Item","id","onClick","sectorIconName","group","sector_icon_name","sectorName","sector_name","showLabel","withTooltip","name","_default","exports"],"sources":["../../../src/pages/OperationsPage/LeftPanel.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react';\nimport { Container, Row, Col, ListGroup } from 'react-bootstrap';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faExclamationTriangle } from '@fortawesome/free-solid-svg-icons';\nimport Sector from 'src/components/Sector';\nimport KandoFilter from 'src/ui-kit/KandoFilter/KandoFilter';\n\nexport interface LeftPanelProps {\n  points: IPoint[];\n  selectedPoint: IPoint | null;\n  setSelectedPoint: (point: IPoint) => void;\n  filterOptions: { value: string; label: string }[];\n  onlyMonitored: boolean;\n}\n\nconst LeftPanel: React.FC<LeftPanelProps> = ({\n  points,\n  selectedPoint,\n  setSelectedPoint,\n  onlyMonitored = true,\n  filterOptions,\n}) => {\n  const [selectedFilters, setSelectedFilters] = useState([]);\n  const [filteredPoints, setFilteredPoints] = useState<IPoint[]>([]);\n  const maxIssues = 3;\n  const issuesIconColor = (length) => {\n    if (length % maxIssues === 0) {\n      return 'icon-red';\n    } else if (length % maxIssues === 2) {\n      return 'icon-orange';\n    } else {\n      return 'icon-yellow';\n    }\n  };\n\n  const showIssues = (point) => {\n    const issuesLength = point?.issues.length;\n    if (issuesLength > 0) {\n      return (\n        <FontAwesomeIcon\n          icon={faExclamationTriangle}\n          className={issuesIconColor(issuesLength)}\n        />\n      );\n    }\n    return '';\n  };\n\n  const sortedPoints = points.sort((a, b) => b.issues.length - a.issues.length);\n\n  useEffect(() => {\n    setFilteredPoints(sortedPoints);\n  }, [sortedPoints]);\n\n  useEffect(() => {\n    const filteredPoints = sortedPoints.filter((point) => {\n      if (selectedFilters.length === 0) {\n        return true; // Show all points if no filters are selected\n      }\n\n      return selectedFilters.some((filter) =>\n        point.issues.some((issue) => issue.type === filter.value),\n      );\n    });\n    setFilteredPoints(filteredPoints);\n  }, [selectedFilters]);\n\n  return (\n    <Container className=\"mt-4 pl-3 pr-2\">\n      <Row>\n        <Col>\n          <h4>{`${onlyMonitored ? 'Monitored ' : ''}Manholes(${\n            filteredPoints.length\n          })`}</h4>\n        </Col>\n      </Row>\n      <Row className=\"mt-3 mb-3\">\n        <Col>\n          <KandoFilter\n            filterOptions={filterOptions}\n            selectedFilters={selectedFilters}\n            setSelectedFilters={setSelectedFilters}\n          ></KandoFilter>\n        </Col>\n      </Row>\n      <Row>\n        <Col>\n          <div className=\"scrollable-list\">\n            <ListGroup>\n              {points.length > 0 &&\n                filteredPoints.map((point) => (\n                  <ListGroup.Item\n                    className={\n                      selectedPoint?.id === point.id\n                        ? 'list-item list-item-selected'\n                        : 'list-item'\n                    }\n                    key={point.id}\n                    onClick={() => setSelectedPoint(point)}\n                  >\n                    <div className=\"item-content\">\n                      <Sector\n                        sectorIconName={point.group.sector_icon_name}\n                        sectorName={point.group.sector_name}\n                        showLabel={false}\n                        withTooltip={true}\n                      ></Sector>\n                      <span>{point.name}</span>\n                    </div>\n                    {showIssues(point)}\n                  </ListGroup.Item>\n                ))}\n            </ListGroup>\n          </div>\n        </Col>\n      </Row>\n    </Container>\n  );\n};\n\nexport default LeftPanel;\n"],"mappings":"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"}
@@ -95,8 +95,9 @@ var useMap = function useMap(mapRef, points, edges, areas, selectedPoint, update
95
95
  if (!pointsLayerRef.current.getLayers().length) {
96
96
  points.forEach(function (point) {
97
97
  var type = point.has_device === true || point.group.type === 'Groups::WastewaterTreatmentPlant' ? point.group.type : 'Groups::default';
98
- var icon = (0, _PointIcon.getPointIconByType)(type, point.name, '', false, true);
99
- var focusedIcon = (0, _PointIcon.getPointIconByType)(type, point.name, '', true, false);
98
+ var hasIssues = 'issues' in point && !point.has_device;
99
+ var icon = (0, _PointIcon.getPointIconByType)(type, point.name, '', false, true, hasIssues);
100
+ var focusedIcon = (0, _PointIcon.getPointIconByType)(type, point.name, '', true, false, hasIssues);
100
101
  if (point.latitude && point.longitude) {
101
102
  var _pointsLayerRef$curre3;
102
103
  var marker = getMarker(point);
@@ -253,4 +254,4 @@ var useMap = function useMap(mapRef, points, edges, areas, selectedPoint, update
253
254
  return map;
254
255
  };
255
256
  exports.useMap = useMap;
256
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_leaflet","_interopRequireDefault","require","_react","_PointIcon","_theme","_MapUtils","useMap","mapRef","points","edges","areas","selectedPoint","updateSelectedPoint","_useState","useState","_useState2","_slicedToArray2","default","map","setMap","_useState3","_useState4","focusedMarker","setFocusedMarker","focusedMarkerRef","useRef","pointsLayerRef","edgesLayerRef","areasLayerRef","useEffect","current","resetAllOthers","mapTypes","baseMaps","leafletMap","mapDefault","satellite","mapTemp","L","renderer","canvas","Object","values","addTo","control","layers","position","off","remove","_pointsLayerRef$curre","eachLayer","marker","options","kando_object_id","id","_isInside","fire","_pointsLayerRef$curre2","getBounds","contains","getLatLng","flyTo","getZoom","duration","animate","handleMarkerClick","point","addMarkers","hasLayer","removeLayer","featureGroup","getLayers","length","forEach","type","has_device","group","icon","getPointIconByType","name","focusedIcon","latitude","longitude","_pointsLayerRef$curre3","getMarker","setIcon","on","_focusedMarkerRef$cur","_leaflet_id","_focusedMarkerRef$cur2","addLayer","addEdges","pointLookup","Map","p","set","edge","_edgesLayerRef$curren","_edgesLayerRef$curren2","sourcePoint","get","source_point_id","targetPoint","target_point_id","latlngs","polyline","color","weight","opacity","smoothFactor","decorator","polylineDecorator","patterns","offset","repeat","symbol","Symbol","arrowHead","pixelSize","polygon","pathOptions","stroke","addAreas","flattenAreas","arguments","undefined","allAreas","area","shape_data","push","Array","isArray","sub_areas","concat","_toConsumableArray2","area_id","_areasLayerRef$curren","interactive","bindTooltip","area_name","permanent","direction","className","focusMap","fitBounds","setView","exports"],"sources":["../../../../src/pages/OperationsPage/Map/useMap.tsx"],"sourcesContent":["import L, { Marker } from 'leaflet';\nimport React, { useEffect, useRef, useState } from 'react';\nimport { getPointIconByType } from 'src/Widgets/Map/points/PointIcon';\nimport { leafletMap } from 'src/styles/theme/theme';\nimport { baseMaps } from 'src/Widgets/Map/MapUtils';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport { IEdge } from 'src/store/edges/models/IEdge';\nimport { IArea } from 'src/store/areas/models/IArea';\n\nexport const useMap = (\n  mapRef: React.RefObject<HTMLDivElement>,\n  points: IPoint[],\n  edges: IEdge[],\n  areas: IArea[],\n  selectedPoint: IPoint | null,\n  updateSelectedPoint: (point: IPoint) => void,\n): L.Map | undefined => {\n  const [map, setMap] = useState<L.Map>();\n  const [focusedMarker, setFocusedMarker] = useState<Marker | null>(null);\n  const focusedMarkerRef = useRef<Marker | null>(null);\n  const pointsLayerRef = useRef<L.FeatureGroup>();\n  const edgesLayerRef = useRef<L.FeatureGroup>();\n  const areasLayerRef = useRef<L.FeatureGroup>();\n\n  useEffect(() => {\n    focusedMarkerRef.current = focusedMarker;\n    resetAllOthers();\n  }, [focusedMarker]);\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: 'bottomright' }).addTo(mapTemp);\n\n    setMap(mapTemp);\n\n    return () => {\n      if (!mapTemp) {\n        return;\n      }\n      mapTemp.off();\n      mapTemp.remove();\n    };\n  }, []);\n\n  const resetAllOthers = () => {\n    pointsLayerRef.current?.eachLayer((marker) => {\n      if (\n        marker.options.kando_object_id !== selectedPoint?.id &&\n        marker._isInside\n      ) {\n        marker.fire('mouseout');\n      }\n    });\n  };\n\n  useEffect(() => {\n    if (selectedPoint === null) {\n      setFocusedMarker(null);\n    } else {\n      pointsLayerRef.current?.eachLayer((marker) => {\n        if (\n          selectedPoint &&\n          marker.options.kando_object_id === selectedPoint?.id\n        ) {\n          if (!map?.getBounds().contains(marker.getLatLng())) {\n            map?.flyTo(marker.getLatLng(), map.getZoom(), {\n              duration: 0.5,\n              animate: false,\n            });\n          }\n          marker.fire('mouseover');\n          setFocusedMarker(marker);\n          return;\n        }\n      });\n    }\n  }, [selectedPoint]);\n\n  const handleMarkerClick = (point) => {\n    updateSelectedPoint(point);\n  };\n\n  const addMarkers = () => {\n    if (!map || !points) {\n      return;\n    }\n\n    if (pointsLayerRef.current) {\n      if (map.hasLayer(pointsLayerRef.current)) {\n        map.removeLayer(pointsLayerRef.current);\n      }\n    }\n\n    pointsLayerRef.current = L.featureGroup();\n    pointsLayerRef.current.addTo(map);\n\n    if (!pointsLayerRef.current.getLayers().length) {\n      points.forEach((point) => {\n        const type =\n          point.has_device === true ||\n          point.group.type === 'Groups::WastewaterTreatmentPlant'\n            ? point.group.type\n            : 'Groups::default';\n        const icon = getPointIconByType(type, point.name, '', false, true);\n\n        const focusedIcon = getPointIconByType(\n          type,\n          point.name,\n          '',\n          true,\n          false,\n        );\n\n        if (point.latitude && point.longitude) {\n          let marker = getMarker(point);\n\n          marker.setIcon(icon);\n          // The use of marker._isInside is to overcome the issue that mouseover is endlessly triggered\n          // and we need it only once\n          marker.on('mouseover', () => {\n            if (!marker._isInside) {\n              marker._isInside = true;\n              marker.setIcon(focusedIcon);\n            }\n          });\n\n          marker.on('mouseout', () => {\n            if (\n              focusedMarkerRef?.current?._leaflet_id !== marker?._leaflet_id\n            ) {\n              marker._isInside = false;\n              marker.setIcon(icon);\n            }\n          });\n\n          marker.on('click', () => {\n            if (\n              focusedMarkerRef?.current?._leaflet_id === marker?._leaflet_id\n            ) {\n              setFocusedMarker(null);\n              handleMarkerClick(null);\n            } else {\n              handleMarkerClick(point);\n            }\n          });\n\n          pointsLayerRef.current?.addLayer(marker);\n        }\n      });\n    }\n  };\n\n  const getMarker = (point: IPoint) => {\n    return L.marker([point.latitude, point.longitude], {\n      kando_object_id: point.id,\n    });\n  };\n\n  const addEdges = () => {\n    if (!map || !edges) {\n      return;\n    }\n\n    const pointLookup = new Map();\n    points.forEach((p) => pointLookup.set(p.id, p));\n\n    if (edgesLayerRef.current) {\n      if (map.hasLayer(edgesLayerRef.current)) {\n        map.removeLayer(edgesLayerRef.current);\n      }\n    }\n\n    edgesLayerRef.current = L.featureGroup();\n    edgesLayerRef.current.addTo(map);\n\n    edges.forEach((edge) => {\n      const sourcePoint = pointLookup.get(edge.source_point_id);\n      const targetPoint = pointLookup.get(edge.target_point_id);\n\n      if (!sourcePoint || !targetPoint) {\n        return;\n      }\n\n      const latlngs = [\n        [sourcePoint?.latitude, sourcePoint?.longitude],\n        [targetPoint?.latitude, targetPoint?.longitude],\n      ];\n\n      const polyline = L.polyline(latlngs, {\n        color: 'black',\n        weight: 1,\n        opacity: 0.5,\n        smoothFactor: 1,\n      });\n\n      edgesLayerRef.current?.addLayer(polyline);\n\n      const decorator = L.polylineDecorator(polyline, {\n        patterns: [\n          {\n            offset: 20,\n            repeat: 60,\n            symbol: L.Symbol.arrowHead({\n              pixelSize: 4,\n              polygon: false,\n              pathOptions: {\n                stroke: true,\n                color: '#555',\n                weight: 1,\n                opacity: 0.8,\n              },\n            }),\n          },\n        ],\n      });\n\n      edgesLayerRef.current?.addLayer(decorator);\n    });\n  };\n\n  const addAreas = () => {\n    if (!map || !areas) {\n      return;\n    }\n\n    if (areasLayerRef.current) {\n      if (map.hasLayer(areasLayerRef.current)) {\n        map.removeLayer(areasLayerRef.current);\n      }\n    }\n\n    areasLayerRef.current = L.featureGroup();\n    areasLayerRef.current.addTo(map);\n\n    const flattenAreas = (areas: IArea[] = []): IArea[] => {\n      let allAreas: IArea[] = [];\n\n      areas.forEach((area: IArea) => {\n        if (area.shape_data.length > 0) {\n          allAreas.push(area);\n        }\n\n        // If there are sub_areas, recurse and concatenate\n        if (Array.isArray(area.sub_areas) && area.sub_areas.length > 0) {\n          allAreas = allAreas.concat(flattenAreas(area.sub_areas));\n        }\n      });\n\n      // Remove duplicates\n      return [\n        ...new Map(allAreas.map((area) => [area.area_id, area])).values(),\n      ];\n    };\n\n    const allAreas = flattenAreas(areas);\n\n    allAreas.forEach((area) => {\n      const polygon = L.polygon(area.shape_data, {\n        color: 'black',\n        weight: 1,\n        opacity: 0.8,\n        smoothFactor: 1,\n        interactive: false,\n        kando_object_id: area.area_id,\n      });\n\n      polygon.bindTooltip(area.area_name, {\n        permanent: true,\n        direction: 'center',\n        className: 'area-tooltip',\n      });\n\n      areasLayerRef.current?.addLayer(polygon);\n    });\n  };\n\n  const focusMap = () => {\n    if (map) {\n      if (\n        pointsLayerRef?.current &&\n        Array.isArray(pointsLayerRef.current.getLayers()) &&\n        pointsLayerRef.current.getLayers().length > 0\n      ) {\n        map.fitBounds(pointsLayerRef.current.getBounds());\n      } else {\n        map.setView([32.219157, 34.982481], 12);\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (map) {\n      addAreas();\n      addEdges();\n      addMarkers();\n      focusMap();\n    }\n  }, [points, areas, edges, map]);\n\n  return map;\n};\n"],"mappings":";;;;;;;;;AAAA,IAAAA,QAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,MAAA,GAAAD,OAAA;AACA,IAAAE,UAAA,GAAAF,OAAA;AACA,IAAAG,MAAA,GAAAH,OAAA;AACA,IAAAI,SAAA,GAAAJ,OAAA;AAKO,IAAMK,MAAM,GAAG,SAATA,MAAMA,CACjBC,MAAuC,EACvCC,MAAgB,EAChBC,KAAc,EACdC,KAAc,EACdC,aAA4B,EAC5BC,mBAA4C,EACtB;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,GAA0C,IAAAN,eAAQ,EAAgB,IAAI,CAAC;IAAAO,UAAA,OAAAL,eAAA,CAAAC,OAAA,EAAAG,UAAA;IAAhEE,aAAa,GAAAD,UAAA;IAAEE,gBAAgB,GAAAF,UAAA;EACtC,IAAMG,gBAAgB,GAAG,IAAAC,aAAM,EAAgB,IAAI,CAAC;EACpD,IAAMC,cAAc,GAAG,IAAAD,aAAM,EAAiB,CAAC;EAC/C,IAAME,aAAa,GAAG,IAAAF,aAAM,EAAiB,CAAC;EAC9C,IAAMG,aAAa,GAAG,IAAAH,aAAM,EAAiB,CAAC;EAE9C,IAAAI,gBAAS,EAAC,YAAM;IACdL,gBAAgB,CAACM,OAAO,GAAGR,aAAa;IACxCS,cAAc,CAAC,CAAC;EAClB,CAAC,EAAE,CAACT,aAAa,CAAC,CAAC;EAEnB,IAAAO,gBAAS,EAAC,YAAM;IACd,IAAI,CAACtB,MAAM,CAACuB,OAAO,EAAE;MACnB;IACF;IAEA,IAAME,QAAQ,GAAG,IAAAC,kBAAQ,EAACC,iBAAU,CAACC,UAAU,EAAED,iBAAU,CAACE,SAAS,CAAC;IACtE,IAAMC,OAAO,GAAGC,gBAAC,CAACpB,GAAG,CAACX,MAAM,CAACuB,OAAO,EAAE;MAAES,QAAQ,EAAED,gBAAC,CAACE,MAAM,CAAC;IAAE,CAAC,CAAC;IAE/DC,MAAM,CAACC,MAAM,CAACV,QAAQ,CAAC,CAAC,CAAC,CAAC,CAACW,KAAK,CAACN,OAAO,CAAC;IAEzCC,gBAAC,CAACM,OAAO,CAACC,MAAM,CAACb,QAAQ,EAAE,CAAC,CAAC,EAAE;MAAEc,QAAQ,EAAE;IAAc,CAAC,CAAC,CAACH,KAAK,CAACN,OAAO,CAAC;IAE1ElB,MAAM,CAACkB,OAAO,CAAC;IAEf,OAAO,YAAM;MACX,IAAI,CAACA,OAAO,EAAE;QACZ;MACF;MACAA,OAAO,CAACU,GAAG,CAAC,CAAC;MACbV,OAAO,CAACW,MAAM,CAAC,CAAC;IAClB,CAAC;EACH,CAAC,EAAE,EAAE,CAAC;EAEN,IAAMjB,cAAc,GAAG,SAAjBA,cAAcA,CAAA,EAAS;IAAA,IAAAkB,qBAAA;IAC3B,CAAAA,qBAAA,GAAAvB,cAAc,CAACI,OAAO,cAAAmB,qBAAA,uBAAtBA,qBAAA,CAAwBC,SAAS,CAAC,UAACC,MAAM,EAAK;MAC5C,IACEA,MAAM,CAACC,OAAO,CAACC,eAAe,MAAK1C,aAAa,aAAbA,aAAa,uBAAbA,aAAa,CAAE2C,EAAE,KACpDH,MAAM,CAACI,SAAS,EAChB;QACAJ,MAAM,CAACK,IAAI,CAAC,UAAU,CAAC;MACzB;IACF,CAAC,CAAC;EACJ,CAAC;EAED,IAAA3B,gBAAS,EAAC,YAAM;IACd,IAAIlB,aAAa,KAAK,IAAI,EAAE;MAC1BY,gBAAgB,CAAC,IAAI,CAAC;IACxB,CAAC,MAAM;MAAA,IAAAkC,sBAAA;MACL,CAAAA,sBAAA,GAAA/B,cAAc,CAACI,OAAO,cAAA2B,sBAAA,uBAAtBA,sBAAA,CAAwBP,SAAS,CAAC,UAACC,MAAM,EAAK;QAC5C,IACExC,aAAa,IACbwC,MAAM,CAACC,OAAO,CAACC,eAAe,MAAK1C,aAAa,aAAbA,aAAa,uBAAbA,aAAa,CAAE2C,EAAE,GACpD;UACA,IAAI,EAACpC,GAAG,aAAHA,GAAG,uBAAHA,GAAG,CAAEwC,SAAS,CAAC,CAAC,CAACC,QAAQ,CAACR,MAAM,CAACS,SAAS,CAAC,CAAC,CAAC,GAAE;YAClD1C,GAAG,aAAHA,GAAG,uBAAHA,GAAG,CAAE2C,KAAK,CAACV,MAAM,CAACS,SAAS,CAAC,CAAC,EAAE1C,GAAG,CAAC4C,OAAO,CAAC,CAAC,EAAE;cAC5CC,QAAQ,EAAE,GAAG;cACbC,OAAO,EAAE;YACX,CAAC,CAAC;UACJ;UACAb,MAAM,CAACK,IAAI,CAAC,WAAW,CAAC;UACxBjC,gBAAgB,CAAC4B,MAAM,CAAC;UACxB;QACF;MACF,CAAC,CAAC;IACJ;EACF,CAAC,EAAE,CAACxC,aAAa,CAAC,CAAC;EAEnB,IAAMsD,iBAAiB,GAAG,SAApBA,iBAAiBA,CAAIC,KAAK,EAAK;IACnCtD,mBAAmB,CAACsD,KAAK,CAAC;EAC5B,CAAC;EAED,IAAMC,UAAU,GAAG,SAAbA,UAAUA,CAAA,EAAS;IACvB,IAAI,CAACjD,GAAG,IAAI,CAACV,MAAM,EAAE;MACnB;IACF;IAEA,IAAIkB,cAAc,CAACI,OAAO,EAAE;MAC1B,IAAIZ,GAAG,CAACkD,QAAQ,CAAC1C,cAAc,CAACI,OAAO,CAAC,EAAE;QACxCZ,GAAG,CAACmD,WAAW,CAAC3C,cAAc,CAACI,OAAO,CAAC;MACzC;IACF;IAEAJ,cAAc,CAACI,OAAO,GAAGQ,gBAAC,CAACgC,YAAY,CAAC,CAAC;IACzC5C,cAAc,CAACI,OAAO,CAACa,KAAK,CAACzB,GAAG,CAAC;IAEjC,IAAI,CAACQ,cAAc,CAACI,OAAO,CAACyC,SAAS,CAAC,CAAC,CAACC,MAAM,EAAE;MAC9ChE,MAAM,CAACiE,OAAO,CAAC,UAACP,KAAK,EAAK;QACxB,IAAMQ,IAAI,GACRR,KAAK,CAACS,UAAU,KAAK,IAAI,IACzBT,KAAK,CAACU,KAAK,CAACF,IAAI,KAAK,kCAAkC,GACnDR,KAAK,CAACU,KAAK,CAACF,IAAI,GAChB,iBAAiB;QACvB,IAAMG,IAAI,GAAG,IAAAC,6BAAkB,EAACJ,IAAI,EAAER,KAAK,CAACa,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC;QAElE,IAAMC,WAAW,GAAG,IAAAF,6BAAkB,EACpCJ,IAAI,EACJR,KAAK,CAACa,IAAI,EACV,EAAE,EACF,IAAI,EACJ,KACF,CAAC;QAED,IAAIb,KAAK,CAACe,QAAQ,IAAIf,KAAK,CAACgB,SAAS,EAAE;UAAA,IAAAC,sBAAA;UACrC,IAAIhC,MAAM,GAAGiC,SAAS,CAAClB,KAAK,CAAC;UAE7Bf,MAAM,CAACkC,OAAO,CAACR,IAAI,CAAC;UACpB;UACA;UACA1B,MAAM,CAACmC,EAAE,CAAC,WAAW,EAAE,YAAM;YAC3B,IAAI,CAACnC,MAAM,CAACI,SAAS,EAAE;cACrBJ,MAAM,CAACI,SAAS,GAAG,IAAI;cACvBJ,MAAM,CAACkC,OAAO,CAACL,WAAW,CAAC;YAC7B;UACF,CAAC,CAAC;UAEF7B,MAAM,CAACmC,EAAE,CAAC,UAAU,EAAE,YAAM;YAAA,IAAAC,qBAAA;YAC1B,IACE,CAAA/D,gBAAgB,aAAhBA,gBAAgB,wBAAA+D,qBAAA,GAAhB/D,gBAAgB,CAAEM,OAAO,cAAAyD,qBAAA,uBAAzBA,qBAAA,CAA2BC,WAAW,OAAKrC,MAAM,aAANA,MAAM,uBAANA,MAAM,CAAEqC,WAAW,GAC9D;cACArC,MAAM,CAACI,SAAS,GAAG,KAAK;cACxBJ,MAAM,CAACkC,OAAO,CAACR,IAAI,CAAC;YACtB;UACF,CAAC,CAAC;UAEF1B,MAAM,CAACmC,EAAE,CAAC,OAAO,EAAE,YAAM;YAAA,IAAAG,sBAAA;YACvB,IACE,CAAAjE,gBAAgB,aAAhBA,gBAAgB,wBAAAiE,sBAAA,GAAhBjE,gBAAgB,CAAEM,OAAO,cAAA2D,sBAAA,uBAAzBA,sBAAA,CAA2BD,WAAW,OAAKrC,MAAM,aAANA,MAAM,uBAANA,MAAM,CAAEqC,WAAW,GAC9D;cACAjE,gBAAgB,CAAC,IAAI,CAAC;cACtB0C,iBAAiB,CAAC,IAAI,CAAC;YACzB,CAAC,MAAM;cACLA,iBAAiB,CAACC,KAAK,CAAC;YAC1B;UACF,CAAC,CAAC;UAEF,CAAAiB,sBAAA,GAAAzD,cAAc,CAACI,OAAO,cAAAqD,sBAAA,uBAAtBA,sBAAA,CAAwBO,QAAQ,CAACvC,MAAM,CAAC;QAC1C;MACF,CAAC,CAAC;IACJ;EACF,CAAC;EAED,IAAMiC,SAAS,GAAG,SAAZA,SAASA,CAAIlB,KAAa,EAAK;IACnC,OAAO5B,gBAAC,CAACa,MAAM,CAAC,CAACe,KAAK,CAACe,QAAQ,EAAEf,KAAK,CAACgB,SAAS,CAAC,EAAE;MACjD7B,eAAe,EAAEa,KAAK,CAACZ;IACzB,CAAC,CAAC;EACJ,CAAC;EAED,IAAMqC,QAAQ,GAAG,SAAXA,QAAQA,CAAA,EAAS;IACrB,IAAI,CAACzE,GAAG,IAAI,CAACT,KAAK,EAAE;MAClB;IACF;IAEA,IAAMmF,WAAW,GAAG,IAAIC,GAAG,CAAC,CAAC;IAC7BrF,MAAM,CAACiE,OAAO,CAAC,UAACqB,CAAC;MAAA,OAAKF,WAAW,CAACG,GAAG,CAACD,CAAC,CAACxC,EAAE,EAAEwC,CAAC,CAAC;IAAA,EAAC;IAE/C,IAAInE,aAAa,CAACG,OAAO,EAAE;MACzB,IAAIZ,GAAG,CAACkD,QAAQ,CAACzC,aAAa,CAACG,OAAO,CAAC,EAAE;QACvCZ,GAAG,CAACmD,WAAW,CAAC1C,aAAa,CAACG,OAAO,CAAC;MACxC;IACF;IAEAH,aAAa,CAACG,OAAO,GAAGQ,gBAAC,CAACgC,YAAY,CAAC,CAAC;IACxC3C,aAAa,CAACG,OAAO,CAACa,KAAK,CAACzB,GAAG,CAAC;IAEhCT,KAAK,CAACgE,OAAO,CAAC,UAACuB,IAAI,EAAK;MAAA,IAAAC,qBAAA,EAAAC,sBAAA;MACtB,IAAMC,WAAW,GAAGP,WAAW,CAACQ,GAAG,CAACJ,IAAI,CAACK,eAAe,CAAC;MACzD,IAAMC,WAAW,GAAGV,WAAW,CAACQ,GAAG,CAACJ,IAAI,CAACO,eAAe,CAAC;MAEzD,IAAI,CAACJ,WAAW,IAAI,CAACG,WAAW,EAAE;QAChC;MACF;MAEA,IAAME,OAAO,GAAG,CACd,CAACL,WAAW,aAAXA,WAAW,uBAAXA,WAAW,CAAElB,QAAQ,EAAEkB,WAAW,aAAXA,WAAW,uBAAXA,WAAW,CAAEjB,SAAS,CAAC,EAC/C,CAACoB,WAAW,aAAXA,WAAW,uBAAXA,WAAW,CAAErB,QAAQ,EAAEqB,WAAW,aAAXA,WAAW,uBAAXA,WAAW,CAAEpB,SAAS,CAAC,CAChD;MAED,IAAMuB,QAAQ,GAAGnE,gBAAC,CAACmE,QAAQ,CAACD,OAAO,EAAE;QACnCE,KAAK,EAAE,OAAO;QACdC,MAAM,EAAE,CAAC;QACTC,OAAO,EAAE,GAAG;QACZC,YAAY,EAAE;MAChB,CAAC,CAAC;MAEF,CAAAZ,qBAAA,GAAAtE,aAAa,CAACG,OAAO,cAAAmE,qBAAA,uBAArBA,qBAAA,CAAuBP,QAAQ,CAACe,QAAQ,CAAC;MAEzC,IAAMK,SAAS,GAAGxE,gBAAC,CAACyE,iBAAiB,CAACN,QAAQ,EAAE;QAC9CO,QAAQ,EAAE,CACR;UACEC,MAAM,EAAE,EAAE;UACVC,MAAM,EAAE,EAAE;UACVC,MAAM,EAAE7E,gBAAC,CAAC8E,MAAM,CAACC,SAAS,CAAC;YACzBC,SAAS,EAAE,CAAC;YACZC,OAAO,EAAE,KAAK;YACdC,WAAW,EAAE;cACXC,MAAM,EAAE,IAAI;cACZf,KAAK,EAAE,MAAM;cACbC,MAAM,EAAE,CAAC;cACTC,OAAO,EAAE;YACX;UACF,CAAC;QACH,CAAC;MAEL,CAAC,CAAC;MAEF,CAAAV,sBAAA,GAAAvE,aAAa,CAACG,OAAO,cAAAoE,sBAAA,uBAArBA,sBAAA,CAAuBR,QAAQ,CAACoB,SAAS,CAAC;IAC5C,CAAC,CAAC;EACJ,CAAC;EAED,IAAMY,QAAQ,GAAG,SAAXA,QAAQA,CAAA,EAAS;IACrB,IAAI,CAACxG,GAAG,IAAI,CAACR,KAAK,EAAE;MAClB;IACF;IAEA,IAAIkB,aAAa,CAACE,OAAO,EAAE;MACzB,IAAIZ,GAAG,CAACkD,QAAQ,CAACxC,aAAa,CAACE,OAAO,CAAC,EAAE;QACvCZ,GAAG,CAACmD,WAAW,CAACzC,aAAa,CAACE,OAAO,CAAC;MACxC;IACF;IAEAF,aAAa,CAACE,OAAO,GAAGQ,gBAAC,CAACgC,YAAY,CAAC,CAAC;IACxC1C,aAAa,CAACE,OAAO,CAACa,KAAK,CAACzB,GAAG,CAAC;IAEhC,IAAMyG,YAAY,GAAG,SAAfA,YAAYA,CAAA,EAAqC;MAAA,IAAjCjH,KAAc,GAAAkH,SAAA,CAAApD,MAAA,QAAAoD,SAAA,QAAAC,SAAA,GAAAD,SAAA,MAAG,EAAE;MACvC,IAAIE,QAAiB,GAAG,EAAE;MAE1BpH,KAAK,CAAC+D,OAAO,CAAC,UAACsD,IAAW,EAAK;QAC7B,IAAIA,IAAI,CAACC,UAAU,CAACxD,MAAM,GAAG,CAAC,EAAE;UAC9BsD,QAAQ,CAACG,IAAI,CAACF,IAAI,CAAC;QACrB;;QAEA;QACA,IAAIG,KAAK,CAACC,OAAO,CAACJ,IAAI,CAACK,SAAS,CAAC,IAAIL,IAAI,CAACK,SAAS,CAAC5D,MAAM,GAAG,CAAC,EAAE;UAC9DsD,QAAQ,GAAGA,QAAQ,CAACO,MAAM,CAACV,YAAY,CAACI,IAAI,CAACK,SAAS,CAAC,CAAC;QAC1D;MACF,CAAC,CAAC;;MAEF;MACA,WAAAE,mBAAA,CAAArH,OAAA,EACK,IAAI4E,GAAG,CAACiC,QAAQ,CAAC5G,GAAG,CAAC,UAAC6G,IAAI;QAAA,OAAK,CAACA,IAAI,CAACQ,OAAO,EAAER,IAAI,CAAC;MAAA,EAAC,CAAC,CAACrF,MAAM,CAAC,CAAC;IAErE,CAAC;IAED,IAAMoF,QAAQ,GAAGH,YAAY,CAACjH,KAAK,CAAC;IAEpCoH,QAAQ,CAACrD,OAAO,CAAC,UAACsD,IAAI,EAAK;MAAA,IAAAS,qBAAA;MACzB,IAAMjB,OAAO,GAAGjF,gBAAC,CAACiF,OAAO,CAACQ,IAAI,CAACC,UAAU,EAAE;QACzCtB,KAAK,EAAE,OAAO;QACdC,MAAM,EAAE,CAAC;QACTC,OAAO,EAAE,GAAG;QACZC,YAAY,EAAE,CAAC;QACf4B,WAAW,EAAE,KAAK;QAClBpF,eAAe,EAAE0E,IAAI,CAACQ;MACxB,CAAC,CAAC;MAEFhB,OAAO,CAACmB,WAAW,CAACX,IAAI,CAACY,SAAS,EAAE;QAClCC,SAAS,EAAE,IAAI;QACfC,SAAS,EAAE,QAAQ;QACnBC,SAAS,EAAE;MACb,CAAC,CAAC;MAEF,CAAAN,qBAAA,GAAA5G,aAAa,CAACE,OAAO,cAAA0G,qBAAA,uBAArBA,qBAAA,CAAuB9C,QAAQ,CAAC6B,OAAO,CAAC;IAC1C,CAAC,CAAC;EACJ,CAAC;EAED,IAAMwB,QAAQ,GAAG,SAAXA,QAAQA,CAAA,EAAS;IACrB,IAAI7H,GAAG,EAAE;MACP,IACE,CAAAQ,cAAc,aAAdA,cAAc,uBAAdA,cAAc,CAAEI,OAAO,KACvBoG,KAAK,CAACC,OAAO,CAACzG,cAAc,CAACI,OAAO,CAACyC,SAAS,CAAC,CAAC,CAAC,IACjD7C,cAAc,CAACI,OAAO,CAACyC,SAAS,CAAC,CAAC,CAACC,MAAM,GAAG,CAAC,EAC7C;QACAtD,GAAG,CAAC8H,SAAS,CAACtH,cAAc,CAACI,OAAO,CAAC4B,SAAS,CAAC,CAAC,CAAC;MACnD,CAAC,MAAM;QACLxC,GAAG,CAAC+H,OAAO,CAAC,CAAC,SAAS,EAAE,SAAS,CAAC,EAAE,EAAE,CAAC;MACzC;IACF;EACF,CAAC;EAED,IAAApH,gBAAS,EAAC,YAAM;IACd,IAAIX,GAAG,EAAE;MACPwG,QAAQ,CAAC,CAAC;MACV/B,QAAQ,CAAC,CAAC;MACVxB,UAAU,CAAC,CAAC;MACZ4E,QAAQ,CAAC,CAAC;IACZ;EACF,CAAC,EAAE,CAACvI,MAAM,EAAEE,KAAK,EAAED,KAAK,EAAES,GAAG,CAAC,CAAC;EAE/B,OAAOA,GAAG;AACZ,CAAC;AAACgI,OAAA,CAAA5I,MAAA,GAAAA,MAAA"}
257
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_leaflet","_interopRequireDefault","require","_react","_PointIcon","_theme","_MapUtils","useMap","mapRef","points","edges","areas","selectedPoint","updateSelectedPoint","_useState","useState","_useState2","_slicedToArray2","default","map","setMap","_useState3","_useState4","focusedMarker","setFocusedMarker","focusedMarkerRef","useRef","pointsLayerRef","edgesLayerRef","areasLayerRef","useEffect","current","resetAllOthers","mapTypes","baseMaps","leafletMap","mapDefault","satellite","mapTemp","L","renderer","canvas","Object","values","addTo","control","layers","position","off","remove","_pointsLayerRef$curre","eachLayer","marker","options","kando_object_id","id","_isInside","fire","_pointsLayerRef$curre2","getBounds","contains","getLatLng","flyTo","getZoom","duration","animate","handleMarkerClick","point","addMarkers","hasLayer","removeLayer","featureGroup","getLayers","length","forEach","type","has_device","group","hasIssues","icon","getPointIconByType","name","focusedIcon","latitude","longitude","_pointsLayerRef$curre3","getMarker","setIcon","on","_focusedMarkerRef$cur","_leaflet_id","_focusedMarkerRef$cur2","addLayer","addEdges","pointLookup","Map","p","set","edge","_edgesLayerRef$curren","_edgesLayerRef$curren2","sourcePoint","get","source_point_id","targetPoint","target_point_id","latlngs","polyline","color","weight","opacity","smoothFactor","decorator","polylineDecorator","patterns","offset","repeat","symbol","Symbol","arrowHead","pixelSize","polygon","pathOptions","stroke","addAreas","flattenAreas","arguments","undefined","allAreas","area","shape_data","push","Array","isArray","sub_areas","concat","_toConsumableArray2","area_id","_areasLayerRef$curren","interactive","bindTooltip","area_name","permanent","direction","className","focusMap","fitBounds","setView","exports"],"sources":["../../../../src/pages/OperationsPage/Map/useMap.tsx"],"sourcesContent":["import L, { Marker } from 'leaflet';\nimport React, { useEffect, useRef, useState } from 'react';\nimport { getPointIconByType } from 'src/Widgets/Map/points/PointIcon';\nimport { leafletMap } from 'src/styles/theme/theme';\nimport { baseMaps } from 'src/Widgets/Map/MapUtils';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport { IEdge } from 'src/store/edges/models/IEdge';\nimport { IArea } from 'src/store/areas/models/IArea';\n\nexport const useMap = (\n  mapRef: React.RefObject<HTMLDivElement>,\n  points: IPoint[],\n  edges: IEdge[],\n  areas: IArea[],\n  selectedPoint: IPoint | null,\n  updateSelectedPoint: (point: IPoint) => void,\n): L.Map | undefined => {\n  const [map, setMap] = useState<L.Map>();\n  const [focusedMarker, setFocusedMarker] = useState<Marker | null>(null);\n  const focusedMarkerRef = useRef<Marker | null>(null);\n  const pointsLayerRef = useRef<L.FeatureGroup>();\n  const edgesLayerRef = useRef<L.FeatureGroup>();\n  const areasLayerRef = useRef<L.FeatureGroup>();\n\n  useEffect(() => {\n    focusedMarkerRef.current = focusedMarker;\n    resetAllOthers();\n  }, [focusedMarker]);\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: 'bottomright' }).addTo(mapTemp);\n\n    setMap(mapTemp);\n\n    return () => {\n      if (!mapTemp) {\n        return;\n      }\n      mapTemp.off();\n      mapTemp.remove();\n    };\n  }, []);\n\n  const resetAllOthers = () => {\n    pointsLayerRef.current?.eachLayer((marker) => {\n      if (\n        marker.options.kando_object_id !== selectedPoint?.id &&\n        marker._isInside\n      ) {\n        marker.fire('mouseout');\n      }\n    });\n  };\n\n  useEffect(() => {\n    if (selectedPoint === null) {\n      setFocusedMarker(null);\n    } else {\n      pointsLayerRef.current?.eachLayer((marker) => {\n        if (\n          selectedPoint &&\n          marker.options.kando_object_id === selectedPoint?.id\n        ) {\n          if (!map?.getBounds().contains(marker.getLatLng())) {\n            map?.flyTo(marker.getLatLng(), map.getZoom(), {\n              duration: 0.5,\n              animate: false,\n            });\n          }\n          marker.fire('mouseover');\n          setFocusedMarker(marker);\n          return;\n        }\n      });\n    }\n  }, [selectedPoint]);\n\n  const handleMarkerClick = (point) => {\n    updateSelectedPoint(point);\n  };\n\n  const addMarkers = () => {\n    if (!map || !points) {\n      return;\n    }\n\n    if (pointsLayerRef.current) {\n      if (map.hasLayer(pointsLayerRef.current)) {\n        map.removeLayer(pointsLayerRef.current);\n      }\n    }\n\n    pointsLayerRef.current = L.featureGroup();\n    pointsLayerRef.current.addTo(map);\n\n    if (!pointsLayerRef.current.getLayers().length) {\n      points.forEach((point) => {\n        const type =\n          point.has_device === true ||\n          point.group.type === 'Groups::WastewaterTreatmentPlant'\n            ? point.group.type\n            : 'Groups::default';\n        const hasIssues = 'issues' in point && !point.has_device;\n        const icon = getPointIconByType(\n          type,\n          point.name,\n          '',\n          false,\n          true,\n          hasIssues,\n        );\n\n        const focusedIcon = getPointIconByType(\n          type,\n          point.name,\n          '',\n          true,\n          false,\n          hasIssues,\n        );\n\n        if (point.latitude && point.longitude) {\n          let marker = getMarker(point);\n\n          marker.setIcon(icon);\n          // The use of marker._isInside is to overcome the issue that mouseover is endlessly triggered\n          // and we need it only once\n          marker.on('mouseover', () => {\n            if (!marker._isInside) {\n              marker._isInside = true;\n              marker.setIcon(focusedIcon);\n            }\n          });\n\n          marker.on('mouseout', () => {\n            if (\n              focusedMarkerRef?.current?._leaflet_id !== marker?._leaflet_id\n            ) {\n              marker._isInside = false;\n              marker.setIcon(icon);\n            }\n          });\n\n          marker.on('click', () => {\n            if (\n              focusedMarkerRef?.current?._leaflet_id === marker?._leaflet_id\n            ) {\n              setFocusedMarker(null);\n              handleMarkerClick(null);\n            } else {\n              handleMarkerClick(point);\n            }\n          });\n\n          pointsLayerRef.current?.addLayer(marker);\n        }\n      });\n    }\n  };\n\n  const getMarker = (point: IPoint) => {\n    return L.marker([point.latitude, point.longitude], {\n      kando_object_id: point.id,\n    });\n  };\n\n  const addEdges = () => {\n    if (!map || !edges) {\n      return;\n    }\n\n    const pointLookup = new Map();\n    points.forEach((p) => pointLookup.set(p.id, p));\n\n    if (edgesLayerRef.current) {\n      if (map.hasLayer(edgesLayerRef.current)) {\n        map.removeLayer(edgesLayerRef.current);\n      }\n    }\n\n    edgesLayerRef.current = L.featureGroup();\n    edgesLayerRef.current.addTo(map);\n\n    edges.forEach((edge) => {\n      const sourcePoint = pointLookup.get(edge.source_point_id);\n      const targetPoint = pointLookup.get(edge.target_point_id);\n\n      if (!sourcePoint || !targetPoint) {\n        return;\n      }\n\n      const latlngs = [\n        [sourcePoint?.latitude, sourcePoint?.longitude],\n        [targetPoint?.latitude, targetPoint?.longitude],\n      ];\n\n      const polyline = L.polyline(latlngs, {\n        color: 'black',\n        weight: 1,\n        opacity: 0.5,\n        smoothFactor: 1,\n      });\n\n      edgesLayerRef.current?.addLayer(polyline);\n\n      const decorator = L.polylineDecorator(polyline, {\n        patterns: [\n          {\n            offset: 20,\n            repeat: 60,\n            symbol: L.Symbol.arrowHead({\n              pixelSize: 4,\n              polygon: false,\n              pathOptions: {\n                stroke: true,\n                color: '#555',\n                weight: 1,\n                opacity: 0.8,\n              },\n            }),\n          },\n        ],\n      });\n\n      edgesLayerRef.current?.addLayer(decorator);\n    });\n  };\n\n  const addAreas = () => {\n    if (!map || !areas) {\n      return;\n    }\n\n    if (areasLayerRef.current) {\n      if (map.hasLayer(areasLayerRef.current)) {\n        map.removeLayer(areasLayerRef.current);\n      }\n    }\n\n    areasLayerRef.current = L.featureGroup();\n    areasLayerRef.current.addTo(map);\n\n    const flattenAreas = (areas: IArea[] = []): IArea[] => {\n      let allAreas: IArea[] = [];\n\n      areas.forEach((area: IArea) => {\n        if (area.shape_data.length > 0) {\n          allAreas.push(area);\n        }\n\n        // If there are sub_areas, recurse and concatenate\n        if (Array.isArray(area.sub_areas) && area.sub_areas.length > 0) {\n          allAreas = allAreas.concat(flattenAreas(area.sub_areas));\n        }\n      });\n\n      // Remove duplicates\n      return [\n        ...new Map(allAreas.map((area) => [area.area_id, area])).values(),\n      ];\n    };\n\n    const allAreas = flattenAreas(areas);\n\n    allAreas.forEach((area) => {\n      const polygon = L.polygon(area.shape_data, {\n        color: 'black',\n        weight: 1,\n        opacity: 0.8,\n        smoothFactor: 1,\n        interactive: false,\n        kando_object_id: area.area_id,\n      });\n\n      polygon.bindTooltip(area.area_name, {\n        permanent: true,\n        direction: 'center',\n        className: 'area-tooltip',\n      });\n\n      areasLayerRef.current?.addLayer(polygon);\n    });\n  };\n\n  const focusMap = () => {\n    if (map) {\n      if (\n        pointsLayerRef?.current &&\n        Array.isArray(pointsLayerRef.current.getLayers()) &&\n        pointsLayerRef.current.getLayers().length > 0\n      ) {\n        map.fitBounds(pointsLayerRef.current.getBounds());\n      } else {\n        map.setView([32.219157, 34.982481], 12);\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (map) {\n      addAreas();\n      addEdges();\n      addMarkers();\n      focusMap();\n    }\n  }, [points, areas, edges, map]);\n\n  return map;\n};\n"],"mappings":";;;;;;;;;AAAA,IAAAA,QAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,MAAA,GAAAD,OAAA;AACA,IAAAE,UAAA,GAAAF,OAAA;AACA,IAAAG,MAAA,GAAAH,OAAA;AACA,IAAAI,SAAA,GAAAJ,OAAA;AAKO,IAAMK,MAAM,GAAG,SAATA,MAAMA,CACjBC,MAAuC,EACvCC,MAAgB,EAChBC,KAAc,EACdC,KAAc,EACdC,aAA4B,EAC5BC,mBAA4C,EACtB;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,GAA0C,IAAAN,eAAQ,EAAgB,IAAI,CAAC;IAAAO,UAAA,OAAAL,eAAA,CAAAC,OAAA,EAAAG,UAAA;IAAhEE,aAAa,GAAAD,UAAA;IAAEE,gBAAgB,GAAAF,UAAA;EACtC,IAAMG,gBAAgB,GAAG,IAAAC,aAAM,EAAgB,IAAI,CAAC;EACpD,IAAMC,cAAc,GAAG,IAAAD,aAAM,EAAiB,CAAC;EAC/C,IAAME,aAAa,GAAG,IAAAF,aAAM,EAAiB,CAAC;EAC9C,IAAMG,aAAa,GAAG,IAAAH,aAAM,EAAiB,CAAC;EAE9C,IAAAI,gBAAS,EAAC,YAAM;IACdL,gBAAgB,CAACM,OAAO,GAAGR,aAAa;IACxCS,cAAc,CAAC,CAAC;EAClB,CAAC,EAAE,CAACT,aAAa,CAAC,CAAC;EAEnB,IAAAO,gBAAS,EAAC,YAAM;IACd,IAAI,CAACtB,MAAM,CAACuB,OAAO,EAAE;MACnB;IACF;IAEA,IAAME,QAAQ,GAAG,IAAAC,kBAAQ,EAACC,iBAAU,CAACC,UAAU,EAAED,iBAAU,CAACE,SAAS,CAAC;IACtE,IAAMC,OAAO,GAAGC,gBAAC,CAACpB,GAAG,CAACX,MAAM,CAACuB,OAAO,EAAE;MAAES,QAAQ,EAAED,gBAAC,CAACE,MAAM,CAAC;IAAE,CAAC,CAAC;IAE/DC,MAAM,CAACC,MAAM,CAACV,QAAQ,CAAC,CAAC,CAAC,CAAC,CAACW,KAAK,CAACN,OAAO,CAAC;IAEzCC,gBAAC,CAACM,OAAO,CAACC,MAAM,CAACb,QAAQ,EAAE,CAAC,CAAC,EAAE;MAAEc,QAAQ,EAAE;IAAc,CAAC,CAAC,CAACH,KAAK,CAACN,OAAO,CAAC;IAE1ElB,MAAM,CAACkB,OAAO,CAAC;IAEf,OAAO,YAAM;MACX,IAAI,CAACA,OAAO,EAAE;QACZ;MACF;MACAA,OAAO,CAACU,GAAG,CAAC,CAAC;MACbV,OAAO,CAACW,MAAM,CAAC,CAAC;IAClB,CAAC;EACH,CAAC,EAAE,EAAE,CAAC;EAEN,IAAMjB,cAAc,GAAG,SAAjBA,cAAcA,CAAA,EAAS;IAAA,IAAAkB,qBAAA;IAC3B,CAAAA,qBAAA,GAAAvB,cAAc,CAACI,OAAO,cAAAmB,qBAAA,uBAAtBA,qBAAA,CAAwBC,SAAS,CAAC,UAACC,MAAM,EAAK;MAC5C,IACEA,MAAM,CAACC,OAAO,CAACC,eAAe,MAAK1C,aAAa,aAAbA,aAAa,uBAAbA,aAAa,CAAE2C,EAAE,KACpDH,MAAM,CAACI,SAAS,EAChB;QACAJ,MAAM,CAACK,IAAI,CAAC,UAAU,CAAC;MACzB;IACF,CAAC,CAAC;EACJ,CAAC;EAED,IAAA3B,gBAAS,EAAC,YAAM;IACd,IAAIlB,aAAa,KAAK,IAAI,EAAE;MAC1BY,gBAAgB,CAAC,IAAI,CAAC;IACxB,CAAC,MAAM;MAAA,IAAAkC,sBAAA;MACL,CAAAA,sBAAA,GAAA/B,cAAc,CAACI,OAAO,cAAA2B,sBAAA,uBAAtBA,sBAAA,CAAwBP,SAAS,CAAC,UAACC,MAAM,EAAK;QAC5C,IACExC,aAAa,IACbwC,MAAM,CAACC,OAAO,CAACC,eAAe,MAAK1C,aAAa,aAAbA,aAAa,uBAAbA,aAAa,CAAE2C,EAAE,GACpD;UACA,IAAI,EAACpC,GAAG,aAAHA,GAAG,uBAAHA,GAAG,CAAEwC,SAAS,CAAC,CAAC,CAACC,QAAQ,CAACR,MAAM,CAACS,SAAS,CAAC,CAAC,CAAC,GAAE;YAClD1C,GAAG,aAAHA,GAAG,uBAAHA,GAAG,CAAE2C,KAAK,CAACV,MAAM,CAACS,SAAS,CAAC,CAAC,EAAE1C,GAAG,CAAC4C,OAAO,CAAC,CAAC,EAAE;cAC5CC,QAAQ,EAAE,GAAG;cACbC,OAAO,EAAE;YACX,CAAC,CAAC;UACJ;UACAb,MAAM,CAACK,IAAI,CAAC,WAAW,CAAC;UACxBjC,gBAAgB,CAAC4B,MAAM,CAAC;UACxB;QACF;MACF,CAAC,CAAC;IACJ;EACF,CAAC,EAAE,CAACxC,aAAa,CAAC,CAAC;EAEnB,IAAMsD,iBAAiB,GAAG,SAApBA,iBAAiBA,CAAIC,KAAK,EAAK;IACnCtD,mBAAmB,CAACsD,KAAK,CAAC;EAC5B,CAAC;EAED,IAAMC,UAAU,GAAG,SAAbA,UAAUA,CAAA,EAAS;IACvB,IAAI,CAACjD,GAAG,IAAI,CAACV,MAAM,EAAE;MACnB;IACF;IAEA,IAAIkB,cAAc,CAACI,OAAO,EAAE;MAC1B,IAAIZ,GAAG,CAACkD,QAAQ,CAAC1C,cAAc,CAACI,OAAO,CAAC,EAAE;QACxCZ,GAAG,CAACmD,WAAW,CAAC3C,cAAc,CAACI,OAAO,CAAC;MACzC;IACF;IAEAJ,cAAc,CAACI,OAAO,GAAGQ,gBAAC,CAACgC,YAAY,CAAC,CAAC;IACzC5C,cAAc,CAACI,OAAO,CAACa,KAAK,CAACzB,GAAG,CAAC;IAEjC,IAAI,CAACQ,cAAc,CAACI,OAAO,CAACyC,SAAS,CAAC,CAAC,CAACC,MAAM,EAAE;MAC9ChE,MAAM,CAACiE,OAAO,CAAC,UAACP,KAAK,EAAK;QACxB,IAAMQ,IAAI,GACRR,KAAK,CAACS,UAAU,KAAK,IAAI,IACzBT,KAAK,CAACU,KAAK,CAACF,IAAI,KAAK,kCAAkC,GACnDR,KAAK,CAACU,KAAK,CAACF,IAAI,GAChB,iBAAiB;QACvB,IAAMG,SAAS,GAAG,QAAQ,IAAIX,KAAK,IAAI,CAACA,KAAK,CAACS,UAAU;QACxD,IAAMG,IAAI,GAAG,IAAAC,6BAAkB,EAC7BL,IAAI,EACJR,KAAK,CAACc,IAAI,EACV,EAAE,EACF,KAAK,EACL,IAAI,EACJH,SACF,CAAC;QAED,IAAMI,WAAW,GAAG,IAAAF,6BAAkB,EACpCL,IAAI,EACJR,KAAK,CAACc,IAAI,EACV,EAAE,EACF,IAAI,EACJ,KAAK,EACLH,SACF,CAAC;QAED,IAAIX,KAAK,CAACgB,QAAQ,IAAIhB,KAAK,CAACiB,SAAS,EAAE;UAAA,IAAAC,sBAAA;UACrC,IAAIjC,MAAM,GAAGkC,SAAS,CAACnB,KAAK,CAAC;UAE7Bf,MAAM,CAACmC,OAAO,CAACR,IAAI,CAAC;UACpB;UACA;UACA3B,MAAM,CAACoC,EAAE,CAAC,WAAW,EAAE,YAAM;YAC3B,IAAI,CAACpC,MAAM,CAACI,SAAS,EAAE;cACrBJ,MAAM,CAACI,SAAS,GAAG,IAAI;cACvBJ,MAAM,CAACmC,OAAO,CAACL,WAAW,CAAC;YAC7B;UACF,CAAC,CAAC;UAEF9B,MAAM,CAACoC,EAAE,CAAC,UAAU,EAAE,YAAM;YAAA,IAAAC,qBAAA;YAC1B,IACE,CAAAhE,gBAAgB,aAAhBA,gBAAgB,wBAAAgE,qBAAA,GAAhBhE,gBAAgB,CAAEM,OAAO,cAAA0D,qBAAA,uBAAzBA,qBAAA,CAA2BC,WAAW,OAAKtC,MAAM,aAANA,MAAM,uBAANA,MAAM,CAAEsC,WAAW,GAC9D;cACAtC,MAAM,CAACI,SAAS,GAAG,KAAK;cACxBJ,MAAM,CAACmC,OAAO,CAACR,IAAI,CAAC;YACtB;UACF,CAAC,CAAC;UAEF3B,MAAM,CAACoC,EAAE,CAAC,OAAO,EAAE,YAAM;YAAA,IAAAG,sBAAA;YACvB,IACE,CAAAlE,gBAAgB,aAAhBA,gBAAgB,wBAAAkE,sBAAA,GAAhBlE,gBAAgB,CAAEM,OAAO,cAAA4D,sBAAA,uBAAzBA,sBAAA,CAA2BD,WAAW,OAAKtC,MAAM,aAANA,MAAM,uBAANA,MAAM,CAAEsC,WAAW,GAC9D;cACAlE,gBAAgB,CAAC,IAAI,CAAC;cACtB0C,iBAAiB,CAAC,IAAI,CAAC;YACzB,CAAC,MAAM;cACLA,iBAAiB,CAACC,KAAK,CAAC;YAC1B;UACF,CAAC,CAAC;UAEF,CAAAkB,sBAAA,GAAA1D,cAAc,CAACI,OAAO,cAAAsD,sBAAA,uBAAtBA,sBAAA,CAAwBO,QAAQ,CAACxC,MAAM,CAAC;QAC1C;MACF,CAAC,CAAC;IACJ;EACF,CAAC;EAED,IAAMkC,SAAS,GAAG,SAAZA,SAASA,CAAInB,KAAa,EAAK;IACnC,OAAO5B,gBAAC,CAACa,MAAM,CAAC,CAACe,KAAK,CAACgB,QAAQ,EAAEhB,KAAK,CAACiB,SAAS,CAAC,EAAE;MACjD9B,eAAe,EAAEa,KAAK,CAACZ;IACzB,CAAC,CAAC;EACJ,CAAC;EAED,IAAMsC,QAAQ,GAAG,SAAXA,QAAQA,CAAA,EAAS;IACrB,IAAI,CAAC1E,GAAG,IAAI,CAACT,KAAK,EAAE;MAClB;IACF;IAEA,IAAMoF,WAAW,GAAG,IAAIC,GAAG,CAAC,CAAC;IAC7BtF,MAAM,CAACiE,OAAO,CAAC,UAACsB,CAAC;MAAA,OAAKF,WAAW,CAACG,GAAG,CAACD,CAAC,CAACzC,EAAE,EAAEyC,CAAC,CAAC;IAAA,EAAC;IAE/C,IAAIpE,aAAa,CAACG,OAAO,EAAE;MACzB,IAAIZ,GAAG,CAACkD,QAAQ,CAACzC,aAAa,CAACG,OAAO,CAAC,EAAE;QACvCZ,GAAG,CAACmD,WAAW,CAAC1C,aAAa,CAACG,OAAO,CAAC;MACxC;IACF;IAEAH,aAAa,CAACG,OAAO,GAAGQ,gBAAC,CAACgC,YAAY,CAAC,CAAC;IACxC3C,aAAa,CAACG,OAAO,CAACa,KAAK,CAACzB,GAAG,CAAC;IAEhCT,KAAK,CAACgE,OAAO,CAAC,UAACwB,IAAI,EAAK;MAAA,IAAAC,qBAAA,EAAAC,sBAAA;MACtB,IAAMC,WAAW,GAAGP,WAAW,CAACQ,GAAG,CAACJ,IAAI,CAACK,eAAe,CAAC;MACzD,IAAMC,WAAW,GAAGV,WAAW,CAACQ,GAAG,CAACJ,IAAI,CAACO,eAAe,CAAC;MAEzD,IAAI,CAACJ,WAAW,IAAI,CAACG,WAAW,EAAE;QAChC;MACF;MAEA,IAAME,OAAO,GAAG,CACd,CAACL,WAAW,aAAXA,WAAW,uBAAXA,WAAW,CAAElB,QAAQ,EAAEkB,WAAW,aAAXA,WAAW,uBAAXA,WAAW,CAAEjB,SAAS,CAAC,EAC/C,CAACoB,WAAW,aAAXA,WAAW,uBAAXA,WAAW,CAAErB,QAAQ,EAAEqB,WAAW,aAAXA,WAAW,uBAAXA,WAAW,CAAEpB,SAAS,CAAC,CAChD;MAED,IAAMuB,QAAQ,GAAGpE,gBAAC,CAACoE,QAAQ,CAACD,OAAO,EAAE;QACnCE,KAAK,EAAE,OAAO;QACdC,MAAM,EAAE,CAAC;QACTC,OAAO,EAAE,GAAG;QACZC,YAAY,EAAE;MAChB,CAAC,CAAC;MAEF,CAAAZ,qBAAA,GAAAvE,aAAa,CAACG,OAAO,cAAAoE,qBAAA,uBAArBA,qBAAA,CAAuBP,QAAQ,CAACe,QAAQ,CAAC;MAEzC,IAAMK,SAAS,GAAGzE,gBAAC,CAAC0E,iBAAiB,CAACN,QAAQ,EAAE;QAC9CO,QAAQ,EAAE,CACR;UACEC,MAAM,EAAE,EAAE;UACVC,MAAM,EAAE,EAAE;UACVC,MAAM,EAAE9E,gBAAC,CAAC+E,MAAM,CAACC,SAAS,CAAC;YACzBC,SAAS,EAAE,CAAC;YACZC,OAAO,EAAE,KAAK;YACdC,WAAW,EAAE;cACXC,MAAM,EAAE,IAAI;cACZf,KAAK,EAAE,MAAM;cACbC,MAAM,EAAE,CAAC;cACTC,OAAO,EAAE;YACX;UACF,CAAC;QACH,CAAC;MAEL,CAAC,CAAC;MAEF,CAAAV,sBAAA,GAAAxE,aAAa,CAACG,OAAO,cAAAqE,sBAAA,uBAArBA,sBAAA,CAAuBR,QAAQ,CAACoB,SAAS,CAAC;IAC5C,CAAC,CAAC;EACJ,CAAC;EAED,IAAMY,QAAQ,GAAG,SAAXA,QAAQA,CAAA,EAAS;IACrB,IAAI,CAACzG,GAAG,IAAI,CAACR,KAAK,EAAE;MAClB;IACF;IAEA,IAAIkB,aAAa,CAACE,OAAO,EAAE;MACzB,IAAIZ,GAAG,CAACkD,QAAQ,CAACxC,aAAa,CAACE,OAAO,CAAC,EAAE;QACvCZ,GAAG,CAACmD,WAAW,CAACzC,aAAa,CAACE,OAAO,CAAC;MACxC;IACF;IAEAF,aAAa,CAACE,OAAO,GAAGQ,gBAAC,CAACgC,YAAY,CAAC,CAAC;IACxC1C,aAAa,CAACE,OAAO,CAACa,KAAK,CAACzB,GAAG,CAAC;IAEhC,IAAM0G,YAAY,GAAG,SAAfA,YAAYA,CAAA,EAAqC;MAAA,IAAjClH,KAAc,GAAAmH,SAAA,CAAArD,MAAA,QAAAqD,SAAA,QAAAC,SAAA,GAAAD,SAAA,MAAG,EAAE;MACvC,IAAIE,QAAiB,GAAG,EAAE;MAE1BrH,KAAK,CAAC+D,OAAO,CAAC,UAACuD,IAAW,EAAK;QAC7B,IAAIA,IAAI,CAACC,UAAU,CAACzD,MAAM,GAAG,CAAC,EAAE;UAC9BuD,QAAQ,CAACG,IAAI,CAACF,IAAI,CAAC;QACrB;;QAEA;QACA,IAAIG,KAAK,CAACC,OAAO,CAACJ,IAAI,CAACK,SAAS,CAAC,IAAIL,IAAI,CAACK,SAAS,CAAC7D,MAAM,GAAG,CAAC,EAAE;UAC9DuD,QAAQ,GAAGA,QAAQ,CAACO,MAAM,CAACV,YAAY,CAACI,IAAI,CAACK,SAAS,CAAC,CAAC;QAC1D;MACF,CAAC,CAAC;;MAEF;MACA,WAAAE,mBAAA,CAAAtH,OAAA,EACK,IAAI6E,GAAG,CAACiC,QAAQ,CAAC7G,GAAG,CAAC,UAAC8G,IAAI;QAAA,OAAK,CAACA,IAAI,CAACQ,OAAO,EAAER,IAAI,CAAC;MAAA,EAAC,CAAC,CAACtF,MAAM,CAAC,CAAC;IAErE,CAAC;IAED,IAAMqF,QAAQ,GAAGH,YAAY,CAAClH,KAAK,CAAC;IAEpCqH,QAAQ,CAACtD,OAAO,CAAC,UAACuD,IAAI,EAAK;MAAA,IAAAS,qBAAA;MACzB,IAAMjB,OAAO,GAAGlF,gBAAC,CAACkF,OAAO,CAACQ,IAAI,CAACC,UAAU,EAAE;QACzCtB,KAAK,EAAE,OAAO;QACdC,MAAM,EAAE,CAAC;QACTC,OAAO,EAAE,GAAG;QACZC,YAAY,EAAE,CAAC;QACf4B,WAAW,EAAE,KAAK;QAClBrF,eAAe,EAAE2E,IAAI,CAACQ;MACxB,CAAC,CAAC;MAEFhB,OAAO,CAACmB,WAAW,CAACX,IAAI,CAACY,SAAS,EAAE;QAClCC,SAAS,EAAE,IAAI;QACfC,SAAS,EAAE,QAAQ;QACnBC,SAAS,EAAE;MACb,CAAC,CAAC;MAEF,CAAAN,qBAAA,GAAA7G,aAAa,CAACE,OAAO,cAAA2G,qBAAA,uBAArBA,qBAAA,CAAuB9C,QAAQ,CAAC6B,OAAO,CAAC;IAC1C,CAAC,CAAC;EACJ,CAAC;EAED,IAAMwB,QAAQ,GAAG,SAAXA,QAAQA,CAAA,EAAS;IACrB,IAAI9H,GAAG,EAAE;MACP,IACE,CAAAQ,cAAc,aAAdA,cAAc,uBAAdA,cAAc,CAAEI,OAAO,KACvBqG,KAAK,CAACC,OAAO,CAAC1G,cAAc,CAACI,OAAO,CAACyC,SAAS,CAAC,CAAC,CAAC,IACjD7C,cAAc,CAACI,OAAO,CAACyC,SAAS,CAAC,CAAC,CAACC,MAAM,GAAG,CAAC,EAC7C;QACAtD,GAAG,CAAC+H,SAAS,CAACvH,cAAc,CAACI,OAAO,CAAC4B,SAAS,CAAC,CAAC,CAAC;MACnD,CAAC,MAAM;QACLxC,GAAG,CAACgI,OAAO,CAAC,CAAC,SAAS,EAAE,SAAS,CAAC,EAAE,EAAE,CAAC;MACzC;IACF;EACF,CAAC;EAED,IAAArH,gBAAS,EAAC,YAAM;IACd,IAAIX,GAAG,EAAE;MACPyG,QAAQ,CAAC,CAAC;MACV/B,QAAQ,CAAC,CAAC;MACVzB,UAAU,CAAC,CAAC;MACZ6E,QAAQ,CAAC,CAAC;IACZ;EACF,CAAC,EAAE,CAACxI,MAAM,EAAEE,KAAK,EAAED,KAAK,EAAES,GAAG,CAAC,CAAC;EAE/B,OAAOA,GAAG;AACZ,CAAC;AAACiI,OAAA,CAAA7I,MAAA,GAAAA,MAAA"}
@@ -0,0 +1,151 @@
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
+ require("./OperationsPage.scss");
11
+ var _react = _interopRequireWildcard(require("react"));
12
+ var _reactRedux = require("react-redux");
13
+ var _reactBootstrap = require("react-bootstrap");
14
+ var _actions = require("store/context/actions");
15
+ var _actions2 = require("store/points/actions");
16
+ var _actions3 = require("store/edges/actions");
17
+ var _actions4 = require("store/areas/actions");
18
+ var _Map = require("./Map/Map");
19
+ var _LeftPanel = _interopRequireDefault(require("./LeftPanel"));
20
+ var _RightPanel = _interopRequireDefault(require("./RightPanel"));
21
+ var _KandoAlert = require("ui-kit/Alert/KandoAlert");
22
+ var _Loader = require("../DashboardMap/Loader");
23
+ 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); }
24
+ 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; }
25
+ var OperationsContainerPage = function OperationsContainerPage(_ref) {
26
+ var _ref$fileId = _ref.fileId,
27
+ fileId = _ref$fileId === void 0 ? '' : _ref$fileId,
28
+ _ref$onlyMonitored = _ref.onlyMonitored,
29
+ onlyMonitored = _ref$onlyMonitored === void 0 ? true : _ref$onlyMonitored,
30
+ _ref$filterOptions = _ref.filterOptions,
31
+ filterOptions = _ref$filterOptions === void 0 ? [] : _ref$filterOptions;
32
+ var dispatch = (0, _reactRedux.useDispatch)();
33
+ var edges_data = (0, _reactRedux.useSelector)(function (state) {
34
+ return state.edges_data;
35
+ });
36
+ var areas_data = (0, _reactRedux.useSelector)(function (state) {
37
+ return state.areas_data;
38
+ });
39
+ var global_data = (0, _reactRedux.useSelector)(function (state) {
40
+ return state.global_data;
41
+ });
42
+ var points_data = (0, _reactRedux.useSelector)(function (state) {
43
+ return state.points_data;
44
+ });
45
+ var _useState = (0, _react.useState)(false),
46
+ _useState2 = (0, _slicedToArray2.default)(_useState, 2),
47
+ showRightPanel = _useState2[0],
48
+ setShowRightPanel = _useState2[1];
49
+ var _useState3 = (0, _react.useState)(null),
50
+ _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
51
+ selectedPoint = _useState4[0],
52
+ setSelectedPoint = _useState4[1];
53
+ var _useState5 = (0, _react.useState)(false),
54
+ _useState6 = (0, _slicedToArray2.default)(_useState5, 2),
55
+ isSmallScreen = _useState6[0],
56
+ setIsSmallScreen = _useState6[1];
57
+ var handleSelectPoint = function handleSelectPoint(newPoint) {
58
+ if (newPoint === null || newPoint.id === (selectedPoint === null || selectedPoint === void 0 ? void 0 : selectedPoint.id)) {
59
+ setSelectedPoint(null);
60
+ } else {
61
+ setSelectedPoint(newPoint);
62
+ }
63
+ };
64
+ (0, _react.useEffect)(function () {
65
+ dispatch((0, _actions.updateNavContext)({
66
+ name: 'operations'
67
+ }));
68
+ var checkScreenSize = function checkScreenSize() {
69
+ setIsSmallScreen(window.innerWidth < 768); // or any breakpoint
70
+ };
71
+
72
+ // Run on mount:
73
+ checkScreenSize();
74
+
75
+ // Also update if the user resizes the browser:
76
+ window.addEventListener('resize', checkScreenSize);
77
+ return function () {
78
+ window.removeEventListener('resize', checkScreenSize);
79
+ };
80
+ }, []);
81
+ (0, _react.useEffect)(function () {
82
+ if (global_data.waterAuthorityId) {
83
+ dispatch((0, _actions2.fetchPoints)(global_data.waterAuthorityId, '', true, fileId));
84
+ dispatch((0, _actions3.fetchEdges)(global_data.waterAuthorityId));
85
+ dispatch((0, _actions4.fetchAreas)(global_data.waterAuthorityId));
86
+ }
87
+ return function () {
88
+ setSelectedPoint(null);
89
+ dispatch((0, _actions2.clearPoints)());
90
+ };
91
+ }, [global_data.waterAuthorityId]);
92
+ var points = (0, _react.useMemo)(function () {
93
+ var _points_data$items;
94
+ return ((_points_data$items = points_data.items) === null || _points_data$items === void 0 ? void 0 : _points_data$items.filter(function (point) {
95
+ return point.latitude && point.longitude;
96
+ })) || [];
97
+ }, [points_data.items]);
98
+ var monitoredPoints = (0, _react.useMemo)(function () {
99
+ return points.filter(function (point) {
100
+ return point.has_device;
101
+ }) || [];
102
+ }, [points]);
103
+ var showLeftPanel = (0, _react.useMemo)(function () {
104
+ return /*#__PURE__*/_react.default.createElement(_LeftPanel.default, {
105
+ filterOptions: filterOptions,
106
+ points: onlyMonitored ? monitoredPoints : points_data.items,
107
+ selectedPoint: selectedPoint,
108
+ setSelectedPoint: handleSelectPoint,
109
+ onlyMonitored: onlyMonitored
110
+ });
111
+ }, [monitoredPoints, selectedPoint, onlyMonitored, filterOptions, points_data.items]);
112
+ (0, _react.useEffect)(function () {
113
+ if (selectedPoint) {
114
+ setShowRightPanel(true);
115
+ } else {
116
+ setShowRightPanel(false);
117
+ }
118
+ }, [selectedPoint]);
119
+ var onRightPanelClose = function onRightPanelClose() {
120
+ setSelectedPoint(null);
121
+ };
122
+ if (isSmallScreen) {
123
+ return /*#__PURE__*/_react.default.createElement(_KandoAlert.KandoAlert, {
124
+ variant: "success",
125
+ header: "Notice"
126
+ }, /*#__PURE__*/_react.default.createElement("h5", null, 'This page is not supported on small screens'), /*#__PURE__*/_react.default.createElement("p", null, 'Please use a larger screen for the best experience.'));
127
+ }
128
+ return /*#__PURE__*/_react.default.createElement(_reactBootstrap.Container, {
129
+ fluid: true,
130
+ className: "vh-90 p-0"
131
+ }, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Row, null, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Col, {
132
+ sm: 3,
133
+ className: "left-panel"
134
+ }, showLeftPanel), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Col, {
135
+ className: "map-column",
136
+ sm: 9
137
+ }, edges_data.isFetching || areas_data.isFetching ? /*#__PURE__*/_react.default.createElement(_Loader.Loader, null) : /*#__PURE__*/_react.default.createElement(_Map.Map, {
138
+ points: points,
139
+ edges: edges_data.items,
140
+ areas: areas_data.newAreas,
141
+ selectedPoint: selectedPoint,
142
+ updateSelectedPoint: handleSelectPoint
143
+ }), /*#__PURE__*/_react.default.createElement(_RightPanel.default, {
144
+ className: "right-panel ".concat(showRightPanel ? 'open' : ''),
145
+ point: selectedPoint,
146
+ onClose: onRightPanelClose
147
+ }))));
148
+ };
149
+ var _default = OperationsContainerPage;
150
+ exports.default = _default;
151
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["require","_react","_interopRequireWildcard","_reactRedux","_reactBootstrap","_actions","_actions2","_actions3","_actions4","_Map","_LeftPanel","_interopRequireDefault","_RightPanel","_KandoAlert","_Loader","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","OperationsContainerPage","_ref","_ref$fileId","fileId","_ref$onlyMonitored","onlyMonitored","_ref$filterOptions","filterOptions","dispatch","useDispatch","edges_data","useSelector","state","areas_data","global_data","points_data","_useState","useState","_useState2","_slicedToArray2","showRightPanel","setShowRightPanel","_useState3","_useState4","selectedPoint","setSelectedPoint","_useState5","_useState6","isSmallScreen","setIsSmallScreen","handleSelectPoint","newPoint","id","useEffect","updateNavContext","name","checkScreenSize","window","innerWidth","addEventListener","removeEventListener","waterAuthorityId","fetchPoints","fetchEdges","fetchAreas","clearPoints","points","useMemo","_points_data$items","items","filter","point","latitude","longitude","monitoredPoints","has_device","showLeftPanel","createElement","onRightPanelClose","KandoAlert","variant","header","Container","fluid","className","Row","Col","sm","isFetching","Loader","Map","edges","areas","newAreas","updateSelectedPoint","concat","onClose","_default","exports"],"sources":["../../../src/pages/OperationsPage/OperationsContainerPage.tsx"],"sourcesContent":["import './OperationsPage.scss';\nimport React, { useEffect, useMemo, useState } from 'react';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { Col, Container, Row } from 'react-bootstrap';\nimport { updateNavContext } from 'src/store/context/actions';\nimport { clearPoints, fetchPoints } from 'src/store/points/actions';\nimport { fetchEdges } from 'src/store/edges/actions';\nimport { fetchAreas } from 'src/store/areas/actions';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport { Map } from './Map/Map';\nimport LeftPanel from './LeftPanel';\nimport RightPanel from './RightPanel';\nimport { KandoAlert } from 'src/ui-kit/Alert/KandoAlert';\nimport { Loader } from '../DashboardMap/Loader';\n\nconst OperationsContainerPage = ({\n  fileId = '',\n  onlyMonitored = true,\n  filterOptions = [],\n}: {\n  fileId?: string;\n  onlyMonitored?: boolean;\n  filterOptions: { value: string; label: string }[];\n}) => {\n  const dispatch = useDispatch();\n  const edges_data = useSelector((state) => state.edges_data);\n  const areas_data = useSelector((state) => state.areas_data);\n  const global_data = useSelector((state) => state.global_data);\n  const points_data = useSelector((state) => state.points_data);\n  const [showRightPanel, setShowRightPanel] = useState(false);\n  const [selectedPoint, setSelectedPoint] = useState<IPoint | null>(null);\n  const [isSmallScreen, setIsSmallScreen] = useState(false);\n\n  const handleSelectPoint = (newPoint: IPoint) => {\n    if (newPoint === null || newPoint.id === selectedPoint?.id) {\n      setSelectedPoint(null);\n    } else {\n      setSelectedPoint(newPoint);\n    }\n  };\n\n  useEffect(() => {\n    dispatch(updateNavContext({ name: 'operations' }));\n\n    const checkScreenSize = () => {\n      setIsSmallScreen(window.innerWidth < 768); // or any breakpoint\n    };\n\n    // Run on mount:\n    checkScreenSize();\n\n    // Also update if the user resizes the browser:\n    window.addEventListener('resize', checkScreenSize);\n    return () => {\n      window.removeEventListener('resize', checkScreenSize);\n    };\n  }, []);\n\n  useEffect(() => {\n    if (global_data.waterAuthorityId) {\n      dispatch(fetchPoints(global_data.waterAuthorityId, '', true, fileId));\n      dispatch(fetchEdges(global_data.waterAuthorityId));\n      dispatch(fetchAreas(global_data.waterAuthorityId));\n    }\n\n    return () => {\n      setSelectedPoint(null);\n      dispatch(clearPoints());\n    };\n  }, [global_data.waterAuthorityId]);\n\n  const points = useMemo(() => {\n    return (\n      points_data.items?.filter(\n        (point: IPoint) => point.latitude && point.longitude,\n      ) || []\n    );\n  }, [points_data.items]);\n\n  const monitoredPoints = useMemo(() => {\n    return points.filter((point: IPoint) => point.has_device) || [];\n  }, [points]);\n\n  const showLeftPanel = useMemo(() => {\n    return (\n      <LeftPanel\n        filterOptions={filterOptions}\n        points={onlyMonitored ? monitoredPoints : points_data.items}\n        selectedPoint={selectedPoint}\n        setSelectedPoint={handleSelectPoint}\n        onlyMonitored={onlyMonitored}\n      />\n    );\n  }, [\n    monitoredPoints,\n    selectedPoint,\n    onlyMonitored,\n    filterOptions,\n    points_data.items,\n  ]);\n\n  useEffect(() => {\n    if (selectedPoint) {\n      setShowRightPanel(true);\n    } else {\n      setShowRightPanel(false);\n    }\n  }, [selectedPoint]);\n\n  const onRightPanelClose = () => {\n    setSelectedPoint(null);\n  };\n\n  if (isSmallScreen) {\n    return (\n      <KandoAlert variant=\"success\" header=\"Notice\">\n        <h5>{'This page is not supported on small screens'}</h5>\n        <p>{'Please use a larger screen for the best experience.'}</p>\n      </KandoAlert>\n    );\n  }\n\n  return (\n    <Container fluid className=\"vh-90 p-0\">\n      <Row>\n        <Col sm={3} className=\"left-panel\">\n          {showLeftPanel}\n        </Col>\n        <Col className=\"map-column\" sm={9}>\n          {edges_data.isFetching || areas_data.isFetching ? (\n            <Loader />\n          ) : (\n            <Map\n              points={points}\n              edges={edges_data.items}\n              areas={areas_data.newAreas}\n              selectedPoint={selectedPoint}\n              updateSelectedPoint={handleSelectPoint}\n            />\n          )}\n          <RightPanel\n            className={`right-panel ${showRightPanel ? 'open' : ''}`}\n            point={selectedPoint}\n            onClose={onRightPanelClose}\n          />\n        </Col>\n      </Row>\n    </Container>\n  );\n};\n\nexport default OperationsContainerPage;\n"],"mappings":"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"}
@@ -0,0 +1,29 @@
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 _react = _interopRequireDefault(require("react"));
9
+ var _reactRouterDom = require("react-router-dom");
10
+ var _OperationsContainerPage = _interopRequireDefault(require("./OperationsContainerPage"));
11
+ var OperationsFilePage = function OperationsFilePage() {
12
+ var _useParams = (0, _reactRouterDom.useParams)(),
13
+ fileId = _useParams.fileId;
14
+ var filterOptions = [{
15
+ value: 'address',
16
+ label: 'No address'
17
+ }, {
18
+ value: 'sector',
19
+ label: 'Default sector'
20
+ }];
21
+ return /*#__PURE__*/_react.default.createElement(_OperationsContainerPage.default, {
22
+ fileId: fileId,
23
+ onlyMonitored: false,
24
+ filterOptions: filterOptions
25
+ });
26
+ };
27
+ var _default = OperationsFilePage;
28
+ exports.default = _default;
29
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9yZWFjdFJvdXRlckRvbSIsIl9PcGVyYXRpb25zQ29udGFpbmVyUGFnZSIsIk9wZXJhdGlvbnNGaWxlUGFnZSIsIl91c2VQYXJhbXMiLCJ1c2VQYXJhbXMiLCJmaWxlSWQiLCJmaWx0ZXJPcHRpb25zIiwidmFsdWUiLCJsYWJlbCIsImRlZmF1bHQiLCJjcmVhdGVFbGVtZW50Iiwib25seU1vbml0b3JlZCIsIl9kZWZhdWx0IiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9wYWdlcy9PcGVyYXRpb25zUGFnZS9PcGVyYXRpb25zRmlsZVBhZ2UudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyB1c2VQYXJhbXMgfSBmcm9tICdyZWFjdC1yb3V0ZXItZG9tJztcbmltcG9ydCBPcGVyYXRpb25zQ29udGFpbmVyUGFnZSBmcm9tICcuL09wZXJhdGlvbnNDb250YWluZXJQYWdlJztcblxuY29uc3QgT3BlcmF0aW9uc0ZpbGVQYWdlID0gKCkgPT4ge1xuICBjb25zdCB7IGZpbGVJZCB9ID0gdXNlUGFyYW1zKCk7XG4gIGNvbnN0IGZpbHRlck9wdGlvbnMgPSBbXG4gICAgeyB2YWx1ZTogJ2FkZHJlc3MnLCBsYWJlbDogJ05vIGFkZHJlc3MnIH0sXG4gICAgeyB2YWx1ZTogJ3NlY3RvcicsIGxhYmVsOiAnRGVmYXVsdCBzZWN0b3InIH0sXG4gIF07XG5cbiAgcmV0dXJuIChcbiAgICA8T3BlcmF0aW9uc0NvbnRhaW5lclBhZ2VcbiAgICAgIGZpbGVJZD17ZmlsZUlkfVxuICAgICAgb25seU1vbml0b3JlZD17ZmFsc2V9XG4gICAgICBmaWx0ZXJPcHRpb25zPXtmaWx0ZXJPcHRpb25zfVxuICAgIC8+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBPcGVyYXRpb25zRmlsZVBhZ2U7XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQSxJQUFBQSxNQUFBLEdBQUFDLHNCQUFBLENBQUFDLE9BQUE7QUFDQSxJQUFBQyxlQUFBLEdBQUFELE9BQUE7QUFDQSxJQUFBRSx3QkFBQSxHQUFBSCxzQkFBQSxDQUFBQyxPQUFBO0FBRUEsSUFBTUcsa0JBQWtCLEdBQUcsU0FBckJBLGtCQUFrQkEsQ0FBQSxFQUFTO0VBQy9CLElBQUFDLFVBQUEsR0FBbUIsSUFBQUMseUJBQVMsRUFBQyxDQUFDO0lBQXRCQyxNQUFNLEdBQUFGLFVBQUEsQ0FBTkUsTUFBTTtFQUNkLElBQU1DLGFBQWEsR0FBRyxDQUNwQjtJQUFFQyxLQUFLLEVBQUUsU0FBUztJQUFFQyxLQUFLLEVBQUU7RUFBYSxDQUFDLEVBQ3pDO0lBQUVELEtBQUssRUFBRSxRQUFRO0lBQUVDLEtBQUssRUFBRTtFQUFpQixDQUFDLENBQzdDO0VBRUQsb0JBQ0VYLE1BQUEsQ0FBQVksT0FBQSxDQUFBQyxhQUFBLENBQUNULHdCQUFBLENBQUFRLE9BQXVCO0lBQ3RCSixNQUFNLEVBQUVBLE1BQU87SUFDZk0sYUFBYSxFQUFFLEtBQU07SUFDckJMLGFBQWEsRUFBRUE7RUFBYyxDQUM5QixDQUFDO0FBRU4sQ0FBQztBQUFDLElBQUFNLFFBQUEsR0FFYVYsa0JBQWtCO0FBQUFXLE9BQUEsQ0FBQUosT0FBQSxHQUFBRyxRQUFBIn0=
@@ -0,0 +1,33 @@
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 _react = _interopRequireDefault(require("react"));
9
+ var _OperationsContainerPage = _interopRequireDefault(require("./OperationsContainerPage"));
10
+ var OperationsUtilityPage = function OperationsUtilityPage() {
11
+ var filterOptions = [{
12
+ value: 'installation_height',
13
+ label: 'Installation Height'
14
+ }, {
15
+ value: 'distance',
16
+ label: 'Distance'
17
+ }, {
18
+ value: 'no_parent',
19
+ label: 'No Parent'
20
+ }, {
21
+ value: 'diameter',
22
+ label: 'Diameter'
23
+ }, {
24
+ value: 'water_consumption',
25
+ label: 'Water Consumption'
26
+ }];
27
+ return /*#__PURE__*/_react.default.createElement(_OperationsContainerPage.default, {
28
+ filterOptions: filterOptions
29
+ });
30
+ };
31
+ var _default = OperationsUtilityPage;
32
+ exports.default = _default;
33
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9PcGVyYXRpb25zQ29udGFpbmVyUGFnZSIsIk9wZXJhdGlvbnNVdGlsaXR5UGFnZSIsImZpbHRlck9wdGlvbnMiLCJ2YWx1ZSIsImxhYmVsIiwiZGVmYXVsdCIsImNyZWF0ZUVsZW1lbnQiLCJfZGVmYXVsdCIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcGFnZXMvT3BlcmF0aW9uc1BhZ2UvT3BlcmF0aW9uc1V0aWxpdHlQYWdlLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IE9wZXJhdGlvbnNDb250YWluZXJQYWdlIGZyb20gJy4vT3BlcmF0aW9uc0NvbnRhaW5lclBhZ2UnO1xuXG5jb25zdCBPcGVyYXRpb25zVXRpbGl0eVBhZ2UgPSAoKSA9PiB7XG4gIGNvbnN0IGZpbHRlck9wdGlvbnMgPSBbXG4gICAgeyB2YWx1ZTogJ2luc3RhbGxhdGlvbl9oZWlnaHQnLCBsYWJlbDogJ0luc3RhbGxhdGlvbiBIZWlnaHQnIH0sXG4gICAgeyB2YWx1ZTogJ2Rpc3RhbmNlJywgbGFiZWw6ICdEaXN0YW5jZScgfSxcbiAgICB7IHZhbHVlOiAnbm9fcGFyZW50JywgbGFiZWw6ICdObyBQYXJlbnQnIH0sXG4gICAgeyB2YWx1ZTogJ2RpYW1ldGVyJywgbGFiZWw6ICdEaWFtZXRlcicgfSxcbiAgICB7IHZhbHVlOiAnd2F0ZXJfY29uc3VtcHRpb24nLCBsYWJlbDogJ1dhdGVyIENvbnN1bXB0aW9uJyB9LFxuICBdO1xuICByZXR1cm4gPE9wZXJhdGlvbnNDb250YWluZXJQYWdlIGZpbHRlck9wdGlvbnM9e2ZpbHRlck9wdGlvbnN9IC8+O1xufTtcblxuZXhwb3J0IGRlZmF1bHQgT3BlcmF0aW9uc1V0aWxpdHlQYWdlO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUEsSUFBQUEsTUFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsd0JBQUEsR0FBQUYsc0JBQUEsQ0FBQUMsT0FBQTtBQUVBLElBQU1FLHFCQUFxQixHQUFHLFNBQXhCQSxxQkFBcUJBLENBQUEsRUFBUztFQUNsQyxJQUFNQyxhQUFhLEdBQUcsQ0FDcEI7SUFBRUMsS0FBSyxFQUFFLHFCQUFxQjtJQUFFQyxLQUFLLEVBQUU7RUFBc0IsQ0FBQyxFQUM5RDtJQUFFRCxLQUFLLEVBQUUsVUFBVTtJQUFFQyxLQUFLLEVBQUU7RUFBVyxDQUFDLEVBQ3hDO0lBQUVELEtBQUssRUFBRSxXQUFXO0lBQUVDLEtBQUssRUFBRTtFQUFZLENBQUMsRUFDMUM7SUFBRUQsS0FBSyxFQUFFLFVBQVU7SUFBRUMsS0FBSyxFQUFFO0VBQVcsQ0FBQyxFQUN4QztJQUFFRCxLQUFLLEVBQUUsbUJBQW1CO0lBQUVDLEtBQUssRUFBRTtFQUFvQixDQUFDLENBQzNEO0VBQ0Qsb0JBQU9QLE1BQUEsQ0FBQVEsT0FBQSxDQUFBQyxhQUFBLENBQUNOLHdCQUFBLENBQUFLLE9BQXVCO0lBQUNILGFBQWEsRUFBRUE7RUFBYyxDQUFFLENBQUM7QUFDbEUsQ0FBQztBQUFDLElBQUFLLFFBQUEsR0FFYU4scUJBQXFCO0FBQUFPLE9BQUEsQ0FBQUgsT0FBQSxHQUFBRSxRQUFBIn0=