@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,427 @@
1
+ // deck.gl-community
2
+ // SPDX-License-Identifier: MIT
3
+ // Copyright (c) vis.gl contributors
4
+ /* eslint-disable */
5
+ export const MarkerMapping = {
6
+ 'bell-filled': {
7
+ x: 0,
8
+ y: 0,
9
+ width: 32,
10
+ height: 32,
11
+ mask: true
12
+ },
13
+ bell: {
14
+ x: 32,
15
+ y: 0,
16
+ width: 32,
17
+ height: 32,
18
+ mask: true
19
+ },
20
+ 'bookmark-filled': {
21
+ x: 0,
22
+ y: 32,
23
+ width: 32,
24
+ height: 32,
25
+ mask: true
26
+ },
27
+ bookmark: {
28
+ x: 32,
29
+ y: 32,
30
+ width: 32,
31
+ height: 32,
32
+ mask: true
33
+ },
34
+ 'cd-filled': {
35
+ x: 64,
36
+ y: 0,
37
+ width: 32,
38
+ height: 32,
39
+ mask: true
40
+ },
41
+ cd: {
42
+ x: 64,
43
+ y: 32,
44
+ width: 32,
45
+ height: 32,
46
+ mask: true
47
+ },
48
+ checkmark: {
49
+ x: 0,
50
+ y: 64,
51
+ width: 32,
52
+ height: 32,
53
+ mask: true
54
+ },
55
+ 'circle-check-filled': {
56
+ x: 32,
57
+ y: 64,
58
+ width: 32,
59
+ height: 32,
60
+ mask: true
61
+ },
62
+ 'circle-check': {
63
+ x: 64,
64
+ y: 64,
65
+ width: 32,
66
+ height: 32,
67
+ mask: true
68
+ },
69
+ 'circle-filled': {
70
+ x: 96,
71
+ y: 0,
72
+ width: 32,
73
+ height: 32,
74
+ mask: true
75
+ },
76
+ 'circle-i-filled': {
77
+ x: 96,
78
+ y: 32,
79
+ width: 32,
80
+ height: 32,
81
+ mask: true
82
+ },
83
+ 'circle-i': {
84
+ x: 96,
85
+ y: 64,
86
+ width: 32,
87
+ height: 32,
88
+ mask: true
89
+ },
90
+ 'circle-minus-filled': {
91
+ x: 0,
92
+ y: 96,
93
+ width: 32,
94
+ height: 32,
95
+ mask: true
96
+ },
97
+ 'circle-minus': {
98
+ x: 32,
99
+ y: 96,
100
+ width: 32,
101
+ height: 32,
102
+ mask: true
103
+ },
104
+ 'circle-plus-filled': {
105
+ x: 64,
106
+ y: 96,
107
+ width: 32,
108
+ height: 32,
109
+ mask: true
110
+ },
111
+ 'circle-plus': {
112
+ x: 96,
113
+ y: 96,
114
+ width: 32,
115
+ height: 32,
116
+ mask: true
117
+ },
118
+ 'circle-questionmark-filled': {
119
+ x: 128,
120
+ y: 0,
121
+ width: 32,
122
+ height: 32,
123
+ mask: true
124
+ },
125
+ 'circle-questionmark': {
126
+ x: 128,
127
+ y: 32,
128
+ width: 32,
129
+ height: 32,
130
+ mask: true
131
+ },
132
+ 'circle-slash-filled': {
133
+ x: 128,
134
+ y: 64,
135
+ width: 32,
136
+ height: 32,
137
+ mask: true
138
+ },
139
+ 'circle-slash': {
140
+ x: 128,
141
+ y: 96,
142
+ width: 32,
143
+ height: 32,
144
+ mask: true
145
+ },
146
+ 'circle-x-filled': {
147
+ x: 0,
148
+ y: 128,
149
+ width: 32,
150
+ height: 32,
151
+ mask: true
152
+ },
153
+ 'circle-x': {
154
+ x: 32,
155
+ y: 128,
156
+ width: 32,
157
+ height: 32,
158
+ mask: true
159
+ },
160
+ circle: {
161
+ x: 64,
162
+ y: 128,
163
+ width: 32,
164
+ height: 32,
165
+ mask: true
166
+ },
167
+ 'diamond-filled': {
168
+ x: 96,
169
+ y: 128,
170
+ width: 32,
171
+ height: 32,
172
+ mask: true
173
+ },
174
+ diamond: {
175
+ x: 128,
176
+ y: 128,
177
+ width: 32,
178
+ height: 32,
179
+ mask: true
180
+ },
181
+ 'flag-filled': {
182
+ x: 160,
183
+ y: 0,
184
+ width: 32,
185
+ height: 32,
186
+ mask: true
187
+ },
188
+ flag: {
189
+ x: 160,
190
+ y: 32,
191
+ width: 32,
192
+ height: 32,
193
+ mask: true
194
+ },
195
+ gear: {
196
+ x: 160,
197
+ y: 64,
198
+ width: 32,
199
+ height: 32,
200
+ mask: true
201
+ },
202
+ 'heart-filled': {
203
+ x: 160,
204
+ y: 96,
205
+ width: 32,
206
+ height: 32,
207
+ mask: true
208
+ },
209
+ heart: {
210
+ x: 160,
211
+ y: 128,
212
+ width: 32,
213
+ height: 32,
214
+ mask: true
215
+ },
216
+ 'location-marker-filled': {
217
+ x: 0,
218
+ y: 160,
219
+ width: 32,
220
+ height: 32,
221
+ mask: true
222
+ },
223
+ 'location-marker': {
224
+ x: 32,
225
+ y: 160,
226
+ width: 32,
227
+ height: 32,
228
+ mask: true
229
+ },
230
+ 'octagonal-star-filled': {
231
+ x: 64,
232
+ y: 160,
233
+ width: 32,
234
+ height: 32,
235
+ mask: true
236
+ },
237
+ 'octagonal-star': {
238
+ x: 96,
239
+ y: 160,
240
+ width: 32,
241
+ height: 32,
242
+ mask: true
243
+ },
244
+ 'person-filled': {
245
+ x: 128,
246
+ y: 160,
247
+ width: 32,
248
+ height: 32,
249
+ mask: true
250
+ },
251
+ person: {
252
+ x: 160,
253
+ y: 160,
254
+ width: 32,
255
+ height: 32,
256
+ mask: true
257
+ },
258
+ 'pin-filled': {
259
+ x: 192,
260
+ y: 0,
261
+ width: 32,
262
+ height: 32,
263
+ mask: true
264
+ },
265
+ pin: {
266
+ x: 192,
267
+ y: 32,
268
+ width: 32,
269
+ height: 32,
270
+ mask: true
271
+ },
272
+ 'plus-small': {
273
+ x: 192,
274
+ y: 64,
275
+ width: 32,
276
+ height: 32,
277
+ mask: true
278
+ },
279
+ plus: {
280
+ x: 192,
281
+ y: 96,
282
+ width: 32,
283
+ height: 32,
284
+ mask: true
285
+ },
286
+ 'rectangle-filled': {
287
+ x: 192,
288
+ y: 128,
289
+ width: 32,
290
+ height: 32,
291
+ mask: true
292
+ },
293
+ rectangle: {
294
+ x: 192,
295
+ y: 160,
296
+ width: 32,
297
+ height: 32,
298
+ mask: true
299
+ },
300
+ 'star-filled': {
301
+ x: 0,
302
+ y: 192,
303
+ width: 32,
304
+ height: 32,
305
+ mask: true
306
+ },
307
+ star: {
308
+ x: 32,
309
+ y: 192,
310
+ width: 32,
311
+ height: 32,
312
+ mask: true
313
+ },
314
+ 'tag-filled': {
315
+ x: 64,
316
+ y: 192,
317
+ width: 32,
318
+ height: 32,
319
+ mask: true
320
+ },
321
+ tag: {
322
+ x: 96,
323
+ y: 192,
324
+ width: 32,
325
+ height: 32,
326
+ mask: true
327
+ },
328
+ 'thumb-down-filled': {
329
+ x: 128,
330
+ y: 192,
331
+ width: 32,
332
+ height: 32,
333
+ mask: true
334
+ },
335
+ 'thumb-down': {
336
+ x: 160,
337
+ y: 192,
338
+ width: 32,
339
+ height: 32,
340
+ mask: true
341
+ },
342
+ 'thumb-up': {
343
+ x: 192,
344
+ y: 192,
345
+ width: 32,
346
+ height: 32,
347
+ mask: true
348
+ },
349
+ 'thumb_up-filled': {
350
+ x: 224,
351
+ y: 0,
352
+ width: 32,
353
+ height: 32,
354
+ mask: true
355
+ },
356
+ 'triangle-down-filled': {
357
+ x: 224,
358
+ y: 32,
359
+ width: 32,
360
+ height: 32,
361
+ mask: true
362
+ },
363
+ 'triangle-down': {
364
+ x: 224,
365
+ y: 64,
366
+ width: 32,
367
+ height: 32,
368
+ mask: true
369
+ },
370
+ 'triangle-left-filled': {
371
+ x: 224,
372
+ y: 96,
373
+ width: 32,
374
+ height: 32,
375
+ mask: true
376
+ },
377
+ 'triangle-left': {
378
+ x: 224,
379
+ y: 128,
380
+ width: 32,
381
+ height: 32,
382
+ mask: true
383
+ },
384
+ 'triangle-right-filled': {
385
+ x: 224,
386
+ y: 160,
387
+ width: 32,
388
+ height: 32,
389
+ mask: true
390
+ },
391
+ 'triangle-right': {
392
+ x: 224,
393
+ y: 192,
394
+ width: 32,
395
+ height: 32,
396
+ mask: true
397
+ },
398
+ 'triangle-up-filled': {
399
+ x: 0,
400
+ y: 224,
401
+ width: 32,
402
+ height: 32,
403
+ mask: true
404
+ },
405
+ 'triangle-up': {
406
+ x: 32,
407
+ y: 224,
408
+ width: 32,
409
+ height: 32,
410
+ mask: true
411
+ },
412
+ 'x-small': {
413
+ x: 64,
414
+ y: 224,
415
+ width: 32,
416
+ height: 32,
417
+ mask: true
418
+ },
419
+ x: {
420
+ x: 96,
421
+ y: 224,
422
+ width: 32,
423
+ height: 32,
424
+ mask: true
425
+ }
426
+ };
427
+ /* eslint-enable */
@@ -0,0 +1,24 @@
1
+ import { CompositeLayer } from '@deck.gl/core';
2
+ import { PathLayer } from '@deck.gl/layers';
3
+ export declare class SplineLayer extends CompositeLayer {
4
+ static layerName: string;
5
+ initializeState(): void;
6
+ shouldUpdateState({ changeFlags }: {
7
+ changeFlags: any;
8
+ }): any;
9
+ updateState({ props, oldProps, changeFlags }: {
10
+ props: any;
11
+ oldProps: any;
12
+ changeFlags: any;
13
+ }): void;
14
+ updateSplineData(): void;
15
+ renderLayers(): PathLayer<any, {
16
+ id: `${any}-splines`;
17
+ data: any;
18
+ getPath: (d: any) => any;
19
+ getColor: any;
20
+ getWidth: any;
21
+ coordinateSystem: any;
22
+ updateTriggers: any;
23
+ }>;
24
+ }
@@ -0,0 +1,68 @@
1
+ // deck.gl-community
2
+ // SPDX-License-Identifier: MIT
3
+ // Copyright (c) vis.gl contributors
4
+ import { COORDINATE_SYSTEM, CompositeLayer } from '@deck.gl/core';
5
+ import { PathLayer } from '@deck.gl/layers';
6
+ import { getCurvePoints } from 'cardinal-spline-js';
7
+ // const getCurvePoints = () => {};
8
+ /* Constants */
9
+ const defaultProps = {
10
+ id: 'spline-layer',
11
+ getData: (d) => d.points,
12
+ getAngle: (x) => 0,
13
+ fontSize: 24,
14
+ coordinateSystem: COORDINATE_SYSTEM.CARTESIAN,
15
+ fp64: false
16
+ };
17
+ export class SplineLayer extends CompositeLayer {
18
+ static layerName = 'SplineLayer';
19
+ initializeState() {
20
+ this.state = { typedEdgeData: [] };
21
+ }
22
+ shouldUpdateState({ changeFlags }) {
23
+ return changeFlags.dataChanged || changeFlags.propsChanged;
24
+ }
25
+ updateState({ props, oldProps, changeFlags }) {
26
+ super.updateState({ props, oldProps, changeFlags });
27
+ if (changeFlags.dataChanged || changeFlags.propsChanged) {
28
+ this.updateSplineData();
29
+ }
30
+ }
31
+ updateSplineData() {
32
+ const { data } = this.props;
33
+ const paths = data.reduce((res, d) => {
34
+ const sourcePosition = this.props.getSourcePosition(d);
35
+ const targetPosition = this.props.getTargetPosition(d);
36
+ const controlPoints = this.props.getControlPoints(d);
37
+ // Catmull-Rom curve
38
+ const serializedControlPoints = controlPoints.toString().split(',');
39
+ // NOTE: we might change the number of points according to the length.
40
+ // so we can render less segements.
41
+ // points = [x1, y1, x2, y2, ...];
42
+ const points = getCurvePoints([...sourcePosition, ...serializedControlPoints, ...targetPosition], 0.5, 10);
43
+ // convert points to [[x1, y1], [x2, y2], ...]
44
+ const path = [];
45
+ for (let idx = 0; idx < points.length; idx += 2) {
46
+ path.push([points[idx], points[idx + 1]]);
47
+ }
48
+ res.push(path);
49
+ return res;
50
+ }, []);
51
+ this.setState({ paths });
52
+ }
53
+ renderLayers() {
54
+ const { coordinateSystem, getColor, getWidth, id, updateTriggers } = this.props;
55
+ const { paths } = this.state;
56
+ return new PathLayer({
57
+ id: `${id}-splines`,
58
+ data: paths,
59
+ getPath: (d) => d,
60
+ getColor,
61
+ getWidth,
62
+ coordinateSystem,
63
+ updateTriggers
64
+ });
65
+ }
66
+ }
67
+ SplineLayer.layerName = 'SplineLayer';
68
+ SplineLayer.defaultProps = defaultProps;
@@ -0,0 +1,16 @@
1
+ import { CompositeLayer } from '@deck.gl/core';
2
+ import { TextLayer } from '@deck.gl/layers';
3
+ export declare class ZoomableTextLayer extends CompositeLayer {
4
+ static layerName: string;
5
+ initializeState(): void;
6
+ shouldUpdateState({ props, changeFlags }: {
7
+ props: any;
8
+ changeFlags: any;
9
+ }): any;
10
+ updateState({ props, oldProps, changeFlags }: {
11
+ props: any;
12
+ oldProps: any;
13
+ changeFlags: any;
14
+ }): void;
15
+ renderLayers(): TextLayer<any, {}>[];
16
+ }
@@ -0,0 +1,65 @@
1
+ // deck.gl-community
2
+ // SPDX-License-Identifier: MIT
3
+ // Copyright (c) vis.gl contributors
4
+ import { CompositeLayer } from '@deck.gl/core';
5
+ import { TextLayer } from '@deck.gl/layers';
6
+ export class ZoomableTextLayer extends CompositeLayer {
7
+ static layerName = 'ZoomableTextLayer';
8
+ initializeState() {
9
+ this.state = { characterSet: [] };
10
+ }
11
+ shouldUpdateState({ props, changeFlags }) {
12
+ const { scaleWithZoom } = this.props;
13
+ if (!scaleWithZoom) {
14
+ return changeFlags.dataChanged || changeFlags.propsChanged;
15
+ }
16
+ return changeFlags.dataChanged || changeFlags.propsChanged || changeFlags.viewportChanged;
17
+ }
18
+ updateState({ props, oldProps, changeFlags }) {
19
+ super.updateState({ props, oldProps, changeFlags });
20
+ if (changeFlags.propsOrDataChanged) {
21
+ const { getText } = props;
22
+ let textLabels = [];
23
+ if (typeof getText === 'function') {
24
+ textLabels = props.data.map(getText);
25
+ }
26
+ else {
27
+ textLabels = [getText];
28
+ }
29
+ const characterSet = new Set(textLabels.join(''));
30
+ const uniqueCharacters = Array.from(characterSet);
31
+ this.setState({ characterSet: uniqueCharacters });
32
+ }
33
+ }
34
+ renderLayers() {
35
+ const { data, getPosition, getColor, getText, getSize, getTextAnchor, getAlignmentBaseline, getAngle, scaleWithZoom, updateTriggers, fontFamily, textWordUnits, textWordBreak, textMaxWidth, textSizeMinPixels } = this.props;
36
+ const sizeUpdateTrigger = scaleWithZoom ? [getSize, this.context.viewport.zoom] : false;
37
+ // getText only expects function not plain value (string)
38
+ const newGetText = typeof getText === 'function' ? getText : () => getText;
39
+ return [
40
+ new TextLayer(this.getSubLayerProps({
41
+ id: '__text-layer',
42
+ data,
43
+ sizeScale: scaleWithZoom ? Math.pow(2, this.context.viewport.zoom - 1) : 1,
44
+ characterSet: this.state.characterSet,
45
+ getPosition,
46
+ getColor,
47
+ getSize,
48
+ getTextAnchor,
49
+ getAlignmentBaseline,
50
+ getAngle,
51
+ getText: newGetText,
52
+ maxWidth: textMaxWidth ?? 12,
53
+ wordBreak: textWordBreak ?? 'break-all',
54
+ fontFamily: fontFamily ?? 'Red Hat Text',
55
+ wordUnits: textWordUnits ?? 'pixels',
56
+ sizeMinPixels: textSizeMinPixels ?? 9,
57
+ updateTriggers: {
58
+ getSize: sizeUpdateTrigger,
59
+ getAngle: [sizeUpdateTrigger, updateTriggers.getPosition],
60
+ ...updateTriggers
61
+ }
62
+ }))
63
+ ];
64
+ }
65
+ }
@@ -0,0 +1,25 @@
1
+ import { CompositeLayer } from '@deck.gl/core';
2
+ import { StraightLineEdgeLayer } from '../layers/edge-layers/straight-line-edge-layer';
3
+ import { PathEdgeLayer } from './edge-layers/path-edge-layer';
4
+ import { CurvedEdgeLayer } from './edge-layers/curved-edge-layer';
5
+ export declare class EdgeLayer extends CompositeLayer {
6
+ static layerName: string;
7
+ static defaultProps: {
8
+ data: any[];
9
+ pickable: boolean;
10
+ getLayoutInfo: (d: any) => {
11
+ type: any;
12
+ sourcePosition: any;
13
+ targetPosition: any;
14
+ controlPoints: any[];
15
+ };
16
+ positionUpdateTrigger: number;
17
+ };
18
+ updateState({ props, oldProps, changeFlags }: {
19
+ props: any;
20
+ oldProps: any;
21
+ changeFlags: any;
22
+ }): void;
23
+ updateStateData(): void;
24
+ renderLayers(): (StraightLineEdgeLayer | PathEdgeLayer | CurvedEdgeLayer)[];
25
+ }
@@ -0,0 +1,75 @@
1
+ // deck.gl-community
2
+ // SPDX-License-Identifier: MIT
3
+ // Copyright (c) vis.gl contributors
4
+ import { COORDINATE_SYSTEM, CompositeLayer } from '@deck.gl/core';
5
+ import { EDGE_TYPE } from '../core/constants';
6
+ import { StraightLineEdgeLayer } from '../layers/edge-layers/straight-line-edge-layer';
7
+ import { PathEdgeLayer } from './edge-layers/path-edge-layer';
8
+ import { CurvedEdgeLayer } from './edge-layers/curved-edge-layer';
9
+ const EDGE_LAYER_MAP = {
10
+ [EDGE_TYPE.LINE]: StraightLineEdgeLayer,
11
+ [EDGE_TYPE.PATH]: PathEdgeLayer,
12
+ [EDGE_TYPE.SPLINE_CURVE]: CurvedEdgeLayer
13
+ };
14
+ export class EdgeLayer extends CompositeLayer {
15
+ static layerName = 'EdgeLayer';
16
+ static defaultProps = {
17
+ data: [],
18
+ pickable: true,
19
+ getLayoutInfo: (d) => ({
20
+ type: d.type,
21
+ sourcePosition: d.sourcePosition,
22
+ targetPosition: d.targetPosition,
23
+ controlPoints: []
24
+ }),
25
+ positionUpdateTrigger: 0
26
+ };
27
+ updateState({ props, oldProps, changeFlags }) {
28
+ super.updateState({ props, oldProps, changeFlags });
29
+ if (changeFlags.dataChanged) {
30
+ this.updateStateData();
31
+ }
32
+ }
33
+ updateStateData() {
34
+ const { data, getLayoutInfo } = this.props;
35
+ // bucket edges by types
36
+ const typedEdgeData = data.reduce((res, d) => {
37
+ const { type } = getLayoutInfo(d);
38
+ res[type].push(d);
39
+ return res;
40
+ }, {
41
+ [EDGE_TYPE.LINE]: [],
42
+ [EDGE_TYPE.PATH]: [],
43
+ [EDGE_TYPE.SPLINE_CURVE]: []
44
+ });
45
+ this.setState({ typedEdgeData });
46
+ }
47
+ renderLayers() {
48
+ const { getLayoutInfo, pickable, positionUpdateTrigger, stylesheet, id } = this.props;
49
+ const { typedEdgeData } = this.state;
50
+ // render lines by types (straight line, path, curves)
51
+ return Object.entries(typedEdgeData).map((e, idx) => {
52
+ const [type, edgeData] = e;
53
+ const Layer = EDGE_LAYER_MAP[type];
54
+ // invalid edge layer type
55
+ if (!Layer) {
56
+ return null;
57
+ }
58
+ return new Layer({
59
+ id: `${id}-${idx}`,
60
+ data: edgeData,
61
+ getLayoutInfo,
62
+ getColor: stylesheet.getDeckGLAccessor('getColor'),
63
+ getWidth: stylesheet.getDeckGLAccessor('getWidth'),
64
+ colorUpdateTrigger: stylesheet.getDeckGLAccessorUpdateTrigger('getColor'),
65
+ widthUpdateTrigger: stylesheet.getDeckGLAccessorUpdateTrigger('getWidth'),
66
+ positionUpdateTrigger,
67
+ pickable,
68
+ coordinateSystem: COORDINATE_SYSTEM.CARTESIAN,
69
+ parameters: {
70
+ depthCompare: 'always'
71
+ }
72
+ });
73
+ });
74
+ }
75
+ }
@@ -0,0 +1,6 @@
1
+ import { CompositeLayer } from '@deck.gl/core';
2
+ import { SplineLayer } from '../common-layers/spline-layer/spline-layer';
3
+ export declare class CurvedEdgeLayer extends CompositeLayer {
4
+ static layerName: string;
5
+ renderLayers(): (boolean | SplineLayer)[];
6
+ }