@kando-env/kando-ui 1.2.450 → 1.2.453
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 +41 -0
- package/lib/Widgets/MostPolluting/Factories/FactoryBox/FactoryBox.js +24 -29
- package/lib/Widgets/MostPolluting/Factories/FactoryBox/styles.js +2 -2
- package/lib/assets/icons/TopNavbar/GraphHierarchyIcon.js +77 -0
- package/lib/assets/icons/TopNavbar/index.js +9 -1
- package/lib/components/Header/InfoBar/InfoBar.js +20 -3
- package/lib/components/Links/StyledLink/StyledLink.js +16 -3
- package/lib/i18n/en.json +1 -0
- package/lib/macros/getVersion.js +1 -1
- package/lib/pages/OperationsPage/RightPanel.js +3 -3
- package/lib/store/permissions/permissionsSlice.js +5 -1
- package/lib/store/points/models/IPoint.js +1 -1
- package/lib/ui-kit/Dashboard/Dashboard.js +14 -6
- package/lib/ui-kit/HierarchyGraph/AutoFitTree.js +164 -0
- package/lib/ui-kit/HierarchyGraph/HierarchyGraph.js +196 -0
- package/lib/ui-kit/HierarchyGraph/LeafSign.js +60 -0
- package/lib/ui-kit/HierarchyGraph/MicroStackedBar.js +65 -0
- package/lib/ui-kit/HierarchyGraph/MicroStackedBarNode.js +59 -0
- package/lib/ui-kit/HierarchyGraph/NodeIcon.js +45 -0
- package/lib/ui-kit/HierarchyGraph/NodeLayout.js +110 -0
- package/lib/ui-kit/HierarchyGraph/PieNode.js +26 -0
- package/lib/ui-kit/HierarchyGraph/index.js +11 -0
- package/lib/ui-kit/HierarchyGraph/utils.js +101 -0
- package/lib/utilities/Truncate.js +4 -3
- package/package.json +2 -2
|
@@ -16,12 +16,12 @@ var _i18n = _interopRequireDefault(require("utilities/i18n"));
|
|
|
16
16
|
var _StyledLink = require("components/Links/StyledLink/StyledLink");
|
|
17
17
|
var _Button = _interopRequireDefault(require("ui-kit/Button/Button"));
|
|
18
18
|
var RightPanel = function RightPanel(_ref) {
|
|
19
|
-
var _point$group;
|
|
19
|
+
var _point$group, _point$issues;
|
|
20
20
|
var point = _ref.point,
|
|
21
21
|
className = _ref.className,
|
|
22
22
|
onClose = _ref.onClose;
|
|
23
23
|
// If not WWTP and has parent
|
|
24
|
-
var showDistance = (point === null || point === void 0 ? void 0 : (_point$group = point.group) === null || _point$group === void 0 ? void 0 : _point$group.type) !== 'Groups::WastewaterTreatmentPlant' && (point === null || point === void 0 ? void 0 : point.issues.every(function (issue) {
|
|
24
|
+
var showDistance = (point === null || point === void 0 ? void 0 : (_point$group = point.group) === null || _point$group === void 0 ? void 0 : _point$group.type) !== 'Groups::WastewaterTreatmentPlant' && (point === null || point === void 0 ? void 0 : (_point$issues = point.issues) === null || _point$issues === void 0 ? void 0 : _point$issues.every(function (issue) {
|
|
25
25
|
return issue.type !== 'no_parent';
|
|
26
26
|
}));
|
|
27
27
|
return /*#__PURE__*/_react.default.createElement("div", {
|
|
@@ -139,4 +139,4 @@ var RightPanel = function RightPanel(_ref) {
|
|
|
139
139
|
};
|
|
140
140
|
var _default = RightPanel;
|
|
141
141
|
exports.default = _default;
|
|
142
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_Card","_ListGroup","_reactI18next","_InfoTooltip","_i_Icon","_i18n","_StyledLink","_Button","RightPanel","_ref","_point$group","point","className","onClose","showDistance","group","type","issues","every","issue","default","createElement","style","maxWidth","margin","backgroundColor","Header","onClick","variant","Item","id","name","description","sector_name","has_device","device_status","Trans","i18nKey","concat","replace","water_consumption_per_day","toFixed","parent_distance","aeye_installation_height","diameter","length","src","iIcon","alt","map","key","InfoTooltip","title","i18n","t","data","message","alignToBottom","alternateIcon","Link","target","to","_default","exports"],"sources":["../../../src/pages/OperationsPage/RightPanel.tsx"],"sourcesContent":["import React from 'react';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport Card from 'react-bootstrap/Card';\nimport ListGroup from 'react-bootstrap/ListGroup';\nimport './OperationsPage.scss';\nimport { Trans } from 'react-i18next';\nimport { InfoTooltip } from 'src/ui-kit/InfoTooltip/InfoTooltip';\nimport iIcon from 'src/assets/icons/informationTooltip/i_Icon.svg';\nimport i18n from 'src/utilities/i18n';\nimport { Link } from 'src/components/Links/StyledLink/StyledLink';\nimport Button from 'src/ui-kit/Button/Button';\n\ntype RightPanelProps = {\n  point: IPoint | null;\n  className?: string;\n  onClose?: () => void;\n};\n\nconst RightPanel: React.FC<RightPanelProps> = ({\n  point,\n  className,\n  onClose,\n}) => {\n  // If not WWTP and has parent\n  const showDistance =\n    point?.group?.type !== 'Groups::WastewaterTreatmentPlant' &&\n    point?.issues.every((issue) => issue.type !== 'no_parent');\n\n  return (\n    <div className={className}>\n      <div className=\"drawer-body p-3\">\n        <Card\n          style={{\n            maxWidth: '600px',\n            margin: '0 auto',\n            backgroundColor: 'white',\n          }}\n        >\n          <Card.Header className=\"d-flex justify-content-between card-header\">\n            {'Manhole Details'}\n            <button className=\"close\" onClick={onClose}>\n              <span>&times;</span>\n            </button>\n          </Card.Header>\n          <ListGroup variant=\"flush\">\n            <ListGroup.Item className=\"list-item\">\n              <span className=\"list-item-label\">{'ID'}</span>\n              <span className=\"list-item-value\">{point?.id}</span>\n            </ListGroup.Item>\n            <ListGroup.Item className=\"list-item\">\n              <span className=\"list-item-label\">{'Name'}</span>\n              <span className=\"list-item-value\">{point?.name}</span>\n            </ListGroup.Item>\n            <ListGroup.Item className=\"list-item\">\n              <span className=\"list-item-label\">{'Description'}</span>\n              <span className=\"list-item-value\">{point?.description}</span>\n            </ListGroup.Item>\n            <ListGroup.Item className=\"list-item\">\n              <span className=\"list-item-label\">{'Sector'}</span>\n              <span className=\"list-item-value\">\n                {point?.group.sector_name}\n              </span>\n            </ListGroup.Item>\n            <ListGroup.Item className=\"list-item\">\n              <span className=\"list-item-label\">{'Monitored'}</span>\n              <span className=\"list-item-value\">\n                {point?.has_device ? 'Yes' : 'No'}\n              </span>\n            </ListGroup.Item>\n            {/* Show only if not monitored */}\n            {!point?.has_device && (\n              <ListGroup.Item className=\"list-item\">\n                <span className=\"list-item-label\">{'Was Monitored'}</span>\n                <span className=\"list-item-value\">\n                  {point?.device_status !== 'regular' ? 'Yes' : 'No'}\n                </span>\n              </ListGroup.Item>\n            )}\n            <ListGroup.Item className=\"list-item\">\n              <span className=\"list-item-label\">{'Type'}</span>{' '}\n              <span className=\"list-item-value\">\n                <Trans\n                  i18nKey={`group_type.${point?.group.type.replace('::', '/')}`}\n                />\n              </span>\n            </ListGroup.Item>\n            {point?.group.water_consumption_per_day != null && (\n              <ListGroup.Item className=\"list-item\">\n                <span className=\"list-item-label\">{'Water Consumption'}</span>\n                <span className=\"list-item-value\">\n                  {point?.group.water_consumption_per_day.toFixed(0)}\n                </span>\n              </ListGroup.Item>\n            )}\n            {showDistance && (\n              <ListGroup.Item className=\"list-item\">\n                <span className=\"list-item-label\">{'Distance'}</span>\n                <span className=\"list-item-value\">\n                  {point?.parent_distance}\n                </span>\n              </ListGroup.Item>\n            )}\n            {point?.aeye_installation_height != null && (\n              <ListGroup.Item className=\"list-item\">\n                <span className=\"list-item-label\">{'Installation Height'}</span>\n                <span className=\"list-item-value\">\n                  {point.aeye_installation_height}\n                </span>\n              </ListGroup.Item>\n            )}\n            <ListGroup.Item className=\"list-item\">\n              <span className=\"list-item-label\">{'Diameter'}</span>\n              <span className=\"list-item-value\">{point?.diameter}</span>\n            </ListGroup.Item>\n            {point?.issues && point.issues.length > 0 && (\n              <ListGroup.Item className=\"list-item\">\n                <span className=\"list-item-label\">\n                  {'Issues '}\n                  <img src={iIcon} alt=\"info\" />\n                </span>\n                <span className=\"issues-list\">\n                  {point?.issues.map((issue) => (\n                    <Card key={issue.type} className={'pl-1 pr-1 issue-card'}>\n                      <InfoTooltip\n                        title={i18n.t(\n                          `operations.filters.filter_types.${issue.type}`,\n                        )}\n                        data={issue.message}\n                        alignToBottom={true}\n                        alternateIcon={''}\n                      >\n                        <Trans\n                          i18nKey={`operations.filters.filter_types.${issue.type}`}\n                        />\n                      </InfoTooltip>\n                    </Card>\n                  ))}\n                </span>\n              </ListGroup.Item>\n            )}\n            <ListGroup.Item className=\"list-item\">\n              <Link target=\"_blank\" to={`/groups/${point?.group.id}/edit`}>\n                <Button>{'Edit site'}</Button>\n              </Link>\n            </ListGroup.Item>\n          </ListGroup>\n        </Card>\n      </div>\n    </div>\n  );\n};\n\nexport default RightPanel;\n"],"mappings":"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"}
|
|
142
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_Card","_ListGroup","_reactI18next","_InfoTooltip","_i_Icon","_i18n","_StyledLink","_Button","RightPanel","_ref","_point$group","_point$issues","point","className","onClose","showDistance","group","type","issues","every","issue","default","createElement","style","maxWidth","margin","backgroundColor","Header","onClick","variant","Item","id","name","description","sector_name","has_device","device_status","Trans","i18nKey","concat","replace","water_consumption_per_day","toFixed","parent_distance","aeye_installation_height","diameter","length","src","iIcon","alt","map","key","InfoTooltip","title","i18n","t","data","message","alignToBottom","alternateIcon","Link","target","to","_default","exports"],"sources":["../../../src/pages/OperationsPage/RightPanel.tsx"],"sourcesContent":["import React from 'react';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport Card from 'react-bootstrap/Card';\nimport ListGroup from 'react-bootstrap/ListGroup';\nimport './OperationsPage.scss';\nimport { Trans } from 'react-i18next';\nimport { InfoTooltip } from 'src/ui-kit/InfoTooltip/InfoTooltip';\nimport iIcon from 'src/assets/icons/informationTooltip/i_Icon.svg';\nimport i18n from 'src/utilities/i18n';\nimport { Link } from 'src/components/Links/StyledLink/StyledLink';\nimport Button from 'src/ui-kit/Button/Button';\n\ntype RightPanelProps = {\n  point: IPoint | null;\n  className?: string;\n  onClose?: () => void;\n};\n\nconst RightPanel: React.FC<RightPanelProps> = ({\n  point,\n  className,\n  onClose,\n}) => {\n  // If not WWTP and has parent\n  const showDistance =\n    point?.group?.type !== 'Groups::WastewaterTreatmentPlant' &&\n    point?.issues?.every((issue) => issue.type !== 'no_parent');\n\n  return (\n    <div className={className}>\n      <div className=\"drawer-body p-3\">\n        <Card\n          style={{\n            maxWidth: '600px',\n            margin: '0 auto',\n            backgroundColor: 'white',\n          }}\n        >\n          <Card.Header className=\"d-flex justify-content-between card-header\">\n            {'Manhole Details'}\n            <button className=\"close\" onClick={onClose}>\n              <span>&times;</span>\n            </button>\n          </Card.Header>\n          <ListGroup variant=\"flush\">\n            <ListGroup.Item className=\"list-item\">\n              <span className=\"list-item-label\">{'ID'}</span>\n              <span className=\"list-item-value\">{point?.id}</span>\n            </ListGroup.Item>\n            <ListGroup.Item className=\"list-item\">\n              <span className=\"list-item-label\">{'Name'}</span>\n              <span className=\"list-item-value\">{point?.name}</span>\n            </ListGroup.Item>\n            <ListGroup.Item className=\"list-item\">\n              <span className=\"list-item-label\">{'Description'}</span>\n              <span className=\"list-item-value\">{point?.description}</span>\n            </ListGroup.Item>\n            <ListGroup.Item className=\"list-item\">\n              <span className=\"list-item-label\">{'Sector'}</span>\n              <span className=\"list-item-value\">\n                {point?.group.sector_name}\n              </span>\n            </ListGroup.Item>\n            <ListGroup.Item className=\"list-item\">\n              <span className=\"list-item-label\">{'Monitored'}</span>\n              <span className=\"list-item-value\">\n                {point?.has_device ? 'Yes' : 'No'}\n              </span>\n            </ListGroup.Item>\n            {/* Show only if not monitored */}\n            {!point?.has_device && (\n              <ListGroup.Item className=\"list-item\">\n                <span className=\"list-item-label\">{'Was Monitored'}</span>\n                <span className=\"list-item-value\">\n                  {point?.device_status !== 'regular' ? 'Yes' : 'No'}\n                </span>\n              </ListGroup.Item>\n            )}\n            <ListGroup.Item className=\"list-item\">\n              <span className=\"list-item-label\">{'Type'}</span>{' '}\n              <span className=\"list-item-value\">\n                <Trans\n                  i18nKey={`group_type.${point?.group.type.replace('::', '/')}`}\n                />\n              </span>\n            </ListGroup.Item>\n            {point?.group.water_consumption_per_day != null && (\n              <ListGroup.Item className=\"list-item\">\n                <span className=\"list-item-label\">{'Water Consumption'}</span>\n                <span className=\"list-item-value\">\n                  {point?.group.water_consumption_per_day.toFixed(0)}\n                </span>\n              </ListGroup.Item>\n            )}\n            {showDistance && (\n              <ListGroup.Item className=\"list-item\">\n                <span className=\"list-item-label\">{'Distance'}</span>\n                <span className=\"list-item-value\">\n                  {point?.parent_distance}\n                </span>\n              </ListGroup.Item>\n            )}\n            {point?.aeye_installation_height != null && (\n              <ListGroup.Item className=\"list-item\">\n                <span className=\"list-item-label\">{'Installation Height'}</span>\n                <span className=\"list-item-value\">\n                  {point.aeye_installation_height}\n                </span>\n              </ListGroup.Item>\n            )}\n            <ListGroup.Item className=\"list-item\">\n              <span className=\"list-item-label\">{'Diameter'}</span>\n              <span className=\"list-item-value\">{point?.diameter}</span>\n            </ListGroup.Item>\n            {point?.issues && point.issues.length > 0 && (\n              <ListGroup.Item className=\"list-item\">\n                <span className=\"list-item-label\">\n                  {'Issues '}\n                  <img src={iIcon} alt=\"info\" />\n                </span>\n                <span className=\"issues-list\">\n                  {point?.issues.map((issue) => (\n                    <Card key={issue.type} className={'pl-1 pr-1 issue-card'}>\n                      <InfoTooltip\n                        title={i18n.t(\n                          `operations.filters.filter_types.${issue.type}`,\n                        )}\n                        data={issue.message}\n                        alignToBottom={true}\n                        alternateIcon={''}\n                      >\n                        <Trans\n                          i18nKey={`operations.filters.filter_types.${issue.type}`}\n                        />\n                      </InfoTooltip>\n                    </Card>\n                  ))}\n                </span>\n              </ListGroup.Item>\n            )}\n            <ListGroup.Item className=\"list-item\">\n              <Link target=\"_blank\" to={`/groups/${point?.group.id}/edit`}>\n                <Button>{'Edit site'}</Button>\n              </Link>\n            </ListGroup.Item>\n          </ListGroup>\n        </Card>\n      </div>\n    </div>\n  );\n};\n\nexport default RightPanel;\n"],"mappings":"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"}
|
|
@@ -21,6 +21,8 @@ var initialState = {
|
|
|
21
21
|
enable_delete_sites: false,
|
|
22
22
|
enable_pollution_contributor: false,
|
|
23
23
|
enable_delete_sampling: false,
|
|
24
|
+
enable_graph_tab: false,
|
|
25
|
+
early_adopter: false,
|
|
24
26
|
user_info: {
|
|
25
27
|
first_name: '',
|
|
26
28
|
last_name: '',
|
|
@@ -48,6 +50,8 @@ var PermissionsSlice = (0, _toolkit.createSlice)({
|
|
|
48
50
|
state.enable_delete_sampling = payload.enable_delete_sampling;
|
|
49
51
|
state.enable_lab_result_report = payload.enable_lab_result_report;
|
|
50
52
|
state.enable_pollution_contributor = payload.enable_pollution_contributor;
|
|
53
|
+
state.enable_graph_tab = payload.enable_graph_tab;
|
|
54
|
+
state.early_adopter = payload.early_adopter;
|
|
51
55
|
state.user_info = payload.user_info;
|
|
52
56
|
},
|
|
53
57
|
setUserInfo: function setUserInfo(state, _ref2) {
|
|
@@ -57,4 +61,4 @@ var PermissionsSlice = (0, _toolkit.createSlice)({
|
|
|
57
61
|
}
|
|
58
62
|
});
|
|
59
63
|
exports.PermissionsSlice = PermissionsSlice;
|
|
60
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
64
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfdG9vbGtpdCIsInJlcXVpcmUiLCJpbml0aWFsU3RhdGUiLCJhcmVhX2Rhc2hib2FyZCIsImVuYWJsZV9zaXRlX2xpbmtzIiwidXRpbGl0aWVzX2Rhc2hib2FyZCIsImVuYWJsZV9hcmVhX2xpbmtzIiwiZW5hYmxlX3VzZV9jYXNlcyIsImVuYWJsZV9ldmVudF9saW5rcyIsImVuYWJsZV9sYWJfcmVzdWx0X3JlcG9ydCIsImVuYWJsZV92aWV3X2xhYl9yZXN1bHQiLCJlbmFibGVfdXBsb2FkX3NpdGVzIiwiZW5hYmxlX2RlbGV0ZV9zaXRlcyIsImVuYWJsZV9wb2xsdXRpb25fY29udHJpYnV0b3IiLCJlbmFibGVfZGVsZXRlX3NhbXBsaW5nIiwiZW5hYmxlX2dyYXBoX3RhYiIsImVhcmx5X2Fkb3B0ZXIiLCJ1c2VyX2luZm8iLCJmaXJzdF9uYW1lIiwibGFzdF9uYW1lIiwiZGF0ZV90aW1lX2Zvcm1hdCIsImlkIiwiZmxvd19yYXRlX3VuaXQiLCJQZXJtaXNzaW9uc1NsaWNlIiwiY3JlYXRlU2xpY2UiLCJuYW1lIiwicmVkdWNlcnMiLCJzZXREYXNoYm9hcmRQZXJtaXNzaW9uIiwic3RhdGUiLCJfcmVmIiwicGF5bG9hZCIsInNldFVzZXJJbmZvIiwiX3JlZjIiLCJleHBvcnRzIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3N0b3JlL3Blcm1pc3Npb25zL3Blcm1pc3Npb25zU2xpY2UudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3JlYXRlU2xpY2UgfSBmcm9tICdAcmVkdXhqcy90b29sa2l0JztcblxuZXhwb3J0IGludGVyZmFjZSBQZXJtaXNzaW9uc1N0YXRlIHtcbiAgYXJlYV9kYXNoYm9hcmQ6IHtcbiAgICBlbmFibGVfc2l0ZV9saW5rczogYm9vbGVhbjtcbiAgfTtcbiAgdXRpbGl0aWVzX2Rhc2hib2FyZDoge1xuICAgIGVuYWJsZV9hcmVhX2xpbmtzOiBib29sZWFuO1xuICAgIGVuYWJsZV9zaXRlX2xpbmtzOiBib29sZWFuO1xuICAgIGVuYWJsZV91c2VfY2FzZXM6IGJvb2xlYW47XG4gIH07XG4gIGVuYWJsZV9ldmVudF9saW5rczogYm9vbGVhbjtcbiAgZW5hYmxlX3ZpZXdfbGFiX3Jlc3VsdDogYm9vbGVhbjtcbiAgZW5hYmxlX3VwbG9hZF9zaXRlczogYm9vbGVhbjtcbiAgZW5hYmxlX2RlbGV0ZV9zaXRlczogYm9vbGVhbjtcbiAgZW5hYmxlX2xhYl9yZXN1bHRfcmVwb3J0OiBib29sZWFuO1xuICBlbmFibGVfcG9sbHV0aW9uX2NvbnRyaWJ1dG9yOiBib29sZWFuO1xuICBlbmFibGVfZGVsZXRlX3NhbXBsaW5nOiBib29sZWFuO1xuICBlbmFibGVfZ3JhcGhfdGFiOiBib29sZWFuO1xuICBlYXJseV9hZG9wdGVyOiBib29sZWFuO1xuICB1c2VyX2luZm86IHtcbiAgICBmbG93X3JhdGVfdW5pdDogc3RyaW5nO1xuICAgIGZpcnN0X25hbWU6IHN0cmluZztcbiAgICBsYXN0X25hbWU6IHN0cmluZztcbiAgICBkYXRlX3RpbWVfZm9ybWF0OiBzdHJpbmc7XG4gICAgaWQ6IHN0cmluZztcbiAgfTtcbn1cblxuY29uc3QgaW5pdGlhbFN0YXRlOiBQZXJtaXNzaW9uc1N0YXRlID0ge1xuICBhcmVhX2Rhc2hib2FyZDoge1xuICAgIGVuYWJsZV9zaXRlX2xpbmtzOiBmYWxzZSxcbiAgfSxcbiAgdXRpbGl0aWVzX2Rhc2hib2FyZDoge1xuICAgIGVuYWJsZV9hcmVhX2xpbmtzOiBmYWxzZSxcbiAgICBlbmFibGVfc2l0ZV9saW5rczogZmFsc2UsXG4gICAgZW5hYmxlX3VzZV9jYXNlczogdHJ1ZSxcbiAgfSxcbiAgZW5hYmxlX2V2ZW50X2xpbmtzOiBmYWxzZSxcbiAgZW5hYmxlX2xhYl9yZXN1bHRfcmVwb3J0OiBmYWxzZSxcbiAgZW5hYmxlX3ZpZXdfbGFiX3Jlc3VsdDogZmFsc2UsXG4gIGVuYWJsZV91cGxvYWRfc2l0ZXM6IGZhbHNlLFxuICBlbmFibGVfZGVsZXRlX3NpdGVzOiBmYWxzZSxcbiAgZW5hYmxlX3BvbGx1dGlvbl9jb250cmlidXRvcjogZmFsc2UsXG4gIGVuYWJsZV9kZWxldGVfc2FtcGxpbmc6IGZhbHNlLFxuICBlbmFibGVfZ3JhcGhfdGFiOiBmYWxzZSxcbiAgZWFybHlfYWRvcHRlcjogZmFsc2UsXG4gIHVzZXJfaW5mbzoge1xuICAgIGZpcnN0X25hbWU6ICcnLFxuICAgIGxhc3RfbmFtZTogJycsXG4gICAgZGF0ZV90aW1lX2Zvcm1hdDogJycsXG4gICAgaWQ6ICcnLFxuICAgIGZsb3dfcmF0ZV91bml0OiAnJyxcbiAgfSxcbn07XG5cbmV4cG9ydCBjb25zdCBQZXJtaXNzaW9uc1NsaWNlID0gY3JlYXRlU2xpY2Uoe1xuICBuYW1lOiAncGVybWlzc2lvbnMnLFxuICBpbml0aWFsU3RhdGUsXG4gIHJlZHVjZXJzOiB7XG4gICAgc2V0RGFzaGJvYXJkUGVybWlzc2lvbjogKHN0YXRlLCB7IHBheWxvYWQgfSkgPT4ge1xuICAgICAgaWYgKHBheWxvYWQuYXJlYV9kYXNoYm9hcmQpIHtcbiAgICAgICAgc3RhdGUuYXJlYV9kYXNoYm9hcmQgPSBwYXlsb2FkLmFyZWFfZGFzaGJvYXJkO1xuICAgICAgfVxuICAgICAgaWYgKHBheWxvYWQudXRpbGl0aWVzX2Rhc2hib2FyZCkge1xuICAgICAgICBzdGF0ZS51dGlsaXRpZXNfZGFzaGJvYXJkID0gcGF5bG9hZC51dGlsaXRpZXNfZGFzaGJvYXJkO1xuICAgICAgfVxuICAgICAgc3RhdGUuZW5hYmxlX2V2ZW50X2xpbmtzID0gcGF5bG9hZC5lbmFibGVfZXZlbnRfbGlua3M7XG4gICAgICBzdGF0ZS5lbmFibGVfdmlld19sYWJfcmVzdWx0ID0gcGF5bG9hZC5lbmFibGVfdmlld19sYWJfcmVzdWx0O1xuICAgICAgc3RhdGUuZW5hYmxlX3VwbG9hZF9zaXRlcyA9IHBheWxvYWQuZW5hYmxlX3VwbG9hZF9zaXRlcztcbiAgICAgIHN0YXRlLmVuYWJsZV9kZWxldGVfc2l0ZXMgPSBwYXlsb2FkLmVuYWJsZV9kZWxldGVfc2l0ZXM7XG4gICAgICBzdGF0ZS5lbmFibGVfZGVsZXRlX3NhbXBsaW5nID0gcGF5bG9hZC5lbmFibGVfZGVsZXRlX3NhbXBsaW5nO1xuICAgICAgc3RhdGUuZW5hYmxlX2xhYl9yZXN1bHRfcmVwb3J0ID0gcGF5bG9hZC5lbmFibGVfbGFiX3Jlc3VsdF9yZXBvcnQ7XG4gICAgICBzdGF0ZS5lbmFibGVfcG9sbHV0aW9uX2NvbnRyaWJ1dG9yID0gcGF5bG9hZC5lbmFibGVfcG9sbHV0aW9uX2NvbnRyaWJ1dG9yO1xuICAgICAgc3RhdGUuZW5hYmxlX2dyYXBoX3RhYiA9IHBheWxvYWQuZW5hYmxlX2dyYXBoX3RhYjtcbiAgICAgIHN0YXRlLmVhcmx5X2Fkb3B0ZXIgPSBwYXlsb2FkLmVhcmx5X2Fkb3B0ZXI7XG4gICAgICBzdGF0ZS51c2VyX2luZm8gPSBwYXlsb2FkLnVzZXJfaW5mbztcbiAgICB9LFxuXG4gICAgc2V0VXNlckluZm86IChzdGF0ZSwgeyBwYXlsb2FkIH0pID0+IHtcbiAgICAgIHN0YXRlLnVzZXJfaW5mbyA9IHBheWxvYWQ7XG4gICAgfSxcbiAgfSxcbn0pO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxJQUFBQSxRQUFBLEdBQUFDLE9BQUE7QUE2QkEsSUFBTUMsWUFBOEIsR0FBRztFQUNyQ0MsY0FBYyxFQUFFO0lBQ2RDLGlCQUFpQixFQUFFO0VBQ3JCLENBQUM7RUFDREMsbUJBQW1CLEVBQUU7SUFDbkJDLGlCQUFpQixFQUFFLEtBQUs7SUFDeEJGLGlCQUFpQixFQUFFLEtBQUs7SUFDeEJHLGdCQUFnQixFQUFFO0VBQ3BCLENBQUM7RUFDREMsa0JBQWtCLEVBQUUsS0FBSztFQUN6QkMsd0JBQXdCLEVBQUUsS0FBSztFQUMvQkMsc0JBQXNCLEVBQUUsS0FBSztFQUM3QkMsbUJBQW1CLEVBQUUsS0FBSztFQUMxQkMsbUJBQW1CLEVBQUUsS0FBSztFQUMxQkMsNEJBQTRCLEVBQUUsS0FBSztFQUNuQ0Msc0JBQXNCLEVBQUUsS0FBSztFQUM3QkMsZ0JBQWdCLEVBQUUsS0FBSztFQUN2QkMsYUFBYSxFQUFFLEtBQUs7RUFDcEJDLFNBQVMsRUFBRTtJQUNUQyxVQUFVLEVBQUUsRUFBRTtJQUNkQyxTQUFTLEVBQUUsRUFBRTtJQUNiQyxnQkFBZ0IsRUFBRSxFQUFFO0lBQ3BCQyxFQUFFLEVBQUUsRUFBRTtJQUNOQyxjQUFjLEVBQUU7RUFDbEI7QUFDRixDQUFDO0FBRU0sSUFBTUMsZ0JBQWdCLEdBQUcsSUFBQUMsb0JBQVcsRUFBQztFQUMxQ0MsSUFBSSxFQUFFLGFBQWE7RUFDbkJ2QixZQUFZLEVBQVpBLFlBQVk7RUFDWndCLFFBQVEsRUFBRTtJQUNSQyxzQkFBc0IsRUFBRSxTQUFBQSx1QkFBQ0MsS0FBSyxFQUFBQyxJQUFBLEVBQWtCO01BQUEsSUFBZEMsT0FBTyxHQUFBRCxJQUFBLENBQVBDLE9BQU87TUFDdkMsSUFBSUEsT0FBTyxDQUFDM0IsY0FBYyxFQUFFO1FBQzFCeUIsS0FBSyxDQUFDekIsY0FBYyxHQUFHMkIsT0FBTyxDQUFDM0IsY0FBYztNQUMvQztNQUNBLElBQUkyQixPQUFPLENBQUN6QixtQkFBbUIsRUFBRTtRQUMvQnVCLEtBQUssQ0FBQ3ZCLG1CQUFtQixHQUFHeUIsT0FBTyxDQUFDekIsbUJBQW1CO01BQ3pEO01BQ0F1QixLQUFLLENBQUNwQixrQkFBa0IsR0FBR3NCLE9BQU8sQ0FBQ3RCLGtCQUFrQjtNQUNyRG9CLEtBQUssQ0FBQ2xCLHNCQUFzQixHQUFHb0IsT0FBTyxDQUFDcEIsc0JBQXNCO01BQzdEa0IsS0FBSyxDQUFDakIsbUJBQW1CLEdBQUdtQixPQUFPLENBQUNuQixtQkFBbUI7TUFDdkRpQixLQUFLLENBQUNoQixtQkFBbUIsR0FBR2tCLE9BQU8sQ0FBQ2xCLG1CQUFtQjtNQUN2RGdCLEtBQUssQ0FBQ2Qsc0JBQXNCLEdBQUdnQixPQUFPLENBQUNoQixzQkFBc0I7TUFDN0RjLEtBQUssQ0FBQ25CLHdCQUF3QixHQUFHcUIsT0FBTyxDQUFDckIsd0JBQXdCO01BQ2pFbUIsS0FBSyxDQUFDZiw0QkFBNEIsR0FBR2lCLE9BQU8sQ0FBQ2pCLDRCQUE0QjtNQUN6RWUsS0FBSyxDQUFDYixnQkFBZ0IsR0FBR2UsT0FBTyxDQUFDZixnQkFBZ0I7TUFDakRhLEtBQUssQ0FBQ1osYUFBYSxHQUFHYyxPQUFPLENBQUNkLGFBQWE7TUFDM0NZLEtBQUssQ0FBQ1gsU0FBUyxHQUFHYSxPQUFPLENBQUNiLFNBQVM7SUFDckMsQ0FBQztJQUVEYyxXQUFXLEVBQUUsU0FBQUEsWUFBQ0gsS0FBSyxFQUFBSSxLQUFBLEVBQWtCO01BQUEsSUFBZEYsT0FBTyxHQUFBRSxLQUFBLENBQVBGLE9BQU87TUFDNUJGLEtBQUssQ0FBQ1gsU0FBUyxHQUFHYSxPQUFPO0lBQzNCO0VBQ0Y7QUFDRixDQUFDLENBQUM7QUFBQ0csT0FBQSxDQUFBVixnQkFBQSxHQUFBQSxnQkFBQSJ9
|
|
@@ -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,
|
|
6
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3N0b3JlL3BvaW50cy9tb2RlbHMvSVBvaW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElHcm91cCB9IGZyb20gJy4vSUdyb3VwJztcbmltcG9ydCB7IElJc3N1ZSB9IGZyb20gJy4vSUlzc3VlJztcblxuZXhwb3J0IGludGVyZmFjZSBJUG9pbnQge1xuICBpZDogbnVtYmVyO1xuICBuYW1lOiBzdHJpbmc7XG4gIGRlc2NyaXB0aW9uOiBzdHJpbmc7XG4gIHR5cGU6IHN0cmluZztcbiAgZGV2aWNlX3N0YXR1czogc3RyaW5nO1xuICBsYXRpdHVkZTogbnVtYmVyO1xuICBsb25naXR1ZGU6IG51bWJlcjtcbiAgaGFzX2RldmljZTogYm9vbGVhbjtcbiAgcGhvdG9fdXJsOiBzdHJpbmc7XG4gIGdyb3VwOiBJR3JvdXA7XG4gIGFyZWFfbmFtZT86IHN0cmluZztcbiAgaXNfcm9vdDogYm9vbGVhbjtcbiAgcGFydF9vZl9vYnNlcnZhdGlvbjogYm9vbGVhbjtcbiAgaGlkZT86IGJvb2xlYW47XG4gIHJlbGF0ZWRFdmVudHNBbW91bnQ/OiBudW1iZXI7XG4gIHBhcnRfb2ZfbW9uaXRvcmVkX3BhdGg/OiBib29sZWFuO1xuICBwYXJ0X29mX2FyZWFfaWQ/OiBudW1iZXIgfCBudWxsO1xuICBldmVudHNWaWV3SG92ZXJlZD86IGJvb2xlYW47XG4gIGluY3JlYXNlZEljb24/OiBib29sZWFuO1xuICBpc19pbmxldDogYm9vbGVhbjtcbiAgaXNfYXNzZXNzbWVudDogYm9vbGVhbjtcbiAgc2NvcmU6IG51bWJlcjtcbiAgYWV5ZV9pbnN0YWxsYXRpb25faGVpZ2h0OiBudW1iZXI7XG4gIGRpYW1ldGVyPzogbnVtYmVyO1xuICBpc3N1ZXM/OiBJSXNzdWVbXTtcbiAgcGFyZW50X2Rpc3RhbmNlOiBudW1iZXI7XG4gIGhhc19zYW1wbGVyOiBib29sZWFuO1xuICBzaG91bGRfaW5zdGFsbDogYm9vbGVhbjtcbiAgZm9yV1dUUE1hcD86IGJvb2xlYW47XG59XG4iXSwibWFwcGluZ3MiOiIifQ==
|
|
@@ -14,6 +14,7 @@ var _DashboardMap = _interopRequireDefault(require("pages/DashboardMap"));
|
|
|
14
14
|
var _Analytics = require("../../utilities/Analytics");
|
|
15
15
|
var _actions = require("../../store/context/actions");
|
|
16
16
|
var _reactRedux = require("react-redux");
|
|
17
|
+
var _HierarchyGraph = _interopRequireDefault(require("../HierarchyGraph"));
|
|
17
18
|
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
19
|
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
20
|
var Dashboard = function Dashboard(_ref) {
|
|
@@ -23,11 +24,17 @@ var Dashboard = function Dashboard(_ref) {
|
|
|
23
24
|
var searchQuery = (0, _useQueryURL.default)();
|
|
24
25
|
var dispatch = (0, _reactRedux.useDispatch)();
|
|
25
26
|
var isMapTab = searchQuery.get('view') === 'map';
|
|
27
|
+
var isGraphTab = searchQuery.get('view') === 'graph';
|
|
26
28
|
var _useSelector = (0, _reactRedux.useSelector)(function (_ref2) {
|
|
27
|
-
var global_data = _ref2.global_data
|
|
28
|
-
|
|
29
|
+
var global_data = _ref2.global_data,
|
|
30
|
+
permissions = _ref2.permissions;
|
|
31
|
+
return {
|
|
32
|
+
waterAuthorityName: global_data.waterAuthorityName,
|
|
33
|
+
enableGraphTab: permissions.enable_graph_tab
|
|
34
|
+
};
|
|
29
35
|
}),
|
|
30
|
-
waterAuthorityName = _useSelector.waterAuthorityName
|
|
36
|
+
waterAuthorityName = _useSelector.waterAuthorityName,
|
|
37
|
+
enableGraphTab = _useSelector.enableGraphTab;
|
|
31
38
|
(0, _react.useEffect)(function () {
|
|
32
39
|
(0, _Analytics.analyticsTrack)("Viewed ".concat(pageName, " Dashboard Page"), {
|
|
33
40
|
utility_name: waterAuthorityName
|
|
@@ -41,13 +48,14 @@ var Dashboard = function Dashboard(_ref) {
|
|
|
41
48
|
link: '/dashboard_v2/index',
|
|
42
49
|
name: waterAuthorityName
|
|
43
50
|
}].concat((0, _toConsumableArray2.default)(breadcrumbs)),
|
|
51
|
+
showGraph: enableGraphTab,
|
|
44
52
|
mapDisable: false
|
|
45
53
|
}), /*#__PURE__*/_react.default.createElement(_DashboardMap.default, {
|
|
46
54
|
className: "".concat(!isMapTab ? 'd-none' : '')
|
|
47
|
-
}), /*#__PURE__*/_react.default.createElement("div", {
|
|
48
|
-
className: "".concat(isMapTab ? 'd-none' : '')
|
|
55
|
+
}), enableGraphTab && /*#__PURE__*/_react.default.createElement(_HierarchyGraph.default, null), /*#__PURE__*/_react.default.createElement("div", {
|
|
56
|
+
className: "".concat(isMapTab || isGraphTab ? 'd-none' : '')
|
|
49
57
|
}, children));
|
|
50
58
|
};
|
|
51
59
|
var _default = Dashboard;
|
|
52
60
|
exports.default = _default;
|
|
53
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
61
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVXaWxkY2FyZCIsInJlcXVpcmUiLCJfdXNlUXVlcnlVUkwiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwiX0luZm9CYXIiLCJfRGFzaGJvYXJkTWFwIiwiX0FuYWx5dGljcyIsIl9hY3Rpb25zIiwiX3JlYWN0UmVkdXgiLCJfSGllcmFyY2h5R3JhcGgiLCJfZ2V0UmVxdWlyZVdpbGRjYXJkQ2FjaGUiLCJub2RlSW50ZXJvcCIsIldlYWtNYXAiLCJjYWNoZUJhYmVsSW50ZXJvcCIsImNhY2hlTm9kZUludGVyb3AiLCJvYmoiLCJfX2VzTW9kdWxlIiwiX3R5cGVvZiIsImRlZmF1bHQiLCJjYWNoZSIsImhhcyIsImdldCIsIm5ld09iaiIsImhhc1Byb3BlcnR5RGVzY3JpcHRvciIsIk9iamVjdCIsImRlZmluZVByb3BlcnR5IiwiZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9yIiwia2V5IiwicHJvdG90eXBlIiwiaGFzT3duUHJvcGVydHkiLCJjYWxsIiwiZGVzYyIsInNldCIsIkRhc2hib2FyZCIsIl9yZWYiLCJwYWdlTmFtZSIsImJyZWFkY3J1bWJzIiwiY2hpbGRyZW4iLCJzZWFyY2hRdWVyeSIsInVzZVF1ZXJ5VVJMIiwiZGlzcGF0Y2giLCJ1c2VEaXNwYXRjaCIsImlzTWFwVGFiIiwiaXNHcmFwaFRhYiIsIl91c2VTZWxlY3RvciIsInVzZVNlbGVjdG9yIiwiX3JlZjIiLCJnbG9iYWxfZGF0YSIsInBlcm1pc3Npb25zIiwid2F0ZXJBdXRob3JpdHlOYW1lIiwiZW5hYmxlR3JhcGhUYWIiLCJlbmFibGVfZ3JhcGhfdGFiIiwidXNlRWZmZWN0IiwiYW5hbHl0aWNzVHJhY2siLCJjb25jYXQiLCJ1dGlsaXR5X25hbWUiLCJ1cGRhdGVOYXZDb250ZXh0IiwibmFtZSIsImNyZWF0ZUVsZW1lbnQiLCJGcmFnbWVudCIsIkluZm9CYXIiLCJwYXJ0cyIsImxpbmsiLCJfdG9Db25zdW1hYmxlQXJyYXkyIiwic2hvd0dyYXBoIiwibWFwRGlzYWJsZSIsImNsYXNzTmFtZSIsIl9kZWZhdWx0IiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy91aS1raXQvRGFzaGJvYXJkL0Rhc2hib2FyZC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IHVzZUVmZmVjdCB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB1c2VRdWVyeVVSTCBmcm9tICcuLi8uLi9ob29rcy91c2VRdWVyeVVSTCc7XG5pbXBvcnQgeyBJbmZvQmFyIH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy9IZWFkZXIvSW5mb0Jhci9JbmZvQmFyJztcbmltcG9ydCBEYXNoYm9hcmRNYXAgZnJvbSAnc3JjL3BhZ2VzL0Rhc2hib2FyZE1hcCc7XG5pbXBvcnQgeyBhbmFseXRpY3NUcmFjayB9IGZyb20gJy4uLy4uL3V0aWxpdGllcy9BbmFseXRpY3MnO1xuaW1wb3J0IHsgdXBkYXRlTmF2Q29udGV4dCB9IGZyb20gJy4uLy4uL3N0b3JlL2NvbnRleHQvYWN0aW9ucyc7XG5pbXBvcnQgeyB1c2VEaXNwYXRjaCwgdXNlU2VsZWN0b3IgfSBmcm9tICdyZWFjdC1yZWR1eCc7XG5pbXBvcnQgSGllcmFyY2h5R3JhcGggZnJvbSAnLi4vSGllcmFyY2h5R3JhcGgnO1xuXG50eXBlIERhc2hib2FyZFByb3BzID0ge1xuICBwYWdlTmFtZTogc3RyaW5nO1xuICBicmVhZGNydW1iczogKHsgbmFtZTogc3RyaW5nOyBsaW5rOiBzdHJpbmcgfSB8IHN0cmluZylbXTtcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0Tm9kZTtcbn07XG5jb25zdCBEYXNoYm9hcmQgPSAoeyBwYWdlTmFtZSwgYnJlYWRjcnVtYnMsIGNoaWxkcmVuIH06IERhc2hib2FyZFByb3BzKSA9PiB7XG4gIGNvbnN0IHNlYXJjaFF1ZXJ5ID0gdXNlUXVlcnlVUkwoKTtcbiAgY29uc3QgZGlzcGF0Y2ggPSB1c2VEaXNwYXRjaCgpO1xuICBjb25zdCBpc01hcFRhYiA9IHNlYXJjaFF1ZXJ5LmdldCgndmlldycpID09PSAnbWFwJztcbiAgY29uc3QgaXNHcmFwaFRhYiA9IHNlYXJjaFF1ZXJ5LmdldCgndmlldycpID09PSAnZ3JhcGgnO1xuICBjb25zdCB7IHdhdGVyQXV0aG9yaXR5TmFtZSwgZW5hYmxlR3JhcGhUYWIgfSA9IHVzZVNlbGVjdG9yKFxuICAgICh7IGdsb2JhbF9kYXRhLCBwZXJtaXNzaW9ucyB9KSA9PiB7XG4gICAgICByZXR1cm4ge1xuICAgICAgICB3YXRlckF1dGhvcml0eU5hbWU6IGdsb2JhbF9kYXRhLndhdGVyQXV0aG9yaXR5TmFtZSxcbiAgICAgICAgZW5hYmxlR3JhcGhUYWI6IHBlcm1pc3Npb25zLmVuYWJsZV9ncmFwaF90YWIsXG4gICAgICB9O1xuICAgIH0sXG4gICk7XG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgYW5hbHl0aWNzVHJhY2soYFZpZXdlZCAke3BhZ2VOYW1lfSBEYXNoYm9hcmQgUGFnZWAsIHtcbiAgICAgIHV0aWxpdHlfbmFtZTogd2F0ZXJBdXRob3JpdHlOYW1lLFxuICAgIH0pO1xuICAgIGRpc3BhdGNoKHVwZGF0ZU5hdkNvbnRleHQoeyBuYW1lOiAnZGFzaGJvYXJkX3YyJyB9KSk7XG4gIH0sIFtdKTtcbiAgcmV0dXJuIChcbiAgICA8PlxuICAgICAgPEluZm9CYXJcbiAgICAgICAgcGFydHM9e1tcbiAgICAgICAgICB7XG4gICAgICAgICAgICBsaW5rOiAnL2Rhc2hib2FyZF92Mi9pbmRleCcsXG4gICAgICAgICAgICBuYW1lOiB3YXRlckF1dGhvcml0eU5hbWUsXG4gICAgICAgICAgfSxcbiAgICAgICAgICAuLi5icmVhZGNydW1icyxcbiAgICAgICAgXX1cbiAgICAgICAgc2hvd0dyYXBoPXtlbmFibGVHcmFwaFRhYn1cbiAgICAgICAgbWFwRGlzYWJsZT17ZmFsc2V9XG4gICAgICAvPlxuICAgICAgPERhc2hib2FyZE1hcCBjbGFzc05hbWU9e2AkeyFpc01hcFRhYiA/ICdkLW5vbmUnIDogJyd9YH0gLz5cbiAgICAgIHtlbmFibGVHcmFwaFRhYiAmJiA8SGllcmFyY2h5R3JhcGggLz59XG4gICAgICA8ZGl2IGNsYXNzTmFtZT17YCR7aXNNYXBUYWIgfHwgaXNHcmFwaFRhYiA/ICdkLW5vbmUnIDogJyd9YH0+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgIDwvZGl2PlxuICAgIDwvPlxuICApO1xufTtcbmV4cG9ydCBkZWZhdWx0IERhc2hib2FyZDtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUEsSUFBQUEsTUFBQSxHQUFBQyx1QkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsWUFBQSxHQUFBQyxzQkFBQSxDQUFBRixPQUFBO0FBQ0EsSUFBQUcsUUFBQSxHQUFBSCxPQUFBO0FBQ0EsSUFBQUksYUFBQSxHQUFBRixzQkFBQSxDQUFBRixPQUFBO0FBQ0EsSUFBQUssVUFBQSxHQUFBTCxPQUFBO0FBQ0EsSUFBQU0sUUFBQSxHQUFBTixPQUFBO0FBQ0EsSUFBQU8sV0FBQSxHQUFBUCxPQUFBO0FBQ0EsSUFBQVEsZUFBQSxHQUFBTixzQkFBQSxDQUFBRixPQUFBO0FBQStDLFNBQUFTLHlCQUFBQyxXQUFBLGVBQUFDLE9BQUEsa0NBQUFDLGlCQUFBLE9BQUFELE9BQUEsUUFBQUUsZ0JBQUEsT0FBQUYsT0FBQSxZQUFBRix3QkFBQSxZQUFBQSx5QkFBQUMsV0FBQSxXQUFBQSxXQUFBLEdBQUFHLGdCQUFBLEdBQUFELGlCQUFBLEtBQUFGLFdBQUE7QUFBQSxTQUFBWCx3QkFBQWUsR0FBQSxFQUFBSixXQUFBLFNBQUFBLFdBQUEsSUFBQUksR0FBQSxJQUFBQSxHQUFBLENBQUFDLFVBQUEsV0FBQUQsR0FBQSxRQUFBQSxHQUFBLGFBQUFFLE9BQUEsQ0FBQUYsR0FBQSx5QkFBQUEsR0FBQSw0QkFBQUcsT0FBQSxFQUFBSCxHQUFBLFVBQUFJLEtBQUEsR0FBQVQsd0JBQUEsQ0FBQUMsV0FBQSxPQUFBUSxLQUFBLElBQUFBLEtBQUEsQ0FBQUMsR0FBQSxDQUFBTCxHQUFBLFlBQUFJLEtBQUEsQ0FBQUUsR0FBQSxDQUFBTixHQUFBLFNBQUFPLE1BQUEs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
|
|
@@ -0,0 +1,164 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.default = AutoFitTree;
|
|
9
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/slicedToArray"));
|
|
10
|
+
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/objectWithoutProperties"));
|
|
11
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
12
|
+
var _reactD3Tree = _interopRequireDefault(require("react-d3-tree"));
|
|
13
|
+
var _reactRouterDom = require("react-router-dom");
|
|
14
|
+
var _PieNode = _interopRequireDefault(require("./PieNode"));
|
|
15
|
+
var _MicroStackedBarNode = _interopRequireDefault(require("./MicroStackedBarNode"));
|
|
16
|
+
var _excluded = ["data", "orientation", "initialDepth", "nodeType"];
|
|
17
|
+
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
|
+
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
|
+
function countDepthAndBreadth(root) {
|
|
20
|
+
var maxDepth = 0;
|
|
21
|
+
var breadthByDepth = [];
|
|
22
|
+
var dfs = function dfs(n) {
|
|
23
|
+
var _n$children;
|
|
24
|
+
var d = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
|
|
25
|
+
maxDepth = Math.max(maxDepth, d);
|
|
26
|
+
breadthByDepth[d] = (breadthByDepth[d] || 0) + 1;
|
|
27
|
+
(_n$children = n.children) === null || _n$children === void 0 ? void 0 : _n$children.forEach(function (c) {
|
|
28
|
+
return dfs(c, d + 1);
|
|
29
|
+
});
|
|
30
|
+
};
|
|
31
|
+
dfs(root);
|
|
32
|
+
var maxBreadth = Math.max.apply(Math, breadthByDepth);
|
|
33
|
+
return {
|
|
34
|
+
maxDepth: maxDepth,
|
|
35
|
+
maxBreadth: maxBreadth
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
function AutoFitTree(_ref) {
|
|
39
|
+
var data = _ref.data,
|
|
40
|
+
_ref$orientation = _ref.orientation,
|
|
41
|
+
orientation = _ref$orientation === void 0 ? 'vertical' : _ref$orientation,
|
|
42
|
+
initialDepth = _ref.initialDepth,
|
|
43
|
+
nodeType = _ref.nodeType,
|
|
44
|
+
rest = (0, _objectWithoutProperties2.default)(_ref, _excluded);
|
|
45
|
+
var PADDING = 35; // screen padding in px
|
|
46
|
+
var wrapperRef = (0, _react.useRef)(null);
|
|
47
|
+
var _useParams = (0, _reactRouterDom.useParams)(),
|
|
48
|
+
siteID = _useParams.siteID;
|
|
49
|
+
var nodeSize = {
|
|
50
|
+
x: 270,
|
|
51
|
+
y: 270
|
|
52
|
+
}; // how much space each node occupies
|
|
53
|
+
var separation = {
|
|
54
|
+
siblings: 0.8,
|
|
55
|
+
nonSiblings: 0.9
|
|
56
|
+
}; // node spacing
|
|
57
|
+
var _useState = (0, _react.useState)({
|
|
58
|
+
width: 500,
|
|
59
|
+
height: 100
|
|
60
|
+
}),
|
|
61
|
+
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
|
|
62
|
+
dims = _useState2[0],
|
|
63
|
+
setDims = _useState2[1];
|
|
64
|
+
|
|
65
|
+
// keep wrapper sized to the viewport
|
|
66
|
+
(0, _react.useEffect)(function () {
|
|
67
|
+
if (!wrapperRef.current) return;
|
|
68
|
+
var ro = new ResizeObserver(function () {
|
|
69
|
+
var r = wrapperRef.current.getBoundingClientRect();
|
|
70
|
+
setDims({
|
|
71
|
+
width: r.width,
|
|
72
|
+
height: r.height
|
|
73
|
+
});
|
|
74
|
+
});
|
|
75
|
+
ro.observe(wrapperRef.current);
|
|
76
|
+
return function () {
|
|
77
|
+
return ro.disconnect();
|
|
78
|
+
};
|
|
79
|
+
}, []);
|
|
80
|
+
var _useMemo = (0, _react.useMemo)(function () {
|
|
81
|
+
var _countDepthAndBreadth = countDepthAndBreadth(data),
|
|
82
|
+
maxDepth = _countDepthAndBreadth.maxDepth,
|
|
83
|
+
maxBreadth = _countDepthAndBreadth.maxBreadth;
|
|
84
|
+
|
|
85
|
+
// approximate required pixel size of the laid-out tree
|
|
86
|
+
var reqW = orientation === 'horizontal' ? (maxDepth + 1) * nodeSize.x : maxBreadth * nodeSize.x * separation.siblings;
|
|
87
|
+
var reqH = orientation === 'horizontal' ? maxBreadth * nodeSize.y * separation.siblings : (maxDepth + 1) * nodeSize.y;
|
|
88
|
+
var availW = Math.max(1, dims.width - PADDING * 2);
|
|
89
|
+
var availH = Math.max(1, dims.height - PADDING * 2);
|
|
90
|
+
var fitZoom = 0.7 * Math.min(availW / reqW, availH / reqH);
|
|
91
|
+
var z = isFinite(fitZoom) && fitZoom > 0 ? fitZoom : 1.2;
|
|
92
|
+
|
|
93
|
+
// anchor === "edge": put root at the leading edge + padding
|
|
94
|
+
if (orientation === 'horizontal') {
|
|
95
|
+
// root on the LEFT, vertically centered
|
|
96
|
+
return {
|
|
97
|
+
zoom: z,
|
|
98
|
+
translate: {
|
|
99
|
+
x: PADDING,
|
|
100
|
+
y: dims.height / 2
|
|
101
|
+
}
|
|
102
|
+
};
|
|
103
|
+
} else {
|
|
104
|
+
// orientation === "vertical" → root on the TOP, horizontally centered
|
|
105
|
+
return {
|
|
106
|
+
zoom: z,
|
|
107
|
+
translate: {
|
|
108
|
+
x: dims.width / 2,
|
|
109
|
+
y: PADDING
|
|
110
|
+
}
|
|
111
|
+
};
|
|
112
|
+
}
|
|
113
|
+
}, [data, nodeSize.x, nodeSize.y, separation.siblings, orientation, dims.width, dims.height]),
|
|
114
|
+
translate = _useMemo.translate,
|
|
115
|
+
zoom = _useMemo.zoom;
|
|
116
|
+
function setCollapsedByDepth(node, maxDepth) {
|
|
117
|
+
var _node$children;
|
|
118
|
+
var d = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0;
|
|
119
|
+
node.collapsed = d >= maxDepth;
|
|
120
|
+
(_node$children = node.children) === null || _node$children === void 0 ? void 0 : _node$children.forEach(function (c) {
|
|
121
|
+
return setCollapsedByDepth(c, maxDepth, d + 1);
|
|
122
|
+
});
|
|
123
|
+
return node;
|
|
124
|
+
}
|
|
125
|
+
var viewData = (0, _react.useMemo)(function () {
|
|
126
|
+
if (!data) return null;
|
|
127
|
+
var clone = JSON.parse(JSON.stringify(data));
|
|
128
|
+
return setCollapsedByDepth(clone, initialDepth);
|
|
129
|
+
}, [data, initialDepth]);
|
|
130
|
+
var renderCustomNodeElement = function renderCustomNodeElement(rd3tProps) {
|
|
131
|
+
return nodeType === 'pie' ? /*#__PURE__*/_react.default.createElement(_PieNode.default, Object.assign({}, rd3tProps, {
|
|
132
|
+
siteID: siteID,
|
|
133
|
+
onNodeClick: rest.onNodeClick
|
|
134
|
+
})) : /*#__PURE__*/_react.default.createElement(_MicroStackedBarNode.default, Object.assign({}, rd3tProps, {
|
|
135
|
+
siteID: siteID,
|
|
136
|
+
onNodeClick: rest.onNodeClick
|
|
137
|
+
}));
|
|
138
|
+
};
|
|
139
|
+
return /*#__PURE__*/_react.default.createElement("div", {
|
|
140
|
+
ref: wrapperRef,
|
|
141
|
+
style: {
|
|
142
|
+
width: '100vw',
|
|
143
|
+
height: '100vh',
|
|
144
|
+
overflow: 'hidden'
|
|
145
|
+
}
|
|
146
|
+
}, /*#__PURE__*/_react.default.createElement(_reactD3Tree.default, Object.assign({
|
|
147
|
+
data: viewData,
|
|
148
|
+
orientation: orientation,
|
|
149
|
+
pathFunc: "step",
|
|
150
|
+
nodeSize: nodeSize,
|
|
151
|
+
separation: separation,
|
|
152
|
+
translate: translate,
|
|
153
|
+
zoom: zoom,
|
|
154
|
+
zoomable: true,
|
|
155
|
+
scaleExtent: {
|
|
156
|
+
min: 0.1,
|
|
157
|
+
max: 2
|
|
158
|
+
},
|
|
159
|
+
renderCustomNodeElement: renderCustomNodeElement,
|
|
160
|
+
collapsible: true,
|
|
161
|
+
initialDepth: initialDepth
|
|
162
|
+
}, rest)));
|
|
163
|
+
}
|
|
164
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactD3Tree","_interopRequireDefault","_reactRouterDom","_PieNode","_MicroStackedBarNode","_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","nodeType","rest","_objectWithoutProperties2","PADDING","wrapperRef","useRef","_useParams","useParams","siteID","nodeSize","x","y","separation","siblings","nonSiblings","_useState","useState","width","height","_useState2","_slicedToArray2","dims","setDims","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","createElement","assign","onNodeClick","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 { useParams } from 'react-router-dom';\nimport PieNode from './PieNode';\nimport MicroStackedBarNode from './MicroStackedBarNode';\nimport { NodeType } from './utils';\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  nodeType,\n  ...rest\n}: {\n  data: any;\n  orientation?: 'vertical' | 'horizontal';\n  initialDepth: number;\n  onNodeClick?: (nodeData: any) => void;\n  nodeType: NodeType;\n}) {\n  const PADDING = 35; // screen padding in px\n  const wrapperRef = useRef<HTMLDivElement>(null);\n  const { siteID } = useParams();\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\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 =\n      orientation === 'horizontal'\n        ? (maxDepth + 1) * nodeSize.x\n        : maxBreadth * nodeSize.x * separation.siblings;\n    const reqH =\n      orientation === 'horizontal'\n        ? maxBreadth * nodeSize.y * separation.siblings\n        : (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    // anchor === \"edge\": put root at the leading edge + padding\n    if (orientation === 'horizontal') {\n      // root on the LEFT, vertically centered\n      return { zoom: z, translate: { x: PADDING, y: dims.height / 2 } };\n    } else {\n      // orientation === \"vertical\" → root on the TOP, horizontally centered\n      return { zoom: z, translate: { x: dims.width / 2, y: PADDING } };\n    }\n  }, [\n    data,\n    nodeSize.x,\n    nodeSize.y,\n    separation.siblings,\n    orientation,\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    nodeType === 'pie' ? (\n      <PieNode {...rd3tProps} siteID={siteID} onNodeClick={rest.onNodeClick} />\n    ) : (\n      <MicroStackedBarNode\n        {...rd3tProps}\n        siteID={siteID}\n        onNodeClick={rest.onNodeClick}\n      />\n    );\n\n  return (\n    <div\n      ref={wrapperRef}\n      style={{ width: '100vw', height: '100vh', overflow: 'hidden' }}\n    >\n      <Tree\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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"}
|