@kando-env/kando-ui 1.2.437-alpha.1 → 1.2.437-alpha.11

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.
@@ -1,42 +1,55 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
- var _typeof = require("@babel/runtime/helpers/typeof");
5
4
  Object.defineProperty(exports, "__esModule", {
6
5
  value: true
7
6
  });
8
7
  exports.default = void 0;
9
8
  var _leaflet = _interopRequireDefault(require("leaflet"));
10
- var _react = _interopRequireWildcard(require("react"));
9
+ var _react = require("react");
11
10
  var _reactRedux = require("react-redux");
12
11
  var _actions = require("store/events/actions");
13
- 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); }
14
- 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; }
15
12
  // @ts-ignore
16
13
 
17
14
  var EventPath = function EventPath(_ref) {
18
15
  var event = _ref.event,
19
16
  global_data = _ref.global_data,
20
17
  _ref$eventPaths = _ref.eventPaths,
21
- eventPaths = _ref$eventPaths === void 0 ? [] : _ref$eventPaths;
18
+ eventPaths = _ref$eventPaths === void 0 ? [] : _ref$eventPaths,
19
+ _ref$points_data = _ref.points_data,
20
+ points_data = _ref$points_data === void 0 ? [] : _ref$points_data;
22
21
  var map = global_data.map;
23
22
  var dispatch = (0, _reactRedux.useDispatch)();
23
+ var groupRef = (0, _react.useRef)(null);
24
+
25
+ // Initialize the group once
26
+ (0, _react.useEffect)(function () {
27
+ if (map && !groupRef.current) {
28
+ groupRef.current = _leaflet.default.featureGroup().addTo(map);
29
+ }
30
+ return function () {
31
+ if (groupRef.current) {
32
+ groupRef.current.clearLayers();
33
+ map.removeLayer(groupRef.current);
34
+ groupRef.current = null;
35
+ }
36
+ };
37
+ }, [map]);
24
38
  var drawPolyline = function drawPolyline(event, layerLatlngs, eventPathsAsMapObjects) {
39
+ if (!groupRef.current) return;
25
40
  var eventPath = _leaflet.default.polyline(layerLatlngs, {
26
41
  color: 'rgb(236,119,156)',
27
42
  weight: 10,
28
43
  className: 'event-path',
29
44
  stroke: true
30
- }).addTo(map);
45
+ }).addTo(groupRef.current);
31
46
  eventPathsAsMapObjects.push(eventPath);
32
47
  eventPath['kando_object_id'] = event.id;
33
48
  eventPath['kando_object'] = 'EventPath';
34
49
  var tailDash;
35
50
  if (window.L.Symbol !== undefined) {
36
51
  tailDash = window.L.polylineDecorator(eventPath._latlngs, {
37
- patterns: [
38
- // defines a pattern of 10px-wide dashes, repeated every 20px on the line
39
- {
52
+ patterns: [{
40
53
  offset: 20,
41
54
  repeat: 60,
42
55
  symbol: window.L.Symbol.arrowHead({
@@ -50,43 +63,79 @@ var EventPath = function EventPath(_ref) {
50
63
  }
51
64
  })
52
65
  }]
53
- }).addTo(map);
66
+ }).addTo(groupRef.current);
54
67
  tailDash['kando_object'] = 'Arrow';
68
+ if (tailDash) eventPathsAsMapObjects.push(tailDash);
69
+ // if (tailDash.bringToFront) tailDash.bringToFront();
55
70
  }
56
- eventPathsAsMapObjects.push(tailDash);
71
+
72
+ // if (eventPath.bringToFront) eventPath.bringToFront();
73
+
57
74
  if (event.hovered) {
58
75
  dispatch((0, _actions.setHoveredEventPaths)(eventPathsAsMapObjects));
59
76
  } else {
60
77
  dispatch((0, _actions.setFocusedEventPaths)(eventPathsAsMapObjects));
61
78
  }
62
79
  };
80
+ var buildLayerLookup = function buildLayerLookup(layers) {
81
+ var lookup = {};
82
+ for (var property in layers) {
83
+ var layer = layers[property];
84
+ if (layer.kando_object_id !== undefined && layer.kando_object === 'Edge') {
85
+ lookup[layer.kando_object_id] = layer;
86
+ }
87
+ }
88
+ return lookup;
89
+ };
90
+
91
+ // Memoize the layer lookup so it only recalculates when map._layers changes
92
+ var layerLookup = (0, _react.useMemo)(function () {
93
+ if (!map) return {};
94
+ return buildLayerLookup(map._layers);
95
+ }, [map, map === null || map === void 0 ? void 0 : map._layers]);
63
96
  var renderEventPath = function renderEventPath(event, isHover) {
64
- if (map !== undefined) {
97
+ if (map !== undefined && groupRef.current) {
98
+ groupRef.current.clearLayers();
65
99
  var eventPathsAsMapObjects = [];
66
- var layers = map._layers;
100
+ // const layers = map._layers;
101
+ // const layerLookup = buildLayerLookup(layers);
102
+
67
103
  event.path.forEach(function (path) {
68
- for (var property in layers) {
69
- if (layers[property].kando_object_id !== undefined && layers[property].kando_object_id === path.edge_id && layers[property].kando_object === 'Edge') {
70
- var layerLatlngs = layers[property].getLatLngs();
71
- drawPolyline(event, layerLatlngs, eventPathsAsMapObjects);
72
- }
104
+ var layer = layerLookup[path.edge_id];
105
+ if (layer) {
106
+ var layerLatlngs = layer.getLatLngs();
107
+ drawPolyline(event, layerLatlngs, eventPathsAsMapObjects);
73
108
  }
74
109
  });
75
- if (!isHover && eventPathsAsMapObjects.length !== 0) {
76
- map.fitBounds(_leaflet.default.featureGroup(eventPathsAsMapObjects).getBounds().pad(0.1));
110
+ if (!isHover) {
111
+ var validLayers = eventPathsAsMapObjects.filter(Boolean);
112
+ if (validLayers.length !== 0) {
113
+ if (validLayers.length >= 2) {
114
+ map.fitBounds(_leaflet.default.featureGroup([validLayers[0], validLayers[validLayers.length - 1]]).getBounds().pad(0.1));
115
+ }
116
+ } else {
117
+ if (points_data.length === 0) return;
118
+ var point = points_data.find(function (point) {
119
+ return point.id === event.last_observation_from_hierarchy.point_id;
120
+ });
121
+ if (point && point.latitude && point.longitude) {
122
+ map.setView([point.latitude, point.longitude], 14);
123
+ }
124
+ }
77
125
  }
78
126
  }
79
127
  };
80
128
  (0, _react.useEffect)(function () {
81
129
  if (eventPaths) {
82
- eventPaths.forEach(function (path) {
83
- map.removeLayer(path);
84
- });
130
+ // eventPaths.forEach((path) => {
131
+ // map.removeLayer(path);
132
+ // });
133
+
85
134
  renderEventPath(event, event.hovered);
86
135
  }
87
136
  }, [event, event.hovered]);
88
- return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null);
137
+ return null;
89
138
  };
90
139
  var _default = EventPath;
91
140
  exports.default = _default;
92
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_leaflet","_interopRequireDefault","require","_react","_interopRequireWildcard","_reactRedux","_actions","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","EventPath","_ref","event","global_data","_ref$eventPaths","eventPaths","map","dispatch","useDispatch","drawPolyline","layerLatlngs","eventPathsAsMapObjects","eventPath","L","polyline","color","weight","className","stroke","addTo","push","id","tailDash","window","Symbol","undefined","polylineDecorator","_latlngs","patterns","offset","repeat","symbol","arrowHead","pixelSize","polygon","pathOptions","opacity","hovered","setHoveredEventPaths","setFocusedEventPaths","renderEventPath","isHover","layers","_layers","path","forEach","property","kando_object_id","edge_id","kando_object","getLatLngs","length","fitBounds","featureGroup","getBounds","pad","useEffect","removeLayer","createElement","Fragment","_default","exports"],"sources":["../../../../src/Widgets/Map/events/EventPath.tsx"],"sourcesContent":["// @ts-ignore\nimport L from 'leaflet';\nimport React, { useEffect } from 'react';\nimport { useDispatch } from 'react-redux';\nimport {\n  setFocusedEventPaths,\n  setHoveredEventPaths,\n} from 'src/store/events/actions';\nimport { IEvent } from 'src/store/events/models/IEvent';\nimport { IGlobalState } from 'src/store/global/models/IGlobalState';\n\ntype IProps = {\n  event: IEvent;\n  global_data: IGlobalState;\n  eventPaths?: any[];\n};\n\nconst EventPath: React.FC<IProps> = ({\n  event,\n  global_data,\n  eventPaths = [],\n}) => {\n  const { map } = global_data;\n  const dispatch = useDispatch();\n\n  const drawPolyline = (\n    event: IEvent,\n    layerLatlngs: any,\n    eventPathsAsMapObjects: any,\n  ) => {\n    let eventPath = L.polyline(layerLatlngs, {\n      color: 'rgb(236,119,156)',\n      weight: 10,\n      className: 'event-path',\n      stroke: true,\n    }).addTo(map);\n\n    eventPathsAsMapObjects.push(eventPath);\n    eventPath['kando_object_id'] = event.id;\n    eventPath['kando_object'] = 'EventPath';\n\n    let tailDash: any;\n    if (window.L.Symbol !== undefined) {\n      tailDash = window.L.polylineDecorator(eventPath._latlngs, {\n        patterns: [\n          // defines a pattern of 10px-wide dashes, repeated every 20px on the line\n          {\n            offset: 20,\n            repeat: 60,\n            symbol: window.L.Symbol.arrowHead({\n              pixelSize: 3,\n              polygon: false,\n              pathOptions: {\n                stroke: true,\n                color: 'rgb(255,255,255)',\n                weight: 1,\n                opacity: 1,\n              },\n            }),\n          },\n        ],\n      }).addTo(map);\n      tailDash['kando_object'] = 'Arrow';\n    }\n\n    eventPathsAsMapObjects.push(tailDash);\n    if (event.hovered) {\n      dispatch(setHoveredEventPaths(eventPathsAsMapObjects));\n    } else {\n      dispatch(setFocusedEventPaths(eventPathsAsMapObjects));\n    }\n  };\n\n  const renderEventPath = (event: IEvent, isHover: boolean) => {\n    if (map !== undefined) {\n      let eventPathsAsMapObjects: any[] = [];\n      let layers = map._layers;\n      event.path.forEach((path: any) => {\n        for (const property in layers) {\n          if (\n            layers[property].kando_object_id !== undefined &&\n            layers[property].kando_object_id === path.edge_id &&\n            layers[property].kando_object === 'Edge'\n          ) {\n            let layerLatlngs = layers[property].getLatLngs();\n            drawPolyline(event, layerLatlngs, eventPathsAsMapObjects);\n          }\n        }\n      });\n\n      if (!isHover && eventPathsAsMapObjects.length !== 0) {\n        map.fitBounds(\n          L.featureGroup(eventPathsAsMapObjects).getBounds().pad(0.1),\n        );\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (eventPaths) {\n      eventPaths.forEach((path) => {\n        map.removeLayer(path);\n      });\n\n      renderEventPath(event, event.hovered);\n    }\n  }, [event, event.hovered]);\n\n  return <></>;\n};\n\nexport default EventPath;\n"],"mappings":"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"}
141
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_leaflet","_interopRequireDefault","require","_react","_reactRedux","_actions","EventPath","_ref","event","global_data","_ref$eventPaths","eventPaths","_ref$points_data","points_data","map","dispatch","useDispatch","groupRef","useRef","useEffect","current","L","featureGroup","addTo","clearLayers","removeLayer","drawPolyline","layerLatlngs","eventPathsAsMapObjects","eventPath","polyline","color","weight","className","stroke","push","id","tailDash","window","Symbol","undefined","polylineDecorator","_latlngs","patterns","offset","repeat","symbol","arrowHead","pixelSize","polygon","pathOptions","opacity","hovered","setHoveredEventPaths","setFocusedEventPaths","buildLayerLookup","layers","lookup","property","layer","kando_object_id","kando_object","layerLookup","useMemo","_layers","renderEventPath","isHover","path","forEach","edge_id","getLatLngs","validLayers","filter","Boolean","length","fitBounds","getBounds","pad","point","find","last_observation_from_hierarchy","point_id","latitude","longitude","setView","_default","exports","default"],"sources":["../../../../src/Widgets/Map/events/EventPath.tsx"],"sourcesContent":["// @ts-ignore\nimport L from 'leaflet';\nimport React, { useEffect, useMemo, useRef } from 'react';\nimport { useDispatch } from 'react-redux';\nimport {\n  setFocusedEventPaths,\n  setHoveredEventPaths,\n} from 'src/store/events/actions';\nimport { IEvent } from 'src/store/events/models/IEvent';\nimport { IGlobalState } from 'src/store/global/models/IGlobalState';\n\ntype IProps = {\n  event: IEvent;\n  global_data: IGlobalState;\n  eventPaths?: any[];\n  points_data?: any[];\n};\n\nconst EventPath: React.FC<IProps> = ({\n  event,\n  global_data,\n  eventPaths = [],\n  points_data = [],\n}) => {\n  const { map } = global_data;\n  const dispatch = useDispatch();\n  const groupRef = useRef<L.FeatureGroup | null>(null);\n\n  // Initialize the group once\n  useEffect(() => {\n    if (map && !groupRef.current) {\n      groupRef.current = L.featureGroup().addTo(map);\n    }\n    return () => {\n      if (groupRef.current) {\n        groupRef.current.clearLayers();\n        map.removeLayer(groupRef.current);\n        groupRef.current = null;\n      }\n    };\n  }, [map]);\n\n  const drawPolyline = (\n    event: IEvent,\n    layerLatlngs: any,\n    eventPathsAsMapObjects: any,\n  ) => {\n    if (!groupRef.current) return;\n\n    let eventPath = L.polyline(layerLatlngs, {\n      color: 'rgb(236,119,156)',\n      weight: 10,\n      className: 'event-path',\n      stroke: true,\n    }).addTo(groupRef.current);\n\n    eventPathsAsMapObjects.push(eventPath);\n    eventPath['kando_object_id'] = event.id;\n    eventPath['kando_object'] = 'EventPath';\n\n    let tailDash: any;\n    if (window.L.Symbol !== undefined) {\n      tailDash = window.L.polylineDecorator(eventPath._latlngs, {\n        patterns: [\n          {\n            offset: 20,\n            repeat: 60,\n            symbol: window.L.Symbol.arrowHead({\n              pixelSize: 3,\n              polygon: false,\n              pathOptions: {\n                stroke: true,\n                color: 'rgb(255,255,255)',\n                weight: 1,\n                opacity: 1,\n              },\n            }),\n          },\n        ],\n      }).addTo(groupRef.current);\n      tailDash['kando_object'] = 'Arrow';\n      if (tailDash) eventPathsAsMapObjects.push(tailDash);\n      // if (tailDash.bringToFront) tailDash.bringToFront();\n    }\n\n    // if (eventPath.bringToFront) eventPath.bringToFront();\n\n    if (event.hovered) {\n      dispatch(setHoveredEventPaths(eventPathsAsMapObjects));\n    } else {\n      dispatch(setFocusedEventPaths(eventPathsAsMapObjects));\n    }\n  };\n\n  const buildLayerLookup = (layers) => {\n    const lookup = {};\n    for (const property in layers) {\n      const layer = layers[property];\n      if (\n        layer.kando_object_id !== undefined &&\n        layer.kando_object === 'Edge'\n      ) {\n        lookup[layer.kando_object_id] = layer;\n      }\n    }\n    return lookup;\n  };\n\n  // Memoize the layer lookup so it only recalculates when map._layers changes\n  const layerLookup = useMemo(() => {\n    if (!map) return {};\n    return buildLayerLookup(map._layers);\n  }, [map, map?._layers]);\n\n  const renderEventPath = (event: IEvent, isHover: boolean) => {\n    if (map !== undefined && groupRef.current) {\n      groupRef.current.clearLayers();\n      let eventPathsAsMapObjects: any[] = [];\n      // const layers = map._layers;\n      // const layerLookup = buildLayerLookup(layers);\n\n      event.path.forEach((path: any) => {\n        const layer = layerLookup[path.edge_id];\n        if (layer) {\n          let layerLatlngs = layer.getLatLngs();\n          drawPolyline(event, layerLatlngs, eventPathsAsMapObjects);\n        }\n      });\n\n      if (!isHover) {\n        const validLayers = eventPathsAsMapObjects.filter(Boolean);\n        if (validLayers.length !== 0) {\n          if (validLayers.length >= 2) {\n            map.fitBounds(\n              L.featureGroup([\n                validLayers[0],\n                validLayers[validLayers.length - 1],\n              ])\n                .getBounds()\n                .pad(0.1),\n            );\n          }\n        } else {\n          if (points_data.length === 0) return;\n\n          const point = points_data.find(\n            (point) =>\n              point.id === event.last_observation_from_hierarchy.point_id,\n          );\n          if (point && point.latitude && point.longitude) {\n            map.setView([point.latitude, point.longitude], 14);\n          }\n        }\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (eventPaths) {\n      // eventPaths.forEach((path) => {\n      //   map.removeLayer(path);\n      // });\n\n      renderEventPath(event, event.hovered);\n    }\n  }, [event, event.hovered]);\n\n  return null;\n};\n\nexport default EventPath;\n"],"mappings":"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"}
@@ -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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"}
@@ -1,19 +1,17 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
- var _typeof = require("@babel/runtime/helpers/typeof");
5
4
  Object.defineProperty(exports, "__esModule", {
6
5
  value: true
7
6
  });
8
7
  exports.Snail = void 0;
9
- var _react = _interopRequireWildcard(require("react"));
8
+ var _react = _interopRequireDefault(require("react"));
10
9
  var _EventPath = _interopRequireDefault(require("./EventPath"));
11
- var _EventIndicator = _interopRequireDefault(require("./EventIndicator"));
12
10
  var _reactRedux = require("react-redux");
13
- 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); }
14
- 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; }
15
11
  // @ts-ignore
16
12
 
13
+ // import EventIndicator from './EventIndicator';
14
+
17
15
  var Snail = function Snail(_ref) {
18
16
  var event = _ref.event;
19
17
  var state = (0, _reactRedux.useSelector)(function (state) {
@@ -23,26 +21,25 @@ var Snail = function Snail(_ref) {
23
21
  return state;
24
22
  }),
25
23
  global_data = _useSelector.global_data;
26
- var _state$events_data = state.events_data,
27
- hoveredEventPaths = _state$events_data.hoveredEventPaths,
28
- focusedEventPaths = _state$events_data.focusedEventPaths;
29
- var map = global_data.map;
30
- var memoizedIndicator = function memoizedIndicator() {
31
- var paths = focusedEventPaths.length !== 0 ? focusedEventPaths : hoveredEventPaths;
32
- return /*#__PURE__*/_react.default.createElement(_EventIndicator.default, {
33
- map: map,
34
- paths: paths,
35
- event: event
36
- });
37
- };
38
- (0, _react.useEffect)(function () {
39
- memoizedIndicator();
40
- }, [hoveredEventPaths, focusedEventPaths]);
24
+ // const { hoveredEventPaths, focusedEventPaths } = state.events_data;
25
+ // const map = global_data.map;
26
+
27
+ // const memoizedIndicator = () => {
28
+ // let paths =
29
+ // focusedEventPaths.length !== 0 ? focusedEventPaths : hoveredEventPaths;
30
+ // return <EventIndicator map={map} paths={paths} event={event} />;
31
+ // };
32
+
33
+ // useEffect(() => {
34
+ // memoizedIndicator();
35
+ // }, [hoveredEventPaths, focusedEventPaths]);
36
+
41
37
  return /*#__PURE__*/_react.default.createElement(_EventPath.default, {
42
38
  event: event,
43
39
  global_data: global_data,
44
- eventPaths: event.path
40
+ eventPaths: event.path,
41
+ points_data: state.points_data.items
45
42
  });
46
43
  };
47
44
  exports.Snail = Snail;
48
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVXaWxkY2FyZCIsInJlcXVpcmUiLCJfRXZlbnRQYXRoIiwiX2ludGVyb3BSZXF1aXJlRGVmYXVsdCIsIl9FdmVudEluZGljYXRvciIsIl9yZWFjdFJlZHV4IiwiX2dldFJlcXVpcmVXaWxkY2FyZENhY2hlIiwibm9kZUludGVyb3AiLCJXZWFrTWFwIiwiY2FjaGVCYWJlbEludGVyb3AiLCJjYWNoZU5vZGVJbnRlcm9wIiwib2JqIiwiX19lc01vZHVsZSIsIl90eXBlb2YiLCJkZWZhdWx0IiwiY2FjaGUiLCJoYXMiLCJnZXQiLCJuZXdPYmoiLCJoYXNQcm9wZXJ0eURlc2NyaXB0b3IiLCJPYmplY3QiLCJkZWZpbmVQcm9wZXJ0eSIsImdldE93blByb3BlcnR5RGVzY3JpcHRvciIsImtleSIsInByb3RvdHlwZSIsImhhc093blByb3BlcnR5IiwiY2FsbCIsImRlc2MiLCJzZXQiLCJTbmFpbCIsIl9yZWYiLCJldmVudCIsInN0YXRlIiwidXNlU2VsZWN0b3IiLCJfdXNlU2VsZWN0b3IiLCJnbG9iYWxfZGF0YSIsIl9zdGF0ZSRldmVudHNfZGF0YSIsImV2ZW50c19kYXRhIiwiaG92ZXJlZEV2ZW50UGF0aHMiLCJmb2N1c2VkRXZlbnRQYXRocyIsIm1hcCIsIm1lbW9pemVkSW5kaWNhdG9yIiwicGF0aHMiLCJsZW5ndGgiLCJjcmVhdGVFbGVtZW50IiwidXNlRWZmZWN0IiwiZXZlbnRQYXRocyIsInBhdGgiLCJleHBvcnRzIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL1dpZGdldHMvTWFwL2V2ZW50cy9TbmFpbC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLy8gQHRzLWlnbm9yZVxuaW1wb3J0IFJlYWN0LCB7IHVzZUVmZmVjdCB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBFdmVudFBhdGggZnJvbSAnLi9FdmVudFBhdGgnO1xuaW1wb3J0IEV2ZW50SW5kaWNhdG9yIGZyb20gJy4vRXZlbnRJbmRpY2F0b3InO1xuaW1wb3J0IHsgSUV2ZW50IH0gZnJvbSAnLi4vLi4vLi4vc3RvcmUvZXZlbnRzL21vZGVscy9JRXZlbnQnO1xuaW1wb3J0IHsgdXNlU2VsZWN0b3IgfSBmcm9tICdyZWFjdC1yZWR1eCc7XG5pbXBvcnQgeyBJQXBwU3RhdGUgfSBmcm9tICcuLi8uLi8uLi9tb2RlbHMvSUFwcFN0YXRlJztcblxudHlwZSBJUHJvcHMgPSB7XG4gIGV2ZW50OiBJRXZlbnQ7XG59O1xuXG5leHBvcnQgY29uc3QgU25haWw6IFJlYWN0LkZDPElQcm9wcz4gPSAoeyBldmVudCB9KSA9PiB7XG4gIGNvbnN0IHN0YXRlID0gdXNlU2VsZWN0b3IoKHN0YXRlOiBJQXBwU3RhdGUpID0+IHN0YXRlKTtcbiAgY29uc3QgeyBnbG9iYWxfZGF0YSB9ID0gdXNlU2VsZWN0b3IoKHN0YXRlOiBJQXBwU3RhdGUpID0+IHN0YXRlKTtcbiAgY29uc3QgeyBob3ZlcmVkRXZlbnRQYXRocywgZm9jdXNlZEV2ZW50UGF0aHMgfSA9IHN0YXRlLmV2ZW50c19kYXRhO1xuICBjb25zdCBtYXAgPSBnbG9iYWxfZGF0YS5tYXA7XG5cbiAgY29uc3QgbWVtb2l6ZWRJbmRpY2F0b3IgPSAoKSA9PiB7XG4gICAgbGV0IHBhdGhzID1cbiAgICAgIGZvY3VzZWRFdmVudFBhdGhzLmxlbmd0aCAhPT0gMCA/IGZvY3VzZWRFdmVudFBhdGhzIDogaG92ZXJlZEV2ZW50UGF0aHM7XG4gICAgcmV0dXJuIDxFdmVudEluZGljYXRvciBtYXA9e21hcH0gcGF0aHM9e3BhdGhzfSBldmVudD17ZXZlbnR9IC8+O1xuICB9O1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgbWVtb2l6ZWRJbmRpY2F0b3IoKTtcbiAgfSwgW2hvdmVyZWRFdmVudFBhdGhzLCBmb2N1c2VkRXZlbnRQYXRoc10pO1xuXG4gIHJldHVybiAoXG4gICAgPEV2ZW50UGF0aFxuICAgICAgZXZlbnQ9e2V2ZW50fVxuICAgICAgZ2xvYmFsX2RhdGE9e2dsb2JhbF9kYXRhfVxuICAgICAgZXZlbnRQYXRo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
45
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9FdmVudFBhdGgiLCJfcmVhY3RSZWR1eCIsIlNuYWlsIiwiX3JlZiIsImV2ZW50Iiwic3RhdGUiLCJ1c2VTZWxlY3RvciIsIl91c2VTZWxlY3RvciIsImdsb2JhbF9kYXRhIiwiZGVmYXVsdCIsImNyZWF0ZUVsZW1lbnQiLCJldmVudFBhdGhzIiwicGF0aCIsInBvaW50c19kYXRhIiwiaXRlbXMiLCJleHBvcnRzIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL1dpZGdldHMvTWFwL2V2ZW50cy9TbmFpbC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLy8gQHRzLWlnbm9yZVxuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBFdmVudFBhdGggZnJvbSAnLi9FdmVudFBhdGgnO1xuLy8gaW1wb3J0IEV2ZW50SW5kaWNhdG9yIGZyb20gJy4vRXZlbnRJbmRpY2F0b3InO1xuaW1wb3J0IHsgSUV2ZW50IH0gZnJvbSAnLi4vLi4vLi4vc3RvcmUvZXZlbnRzL21vZGVscy9JRXZlbnQnO1xuaW1wb3J0IHsgdXNlU2VsZWN0b3IgfSBmcm9tICdyZWFjdC1yZWR1eCc7XG5pbXBvcnQgeyBJQXBwU3RhdGUgfSBmcm9tICcuLi8uLi8uLi9tb2RlbHMvSUFwcFN0YXRlJztcblxudHlwZSBJUHJvcHMgPSB7XG4gIGV2ZW50OiBJRXZlbnQ7XG59O1xuXG5leHBvcnQgY29uc3QgU25haWw6IFJlYWN0LkZDPElQcm9wcz4gPSAoeyBldmVudCB9KSA9PiB7XG4gIGNvbnN0IHN0YXRlID0gdXNlU2VsZWN0b3IoKHN0YXRlOiBJQXBwU3RhdGUpID0+IHN0YXRlKTtcbiAgY29uc3QgeyBnbG9iYWxfZGF0YSB9ID0gdXNlU2VsZWN0b3IoKHN0YXRlOiBJQXBwU3RhdGUpID0+IHN0YXRlKTtcbiAgLy8gY29uc3QgeyBob3ZlcmVkRXZlbnRQYXRocywgZm9jdXNlZEV2ZW50UGF0aHMgfSA9IHN0YXRlLmV2ZW50c19kYXRhO1xuICAvLyBjb25zdCBtYXAgPSBnbG9iYWxfZGF0YS5tYXA7XG5cbiAgLy8gY29uc3QgbWVtb2l6ZWRJbmRpY2F0b3IgPSAoKSA9PiB7XG4gIC8vICAgbGV0IHBhdGhzID1cbiAgLy8gICAgIGZvY3VzZWRFdmVudFBhdGhzLmxlbmd0aCAhPT0gMCA/IGZvY3VzZWRFdmVudFBhdGhzIDogaG92ZXJlZEV2ZW50UGF0aHM7XG4gIC8vICAgcmV0dXJuIDxFdmVudEluZGljYXRvciBtYXA9e21hcH0gcGF0aHM9e3BhdGhzfSBldmVudD17ZXZlbnR9IC8+O1xuICAvLyB9O1xuXG4gIC8vIHVzZUVmZmVjdCgoKSA9PiB7XG4gIC8vICAgbWVtb2l6ZWRJbmRpY2F0b3IoKTtcbiAgLy8gfSwgW2hvdmVyZWRFdmVudFBhdGhzLCBmb2N1c2VkRXZlbnRQYXRoc10pO1xuXG4gIHJldHVybiAoXG4gICAgPEV2ZW50UGF0aFxuICAgICAgZXZlbnQ9e2V2ZW50fVxuICAgICAgZ2xvYmFsX2RhdGE9e2dsb2JhbF9kYXRhfVxuICAgICAgZXZlbnRQYXRocz17ZXZlbnQucGF0aH1cbiAgICAgIHBvaW50c19kYXRhPXtzdGF0ZS5wb2ludHNfZGF0YS5pdGVtc31cbiAgICAvPlxuICApO1xufTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUNBLElBQUFBLE1BQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUNBLElBQUFDLFVBQUEsR0FBQUYsc0JBQUEsQ0FBQUMsT0FBQTtBQUdBLElBQUFFLFdBQUEsR0FBQUYsT0FBQTtBQUxBOztBQUdBOztBQVNPLElBQU1HLEtBQXVCLEdBQUcsU0FBMUJBLEtBQXVCQSxDQUFBQyxJQUFBLEVBQWtCO0VBQUEsSUFBWkMsS0FBSyxHQUFBRCxJQUFBLENBQUxDLEtBQUs7RUFDN0MsSUFBTUMsS0FBSyxHQUFHLElBQUFDLHVCQUFXLEVBQUMsVUFBQ0QsS0FBZ0I7SUFBQSxPQUFLQSxLQUFLO0VBQUEsRUFBQztFQUN0RCxJQUFBRSxZQUFBLEdBQXdCLElBQUFELHVCQUFXLEVBQUMsVUFBQ0QsS0FBZ0I7TUFBQSxPQUFLQSxLQUFLO0lBQUEsRUFBQztJQUF4REcsV0FBVyxHQUFBRCxZQUFBLENBQVhDLFdBQVc7RUFDbkI7RUFDQTs7RUFFQTtFQUNBO0VBQ0E7RUFDQTtFQUNBOztFQUVBO0VBQ0E7RUFDQTs7RUFFQSxvQkFDRVgsTUFBQSxDQUFBWSxPQUFBLENBQUFDLGFBQUEsQ0FBQ1YsVUFBQSxDQUFBUyxPQUFTO0lBQ1JMLEtBQUssRUFBRUEsS0FBTTtJQUNiSSxXQUFXLEVBQUVBLFdBQVk7SUFDekJHLFVBQVUsRUFBRVAsS0FBSyxDQUFDUSxJQUFLO0lBQ3ZCQyxXQUFXLEVBQUVSLEtBQUssQ0FBQ1EsV0FBVyxDQUFDQztFQUFNLENBQ3RDLENBQUM7QUFFTixDQUFDO0FBQUNDLE9BQUEsQ0FBQWIsS0FBQSxHQUFBQSxLQUFBIn0=
@@ -21,12 +21,11 @@ var _reactRouterDom = require("react-router-dom");
21
21
  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); }
22
22
  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; }
23
23
  function mapStateToProps(state) {
24
- var events_data = state.events_data,
25
- areas_data = state.areas_data,
24
+ var areas_data = state.areas_data,
26
25
  points_data = state.points_data,
27
26
  global_data = state.global_data;
28
27
  return {
29
- events_data: events_data,
28
+ // events_data,
30
29
  areas_data: areas_data,
31
30
  points_data: points_data,
32
31
  global_data: global_data
@@ -143,8 +142,12 @@ var PointMarker = function PointMarker(props) {
143
142
  return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null);
144
143
  };
145
144
  var connectedMarker = (0, _reactRedux.connect)(mapStateToProps);
146
- var _default = connectedMarker( /*#__PURE__*/_react.default.memo(PointMarker, function (prevProps, nextProps) {
147
- return prevProps.events_data.focusedEvent === nextProps.events_data.focusedEvent;
148
- }));
145
+ var _default = connectedMarker( /*#__PURE__*/_react.default.memo(PointMarker)
146
+ // React.memo(PointMarker, (prevProps, nextProps) => {
147
+ // return (
148
+ // prevProps.events_data.focusedEvent === nextProps.events_data.focusedEvent
149
+ // );
150
+ // }),
151
+ );
149
152
  exports.default = _default;
150
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRedux","_PointUtils","_Widget","_reactDom","_interopRequireDefault","_utils","_ListContext","_Capacity","_reactRouterDom","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","mapStateToProps","state","events_data","areas_data","points_data","global_data","PointMarker","props","map","point","rerender","layerGroup","flowRateUnit","dispatch","useDispatch","_useSelectedItem","useSelectedItem","handleSelectItem","WWTPMode","useSelector","wwtp_dashboard","history","useHistory","WWTPMapLogic","markerLocation","wwtpPoint","_objectSpread2","forWWTPMap","markerOnMap","getLayers","find","layer","kando_object_id","id","args","wwtp","bubbleForWWTP","tooltipVisible","addTo","fetchDataAndShowPopup","_ref","_asyncToGenerator2","_regenerator","mark","_callee","widgetContainer","wrap","_callee$","_context","prev","next","document","createElement","createPopupForObject","renderedElement","marker","fetchCapacity","waterAuthorityId","then","listData","ReactDOM","render","Widget","object","points","items","areas","newAreas","isPopupOpen","openPopup","stop","apply","arguments","on","closePopup","sendAnalyticsEvent","point_id","point_name","name","setIcon","renderLogic","pointIsWWTP","createBubblePoint","useEffect","Fragment","connectedMarker","connect","_default","React","memo","prevProps","nextProps","focusedEvent","exports"],"sources":["../../../../src/Widgets/Map/points/PointMarker.tsx"],"sourcesContent":["import React, { useEffect } from 'react';\nimport { connect, ConnectedProps, useDispatch, useSelector } from 'react-redux';\nimport { IAppState } from 'src/models/IAppState';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport {\n  bubbleForWWTP,\n  createBubblePoint,\n  pointIsWWTP,\n  setIcon,\n} from './PointUtils';\nimport { Widget } from 'src/pages/DashboardMap/Widget';\nimport ReactDOM from 'react-dom';\nimport L, { LatLngTuple } from 'leaflet';\nimport {\n  createPopupForObject,\n  sendAnalyticsEvent,\n} from 'src/pages/DashboardMap/utils';\nimport { useSelectedItem } from 'src/pages/DashboardMap/ListContext';\nimport { fetchCapacity } from 'src/pages/DashboardMap/Capacity';\nimport { useHistory } from 'react-router-dom';\n\nfunction mapStateToProps(state: IAppState) {\n  const { events_data, areas_data, points_data, global_data } = state;\n\n  return {\n    events_data,\n    areas_data,\n    points_data,\n    global_data,\n  };\n}\n\ntype Props = ConnectedProps<typeof connectedMarker> & {\n  map: any;\n  point: IPoint;\n  rerender: string;\n  layerGroup: any;\n  flowRateUnit: string;\n};\n\nconst PointMarker: React.FC<Props> = (props) => {\n  const {\n    map,\n    point,\n    rerender,\n    layerGroup,\n    flowRateUnit,\n    points_data,\n    areas_data,\n    global_data,\n  } = props;\n  const dispatch = useDispatch();\n  const { handleSelectItem } = useSelectedItem();\n  const WWTPMode = useSelector((state) => state.wwtp_dashboard.map !== null);\n  const history = useHistory();\n\n  const WWTPMapLogic = (markerLocation) => {\n    const wwtpPoint = {\n      ...point,\n      forWWTPMap: true,\n    };\n    const markerOnMap = layerGroup\n      .getLayers()\n      .find((layer) => layer.kando_object_id === point.id);\n    let args = { markerLocation, wwtpPoint };\n    let wwtp: L.Marker = markerOnMap ? markerOnMap : bubbleForWWTP(args);\n    let tooltipVisible = false;\n\n    if (!markerOnMap) {\n      wwtp.addTo(layerGroup);\n    }\n\n    const fetchDataAndShowPopup = async () => {\n      const widgetContainer = document.createElement('span');\n\n      createPopupForObject({\n        renderedElement: widgetContainer,\n        marker: wwtp,\n      });\n\n      fetchCapacity('site', point.id, global_data.waterAuthorityId).then(\n        (listData) => {\n          ReactDOM.render(\n            <Widget\n              object={wwtpPoint}\n              dispatch={dispatch}\n              points={points_data.items}\n              areas={areas_data.newAreas}\n              map={map}\n              global_data={global_data}\n              listData={listData}\n              history={history}\n            />,\n            widgetContainer,\n          );\n        },\n      );\n\n      if (!wwtp.isPopupOpen()) {\n        wwtp.openPopup();\n      }\n    };\n\n    wwtp.on('click', () => {\n      wwtp.isPopupOpen() ? wwtp.closePopup() : fetchDataAndShowPopup();\n      sendAnalyticsEvent('Map View - WWTP clicked', 'map', {\n        point_id: point.id,\n        point_name: point.name,\n      });\n    });\n\n    wwtp.on('mouseover', () => {\n      if (tooltipVisible) return;\n\n      setIcon(wwtp, true, point);\n      tooltipVisible = true;\n    });\n\n    wwtp.on('mouseout', () => {\n      if (wwtp.isPopupOpen()) return;\n\n      setIcon(wwtp, false, point);\n      tooltipVisible = false;\n    });\n\n    wwtp.on('popupclose', () => {\n      setIcon(wwtp, false, point);\n      tooltipVisible = false;\n    });\n\n    wwtp.on('popupopen', () => {\n      setIcon(wwtp, true, point);\n      tooltipVisible = true;\n    });\n  };\n\n  const renderLogic = () => {\n    let markerLocation: LatLngTuple = [point['latitude'], point['longitude']];\n    if (markerLocation[0] === null) return;\n\n    if (pointIsWWTP(point) && WWTPMode === true) {\n      WWTPMapLogic(markerLocation);\n    } else {\n      createBubblePoint(\n        markerLocation,\n        point,\n        map,\n        null,\n        layerGroup,\n        flowRateUnit,\n        handleSelectItem,\n      );\n    }\n  };\n\n  useEffect(() => {\n    renderLogic();\n  }, [rerender]);\n\n  return <></>;\n};\n\nconst connectedMarker = connect(mapStateToProps);\nexport default connectedMarker(\n  React.memo(PointMarker, (prevProps, nextProps) => {\n    return (\n      prevProps.events_data.focusedEvent === nextProps.events_data.focusedEvent\n    );\n  }),\n);\n"],"mappings":"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"}
153
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRedux","_PointUtils","_Widget","_reactDom","_interopRequireDefault","_utils","_ListContext","_Capacity","_reactRouterDom","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","mapStateToProps","state","areas_data","points_data","global_data","PointMarker","props","map","point","rerender","layerGroup","flowRateUnit","dispatch","useDispatch","_useSelectedItem","useSelectedItem","handleSelectItem","WWTPMode","useSelector","wwtp_dashboard","history","useHistory","WWTPMapLogic","markerLocation","wwtpPoint","_objectSpread2","forWWTPMap","markerOnMap","getLayers","find","layer","kando_object_id","id","args","wwtp","bubbleForWWTP","tooltipVisible","addTo","fetchDataAndShowPopup","_ref","_asyncToGenerator2","_regenerator","mark","_callee","widgetContainer","wrap","_callee$","_context","prev","next","document","createElement","createPopupForObject","renderedElement","marker","fetchCapacity","waterAuthorityId","then","listData","ReactDOM","render","Widget","object","points","items","areas","newAreas","isPopupOpen","openPopup","stop","apply","arguments","on","closePopup","sendAnalyticsEvent","point_id","point_name","name","setIcon","renderLogic","pointIsWWTP","createBubblePoint","useEffect","Fragment","connectedMarker","connect","_default","React","memo","exports"],"sources":["../../../../src/Widgets/Map/points/PointMarker.tsx"],"sourcesContent":["import React, { useEffect } from 'react';\nimport { connect, ConnectedProps, useDispatch, useSelector } from 'react-redux';\nimport { IAppState } from 'src/models/IAppState';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport {\n  bubbleForWWTP,\n  createBubblePoint,\n  pointIsWWTP,\n  setIcon,\n} from './PointUtils';\nimport { Widget } from 'src/pages/DashboardMap/Widget';\nimport ReactDOM from 'react-dom';\nimport L, { LatLngTuple } from 'leaflet';\nimport {\n  createPopupForObject,\n  sendAnalyticsEvent,\n} from 'src/pages/DashboardMap/utils';\nimport { useSelectedItem } from 'src/pages/DashboardMap/ListContext';\nimport { fetchCapacity } from 'src/pages/DashboardMap/Capacity';\nimport { useHistory } from 'react-router-dom';\n\nfunction mapStateToProps(state: IAppState) {\n  const { areas_data, points_data, global_data } = state;\n\n  return {\n    // events_data,\n    areas_data,\n    points_data,\n    global_data,\n  };\n}\n\ntype Props = ConnectedProps<typeof connectedMarker> & {\n  map: any;\n  point: IPoint;\n  rerender: string;\n  layerGroup: any;\n  flowRateUnit: string;\n};\n\nconst PointMarker: React.FC<Props> = (props) => {\n  const {\n    map,\n    point,\n    rerender,\n    layerGroup,\n    flowRateUnit,\n    points_data,\n    areas_data,\n    global_data,\n  } = props;\n  const dispatch = useDispatch();\n  const { handleSelectItem } = useSelectedItem();\n  const WWTPMode = useSelector((state) => state.wwtp_dashboard.map !== null);\n  const history = useHistory();\n\n  const WWTPMapLogic = (markerLocation) => {\n    const wwtpPoint = {\n      ...point,\n      forWWTPMap: true,\n    };\n    const markerOnMap = layerGroup\n      .getLayers()\n      .find((layer) => layer.kando_object_id === point.id);\n    let args = { markerLocation, wwtpPoint };\n    let wwtp: L.Marker = markerOnMap ? markerOnMap : bubbleForWWTP(args);\n    let tooltipVisible = false;\n\n    if (!markerOnMap) {\n      wwtp.addTo(layerGroup);\n    }\n\n    const fetchDataAndShowPopup = async () => {\n      const widgetContainer = document.createElement('span');\n\n      createPopupForObject({\n        renderedElement: widgetContainer,\n        marker: wwtp,\n      });\n\n      fetchCapacity('site', point.id, global_data.waterAuthorityId).then(\n        (listData) => {\n          ReactDOM.render(\n            <Widget\n              object={wwtpPoint}\n              dispatch={dispatch}\n              points={points_data.items}\n              areas={areas_data.newAreas}\n              map={map}\n              global_data={global_data}\n              listData={listData}\n              history={history}\n            />,\n            widgetContainer,\n          );\n        },\n      );\n\n      if (!wwtp.isPopupOpen()) {\n        wwtp.openPopup();\n      }\n    };\n\n    wwtp.on('click', () => {\n      wwtp.isPopupOpen() ? wwtp.closePopup() : fetchDataAndShowPopup();\n      sendAnalyticsEvent('Map View - WWTP clicked', 'map', {\n        point_id: point.id,\n        point_name: point.name,\n      });\n    });\n\n    wwtp.on('mouseover', () => {\n      if (tooltipVisible) return;\n\n      setIcon(wwtp, true, point);\n      tooltipVisible = true;\n    });\n\n    wwtp.on('mouseout', () => {\n      if (wwtp.isPopupOpen()) return;\n\n      setIcon(wwtp, false, point);\n      tooltipVisible = false;\n    });\n\n    wwtp.on('popupclose', () => {\n      setIcon(wwtp, false, point);\n      tooltipVisible = false;\n    });\n\n    wwtp.on('popupopen', () => {\n      setIcon(wwtp, true, point);\n      tooltipVisible = true;\n    });\n  };\n\n  const renderLogic = () => {\n    let markerLocation: LatLngTuple = [point['latitude'], point['longitude']];\n    if (markerLocation[0] === null) return;\n\n    if (pointIsWWTP(point) && WWTPMode === true) {\n      WWTPMapLogic(markerLocation);\n    } else {\n      createBubblePoint(\n        markerLocation,\n        point,\n        map,\n        null,\n        layerGroup,\n        flowRateUnit,\n        handleSelectItem,\n      );\n    }\n  };\n\n  useEffect(() => {\n    renderLogic();\n  }, [rerender]);\n\n  return <></>;\n};\n\nconst connectedMarker = connect(mapStateToProps);\nexport default connectedMarker(\n  React.memo(PointMarker),\n  // React.memo(PointMarker, (prevProps, nextProps) => {\n  //   return (\n  //     prevProps.events_data.focusedEvent === nextProps.events_data.focusedEvent\n  //   );\n  // }),\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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"}