@antv/layout 1.2.12 → 1.2.14-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (238) hide show
  1. package/dist/85db61ddc757dae66e04.worker.js +2 -0
  2. package/dist/85db61ddc757dae66e04.worker.js.map +1 -0
  3. package/dist/index.min.js +1 -1
  4. package/dist/index.min.js.map +1 -1
  5. package/lib/{dagre → antv-dagre}/acyclic.d.ts +1 -1
  6. package/lib/antv-dagre/acyclic.js +65 -0
  7. package/lib/antv-dagre/acyclic.js.map +1 -0
  8. package/lib/antv-dagre/add-border-segments.js +41 -0
  9. package/lib/antv-dagre/add-border-segments.js.map +1 -0
  10. package/lib/{dagre → antv-dagre}/coordinate-system.d.ts +2 -1
  11. package/lib/antv-dagre/coordinate-system.js +69 -0
  12. package/lib/antv-dagre/coordinate-system.js.map +1 -0
  13. package/lib/{dagre → antv-dagre}/data/list.d.ts +1 -1
  14. package/lib/{dagre → antv-dagre}/data/list.js +23 -22
  15. package/lib/antv-dagre/data/list.js.map +1 -0
  16. package/lib/{dagre → antv-dagre}/greedy-fas.d.ts +2 -2
  17. package/lib/antv-dagre/greedy-fas.js +141 -0
  18. package/lib/antv-dagre/greedy-fas.js.map +1 -0
  19. package/lib/{dagre → antv-dagre}/layout.d.ts +2 -1
  20. package/lib/{dagre → antv-dagre}/layout.js +156 -154
  21. package/lib/antv-dagre/layout.js.map +1 -0
  22. package/lib/{dagre → antv-dagre}/nesting-graph.js +42 -39
  23. package/lib/antv-dagre/nesting-graph.js.map +1 -0
  24. package/lib/{dagre → antv-dagre}/normalize.d.ts +2 -2
  25. package/lib/{dagre → antv-dagre}/normalize.js +29 -25
  26. package/lib/antv-dagre/normalize.js.map +1 -0
  27. package/lib/{dagre → antv-dagre}/order/add-subgraph-constraints.js +13 -9
  28. package/lib/antv-dagre/order/add-subgraph-constraints.js.map +1 -0
  29. package/lib/{dagre → antv-dagre}/order/barycenter.d.ts +2 -2
  30. package/lib/antv-dagre/order/barycenter.js +27 -0
  31. package/lib/antv-dagre/order/barycenter.js.map +1 -0
  32. package/lib/{dagre → antv-dagre}/order/build-layer-graph.js +23 -23
  33. package/lib/antv-dagre/order/build-layer-graph.js.map +1 -0
  34. package/lib/antv-dagre/order/cross-count.d.ts +3 -0
  35. package/lib/{dagre → antv-dagre}/order/cross-count.js +21 -17
  36. package/lib/antv-dagre/order/cross-count.js.map +1 -0
  37. package/lib/{dagre → antv-dagre}/order/index.d.ts +1 -1
  38. package/lib/antv-dagre/order/index.js +95 -0
  39. package/lib/antv-dagre/order/index.js.map +1 -0
  40. package/lib/{dagre → antv-dagre}/order/init-data-order.js +12 -9
  41. package/lib/antv-dagre/order/init-data-order.js.map +1 -0
  42. package/lib/antv-dagre/order/init-order.js +51 -0
  43. package/lib/antv-dagre/order/init-order.js.map +1 -0
  44. package/lib/{dagre → antv-dagre}/order/resolve-conflicts.d.ts +3 -3
  45. package/lib/{dagre → antv-dagre}/order/resolve-conflicts.js +35 -36
  46. package/lib/antv-dagre/order/resolve-conflicts.js.map +1 -0
  47. package/lib/{dagre → antv-dagre}/order/sort-subgraph.js +28 -23
  48. package/lib/antv-dagre/order/sort-subgraph.js.map +1 -0
  49. package/lib/{dagre → antv-dagre}/order/sort.d.ts +2 -2
  50. package/lib/{dagre → antv-dagre}/order/sort.js +23 -19
  51. package/lib/antv-dagre/order/sort.js.map +1 -0
  52. package/lib/{dagre → antv-dagre}/parent-dummy-chains.js +32 -28
  53. package/lib/antv-dagre/parent-dummy-chains.js.map +1 -0
  54. package/lib/{dagre → antv-dagre}/position/bk.d.ts +5 -4
  55. package/lib/{dagre → antv-dagre}/position/bk.js +162 -148
  56. package/lib/antv-dagre/position/bk.js.map +1 -0
  57. package/lib/{dagre → antv-dagre}/position/index.d.ts +2 -1
  58. package/lib/antv-dagre/position/index.js +55 -0
  59. package/lib/antv-dagre/position/index.js.map +1 -0
  60. package/lib/{dagre → antv-dagre}/rank/feasible-tree.d.ts +2 -2
  61. package/lib/{dagre → antv-dagre}/rank/feasible-tree.js +42 -38
  62. package/lib/antv-dagre/rank/feasible-tree.js.map +1 -0
  63. package/lib/antv-dagre/rank/index.d.ts +2 -0
  64. package/lib/{dagre → antv-dagre}/rank/index.js +17 -13
  65. package/lib/antv-dagre/rank/index.js.map +1 -0
  66. package/lib/{dagre → antv-dagre}/rank/network-simplex.d.ts +2 -2
  67. package/lib/{dagre → antv-dagre}/rank/network-simplex.js +90 -81
  68. package/lib/antv-dagre/rank/network-simplex.js.map +1 -0
  69. package/lib/{dagre → antv-dagre}/rank/util.d.ts +2 -2
  70. package/lib/{dagre → antv-dagre}/rank/util.js +37 -32
  71. package/lib/antv-dagre/rank/util.js.map +1 -0
  72. package/lib/antv-dagre/types.d.ts +2 -0
  73. package/lib/antv-dagre/types.js +3 -0
  74. package/lib/antv-dagre/types.js.map +1 -0
  75. package/lib/{dagre → antv-dagre}/util.d.ts +1 -1
  76. package/lib/antv-dagre/util.js +299 -0
  77. package/lib/antv-dagre/util.js.map +1 -0
  78. package/lib/antv-dagre.d.ts +50 -0
  79. package/lib/antv-dagre.js +542 -0
  80. package/lib/antv-dagre.js.map +1 -0
  81. package/lib/bundle-entry.d.ts +2 -18
  82. package/lib/bundle-entry.js +5 -18
  83. package/lib/bundle-entry.js.map +1 -1
  84. package/lib/bundle-supervisor.d.ts +4 -22
  85. package/lib/bundle-supervisor.js +59 -54
  86. package/lib/bundle-supervisor.js.map +1 -1
  87. package/lib/bundle-worker.d.ts +1 -1
  88. package/lib/bundle-worker.js +38 -35
  89. package/lib/bundle-worker.js.map +1 -1
  90. package/lib/circular.d.ts +1 -1
  91. package/lib/circular.js +133 -145
  92. package/lib/circular.js.map +1 -1
  93. package/lib/comboCombined.d.ts +1 -1
  94. package/lib/comboCombined.js +273 -299
  95. package/lib/comboCombined.js.map +1 -1
  96. package/lib/concentric.d.ts +1 -1
  97. package/lib/concentric.js +173 -179
  98. package/lib/concentric.js.map +1 -1
  99. package/lib/d3Force/forceInBox.js +80 -78
  100. package/lib/d3Force/forceInBox.js.map +1 -1
  101. package/lib/d3Force/index.d.ts +2 -2
  102. package/lib/d3Force/index.js +207 -229
  103. package/lib/d3Force/index.js.map +1 -1
  104. package/lib/dagre.d.ts +13 -24
  105. package/lib/dagre.js +61 -541
  106. package/lib/dagre.js.map +1 -1
  107. package/lib/exports.d.ts +17 -0
  108. package/lib/exports.js +20 -0
  109. package/lib/exports.js.map +1 -0
  110. package/lib/force/forceNBody.js +48 -47
  111. package/lib/force/forceNBody.js.map +1 -1
  112. package/lib/force/index.d.ts +1 -1
  113. package/lib/force/index.js +301 -324
  114. package/lib/force/index.js.map +1 -1
  115. package/lib/force/types.d.ts +5 -5
  116. package/lib/force/types.js +2 -1
  117. package/lib/forceAtlas2/body.d.ts +1 -1
  118. package/lib/forceAtlas2/body.js +32 -31
  119. package/lib/forceAtlas2/body.js.map +1 -1
  120. package/lib/forceAtlas2/index.d.ts +1 -1
  121. package/lib/forceAtlas2/index.js +219 -227
  122. package/lib/forceAtlas2/index.js.map +1 -1
  123. package/lib/forceAtlas2/quad.d.ts +2 -2
  124. package/lib/forceAtlas2/quad.js +43 -42
  125. package/lib/forceAtlas2/quad.js.map +1 -1
  126. package/lib/forceAtlas2/quadTree.js +19 -17
  127. package/lib/forceAtlas2/quadTree.js.map +1 -1
  128. package/lib/fruchterman.d.ts +1 -1
  129. package/lib/fruchterman.js +203 -219
  130. package/lib/fruchterman.js.map +1 -1
  131. package/lib/grid.d.ts +1 -1
  132. package/lib/grid.js +201 -207
  133. package/lib/grid.js.map +1 -1
  134. package/lib/index.d.ts +1 -15
  135. package/lib/index.js +5 -16
  136. package/lib/index.js.map +1 -1
  137. package/lib/mds.d.ts +1 -1
  138. package/lib/mds.js +73 -79
  139. package/lib/mds.js.map +1 -1
  140. package/lib/radial/index.d.ts +1 -1
  141. package/lib/radial/index.js +183 -186
  142. package/lib/radial/index.js.map +1 -1
  143. package/lib/radial/mds.d.ts +1 -1
  144. package/lib/radial/mds.js +20 -14
  145. package/lib/radial/mds.js.map +1 -1
  146. package/lib/radial/radial-nonoverlap-force.d.ts +2 -2
  147. package/lib/radial/radial-nonoverlap-force.js +40 -37
  148. package/lib/radial/radial-nonoverlap-force.js.map +1 -1
  149. package/lib/random.d.ts +1 -1
  150. package/lib/random.js +57 -66
  151. package/lib/random.js.map +1 -1
  152. package/lib/registry.d.ts +2 -2
  153. package/lib/registry.js +30 -25
  154. package/lib/registry.js.map +1 -1
  155. package/lib/supervisor.d.ts +2 -3
  156. package/lib/supervisor.js +63 -58
  157. package/lib/supervisor.js.map +1 -1
  158. package/lib/types.d.ts +20 -74
  159. package/lib/types.js +5 -1
  160. package/lib/types.js.map +1 -1
  161. package/lib/util/array.js +4 -1
  162. package/lib/util/array.js.map +1 -1
  163. package/lib/util/common.d.ts +1 -1
  164. package/lib/util/common.js +11 -8
  165. package/lib/util/common.js.map +1 -1
  166. package/lib/util/function.js +41 -37
  167. package/lib/util/function.js.map +1 -1
  168. package/lib/util/index.d.ts +0 -2
  169. package/lib/util/index.js +7 -6
  170. package/lib/util/index.js.map +1 -1
  171. package/lib/util/math.d.ts +1 -26
  172. package/lib/util/math.js +55 -154
  173. package/lib/util/math.js.map +1 -1
  174. package/lib/util/object.d.ts +1 -1
  175. package/lib/util/object.js +20 -15
  176. package/lib/util/object.js.map +1 -1
  177. package/lib/util/size.d.ts +3 -0
  178. package/lib/util/size.js +16 -0
  179. package/lib/util/size.js.map +1 -0
  180. package/lib/worker.js +36 -35
  181. package/lib/worker.js.map +1 -1
  182. package/package.json +10 -6
  183. package/dist/4161e9d58bae8f39711a.worker.js +0 -2
  184. package/dist/4161e9d58bae8f39711a.worker.js.map +0 -1
  185. package/lib/dagre/acyclic.js +0 -62
  186. package/lib/dagre/acyclic.js.map +0 -1
  187. package/lib/dagre/add-border-segments.js +0 -37
  188. package/lib/dagre/add-border-segments.js.map +0 -1
  189. package/lib/dagre/coordinate-system.js +0 -65
  190. package/lib/dagre/coordinate-system.js.map +0 -1
  191. package/lib/dagre/data/list.js.map +0 -1
  192. package/lib/dagre/greedy-fas.js +0 -147
  193. package/lib/dagre/greedy-fas.js.map +0 -1
  194. package/lib/dagre/layout.js.map +0 -1
  195. package/lib/dagre/nesting-graph.js.map +0 -1
  196. package/lib/dagre/normalize.js.map +0 -1
  197. package/lib/dagre/order/add-subgraph-constraints.js.map +0 -1
  198. package/lib/dagre/order/barycenter.js +0 -23
  199. package/lib/dagre/order/barycenter.js.map +0 -1
  200. package/lib/dagre/order/build-layer-graph.js.map +0 -1
  201. package/lib/dagre/order/cross-count.d.ts +0 -3
  202. package/lib/dagre/order/cross-count.js.map +0 -1
  203. package/lib/dagre/order/index.js +0 -91
  204. package/lib/dagre/order/index.js.map +0 -1
  205. package/lib/dagre/order/init-data-order.js.map +0 -1
  206. package/lib/dagre/order/init-order.js +0 -50
  207. package/lib/dagre/order/init-order.js.map +0 -1
  208. package/lib/dagre/order/resolve-conflicts.js.map +0 -1
  209. package/lib/dagre/order/sort-subgraph.js.map +0 -1
  210. package/lib/dagre/order/sort.js.map +0 -1
  211. package/lib/dagre/parent-dummy-chains.js.map +0 -1
  212. package/lib/dagre/position/bk.js.map +0 -1
  213. package/lib/dagre/position/index.js +0 -54
  214. package/lib/dagre/position/index.js.map +0 -1
  215. package/lib/dagre/rank/feasible-tree.js.map +0 -1
  216. package/lib/dagre/rank/index.d.ts +0 -2
  217. package/lib/dagre/rank/index.js.map +0 -1
  218. package/lib/dagre/rank/network-simplex.js.map +0 -1
  219. package/lib/dagre/rank/util.js.map +0 -1
  220. package/lib/dagre/util.js +0 -289
  221. package/lib/dagre/util.js.map +0 -1
  222. package/lib/util/gpu.d.ts +0 -45
  223. package/lib/util/gpu.js +0 -214
  224. package/lib/util/gpu.js.map +0 -1
  225. package/lib/util/number.d.ts +0 -1
  226. package/lib/util/number.js +0 -5
  227. package/lib/util/number.js.map +0 -1
  228. package/lib/util/string.d.ts +0 -1
  229. package/lib/util/string.js +0 -15
  230. package/lib/util/string.js.map +0 -1
  231. /package/lib/{dagre → antv-dagre}/add-border-segments.d.ts +0 -0
  232. /package/lib/{dagre → antv-dagre}/nesting-graph.d.ts +0 -0
  233. /package/lib/{dagre → antv-dagre}/order/add-subgraph-constraints.d.ts +0 -0
  234. /package/lib/{dagre → antv-dagre}/order/build-layer-graph.d.ts +0 -0
  235. /package/lib/{dagre → antv-dagre}/order/init-data-order.d.ts +0 -0
  236. /package/lib/{dagre → antv-dagre}/order/init-order.d.ts +0 -0
  237. /package/lib/{dagre → antv-dagre}/order/sort-subgraph.d.ts +0 -0
  238. /package/lib/{dagre → antv-dagre}/parent-dummy-chains.d.ts +0 -0
@@ -1,8 +1,11 @@
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 = {
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FruchtermanLayout = void 0;
4
+ const tslib_1 = require("tslib");
5
+ const graphlib_1 = require("@antv/graphlib");
6
+ const util_1 = require("@antv/util");
7
+ const util_2 = require("./util");
8
+ const DEFAULTS_LAYOUT_OPTIONS = {
6
9
  maxIteration: 1000,
7
10
  gravity: 10,
8
11
  speed: 5,
@@ -10,9 +13,9 @@ var DEFAULTS_LAYOUT_OPTIONS = {
10
13
  clusterGravity: 10,
11
14
  width: 300,
12
15
  height: 300,
13
- nodeClusterBy: "cluster",
16
+ nodeClusterBy: 'cluster',
14
17
  };
15
- var SPEED_DIVISOR = 800;
18
+ const SPEED_DIVISOR = 800;
16
19
  /**
17
20
  * Layout with fructherman force model
18
21
  *
@@ -28,179 +31,162 @@ var SPEED_DIVISOR = 800;
28
31
  * // If you want to assign the positions directly to the nodes, use assign method.
29
32
  * await layout.assign(graph, { center: [100, 100] });
30
33
  */
31
- var FruchtermanLayout = /** @class */ (function () {
32
- function FruchtermanLayout(options) {
33
- if (options === void 0) { options = {}; }
34
+ class FruchtermanLayout {
35
+ constructor(options = {}) {
34
36
  this.options = options;
35
- this.id = "fruchterman";
37
+ this.id = 'fruchterman';
36
38
  this.timeInterval = 0;
37
39
  this.running = false;
38
- this.options = __assign(__assign({}, DEFAULTS_LAYOUT_OPTIONS), options);
40
+ this.options = Object.assign(Object.assign({}, DEFAULTS_LAYOUT_OPTIONS), options);
39
41
  }
40
42
  /**
41
43
  * Return the positions of nodes and edges(if needed).
42
44
  */
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
- });
45
+ execute(graph, options) {
46
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
47
+ return this.genericFruchtermanLayout(false, graph, options);
48
48
  });
49
- };
49
+ }
50
50
  /**
51
51
  * To directly assign the positions to the nodes.
52
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
- });
53
+ assign(graph, options) {
54
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
55
+ this.genericFruchtermanLayout(true, graph, options);
59
56
  });
60
- };
57
+ }
61
58
  /**
62
59
  * Stop simulation immediately.
63
60
  */
64
- FruchtermanLayout.prototype.stop = function () {
65
- if (this.timeInterval && typeof window !== "undefined") {
61
+ stop() {
62
+ if (this.timeInterval && typeof window !== 'undefined') {
66
63
  window.clearInterval(this.timeInterval);
67
64
  }
68
65
  this.running = false;
69
- };
66
+ }
70
67
  /**
71
68
  * Manually steps the simulation by the specified number of iterations.
72
69
  * @see https://github.com/d3/d3-force#simulation_tick
73
70
  */
74
- FruchtermanLayout.prototype.tick = function (iterations) {
75
- var _this = this;
76
- if (iterations === void 0) { iterations = this.options.maxIteration || 1; }
71
+ tick(iterations = this.options.maxIteration || 1) {
77
72
  if (this.lastResult) {
78
73
  return this.lastResult;
79
74
  }
80
- for (var i = 0; i < iterations; i++) {
75
+ for (let i = 0; i < iterations; i++) {
81
76
  this.runOneStep(this.lastGraph, this.lastClusterMap, this.lastOptions);
82
77
  }
83
- var result = {
78
+ const result = {
84
79
  nodes: this.lastLayoutNodes,
85
80
  edges: this.lastLayoutEdges,
86
81
  };
87
82
  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
- });
83
+ result.nodes.forEach((node) => this.lastGraph.mergeNodeData(node.id, {
84
+ x: node.data.x,
85
+ y: node.data.y,
86
+ z: this.options.dimensions === 3 ? node.data.z : undefined,
87
+ }));
95
88
  }
96
89
  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];
90
+ }
91
+ genericFruchtermanLayout(assign, graph, options) {
92
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
93
+ if (this.running)
94
+ return;
95
+ const formattedOptions = this.formatOptions(options);
96
+ const { dimensions, width, height, center, clustering, nodeClusterBy, maxIteration, onTick, } = formattedOptions;
97
+ const nodes = graph.getAllNodes();
98
+ const edges = graph.getAllEdges();
99
+ if (!(nodes === null || nodes === void 0 ? void 0 : nodes.length)) {
100
+ const result = { nodes: [], edges };
101
+ this.lastResult = result;
102
+ return result;
103
+ }
104
+ if (nodes.length === 1) {
105
+ if (assign) {
106
+ graph.mergeNodeData(nodes[0].id, {
107
+ x: center[0],
108
+ y: center[1],
109
+ z: dimensions === 3 ? center[2] : undefined,
110
+ });
113
111
  }
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
- });
112
+ const result = {
113
+ nodes: [
114
+ Object.assign(Object.assign({}, nodes[0]), { data: Object.assign(Object.assign({}, nodes[0].data), { x: center[0], y: center[1], z: dimensions === 3 ? center[2] : undefined }) }),
115
+ ],
116
+ edges,
117
+ };
118
+ this.lastResult = result;
119
+ return result;
120
+ }
121
+ const layoutNodes = nodes.map((node) => (0, util_2.cloneFormatData)(node, [width, height]));
122
+ const calcGraph = new graphlib_1.Graph({
123
+ nodes: layoutNodes,
124
+ edges,
125
+ });
126
+ // clustering info
127
+ const clusterMap = {};
128
+ if (clustering) {
129
+ layoutNodes.forEach((node) => {
130
+ const clusterValue = node.data[nodeClusterBy];
131
+ if (!clusterMap[clusterValue]) {
132
+ clusterMap[clusterValue] = {
133
+ name: clusterValue,
134
+ cx: 0,
135
+ cy: 0,
136
+ count: 0,
137
+ };
121
138
  }
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
139
  });
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
- }
140
+ }
141
+ // Use them later in `tick`.
142
+ this.lastLayoutNodes = layoutNodes;
143
+ this.lastLayoutEdges = edges;
144
+ this.lastAssign = assign;
145
+ this.lastGraph = calcGraph;
146
+ this.lastOptions = formattedOptions;
147
+ this.lastClusterMap = clusterMap;
148
+ if (typeof window === 'undefined')
149
+ return;
150
+ let iter = 0;
151
+ return new Promise((resolve) => {
152
+ // interval for render the result after each iteration
153
+ this.timeInterval = window.setInterval(() => {
154
+ if (!this.running) {
155
+ resolve({ nodes: layoutNodes, edges });
156
+ return;
157
+ }
158
+ this.runOneStep(calcGraph, clusterMap, formattedOptions);
159
+ if (assign) {
160
+ layoutNodes.forEach(({ id, data }) => graph.mergeNodeData(id, {
161
+ x: data.x,
162
+ y: data.y,
163
+ z: dimensions === 3 ? data.z : undefined,
164
+ }));
165
+ }
166
+ onTick === null || onTick === void 0 ? void 0 : onTick({
167
+ nodes: layoutNodes,
168
+ edges,
148
169
  });
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
- })];
170
+ iter++;
171
+ if (iter >= maxIteration) {
172
+ window.clearInterval(this.timeInterval);
173
+ resolve({ nodes: layoutNodes, edges });
174
+ }
175
+ }, 0);
176
+ this.running = true;
190
177
  });
191
178
  });
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;
179
+ }
180
+ formatOptions(options = {}) {
181
+ const mergedOptions = Object.assign(Object.assign({}, this.options), options);
182
+ const { clustering, nodeClusterBy } = mergedOptions;
183
+ const { center: propsCenter, width: propsWidth, height: propsHeight, } = mergedOptions;
198
184
  mergedOptions.width =
199
- !propsWidth && typeof window !== "undefined"
185
+ !propsWidth && typeof window !== 'undefined'
200
186
  ? window.innerWidth
201
187
  : propsWidth;
202
188
  mergedOptions.height =
203
- !propsHeight && typeof window !== "undefined"
189
+ !propsHeight && typeof window !== 'undefined'
204
190
  ? window.innerHeight
205
191
  : propsHeight;
206
192
  mergedOptions.center = !propsCenter
@@ -208,59 +194,59 @@ var FruchtermanLayout = /** @class */ (function () {
208
194
  : propsCenter;
209
195
  mergedOptions.clustering = clustering && !!nodeClusterBy;
210
196
  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 = {};
197
+ }
198
+ runOneStep(calcGraph, clusterMap, options) {
199
+ const { dimensions, height, width, gravity, center, speed, clustering, nodeClusterBy, clusterGravity: propsClusterGravity, } = options;
200
+ const area = height * width;
201
+ const maxDisplace = Math.sqrt(area) / 10;
202
+ const nodes = calcGraph.getAllNodes();
203
+ const k2 = area / (nodes.length + 1);
204
+ const k = Math.sqrt(k2);
205
+ const displacements = {};
220
206
  this.applyCalculate(calcGraph, displacements, k, k2);
221
207
  // gravity for clusters
222
208
  if (clustering) {
223
209
  // reset the clustering centers
224
- for (var key in clusterMap) {
210
+ for (const key in clusterMap) {
225
211
  clusterMap[key].cx = 0;
226
212
  clusterMap[key].cy = 0;
227
213
  clusterMap[key].count = 0;
228
214
  }
229
215
  // 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)) {
216
+ nodes.forEach((node) => {
217
+ const { data } = node; // node is one of layoutNodes, which is formatted and data field exists
218
+ const c = clusterMap[data[nodeClusterBy]];
219
+ if ((0, util_1.isNumber)(data.x)) {
234
220
  c.cx += data.x;
235
221
  }
236
- if (isNumber(data.y)) {
222
+ if ((0, util_1.isNumber)(data.y)) {
237
223
  c.cy += data.y;
238
224
  }
239
225
  c.count++;
240
226
  });
241
- for (var key in clusterMap) {
227
+ for (const key in clusterMap) {
242
228
  clusterMap[key].cx /= clusterMap[key].count;
243
229
  clusterMap[key].cy /= clusterMap[key].count;
244
230
  }
245
231
  // 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))
232
+ const clusterGravity = (propsClusterGravity || gravity);
233
+ nodes.forEach((node, j) => {
234
+ const { id, data } = node;
235
+ if (!(0, util_1.isNumber)(data.x) || !(0, util_1.isNumber)(data.y))
250
236
  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;
237
+ const c = clusterMap[data[nodeClusterBy]];
238
+ const distLength = Math.sqrt((data.x - c.cx) * (data.x - c.cx) + (data.y - c.cy) * (data.y - c.cy));
239
+ const gravityForce = k * clusterGravity;
254
240
  displacements[id].x -= (gravityForce * (data.x - c.cx)) / distLength;
255
241
  displacements[id].y -= (gravityForce * (data.y - c.cy)) / distLength;
256
242
  });
257
243
  }
258
244
  // gravity
259
- nodes.forEach(function (node, j) {
260
- var id = node.id, data = node.data;
261
- if (!isNumber(data.x) || !isNumber(data.y))
245
+ nodes.forEach((node, j) => {
246
+ const { id, data } = node;
247
+ if (!(0, util_1.isNumber)(data.x) || !(0, util_1.isNumber)(data.y))
262
248
  return;
263
- var gravityForce = 0.01 * k * gravity;
249
+ const gravityForce = 0.01 * k * gravity;
264
250
  displacements[id].x -= gravityForce * (data.x - center[0]);
265
251
  displacements[id].y -= gravityForce * (data.y - center[1]);
266
252
  if (dimensions === 3) {
@@ -268,9 +254,9 @@ var FruchtermanLayout = /** @class */ (function () {
268
254
  }
269
255
  });
270
256
  // move
271
- nodes.forEach(function (node, j) {
272
- var id = node.id, data = node.data;
273
- if (isNumber(data.fx) && isNumber(data.fy)) {
257
+ nodes.forEach((node, j) => {
258
+ const { id, data } = node;
259
+ if ((0, util_1.isNumber)(data.fx) && (0, util_1.isNumber)(data.fy)) {
274
260
  data.x = data.fx;
275
261
  data.y = data.fy;
276
262
  if (dimensions === 3) {
@@ -278,99 +264,97 @@ var FruchtermanLayout = /** @class */ (function () {
278
264
  }
279
265
  return;
280
266
  }
281
- if (!isNumber(data.x) || !isNumber(data.y))
267
+ if (!(0, util_1.isNumber)(data.x) || !(0, util_1.isNumber)(data.y))
282
268
  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));
269
+ const distLength = Math.sqrt(displacements[id].x * displacements[id].x +
270
+ displacements[id].y * displacements[id].y +
271
+ (dimensions === 3 ? displacements[id].z * displacements[id].z : 0));
285
272
  if (distLength > 0) {
286
273
  // && !n.isFixed()
287
- var limitedDist = Math.min(maxDisplace * (speed / SPEED_DIVISOR), distLength);
274
+ const limitedDist = Math.min(maxDisplace * (speed / SPEED_DIVISOR), distLength);
288
275
  calcGraph.mergeNodeData(id, {
289
276
  x: data.x + (displacements[id].x / distLength) * limitedDist,
290
277
  y: data.y + (displacements[id].y / distLength) * limitedDist,
291
- z: dimensions === 3 ? data.z + (displacements[id].z / distLength) * limitedDist : undefined
278
+ z: dimensions === 3
279
+ ? data.z + (displacements[id].z / distLength) * limitedDist
280
+ : undefined,
292
281
  });
293
282
  }
294
283
  });
295
- };
296
- FruchtermanLayout.prototype.applyCalculate = function (calcGraph, displacements, k, k2) {
284
+ }
285
+ applyCalculate(calcGraph, displacements, k, k2) {
297
286
  this.calRepulsive(calcGraph, displacements, k2);
298
287
  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;
288
+ }
289
+ calRepulsive(calcGraph, displacements, k2) {
290
+ const nodes = calcGraph.getAllNodes();
291
+ nodes.forEach(({ data: v, id: vid }, i) => {
305
292
  displacements[vid] = { x: 0, y: 0, z: 0 };
306
- nodes.forEach(function (_a, j) {
307
- var u = _a.data, uid = _a.id;
293
+ nodes.forEach(({ data: u, id: uid }, j) => {
308
294
  if (i <= j ||
309
- !isNumber(v.x) ||
310
- !isNumber(u.x) ||
311
- !isNumber(v.y) ||
312
- !isNumber(u.y)) {
295
+ !(0, util_1.isNumber)(v.x) ||
296
+ !(0, util_1.isNumber)(u.x) ||
297
+ !(0, util_1.isNumber)(v.y) ||
298
+ !(0, util_1.isNumber)(u.y)) {
313
299
  return;
314
300
  }
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;
301
+ let vecX = v.x - u.x;
302
+ let vecY = v.y - u.y;
303
+ let vecZ = this.options.dimensions === 3 ? v.z - u.z : 0;
304
+ let lengthSqr = vecX * vecX + vecY * vecY + vecZ * vecZ;
319
305
  if (lengthSqr === 0) {
320
306
  lengthSqr = 1;
321
307
  vecX = 0.01;
322
308
  vecY = 0.01;
323
309
  vecZ = 0.01;
324
310
  }
325
- var common = k2 / lengthSqr;
326
- var dispX = vecX * common;
327
- var dispY = vecY * common;
328
- var dispZ = vecZ * common;
311
+ const common = k2 / lengthSqr;
312
+ const dispX = vecX * common;
313
+ const dispY = vecY * common;
314
+ const dispZ = vecZ * common;
329
315
  displacements[vid].x += dispX;
330
316
  displacements[vid].y += dispY;
331
317
  displacements[uid].x -= dispX;
332
318
  displacements[uid].y -= dispY;
333
- if (_this.options.dimensions === 3) {
319
+ if (this.options.dimensions === 3) {
334
320
  displacements[vid].z += dispZ;
335
321
  displacements[uid].z -= dispZ;
336
322
  }
337
323
  });
338
324
  });
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;
325
+ }
326
+ calAttractive(calcGraph, displacements, k) {
327
+ const edges = calcGraph.getAllEdges();
328
+ edges.forEach((e) => {
329
+ const { source, target } = e;
345
330
  if (!source || !target || source === target) {
346
331
  return;
347
332
  }
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)) {
333
+ const { data: u } = calcGraph.getNode(source);
334
+ const { data: v } = calcGraph.getNode(target);
335
+ if (!(0, util_1.isNumber)(v.x) ||
336
+ !(0, util_1.isNumber)(u.x) ||
337
+ !(0, util_1.isNumber)(v.y) ||
338
+ !(0, util_1.isNumber)(u.y)) {
354
339
  return;
355
340
  }
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;
341
+ const vecX = v.x - u.x;
342
+ const vecY = v.y - u.y;
343
+ const vecZ = this.options.dimensions === 3 ? v.z - u.z : 0;
344
+ const common = Math.sqrt(vecX * vecX + vecY * vecY + vecZ * vecZ) / k;
345
+ const dispX = vecX * common;
346
+ const dispY = vecY * common;
347
+ const dispZ = vecZ * common;
363
348
  displacements[source].x += dispX;
364
349
  displacements[source].y += dispY;
365
350
  displacements[target].x -= dispX;
366
351
  displacements[target].y -= dispY;
367
- if (_this.options.dimensions === 3) {
352
+ if (this.options.dimensions === 3) {
368
353
  displacements[source].z += dispZ;
369
354
  displacements[target].z -= dispZ;
370
355
  }
371
356
  });
372
- };
373
- return FruchtermanLayout;
374
- }());
375
- export { FruchtermanLayout };
357
+ }
358
+ }
359
+ exports.FruchtermanLayout = FruchtermanLayout;
376
360
  //# sourceMappingURL=fruchterman.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"fruchterman.js","sourceRoot":"","sources":["../src/fruchterman.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"fruchterman.js","sourceRoot":"","sources":["../src/fruchterman.ts"],"names":[],"mappings":"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"}
package/lib/grid.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- import type { Graph, GridLayoutOptions, LayoutMapping, Layout } from "./types";
1
+ import type { Graph, GridLayoutOptions, Layout, LayoutMapping } from './types';
2
2
  /**
3
3
  * Layout arranging the nodes in a grid.
4
4
  *