@antv/layout 0.2.0 → 0.2.3

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 (297) hide show
  1. package/dist/layout.min.js +1 -1
  2. package/dist/layout.min.js.LICENSE.txt +0 -9
  3. package/dist/layout.min.js.map +1 -1
  4. package/es/layout/circular.js.map +1 -1
  5. package/es/layout/comboCombined.js +3 -19
  6. package/es/layout/comboCombined.js.map +1 -1
  7. package/es/layout/concentric.js.map +1 -1
  8. package/es/layout/dagre/graph.d.ts +91 -0
  9. package/es/layout/dagre/graph.js +4 -0
  10. package/es/layout/dagre/graph.js.map +1 -0
  11. package/es/layout/dagre/index.d.ts +3 -4
  12. package/es/layout/dagre/index.js +0 -2
  13. package/es/layout/dagre/index.js.map +1 -1
  14. package/es/layout/dagre/src/acyclic.d.ts +1 -2
  15. package/es/layout/dagre/src/acyclic.js +7 -7
  16. package/es/layout/dagre/src/acyclic.js.map +1 -1
  17. package/es/layout/dagre/src/add-border-segments.d.ts +1 -2
  18. package/es/layout/dagre/src/add-border-segments.js +5 -5
  19. package/es/layout/dagre/src/add-border-segments.js.map +1 -1
  20. package/es/layout/dagre/src/coordinate-system.d.ts +1 -2
  21. package/es/layout/dagre/src/coordinate-system.js +15 -5
  22. package/es/layout/dagre/src/coordinate-system.js.map +1 -1
  23. package/es/layout/dagre/src/data/list.d.ts +9 -5
  24. package/es/layout/dagre/src/data/list.js +25 -27
  25. package/es/layout/dagre/src/data/list.js.map +1 -1
  26. package/es/layout/dagre/src/debug.d.ts +2 -3
  27. package/es/layout/dagre/src/debug.js +3 -5
  28. package/es/layout/dagre/src/debug.js.map +1 -1
  29. package/es/layout/dagre/src/greedy-fas.d.ts +2 -3
  30. package/es/layout/dagre/src/greedy-fas.js +16 -15
  31. package/es/layout/dagre/src/greedy-fas.js.map +1 -1
  32. package/es/layout/dagre/src/layout.d.ts +2 -3
  33. package/es/layout/dagre/src/layout.js +170 -91
  34. package/es/layout/dagre/src/layout.js.map +1 -1
  35. package/es/layout/dagre/src/nesting-graph.d.ts +1 -2
  36. package/es/layout/dagre/src/nesting-graph.js +15 -10
  37. package/es/layout/dagre/src/nesting-graph.js.map +1 -1
  38. package/es/layout/dagre/src/normalize.d.ts +1 -2
  39. package/es/layout/dagre/src/normalize.js +12 -11
  40. package/es/layout/dagre/src/normalize.js.map +1 -1
  41. package/es/layout/dagre/src/order/add-subgraph-constraints.d.ts +1 -2
  42. package/es/layout/dagre/src/order/add-subgraph-constraints.js.map +1 -1
  43. package/es/layout/dagre/src/order/barycenter.d.ts +1 -2
  44. package/es/layout/dagre/src/order/barycenter.js.map +1 -1
  45. package/es/layout/dagre/src/order/build-layer-graph.d.ts +2 -3
  46. package/es/layout/dagre/src/order/build-layer-graph.js +12 -8
  47. package/es/layout/dagre/src/order/build-layer-graph.js.map +1 -1
  48. package/es/layout/dagre/src/order/cross-count.d.ts +2 -3
  49. package/es/layout/dagre/src/order/cross-count.js +13 -12
  50. package/es/layout/dagre/src/order/cross-count.js.map +1 -1
  51. package/es/layout/dagre/src/order/index.d.ts +2 -3
  52. package/es/layout/dagre/src/order/index.js +17 -15
  53. package/es/layout/dagre/src/order/index.js.map +1 -1
  54. package/es/layout/dagre/src/order/init-data-order.d.ts +1 -2
  55. package/es/layout/dagre/src/order/init-data-order.js +3 -5
  56. package/es/layout/dagre/src/order/init-data-order.js.map +1 -1
  57. package/es/layout/dagre/src/order/init-order.d.ts +2 -3
  58. package/es/layout/dagre/src/order/init-order.js +1 -2
  59. package/es/layout/dagre/src/order/init-order.js.map +1 -1
  60. package/es/layout/dagre/src/order/resolve-conflicts.d.ts +18 -3
  61. package/es/layout/dagre/src/order/resolve-conflicts.js +9 -29
  62. package/es/layout/dagre/src/order/resolve-conflicts.js.map +1 -1
  63. package/es/layout/dagre/src/order/sort-subgraph.d.ts +6 -3
  64. package/es/layout/dagre/src/order/sort-subgraph.js +19 -14
  65. package/es/layout/dagre/src/order/sort-subgraph.js.map +1 -1
  66. package/es/layout/dagre/src/order/sort.d.ts +6 -1
  67. package/es/layout/dagre/src/order/sort.js +2 -2
  68. package/es/layout/dagre/src/order/sort.js.map +1 -1
  69. package/es/layout/dagre/src/parent-dummy-chains.d.ts +1 -2
  70. package/es/layout/dagre/src/parent-dummy-chains.js +47 -44
  71. package/es/layout/dagre/src/parent-dummy-chains.js.map +1 -1
  72. package/es/layout/dagre/src/position/bk.d.ts +22 -31
  73. package/es/layout/dagre/src/position/bk.js +49 -83
  74. package/es/layout/dagre/src/position/bk.js.map +1 -1
  75. package/es/layout/dagre/src/position/index.d.ts +1 -2
  76. package/es/layout/dagre/src/position/index.js +12 -14
  77. package/es/layout/dagre/src/position/index.js.map +1 -1
  78. package/es/layout/dagre/src/rank/feasible-tree.d.ts +5 -6
  79. package/es/layout/dagre/src/rank/feasible-tree.js +1 -2
  80. package/es/layout/dagre/src/rank/feasible-tree.js.map +1 -1
  81. package/es/layout/dagre/src/rank/index.d.ts +2 -3
  82. package/es/layout/dagre/src/rank/index.js.map +1 -1
  83. package/es/layout/dagre/src/rank/network-simplex.d.ts +8 -11
  84. package/es/layout/dagre/src/rank/network-simplex.js +18 -31
  85. package/es/layout/dagre/src/rank/network-simplex.js.map +1 -1
  86. package/es/layout/dagre/src/rank/util.d.ts +4 -5
  87. package/es/layout/dagre/src/rank/util.js +37 -20
  88. package/es/layout/dagre/src/rank/util.js.map +1 -1
  89. package/es/layout/dagre/src/util.d.ts +29 -48
  90. package/es/layout/dagre/src/util.js +91 -101
  91. package/es/layout/dagre/src/util.js.map +1 -1
  92. package/es/layout/dagre.d.ts +1 -1
  93. package/es/layout/dagre.js +28 -24
  94. package/es/layout/dagre.js.map +1 -1
  95. package/es/layout/fruchterman.js.map +1 -1
  96. package/es/layout/gForce.js +14 -6
  97. package/es/layout/gForce.js.map +1 -1
  98. package/lib/index.js +5 -1
  99. package/lib/index.js.map +1 -1
  100. package/lib/layout/circular.js.map +1 -1
  101. package/lib/layout/comboCombined.js +2 -18
  102. package/lib/layout/comboCombined.js.map +1 -1
  103. package/lib/layout/comboForce.js +5 -5
  104. package/lib/layout/comboForce.js.map +1 -1
  105. package/lib/layout/concentric.js.map +1 -1
  106. package/lib/layout/dagre/graph.d.ts +91 -0
  107. package/lib/layout/dagre/graph.js +28 -0
  108. package/lib/layout/dagre/graph.js.map +1 -0
  109. package/lib/layout/dagre/index.d.ts +3 -4
  110. package/lib/layout/dagre/index.js +0 -2
  111. package/lib/layout/dagre/index.js.map +1 -1
  112. package/lib/layout/dagre/src/acyclic.d.ts +1 -2
  113. package/lib/layout/dagre/src/acyclic.js +7 -7
  114. package/lib/layout/dagre/src/acyclic.js.map +1 -1
  115. package/lib/layout/dagre/src/add-border-segments.d.ts +1 -2
  116. package/lib/layout/dagre/src/add-border-segments.js +5 -8
  117. package/lib/layout/dagre/src/add-border-segments.js.map +1 -1
  118. package/lib/layout/dagre/src/coordinate-system.d.ts +1 -2
  119. package/lib/layout/dagre/src/coordinate-system.js +15 -5
  120. package/lib/layout/dagre/src/coordinate-system.js.map +1 -1
  121. package/lib/layout/dagre/src/data/list.d.ts +9 -5
  122. package/lib/layout/dagre/src/data/list.js +25 -26
  123. package/lib/layout/dagre/src/data/list.js.map +1 -1
  124. package/lib/layout/dagre/src/debug.d.ts +2 -3
  125. package/lib/layout/dagre/src/debug.js +6 -11
  126. package/lib/layout/dagre/src/debug.js.map +1 -1
  127. package/lib/layout/dagre/src/greedy-fas.d.ts +2 -3
  128. package/lib/layout/dagre/src/greedy-fas.js +41 -15
  129. package/lib/layout/dagre/src/greedy-fas.js.map +1 -1
  130. package/lib/layout/dagre/src/layout.d.ts +2 -3
  131. package/lib/layout/dagre/src/layout.js +171 -100
  132. package/lib/layout/dagre/src/layout.js.map +1 -1
  133. package/lib/layout/dagre/src/nesting-graph.d.ts +1 -2
  134. package/lib/layout/dagre/src/nesting-graph.js +15 -13
  135. package/lib/layout/dagre/src/nesting-graph.js.map +1 -1
  136. package/lib/layout/dagre/src/normalize.d.ts +1 -2
  137. package/lib/layout/dagre/src/normalize.js +12 -14
  138. package/lib/layout/dagre/src/normalize.js.map +1 -1
  139. package/lib/layout/dagre/src/order/add-subgraph-constraints.d.ts +1 -2
  140. package/lib/layout/dagre/src/order/add-subgraph-constraints.js.map +1 -1
  141. package/lib/layout/dagre/src/order/barycenter.d.ts +1 -2
  142. package/lib/layout/dagre/src/order/barycenter.js.map +1 -1
  143. package/lib/layout/dagre/src/order/build-layer-graph.d.ts +2 -3
  144. package/lib/layout/dagre/src/order/build-layer-graph.js +13 -12
  145. package/lib/layout/dagre/src/order/build-layer-graph.js.map +1 -1
  146. package/lib/layout/dagre/src/order/cross-count.d.ts +2 -3
  147. package/lib/layout/dagre/src/order/cross-count.js +14 -13
  148. package/lib/layout/dagre/src/order/cross-count.js.map +1 -1
  149. package/lib/layout/dagre/src/order/index.d.ts +2 -3
  150. package/lib/layout/dagre/src/order/index.js +15 -13
  151. package/lib/layout/dagre/src/order/index.js.map +1 -1
  152. package/lib/layout/dagre/src/order/init-data-order.d.ts +1 -2
  153. package/lib/layout/dagre/src/order/init-data-order.js +3 -5
  154. package/lib/layout/dagre/src/order/init-data-order.js.map +1 -1
  155. package/lib/layout/dagre/src/order/init-order.d.ts +2 -3
  156. package/lib/layout/dagre/src/order/init-order.js +1 -2
  157. package/lib/layout/dagre/src/order/init-order.js.map +1 -1
  158. package/lib/layout/dagre/src/order/resolve-conflicts.d.ts +18 -3
  159. package/lib/layout/dagre/src/order/resolve-conflicts.js +9 -29
  160. package/lib/layout/dagre/src/order/resolve-conflicts.js.map +1 -1
  161. package/lib/layout/dagre/src/order/sort-subgraph.d.ts +6 -3
  162. package/lib/layout/dagre/src/order/sort-subgraph.js +16 -11
  163. package/lib/layout/dagre/src/order/sort-subgraph.js.map +1 -1
  164. package/lib/layout/dagre/src/order/sort.d.ts +6 -1
  165. package/lib/layout/dagre/src/order/sort.js +2 -5
  166. package/lib/layout/dagre/src/order/sort.js.map +1 -1
  167. package/lib/layout/dagre/src/parent-dummy-chains.d.ts +1 -2
  168. package/lib/layout/dagre/src/parent-dummy-chains.js +47 -44
  169. package/lib/layout/dagre/src/parent-dummy-chains.js.map +1 -1
  170. package/lib/layout/dagre/src/position/bk.d.ts +22 -31
  171. package/lib/layout/dagre/src/position/bk.js +75 -85
  172. package/lib/layout/dagre/src/position/bk.js.map +1 -1
  173. package/lib/layout/dagre/src/position/index.d.ts +1 -2
  174. package/lib/layout/dagre/src/position/index.js +14 -17
  175. package/lib/layout/dagre/src/position/index.js.map +1 -1
  176. package/lib/layout/dagre/src/rank/feasible-tree.d.ts +5 -6
  177. package/lib/layout/dagre/src/rank/feasible-tree.js +3 -7
  178. package/lib/layout/dagre/src/rank/feasible-tree.js.map +1 -1
  179. package/lib/layout/dagre/src/rank/index.d.ts +2 -3
  180. package/lib/layout/dagre/src/rank/index.js.map +1 -1
  181. package/lib/layout/dagre/src/rank/network-simplex.d.ts +8 -11
  182. package/lib/layout/dagre/src/rank/network-simplex.js +27 -35
  183. package/lib/layout/dagre/src/rank/network-simplex.js.map +1 -1
  184. package/lib/layout/dagre/src/rank/util.d.ts +4 -5
  185. package/lib/layout/dagre/src/rank/util.js +36 -19
  186. package/lib/layout/dagre/src/rank/util.js.map +1 -1
  187. package/lib/layout/dagre/src/util.d.ts +29 -48
  188. package/lib/layout/dagre/src/util.js +80 -92
  189. package/lib/layout/dagre/src/util.js.map +1 -1
  190. package/lib/layout/dagre.d.ts +1 -1
  191. package/lib/layout/dagre.js +27 -23
  192. package/lib/layout/dagre.js.map +1 -1
  193. package/lib/layout/er/core.js +5 -1
  194. package/lib/layout/er/core.js.map +1 -1
  195. package/lib/layout/force/force-in-a-box.js +7 -3
  196. package/lib/layout/force/force-in-a-box.js.map +1 -1
  197. package/lib/layout/force/force.js +5 -1
  198. package/lib/layout/force/force.js.map +1 -1
  199. package/lib/layout/force/index.js +5 -1
  200. package/lib/layout/force/index.js.map +1 -1
  201. package/lib/layout/fruchterman.js.map +1 -1
  202. package/lib/layout/gForce.js +10 -2
  203. package/lib/layout/gForce.js.map +1 -1
  204. package/lib/layout/grid.js +2 -2
  205. package/lib/layout/grid.js.map +1 -1
  206. package/lib/layout/index.js +5 -1
  207. package/lib/layout/index.js.map +1 -1
  208. package/lib/layout/radial/index.js +5 -1
  209. package/lib/layout/radial/index.js.map +1 -1
  210. package/lib/registy/index.js +1 -1
  211. package/lib/registy/index.js.map +1 -1
  212. package/lib/util/index.js +5 -1
  213. package/lib/util/index.js.map +1 -1
  214. package/package.json +3 -2
  215. package/src/index.ts +7 -0
  216. package/src/layout/base.ts +54 -0
  217. package/src/layout/circular.ts +369 -0
  218. package/src/layout/comboCombined.ts +390 -0
  219. package/src/layout/comboForce.ts +873 -0
  220. package/src/layout/concentric.ts +289 -0
  221. package/src/layout/constants.ts +21 -0
  222. package/src/layout/dagre/graph.ts +104 -0
  223. package/src/layout/dagre/index.ts +31 -0
  224. package/src/layout/dagre/src/acyclic.ts +58 -0
  225. package/src/layout/dagre/src/add-border-segments.ts +47 -0
  226. package/src/layout/dagre/src/coordinate-system.ts +77 -0
  227. package/src/layout/dagre/src/data/list.ts +60 -0
  228. package/src/layout/dagre/src/debug.ts +30 -0
  229. package/src/layout/dagre/src/greedy-fas.ts +144 -0
  230. package/src/layout/dagre/src/layout.ts +580 -0
  231. package/src/layout/dagre/src/nesting-graph.ts +143 -0
  232. package/src/layout/dagre/src/normalize.ts +96 -0
  233. package/src/layout/dagre/src/order/add-subgraph-constraints.ts +29 -0
  234. package/src/layout/dagre/src/order/barycenter.ts +26 -0
  235. package/src/layout/dagre/src/order/build-layer-graph.ts +82 -0
  236. package/src/layout/dagre/src/order/cross-count.ts +77 -0
  237. package/src/layout/dagre/src/order/index.ts +105 -0
  238. package/src/layout/dagre/src/order/init-data-order.ts +27 -0
  239. package/src/layout/dagre/src/order/init-order.ts +56 -0
  240. package/src/layout/dagre/src/order/resolve-conflicts.ts +152 -0
  241. package/src/layout/dagre/src/order/sort-subgraph.ts +105 -0
  242. package/src/layout/dagre/src/order/sort.ts +76 -0
  243. package/src/layout/dagre/src/parent-dummy-chains.ts +102 -0
  244. package/src/layout/dagre/src/position/bk.ts +494 -0
  245. package/src/layout/dagre/src/position/index.ts +82 -0
  246. package/src/layout/dagre/src/rank/feasible-tree.ts +165 -0
  247. package/src/layout/dagre/src/rank/index.ts +54 -0
  248. package/src/layout/dagre/src/rank/network-simplex.ts +225 -0
  249. package/src/layout/dagre/src/rank/util.ts +157 -0
  250. package/src/layout/dagre/src/util.ts +308 -0
  251. package/src/layout/dagre.ts +423 -0
  252. package/src/layout/dagreCompound.ts +518 -0
  253. package/src/layout/er/core.ts +117 -0
  254. package/src/layout/er/forceGrid.ts +95 -0
  255. package/src/layout/er/grid.ts +185 -0
  256. package/src/layout/er/index.ts +68 -0
  257. package/src/layout/er/mysqlWorkbench.ts +345 -0
  258. package/src/layout/er/type.ts +39 -0
  259. package/src/layout/force/force-in-a-box.ts +400 -0
  260. package/src/layout/force/force.ts +391 -0
  261. package/src/layout/force/index.ts +1 -0
  262. package/src/layout/forceAtlas2/body.ts +115 -0
  263. package/src/layout/forceAtlas2/index.ts +556 -0
  264. package/src/layout/forceAtlas2/quad.ts +115 -0
  265. package/src/layout/forceAtlas2/quadTree.ts +107 -0
  266. package/src/layout/fruchterman.ts +361 -0
  267. package/src/layout/gForce.ts +487 -0
  268. package/src/layout/gpu/fruchterman.ts +314 -0
  269. package/src/layout/gpu/fruchtermanShader.ts +204 -0
  270. package/src/layout/gpu/gForce.ts +406 -0
  271. package/src/layout/gpu/gForceShader.ts +221 -0
  272. package/src/layout/grid.ts +391 -0
  273. package/src/layout/index.ts +45 -0
  274. package/src/layout/layout.ts +75 -0
  275. package/src/layout/mds.ts +140 -0
  276. package/src/layout/radial/index.ts +1 -0
  277. package/src/layout/radial/mds.ts +51 -0
  278. package/src/layout/radial/radial.ts +500 -0
  279. package/src/layout/radial/radialNonoverlapForce.ts +189 -0
  280. package/src/layout/random.ts +75 -0
  281. package/src/layout/types.ts +421 -0
  282. package/src/registy/index.ts +43 -0
  283. package/src/util/array.ts +1 -0
  284. package/src/util/function.ts +64 -0
  285. package/src/util/gpu.ts +254 -0
  286. package/src/util/index.ts +6 -0
  287. package/src/util/math.ts +158 -0
  288. package/src/util/number.ts +8 -0
  289. package/src/util/object.ts +28 -0
  290. package/src/util/string.ts +18 -0
  291. package/CHANGELOG.md +0 -78
  292. package/es/layout/dagre/src/graphlib.d.ts +0 -2
  293. package/es/layout/dagre/src/graphlib.js +0 -51
  294. package/es/layout/dagre/src/graphlib.js.map +0 -1
  295. package/lib/layout/dagre/src/graphlib.d.ts +0 -2
  296. package/lib/layout/dagre/src/graphlib.js +0 -56
  297. package/lib/layout/dagre/src/graphlib.js.map +0 -1
@@ -0,0 +1,105 @@
1
+ import { Graph } from "../../graph";
2
+ import barycenter from "./barycenter";
3
+ import resolveConflicts, { ConflictEntry } from "./resolve-conflicts";
4
+ import sort from "./sort";
5
+
6
+ const sortSubgraph = (
7
+ g: Graph,
8
+ v: string,
9
+ cg: Graph,
10
+ biasRight?: boolean,
11
+ usePrev?: boolean
12
+ ) => {
13
+ let movable = g.children(v);
14
+ // fixorder的点不参与排序(这个方案不合适,只排了新增节点,和原来的分离)
15
+ const node = g.node(v)!;
16
+ const bl = node ? node.borderLeft : undefined;
17
+ const br = node ? node.borderRight : undefined;
18
+ const subgraphs: Record<string, Partial<ConflictEntry>> = {};
19
+
20
+ if (bl) {
21
+ movable = movable?.filter((w) => {
22
+ return w !== bl && w !== br;
23
+ });
24
+ }
25
+
26
+ const barycenters = barycenter(g, movable || []);
27
+ barycenters?.forEach((entry) => {
28
+ if (g.children(entry.v)?.length) {
29
+ const subgraphResult = sortSubgraph(g, entry.v, cg, biasRight);
30
+ subgraphs[entry.v] = subgraphResult;
31
+ if (subgraphResult.hasOwnProperty("barycenter")) {
32
+ mergeBarycenters(entry, subgraphResult);
33
+ }
34
+ }
35
+ });
36
+
37
+ const entries = resolveConflicts(barycenters, cg);
38
+ expandSubgraphs(entries, subgraphs);
39
+
40
+ // 添加fixorder信息到entries里边
41
+ // TODO: 不考虑复合情况,只用第一个点的fixorder信息,后续考虑更完备的实现
42
+ entries
43
+ .filter((e) => e.vs.length > 0)
44
+ ?.forEach((e) => {
45
+ const node = g.node(e.vs[0])!;
46
+ if (node) {
47
+ e.fixorder = node.fixorder;
48
+ e.order = node.order;
49
+ }
50
+ });
51
+
52
+ const result = sort(entries, biasRight, usePrev);
53
+
54
+ if (bl) {
55
+ result.vs = [bl, result.vs, br].flat();
56
+ if (g.predecessors(bl)?.length) {
57
+ const blPred = g.node(g.predecessors(bl)?.[0] || "")!;
58
+ const brPred = g.node(g.predecessors(br)?.[0] || "")!;
59
+ if (!result.hasOwnProperty("barycenter")) {
60
+ result.barycenter = 0;
61
+ result.weight = 0;
62
+ }
63
+ result.barycenter =
64
+ (result.barycenter! * result.weight! +
65
+ (blPred.order as number) +
66
+ (brPred.order as number)) /
67
+ (result.weight! + 2);
68
+ result.weight! += 2;
69
+ }
70
+ }
71
+
72
+ return result;
73
+ };
74
+
75
+ const expandSubgraphs = (
76
+ entries: ConflictEntry[],
77
+ subgraphs: Record<string, Partial<ConflictEntry>>
78
+ ) => {
79
+ entries?.forEach((entry) => {
80
+ const vss = entry.vs?.map((v: string) => {
81
+ if (subgraphs[v]) {
82
+ return subgraphs[v].vs!;
83
+ }
84
+ return v;
85
+ });
86
+ entry.vs = vss.flat();
87
+ });
88
+ };
89
+
90
+ const mergeBarycenters = (
91
+ target: { weight?: number; barycenter?: number },
92
+ other: { weight?: number; barycenter?: number }
93
+ ) => {
94
+ if (target.barycenter !== undefined) {
95
+ target.barycenter =
96
+ (target.barycenter * target.weight! + other.barycenter! * other.weight!) /
97
+ (target.weight! + other.weight!);
98
+ target.weight! += other.weight!;
99
+ } else {
100
+ target.barycenter = other.barycenter;
101
+ target.weight = other.weight;
102
+ }
103
+ };
104
+
105
+ export default sortSubgraph;
@@ -0,0 +1,76 @@
1
+ import { partition } from "../util";
2
+ import { ConflictEntry } from "./resolve-conflicts";
3
+
4
+ const sort = (entries: ConflictEntry[], biasRight?: boolean, usePrev?: boolean) => {
5
+ const parts = partition(entries, (entry) => {
6
+ // NOTE: 有fixorder的也可以排
7
+ return (entry.hasOwnProperty("fixorder") && !isNaN(entry.fixorder!)) || entry.hasOwnProperty("barycenter");
8
+ });
9
+ const sortable = parts.lhs;
10
+ const unsortable = parts.rhs.sort((a, b) => -a.i - (-b.i));
11
+ const vs: string[][] = [];
12
+ let sum = 0;
13
+ let weight = 0;
14
+ let vsIndex = 0;
15
+
16
+ sortable?.sort(compareWithBias(!!biasRight, !!usePrev));
17
+
18
+ vsIndex = consumeUnsortable(vs, unsortable, vsIndex);
19
+
20
+ sortable?.forEach((entry) => {
21
+ vsIndex += entry.vs?.length;
22
+ vs.push(entry.vs);
23
+ sum += entry.barycenter! * entry.weight!;
24
+ weight += entry.weight!;
25
+ vsIndex = consumeUnsortable(vs, unsortable, vsIndex);
26
+ });
27
+
28
+ const result: { vs: string[], barycenter?: number, weight?: number } = { vs: vs.flat() };
29
+ if (weight) {
30
+ result.barycenter = sum / weight;
31
+ result.weight = weight;
32
+ }
33
+ return result;
34
+ };
35
+
36
+ const consumeUnsortable = (vs: string[][], unsortable: ConflictEntry[], index: number) => {
37
+ let iindex = index;
38
+ let last;
39
+ while (unsortable.length && (last = unsortable[unsortable.length - 1]).i <= iindex) {
40
+ unsortable.pop();
41
+ vs?.push(last.vs);
42
+ iindex++;
43
+ }
44
+ return iindex;
45
+ };
46
+
47
+ /**
48
+ * 配置是否考虑使用之前的布局结果
49
+ */
50
+ const compareWithBias = (bias: boolean, usePrev: boolean) => {
51
+ return (entryV: ConflictEntry, entryW: ConflictEntry) => {
52
+ // 排序的时候先判断fixorder,不行再判断重心
53
+ if (entryV.fixorder !== undefined && entryW.fixorder !== undefined) {
54
+ return entryV.fixorder - entryW.fixorder;
55
+ }
56
+ if (entryV.barycenter! < entryW.barycenter!) {
57
+ return -1;
58
+ }
59
+ if (entryV.barycenter! > entryW.barycenter!) {
60
+ return 1;
61
+ }
62
+ // 重心相同,考虑之前排好的顺序
63
+ if (usePrev && entryV.order !== undefined && entryW.order !== undefined) {
64
+ if (entryV.order < entryW.order) {
65
+ return -1;
66
+ }
67
+ if (entryV.order > entryW.order) {
68
+ return 1;
69
+ }
70
+ }
71
+
72
+ return !bias ? entryV.i - entryW.i : entryW.i - entryV.i;
73
+ };
74
+ };
75
+
76
+ export default sort;
@@ -0,0 +1,102 @@
1
+ import { Graph } from "../graph";
2
+
3
+ type OrderItem = { low: number; lim: number };
4
+
5
+ // deep first search with both order low for pre, lim for post
6
+ const dfsBothOrder = (g: Graph) => {
7
+ const result: Record<string, OrderItem> = {};
8
+ let lim = 0;
9
+
10
+ const dfs = (v: string) => {
11
+ const low = lim;
12
+ g.children(v)?.forEach(dfs);
13
+ result[v] = { low, lim: lim++ };
14
+ };
15
+ g.children()?.forEach(dfs);
16
+
17
+ return result;
18
+ };
19
+
20
+ // Find a path from v to w through the lowest common ancestor (LCA). Return the
21
+ // full path and the LCA.
22
+ const findPath = (
23
+ g: Graph,
24
+ postorderNums: Record<string, OrderItem>,
25
+ v: string,
26
+ w: string
27
+ ) => {
28
+ const vPath = [];
29
+ const wPath = [];
30
+ const low = Math.min(postorderNums[v].low, postorderNums[w].low);
31
+ const lim = Math.max(postorderNums[v].lim, postorderNums[w].lim);
32
+ let parent: string | undefined;
33
+ let lca: string | undefined;
34
+
35
+ // Traverse up from v to find the LCA
36
+ parent = v;
37
+ do {
38
+ parent = g.parent(parent);
39
+ vPath.push(parent);
40
+ } while (
41
+ parent &&
42
+ (postorderNums[parent].low > low || lim > postorderNums[parent].lim)
43
+ );
44
+ lca = parent;
45
+
46
+ // Traverse from w to LCA
47
+ parent = w;
48
+ while (parent && parent !== lca) {
49
+ wPath.push(parent);
50
+ parent = g.parent(parent);
51
+ }
52
+
53
+ return { lca, path: vPath.concat(wPath.reverse()) };
54
+ };
55
+
56
+ const parentDummyChains = (g: Graph) => {
57
+ const postorderNums = dfsBothOrder(g);
58
+
59
+ g.graph().dummyChains?.forEach((startV) => {
60
+ let v = startV;
61
+ let node = g.node(v)!;
62
+ const edgeObj = node.edgeObj;
63
+ if (!edgeObj) return;
64
+ const pathData = findPath(g, postorderNums, edgeObj.v, edgeObj.w);
65
+ const path = pathData.path;
66
+ const lca = pathData.lca;
67
+ let pathIdx = 0;
68
+ let pathV = path[pathIdx]!;
69
+ let ascending = true;
70
+
71
+ while (v !== edgeObj.w) {
72
+ node = g.node(v)!;
73
+
74
+ if (ascending) {
75
+ while (pathV !== lca && g.node(pathV)?.maxRank! < node.rank!) {
76
+ pathIdx++;
77
+ pathV = path[pathIdx]!;
78
+ }
79
+
80
+ if (pathV === lca) {
81
+ ascending = false;
82
+ }
83
+ }
84
+
85
+ if (!ascending) {
86
+ while (
87
+ pathIdx < path.length - 1 &&
88
+ (g.node(path[pathIdx + 1]!)?.minRank as number) <=
89
+ (node.rank as number)
90
+ ) {
91
+ pathIdx++;
92
+ }
93
+ pathV = path[pathIdx]!;
94
+ }
95
+
96
+ g.setParent(v, pathV);
97
+ v = g.successors(v)![0];
98
+ }
99
+ });
100
+ };
101
+
102
+ export default parentDummyChains;