@kando-env/kando-ui 1.2.395-alpha.2 → 1.2.395-alpha.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/macros/getVersion.js +1 -1
- package/lib/pages/OperationsPage/Map/Map.js +30 -0
- package/lib/pages/OperationsPage/Map/useMap.js +201 -0
- package/lib/pages/OperationsPage/OperationsPage.js +9 -3
- package/lib/pages/OperationsPage/OperationsPage.scss +4 -0
- package/lib/pages/OperationsPage/RightPanel.js +2 -2
- package/package.json +1 -1
- package/lib/pages/OperationsPage/Map.js +0 -29
- package/lib/pages/OperationsPage/useMap.js +0 -170
package/lib/macros/getVersion.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
var packageJsonVersion = "1.2.395-alpha.
|
|
3
|
+
var packageJsonVersion = "1.2.395-alpha.3";
|
|
4
4
|
if (typeof packageJsonVersion === 'string') {
|
|
5
5
|
// eslint-disable-next-line no-console
|
|
6
6
|
console.log("%c Kando UI %c v".concat(packageJsonVersion, " "), 'font-size: 15px; background-color: #fff; color: #e20f53;', 'font-weight: bold; font-size: 15px; background-color: #e20f53; color: #fff;', "with NODE_ENV=".concat(process.env.NODE_ENV));
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.Map = void 0;
|
|
9
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
10
|
+
var _useMap = require("./useMap");
|
|
11
|
+
var _ErrorBoundary = _interopRequireDefault(require("utilities/ErrorBoundary"));
|
|
12
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
13
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
14
|
+
var Map = function Map(_ref) {
|
|
15
|
+
var points = _ref.points,
|
|
16
|
+
edges = _ref.edges,
|
|
17
|
+
areas = _ref.areas,
|
|
18
|
+
selectedPoint = _ref.selectedPoint,
|
|
19
|
+
updateSelectedPoint = _ref.updateSelectedPoint;
|
|
20
|
+
var mapRef = (0, _react.useRef)(null);
|
|
21
|
+
(0, _useMap.useMap)(mapRef, points, edges, areas, selectedPoint, updateSelectedPoint);
|
|
22
|
+
return /*#__PURE__*/_react.default.createElement("div", {
|
|
23
|
+
className: "map-container"
|
|
24
|
+
}, /*#__PURE__*/_react.default.createElement(_ErrorBoundary.default, null, /*#__PURE__*/_react.default.createElement("div", {
|
|
25
|
+
ref: mapRef,
|
|
26
|
+
className: "map-heights"
|
|
27
|
+
})));
|
|
28
|
+
};
|
|
29
|
+
exports.Map = Map;
|
|
30
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVXaWxkY2FyZCIsInJlcXVpcmUiLCJfdXNlTWFwIiwiX0Vycm9yQm91bmRhcnkiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwiX2dldFJlcXVpcmVXaWxkY2FyZENhY2hlIiwibm9kZUludGVyb3AiLCJXZWFrTWFwIiwiY2FjaGVCYWJlbEludGVyb3AiLCJjYWNoZU5vZGVJbnRlcm9wIiwib2JqIiwiX19lc01vZHVsZSIsIl90eXBlb2YiLCJkZWZhdWx0IiwiY2FjaGUiLCJoYXMiLCJnZXQiLCJuZXdPYmoiLCJoYXNQcm9wZXJ0eURlc2NyaXB0b3IiLCJPYmplY3QiLCJkZWZpbmVQcm9wZXJ0eSIsImdldE93blByb3BlcnR5RGVzY3JpcHRvciIsImtleSIsInByb3RvdHlwZSIsImhhc093blByb3BlcnR5IiwiY2FsbCIsImRlc2MiLCJzZXQiLCJNYXAiLCJfcmVmIiwicG9pbnRzIiwiZWRnZXMiLCJhcmVhcyIsInNlbGVjdGVkUG9pbnQiLCJ1cGRhdGVTZWxlY3RlZFBvaW50IiwibWFwUmVmIiwidXNlUmVmIiwidXNlTWFwIiwiY3JlYXRlRWxlbWVudCIsImNsYXNzTmFtZSIsInJlZiIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvcGFnZXMvT3BlcmF0aW9uc1BhZ2UvTWFwL01hcC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IHVzZVJlZiB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHVzZU1hcCB9IGZyb20gJy4vdXNlTWFwJztcbmltcG9ydCBFcnJvckJvdW5kYXJ5IGZyb20gJ3NyYy91dGlsaXRpZXMvRXJyb3JCb3VuZGFyeSc7XG5pbXBvcnQgeyBJUG9pbnQgfSBmcm9tICdzcmMvc3RvcmUvcG9pbnRzL21vZGVscy9JUG9pbnQnO1xuaW1wb3J0IHsgSUVkZ2UgfSBmcm9tICdzcmMvc3RvcmUvZWRnZXMvbW9kZWxzL0lFZGdlJztcbmltcG9ydCB7IElBcmVhIH0gZnJvbSAnc3JjL3N0b3JlL2FyZWFzL21vZGVscy9JQXJlYSc7XG5cbmludGVyZmFjZSBNYXBQcm9wcyB7XG4gIHBvaW50czogSVBvaW50W107XG4gIGVkZ2VzOiBJRWRnZVtdO1xuICBhcmVhczogSUFyZWFbXTtcbiAgc2VsZWN0ZWRQb2ludDogSVBvaW50IHwgbnVsbDtcbiAgdXBkYXRlU2VsZWN0ZWRQb2ludDogKHBvaW50OiBJUG9pbnQpID0+IHZvaWQ7XG59XG5cbmV4cG9ydCBjb25zdCBNYXA6IFJlYWN0LkZDPE1hcFByb3BzPiA9ICh7XG4gIHBvaW50cyxcbiAgZWRnZXMsXG4gIGFyZWFzLFxuICBzZWxlY3RlZFBvaW50LFxuICB1cGRhdGVTZWxlY3RlZFBvaW50LFxufSkgPT4ge1xuICBjb25zdCBtYXBSZWYgPSB1c2VSZWY8SFRNTERpdkVsZW1lbnQ+KG51bGwpO1xuICB1c2VNYXAobWFwUmVmLCBwb2ludHMsIGVkZ2VzLCBhcmVhcywgc2VsZWN0ZWRQb2ludCwgdXBkYXRlU2VsZWN0ZWRQb2ludCk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNsYXNzTmFtZT1cIm1hcC1jb250YWluZXJcIj5cbiAgICAgIDxFcnJvckJvdW5kYXJ5PlxuICAgICAgICA8ZGl2IHJlZj17bWFwUmVmfSBjbGFzc05hbWU9XCJtYXAtaGVpZ2h0c1wiIC8+XG4gICAgICA8L0Vycm9yQm91bmRhcnk+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7OztBQUFBLElBQUFBLE1BQUEsR0FBQUMsdUJBQUEsQ0FBQUMsT0FBQTtBQUNBLElBQUFDLE9BQUEsR0FBQUQsT0FBQTtBQUNBLElBQUFFLGNBQUEsR0FBQUMsc0JBQUEsQ0FBQUgsT0FBQTtBQUF3RCxTQUFBSSx5QkFBQUMsV0FBQSxlQUFBQyxPQUFBLGtDQUFBQyxpQkFBQSxPQUFBRCxPQUFBLFFBQUFFLGdCQUFBLE9BQUFGLE9BQUEsWUFBQUYsd0JBQUEsWUFBQUEseUJBQUFDLFdBQUEsV0FBQUEsV0FBQSxHQUFBRyxnQkFBQSxHQUFBRCxpQkFBQSxLQUFBRixXQUFBO0FBQUEsU0FBQU4sd0JBQUFVLEdBQUEsRUFBQUosV0FBQSxTQUFBQSxXQUFBLElBQUFJLEdBQUEsSUFBQUEsR0FBQSxDQUFBQyxVQUFBLFdBQUFELEdBQUEsUUFBQUEsR0FBQSxhQUFBRSxPQUFBLENBQUFGLEdBQUEseUJBQUFBLEdBQUEsNEJBQUFHLE9BQUEsRUFBQUgsR0FBQSxVQUFBSSxLQUFBLEdBQUFULHdCQUFBLENBQUFDLFdBQUEsT0FBQVEsS0FBQSxJQUFBQSxLQUFBLENBQUFDLEdBQUEsQ0FBQUwsR0FBQSxZQUFBSSxLQUFBLENBQUFFLEdBQUEsQ0FBQU4sR0FBQSxTQUFBTyxNQUFBLFdBQUFDLHFCQUFBLEdBQUFDLE1BQUEsQ0FBQUMsY0FBQSxJQUFBRCxNQUFBLENBQUFFLHdCQUFBLFdBQUFDLEdBQUEsSUFBQVosR0FBQSxRQUFBWSxHQUFBLGtCQUFBSCxNQUFBLENBQUFJLFNBQUEsQ0FBQUMsY0FBQSxDQUFBQyxJQUFBLENBQUFmLEdBQUEsRUFBQVksR0FBQSxTQUFBSSxJQUFBLEdBQUFSLHFCQUFBLEdBQUFDLE1BQUEsQ0FBQUUsd0JBQUEsQ0FBQVgsR0FBQSxFQUFBWSxHQUFBLGNBQUFJLElBQUEsS0FBQUEsSUFBQSxDQUFBVixHQUFBLElBQUFVLElBQUEsQ0FBQUMsR0FBQSxLQUFBUixNQUFBLENBQUFDLGNBQUEsQ0FBQUgsTUFBQSxFQUFBSyxHQUFBLEVBQUFJLElBQUEsWUFBQVQsTUFBQSxDQUFBSyxHQUFBLElBQUFaLEdBQUEsQ0FBQVksR0FBQSxTQUFBTCxNQUFBLENBQUFKLE9BQUEsR0FBQUgsR0FBQSxNQUFBSSxLQUFBLElBQUFBLEtBQUEsQ0FBQWEsR0FBQSxDQUFBakIsR0FBQSxFQUFBTyxNQUFBLFlBQUFBLE1BQUE7QUFhakQsSUFBTVcsR0FBdUIsR0FBRyxTQUExQkEsR0FBdUJBLENBQUFDLElBQUEsRUFNOUI7RUFBQSxJQUxKQyxNQUFNLEdBQUFELElBQUEsQ0FBTkMsTUFBTTtJQUNOQyxLQUFLLEdBQUFGLElBQUEsQ0FBTEUsS0FBSztJQUNMQyxLQUFLLEdBQUFILElBQUEsQ0FBTEcsS0FBSztJQUNMQyxhQUFhLEdBQUFKLElBQUEsQ0FBYkksYUFBYTtJQUNiQyxtQkFBbUIsR0FBQUwsSUFBQSxDQUFuQkssbUJBQW1CO0VBRW5CLElBQU1DLE1BQU0sR0FBRyxJQUFBQyxhQUFNLEVBQWlCLElBQUksQ0FBQztFQUMzQyxJQUFBQyxjQUFNLEVBQUNGLE1BQU0sRUFBRUwsTUFBTSxFQUFFQyxLQUFLLEVBQUVDLEtBQUssRUFBRUMsYUFBYSxFQUFFQyxtQkFBbUIsQ0FBQztFQUV4RSxvQkFDRW5DLE1BQUEsQ0FBQWMsT0FBQSxDQUFBeUIsYUFBQTtJQUFLQyxTQUFTLEVBQUM7RUFBZSxnQkFDNUJ4QyxNQUFBLENBQUFjLE9BQUEsQ0FBQXlCLGFBQUEsQ0FBQ25DLGNBQUEsQ0FBQVUsT0FBYSxxQkFDWmQsTUFBQSxDQUFBYyxPQUFBLENBQUF5QixhQUFBO0lBQUtFLEdBQUcsRUFBRUwsTUFBTztJQUFDSSxTQUFTLEVBQUM7RUFBYSxDQUFFLENBQzlCLENBQ1osQ0FBQztBQUVWLENBQUM7QUFBQ0UsT0FBQSxDQUFBYixHQUFBLEdBQUFBLEdBQUEifQ==
|
|
@@ -0,0 +1,201 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.useMap = void 0;
|
|
8
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/slicedToArray"));
|
|
9
|
+
var _leaflet = _interopRequireDefault(require("leaflet"));
|
|
10
|
+
var _react = require("react");
|
|
11
|
+
var _PointIcon = require("Widgets/Map/points/PointIcon");
|
|
12
|
+
var _theme = require("styles/theme/theme");
|
|
13
|
+
var _MapUtils = require("Widgets/Map/MapUtils");
|
|
14
|
+
var useMap = function useMap(mapRef, points, edges, areas, selectedPoint, updateSelectedPoint) {
|
|
15
|
+
var _useState = (0, _react.useState)(),
|
|
16
|
+
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
|
|
17
|
+
map = _useState2[0],
|
|
18
|
+
setMap = _useState2[1];
|
|
19
|
+
var _useState3 = (0, _react.useState)(null),
|
|
20
|
+
_useState4 = (0, _slicedToArray2.default)(_useState3, 2),
|
|
21
|
+
focusedMarker = _useState4[0],
|
|
22
|
+
setFocusedMarker = _useState4[1];
|
|
23
|
+
var pointsLayerRef = (0, _react.useRef)();
|
|
24
|
+
var edgesLayerRef = (0, _react.useRef)();
|
|
25
|
+
var areasLayerRef = (0, _react.useRef)();
|
|
26
|
+
(0, _react.useEffect)(function () {
|
|
27
|
+
if (!mapRef.current) {
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
var mapTypes = (0, _MapUtils.baseMaps)(_theme.leafletMap.mapDefault, _theme.leafletMap.satellite);
|
|
31
|
+
var mapTemp = _leaflet.default.map(mapRef.current, {
|
|
32
|
+
renderer: _leaflet.default.canvas()
|
|
33
|
+
});
|
|
34
|
+
Object.values(mapTypes)[0].addTo(mapTemp);
|
|
35
|
+
_leaflet.default.control.layers(mapTypes, {}, {
|
|
36
|
+
position: 'bottomright'
|
|
37
|
+
}).addTo(mapTemp);
|
|
38
|
+
setMap(mapTemp);
|
|
39
|
+
return function () {
|
|
40
|
+
if (!mapTemp) {
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
mapTemp.off();
|
|
44
|
+
mapTemp.remove();
|
|
45
|
+
};
|
|
46
|
+
}, []);
|
|
47
|
+
(0, _react.useEffect)(function () {
|
|
48
|
+
var _pointsLayerRef$curre;
|
|
49
|
+
if (focusedMarker) {
|
|
50
|
+
focusedMarker.fire('mouseout');
|
|
51
|
+
}
|
|
52
|
+
(_pointsLayerRef$curre = pointsLayerRef.current) === null || _pointsLayerRef$curre === void 0 ? void 0 : _pointsLayerRef$curre.eachLayer(function (marker) {
|
|
53
|
+
if (selectedPoint && marker.options.kando_object_id === (selectedPoint === null || selectedPoint === void 0 ? void 0 : selectedPoint.id)) {
|
|
54
|
+
marker.fire('mouseover');
|
|
55
|
+
setFocusedMarker(marker);
|
|
56
|
+
return;
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
}, [selectedPoint]);
|
|
60
|
+
var handleMarkerClick = function handleMarkerClick(point) {
|
|
61
|
+
updateSelectedPoint(point);
|
|
62
|
+
};
|
|
63
|
+
var addMarkers = function addMarkers() {
|
|
64
|
+
if (!map || !points) {
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
67
|
+
if (pointsLayerRef.current) {
|
|
68
|
+
if (map.hasLayer(pointsLayerRef.current)) {
|
|
69
|
+
map.removeLayer(pointsLayerRef.current);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
pointsLayerRef.current = _leaflet.default.featureGroup();
|
|
73
|
+
pointsLayerRef.current.addTo(map);
|
|
74
|
+
if (!pointsLayerRef.current.getLayers().length) {
|
|
75
|
+
points.forEach(function (point) {
|
|
76
|
+
var _pointsLayerRef$curre2;
|
|
77
|
+
var icon = (0, _PointIcon.getPointIconByType)(point.group.type, point.name, '', false, true);
|
|
78
|
+
var focusedIcon = (0, _PointIcon.getPointIconByType)(point.group.type, point.name, '', true, false);
|
|
79
|
+
var marker = getMarker(point);
|
|
80
|
+
if (marker instanceof _leaflet.default.Marker) {
|
|
81
|
+
marker.setIcon(icon);
|
|
82
|
+
// The use of marker._isInside is to overcome the issue that mouseover is endlessly triggered
|
|
83
|
+
// and we need it onley once
|
|
84
|
+
marker.on('mouseover', function () {
|
|
85
|
+
if (!marker._isInside) {
|
|
86
|
+
marker._isInside = true;
|
|
87
|
+
marker.setIcon(focusedIcon);
|
|
88
|
+
}
|
|
89
|
+
});
|
|
90
|
+
marker.on('mouseout', function () {
|
|
91
|
+
marker._isInside = false;
|
|
92
|
+
marker.setIcon(icon);
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
marker.on('click', function () {
|
|
96
|
+
handleMarkerClick(point);
|
|
97
|
+
});
|
|
98
|
+
(_pointsLayerRef$curre2 = pointsLayerRef.current) === null || _pointsLayerRef$curre2 === void 0 ? void 0 : _pointsLayerRef$curre2.addLayer(marker);
|
|
99
|
+
});
|
|
100
|
+
}
|
|
101
|
+
if (pointsLayerRef.current.getLayers().length) {
|
|
102
|
+
map.fitBounds(pointsLayerRef.current.getBounds());
|
|
103
|
+
} else {
|
|
104
|
+
map.setView([32.219157, 34.982481], 12);
|
|
105
|
+
}
|
|
106
|
+
};
|
|
107
|
+
var getMarker = function getMarker(point) {
|
|
108
|
+
if (point.has_device === true || point.group.type === 'Groups::WastewaterTreatmentPlant') {
|
|
109
|
+
return _leaflet.default.marker([point.latitude, point.longitude], {
|
|
110
|
+
kando_object_id: point.id
|
|
111
|
+
});
|
|
112
|
+
} else {
|
|
113
|
+
return _leaflet.default.circleMarker([point.latitude, point.longitude], {
|
|
114
|
+
radius: 4,
|
|
115
|
+
// circle radius in pixels
|
|
116
|
+
color: '#000000',
|
|
117
|
+
// border (stroke) color
|
|
118
|
+
weight: 1,
|
|
119
|
+
// border (stroke) width
|
|
120
|
+
fillColor: '#ffffff',
|
|
121
|
+
// fill color (white)
|
|
122
|
+
fillOpacity: 1,
|
|
123
|
+
// fully opaque
|
|
124
|
+
kando_object_id: point.id
|
|
125
|
+
});
|
|
126
|
+
}
|
|
127
|
+
};
|
|
128
|
+
var addEdges = function addEdges() {
|
|
129
|
+
// console.log('edges', edges);
|
|
130
|
+
if (!map || !edges) {
|
|
131
|
+
return;
|
|
132
|
+
}
|
|
133
|
+
if (edgesLayerRef.current) {
|
|
134
|
+
if (map.hasLayer(edgesLayerRef.current)) {
|
|
135
|
+
map.removeLayer(edgesLayerRef.current);
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
edgesLayerRef.current = _leaflet.default.featureGroup();
|
|
139
|
+
edgesLayerRef.current.addTo(map);
|
|
140
|
+
edges.forEach(function (edge) {
|
|
141
|
+
var _edgesLayerRef$curren;
|
|
142
|
+
var sourcePoint = points.find(function (point) {
|
|
143
|
+
return point.id === edge.source_point_id;
|
|
144
|
+
});
|
|
145
|
+
var targetPoint = points.find(function (point) {
|
|
146
|
+
return point.id === edge.target_point_id;
|
|
147
|
+
});
|
|
148
|
+
// console.log('sourcePoint', sourcePoint);
|
|
149
|
+
// console.log('targetPoint', targetPoint);
|
|
150
|
+
|
|
151
|
+
if (!sourcePoint || !targetPoint) {
|
|
152
|
+
return;
|
|
153
|
+
}
|
|
154
|
+
var latlngs = [[sourcePoint === null || sourcePoint === void 0 ? void 0 : sourcePoint.latitude, sourcePoint === null || sourcePoint === void 0 ? void 0 : sourcePoint.longitude], [targetPoint === null || targetPoint === void 0 ? void 0 : targetPoint.latitude, targetPoint === null || targetPoint === void 0 ? void 0 : targetPoint.longitude]];
|
|
155
|
+
var polyline = _leaflet.default.polyline(latlngs, {
|
|
156
|
+
color: 'black',
|
|
157
|
+
weight: 1,
|
|
158
|
+
opacity: 0.5,
|
|
159
|
+
smoothFactor: 1
|
|
160
|
+
});
|
|
161
|
+
(_edgesLayerRef$curren = edgesLayerRef.current) === null || _edgesLayerRef$curren === void 0 ? void 0 : _edgesLayerRef$curren.addLayer(polyline);
|
|
162
|
+
});
|
|
163
|
+
};
|
|
164
|
+
var addAreas = function addAreas() {
|
|
165
|
+
if (!map || !areas) {
|
|
166
|
+
return;
|
|
167
|
+
}
|
|
168
|
+
if (areasLayerRef.current) {
|
|
169
|
+
if (map.hasLayer(areasLayerRef.current)) {
|
|
170
|
+
map.removeLayer(areasLayerRef.current);
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
areasLayerRef.current = _leaflet.default.featureGroup();
|
|
174
|
+
areasLayerRef.current.addTo(map);
|
|
175
|
+
areas.forEach(function (area) {
|
|
176
|
+
var _areasLayerRef$curren;
|
|
177
|
+
var polygon = _leaflet.default.polygon(area.shape_data, {
|
|
178
|
+
color: 'black',
|
|
179
|
+
weight: 1,
|
|
180
|
+
opacity: 0.8,
|
|
181
|
+
smoothFactor: 1,
|
|
182
|
+
interactive: false,
|
|
183
|
+
kando_object_id: area.area_id
|
|
184
|
+
});
|
|
185
|
+
polygon.bindTooltip(area.area_name, {
|
|
186
|
+
permanent: true,
|
|
187
|
+
direction: 'center',
|
|
188
|
+
className: 'area-tooltip'
|
|
189
|
+
});
|
|
190
|
+
(_areasLayerRef$curren = areasLayerRef.current) === null || _areasLayerRef$curren === void 0 ? void 0 : _areasLayerRef$curren.addLayer(polygon);
|
|
191
|
+
});
|
|
192
|
+
};
|
|
193
|
+
(0, _react.useEffect)(function () {
|
|
194
|
+
addAreas();
|
|
195
|
+
addMarkers();
|
|
196
|
+
addEdges();
|
|
197
|
+
}, [points, map]);
|
|
198
|
+
return map;
|
|
199
|
+
};
|
|
200
|
+
exports.useMap = useMap;
|
|
201
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_leaflet","_interopRequireDefault","require","_react","_PointIcon","_theme","_MapUtils","useMap","mapRef","points","edges","areas","selectedPoint","updateSelectedPoint","_useState","useState","_useState2","_slicedToArray2","default","map","setMap","_useState3","_useState4","focusedMarker","setFocusedMarker","pointsLayerRef","useRef","edgesLayerRef","areasLayerRef","useEffect","current","mapTypes","baseMaps","leafletMap","mapDefault","satellite","mapTemp","L","renderer","canvas","Object","values","addTo","control","layers","position","off","remove","_pointsLayerRef$curre","fire","eachLayer","marker","options","kando_object_id","id","handleMarkerClick","point","addMarkers","hasLayer","removeLayer","featureGroup","getLayers","length","forEach","_pointsLayerRef$curre2","icon","getPointIconByType","group","type","name","focusedIcon","getMarker","Marker","setIcon","on","_isInside","addLayer","fitBounds","getBounds","setView","has_device","latitude","longitude","circleMarker","radius","color","weight","fillColor","fillOpacity","addEdges","edge","_edgesLayerRef$curren","sourcePoint","find","source_point_id","targetPoint","target_point_id","latlngs","polyline","opacity","smoothFactor","addAreas","area","_areasLayerRef$curren","polygon","shape_data","interactive","area_id","bindTooltip","area_name","permanent","direction","className","exports"],"sources":["../../../../src/pages/OperationsPage/Map/useMap.tsx"],"sourcesContent":["import L, { Marker } from 'leaflet';\nimport React, { useEffect, useRef, useState } from 'react';\nimport { getPointIconByType } from 'src/Widgets/Map/points/PointIcon';\nimport { leafletMap } from 'src/styles/theme/theme';\nimport { baseMaps } from 'src/Widgets/Map/MapUtils';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport { IEdge } from 'src/store/edges/models/IEdge';\nimport { IArea } from 'src/store/areas/models/IArea';\n\nexport const useMap = (\n  mapRef: React.RefObject<HTMLDivElement>,\n  points: IPoint[],\n  edges: IEdge[],\n  areas: IArea[],\n  selectedPoint: IPoint | null,\n  updateSelectedPoint: (point: IPoint) => void,\n): L.Map | undefined => {\n  const [map, setMap] = useState<L.Map>();\n  const [focusedMarker, setFocusedMarker] = useState<Marker | null>(null);\n  const pointsLayerRef = useRef<L.FeatureGroup>();\n  const edgesLayerRef = useRef<L.FeatureGroup>();\n  const areasLayerRef = useRef<L.FeatureGroup>();\n\n  useEffect(() => {\n    if (!mapRef.current) {\n      return;\n    }\n\n    const mapTypes = baseMaps(leafletMap.mapDefault, leafletMap.satellite);\n    const mapTemp = L.map(mapRef.current, { renderer: L.canvas() });\n\n    Object.values(mapTypes)[0].addTo(mapTemp);\n\n    L.control.layers(mapTypes, {}, { position: 'bottomright' }).addTo(mapTemp);\n\n    setMap(mapTemp);\n\n    return () => {\n      if (!mapTemp) {\n        return;\n      }\n      mapTemp.off();\n      mapTemp.remove();\n    };\n  }, []);\n\n  useEffect(() => {\n    if (focusedMarker) {\n      focusedMarker.fire('mouseout');\n    }\n\n    pointsLayerRef.current?.eachLayer((marker) => {\n      if (\n        selectedPoint &&\n        marker.options.kando_object_id === selectedPoint?.id\n      ) {\n        marker.fire('mouseover');\n        setFocusedMarker(marker);\n        return;\n      }\n    });\n  }, [selectedPoint]);\n\n  const handleMarkerClick = (point) => {\n    updateSelectedPoint(point);\n  };\n\n  const addMarkers = () => {\n    if (!map || !points) {\n      return;\n    }\n\n    if (pointsLayerRef.current) {\n      if (map.hasLayer(pointsLayerRef.current)) {\n        map.removeLayer(pointsLayerRef.current);\n      }\n    }\n\n    pointsLayerRef.current = L.featureGroup();\n    pointsLayerRef.current.addTo(map);\n\n    if (!pointsLayerRef.current.getLayers().length) {\n      points.forEach((point) => {\n        const icon = getPointIconByType(\n          point.group.type,\n          point.name,\n          '',\n          false,\n          true,\n        );\n\n        const focusedIcon = getPointIconByType(\n          point.group.type,\n          point.name,\n          '',\n          true,\n          false,\n        );\n\n        let marker = getMarker(point);\n\n        if (marker instanceof L.Marker) {\n          marker.setIcon(icon);\n          // The use of marker._isInside is to overcome the issue that mouseover is endlessly triggered\n          // and we need it onley once\n          marker.on('mouseover', () => {\n            if (!marker._isInside) {\n              marker._isInside = true;\n              marker.setIcon(focusedIcon);\n            }\n          });\n          marker.on('mouseout', () => {\n            marker._isInside = false;\n            marker.setIcon(icon);\n          });\n        }\n\n        marker.on('click', () => {\n          handleMarkerClick(point);\n        });\n\n        pointsLayerRef.current?.addLayer(marker);\n      });\n    }\n\n    if (pointsLayerRef.current.getLayers().length) {\n      map.fitBounds(pointsLayerRef.current.getBounds());\n    } else {\n      map.setView([32.219157, 34.982481], 12);\n    }\n  };\n\n  const getMarker = (point: IPoint) => {\n    if (\n      point.has_device === true ||\n      point.group.type === 'Groups::WastewaterTreatmentPlant'\n    ) {\n      return L.marker([point.latitude, point.longitude], {\n        kando_object_id: point.id,\n      });\n    } else {\n      return L.circleMarker([point.latitude, point.longitude], {\n        radius: 4, // circle radius in pixels\n        color: '#000000', // border (stroke) color\n        weight: 1, // border (stroke) width\n        fillColor: '#ffffff', // fill color (white)\n        fillOpacity: 1, // fully opaque\n        kando_object_id: point.id,\n      });\n    }\n  };\n\n  const addEdges = () => {\n    // console.log('edges', edges);\n    if (!map || !edges) {\n      return;\n    }\n\n    if (edgesLayerRef.current) {\n      if (map.hasLayer(edgesLayerRef.current)) {\n        map.removeLayer(edgesLayerRef.current);\n      }\n    }\n\n    edgesLayerRef.current = L.featureGroup();\n    edgesLayerRef.current.addTo(map);\n\n    edges.forEach((edge) => {\n      const sourcePoint = points.find(\n        (point) => point.id === edge.source_point_id,\n      );\n      const targetPoint = points.find(\n        (point) => point.id === edge.target_point_id,\n      );\n      // console.log('sourcePoint', sourcePoint);\n      // console.log('targetPoint', targetPoint);\n\n      if (!sourcePoint || !targetPoint) {\n        return;\n      }\n\n      const latlngs = [\n        [sourcePoint?.latitude, sourcePoint?.longitude],\n        [targetPoint?.latitude, targetPoint?.longitude],\n      ];\n\n      const polyline = L.polyline(latlngs, {\n        color: 'black',\n        weight: 1,\n        opacity: 0.5,\n        smoothFactor: 1,\n      });\n\n      edgesLayerRef.current?.addLayer(polyline);\n    });\n  };\n\n  const addAreas = () => {\n    if (!map || !areas) {\n      return;\n    }\n\n    if (areasLayerRef.current) {\n      if (map.hasLayer(areasLayerRef.current)) {\n        map.removeLayer(areasLayerRef.current);\n      }\n    }\n\n    areasLayerRef.current = L.featureGroup();\n    areasLayerRef.current.addTo(map);\n\n    areas.forEach((area) => {\n      const polygon = L.polygon(area.shape_data, {\n        color: 'black',\n        weight: 1,\n        opacity: 0.8,\n        smoothFactor: 1,\n        interactive: false,\n        kando_object_id: area.area_id,\n      });\n\n      polygon.bindTooltip(area.area_name, {\n        permanent: true,\n        direction: 'center',\n        className: 'area-tooltip',\n      });\n\n      areasLayerRef.current?.addLayer(polygon);\n    });\n  };\n\n  useEffect(() => {\n    addAreas();\n    addMarkers();\n    addEdges();\n  }, [points, map]);\n\n  return map;\n};\n"],"mappings":"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"}
|
|
@@ -14,9 +14,10 @@ var _reactBootstrap = require("react-bootstrap");
|
|
|
14
14
|
var _actions = require("store/context/actions");
|
|
15
15
|
var _actions2 = require("store/points/actions");
|
|
16
16
|
var _actions3 = require("store/edges/actions");
|
|
17
|
-
var _Map = require("./Map");
|
|
17
|
+
var _Map = require("./Map/Map");
|
|
18
18
|
var _LeftPanel = _interopRequireDefault(require("./LeftPanel"));
|
|
19
19
|
var _RightPanel = _interopRequireDefault(require("./RightPanel"));
|
|
20
|
+
var _actions4 = require("store/areas/actions");
|
|
20
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); }
|
|
21
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; }
|
|
22
23
|
var OperationsPage = function OperationsPage() {
|
|
@@ -27,6 +28,9 @@ var OperationsPage = function OperationsPage() {
|
|
|
27
28
|
var edges_data = (0, _reactRedux.useSelector)(function (state) {
|
|
28
29
|
return state.edges_data;
|
|
29
30
|
});
|
|
31
|
+
var areas_data = (0, _reactRedux.useSelector)(function (state) {
|
|
32
|
+
return state.areas_data;
|
|
33
|
+
});
|
|
30
34
|
var global_data = (0, _reactRedux.useSelector)(function (state) {
|
|
31
35
|
return state.global_data;
|
|
32
36
|
});
|
|
@@ -54,6 +58,7 @@ var OperationsPage = function OperationsPage() {
|
|
|
54
58
|
if (global_data.waterAuthorityId) {
|
|
55
59
|
dispatch((0, _actions2.fetchPoints)(global_data.waterAuthorityId));
|
|
56
60
|
dispatch((0, _actions3.fetchEdges)(global_data.waterAuthorityId));
|
|
61
|
+
dispatch((0, _actions4.fetchAreas)(global_data.waterAuthorityId));
|
|
57
62
|
}
|
|
58
63
|
}, [global_data.waterAuthorityId]);
|
|
59
64
|
var monitoredPoints = (0, _react.useMemo)(function () {
|
|
@@ -93,9 +98,10 @@ var OperationsPage = function OperationsPage() {
|
|
|
93
98
|
}, showLeftPanel), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Col, {
|
|
94
99
|
className: "map-column",
|
|
95
100
|
sm: 9
|
|
96
|
-
}, /*#__PURE__*/_react.default.createElement(_Map.Map, {
|
|
101
|
+
}, !edges_data.isFetching && !areas_data.isFetching && /*#__PURE__*/_react.default.createElement(_Map.Map, {
|
|
97
102
|
points: points,
|
|
98
103
|
edges: edges_data.items,
|
|
104
|
+
areas: areas_data.newAreas,
|
|
99
105
|
selectedPoint: selectedPoint,
|
|
100
106
|
updateSelectedPoint: handleSelectPoint
|
|
101
107
|
}), /*#__PURE__*/_react.default.createElement(_RightPanel.default, {
|
|
@@ -106,4 +112,4 @@ var OperationsPage = function OperationsPage() {
|
|
|
106
112
|
};
|
|
107
113
|
var _default = OperationsPage;
|
|
108
114
|
exports.default = _default;
|
|
109
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["require","_react","_interopRequireWildcard","_reactRedux","_reactBootstrap","_actions","_actions2","_actions3","_Map","_LeftPanel","_interopRequireDefault","_RightPanel","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","OperationsPage","dispatch","useDispatch","points_data","useSelector","state","edges_data","global_data","_useState","useState","_useState2","_slicedToArray2","showRightPanel","setShowRightPanel","_useState3","_useState4","selectedPoint","setSelectedPoint","handleSelectPoint","newPoint","id","useEffect","updateNavContext","name","waterAuthorityId","fetchPoints","fetchEdges","monitoredPoints","useMemo","_points_data$items","items","filter","point","has_device","points","_points_data$items2","latitude","longitude","showLeftPanel","createElement","onRightPanelClose","Container","fluid","className","Row","Col","sm","Map","edges","updateSelectedPoint","concat","onClose","_default","exports"],"sources":["../../../src/pages/OperationsPage/OperationsPage.tsx"],"sourcesContent":["import './OperationsPage.scss';\nimport React, { useEffect, useMemo, useState } from 'react';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { Col, Container, Row } from 'react-bootstrap';\nimport { updateNavContext } from 'src/store/context/actions';\nimport { fetchPoints } from 'src/store/points/actions';\nimport { fetchEdges } from 'src/store/edges/actions';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport { Map } from './Map';\nimport LeftPanel from './LeftPanel';\nimport RightPanel from './RightPanel';\n\nconst OperationsPage: React.FC = () => {\n  const dispatch = useDispatch();\n  const points_data = useSelector((state) => state.points_data);\n  const edges_data = useSelector((state) => state.edges_data);\n  const global_data = useSelector((state) => state.global_data);\n  const [showRightPanel, setShowRightPanel] = useState(false);\n  const [selectedPoint, setSelectedPoint] = useState<IPoint | null>(null);\n\n  const handleSelectPoint = (newPoint: IPoint) => {\n    if (selectedPoint && newPoint.id === selectedPoint.id) {\n      setSelectedPoint(null);\n    } else {\n      setSelectedPoint(newPoint);\n    }\n  };\n\n  useEffect(() => {\n    dispatch(updateNavContext({ name: 'operations' }));\n  }, []);\n\n  useEffect(() => {\n    if (global_data.waterAuthorityId) {\n      dispatch(fetchPoints(global_data.waterAuthorityId));\n      dispatch(fetchEdges(global_data.waterAuthorityId));\n    }\n  }, [global_data.waterAuthorityId]);\n\n  const monitoredPoints = useMemo(() => {\n    return points_data.items?.filter((point: IPoint) => point.has_device) || [];\n  }, [points_data.items]);\n\n  const points = useMemo(() => {\n    return (\n      points_data.items?.filter(\n        (point: IPoint) => point.latitude && point.longitude,\n      ) || []\n    );\n  }, [points_data.items]);\n\n  const showLeftPanel = useMemo(() => {\n    return (\n      <LeftPanel\n        points={monitoredPoints}\n        setSelectedPoint={handleSelectPoint}\n      />\n    );\n  }, [monitoredPoints, selectedPoint]);\n\n  useEffect(() => {\n    if (selectedPoint) {\n      setShowRightPanel(true);\n    } else {\n      setShowRightPanel(false);\n    }\n  }, [selectedPoint]);\n\n  const onRightPanelClose = () => {\n    setSelectedPoint(null);\n  };\n\n  return (\n    <Container fluid className=\"vh-90 p-0\">\n      <Row>\n        <Col sm={3} className=\"left-panel\">\n          {showLeftPanel}\n        </Col>\n        <Col className=\"map-column\" sm={9}>\n          <Map\n            points={points}\n            edges={edges_data.items}\n            selectedPoint={selectedPoint}\n            updateSelectedPoint={handleSelectPoint}\n          />\n          <RightPanel\n            className={`right-panel ${showRightPanel ? 'open' : ''}`}\n            point={selectedPoint}\n            onClose={onRightPanelClose}\n          />\n        </Col>\n      </Row>\n    </Container>\n  );\n};\n\nexport default OperationsPage;\n"],"mappings":"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"}
|
|
115
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["require","_react","_interopRequireWildcard","_reactRedux","_reactBootstrap","_actions","_actions2","_actions3","_Map","_LeftPanel","_interopRequireDefault","_RightPanel","_actions4","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","OperationsPage","dispatch","useDispatch","points_data","useSelector","state","edges_data","areas_data","global_data","_useState","useState","_useState2","_slicedToArray2","showRightPanel","setShowRightPanel","_useState3","_useState4","selectedPoint","setSelectedPoint","handleSelectPoint","newPoint","id","useEffect","updateNavContext","name","waterAuthorityId","fetchPoints","fetchEdges","fetchAreas","monitoredPoints","useMemo","_points_data$items","items","filter","point","has_device","points","_points_data$items2","latitude","longitude","showLeftPanel","createElement","onRightPanelClose","Container","fluid","className","Row","Col","sm","isFetching","Map","edges","areas","newAreas","updateSelectedPoint","concat","onClose","_default","exports"],"sources":["../../../src/pages/OperationsPage/OperationsPage.tsx"],"sourcesContent":["import './OperationsPage.scss';\nimport React, { useEffect, useMemo, useState } from 'react';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { Col, Container, Row } from 'react-bootstrap';\nimport { updateNavContext } from 'src/store/context/actions';\nimport { fetchPoints } from 'src/store/points/actions';\nimport { fetchEdges } from 'src/store/edges/actions';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport { Map } from './Map/Map';\nimport LeftPanel from './LeftPanel';\nimport RightPanel from './RightPanel';\nimport { fetchAreas } from 'src/store/areas/actions';\n\nconst OperationsPage: React.FC = () => {\n  const dispatch = useDispatch();\n  const points_data = useSelector((state) => state.points_data);\n  const edges_data = useSelector((state) => state.edges_data);\n  const areas_data = useSelector((state) => state.areas_data);\n  const global_data = useSelector((state) => state.global_data);\n  const [showRightPanel, setShowRightPanel] = useState(false);\n  const [selectedPoint, setSelectedPoint] = useState<IPoint | null>(null);\n\n  const handleSelectPoint = (newPoint: IPoint) => {\n    if (selectedPoint && newPoint.id === selectedPoint.id) {\n      setSelectedPoint(null);\n    } else {\n      setSelectedPoint(newPoint);\n    }\n  };\n\n  useEffect(() => {\n    dispatch(updateNavContext({ name: 'operations' }));\n  }, []);\n\n  useEffect(() => {\n    if (global_data.waterAuthorityId) {\n      dispatch(fetchPoints(global_data.waterAuthorityId));\n      dispatch(fetchEdges(global_data.waterAuthorityId));\n      dispatch(fetchAreas(global_data.waterAuthorityId));\n    }\n  }, [global_data.waterAuthorityId]);\n\n  const monitoredPoints = useMemo(() => {\n    return points_data.items?.filter((point: IPoint) => point.has_device) || [];\n  }, [points_data.items]);\n\n  const points = useMemo(() => {\n    return (\n      points_data.items?.filter(\n        (point: IPoint) => point.latitude && point.longitude,\n      ) || []\n    );\n  }, [points_data.items]);\n\n  const showLeftPanel = useMemo(() => {\n    return (\n      <LeftPanel\n        points={monitoredPoints}\n        setSelectedPoint={handleSelectPoint}\n      />\n    );\n  }, [monitoredPoints, selectedPoint]);\n\n  useEffect(() => {\n    if (selectedPoint) {\n      setShowRightPanel(true);\n    } else {\n      setShowRightPanel(false);\n    }\n  }, [selectedPoint]);\n\n  const onRightPanelClose = () => {\n    setSelectedPoint(null);\n  };\n\n  return (\n    <Container fluid className=\"vh-90 p-0\">\n      <Row>\n        <Col sm={3} className=\"left-panel\">\n          {showLeftPanel}\n        </Col>\n        <Col className=\"map-column\" sm={9}>\n          {!edges_data.isFetching && !areas_data.isFetching && (\n            <Map\n              points={points}\n              edges={edges_data.items}\n              areas={areas_data.newAreas}\n              selectedPoint={selectedPoint}\n              updateSelectedPoint={handleSelectPoint}\n            />\n          )}\n          <RightPanel\n            className={`right-panel ${showRightPanel ? 'open' : ''}`}\n            point={selectedPoint}\n            onClose={onRightPanelClose}\n          />\n        </Col>\n      </Row>\n    </Container>\n  );\n};\n\nexport default OperationsPage;\n"],"mappings":"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"}
|
|
@@ -21,8 +21,8 @@ var RightPanel = function RightPanel(_ref) {
|
|
|
21
21
|
className: "drawer-body p-3"
|
|
22
22
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
23
23
|
className: "form-group"
|
|
24
|
-
}, /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement("strong", null, 'Name:'), " ", point === null || point === void 0 ? void 0 : point.name), /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement("strong", null, 'Description:'), " ", point === null || point === void 0 ? void 0 : point.description), /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement("strong", null, 'Device Status:'), " ", point === null || point === void 0 ? void 0 : point.device_status), /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement("strong", null, 'Sector:'), " ", point === null || point === void 0 ? void 0 : point.group.sector_name), /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement("strong", null, 'Type:'), " ", point === null || point === void 0 ? void 0 : point.group.type), /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement("strong", null, 'Water Discharge:'), ' ', point === null || point === void 0 ? void 0 : point.group.water_discharge)))));
|
|
24
|
+
}, /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement("strong", null, 'Name:'), " ", point === null || point === void 0 ? void 0 : point.name), /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement("strong", null, 'Description:'), " ", point === null || point === void 0 ? void 0 : point.description), /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement("strong", null, 'Monitored:'), " ", (point === null || point === void 0 ? void 0 : point.has_device) ? 'Yes' : 'No'), /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement("strong", null, 'Device Status:'), " ", point === null || point === void 0 ? void 0 : point.device_status), /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement("strong", null, 'Sector:'), " ", point === null || point === void 0 ? void 0 : point.group.sector_name), /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement("strong", null, 'Type:'), " ", point === null || point === void 0 ? void 0 : point.group.type), /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement("strong", null, 'Water Discharge:'), ' ', point === null || point === void 0 ? void 0 : point.group.water_discharge)))));
|
|
25
25
|
};
|
|
26
26
|
var _default = RightPanel;
|
|
27
27
|
exports.default = _default;
|
|
28
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
28
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIlJpZ2h0UGFuZWwiLCJfcmVmIiwicG9pbnQiLCJjbGFzc05hbWUiLCJvbkNsb3NlIiwiZGVmYXVsdCIsImNyZWF0ZUVsZW1lbnQiLCJvbkNsaWNrIiwibmFtZSIsImRlc2NyaXB0aW9uIiwiaGFzX2RldmljZSIsImRldmljZV9zdGF0dXMiLCJncm91cCIsInNlY3Rvcl9uYW1lIiwidHlwZSIsIndhdGVyX2Rpc2NoYXJnZSIsIl9kZWZhdWx0IiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9wYWdlcy9PcGVyYXRpb25zUGFnZS9SaWdodFBhbmVsLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgSVBvaW50IH0gZnJvbSAnc3JjL3N0b3JlL3BvaW50cy9tb2RlbHMvSVBvaW50JztcblxudHlwZSBSaWdodFBhbmVsUHJvcHMgPSB7XG4gIHBvaW50OiBJUG9pbnQgfCBudWxsO1xuICBjbGFzc05hbWU/OiBzdHJpbmc7XG4gIG9uQ2xvc2U/OiAoKSA9PiB2b2lkO1xufTtcblxuY29uc3QgUmlnaHRQYW5lbDogUmVhY3QuRkM8UmlnaHRQYW5lbFByb3BzPiA9ICh7XG4gIHBvaW50LFxuICBjbGFzc05hbWUsXG4gIG9uQ2xvc2UsXG59KSA9PiB7XG4gIHJldHVybiAoXG4gICAgPGRpdiBjbGFzc05hbWU9e2NsYXNzTmFtZX0+XG4gICAgICA8ZGl2IGNsYXNzTmFtZT1cImRyYXdlci1oZWFkZXIgZC1mbGV4IGFsaWduLWl0ZW1zLWNlbnRlciBqdXN0aWZ5LWNvbnRlbnQtYmV0d2VlbiBwLTMgcHItNFwiPlxuICAgICAgICB7J1BvaW50IERldGFpbHMnfVxuICAgICAgICA8YnV0dG9uIGNsYXNzTmFtZT1cImNsb3NlXCIgb25DbGljaz17b25DbG9zZX0+XG4gICAgICAgICAgPHNwYW4+JnRpbWVzOzwvc3Bhbj5cbiAgICAgICAgPC9idXR0b24+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxkaXY+XG4gICAgICAgIDxkaXYgY2xhc3NOYW1lPVwiZHJhd2VyLWJvZHkgcC0zXCI+XG4gICAgICAgICAgPGRpdiBjbGFzc05hbWU9XCJmb3JtLWdyb3VwXCI+XG4gICAgICAgICAgICA8cD5cbiAgICAgICAgICAgICAgPHN0cm9uZz57J05hbWU6J308L3N0cm9uZz4ge3BvaW50Py5uYW1lfVxuICAgICAgICAgICAgPC9wPlxuICAgICAgICAgICAgPHA+XG4gICAgICAgICAgICAgIDxzdHJvbmc+eydEZXNjcmlwdGlvbjonfTwvc3Ryb25nPiB7cG9pbnQ/LmRlc2NyaXB0aW9ufVxuICAgICAgICAgICAgPC9wPlxuICAgICAgICAgICAgPHA+XG4gICAgICAgICAgICAgIDxzdHJvbmc+eydNb25pdG9yZWQ6J308L3N0cm9uZz4ge3BvaW50Py5oYXNfZGV2aWNlID8gJ1llcycgOiAnTm8nfVxuICAgICAgICAgICAgPC9wPlxuICAgICAgICAgICAgPHA+XG4gICAgICAgICAgICAgIDxzdHJvbmc+eydEZXZpY2UgU3RhdHVzOid9PC9zdHJvbmc+IHtwb2ludD8uZGV2aWNlX3N0YXR1c31cbiAgICAgICAgICAgIDwvcD5cbiAgICAgICAgICAgIDxwPlxuICAgICAgICAgICAgICA8c3Ryb25nPnsnU2VjdG9yOid9PC9zdHJvbmc+IHtwb2ludD8uZ3JvdXAuc2VjdG9yX25hbWV9XG4gICAgICAgICAgICA8L3A+XG4gICAgICAgICAgICA8cD5cbiAgICAgICAgICAgICAgPHN0cm9uZz57J1R5cGU6J308L3N0cm9uZz4ge3BvaW50Py5ncm91cC50eXBlfVxuICAgICAgICAgICAgPC9wPlxuICAgICAgICAgICAgPHA+XG4gICAgICAgICAgICAgIDxzdHJvbmc+eydXYXRlciBEaXNjaGFyZ2U6J308L3N0cm9uZz57JyAnfVxuICAgICAgICAgICAgICB7cG9pbnQ/Lmdyb3VwLndhdGVyX2Rpc2NoYXJnZX1cbiAgICAgICAgICAgIDwvcD5cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IFJpZ2h0UGFuZWw7XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQSxJQUFBQSxNQUFBLEdBQUFDLHNCQUFBLENBQUFDLE9BQUE7QUFTQSxJQUFNQyxVQUFxQyxHQUFHLFNBQXhDQSxVQUFxQ0EsQ0FBQUMsSUFBQSxFQUlyQztFQUFBLElBSEpDLEtBQUssR0FBQUQsSUFBQSxDQUFMQyxLQUFLO0lBQ0xDLFNBQVMsR0FBQUYsSUFBQSxDQUFURSxTQUFTO0lBQ1RDLE9BQU8sR0FBQUgsSUFBQSxDQUFQRyxPQUFPO0VBRVAsb0JBQ0VQLE1BQUEsQ0FBQVEsT0FBQSxDQUFBQyxhQUFBO0lBQUtILFNBQVMsRUFBRUE7RUFBVSxnQkFDeEJOLE1BQUEsQ0FBQVEsT0FBQSxDQUFBQyxhQUFBO0lBQUtILFNBQVMsRUFBQztFQUEwRSxHQUN0RixlQUFlLGVBQ2hCTixNQUFBLENBQUFRLE9BQUEsQ0FBQUMsYUFBQTtJQUFRSCxTQUFTLEVBQUMsT0FBTztJQUFDSSxPQUFPLEVBQUVIO0VBQVEsZ0JBQ3pDUCxNQUFBLENBQUFRLE9BQUEsQ0FBQUMsYUFBQSxlQUFNLE1BQWEsQ0FDYixDQUNMLENBQUMsZUFDTlQsTUFBQSxDQUFBUSxPQUFBLENBQUFDLGFBQUEsMkJBQ0VULE1BQUEsQ0FBQVEsT0FBQSxDQUFBQyxhQUFBO0lBQUtILFNBQVMsRUFBQztFQUFpQixnQkFDOUJOLE1BQUEsQ0FBQVEsT0FBQSxDQUFBQyxhQUFBO0lBQUtILFNBQVMsRUFBQztFQUFZLGdCQUN6Qk4sTUFBQSxDQUFBUSxPQUFBLENBQUFDLGFBQUEseUJBQ0VULE1BQUEsQ0FBQVEsT0FBQSxDQUFBQyxhQUFBLGlCQUFTLE9BQWdCLENBQUMsS0FBQyxFQUFDSixLQUFLLGFBQUxBLEtBQUssdUJBQUxBLEtBQUssQ0FBRU0sSUFDbEMsQ0FBQyxlQUNKWCxNQUFBLENBQUFRLE9BQUEsQ0FBQUMsYUFBQSx5QkFDRVQsTUFBQSxDQUFBUSxPQUFBLENBQUFDLGFBQUEsaUJBQVMsY0FBdUIsQ0FBQyxLQUFDLEVBQUNKLEtBQUssYUFBTEEsS0FBSyx1QkFBTEEsS0FBSyxDQUFFTyxXQUN6QyxDQUFDLGVBQ0paLE1BQUEsQ0FBQVEsT0FBQSxDQUFBQyxhQUFBLHlCQUNFVCxNQUFBLENBQUFRLE9BQUEsQ0FBQUMsYUFBQSxpQkFBUyxZQUFxQixDQUFDLEtBQUMsRUFBQyxDQUFBSixLQUFLLGFBQUxBLEtBQUssdUJBQUxBLEtBQUssQ0FBRVEsVUFBVSxJQUFHLEtBQUssR0FBRyxJQUM1RCxDQUFDLGVBQ0piLE1BQUEsQ0FBQVEsT0FBQSxDQUFBQyxhQUFBLHlCQUNFVCxNQUFBLENBQUFRLE9BQUEsQ0FBQUMsYUFBQSxpQkFBUyxnQkFBeUIsQ0FBQyxLQUFDLEVBQUNKLEtBQUssYUFBTEEsS0FBSyx1QkFBTEEsS0FBSyxDQUFFUyxhQUMzQyxDQUFDLGVBQ0pkLE1BQUEsQ0FBQVEsT0FBQSxDQUFBQyxhQUFBLHlCQUNFVCxNQUFBLENBQUFRLE9BQUEsQ0FBQUMsYUFBQSxpQkFBUyxTQUFrQixDQUFDLEtBQUMsRUFBQ0osS0FBSyxhQUFMQSxLQUFLLHVCQUFMQSxLQUFLLENBQUVVLEtBQUssQ0FBQ0MsV0FDMUMsQ0FBQyxlQUNKaEIsTUFBQSxDQUFBUSxPQUFBLENBQUFDLGFBQUEseUJBQ0VULE1BQUEsQ0FBQVEsT0FBQSxDQUFBQyxhQUFBLGlCQUFTLE9BQWdCLENBQUMsS0FBQyxFQUFDSixLQUFLLGFBQUxBLEtBQUssdUJBQUxBLEtBQUssQ0FBRVUsS0FBSyxDQUFDRSxJQUN4QyxDQUFDLGVBQ0pqQixNQUFBLENBQUFRLE9BQUEsQ0FBQUMsYUFBQSx5QkFDRVQsTUFBQSxDQUFBUSxPQUFBLENBQUFDLGFBQUEsaUJBQVMsa0JBQTJCLENBQUMsRUFBQyxHQUFHLEVBQ3hDSixLQUFLLGFBQUxBLEtBQUssdUJBQUxBLEtBQUssQ0FBRVUsS0FBSyxDQUFDRyxlQUNiLENBQ0EsQ0FDRixDQUNGLENBQ0YsQ0FBQztBQUVWLENBQUM7QUFBQyxJQUFBQyxRQUFBLEdBRWFoQixVQUFVO0FBQUFpQixPQUFBLENBQUFaLE9BQUEsR0FBQVcsUUFBQSJ9
|
package/package.json
CHANGED
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
5
|
-
Object.defineProperty(exports, "__esModule", {
|
|
6
|
-
value: true
|
|
7
|
-
});
|
|
8
|
-
exports.Map = void 0;
|
|
9
|
-
var _react = _interopRequireWildcard(require("react"));
|
|
10
|
-
var _useMap = require("./useMap");
|
|
11
|
-
var _ErrorBoundary = _interopRequireDefault(require("utilities/ErrorBoundary"));
|
|
12
|
-
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
13
|
-
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
14
|
-
var Map = function Map(_ref) {
|
|
15
|
-
var points = _ref.points,
|
|
16
|
-
edges = _ref.edges,
|
|
17
|
-
selectedPoint = _ref.selectedPoint,
|
|
18
|
-
updateSelectedPoint = _ref.updateSelectedPoint;
|
|
19
|
-
var mapRef = (0, _react.useRef)(null);
|
|
20
|
-
(0, _useMap.useMap)(mapRef, points, edges, selectedPoint, updateSelectedPoint);
|
|
21
|
-
return /*#__PURE__*/_react.default.createElement("div", {
|
|
22
|
-
className: "map-container"
|
|
23
|
-
}, /*#__PURE__*/_react.default.createElement(_ErrorBoundary.default, null, /*#__PURE__*/_react.default.createElement("div", {
|
|
24
|
-
ref: mapRef,
|
|
25
|
-
className: "map-heights"
|
|
26
|
-
})));
|
|
27
|
-
};
|
|
28
|
-
exports.Map = Map;
|
|
29
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVXaWxkY2FyZCIsInJlcXVpcmUiLCJfdXNlTWFwIiwiX0Vycm9yQm91bmRhcnkiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwiX2dldFJlcXVpcmVXaWxkY2FyZENhY2hlIiwibm9kZUludGVyb3AiLCJXZWFrTWFwIiwiY2FjaGVCYWJlbEludGVyb3AiLCJjYWNoZU5vZGVJbnRlcm9wIiwib2JqIiwiX19lc01vZHVsZSIsIl90eXBlb2YiLCJkZWZhdWx0IiwiY2FjaGUiLCJoYXMiLCJnZXQiLCJuZXdPYmoiLCJoYXNQcm9wZXJ0eURlc2NyaXB0b3IiLCJPYmplY3QiLCJkZWZpbmVQcm9wZXJ0eSIsImdldE93blByb3BlcnR5RGVzY3JpcHRvciIsImtleSIsInByb3RvdHlwZSIsImhhc093blByb3BlcnR5IiwiY2FsbCIsImRlc2MiLCJzZXQiLCJNYXAiLCJfcmVmIiwicG9pbnRzIiwiZWRnZXMiLCJzZWxlY3RlZFBvaW50IiwidXBkYXRlU2VsZWN0ZWRQb2ludCIsIm1hcFJlZiIsInVzZVJlZiIsInVzZU1hcCIsImNyZWF0ZUVsZW1lbnQiLCJjbGFzc05hbWUiLCJyZWYiLCJleHBvcnRzIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3BhZ2VzL09wZXJhdGlvbnNQYWdlL01hcC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IHVzZVJlZiB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHVzZU1hcCB9IGZyb20gJy4vdXNlTWFwJztcbmltcG9ydCBFcnJvckJvdW5kYXJ5IGZyb20gJ3NyYy91dGlsaXRpZXMvRXJyb3JCb3VuZGFyeSc7XG5pbXBvcnQgeyBJUG9pbnQgfSBmcm9tICdzcmMvc3RvcmUvcG9pbnRzL21vZGVscy9JUG9pbnQnO1xuaW1wb3J0IHsgSUVkZ2UgfSBmcm9tICdzcmMvc3RvcmUvZWRnZXMvbW9kZWxzL0lFZGdlJztcblxuaW50ZXJmYWNlIE1hcFByb3BzIHtcbiAgcG9pbnRzOiBJUG9pbnRbXTtcbiAgZWRnZXM6IElFZGdlW107XG4gIHNlbGVjdGVkUG9pbnQ6IElQb2ludCB8IG51bGw7XG4gIHVwZGF0ZVNlbGVjdGVkUG9pbnQ6IChwb2ludDogSVBvaW50KSA9PiB2b2lkO1xufVxuXG5leHBvcnQgY29uc3QgTWFwOiBSZWFjdC5GQzxNYXBQcm9wcz4gPSAoe1xuICBwb2ludHMsXG4gIGVkZ2VzLFxuICBzZWxlY3RlZFBvaW50LFxuICB1cGRhdGVTZWxlY3RlZFBvaW50LFxufSkgPT4ge1xuICBjb25zdCBtYXBSZWYgPSB1c2VSZWY8SFRNTERpdkVsZW1lbnQ+KG51bGwpO1xuICB1c2VNYXAobWFwUmVmLCBwb2ludHMsIGVkZ2VzLCBzZWxlY3RlZFBvaW50LCB1cGRhdGVTZWxlY3RlZFBvaW50KTtcblxuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPVwibWFwLWNvbnRhaW5lclwiPlxuICAgICAgPEVycm9yQm91bmRhcnk+XG4gICAgICAgIDxkaXYgcmVmPXttYXBSZWZ9IGNsYXNzTmFtZT1cIm1hcC1oZWlnaHRzXCIgLz5cbiAgICAgIDwvRXJyb3JCb3VuZGFyeT5cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBQUEsSUFBQUEsTUFBQSxHQUFBQyx1QkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsT0FBQSxHQUFBRCxPQUFBO0FBQ0EsSUFBQUUsY0FBQSxHQUFBQyxzQkFBQSxDQUFBSCxPQUFBO0FBQXdELFNBQUFJLHlCQUFBQyxXQUFBLGVBQUFDLE9BQUEsa0NBQUFDLGlCQUFBLE9BQUFELE9BQUEsUUFBQUUsZ0JBQUEsT0FBQUYsT0FBQSxZQUFBRix3QkFBQSxZQUFBQSx5QkFBQUMsV0FBQSxXQUFBQSxXQUFBLEdBQUFHLGdCQUFBLEdBQUFELGlCQUFBLEtBQUFGLFdBQUE7QUFBQSxTQUFBTix3QkFBQVUsR0FBQSxFQUFBSixXQUFBLFNBQUFBLFdBQUEsSUFBQUksR0FBQSxJQUFBQSxHQUFBLENBQUFDLFVBQUEsV0FBQUQsR0FBQSxRQUFBQSxHQUFBLGFBQUFFLE9BQUEsQ0FBQUYsR0FBQSx5QkFBQUEsR0FBQSw0QkFBQUcsT0FBQSxFQUFBSCxHQUFBLFVBQUFJLEtBQUEsR0FBQVQsd0JBQUEsQ0FBQUMsV0FBQSxPQUFBUSxLQUFBLElBQUFBLEtBQUEsQ0FBQUMsR0FBQSxDQUFBTCxHQUFBLFlBQUFJLEtBQUEsQ0FBQUUsR0FBQSxDQUFBTixHQUFBLFNBQUFPLE1BQUEsV0FBQUMscUJBQUEsR0FBQUMsTUFBQSxDQUFBQyxjQUFBLElBQUFELE1BQUEsQ0FBQUUsd0JBQUEsV0FBQUMsR0FBQSxJQUFBWixHQUFBLFFBQUFZLEdBQUEsa0JBQUFILE1BQUEsQ0FBQUksU0FBQSxDQUFBQyxjQUFBLENBQUFDLElBQUEsQ0FBQWYsR0FBQSxFQUFBWSxHQUFBLFNBQUFJLElBQUEsR0FBQVIscUJBQUEsR0FBQUMsTUFBQSxDQUFBRSx3QkFBQSxDQUFBWCxHQUFBLEVBQUFZLEdBQUEsY0FBQUksSUFBQSxLQUFBQSxJQUFBLENBQUFWLEdBQUEsSUFBQVUsSUFBQSxDQUFBQyxHQUFBLEtBQUFSLE1BQUEsQ0FBQUMsY0FBQSxDQUFBSCxNQUFBLEVBQUFLLEdBQUEsRUFBQUksSUFBQSxZQUFBVCxNQUFBLENBQUFLLEdBQUEsSUFBQVosR0FBQSxDQUFBWSxHQUFBLFNBQUFMLE1BQUEsQ0FBQUosT0FBQSxHQUFBSCxHQUFBLE1BQUFJLEtBQUEsSUFBQUEsS0FBQSxDQUFBYSxHQUFBLENBQUFqQixHQUFBLEVBQUFPLE1BQUEsWUFBQUEsTUFBQTtBQVdqRCxJQUFNVyxHQUF1QixHQUFHLFNBQTFCQSxHQUF1QkEsQ0FBQUMsSUFBQSxFQUs5QjtFQUFBLElBSkpDLE1BQU0sR0FBQUQsSUFBQSxDQUFOQyxNQUFNO0lBQ05DLEtBQUssR0FBQUYsSUFBQSxDQUFMRSxLQUFLO0lBQ0xDLGFBQWEsR0FBQUgsSUFBQSxDQUFiRyxhQUFhO0lBQ2JDLG1CQUFtQixHQUFBSixJQUFBLENBQW5CSSxtQkFBbUI7RUFFbkIsSUFBTUMsTUFBTSxHQUFHLElBQUFDLGFBQU0sRUFBaUIsSUFBSSxDQUFDO0VBQzNDLElBQUFDLGNBQU0sRUFBQ0YsTUFBTSxFQUFFSixNQUFNLEVBQUVDLEtBQUssRUFBRUMsYUFBYSxFQUFFQyxtQkFBbUIsQ0FBQztFQUVqRSxvQkFDRWxDLE1BQUEsQ0FBQWMsT0FBQSxDQUFBd0IsYUFBQTtJQUFLQyxTQUFTLEVBQUM7RUFBZSxnQkFDNUJ2QyxNQUFBLENBQUFjLE9BQUEsQ0FBQXdCLGFBQUEsQ0FBQ2xDLGNBQUEsQ0FBQVUsT0FBYSxxQkFDWmQsTUFBQSxDQUFBYyxPQUFBLENBQUF3QixhQUFBO0lBQUtFLEdBQUcsRUFBRUwsTUFBTztJQUFDSSxTQUFTLEVBQUM7RUFBYSxDQUFFLENBQzlCLENBQ1osQ0FBQztBQUVWLENBQUM7QUFBQ0UsT0FBQSxDQUFBWixHQUFBLEdBQUFBLEdBQUEifQ==
|
|
@@ -1,170 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
Object.defineProperty(exports, "__esModule", {
|
|
5
|
-
value: true
|
|
6
|
-
});
|
|
7
|
-
exports.useMap = void 0;
|
|
8
|
-
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/slicedToArray"));
|
|
9
|
-
var _leaflet = _interopRequireDefault(require("leaflet"));
|
|
10
|
-
var _react = require("react");
|
|
11
|
-
var _PointIcon = require("Widgets/Map/points/PointIcon");
|
|
12
|
-
var _theme = require("styles/theme/theme");
|
|
13
|
-
var _MapUtils = require("Widgets/Map/MapUtils");
|
|
14
|
-
var useMap = function useMap(mapRef, points, edges, selectedPoint, updateSelectedPoint) {
|
|
15
|
-
var _useState = (0, _react.useState)(),
|
|
16
|
-
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
|
|
17
|
-
map = _useState2[0],
|
|
18
|
-
setMap = _useState2[1];
|
|
19
|
-
var _useState3 = (0, _react.useState)(null),
|
|
20
|
-
_useState4 = (0, _slicedToArray2.default)(_useState3, 2),
|
|
21
|
-
focusedMarker = _useState4[0],
|
|
22
|
-
setFocusedMarker = _useState4[1];
|
|
23
|
-
var pointsLayerRef = (0, _react.useRef)();
|
|
24
|
-
var edgesLayerRef = (0, _react.useRef)();
|
|
25
|
-
(0, _react.useEffect)(function () {
|
|
26
|
-
if (!mapRef.current) {
|
|
27
|
-
return;
|
|
28
|
-
}
|
|
29
|
-
var mapTypes = (0, _MapUtils.baseMaps)(_theme.leafletMap.mapDefault, _theme.leafletMap.satellite);
|
|
30
|
-
var mapTemp = _leaflet.default.map(mapRef.current, {
|
|
31
|
-
renderer: _leaflet.default.canvas()
|
|
32
|
-
});
|
|
33
|
-
Object.values(mapTypes)[0].addTo(mapTemp);
|
|
34
|
-
_leaflet.default.control.layers(mapTypes, {}, {
|
|
35
|
-
position: 'bottomright'
|
|
36
|
-
}).addTo(mapTemp);
|
|
37
|
-
setMap(mapTemp);
|
|
38
|
-
return function () {
|
|
39
|
-
if (!mapTemp) {
|
|
40
|
-
return;
|
|
41
|
-
}
|
|
42
|
-
mapTemp.off();
|
|
43
|
-
mapTemp.remove();
|
|
44
|
-
};
|
|
45
|
-
}, []);
|
|
46
|
-
(0, _react.useEffect)(function () {
|
|
47
|
-
var _pointsLayerRef$curre;
|
|
48
|
-
if (focusedMarker) {
|
|
49
|
-
focusedMarker.fire('mouseout');
|
|
50
|
-
}
|
|
51
|
-
(_pointsLayerRef$curre = pointsLayerRef.current) === null || _pointsLayerRef$curre === void 0 ? void 0 : _pointsLayerRef$curre.eachLayer(function (marker) {
|
|
52
|
-
if (selectedPoint && marker.options.kando_object_id === (selectedPoint === null || selectedPoint === void 0 ? void 0 : selectedPoint.id)) {
|
|
53
|
-
marker.fire('mouseover');
|
|
54
|
-
setFocusedMarker(marker);
|
|
55
|
-
return;
|
|
56
|
-
}
|
|
57
|
-
});
|
|
58
|
-
}, [selectedPoint]);
|
|
59
|
-
var handleMarkerClick = function handleMarkerClick(point) {
|
|
60
|
-
updateSelectedPoint(point);
|
|
61
|
-
};
|
|
62
|
-
var addMarkers = function addMarkers() {
|
|
63
|
-
if (!map || !points) {
|
|
64
|
-
return;
|
|
65
|
-
}
|
|
66
|
-
if (pointsLayerRef.current) {
|
|
67
|
-
if (map.hasLayer(pointsLayerRef.current)) {
|
|
68
|
-
map.removeLayer(pointsLayerRef.current);
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
pointsLayerRef.current = _leaflet.default.featureGroup();
|
|
72
|
-
pointsLayerRef.current.addTo(map);
|
|
73
|
-
if (!pointsLayerRef.current.getLayers().length) {
|
|
74
|
-
points.forEach(function (point) {
|
|
75
|
-
var _pointsLayerRef$curre2;
|
|
76
|
-
var icon = (0, _PointIcon.getPointIconByType)(point.group.type, point.name, '', false, true);
|
|
77
|
-
var focusedIcon = (0, _PointIcon.getPointIconByType)(point.group.type, point.name, '', true, false);
|
|
78
|
-
var marker = getMarker(point);
|
|
79
|
-
if (point.has_device) {
|
|
80
|
-
marker.setIcon(icon);
|
|
81
|
-
// The use of marker._isInside is to overcome the issue that mouseover is endlessly triggered
|
|
82
|
-
// and we need it onley once
|
|
83
|
-
marker.on('mouseover', function () {
|
|
84
|
-
if (!marker._isInside) {
|
|
85
|
-
marker._isInside = true;
|
|
86
|
-
marker.setIcon(focusedIcon);
|
|
87
|
-
}
|
|
88
|
-
});
|
|
89
|
-
marker.on('mouseout', function () {
|
|
90
|
-
marker._isInside = false;
|
|
91
|
-
marker.setIcon(icon);
|
|
92
|
-
});
|
|
93
|
-
}
|
|
94
|
-
marker.on('click', function () {
|
|
95
|
-
handleMarkerClick(point);
|
|
96
|
-
});
|
|
97
|
-
(_pointsLayerRef$curre2 = pointsLayerRef.current) === null || _pointsLayerRef$curre2 === void 0 ? void 0 : _pointsLayerRef$curre2.addLayer(marker);
|
|
98
|
-
});
|
|
99
|
-
}
|
|
100
|
-
if (pointsLayerRef.current.getLayers().length) {
|
|
101
|
-
map.fitBounds(pointsLayerRef.current.getBounds());
|
|
102
|
-
} else {
|
|
103
|
-
map.setView([32.219157, 34.982481], 12);
|
|
104
|
-
}
|
|
105
|
-
};
|
|
106
|
-
var getMarker = function getMarker(point) {
|
|
107
|
-
if (point.has_device === true) {
|
|
108
|
-
return _leaflet.default.marker([point.latitude, point.longitude], {
|
|
109
|
-
kando_object_id: point.id
|
|
110
|
-
});
|
|
111
|
-
} else {
|
|
112
|
-
return _leaflet.default.circleMarker([point.latitude, point.longitude], {
|
|
113
|
-
radius: 4,
|
|
114
|
-
// circle radius in pixels
|
|
115
|
-
color: '#000000',
|
|
116
|
-
// border (stroke) color
|
|
117
|
-
weight: 1,
|
|
118
|
-
// border (stroke) width
|
|
119
|
-
fillColor: '#ffffff',
|
|
120
|
-
// fill color (white)
|
|
121
|
-
fillOpacity: 1,
|
|
122
|
-
// fully opaque
|
|
123
|
-
kando_object_id: point.id
|
|
124
|
-
});
|
|
125
|
-
}
|
|
126
|
-
};
|
|
127
|
-
var addEdges = function addEdges() {
|
|
128
|
-
// console.log('edges', edges);
|
|
129
|
-
if (!map || !edges) {
|
|
130
|
-
return;
|
|
131
|
-
}
|
|
132
|
-
if (edgesLayerRef.current) {
|
|
133
|
-
if (map.hasLayer(edgesLayerRef.current)) {
|
|
134
|
-
map.removeLayer(edgesLayerRef.current);
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
edgesLayerRef.current = _leaflet.default.featureGroup();
|
|
138
|
-
edgesLayerRef.current.addTo(map);
|
|
139
|
-
edges.forEach(function (edge) {
|
|
140
|
-
var _edgesLayerRef$curren;
|
|
141
|
-
var sourcePoint = points.find(function (point) {
|
|
142
|
-
return point.id === edge.source_point_id;
|
|
143
|
-
});
|
|
144
|
-
var targetPoint = points.find(function (point) {
|
|
145
|
-
return point.id === edge.target_point_id;
|
|
146
|
-
});
|
|
147
|
-
// console.log('sourcePoint', sourcePoint);
|
|
148
|
-
// console.log('targetPoint', targetPoint);
|
|
149
|
-
|
|
150
|
-
if (!sourcePoint || !targetPoint) {
|
|
151
|
-
return;
|
|
152
|
-
}
|
|
153
|
-
var latlngs = [[sourcePoint === null || sourcePoint === void 0 ? void 0 : sourcePoint.latitude, sourcePoint === null || sourcePoint === void 0 ? void 0 : sourcePoint.longitude], [targetPoint === null || targetPoint === void 0 ? void 0 : targetPoint.latitude, targetPoint === null || targetPoint === void 0 ? void 0 : targetPoint.longitude]];
|
|
154
|
-
var polyline = _leaflet.default.polyline(latlngs, {
|
|
155
|
-
color: 'black',
|
|
156
|
-
weight: 1,
|
|
157
|
-
opacity: 0.5,
|
|
158
|
-
smoothFactor: 1
|
|
159
|
-
});
|
|
160
|
-
(_edgesLayerRef$curren = edgesLayerRef.current) === null || _edgesLayerRef$curren === void 0 ? void 0 : _edgesLayerRef$curren.addLayer(polyline);
|
|
161
|
-
});
|
|
162
|
-
};
|
|
163
|
-
(0, _react.useEffect)(function () {
|
|
164
|
-
addMarkers();
|
|
165
|
-
addEdges();
|
|
166
|
-
}, [points, map]);
|
|
167
|
-
return map;
|
|
168
|
-
};
|
|
169
|
-
exports.useMap = useMap;
|
|
170
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_leaflet","_interopRequireDefault","require","_react","_PointIcon","_theme","_MapUtils","useMap","mapRef","points","edges","selectedPoint","updateSelectedPoint","_useState","useState","_useState2","_slicedToArray2","default","map","setMap","_useState3","_useState4","focusedMarker","setFocusedMarker","pointsLayerRef","useRef","edgesLayerRef","useEffect","current","mapTypes","baseMaps","leafletMap","mapDefault","satellite","mapTemp","L","renderer","canvas","Object","values","addTo","control","layers","position","off","remove","_pointsLayerRef$curre","fire","eachLayer","marker","options","kando_object_id","id","handleMarkerClick","point","addMarkers","hasLayer","removeLayer","featureGroup","getLayers","length","forEach","_pointsLayerRef$curre2","icon","getPointIconByType","group","type","name","focusedIcon","getMarker","has_device","setIcon","on","_isInside","addLayer","fitBounds","getBounds","setView","latitude","longitude","circleMarker","radius","color","weight","fillColor","fillOpacity","addEdges","edge","_edgesLayerRef$curren","sourcePoint","find","source_point_id","targetPoint","target_point_id","latlngs","polyline","opacity","smoothFactor","exports"],"sources":["../../../src/pages/OperationsPage/useMap.tsx"],"sourcesContent":["import L, { Marker } from 'leaflet';\nimport React, { useEffect, useRef, useState } from 'react';\nimport { getPointIconByType } from 'src/Widgets/Map/points/PointIcon';\nimport { leafletMap } from 'src/styles/theme/theme';\nimport { baseMaps } from 'src/Widgets/Map/MapUtils';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport { IEdge } from 'src/store/edges/models/IEdge';\n\nexport const useMap = (\n  mapRef: React.RefObject<HTMLDivElement>,\n  points: IPoint[],\n  edges: IEdge[],\n  selectedPoint: IPoint | null,\n  updateSelectedPoint: (point: IPoint) => void,\n): L.Map | undefined => {\n  const [map, setMap] = useState<L.Map>();\n  const [focusedMarker, setFocusedMarker] = useState<Marker | null>(null);\n  const pointsLayerRef = useRef<L.FeatureGroup>();\n  const edgesLayerRef = useRef<L.FeatureGroup>();\n\n  useEffect(() => {\n    if (!mapRef.current) {\n      return;\n    }\n\n    const mapTypes = baseMaps(leafletMap.mapDefault, leafletMap.satellite);\n    const mapTemp = L.map(mapRef.current, { renderer: L.canvas() });\n\n    Object.values(mapTypes)[0].addTo(mapTemp);\n\n    L.control.layers(mapTypes, {}, { position: 'bottomright' }).addTo(mapTemp);\n\n    setMap(mapTemp);\n\n    return () => {\n      if (!mapTemp) {\n        return;\n      }\n      mapTemp.off();\n      mapTemp.remove();\n    };\n  }, []);\n\n  useEffect(() => {\n    if (focusedMarker) {\n      focusedMarker.fire('mouseout');\n    }\n\n    pointsLayerRef.current?.eachLayer((marker) => {\n      if (\n        selectedPoint &&\n        marker.options.kando_object_id === selectedPoint?.id\n      ) {\n        marker.fire('mouseover');\n        setFocusedMarker(marker);\n        return;\n      }\n    });\n  }, [selectedPoint]);\n\n  const handleMarkerClick = (point) => {\n    updateSelectedPoint(point);\n  };\n\n  const addMarkers = () => {\n    if (!map || !points) {\n      return;\n    }\n\n    if (pointsLayerRef.current) {\n      if (map.hasLayer(pointsLayerRef.current)) {\n        map.removeLayer(pointsLayerRef.current);\n      }\n    }\n\n    pointsLayerRef.current = L.featureGroup();\n    pointsLayerRef.current.addTo(map);\n\n    if (!pointsLayerRef.current.getLayers().length) {\n      points.forEach((point) => {\n        const icon = getPointIconByType(\n          point.group.type,\n          point.name,\n          '',\n          false,\n          true,\n        );\n\n        const focusedIcon = getPointIconByType(\n          point.group.type,\n          point.name,\n          '',\n          true,\n          false,\n        );\n\n        let marker = getMarker(point);\n\n        if (point.has_device) {\n          marker.setIcon(icon);\n          // The use of marker._isInside is to overcome the issue that mouseover is endlessly triggered\n          // and we need it onley once\n          marker.on('mouseover', () => {\n            if (!marker._isInside) {\n              marker._isInside = true;\n              marker.setIcon(focusedIcon);\n            }\n          });\n          marker.on('mouseout', () => {\n            marker._isInside = false;\n            marker.setIcon(icon);\n          });\n        }\n\n        marker.on('click', () => {\n          handleMarkerClick(point);\n        });\n\n        pointsLayerRef.current?.addLayer(marker);\n      });\n    }\n\n    if (pointsLayerRef.current.getLayers().length) {\n      map.fitBounds(pointsLayerRef.current.getBounds());\n    } else {\n      map.setView([32.219157, 34.982481], 12);\n    }\n  };\n\n  const getMarker = (point: IPoint) => {\n    if (point.has_device === true) {\n      return L.marker([point.latitude, point.longitude], {\n        kando_object_id: point.id,\n      });\n    } else {\n      return L.circleMarker([point.latitude, point.longitude], {\n        radius: 4, // circle radius in pixels\n        color: '#000000', // border (stroke) color\n        weight: 1, // border (stroke) width\n        fillColor: '#ffffff', // fill color (white)\n        fillOpacity: 1, // fully opaque\n        kando_object_id: point.id,\n      });\n    }\n  };\n\n  const addEdges = () => {\n    // console.log('edges', edges);\n    if (!map || !edges) {\n      return;\n    }\n\n    if (edgesLayerRef.current) {\n      if (map.hasLayer(edgesLayerRef.current)) {\n        map.removeLayer(edgesLayerRef.current);\n      }\n    }\n\n    edgesLayerRef.current = L.featureGroup();\n    edgesLayerRef.current.addTo(map);\n\n    edges.forEach((edge) => {\n      const sourcePoint = points.find(\n        (point) => point.id === edge.source_point_id,\n      );\n      const targetPoint = points.find(\n        (point) => point.id === edge.target_point_id,\n      );\n      // console.log('sourcePoint', sourcePoint);\n      // console.log('targetPoint', targetPoint);\n\n      if (!sourcePoint || !targetPoint) {\n        return;\n      }\n\n      const latlngs = [\n        [sourcePoint?.latitude, sourcePoint?.longitude],\n        [targetPoint?.latitude, targetPoint?.longitude],\n      ];\n\n      const polyline = L.polyline(latlngs, {\n        color: 'black',\n        weight: 1,\n        opacity: 0.5,\n        smoothFactor: 1,\n      });\n\n      edgesLayerRef.current?.addLayer(polyline);\n    });\n  };\n\n  useEffect(() => {\n    addMarkers();\n    addEdges();\n  }, [points, map]);\n\n  return map;\n};\n"],"mappings":"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"}
|