@kando-env/kando-ui 1.2.449-alpha.0 → 1.2.449-alpha.10

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.
@@ -11,58 +11,35 @@ var _react = _interopRequireWildcard(require("react"));
11
11
  var _useQueryURL = _interopRequireDefault(require("../../hooks/useQueryURL"));
12
12
  var _utils = require("./utils");
13
13
  var _reactRedux = require("react-redux");
14
- var _reactD3Tree = _interopRequireDefault(require("react-d3-tree"));
14
+ var _AutoFitTree = _interopRequireDefault(require("./AutoFitTree"));
15
+ var _reactBootstrap = require("react-bootstrap");
16
+ var _Loader = require("../../pages/DashboardMap/Loader");
17
+ var _Button = _interopRequireDefault(require("../Button/Button"));
18
+ var _RightPanel = _interopRequireDefault(require("../../pages/OperationsPage/RightPanel"));
15
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); }
16
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; }
17
21
  var HierarchyGraph = function HierarchyGraph() {
18
- var treeContainer = (0, _react.useRef)(null);
19
22
  var searchQuery = (0, _useQueryURL.default)();
20
- var _useState = (0, _react.useState)({
21
- width: 0,
22
- height: 0
23
- }),
24
- _useState2 = (0, _slicedToArray2.default)(_useState, 2),
25
- dimensions = _useState2[0],
26
- setDimensions = _useState2[1];
27
23
  var ReduxState = (0, _reactRedux.useSelector)(function (state) {
28
24
  return state;
29
25
  });
30
- // Measure container size
31
- (0, _react.useEffect)(function () {
32
- if (treeContainer.current) {
33
- var _ref = treeContainer.current.getBoundingClientRect() || {
34
- width: 0,
35
- height: 0
36
- },
37
- width = _ref.width,
38
- height = _ref.height;
39
- setDimensions({
40
- width: width,
41
- height: height
42
- });
43
- }
44
-
45
- // Optional: auto-resize on window change
46
- var handleResize = function handleResize() {
47
- if (treeContainer.current) {
48
- var _treeContainer$curren = treeContainer.current.getBoundingClientRect(),
49
- _width = _treeContainer$curren.width,
50
- _height = _treeContainer$curren.height;
51
- setDimensions({
52
- width: _width,
53
- height: _height
54
- });
55
- }
56
- };
57
- window.addEventListener('resize', handleResize);
58
- return function () {
59
- return window.removeEventListener('resize', handleResize);
60
- };
61
- }, []);
26
+ var _useState = (0, _react.useState)('vertical'),
27
+ _useState2 = (0, _slicedToArray2.default)(_useState, 2),
28
+ orientation = _useState2[0],
29
+ setOrientation = _useState2[1];
30
+ var _useState3 = (0, _react.useState)(12),
31
+ _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
32
+ depth = _useState4[0],
33
+ setDepth = _useState4[1];
34
+ var _useState5 = (0, _react.useState)(null),
35
+ _useState6 = (0, _slicedToArray2.default)(_useState5, 2),
36
+ selectedPoint = _useState6[0],
37
+ setSelectedPoint = _useState6[1];
38
+ var _useState7 = (0, _react.useState)(false),
39
+ _useState8 = (0, _slicedToArray2.default)(_useState7, 2),
40
+ showRightPanel = _useState8[0],
41
+ setShowRightPanel = _useState8[1];
62
42
  var isGraphTab = searchQuery.get('view') === 'graph';
63
- if (!isGraphTab) {
64
- return null;
65
- }
66
43
  var points_data = ReduxState.points_data,
67
44
  edges_data = ReduxState.edges_data,
68
45
  waterAuthorityName = ReduxState.global_data.waterAuthorityName;
@@ -70,45 +47,70 @@ var HierarchyGraph = function HierarchyGraph() {
70
47
  return point.has_device;
71
48
  }));
72
49
  var edgesWithDevice = edges_data.items.filter(function (edge) {
73
- return pointsWithDevice[edge.source_point_id];
50
+ return pointsWithDevice[edge.source_point_id] || edge.descendants_has_device;
74
51
  });
75
- var treeData = (0, _utils.buildTree)(edgesWithDevice, (0, _utils.mapById)(points_data.items), waterAuthorityName);
52
+ var point_map_data = (0, _utils.mapById)(points_data.items);
53
+ var treeData = (0, _utils.buildTree)(edgesWithDevice, point_map_data, waterAuthorityName);
54
+ var onNodeClick = function onNodeClick(nodeData, event) {
55
+ setSelectedPoint(points_data.items.find(function (p) {
56
+ return p.id === nodeData.data.attributes.point_id;
57
+ }));
58
+ setShowRightPanel(!showRightPanel);
59
+ };
60
+ if (!isGraphTab) {
61
+ return null;
62
+ }
76
63
 
77
64
  // The component expects either an array or a single object
78
- return /*#__PURE__*/_react.default.createElement("div", {
79
- ref: treeContainer,
65
+ return /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("div", {
80
66
  style: {
81
- height: '100vh',
82
- width: '100vw',
83
- padding: 0
67
+ marginTop: '10px',
68
+ marginInlineStart: '10px',
69
+ display: 'flex',
70
+ gap: 8,
71
+ zIndex: 10
84
72
  }
85
- }, /*#__PURE__*/_react.default.createElement(_reactD3Tree.default, {
86
- translate: {
87
- x: dimensions.width / 2,
88
- // Center horizontally
89
- y: 100 // Vertical offset (distance from top)
90
- },
91
-
92
- orientation: "vertical",
93
- collapsible: true,
94
- initialDepth: 0,
95
- separation: {
96
- siblings: 1,
97
- nonSiblings: 1.2
98
- },
99
- nodeSize: {
100
- x: 240,
101
- y: 120
102
- },
103
- shouldCollapseNeighborNodes: true,
104
- dimensions: {
105
- height: dimensions.height / 10,
106
- width: dimensions.width
107
- },
108
- pathFunc: "step",
109
- data: treeData
110
- }));
73
+ }, /*#__PURE__*/_react.default.createElement(_Button.default, {
74
+ onClick: function onClick() {
75
+ return setDepth(1);
76
+ }
77
+ }, 'Collapse All'), /*#__PURE__*/_react.default.createElement(_Button.default, {
78
+ onClick: function onClick() {
79
+ return setDepth(12);
80
+ }
81
+ }, 'Expand All'), /*#__PURE__*/_react.default.createElement(_Button.default, {
82
+ onClick: function onClick() {
83
+ return setOrientation(function (prev) {
84
+ return prev === 'horizontal' ? 'vertical' : 'horizontal';
85
+ });
86
+ }
87
+ }, 'Toggle Orientation')), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Container, {
88
+ fluid: true,
89
+ className: "p-0",
90
+ style: {
91
+ overflow: 'hidden'
92
+ }
93
+ }, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Row, {
94
+ className: "map-column",
95
+ sm: 12
96
+ }, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Col, {
97
+ style: {
98
+ height: '85vh'
99
+ }
100
+ }, edges_data.isFetching || points_data.isFetching ? /*#__PURE__*/_react.default.createElement(_Loader.Loader, null) : /*#__PURE__*/_react.default.createElement(_AutoFitTree.default, {
101
+ initialDepth: depth,
102
+ data: treeData,
103
+ orientation: orientation,
104
+ onNodeClick: onNodeClick
105
+ }), /*#__PURE__*/_react.default.createElement(_RightPanel.default, {
106
+ className: "right-panel ".concat(showRightPanel ? 'open' : ''),
107
+ point: selectedPoint,
108
+ onClose: function onClose() {
109
+ setSelectedPoint(null);
110
+ setShowRightPanel(false);
111
+ }
112
+ })))));
111
113
  };
112
114
  var _default = HierarchyGraph;
113
115
  exports.default = _default;
114
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_useQueryURL","_interopRequireDefault","_utils","_reactRedux","_reactD3Tree","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","HierarchyGraph","treeContainer","useRef","searchQuery","useQueryURL","_useState","useState","width","height","_useState2","_slicedToArray2","dimensions","setDimensions","ReduxState","useSelector","state","useEffect","current","_ref","getBoundingClientRect","handleResize","_treeContainer$curren","window","addEventListener","removeEventListener","isGraphTab","points_data","edges_data","waterAuthorityName","global_data","pointsWithDevice","mapById","items","filter","point","has_device","edgesWithDevice","edge","source_point_id","treeData","buildTree","createElement","ref","style","padding","translate","x","y","orientation","collapsible","initialDepth","separation","siblings","nonSiblings","nodeSize","shouldCollapseNeighborNodes","pathFunc","data","_default","exports"],"sources":["../../../src/ui-kit/HierarchyGraph/HierarchyGraph.tsx"],"sourcesContent":["import React from 'react';\nimport useQueryURL from '../../hooks/useQueryURL';\nimport { buildTree, mapById } from './utils';\nimport { useSelector } from 'react-redux';\nimport Tree from 'react-d3-tree';\nimport { useEffect, useState, useRef } from 'react';\n\nconst HierarchyGraph = () => {\n  const treeContainer = useRef<HTMLDivElement>(null);\n  const searchQuery = useQueryURL();\n  const [dimensions, setDimensions] = useState({ width: 0, height: 0 });\n  const ReduxState = useSelector((state) => state);\n  // Measure container size\n  useEffect(() => {\n    if (treeContainer.current) {\n      const { width, height } =\n        treeContainer.current.getBoundingClientRect() || {\n          width: 0,\n          height: 0,\n        };\n      setDimensions({ width, height });\n    }\n\n    // Optional: auto-resize on window change\n    const handleResize = () => {\n      if (treeContainer.current) {\n        const { width, height } = treeContainer.current.getBoundingClientRect();\n        setDimensions({ width, height });\n      }\n    };\n    window.addEventListener('resize', handleResize);\n    return () => window.removeEventListener('resize', handleResize);\n  }, []);\n  const isGraphTab = searchQuery.get('view') === 'graph';\n  if (!isGraphTab) {\n    return null;\n  }\n  const {\n    points_data,\n    edges_data,\n    global_data: { waterAuthorityName },\n  } = ReduxState;\n  const pointsWithDevice = mapById(\n    points_data.items.filter((point) => point.has_device),\n  );\n  const edgesWithDevice = edges_data.items.filter(\n    (edge) => pointsWithDevice[edge.source_point_id],\n  );\n  const treeData = buildTree(\n    edgesWithDevice,\n    mapById(points_data.items),\n    waterAuthorityName,\n  );\n\n  // The component expects either an array or a single object\n  return (\n    <div\n      ref={treeContainer}\n      style={{ height: '100vh', width: '100vw', padding: 0 }}\n    >\n      <Tree\n        translate={{\n          x: dimensions.width / 2, // Center horizontally\n          y: 100, // Vertical offset (distance from top)\n        }}\n        orientation=\"vertical\"\n        collapsible\n        initialDepth={0}\n        separation={{ siblings: 1, nonSiblings: 1.2 }}\n        nodeSize={{ x: 240, y: 120 }}\n        shouldCollapseNeighborNodes\n        dimensions={{ height: dimensions.height / 10, width: dimensions.width }}\n        pathFunc=\"step\"\n        data={treeData}\n      />\n    </div>\n  );\n};\nexport default HierarchyGraph;\n"],"mappings":"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"}
116
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_useQueryURL","_interopRequireDefault","_utils","_reactRedux","_AutoFitTree","_reactBootstrap","_Loader","_Button","_RightPanel","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","HierarchyGraph","searchQuery","useQueryURL","ReduxState","useSelector","state","_useState","useState","_useState2","_slicedToArray2","orientation","setOrientation","_useState3","_useState4","depth","setDepth","_useState5","_useState6","selectedPoint","setSelectedPoint","_useState7","_useState8","showRightPanel","setShowRightPanel","isGraphTab","points_data","edges_data","waterAuthorityName","global_data","pointsWithDevice","mapById","items","filter","point","has_device","edgesWithDevice","edge","source_point_id","descendants_has_device","point_map_data","treeData","buildTree","onNodeClick","nodeData","event","find","p","id","data","attributes","point_id","createElement","style","marginTop","marginInlineStart","display","gap","zIndex","onClick","prev","Container","fluid","className","overflow","Row","sm","Col","height","isFetching","Loader","initialDepth","concat","onClose","_default","exports"],"sources":["../../../src/ui-kit/HierarchyGraph/HierarchyGraph.tsx"],"sourcesContent":["import React from 'react';\n\nimport useQueryURL from '../../hooks/useQueryURL';\nimport { buildTree, mapById } from './utils';\nimport { useSelector } from 'react-redux';\nimport { useState } from 'react';\nimport AutoFitTree from './AutoFitTree';\nimport { Container, Row, Col } from 'react-bootstrap';\nimport { Loader } from '../../pages/DashboardMap/Loader';\nimport Button from '../Button/Button';\nimport RightPanel from '../../pages/OperationsPage/RightPanel';\n\nconst HierarchyGraph = () => {\n  const searchQuery = useQueryURL();\n  const ReduxState = useSelector((state) => state);\n  const [orientation, setOrientation] = useState<'horizontal' | 'vertical'>(\n    'vertical',\n  );\n  const [depth, setDepth] = useState<number>(12);\n  const [selectedPoint, setSelectedPoint] = useState(null);\n  const [showRightPanel, setShowRightPanel] = useState(false);\n  const isGraphTab = searchQuery.get('view') === 'graph';\n  const {\n    points_data,\n    edges_data,\n    global_data: { waterAuthorityName },\n  } = ReduxState;\n  const pointsWithDevice = mapById(\n    points_data.items.filter((point) => point.has_device),\n  );\n  const edgesWithDevice = edges_data.items.filter(\n    (edge) =>\n      pointsWithDevice[edge.source_point_id] || edge.descendants_has_device,\n  );\n  const point_map_data = mapById(points_data.items);\n  const treeData = buildTree(\n    edgesWithDevice,\n    point_map_data,\n    waterAuthorityName,\n  );\n  const onNodeClick = (nodeData, event) => {\n    setSelectedPoint(\n      points_data.items.find((p) => p.id === nodeData.data.attributes.point_id),\n    );\n    setShowRightPanel(!showRightPanel);\n  };\n\n  if (!isGraphTab) {\n    return null;\n  }\n\n  // The component expects either an array or a single object\n  return (\n    <div>\n      {/*<OrientationSwitcher*/}\n      {/*  orientation={orientation}*/}\n      {/*  setOrientation={setOrientation}*/}\n      {/*/>*/}\n      <div\n        style={{\n          marginTop: '10px',\n          marginInlineStart: '10px',\n          display: 'flex',\n          gap: 8,\n          zIndex: 10,\n        }}\n      >\n        <Button onClick={() => setDepth(1)}>{'Collapse All'}</Button>\n        <Button onClick={() => setDepth(12)}>{'Expand All'}</Button>\n        <Button\n          onClick={() =>\n            setOrientation((prev) =>\n              prev === 'horizontal' ? 'vertical' : 'horizontal',\n            )\n          }\n        >\n          {'Toggle Orientation'}\n        </Button>\n      </div>\n\n      <Container fluid className=\"p-0\" style={{ overflow: 'hidden' }}>\n        <Row className=\"map-column\" sm={12}>\n          <Col style={{ height: '85vh' }}>\n            {edges_data.isFetching || points_data.isFetching ? (\n              <Loader />\n            ) : (\n              <AutoFitTree\n                initialDepth={depth}\n                data={treeData}\n                orientation={orientation}\n                onNodeClick={onNodeClick}\n              />\n            )}\n            <RightPanel\n              className={`right-panel ${showRightPanel ? 'open' : ''}`}\n              point={selectedPoint}\n              onClose={() => {\n                setSelectedPoint(null);\n                setShowRightPanel(false);\n              }}\n            />\n          </Col>\n        </Row>\n      </Container>\n    </div>\n  );\n};\nexport default HierarchyGraph;\n"],"mappings":"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"}
@@ -0,0 +1,77 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.default = void 0;
8
+ var _react = _interopRequireDefault(require("react"));
9
+ var _zoomIn = require("@svgr/webpack?&svgo=false&ref!assets/icons/zoom-in.svg");
10
+ var _scoreToData = require("../../utilities/scoreToData");
11
+ var _FactoryCard = _interopRequireDefault(require("../../Widgets/MostPolluting/Factories/FactoryBox/FactoryCard"));
12
+ var _NodeIcon = _interopRequireDefault(require("./NodeIcon"));
13
+ var _TopNavbar = require("../../assets/icons/TopNavbar");
14
+ var _StyledLink = require("components/Links/StyledLink/StyledLink");
15
+ var _utils = require("./utils");
16
+ var _theme = require("styles/theme/theme");
17
+ var _PointUtils = require("../../Widgets/Map/points/PointUtils");
18
+ var Node = function Node(_ref) {
19
+ var _nodeDatum$attributes, _nodeDatum$attributes2, _nodeDatum$attributes3, _nodeDatum$attributes4, _nodeDatum$attributes5, _nodeDatum$attributes6, _nodeDatum$attributes7, _nodeDatum$attributes8;
20
+ var nodeDatum = _ref.nodeDatum,
21
+ toggleNode = _ref.toggleNode,
22
+ onNodeClick = _ref.onNodeClick,
23
+ siteID = _ref.siteID;
24
+ var score = ((_nodeDatum$attributes = nodeDatum.attributes) === null || _nodeDatum$attributes === void 0 ? void 0 : _nodeDatum$attributes.score) || 0;
25
+ var borderColor = (0, _scoreToData.scoreToColor)(score);
26
+ var factoryType = (_nodeDatum$attributes2 = nodeDatum.attributes) === null || _nodeDatum$attributes2 === void 0 ? void 0 : _nodeDatum$attributes2.type;
27
+ var qualityData = (_nodeDatum$attributes3 = nodeDatum.attributes) === null || _nodeDatum$attributes3 === void 0 ? void 0 : _nodeDatum$attributes3.type_distribution;
28
+ var isLeafNode = !nodeDatum.children || nodeDatum.children.length === 0;
29
+ var isMonitored = (_nodeDatum$attributes4 = nodeDatum.attributes) === null || _nodeDatum$attributes4 === void 0 ? void 0 : _nodeDatum$attributes4.monitored;
30
+ var isFocused = siteID === ((_nodeDatum$attributes5 = nodeDatum.attributes) === null || _nodeDatum$attributes5 === void 0 ? void 0 : (_nodeDatum$attributes6 = _nodeDatum$attributes5.point_id) === null || _nodeDatum$attributes6 === void 0 ? void 0 : _nodeDatum$attributes6.toString());
31
+ var isUpsaleLeafNode = isLeafNode && !(0, _PointUtils.isFactoryType)(factoryType);
32
+ var cardStyle = {
33
+ borderColor: borderColor,
34
+ borderStyle: isLeafNode ? 'double' : isMonitored ? 'solid' : 'dashed',
35
+ borderWidth: isLeafNode ? '5px' : '3px',
36
+ backgroundColor: isFocused ? _theme.theme.colorScheme.primary.pt20 : isUpsaleLeafNode ? _theme.theme.colorScheme.secondary.s3 : '#FFFFFF'
37
+ };
38
+ var title = factoryType === 'area' ? (_nodeDatum$attributes7 = nodeDatum.attributes) === null || _nodeDatum$attributes7 === void 0 ? void 0 : _nodeDatum$attributes7.area_name : nodeDatum.name;
39
+ var onShowDetails = function onShowDetails(event) {
40
+ event.stopPropagation();
41
+ onNodeClick(event);
42
+ };
43
+ if (!nodeDatum.name) {
44
+ return null;
45
+ }
46
+ return /*#__PURE__*/_react.default.createElement("g", {
47
+ onClick: toggleNode,
48
+ style: {
49
+ cursor: 'pointer'
50
+ }
51
+ }, /*#__PURE__*/_react.default.createElement("foreignObject", {
52
+ x: "-100",
53
+ y: "-50",
54
+ width: "200",
55
+ height: "100"
56
+ }, /*#__PURE__*/_react.default.createElement(_FactoryCard.default, {
57
+ style: cardStyle,
58
+ title: title,
59
+ type: factoryType,
60
+ score: score,
61
+ qualityData: qualityData,
62
+ headerRight: /*#__PURE__*/_react.default.createElement(_NodeIcon.default, {
63
+ type: factoryType
64
+ })
65
+ }, /*#__PURE__*/_react.default.createElement(_utils.ActionsContainer, null, /*#__PURE__*/_react.default.createElement(_zoomIn.ReactComponent, {
66
+ onClick: onShowDetails
67
+ }), /*#__PURE__*/_react.default.createElement(_StyledLink.StyledLink, {
68
+ target: "_blank",
69
+ to: "/dashboard_v2/site/".concat((_nodeDatum$attributes8 = nodeDatum.attributes) === null || _nodeDatum$attributes8 === void 0 ? void 0 : _nodeDatum$attributes8.point_id),
70
+ onClick: function onClick(e) {
71
+ return e.stopPropagation();
72
+ }
73
+ }, /*#__PURE__*/_react.default.createElement(_TopNavbar.DashboardSvg, null))))));
74
+ };
75
+ var _default = Node;
76
+ exports.default = _default;
77
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_zoomIn","_scoreToData","_FactoryCard","_NodeIcon","_TopNavbar","_StyledLink","_utils","_theme","_PointUtils","Node","_ref","_nodeDatum$attributes","_nodeDatum$attributes2","_nodeDatum$attributes3","_nodeDatum$attributes4","_nodeDatum$attributes5","_nodeDatum$attributes6","_nodeDatum$attributes7","_nodeDatum$attributes8","nodeDatum","toggleNode","onNodeClick","siteID","score","attributes","borderColor","scoreToColor","factoryType","type","qualityData","type_distribution","isLeafNode","children","length","isMonitored","monitored","isFocused","point_id","toString","isUpsaleLeafNode","isFactoryType","cardStyle","borderStyle","borderWidth","backgroundColor","theme","colorScheme","primary","pt20","secondary","s3","title","area_name","name","onShowDetails","event","stopPropagation","default","createElement","onClick","style","cursor","x","y","width","height","headerRight","ActionsContainer","ReactComponent","StyledLink","target","to","concat","e","DashboardSvg","_default","exports"],"sources":["../../../src/ui-kit/HierarchyGraph/Node.tsx"],"sourcesContent":["import React from 'react';\nimport { ReactComponent as DetailsSvg } from 'src/assets/icons/zoom-in.svg';\nimport { scoreToColor } from '../../utilities/scoreToData';\nimport FactoryCard from '../../Widgets/MostPolluting/Factories/FactoryBox/FactoryCard';\nimport NodeIcon from './NodeIcon';\nimport { DashboardSvg } from '../../assets/icons/TopNavbar';\nimport { StyledLink } from 'src/components/Links/StyledLink/StyledLink';\nimport { ActionsContainer } from './utils';\nimport { theme } from 'src/styles/theme/theme';\nimport { isFactoryType } from '../../Widgets/Map/points/PointUtils';\n\nconst Node = ({ nodeDatum, toggleNode, onNodeClick, siteID }) => {\n  const score = nodeDatum.attributes?.score || 0;\n  const borderColor = scoreToColor(score);\n  const factoryType = nodeDatum.attributes?.type;\n  const qualityData = nodeDatum.attributes?.type_distribution;\n  const isLeafNode = !nodeDatum.children || nodeDatum.children.length === 0;\n  const isMonitored = nodeDatum.attributes?.monitored;\n  const isFocused = siteID === nodeDatum.attributes?.point_id?.toString();\n  const isUpsaleLeafNode = isLeafNode && !isFactoryType(factoryType);\n\n  const cardStyle: React.CSSProperties = {\n    borderColor,\n    borderStyle: isLeafNode ? 'double' : isMonitored ? 'solid' : 'dashed',\n    borderWidth: isLeafNode ? '5px' : '3px',\n    backgroundColor: isFocused\n      ? theme.colorScheme.primary.pt20\n      : isUpsaleLeafNode\n      ? theme.colorScheme.secondary.s3\n      : '#FFFFFF',\n  };\n  const title =\n    factoryType === 'area' ? nodeDatum.attributes?.area_name : nodeDatum.name;\n  const onShowDetails = (event) => {\n    event.stopPropagation();\n    onNodeClick(event);\n  };\n\n  if (!nodeDatum.name) {\n    return null;\n  }\n  return (\n    <g onClick={toggleNode} style={{ cursor: 'pointer' }}>\n      <foreignObject x=\"-100\" y=\"-50\" width=\"200\" height=\"100\">\n        <FactoryCard\n          style={cardStyle}\n          title={title}\n          type={factoryType}\n          score={score}\n          qualityData={qualityData}\n          headerRight={<NodeIcon type={factoryType} />}\n        >\n          {/*<SeverityBadge props={{ props: {score} }} />*/}\n          <ActionsContainer>\n            <DetailsSvg onClick={onShowDetails} />\n            <StyledLink\n              target=\"_blank\"\n              to={`/dashboard_v2/site/${nodeDatum.attributes?.point_id}`}\n              onClick={(e) => e.stopPropagation()}\n            >\n              <DashboardSvg />\n            </StyledLink>\n          </ActionsContainer>\n        </FactoryCard>\n      </foreignObject>\n    </g>\n  );\n};\nexport default Node;\n"],"mappings":"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"}
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.default = void 0;
8
+ var _i18n = _interopRequireDefault(require("utilities/i18n"));
9
+ var _react = _interopRequireDefault(require("react"));
10
+ var _PointUtils = require("../../Widgets/Map/points/PointUtils");
11
+ var _assets = require("../../components/Tabs/assets");
12
+ var NodeIcon = function NodeIcon(_ref) {
13
+ var type = _ref.type;
14
+ var style = {
15
+ width: '25px',
16
+ height: '25px',
17
+ fill: '#555'
18
+ };
19
+ if ((0, _PointUtils.isFactoryType)(type)) {
20
+ return /*#__PURE__*/_react.default.createElement(_assets.PlantSvg, {
21
+ style: style,
22
+ title: _i18n.default.t('Factory')
23
+ });
24
+ }
25
+ if ((0, _PointUtils.pointIsWWTP)({
26
+ group: {
27
+ type: type
28
+ }
29
+ })) {
30
+ return /*#__PURE__*/_react.default.createElement(_assets.MatashSvg, {
31
+ style: style,
32
+ title: _i18n.default.t('WWTP')
33
+ });
34
+ }
35
+ if (type === 'area') {
36
+ return /*#__PURE__*/_react.default.createElement(_assets.ShapeSvg, {
37
+ style: style,
38
+ title: _i18n.default.t('Area')
39
+ });
40
+ }
41
+ return null;
42
+ };
43
+ var _default = NodeIcon;
44
+ exports.default = _default;
45
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfaTE4biIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwiX3JlYWN0IiwiX1BvaW50VXRpbHMiLCJfYXNzZXRzIiwiTm9kZUljb24iLCJfcmVmIiwidHlwZSIsInN0eWxlIiwid2lkdGgiLCJoZWlnaHQiLCJmaWxsIiwiaXNGYWN0b3J5VHlwZSIsImRlZmF1bHQiLCJjcmVhdGVFbGVtZW50IiwiUGxhbnRTdmciLCJ0aXRsZSIsImkxOG4iLCJ0IiwicG9pbnRJc1dXVFAiLCJncm91cCIsIk1hdGFzaFN2ZyIsIlNoYXBlU3ZnIiwiX2RlZmF1bHQiLCJleHBvcnRzIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3VpLWtpdC9IaWVyYXJjaHlHcmFwaC9Ob2RlSWNvbi50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGkxOG4gZnJvbSAnc3JjL3V0aWxpdGllcy9pMThuJztcbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQge1xuICBpc0ZhY3RvcnlUeXBlLFxuICBwb2ludElzV1dUUCxcbn0gZnJvbSAnLi4vLi4vV2lkZ2V0cy9NYXAvcG9pbnRzL1BvaW50VXRpbHMnO1xuaW1wb3J0IHsgU2hhcGVTdmcsIE1hdGFzaFN2ZywgUGxhbnRTdmcgfSBmcm9tICcuLi8uLi9jb21wb25lbnRzL1RhYnMvYXNzZXRzJztcblxuY29uc3QgTm9kZUljb24gPSAoeyB0eXBlIH06IHsgdHlwZTogc3RyaW5nIH0pID0+IHtcbiAgY29uc3Qgc3R5bGUgPSB7IHdpZHRoOiAnMjVweCcsIGhlaWdodDogJzI1cHgnLCBmaWxsOiAnIzU1NScgfTtcblxuICBpZiAoaXNGYWN0b3J5VHlwZSh0eXBlKSkge1xuICAgIHJldHVybiA8UGxhbnRTdmcgc3R5bGU9e3N0eWxlfSB0aXRsZT17aTE4bi50KCdGYWN0b3J5Jyl9IC8+O1xuICB9XG4gIGlmIChwb2ludElzV1dUUCh7IGdyb3VwOiB7IHR5cGUgfSB9KSkge1xuICAgIHJldHVybiA8TWF0YXNoU3ZnIHN0eWxlPXtzdHlsZX0gdGl0bGU9e2kxOG4udCgnV1dUUCcpfSAvPjtcbiAgfVxuICBpZiAodHlwZSA9PT0gJ2FyZWEnKSB7XG4gICAgcmV0dXJuIDxTaGFwZVN2ZyBzdHlsZT17c3R5bGV9IHRpdGxlPXtpMThuLnQoJ0FyZWEnKX0gLz47XG4gIH1cbiAgcmV0dXJuIG51bGw7XG59O1xuZXhwb3J0IGRlZmF1bHQgTm9kZUljb247XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQSxJQUFBQSxLQUFBLEdBQUFDLHNCQUFBLENBQUFDLE9BQUE7QUFDQSxJQUFBQyxNQUFBLEdBQUFGLHNCQUFBLENBQUFDLE9BQUE7QUFDQSxJQUFBRSxXQUFBLEdBQUFGLE9BQUE7QUFJQSxJQUFBRyxPQUFBLEdBQUFILE9BQUE7QUFFQSxJQUFNSSxRQUFRLEdBQUcsU0FBWEEsUUFBUUEsQ0FBQUMsSUFBQSxFQUFtQztFQUFBLElBQTdCQyxJQUFJLEdBQUFELElBQUEsQ0FBSkMsSUFBSTtFQUN0QixJQUFNQyxLQUFLLEdBQUc7SUFBRUMsS0FBSyxFQUFFLE1BQU07SUFBRUMsTUFBTSxFQUFFLE1BQU07SUFBRUMsSUFBSSxFQUFFO0VBQU8sQ0FBQztFQUU3RCxJQUFJLElBQUFDLHlCQUFhLEVBQUNMLElBQUksQ0FBQyxFQUFFO0lBQ3ZCLG9CQUFPTCxNQUFBLENBQUFXLE9BQUEsQ0FBQUMsYUFBQSxDQUFDVixPQUFBLENBQUFXLFFBQVE7TUFBQ1AsS0FBSyxFQUFFQSxLQUFNO01BQUNRLEtBQUssRUFBRUMsYUFBSSxDQUFDQyxDQUFDLENBQUMsU0FBUztJQUFFLENBQUUsQ0FBQztFQUM3RDtFQUNBLElBQUksSUFBQUMsdUJBQVcsRUFBQztJQUFFQyxLQUFLLEVBQUU7TUFBRWIsSUFBSSxFQUFKQTtJQUFLO0VBQUUsQ0FBQyxDQUFDLEVBQUU7SUFDcEMsb0JBQU9MLE1BQUEsQ0FBQVcsT0FBQSxDQUFBQyxhQUFBLENBQUNWLE9BQUEsQ0FBQWlCLFNBQVM7TUFBQ2IsS0FBSyxFQUFFQSxLQUFNO01BQUNRLEtBQUssRUFBRUMsYUFBSSxDQUFDQyxDQUFDLENBQUMsTUFBTTtJQUFFLENBQUUsQ0FBQztFQUMzRDtFQUNBLElBQUlYLElBQUksS0FBSyxNQUFNLEVBQUU7SUFDbkIsb0JBQU9MLE1BQUEsQ0FBQVcsT0FBQSxDQUFBQyxhQUFBLENBQUNWLE9BQUEsQ0FBQWtCLFFBQVE7TUFBQ2QsS0FBSyxFQUFFQSxLQUFNO01BQUNRLEtBQUssRUFBRUMsYUFBSSxDQUFDQyxDQUFDLENBQUMsTUFBTTtJQUFFLENBQUUsQ0FBQztFQUMxRDtFQUNBLE9BQU8sSUFBSTtBQUNiLENBQUM7QUFBQyxJQUFBSyxRQUFBLEdBQ2FsQixRQUFRO0FBQUFtQixPQUFBLENBQUFYLE9BQUEsR0FBQVUsUUFBQSJ9
@@ -0,0 +1,113 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.default = exports.ButtonStyle = void 0;
8
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
9
+ var _react = _interopRequireDefault(require("react"));
10
+ var _reactBootstrap = require("react-bootstrap");
11
+ var OrientationSwitcher = function OrientationSwitcher(_ref) {
12
+ var orientation = _ref.orientation,
13
+ setOrientation = _ref.setOrientation;
14
+ return /*#__PURE__*/_react.default.createElement(ButtonStyle, {
15
+ rounded: true
16
+ }, /*#__PURE__*/_react.default.createElement("div", {
17
+ style: {
18
+ margin: '10px'
19
+ }
20
+ }, /*#__PURE__*/_react.default.createElement(_reactBootstrap.ButtonGroup, {
21
+ toggle: true
22
+ }, /*#__PURE__*/_react.default.createElement(_reactBootstrap.ToggleButton, {
23
+ type: "radio",
24
+ variant: orientation === 'horizontal' ? 'outline-primary' : 'outline-secondary',
25
+ name: "orientation",
26
+ value: "horizontal",
27
+ checked: orientation === 'horizontal',
28
+ onChange: function onChange() {
29
+ return setOrientation('horizontal');
30
+ }
31
+ }, 'Horizontal'), /*#__PURE__*/_react.default.createElement(_reactBootstrap.ToggleButton, {
32
+ type: "radio",
33
+ variant: orientation === 'vertical' ? 'outline-primary' : 'outline-secondary',
34
+ name: "orientation",
35
+ value: "vertical",
36
+ checked: orientation === 'vertical',
37
+ onChange: function onChange() {
38
+ return setOrientation('vertical');
39
+ }
40
+ }, 'Vertical'))));
41
+ };
42
+ var ButtonStyle = _styledComponents.default.div.attrs(function (props) {
43
+ return {
44
+ rounded: props.rounded
45
+ };
46
+ }).withConfig({
47
+ displayName: "OrientationSwitcher__ButtonStyle",
48
+ componentId: "sc-7t3mqp-0"
49
+ })([".btn{border-radius:", ";&.block{display:block;width:100%;}&.sm{font-size:", ";}&.md{font-size:", ";}&.lg{font-size:", ";}&.xl{font-size:", ";}}.btn-outline-primary{background-color:", ";border-color:", ";color:", ";&.outline{background-color:transparent;color:", ";}&.btn-primary:active{background-color:", ";border-color:", ";}&.btn-primary:focus{box-shadow:0 0 0 3px ", ";}&.btn-primary:hover{background-color:", ";color:", ";}&.active.btn{background-color:", ";border-color:", ";}}.btn-secondary{background-color:", ";color:", ";border:none;&.outline{background-color:transparent;color:", ";}&.btn-secondary:active{}&.btn-secondary:focus{box-shadow:0 0 0 3px ", ";}&.btn-secondary:hover{font-weight:600;}}"], function (_ref2) {
50
+ var rounded = _ref2.rounded;
51
+ return rounded ? '20px' : '4px';
52
+ }, function (_ref3) {
53
+ var theme = _ref3.theme;
54
+ return theme.fontSize.sm;
55
+ }, function (_ref4) {
56
+ var theme = _ref4.theme;
57
+ return theme.fontSize.md;
58
+ }, function (_ref5) {
59
+ var theme = _ref5.theme;
60
+ return theme.fontSize.lg;
61
+ }, function (_ref6) {
62
+ var theme = _ref6.theme;
63
+ return theme.fontSize.xl;
64
+ }, function (_ref7) {
65
+ var theme = _ref7.theme;
66
+ return theme.colorScheme.primary.p1;
67
+ }, function (_ref8) {
68
+ var theme = _ref8.theme;
69
+ return theme.colorScheme.primary.p1;
70
+ }, function (_ref9) {
71
+ var theme = _ref9.theme;
72
+ return theme.colorScheme.natural.n1;
73
+ }, function (_ref10) {
74
+ var theme = _ref10.theme;
75
+ return theme.colorScheme.primary.p1;
76
+ }, function (_ref11) {
77
+ var theme = _ref11.theme;
78
+ return theme.colorScheme.primary.p1;
79
+ }, function (_ref12) {
80
+ var theme = _ref12.theme;
81
+ return theme.colorScheme.primary.p1;
82
+ }, function (_ref13) {
83
+ var theme = _ref13.theme;
84
+ return theme.colorScheme.primary.pt50;
85
+ }, function (_ref14) {
86
+ var theme = _ref14.theme;
87
+ return theme.colorScheme.primary.pt80;
88
+ }, function (_ref15) {
89
+ var theme = _ref15.theme;
90
+ return theme.colorScheme.natural.n1;
91
+ }, function (_ref16) {
92
+ var theme = _ref16.theme;
93
+ return theme.colorScheme.primary.p1;
94
+ }, function (_ref17) {
95
+ var theme = _ref17.theme;
96
+ return theme.colorScheme.primary.p1;
97
+ }, function (_ref18) {
98
+ var theme = _ref18.theme;
99
+ return theme.colorScheme.natural.n1;
100
+ }, function (_ref19) {
101
+ var theme = _ref19.theme;
102
+ return theme.colorScheme.natural.n100;
103
+ }, function (_ref20) {
104
+ var theme = _ref20.theme;
105
+ return theme.colorScheme.secondary.s1;
106
+ }, function (_ref21) {
107
+ var theme = _ref21.theme;
108
+ return theme.colorScheme.secondary.s2;
109
+ });
110
+ exports.ButtonStyle = ButtonStyle;
111
+ var _default = OrientationSwitcher;
112
+ exports.default = _default;
113
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_reactBootstrap","OrientationSwitcher","_ref","orientation","setOrientation","default","createElement","ButtonStyle","rounded","style","margin","ButtonGroup","toggle","ToggleButton","type","variant","name","value","checked","onChange","styled","div","attrs","props","withConfig","displayName","componentId","_ref2","_ref3","theme","fontSize","sm","_ref4","md","_ref5","lg","_ref6","xl","_ref7","colorScheme","primary","p1","_ref8","_ref9","natural","n1","_ref10","_ref11","_ref12","_ref13","pt50","_ref14","pt80","_ref15","_ref16","_ref17","_ref18","_ref19","n100","_ref20","secondary","s1","_ref21","s2","exports","_default"],"sources":["../../../src/ui-kit/HierarchyGraph/OrientationSwitcher.tsx"],"sourcesContent":["import React from 'react';\nimport styled from 'styled-components/macro';\nimport { ButtonGroup, ToggleButton } from 'react-bootstrap';\n\nconst OrientationSwitcher = ({ orientation, setOrientation }) => {\n  return (\n    <ButtonStyle rounded={true}>\n      <div style={{ margin: '10px' }}>\n        <ButtonGroup toggle>\n          <ToggleButton\n            type=\"radio\"\n            variant={\n              orientation === 'horizontal'\n                ? 'outline-primary'\n                : 'outline-secondary'\n            }\n            name=\"orientation\"\n            value=\"horizontal\"\n            checked={orientation === 'horizontal'}\n            onChange={() => setOrientation('horizontal')}\n          >\n            {'Horizontal'}\n          </ToggleButton>\n          <ToggleButton\n            type=\"radio\"\n            variant={\n              orientation === 'vertical'\n                ? 'outline-primary'\n                : 'outline-secondary'\n            }\n            name=\"orientation\"\n            value=\"vertical\"\n            checked={orientation === 'vertical'}\n            onChange={() => setOrientation('vertical')}\n          >\n            {'Vertical'}\n          </ToggleButton>\n        </ButtonGroup>\n      </div>\n    </ButtonStyle>\n  );\n};\ninterface buttonStyleProps {\n  rounded?: boolean;\n  width?: string;\n}\n\nexport const ButtonStyle = styled.div.attrs((props: buttonStyleProps) => ({\n  rounded: props.rounded,\n}))`\n  .btn {\n    border-radius: ${({ rounded }) => (rounded ? '20px' : '4px')};\n    &.block {\n      display: block;\n      width: 100%;\n    }\n    &.sm {\n      font-size: ${({ theme }) => theme.fontSize.sm};\n    }\n    &.md {\n      font-size: ${({ theme }) => theme.fontSize.md};\n    }\n    &.lg {\n      font-size: ${({ theme }) => theme.fontSize.lg};\n    }\n    &.xl {\n      font-size: ${({ theme }) => theme.fontSize.xl};\n    }\n  }\n\n  .btn-outline-primary {\n    background-color: ${({ theme }) => theme.colorScheme.primary.p1};\n    border-color: ${({ theme }) => theme.colorScheme.primary.p1};\n    color: ${({ theme }) => theme.colorScheme.natural.n1};\n    &.outline {\n      background-color: transparent;\n      color: ${({ theme }) => theme.colorScheme.primary.p1};\n    }\n    &.btn-primary:active {\n      background-color: ${({ theme }) => theme.colorScheme.primary.p1};\n      border-color: ${({ theme }) => theme.colorScheme.primary.p1};\n    }\n    &.btn-primary:focus {\n      box-shadow: 0 0 0 3px ${({ theme }) => theme.colorScheme.primary.pt50};\n    }\n    &.btn-primary:hover {\n      background-color: ${({ theme }) => theme.colorScheme.primary.pt80};\n      color: ${({ theme }) => theme.colorScheme.natural.n1};\n    }\n    &.active.btn {\n      background-color: ${({ theme }) => theme.colorScheme.primary.p1};\n      border-color: ${({ theme }) => theme.colorScheme.primary.p1};\n    }\n  }\n\n  .btn-secondary {\n    background-color: ${({ theme }) => theme.colorScheme.natural.n1};\n    color: ${({ theme }) => theme.colorScheme.natural.n100};\n    border: none;\n    &.outline {\n      background-color: transparent;\n      color: ${({ theme }) => theme.colorScheme.secondary.s1};\n    }\n    &.btn-secondary:active {\n    }\n    &.btn-secondary:focus {\n      box-shadow: 0 0 0 3px ${({ theme }) => theme.colorScheme.secondary.s2};\n    }\n    &.btn-secondary:hover {\n      font-weight: 600;\n    }\n  }\n`;\nexport default OrientationSwitcher;\n"],"mappings":"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"}
@@ -4,16 +4,22 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
4
4
  Object.defineProperty(exports, "__esModule", {
5
5
  value: true
6
6
  });
7
+ exports.ActionsContainer = void 0;
7
8
  exports.buildTree = buildTree;
8
9
  exports.mapById = mapById;
10
+ var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/objectSpread2"));
11
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/objectWithoutProperties"));
9
12
  var _createForOfIteratorHelper2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/createForOfIteratorHelper"));
13
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
14
+ var _excluded = ["name"],
15
+ _excluded2 = ["id", "name", "has_device", "group", "area_name"];
10
16
  /**
11
17
  * Convert edges to rows suitable for d3.stratify()
12
18
  * Returns an array of { id, parentId, distance?, shape_data? }
13
19
  * If multiple roots exist, you can optionally add a super root row.
14
20
  */
15
21
 
16
- function buildTree(connections, point_names, utility_name) {
22
+ function buildTree(connections, point_data, utility_name) {
17
23
  var nodes = {};
18
24
  var children = new Set();
19
25
 
@@ -26,19 +32,30 @@ function buildTree(connections, point_names, utility_name) {
26
32
  source_point_id = _step$value.source_point_id,
27
33
  target_point_id = _step$value.target_point_id,
28
34
  distance = _step$value.distance;
35
+ var _ref = point_data[source_point_id] || {},
36
+ name = _ref.name,
37
+ sourceData = (0, _objectWithoutProperties2.default)(_ref, _excluded);
29
38
  if (!nodes[source_point_id]) nodes[source_point_id] = {
30
- name: point_names[source_point_id],
31
- children: [],
32
- attributes: {
33
- distance: distance
34
- }
35
- };
36
- if (!nodes[target_point_id]) nodes[target_point_id] = {
37
- name: point_names[target_point_id],
39
+ name: name,
38
40
  children: []
39
41
  };
42
+ if (!nodes[target_point_id]) {
43
+ var target_data = point_data[target_point_id] || {};
44
+ nodes[target_point_id] = {
45
+ name: target_data.name,
46
+ attributes: (0, _objectSpread2.default)((0, _objectSpread2.default)({}, target_data), {}, {
47
+ point_id: target_point_id
48
+ }),
49
+ children: []
50
+ };
51
+ }
40
52
  nodes[target_point_id].children.push(nodes[source_point_id]);
41
53
  children.add(source_point_id);
54
+ nodes[source_point_id].attributes = (0, _objectSpread2.default)((0, _objectSpread2.default)({
55
+ distance: distance
56
+ }, sourceData), {}, {
57
+ point_id: source_point_id
58
+ });
42
59
  }
43
60
 
44
61
  // Find root(s)
@@ -60,11 +77,25 @@ function buildTree(connections, point_names, utility_name) {
60
77
  };
61
78
  }
62
79
  function mapById(items) {
63
- return items.reduce(function (acc, _ref) {
64
- var id = _ref.id,
65
- name = _ref.name;
66
- acc[id] = name;
80
+ return items.reduce(function (acc, _ref2) {
81
+ var id = _ref2.id,
82
+ name = _ref2.name,
83
+ has_device = _ref2.has_device,
84
+ group = _ref2.group,
85
+ area_name = _ref2.area_name,
86
+ props = (0, _objectWithoutProperties2.default)(_ref2, _excluded2);
87
+ acc[id] = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, props), {}, {
88
+ name: name,
89
+ monitored: has_device,
90
+ type: area_name ? 'area' : group.type,
91
+ area_name: area_name
92
+ });
67
93
  return acc;
68
94
  }, {});
69
95
  }
70
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJidWlsZFRyZWUiLCJjb25uZWN0aW9ucyIsInBvaW50X25hbWVzIiwidXRpbGl0eV9uYW1lIiwibm9kZXMiLCJjaGlsZHJlbiIsIlNldCIsIl9pdGVyYXRvciIsIl9jcmVhdGVGb3JPZkl0ZXJhdG9ySGVscGVyMiIsImRlZmF1bHQiLCJfc3RlcCIsInMiLCJuIiwiZG9uZSIsIl9zdGVwJHZhbHVlIiwidmFsdWUiLCJzb3VyY2VfcG9pbnRfaWQiLCJ0YXJnZXRfcG9pbnRfaWQiLCJkaXN0YW5jZSIsIm5hbWUiLCJhdHRyaWJ1dGVzIiwicHVzaCIsImFkZCIsImVyciIsImUiLCJmIiwicm9vdHMiLCJPYmplY3QiLCJrZXlzIiwiZmlsdGVyIiwiaWQiLCJoYXMiLCJOdW1iZXIiLCJtYXAiLCJsZW5ndGgiLCJtYXBCeUlkIiwiaXRlbXMiLCJyZWR1Y2UiLCJhY2MiLCJfcmVmIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3VpLWtpdC9IaWVyYXJjaHlHcmFwaC91dGlscy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvbnZlcnQgZWRnZXMgdG8gcm93cyBzdWl0YWJsZSBmb3IgZDMuc3RyYXRpZnkoKVxuICogUmV0dXJucyBhbiBhcnJheSBvZiB7IGlkLCBwYXJlbnRJZCwgZGlzdGFuY2U/LCBzaGFwZV9kYXRhPyB9XG4gKiBJZiBtdWx0aXBsZSByb290cyBleGlzdCwgeW91IGNhbiBvcHRpb25hbGx5IGFkZCBhIHN1cGVyIHJvb3Qgcm93LlxuICovXG50eXBlIEVkZ2UgPSB7XG4gIHNvdXJjZV9wb2ludF9pZDogbnVtYmVyIHwgc3RyaW5nO1xuICB0YXJnZXRfcG9pbnRfaWQ6IG51bWJlciB8IHN0cmluZztcbiAgZGlzdGFuY2U/OiBudW1iZXI7XG59O1xudHlwZSBUcmVlTm9kZSA9IHtcbiAgbmFtZTogc3RyaW5nO1xuICBjaGlsZHJlbj86IFRyZWVOb2RlW107XG4gIGF0dHJpYnV0ZXM/OiB7IGRpc3RhbmNlOiBudW1iZXIgfTtcbn07XG50eXBlIFRyZWVEYXRhID0gVHJlZU5vZGUgfCB7IG5hbWU6IHN0cmluZzsgY2hpbGRyZW46IFRyZWVOb2RlW10gfTtcblxuZXhwb3J0IGZ1bmN0aW9uIGJ1aWxkVHJlZShcbiAgY29ubmVjdGlvbnM6IEVkZ2VbXSxcbiAgcG9pbnRfbmFtZXMsXG4gIHV0aWxpdHlfbmFtZSxcbik6IFRyZWVEYXRhIHtcbiAgY29uc3Qgbm9kZXMgPSB7fTtcbiAgY29uc3QgY2hpbGRyZW4gPSBuZXcgU2V0KCk7XG5cbiAgLy8gQnVpbGQgbWFwIG9mIG5vZGVzIGFuZCB0cmFjayBjaGlsZHJlblxuICBmb3IgKGNvbnN0IHsgc291cmNlX3BvaW50X2lkLCB0YXJnZXRfcG9pbnRfaWQsIGRpc3RhbmNlIH0gb2YgY29ubmVjdGlvbnMpIHtcbiAgICBpZiAoIW5vZGVzW3NvdXJjZV9wb2ludF9pZF0pXG4gICAgICBub2Rlc1tzb3VyY2VfcG9pbnRfaWRdID0ge1xuICAgICAgICBuYW1lOiBwb2ludF9uYW1lc1tzb3VyY2VfcG9pbnRfaWRdLFxuICAgICAgICBjaGlsZHJlbjogW10sXG4gICAgICAgIGF0dHJpYnV0ZXM6IHsgZGlzdGFuY2UgfSxcbiAgICAgIH07XG4gICAgaWYgKCFub2Rlc1t0YXJnZXRfcG9pbnRfaWRdKVxuICAgICAgbm9kZXNbdGFyZ2V0X3BvaW50X2lkXSA9IHtcbiAgICAgICAgbmFtZTogcG9pbnRfbmFtZXNbdGFyZ2V0X3BvaW50X2lkXSxcbiAgICAgICAgY2hpbGRyZW46IFtdLFxuICAgICAgfTtcbiAgICBub2Rlc1t0YXJnZXRfcG9pbnRfaWRdLmNoaWxkcmVuLnB1c2gobm9kZXNbc291cmNlX3BvaW50X2lkXSk7XG4gICAgY2hpbGRyZW4uYWRkKHNvdXJjZV9wb2ludF9pZCk7XG4gIH1cblxuICAvLyBGaW5kIHJvb3QocylcbiAgY29uc3Qgcm9vdHMgPSBPYmplY3Qua2V5cyhub2RlcylcbiAgICAuZmlsdGVyKChpZCkgPT4gIWNoaWxkcmVuLmhhcyhOdW1iZXIoaWQpKSlcbiAgICAubWFwKChpZCkgPT4gbm9kZXNbaWRdKTtcblxuICAvLyBJZiBtdWx0aXBsZSByb290cyBleGlzdCwgd3JhcCBpbiBhIHN1cGVyIHJvb3RcbiAgcmV0dXJuIHJvb3RzLmxlbmd0aCA9PT0gMVxuICAgID8gcm9vdHNbMF1cbiAgICA6IHsgbmFtZTogdXRpbGl0eV9uYW1lLCBjaGlsZHJlbjogcm9vdHMgfTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIG1hcEJ5SWQ8VCBleHRlbmRzIHsgaWQ6IHN0cmluZyB8IG51bWJlcjsgbmFtZTogc3RyaW5nIH0+KFxuICBpdGVtczogVFtdLFxuKTogUmVjb3JkPHN0cmluZyB8IG51bWJlciwgc3RyaW5nPiB7XG4gIHJldHVybiBpdGVtcy5yZWR1Y2UoKGFjYywgeyBpZCwgbmFtZSB9KSA9PiB7XG4gICAgYWNjW2lkXSA9IG5hbWU7XG4gICAgcmV0dXJuIGFjYztcbiAgfSwge30gYXMgUmVjb3JkPHN0cmluZyB8IG51bWJlciwgc3RyaW5nPik7XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBYU8sU0FBU0EsU0FBU0EsQ0FDdkJDLFdBQW1CLEVBQ25CQyxXQUFXLEVBQ1hDLFlBQVksRUFDRjtFQUNWLElBQU1DLEtBQUssR0FBRyxDQUFDLENBQUM7RUFDaEIsSUFBTUMsUUFBUSxHQUFHLElBQUlDLEdBQUcsQ0FBQyxDQUFDOztFQUUxQjtFQUFBLElBQUFDLFNBQUEsT0FBQUMsMkJBQUEsQ0FBQUMsT0FBQSxFQUM2RFIsV0FBVztJQUFBUyxLQUFBO0VBQUE7SUFBeEUsS0FBQUgsU0FBQSxDQUFBSSxDQUFBLE1BQUFELEtBQUEsR0FBQUgsU0FBQSxDQUFBSyxDQUFBLElBQUFDLElBQUEsR0FBMEU7TUFBQSxJQUFBQyxXQUFBLEdBQUFKLEtBQUEsQ0FBQUssS0FBQTtRQUE3REMsZUFBZSxHQUFBRixXQUFBLENBQWZFLGVBQWU7UUFBRUMsZUFBZSxHQUFBSCxXQUFBLENBQWZHLGVBQWU7UUFBRUMsUUFBUSxHQUFBSixXQUFBLENBQVJJLFFBQVE7TUFDckQsSUFBSSxDQUFDZCxLQUFLLENBQUNZLGVBQWUsQ0FBQyxFQUN6QlosS0FBSyxDQUFDWSxlQUFlLENBQUMsR0FBRztRQUN2QkcsSUFBSSxFQUFFakIsV0FBVyxDQUFDYyxlQUFlLENBQUM7UUFDbENYLFFBQVEsRUFBRSxFQUFFO1FBQ1plLFVBQVUsRUFBRTtVQUFFRixRQUFRLEVBQVJBO1FBQVM7TUFDekIsQ0FBQztNQUNILElBQUksQ0FBQ2QsS0FBSyxDQUFDYSxlQUFlLENBQUMsRUFDekJiLEtBQUssQ0FBQ2EsZUFBZSxDQUFDLEdBQUc7UUFDdkJFLElBQUksRUFBRWpCLFdBQVcsQ0FBQ2UsZUFBZSxDQUFDO1FBQ2xDWixRQUFRLEVBQUU7TUFDWixDQUFDO01BQ0hELEtBQUssQ0FBQ2EsZUFBZSxDQUFDLENBQUNaLFFBQVEsQ0FBQ2dCLElBQUksQ0FBQ2pCLEtBQUssQ0FBQ1ksZUFBZSxDQUFDLENBQUM7TUFDNURYLFFBQVEsQ0FBQ2lCLEdBQUcsQ0FBQ04sZUFBZSxDQUFDO0lBQy9COztJQUVBO0VBQUEsU0FBQU8sR0FBQTtJQUFBaEIsU0FBQSxDQUFBaUIsQ0FBQSxDQUFBRCxHQUFBO0VBQUE7SUFBQWhCLFNBQUEsQ0FBQWtCLENBQUE7RUFBQTtFQUNBLElBQU1DLEtBQUssR0FBR0MsTUFBTSxDQUFDQyxJQUFJLENBQUN4QixLQUFLLENBQUMsQ0FDN0J5QixNQUFNLENBQUMsVUFBQ0MsRUFBRTtJQUFBLE9BQUssQ0FBQ3pCLFFBQVEsQ0FBQzBCLEdBQUcsQ0FBQ0MsTUFBTSxDQUFDRixFQUFFLENBQUMsQ0FBQztFQUFBLEVBQUMsQ0FDekNHLEdBQUcsQ0FBQyxVQUFDSCxFQUFFO0lBQUEsT0FBSzFCLEtBQUssQ0FBQzBCLEVBQUUsQ0FBQztFQUFBLEVBQUM7O0VBRXpCO0VBQ0EsT0FBT0osS0FBSyxDQUFDUSxNQUFNLEtBQUssQ0FBQyxHQUNyQlIsS0FBSyxDQUFDLENBQUMsQ0FBQyxHQUNSO0lBQUVQLElBQUksRUFBRWhCLFlBQVk7SUFBRUUsUUFBUSxFQUFFcUI7RUFBTSxDQUFDO0FBQzdDO0FBRU8sU0FBU1MsT0FBT0EsQ0FDckJDLEtBQVUsRUFDdUI7RUFDakMsT0FBT0EsS0FBSyxDQUFDQyxNQUFNLENBQUMsVUFBQ0MsR0FBRyxFQUFBQyxJQUFBLEVBQW1CO0lBQUEsSUFBZlQsRUFBRSxHQUFBUyxJQUFBLENBQUZULEVBQUU7TUFBRVgsSUFBSSxHQUFBb0IsSUFBQSxDQUFKcEIsSUFBSTtJQUNsQ21CLEdBQUcsQ0FBQ1IsRUFBRSxDQUFDLEdBQUdYLElBQUk7SUFDZCxPQUFPbUIsR0FBRztFQUNaLENBQUMsRUFBRSxDQUFDLENBQW9DLENBQUM7QUFDM0MifQ==
96
+ var ActionsContainer = _styledComponents.default.div.withConfig({
97
+ displayName: "utils__ActionsContainer",
98
+ componentId: "sc-21qmj9-0"
99
+ })(["{width:100%;text-align:center;margin-top:-10px;margin-inline-start:15px;}"]);
100
+ exports.ActionsContainer = ActionsContainer;
101
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJidWlsZFRyZWUiLCJjb25uZWN0aW9ucyIsInBvaW50X2RhdGEiLCJ1dGlsaXR5X25hbWUiLCJub2RlcyIsImNoaWxkcmVuIiwiU2V0IiwiX2l0ZXJhdG9yIiwiX2NyZWF0ZUZvck9mSXRlcmF0b3JIZWxwZXIyIiwiZGVmYXVsdCIsIl9zdGVwIiwicyIsIm4iLCJkb25lIiwiX3N0ZXAkdmFsdWUiLCJ2YWx1ZSIsInNvdXJjZV9wb2ludF9pZCIsInRhcmdldF9wb2ludF9pZCIsImRpc3RhbmNlIiwiX3JlZiIsIm5hbWUiLCJzb3VyY2VEYXRhIiwiX29iamVjdFdpdGhvdXRQcm9wZXJ0aWVzMiIsIl9leGNsdWRlZCIsInRhcmdldF9kYXRhIiwiYXR0cmlidXRlcyIsIl9vYmplY3RTcHJlYWQyIiwicG9pbnRfaWQiLCJwdXNoIiwiYWRkIiwiZXJyIiwiZSIsImYiLCJyb290cyIsIk9iamVjdCIsImtleXMiLCJmaWx0ZXIiLCJpZCIsImhhcyIsIk51bWJlciIsIm1hcCIsImxlbmd0aCIsIm1hcEJ5SWQiLCJpdGVtcyIsInJlZHVjZSIsImFjYyIsIl9yZWYyIiwiaGFzX2RldmljZSIsImdyb3VwIiwiYXJlYV9uYW1lIiwicHJvcHMiLCJfZXhjbHVkZWQyIiwibW9uaXRvcmVkIiwidHlwZSIsIkFjdGlvbnNDb250YWluZXIiLCJzdHlsZWQiLCJkaXYiLCJ3aXRoQ29uZmlnIiwiZGlzcGxheU5hbWUiLCJjb21wb25lbnRJZCIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdWkta2l0L0hpZXJhcmNoeUdyYXBoL3V0aWxzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElQb2ludCB9IGZyb20gJy4uLy4uL3N0b3JlL3BvaW50cy9tb2RlbHMvSVBvaW50JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnc3R5bGVkLWNvbXBvbmVudHMvbWFjcm8nO1xuXG4vKipcbiAqIENvbnZlcnQgZWRnZXMgdG8gcm93cyBzdWl0YWJsZSBmb3IgZDMuc3RyYXRpZnkoKVxuICogUmV0dXJucyBhbiBhcnJheSBvZiB7IGlkLCBwYXJlbnRJZCwgZGlzdGFuY2U/LCBzaGFwZV9kYXRhPyB9XG4gKiBJZiBtdWx0aXBsZSByb290cyBleGlzdCwgeW91IGNhbiBvcHRpb25hbGx5IGFkZCBhIHN1cGVyIHJvb3Qgcm93LlxuICovXG50eXBlIEVkZ2UgPSB7XG4gIHNvdXJjZV9wb2ludF9pZDogbnVtYmVyIHwgc3RyaW5nO1xuICB0YXJnZXRfcG9pbnRfaWQ6IG51bWJlciB8IHN0cmluZztcbiAgZGlzdGFuY2U/OiBudW1iZXI7XG59O1xudHlwZSBUcmVlTm9kZSA9IHtcbiAgbmFtZTogc3RyaW5nO1xuICBjaGlsZHJlbj86IFRyZWVOb2RlW107XG4gIGF0dHJpYnV0ZXM/OiB7IGRpc3RhbmNlOiBudW1iZXI7IHR5cGU6IHN0cmluZzsgbW9uaXRvcmVkOiBib29sZWFuIH07XG59O1xudHlwZSBUcmVlRGF0YSA9IFRyZWVOb2RlIHwgeyBuYW1lOiBzdHJpbmc7IGNoaWxkcmVuOiBUcmVlTm9kZVtdIH07XG5cbmV4cG9ydCBmdW5jdGlvbiBidWlsZFRyZWUoXG4gIGNvbm5lY3Rpb25zOiBFZGdlW10sXG4gIHBvaW50X2RhdGEsXG4gIHV0aWxpdHlfbmFtZSxcbik6IFRyZWVEYXRhIHtcbiAgY29uc3Qgbm9kZXMgPSB7fTtcbiAgY29uc3QgY2hpbGRyZW4gPSBuZXcgU2V0KCk7XG5cbiAgLy8gQnVpbGQgbWFwIG9mIG5vZGVzIGFuZCB0cmFjayBjaGlsZHJlblxuICBmb3IgKGNvbnN0IHsgc291cmNlX3BvaW50X2lkLCB0YXJnZXRfcG9pbnRfaWQsIGRpc3RhbmNlIH0gb2YgY29ubmVjdGlvbnMpIHtcbiAgICBjb25zdCB7IG5hbWUsIC4uLnNvdXJjZURhdGEgfSA9IHBvaW50X2RhdGFbc291cmNlX3BvaW50X2lkXSB8fCB7fTtcbiAgICBpZiAoIW5vZGVzW3NvdXJjZV9wb2ludF9pZF0pXG4gICAgICBub2Rlc1tzb3VyY2VfcG9pbnRfaWRdID0ge1xuICAgICAgICBuYW1lLFxuICAgICAgICBjaGlsZHJlbjogW10sXG4gICAgICB9O1xuICAgIGlmICghbm9kZXNbdGFyZ2V0X3BvaW50X2lkXSkge1xuICAgICAgY29uc3QgdGFyZ2V0X2RhdGEgPSBwb2ludF9kYXRhW3RhcmdldF9wb2ludF9pZF0gfHwge307XG4gICAgICBub2Rlc1t0YXJnZXRfcG9pbnRfaWRdID0ge1xuICAgICAgICBuYW1lOiB0YXJnZXRfZGF0YS5uYW1lLFxuICAgICAgICBhdHRyaWJ1dGVzOiB7XG4gICAgICAgICAgLi4udGFyZ2V0X2RhdGEsXG4gICAgICAgICAgcG9pbnRfaWQ6IHRhcmdldF9wb2ludF9pZCxcbiAgICAgICAgfSxcbiAgICAgICAgY2hpbGRyZW46IFtdLFxuICAgICAgfTtcbiAgICB9XG4gICAgbm9kZXNbdGFyZ2V0X3BvaW50X2lkXS5jaGlsZHJlbi5wdXNoKG5vZGVzW3NvdXJjZV9wb2ludF9pZF0pO1xuICAgIGNoaWxkcmVuLmFkZChzb3VyY2VfcG9pbnRfaWQpO1xuICAgIG5vZGVzW3NvdXJjZV9wb2ludF9pZF0uYXR0cmlidXRlcyA9IHtcbiAgICAgIGRpc3RhbmNlLFxuICAgICAgLi4uc291cmNlRGF0YSxcbiAgICAgIHBvaW50X2lkOiBzb3VyY2VfcG9pbnRfaWQsXG4gICAgfTtcbiAgfVxuXG4gIC8vIEZpbmQgcm9vdChzKVxuICBjb25zdCByb290cyA9IE9iamVjdC5rZXlzKG5vZGVzKVxuICAgIC5maWx0ZXIoKGlkKSA9PiAhY2hpbGRyZW4uaGFzKE51bWJlcihpZCkpKVxuICAgIC5tYXAoKGlkKSA9PiBub2Rlc1tpZF0pO1xuXG4gIC8vIElmIG11bHRpcGxlIHJvb3RzIGV4aXN0LCB3cmFwIGluIGEgc3VwZXIgcm9vdFxuICByZXR1cm4gcm9vdHMubGVuZ3RoID09PSAxXG4gICAgPyByb290c1swXVxuICAgIDogeyBuYW1lOiB1dGlsaXR5X25hbWUsIGNoaWxkcmVuOiByb290cyB9O1xufVxudHlwZSBQb2ludERhdGEgPSB7XG4gIG5hbWU6IHN0cmluZztcbiAgbW9uaXRvcmVkOiBib29sZWFuO1xuICB0eXBlOiBzdHJpbmc7XG4gIGFyZWFfbmFtZT86IHN0cmluZztcbiAgc2NvcmU/OiBudW1iZXI7XG59O1xuZXhwb3J0IGZ1bmN0aW9uIG1hcEJ5SWQoaXRlbXM6IElQb2ludFtdKTogUmVjb3JkPHN0cmluZyB8IG51bWJlciwgUG9pbnREYXRhPiB7XG4gIHJldHVybiBpdGVtcy5yZWR1Y2UoXG4gICAgKGFjYywgeyBpZCwgbmFtZSwgaGFzX2RldmljZSwgZ3JvdXAsIGFyZWFfbmFtZSwgLi4ucHJvcHMgfSkgPT4ge1xuICAgICAgYWNjW2lkXSA9IHtcbiAgICAgICAgLi4ucHJvcHMsXG4gICAgICAgIG5hbWUsXG4gICAgICAgIG1vbml0b3JlZDogaGFzX2RldmljZSxcbiAgICAgICAgdHlwZTogYXJlYV9uYW1lID8gJ2FyZWEnIDogZ3JvdXAudHlwZSxcbiAgICAgICAgYXJlYV9uYW1lLFxuICAgICAgfTtcbiAgICAgIHJldHVybiBhY2M7XG4gICAgfSxcbiAgICB7fSBhcyBSZWNvcmQ8c3RyaW5nIHwgbnVtYmVyLCBQb2ludERhdGE+LFxuICApO1xufVxuXG5leHBvcnQgY29uc3QgQWN0aW9uc0NvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gICB7XG4gICAgd2lkdGg6IDEwMCU7XG4gICAgdGV4dC1hbGlnbjogY2VudGVyO1xuICAgIG1hcmdpbi10b3A6IC0xMHB4O1xuICAgIG1hcmdpbi1pbmxpbmUtc3RhcnQ6IDE1cHg7XG4gIH1cbmA7XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7OztBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBYU8sU0FBU0EsU0FBU0EsQ0FDdkJDLFdBQW1CLEVBQ25CQyxVQUFVLEVBQ1ZDLFlBQVksRUFDRjtFQUNWLElBQU1DLEtBQUssR0FBRyxDQUFDLENBQUM7RUFDaEIsSUFBTUMsUUFBUSxHQUFHLElBQUlDLEdBQUcsQ0FBQyxDQUFDOztFQUUxQjtFQUFBLElBQUFDLFNBQUEsT0FBQUMsMkJBQUEsQ0FBQUMsT0FBQSxFQUM2RFIs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