@deck.gl-community/graph-layers 9.2.0-beta.2 → 9.2.0-beta.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 (232) hide show
  1. package/dist/core/graph-engine.d.ts +63 -21
  2. package/dist/core/graph-engine.d.ts.map +1 -1
  3. package/dist/core/graph-engine.js +155 -75
  4. package/dist/core/graph-engine.js.map +1 -1
  5. package/dist/core/graph-layout.d.ts +22 -18
  6. package/dist/core/graph-layout.d.ts.map +1 -1
  7. package/dist/core/graph-layout.js +33 -18
  8. package/dist/core/graph-layout.js.map +1 -1
  9. package/dist/core/interaction-manager.d.ts +2 -2
  10. package/dist/core/interaction-manager.d.ts.map +1 -1
  11. package/dist/core/interaction-manager.js +7 -5
  12. package/dist/core/interaction-manager.js.map +1 -1
  13. package/dist/graph/arrow-graph.d.ts +69 -0
  14. package/dist/graph/arrow-graph.d.ts.map +1 -0
  15. package/dist/graph/arrow-graph.js +513 -0
  16. package/dist/graph/arrow-graph.js.map +1 -0
  17. package/dist/graph/classic-graph.d.ts +169 -0
  18. package/dist/graph/classic-graph.d.ts.map +1 -0
  19. package/dist/graph/classic-graph.js +390 -0
  20. package/dist/graph/classic-graph.js.map +1 -0
  21. package/dist/graph/edge.d.ts +6 -6
  22. package/dist/graph/edge.d.ts.map +1 -1
  23. package/dist/graph/edge.js.map +1 -1
  24. package/dist/graph/functions/arrow-utils.d.ts +6 -0
  25. package/dist/graph/functions/arrow-utils.d.ts.map +1 -0
  26. package/dist/graph/functions/arrow-utils.js +67 -0
  27. package/dist/graph/functions/arrow-utils.js.map +1 -0
  28. package/dist/graph/functions/create-graph-from-data.d.ts +3 -0
  29. package/dist/graph/functions/create-graph-from-data.d.ts.map +1 -0
  30. package/dist/graph/functions/create-graph-from-data.js +12 -0
  31. package/dist/graph/functions/create-graph-from-data.js.map +1 -0
  32. package/dist/graph/graph-normalization.d.ts +10 -0
  33. package/dist/graph/graph-normalization.d.ts.map +1 -0
  34. package/dist/graph/graph-normalization.js +65 -0
  35. package/dist/graph/graph-normalization.js.map +1 -0
  36. package/dist/graph/graph.d.ts +62 -155
  37. package/dist/graph/graph.d.ts.map +1 -1
  38. package/dist/graph/graph.js +11 -300
  39. package/dist/graph/graph.js.map +1 -1
  40. package/dist/graph/node.d.ts +6 -6
  41. package/dist/graph/node.d.ts.map +1 -1
  42. package/dist/graph/node.js +2 -2
  43. package/dist/graph/node.js.map +1 -1
  44. package/dist/graph-data/arrow-graph-data-builder.d.ts +21 -0
  45. package/dist/graph-data/arrow-graph-data-builder.d.ts.map +1 -0
  46. package/dist/graph-data/arrow-graph-data-builder.js +105 -0
  47. package/dist/graph-data/arrow-graph-data-builder.js.map +1 -0
  48. package/dist/graph-data/graph-data-builder.d.ts +6 -0
  49. package/dist/graph-data/graph-data-builder.d.ts.map +1 -0
  50. package/dist/graph-data/graph-data-builder.js +1 -0
  51. package/dist/graph-data/graph-data-builder.js.map +1 -0
  52. package/dist/graph-data/graph-data.d.ts +40 -0
  53. package/dist/graph-data/graph-data.d.ts.map +1 -0
  54. package/dist/graph-data/graph-data.js +11 -0
  55. package/dist/graph-data/graph-data.js.map +1 -0
  56. package/dist/graph-data/plain-graph-data-builder.d.ts +20 -0
  57. package/dist/graph-data/plain-graph-data-builder.d.ts.map +1 -0
  58. package/dist/graph-data/plain-graph-data-builder.js +105 -0
  59. package/dist/graph-data/plain-graph-data-builder.js.map +1 -0
  60. package/dist/graph-style-schema.cdn.js +1 -1
  61. package/dist/graph-style-schema.json +1 -1
  62. package/dist/index.cjs +6905 -4576
  63. package/dist/index.cjs.map +4 -4
  64. package/dist/index.d.ts +14 -7
  65. package/dist/index.d.ts.map +1 -1
  66. package/dist/index.js +24 -11
  67. package/dist/index.js.map +1 -1
  68. package/dist/layers/common-layers/flow-path-layer/flow-path-layer.d.ts.map +1 -1
  69. package/dist/layers/common-layers/flow-path-layer/flow-path-layer.js +1 -2
  70. package/dist/layers/common-layers/flow-path-layer/flow-path-layer.js.map +1 -1
  71. package/dist/layers/common-layers/grid-layer/grid-layer.d.ts +83 -0
  72. package/dist/layers/common-layers/grid-layer/grid-layer.d.ts.map +1 -0
  73. package/dist/layers/common-layers/grid-layer/grid-layer.js +133 -0
  74. package/dist/layers/common-layers/grid-layer/grid-layer.js.map +1 -0
  75. package/dist/layers/edge-attachment-helper.d.ts.map +1 -1
  76. package/dist/layers/edge-attachment-helper.js +1 -2
  77. package/dist/layers/edge-attachment-helper.js.map +1 -1
  78. package/dist/layers/graph-layer.d.ts +68 -11
  79. package/dist/layers/graph-layer.d.ts.map +1 -1
  80. package/dist/layers/graph-layer.js +435 -50
  81. package/dist/layers/graph-layer.js.map +1 -1
  82. package/dist/layouts/d3-dag/collapsable-d3-dag-layout.d.ts +24 -0
  83. package/dist/layouts/d3-dag/collapsable-d3-dag-layout.d.ts.map +1 -0
  84. package/dist/layouts/d3-dag/collapsable-d3-dag-layout.js +251 -0
  85. package/dist/layouts/d3-dag/collapsable-d3-dag-layout.js.map +1 -0
  86. package/dist/layouts/d3-dag/d3-dag-layout.d.ts +46 -61
  87. package/dist/layouts/d3-dag/d3-dag-layout.d.ts.map +1 -1
  88. package/dist/layouts/d3-dag/d3-dag-layout.js +85 -270
  89. package/dist/layouts/d3-dag/d3-dag-layout.js.map +1 -1
  90. package/dist/layouts/d3-force/d3-force-layout.d.ts +20 -8
  91. package/dist/layouts/d3-force/d3-force-layout.d.ts.map +1 -1
  92. package/dist/layouts/d3-force/d3-force-layout.js +39 -20
  93. package/dist/layouts/d3-force/d3-force-layout.js.map +1 -1
  94. package/dist/layouts/experimental/force-multi-graph-layout.d.ts +19 -15
  95. package/dist/layouts/experimental/force-multi-graph-layout.d.ts.map +1 -1
  96. package/dist/layouts/experimental/force-multi-graph-layout.js +47 -38
  97. package/dist/layouts/experimental/force-multi-graph-layout.js.map +1 -1
  98. package/dist/layouts/experimental/hive-plot-layout.d.ts +18 -15
  99. package/dist/layouts/experimental/hive-plot-layout.d.ts.map +1 -1
  100. package/dist/layouts/experimental/hive-plot-layout.js +33 -34
  101. package/dist/layouts/experimental/hive-plot-layout.js.map +1 -1
  102. package/dist/layouts/experimental/radial-layout.d.ts +12 -7
  103. package/dist/layouts/experimental/radial-layout.d.ts.map +1 -1
  104. package/dist/layouts/experimental/radial-layout.js +31 -14
  105. package/dist/layouts/experimental/radial-layout.js.map +1 -1
  106. package/dist/layouts/gpu-force/gpu-force-layout.d.ts +11 -8
  107. package/dist/layouts/gpu-force/gpu-force-layout.d.ts.map +1 -1
  108. package/dist/layouts/gpu-force/gpu-force-layout.js +59 -56
  109. package/dist/layouts/gpu-force/gpu-force-layout.js.map +1 -1
  110. package/dist/layouts/simple-layout.d.ts +8 -25
  111. package/dist/layouts/simple-layout.d.ts.map +1 -1
  112. package/dist/layouts/simple-layout.js +13 -17
  113. package/dist/layouts/simple-layout.js.map +1 -1
  114. package/dist/loaders/dot-graph-loader.d.ts +25 -0
  115. package/dist/loaders/dot-graph-loader.d.ts.map +1 -0
  116. package/dist/loaders/dot-graph-loader.js +668 -0
  117. package/dist/loaders/dot-graph-loader.js.map +1 -0
  118. package/dist/loaders/json-graph-loader.d.ts +6 -0
  119. package/dist/loaders/json-graph-loader.d.ts.map +1 -0
  120. package/dist/loaders/json-graph-loader.js +31 -0
  121. package/dist/loaders/json-graph-loader.js.map +1 -0
  122. package/dist/loaders/{edge-parsers.d.ts → parsers/edge-parsers.d.ts} +1 -1
  123. package/dist/loaders/parsers/edge-parsers.d.ts.map +1 -0
  124. package/dist/loaders/{edge-parsers.js → parsers/edge-parsers.js} +1 -1
  125. package/dist/loaders/parsers/edge-parsers.js.map +1 -0
  126. package/dist/loaders/{node-parsers.d.ts → parsers/node-parsers.d.ts} +1 -1
  127. package/dist/loaders/parsers/node-parsers.d.ts.map +1 -0
  128. package/dist/loaders/{node-parsers.js → parsers/node-parsers.js} +1 -1
  129. package/dist/loaders/parsers/node-parsers.js.map +1 -0
  130. package/dist/loaders/parsers/parse-json-graph.d.ts +29 -0
  131. package/dist/loaders/parsers/parse-json-graph.d.ts.map +1 -0
  132. package/dist/loaders/parsers/parse-json-graph.js +78 -0
  133. package/dist/loaders/parsers/parse-json-graph.js.map +1 -0
  134. package/dist/style/graph-style-engine.d.ts +4 -2
  135. package/dist/style/graph-style-engine.d.ts.map +1 -1
  136. package/dist/style/graph-style-engine.js +3 -2
  137. package/dist/style/graph-style-engine.js.map +1 -1
  138. package/dist/style/{style-engine.d.ts → stylesheet-engine.d.ts} +3 -3
  139. package/dist/style/stylesheet-engine.d.ts.map +1 -0
  140. package/dist/style/{style-engine.js → stylesheet-engine.js} +1 -1
  141. package/dist/style/stylesheet-engine.js.map +1 -0
  142. package/dist/utils/collapsed-chains.d.ts +8 -8
  143. package/dist/utils/collapsed-chains.d.ts.map +1 -1
  144. package/dist/utils/collapsed-chains.js +1 -6
  145. package/dist/utils/collapsed-chains.js.map +1 -1
  146. package/dist/utils/rank-grid.d.ts +30 -0
  147. package/dist/utils/rank-grid.d.ts.map +1 -0
  148. package/dist/utils/rank-grid.js +306 -0
  149. package/dist/utils/rank-grid.js.map +1 -0
  150. package/package.json +4 -8
  151. package/src/_disabled/arrow-graph-data.ts.disabled +18 -0
  152. package/src/_disabled/columnar-graph-data-builder.ts.disabled +250 -0
  153. package/src/_disabled/graph-runtime-layout.ts.disabled +29 -0
  154. package/src/core/graph-engine.ts +201 -84
  155. package/src/core/graph-layout.ts +52 -29
  156. package/src/core/interaction-manager.ts +20 -20
  157. package/src/graph/arrow-graph.ts +648 -0
  158. package/src/graph/classic-graph.ts +447 -0
  159. package/src/graph/edge.ts +7 -7
  160. package/src/graph/functions/arrow-utils.ts +72 -0
  161. package/src/graph/functions/convert-arrow-graph-to-classic-graph.ts.disabled +47 -0
  162. package/src/graph/functions/convert-plain-graph-to-arrow-graph.ts.disabled +119 -0
  163. package/src/graph/functions/create-graph-from-data.ts +16 -0
  164. package/src/graph/functions/create-plain-graph-from-data.ts.disabled +176 -0
  165. package/src/graph/graph-normalization.ts +87 -0
  166. package/src/graph/graph.ts +68 -339
  167. package/src/graph/node.ts +9 -9
  168. package/src/graph/tabular-graph.ts.disabled +761 -0
  169. package/src/graph-data/arrow-graph-data-builder.ts +165 -0
  170. package/src/graph-data/graph-data-builder.ts +7 -0
  171. package/src/graph-data/graph-data.ts +57 -0
  172. package/src/graph-data/plain-graph-data-builder.ts +132 -0
  173. package/src/index.ts +53 -13
  174. package/src/layers/common-layers/flow-path-layer/flow-path-layer.ts +1 -2
  175. package/src/layers/common-layers/grid-layer/grid-layer.ts +237 -0
  176. package/src/layers/edge-attachment-helper.ts +22 -16
  177. package/src/layers/graph-layer.ts +642 -62
  178. package/src/layouts/d3-dag/collapsable-d3-dag-layout.ts +330 -0
  179. package/src/layouts/d3-dag/d3-dag-layout.ts +166 -396
  180. package/src/layouts/d3-force/d3-force-layout.ts +52 -30
  181. package/src/layouts/experimental/force-multi-graph-layout.ts +55 -49
  182. package/src/layouts/experimental/hive-plot-layout.ts +41 -42
  183. package/src/layouts/experimental/radial-layout.ts +39 -20
  184. package/src/layouts/gpu-force/gpu-force-layout.ts +72 -70
  185. package/src/layouts/simple-layout.ts +20 -44
  186. package/src/loaders/{create-graph.ts → deprecated/create-graph.ts.disabled} +6 -6
  187. package/src/loaders/deprecated/json-classic-graph-loader.ts.disabled +33 -0
  188. package/src/loaders/{simple-json-graph-loader.ts → deprecated/simple-json-graph-loader.ts.disabled} +3 -3
  189. package/src/loaders/{table-graph-loader.ts → deprecated/table-graph-loader.ts.disabled} +8 -8
  190. package/src/loaders/dot-graph-loader.ts +860 -0
  191. package/src/loaders/json-graph-loader.ts +48 -0
  192. package/src/loaders/parsers/create-graph-data.ts.disabled +45 -0
  193. package/src/loaders/{edge-parsers.ts → parsers/edge-parsers.ts} +2 -2
  194. package/src/loaders/{node-parsers.ts → parsers/node-parsers.ts} +2 -2
  195. package/src/loaders/parsers/parse-json-graph.ts +134 -0
  196. package/src/style/graph-style-engine.ts +5 -2
  197. package/src/style/{style-engine.ts → stylesheet-engine.ts} +3 -3
  198. package/src/utils/collapsed-chains.ts +11 -17
  199. package/src/utils/rank-grid.ts +426 -0
  200. package/dist/loaders/create-graph.d.ts +0 -12
  201. package/dist/loaders/create-graph.d.ts.map +0 -1
  202. package/dist/loaders/create-graph.js +0 -38
  203. package/dist/loaders/create-graph.js.map +0 -1
  204. package/dist/loaders/edge-parsers.d.ts.map +0 -1
  205. package/dist/loaders/edge-parsers.js.map +0 -1
  206. package/dist/loaders/json-loader.d.ts +0 -7
  207. package/dist/loaders/json-loader.d.ts.map +0 -1
  208. package/dist/loaders/json-loader.js +0 -16
  209. package/dist/loaders/json-loader.js.map +0 -1
  210. package/dist/loaders/node-parsers.d.ts.map +0 -1
  211. package/dist/loaders/node-parsers.js.map +0 -1
  212. package/dist/loaders/simple-json-graph-loader.d.ts +0 -11
  213. package/dist/loaders/simple-json-graph-loader.d.ts.map +0 -1
  214. package/dist/loaders/simple-json-graph-loader.js +0 -20
  215. package/dist/loaders/simple-json-graph-loader.js.map +0 -1
  216. package/dist/loaders/table-graph-loader.d.ts +0 -16
  217. package/dist/loaders/table-graph-loader.d.ts.map +0 -1
  218. package/dist/loaders/table-graph-loader.js +0 -91
  219. package/dist/loaders/table-graph-loader.js.map +0 -1
  220. package/dist/style/style-engine.d.ts.map +0 -1
  221. package/dist/style/style-engine.js.map +0 -1
  222. package/dist/widgets/long-press-button.d.ts +0 -12
  223. package/dist/widgets/long-press-button.d.ts.map +0 -1
  224. package/dist/widgets/long-press-button.js +0 -31
  225. package/dist/widgets/long-press-button.js.map +0 -1
  226. package/dist/widgets/view-control-widget.d.ts +0 -77
  227. package/dist/widgets/view-control-widget.d.ts.map +0 -1
  228. package/dist/widgets/view-control-widget.js +0 -197
  229. package/dist/widgets/view-control-widget.js.map +0 -1
  230. package/src/loaders/json-loader.ts +0 -19
  231. package/src/widgets/long-press-button.tsx +0 -50
  232. package/src/widgets/view-control-widget.tsx +0 -339
@@ -1,28 +1,61 @@
1
1
  import type { Bounds2D } from '@math.gl/types';
2
- import type { Node } from '../graph/node';
3
- import { Edge } from '../graph/edge';
4
- import { Graph } from '../graph/graph';
5
- import { GraphLayout } from './graph-layout';
6
- export type GraphEngineProps = {
2
+ import type { Graph, EdgeInterface, NodeInterface } from '../graph/graph';
3
+ import { ClassicGraph } from '../graph/classic-graph';
4
+ import { GraphLayout, type GraphLayoutEventDetail } from './graph-layout';
5
+ import { GraphStylesheetEngine, type GraphStylesheet } from '../style/graph-style-engine';
6
+ type ClassicGraphEngineProps = {
7
+ graph: ClassicGraph;
8
+ layout: GraphLayout;
9
+ onLayoutStart?: (detail?: GraphLayoutEventDetail) => void;
10
+ onLayoutChange?: (detail?: GraphLayoutEventDetail) => void;
11
+ onLayoutDone?: (detail?: GraphLayoutEventDetail) => void;
12
+ onLayoutError?: (error?: unknown) => void;
13
+ onTransactionStart?: () => void;
14
+ onTransactionEnd?: () => void;
15
+ onNodeAdded?: (node: NodeInterface) => void;
16
+ onNodeRemoved?: (node: NodeInterface) => void;
17
+ onNodeUpdated?: (node: NodeInterface) => void;
18
+ onEdgeAdded?: (edge: EdgeInterface) => void;
19
+ onEdgeRemoved?: (edge: EdgeInterface) => void;
20
+ onEdgeUpdated?: (edge: EdgeInterface) => void;
21
+ };
22
+ type InterfaceGraphEngineProps = {
7
23
  graph: Graph;
8
24
  layout: GraphLayout;
25
+ onLayoutStart?: (detail?: GraphLayoutEventDetail) => void;
26
+ onLayoutChange?: (detail?: GraphLayoutEventDetail) => void;
27
+ onLayoutDone?: (detail?: GraphLayoutEventDetail) => void;
28
+ onLayoutError?: (error?: unknown) => void;
29
+ onTransactionStart?: () => void;
30
+ onTransactionEnd?: () => void;
31
+ onNodeAdded?: (node: NodeInterface) => void;
32
+ onNodeRemoved?: (node: NodeInterface) => void;
33
+ onNodeUpdated?: (node: NodeInterface) => void;
34
+ onEdgeAdded?: (edge: EdgeInterface) => void;
35
+ onEdgeRemoved?: (edge: EdgeInterface) => void;
36
+ onEdgeUpdated?: (edge: EdgeInterface) => void;
9
37
  };
38
+ export type GraphEngineProps = ClassicGraphEngineProps | InterfaceGraphEngineProps;
10
39
  /** Graph engine controls the graph data and layout calculation */
11
- export declare class GraphEngine extends EventTarget {
12
- props: Readonly<Required<GraphEngineProps>>;
40
+ export declare class GraphEngine {
41
+ private _props;
13
42
  private readonly _graph;
14
43
  private readonly _layout;
15
44
  private readonly _cache;
16
45
  private _layoutDirty;
17
46
  private _transactionInProgress;
47
+ private _graphCallbacksAttached;
48
+ private _layoutCallbacksAttached;
18
49
  constructor(props: GraphEngineProps);
19
50
  /** @deprecated Use props constructor: new GraphEngine(props) */
20
- constructor(graph: Graph, layout: GraphLayout);
51
+ constructor(graph: ClassicGraph, layout: GraphLayout);
52
+ get props(): GraphEngineProps;
53
+ setProps(props: Partial<Omit<GraphEngineProps, 'graph' | 'layout'>>): void;
21
54
  /** Getters */
22
- getNodes: () => Node[];
23
- getEdges: () => Edge[];
24
- getNodePosition: (node: Node) => [number, number];
25
- getEdgePosition: (edge: Edge) => {
55
+ getNodes: () => NodeInterface[];
56
+ getEdges: () => EdgeInterface[];
57
+ getNodePosition: (node: NodeInterface) => [number, number];
58
+ getEdgePosition: (edge: EdgeInterface) => {
26
59
  type: string;
27
60
  sourcePosition: number[];
28
61
  targetPosition: number[];
@@ -33,33 +66,42 @@ export declare class GraphEngine extends EventTarget {
33
66
  getLayoutState: () => import("./graph-layout").GraphLayoutState;
34
67
  getLayoutBounds: () => Bounds2D | null;
35
68
  /** Operations on the graph */
36
- lockNodePosition: (node: any, x: any, y: any) => void;
37
- unlockNodePosition: (node: any) => void;
69
+ lockNodePosition: (node: NodeInterface, x: number, y: number) => void;
70
+ unlockNodePosition: (node: NodeInterface) => void;
71
+ findNode(nodeId: string | number): NodeInterface | undefined;
72
+ createStylesheetEngine(style: GraphStylesheet, options?: {
73
+ stateUpdateTrigger?: unknown;
74
+ }): GraphStylesheetEngine;
38
75
  /**
39
76
  * @fires GraphEngine#onLayoutStart
40
77
  */
41
- _onLayoutStart: (event: Event) => void;
78
+ _onLayoutStart: (detail?: GraphLayoutEventDetail) => void;
42
79
  /**
43
80
  * @fires GraphEngine#onLayoutChange
44
81
  */
45
- _onLayoutChange: (event: Event) => void;
82
+ _onLayoutChange: (detail?: GraphLayoutEventDetail) => void;
46
83
  /**
47
84
  * @fires GraphEngine#onLayoutDone
48
85
  */
49
- _onLayoutDone: (event: Event) => void;
86
+ _onLayoutDone: (detail?: GraphLayoutEventDetail) => void;
50
87
  /**
51
88
  * @fires GraphEngine#onLayoutError
52
89
  */
53
- _onLayoutError: (event: Event) => void;
54
- _onGraphStructureChanged: (entity: any) => void;
90
+ _onLayoutError: (error?: unknown) => void;
91
+ _onGraphStructureChanged: () => void;
55
92
  _onTransactionStart: () => void;
56
93
  _onTransactionEnd: () => void;
57
94
  /** Layout calculations */
58
95
  run: () => void;
59
96
  clear: () => void;
60
- resume: () => any;
61
- stop: () => any;
97
+ resume: () => void;
98
+ stop: () => void;
62
99
  _graphChanged: () => void;
63
100
  _updateLayout: () => void;
64
101
  _updateCache(key: any, updateValue: any): void;
102
+ private _attachGraphCallbacks;
103
+ private _detachGraphCallbacks;
104
+ private _attachLayoutCallbacks;
105
+ private _detachLayoutCallbacks;
65
106
  }
107
+ export {};
@@ -1 +1 @@
1
- {"version":3,"file":"graph-engine.d.ts","sourceRoot":"","sources":["../../src/core/graph-engine.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAC,QAAQ,EAAC,MAAM,gBAAgB,CAAC;AAE7C,OAAO,KAAK,EAAC,IAAI,EAAC,yBAAsB;AACxC,OAAO,EAAC,IAAI,EAAC,yBAAsB;AACnC,OAAO,EAAC,KAAK,EAAC,0BAAuB;AACrC,OAAO,EAAC,WAAW,EAA8B,0BAAuB;AAIxE,MAAM,MAAM,gBAAgB,GAAG;IAC7B,KAAK,EAAE,KAAK,CAAC;IACb,MAAM,EAAE,WAAW,CAAC;CACrB,CAAC;AAEF,kEAAkE;AAClE,qBAAa,WAAY,SAAQ,WAAW;IAC1C,KAAK,EAAE,QAAQ,CAAC,QAAQ,CAAC,gBAAgB,CAAC,CAAC,CAAC;IAE5C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAQ;IAC/B,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAc;IACtC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAmD;IAC1E,OAAO,CAAC,YAAY,CAAS;IAC7B,OAAO,CAAC,sBAAsB,CAAS;gBAE3B,KAAK,EAAE,gBAAgB;IACnC,gEAAgE;gBACpD,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,WAAW;IAgB7C,cAAc;IAEd,QAAQ,QAAO,IAAI,EAAE,CAMnB;IAEF,QAAQ,QAK6B,IAAI,EAAE,CACzC;IAEF,eAAe,GAAI,MAAM,IAAI,sBAAwC;IAErE,eAAe,GAAI,MAAM,IAAI;;;;;MAAwC;IAErE,eAAe,eAA6B;IAE5C,mBAAmB,eAA8B;IAEjD,cAAc,kDAA4B;IAE1C,eAAe,QAAO,QAAQ,GAAG,IAAI,CAA6B;IAElE,8BAA8B;IAE9B,gBAAgB,GAAI,SAAI,EAAE,MAAC,EAAE,MAAC,UAA+C;IAE7E,kBAAkB,GAAI,SAAI,UAA2C;IAErE;;OAEG;IACH,cAAc,GAAI,OAAO,KAAK,UAQ5B;IAEF;;OAEG;IACH,eAAe,GAAI,OAAO,KAAK,UAQ7B;IAEF;;OAEG;IACH,aAAa,GAAI,OAAO,KAAK,UAQ3B;IAEF;;OAEG;IACH,cAAc,GAAI,OAAO,KAAK,UAO5B;IAEF,wBAAwB,GAAI,WAAM,UAGhC;IAEF,mBAAmB,aAEjB;IAEF,iBAAiB,aAGf;IAEF,0BAA0B;IAE1B,GAAG,aAkBD;IAEF,KAAK,aAaH;IAEF,MAAM,YAA+B;IAErC,IAAI,YAA6B;IAEjC,aAAa,aAIX;IAEF,aAAa,aAKX;IAEF,YAAY,CAAC,GAAG,KAAA,EAAE,WAAW,KAAA;CAG9B"}
1
+ {"version":3,"file":"graph-engine.d.ts","sourceRoot":"","sources":["../../src/core/graph-engine.ts"],"names":[],"mappings":"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"}
@@ -1,137 +1,145 @@
1
1
  // deck.gl-community
2
2
  // SPDX-License-Identifier: MIT
3
3
  // Copyright (c) vis.gl contributors
4
- import { Graph } from '../graph/graph';
4
+ import { ClassicGraph } from '../graph/classic-graph';
5
+ import { GraphLayout } from './graph-layout';
5
6
  import { Cache } from './cache';
6
7
  import { log } from '../utils/log';
8
+ import { GraphStylesheetEngine } from '../style/graph-style-engine';
7
9
  /** Graph engine controls the graph data and layout calculation */
8
- export class GraphEngine extends EventTarget {
9
- props;
10
+ export class GraphEngine {
11
+ _props;
10
12
  _graph;
11
13
  _layout;
12
14
  _cache = new Cache();
13
15
  _layoutDirty = false;
14
16
  _transactionInProgress = false;
17
+ _graphCallbacksAttached = false;
18
+ _layoutCallbacksAttached = false;
15
19
  constructor(props, layout) {
16
- super();
17
- if (props instanceof Graph) {
18
- props = {
19
- graph: props,
20
- layout
21
- };
20
+ let normalizedProps;
21
+ if (props instanceof ClassicGraph) {
22
+ if (!(layout instanceof GraphLayout)) {
23
+ throw new Error('GraphEngine: legacy graphs require a GraphLayout instance.');
24
+ }
25
+ normalizedProps = { graph: props, layout };
22
26
  }
23
- this.props = props;
24
- this._graph = props.graph;
25
- this._layout = props.layout;
27
+ else {
28
+ normalizedProps = props;
29
+ }
30
+ this._props = { ...normalizedProps };
31
+ this._graph = normalizedProps.graph;
32
+ this._layout = normalizedProps.layout;
33
+ }
34
+ get props() {
35
+ return { ...this._props };
36
+ }
37
+ setProps(props) {
38
+ this._props = {
39
+ ...this._props,
40
+ ...props,
41
+ graph: this._props.graph,
42
+ layout: this._props.layout
43
+ };
26
44
  }
27
45
  /** Getters */
28
46
  getNodes = () => {
29
- this._updateCache('nodes', () => this._graph.getNodes().filter((node) => this.getNodePosition(node)));
30
- return this._cache.get('nodes');
47
+ this._updateCache('nodes', () => Array.from(this._graph.getNodes()).filter((node) => {
48
+ const position = this.getNodePosition(node);
49
+ return position !== null && position !== undefined;
50
+ }));
51
+ return this._cache.get('nodes') ?? [];
31
52
  };
32
53
  getEdges = () => {
33
- this._updateCache('edges', () => this._graph.getEdges().filter((edge) => this.getEdgePosition(edge)));
34
- return this._cache.get('edges');
54
+ this._updateCache('edges', () => Array.from(this._graph.getEdges()).filter((edge) => {
55
+ const layout = this.getEdgePosition(edge);
56
+ return layout !== null && layout !== undefined;
57
+ }));
58
+ return this._cache.get('edges') ?? [];
59
+ };
60
+ getNodePosition = (node) => {
61
+ return this._layout.getNodePosition(node) ?? null;
62
+ };
63
+ getEdgePosition = (edge) => {
64
+ return this._layout.getEdgePosition(edge) ?? null;
35
65
  };
36
- getNodePosition = (node) => this._layout.getNodePosition(node);
37
- getEdgePosition = (edge) => this._layout.getEdgePosition(edge);
38
66
  getGraphVersion = () => this._graph.version;
39
67
  getLayoutLastUpdate = () => this._layout.version;
40
68
  getLayoutState = () => this._layout.state;
41
- getLayoutBounds = () => this._layout.getBounds();
69
+ getLayoutBounds = () => this._layout.getBounds() ?? null;
42
70
  /** Operations on the graph */
43
- lockNodePosition = (node, x, y) => this._layout.lockNodePosition(node, x, y);
44
- unlockNodePosition = (node) => this._layout.unlockNodePosition(node);
71
+ lockNodePosition = (node, x, y) => {
72
+ this._layout.lockNodePosition(node, x, y);
73
+ };
74
+ unlockNodePosition = (node) => {
75
+ this._layout.unlockNodePosition(node);
76
+ };
77
+ findNode(nodeId) {
78
+ return this._graph.findNode?.(nodeId) ?? this._graph.findNodeById?.(nodeId);
79
+ }
80
+ createStylesheetEngine(style, options = {}) {
81
+ return new GraphStylesheetEngine(style, options);
82
+ }
45
83
  /**
46
84
  * @fires GraphEngine#onLayoutStart
47
85
  */
48
- _onLayoutStart = (event) => {
86
+ _onLayoutStart = (detail) => {
49
87
  log.log(0, 'GraphEngine: layout start')();
50
- const detail = event instanceof CustomEvent ? event.detail : undefined;
51
- /**
52
- * @event GraphEngine#onLayoutStart
53
- * @type {CustomEvent}
54
- */
55
- this.dispatchEvent(new CustomEvent('onLayoutStart', { detail }));
88
+ this._props.onLayoutStart?.(detail);
56
89
  };
57
90
  /**
58
91
  * @fires GraphEngine#onLayoutChange
59
92
  */
60
- _onLayoutChange = (event) => {
93
+ _onLayoutChange = (detail) => {
61
94
  log.log(0, 'GraphEngine: layout update event')();
62
- const detail = event instanceof CustomEvent ? event.detail : undefined;
63
- /**
64
- * @event GraphEngine#onLayoutChange
65
- * @type {CustomEvent}
66
- */
67
- this.dispatchEvent(new CustomEvent('onLayoutChange', { detail }));
95
+ this._props.onLayoutChange?.(detail);
68
96
  };
69
97
  /**
70
98
  * @fires GraphEngine#onLayoutDone
71
99
  */
72
- _onLayoutDone = (event) => {
100
+ _onLayoutDone = (detail) => {
73
101
  log.log(0, 'GraphEngine: layout end')();
74
- const detail = event instanceof CustomEvent ? event.detail : undefined;
75
- /**
76
- * @event GraphEngine#onLayoutDone
77
- * @type {CustomEvent}
78
- */
79
- this.dispatchEvent(new CustomEvent('onLayoutDone', { detail }));
102
+ this._props.onLayoutDone?.(detail);
80
103
  };
81
104
  /**
82
105
  * @fires GraphEngine#onLayoutError
83
106
  */
84
- _onLayoutError = (event) => {
85
- const detail = event instanceof CustomEvent ? event.detail : undefined;
86
- /**
87
- * @event GraphEngine#onLayoutError
88
- * @type {CustomEvent}
89
- */
90
- this.dispatchEvent(new CustomEvent('onLayoutError', { detail }));
91
- };
92
- _onGraphStructureChanged = (entity) => {
107
+ _onLayoutError = (error) => {
108
+ this._props.onLayoutError?.(error);
109
+ };
110
+ _onGraphStructureChanged = () => {
93
111
  this._layoutDirty = true;
94
112
  this._graphChanged();
95
113
  };
96
114
  _onTransactionStart = () => {
97
115
  this._transactionInProgress = true;
116
+ this._props.onTransactionStart?.();
98
117
  };
99
118
  _onTransactionEnd = () => {
100
119
  this._transactionInProgress = false;
101
120
  this._graphChanged();
121
+ this._props.onTransactionEnd?.();
102
122
  };
103
123
  /** Layout calculations */
104
124
  run = () => {
105
125
  log.log(1, 'GraphEngine: run');
106
126
  // TODO: throw if running on a cleared engine
107
- this._graph.addEventListener('transactionStart', this._onTransactionStart);
108
- this._graph.addEventListener('transactionEnd', this._onTransactionEnd);
109
- this._graph.addEventListener('onNodeAdded', this._onGraphStructureChanged);
110
- this._graph.addEventListener('onNodeRemoved', this._onGraphStructureChanged);
111
- this._graph.addEventListener('onEdgeAdded', this._onGraphStructureChanged);
112
- this._graph.addEventListener('onEdgeRemoved', this._onGraphStructureChanged);
113
- this._layout.addEventListener('onLayoutStart', this._onLayoutStart);
114
- this._layout.addEventListener('onLayoutChange', this._onLayoutChange);
115
- this._layout.addEventListener('onLayoutDone', this._onLayoutDone);
116
- this._layout.addEventListener('onLayoutError', this._onLayoutError);
127
+ this._attachGraphCallbacks();
128
+ this._attachLayoutCallbacks();
117
129
  this._layout.initializeGraph(this._graph);
118
130
  this._layout.start();
119
131
  };
120
132
  clear = () => {
121
133
  log.log(1, 'GraphEngine: end');
122
- this._graph.removeEventListener('transactionStart', this._onTransactionStart);
123
- this._graph.removeEventListener('transactionEnd', this._onTransactionEnd);
124
- this._graph.removeEventListener('onNodeAdded', this._onGraphStructureChanged);
125
- this._graph.removeEventListener('onNodeRemoved', this._onGraphStructureChanged);
126
- this._graph.removeEventListener('onEdgeAdded', this._onGraphStructureChanged);
127
- this._graph.removeEventListener('onEdgeRemoved', this._onGraphStructureChanged);
128
- this._layout.removeEventListener('onLayoutStart', this._onLayoutStart);
129
- this._layout.removeEventListener('onLayoutChange', this._onLayoutChange);
130
- this._layout.removeEventListener('onLayoutDone', this._onLayoutDone);
131
- this._layout.removeEventListener('onLayoutError', this._onLayoutError);
132
- };
133
- resume = () => this._layout.resume();
134
- stop = () => this._layout.stop();
134
+ this._detachGraphCallbacks();
135
+ this._detachLayoutCallbacks();
136
+ };
137
+ resume = () => {
138
+ this._layout.resume();
139
+ };
140
+ stop = () => {
141
+ this._layout.stop();
142
+ };
135
143
  _graphChanged = () => {
136
144
  if (this._layoutDirty && !this._transactionInProgress) {
137
145
  this._updateLayout();
@@ -144,6 +152,78 @@ export class GraphEngine extends EventTarget {
144
152
  this._layoutDirty = false;
145
153
  };
146
154
  _updateCache(key, updateValue) {
147
- this._cache.set(key, updateValue, this._graph.version + this._layout.version);
155
+ this._cache.set(key, updateValue, this.getGraphVersion() + this.getLayoutLastUpdate());
156
+ }
157
+ _attachGraphCallbacks() {
158
+ if (this._graphCallbacksAttached) {
159
+ return;
160
+ }
161
+ this._graph.updateProps({
162
+ onTransactionStart: this._onTransactionStart,
163
+ onTransactionEnd: this._onTransactionEnd,
164
+ onNodeAdded: (node) => {
165
+ this._onGraphStructureChanged();
166
+ this._props.onNodeAdded?.(node);
167
+ },
168
+ onNodeRemoved: (node) => {
169
+ this._onGraphStructureChanged();
170
+ this._props.onNodeRemoved?.(node);
171
+ },
172
+ onNodeUpdated: (node) => {
173
+ this._props.onNodeUpdated?.(node);
174
+ },
175
+ onEdgeAdded: (edge) => {
176
+ this._onGraphStructureChanged();
177
+ this._props.onEdgeAdded?.(edge);
178
+ },
179
+ onEdgeRemoved: (edge) => {
180
+ this._onGraphStructureChanged();
181
+ this._props.onEdgeRemoved?.(edge);
182
+ },
183
+ onEdgeUpdated: (edge) => {
184
+ this._props.onEdgeUpdated?.(edge);
185
+ }
186
+ });
187
+ this._graphCallbacksAttached = true;
188
+ }
189
+ _detachGraphCallbacks() {
190
+ if (!this._graphCallbacksAttached) {
191
+ return;
192
+ }
193
+ this._graph.updateProps({
194
+ onTransactionStart: undefined,
195
+ onTransactionEnd: undefined,
196
+ onNodeAdded: undefined,
197
+ onNodeRemoved: undefined,
198
+ onNodeUpdated: undefined,
199
+ onEdgeAdded: undefined,
200
+ onEdgeRemoved: undefined,
201
+ onEdgeUpdated: undefined
202
+ });
203
+ this._graphCallbacksAttached = false;
204
+ }
205
+ _attachLayoutCallbacks() {
206
+ if (this._layoutCallbacksAttached) {
207
+ return;
208
+ }
209
+ this._layout.setProps({
210
+ onLayoutStart: this._onLayoutStart,
211
+ onLayoutChange: this._onLayoutChange,
212
+ onLayoutDone: this._onLayoutDone,
213
+ onLayoutError: this._onLayoutError
214
+ });
215
+ this._layoutCallbacksAttached = true;
216
+ }
217
+ _detachLayoutCallbacks() {
218
+ if (!this._layoutCallbacksAttached) {
219
+ return;
220
+ }
221
+ this._layout.setProps({
222
+ onLayoutStart: undefined,
223
+ onLayoutChange: undefined,
224
+ onLayoutDone: undefined,
225
+ onLayoutError: undefined
226
+ });
227
+ this._layoutCallbacksAttached = false;
148
228
  }
149
229
  }
@@ -1 +1 @@
1
- {"version":3,"file":"graph-engine.js","sourceRoot":"","sources":["../../src/core/graph-engine.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"graph-engine.js","sourceRoot":"","sources":["../../src/core/graph-engine.ts"],"names":[],"mappings":"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"}
@@ -1,18 +1,20 @@
1
1
  import type { Bounds2D } from '@math.gl/types';
2
- import type { Graph } from '../graph/graph';
3
- import type { Node } from '../graph/node';
4
- import type { Edge } from '../graph/edge';
2
+ import type { Graph, NodeInterface, EdgeInterface } from '../graph/graph';
5
3
  export type GraphLayoutState = 'init' | 'start' | 'calculating' | 'done' | 'error';
6
4
  export type GraphLayoutEventDetail = {
7
5
  bounds: Bounds2D | null;
8
6
  };
9
- export type GraphLayoutProps = {};
10
- /** All the layout classes are extended from this base layout class. */
11
- export declare abstract class GraphLayout<OptionsT extends GraphLayoutProps = GraphLayoutProps> extends EventTarget {
12
- /** Name of the layout. */
13
- protected readonly _name: string;
14
- /** Extra configuration options of the layout. */
15
- protected _options: OptionsT;
7
+ export type GraphLayoutProps = {
8
+ onLayoutStart?: (detail?: GraphLayoutEventDetail) => void;
9
+ onLayoutChange?: (detail?: GraphLayoutEventDetail) => void;
10
+ onLayoutDone?: (detail?: GraphLayoutEventDetail) => void;
11
+ onLayoutError?: (error?: unknown) => void;
12
+ };
13
+ export declare abstract class GraphLayout<PropsT extends GraphLayoutProps = GraphLayoutProps> {
14
+ static defaultProps: Readonly<Required<GraphLayoutProps>>;
15
+ get [Symbol.toStringTag](): string;
16
+ /** Extra configuration props of the layout. */
17
+ protected props: Required<PropsT>;
16
18
  /**
17
19
  * Last computed layout bounds in local layout coordinates.
18
20
  *
@@ -24,9 +26,11 @@ export declare abstract class GraphLayout<OptionsT extends GraphLayoutProps = Gr
24
26
  state: GraphLayoutState;
25
27
  /**
26
28
  * Constructor of GraphLayout
27
- * @param options extra configuration options of the layout
29
+ * @param props extra configuration props of the layout
28
30
  */
29
- constructor(options: OptionsT);
31
+ constructor(props: PropsT, defaultProps?: Required<PropsT>);
32
+ getProps(): PropsT;
33
+ setProps(props: Partial<PropsT>): void;
30
34
  /**
31
35
  * Check the equality of two layouts
32
36
  * @param layout - The layout to be compared.
@@ -34,9 +38,9 @@ export declare abstract class GraphLayout<OptionsT extends GraphLayoutProps = Gr
34
38
  */
35
39
  equals(layout: GraphLayout): boolean;
36
40
  /** access the position of the node in the layout */
37
- getNodePosition(node: Node): [number, number];
41
+ getNodePosition(node: NodeInterface): [number, number];
38
42
  /** access the layout information of the edge */
39
- getEdgePosition(edge: Edge): {
43
+ getEdgePosition(edge: EdgeInterface): {
40
44
  type: string;
41
45
  sourcePosition: number[];
42
46
  targetPosition: number[];
@@ -48,19 +52,19 @@ export declare abstract class GraphLayout<OptionsT extends GraphLayoutProps = Gr
48
52
  * @param x x coordinate
49
53
  * @param y y coordinate
50
54
  */
51
- lockNodePosition(node: Node, x: number, y: number): void;
55
+ lockNodePosition(node: NodeInterface, x: number, y: number): void;
52
56
  /**
53
57
  * Unlock the node, the node will be able to move freely.
54
58
  * @param {Object} node Node to be unlocked
55
59
  */
56
- unlockNodePosition(node: Node): void;
60
+ unlockNodePosition(node: NodeInterface): void;
57
61
  /** Returns the last computed layout bounds, if available. */
58
62
  getBounds(): Bounds2D | null;
59
63
  /** virtual functions: will be implemented in the child class */
60
64
  /** first time to pass the graph data into this layout */
61
- abstract initializeGraph(graph: Graph): any;
65
+ abstract initializeGraph(graph: Graph): void;
62
66
  /** update the existing graph */
63
- abstract updateGraph(graph: Graph): any;
67
+ abstract updateGraph(graph: Graph): void;
64
68
  /** start the layout calculation */
65
69
  abstract start(): any;
66
70
  /** update the layout calculation */
@@ -1 +1 @@
1
- {"version":3,"file":"graph-layout.d.ts","sourceRoot":"","sources":["../../src/core/graph-layout.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAC,QAAQ,EAAC,MAAM,gBAAgB,CAAC;AAE7C,OAAO,KAAK,EAAC,KAAK,EAAC,0BAAuB;AAC1C,OAAO,KAAK,EAAC,IAAI,EAAC,yBAAsB;AACxC,OAAO,KAAK,EAAC,IAAI,EAAC,yBAAsB;AAMxC,MAAM,MAAM,gBAAgB,GAAG,MAAM,GAAG,OAAO,GAAG,aAAa,GAAG,MAAM,GAAG,OAAO,CAAC;AAEnF,MAAM,MAAM,sBAAsB,GAAG;IACnC,MAAM,EAAE,QAAQ,GAAG,IAAI,CAAC;CACzB,CAAC;AAEF,MAAM,MAAM,gBAAgB,GAAG,EAAE,CAAC;AAElC,uEAAuE;AACvE,8BAAsB,WAAW,CAC/B,QAAQ,SAAS,gBAAgB,GAAG,gBAAgB,CACpD,SAAQ,WAAW;IACnB,0BAA0B;IAC1B,SAAS,CAAC,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAiB;IACjD,iDAAiD;IACjD,SAAS,CAAC,QAAQ,EAAE,QAAQ,CAAC;IAE7B;;;;;OAKG;IACH,SAAS,CAAC,OAAO,EAAE,QAAQ,GAAG,IAAI,CAAQ;IAEnC,OAAO,SAAK;IACZ,KAAK,EAAE,gBAAgB,CAAU;IAExC;;;OAGG;gBACS,OAAO,EAAE,QAAQ;IAK7B;;;;OAIG;IACH,MAAM,CAAC,MAAM,EAAE,WAAW,GAAG,OAAO;IASpC,oDAAoD;IACpD,eAAe,CAAC,IAAI,EAAE,IAAI,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC;IAI7C,gDAAgD;IAChD,eAAe,CAAC,IAAI,EAAE,IAAI;;;;;;IAS1B;;;;;OAKG;IACH,gBAAgB,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM;IAEjD;;;OAGG;IACH,kBAAkB,CAAC,IAAI,EAAE,IAAI;IAE7B,6DAA6D;IAC7D,SAAS,IAAI,QAAQ,GAAG,IAAI;IAI1B,gEAAgE;IAElE,yDAAyD;IACzD,QAAQ,CAAC,eAAe,CAAC,KAAK,EAAE,KAAK;IACrC,gCAAgC;IAChC,QAAQ,CAAC,WAAW,CAAC,KAAK,EAAE,KAAK;IACjC,mCAAmC;IACnC,QAAQ,CAAC,KAAK;IACd,oCAAoC;IACpC,QAAQ,CAAC,MAAM;IACf,oCAAoC;IACpC,QAAQ,CAAC,MAAM;IACf,kCAAkC;IAClC,QAAQ,CAAC,IAAI;IAKb,qEAAqE;IAErE,SAAS,CAAC,aAAa,IAAI,IAAI;IAE/B;;;;OAIG;IACH,SAAS,CAAC,gBAAgB,CACxB,SAAS,EAAE,QAAQ,CAAC,QAAQ,CAAC,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,GAAG,IAAI,GAAG,SAAS,CAAC,GACjE,QAAQ,GAAG,IAAI;IAiClB;;;;OAIG;IACH,SAAS,CAAC,kBAAkB,CAAC,KAAK,EAAE,OAAO,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,IAAI;IAmBrE,OAAO,CAAC,eAAe;IAIvB,SAAS,CAAC,YAAY,CAAC,KAAK,EAAE,gBAAgB;IAK9C,uCAAuC;IACvC,SAAS,CAAC,cAAc,QAAO,IAAI,CAYjC;IAEF,wCAAwC;IACxC,SAAS,CAAC,eAAe,QAAO,IAAI,CAYlC;IAEF,sCAAsC;IACtC,SAAS,CAAC,aAAa,QAAO,IAAI,CAYhC;IAEF,uCAAuC;IACvC,SAAS,CAAC,cAAc,QAAO,IAAI,CASjC;CACH"}
1
+ {"version":3,"file":"graph-layout.d.ts","sourceRoot":"","sources":["../../src/core/graph-layout.ts"],"names":[],"mappings":"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"}