@kando-env/kando-ui 1.2.437-alpha.2 → 1.2.437-alpha.3

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.
@@ -60,6 +60,7 @@ var PointOfEvent = function PointOfEvent(_ref) {
60
60
  (0, _jquery.default)('#sector').empty().append(sector);
61
61
  }, 200);
62
62
  var attachClickEvent = function attachClickEvent(selector, observation) {
63
+ (0, _jquery.default)(document.body).off('click', selector); // Remove previous handlers
63
64
  (0, _jquery.default)(document.body).on('click', selector, function () {
64
65
  dispatch((0, _actions.closeFloatingGraph)());
65
66
  dispatch((0, _actions.openFloatingGraph)(true, observation, point));
@@ -154,4 +155,4 @@ var PointOfEvent = function PointOfEvent(_ref) {
154
155
  return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null);
155
156
  };
156
157
  exports.PointOfEvent = PointOfEvent;
157
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_PointUtils","_reactDom","_interopRequireDefault","_TimeFormat","_Sector","_jquery","_actions","_reactRedux","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof3","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","PointOfEvent","_ref","map","point","event","dispatch","useDispatch","bindPopupToPoint","obs","arguments","length","undefined","layers","_layers","_loop","property","includes","kando_object","kando_object_id","id","bindPopup","popupContent","minWidth","on","e","firstSeen","document","createElement","lastSeen","sector","ReactDOM","render","timestamp","start_time","time_zone","last_seen_time","sectorName","group","sector_name","sectorIconName","sector_icon_name","width","setTimeout","$","empty","append","attachClickEvent","selector","observation","body","closeFloatingGraph","openFloatingGraph","openPopup","v","_ret","_typeof2","useEffect","device_status","focused","observations","filter","point_id","Fragment","exports"],"sources":["../../../../src/Widgets/Map/events/PointOfEvent.tsx"],"sourcesContent":["import React, { useEffect } from 'react';\nimport { popupContent } from '../points/PointUtils';\nimport ReactDOM from 'react-dom';\nimport TimeFormat from '../../../utilities/TimeFormat';\nimport Sector from '../../../components/Sector';\nimport $ from 'jquery';\nimport {\n  closeFloatingGraph,\n  openFloatingGraph,\n} from '../../../store/global/actions';\nimport { IPoint } from '../../../store/points/models/IPoint';\nimport { IEvent } from '../../../store/events/models/IEvent';\nimport { useDispatch } from 'react-redux';\n\ntype IProps = {\n  map: any;\n  point: IPoint;\n  event: IEvent;\n};\n\nexport const PointOfEvent: React.FC<IProps> = ({ map, point, event }) => {\n  const dispatch = useDispatch();\n  // const { flow_rate_unit: flowRateUnit } = useSelector(\n  //   (state: any) => state.permissions.user_info,\n  // );\n\n  const bindPopupToPoint = (obs: any = null) => {\n    let layers = map._layers;\n    for (const property in layers) {\n      if (\n        ['Point', 'Observation'].includes(layers[property].kando_object) &&\n        layers[property].kando_object_id === point.id\n      ) {\n        layers[property].bindPopup(popupContent(obs, point), {\n          minWidth: 200,\n        });\n        layers[property].on('popupopen', function (e: any) {\n          let firstSeen = document.createElement('div');\n          let lastSeen = document.createElement('div');\n          let sector = document.createElement('div');\n\n          if (obs !== null) {\n            ReactDOM.render(\n              <TimeFormat\n                timestamp={obs.start_time}\n                time_zone={obs.time_zone}\n              />,\n              firstSeen,\n            );\n            ReactDOM.render(\n              <TimeFormat\n                timestamp={obs.last_seen_time}\n                time_zone={obs.time_zone}\n              />,\n              lastSeen,\n            );\n          } else {\n            ReactDOM.render(\n              <Sector\n                sectorName={point.group.sector_name}\n                sectorIconName={point.group.sector_icon_name}\n                width=\"37\"\n              />,\n              sector,\n            );\n          }\n\n          setTimeout(() => {\n            $('#first-seen-popup').empty().append(firstSeen);\n            $('#last-seen-popup').empty().append(lastSeen);\n            $('#sector').empty().append(sector);\n          }, 200);\n\n          let attachClickEvent = (selector: string, observation: any) => {\n            $(document.body).on('click', selector, () => {\n              dispatch(closeFloatingGraph());\n              dispatch(openFloatingGraph(true, observation, point));\n            });\n          };\n\n          if (obs !== null) {\n            attachClickEvent('.popup-graph-icon-' + obs.id, obs);\n          } else {\n            attachClickEvent('.popup-graph-icon-' + point.id, null);\n          }\n        });\n        layers[property].on('click', () => {\n          layers[property].openPopup();\n        });\n        return;\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (!map || !point || !event) return;\n\n    // if (isCollectorUnmonitored(point)) return;\n\n    // let markerLocation: LatLngTuple = [point['latitude'], point['longitude']];\n    // let layerGroup = L.layerGroup();\n\n    // createBubblePoint(\n    //   markerLocation,\n    //   point,\n    //   map,\n    //   event.hovered,\n    //   layerGroup,\n    //   flowRateUnit,\n    // );\n\n    if (point.device_status !== 'regular' && event.focused) {\n      let obs = event.observations.filter(\n        (obs) => obs.point_id === point.id,\n      )[0];\n\n      bindPopupToPoint(obs);\n    }\n\n    // if (event.focused)\n    //   createSamplingIcons(\n    //     markerLocation,\n    //     event,\n    //     point,\n    //     map,\n    //     event.hovered,\n    //     layerGroup,\n    //   );\n    // let hasPrimaryIcon = matchIconToPoint(point, event) !== null;\n\n    // if (pointIsObservation(event, point) && event.focused) {\n    //   createObservationIconPoint(\n    //     markerLocation,\n    //     hasPrimaryIcon,\n    //     map,\n    //     point,\n    //     event,\n    //     event.hovered,\n    //     layerGroup,\n    //   );\n    // }\n    // layerGroup.addTo(map);\n\n    // iconZoomControl(map);\n    // if (event.hovered) {\n    //   return function cleanup() {\n    //     // UNBIND POPUP\n    //     removeFromMap(map, point, 'ObservationHovered');\n    //     removeFromMap(map, point, 'PointHovered');\n    //     removeFromMap(map, point, 'SamplingHovered');\n    //     removeFromMap(map, point, 'IconNumberHovered');\n    //   };\n    // } else {\n    //   return function cleanup() {\n    //     // UNBIND POPUP\n    //     removeFromMap(map, point, 'Observation');\n    //     removeFromMap(map, point, 'Point');\n    //     removeFromMap(map, point, 'Sampling');\n    //     removeFromMap(map, point, 'IconNumber');\n    //   };\n    // }\n  }, [event.focused]);\n\n  return <></>;\n};\n"],"mappings":"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"}
158
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_PointUtils","_reactDom","_interopRequireDefault","_TimeFormat","_Sector","_jquery","_actions","_reactRedux","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof3","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","PointOfEvent","_ref","map","point","event","dispatch","useDispatch","bindPopupToPoint","obs","arguments","length","undefined","layers","_layers","_loop","property","includes","kando_object","kando_object_id","id","bindPopup","popupContent","minWidth","on","e","firstSeen","document","createElement","lastSeen","sector","ReactDOM","render","timestamp","start_time","time_zone","last_seen_time","sectorName","group","sector_name","sectorIconName","sector_icon_name","width","setTimeout","$","empty","append","attachClickEvent","selector","observation","body","off","closeFloatingGraph","openFloatingGraph","openPopup","v","_ret","_typeof2","useEffect","device_status","focused","observations","filter","point_id","Fragment","exports"],"sources":["../../../../src/Widgets/Map/events/PointOfEvent.tsx"],"sourcesContent":["import React, { useEffect } from 'react';\nimport { popupContent } from '../points/PointUtils';\nimport ReactDOM from 'react-dom';\nimport TimeFormat from '../../../utilities/TimeFormat';\nimport Sector from '../../../components/Sector';\nimport $ from 'jquery';\nimport {\n  closeFloatingGraph,\n  openFloatingGraph,\n} from '../../../store/global/actions';\nimport { IPoint } from '../../../store/points/models/IPoint';\nimport { IEvent } from '../../../store/events/models/IEvent';\nimport { useDispatch } from 'react-redux';\n\ntype IProps = {\n  map: any;\n  point: IPoint;\n  event: IEvent;\n};\n\nexport const PointOfEvent: React.FC<IProps> = ({ map, point, event }) => {\n  const dispatch = useDispatch();\n  // const { flow_rate_unit: flowRateUnit } = useSelector(\n  //   (state: any) => state.permissions.user_info,\n  // );\n\n  const bindPopupToPoint = (obs: any = null) => {\n    let layers = map._layers;\n    for (const property in layers) {\n      if (\n        ['Point', 'Observation'].includes(layers[property].kando_object) &&\n        layers[property].kando_object_id === point.id\n      ) {\n        layers[property].bindPopup(popupContent(obs, point), {\n          minWidth: 200,\n        });\n        layers[property].on('popupopen', function (e: any) {\n          let firstSeen = document.createElement('div');\n          let lastSeen = document.createElement('div');\n          let sector = document.createElement('div');\n\n          if (obs !== null) {\n            ReactDOM.render(\n              <TimeFormat\n                timestamp={obs.start_time}\n                time_zone={obs.time_zone}\n              />,\n              firstSeen,\n            );\n            ReactDOM.render(\n              <TimeFormat\n                timestamp={obs.last_seen_time}\n                time_zone={obs.time_zone}\n              />,\n              lastSeen,\n            );\n          } else {\n            ReactDOM.render(\n              <Sector\n                sectorName={point.group.sector_name}\n                sectorIconName={point.group.sector_icon_name}\n                width=\"37\"\n              />,\n              sector,\n            );\n          }\n\n          setTimeout(() => {\n            $('#first-seen-popup').empty().append(firstSeen);\n            $('#last-seen-popup').empty().append(lastSeen);\n            $('#sector').empty().append(sector);\n          }, 200);\n\n          let attachClickEvent = (selector: string, observation: any) => {\n            $(document.body).off('click', selector); // Remove previous handlers\n            $(document.body).on('click', selector, () => {\n              dispatch(closeFloatingGraph());\n              dispatch(openFloatingGraph(true, observation, point));\n            });\n          };\n\n          if (obs !== null) {\n            attachClickEvent('.popup-graph-icon-' + obs.id, obs);\n          } else {\n            attachClickEvent('.popup-graph-icon-' + point.id, null);\n          }\n        });\n        layers[property].on('click', () => {\n          layers[property].openPopup();\n        });\n        return;\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (!map || !point || !event) return;\n\n    // if (isCollectorUnmonitored(point)) return;\n\n    // let markerLocation: LatLngTuple = [point['latitude'], point['longitude']];\n    // let layerGroup = L.layerGroup();\n\n    // createBubblePoint(\n    //   markerLocation,\n    //   point,\n    //   map,\n    //   event.hovered,\n    //   layerGroup,\n    //   flowRateUnit,\n    // );\n\n    if (point.device_status !== 'regular' && event.focused) {\n      let obs = event.observations.filter(\n        (obs) => obs.point_id === point.id,\n      )[0];\n\n      bindPopupToPoint(obs);\n    }\n\n    // if (event.focused)\n    //   createSamplingIcons(\n    //     markerLocation,\n    //     event,\n    //     point,\n    //     map,\n    //     event.hovered,\n    //     layerGroup,\n    //   );\n    // let hasPrimaryIcon = matchIconToPoint(point, event) !== null;\n\n    // if (pointIsObservation(event, point) && event.focused) {\n    //   createObservationIconPoint(\n    //     markerLocation,\n    //     hasPrimaryIcon,\n    //     map,\n    //     point,\n    //     event,\n    //     event.hovered,\n    //     layerGroup,\n    //   );\n    // }\n    // layerGroup.addTo(map);\n\n    // iconZoomControl(map);\n    // if (event.hovered) {\n    //   return function cleanup() {\n    //     // UNBIND POPUP\n    //     removeFromMap(map, point, 'ObservationHovered');\n    //     removeFromMap(map, point, 'PointHovered');\n    //     removeFromMap(map, point, 'SamplingHovered');\n    //     removeFromMap(map, point, 'IconNumberHovered');\n    //   };\n    // } else {\n    //   return function cleanup() {\n    //     // UNBIND POPUP\n    //     removeFromMap(map, point, 'Observation');\n    //     removeFromMap(map, point, 'Point');\n    //     removeFromMap(map, point, 'Sampling');\n    //     removeFromMap(map, point, 'IconNumber');\n    //   };\n    // }\n  }, [event.focused]);\n\n  return <></>;\n};\n"],"mappings":"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"}
@@ -24,29 +24,23 @@ var PointMarkers = function PointMarkers(props) {
24
24
  var isPointBelongToGroupTypes = function isPointBelongToGroupTypes(point) {
25
25
  return (0, _PointUtils.pointIsWWTP)(point) || (0, _PointUtils.pointIsFactory)(point) || point.group.type === 'Groups::Collectors' && point.has_device || point.group.type === 'Groups::PumpStation';
26
26
  };
27
-
28
- // const pointHasCoordinates = (point: IPoint) => {
29
- // const lat = point.latitude;
30
- // const lng = point.longitude;
31
- // const isValid =
32
- // typeof lat === 'number' &&
33
- // typeof lng === 'number' &&
34
- // !isNaN(lat) &&
35
- // !isNaN(lng);
36
- // if (!isValid) {
37
- // console.warn(`Point ${point.id} has invalid coordinates: ${lat}, ${lng}`);
38
- // }
39
- // return isValid;
40
- // };
41
-
27
+ var pointHasCoordinates = function pointHasCoordinates(point) {
28
+ var lat = point.latitude;
29
+ var lng = point.longitude;
30
+ var isValid = typeof lat === 'number' && typeof lng === 'number' && !isNaN(lat) && !isNaN(lng);
31
+ if (!isValid) {
32
+ console.warn("Point ".concat(point.id, " has invalid coordinates: ").concat(lat, ", ").concat(lng));
33
+ }
34
+ return isValid;
35
+ };
42
36
  var filterStatement = function filterStatement(point) {
43
- return isPointBelongToGroupTypes(point);
37
+ return isPointBelongToGroupTypes(point) && pointHasCoordinates(point);
44
38
  };
45
- var filteredPoints = function filteredPoints() {
39
+ var filteredPoints = (0, _react.useMemo)(function () {
46
40
  return points.filter(function (point) {
47
41
  return filterStatement(point);
48
42
  });
49
- };
43
+ }, [points]);
50
44
 
51
45
  // const globalData = useSelector(
52
46
  // (state: ReturnType<typeof appReducer>) => state.global_data,
@@ -161,7 +155,7 @@ var PointMarkers = function PointMarkers(props) {
161
155
  // }
162
156
  }
163
157
  }, [rerender, points]);
164
- return /*#__PURE__*/_react.default.createElement("div", null, points.length !== 0 && filteredPoints().map(function (point) {
158
+ return /*#__PURE__*/_react.default.createElement("div", null, points.length !== 0 && filteredPoints.map(function (point) {
165
159
  return /*#__PURE__*/_react.default.createElement(_PointMarker.default, {
166
160
  map: map,
167
161
  point: point,
@@ -173,4 +167,4 @@ var PointMarkers = function PointMarkers(props) {
173
167
  }));
174
168
  };
175
169
  exports.PointMarkers = PointMarkers;
176
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_PointMarker","_interopRequireDefault","_PointUtils","_reactRedux","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","PointMarkers","props","points","map","factoriesGroup","wwtpsGroup","collectorsGroup","rerender","isPointBelongToGroupTypes","point","pointIsWWTP","pointIsFactory","group","type","has_device","filterStatement","filteredPoints","filter","userInfo","useSelector","state","permissions","user_info","useEffect","addLayerGroup","removeLayerGroup","createElement","length","id","layerGroup","flowRateUnit","flow_rate_unit","exports"],"sources":["../../../../src/Widgets/Map/points/PointMarkers.tsx"],"sourcesContent":["import React, { useEffect } from 'react';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport PointMarker from './PointMarker';\nimport {\n  addLayerGroup,\n  removeLayerGroup,\n  pointIsFactory,\n  pointIsWWTP,\n} from './PointUtils';\nimport { useSelector } from 'react-redux';\n\ntype Props = {\n  map: any;\n  points: any;\n  includeUnmonitoredPoints: boolean;\n  rerender: string;\n  factoriesGroup: any;\n  wwtpsGroup: any;\n  collectorsGroup: any;\n  forEventsView?: boolean;\n};\n\nexport const PointMarkers: React.FC<Props> = (props) => {\n  const { points, map, factoriesGroup, wwtpsGroup, collectorsGroup, rerender } =\n    props;\n\n  // This function is used to determine if a point should be included in the map.\n  const isPointBelongToGroupTypes = (point: IPoint) => {\n    return (\n      pointIsWWTP(point) ||\n      pointIsFactory(point) ||\n      (point.group.type === 'Groups::Collectors' && point.has_device) ||\n      point.group.type === 'Groups::PumpStation'\n    );\n  };\n\n  // const pointHasCoordinates = (point: IPoint) => {\n  //   const lat = point.latitude;\n  //   const lng = point.longitude;\n  //   const isValid =\n  //     typeof lat === 'number' &&\n  //     typeof lng === 'number' &&\n  //     !isNaN(lat) &&\n  //     !isNaN(lng);\n  //   if (!isValid) {\n  //     console.warn(`Point ${point.id} has invalid coordinates: ${lat}, ${lng}`);\n  //   }\n  //   return isValid;\n  // };\n\n  const filterStatement = (point) => {\n    return isPointBelongToGroupTypes(point);\n  };\n\n  const filteredPoints = () => {\n    return points.filter((point: IPoint) => filterStatement(point));\n  };\n\n  // const globalData = useSelector(\n  //   (state: ReturnType<typeof appReducer>) => state.global_data,\n  // );\n\n  const userInfo = useSelector((state) => state.permissions.user_info);\n\n  // const [layersToRemove, setLayersToRemove] = useState<any[]>([]);\n\n  // const removeEventPointsFromCluster = (uniqeIds, localLayersToRemove) => {\n  //   if (!factoriesGroup || !map) {\n  //     console.warn('Either factoriesGroup or map is undefined.');\n  //     return;\n  //   }\n\n  //   // Refresh clusters to update internal structures.\n  //   factoriesGroup.refreshClusters();\n\n  //   uniqeIds.forEach((id) => {\n  //     for (const property in map._layers) {\n  //       const layer = map._layers[property];\n  //       // Check that the layer exists, is of type 'Point', has the expected id,\n  //       // and that it implements getLatLng.\n  //       if (\n  //         layer &&\n  //         layer.kando_object === 'Point' &&\n  //         layer.kando_object_id === id &&\n  //         typeof layer.getLatLng === 'function' &&\n  //         typeof layer._zoom === 'number'\n  //       ) {\n  //         localLayersToRemove.push(layer);\n  //       }\n  //     }\n  //   });\n\n  //   // Filter out duplicates and any undefined layers.\n  //   const uniqueLayers = localLayersToRemove.filter(\n  //     (layer, index, self) =>\n  //       layer &&\n  //       typeof layer.getLatLng === 'function' &&\n  //       index ===\n  //         self.findIndex((l) => l.kando_object_id === layer.kando_object_id),\n  //   );\n\n  //   setLayersToRemove(uniqueLayers);\n  //   factoriesGroup.removeLayers(uniqueLayers);\n  // };\n\n  // const addEventPointsToCluster = () => {\n  //   let layersToDraw = [];\n  //   let layersIds = layersToRemove.map((layer) => layer.kando_object_id);\n  //   let uniqeIds = [...new Set(layersIds)];\n  //   uniqeIds.forEach((id) => {\n  //     layersToDraw.push(\n  //       layersToRemove.find((layer) => layer.kando_object_id === id),\n  //     );\n  //   });\n\n  //   layersToDraw.forEach((layer) => {\n  //     let point = points.find((point) => point.id === layer.kando_object_id);\n  //     point && bindPopupToMarker(point, layer, userInfo.flow_rate_unit);\n  //   });\n  //   factoriesGroup.addLayers(layersToDraw);\n  // };\n\n  // const makeSureThereAreNoDuplicates = () => {\n  //   let localLayersToRemove = [];\n\n  //   if (eventsData.focusedEvent) {\n  //     let obsIds = eventsData.focusedEvent.observations.map(\n  //       (obs) => obs.point_id,\n  //     );\n  //     let uniqeIds = [...new Set(obsIds)];\n  //     removeEventPointsFromCluster(uniqeIds, localLayersToRemove);\n  //   } else {\n  //     addEventPointsToCluster();\n  //   }\n  // };\n\n  useEffect(() => {\n    if (map) {\n      // if (forEventsView) {\n      //   // In events view, always show all layers\n      //   addLayerGroup(map, factoriesGroup);\n      //   addLayerGroup(map, wwtpsGroup);\n      //   addLayerGroup(map, collectorsGroup);\n      // } else {\n      switch (rerender) {\n        case 'XLarge':\n          addLayerGroup(map, wwtpsGroup);\n          // factories group has a parent layer in map.tsx\n          // so we don't need to remove it here\n          // removeLayerGroup(map, factoriesGroup);\n          removeLayerGroup(map, collectorsGroup);\n          removeLayerGroup(map, factoriesGroup);\n          break;\n        case 'Large':\n        case 'MLarge':\n        case 'Medium':\n        case 'Small':\n          // we are handling factoriesParentGroup in map.tsx\n          // addLayerGroup(map, factoriesGroup);\n          addLayerGroup(map, wwtpsGroup);\n          addLayerGroup(map, collectorsGroup);\n          addLayerGroup(map, factoriesGroup);\n          break;\n        default:\n          break;\n      }\n      // }\n    }\n  }, [rerender, points]);\n\n  return (\n    <div>\n      {points.length !== 0 &&\n        filteredPoints().map((point: IPoint) => (\n          <PointMarker\n            map={map}\n            point={point}\n            key={point.id}\n            rerender={rerender}\n            layerGroup={\n              point.group.type === 'Groups::Factory'\n                ? factoriesGroup\n                : point.group.type === 'Groups::WastewaterTreatmentPlant'\n                ? wwtpsGroup\n                : collectorsGroup\n            }\n            flowRateUnit={userInfo.flow_rate_unit}\n          />\n        ))}\n    </div>\n  );\n};\n"],"mappings":"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"}
170
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_PointMarker","_interopRequireDefault","_PointUtils","_reactRedux","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","PointMarkers","props","points","map","factoriesGroup","wwtpsGroup","collectorsGroup","rerender","isPointBelongToGroupTypes","point","pointIsWWTP","pointIsFactory","group","type","has_device","pointHasCoordinates","lat","latitude","lng","longitude","isValid","isNaN","console","warn","concat","id","filterStatement","filteredPoints","useMemo","filter","userInfo","useSelector","state","permissions","user_info","useEffect","addLayerGroup","removeLayerGroup","createElement","length","layerGroup","flowRateUnit","flow_rate_unit","exports"],"sources":["../../../../src/Widgets/Map/points/PointMarkers.tsx"],"sourcesContent":["import React, { useEffect, useMemo } from 'react';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport PointMarker from './PointMarker';\nimport {\n  addLayerGroup,\n  removeLayerGroup,\n  pointIsFactory,\n  pointIsWWTP,\n} from './PointUtils';\nimport { useSelector } from 'react-redux';\n\ntype Props = {\n  map: any;\n  points: any;\n  includeUnmonitoredPoints: boolean;\n  rerender: string;\n  factoriesGroup: any;\n  wwtpsGroup: any;\n  collectorsGroup: any;\n  forEventsView?: boolean;\n};\n\nexport const PointMarkers: React.FC<Props> = (props) => {\n  const { points, map, factoriesGroup, wwtpsGroup, collectorsGroup, rerender } =\n    props;\n\n  // This function is used to determine if a point should be included in the map.\n  const isPointBelongToGroupTypes = (point: IPoint) => {\n    return (\n      pointIsWWTP(point) ||\n      pointIsFactory(point) ||\n      (point.group.type === 'Groups::Collectors' && point.has_device) ||\n      point.group.type === 'Groups::PumpStation'\n    );\n  };\n\n  const pointHasCoordinates = (point: IPoint) => {\n    const lat = point.latitude;\n    const lng = point.longitude;\n    const isValid =\n      typeof lat === 'number' &&\n      typeof lng === 'number' &&\n      !isNaN(lat) &&\n      !isNaN(lng);\n    if (!isValid) {\n      console.warn(`Point ${point.id} has invalid coordinates: ${lat}, ${lng}`);\n    }\n    return isValid;\n  };\n\n  const filterStatement = (point) => {\n    return isPointBelongToGroupTypes(point) && pointHasCoordinates(point);\n  };\n\n  const filteredPoints = useMemo(() => {\n    return points.filter((point: IPoint) => filterStatement(point));\n  }, [points]);\n\n  // const globalData = useSelector(\n  //   (state: ReturnType<typeof appReducer>) => state.global_data,\n  // );\n\n  const userInfo = useSelector((state) => state.permissions.user_info);\n\n  // const [layersToRemove, setLayersToRemove] = useState<any[]>([]);\n\n  // const removeEventPointsFromCluster = (uniqeIds, localLayersToRemove) => {\n  //   if (!factoriesGroup || !map) {\n  //     console.warn('Either factoriesGroup or map is undefined.');\n  //     return;\n  //   }\n\n  //   // Refresh clusters to update internal structures.\n  //   factoriesGroup.refreshClusters();\n\n  //   uniqeIds.forEach((id) => {\n  //     for (const property in map._layers) {\n  //       const layer = map._layers[property];\n  //       // Check that the layer exists, is of type 'Point', has the expected id,\n  //       // and that it implements getLatLng.\n  //       if (\n  //         layer &&\n  //         layer.kando_object === 'Point' &&\n  //         layer.kando_object_id === id &&\n  //         typeof layer.getLatLng === 'function' &&\n  //         typeof layer._zoom === 'number'\n  //       ) {\n  //         localLayersToRemove.push(layer);\n  //       }\n  //     }\n  //   });\n\n  //   // Filter out duplicates and any undefined layers.\n  //   const uniqueLayers = localLayersToRemove.filter(\n  //     (layer, index, self) =>\n  //       layer &&\n  //       typeof layer.getLatLng === 'function' &&\n  //       index ===\n  //         self.findIndex((l) => l.kando_object_id === layer.kando_object_id),\n  //   );\n\n  //   setLayersToRemove(uniqueLayers);\n  //   factoriesGroup.removeLayers(uniqueLayers);\n  // };\n\n  // const addEventPointsToCluster = () => {\n  //   let layersToDraw = [];\n  //   let layersIds = layersToRemove.map((layer) => layer.kando_object_id);\n  //   let uniqeIds = [...new Set(layersIds)];\n  //   uniqeIds.forEach((id) => {\n  //     layersToDraw.push(\n  //       layersToRemove.find((layer) => layer.kando_object_id === id),\n  //     );\n  //   });\n\n  //   layersToDraw.forEach((layer) => {\n  //     let point = points.find((point) => point.id === layer.kando_object_id);\n  //     point && bindPopupToMarker(point, layer, userInfo.flow_rate_unit);\n  //   });\n  //   factoriesGroup.addLayers(layersToDraw);\n  // };\n\n  // const makeSureThereAreNoDuplicates = () => {\n  //   let localLayersToRemove = [];\n\n  //   if (eventsData.focusedEvent) {\n  //     let obsIds = eventsData.focusedEvent.observations.map(\n  //       (obs) => obs.point_id,\n  //     );\n  //     let uniqeIds = [...new Set(obsIds)];\n  //     removeEventPointsFromCluster(uniqeIds, localLayersToRemove);\n  //   } else {\n  //     addEventPointsToCluster();\n  //   }\n  // };\n\n  useEffect(() => {\n    if (map) {\n      // if (forEventsView) {\n      //   // In events view, always show all layers\n      //   addLayerGroup(map, factoriesGroup);\n      //   addLayerGroup(map, wwtpsGroup);\n      //   addLayerGroup(map, collectorsGroup);\n      // } else {\n      switch (rerender) {\n        case 'XLarge':\n          addLayerGroup(map, wwtpsGroup);\n          // factories group has a parent layer in map.tsx\n          // so we don't need to remove it here\n          // removeLayerGroup(map, factoriesGroup);\n          removeLayerGroup(map, collectorsGroup);\n          removeLayerGroup(map, factoriesGroup);\n          break;\n        case 'Large':\n        case 'MLarge':\n        case 'Medium':\n        case 'Small':\n          // we are handling factoriesParentGroup in map.tsx\n          // addLayerGroup(map, factoriesGroup);\n          addLayerGroup(map, wwtpsGroup);\n          addLayerGroup(map, collectorsGroup);\n          addLayerGroup(map, factoriesGroup);\n          break;\n        default:\n          break;\n      }\n      // }\n    }\n  }, [rerender, points]);\n\n  return (\n    <div>\n      {points.length !== 0 &&\n        filteredPoints.map((point: IPoint) => (\n          <PointMarker\n            map={map}\n            point={point}\n            key={point.id}\n            rerender={rerender}\n            layerGroup={\n              point.group.type === 'Groups::Factory'\n                ? factoriesGroup\n                : point.group.type === 'Groups::WastewaterTreatmentPlant'\n                ? wwtpsGroup\n                : collectorsGroup\n            }\n            flowRateUnit={userInfo.flow_rate_unit}\n          />\n        ))}\n    </div>\n  );\n};\n"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
 
3
- var packageJsonVersion = "1.2.437-alpha.2";
3
+ var packageJsonVersion = "1.2.437-alpha.3";
4
4
  if (typeof packageJsonVersion === 'string') {
5
5
  // eslint-disable-next-line no-console
6
6
  console.log("%c Kando UI %c v".concat(packageJsonVersion, " "), 'font-size: 15px; background-color: #fff; color: #e20f53;', 'font-weight: bold; font-size: 15px; background-color: #e20f53; color: #fff;', "with NODE_ENV=".concat(process.env.NODE_ENV));
@@ -124,9 +124,25 @@ var EventsMapContainer = function EventsMapContainer(props) {
124
124
  // );
125
125
 
126
126
  var areaToCenterBy = (0, _react.useMemo)(function () {
127
- if (!mappedAreas || mappedAreas.length === 0) return null;
128
- return (0, _EventsMapContainerHelpers.getAreasToCenterBy)(global_data, mappedAreas);
129
- }, [mappedAreas]);
127
+ var focusedEvent = events_data.focusedEvent;
128
+ if (focusedEvent) {
129
+ var firstPointId = focusedEvent.first_observation_from_hierarchy.point_id;
130
+ var lastPointId = focusedEvent.last_observation_from_hierarchy.point_id;
131
+ var firstPoint = points_data.items.find(function (point) {
132
+ return point.id === firstPointId;
133
+ });
134
+ var lastPoint = points_data.items.find(function (point) {
135
+ return point.id === lastPointId;
136
+ });
137
+ if (firstPoint && lastPoint) {
138
+ return [[firstPoint === null || firstPoint === void 0 ? void 0 : firstPoint.latitude, firstPoint === null || firstPoint === void 0 ? void 0 : firstPoint.longitude], [lastPoint === null || lastPoint === void 0 ? void 0 : lastPoint.latitude, lastPoint === null || lastPoint === void 0 ? void 0 : lastPoint.longitude]];
139
+ }
140
+ }
141
+ if (mappedAreas && mappedAreas.length > 0) {
142
+ return (0, _EventsMapContainerHelpers.getAreasToCenterBy)(global_data, mappedAreas);
143
+ }
144
+ return null;
145
+ }, [mappedAreas, events_data.focusedEvent]);
130
146
  (0, _react.useEffect)(function () {
131
147
  if (global_data.waterAuthorityId) {
132
148
  var period = getActiveTimeFilterPeriod();
@@ -166,4 +182,4 @@ var EventsMapContainer = function EventsMapContainer(props) {
166
182
  }));
167
183
  };
168
184
  exports.EventsMapContainer = EventsMapContainer;
169
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRedux","_EventsMapContainerHelpers","_actions","_actions2","_actions3","_Map","_FloatingGraph","_interopRequireDefault","_GraphUtils","_actions4","_DragAndDropArea","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","EventsMapContainer","props","_global_data$floating","_global_data$floating2","dispatch","useDispatch","ReduxState","useSelector","state","areas_data","global_data","points_data","events_data","edges_data","isTimeFilterNotSelected","useMemo","_global_data$activeFi","filters","activeFilter","filter_items","length","index","type","mappedAreas","areasMapper","getActiveTimeFilterPeriod","_global_data$activeFi2","items","activeTimeFilter","selected_options","JSON","parse","areaToCenterBy","getAreasToCenterBy","useEffect","waterAuthorityId","period","fetchPoints","fetchEdges","fetchAreas","cleanup","closeFloatingGraph","createElement","Map","assign","areas","points","edges","focusedEvent","hoveredEvent","hideEdges","includeUnmonitoredPoints","includeUnmonitoredDescendantsForEdges","forEventsView","focusedEventPath","focusedEventPaths","floatingGraph","isOpen","open","customHighChartOptions","dndGraphInitOptions","closeGraphHandler","globalDataFloatingGraph","event_data","graphId","point","id","exports"],"sources":["../../../../src/pages/EventsPage/EventsMapContainer/EventsMapContainer.tsx"],"sourcesContent":["import React, { useEffect, useMemo } from 'react';\nimport { useDispatch, useSelector } from 'react-redux';\nimport {\n  areasMapper,\n  getAreasToCenterBy,\n} from 'src/pages/EventsPage/EventsMapContainer/EventsMapContainerHelpers';\nimport { fetchAreas } from 'src/store/areas/actions';\nimport { fetchEdges } from 'src/store/edges/actions';\nimport { fetchPoints } from 'src/store/points/actions';\nimport { Map } from 'src/Widgets/Map/Map';\nimport FloatingGraph from 'src/pages/EventsPage/FloatingGraph/FloatingGraph';\nimport { dndGraphInitOptions } from 'src/Widgets/Map/GraphUtils';\nimport { closeFloatingGraph } from 'src/store/global/actions';\nimport DragAndDropArea from '../DragAndDropArea';\n\ninterface EventsMapContainerProps {\n  showSecondMap: boolean;\n}\nexport const EventsMapContainer: React.FC<EventsMapContainerProps> = (\n  props,\n) => {\n  const dispatch = useDispatch();\n  const ReduxState = useSelector((state) => state);\n  const { areas_data, global_data, points_data, events_data, edges_data } =\n    ReduxState;\n\n  const isTimeFilterNotSelected = useMemo(() => {\n    const filters = global_data?.activeFilter?.filter_items;\n\n    if (!filters || filters.length < 1) {\n      return true;\n    }\n\n    for (let index = 0; index < filters.length; index++) {\n      if (filters[index].type === 'TimeFilterItem') {\n        return false;\n      }\n    }\n\n    return true;\n  }, [global_data?.activeFilter]);\n\n  const mappedAreas = useMemo(\n    () => areasMapper(areas_data, isTimeFilterNotSelected),\n    [areas_data, isTimeFilterNotSelected],\n  );\n\n  const getActiveTimeFilterPeriod = () => {\n    const items = global_data?.activeFilter?.filter_items;\n    let activeTimeFilter = '1m';\n\n    if (!items || items.length < 1) {\n      return activeTimeFilter;\n    }\n\n    for (let index = 0; index < items.length; index++) {\n      if (items[index].type === 'TimeFilterItem') {\n        if (typeof items[index].selected_options === 'string')\n          items[index].selected_options = JSON.parse(\n            items[index].selected_options,\n          );\n\n        activeTimeFilter = items[index].selected_options[0];\n        break;\n      }\n    }\n    return activeTimeFilter;\n  };\n\n  // const EventsPerSite = useMemo(\n  //   () => CountEventsPerSiteID(events_data.items),\n  //   [events_data.items],\n  // );\n\n  // const MustSeenSites = useMemo(() => {\n  //   if (events_data.focusedEvent) {\n  //     return getFocusedEventMustSeenSites(events_data.focusedEvent);\n  //   } else if (events_data.hoveredEvent) {\n  //     return getFocusedEventMustSeenSites(events_data.hoveredEvent);\n  //   }\n  //   return {};\n  // }, [EventsPerSite, events_data.focusedEvent, events_data.hoveredEvent]);\n\n  // const mappedPoints = useMemo(\n  //   () =>\n  //     points_data.items.map((point) => {\n  //       const newPoint = { ...point };\n\n  //       if (!EventsPerSite[point.id] || isCollectorUnmonitored(point)) {\n  //         newPoint.hide = true;\n  //       }\n\n  //       if (events_data.focusedEvent) {\n  //         if (!MustSeenSites[point.id]) {\n  //           newPoint.hide = true;\n  //         } else {\n  //           newPoint.hide = false;\n  //         }\n  //       } else if (events_data.hoveredEvent) {\n  //         if (!MustSeenSites[point.id] && isCollectorUnmonitored(point)) {\n  //           newPoint.hide = true;\n  //         } else {\n  //           newPoint.hide = false;\n  //         }\n  //       }\n\n  //       newPoint.relatedEventsAmount = EventsPerSite[point.id] || 0;\n  //       newPoint.eventsViewHovered = true;\n  //       return newPoint;\n  //     }),\n  //   [\n  //     points_data,\n  //     EventsPerSite,\n  //     events_data.items,\n  //     events_data.focusedEvent,\n  //     events_data.hoveredEvent,\n  //   ],\n  // );\n\n  // eslint-disable-next-line\n  // const mappedEdges = edges_data.items.filter(\n  //   (edge) =>\n  //     // (Number(EventsPerSite[edge.source_point_id]) > 0 ||\n  //     // Number(EventsPerSite[edge.target_point_id]) > 0)\n  //     //  &&\n  //     edge.descendants_has_device === true ||\n  //     edge.descendants_has_none_collectors === true,\n  // );\n\n  const areaToCenterBy = useMemo(() => {\n    if (!mappedAreas || mappedAreas.length === 0) return null;\n\n    return getAreasToCenterBy(global_data, mappedAreas);\n  }, [mappedAreas]);\n\n  useEffect(() => {\n    if (global_data.waterAuthorityId) {\n      const period = getActiveTimeFilterPeriod();\n      dispatch(fetchPoints(global_data.waterAuthorityId, period));\n      dispatch(fetchEdges(global_data.waterAuthorityId));\n      dispatch(fetchAreas(global_data.waterAuthorityId, period, true));\n    }\n\n    return function cleanup() {\n      dispatch(closeFloatingGraph());\n    };\n  }, [global_data.waterAuthorityId, global_data.activeFilter]);\n\n  return (\n    <Map\n      areas={mappedAreas}\n      global_data={global_data}\n      points={points_data.items}\n      edges={edges_data.items}\n      focusedEvent={events_data.focusedEvent}\n      hoveredEvent={events_data.hoveredEvent}\n      areaToCenterBy={areaToCenterBy}\n      hideEdges={false}\n      includeUnmonitoredPoints={true}\n      includeUnmonitoredDescendantsForEdges={true}\n      forEventsView={true}\n      {...props}\n    >\n      {\n        <DragAndDropArea focusedEventPath={events_data?.focusedEventPaths}>\n          {{\n            floatingGraph: (\n              <FloatingGraph\n                isOpen={global_data?.floatingGraph.open}\n                customHighChartOptions={dndGraphInitOptions}\n                closeGraphHandler={() => {\n                  dispatch(closeFloatingGraph());\n                }}\n                globalDataFloatingGraph={global_data.floatingGraph}\n                event_data={events_data?.focusedEvent}\n                graphId={global_data?.floatingGraph?.point?.id}\n              />\n            ),\n          }}\n        </DragAndDropArea>\n      }\n    </Map>\n  );\n};\n"],"mappings":"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"}
185
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRedux","_EventsMapContainerHelpers","_actions","_actions2","_actions3","_Map","_FloatingGraph","_interopRequireDefault","_GraphUtils","_actions4","_DragAndDropArea","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","EventsMapContainer","props","_global_data$floating","_global_data$floating2","dispatch","useDispatch","ReduxState","useSelector","state","areas_data","global_data","points_data","events_data","edges_data","isTimeFilterNotSelected","useMemo","_global_data$activeFi","filters","activeFilter","filter_items","length","index","type","mappedAreas","areasMapper","getActiveTimeFilterPeriod","_global_data$activeFi2","items","activeTimeFilter","selected_options","JSON","parse","areaToCenterBy","focusedEvent","firstPointId","first_observation_from_hierarchy","point_id","lastPointId","last_observation_from_hierarchy","firstPoint","find","point","id","lastPoint","latitude","longitude","getAreasToCenterBy","useEffect","waterAuthorityId","period","fetchPoints","fetchEdges","fetchAreas","cleanup","closeFloatingGraph","createElement","Map","assign","areas","points","edges","hoveredEvent","hideEdges","includeUnmonitoredPoints","includeUnmonitoredDescendantsForEdges","forEventsView","focusedEventPath","focusedEventPaths","floatingGraph","isOpen","open","customHighChartOptions","dndGraphInitOptions","closeGraphHandler","globalDataFloatingGraph","event_data","graphId","exports"],"sources":["../../../../src/pages/EventsPage/EventsMapContainer/EventsMapContainer.tsx"],"sourcesContent":["import React, { useEffect, useMemo } from 'react';\nimport { useDispatch, useSelector } from 'react-redux';\nimport {\n  areasMapper,\n  getAreasToCenterBy,\n} from 'src/pages/EventsPage/EventsMapContainer/EventsMapContainerHelpers';\nimport { fetchAreas } from 'src/store/areas/actions';\nimport { fetchEdges } from 'src/store/edges/actions';\nimport { fetchPoints } from 'src/store/points/actions';\nimport { Map } from 'src/Widgets/Map/Map';\nimport FloatingGraph from 'src/pages/EventsPage/FloatingGraph/FloatingGraph';\nimport { dndGraphInitOptions } from 'src/Widgets/Map/GraphUtils';\nimport { closeFloatingGraph } from 'src/store/global/actions';\nimport DragAndDropArea from '../DragAndDropArea';\n\ninterface EventsMapContainerProps {\n  showSecondMap: boolean;\n}\nexport const EventsMapContainer: React.FC<EventsMapContainerProps> = (\n  props,\n) => {\n  const dispatch = useDispatch();\n  const ReduxState = useSelector((state) => state);\n  const { areas_data, global_data, points_data, events_data, edges_data } =\n    ReduxState;\n\n  const isTimeFilterNotSelected = useMemo(() => {\n    const filters = global_data?.activeFilter?.filter_items;\n\n    if (!filters || filters.length < 1) {\n      return true;\n    }\n\n    for (let index = 0; index < filters.length; index++) {\n      if (filters[index].type === 'TimeFilterItem') {\n        return false;\n      }\n    }\n\n    return true;\n  }, [global_data?.activeFilter]);\n\n  const mappedAreas = useMemo(\n    () => areasMapper(areas_data, isTimeFilterNotSelected),\n    [areas_data, isTimeFilterNotSelected],\n  );\n\n  const getActiveTimeFilterPeriod = () => {\n    const items = global_data?.activeFilter?.filter_items;\n    let activeTimeFilter = '1m';\n\n    if (!items || items.length < 1) {\n      return activeTimeFilter;\n    }\n\n    for (let index = 0; index < items.length; index++) {\n      if (items[index].type === 'TimeFilterItem') {\n        if (typeof items[index].selected_options === 'string')\n          items[index].selected_options = JSON.parse(\n            items[index].selected_options,\n          );\n\n        activeTimeFilter = items[index].selected_options[0];\n        break;\n      }\n    }\n    return activeTimeFilter;\n  };\n\n  // const EventsPerSite = useMemo(\n  //   () => CountEventsPerSiteID(events_data.items),\n  //   [events_data.items],\n  // );\n\n  // const MustSeenSites = useMemo(() => {\n  //   if (events_data.focusedEvent) {\n  //     return getFocusedEventMustSeenSites(events_data.focusedEvent);\n  //   } else if (events_data.hoveredEvent) {\n  //     return getFocusedEventMustSeenSites(events_data.hoveredEvent);\n  //   }\n  //   return {};\n  // }, [EventsPerSite, events_data.focusedEvent, events_data.hoveredEvent]);\n\n  // const mappedPoints = useMemo(\n  //   () =>\n  //     points_data.items.map((point) => {\n  //       const newPoint = { ...point };\n\n  //       if (!EventsPerSite[point.id] || isCollectorUnmonitored(point)) {\n  //         newPoint.hide = true;\n  //       }\n\n  //       if (events_data.focusedEvent) {\n  //         if (!MustSeenSites[point.id]) {\n  //           newPoint.hide = true;\n  //         } else {\n  //           newPoint.hide = false;\n  //         }\n  //       } else if (events_data.hoveredEvent) {\n  //         if (!MustSeenSites[point.id] && isCollectorUnmonitored(point)) {\n  //           newPoint.hide = true;\n  //         } else {\n  //           newPoint.hide = false;\n  //         }\n  //       }\n\n  //       newPoint.relatedEventsAmount = EventsPerSite[point.id] || 0;\n  //       newPoint.eventsViewHovered = true;\n  //       return newPoint;\n  //     }),\n  //   [\n  //     points_data,\n  //     EventsPerSite,\n  //     events_data.items,\n  //     events_data.focusedEvent,\n  //     events_data.hoveredEvent,\n  //   ],\n  // );\n\n  // eslint-disable-next-line\n  // const mappedEdges = edges_data.items.filter(\n  //   (edge) =>\n  //     // (Number(EventsPerSite[edge.source_point_id]) > 0 ||\n  //     // Number(EventsPerSite[edge.target_point_id]) > 0)\n  //     //  &&\n  //     edge.descendants_has_device === true ||\n  //     edge.descendants_has_none_collectors === true,\n  // );\n\n  const areaToCenterBy = useMemo(() => {\n    const focusedEvent = events_data.focusedEvent;\n\n    if (focusedEvent) {\n      const firstPointId =\n        focusedEvent.first_observation_from_hierarchy.point_id;\n      const lastPointId = focusedEvent.last_observation_from_hierarchy.point_id;\n      const firstPoint = points_data.items.find(\n        (point) => point.id === firstPointId,\n      );\n      const lastPoint = points_data.items.find(\n        (point) => point.id === lastPointId,\n      );\n\n      if (firstPoint && lastPoint) {\n        return [\n          [firstPoint?.latitude, firstPoint?.longitude],\n          [lastPoint?.latitude, lastPoint?.longitude],\n        ];\n      }\n    }\n\n    if (mappedAreas && mappedAreas.length > 0) {\n      return getAreasToCenterBy(global_data, mappedAreas);\n    }\n\n    return null;\n  }, [mappedAreas, events_data.focusedEvent]);\n\n  useEffect(() => {\n    if (global_data.waterAuthorityId) {\n      const period = getActiveTimeFilterPeriod();\n      dispatch(fetchPoints(global_data.waterAuthorityId, period));\n      dispatch(fetchEdges(global_data.waterAuthorityId));\n      dispatch(fetchAreas(global_data.waterAuthorityId, period, true));\n    }\n\n    return function cleanup() {\n      dispatch(closeFloatingGraph());\n    };\n  }, [global_data.waterAuthorityId, global_data.activeFilter]);\n\n  return (\n    <Map\n      areas={mappedAreas}\n      global_data={global_data}\n      points={points_data.items}\n      edges={edges_data.items}\n      focusedEvent={events_data.focusedEvent}\n      hoveredEvent={events_data.hoveredEvent}\n      areaToCenterBy={areaToCenterBy}\n      hideEdges={false}\n      includeUnmonitoredPoints={true}\n      includeUnmonitoredDescendantsForEdges={true}\n      forEventsView={true}\n      {...props}\n    >\n      {\n        <DragAndDropArea focusedEventPath={events_data?.focusedEventPaths}>\n          {{\n            floatingGraph: (\n              <FloatingGraph\n                isOpen={global_data?.floatingGraph.open}\n                customHighChartOptions={dndGraphInitOptions}\n                closeGraphHandler={() => {\n                  dispatch(closeFloatingGraph());\n                }}\n                globalDataFloatingGraph={global_data.floatingGraph}\n                event_data={events_data?.focusedEvent}\n                graphId={global_data?.floatingGraph?.point?.id}\n              />\n            ),\n          }}\n        </DragAndDropArea>\n      }\n    </Map>\n  );\n};\n"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@kando-env/kando-ui",
3
- "version": "1.2.437-alpha.2",
3
+ "version": "1.2.437-alpha.3",
4
4
  "main": "lib/index.js",
5
5
  "author": "Nadav(Private) <nadavk72@gmail.com>",
6
6
  "scripts": {