@visactor/vchart-extension 1.13.22-alpha.4 → 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 -24
  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 -21
  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 -16
  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 -4
  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,64 +0,0 @@
1
- import { CommonChartSpecTransformer } from "@visactor/vchart";
2
-
3
- import { processSequenceData } from "./utils";
4
-
5
- import { DATA_KEY } from "./constant";
6
-
7
- export class SequenceScatterPixelChartSpecTransformer extends CommonChartSpecTransformer {
8
- transformSpec(spec) {
9
- var _a, _b, _c, _d, _e;
10
- super.transformSpec(spec);
11
- const dataSpecs = processSequenceData(spec);
12
- spec.type = "common", spec.dataKey = DATA_KEY, spec.data = dataSpecs[0].data, spec.width = 300,
13
- spec.height = 300, spec.autoFit = !1, spec.series = [ {
14
- type: "scatter",
15
- xField: spec.xField,
16
- yField: spec.yField
17
- } ], spec.player && (spec.player = Object.assign(Object.assign({}, spec.player), {
18
- specs: dataSpecs
19
- }), spec.animationAppear = {
20
- duration: null !== (_b = null === (_a = spec.player) || void 0 === _a ? void 0 : _a.duration) && void 0 !== _b ? _b : 2e3,
21
- easing: "linear"
22
- }, spec.animationUpdate = {
23
- duration: null !== (_d = null === (_c = spec.player) || void 0 === _c ? void 0 : _c.duration) && void 0 !== _d ? _d : 2e3,
24
- easing: "linear"
25
- }), spec.axes = [ {
26
- orient: "left",
27
- type: "linear"
28
- }, {
29
- orient: "bottom",
30
- label: {
31
- visible: !0
32
- },
33
- type: "linear"
34
- } ], spec.customMark = [ {
35
- type: "image",
36
- dataIndex: 2,
37
- style: {
38
- x: 0,
39
- y: 0,
40
- width: 300,
41
- height: 300,
42
- image: datum => datum.imageData,
43
- zIndex: -1
44
- }
45
- }, {
46
- type: "text",
47
- dataIndex: 1,
48
- style: Object.assign({
49
- text: datum => datum.inter,
50
- x: 50,
51
- y: () => 10,
52
- textBaseline: "top",
53
- textAlign: "left",
54
- fontSize: 100,
55
- fontWeight: "bolder",
56
- fill: "black",
57
- fillOpacity: .2
58
- }, null === (_e = spec.infoLabel) || void 0 === _e ? void 0 : _e.style)
59
- } ], spec.tooltip = {
60
- visible: !1
61
- }, super.transformSpec(spec);
62
- }
63
- }
64
- //# sourceMappingURL=sequence-scatter-pixel-transformer.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["charts/sequence-scatter-pixel/sequence-scatter-pixel-transformer.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,0BAA0B,EAAE,MAAM,kBAAkB,CAAC;AAC9D,OAAO,EAAE,mBAAmB,EAAE,MAAM,SAAS,CAAC;AAC9C,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAEtC,MAAM,OAAO,wCAAyC,SAAQ,0BAA+B;IAC3F,aAAa,CAAC,IAAS;;QACrB,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QAC1B,MAAM,SAAS,GAAG,mBAAmB,CAAC,IAA4C,CAAC,CAAC;QAEpF,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC;QACrB,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC;QACxB,IAAI,CAAC,IAAI,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QAE9B,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC;QACjB,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC;QAClB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QAErB,IAAI,CAAC,MAAM,GAAG;YACZ;gBACE,IAAI,EAAE,SAAS;gBACf,MAAM,EAAE,IAAI,CAAC,MAAM;gBACnB,MAAM,EAAE,IAAI,CAAC,MAAM;aACpB;SACF,CAAC;QAEF,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,MAAM,mCACN,IAAI,CAAC,MAAM,KACd,KAAK,EAAE,SAAS,GACjB,CAAC;YACF,IAAI,CAAC,eAAe,GAAG;gBACrB,QAAQ,EAAE,MAAA,MAAA,IAAI,CAAC,MAAM,0CAAE,QAAQ,mCAAI,IAAI;gBACvC,MAAM,EAAE,QAAQ;aACjB,CAAC;YAEF,IAAI,CAAC,eAAe,GAAG;gBACrB,QAAQ,EAAE,MAAA,MAAA,IAAI,CAAC,MAAM,0CAAE,QAAQ,mCAAI,IAAI;gBACvC,MAAM,EAAE,QAAQ;aACjB,CAAC;SACH;QAED,IAAI,CAAC,IAAI,GAAG;YACV;gBACE,MAAM,EAAE,MAAM;gBACd,IAAI,EAAE,QAAQ;aACf;YACD;gBACE,MAAM,EAAE,QAAQ;gBAChB,KAAK,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE;gBACxB,IAAI,EAAE,QAAQ;aACf;SACF,CAAC;QAEF,IAAI,CAAC,UAAU,GAAG;YAEhB;gBACE,IAAI,EAAE,OAAO;gBACb,SAAS,EAAE,CAAC;gBACZ,KAAK,EAAE;oBACL,CAAC,EAAE,CAAC;oBACJ,CAAC,EAAE,CAAC;oBACJ,KAAK,EAAE,GAAG;oBACV,MAAM,EAAE,GAAG;oBACX,KAAK,EAAE,CAAC,KAAY,EAAE,EAAE,CAAC,KAAK,CAAC,SAAS;oBACxC,MAAM,EAAE,CAAC,CAAC;iBACX;aACF;YACD;gBACE,IAAI,EAAE,MAAM;gBACZ,SAAS,EAAE,CAAC;gBACZ,KAAK,kBACH,IAAI,EAAE,CAAC,KAAY,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,EACtC,CAAC,EAAE,EAAE,EACL,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,EACX,YAAY,EAAE,KAAK,EACnB,SAAS,EAAE,MAAM,EACjB,QAAQ,EAAE,GAAG,EACb,UAAU,EAAE,QAAQ,EACpB,IAAI,EAAE,OAAO,EACb,WAAW,EAAE,GAAG,IACb,MAAA,IAAI,CAAC,SAAS,0CAAE,KAAK,CACzB;aACF;SACF,CAAC;QAEF,IAAI,CAAC,OAAO,GAAG;YACb,OAAO,EAAE,KAAK;SACf,CAAC;QAEF,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC;CACF","file":"sequence-scatter-pixel-transformer.js","sourcesContent":["import { Datum } from '@visactor/vchart/src/typings';\nimport type { ISequenceScatterPixelSpec } from './interface';\nimport { CommonChartSpecTransformer } from '@visactor/vchart';\nimport { processSequenceData } from './utils';\nimport { DATA_KEY } from './constant';\n\nexport class SequenceScatterPixelChartSpecTransformer extends CommonChartSpecTransformer<any> {\n transformSpec(spec: any): void {\n super.transformSpec(spec);\n const dataSpecs = processSequenceData(spec as unknown as ISequenceScatterPixelSpec);\n\n spec.type = 'common';\n spec.dataKey = DATA_KEY;\n spec.data = dataSpecs[0].data;\n\n spec.width = 300;\n spec.height = 300;\n spec.autoFit = false;\n\n spec.series = [\n {\n type: 'scatter',\n xField: spec.xField,\n yField: spec.yField\n }\n ];\n\n if (spec.player) {\n spec.player = {\n ...spec.player,\n specs: dataSpecs\n };\n spec.animationAppear = {\n duration: spec.player?.duration ?? 2000,\n easing: 'linear'\n };\n\n spec.animationUpdate = {\n duration: spec.player?.duration ?? 2000,\n easing: 'linear'\n };\n }\n\n spec.axes = [\n {\n orient: 'left',\n type: 'linear'\n },\n {\n orient: 'bottom',\n label: { visible: true },\n type: 'linear'\n }\n ];\n\n spec.customMark = [\n // 背景图像\n {\n type: 'image',\n dataIndex: 2,\n style: {\n x: 0,\n y: 0,\n width: 300,\n height: 300,\n image: (datum: Datum) => datum.imageData,\n zIndex: -1\n }\n },\n {\n type: 'text',\n dataIndex: 1,\n style: {\n text: (datum: Datum) => datum['inter'],\n x: 50,\n y: () => 10,\n textBaseline: 'top',\n textAlign: 'left',\n fontSize: 100,\n fontWeight: 'bolder',\n fill: 'black',\n fillOpacity: 0.2,\n ...spec.infoLabel?.style\n }\n }\n ];\n\n spec.tooltip = {\n visible: false\n };\n\n super.transformSpec(spec);\n }\n}\n"]}
@@ -1,16 +0,0 @@
1
- import { ISequenceScatterPixelSpec } from './interface';
2
- import { VChart, BaseChart } from '@visactor/vchart';
3
- import { SequenceScatterPixelChartSpecTransformer } from './sequence-scatter-pixel-transformer';
4
- export declare class SequenceScatterPixel extends BaseChart<Omit<ISequenceScatterPixelSpec, 'data'>> {
5
- type: string;
6
- static type: string;
7
- static readonly view: string;
8
- _spec: ISequenceScatterPixelSpec;
9
- static readonly transformerConstructor: typeof SequenceScatterPixelChartSpecTransformer;
10
- readonly transformerConstructor: typeof SequenceScatterPixelChartSpecTransformer;
11
- init(): void;
12
- protected isValid(): boolean;
13
- }
14
- export declare const registerSequenceScatterPixel: (option?: {
15
- VChart?: typeof VChart;
16
- }) => void;
@@ -1,28 +0,0 @@
1
- import { VChart, BaseChart, ScatterChart } from "@visactor/vchart";
2
-
3
- import { SequenceScatterPixelChartSpecTransformer } from "./sequence-scatter-pixel-transformer";
4
-
5
- export class SequenceScatterPixel extends BaseChart {
6
- constructor() {
7
- super(...arguments), this.type = "sequenceScatterPixel", this.transformerConstructor = SequenceScatterPixelChartSpecTransformer;
8
- }
9
- init() {
10
- this.isValid() && super.init();
11
- }
12
- isValid() {
13
- var _a, _b, _c, _d;
14
- const {xField: xField, yField: yField, data: data} = this._spec;
15
- return xField && yField ? !!data || (null === (_d = (_c = this._option).onError) || void 0 === _d || _d.call(_c, "Data is required"),
16
- !1) : (null === (_b = (_a = this._option).onError) || void 0 === _b || _b.call(_a, "Missing Required Config: `xField`, `yField` "),
17
- !1);
18
- }
19
- }
20
-
21
- SequenceScatterPixel.type = "sequenceScatterPixel", SequenceScatterPixel.view = "singleDefault",
22
- SequenceScatterPixel.transformerConstructor = SequenceScatterPixelChartSpecTransformer;
23
-
24
- export const registerSequenceScatterPixel = option => {
25
- const vchartConstructor = (null == option ? void 0 : option.VChart) || VChart;
26
- vchartConstructor && vchartConstructor.useChart([ SequenceScatterPixel, ScatterChart ]);
27
- };
28
- //# sourceMappingURL=sequence-scatter-pixel.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["charts/sequence-scatter-pixel/sequence-scatter-pixel.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AACnE,OAAO,EAAE,wCAAwC,EAAE,MAAM,sCAAsC,CAAC;AAEhG,MAAM,OAAO,oBAAqB,SAAQ,SAAkD;IAA5F;;QACE,SAAI,GAAG,sBAAsB,CAAC;QAOrB,2BAAsB,GAAG,wCAAwC,CAAC;IAqB7E,CAAC;IAnBC,IAAI;QACF,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE;YACnB,OAAO;SACR;QACD,KAAK,CAAC,IAAI,EAAE,CAAC;IACf,CAAC;IAES,OAAO;;QACf,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC;QAC5C,IAAI,CAAC,MAAM,IAAI,CAAC,MAAM,EAAE;YACtB,MAAA,MAAA,IAAI,CAAC,OAAO,EAAC,OAAO,mDAAG,8CAA8C,CAAC,CAAC;YACvE,OAAO,KAAK,CAAC;SACd;QACD,IAAI,CAAC,IAAI,EAAE;YACT,MAAA,MAAA,IAAI,CAAC,OAAO,EAAC,OAAO,mDAAG,kBAAkB,CAAC,CAAC;YAC3C,OAAO,KAAK,CAAC;SACd;QACD,OAAO,IAAI,CAAC;IACd,CAAC;;AA1BM,yBAAI,GAAG,sBAAsB,CAAC;AACrB,yBAAI,GAAW,eAAe,CAAC;AAI/B,2CAAsB,GAAG,wCAAwC,CAAC;AAwBpF,MAAM,CAAC,MAAM,4BAA4B,GAAG,CAAC,MAAmC,EAAE,EAAE;IAClF,MAAM,iBAAiB,GAAG,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,MAAM,KAAI,MAAM,CAAC;IACnD,IAAI,iBAAiB,EAAE;QACrB,iBAAiB,CAAC,QAAQ,CAAC,CAAC,oBAAoB,EAAE,YAAY,CAAC,CAAC,CAAC;KAClE;AACH,CAAC,CAAC","file":"sequence-scatter-pixel.js","sourcesContent":["import { ISequenceScatterPixelSpec } from './interface';\nimport { VChart, BaseChart, ScatterChart } from '@visactor/vchart';\nimport { SequenceScatterPixelChartSpecTransformer } from './sequence-scatter-pixel-transformer';\n\nexport class SequenceScatterPixel extends BaseChart<Omit<ISequenceScatterPixelSpec, 'data'>> {\n type = 'sequenceScatterPixel';\n static type = 'sequenceScatterPixel';\n static readonly view: string = 'singleDefault';\n\n declare _spec: ISequenceScatterPixelSpec;\n\n static readonly transformerConstructor = SequenceScatterPixelChartSpecTransformer;\n readonly transformerConstructor = SequenceScatterPixelChartSpecTransformer;\n\n init() {\n if (!this.isValid()) {\n return;\n }\n super.init();\n }\n\n protected isValid() {\n const { xField, yField, data } = this._spec;\n if (!xField || !yField) {\n this._option.onError?.('Missing Required Config: `xField`, `yField` ');\n return false;\n }\n if (!data) {\n this._option.onError?.('Data is required');\n return false;\n }\n return true;\n }\n}\n\nexport const registerSequenceScatterPixel = (option?: { VChart?: typeof VChart }) => {\n const vchartConstructor = option?.VChart || VChart;\n if (vchartConstructor) {\n vchartConstructor.useChart([SequenceScatterPixel, ScatterChart]);\n }\n};\n"]}
@@ -1,3 +0,0 @@
1
- import { ISequenceScatterPixelSpec } from './interface';
2
- export declare function createImageDataFromColorMatrix(colorMatrix: any[][], spec: ISequenceScatterPixelSpec): string | null;
3
- export declare function processSequenceData(spec: ISequenceScatterPixelSpec): any[];
@@ -1,46 +0,0 @@
1
- import { BACKGROUND_KEY, DATA_KEY } from "./constant";
2
-
3
- export function createImageDataFromColorMatrix(colorMatrix, spec) {
4
- var _a;
5
- if ("undefined" == typeof document) throw new Error("Canvas rendering requires browser environment with document object");
6
- const canvas = document.createElement("canvas");
7
- canvas.width = spec.width, canvas.height = spec.height;
8
- const ctx = canvas.getContext("2d");
9
- if (!ctx) throw new Error("Failed to get 2D rendering context from canvas");
10
- const imageData = ctx.createImageData(spec.width, spec.height);
11
- for (let y = 0; y < 300; y++) for (let x = 0; x < 300; x++) {
12
- const rgb = (null === (_a = colorMatrix[y]) || void 0 === _a ? void 0 : _a[x]) || [ 0, 0, 0 ], pixelIndex = 4 * (300 * y + x);
13
- imageData.data[pixelIndex] = Math.round(255 * rgb[0]), imageData.data[pixelIndex + 1] = Math.round(255 * rgb[1]),
14
- imageData.data[pixelIndex + 2] = Math.round(255 * rgb[2]), imageData.data[pixelIndex + 3] = 255;
15
- }
16
- return ctx.putImageData(imageData, 0, 0), canvas.toDataURL("image/png");
17
- }
18
-
19
- export function processSequenceData(spec) {
20
- const result = [];
21
- return Object.keys(spec.data).forEach((inter => {
22
- let backgroundData = null;
23
- if (spec.backgroundColors && spec.backgroundColors[inter]) {
24
- backgroundData = {
25
- imageData: createImageDataFromColorMatrix(spec.backgroundColors[inter], spec)
26
- };
27
- }
28
- result.push({
29
- data: [ {
30
- id: "nodes",
31
- values: spec.data[inter].map(((d, i) => Object.assign(Object.assign({}, d), {
32
- [DATA_KEY]: i
33
- })))
34
- }, {
35
- id: "inter",
36
- values: [ {
37
- inter: inter
38
- } ]
39
- }, {
40
- id: BACKGROUND_KEY,
41
- values: backgroundData ? [ backgroundData ] : []
42
- } ]
43
- });
44
- })), result;
45
- }
46
- //# sourceMappingURL=utils.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["charts/sequence-scatter-pixel/utils.ts"],"names":[],"mappings":"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","file":"utils.js","sourcesContent":["import { ISequenceScatterPixelSpec } from './interface';\nimport { BACKGROUND_KEY, DATA_KEY } from './constant';\n\n// 将RGB三元组数组转换为Canvas可用的imageData\nexport function createImageDataFromColorMatrix(colorMatrix: any[][], spec: ISequenceScatterPixelSpec): string | null {\n // 浏览器环境检查\n if (typeof document === 'undefined') {\n throw new Error('Canvas rendering requires browser environment with document object'); // 非浏览器环境下返回null\n }\n\n // 创建Canvas离屏渲染\n const canvas = document.createElement('canvas');\n canvas.width = spec.width;\n canvas.height = spec.height;\n const ctx = canvas.getContext('2d');\n\n if (!ctx) {\n throw new Error('Failed to get 2D rendering context from canvas'); // Canvas context creation failed\n }\n\n // 创建imageData\n const imageData = ctx.createImageData(spec.width, spec.height);\n\n // 填充像素数据\n for (let y = 0; y < 300; y++) {\n for (let x = 0; x < 300; x++) {\n const rgb = colorMatrix[y]?.[x] || [0, 0, 0];\n const pixelIndex = (y * 300 + x) * 4;\n\n // 转换0-1范围到0-255\n imageData.data[pixelIndex] = Math.round(rgb[0] * 255); // R\n imageData.data[pixelIndex + 1] = Math.round(rgb[1] * 255); // G\n imageData.data[pixelIndex + 2] = Math.round(rgb[2] * 255); // B\n imageData.data[pixelIndex + 3] = 255; // A (完全不透明)\n }\n }\n\n // 将imageData绘制到canvas然后返回dataURL\n ctx.putImageData(imageData, 0, 0);\n return canvas.toDataURL('image/png');\n}\n\nexport function processSequenceData(spec: ISequenceScatterPixelSpec) {\n const result: any[] = [];\n Object.keys(spec.data).forEach(inter => {\n let backgroundData = null;\n if (spec.backgroundColors && spec.backgroundColors[inter]) {\n const imageData = createImageDataFromColorMatrix(spec.backgroundColors[inter], spec);\n backgroundData = { imageData };\n }\n result.push({\n data: [\n {\n id: 'nodes',\n values: spec.data[inter].map((d, i) => {\n return { ...d, [DATA_KEY]: i };\n })\n },\n {\n id: 'inter',\n values: [\n {\n inter\n }\n ]\n },\n {\n id: BACKGROUND_KEY,\n values: backgroundData ? [backgroundData] : []\n }\n ]\n });\n });\n return result;\n}\n"]}
@@ -1,7 +0,0 @@
1
- import { AbstractComponent } from '@visactor/vrender-components';
2
- import { BarLinkAttrs } from './type';
3
- export declare class BarLinkComponent extends AbstractComponent<Required<BarLinkAttrs>> {
4
- name: string;
5
- protected render(): void;
6
- }
7
- export declare const registerBarLink: () => void;
@@ -1,85 +0,0 @@
1
- import { AbstractComponent, Segment } from "@visactor/vrender-components";
2
-
3
- import { cloneDeep, isEmpty } from "@visactor/vutils";
4
-
5
- import { Factory } from "@visactor/vgrammar-core";
6
-
7
- import { createArea, createText } from "@visactor/vrender-core";
8
-
9
- import { STACK_FIELD_END, STACK_FIELD_START } from "@visactor/vchart";
10
-
11
- import { BAR_LINK } from "./constant";
12
-
13
- export class BarLinkComponent extends AbstractComponent {
14
- constructor() {
15
- super(...arguments), this.name = BAR_LINK;
16
- }
17
- render() {
18
- const {data: data, linkStyle: linkStyle, areaStyle: areaStyle, styleMap: styleMap, label: label, linkType: linkType = "total"} = this.attribute;
19
- isEmpty(data) || (this.removeAllChild(), data.forEach(((datum, index) => {
20
- var _a, _b, _c, _d, _e;
21
- const {linePoints: linePoints, areaPoints: areaPoints, id: id = index, color: color, data: curData} = datum;
22
- if (areaPoints && !1 !== (null === (_a = null == styleMap ? void 0 : styleMap[`area-${id}`]) || void 0 === _a ? void 0 : _a.visible)) {
23
- const area = createArea(Object.assign(Object.assign({
24
- points: areaPoints,
25
- fillOpacity: .3,
26
- fill: color,
27
- zIndex: 0
28
- }, areaStyle), null == styleMap ? void 0 : styleMap[`area-${id}`]));
29
- area.name = "bar-link-area", area.id = `area-${id}`, this.add(area);
30
- }
31
- if (linePoints && !1 !== (null === (_b = null == styleMap ? void 0 : styleMap[`line-${id}`]) || void 0 === _b ? void 0 : _b.visible) && 0 !== (null === (_c = null == linkStyle ? void 0 : linkStyle.lineStyle) || void 0 === _c ? void 0 : _c.lineWidth) && 0 !== (null === (_d = null == styleMap ? void 0 : styleMap[`line-${id}`]) || void 0 === _d ? void 0 : _d.lineWidth)) {
32
- const {startSymbol: startSymbol = {}, endSymbol: endSymbol = {}, lineStyle: lineStyle} = linkStyle || {}, startSymbolAttrs = cloneDeep(startSymbol), endSymbolAttrs = cloneDeep(endSymbol);
33
- (null == styleMap ? void 0 : styleMap[`line-${id}`]) && styleMap[`line-${id}`].stroke && (startSymbolAttrs.style = Object.assign(Object.assign({}, startSymbolAttrs.style), {
34
- color: styleMap[`line-${id}`].stroke
35
- }), endSymbolAttrs.style = Object.assign(Object.assign({}, endSymbolAttrs.style), {
36
- color: styleMap[`line-${id}`].stroke
37
- })), startSymbolAttrs.symbolType || startSymbolAttrs.originSymbolType || (startSymbolAttrs.originSymbolType = "solidArrow"),
38
- endSymbolAttrs.symbolType || endSymbolAttrs.originSymbolType || (endSymbolAttrs.originSymbolType = "solidArrow");
39
- const line = new Segment({
40
- points: linePoints,
41
- startSymbol: Object.assign({
42
- size: 8
43
- }, startSymbolAttrs),
44
- endSymbol: Object.assign({
45
- size: 8
46
- }, endSymbolAttrs),
47
- lineStyle: Object.assign(Object.assign({
48
- lineDash: [ 3, 3 ],
49
- lineWidth: 1,
50
- stroke: "#000"
51
- }, lineStyle), null == styleMap ? void 0 : styleMap[`line-${id}`]),
52
- pickable: !0,
53
- childrenPickable: !1,
54
- zIndex: 1
55
- });
56
- line.name = "bar-link-line", line.id = `line-${id}`, this.add(line);
57
- }
58
- if ((null == label ? void 0 : label.visible) && !1 !== (null === (_e = null == styleMap ? void 0 : styleMap[`label-${id}`]) || void 0 === _e ? void 0 : _e.visible)) {
59
- const {style: style, formatMethod: formatMethod} = label, [startData, endData] = curData;
60
- let startValue = startData[STACK_FIELD_END], endValue = endData[STACK_FIELD_END];
61
- "value" === linkType && (startValue = startData[STACK_FIELD_END] - startData[STACK_FIELD_START],
62
- endValue = endData[STACK_FIELD_END] - endData[STACK_FIELD_START]);
63
- const value = endValue - startValue, percentage = (endValue - startValue) / startValue * 100, text = createText(Object.assign(Object.assign({
64
- x: .5 * (linePoints[0].x + linePoints[1].x),
65
- y: .5 * (linePoints[0].y + linePoints[1].y),
66
- text: formatMethod ? formatMethod(value, percentage, curData) : `${value} ${percentage}`,
67
- fontSize: 14,
68
- fill: "#000",
69
- stroke: "#fff",
70
- lineWidth: 1,
71
- textAlign: "center",
72
- textBaseline: "middle",
73
- background: "#fff",
74
- zIndex: 2
75
- }, style), null == styleMap ? void 0 : styleMap[`label-${id}`]));
76
- text.name = "bar-link-label", text.id = `label-${id}`, this.add(text);
77
- }
78
- })));
79
- }
80
- }
81
-
82
- export const registerBarLink = () => {
83
- Factory.registerGraphicComponent(BAR_LINK, (attrs => new BarLinkComponent(attrs)));
84
- };
85
- //# sourceMappingURL=bar-link.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["components/bar-link/bar-link.ts"],"names":[],"mappings":"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","file":"bar-link.js","sourcesContent":["/**\n * @description 堆叠柱系列的连接线组件\n * @author zhangweixing\n */\nimport { AbstractComponent, Segment } from '@visactor/vrender-components';\nimport { cloneDeep, isEmpty } from '@visactor/vutils';\nimport { Factory } from '@visactor/vgrammar-core';\nimport { type IGraphic, type ILineGraphicAttribute, createArea, createText } from '@visactor/vrender-core';\nimport { STACK_FIELD_END, STACK_FIELD_START } from '@visactor/vchart';\nimport { BarLinkAttrs } from './type';\nimport { BAR_LINK } from './constant';\n\nexport class BarLinkComponent extends AbstractComponent<Required<BarLinkAttrs>> {\n name = BAR_LINK;\n\n protected render() {\n const { data, linkStyle, areaStyle, styleMap, label, linkType = 'total' } = this.attribute as BarLinkLineAttrs;\n if (isEmpty(data)) {\n return;\n }\n this.removeAllChild();\n data.forEach((datum, index) => {\n const { linePoints, areaPoints, id = index, color, data: curData } = datum;\n\n if (areaPoints && styleMap?.[`area-${id}`]?.visible !== false) {\n // 先绘制面\n const area = createArea({\n points: areaPoints,\n fillOpacity: 0.3,\n fill: color,\n zIndex: 0,\n ...areaStyle,\n ...styleMap?.[`area-${id}`]\n });\n area.name = 'bar-link-area';\n area.id = `area-${id}`;\n this.add(area);\n }\n\n if (\n linePoints &&\n styleMap?.[`line-${id}`]?.visible !== false &&\n linkStyle?.lineStyle?.lineWidth !== 0 &&\n styleMap?.[`line-${id}`]?.lineWidth !== 0\n ) {\n // 再绘制点\n const { startSymbol = {}, endSymbol = {}, lineStyle } = linkStyle || {};\n\n const startSymbolAttrs = cloneDeep(startSymbol);\n const endSymbolAttrs = cloneDeep(endSymbol);\n if (styleMap?.[`line-${id}`] && styleMap[`line-${id}`].stroke) {\n (startSymbolAttrs as any).style = {\n ...(startSymbolAttrs as any).style,\n color: styleMap[`line-${id}`].stroke\n };\n (endSymbolAttrs as any).style = {\n ...(endSymbolAttrs as any).style,\n color: styleMap[`line-${id}`].stroke\n };\n }\n\n if (!(startSymbolAttrs as any).symbolType && !(startSymbolAttrs as any).originSymbolType) {\n (startSymbolAttrs as any).originSymbolType = 'solidArrow';\n }\n if (!(endSymbolAttrs as any).symbolType && !(endSymbolAttrs as any).originSymbolType) {\n (endSymbolAttrs as any).originSymbolType = 'solidArrow';\n }\n const line = new Segment({\n points: linePoints,\n startSymbol: {\n size: 8,\n ...startSymbolAttrs\n },\n endSymbol: {\n size: 8,\n ...endSymbolAttrs\n },\n lineStyle: {\n lineDash: [3, 3],\n lineWidth: 1,\n stroke: '#000',\n ...lineStyle,\n ...styleMap?.[`line-${id}`]\n } as ILineGraphicAttribute,\n pickable: true,\n childrenPickable: false,\n zIndex: 1\n });\n line.name = 'bar-link-line';\n line.id = `line-${id}`;\n this.add(line as unknown as IGraphic);\n }\n\n if (label?.visible && styleMap?.[`label-${id}`]?.visible !== false) {\n const { style, formatMethod } = label;\n\n const [startData, endData] = curData;\n\n let startValue = startData[STACK_FIELD_END];\n let endValue = endData[STACK_FIELD_END];\n if (linkType === 'value') {\n startValue = startData[STACK_FIELD_END] - startData[STACK_FIELD_START];\n endValue = endData[STACK_FIELD_END] - endData[STACK_FIELD_START];\n }\n\n const value = endValue - startValue;\n const percentage = ((endValue - startValue) / startValue) * 100;\n\n const text = createText({\n x: (linePoints[0].x + linePoints[1].x) * 0.5,\n y: (linePoints[0].y + linePoints[1].y) * 0.5,\n text: formatMethod ? formatMethod(value, percentage, curData) : `${value} ${percentage}`,\n fontSize: 14,\n fill: '#000',\n stroke: '#fff',\n lineWidth: 1,\n textAlign: 'center',\n textBaseline: 'middle',\n background: '#fff',\n zIndex: 2,\n ...style,\n ...styleMap?.[`label-${id}`]\n });\n text.name = 'bar-link-label';\n text.id = `label-${id}`;\n this.add(text);\n }\n });\n }\n}\n\nexport const registerBarLink = () => {\n Factory.registerGraphicComponent(\n BAR_LINK,\n (attrs: Required<BarLinkAttrs>) => new BarLinkComponent(attrs) as unknown as IGraphic\n );\n};\n"]}
@@ -1 +0,0 @@
1
- export declare const BAR_LINK = "barLink";
@@ -1,2 +0,0 @@
1
- export const BAR_LINK = "barLink";
2
- //# sourceMappingURL=constant.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["components/bar-link/constant.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,QAAQ,GAAG,SAAS,CAAC","file":"constant.js","sourcesContent":["export const BAR_LINK = 'barLink';\n"]}
@@ -1,4 +0,0 @@
1
- export { BarLinkComponent, registerBarLink } from './bar-link';
2
- export * from './type';
3
- export { getBarLinkConfig, appendBarLinkConfig } from './util';
4
- export * from './constant';
@@ -1,7 +0,0 @@
1
- export { BarLinkComponent, registerBarLink } from "./bar-link";
2
-
3
- export * from "./type";
4
-
5
- export { getBarLinkConfig, appendBarLinkConfig } from "./util";
6
-
7
- export * from "./constant";
@@ -1 +0,0 @@
1
- {"version":3,"sources":["components/bar-link/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAC/D,cAAc,QAAQ,CAAC;AACvB,OAAO,EAAE,gBAAgB,EAAE,mBAAmB,EAAE,MAAM,QAAQ,CAAC;AAC/D,cAAc,YAAY,CAAC","file":"index.js","sourcesContent":["export { BarLinkComponent, registerBarLink } from './bar-link';\nexport * from './type';\nexport { getBarLinkConfig, appendBarLinkConfig } from './util';\nexport * from './constant';\n"]}
@@ -1,27 +0,0 @@
1
- import type { IAreaGraphicAttribute, IGroupGraphicAttribute, ILineGraphicAttribute, ITextGraphicAttribute } from '@visactor/vrender-core';
2
- import type { SegmentAttributes } from '@visactor/vrender-components';
3
- import type { Dict, IPointLike } from '@visactor/vutils';
4
- export type Point = {
5
- x: number;
6
- y: number;
7
- };
8
- export type BarLinkDatum = {
9
- areaPoints: [IPointLike, IPointLike];
10
- linePoints: [IPointLike, IPointLike];
11
- id?: string;
12
- color?: string;
13
- data: [Dict<any>, Dict<any>];
14
- };
15
- export interface BarLinkAttrs extends IGroupGraphicAttribute {
16
- data: BarLinkDatum[];
17
- linkType?: 'total' | 'value';
18
- doFill?: boolean;
19
- linkStyle?: Pick<SegmentAttributes, 'startSymbol' | 'endSymbol' | 'lineStyle'>;
20
- areaStyle?: IAreaGraphicAttribute;
21
- styleMap?: Record<string, ILineGraphicAttribute>;
22
- label?: {
23
- visible?: boolean;
24
- style?: ITextGraphicAttribute;
25
- formatMethod?: (value: number, percent: number, data: [any, any]) => (string | number) | (string | number)[];
26
- };
27
- }
@@ -1,2 +0,0 @@
1
- export { };
2
- //# sourceMappingURL=type.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["components/bar-link/type.ts"],"names":[],"mappings":"","file":"type.js","sourcesContent":["import type {\n IAreaGraphicAttribute,\n IGroupGraphicAttribute,\n ILineGraphicAttribute,\n ITextGraphicAttribute\n} from '@visactor/vrender-core';\nimport type { SegmentAttributes } from '@visactor/vrender-components';\nimport type { Dict, IPointLike } from '@visactor/vutils';\n\nexport type Point = {\n x: number;\n y: number;\n};\n\nexport type BarLinkDatum = {\n /**\n * 用于绘制的面积的坐标点\n */\n areaPoints: [IPointLike, IPointLike];\n /**\n * 用于绘制线的坐标点\n */\n linePoints: [IPointLike, IPointLike];\n\n /**\n * 唯一标识,如果不声明,则默认使用数据索引\n */\n id?: string;\n color?: string;\n /**\n * 点携带的图形数据\n */\n data: [Dict<any>, Dict<any>];\n};\n\nexport interface BarLinkAttrs extends IGroupGraphicAttribute {\n data: BarLinkDatum[];\n /**\n * 连接类型\n * 1. 'total' 累计值进行连接\n * 2. 'value' 本身值连接\n */\n linkType?: 'total' | 'value';\n /**\n * 是否填充\n */\n doFill?: boolean;\n linkStyle?: Pick<SegmentAttributes, 'startSymbol' | 'endSymbol' | 'lineStyle'>;\n areaStyle?: IAreaGraphicAttribute;\n /**\n * 用于配置各个线的样式,key 对应线的 id,主要用于连接线的编辑场景\n * 1. 删除:{ visible: false }\n * 2. 样式编辑:{ stroke: 'red' }\n */\n styleMap?: Record<string, ILineGraphicAttribute>;\n label?: {\n visible?: boolean;\n style?: ITextGraphicAttribute;\n formatMethod?: (value: number, percent: number, data: [any, any]) => (string | number) | (string | number)[];\n };\n}\n"]}
@@ -1,22 +0,0 @@
1
- import type { IElement } from '@visactor/vgrammar-core';
2
- import type { Dict } from '@visactor/vutils';
3
- import type { BarLinkAttrs, BarLinkDatum } from './type';
4
- import type { ISpec } from '@visactor/vchart';
5
- export declare function groupBarsByFields(elements: IElement[], groupFields: string[]): Dict<IElement[]>;
6
- export declare function getLinkData(currentElement: IElement, nextElement: IElement, config: {
7
- isHorizontal: boolean;
8
- isXAxisInverse: boolean;
9
- isYAxisInverse: boolean;
10
- linkType: string;
11
- doFill: boolean;
12
- regionStartX: number;
13
- regionStartY: number;
14
- }): BarLinkDatum;
15
- export declare function getBarLinkConfig(style?: Pick<BarLinkAttrs, 'areaStyle' | 'label' | 'linkStyle' | 'styleMap' | 'doFill' | 'linkType'>, extraStyle?: any): {
16
- type: string;
17
- componentType: string;
18
- zIndex: number;
19
- interactive: boolean;
20
- style: any;
21
- };
22
- export declare function appendBarLinkConfig(rawSpec: ISpec, barLinkSpec?: Pick<BarLinkAttrs, 'areaStyle' | 'label' | 'linkStyle' | 'styleMap' | 'doFill' | 'linkType'>): void;
@@ -1,178 +0,0 @@
1
- var __rest = this && this.__rest || function(s, e) {
2
- var t = {};
3
- for (var p in s) Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0 && (t[p] = s[p]);
4
- if (null != s && "function" == typeof Object.getOwnPropertySymbols) {
5
- var i = 0;
6
- 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]]);
7
- }
8
- return t;
9
- };
10
-
11
- import { STACK_FIELD_END } from "@visactor/vchart";
12
-
13
- import { array } from "@visactor/vutils";
14
-
15
- import { BAR_LINK } from "./constant";
16
-
17
- export function groupBarsByFields(elements, groupFields) {
18
- var _a;
19
- const result = {};
20
- for (let i = 0; i < elements.length; i++) {
21
- const item = elements[i], itemData = null === (_a = item.data) || void 0 === _a ? void 0 : _a[0], groupKey = groupFields.map((field => itemData[field])).join("-");
22
- result[groupKey] || (result[groupKey] = []), result[groupKey].push(item);
23
- }
24
- return result;
25
- }
26
-
27
- export function getLinkData(currentElement, nextElement, config) {
28
- const {isHorizontal: isHorizontal, isXAxisInverse: isXAxisInverse, isYAxisInverse: isYAxisInverse, linkType: linkType, doFill: doFill, regionStartX: regionStartX, regionStartY: regionStartY} = config, currentBarGraphic = currentElement.getGraphicItem(), nextBarGraphic = nextElement.getGraphicItem(), currentBarBounds = currentBarGraphic.AABBBounds, nextBarBounds = nextBarGraphic.AABBBounds;
29
- let linePoints, areaPoints;
30
- return isHorizontal ? (linePoints = [ {
31
- x: (currentBarBounds.x1 + currentBarBounds.x2) / 2 + regionStartX,
32
- y: currentBarBounds.y1 + regionStartY
33
- }, {
34
- x: (nextBarBounds.x1 + nextBarBounds.x2) / 2 + regionStartX,
35
- y: nextBarBounds.y2 + regionStartY
36
- } ], isXAxisInverse ? ("total" === linkType && (linePoints = [ {
37
- x: currentBarBounds.x1 + regionStartX,
38
- y: currentBarBounds.y1 + regionStartY
39
- }, {
40
- x: nextBarBounds.x1 + regionStartX,
41
- y: nextBarBounds.y2 + regionStartY
42
- } ]), doFill && (areaPoints = [ {
43
- x: currentBarBounds.x1 + regionStartX,
44
- x1: currentBarBounds.x2 + regionStartX,
45
- y: currentBarBounds.y1 + regionStartY
46
- }, {
47
- x: nextBarBounds.x1 + regionStartX,
48
- x1: nextBarBounds.x2 + regionStartX,
49
- y: nextBarBounds.y2 + regionStartY
50
- } ])) : ("total" === linkType && (linePoints = [ {
51
- x: currentBarBounds.x2 + regionStartX,
52
- y: currentBarBounds.y1 + regionStartY
53
- }, {
54
- x: nextBarBounds.x2 + regionStartX,
55
- y: nextBarBounds.y2 + regionStartY
56
- } ]), doFill && (areaPoints = [ {
57
- x: currentBarBounds.x2 + regionStartX,
58
- x1: currentBarBounds.x1 + regionStartX,
59
- y: currentBarBounds.y1 + regionStartY
60
- }, {
61
- x: nextBarBounds.x2 + regionStartX,
62
- x1: nextBarBounds.x1 + regionStartX,
63
- y: nextBarBounds.y2 + regionStartY
64
- } ]))) : (linePoints = [ {
65
- x: currentBarBounds.x2 + regionStartX,
66
- y: (currentBarBounds.y1 + currentBarBounds.y2) / 2 + regionStartY
67
- }, {
68
- x: nextBarBounds.x1 + regionStartX,
69
- y: (nextBarBounds.y1 + nextBarBounds.y2) / 2 + regionStartY
70
- } ], isYAxisInverse ? ("total" === linkType && (linePoints = [ {
71
- x: currentBarBounds.x2 + regionStartX,
72
- y: currentBarBounds.y2 + regionStartY
73
- }, {
74
- x: nextBarBounds.x1 + regionStartX,
75
- y: nextBarBounds.y2 + regionStartY
76
- } ]), doFill && (areaPoints = [ {
77
- x: currentBarBounds.x2 + regionStartX,
78
- y: currentBarBounds.y2 + regionStartY,
79
- y1: currentBarBounds.y1 + regionStartY
80
- }, {
81
- x: nextBarBounds.x1 + regionStartX,
82
- y: nextBarBounds.y2 + regionStartY,
83
- y1: nextBarBounds.y1 + regionStartY
84
- } ])) : ("total" === linkType && (linePoints = [ {
85
- x: currentBarBounds.x2 + regionStartX,
86
- y: currentBarBounds.y1 + regionStartY
87
- }, {
88
- x: nextBarBounds.x1 + regionStartX,
89
- y: nextBarBounds.y1 + regionStartY
90
- } ]), doFill && (areaPoints = [ {
91
- x: currentBarBounds.x2 + regionStartX,
92
- y: currentBarBounds.y1 + regionStartY,
93
- y1: currentBarBounds.y2 + regionStartY
94
- }, {
95
- x: nextBarBounds.x1 + regionStartX,
96
- y: nextBarBounds.y1 + regionStartY,
97
- y1: nextBarBounds.y2 + regionStartY
98
- } ]))), {
99
- areaPoints: areaPoints,
100
- linePoints: linePoints,
101
- data: [ currentElement.data[0], nextElement.data[0] ],
102
- color: currentBarGraphic.attribute.fill
103
- };
104
- }
105
-
106
- export function getBarLinkConfig(style = {}, extraStyle) {
107
- const {linkType: linkType = "total", doFill: doFill} = style, rest = __rest(style, [ "linkType", "doFill" ]);
108
- return {
109
- type: "component",
110
- componentType: BAR_LINK,
111
- zIndex: 500,
112
- interactive: !1,
113
- style: Object.assign(Object.assign({
114
- data: (datum, context) => {
115
- const {vchart: vchart} = context, regions = vchart.getChart().getAllRegions(), linkLineData = [];
116
- return regions.forEach((region => {
117
- const barSeriesArr = region.getSeries().filter((s => "bar" === s.type)), {x: regionStartX, y: regionStartY} = region.getLayoutStartPoint();
118
- if (barSeriesArr.length) {
119
- const groupFields = barSeriesArr[0].getGroupFields(), allBarElements = [];
120
- barSeriesArr.forEach((barSeries => {
121
- var _a, _b;
122
- (null === (_b = null === (_a = barSeries.getMarkInName("bar")) || void 0 === _a ? void 0 : _a.getProduct()) || void 0 === _b ? void 0 : _b.elements).forEach((barElement => {
123
- allBarElements.push(barElement);
124
- }));
125
- }));
126
- const groupData = groupBarsByFields(allBarElements, groupFields);
127
- Object.values(groupData).forEach((groupedValues => {
128
- groupedValues.sort(((prev, curr) => prev.data[0][STACK_FIELD_END] - curr.data[0][STACK_FIELD_END]));
129
- }));
130
- const barSeries = barSeriesArr[0], isHorizontal = "horizontal" === barSeries.direction, isYAxisInverse = barSeries.getYAxisHelper().isInverse(), isXAxisInverse = barSeries.getXAxisHelper().isInverse(), groupValues = Object.values(groupData);
131
- if (groupValues.length) if (isHorizontal) {
132
- groupValues[0][0].getGraphicItem().AABBBounds.y1 < groupValues[groupValues.length - 1][0].getGraphicItem().AABBBounds.y1 && groupValues.reverse();
133
- } else {
134
- groupValues[0][0].getGraphicItem().AABBBounds.x1 > groupValues[groupValues.length - 1][0].getGraphicItem().AABBBounds.x1 && groupValues.reverse();
135
- }
136
- for (let index = 0; index < groupValues.length - 1; index++) {
137
- const currentValues = groupValues[index], nextValues = groupValues[index + 1];
138
- if (currentValues.forEach(((element, elementIndex) => {
139
- var _a;
140
- const linkData = getLinkData(element, null !== (_a = nextValues[elementIndex]) && void 0 !== _a ? _a : nextValues[nextValues.length - 1], {
141
- isHorizontal: isHorizontal,
142
- isXAxisInverse: isXAxisInverse,
143
- isYAxisInverse: isYAxisInverse,
144
- doFill: doFill,
145
- linkType: linkType,
146
- regionStartX: regionStartX,
147
- regionStartY: regionStartY
148
- });
149
- linkLineData.push(linkData);
150
- })), currentValues.length < nextValues.length) {
151
- const lastElementOfCurrentElement = currentValues[currentValues.length - 1];
152
- for (let i = currentValues.length; i < nextValues.length; i++) {
153
- const linkData = getLinkData(lastElementOfCurrentElement, nextValues[i], {
154
- isHorizontal: isHorizontal,
155
- isXAxisInverse: isXAxisInverse,
156
- isYAxisInverse: isYAxisInverse,
157
- doFill: doFill,
158
- linkType: linkType,
159
- regionStartX: regionStartX,
160
- regionStartY: regionStartY
161
- });
162
- linkLineData.push(linkData);
163
- }
164
- }
165
- }
166
- }
167
- })), linkLineData;
168
- },
169
- linkType: linkType
170
- }, rest), extraStyle)
171
- };
172
- }
173
-
174
- export function appendBarLinkConfig(rawSpec, barLinkSpec) {
175
- rawSpec.customMark = array(rawSpec.customMark).filter((obj => obj.componentType !== BAR_LINK)),
176
- rawSpec.customMark.push(getBarLinkConfig(barLinkSpec));
177
- }
178
- //# sourceMappingURL=util.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["components/bar-link/util.ts"],"names":[],"mappings":"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","file":"util.js","sourcesContent":["import type { IElement } from '@visactor/vgrammar-core';\nimport type { Dict, IPointLike } from '@visactor/vutils';\nimport type { BarLinkAttrs, BarLinkDatum } from './type';\nimport type { ICartesianSeries, ISpec } from '@visactor/vchart';\nimport { STACK_FIELD_END } from '@visactor/vchart';\nimport { array } from '@visactor/vutils';\nimport { BAR_LINK } from './constant';\n\nexport function groupBarsByFields(elements: IElement[], groupFields: string[]) {\n const result: Dict<IElement[]> = {};\n for (let i = 0; i < elements.length; i++) {\n const item = elements[i];\n const itemData = item.data?.[0];\n const groupKey = groupFields.map(field => itemData[field]).join('-');\n if (!result[groupKey]) {\n result[groupKey] = [];\n }\n result[groupKey].push(item);\n }\n return result;\n}\n\nexport function getLinkData(\n currentElement: IElement,\n nextElement: IElement,\n config: {\n isHorizontal: boolean;\n isXAxisInverse: boolean;\n isYAxisInverse: boolean;\n linkType: string;\n doFill: boolean;\n regionStartX: number;\n regionStartY: number;\n }\n): BarLinkDatum {\n const { isHorizontal, isXAxisInverse, isYAxisInverse, linkType, doFill, regionStartX, regionStartY } = config;\n const currentBarGraphic = currentElement.getGraphicItem();\n const nextBarGraphic = nextElement.getGraphicItem();\n const currentBarBounds = currentBarGraphic.AABBBounds;\n const nextBarBounds = nextBarGraphic.AABBBounds;\n\n let linePoints: [IPointLike, IPointLike];\n let areaPoints: [IPointLike, IPointLike];\n\n if (isHorizontal) {\n linePoints = [\n {\n x: (currentBarBounds.x1 + currentBarBounds.x2) / 2 + regionStartX,\n y: currentBarBounds.y1 + regionStartY\n },\n {\n x: (nextBarBounds.x1 + nextBarBounds.x2) / 2 + regionStartX,\n y: nextBarBounds.y2 + regionStartY\n }\n ];\n if (isXAxisInverse) {\n if (linkType === 'total') {\n linePoints = [\n {\n x: currentBarBounds.x1 + regionStartX,\n y: currentBarBounds.y1 + regionStartY\n },\n {\n x: nextBarBounds.x1 + regionStartX,\n y: nextBarBounds.y2 + regionStartY\n }\n ];\n }\n\n if (doFill) {\n areaPoints = [\n {\n x: currentBarBounds.x1 + regionStartX,\n x1: currentBarBounds.x2 + regionStartX,\n y: currentBarBounds.y1 + regionStartY\n },\n {\n x: nextBarBounds.x1 + regionStartX,\n x1: nextBarBounds.x2 + regionStartX,\n y: nextBarBounds.y2 + regionStartY\n }\n ];\n }\n } else {\n if (linkType === 'total') {\n linePoints = [\n {\n x: currentBarBounds.x2 + regionStartX,\n y: currentBarBounds.y1 + regionStartY\n },\n {\n x: nextBarBounds.x2 + regionStartX,\n y: nextBarBounds.y2 + regionStartY\n }\n ];\n }\n\n if (doFill) {\n areaPoints = [\n {\n x: currentBarBounds.x2 + regionStartX,\n x1: currentBarBounds.x1 + regionStartX,\n y: currentBarBounds.y1 + regionStartY\n },\n {\n x: nextBarBounds.x2 + regionStartX,\n x1: nextBarBounds.x1 + regionStartX,\n y: nextBarBounds.y2 + regionStartY\n }\n ];\n }\n }\n } else {\n linePoints = [\n {\n x: currentBarBounds.x2 + regionStartX,\n y: (currentBarBounds.y1 + currentBarBounds.y2) / 2 + regionStartY\n },\n {\n x: nextBarBounds.x1 + regionStartX,\n y: (nextBarBounds.y1 + nextBarBounds.y2) / 2 + regionStartY\n }\n ];\n\n if (isYAxisInverse) {\n if (linkType === 'total') {\n linePoints = [\n {\n x: currentBarBounds.x2 + regionStartX,\n y: currentBarBounds.y2 + regionStartY\n },\n {\n x: nextBarBounds.x1 + regionStartX,\n y: nextBarBounds.y2 + regionStartY\n }\n ];\n }\n if (doFill) {\n areaPoints = [\n {\n x: currentBarBounds.x2 + regionStartX,\n y: currentBarBounds.y2 + regionStartY,\n y1: currentBarBounds.y1 + regionStartY\n },\n {\n x: nextBarBounds.x1 + regionStartX,\n y: nextBarBounds.y2 + regionStartY,\n y1: nextBarBounds.y1 + regionStartY\n }\n ];\n }\n } else {\n if (linkType === 'total') {\n linePoints = [\n {\n x: currentBarBounds.x2 + regionStartX,\n y: currentBarBounds.y1 + regionStartY\n },\n {\n x: nextBarBounds.x1 + regionStartX,\n y: nextBarBounds.y1 + regionStartY\n }\n ];\n }\n if (doFill) {\n areaPoints = [\n {\n x: currentBarBounds.x2 + regionStartX,\n y: currentBarBounds.y1 + regionStartY,\n y1: currentBarBounds.y2 + regionStartY\n },\n {\n x: nextBarBounds.x1 + regionStartX,\n y: nextBarBounds.y1 + regionStartY,\n y1: nextBarBounds.y2 + regionStartY\n }\n ];\n }\n }\n }\n\n return {\n // points,\n areaPoints,\n linePoints,\n data: [currentElement.data[0], nextElement.data[0]],\n color: currentBarGraphic.attribute.fill as string\n };\n}\n\nexport function getBarLinkConfig(\n style: Pick<BarLinkAttrs, 'areaStyle' | 'label' | 'linkStyle' | 'styleMap' | 'doFill' | 'linkType'> = {},\n extraStyle?: any\n) {\n const { linkType = 'total', doFill, ...rest } = style;\n return {\n type: 'component',\n componentType: BAR_LINK,\n zIndex: 500, // 需要处于 region 上层\n interactive: false,\n style: {\n data: (datum: any, context: any) => {\n const { vchart } = context;\n const regions = vchart.getChart().getAllRegions();\n const linkLineData: BarLinkDatum[] = [];\n regions.forEach((region: any) => {\n // 获取所有 bar 系列\n const barSeriesArr = region\n .getSeries()\n .filter((s: ICartesianSeries) => s.type === 'bar') as ICartesianSeries[];\n const { x: regionStartX, y: regionStartY } = region.getLayoutStartPoint();\n if (barSeriesArr.length) {\n const groupFields = barSeriesArr[0].getGroupFields();\n const allBarElements: IElement[] = [];\n barSeriesArr.forEach(barSeries => {\n const barGraphicElements = barSeries.getMarkInName('bar')?.getProduct()?.elements;\n barGraphicElements.forEach(barElement => {\n allBarElements.push(barElement);\n });\n });\n // 按照 xField/yField 进行分组\n const groupData = groupBarsByFields(allBarElements, groupFields);\n\n // 对同组内的图形进行排序\n Object.values(groupData).forEach((groupedValues: IElement[]) => {\n groupedValues.sort((prev: IElement, curr: IElement) => {\n return prev.data[0][STACK_FIELD_END] - curr.data[0][STACK_FIELD_END];\n });\n });\n\n const barSeries = barSeriesArr[0];\n const isHorizontal = barSeries.direction === 'horizontal';\n const isYAxisInverse = barSeries.getYAxisHelper().isInverse();\n const isXAxisInverse = barSeries.getXAxisHelper().isInverse();\n\n const groupValues: IElement[][] = Object.values(groupData);\n\n // 根据每组图形:\n // 1. 水平,每组图形的 y1 进行由小到大排序,保证图形顺序\n // 2. 垂直,每组图形的 x1 进行由小到大排序,保证图形顺序\n if (groupValues.length) {\n if (isHorizontal) {\n const firstElementPosY = groupValues[0][0].getGraphicItem().AABBBounds.y1;\n const lastElementPosY = groupValues[groupValues.length - 1][0].getGraphicItem().AABBBounds.y1;\n if (firstElementPosY < lastElementPosY) {\n groupValues.reverse();\n }\n } else {\n const firstElementPosX = groupValues[0][0].getGraphicItem().AABBBounds.x1;\n const lastElementPosX = groupValues[groupValues.length - 1][0].getGraphicItem().AABBBounds.x1;\n if (firstElementPosX > lastElementPosX) {\n groupValues.reverse();\n }\n }\n }\n\n for (let index = 0; index < groupValues.length - 1; index++) {\n const currentValues: IElement[] = groupValues[index];\n const nextValues: IElement[] = groupValues[index + 1];\n\n currentValues.forEach((element, elementIndex) => {\n const nextElement = nextValues[elementIndex] ?? nextValues[nextValues.length - 1];\n\n const linkData = getLinkData(element, nextElement, {\n isHorizontal,\n isXAxisInverse,\n isYAxisInverse,\n doFill,\n linkType,\n regionStartX,\n regionStartY\n });\n\n linkLineData.push(linkData);\n });\n\n if (currentValues.length < nextValues.length) {\n // 如果当前组的个数小于下一个组的个数,用当前组的最后一个元素去链接下一组剩余的图形\n // 使用当前组的最后一个元素去链接下一组剩余的图形\n const lastElementOfCurrentElement = currentValues[currentValues.length - 1];\n for (let i = currentValues.length; i < nextValues.length; i++) {\n const nextElement = nextValues[i];\n\n const linkData = getLinkData(lastElementOfCurrentElement, nextElement, {\n isHorizontal,\n isXAxisInverse,\n isYAxisInverse,\n doFill,\n linkType,\n regionStartX,\n regionStartY\n });\n\n linkLineData.push(linkData);\n }\n }\n }\n }\n });\n\n return linkLineData;\n },\n linkType,\n ...rest,\n ...extraStyle\n }\n };\n}\n\nexport function appendBarLinkConfig(\n rawSpec: ISpec,\n barLinkSpec?: Pick<BarLinkAttrs, 'areaStyle' | 'label' | 'linkStyle' | 'styleMap' | 'doFill' | 'linkType'>\n) {\n // 判断 editorSpec 中是否有 barLink,有则添加 customMark\n (rawSpec as any).customMark = array((rawSpec as any).customMark).filter((obj: any) => obj.componentType !== BAR_LINK);\n (rawSpec as any).customMark.push(getBarLinkConfig(barLinkSpec));\n}\n"]}