@kando-env/kando-ui 1.2.458-alpha.15 → 1.2.458-alpha.17
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/Widgets/MostPolluting/Factories/FactoryBox/CardLayout.js +21 -6
- package/lib/components/Header/InfoBar/Search/SearchContainer.js +4 -3
- package/lib/i18n/en.json +1 -0
- package/lib/macros/getVersion.js +1 -1
- package/lib/pages/EventsPage/events/events_list/Filter/Filter.js +13 -3
- package/lib/pages/EventsPage/events/events_list/Filter/FilterContainer.js +27 -7
- package/lib/pages/EventsPage/events/events_list/Filter/FilterStyle.scss +15 -0
- package/lib/ui-kit/HierarchyGraph/AutoFitTree.js +9 -2
- package/lib/ui-kit/HierarchyGraph/HierarchyGraph.js +25 -13
- package/lib/ui-kit/HierarchyGraph/NodeLayout.js +15 -13
- package/lib/ui-kit/HierarchyGraph/style.scss +57 -31
- package/lib/ui-kit/HierarchyGraph/utils.js +1 -1
- package/package.json +1 -1
|
@@ -9,6 +9,7 @@ var _styledComponents = _interopRequireDefault(require("styled-components"));
|
|
|
9
9
|
var _react = _interopRequireDefault(require("react"));
|
|
10
10
|
var _styles = require("./styles");
|
|
11
11
|
var _Truncate = _interopRequireDefault(require("../../../../utilities/Truncate"));
|
|
12
|
+
var _StyledLink = require("../../../../components/Links/StyledLink/StyledLink");
|
|
12
13
|
var KdPercentStyle = _styledComponents.default.div.withConfig({
|
|
13
14
|
displayName: "CardLayout__KdPercentStyle",
|
|
14
15
|
componentId: "sc-9gxpm8-0"
|
|
@@ -16,11 +17,19 @@ var KdPercentStyle = _styledComponents.default.div.withConfig({
|
|
|
16
17
|
return props.width;
|
|
17
18
|
});
|
|
18
19
|
exports.KdPercentStyle = KdPercentStyle;
|
|
20
|
+
var Header = function Header(titleText) {
|
|
21
|
+
return /*#__PURE__*/_react.default.createElement(_Truncate.default, {
|
|
22
|
+
characters: 0,
|
|
23
|
+
inheritTextAlign: true
|
|
24
|
+
}, /*#__PURE__*/_react.default.createElement("span", null, titleText));
|
|
25
|
+
};
|
|
19
26
|
var CardLayout = function CardLayout(_ref) {
|
|
20
27
|
var style = _ref.style,
|
|
21
28
|
title = _ref.title,
|
|
22
29
|
children = _ref.children,
|
|
23
|
-
headerRight = _ref.headerRight
|
|
30
|
+
headerRight = _ref.headerRight,
|
|
31
|
+
_ref$linkedHeaderUrl = _ref.linkedHeaderUrl,
|
|
32
|
+
linkedHeaderUrl = _ref$linkedHeaderUrl === void 0 ? '' : _ref$linkedHeaderUrl;
|
|
24
33
|
return /*#__PURE__*/_react.default.createElement(_styles.Box, {
|
|
25
34
|
style: style
|
|
26
35
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
@@ -29,13 +38,19 @@ var CardLayout = function CardLayout(_ref) {
|
|
|
29
38
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
30
39
|
className: "title",
|
|
31
40
|
"data-text": title
|
|
32
|
-
}, /*#__PURE__*/_react.default.createElement(
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
41
|
+
}, linkedHeaderUrl ? /*#__PURE__*/_react.default.createElement(_StyledLink.StyledLink, {
|
|
42
|
+
target: "_blank",
|
|
43
|
+
updateParams: {
|
|
44
|
+
view: 'dashboard'
|
|
45
|
+
},
|
|
46
|
+
to: linkedHeaderUrl,
|
|
47
|
+
onClick: function onClick(e) {
|
|
48
|
+
return e.stopPropagation();
|
|
49
|
+
}
|
|
50
|
+
}, Header(title)) : Header(title)), headerRight), /*#__PURE__*/_react.default.createElement("div", {
|
|
36
51
|
className: "content"
|
|
37
52
|
}, children));
|
|
38
53
|
};
|
|
39
54
|
var _default = CardLayout;
|
|
40
55
|
exports.default = _default;
|
|
41
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
56
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9zdHlsZXMiLCJfVHJ1bmNhdGUiLCJfU3R5bGVkTGluayIsIktkUGVyY2VudFN0eWxlIiwic3R5bGVkIiwiZGl2Iiwid2l0aENvbmZpZyIsImRpc3BsYXlOYW1lIiwiY29tcG9uZW50SWQiLCJwcm9wcyIsIndpZHRoIiwiZXhwb3J0cyIsIkhlYWRlciIsInRpdGxlVGV4dCIsImRlZmF1bHQiLCJjcmVhdGVFbGVtZW50IiwiY2hhcmFjdGVycyIsImluaGVyaXRUZXh0QWxpZ24iLCJDYXJkTGF5b3V0IiwiX3JlZiIsInN0eWxlIiwidGl0bGUiLCJjaGlsZHJlbiIsImhlYWRlclJpZ2h0IiwiX3JlZiRsaW5rZWRIZWFkZXJVcmwiLCJsaW5rZWRIZWFkZXJVcmwiLCJCb3giLCJjbGFzc05hbWUiLCJTdHlsZWRMaW5rIiwidGFyZ2V0IiwidXBkYXRlUGFyYW1zIiwidmlldyIsInRvIiwib25DbGljayIsImUiLCJzdG9wUHJvcGFnYXRpb24iLCJfZGVmYXVsdCJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9XaWRnZXRzL01vc3RQb2xsdXRpbmcvRmFjdG9yaWVzL0ZhY3RvcnlCb3gvQ2FyZExheW91dC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnc3R5bGVkLWNvbXBvbmVudHMvbWFjcm8nO1xuaW1wb3J0IHsgQm94IH0gZnJvbSAnLi9zdHlsZXMnO1xuaW1wb3J0IFRydW5jYXRlIGZyb20gJy4uLy4uLy4uLy4uL3V0aWxpdGllcy9UcnVuY2F0ZSc7XG5pbXBvcnQgeyBTdHlsZWRMaW5rIH0gZnJvbSAnLi4vLi4vLi4vLi4vY29tcG9uZW50cy9MaW5rcy9TdHlsZWRMaW5rL1N0eWxlZExpbmsnO1xuXG5leHBvcnQgY29uc3QgS2RQZXJjZW50U3R5bGUgPSBzdHlsZWQuZGl2PHsgd2lkdGg6IHN0cmluZyB9PmBcbiAgZm9udC1zaXplOiAxNHB4O1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG4gIHdpZHRoOiAkeyhwcm9wcykgPT4gcHJvcHMud2lkdGh9O1xuICAuc2NvcmUge1xuICAgIGZvbnQtd2VpZ2h0OiA2MDA7XG4gIH1cbmA7XG5cbnR5cGUgRmFjdG9yeUNhcmRQcm9wcyA9IHtcbiAgc3R5bGU/OiBSZWFjdC5DU1NQcm9wZXJ0aWVzO1xuICB0aXRsZTogc3RyaW5nO1xuICBjaGlsZHJlbj86IFJlYWN0LlJlYWN0Tm9kZTtcbiAgaGVhZGVyUmlnaHQ/OiBSZWFjdC5SZWFjdE5vZGU7XG4gIGxpbmtlZEhlYWRlclVybD86IHN0cmluZztcbn07XG5cbmNvbnN0IEhlYWRlciA9ICh0aXRsZVRleHQpID0+IHtcbiAgcmV0dXJuIChcbiAgICA8VHJ1bmNhdGUgY2hhcmFjdGVycz17MH0gaW5oZXJpdFRleHRBbGlnbj17dHJ1ZX0+XG4gICAgICA8c3Bhbj57dGl0bGVUZXh0fTwvc3Bhbj5cbiAgICA8L1RydW5jYXRlPlxuICApO1xufTtcbmNvbnN0IENhcmRMYXlvdXQgPSAoe1xuICBzdHlsZSxcbiAgdGl0bGUsXG4gIGNoaWxkcmVuLFxuICBoZWFkZXJSaWdodCxcbiAgbGlua2VkSGVhZGVyVXJsID0gJycsXG59OiBGYWN0b3J5Q2FyZFByb3BzKSA9PiB7XG4gIHJldHVybiAoXG4gICAgPEJveCBzdHlsZT17c3R5bGV9PlxuICAgICAgPGRpdiBjbGFzc05hbWU9e2B0b3BgfSBkYXRhLXRleHQ9e3RpdGxlfT5cbiAgICAgICAgPGRpdiBjbGFzc05hbWU9XCJ0aXRsZVwiIGRhdGEtdGV4dD17dGl0bGV9PlxuICAgICAgICAgIHtsaW5rZWRIZWFkZXJVcmwgPyAoXG4gICAgICAgICAgICA8U3R5bGVkTGlua1xuICAgICAgICAgICAgICB0YXJnZXQ9XCJfYmxhbmtcIlxuICAgICAgICAgICAgICB1cGRhdGVQYXJhbXM9e3sgdmlldzogJ2Rhc2hib2FyZCcgfX1cbiAgICAgICAgICAgICAgdG89e2xpbmtlZEhlYWRlclVybH1cbiAgICAgICAgICAgICAgb25DbGljaz17KGUpID0+IGUuc3RvcFByb3BhZ2F0aW9uKCl9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtIZWFkZXIodGl0bGUpfVxuICAgICAgICAgICAgPC9TdHlsZWRMaW5rPlxuICAgICAgICAgICkgOiAoXG4gICAgICAgICAgICBIZWFkZXIodGl0bGUpXG4gICAgICAgICAgKX1cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIHtoZWFkZXJSaWdodH1cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdiBjbGFzc05hbWU9XCJjb250ZW50XCI+e2NoaWxkcmVufTwvZGl2PlxuICAgIDwvQm94PlxuICApO1xufTtcbmV4cG9ydCBkZWZhdWx0IENhcmRMYXlvdXQ7XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBQUEsSUFBQUEsTUFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBRUEsSUFBQUMsT0FBQSxHQUFBRCxPQUFBO0FBQ0EsSUFBQUUsU0FBQSxHQUFBSCxzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUcsV0FBQSxHQUFBSCxPQUFBO0FBRU8sSUFBTUksY0FBYyxHQUFHQyx5QkFBTSxDQUFDQyxHQUFHLENBQUFDLFVBQUE7RUFBQUMsV0FBQTtFQUFBQyxXQUFBO0FBQUEsNEhBSzdCLFVBQUNDLEtBQUs7RUFBQSxPQUFLQSxLQUFLLENBQUNDLEtBQUs7QUFBQSxFQUloQztBQUFDQyxPQUFBLENBQUFSLGNBQUEsR0FBQUEsY0FBQTtBQVVGLElBQU1TLE1BQU0sR0FBRyxTQUFUQSxNQUFNQSxDQUFJQyxTQUFTLEVBQUs7RUFDNUIsb0JBQ0VoQixNQUFBLENBQUFpQixPQUFBLENBQUFDLGFBQUEsQ0FBQ2QsU0FBQSxDQUFBYSxPQUFRO0lBQUNFLFVBQVUsRUFBRSxDQUFFO0lBQUNDLGdCQUFnQixFQUFFO0VBQUssZ0JBQzlDcEIsTUFBQSxDQUFBaUIsT0FBQSxDQUFBQyxhQUFBLGVBQU9GLFNBQWdCLENBQ2YsQ0FBQztBQUVmLENBQUM7QUFDRCxJQUFNSyxVQUFVLEdBQUcsU0FBYkEsVUFBVUEsQ0FBQUMsSUFBQSxFQU1RO0VBQUEsSUFMdEJDLEtBQUssR0FBQUQsSUFBQSxDQUFMQyxLQUFLO0lBQ0xDLEtBQUssR0FBQUYsSUFBQSxDQUFMRSxLQUFLO0lBQ0xDLFFBQVEsR0FBQUgsSUFBQSxDQUFSRyxRQUFRO0lBQ1JDLFdBQVcsR0FBQUosSUFBQSxDQUFYSSxXQUFXO0lBQUFDLG9CQUFBLEdBQUFMLElBQUEsQ0FDWE0sZUFBZTtJQUFmQSxlQUFlLEdBQUFELG9CQUFBLGNBQUcsRUFBRSxHQUFBQSxvQkFBQTtFQUVwQixvQkFDRTNCLE1BQUEsQ0FBQWlCLE9BQUEsQ0FBQUMsYUFBQSxDQUFDZixPQUFBLENBQUEwQixHQUFHO0lBQUNOLEtBQUssRUFBRUE7RUFBTSxnQkFDaEJ2QixNQUFBLENBQUFpQixPQUFBLENBQUFDLGFBQUE7SUFBS1ksU0FBUyxPQUFRO0lBQUMsYUFBV047RUFBTSxnQkFDdEN4QixNQUFBLENBQUFpQixPQUFBLENBQUFDLGFBQUE7SUFBS1ksU0FBUyxFQUFDLE9BQU87SUFBQyxhQUFXTjtFQUFNLEdBQ3JDSSxlQUFlLGdCQUNkNUIsTUFBQSxDQUFBaUIsT0FBQSxDQUFBQyxhQUFBLENBQUNiLFdBQUEsQ0FBQTBCLFVBQVU7SUFDVEMsTUFBTSxFQUFDLFFBQVE7SUFDZkMsWUFBWSxFQUFFO01BQUVDLElBQUksRUFBRTtJQUFZLENBQUU7SUFDcENDLEVBQUUsRUFBRVAsZUFBZ0I7SUFDcEJRLE9BQU8sRUFBRSxTQUFBQSxRQUFDQyxDQUFDO01BQUEsT0FBS0EsQ0FBQyxDQUFDQyxlQUFlLENBQUMsQ0FBQztJQUFBO0VBQUMsR0FFbkN2QixNQUFNLENBQUNTLEtBQUssQ0FDSCxDQUFDLEdBRWJULE1BQU0sQ0FBQ1MsS0FBSyxDQUVYLENBQUMsRUFDTEUsV0FDRSxDQUFDLGVBQ04xQixNQUFBLENBQUFpQixPQUFBLENBQUFDLGFBQUE7SUFBS1ksU0FBUyxFQUFDO0VBQVMsR0FBRUwsUUFBYyxDQUNyQyxDQUFDO0FBRVYsQ0FBQztBQUFDLElBQUFjLFFBQUEsR0FDYWxCLFVBQVU7QUFBQVAsT0FBQSxDQUFBRyxPQUFBLEdBQUFzQixRQUFBIn0=
|
|
@@ -38,8 +38,9 @@ var SearchContainer = function SearchContainer() {
|
|
|
38
38
|
waterAuthorityName = _useSelector.waterAuthorityName;
|
|
39
39
|
var getViewMode = function getViewMode() {
|
|
40
40
|
var params = new URLSearchParams(location.search);
|
|
41
|
-
var viewParam = params.get('view');
|
|
42
|
-
|
|
41
|
+
var viewParam = params.get('view') || '';
|
|
42
|
+
var availableViews = ['map', 'hierarchy'];
|
|
43
|
+
return availableViews.includes(viewParam) ? viewParam : 'dashboard';
|
|
43
44
|
};
|
|
44
45
|
var handleChange = function handleChange(selected) {
|
|
45
46
|
if (!selected) {
|
|
@@ -62,4 +63,4 @@ var SearchContainer = function SearchContainer() {
|
|
|
62
63
|
};
|
|
63
64
|
var _default = /*#__PURE__*/_react.default.memo(SearchContainer);
|
|
64
65
|
exports.default = _default;
|
|
65
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
66
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRedux","_reactRouterDom","_Search","_interopRequireDefault","_Analytics","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","fetchData","url","setData","fetch","then","response","json","result","SearchContainer","_useState","useState","_useState2","_slicedToArray2","data","history","useHistory","location","useLocation","navContext","useSelector","state","nav_context_data","_useSelector","global_data","waterAuthorityId","waterAuthorityName","getViewMode","params","URLSearchParams","search","viewParam","availableViews","includes","handleChange","selected","analyticsTrack","selection","label","utility_name","push","concat","sub_type","id","locale","useEffect","createElement","Fragment","onChange","options","viewMode","_default","React","memo","exports"],"sources":["../../../../../src/components/Header/InfoBar/Search/SearchContainer.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react';\nimport { useSelector } from 'react-redux';\nimport { useHistory, useLocation } from 'react-router-dom';\n\nimport { appReducer } from 'src/store/rootReducer';\nimport Search from './Search';\nimport { analyticsTrack } from 'src/utilities/Analytics';\n\nconst fetchData = (url: string, setData: Function) => {\n  fetch(url)\n    .then((response) => response.json())\n    .then((result) => setData(result));\n};\n\nconst SearchContainer = () => {\n  const [data, setData] = useState<any>(null);\n  const history = useHistory();\n  const location = useLocation();\n  const navContext = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.nav_context_data.navContext,\n  );\n\n  const { waterAuthorityId, waterAuthorityName } = useSelector(\n    (state) => state.global_data,\n  );\n\n  const getViewMode = () => {\n    const params = new URLSearchParams(location.search);\n    const viewParam = params.get('view') || '';\n    const availableViews = ['map', 'hierarchy'];\n    return availableViews.includes(viewParam) ? viewParam : 'dashboard';\n  };\n\n  const handleChange = (selected: any) => {\n    if (!selected) {\n      return;\n    }\n\n    analyticsTrack('Clicked dashboard search', {\n      selection: selected.label,\n      utility_name: waterAuthorityName,\n    });\n\n    history.push(\n      `/dashboard_v2/${selected.sub_type}/${\n        selected.id\n      }?water_authority_id=${waterAuthorityId}&locale=${\n        navContext.locale\n      }&view=${getViewMode()}`,\n    );\n  };\n\n  useEffect(() => {\n    fetchData(`/data/search?water_authority_id=${waterAuthorityId}`, setData);\n  }, [waterAuthorityId]);\n\n  return (\n    <>\n      {data && (\n        <Search\n          onChange={handleChange}\n          options={data}\n          viewMode={getViewMode()}\n        />\n      )}\n    </>\n  );\n};\n\nexport default React.memo(SearchContainer);\n"],"mappings":"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"}
|
package/lib/i18n/en.json
CHANGED
package/lib/macros/getVersion.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
var packageJsonVersion = "1.2.458-alpha.
|
|
3
|
+
var packageJsonVersion = "1.2.458-alpha.17";
|
|
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));
|
|
@@ -21,7 +21,8 @@ var Filter = function Filter(props) {
|
|
|
21
21
|
setActiveFilterCopy = props.setActiveFilterCopy,
|
|
22
22
|
parseSelectedItems = props.parseSelectedItems,
|
|
23
23
|
availableFilterItems = props.availableFilterItems,
|
|
24
|
-
applyFilter = props.applyFilter
|
|
24
|
+
applyFilter = props.applyFilter,
|
|
25
|
+
resetFilter = props.resetFilter;
|
|
25
26
|
var _useState = (0, _react.useState)({
|
|
26
27
|
filterItemId: null,
|
|
27
28
|
show: false
|
|
@@ -113,8 +114,17 @@ var Filter = function Filter(props) {
|
|
|
113
114
|
onClick: function onClick() {
|
|
114
115
|
handleApplyFilter();
|
|
115
116
|
}
|
|
116
|
-
}, _i18n.default.t('events_overview.filter.apply'))))
|
|
117
|
+
}, _i18n.default.t('events_overview.filter.apply')))), resetFilter && /*#__PURE__*/_react.default.createElement("li", {
|
|
118
|
+
className: 'fixed-action'
|
|
119
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
120
|
+
className: 'reset-button-container'
|
|
121
|
+
}, /*#__PURE__*/_react.default.createElement("a", {
|
|
122
|
+
className: 'reset-button',
|
|
123
|
+
onClick: function onClick() {
|
|
124
|
+
resetFilter();
|
|
125
|
+
}
|
|
126
|
+
}, _i18n.default.t('events_overview.filter.reset'))))));
|
|
117
127
|
};
|
|
118
128
|
var _default = Filter;
|
|
119
129
|
exports.default = _default;
|
|
120
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["require","_react","_interopRequireWildcard","_Dropdown","_interopRequireDefault","_add","_i18n","_FilterItem","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","Filter","props","activeFilterCopy","setActiveFilterCopy","parseSelectedItems","availableFilterItems","applyFilter","_useState","useState","filterItemId","show","_useState2","_slicedToArray2","showFilterItemOptionsPopup","setShowFilterItemOptionsPopup","camelToSnakeCase","str","toLowerCase","slice","length","replace","letter","concat","translateFilterItemType","filterItemType","i18n","t","buildUnselectedItems","filter_item","filter_items","undefined","find","selected_item","type","createElement","Item","href","onClick","addFilterItem","filterItem","push","id","max_selected_items","filter_id","available_options","options","selected_options","activeFilterDuplicate","assign","handleApplyFilter","useEffect","className","map","Toggle","variant","ReactComponent","height","width","Menu","_default","exports"],"sources":["../../../../../../src/pages/EventsPage/events/events_list/Filter/Filter.tsx"],"sourcesContent":["import '@kenshooui/react-multi-select/dist/style.css';\nimport React, { useEffect, useState } from 'react';\nimport Dropdown from 'react-bootstrap/Dropdown';\nimport { ReactComponent as PlusIcon } from 'src/assets/icons/add.svg';\nimport { IFilterItem } from 'src/store/filters/IFilterItem';\nimport i18n from 'src/utilities/i18n';\nimport '../../EventsStyle.scss';\nimport FilterItem from './FilterItem';\n\ntype IProps = {\n  activeFilterCopy: any;\n  setActiveFilterCopy: React.Dispatch<any>;\n  parseSelectedItems: any;\n  availableFilterItems: any;\n  applyFilter: any;\n};\n\nconst Filter: React.FC<IProps> = (props) => {\n  const {\n    activeFilterCopy,\n    setActiveFilterCopy,\n    parseSelectedItems,\n    availableFilterItems,\n    applyFilter,\n  } = props;\n  const [showFilterItemOptionsPopup, setShowFilterItemOptionsPopup] = useState({\n    filterItemId: null,\n    show: false,\n  });\n  const camelToSnakeCase = (str: string) =>\n    str[0].toLowerCase() +\n    str\n      .slice(1, str.length)\n      .replace(/[A-Z]/g, (letter) => `_${letter.toLowerCase()}`);\n  const translateFilterItemType = (filterItemType: string) => {\n    return i18n.t(\n      `events_overview.filter.filter_types.${camelToSnakeCase(filterItemType)}`,\n    );\n  };\n  const buildUnselectedItems = (filter_item: IFilterItem) => {\n    if (\n      activeFilterCopy.filter_items !== undefined &&\n      activeFilterCopy.filter_items.find(\n        (selected_item: IFilterItem) => selected_item.type === filter_item.type,\n      ) === undefined\n    ) {\n      return (\n        <Dropdown.Item\n          href=\"#\"\n          key={filter_item.type}\n          onClick={() => addFilterItem(filter_item, activeFilterCopy)}\n        >\n          {translateFilterItemType(filter_item.type)}\n        </Dropdown.Item>\n      );\n    } else {\n      return;\n    }\n  };\n\n  const addFilterItem = (filterItem: any, activeFilterCopy: any) => {\n    activeFilterCopy.filter_items.push({\n      id: filterItem.type,\n      type: filterItem.type,\n      max_selected_items: filterItem.max_selected_items,\n      filter_id: activeFilterCopy.id,\n      available_options: filterItem.options,\n      selected_options: [],\n    });\n\n    let activeFilterDuplicate = Object.assign({}, activeFilterCopy);\n    setActiveFilterCopy(activeFilterDuplicate);\n  };\n\n  const handleApplyFilter = () => {\n    applyFilter();\n    setShowFilterItemOptionsPopup({ filterItemId: null, show: false });\n  };\n\n  useEffect(() => {\n    applyFilter();\n  }, []);\n\n  return (\n    <div className={'filter'}>\n      <ul\n        className={`filter_items ${\n          activeFilterCopy.filter_items.length === availableFilterItems.length\n            ? 'filter_items--disabled'\n            : ''\n        }`}\n      >\n        {activeFilterCopy !== undefined &&\n          activeFilterCopy.filter_items !== undefined &&\n          activeFilterCopy.filter_items.length !== 0 &&\n          activeFilterCopy.filter_items.map((filter_item: IFilterItem) => (\n            <li className={'filter_item'} key={filter_item.id}>\n              <FilterItem\n                activeFilterCopy={activeFilterCopy}\n                setActiveFilterCopy={setActiveFilterCopy}\n                filter_item={filter_item}\n                parseSelectedItems={parseSelectedItems}\n                availableFilterItems={availableFilterItems}\n                showFilterItemOptionsPopup={showFilterItemOptionsPopup}\n                setShowFilterItemOptionsPopup={setShowFilterItemOptionsPopup}\n              />\n            </li>\n          ))}\n        <li className={'fixed-action'}>\n          <Dropdown className={'available-filter-items'}>\n            <Dropdown.Toggle variant=\"success\" id=\"dropdown-basic\">\n              <span>\n                <PlusIcon className=\"plus-icon\" height=\"15px\" width=\"15px\" />\n                {i18n.t('events_overview.filter.add_filter_item')}\n              </span>\n            </Dropdown.Toggle>\n\n            <Dropdown.Menu>\n              <ul>\n                {availableFilterItems.length !== 0 &&\n                  availableFilterItems.map((filter_item: IFilterItem) =>\n                    buildUnselectedItems(filter_item),\n                  )}\n              </ul>\n            </Dropdown.Menu>\n          </Dropdown>\n        </li>\n        <li className={'fixed-action'}>\n          <div className={'apply-button-container'}>\n            <a\n              className={'apply-button'}\n              onClick={() => {\n                handleApplyFilter();\n              }}\n            >\n              {i18n.t('events_overview.filter.apply')}\n            </a>\n          </div>\n        </li>\n      </ul>\n    </div>\n  );\n};\n\nexport default Filter;\n"],"mappings":"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"}
|
|
130
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["require","_react","_interopRequireWildcard","_Dropdown","_interopRequireDefault","_add","_i18n","_FilterItem","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","Filter","props","activeFilterCopy","setActiveFilterCopy","parseSelectedItems","availableFilterItems","applyFilter","resetFilter","_useState","useState","filterItemId","show","_useState2","_slicedToArray2","showFilterItemOptionsPopup","setShowFilterItemOptionsPopup","camelToSnakeCase","str","toLowerCase","slice","length","replace","letter","concat","translateFilterItemType","filterItemType","i18n","t","buildUnselectedItems","filter_item","filter_items","undefined","find","selected_item","type","createElement","Item","href","onClick","addFilterItem","filterItem","push","id","max_selected_items","filter_id","available_options","options","selected_options","activeFilterDuplicate","assign","handleApplyFilter","useEffect","className","map","Toggle","variant","ReactComponent","height","width","Menu","_default","exports"],"sources":["../../../../../../src/pages/EventsPage/events/events_list/Filter/Filter.tsx"],"sourcesContent":["import '@kenshooui/react-multi-select/dist/style.css';\nimport React, { useEffect, useState } from 'react';\nimport Dropdown from 'react-bootstrap/Dropdown';\nimport { ReactComponent as PlusIcon } from 'src/assets/icons/add.svg';\nimport { IFilterItem } from 'src/store/filters/IFilterItem';\nimport i18n from 'src/utilities/i18n';\nimport '../../EventsStyle.scss';\nimport FilterItem from './FilterItem';\n\ntype IProps = {\n  activeFilterCopy: any;\n  setActiveFilterCopy: React.Dispatch<any>;\n  parseSelectedItems: any;\n  availableFilterItems: any;\n  applyFilter: any;\n  resetFilter: any;\n};\n\nconst Filter: React.FC<IProps> = (props) => {\n  const {\n    activeFilterCopy,\n    setActiveFilterCopy,\n    parseSelectedItems,\n    availableFilterItems,\n    applyFilter,\n    resetFilter,\n  } = props;\n  const [showFilterItemOptionsPopup, setShowFilterItemOptionsPopup] = useState({\n    filterItemId: null,\n    show: false,\n  });\n  const camelToSnakeCase = (str: string) =>\n    str[0].toLowerCase() +\n    str\n      .slice(1, str.length)\n      .replace(/[A-Z]/g, (letter) => `_${letter.toLowerCase()}`);\n  const translateFilterItemType = (filterItemType: string) => {\n    return i18n.t(\n      `events_overview.filter.filter_types.${camelToSnakeCase(filterItemType)}`,\n    );\n  };\n  const buildUnselectedItems = (filter_item: IFilterItem) => {\n    if (\n      activeFilterCopy.filter_items !== undefined &&\n      activeFilterCopy.filter_items.find(\n        (selected_item: IFilterItem) => selected_item.type === filter_item.type,\n      ) === undefined\n    ) {\n      return (\n        <Dropdown.Item\n          href=\"#\"\n          key={filter_item.type}\n          onClick={() => addFilterItem(filter_item, activeFilterCopy)}\n        >\n          {translateFilterItemType(filter_item.type)}\n        </Dropdown.Item>\n      );\n    } else {\n      return;\n    }\n  };\n\n  const addFilterItem = (filterItem: any, activeFilterCopy: any) => {\n    activeFilterCopy.filter_items.push({\n      id: filterItem.type,\n      type: filterItem.type,\n      max_selected_items: filterItem.max_selected_items,\n      filter_id: activeFilterCopy.id,\n      available_options: filterItem.options,\n      selected_options: [],\n    });\n\n    let activeFilterDuplicate = Object.assign({}, activeFilterCopy);\n    setActiveFilterCopy(activeFilterDuplicate);\n  };\n\n  const handleApplyFilter = () => {\n    applyFilter();\n    setShowFilterItemOptionsPopup({ filterItemId: null, show: false });\n  };\n\n  useEffect(() => {\n    applyFilter();\n  }, []);\n\n  return (\n    <div className={'filter'}>\n      <ul\n        className={`filter_items ${\n          activeFilterCopy.filter_items.length === availableFilterItems.length\n            ? 'filter_items--disabled'\n            : ''\n        }`}\n      >\n        {activeFilterCopy !== undefined &&\n          activeFilterCopy.filter_items !== undefined &&\n          activeFilterCopy.filter_items.length !== 0 &&\n          activeFilterCopy.filter_items.map((filter_item: IFilterItem) => (\n            <li className={'filter_item'} key={filter_item.id}>\n              <FilterItem\n                activeFilterCopy={activeFilterCopy}\n                setActiveFilterCopy={setActiveFilterCopy}\n                filter_item={filter_item}\n                parseSelectedItems={parseSelectedItems}\n                availableFilterItems={availableFilterItems}\n                showFilterItemOptionsPopup={showFilterItemOptionsPopup}\n                setShowFilterItemOptionsPopup={setShowFilterItemOptionsPopup}\n              />\n            </li>\n          ))}\n        <li className={'fixed-action'}>\n          <Dropdown className={'available-filter-items'}>\n            <Dropdown.Toggle variant=\"success\" id=\"dropdown-basic\">\n              <span>\n                <PlusIcon className=\"plus-icon\" height=\"15px\" width=\"15px\" />\n                {i18n.t('events_overview.filter.add_filter_item')}\n              </span>\n            </Dropdown.Toggle>\n\n            <Dropdown.Menu>\n              <ul>\n                {availableFilterItems.length !== 0 &&\n                  availableFilterItems.map((filter_item: IFilterItem) =>\n                    buildUnselectedItems(filter_item),\n                  )}\n              </ul>\n            </Dropdown.Menu>\n          </Dropdown>\n        </li>\n        <li className={'fixed-action'}>\n          <div className={'apply-button-container'}>\n            <a\n              className={'apply-button'}\n              onClick={() => {\n                handleApplyFilter();\n              }}\n            >\n              {i18n.t('events_overview.filter.apply')}\n            </a>\n          </div>\n        </li>\n        {resetFilter && (\n          <li className={'fixed-action'}>\n            <div className={'reset-button-container'}>\n              <a\n                className={'reset-button'}\n                onClick={() => {\n                  resetFilter();\n                }}\n              >\n                {i18n.t('events_overview.filter.reset')}\n              </a>\n            </div>\n          </li>\n        )}\n      </ul>\n    </div>\n  );\n};\n\nexport default Filter;\n"],"mappings":"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"}
|
|
@@ -7,6 +7,7 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
7
7
|
});
|
|
8
8
|
exports.default = void 0;
|
|
9
9
|
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/toConsumableArray"));
|
|
10
|
+
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/objectSpread2"));
|
|
10
11
|
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/slicedToArray"));
|
|
11
12
|
var _react = _interopRequireWildcard(require("react"));
|
|
12
13
|
var _reactBootstrap = require("react-bootstrap");
|
|
@@ -42,7 +43,9 @@ var FilterContainer = function FilterContainer(props) {
|
|
|
42
43
|
filterPopupOpen = props.filterPopupOpen,
|
|
43
44
|
applyLogic = props.applyLogic,
|
|
44
45
|
_props$fetchType = props.fetchType,
|
|
45
|
-
fetchType = _props$fetchType === void 0 ? 'EventFilters' : _props$fetchType
|
|
46
|
+
fetchType = _props$fetchType === void 0 ? 'EventFilters' : _props$fetchType,
|
|
47
|
+
_props$resetFilter = props.resetFilter,
|
|
48
|
+
resetFilter = _props$resetFilter === void 0 ? null : _props$resetFilter;
|
|
46
49
|
var dispatch = (0, _reactRedux.useDispatch)();
|
|
47
50
|
var nameInput = (0, _react.useRef)(null);
|
|
48
51
|
var filterContent = (0, _react.useRef)(null);
|
|
@@ -67,10 +70,14 @@ var FilterContainer = function FilterContainer(props) {
|
|
|
67
70
|
_useState10 = (0, _slicedToArray2.default)(_useState9, 2),
|
|
68
71
|
activeFilter = _useState10[0],
|
|
69
72
|
setActiveFilter = _useState10[1];
|
|
70
|
-
var _useState11 = (0, _react.useState)(
|
|
73
|
+
var _useState11 = (0, _react.useState)([]),
|
|
71
74
|
_useState12 = (0, _slicedToArray2.default)(_useState11, 2),
|
|
72
|
-
|
|
73
|
-
|
|
75
|
+
defaultFilters = _useState12[0],
|
|
76
|
+
setDefaultFilters = _useState12[1];
|
|
77
|
+
var _useState13 = (0, _react.useState)(undefined),
|
|
78
|
+
_useState14 = (0, _slicedToArray2.default)(_useState13, 2),
|
|
79
|
+
activeFilterCopy = _useState14[0],
|
|
80
|
+
setActiveFilterCopy = _useState14[1];
|
|
74
81
|
// @ts-ignore
|
|
75
82
|
var csrf = document.querySelector("meta[name='csrf-token']").getAttribute('content');
|
|
76
83
|
var useQuery = function useQuery() {
|
|
@@ -81,6 +88,14 @@ var FilterContainer = function FilterContainer(props) {
|
|
|
81
88
|
var getKQLFromURL = function getKQLFromURL() {
|
|
82
89
|
return query.get('valuesFromKQL');
|
|
83
90
|
};
|
|
91
|
+
var handleResetFilter = function handleResetFilter() {
|
|
92
|
+
debugger;
|
|
93
|
+
var removeFilters = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, activeFilterCopy), {}, {
|
|
94
|
+
filter_items: defaultFilters
|
|
95
|
+
});
|
|
96
|
+
setActiveFilterCopy(removeFilters);
|
|
97
|
+
resetFilter && resetFilter();
|
|
98
|
+
};
|
|
84
99
|
var getPointsToFilters = function getPointsToFilters(availableFilterItems, filters) {
|
|
85
100
|
var interestPointFilterItem = availableFilterItems.find(function (f) {
|
|
86
101
|
return f.type === 'InterestPointFilterItem';
|
|
@@ -158,6 +173,7 @@ var FilterContainer = function FilterContainer(props) {
|
|
|
158
173
|
siteID = _useParams.siteID,
|
|
159
174
|
areaID = _useParams.areaID;
|
|
160
175
|
var getData = function getData() {
|
|
176
|
+
var firstTime = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
|
|
161
177
|
fetch("/ui_filters.json?water_authority_id=".concat(global_data.waterAuthorityId, "&filter_type=").concat(fetchType, "&valuesFromKQL=").concat(getKQLFromURL()).concat(siteID ? "&site_id=".concat(siteID) : '').concat(areaID ? "&area_id=".concat(areaID) : '')).then(function (response) {
|
|
162
178
|
return response.json();
|
|
163
179
|
}).then(function (json) {
|
|
@@ -175,6 +191,9 @@ var FilterContainer = function FilterContainer(props) {
|
|
|
175
191
|
setActiveFilter(active);
|
|
176
192
|
setActiveFilterCopy(active);
|
|
177
193
|
}
|
|
194
|
+
if (firstTime) {
|
|
195
|
+
setDefaultFilters(deepClone(active.filter_items));
|
|
196
|
+
}
|
|
178
197
|
applyFilter(active);
|
|
179
198
|
});
|
|
180
199
|
};
|
|
@@ -303,7 +322,7 @@ var FilterContainer = function FilterContainer(props) {
|
|
|
303
322
|
setWaId(getWaIdFromURL());
|
|
304
323
|
if (!rendered) {
|
|
305
324
|
setRendered(true);
|
|
306
|
-
getData();
|
|
325
|
+
getData(!rendered);
|
|
307
326
|
} else {
|
|
308
327
|
if (global_data.eventFilterParam === '' && filters.length !== 0) {
|
|
309
328
|
var filter = filters.find(function (filter) {
|
|
@@ -383,10 +402,11 @@ var FilterContainer = function FilterContainer(props) {
|
|
|
383
402
|
activeFilterCopy: activeFilterCopy,
|
|
384
403
|
availableFilterItems: availableFilterItems,
|
|
385
404
|
parseSelectedItems: _kql.parseSelectedItems,
|
|
386
|
-
applyFilter: applyFilter
|
|
405
|
+
applyFilter: applyFilter,
|
|
406
|
+
resetFilter: resetFilter ? handleResetFilter : null
|
|
387
407
|
}))));
|
|
388
408
|
};
|
|
389
409
|
var connector = (0, _reactRedux.connect)(mapStateToProps);
|
|
390
410
|
var _default = connector(FilterContainer);
|
|
391
411
|
exports.default = _default;
|
|
392
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactBootstrap","_Dropdown","_interopRequireDefault","_reactRedux","_reactRouterDom","_diskette","_list","_actions","_i18n","_kql","_Filter","_FiltersDropDown","_actionsCreator","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","mapStateToProps","state","global_data","nav_context_data","points_data","FilterContainer","props","custom_points","filterPopupOpen","applyLogic","_props$fetchType","fetchType","dispatch","useDispatch","nameInput","useRef","filterContent","_useState","useState","_useState2","_slicedToArray2","filters","setFilters","_useState3","_useState4","availableFilterItems","setAvailableFilterItems","_useState5","_useState6","rendered","setRendered","_useState7","_useState8","WaId","setWaId","_useState9","undefined","_useState10","activeFilter","setActiveFilter","_useState11","_useState12","activeFilterCopy","setActiveFilterCopy","csrf","document","querySelector","getAttribute","useQuery","URLSearchParams","useLocation","search","history","useHistory","query","getKQLFromURL","getPointsToFilters","interestPointFilterItem","find","f","type","filteredPointsData","items","filter","point","part_of_observation","map","id","name","group","options","forEach","filterItem","filter_items","fi","available_options","updateSiteToFilters","siteFilterItem","fetchEventFilters","preparedParams","method","url","arguments","length","fetch","headers","Accept","body","JSON","stringify","then","response","json","data","available_filter_items","saved","deepClone","parse","_useParams","useParams","siteID","areaID","getData","concat","waterAuthorityId","jsonShallowCopy","assign","active","displayed_filter","selectedPeriod","selected_options","activateFilter","applyFilter","handleFilterChange","current","click","saveActiveFilter","clonedFilters","filterToModifyIndex","indexOf","filter_type","ui_filter","is_active","Math","sign","createFilter","newFilter","_toConsumableArray2","deleteFilter","getEventIdFromURL","getWaIdFromURL","getKQLValuesFromURL","value","navContext","includes","push","locale","buildKQLQuery","setEventFilterParam","setActiveFilterGlobally","setSamplingData","currentPage","isFetch","handleCreationClick","useEffect","eventFilterParam","cleanup","createElement","className","ref","i18n","t","Toggle","variant","ReactComponent","height","width","fill","Menu","Item","disabled","onClick","FormControl","placeholder","autoFocus","Button","parseSelectedItems","connector","connect","_default","exports"],"sources":["../../../../../../src/pages/EventsPage/events/events_list/Filter/FilterContainer.tsx"],"sourcesContent":["import React, { useEffect, useRef, useState } from 'react';\nimport { Button, FormControl } from 'react-bootstrap';\nimport Dropdown from 'react-bootstrap/Dropdown';\nimport { connect, ConnectedProps, useDispatch } from 'react-redux';\nimport { useHistory, useLocation, useParams } from 'react-router-dom';\nimport { ReactComponent as SaveIcon } from 'src/assets/icons/diskette.svg';\nimport { ReactComponent as ListIcon } from 'src/assets/icons/list.svg';\nimport { IAppState } from 'src/models/IAppState';\nimport { IFilter } from 'src/store/filters/IFilter';\nimport { IFilterItem } from 'src/store/filters/IFilterItem';\nimport {\n  setActiveFilterGlobally,\n  setEventFilterParam,\n} from 'src/store/global/actions';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport i18n from 'src/utilities/i18n';\nimport { buildKQLQuery, parseSelectedItems } from 'src/utilities/kql';\nimport './FilterStyle.scss';\nimport Filter from './Filter';\nimport FiltersDropDown from './FiltersDropDown';\nimport { setSamplingData } from 'src/store/samplings/actionsCreator';\nfunction mapStateToProps(state: IAppState) {\n  const { global_data, nav_context_data, points_data } = state;\n\n  return {\n    global_data,\n    nav_context_data,\n    points_data,\n  };\n}\n\ntype IProps = ConnectedProps<typeof connector> & {\n  filterPopupOpen: boolean;\n  fetchType: string;\n  custom_points?: any;\n  applyLogic?: (values: string) => void;\n};\n\nconst FilterContainer: React.FC<IProps> = (props) => {\n  const {\n    global_data,\n    nav_context_data,\n    points_data,\n    custom_points,\n    filterPopupOpen,\n    applyLogic,\n    fetchType = 'EventFilters',\n  } = props;\n  const dispatch = useDispatch();\n  const nameInput = useRef<HTMLInputElement>(null);\n  const filterContent = useRef<HTMLDivElement>(null);\n  const [filters, setFilters] = useState<any>([]);\n  const [availableFilterItems, setAvailableFilterItems] = useState([]);\n  const [rendered, setRendered] = useState(false);\n  const [WaId, setWaId] = useState<string | null>();\n  //eslint-disable-next-line\n  const [activeFilter, setActiveFilter] = useState<any>(undefined);\n  const [activeFilterCopy, setActiveFilterCopy] = useState<any>(undefined);\n  // @ts-ignore\n  const csrf = document\n    .querySelector(\"meta[name='csrf-token']\")\n    .getAttribute('content');\n  const useQuery = () => {\n    return new URLSearchParams(useLocation().search);\n  };\n  const history = useHistory();\n  const query = useQuery();\n  const getKQLFromURL = () => {\n    return query.get('valuesFromKQL');\n  };\n\n  const getPointsToFilters = (availableFilterItems: any, filters: any) => {\n    let interestPointFilterItem = availableFilterItems.find(\n      (f: IFilterItem) => f.type === 'InterestPointFilterItem',\n    );\n    let filteredPointsData =\n      custom_points ||\n      points_data.items\n        .filter((point: IPoint) => point.part_of_observation === true)\n        .map((point: IPoint) => {\n          return { id: point.id, name: point.group.name };\n        });\n\n    if (interestPointFilterItem !== undefined) {\n      interestPointFilterItem.options = filteredPointsData;\n    }\n\n    filters.forEach((f: IFilter) => {\n      let filterItem = f.filter_items.find(\n        (fi: IFilterItem) => fi.type === 'InterestPointFilterItem',\n      );\n\n      if (filterItem !== undefined) {\n        filterItem.available_options = filteredPointsData;\n      }\n    });\n    if (custom_points) {\n      updateSiteToFilters(availableFilterItems, filters);\n    }\n    setFilters(filters);\n  };\n\n  const updateSiteToFilters = (availableFilterItems: any, filters: any) => {\n    let siteFilterItem = availableFilterItems.find(\n      (f: IFilterItem) => f.type === 'SiteFilterItem',\n    );\n    let filteredPointsData = custom_points;\n\n    if (siteFilterItem !== undefined) {\n      siteFilterItem.options = filteredPointsData;\n    }\n\n    filters.forEach((f: IFilter) => {\n      let filterItem = f.filter_items.find(\n        (fi: IFilterItem) => fi.type === 'SiteFilterItem',\n      );\n\n      if (filterItem !== undefined) {\n        filterItem.available_options = filteredPointsData;\n      }\n    });\n  };\n\n  const fetchEventFilters = (\n    preparedParams: any,\n    method: string,\n    url: string,\n    filter: any = null,\n  ) => {\n    if (csrf !== null) {\n      fetch(url, {\n        method: method,\n        headers: {\n          'Content-Type': 'application/json',\n          'X-CSRF-Token': csrf,\n          Accept: 'application/json',\n        },\n        body: JSON.stringify(preparedParams),\n      })\n        .then((response) => response.json())\n        .then((data) => {\n          getPointsToFilters(data.available_filter_items, data.filters);\n\n          if (filter !== null) {\n            let saved = data.filters.find(\n              (f: IFilter) => f.name === filter.name,\n            );\n            setActiveFilter(saved);\n            setActiveFilterCopy(saved);\n          }\n        });\n    }\n  };\n\n  const deepClone = (data: any) => {\n    return JSON.parse(JSON.stringify(data));\n  };\n\n  const { siteID, areaID } = useParams();\n\n  const getData = () => {\n    fetch(\n      `/ui_filters.json?water_authority_id=${\n        global_data.waterAuthorityId\n      }&filter_type=${fetchType}&valuesFromKQL=${getKQLFromURL()}${\n        siteID ? `&site_id=${siteID}` : ''\n      }${areaID ? `&area_id=${areaID}` : ''}`,\n    )\n      .then((response) => response.json())\n      .then((json) => {\n        getPointsToFilters(json.available_filter_items, json.filters);\n\n        let jsonShallowCopy = Object.assign({}, json);\n        jsonShallowCopy.filters = deepClone(jsonShallowCopy.filters);\n        let active = jsonShallowCopy.displayed_filter;\n\n        if (\n          global_data.selectedPeriod !== undefined &&\n          global_data.selectedPeriod !== null\n        ) {\n          active.filter_items[1].selected_options = [\n            global_data.selectedPeriod,\n          ];\n        }\n\n        if (active === undefined) {\n          activateFilter(jsonShallowCopy.filters[0]);\n        } else {\n          setAvailableFilterItems(jsonShallowCopy.available_filter_items);\n          setActiveFilter(active);\n          setActiveFilterCopy(active);\n        }\n\n        applyFilter(active);\n      });\n  };\n\n  const handleFilterChange = (filter: IFilter) => {\n    setActiveFilter(deepClone(filter));\n    setActiveFilterCopy(deepClone(filter));\n    filterContent.current!.click();\n  };\n\n  const saveActiveFilter = (\n    filter:\n      | IFilter\n      | {\n          id: number;\n          name: string;\n          filter_items: IFilterItem[];\n          is_active: boolean;\n        },\n  ) => {\n    let clonedFilters = deepClone(filters);\n    let filterToModifyIndex = clonedFilters.indexOf(\n      clonedFilters.find((f: any) => f.id === filter.id),\n    );\n    let preparedParams = {\n      filter_type: fetchType,\n      ui_filter: {\n        name: filter.name,\n        is_active: filter.is_active,\n        filter_items: JSON.stringify(filter.filter_items),\n      },\n    };\n\n    clonedFilters[filterToModifyIndex] = filter;\n    setFilters(clonedFilters);\n    setActiveFilter(filter);\n    setActiveFilterCopy(filter);\n\n    if (Math.sign(filter.id) > 0) {\n      fetchEventFilters(\n        preparedParams,\n        'PUT',\n        `/ui_filters/${filter.id}?water_authority_id=${global_data.waterAuthorityId}`,\n        filter,\n      );\n    } else {\n      fetchEventFilters(\n        preparedParams,\n        'POST',\n        `/ui_filters?water_authority_id=${global_data.waterAuthorityId}`,\n        filter,\n      );\n    }\n  };\n\n  const createFilter = (filter: IFilter, name: string) => {\n    let newFilter = {\n      id: -1,\n      name: name,\n      filter_items: filter.filter_items,\n      is_active: false,\n    };\n\n    setFilters([...filters, newFilter]);\n    setActiveFilterCopy(newFilter);\n    setActiveFilter(newFilter);\n    saveActiveFilter(newFilter);\n  };\n\n  const deleteFilter = (filter: IFilter) => {\n    if (csrf !== null && filter.id !== -1) {\n      fetch(\n        `/ui_filters/${filter.id}?water_authority_id=${global_data.waterAuthorityId}&filter_type=${fetchType}`,\n        {\n          method: 'DELETE',\n          headers: {\n            'X-CSRF-Token': csrf,\n          },\n        },\n      )\n        .then((response) => response.json())\n        .then((data) => {\n          let active = data.filters.find(\n            (filter: IFilter) => filter.is_active === true,\n          );\n\n          if (active !== undefined) {\n            setFilters(data.filters);\n            setActiveFilter(active);\n            setActiveFilterCopy(active);\n          } else {\n            if (data.filters.length === 0) {\n              getData();\n            } else {\n              data.filters[0].is_active = true;\n              setActiveFilter(data.filters[0]);\n              setActiveFilterCopy(data.filters[0]);\n              setFilters(data.filters);\n            }\n          }\n        });\n    }\n  };\n\n  const getEventIdFromURL = () => {\n    return query.get('eventId');\n  };\n\n  const getWaIdFromURL = () => {\n    return query.get('water_authority_id');\n  };\n\n  const getKQLValuesFromURL = () => {\n    return query.get('valuesFromKQL');\n  };\n\n  const activateFilter = (filter: IFilter) => {\n    fetchEventFilters(\n      {},\n      'PUT',\n      `/ui_filters/activate/${filter.id}?water_authority_id=${global_data.waterAuthorityId}&filter_type=${fetchType}`,\n      filter,\n    );\n  };\n\n  const applyFilter = (filter = activeFilterCopy) => {\n    let value = 'severity';\n\n    if (nav_context_data.navContext.name === 'samplings-list') {\n      value = 'newest';\n    } else {\n      if (getKQLValuesFromURL() !== null) {\n        if (\n          getKQLValuesFromURL()!.includes('ORDER_BY') &&\n          getKQLValuesFromURL()!.includes('newest')\n        ) {\n          value = 'newest';\n        } else if (\n          getKQLValuesFromURL()!.includes('ORDER_BY') &&\n          getKQLValuesFromURL()!.includes('oldest')\n        ) {\n          value = 'oldest';\n        } else if (\n          getKQLValuesFromURL()!.includes('ORDER_BY') &&\n          getKQLValuesFromURL()!.includes('severity')\n        ) {\n          value = 'severity';\n        }\n      }\n    }\n\n    if (nav_context_data.navContext.name === 'events_view') {\n      history.push(\n        `/${nav_context_data.navContext.name}/index?water_authority_id=${\n          global_data.waterAuthorityId\n        }&locale=${\n          nav_context_data.navContext.locale\n        }&eventId=${getEventIdFromURL()}&valuesFromKQL=${buildKQLQuery(\n          filter,\n          value,\n        )}`,\n      );\n    }\n\n    if (nav_context_data.navContext.name === 'samplings-list') {\n      history.push(\n        `/${nav_context_data.navContext.name}/index?water_authority_id=${\n          global_data.waterAuthorityId\n        }&locale=${\n          nav_context_data.navContext.locale\n        }&valuesFromKQL=${buildKQLQuery(filter, value)}`,\n      );\n\n      if (applyLogic !== undefined) applyLogic(buildKQLQuery(filter, value));\n    }\n    if (fetchType === 'HierarchyFilter') {\n      applyLogic(filter);\n    }\n\n    dispatch(setEventFilterParam(buildKQLQuery(filter, value)));\n    dispatch(setActiveFilterGlobally(filter));\n    // Always reset page to 1 when a new filter is applied\n    dispatch(setSamplingData({ currentPage: 1, isFetch: false }));\n  };\n\n  const handleCreationClick = () => {\n    createFilter(activeFilterCopy, nameInput.current!.value);\n    nameInput.current!.value = '';\n    filterContent.current!.click();\n  };\n\n  useEffect(() => {\n    setWaId(getWaIdFromURL());\n    if (!rendered) {\n      setRendered(true);\n      getData();\n    } else {\n      if (global_data.eventFilterParam === '' && filters.length !== 0) {\n        let filter = filters.find((filter: IFilter) => {\n          return filter.is_active;\n        });\n        setActiveFilterCopy(filter);\n      }\n    }\n    return function cleanup() {\n      setRendered(false);\n    };\n  }, [global_data.waterAuthorityId, WaId]);\n\n  return (\n    <div\n      className={`filter-container ${\n        filterPopupOpen ? '' : 'filter-container--hidden'\n      }`}\n    >\n      {activeFilterCopy !== undefined && (\n        <div className={'filter-container__content'} ref={filterContent}>\n          <div className={'filter-container__content__header'}>\n            <div className={'title'}>\n              <h4>{i18n.t('events_overview.filter.filter')}</h4>\n            </div>\n\n            <div className={'actions'}>\n              <Dropdown className={'action'}>\n                <Dropdown.Toggle variant=\"success\" id=\"dropdown-basic\">\n                  <ListIcon\n                    className=\"preset-icon\"\n                    height=\"14px\"\n                    width=\"14px\"\n                    fill=\"#1d1d1d\"\n                  />\n                  {activeFilterCopy.name}{' '}\n                  {activeFilterCopy.id === -1 ? (\n                    <b> ({i18n.t('events_overview.filter.unsaved')}) </b>\n                  ) : (\n                    ''\n                  )}\n                </Dropdown.Toggle>\n\n                <FiltersDropDown\n                  filters={filters}\n                  handleFilterChange={handleFilterChange}\n                  activeFilterCopy={activeFilterCopy}\n                  activateFilter={activateFilter}\n                  deleteFilter={deleteFilter}\n                />\n              </Dropdown>\n\n              <Dropdown className={'action'}>\n                <Dropdown.Toggle variant=\"success\" id=\"dropdown-basic\">\n                  <SaveIcon\n                    className=\"save-icon\"\n                    height=\"13px\"\n                    width=\"13px\"\n                    fill=\"#1d1d1d\"\n                  />\n                  <span>{i18n.t('events_overview.filter.save.label')}</span>\n                </Dropdown.Toggle>\n\n                <Dropdown.Menu>\n                  <Dropdown.Item\n                    disabled={activeFilterCopy.id === -1 ? true : false}\n                    onClick={() => {\n                      saveActiveFilter(activeFilterCopy);\n                    }}\n                  >\n                    {i18n.t('events_overview.filter.save.existing')}\n                  </Dropdown.Item>\n                  <Dropdown className={'action action--save'}>\n                    <Dropdown.Toggle variant=\"success\" id=\"dropdown-basic\">\n                      {i18n.t('events_overview.filter.save.new')}\n                    </Dropdown.Toggle>\n\n                    <Dropdown.Menu>\n                      <div className={'new-filter-popup'}>\n                        <FormControl\n                          placeholder={i18n.t(\n                            'events_overview.filter.save.field_placeholder',\n                          )}\n                          aria-label=\"Name this filter\"\n                          aria-describedby=\"basic-addon2\"\n                          ref={nameInput}\n                          autoFocus={true}\n                        />\n                        <br />\n                        <Button\n                          onClick={() => {\n                            handleCreationClick();\n                          }}\n                          variant=\"success\"\n                        >\n                          {i18n.t('device_health_status.ok')}\n                        </Button>\n                      </div>\n                    </Dropdown.Menu>\n                  </Dropdown>\n                </Dropdown.Menu>\n              </Dropdown>\n            </div>\n          </div>\n\n          <div className={'filter-container__content__body'}>\n            <Filter\n              setActiveFilterCopy={setActiveFilterCopy}\n              activeFilterCopy={activeFilterCopy}\n              availableFilterItems={availableFilterItems}\n              parseSelectedItems={parseSelectedItems}\n              applyFilter={applyFilter}\n            />\n          </div>\n        </div>\n      )}\n    </div>\n  );\n};\n\nconst connector = connect(mapStateToProps);\nexport default connector(FilterContainer);\n"],"mappings":"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"}
|
|
412
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactBootstrap","_Dropdown","_interopRequireDefault","_reactRedux","_reactRouterDom","_diskette","_list","_actions","_i18n","_kql","_Filter","_FiltersDropDown","_actionsCreator","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","mapStateToProps","state","global_data","nav_context_data","points_data","FilterContainer","props","custom_points","filterPopupOpen","applyLogic","_props$fetchType","fetchType","_props$resetFilter","resetFilter","dispatch","useDispatch","nameInput","useRef","filterContent","_useState","useState","_useState2","_slicedToArray2","filters","setFilters","_useState3","_useState4","availableFilterItems","setAvailableFilterItems","_useState5","_useState6","rendered","setRendered","_useState7","_useState8","WaId","setWaId","_useState9","undefined","_useState10","activeFilter","setActiveFilter","_useState11","_useState12","defaultFilters","setDefaultFilters","_useState13","_useState14","activeFilterCopy","setActiveFilterCopy","csrf","document","querySelector","getAttribute","useQuery","URLSearchParams","useLocation","search","history","useHistory","query","getKQLFromURL","handleResetFilter","removeFilters","_objectSpread2","filter_items","getPointsToFilters","interestPointFilterItem","find","f","type","filteredPointsData","items","filter","point","part_of_observation","map","id","name","group","options","forEach","filterItem","fi","available_options","updateSiteToFilters","siteFilterItem","fetchEventFilters","preparedParams","method","url","arguments","length","fetch","headers","Accept","body","JSON","stringify","then","response","json","data","available_filter_items","saved","deepClone","parse","_useParams","useParams","siteID","areaID","getData","firstTime","concat","waterAuthorityId","jsonShallowCopy","assign","active","displayed_filter","selectedPeriod","selected_options","activateFilter","applyFilter","handleFilterChange","current","click","saveActiveFilter","clonedFilters","filterToModifyIndex","indexOf","filter_type","ui_filter","is_active","Math","sign","createFilter","newFilter","_toConsumableArray2","deleteFilter","getEventIdFromURL","getWaIdFromURL","getKQLValuesFromURL","value","navContext","includes","push","locale","buildKQLQuery","setEventFilterParam","setActiveFilterGlobally","setSamplingData","currentPage","isFetch","handleCreationClick","useEffect","eventFilterParam","cleanup","createElement","className","ref","i18n","t","Toggle","variant","ReactComponent","height","width","fill","Menu","Item","disabled","onClick","FormControl","placeholder","autoFocus","Button","parseSelectedItems","connector","connect","_default","exports"],"sources":["../../../../../../src/pages/EventsPage/events/events_list/Filter/FilterContainer.tsx"],"sourcesContent":["import React, { useEffect, useRef, useState } from 'react';\nimport { Button, FormControl } from 'react-bootstrap';\nimport Dropdown from 'react-bootstrap/Dropdown';\nimport { connect, ConnectedProps, useDispatch } from 'react-redux';\nimport { useHistory, useLocation, useParams } from 'react-router-dom';\nimport { ReactComponent as SaveIcon } from 'src/assets/icons/diskette.svg';\nimport { ReactComponent as ListIcon } from 'src/assets/icons/list.svg';\nimport { IAppState } from 'src/models/IAppState';\nimport { IFilter } from 'src/store/filters/IFilter';\nimport { IFilterItem } from 'src/store/filters/IFilterItem';\nimport {\n  setActiveFilterGlobally,\n  setEventFilterParam,\n} from 'src/store/global/actions';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport i18n from 'src/utilities/i18n';\nimport { buildKQLQuery, parseSelectedItems } from 'src/utilities/kql';\nimport './FilterStyle.scss';\nimport Filter from './Filter';\nimport FiltersDropDown from './FiltersDropDown';\nimport { setSamplingData } from 'src/store/samplings/actionsCreator';\nfunction mapStateToProps(state: IAppState) {\n  const { global_data, nav_context_data, points_data } = state;\n\n  return {\n    global_data,\n    nav_context_data,\n    points_data,\n  };\n}\n\ntype IProps = ConnectedProps<typeof connector> & {\n  filterPopupOpen: boolean;\n  fetchType: string;\n  custom_points?: any;\n  applyLogic?: (values: string) => void;\n  resetFilter?: () => void;\n};\n\nconst FilterContainer: React.FC<IProps> = (props) => {\n  const {\n    global_data,\n    nav_context_data,\n    points_data,\n    custom_points,\n    filterPopupOpen,\n    applyLogic,\n    fetchType = 'EventFilters',\n    resetFilter = null,\n  } = props;\n  const dispatch = useDispatch();\n  const nameInput = useRef<HTMLInputElement>(null);\n  const filterContent = useRef<HTMLDivElement>(null);\n  const [filters, setFilters] = useState<any>([]);\n  const [availableFilterItems, setAvailableFilterItems] = useState([]);\n  const [rendered, setRendered] = useState(false);\n  const [WaId, setWaId] = useState<string | null>();\n  //eslint-disable-next-line\n  const [activeFilter, setActiveFilter] = useState<any>(undefined);\n  const [defaultFilters, setDefaultFilters] = useState<any>([]);\n  const [activeFilterCopy, setActiveFilterCopy] = useState<any>(undefined);\n  // @ts-ignore\n  const csrf = document\n    .querySelector(\"meta[name='csrf-token']\")\n    .getAttribute('content');\n  const useQuery = () => {\n    return new URLSearchParams(useLocation().search);\n  };\n  const history = useHistory();\n  const query = useQuery();\n  const getKQLFromURL = () => {\n    return query.get('valuesFromKQL');\n  };\n\n  const handleResetFilter = () => {\n    debugger;\n    const removeFilters = { ...activeFilterCopy, filter_items: defaultFilters };\n    setActiveFilterCopy(removeFilters);\n    resetFilter && resetFilter();\n  };\n\n  const getPointsToFilters = (availableFilterItems: any, filters: any) => {\n    let interestPointFilterItem = availableFilterItems.find(\n      (f: IFilterItem) => f.type === 'InterestPointFilterItem',\n    );\n    let filteredPointsData =\n      custom_points ||\n      points_data.items\n        .filter((point: IPoint) => point.part_of_observation === true)\n        .map((point: IPoint) => {\n          return { id: point.id, name: point.group.name };\n        });\n\n    if (interestPointFilterItem !== undefined) {\n      interestPointFilterItem.options = filteredPointsData;\n    }\n\n    filters.forEach((f: IFilter) => {\n      let filterItem = f.filter_items.find(\n        (fi: IFilterItem) => fi.type === 'InterestPointFilterItem',\n      );\n\n      if (filterItem !== undefined) {\n        filterItem.available_options = filteredPointsData;\n      }\n    });\n    if (custom_points) {\n      updateSiteToFilters(availableFilterItems, filters);\n    }\n    setFilters(filters);\n  };\n\n  const updateSiteToFilters = (availableFilterItems: any, filters: any) => {\n    let siteFilterItem = availableFilterItems.find(\n      (f: IFilterItem) => f.type === 'SiteFilterItem',\n    );\n    let filteredPointsData = custom_points;\n\n    if (siteFilterItem !== undefined) {\n      siteFilterItem.options = filteredPointsData;\n    }\n\n    filters.forEach((f: IFilter) => {\n      let filterItem = f.filter_items.find(\n        (fi: IFilterItem) => fi.type === 'SiteFilterItem',\n      );\n\n      if (filterItem !== undefined) {\n        filterItem.available_options = filteredPointsData;\n      }\n    });\n  };\n\n  const fetchEventFilters = (\n    preparedParams: any,\n    method: string,\n    url: string,\n    filter: any = null,\n  ) => {\n    if (csrf !== null) {\n      fetch(url, {\n        method: method,\n        headers: {\n          'Content-Type': 'application/json',\n          'X-CSRF-Token': csrf,\n          Accept: 'application/json',\n        },\n        body: JSON.stringify(preparedParams),\n      })\n        .then((response) => response.json())\n        .then((data) => {\n          getPointsToFilters(data.available_filter_items, data.filters);\n\n          if (filter !== null) {\n            let saved = data.filters.find(\n              (f: IFilter) => f.name === filter.name,\n            );\n            setActiveFilter(saved);\n            setActiveFilterCopy(saved);\n          }\n        });\n    }\n  };\n\n  const deepClone = (data: any) => {\n    return JSON.parse(JSON.stringify(data));\n  };\n\n  const { siteID, areaID } = useParams();\n\n  const getData = (firstTime = false) => {\n    fetch(\n      `/ui_filters.json?water_authority_id=${\n        global_data.waterAuthorityId\n      }&filter_type=${fetchType}&valuesFromKQL=${getKQLFromURL()}${\n        siteID ? `&site_id=${siteID}` : ''\n      }${areaID ? `&area_id=${areaID}` : ''}`,\n    )\n      .then((response) => response.json())\n      .then((json) => {\n        getPointsToFilters(json.available_filter_items, json.filters);\n\n        let jsonShallowCopy = Object.assign({}, json);\n        jsonShallowCopy.filters = deepClone(jsonShallowCopy.filters);\n        let active = jsonShallowCopy.displayed_filter;\n\n        if (\n          global_data.selectedPeriod !== undefined &&\n          global_data.selectedPeriod !== null\n        ) {\n          active.filter_items[1].selected_options = [\n            global_data.selectedPeriod,\n          ];\n        }\n\n        if (active === undefined) {\n          activateFilter(jsonShallowCopy.filters[0]);\n        } else {\n          setAvailableFilterItems(jsonShallowCopy.available_filter_items);\n          setActiveFilter(active);\n          setActiveFilterCopy(active);\n        }\n        if (firstTime) {\n          setDefaultFilters(deepClone(active.filter_items));\n        }\n\n        applyFilter(active);\n      });\n  };\n\n  const handleFilterChange = (filter: IFilter) => {\n    setActiveFilter(deepClone(filter));\n    setActiveFilterCopy(deepClone(filter));\n    filterContent.current!.click();\n  };\n\n  const saveActiveFilter = (\n    filter:\n      | IFilter\n      | {\n          id: number;\n          name: string;\n          filter_items: IFilterItem[];\n          is_active: boolean;\n        },\n  ) => {\n    let clonedFilters = deepClone(filters);\n    let filterToModifyIndex = clonedFilters.indexOf(\n      clonedFilters.find((f: any) => f.id === filter.id),\n    );\n    let preparedParams = {\n      filter_type: fetchType,\n      ui_filter: {\n        name: filter.name,\n        is_active: filter.is_active,\n        filter_items: JSON.stringify(filter.filter_items),\n      },\n    };\n\n    clonedFilters[filterToModifyIndex] = filter;\n    setFilters(clonedFilters);\n    setActiveFilter(filter);\n    setActiveFilterCopy(filter);\n\n    if (Math.sign(filter.id) > 0) {\n      fetchEventFilters(\n        preparedParams,\n        'PUT',\n        `/ui_filters/${filter.id}?water_authority_id=${global_data.waterAuthorityId}`,\n        filter,\n      );\n    } else {\n      fetchEventFilters(\n        preparedParams,\n        'POST',\n        `/ui_filters?water_authority_id=${global_data.waterAuthorityId}`,\n        filter,\n      );\n    }\n  };\n\n  const createFilter = (filter: IFilter, name: string) => {\n    let newFilter = {\n      id: -1,\n      name: name,\n      filter_items: filter.filter_items,\n      is_active: false,\n    };\n\n    setFilters([...filters, newFilter]);\n    setActiveFilterCopy(newFilter);\n    setActiveFilter(newFilter);\n    saveActiveFilter(newFilter);\n  };\n\n  const deleteFilter = (filter: IFilter) => {\n    if (csrf !== null && filter.id !== -1) {\n      fetch(\n        `/ui_filters/${filter.id}?water_authority_id=${global_data.waterAuthorityId}&filter_type=${fetchType}`,\n        {\n          method: 'DELETE',\n          headers: {\n            'X-CSRF-Token': csrf,\n          },\n        },\n      )\n        .then((response) => response.json())\n        .then((data) => {\n          let active = data.filters.find(\n            (filter: IFilter) => filter.is_active === true,\n          );\n\n          if (active !== undefined) {\n            setFilters(data.filters);\n            setActiveFilter(active);\n            setActiveFilterCopy(active);\n          } else {\n            if (data.filters.length === 0) {\n              getData();\n            } else {\n              data.filters[0].is_active = true;\n              setActiveFilter(data.filters[0]);\n              setActiveFilterCopy(data.filters[0]);\n              setFilters(data.filters);\n            }\n          }\n        });\n    }\n  };\n\n  const getEventIdFromURL = () => {\n    return query.get('eventId');\n  };\n\n  const getWaIdFromURL = () => {\n    return query.get('water_authority_id');\n  };\n\n  const getKQLValuesFromURL = () => {\n    return query.get('valuesFromKQL');\n  };\n\n  const activateFilter = (filter: IFilter) => {\n    fetchEventFilters(\n      {},\n      'PUT',\n      `/ui_filters/activate/${filter.id}?water_authority_id=${global_data.waterAuthorityId}&filter_type=${fetchType}`,\n      filter,\n    );\n  };\n\n  const applyFilter = (filter = activeFilterCopy) => {\n    let value = 'severity';\n\n    if (nav_context_data.navContext.name === 'samplings-list') {\n      value = 'newest';\n    } else {\n      if (getKQLValuesFromURL() !== null) {\n        if (\n          getKQLValuesFromURL()!.includes('ORDER_BY') &&\n          getKQLValuesFromURL()!.includes('newest')\n        ) {\n          value = 'newest';\n        } else if (\n          getKQLValuesFromURL()!.includes('ORDER_BY') &&\n          getKQLValuesFromURL()!.includes('oldest')\n        ) {\n          value = 'oldest';\n        } else if (\n          getKQLValuesFromURL()!.includes('ORDER_BY') &&\n          getKQLValuesFromURL()!.includes('severity')\n        ) {\n          value = 'severity';\n        }\n      }\n    }\n\n    if (nav_context_data.navContext.name === 'events_view') {\n      history.push(\n        `/${nav_context_data.navContext.name}/index?water_authority_id=${\n          global_data.waterAuthorityId\n        }&locale=${\n          nav_context_data.navContext.locale\n        }&eventId=${getEventIdFromURL()}&valuesFromKQL=${buildKQLQuery(\n          filter,\n          value,\n        )}`,\n      );\n    }\n\n    if (nav_context_data.navContext.name === 'samplings-list') {\n      history.push(\n        `/${nav_context_data.navContext.name}/index?water_authority_id=${\n          global_data.waterAuthorityId\n        }&locale=${\n          nav_context_data.navContext.locale\n        }&valuesFromKQL=${buildKQLQuery(filter, value)}`,\n      );\n\n      if (applyLogic !== undefined) applyLogic(buildKQLQuery(filter, value));\n    }\n    if (fetchType === 'HierarchyFilter') {\n      applyLogic(filter);\n    }\n\n    dispatch(setEventFilterParam(buildKQLQuery(filter, value)));\n    dispatch(setActiveFilterGlobally(filter));\n    // Always reset page to 1 when a new filter is applied\n    dispatch(setSamplingData({ currentPage: 1, isFetch: false }));\n  };\n\n  const handleCreationClick = () => {\n    createFilter(activeFilterCopy, nameInput.current!.value);\n    nameInput.current!.value = '';\n    filterContent.current!.click();\n  };\n\n  useEffect(() => {\n    setWaId(getWaIdFromURL());\n    if (!rendered) {\n      setRendered(true);\n      getData(!rendered);\n    } else {\n      if (global_data.eventFilterParam === '' && filters.length !== 0) {\n        let filter = filters.find((filter: IFilter) => {\n          return filter.is_active;\n        });\n        setActiveFilterCopy(filter);\n      }\n    }\n    return function cleanup() {\n      setRendered(false);\n    };\n  }, [global_data.waterAuthorityId, WaId]);\n\n  return (\n    <div\n      className={`filter-container ${\n        filterPopupOpen ? '' : 'filter-container--hidden'\n      }`}\n    >\n      {activeFilterCopy !== undefined && (\n        <div className={'filter-container__content'} ref={filterContent}>\n          <div className={'filter-container__content__header'}>\n            <div className={'title'}>\n              <h4>{i18n.t('events_overview.filter.filter')}</h4>\n            </div>\n\n            <div className={'actions'}>\n              <Dropdown className={'action'}>\n                <Dropdown.Toggle variant=\"success\" id=\"dropdown-basic\">\n                  <ListIcon\n                    className=\"preset-icon\"\n                    height=\"14px\"\n                    width=\"14px\"\n                    fill=\"#1d1d1d\"\n                  />\n                  {activeFilterCopy.name}{' '}\n                  {activeFilterCopy.id === -1 ? (\n                    <b> ({i18n.t('events_overview.filter.unsaved')}) </b>\n                  ) : (\n                    ''\n                  )}\n                </Dropdown.Toggle>\n\n                <FiltersDropDown\n                  filters={filters}\n                  handleFilterChange={handleFilterChange}\n                  activeFilterCopy={activeFilterCopy}\n                  activateFilter={activateFilter}\n                  deleteFilter={deleteFilter}\n                />\n              </Dropdown>\n\n              <Dropdown className={'action'}>\n                <Dropdown.Toggle variant=\"success\" id=\"dropdown-basic\">\n                  <SaveIcon\n                    className=\"save-icon\"\n                    height=\"13px\"\n                    width=\"13px\"\n                    fill=\"#1d1d1d\"\n                  />\n                  <span>{i18n.t('events_overview.filter.save.label')}</span>\n                </Dropdown.Toggle>\n\n                <Dropdown.Menu>\n                  <Dropdown.Item\n                    disabled={activeFilterCopy.id === -1 ? true : false}\n                    onClick={() => {\n                      saveActiveFilter(activeFilterCopy);\n                    }}\n                  >\n                    {i18n.t('events_overview.filter.save.existing')}\n                  </Dropdown.Item>\n                  <Dropdown className={'action action--save'}>\n                    <Dropdown.Toggle variant=\"success\" id=\"dropdown-basic\">\n                      {i18n.t('events_overview.filter.save.new')}\n                    </Dropdown.Toggle>\n\n                    <Dropdown.Menu>\n                      <div className={'new-filter-popup'}>\n                        <FormControl\n                          placeholder={i18n.t(\n                            'events_overview.filter.save.field_placeholder',\n                          )}\n                          aria-label=\"Name this filter\"\n                          aria-describedby=\"basic-addon2\"\n                          ref={nameInput}\n                          autoFocus={true}\n                        />\n                        <br />\n                        <Button\n                          onClick={() => {\n                            handleCreationClick();\n                          }}\n                          variant=\"success\"\n                        >\n                          {i18n.t('device_health_status.ok')}\n                        </Button>\n                      </div>\n                    </Dropdown.Menu>\n                  </Dropdown>\n                </Dropdown.Menu>\n              </Dropdown>\n            </div>\n          </div>\n\n          <div className={'filter-container__content__body'}>\n            <Filter\n              setActiveFilterCopy={setActiveFilterCopy}\n              activeFilterCopy={activeFilterCopy}\n              availableFilterItems={availableFilterItems}\n              parseSelectedItems={parseSelectedItems}\n              applyFilter={applyFilter}\n              resetFilter={resetFilter ? handleResetFilter : null}\n            />\n          </div>\n        </div>\n      )}\n    </div>\n  );\n};\n\nconst connector = connect(mapStateToProps);\nexport default connector(FilterContainer);\n"],"mappings":"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"}
|
|
@@ -64,6 +64,21 @@
|
|
|
64
64
|
}
|
|
65
65
|
}
|
|
66
66
|
|
|
67
|
+
.reset-button-container {
|
|
68
|
+
cursor: pointer;
|
|
69
|
+
|
|
70
|
+
.reset-button {
|
|
71
|
+
background-color: white;
|
|
72
|
+
border: 1px solid #f6004f;
|
|
73
|
+
padding: 6px 29px;
|
|
74
|
+
font-size: 14px;
|
|
75
|
+
|
|
76
|
+
border-radius: 12px;
|
|
77
|
+
color: #f6004f;
|
|
78
|
+
text-decoration: none;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
|
|
67
82
|
#dropdown-basic {
|
|
68
83
|
background: white;
|
|
69
84
|
color: black;
|
|
@@ -14,6 +14,7 @@ var _ScoreNode = _interopRequireDefault(require("./ScoreNode"));
|
|
|
14
14
|
var _PollutionContributorNode = _interopRequireDefault(require("./PollutionContributorNode"));
|
|
15
15
|
var _utils = require("./utils");
|
|
16
16
|
var _reactRedux = require("react-redux");
|
|
17
|
+
var _reactRouterDom = require("react-router-dom");
|
|
17
18
|
var _excluded = ["data", "orientation", "initialDepth", "treeKey", "selectedFilters"];
|
|
18
19
|
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); }
|
|
19
20
|
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; }
|
|
@@ -117,16 +118,22 @@ function AutoFitTree(_ref) {
|
|
|
117
118
|
var clone = JSON.parse(JSON.stringify(data));
|
|
118
119
|
return setCollapsedByDepth(clone, initialDepth);
|
|
119
120
|
}, [data, initialDepth]);
|
|
121
|
+
var _useParams = (0, _reactRouterDom.useParams)(),
|
|
122
|
+
siteID = _useParams.siteID,
|
|
123
|
+
areaID = _useParams.areaID;
|
|
120
124
|
var renderCustomNodeElement = function renderCustomNodeElement(rd3tProps) {
|
|
121
|
-
var _selectedFilters$Samp, _selectedFilters$Insi;
|
|
125
|
+
var _selectedFilters$Samp, _selectedFilters$Insi, _rd3tProps$nodeDatum$, _rd3tProps$nodeDatum$2, _rd3tProps$nodeDatum$3, _rd3tProps$nodeDatum$4;
|
|
122
126
|
var isRoot = rd3tProps.nodeDatum.__rd3t.depth === 0;
|
|
123
127
|
var showSamplers = (selectedFilters === null || selectedFilters === void 0 ? void 0 : (_selectedFilters$Samp = selectedFilters.SamplerFilterItem) === null || _selectedFilters$Samp === void 0 ? void 0 : _selectedFilters$Samp.toString()) === 'with' || false;
|
|
124
128
|
var insightData = (selectedFilters === null || selectedFilters === void 0 ? void 0 : (_selectedFilters$Insi = selectedFilters.InsightDataFilterItem) === null || _selectedFilters$Insi === void 0 ? void 0 : _selectedFilters$Insi.toString()) || 'score';
|
|
129
|
+
var isHighlight = siteID && siteID === ((_rd3tProps$nodeDatum$ = rd3tProps.nodeDatum.attributes) === null || _rd3tProps$nodeDatum$ === void 0 ? void 0 : (_rd3tProps$nodeDatum$2 = _rd3tProps$nodeDatum$.point_id) === null || _rd3tProps$nodeDatum$2 === void 0 ? void 0 : _rd3tProps$nodeDatum$2.toString()) || areaID && areaID === ((_rd3tProps$nodeDatum$3 = rd3tProps.nodeDatum.attributes) === null || _rd3tProps$nodeDatum$3 === void 0 ? void 0 : (_rd3tProps$nodeDatum$4 = _rd3tProps$nodeDatum$3.area_id) === null || _rd3tProps$nodeDatum$4 === void 0 ? void 0 : _rd3tProps$nodeDatum$4.toString());
|
|
125
130
|
return !isRoot && (0, _utils.shouldFilterOut)(rd3tProps, selectedFilters) ? /*#__PURE__*/_react.default.createElement("div", null) : insightData === 'score' ? /*#__PURE__*/_react.default.createElement(_ScoreNode.default, Object.assign({}, rd3tProps, {
|
|
131
|
+
isHighlight: isHighlight,
|
|
126
132
|
onNodeClick: rest.onNodeClick,
|
|
127
133
|
earlyAdopter: early_adopter,
|
|
128
134
|
showSamplers: showSamplers
|
|
129
135
|
})) : /*#__PURE__*/_react.default.createElement(_PollutionContributorNode.default, Object.assign({}, rd3tProps, {
|
|
136
|
+
isHighlight: isHighlight,
|
|
130
137
|
onNodeClick: rest.onNodeClick,
|
|
131
138
|
earlyAdopter: early_adopter,
|
|
132
139
|
showSamplers: showSamplers
|
|
@@ -158,4 +165,4 @@ function AutoFitTree(_ref) {
|
|
|
158
165
|
initialDepth: initialDepth
|
|
159
166
|
}, rest)));
|
|
160
167
|
}
|
|
161
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactD3Tree","_interopRequireDefault","_ScoreNode","_PollutionContributorNode","_utils","_reactRedux","_excluded","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","countDepthAndBreadth","root","maxDepth","breadthByDepth","dfs","n","_n$children","d","arguments","length","undefined","Math","max","children","forEach","c","maxBreadth","apply","AutoFitTree","_ref","data","_ref$orientation","orientation","initialDepth","treeKey","_ref$selectedFilters","selectedFilters","rest","_objectWithoutProperties2","PADDING","wrapperRef","useRef","nodeSize","x","y","separation","siblings","nonSiblings","_useState","useState","width","height","_useState2","_slicedToArray2","dims","setDims","early_adopter","useSelector","state","permissions","useEffect","current","ro","ResizeObserver","r","getBoundingClientRect","observe","disconnect","_useMemo","useMemo","_countDepthAndBreadth","reqW","reqH","availW","availH","fitZoom","min","z","isFinite","zoom","translate","setCollapsedByDepth","node","_node$children","collapsed","viewData","clone","JSON","parse","stringify","renderCustomNodeElement","rd3tProps","_selectedFilters$Samp","_selectedFilters$Insi","isRoot","nodeDatum","__rd3t","depth","showSamplers","SamplerFilterItem","toString","insightData","InsightDataFilterItem","shouldFilterOut","createElement","assign","onNodeClick","earlyAdopter","ref","style","overflow","pathFunc","zoomable","scaleExtent","collapsible"],"sources":["../../../src/ui-kit/HierarchyGraph/AutoFitTree.tsx"],"sourcesContent":["import React, { useRef, useState, useEffect, useMemo } from 'react';\nimport Tree, { RawNodeDatum } from 'react-d3-tree';\nimport ScoreNode from './ScoreNode';\nimport PollutionContributorNode from './PollutionContributorNode';\nimport { InsightData, shouldFilterOut } from './utils';\nimport { useSelector } from 'react-redux';\n\ntype Sep = { siblings: number; nonSiblings: number };\n\nfunction countDepthAndBreadth(root: RawNodeDatum) {\n  let maxDepth = 0;\n  const breadthByDepth: number[] = [];\n  const dfs = (n: RawNodeDatum, d = 0) => {\n    maxDepth = Math.max(maxDepth, d);\n    breadthByDepth[d] = (breadthByDepth[d] || 0) + 1;\n    n.children?.forEach((c) => dfs(c, d + 1));\n  };\n  dfs(root);\n  const maxBreadth = Math.max(...breadthByDepth);\n  return { maxDepth, maxBreadth };\n}\nexport default function AutoFitTree({\n  data,\n  orientation = 'vertical',\n  initialDepth,\n  treeKey,\n  selectedFilters = {},\n  ...rest\n}: {\n  data: any;\n  orientation?: 'vertical' | 'horizontal';\n  initialDepth: number;\n  onNodeClick?: (nodeData: any) => void;\n  treeKey: number;\n  selectedFilters?: any;\n}) {\n  const PADDING = 42; // screen padding in px\n  const wrapperRef = useRef<HTMLDivElement>(null);\n  const nodeSize = { x: 270, y: 270 }; // how much space each node occupies\n  const separation: Sep = { siblings: 0.8, nonSiblings: 0.9 }; // node spacing\n  const [dims, setDims] = useState({ width: 500, height: 100 });\n  const early_adopter = useSelector(\n    (state: any) => state.permissions.early_adopter,\n  );\n\n  // keep wrapper sized to the viewport\n  useEffect(() => {\n    if (!wrapperRef.current) return;\n    const ro = new ResizeObserver(() => {\n      const r = wrapperRef.current!.getBoundingClientRect();\n      setDims({ width: r.width, height: r.height });\n    });\n    ro.observe(wrapperRef.current);\n    return () => ro.disconnect();\n  }, []);\n\n  const { translate, zoom } = useMemo(() => {\n    const { maxDepth, maxBreadth } = countDepthAndBreadth(data);\n\n    // approximate required pixel size of the laid-out tree\n    const reqW = maxBreadth * nodeSize.x * separation.siblings;\n    const reqH = (maxDepth + 1) * nodeSize.y;\n\n    const availW = Math.max(1, dims.width - PADDING * 2);\n    const availH = Math.max(1, dims.height - PADDING * 2);\n\n    const fitZoom = 0.7 * Math.min(availW / reqW, availH / reqH);\n    const z = isFinite(fitZoom) && fitZoom > 0 ? fitZoom : 1.2;\n\n    return { zoom: z, translate: { x: dims.width / 2, y: PADDING } };\n  }, [\n    data,\n    nodeSize.x,\n    nodeSize.y,\n    separation.siblings,\n    dims.width,\n    dims.height,\n  ]);\n\n  function setCollapsedByDepth(node: any, maxDepth: number, d = 0) {\n    node.collapsed = d >= maxDepth;\n    node.children?.forEach((c) => setCollapsedByDepth(c, maxDepth, d + 1));\n    return node;\n  }\n\n  const viewData = useMemo(() => {\n    if (!data) return null;\n    const clone = JSON.parse(JSON.stringify(data));\n    return setCollapsedByDepth(clone, initialDepth);\n  }, [data, initialDepth]);\n\n  const renderCustomNodeElement = (rd3tProps) => {\n    const isRoot = rd3tProps.nodeDatum.__rd3t.depth === 0;\n    const showSamplers =\n      selectedFilters?.SamplerFilterItem?.toString() === 'with' || false;\n    const insightData =\n      (selectedFilters?.InsightDataFilterItem?.toString() as InsightData) ||\n      'score';\n    return !isRoot && shouldFilterOut(rd3tProps, selectedFilters) ? (\n      <div></div>\n    ) : insightData === 'score' ? (\n      <ScoreNode\n        {...rd3tProps}\n        onNodeClick={rest.onNodeClick}\n        earlyAdopter={early_adopter}\n        showSamplers={showSamplers}\n      />\n    ) : (\n      <PollutionContributorNode\n        {...rd3tProps}\n        onNodeClick={rest.onNodeClick}\n        earlyAdopter={early_adopter}\n        showSamplers={showSamplers}\n      />\n    );\n  };\n\n  return (\n    <div\n      ref={wrapperRef}\n      style={{ width: '100vw', height: '100vh', overflow: 'hidden' }}\n    >\n      <Tree\n        key={treeKey}\n        data={viewData}\n        orientation={orientation}\n        pathFunc=\"step\"\n        nodeSize={nodeSize}\n        separation={separation}\n        translate={translate}\n        zoom={zoom}\n        zoomable\n        scaleExtent={{ min: 0.1, max: 2 }}\n        renderCustomNodeElement={renderCustomNodeElement}\n        collapsible\n        initialDepth={initialDepth}\n        {...rest}\n      />\n    </div>\n  );\n}\n"],"mappings":"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"}
|
|
168
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactD3Tree","_interopRequireDefault","_ScoreNode","_PollutionContributorNode","_utils","_reactRedux","_reactRouterDom","_excluded","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","countDepthAndBreadth","root","maxDepth","breadthByDepth","dfs","n","_n$children","d","arguments","length","undefined","Math","max","children","forEach","c","maxBreadth","apply","AutoFitTree","_ref","data","_ref$orientation","orientation","initialDepth","treeKey","_ref$selectedFilters","selectedFilters","rest","_objectWithoutProperties2","PADDING","wrapperRef","useRef","nodeSize","x","y","separation","siblings","nonSiblings","_useState","useState","width","height","_useState2","_slicedToArray2","dims","setDims","early_adopter","useSelector","state","permissions","useEffect","current","ro","ResizeObserver","r","getBoundingClientRect","observe","disconnect","_useMemo","useMemo","_countDepthAndBreadth","reqW","reqH","availW","availH","fitZoom","min","z","isFinite","zoom","translate","setCollapsedByDepth","node","_node$children","collapsed","viewData","clone","JSON","parse","stringify","_useParams","useParams","siteID","areaID","renderCustomNodeElement","rd3tProps","_selectedFilters$Samp","_selectedFilters$Insi","_rd3tProps$nodeDatum$","_rd3tProps$nodeDatum$2","_rd3tProps$nodeDatum$3","_rd3tProps$nodeDatum$4","isRoot","nodeDatum","__rd3t","depth","showSamplers","SamplerFilterItem","toString","insightData","InsightDataFilterItem","isHighlight","attributes","point_id","area_id","shouldFilterOut","createElement","assign","onNodeClick","earlyAdopter","ref","style","overflow","pathFunc","zoomable","scaleExtent","collapsible"],"sources":["../../../src/ui-kit/HierarchyGraph/AutoFitTree.tsx"],"sourcesContent":["import React, { useRef, useState, useEffect, useMemo } from 'react';\nimport Tree, { RawNodeDatum } from 'react-d3-tree';\nimport ScoreNode from './ScoreNode';\nimport PollutionContributorNode from './PollutionContributorNode';\nimport { InsightData, shouldFilterOut } from './utils';\nimport { useSelector } from 'react-redux';\nimport { useParams } from 'react-router-dom';\n\ntype Sep = { siblings: number; nonSiblings: number };\n\nfunction countDepthAndBreadth(root: RawNodeDatum) {\n  let maxDepth = 0;\n  const breadthByDepth: number[] = [];\n  const dfs = (n: RawNodeDatum, d = 0) => {\n    maxDepth = Math.max(maxDepth, d);\n    breadthByDepth[d] = (breadthByDepth[d] || 0) + 1;\n    n.children?.forEach((c) => dfs(c, d + 1));\n  };\n  dfs(root);\n  const maxBreadth = Math.max(...breadthByDepth);\n  return { maxDepth, maxBreadth };\n}\nexport default function AutoFitTree({\n  data,\n  orientation = 'vertical',\n  initialDepth,\n  treeKey,\n  selectedFilters = {},\n  ...rest\n}: {\n  data: any;\n  orientation?: 'vertical' | 'horizontal';\n  initialDepth: number;\n  onNodeClick?: (nodeData: any) => void;\n  treeKey: number;\n  selectedFilters?: any;\n}) {\n  const PADDING = 42; // screen padding in px\n  const wrapperRef = useRef<HTMLDivElement>(null);\n  const nodeSize = { x: 270, y: 270 }; // how much space each node occupies\n  const separation: Sep = { siblings: 0.8, nonSiblings: 0.9 }; // node spacing\n  const [dims, setDims] = useState({ width: 500, height: 100 });\n  const early_adopter = useSelector(\n    (state: any) => state.permissions.early_adopter,\n  );\n\n  // keep wrapper sized to the viewport\n  useEffect(() => {\n    if (!wrapperRef.current) return;\n    const ro = new ResizeObserver(() => {\n      const r = wrapperRef.current!.getBoundingClientRect();\n      setDims({ width: r.width, height: r.height });\n    });\n    ro.observe(wrapperRef.current);\n    return () => ro.disconnect();\n  }, []);\n\n  const { translate, zoom } = useMemo(() => {\n    const { maxDepth, maxBreadth } = countDepthAndBreadth(data);\n\n    // approximate required pixel size of the laid-out tree\n    const reqW = maxBreadth * nodeSize.x * separation.siblings;\n    const reqH = (maxDepth + 1) * nodeSize.y;\n\n    const availW = Math.max(1, dims.width - PADDING * 2);\n    const availH = Math.max(1, dims.height - PADDING * 2);\n\n    const fitZoom = 0.7 * Math.min(availW / reqW, availH / reqH);\n    const z = isFinite(fitZoom) && fitZoom > 0 ? fitZoom : 1.2;\n\n    return { zoom: z, translate: { x: dims.width / 2, y: PADDING } };\n  }, [\n    data,\n    nodeSize.x,\n    nodeSize.y,\n    separation.siblings,\n    dims.width,\n    dims.height,\n  ]);\n\n  function setCollapsedByDepth(node: any, maxDepth: number, d = 0) {\n    node.collapsed = d >= maxDepth;\n    node.children?.forEach((c) => setCollapsedByDepth(c, maxDepth, d + 1));\n    return node;\n  }\n\n  const viewData = useMemo(() => {\n    if (!data) return null;\n    const clone = JSON.parse(JSON.stringify(data));\n    return setCollapsedByDepth(clone, initialDepth);\n  }, [data, initialDepth]);\n\n  const { siteID, areaID } = useParams();\n\n  const renderCustomNodeElement = (rd3tProps) => {\n    const isRoot = rd3tProps.nodeDatum.__rd3t.depth === 0;\n    const showSamplers =\n      selectedFilters?.SamplerFilterItem?.toString() === 'with' || false;\n    const insightData =\n      (selectedFilters?.InsightDataFilterItem?.toString() as InsightData) ||\n      'score';\n    const isHighlight =\n      (siteID &&\n        siteID === rd3tProps.nodeDatum.attributes?.point_id?.toString()) ||\n      (areaID &&\n        areaID === rd3tProps.nodeDatum.attributes?.area_id?.toString());\n    return !isRoot && shouldFilterOut(rd3tProps, selectedFilters) ? (\n      <div></div>\n    ) : insightData === 'score' ? (\n      <ScoreNode\n        {...rd3tProps}\n        isHighlight={isHighlight}\n        onNodeClick={rest.onNodeClick}\n        earlyAdopter={early_adopter}\n        showSamplers={showSamplers}\n      />\n    ) : (\n      <PollutionContributorNode\n        {...rd3tProps}\n        isHighlight={isHighlight}\n        onNodeClick={rest.onNodeClick}\n        earlyAdopter={early_adopter}\n        showSamplers={showSamplers}\n      />\n    );\n  };\n\n  return (\n    <div\n      ref={wrapperRef}\n      style={{ width: '100vw', height: '100vh', overflow: 'hidden' }}\n    >\n      <Tree\n        key={treeKey}\n        data={viewData}\n        orientation={orientation}\n        pathFunc=\"step\"\n        nodeSize={nodeSize}\n        separation={separation}\n        translate={translate}\n        zoom={zoom}\n        zoomable\n        scaleExtent={{ min: 0.1, max: 2 }}\n        renderCustomNodeElement={renderCustomNodeElement}\n        collapsible\n        initialDepth={initialDepth}\n        {...rest}\n      />\n    </div>\n  );\n}\n"],"mappings":"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"}
|
|
@@ -27,18 +27,22 @@ var HierarchyGraph = function HierarchyGraph() {
|
|
|
27
27
|
var ReduxState = (0, _reactRedux.useSelector)(function (state) {
|
|
28
28
|
return state;
|
|
29
29
|
});
|
|
30
|
-
var _useState = (0, _react.useState)(
|
|
30
|
+
var _useState = (0, _react.useState)(0),
|
|
31
31
|
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
var _useState3 = (0, _react.useState)(
|
|
32
|
+
treeKey = _useState2[0],
|
|
33
|
+
setTreeKey = _useState2[1];
|
|
34
|
+
var _useState3 = (0, _react.useState)(null),
|
|
35
35
|
_useState4 = (0, _slicedToArray2.default)(_useState3, 2),
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
var _useState5 = (0, _react.useState)(
|
|
36
|
+
selectedPoint = _useState4[0],
|
|
37
|
+
setSelectedPoint = _useState4[1];
|
|
38
|
+
var _useState5 = (0, _react.useState)(false),
|
|
39
39
|
_useState6 = (0, _slicedToArray2.default)(_useState5, 2),
|
|
40
|
-
|
|
41
|
-
|
|
40
|
+
showRightPanel = _useState6[0],
|
|
41
|
+
setShowRightPanel = _useState6[1];
|
|
42
|
+
var _useState7 = (0, _react.useState)({}),
|
|
43
|
+
_useState8 = (0, _slicedToArray2.default)(_useState7, 2),
|
|
44
|
+
filterOptions = _useState8[0],
|
|
45
|
+
setFilterOptions = _useState8[1];
|
|
42
46
|
var isHierarchyTab = searchQuery.get('view') === 'hierarchy';
|
|
43
47
|
var points_data = ReduxState.points_data,
|
|
44
48
|
edges_data = ReduxState.edges_data,
|
|
@@ -159,14 +163,22 @@ var HierarchyGraph = function HierarchyGraph() {
|
|
|
159
163
|
// You can update state or make API calls based on the applied filter
|
|
160
164
|
};
|
|
161
165
|
|
|
166
|
+
var resetFilter = function resetFilter() {
|
|
167
|
+
setFilterOptions({});
|
|
168
|
+
setTreeKey(treeKey + 1); // Force re-render by changing key
|
|
169
|
+
};
|
|
170
|
+
|
|
162
171
|
if (!isHierarchyTab) {
|
|
163
172
|
return null;
|
|
164
173
|
}
|
|
165
|
-
return /*#__PURE__*/_react.default.createElement("div",
|
|
174
|
+
return /*#__PURE__*/_react.default.createElement("div", {
|
|
175
|
+
className: 'hierarchy-graph-page'
|
|
176
|
+
}, !points_data.isFetching && treeKey > -1 && /*#__PURE__*/_react.default.createElement(_FilterContainer.default, {
|
|
166
177
|
filterPopupOpen: true,
|
|
167
178
|
fetchType: 'HierarchyFilter',
|
|
168
179
|
applyLogic: updateFilter,
|
|
169
|
-
custom_points: filterPoints
|
|
180
|
+
custom_points: filterPoints,
|
|
181
|
+
resetFilter: resetFilter
|
|
170
182
|
}), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Container, {
|
|
171
183
|
fluid: true,
|
|
172
184
|
className: "p-0",
|
|
@@ -181,7 +193,7 @@ var HierarchyGraph = function HierarchyGraph() {
|
|
|
181
193
|
height: '85vh'
|
|
182
194
|
}
|
|
183
195
|
}, edges_data.isFetching || points_data.isFetching || !filterOptions || !treeData || isLoadingSites ? /*#__PURE__*/_react.default.createElement(_Loader.Loader, null) : /*#__PURE__*/_react.default.createElement(_AutoFitTree.default, {
|
|
184
|
-
treeKey:
|
|
196
|
+
treeKey: treeKey,
|
|
185
197
|
initialDepth: 12,
|
|
186
198
|
data: treeData,
|
|
187
199
|
selectedFilters: filterOptions,
|
|
@@ -197,4 +209,4 @@ var HierarchyGraph = function HierarchyGraph() {
|
|
|
197
209
|
};
|
|
198
210
|
var _default = HierarchyGraph;
|
|
199
211
|
exports.default = _default;
|
|
200
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_useQueryURL","_interopRequireDefault","_utils","_reactRedux","_AutoFitTree","_reactBootstrap","_Loader","_RightPanel","_urls","_useApiWithDashboardQuery","_FilterContainer","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","HierarchyGraph","searchQuery","useQueryURL","ReduxState","useSelector","state","_useState","useState","_useState2","_slicedToArray2","selectedPoint","setSelectedPoint","_useState3","_useState4","showRightPanel","setShowRightPanel","_useState5","_useState6","filterOptions","setFilterOptions","isHierarchyTab","points_data","edges_data","waterAuthorityName","global_data","onNodeClick","nodeData","items","find","p","id","attributes","point_id","factoriesEndPoint","useMemo","urls","dashboard","Utility","factories","paramsAll","type","_useApiWithDashboardQ","useApiWithDashboardQuery","_useApiWithDashboardQ2","responseSites","isLoadingSites","errorSites","pollutionBySiteId","m","Map","data","_iterator","_createForOfIteratorHelper2","_step","s","n","done","_step$value","value","site_id","pollution","sector_name","sector_id","contributor_percents","extraData","type_distribution","err","e","f","decoratedPointsById","base","mapById","copy","_i","_Object$keys","keys","length","numId","Number","_objectSpread2","edgesWithDevice","pointsWithDevice","filter","has_device","edge","source_point_id","descendants_has_device","filterPoints","pointsOption","pointList","forEach","sourcePoint","targetPoint","target_point_id","name","group","values","treeData","buildTree","updateFilter","appliedFilter","selectedFilters","filter_items","item","selected_options","createElement","isFetching","filterPopupOpen","fetchType","applyLogic","custom_points","Container","fluid","className","style","overflow","Row","sm","Col","height","Loader","treeKey","initialDepth","concat","point","onClose","_default","exports"],"sources":["../../../src/ui-kit/HierarchyGraph/HierarchyGraph.tsx"],"sourcesContent":["import React, { useMemo } from 'react';\n\nimport useQueryURL from '../../hooks/useQueryURL';\nimport { buildTree, mapById } from './utils';\nimport { useSelector } from 'react-redux';\nimport { useState } from 'react';\nimport AutoFitTree from './AutoFitTree';\nimport { Container, Row, Col } from 'react-bootstrap';\nimport { Loader } from '../../pages/DashboardMap/Loader';\nimport RightPanel from '../../pages/OperationsPage/RightPanel';\nimport { urls } from '../../utilities/urls';\nimport { useApiWithDashboardQuery } from '../../hooks/useApiWithDashboardQuery';\nimport { FactoriesResponse } from '../../Widgets/MostPolluting/Factories/factoriesResponse.interface';\nimport FilterContainer from '../../pages/EventsPage/events/events_list/Filter/FilterContainer';\n\nconst HierarchyGraph = () => {\n  const searchQuery = useQueryURL();\n  const ReduxState = useSelector((state) => state);\n  const [selectedPoint, setSelectedPoint] = useState(null);\n  const [showRightPanel, setShowRightPanel] = useState(false);\n  const [filterOptions, setFilterOptions] = useState({});\n  const isHierarchyTab = searchQuery.get('view') === 'hierarchy';\n  const {\n    points_data,\n    edges_data,\n    global_data: { waterAuthorityName },\n  } = ReduxState;\n\n  const onNodeClick = (nodeData) => {\n    setSelectedPoint(\n      points_data.items.find((p) => p.id === nodeData.attributes.point_id),\n    );\n    setShowRightPanel(!showRightPanel);\n  };\n\n  // stable endpoints/params ✅\n  const factoriesEndPoint = useMemo(\n    () => urls().dashboard.Utility.factories,\n    [],\n  );\n\n  const paramsAll = useMemo(() => ({ type: 'All' }), []);\n\n  // fetches\n  const [responseSites, isLoadingSites, errorSites] =\n    useApiWithDashboardQuery<FactoriesResponse>(factoriesEndPoint, paramsAll);\n\n  // 1) Build a pollution map from both responses (no state; pure memo)\n  const pollutionBySiteId = useMemo(() => {\n    const m = new Map<number, any>();\n    if (responseSites?.data) {\n      for (const {\n        site_id,\n        pollution,\n        sector_name,\n        sector_id,\n        contributor_percents,\n      } of responseSites.data) {\n        const extraData = { sector_name, contributor_percents, sector_id };\n        if (pollution?.type_distribution)\n          extraData['pollution'] = pollution.type_distribution;\n        m.set(site_id, extraData);\n      }\n    }\n    return m;\n  }, [responseSites?.data]);\n\n  // 2) Create a SAFE copy of point_map_data with pollution merged in (no mutations)\n  const decoratedPointsById = useMemo(() => {\n    // mapById(points_data.items) returns a plain object keyed by id; clone it\n    const base = mapById(points_data.items);\n    const copy: Record<number, any> = {};\n    for (const id of Object.keys(base)) {\n      const numId = Number(id);\n      const pollution = pollutionBySiteId.get(numId);\n      // shallow clone each point; add pollution if exists\n      copy[numId] = pollution\n        ? { ...base[numId], ...pollution }\n        : { ...base[numId] };\n    }\n    return copy;\n  }, [points_data.items, pollutionBySiteId]);\n\n  // 3) Compute edgesWithDevice safely/memoized (no extra renders)\n  const edgesWithDevice = useMemo(() => {\n    const pointsWithDevice = mapById(\n      points_data.items.filter((p) => p.has_device),\n    );\n    return edges_data.items.filter(\n      (edge) =>\n        pointsWithDevice[edge.source_point_id] || edge.descendants_has_device,\n    );\n  }, [points_data.items, edges_data.items]);\n\n  const filterPoints = useMemo(() => {\n    const pointsOption = {};\n    const pointList = points_data.items;\n    edgesWithDevice.forEach((edge) => {\n      const sourcePoint = pointList.find((p) => p.id === edge.source_point_id);\n      const targetPoint = pointList.find((p) => p.id === edge.target_point_id);\n      if (sourcePoint)\n        pointsOption[sourcePoint.id] = {\n          id: sourcePoint.id,\n          name: sourcePoint.group.name,\n        };\n      if (targetPoint)\n        pointsOption[targetPoint.id] = {\n          id: targetPoint.id,\n          name: targetPoint.group.name,\n        };\n    });\n    return Object.values(pointsOption);\n  }, [points_data.items, edgesWithDevice]);\n\n  // 4) Build the tree ONLY when data is ready; keep referential stability\n  const treeData = useMemo(() => {\n    if (isLoadingSites || errorSites) return null;\n\n    return buildTree(edgesWithDevice, decoratedPointsById, waterAuthorityName);\n  }, [\n    edgesWithDevice,\n    decoratedPointsById,\n    waterAuthorityName,\n    isLoadingSites,\n    errorSites,\n  ]);\n\n  const updateFilter = (appliedFilter) => {\n    // Process the applied filter as needed\n    const selectedFilters = {};\n\n    appliedFilter.filter_items.forEach((item) => {\n      selectedFilters[item.type] = item.selected_options;\n    });\n    setFilterOptions(selectedFilters);\n    // You can update state or make API calls based on the applied filter\n  };\n\n  if (!isHierarchyTab) {\n    return null;\n  }\n\n  return (\n    <div>\n      {!points_data.isFetching && (\n        <FilterContainer\n          filterPopupOpen={true}\n          fetchType={'HierarchyFilter'}\n          applyLogic={updateFilter}\n          custom_points={filterPoints}\n        />\n      )}\n\n      <Container fluid className=\"p-0\" style={{ overflow: 'hidden' }}>\n        <Row className=\"map-column\" sm={12}>\n          <Col style={{ height: '85vh' }}>\n            {edges_data.isFetching ||\n            points_data.isFetching ||\n            !filterOptions ||\n            !treeData ||\n            isLoadingSites ? (\n              <Loader />\n            ) : (\n              <AutoFitTree\n                treeKey={0}\n                initialDepth={12}\n                data={treeData}\n                selectedFilters={filterOptions}\n                onNodeClick={onNodeClick}\n              />\n            )}\n            <RightPanel\n              className={`right-panel ${showRightPanel ? 'open' : ''}`}\n              point={selectedPoint}\n              onClose={() => {\n                setSelectedPoint(null);\n                setShowRightPanel(false);\n              }}\n            />\n          </Col>\n        </Row>\n      </Container>\n    </div>\n  );\n};\nexport default HierarchyGraph;\n"],"mappings":"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"}
|
|
212
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_useQueryURL","_interopRequireDefault","_utils","_reactRedux","_AutoFitTree","_reactBootstrap","_Loader","_RightPanel","_urls","_useApiWithDashboardQuery","_FilterContainer","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","HierarchyGraph","searchQuery","useQueryURL","ReduxState","useSelector","state","_useState","useState","_useState2","_slicedToArray2","treeKey","setTreeKey","_useState3","_useState4","selectedPoint","setSelectedPoint","_useState5","_useState6","showRightPanel","setShowRightPanel","_useState7","_useState8","filterOptions","setFilterOptions","isHierarchyTab","points_data","edges_data","waterAuthorityName","global_data","onNodeClick","nodeData","items","find","p","id","attributes","point_id","factoriesEndPoint","useMemo","urls","dashboard","Utility","factories","paramsAll","type","_useApiWithDashboardQ","useApiWithDashboardQuery","_useApiWithDashboardQ2","responseSites","isLoadingSites","errorSites","pollutionBySiteId","m","Map","data","_iterator","_createForOfIteratorHelper2","_step","s","n","done","_step$value","value","site_id","pollution","sector_name","sector_id","contributor_percents","extraData","type_distribution","err","e","f","decoratedPointsById","base","mapById","copy","_i","_Object$keys","keys","length","numId","Number","_objectSpread2","edgesWithDevice","pointsWithDevice","filter","has_device","edge","source_point_id","descendants_has_device","filterPoints","pointsOption","pointList","forEach","sourcePoint","targetPoint","target_point_id","name","group","values","treeData","buildTree","updateFilter","appliedFilter","selectedFilters","filter_items","item","selected_options","resetFilter","createElement","className","isFetching","filterPopupOpen","fetchType","applyLogic","custom_points","Container","fluid","style","overflow","Row","sm","Col","height","Loader","initialDepth","concat","point","onClose","_default","exports"],"sources":["../../../src/ui-kit/HierarchyGraph/HierarchyGraph.tsx"],"sourcesContent":["import React, { useMemo } from 'react';\n\nimport useQueryURL from '../../hooks/useQueryURL';\nimport { buildTree, mapById } from './utils';\nimport { useSelector } from 'react-redux';\nimport { useState } from 'react';\nimport AutoFitTree from './AutoFitTree';\nimport { Container, Row, Col } from 'react-bootstrap';\nimport { Loader } from '../../pages/DashboardMap/Loader';\nimport RightPanel from '../../pages/OperationsPage/RightPanel';\nimport { urls } from '../../utilities/urls';\nimport { useApiWithDashboardQuery } from '../../hooks/useApiWithDashboardQuery';\nimport { FactoriesResponse } from '../../Widgets/MostPolluting/Factories/factoriesResponse.interface';\nimport FilterContainer from '../../pages/EventsPage/events/events_list/Filter/FilterContainer';\n\nconst HierarchyGraph = () => {\n  const searchQuery = useQueryURL();\n  const ReduxState = useSelector((state) => state);\n  const [treeKey, setTreeKey] = useState(0);\n  const [selectedPoint, setSelectedPoint] = useState(null);\n  const [showRightPanel, setShowRightPanel] = useState(false);\n  const [filterOptions, setFilterOptions] = useState({});\n  const isHierarchyTab = searchQuery.get('view') === 'hierarchy';\n  const {\n    points_data,\n    edges_data,\n    global_data: { waterAuthorityName },\n  } = ReduxState;\n\n  const onNodeClick = (nodeData) => {\n    setSelectedPoint(\n      points_data.items.find((p) => p.id === nodeData.attributes.point_id),\n    );\n    setShowRightPanel(!showRightPanel);\n  };\n\n  // stable endpoints/params ✅\n  const factoriesEndPoint = useMemo(\n    () => urls().dashboard.Utility.factories,\n    [],\n  );\n\n  const paramsAll = useMemo(() => ({ type: 'All' }), []);\n\n  // fetches\n  const [responseSites, isLoadingSites, errorSites] =\n    useApiWithDashboardQuery<FactoriesResponse>(factoriesEndPoint, paramsAll);\n\n  // 1) Build a pollution map from both responses (no state; pure memo)\n  const pollutionBySiteId = useMemo(() => {\n    const m = new Map<number, any>();\n    if (responseSites?.data) {\n      for (const {\n        site_id,\n        pollution,\n        sector_name,\n        sector_id,\n        contributor_percents,\n      } of responseSites.data) {\n        const extraData = { sector_name, contributor_percents, sector_id };\n        if (pollution?.type_distribution)\n          extraData['pollution'] = pollution.type_distribution;\n        m.set(site_id, extraData);\n      }\n    }\n    return m;\n  }, [responseSites?.data]);\n\n  // 2) Create a SAFE copy of point_map_data with pollution merged in (no mutations)\n  const decoratedPointsById = useMemo(() => {\n    // mapById(points_data.items) returns a plain object keyed by id; clone it\n    const base = mapById(points_data.items);\n    const copy: Record<number, any> = {};\n    for (const id of Object.keys(base)) {\n      const numId = Number(id);\n      const pollution = pollutionBySiteId.get(numId);\n      // shallow clone each point; add pollution if exists\n      copy[numId] = pollution\n        ? { ...base[numId], ...pollution }\n        : { ...base[numId] };\n    }\n    return copy;\n  }, [points_data.items, pollutionBySiteId]);\n\n  // 3) Compute edgesWithDevice safely/memoized (no extra renders)\n  const edgesWithDevice = useMemo(() => {\n    const pointsWithDevice = mapById(\n      points_data.items.filter((p) => p.has_device),\n    );\n    return edges_data.items.filter(\n      (edge) =>\n        pointsWithDevice[edge.source_point_id] || edge.descendants_has_device,\n    );\n  }, [points_data.items, edges_data.items]);\n\n  const filterPoints = useMemo(() => {\n    const pointsOption = {};\n    const pointList = points_data.items;\n    edgesWithDevice.forEach((edge) => {\n      const sourcePoint = pointList.find((p) => p.id === edge.source_point_id);\n      const targetPoint = pointList.find((p) => p.id === edge.target_point_id);\n      if (sourcePoint)\n        pointsOption[sourcePoint.id] = {\n          id: sourcePoint.id,\n          name: sourcePoint.group.name,\n        };\n      if (targetPoint)\n        pointsOption[targetPoint.id] = {\n          id: targetPoint.id,\n          name: targetPoint.group.name,\n        };\n    });\n    return Object.values(pointsOption);\n  }, [points_data.items, edgesWithDevice]);\n\n  // 4) Build the tree ONLY when data is ready; keep referential stability\n  const treeData = useMemo(() => {\n    if (isLoadingSites || errorSites) return null;\n\n    return buildTree(edgesWithDevice, decoratedPointsById, waterAuthorityName);\n  }, [\n    edgesWithDevice,\n    decoratedPointsById,\n    waterAuthorityName,\n    isLoadingSites,\n    errorSites,\n  ]);\n\n  const updateFilter = (appliedFilter) => {\n    // Process the applied filter as needed\n    const selectedFilters = {};\n\n    appliedFilter.filter_items.forEach((item) => {\n      selectedFilters[item.type] = item.selected_options;\n    });\n    setFilterOptions(selectedFilters);\n    // You can update state or make API calls based on the applied filter\n  };\n\n  const resetFilter = () => {\n    setFilterOptions({});\n    setTreeKey(treeKey + 1); // Force re-render by changing key\n  };\n\n  if (!isHierarchyTab) {\n    return null;\n  }\n\n  return (\n    <div className={'hierarchy-graph-page'}>\n      {!points_data.isFetching && treeKey > -1 && (\n        <FilterContainer\n          filterPopupOpen={true}\n          fetchType={'HierarchyFilter'}\n          applyLogic={updateFilter}\n          custom_points={filterPoints}\n          resetFilter={resetFilter}\n        />\n      )}\n\n      <Container fluid className=\"p-0\" style={{ overflow: 'hidden' }}>\n        <Row className=\"map-column\" sm={12}>\n          <Col style={{ height: '85vh' }}>\n            {edges_data.isFetching ||\n            points_data.isFetching ||\n            !filterOptions ||\n            !treeData ||\n            isLoadingSites ? (\n              <Loader />\n            ) : (\n              <AutoFitTree\n                treeKey={treeKey}\n                initialDepth={12}\n                data={treeData}\n                selectedFilters={filterOptions}\n                onNodeClick={onNodeClick}\n              />\n            )}\n            <RightPanel\n              className={`right-panel ${showRightPanel ? 'open' : ''}`}\n              point={selectedPoint}\n              onClose={() => {\n                setSelectedPoint(null);\n                setShowRightPanel(false);\n              }}\n            />\n          </Col>\n        </Row>\n      </Container>\n    </div>\n  );\n};\nexport default HierarchyGraph;\n"],"mappings":"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"}
|
|
@@ -18,35 +18,35 @@ var _theme = require("../../styles/theme/theme");
|
|
|
18
18
|
var _icons = require("utilities/map/icons");
|
|
19
19
|
require("./style.scss");
|
|
20
20
|
var NodeLayout = function NodeLayout(_ref) {
|
|
21
|
-
var _nodeDatum$attributes, _nodeDatum$attributes2, _nodeDatum$
|
|
21
|
+
var _nodeDatum$attributes, _nodeDatum$attributes2, _nodeDatum$attributes3, _nodeDatum$attributes4, _nodeDatum$attributes5;
|
|
22
22
|
var nodeDatum = _ref.nodeDatum,
|
|
23
23
|
toggleNode = _ref.toggleNode,
|
|
24
24
|
searchTerm = _ref.searchTerm,
|
|
25
25
|
showSamplers = _ref.showSamplers,
|
|
26
|
+
_ref$isHighlight = _ref.isHighlight,
|
|
27
|
+
isHighlight = _ref$isHighlight === void 0 ? false : _ref$isHighlight,
|
|
26
28
|
children = _ref.children,
|
|
27
29
|
contentStyle = _ref.contentStyle;
|
|
28
30
|
var factoryType = ((_nodeDatum$attributes = nodeDatum.attributes) === null || _nodeDatum$attributes === void 0 ? void 0 : _nodeDatum$attributes.type) || '';
|
|
29
31
|
var isLeafNode = !nodeDatum.children || nodeDatum.children.length === 0;
|
|
30
32
|
var isMonitored = (_nodeDatum$attributes2 = nodeDatum.attributes) === null || _nodeDatum$attributes2 === void 0 ? void 0 : _nodeDatum$attributes2.monitored;
|
|
31
|
-
var borderColor = _theme.theme.natural.
|
|
32
|
-
var isHighlighted = !!searchTerm && (((_nodeDatum$name = nodeDatum.name) === null || _nodeDatum$name === void 0 ? void 0 : (_nodeDatum$name$toLow = _nodeDatum$name.toLowerCase()) === null || _nodeDatum$name$toLow === void 0 ? void 0 : _nodeDatum$name$toLow.includes(searchTerm.toLowerCase())) || (nodeDatum === null || nodeDatum === void 0 ? void 0 : (_nodeDatum$attributes3 = nodeDatum.attributes) === null || _nodeDatum$attributes3 === void 0 ? void 0 : (_nodeDatum$attributes4 = _nodeDatum$attributes3.area_name) === null || _nodeDatum$attributes4 === void 0 ? void 0 : (_nodeDatum$attributes5 = _nodeDatum$attributes4.toLowerCase()) === null || _nodeDatum$attributes5 === void 0 ? void 0 : _nodeDatum$attributes5.includes(searchTerm.toLowerCase())));
|
|
33
|
-
// const isFocused = siteID === nodeDatum.attributes?.point_id?.toString();
|
|
34
|
-
|
|
33
|
+
var borderColor = _theme.theme.natural.n60;
|
|
35
34
|
var cardStyle = {
|
|
36
35
|
borderRadius: '4px',
|
|
37
|
-
borderColor:
|
|
36
|
+
borderColor: isHighlight ? _theme.theme.brand.surface.muted : borderColor,
|
|
38
37
|
borderStyle: isMonitored ? 'solid' : 'dashed',
|
|
39
38
|
borderWidth: '3px',
|
|
39
|
+
color: isHighlight ? 'white' : _theme.theme.natural.text.default,
|
|
40
40
|
backgroundColor: '#FFFFFF',
|
|
41
41
|
stroke: 'none',
|
|
42
42
|
height: '170px'
|
|
43
43
|
};
|
|
44
|
-
var title = factoryType === 'area' ? ((_nodeDatum$
|
|
44
|
+
var title = factoryType === 'area' ? ((_nodeDatum$attributes3 = nodeDatum.attributes) === null || _nodeDatum$attributes3 === void 0 ? void 0 : _nodeDatum$attributes3.area_name) || nodeDatum.name : nodeDatum.name;
|
|
45
45
|
// const onShowDetails = (event) => {
|
|
46
46
|
// event.stopPropagation();
|
|
47
47
|
// onNodeClick(nodeDatum);
|
|
48
48
|
// };
|
|
49
|
-
var isShowSampler = showSamplers && ((_nodeDatum$
|
|
49
|
+
var isShowSampler = showSamplers && ((_nodeDatum$attributes4 = nodeDatum.attributes) === null || _nodeDatum$attributes4 === void 0 ? void 0 : _nodeDatum$attributes4.has_sampler);
|
|
50
50
|
if (!nodeDatum.name) {
|
|
51
51
|
return null;
|
|
52
52
|
}
|
|
@@ -54,15 +54,16 @@ var NodeLayout = function NodeLayout(_ref) {
|
|
|
54
54
|
onClick: toggleNode,
|
|
55
55
|
style: {
|
|
56
56
|
cursor: 'pointer'
|
|
57
|
-
}
|
|
57
|
+
},
|
|
58
|
+
className: isHighlight ? 'highlight' : ''
|
|
58
59
|
}, /*#__PURE__*/_react.default.createElement("foreignObject", {
|
|
59
60
|
x: "-100",
|
|
60
61
|
y: "-137",
|
|
61
62
|
width: "200",
|
|
62
63
|
height: "250"
|
|
63
|
-
}, ((_nodeDatum$
|
|
64
|
+
}, ((_nodeDatum$attributes5 = nodeDatum.attributes) === null || _nodeDatum$attributes5 === void 0 ? void 0 : _nodeDatum$attributes5.point_id) && /*#__PURE__*/_react.default.createElement(_utils.ActionsContainer, null, /*#__PURE__*/_react.default.createElement(_StyledLink.StyledLink, {
|
|
64
65
|
style: {
|
|
65
|
-
stroke: _theme.theme.brand.surface.
|
|
66
|
+
stroke: _theme.theme.brand.surface.muted,
|
|
66
67
|
strokeWidth: 1,
|
|
67
68
|
background: 'white',
|
|
68
69
|
marginInlineStart: 64
|
|
@@ -105,7 +106,8 @@ var NodeLayout = function NodeLayout(_ref) {
|
|
|
105
106
|
style: cardStyle,
|
|
106
107
|
headerRight: /*#__PURE__*/_react.default.createElement(_NodeIcon.default, {
|
|
107
108
|
type: factoryType
|
|
108
|
-
})
|
|
109
|
+
}),
|
|
110
|
+
linkedHeaderUrl: nodeDatum.attributes ? "/dashboard_v2/site/".concat(nodeDatum.attributes.point_id) : ''
|
|
109
111
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
110
112
|
className: 'node-content',
|
|
111
113
|
style: contentStyle
|
|
@@ -115,4 +117,4 @@ var NodeLayout = function NodeLayout(_ref) {
|
|
|
115
117
|
};
|
|
116
118
|
var _default = NodeLayout;
|
|
117
119
|
exports.default = _default;
|
|
118
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_CardLayout","_NodeIcon","_TopNavbar","_StyledLink","_utils","_LeafSign","_reactI18next","_reactBootstrap","_theme","_icons","NodeLayout","_ref","_nodeDatum$attributes","_nodeDatum$attributes2","_nodeDatum$name","_nodeDatum$name$toLow","_nodeDatum$attributes3","_nodeDatum$attributes4","_nodeDatum$attributes5","_nodeDatum$attributes6","_nodeDatum$attributes7","_nodeDatum$attributes8","nodeDatum","toggleNode","searchTerm","showSamplers","children","contentStyle","factoryType","attributes","type","isLeafNode","length","isMonitored","monitored","borderColor","theme","natural","n30","isHighlighted","name","toLowerCase","includes","area_name","cardStyle","borderRadius","brand","surface","muted","borderStyle","borderWidth","backgroundColor","stroke","height","title","isShowSampler","has_sampler","default","createElement","onClick","style","cursor","x","y","width","point_id","ActionsContainer","StyledLink","strokeWidth","background","marginInlineStart","target","updateParams","view","to","concat","e","stopPropagation","OverlayTrigger","overlay","Tooltip","id","placement","Trans","i18nKey","MapSvg","className","src","samplerIcon","alt","headerRight","color","_default","exports"],"sources":["../../../src/ui-kit/HierarchyGraph/NodeLayout.tsx"],"sourcesContent":["import React from 'react';\nimport CardLayout from '../../Widgets/MostPolluting/Factories/FactoryBox/CardLayout';\nimport NodeIcon from './NodeIcon';\nimport { MapSvg } from '../../assets/icons/TopNavbar';\nimport { StyledLink } from 'src/components/Links/StyledLink/StyledLink';\nimport { ActionsContainer, NodeProps } from './utils';\nimport LeafSign from './LeafSign';\nimport { Trans } from 'react-i18next';\nimport { OverlayTrigger, Tooltip } from 'react-bootstrap';\nimport { theme } from '../../styles/theme/theme';\nimport { samplerIcon } from 'src/utilities/map/icons';\nimport './style.scss';\n\nconst NodeLayout = ({\n  nodeDatum,\n  toggleNode,\n  searchTerm,\n  showSamplers,\n  children,\n  contentStyle,\n}: NodeProps) => {\n  const factoryType = nodeDatum.attributes?.type || '';\n  const isLeafNode = !nodeDatum.children || nodeDatum.children.length === 0;\n  const isMonitored = nodeDatum.attributes?.monitored;\n  const borderColor = theme.natural.n30;\n  const isHighlighted =\n    !!searchTerm &&\n    (nodeDatum.name?.toLowerCase()?.includes(searchTerm.toLowerCase()) ||\n      nodeDatum?.attributes?.area_name\n        ?.toLowerCase()\n        ?.includes(searchTerm.toLowerCase()));\n  // const isFocused = siteID === nodeDatum.attributes?.point_id?.toString();\n\n  const cardStyle: React.CSSProperties = {\n    borderRadius: '4px',\n    borderColor: isHighlighted ? theme.brand.surface.muted : borderColor,\n    borderStyle: isMonitored ? 'solid' : 'dashed',\n    borderWidth: '3px',\n    backgroundColor: '#FFFFFF',\n    stroke: 'none',\n    height: '170px',\n  };\n  const title =\n    factoryType === 'area'\n      ? nodeDatum.attributes?.area_name || nodeDatum.name\n      : nodeDatum.name;\n  // const onShowDetails = (event) => {\n  //   event.stopPropagation();\n  //   onNodeClick(nodeDatum);\n  // };\n  const isShowSampler = showSamplers && nodeDatum.attributes?.has_sampler;\n\n  if (!nodeDatum.name) {\n    return null;\n  }\n  return (\n    <g onClick={toggleNode} style={{ cursor: 'pointer' }}>\n      <foreignObject x=\"-100\" y=\"-137\" width=\"200\" height=\"250\">\n        {nodeDatum.attributes?.point_id && (\n          <ActionsContainer>\n            {/*{earlyAdopter && (*/}\n            {/*  <span style={{ marginInlineEnd: '8px' }}>*/}\n            {/*    <OverlayTrigger*/}\n            {/*      overlay={*/}\n            {/*        <Tooltip id={'details'} placement=\"auto\">*/}\n            {/*          <Trans*/}\n            {/*            i18nKey={'group_screen.general_tab.group_details'}*/}\n            {/*          />*/}\n            {/*        </Tooltip>*/}\n            {/*      }*/}\n            {/*    >*/}\n            {/*      <DetailsSvg onClick={onShowDetails} />*/}\n            {/*    </OverlayTrigger>*/}\n            {/*  </span>*/}\n            {/*)}*/}\n            <StyledLink\n              style={{\n                stroke: theme.brand.surface.default,\n                strokeWidth: 1,\n                background: 'white',\n                marginInlineStart: 64,\n              }}\n              target=\"_blank\"\n              updateParams={{ view: 'map' }}\n              to={`/dashboard_v2/site/${nodeDatum.attributes.point_id}`}\n              onClick={(e) => e.stopPropagation()}\n            >\n              <OverlayTrigger\n                overlay={\n                  <Tooltip id=\"map\" placement=\"auto\">\n                    <Trans i18nKey={'header.map'} />\n                  </Tooltip>\n                }\n              >\n                <MapSvg style={{ width: 55, height: 55 }} />\n              </OverlayTrigger>\n            </StyledLink>\n            {isShowSampler && (\n              <OverlayTrigger\n                overlay={\n                  <Tooltip id=\"sampler\" placement=\"auto\">\n                    <Trans\n                      i18nKey={\n                        'dashboard_v2.utility_dashboard.hierarchy.sampler'\n                      }\n                    />\n                  </Tooltip>\n                }\n              >\n                <span className={'sampler-icon-holder'}>\n                  <img\n                    src={samplerIcon()}\n                    className=\"sampler-icon\"\n                    alt={'sampler'}\n                  />\n                </span>\n              </OverlayTrigger>\n            )}\n          </ActionsContainer>\n        )}\n        <CardLayout\n          title={title}\n          style={cardStyle}\n          headerRight={<NodeIcon type={factoryType} />}\n        >\n          <div className={'node-content'} style={contentStyle}>\n            {nodeDatum.attributes && isMonitored && children}\n          </div>\n        </CardLayout>\n      </foreignObject>\n      {isLeafNode && <LeafSign color={borderColor} />}\n    </g>\n  );\n};\nexport default NodeLayout;\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,WAAA,GAAAF,sBAAA,CAAAC,OAAA;AACA,IAAAE,SAAA,GAAAH,sBAAA,CAAAC,OAAA;AACA,IAAAG,UAAA,GAAAH,OAAA;AACA,IAAAI,WAAA,GAAAJ,OAAA;AACA,IAAAK,MAAA,GAAAL,OAAA;AACA,IAAAM,SAAA,GAAAP,sBAAA,CAAAC,OAAA;AACA,IAAAO,aAAA,GAAAP,OAAA;AACA,IAAAQ,eAAA,GAAAR,OAAA;AACA,IAAAS,MAAA,GAAAT,OAAA;AACA,IAAAU,MAAA,GAAAV,OAAA;AACAA,OAAA;AAEA,IAAMW,UAAU,GAAG,SAAbA,UAAUA,CAAAC,IAAA,EAOC;EAAA,IAAAC,qBAAA,EAAAC,sBAAA,EAAAC,eAAA,EAAAC,qBAAA,EAAAC,sBAAA,EAAAC,sBAAA,EAAAC,sBAAA,EAAAC,sBAAA,EAAAC,sBAAA,EAAAC,sBAAA;EAAA,IANfC,SAAS,GAAAX,IAAA,CAATW,SAAS;IACTC,UAAU,GAAAZ,IAAA,CAAVY,UAAU;IACVC,UAAU,GAAAb,IAAA,CAAVa,UAAU;IACVC,YAAY,GAAAd,IAAA,CAAZc,YAAY;IACZC,QAAQ,GAAAf,IAAA,CAARe,QAAQ;IACRC,YAAY,GAAAhB,IAAA,CAAZgB,YAAY;EAEZ,IAAMC,WAAW,GAAG,EAAAhB,qBAAA,GAAAU,SAAS,CAACO,UAAU,cAAAjB,qBAAA,uBAApBA,qBAAA,CAAsBkB,IAAI,KAAI,EAAE;EACpD,IAAMC,UAAU,GAAG,CAACT,SAAS,CAACI,QAAQ,IAAIJ,SAAS,CAACI,QAAQ,CAACM,MAAM,KAAK,CAAC;EACzE,IAAMC,WAAW,IAAApB,sBAAA,GAAGS,SAAS,CAACO,UAAU,cAAAhB,sBAAA,uBAApBA,sBAAA,CAAsBqB,SAAS;EACnD,IAAMC,WAAW,GAAGC,YAAK,CAACC,OAAO,CAACC,GAAG;EACrC,IAAMC,aAAa,GACjB,CAAC,CAACf,UAAU,KACX,EAAAV,eAAA,GAAAQ,SAAS,CAACkB,IAAI,cAAA1B,eAAA,wBAAAC,qBAAA,GAAdD,eAAA,CAAgB2B,WAAW,CAAC,CAAC,cAAA1B,qBAAA,uBAA7BA,qBAAA,CAA+B2B,QAAQ,CAAClB,UAAU,CAACiB,WAAW,CAAC,CAAC,CAAC,MAChEnB,SAAS,aAATA,SAAS,wBAAAN,sBAAA,GAATM,SAAS,CAAEO,UAAU,cAAAb,sBAAA,wBAAAC,sBAAA,GAArBD,sBAAA,CAAuB2B,SAAS,cAAA1B,sBAAA,wBAAAC,sBAAA,GAAhCD,sBAAA,CACIwB,WAAW,CAAC,CAAC,cAAAvB,sBAAA,uBADjBA,sBAAA,CAEIwB,QAAQ,CAAClB,UAAU,CAACiB,WAAW,CAAC,CAAC,CAAC,EAAC;EAC3C;;EAEA,IAAMG,SAA8B,GAAG;IACrCC,YAAY,EAAE,KAAK;IACnBV,WAAW,EAAEI,aAAa,GAAGH,YAAK,CAACU,KAAK,CAACC,OAAO,CAACC,KAAK,GAAGb,WAAW;IACpEc,WAAW,EAAEhB,WAAW,GAAG,OAAO,GAAG,QAAQ;IAC7CiB,WAAW,EAAE,KAAK;IAClBC,eAAe,EAAE,SAAS;IAC1BC,MAAM,EAAE,MAAM;IACdC,MAAM,EAAE;EACV,CAAC;EACD,IAAMC,KAAK,GACT1B,WAAW,KAAK,MAAM,GAClB,EAAAT,sBAAA,GAAAG,SAAS,CAACO,UAAU,cAAAV,sBAAA,uBAApBA,sBAAA,CAAsBwB,SAAS,KAAIrB,SAAS,CAACkB,IAAI,GACjDlB,SAAS,CAACkB,IAAI;EACpB;EACA;EACA;EACA;EACA,IAAMe,aAAa,GAAG9B,YAAY,MAAAL,sBAAA,GAAIE,SAAS,CAACO,UAAU,cAAAT,sBAAA,uBAApBA,sBAAA,CAAsBoC,WAAW;EAEvE,IAAI,CAAClC,SAAS,CAACkB,IAAI,EAAE;IACnB,OAAO,IAAI;EACb;EACA,oBACE3C,MAAA,CAAA4D,OAAA,CAAAC,aAAA;IAAGC,OAAO,EAAEpC,UAAW;IAACqC,KAAK,EAAE;MAAEC,MAAM,EAAE;IAAU;EAAE,gBACnDhE,MAAA,CAAA4D,OAAA,CAAAC,aAAA;IAAeI,CAAC,EAAC,MAAM;IAACC,CAAC,EAAC,MAAM;IAACC,KAAK,EAAC,KAAK;IAACX,MAAM,EAAC;EAAK,GACtD,EAAAhC,sBAAA,GAAAC,SAAS,CAACO,UAAU,cAAAR,sBAAA,uBAApBA,sBAAA,CAAsB4C,QAAQ,kBAC7BpE,MAAA,CAAA4D,OAAA,CAAAC,aAAA,CAACtD,MAAA,CAAA8D,gBAAgB,qBAgBfrE,MAAA,CAAA4D,OAAA,CAAAC,aAAA,CAACvD,WAAA,CAAAgE,UAAU;IACTP,KAAK,EAAE;MACLR,MAAM,EAAEhB,YAAK,CAACU,KAAK,CAACC,OAAO,CAACU,OAAO;MACnCW,WAAW,EAAE,CAAC;MACdC,UAAU,EAAE,OAAO;MACnBC,iBAAiB,EAAE;IACrB,CAAE;IACFC,MAAM,EAAC,QAAQ;IACfC,YAAY,EAAE;MAAEC,IAAI,EAAE;IAAM,CAAE;IAC9BC,EAAE,wBAAAC,MAAA,CAAwBrD,SAAS,CAACO,UAAU,CAACoC,QAAQ,CAAG;IAC1DN,OAAO,EAAE,SAAAA,QAACiB,CAAC;MAAA,OAAKA,CAAC,CAACC,eAAe,CAAC,CAAC;IAAA;EAAC,gBAEpChF,MAAA,CAAA4D,OAAA,CAAAC,aAAA,CAACnD,eAAA,CAAAuE,cAAc;IACbC,OAAO,eACLlF,MAAA,CAAA4D,OAAA,CAAAC,aAAA,CAACnD,eAAA,CAAAyE,OAAO;MAACC,EAAE,EAAC,KAAK;MAACC,SAAS,EAAC;IAAM,gBAChCrF,MAAA,CAAA4D,OAAA,CAAAC,aAAA,CAACpD,aAAA,CAAA6E,KAAK;MAACC,OAAO,EAAE;IAAa,CAAE,CACxB;EACV,gBAEDvF,MAAA,CAAA4D,OAAA,CAAAC,aAAA,CAACxD,UAAA,CAAAmF,MAAM;IAACzB,KAAK,EAAE;MAAEI,KAAK,EAAE,EAAE;MAAEX,MAAM,EAAE;IAAG;EAAE,CAAE,CAC7B,CACN,CAAC,EACZE,aAAa,iBACZ1D,MAAA,CAAA4D,OAAA,CAAAC,aAAA,CAACnD,eAAA,CAAAuE,cAAc;IACbC,OAAO,eACLlF,MAAA,CAAA4D,OAAA,CAAAC,aAAA,CAACnD,eAAA,CAAAyE,OAAO;MAACC,EAAE,EAAC,SAAS;MAACC,SAAS,EAAC;IAAM,gBACpCrF,MAAA,CAAA4D,OAAA,CAAAC,aAAA,CAACpD,aAAA,CAAA6E,KAAK;MACJC,OAAO,EACL;IACD,CACF,CACM;EACV,gBAEDvF,MAAA,CAAA4D,OAAA,CAAAC,aAAA;IAAM4B,SAAS,EAAE;EAAsB,gBACrCzF,MAAA,CAAA4D,OAAA,CAAAC,aAAA;IACE6B,GAAG,EAAE,IAAAC,kBAAW,EAAC,CAAE;IACnBF,SAAS,EAAC,cAAc;IACxBG,GAAG,EAAE;EAAU,CAChB,CACG,CACQ,CAEF,CACnB,eACD5F,MAAA,CAAA4D,OAAA,CAAAC,aAAA,CAAC1D,WAAA,CAAAyD,OAAU;IACTH,KAAK,EAAEA,KAAM;IACbM,KAAK,EAAEhB,SAAU;IACjB8C,WAAW,eAAE7F,MAAA,CAAA4D,OAAA,CAAAC,aAAA,CAACzD,SAAA,CAAAwD,OAAQ;MAAC3B,IAAI,EAAEF;IAAY,CAAE;EAAE,gBAE7C/B,MAAA,CAAA4D,OAAA,CAAAC,aAAA;IAAK4B,SAAS,EAAE,cAAe;IAAC1B,KAAK,EAAEjC;EAAa,GACjDL,SAAS,CAACO,UAAU,IAAII,WAAW,IAAIP,QACrC,CACK,CACC,CAAC,EACfK,UAAU,iBAAIlC,MAAA,CAAA4D,OAAA,CAAAC,aAAA,CAACrD,SAAA,CAAAoD,OAAQ;IAACkC,KAAK,EAAExD;EAAY,CAAE,CAC7C,CAAC;AAER,CAAC;AAAC,IAAAyD,QAAA,GACalF,UAAU;AAAAmF,OAAA,CAAApC,OAAA,GAAAmC,QAAA"}
|
|
120
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_CardLayout","_NodeIcon","_TopNavbar","_StyledLink","_utils","_LeafSign","_reactI18next","_reactBootstrap","_theme","_icons","NodeLayout","_ref","_nodeDatum$attributes","_nodeDatum$attributes2","_nodeDatum$attributes3","_nodeDatum$attributes4","_nodeDatum$attributes5","nodeDatum","toggleNode","searchTerm","showSamplers","_ref$isHighlight","isHighlight","children","contentStyle","factoryType","attributes","type","isLeafNode","length","isMonitored","monitored","borderColor","theme","natural","n60","cardStyle","borderRadius","brand","surface","muted","borderStyle","borderWidth","color","text","default","backgroundColor","stroke","height","title","area_name","name","isShowSampler","has_sampler","createElement","onClick","style","cursor","className","x","y","width","point_id","ActionsContainer","StyledLink","strokeWidth","background","marginInlineStart","target","updateParams","view","to","concat","e","stopPropagation","OverlayTrigger","overlay","Tooltip","id","placement","Trans","i18nKey","MapSvg","src","samplerIcon","alt","headerRight","linkedHeaderUrl","_default","exports"],"sources":["../../../src/ui-kit/HierarchyGraph/NodeLayout.tsx"],"sourcesContent":["import React from 'react';\nimport CardLayout from '../../Widgets/MostPolluting/Factories/FactoryBox/CardLayout';\nimport NodeIcon from './NodeIcon';\nimport { MapSvg } from '../../assets/icons/TopNavbar';\nimport { StyledLink } from 'src/components/Links/StyledLink/StyledLink';\nimport { ActionsContainer, NodeProps } from './utils';\nimport LeafSign from './LeafSign';\nimport { Trans } from 'react-i18next';\nimport { OverlayTrigger, Tooltip } from 'react-bootstrap';\nimport { theme } from '../../styles/theme/theme';\nimport { samplerIcon } from 'src/utilities/map/icons';\nimport './style.scss';\n\nconst NodeLayout = ({\n  nodeDatum,\n  toggleNode,\n  searchTerm,\n  showSamplers,\n  isHighlight = false,\n  children,\n  contentStyle,\n}: NodeProps) => {\n  const factoryType = nodeDatum.attributes?.type || '';\n  const isLeafNode = !nodeDatum.children || nodeDatum.children.length === 0;\n  const isMonitored = nodeDatum.attributes?.monitored;\n  const borderColor = theme.natural.n60;\n\n  const cardStyle: React.CSSProperties = {\n    borderRadius: '4px',\n    borderColor: isHighlight ? theme.brand.surface.muted : borderColor,\n    borderStyle: isMonitored ? 'solid' : 'dashed',\n    borderWidth: '3px',\n    color: isHighlight ? 'white' : theme.natural.text.default,\n    backgroundColor: '#FFFFFF',\n    stroke: 'none',\n    height: '170px',\n  };\n  const title =\n    factoryType === 'area'\n      ? nodeDatum.attributes?.area_name || nodeDatum.name\n      : nodeDatum.name;\n  // const onShowDetails = (event) => {\n  //   event.stopPropagation();\n  //   onNodeClick(nodeDatum);\n  // };\n  const isShowSampler = showSamplers && nodeDatum.attributes?.has_sampler;\n\n  if (!nodeDatum.name) {\n    return null;\n  }\n  return (\n    <g\n      onClick={toggleNode}\n      style={{ cursor: 'pointer' }}\n      className={isHighlight ? 'highlight' : ''}\n    >\n      <foreignObject x=\"-100\" y=\"-137\" width=\"200\" height=\"250\">\n        {nodeDatum.attributes?.point_id && (\n          <ActionsContainer>\n            {/*{earlyAdopter && (*/}\n            {/*  <span style={{ marginInlineEnd: '8px' }}>*/}\n            {/*    <OverlayTrigger*/}\n            {/*      overlay={*/}\n            {/*        <Tooltip id={'details'} placement=\"auto\">*/}\n            {/*          <Trans*/}\n            {/*            i18nKey={'group_screen.general_tab.group_details'}*/}\n            {/*          />*/}\n            {/*        </Tooltip>*/}\n            {/*      }*/}\n            {/*    >*/}\n            {/*      <DetailsSvg onClick={onShowDetails} />*/}\n            {/*    </OverlayTrigger>*/}\n            {/*  </span>*/}\n            {/*)}*/}\n            <StyledLink\n              style={{\n                stroke: theme.brand.surface.muted,\n                strokeWidth: 1,\n                background: 'white',\n                marginInlineStart: 64,\n              }}\n              target=\"_blank\"\n              updateParams={{ view: 'map' }}\n              to={`/dashboard_v2/site/${nodeDatum.attributes.point_id}`}\n              onClick={(e) => e.stopPropagation()}\n            >\n              <OverlayTrigger\n                overlay={\n                  <Tooltip id=\"map\" placement=\"auto\">\n                    <Trans i18nKey={'header.map'} />\n                  </Tooltip>\n                }\n              >\n                <MapSvg style={{ width: 55, height: 55 }} />\n              </OverlayTrigger>\n            </StyledLink>\n            {isShowSampler && (\n              <OverlayTrigger\n                overlay={\n                  <Tooltip id=\"sampler\" placement=\"auto\">\n                    <Trans\n                      i18nKey={\n                        'dashboard_v2.utility_dashboard.hierarchy.sampler'\n                      }\n                    />\n                  </Tooltip>\n                }\n              >\n                <span className={'sampler-icon-holder'}>\n                  <img\n                    src={samplerIcon()}\n                    className=\"sampler-icon\"\n                    alt={'sampler'}\n                  />\n                </span>\n              </OverlayTrigger>\n            )}\n          </ActionsContainer>\n        )}\n        <CardLayout\n          title={title}\n          style={cardStyle}\n          headerRight={<NodeIcon type={factoryType} />}\n          linkedHeaderUrl={\n            nodeDatum.attributes\n              ? `/dashboard_v2/site/${nodeDatum.attributes.point_id}`\n              : ''\n          }\n        >\n          <div className={'node-content'} style={contentStyle}>\n            {nodeDatum.attributes && isMonitored && children}\n          </div>\n        </CardLayout>\n      </foreignObject>\n      {isLeafNode && <LeafSign color={borderColor} />}\n    </g>\n  );\n};\nexport default NodeLayout;\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,WAAA,GAAAF,sBAAA,CAAAC,OAAA;AACA,IAAAE,SAAA,GAAAH,sBAAA,CAAAC,OAAA;AACA,IAAAG,UAAA,GAAAH,OAAA;AACA,IAAAI,WAAA,GAAAJ,OAAA;AACA,IAAAK,MAAA,GAAAL,OAAA;AACA,IAAAM,SAAA,GAAAP,sBAAA,CAAAC,OAAA;AACA,IAAAO,aAAA,GAAAP,OAAA;AACA,IAAAQ,eAAA,GAAAR,OAAA;AACA,IAAAS,MAAA,GAAAT,OAAA;AACA,IAAAU,MAAA,GAAAV,OAAA;AACAA,OAAA;AAEA,IAAMW,UAAU,GAAG,SAAbA,UAAUA,CAAAC,IAAA,EAQC;EAAA,IAAAC,qBAAA,EAAAC,sBAAA,EAAAC,sBAAA,EAAAC,sBAAA,EAAAC,sBAAA;EAAA,IAPfC,SAAS,GAAAN,IAAA,CAATM,SAAS;IACTC,UAAU,GAAAP,IAAA,CAAVO,UAAU;IACVC,UAAU,GAAAR,IAAA,CAAVQ,UAAU;IACVC,YAAY,GAAAT,IAAA,CAAZS,YAAY;IAAAC,gBAAA,GAAAV,IAAA,CACZW,WAAW;IAAXA,WAAW,GAAAD,gBAAA,cAAG,KAAK,GAAAA,gBAAA;IACnBE,QAAQ,GAAAZ,IAAA,CAARY,QAAQ;IACRC,YAAY,GAAAb,IAAA,CAAZa,YAAY;EAEZ,IAAMC,WAAW,GAAG,EAAAb,qBAAA,GAAAK,SAAS,CAACS,UAAU,cAAAd,qBAAA,uBAApBA,qBAAA,CAAsBe,IAAI,KAAI,EAAE;EACpD,IAAMC,UAAU,GAAG,CAACX,SAAS,CAACM,QAAQ,IAAIN,SAAS,CAACM,QAAQ,CAACM,MAAM,KAAK,CAAC;EACzE,IAAMC,WAAW,IAAAjB,sBAAA,GAAGI,SAAS,CAACS,UAAU,cAAAb,sBAAA,uBAApBA,sBAAA,CAAsBkB,SAAS;EACnD,IAAMC,WAAW,GAAGC,YAAK,CAACC,OAAO,CAACC,GAAG;EAErC,IAAMC,SAA8B,GAAG;IACrCC,YAAY,EAAE,KAAK;IACnBL,WAAW,EAAEV,WAAW,GAAGW,YAAK,CAACK,KAAK,CAACC,OAAO,CAACC,KAAK,GAAGR,WAAW;IAClES,WAAW,EAAEX,WAAW,GAAG,OAAO,GAAG,QAAQ;IAC7CY,WAAW,EAAE,KAAK;IAClBC,KAAK,EAAErB,WAAW,GAAG,OAAO,GAAGW,YAAK,CAACC,OAAO,CAACU,IAAI,CAACC,OAAO;IACzDC,eAAe,EAAE,SAAS;IAC1BC,MAAM,EAAE,MAAM;IACdC,MAAM,EAAE;EACV,CAAC;EACD,IAAMC,KAAK,GACTxB,WAAW,KAAK,MAAM,GAClB,EAAAX,sBAAA,GAAAG,SAAS,CAACS,UAAU,cAAAZ,sBAAA,uBAApBA,sBAAA,CAAsBoC,SAAS,KAAIjC,SAAS,CAACkC,IAAI,GACjDlC,SAAS,CAACkC,IAAI;EACpB;EACA;EACA;EACA;EACA,IAAMC,aAAa,GAAGhC,YAAY,MAAAL,sBAAA,GAAIE,SAAS,CAACS,UAAU,cAAAX,sBAAA,uBAApBA,sBAAA,CAAsBsC,WAAW;EAEvE,IAAI,CAACpC,SAAS,CAACkC,IAAI,EAAE;IACnB,OAAO,IAAI;EACb;EACA,oBACEtD,MAAA,CAAAgD,OAAA,CAAAS,aAAA;IACEC,OAAO,EAAErC,UAAW;IACpBsC,KAAK,EAAE;MAAEC,MAAM,EAAE;IAAU,CAAE;IAC7BC,SAAS,EAAEpC,WAAW,GAAG,WAAW,GAAG;EAAG,gBAE1CzB,MAAA,CAAAgD,OAAA,CAAAS,aAAA;IAAeK,CAAC,EAAC,MAAM;IAACC,CAAC,EAAC,MAAM;IAACC,KAAK,EAAC,KAAK;IAACb,MAAM,EAAC;EAAK,GACtD,EAAAhC,sBAAA,GAAAC,SAAS,CAACS,UAAU,cAAAV,sBAAA,uBAApBA,sBAAA,CAAsB8C,QAAQ,kBAC7BjE,MAAA,CAAAgD,OAAA,CAAAS,aAAA,CAAClD,MAAA,CAAA2D,gBAAgB,qBAgBflE,MAAA,CAAAgD,OAAA,CAAAS,aAAA,CAACnD,WAAA,CAAA6D,UAAU;IACTR,KAAK,EAAE;MACLT,MAAM,EAAEd,YAAK,CAACK,KAAK,CAACC,OAAO,CAACC,KAAK;MACjCyB,WAAW,EAAE,CAAC;MACdC,UAAU,EAAE,OAAO;MACnBC,iBAAiB,EAAE;IACrB,CAAE;IACFC,MAAM,EAAC,QAAQ;IACfC,YAAY,EAAE;MAAEC,IAAI,EAAE;IAAM,CAAE;IAC9BC,EAAE,wBAAAC,MAAA,CAAwBvD,SAAS,CAACS,UAAU,CAACoC,QAAQ,CAAG;IAC1DP,OAAO,EAAE,SAAAA,QAACkB,CAAC;MAAA,OAAKA,CAAC,CAACC,eAAe,CAAC,CAAC;IAAA;EAAC,gBAEpC7E,MAAA,CAAAgD,OAAA,CAAAS,aAAA,CAAC/C,eAAA,CAAAoE,cAAc;IACbC,OAAO,eACL/E,MAAA,CAAAgD,OAAA,CAAAS,aAAA,CAAC/C,eAAA,CAAAsE,OAAO;MAACC,EAAE,EAAC,KAAK;MAACC,SAAS,EAAC;IAAM,gBAChClF,MAAA,CAAAgD,OAAA,CAAAS,aAAA,CAAChD,aAAA,CAAA0E,KAAK;MAACC,OAAO,EAAE;IAAa,CAAE,CACxB;EACV,gBAEDpF,MAAA,CAAAgD,OAAA,CAAAS,aAAA,CAACpD,UAAA,CAAAgF,MAAM;IAAC1B,KAAK,EAAE;MAAEK,KAAK,EAAE,EAAE;MAAEb,MAAM,EAAE;IAAG;EAAE,CAAE,CAC7B,CACN,CAAC,EACZI,aAAa,iBACZvD,MAAA,CAAAgD,OAAA,CAAAS,aAAA,CAAC/C,eAAA,CAAAoE,cAAc;IACbC,OAAO,eACL/E,MAAA,CAAAgD,OAAA,CAAAS,aAAA,CAAC/C,eAAA,CAAAsE,OAAO;MAACC,EAAE,EAAC,SAAS;MAACC,SAAS,EAAC;IAAM,gBACpClF,MAAA,CAAAgD,OAAA,CAAAS,aAAA,CAAChD,aAAA,CAAA0E,KAAK;MACJC,OAAO,EACL;IACD,CACF,CACM;EACV,gBAEDpF,MAAA,CAAAgD,OAAA,CAAAS,aAAA;IAAMI,SAAS,EAAE;EAAsB,gBACrC7D,MAAA,CAAAgD,OAAA,CAAAS,aAAA;IACE6B,GAAG,EAAE,IAAAC,kBAAW,EAAC,CAAE;IACnB1B,SAAS,EAAC,cAAc;IACxB2B,GAAG,EAAE;EAAU,CAChB,CACG,CACQ,CAEF,CACnB,eACDxF,MAAA,CAAAgD,OAAA,CAAAS,aAAA,CAACtD,WAAA,CAAA6C,OAAU;IACTI,KAAK,EAAEA,KAAM;IACbO,KAAK,EAAEpB,SAAU;IACjBkD,WAAW,eAAEzF,MAAA,CAAAgD,OAAA,CAAAS,aAAA,CAACrD,SAAA,CAAA4C,OAAQ;MAAClB,IAAI,EAAEF;IAAY,CAAE,CAAE;IAC7C8D,eAAe,EACbtE,SAAS,CAACS,UAAU,yBAAA8C,MAAA,CACMvD,SAAS,CAACS,UAAU,CAACoC,QAAQ,IACnD;EACL,gBAEDjE,MAAA,CAAAgD,OAAA,CAAAS,aAAA;IAAKI,SAAS,EAAE,cAAe;IAACF,KAAK,EAAEhC;EAAa,GACjDP,SAAS,CAACS,UAAU,IAAII,WAAW,IAAIP,QACrC,CACK,CACC,CAAC,EACfK,UAAU,iBAAI/B,MAAA,CAAAgD,OAAA,CAAAS,aAAA,CAACjD,SAAA,CAAAwC,OAAQ;IAACF,KAAK,EAAEX;EAAY,CAAE,CAC7C,CAAC;AAER,CAAC;AAAC,IAAAwD,QAAA,GACa9E,UAAU;AAAA+E,OAAA,CAAA5C,OAAA,GAAA2C,QAAA"}
|
|
@@ -1,43 +1,69 @@
|
|
|
1
|
-
.
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
1
|
+
.hierarchy-graph-page {
|
|
2
|
+
.sampler-icon-holder {
|
|
3
|
+
margin-inline-start: 33px;
|
|
4
|
+
|
|
5
|
+
.sampler-icon {
|
|
6
|
+
width: 45px;
|
|
7
|
+
position: static;
|
|
8
|
+
margin-bottom: -30px;
|
|
9
|
+
}
|
|
7
10
|
}
|
|
8
|
-
|
|
9
|
-
.filter-container {
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
11
|
+
|
|
12
|
+
.filter-container {
|
|
13
|
+
position: unset !important;
|
|
14
|
+
box-shadow: none;
|
|
15
|
+
padding-bottom: 0;
|
|
16
|
+
width: 100vw;
|
|
17
|
+
|
|
18
|
+
.filter-container__content__header {
|
|
19
|
+
justify-content: flex-start;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
.filter-container__content__body {
|
|
23
|
+
margin-inline-start: -15px;
|
|
24
|
+
|
|
25
|
+
.filter_item:first-child {
|
|
26
|
+
margin-inline-start: 15px;
|
|
27
|
+
}
|
|
28
|
+
}
|
|
16
29
|
}
|
|
17
|
-
.
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
30
|
+
.top {
|
|
31
|
+
.title {
|
|
32
|
+
color: #18191a;
|
|
33
|
+
a {
|
|
34
|
+
color: #18191a !important;
|
|
35
|
+
}
|
|
21
36
|
}
|
|
22
37
|
}
|
|
23
|
-
}
|
|
24
|
-
.node-content {
|
|
25
|
-
display: flex;
|
|
26
|
-
justify-content: center;
|
|
27
38
|
|
|
28
|
-
.
|
|
29
|
-
|
|
39
|
+
.highlight {
|
|
40
|
+
.top {
|
|
41
|
+
color: white;
|
|
42
|
+
background-color: #f59fb5 !important;
|
|
43
|
+
a {
|
|
44
|
+
color: white !important;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
30
47
|
}
|
|
31
48
|
|
|
32
|
-
.
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
font-size: 22px;
|
|
36
|
-
text-align: center;
|
|
49
|
+
.node-content {
|
|
50
|
+
display: flex;
|
|
51
|
+
justify-content: center;
|
|
37
52
|
|
|
38
|
-
.score
|
|
39
|
-
|
|
53
|
+
.score {
|
|
54
|
+
height: fit-content;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
.score-level {
|
|
58
|
+
width: fit-content;
|
|
59
|
+
line-height: 40px;
|
|
60
|
+
font-size: 22px;
|
|
40
61
|
text-align: center;
|
|
62
|
+
|
|
63
|
+
.score-item {
|
|
64
|
+
padding: 2px 8px;
|
|
65
|
+
text-align: center;
|
|
66
|
+
}
|
|
41
67
|
}
|
|
42
68
|
}
|
|
43
69
|
}
|
|
@@ -113,4 +113,4 @@ var ActionsContainer = _styledComponents.default.div.withConfig({
|
|
|
113
113
|
componentId: "sc-21qmj9-0"
|
|
114
114
|
})(["{}"]);
|
|
115
115
|
exports.ActionsContainer = ActionsContainer;
|
|
116
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["buildTree","connections","point_data","utility_name","nodes","children","Set","_iterator","_createForOfIteratorHelper2","default","_step","s","n","done","_step$value","value","source_point_id","target_point_id","distance","_ref","name","sourceData","_objectWithoutProperties2","_excluded","target_data","attributes","_objectSpread2","point_id","push","add","err","e","f","roots","Object","keys","filter","id","has","Number","map","length","mapById","items","reduce","acc","_ref2","has_device","group","area_name","props","_excluded2","monitored","type","shouldFilterOut","rd3tProps","selectedFilters","_rd3tProps$nodeDatum$","_rd3tProps$nodeDatum$2","_rd3tProps$nodeDatum$3","_selectedFilters$Poin","_rd3tProps$nodeDatum$4","_rd3tProps$nodeDatum$5","isMonitored","nodeDatum","siteId","sectorId","sector_id","filterBySite","SiteFilterItem","includes","filterBySector","SectorFilterItem","showOnlyMonitored","PointsModeFilterItem","toString","interestPointsFilter","InterestPointFilterItem","filterByInterestPoint","filterByArea","AreaFilterItem","area_id","exports","ActionsContainer","styled","div","withConfig","displayName","componentId"],"sources":["../../../src/ui-kit/HierarchyGraph/utils.ts"],"sourcesContent":["import { IPoint } from '../../store/points/models/IPoint';\nimport styled from 'styled-components/macro';\nimport React from 'react';\n\n/**\n * Convert edges to rows suitable for d3.stratify()\n * Returns an array of { id, parentId, distance?, shape_data? }\n * If multiple roots exist, you can optionally add a super root row.\n */\ntype Edge = {\n  source_point_id: number | string;\n  target_point_id: number | string;\n  distance?: number;\n};\ntype TreeNode = {\n  name: string;\n  children?: TreeNode[];\n  attributes?: { distance: number; type: string; monitored: boolean };\n};\nexport type TreeData = TreeNode | { name: string; children: TreeNode[] };\n\nexport function buildTree(\n  connections: Edge[],\n  point_data,\n  utility_name,\n): TreeData {\n  const nodes = {};\n  const children = new Set();\n\n  // Build map of nodes and track children\n  for (const { source_point_id, target_point_id, distance } of connections) {\n    const { name, ...sourceData } = point_data[source_point_id] || {};\n    if (!nodes[source_point_id])\n      nodes[source_point_id] = {\n        name,\n        children: [],\n      };\n    if (!nodes[target_point_id]) {\n      const target_data = point_data[target_point_id] || {};\n      nodes[target_point_id] = {\n        name: target_data.name,\n        attributes: {\n          ...target_data,\n          point_id: target_point_id,\n        },\n        children: [],\n      };\n    }\n    nodes[target_point_id].children.push(nodes[source_point_id]);\n    children.add(source_point_id);\n    nodes[source_point_id].attributes = {\n      distance,\n      ...sourceData,\n      point_id: source_point_id,\n    };\n  }\n\n  // Find root(s)\n  const roots = Object.keys(nodes)\n    .filter((id) => !children.has(Number(id)))\n    .map((id) => nodes[id]);\n\n  // If multiple roots exist, wrap in a super root\n  return roots.length === 1\n    ? roots[0]\n    : { name: utility_name, children: roots };\n}\ntype PointData = {\n  name: string;\n  monitored: boolean;\n  type: string;\n  area_name?: string;\n  score?: number;\n  pollution?: any;\n};\nexport function mapById(items: IPoint[]): Record<string | number, PointData> {\n  return items.reduce(\n    (acc, { id, name, has_device, group, area_name, ...props }) => {\n      acc[id] = {\n        ...props,\n        name,\n        monitored: has_device,\n        type: area_name ? 'area' : group.type,\n        area_name,\n      };\n      return acc;\n    },\n    {} as Record<string | number, PointData>,\n  );\n}\n\nexport type NodeProps = {\n  nodeDatum: {\n    name: string;\n    attributes?: {\n      score?: number;\n      type?: string;\n      point_id?: number | string;\n      area_name?: string;\n      monitored?: boolean;\n      pollution?: any;\n      sector_name?: string;\n      contributor_percents: number;\n    };\n    children?: any[];\n  };\n  children?: React.ReactNode;\n  searchTerm?: string;\n  toggleNode: () => void;\n  onNodeClick: (nodeData: any) => void;\n  contentStyle?: React.CSSProperties;\n  earlyAdopter?: boolean;\n  showSamplers?: boolean;\n};\nexport type InsightData = 'score' | 'pollution_contributor';\nexport const shouldFilterOut = (rd3tProps, selectedFilters) => {\n  const isMonitored = rd3tProps.nodeDatum.attributes?.monitored;\n  const siteId = rd3tProps.nodeDatum.attributes?.point_id;\n  const sectorId = rd3tProps.nodeDatum.attributes?.sector_id;\n  const filterBySite =\n    selectedFilters?.SiteFilterItem &&\n    !selectedFilters.SiteFilterItem.includes(siteId);\n  const filterBySector =\n    selectedFilters?.SectorFilterItem &&\n    !selectedFilters.SectorFilterItem.includes(sectorId);\n  const showOnlyMonitored =\n    selectedFilters?.PointsModeFilterItem?.toString() === 'monitored' || false;\n  const interestPointsFilter = selectedFilters?.InterestPointFilterItem || [];\n  const filterByInterestPoint =\n    interestPointsFilter.length > 0 &&\n    !interestPointsFilter.includes(rd3tProps.nodeDatum.attributes?.point_id);\n  const filterByArea =\n    selectedFilters?.AreaFilterItem &&\n    selectedFilters.AreaFilterItem.length > 0 &&\n    !selectedFilters.AreaFilterItem.includes(\n      rd3tProps.nodeDatum.attributes?.area_id,\n    );\n  return (\n    (showOnlyMonitored && !isMonitored) ||\n    filterBySite ||\n    filterByInterestPoint ||\n    filterByArea ||\n    filterBySector\n  );\n};\n\nexport const ActionsContainer = styled.div`\n   {\n    //text-align: center;\n  }\n`;\n"],"mappings":"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"}
|
|
116
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["buildTree","connections","point_data","utility_name","nodes","children","Set","_iterator","_createForOfIteratorHelper2","default","_step","s","n","done","_step$value","value","source_point_id","target_point_id","distance","_ref","name","sourceData","_objectWithoutProperties2","_excluded","target_data","attributes","_objectSpread2","point_id","push","add","err","e","f","roots","Object","keys","filter","id","has","Number","map","length","mapById","items","reduce","acc","_ref2","has_device","group","area_name","props","_excluded2","monitored","type","shouldFilterOut","rd3tProps","selectedFilters","_rd3tProps$nodeDatum$","_rd3tProps$nodeDatum$2","_rd3tProps$nodeDatum$3","_selectedFilters$Poin","_rd3tProps$nodeDatum$4","_rd3tProps$nodeDatum$5","isMonitored","nodeDatum","siteId","sectorId","sector_id","filterBySite","SiteFilterItem","includes","filterBySector","SectorFilterItem","showOnlyMonitored","PointsModeFilterItem","toString","interestPointsFilter","InterestPointFilterItem","filterByInterestPoint","filterByArea","AreaFilterItem","area_id","exports","ActionsContainer","styled","div","withConfig","displayName","componentId"],"sources":["../../../src/ui-kit/HierarchyGraph/utils.ts"],"sourcesContent":["import { IPoint } from '../../store/points/models/IPoint';\nimport styled from 'styled-components/macro';\nimport React from 'react';\n\n/**\n * Convert edges to rows suitable for d3.stratify()\n * Returns an array of { id, parentId, distance?, shape_data? }\n * If multiple roots exist, you can optionally add a super root row.\n */\ntype Edge = {\n  source_point_id: number | string;\n  target_point_id: number | string;\n  distance?: number;\n};\ntype TreeNode = {\n  name: string;\n  children?: TreeNode[];\n  attributes?: { distance: number; type: string; monitored: boolean };\n};\nexport type TreeData = TreeNode | { name: string; children: TreeNode[] };\n\nexport function buildTree(\n  connections: Edge[],\n  point_data,\n  utility_name,\n): TreeData {\n  const nodes = {};\n  const children = new Set();\n\n  // Build map of nodes and track children\n  for (const { source_point_id, target_point_id, distance } of connections) {\n    const { name, ...sourceData } = point_data[source_point_id] || {};\n    if (!nodes[source_point_id])\n      nodes[source_point_id] = {\n        name,\n        children: [],\n      };\n    if (!nodes[target_point_id]) {\n      const target_data = point_data[target_point_id] || {};\n      nodes[target_point_id] = {\n        name: target_data.name,\n        attributes: {\n          ...target_data,\n          point_id: target_point_id,\n        },\n        children: [],\n      };\n    }\n    nodes[target_point_id].children.push(nodes[source_point_id]);\n    children.add(source_point_id);\n    nodes[source_point_id].attributes = {\n      distance,\n      ...sourceData,\n      point_id: source_point_id,\n    };\n  }\n\n  // Find root(s)\n  const roots = Object.keys(nodes)\n    .filter((id) => !children.has(Number(id)))\n    .map((id) => nodes[id]);\n\n  // If multiple roots exist, wrap in a super root\n  return roots.length === 1\n    ? roots[0]\n    : { name: utility_name, children: roots };\n}\ntype PointData = {\n  name: string;\n  monitored: boolean;\n  type: string;\n  area_name?: string;\n  score?: number;\n  pollution?: any;\n};\nexport function mapById(items: IPoint[]): Record<string | number, PointData> {\n  return items.reduce(\n    (acc, { id, name, has_device, group, area_name, ...props }) => {\n      acc[id] = {\n        ...props,\n        name,\n        monitored: has_device,\n        type: area_name ? 'area' : group.type,\n        area_name,\n      };\n      return acc;\n    },\n    {} as Record<string | number, PointData>,\n  );\n}\n\nexport type NodeProps = {\n  nodeDatum: {\n    name: string;\n    attributes?: {\n      score?: number;\n      type?: string;\n      point_id?: number | string;\n      area_name?: string;\n      monitored?: boolean;\n      pollution?: any;\n      sector_name?: string;\n      contributor_percents: number;\n    };\n    children?: any[];\n  };\n  children?: React.ReactNode;\n  searchTerm?: string;\n  isHighlight: boolean;\n  toggleNode: () => void;\n  onNodeClick: (nodeData: any) => void;\n  contentStyle?: React.CSSProperties;\n  earlyAdopter?: boolean;\n  showSamplers?: boolean;\n};\nexport type InsightData = 'score' | 'pollution_contributor';\nexport const shouldFilterOut = (rd3tProps, selectedFilters) => {\n  const isMonitored = rd3tProps.nodeDatum.attributes?.monitored;\n  const siteId = rd3tProps.nodeDatum.attributes?.point_id;\n  const sectorId = rd3tProps.nodeDatum.attributes?.sector_id;\n  const filterBySite =\n    selectedFilters?.SiteFilterItem &&\n    !selectedFilters.SiteFilterItem.includes(siteId);\n  const filterBySector =\n    selectedFilters?.SectorFilterItem &&\n    !selectedFilters.SectorFilterItem.includes(sectorId);\n  const showOnlyMonitored =\n    selectedFilters?.PointsModeFilterItem?.toString() === 'monitored' || false;\n  const interestPointsFilter = selectedFilters?.InterestPointFilterItem || [];\n  const filterByInterestPoint =\n    interestPointsFilter.length > 0 &&\n    !interestPointsFilter.includes(rd3tProps.nodeDatum.attributes?.point_id);\n  const filterByArea =\n    selectedFilters?.AreaFilterItem &&\n    selectedFilters.AreaFilterItem.length > 0 &&\n    !selectedFilters.AreaFilterItem.includes(\n      rd3tProps.nodeDatum.attributes?.area_id,\n    );\n  return (\n    (showOnlyMonitored && !isMonitored) ||\n    filterBySite ||\n    filterByInterestPoint ||\n    filterByArea ||\n    filterBySector\n  );\n};\n\nexport const ActionsContainer = styled.div`\n   {\n    //text-align: center;\n  }\n`;\n"],"mappings":"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"}
|