@kando-env/kando-ui 1.2.371-alpha.6 → 1.2.371-alpha.7
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.
|
@@ -12,10 +12,9 @@ var _react = _interopRequireDefault(require("react"));
|
|
|
12
12
|
var _StyledLink = require("components/Links/StyledLink/StyledLink");
|
|
13
13
|
var _rightArrowLight = require("@svgr/webpack?-svgo!./right-arrow-light.svg");
|
|
14
14
|
var _Analytics = require("utilities/Analytics");
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
15
|
+
var _WWTPDashboardSlice = require("store/WWTPDashboard/WWTPDashboardSlice");
|
|
16
|
+
var _reactRedux = require("react-redux");
|
|
17
|
+
var _Widget = require("pages/DashboardMap/Widget");
|
|
19
18
|
var Breadcrumbs = function Breadcrumbs(_ref) {
|
|
20
19
|
var parts = _ref.parts;
|
|
21
20
|
// const cleanEmptyCrumbs = (parts) => {
|
|
@@ -24,67 +23,167 @@ var Breadcrumbs = function Breadcrumbs(_ref) {
|
|
|
24
23
|
// });
|
|
25
24
|
// };
|
|
26
25
|
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
26
|
+
var dispatch = (0, _reactRedux.useDispatch)();
|
|
27
|
+
var _useSelector = (0, _reactRedux.useSelector)(function (state) {
|
|
28
|
+
return state.global_data;
|
|
29
|
+
}),
|
|
30
|
+
waterAuthorityId = _useSelector.waterAuthorityId;
|
|
31
|
+
var locale = (0, _reactRedux.useSelector)(function (state) {
|
|
32
|
+
return state.nav_context_data.navContext.locale;
|
|
33
|
+
});
|
|
34
|
+
var points = (0, _reactRedux.useSelector)(function (state) {
|
|
35
|
+
return state.points_data.items;
|
|
36
|
+
});
|
|
37
|
+
var areas = (0, _reactRedux.useSelector)(function (state) {
|
|
38
|
+
return state.areas_data.newAreas;
|
|
39
|
+
});
|
|
40
|
+
var updateFocusedArea = /*#__PURE__*/function () {
|
|
41
|
+
var _ref2 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(part) {
|
|
42
|
+
return _regenerator.default.wrap(function _callee$(_context) {
|
|
43
|
+
while (1) {
|
|
44
|
+
switch (_context.prev = _context.next) {
|
|
45
|
+
case 0:
|
|
46
|
+
if (!part.point_id) {
|
|
47
|
+
_context.next = 5;
|
|
48
|
+
break;
|
|
49
|
+
}
|
|
50
|
+
_context.next = 3;
|
|
51
|
+
return changeFocusedPoint(part.point_id);
|
|
52
|
+
case 3:
|
|
53
|
+
_context.next = 8;
|
|
54
|
+
break;
|
|
55
|
+
case 5:
|
|
56
|
+
if (!part.area_id) {
|
|
57
|
+
_context.next = 8;
|
|
58
|
+
break;
|
|
59
|
+
}
|
|
60
|
+
_context.next = 8;
|
|
61
|
+
return changeFocusedArea({
|
|
62
|
+
id: part.area_id,
|
|
63
|
+
is_virtual: part.link.includes('varea')
|
|
64
|
+
});
|
|
65
|
+
case 8:
|
|
66
|
+
case "end":
|
|
67
|
+
return _context.stop();
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}, _callee);
|
|
71
|
+
}));
|
|
72
|
+
return function updateFocusedArea(_x) {
|
|
73
|
+
return _ref2.apply(this, arguments);
|
|
74
|
+
};
|
|
75
|
+
}();
|
|
76
|
+
var changeFocusedPoint = /*#__PURE__*/function () {
|
|
77
|
+
var _ref3 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2(selectedPointId) {
|
|
78
|
+
var point, listItems, focusedPoint;
|
|
79
|
+
return _regenerator.default.wrap(function _callee2$(_context2) {
|
|
80
|
+
while (1) {
|
|
81
|
+
switch (_context2.prev = _context2.next) {
|
|
82
|
+
case 0:
|
|
83
|
+
point = points.find(function (point) {
|
|
84
|
+
return point.id === selectedPointId;
|
|
85
|
+
});
|
|
86
|
+
if (point) {
|
|
87
|
+
_context2.next = 3;
|
|
88
|
+
break;
|
|
89
|
+
}
|
|
90
|
+
return _context2.abrupt("return");
|
|
91
|
+
case 3:
|
|
92
|
+
_context2.next = 5;
|
|
93
|
+
return loadData({
|
|
94
|
+
url: "site/".concat(point === null || point === void 0 ? void 0 : point.id),
|
|
95
|
+
type: 'point',
|
|
96
|
+
item: point
|
|
97
|
+
});
|
|
98
|
+
case 5:
|
|
99
|
+
listItems = _context2.sent;
|
|
100
|
+
focusedPoint = (0, _Widget.updatePoint)({
|
|
101
|
+
point: point,
|
|
102
|
+
listItems: listItems,
|
|
103
|
+
areas: areas,
|
|
104
|
+
points: points
|
|
105
|
+
});
|
|
106
|
+
dispatch((0, _WWTPDashboardSlice.setFocusedArea)(focusedPoint));
|
|
107
|
+
case 8:
|
|
108
|
+
case "end":
|
|
109
|
+
return _context2.stop();
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
}, _callee2);
|
|
113
|
+
}));
|
|
114
|
+
return function changeFocusedPoint(_x2) {
|
|
115
|
+
return _ref3.apply(this, arguments);
|
|
116
|
+
};
|
|
117
|
+
}();
|
|
118
|
+
var changeFocusedArea = /*#__PURE__*/function () {
|
|
119
|
+
var _ref5 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee3(_ref4) {
|
|
120
|
+
var id, is_virtual, area;
|
|
121
|
+
return _regenerator.default.wrap(function _callee3$(_context3) {
|
|
122
|
+
while (1) {
|
|
123
|
+
switch (_context3.prev = _context3.next) {
|
|
124
|
+
case 0:
|
|
125
|
+
id = _ref4.id, is_virtual = _ref4.is_virtual;
|
|
126
|
+
area = areas.find(function (area) {
|
|
127
|
+
return area.area_id === id && area.is_virtual === is_virtual;
|
|
128
|
+
});
|
|
129
|
+
if (area) {
|
|
130
|
+
_context3.next = 4;
|
|
131
|
+
break;
|
|
132
|
+
}
|
|
133
|
+
return _context3.abrupt("return");
|
|
134
|
+
case 4:
|
|
135
|
+
dispatch((0, _WWTPDashboardSlice.setFocusedArea)(area));
|
|
136
|
+
case 5:
|
|
137
|
+
case "end":
|
|
138
|
+
return _context3.stop();
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
}, _callee3);
|
|
142
|
+
}));
|
|
143
|
+
return function changeFocusedArea(_x3) {
|
|
144
|
+
return _ref5.apply(this, arguments);
|
|
145
|
+
};
|
|
146
|
+
}();
|
|
147
|
+
var loadData = /*#__PURE__*/function () {
|
|
148
|
+
var _ref7 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee4(_ref6) {
|
|
149
|
+
var url, type, item, response, listItems;
|
|
150
|
+
return _regenerator.default.wrap(function _callee4$(_context4) {
|
|
151
|
+
while (1) {
|
|
152
|
+
switch (_context4.prev = _context4.next) {
|
|
153
|
+
case 0:
|
|
154
|
+
url = _ref6.url, type = _ref6.type, item = _ref6.item;
|
|
155
|
+
_context4.next = 3;
|
|
156
|
+
return fetch("/api_ui/wwtp_page/".concat(url, "/capacity?locale=").concat(locale, "&water_authority_id=").concat(waterAuthorityId));
|
|
157
|
+
case 3:
|
|
158
|
+
response = _context4.sent;
|
|
159
|
+
listItems = {
|
|
160
|
+
data: []
|
|
161
|
+
};
|
|
162
|
+
if (!response.ok) {
|
|
163
|
+
_context4.next = 11;
|
|
164
|
+
break;
|
|
165
|
+
}
|
|
166
|
+
_context4.next = 8;
|
|
167
|
+
return response.json();
|
|
168
|
+
case 8:
|
|
169
|
+
listItems = _context4.sent;
|
|
170
|
+
_context4.next = 12;
|
|
171
|
+
break;
|
|
172
|
+
case 11:
|
|
173
|
+
console.warn("HTTP error! for ".concat(type, ": ").concat(item, ", status: "), response.status);
|
|
174
|
+
case 12:
|
|
175
|
+
return _context4.abrupt("return", listItems.data);
|
|
176
|
+
case 13:
|
|
177
|
+
case "end":
|
|
178
|
+
return _context4.stop();
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
}, _callee4);
|
|
182
|
+
}));
|
|
183
|
+
return function loadData(_x4) {
|
|
184
|
+
return _ref7.apply(this, arguments);
|
|
185
|
+
};
|
|
186
|
+
}();
|
|
88
187
|
|
|
89
188
|
// parts = cleanEmptyCrumbs(parts);
|
|
90
189
|
|
|
@@ -102,21 +201,22 @@ var Breadcrumbs = function Breadcrumbs(_ref) {
|
|
|
102
201
|
className: "tab".concat(index === parts.length - 2 ? ' last' : '')
|
|
103
202
|
}, typeof part === 'string' ? part : /*#__PURE__*/_react.default.createElement(_StyledLink.Link, {
|
|
104
203
|
to: part.link,
|
|
105
|
-
onClick: /*#__PURE__*/(0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function
|
|
106
|
-
return _regenerator.default.wrap(function
|
|
204
|
+
onClick: /*#__PURE__*/(0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee5() {
|
|
205
|
+
return _regenerator.default.wrap(function _callee5$(_context5) {
|
|
107
206
|
while (1) {
|
|
108
|
-
switch (
|
|
207
|
+
switch (_context5.prev = _context5.next) {
|
|
109
208
|
case 0:
|
|
110
209
|
(0, _Analytics.analyticsTrack)('Breadcrumbs clicked', {
|
|
111
210
|
name: part.name
|
|
112
211
|
});
|
|
113
|
-
|
|
114
|
-
|
|
212
|
+
_context5.next = 3;
|
|
213
|
+
return updateFocusedArea(part);
|
|
214
|
+
case 3:
|
|
115
215
|
case "end":
|
|
116
|
-
return
|
|
216
|
+
return _context5.stop();
|
|
117
217
|
}
|
|
118
218
|
}
|
|
119
|
-
},
|
|
219
|
+
}, _callee5);
|
|
120
220
|
}))
|
|
121
221
|
}, part.name)));
|
|
122
222
|
}));
|
|
@@ -126,4 +226,4 @@ var Container = _styledComponents.default.div.withConfig({
|
|
|
126
226
|
displayName: "Breadcrumbs__Container",
|
|
127
227
|
componentId: "sc-12kmapt-0"
|
|
128
228
|
})(["display:flex;font-size:14px;font-weight:300;align-items:center;> .tab,.arrow{margin-right:10px;color:#1e1e1e;a{color:#1e1e1e;}&.last{font-weight:600;}}> .arrow{transform:rotate(-90deg);}[dir='rtl'] &{> .arrow{transform:rotate(90deg);}}"]);
|
|
129
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_StyledLink","_rightArrowLight","_Analytics","Breadcrumbs","_ref","parts","default","createElement","Container","className","Link","to","link","name","slice","map","part","index","Fragment","ReactComponent","key","height","width","concat","length","onClick","_asyncToGenerator2","_regenerator","mark","_callee","wrap","_callee$","_context","prev","next","analyticsTrack","stop","exports","styled","div","withConfig","displayName","componentId"],"sources":["../../../../../src/components/Header/InfoBar/Breadcrumbs/Breadcrumbs.tsx"],"sourcesContent":["import React from 'react';\nimport { Link } from 'src/components/Links/StyledLink/StyledLink';\nimport styled from 'styled-components/macro';\nimport { ReactComponent as RightArrow } from './right-arrow-light.svg';\nimport { analyticsTrack } from 'src/utilities/Analytics';\n// import { setFocusedArea } from 'src/store/WWTPDashboard/WWTPDashboardSlice';\n// import { useSelector } from 'react-redux';\n// import { updatePoint } from 'src/pages/DashboardMap/Widget';\nimport { Part } from '../types';\n\nexport const Breadcrumbs: React.FC<{\n  parts: Part[];\n}> = ({ parts }) => {\n  // const cleanEmptyCrumbs = (parts) => {\n  //   return parts.filter((el) => {\n  //     return el && (typeof el === 'string' || el['name'] !== undefined);\n  //   });\n  // };\n\n  // const dispatch = useDispatch();\n  // const { waterAuthorityId } = useSelector((state) => state.global_data);\n  // const locale = useSelector(\n  //   (state) => state.nav_context_data.navContext.locale,\n  // );\n  // const points = useSelector((state) => state.points_data.items);\n  // const areas = useSelector((state) => state.areas_data.newAreas);\n  // const updateFocusedArea = async (part: LinkedPart) => {\n  //   if (part.point_id) {\n  //     await changeFocusedPoint(part.point_id);\n  //   } else if (part.area_id) {\n  //     await changeFocusedArea({\n  //       id: part.area_id,\n  //       is_virtual: part.link.includes('varea'),\n  //     });\n  //   }\n  // };\n  // const changeFocusedPoint = async (selectedPointId) => {\n  //   const point = points.find((point) => point.id === selectedPointId);\n  //   if (!point) return;\n\n  //   let listItems = await loadData({\n  //     url: `site/${point?.id}`,\n  //     type: 'point',\n  //     item: point,\n  //   });\n\n  //   const focusedPoint = updatePoint({\n  //     point,\n  //     listItems,\n  //     areas,\n  //     points,\n  //   });\n  //   //dispatch(setFocusedArea(focusedPoint));\n  // };\n\n  // const changeFocusedArea = async ({ id, is_virtual }) => {\n  //   const area = areas.find(\n  //     (area) => area.area_id === id && area.is_virtual === is_virtual,\n  //   );\n  //   if (!area) return;\n\n  //   //dispatch(setFocusedArea(area));\n  // };\n\n  // const loadData = async ({ url, type, item }) => {\n  //   const response = await fetch(\n  //     `/api_ui/wwtp_page/${url}/capacity?locale=${locale}&water_authority_id=${waterAuthorityId}`,\n  //   );\n  //   let listItems = { data: [] };\n  //   if (response.ok) {\n  //     listItems = await response.json();\n  //   } else {\n  //     console.warn(\n  //       `HTTP error! for ${type}: ${item}, status: `,\n  //       response.status,\n  //     );\n  //   }\n\n  //   return listItems.data;\n  // };\n\n  // parts = cleanEmptyCrumbs(parts);\n\n  return (\n    <Container>\n      <div className=\"tab\">\n        {parts[0] &&\n          (typeof parts[0] === 'string' ? (\n            parts[0]\n          ) : (\n            <Link to={parts[0].link || '/'}>{parts[0].name}</Link>\n          ))}\n      </div>\n\n      {parts.slice(1).map((part, index) => (\n        <>\n          <RightArrow key={index} className=\"arrow\" height=\"9px\" width=\"6px\" />\n          <div className={`tab${index === parts.length - 2 ? ' last' : ''}`}>\n            {typeof part === 'string' ? (\n              part\n            ) : (\n              <Link\n                to={part.link}\n                onClick={async () => {\n                  analyticsTrack('Breadcrumbs clicked', {\n                    name: part.name,\n                  });\n                  // await updateFocusedArea(part);\n                }}\n              >\n                {part.name}\n              </Link>\n            )}\n          </div>\n        </>\n      ))}\n    </Container>\n  );\n};\n\nconst Container = styled.div`\n  display: flex;\n\n  font-size: 14px;\n  font-weight: 300;\n  align-items: center;\n\n  > .tab,\n  .arrow {\n    margin-right: 10px;\n    color: #1e1e1e;\n\n    a {\n      color: #1e1e1e;\n    }\n    &.last {\n      font-weight: 600;\n    }\n  }\n\n  > .arrow {\n    transform: rotate(-90deg);\n  }\n  [dir='rtl'] & {\n    > .arrow {\n      transform: rotate(90deg);\n    }\n  }\n`;\n"],"mappings":"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"}
|
|
229
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_StyledLink","_rightArrowLight","_Analytics","_WWTPDashboardSlice","_reactRedux","_Widget","Breadcrumbs","_ref","parts","dispatch","useDispatch","_useSelector","useSelector","state","global_data","waterAuthorityId","locale","nav_context_data","navContext","points","points_data","items","areas","areas_data","newAreas","updateFocusedArea","_ref2","_asyncToGenerator2","default","_regenerator","mark","_callee","part","wrap","_callee$","_context","prev","next","point_id","changeFocusedPoint","area_id","changeFocusedArea","id","is_virtual","link","includes","stop","_x","apply","arguments","_ref3","_callee2","selectedPointId","point","listItems","focusedPoint","_callee2$","_context2","find","abrupt","loadData","url","concat","type","item","sent","updatePoint","setFocusedArea","_x2","_ref5","_callee3","_ref4","area","_callee3$","_context3","_x3","_ref7","_callee4","_ref6","response","_callee4$","_context4","fetch","data","ok","json","console","warn","status","_x4","createElement","Container","className","Link","to","name","slice","map","index","Fragment","ReactComponent","key","height","width","length","onClick","_callee5","_callee5$","_context5","analyticsTrack","exports","styled","div","withConfig","displayName","componentId"],"sources":["../../../../../src/components/Header/InfoBar/Breadcrumbs/Breadcrumbs.tsx"],"sourcesContent":["import React from 'react';\nimport { Link } from 'src/components/Links/StyledLink/StyledLink';\nimport styled from 'styled-components/macro';\nimport { ReactComponent as RightArrow } from './right-arrow-light.svg';\nimport { analyticsTrack } from 'src/utilities/Analytics';\nimport { setFocusedArea } from 'src/store/WWTPDashboard/WWTPDashboardSlice';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { updatePoint } from 'src/pages/DashboardMap/Widget';\nimport { LinkedPart, Part } from '../types';\n\nexport const Breadcrumbs: React.FC<{\n  parts: Part[];\n}> = ({ parts }) => {\n  // const cleanEmptyCrumbs = (parts) => {\n  //   return parts.filter((el) => {\n  //     return el && (typeof el === 'string' || el['name'] !== undefined);\n  //   });\n  // };\n\n  const dispatch = useDispatch();\n  const { waterAuthorityId } = useSelector((state) => state.global_data);\n  const locale = useSelector(\n    (state) => state.nav_context_data.navContext.locale,\n  );\n  const points = useSelector((state) => state.points_data.items);\n  const areas = useSelector((state) => state.areas_data.newAreas);\n  const updateFocusedArea = async (part: LinkedPart) => {\n    if (part.point_id) {\n      await changeFocusedPoint(part.point_id);\n    } else if (part.area_id) {\n      await changeFocusedArea({\n        id: part.area_id,\n        is_virtual: part.link.includes('varea'),\n      });\n    }\n  };\n  const changeFocusedPoint = async (selectedPointId) => {\n    const point = points.find((point) => point.id === selectedPointId);\n    if (!point) return;\n\n    let listItems = await loadData({\n      url: `site/${point?.id}`,\n      type: 'point',\n      item: point,\n    });\n\n    const focusedPoint = updatePoint({\n      point,\n      listItems,\n      areas,\n      points,\n    });\n    dispatch(setFocusedArea(focusedPoint));\n  };\n\n  const changeFocusedArea = async ({ id, is_virtual }) => {\n    const area = areas.find(\n      (area) => area.area_id === id && area.is_virtual === is_virtual,\n    );\n    if (!area) return;\n\n    dispatch(setFocusedArea(area));\n  };\n\n  const loadData = async ({ url, type, item }) => {\n    const response = await fetch(\n      `/api_ui/wwtp_page/${url}/capacity?locale=${locale}&water_authority_id=${waterAuthorityId}`,\n    );\n    let listItems = { data: [] };\n    if (response.ok) {\n      listItems = await response.json();\n    } else {\n      console.warn(\n        `HTTP error! for ${type}: ${item}, status: `,\n        response.status,\n      );\n    }\n\n    return listItems.data;\n  };\n\n  // parts = cleanEmptyCrumbs(parts);\n\n  return (\n    <Container>\n      <div className=\"tab\">\n        {parts[0] &&\n          (typeof parts[0] === 'string' ? (\n            parts[0]\n          ) : (\n            <Link to={parts[0].link || '/'}>{parts[0].name}</Link>\n          ))}\n      </div>\n\n      {parts.slice(1).map((part, index) => (\n        <>\n          <RightArrow key={index} className=\"arrow\" height=\"9px\" width=\"6px\" />\n          <div className={`tab${index === parts.length - 2 ? ' last' : ''}`}>\n            {typeof part === 'string' ? (\n              part\n            ) : (\n              <Link\n                to={part.link}\n                onClick={async () => {\n                  analyticsTrack('Breadcrumbs clicked', {\n                    name: part.name,\n                  });\n                  await updateFocusedArea(part);\n                }}\n              >\n                {part.name}\n              </Link>\n            )}\n          </div>\n        </>\n      ))}\n    </Container>\n  );\n};\n\nconst Container = styled.div`\n  display: flex;\n\n  font-size: 14px;\n  font-weight: 300;\n  align-items: center;\n\n  > .tab,\n  .arrow {\n    margin-right: 10px;\n    color: #1e1e1e;\n\n    a {\n      color: #1e1e1e;\n    }\n    &.last {\n      font-weight: 600;\n    }\n  }\n\n  > .arrow {\n    transform: rotate(-90deg);\n  }\n  [dir='rtl'] & {\n    > .arrow {\n      transform: rotate(90deg);\n    }\n  }\n`;\n"],"mappings":";;;;;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,WAAA,GAAAD,OAAA;AAAkE,IAAAE,gBAAA,GAAAF,OAAA;AAGlE,IAAAG,UAAA,GAAAH,OAAA;AACA,IAAAI,mBAAA,GAAAJ,OAAA;AACA,IAAAK,WAAA,GAAAL,OAAA;AACA,IAAAM,OAAA,GAAAN,OAAA;AAGO,IAAMO,WAEX,GAAG,SAFQA,WAEXA,CAAAC,IAAA,EAAkB;EAAA,IAAZC,KAAK,GAAAD,IAAA,CAALC,KAAK;EACX;EACA;EACA;EACA;EACA;;EAEA,IAAMC,QAAQ,GAAG,IAAAC,uBAAW,EAAC,CAAC;EAC9B,IAAAC,YAAA,GAA6B,IAAAC,uBAAW,EAAC,UAACC,KAAK;MAAA,OAAKA,KAAK,CAACC,WAAW;IAAA,EAAC;IAA9DC,gBAAgB,GAAAJ,YAAA,CAAhBI,gBAAgB;EACxB,IAAMC,MAAM,GAAG,IAAAJ,uBAAW,EACxB,UAACC,KAAK;IAAA,OAAKA,KAAK,CAACI,gBAAgB,CAACC,UAAU,CAACF,MAAM;EAAA,CACrD,CAAC;EACD,IAAMG,MAAM,GAAG,IAAAP,uBAAW,EAAC,UAACC,KAAK;IAAA,OAAKA,KAAK,CAACO,WAAW,CAACC,KAAK;EAAA,EAAC;EAC9D,IAAMC,KAAK,GAAG,IAAAV,uBAAW,EAAC,UAACC,KAAK;IAAA,OAAKA,KAAK,CAACU,UAAU,CAACC,QAAQ;EAAA,EAAC;EAC/D,IAAMC,iBAAiB;IAAA,IAAAC,KAAA,OAAAC,kBAAA,CAAAC,OAAA,gBAAAC,YAAA,CAAAD,OAAA,CAAAE,IAAA,CAAG,SAAAC,QAAOC,IAAgB;MAAA,OAAAH,YAAA,CAAAD,OAAA,CAAAK,IAAA,UAAAC,SAAAC,QAAA;QAAA;UAAA,QAAAA,QAAA,CAAAC,IAAA,GAAAD,QAAA,CAAAE,IAAA;YAAA;cAAA,KAC3CL,IAAI,CAACM,QAAQ;gBAAAH,QAAA,CAAAE,IAAA;gBAAA;cAAA;cAAAF,QAAA,CAAAE,IAAA;cAAA,OACTE,kBAAkB,CAACP,IAAI,CAACM,QAAQ,CAAC;YAAA;cAAAH,QAAA,CAAAE,IAAA;cAAA;YAAA;cAAA,KAC9BL,IAAI,CAACQ,OAAO;gBAAAL,QAAA,CAAAE,IAAA;gBAAA;cAAA;cAAAF,QAAA,CAAAE,IAAA;cAAA,OACfI,iBAAiB,CAAC;gBACtBC,EAAE,EAAEV,IAAI,CAACQ,OAAO;gBAChBG,UAAU,EAAEX,IAAI,CAACY,IAAI,CAACC,QAAQ,CAAC,OAAO;cACxC,CAAC,CAAC;YAAA;YAAA;cAAA,OAAAV,QAAA,CAAAW,IAAA;UAAA;QAAA;MAAA,GAAAf,OAAA;IAAA,CAEL;IAAA,gBATKN,iBAAiBA,CAAAsB,EAAA;MAAA,OAAArB,KAAA,CAAAsB,KAAA,OAAAC,SAAA;IAAA;EAAA,GAStB;EACD,IAAMV,kBAAkB;IAAA,IAAAW,KAAA,OAAAvB,kBAAA,CAAAC,OAAA,gBAAAC,YAAA,CAAAD,OAAA,CAAAE,IAAA,CAAG,SAAAqB,SAAOC,eAAe;MAAA,IAAAC,KAAA,EAAAC,SAAA,EAAAC,YAAA;MAAA,OAAA1B,YAAA,CAAAD,OAAA,CAAAK,IAAA,UAAAuB,UAAAC,SAAA;QAAA;UAAA,QAAAA,SAAA,CAAArB,IAAA,GAAAqB,SAAA,CAAApB,IAAA;YAAA;cACzCgB,KAAK,GAAGlC,MAAM,CAACuC,IAAI,CAAC,UAACL,KAAK;gBAAA,OAAKA,KAAK,CAACX,EAAE,KAAKU,eAAe;cAAA,EAAC;cAAA,IAC7DC,KAAK;gBAAAI,SAAA,CAAApB,IAAA;gBAAA;cAAA;cAAA,OAAAoB,SAAA,CAAAE,MAAA;YAAA;cAAAF,SAAA,CAAApB,IAAA;cAAA,OAEYuB,QAAQ,CAAC;gBAC7BC,GAAG,UAAAC,MAAA,CAAUT,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEX,EAAE,CAAE;gBACxBqB,IAAI,EAAE,OAAO;gBACbC,IAAI,EAAEX;cACR,CAAC,CAAC;YAAA;cAJEC,SAAS,GAAAG,SAAA,CAAAQ,IAAA;cAMPV,YAAY,GAAG,IAAAW,mBAAW,EAAC;gBAC/Bb,KAAK,EAALA,KAAK;gBACLC,SAAS,EAATA,SAAS;gBACThC,KAAK,EAALA,KAAK;gBACLH,MAAM,EAANA;cACF,CAAC,CAAC;cACFV,QAAQ,CAAC,IAAA0D,kCAAc,EAACZ,YAAY,CAAC,CAAC;YAAC;YAAA;cAAA,OAAAE,SAAA,CAAAX,IAAA;UAAA;QAAA;MAAA,GAAAK,QAAA;IAAA,CACxC;IAAA,gBAjBKZ,kBAAkBA,CAAA6B,GAAA;MAAA,OAAAlB,KAAA,CAAAF,KAAA,OAAAC,SAAA;IAAA;EAAA,GAiBvB;EAED,IAAMR,iBAAiB;IAAA,IAAA4B,KAAA,OAAA1C,kBAAA,CAAAC,OAAA,gBAAAC,YAAA,CAAAD,OAAA,CAAAE,IAAA,CAAG,SAAAwC,SAAAC,KAAA;MAAA,IAAA7B,EAAA,EAAAC,UAAA,EAAA6B,IAAA;MAAA,OAAA3C,YAAA,CAAAD,OAAA,CAAAK,IAAA,UAAAwC,UAAAC,SAAA;QAAA;UAAA,QAAAA,SAAA,CAAAtC,IAAA,GAAAsC,SAAA,CAAArC,IAAA;YAAA;cAASK,EAAE,GAAA6B,KAAA,CAAF7B,EAAE,EAAEC,UAAU,GAAA4B,KAAA,CAAV5B,UAAU;cACzC6B,IAAI,GAAGlD,KAAK,CAACoC,IAAI,CACrB,UAACc,IAAI;gBAAA,OAAKA,IAAI,CAAChC,OAAO,KAAKE,EAAE,IAAI8B,IAAI,CAAC7B,UAAU,KAAKA,UAAU;cAAA,CACjE,CAAC;cAAA,IACI6B,IAAI;gBAAAE,SAAA,CAAArC,IAAA;gBAAA;cAAA;cAAA,OAAAqC,SAAA,CAAAf,MAAA;YAAA;cAETlD,QAAQ,CAAC,IAAA0D,kCAAc,EAACK,IAAI,CAAC,CAAC;YAAC;YAAA;cAAA,OAAAE,SAAA,CAAA5B,IAAA;UAAA;QAAA;MAAA,GAAAwB,QAAA;IAAA,CAChC;IAAA,gBAPK7B,iBAAiBA,CAAAkC,GAAA;MAAA,OAAAN,KAAA,CAAArB,KAAA,OAAAC,SAAA;IAAA;EAAA,GAOtB;EAED,IAAMW,QAAQ;IAAA,IAAAgB,KAAA,OAAAjD,kBAAA,CAAAC,OAAA,gBAAAC,YAAA,CAAAD,OAAA,CAAAE,IAAA,CAAG,SAAA+C,SAAAC,KAAA;MAAA,IAAAjB,GAAA,EAAAE,IAAA,EAAAC,IAAA,EAAAe,QAAA,EAAAzB,SAAA;MAAA,OAAAzB,YAAA,CAAAD,OAAA,CAAAK,IAAA,UAAA+C,UAAAC,SAAA;QAAA;UAAA,QAAAA,SAAA,CAAA7C,IAAA,GAAA6C,SAAA,CAAA5C,IAAA;YAAA;cAASwB,GAAG,GAAAiB,KAAA,CAAHjB,GAAG,EAAEE,IAAI,GAAAe,KAAA,CAAJf,IAAI,EAAEC,IAAI,GAAAc,KAAA,CAAJd,IAAI;cAAAiB,SAAA,CAAA5C,IAAA;cAAA,OAChB6C,KAAK,sBAAApB,MAAA,CACLD,GAAG,uBAAAC,MAAA,CAAoB9C,MAAM,0BAAA8C,MAAA,CAAuB/C,gBAAgB,CAC3F,CAAC;YAAA;cAFKgE,QAAQ,GAAAE,SAAA,CAAAhB,IAAA;cAGVX,SAAS,GAAG;gBAAE6B,IAAI,EAAE;cAAG,CAAC;cAAA,KACxBJ,QAAQ,CAACK,EAAE;gBAAAH,SAAA,CAAA5C,IAAA;gBAAA;cAAA;cAAA4C,SAAA,CAAA5C,IAAA;cAAA,OACK0C,QAAQ,CAACM,IAAI,CAAC,CAAC;YAAA;cAAjC/B,SAAS,GAAA2B,SAAA,CAAAhB,IAAA;cAAAgB,SAAA,CAAA5C,IAAA;cAAA;YAAA;cAETiD,OAAO,CAACC,IAAI,oBAAAzB,MAAA,CACSC,IAAI,QAAAD,MAAA,CAAKE,IAAI,iBAChCe,QAAQ,CAACS,MACX,CAAC;YAAC;cAAA,OAAAP,SAAA,CAAAtB,MAAA,WAGGL,SAAS,CAAC6B,IAAI;YAAA;YAAA;cAAA,OAAAF,SAAA,CAAAnC,IAAA;UAAA;QAAA;MAAA,GAAA+B,QAAA;IAAA,CACtB;IAAA,gBAfKjB,QAAQA,CAAA6B,GAAA;MAAA,OAAAb,KAAA,CAAA5B,KAAA,OAAAC,SAAA;IAAA;EAAA,GAeb;;EAED;;EAEA,oBACEpD,MAAA,CAAA+B,OAAA,CAAA8D,aAAA,CAACC,SAAS,qBACR9F,MAAA,CAAA+B,OAAA,CAAA8D,aAAA;IAAKE,SAAS,EAAC;EAAK,GACjBpF,KAAK,CAAC,CAAC,CAAC,KACN,OAAOA,KAAK,CAAC,CAAC,CAAC,KAAK,QAAQ,GAC3BA,KAAK,CAAC,CAAC,CAAC,gBAERX,MAAA,CAAA+B,OAAA,CAAA8D,aAAA,CAAC1F,WAAA,CAAA6F,IAAI;IAACC,EAAE,EAAEtF,KAAK,CAAC,CAAC,CAAC,CAACoC,IAAI,IAAI;EAAI,GAAEpC,KAAK,CAAC,CAAC,CAAC,CAACuF,IAAW,CACtD,CACA,CAAC,EAELvF,KAAK,CAACwF,KAAK,CAAC,CAAC,CAAC,CAACC,GAAG,CAAC,UAACjE,IAAI,EAAEkE,KAAK;IAAA,oBAC9BrG,MAAA,CAAA+B,OAAA,CAAA8D,aAAA,CAAA7F,MAAA,CAAA+B,OAAA,CAAAuE,QAAA,qBACEtG,MAAA,CAAA+B,OAAA,CAAA8D,aAAA,CAACzF,gBAAA,CAAAmG,cAAU;MAACC,GAAG,EAAEH,KAAM;MAACN,SAAS,EAAC,OAAO;MAACU,MAAM,EAAC,KAAK;MAACC,KAAK,EAAC;IAAK,CAAE,CAAC,eACrE1G,MAAA,CAAA+B,OAAA,CAAA8D,aAAA;MAAKE,SAAS,QAAA9B,MAAA,CAAQoC,KAAK,KAAK1F,KAAK,CAACgG,MAAM,GAAG,CAAC,GAAG,OAAO,GAAG,EAAE;IAAG,GAC/D,OAAOxE,IAAI,KAAK,QAAQ,GACvBA,IAAI,gBAEJnC,MAAA,CAAA+B,OAAA,CAAA8D,aAAA,CAAC1F,WAAA,CAAA6F,IAAI;MACHC,EAAE,EAAE9D,IAAI,CAACY,IAAK;MACd6D,OAAO,mBAAA9E,kBAAA,CAAAC,OAAA,gBAAAC,YAAA,CAAAD,OAAA,CAAAE,IAAA,CAAE,SAAA4E,SAAA;QAAA,OAAA7E,YAAA,CAAAD,OAAA,CAAAK,IAAA,UAAA0E,UAAAC,SAAA;UAAA;YAAA,QAAAA,SAAA,CAAAxE,IAAA,GAAAwE,SAAA,CAAAvE,IAAA;cAAA;gBACP,IAAAwE,yBAAc,EAAC,qBAAqB,EAAE;kBACpCd,IAAI,EAAE/D,IAAI,CAAC+D;gBACb,CAAC,CAAC;gBAACa,SAAA,CAAAvE,IAAA;gBAAA,OACGZ,iBAAiB,CAACO,IAAI,CAAC;cAAA;cAAA;gBAAA,OAAA4E,SAAA,CAAA9D,IAAA;YAAA;UAAA;QAAA,GAAA4D,QAAA;MAAA,CAC9B;IAAC,GAED1E,IAAI,CAAC+D,IACF,CAEL,CACL,CAAC;EAAA,CACJ,CACQ,CAAC;AAEhB,CAAC;AAACe,OAAA,CAAAxG,WAAA,GAAAA,WAAA;AAEF,IAAMqF,SAAS,GAAGoB,yBAAM,CAACC,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,mPA4B3B"}
|
package/lib/macros/getVersion.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
var packageJsonVersion = "1.2.371-alpha.
|
|
3
|
+
var packageJsonVersion = "1.2.371-alpha.7";
|
|
4
4
|
if (typeof packageJsonVersion === 'string') {
|
|
5
5
|
// eslint-disable-next-line no-console
|
|
6
6
|
console.log("%c Kando UI %c v".concat(packageJsonVersion, " "), 'font-size: 15px; background-color: #fff; color: #e20f53;', 'font-weight: bold; font-size: 15px; background-color: #e20f53; color: #fff;', "with NODE_ENV=".concat(process.env.NODE_ENV));
|
|
@@ -122,7 +122,7 @@ var List = function List(props) {
|
|
|
122
122
|
});
|
|
123
123
|
dispatch((0, _WWTPDashboardSlice.setFocusedArea)(focusedAreaWithUpdatedSubAreas));
|
|
124
124
|
}
|
|
125
|
-
}, [
|
|
125
|
+
}, [areas_data]);
|
|
126
126
|
(0, _react.useEffect)(function () {
|
|
127
127
|
var _points_data$items;
|
|
128
128
|
if (!focusedArea || !focusedArea.factories || focusedArea.factories.length === 0 || (points_data === null || points_data === void 0 ? void 0 : points_data.isFetching) === true || (points_data === null || points_data === void 0 ? void 0 : (_points_data$items = points_data.items) === null || _points_data$items === void 0 ? void 0 : _points_data$items.length) === 0) return;
|
|
@@ -218,4 +218,4 @@ var ErrorMessage = _styledComponents.default.div.withConfig({
|
|
|
218
218
|
displayName: "List__ErrorMessage",
|
|
219
219
|
componentId: "sc-1f5wz2c-4"
|
|
220
220
|
})(["display:flex;height:100%;font-size:20px;justify-content:center;box-shadow:-0.9px -0.5px 5px 0 rgba(0,0,0,0.06);border:solid 1px #ebebeb;padding:20px;"]);
|
|
221
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_theme","_reactRedux","_utils","_AreaCard","_FactoryCard","_OrganicCard","_interopRequireDefault","_PotentialSaving","_ListContext","_i18n","_DischargePattern","_QualitySummary","_LineChart","_WWTPDashboardSlice","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof3","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","List","props","_WWTPInfo$point","_WWTPInfo$point2","ReduxState","useSelector","state","areas_data","points_data","dispatch","useDispatch","_useSelectedItem","useSelectedItem","selectedItem","handleSelectItem","WWTPInfo","_useSelector","wwtp_dashboard","focusedArea","map","selectedRef","useRef","siteID","point","id","handleItemClick","item","noDataMessage","i18n","t","showedAreas","allArray","sub_areas","sortAreas","filter","Boolean","area_id","area_name","area","top_level","listDetails","useMemo","_focusedArea$sub_area","_focusedArea$sub_area2","is_no_areas","forWWTPMap","undefined","length","has_device","createElement","ListContainer","ErrorMessage","SummaryComponent","endpoint","concat","className","LineChartComponent","title","DischargePattern","Number","AreaCard","object","mapRef","onClick","selected","itemRef","factories","sortPoints","factory","FactoryCard","useEffect","isFetching","subAreasChanged","areasScoreChangedById","newAreas","focusedAreaWithUpdatedSubAreas","_objectSpread2","getUpdatedAreasById","setFocusedArea","_points_data$items","items","getPoints","arr1","arr2","_iterator","_createForOfIteratorHelper2","_step","_loop","item1","value","matchingItem","find","item2","area_score","v","s","n","done","_ret","_typeof2","err","e","f","array1","array2","updatedArray","obj2","some","obj1","_selectedRef$current","current","scrollIntoView","behavior","block","inline","group","type","clicked","WWTPDetails","style","overflow","name","exports","styled","div","withConfig","displayName","componentId","theme","WWTPMap","bg","QualitySummary","LineChart"],"sources":["../../../src/pages/DashboardMap/List.tsx"],"sourcesContent":["import { IArea } from '../../store/areas/models/IArea';\nimport React, { useEffect, useMemo, useRef } from 'react';\nimport styled from 'styled-components/macro';\nimport { theme } from 'src/styles/theme/theme';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { appReducer } from '../../store/rootReducer';\nimport { sortAreas, getPoints, sortPoints } from './utils';\nimport { AreaCard } from './AreaCard';\nimport { FactoryCard } from './FactoryCard';\nimport OrganicCard from '../WwtpPage/OrganicCard';\nimport ImpactCard from '../WwtpPage/PotentialSaving';\nimport { useSelectedItem } from './ListContext';\nimport i18n from 'src/utilities/i18n';\nimport { DischargePattern } from '../SitePage/DischargePattern/DischargePattern';\nimport { QualitySummary } from 'src/Widgets/QualitySummary/QualitySummary';\nimport { LineChart } from 'src/pages/AreaPage/Dashboard/LineChart/LineChart';\nimport { setFocusedArea } from 'src/store/WWTPDashboard/WWTPDashboardSlice';\n\ntype IProps = {\n  global_data: any;\n  WWTPInfo: any;\n};\n\nexport const List: React.FC<IProps> = (props) => {\n  const ReduxState = useSelector((state) => state);\n  const { areas_data, points_data } = ReduxState;\n  const dispatch = useDispatch();\n  const { selectedItem, handleSelectItem } = useSelectedItem();\n  const { WWTPInfo } = props;\n  const { focusedArea, map } = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.wwtp_dashboard,\n  );\n  const selectedRef = useRef(null);\n  const siteID = WWTPInfo.point?.id;\n\n  const handleItemClick = (item) => {\n    handleSelectItem(item);\n  };\n\n  const noDataMessage = i18n.t('wwtpPage.no_data_for_site');\n\n  const showedAreas = (focusedArea) => {\n    let allArray =\n      focusedArea.sub_areas && sortAreas(focusedArea.sub_areas).filter(Boolean);\n\n    if (focusedArea.area_id === null && focusedArea.area_name === '') {\n      allArray = allArray.filter((area) => area.top_level === true);\n    }\n\n    return allArray;\n  };\n\n  const listDetails = useMemo(() => {\n    if (!siteID && !focusedArea) {\n      return;\n    }\n\n    const is_no_areas =\n      focusedArea &&\n      focusedArea?.forWWTPMap === true &&\n      siteID !== undefined &&\n      focusedArea.sub_areas?.length === 0;\n\n    if (is_no_areas) {\n      if (\n        // focusedArea?.clicked === undefined ||\n        focusedArea?.has_device === false ||\n        !siteID\n      ) {\n        return (\n          <ListContainer>\n            <ErrorMessage>{noDataMessage}</ErrorMessage>\n          </ListContainer>\n        );\n      } else {\n        return (\n          <ListContainer>\n            <SummaryComponent\n              endpoint={`/data/events-component-data/${siteID}`}\n              className=\"summary-component\"\n            />\n            <LineChartComponent\n              title={i18n.t('area_dashboard.trend')}\n              endpoint={`/points/${siteID}/trend-graph`}\n            />\n            <DischargePattern siteID={Number(siteID)} />\n          </ListContainer>\n        );\n      }\n    }\n\n    if (focusedArea && focusedArea?.sub_areas?.length > 0) {\n      return showedAreas(focusedArea).map((area: IArea) => (\n        <AreaCard\n          key={area.area_id}\n          object={area}\n          mapRef={map}\n          onClick={() => handleItemClick(area.area_id)}\n          selected={selectedItem === area.area_id}\n          itemRef={selectedItem === area.area_id ? selectedRef : null}\n        />\n      ));\n    } else {\n      if (focusedArea?.factories) {\n        return sortPoints(focusedArea.factories)\n          .filter(Boolean)\n          .map((factory) => (\n            <FactoryCard\n              key={factory.id}\n              object={factory}\n              mapRef={map}\n              onClick={() => handleItemClick(factory.id)}\n              selected={selectedItem === factory.id}\n              itemRef={selectedItem === factory.id ? selectedRef : null}\n            />\n          ));\n      }\n    }\n  }, [selectedItem, focusedArea]);\n\n  // Update the list only if the score of at least one of the sub-areas has changed\n  useEffect(() => {\n    if (\n      focusedArea &&\n      focusedArea.sub_areas &&\n      focusedArea.sub_areas.length > 0 &&\n      areas_data?.isFetching === false\n    ) {\n      const subAreasChanged = areasScoreChangedById(\n        focusedArea.sub_areas,\n        areas_data.newAreas,\n      );\n      if (!subAreasChanged) return;\n\n      const focusedAreaWithUpdatedSubAreas = {\n        ...focusedArea,\n        sub_areas: getUpdatedAreasById(\n          focusedArea.sub_areas,\n          areas_data.newAreas,\n        ),\n      };\n      dispatch(setFocusedArea(focusedAreaWithUpdatedSubAreas));\n    }\n  }, [selectedItem, areas_data]);\n\n  useEffect(() => {\n    if (\n      !focusedArea ||\n      !focusedArea.factories ||\n      focusedArea.factories.length === 0 ||\n      points_data?.isFetching === true ||\n      points_data?.items?.length === 0\n    )\n      return;\n\n    dispatch(\n      setFocusedArea({\n        ...focusedArea,\n        factories: getPoints(focusedArea?.factories, points_data.items),\n      }),\n    );\n  }, [points_data]);\n\n  const areasScoreChangedById = (arr1, arr2) => {\n    // go over the 1st array\n    for (let item1 of arr1) {\n      // Find the object with the same id in the second array\n      let matchingItem = arr2.find((item2) => item2.area_id === item1.area_id);\n\n      // Return true if one matching item is found in the second array and their scores changed\n      if (matchingItem && item1.area_score !== matchingItem.area_score) {\n        return true;\n      }\n    }\n\n    // If all items matched and had the same score, return false\n    return false;\n  };\n\n  const getUpdatedAreasById = (array1, array2) => {\n    const updatedArray = array2.filter((obj2) =>\n      array1.some((obj1) => obj1.area_id === obj2.area_id),\n    );\n\n    return updatedArray?.length > 0 ? updatedArray : array1;\n  };\n\n  useEffect(() => {\n    selectedRef.current?.scrollIntoView({\n      behavior: 'smooth',\n      block: 'center',\n      inline: 'center',\n    });\n  }, [selectedItem]);\n\n  if (\n    focusedArea?.group &&\n    focusedArea.group.type === 'Groups::WastewaterTreatmentPlant' &&\n    focusedArea?.clicked === undefined\n  )\n    return (\n      <WWTPDetails className=\"p-3\" style={{ overflow: 'scroll' }}>\n        <h3>{WWTPInfo.point?.name}</h3>\n        <div className={'h-auto my-4'}>\n          <OrganicCard />\n        </div>\n        <div className={'h-auto mt-2'}>\n          <ImpactCard />\n        </div>\n      </WWTPDetails>\n    );\n\n  return (\n    <WWTPDetails className=\"p-3\" style={{ overflow: 'scroll' }}>\n      <h3>{focusedArea?.area_name || focusedArea?.name}</h3>\n      <ul className={'mx-n3'}>{listDetails}</ul>\n    </WWTPDetails>\n  );\n};\n\nconst WWTPDetails = styled.div`\n  width: 100%;\n  height: calc(100vh - 134px);\n  background: ${theme.WWTPMap.bg};\n`;\n\nconst SummaryComponent = styled(QualitySummary)`\n  grid-area: summary;\n\n  summary-component {\n    background-color: blue;\n  }\n`;\n\nconst LineChartComponent = styled(LineChart)`\n  grid-area: graph;\n`;\n\nconst ListContainer = styled.div`\n  display: flex;\n  flex-direction: column;\n  justify-content: space-between;\n  height: 100%;\n  padding: 20px;\n  gap: 30px;\n`;\n\nconst ErrorMessage = styled.div`\n  display: flex;\n  height: 100%;\n  font-size: 20px;\n  justify-content: center;\n  box-shadow: -0.9px -0.5px 5px 0 rgba(0, 0, 0, 0.06);\n  border: solid 1px #ebebeb;\n  padding: 20px;\n`;\n"],"mappings":"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"}
|
|
221
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_theme","_reactRedux","_utils","_AreaCard","_FactoryCard","_OrganicCard","_interopRequireDefault","_PotentialSaving","_ListContext","_i18n","_DischargePattern","_QualitySummary","_LineChart","_WWTPDashboardSlice","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof3","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","List","props","_WWTPInfo$point","_WWTPInfo$point2","ReduxState","useSelector","state","areas_data","points_data","dispatch","useDispatch","_useSelectedItem","useSelectedItem","selectedItem","handleSelectItem","WWTPInfo","_useSelector","wwtp_dashboard","focusedArea","map","selectedRef","useRef","siteID","point","id","handleItemClick","item","noDataMessage","i18n","t","showedAreas","allArray","sub_areas","sortAreas","filter","Boolean","area_id","area_name","area","top_level","listDetails","useMemo","_focusedArea$sub_area","_focusedArea$sub_area2","is_no_areas","forWWTPMap","undefined","length","has_device","createElement","ListContainer","ErrorMessage","SummaryComponent","endpoint","concat","className","LineChartComponent","title","DischargePattern","Number","AreaCard","object","mapRef","onClick","selected","itemRef","factories","sortPoints","factory","FactoryCard","useEffect","isFetching","subAreasChanged","areasScoreChangedById","newAreas","focusedAreaWithUpdatedSubAreas","_objectSpread2","getUpdatedAreasById","setFocusedArea","_points_data$items","items","getPoints","arr1","arr2","_iterator","_createForOfIteratorHelper2","_step","_loop","item1","value","matchingItem","find","item2","area_score","v","s","n","done","_ret","_typeof2","err","e","f","array1","array2","updatedArray","obj2","some","obj1","_selectedRef$current","current","scrollIntoView","behavior","block","inline","group","type","clicked","WWTPDetails","style","overflow","name","exports","styled","div","withConfig","displayName","componentId","theme","WWTPMap","bg","QualitySummary","LineChart"],"sources":["../../../src/pages/DashboardMap/List.tsx"],"sourcesContent":["import { IArea } from '../../store/areas/models/IArea';\nimport React, { useEffect, useMemo, useRef } from 'react';\nimport styled from 'styled-components/macro';\nimport { theme } from 'src/styles/theme/theme';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { appReducer } from '../../store/rootReducer';\nimport { sortAreas, getPoints, sortPoints } from './utils';\nimport { AreaCard } from './AreaCard';\nimport { FactoryCard } from './FactoryCard';\nimport OrganicCard from '../WwtpPage/OrganicCard';\nimport ImpactCard from '../WwtpPage/PotentialSaving';\nimport { useSelectedItem } from './ListContext';\nimport i18n from 'src/utilities/i18n';\nimport { DischargePattern } from '../SitePage/DischargePattern/DischargePattern';\nimport { QualitySummary } from 'src/Widgets/QualitySummary/QualitySummary';\nimport { LineChart } from 'src/pages/AreaPage/Dashboard/LineChart/LineChart';\nimport { setFocusedArea } from 'src/store/WWTPDashboard/WWTPDashboardSlice';\n\ntype IProps = {\n  global_data: any;\n  WWTPInfo: any;\n};\n\nexport const List: React.FC<IProps> = (props) => {\n  const ReduxState = useSelector((state) => state);\n  const { areas_data, points_data } = ReduxState;\n  const dispatch = useDispatch();\n  const { selectedItem, handleSelectItem } = useSelectedItem();\n  const { WWTPInfo } = props;\n  const { focusedArea, map } = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.wwtp_dashboard,\n  );\n  const selectedRef = useRef(null);\n  const siteID = WWTPInfo.point?.id;\n\n  const handleItemClick = (item) => {\n    handleSelectItem(item);\n  };\n\n  const noDataMessage = i18n.t('wwtpPage.no_data_for_site');\n\n  const showedAreas = (focusedArea) => {\n    let allArray =\n      focusedArea.sub_areas && sortAreas(focusedArea.sub_areas).filter(Boolean);\n\n    if (focusedArea.area_id === null && focusedArea.area_name === '') {\n      allArray = allArray.filter((area) => area.top_level === true);\n    }\n\n    return allArray;\n  };\n\n  const listDetails = useMemo(() => {\n    if (!siteID && !focusedArea) {\n      return;\n    }\n\n    const is_no_areas =\n      focusedArea &&\n      focusedArea?.forWWTPMap === true &&\n      siteID !== undefined &&\n      focusedArea.sub_areas?.length === 0;\n\n    if (is_no_areas) {\n      if (\n        // focusedArea?.clicked === undefined ||\n        focusedArea?.has_device === false ||\n        !siteID\n      ) {\n        return (\n          <ListContainer>\n            <ErrorMessage>{noDataMessage}</ErrorMessage>\n          </ListContainer>\n        );\n      } else {\n        return (\n          <ListContainer>\n            <SummaryComponent\n              endpoint={`/data/events-component-data/${siteID}`}\n              className=\"summary-component\"\n            />\n            <LineChartComponent\n              title={i18n.t('area_dashboard.trend')}\n              endpoint={`/points/${siteID}/trend-graph`}\n            />\n            <DischargePattern siteID={Number(siteID)} />\n          </ListContainer>\n        );\n      }\n    }\n\n    if (focusedArea && focusedArea?.sub_areas?.length > 0) {\n      return showedAreas(focusedArea).map((area: IArea) => (\n        <AreaCard\n          key={area.area_id}\n          object={area}\n          mapRef={map}\n          onClick={() => handleItemClick(area.area_id)}\n          selected={selectedItem === area.area_id}\n          itemRef={selectedItem === area.area_id ? selectedRef : null}\n        />\n      ));\n    } else {\n      if (focusedArea?.factories) {\n        return sortPoints(focusedArea.factories)\n          .filter(Boolean)\n          .map((factory) => (\n            <FactoryCard\n              key={factory.id}\n              object={factory}\n              mapRef={map}\n              onClick={() => handleItemClick(factory.id)}\n              selected={selectedItem === factory.id}\n              itemRef={selectedItem === factory.id ? selectedRef : null}\n            />\n          ));\n      }\n    }\n  }, [selectedItem, focusedArea]);\n\n  // Update the list only if the score of at least one of the sub-areas has changed\n  useEffect(() => {\n    if (\n      focusedArea &&\n      focusedArea.sub_areas &&\n      focusedArea.sub_areas.length > 0 &&\n      areas_data?.isFetching === false\n    ) {\n      const subAreasChanged = areasScoreChangedById(\n        focusedArea.sub_areas,\n        areas_data.newAreas,\n      );\n      if (!subAreasChanged) return;\n\n      const focusedAreaWithUpdatedSubAreas = {\n        ...focusedArea,\n        sub_areas: getUpdatedAreasById(\n          focusedArea.sub_areas,\n          areas_data.newAreas,\n        ),\n      };\n      dispatch(setFocusedArea(focusedAreaWithUpdatedSubAreas));\n    }\n  }, [areas_data]);\n\n  useEffect(() => {\n    if (\n      !focusedArea ||\n      !focusedArea.factories ||\n      focusedArea.factories.length === 0 ||\n      points_data?.isFetching === true ||\n      points_data?.items?.length === 0\n    )\n      return;\n\n    dispatch(\n      setFocusedArea({\n        ...focusedArea,\n        factories: getPoints(focusedArea?.factories, points_data.items),\n      }),\n    );\n  }, [points_data]);\n\n  const areasScoreChangedById = (arr1, arr2) => {\n    // go over the 1st array\n    for (let item1 of arr1) {\n      // Find the object with the same id in the second array\n      let matchingItem = arr2.find((item2) => item2.area_id === item1.area_id);\n\n      // Return true if one matching item is found in the second array and their scores changed\n      if (matchingItem && item1.area_score !== matchingItem.area_score) {\n        return true;\n      }\n    }\n\n    // If all items matched and had the same score, return false\n    return false;\n  };\n\n  const getUpdatedAreasById = (array1, array2) => {\n    const updatedArray = array2.filter((obj2) =>\n      array1.some((obj1) => obj1.area_id === obj2.area_id),\n    );\n\n    return updatedArray?.length > 0 ? updatedArray : array1;\n  };\n\n  useEffect(() => {\n    selectedRef.current?.scrollIntoView({\n      behavior: 'smooth',\n      block: 'center',\n      inline: 'center',\n    });\n  }, [selectedItem]);\n\n  if (\n    focusedArea?.group &&\n    focusedArea.group.type === 'Groups::WastewaterTreatmentPlant' &&\n    focusedArea?.clicked === undefined\n  )\n    return (\n      <WWTPDetails className=\"p-3\" style={{ overflow: 'scroll' }}>\n        <h3>{WWTPInfo.point?.name}</h3>\n        <div className={'h-auto my-4'}>\n          <OrganicCard />\n        </div>\n        <div className={'h-auto mt-2'}>\n          <ImpactCard />\n        </div>\n      </WWTPDetails>\n    );\n\n  return (\n    <WWTPDetails className=\"p-3\" style={{ overflow: 'scroll' }}>\n      <h3>{focusedArea?.area_name || focusedArea?.name}</h3>\n      <ul className={'mx-n3'}>{listDetails}</ul>\n    </WWTPDetails>\n  );\n};\n\nconst WWTPDetails = styled.div`\n  width: 100%;\n  height: calc(100vh - 134px);\n  background: ${theme.WWTPMap.bg};\n`;\n\nconst SummaryComponent = styled(QualitySummary)`\n  grid-area: summary;\n\n  summary-component {\n    background-color: blue;\n  }\n`;\n\nconst LineChartComponent = styled(LineChart)`\n  grid-area: graph;\n`;\n\nconst ListContainer = styled.div`\n  display: flex;\n  flex-direction: column;\n  justify-content: space-between;\n  height: 100%;\n  padding: 20px;\n  gap: 30px;\n`;\n\nconst ErrorMessage = styled.div`\n  display: flex;\n  height: 100%;\n  font-size: 20px;\n  justify-content: center;\n  box-shadow: -0.9px -0.5px 5px 0 rgba(0, 0, 0, 0.06);\n  border: solid 1px #ebebeb;\n  padding: 20px;\n`;\n"],"mappings":"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"}
|