@kando-env/kando-ui 1.2.449-alpha.7 → 1.2.449-alpha.8
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/macros/getVersion.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
var packageJsonVersion = "1.2.449-alpha.
|
|
3
|
+
var packageJsonVersion = "1.2.449-alpha.8";
|
|
4
4
|
if (typeof packageJsonVersion === 'string') {
|
|
5
5
|
// eslint-disable-next-line no-console
|
|
6
6
|
console.log("%c Kando UI %c v".concat(packageJsonVersion, " "), 'font-size: 15px; background-color: #fff; color: #e20f53;', 'font-weight: bold; font-size: 15px; background-color: #e20f53; color: #fff;', "with NODE_ENV=".concat(process.env.NODE_ENV));
|
|
@@ -6,98 +6,131 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
value: true
|
|
7
7
|
});
|
|
8
8
|
exports.default = AutoFitTree;
|
|
9
|
-
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/toConsumableArray"));
|
|
10
9
|
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/slicedToArray"));
|
|
11
10
|
var _react = _interopRequireWildcard(require("react"));
|
|
12
11
|
var _reactD3Tree = _interopRequireDefault(require("react-d3-tree"));
|
|
13
12
|
var _Node = _interopRequireDefault(require("./Node"));
|
|
14
13
|
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); }
|
|
15
14
|
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; }
|
|
15
|
+
function countDepthAndBreadth(root) {
|
|
16
|
+
var maxDepth = 0;
|
|
17
|
+
var breadthByDepth = [];
|
|
18
|
+
var dfs = function dfs(n) {
|
|
19
|
+
var _n$children;
|
|
20
|
+
var d = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
|
|
21
|
+
maxDepth = Math.max(maxDepth, d);
|
|
22
|
+
breadthByDepth[d] = (breadthByDepth[d] || 0) + 1;
|
|
23
|
+
(_n$children = n.children) === null || _n$children === void 0 ? void 0 : _n$children.forEach(function (c) {
|
|
24
|
+
return dfs(c, d + 1);
|
|
25
|
+
});
|
|
26
|
+
};
|
|
27
|
+
dfs(root);
|
|
28
|
+
var maxBreadth = Math.max.apply(Math, breadthByDepth);
|
|
29
|
+
return {
|
|
30
|
+
maxDepth: maxDepth,
|
|
31
|
+
maxBreadth: maxBreadth
|
|
32
|
+
};
|
|
33
|
+
}
|
|
16
34
|
function AutoFitTree(_ref) {
|
|
17
35
|
var data = _ref.data,
|
|
18
36
|
_ref$orientation = _ref.orientation,
|
|
19
|
-
orientation = _ref$orientation === void 0 ? 'vertical' : _ref$orientation
|
|
20
|
-
|
|
37
|
+
orientation = _ref$orientation === void 0 ? 'vertical' : _ref$orientation,
|
|
38
|
+
initialDepth = _ref.initialDepth;
|
|
39
|
+
var PADDING = 20; // screen padding in px
|
|
40
|
+
var wrapperRef = (0, _react.useRef)(null);
|
|
41
|
+
var nodeSize = {
|
|
42
|
+
x: 180,
|
|
43
|
+
y: 140
|
|
44
|
+
}; // how much space each node occupies
|
|
45
|
+
var separation = {
|
|
46
|
+
siblings: 1,
|
|
47
|
+
nonSiblings: 1.2
|
|
48
|
+
}; // node spacing
|
|
21
49
|
var _useState = (0, _react.useState)({
|
|
22
|
-
|
|
23
|
-
|
|
50
|
+
width: 100,
|
|
51
|
+
height: 100
|
|
24
52
|
}),
|
|
25
53
|
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
var _useState3 = (0, _react.useState)(1),
|
|
29
|
-
_useState4 = (0, _slicedToArray2.default)(_useState3, 2),
|
|
30
|
-
zoom = _useState4[0],
|
|
31
|
-
setZoom = _useState4[1];
|
|
54
|
+
dims = _useState2[0],
|
|
55
|
+
setDims = _useState2[1];
|
|
32
56
|
|
|
33
|
-
//
|
|
34
|
-
var getTreeStats = function getTreeStats(node) {
|
|
35
|
-
var maxDepth = 0;
|
|
36
|
-
var maxBreadth = 0;
|
|
37
|
-
var levels = {};
|
|
38
|
-
function traverse(n) {
|
|
39
|
-
var depth = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
|
|
40
|
-
maxDepth = Math.max(maxDepth, depth);
|
|
41
|
-
levels[depth] = (levels[depth] || 0) + 1;
|
|
42
|
-
(n.children || []).forEach(function (c) {
|
|
43
|
-
return traverse(c, depth + 1);
|
|
44
|
-
});
|
|
45
|
-
}
|
|
46
|
-
traverse(node);
|
|
47
|
-
maxBreadth = Math.max.apply(Math, (0, _toConsumableArray2.default)(Object.values(levels)));
|
|
48
|
-
return {
|
|
49
|
-
maxDepth: maxDepth,
|
|
50
|
-
maxBreadth: maxBreadth
|
|
51
|
-
};
|
|
52
|
-
};
|
|
57
|
+
// keep wrapper sized to the viewport
|
|
53
58
|
(0, _react.useEffect)(function () {
|
|
54
|
-
if (!
|
|
55
|
-
var
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
y: 100
|
|
59
|
+
if (!wrapperRef.current) return;
|
|
60
|
+
var ro = new ResizeObserver(function () {
|
|
61
|
+
var r = wrapperRef.current.getBoundingClientRect();
|
|
62
|
+
setDims({
|
|
63
|
+
width: r.width,
|
|
64
|
+
height: r.height
|
|
65
|
+
});
|
|
66
|
+
});
|
|
67
|
+
ro.observe(wrapperRef.current);
|
|
68
|
+
return function () {
|
|
69
|
+
return ro.disconnect();
|
|
66
70
|
};
|
|
71
|
+
}, []);
|
|
72
|
+
var _useMemo = (0, _react.useMemo)(function () {
|
|
73
|
+
var _countDepthAndBreadth = countDepthAndBreadth(data),
|
|
74
|
+
maxDepth = _countDepthAndBreadth.maxDepth,
|
|
75
|
+
maxBreadth = _countDepthAndBreadth.maxBreadth;
|
|
67
76
|
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
77
|
+
// approximate required pixel size of the laid-out tree
|
|
78
|
+
var reqW = orientation === 'horizontal' ? (maxDepth + 1) * nodeSize.x : maxBreadth * nodeSize.x * separation.siblings;
|
|
79
|
+
var reqH = orientation === 'horizontal' ? maxBreadth * nodeSize.y * separation.siblings : (maxDepth + 1) * nodeSize.y;
|
|
80
|
+
var availW = Math.max(1, dims.width - PADDING * 2);
|
|
81
|
+
var availH = Math.max(1, dims.height - PADDING * 2);
|
|
82
|
+
var fitZoom = 0.8 * Math.min(availW / reqW, availH / reqH);
|
|
83
|
+
var z = isFinite(fitZoom) && fitZoom > 0 ? fitZoom : 1.2;
|
|
71
84
|
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
+
// anchor === "edge": put root at the leading edge + padding
|
|
86
|
+
if (orientation === 'horizontal') {
|
|
87
|
+
// root on the LEFT, vertically centered
|
|
88
|
+
return {
|
|
89
|
+
zoom: z,
|
|
90
|
+
translate: {
|
|
91
|
+
x: PADDING,
|
|
92
|
+
y: dims.height / 2
|
|
93
|
+
}
|
|
94
|
+
};
|
|
95
|
+
} else {
|
|
96
|
+
// orientation === "vertical" → root on the TOP, horizontally centered
|
|
97
|
+
return {
|
|
98
|
+
zoom: z,
|
|
99
|
+
translate: {
|
|
100
|
+
x: dims.width / 2,
|
|
101
|
+
y: PADDING
|
|
102
|
+
}
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
}, [data, nodeSize.x, nodeSize.y, separation.siblings, orientation, dims.width, dims.height]),
|
|
106
|
+
translate = _useMemo.translate,
|
|
107
|
+
zoom = _useMemo.zoom;
|
|
85
108
|
return /*#__PURE__*/_react.default.createElement("div", {
|
|
86
|
-
ref:
|
|
109
|
+
ref: wrapperRef,
|
|
87
110
|
style: {
|
|
88
111
|
width: '100vw',
|
|
89
|
-
height: '100vh'
|
|
112
|
+
height: '100vh',
|
|
113
|
+
overflow: 'hidden'
|
|
90
114
|
}
|
|
91
115
|
}, /*#__PURE__*/_react.default.createElement(_reactD3Tree.default, {
|
|
116
|
+
initialDepth: initialDepth,
|
|
92
117
|
data: data,
|
|
93
118
|
orientation: orientation,
|
|
94
119
|
pathFunc: "step",
|
|
95
|
-
|
|
120
|
+
nodeSize: nodeSize,
|
|
121
|
+
separation: separation,
|
|
96
122
|
translate: translate,
|
|
123
|
+
zoom: zoom,
|
|
124
|
+
zoomable: true,
|
|
125
|
+
scaleExtent: {
|
|
126
|
+
min: 0.1,
|
|
127
|
+
max: 1
|
|
128
|
+
},
|
|
97
129
|
renderCustomNodeElement: function renderCustomNodeElement(data) {
|
|
98
130
|
return (0, _Node.default)(data);
|
|
99
131
|
},
|
|
100
132
|
collapsible: true
|
|
133
|
+
// onNodeMouseOut={handleNodeMouseOut}
|
|
101
134
|
}));
|
|
102
135
|
}
|
|
103
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactD3Tree","_interopRequireDefault","_Node","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","AutoFitTree","_ref","data","_ref$orientation","orientation","containerRef","useRef","_useState","useState","x","y","_useState2","_slicedToArray2","translate","setTranslate","_useState3","_useState4","zoom","setZoom","getTreeStats","node","maxDepth","maxBreadth","levels","traverse","n","depth","arguments","length","undefined","Math","max","children","forEach","c","apply","_toConsumableArray2","values","useEffect","current","_containerRef$current","getBoundingClientRect","width","height","_getTreeStats","Array","isArray","nodeSize","estimatedWidth","estimatedHeight","padding","scaleX","scaleY","newZoom","min","translateX","translateY","createElement","ref","style","pathFunc","renderCustomNodeElement","Node","collapsible"],"sources":["../../../src/ui-kit/HierarchyGraph/AutoFitTree.tsx"],"sourcesContent":["import React, { useRef, useState, useEffect } from 'react';\nimport Tree from 'react-d3-tree';\nimport Node from './Node';\n\nexport default function AutoFitTree({\n  data,\n  orientation = 'vertical',\n}: {\n  data: any;\n  orientation?: 'vertical' | 'horizontal';\n}) {\n  const containerRef = useRef<HTMLDivElement>(null);\n  const [translate, setTranslate] = useState({ x: 0, y: 0 });\n  const [zoom, setZoom] = useState(1);\n\n  // ---- Utility: count depth and breadth ----\n  const getTreeStats = (node: any) => {\n    let maxDepth = 0;\n    let maxBreadth = 0;\n    const levels: Record<number, number> = {};\n\n    function traverse(n: any, depth = 0) {\n      maxDepth = Math.max(maxDepth, depth);\n      levels[depth] = (levels[depth] || 0) + 1;\n      (n.children || []).forEach((c: any) => traverse(c, depth + 1));\n    }\n\n    traverse(node);\n    maxBreadth = Math.max(...Object.values(levels));\n    return { maxDepth, maxBreadth };\n  };\n\n  useEffect(() => {\n    if (!containerRef.current || !data) return;\n\n    const { width, height } = containerRef.current.getBoundingClientRect();\n    const { maxDepth, maxBreadth } = getTreeStats(\n      Array.isArray(data) ? data[0] : data,\n    );\n\n    // Your estimated node size\n    const nodeSize = { x: 180, y: 100 };\n\n    // Compute rough layout bounds\n    const estimatedWidth = nodeSize.x * (maxDepth + 1);\n    const estimatedHeight = nodeSize.y * (maxBreadth + 1);\n\n    // Fit to container with padding\n    const padding = 40;\n    const scaleX = (width - padding) / estimatedWidth;\n    const scaleY = (height - padding) / estimatedHeight;\n    const newZoom = Math.min(scaleX, scaleY);\n    const translateX =\n      orientation === 'horizontal'\n        ? Math.max((width - estimatedWidth * newZoom) / 2, padding)\n        : width / 2;\n\n    const translateY =\n      orientation === 'horizontal'\n        ? height / 2\n        : Math.max((height - estimatedHeight * newZoom) / 2, padding); // Center tree root\n    setTranslate({ x: translateX, y: translateY });\n    setZoom(newZoom);\n  }, [data, orientation]);\n\n  return (\n    <div ref={containerRef} style={{ width: '100vw', height: '100vh' }}>\n      <Tree\n        data={data}\n        orientation={orientation}\n        pathFunc=\"step\"\n        zoom={zoom}\n        translate={translate}\n        renderCustomNodeElement={(data) => Node(data)}\n        collapsible={true}\n      />\n    </div>\n  );\n}\n"],"mappings":"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"}
|
|
136
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactD3Tree","_interopRequireDefault","_Node","_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","PADDING","wrapperRef","useRef","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","createElement","ref","style","overflow","pathFunc","zoomable","scaleExtent","renderCustomNodeElement","Node","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 Node from './Node';\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}: {\n  data: any;\n  orientation?: 'vertical' | 'horizontal';\n  initialDepth: number;\n}) {\n  const PADDING = 20; // screen padding in px\n  const wrapperRef = useRef<HTMLDivElement>(null);\n  const nodeSize = { x: 180, y: 140 }; // how much space each node occupies\n  const separation: Sep = { siblings: 1, nonSiblings: 1.2 }; // node spacing\n  const [dims, setDims] = useState({ width: 100, 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.8 * 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  return (\n    <div\n      ref={wrapperRef}\n      style={{ width: '100vw', height: '100vh', overflow: 'hidden' }}\n    >\n      <Tree\n        initialDepth={initialDepth}\n        data={data}\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: 1 }}\n        renderCustomNodeElement={(data) => Node(data)}\n        collapsible={true}\n        // onNodeMouseOut={handleNodeMouseOut}\n      />\n    </div>\n  );\n}\n"],"mappings":"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"}
|
|
@@ -12,7 +12,9 @@ var _useQueryURL = _interopRequireDefault(require("../../hooks/useQueryURL"));
|
|
|
12
12
|
var _utils = require("./utils");
|
|
13
13
|
var _reactRedux = require("react-redux");
|
|
14
14
|
var _AutoFitTree = _interopRequireDefault(require("./AutoFitTree"));
|
|
15
|
-
var
|
|
15
|
+
var _reactBootstrap = require("react-bootstrap");
|
|
16
|
+
var _Loader = require("../../pages/DashboardMap/Loader");
|
|
17
|
+
var _Button = _interopRequireDefault(require("../Button/Button"));
|
|
16
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); }
|
|
17
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; }
|
|
18
20
|
var HierarchyGraph = function HierarchyGraph() {
|
|
@@ -24,6 +26,10 @@ var HierarchyGraph = function HierarchyGraph() {
|
|
|
24
26
|
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
|
|
25
27
|
orientation = _useState2[0],
|
|
26
28
|
setOrientation = _useState2[1];
|
|
29
|
+
var _useState3 = (0, _react.useState)(12),
|
|
30
|
+
_useState4 = (0, _slicedToArray2.default)(_useState3, 2),
|
|
31
|
+
depth = _useState4[0],
|
|
32
|
+
setDepth = _useState4[1];
|
|
27
33
|
var isGraphTab = searchQuery.get('view') === 'graph';
|
|
28
34
|
var points_data = ReduxState.points_data,
|
|
29
35
|
edges_data = ReduxState.edges_data,
|
|
@@ -36,29 +42,52 @@ var HierarchyGraph = function HierarchyGraph() {
|
|
|
36
42
|
});
|
|
37
43
|
var point_map_data = (0, _utils.mapById)(points_data.items);
|
|
38
44
|
var treeData = (0, _utils.buildTree)(edgesWithDevice, point_map_data, waterAuthorityName);
|
|
39
|
-
if (!isGraphTab
|
|
45
|
+
if (!isGraphTab) {
|
|
40
46
|
return null;
|
|
41
47
|
}
|
|
42
48
|
|
|
43
49
|
// The component expects either an array or a single object
|
|
44
|
-
return /*#__PURE__*/_react.default.createElement("div", {
|
|
50
|
+
return /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("div", {
|
|
45
51
|
style: {
|
|
46
|
-
|
|
47
|
-
|
|
52
|
+
marginTop: '10px',
|
|
53
|
+
marginInlineStart: '10px',
|
|
54
|
+
display: 'flex',
|
|
55
|
+
gap: 8,
|
|
56
|
+
zIndex: 10
|
|
48
57
|
}
|
|
49
|
-
}, /*#__PURE__*/_react.default.createElement(
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
58
|
+
}, /*#__PURE__*/_react.default.createElement(_Button.default, {
|
|
59
|
+
onClick: function onClick() {
|
|
60
|
+
return setDepth(1);
|
|
61
|
+
}
|
|
62
|
+
}, 'Collapse All'), /*#__PURE__*/_react.default.createElement(_Button.default, {
|
|
63
|
+
onClick: function onClick() {
|
|
64
|
+
return setDepth(12);
|
|
65
|
+
}
|
|
66
|
+
}, 'Expand All'), /*#__PURE__*/_react.default.createElement(_Button.default, {
|
|
67
|
+
onClick: function onClick() {
|
|
68
|
+
return setOrientation(function (prev) {
|
|
69
|
+
return prev === 'horizontal' ? 'vertical' : 'horizontal';
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
}, 'Toggle Orientation')), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Container, {
|
|
73
|
+
fluid: true,
|
|
74
|
+
className: "p-0",
|
|
75
|
+
style: {
|
|
76
|
+
overflow: 'hidden'
|
|
77
|
+
}
|
|
78
|
+
}, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Row, {
|
|
79
|
+
className: "map-column",
|
|
80
|
+
sm: 12
|
|
81
|
+
}, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Col, {
|
|
53
82
|
style: {
|
|
54
|
-
height: '
|
|
55
|
-
width: '100vw'
|
|
83
|
+
height: '85vh'
|
|
56
84
|
}
|
|
57
|
-
}, /*#__PURE__*/_react.default.createElement(_AutoFitTree.default, {
|
|
85
|
+
}, edges_data.isFetching || points_data.isFetching ? /*#__PURE__*/_react.default.createElement(_Loader.Loader, null) : /*#__PURE__*/_react.default.createElement(_AutoFitTree.default, {
|
|
86
|
+
initialDepth: depth,
|
|
58
87
|
data: treeData,
|
|
59
88
|
orientation: orientation
|
|
60
|
-
})));
|
|
89
|
+
})))));
|
|
61
90
|
};
|
|
62
91
|
var _default = HierarchyGraph;
|
|
63
92
|
exports.default = _default;
|
|
64
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVXaWxkY2FyZCIsInJlcXVpcmUiLCJfdXNlUXVlcnlVUkwiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwiX3V0aWxzIiwiX3JlYWN0UmVkdXgiLCJfQXV0b0ZpdFRyZWUiLCJfT3JpZW50YXRpb25Td2l0Y2hlciIsIl9nZXRSZXF1aXJlV2lsZGNhcmRDYWNoZSIsIm5vZGVJbnRlcm9wIiwiV2Vha01hcCIsImNhY2hlQmFiZWxJbnRlcm9wIiwiY2FjaGVOb2RlSW50ZXJvcCIsIm9iaiIsIl9fZXNNb2R1bGUiLCJfdHlwZW9mIiwiZGVmYXVsdCIsImNhY2hlIiwiaGFzIiwiZ2V0IiwibmV3T2JqIiwiaGFzUHJvcGVydHlEZXNjcmlwdG9yIiwiT2JqZWN0IiwiZGVmaW5lUHJvcGVydHkiLCJnZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3IiLCJrZXkiLCJwcm90b3R5cGUiLCJoYXNPd25Qcm9wZXJ0eSIsImNhbGwiLCJkZXNjIiwic2V0IiwiSGllcmFyY2h5R3JhcGgiLCJzZWFyY2hRdWVyeSIsInVzZVF1ZXJ5VVJMIiwiUmVkdXhTdGF0ZSIsInVzZVNlbGVjdG9yIiwic3RhdGUiLCJfdXNlU3RhdGUiLCJ1c2VTdGF0ZSIsIl91c2VTdGF0ZTIiLCJfc2xpY2VkVG9BcnJheTIiLCJvcmllbnRhdGlvbiIsInNldE9yaWVudGF0aW9uIiwiaXNHcmFwaFRhYiIsInBvaW50c19kYXRhIiwiZWRnZXNfZGF0YSIsIndhdGVyQXV0aG9yaXR5TmFtZSIsImdsb2JhbF9kYXRhIiwicG9pbnRzV2l0aERldmljZSIsIm1hcEJ5SWQiLCJpdGVtcyIsImZpbHRlciIsInBvaW50IiwiaGFzX2RldmljZSIsImVkZ2VzV2l0aERldmljZSIsImVkZ2UiLCJzb3VyY2VfcG9pbnRfaWQiLCJkZXNjZW5kYW50c19oYXNfZGV2aWNlIiwicG9pbnRfbWFwX2RhdGEiLCJ0cmVlRGF0YSIsImJ1aWxkVHJlZSIsImlzRmV0Y2hpbmciLCJjcmVhdGVFbGVtZW50Iiwic3R5bGUiLCJ3aWR0aCIsImhlaWdodCIsImRhdGEiLCJfZGVmYXVsdCIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdWkta2l0L0hpZXJhcmNoeUdyYXBoL0hpZXJhcmNoeUdyYXBoLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHVzZVF1ZXJ5VVJMIGZyb20gJy4uLy4uL2hvb2tzL3VzZVF1ZXJ5VVJMJztcbmltcG9ydCB7IGJ1aWxkVHJlZSwgbWFwQnlJZCB9IGZyb20gJy4vdXRpbHMnO1xuaW1wb3J0IHsgdXNlU2VsZWN0b3IgfSBmcm9tICdyZWFjdC1yZWR1eCc7XG5pbXBvcnQgeyB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBBdXRvRml0VHJlZSBmcm9tICcuL0F1dG9GaXRUcmVlJztcbmltcG9ydCBPcmllbnRhdGlvblN3aXRjaGVyIGZyb20gJy4vT3JpZW50YXRpb25Td2l0Y2hlcic7XG5cbmNvbnN0IEhpZXJhcmNoeUdyYXBoID0gKCkgPT4ge1xuICBjb25zdCBzZWFyY2hRdWVyeSA9IHVzZVF1ZXJ5VVJMKCk7XG4gIGNvbnN0IFJlZHV4U3RhdGUgPSB1c2VTZWxlY3Rvcigoc3RhdGUpID0+IHN0YXRlKTtcbiAgY29uc3QgW29yaWVudGF0aW9uLCBzZXRPcmllbnRhdGlvbl0gPSB1c2VTdGF0ZTwnaG9yaXpvbnRhbCcgfCAndmVydGljYWwnPihcbiAgICAnaG9yaXpvbnRhbCcsXG4gICk7XG5cbiAgY29uc3QgaXNHcmFwaFRhYiA9IHNlYXJjaFF1ZXJ5LmdldCgndmlldycpID09PSAnZ3JhcGgnO1xuICBjb25zdCB7XG4gICAgcG9pbnRzX2RhdGEsXG4gICAgZWRnZXNfZGF0YSxcbiAgICBnbG9iYWxfZGF0YTogeyB3YXRlckF1dGhvcml0eU5hbWUgfSxcbiAgfSA9IFJlZHV4U3RhdGU7XG4gIGNvbnN0IHBvaW50c1dpdGhEZXZpY2UgPSBtYXBCeUlkKFxuICAgIHBvaW50c19kYXRhLml0ZW1zLmZpbHRlcigocG9pbnQpID0+IHBvaW50Lmhhc19kZXZpY2UpLFxuICApO1xuICBjb25zdCBlZGdlc1dpdGhEZXZpY2UgPSBlZGdlc19kYXRhLml0ZW1zLmZpbHRlcihcbiAgICAoZWRnZSkgPT5cbiAgICAgIHBvaW50c1dpdGhEZXZpY2VbZWRnZS5zb3VyY2VfcG9pbnRfaWRdIHx8IGVkZ2UuZGVzY2VuZGFudHNfaGFzX2RldmljZSxcbiAgKTtcbiAgY29uc3QgcG9pbnRfbWFwX2RhdGEgPSBtYXBCeUlkKHBvaW50c19kYXRhLml0ZW1zKTtcbiAgY29uc3QgdHJlZURhdGEgPSBidWlsZFRyZWUoXG4gICAgZWRnZXNXaXRoRGV2aWNlLFxuICAgIHBvaW50X21hcF9kYXRhLFxuICAgIHdhdGVyQXV0aG9yaXR5TmFtZSxcbiAgKTtcblxuICBpZiAoIWlzR3JhcGhUYWIgfHwgZWRnZXNfZGF0YS5pc0ZldGNoaW5nIHx8IHBvaW50c19kYXRhLmlzRmV0Y2hpbmcpIHtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuXG4gIC8vIFRoZSBjb21wb25lbnQgZXhwZWN0cyBlaXRoZXIgYW4gYXJyYXkgb3IgYSBzaW5nbGUgb2JqZWN0XG4gIHJldHVybiAoXG4gICAgPGRpdiBzdHlsZT17eyB3aWR0aDogJzEwMHZoJywgaGVpZ2h0OiAnMTAwJScgfX0+XG4gICAgICA8T3JpZW50YXRpb25Td2l0Y2hlclxuICAgICAgICBvcmllbnRhdGlvbj17b3JpZW50YXRpb259XG4gICAgICAgIHNldE9yaWVudGF0aW9uPXtzZXRPcmllbnRhdGlvbn1cbiAgICAgIC8+XG5cbiAgICAgIDxkaXZcbiAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICBoZWlnaHQ6ICcxMDAlJyxcbiAgICAgICAgICB3aWR0aDogJzEwMHZ3JyxcbiAgICAgICAgfX1cbiAgICAgID5cbiAgICAgICAgPEF1dG9GaXRUcmVlIGRhdGE9e3RyZWVEYXRhfSBvcmllbnRhdGlvbj17b3JpZW50YXRpb259IC8+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5c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
|
|
93
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_useQueryURL","_interopRequireDefault","_utils","_reactRedux","_AutoFitTree","_reactBootstrap","_Loader","_Button","_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","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","createElement","style","marginTop","marginInlineStart","display","gap","zIndex","onClick","prev","Container","fluid","className","overflow","Row","sm","Col","height","isFetching","Loader","initialDepth","data","_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';\n\nconst HierarchyGraph = () => {\n  const searchQuery = useQueryURL();\n  const ReduxState = useSelector((state) => state);\n  const [orientation, setOrientation] = useState<'horizontal' | 'vertical'>(\n    'horizontal',\n  );\n  const [depth, setDepth] = useState<number>(12);\n\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\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              />\n            )}\n          </Col>\n        </Row>\n      </Container>\n    </div>\n  );\n};\nexport default HierarchyGraph;\n"],"mappings":"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"}
|
|
@@ -12,13 +12,14 @@ var _PointUtils = require("../../Widgets/Map/points/PointUtils");
|
|
|
12
12
|
var _factoryIcon = require("@svgr/webpack?&svgo=false&ref!assets/point_icons/factory-icon.svg");
|
|
13
13
|
var _assets = require("../../components/Tabs/assets");
|
|
14
14
|
var Node = function Node(_ref) {
|
|
15
|
-
var _nodeDatum$attributes, _nodeDatum$attributes2, _nodeDatum$attributes3, _nodeDatum$attributes4, _nodeDatum$attributes5;
|
|
15
|
+
var _nodeDatum$attributes, _nodeDatum$attributes2, _nodeDatum$attributes3, _nodeDatum$attributes4, _nodeDatum$attributes5, _nodeDatum$attributes6;
|
|
16
16
|
var nodeDatum = _ref.nodeDatum,
|
|
17
17
|
toggleNode = _ref.toggleNode;
|
|
18
|
-
var
|
|
18
|
+
var borderColor = nodeDatum.children.length ? '#B1BAC1FF' : '#DC35457D';
|
|
19
19
|
if (!nodeDatum.name) {
|
|
20
20
|
return null;
|
|
21
21
|
}
|
|
22
|
+
var monitoredPoint = (_nodeDatum$attributes = nodeDatum.attributes) === null || _nodeDatum$attributes === void 0 ? void 0 : _nodeDatum$attributes.monitored;
|
|
22
23
|
return /*#__PURE__*/_react.default.createElement("g", {
|
|
23
24
|
onClick: toggleNode
|
|
24
25
|
}, /*#__PURE__*/_react.default.createElement("foreignObject", {
|
|
@@ -28,9 +29,14 @@ var Node = function Node(_ref) {
|
|
|
28
29
|
height: "100"
|
|
29
30
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
30
31
|
style: {
|
|
31
|
-
backgroundColor:
|
|
32
|
+
backgroundColor: 'white',
|
|
32
33
|
padding: '4px',
|
|
33
|
-
|
|
34
|
+
width: '90px',
|
|
35
|
+
height: '75px',
|
|
36
|
+
borderRadius: '4px',
|
|
37
|
+
borderStyle: monitoredPoint ? 'solid' : 'dashed',
|
|
38
|
+
borderWidth: monitoredPoint ? 'initial' : 'thin',
|
|
39
|
+
borderColor: borderColor
|
|
34
40
|
}
|
|
35
41
|
}, /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
|
|
36
42
|
style: {
|
|
@@ -39,28 +45,28 @@ var Node = function Node(_ref) {
|
|
|
39
45
|
justifyContent: 'space-between'
|
|
40
46
|
}
|
|
41
47
|
}, /*#__PURE__*/_react.default.createElement(_AssessmentIcon.AssessmentIcon, {
|
|
42
|
-
isAssessment: !((_nodeDatum$
|
|
43
|
-
}), (0, _PointUtils.isFactoryType)((_nodeDatum$
|
|
48
|
+
isAssessment: !((_nodeDatum$attributes2 = nodeDatum.attributes) === null || _nodeDatum$attributes2 === void 0 ? void 0 : _nodeDatum$attributes2.monitored)
|
|
49
|
+
}), (0, _PointUtils.isFactoryType)((_nodeDatum$attributes3 = nodeDatum.attributes) === null || _nodeDatum$attributes3 === void 0 ? void 0 : _nodeDatum$attributes3.type) && /*#__PURE__*/_react.default.createElement(_factoryIcon.ReactComponent, {
|
|
44
50
|
style: {
|
|
45
51
|
height: '20px',
|
|
46
52
|
width: '20px'
|
|
47
53
|
}
|
|
48
|
-
}), ((_nodeDatum$
|
|
54
|
+
}), ((_nodeDatum$attributes4 = nodeDatum.attributes) === null || _nodeDatum$attributes4 === void 0 ? void 0 : _nodeDatum$attributes4.area_name) && /*#__PURE__*/_react.default.createElement(_assets.ShapeSvg, {
|
|
49
55
|
style: {
|
|
50
56
|
height: '20px',
|
|
51
57
|
width: '20px',
|
|
52
58
|
fill: '#777'
|
|
53
59
|
}
|
|
54
60
|
})), /*#__PURE__*/_react.default.createElement(_SamplingSiteTableCell.SamplingSiteTableCell, {
|
|
55
|
-
site: ((_nodeDatum$
|
|
56
|
-
}), ((_nodeDatum$
|
|
61
|
+
site: ((_nodeDatum$attributes5 = nodeDatum.attributes) === null || _nodeDatum$attributes5 === void 0 ? void 0 : _nodeDatum$attributes5.area_name) || nodeDatum.name
|
|
62
|
+
}), ((_nodeDatum$attributes6 = nodeDatum.attributes) === null || _nodeDatum$attributes6 === void 0 ? void 0 : _nodeDatum$attributes6.distance) > 0 && /*#__PURE__*/_react.default.createElement("div", {
|
|
57
63
|
style: {
|
|
58
64
|
marginTop: '4px',
|
|
59
65
|
fontSize: '11px',
|
|
60
|
-
color: '#
|
|
66
|
+
color: '#B1BAC1FF'
|
|
61
67
|
}
|
|
62
68
|
}, 'Distance:', " ", nodeDatum.attributes.distance)))));
|
|
63
69
|
};
|
|
64
70
|
var _default = Node;
|
|
65
71
|
exports.default = _default;
|
|
66
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
72
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9Bc3Nlc3NtZW50SWNvbiIsIl9TYW1wbGluZ1NpdGVUYWJsZUNlbGwiLCJfUG9pbnRVdGlscyIsIl9mYWN0b3J5SWNvbiIsIl9hc3NldHMiLCJOb2RlIiwiX3JlZiIsIl9ub2RlRGF0dW0kYXR0cmlidXRlcyIsIl9ub2RlRGF0dW0kYXR0cmlidXRlczIiLCJfbm9kZURhdHVtJGF0dHJpYnV0ZXMzIiwiX25vZGVEYXR1bSRhdHRyaWJ1dGVzNCIsIl9ub2RlRGF0dW0kYXR0cmlidXRlczUiLCJfbm9kZURhdHVtJGF0dHJpYnV0ZXM2Iiwibm9kZURhdHVtIiwidG9nZ2xlTm9kZSIsImJvcmRlckNvbG9yIiwiY2hpbGRyZW4iLCJsZW5ndGgiLCJuYW1lIiwibW9uaXRvcmVkUG9pbnQiLCJhdHRyaWJ1dGVzIiwibW9uaXRvcmVkIiwiZGVmYXVsdCIsImNyZWF0ZUVsZW1lbnQiLCJvbkNsaWNrIiwieCIsInkiLCJ3aWR0aCIsImhlaWdodCIsInN0eWxlIiwiYmFja2dyb3VuZENvbG9yIiwicGFkZGluZyIsImJvcmRlclJhZGl1cyIsImJvcmRlclN0eWxlIiwiYm9yZGVyV2lkdGgiLCJGcmFnbWVudCIsImRpc3BsYXkiLCJhbGlnbkl0ZW1zIiwianVzdGlmeUNvbnRlbnQiLCJBc3Nlc3NtZW50SWNvbiIsImlzQXNzZXNzbWVudCIsImlzRmFjdG9yeVR5cGUiLCJ0eXBlIiwiUmVhY3RDb21wb25lbnQiLCJhcmVhX25hbWUiLCJTaGFwZVN2ZyIsImZpbGwiLCJTYW1wbGluZ1NpdGVUYWJsZUNlbGwiLCJzaXRlIiwiZGlzdGFuY2UiLCJtYXJnaW5Ub3AiLCJmb250U2l6ZSIsImNvbG9yIiwiX2RlZmF1bHQiLCJleHBvcnRzIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3VpLWtpdC9IaWVyYXJjaHlHcmFwaC9Ob2RlLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgQXNzZXNzbWVudEljb24gfSBmcm9tICcuLi8uLi9wYWdlcy9EYXNoYm9hcmRNYXAvQXNzZXNzbWVudEljb24nO1xuaW1wb3J0IHsgU2FtcGxpbmdTaXRlVGFibGVDZWxsIH0gZnJvbSAnLi4vLi4vcGFnZXMvU2FtcGxpbmdzUGFnZS9TYW1wbGluZ1NpdGVUYWJsZUNlbGwnO1xuaW1wb3J0IHsgaXNGYWN0b3J5VHlwZSB9IGZyb20gJy4uLy4uL1dpZGdldHMvTWFwL3BvaW50cy9Qb2ludFV0aWxzJztcbmltcG9ydCB7IFJlYWN0Q29tcG9uZW50IGFzIEZhY3RvcnlJY29uIH0gZnJvbSAnc3JjL2Fzc2V0cy9wb2ludF9pY29ucy9mYWN0b3J5LWljb24uc3ZnJztcbmltcG9ydCB7IFNoYXBlU3ZnIH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy9UYWJzL2Fzc2V0cyc7XG5cbmNvbnN0IE5vZGUgPSAoeyBub2RlRGF0dW0sIHRvZ2dsZU5vZGUgfSkgPT4ge1xuICBjb25zdCBib3JkZXJDb2xvciA9IG5vZGVEYXR1bS5jaGlsZHJlbi5sZW5ndGggPyAnI0IxQkFDMUZGJyA6ICcjREMzNTQ1N0QnO1xuXG4gIGlmICghbm9kZURhdHVtLm5hbWUpIHtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuXG4gIGNvbnN0IG1vbml0b3JlZFBvaW50ID0gbm9kZURhdHVtLmF0dHJpYnV0ZXM/Lm1vbml0b3JlZDtcblxuICByZXR1cm4gKFxuICAgIDxnIG9uQ2xpY2s9e3RvZ2dsZU5vZGV9PlxuICAgICAgPGZvcmVpZ25PYmplY3QgeD1cIi0xMlwiIHk9XCItMTVcIiB3aWR0aD1cIjEwMFwiIGhlaWdodD1cIjEwMFwiPlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICAgIGJhY2tncm91bmRDb2xvcjogJ3doaXRlJyxcbiAgICAgICAgICAgIHBhZGRpbmc6ICc0cHgnLFxuICAgICAgICAgICAgd2lkdGg6ICc5MHB4JyxcbiAgICAgICAgICAgIGhlaWdodDogJzc1cHgnLFxuICAgICAgICAgICAgYm9yZGVyUmFkaXVzOiAnNHB4JyxcbiAgICAgICAgICAgIGJvcmRlclN0eWxlOiBtb25pdG9yZWRQb2ludCA/ICdzb2xpZCcgOiAnZGFzaGVkJyxcbiAgICAgICAgICAgIGJvcmRlcldpZHRoOiBtb25pdG9yZWRQb2ludCA/ICdpbml0aWFsJyA6ICd0aGluJyxcbiAgICAgICAgICAgIGJvcmRlckNvbG9yOiBib3JkZXJDb2xvcixcbiAgICAgICAgICB9fVxuICAgICAgICA+XG4gICAgICAgICAgPD5cbiAgICAgICAgICAgIDxkaXZcbiAgICAgICAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgICAgICAganVzdGlmeUNvbnRlbnQ6ICdzcGFjZS1iZXR3ZWVuJyxcbiAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgPEFzc2Vzc21lbnRJY29uIGlzQXNzZXNzbWVudD17IW5vZGVEYXR1bS5hdHRyaWJ1dGVzPy5tb25pdG9yZWR9IC8+XG5cbiAgICAgICAgICAgICAge2lzRmFjdG9yeVR5cGUobm9kZURhdHVtLmF0dHJpYnV0ZXM/LnR5cGUpICYmIChcbiAgICAgICAgICAgICAgICA8RmFjdG9yeUljb25cbiAgICAgICAgICAgICAgICAgIHN0eWxlPXt7XG4gICAgICAgICAgICAgICAgICAgIGhlaWdodDogJzIwcHgnLFxuICAgICAgICAgICAgICAgICAgICB3aWR0aDogJzIwcHgnLFxuICAgICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgICB7bm9kZURhdHVtLmF0dHJpYnV0ZXM/LmFyZWFfbmFtZSAmJiAoXG4gICAgICAgICAgICAgICAgPFNoYXBlU3ZnXG4gICAgICAgICAgICAgICAgICBzdHlsZT17e1xuICAgICAgICAgICAgICAgICAgICBoZWlnaHQ6ICcyMHB4JyxcbiAgICAgICAgICAgICAgICAgICAgd2lkdGg6ICcyMHB4JyxcbiAgICAgICAgICAgICAgICAgICAgZmlsbDogJyM3NzcnLFxuICAgICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8U2FtcGxpbmdTaXRlVGFibGVDZWxsXG4gICAgICAgICAgICAgIHNpdGU9e25vZGVEYXR1bS5hdHRyaWJ1dGVzPy5hcmVhX25hbWUgfHwgbm9kZURhdHVtLm5hbWV9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgICAge25vZGVEYXR1bS5hdHRyaWJ1dGVzPy5kaXN0YW5jZSA+IDAgJiYgKFxuICAgICAgICAgICAgICA8ZGl2XG4gICAgICAgICAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICAgICAgICAgIG1hcmdpblRvcDogJzRweCcsXG4gICAgICAgICAgICAgICAgICBmb250U2l6ZTogJzExcHgnLFxuICAgICAgICAgICAgICAgICAgY29sb3I6ICcjQjFCQUMxRkYnLFxuICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICB7J0Rpc3RhbmNlOid9IHtub2RlRGF0dW0uYXR0cmlidXRlcy5kaXN0YW5jZX1cbiAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICApfVxuICAgICAgICAgIDwvPlxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvZm9yZWlnbk9iamVjdD5cbiAgICA8L2c+XG4gICk7XG59O1xuZXhwb3J0IGRlZmF1bHQgTm9kZTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBLElBQUFBLE1BQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUNBLElBQUFDLGVBQUEsR0FBQUQsT0FBQTtBQUNBLElBQUFFLHNCQUFBLEdBQUFGLE9BQUE7QUFDQSxJQUFBRyxXQUFBLEdBQUFILE9BQUE7QUFBb0Us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
|
|
@@ -42,7 +42,8 @@ function buildTree(connections, point_data, utility_name) {
|
|
|
42
42
|
attributes: {
|
|
43
43
|
monitored: target_data.monitored,
|
|
44
44
|
type: target_data.type,
|
|
45
|
-
area_name: target_data.area_name
|
|
45
|
+
area_name: target_data.area_name,
|
|
46
|
+
point_id: target_point_id
|
|
46
47
|
},
|
|
47
48
|
children: []
|
|
48
49
|
};
|
|
@@ -53,7 +54,8 @@ function buildTree(connections, point_data, utility_name) {
|
|
|
53
54
|
distance: distance,
|
|
54
55
|
monitored: monitored,
|
|
55
56
|
type: type,
|
|
56
|
-
area_name: area_name
|
|
57
|
+
area_name: area_name,
|
|
58
|
+
point_id: source_point_id
|
|
57
59
|
};
|
|
58
60
|
}
|
|
59
61
|
|
|
@@ -91,4 +93,4 @@ function mapById(items) {
|
|
|
91
93
|
return acc;
|
|
92
94
|
}, {});
|
|
93
95
|
}
|
|
94
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
96
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJidWlsZFRyZWUiLCJjb25uZWN0aW9ucyIsInBvaW50X2RhdGEiLCJ1dGlsaXR5X25hbWUiLCJub2RlcyIsImNoaWxkcmVuIiwiU2V0IiwiX2l0ZXJhdG9yIiwiX2NyZWF0ZUZvck9mSXRlcmF0b3JIZWxwZXIyIiwiZGVmYXVsdCIsIl9zdGVwIiwicyIsIm4iLCJkb25lIiwiX3N0ZXAkdmFsdWUiLCJ2YWx1ZSIsInNvdXJjZV9wb2ludF9pZCIsInRhcmdldF9wb2ludF9pZCIsImRpc3RhbmNlIiwiX3JlZiIsIm5hbWUiLCJtb25pdG9yZWQiLCJ0eXBlIiwiYXJlYV9uYW1lIiwidGFyZ2V0X2RhdGEiLCJhdHRyaWJ1dGVzIiwicG9pbnRfaWQiLCJwdXNoIiwiYWRkIiwiZXJyIiwiZSIsImYiLCJyb290cyIsIk9iamVjdCIsImtleXMiLCJmaWx0ZXIiLCJpZCIsImhhcyIsIk51bWJlciIsIm1hcCIsImxlbmd0aCIsIm1hcEJ5SWQiLCJpdGVtcyIsInJlZHVjZSIsImFjYyIsIl9yZWYyIiwiaGFzX2RldmljZSIsImdyb3VwIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3VpLWtpdC9IaWVyYXJjaHlHcmFwaC91dGlscy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJR3JvdXAgfSBmcm9tICcuLi8uLi9zdG9yZS9wb2ludHMvbW9kZWxzL0lHcm91cCc7XG5cbi8qKlxuICogQ29udmVydCBlZGdlcyB0byByb3dzIHN1aXRhYmxlIGZvciBkMy5zdHJhdGlmeSgpXG4gKiBSZXR1cm5zIGFuIGFycmF5IG9mIHsgaWQsIHBhcmVudElkLCBkaXN0YW5jZT8sIHNoYXBlX2RhdGE/IH1cbiAqIElmIG11bHRpcGxlIHJvb3RzIGV4aXN0LCB5b3UgY2FuIG9wdGlvbmFsbHkgYWRkIGEgc3VwZXIgcm9vdCByb3cuXG4gKi9cbnR5cGUgRWRnZSA9IHtcbiAgc291cmNlX3BvaW50X2lkOiBudW1iZXIgfCBzdHJpbmc7XG4gIHRhcmdldF9wb2ludF9pZDogbnVtYmVyIHwgc3RyaW5nO1xuICBkaXN0YW5jZT86IG51bWJlcjtcbn07XG50eXBlIFRyZWVOb2RlID0ge1xuICBuYW1lOiBzdHJpbmc7XG4gIGNoaWxkcmVuPzogVHJlZU5vZGVbXTtcbiAgYXR0cmlidXRlcz86IHsgZGlzdGFuY2U6IG51bWJlcjsgdHlwZTogc3RyaW5nOyBtb25pdG9yZWQ6IGJvb2xlYW4gfTtcbn07XG50eXBlIFRyZWVEYXRhID0gVHJlZU5vZGUgfCB7IG5hbWU6IHN0cmluZzsgY2hpbGRyZW46IFRyZWVOb2RlW10gfTtcblxuZXhwb3J0IGZ1bmN0aW9uIGJ1aWxkVHJlZShcbiAgY29ubmVjdGlvbnM6IEVkZ2VbXSxcbiAgcG9pbnRfZGF0YSxcbiAgdXRpbGl0eV9uYW1lLFxuKTogVHJlZURhdGEge1xuICBjb25zdCBub2RlcyA9IHt9O1xuICBjb25zdCBjaGlsZHJlbiA9IG5ldyBTZXQoKTtcblxuICAvLyBCdWlsZCBtYXAgb2Ygbm9kZXMgYW5kIHRyYWNrIGNoaWxkcmVuXG4gIGZvciAoY29uc3QgeyBzb3VyY2VfcG9pbnRfaWQsIHRhcmdldF9wb2ludF9pZCwgZGlzdGFuY2UgfSBvZiBjb25uZWN0aW9ucykge1xuICAgIGNvbnN0IHsgbmFtZSwgbW9uaXRvcmVkLCB0eXBlLCBhcmVhX25hbWUgfSA9XG4gICAgICBwb2ludF9kYXRhW3NvdXJjZV9wb2ludF9pZF0gfHwge307XG4gICAgaWYgKCFub2Rlc1tzb3VyY2VfcG9pbnRfaWRdKVxuICAgICAgbm9kZXNbc291cmNlX3BvaW50X2lkXSA9IHtcbiAgICAgICAgbmFtZSxcbiAgICAgICAgY2hpbGRyZW46IFtdLFxuICAgICAgfTtcbiAgICBpZiAoIW5vZGVzW3RhcmdldF9wb2ludF9pZF0pIHtcbiAgICAgIGNvbnN0IHRhcmdldF9kYXRhID0gcG9pbnRfZGF0YVt0YXJnZXRfcG9pbnRfaWRdIHx8IHt9O1xuICAgICAgbm9kZXNbdGFyZ2V0X3BvaW50X2lkXSA9IHtcbiAgICAgICAgbmFtZTogdGFyZ2V0X2RhdGEubmFtZSxcbiAgICAgICAgYXR0cmlidXRlczoge1xuICAgICAgICAgIG1vbml0b3JlZDogdGFyZ2V0X2RhdGEubW9uaXRvcmVkLFxuICAgICAgICAgIHR5cGU6IHRhcmdldF9kYXRhLnR5cGUsXG4gICAgICAgICAgYXJlYV9uYW1lOiB0YXJnZXRfZGF0YS5hcmVhX25hbWUsXG4gICAgICAgICAgcG9pbnRfaWQ6IHRhcmdldF9wb2ludF9pZCxcbiAgICAgICAgfSxcbiAgICAgICAgY2hpbGRyZW46IFtdLFxuICAgICAgfTtcbiAgICB9XG4gICAgbm9kZXNbdGFyZ2V0X3BvaW50X2lkXS5jaGlsZHJlbi5wdXNoKG5vZGVzW3NvdXJjZV9wb2ludF9pZF0pO1xuICAgIGNoaWxkcmVuLmFkZChzb3VyY2VfcG9pbnRfaWQpO1xuICAgIG5vZGVzW3NvdXJjZV9wb2ludF9pZF0uYXR0cmlidXRlcyA9IHtcbiAgICAgIGRpc3RhbmNlLFxuICAgICAgbW9uaXRvcmVkLFxuICAgICAgdHlwZSxcbiAgICAgIGFyZWFfbmFtZSxcbiAgICAgIHBvaW50X2lkOiBzb3VyY2VfcG9pbnRfaWQsXG4gICAgfTtcbiAgfVxuXG4gIC8vIEZpbmQgcm9vdChzKVxuICBjb25zdCByb290cyA9IE9iamVjdC5rZXlzKG5vZGVzKVxuICAgIC5maWx0ZXIoKGlkKSA9PiAhY2hpbGRyZW4uaGFzKE51bWJlcihpZCkpKVxuICAgIC5tYXAoKGlkKSA9PiBub2Rlc1tpZF0pO1xuXG4gIC8vIElmIG11bHRpcGxlIHJvb3RzIGV4aXN0LCB3cmFwIGluIGEgc3VwZXIgcm9vdFxuICByZXR1cm4gcm9vdHMubGVuZ3RoID09PSAxXG4gICAgPyByb290c1swXVxuICAgIDogeyBuYW1lOiB1dGlsaXR5X25hbWUsIGNoaWxkcmVuOiByb290cyB9O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gbWFwQnlJZDxcbiAgVCBleHRlbmRzIHtcbiAgICBpZDogc3RyaW5nIHwgbnVtYmVyO1xuICAgIG5hbWU6IHN0cmluZztcbiAgICBoYXNfZGV2aWNlOiBib29sZWFuO1xuICAgIGdyb3VwOiBJR3JvdXA7XG4gICAgYXJlYV9uYW1lPzogc3RyaW5nO1xuICB9LFxuPihcbiAgaXRlbXM6IFRbXSxcbik6IFJlY29yZDxzdHJpbmcgfCBudW1iZXIsIHsgbmFtZTogc3RyaW5nOyBtb25pdG9yZWQ6IGJvb2xlYW47IHR5cGU6IHN0cmluZyB9PiB7XG4gIHJldHVybiBpdGVtcy5yZWR1Y2UoKGFjYywgeyBpZCwgbmFtZSwgaGFzX2RldmljZSwgZ3JvdXAsIGFyZWFfbmFtZSB9KSA9PiB7XG4gICAgYWNjW2lkXSA9IHtcbiAgICAgIG5hbWUsXG4gICAgICBtb25pdG9yZWQ6IGhhc19kZXZpY2UsXG4gICAgICB0eXBlOiBhcmVhX25hbWUgPyAnYXJlYScgOiBncm91cC50eXBlLFxuICAgICAgYXJlYV9uYW1lLFxuICAgIH07XG4gICAgcmV0dXJuIGFjYztcbiAgfSwge30gYXMgUmVjb3JkPHN0cmluZyB8IG51bWJlciwgeyBuYW1lOiBzdHJpbmc7IG1vbml0b3JlZDogYm9vbGVhbjsgdHlwZTogc3RyaW5nOyBhcmVhX25hbWU/OiBzdHJpbmcgfT4pO1xufVxuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQWFPLFNBQVNBLFNBQVNBLENBQ3ZCQyxXQUFtQixFQUNuQkMsVUFBVSxFQUNWQyxZQUFZLEVBQ0Y7RUFDVixJQUFNQyxLQUFLLEdBQUcsQ0FBQyxDQUFDO0VBQ2hCLElBQU1DLFFBQVEsR0FBRyxJQUFJQyxHQUFHLENBQUMsQ0FBQzs7RUFFMUI7RUFBQSxJQUFBQyxTQUFBLE9BQUFDLDJCQUFBLENBQUFDLE9BQUEsRUFDNkRSLFdBQVc7SUFBQVMsS0FBQTtFQUFBO0lBQXhFLEtBQUFILFNBQUEsQ0FBQUksQ0FBQSxNQUFBRCxLQUFBLEdBQUFILFNBQUEsQ0FBQUssQ0FBQSxJQUFBQyxJQUFBLEdBQTBFO01BQUEsSUFBQUMsV0FBQSxHQUFBSixLQUFBLENBQUFLLEtBQUE7UUFBN0RDLGVBQWUsR0FBQUYsV0FBQSxDQUFmRSxlQUFlO1FBQUVDLGVBQWUs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
|