@visactor/vchart-extension 2.0.7-alpha.0 → 2.0.7-alpha.10

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 (297) hide show
  1. package/build/index.js +7327 -26054
  2. package/build/index.min.js +13 -12
  3. package/cjs/charts/3d/arc-3d.js +4 -5
  4. package/cjs/charts/3d/arc-3d.js.map +1 -1
  5. package/cjs/charts/3d/layout.d.ts +1 -1
  6. package/cjs/charts/3d/layout.js.map +1 -1
  7. package/cjs/charts/3d/plugin.js +4 -4
  8. package/cjs/charts/3d/plugin.js.map +1 -1
  9. package/cjs/charts/3d/pyramid-3d.js +4 -5
  10. package/cjs/charts/3d/pyramid-3d.js.map +1 -1
  11. package/cjs/charts/3d/rect-3d.js +4 -4
  12. package/cjs/charts/3d/rect-3d.js.map +1 -1
  13. package/cjs/charts/axis-3d/band-axis.js +2 -2
  14. package/cjs/charts/axis-3d/band-axis.js.map +1 -1
  15. package/cjs/charts/axis-3d/linear-axis.js +2 -2
  16. package/cjs/charts/axis-3d/linear-axis.js.map +1 -1
  17. package/cjs/charts/axis-3d/log-axis.js +2 -2
  18. package/cjs/charts/axis-3d/log-axis.js.map +1 -1
  19. package/cjs/charts/axis-3d/symlog-axis.js +2 -2
  20. package/cjs/charts/axis-3d/symlog-axis.js.map +1 -1
  21. package/cjs/charts/axis-3d/time-axis.js +2 -2
  22. package/cjs/charts/axis-3d/time-axis.js.map +1 -1
  23. package/cjs/charts/candlestick/candlestick.d.ts +1 -1
  24. package/cjs/charts/candlestick/candlestick.js +1 -2
  25. package/cjs/charts/candlestick/candlestick.js.map +1 -1
  26. package/cjs/charts/candlestick/mark/candlestick.d.ts +2 -1
  27. package/cjs/charts/candlestick/mark/candlestick.js +4 -4
  28. package/cjs/charts/candlestick/mark/candlestick.js.map +1 -1
  29. package/cjs/charts/candlestick/series/animation.d.ts +2 -2
  30. package/cjs/charts/candlestick/series/animation.js +17 -17
  31. package/cjs/charts/candlestick/series/animation.js.map +1 -1
  32. package/cjs/charts/candlestick/series/candlestick.d.ts +2 -1
  33. package/cjs/charts/candlestick/series/candlestick.js +4 -4
  34. package/cjs/charts/candlestick/series/candlestick.js.map +1 -1
  35. package/cjs/charts/combination-candlestick/combination-candlestick-transformer.js +13 -13
  36. package/cjs/charts/combination-candlestick/combination-candlestick-transformer.js.map +1 -1
  37. package/cjs/charts/combination-candlestick/combination-candlestick.js +4 -3
  38. package/cjs/charts/combination-candlestick/combination-candlestick.js.map +1 -1
  39. package/cjs/charts/conversion-funnel/arrow-data-transform.d.ts +1 -1
  40. package/cjs/charts/conversion-funnel/arrow-data-transform.js +5 -5
  41. package/cjs/charts/conversion-funnel/arrow-data-transform.js.map +1 -1
  42. package/cjs/charts/conversion-funnel/conversion-funnel-transformer.js +2 -2
  43. package/cjs/charts/conversion-funnel/conversion-funnel-transformer.js.map +1 -1
  44. package/cjs/charts/conversion-funnel/conversion-funnel.d.ts +1 -1
  45. package/cjs/charts/conversion-funnel/conversion-funnel.js +2 -2
  46. package/cjs/charts/conversion-funnel/conversion-funnel.js.map +1 -1
  47. package/cjs/charts/image-cloud/series/animation.d.ts +2 -2
  48. package/cjs/charts/image-cloud/series/animation.js +8 -8
  49. package/cjs/charts/image-cloud/series/animation.js.map +1 -1
  50. package/cjs/charts/image-cloud/series/image-cloud.d.ts +4 -4
  51. package/cjs/charts/image-cloud/series/image-cloud.js +16 -16
  52. package/cjs/charts/image-cloud/series/image-cloud.js.map +1 -1
  53. package/cjs/charts/image-cloud/series/interface.d.ts +1 -1
  54. package/cjs/charts/image-cloud/series/interface.js.map +1 -1
  55. package/cjs/charts/pictogram/element-highlight-by-graphic-name.js +2 -2
  56. package/cjs/charts/pictogram/element-highlight-by-graphic-name.js.map +1 -1
  57. package/cjs/charts/pictogram/series/pictogram-transformer.js +3 -3
  58. package/cjs/charts/pictogram/series/pictogram-transformer.js.map +1 -1
  59. package/cjs/charts/pictogram/series/pictogram.d.ts +3 -3
  60. package/cjs/charts/pictogram/series/pictogram.js +27 -27
  61. package/cjs/charts/pictogram/series/pictogram.js.map +1 -1
  62. package/cjs/charts/pictogram/series/svg-source.d.ts +1 -2
  63. package/cjs/charts/pictogram/series/svg-source.js +3 -3
  64. package/cjs/charts/pictogram/series/svg-source.js.map +1 -1
  65. package/cjs/charts/pictogram/series/transform.d.ts +1 -1
  66. package/cjs/charts/pictogram/series/transform.js +6 -6
  67. package/cjs/charts/pictogram/series/transform.js.map +1 -1
  68. package/cjs/charts/ranking-bar/interface.d.ts +1 -1
  69. package/cjs/charts/ranking-bar/interface.js.map +1 -1
  70. package/cjs/charts/ranking-bar/ranking-bar-transformer.js +2 -2
  71. package/cjs/charts/ranking-bar/ranking-bar-transformer.js.map +1 -1
  72. package/cjs/charts/ranking-list/interface.d.ts +4 -4
  73. package/cjs/charts/ranking-list/interface.js.map +1 -1
  74. package/cjs/charts/ranking-list/ranking-list-transformer.d.ts +37 -37
  75. package/cjs/charts/ranking-list/ranking-list-transformer.js +5 -5
  76. package/cjs/charts/ranking-list/ranking-list-transformer.js.map +1 -1
  77. package/cjs/charts/ranking-list/utils.js +2 -2
  78. package/cjs/charts/ranking-list/utils.js.map +1 -1
  79. package/cjs/charts/sequence-scatter-kde/interface.d.ts +3 -3
  80. package/cjs/charts/sequence-scatter-kde/interface.js.map +1 -1
  81. package/cjs/charts/sequence-scatter-link/interface.d.ts +2 -2
  82. package/cjs/charts/sequence-scatter-link/interface.js.map +1 -1
  83. package/cjs/charts/sequence-scatter-pixel/interface.d.ts +3 -3
  84. package/cjs/charts/sequence-scatter-pixel/interface.js.map +1 -1
  85. package/cjs/charts/word-cloud-3d/animation.js +3 -3
  86. package/cjs/charts/word-cloud-3d/animation.js.map +1 -1
  87. package/cjs/components/bar-link/bar-link.d.ts +1 -1
  88. package/cjs/components/bar-link/bar-link.js +11 -11
  89. package/cjs/components/bar-link/bar-link.js.map +1 -1
  90. package/cjs/components/bar-link/type.d.ts +1 -6
  91. package/cjs/components/bar-link/type.js.map +1 -1
  92. package/cjs/components/bar-link/util.d.ts +1 -1
  93. package/cjs/components/bar-link/util.js +2 -2
  94. package/cjs/components/bar-link/util.js.map +1 -1
  95. package/cjs/components/bar-regression-line/index.d.ts +26 -0
  96. package/cjs/components/bar-regression-line/index.js +87 -0
  97. package/cjs/components/bar-regression-line/index.js.map +1 -0
  98. package/cjs/components/bar-regression-line/type.d.ts +8 -0
  99. package/cjs/components/bar-regression-line/type.js +6 -0
  100. package/cjs/components/bar-regression-line/type.js.map +1 -0
  101. package/cjs/components/histogram-regression-line/index.d.ts +22 -0
  102. package/cjs/components/histogram-regression-line/index.js +79 -0
  103. package/cjs/components/histogram-regression-line/index.js.map +1 -0
  104. package/cjs/components/histogram-regression-line/type.d.ts +8 -0
  105. package/cjs/components/histogram-regression-line/type.js +6 -0
  106. package/cjs/components/histogram-regression-line/type.js.map +1 -0
  107. package/cjs/components/map-label/layout.d.ts +1 -1
  108. package/cjs/components/map-label/layout.js +4 -4
  109. package/cjs/components/map-label/layout.js.map +1 -1
  110. package/cjs/components/map-label/map-label.d.ts +3 -4
  111. package/cjs/components/map-label/map-label.js +21 -21
  112. package/cjs/components/map-label/map-label.js.map +1 -1
  113. package/cjs/components/map-label/type.d.ts +1 -1
  114. package/cjs/components/map-label/type.js.map +1 -1
  115. package/cjs/components/regression-line/index.d.ts +2 -0
  116. package/cjs/components/regression-line/index.js +21 -0
  117. package/cjs/components/regression-line/index.js.map +1 -0
  118. package/cjs/components/regression-line/regression-line.d.ts +8 -0
  119. package/cjs/components/regression-line/regression-line.js +58 -0
  120. package/cjs/components/regression-line/regression-line.js.map +1 -0
  121. package/cjs/components/regression-line/type.d.ts +30 -0
  122. package/cjs/components/regression-line/type.js +6 -0
  123. package/cjs/components/regression-line/type.js.map +1 -0
  124. package/cjs/components/scatter-regression-line/index.d.ts +25 -0
  125. package/cjs/components/scatter-regression-line/index.js +103 -0
  126. package/cjs/components/scatter-regression-line/index.js.map +1 -0
  127. package/cjs/components/scatter-regression-line/type.d.ts +9 -0
  128. package/cjs/components/scatter-regression-line/type.js +6 -0
  129. package/cjs/components/scatter-regression-line/type.js.map +1 -0
  130. package/cjs/components/series-break/series-break.d.ts +2 -2
  131. package/cjs/components/series-break/series-break.js +10 -10
  132. package/cjs/components/series-break/series-break.js.map +1 -1
  133. package/cjs/components/series-break/type.d.ts +1 -2
  134. package/cjs/components/series-break/type.js.map +1 -1
  135. package/cjs/components/series-break/util.js +7 -7
  136. package/cjs/components/series-break/util.js.map +1 -1
  137. package/cjs/components/series-label/series-label.d.ts +2 -2
  138. package/cjs/components/series-label/series-label.js +8 -8
  139. package/cjs/components/series-label/series-label.js.map +1 -1
  140. package/cjs/components/series-label/type.d.ts +1 -2
  141. package/cjs/components/series-label/type.js.map +1 -1
  142. package/cjs/components/series-label/util.d.ts +4 -4
  143. package/cjs/components/series-label/util.js +5 -5
  144. package/cjs/components/series-label/util.js.map +1 -1
  145. package/cjs/index.d.ts +4 -0
  146. package/cjs/index.js +3 -1
  147. package/cjs/index.js.map +1 -1
  148. package/cjs/type/type.d.ts +1 -1
  149. package/cjs/type/type.js.map +1 -1
  150. package/esm/charts/3d/arc-3d.js +1 -3
  151. package/esm/charts/3d/arc-3d.js.map +1 -1
  152. package/esm/charts/3d/layout.d.ts +1 -1
  153. package/esm/charts/3d/layout.js.map +1 -1
  154. package/esm/charts/3d/plugin.js +1 -1
  155. package/esm/charts/3d/plugin.js.map +1 -1
  156. package/esm/charts/3d/pyramid-3d.js +1 -3
  157. package/esm/charts/3d/pyramid-3d.js.map +1 -1
  158. package/esm/charts/3d/rect-3d.js +1 -3
  159. package/esm/charts/3d/rect-3d.js.map +1 -1
  160. package/esm/charts/axis-3d/band-axis.js +1 -1
  161. package/esm/charts/axis-3d/band-axis.js.map +1 -1
  162. package/esm/charts/axis-3d/linear-axis.js +1 -1
  163. package/esm/charts/axis-3d/linear-axis.js.map +1 -1
  164. package/esm/charts/axis-3d/log-axis.js +1 -1
  165. package/esm/charts/axis-3d/log-axis.js.map +1 -1
  166. package/esm/charts/axis-3d/symlog-axis.js +1 -1
  167. package/esm/charts/axis-3d/symlog-axis.js.map +1 -1
  168. package/esm/charts/axis-3d/time-axis.js +1 -1
  169. package/esm/charts/axis-3d/time-axis.js.map +1 -1
  170. package/esm/charts/candlestick/candlestick.d.ts +1 -1
  171. package/esm/charts/candlestick/candlestick.js +1 -2
  172. package/esm/charts/candlestick/candlestick.js.map +1 -1
  173. package/esm/charts/candlestick/mark/candlestick.d.ts +2 -1
  174. package/esm/charts/candlestick/mark/candlestick.js +1 -5
  175. package/esm/charts/candlestick/mark/candlestick.js.map +1 -1
  176. package/esm/charts/candlestick/series/animation.d.ts +2 -2
  177. package/esm/charts/candlestick/series/animation.js +2 -2
  178. package/esm/charts/candlestick/series/animation.js.map +1 -1
  179. package/esm/charts/candlestick/series/candlestick.d.ts +2 -1
  180. package/esm/charts/candlestick/series/candlestick.js +1 -1
  181. package/esm/charts/candlestick/series/candlestick.js.map +1 -1
  182. package/esm/charts/combination-candlestick/combination-candlestick-transformer.js +1 -1
  183. package/esm/charts/combination-candlestick/combination-candlestick-transformer.js.map +1 -1
  184. package/esm/charts/combination-candlestick/combination-candlestick.js +3 -2
  185. package/esm/charts/combination-candlestick/combination-candlestick.js.map +1 -1
  186. package/esm/charts/conversion-funnel/arrow-data-transform.d.ts +1 -1
  187. package/esm/charts/conversion-funnel/arrow-data-transform.js +1 -1
  188. package/esm/charts/conversion-funnel/arrow-data-transform.js.map +1 -1
  189. package/esm/charts/conversion-funnel/conversion-funnel-transformer.js +1 -1
  190. package/esm/charts/conversion-funnel/conversion-funnel-transformer.js.map +1 -1
  191. package/esm/charts/conversion-funnel/conversion-funnel.d.ts +1 -1
  192. package/esm/charts/conversion-funnel/conversion-funnel.js +1 -1
  193. package/esm/charts/conversion-funnel/conversion-funnel.js.map +1 -1
  194. package/esm/charts/image-cloud/series/animation.d.ts +2 -2
  195. package/esm/charts/image-cloud/series/animation.js +2 -2
  196. package/esm/charts/image-cloud/series/animation.js.map +1 -1
  197. package/esm/charts/image-cloud/series/image-cloud.d.ts +4 -4
  198. package/esm/charts/image-cloud/series/image-cloud.js +3 -3
  199. package/esm/charts/image-cloud/series/image-cloud.js.map +1 -1
  200. package/esm/charts/image-cloud/series/interface.d.ts +1 -1
  201. package/esm/charts/image-cloud/series/interface.js.map +1 -1
  202. package/esm/charts/pictogram/element-highlight-by-graphic-name.js +1 -1
  203. package/esm/charts/pictogram/element-highlight-by-graphic-name.js.map +1 -1
  204. package/esm/charts/pictogram/series/pictogram-transformer.js +1 -1
  205. package/esm/charts/pictogram/series/pictogram-transformer.js.map +1 -1
  206. package/esm/charts/pictogram/series/pictogram.d.ts +3 -3
  207. package/esm/charts/pictogram/series/pictogram.js +3 -3
  208. package/esm/charts/pictogram/series/pictogram.js.map +1 -1
  209. package/esm/charts/pictogram/series/svg-source.d.ts +1 -2
  210. package/esm/charts/pictogram/series/svg-source.js +1 -1
  211. package/esm/charts/pictogram/series/svg-source.js.map +1 -1
  212. package/esm/charts/pictogram/series/transform.d.ts +1 -1
  213. package/esm/charts/pictogram/series/transform.js +1 -1
  214. package/esm/charts/pictogram/series/transform.js.map +1 -1
  215. package/esm/charts/ranking-bar/interface.d.ts +1 -1
  216. package/esm/charts/ranking-bar/interface.js.map +1 -1
  217. package/esm/charts/ranking-bar/ranking-bar-transformer.js +1 -3
  218. package/esm/charts/ranking-bar/ranking-bar-transformer.js.map +1 -1
  219. package/esm/charts/ranking-list/interface.d.ts +4 -4
  220. package/esm/charts/ranking-list/interface.js.map +1 -1
  221. package/esm/charts/ranking-list/ranking-list-transformer.d.ts +37 -37
  222. package/esm/charts/ranking-list/ranking-list-transformer.js +1 -1
  223. package/esm/charts/ranking-list/ranking-list-transformer.js.map +1 -1
  224. package/esm/charts/ranking-list/utils.js +1 -1
  225. package/esm/charts/ranking-list/utils.js.map +1 -1
  226. package/esm/charts/sequence-scatter-kde/interface.d.ts +3 -3
  227. package/esm/charts/sequence-scatter-kde/interface.js.map +1 -1
  228. package/esm/charts/sequence-scatter-link/interface.d.ts +2 -2
  229. package/esm/charts/sequence-scatter-link/interface.js.map +1 -1
  230. package/esm/charts/sequence-scatter-pixel/interface.d.ts +3 -3
  231. package/esm/charts/sequence-scatter-pixel/interface.js.map +1 -1
  232. package/esm/charts/word-cloud-3d/animation.js +1 -1
  233. package/esm/charts/word-cloud-3d/animation.js.map +1 -1
  234. package/esm/components/bar-link/bar-link.d.ts +1 -1
  235. package/esm/components/bar-link/bar-link.js +2 -4
  236. package/esm/components/bar-link/bar-link.js.map +1 -1
  237. package/esm/components/bar-link/type.d.ts +1 -6
  238. package/esm/components/bar-link/type.js.map +1 -1
  239. package/esm/components/bar-link/util.d.ts +1 -1
  240. package/esm/components/bar-link/util.js +1 -1
  241. package/esm/components/bar-link/util.js.map +1 -1
  242. package/esm/components/bar-regression-line/index.d.ts +26 -0
  243. package/esm/components/bar-regression-line/index.js +80 -0
  244. package/esm/components/bar-regression-line/index.js.map +1 -0
  245. package/esm/components/bar-regression-line/type.d.ts +8 -0
  246. package/esm/components/bar-regression-line/type.js +2 -0
  247. package/esm/components/bar-regression-line/type.js.map +1 -0
  248. package/esm/components/histogram-regression-line/index.d.ts +22 -0
  249. package/esm/components/histogram-regression-line/index.js +75 -0
  250. package/esm/components/histogram-regression-line/index.js.map +1 -0
  251. package/esm/components/histogram-regression-line/type.d.ts +8 -0
  252. package/esm/components/histogram-regression-line/type.js +2 -0
  253. package/esm/components/histogram-regression-line/type.js.map +1 -0
  254. package/esm/components/map-label/layout.d.ts +1 -1
  255. package/esm/components/map-label/layout.js +1 -1
  256. package/esm/components/map-label/layout.js.map +1 -1
  257. package/esm/components/map-label/map-label.d.ts +3 -4
  258. package/esm/components/map-label/map-label.js +3 -5
  259. package/esm/components/map-label/map-label.js.map +1 -1
  260. package/esm/components/map-label/type.d.ts +1 -1
  261. package/esm/components/map-label/type.js.map +1 -1
  262. package/esm/components/regression-line/index.d.ts +2 -0
  263. package/esm/components/regression-line/index.js +4 -0
  264. package/esm/components/regression-line/index.js.map +1 -0
  265. package/esm/components/regression-line/regression-line.d.ts +8 -0
  266. package/esm/components/regression-line/regression-line.js +52 -0
  267. package/esm/components/regression-line/regression-line.js.map +1 -0
  268. package/esm/components/regression-line/type.d.ts +30 -0
  269. package/esm/components/regression-line/type.js +2 -0
  270. package/esm/components/regression-line/type.js.map +1 -0
  271. package/esm/components/scatter-regression-line/index.d.ts +25 -0
  272. package/esm/components/scatter-regression-line/index.js +99 -0
  273. package/esm/components/scatter-regression-line/index.js.map +1 -0
  274. package/esm/components/scatter-regression-line/type.d.ts +9 -0
  275. package/esm/components/scatter-regression-line/type.js +2 -0
  276. package/esm/components/scatter-regression-line/type.js.map +1 -0
  277. package/esm/components/series-break/series-break.d.ts +2 -2
  278. package/esm/components/series-break/series-break.js +2 -4
  279. package/esm/components/series-break/series-break.js.map +1 -1
  280. package/esm/components/series-break/type.d.ts +1 -2
  281. package/esm/components/series-break/type.js.map +1 -1
  282. package/esm/components/series-break/util.js +1 -1
  283. package/esm/components/series-break/util.js.map +1 -1
  284. package/esm/components/series-label/series-label.d.ts +2 -2
  285. package/esm/components/series-label/series-label.js +2 -4
  286. package/esm/components/series-label/series-label.js.map +1 -1
  287. package/esm/components/series-label/type.d.ts +1 -2
  288. package/esm/components/series-label/type.js.map +1 -1
  289. package/esm/components/series-label/util.d.ts +4 -4
  290. package/esm/components/series-label/util.js +1 -1
  291. package/esm/components/series-label/util.js.map +1 -1
  292. package/esm/index.d.ts +4 -0
  293. package/esm/index.js +9 -1
  294. package/esm/index.js.map +1 -1
  295. package/esm/type/type.d.ts +1 -1
  296. package/esm/type/type.js.map +1 -1
  297. package/package.json +11 -11
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/regression-line/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,oDAAkC;AAClC,yCAAuB","file":"index.js","sourcesContent":["export * from './regression-line';\nexport * from './type';\n"]}
@@ -0,0 +1,8 @@
1
+ import { AbstractComponent } from '@visactor/vchart';
2
+ import type { RegressionLineAttrs } from '../regression-line/type';
3
+ export declare const REGRESSION_LINE = "regressionLine";
4
+ export declare class RegressionLine extends AbstractComponent<Required<RegressionLineAttrs>> {
5
+ name: string;
6
+ protected render(): void;
7
+ }
8
+ export declare const registerRegressionLine: () => void;
@@ -0,0 +1,58 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: !0
5
+ }), exports.registerRegressionLine = exports.RegressionLine = exports.REGRESSION_LINE = void 0;
6
+
7
+ const vchart_1 = require("@visactor/vchart"), vchart_2 = require("@visactor/vchart"), vchart_3 = require("@visactor/vchart");
8
+
9
+ exports.REGRESSION_LINE = "regressionLine";
10
+
11
+ class RegressionLine extends vchart_1.AbstractComponent {
12
+ constructor() {
13
+ super(...arguments), this.name = exports.REGRESSION_LINE;
14
+ }
15
+ render() {
16
+ this.removeAllChild();
17
+ const {data: data, line: line = {}, label: label, name: name = "regression-line", confidenceInterval: confidenceInterval} = this.attribute;
18
+ (0, vchart_2.isEmpty)(data) || data.forEach((d => {
19
+ const {color: color} = d;
20
+ if (d.area && !1 !== (null == confidenceInterval ? void 0 : confidenceInterval.visible)) {
21
+ const areaShape = (0, vchart_1.createArea)(Object.assign(Object.assign({
22
+ points: d.area
23
+ }, (0, vchart_2.isValid)(color) ? {
24
+ fill: color,
25
+ fillOpacity: .12
26
+ } : null), null == confidenceInterval ? void 0 : confidenceInterval.style));
27
+ areaShape.name = "scatter-regression-area", this.add(areaShape);
28
+ }
29
+ if (d.line && !1 !== (null == line ? void 0 : line.visible)) {
30
+ const lineShape = (0, vchart_1.createLine)(Object.assign(Object.assign({
31
+ points: d.line,
32
+ lineWidth: 1
33
+ }, (0, vchart_2.isValid)(color) ? {
34
+ stroke: color
35
+ } : null), null == line ? void 0 : line.style));
36
+ lineShape.name = `${name}-curve`, this.add(lineShape);
37
+ }
38
+ const lastPoint = (0, vchart_2.last)(d.line);
39
+ if (label && !1 !== label.visible && label.text && lastPoint) {
40
+ const tag = (0, vchart_1.createText)(Object.assign(Object.assign(Object.assign({}, lastPoint), {
41
+ text: label.text,
42
+ textAlign: "end",
43
+ textBaseline: "middle"
44
+ }), label.style));
45
+ tag.name = `${name}-label`, this.add(tag);
46
+ }
47
+ }));
48
+ }
49
+ }
50
+
51
+ exports.RegressionLine = RegressionLine;
52
+
53
+ const registerRegressionLine = () => {
54
+ vchart_3.Factory.registerGraphicComponent(exports.REGRESSION_LINE, (attrs => new RegressionLine(attrs)));
55
+ };
56
+
57
+ exports.registerRegressionLine = registerRegressionLine;
58
+ //# sourceMappingURL=regression-line.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/regression-line/regression-line.ts"],"names":[],"mappings":";;;AAAA,6CAAwG;AACxG,6CAA0D;AAC1D,6CAA2C;AAG9B,QAAA,eAAe,GAAG,gBAAgB,CAAC;AAEhD,MAAa,cAAe,SAAQ,0BAAgD;IAApF;;QACE,SAAI,GAAG,uBAAe,CAAC;IAoDzB,CAAC;IAnDW,MAAM;QACd,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,MAAM,EACJ,IAAI,EACJ,IAAI,GAAG,EAAE,EACT,KAAK,EACL,IAAI,GAAG,iBAAiB,EACxB,kBAAkB,EACnB,GAAG,IAAI,CAAC,SAAgC,CAAC;QAC1C,IAAI,IAAA,gBAAO,EAAC,IAAI,CAAC,EAAE;YACjB,OAAO;SACR;QAED,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YACf,MAAM,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC;YACpB,IAAI,CAAC,CAAC,IAAI,IAAI,CAAA,kBAAkB,aAAlB,kBAAkB,uBAAlB,kBAAkB,CAAE,OAAO,MAAK,KAAK,EAAE;gBACnD,MAAM,SAAS,GAAG,IAAA,mBAAU,gCAC1B,MAAM,EAAE,CAAC,CAAC,IAAI,IACX,CAAC,IAAA,gBAAO,EAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,GAC5D,kBAAkB,aAAlB,kBAAkB,uBAAlB,kBAAkB,CAAE,KAAK,EAC5B,CAAC;gBACH,SAAS,CAAC,IAAI,GAAG,yBAAyB,CAAC;gBAC3C,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;aACrB;YAED,IAAI,CAAC,CAAC,IAAI,IAAI,CAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,OAAO,MAAK,KAAK,EAAE;gBACrC,MAAM,SAAS,GAAG,IAAA,mBAAU,gCAC1B,MAAM,EAAE,CAAC,CAAC,IAAI,EACd,SAAS,EAAE,CAAC,IACT,CAAC,IAAA,gBAAO,EAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,GAC3C,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,KAAK,EACd,CAAC;gBACH,SAAS,CAAC,IAAI,GAAG,GAAG,IAAI,QAAQ,CAAC;gBACjC,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;aACrB;YAED,MAAM,SAAS,GAAG,IAAA,aAAI,EAAC,CAAC,CAAC,IAAI,CAAC,CAAC;YAE/B,IAAI,KAAK,IAAI,KAAK,CAAC,OAAO,KAAK,KAAK,IAAI,KAAK,CAAC,IAAI,IAAI,SAAS,EAAE;gBAC/D,MAAM,GAAG,GAAG,IAAA,mBAAU,gDACjB,SAAS,KACZ,IAAI,EAAE,KAAK,CAAC,IAAI,EAChB,SAAS,EAAE,KAAK,EAChB,YAAY,EAAE,QAAQ,KACnB,KAAK,CAAC,KAAK,EACd,CAAC;gBACH,GAAG,CAAC,IAAI,GAAG,GAAG,IAAI,QAAQ,CAAC;gBAC3B,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;aACf;QACH,CAAC,CAAC,CAAC;IACL,CAAC;CACF;AArDD,wCAqDC;AAEM,MAAM,sBAAsB,GAAG,GAAG,EAAE;IACzC,gBAAO,CAAC,wBAAwB,CAC9B,uBAAe,EACf,CAAC,KAAoC,EAAE,EAAE,CAAC,IAAI,cAAc,CAAC,KAAK,CAAwB,CAC3F,CAAC;AACJ,CAAC,CAAC;AALW,QAAA,sBAAsB,0BAKjC","file":"regression-line.js","sourcesContent":["import { AbstractComponent, type IGraphic, createText, createLine, createArea } from '@visactor/vchart';\nimport { isEmpty, isValid, last } from '@visactor/vchart';\nimport { Factory } from '@visactor/vchart';\nimport type { RegressionLineAttrs } from '../regression-line/type';\n\nexport const REGRESSION_LINE = 'regressionLine';\n\nexport class RegressionLine extends AbstractComponent<Required<RegressionLineAttrs>> {\n name = REGRESSION_LINE;\n protected render() {\n this.removeAllChild();\n const {\n data,\n line = {},\n label,\n name = 'regression-line',\n confidenceInterval\n } = this.attribute as RegressionLineAttrs;\n if (isEmpty(data)) {\n return;\n }\n\n data.forEach(d => {\n const { color } = d;\n if (d.area && confidenceInterval?.visible !== false) {\n const areaShape = createArea({\n points: d.area,\n ...(isValid(color) ? { fill: color, fillOpacity: 0.12 } : null),\n ...confidenceInterval?.style\n });\n areaShape.name = 'scatter-regression-area';\n this.add(areaShape);\n }\n\n if (d.line && line?.visible !== false) {\n const lineShape = createLine({\n points: d.line,\n lineWidth: 1,\n ...(isValid(color) ? { stroke: color } : null),\n ...line?.style\n });\n lineShape.name = `${name}-curve`;\n this.add(lineShape);\n }\n\n const lastPoint = last(d.line);\n\n if (label && label.visible !== false && label.text && lastPoint) {\n const tag = createText({\n ...lastPoint,\n text: label.text,\n textAlign: 'end',\n textBaseline: 'middle',\n ...label.style\n });\n tag.name = `${name}-label`;\n this.add(tag);\n }\n });\n }\n}\n\nexport const registerRegressionLine = () => {\n Factory.registerGraphicComponent(\n REGRESSION_LINE,\n (attrs: Required<RegressionLineAttrs>) => new RegressionLine(attrs) as unknown as IGraphic\n );\n};\n"]}
@@ -0,0 +1,30 @@
1
+ import type { IAreaGraphicAttribute, IGroupGraphicAttribute, ILineGraphicAttribute, ITextGraphicAttribute } from '@visactor/vchart';
2
+ export interface RegressionLineData {
3
+ color?: string;
4
+ line: {
5
+ x: number;
6
+ y: number;
7
+ }[];
8
+ area?: {
9
+ x: number;
10
+ y: number;
11
+ y1: number;
12
+ }[];
13
+ }
14
+ export interface RegressionLineAttrs extends IGroupGraphicAttribute {
15
+ name?: string;
16
+ line?: {
17
+ visible?: boolean;
18
+ style?: ILineGraphicAttribute;
19
+ };
20
+ label?: {
21
+ visible?: boolean;
22
+ text: string;
23
+ style?: ITextGraphicAttribute;
24
+ };
25
+ confidenceInterval?: {
26
+ visible?: boolean;
27
+ style?: IAreaGraphicAttribute;
28
+ };
29
+ data: RegressionLineData[];
30
+ }
@@ -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":["../src/components/regression-line/type.ts"],"names":[],"mappings":"","file":"type.js","sourcesContent":["import type {\n IAreaGraphicAttribute,\n IGroupGraphicAttribute,\n ILineGraphicAttribute,\n ITextGraphicAttribute\n} from '@visactor/vchart';\n\n/**\n * 回归线数据格式\n */\nexport interface RegressionLineData {\n /**\n * 颜色值\n */\n color?: string;\n /**\n * 回归线数据点\n */\n line: { x: number; y: number }[];\n /**\n * 置信区间数据点\n */\n area?: { x: number; y: number; y1: number }[];\n}\n\nexport interface RegressionLineAttrs extends IGroupGraphicAttribute {\n /**\n * 用于区分的名称\n */\n name?: string;\n /**\n * 回归线配置\n */\n line?: {\n /**\n * 是否显示系列标签\n * @default true\n */\n visible?: boolean;\n /**\n * 线样式\n */\n style?: ILineGraphicAttribute;\n };\n /**\n * 回归线公式标签\n */\n label?: {\n /**\n * 是否显示标签\n */\n visible?: boolean;\n /**\n * 标签文本\n */\n text: string;\n /**\n * 标签样式\n */\n style?: ITextGraphicAttribute;\n };\n /**\n * 置信区间\n */\n confidenceInterval?: {\n visible?: boolean;\n style?: IAreaGraphicAttribute;\n };\n\n data: RegressionLineData[];\n}\n"]}
@@ -0,0 +1,25 @@
1
+ import type { ISpec } from '@visactor/vchart';
2
+ import type { ScatterRegressionLineSpec } from './type';
3
+ import type { RegressionLineData } from '../regression-line/type';
4
+ export declare function getScatterRegressionLineConfig(type: 'linear' | 'logisitc' | 'lowess' | 'polynomial', config: Omit<ScatterRegressionLineSpec, 'visible' | 'type'>): {
5
+ type: string;
6
+ componentType: string;
7
+ interactive: boolean;
8
+ style: {
9
+ data: (datum: any, ctx: any) => RegressionLineData[];
10
+ line: {
11
+ visible?: boolean;
12
+ style?: import("@visactor/vchart").ILineGraphicAttribute;
13
+ };
14
+ confidenceInterval: {
15
+ visible?: boolean;
16
+ style?: import("@visactor/vchart").IAreaGraphicAttribute;
17
+ };
18
+ label: {
19
+ visible?: boolean;
20
+ text: string;
21
+ style?: import("@visactor/vchart").ITextGraphicAttribute;
22
+ };
23
+ };
24
+ };
25
+ export declare function appendScatterRegressionLineConfig(chartSpec: ISpec, spec?: ScatterRegressionLineSpec | ScatterRegressionLineSpec[]): void;
@@ -0,0 +1,103 @@
1
+ "use strict";
2
+
3
+ var __rest = this && this.__rest || function(s, e) {
4
+ var t = {};
5
+ for (var p in s) Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0 && (t[p] = s[p]);
6
+ if (null != s && "function" == typeof Object.getOwnPropertySymbols) {
7
+ var i = 0;
8
+ for (p = Object.getOwnPropertySymbols(s); i < p.length; i++) e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]) && (t[p[i]] = s[p[i]]);
9
+ }
10
+ return t;
11
+ };
12
+
13
+ Object.defineProperty(exports, "__esModule", {
14
+ value: !0
15
+ }), exports.appendScatterRegressionLineConfig = exports.getScatterRegressionLineConfig = void 0;
16
+
17
+ const vchart_1 = require("@visactor/vchart"), vchart_2 = require("@visactor/vchart"), regression_line_1 = require("../regression-line/regression-line"), getRegressionByType = (type, data, x = (d => d.x), y = (d => d.y), degree) => {
18
+ switch (type) {
19
+ case "logisitc":
20
+ return (0, vchart_1.regressionLogistic)(data, x, y);
21
+
22
+ case "lowess":
23
+ return (0, vchart_1.regressionLowess)(data, x, y);
24
+
25
+ case "polynomial":
26
+ return (0, vchart_1.regressionPolynomial)(data, x, y, {
27
+ degree: degree
28
+ });
29
+
30
+ default:
31
+ return (0, vchart_1.regressionLinear)(data, x, y);
32
+ }
33
+ };
34
+
35
+ function getScatterRegressionLineConfig(type, config) {
36
+ const {color: color, line: line, confidenceInterval: confidenceInterval, label: label} = config;
37
+ return {
38
+ type: "component",
39
+ componentType: regression_line_1.REGRESSION_LINE,
40
+ interactive: !1,
41
+ style: {
42
+ data: (datum, ctx) => {
43
+ const series = ctx.vchart.getChart().getAllSeries().filter((s => s.type === vchart_2.SeriesTypeEnum.scatter)), regressionData = [];
44
+ return series && series.length && series.forEach((s => {
45
+ var _a, _b;
46
+ const start = s.getRegion().getLayoutStartPoint(), rect = s.getRegion().getLayoutRect(), yClamper = (0,
47
+ vchart_1.clamper)(start.y, start.y + rect.height), colorAttrOptions = s.getColorAttribute(), groups = s.getSeriesKeys(), data = s.getViewData().latestData, fieldX = null === (_a = s.fieldX) || void 0 === _a ? void 0 : _a[0], fieldY = null === (_b = s.fieldY) || void 0 === _b ? void 0 : _b[0];
48
+ fieldX && fieldY && data && !(data.length <= 2) && groups.forEach((group => {
49
+ var _a;
50
+ const groupData = data.filter((d => d[null == colorAttrOptions ? void 0 : colorAttrOptions.field] === group));
51
+ if (!groupData.length) return;
52
+ const {evaluateGrid: evaluateGrid, confidenceInterval: confidenceInterval} = getRegressionByType(type, groupData, (datum => null == datum ? void 0 : datum[fieldX]), (datum => null == datum ? void 0 : datum[fieldY]), config.polynomialDegree), N = Math.max(3, Math.floor(groupData.length / 4)), lineData = evaluateGrid(N), confidenceData = confidenceInterval(N);
53
+ regressionData.push({
54
+ color: null != color ? color : null === (_a = null == colorAttrOptions ? void 0 : colorAttrOptions.scale) || void 0 === _a ? void 0 : _a.scale(group),
55
+ line: lineData.map((ld => {
56
+ const d = {
57
+ [fieldX]: ld.x,
58
+ [fieldY]: ld.y
59
+ };
60
+ return {
61
+ x: s.dataToPositionX(d) + start.x,
62
+ y: yClamper("logisitc" === type ? start.y + rect.height * (1 - ld.y) : s.dataToPositionY(d) + start.y)
63
+ };
64
+ })),
65
+ area: confidenceData.map((c => {
66
+ const d = {
67
+ [fieldX]: c.x,
68
+ [fieldY]: c.lower
69
+ };
70
+ return {
71
+ x: s.dataToPositionX(d) + start.x,
72
+ y: yClamper(s.dataToPositionY(d) + start.y),
73
+ y1: yClamper(s.dataToPositionY({
74
+ [fieldY]: c.upper
75
+ }) + start.y)
76
+ };
77
+ }))
78
+ });
79
+ }));
80
+ })), regressionData;
81
+ },
82
+ line: line,
83
+ confidenceInterval: confidenceInterval,
84
+ label: label
85
+ }
86
+ };
87
+ }
88
+
89
+ function appendScatterRegressionLineConfig(chartSpec, spec) {
90
+ var _a, _b;
91
+ spec || (spec = null !== (_a = (0, vchart_1.get)(chartSpec, regression_line_1.REGRESSION_LINE)) && void 0 !== _a ? _a : (0,
92
+ vchart_1.get)(null === (_b = chartSpec.series) || void 0 === _b ? void 0 : _b.find((s => s.type === vchart_2.SeriesTypeEnum.scatter)), regression_line_1.REGRESSION_LINE));
93
+ (0, vchart_1.array)(spec).forEach((s => {
94
+ if (!1 !== s.visible) {
95
+ chartSpec.customMark || (chartSpec.customMark = []);
96
+ const {type: type} = s, rest = __rest(s, [ "type" ]);
97
+ chartSpec.customMark.push(getScatterRegressionLineConfig(type, rest));
98
+ }
99
+ }));
100
+ }
101
+
102
+ exports.getScatterRegressionLineConfig = getScatterRegressionLineConfig, exports.appendScatterRegressionLineConfig = appendScatterRegressionLineConfig;
103
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/scatter-regression-line/index.ts"],"names":[],"mappings":"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","file":"index.js","sourcesContent":["/**\n * @description 散点图回归线组件\n * @author kangxiaoting\n */\nimport {\n array,\n clamper,\n get,\n regressionLinear,\n regressionLogistic,\n regressionLowess,\n regressionPolynomial\n} from '@visactor/vchart';\nimport type { Datum, ICartesianSeries, ISpec } from '@visactor/vchart';\nimport { SeriesTypeEnum } from '@visactor/vchart';\nimport type { ScatterRegressionLineSpec } from './type';\nimport type { RegressionLineData } from '../regression-line/type';\nimport { REGRESSION_LINE } from '../regression-line/regression-line';\n\nconst getRegressionByType = (\n type: 'linear' | 'logisitc' | 'lowess' | 'polynomial',\n data: any[],\n x: (d: any) => number = d => d.x,\n y: (d: any) => number = d => d.y,\n degree?: number\n) => {\n switch (type) {\n case 'logisitc':\n return regressionLogistic(data, x, y);\n case 'lowess':\n return regressionLowess(data, x, y);\n case 'polynomial':\n return regressionPolynomial(data, x, y, { degree });\n default:\n return regressionLinear(data, x, y);\n }\n};\n\n/**\n * 获取系列标签的 spec 配置\n * @param position 显示位置\n * @param config 系列标签的样式配置\n * @returns\n */\nexport function getScatterRegressionLineConfig(\n type: 'linear' | 'logisitc' | 'lowess' | 'polynomial',\n config: Omit<ScatterRegressionLineSpec, 'visible' | 'type'>\n) {\n const { color, line, confidenceInterval, label } = config;\n return {\n type: 'component',\n componentType: REGRESSION_LINE,\n interactive: false,\n style: {\n data: (datum: any, ctx: any) => {\n const vchart = ctx.vchart;\n const chart = vchart.getChart();\n const series = chart.getAllSeries().filter((s: any) => s.type === SeriesTypeEnum.scatter) as ICartesianSeries[];\n const regressionData: RegressionLineData[] = [];\n\n // 必须存在散点图系列\n if (series && series.length) {\n series.forEach(s => {\n const start = s.getRegion().getLayoutStartPoint();\n const rect = s.getRegion().getLayoutRect();\n const yClamper = clamper(start.y, start.y + rect.height);\n const colorAttrOptions = s.getColorAttribute();\n const groups = s.getSeriesKeys();\n const data = s.getViewData().latestData;\n const fieldX = s.fieldX?.[0];\n const fieldY = s.fieldY?.[0];\n\n if (!fieldX || !fieldY || !data || data.length <= 2) {\n return;\n }\n\n groups.forEach(group => {\n const groupData = data.filter((d: Datum) => d[colorAttrOptions?.field] === group);\n\n if (!groupData.length) {\n return;\n }\n const { evaluateGrid, confidenceInterval } = getRegressionByType(\n type,\n groupData,\n (datum: Datum) => datum?.[fieldX],\n (datum: Datum) => datum?.[fieldY],\n config.polynomialDegree\n );\n const N = Math.max(3, Math.floor(groupData.length / 4));\n const lineData = evaluateGrid(N);\n const confidenceData = confidenceInterval(N);\n\n regressionData.push({\n color: color ?? colorAttrOptions?.scale?.scale(group),\n line: lineData.map((ld: Datum) => {\n const d = { [fieldX]: ld.x, [fieldY]: ld.y };\n return {\n x: s.dataToPositionX(d) + start.x,\n y: yClamper(\n type === 'logisitc' ? start.y + rect.height * (1 - ld.y) : s.dataToPositionY(d) + start.y\n )\n };\n }),\n area: confidenceData.map((c: Datum) => {\n const d = { [fieldX]: c.x, [fieldY]: c.lower };\n return {\n x: s.dataToPositionX(d) + start.x,\n y: yClamper(s.dataToPositionY(d) + start.y),\n y1: yClamper(s.dataToPositionY({ [fieldY]: c.upper }) + start.y)\n };\n })\n });\n });\n });\n }\n\n return regressionData;\n },\n line,\n confidenceInterval,\n label\n }\n };\n}\n\nexport function appendScatterRegressionLineConfig(\n chartSpec: ISpec,\n spec?: ScatterRegressionLineSpec | ScatterRegressionLineSpec[]\n) {\n if (!spec) {\n spec =\n get(chartSpec, REGRESSION_LINE) ??\n get(\n chartSpec.series?.find(s => s.type === SeriesTypeEnum.scatter),\n REGRESSION_LINE\n );\n }\n\n const specs = array(spec);\n\n specs.forEach((s: ScatterRegressionLineSpec) => {\n if (s.visible !== false) {\n if (!(chartSpec as any).customMark) {\n (chartSpec as any).customMark = [];\n }\n\n const { type, ...rest } = s;\n (chartSpec as any).customMark.push(getScatterRegressionLineConfig(type, rest));\n }\n });\n}\n"]}
@@ -0,0 +1,9 @@
1
+ import type { RegressionLineAttrs } from '../regression-line/type';
2
+ export interface ScatterRegressionLineAttrs extends RegressionLineAttrs {
3
+ type: 'linear' | 'logisitc' | 'lowess' | 'polynomial';
4
+ polynomialDegree?: number;
5
+ }
6
+ export interface ScatterRegressionLineSpec extends Partial<Pick<ScatterRegressionLineAttrs, 'type' | 'polynomialDegree' | 'line' | 'label' | 'confidenceInterval'>> {
7
+ visible?: boolean;
8
+ color?: string;
9
+ }
@@ -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":["../src/components/scatter-regression-line/type.ts"],"names":[],"mappings":"","file":"type.js","sourcesContent":["import type { RegressionLineAttrs } from '../regression-line/type';\n\nexport interface ScatterRegressionLineAttrs extends RegressionLineAttrs {\n type: 'linear' | 'logisitc' | 'lowess' | 'polynomial';\n /**\n * 多项式回归的阶数,仅当 type 为 polynomial 时有效\n */\n polynomialDegree?: number;\n}\n\nexport interface ScatterRegressionLineSpec\n extends Partial<\n Pick<ScatterRegressionLineAttrs, 'type' | 'polynomialDegree' | 'line' | 'label' | 'confidenceInterval'>\n > {\n /**\n * 是否显示回归线\n */\n visible?: boolean;\n /**\n * 主色,可以不设置,默认取散点图系列颜色\n */\n color?: string;\n}\n"]}
@@ -1,5 +1,5 @@
1
- import { AbstractComponent } from '@visactor/vrender-components';
2
- import { SeriesBreakAttrs } from './type';
1
+ import { AbstractComponent } from '@visactor/vchart';
2
+ import type { SeriesBreakAttrs } from './type';
3
3
  export declare class SeriesBreakComponent extends AbstractComponent<Required<SeriesBreakAttrs>> {
4
4
  name: string;
5
5
  protected render(): void;
@@ -14,7 +14,7 @@ Object.defineProperty(exports, "__esModule", {
14
14
  value: !0
15
15
  }), exports.registerSeriesBreak = exports.SeriesBreakComponent = void 0;
16
16
 
17
- const vrender_components_1 = require("@visactor/vrender-components"), vrender_core_1 = require("@visactor/vrender-core"), vutils_1 = require("@visactor/vutils"), constant_1 = require("./constant"), vchart_1 = require("@visactor/vchart");
17
+ const vchart_1 = require("@visactor/vchart"), vchart_2 = require("@visactor/vchart"), constant_1 = require("./constant"), vchart_3 = require("@visactor/vchart");
18
18
 
19
19
  function generateZigzagPath(start, end, size, angle, isVertical = !1) {
20
20
  const path = [], {x: startX, y: startY} = start, {x: endX, y: endY} = end, numZigzags = isVertical ? Math.floor((endY - startY) / (2 * size)) : Math.floor((endX - startX) / (2 * size)), angleRad = Math.PI / 180 * angle, deltaX = size * Math.cos(angleRad), deltaY = size * Math.sin(angleRad);
@@ -31,7 +31,7 @@ const checkOverlap = (prevData, newEntry) => {
31
31
  const {start: start, end: end} = newEntry, isVertical = start.x === end.x, equalDim = isVertical ? "x" : "y", diffDim = isVertical ? "y" : "x";
32
32
  let needAppend = !0;
33
33
  prevData.length && prevData.forEach((prevEntry => {
34
- if ((0, vutils_1.isNumberClose)(prevEntry.start[equalDim], start[equalDim])) {
34
+ if ((0, vchart_2.isNumberClose)(prevEntry.start[equalDim], start[equalDim])) {
35
35
  const minDim = Math.min(start[diffDim], end[diffDim]), maxDim = Math.max(start[diffDim], end[diffDim]), prevMinDim = Math.min(prevEntry.start[diffDim], prevEntry.end[diffDim]), prevMaxDim = Math.max(prevEntry.start[diffDim], prevEntry.end[diffDim]);
36
36
  if (!(maxDim < prevMinDim - 1e-6 || minDim > prevMaxDim + 1e-6)) return prevEntry.start[diffDim] = Math.min(prevMinDim, minDim),
37
37
  prevEntry.end[diffDim] = Math.max(prevMaxDim, maxDim), void (needAppend = !1);
@@ -39,14 +39,14 @@ const checkOverlap = (prevData, newEntry) => {
39
39
  })), needAppend && prevData.push(newEntry);
40
40
  };
41
41
 
42
- class SeriesBreakComponent extends vrender_components_1.AbstractComponent {
42
+ class SeriesBreakComponent extends vchart_1.AbstractComponent {
43
43
  constructor() {
44
44
  super(...arguments), this.name = constant_1.SERIES_BREAK;
45
45
  }
46
46
  render() {
47
47
  this.removeAllChild();
48
48
  const {data: data = []} = this.attribute;
49
- if ((0, vutils_1.isEmpty)(data)) return;
49
+ if ((0, vchart_2.isEmpty)(data)) return;
50
50
  const verticalData = [], horizontalData = [];
51
51
  data.forEach((breakData => {
52
52
  const {start: start, end: end} = breakData, isVertical = start.x === end.x;
@@ -54,7 +54,7 @@ class SeriesBreakComponent extends vrender_components_1.AbstractComponent {
54
54
  })), [ ...verticalData, ...horizontalData ].forEach(((breakData, id) => {
55
55
  var _a;
56
56
  const {start: start, end: end, size: size = 4, gap: gap = 5, style: style = {}} = breakData, rest = __rest(breakData, [ "start", "end", "size", "gap", "style" ]), breakGroup = (0,
57
- vrender_core_1.createGroup)({}), isVertical = start.x === end.x;
57
+ vchart_1.createGroup)({}), isVertical = start.x === end.x;
58
58
  let startPathStart, startPathEnd, endPathStart, endPathEnd;
59
59
  isVertical ? (startPathStart = {
60
60
  x: start.x - gap / 2,
@@ -82,27 +82,27 @@ class SeriesBreakComponent extends vrender_components_1.AbstractComponent {
82
82
  y: end.y + gap / 2
83
83
  });
84
84
  const startPath = generateZigzagPath(startPathStart, startPathEnd, size, isVertical ? 75 : 15, isVertical), centerPath = generateZigzagPath(start, end, size, isVertical ? 75 : 15, isVertical), endPath = generateZigzagPath(endPathStart, endPathEnd, size, isVertical ? 75 : 15, isVertical);
85
- breakGroup.add((0, vrender_core_1.createPath)(Object.assign(Object.assign({
85
+ breakGroup.add((0, vchart_1.createPath)(Object.assign(Object.assign({
86
86
  path: startPath,
87
87
  stroke: "#000",
88
88
  lineWidth: 1
89
89
  }, style), {
90
90
  pickable: !1,
91
91
  zIndex: 1
92
- }))), breakGroup.add((0, vrender_core_1.createPath)(Object.assign(Object.assign({
92
+ }))), breakGroup.add((0, vchart_1.createPath)(Object.assign(Object.assign({
93
93
  path: endPath,
94
94
  stroke: "#000",
95
95
  lineWidth: 1
96
96
  }, style), {
97
97
  pickable: !1,
98
98
  zIndex: 1
99
- }))), breakGroup.add((0, vrender_core_1.createPath)({
99
+ }))), breakGroup.add((0, vchart_1.createPath)({
100
100
  path: centerPath,
101
101
  stroke: "#fff",
102
102
  lineWidth: gap,
103
103
  pickable: !1,
104
104
  zIndex: 0
105
- })), breakGroup.name = "series-break", breakGroup.data = rest, (0, vutils_1.isValid)(rest.axisId) && (breakGroup.id = `${null !== (_a = rest.axisId) && void 0 !== _a ? _a : ""}_${id}`),
105
+ })), breakGroup.name = "series-break", breakGroup.data = rest, (0, vchart_2.isValid)(rest.axisId) && (breakGroup.id = `${null !== (_a = rest.axisId) && void 0 !== _a ? _a : ""}_${id}`),
106
106
  this.add(breakGroup);
107
107
  }));
108
108
  }
@@ -111,7 +111,7 @@ class SeriesBreakComponent extends vrender_components_1.AbstractComponent {
111
111
  exports.SeriesBreakComponent = SeriesBreakComponent;
112
112
 
113
113
  const registerSeriesBreak = () => {
114
- vchart_1.Factory.registerGraphicComponent("seriesBreak", (attrs => new SeriesBreakComponent(attrs)));
114
+ vchart_3.Factory.registerGraphicComponent("seriesBreak", (attrs => new SeriesBreakComponent(attrs)));
115
115
  };
116
116
 
117
117
  exports.registerSeriesBreak = registerSeriesBreak;
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/components/series-break/series-break.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAKA,qEAAwE;AAExE,yDAA2E;AAC3E,6CAAmE;AACnE,yCAA0C;AAC1C,6CAA2C;AAY3C,SAAS,kBAAkB,CAAC,KAAY,EAAE,GAAU,EAAE,IAAY,EAAE,KAAa,EAAE,UAAU,GAAG,KAAK;IACnG,MAAM,IAAI,GAAG,EAAE,CAAC;IAChB,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,GAAG,KAAK,CAAC;IACvC,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,IAAI,EAAE,GAAG,GAAG,CAAC;IAGjC,MAAM,UAAU,GAAG,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,GAAG,MAAM,CAAC,GAAG,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,GAAG,MAAM,CAAC,GAAG,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC;IAGpH,MAAM,QAAQ,GAAG,CAAC,IAAI,CAAC,EAAE,GAAG,GAAG,CAAC,GAAG,KAAK,CAAC;IACzC,MAAM,MAAM,GAAG,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IACzC,MAAM,MAAM,GAAG,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IAGzC,IAAI,CAAC,IAAI,CAAC,KAAK,MAAM,IAAI,MAAM,EAAE,CAAC,CAAC;IAEnC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,UAAU,EAAE,CAAC,EAAE,EAAE;QACpC,MAAM,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,GAAG,IAAI,GAAG,CAAC,CAAC;QACzF,MAAM,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,GAAG,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,MAAM,GAAG,MAAM,CAAC;QAC/F,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;KAC1B;IAGD,IAAI,CAAC,IAAI,CAAC,KAAK,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,IAAI,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC;IAE3E,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AACxB,CAAC;AAED,MAAM,YAAY,GAAG,CAAC,QAA2B,EAAE,QAAyB,EAAE,EAAE;IAC9E,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,QAAQ,CAAC;IAChC,MAAM,UAAU,GAAG,KAAK,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;IACrC,MAAM,QAAQ,GAAG,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;IACxC,MAAM,OAAO,GAAG,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;IACvC,IAAI,UAAU,GAAG,IAAI,CAAC;IACtB,MAAM,GAAG,GAAG,IAAI,CAAC;IAEjB,IAAI,QAAQ,CAAC,MAAM,EAAE;QACnB,QAAQ,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;YAC3B,IAAI,IAAA,sBAAa,EAAC,SAAS,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC,EAAE;gBAE7D,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC;gBACtD,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC;gBACtD,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,SAAS,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC;gBAC9E,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,SAAS,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC;gBAC9E,MAAM,UAAU,GAAG,CAAC,CAAC,MAAM,GAAG,UAAU,GAAG,GAAG,IAAI,MAAM,GAAG,UAAU,GAAG,GAAG,CAAC,CAAC;gBAE7E,IAAI,UAAU,EAAE;oBACd,SAAS,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;oBACxD,SAAS,CAAC,GAAG,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;oBACtD,UAAU,GAAG,KAAK,CAAC;oBACnB,OAAO;iBACR;aACF;QACH,CAAC,CAAC,CAAC;KACJ;IAED,IAAI,UAAU,EAAE;QACd,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;KACzB;AACH,CAAC,CAAC;AAEF,MAAa,oBAAqB,SAAQ,sCAA6C;IAAvF;;QACE,SAAI,GAAG,uBAAY,CAAC;IA0GtB,CAAC;IAzGW,MAAM;QACd,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,MAAM,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,IAAI,CAAC,SAA6B,CAAC;QACzD,IAAI,IAAA,gBAAO,EAAC,IAAI,CAAC,EAAE;YACjB,OAAO;SACR;QAED,MAAM,YAAY,GAAsB,EAAE,CAAC;QAC3C,MAAM,cAAc,GAAsB,EAAE,CAAC;QAE7C,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;YACvB,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,SAAS,CAAC;YACjC,MAAM,UAAU,GAAG,KAAK,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;YAErC,YAAY,CAAC,UAAU,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,cAAc,EAAE,SAAS,CAAC,CAAC;QACtE,CAAC,CAAC,CAAC;QAEH,CAAC,GAAG,YAAY,EAAE,GAAG,cAAc,CAAC,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,EAAE,EAAE,EAAE;;YAC7D,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,IAAI,GAAG,CAAC,EAAE,GAAG,GAAG,CAAC,EAAE,KAAK,GAAG,EAAE,KAAc,SAAS,EAAlB,IAAI,UAAK,SAAS,EAAlE,wCAAsD,CAAY,CAAC;YACzE,MAAM,UAAU,GAAG,IAAA,0BAAW,EAAC,EAAE,CAAC,CAAC;YACnC,MAAM,UAAU,GAAG,KAAK,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;YAErC,IAAI,cAAc,CAAC;YACnB,IAAI,YAAY,CAAC;YACjB,IAAI,YAAY,CAAC;YACjB,IAAI,UAAU,CAAC;YACf,IAAI,UAAU,EAAE;gBACd,cAAc,GAAG;oBACf,CAAC,EAAE,KAAK,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC;oBACpB,CAAC,EAAE,KAAK,CAAC,CAAC;iBACX,CAAC;gBACF,YAAY,GAAG;oBACb,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC;oBAClB,CAAC,EAAE,GAAG,CAAC,CAAC;iBACT,CAAC;gBACF,YAAY,GAAG;oBACb,CAAC,EAAE,KAAK,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC;oBACpB,CAAC,EAAE,KAAK,CAAC,CAAC;iBACX,CAAC;gBACF,UAAU,GAAG;oBACX,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC;oBAClB,CAAC,EAAE,GAAG,CAAC,CAAC;iBACT,CAAC;aACH;iBAAM;gBACL,cAAc,GAAG;oBACf,CAAC,EAAE,KAAK,CAAC,CAAC;oBACV,CAAC,EAAE,KAAK,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC;iBACrB,CAAC;gBACF,YAAY,GAAG;oBACb,CAAC,EAAE,GAAG,CAAC,CAAC;oBACR,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC;iBACnB,CAAC;gBACF,YAAY,GAAG;oBACb,CAAC,EAAE,KAAK,CAAC,CAAC;oBACV,CAAC,EAAE,KAAK,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC;iBACrB,CAAC;gBACF,UAAU,GAAG;oBACX,CAAC,EAAE,GAAG,CAAC,CAAC;oBACR,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC;iBACnB,CAAC;aACH;YAED,MAAM,SAAS,GAAG,kBAAkB,CAAC,cAAc,EAAE,YAAY,EAAE,IAAI,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,UAAU,CAAC,CAAC;YAC3G,MAAM,UAAU,GAAG,kBAAkB,CAAC,KAAK,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,UAAU,CAAC,CAAC;YAC1F,MAAM,OAAO,GAAG,kBAAkB,CAAC,YAAY,EAAE,UAAU,EAAE,IAAI,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,UAAU,CAAC,CAAC;YACrG,UAAU,CAAC,GAAG,CACZ,IAAA,yBAAU,gCACR,IAAI,EAAE,SAAS,EACf,MAAM,EAAE,MAAM,EACd,SAAS,EAAE,CAAC,IACT,KAAK,KACR,QAAQ,EAAE,KAAK,EACf,MAAM,EAAE,CAAC,IACT,CACH,CAAC;YACF,UAAU,CAAC,GAAG,CACZ,IAAA,yBAAU,gCACR,IAAI,EAAE,OAAO,EACb,MAAM,EAAE,MAAM,EACd,SAAS,EAAE,CAAC,IACT,KAAK,KACR,QAAQ,EAAE,KAAK,EACf,MAAM,EAAE,CAAC,IACT,CACH,CAAC;YACF,UAAU,CAAC,GAAG,CACZ,IAAA,yBAAU,EAAC;gBACT,IAAI,EAAE,UAAU;gBAChB,MAAM,EAAE,MAAM;gBACd,SAAS,EAAE,GAAG;gBACd,QAAQ,EAAE,KAAK;gBACf,MAAM,EAAE,CAAC;aACV,CAAC,CACH,CAAC;YAEF,UAAU,CAAC,IAAI,GAAG,cAAc,CAAC;YACjC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC;YAEvB,IAAI,IAAA,gBAAO,EAAC,IAAI,CAAC,MAAM,CAAC,EAAE;gBACxB,UAAU,CAAC,EAAE,GAAG,GAAG,MAAA,IAAI,CAAC,MAAM,mCAAI,EAAE,IAAI,EAAE,EAAE,CAAC;aAC9C;YAED,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QACvB,CAAC,CAAC,CAAC;IACL,CAAC;CACF;AA3GD,oDA2GC;AAEM,MAAM,mBAAmB,GAAG,GAAG,EAAE;IACtC,gBAAO,CAAC,wBAAwB,CAC9B,aAAa,EACb,CAAC,KAAiC,EAAE,EAAE,CAAC,IAAI,oBAAoB,CAAC,KAAK,CAAwB,CAC9F,CAAC;AACJ,CAAC,CAAC;AALW,QAAA,mBAAmB,uBAK9B","file":"series-break.js","sourcesContent":["/**\n * @description vchart 自定义组件,用于实现 bar、area、line 这些图形的截断图形生成\n * @author zhangweixing\n */\n\nimport { AbstractComponent, Point } from '@visactor/vrender-components';\nimport { SeriesBreakAttrs, SeriesBreakData } from './type';\nimport { createGroup, createPath, IGraphic } from '@visactor/vrender-core';\nimport { isEmpty, isNumberClose, isValid } from '@visactor/vutils';\nimport { SERIES_BREAK } from './constant';\nimport { Factory } from '@visactor/vchart';\n\n/**\n * 求锯齿的路径(一个锯齿由向上和向下的两个线段组成)\n * @param start 锯齿的起始点\n * @param end 锯齿的结束点\n * @param size 锯齿的高度\n * @param angle 锯齿的角度\n * @param gap 两条锯齿的间距\n * @param isVertical 是否垂直\n * @returns\n */\nfunction generateZigzagPath(start: Point, end: Point, size: number, angle: number, isVertical = false) {\n const path = [];\n const { x: startX, y: startY } = start;\n const { x: endX, y: endY } = end;\n\n // 计算锯齿的数量\n const numZigzags = isVertical ? Math.floor((endY - startY) / (size * 2)) : Math.floor((endX - startX) / (size * 2));\n\n // 计算倾斜角度的增量\n const angleRad = (Math.PI / 180) * angle; // 转换为弧度\n const deltaX = size * Math.cos(angleRad);\n const deltaY = size * Math.sin(angleRad);\n\n // 添加第一条锯齿的起始点\n path.push(`M ${startX} ${startY}`);\n\n for (let i = 0; i <= numZigzags; i++) {\n const x = isVertical ? startX + (i % 2 === 0 ? deltaX : -deltaX) : startX + i * size * 2;\n const y = isVertical ? startY + i * size * 2 : i % 2 === 0 ? startY - deltaY : startY + deltaY;\n path.push(`L ${x} ${y}`);\n }\n\n // 添加第一条锯齿的结束点\n path.push(`L ${isVertical ? startX : endX} ${isVertical ? endY : startY}`);\n\n return path.join(' ');\n}\n\nconst checkOverlap = (prevData: SeriesBreakData[], newEntry: SeriesBreakData) => {\n const { start, end } = newEntry;\n const isVertical = start.x === end.x;\n const equalDim = isVertical ? 'x' : 'y';\n const diffDim = isVertical ? 'y' : 'x';\n let needAppend = true;\n const EPS = 1e-6;\n\n if (prevData.length) {\n prevData.forEach(prevEntry => {\n if (isNumberClose(prevEntry.start[equalDim], start[equalDim])) {\n // 判断是否有重叠,有重叠取交集\n const minDim = Math.min(start[diffDim], end[diffDim]);\n const maxDim = Math.max(start[diffDim], end[diffDim]);\n const prevMinDim = Math.min(prevEntry.start[diffDim], prevEntry.end[diffDim]);\n const prevMaxDim = Math.max(prevEntry.start[diffDim], prevEntry.end[diffDim]);\n const hasOverlap = !(maxDim < prevMinDim - EPS || minDim > prevMaxDim + EPS);\n\n if (hasOverlap) {\n prevEntry.start[diffDim] = Math.min(prevMinDim, minDim);\n prevEntry.end[diffDim] = Math.max(prevMaxDim, maxDim);\n needAppend = false;\n return;\n }\n }\n });\n }\n\n if (needAppend) {\n prevData.push(newEntry);\n }\n};\n\nexport class SeriesBreakComponent extends AbstractComponent<Required<SeriesBreakAttrs>> {\n name = SERIES_BREAK;\n protected render() {\n this.removeAllChild();\n const { data = [] } = this.attribute as SeriesBreakAttrs;\n if (isEmpty(data)) {\n return;\n }\n // 去除重叠数据\n const verticalData: SeriesBreakData[] = [];\n const horizontalData: SeriesBreakData[] = [];\n\n data.forEach(breakData => {\n const { start, end } = breakData;\n const isVertical = start.x === end.x;\n\n checkOverlap(isVertical ? verticalData : horizontalData, breakData);\n });\n\n [...verticalData, ...horizontalData].forEach((breakData, id) => {\n const { start, end, size = 4, gap = 5, style = {}, ...rest } = breakData;\n const breakGroup = createGroup({});\n const isVertical = start.x === end.x;\n\n let startPathStart;\n let startPathEnd;\n let endPathStart;\n let endPathEnd;\n if (isVertical) {\n startPathStart = {\n x: start.x - gap / 2,\n y: start.y\n };\n startPathEnd = {\n x: end.x - gap / 2,\n y: end.y\n };\n endPathStart = {\n x: start.x + gap / 2,\n y: start.y\n };\n endPathEnd = {\n x: end.x + gap / 2,\n y: end.y\n };\n } else {\n startPathStart = {\n x: start.x,\n y: start.y - gap / 2\n };\n startPathEnd = {\n x: end.x,\n y: end.y - gap / 2\n };\n endPathStart = {\n x: start.x,\n y: start.y + gap / 2\n };\n endPathEnd = {\n x: end.x,\n y: end.y + gap / 2\n };\n }\n\n const startPath = generateZigzagPath(startPathStart, startPathEnd, size, isVertical ? 75 : 15, isVertical);\n const centerPath = generateZigzagPath(start, end, size, isVertical ? 75 : 15, isVertical);\n const endPath = generateZigzagPath(endPathStart, endPathEnd, size, isVertical ? 75 : 15, isVertical);\n breakGroup.add(\n createPath({\n path: startPath,\n stroke: '#000',\n lineWidth: 1,\n ...style,\n pickable: false,\n zIndex: 1\n })\n );\n breakGroup.add(\n createPath({\n path: endPath,\n stroke: '#000',\n lineWidth: 1,\n ...style,\n pickable: false,\n zIndex: 1\n })\n );\n breakGroup.add(\n createPath({\n path: centerPath,\n stroke: '#fff',\n lineWidth: gap,\n pickable: false,\n zIndex: 0\n })\n );\n\n breakGroup.name = 'series-break';\n breakGroup.data = rest;\n\n if (isValid(rest.axisId)) {\n breakGroup.id = `${rest.axisId ?? ''}_${id}`;\n }\n\n this.add(breakGroup);\n });\n }\n}\n\nexport const registerSeriesBreak = () => {\n Factory.registerGraphicComponent(\n 'seriesBreak',\n (attrs: Required<SeriesBreakAttrs>) => new SeriesBreakComponent(attrs) as unknown as IGraphic\n );\n};\n"]}
1
+ {"version":3,"sources":["../src/components/series-break/series-break.ts"],"names":[],"mappings":"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","file":"series-break.js","sourcesContent":["/**\n * @description vchart 自定义组件,用于实现 bar、area、line 这些图形的截断图形生成\n * @author zhangweixing\n */\n\nimport type { Point, IGraphic } from '@visactor/vchart';\nimport { AbstractComponent, createGroup, createPath } from '@visactor/vchart';\nimport type { SeriesBreakAttrs, SeriesBreakData } from './type';\nimport { isEmpty, isNumberClose, isValid } from '@visactor/vchart';\nimport { SERIES_BREAK } from './constant';\nimport { Factory } from '@visactor/vchart';\n\n/**\n * 求锯齿的路径(一个锯齿由向上和向下的两个线段组成)\n * @param start 锯齿的起始点\n * @param end 锯齿的结束点\n * @param size 锯齿的高度\n * @param angle 锯齿的角度\n * @param gap 两条锯齿的间距\n * @param isVertical 是否垂直\n * @returns\n */\nfunction generateZigzagPath(start: Point, end: Point, size: number, angle: number, isVertical = false) {\n const path = [];\n const { x: startX, y: startY } = start;\n const { x: endX, y: endY } = end;\n\n // 计算锯齿的数量\n const numZigzags = isVertical ? Math.floor((endY - startY) / (size * 2)) : Math.floor((endX - startX) / (size * 2));\n\n // 计算倾斜角度的增量\n const angleRad = (Math.PI / 180) * angle; // 转换为弧度\n const deltaX = size * Math.cos(angleRad);\n const deltaY = size * Math.sin(angleRad);\n\n // 添加第一条锯齿的起始点\n path.push(`M ${startX} ${startY}`);\n\n for (let i = 0; i <= numZigzags; i++) {\n const x = isVertical ? startX + (i % 2 === 0 ? deltaX : -deltaX) : startX + i * size * 2;\n const y = isVertical ? startY + i * size * 2 : i % 2 === 0 ? startY - deltaY : startY + deltaY;\n path.push(`L ${x} ${y}`);\n }\n\n // 添加第一条锯齿的结束点\n path.push(`L ${isVertical ? startX : endX} ${isVertical ? endY : startY}`);\n\n return path.join(' ');\n}\n\nconst checkOverlap = (prevData: SeriesBreakData[], newEntry: SeriesBreakData) => {\n const { start, end } = newEntry;\n const isVertical = start.x === end.x;\n const equalDim = isVertical ? 'x' : 'y';\n const diffDim = isVertical ? 'y' : 'x';\n let needAppend = true;\n const EPS = 1e-6;\n\n if (prevData.length) {\n prevData.forEach(prevEntry => {\n if (isNumberClose(prevEntry.start[equalDim], start[equalDim])) {\n // 判断是否有重叠,有重叠取交集\n const minDim = Math.min(start[diffDim], end[diffDim]);\n const maxDim = Math.max(start[diffDim], end[diffDim]);\n const prevMinDim = Math.min(prevEntry.start[diffDim], prevEntry.end[diffDim]);\n const prevMaxDim = Math.max(prevEntry.start[diffDim], prevEntry.end[diffDim]);\n const hasOverlap = !(maxDim < prevMinDim - EPS || minDim > prevMaxDim + EPS);\n\n if (hasOverlap) {\n prevEntry.start[diffDim] = Math.min(prevMinDim, minDim);\n prevEntry.end[diffDim] = Math.max(prevMaxDim, maxDim);\n needAppend = false;\n return;\n }\n }\n });\n }\n\n if (needAppend) {\n prevData.push(newEntry);\n }\n};\n\nexport class SeriesBreakComponent extends AbstractComponent<Required<SeriesBreakAttrs>> {\n name = SERIES_BREAK;\n protected render() {\n this.removeAllChild();\n const { data = [] } = this.attribute as SeriesBreakAttrs;\n if (isEmpty(data)) {\n return;\n }\n // 去除重叠数据\n const verticalData: SeriesBreakData[] = [];\n const horizontalData: SeriesBreakData[] = [];\n\n data.forEach(breakData => {\n const { start, end } = breakData;\n const isVertical = start.x === end.x;\n\n checkOverlap(isVertical ? verticalData : horizontalData, breakData);\n });\n\n [...verticalData, ...horizontalData].forEach((breakData, id) => {\n const { start, end, size = 4, gap = 5, style = {}, ...rest } = breakData;\n const breakGroup = createGroup({});\n const isVertical = start.x === end.x;\n\n let startPathStart;\n let startPathEnd;\n let endPathStart;\n let endPathEnd;\n if (isVertical) {\n startPathStart = {\n x: start.x - gap / 2,\n y: start.y\n };\n startPathEnd = {\n x: end.x - gap / 2,\n y: end.y\n };\n endPathStart = {\n x: start.x + gap / 2,\n y: start.y\n };\n endPathEnd = {\n x: end.x + gap / 2,\n y: end.y\n };\n } else {\n startPathStart = {\n x: start.x,\n y: start.y - gap / 2\n };\n startPathEnd = {\n x: end.x,\n y: end.y - gap / 2\n };\n endPathStart = {\n x: start.x,\n y: start.y + gap / 2\n };\n endPathEnd = {\n x: end.x,\n y: end.y + gap / 2\n };\n }\n\n const startPath = generateZigzagPath(startPathStart, startPathEnd, size, isVertical ? 75 : 15, isVertical);\n const centerPath = generateZigzagPath(start, end, size, isVertical ? 75 : 15, isVertical);\n const endPath = generateZigzagPath(endPathStart, endPathEnd, size, isVertical ? 75 : 15, isVertical);\n breakGroup.add(\n createPath({\n path: startPath,\n stroke: '#000',\n lineWidth: 1,\n ...style,\n pickable: false,\n zIndex: 1\n })\n );\n breakGroup.add(\n createPath({\n path: endPath,\n stroke: '#000',\n lineWidth: 1,\n ...style,\n pickable: false,\n zIndex: 1\n })\n );\n breakGroup.add(\n createPath({\n path: centerPath,\n stroke: '#fff',\n lineWidth: gap,\n pickable: false,\n zIndex: 0\n })\n );\n\n breakGroup.name = 'series-break';\n breakGroup.data = rest;\n\n if (isValid(rest.axisId)) {\n breakGroup.id = `${rest.axisId ?? ''}_${id}`;\n }\n\n this.add(breakGroup);\n });\n }\n}\n\nexport const registerSeriesBreak = () => {\n Factory.registerGraphicComponent(\n 'seriesBreak',\n (attrs: Required<SeriesBreakAttrs>) => new SeriesBreakComponent(attrs) as unknown as IGraphic\n );\n};\n"]}
@@ -1,5 +1,4 @@
1
- import { Point } from '@visactor/vrender-components';
2
- import { IGroupGraphicAttribute, ILineGraphicAttribute } from '@visactor/vrender-core';
1
+ import type { IGroupGraphicAttribute, ILineGraphicAttribute, Point } from '@visactor/vchart';
3
2
  export type SeriesBreakData = {
4
3
  start: Point;
5
4
  end: Point;
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/components/series-break/type.ts"],"names":[],"mappings":"","file":"type.js","sourcesContent":["import { Point } from '@visactor/vrender-components';\nimport { IGroupGraphicAttribute, ILineGraphicAttribute } from '@visactor/vrender-core';\n\nexport type SeriesBreakData = {\n /**\n * 起始点\n */\n start: Point;\n /**\n * 结束点\n */\n end: Point;\n /**\n * 锯齿的大小\n * @default 4\n */\n size?: number;\n /**\n * 两条平行的锯齿的间距\n * @default 5\n */\n gap?: number;\n /**\n * 截断样式\n */\n style?: ILineGraphicAttribute;\n /**\n * 轴截断关联的坐标轴 id\n */\n axisId: string;\n /**\n * 当前轴截断的数据范围\n */\n data: [number, number];\n};\n\nexport interface SeriesBreakAttrs extends IGroupGraphicAttribute {\n data: SeriesBreakData[];\n}\n"]}
1
+ {"version":3,"sources":["../src/components/series-break/type.ts"],"names":[],"mappings":"","file":"type.js","sourcesContent":["import type { IGroupGraphicAttribute, ILineGraphicAttribute, Point } from '@visactor/vchart';\n\nexport type SeriesBreakData = {\n /**\n * 起始点\n */\n start: Point;\n /**\n * 结束点\n */\n end: Point;\n /**\n * 锯齿的大小\n * @default 4\n */\n size?: number;\n /**\n * 两条平行的锯齿的间距\n * @default 5\n */\n gap?: number;\n /**\n * 截断样式\n */\n style?: ILineGraphicAttribute;\n /**\n * 轴截断关联的坐标轴 id\n */\n axisId: string;\n /**\n * 当前轴截断的数据范围\n */\n data: [number, number];\n};\n\nexport interface SeriesBreakAttrs extends IGroupGraphicAttribute {\n data: SeriesBreakData[];\n}\n"]}
@@ -4,7 +4,7 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: !0
5
5
  }), exports.appendSeriesBreakConfig = exports.getSeriesBreakConfig = void 0;
6
6
 
7
- const vutils_1 = require("@visactor/vutils"), element_1 = require("../../utils/element"), math_1 = require("../../utils/math"), constant_1 = require("./constant"), barOffset = 2, lineOffset = 10, areaOffset = 0;
7
+ const vchart_1 = require("@visactor/vchart"), element_1 = require("../../utils/element"), math_1 = require("../../utils/math"), constant_1 = require("./constant"), barOffset = 2, lineOffset = 10, areaOffset = 0;
8
8
 
9
9
  function getSeriesBreakConfig(axesSpec, axesIndex) {
10
10
  return {
@@ -17,12 +17,12 @@ function getSeriesBreakConfig(axesSpec, axesIndex) {
17
17
  const seriesBreakData = [], chart = ctx.vchart.getChart(), isHorizontal = "horizontal" === chart.getAllSeries()[0].direction;
18
18
  return axesSpec.forEach(((spec, index) => {
19
19
  var _a, _b;
20
- const axisId = spec.id, axisModel = (0, vutils_1.isValid)(axisId) ? chart.getComponentByUserId(axisId) : axesIndex && (0,
21
- vutils_1.isValid)(axesIndex[index]) ? chart.getComponentByIndex("axes", axesIndex[index]) : null === (_a = chart.getComponentsByKey("axes").filter((axis => axis.getSpec().breaks === spec.breaks))) || void 0 === _a ? void 0 : _a[0];
20
+ const axisId = spec.id, axisModel = (0, vchart_1.isValid)(axisId) ? chart.getComponentByUserId(axisId) : axesIndex && (0,
21
+ vchart_1.isValid)(axesIndex[index]) ? chart.getComponentByIndex("axes", axesIndex[index]) : null === (_a = chart.getComponentsByKey("axes").filter((axis => axis.getSpec().breaks === spec.breaks))) || void 0 === _a ? void 0 : _a[0];
22
22
  if (!axisModel) return;
23
23
  const parsedAxisId = null != axisId ? axisId : `${axisModel.type}-${axisModel.id}`, regionBounds = (0,
24
24
  element_1.getAllRegionBounds)(axisModel.getRegions());
25
- (0, vutils_1.array)(null === (_b = axisModel._break) || void 0 === _b ? void 0 : _b.breaks).forEach((breakConfig => {
25
+ (0, vchart_1.array)(null === (_b = axisModel._break) || void 0 === _b ? void 0 : _b.breaks).forEach((breakConfig => {
26
26
  const {range: range, breakSymbol: breakSymbol, gap: gap = 5} = breakConfig, pos1 = axisModel.valueToPosition(range[0]), pos2 = axisModel.valueToPosition(range[1]), posY = (pos1 + pos2) / 2 + (isHorizontal ? regionBounds.x1 : regionBounds.y1);
27
27
  chart.getAllSeries().forEach((s => {
28
28
  if ("bar" === s.type || "waterfall" === s.type) {
@@ -170,8 +170,8 @@ function getSeriesBreakConfig(axesSpec, axesIndex) {
170
170
  function getIntersectionsFromLineAndPolyline(line, points) {
171
171
  const intersections = [];
172
172
  for (let index = 1; index < points.length; index++) {
173
- const intersection = (0, vutils_1.getIntersectPoint)([ line.start.x, line.start.y ], [ line.end.x, line.end.y ], [ points[index].x, points[index].y ], [ points[index - 1].x, points[index - 1].y ]);
174
- intersection && !intersections.find((point => (0, math_1.isNumberEqual)(vutils_1.PointService.distancePP({
173
+ const intersection = (0, vchart_1.getIntersectPoint)([ line.start.x, line.start.y ], [ line.end.x, line.end.y ], [ points[index].x, points[index].y ], [ points[index - 1].x, points[index - 1].y ]);
174
+ intersection && !intersections.find((point => (0, math_1.isNumberEqual)(vchart_1.PointService.distancePP({
175
175
  x: point[0],
176
176
  y: point[1]
177
177
  }, {
@@ -237,7 +237,7 @@ const appendSeriesBreakConfig = rawSpec => {
237
237
  var _a;
238
238
  if (null === (_a = rawSpec.axes) || void 0 === _a ? void 0 : _a.length) {
239
239
  const breakedAxes = rawSpec.axes.filter((axis => axis.breaks && axis.breaks.length && !1 !== axis.visible));
240
- if (breakedAxes.length) return rawSpec.customMark = (0, vutils_1.array)(rawSpec.customMark).filter((obj => obj.componentType !== constant_1.SERIES_BREAK)),
240
+ if (breakedAxes.length) return rawSpec.customMark = (0, vchart_1.array)(rawSpec.customMark).filter((obj => obj.componentType !== constant_1.SERIES_BREAK)),
241
241
  rawSpec.customMark.push(getSeriesBreakConfig(breakedAxes, breakedAxes.map((axisSpec => rawSpec.axes.indexOf(axisSpec))))),
242
242
  !0;
243
243
  }