@kando-env/kando-ui 1.2.395-alpha.6 → 1.2.395

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,201 +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, 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
- var pointLookup = new Map();
134
- points.forEach(function (p) {
135
- return pointLookup.set(p.id, p);
136
- });
137
- if (edgesLayerRef.current) {
138
- if (map.hasLayer(edgesLayerRef.current)) {
139
- map.removeLayer(edgesLayerRef.current);
140
- }
141
- }
142
- edgesLayerRef.current = _leaflet.default.featureGroup();
143
- edgesLayerRef.current.addTo(map);
144
- edges.forEach(function (edge) {
145
- var _edgesLayerRef$curren;
146
- var sourcePoint = pointLookup.get(edge.source_point_id);
147
- var targetPoint = pointLookup.get(edge.target_point_id);
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","pointLookup","Map","p","set","edge","_edgesLayerRef$curren","sourcePoint","get","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    const pointLookup = new Map();\n    points.forEach((p) => pointLookup.set(p.id, p));\n\n    if (edgesLayerRef.current) {\n      if (map.hasLayer(edgesLayerRef.current)) {\n        map.removeLayer(edgesLayerRef.current);\n      }\n    }\n\n    edgesLayerRef.current = L.featureGroup();\n    edgesLayerRef.current.addTo(map);\n\n    edges.forEach((edge) => {\n      const sourcePoint = pointLookup.get(edge.source_point_id);\n      const targetPoint = pointLookup.get(edge.target_point_id);\n      // 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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"}
@@ -1,154 +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.default = void 0;
9
- var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/slicedToArray"));
10
- require("./OperationsPage.scss");
11
- var _react = _interopRequireWildcard(require("react"));
12
- var _reactRedux = require("react-redux");
13
- var _reactBootstrap = require("react-bootstrap");
14
- var _actions = require("store/context/actions");
15
- var _actions2 = require("store/points/actions");
16
- var _actions3 = require("store/edges/actions");
17
- var _Map = require("./Map/Map");
18
- var _LeftPanel = _interopRequireDefault(require("./LeftPanel"));
19
- var _RightPanel = _interopRequireDefault(require("./RightPanel"));
20
- var _actions4 = require("store/areas/actions");
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
- 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
- var OperationsPage = function OperationsPage() {
24
- var dispatch = (0, _reactRedux.useDispatch)();
25
- var points_data = (0, _reactRedux.useSelector)(function (state) {
26
- return state.points_data;
27
- });
28
- var edges_data = (0, _reactRedux.useSelector)(function (state) {
29
- return state.edges_data;
30
- });
31
- var areas_data = (0, _reactRedux.useSelector)(function (state) {
32
- return state.areas_data;
33
- });
34
- var global_data = (0, _reactRedux.useSelector)(function (state) {
35
- return state.global_data;
36
- });
37
- var _useState = (0, _react.useState)(false),
38
- _useState2 = (0, _slicedToArray2.default)(_useState, 2),
39
- showRightPanel = _useState2[0],
40
- setShowRightPanel = _useState2[1];
41
- var _useState3 = (0, _react.useState)(null),
42
- _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
43
- selectedPoint = _useState4[0],
44
- setSelectedPoint = _useState4[1];
45
- var _useState5 = (0, _react.useState)(false),
46
- _useState6 = (0, _slicedToArray2.default)(_useState5, 2),
47
- isSmallScreen = _useState6[0],
48
- setIsSmallScreen = _useState6[1];
49
- var handleSelectPoint = function handleSelectPoint(newPoint) {
50
- if (selectedPoint && newPoint.id === selectedPoint.id) {
51
- setSelectedPoint(null);
52
- } else {
53
- setSelectedPoint(newPoint);
54
- }
55
- };
56
- (0, _react.useEffect)(function () {
57
- dispatch((0, _actions.updateNavContext)({
58
- name: 'operations'
59
- }));
60
- var checkScreenSize = function checkScreenSize() {
61
- setIsSmallScreen(window.innerWidth < 768); // or any breakpoint
62
- };
63
-
64
- // Run on mount:
65
- checkScreenSize();
66
-
67
- // Also update if the user resizes the browser:
68
- window.addEventListener('resize', checkScreenSize);
69
- return function () {
70
- window.removeEventListener('resize', checkScreenSize);
71
- };
72
- }, []);
73
- (0, _react.useEffect)(function () {
74
- if (global_data.waterAuthorityId) {
75
- dispatch((0, _actions2.fetchPoints)(global_data.waterAuthorityId));
76
- dispatch((0, _actions3.fetchEdges)(global_data.waterAuthorityId));
77
- dispatch((0, _actions4.fetchAreas)(global_data.waterAuthorityId));
78
- }
79
- }, [global_data.waterAuthorityId]);
80
- var monitoredPoints = (0, _react.useMemo)(function () {
81
- var _points_data$items;
82
- return ((_points_data$items = points_data.items) === null || _points_data$items === void 0 ? void 0 : _points_data$items.filter(function (point) {
83
- return point.has_device;
84
- })) || [];
85
- }, [points_data.items]);
86
- var points = (0, _react.useMemo)(function () {
87
- var _points_data$items2;
88
- return ((_points_data$items2 = points_data.items) === null || _points_data$items2 === void 0 ? void 0 : _points_data$items2.filter(function (point) {
89
- return point.latitude && point.longitude;
90
- })) || [];
91
- }, [points_data.items]);
92
- var showLeftPanel = (0, _react.useMemo)(function () {
93
- return /*#__PURE__*/_react.default.createElement(_LeftPanel.default, {
94
- points: monitoredPoints,
95
- selectedPoint: selectedPoint,
96
- setSelectedPoint: setSelectedPoint
97
- });
98
- }, [monitoredPoints, selectedPoint]);
99
- (0, _react.useEffect)(function () {
100
- if (selectedPoint) {
101
- setShowRightPanel(true);
102
- } else {
103
- setShowRightPanel(false);
104
- }
105
- }, [selectedPoint]);
106
- var onRightPanelClose = function onRightPanelClose() {
107
- setSelectedPoint(null);
108
- };
109
- var getDistance = function getDistance() {
110
- if (selectedPoint && edges_data.items) {
111
- var edge = edges_data.items.find(function (edge) {
112
- return edge.source_point_id === selectedPoint.id;
113
- });
114
- return (edge === null || edge === void 0 ? void 0 : edge.distance) || 0;
115
- }
116
- return 0;
117
- };
118
- if (isSmallScreen) {
119
- // Show a message or a specialized layout
120
- return /*#__PURE__*/_react.default.createElement(_reactBootstrap.Container, null, /*#__PURE__*/_react.default.createElement("div", {
121
- style: {
122
- marginTop: '6rem',
123
- textAlign: 'center',
124
- border: '1px solid #ccc',
125
- padding: '1rem',
126
- borderRadius: '10px'
127
- }
128
- }, /*#__PURE__*/_react.default.createElement("h5", null, 'This page is not supported on small screens'), /*#__PURE__*/_react.default.createElement("p", null, 'Please use a larger screen for the best experience.')));
129
- }
130
- return /*#__PURE__*/_react.default.createElement(_reactBootstrap.Container, {
131
- fluid: true,
132
- className: "vh-90 p-0"
133
- }, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Row, null, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Col, {
134
- sm: 3,
135
- className: "left-panel"
136
- }, showLeftPanel), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Col, {
137
- className: "map-column",
138
- sm: 9
139
- }, !edges_data.isFetching && !areas_data.isFetching && /*#__PURE__*/_react.default.createElement(_Map.Map, {
140
- points: points,
141
- edges: edges_data.items,
142
- areas: areas_data.newAreas,
143
- selectedPoint: selectedPoint,
144
- updateSelectedPoint: handleSelectPoint
145
- }), /*#__PURE__*/_react.default.createElement(_RightPanel.default, {
146
- className: "right-panel ".concat(showRightPanel ? 'open' : ''),
147
- point: selectedPoint,
148
- distance: getDistance(),
149
- onClose: onRightPanelClose
150
- }))));
151
- };
152
- var _default = OperationsPage;
153
- exports.default = _default;
154
- //# 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","_useState5","_useState6","isSmallScreen","setIsSmallScreen","handleSelectPoint","newPoint","id","useEffect","updateNavContext","name","checkScreenSize","window","innerWidth","addEventListener","removeEventListener","waterAuthorityId","fetchPoints","fetchEdges","fetchAreas","monitoredPoints","useMemo","_points_data$items","items","filter","point","has_device","points","_points_data$items2","latitude","longitude","showLeftPanel","createElement","onRightPanelClose","getDistance","edge","find","source_point_id","distance","Container","style","marginTop","textAlign","border","padding","borderRadius","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  const [isSmallScreen, setIsSmallScreen] = useState(false);\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    const checkScreenSize = () => {\n      setIsSmallScreen(window.innerWidth < 768); // or any breakpoint\n    };\n\n    // Run on mount:\n    checkScreenSize();\n\n    // Also update if the user resizes the browser:\n    window.addEventListener('resize', checkScreenSize);\n    return () => {\n      window.removeEventListener('resize', checkScreenSize);\n    };\n  }, []);\n\n  useEffect(() => {\n    if (global_data.waterAuthorityId) {\n      dispatch(fetchPoints(global_data.waterAuthorityId));\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        selectedPoint={selectedPoint}\n        setSelectedPoint={setSelectedPoint}\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  const getDistance = () => {\n    if (selectedPoint && edges_data.items) {\n      const edge = edges_data.items.find(\n        (edge) => edge.source_point_id === selectedPoint.id,\n      );\n      return edge?.distance || 0;\n    }\n    return 0;\n  };\n\n  if (isSmallScreen) {\n    // Show a message or a specialized layout\n    return (\n      <Container>\n        <div\n          style={{\n            marginTop: '6rem',\n            textAlign: 'center',\n            border: '1px solid #ccc',\n            padding: '1rem',\n            borderRadius: '10px',\n          }}\n        >\n          <h5>{'This page is not supported on small screens'}</h5>\n          <p>{'Please use a larger screen for the best experience.'}</p>\n        </div>\n      </Container>\n    );\n  }\n\n  return (\n    <Container fluid className=\"vh-90 p-0\">\n      <Row>\n        <Col sm={3} className=\"left-panel\">\n          {showLeftPanel}\n        </Col>\n        <Col className=\"map-column\" sm={9}>\n          {!edges_data.isFetching && !areas_data.isFetching && (\n            <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            distance={getDistance()}\n            onClose={onRightPanelClose}\n          />\n        </Col>\n      </Row>\n    </Container>\n  );\n};\n\nexport default OperationsPage;\n"],"mappings":"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"}
@@ -1,64 +0,0 @@
1
- .map-column {
2
- position: relative;
3
- .kd-map-container {
4
- position: relative;
5
- height: calc(100vh - 68px);
6
- width: 100wh;
7
-
8
- #map {
9
- height: 100%;
10
- width: 100%;
11
-
12
- *,
13
- *:focus,
14
- *:hover {
15
- outline: none;
16
- }
17
- }
18
- }
19
-
20
- .right-panel {
21
- position: absolute;
22
- top: 0;
23
- right: 0;
24
- width: 350px;
25
- height: 100%;
26
- background-color: #fff;
27
- box-shadow: -2px 0 8px rgba(0, 0, 0, 0.2);
28
- transition: transform 0.3s ease-in-out;
29
- transform: translateX(100%);
30
- z-index: 1000;
31
- display: flex;
32
- flex-direction: column; /* to have header, body, footer stacked */
33
- }
34
-
35
- .right-panel.open {
36
- transform: translateX(0);
37
- }
38
- }
39
-
40
- .left-panel {
41
- height: calc(100vh - 68px);
42
- overflow-y: auto;
43
- overflow-x: hidden;
44
- background-color: #f5f5f5;
45
-
46
- .list-item {
47
- padding: 10px;
48
- border-bottom: 1px solid #e0e0e0;
49
- cursor: pointer;
50
- transition: background-color 0.3s;
51
-
52
- &:hover {
53
- background-color: #e0e0e0;
54
- }
55
-
56
- &.list-item-selected {
57
- background-color: #e0e0e0;
58
- }
59
- }
60
- }
61
-
62
- .area-tooltip {
63
- font-weight: 600;
64
- }
@@ -1,29 +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.default = void 0;
8
- var _react = _interopRequireDefault(require("react"));
9
- var RightPanel = function RightPanel(_ref) {
10
- var point = _ref.point,
11
- distance = _ref.distance,
12
- className = _ref.className,
13
- onClose = _ref.onClose;
14
- return /*#__PURE__*/_react.default.createElement("div", {
15
- className: className
16
- }, /*#__PURE__*/_react.default.createElement("div", {
17
- className: "drawer-header d-flex align-items-center justify-content-between p-3 pr-4"
18
- }, 'Point Details', /*#__PURE__*/_react.default.createElement("button", {
19
- className: "close",
20
- onClick: onClose
21
- }, /*#__PURE__*/_react.default.createElement("span", null, "\xD7"))), /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("div", {
22
- className: "drawer-body p-3"
23
- }, /*#__PURE__*/_react.default.createElement("div", {
24
- className: "form-group"
25
- }, /*#__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, 'Was Monitored:'), ' ', (point === null || point === void 0 ? void 0 : point.device_status) !== 'regular' ? 'Yes' : 'No'), /*#__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.split('::')[1]), /*#__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), /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement("strong", null, 'Distance:'), " ", distance)))));
26
- };
27
- var _default = RightPanel;
28
- exports.default = _default;
29
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIlJpZ2h0UGFuZWwiLCJfcmVmIiwicG9pbnQiLCJkaXN0YW5jZSIsImNsYXNzTmFtZSIsIm9uQ2xvc2UiLCJkZWZhdWx0IiwiY3JlYXRlRWxlbWVudCIsIm9uQ2xpY2siLCJuYW1lIiwiZGVzY3JpcHRpb24iLCJoYXNfZGV2aWNlIiwiZGV2aWNlX3N0YXR1cyIsImdyb3VwIiwic2VjdG9yX25hbWUiLCJ0eXBlIiwic3BsaXQiLCJ3YXRlcl9kaXNjaGFyZ2UiLCJfZGVmYXVsdCIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcGFnZXMvT3BlcmF0aW9uc1BhZ2UvUmlnaHRQYW5lbC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IElQb2ludCB9IGZyb20gJ3NyYy9zdG9yZS9wb2ludHMvbW9kZWxzL0lQb2ludCc7XG5cbnR5cGUgUmlnaHRQYW5lbFByb3BzID0ge1xuICBwb2ludDogSVBvaW50IHwgbnVsbDtcbiAgZGlzdGFuY2U6IG51bWJlcjtcbiAgY2xhc3NOYW1lPzogc3RyaW5nO1xuICBvbkNsb3NlPzogKCkgPT4gdm9pZDtcbn07XG5cbmNvbnN0IFJpZ2h0UGFuZWw6IFJlYWN0LkZDPFJpZ2h0UGFuZWxQcm9wcz4gPSAoe1xuICBwb2ludCxcbiAgZGlzdGFuY2UsXG4gIGNsYXNzTmFtZSxcbiAgb25DbG9zZSxcbn0pID0+IHtcbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNsYXNzTmFtZT17Y2xhc3NOYW1lfT5cbiAgICAgIDxkaXYgY2xhc3NOYW1lPVwiZHJhd2VyLWhlYWRlciBkLWZsZXggYWxpZ24taXRlbXMtY2VudGVyIGp1c3RpZnktY29udGVudC1iZXR3ZWVuIHAtMyBwci00XCI+XG4gICAgICAgIHsnUG9pbnQgRGV0YWlscyd9XG4gICAgICAgIDxidXR0b24gY2xhc3NOYW1lPVwiY2xvc2VcIiBvbkNsaWNrPXtvbkNsb3NlfT5cbiAgICAgICAgICA8c3Bhbj4mdGltZXM7PC9zcGFuPlxuICAgICAgICA8L2J1dHRvbj5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdj5cbiAgICAgICAgPGRpdiBjbGFzc05hbWU9XCJkcmF3ZXItYm9keSBwLTNcIj5cbiAgICAgICAgICA8ZGl2IGNsYXNzTmFtZT1cImZvcm0tZ3JvdXBcIj5cbiAgICAgICAgICAgIDxwPlxuICAgICAgICAgICAgICA8c3Ryb25nPnsnTmFtZTonfTwvc3Ryb25nPiB7cG9pbnQ/Lm5hbWV9XG4gICAgICAgICAgICA8L3A+XG4gICAgICAgICAgICA8cD5cbiAgICAgICAgICAgICAgPHN0cm9uZz57J0Rlc2NyaXB0aW9uOid9PC9zdHJvbmc+IHtwb2ludD8uZGVzY3JpcHRpb259XG4gICAgICAgICAgICA8L3A+XG4gICAgICAgICAgICA8cD5cbiAgICAgICAgICAgICAgPHN0cm9uZz57J01vbml0b3JlZDonfTwvc3Ryb25nPiB7cG9pbnQ/Lmhhc19kZXZpY2UgPyAnWWVzJyA6ICdObyd9XG4gICAgICAgICAgICA8L3A+XG4gICAgICAgICAgICA8cD5cbiAgICAgICAgICAgICAgPHN0cm9uZz57J1dhcyBNb25pdG9yZWQ6J308L3N0cm9uZz57JyAnfVxuICAgICAgICAgICAgICB7cG9pbnQ/LmRldmljZV9zdGF0dXMgIT09ICdyZWd1bGFyJyA/ICdZZXMnIDogJ05vJ31cbiAgICAgICAgICAgIDwvcD5cbiAgICAgICAgICAgIDxwPlxuICAgICAgICAgICAgICA8c3Ryb25nPnsnU2VjdG9yOid9PC9zdHJvbmc+IHtwb2ludD8uZ3JvdXAuc2VjdG9yX25hbWV9XG4gICAgICAgICAgICA8L3A+XG4gICAgICAgICAgICA8cD5cbiAgICAgICAgICAgICAgPHN0cm9uZz57J1R5cGU6J308L3N0cm9uZz4ge3BvaW50Py5ncm91cC50eXBlLnNwbGl0KCc6OicpWzFdfVxuICAgICAgICAgICAgPC9wPlxuICAgICAgICAgICAgPHA+XG4gICAgICAgICAgICAgIDxzdHJvbmc+eydXYXRlciBEaXNjaGFyZ2U6J308L3N0cm9uZz57JyAnfVxuICAgICAgICAgICAgICB7cG9pbnQ/Lmdyb3VwLndhdGVyX2Rpc2NoYXJnZX1cbiAgICAgICAgICAgIDwvcD5cbiAgICAgICAgICAgIDxwPlxuICAgICAgICAgICAgICA8c3Ryb25nPnsnRGlzdGFuY2U6J308L3N0cm9uZz4ge2Rpc3RhbmNlfVxuICAgICAgICAgICAgPC9wPlxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgUmlnaHRQYW5lbDtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBLElBQUFBLE1BQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQVVBLElBQU1DLFVBQXFDLEdBQUcsU0FBeENBLFVBQXFDQSxDQUFBQyxJQUFBLEVBS3JDO0VBQUEsSUFKSkMsS0FBSyxHQUFBRCxJQUFBLENBQUxDLEtBQUs7SUFDTEMsUUFBUSxHQUFBRixJQUFBLENBQVJFLFFBQVE7SUFDUkMsU0FBUyxHQUFBSCxJQUFBLENBQVRHLFNBQVM7SUFDVEMsT0FBTyxHQUFBSixJQUFBLENBQVBJLE9BQU87RUFFUCxvQkFDRVIsTUFBQSxDQUFBUyxPQUFBLENBQUFDLGFBQUE7SUFBS0gsU0FBUyxFQUFFQTtFQUFVLGdCQUN4QlAsTUFBQSxDQUFBUyxPQUFBLENBQUFDLGFBQUE7SUFBS0gsU0FBUyxFQUFDO0VBQTBFLEdBQ3RGLGVBQWUsZUFDaEJQLE1BQUEsQ0FBQVMsT0FBQSxDQUFBQyxhQUFBO0lBQVFILFNBQVMsRUFBQyxPQUFPO0lBQUNJLE9BQU8sRUFBRUg7RUFBUSxnQkFDekNSLE1BQUEsQ0FBQVMsT0FBQSxDQUFBQyxhQUFBLGVBQU0sTUFBYSxDQUNiLENBQ0wsQ0FBQyxlQUNOVixNQUFBLENBQUFTLE9BQUEsQ0FBQUMsYUFBQSwyQkFDRVYsTUFBQSxDQUFBUyxPQUFBLENBQUFDLGFBQUE7SUFBS0gsU0FBUyxFQUFDO0VBQWlCLGdCQUM5QlAsTUFBQSxDQUFBUyxPQUFBLENBQUFDLGFBQUE7SUFBS0gsU0FBUyxFQUFDO0VBQVksZ0JBQ3pCUCxNQUFBLENBQUFTLE9BQUEsQ0FBQUMsYUFBQSx5QkFDRVYsTUFBQSxDQUFBUyxPQUFBLENBQUFDLGFBQUEsaUJBQVMsT0FBZ0IsQ0FBQyxLQUFDLEVBQUNMLEtBQUssYUFBTEEsS0FBSyx1QkFBTEEsS0FBSyxDQUFFTyxJQUNsQyxDQUFDLGVBQ0paLE1BQUEsQ0FBQVMsT0FBQSxDQUFBQyxhQUFBLHlCQUNFVixNQUFBLENBQUFTLE9BQUEsQ0FBQUMsYUFBQSxpQkFBUyxjQUF1QixDQUFDLEtBQUMsRUFBQ0wsS0FBSyxhQUFMQSxLQUFLLHVCQUFMQSxLQUFLLENBQUVRLFdBQ3pDLENBQUMsZUFDSmIsTUFBQSxDQUFBUyxPQUFBLENBQUFDLGFBQUEseUJBQ0VWLE1BQUEsQ0FBQVMsT0FBQSxDQUFBQyxhQUFBLGlCQUFTLFlBQXFCLENBQUMsS0FBQyxFQUFDLENBQUFMLEtBQUssYUFBTEEsS0FBSyx1QkFBTEEsS0FBSyxDQUFFUyxVQUFVLElBQUcsS0FBSyxHQUFHLElBQzVELENBQUMsZUFDSmQsTUFBQSxDQUFBUyxPQUFBLENBQUFDLGFBQUEseUJBQ0VWLE1BQUEsQ0FBQVMsT0FBQSxDQUFBQyxhQUFBLGlCQUFTLGdCQUF5QixDQUFDLEVBQUMsR0FBRyxFQUN0QyxDQUFBTCxLQUFLLGFBQUxBLEtBQUssdUJBQUxBLEtBQUssQ0FBRVUsYUFBYSxNQUFLLFNBQVMsR0FBRyxLQUFLLEdBQUcsSUFDN0MsQ0FBQyxlQUNKZixNQUFBLENBQUFTLE9BQUEsQ0FBQUMsYUFBQSx5QkFDRVYsTUFBQSxDQUFBUyxPQUFBLENBQUFDLGFBQUEsaUJBQVMsU0FBa0IsQ0FBQyxLQUFDLEVBQUNMLEtBQUssYUFBTEEsS0FBSyx1QkFBTEEsS0FBSyxDQUFFVyxLQUFLLENBQUNDLFdBQzFDLENBQUMsZUFDSmpCLE1BQUEsQ0FBQVMsT0FBQSxDQUFBQyxhQUFBLHlCQUNFVixNQUFBLENBQUFTLE9BQUEsQ0FBQUMsYUFBQSxpQkFBUyxPQUFnQixDQUFDLEtBQUMsRUFBQ0wsS0FBSyxhQUFMQSxLQUFLLHVCQUFMQSxLQUFLLENBQUVXLEtBQUssQ0FBQ0UsSUFBSSxDQUFDQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUMxRCxDQUFDLGVBQ0puQixNQUFBLENBQUFTLE9BQUEsQ0FBQUMsYUFBQSx5QkFDRVYsTUFBQSxDQUFBUyxPQUFBLENBQUFDLGFBQUEsaUJBQVMsa0JBQTJCLENBQUMsRUFBQyxHQUFHLEVBQ3hDTCxLQUFLLGFBQUxBLEtBQUssdUJBQUxBLEtBQUssQ0FBRVcsS0FBSyxDQUFDSSxlQUNiLENBQUMsZUFDSnBCLE1BQUEsQ0FBQVMsT0FBQSxDQUFBQyxhQUFBLHlCQUNFVixNQUFBLENBQUFTLE9BQUEsQ0FBQUMsYUFBQSxpQkFBUyxXQUFvQixDQUFDLEtBQUMsRUFBQ0osUUFDL0IsQ0FDQSxDQUNGLENBQ0YsQ0FDRixDQUFDO0FBRVYsQ0FBQztBQUFDLElBQUFlLFFBQUEsR0FFYWxCLFVBQVU7QUFBQW1CLE9BQUEsQ0FBQWIsT0FBQSxHQUFBWSxRQUFBIn0=
@@ -1,11 +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.default = void 0;
8
- var _OperationsPage = _interopRequireDefault(require("./OperationsPage"));
9
- var _default = _OperationsPage.default;
10
- exports.default = _default;
11
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfT3BlcmF0aW9uc1BhZ2UiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9kZWZhdWx0IiwiT3BlcmF0aW9uc1BhZ2UiLCJleHBvcnRzIiwiZGVmYXVsdCJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9wYWdlcy9PcGVyYXRpb25zUGFnZS9pbmRleC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgT3BlcmF0aW9uc1BhZ2UgZnJvbSAnLi9PcGVyYXRpb25zUGFnZSc7XG5leHBvcnQgZGVmYXVsdCBPcGVyYXRpb25zUGFnZTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBLElBQUFBLGVBQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUE4QyxJQUFBQyxRQUFBLEdBQy9CQyx1QkFBYztBQUFBQyxPQUFBLENBQUFDLE9BQUEsR0FBQUgsUUFBQSJ9
@@ -1,29 +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.KandoAlert = void 0;
8
- var _react = _interopRequireDefault(require("react"));
9
- var _Alert = _interopRequireDefault(require("react-bootstrap/Alert"));
10
- // The background color changes based on the selected variant
11
-
12
- var KandoAlert = function KandoAlert(_ref) {
13
- var variant = _ref.variant,
14
- header = _ref.header,
15
- children = _ref.children;
16
- return /*#__PURE__*/_react.default.createElement(_Alert.default, {
17
- variant: variant,
18
- style: {
19
- border: '1px solid #ccc',
20
- borderRadius: '1rem',
21
- padding: '1rem 1.5rem',
22
- maxWidth: '600px',
23
- width: '90%',
24
- margin: '4rem auto 0 auto'
25
- }
26
- }, /*#__PURE__*/_react.default.createElement(_Alert.default.Heading, null, header), /*#__PURE__*/_react.default.createElement("p", null, children));
27
- };
28
- exports.KandoAlert = KandoAlert;
29
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9BbGVydCIsIkthbmRvQWxlcnQiLCJfcmVmIiwidmFyaWFudCIsImhlYWRlciIsImNoaWxkcmVuIiwiZGVmYXVsdCIsImNyZWF0ZUVsZW1lbnQiLCJzdHlsZSIsImJvcmRlciIsImJvcmRlclJhZGl1cyIsInBhZGRpbmciLCJtYXhXaWR0aCIsIndpZHRoIiwibWFyZ2luIiwiSGVhZGluZyIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdWkta2l0L0FsZXJ0L0thbmRvQWxlcnQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgQWxlcnQgZnJvbSAncmVhY3QtYm9vdHN0cmFwL0FsZXJ0JztcblxuLy8gVGhlIGJhY2tncm91bmQgY29sb3IgY2hhbmdlcyBiYXNlZCBvbiB0aGUgc2VsZWN0ZWQgdmFyaWFudFxudHlwZSBCb290c3RyYXBBbGVydFZhcmlhbnQgPVxuICB8ICdwcmltYXJ5J1xuICB8ICdzZWNvbmRhcnknXG4gIHwgJ3N1Y2Nlc3MnXG4gIHwgJ2RhbmdlcidcbiAgfCAnd2FybmluZydcbiAgfCAnaW5mbydcbiAgfCAnbGlnaHQnXG4gIHwgJ2RhcmsnO1xuXG5pbnRlcmZhY2UgQWxlcnRQcm9wcyB7XG4gIHZhcmlhbnQ6IEJvb3RzdHJhcEFsZXJ0VmFyaWFudDtcbiAgaGVhZGVyOiBzdHJpbmc7XG4gIGNoaWxkcmVuOiBSZWFjdC5SZWFjdE5vZGU7XG59XG5cbmV4cG9ydCBjb25zdCBLYW5kb0FsZXJ0OiBSZWFjdC5GQzxBbGVydFByb3BzPiA9ICh7XG4gIHZhcmlhbnQsXG4gIGhlYWRlcixcbiAgY2hpbGRyZW4sXG59KSA9PiB7XG4gIHJldHVybiAoXG4gICAgPEFsZXJ0XG4gICAgICB2YXJpYW50PXt2YXJpYW50fVxuICAgICAgc3R5bGU9e3tcbiAgICAgICAgYm9yZGVyOiAnMXB4IHNvbGlkICNjY2MnLFxuICAgICAgICBib3JkZXJSYWRpdXM6ICcxcmVtJyxcbiAgICAgICAgcGFkZGluZzogJzFyZW0gMS41cmVtJyxcbiAgICAgICAgbWF4V2lkdGg6ICc2MDBweCcsXG4gICAgICAgIHdpZHRoOiAnOTAlJyxcbiAgICAgICAgbWFyZ2luOiAnNHJlbSBhdXRvIDAgYXV0bycsXG4gICAgICB9fVxuICAgID5cbiAgICAgIDxBbGVydC5IZWFkaW5nPntoZWFkZXJ9PC9BbGVydC5IZWFkaW5nPlxuICAgICAgPHA+e2NoaWxkcmVufTwvcD5cbiAgICA8L0FsZXJ0PlxuICApO1xufTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBLElBQUFBLE1BQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUNBLElBQUFDLE1BQUEsR0FBQUYsc0JBQUEsQ0FBQUMsT0FBQTtBQUVBOztBQWlCTyxJQUFNRSxVQUFnQyxHQUFHLFNBQW5DQSxVQUFnQ0EsQ0FBQUMsSUFBQSxFQUl2QztFQUFBLElBSEpDLE9BQU8sR0FBQUQsSUFBQSxDQUFQQyxPQUFPO0lBQ1BDLE1BQU0sR0FBQUYsSUFBQSxDQUFORSxNQUFNO0lBQ05DLFFBQVEsR0FBQUgsSUFBQSxDQUFSRyxRQUFRO0VBRVIsb0JBQ0VSLE1BQUEsQ0FBQVMsT0FBQSxDQUFBQyxhQUFBLENBQUNQLE1BQUEsQ0FBQU0sT0FBSztJQUNKSCxPQUFPLEVBQUVBLE9BQVE7SUFDakJLLEtBQUssRUFBRTtNQUNMQyxNQUFNLEVBQUUsZ0JBQWdCO01BQ3hCQyxZQUFZLEVBQUUsTUFBTTtNQUNwQkMsT0FBTyxFQUFFLGFBQWE7TUFDdEJDLFFBQVEsRUFBRSxPQUFPO01BQ2pCQyxLQUFLLEVBQUUsS0FBSztNQUNaQyxNQUFNLEVBQUU7SUFDVjtFQUFFLGdCQUVGakIsTUFBQSxDQUFBUyxPQUFBLENBQUFDLGFBQUEsQ0FBQ1AsTUFBQSxDQUFBTSxPQUFLLENBQUNTLE9BQU8sUUFBRVgsTUFBc0IsQ0FBQyxlQUN2Q1AsTUFBQSxDQUFBUyxPQUFBLENBQUFDLGFBQUEsWUFBSUYsUUFBWSxDQUNYLENBQUM7QUFFWixDQUFDO0FBQUNXLE9BQUEsQ0FBQWYsVUFBQSxHQUFBQSxVQUFBIn0=