@visactor/vchart-extension 1.13.18 → 1.13.19-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 (291) hide show
  1. package/build/index.js +13990 -0
  2. package/build/index.min.js +15 -0
  3. package/cjs/charts/conversion-funnel/arrow-data-transform.d.ts +24 -0
  4. package/cjs/charts/conversion-funnel/arrow-data-transform.js +99 -0
  5. package/cjs/charts/conversion-funnel/arrow-data-transform.js.map +1 -0
  6. package/cjs/charts/conversion-funnel/conversion-funnel-transformer.d.ts +7 -0
  7. package/cjs/charts/conversion-funnel/conversion-funnel-transformer.js +196 -0
  8. package/cjs/charts/conversion-funnel/conversion-funnel-transformer.js.map +1 -0
  9. package/cjs/charts/conversion-funnel/conversion-funnel.d.ts +40 -0
  10. package/cjs/charts/conversion-funnel/conversion-funnel.js +78 -0
  11. package/cjs/charts/conversion-funnel/conversion-funnel.js.map +1 -0
  12. package/cjs/charts/conversion-funnel/index.d.ts +2 -0
  13. package/cjs/charts/conversion-funnel/index.js +21 -0
  14. package/cjs/charts/conversion-funnel/index.js.map +1 -0
  15. package/cjs/charts/conversion-funnel/interface.d.ts +35 -0
  16. package/cjs/charts/conversion-funnel/interface.js +6 -0
  17. package/cjs/charts/conversion-funnel/interface.js.map +1 -0
  18. package/cjs/charts/conversion-funnel/util.d.ts +3 -0
  19. package/cjs/charts/conversion-funnel/util.js +17 -0
  20. package/cjs/charts/conversion-funnel/util.js.map +1 -0
  21. package/cjs/charts/ranking-bar/interface.d.ts +45 -0
  22. package/cjs/charts/ranking-bar/interface.js +6 -0
  23. package/cjs/charts/ranking-bar/interface.js.map +1 -0
  24. package/cjs/charts/ranking-bar/ranking-bar-transformer.d.ts +10 -0
  25. package/cjs/charts/ranking-bar/ranking-bar-transformer.js +291 -0
  26. package/cjs/charts/ranking-bar/ranking-bar-transformer.js.map +1 -0
  27. package/cjs/charts/ranking-bar/ranking-bar.d.ts +16 -0
  28. package/cjs/charts/ranking-bar/ranking-bar.js +34 -0
  29. package/cjs/charts/ranking-bar/ranking-bar.js.map +1 -0
  30. package/cjs/charts/ranking-list/constant.d.ts +2 -0
  31. package/cjs/charts/ranking-list/constant.js +75 -0
  32. package/cjs/charts/ranking-list/constant.js.map +1 -0
  33. package/cjs/charts/ranking-list/interface.d.ts +74 -0
  34. package/cjs/charts/ranking-list/interface.js +6 -0
  35. package/cjs/charts/ranking-list/interface.js.map +1 -0
  36. package/cjs/charts/ranking-list/ranking-list-transformer.d.ts +459 -0
  37. package/cjs/charts/ranking-list/ranking-list-transformer.js +382 -0
  38. package/cjs/charts/ranking-list/ranking-list-transformer.js.map +1 -0
  39. package/cjs/charts/ranking-list/ranking-list.d.ts +16 -0
  40. package/cjs/charts/ranking-list/ranking-list.js +34 -0
  41. package/cjs/charts/ranking-list/ranking-list.js.map +1 -0
  42. package/cjs/charts/ranking-list/utils.d.ts +7 -0
  43. package/cjs/charts/ranking-list/utils.js +51 -0
  44. package/cjs/charts/ranking-list/utils.js.map +1 -0
  45. package/cjs/charts/sequence-scatter-kde/constant.d.ts +3 -0
  46. package/cjs/charts/sequence-scatter-kde/constant.js +7 -0
  47. package/cjs/charts/sequence-scatter-kde/constant.js.map +1 -0
  48. package/cjs/charts/sequence-scatter-kde/interface.d.ts +29 -0
  49. package/cjs/charts/sequence-scatter-kde/interface.js +6 -0
  50. package/cjs/charts/sequence-scatter-kde/interface.js.map +1 -0
  51. package/cjs/charts/sequence-scatter-kde/sequence-scatter-kde-transformer.d.ts +6 -0
  52. package/cjs/charts/sequence-scatter-kde/sequence-scatter-kde-transformer.js +142 -0
  53. package/cjs/charts/sequence-scatter-kde/sequence-scatter-kde-transformer.js.map +1 -0
  54. package/cjs/charts/sequence-scatter-kde/sequence-scatter-kde.d.ts +16 -0
  55. package/cjs/charts/sequence-scatter-kde/sequence-scatter-kde.js +34 -0
  56. package/cjs/charts/sequence-scatter-kde/sequence-scatter-kde.js.map +1 -0
  57. package/cjs/charts/sequence-scatter-kde/utils.d.ts +9 -0
  58. package/cjs/charts/sequence-scatter-kde/utils.js +42 -0
  59. package/cjs/charts/sequence-scatter-kde/utils.js.map +1 -0
  60. package/cjs/charts/sequence-scatter-link/interface.d.ts +59 -0
  61. package/cjs/charts/sequence-scatter-link/interface.js +6 -0
  62. package/cjs/charts/sequence-scatter-link/interface.js.map +1 -0
  63. package/cjs/charts/sequence-scatter-link/sequence-scatter-link-transformer.d.ts +6 -0
  64. package/cjs/charts/sequence-scatter-link/sequence-scatter-link-transformer.js +328 -0
  65. package/cjs/charts/sequence-scatter-link/sequence-scatter-link-transformer.js.map +1 -0
  66. package/cjs/charts/sequence-scatter-link/sequence-scatter-link.d.ts +16 -0
  67. package/cjs/charts/sequence-scatter-link/sequence-scatter-link.js +34 -0
  68. package/cjs/charts/sequence-scatter-link/sequence-scatter-link.js.map +1 -0
  69. package/cjs/charts/sequence-scatter-link/utils.d.ts +9 -0
  70. package/cjs/charts/sequence-scatter-link/utils.js +108 -0
  71. package/cjs/charts/sequence-scatter-link/utils.js.map +1 -0
  72. package/cjs/charts/sequence-scatter-pixel/constant.d.ts +3 -0
  73. package/cjs/charts/sequence-scatter-pixel/constant.js +7 -0
  74. package/cjs/charts/sequence-scatter-pixel/constant.js.map +1 -0
  75. package/cjs/charts/sequence-scatter-pixel/interface.d.ts +29 -0
  76. package/cjs/charts/sequence-scatter-pixel/interface.js +6 -0
  77. package/cjs/charts/sequence-scatter-pixel/interface.js.map +1 -0
  78. package/cjs/charts/sequence-scatter-pixel/sequence-scatter-pixel-transformer.d.ts +4 -0
  79. package/cjs/charts/sequence-scatter-pixel/sequence-scatter-pixel-transformer.js +68 -0
  80. package/cjs/charts/sequence-scatter-pixel/sequence-scatter-pixel-transformer.js.map +1 -0
  81. package/cjs/charts/sequence-scatter-pixel/sequence-scatter-pixel.d.ts +16 -0
  82. package/cjs/charts/sequence-scatter-pixel/sequence-scatter-pixel.js +34 -0
  83. package/cjs/charts/sequence-scatter-pixel/sequence-scatter-pixel.js.map +1 -0
  84. package/cjs/charts/sequence-scatter-pixel/utils.d.ts +3 -0
  85. package/cjs/charts/sequence-scatter-pixel/utils.js +53 -0
  86. package/cjs/charts/sequence-scatter-pixel/utils.js.map +1 -0
  87. package/cjs/components/bar-link/bar-link.d.ts +7 -0
  88. package/cjs/components/bar-link/bar-link.js +87 -0
  89. package/cjs/components/bar-link/bar-link.js.map +1 -0
  90. package/cjs/components/bar-link/constant.d.ts +1 -0
  91. package/cjs/components/bar-link/constant.js +6 -0
  92. package/cjs/components/bar-link/constant.js.map +1 -0
  93. package/cjs/components/bar-link/index.d.ts +4 -0
  94. package/cjs/components/bar-link/index.js +49 -0
  95. package/cjs/components/bar-link/index.js.map +1 -0
  96. package/cjs/components/bar-link/type.d.ts +27 -0
  97. package/cjs/components/bar-link/type.js +6 -0
  98. package/cjs/components/bar-link/type.js.map +1 -0
  99. package/cjs/components/bar-link/util.d.ts +22 -0
  100. package/cjs/components/bar-link/util.js +183 -0
  101. package/cjs/components/bar-link/util.js.map +1 -0
  102. package/cjs/components/series-break/constant.d.ts +1 -0
  103. package/cjs/components/series-break/constant.js +6 -0
  104. package/cjs/components/series-break/constant.js.map +1 -0
  105. package/cjs/components/series-break/index.d.ts +4 -0
  106. package/cjs/components/series-break/index.js +49 -0
  107. package/cjs/components/series-break/index.js.map +1 -0
  108. package/cjs/components/series-break/series-break.d.ts +7 -0
  109. package/cjs/components/series-break/series-break.js +118 -0
  110. package/cjs/components/series-break/series-break.js.map +1 -0
  111. package/cjs/components/series-break/type.d.ts +14 -0
  112. package/cjs/components/series-break/type.js +6 -0
  113. package/cjs/components/series-break/type.js.map +1 -0
  114. package/cjs/components/series-break/util.d.ts +13 -0
  115. package/cjs/components/series-break/util.js +248 -0
  116. package/cjs/components/series-break/util.js.map +1 -0
  117. package/cjs/components/series-label/constant.d.ts +1 -0
  118. package/cjs/components/series-label/constant.js +6 -0
  119. package/cjs/components/series-label/constant.js.map +1 -0
  120. package/cjs/components/series-label/index.d.ts +3 -0
  121. package/cjs/components/series-label/index.js +49 -0
  122. package/cjs/components/series-label/index.js.map +1 -0
  123. package/cjs/components/series-label/series-label.d.ts +7 -0
  124. package/cjs/components/series-label/series-label.js +114 -0
  125. package/cjs/components/series-label/series-label.js.map +1 -0
  126. package/cjs/components/series-label/type.d.ts +41 -0
  127. package/cjs/components/series-label/type.js +6 -0
  128. package/cjs/components/series-label/type.js.map +1 -0
  129. package/cjs/components/series-label/util.d.ts +33 -0
  130. package/cjs/components/series-label/util.js +152 -0
  131. package/cjs/components/series-label/util.js.map +1 -0
  132. package/cjs/index.d.ts +9 -0
  133. package/cjs/index.js +25 -0
  134. package/cjs/index.js.map +1 -0
  135. package/cjs/type/index.d.ts +1 -0
  136. package/cjs/type/index.js +21 -0
  137. package/cjs/type/index.js.map +1 -0
  138. package/cjs/type/type.d.ts +8 -0
  139. package/cjs/type/type.js +6 -0
  140. package/cjs/type/type.js.map +1 -0
  141. package/cjs/utils/element.d.ts +7 -0
  142. package/cjs/utils/element.js +21 -0
  143. package/cjs/utils/element.js.map +1 -0
  144. package/cjs/utils/math.d.ts +1 -0
  145. package/cjs/utils/math.js +10 -0
  146. package/cjs/utils/math.js.map +1 -0
  147. package/esm/charts/conversion-funnel/arrow-data-transform.d.ts +24 -0
  148. package/esm/charts/conversion-funnel/arrow-data-transform.js +94 -0
  149. package/esm/charts/conversion-funnel/arrow-data-transform.js.map +1 -0
  150. package/esm/charts/conversion-funnel/conversion-funnel-transformer.d.ts +7 -0
  151. package/esm/charts/conversion-funnel/conversion-funnel-transformer.js +192 -0
  152. package/esm/charts/conversion-funnel/conversion-funnel-transformer.js.map +1 -0
  153. package/esm/charts/conversion-funnel/conversion-funnel.d.ts +40 -0
  154. package/esm/charts/conversion-funnel/conversion-funnel.js +81 -0
  155. package/esm/charts/conversion-funnel/conversion-funnel.js.map +1 -0
  156. package/esm/charts/conversion-funnel/index.d.ts +2 -0
  157. package/esm/charts/conversion-funnel/index.js +4 -0
  158. package/esm/charts/conversion-funnel/index.js.map +1 -0
  159. package/esm/charts/conversion-funnel/interface.d.ts +35 -0
  160. package/esm/charts/conversion-funnel/interface.js +2 -0
  161. package/esm/charts/conversion-funnel/interface.js.map +1 -0
  162. package/esm/charts/conversion-funnel/util.d.ts +3 -0
  163. package/esm/charts/conversion-funnel/util.js +10 -0
  164. package/esm/charts/conversion-funnel/util.js.map +1 -0
  165. package/esm/charts/ranking-bar/interface.d.ts +45 -0
  166. package/esm/charts/ranking-bar/interface.js +2 -0
  167. package/esm/charts/ranking-bar/interface.js.map +1 -0
  168. package/esm/charts/ranking-bar/ranking-bar-transformer.d.ts +10 -0
  169. package/esm/charts/ranking-bar/ranking-bar-transformer.js +285 -0
  170. package/esm/charts/ranking-bar/ranking-bar-transformer.js.map +1 -0
  171. package/esm/charts/ranking-bar/ranking-bar.d.ts +16 -0
  172. package/esm/charts/ranking-bar/ranking-bar.js +27 -0
  173. package/esm/charts/ranking-bar/ranking-bar.js.map +1 -0
  174. package/esm/charts/ranking-list/constant.d.ts +2 -0
  175. package/esm/charts/ranking-list/constant.js +69 -0
  176. package/esm/charts/ranking-list/constant.js.map +1 -0
  177. package/esm/charts/ranking-list/interface.d.ts +74 -0
  178. package/esm/charts/ranking-list/interface.js +2 -0
  179. package/esm/charts/ranking-list/interface.js.map +1 -0
  180. package/esm/charts/ranking-list/ranking-list-transformer.d.ts +459 -0
  181. package/esm/charts/ranking-list/ranking-list-transformer.js +382 -0
  182. package/esm/charts/ranking-list/ranking-list-transformer.js.map +1 -0
  183. package/esm/charts/ranking-list/ranking-list.d.ts +16 -0
  184. package/esm/charts/ranking-list/ranking-list.js +27 -0
  185. package/esm/charts/ranking-list/ranking-list.js.map +1 -0
  186. package/esm/charts/ranking-list/utils.d.ts +7 -0
  187. package/esm/charts/ranking-list/utils.js +41 -0
  188. package/esm/charts/ranking-list/utils.js.map +1 -0
  189. package/esm/charts/sequence-scatter-kde/constant.d.ts +3 -0
  190. package/esm/charts/sequence-scatter-kde/constant.js +6 -0
  191. package/esm/charts/sequence-scatter-kde/constant.js.map +1 -0
  192. package/esm/charts/sequence-scatter-kde/interface.d.ts +29 -0
  193. package/esm/charts/sequence-scatter-kde/interface.js +2 -0
  194. package/esm/charts/sequence-scatter-kde/interface.js.map +1 -0
  195. package/esm/charts/sequence-scatter-kde/sequence-scatter-kde-transformer.d.ts +6 -0
  196. package/esm/charts/sequence-scatter-kde/sequence-scatter-kde-transformer.js +137 -0
  197. package/esm/charts/sequence-scatter-kde/sequence-scatter-kde-transformer.js.map +1 -0
  198. package/esm/charts/sequence-scatter-kde/sequence-scatter-kde.d.ts +16 -0
  199. package/esm/charts/sequence-scatter-kde/sequence-scatter-kde.js +28 -0
  200. package/esm/charts/sequence-scatter-kde/sequence-scatter-kde.js.map +1 -0
  201. package/esm/charts/sequence-scatter-kde/utils.d.ts +9 -0
  202. package/esm/charts/sequence-scatter-kde/utils.js +34 -0
  203. package/esm/charts/sequence-scatter-kde/utils.js.map +1 -0
  204. package/esm/charts/sequence-scatter-link/interface.d.ts +59 -0
  205. package/esm/charts/sequence-scatter-link/interface.js +2 -0
  206. package/esm/charts/sequence-scatter-link/interface.js.map +1 -0
  207. package/esm/charts/sequence-scatter-link/sequence-scatter-link-transformer.d.ts +6 -0
  208. package/esm/charts/sequence-scatter-link/sequence-scatter-link-transformer.js +321 -0
  209. package/esm/charts/sequence-scatter-link/sequence-scatter-link-transformer.js.map +1 -0
  210. package/esm/charts/sequence-scatter-link/sequence-scatter-link.d.ts +16 -0
  211. package/esm/charts/sequence-scatter-link/sequence-scatter-link.js +28 -0
  212. package/esm/charts/sequence-scatter-link/sequence-scatter-link.js.map +1 -0
  213. package/esm/charts/sequence-scatter-link/utils.d.ts +9 -0
  214. package/esm/charts/sequence-scatter-link/utils.js +100 -0
  215. package/esm/charts/sequence-scatter-link/utils.js.map +1 -0
  216. package/esm/charts/sequence-scatter-pixel/constant.d.ts +3 -0
  217. package/esm/charts/sequence-scatter-pixel/constant.js +6 -0
  218. package/esm/charts/sequence-scatter-pixel/constant.js.map +1 -0
  219. package/esm/charts/sequence-scatter-pixel/interface.d.ts +29 -0
  220. package/esm/charts/sequence-scatter-pixel/interface.js +2 -0
  221. package/esm/charts/sequence-scatter-pixel/interface.js.map +1 -0
  222. package/esm/charts/sequence-scatter-pixel/sequence-scatter-pixel-transformer.d.ts +4 -0
  223. package/esm/charts/sequence-scatter-pixel/sequence-scatter-pixel-transformer.js +64 -0
  224. package/esm/charts/sequence-scatter-pixel/sequence-scatter-pixel-transformer.js.map +1 -0
  225. package/esm/charts/sequence-scatter-pixel/sequence-scatter-pixel.d.ts +16 -0
  226. package/esm/charts/sequence-scatter-pixel/sequence-scatter-pixel.js +28 -0
  227. package/esm/charts/sequence-scatter-pixel/sequence-scatter-pixel.js.map +1 -0
  228. package/esm/charts/sequence-scatter-pixel/utils.d.ts +3 -0
  229. package/esm/charts/sequence-scatter-pixel/utils.js +45 -0
  230. package/esm/charts/sequence-scatter-pixel/utils.js.map +1 -0
  231. package/esm/components/bar-link/bar-link.d.ts +7 -0
  232. package/esm/components/bar-link/bar-link.js +85 -0
  233. package/esm/components/bar-link/bar-link.js.map +1 -0
  234. package/esm/components/bar-link/constant.d.ts +1 -0
  235. package/esm/components/bar-link/constant.js +2 -0
  236. package/esm/components/bar-link/constant.js.map +1 -0
  237. package/esm/components/bar-link/index.d.ts +4 -0
  238. package/esm/components/bar-link/index.js +8 -0
  239. package/esm/components/bar-link/index.js.map +1 -0
  240. package/esm/components/bar-link/type.d.ts +27 -0
  241. package/esm/components/bar-link/type.js +2 -0
  242. package/esm/components/bar-link/type.js.map +1 -0
  243. package/esm/components/bar-link/util.d.ts +22 -0
  244. package/esm/components/bar-link/util.js +178 -0
  245. package/esm/components/bar-link/util.js.map +1 -0
  246. package/esm/components/series-break/constant.d.ts +1 -0
  247. package/esm/components/series-break/constant.js +2 -0
  248. package/esm/components/series-break/constant.js.map +1 -0
  249. package/esm/components/series-break/index.d.ts +4 -0
  250. package/esm/components/series-break/index.js +8 -0
  251. package/esm/components/series-break/index.js.map +1 -0
  252. package/esm/components/series-break/series-break.d.ts +7 -0
  253. package/esm/components/series-break/series-break.js +115 -0
  254. package/esm/components/series-break/series-break.js.map +1 -0
  255. package/esm/components/series-break/type.d.ts +14 -0
  256. package/esm/components/series-break/type.js +2 -0
  257. package/esm/components/series-break/type.js.map +1 -0
  258. package/esm/components/series-break/util.d.ts +13 -0
  259. package/esm/components/series-break/util.js +244 -0
  260. package/esm/components/series-break/util.js.map +1 -0
  261. package/esm/components/series-label/constant.d.ts +1 -0
  262. package/esm/components/series-label/constant.js +2 -0
  263. package/esm/components/series-label/constant.js.map +1 -0
  264. package/esm/components/series-label/index.d.ts +3 -0
  265. package/esm/components/series-label/index.js +6 -0
  266. package/esm/components/series-label/index.js.map +1 -0
  267. package/esm/components/series-label/series-label.d.ts +7 -0
  268. package/esm/components/series-label/series-label.js +110 -0
  269. package/esm/components/series-label/series-label.js.map +1 -0
  270. package/esm/components/series-label/type.d.ts +41 -0
  271. package/esm/components/series-label/type.js +2 -0
  272. package/esm/components/series-label/type.js.map +1 -0
  273. package/esm/components/series-label/util.d.ts +33 -0
  274. package/esm/components/series-label/util.js +144 -0
  275. package/esm/components/series-label/util.js.map +1 -0
  276. package/esm/index.d.ts +9 -0
  277. package/esm/index.js +17 -0
  278. package/esm/index.js.map +1 -0
  279. package/esm/type/index.d.ts +1 -0
  280. package/esm/type/index.js +2 -0
  281. package/esm/type/index.js.map +1 -0
  282. package/esm/type/type.d.ts +8 -0
  283. package/esm/type/type.js +2 -0
  284. package/esm/type/type.js.map +1 -0
  285. package/esm/utils/element.d.ts +7 -0
  286. package/esm/utils/element.js +15 -0
  287. package/esm/utils/element.js.map +1 -0
  288. package/esm/utils/math.d.ts +1 -0
  289. package/esm/utils/math.js +4 -0
  290. package/esm/utils/math.js.map +1 -0
  291. package/package.json +6 -6
@@ -0,0 +1,68 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: !0
5
+ }), exports.SequenceScatterPixelChartSpecTransformer = void 0;
6
+
7
+ const vchart_1 = require("@visactor/vchart"), utils_1 = require("./utils"), constant_1 = require("./constant");
8
+
9
+ class SequenceScatterPixelChartSpecTransformer extends vchart_1.CommonChartSpecTransformer {
10
+ transformSpec(spec) {
11
+ var _a, _b, _c, _d, _e;
12
+ super.transformSpec(spec);
13
+ const dataSpecs = (0, utils_1.processSequenceData)(spec);
14
+ spec.type = "common", spec.dataKey = constant_1.DATA_KEY, spec.data = dataSpecs[0].data,
15
+ spec.width = 300, spec.height = 300, spec.autoFit = !1, spec.series = [ {
16
+ type: "scatter",
17
+ xField: spec.xField,
18
+ yField: spec.yField
19
+ } ], spec.player && (spec.player = Object.assign(Object.assign({}, spec.player), {
20
+ specs: dataSpecs
21
+ }), spec.animationAppear = {
22
+ duration: null !== (_b = null === (_a = spec.player) || void 0 === _a ? void 0 : _a.duration) && void 0 !== _b ? _b : 2e3,
23
+ easing: "linear"
24
+ }, spec.animationUpdate = {
25
+ duration: null !== (_d = null === (_c = spec.player) || void 0 === _c ? void 0 : _c.duration) && void 0 !== _d ? _d : 2e3,
26
+ easing: "linear"
27
+ }), spec.axes = [ {
28
+ orient: "left",
29
+ type: "linear"
30
+ }, {
31
+ orient: "bottom",
32
+ label: {
33
+ visible: !0
34
+ },
35
+ type: "linear"
36
+ } ], spec.customMark = [ {
37
+ type: "image",
38
+ dataIndex: 2,
39
+ style: {
40
+ x: 0,
41
+ y: 0,
42
+ width: 300,
43
+ height: 300,
44
+ image: datum => datum.imageData,
45
+ zIndex: -1
46
+ }
47
+ }, {
48
+ type: "text",
49
+ dataIndex: 1,
50
+ style: Object.assign({
51
+ text: datum => datum.inter,
52
+ x: 50,
53
+ y: () => 10,
54
+ textBaseline: "top",
55
+ textAlign: "left",
56
+ fontSize: 100,
57
+ fontWeight: "bolder",
58
+ fill: "black",
59
+ fillOpacity: .2
60
+ }, null === (_e = spec.infoLabel) || void 0 === _e ? void 0 : _e.style)
61
+ } ], spec.tooltip = {
62
+ visible: !1
63
+ }, super.transformSpec(spec);
64
+ }
65
+ }
66
+
67
+ exports.SequenceScatterPixelChartSpecTransformer = SequenceScatterPixelChartSpecTransformer;
68
+ //# 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,6CAA8D;AAC9D,mCAA8C;AAC9C,yCAAsC;AAEtC,MAAa,wCAAyC,SAAQ,mCAA+B;IAC3F,aAAa,CAAC,IAAS;;QACrB,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QAC1B,MAAM,SAAS,GAAG,IAAA,2BAAmB,EAAC,IAA4C,CAAC,CAAC;QAEpF,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC;QACrB,IAAI,CAAC,OAAO,GAAG,mBAAQ,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;AAvFD,4FAuFC","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,34 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: !0
5
+ }), exports.registerSequenceScatterPixel = exports.SequenceScatterPixel = void 0;
6
+
7
+ const vchart_1 = require("@visactor/vchart"), sequence_scatter_pixel_transformer_1 = require("./sequence-scatter-pixel-transformer");
8
+
9
+ class SequenceScatterPixel extends vchart_1.BaseChart {
10
+ constructor() {
11
+ super(...arguments), this.type = "sequenceScatterPixel", this.transformerConstructor = sequence_scatter_pixel_transformer_1.SequenceScatterPixelChartSpecTransformer;
12
+ }
13
+ init() {
14
+ this.isValid() && super.init();
15
+ }
16
+ isValid() {
17
+ var _a, _b, _c, _d;
18
+ const {xField: xField, yField: yField, data: data} = this._spec;
19
+ return xField && yField ? !!data || (null === (_d = (_c = this._option).onError) || void 0 === _d || _d.call(_c, "Data is required"),
20
+ !1) : (null === (_b = (_a = this._option).onError) || void 0 === _b || _b.call(_a, "Missing Required Config: `xField`, `yField` "),
21
+ !1);
22
+ }
23
+ }
24
+
25
+ exports.SequenceScatterPixel = SequenceScatterPixel, SequenceScatterPixel.type = "sequenceScatterPixel",
26
+ SequenceScatterPixel.view = "singleDefault", SequenceScatterPixel.transformerConstructor = sequence_scatter_pixel_transformer_1.SequenceScatterPixelChartSpecTransformer;
27
+
28
+ const registerSequenceScatterPixel = option => {
29
+ const vchartConstructor = (null == option ? void 0 : option.VChart) || vchart_1.VChart;
30
+ vchartConstructor && vchartConstructor.useChart([ SequenceScatterPixel, vchart_1.ScatterChart ]);
31
+ };
32
+
33
+ exports.registerSequenceScatterPixel = registerSequenceScatterPixel;
34
+ //# sourceMappingURL=sequence-scatter-pixel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["charts/sequence-scatter-pixel/sequence-scatter-pixel.ts"],"names":[],"mappings":";;;AACA,6CAAmE;AACnE,6FAAgG;AAEhG,MAAa,oBAAqB,SAAQ,kBAAkD;IAA5F;;QACE,SAAI,GAAG,sBAAsB,CAAC;QAOrB,2BAAsB,GAAG,6EAAwC,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;;AA5BH,oDA6BC;AA3BQ,yBAAI,GAAG,sBAAsB,CAAC;AACrB,yBAAI,GAAW,eAAe,CAAC;AAI/B,2CAAsB,GAAG,6EAAwC,CAAC;AAwB7E,MAAM,4BAA4B,GAAG,CAAC,MAAmC,EAAE,EAAE;IAClF,MAAM,iBAAiB,GAAG,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,MAAM,KAAI,eAAM,CAAC;IACnD,IAAI,iBAAiB,EAAE;QACrB,iBAAiB,CAAC,QAAQ,CAAC,CAAC,oBAAoB,EAAE,qBAAY,CAAC,CAAC,CAAC;KAClE;AACH,CAAC,CAAC;AALW,QAAA,4BAA4B,gCAKvC","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,53 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: !0
5
+ }), exports.processSequenceData = exports.createImageDataFromColorMatrix = void 0;
6
+
7
+ const constant_1 = require("./constant");
8
+
9
+ function createImageDataFromColorMatrix(colorMatrix, spec) {
10
+ var _a;
11
+ if ("undefined" == typeof document) throw new Error("Canvas rendering requires browser environment with document object");
12
+ const canvas = document.createElement("canvas");
13
+ canvas.width = spec.width, canvas.height = spec.height;
14
+ const ctx = canvas.getContext("2d");
15
+ if (!ctx) throw new Error("Failed to get 2D rendering context from canvas");
16
+ const imageData = ctx.createImageData(spec.width, spec.height);
17
+ for (let y = 0; y < 300; y++) for (let x = 0; x < 300; x++) {
18
+ const rgb = (null === (_a = colorMatrix[y]) || void 0 === _a ? void 0 : _a[x]) || [ 0, 0, 0 ], pixelIndex = 4 * (300 * y + x);
19
+ imageData.data[pixelIndex] = Math.round(255 * rgb[0]), imageData.data[pixelIndex + 1] = Math.round(255 * rgb[1]),
20
+ imageData.data[pixelIndex + 2] = Math.round(255 * rgb[2]), imageData.data[pixelIndex + 3] = 255;
21
+ }
22
+ return ctx.putImageData(imageData, 0, 0), canvas.toDataURL("image/png");
23
+ }
24
+
25
+ function processSequenceData(spec) {
26
+ const result = [];
27
+ return Object.keys(spec.data).forEach((inter => {
28
+ let backgroundData = null;
29
+ if (spec.backgroundColors && spec.backgroundColors[inter]) {
30
+ backgroundData = {
31
+ imageData: createImageDataFromColorMatrix(spec.backgroundColors[inter], spec)
32
+ };
33
+ }
34
+ result.push({
35
+ data: [ {
36
+ id: "nodes",
37
+ values: spec.data[inter].map(((d, i) => Object.assign(Object.assign({}, d), {
38
+ [constant_1.DATA_KEY]: i
39
+ })))
40
+ }, {
41
+ id: "inter",
42
+ values: [ {
43
+ inter: inter
44
+ } ]
45
+ }, {
46
+ id: constant_1.BACKGROUND_KEY,
47
+ values: backgroundData ? [ backgroundData ] : []
48
+ } ]
49
+ });
50
+ })), result;
51
+ }
52
+
53
+ exports.createImageDataFromColorMatrix = createImageDataFromColorMatrix, exports.processSequenceData = processSequenceData;
@@ -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,87 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: !0
5
+ }), exports.registerBarLink = exports.BarLinkComponent = void 0;
6
+
7
+ const vrender_components_1 = require("@visactor/vrender-components"), vutils_1 = require("@visactor/vutils"), vgrammar_core_1 = require("@visactor/vgrammar-core"), vrender_core_1 = require("@visactor/vrender-core"), vchart_1 = require("@visactor/vchart"), constant_1 = require("./constant");
8
+
9
+ class BarLinkComponent extends vrender_components_1.AbstractComponent {
10
+ constructor() {
11
+ super(...arguments), this.name = constant_1.BAR_LINK;
12
+ }
13
+ render() {
14
+ const {data: data, linkStyle: linkStyle, areaStyle: areaStyle, styleMap: styleMap, label: label, linkType: linkType = "total"} = this.attribute;
15
+ (0, vutils_1.isEmpty)(data) || (this.removeAllChild(), data.forEach(((datum, index) => {
16
+ var _a, _b, _c, _d, _e;
17
+ const {linePoints: linePoints, areaPoints: areaPoints, id: id = index, color: color, data: curData} = datum;
18
+ if (areaPoints && !1 !== (null === (_a = null == styleMap ? void 0 : styleMap[`area-${id}`]) || void 0 === _a ? void 0 : _a.visible)) {
19
+ const area = (0, vrender_core_1.createArea)(Object.assign(Object.assign({
20
+ points: areaPoints,
21
+ fillOpacity: .3,
22
+ fill: color,
23
+ zIndex: 0
24
+ }, areaStyle), null == styleMap ? void 0 : styleMap[`area-${id}`]));
25
+ area.name = "bar-link-area", area.id = `area-${id}`, this.add(area);
26
+ }
27
+ 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)) {
28
+ const {startSymbol: startSymbol = {}, endSymbol: endSymbol = {}, lineStyle: lineStyle} = linkStyle || {}, startSymbolAttrs = (0,
29
+ vutils_1.cloneDeep)(startSymbol), endSymbolAttrs = (0, vutils_1.cloneDeep)(endSymbol);
30
+ (null == styleMap ? void 0 : styleMap[`line-${id}`]) && styleMap[`line-${id}`].stroke && (startSymbolAttrs.style = Object.assign(Object.assign({}, startSymbolAttrs.style), {
31
+ color: styleMap[`line-${id}`].stroke
32
+ }), endSymbolAttrs.style = Object.assign(Object.assign({}, endSymbolAttrs.style), {
33
+ color: styleMap[`line-${id}`].stroke
34
+ })), startSymbolAttrs.symbolType || startSymbolAttrs.originSymbolType || (startSymbolAttrs.originSymbolType = "solidArrow"),
35
+ endSymbolAttrs.symbolType || endSymbolAttrs.originSymbolType || (endSymbolAttrs.originSymbolType = "solidArrow");
36
+ const line = new vrender_components_1.Segment({
37
+ points: linePoints,
38
+ startSymbol: Object.assign({
39
+ size: 8
40
+ }, startSymbolAttrs),
41
+ endSymbol: Object.assign({
42
+ size: 8
43
+ }, endSymbolAttrs),
44
+ lineStyle: Object.assign(Object.assign({
45
+ lineDash: [ 3, 3 ],
46
+ lineWidth: 1,
47
+ stroke: "#000"
48
+ }, lineStyle), null == styleMap ? void 0 : styleMap[`line-${id}`]),
49
+ pickable: !0,
50
+ childrenPickable: !1,
51
+ zIndex: 1
52
+ });
53
+ line.name = "bar-link-line", line.id = `line-${id}`, this.add(line);
54
+ }
55
+ if ((null == label ? void 0 : label.visible) && !1 !== (null === (_e = null == styleMap ? void 0 : styleMap[`label-${id}`]) || void 0 === _e ? void 0 : _e.visible)) {
56
+ const {style: style, formatMethod: formatMethod} = label, [startData, endData] = curData;
57
+ let startValue = startData[vchart_1.STACK_FIELD_END], endValue = endData[vchart_1.STACK_FIELD_END];
58
+ "value" === linkType && (startValue = startData[vchart_1.STACK_FIELD_END] - startData[vchart_1.STACK_FIELD_START],
59
+ endValue = endData[vchart_1.STACK_FIELD_END] - endData[vchart_1.STACK_FIELD_START]);
60
+ const value = endValue - startValue, percentage = (endValue - startValue) / startValue * 100, text = (0,
61
+ vrender_core_1.createText)(Object.assign(Object.assign({
62
+ x: .5 * (linePoints[0].x + linePoints[1].x),
63
+ y: .5 * (linePoints[0].y + linePoints[1].y),
64
+ text: formatMethod ? formatMethod(value, percentage, curData) : `${value} ${percentage}`,
65
+ fontSize: 14,
66
+ fill: "#000",
67
+ stroke: "#fff",
68
+ lineWidth: 1,
69
+ textAlign: "center",
70
+ textBaseline: "middle",
71
+ background: "#fff",
72
+ zIndex: 2
73
+ }, style), null == styleMap ? void 0 : styleMap[`label-${id}`]));
74
+ text.name = "bar-link-label", text.id = `label-${id}`, this.add(text);
75
+ }
76
+ })));
77
+ }
78
+ }
79
+
80
+ exports.BarLinkComponent = BarLinkComponent;
81
+
82
+ const registerBarLink = () => {
83
+ vgrammar_core_1.Factory.registerGraphicComponent(constant_1.BAR_LINK, (attrs => new BarLinkComponent(attrs)));
84
+ };
85
+
86
+ exports.registerBarLink = registerBarLink;
87
+ //# 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,6 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: !0
5
+ }), exports.BAR_LINK = void 0, exports.BAR_LINK = "barLink";
6
+ //# sourceMappingURL=constant.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["components/bar-link/constant.ts"],"names":[],"mappings":";;;AAAa,QAAA,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,49 @@
1
+ "use strict";
2
+
3
+ var __createBinding = this && this.__createBinding || (Object.create ? function(o, m, k, k2) {
4
+ void 0 === k2 && (k2 = k);
5
+ var desc = Object.getOwnPropertyDescriptor(m, k);
6
+ desc && !("get" in desc ? !m.__esModule : desc.writable || desc.configurable) || (desc = {
7
+ enumerable: !0,
8
+ get: function() {
9
+ return m[k];
10
+ }
11
+ }), Object.defineProperty(o, k2, desc);
12
+ } : function(o, m, k, k2) {
13
+ void 0 === k2 && (k2 = k), o[k2] = m[k];
14
+ }), __exportStar = this && this.__exportStar || function(m, exports) {
15
+ for (var p in m) "default" === p || Object.prototype.hasOwnProperty.call(exports, p) || __createBinding(exports, m, p);
16
+ };
17
+
18
+ Object.defineProperty(exports, "__esModule", {
19
+ value: !0
20
+ }), exports.appendBarLinkConfig = exports.getBarLinkConfig = exports.registerBarLink = exports.BarLinkComponent = void 0;
21
+
22
+ var bar_link_1 = require("./bar-link");
23
+
24
+ Object.defineProperty(exports, "BarLinkComponent", {
25
+ enumerable: !0,
26
+ get: function() {
27
+ return bar_link_1.BarLinkComponent;
28
+ }
29
+ }), Object.defineProperty(exports, "registerBarLink", {
30
+ enumerable: !0,
31
+ get: function() {
32
+ return bar_link_1.registerBarLink;
33
+ }
34
+ }), __exportStar(require("./type"), exports);
35
+
36
+ var util_1 = require("./util");
37
+
38
+ Object.defineProperty(exports, "getBarLinkConfig", {
39
+ enumerable: !0,
40
+ get: function() {
41
+ return util_1.getBarLinkConfig;
42
+ }
43
+ }), Object.defineProperty(exports, "appendBarLinkConfig", {
44
+ enumerable: !0,
45
+ get: function() {
46
+ return util_1.appendBarLinkConfig;
47
+ }
48
+ }), __exportStar(require("./constant"), exports);
49
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["components/bar-link/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,uCAA+D;AAAtD,4GAAA,gBAAgB,OAAA;AAAE,2GAAA,eAAe,OAAA;AAC1C,yCAAuB;AACvB,+BAA+D;AAAtD,wGAAA,gBAAgB,OAAA;AAAE,2GAAA,mBAAmB,OAAA;AAC9C,6CAA2B","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,6 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: !0
5
+ });
6
+ //# 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;