@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.
- package/lib/Widgets/Map/events/EventPath.js +74 -25
- package/lib/Widgets/Map/events/PointOfEvent.js +2 -1
- package/lib/Widgets/Map/events/Snail.js +19 -22
- package/lib/Widgets/Map/points/PointMarker.js +10 -7
- package/lib/Widgets/Map/points/PointMarkers.js +14 -20
- package/lib/macros/getVersion.js +2 -2
- package/lib/pages/EventsPage/EventsMapContainer/EventsMapContainer.js +20 -4
- package/lib/pages/EventsPage/EventsMapContainer/EventsMapContainerHelpers.js +27 -21
- package/lib/pages/EventsPage/events/Sidebar.js +30 -25
- package/lib/pages/EventsPage/events/event_info/EventInfo.js +31 -15
- package/lib/pages/EventsPage/events/events_list/EventsList.js +5 -2
- package/package.json +1 -1
|
@@ -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 =
|
|
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(
|
|
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(
|
|
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
|
-
|
|
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
|
-
|
|
100
|
+
// const layers = map._layers;
|
|
101
|
+
// const layerLookup = buildLayerLookup(layers);
|
|
102
|
+
|
|
67
103
|
event.path.forEach(function (path) {
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
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
|
|
76
|
-
|
|
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(
|
|
83
|
-
|
|
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
|
|
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":";;;;;;;;AACA,IAAAA,QAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,MAAA,GAAAC,uBAAA,CAAAF,OAAA;AACA,IAAAG,WAAA,GAAAH,OAAA;AACA,IAAAI,QAAA,GAAAJ,OAAA;AAGkC,SAAAK,yBAAAC,WAAA,eAAAC,OAAA,kCAAAC,iBAAA,OAAAD,OAAA,QAAAE,gBAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,yBAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAAJ,wBAAAQ,GAAA,EAAAJ,WAAA,SAAAA,WAAA,IAAAI,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,aAAAE,OAAA,CAAAF,GAAA,yBAAAA,GAAA,4BAAAG,OAAA,EAAAH,GAAA,UAAAI,KAAA,GAAAT,wBAAA,CAAAC,WAAA,OAAAQ,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAL,GAAA,YAAAI,KAAA,CAAAE,GAAA,CAAAN,GAAA,SAAAO,MAAA,WAAAC,qBAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,GAAA,IAAAZ,GAAA,QAAAY,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAf,GAAA,EAAAY,GAAA,SAAAI,IAAA,GAAAR,qBAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAX,GAAA,EAAAY,GAAA,cAAAI,IAAA,KAAAA,IAAA,CAAAV,GAAA,IAAAU,IAAA,CAAAC,GAAA,KAAAR,MAAA,CAAAC,cAAA,CAAAH,MAAA,EAAAK,GAAA,EAAAI,IAAA,YAAAT,MAAA,CAAAK,GAAA,IAAAZ,GAAA,CAAAY,GAAA,SAAAL,MAAA,CAAAJ,OAAA,GAAAH,GAAA,MAAAI,KAAA,IAAAA,KAAA,CAAAa,GAAA,CAAAjB,GAAA,EAAAO,MAAA,YAAAA,MAAA;AAPlC;;AAiBA,IAAMW,SAA2B,GAAG,SAA9BA,SAA2BA,CAAAC,IAAA,EAI3B;EAAA,IAHJC,KAAK,GAAAD,IAAA,CAALC,KAAK;IACLC,WAAW,GAAAF,IAAA,CAAXE,WAAW;IAAAC,eAAA,GAAAH,IAAA,CACXI,UAAU;IAAVA,UAAU,GAAAD,eAAA,cAAG,EAAE,GAAAA,eAAA;EAEf,IAAQE,GAAG,GAAKH,WAAW,CAAnBG,GAAG;EACX,IAAMC,QAAQ,GAAG,IAAAC,uBAAW,EAAC,CAAC;EAE9B,IAAMC,YAAY,GAAG,SAAfA,YAAYA,CAChBP,KAAa,EACbQ,YAAiB,EACjBC,sBAA2B,EACxB;IACH,IAAIC,SAAS,GAAGC,gBAAC,CAACC,QAAQ,CAACJ,YAAY,EAAE;MACvCK,KAAK,EAAE,kBAAkB;MACzBC,MAAM,EAAE,EAAE;MACVC,SAAS,EAAE,YAAY;MACvBC,MAAM,EAAE;IACV,CAAC,CAAC,CAACC,KAAK,CAACb,GAAG,CAAC;IAEbK,sBAAsB,CAACS,IAAI,CAACR,SAAS,CAAC;IACtCA,SAAS,CAAC,iBAAiB,CAAC,GAAGV,KAAK,CAACmB,EAAE;IACvCT,SAAS,CAAC,cAAc,CAAC,GAAG,WAAW;IAEvC,IAAIU,QAAa;IACjB,IAAIC,MAAM,CAACV,CAAC,CAACW,MAAM,KAAKC,SAAS,EAAE;MACjCH,QAAQ,GAAGC,MAAM,CAACV,CAAC,CAACa,iBAAiB,CAACd,SAAS,CAACe,QAAQ,EAAE;QACxDC,QAAQ,EAAE;QACR;QACA;UACEC,MAAM,EAAE,EAAE;UACVC,MAAM,EAAE,EAAE;UACVC,MAAM,EAAER,MAAM,CAACV,CAAC,CAACW,MAAM,CAACQ,SAAS,CAAC;YAChCC,SAAS,EAAE,CAAC;YACZC,OAAO,EAAE,KAAK;YACdC,WAAW,EAAE;cACXjB,MAAM,EAAE,IAAI;cACZH,KAAK,EAAE,kBAAkB;cACzBC,MAAM,EAAE,CAAC;cACToB,OAAO,EAAE;YACX;UACF,CAAC;QACH,CAAC;MAEL,CAAC,CAAC,CAACjB,KAAK,CAACb,GAAG,CAAC;MACbgB,QAAQ,CAAC,cAAc,CAAC,GAAG,OAAO;IACpC;IAEAX,sBAAsB,CAACS,IAAI,CAACE,QAAQ,CAAC;IACrC,IAAIpB,KAAK,CAACmC,OAAO,EAAE;MACjB9B,QAAQ,CAAC,IAAA+B,6BAAoB,EAAC3B,sBAAsB,CAAC,CAAC;IACxD,CAAC,MAAM;MACLJ,QAAQ,CAAC,IAAAgC,6BAAoB,EAAC5B,sBAAsB,CAAC,CAAC;IACxD;EACF,CAAC;EAED,IAAM6B,eAAe,GAAG,SAAlBA,eAAeA,CAAItC,KAAa,EAAEuC,OAAgB,EAAK;IAC3D,IAAInC,GAAG,KAAKmB,SAAS,EAAE;MACrB,IAAId,sBAA6B,GAAG,EAAE;MACtC,IAAI+B,MAAM,GAAGpC,GAAG,CAACqC,OAAO;MACxBzC,KAAK,CAAC0C,IAAI,CAACC,OAAO,CAAC,UAACD,IAAS,EAAK;QAChC,KAAK,IAAME,QAAQ,IAAIJ,MAAM,EAAE;UAC7B,IACEA,MAAM,CAACI,QAAQ,CAAC,CAACC,eAAe,KAAKtB,SAAS,IAC9CiB,MAAM,CAACI,QAAQ,CAAC,CAACC,eAAe,KAAKH,IAAI,CAACI,OAAO,IACjDN,MAAM,CAACI,QAAQ,CAAC,CAACG,YAAY,KAAK,MAAM,EACxC;YACA,IAAIvC,YAAY,GAAGgC,MAAM,CAACI,QAAQ,CAAC,CAACI,UAAU,CAAC,CAAC;YAChDzC,YAAY,CAACP,KAAK,EAAEQ,YAAY,EAAEC,sBAAsB,CAAC;UAC3D;QACF;MACF,CAAC,CAAC;MAEF,IAAI,CAAC8B,OAAO,IAAI9B,sBAAsB,CAACwC,MAAM,KAAK,CAAC,EAAE;QACnD7C,GAAG,CAAC8C,SAAS,CACXvC,gBAAC,CAACwC,YAAY,CAAC1C,sBAAsB,CAAC,CAAC2C,SAAS,CAAC,CAAC,CAACC,GAAG,CAAC,GAAG,CAC5D,CAAC;MACH;IACF;EACF,CAAC;EAED,IAAAC,gBAAS,EAAC,YAAM;IACd,IAAInD,UAAU,EAAE;MACdA,UAAU,CAACwC,OAAO,CAAC,UAACD,IAAI,EAAK;QAC3BtC,GAAG,CAACmD,WAAW,CAACb,IAAI,CAAC;MACvB,CAAC,CAAC;MAEFJ,eAAe,CAACtC,KAAK,EAAEA,KAAK,CAACmC,OAAO,CAAC;IACvC;EACF,CAAC,EAAE,CAACnC,KAAK,EAAEA,KAAK,CAACmC,OAAO,CAAC,CAAC;EAE1B,oBAAOhE,MAAA,CAAAY,OAAA,CAAAyE,aAAA,CAAArF,MAAA,CAAAY,OAAA,CAAA0E,QAAA,MAAI,CAAC;AACd,CAAC;AAAC,IAAAC,QAAA,GAEa5D,SAAS;AAAA6D,OAAA,CAAA5E,OAAA,GAAA2E,QAAA"}
|
|
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 =
|
|
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
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
};
|
|
38
|
-
|
|
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,
|
|
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
|
|
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
|
-
|
|
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
|
|
147
|
-
|
|
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
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
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
|
|
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
|
|
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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"}
|