@visactor/vchart-extension 1.13.22-alpha.3 → 1.13.22

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 (369) hide show
  1. package/package.json +14 -9
  2. package/build/index.js +0 -14714
  3. package/build/index.min.js +0 -15
  4. package/cjs/charts/compare-sankey/compare-sankey-sub-data.d.ts +0 -21
  5. package/cjs/charts/compare-sankey/compare-sankey-sub-data.js +0 -118
  6. package/cjs/charts/compare-sankey/compare-sankey-sub-data.js.map +0 -1
  7. package/cjs/charts/compare-sankey/compare-sankey-sub-nodes.d.ts +0 -2
  8. package/cjs/charts/compare-sankey/compare-sankey-sub-nodes.js +0 -21
  9. package/cjs/charts/compare-sankey/compare-sankey-sub-nodes.js.map +0 -1
  10. package/cjs/charts/compare-sankey/compare-sankey-transformer.d.ts +0 -7
  11. package/cjs/charts/compare-sankey/compare-sankey-transformer.js +0 -25
  12. package/cjs/charts/compare-sankey/compare-sankey-transformer.js.map +0 -1
  13. package/cjs/charts/compare-sankey/compare-sankey.d.ts +0 -44
  14. package/cjs/charts/compare-sankey/compare-sankey.js +0 -196
  15. package/cjs/charts/compare-sankey/compare-sankey.js.map +0 -1
  16. package/cjs/charts/compare-sankey/index.d.ts +0 -2
  17. package/cjs/charts/compare-sankey/index.js +0 -21
  18. package/cjs/charts/compare-sankey/index.js.map +0 -1
  19. package/cjs/charts/compare-sankey/interface.d.ts +0 -24
  20. package/cjs/charts/compare-sankey/interface.js +0 -6
  21. package/cjs/charts/compare-sankey/interface.js.map +0 -1
  22. package/cjs/charts/compare-sankey/utils.d.ts +0 -9
  23. package/cjs/charts/compare-sankey/utils.js +0 -48
  24. package/cjs/charts/compare-sankey/utils.js.map +0 -1
  25. package/cjs/charts/compare-sankey-diff/compare-sankey-diff-data.d.ts +0 -8
  26. package/cjs/charts/compare-sankey-diff/compare-sankey-diff-data.js +0 -85
  27. package/cjs/charts/compare-sankey-diff/compare-sankey-diff-data.js.map +0 -1
  28. package/cjs/charts/compare-sankey-diff/compare-sankey-diff-transformer.d.ts +0 -7
  29. package/cjs/charts/compare-sankey-diff/compare-sankey-diff-transformer.js +0 -25
  30. package/cjs/charts/compare-sankey-diff/compare-sankey-diff-transformer.js.map +0 -1
  31. package/cjs/charts/compare-sankey-diff/compare-sankey-diff.d.ts +0 -34
  32. package/cjs/charts/compare-sankey-diff/compare-sankey-diff.js +0 -98
  33. package/cjs/charts/compare-sankey-diff/compare-sankey-diff.js.map +0 -1
  34. package/cjs/charts/compare-sankey-diff/index.d.ts +0 -2
  35. package/cjs/charts/compare-sankey-diff/index.js +0 -20
  36. package/cjs/charts/compare-sankey-diff/index.js.map +0 -1
  37. package/cjs/charts/compare-sankey-diff/interface.d.ts +0 -24
  38. package/cjs/charts/compare-sankey-diff/interface.js +0 -6
  39. package/cjs/charts/compare-sankey-diff/interface.js.map +0 -1
  40. package/cjs/charts/conversion-funnel/arrow-data-transform.d.ts +0 -24
  41. package/cjs/charts/conversion-funnel/arrow-data-transform.js +0 -99
  42. package/cjs/charts/conversion-funnel/arrow-data-transform.js.map +0 -1
  43. package/cjs/charts/conversion-funnel/conversion-funnel-transformer.d.ts +0 -7
  44. package/cjs/charts/conversion-funnel/conversion-funnel-transformer.js +0 -196
  45. package/cjs/charts/conversion-funnel/conversion-funnel-transformer.js.map +0 -1
  46. package/cjs/charts/conversion-funnel/conversion-funnel.d.ts +0 -40
  47. package/cjs/charts/conversion-funnel/conversion-funnel.js +0 -78
  48. package/cjs/charts/conversion-funnel/conversion-funnel.js.map +0 -1
  49. package/cjs/charts/conversion-funnel/index.d.ts +0 -2
  50. package/cjs/charts/conversion-funnel/index.js +0 -21
  51. package/cjs/charts/conversion-funnel/index.js.map +0 -1
  52. package/cjs/charts/conversion-funnel/interface.d.ts +0 -35
  53. package/cjs/charts/conversion-funnel/interface.js +0 -6
  54. package/cjs/charts/conversion-funnel/interface.js.map +0 -1
  55. package/cjs/charts/conversion-funnel/util.d.ts +0 -3
  56. package/cjs/charts/conversion-funnel/util.js +0 -17
  57. package/cjs/charts/conversion-funnel/util.js.map +0 -1
  58. package/cjs/charts/ranking-bar/interface.d.ts +0 -45
  59. package/cjs/charts/ranking-bar/interface.js +0 -6
  60. package/cjs/charts/ranking-bar/interface.js.map +0 -1
  61. package/cjs/charts/ranking-bar/ranking-bar-transformer.d.ts +0 -10
  62. package/cjs/charts/ranking-bar/ranking-bar-transformer.js +0 -291
  63. package/cjs/charts/ranking-bar/ranking-bar-transformer.js.map +0 -1
  64. package/cjs/charts/ranking-bar/ranking-bar.d.ts +0 -16
  65. package/cjs/charts/ranking-bar/ranking-bar.js +0 -34
  66. package/cjs/charts/ranking-bar/ranking-bar.js.map +0 -1
  67. package/cjs/charts/ranking-list/constant.d.ts +0 -2
  68. package/cjs/charts/ranking-list/constant.js +0 -75
  69. package/cjs/charts/ranking-list/constant.js.map +0 -1
  70. package/cjs/charts/ranking-list/interface.d.ts +0 -74
  71. package/cjs/charts/ranking-list/interface.js +0 -6
  72. package/cjs/charts/ranking-list/interface.js.map +0 -1
  73. package/cjs/charts/ranking-list/ranking-list-transformer.d.ts +0 -459
  74. package/cjs/charts/ranking-list/ranking-list-transformer.js +0 -383
  75. package/cjs/charts/ranking-list/ranking-list-transformer.js.map +0 -1
  76. package/cjs/charts/ranking-list/ranking-list.d.ts +0 -16
  77. package/cjs/charts/ranking-list/ranking-list.js +0 -34
  78. package/cjs/charts/ranking-list/ranking-list.js.map +0 -1
  79. package/cjs/charts/ranking-list/utils.d.ts +0 -7
  80. package/cjs/charts/ranking-list/utils.js +0 -51
  81. package/cjs/charts/ranking-list/utils.js.map +0 -1
  82. package/cjs/charts/sequence-scatter-kde/constant.d.ts +0 -3
  83. package/cjs/charts/sequence-scatter-kde/constant.js +0 -6
  84. package/cjs/charts/sequence-scatter-kde/constant.js.map +0 -1
  85. package/cjs/charts/sequence-scatter-kde/interface.d.ts +0 -29
  86. package/cjs/charts/sequence-scatter-kde/interface.js +0 -6
  87. package/cjs/charts/sequence-scatter-kde/interface.js.map +0 -1
  88. package/cjs/charts/sequence-scatter-kde/sequence-scatter-kde-transformer.d.ts +0 -6
  89. package/cjs/charts/sequence-scatter-kde/sequence-scatter-kde-transformer.js +0 -142
  90. package/cjs/charts/sequence-scatter-kde/sequence-scatter-kde-transformer.js.map +0 -1
  91. package/cjs/charts/sequence-scatter-kde/sequence-scatter-kde.d.ts +0 -16
  92. package/cjs/charts/sequence-scatter-kde/sequence-scatter-kde.js +0 -34
  93. package/cjs/charts/sequence-scatter-kde/sequence-scatter-kde.js.map +0 -1
  94. package/cjs/charts/sequence-scatter-kde/utils.d.ts +0 -9
  95. package/cjs/charts/sequence-scatter-kde/utils.js +0 -42
  96. package/cjs/charts/sequence-scatter-kde/utils.js.map +0 -1
  97. package/cjs/charts/sequence-scatter-link/interface.d.ts +0 -59
  98. package/cjs/charts/sequence-scatter-link/interface.js +0 -6
  99. package/cjs/charts/sequence-scatter-link/interface.js.map +0 -1
  100. package/cjs/charts/sequence-scatter-link/sequence-scatter-link-transformer.d.ts +0 -6
  101. package/cjs/charts/sequence-scatter-link/sequence-scatter-link-transformer.js +0 -328
  102. package/cjs/charts/sequence-scatter-link/sequence-scatter-link-transformer.js.map +0 -1
  103. package/cjs/charts/sequence-scatter-link/sequence-scatter-link.d.ts +0 -16
  104. package/cjs/charts/sequence-scatter-link/sequence-scatter-link.js +0 -34
  105. package/cjs/charts/sequence-scatter-link/sequence-scatter-link.js.map +0 -1
  106. package/cjs/charts/sequence-scatter-link/utils.d.ts +0 -9
  107. package/cjs/charts/sequence-scatter-link/utils.js +0 -108
  108. package/cjs/charts/sequence-scatter-link/utils.js.map +0 -1
  109. package/cjs/charts/sequence-scatter-pixel/constant.d.ts +0 -3
  110. package/cjs/charts/sequence-scatter-pixel/constant.js +0 -7
  111. package/cjs/charts/sequence-scatter-pixel/constant.js.map +0 -1
  112. package/cjs/charts/sequence-scatter-pixel/interface.d.ts +0 -29
  113. package/cjs/charts/sequence-scatter-pixel/interface.js +0 -6
  114. package/cjs/charts/sequence-scatter-pixel/interface.js.map +0 -1
  115. package/cjs/charts/sequence-scatter-pixel/sequence-scatter-pixel-transformer.d.ts +0 -4
  116. package/cjs/charts/sequence-scatter-pixel/sequence-scatter-pixel-transformer.js +0 -68
  117. package/cjs/charts/sequence-scatter-pixel/sequence-scatter-pixel-transformer.js.map +0 -1
  118. package/cjs/charts/sequence-scatter-pixel/sequence-scatter-pixel.d.ts +0 -16
  119. package/cjs/charts/sequence-scatter-pixel/sequence-scatter-pixel.js +0 -34
  120. package/cjs/charts/sequence-scatter-pixel/sequence-scatter-pixel.js.map +0 -1
  121. package/cjs/charts/sequence-scatter-pixel/utils.d.ts +0 -3
  122. package/cjs/charts/sequence-scatter-pixel/utils.js +0 -54
  123. package/cjs/charts/sequence-scatter-pixel/utils.js.map +0 -1
  124. package/cjs/components/bar-link/bar-link.d.ts +0 -7
  125. package/cjs/components/bar-link/bar-link.js +0 -87
  126. package/cjs/components/bar-link/bar-link.js.map +0 -1
  127. package/cjs/components/bar-link/constant.d.ts +0 -1
  128. package/cjs/components/bar-link/constant.js +0 -6
  129. package/cjs/components/bar-link/constant.js.map +0 -1
  130. package/cjs/components/bar-link/index.d.ts +0 -4
  131. package/cjs/components/bar-link/index.js +0 -48
  132. package/cjs/components/bar-link/index.js.map +0 -1
  133. package/cjs/components/bar-link/type.d.ts +0 -27
  134. package/cjs/components/bar-link/type.js +0 -6
  135. package/cjs/components/bar-link/type.js.map +0 -1
  136. package/cjs/components/bar-link/util.d.ts +0 -22
  137. package/cjs/components/bar-link/util.js +0 -183
  138. package/cjs/components/bar-link/util.js.map +0 -1
  139. package/cjs/components/series-break/constant.d.ts +0 -1
  140. package/cjs/components/series-break/constant.js +0 -6
  141. package/cjs/components/series-break/constant.js.map +0 -1
  142. package/cjs/components/series-break/index.d.ts +0 -4
  143. package/cjs/components/series-break/index.js +0 -49
  144. package/cjs/components/series-break/index.js.map +0 -1
  145. package/cjs/components/series-break/series-break.d.ts +0 -7
  146. package/cjs/components/series-break/series-break.js +0 -118
  147. package/cjs/components/series-break/series-break.js.map +0 -1
  148. package/cjs/components/series-break/type.d.ts +0 -14
  149. package/cjs/components/series-break/type.js +0 -6
  150. package/cjs/components/series-break/type.js.map +0 -1
  151. package/cjs/components/series-break/util.d.ts +0 -13
  152. package/cjs/components/series-break/util.js +0 -248
  153. package/cjs/components/series-break/util.js.map +0 -1
  154. package/cjs/components/series-label/constant.d.ts +0 -1
  155. package/cjs/components/series-label/constant.js +0 -6
  156. package/cjs/components/series-label/constant.js.map +0 -1
  157. package/cjs/components/series-label/index.d.ts +0 -3
  158. package/cjs/components/series-label/index.js +0 -49
  159. package/cjs/components/series-label/index.js.map +0 -1
  160. package/cjs/components/series-label/series-label.d.ts +0 -7
  161. package/cjs/components/series-label/series-label.js +0 -114
  162. package/cjs/components/series-label/series-label.js.map +0 -1
  163. package/cjs/components/series-label/type.d.ts +0 -41
  164. package/cjs/components/series-label/type.js +0 -6
  165. package/cjs/components/series-label/type.js.map +0 -1
  166. package/cjs/components/series-label/util.d.ts +0 -33
  167. package/cjs/components/series-label/util.js +0 -152
  168. package/cjs/components/series-label/util.js.map +0 -1
  169. package/cjs/index.d.ts +0 -11
  170. package/cjs/index.js +0 -26
  171. package/cjs/index.js.map +0 -1
  172. package/cjs/type/index.d.ts +0 -1
  173. package/cjs/type/index.js +0 -21
  174. package/cjs/type/index.js.map +0 -1
  175. package/cjs/type/type.d.ts +0 -8
  176. package/cjs/type/type.js +0 -6
  177. package/cjs/type/type.js.map +0 -1
  178. package/cjs/utils/element.d.ts +0 -7
  179. package/cjs/utils/element.js +0 -21
  180. package/cjs/utils/element.js.map +0 -1
  181. package/cjs/utils/mark.d.ts +0 -2
  182. package/cjs/utils/mark.js +0 -14
  183. package/cjs/utils/mark.js.map +0 -1
  184. package/cjs/utils/math.d.ts +0 -1
  185. package/cjs/utils/math.js +0 -10
  186. package/cjs/utils/math.js.map +0 -1
  187. package/esm/charts/compare-sankey/compare-sankey-sub-data.d.ts +0 -21
  188. package/esm/charts/compare-sankey/compare-sankey-sub-data.js +0 -106
  189. package/esm/charts/compare-sankey/compare-sankey-sub-data.js.map +0 -1
  190. package/esm/charts/compare-sankey/compare-sankey-sub-nodes.d.ts +0 -2
  191. package/esm/charts/compare-sankey/compare-sankey-sub-nodes.js +0 -13
  192. package/esm/charts/compare-sankey/compare-sankey-sub-nodes.js.map +0 -1
  193. package/esm/charts/compare-sankey/compare-sankey-transformer.d.ts +0 -7
  194. package/esm/charts/compare-sankey/compare-sankey-transformer.js +0 -17
  195. package/esm/charts/compare-sankey/compare-sankey-transformer.js.map +0 -1
  196. package/esm/charts/compare-sankey/compare-sankey.d.ts +0 -44
  197. package/esm/charts/compare-sankey/compare-sankey.js +0 -199
  198. package/esm/charts/compare-sankey/compare-sankey.js.map +0 -1
  199. package/esm/charts/compare-sankey/index.d.ts +0 -2
  200. package/esm/charts/compare-sankey/index.js +0 -4
  201. package/esm/charts/compare-sankey/index.js.map +0 -1
  202. package/esm/charts/compare-sankey/interface.d.ts +0 -24
  203. package/esm/charts/compare-sankey/interface.js +0 -2
  204. package/esm/charts/compare-sankey/interface.js.map +0 -1
  205. package/esm/charts/compare-sankey/utils.d.ts +0 -9
  206. package/esm/charts/compare-sankey/utils.js +0 -39
  207. package/esm/charts/compare-sankey/utils.js.map +0 -1
  208. package/esm/charts/compare-sankey-diff/compare-sankey-diff-data.d.ts +0 -8
  209. package/esm/charts/compare-sankey-diff/compare-sankey-diff-data.js +0 -77
  210. package/esm/charts/compare-sankey-diff/compare-sankey-diff-data.js.map +0 -1
  211. package/esm/charts/compare-sankey-diff/compare-sankey-diff-transformer.d.ts +0 -7
  212. package/esm/charts/compare-sankey-diff/compare-sankey-diff-transformer.js +0 -17
  213. package/esm/charts/compare-sankey-diff/compare-sankey-diff-transformer.js.map +0 -1
  214. package/esm/charts/compare-sankey-diff/compare-sankey-diff.d.ts +0 -34
  215. package/esm/charts/compare-sankey-diff/compare-sankey-diff.js +0 -97
  216. package/esm/charts/compare-sankey-diff/compare-sankey-diff.js.map +0 -1
  217. package/esm/charts/compare-sankey-diff/index.d.ts +0 -2
  218. package/esm/charts/compare-sankey-diff/index.js +0 -3
  219. package/esm/charts/compare-sankey-diff/index.js.map +0 -1
  220. package/esm/charts/compare-sankey-diff/interface.d.ts +0 -24
  221. package/esm/charts/compare-sankey-diff/interface.js +0 -2
  222. package/esm/charts/compare-sankey-diff/interface.js.map +0 -1
  223. package/esm/charts/conversion-funnel/arrow-data-transform.d.ts +0 -24
  224. package/esm/charts/conversion-funnel/arrow-data-transform.js +0 -94
  225. package/esm/charts/conversion-funnel/arrow-data-transform.js.map +0 -1
  226. package/esm/charts/conversion-funnel/conversion-funnel-transformer.d.ts +0 -7
  227. package/esm/charts/conversion-funnel/conversion-funnel-transformer.js +0 -192
  228. package/esm/charts/conversion-funnel/conversion-funnel-transformer.js.map +0 -1
  229. package/esm/charts/conversion-funnel/conversion-funnel.d.ts +0 -40
  230. package/esm/charts/conversion-funnel/conversion-funnel.js +0 -81
  231. package/esm/charts/conversion-funnel/conversion-funnel.js.map +0 -1
  232. package/esm/charts/conversion-funnel/index.d.ts +0 -2
  233. package/esm/charts/conversion-funnel/index.js +0 -4
  234. package/esm/charts/conversion-funnel/index.js.map +0 -1
  235. package/esm/charts/conversion-funnel/interface.d.ts +0 -35
  236. package/esm/charts/conversion-funnel/interface.js +0 -2
  237. package/esm/charts/conversion-funnel/interface.js.map +0 -1
  238. package/esm/charts/conversion-funnel/util.d.ts +0 -3
  239. package/esm/charts/conversion-funnel/util.js +0 -10
  240. package/esm/charts/conversion-funnel/util.js.map +0 -1
  241. package/esm/charts/ranking-bar/interface.d.ts +0 -45
  242. package/esm/charts/ranking-bar/interface.js +0 -2
  243. package/esm/charts/ranking-bar/interface.js.map +0 -1
  244. package/esm/charts/ranking-bar/ranking-bar-transformer.d.ts +0 -10
  245. package/esm/charts/ranking-bar/ranking-bar-transformer.js +0 -285
  246. package/esm/charts/ranking-bar/ranking-bar-transformer.js.map +0 -1
  247. package/esm/charts/ranking-bar/ranking-bar.d.ts +0 -16
  248. package/esm/charts/ranking-bar/ranking-bar.js +0 -27
  249. package/esm/charts/ranking-bar/ranking-bar.js.map +0 -1
  250. package/esm/charts/ranking-list/constant.d.ts +0 -2
  251. package/esm/charts/ranking-list/constant.js +0 -69
  252. package/esm/charts/ranking-list/constant.js.map +0 -1
  253. package/esm/charts/ranking-list/interface.d.ts +0 -74
  254. package/esm/charts/ranking-list/interface.js +0 -2
  255. package/esm/charts/ranking-list/interface.js.map +0 -1
  256. package/esm/charts/ranking-list/ranking-list-transformer.d.ts +0 -459
  257. package/esm/charts/ranking-list/ranking-list-transformer.js +0 -383
  258. package/esm/charts/ranking-list/ranking-list-transformer.js.map +0 -1
  259. package/esm/charts/ranking-list/ranking-list.d.ts +0 -16
  260. package/esm/charts/ranking-list/ranking-list.js +0 -27
  261. package/esm/charts/ranking-list/ranking-list.js.map +0 -1
  262. package/esm/charts/ranking-list/utils.d.ts +0 -7
  263. package/esm/charts/ranking-list/utils.js +0 -41
  264. package/esm/charts/ranking-list/utils.js.map +0 -1
  265. package/esm/charts/sequence-scatter-kde/constant.d.ts +0 -3
  266. package/esm/charts/sequence-scatter-kde/constant.js +0 -5
  267. package/esm/charts/sequence-scatter-kde/constant.js.map +0 -1
  268. package/esm/charts/sequence-scatter-kde/interface.d.ts +0 -29
  269. package/esm/charts/sequence-scatter-kde/interface.js +0 -2
  270. package/esm/charts/sequence-scatter-kde/interface.js.map +0 -1
  271. package/esm/charts/sequence-scatter-kde/sequence-scatter-kde-transformer.d.ts +0 -6
  272. package/esm/charts/sequence-scatter-kde/sequence-scatter-kde-transformer.js +0 -137
  273. package/esm/charts/sequence-scatter-kde/sequence-scatter-kde-transformer.js.map +0 -1
  274. package/esm/charts/sequence-scatter-kde/sequence-scatter-kde.d.ts +0 -16
  275. package/esm/charts/sequence-scatter-kde/sequence-scatter-kde.js +0 -28
  276. package/esm/charts/sequence-scatter-kde/sequence-scatter-kde.js.map +0 -1
  277. package/esm/charts/sequence-scatter-kde/utils.d.ts +0 -9
  278. package/esm/charts/sequence-scatter-kde/utils.js +0 -34
  279. package/esm/charts/sequence-scatter-kde/utils.js.map +0 -1
  280. package/esm/charts/sequence-scatter-link/interface.d.ts +0 -59
  281. package/esm/charts/sequence-scatter-link/interface.js +0 -2
  282. package/esm/charts/sequence-scatter-link/interface.js.map +0 -1
  283. package/esm/charts/sequence-scatter-link/sequence-scatter-link-transformer.d.ts +0 -6
  284. package/esm/charts/sequence-scatter-link/sequence-scatter-link-transformer.js +0 -321
  285. package/esm/charts/sequence-scatter-link/sequence-scatter-link-transformer.js.map +0 -1
  286. package/esm/charts/sequence-scatter-link/sequence-scatter-link.d.ts +0 -16
  287. package/esm/charts/sequence-scatter-link/sequence-scatter-link.js +0 -28
  288. package/esm/charts/sequence-scatter-link/sequence-scatter-link.js.map +0 -1
  289. package/esm/charts/sequence-scatter-link/utils.d.ts +0 -9
  290. package/esm/charts/sequence-scatter-link/utils.js +0 -100
  291. package/esm/charts/sequence-scatter-link/utils.js.map +0 -1
  292. package/esm/charts/sequence-scatter-pixel/constant.d.ts +0 -3
  293. package/esm/charts/sequence-scatter-pixel/constant.js +0 -6
  294. package/esm/charts/sequence-scatter-pixel/constant.js.map +0 -1
  295. package/esm/charts/sequence-scatter-pixel/interface.d.ts +0 -29
  296. package/esm/charts/sequence-scatter-pixel/interface.js +0 -2
  297. package/esm/charts/sequence-scatter-pixel/interface.js.map +0 -1
  298. package/esm/charts/sequence-scatter-pixel/sequence-scatter-pixel-transformer.d.ts +0 -4
  299. package/esm/charts/sequence-scatter-pixel/sequence-scatter-pixel-transformer.js +0 -64
  300. package/esm/charts/sequence-scatter-pixel/sequence-scatter-pixel-transformer.js.map +0 -1
  301. package/esm/charts/sequence-scatter-pixel/sequence-scatter-pixel.d.ts +0 -16
  302. package/esm/charts/sequence-scatter-pixel/sequence-scatter-pixel.js +0 -28
  303. package/esm/charts/sequence-scatter-pixel/sequence-scatter-pixel.js.map +0 -1
  304. package/esm/charts/sequence-scatter-pixel/utils.d.ts +0 -3
  305. package/esm/charts/sequence-scatter-pixel/utils.js +0 -46
  306. package/esm/charts/sequence-scatter-pixel/utils.js.map +0 -1
  307. package/esm/components/bar-link/bar-link.d.ts +0 -7
  308. package/esm/components/bar-link/bar-link.js +0 -85
  309. package/esm/components/bar-link/bar-link.js.map +0 -1
  310. package/esm/components/bar-link/constant.d.ts +0 -1
  311. package/esm/components/bar-link/constant.js +0 -2
  312. package/esm/components/bar-link/constant.js.map +0 -1
  313. package/esm/components/bar-link/index.d.ts +0 -4
  314. package/esm/components/bar-link/index.js +0 -7
  315. package/esm/components/bar-link/index.js.map +0 -1
  316. package/esm/components/bar-link/type.d.ts +0 -27
  317. package/esm/components/bar-link/type.js +0 -2
  318. package/esm/components/bar-link/type.js.map +0 -1
  319. package/esm/components/bar-link/util.d.ts +0 -22
  320. package/esm/components/bar-link/util.js +0 -178
  321. package/esm/components/bar-link/util.js.map +0 -1
  322. package/esm/components/series-break/constant.d.ts +0 -1
  323. package/esm/components/series-break/constant.js +0 -2
  324. package/esm/components/series-break/constant.js.map +0 -1
  325. package/esm/components/series-break/index.d.ts +0 -4
  326. package/esm/components/series-break/index.js +0 -8
  327. package/esm/components/series-break/index.js.map +0 -1
  328. package/esm/components/series-break/series-break.d.ts +0 -7
  329. package/esm/components/series-break/series-break.js +0 -115
  330. package/esm/components/series-break/series-break.js.map +0 -1
  331. package/esm/components/series-break/type.d.ts +0 -14
  332. package/esm/components/series-break/type.js +0 -2
  333. package/esm/components/series-break/type.js.map +0 -1
  334. package/esm/components/series-break/util.d.ts +0 -13
  335. package/esm/components/series-break/util.js +0 -244
  336. package/esm/components/series-break/util.js.map +0 -1
  337. package/esm/components/series-label/constant.d.ts +0 -1
  338. package/esm/components/series-label/constant.js +0 -2
  339. package/esm/components/series-label/constant.js.map +0 -1
  340. package/esm/components/series-label/index.d.ts +0 -3
  341. package/esm/components/series-label/index.js +0 -6
  342. package/esm/components/series-label/index.js.map +0 -1
  343. package/esm/components/series-label/series-label.d.ts +0 -7
  344. package/esm/components/series-label/series-label.js +0 -110
  345. package/esm/components/series-label/series-label.js.map +0 -1
  346. package/esm/components/series-label/type.d.ts +0 -41
  347. package/esm/components/series-label/type.js +0 -2
  348. package/esm/components/series-label/type.js.map +0 -1
  349. package/esm/components/series-label/util.d.ts +0 -33
  350. package/esm/components/series-label/util.js +0 -144
  351. package/esm/components/series-label/util.js.map +0 -1
  352. package/esm/index.d.ts +0 -11
  353. package/esm/index.js +0 -21
  354. package/esm/index.js.map +0 -1
  355. package/esm/type/index.d.ts +0 -1
  356. package/esm/type/index.js +0 -2
  357. package/esm/type/index.js.map +0 -1
  358. package/esm/type/type.d.ts +0 -8
  359. package/esm/type/type.js +0 -2
  360. package/esm/type/type.js.map +0 -1
  361. package/esm/utils/element.d.ts +0 -7
  362. package/esm/utils/element.js +0 -15
  363. package/esm/utils/element.js.map +0 -1
  364. package/esm/utils/mark.d.ts +0 -2
  365. package/esm/utils/mark.js +0 -4
  366. package/esm/utils/mark.js.map +0 -1
  367. package/esm/utils/math.d.ts +0 -1
  368. package/esm/utils/math.js +0 -4
  369. package/esm/utils/math.js.map +0 -1
@@ -1,48 +0,0 @@
1
- "use strict";
2
-
3
- var __rest = this && this.__rest || function(s, e) {
4
- var t = {};
5
- for (var p in s) Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0 && (t[p] = s[p]);
6
- if (null != s && "function" == typeof Object.getOwnPropertySymbols) {
7
- var i = 0;
8
- for (p = Object.getOwnPropertySymbols(s); i < p.length; i++) e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]) && (t[p[i]] = s[p[i]]);
9
- }
10
- return t;
11
- };
12
-
13
- Object.defineProperty(exports, "__esModule", {
14
- value: !0
15
- }), exports.getNodeDatumInSubTree = exports.getNodeDatumInTree = exports.getSubNodeDatum = exports.traverseTree = void 0;
16
-
17
- const traverseTree = (subTree, callback) => {
18
- subTree.forEach((node => {
19
- callback(node), node.children && node.children.length && (0, exports.traverseTree)(node.children, callback);
20
- }));
21
- };
22
-
23
- function getSubNodeDatum(allNodeElements, filter) {
24
- return allNodeElements.filter((n => filter(n.data[0])));
25
- }
26
-
27
- function getNodeDatumInTree(nodes, filter) {
28
- const result = [];
29
- return nodes.forEach((node => {
30
- (0, exports.traverseTree)([ node ], (node => {
31
- filter(node) && result.push(node);
32
- }));
33
- })), result;
34
- }
35
-
36
- function getNodeDatumInSubTree(subNodes, filter) {
37
- const list = [];
38
- return subNodes.forEach((subNode => {
39
- const {nodes: nodes} = subNode, result = __rest(subNode, [ "nodes" ]);
40
- result.datum = [], nodes.forEach((node => {
41
- filter(node) && result.datum.push(node);
42
- })), list.push(result);
43
- })), list;
44
- }
45
-
46
- exports.traverseTree = traverseTree, exports.getSubNodeDatum = getSubNodeDatum,
47
- exports.getNodeDatumInTree = getNodeDatumInTree, exports.getNodeDatumInSubTree = getNodeDatumInSubTree;
48
- //# sourceMappingURL=utils.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["charts/compare-sankey/utils.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAGO,MAAM,YAAY,GAAG,CAAC,OAAc,EAAE,QAA6B,EAAE,EAAE;IAC5E,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;QACrB,QAAQ,CAAC,IAAI,CAAC,CAAC;QACf,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YACzC,IAAA,oBAAY,EAAC,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;SACvC;IACH,CAAC,CAAC,CAAC;AACL,CAAC,CAAC;AAPW,QAAA,YAAY,gBAOvB;AAuBF,SAAgB,eAAe,CAAC,eAA2B,EAAE,MAA2B;IACtF,OAAO,eAAe,CAAC,MAAM,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAC/D,CAAC;AAFD,0CAEC;AAKD,SAAgB,kBAAkB,CAAC,KAAY,EAAE,MAA2B;IAC1E,MAAM,MAAM,GAAU,EAAE,CAAC;IACzB,KAAK,CAAC,OAAO,CAAC,CAAC,IAAS,EAAE,EAAE;QAC1B,IAAA,oBAAY,EAAC,CAAC,IAAI,CAAC,EAAE,CAAC,IAAS,EAAE,EAAE;YACjC,IAAI,MAAM,CAAC,IAAI,CAAC,EAAE;gBAChB,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aACnB;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IACH,OAAO,MAAM,CAAC;AAChB,CAAC;AAVD,gDAUC;AAED,SAAgB,qBAAqB,CAAC,QAAe,EAAE,MAA2B;IAChF,MAAM,IAAI,GAIJ,EAAE,CAAC;IACT,QAAQ,CAAC,OAAO,CAAC,CAAC,OAAY,EAAE,EAAE;QAChC,MAAM,EAAE,KAAK,KAAgB,OAAO,EAAlB,MAAM,UAAK,OAAO,EAA9B,SAAoB,CAAU,CAAC;QACrC,MAAM,CAAC,KAAK,GAAG,EAAE,CAAC;QAClB,KAAK,CAAC,OAAO,CAAC,CAAC,IAAS,EAAE,EAAE;YAC1B,IAAI,MAAM,CAAC,IAAI,CAAC,EAAE;gBAChB,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aACzB;QACH,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACpB,CAAC,CAAC,CAAC;IACH,OAAO,IAAI,CAAC;AACd,CAAC;AAjBD,sDAiBC","file":"utils.js","sourcesContent":["import { Datum, IElement } from '@visactor/vgrammar-core';\n\n// 遍历树,桑基图节点通过 callback 返回到调用方\nexport const traverseTree = (subTree: any[], callback: (node: any) => void) => {\n subTree.forEach(node => {\n callback(node);\n if (node.children && node.children.length) {\n traverseTree(node.children, callback);\n }\n });\n};\n\n/**\n * 通过节点获取链接节点\n * 规则如下\n * 1. 节点有 children 时,链接节点为 children 中第一个节点\n * 2. 节点无 children 时,链接节点为父节点\n */\n// export const getLinkNodeInFSAT = (\n// node: any,\n// allNodeElements: IElement[],\n// allLinkElements: IElement[],\n// viewData: DataView\n// ) => {\n// return {\n// nodeKey: [],\n// linkKey: []\n// } as { nodeKey: string[]; linkKey: string[] };\n// };\n\n/**\n * 获取符合条件的子节点元素\n */\nexport function getSubNodeDatum(allNodeElements: IElement[], filter: (n: any) => boolean) {\n return allNodeElements.filter((n: any) => filter(n.data[0]));\n}\n\n/**\n * 在原始树结构中查找符合条件的节点\n */\nexport function getNodeDatumInTree(nodes: any[], filter: (n: any) => boolean) {\n const result: any[] = [];\n nodes.forEach((node: any) => {\n traverseTree([node], (node: any) => {\n if (filter(node)) {\n result.push(node);\n }\n });\n });\n return result;\n}\n\nexport function getNodeDatumInSubTree(subNodes: any[], filter: (n: any) => boolean) {\n const list: {\n type: string;\n datum: Datum[];\n [key: string]: any;\n }[] = [];\n subNodes.forEach((subNode: any) => {\n const { nodes, ...result } = subNode;\n result.datum = [];\n nodes.forEach((node: any) => {\n if (filter(node)) {\n result.datum.push(node);\n }\n });\n list.push(result);\n });\n return list;\n}\n"]}
@@ -1,8 +0,0 @@
1
- import type { DataView } from '@visactor/vdataset';
2
- export interface ICompareSankeyLayoutOpt {
3
- rawData: () => DataView;
4
- nodeKey: string;
5
- subNodeGap: number;
6
- subNodeMinSize?: number;
7
- }
8
- export declare const compareSankeyDiffSubData: (data: Array<DataView>, opt: ICompareSankeyLayoutOpt) => {};
@@ -1,85 +0,0 @@
1
- "use strict";
2
-
3
- var __rest = this && this.__rest || function(s, e) {
4
- var t = {};
5
- for (var p in s) Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0 && (t[p] = s[p]);
6
- if (null != s && "function" == typeof Object.getOwnPropertySymbols) {
7
- var i = 0;
8
- for (p = Object.getOwnPropertySymbols(s); i < p.length; i++) e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]) && (t[p[i]] = s[p[i]]);
9
- }
10
- return t;
11
- };
12
-
13
- Object.defineProperty(exports, "__esModule", {
14
- value: !0
15
- }), exports.compareSankeyDiffSubData = void 0;
16
-
17
- const compareSankeyDiffSubData = (data, opt) => {
18
- var _a, _b, _c, _d, _e, _f, _g;
19
- const viewData = data[0];
20
- if (!(null === (_a = viewData.latestData) || void 0 === _a ? void 0 : _a.length)) return {};
21
- const subNodeMinSize = null !== (_b = opt.subNodeMinSize) && void 0 !== _b ? _b : 0, subNodeGap = opt.subNodeGap, subDataList = [], sankeyLayoutTransform = viewData.dataSet.getTransform("sankeyLayout"), sankeyTransformOption = Object.assign({}, viewData.transformsArr.find((t => "sankeyLayout" === t.type)).options);
22
- delete sankeyTransformOption.customLayout;
23
- const viewDataLatest = viewData.latestData[0];
24
- null === (_g = null === (_f = null === (_e = null === (_d = null === (_c = viewData.rawData) || void 0 === _c ? void 0 : _c[0]) || void 0 === _d ? void 0 : _d.latestData) || void 0 === _e ? void 0 : _e[0]) || void 0 === _f ? void 0 : _f.subNode) || void 0 === _g || _g.forEach((subGroup => {
25
- const {nodes: nodes} = subGroup, rest = __rest(subGroup, [ "nodes" ]), data = sankeyLayoutTransform([ Object.assign({
26
- nodes: nodes
27
- }, rest) ], sankeyTransformOption);
28
- Object.keys(rest).forEach((key => {
29
- data[0].nodes.forEach((n => {
30
- n[key] = rest[key];
31
- }));
32
- })), subDataList.push({
33
- data: data,
34
- external: rest
35
- });
36
- }));
37
- const subCount = subDataList.length;
38
- viewData.latestData[0].nodes.forEach(((n, index) => {
39
- let currentY = n.y0;
40
- const totalSize = n.y1 - n.y0 - (subCount - 1) * subNodeGap, totalValue = n.value;
41
- subDataList.forEach((subData => {
42
- var _a;
43
- let subN = subData.data[0].nodes[index];
44
- if (subN.key !== n.key && (subN = subData.data[0].nodes.find((n => n.key == n.key))),
45
- !subN) return;
46
- const percent = 0 === totalValue ? 0 : subN.value / totalValue, nodeSize = Math.max(subNodeMinSize, totalSize * percent), diffX = n.x0 - subN.x0, lastY0 = subN.y0, lastSize = subN.y1 - subN.y0, sizeMultiply = nodeSize / lastSize;
47
- subN._compare_compute_temp = {
48
- diffX: diffX,
49
- lastY0: lastY0,
50
- lastSize: lastSize,
51
- sizeMultiply: sizeMultiply
52
- }, subN.x0 = n.x0, subN.x1 = n.x1, subN.y0 = currentY, subN.y1 = currentY + nodeSize,
53
- currentY += nodeSize + subNodeGap, null === (_a = subN.sourceLinks) || void 0 === _a || _a.forEach((link => {
54
- var _a;
55
- link.type = subN.type, link.x0 = (null !== (_a = link.x0) && void 0 !== _a ? _a : 0) + diffX,
56
- link.thickness = link.thickness * sizeMultiply, link.y0 = (link.y0 - lastY0) * sizeMultiply + subN.y0,
57
- link.sourceRect && (link.sourceRect.x0 = subN.x0, link.sourceRect.x1 = subN.x1,
58
- link.sourceRect.y0 = subN.y0, link.sourceRect.y1 = subN.y1);
59
- }));
60
- }));
61
- })), subDataList.forEach((subData => {
62
- subData.data[0].nodes.forEach((n => {
63
- var _a;
64
- const {diffX: diffX, lastY0: lastY0, sizeMultiply: sizeMultiply} = n._compare_compute_temp;
65
- null === (_a = n.targetLinks) || void 0 === _a || _a.forEach((link => {
66
- var _a;
67
- link.x1 = (null !== (_a = link.x1) && void 0 !== _a ? _a : 0) + diffX, link.y1 = (link.y1 - lastY0) * sizeMultiply + n.y0,
68
- link.targetRect && (link.targetRect.x0 = n.x0, link.targetRect.x1 = n.x1, link.targetRect.y0 = n.y0,
69
- link.targetRect.y1 = n.y1);
70
- }));
71
- }));
72
- }));
73
- const finalViewData = {
74
- columns: [],
75
- links: [],
76
- nodes: []
77
- };
78
- return finalViewData.columns = viewDataLatest.columns.reduce(((prev, cur, curIndex) => (prev.push(subDataList.reduce(((prev, cur) => prev.concat(cur.data[0].columns[curIndex])), [])),
79
- prev)), []), finalViewData.links = subDataList.reduce(((prev, cur) => prev.concat(cur.data[0].links)), []),
80
- finalViewData.nodes = subDataList.reduce(((prev, cur) => prev.concat(cur.data[0].nodes)), []),
81
- [ finalViewData ];
82
- };
83
-
84
- exports.compareSankeyDiffSubData = compareSankeyDiffSubData;
85
- //# sourceMappingURL=compare-sankey-diff-data.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["charts/compare-sankey-diff/compare-sankey-diff-data.ts"],"names":[],"mappings":"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","file":"compare-sankey-diff-data.js","sourcesContent":["import type { DataView } from '@visactor/vdataset';\nimport { SankeyNodeElement } from '@visactor/vgrammar-sankey';\n\nexport interface ICompareSankeyLayoutOpt {\n rawData: () => DataView;\n nodeKey: string;\n subNodeGap: number;\n subNodeMinSize?: number;\n}\n\nexport const compareSankeyDiffSubData = (data: Array<DataView>, opt: ICompareSankeyLayoutOpt) => {\n const viewData = data[0] as DataView;\n if (!viewData.latestData?.length) {\n return {};\n }\n\n const subNodeMinSize = opt.subNodeMinSize ?? 0;\n const subNodeGap = opt.subNodeGap;\n const subDataList: { data: any[]; external: any }[] = [];\n const sankeyLayoutTransform = viewData.dataSet.getTransform('sankeyLayout');\n const sankeyTransformOption = { ...viewData.transformsArr.find(t => t.type === 'sankeyLayout').options };\n // 自定义 layout 后处理不执行\n delete sankeyTransformOption.customLayout;\n const viewDataLatest = viewData.latestData[0];\n // 使用每一个对比数据生成对比节点和对比边\n viewData.rawData?.[0]?.latestData?.[0]?.subNode?.forEach((subGroup: any) => {\n const { nodes, ...rest } = subGroup;\n const data = sankeyLayoutTransform([{ nodes, ...rest }], sankeyTransformOption);\n Object.keys(rest).forEach(key => {\n data[0].nodes.forEach((n: { [x: string]: any }) => {\n n[key] = rest[key];\n });\n });\n subDataList.push({ data: data, external: rest });\n });\n\n const subCount = subDataList.length;\n viewData.latestData[0].nodes.forEach((n: SankeyNodeElement, index: number) => {\n let currentY = n.y0;\n const totalSize = n.y1 - n.y0 - (subCount - 1) * subNodeGap;\n const totalValue = n.value;\n subDataList.forEach((subData: any) => {\n let subN = subData.data[0].nodes[index] as SankeyNodeElement;\n if (subN.key !== n.key) {\n subN = subData.data[0].nodes.find((n: SankeyNodeElement) => n.key === n.key);\n }\n if (!subN) {\n return;\n }\n const percent = totalValue === 0 ? 0 : subN.value / totalValue;\n const nodeSize = Math.max(subNodeMinSize, totalSize * percent);\n\n // x 方向偏移\n const diffX = n.x0 - subN.x0;\n const lastY0 = subN.y0;\n const lastSize = subN.y1 - subN.y0;\n const sizeMultiply = nodeSize / lastSize;\n\n // @ts-expect-error\n subN._compare_compute_temp = {\n diffX,\n lastY0,\n lastSize,\n sizeMultiply\n };\n\n subN.x0 = n.x0;\n subN.x1 = n.x1;\n subN.y0 = currentY;\n subN.y1 = currentY + nodeSize;\n currentY += nodeSize + subNodeGap;\n\n // updateLink // 只更新 source Link\n subN.sourceLinks?.forEach(link => {\n // @ts-expect-error\n link.type = subN.type;\n link.x0 = (link.x0 ?? 0) + diffX;\n link.thickness = link.thickness * sizeMultiply;\n link.y0 = (link.y0 - lastY0) * sizeMultiply + subN.y0;\n\n if (link.sourceRect) {\n link.sourceRect.x0 = subN.x0;\n link.sourceRect.x1 = subN.x1;\n link.sourceRect.y0 = subN.y0;\n link.sourceRect.y1 = subN.y1;\n }\n });\n });\n });\n\n // 最后更新一次target Link\n subDataList.forEach((subData: any) => {\n subData.data[0].nodes.forEach((n: SankeyNodeElement) => {\n // @ts-expect-error\n const { diffX, lastY0, sizeMultiply } = n._compare_compute_temp;\n // target Link\n n.targetLinks?.forEach(link => {\n link.x1 = (link.x1 ?? 0) + diffX;\n link.y1 = (link.y1 - lastY0) * sizeMultiply + n.y0;\n\n if (link.targetRect) {\n link.targetRect.x0 = n.x0;\n link.targetRect.x1 = n.x1;\n link.targetRect.y0 = n.y0;\n link.targetRect.y1 = n.y1;\n }\n });\n });\n });\n\n const finalViewData: { columns: any[]; links: any[]; nodes: any[] } = {\n columns: [],\n links: [],\n nodes: []\n };\n // 合并节点和边\n finalViewData.columns = viewDataLatest.columns.reduce((prev: any[], cur: any, curIndex: number) => {\n prev.push(subDataList.reduce((prev, cur) => prev.concat(cur.data[0].columns[curIndex]), []));\n return prev;\n }, []);\n finalViewData.links = subDataList.reduce((prev, cur) => prev.concat(cur.data[0].links), []);\n finalViewData.nodes = subDataList.reduce((prev, cur) => prev.concat(cur.data[0].nodes), []);\n return [finalViewData];\n};\n"]}
@@ -1,7 +0,0 @@
1
- import type { ICompareSankeyDiffChartSpecBase } from './interface';
2
- import { SankeyChartSpecTransformer } from '@visactor/vchart';
3
- export declare class CompareSankeyDiffChartSpecTransformer extends SankeyChartSpecTransformer<ICompareSankeyDiffChartSpecBase> {
4
- seriesType: string;
5
- transformSpec(spec: ICompareSankeyDiffChartSpecBase): void;
6
- _getDefaultSeriesSpec(spec: ICompareSankeyDiffChartSpecBase): any;
7
- }
@@ -1,25 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: !0
5
- }), exports.CompareSankeyDiffChartSpecTransformer = void 0;
6
-
7
- const vchart_1 = require("@visactor/vchart");
8
-
9
- class CompareSankeyDiffChartSpecTransformer extends vchart_1.SankeyChartSpecTransformer {
10
- constructor() {
11
- super(...arguments), this.seriesType = "compareSankeyDiff";
12
- }
13
- transformSpec(spec) {
14
- super.transformSpec(spec);
15
- }
16
- _getDefaultSeriesSpec(spec) {
17
- const seriesSpec = super._getDefaultSeriesSpec(spec);
18
- return seriesSpec.subNodeGap = spec.subNodeGap, seriesSpec.subNodeMinSize = spec.subNodeMinSize,
19
- seriesSpec.compareNodeColor = spec.compareNodeColor, seriesSpec.compareLinkColor = spec.compareLinkColor,
20
- seriesSpec;
21
- }
22
- }
23
-
24
- exports.CompareSankeyDiffChartSpecTransformer = CompareSankeyDiffChartSpecTransformer;
25
- //# sourceMappingURL=compare-sankey-diff-transformer.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["charts/compare-sankey-diff/compare-sankey-diff-transformer.ts"],"names":[],"mappings":";;;AACA,6CAA8D;AAM9D,MAAa,qCAAsC,SAAQ,mCAA2D;IAAtH;;QACE,eAAU,GAAG,mBAAmB,CAAC;IAmBnC,CAAC;IAfC,aAAa,CAAC,IAAqC;QACjD,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC;IAKD,qBAAqB,CAAC,IAAqC;QACzD,MAAM,UAAU,GAAG,KAAK,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;QACpD,UAA2C,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC;QACzE,UAA2C,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC;QACjF,UAA2C,CAAC,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC;QACrF,UAA2C,CAAC,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC;QACtF,OAAO,UAAU,CAAC;IACpB,CAAC;CACF;AApBD,sFAoBC","file":"compare-sankey-diff-transformer.js","sourcesContent":["import type { ICompareSankeyDiffChartSpecBase, ICompareSankeyDiffSeriesSpec } from './interface';\nimport { SankeyChartSpecTransformer } from '@visactor/vchart';\n\n/**\n * compare-sankey-diff 图表规格转换器\n */\n// @ts-expect-error\nexport class CompareSankeyDiffChartSpecTransformer extends SankeyChartSpecTransformer<ICompareSankeyDiffChartSpecBase> {\n seriesType = 'compareSankeyDiff';\n /**\n * 转换外部传入的图表规格\n */\n transformSpec(spec: ICompareSankeyDiffChartSpecBase): void {\n super.transformSpec(spec);\n }\n\n /**\n * 生成默认的系列规格,并将图表级配置下发到系列\n */\n _getDefaultSeriesSpec(spec: ICompareSankeyDiffChartSpecBase) {\n const seriesSpec = super._getDefaultSeriesSpec(spec);\n (seriesSpec as ICompareSankeyDiffSeriesSpec).subNodeGap = spec.subNodeGap;\n (seriesSpec as ICompareSankeyDiffSeriesSpec).subNodeMinSize = spec.subNodeMinSize;\n (seriesSpec as ICompareSankeyDiffSeriesSpec).compareNodeColor = spec.compareNodeColor;\n (seriesSpec as ICompareSankeyDiffSeriesSpec).compareLinkColor = spec.compareLinkColor;\n return seriesSpec;\n }\n}\n"]}
@@ -1,34 +0,0 @@
1
- import type { ICompareSankeyDiffChartSpecBase, ICompareSankeyDiffSeriesSpecBase } from './interface';
2
- import { VChart, SankeyChart, SankeySeries } from '@visactor/vchart';
3
- import { CompareSankeyDiffChartSpecTransformer } from './compare-sankey-diff-transformer';
4
- type Datum = any;
5
- export declare class CompareSankeyDiffChart extends SankeyChart<ICompareSankeyDiffChartSpecBase> {
6
- type: string;
7
- static type: string;
8
- readonly seriesType: string;
9
- _spec: ICompareSankeyDiffChartSpecBase;
10
- static readonly transformerConstructor: typeof CompareSankeyDiffChartSpecTransformer;
11
- readonly transformerConstructor: typeof CompareSankeyDiffChartSpecTransformer;
12
- }
13
- export declare class CompareSankeyDiffSeries extends SankeySeries<ICompareSankeyDiffSeriesSpecBase> {
14
- type: string;
15
- static type: string;
16
- initData(): void;
17
- compileData(): void;
18
- _initLinkMarkStyle(): void;
19
- _initNodeMarkStyle(): void;
20
- protected _fillCompareNode: (datum: any) => any;
21
- protected _fillCompareLink: (datum: any) => any;
22
- protected _handleClearEmpty(highlightState: string, blurState: string): void;
23
- getSubNodeDatum(filter: (n: Datum) => boolean): import("@visactor/vgrammar-core").IElement[];
24
- getNodeDatumInTree(filter: (n: any) => boolean): any[];
25
- getNodeDatumInSubTree(filter: (n: any) => boolean): {
26
- [key: string]: any;
27
- type: string;
28
- datum: any[];
29
- }[];
30
- }
31
- export declare const registerCompareSankeyDiffChart: (option?: {
32
- VChart?: typeof VChart;
33
- }) => void;
34
- export {};
@@ -1,98 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: !0
5
- }), exports.registerCompareSankeyDiffChart = exports.CompareSankeyDiffSeries = exports.CompareSankeyDiffChart = void 0;
6
-
7
- const vchart_1 = require("@visactor/vchart"), vdataset_1 = require("@visactor/vdataset"), compare_sankey_diff_transformer_1 = require("./compare-sankey-diff-transformer"), compare_sankey_diff_data_1 = require("./compare-sankey-diff-data"), utils_1 = require("../compare-sankey/utils");
8
-
9
- class CompareSankeyDiffChart extends vchart_1.SankeyChart {
10
- constructor() {
11
- super(...arguments), this.type = "compareSankeyDiff", this.seriesType = CompareSankeyDiffSeries.type,
12
- this.transformerConstructor = compare_sankey_diff_transformer_1.CompareSankeyDiffChartSpecTransformer;
13
- }
14
- }
15
-
16
- exports.CompareSankeyDiffChart = CompareSankeyDiffChart, CompareSankeyDiffChart.type = "compareSankeyDiff",
17
- CompareSankeyDiffChart.transformerConstructor = compare_sankey_diff_transformer_1.CompareSankeyDiffChartSpecTransformer;
18
-
19
- class CompareSankeyDiffSeries extends vchart_1.SankeySeries {
20
- constructor() {
21
- super(...arguments), this.type = "compareSankeyDiff", this._fillCompareNode = datum => {
22
- var _a, _b, _c, _d;
23
- const specAny = this._spec;
24
- return (null === (_a = specAny.compareNodeColor) || void 0 === _a ? void 0 : _a[datum.type]) ? specAny.compareNodeColor[datum.type] : null !== (_d = null === (_c = null === (_b = this._spec.node) || void 0 === _b ? void 0 : _b.style) || void 0 === _c ? void 0 : _c.fill) && void 0 !== _d ? _d : this._fillByNode(datum);
25
- }, this._fillCompareLink = datum => {
26
- var _a, _b, _c, _d;
27
- const specAny = this._spec;
28
- return (null === (_a = specAny.compareLinkColor) || void 0 === _a ? void 0 : _a[datum.type]) ? specAny.compareLinkColor[datum.type] : null !== (_d = null === (_c = null === (_b = this._spec.link) || void 0 === _b ? void 0 : _b.style) || void 0 === _c ? void 0 : _c.fill) && void 0 !== _d ? _d : this._fillByLink(datum);
29
- };
30
- }
31
- initData() {
32
- var _a, _b;
33
- super.initData();
34
- const {dataSet: dataSet} = this._option, compareData = new vdataset_1.DataView(dataSet, {
35
- name: `compare-sankey-diff-compare-data-${this.id}-data`
36
- });
37
- compareData.parse([ this.getViewData() ], {
38
- type: "dataview"
39
- }), (0, vchart_1.registerDataSetInstanceTransform)(this._dataSet, "compareSankeyDiffSubData", compare_sankey_diff_data_1.compareSankeyDiffSubData),
40
- compareData.transform({
41
- type: "compareSankeyDiffSubData",
42
- options: {
43
- rawData: () => this.getRawData(),
44
- valueField: this._valueField,
45
- nodeKey: this._spec.nodeKey,
46
- subNodeGap: null !== (_a = this._spec.subNodeGap) && void 0 !== _a ? _a : 2,
47
- subNodeMinSize: null !== (_b = this._spec.subNodeMinSize) && void 0 !== _b ? _b : 0
48
- }
49
- }), this._nodesSeriesData.getDataView().parse([ compareData ], {
50
- type: "dataview"
51
- }), this._linksSeriesData.getDataView().parse([ compareData ], {
52
- type: "dataview"
53
- });
54
- }
55
- compileData() {
56
- super.compileData();
57
- }
58
- _initLinkMarkStyle() {
59
- super._initLinkMarkStyle(), this._spec.compareLinkColor && this.setMarkStyle(this._linkMark, {
60
- fill: this._fillCompareLink
61
- }, "normal", vchart_1.AttributeLevel.User_Mark);
62
- }
63
- _initNodeMarkStyle() {
64
- super._initNodeMarkStyle(), this._spec.compareNodeColor && this.setMarkStyle(this._nodeMark, {
65
- fill: this._fillCompareNode
66
- }, "normal", vchart_1.AttributeLevel.User_Mark);
67
- }
68
- _handleClearEmpty(highlightState, blurState) {
69
- super._handleClearEmpty(highlightState, blurState);
70
- const allNodeElements = this._nodeMark.getProductElements();
71
- !allNodeElements && allNodeElements.length || allNodeElements.forEach((el => {
72
- el.removeState(vchart_1.STATE_VALUE_ENUM.STATE_HOVER);
73
- }));
74
- const allLinkElements = this._linkMark.getProductElements();
75
- !allLinkElements && allLinkElements.length || allLinkElements.forEach((el => {
76
- el.removeState(vchart_1.STATE_VALUE_ENUM.STATE_HOVER);
77
- }));
78
- }
79
- getSubNodeDatum(filter) {
80
- return (0, utils_1.getSubNodeDatum)(this._nodeMark.getProductElements(), filter);
81
- }
82
- getNodeDatumInTree(filter) {
83
- return (0, utils_1.getNodeDatumInTree)(this._rawData.latestData[0].nodes, filter);
84
- }
85
- getNodeDatumInSubTree(filter) {
86
- return (0, utils_1.getNodeDatumInSubTree)(this._rawData.latestData[0].subNode, filter);
87
- }
88
- }
89
-
90
- exports.CompareSankeyDiffSeries = CompareSankeyDiffSeries, CompareSankeyDiffSeries.type = "compareSankeyDiff";
91
-
92
- const registerCompareSankeyDiffChart = option => {
93
- const vchartConstructor = (null == option ? void 0 : option.VChart) || vchart_1.VChart;
94
- vchartConstructor && (vchartConstructor.useChart([ CompareSankeyDiffChart ]), vchartConstructor.useSeries([ CompareSankeyDiffSeries ]));
95
- };
96
-
97
- exports.registerCompareSankeyDiffChart = registerCompareSankeyDiffChart;
98
- //# sourceMappingURL=compare-sankey-diff.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["charts/compare-sankey-diff/compare-sankey-diff.ts"],"names":[],"mappings":"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","file":"compare-sankey-diff.js","sourcesContent":["import type { ICompareSankeyDiffChartSpecBase, ICompareSankeyDiffSeriesSpecBase } from './interface';\nimport type { IRectMarkSpec } from '@visactor/vchart';\nimport {\n VChart,\n SankeyChart,\n SankeySeries,\n registerDataSetInstanceTransform,\n STATE_VALUE_ENUM,\n AttributeLevel\n} from '@visactor/vchart';\nimport { DataView } from '@visactor/vdataset';\nimport { CompareSankeyDiffChartSpecTransformer } from './compare-sankey-diff-transformer';\nimport { compareSankeyDiffSubData } from './compare-sankey-diff-data';\nimport { getNodeDatumInSubTree, getNodeDatumInTree, getSubNodeDatum } from '../compare-sankey/utils';\n\ntype Datum = any;\n/**\n * compare-sankey-diff 图表类\n */\n// @ts-expect-error\nexport class CompareSankeyDiffChart extends SankeyChart<ICompareSankeyDiffChartSpecBase> {\n type = 'compareSankeyDiff';\n static type = 'compareSankeyDiff';\n readonly seriesType = CompareSankeyDiffSeries.type;\n\n declare _spec: ICompareSankeyDiffChartSpecBase;\n\n static readonly transformerConstructor = CompareSankeyDiffChartSpecTransformer;\n readonly transformerConstructor = CompareSankeyDiffChartSpecTransformer;\n}\n\n/**\n * compare-sankey-diff 系列类\n */\n// @ts-expect-error\nexport class CompareSankeyDiffSeries extends SankeySeries<ICompareSankeyDiffSeriesSpecBase> {\n // @ts-ignore\n type = 'compareSankeyDiff';\n static type = 'compareSankeyDiff';\n\n /**\n * 初始化数据视图,构建子节点数据与对比节点数据\n */\n initData() {\n super.initData();\n const { dataSet } = this._option;\n\n // 数据逻辑变化\n // 使用原始总计数据生成原始节点位置 这里可以不变\n // 使用每一个对比数据生成对比节点和对比边\n // 使用总计数据的节点位置更新对比数据的节点位置\n // 使用对比数据的点更新对比数据的边\n // 新数据以来原始数据,以来原始数据结果\n\n const compareData = new DataView(dataSet, { name: `compare-sankey-diff-compare-data-${this.id}-data` });\n compareData.parse([this.getViewData()], { type: 'dataview' });\n\n // 注册并执行子节点拆解与聚合\n registerDataSetInstanceTransform(this._dataSet, 'compareSankeyDiffSubData', compareSankeyDiffSubData);\n compareData.transform({\n type: 'compareSankeyDiffSubData',\n options: {\n rawData: () => this.getRawData(),\n valueField: this._valueField,\n nodeKey: this._spec.nodeKey,\n subNodeGap: (this._spec as any).subNodeGap ?? 2,\n subNodeMinSize: (this._spec as any).subNodeMinSize ?? 0\n }\n });\n\n this._nodesSeriesData.getDataView().parse([compareData], {\n type: 'dataview'\n });\n this._linksSeriesData.getDataView().parse([compareData], {\n type: 'dataview'\n });\n }\n\n /**\n * 编译数据\n */\n compileData() {\n super.compileData();\n }\n\n /**\n * 初始化链接样式(激活态)\n */\n _initLinkMarkStyle() {\n super._initLinkMarkStyle();\n if ((this._spec as any).compareLinkColor) {\n this.setMarkStyle<IRectMarkSpec>(\n this._linkMark,\n { fill: this._fillCompareLink },\n 'normal',\n AttributeLevel.User_Mark\n );\n }\n }\n\n /**\n * 初始化节点样式(支持对比颜色)\n */\n _initNodeMarkStyle() {\n super._initNodeMarkStyle();\n if ((this._spec as any).compareNodeColor) {\n this.setMarkStyle<IRectMarkSpec>(\n this._nodeMark,\n { fill: this._fillCompareNode },\n 'normal',\n AttributeLevel.User_Mark\n );\n }\n }\n\n /**\n * 计算节点填充色(支持 compareNodeColor)\n */\n protected _fillCompareNode = (datum: any) => {\n const specAny = this._spec as any;\n if (specAny.compareNodeColor?.[datum.type]) {\n return specAny.compareNodeColor[datum.type];\n }\n return this._spec.node?.style?.fill ?? this._fillByNode(datum);\n };\n\n /**\n * 计算激活态链接填充色(支持 compareLinkColor)\n */\n protected _fillCompareLink = (datum: any) => {\n const specAny = this._spec as any;\n if (specAny.compareLinkColor?.[datum.type]) {\n return specAny.compareLinkColor[datum.type];\n }\n return this._spec.link?.style?.fill ?? this._fillByLink(datum);\n };\n\n /**\n * 清除状态时同时清空激活态链接与 hover\n */\n protected _handleClearEmpty(highlightState: string, blurState: string) {\n super._handleClearEmpty(highlightState, blurState);\n\n const allNodeElements = this._nodeMark.getProductElements();\n if (allNodeElements || !allNodeElements.length) {\n allNodeElements.forEach(el => {\n el.removeState(STATE_VALUE_ENUM.STATE_HOVER);\n });\n }\n\n const allLinkElements = this._linkMark.getProductElements();\n if (allLinkElements || !allLinkElements.length) {\n allLinkElements.forEach(el => {\n el.removeState(STATE_VALUE_ENUM.STATE_HOVER);\n });\n }\n }\n\n public getSubNodeDatum(filter: (n: Datum) => boolean) {\n return getSubNodeDatum(this._nodeMark.getProductElements(), filter);\n }\n\n public getNodeDatumInTree(filter: (n: any) => boolean) {\n return getNodeDatumInTree(this._rawData.latestData[0].nodes, filter);\n }\n\n public getNodeDatumInSubTree(filter: (n: any) => boolean) {\n return getNodeDatumInSubTree(this._rawData.latestData[0].subNode, filter);\n }\n}\n\n/**\n * 注册 compare-sankey-diff 图表与系列\n */\nexport const registerCompareSankeyDiffChart = (option?: { VChart?: typeof VChart }) => {\n const vchartConstructor = option?.VChart || VChart;\n if (vchartConstructor) {\n vchartConstructor.useChart([CompareSankeyDiffChart]);\n vchartConstructor.useSeries([CompareSankeyDiffSeries]);\n }\n};\n"]}
@@ -1,2 +0,0 @@
1
- export * from './interface';
2
- export * from './compare-sankey-diff';
@@ -1,20 +0,0 @@
1
- "use strict";
2
-
3
- var __createBinding = this && this.__createBinding || (Object.create ? function(o, m, k, k2) {
4
- void 0 === k2 && (k2 = k);
5
- var desc = Object.getOwnPropertyDescriptor(m, k);
6
- desc && !("get" in desc ? !m.__esModule : desc.writable || desc.configurable) || (desc = {
7
- enumerable: !0,
8
- get: function() {
9
- return m[k];
10
- }
11
- }), Object.defineProperty(o, k2, desc);
12
- } : function(o, m, k, k2) {
13
- void 0 === k2 && (k2 = k), o[k2] = m[k];
14
- }), __exportStar = this && this.__exportStar || function(m, exports) {
15
- for (var p in m) "default" === p || Object.prototype.hasOwnProperty.call(exports, p) || __createBinding(exports, m, p);
16
- };
17
-
18
- Object.defineProperty(exports, "__esModule", {
19
- value: !0
20
- }), __exportStar(require("./interface"), exports), __exportStar(require("./compare-sankey-diff"), exports);
@@ -1 +0,0 @@
1
- {"version":3,"sources":["charts/compare-sankey-diff/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,8CAA4B;AAC5B,wDAAsC","file":"index.js","sourcesContent":["export * from './interface';\nexport * from './compare-sankey-diff';\n"]}
@@ -1,24 +0,0 @@
1
- import type { ISankeyChartSpec, ISankeySeriesSpec } from '@visactor/vchart';
2
- export interface ICompareSankeyDiffSpec {
3
- subNodeGap?: number;
4
- subNodeMinSize?: number;
5
- compareNodeColor?: {
6
- [key: string]: string;
7
- };
8
- compareLinkColor?: {
9
- [key: string]: string;
10
- };
11
- emphasis?: Omit<ISankeySeriesSpec['emphasis'], 'effect'> & {
12
- effect?: ISankeySeriesSpec['emphasis']['effect'] | 'related-node';
13
- };
14
- }
15
- export interface ICompareSankeyDiffSeriesSpecBase extends Omit<ISankeySeriesSpec, 'emphasis'>, ICompareSankeyDiffSpec {
16
- }
17
- export interface ICompareSankeyDiffChartSpecBase extends Omit<ISankeyChartSpec, 'emphasis'>, ICompareSankeyDiffSpec {
18
- }
19
- export interface ICompareSankeyDiffSeriesSpec extends Omit<ICompareSankeyDiffSeriesSpecBase, 'type' | 'series'> {
20
- type: 'compareSankeyDiff';
21
- }
22
- export interface ICompareSankeyDiffChartSpec extends Omit<ICompareSankeyDiffChartSpecBase, 'type' | 'series'> {
23
- type: 'compareSankeyDiff';
24
- }
@@ -1,6 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: !0
5
- });
6
- //# sourceMappingURL=interface.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["charts/compare-sankey-diff/interface.ts"],"names":[],"mappings":"","file":"interface.js","sourcesContent":["import type { ISankeyChartSpec, ISankeySeriesSpec } from '@visactor/vchart';\n\nexport interface ICompareSankeyDiffSpec {\n /**\n * 子节点间距\n */\n subNodeGap?: number;\n /**\n * 子节点最小高度\n */\n subNodeMinSize?: number;\n /**\n * 对比节点颜色\n */\n compareNodeColor?: { [key: string]: string };\n /**\n * 对比边点颜色\n */\n compareLinkColor?: { [key: string]: string };\n\n /**\n * 强调配置\n */\n emphasis?: Omit<ISankeySeriesSpec['emphasis'], 'effect'> & {\n effect?: ISankeySeriesSpec['emphasis']['effect'] | 'related-node';\n };\n}\n/**\n * compare-sankey-diff 图表的系列配置基类\n */\nexport interface ICompareSankeyDiffSeriesSpecBase extends Omit<ISankeySeriesSpec, 'emphasis'>, ICompareSankeyDiffSpec {}\n\n/**\n * compare-sankey-diff 图表的图表配置基类\n */\nexport interface ICompareSankeyDiffChartSpecBase extends Omit<ISankeyChartSpec, 'emphasis'>, ICompareSankeyDiffSpec {}\n\n/**\n * compare-sankey-diff 系列配置(设置系列类型)\n */\nexport interface ICompareSankeyDiffSeriesSpec extends Omit<ICompareSankeyDiffSeriesSpecBase, 'type' | 'series'> {\n type: 'compareSankeyDiff';\n}\n\n/**\n * compare-sankey-diff 图表配置(设置图表类型)\n */\nexport interface ICompareSankeyDiffChartSpec extends Omit<ICompareSankeyDiffChartSpecBase, 'type' | 'series'> {\n type: 'compareSankeyDiff';\n}\n"]}
@@ -1,24 +0,0 @@
1
- import type { IPointLike } from '@visactor/vutils';
2
- import type { IConversionFunnelSpec, Arrow } from './interface';
3
- export interface ParsedArrow extends Arrow {
4
- position: 'left' | 'right';
5
- distance: number;
6
- span: number;
7
- layout: {
8
- isLayout: boolean;
9
- duplicateNode: ParsedArrow | null;
10
- fromIndex: number;
11
- toIndex: number;
12
- fromTotal: number;
13
- toTotal: number;
14
- level: number;
15
- points: IPointLike[];
16
- };
17
- context: {
18
- field: string;
19
- };
20
- id: string;
21
- }
22
- export declare const conversionArrowTransform: (arrowSpec: IConversionFunnelSpec['conversionArrow'], options: {
23
- categoryField: string;
24
- }) => ParsedArrow[];
@@ -1,99 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: !0
5
- }), exports.conversionArrowTransform = void 0;
6
-
7
- const vutils_1 = require("@visactor/vutils"), util_1 = require("./util"), conversionArrowTransform = (arrowSpec, options) => {
8
- var _a, _b, _c;
9
- if (!arrowSpec || !(null === (_a = arrowSpec.arrows) || void 0 === _a ? void 0 : _a.length)) return [];
10
- const {arrows: arrows} = arrowSpec, parsedArrows = parseArrow(arrows, options.categoryField), leftArrows = parsedArrows.filter((arrow => "left" === arrow.position)), rightArrows = parsedArrows.filter((arrow => "right" === arrow.position));
11
- return [ ...null !== (_b = computeArrows(leftArrows)) && void 0 !== _b ? _b : [], ...null !== (_c = computeArrows(rightArrows)) && void 0 !== _c ? _c : [] ];
12
- };
13
-
14
- function parseArrow(arrows, categoryField) {
15
- return arrows.filter((arrow => (0, vutils_1.isValidNumber)(arrow.from * arrow.to))).map(((arrow, index) => {
16
- const {from: from, to: to, position: position = "right"} = arrow;
17
- return Object.assign(Object.assign({}, arrow), {
18
- position: position,
19
- distance: arrow.distance || 40,
20
- from: Math.min(from, to),
21
- to: Math.max(from, to),
22
- span: Math.abs(from - to),
23
- isLayout: !1,
24
- context: {
25
- field: categoryField
26
- },
27
- layout: {
28
- level: 0
29
- },
30
- id: `${from}-${to}-${position}-${index}`
31
- });
32
- }));
33
- }
34
-
35
- function computeArrows(arrows) {
36
- if (0 === (null == arrows ? void 0 : arrows.length)) return null;
37
- const nodeDegreeMap = new Map;
38
- return arrows.forEach((arrow => {
39
- const fromNodeDegree = nodeDegreeMap.get(arrow.from);
40
- if ((0, vutils_1.isValid)(fromNodeDegree)) {
41
- const firstNodeWidthSameFromTo = fromNodeDegree.fromArrows.find((node => (0, util_1.isSameArrow)(node, arrow)));
42
- firstNodeWidthSameFromTo ? arrow.layout.duplicateNode = firstNodeWidthSameFromTo : fromNodeDegree.degree += 1,
43
- fromNodeDegree.fromArrows.push(arrow);
44
- } else nodeDegreeMap.set(arrow.from, {
45
- fromArrows: [ arrow ],
46
- toArrows: [],
47
- totalArrows: [],
48
- degree: 1
49
- });
50
- const toNodeDegree = nodeDegreeMap.get(arrow.to);
51
- if ((0, vutils_1.isValid)(toNodeDegree)) {
52
- const firstNodeWidthSameFromTo = toNodeDegree.toArrows.find((node => (0, util_1.isSameArrow)(node, arrow)));
53
- firstNodeWidthSameFromTo ? arrow.layout.duplicateNode = firstNodeWidthSameFromTo : toNodeDegree.degree += 1,
54
- toNodeDegree.toArrows.push(arrow);
55
- } else nodeDegreeMap.set(arrow.to, {
56
- toArrows: [ arrow ],
57
- fromArrows: [],
58
- totalArrows: [],
59
- degree: 1
60
- });
61
- })), nodeDegreeMap.forEach((node => {
62
- node.fromArrows.sort(((a, b) => b.span - a.span)), node.toArrows.sort(((a, b) => a.span - b.span)),
63
- node.totalArrows = [ ...node.toArrows, ...node.fromArrows ];
64
- })), arrows.sort(((a, b) => a.span - b.span)).forEach((arrow => {
65
- var _a;
66
- const arrowsIsLayout = arrows.filter((arrow => arrow.layout.isLayout)), maxLevelArrow = (0,
67
- vutils_1.maxInArray)(arrowsIsLayout, ((cur, curMax) => cur.layout.level - curMax.layout.level));
68
- let level = null !== (_a = null == maxLevelArrow ? void 0 : maxLevelArrow.layout.level) && void 0 !== _a ? _a : 0;
69
- for (;level >= 0; ) {
70
- if (arrowsIsLayout.some((arr => arr.layout.level === level && (0, util_1.isArrowCross)(arr, arrow)))) {
71
- level += 1;
72
- break;
73
- }
74
- --level;
75
- }
76
- arrow.layout.level = Math.max(0, level), arrow.layout.fromTotal = nodeDegreeMap.get(arrow.from).degree,
77
- arrow.layout.toTotal = nodeDegreeMap.get(arrow.to).degree;
78
- const duplicateNode = arrow.layout.duplicateNode;
79
- duplicateNode ? (arrow.layout.fromIndex = duplicateNode.layout.fromIndex, arrow.layout.toIndex = duplicateNode.layout.toIndex) : (arrow.layout.fromIndex = computeIndex(arrow, nodeDegreeMap.get(arrow.from).totalArrows),
80
- arrow.layout.toIndex = computeIndex(arrow, nodeDegreeMap.get(arrow.to).totalArrows)),
81
- arrow.layout.isLayout = !0;
82
- })), arrows;
83
- }
84
-
85
- function computeIndex(arrow, totalArrows) {
86
- let index = 0, duplicateCount = 0;
87
- for (let i = 0; i < totalArrows.length; i++) {
88
- const curArrow = totalArrows[i];
89
- if (curArrow === arrow) {
90
- index = i - duplicateCount;
91
- break;
92
- }
93
- curArrow.layout.duplicateNode && duplicateCount++;
94
- }
95
- return index;
96
- }
97
-
98
- //# sourceMappingURL=arrow-data-transform.js.map
99
- exports.conversionArrowTransform = conversionArrowTransform;
@@ -1 +0,0 @@
1
- {"version":3,"sources":["charts/conversion-funnel/arrow-data-transform.ts"],"names":[],"mappings":"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","file":"arrow-data-transform.js","sourcesContent":["import type { IPointLike } from '@visactor/vutils';\nimport type { IConversionFunnelSpec, Arrow } from './interface';\nimport { isValid, isValidNumber, maxInArray } from '@visactor/vutils';\nimport { isArrowCross, isSameArrow } from './util';\n\nexport interface ParsedArrow extends Arrow {\n position: 'left' | 'right';\n distance: number;\n /** 层级跨度 */\n span: number;\n layout: {\n isLayout: boolean;\n duplicateNode: ParsedArrow | null;\n fromIndex: number;\n toIndex: number;\n fromTotal: number;\n toTotal: number;\n level: number;\n points: IPointLike[];\n };\n context: {\n field: string;\n };\n id: string;\n}\n\nexport const conversionArrowTransform = (\n arrowSpec: IConversionFunnelSpec['conversionArrow'],\n options: {\n categoryField: string;\n }\n) => {\n if (!arrowSpec || !arrowSpec.arrows?.length) {\n return [];\n }\n const { arrows } = arrowSpec;\n\n const parsedArrows = parseArrow(arrows, options.categoryField);\n const leftArrows = parsedArrows.filter(arrow => arrow.position === 'left');\n const rightArrows = parsedArrows.filter(arrow => arrow.position === 'right');\n\n const left = computeArrows(leftArrows) ?? [];\n const right = computeArrows(rightArrows) ?? [];\n return [...left, ...right];\n};\n\nfunction parseArrow(arrows: Arrow[], categoryField: string): ParsedArrow[] {\n return arrows\n .filter(arrow => isValidNumber(arrow.from * arrow.to))\n .map((arrow, index) => {\n const { from, to, position = 'right' } = arrow;\n return {\n ...arrow,\n position,\n distance: arrow.distance || 40,\n from: Math.min(from, to),\n to: Math.max(from, to),\n span: Math.abs(from - to),\n isLayout: false,\n context: {\n field: categoryField\n },\n layout: {\n level: 0\n },\n id: `${from}-${to}-${position}-${index}`\n } as unknown as ParsedArrow;\n });\n}\n\nfunction computeArrows(arrows: ParsedArrow[]) {\n if (arrows?.length === 0) {\n return null;\n }\n\n const nodeDegreeMap = new Map<\n number,\n {\n fromArrows: ParsedArrow[];\n toArrows: ParsedArrow[];\n totalArrows: ParsedArrow[];\n degree: number;\n }\n >();\n\n arrows.forEach(arrow => {\n const fromNodeDegree = nodeDegreeMap.get(arrow.from);\n if (isValid(fromNodeDegree)) {\n const firstNodeWidthSameFromTo = fromNodeDegree.fromArrows.find(node => isSameArrow(node, arrow));\n if (!firstNodeWidthSameFromTo) {\n fromNodeDegree.degree += 1;\n } else {\n arrow.layout.duplicateNode = firstNodeWidthSameFromTo;\n }\n fromNodeDegree.fromArrows.push(arrow);\n } else {\n nodeDegreeMap.set(arrow.from, {\n fromArrows: [arrow],\n toArrows: [],\n totalArrows: [],\n degree: 1\n });\n }\n\n const toNodeDegree = nodeDegreeMap.get(arrow.to);\n if (isValid(toNodeDegree)) {\n const firstNodeWidthSameFromTo = toNodeDegree.toArrows.find(node => isSameArrow(node, arrow));\n if (!firstNodeWidthSameFromTo) {\n toNodeDegree.degree += 1;\n } else {\n arrow.layout.duplicateNode = firstNodeWidthSameFromTo;\n }\n toNodeDegree.toArrows.push(arrow);\n } else {\n nodeDegreeMap.set(arrow.to, {\n toArrows: [arrow],\n fromArrows: [],\n totalArrows: [],\n degree: 1\n });\n }\n });\n nodeDegreeMap.forEach(node => {\n // 入边,层级跨度越大的越靠下\n node.fromArrows.sort((a, b) => b.span - a.span);\n // 出边,层级跨度越大的越靠上\n node.toArrows.sort((a, b) => a.span - b.span);\n // 入边在上,出边在下\n node.totalArrows = [...node.toArrows, ...node.fromArrows];\n });\n\n arrows\n .sort((a, b) => a.span - b.span)\n .forEach(arrow => {\n const arrowsIsLayout = arrows.filter(arrow => arrow.layout.isLayout);\n // 1. 计算当前箭头所在层级\n const maxLevelArrow = maxInArray(arrowsIsLayout, (cur, curMax) => cur.layout.level - curMax.layout.level);\n\n let level = maxLevelArrow?.layout.level ?? 0;\n while (level >= 0) {\n if (arrowsIsLayout.some(arr => arr.layout.level === level && isArrowCross(arr, arrow))) {\n level += 1;\n break;\n }\n --level;\n }\n arrow.layout.level = Math.max(0, level);\n // 2. 获取当前箭头所在层级的出入度信息\n arrow.layout.fromTotal = nodeDegreeMap.get(arrow.from).degree;\n arrow.layout.toTotal = nodeDegreeMap.get(arrow.to).degree;\n // 3. 计算 from 和 to 的顺序\n const duplicateNode = arrow.layout.duplicateNode;\n if (duplicateNode) {\n arrow.layout.fromIndex = duplicateNode.layout.fromIndex;\n arrow.layout.toIndex = duplicateNode.layout.toIndex;\n } else {\n arrow.layout.fromIndex = computeIndex(arrow, nodeDegreeMap.get(arrow.from).totalArrows);\n arrow.layout.toIndex = computeIndex(arrow, nodeDegreeMap.get(arrow.to).totalArrows);\n }\n arrow.layout.isLayout = true;\n });\n\n return arrows;\n}\n\nfunction computeIndex(arrow: ParsedArrow, totalArrows: ParsedArrow[]) {\n let index = 0;\n let duplicateCount = 0;\n for (let i = 0; i < totalArrows.length; i++) {\n const curArrow = totalArrows[i];\n if (curArrow === arrow) {\n index = i - duplicateCount;\n break;\n }\n if (curArrow.layout.duplicateNode) {\n duplicateCount++;\n }\n }\n return index;\n}\n"]}
@@ -1,7 +0,0 @@
1
- import type { IConversionFunnelChartSpecBase } from './interface';
2
- declare const ConversionFunnelChartSpecTransformer_base: typeof import("@visactor/vchart/esm/chart/funnel").FunnelChartSpecTransformer;
3
- export declare class ConversionFunnelChartSpecTransformer extends ConversionFunnelChartSpecTransformer_base<IConversionFunnelChartSpecBase> {
4
- transformSpec(spec: IConversionFunnelChartSpecBase): void;
5
- _getDefaultSeriesSpec(spec: IConversionFunnelChartSpecBase): import("@visactor/vchart").IFunnelSeriesSpec;
6
- }
7
- export {};