@kando-env/kando-ui 1.2.458-alpha.8 → 1.2.458

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.
Files changed (46) hide show
  1. package/lib/Widgets/Map/Map.js +3 -3
  2. package/lib/Widgets/Map/MapUtils.js +1 -2
  3. package/lib/Widgets/MostPolluting/Factories/FactoryBox/CardLayout.js +21 -6
  4. package/lib/Widgets/MostPolluting/components/PotentialImpact.test.js +2 -1
  5. package/lib/Widgets/PotentialImpactSummary/Icon.js +2 -1
  6. package/lib/components/DamageType/DamageType.js +3 -3
  7. package/lib/components/DischargeHeatmap/DischargeHeatmapContainer.js +2 -2
  8. package/lib/components/DischargeHeatmap/mocks/handlers.js +3 -3
  9. package/lib/components/Header/InfoBar/Search/SearchContainer.js +4 -3
  10. package/lib/components/TrendGraphNVL/TrendGraphNVL.js +2 -1
  11. package/lib/i18n/en.json +11 -4
  12. package/lib/macros/getVersion.js +2 -2
  13. package/lib/pages/CovidPage/components/TrendGraphNVL/TrendGraphNVL.js +2 -1
  14. package/lib/pages/EventsPage/EventsMapContainer/EventsMapContainerHelpers.js +2 -1
  15. package/lib/pages/EventsPage/events/event_info/EventSection.test.js +22 -21
  16. package/lib/pages/EventsPage/events/event_info/Header/Header.js +1 -1
  17. package/lib/pages/EventsPage/events/event_info/Header/HeaderContainer.js +1 -1
  18. package/lib/pages/EventsPage/events/event_info/Header/index.js +1 -1
  19. package/lib/pages/EventsPage/events/event_info/SeverityScore/index.js +1 -1
  20. package/lib/pages/EventsPage/events/event_info/Timelines/index.js +1 -1
  21. package/lib/pages/EventsPage/events/events_list/Filter/Filter.js +14 -3
  22. package/lib/pages/EventsPage/events/events_list/Filter/FilterContainer.js +24 -7
  23. package/lib/pages/EventsPage/events/events_list/Filter/FilterItem.js +4 -1
  24. package/lib/pages/EventsPage/events/events_list/Filter/FilterStyle.scss +27 -0
  25. package/lib/pages/EventsPage/events/events_list/Filter/OptionsDropDown.js +15 -3
  26. package/lib/pages/EventsPage/events/events_list/Filter/SingleSelect.js +76 -0
  27. package/lib/pages/SamplingsPage/SamplingsPage.js +4 -2
  28. package/lib/pages/SamplingsPage/style.module.scss +4 -0
  29. package/lib/store/filters/IFilterItem.js +1 -1
  30. package/lib/test/mocks/browser.js +1 -1
  31. package/lib/test/test-utils.js +1 -1
  32. package/lib/ui-kit/HierarchyGraph/AutoFitTree.js +21 -17
  33. package/lib/ui-kit/HierarchyGraph/HierarchyGraph.js +120 -16
  34. package/lib/ui-kit/HierarchyGraph/MicroStackedBar.js +18 -8
  35. package/lib/ui-kit/HierarchyGraph/NodeLayout.js +18 -33
  36. package/lib/ui-kit/HierarchyGraph/PollutionContributorNode.js +48 -0
  37. package/lib/ui-kit/HierarchyGraph/ScoreNode.js +35 -0
  38. package/lib/ui-kit/HierarchyGraph/style.scss +67 -31
  39. package/lib/ui-kit/HierarchyGraph/utils.js +16 -1
  40. package/lib/ui-kit/KandoTable/KandoTable.test.js +1 -1
  41. package/lib/utilities/Enum.js +4 -4
  42. package/lib/utilities/scoreToData.test.js +1 -1
  43. package/lib/utilities/urls.js +6 -1
  44. package/package.json +1 -1
  45. package/lib/ui-kit/HierarchyGraph/MicroStackedBarNode.js +0 -67
  46. package/lib/ui-kit/HierarchyGraph/PieNode.js +0 -26
@@ -0,0 +1,76 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.SingleSelect = SingleSelect;
9
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/slicedToArray"));
10
+ var _react = _interopRequireWildcard(require("react"));
11
+ var _reactMultiSelect = _interopRequireDefault(require("@kenshooui/react-multi-select"));
12
+ require("@kenshooui/react-multi-select/dist/style.css");
13
+ var _radioButtonChecked = _interopRequireDefault(require("react-icons/lib/md/radio-button-checked"));
14
+ var _radioButtonUnchecked = _interopRequireDefault(require("react-icons/lib/md/radio-button-unchecked"));
15
+ 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); }
16
+ 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; }
17
+ // items should be: [{ id, label, ... }, ...]
18
+ // value is a single item or null
19
+ // onChange gets called with the selected item (or null)
20
+ function SingleSelect(_ref) {
21
+ var items = _ref.items,
22
+ value = _ref.value,
23
+ onChange = _ref.onChange,
24
+ responsiveHeight = _ref.responsiveHeight,
25
+ wrapperClassName = _ref.wrapperClassName;
26
+ var _useState = (0, _react.useState)(value || []),
27
+ _useState2 = (0, _slicedToArray2.default)(_useState, 2),
28
+ selectedItems = _useState2[0],
29
+ setSelectedItems = _useState2[1];
30
+ var Item = function Item(_ref2) {
31
+ var item = _ref2.item,
32
+ checked = _ref2.checked;
33
+ return /*#__PURE__*/_react.default.createElement("div", {
34
+ style: {
35
+ display: 'flex',
36
+ alignItems: 'center',
37
+ lineHeight: '14px',
38
+ height: '100%',
39
+ margin: '12px'
40
+ },
41
+ onClick: function onClick() {
42
+ handleChange([item]);
43
+ }
44
+ }, /*#__PURE__*/_react.default.createElement("div", {
45
+ style: {
46
+ fontSize: '24px',
47
+ margin: '0 12px 0 0'
48
+ }
49
+ }, !checked ? /*#__PURE__*/_react.default.createElement(_radioButtonUnchecked.default, null) : /*#__PURE__*/_react.default.createElement(_radioButtonChecked.default, null)), item.label);
50
+ };
51
+ var handleChange = function handleChange(newSelectedItems) {
52
+ setSelectedItems(newSelectedItems);
53
+ onChange(newSelectedItems);
54
+ };
55
+ (0, _react.useEffect)(function () {
56
+ setSelectedItems(value);
57
+ }, [value]);
58
+ return /*#__PURE__*/_react.default.createElement(_reactMultiSelect.default, {
59
+ responsiveHeight: responsiveHeight - 40,
60
+ wrapperClassName: wrapperClassName,
61
+ items: items,
62
+ selectedItems: selectedItems
63
+ // onChange={handleChange}
64
+ ,
65
+ maxSelectedItems: 2,
66
+ showSearch: false,
67
+ showSelectAll: false
68
+ // 🔒 single selection
69
+ ,
70
+ itemRenderer: Item // 👈 radio UI instead of checkbox
71
+ // Optional tweaks:
72
+ ,
73
+ showSelectedItems: false // keep the right pane, like original UI
74
+ });
75
+ }
76
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVXaWxkY2FyZCIsInJlcXVpcmUiLCJfcmVhY3RNdWx0aVNlbGVjdCIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJfcmFkaW9CdXR0b25DaGVja2VkIiwiX3JhZGlvQnV0dG9uVW5jaGVja2VkIiwiX2dldFJlcXVpcmVXaWxkY2FyZENhY2hlIiwibm9kZUludGVyb3AiLCJXZWFrTWFwIiwiY2FjaGVCYWJlbEludGVyb3AiLCJjYWNoZU5vZGVJbnRlcm9wIiwib2JqIiwiX19lc01vZHVsZSIsIl90eXBlb2YiLCJkZWZhdWx0IiwiY2FjaGUiLCJoYXMiLCJnZXQiLCJuZXdPYmoiLCJoYXNQcm9wZXJ0eURlc2NyaXB0b3IiLCJPYmplY3QiLCJkZWZpbmVQcm9wZXJ0eSIsImdldE93blByb3BlcnR5RGVzY3JpcHRvciIsImtleSIsInByb3RvdHlwZSIsImhhc093blByb3BlcnR5IiwiY2FsbCIsImRlc2MiLCJzZXQiLCJTaW5nbGVTZWxlY3QiLCJfcmVmIiwiaXRlbXMiLCJ2YWx1ZSIsIm9uQ2hhbmdlIiwicmVzcG9uc2l2ZUhlaWdodCIsIndyYXBwZXJDbGFzc05hbWUiLCJfdXNlU3RhdGUiLCJ1c2VTdGF0ZSIsIl91c2VTdGF0ZTIiLCJfc2xpY2VkVG9BcnJheTIiLCJzZWxlY3RlZEl0ZW1zIiwic2V0U2VsZWN0ZWRJdGVtcyIsIkl0ZW0iLCJfcmVmMiIsIml0ZW0iLCJjaGVja2VkIiwiY3JlYXRlRWxlbWVudCIsInN0eWxlIiwiZGlzcGxheSIsImFsaWduSXRlbXMiLCJsaW5lSGVpZ2h0IiwiaGVpZ2h0IiwibWFyZ2luIiwib25DbGljayIsImhhbmRsZUNoYW5nZSIsImZvbnRTaXplIiwibGFiZWwiLCJuZXdTZWxlY3RlZEl0ZW1zIiwidXNlRWZmZWN0IiwibWF4U2VsZWN0ZWRJdGVtcyIsInNob3dTZWFyY2giLCJzaG93U2VsZWN0QWxsIiwiaXRlbVJlbmRlcmVyIiwic2hvd1NlbGVjdGVkSXRlbXMiXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvcGFnZXMvRXZlbnRzUGFnZS9ldmVudHMvZXZlbnRzX2xpc3QvRmlsdGVyL1NpbmdsZVNlbGVjdC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IHVzZUVmZmVjdCwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgTXVsdGlTZWxlY3QgZnJvbSAnQGtlbnNob291aS9yZWFjdC1tdWx0aS1zZWxlY3QnO1xuaW1wb3J0ICdAa2Vuc2hvb3VpL3JlYWN0LW11bHRpLXNlbGVjdC9kaXN0L3N0eWxlLmNzcyc7XG5pbXBvcnQgUmFkaW9DaGVja2VkSWNvbiBmcm9tICdyZWFjdC1pY29ucy9saWIvbWQvcmFkaW8tYnV0dG9uLWNoZWNrZWQnO1xuaW1wb3J0IFJhZGlvVW5jaGVja2VkSWNvbiBmcm9tICdyZWFjdC1pY29ucy9saWIvbWQvcmFkaW8tYnV0dG9uLXVuY2hlY2tlZCc7XG5cbi8vIGl0ZW1zIHNob3VsZCBiZTogW3sgaWQsIGxhYmVsLCAuLi4gfSwgLi4uXVxuLy8gdmFsdWUgaXMgYSBzaW5nbGUgaXRlbSBvciBudWxsXG4vLyBvbkNoYW5nZSBnZXRzIGNhbGxlZCB3aXRoIHRoZSBzZWxlY3RlZCBpdGVtIChvciBudWxsKVxuZXhwb3J0IGZ1bmN0aW9uIFNpbmdsZVNlbGVjdCh7XG4gIGl0ZW1zLFxuICB2YWx1ZSxcbiAgb25DaGFuZ2UsXG4gIHJlc3BvbnNpdmVIZWlnaHQsXG4gIHdyYXBwZXJDbGFzc05hbWUsXG59KSB7XG4gIGNvbnN0IFtzZWxlY3RlZEl0ZW1zLCBzZXRTZWxlY3RlZEl0ZW1zXSA9IHVzZVN0YXRlKHZhbHVlIHx8IFtdKTtcblxuICBjb25zdCBJdGVtID0gKHsgaXRlbSwgY2hlY2tlZCB9KSA9PiAoXG4gICAgPGRpdlxuICAgICAgc3R5bGU9e3tcbiAgICAgICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgICAgbGluZUhlaWdodDogJzE0cHgnLFxuICAgICAgICBoZWlnaHQ6ICcxMDAlJyxcbiAgICAgICAgbWFyZ2luOiAnMTJweCcsXG4gICAgICB9fVxuICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICBoYW5kbGVDaGFuZ2UoW2l0ZW1dKTtcbiAgICAgIH19XG4gICAgPlxuICAgICAgPGRpdiBzdHlsZT17eyBmb250U2l6ZTogJzI0cHgnLCBtYXJnaW46ICcwIDEycHggMCAwJyB9fT5cbiAgICAgICAgeyFjaGVja2VkID8gPFJhZGlvVW5jaGVja2VkSWNvbiAvPiA6IDxSYWRpb0NoZWNrZWRJY29uIC8+fVxuICAgICAgPC9kaXY+XG4gICAgICB7aXRlbS5sYWJlbH1cbiAgICA8L2Rpdj5cbiAgKTtcblxuICBjb25zdCBoYW5kbGVDaGFuZ2UgPSAobmV3U2VsZWN0ZWRJdGVtcykgPT4ge1xuICAgIHNldFNlbGVjdGVkSXRlbXMobmV3U2VsZWN0ZWRJdGVtcyk7XG4gICAgb25DaGFuZ2UobmV3U2VsZWN0ZWRJdGVtcyk7XG4gIH07XG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBzZXRTZWxlY3RlZEl0ZW1zKHZhbHVlKTtcbiAgfSwgW3ZhbHVlXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8TXVsdGlTZWxlY3RcbiAgICAgIHJlc3BvbnNpdmVIZWlnaHQ9e3Jlc3BvbnNpdmVIZWlnaHQgLSA0MH1cbiAgICAgIHdyYXBwZXJDbGFzc05hbWU9e3dyYXBwZXJDbGFzc05hbWV9XG4gICAgICBpdGVtcz17aXRlbXN9XG4gICAgICBzZWxlY3RlZEl0ZW1zPXtzZWxlY3RlZEl0ZW1zfVxuICAgICAgLy8gb25DaGFuZ2U9e2hhbmRsZUNoYW5nZX1cbiAgICAgIG1heFNlbGVjdGVkSXRlbXM9ezJ9XG4gICAgICBzaG93U2VhcmNoPXtmYWxzZX1cbiAgICAgIHNob3dTZWxlY3RBbGw9e2ZhbHNlfVxuICAgICAgLy8g8J+UkiBzaW5nbGUgc2VsZWN0aW9uXG4gICAgICBpdGVtUmVuZGVyZXI9e0l0ZW19IC8vIPCfkYggcmFkaW8gVUkgaW5zdGVhZCBvZiBjaGVja2JveFxuICAgICAgLy8gT3B0aW9uYWwgdHdlYWtzOlxuICAgICAgc2hvd1NlbGVjdGVkSXRlbXM9e2ZhbHNlfSAvLyBrZWVwIHRoZSByaWdodCBwYW5lLCBsaWtlIG9yaWdpbmFsIFVJXG4gICAgLz5cbiAgKTtcbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUEsSUFBQUEsTUFBQSxHQUFBQyx1QkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsaUJBQUEsR0FBQUMsc0JBQUEsQ0FBQUYsT0FBQTtBQUNBQSxPQUFBO0FBQ0EsSUFBQUcsbUJBQUEsR0FBQUQsc0JBQUEsQ0FBQUYsT0FBQTtBQUNBLElBQUFJLHFCQUFBLEdBQUFGLHNCQUFBLENBQUFGLE9BQUE7QUFBMkUsU0FBQUsseUJBQUFDLFdBQUEsZUFBQUMsT0FBQSxrQ0FBQUMsaUJBQUEsT0FBQUQsT0FBQSxRQUFBRSxnQkFBQSxPQUFBRixPQUFBLFlBQUFGLHdCQUFBLFlBQUFBLHlCQUFBQyxXQUFBLFdBQUFBLFdBQUEsR0FBQUcsZ0JBQUEsR0FBQUQsaUJBQUEsS0FBQUYsV0FBQTtBQUFBLFNBQUFQLHdCQUFBVyxHQUFBLEVBQUFKLFdBQUEsU0FBQUEsV0FBQSxJQUFBSSxHQUFBLElBQUFBLEdBQUEsQ0FBQUMsVUFBQSxXQUFBRCxHQUFBLFFBQUFBLEdBQUEsYUFBQUUsT0FBQSxDQUFBRixHQUFBLHlCQUFBQSxHQUFBLDRCQUFBRyxPQUFBLEVBQUFILEdBQUEsVUFBQUksS0FBQSxHQUFBVCx3QkFBQSxDQUFBQyxXQUFBLE9BQUFRLEtBQUEsSUFBQUEsS0FBQSxDQUFBQyxHQUFBLENBQUFMLEdBQUEsWUFBQUksS0FBQSxDQUFBRSxHQUFBLENBQUFOLEdBQUEsU0FBQU8sTUFBQSxXQUFBQyxxQkFBQSxHQUFBQyxNQUFBLENBQUFDLGNBQUEsSUFBQUQsTUFBQSxDQUFBRSx3QkFBQSxXQUFBQyxHQUFBLElBQUFaLEdBQUEsUUFBQVksR0FBQSxrQkFBQUgsTUFBQSxDQUFBSSxTQUFBLENBQUFDLGNBQUEsQ0FBQUMsSUFBQSxDQUFB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
@@ -101,7 +101,9 @@ var SamplingsPage = function SamplingsPage(_ref) {
101
101
  downloadData: downloadData
102
102
  }), /*#__PURE__*/_react.default.createElement(_NewSamplingAction.default, {
103
103
  waterAuthorityId: waterAuthorityId
104
- })))), !_reactDeviceDetect.isMobile && samplings.length > 0 && /*#__PURE__*/_react.default.createElement(_uiKit.KandoTable, {
104
+ })))), !_reactDeviceDetect.isMobile && samplings.length === 0 && /*#__PURE__*/_react.default.createElement("div", {
105
+ className: _styleModule.default.noDataMessage
106
+ }, _i18n.default.t('samplings_page.no_samplings_message')), !_reactDeviceDetect.isMobile && samplings.length > 0 && /*#__PURE__*/_react.default.createElement(_uiKit.KandoTable, {
105
107
  data: samplings,
106
108
  totalRows: totalRows,
107
109
  columns: columns,
@@ -123,4 +125,4 @@ var SamplingsPage = function SamplingsPage(_ref) {
123
125
  }));
124
126
  };
125
127
  exports.SamplingsPage = SamplingsPage;
126
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_uiKit","_i18n","_interopRequireDefault","_samplingsPageUtils","_reactRedux","_Analytics","_actions","_reactDeviceDetect","_SamplingsMobileList","_NewSamplingAction","_styleModule","_FilterContainer","_DesktopActions","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","SamplingsPageTitle","styled","h1","withConfig","displayName","componentId","props","isMobile","exports","SamplingsPage","_ref","columns","handleSort","onSetPerPage","onChangePage","getValuesFromKQL","downloadData","waterAuthorityId","useSelector","state","global_data","waterAuthorityName","dispatch","useDispatch","useEffect","analyticsTrack","updateNavContext","name","utility_name","_useSelector","samplings_data","totalRows","isFetch","samplings","PAGINATION_COMPONENT_OPTIONS","rowsPerPageText","i18n","t","rangeSeparatorText","selectAllRowsItemText","customTableStyles","headCells","style","paddingLeft","paddingRight","cells","createElement","className","concat","Style","samplingsLayout","topPanelWrapper","filterPopupOpen","fetchType","applyLogic","topPanel","samplingsResults","length","Fragment","desktopActions","KandoTable","data","expandableRows","isPaginationServer","isSortServer","progressPending","paginationRowsPerPageOptions","ROWS_PER_PAGE_OPTIONS","paginationPerPage","TABLE_PAGINATION_PER_PAGE","defaultSortFieldId","DEFAULT_SORTFIELD","pagination","paginationComponentOptions","customStyles"],"sources":["../../../src/pages/SamplingsPage/SamplingsPage.tsx"],"sourcesContent":["import React, { FC, useEffect } from 'react';\nimport { PaginationOptions, TableColumn } from 'react-data-table-component';\nimport { KandoTable } from 'src/ui-kit';\nimport i18n from 'src/utilities/i18n';\nimport styled from 'styled-components/macro';\nimport {\n  SamplingData,\n  ROWS_PER_PAGE_OPTIONS,\n  TABLE_PAGINATION_PER_PAGE,\n  DEFAULT_SORTFIELD,\n} from './samplingsPageUtils';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { analyticsTrack } from 'src/utilities/Analytics';\nimport { updateNavContext } from 'src/store/context/actions';\nimport { isMobile } from 'react-device-detect';\nimport { appReducer } from 'src/store/rootReducer';\nimport SamplingsMobileList from './SamplingsMobileList';\nimport NewSamplingAction from 'src/pages/SamplingsPage/NewSamplingAction';\nimport Style from './style.module.scss';\nimport './table.styles.scss';\nimport './FilterStyle.scss';\nimport FilterContainer from '../EventsPage/events/events_list/Filter/FilterContainer';\nimport { IDownloadProps } from './DesktopActions/DownloadCSV';\nimport DesktopActions from './DesktopActions';\n\ninterface SamplingsPageProps {\n  columns: TableColumn<SamplingData>[];\n  handleSort: (\n    column: TableColumn<SamplingData>,\n    sortDirection: string,\n  ) => void;\n  onSetPerPage?: (currentRowsPerPage: number, currentPage: number) => void;\n  onChangePage?: (page: number) => void;\n  getValuesFromKQL?: (values: string) => void;\n  downloadData: IDownloadProps;\n}\n\ninterface h1Props {\n  isMobile?: boolean;\n}\n\nexport const SamplingsPageTitle = styled.h1<h1Props>`\n  display: flex;\n  font-size: ${(props) => (props.isMobile ? '32' : '40')}px;\n`;\n\nexport const SamplingsPage: FC<SamplingsPageProps> = ({\n  columns,\n  handleSort,\n  onSetPerPage,\n  onChangePage,\n  getValuesFromKQL,\n  downloadData,\n}) => {\n  const waterAuthorityId: number = useSelector(\n    (state: ReturnType<typeof appReducer>) =>\n      state.global_data.waterAuthorityId,\n  );\n  const waterAuthorityName = useSelector(\n    (state) => state.global_data.waterAuthorityName,\n  );\n\n  const dispatch = useDispatch();\n  useEffect(() => {\n    analyticsTrack('Viewed Sampling Operations Page');\n    dispatch(\n      updateNavContext({\n        name: 'samplings-list',\n        utility_name: waterAuthorityName,\n      }),\n    );\n  }, []);\n\n  const { totalRows, isFetch, samplings } = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.samplings_data,\n  );\n\n  const PAGINATION_COMPONENT_OPTIONS: PaginationOptions = {\n    rowsPerPageText: i18n.t('components.data_table.rows_per_page') + ':',\n    rangeSeparatorText: i18n.t('components.data_table.of'),\n    selectAllRowsItemText: i18n.t('all'),\n  };\n\n  // reduce columns' spacing\n  const customTableStyles = {\n    headCells: {\n      style: {\n        paddingLeft: '4px',\n        paddingRight: '4px',\n      },\n    },\n    cells: {\n      style: {\n        paddingLeft: '4px',\n        paddingRight: '4px',\n      },\n    },\n  };\n\n  return (\n    <div className={`${Style.samplingsLayout} samplingsLayout`}>\n      <div className={Style.topPanelWrapper}>\n        <SamplingsPageTitle isMobile={isMobile}>\n          {i18n.t('samplings_page.page_title')}\n        </SamplingsPageTitle>\n\n        <FilterContainer\n          filterPopupOpen={true}\n          fetchType={'SamplingFilter'}\n          applyLogic={getValuesFromKQL}\n        />\n\n        <div className={Style.topPanel}>\n          <div className={Style.samplingsResults}>\n            {samplings.length > 0 && (\n              <>\n                <span data-test-id=\"total-rows\">{totalRows}</span>\n                {i18n.t('general.results')}\n              </>\n            )}\n          </div>\n          <div className={`${isMobile ? '' : Style.desktopActions}`}>\n            <DesktopActions downloadData={downloadData} />\n            <NewSamplingAction waterAuthorityId={waterAuthorityId} />\n          </div>\n        </div>\n      </div>\n      {!isMobile && samplings.length > 0 && (\n        <KandoTable\n          data={samplings}\n          totalRows={totalRows}\n          columns={columns}\n          expandableRows={false}\n          handleSort={handleSort}\n          onSetPerPage={onSetPerPage}\n          onChangePage={onChangePage}\n          isPaginationServer={true}\n          isSortServer={true}\n          progressPending={isFetch}\n          paginationRowsPerPageOptions={ROWS_PER_PAGE_OPTIONS}\n          paginationPerPage={TABLE_PAGINATION_PER_PAGE}\n          defaultSortFieldId={DEFAULT_SORTFIELD}\n          pagination={true}\n          paginationComponentOptions={PAGINATION_COMPONENT_OPTIONS}\n          customStyles={customTableStyles}\n        />\n      )}\n      {isMobile && (\n        <SamplingsMobileList\n          samplings={samplings.length > 0 ? samplings : []}\n        />\n      )}\n    </div>\n  );\n};\n"],"mappings":"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"}
128
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_uiKit","_i18n","_interopRequireDefault","_samplingsPageUtils","_reactRedux","_Analytics","_actions","_reactDeviceDetect","_SamplingsMobileList","_NewSamplingAction","_styleModule","_FilterContainer","_DesktopActions","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","SamplingsPageTitle","styled","h1","withConfig","displayName","componentId","props","isMobile","exports","SamplingsPage","_ref","columns","handleSort","onSetPerPage","onChangePage","getValuesFromKQL","downloadData","waterAuthorityId","useSelector","state","global_data","waterAuthorityName","dispatch","useDispatch","useEffect","analyticsTrack","updateNavContext","name","utility_name","_useSelector","samplings_data","totalRows","isFetch","samplings","PAGINATION_COMPONENT_OPTIONS","rowsPerPageText","i18n","t","rangeSeparatorText","selectAllRowsItemText","customTableStyles","headCells","style","paddingLeft","paddingRight","cells","createElement","className","concat","Style","samplingsLayout","topPanelWrapper","filterPopupOpen","fetchType","applyLogic","topPanel","samplingsResults","length","Fragment","desktopActions","noDataMessage","KandoTable","data","expandableRows","isPaginationServer","isSortServer","progressPending","paginationRowsPerPageOptions","ROWS_PER_PAGE_OPTIONS","paginationPerPage","TABLE_PAGINATION_PER_PAGE","defaultSortFieldId","DEFAULT_SORTFIELD","pagination","paginationComponentOptions","customStyles"],"sources":["../../../src/pages/SamplingsPage/SamplingsPage.tsx"],"sourcesContent":["import React, { FC, useEffect } from 'react';\nimport { PaginationOptions, TableColumn } from 'react-data-table-component';\nimport { KandoTable } from 'src/ui-kit';\nimport i18n from 'src/utilities/i18n';\nimport styled from 'styled-components/macro';\nimport {\n  SamplingData,\n  ROWS_PER_PAGE_OPTIONS,\n  TABLE_PAGINATION_PER_PAGE,\n  DEFAULT_SORTFIELD,\n} from './samplingsPageUtils';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { analyticsTrack } from 'src/utilities/Analytics';\nimport { updateNavContext } from 'src/store/context/actions';\nimport { isMobile } from 'react-device-detect';\nimport { appReducer } from 'src/store/rootReducer';\nimport SamplingsMobileList from './SamplingsMobileList';\nimport NewSamplingAction from 'src/pages/SamplingsPage/NewSamplingAction';\nimport Style from './style.module.scss';\nimport './table.styles.scss';\nimport './FilterStyle.scss';\nimport FilterContainer from '../EventsPage/events/events_list/Filter/FilterContainer';\nimport { IDownloadProps } from './DesktopActions/DownloadCSV';\nimport DesktopActions from './DesktopActions';\n\ninterface SamplingsPageProps {\n  columns: TableColumn<SamplingData>[];\n  handleSort: (\n    column: TableColumn<SamplingData>,\n    sortDirection: string,\n  ) => void;\n  onSetPerPage?: (currentRowsPerPage: number, currentPage: number) => void;\n  onChangePage?: (page: number) => void;\n  getValuesFromKQL?: (values: string) => void;\n  downloadData: IDownloadProps;\n}\n\ninterface h1Props {\n  isMobile?: boolean;\n}\n\nexport const SamplingsPageTitle = styled.h1<h1Props>`\n  display: flex;\n  font-size: ${(props) => (props.isMobile ? '32' : '40')}px;\n`;\n\nexport const SamplingsPage: FC<SamplingsPageProps> = ({\n  columns,\n  handleSort,\n  onSetPerPage,\n  onChangePage,\n  getValuesFromKQL,\n  downloadData,\n}) => {\n  const waterAuthorityId: number = useSelector(\n    (state: ReturnType<typeof appReducer>) =>\n      state.global_data.waterAuthorityId,\n  );\n  const waterAuthorityName = useSelector(\n    (state) => state.global_data.waterAuthorityName,\n  );\n\n  const dispatch = useDispatch();\n  useEffect(() => {\n    analyticsTrack('Viewed Sampling Operations Page');\n    dispatch(\n      updateNavContext({\n        name: 'samplings-list',\n        utility_name: waterAuthorityName,\n      }),\n    );\n  }, []);\n\n  const { totalRows, isFetch, samplings } = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.samplings_data,\n  );\n\n  const PAGINATION_COMPONENT_OPTIONS: PaginationOptions = {\n    rowsPerPageText: i18n.t('components.data_table.rows_per_page') + ':',\n    rangeSeparatorText: i18n.t('components.data_table.of'),\n    selectAllRowsItemText: i18n.t('all'),\n  };\n\n  // reduce columns' spacing\n  const customTableStyles = {\n    headCells: {\n      style: {\n        paddingLeft: '4px',\n        paddingRight: '4px',\n      },\n    },\n    cells: {\n      style: {\n        paddingLeft: '4px',\n        paddingRight: '4px',\n      },\n    },\n  };\n\n  return (\n    <div className={`${Style.samplingsLayout} samplingsLayout`}>\n      <div className={Style.topPanelWrapper}>\n        <SamplingsPageTitle isMobile={isMobile}>\n          {i18n.t('samplings_page.page_title')}\n        </SamplingsPageTitle>\n\n        <FilterContainer\n          filterPopupOpen={true}\n          fetchType={'SamplingFilter'}\n          applyLogic={getValuesFromKQL}\n        />\n\n        <div className={Style.topPanel}>\n          <div className={Style.samplingsResults}>\n            {samplings.length > 0 && (\n              <>\n                <span data-test-id=\"total-rows\">{totalRows}</span>\n                {i18n.t('general.results')}\n              </>\n            )}\n          </div>\n          <div className={`${isMobile ? '' : Style.desktopActions}`}>\n            <DesktopActions downloadData={downloadData} />\n            <NewSamplingAction waterAuthorityId={waterAuthorityId} />\n          </div>\n        </div>\n      </div>\n      {!isMobile && samplings.length === 0 && (\n        <div className={Style.noDataMessage}>\n          {i18n.t('samplings_page.no_samplings_message')}\n        </div>\n      )}\n      {!isMobile && samplings.length > 0 && (\n        <KandoTable\n          data={samplings}\n          totalRows={totalRows}\n          columns={columns}\n          expandableRows={false}\n          handleSort={handleSort}\n          onSetPerPage={onSetPerPage}\n          onChangePage={onChangePage}\n          isPaginationServer={true}\n          isSortServer={true}\n          progressPending={isFetch}\n          paginationRowsPerPageOptions={ROWS_PER_PAGE_OPTIONS}\n          paginationPerPage={TABLE_PAGINATION_PER_PAGE}\n          defaultSortFieldId={DEFAULT_SORTFIELD}\n          pagination={true}\n          paginationComponentOptions={PAGINATION_COMPONENT_OPTIONS}\n          customStyles={customTableStyles}\n        />\n      )}\n      {isMobile && (\n        <SamplingsMobileList\n          samplings={samplings.length > 0 ? samplings : []}\n        />\n      )}\n    </div>\n  );\n};\n"],"mappings":"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"}
@@ -244,3 +244,7 @@ $color-kh1: #e73d7a;
244
244
  }
245
245
  }
246
246
  }
247
+ .noDataMessage {
248
+ height: 100vh;
249
+ margin-inline-start: 20px;
250
+ }
@@ -3,4 +3,4 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3N0b3JlL2ZpbHRlcnMvSUZpbHRlckl0ZW0udHMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBJRmlsdGVySXRlbSB7XG4gIGlkOiBudW1iZXI7XG4gIGZpbHRlcl9pZDogbnVtYmVyO1xuICB0eXBlOiBzdHJpbmc7XG4gIHNlbGVjdGVkX29wdGlvbnM6IGFueVtdO1xuICBhdmFpbGFibGVfb3B0aW9uczogYW55W107XG4gIGNyZWF0ZWRfYXQ6IHN0cmluZztcbiAgdXBkYXRlZF9hdDogc3RyaW5nO1xufVxuIl0sIm1hcHBpbmdzIjoiIn0=
6
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3N0b3JlL2ZpbHRlcnMvSUZpbHRlckl0ZW0udHMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBJRmlsdGVySXRlbSB7XG4gIGlkOiBudW1iZXI7XG4gIGZpbHRlcl9pZDogbnVtYmVyO1xuICBtYXhfc2VsZWN0ZWRfaXRlbXM6IG51bWJlcjtcbiAgdHlwZTogc3RyaW5nO1xuICBzZWxlY3RlZF9vcHRpb25zOiBhbnlbXTtcbiAgYXZhaWxhYmxlX29wdGlvbnM6IGFueVtdO1xuICBjcmVhdGVkX2F0OiBzdHJpbmc7XG4gIHVwZGF0ZWRfYXQ6IHN0cmluZztcbn1cbiJdLCJtYXBwaW5ncyI6IiJ9
@@ -16,4 +16,4 @@ var _handlers = require("components/DischargeHeatmap/mocks/handlers");
16
16
  // This configures a Service Worker with the given request handlers.
17
17
  var worker = _msw.setupWorker.apply(void 0, (0, _toConsumableArray2.default)(_handlers.handlers));
18
18
  exports.worker = worker;
19
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfbXN3IiwicmVxdWlyZSIsIl9oYW5kbGVycyIsIndvcmtlciIsInNldHVwV29ya2VyIiwiYXBwbHkiLCJfdG9Db25zdW1hYmxlQXJyYXkyIiwiZGVmYXVsdCIsImhhbmRsZXJzIiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy90ZXN0L21vY2tzL2Jyb3dzZXIuanMiXSwic291cmNlc0NvbnRlbnQiOlsiLy8gVGhpcyBpcyByZXF1aXJlZCBmb3IgTVNXLlxuXG5pbXBvcnQgeyBzZXR1cFdvcmtlciB9IGZyb20gJ21zdyc7XG5cbi8vIEJlbG93IGFkZCB0aGUgbGlzdCBvZiBoYW5kbGVycyAobW9ja3MpIC0gcmVhZCBodHRwczovL21zd2pzLmlvL2RvY3MvYXBpL3Jlc3Rcbi8vIFRPRE86IHRoaXMgaXMgdW5uZWVkZWQsIGxlYXZpbmcgZm9yIG5vd1xuaW1wb3J0IHsgaGFuZGxlcnMgfSBmcm9tICdzcmMvY29tcG9uZW50cy9EaXNjaGFyZ2VIZWF0bWFwL21vY2tzL2hhbmRsZXJzJztcblxuLy8gVGhpcyBjb25maWd1cmVzIGEgU2VydmljZSBXb3JrZXIgd2l0aCB0aGUgZ2l2ZW4gcmVxdWVzdCBoYW5kbGVycy5cbmV4cG9ydCBjb25zdCB3b3JrZXIgPSBzZXR1cFdvcmtlciguLi5oYW5kbGVycyk7XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBRUEsSUFBQUEsSUFBQSxHQUFBQyxPQUFBO0FBSUEsSUFBQUMsU0FBQSxHQUFBRCxPQUFBO0FBTkE7O0FBSUE7QUFDQTs7QUFHQTtBQUNPLElBQU1FLE1BQU0sR0FBR0MsZ0JBQVcsQ0FBQUMsS0FBQSxhQUFBQyxtQkFBQSxDQUFBQyxPQUFBLEVBQUlDLGtCQUFRLEVBQUM7QUFBQ0MsT0FBQSxDQUFBTixNQUFBLEdBQUFBLE1BQUEifQ==
19
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfbXN3IiwicmVxdWlyZSIsIl9oYW5kbGVycyIsIndvcmtlciIsInNldHVwV29ya2VyIiwiYXBwbHkiLCJfdG9Db25zdW1hYmxlQXJyYXkyIiwiZGVmYXVsdCIsImhhbmRsZXJzIiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy90ZXN0L21vY2tzL2Jyb3dzZXIuanMiXSwic291cmNlc0NvbnRlbnQiOlsiLy8gVGhpcyBpcyByZXF1aXJlZCBmb3IgTVNXLlxuXG5pbXBvcnQgeyBzZXR1cFdvcmtlciB9IGZyb20gJ21zdydcblxuLy8gQmVsb3cgYWRkIHRoZSBsaXN0IG9mIGhhbmRsZXJzIChtb2NrcykgLSByZWFkIGh0dHBzOi8vbXN3anMuaW8vZG9jcy9hcGkvcmVzdFxuLy8gVE9ETzogdGhpcyBpcyB1bm5lZWRlZCwgbGVhdmluZyBmb3Igbm93XG5pbXBvcnQgeyBoYW5kbGVycyB9IGZyb20gJ3NyYy9jb21wb25lbnRzL0Rpc2NoYXJnZUhlYXRtYXAvbW9ja3MvaGFuZGxlcnMnXG5cbi8vIFRoaXMgY29uZmlndXJlcyBhIFNlcnZpY2UgV29ya2VyIHdpdGggdGhlIGdpdmVuIHJlcXVlc3QgaGFuZGxlcnMuXG5leHBvcnQgY29uc3Qgd29ya2VyID0gc2V0dXBXb3JrZXIoLi4uaGFuZGxlcnMpIl0sIm1hcHBpbmdzIjoiOzs7Ozs7OztBQUVBLElBQUFBLElBQUEsR0FBQUMsT0FBQTtBQUlBLElBQUFDLFNBQUEsR0FBQUQsT0FBQTtBQU5BOztBQUlBO0FBQ0E7O0FBR0E7QUFDTyxJQUFNRSxNQUFNLEdBQUdDLGdCQUFXLENBQUFDLEtBQUEsYUFBQUMsbUJBQUEsQ0FBQUMsT0FBQSxFQUFJQyxrQkFBUSxFQUFDO0FBQUFDLE9BQUEsQ0FBQU4sTUFBQSxHQUFBQSxNQUFBIn0=
@@ -48,4 +48,4 @@ function render(ui) {
48
48
  // re-export everything
49
49
 
50
50
  // override render method
51
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9yZWR1eCIsIl9yZWFjdDIiLCJPYmplY3QiLCJrZXlzIiwiZm9yRWFjaCIsImtleSIsInByb3RvdHlwZSIsImhhc093blByb3BlcnR5IiwiY2FsbCIsIl9leHBvcnROYW1lcyIsImV4cG9ydHMiLCJkZWZpbmVQcm9wZXJ0eSIsImVudW1lcmFibGUiLCJnZXQiLCJfcmVhY3RSZWR1eCIsIl9yb290UmVkdWNlciIsIl9leGNsdWRlZCIsInJlbmRlciIsInVpIiwiX3JlZiIsImFyZ3VtZW50cyIsImxlbmd0aCIsInVuZGVmaW5lZCIsImluaXRpYWxTdGF0ZSIsIl9yZWYkc3RvcmUiLCJzdG9yZSIsImNyZWF0ZVN0b3JlIiwicm9vdFJlZHVjZXIiLCJyZW5kZXJPcHRpb25zIiwiX29iamVjdFdpdGhvdXRQcm9wZXJ0aWVzMiIsImRlZmF1bHQiLCJXcmFwcGVyIiwiX3JlZjIiLCJjaGlsZHJlbiIsImNyZWF0ZUVsZW1lbnQiLCJQcm92aWRlciIsInJ0bFJlbmRlciIsIl9vYmplY3RTcHJlYWQyIiwid3JhcHBlciJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90ZXN0L3Rlc3QtdXRpbHMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGNyZWF0ZVN0b3JlIH0gZnJvbSAncmVkdXgnO1xuaW1wb3J0IHsgcmVuZGVyIGFzIHJ0bFJlbmRlciB9IGZyb20gJ0B0ZXN0aW5nLWxpYnJhcnkvcmVhY3QnO1xuaW1wb3J0IHsgUHJvdmlkZXIgfSBmcm9tICdyZWFjdC1yZWR1eCc7XG4vLyBJbXBvcnQgeW91ciBvd24gcmVkdWNlclxuaW1wb3J0IHsgcm9vdFJlZHVjZXIgfSBmcm9tICdzcmMvc3RvcmUvcm9vdFJlZHVjZXInO1xuaW1wb3J0ICdAdGVzdGluZy1saWJyYXJ5L2plc3QtZG9tL2V4dGVuZC1leHBlY3QnO1xuXG5mdW5jdGlvbiByZW5kZXIoXG4gIHVpLFxuICB7XG4gICAgaW5pdGlhbFN0YXRlLFxuICAgIHN0b3JlID0gY3JlYXRlU3RvcmUocm9vdFJlZHVjZXIsIGluaXRpYWxTdGF0ZSksXG4gICAgLi4ucmVuZGVyT3B0aW9uc1xuICB9ID0ge30sXG4pIHtcbiAgZnVuY3Rpb24gV3JhcHBlcih7IGNoaWxkcmVuIH0pIHtcbiAgICByZXR1cm4gPFByb3ZpZGVyIHN0b3JlPXtzdG9yZX0+e2NoaWxkcmVufTwvUHJvdmlkZXI+O1xuICB9XG4gIHJldHVybiBydGxSZW5kZXIodWksIHsgd3JhcHBlcjogV3JhcHBlciwgLi4ucmVuZGVyT3B0aW9ucyB9KTtcbn1cblxuLy8gcmUtZXhwb3J0IGV2ZXJ5dGhpbmdcbmV4cG9ydCAqIGZyb20gJ0B0ZXN0aW5nLWxpYnJhcnkvcmVhY3QnO1xuLy8gb3ZlcnJpZGUgcmVuZGVyIG1ldGhvZFxuZXhwb3J0IHsgcmVuZGVyIH07XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztBQUFBLElBQUFBLE1BQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUNBLElBQUFDLE1BQUEsR0FBQUQsT0FBQTtBQUNBLElBQUFFLE9BQUEsR0FBQUYsT0FBQTtBQXFCQUcsTUFBQSxDQUFBQyxJQUFBLENBQUFGLE9BQUEsRUFBQUcsT0FBQSxXQUFBQyxHQUFBO0VBQUEsSUFBQUEsR0FBQSxrQkFBQUEsR0FBQTtFQUFBLElBQUFILE1BQUEsQ0FBQUksU0FBQSxDQUFBQyxjQUFBLENBQUFDLElBQUEsQ0FBQUMsWUFBQSxFQUFBSixHQUFBO0VBQUEsSUFBQUEsR0FBQSxJQUFBSyxPQUFBLElBQUFBLE9BQUEsQ0FBQUwsR0FBQSxNQUFBSixPQUFBLENBQUFJLEdBQUE7RUFBQUgsTUFBQSxDQUFBUyxjQUFBLENBQUFELE9BQUEsRUFBQUwsR0FBQTtJQUFBTyxVQUFBO0lBQUFDLEdBQUEsV0FBQUEsSUFBQTtNQUFBLE9BQUFaLE9BQUEsQ0FBQUksR0FBQTtJQUFBO0VBQUE7QUFBQTtBQXBCQSxJQUFBUyxXQUFBLEdBQUFmLE9BQUE7QUFFQSxJQUFBZ0IsWUFBQSxHQUFBaEIsT0FBQTtBQUNBQSxPQUFBO0FBQWlELElBQUFpQixTQUFBLDhCQUZqRDtBQUlBLFNBQVNDLE1BQU1BLENBQ2JDLEVBQUUsRUFNRjtFQUFBLElBQUFDLElBQUEsR0FBQUMsU0FBQSxDQUFBQyxNQUFBLFFBQUFELFNBQUEsUUFBQUUsU0FBQSxHQUFBRixTQUFBLE1BREksQ0FBQyxDQUFDO0lBSEpHLFlBQVksR0FBQUosSUFBQSxDQUFaSSxZQUFZO0lBQUFDLFVBQUEsR0FBQUwsSUFBQSxDQUNaTSxLQUFLO0lBQUxBLEtBQUssR0FBQUQsVUFBQSxjQUFHLElBQUFFLGtCQUFXLEVBQUNDLHdCQUFXLEVBQUVKLFlBQVksQ0FBQyxHQUFBQyxVQUFBO0lBQzNDSSxhQUFhLE9BQUFDLHlCQUFBLENBQUFDLE9BQUEsRUFBQVgsSUFBQSxFQUFBSCxTQUFBO0VBR2xCLFNBQVNlLE9BQU9BLENBQUFDLEtBQUEsRUFBZTtJQUFBLElBQVpDLFFBQVEsR0FBQUQsS0FBQSxDQUFSQyxRQUFRO0lBQ3pCLG9CQUFPcEMsTUFBQSxDQUFBaUMsT0FBQSxDQUFBSSxhQUFBLENBQUNwQixXQUFBLENBQUFxQixRQUFRO01BQUNWLEtBQUssRUFBRUE7SUFBTSxHQUFFUSxRQUFtQixDQUFDO0VBQ3REO0VBQ0EsT0FBTyxJQUFBRyxjQUFTLEVBQUNsQixFQUFFLE1BQUFtQixjQUFBLENBQUFQLE9BQUE7SUFBSVEsT0FBTyxFQUFFUDtFQUFPLEdBQUtILGFBQWEsQ0FBRSxDQUFDO0FBQzlEOztBQUVBOztBQUVBIn0=
51
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9yZWR1eCIsIl9yZWFjdDIiLCJPYmplY3QiLCJrZXlzIiwiZm9yRWFjaCIsImtleSIsInByb3RvdHlwZSIsImhhc093blByb3BlcnR5IiwiY2FsbCIsIl9leHBvcnROYW1lcyIsImV4cG9ydHMiLCJkZWZpbmVQcm9wZXJ0eSIsImVudW1lcmFibGUiLCJnZXQiLCJfcmVhY3RSZWR1eCIsIl9yb290UmVkdWNlciIsIl9leGNsdWRlZCIsInJlbmRlciIsInVpIiwiX3JlZiIsImFyZ3VtZW50cyIsImxlbmd0aCIsInVuZGVmaW5lZCIsImluaXRpYWxTdGF0ZSIsIl9yZWYkc3RvcmUiLCJzdG9yZSIsImNyZWF0ZVN0b3JlIiwicm9vdFJlZHVjZXIiLCJyZW5kZXJPcHRpb25zIiwiX29iamVjdFdpdGhvdXRQcm9wZXJ0aWVzMiIsImRlZmF1bHQiLCJXcmFwcGVyIiwiX3JlZjIiLCJjaGlsZHJlbiIsImNyZWF0ZUVsZW1lbnQiLCJQcm92aWRlciIsInJ0bFJlbmRlciIsIl9vYmplY3RTcHJlYWQyIiwid3JhcHBlciJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90ZXN0L3Rlc3QtdXRpbHMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGNyZWF0ZVN0b3JlIH0gZnJvbSAncmVkdXgnO1xuaW1wb3J0IHsgcmVuZGVyIGFzIHJ0bFJlbmRlciB9IGZyb20gJ0B0ZXN0aW5nLWxpYnJhcnkvcmVhY3QnO1xuaW1wb3J0IHsgUHJvdmlkZXIgfSBmcm9tICdyZWFjdC1yZWR1eCc7XG4vLyBJbXBvcnQgeW91ciBvd24gcmVkdWNlclxuaW1wb3J0IHsgcm9vdFJlZHVjZXIgfSBmcm9tICdzcmMvc3RvcmUvcm9vdFJlZHVjZXInO1xuaW1wb3J0ICdAdGVzdGluZy1saWJyYXJ5L2plc3QtZG9tL2V4dGVuZC1leHBlY3QnO1xuXG5mdW5jdGlvbiByZW5kZXIoXG4gIHVpLFxuICB7XG4gICAgaW5pdGlhbFN0YXRlLFxuICAgIHN0b3JlID0gY3JlYXRlU3RvcmUocm9vdFJlZHVjZXIsIGluaXRpYWxTdGF0ZSksXG4gICAgLi4ucmVuZGVyT3B0aW9uc1xuICB9ID0ge31cbikge1xuICBmdW5jdGlvbiBXcmFwcGVyKHsgY2hpbGRyZW4gfSkge1xuICAgIHJldHVybiA8UHJvdmlkZXIgc3RvcmU9e3N0b3JlfT57Y2hpbGRyZW59PC9Qcm92aWRlcj5cbiAgfVxuICByZXR1cm4gcnRsUmVuZGVyKHVpLCB7IHdyYXBwZXI6IFdyYXBwZXIsIC4uLnJlbmRlck9wdGlvbnMgfSk7XG59XG5cbi8vIHJlLWV4cG9ydCBldmVyeXRoaW5nXG5leHBvcnQgKiBmcm9tICdAdGVzdGluZy1saWJyYXJ5L3JlYWN0Jztcbi8vIG92ZXJyaWRlIHJlbmRlciBtZXRob2RcbmV4cG9ydCB7IHJlbmRlciB9O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7QUFBQSxJQUFBQSxNQUFBLEdBQUFDLHNCQUFBLENBQUFDLE9BQUE7QUFDQSxJQUFBQyxNQUFBLEdBQUFELE9BQUE7QUFDQSxJQUFBRSxPQUFBLEdBQUFGLE9BQUE7QUFxQkFHLE1BQUEsQ0FBQUMsSUFBQSxDQUFBRixPQUFBLEVBQUFHLE9BQUEsV0FBQUMsR0FBQTtFQUFBLElBQUFBLEdBQUEsa0JBQUFBLEdBQUE7RUFBQSxJQUFBSCxNQUFBLENBQUFJLFNBQUEsQ0FBQUMsY0FBQSxDQUFBQyxJQUFBLENBQUFDLFlBQUEsRUFBQUosR0FBQTtFQUFBLElBQUFBLEdBQUEsSUFBQUssT0FBQSxJQUFBQSxPQUFBLENBQUFMLEdBQUEsTUFBQUosT0FBQSxDQUFBSSxHQUFBO0VBQUFILE1BQUEsQ0FBQVMsY0FBQSxDQUFBRCxPQUFBLEVBQUFMLEdBQUE7SUFBQU8sVUFBQTtJQUFBQyxHQUFBLFdBQUFBLElBQUE7TUFBQSxPQUFBWixPQUFBLENBQUFJLEdBQUE7SUFBQTtFQUFBO0FBQUE7QUFwQkEsSUFBQVMsV0FBQSxHQUFBZixPQUFBO0FBRUEsSUFBQWdCLFlBQUEsR0FBQWhCLE9BQUE7QUFDQUEsT0FBQTtBQUFpRCxJQUFBaUIsU0FBQSw4QkFGakQ7QUFJQSxTQUFTQyxNQUFNQSxDQUNiQyxFQUFFLEVBTUY7RUFBQSxJQUFBQyxJQUFBLEdBQUFDLFNBQUEsQ0FBQUMsTUFBQSxRQUFBRCxTQUFBLFFBQUFFLFNBQUEsR0FBQUYsU0FBQSxNQURJLENBQUMsQ0FBQztJQUhKRyxZQUFZLEdBQUFKLElBQUEsQ0FBWkksWUFBWTtJQUFBQyxVQUFBLEdBQUFMLElBQUEsQ0FDWk0sS0FBSztJQUFMQSxLQUFLLEdBQUFELFVBQUEsY0FBRyxJQUFBRSxrQkFBVyxFQUFDQyx3QkFBVyxFQUFFSixZQUFZLENBQUMsR0FBQUMsVUFBQTtJQUMzQ0ksYUFBYSxPQUFBQyx5QkFBQSxDQUFBQyxPQUFBLEVBQUFYLElBQUEsRUFBQUgsU0FBQTtFQUdsQixTQUFTZSxPQUFPQSxDQUFBQyxLQUFBLEVBQWU7SUFBQSxJQUFaQyxRQUFRLEdBQUFELEtBQUEsQ0FBUkMsUUFBUTtJQUN6QixvQkFBT3BDLE1BQUEsQ0FBQWlDLE9BQUEsQ0FBQUksYUFBQSxDQUFDcEIsV0FBQSxDQUFBcUIsUUFBUTtNQUFDVixLQUFLLEVBQUVBO0lBQU0sR0FBRVEsUUFBbUIsQ0FBQztFQUN0RDtFQUNBLE9BQU8sSUFBQUcsY0FBUyxFQUFDbEIsRUFBRSxNQUFBbUIsY0FBQSxDQUFBUCxPQUFBO0lBQUlRLE9BQU8sRUFBRVA7RUFBTyxHQUFLSCxhQUFhLENBQUUsQ0FBQztBQUM5RDs7QUFFQTs7QUFFQSJ9
@@ -10,10 +10,12 @@ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm
10
10
  var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/objectWithoutProperties"));
11
11
  var _react = _interopRequireWildcard(require("react"));
12
12
  var _reactD3Tree = _interopRequireDefault(require("react-d3-tree"));
13
- var _PieNode = _interopRequireDefault(require("./PieNode"));
14
- var _MicroStackedBarNode = _interopRequireDefault(require("./MicroStackedBarNode"));
13
+ var _ScoreNode = _interopRequireDefault(require("./ScoreNode"));
14
+ var _PollutionContributorNode = _interopRequireDefault(require("./PollutionContributorNode"));
15
+ var _utils = require("./utils");
15
16
  var _reactRedux = require("react-redux");
16
- var _excluded = ["data", "orientation", "initialDepth", "treeKey", "selectedFilters"];
17
+ var _reactRouterDom = require("react-router-dom");
18
+ var _excluded = ["data", "orientation", "initialDepth", "treeKey", "selectedFilters", "exceededSiteIds"];
17
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); }
18
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; }
19
21
  function countDepthAndBreadth(root) {
@@ -43,6 +45,8 @@ function AutoFitTree(_ref) {
43
45
  treeKey = _ref.treeKey,
44
46
  _ref$selectedFilters = _ref.selectedFilters,
45
47
  selectedFilters = _ref$selectedFilters === void 0 ? {} : _ref$selectedFilters,
48
+ _ref$exceededSiteIds = _ref.exceededSiteIds,
49
+ exceededSiteIds = _ref$exceededSiteIds === void 0 ? [] : _ref$exceededSiteIds,
46
50
  rest = (0, _objectWithoutProperties2.default)(_ref, _excluded);
47
51
  var PADDING = 42; // screen padding in px
48
52
  var wrapperRef = (0, _react.useRef)(null);
@@ -116,25 +120,25 @@ function AutoFitTree(_ref) {
116
120
  var clone = JSON.parse(JSON.stringify(data));
117
121
  return setCollapsedByDepth(clone, initialDepth);
118
122
  }, [data, initialDepth]);
123
+ var _useParams = (0, _reactRouterDom.useParams)(),
124
+ siteID = _useParams.siteID,
125
+ areaID = _useParams.areaID;
119
126
  var renderCustomNodeElement = function renderCustomNodeElement(rd3tProps) {
120
- var _rd3tProps$nodeDatum$, _rd3tProps$nodeDatum$2, _rd3tProps$nodeDatum$3, _selectedFilters$Poin, _selectedFilters$Samp, _rd3tProps$nodeDatum$4, _rd3tProps$nodeDatum$5;
127
+ var _selectedFilters$Samp, _selectedFilters$Insi, _rd3tProps$nodeDatum$, _rd3tProps$nodeDatum$2, _rd3tProps$nodeDatum$3, _rd3tProps$nodeDatum$4, _rd3tProps$nodeDatum$5;
121
128
  var isRoot = rd3tProps.nodeDatum.__rd3t.depth === 0;
122
- var isMonitored = (_rd3tProps$nodeDatum$ = rd3tProps.nodeDatum.attributes) === null || _rd3tProps$nodeDatum$ === void 0 ? void 0 : _rd3tProps$nodeDatum$.monitored;
123
- var siteId = (_rd3tProps$nodeDatum$2 = rd3tProps.nodeDatum.attributes) === null || _rd3tProps$nodeDatum$2 === void 0 ? void 0 : _rd3tProps$nodeDatum$2.point_id;
124
- var sectorId = (_rd3tProps$nodeDatum$3 = rd3tProps.nodeDatum.attributes) === null || _rd3tProps$nodeDatum$3 === void 0 ? void 0 : _rd3tProps$nodeDatum$3.sector_id;
125
- var filterBySite = (selectedFilters === null || selectedFilters === void 0 ? void 0 : selectedFilters.SiteFilterItem) && !selectedFilters.SiteFilterItem.includes(siteId);
126
- var filterBySector = (selectedFilters === null || selectedFilters === void 0 ? void 0 : selectedFilters.SectorFilterItem) && !selectedFilters.SectorFilterItem.includes(sectorId);
127
- var showOnlyMonitored = (selectedFilters === null || selectedFilters === void 0 ? void 0 : (_selectedFilters$Poin = selectedFilters.PointsModeFilterItem) === null || _selectedFilters$Poin === void 0 ? void 0 : _selectedFilters$Poin.toString()) === 'monitored' || false;
128
129
  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;
129
- var interestPointsFilter = (selectedFilters === null || selectedFilters === void 0 ? void 0 : selectedFilters.InterestPointFilterItem) || [];
130
- var filterByInterestPoint = interestPointsFilter.length > 0 && !interestPointsFilter.includes((_rd3tProps$nodeDatum$4 = rd3tProps.nodeDatum.attributes) === null || _rd3tProps$nodeDatum$4 === void 0 ? void 0 : _rd3tProps$nodeDatum$4.point_id);
131
- var filterByArea = (selectedFilters === null || selectedFilters === void 0 ? void 0 : selectedFilters.AreaFilterItem) && selectedFilters.AreaFilterItem.length > 0 && !selectedFilters.AreaFilterItem.includes((_rd3tProps$nodeDatum$5 = rd3tProps.nodeDatum.attributes) === null || _rd3tProps$nodeDatum$5 === void 0 ? void 0 : _rd3tProps$nodeDatum$5.area_id);
132
- var nodeType = (selectedFilters === null || selectedFilters === void 0 ? void 0 : selectedFilters.NodeTypeFilterItem) || 'pie';
133
- return !isRoot && (showOnlyMonitored && !isMonitored || filterBySite || filterByInterestPoint || filterByArea || filterBySector) ? /*#__PURE__*/_react.default.createElement("div", null) : nodeType === 'pie' ? /*#__PURE__*/_react.default.createElement(_PieNode.default, Object.assign({}, rd3tProps, {
130
+ var insightData = (selectedFilters === null || selectedFilters === void 0 ? void 0 : (_selectedFilters$Insi = selectedFilters.InsightDataFilterItem) === null || _selectedFilters$Insi === void 0 ? void 0 : _selectedFilters$Insi.toString()) || 'score';
131
+ 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());
132
+ var isExceeded = exceededSiteIds.includes((_rd3tProps$nodeDatum$5 = rd3tProps.nodeDatum.attributes) === null || _rd3tProps$nodeDatum$5 === void 0 ? void 0 : _rd3tProps$nodeDatum$5.point_id);
133
+ return !isRoot && (0, _utils.shouldFilterOut)(rd3tProps, selectedFilters) ? /*#__PURE__*/_react.default.createElement("div", null) : insightData === 'score' ? /*#__PURE__*/_react.default.createElement(_ScoreNode.default, Object.assign({}, rd3tProps, {
134
+ isHighlight: isHighlight,
135
+ isExceeded: isExceeded,
134
136
  onNodeClick: rest.onNodeClick,
135
137
  earlyAdopter: early_adopter,
136
138
  showSamplers: showSamplers
137
- })) : /*#__PURE__*/_react.default.createElement(_MicroStackedBarNode.default, Object.assign({}, rd3tProps, {
139
+ })) : /*#__PURE__*/_react.default.createElement(_PollutionContributorNode.default, Object.assign({}, rd3tProps, {
140
+ isExceeded: isExceeded,
141
+ isHighlight: isHighlight,
138
142
  onNodeClick: rest.onNodeClick,
139
143
  earlyAdopter: early_adopter,
140
144
  showSamplers: showSamplers
@@ -166,4 +170,4 @@ function AutoFitTree(_ref) {
166
170
  initialDepth: initialDepth
167
171
  }, rest)));
168
172
  }
169
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactD3Tree","_interopRequireDefault","_PieNode","_MicroStackedBarNode","_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","_rd3tProps$nodeDatum$","_rd3tProps$nodeDatum$2","_rd3tProps$nodeDatum$3","_selectedFilters$Poin","_selectedFilters$Samp","_rd3tProps$nodeDatum$4","_rd3tProps$nodeDatum$5","isRoot","nodeDatum","__rd3t","depth","isMonitored","attributes","monitored","siteId","point_id","sectorId","sector_id","filterBySite","SiteFilterItem","includes","filterBySector","SectorFilterItem","showOnlyMonitored","PointsModeFilterItem","toString","showSamplers","SamplerFilterItem","interestPointsFilter","InterestPointFilterItem","filterByInterestPoint","filterByArea","AreaFilterItem","area_id","nodeType","NodeTypeFilterItem","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 PieNode from './PieNode';\nimport MicroStackedBarNode from './MicroStackedBarNode';\nimport { NodeType } 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 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' ||\n      false;\n    const showSamplers =\n      selectedFilters?.SamplerFilterItem?.toString() === 'with' || 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    const nodeType = (selectedFilters?.NodeTypeFilterItem as NodeType) || 'pie';\n    return !isRoot &&\n      ((showOnlyMonitored && !isMonitored) ||\n        filterBySite ||\n        filterByInterestPoint ||\n        filterByArea ||\n        filterBySector) ? (\n      <div></div>\n    ) : nodeType === 'pie' ? (\n      <PieNode\n        {...rd3tProps}\n        onNodeClick={rest.onNodeClick}\n        earlyAdopter={early_adopter}\n        showSamplers={showSamplers}\n      />\n    ) : (\n      <MicroStackedBarNode\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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"}
173
+ //# 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","_ref$exceededSiteIds","exceededSiteIds","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","_rd3tProps$nodeDatum$5","isRoot","nodeDatum","__rd3t","depth","showSamplers","SamplerFilterItem","toString","insightData","InsightDataFilterItem","isHighlight","attributes","point_id","area_id","isExceeded","includes","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  exceededSiteIds = [],\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  exceededSiteIds?: number[];\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    const isExceeded = exceededSiteIds.includes(\n      rd3tProps.nodeDatum.attributes?.point_id,\n    );\n    return !isRoot && shouldFilterOut(rd3tProps, selectedFilters) ? (\n      <div></div>\n    ) : insightData === 'score' ? (\n      <ScoreNode\n        {...rd3tProps}\n        isHighlight={isHighlight}\n        isExceeded={isExceeded}\n        onNodeClick={rest.onNodeClick}\n        earlyAdopter={early_adopter}\n        showSamplers={showSamplers}\n      />\n    ) : (\n      <PollutionContributorNode\n        {...rd3tProps}\n        isExceeded={isExceeded}\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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"}