@deck.gl-community/graph-layers 9.0.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 (210) hide show
  1. package/LICENSE +20 -0
  2. package/README.md +7 -0
  3. package/dist/core/base-layout.d.ts +71 -0
  4. package/dist/core/base-layout.js +133 -0
  5. package/dist/core/cache.d.ts +14 -0
  6. package/dist/core/cache.js +26 -0
  7. package/dist/core/constants.d.ts +101 -0
  8. package/dist/core/constants.js +48 -0
  9. package/dist/core/edge.d.ts +86 -0
  10. package/dist/core/edge.js +121 -0
  11. package/dist/core/graph-engine.d.ts +54 -0
  12. package/dist/core/graph-engine.js +128 -0
  13. package/dist/core/graph.d.ts +155 -0
  14. package/dist/core/graph.js +301 -0
  15. package/dist/core/interaction-manager.d.ts +40 -0
  16. package/dist/core/interaction-manager.js +169 -0
  17. package/dist/core/node.d.ts +103 -0
  18. package/dist/core/node.js +177 -0
  19. package/dist/index.cjs +3540 -0
  20. package/dist/index.cjs.map +7 -0
  21. package/dist/index.d.ts +19 -0
  22. package/dist/index.js +28 -0
  23. package/dist/layers/common-layers/flow-path-layer/flow-path-layer-fragment.glsl.d.ts +1 -0
  24. package/dist/layers/common-layers/flow-path-layer/flow-path-layer-fragment.glsl.js +49 -0
  25. package/dist/layers/common-layers/flow-path-layer/flow-path-layer-vertex-tf.glsl.d.ts +1 -0
  26. package/dist/layers/common-layers/flow-path-layer/flow-path-layer-vertex-tf.glsl.js +14 -0
  27. package/dist/layers/common-layers/flow-path-layer/flow-path-layer-vertex.glsl.d.ts +1 -0
  28. package/dist/layers/common-layers/flow-path-layer/flow-path-layer-vertex.glsl.js +73 -0
  29. package/dist/layers/common-layers/flow-path-layer/flow-path-layer.d.ts +20 -0
  30. package/dist/layers/common-layers/flow-path-layer/flow-path-layer.js +133 -0
  31. package/dist/layers/common-layers/marker-layer/atlas-data-url.d.ts +3 -0
  32. package/dist/layers/common-layers/marker-layer/atlas-data-url.js +8 -0
  33. package/dist/layers/common-layers/marker-layer/marker-layer.d.ts +13 -0
  34. package/dist/layers/common-layers/marker-layer/marker-layer.js +29 -0
  35. package/dist/layers/common-layers/marker-layer/marker-list.d.ts +62 -0
  36. package/dist/layers/common-layers/marker-layer/marker-list.js +67 -0
  37. package/dist/layers/common-layers/marker-layer/marker-mapping.d.ts +422 -0
  38. package/dist/layers/common-layers/marker-layer/marker-mapping.js +427 -0
  39. package/dist/layers/common-layers/spline-layer/spline-layer.d.ts +24 -0
  40. package/dist/layers/common-layers/spline-layer/spline-layer.js +68 -0
  41. package/dist/layers/common-layers/zoomable-text-layer/zoomable-text-layer.d.ts +16 -0
  42. package/dist/layers/common-layers/zoomable-text-layer/zoomable-text-layer.js +65 -0
  43. package/dist/layers/edge-layer.d.ts +25 -0
  44. package/dist/layers/edge-layer.js +75 -0
  45. package/dist/layers/edge-layers/curved-edge-layer.d.ts +6 -0
  46. package/dist/layers/edge-layers/curved-edge-layer.js +69 -0
  47. package/dist/layers/edge-layers/edge-label-layer.d.ts +6 -0
  48. package/dist/layers/edge-layers/edge-label-layer.js +42 -0
  49. package/dist/layers/edge-layers/flow-layer.d.ts +6 -0
  50. package/dist/layers/edge-layers/flow-layer.js +28 -0
  51. package/dist/layers/edge-layers/path-edge-layer.d.ts +6 -0
  52. package/dist/layers/edge-layers/path-edge-layer.js +27 -0
  53. package/dist/layers/edge-layers/straight-line-edge-layer.d.ts +6 -0
  54. package/dist/layers/edge-layers/straight-line-edge-layer.js +26 -0
  55. package/dist/layers/graph-layer.d.ts +32 -0
  56. package/dist/layers/graph-layer.js +193 -0
  57. package/dist/layers/node-layers/circle-layer.d.ts +6 -0
  58. package/dist/layers/node-layers/circle-layer.js +23 -0
  59. package/dist/layers/node-layers/image-layer.d.ts +6 -0
  60. package/dist/layers/node-layers/image-layer.js +23 -0
  61. package/dist/layers/node-layers/label-layer.d.ts +6 -0
  62. package/dist/layers/node-layers/label-layer.js +23 -0
  63. package/dist/layers/node-layers/path-rounded-rectange-layer.d.ts +6 -0
  64. package/dist/layers/node-layers/path-rounded-rectange-layer.js +46 -0
  65. package/dist/layers/node-layers/rectangle-layer.d.ts +6 -0
  66. package/dist/layers/node-layers/rectangle-layer.js +49 -0
  67. package/dist/layers/node-layers/rounded-rectangle-layer-fragment.d.ts +1 -0
  68. package/dist/layers/node-layers/rounded-rectangle-layer-fragment.js +30 -0
  69. package/dist/layers/node-layers/rounded-rectangle-layer.d.ts +8 -0
  70. package/dist/layers/node-layers/rounded-rectangle-layer.js +28 -0
  71. package/dist/layers/node-layers/zoomable-marker-layer.d.ts +10 -0
  72. package/dist/layers/node-layers/zoomable-marker-layer.js +40 -0
  73. package/dist/layouts/d3-force/d3-force-layout.d.ts +24 -0
  74. package/dist/layouts/d3-force/d3-force-layout.js +116 -0
  75. package/dist/layouts/d3-force/worker.d.ts +0 -0
  76. package/dist/layouts/d3-force/worker.js +46 -0
  77. package/dist/layouts/gpu-force/gpu-force-layout.d.ts +30 -0
  78. package/dist/layouts/gpu-force/gpu-force-layout.js +232 -0
  79. package/dist/layouts/gpu-force/worker.d.ts +0 -0
  80. package/dist/layouts/gpu-force/worker.js +116 -0
  81. package/dist/layouts/simple-layout/simple-layout.d.ts +22 -0
  82. package/dist/layouts/simple-layout/simple-layout.js +64 -0
  83. package/dist/loaders/edge-parsers.d.ts +6 -0
  84. package/dist/loaders/edge-parsers.js +17 -0
  85. package/dist/loaders/json-loader.d.ts +7 -0
  86. package/dist/loaders/json-loader.js +16 -0
  87. package/dist/loaders/node-parsers.d.ts +3 -0
  88. package/dist/loaders/node-parsers.js +11 -0
  89. package/dist/style/style-property.d.ts +14 -0
  90. package/dist/style/style-property.js +195 -0
  91. package/dist/style/style-sheet.d.ts +10 -0
  92. package/dist/style/style-sheet.js +252 -0
  93. package/dist/utils/create-graph.d.ts +8 -0
  94. package/dist/utils/create-graph.js +33 -0
  95. package/dist/utils/layer-utils.d.ts +1 -0
  96. package/dist/utils/layer-utils.js +20 -0
  97. package/dist/utils/log.d.ts +2 -0
  98. package/dist/utils/log.js +6 -0
  99. package/dist/utils/polygon-calculations.d.ts +1 -0
  100. package/dist/utils/polygon-calculations.js +102 -0
  101. package/package.json +55 -0
  102. package/src/core/base-layout.ts +154 -0
  103. package/src/core/cache.ts +31 -0
  104. package/src/core/constants.ts +58 -0
  105. package/src/core/edge.ts +145 -0
  106. package/src/core/graph-engine.ts +170 -0
  107. package/src/core/graph.ts +342 -0
  108. package/src/core/interaction-manager.ts +225 -0
  109. package/src/core/node.ts +205 -0
  110. package/src/index.ts +42 -0
  111. package/src/layers/common-layers/flow-path-layer/flow-path-layer-fragment.glsl.ts +50 -0
  112. package/src/layers/common-layers/flow-path-layer/flow-path-layer-vertex-tf.glsl.ts +15 -0
  113. package/src/layers/common-layers/flow-path-layer/flow-path-layer-vertex.glsl.ts +74 -0
  114. package/src/layers/common-layers/flow-path-layer/flow-path-layer.ts +154 -0
  115. package/src/layers/common-layers/marker-layer/atlas-data-url.ts +10 -0
  116. package/src/layers/common-layers/marker-layer/marker-atlas.png +0 -0
  117. package/src/layers/common-layers/marker-layer/marker-layer.ts +36 -0
  118. package/src/layers/common-layers/marker-layer/marker-list.ts +68 -0
  119. package/src/layers/common-layers/marker-layer/marker-mapping.ts +428 -0
  120. package/src/layers/common-layers/marker-layer/markers/bell-filled.png +0 -0
  121. package/src/layers/common-layers/marker-layer/markers/bell.png +0 -0
  122. package/src/layers/common-layers/marker-layer/markers/bookmark-filled.png +0 -0
  123. package/src/layers/common-layers/marker-layer/markers/bookmark.png +0 -0
  124. package/src/layers/common-layers/marker-layer/markers/cd-filled.png +0 -0
  125. package/src/layers/common-layers/marker-layer/markers/cd.png +0 -0
  126. package/src/layers/common-layers/marker-layer/markers/checkmark.png +0 -0
  127. package/src/layers/common-layers/marker-layer/markers/circle-check-filled.png +0 -0
  128. package/src/layers/common-layers/marker-layer/markers/circle-check.png +0 -0
  129. package/src/layers/common-layers/marker-layer/markers/circle-filled.png +0 -0
  130. package/src/layers/common-layers/marker-layer/markers/circle-i-filled.png +0 -0
  131. package/src/layers/common-layers/marker-layer/markers/circle-i.png +0 -0
  132. package/src/layers/common-layers/marker-layer/markers/circle-minus-filled.png +0 -0
  133. package/src/layers/common-layers/marker-layer/markers/circle-minus.png +0 -0
  134. package/src/layers/common-layers/marker-layer/markers/circle-plus-filled.png +0 -0
  135. package/src/layers/common-layers/marker-layer/markers/circle-plus.png +0 -0
  136. package/src/layers/common-layers/marker-layer/markers/circle-questionmark-filled.png +0 -0
  137. package/src/layers/common-layers/marker-layer/markers/circle-questionmark.png +0 -0
  138. package/src/layers/common-layers/marker-layer/markers/circle-slash-filled.png +0 -0
  139. package/src/layers/common-layers/marker-layer/markers/circle-slash.png +0 -0
  140. package/src/layers/common-layers/marker-layer/markers/circle-x-filled.png +0 -0
  141. package/src/layers/common-layers/marker-layer/markers/circle-x.png +0 -0
  142. package/src/layers/common-layers/marker-layer/markers/circle.png +0 -0
  143. package/src/layers/common-layers/marker-layer/markers/diamond-filled.png +0 -0
  144. package/src/layers/common-layers/marker-layer/markers/diamond.png +0 -0
  145. package/src/layers/common-layers/marker-layer/markers/flag-filled.png +0 -0
  146. package/src/layers/common-layers/marker-layer/markers/flag.png +0 -0
  147. package/src/layers/common-layers/marker-layer/markers/gear.png +0 -0
  148. package/src/layers/common-layers/marker-layer/markers/heart-filled.png +0 -0
  149. package/src/layers/common-layers/marker-layer/markers/heart.png +0 -0
  150. package/src/layers/common-layers/marker-layer/markers/location-marker-filled.png +0 -0
  151. package/src/layers/common-layers/marker-layer/markers/location-marker.png +0 -0
  152. package/src/layers/common-layers/marker-layer/markers/octagonal-star-filled.png +0 -0
  153. package/src/layers/common-layers/marker-layer/markers/octagonal-star.png +0 -0
  154. package/src/layers/common-layers/marker-layer/markers/person-filled.png +0 -0
  155. package/src/layers/common-layers/marker-layer/markers/person.png +0 -0
  156. package/src/layers/common-layers/marker-layer/markers/pin-filled.png +0 -0
  157. package/src/layers/common-layers/marker-layer/markers/pin.png +0 -0
  158. package/src/layers/common-layers/marker-layer/markers/plus-small.png +0 -0
  159. package/src/layers/common-layers/marker-layer/markers/plus.png +0 -0
  160. package/src/layers/common-layers/marker-layer/markers/rectangle-filled.png +0 -0
  161. package/src/layers/common-layers/marker-layer/markers/rectangle.png +0 -0
  162. package/src/layers/common-layers/marker-layer/markers/star-filled.png +0 -0
  163. package/src/layers/common-layers/marker-layer/markers/star.png +0 -0
  164. package/src/layers/common-layers/marker-layer/markers/tag-filled.png +0 -0
  165. package/src/layers/common-layers/marker-layer/markers/tag.png +0 -0
  166. package/src/layers/common-layers/marker-layer/markers/thumb-down-filled.png +0 -0
  167. package/src/layers/common-layers/marker-layer/markers/thumb-down.png +0 -0
  168. package/src/layers/common-layers/marker-layer/markers/thumb-up.png +0 -0
  169. package/src/layers/common-layers/marker-layer/markers/thumb_up-filled.png +0 -0
  170. package/src/layers/common-layers/marker-layer/markers/triangle-down-filled.png +0 -0
  171. package/src/layers/common-layers/marker-layer/markers/triangle-down.png +0 -0
  172. package/src/layers/common-layers/marker-layer/markers/triangle-left-filled.png +0 -0
  173. package/src/layers/common-layers/marker-layer/markers/triangle-left.png +0 -0
  174. package/src/layers/common-layers/marker-layer/markers/triangle-right-filled.png +0 -0
  175. package/src/layers/common-layers/marker-layer/markers/triangle-right.png +0 -0
  176. package/src/layers/common-layers/marker-layer/markers/triangle-up-filled.png +0 -0
  177. package/src/layers/common-layers/marker-layer/markers/triangle-up.png +0 -0
  178. package/src/layers/common-layers/marker-layer/markers/x-small.png +0 -0
  179. package/src/layers/common-layers/marker-layer/markers/x.png +0 -0
  180. package/src/layers/common-layers/spline-layer/spline-layer.ts +83 -0
  181. package/src/layers/common-layers/zoomable-text-layer/zoomable-text-layer.ts +90 -0
  182. package/src/layers/edge-layer.ts +88 -0
  183. package/src/layers/edge-layers/curved-edge-layer.ts +88 -0
  184. package/src/layers/edge-layers/edge-label-layer.ts +48 -0
  185. package/src/layers/edge-layers/flow-layer.ts +34 -0
  186. package/src/layers/edge-layers/path-edge-layer.ts +39 -0
  187. package/src/layers/edge-layers/straight-line-edge-layer.ts +38 -0
  188. package/src/layers/graph-layer.ts +225 -0
  189. package/src/layers/node-layers/circle-layer.ts +29 -0
  190. package/src/layers/node-layers/image-layer.ts +29 -0
  191. package/src/layers/node-layers/label-layer.ts +29 -0
  192. package/src/layers/node-layers/path-rounded-rectange-layer.ts +56 -0
  193. package/src/layers/node-layers/rectangle-layer.ts +58 -0
  194. package/src/layers/node-layers/rounded-rectangle-layer-fragment.ts +31 -0
  195. package/src/layers/node-layers/rounded-rectangle-layer.ts +32 -0
  196. package/src/layers/node-layers/zoomable-marker-layer.ts +49 -0
  197. package/src/layouts/d3-force/d3-force-layout.ts +145 -0
  198. package/src/layouts/d3-force/worker.ts +61 -0
  199. package/src/layouts/gpu-force/gpu-force-layout.ts +249 -0
  200. package/src/layouts/gpu-force/worker.ts +137 -0
  201. package/src/layouts/simple-layout/simple-layout.ts +87 -0
  202. package/src/loaders/edge-parsers.ts +21 -0
  203. package/src/loaders/json-loader.ts +19 -0
  204. package/src/loaders/node-parsers.ts +13 -0
  205. package/src/style/style-property.ts +229 -0
  206. package/src/style/style-sheet.ts +277 -0
  207. package/src/utils/create-graph.ts +38 -0
  208. package/src/utils/layer-utils.ts +23 -0
  209. package/src/utils/log.ts +9 -0
  210. package/src/utils/polygon-calculations.ts +154 -0
@@ -0,0 +1,90 @@
1
+ // deck.gl-community
2
+ // SPDX-License-Identifier: MIT
3
+ // Copyright (c) vis.gl contributors
4
+
5
+ import {CompositeLayer} from '@deck.gl/core';
6
+ import {TextLayer} from '@deck.gl/layers';
7
+
8
+ export class ZoomableTextLayer extends CompositeLayer {
9
+ static layerName = 'ZoomableTextLayer';
10
+
11
+ initializeState() {
12
+ this.state = {characterSet: []};
13
+ }
14
+
15
+ shouldUpdateState({props, changeFlags}) {
16
+ const {scaleWithZoom} = this.props as any;
17
+ if (!scaleWithZoom) {
18
+ return changeFlags.dataChanged || changeFlags.propsChanged;
19
+ }
20
+ return changeFlags.dataChanged || changeFlags.propsChanged || changeFlags.viewportChanged;
21
+ }
22
+
23
+ updateState({props, oldProps, changeFlags}) {
24
+ super.updateState({props, oldProps, changeFlags} as any);
25
+ if (changeFlags.propsOrDataChanged) {
26
+ const {getText} = props;
27
+ let textLabels = [];
28
+ if (typeof getText === 'function') {
29
+ textLabels = props.data.map(getText);
30
+ } else {
31
+ textLabels = [getText];
32
+ }
33
+ const characterSet = new Set(textLabels.join(''));
34
+ const uniqueCharacters = Array.from(characterSet);
35
+ this.setState({characterSet: uniqueCharacters});
36
+ }
37
+ }
38
+
39
+ renderLayers() {
40
+ const {
41
+ data,
42
+ getPosition,
43
+ getColor,
44
+ getText,
45
+ getSize,
46
+ getTextAnchor,
47
+ getAlignmentBaseline,
48
+ getAngle,
49
+ scaleWithZoom,
50
+ updateTriggers,
51
+ fontFamily,
52
+ textWordUnits,
53
+ textWordBreak,
54
+ textMaxWidth,
55
+ textSizeMinPixels
56
+ } = this.props as any;
57
+
58
+ const sizeUpdateTrigger = scaleWithZoom ? [getSize, this.context.viewport.zoom] : false;
59
+ // getText only expects function not plain value (string)
60
+ const newGetText = typeof getText === 'function' ? getText : () => getText;
61
+
62
+ return [
63
+ new TextLayer(
64
+ this.getSubLayerProps({
65
+ id: '__text-layer',
66
+ data,
67
+ sizeScale: scaleWithZoom ? Math.pow(2, this.context.viewport.zoom - 1) : 1,
68
+ characterSet: this.state.characterSet,
69
+ getPosition,
70
+ getColor,
71
+ getSize,
72
+ getTextAnchor,
73
+ getAlignmentBaseline,
74
+ getAngle,
75
+ getText: newGetText,
76
+ maxWidth: textMaxWidth ?? 12,
77
+ wordBreak: textWordBreak ?? 'break-all',
78
+ fontFamily: fontFamily ?? 'Red Hat Text',
79
+ wordUnits: textWordUnits ?? 'pixels',
80
+ sizeMinPixels: textSizeMinPixels ?? 9,
81
+ updateTriggers: {
82
+ getSize: sizeUpdateTrigger,
83
+ getAngle: [sizeUpdateTrigger, updateTriggers.getPosition],
84
+ ...updateTriggers
85
+ }
86
+ })
87
+ )
88
+ ];
89
+ }
90
+ }
@@ -0,0 +1,88 @@
1
+ // deck.gl-community
2
+ // SPDX-License-Identifier: MIT
3
+ // Copyright (c) vis.gl contributors
4
+
5
+ import {COORDINATE_SYSTEM, CompositeLayer} from '@deck.gl/core';
6
+
7
+ import {EDGE_TYPE} from '../core/constants';
8
+ import {StraightLineEdgeLayer} from '../layers/edge-layers/straight-line-edge-layer';
9
+ import {PathEdgeLayer} from './edge-layers/path-edge-layer';
10
+ import {CurvedEdgeLayer} from './edge-layers/curved-edge-layer';
11
+
12
+ const EDGE_LAYER_MAP = {
13
+ [EDGE_TYPE.LINE]: StraightLineEdgeLayer,
14
+ [EDGE_TYPE.PATH]: PathEdgeLayer,
15
+ [EDGE_TYPE.SPLINE_CURVE]: CurvedEdgeLayer
16
+ };
17
+
18
+ export class EdgeLayer extends CompositeLayer {
19
+ static layerName = 'EdgeLayer';
20
+
21
+ static defaultProps = {
22
+ data: [],
23
+ pickable: true,
24
+ getLayoutInfo: (d) => ({
25
+ type: d.type,
26
+ sourcePosition: d.sourcePosition,
27
+ targetPosition: d.targetPosition,
28
+ controlPoints: []
29
+ }),
30
+ positionUpdateTrigger: 0
31
+ };
32
+
33
+ updateState({props, oldProps, changeFlags}) {
34
+ super.updateState({props, oldProps, changeFlags} as any);
35
+ if (changeFlags.dataChanged) {
36
+ this.updateStateData();
37
+ }
38
+ }
39
+
40
+ updateStateData() {
41
+ const {data, getLayoutInfo} = this.props as any;
42
+ // bucket edges by types
43
+ const typedEdgeData = data.reduce(
44
+ (res, d) => {
45
+ const {type} = getLayoutInfo(d);
46
+ res[type].push(d);
47
+ return res;
48
+ },
49
+ {
50
+ [EDGE_TYPE.LINE]: [],
51
+ [EDGE_TYPE.PATH]: [],
52
+ [EDGE_TYPE.SPLINE_CURVE]: []
53
+ }
54
+ );
55
+ this.setState({typedEdgeData});
56
+ }
57
+
58
+ renderLayers() {
59
+ const {getLayoutInfo, pickable, positionUpdateTrigger, stylesheet, id} = this.props as any;
60
+
61
+ const {typedEdgeData} = this.state;
62
+
63
+ // render lines by types (straight line, path, curves)
64
+ return Object.entries(typedEdgeData).map((e, idx) => {
65
+ const [type, edgeData] = e;
66
+ const Layer = EDGE_LAYER_MAP[type];
67
+ // invalid edge layer type
68
+ if (!Layer) {
69
+ return null;
70
+ }
71
+ return new Layer({
72
+ id: `${id}-${idx}`,
73
+ data: edgeData,
74
+ getLayoutInfo,
75
+ getColor: stylesheet.getDeckGLAccessor('getColor'),
76
+ getWidth: stylesheet.getDeckGLAccessor('getWidth'),
77
+ colorUpdateTrigger: stylesheet.getDeckGLAccessorUpdateTrigger('getColor'),
78
+ widthUpdateTrigger: stylesheet.getDeckGLAccessorUpdateTrigger('getWidth'),
79
+ positionUpdateTrigger,
80
+ pickable,
81
+ coordinateSystem: COORDINATE_SYSTEM.CARTESIAN,
82
+ parameters: {
83
+ depthCompare: 'always'
84
+ }
85
+ } as any);
86
+ });
87
+ }
88
+ }
@@ -0,0 +1,88 @@
1
+ // deck.gl-community
2
+ // SPDX-License-Identifier: MIT
3
+ // Copyright (c) vis.gl contributors
4
+
5
+ import {CompositeLayer} from '@deck.gl/core';
6
+ import {ScatterplotLayer, LineLayer} from '@deck.gl/layers';
7
+ import {SplineLayer} from '../common-layers/spline-layer/spline-layer';
8
+
9
+ const DEBUG = false;
10
+
11
+ export class CurvedEdgeLayer extends CompositeLayer {
12
+ static layerName = 'CurvedEdgeLayer';
13
+
14
+ // @ts-expect-error TODO
15
+ renderLayers() {
16
+ const {
17
+ data,
18
+ getLayoutInfo,
19
+ positionUpdateTrigger = 0,
20
+ colorUpdateTrigger = 0,
21
+ widthUpdateTrigger = 0,
22
+ ...otherProps
23
+ } = this.props as any;
24
+ return [
25
+ DEBUG &&
26
+ new ScatterplotLayer(
27
+ this.getSubLayerProps({
28
+ id: '__control-points',
29
+ data,
30
+ getPosition: (e) => getLayoutInfo(e).controlPoints[0],
31
+ getColor: (d) => [190, 190, 190, 150],
32
+ getRadius: (d) => 5,
33
+ updateTriggers: {
34
+ getPosition: positionUpdateTrigger
35
+ },
36
+ ...otherProps
37
+ })
38
+ ),
39
+ DEBUG &&
40
+ new LineLayer(
41
+ this.getSubLayerProps({
42
+ id: '__first_segment',
43
+ data,
44
+ getSourcePosition: (e) => getLayoutInfo(e).sourcePosition,
45
+ getTargetPosition: (e) => getLayoutInfo(e).controlPoints[0],
46
+ getColor: (e) => [210, 210, 210, 150],
47
+ updateTriggers: {
48
+ getSourcePosition: positionUpdateTrigger,
49
+ getTargetPosition: positionUpdateTrigger
50
+ },
51
+ ...otherProps
52
+ })
53
+ ),
54
+ DEBUG &&
55
+ new LineLayer(
56
+ this.getSubLayerProps({
57
+ id: '__last_segment',
58
+ data,
59
+ getSourcePosition: (e) => getLayoutInfo(e).controlPoints[0],
60
+ getTargetPosition: (e) => getLayoutInfo(e).targetPosition,
61
+ getColor: (e) => [210, 210, 210, 150],
62
+ updateTriggers: {
63
+ getSourcePosition: positionUpdateTrigger,
64
+ getTargetPosition: positionUpdateTrigger
65
+ },
66
+ ...otherProps
67
+ })
68
+ ),
69
+ new SplineLayer(
70
+ this.getSubLayerProps({
71
+ id: '__spline_layer',
72
+ data,
73
+ getSourcePosition: (e) => getLayoutInfo(e).sourcePosition,
74
+ getTargetPosition: (e) => getLayoutInfo(e).targetPosition,
75
+ getControlPoints: (e) => getLayoutInfo(e).controlPoints,
76
+ updateTriggers: {
77
+ getSourcePosition: positionUpdateTrigger,
78
+ getTargetPosition: positionUpdateTrigger,
79
+ getControlPoints: positionUpdateTrigger,
80
+ getColor: colorUpdateTrigger,
81
+ getWidth: widthUpdateTrigger
82
+ },
83
+ ...otherProps
84
+ })
85
+ )
86
+ ];
87
+ }
88
+ }
@@ -0,0 +1,48 @@
1
+ // deck.gl-community
2
+ // SPDX-License-Identifier: MIT
3
+ // Copyright (c) vis.gl contributors
4
+
5
+ import {CompositeLayer} from '@deck.gl/core';
6
+ import {ZoomableTextLayer} from '../common-layers/zoomable-text-layer/zoomable-text-layer';
7
+
8
+ export class EdgeLabelLayer extends CompositeLayer {
9
+ static layerName = 'EdgeLabelLayer';
10
+
11
+ renderLayers() {
12
+ const {data, getLayoutInfo, positionUpdateTrigger = 0, stylesheet} = this.props as any;
13
+ return [
14
+ new ZoomableTextLayer(
15
+ this.getSubLayerProps({
16
+ id: 'edge-label-layer',
17
+ data,
18
+ getPosition: (e) => {
19
+ const {sourcePosition, targetPosition, controlPoints = []} = getLayoutInfo(e);
20
+ // consider all the points on this edge
21
+ const allPoints = [sourcePosition, targetPosition, ...controlPoints];
22
+ const sumX = allPoints.reduce((res, p) => res + p[0], 0);
23
+ const sumY = allPoints.reduce((res, p) => res + p[1], 0);
24
+ // find the centroid of those points
25
+ return [sumX / allPoints.length, sumY / allPoints.length];
26
+ },
27
+ getAngle: (e) => {
28
+ const {sourcePosition, targetPosition} = getLayoutInfo(e);
29
+ // sort the nodes from left to right
30
+ const [newSourcePosition, newTargetPosition] =
31
+ sourcePosition[0] < targetPosition[0]
32
+ ? [sourcePosition, targetPosition]
33
+ : [targetPosition, sourcePosition];
34
+ // angle in degrees
35
+ const deltaX = newTargetPosition[0] - newSourcePosition[0];
36
+ const deltaY = newTargetPosition[1] - newSourcePosition[1];
37
+ return (Math.atan2(deltaY, deltaX) * -180) / Math.PI;
38
+ },
39
+ ...stylesheet.getDeckGLAccessors(),
40
+ updateTriggers: {
41
+ ...stylesheet.getDeckGLUpdateTriggers(),
42
+ getPosition: positionUpdateTrigger
43
+ }
44
+ })
45
+ )
46
+ ];
47
+ }
48
+ }
@@ -0,0 +1,34 @@
1
+ // deck.gl-community
2
+ // SPDX-License-Identifier: MIT
3
+ // Copyright (c) vis.gl contributors
4
+
5
+ import {CompositeLayer} from '@deck.gl/core';
6
+
7
+ import {FlowPathLayer} from '../common-layers/flow-path-layer/flow-path-layer';
8
+
9
+ export class FlowLayer extends CompositeLayer {
10
+ static layerName = 'FlowLayer';
11
+
12
+ renderLayers() {
13
+ const {data, getLayoutInfo, positionUpdateTrigger = 0, stylesheet} = this.props as any;
14
+ return [
15
+ new FlowPathLayer(
16
+ this.getSubLayerProps({
17
+ id: '__flow-layer',
18
+ data,
19
+ ...stylesheet.getDeckGLAccessors(),
20
+ getSourcePosition: (e) => getLayoutInfo(e).sourcePosition,
21
+ getTargetPosition: (e) => getLayoutInfo(e).targetPosition,
22
+ parameters: {
23
+ depthTest: false
24
+ },
25
+ updateTriggers: {
26
+ ...stylesheet.getDeckGLUpdateTriggers(),
27
+ getSourcePosition: positionUpdateTrigger,
28
+ getTargetPosition: positionUpdateTrigger
29
+ }
30
+ })
31
+ )
32
+ ];
33
+ }
34
+ }
@@ -0,0 +1,39 @@
1
+ // deck.gl-community
2
+ // SPDX-License-Identifier: MIT
3
+ // Copyright (c) vis.gl contributors
4
+
5
+ import {CompositeLayer} from '@deck.gl/core';
6
+ import {PathLayer} from '@deck.gl/layers';
7
+
8
+ export class PathEdgeLayer extends CompositeLayer {
9
+ static layerName = 'PathEdgeLayer';
10
+
11
+ renderLayers() {
12
+ const {
13
+ data,
14
+ getLayoutInfo,
15
+ positionUpdateTrigger = 0,
16
+ colorUpdateTrigger = 0,
17
+ widthUpdateTrigger = 0,
18
+ ...otherProps
19
+ } = this.props as any;
20
+ return [
21
+ new PathLayer(
22
+ this.getSubLayerProps({
23
+ id: '__line-layer',
24
+ data,
25
+ getPath: (e) => {
26
+ const {sourcePosition, targetPosition, controlPoints} = getLayoutInfo(e);
27
+ return [sourcePosition, ...controlPoints, targetPosition];
28
+ },
29
+ updateTriggers: {
30
+ getColor: colorUpdateTrigger,
31
+ getPath: positionUpdateTrigger,
32
+ getWidth: widthUpdateTrigger
33
+ },
34
+ ...otherProps
35
+ })
36
+ )
37
+ ];
38
+ }
39
+ }
@@ -0,0 +1,38 @@
1
+ // deck.gl-community
2
+ // SPDX-License-Identifier: MIT
3
+ // Copyright (c) vis.gl contributors
4
+
5
+ import {CompositeLayer} from '@deck.gl/core';
6
+ import {LineLayer} from '@deck.gl/layers';
7
+
8
+ export class StraightLineEdgeLayer extends CompositeLayer {
9
+ static layerName = 'StraightLineEdgeLayer';
10
+
11
+ renderLayers() {
12
+ const {
13
+ data,
14
+ getLayoutInfo,
15
+ positionUpdateTrigger = 0,
16
+ colorUpdateTrigger = 0,
17
+ widthUpdateTrigger = 0,
18
+ ...otherProps
19
+ } = this.props as any;
20
+ return [
21
+ new LineLayer(
22
+ this.getSubLayerProps({
23
+ id: '__line-layer',
24
+ data,
25
+ getSourcePosition: (e) => getLayoutInfo(e).sourcePosition,
26
+ getTargetPosition: (e) => getLayoutInfo(e).targetPosition,
27
+ updateTriggers: {
28
+ getColor: colorUpdateTrigger,
29
+ getSourcePosition: positionUpdateTrigger,
30
+ getTargetPosition: positionUpdateTrigger,
31
+ getWidth: widthUpdateTrigger
32
+ },
33
+ ...otherProps
34
+ })
35
+ )
36
+ ];
37
+ }
38
+ }
@@ -0,0 +1,225 @@
1
+ // deck.gl-community
2
+ // SPDX-License-Identifier: MIT
3
+ // Copyright (c) vis.gl contributors
4
+
5
+ import {COORDINATE_SYSTEM, CompositeLayer} from '@deck.gl/core';
6
+
7
+ import {Stylesheet} from '../style/style-sheet';
8
+ import {NODE_TYPE, EDGE_DECORATOR_TYPE} from '../core/constants';
9
+ import {mixedGetPosition} from '../utils/layer-utils';
10
+ import {InteractionManager} from '../core/interaction-manager';
11
+
12
+ import {log} from '../utils/log';
13
+
14
+ // node layers
15
+ import {CircleLayer} from './node-layers/circle-layer';
16
+ import {ImageLayer} from './node-layers/image-layer';
17
+ import {LabelLayer} from './node-layers/label-layer';
18
+ import {RectangleLayer} from './node-layers/rectangle-layer';
19
+ import {RoundedRectangleLayer} from './node-layers/rounded-rectangle-layer';
20
+ import {PathBasedRoundedRectangleLayer} from './node-layers/path-rounded-rectange-layer';
21
+ import {ZoomableMarkerLayer} from './node-layers/zoomable-marker-layer';
22
+
23
+ // edge layers
24
+ import {EdgeLayer} from './edge-layer';
25
+ import {EdgeLabelLayer} from './edge-layers/edge-label-layer';
26
+ import {FlowLayer} from './edge-layers/flow-layer';
27
+
28
+ const NODE_LAYER_MAP = {
29
+ [NODE_TYPE.RECTANGLE]: RectangleLayer,
30
+ [NODE_TYPE.ROUNDED_RECTANGLE]: RoundedRectangleLayer,
31
+ [NODE_TYPE.PATH_ROUNDED_RECTANGLE]: PathBasedRoundedRectangleLayer,
32
+ [NODE_TYPE.ICON]: ImageLayer,
33
+ [NODE_TYPE.CIRCLE]: CircleLayer,
34
+ [NODE_TYPE.LABEL]: LabelLayer,
35
+ [NODE_TYPE.MARKER]: ZoomableMarkerLayer
36
+ };
37
+
38
+ const EDGE_DECORATOR_LAYER_MAP = {
39
+ [EDGE_DECORATOR_TYPE.LABEL]: EdgeLabelLayer,
40
+ [EDGE_DECORATOR_TYPE.FLOW]: FlowLayer
41
+ };
42
+
43
+ const SHARED_LAYER_PROPS = {
44
+ coordinateSystem: COORDINATE_SYSTEM.CARTESIAN,
45
+ parameters: {
46
+ depthTest: false
47
+ }
48
+ };
49
+ const defaultProps = {
50
+ // an array of styles for layers
51
+ nodeStyle: [],
52
+ nodeEvents: {
53
+ onMouseLeave: () => {},
54
+ onHover: () => {},
55
+ onMouseEnter: () => {},
56
+ onClick: () => {},
57
+ onDrag: () => {}
58
+ },
59
+ edgeStyle: {
60
+ color: 'black',
61
+ strokeWidth: 1,
62
+ // an array of styles for layers
63
+ decorators: []
64
+ },
65
+ edgeEvents: {
66
+ onClick: () => {},
67
+ onHover: () => {}
68
+ },
69
+ enableDragging: false
70
+ };
71
+
72
+ export class GraphLayer extends CompositeLayer {
73
+ static defaultProps = {
74
+ pickable: true
75
+ };
76
+
77
+ forceUpdate = () => {
78
+ if (this.context && this.context.layerManager) {
79
+ this.setNeedsUpdate();
80
+ this.setChangeFlags({dataChanged: true} as any); // TODO
81
+ }
82
+ };
83
+
84
+ constructor(props) {
85
+ super(props);
86
+
87
+ // added or removed a node, or in general something layout related changed
88
+ props.engine.addEventListener('onLayoutChange', this.forceUpdate);
89
+ }
90
+
91
+ initializeState() {
92
+ const interactionManager = new InteractionManager(this.props as any, () => this.forceUpdate());
93
+ this.state = {interactionManager};
94
+ }
95
+
96
+ shouldUpdateState({changeFlags}) {
97
+ return changeFlags.dataChanged || changeFlags.propsChanged;
98
+ }
99
+
100
+ updateState({props}) {
101
+ (this.state.interactionManager as any).updateProps(props);
102
+ }
103
+
104
+ finalize() {
105
+ (this.props as any).engine.removeEventListener('onLayoutChange', this.forceUpdate);
106
+ }
107
+
108
+ createNodeLayers() {
109
+ const {engine, nodeStyle} = this.props as any;
110
+ if (!nodeStyle || !Array.isArray(nodeStyle) || nodeStyle.length === 0) {
111
+ return [];
112
+ }
113
+ return nodeStyle.filter(Boolean).map((style, idx) => {
114
+ const {pickable = true, visible = true, data = (nodes) => nodes, ...restStyle} = style;
115
+ const LayerType = NODE_LAYER_MAP[style.type];
116
+ if (!LayerType) {
117
+ log.error(`Invalid node type: ${style.type}`)();
118
+ throw new Error(`Invalid node type: ${style.type}`);
119
+ }
120
+ const stylesheet = new Stylesheet(restStyle, {
121
+ stateUpdateTrigger: (this.state.interactionManager as any).getLastInteraction()
122
+ });
123
+ const getOffset = stylesheet.getDeckGLAccessor('getOffset');
124
+ return new LayerType({
125
+ ...SHARED_LAYER_PROPS,
126
+ id: `node-rule-${idx}`,
127
+ data: data(engine.getNodes()),
128
+ getPosition: mixedGetPosition(engine.getNodePosition, getOffset),
129
+ pickable,
130
+ positionUpdateTrigger: [
131
+ engine.getLayoutLastUpdate(),
132
+ engine.getLayoutState(),
133
+ stylesheet.getDeckGLAccessorUpdateTrigger('getOffset')
134
+ ].join(),
135
+ stylesheet,
136
+ visible
137
+ } as any);
138
+ });
139
+ }
140
+
141
+ createEdgeLayers() {
142
+ const {edgeStyle, engine} = this.props as any;
143
+
144
+ if (!edgeStyle) {
145
+ return [];
146
+ }
147
+
148
+ return (Array.isArray(edgeStyle) ? edgeStyle : [edgeStyle])
149
+ .filter(Boolean)
150
+ .flatMap((style, idx) => {
151
+ const {decorators, data = (edges) => edges, visible = true, ...restEdgeStyle} = style;
152
+ const stylesheet = new Stylesheet(
153
+ {
154
+ type: 'Edge',
155
+ ...restEdgeStyle
156
+ },
157
+ {
158
+ stateUpdateTrigger: (this.state.interactionManager as any).getLastInteraction()
159
+ }
160
+ );
161
+
162
+ const edgeLayer = new EdgeLayer({
163
+ ...SHARED_LAYER_PROPS,
164
+ id: `edge-layer-${idx}`,
165
+ data: data(engine.getEdges()),
166
+ getLayoutInfo: engine.getEdgePosition,
167
+ pickable: true,
168
+ positionUpdateTrigger: [engine.getLayoutLastUpdate(), engine.getLayoutState()].join(),
169
+ stylesheet,
170
+ visible
171
+ } as any);
172
+
173
+ if (!decorators || !Array.isArray(decorators) || decorators.length === 0) {
174
+ return edgeLayer;
175
+ }
176
+ const decoratorLayers = decorators.filter(Boolean).flatMap((decoratorStyle, idx2) => {
177
+ const DecoratorLayer = EDGE_DECORATOR_LAYER_MAP[decoratorStyle.type];
178
+ if (!DecoratorLayer) {
179
+ log.error(`Invalid edge decorator type: ${decoratorStyle.type}`)();
180
+ throw new Error(`Invalid edge decorator type: ${decoratorStyle.type}`);
181
+ }
182
+ const decoratorStylesheet = new Stylesheet(decoratorStyle, {
183
+ stateUpdateTrigger: (this.state.interactionManager as any).getLastInteraction()
184
+ });
185
+ return new DecoratorLayer({
186
+ ...SHARED_LAYER_PROPS,
187
+ id: `edge-decorator-${idx2}`,
188
+ data: data(engine.getEdges()),
189
+ getLayoutInfo: engine.getEdgePosition,
190
+ pickable: true,
191
+ positionUpdateTrigger: [engine.getLayoutLastUpdate(), engine.getLayoutState()].join(),
192
+ stylesheet: decoratorStylesheet
193
+ } as any);
194
+ });
195
+ return [edgeLayer, decoratorLayers];
196
+ });
197
+ }
198
+
199
+ onClick(info, event): boolean {
200
+ return (this.state.interactionManager as any).onClick(info, event) || false;
201
+ }
202
+
203
+ onHover(info, event): boolean {
204
+ return (this.state.interactionManager as any).onHover(info, event) || false;
205
+ }
206
+
207
+ onDragStart(info, event) {
208
+ (this.state.interactionManager as any).onDragStart(info, event);
209
+ }
210
+
211
+ onDrag(info, event) {
212
+ (this.state.interactionManager as any).onDrag(info, event);
213
+ }
214
+
215
+ onDragEnd(info, event) {
216
+ (this.state.interactionManager as any).onDragEnd(info, event);
217
+ }
218
+
219
+ renderLayers() {
220
+ return [this.createEdgeLayers(), this.createNodeLayers()];
221
+ }
222
+ }
223
+
224
+ GraphLayer.layerName = 'GraphLayer';
225
+ (GraphLayer as any).defaultProps = defaultProps;
@@ -0,0 +1,29 @@
1
+ // deck.gl-community
2
+ // SPDX-License-Identifier: MIT
3
+ // Copyright (c) vis.gl contributors
4
+
5
+ import {CompositeLayer} from '@deck.gl/core';
6
+ import {ScatterplotLayer} from '@deck.gl/layers';
7
+
8
+ export class CircleLayer extends CompositeLayer {
9
+ static layerName = 'CircleLayer';
10
+
11
+ renderLayers() {
12
+ const {data, getPosition, stylesheet, positionUpdateTrigger = 0} = this.props as any;
13
+
14
+ return [
15
+ new ScatterplotLayer(
16
+ this.getSubLayerProps({
17
+ id: '__scatterplot-layer',
18
+ data,
19
+ getPosition,
20
+ ...stylesheet.getDeckGLAccessors(),
21
+ updateTriggers: {
22
+ getPosition: positionUpdateTrigger,
23
+ ...stylesheet.getDeckGLUpdateTriggers()
24
+ }
25
+ })
26
+ )
27
+ ];
28
+ }
29
+ }