@visactor/vchart-extension 1.13.22 → 1.13.23-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (369) hide show
  1. package/build/index.js +14540 -0
  2. package/build/index.min.js +15 -0
  3. package/cjs/charts/compare-sankey/compare-sankey-sub-data.d.ts +21 -0
  4. package/cjs/charts/compare-sankey/compare-sankey-sub-data.js +118 -0
  5. package/cjs/charts/compare-sankey/compare-sankey-sub-data.js.map +1 -0
  6. package/cjs/charts/compare-sankey/compare-sankey-sub-nodes.d.ts +2 -0
  7. package/cjs/charts/compare-sankey/compare-sankey-sub-nodes.js +21 -0
  8. package/cjs/charts/compare-sankey/compare-sankey-sub-nodes.js.map +1 -0
  9. package/cjs/charts/compare-sankey/compare-sankey-transformer.d.ts +7 -0
  10. package/cjs/charts/compare-sankey/compare-sankey-transformer.js +25 -0
  11. package/cjs/charts/compare-sankey/compare-sankey-transformer.js.map +1 -0
  12. package/cjs/charts/compare-sankey/compare-sankey.d.ts +46 -0
  13. package/cjs/charts/compare-sankey/compare-sankey.js +202 -0
  14. package/cjs/charts/compare-sankey/compare-sankey.js.map +1 -0
  15. package/cjs/charts/compare-sankey/index.d.ts +2 -0
  16. package/cjs/charts/compare-sankey/index.js +21 -0
  17. package/cjs/charts/compare-sankey/index.js.map +1 -0
  18. package/cjs/charts/compare-sankey/interface.d.ts +24 -0
  19. package/cjs/charts/compare-sankey/interface.js +6 -0
  20. package/cjs/charts/compare-sankey/interface.js.map +1 -0
  21. package/cjs/charts/compare-sankey/utils.d.ts +9 -0
  22. package/cjs/charts/compare-sankey/utils.js +48 -0
  23. package/cjs/charts/compare-sankey/utils.js.map +1 -0
  24. package/cjs/charts/compare-sankey-diff/compare-sankey-diff-data.d.ts +8 -0
  25. package/cjs/charts/compare-sankey-diff/compare-sankey-diff-data.js +85 -0
  26. package/cjs/charts/compare-sankey-diff/compare-sankey-diff-data.js.map +1 -0
  27. package/cjs/charts/compare-sankey-diff/compare-sankey-diff-transformer.d.ts +7 -0
  28. package/cjs/charts/compare-sankey-diff/compare-sankey-diff-transformer.js +25 -0
  29. package/cjs/charts/compare-sankey-diff/compare-sankey-diff-transformer.js.map +1 -0
  30. package/cjs/charts/compare-sankey-diff/compare-sankey-diff.d.ts +34 -0
  31. package/cjs/charts/compare-sankey-diff/compare-sankey-diff.js +98 -0
  32. package/cjs/charts/compare-sankey-diff/compare-sankey-diff.js.map +1 -0
  33. package/cjs/charts/compare-sankey-diff/index.d.ts +2 -0
  34. package/cjs/charts/compare-sankey-diff/index.js +21 -0
  35. package/cjs/charts/compare-sankey-diff/index.js.map +1 -0
  36. package/cjs/charts/compare-sankey-diff/interface.d.ts +24 -0
  37. package/cjs/charts/compare-sankey-diff/interface.js +5 -0
  38. package/cjs/charts/compare-sankey-diff/interface.js.map +1 -0
  39. package/cjs/charts/conversion-funnel/arrow-data-transform.d.ts +24 -0
  40. package/cjs/charts/conversion-funnel/arrow-data-transform.js +99 -0
  41. package/cjs/charts/conversion-funnel/arrow-data-transform.js.map +1 -0
  42. package/cjs/charts/conversion-funnel/conversion-funnel-transformer.d.ts +7 -0
  43. package/cjs/charts/conversion-funnel/conversion-funnel-transformer.js +196 -0
  44. package/cjs/charts/conversion-funnel/conversion-funnel-transformer.js.map +1 -0
  45. package/cjs/charts/conversion-funnel/conversion-funnel.d.ts +40 -0
  46. package/cjs/charts/conversion-funnel/conversion-funnel.js +78 -0
  47. package/cjs/charts/conversion-funnel/conversion-funnel.js.map +1 -0
  48. package/cjs/charts/conversion-funnel/index.d.ts +2 -0
  49. package/cjs/charts/conversion-funnel/index.js +21 -0
  50. package/cjs/charts/conversion-funnel/index.js.map +1 -0
  51. package/cjs/charts/conversion-funnel/interface.d.ts +35 -0
  52. package/cjs/charts/conversion-funnel/interface.js +6 -0
  53. package/cjs/charts/conversion-funnel/interface.js.map +1 -0
  54. package/cjs/charts/conversion-funnel/util.d.ts +3 -0
  55. package/cjs/charts/conversion-funnel/util.js +17 -0
  56. package/cjs/charts/conversion-funnel/util.js.map +1 -0
  57. package/cjs/charts/ranking-bar/interface.d.ts +45 -0
  58. package/cjs/charts/ranking-bar/interface.js +6 -0
  59. package/cjs/charts/ranking-bar/interface.js.map +1 -0
  60. package/cjs/charts/ranking-bar/ranking-bar-transformer.d.ts +10 -0
  61. package/cjs/charts/ranking-bar/ranking-bar-transformer.js +291 -0
  62. package/cjs/charts/ranking-bar/ranking-bar-transformer.js.map +1 -0
  63. package/cjs/charts/ranking-bar/ranking-bar.d.ts +16 -0
  64. package/cjs/charts/ranking-bar/ranking-bar.js +34 -0
  65. package/cjs/charts/ranking-bar/ranking-bar.js.map +1 -0
  66. package/cjs/charts/ranking-list/constant.d.ts +2 -0
  67. package/cjs/charts/ranking-list/constant.js +75 -0
  68. package/cjs/charts/ranking-list/constant.js.map +1 -0
  69. package/cjs/charts/ranking-list/interface.d.ts +74 -0
  70. package/cjs/charts/ranking-list/interface.js +6 -0
  71. package/cjs/charts/ranking-list/interface.js.map +1 -0
  72. package/cjs/charts/ranking-list/ranking-list-transformer.d.ts +459 -0
  73. package/cjs/charts/ranking-list/ranking-list-transformer.js +383 -0
  74. package/cjs/charts/ranking-list/ranking-list-transformer.js.map +1 -0
  75. package/cjs/charts/ranking-list/ranking-list.d.ts +16 -0
  76. package/cjs/charts/ranking-list/ranking-list.js +34 -0
  77. package/cjs/charts/ranking-list/ranking-list.js.map +1 -0
  78. package/cjs/charts/ranking-list/utils.d.ts +7 -0
  79. package/cjs/charts/ranking-list/utils.js +51 -0
  80. package/cjs/charts/ranking-list/utils.js.map +1 -0
  81. package/cjs/charts/sequence-scatter-kde/constant.d.ts +3 -0
  82. package/cjs/charts/sequence-scatter-kde/constant.js +7 -0
  83. package/cjs/charts/sequence-scatter-kde/constant.js.map +1 -0
  84. package/cjs/charts/sequence-scatter-kde/interface.d.ts +29 -0
  85. package/cjs/charts/sequence-scatter-kde/interface.js +5 -0
  86. package/cjs/charts/sequence-scatter-kde/interface.js.map +1 -0
  87. package/cjs/charts/sequence-scatter-kde/sequence-scatter-kde-transformer.d.ts +6 -0
  88. package/cjs/charts/sequence-scatter-kde/sequence-scatter-kde-transformer.js +142 -0
  89. package/cjs/charts/sequence-scatter-kde/sequence-scatter-kde-transformer.js.map +1 -0
  90. package/cjs/charts/sequence-scatter-kde/sequence-scatter-kde.d.ts +16 -0
  91. package/cjs/charts/sequence-scatter-kde/sequence-scatter-kde.js +34 -0
  92. package/cjs/charts/sequence-scatter-kde/sequence-scatter-kde.js.map +1 -0
  93. package/cjs/charts/sequence-scatter-kde/utils.d.ts +9 -0
  94. package/cjs/charts/sequence-scatter-kde/utils.js +42 -0
  95. package/cjs/charts/sequence-scatter-kde/utils.js.map +1 -0
  96. package/cjs/charts/sequence-scatter-link/interface.d.ts +59 -0
  97. package/cjs/charts/sequence-scatter-link/interface.js +6 -0
  98. package/cjs/charts/sequence-scatter-link/interface.js.map +1 -0
  99. package/cjs/charts/sequence-scatter-link/sequence-scatter-link-transformer.d.ts +6 -0
  100. package/cjs/charts/sequence-scatter-link/sequence-scatter-link-transformer.js +328 -0
  101. package/cjs/charts/sequence-scatter-link/sequence-scatter-link-transformer.js.map +1 -0
  102. package/cjs/charts/sequence-scatter-link/sequence-scatter-link.d.ts +16 -0
  103. package/cjs/charts/sequence-scatter-link/sequence-scatter-link.js +34 -0
  104. package/cjs/charts/sequence-scatter-link/sequence-scatter-link.js.map +1 -0
  105. package/cjs/charts/sequence-scatter-link/utils.d.ts +9 -0
  106. package/cjs/charts/sequence-scatter-link/utils.js +108 -0
  107. package/cjs/charts/sequence-scatter-link/utils.js.map +1 -0
  108. package/cjs/charts/sequence-scatter-pixel/constant.d.ts +3 -0
  109. package/cjs/charts/sequence-scatter-pixel/constant.js +7 -0
  110. package/cjs/charts/sequence-scatter-pixel/constant.js.map +1 -0
  111. package/cjs/charts/sequence-scatter-pixel/interface.d.ts +29 -0
  112. package/cjs/charts/sequence-scatter-pixel/interface.js +6 -0
  113. package/cjs/charts/sequence-scatter-pixel/interface.js.map +1 -0
  114. package/cjs/charts/sequence-scatter-pixel/sequence-scatter-pixel-transformer.d.ts +4 -0
  115. package/cjs/charts/sequence-scatter-pixel/sequence-scatter-pixel-transformer.js +68 -0
  116. package/cjs/charts/sequence-scatter-pixel/sequence-scatter-pixel-transformer.js.map +1 -0
  117. package/cjs/charts/sequence-scatter-pixel/sequence-scatter-pixel.d.ts +16 -0
  118. package/cjs/charts/sequence-scatter-pixel/sequence-scatter-pixel.js +34 -0
  119. package/cjs/charts/sequence-scatter-pixel/sequence-scatter-pixel.js.map +1 -0
  120. package/cjs/charts/sequence-scatter-pixel/utils.d.ts +3 -0
  121. package/cjs/charts/sequence-scatter-pixel/utils.js +54 -0
  122. package/cjs/charts/sequence-scatter-pixel/utils.js.map +1 -0
  123. package/cjs/components/bar-link/bar-link.d.ts +7 -0
  124. package/cjs/components/bar-link/bar-link.js +87 -0
  125. package/cjs/components/bar-link/bar-link.js.map +1 -0
  126. package/cjs/components/bar-link/constant.d.ts +1 -0
  127. package/cjs/components/bar-link/constant.js +6 -0
  128. package/cjs/components/bar-link/constant.js.map +1 -0
  129. package/cjs/components/bar-link/index.d.ts +4 -0
  130. package/cjs/components/bar-link/index.js +49 -0
  131. package/cjs/components/bar-link/index.js.map +1 -0
  132. package/cjs/components/bar-link/type.d.ts +27 -0
  133. package/cjs/components/bar-link/type.js +6 -0
  134. package/cjs/components/bar-link/type.js.map +1 -0
  135. package/cjs/components/bar-link/util.d.ts +22 -0
  136. package/cjs/components/bar-link/util.js +183 -0
  137. package/cjs/components/bar-link/util.js.map +1 -0
  138. package/cjs/components/series-break/constant.d.ts +1 -0
  139. package/cjs/components/series-break/constant.js +6 -0
  140. package/cjs/components/series-break/constant.js.map +1 -0
  141. package/cjs/components/series-break/index.d.ts +4 -0
  142. package/cjs/components/series-break/index.js +49 -0
  143. package/cjs/components/series-break/index.js.map +1 -0
  144. package/cjs/components/series-break/series-break.d.ts +7 -0
  145. package/cjs/components/series-break/series-break.js +118 -0
  146. package/cjs/components/series-break/series-break.js.map +1 -0
  147. package/cjs/components/series-break/type.d.ts +14 -0
  148. package/cjs/components/series-break/type.js +6 -0
  149. package/cjs/components/series-break/type.js.map +1 -0
  150. package/cjs/components/series-break/util.d.ts +13 -0
  151. package/cjs/components/series-break/util.js +248 -0
  152. package/cjs/components/series-break/util.js.map +1 -0
  153. package/cjs/components/series-label/constant.d.ts +1 -0
  154. package/cjs/components/series-label/constant.js +5 -0
  155. package/cjs/components/series-label/constant.js.map +1 -0
  156. package/cjs/components/series-label/index.d.ts +3 -0
  157. package/cjs/components/series-label/index.js +49 -0
  158. package/cjs/components/series-label/index.js.map +1 -0
  159. package/cjs/components/series-label/series-label.d.ts +7 -0
  160. package/cjs/components/series-label/series-label.js +114 -0
  161. package/cjs/components/series-label/series-label.js.map +1 -0
  162. package/cjs/components/series-label/type.d.ts +41 -0
  163. package/cjs/components/series-label/type.js +6 -0
  164. package/cjs/components/series-label/type.js.map +1 -0
  165. package/cjs/components/series-label/util.d.ts +33 -0
  166. package/cjs/components/series-label/util.js +152 -0
  167. package/cjs/components/series-label/util.js.map +1 -0
  168. package/cjs/index.d.ts +11 -0
  169. package/cjs/index.js +26 -0
  170. package/cjs/index.js.map +1 -0
  171. package/cjs/type/index.d.ts +1 -0
  172. package/cjs/type/index.js +21 -0
  173. package/cjs/type/index.js.map +1 -0
  174. package/cjs/type/type.d.ts +8 -0
  175. package/cjs/type/type.js +6 -0
  176. package/cjs/type/type.js.map +1 -0
  177. package/cjs/utils/element.d.ts +7 -0
  178. package/cjs/utils/element.js +21 -0
  179. package/cjs/utils/element.js.map +1 -0
  180. package/cjs/utils/mark.d.ts +2 -0
  181. package/cjs/utils/mark.js +14 -0
  182. package/cjs/utils/mark.js.map +1 -0
  183. package/cjs/utils/math.d.ts +1 -0
  184. package/cjs/utils/math.js +10 -0
  185. package/cjs/utils/math.js.map +1 -0
  186. package/esm/charts/compare-sankey/compare-sankey-sub-data.d.ts +21 -0
  187. package/esm/charts/compare-sankey/compare-sankey-sub-data.js +106 -0
  188. package/esm/charts/compare-sankey/compare-sankey-sub-data.js.map +1 -0
  189. package/esm/charts/compare-sankey/compare-sankey-sub-nodes.d.ts +2 -0
  190. package/esm/charts/compare-sankey/compare-sankey-sub-nodes.js +13 -0
  191. package/esm/charts/compare-sankey/compare-sankey-sub-nodes.js.map +1 -0
  192. package/esm/charts/compare-sankey/compare-sankey-transformer.d.ts +7 -0
  193. package/esm/charts/compare-sankey/compare-sankey-transformer.js +17 -0
  194. package/esm/charts/compare-sankey/compare-sankey-transformer.js.map +1 -0
  195. package/esm/charts/compare-sankey/compare-sankey.d.ts +46 -0
  196. package/esm/charts/compare-sankey/compare-sankey.js +205 -0
  197. package/esm/charts/compare-sankey/compare-sankey.js.map +1 -0
  198. package/esm/charts/compare-sankey/index.d.ts +2 -0
  199. package/esm/charts/compare-sankey/index.js +4 -0
  200. package/esm/charts/compare-sankey/index.js.map +1 -0
  201. package/esm/charts/compare-sankey/interface.d.ts +24 -0
  202. package/esm/charts/compare-sankey/interface.js +2 -0
  203. package/esm/charts/compare-sankey/interface.js.map +1 -0
  204. package/esm/charts/compare-sankey/utils.d.ts +9 -0
  205. package/esm/charts/compare-sankey/utils.js +39 -0
  206. package/esm/charts/compare-sankey/utils.js.map +1 -0
  207. package/esm/charts/compare-sankey-diff/compare-sankey-diff-data.d.ts +8 -0
  208. package/esm/charts/compare-sankey-diff/compare-sankey-diff-data.js +77 -0
  209. package/esm/charts/compare-sankey-diff/compare-sankey-diff-data.js.map +1 -0
  210. package/esm/charts/compare-sankey-diff/compare-sankey-diff-transformer.d.ts +7 -0
  211. package/esm/charts/compare-sankey-diff/compare-sankey-diff-transformer.js +17 -0
  212. package/esm/charts/compare-sankey-diff/compare-sankey-diff-transformer.js.map +1 -0
  213. package/esm/charts/compare-sankey-diff/compare-sankey-diff.d.ts +34 -0
  214. package/esm/charts/compare-sankey-diff/compare-sankey-diff.js +97 -0
  215. package/esm/charts/compare-sankey-diff/compare-sankey-diff.js.map +1 -0
  216. package/esm/charts/compare-sankey-diff/index.d.ts +2 -0
  217. package/esm/charts/compare-sankey-diff/index.js +4 -0
  218. package/esm/charts/compare-sankey-diff/index.js.map +1 -0
  219. package/esm/charts/compare-sankey-diff/interface.d.ts +24 -0
  220. package/esm/charts/compare-sankey-diff/interface.js +1 -0
  221. package/esm/charts/compare-sankey-diff/interface.js.map +1 -0
  222. package/esm/charts/conversion-funnel/arrow-data-transform.d.ts +24 -0
  223. package/esm/charts/conversion-funnel/arrow-data-transform.js +94 -0
  224. package/esm/charts/conversion-funnel/arrow-data-transform.js.map +1 -0
  225. package/esm/charts/conversion-funnel/conversion-funnel-transformer.d.ts +7 -0
  226. package/esm/charts/conversion-funnel/conversion-funnel-transformer.js +192 -0
  227. package/esm/charts/conversion-funnel/conversion-funnel-transformer.js.map +1 -0
  228. package/esm/charts/conversion-funnel/conversion-funnel.d.ts +40 -0
  229. package/esm/charts/conversion-funnel/conversion-funnel.js +81 -0
  230. package/esm/charts/conversion-funnel/conversion-funnel.js.map +1 -0
  231. package/esm/charts/conversion-funnel/index.d.ts +2 -0
  232. package/esm/charts/conversion-funnel/index.js +4 -0
  233. package/esm/charts/conversion-funnel/index.js.map +1 -0
  234. package/esm/charts/conversion-funnel/interface.d.ts +35 -0
  235. package/esm/charts/conversion-funnel/interface.js +2 -0
  236. package/esm/charts/conversion-funnel/interface.js.map +1 -0
  237. package/esm/charts/conversion-funnel/util.d.ts +3 -0
  238. package/esm/charts/conversion-funnel/util.js +10 -0
  239. package/esm/charts/conversion-funnel/util.js.map +1 -0
  240. package/esm/charts/ranking-bar/interface.d.ts +45 -0
  241. package/esm/charts/ranking-bar/interface.js +2 -0
  242. package/esm/charts/ranking-bar/interface.js.map +1 -0
  243. package/esm/charts/ranking-bar/ranking-bar-transformer.d.ts +10 -0
  244. package/esm/charts/ranking-bar/ranking-bar-transformer.js +285 -0
  245. package/esm/charts/ranking-bar/ranking-bar-transformer.js.map +1 -0
  246. package/esm/charts/ranking-bar/ranking-bar.d.ts +16 -0
  247. package/esm/charts/ranking-bar/ranking-bar.js +27 -0
  248. package/esm/charts/ranking-bar/ranking-bar.js.map +1 -0
  249. package/esm/charts/ranking-list/constant.d.ts +2 -0
  250. package/esm/charts/ranking-list/constant.js +69 -0
  251. package/esm/charts/ranking-list/constant.js.map +1 -0
  252. package/esm/charts/ranking-list/interface.d.ts +74 -0
  253. package/esm/charts/ranking-list/interface.js +2 -0
  254. package/esm/charts/ranking-list/interface.js.map +1 -0
  255. package/esm/charts/ranking-list/ranking-list-transformer.d.ts +459 -0
  256. package/esm/charts/ranking-list/ranking-list-transformer.js +383 -0
  257. package/esm/charts/ranking-list/ranking-list-transformer.js.map +1 -0
  258. package/esm/charts/ranking-list/ranking-list.d.ts +16 -0
  259. package/esm/charts/ranking-list/ranking-list.js +27 -0
  260. package/esm/charts/ranking-list/ranking-list.js.map +1 -0
  261. package/esm/charts/ranking-list/utils.d.ts +7 -0
  262. package/esm/charts/ranking-list/utils.js +41 -0
  263. package/esm/charts/ranking-list/utils.js.map +1 -0
  264. package/esm/charts/sequence-scatter-kde/constant.d.ts +3 -0
  265. package/esm/charts/sequence-scatter-kde/constant.js +6 -0
  266. package/esm/charts/sequence-scatter-kde/constant.js.map +1 -0
  267. package/esm/charts/sequence-scatter-kde/interface.d.ts +29 -0
  268. package/esm/charts/sequence-scatter-kde/interface.js +1 -0
  269. package/esm/charts/sequence-scatter-kde/interface.js.map +1 -0
  270. package/esm/charts/sequence-scatter-kde/sequence-scatter-kde-transformer.d.ts +6 -0
  271. package/esm/charts/sequence-scatter-kde/sequence-scatter-kde-transformer.js +137 -0
  272. package/esm/charts/sequence-scatter-kde/sequence-scatter-kde-transformer.js.map +1 -0
  273. package/esm/charts/sequence-scatter-kde/sequence-scatter-kde.d.ts +16 -0
  274. package/esm/charts/sequence-scatter-kde/sequence-scatter-kde.js +28 -0
  275. package/esm/charts/sequence-scatter-kde/sequence-scatter-kde.js.map +1 -0
  276. package/esm/charts/sequence-scatter-kde/utils.d.ts +9 -0
  277. package/esm/charts/sequence-scatter-kde/utils.js +34 -0
  278. package/esm/charts/sequence-scatter-kde/utils.js.map +1 -0
  279. package/esm/charts/sequence-scatter-link/interface.d.ts +59 -0
  280. package/esm/charts/sequence-scatter-link/interface.js +2 -0
  281. package/esm/charts/sequence-scatter-link/interface.js.map +1 -0
  282. package/esm/charts/sequence-scatter-link/sequence-scatter-link-transformer.d.ts +6 -0
  283. package/esm/charts/sequence-scatter-link/sequence-scatter-link-transformer.js +321 -0
  284. package/esm/charts/sequence-scatter-link/sequence-scatter-link-transformer.js.map +1 -0
  285. package/esm/charts/sequence-scatter-link/sequence-scatter-link.d.ts +16 -0
  286. package/esm/charts/sequence-scatter-link/sequence-scatter-link.js +28 -0
  287. package/esm/charts/sequence-scatter-link/sequence-scatter-link.js.map +1 -0
  288. package/esm/charts/sequence-scatter-link/utils.d.ts +9 -0
  289. package/esm/charts/sequence-scatter-link/utils.js +100 -0
  290. package/esm/charts/sequence-scatter-link/utils.js.map +1 -0
  291. package/esm/charts/sequence-scatter-pixel/constant.d.ts +3 -0
  292. package/esm/charts/sequence-scatter-pixel/constant.js +6 -0
  293. package/esm/charts/sequence-scatter-pixel/constant.js.map +1 -0
  294. package/esm/charts/sequence-scatter-pixel/interface.d.ts +29 -0
  295. package/esm/charts/sequence-scatter-pixel/interface.js +2 -0
  296. package/esm/charts/sequence-scatter-pixel/interface.js.map +1 -0
  297. package/esm/charts/sequence-scatter-pixel/sequence-scatter-pixel-transformer.d.ts +4 -0
  298. package/esm/charts/sequence-scatter-pixel/sequence-scatter-pixel-transformer.js +64 -0
  299. package/esm/charts/sequence-scatter-pixel/sequence-scatter-pixel-transformer.js.map +1 -0
  300. package/esm/charts/sequence-scatter-pixel/sequence-scatter-pixel.d.ts +16 -0
  301. package/esm/charts/sequence-scatter-pixel/sequence-scatter-pixel.js +28 -0
  302. package/esm/charts/sequence-scatter-pixel/sequence-scatter-pixel.js.map +1 -0
  303. package/esm/charts/sequence-scatter-pixel/utils.d.ts +3 -0
  304. package/esm/charts/sequence-scatter-pixel/utils.js +46 -0
  305. package/esm/charts/sequence-scatter-pixel/utils.js.map +1 -0
  306. package/esm/components/bar-link/bar-link.d.ts +7 -0
  307. package/esm/components/bar-link/bar-link.js +85 -0
  308. package/esm/components/bar-link/bar-link.js.map +1 -0
  309. package/esm/components/bar-link/constant.d.ts +1 -0
  310. package/esm/components/bar-link/constant.js +2 -0
  311. package/esm/components/bar-link/constant.js.map +1 -0
  312. package/esm/components/bar-link/index.d.ts +4 -0
  313. package/esm/components/bar-link/index.js +8 -0
  314. package/esm/components/bar-link/index.js.map +1 -0
  315. package/esm/components/bar-link/type.d.ts +27 -0
  316. package/esm/components/bar-link/type.js +2 -0
  317. package/esm/components/bar-link/type.js.map +1 -0
  318. package/esm/components/bar-link/util.d.ts +22 -0
  319. package/esm/components/bar-link/util.js +178 -0
  320. package/esm/components/bar-link/util.js.map +1 -0
  321. package/esm/components/series-break/constant.d.ts +1 -0
  322. package/esm/components/series-break/constant.js +2 -0
  323. package/esm/components/series-break/constant.js.map +1 -0
  324. package/esm/components/series-break/index.d.ts +4 -0
  325. package/esm/components/series-break/index.js +8 -0
  326. package/esm/components/series-break/index.js.map +1 -0
  327. package/esm/components/series-break/series-break.d.ts +7 -0
  328. package/esm/components/series-break/series-break.js +115 -0
  329. package/esm/components/series-break/series-break.js.map +1 -0
  330. package/esm/components/series-break/type.d.ts +14 -0
  331. package/esm/components/series-break/type.js +2 -0
  332. package/esm/components/series-break/type.js.map +1 -0
  333. package/esm/components/series-break/util.d.ts +13 -0
  334. package/esm/components/series-break/util.js +244 -0
  335. package/esm/components/series-break/util.js.map +1 -0
  336. package/esm/components/series-label/constant.d.ts +1 -0
  337. package/esm/components/series-label/constant.js +1 -0
  338. package/esm/components/series-label/constant.js.map +1 -0
  339. package/esm/components/series-label/index.d.ts +3 -0
  340. package/esm/components/series-label/index.js +6 -0
  341. package/esm/components/series-label/index.js.map +1 -0
  342. package/esm/components/series-label/series-label.d.ts +7 -0
  343. package/esm/components/series-label/series-label.js +110 -0
  344. package/esm/components/series-label/series-label.js.map +1 -0
  345. package/esm/components/series-label/type.d.ts +41 -0
  346. package/esm/components/series-label/type.js +2 -0
  347. package/esm/components/series-label/type.js.map +1 -0
  348. package/esm/components/series-label/util.d.ts +33 -0
  349. package/esm/components/series-label/util.js +144 -0
  350. package/esm/components/series-label/util.js.map +1 -0
  351. package/esm/index.d.ts +11 -0
  352. package/esm/index.js +21 -0
  353. package/esm/index.js.map +1 -0
  354. package/esm/type/index.d.ts +1 -0
  355. package/esm/type/index.js +2 -0
  356. package/esm/type/index.js.map +1 -0
  357. package/esm/type/type.d.ts +8 -0
  358. package/esm/type/type.js +2 -0
  359. package/esm/type/type.js.map +1 -0
  360. package/esm/utils/element.d.ts +7 -0
  361. package/esm/utils/element.js +15 -0
  362. package/esm/utils/element.js.map +1 -0
  363. package/esm/utils/mark.d.ts +2 -0
  364. package/esm/utils/mark.js +4 -0
  365. package/esm/utils/mark.js.map +1 -0
  366. package/esm/utils/math.d.ts +1 -0
  367. package/esm/utils/math.js +4 -0
  368. package/esm/utils/math.js.map +1 -0
  369. package/package.json +3 -3
@@ -0,0 +1,64 @@
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
@@ -0,0 +1 @@
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"]}
@@ -0,0 +1,16 @@
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;
@@ -0,0 +1,28 @@
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
@@ -0,0 +1 @@
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"]}
@@ -0,0 +1,3 @@
1
+ import { ISequenceScatterPixelSpec } from './interface';
2
+ export declare function createImageDataFromColorMatrix(colorMatrix: any[][], spec: ISequenceScatterPixelSpec): string | null;
3
+ export declare function processSequenceData(spec: ISequenceScatterPixelSpec): any[];
@@ -0,0 +1,46 @@
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
@@ -0,0 +1 @@
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"]}
@@ -0,0 +1,7 @@
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;
@@ -0,0 +1,85 @@
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
@@ -0,0 +1 @@
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"]}
@@ -0,0 +1 @@
1
+ export declare const BAR_LINK = "barLink";
@@ -0,0 +1,2 @@
1
+ export const BAR_LINK = "barLink";
2
+ //# sourceMappingURL=constant.js.map
@@ -0,0 +1 @@
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"]}
@@ -0,0 +1,4 @@
1
+ export { BarLinkComponent, registerBarLink } from './bar-link';
2
+ export * from './type';
3
+ export { getBarLinkConfig, appendBarLinkConfig } from './util';
4
+ export * from './constant';
@@ -0,0 +1,8 @@
1
+ export { BarLinkComponent, registerBarLink } from "./bar-link";
2
+
3
+ export * from "./type";
4
+
5
+ export { getBarLinkConfig, appendBarLinkConfig } from "./util";
6
+
7
+ export * from "./constant";
8
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
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"]}
@@ -0,0 +1,27 @@
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
+ }
@@ -0,0 +1,2 @@
1
+ export { };
2
+ //# sourceMappingURL=type.js.map
@@ -0,0 +1 @@
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"]}
@@ -0,0 +1,22 @@
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;
@@ -0,0 +1,178 @@
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
@@ -0,0 +1 @@
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"]}