@antv/layout 1.2.10 → 1.2.11
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/dist/747bfdc8efc94bc1fa90.worker.js +2 -0
- package/dist/747bfdc8efc94bc1fa90.worker.js.map +1 -0
- package/dist/index.min.js +1 -1
- package/dist/index.min.js.map +1 -1
- package/lib/bundle-entry.js +19 -0
- package/lib/bundle-entry.js.map +1 -0
- package/lib/bundle-supervisor.js +94 -0
- package/lib/bundle-supervisor.js.map +1 -0
- package/lib/bundle-worker.js +52 -0
- package/lib/bundle-worker.js.map +1 -0
- package/lib/circular.js +258 -0
- package/lib/circular.js.map +1 -0
- package/lib/comboCombined.js +440 -0
- package/lib/comboCombined.js.map +1 -0
- package/lib/concentric.js +229 -0
- package/lib/concentric.js.map +1 -0
- package/lib/d3Force/forceInBox.js +331 -0
- package/lib/d3Force/forceInBox.js.map +1 -0
- package/lib/d3Force/index.js +338 -0
- package/lib/d3Force/index.js.map +1 -0
- package/lib/dagre/acyclic.js +62 -0
- package/lib/dagre/acyclic.js.map +1 -0
- package/lib/dagre/add-border-segments.js +37 -0
- package/lib/dagre/add-border-segments.js.map +1 -0
- package/lib/dagre/coordinate-system.js +65 -0
- package/lib/dagre/coordinate-system.js.map +1 -0
- package/lib/dagre/data/list.d.ts +1 -1
- package/lib/dagre/data/list.js +50 -0
- package/lib/dagre/data/list.js.map +1 -0
- package/lib/dagre/greedy-fas.js +147 -0
- package/lib/dagre/greedy-fas.js.map +1 -0
- package/lib/dagre/layout.js +470 -0
- package/lib/dagre/layout.js.map +1 -0
- package/lib/dagre/nesting-graph.js +153 -0
- package/lib/dagre/nesting-graph.js.map +1 -0
- package/lib/dagre/normalize.js +98 -0
- package/lib/dagre/normalize.js.map +1 -0
- package/lib/dagre/order/add-subgraph-constraints.js +45 -0
- package/lib/dagre/order/add-subgraph-constraints.js.map +1 -0
- package/lib/dagre/order/barycenter.js +23 -0
- package/lib/dagre/order/barycenter.js.map +1 -0
- package/lib/dagre/order/build-layer-graph.js +96 -0
- package/lib/dagre/order/build-layer-graph.js.map +1 -0
- package/lib/dagre/order/cross-count.js +63 -0
- package/lib/dagre/order/cross-count.js.map +1 -0
- package/lib/dagre/order/index.js +91 -0
- package/lib/dagre/order/index.js.map +1 -0
- package/lib/dagre/order/init-data-order.js +28 -0
- package/lib/dagre/order/init-data-order.js.map +1 -0
- package/lib/dagre/order/init-order.js +50 -0
- package/lib/dagre/order/init-order.js.map +1 -0
- package/lib/dagre/order/resolve-conflicts.d.ts +1 -1
- package/lib/dagre/order/resolve-conflicts.js +121 -0
- package/lib/dagre/order/resolve-conflicts.js.map +1 -0
- package/lib/dagre/order/sort-subgraph.js +84 -0
- package/lib/dagre/order/sort-subgraph.js.map +1 -0
- package/lib/dagre/order/sort.js +74 -0
- package/lib/dagre/order/sort.js.map +1 -0
- package/lib/dagre/parent-dummy-chains.js +80 -0
- package/lib/dagre/parent-dummy-chains.js.map +1 -0
- package/lib/dagre/position/bk.d.ts +1 -1
- package/lib/dagre/position/bk.js +398 -0
- package/lib/dagre/position/bk.js.map +1 -0
- package/lib/dagre/position/index.js +54 -0
- package/lib/dagre/position/index.js.map +1 -0
- package/lib/dagre/rank/feasible-tree.js +164 -0
- package/lib/dagre/rank/feasible-tree.js.map +1 -0
- package/lib/dagre/rank/index.js +48 -0
- package/lib/dagre/rank/index.js.map +1 -0
- package/lib/dagre/rank/network-simplex.js +232 -0
- package/lib/dagre/rank/network-simplex.js.map +1 -0
- package/lib/dagre/rank/util.js +138 -0
- package/lib/dagre/rank/util.js.map +1 -0
- package/lib/dagre/util.js +289 -0
- package/lib/dagre/util.js.map +1 -0
- package/lib/dagre.js +545 -0
- package/lib/dagre.js.map +1 -0
- package/lib/force/forceNBody.js +123 -0
- package/lib/force/forceNBody.js.map +1 -0
- package/lib/force/index.js +805 -0
- package/lib/force/index.js.map +1 -0
- package/lib/force/types.d.ts +3 -3
- package/lib/force/types.js +2 -0
- package/lib/force/types.js.map +1 -0
- package/lib/forceAtlas2/body.d.ts +1 -1
- package/lib/forceAtlas2/body.js +91 -0
- package/lib/forceAtlas2/body.js.map +1 -0
- package/lib/forceAtlas2/index.js +562 -0
- package/lib/forceAtlas2/index.js.map +1 -0
- package/lib/forceAtlas2/quad.d.ts +1 -1
- package/lib/forceAtlas2/quad.js +98 -0
- package/lib/forceAtlas2/quad.js.map +1 -0
- package/lib/forceAtlas2/quadTree.js +105 -0
- package/lib/forceAtlas2/quadTree.js.map +1 -0
- package/lib/fruchterman.js +376 -0
- package/lib/fruchterman.js.map +1 -0
- package/lib/grid.js +308 -0
- package/lib/grid.js.map +1 -0
- package/lib/index.js +17 -0
- package/lib/index.js.map +1 -0
- package/lib/mds.js +137 -0
- package/lib/mds.js.map +1 -0
- package/lib/radial/index.js +355 -0
- package/lib/radial/index.js.map +1 -0
- package/lib/radial/mds.js +29 -0
- package/lib/radial/mds.js.map +1 -0
- package/lib/radial/radial-nonoverlap-force.d.ts +1 -1
- package/lib/radial/radial-nonoverlap-force.js +100 -0
- package/lib/radial/radial-nonoverlap-force.js.map +1 -0
- package/lib/random.js +98 -0
- package/lib/random.js.map +1 -0
- package/lib/registry.js +27 -0
- package/lib/registry.js.map +1 -0
- package/lib/supervisor.js +90 -0
- package/lib/supervisor.js.map +1 -0
- package/lib/types.d.ts +13 -13
- package/lib/types.js +4 -0
- package/lib/types.js.map +1 -0
- package/lib/util/array.js +2 -0
- package/lib/util/array.js.map +1 -0
- package/lib/util/common.d.ts +12 -0
- package/lib/util/common.js +32 -0
- package/lib/util/common.js.map +1 -0
- package/lib/util/function.js +126 -0
- package/lib/util/function.js.map +1 -0
- package/lib/util/gpu.js +214 -0
- package/lib/util/gpu.js.map +1 -0
- package/lib/util/index.js +7 -0
- package/lib/util/index.js.map +1 -0
- package/lib/util/math.js +257 -0
- package/lib/util/math.js.map +1 -0
- package/lib/util/number.js +5 -0
- package/lib/util/number.js.map +1 -0
- package/lib/util/object.js +42 -0
- package/lib/util/object.js.map +1 -0
- package/lib/util/string.js +15 -0
- package/lib/util/string.js.map +1 -0
- package/lib/worker.d.ts +1 -0
- package/lib/worker.js +45 -0
- package/lib/worker.js.map +1 -0
- package/package.json +2 -2
- package/dist/5fc550bbb6f708833d84.worker.js +0 -2
- package/dist/5fc550bbb6f708833d84.worker.js.map +0 -1
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
var Quad = /** @class */ (function () {
|
|
2
|
+
function Quad(params) {
|
|
3
|
+
/**
|
|
4
|
+
* the center position of this quad
|
|
5
|
+
* @type {number}
|
|
6
|
+
*/
|
|
7
|
+
this.xmid = params.xmid;
|
|
8
|
+
/**
|
|
9
|
+
* the center position of this quad
|
|
10
|
+
* @type {number}
|
|
11
|
+
*/
|
|
12
|
+
this.ymid = params.ymid;
|
|
13
|
+
/**
|
|
14
|
+
* the length of this quad
|
|
15
|
+
* @type {number}
|
|
16
|
+
*/
|
|
17
|
+
this.length = params.length;
|
|
18
|
+
/**
|
|
19
|
+
* the mass center of this quad
|
|
20
|
+
* @type {number}
|
|
21
|
+
*/
|
|
22
|
+
this.massCenter = params.massCenter || [0, 0];
|
|
23
|
+
/**
|
|
24
|
+
* the mass of this quad
|
|
25
|
+
* @type {number}
|
|
26
|
+
*/
|
|
27
|
+
this.mass = params.mass || 1;
|
|
28
|
+
}
|
|
29
|
+
Quad.prototype.getLength = function () {
|
|
30
|
+
return this.length;
|
|
31
|
+
};
|
|
32
|
+
Quad.prototype.contains = function (x, y) {
|
|
33
|
+
var halfLen = this.length / 2;
|
|
34
|
+
return (x <= this.xmid + halfLen &&
|
|
35
|
+
x >= this.xmid - halfLen &&
|
|
36
|
+
y <= this.ymid + halfLen &&
|
|
37
|
+
y >= this.ymid - halfLen);
|
|
38
|
+
};
|
|
39
|
+
// northwest quadrant
|
|
40
|
+
// tslint:disable-next-line
|
|
41
|
+
Quad.prototype.NW = function () {
|
|
42
|
+
var x = this.xmid - this.length / 4;
|
|
43
|
+
var y = this.ymid + this.length / 4;
|
|
44
|
+
var len = this.length / 2;
|
|
45
|
+
var params = {
|
|
46
|
+
xmid: x,
|
|
47
|
+
ymid: y,
|
|
48
|
+
length: len
|
|
49
|
+
};
|
|
50
|
+
var NW = new Quad(params);
|
|
51
|
+
return NW;
|
|
52
|
+
};
|
|
53
|
+
// northeast
|
|
54
|
+
// tslint:disable-next-line
|
|
55
|
+
Quad.prototype.NE = function () {
|
|
56
|
+
var x = this.xmid + this.length / 4;
|
|
57
|
+
var y = this.ymid + this.length / 4;
|
|
58
|
+
var len = this.length / 2;
|
|
59
|
+
var params = {
|
|
60
|
+
xmid: x,
|
|
61
|
+
ymid: y,
|
|
62
|
+
length: len
|
|
63
|
+
};
|
|
64
|
+
var NE = new Quad(params);
|
|
65
|
+
return NE;
|
|
66
|
+
};
|
|
67
|
+
// southwest
|
|
68
|
+
// tslint:disable-next-line
|
|
69
|
+
Quad.prototype.SW = function () {
|
|
70
|
+
var x = this.xmid - this.length / 4;
|
|
71
|
+
var y = this.ymid - this.length / 4;
|
|
72
|
+
var len = this.length / 2;
|
|
73
|
+
var params = {
|
|
74
|
+
xmid: x,
|
|
75
|
+
ymid: y,
|
|
76
|
+
length: len
|
|
77
|
+
};
|
|
78
|
+
var SW = new Quad(params);
|
|
79
|
+
return SW;
|
|
80
|
+
};
|
|
81
|
+
// southeast
|
|
82
|
+
// tslint:disable-next-line
|
|
83
|
+
Quad.prototype.SE = function () {
|
|
84
|
+
var x = this.xmid + this.length / 4;
|
|
85
|
+
var y = this.ymid - this.length / 4;
|
|
86
|
+
var len = this.length / 2;
|
|
87
|
+
var params = {
|
|
88
|
+
xmid: x,
|
|
89
|
+
ymid: y,
|
|
90
|
+
length: len
|
|
91
|
+
};
|
|
92
|
+
var SE = new Quad(params);
|
|
93
|
+
return SE;
|
|
94
|
+
};
|
|
95
|
+
return Quad;
|
|
96
|
+
}());
|
|
97
|
+
export default Quad;
|
|
98
|
+
//# sourceMappingURL=quad.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"quad.js","sourceRoot":"","sources":["../../src/forceAtlas2/quad.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @fileOverview quadTree
|
|
3
|
+
* @author shiwu.wyy@antfin.com
|
|
4
|
+
*/
|
|
5
|
+
var QuadTree = /** @class */ (function () {
|
|
6
|
+
// each quadtree represents a quadrant and an aggregate body
|
|
7
|
+
// that represents all bodies inside the quadrant
|
|
8
|
+
function QuadTree(param) {
|
|
9
|
+
/**
|
|
10
|
+
* (aggregated) body in this quad
|
|
11
|
+
* @type {object}
|
|
12
|
+
*/
|
|
13
|
+
this.body = null;
|
|
14
|
+
/**
|
|
15
|
+
* tree representing the northwest quadrant
|
|
16
|
+
* @type {object}
|
|
17
|
+
*/
|
|
18
|
+
this.quad = null;
|
|
19
|
+
this.NW = null;
|
|
20
|
+
this.NE = null;
|
|
21
|
+
this.SW = null;
|
|
22
|
+
this.SE = null;
|
|
23
|
+
/**
|
|
24
|
+
* threshold
|
|
25
|
+
* @type {number}
|
|
26
|
+
*/
|
|
27
|
+
this.theta = 0.5;
|
|
28
|
+
if (param != null)
|
|
29
|
+
this.quad = param;
|
|
30
|
+
}
|
|
31
|
+
// insert a body(node) into the tree
|
|
32
|
+
QuadTree.prototype.insert = function (bo) {
|
|
33
|
+
// if this node does not contain a body, put the new body bo here
|
|
34
|
+
if (this.body == null) {
|
|
35
|
+
this.body = bo;
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
// internal node
|
|
39
|
+
if (!this._isExternal()) {
|
|
40
|
+
// update mass info
|
|
41
|
+
this.body = this.body.add(bo);
|
|
42
|
+
// insert body into quadrant
|
|
43
|
+
this._putBody(bo);
|
|
44
|
+
}
|
|
45
|
+
else { // external node
|
|
46
|
+
// divide this region into four children
|
|
47
|
+
if (this.quad) {
|
|
48
|
+
this.NW = new QuadTree(this.quad.NW());
|
|
49
|
+
this.NE = new QuadTree(this.quad.NE());
|
|
50
|
+
this.SW = new QuadTree(this.quad.SW());
|
|
51
|
+
this.SE = new QuadTree(this.quad.SE());
|
|
52
|
+
}
|
|
53
|
+
// insert this body and bo
|
|
54
|
+
this._putBody(this.body);
|
|
55
|
+
this._putBody(bo);
|
|
56
|
+
// update the mass info
|
|
57
|
+
this.body = this.body.add(bo);
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
// inserts bo into a quad
|
|
61
|
+
// tslint:disable-next-line
|
|
62
|
+
QuadTree.prototype._putBody = function (bo) {
|
|
63
|
+
if (!this.quad)
|
|
64
|
+
return;
|
|
65
|
+
if (bo.in(this.quad.NW()) && this.NW)
|
|
66
|
+
this.NW.insert(bo);
|
|
67
|
+
else if (bo.in(this.quad.NE()) && this.NE)
|
|
68
|
+
this.NE.insert(bo);
|
|
69
|
+
else if (bo.in(this.quad.SW()) && this.SW)
|
|
70
|
+
this.SW.insert(bo);
|
|
71
|
+
else if (bo.in(this.quad.SE()) && this.SE)
|
|
72
|
+
this.SE.insert(bo);
|
|
73
|
+
};
|
|
74
|
+
// tslint:disable-next-line
|
|
75
|
+
QuadTree.prototype._isExternal = function () {
|
|
76
|
+
// four children are null
|
|
77
|
+
return (this.NW == null && this.NE == null && this.SW == null && this.SE == null);
|
|
78
|
+
};
|
|
79
|
+
// update the forces
|
|
80
|
+
QuadTree.prototype.updateForce = function (bo) {
|
|
81
|
+
if (this.body == null || bo === this.body) {
|
|
82
|
+
return;
|
|
83
|
+
}
|
|
84
|
+
// if the current node is external
|
|
85
|
+
if (this._isExternal())
|
|
86
|
+
bo.addForce(this.body);
|
|
87
|
+
// internal nodes
|
|
88
|
+
else {
|
|
89
|
+
var s = this.quad ? this.quad.getLength() : 0;
|
|
90
|
+
var d = this.body.distanceTo(bo);
|
|
91
|
+
// b is far enough
|
|
92
|
+
if ((s / d) < this.theta)
|
|
93
|
+
bo.addForce(this.body);
|
|
94
|
+
else {
|
|
95
|
+
this.NW && this.NW.updateForce(bo);
|
|
96
|
+
this.NE && this.NE.updateForce(bo);
|
|
97
|
+
this.SW && this.SW.updateForce(bo);
|
|
98
|
+
this.SE && this.SE.updateForce(bo);
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
};
|
|
102
|
+
return QuadTree;
|
|
103
|
+
}());
|
|
104
|
+
export default QuadTree;
|
|
105
|
+
//# sourceMappingURL=quadTree.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"quadTree.js","sourceRoot":"","sources":["../../src/forceAtlas2/quadTree.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,376 @@
|
|
|
1
|
+
import { __assign, __awaiter, __generator } from "tslib";
|
|
2
|
+
import { isNumber } from "@antv/util";
|
|
3
|
+
import { Graph as IGraph } from "@antv/graphlib";
|
|
4
|
+
import { cloneFormatData } from "./util";
|
|
5
|
+
var DEFAULTS_LAYOUT_OPTIONS = {
|
|
6
|
+
maxIteration: 1000,
|
|
7
|
+
gravity: 10,
|
|
8
|
+
speed: 5,
|
|
9
|
+
clustering: false,
|
|
10
|
+
clusterGravity: 10,
|
|
11
|
+
width: 300,
|
|
12
|
+
height: 300,
|
|
13
|
+
nodeClusterBy: "cluster",
|
|
14
|
+
};
|
|
15
|
+
var SPEED_DIVISOR = 800;
|
|
16
|
+
/**
|
|
17
|
+
* Layout with fructherman force model
|
|
18
|
+
*
|
|
19
|
+
* @example
|
|
20
|
+
* // Assign layout options when initialization.
|
|
21
|
+
* const layout = new FruchtermanLayout({ center: [100, 100] });
|
|
22
|
+
* const positions = await layout.execute(graph); // { nodes: [], edges: [] }
|
|
23
|
+
*
|
|
24
|
+
* // Or use different options later.
|
|
25
|
+
* const layout = new FruchtermanLayout({ center: [100, 100] });
|
|
26
|
+
* const positions = await layout.execute(graph, { center: [100, 100] }); // { nodes: [], edges: [] }
|
|
27
|
+
*
|
|
28
|
+
* // If you want to assign the positions directly to the nodes, use assign method.
|
|
29
|
+
* await layout.assign(graph, { center: [100, 100] });
|
|
30
|
+
*/
|
|
31
|
+
var FruchtermanLayout = /** @class */ (function () {
|
|
32
|
+
function FruchtermanLayout(options) {
|
|
33
|
+
if (options === void 0) { options = {}; }
|
|
34
|
+
this.options = options;
|
|
35
|
+
this.id = "fruchterman";
|
|
36
|
+
this.timeInterval = 0;
|
|
37
|
+
this.running = false;
|
|
38
|
+
this.options = __assign(__assign({}, DEFAULTS_LAYOUT_OPTIONS), options);
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Return the positions of nodes and edges(if needed).
|
|
42
|
+
*/
|
|
43
|
+
FruchtermanLayout.prototype.execute = function (graph, options) {
|
|
44
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
45
|
+
return __generator(this, function (_a) {
|
|
46
|
+
return [2 /*return*/, this.genericFruchtermanLayout(false, graph, options)];
|
|
47
|
+
});
|
|
48
|
+
});
|
|
49
|
+
};
|
|
50
|
+
/**
|
|
51
|
+
* To directly assign the positions to the nodes.
|
|
52
|
+
*/
|
|
53
|
+
FruchtermanLayout.prototype.assign = function (graph, options) {
|
|
54
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
55
|
+
return __generator(this, function (_a) {
|
|
56
|
+
this.genericFruchtermanLayout(true, graph, options);
|
|
57
|
+
return [2 /*return*/];
|
|
58
|
+
});
|
|
59
|
+
});
|
|
60
|
+
};
|
|
61
|
+
/**
|
|
62
|
+
* Stop simulation immediately.
|
|
63
|
+
*/
|
|
64
|
+
FruchtermanLayout.prototype.stop = function () {
|
|
65
|
+
if (this.timeInterval && typeof window !== "undefined") {
|
|
66
|
+
window.clearInterval(this.timeInterval);
|
|
67
|
+
}
|
|
68
|
+
this.running = false;
|
|
69
|
+
};
|
|
70
|
+
/**
|
|
71
|
+
* Manually steps the simulation by the specified number of iterations.
|
|
72
|
+
* @see https://github.com/d3/d3-force#simulation_tick
|
|
73
|
+
*/
|
|
74
|
+
FruchtermanLayout.prototype.tick = function (iterations) {
|
|
75
|
+
var _this = this;
|
|
76
|
+
if (iterations === void 0) { iterations = this.options.maxIteration || 1; }
|
|
77
|
+
if (this.lastResult) {
|
|
78
|
+
return this.lastResult;
|
|
79
|
+
}
|
|
80
|
+
for (var i = 0; i < iterations; i++) {
|
|
81
|
+
this.runOneStep(this.lastGraph, this.lastClusterMap, this.lastOptions);
|
|
82
|
+
}
|
|
83
|
+
var result = {
|
|
84
|
+
nodes: this.lastLayoutNodes,
|
|
85
|
+
edges: this.lastLayoutEdges,
|
|
86
|
+
};
|
|
87
|
+
if (this.lastAssign) {
|
|
88
|
+
result.nodes.forEach(function (node) {
|
|
89
|
+
return _this.lastGraph.mergeNodeData(node.id, {
|
|
90
|
+
x: node.data.x,
|
|
91
|
+
y: node.data.y,
|
|
92
|
+
z: _this.options.dimensions === 3 ? node.data.z : undefined
|
|
93
|
+
});
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
return result;
|
|
97
|
+
};
|
|
98
|
+
FruchtermanLayout.prototype.genericFruchtermanLayout = function (assign, graph, options) {
|
|
99
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
100
|
+
var formattedOptions, dimensions, width, height, center, clustering, nodeClusterBy, maxIteration, onTick, nodes, edges, result, result, layoutNodes, calcGraph, clusterMap, iter;
|
|
101
|
+
var _this = this;
|
|
102
|
+
return __generator(this, function (_a) {
|
|
103
|
+
if (this.running)
|
|
104
|
+
return [2 /*return*/];
|
|
105
|
+
formattedOptions = this.formatOptions(options);
|
|
106
|
+
dimensions = formattedOptions.dimensions, width = formattedOptions.width, height = formattedOptions.height, center = formattedOptions.center, clustering = formattedOptions.clustering, nodeClusterBy = formattedOptions.nodeClusterBy, maxIteration = formattedOptions.maxIteration, onTick = formattedOptions.onTick;
|
|
107
|
+
nodes = graph.getAllNodes();
|
|
108
|
+
edges = graph.getAllEdges();
|
|
109
|
+
if (!(nodes === null || nodes === void 0 ? void 0 : nodes.length)) {
|
|
110
|
+
result = { nodes: [], edges: edges };
|
|
111
|
+
this.lastResult = result;
|
|
112
|
+
return [2 /*return*/, result];
|
|
113
|
+
}
|
|
114
|
+
if (nodes.length === 1) {
|
|
115
|
+
if (assign) {
|
|
116
|
+
graph.mergeNodeData(nodes[0].id, {
|
|
117
|
+
x: center[0],
|
|
118
|
+
y: center[1],
|
|
119
|
+
z: dimensions === 3 ? center[2] : undefined
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
result = {
|
|
123
|
+
nodes: [
|
|
124
|
+
__assign(__assign({}, nodes[0]), { data: __assign(__assign({}, nodes[0].data), { x: center[0], y: center[1], z: dimensions === 3 ? center[2] : undefined }) }),
|
|
125
|
+
],
|
|
126
|
+
edges: edges,
|
|
127
|
+
};
|
|
128
|
+
this.lastResult = result;
|
|
129
|
+
return [2 /*return*/, result];
|
|
130
|
+
}
|
|
131
|
+
layoutNodes = nodes.map(function (node) { return cloneFormatData(node, [width, height]); });
|
|
132
|
+
calcGraph = new IGraph({
|
|
133
|
+
nodes: layoutNodes,
|
|
134
|
+
edges: edges,
|
|
135
|
+
});
|
|
136
|
+
clusterMap = {};
|
|
137
|
+
if (clustering) {
|
|
138
|
+
layoutNodes.forEach(function (node) {
|
|
139
|
+
var clusterValue = node.data[nodeClusterBy];
|
|
140
|
+
if (!clusterMap[clusterValue]) {
|
|
141
|
+
clusterMap[clusterValue] = {
|
|
142
|
+
name: clusterValue,
|
|
143
|
+
cx: 0,
|
|
144
|
+
cy: 0,
|
|
145
|
+
count: 0,
|
|
146
|
+
};
|
|
147
|
+
}
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
// Use them later in `tick`.
|
|
151
|
+
this.lastLayoutNodes = layoutNodes;
|
|
152
|
+
this.lastLayoutEdges = edges;
|
|
153
|
+
this.lastAssign = assign;
|
|
154
|
+
this.lastGraph = calcGraph;
|
|
155
|
+
this.lastOptions = formattedOptions;
|
|
156
|
+
this.lastClusterMap = clusterMap;
|
|
157
|
+
if (typeof window === "undefined")
|
|
158
|
+
return [2 /*return*/];
|
|
159
|
+
iter = 0;
|
|
160
|
+
return [2 /*return*/, new Promise(function (resolve) {
|
|
161
|
+
// interval for render the result after each iteration
|
|
162
|
+
_this.timeInterval = window.setInterval(function () {
|
|
163
|
+
if (!_this.running) {
|
|
164
|
+
resolve({ nodes: layoutNodes, edges: edges });
|
|
165
|
+
return;
|
|
166
|
+
}
|
|
167
|
+
_this.runOneStep(calcGraph, clusterMap, formattedOptions);
|
|
168
|
+
if (assign) {
|
|
169
|
+
layoutNodes.forEach(function (_a) {
|
|
170
|
+
var id = _a.id, data = _a.data;
|
|
171
|
+
return graph.mergeNodeData(id, {
|
|
172
|
+
x: data.x,
|
|
173
|
+
y: data.y,
|
|
174
|
+
z: dimensions === 3 ? data.z : undefined
|
|
175
|
+
});
|
|
176
|
+
});
|
|
177
|
+
}
|
|
178
|
+
onTick === null || onTick === void 0 ? void 0 : onTick({
|
|
179
|
+
nodes: layoutNodes,
|
|
180
|
+
edges: edges,
|
|
181
|
+
});
|
|
182
|
+
iter++;
|
|
183
|
+
if (iter >= maxIteration) {
|
|
184
|
+
window.clearInterval(_this.timeInterval);
|
|
185
|
+
resolve({ nodes: layoutNodes, edges: edges });
|
|
186
|
+
}
|
|
187
|
+
}, 0);
|
|
188
|
+
_this.running = true;
|
|
189
|
+
})];
|
|
190
|
+
});
|
|
191
|
+
});
|
|
192
|
+
};
|
|
193
|
+
FruchtermanLayout.prototype.formatOptions = function (options) {
|
|
194
|
+
if (options === void 0) { options = {}; }
|
|
195
|
+
var mergedOptions = __assign(__assign({}, this.options), options);
|
|
196
|
+
var clustering = mergedOptions.clustering, nodeClusterBy = mergedOptions.nodeClusterBy;
|
|
197
|
+
var propsCenter = mergedOptions.center, propsWidth = mergedOptions.width, propsHeight = mergedOptions.height;
|
|
198
|
+
mergedOptions.width =
|
|
199
|
+
!propsWidth && typeof window !== "undefined"
|
|
200
|
+
? window.innerWidth
|
|
201
|
+
: propsWidth;
|
|
202
|
+
mergedOptions.height =
|
|
203
|
+
!propsHeight && typeof window !== "undefined"
|
|
204
|
+
? window.innerHeight
|
|
205
|
+
: propsHeight;
|
|
206
|
+
mergedOptions.center = !propsCenter
|
|
207
|
+
? [mergedOptions.width / 2, mergedOptions.height / 2]
|
|
208
|
+
: propsCenter;
|
|
209
|
+
mergedOptions.clustering = clustering && !!nodeClusterBy;
|
|
210
|
+
return mergedOptions;
|
|
211
|
+
};
|
|
212
|
+
FruchtermanLayout.prototype.runOneStep = function (calcGraph, clusterMap, options) {
|
|
213
|
+
var dimensions = options.dimensions, height = options.height, width = options.width, gravity = options.gravity, center = options.center, speed = options.speed, clustering = options.clustering, nodeClusterBy = options.nodeClusterBy, propsClusterGravity = options.clusterGravity;
|
|
214
|
+
var area = height * width;
|
|
215
|
+
var maxDisplace = Math.sqrt(area) / 10;
|
|
216
|
+
var nodes = calcGraph.getAllNodes();
|
|
217
|
+
var k2 = area / (nodes.length + 1);
|
|
218
|
+
var k = Math.sqrt(k2);
|
|
219
|
+
var displacements = {};
|
|
220
|
+
this.applyCalculate(calcGraph, displacements, k, k2);
|
|
221
|
+
// gravity for clusters
|
|
222
|
+
if (clustering) {
|
|
223
|
+
// reset the clustering centers
|
|
224
|
+
for (var key in clusterMap) {
|
|
225
|
+
clusterMap[key].cx = 0;
|
|
226
|
+
clusterMap[key].cy = 0;
|
|
227
|
+
clusterMap[key].count = 0;
|
|
228
|
+
}
|
|
229
|
+
// re-compute clustering centers
|
|
230
|
+
nodes.forEach(function (node) {
|
|
231
|
+
var data = node.data; // node is one of layoutNodes, which is formatted and data field exists
|
|
232
|
+
var c = clusterMap[data[nodeClusterBy]];
|
|
233
|
+
if (isNumber(data.x)) {
|
|
234
|
+
c.cx += data.x;
|
|
235
|
+
}
|
|
236
|
+
if (isNumber(data.y)) {
|
|
237
|
+
c.cy += data.y;
|
|
238
|
+
}
|
|
239
|
+
c.count++;
|
|
240
|
+
});
|
|
241
|
+
for (var key in clusterMap) {
|
|
242
|
+
clusterMap[key].cx /= clusterMap[key].count;
|
|
243
|
+
clusterMap[key].cy /= clusterMap[key].count;
|
|
244
|
+
}
|
|
245
|
+
// compute the cluster gravity forces
|
|
246
|
+
var clusterGravity_1 = (propsClusterGravity || gravity);
|
|
247
|
+
nodes.forEach(function (node, j) {
|
|
248
|
+
var id = node.id, data = node.data;
|
|
249
|
+
if (!isNumber(data.x) || !isNumber(data.y))
|
|
250
|
+
return;
|
|
251
|
+
var c = clusterMap[data[nodeClusterBy]];
|
|
252
|
+
var distLength = Math.sqrt((data.x - c.cx) * (data.x - c.cx) + (data.y - c.cy) * (data.y - c.cy));
|
|
253
|
+
var gravityForce = k * clusterGravity_1;
|
|
254
|
+
displacements[id].x -= (gravityForce * (data.x - c.cx)) / distLength;
|
|
255
|
+
displacements[id].y -= (gravityForce * (data.y - c.cy)) / distLength;
|
|
256
|
+
});
|
|
257
|
+
}
|
|
258
|
+
// gravity
|
|
259
|
+
nodes.forEach(function (node, j) {
|
|
260
|
+
var id = node.id, data = node.data;
|
|
261
|
+
if (!isNumber(data.x) || !isNumber(data.y))
|
|
262
|
+
return;
|
|
263
|
+
var gravityForce = 0.01 * k * gravity;
|
|
264
|
+
displacements[id].x -= gravityForce * (data.x - center[0]);
|
|
265
|
+
displacements[id].y -= gravityForce * (data.y - center[1]);
|
|
266
|
+
if (dimensions === 3) {
|
|
267
|
+
displacements[id].z -= gravityForce * (data.z - center[2]);
|
|
268
|
+
}
|
|
269
|
+
});
|
|
270
|
+
// move
|
|
271
|
+
nodes.forEach(function (node, j) {
|
|
272
|
+
var id = node.id, data = node.data;
|
|
273
|
+
if (isNumber(data.fx) && isNumber(data.fy)) {
|
|
274
|
+
data.x = data.fx;
|
|
275
|
+
data.y = data.fy;
|
|
276
|
+
if (dimensions === 3) {
|
|
277
|
+
data.z = data.fz;
|
|
278
|
+
}
|
|
279
|
+
return;
|
|
280
|
+
}
|
|
281
|
+
if (!isNumber(data.x) || !isNumber(data.y))
|
|
282
|
+
return;
|
|
283
|
+
var distLength = Math.sqrt(displacements[id].x * displacements[id].x +
|
|
284
|
+
displacements[id].y * displacements[id].y + (dimensions === 3 ? displacements[id].z * displacements[id].z : 0));
|
|
285
|
+
if (distLength > 0) {
|
|
286
|
+
// && !n.isFixed()
|
|
287
|
+
var limitedDist = Math.min(maxDisplace * (speed / SPEED_DIVISOR), distLength);
|
|
288
|
+
calcGraph.mergeNodeData(id, {
|
|
289
|
+
x: data.x + (displacements[id].x / distLength) * limitedDist,
|
|
290
|
+
y: data.y + (displacements[id].y / distLength) * limitedDist,
|
|
291
|
+
z: dimensions === 3 ? data.z + (displacements[id].z / distLength) * limitedDist : undefined
|
|
292
|
+
});
|
|
293
|
+
}
|
|
294
|
+
});
|
|
295
|
+
};
|
|
296
|
+
FruchtermanLayout.prototype.applyCalculate = function (calcGraph, displacements, k, k2) {
|
|
297
|
+
this.calRepulsive(calcGraph, displacements, k2);
|
|
298
|
+
this.calAttractive(calcGraph, displacements, k);
|
|
299
|
+
};
|
|
300
|
+
FruchtermanLayout.prototype.calRepulsive = function (calcGraph, displacements, k2) {
|
|
301
|
+
var _this = this;
|
|
302
|
+
var nodes = calcGraph.getAllNodes();
|
|
303
|
+
nodes.forEach(function (_a, i) {
|
|
304
|
+
var v = _a.data, vid = _a.id;
|
|
305
|
+
displacements[vid] = { x: 0, y: 0, z: 0 };
|
|
306
|
+
nodes.forEach(function (_a, j) {
|
|
307
|
+
var u = _a.data, uid = _a.id;
|
|
308
|
+
if (i <= j ||
|
|
309
|
+
!isNumber(v.x) ||
|
|
310
|
+
!isNumber(u.x) ||
|
|
311
|
+
!isNumber(v.y) ||
|
|
312
|
+
!isNumber(u.y)) {
|
|
313
|
+
return;
|
|
314
|
+
}
|
|
315
|
+
var vecX = v.x - u.x;
|
|
316
|
+
var vecY = v.y - u.y;
|
|
317
|
+
var vecZ = _this.options.dimensions === 3 ? v.z - u.z : 0;
|
|
318
|
+
var lengthSqr = vecX * vecX + vecY * vecY + vecZ * vecZ;
|
|
319
|
+
if (lengthSqr === 0) {
|
|
320
|
+
lengthSqr = 1;
|
|
321
|
+
vecX = 0.01;
|
|
322
|
+
vecY = 0.01;
|
|
323
|
+
vecZ = 0.01;
|
|
324
|
+
}
|
|
325
|
+
var common = k2 / lengthSqr;
|
|
326
|
+
var dispX = vecX * common;
|
|
327
|
+
var dispY = vecY * common;
|
|
328
|
+
var dispZ = vecZ * common;
|
|
329
|
+
displacements[vid].x += dispX;
|
|
330
|
+
displacements[vid].y += dispY;
|
|
331
|
+
displacements[uid].x -= dispX;
|
|
332
|
+
displacements[uid].y -= dispY;
|
|
333
|
+
if (_this.options.dimensions === 3) {
|
|
334
|
+
displacements[vid].z += dispZ;
|
|
335
|
+
displacements[uid].z -= dispZ;
|
|
336
|
+
}
|
|
337
|
+
});
|
|
338
|
+
});
|
|
339
|
+
};
|
|
340
|
+
FruchtermanLayout.prototype.calAttractive = function (calcGraph, displacements, k) {
|
|
341
|
+
var _this = this;
|
|
342
|
+
var edges = calcGraph.getAllEdges();
|
|
343
|
+
edges.forEach(function (e) {
|
|
344
|
+
var source = e.source, target = e.target;
|
|
345
|
+
if (!source || !target || source === target) {
|
|
346
|
+
return;
|
|
347
|
+
}
|
|
348
|
+
var u = calcGraph.getNode(source).data;
|
|
349
|
+
var v = calcGraph.getNode(target).data;
|
|
350
|
+
if (!isNumber(v.x) ||
|
|
351
|
+
!isNumber(u.x) ||
|
|
352
|
+
!isNumber(v.y) ||
|
|
353
|
+
!isNumber(u.y)) {
|
|
354
|
+
return;
|
|
355
|
+
}
|
|
356
|
+
var vecX = v.x - u.x;
|
|
357
|
+
var vecY = v.y - u.y;
|
|
358
|
+
var vecZ = _this.options.dimensions === 3 ? v.z - u.z : 0;
|
|
359
|
+
var common = Math.sqrt(vecX * vecX + vecY * vecY + vecZ * vecZ) / k;
|
|
360
|
+
var dispX = vecX * common;
|
|
361
|
+
var dispY = vecY * common;
|
|
362
|
+
var dispZ = vecZ * common;
|
|
363
|
+
displacements[source].x += dispX;
|
|
364
|
+
displacements[source].y += dispY;
|
|
365
|
+
displacements[target].x -= dispX;
|
|
366
|
+
displacements[target].y -= dispY;
|
|
367
|
+
if (_this.options.dimensions === 3) {
|
|
368
|
+
displacements[source].z += dispZ;
|
|
369
|
+
displacements[target].z -= dispZ;
|
|
370
|
+
}
|
|
371
|
+
});
|
|
372
|
+
};
|
|
373
|
+
return FruchtermanLayout;
|
|
374
|
+
}());
|
|
375
|
+
export { FruchtermanLayout };
|
|
376
|
+
//# sourceMappingURL=fruchterman.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fruchterman.js","sourceRoot":"","sources":["../src/fruchterman.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,KAAK,IAAI,MAAM,EAAE,MAAM,gBAAgB,CAAC;AAajD,OAAO,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AAEzC,IAAM,uBAAuB,GAAsC;IACjE,YAAY,EAAE,IAAI;IAClB,OAAO,EAAE,EAAE;IACX,KAAK,EAAE,CAAC;IACR,UAAU,EAAE,KAAK;IACjB,cAAc,EAAE,EAAE;IAClB,KAAK,EAAE,GAAG;IACV,MAAM,EAAE,GAAG;IACX,aAAa,EAAE,SAAS;CACzB,CAAC;AACF,IAAM,aAAa,GAAG,GAAG,CAAC;AA2B1B;;;;;;;;;;;;;;GAcG;AACH;IAgBE,2BACS,OAAkE;QAAlE,wBAAA,EAAA,UAAoC,EAA8B;QAAlE,YAAO,GAAP,OAAO,CAA2D;QAd3E,OAAE,GAAG,aAAa,CAAC;QAEX,iBAAY,GAAW,CAAC,CAAC;QAEzB,YAAO,GAAY,KAAK,CAAC;QAY/B,IAAI,CAAC,OAAO,yBACP,uBAAuB,GACvB,OAAO,CACX,CAAC;IACJ,CAAC;IAED;;OAEG;IACG,mCAAO,GAAb,UAAc,KAAY,EAAE,OAAkC;;;gBAC5D,sBAAO,IAAI,CAAC,wBAAwB,CAAC,KAAK,EAAE,KAAK,EAAE,OAAO,CAAC,EAAC;;;KAC7D;IACD;;OAEG;IACG,kCAAM,GAAZ,UAAa,KAAY,EAAE,OAAkC;;;gBAC3D,IAAI,CAAC,wBAAwB,CAAC,IAAI,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;;;;KACrD;IAED;;OAEG;IACH,gCAAI,GAAJ;QACE,IAAI,IAAI,CAAC,YAAY,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE;YACtD,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;SACzC;QACD,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;IAED;;;OAGG;IACH,gCAAI,GAAJ,UAAK,UAA2C;QAAhD,iBAyBC;QAzBI,2BAAA,EAAA,aAAa,IAAI,CAAC,OAAO,CAAC,YAAY,IAAI,CAAC;QAC9C,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,OAAO,IAAI,CAAC,UAAU,CAAC;SACxB;QAED,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,EAAE,CAAC,EAAE,EAAE;YACnC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;SACxE;QAED,IAAM,MAAM,GAAG;YACb,KAAK,EAAE,IAAI,CAAC,eAAe;YAC3B,KAAK,EAAE,IAAI,CAAC,eAAe;SAC5B,CAAC;QAEF,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,UAAC,IAAI;gBACxB,OAAA,KAAI,CAAC,SAAS,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,EAAE;oBACpC,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;oBACd,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;oBACd,CAAC,EAAE,KAAI,CAAC,OAAO,CAAC,UAAU,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS;iBAC3D,CAAC;YAJF,CAIE,CACH,CAAC;SACH;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;IAYa,oDAAwB,GAAtC,UACE,MAAe,EACf,KAAY,EACZ,OAAkC;;;;;gBAElC,IAAI,IAAI,CAAC,OAAO;oBAAE,sBAAO;gBAEnB,gBAAgB,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;gBAEnD,UAAU,GAQR,gBAAgB,WARR,EACV,KAAK,GAOH,gBAAgB,MAPb,EACL,MAAM,GAMJ,gBAAgB,OANZ,EACN,MAAM,GAKJ,gBAAgB,OALZ,EACN,UAAU,GAIR,gBAAgB,WAJR,EACV,aAAa,GAGX,gBAAgB,cAHL,EACb,YAAY,GAEV,gBAAgB,aAFN,EACZ,MAAM,GACJ,gBAAgB,OADZ,CACa;gBAEf,KAAK,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC;gBAC5B,KAAK,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC;gBAElC,IAAI,CAAC,CAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,MAAM,CAAA,EAAE;oBACZ,MAAM,GAAG,EAAE,KAAK,EAAE,EAAW,EAAE,KAAK,OAAA,EAAE,CAAC;oBAC7C,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC;oBACzB,sBAAO,MAAM,EAAC;iBACf;gBAED,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;oBACtB,IAAI,MAAM,EAAE;wBACV,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE;4BAC/B,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC;4BACZ,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC;4BACZ,CAAC,EAAE,UAAU,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS;yBAC5C,CAAC,CAAC;qBACJ;oBACK,MAAM,GAAG;wBACb,KAAK,EAAE;kDAEA,KAAK,CAAC,CAAC,CAAC,KACX,IAAI,wBACC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,KAChB,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EACZ,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EACZ,CAAC,EAAE,UAAU,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS;yBAGhD;wBACD,KAAK,OAAA;qBACN,CAAC;oBACF,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC;oBACzB,sBAAO,MAAM,EAAC;iBACf;gBAEK,WAAW,GAAc,KAAK,CAAC,GAAG,CACtC,UAAC,IAAI,IAAK,OAAA,eAAe,CAAC,IAAI,EAAE,CAAC,KAAK,EAAE,MAAM,CAAC,CAAY,EAAjD,CAAiD,CAC5D,CAAC;gBACI,SAAS,GAAG,IAAI,MAAM,CAAwB;oBAClD,KAAK,EAAE,WAAW;oBAClB,KAAK,OAAA;iBACN,CAAC,CAAC;gBAGG,UAAU,GAAe,EAAE,CAAC;gBAClC,IAAI,UAAU,EAAE;oBACd,WAAW,CAAC,OAAO,CAAC,UAAC,IAAI;wBACvB,IAAM,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,CAAW,CAAC;wBACxD,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,EAAE;4BAC7B,UAAU,CAAC,YAAY,CAAC,GAAG;gCACzB,IAAI,EAAE,YAAY;gCAClB,EAAE,EAAE,CAAC;gCACL,EAAE,EAAE,CAAC;gCACL,KAAK,EAAE,CAAC;6BACT,CAAC;yBACH;oBACH,CAAC,CAAC,CAAC;iBACJ;gBAED,4BAA4B;gBAC5B,IAAI,CAAC,eAAe,GAAG,WAAW,CAAC;gBACnC,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;gBAC7B,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC;gBACzB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;gBAC3B,IAAI,CAAC,WAAW,GAAG,gBAAgB,CAAC;gBACpC,IAAI,CAAC,cAAc,GAAG,UAAU,CAAC;gBAEjC,IAAI,OAAO,MAAM,KAAK,WAAW;oBAAE,sBAAO;gBACtC,IAAI,GAAG,CAAC,CAAC;gBAEb,sBAAO,IAAI,OAAO,CAAC,UAAC,OAAO;wBACzB,sDAAsD;wBACtD,KAAI,CAAC,YAAY,GAAG,MAAM,CAAC,WAAW,CAAC;4BACrC,IAAI,CAAC,KAAI,CAAC,OAAO,EAAE;gCACjB,OAAO,CAAC,EAAE,KAAK,EAAE,WAAW,EAAE,KAAK,OAAA,EAAE,CAAC,CAAC;gCACvC,OAAO;6BACR;4BAED,KAAI,CAAC,UAAU,CAAC,SAAS,EAAE,UAAU,EAAE,gBAAgB,CAAC,CAAC;4BACzD,IAAI,MAAM,EAAE;gCACV,WAAW,CAAC,OAAO,CAAC,UAAC,EAAY;wCAAV,EAAE,QAAA,EAAE,IAAI,UAAA;oCAC7B,OAAA,KAAK,CAAC,aAAa,CAAC,EAAE,EAAE;wCACtB,CAAC,EAAE,IAAI,CAAC,CAAC;wCACT,CAAC,EAAE,IAAI,CAAC,CAAC;wCACT,CAAC,EAAE,UAAU,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS;qCACzC,CAAC;gCAJF,CAIE,CACH,CAAC;6BACH;4BACD,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAG;gCACP,KAAK,EAAE,WAAW;gCAClB,KAAK,OAAA;6BACN,CAAC,CAAC;4BACH,IAAI,EAAE,CAAC;4BACP,IAAI,IAAI,IAAI,YAAY,EAAE;gCACxB,MAAM,CAAC,aAAa,CAAC,KAAI,CAAC,YAAY,CAAC,CAAC;gCACxC,OAAO,CAAC,EAAE,KAAK,EAAE,WAAW,EAAE,KAAK,OAAA,EAAE,CAAC,CAAC;6BACxC;wBACH,CAAC,EAAE,CAAC,CAAC,CAAC;wBACN,KAAI,CAAC,OAAO,GAAG,IAAI,CAAC;oBACtB,CAAC,CAAC,EAAC;;;KACJ;IAEO,yCAAa,GAArB,UACE,OAAsC;QAAtC,wBAAA,EAAA,YAAsC;QAEtC,IAAM,aAAa,GAAG,sBAAK,IAAI,CAAC,OAAO,GAAK,OAAO,CAAsB,CAAC;QAClE,IAAA,UAAU,GAAoB,aAAa,WAAjC,EAAE,aAAa,GAAK,aAAa,cAAlB,CAAmB;QAGlD,IAAQ,WAAW,GAGjB,aAAa,OAHI,EACZ,UAAU,GAEf,aAAa,MAFE,EACT,WAAW,GACjB,aAAa,OADI,CACH;QAClB,aAAa,CAAC,KAAK;YACjB,CAAC,UAAU,IAAI,OAAO,MAAM,KAAK,WAAW;gBAC1C,CAAC,CAAC,MAAM,CAAC,UAAU;gBACnB,CAAC,CAAE,UAAqB,CAAC;QAC7B,aAAa,CAAC,MAAM;YAClB,CAAC,WAAW,IAAI,OAAO,MAAM,KAAK,WAAW;gBAC3C,CAAC,CAAC,MAAM,CAAC,WAAW;gBACpB,CAAC,CAAE,WAAsB,CAAC;QAC9B,aAAa,CAAC,MAAM,GAAG,CAAC,WAAW;YACjC,CAAC,CAAC,CAAC,aAAa,CAAC,KAAK,GAAG,CAAC,EAAE,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC;YACrD,CAAC,CAAE,WAA0B,CAAC;QAEhC,aAAa,CAAC,UAAU,GAAG,UAAU,IAAI,CAAC,CAAC,aAAa,CAAC;QAEzD,OAAO,aAAa,CAAC;IACvB,CAAC;IAEO,sCAAU,GAAlB,UACE,SAAoB,EACpB,UAAsB,EACtB,OAAyB;QAGvB,IAAA,UAAU,GASR,OAAO,WATC,EACV,MAAM,GAQJ,OAAO,OARH,EACN,KAAK,GAOH,OAAO,MAPJ,EACL,OAAO,GAML,OAAO,QANF,EACP,MAAM,GAKJ,OAAO,OALH,EACN,KAAK,GAIH,OAAO,MAJJ,EACL,UAAU,GAGR,OAAO,WAHC,EACV,aAAa,GAEX,OAAO,cAFI,EACG,mBAAmB,GACjC,OAAO,eAD0B,CACzB;QACZ,IAAM,IAAI,GAAG,MAAM,GAAG,KAAK,CAAC;QAC5B,IAAM,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;QACzC,IAAM,KAAK,GAAG,SAAS,CAAC,WAAW,EAAE,CAAC;QACtC,IAAM,EAAE,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QACrC,IAAM,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACxB,IAAM,aAAa,GAAoB,EAAE,CAAC;QAC1C,IAAI,CAAC,cAAc,CAAC,SAAS,EAAE,aAAa,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;QAErD,uBAAuB;QACvB,IAAI,UAAU,EAAE;YACd,+BAA+B;YAC/B,KAAK,IAAM,GAAG,IAAI,UAAU,EAAE;gBAC5B,UAAU,CAAC,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;gBACvB,UAAU,CAAC,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;gBACvB,UAAU,CAAC,GAAG,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC;aAC3B;YACD,gCAAgC;YAChC,KAAK,CAAC,OAAO,CAAC,UAAC,IAAI;gBACT,IAAA,IAAI,GAAK,IAAI,KAAT,CAAU,CAAC,uEAAuE;gBAC9F,IAAM,CAAC,GAAG,UAAU,CAAC,IAAI,CAAC,aAAa,CAAW,CAAC,CAAC;gBACpD,IAAI,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE;oBACpB,CAAC,CAAC,EAAE,IAAI,IAAI,CAAC,CAAC,CAAC;iBAChB;gBACD,IAAI,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE;oBACpB,CAAC,CAAC,EAAE,IAAI,IAAI,CAAC,CAAC,CAAC;iBAChB;gBACD,CAAC,CAAC,KAAK,EAAE,CAAC;YACZ,CAAC,CAAC,CAAC;YACH,KAAK,IAAM,GAAG,IAAI,UAAU,EAAE;gBAC5B,UAAU,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,UAAU,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC;gBAC5C,UAAU,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,UAAU,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC;aAC7C;YAED,qCAAqC;YACrC,IAAM,gBAAc,GAAG,CAAC,mBAAmB,IAAI,OAAO,CAAW,CAAC;YAClE,KAAK,CAAC,OAAO,CAAC,UAAC,IAAI,EAAE,CAAC;gBACZ,IAAA,EAAE,GAAW,IAAI,GAAf,EAAE,IAAI,GAAK,IAAI,KAAT,CAAU;gBAC1B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC;oBAAE,OAAO;gBACnD,IAAM,CAAC,GAAG,UAAU,CAAC,IAAI,CAAC,aAAa,CAAW,CAAC,CAAC;gBACpD,IAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAC1B,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CACtE,CAAC;gBACF,IAAM,YAAY,GAAG,CAAC,GAAG,gBAAc,CAAC;gBACxC,aAAa,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,UAAU,CAAC;gBACrE,aAAa,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,UAAU,CAAC;YACvE,CAAC,CAAC,CAAC;SACJ;QAED,UAAU;QACV,KAAK,CAAC,OAAO,CAAC,UAAC,IAAI,EAAE,CAAC;YACZ,IAAA,EAAE,GAAW,IAAI,GAAf,EAAE,IAAI,GAAK,IAAI,KAAT,CAAU;YAC1B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC;gBAAE,OAAO;YACnD,IAAM,YAAY,GAAG,IAAI,GAAG,CAAC,GAAG,OAAO,CAAC;YACxC,aAAa,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,YAAY,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;YAC3D,aAAa,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,YAAY,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;YAC3D,IAAI,UAAU,KAAK,CAAC,EAAE;gBACpB,aAAa,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,YAAY,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;aAC5D;QACH,CAAC,CAAC,CAAC;QAEH,OAAO;QACP,KAAK,CAAC,OAAO,CAAC,UAAC,IAAa,EAAE,CAAC;YACrB,IAAA,EAAE,GAAW,IAAI,GAAf,EAAE,IAAI,GAAK,IAAI,KAAT,CAAU;YAC1B,IAAI,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE;gBAC1C,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,EAAY,CAAC;gBAC3B,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,EAAY,CAAC;gBAC3B,IAAI,UAAU,KAAK,CAAC,EAAE;oBACpB,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,EAAY,CAAC;iBAC5B;gBACD,OAAO;aACR;YACD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC;gBAAE,OAAO;YACnD,IAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAC1B,aAAa,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,aAAa,CAAC,EAAE,CAAC,CAAC,CAAC;gBACvC,aAAa,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,aAAa,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,UAAU,KAAK,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,aAAa,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CACjH,CAAC;YACF,IAAI,UAAU,GAAG,CAAC,EAAE;gBAClB,kBAAkB;gBAClB,IAAM,WAAW,GAAG,IAAI,CAAC,GAAG,CAC1B,WAAW,GAAG,CAAC,KAAK,GAAG,aAAa,CAAC,EACrC,UAAU,CACX,CAAC;gBACF,SAAS,CAAC,aAAa,CAAC,EAAE,EAAE;oBAC1B,CAAC,EAAE,IAAI,CAAC,CAAC,GAAG,CAAC,aAAa,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,GAAG,WAAW;oBAC5D,CAAC,EAAE,IAAI,CAAC,CAAC,GAAG,CAAC,aAAa,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,GAAG,WAAW;oBAC5D,CAAC,EAAE,UAAU,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,aAAa,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC,SAAS;iBAC5F,CAAC,CAAC;aACJ;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IACO,0CAAc,GAAtB,UACE,SAAoB,EACpB,aAA8B,EAC9B,CAAS,EACT,EAAU;QAEV,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,aAAa,EAAE,EAAE,CAAC,CAAC;QAChD,IAAI,CAAC,aAAa,CAAC,SAAS,EAAE,aAAa,EAAE,CAAC,CAAC,CAAC;IAClD,CAAC;IAEO,wCAAY,GAApB,UACE,SAAoB,EACpB,aAA8B,EAC9B,EAAU;QAHZ,iBA2CC;QAtCC,IAAM,KAAK,GAAG,SAAS,CAAC,WAAW,EAAE,CAAC;QACtC,KAAK,CAAC,OAAO,CAAC,UAAC,EAAoB,EAAE,CAAC;gBAAf,CAAC,UAAA,EAAM,GAAG,QAAA;YAC/B,aAAa,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;YAC1C,KAAK,CAAC,OAAO,CAAC,UAAC,EAAoB,EAAE,CAAC;oBAAf,CAAC,UAAA,EAAM,GAAG,QAAA;gBAC/B,IACE,CAAC,IAAI,CAAC;oBACN,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;oBACd,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;oBACd,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;oBACd,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,EACd;oBACA,OAAO;iBACR;gBACD,IAAI,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;gBACrB,IAAI,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;gBACrB,IAAI,IAAI,GAAG,KAAI,CAAC,OAAO,CAAC,UAAU,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBACzD,IAAI,SAAS,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC;gBACxD,IAAI,SAAS,KAAK,CAAC,EAAE;oBACnB,SAAS,GAAG,CAAC,CAAC;oBACd,IAAI,GAAG,IAAI,CAAC;oBACZ,IAAI,GAAG,IAAI,CAAC;oBACZ,IAAI,GAAG,IAAI,CAAC;iBACb;gBACD,IAAM,MAAM,GAAG,EAAE,GAAG,SAAS,CAAC;gBAC9B,IAAM,KAAK,GAAG,IAAI,GAAG,MAAM,CAAC;gBAC5B,IAAM,KAAK,GAAG,IAAI,GAAG,MAAM,CAAC;gBAC5B,IAAM,KAAK,GAAG,IAAI,GAAG,MAAM,CAAC;gBAC5B,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC;gBAC9B,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC;gBAC9B,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC;gBAC9B,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC;gBAE9B,IAAI,KAAI,CAAC,OAAO,CAAC,UAAU,KAAK,CAAC,EAAE;oBACjC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC;oBAC9B,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC;iBAC/B;YACH,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,yCAAa,GAArB,UACE,SAAoB,EACpB,aAA8B,EAC9B,CAAS;QAHX,iBAsCC;QAjCC,IAAM,KAAK,GAAG,SAAS,CAAC,WAAW,EAAE,CAAC;QACtC,KAAK,CAAC,OAAO,CAAC,UAAC,CAAC;YACN,IAAA,MAAM,GAAa,CAAC,OAAd,EAAE,MAAM,GAAK,CAAC,OAAN,CAAO;YAC7B,IAAI,CAAC,MAAM,IAAI,CAAC,MAAM,IAAI,MAAM,KAAK,MAAM,EAAE;gBAC3C,OAAO;aACR;YACO,IAAM,CAAC,GAAK,SAAS,CAAC,OAAO,CAAC,MAAM,CAAC,KAA9B,CAA+B;YACtC,IAAM,CAAC,GAAK,SAAS,CAAC,OAAO,CAAC,MAAM,CAAC,KAA9B,CAA+B;YAC9C,IACE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;gBACd,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;gBACd,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;gBACd,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,EACd;gBACA,OAAO;aACR;YACD,IAAM,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YACvB,IAAM,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YACvB,IAAM,IAAI,GAAG,KAAI,CAAC,OAAO,CAAC,UAAU,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC3D,IAAM,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;YACtE,IAAM,KAAK,GAAG,IAAI,GAAG,MAAM,CAAC;YAC5B,IAAM,KAAK,GAAG,IAAI,GAAG,MAAM,CAAC;YAC5B,IAAM,KAAK,GAAG,IAAI,GAAG,MAAM,CAAC;YAC5B,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC;YACjC,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC;YACjC,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC;YACjC,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC;YAEjC,IAAI,KAAI,CAAC,OAAO,CAAC,UAAU,KAAK,CAAC,EAAE;gBACjC,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC;gBACjC,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC;aAClC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IACH,wBAAC;AAAD,CAAC,AAtbD,IAsbC"}
|