@kando-env/kando-ui 1.2.398-alpha.18 → 1.2.398-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.
@@ -19,7 +19,6 @@ var _Map = require("./Map/Map");
19
19
  var _LeftPanel = _interopRequireDefault(require("./LeftPanel"));
20
20
  var _RightPanel = _interopRequireDefault(require("./RightPanel"));
21
21
  var _KandoAlert = require("ui-kit/Alert/KandoAlert");
22
- var _Loader = require("../DashboardMap/Loader");
23
22
  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); }
24
23
  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; }
25
24
  var OperationsPage = function OperationsPage() {
@@ -80,7 +79,6 @@ var OperationsPage = function OperationsPage() {
80
79
  }
81
80
  return function () {
82
81
  setSelectedPoint(null);
83
- dispatch((0, _actions2.clearPoints)());
84
82
  };
85
83
  }, [global_data.waterAuthorityId]);
86
84
  var points = (0, _react.useMemo)(function () {
@@ -111,6 +109,17 @@ var OperationsPage = function OperationsPage() {
111
109
  var onRightPanelClose = function onRightPanelClose() {
112
110
  setSelectedPoint(null);
113
111
  };
112
+
113
+ // TBD - move that to the server
114
+ var getDistance = function getDistance() {
115
+ if (selectedPoint && edges_data.items) {
116
+ var edge = edges_data.items.find(function (edge) {
117
+ return edge.source_point_id === selectedPoint.id;
118
+ });
119
+ return (edge === null || edge === void 0 ? void 0 : edge.distance) || 0;
120
+ }
121
+ return 0;
122
+ };
114
123
  if (isSmallScreen) {
115
124
  return /*#__PURE__*/_react.default.createElement(_KandoAlert.KandoAlert, {
116
125
  variant: "success",
@@ -126,7 +135,7 @@ var OperationsPage = function OperationsPage() {
126
135
  }, showLeftPanel), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Col, {
127
136
  className: "map-column",
128
137
  sm: 9
129
- }, edges_data.isFetching || areas_data.isFetching ? /*#__PURE__*/_react.default.createElement(_Loader.Loader, null) : /*#__PURE__*/_react.default.createElement(_Map.Map, {
138
+ }, !edges_data.isFetching && !areas_data.isFetching && /*#__PURE__*/_react.default.createElement(_Map.Map, {
130
139
  points: points,
131
140
  edges: edges_data.items,
132
141
  areas: areas_data.newAreas,
@@ -135,9 +144,10 @@ var OperationsPage = function OperationsPage() {
135
144
  }), /*#__PURE__*/_react.default.createElement(_RightPanel.default, {
136
145
  className: "right-panel ".concat(showRightPanel ? 'open' : ''),
137
146
  point: selectedPoint,
147
+ distance: getDistance(),
138
148
  onClose: onRightPanelClose
139
149
  }))));
140
150
  };
141
151
  var _default = OperationsPage;
142
152
  exports.default = _default;
143
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["require","_react","_interopRequireWildcard","_reactRedux","_reactBootstrap","_actions","_actions2","_actions3","_actions4","_Map","_LeftPanel","_interopRequireDefault","_RightPanel","_KandoAlert","_Loader","_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","clearPoints","points","useMemo","_points_data$items","items","filter","point","latitude","longitude","monitoredPoints","has_device","showLeftPanel","createElement","onRightPanelClose","KandoAlert","variant","header","Container","fluid","className","Row","Col","sm","isFetching","Loader","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 { clearPoints, fetchPoints } from 'src/store/points/actions';\nimport { fetchEdges } from 'src/store/edges/actions';\nimport { fetchAreas } from 'src/store/areas/actions';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport { Map } from './Map/Map';\nimport LeftPanel from './LeftPanel';\nimport RightPanel from './RightPanel';\nimport { KandoAlert } from 'src/ui-kit/Alert/KandoAlert';\nimport { Loader } from '../DashboardMap/Loader';\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 (newPoint === null || 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, '', true));\n      dispatch(fetchEdges(global_data.waterAuthorityId));\n      dispatch(fetchAreas(global_data.waterAuthorityId));\n    }\n\n    return () => {\n      setSelectedPoint(null);\n      dispatch(clearPoints());\n    };\n  }, [global_data.waterAuthorityId]);\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 monitoredPoints = useMemo(() => {\n    return points.filter((point: IPoint) => point.has_device) || [];\n  }, [points]);\n\n  const showLeftPanel = useMemo(() => {\n    return (\n      <LeftPanel\n        points={monitoredPoints}\n        selectedPoint={selectedPoint}\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  if (isSmallScreen) {\n    return (\n      <KandoAlert variant=\"success\" header=\"Notice\">\n        <h5>{'This page is not supported on small screens'}</h5>\n        <p>{'Please use a larger screen for the best experience.'}</p>\n      </KandoAlert>\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            <Loader />\n          ) : (\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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"}
153
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["require","_react","_interopRequireWildcard","_reactRedux","_reactBootstrap","_actions","_actions2","_actions3","_actions4","_Map","_LeftPanel","_interopRequireDefault","_RightPanel","_KandoAlert","_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","points","useMemo","_points_data$items","items","filter","point","latitude","longitude","monitoredPoints","has_device","showLeftPanel","createElement","onRightPanelClose","getDistance","edge","find","source_point_id","distance","KandoAlert","variant","header","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 { fetchAreas } from 'src/store/areas/actions';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport { Map } from './Map/Map';\nimport LeftPanel from './LeftPanel';\nimport RightPanel from './RightPanel';\nimport { KandoAlert } from 'src/ui-kit/Alert/KandoAlert';\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 (newPoint === null || 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, '', true));\n      dispatch(fetchEdges(global_data.waterAuthorityId));\n      dispatch(fetchAreas(global_data.waterAuthorityId));\n    }\n\n    return () => {\n      setSelectedPoint(null);\n    };\n  }, [global_data.waterAuthorityId]);\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 monitoredPoints = useMemo(() => {\n    return points.filter((point: IPoint) => point.has_device) || [];\n  }, [points]);\n\n  const showLeftPanel = useMemo(() => {\n    return (\n      <LeftPanel\n        points={monitoredPoints}\n        selectedPoint={selectedPoint}\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  // TBD - move that to the server\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    return (\n      <KandoAlert variant=\"success\" header=\"Notice\">\n        <h5>{'This page is not supported on small screens'}</h5>\n        <p>{'Please use a larger screen for the best experience.'}</p>\n      </KandoAlert>\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,8 +1,3 @@
1
- html,
2
- body {
3
- overflow-x: hidden;
4
- }
5
-
6
1
  .map-column {
7
2
  .map-container {
8
3
  *,
@@ -10,10 +5,6 @@ body {
10
5
  *:hover {
11
6
  outline: none;
12
7
  }
13
-
14
- .area-tooltip {
15
- font-weight: 600;
16
- }
17
8
  }
18
9
 
19
10
  .right-panel {
@@ -28,70 +19,12 @@ body {
28
19
  transform: translateX(100%);
29
20
  z-index: 1000;
30
21
  display: flex;
31
- flex-direction: column;
22
+ flex-direction: column; /* to have header, body, footer stacked */
32
23
  }
33
24
 
34
25
  .right-panel.open {
35
26
  transform: translateX(0);
36
27
  }
37
-
38
- .list-group-item {
39
- border: none;
40
- }
41
-
42
- .list-item {
43
- display: flex;
44
- justify-content: space-between;
45
- align-items: baseline;
46
- width: 100%;
47
- border: none;
48
- flex-wrap: wrap;
49
-
50
- .list-item-label {
51
- // flex: 1;
52
- text-align: left;
53
- }
54
-
55
- .list-item-value {
56
- flex: 1;
57
- text-align: right;
58
- word-break: break-word;
59
- font-weight: 600;
60
- }
61
- }
62
-
63
- .card-header {
64
- font-size: 24px;
65
- color: #e31b62;
66
- font-weight: 600;
67
- background-color: white;
68
- }
69
-
70
- .issues-list {
71
- display: inline-flex;
72
- align-items: center;
73
- gap: 10px;
74
- flex-wrap: wrap;
75
- justify-content: flex-start;
76
- }
77
-
78
- .issue-card {
79
- width: fit-content;
80
- background-color: #e0e0e0;
81
- cursor: default;
82
- display: inline-block;
83
- margin-bottom: 8px;
84
-
85
- .info-tooltip .tooltip-content {
86
- margin-inline-start: calc(100% - 260px);
87
- }
88
- .info-tooltip::after {
89
- margin-inline-start: calc(20% + 1px);
90
- }
91
- .info-tooltip:hover {
92
- cursor: default;
93
- }
94
- }
95
28
  }
96
29
 
97
30
  .left-panel {
@@ -100,11 +33,6 @@ body {
100
33
  overflow-x: hidden;
101
34
  background-color: #f5f5f5;
102
35
 
103
- .scrollable-list {
104
- overflow-y: auto;
105
- max-height: calc(100vh - 200px);
106
- }
107
-
108
36
  .list-item {
109
37
  padding: 0.75rem;
110
38
  border-bottom: 1px solid #e0e0e0;
@@ -141,3 +69,7 @@ body {
141
69
  }
142
70
  }
143
71
  }
72
+
73
+ .area-tooltip {
74
+ font-weight: 600;
75
+ }
@@ -8,15 +8,19 @@ exports.default = void 0;
8
8
  var _react = _interopRequireDefault(require("react"));
9
9
  var _Card = _interopRequireDefault(require("react-bootstrap/Card"));
10
10
  var _ListGroup = _interopRequireDefault(require("react-bootstrap/ListGroup"));
11
- require("./OperationsPage.scss");
12
- var _reactI18next = require("react-i18next");
13
- var _InfoTooltip = require("ui-kit/InfoTooltip/InfoTooltip");
14
- var _i_Icon = _interopRequireDefault(require("assets/icons/informationTooltip/i_Icon.svg"));
15
- var _i18n = _interopRequireDefault(require("utilities/i18n"));
16
11
  var RightPanel = function RightPanel(_ref) {
12
+ var _point$device, _point$issues;
17
13
  var point = _ref.point,
14
+ distance = _ref.distance,
18
15
  className = _ref.className,
19
16
  onClose = _ref.onClose;
17
+ var splitCamelCase = function splitCamelCase(str) {
18
+ if (!str) {
19
+ return '';
20
+ }
21
+ return str.replace(/([a-z])([A-Z])/g, '$1 $2'); // Add space before each capital letter
22
+ };
23
+
20
24
  return /*#__PURE__*/_react.default.createElement("div", {
21
25
  className: className
22
26
  }, /*#__PURE__*/_react.default.createElement("div", {
@@ -26,98 +30,15 @@ var RightPanel = function RightPanel(_ref) {
26
30
  maxWidth: '600px',
27
31
  margin: '0 auto'
28
32
  }
29
- }, /*#__PURE__*/_react.default.createElement(_Card.default.Header, {
30
- className: "d-flex justify-content-between card-header"
31
- }, 'Manhole Details', /*#__PURE__*/_react.default.createElement("button", {
33
+ }, /*#__PURE__*/_react.default.createElement(_Card.default.Header, null, 'Manhole Details', /*#__PURE__*/_react.default.createElement("button", {
32
34
  className: "close",
33
35
  onClick: onClose
34
36
  }, /*#__PURE__*/_react.default.createElement("span", null, "\xD7"))), /*#__PURE__*/_react.default.createElement(_ListGroup.default, {
35
37
  variant: "flush"
36
- }, /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, {
37
- className: "list-item"
38
- }, /*#__PURE__*/_react.default.createElement("span", {
39
- className: "list-item-label"
40
- }, 'ID'), /*#__PURE__*/_react.default.createElement("span", {
41
- className: "list-item-value"
42
- }, point === null || point === void 0 ? void 0 : point.id)), /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, {
43
- className: "list-item"
44
- }, /*#__PURE__*/_react.default.createElement("span", {
45
- className: "list-item-label"
46
- }, 'Name'), /*#__PURE__*/_react.default.createElement("span", {
47
- className: "list-item-value"
48
- }, point === null || point === void 0 ? void 0 : point.name)), /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, {
49
- className: "list-item"
50
- }, /*#__PURE__*/_react.default.createElement("span", {
51
- className: "list-item-label"
52
- }, 'Description'), /*#__PURE__*/_react.default.createElement("span", {
53
- className: "list-item-value"
54
- }, point === null || point === void 0 ? void 0 : point.description)), /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, {
55
- className: "list-item"
56
- }, /*#__PURE__*/_react.default.createElement("span", {
57
- className: "list-item-label"
58
- }, 'Sector'), /*#__PURE__*/_react.default.createElement("span", {
59
- className: "list-item-value"
60
- }, point === null || point === void 0 ? void 0 : point.group.sector_name)), /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, {
61
- className: "list-item"
62
- }, /*#__PURE__*/_react.default.createElement("span", {
63
- className: "list-item-label"
64
- }, 'Monitored'), /*#__PURE__*/_react.default.createElement("span", {
65
- className: "list-item-value"
66
- }, (point === null || point === void 0 ? void 0 : point.has_device) ? 'Yes' : 'No')), !(point === null || point === void 0 ? void 0 : point.has_device) && /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, {
67
- className: "list-item"
68
- }, /*#__PURE__*/_react.default.createElement("span", {
69
- className: "list-item-label"
70
- }, 'Was Monitored'), /*#__PURE__*/_react.default.createElement("span", {
71
- className: "list-item-value"
72
- }, (point === null || point === void 0 ? void 0 : point.device_status) !== 'regular' ? 'Yes' : 'No')), /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, {
73
- className: "list-item"
74
- }, /*#__PURE__*/_react.default.createElement("span", {
75
- className: "list-item-label"
76
- }, 'Type'), ' ', /*#__PURE__*/_react.default.createElement("span", {
77
- className: "list-item-value"
78
- }, /*#__PURE__*/_react.default.createElement(_reactI18next.Trans, {
79
- i18nKey: "group_type.".concat(point === null || point === void 0 ? void 0 : point.group.type.replace('::', '/'))
80
- }))), /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, {
81
- className: "list-item"
82
- }, /*#__PURE__*/_react.default.createElement("span", {
83
- className: "list-item-label"
84
- }, 'Water Discharge'), /*#__PURE__*/_react.default.createElement("span", {
85
- className: "list-item-value"
86
- }, point === null || point === void 0 ? void 0 : point.group.water_discharge.toFixed(2))), /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, {
87
- className: "list-item"
88
- }, /*#__PURE__*/_react.default.createElement("span", {
89
- className: "list-item-label"
90
- }, 'Parent Distance'), /*#__PURE__*/_react.default.createElement("span", {
91
- className: "list-item-value"
92
- }, point === null || point === void 0 ? void 0 : point.parent_distance)), (point === null || point === void 0 ? void 0 : point.aeye_installation_height) && /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, {
93
- className: "list-item"
94
- }, /*#__PURE__*/_react.default.createElement("span", {
95
- className: "list-item-label"
96
- }, 'Installation Height'), /*#__PURE__*/_react.default.createElement("span", {
97
- className: "list-item-value"
98
- }, point.aeye_installation_height)), (point === null || point === void 0 ? void 0 : point.issues) && point.issues.length > 0 && /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, {
99
- className: "list-item"
100
- }, /*#__PURE__*/_react.default.createElement("span", {
101
- className: "list-item-label"
102
- }, 'Issues ', /*#__PURE__*/_react.default.createElement("img", {
103
- src: _i_Icon.default,
104
- alt: "info"
105
- })), /*#__PURE__*/_react.default.createElement("span", {
106
- className: "issues-list"
107
- }, point === null || point === void 0 ? void 0 : point.issues.map(function (issue) {
108
- return /*#__PURE__*/_react.default.createElement(_Card.default, {
109
- key: issue.type,
110
- className: 'pl-1 pr-1 issue-card'
111
- }, /*#__PURE__*/_react.default.createElement(_InfoTooltip.InfoTooltip, {
112
- title: _i18n.default.t("operations.filters.filter_types.".concat(issue.type)),
113
- data: issue.message,
114
- alignToBottom: true,
115
- alternateIcon: ''
116
- }, /*#__PURE__*/_react.default.createElement(_reactI18next.Trans, {
117
- i18nKey: "operations.filters.filter_types.".concat(issue.type)
118
- })));
119
- })))))));
38
+ }, /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, null, /*#__PURE__*/_react.default.createElement("strong", null, 'Name:'), " ", point === null || point === void 0 ? void 0 : point.name), /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, null, /*#__PURE__*/_react.default.createElement("strong", null, 'Description:'), " ", point === null || point === void 0 ? void 0 : point.description), /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, null, /*#__PURE__*/_react.default.createElement("strong", null, 'Monitored:'), " ", (point === null || point === void 0 ? void 0 : point.has_device) ? 'Yes' : 'No'), !(point === null || point === void 0 ? void 0 : point.has_device) && /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, 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(_ListGroup.default.Item, null, /*#__PURE__*/_react.default.createElement("strong", null, 'Sector:'), " ", point === null || point === void 0 ? void 0 : point.group.sector_name), /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, null, /*#__PURE__*/_react.default.createElement("strong", null, 'Type:'), ' ', splitCamelCase(point === null || point === void 0 ? void 0 : point.group.type.split('::')[1])), /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, null, /*#__PURE__*/_react.default.createElement("strong", null, 'Water Discharge:'), ' ', point === null || point === void 0 ? void 0 : point.group.water_discharge), /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, null, /*#__PURE__*/_react.default.createElement("strong", null, 'Distance:'), " ", distance), (point === null || point === void 0 ? void 0 : point.device) && /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, null, /*#__PURE__*/_react.default.createElement("strong", null, 'Installation Height:'), ' ', point === null || point === void 0 ? void 0 : (_point$device = point.device) === null || _point$device === void 0 ? void 0 : _point$device.aeye_installation_height), (point === null || point === void 0 ? void 0 : (_point$issues = point.issues) === null || _point$issues === void 0 ? void 0 : _point$issues.length) > 0 && /*#__PURE__*/_react.default.createElement(_ListGroup.default.Item, null, /*#__PURE__*/_react.default.createElement("strong", null, 'Issues:'), ' ', point === null || point === void 0 ? void 0 : point.issues.map(function (issue) {
39
+ return issue;
40
+ }).join(', '))))));
120
41
  };
121
42
  var _default = RightPanel;
122
43
  exports.default = _default;
123
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_Card","_ListGroup","_reactI18next","_InfoTooltip","_i_Icon","_i18n","RightPanel","_ref","point","className","onClose","default","createElement","style","maxWidth","margin","Header","onClick","variant","Item","id","name","description","group","sector_name","has_device","device_status","Trans","i18nKey","concat","type","replace","water_discharge","toFixed","parent_distance","aeye_installation_height","issues","length","src","iIcon","alt","map","issue","key","InfoTooltip","title","i18n","t","data","message","alignToBottom","alternateIcon","_default","exports"],"sources":["../../../src/pages/OperationsPage/RightPanel.tsx"],"sourcesContent":["import React from 'react';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport Card from 'react-bootstrap/Card';\nimport ListGroup from 'react-bootstrap/ListGroup';\nimport './OperationsPage.scss';\nimport { Trans } from 'react-i18next';\nimport { InfoTooltip } from 'src/ui-kit/InfoTooltip/InfoTooltip';\nimport iIcon from 'src/assets/icons/informationTooltip/i_Icon.svg';\nimport i18n from 'src/utilities/i18n';\n\ntype RightPanelProps = {\n  point: IPoint | null;\n  className?: string;\n  onClose?: () => void;\n};\n\nconst RightPanel: React.FC<RightPanelProps> = ({\n  point,\n  className,\n  onClose,\n}) => {\n  return (\n    <div className={className}>\n      <div className=\"drawer-body p-3\">\n        <Card style={{ maxWidth: '600px', margin: '0 auto' }}>\n          <Card.Header className=\"d-flex justify-content-between card-header\">\n            {'Manhole Details'}\n            <button className=\"close\" onClick={onClose}>\n              <span>&times;</span>\n            </button>\n          </Card.Header>\n          <ListGroup variant=\"flush\">\n            <ListGroup.Item className=\"list-item\">\n              <span className=\"list-item-label\">{'ID'}</span>\n              <span className=\"list-item-value\">{point?.id}</span>\n            </ListGroup.Item>\n            <ListGroup.Item className=\"list-item\">\n              <span className=\"list-item-label\">{'Name'}</span>\n              <span className=\"list-item-value\">{point?.name}</span>\n            </ListGroup.Item>\n            <ListGroup.Item className=\"list-item\">\n              <span className=\"list-item-label\">{'Description'}</span>\n              <span className=\"list-item-value\">{point?.description}</span>\n            </ListGroup.Item>\n            <ListGroup.Item className=\"list-item\">\n              <span className=\"list-item-label\">{'Sector'}</span>\n              <span className=\"list-item-value\">\n                {point?.group.sector_name}\n              </span>\n            </ListGroup.Item>\n            <ListGroup.Item className=\"list-item\">\n              <span className=\"list-item-label\">{'Monitored'}</span>\n              <span className=\"list-item-value\">\n                {point?.has_device ? 'Yes' : 'No'}\n              </span>\n            </ListGroup.Item>\n            {/* Show only if not monitored */}\n            {!point?.has_device && (\n              <ListGroup.Item className=\"list-item\">\n                <span className=\"list-item-label\">{'Was Monitored'}</span>\n                <span className=\"list-item-value\">\n                  {point?.device_status !== 'regular' ? 'Yes' : 'No'}\n                </span>\n              </ListGroup.Item>\n            )}\n            <ListGroup.Item className=\"list-item\">\n              <span className=\"list-item-label\">{'Type'}</span>{' '}\n              <span className=\"list-item-value\">\n                <Trans\n                  i18nKey={`group_type.${point?.group.type.replace('::', '/')}`}\n                />\n              </span>\n            </ListGroup.Item>\n            <ListGroup.Item className=\"list-item\">\n              <span className=\"list-item-label\">{'Water Discharge'}</span>\n              <span className=\"list-item-value\">\n                {point?.group.water_discharge.toFixed(2)}\n              </span>\n            </ListGroup.Item>\n            <ListGroup.Item className=\"list-item\">\n              <span className=\"list-item-label\">{'Parent Distance'}</span>\n              <span className=\"list-item-value\">{point?.parent_distance}</span>\n            </ListGroup.Item>\n            {point?.aeye_installation_height && (\n              <ListGroup.Item className=\"list-item\">\n                <span className=\"list-item-label\">{'Installation Height'}</span>\n                <span className=\"list-item-value\">\n                  {point.aeye_installation_height}\n                </span>\n              </ListGroup.Item>\n            )}\n            {point?.issues && point.issues.length > 0 && (\n              <ListGroup.Item className=\"list-item\">\n                <span className=\"list-item-label\">\n                  {'Issues '}\n                  <img src={iIcon} alt=\"info\" />\n                </span>\n                <span className=\"issues-list\">\n                  {point?.issues.map((issue) => (\n                    <Card key={issue.type} className={'pl-1 pr-1 issue-card'}>\n                      <InfoTooltip\n                        title={i18n.t(\n                          `operations.filters.filter_types.${issue.type}`,\n                        )}\n                        data={issue.message}\n                        alignToBottom={true}\n                        alternateIcon={''}\n                      >\n                        <Trans\n                          i18nKey={`operations.filters.filter_types.${issue.type}`}\n                        />\n                      </InfoTooltip>\n                    </Card>\n                  ))}\n                </span>\n              </ListGroup.Item>\n            )}\n          </ListGroup>\n        </Card>\n      </div>\n    </div>\n  );\n};\n\nexport default RightPanel;\n"],"mappings":"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"}
44
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_Card","_ListGroup","RightPanel","_ref","_point$device","_point$issues","point","distance","className","onClose","splitCamelCase","str","replace","default","createElement","style","maxWidth","margin","Header","onClick","variant","Item","name","description","has_device","device_status","group","sector_name","type","split","water_discharge","device","aeye_installation_height","issues","length","map","issue","join","_default","exports"],"sources":["../../../src/pages/OperationsPage/RightPanel.tsx"],"sourcesContent":["import React from 'react';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport Card from 'react-bootstrap/Card';\nimport ListGroup from 'react-bootstrap/ListGroup';\n\ntype RightPanelProps = {\n  point: IPoint | null;\n  distance: number;\n  className?: string;\n  onClose?: () => void;\n};\n\nconst RightPanel: React.FC<RightPanelProps> = ({\n  point,\n  distance,\n  className,\n  onClose,\n}) => {\n  const splitCamelCase = (str) => {\n    if (!str) {\n      return '';\n    }\n\n    return str.replace(/([a-z])([A-Z])/g, '$1 $2'); // Add space before each capital letter\n  };\n\n  return (\n    <div className={className}>\n      <div className=\"drawer-body p-3\">\n        <Card style={{ maxWidth: '600px', margin: '0 auto' }}>\n          <Card.Header>\n            {'Manhole Details'}\n            <button className=\"close\" onClick={onClose}>\n              <span>&times;</span>\n            </button>\n          </Card.Header>\n          <ListGroup variant=\"flush\">\n            <ListGroup.Item>\n              <strong>{'Name:'}</strong> {point?.name}\n            </ListGroup.Item>\n            <ListGroup.Item>\n              <strong>{'Description:'}</strong> {point?.description}\n            </ListGroup.Item>\n            <ListGroup.Item>\n              <strong>{'Monitored:'}</strong> {point?.has_device ? 'Yes' : 'No'}\n            </ListGroup.Item>\n            {/* Show only if not monitored */}\n            {!point?.has_device && (\n              <ListGroup.Item>\n                <strong>{'Was Monitored:'}</strong>{' '}\n                {point?.device_status !== 'regular' ? 'Yes' : 'No'}\n              </ListGroup.Item>\n            )}\n            <ListGroup.Item>\n              <strong>{'Sector:'}</strong> {point?.group.sector_name}\n            </ListGroup.Item>\n            <ListGroup.Item>\n              <strong>{'Type:'}</strong>{' '}\n              {splitCamelCase(point?.group.type.split('::')[1])}\n            </ListGroup.Item>\n            <ListGroup.Item>\n              <strong>{'Water Discharge:'}</strong>{' '}\n              {point?.group.water_discharge}\n            </ListGroup.Item>\n            <ListGroup.Item>\n              <strong>{'Distance:'}</strong> {distance}\n            </ListGroup.Item>\n            {point?.device && (\n              <ListGroup.Item>\n                <strong>{'Installation Height:'}</strong>{' '}\n                {point?.device?.aeye_installation_height}\n              </ListGroup.Item>\n            )}\n            {point?.issues?.length > 0 && (\n              <ListGroup.Item>\n                <strong>{'Issues:'}</strong>{' '}\n                {point?.issues.map((issue) => issue).join(', ')}\n              </ListGroup.Item>\n            )}\n          </ListGroup>\n        </Card>\n      </div>\n    </div>\n  );\n};\n\nexport default RightPanel;\n"],"mappings":"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"}
@@ -5,51 +5,20 @@ var _typeof = require("@babel/runtime/helpers/typeof");
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
- exports.default = void 0;
8
+ exports.Map = void 0;
9
9
  var _react = _interopRequireWildcard(require("react"));
10
- var _useMap2 = require("./useMap");
10
+ var _useMap = require("./useMap");
11
11
  var _ErrorBoundary = _interopRequireDefault(require("utilities/ErrorBoundary"));
12
12
  require("./Map.scss");
13
13
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
14
14
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
15
- var Map = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
15
+ var Map = function Map(_ref) {
16
16
  var filteredUseCase = _ref.filteredUseCase,
17
17
  points = _ref.points,
18
18
  polygon = _ref.polygon,
19
19
  onBoundsChange = _ref.onBoundsChange;
20
20
  var mapRef = (0, _react.useRef)(null);
21
- var _useMap = (0, _useMap2.useMap)(mapRef, points, filteredUseCase, polygon),
22
- map = _useMap.map,
23
- markers = _useMap.markers;
24
- (0, _react.useImperativeHandle)(ref, function () {
25
- return {
26
- zoomToPoint: function zoomToPoint(lat, lng) {
27
- if (map) {
28
- map.setView([lat, lng], map.getMaxZoom());
29
- }
30
- },
31
- clickOnMarker: function clickOnMarker(lat, lng) {
32
- if (map) {
33
- var marker = markers.find(function (m) {
34
- return m.getLatLng().lat === lat && m.getLatLng().lng === lng;
35
- });
36
- if (marker && marker.getElement()) {
37
- marker.fire('click');
38
- }
39
- }
40
- },
41
- closePopup: function closePopup() {
42
- if (map) {
43
- map.closePopup();
44
- }
45
- }
46
- };
47
- });
48
-
49
- // useEffect(() => {
50
- // console.log('Markers updated:', markers.length);
51
- // }, [markers]);
52
-
21
+ var map = (0, _useMap.useMap)(mapRef, points, filteredUseCase, polygon);
53
22
  (0, _react.useEffect)(function () {
54
23
  if (map && mapRef.current) {
55
24
  if (onBoundsChange) {
@@ -73,7 +42,6 @@ var Map = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
73
42
  ref: mapRef,
74
43
  className: "map-heights"
75
44
  })));
76
- });
77
- var _default = Map;
78
- exports.default = _default;
79
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVXaWxkY2FyZCIsInJlcXVpcmUiLCJfdXNlTWFwMiIsIl9FcnJvckJvdW5kYXJ5IiwiX2ludGVyb3BSZXF1aXJlRGVmYXVsdCIsIl9nZXRSZXF1aXJlV2lsZGNhcmRDYWNoZSIsIm5vZGVJbnRlcm9wIiwiV2Vha01hcCIsImNhY2hlQmFiZWxJbnRlcm9wIiwiY2FjaGVOb2RlSW50ZXJvcCIsIm9iaiIsIl9fZXNNb2R1bGUiLCJfdHlwZW9mIiwiZGVmYXVsdCIsImNhY2hlIiwiaGFzIiwiZ2V0IiwibmV3T2JqIiwiaGFzUHJvcGVydHlEZXNjcmlwdG9yIiwiT2JqZWN0IiwiZGVmaW5lUHJvcGVydHkiLCJnZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3IiLCJrZXkiLCJwcm90b3R5cGUiLCJoYXNPd25Qcm9wZXJ0eSIsImNhbGwiLCJkZXNjIiwic2V0IiwiTWFwIiwiZm9yd2FyZFJlZiIsIl9yZWYiLCJyZWYiLCJmaWx0ZXJlZFVzZUNhc2UiLCJwb2ludHMiLCJwb2x5Z29uIiwib25Cb3VuZHNDaGFuZ2UiLCJtYXBSZWYiLCJ1c2VSZWYiLCJfdXNlTWFwIiwidXNlTWFwIiwibWFwIiwibWFya2VycyIsInVzZUltcGVyYXRpdmVIYW5kbGUiLCJ6b29tVG9Qb2ludCIsImxhdCIsImxuZyIsInNldFZpZXciLCJnZXRNYXhab29tIiwiY2xpY2tPbk1hcmtlciIsIm1hcmtlciIsImZpbmQiLCJtIiwiZ2V0TGF0TG5nIiwiZ2V0RWxlbWVudCIsImZpcmUiLCJjbG9zZVBvcHVwIiwidXNlRWZmZWN0IiwiY3VycmVudCIsImdldEJvdW5kcyIsImhhbmRsZU1hcEVuZCIsIm9uIiwib2ZmIiwiY3JlYXRlRWxlbWVudCIsImNsYXNzTmFtZSIsIl9kZWZhdWx0IiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9wYWdlcy9Qb2xsdXRpb25SaXNrQXNzZXNzbWVudC9NYXAudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwge1xuICB1c2VFZmZlY3QsXG4gIHVzZVJlZixcbiAgdXNlSW1wZXJhdGl2ZUhhbmRsZSxcbiAgZm9yd2FyZFJlZixcbn0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgdXNlTWFwIH0gZnJvbSAnLi91c2VNYXAnO1xuaW1wb3J0IEVycm9yQm91bmRhcnkgZnJvbSAnc3JjL3V0aWxpdGllcy9FcnJvckJvdW5kYXJ5JztcbmltcG9ydCAnLi9NYXAuc2Nzcyc7XG5pbXBvcnQgeyBJR2VvUG9pbnQgfSBmcm9tICdzcmMvc3RvcmUvcG9pbnRzL21vZGVscy9JR2VvUG9pbnQnO1xuaW1wb3J0IHsgR2VvSlNPTiwgTGF0TG5nQm91bmRzIH0gZnJvbSAnbGVhZmxldCc7XG5cbmludGVyZmFjZSBNYXBQcm9wcyB7XG4gIGZpbHRlcmVkVXNlQ2FzZTogYW55O1xuICBwb2ludHM6IElHZW9Qb2ludFtdO1xuICBwb2x5Z29uOiBHZW9KU09OO1xuICBvbkJvdW5kc0NoYW5nZT86IChib3VuZHM6IExhdExuZ0JvdW5kcykgPT4gdm9pZDtcbn1cblxuY29uc3QgTWFwID0gZm9yd2FyZFJlZihcbiAgKHsgZmlsdGVyZWRVc2VDYXNlLCBwb2ludHMsIHBvbHlnb24sIG9uQm91bmRzQ2hhbmdlIH06IE1hcFByb3BzLCByZWYpID0+IHtcbiAgICBjb25zdCBtYXBSZWYgPSB1c2VSZWY8SFRNTERpdkVsZW1lbnQ+KG51bGwpO1xuICAgIGNvbnN0IHsgbWFwLCBtYXJrZXJzIH0gPSB1c2VNYXAobWFwUmVmLCBwb2ludHMsIGZpbHRlcmVkVXNlQ2FzZSwgcG9seWdvbik7XG5cbiAgICB1c2VJbXBlcmF0aXZlSGFuZGxlKHJlZiwgKCkgPT4gKHtcbiAgICAgIHpvb21Ub1BvaW50OiAobGF0OiBudW1iZXIsIGxuZzogbnVtYmVyKSA9PiB7XG4gICAgICAgIGlmIChtYXApIHtcbiAgICAgICAgICBtYXAuc2V0VmlldyhbbGF0LCBsbmddLCBtYXAuZ2V0TWF4Wm9vbSgpKTtcbiAgICAgICAgfVxuICAgICAgfSxcbiAgICAgIGNsaWNrT25NYXJrZXI6IChsYXQ6IG51bWJlciwgbG5nOiBudW1iZXIpID0+IHtcbiAgICAgICAgaWYgKG1hcCkge1xuICAgICAgICAgIGNvbnN0IG1hcmtlciA9IG1hcmtlcnMuZmluZChcbiAgICAgICAgICAgIChtKSA9PiBtLmdldExhdExuZygpLmxhdCA9PT0gbGF0ICYmIG0uZ2V0TGF0TG5nKCkubG5nID09PSBsbmcsXG4gICAgICAgICAgKTtcbiAgICAgICAgICBpZiAobWFya2VyICYmIG1hcmtlci5nZXRFbGVtZW50KCkpIHtcbiAgICAgICAgICAgIG1hcmtlci5maXJlKCdjbGljaycpO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfSxcbiAgICAgIGNsb3NlUG9wdXA6ICgpID0+IHtcbiAgICAgICAgaWYgKG1hcCkge1xuICAgICAgICAgIG1hcC5jbG9zZVBvcHVwKCk7XG4gICAgICAgIH1cbiAgICAgIH0sXG4gICAgfSkpO1xuXG4gICAgLy8gdXNlRWZmZWN0KCgpID0+IHtcbiAgICAvLyAgIGNvbnNvbGUubG9nKCdNYXJrZXJzIHVwZGF0ZWQ6JywgbWFya2Vycy5sZW5ndGgpO1xuICAgIC8vIH0sIFttYXJrZXJzXSk7XG5cbiAgICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgICAgaWYgKG1hcCAmJiBtYXBSZWYuY3VycmVudCkge1xuICAgICAgICBpZiAob25Cb3VuZHNDaGFuZ2UpIHtcbiAgICAgICAgICBvbkJvdW5kc0NoYW5nZShtYXAuZ2V0Qm91bmRzKCkpO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgaGFuZGxlTWFwRW5kID0gKCkgPT4ge1xuICAgICAgICAgIGlmIChvbkJvdW5kc0NoYW5nZSkge1xuICAgICAgICAgICAgb25Cb3VuZHNDaGFuZ2UobWFwLmdldEJvdW5kcygpKTtcbiAgICAgICAgICB9XG4gICAgICAgIH07XG5cbiAgICAgICAgbWFwLm9uKCdtb3ZlZW5kJywgaGFuZGxlTWFwRW5kKTtcblxuICAgICAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgICAgIG1hcC5vZmYoJ21vdmVlbmQnLCBoYW5kbGVNYXBFbmQpO1xuICAgICAgICB9O1xuICAgICAgfVxuICAgICAgcmV0dXJuO1xuICAgIH0sIFttYXAsIG9uQm91bmRzQ2hhbmdlXSk7XG5cbiAgICByZXR1cm4gKFxuICAgICAgPGRpdiBjbGFzc05hbWU9XCJtYXAtY29udGFpbmVyXCI+XG4gICAgICAgIDxFcnJvckJvdW5kYXJ5PlxuICAgICAgICAgIDxkaXYgcmVmPXttYXBSZWZ9IGNsYXNzTmFtZT1cIm1hcC1oZWlnaHRzXCIgLz5cbiAgICAgICAgPC9FcnJvckJvdW5kYXJ5PlxuICAgICAgPC9kaXY+XG4gICAgKTtcbiAgfSxcbik7XG5cbmV4cG9ydCBkZWZhdWx0IE1hcDtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFBQSxJQUFBQSxNQUFBLEdBQUFDLHVCQUFBLENBQUFDLE9BQUE7QUFNQSxJQUFBQyxRQUFBLEdBQUFELE9BQUE7QUFDQSxJQUFBRSxjQUFBLEdBQUFDLHNCQUFBLENBQUFILE9BQUE7QUFDQUEsT0FBQTtBQUFvQixTQUFBSSx5QkFBQUMsV0FBQSxlQUFBQyxPQUFBLGtDQUFBQyxpQkFBQSxPQUFBRCxPQUFBLFFBQUFFLGdCQUFBLE9BQUFGLE9BQUEsWUFBQUYsd0JBQUEsWUFBQUEseUJBQUFDLFdBQUEsV0FBQUEsV0FBQSxHQUFBRyxnQkFBQSxHQUFBRCxpQkFBQSxLQUFBRixXQUFBO0FBQUEsU0FBQU4sd0JBQUFVLEdBQUEsRUFBQUosV0FBQSxTQUFBQSxXQUFBLElBQUFJLEdBQUEsSUFBQUEsR0FBQSxDQUFBQyxVQUFBLFdBQUFELEdBQUEsUUFBQUEsR0FBQSxhQUFBRSxPQUFBLENBQUFGLEdBQUEseUJBQUFBLEdBQUEsNEJBQUFHLE9BQUEsRUFBQUgsR0FBQSxVQUFBSSxLQUFBLEdBQUFULHdCQUFBLENBQUFDLFdBQUEsT0FBQVEsS0FBQSxJQUFBQSxLQUFBLENBQUFDLEdBQUEsQ0FBQUwsR0FBQSxZQUFBSSxLQUFBLENBQUFFLEdBQUEsQ0FBQU4sR0FBQSxTQUFBTyxN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
45
+ };
46
+ exports.Map = Map;
47
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVXaWxkY2FyZCIsInJlcXVpcmUiLCJfdXNlTWFwIiwiX0Vycm9yQm91bmRhcnkiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwiX2dldFJlcXVpcmVXaWxkY2FyZENhY2hlIiwibm9kZUludGVyb3AiLCJXZWFrTWFwIiwiY2FjaGVCYWJlbEludGVyb3AiLCJjYWNoZU5vZGVJbnRlcm9wIiwib2JqIiwiX19lc01vZHVsZSIsIl90eXBlb2YiLCJkZWZhdWx0IiwiY2FjaGUiLCJoYXMiLCJnZXQiLCJuZXdPYmoiLCJoYXNQcm9wZXJ0eURlc2NyaXB0b3IiLCJPYmplY3QiLCJkZWZpbmVQcm9wZXJ0eSIsImdldE93blByb3BlcnR5RGVzY3JpcHRvciIsImtleSIsInByb3RvdHlwZSIsImhhc093blByb3BlcnR5IiwiY2FsbCIsImRlc2MiLCJzZXQiLCJNYXAiLCJfcmVmIiwiZmlsdGVyZWRVc2VDYXNlIiwicG9pbnRzIiwicG9seWdvbiIsIm9uQm91bmRzQ2hhbmdlIiwibWFwUmVmIiwidXNlUmVmIiwibWFwIiwidXNlTWFwIiwidXNlRWZmZWN0IiwiY3VycmVudCIsImdldEJvdW5kcyIsImhhbmRsZU1hcEVuZCIsIm9uIiwib2ZmIiwiY3JlYXRlRWxlbWVudCIsImNsYXNzTmFtZSIsInJlZiIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcGFnZXMvUG9sbHV0aW9uUmlza0Fzc2Vzc21lbnQvTWFwLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0LCB1c2VSZWYgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyB1c2VNYXAgfSBmcm9tICcuL3VzZU1hcCc7XG5pbXBvcnQgRXJyb3JCb3VuZGFyeSBmcm9tICdzcmMvdXRpbGl0aWVzL0Vycm9yQm91bmRhcnknO1xuaW1wb3J0ICcuL01hcC5zY3NzJztcbmltcG9ydCB7IElHZW9Qb2ludCB9IGZyb20gJ3NyYy9zdG9yZS9wb2ludHMvbW9kZWxzL0lHZW9Qb2ludCc7XG5pbXBvcnQgeyBHZW9KU09OLCBMYXRMbmdCb3VuZHMgfSBmcm9tICdsZWFmbGV0JztcblxuaW50ZXJmYWNlIE1hcFByb3BzIHtcbiAgZmlsdGVyZWRVc2VDYXNlOiBhbnk7XG4gIHBvaW50czogSUdlb1BvaW50W107XG4gIHBvbHlnb246IEdlb0pTT047XG4gIG9uQm91bmRzQ2hhbmdlPzogKGJvdW5kczogTGF0TG5nQm91bmRzKSA9PiB2b2lkO1xufVxuXG5leHBvcnQgY29uc3QgTWFwOiBSZWFjdC5GQzxNYXBQcm9wcz4gPSAoe1xuICBmaWx0ZXJlZFVzZUNhc2UsXG4gIHBvaW50cyxcbiAgcG9seWdvbixcbiAgb25Cb3VuZHNDaGFuZ2UsXG59KSA9PiB7XG4gIGNvbnN0IG1hcFJlZiA9IHVzZVJlZjxIVE1MRGl2RWxlbWVudD4obnVsbCk7XG4gIGNvbnN0IG1hcCA9IHVzZU1hcChtYXBSZWYsIHBvaW50cywgZmlsdGVyZWRVc2VDYXNlLCBwb2x5Z29uKTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChtYXAgJiYgbWFwUmVmLmN1cnJlbnQpIHtcbiAgICAgIGlmIChvbkJvdW5kc0NoYW5nZSkge1xuICAgICAgICBvbkJvdW5kc0NoYW5nZShtYXAuZ2V0Qm91bmRzKCkpO1xuICAgICAgfVxuXG4gICAgICBjb25zdCBoYW5kbGVNYXBFbmQgPSAoKSA9PiB7XG4gICAgICAgIGlmIChvbkJvdW5kc0NoYW5nZSkge1xuICAgICAgICAgIG9uQm91bmRzQ2hhbmdlKG1hcC5nZXRCb3VuZHMoKSk7XG4gICAgICAgIH1cbiAgICAgIH07XG5cbiAgICAgIG1hcC5vbignbW92ZWVuZCcsIGhhbmRsZU1hcEVuZCk7XG5cbiAgICAgIHJldHVybiAoKSA9PiB7XG4gICAgICAgIG1hcC5vZmYoJ21vdmVlbmQnLCBoYW5kbGVNYXBFbmQpO1xuICAgICAgfTtcbiAgICB9XG4gICAgcmV0dXJuO1xuICB9LCBbbWFwLCBvbkJvdW5kc0NoYW5nZV0pO1xuXG4gIHJldHVybiAoXG4gICAgPGRpdiBjbGFzc05hbWU9XCJtYXAtY29udGFpbmVyXCI+XG4gICAgICA8RXJyb3JCb3VuZGFyeT5cbiAgICAgICAgPGRpdiByZWY9e21hcFJlZn0gY2xhc3NOYW1lPVwibWFwLWhlaWdodHNcIiAvPlxuICAgICAgPC9FcnJvckJvdW5kYXJ5PlxuICAgIDwvZGl2PlxuICApO1xufTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFBQSxJQUFBQSxNQUFBLEdBQUFDLHVCQUFBLENBQUFDLE9BQUE7QUFDQSxJQUFBQyxPQUFBLEdBQUFELE9BQUE7QUFDQSxJQUFBRSxjQUFBLEdBQUFDLHNCQUFBLENBQUFILE9BQUE7QUFDQUEsT0FBQTtBQUFvQixTQUFBSSx5QkFBQUMsV0FBQSxlQUFBQyxPQUFBLGtDQUFBQyxpQkFBQSxPQUFBRCxPQUFBLFFBQUFFLGdCQUFBLE9BQUFGLE9BQUEsWUFBQUYsd0JBQUEsWUFBQUEseUJBQUFDLFdBQUEsV0FBQUEsV0FBQSxHQUFBRyxnQkFBQSxHQUFBRCxpQkFBQSxLQUFBRixXQUFBO0FBQUEsU0FBQU4sd0JBQUFVLEdBQUEsRUFBQUosV0FBQSxTQUFBQSxXQUFBLElBQUFJLEdBQUEsSUFBQUEsR0FBQSxDQUFBQyxVQUFBLFdBQUFELEdBQUEsUUFBQUEsR0FBQSxhQUFBRSxPQUFBLENBQUFGLEdBQUEseUJBQUFBLEdBQUEsNEJBQUFHLE9BQUEsRUFBQUgsR0FBQSxVQUFBSSxLQUFBLEdBQUFULHdCQUFBLENBQUFDLFdBQUEsT0FBQVEsS0FBQSxJQUFBQSxLQUFBLENBQUFDLEdBQUEsQ0FBQUwsR0FBQSxZQUFBSSxLQUFBLENBQUFFLEdBQUEsQ0FBQU4sR0FBQSxTQUFBTyxNQUFBLFdBQUFDLHFCQUFBLEdBQUFDLE1BQUEsQ0FBQUMsY0FBQSxJQUFBRCxNQUFBLENBQUFFLHdCQUFBLFdBQUFDLEdBQUEsSUFBQVosR0FBQSxRQUFBWSxHQUFBLGtCQUFBSCxNQUFBLENBQUFJLFNBQUEsQ0FBQUMsY0FBQSxDQUFBQyxJQUFBLENBQUFmLEdBQUEsRUFBQVksR0FBQSxTQUFBSSxJQUFBLEdBQUFSLHFCQUFBLEdBQUFDLE1BQUEsQ0FBQUUsd0JBQUEsQ0FBQVgsR0FBQSxFQUFBWSxHQUFBLGNBQUFJLElBQUEsS0FBQUEsSUFBQSxDQUFBVixHQUFBLElBQUFVLElBQUEsQ0FBQUMsR0FBQSxLQUFBUixNQUFBLENBQUFDLGNBQUEsQ0FBQUgsTUFBQSxFQUFBSyxHQUFBLEVBQUFJLElBQUEsWUFBQVQsTUFBQSxDQUFBSyxHQUFBLElBQUFaLEdBQUEsQ0FBQVksR0FBQSxTQUFBTCxNQUFBLENBQUFKLE9BQUEsR0FBQUgsR0FBQSxNQUFBSSxLQUFBLElBQUFBLEtBQUEsQ0FBQWEsR0FBQSxDQUFBakIsR0FBQSxFQUFBTyxNQUFBLFlBQUFBLE1BQUE7QUFXYixJQUFNVyxHQUF1QixHQUFHLFNBQTFCQSxHQUF1QkEsQ0FBQUMsSUFBQSxFQUs5QjtFQUFBLElBSkpDLGVBQWUsR0FBQUQsSUFBQSxDQUFmQyxlQUFlO0lBQ2ZDLE1BQU0sR0FBQUYsSUFBQSxDQUFORSxNQUFNO0lBQ05DLE9BQU8sR0FBQUgsSUFBQSxDQUFQRyxPQUFPO0lBQ1BDLGNBQWMsR0FBQUosSUFBQSxDQUFkSSxjQUFjO0VBRWQsSUFBTUMsTUFBTSxHQUFHLElBQUFDLGFBQU0sRUFBaUIsSUFBSSxDQUFDO0VBQzNDLElBQU1DLEdBQUcsR0FBRyxJQUFBQyxjQUFNLEVBQUNILE1BQU0sRUFBRUgsTUFBTSxFQUFFRCxlQUFlLEVBQUVFLE9BQU8sQ0FBQztFQUU1RCxJQUFBTSxnQkFBUyxFQUFDLFlBQU07SUFDZCxJQUFJRixHQUFHLElBQUlGLE1BQU0sQ0FBQ0ssT0FBTyxFQUFFO01BQ3pCLElBQUlOLGNBQWMsRUFBRTtRQUNsQkEsY0FBYyxDQUFDRyxHQUFHLENBQUNJLFNBQVMsQ0FBQyxDQUFDLENBQUM7TUFDakM7TUFFQSxJQUFNQyxZQUFZLEdBQUcsU0FBZkEsWUFBWUEsQ0FBQSxFQUFTO1FBQ3pCLElBQUlSLGNBQWMsRUFBRTtVQUNsQkEsY0FBYyxDQUFDRyxHQUFHLENBQUNJLFNBQVMsQ0FBQyxDQUFDLENBQUM7UUFDakM7TUFDRixDQUFDO01BRURKLEdBQUcsQ0FBQ00sRUFBRSxDQUFDLFNBQVMsRUFBRUQsWUFBWSxDQUFDO01BRS9CLE9BQU8sWUFBTTtRQUNYTCxHQUFHLENBQUNPLEdBQUcsQ0FBQyxTQUFTLEVBQUVGLFlBQVksQ0FBQztNQUNsQyxDQUFDO0lBQ0g7SUFDQTtFQUNGLENBQUMsRUFBRSxDQUFDTCxHQUFHLEVBQUVILGNBQWMsQ0FBQyxDQUFDO0VBRXpCLG9CQUNFbEMsTUFBQSxDQUFBYyxPQUFBLENBQUErQixhQUFBO0lBQUtDLFNBQVMsRUFBQztFQUFlLGdCQUM1QjlDLE1BQUEsQ0FBQWMsT0FBQSxDQUFBK0IsYUFBQSxDQUFDekMsY0FBQSxDQUFBVSxPQUFhLHFCQUNaZCxNQUFBLENBQUFjLE9BQUEsQ0FBQStCLGFBQUE7SUFBS0UsR0FBRyxFQUFFWixNQUFPO0lBQUNXLFNBQVMsRUFBQztFQUFhLENBQUUsQ0FDOUIsQ0FDWixDQUFDO0FBRVYsQ0FBQztBQUFDRSxPQUFBLENBQUFuQixHQUFBLEdBQUFBLEdBQUEifQ==