@unovis/ts 1.1.1-beta.6 → 1.1.1-beta.7

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 (710) hide show
  1. package/declaration.d.ts +1 -0
  2. package/index.ts +1 -0
  3. package/licences.txt +43 -0
  4. package/maps.ts +1 -0
  5. package/package.json +1 -1
  6. package/rollup.config.js +71 -0
  7. package/rules/ts-getter-setter.js +35 -0
  8. package/src/components/area/config.ts +29 -0
  9. package/src/components/area/index.ts +133 -0
  10. package/{components/area/style.js → src/components/area/style.ts} +9 -10
  11. package/src/components/area/types.ts +2 -0
  12. package/src/components/axis/config.ts +76 -0
  13. package/src/components/axis/index.ts +363 -0
  14. package/{components/axis/style.js → src/components/axis/style.ts} +27 -22
  15. package/src/components/axis/types.ts +4 -0
  16. package/src/components/brush/config.ts +51 -0
  17. package/src/components/brush/index.ts +233 -0
  18. package/{components/brush/style.js → src/components/brush/style.ts} +15 -14
  19. package/src/components/brush/types.ts +8 -0
  20. package/src/components/bullet-legend/config.ts +38 -0
  21. package/src/components/bullet-legend/index.ts +104 -0
  22. package/{components/bullet-legend/style.js → src/components/bullet-legend/style.ts} +18 -16
  23. package/src/components/bullet-legend/types.ts +7 -0
  24. package/src/components/chord-diagram/config.ts +53 -0
  25. package/src/components/chord-diagram/index.ts +401 -0
  26. package/src/components/chord-diagram/modules/label.ts +155 -0
  27. package/src/components/chord-diagram/modules/link.ts +91 -0
  28. package/src/components/chord-diagram/modules/node.ts +80 -0
  29. package/{components/chord-diagram/style.js → src/components/chord-diagram/style.ts} +39 -30
  30. package/src/components/chord-diagram/types.ts +68 -0
  31. package/src/components/crosshair/config.ts +48 -0
  32. package/src/components/crosshair/index.ts +220 -0
  33. package/{components/crosshair/style.js → src/components/crosshair/style.ts} +12 -12
  34. package/src/components/crosshair/types.ts +15 -0
  35. package/src/components/donut/config.ts +65 -0
  36. package/src/components/donut/index.ts +148 -0
  37. package/src/components/donut/modules/arc.ts +86 -0
  38. package/{components/donut/style.js → src/components/donut/style.ts} +20 -18
  39. package/src/components/donut/types.ts +17 -0
  40. package/src/components/flow-legend/config.ts +31 -0
  41. package/src/components/flow-legend/index.ts +103 -0
  42. package/{components/flow-legend/style.js → src/components/flow-legend/style.ts} +25 -21
  43. package/src/components/flow-legend/types.ts +10 -0
  44. package/src/components/free-brush/config.ts +54 -0
  45. package/src/components/free-brush/index.ts +207 -0
  46. package/{components/free-brush/style.js → src/components/free-brush/style.ts} +12 -12
  47. package/src/components/free-brush/types.ts +8 -0
  48. package/src/components/graph/config.ts +280 -0
  49. package/src/components/graph/index.ts +809 -0
  50. package/src/components/graph/modules/layout-helpers.ts +96 -0
  51. package/src/components/graph/modules/layout.ts +502 -0
  52. package/src/components/graph/modules/link/helper.ts +105 -0
  53. package/src/components/graph/modules/link/index.ts +302 -0
  54. package/{components/graph/modules/link/style.js → src/components/graph/modules/link/style.ts} +45 -34
  55. package/src/components/graph/modules/node/helper.ts +162 -0
  56. package/src/components/graph/modules/node/index.ts +343 -0
  57. package/{components/graph/modules/node/style.js → src/components/graph/modules/node/style.ts} +72 -52
  58. package/src/components/graph/modules/panel/helper.ts +160 -0
  59. package/src/components/graph/modules/panel/index.ts +137 -0
  60. package/{components/graph/modules/panel/style.js → src/components/graph/modules/panel/style.ts} +42 -32
  61. package/src/components/graph/modules/shape.ts +108 -0
  62. package/src/components/graph/modules/zoom-levels.ts +6 -0
  63. package/src/components/graph/style.ts +72 -0
  64. package/src/components/graph/types.ts +152 -0
  65. package/src/components/grouped-bar/config.ts +40 -0
  66. package/src/components/grouped-bar/index.ts +325 -0
  67. package/{components/grouped-bar/style.js → src/components/grouped-bar/style.ts} +15 -14
  68. package/src/components/leaflet-flow-map/config.ts +60 -0
  69. package/src/components/leaflet-flow-map/index.ts +279 -0
  70. package/src/components/leaflet-flow-map/renderer-utils.ts +14 -0
  71. package/src/components/leaflet-flow-map/renderer.ts +146 -0
  72. package/{components/leaflet-flow-map/shaders.js → src/components/leaflet-flow-map/shaders.ts} +4 -7
  73. package/src/components/leaflet-flow-map/types.ts +18 -0
  74. package/src/components/leaflet-map/config.ts +234 -0
  75. package/src/components/leaflet-map/index.ts +808 -0
  76. package/src/components/leaflet-map/leaflet.css +625 -0
  77. package/src/components/leaflet-map/modules/clusterBackground.ts +34 -0
  78. package/src/components/leaflet-map/modules/donut.ts +37 -0
  79. package/src/components/leaflet-map/modules/map.ts +178 -0
  80. package/src/components/leaflet-map/modules/node.ts +208 -0
  81. package/src/components/leaflet-map/modules/selectionRing.ts +63 -0
  82. package/src/components/leaflet-map/modules/utils.ts +290 -0
  83. package/{components → src/components}/leaflet-map/renderer/leaflet-maplibre-gl.js +76 -78
  84. package/src/components/leaflet-map/renderer/map-style.ts +24 -0
  85. package/src/components/leaflet-map/renderer/mapboxgl/mapboxgl-dark-theme.json +35 -0
  86. package/src/components/leaflet-map/renderer/mapboxgl/mapboxgl-light-theme.json +35 -0
  87. package/src/components/leaflet-map/renderer/mapboxgl/mapboxgl-settings.json +2185 -0
  88. package/src/components/leaflet-map/renderer/mapboxgl-layer.ts +43 -0
  89. package/src/components/leaflet-map/renderer/mapboxgl-utils.ts +40 -0
  90. package/{components → src/components}/leaflet-map/renderer/maplibre-gl.css.js +2 -4
  91. package/src/components/leaflet-map/style.ts +217 -0
  92. package/src/components/leaflet-map/types.ts +75 -0
  93. package/src/components/line/config.ts +34 -0
  94. package/src/components/line/index.ts +188 -0
  95. package/{components/line/style.js → src/components/line/style.ts} +18 -16
  96. package/src/components/line/types.ts +3 -0
  97. package/src/components/nested-donut/config.ts +75 -0
  98. package/src/components/nested-donut/index.ts +176 -0
  99. package/src/components/nested-donut/modules/arc.ts +78 -0
  100. package/src/components/nested-donut/modules/label.ts +63 -0
  101. package/src/components/nested-donut/style.ts +82 -0
  102. package/src/components/nested-donut/types.ts +29 -0
  103. package/src/components/sankey/config.ts +195 -0
  104. package/src/components/sankey/index.ts +387 -0
  105. package/src/components/sankey/modules/label.ts +228 -0
  106. package/src/components/sankey/modules/link.ts +141 -0
  107. package/src/components/sankey/modules/node.ts +221 -0
  108. package/{components/sankey/style.js → src/components/sankey/style.ts} +60 -44
  109. package/src/components/sankey/types.ts +95 -0
  110. package/src/components/scatter/config.ts +49 -0
  111. package/src/components/scatter/index.ts +220 -0
  112. package/src/components/scatter/modules/point.ts +123 -0
  113. package/src/components/scatter/modules/utils.ts +150 -0
  114. package/{components/scatter/style.js → src/components/scatter/style.ts} +15 -14
  115. package/src/components/scatter/types.ts +21 -0
  116. package/src/components/stacked-bar/config.ts +42 -0
  117. package/src/components/stacked-bar/index.ts +267 -0
  118. package/{components/stacked-bar/style.js → src/components/stacked-bar/style.ts} +15 -14
  119. package/src/components/stacked-bar/types.ts +5 -0
  120. package/src/components/timeline/config.ts +49 -0
  121. package/src/components/timeline/index.ts +302 -0
  122. package/{components/timeline/style.js → src/components/timeline/style.ts} +39 -30
  123. package/src/components/tooltip/config.ts +69 -0
  124. package/src/components/tooltip/index.ts +220 -0
  125. package/{components → src/components}/tooltip/style.js +11 -14
  126. package/src/components/topojson-map/config.ts +124 -0
  127. package/src/components/topojson-map/index.ts +436 -0
  128. package/{components/topojson-map/style.js → src/components/topojson-map/style.ts} +33 -26
  129. package/src/components/topojson-map/types.ts +123 -0
  130. package/src/components/topojson-map/utils.ts +29 -0
  131. package/src/components/vis-controls/config.ts +16 -0
  132. package/src/components/vis-controls/index.ts +68 -0
  133. package/{components/vis-controls/style.js → src/components/vis-controls/style.ts} +34 -27
  134. package/src/components/vis-controls/types.ts +14 -0
  135. package/src/components/xy-labels/config.ts +56 -0
  136. package/src/components/xy-labels/index.ts +109 -0
  137. package/src/components/xy-labels/modules/label.ts +140 -0
  138. package/{components/xy-labels/style.js → src/components/xy-labels/style.ts} +15 -14
  139. package/src/components/xy-labels/types.ts +26 -0
  140. package/src/components.ts +56 -0
  141. package/src/containers/single-container/config.ts +15 -0
  142. package/src/containers/single-container/index.ts +150 -0
  143. package/src/containers/xy-container/config.ts +112 -0
  144. package/src/containers/xy-container/index.ts +407 -0
  145. package/src/containers.ts +6 -0
  146. package/src/core/component/config.ts +61 -0
  147. package/src/core/component/index.ts +154 -0
  148. package/src/core/component/types.ts +9 -0
  149. package/src/core/config/index.ts +12 -0
  150. package/src/core/container/config.ts +56 -0
  151. package/src/core/container/index.ts +136 -0
  152. package/src/core/xy-component/config.ts +46 -0
  153. package/src/core/xy-component/index.ts +90 -0
  154. package/src/data-models/core.ts +15 -0
  155. package/src/data-models/graph.ts +138 -0
  156. package/src/data-models/map-graph.ts +72 -0
  157. package/src/data-models/map.ts +18 -0
  158. package/src/data-models/series.ts +16 -0
  159. package/src/index.ts +7 -0
  160. package/src/maps/china-provinces.json +1 -0
  161. package/src/maps/fr-regions.json +1 -0
  162. package/src/maps/germany-regions.json +1 -0
  163. package/src/maps/ind-regions.json +1 -0
  164. package/src/maps/uk-regions.json +1 -0
  165. package/src/maps/us-counties.json +1 -0
  166. package/src/maps/us-states.json +1 -0
  167. package/src/maps/world-110m-alpha.json +1 -0
  168. package/src/maps/world-simple.json +1 -0
  169. package/src/maps/world-simplest.json +1 -0
  170. package/src/maps.ts +34 -0
  171. package/src/styles/colors.ts +28 -0
  172. package/src/styles/index.ts +38 -0
  173. package/{styles/sizes.js → src/styles/sizes.ts} +6 -8
  174. package/src/types/accessor.ts +5 -0
  175. package/src/types/component.ts +15 -0
  176. package/src/types/curve.ts +62 -0
  177. package/src/types/data.ts +5 -0
  178. package/src/types/direction.ts +6 -0
  179. package/src/types/graph.ts +40 -0
  180. package/src/types/map.ts +5 -0
  181. package/src/types/misc.ts +10 -0
  182. package/src/types/position.ts +23 -0
  183. package/src/types/scale.ts +47 -0
  184. package/src/types/shape.ts +7 -0
  185. package/src/types/spacing.ts +6 -0
  186. package/src/types/svg.ts +32 -0
  187. package/src/types/symbol.ts +21 -0
  188. package/src/types/text.ts +71 -0
  189. package/src/types.ts +31 -0
  190. package/src/utils/color.ts +41 -0
  191. package/src/utils/d3.ts +15 -0
  192. package/src/utils/data.ts +328 -0
  193. package/src/utils/html.ts +13 -0
  194. package/src/utils/map.ts +29 -0
  195. package/src/utils/misc.ts +54 -0
  196. package/src/utils/path.ts +196 -0
  197. package/src/utils/scale.ts +1 -0
  198. package/src/utils/style.ts +37 -0
  199. package/src/utils/svg.ts +49 -0
  200. package/src/utils/text.ts +529 -0
  201. package/src/utils/type.ts +9 -0
  202. package/tsconfig.json +29 -0
  203. package/components/area/config.d.ts +0 -25
  204. package/components/area/config.js +0 -16
  205. package/components/area/config.js.map +0 -1
  206. package/components/area/index.d.ts +0 -19
  207. package/components/area/index.js +0 -102
  208. package/components/area/index.js.map +0 -1
  209. package/components/area/style.d.ts +0 -3
  210. package/components/area/style.js.map +0 -1
  211. package/components/area/types.d.ts +0 -6
  212. package/components/axis/config.d.ts +0 -71
  213. package/components/axis/config.js +0 -32
  214. package/components/axis/config.js.map +0 -1
  215. package/components/axis/index.d.ts +0 -44
  216. package/components/axis/index.js +0 -305
  217. package/components/axis/index.js.map +0 -1
  218. package/components/axis/style.d.ts +0 -9
  219. package/components/axis/style.js.map +0 -1
  220. package/components/axis/types.d.ts +0 -4
  221. package/components/axis/types.js +0 -8
  222. package/components/axis/types.js.map +0 -1
  223. package/components/brush/config.d.ts +0 -42
  224. package/components/brush/config.js +0 -24
  225. package/components/brush/config.js.map +0 -1
  226. package/components/brush/index.d.ts +0 -28
  227. package/components/brush/index.js +0 -199
  228. package/components/brush/index.js.map +0 -1
  229. package/components/brush/style.d.ts +0 -5
  230. package/components/brush/style.js.map +0 -1
  231. package/components/brush/types.d.ts +0 -7
  232. package/components/brush/types.js +0 -8
  233. package/components/brush/types.js.map +0 -1
  234. package/components/bullet-legend/config.d.ts +0 -34
  235. package/components/bullet-legend/config.js +0 -16
  236. package/components/bullet-legend/config.js.map +0 -1
  237. package/components/bullet-legend/index.d.ts +0 -19
  238. package/components/bullet-legend/index.js +0 -79
  239. package/components/bullet-legend/index.js.map +0 -1
  240. package/components/bullet-legend/style.d.ts +0 -6
  241. package/components/bullet-legend/style.js.map +0 -1
  242. package/components/bullet-legend/types.d.ts +0 -7
  243. package/components/bullet-legend/types.js +0 -2
  244. package/components/bullet-legend/types.js.map +0 -1
  245. package/components/chord-diagram/config.d.ts +0 -44
  246. package/components/chord-diagram/config.js +0 -25
  247. package/components/chord-diagram/config.js.map +0 -1
  248. package/components/chord-diagram/index.d.ts +0 -42
  249. package/components/chord-diagram/index.js +0 -305
  250. package/components/chord-diagram/index.js.map +0 -1
  251. package/components/chord-diagram/modules/label.d.ts +0 -8
  252. package/components/chord-diagram/modules/label.js +0 -115
  253. package/components/chord-diagram/modules/label.js.map +0 -1
  254. package/components/chord-diagram/modules/link.d.ts +0 -21
  255. package/components/chord-diagram/modules/link.js +0 -63
  256. package/components/chord-diagram/modules/link.js.map +0 -1
  257. package/components/chord-diagram/modules/node.d.ts +0 -17
  258. package/components/chord-diagram/modules/node.js +0 -52
  259. package/components/chord-diagram/modules/node.js.map +0 -1
  260. package/components/chord-diagram/style.d.ts +0 -13
  261. package/components/chord-diagram/style.js.map +0 -1
  262. package/components/chord-diagram/types.d.ts +0 -58
  263. package/components/chord-diagram/types.js +0 -8
  264. package/components/chord-diagram/types.js.map +0 -1
  265. package/components/crosshair/config.d.ts +0 -43
  266. package/components/crosshair/config.js +0 -19
  267. package/components/crosshair/config.js.map +0 -1
  268. package/components/crosshair/index.d.ts +0 -35
  269. package/components/crosshair/index.js +0 -183
  270. package/components/crosshair/index.js.map +0 -1
  271. package/components/crosshair/style.d.ts +0 -4
  272. package/components/crosshair/style.js.map +0 -1
  273. package/components/crosshair/types.d.ts +0 -13
  274. package/components/crosshair/types.js +0 -2
  275. package/components/crosshair/types.js.map +0 -1
  276. package/components/donut/config.d.ts +0 -59
  277. package/components/donut/config.js +0 -28
  278. package/components/donut/config.js.map +0 -1
  279. package/components/donut/index.d.ts +0 -21
  280. package/components/donut/index.js +0 -107
  281. package/components/donut/index.js.map +0 -1
  282. package/components/donut/modules/arc.d.ts +0 -10
  283. package/components/donut/modules/arc.js +0 -59
  284. package/components/donut/modules/arc.js.map +0 -1
  285. package/components/donut/style.d.ts +0 -7
  286. package/components/donut/style.js.map +0 -1
  287. package/components/donut/types.d.ts +0 -20
  288. package/components/flow-legend/config.d.ts +0 -29
  289. package/components/flow-legend/config.js +0 -18
  290. package/components/flow-legend/config.js.map +0 -1
  291. package/components/flow-legend/index.d.ts +0 -16
  292. package/components/flow-legend/index.js +0 -75
  293. package/components/flow-legend/index.js.map +0 -1
  294. package/components/flow-legend/style.d.ts +0 -8
  295. package/components/flow-legend/style.js.map +0 -1
  296. package/components/flow-legend/types.d.ts +0 -9
  297. package/components/flow-legend/types.js +0 -8
  298. package/components/flow-legend/types.js.map +0 -1
  299. package/components/free-brush/config.d.ts +0 -45
  300. package/components/free-brush/config.js +0 -24
  301. package/components/free-brush/config.js.map +0 -1
  302. package/components/free-brush/index.d.ts +0 -20
  303. package/components/free-brush/index.js +0 -192
  304. package/components/free-brush/index.js.map +0 -1
  305. package/components/free-brush/style.d.ts +0 -4
  306. package/components/free-brush/style.js.map +0 -1
  307. package/components/free-brush/types.d.ts +0 -7
  308. package/components/free-brush/types.js +0 -9
  309. package/components/free-brush/types.js.map +0 -1
  310. package/components/graph/config.d.ts +0 -238
  311. package/components/graph/config.js +0 -84
  312. package/components/graph/config.js.map +0 -1
  313. package/components/graph/index.d.ts +0 -126
  314. package/components/graph/index.js +0 -656
  315. package/components/graph/index.js.map +0 -1
  316. package/components/graph/modules/layout-helpers.d.ts +0 -21
  317. package/components/graph/modules/layout-helpers.js +0 -69
  318. package/components/graph/modules/layout-helpers.js.map +0 -1
  319. package/components/graph/modules/layout.d.ts +0 -10
  320. package/components/graph/modules/layout.js +0 -399
  321. package/components/graph/modules/layout.js.map +0 -1
  322. package/components/graph/modules/link/helper.d.ts +0 -25
  323. package/components/graph/modules/link/helper.js +0 -74
  324. package/components/graph/modules/link/helper.js.map +0 -1
  325. package/components/graph/modules/link/index.d.ts +0 -11
  326. package/components/graph/modules/link/index.js +0 -212
  327. package/components/graph/modules/link/index.js.map +0 -1
  328. package/components/graph/modules/link/style.d.ts +0 -15
  329. package/components/graph/modules/link/style.js.map +0 -1
  330. package/components/graph/modules/node/helper.d.ts +0 -21
  331. package/components/graph/modules/node/helper.js +0 -126
  332. package/components/graph/modules/node/helper.js.map +0 -1
  333. package/components/graph/modules/node/index.d.ts +0 -11
  334. package/components/graph/modules/node/index.js +0 -252
  335. package/components/graph/modules/node/index.js.map +0 -1
  336. package/components/graph/modules/node/style.d.ts +0 -24
  337. package/components/graph/modules/node/style.js.map +0 -1
  338. package/components/graph/modules/panel/helper.d.ts +0 -18
  339. package/components/graph/modules/panel/helper.js +0 -111
  340. package/components/graph/modules/panel/helper.js.map +0 -1
  341. package/components/graph/modules/panel/index.d.ts +0 -7
  342. package/components/graph/modules/panel/index.js +0 -98
  343. package/components/graph/modules/panel/index.js.map +0 -1
  344. package/components/graph/modules/panel/style.d.ts +0 -14
  345. package/components/graph/modules/panel/style.js.map +0 -1
  346. package/components/graph/modules/shape.d.ts +0 -6
  347. package/components/graph/modules/shape.js +0 -80
  348. package/components/graph/modules/shape.js.map +0 -1
  349. package/components/graph/modules/zoom-levels.d.ts +0 -6
  350. package/components/graph/modules/zoom-levels.js +0 -10
  351. package/components/graph/modules/zoom-levels.js.map +0 -1
  352. package/components/graph/style.d.ts +0 -6
  353. package/components/graph/style.js +0 -66
  354. package/components/graph/style.js.map +0 -1
  355. package/components/graph/types.d.ts +0 -125
  356. package/components/graph/types.js +0 -30
  357. package/components/graph/types.js.map +0 -1
  358. package/components/grouped-bar/config.d.ts +0 -36
  359. package/components/grouped-bar/config.js +0 -20
  360. package/components/grouped-bar/config.js.map +0 -1
  361. package/components/grouped-bar/index.d.ts +0 -32
  362. package/components/grouped-bar/index.js +0 -249
  363. package/components/grouped-bar/index.js.map +0 -1
  364. package/components/grouped-bar/style.d.ts +0 -5
  365. package/components/grouped-bar/style.js.map +0 -1
  366. package/components/leaflet-flow-map/config.d.ts +0 -46
  367. package/components/leaflet-flow-map/config.js +0 -25
  368. package/components/leaflet-flow-map/config.js.map +0 -1
  369. package/components/leaflet-flow-map/index.d.ts +0 -52
  370. package/components/leaflet-flow-map/index.js +0 -220
  371. package/components/leaflet-flow-map/index.js.map +0 -1
  372. package/components/leaflet-flow-map/renderer-utils.d.ts +0 -5
  373. package/components/leaflet-flow-map/renderer-utils.js +0 -15
  374. package/components/leaflet-flow-map/renderer-utils.js.map +0 -1
  375. package/components/leaflet-flow-map/renderer.d.ts +0 -26
  376. package/components/leaflet-flow-map/renderer.js +0 -117
  377. package/components/leaflet-flow-map/renderer.js.map +0 -1
  378. package/components/leaflet-flow-map/shaders.d.ts +0 -2
  379. package/components/leaflet-flow-map/shaders.js.map +0 -1
  380. package/components/leaflet-flow-map/types.d.ts +0 -23
  381. package/components/leaflet-map/config.d.ts +0 -193
  382. package/components/leaflet-map/config.js +0 -71
  383. package/components/leaflet-map/config.js.map +0 -1
  384. package/components/leaflet-map/index.d.ts +0 -130
  385. package/components/leaflet-map/index.js +0 -690
  386. package/components/leaflet-map/index.js.map +0 -1
  387. package/components/leaflet-map/leaflet.css.js +0 -5
  388. package/components/leaflet-map/leaflet.css.js.map +0 -1
  389. package/components/leaflet-map/modules/clusterBackground.d.ts +0 -5
  390. package/components/leaflet-map/modules/clusterBackground.js +0 -27
  391. package/components/leaflet-map/modules/clusterBackground.js.map +0 -1
  392. package/components/leaflet-map/modules/donut.d.ts +0 -3
  393. package/components/leaflet-map/modules/donut.js +0 -25
  394. package/components/leaflet-map/modules/donut.js.map +0 -1
  395. package/components/leaflet-map/modules/map.d.ts +0 -14
  396. package/components/leaflet-map/modules/map.js +0 -154
  397. package/components/leaflet-map/modules/map.js.map +0 -1
  398. package/components/leaflet-map/modules/node.d.ts +0 -9
  399. package/components/leaflet-map/modules/node.js +0 -162
  400. package/components/leaflet-map/modules/node.js.map +0 -1
  401. package/components/leaflet-map/modules/selectionRing.d.ts +0 -7
  402. package/components/leaflet-map/modules/selectionRing.js +0 -41
  403. package/components/leaflet-map/modules/selectionRing.js.map +0 -1
  404. package/components/leaflet-map/modules/utils.d.ts +0 -50
  405. package/components/leaflet-map/modules/utils.js +0 -210
  406. package/components/leaflet-map/modules/utils.js.map +0 -1
  407. package/components/leaflet-map/renderer/leaflet-maplibre-gl.js.map +0 -1
  408. package/components/leaflet-map/renderer/map-style.d.ts +0 -4
  409. package/components/leaflet-map/renderer/map-style.js +0 -15
  410. package/components/leaflet-map/renderer/map-style.js.map +0 -1
  411. package/components/leaflet-map/renderer/mapboxgl/mapboxgl-dark-theme.json.js +0 -40
  412. package/components/leaflet-map/renderer/mapboxgl/mapboxgl-dark-theme.json.js.map +0 -1
  413. package/components/leaflet-map/renderer/mapboxgl/mapboxgl-light-theme.json.js +0 -40
  414. package/components/leaflet-map/renderer/mapboxgl/mapboxgl-light-theme.json.js.map +0 -1
  415. package/components/leaflet-map/renderer/mapboxgl/mapboxgl-settings.json.js +0 -4981
  416. package/components/leaflet-map/renderer/mapboxgl/mapboxgl-settings.json.js.map +0 -1
  417. package/components/leaflet-map/renderer/mapboxgl-layer.d.ts +0 -8
  418. package/components/leaflet-map/renderer/mapboxgl-layer.js +0 -27
  419. package/components/leaflet-map/renderer/mapboxgl-layer.js.map +0 -1
  420. package/components/leaflet-map/renderer/mapboxgl-utils.d.ts +0 -4
  421. package/components/leaflet-map/renderer/mapboxgl-utils.js +0 -39
  422. package/components/leaflet-map/renderer/mapboxgl-utils.js.map +0 -1
  423. package/components/leaflet-map/renderer/maplibre-gl.css.js.map +0 -1
  424. package/components/leaflet-map/style.d.ts +0 -52
  425. package/components/leaflet-map/style.js +0 -183
  426. package/components/leaflet-map/style.js.map +0 -1
  427. package/components/leaflet-map/types.d.ts +0 -75
  428. package/components/leaflet-map/types.js +0 -15
  429. package/components/leaflet-map/types.js.map +0 -1
  430. package/components/line/config.d.ts +0 -30
  431. package/components/line/config.js +0 -17
  432. package/components/line/config.js.map +0 -1
  433. package/components/line/index.d.ts +0 -27
  434. package/components/line/index.js +0 -152
  435. package/components/line/index.js.map +0 -1
  436. package/components/line/style.d.ts +0 -6
  437. package/components/line/style.js.map +0 -1
  438. package/components/line/types.d.ts +0 -12
  439. package/components/nested-donut/config.d.ts +0 -59
  440. package/components/nested-donut/config.js +0 -19
  441. package/components/nested-donut/config.js.map +0 -1
  442. package/components/nested-donut/index.d.ts +0 -38
  443. package/components/nested-donut/index.js +0 -133
  444. package/components/nested-donut/index.js.map +0 -1
  445. package/components/nested-donut/modules/arc.d.ts +0 -17
  446. package/components/nested-donut/modules/arc.js +0 -50
  447. package/components/nested-donut/modules/arc.js.map +0 -1
  448. package/components/nested-donut/modules/label.d.ts +0 -7
  449. package/components/nested-donut/modules/label.js +0 -34
  450. package/components/nested-donut/modules/label.js.map +0 -1
  451. package/components/nested-donut/style.d.ts +0 -26
  452. package/components/nested-donut/style.js +0 -70
  453. package/components/nested-donut/style.js.map +0 -1
  454. package/components/nested-donut/types.d.ts +0 -24
  455. package/components/nested-donut/types.js +0 -11
  456. package/components/nested-donut/types.js.map +0 -1
  457. package/components/sankey/config.d.ts +0 -162
  458. package/components/sankey/config.js +0 -65
  459. package/components/sankey/config.js.map +0 -1
  460. package/components/sankey/index.d.ts +0 -59
  461. package/components/sankey/index.js +0 -306
  462. package/components/sankey/index.js.map +0 -1
  463. package/components/sankey/modules/label.d.ts +0 -23
  464. package/components/sankey/modules/label.js +0 -168
  465. package/components/sankey/modules/label.js.map +0 -1
  466. package/components/sankey/modules/link.d.ts +0 -14
  467. package/components/sankey/modules/link.js +0 -108
  468. package/components/sankey/modules/link.js.map +0 -1
  469. package/components/sankey/modules/node.d.ts +0 -10
  470. package/components/sankey/modules/node.js +0 -156
  471. package/components/sankey/modules/node.js.map +0 -1
  472. package/components/sankey/style.d.ts +0 -20
  473. package/components/sankey/style.js.map +0 -1
  474. package/components/sankey/types.d.ts +0 -84
  475. package/components/sankey/types.js +0 -34
  476. package/components/sankey/types.js.map +0 -1
  477. package/components/scatter/config.d.ts +0 -44
  478. package/components/scatter/config.js +0 -23
  479. package/components/scatter/config.js.map +0 -1
  480. package/components/scatter/index.d.ts +0 -28
  481. package/components/scatter/index.js +0 -167
  482. package/components/scatter/index.js.map +0 -1
  483. package/components/scatter/modules/point.d.ts +0 -7
  484. package/components/scatter/modules/point.js +0 -86
  485. package/components/scatter/modules/point.js.map +0 -1
  486. package/components/scatter/modules/utils.d.ts +0 -11
  487. package/components/scatter/modules/utils.js +0 -112
  488. package/components/scatter/modules/utils.js.map +0 -1
  489. package/components/scatter/style.d.ts +0 -5
  490. package/components/scatter/style.js.map +0 -1
  491. package/components/scatter/types.d.ts +0 -19
  492. package/components/stacked-bar/config.d.ts +0 -38
  493. package/components/stacked-bar/config.js +0 -20
  494. package/components/stacked-bar/config.js.map +0 -1
  495. package/components/stacked-bar/index.d.ts +0 -28
  496. package/components/stacked-bar/index.js +0 -208
  497. package/components/stacked-bar/index.js.map +0 -1
  498. package/components/stacked-bar/style.d.ts +0 -5
  499. package/components/stacked-bar/style.js.map +0 -1
  500. package/components/stacked-bar/types.d.ts +0 -5
  501. package/components/timeline/config.d.ts +0 -43
  502. package/components/timeline/config.js +0 -24
  503. package/components/timeline/config.js.map +0 -1
  504. package/components/timeline/index.d.ts +0 -41
  505. package/components/timeline/index.js +0 -244
  506. package/components/timeline/index.js.map +0 -1
  507. package/components/timeline/style.d.ts +0 -13
  508. package/components/timeline/style.js.map +0 -1
  509. package/components/tooltip/config.d.ts +0 -68
  510. package/components/tooltip/config.js +0 -20
  511. package/components/tooltip/config.js.map +0 -1
  512. package/components/tooltip/index.d.ts +0 -36
  513. package/components/tooltip/index.js +0 -184
  514. package/components/tooltip/index.js.map +0 -1
  515. package/components/tooltip/style.js.map +0 -1
  516. package/components/topojson-map/config.d.ts +0 -99
  517. package/components/topojson-map/config.js +0 -42
  518. package/components/topojson-map/config.js.map +0 -1
  519. package/components/topojson-map/index.d.ts +0 -52
  520. package/components/topojson-map/index.js +0 -355
  521. package/components/topojson-map/index.js.map +0 -1
  522. package/components/topojson-map/style.d.ts +0 -11
  523. package/components/topojson-map/style.js.map +0 -1
  524. package/components/topojson-map/types.d.ts +0 -78
  525. package/components/topojson-map/types.js +0 -80
  526. package/components/topojson-map/types.js.map +0 -1
  527. package/components/topojson-map/utils.d.ts +0 -3
  528. package/components/topojson-map/utils.js +0 -30
  529. package/components/topojson-map/utils.js.map +0 -1
  530. package/components/vis-controls/config.d.ts +0 -12
  531. package/components/vis-controls/config.js +0 -13
  532. package/components/vis-controls/config.js.map +0 -1
  533. package/components/vis-controls/index.d.ts +0 -14
  534. package/components/vis-controls/index.js +0 -52
  535. package/components/vis-controls/index.js.map +0 -1
  536. package/components/vis-controls/style.d.ts +0 -11
  537. package/components/vis-controls/style.js.map +0 -1
  538. package/components/vis-controls/types.d.ts +0 -13
  539. package/components/vis-controls/types.js +0 -8
  540. package/components/vis-controls/types.js.map +0 -1
  541. package/components/xy-labels/config.d.ts +0 -48
  542. package/components/xy-labels/config.js +0 -25
  543. package/components/xy-labels/config.js.map +0 -1
  544. package/components/xy-labels/index.d.ts +0 -15
  545. package/components/xy-labels/index.js +0 -87
  546. package/components/xy-labels/index.js.map +0 -1
  547. package/components/xy-labels/modules/label.d.ts +0 -9
  548. package/components/xy-labels/modules/label.js +0 -107
  549. package/components/xy-labels/modules/label.js.map +0 -1
  550. package/components/xy-labels/style.d.ts +0 -5
  551. package/components/xy-labels/style.js.map +0 -1
  552. package/components/xy-labels/types.d.ts +0 -23
  553. package/components/xy-labels/types.js +0 -9
  554. package/components/xy-labels/types.js.map +0 -1
  555. package/components.d.ts +0 -51
  556. package/components.js +0 -29
  557. package/components.js.map +0 -1
  558. package/containers/single-container/config.d.ts +0 -12
  559. package/containers/single-container/config.js +0 -12
  560. package/containers/single-container/config.js.map +0 -1
  561. package/containers/single-container/index.d.ts +0 -19
  562. package/containers/single-container/index.js +0 -128
  563. package/containers/single-container/index.js.map +0 -1
  564. package/containers/xy-container/config.d.ts +0 -99
  565. package/containers/xy-container/config.js +0 -30
  566. package/containers/xy-container/config.js.map +0 -1
  567. package/containers/xy-container/index.d.ts +0 -34
  568. package/containers/xy-container/index.js +0 -330
  569. package/containers/xy-container/index.js.map +0 -1
  570. package/containers.d.ts +0 -6
  571. package/containers.js +0 -4
  572. package/containers.js.map +0 -1
  573. package/core/component/config.d.ts +0 -58
  574. package/core/component/config.js +0 -14
  575. package/core/component/config.js.map +0 -1
  576. package/core/component/index.d.ts +0 -43
  577. package/core/component/index.js +0 -118
  578. package/core/component/index.js.map +0 -1
  579. package/core/component/types.d.ts +0 -2
  580. package/core/component/types.js +0 -2
  581. package/core/component/types.js.map +0 -1
  582. package/core/config/index.d.ts +0 -3
  583. package/core/config/index.js +0 -16
  584. package/core/config/index.js.map +0 -1
  585. package/core/container/config.d.ts +0 -48
  586. package/core/container/config.js +0 -29
  587. package/core/container/config.js.map +0 -1
  588. package/core/container/index.d.ts +0 -26
  589. package/core/container/index.js +0 -105
  590. package/core/container/index.js.map +0 -1
  591. package/core/xy-component/config.d.ts +0 -38
  592. package/core/xy-component/config.js +0 -20
  593. package/core/xy-component/config.js.map +0 -1
  594. package/core/xy-component/index.d.ts +0 -27
  595. package/core/xy-component/index.js +0 -74
  596. package/core/xy-component/index.js.map +0 -1
  597. package/data-models/core.d.ts +0 -6
  598. package/data-models/core.js +0 -14
  599. package/data-models/core.js.map +0 -1
  600. package/data-models/graph.d.ts +0 -24
  601. package/data-models/graph.js +0 -107
  602. package/data-models/graph.js.map +0 -1
  603. package/data-models/map-graph.d.ts +0 -21
  604. package/data-models/map-graph.js +0 -62
  605. package/data-models/map-graph.js.map +0 -1
  606. package/data-models/map.d.ts +0 -5
  607. package/data-models/map.js +0 -12
  608. package/data-models/map.js.map +0 -1
  609. package/data-models/series.d.ts +0 -6
  610. package/data-models/series.js +0 -19
  611. package/data-models/series.js.map +0 -1
  612. package/index.d.ts +0 -7
  613. package/index.js +0 -55
  614. package/index.js.map +0 -1
  615. package/maps/china-provinces.json.js +0 -140373
  616. package/maps/fr-regions.json.js +0 -14162
  617. package/maps/germany-regions.json.js +0 -35760
  618. package/maps/ind-regions.json.js +0 -290584
  619. package/maps/uk-regions.json.js +0 -96233
  620. package/maps/us-counties.json.js +0 -206318
  621. package/maps/us-states.json.js +0 -16345
  622. package/maps/world-110m-alpha.json.js +0 -251366
  623. package/maps/world-simple.json.js +0 -89428
  624. package/maps/world-simplest.json.js +0 -28175
  625. package/maps.d.ts +0 -60
  626. package/maps.js +0 -23
  627. package/styles/colors.d.ts +0 -7
  628. package/styles/colors.js +0 -24
  629. package/styles/colors.js.map +0 -1
  630. package/styles/index.d.ts +0 -7
  631. package/styles/index.js +0 -38
  632. package/styles/index.js.map +0 -1
  633. package/styles/sizes.d.ts +0 -2
  634. package/styles/sizes.js.map +0 -1
  635. package/types/accessor.d.ts +0 -5
  636. package/types/accessor.js +0 -2
  637. package/types/accessor.js.map +0 -1
  638. package/types/component.d.ts +0 -13
  639. package/types/component.js +0 -14
  640. package/types/component.js.map +0 -1
  641. package/types/curve.d.ts +0 -40
  642. package/types/curve.js +0 -46
  643. package/types/curve.js.map +0 -1
  644. package/types/data.d.ts +0 -7
  645. package/types/data.js +0 -2
  646. package/types/data.js.map +0 -1
  647. package/types/direction.d.ts +0 -6
  648. package/types/direction.js +0 -10
  649. package/types/direction.js.map +0 -1
  650. package/types/graph.d.ts +0 -35
  651. package/types/graph.js +0 -2
  652. package/types/graph.js.map +0 -1
  653. package/types/map.d.ts +0 -4
  654. package/types/map.js +0 -2
  655. package/types/map.js.map +0 -1
  656. package/types/misc.d.ts +0 -8
  657. package/types/position.d.ts +0 -20
  658. package/types/position.js +0 -27
  659. package/types/position.js.map +0 -1
  660. package/types/scale.d.ts +0 -23
  661. package/types/scale.js +0 -27
  662. package/types/scale.js.map +0 -1
  663. package/types/shape.d.ts +0 -7
  664. package/types/shape.js +0 -11
  665. package/types/shape.js.map +0 -1
  666. package/types/spacing.d.ts +0 -6
  667. package/types/spacing.js +0 -2
  668. package/types/spacing.js.map +0 -1
  669. package/types/svg.d.ts +0 -18
  670. package/types/svg.js +0 -22
  671. package/types/svg.js.map +0 -1
  672. package/types/symbol.d.ts +0 -18
  673. package/types/symbol.js +0 -24
  674. package/types/symbol.js.map +0 -1
  675. package/types/text.d.ts +0 -47
  676. package/types/text.js +0 -26
  677. package/types/text.js.map +0 -1
  678. package/types.d.ts +0 -27
  679. package/types.js +0 -30
  680. package/types.js.map +0 -1
  681. package/utils/color.d.ts +0 -10
  682. package/utils/color.js +0 -32
  683. package/utils/color.js.map +0 -1
  684. package/utils/d3.d.ts +0 -3
  685. package/utils/d3.js +0 -16
  686. package/utils/d3.js.map +0 -1
  687. package/utils/data.d.ts +0 -45
  688. package/utils/data.js +0 -274
  689. package/utils/data.js.map +0 -1
  690. package/utils/html.d.ts +0 -1
  691. package/utils/html.js +0 -16
  692. package/utils/html.js.map +0 -1
  693. package/utils/map.d.ts +0 -2
  694. package/utils/map.js +0 -20
  695. package/utils/map.js.map +0 -1
  696. package/utils/misc.d.ts +0 -9
  697. package/utils/misc.js +0 -47
  698. package/utils/misc.js.map +0 -1
  699. package/utils/path.d.ts +0 -23
  700. package/utils/path.js +0 -144
  701. package/utils/path.js.map +0 -1
  702. package/utils/scale.d.ts +0 -1
  703. package/utils/style.d.ts +0 -6
  704. package/utils/style.js +0 -24
  705. package/utils/style.js.map +0 -1
  706. package/utils/svg.d.ts +0 -3
  707. package/utils/text.d.ts +0 -139
  708. package/utils/text.js +0 -443
  709. package/utils/text.js.map +0 -1
  710. package/utils/type.d.ts +0 -5
@@ -0,0 +1,401 @@
1
+ import { Selection } from 'd3-selection'
2
+ import { nest } from 'd3-collection'
3
+ import { HierarchyNode, hierarchy, partition } from 'd3-hierarchy'
4
+ import { arc, line } from 'd3-shape'
5
+ import { scalePow, ScalePower } from 'd3-scale'
6
+ import { max } from 'd3-array'
7
+
8
+ // Core
9
+ import { ComponentCore } from 'core/component'
10
+ import { GraphDataModel } from 'data-models/graph'
11
+
12
+ // Utils
13
+ import { getNumber, isNumber, groupBy, getString, getValue } from 'utils/data'
14
+ import { estimateStringPixelLength } from 'utils/text'
15
+
16
+ // Types
17
+ import { GraphNodeCore } from 'types/graph'
18
+ import { Spacing } from 'types/spacing'
19
+ import { Curve } from 'types/curve'
20
+
21
+ // Local Types
22
+ import {
23
+ ChordInputNode,
24
+ ChordInputLink,
25
+ ChordDiagramData,
26
+ ChordHierarchyNode,
27
+ ChordNode,
28
+ ChordRibbon,
29
+ ChordLabelAlignment,
30
+ ChordLeafNode,
31
+ ChordRibbonPoint,
32
+ ChordNodeDatum,
33
+ } from './types'
34
+
35
+ // Config
36
+ import { ChordDiagramConfig, ChordDiagramConfigInterface } from './config'
37
+
38
+ // Modules
39
+ import { createNode, updateNode, removeNode } from './modules/node'
40
+ import { createLabel, updateLabel, removeLabel, LABEL_PADDING } from './modules/label'
41
+ import { createLink, updateLink, removeLink } from './modules/link'
42
+
43
+ // Styles
44
+ import * as s from './style'
45
+
46
+ export class ChordDiagram<
47
+ N extends ChordInputNode,
48
+ L extends ChordInputLink,
49
+ > extends ComponentCore<
50
+ ChordDiagramData<N, L>,
51
+ ChordDiagramConfig<N, L>,
52
+ ChordDiagramConfigInterface<N, L>
53
+ > {
54
+ static selectors = s
55
+ config: ChordDiagramConfig<N, L> = new ChordDiagramConfig()
56
+ datamodel: GraphDataModel<N, L> = new GraphDataModel()
57
+
58
+ nodeGroup: Selection<SVGGElement, unknown, SVGGElement, unknown>
59
+ linkGroup: Selection<SVGGElement, unknown, SVGGElement, unknown>
60
+ labelGroup: Selection<SVGGElement, unknown, SVGGElement, unknown>
61
+ arcGen = arc<ChordNode<N>>()
62
+ radiusScale: ScalePower<number, number> = scalePow()
63
+ private _nodes: ChordNode<N>[] = []
64
+ private _links: ChordRibbon<N>[] = []
65
+ private _rootNode: ChordNode<N>
66
+
67
+ events = {
68
+ [ChordDiagram.selectors.node]: {
69
+ mouseover: this._onNodeMouseOver.bind(this),
70
+ mouseout: this._onNodeMouseOut.bind(this),
71
+ },
72
+ [ChordDiagram.selectors.link]: {
73
+ mouseover: this._onLinkMouseOver.bind(this),
74
+ mouseout: this._onLinkMouseOut.bind(this),
75
+ },
76
+ }
77
+
78
+ constructor (config?: ChordDiagramConfigInterface<N, L>) {
79
+ super()
80
+ if (config) this.config.init(config)
81
+ this.linkGroup = this.g.append('g').attr('class', s.links)
82
+ this.nodeGroup = this.g.append('g').attr('class', s.nodes)
83
+ this.labelGroup = this.g.append('g').attr('class', s.labels)
84
+ }
85
+
86
+ get bleed (): Spacing {
87
+ const { config } = this
88
+ let top = 0; let bottom = 0; let right = 0; let left = 0
89
+ const padding = 4 + LABEL_PADDING * 2
90
+ this._nodes.forEach(n => {
91
+ const nodeLabelAlignment = getValue(n.data, config.nodeLabelAlignment)
92
+ if (n.height === 0 && nodeLabelAlignment === ChordLabelAlignment.Perpendicular) {
93
+ const labelWidth = estimateStringPixelLength(getString(n.data as N, config.nodeLabel) ?? '', 16)
94
+ const [x, y] = this.arcGen.centroid(n)
95
+
96
+ if (x < 0) left = Math.max(left, labelWidth)
97
+ else right = Math.max(right, labelWidth)
98
+
99
+ if (y < 0) top = Math.max(top, labelWidth)
100
+ else bottom = Math.max(bottom, labelWidth)
101
+ }
102
+ })
103
+ left += padding
104
+ right += padding
105
+ bottom += padding
106
+ top += padding
107
+ return { top, bottom, left, right }
108
+ }
109
+
110
+ _render (customDuration?: number): void {
111
+ super._render(customDuration)
112
+ const { config, config: { radiusScaleExponent }, radiusScale } = this
113
+ const nodes = this._getHierarchyNodes()
114
+ const duration = isNumber(customDuration) ? customDuration : config.duration
115
+
116
+ this.arcGen
117
+ .startAngle(d => d.x0)
118
+ .endAngle(d => d.x1)
119
+ .cornerRadius(d => getNumber(d, config.cornerRadius))
120
+ .innerRadius(d => this.radiusScale(d.y1) - getNumber(d, config.nodeWidth))
121
+ .outerRadius(d => this.radiusScale(d.y1))
122
+
123
+ const linkLineGen = line().curve(Curve.catmullRom.alpha(0.25))
124
+
125
+ const hierarchyData = nodes
126
+
127
+ const partitionData = partition<N | ChordHierarchyNode<N>>().size([config.angleRange[1], 1])(hierarchyData) as ChordNode<N>
128
+ this._calculateRadialPosition(partitionData)
129
+
130
+ const size = Math.min(this._width, this._height)
131
+ const radius = size / 2 - max([this.bleed.top, this.bleed.bottom, this.bleed.left, this.bleed.right])
132
+ const labelWidth = size - radius - config.nodeWidth
133
+
134
+ radiusScale
135
+ .exponent(radiusScaleExponent)
136
+ .range([0, radius])
137
+
138
+ const partitionDataWithRoot = partitionData.descendants()
139
+ this._rootNode = partitionDataWithRoot.find(d => d.depth === 0)
140
+ this._nodes = partitionDataWithRoot.filter(d => d.depth !== 0) // Filter out the root node
141
+ this._links = this._getRibbons(partitionData)
142
+
143
+ // Create Node and Link state objects
144
+ this._nodes.forEach((node, i) => {
145
+ // Add hierarchy data for non leaf nodes
146
+ if (node.children) {
147
+ node.data = Object.assign(node.data, {
148
+ depth: node.depth,
149
+ height: node.height,
150
+ value: node.value,
151
+ ancestors: node.ancestors().map(d => (d.data as ChordHierarchyNode<N>).key),
152
+ })
153
+ }
154
+ node.x0 = Number.isNaN(node.x0) ? 0 : node.x0
155
+ node.x1 = Number.isNaN(node.x1) ? 0 : node.x1
156
+ node.uid = `${this.uid}-n${i}`
157
+ node._state = {}
158
+ })
159
+ this._links.forEach(link => { link._state = {} })
160
+
161
+ // Center the view
162
+ this.g.attr('transform', `translate(${this._width / 2},${this._height / 2})`)
163
+
164
+ // Links
165
+ const linksSelection = this.linkGroup
166
+ .selectAll<SVGPathElement, ChordRibbon<N>>(`.${s.link}`)
167
+ .data(this._links, d => String(d.data._id))
168
+
169
+ const linksEnter = linksSelection.enter().append('path')
170
+ .attr('class', s.link)
171
+ .call(createLink, linkLineGen)
172
+
173
+ const linksMerged = linksSelection.merge(linksEnter)
174
+ linksMerged.call(updateLink, config, linkLineGen, duration)
175
+
176
+ linksSelection.exit()
177
+ .call(removeLink, duration)
178
+
179
+ // Nodes
180
+ const nodesSelection = this.nodeGroup
181
+ .selectAll<SVGPathElement, ChordNode<N>>(`.${s.node}`)
182
+ .data(this._nodes, d => String(d.uid))
183
+
184
+ const nodesEnter = nodesSelection.enter().append('path')
185
+ .attr('class', s.node)
186
+ .call(createNode, config)
187
+
188
+ const nodesMerged = nodesSelection.merge(nodesEnter)
189
+ nodesMerged.call(updateNode, config, this.arcGen, duration)
190
+
191
+ nodesSelection.exit()
192
+ .call(removeNode, duration)
193
+
194
+ // Labels
195
+ const labels = this.labelGroup
196
+ .selectAll<SVGGElement, ChordNode<N>>(`.${s.gLabel}`)
197
+ .data(this._nodes, d => String(d.uid))
198
+
199
+ const labelEnter = labels.enter().append('g')
200
+ .attr('class', s.gLabel)
201
+ .call(createLabel, config, radiusScale)
202
+
203
+ const labelsMerged = labels.merge(labelEnter)
204
+ labelsMerged.call(updateLabel, config, labelWidth, radiusScale, duration)
205
+
206
+ labels.exit()
207
+ .attr('class', s.labelExit)
208
+ .call(removeLabel, duration)
209
+ }
210
+
211
+ private _getHierarchyNodes (): HierarchyNode<ChordNodeDatum<N>> {
212
+ const { config, datamodel: { nodes, links } } = this
213
+ nodes.forEach(n => { delete n._state.value })
214
+ links.forEach(l => {
215
+ delete l._state.points
216
+ l.source._state.value = (l.source._state.value || 0) + getNumber(l, config.linkValue)
217
+ l.target._state.value = (l.target._state.value || 0) + getNumber(l, config.linkValue)
218
+ })
219
+
220
+ // TODO: Replace with d3-group
221
+ const nestGen = nest<N>()
222
+ config.nodeLevels.forEach(levelAccessor => {
223
+ nestGen.key(d => d[levelAccessor])
224
+ })
225
+ const root = { key: 'root', values: nestGen.entries(nodes) }
226
+ const hierarchyNodes = hierarchy(root, d => d.values)
227
+ .sum((d) => (d as unknown as GraphNodeCore<N, L>)._state?.value)
228
+
229
+ return hierarchyNodes
230
+ }
231
+
232
+ private _getRibbons (partitionData: ChordNode<N>): ChordRibbon<N>[] {
233
+ const { config, datamodel: { links } } = this
234
+ const findNode = (
235
+ nodes: ChordLeafNode<N>[],
236
+ id: string
237
+ ): ChordLeafNode<N> => nodes.find(n => n.data._id === id)
238
+ const leafNodes = partitionData.leaves() as ChordLeafNode<N>[]
239
+
240
+ type LinksArrayType = typeof links
241
+ const groupedBySource: Record<string, LinksArrayType> = groupBy(links, d => d.source._id)
242
+ const groupedByTarget: Record<string, LinksArrayType> = groupBy(links, d => d.target._id)
243
+
244
+ const getNodesInRibbon = (
245
+ source: ChordLeafNode<N>,
246
+ target: ChordLeafNode<N>,
247
+ partitionHeight: number,
248
+ nodes: ChordLeafNode<N>[] = []
249
+ ): ChordNode<N>[] => {
250
+ nodes[source.height] = source
251
+ nodes[partitionHeight * 2 - target.height] = target
252
+ if (source.parent && target.parent) getNodesInRibbon(source.parent, target.parent, partitionHeight, nodes)
253
+ return nodes
254
+ }
255
+
256
+ const calculatePoints = (
257
+ links: LinksArrayType,
258
+ type: 'in' | 'out',
259
+ depth: number
260
+ ): void => {
261
+ links.forEach(link => {
262
+ if (!link._state.points) link._state.points = []
263
+ const sourceLeaf = findNode(leafNodes, link.source._id)
264
+ const targetLeaf = findNode(leafNodes, link.target._id)
265
+ const nodesInRibbon = getNodesInRibbon(
266
+ type === 'out' ? sourceLeaf : targetLeaf,
267
+ type === 'out' ? targetLeaf : sourceLeaf,
268
+ partitionData.height)
269
+ const currNode = nodesInRibbon[depth]
270
+ const len = currNode.x1 - currNode.x0
271
+ const x0 = currNode._prevX1 ?? currNode.x0
272
+ const x1 = x0 + len * getNumber(link, config.linkValue) / currNode.value
273
+ currNode._prevX1 = x1
274
+
275
+ const pointIdx = type === 'out' ? depth : partitionData.height * 2 - 1 - depth
276
+ link._state.points[pointIdx] = this._convertRadialToCartesian(
277
+ Math.min(x0, x1),
278
+ Math.max(x0, x1),
279
+ currNode.y1,
280
+ config.nodeWidth
281
+ )
282
+ })
283
+ }
284
+
285
+ leafNodes.forEach(leafNode => {
286
+ const outLinks = groupedBySource[leafNode.data._id] || []
287
+ const inLinks = groupedByTarget[leafNode.data._id] || []
288
+ for (let depth = 0; depth < partitionData.height; depth += 1) {
289
+ calculatePoints(outLinks, 'out', depth)
290
+ calculatePoints(inLinks, 'in', depth)
291
+ }
292
+ })
293
+
294
+ const ribbons = links.map(l => {
295
+ const sourceNode = findNode(leafNodes, l.source._id)
296
+ const targetNode = findNode(leafNodes, l.target._id)
297
+
298
+ return {
299
+ source: sourceNode,
300
+ target: targetNode,
301
+ data: l,
302
+ points: l._state.points,
303
+ _state: {},
304
+ }
305
+ })
306
+
307
+ return ribbons
308
+ }
309
+
310
+ private _convertRadialToCartesian (x0: number, x1: number, y: number, nodeWidth: number): ChordRibbonPoint {
311
+ const r = Math.max(this.radiusScale(y) - nodeWidth, 0)
312
+ const a0 = x0 - Math.PI / 2
313
+ const a1 = x1 - Math.PI / 2
314
+
315
+ return {
316
+ a0,
317
+ a1,
318
+ r,
319
+ x0: r * Math.cos(a0),
320
+ x1: r * Math.cos(a1),
321
+ y0: r * Math.sin(a0),
322
+ y1: r * Math.sin(a1),
323
+ }
324
+ }
325
+
326
+ private _calculateRadialPosition (
327
+ hierarchyNode: ChordNode<N>,
328
+ scalingCoeff = 0.95,
329
+ nodePadding = 0.02
330
+ ): void {
331
+ if (!hierarchyNode.children) return
332
+
333
+ // Calculate x0 and x1
334
+ const nodeLength = (hierarchyNode.x1 - hierarchyNode.x0)
335
+ const scaledNodeLength = nodeLength * scalingCoeff
336
+ const delta = nodeLength - scaledNodeLength
337
+ let x0 = hierarchyNode.x0 + delta / 2
338
+ for (const node of hierarchyNode.children) {
339
+ const childX0 = x0
340
+ const childX1 = x0 + (node.value / hierarchyNode.value) * scaledNodeLength - nodePadding / 2
341
+ const childNodeLength = childX1 - childX0
342
+ const scaledChildNodeLength = childNodeLength * scalingCoeff
343
+ const childDelta = childNodeLength - scaledChildNodeLength
344
+ node.x0 = childX0 + childDelta / 2
345
+ node.x1 = node.x0 + scaledChildNodeLength
346
+ x0 = childX1 + nodePadding / 2 + childDelta / 2
347
+ }
348
+ // Go deeper in the hierarchy
349
+ for (const node of hierarchyNode.children) {
350
+ this._calculateRadialPosition(node, scalingCoeff, nodePadding)
351
+ }
352
+ }
353
+
354
+ private _onNodeMouseOver (d: ChordNode<N>): void {
355
+ let ribbons: ChordRibbon<N>[]
356
+ if (d.children) {
357
+ const leaves = d.leaves() as ChordLeafNode<N>[]
358
+ ribbons = this._links.filter(l =>
359
+ leaves.find(leaf => l.source.data.id === leaf.data.id || l.target.data.id === leaf.data.id)
360
+ )
361
+ } else {
362
+ const leaf = d as ChordLeafNode<N>
363
+ ribbons = this._links.filter(l => l.source.data.id === leaf.data.id || l.target.data.id === leaf.data.id)
364
+ }
365
+ this._highlightOnHover(ribbons)
366
+ }
367
+
368
+ private _onNodeMouseOut (): void {
369
+ this._highlightOnHover()
370
+ }
371
+
372
+ private _onLinkMouseOver (d: ChordRibbon<N>): void {
373
+ this._highlightOnHover([d])
374
+ }
375
+
376
+ private _onLinkMouseOut (): void {
377
+ this._highlightOnHover()
378
+ }
379
+
380
+ private _highlightOnHover (links?: ChordRibbon<N>[]): void {
381
+ if (links) {
382
+ links.forEach(l => {
383
+ l._state.hovered = true
384
+ const sourcePath = (l.source as ChordNode<N>).path(this._rootNode)
385
+ const targetPath = (l.target as ChordNode<N>).path(this._rootNode)
386
+ sourcePath.forEach(n => { if (n.depth) n._state.hovered = true })
387
+ targetPath.forEach(n => { if (n.depth) n._state.hovered = true })
388
+ })
389
+ } else {
390
+ this._nodes.forEach(n => { delete n._state.hovered })
391
+ this._links.forEach(l => { delete l._state.hovered })
392
+ }
393
+
394
+ this.nodeGroup.selectAll<SVGPathElement, ChordNode<N>>(`.${s.node}`)
395
+ .classed(s.hoveredNode, d => d._state.hovered)
396
+ this.linkGroup.selectAll<SVGPathElement, ChordRibbon<N>>(`.${s.link}`)
397
+ .classed(s.hoveredLink, d => d._state.hovered)
398
+
399
+ this.g.classed(s.transparent, !!links)
400
+ }
401
+ }
@@ -0,0 +1,155 @@
1
+ import { select, Selection } from 'd3-selection'
2
+ import { ScaleContinuousNumeric } from 'd3-scale'
3
+ import { color } from 'd3-color'
4
+
5
+ // Utils
6
+ import { trimSVGText } from 'utils/text'
7
+ import { smartTransition } from 'utils/d3'
8
+ import { getNumber, getString, getValue } from 'utils/data'
9
+ import { getColor, hexToBrightness } from 'utils/color'
10
+
11
+ // Config
12
+ import { ChordDiagramConfig } from '../config'
13
+
14
+ // Local Types
15
+ import { ChordInputLink, ChordInputNode, ChordLabelAlignment, ChordNode } from '../types'
16
+
17
+ // Styles
18
+ import * as s from '../style'
19
+
20
+ export const LABEL_PADDING = 3
21
+
22
+ function getLabelFillColor<N extends ChordInputNode, L extends ChordInputLink> (
23
+ d: ChordNode<N>,
24
+ config: ChordDiagramConfig<N, L>
25
+ ): string {
26
+ const nodeLabelAlignment = getValue(d.data, config.nodeLabelAlignment) ?? ChordLabelAlignment.Along
27
+ switch (nodeLabelAlignment) {
28
+ case ChordLabelAlignment.Perpendicular: {
29
+ return getColor(d.data, config.nodeColor, d.height)
30
+ }
31
+ case ChordLabelAlignment.Along: {
32
+ const c = getColor(d.data, config.nodeColor, d.height)
33
+ const colorParsed = color(c)
34
+ const brightness = colorParsed ? hexToBrightness(colorParsed.hex()) : 0
35
+ return brightness > 0.65 ? 'var(--vis-chord-diagram-label-text-fill-color-dark)' : 'var(--vis-chord-diagram-label-text-fill-color-bright)'
36
+ }
37
+ }
38
+ }
39
+
40
+ function getLabelTextAnchor<N extends ChordInputNode, L extends ChordInputLink> (
41
+ d: ChordNode<N>,
42
+ config: ChordDiagramConfig<N, L>
43
+ ): string | null {
44
+ const nodeLabelAlignment = getValue(d.data, config.nodeLabelAlignment) ?? ChordLabelAlignment.Along
45
+ switch (nodeLabelAlignment) {
46
+ case ChordLabelAlignment.Perpendicular: {
47
+ const angleCenter = (d.x0 + d.x1) / 2
48
+ const angleDegree = angleCenter * 180 / Math.PI
49
+ return angleDegree < 180 ? 'start' : 'end'
50
+ }
51
+ case ChordLabelAlignment.Along: {
52
+ return null
53
+ }
54
+ }
55
+ }
56
+
57
+ function getLabelTransform<N extends ChordInputNode, L extends ChordInputLink> (
58
+ d: ChordNode<N>,
59
+ config: ChordDiagramConfig<N, L>,
60
+ radiusScale: ScaleContinuousNumeric<number, number>
61
+ ): string | null {
62
+ const nodeLabelAlignment = getValue(d.data, config.nodeLabelAlignment) ?? ChordLabelAlignment.Along
63
+ switch (nodeLabelAlignment) {
64
+ case ChordLabelAlignment.Perpendicular: {
65
+ const r = radiusScale(d.y1) + LABEL_PADDING
66
+ const angleCenter = (d.x0 + d.x1) / 2
67
+ const angle = angleCenter - Math.PI / 2
68
+ const x = r * Math.cos(angle)
69
+ const y = r * Math.sin(angle)
70
+ return `translate(${x}, ${y})`
71
+ }
72
+ case ChordLabelAlignment.Along:
73
+ return null
74
+ }
75
+ }
76
+
77
+ export function createLabel<N extends ChordInputNode, L extends ChordInputLink> (
78
+ selection: Selection<SVGGElement, ChordNode<N>, SVGGElement, unknown>,
79
+ config: ChordDiagramConfig<N, L>,
80
+ radiusScale: ScaleContinuousNumeric<number, number>
81
+ ): void {
82
+ selection.style('opacity', 0)
83
+ .attr('transform', d => getLabelTransform(d, config, radiusScale))
84
+
85
+ selection.append('text')
86
+ .attr('class', s.label)
87
+ .style('fill', d => getColor(d.data, config.nodeColor, d.height))
88
+ }
89
+
90
+ export function updateLabel<N extends ChordInputNode, L extends ChordInputLink> (
91
+ selection: Selection<SVGGElement, ChordNode<N>, SVGGElement, unknown>,
92
+ config: ChordDiagramConfig<N, L>,
93
+ width: number,
94
+ radiusScale: ScaleContinuousNumeric<number, number>,
95
+ duration: number
96
+ ): void {
97
+ const { nodeLabel, nodeLabelColor, nodeWidth } = config
98
+
99
+ smartTransition(selection, duration)
100
+ .attr('transform', d => getLabelTransform(d, config, radiusScale))
101
+ .style('opacity', 1)
102
+
103
+ const label: Selection<SVGTextElement, ChordNode<N>, SVGElement, unknown> = selection.select(`.${s.label}`)
104
+ label.select('textPath').remove()
105
+ label
106
+ .text(d => getString(d.data, nodeLabel))
107
+ .style('fill', d => getColor(d.data, nodeLabelColor) ?? getLabelFillColor(d, config))
108
+ .style('text-anchor', d => getLabelTextAnchor(d, config))
109
+
110
+ label.each((d: ChordNode<N>, i: number, elements) => {
111
+ const nodeLabelAlignment = getValue(d.data, config.nodeLabelAlignment) ?? ChordLabelAlignment.Along
112
+ const radianArcLength = d.x1 - d.x0 - getNumber(d, config.padAngle) * 2
113
+ const radius = radiusScale(d.y1) - getNumber(d, config.nodeWidth) / 2
114
+ const arcLength = radius * radianArcLength
115
+ const maxWidth = (nodeLabelAlignment === ChordLabelAlignment.Along ? arcLength : width) - LABEL_PADDING * 2
116
+
117
+ const textElementSelection = select(elements[i])
118
+ trimSVGText(textElementSelection, maxWidth)
119
+ textElementSelection
120
+ .attr('dx', nodeLabelAlignment === ChordLabelAlignment.Along ? LABEL_PADDING : null)
121
+ .attr('dy', nodeLabelAlignment === ChordLabelAlignment.Along ? getNumber(d.data, nodeWidth) / 2 : null)
122
+
123
+ if (nodeLabelAlignment === ChordLabelAlignment.Along) {
124
+ const textElement = select(elements[i])
125
+ const textWidth = textElement.node().getBoundingClientRect().width
126
+ const labelText = textElement.text()
127
+
128
+ select(elements[i])
129
+ .text('')
130
+ .style('display', textWidth > maxWidth && 'none')
131
+
132
+ select(elements[i]).append('textPath')
133
+ .attr('href', `#${d.uid}`)
134
+ .text(labelText)
135
+ }
136
+ })
137
+
138
+ smartTransition(label, duration)
139
+ .attr('transform', d => {
140
+ const nodeLabelAlignment = getValue(d.data, config.nodeLabelAlignment)
141
+ if (nodeLabelAlignment !== ChordLabelAlignment.Perpendicular) return null
142
+ const angleCenter = (d.x0 + d.x1) / 2
143
+ const angleDegree = angleCenter * 180 / Math.PI
144
+ return `rotate(${angleDegree < 180 ? angleDegree - 90 : angleDegree + 90})`
145
+ })
146
+ }
147
+
148
+ export function removeLabel (
149
+ selection: Selection<SVGGElement, unknown, SVGGElement, unknown>,
150
+ duration: number
151
+ ): void {
152
+ smartTransition(selection, duration)
153
+ .style('opacity', 0)
154
+ .remove()
155
+ }
@@ -0,0 +1,91 @@
1
+ import { Selection, select } from 'd3-selection'
2
+ import { path } from 'd3-path'
3
+ import { Line } from 'd3-shape'
4
+ import { Transition } from 'd3-transition'
5
+ import { interpolatePath } from 'd3-interpolate-path'
6
+
7
+ // Utils
8
+ import { getColor } from 'utils/color'
9
+ import { smartTransition } from 'utils/d3'
10
+
11
+ // Local Types
12
+ import { ChordInputLink, ChordInputNode, ChordRibbon, ChordRibbonPoint } from '../types'
13
+ import { ChordDiagramConfig } from '../config'
14
+
15
+ export interface ArcLink extends SVGElement {
16
+ _animState?: {
17
+ source: { y0: number; y1: number };
18
+ target: { x0: number; x1: number; y1: number };
19
+ };
20
+ }
21
+
22
+ export function emptyPath (): string {
23
+ return 'M0,0 L0,0'
24
+ }
25
+
26
+ // Creates a path consisting of the inner source arc, node arcs and connecting curves
27
+ function linkGen (points: ChordRibbonPoint[], lineGen: Line<[number, number]>): string {
28
+ const p = path()
29
+ const sourceArc = points[0]
30
+ const targetArc = points[points.length - 1]
31
+
32
+ if (points.length === 2) {
33
+ // Writing a custom curve here since generators won't produce a curved line from only two points
34
+ p.moveTo(sourceArc.x1, sourceArc.y1)
35
+ p.quadraticCurveTo(0, 0, targetArc.x0, targetArc.y0)
36
+ p.arc(0, 0, targetArc.r, targetArc.a0, targetArc.a1)
37
+ p.quadraticCurveTo(0, 0, sourceArc.x0, sourceArc.y0)
38
+ p.arc(0, 0, sourceArc.r, sourceArc.a0, sourceArc.a1)
39
+ } else {
40
+ const inner: [number, number][] = points.map((d, i) => i < points.length / 2 ? [d.x1, d.y1] : [d.x0, d.y0])
41
+ const outer: [number, number][] = points.map((d, i) => i < points.length / 2 ? [d.x0, d.y0] : [d.x1, d.y1])
42
+
43
+ lineGen.context(p as CanvasRenderingContext2D)
44
+ lineGen(inner)
45
+ p.arc(0, 0, targetArc.r, targetArc.a0, targetArc.a1)
46
+ lineGen(outer.reverse())
47
+ p.arc(0, 0, sourceArc.r, sourceArc.a0, sourceArc.a1)
48
+ }
49
+ return p.toString()
50
+ }
51
+
52
+ export function createLink<N extends ChordInputNode> (
53
+ selection: Selection<SVGPathElement, ChordRibbon<N>, SVGGElement, unknown>,
54
+ lineGen: Line<[number, number]>
55
+ ): void {
56
+ selection
57
+ .attr('d', d => linkGen(d.points, lineGen) || emptyPath())
58
+ .style('opacity', 0)
59
+ }
60
+
61
+ export function updateLink<N extends ChordInputNode, L extends ChordInputLink> (
62
+ selection: Selection<SVGPathElement, ChordRibbon<N>, SVGGElement, unknown>,
63
+ config: ChordDiagramConfig<N, L>,
64
+ lineGen: Line<[number, number]>,
65
+ duration: number
66
+ ): void {
67
+ const selTransition = smartTransition(selection, duration)
68
+ .style('fill', d => getColor(d.data, config.linkColor))
69
+ .style('stroke', d => getColor(d.data, config.linkColor))
70
+ .style('opacity', 'var(--vis-chord-diagram-link-opacity)')
71
+
72
+ if (duration) {
73
+ const transition = selTransition as Transition<SVGPathElement, ChordRibbon<N>, SVGGElement, unknown>
74
+ transition.attrTween('d', (d, i, el) => {
75
+ const previous = select(el[i]).attr('d')
76
+ const next = linkGen(d.points, lineGen) || emptyPath()
77
+ return interpolatePath(previous, next)
78
+ })
79
+ } else {
80
+ selTransition.attr('d', d => linkGen(d.points, lineGen) || emptyPath())
81
+ }
82
+ }
83
+
84
+ export function removeLink (
85
+ selection: Selection<SVGPathElement, unknown, SVGGElement, unknown>,
86
+ duration: number
87
+ ): void {
88
+ smartTransition(selection, duration)
89
+ .style('opacity', 0)
90
+ .remove()
91
+ }