@visactor/vchart-extension 1.12.18 → 1.12.19

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 (177) hide show
  1. package/build/index.js +10244 -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/components/bar-link/bar-link.d.ts +7 -0
  31. package/cjs/components/bar-link/bar-link.js +87 -0
  32. package/cjs/components/bar-link/bar-link.js.map +1 -0
  33. package/cjs/components/bar-link/constant.d.ts +1 -0
  34. package/cjs/components/bar-link/constant.js +6 -0
  35. package/cjs/components/bar-link/constant.js.map +1 -0
  36. package/cjs/components/bar-link/index.d.ts +4 -0
  37. package/cjs/components/bar-link/index.js +48 -0
  38. package/cjs/components/bar-link/index.js.map +1 -0
  39. package/cjs/components/bar-link/type.d.ts +27 -0
  40. package/cjs/components/bar-link/type.js +6 -0
  41. package/cjs/components/bar-link/type.js.map +1 -0
  42. package/cjs/components/bar-link/util.d.ts +22 -0
  43. package/cjs/components/bar-link/util.js +183 -0
  44. package/cjs/components/bar-link/util.js.map +1 -0
  45. package/cjs/components/series-break/constant.d.ts +1 -0
  46. package/cjs/components/series-break/constant.js +6 -0
  47. package/cjs/components/series-break/constant.js.map +1 -0
  48. package/cjs/components/series-break/index.d.ts +4 -0
  49. package/cjs/components/series-break/index.js +49 -0
  50. package/cjs/components/series-break/index.js.map +1 -0
  51. package/cjs/components/series-break/series-break.d.ts +7 -0
  52. package/cjs/components/series-break/series-break.js +118 -0
  53. package/cjs/components/series-break/series-break.js.map +1 -0
  54. package/cjs/components/series-break/type.d.ts +14 -0
  55. package/cjs/components/series-break/type.js +6 -0
  56. package/cjs/components/series-break/type.js.map +1 -0
  57. package/cjs/components/series-break/util.d.ts +13 -0
  58. package/cjs/components/series-break/util.js +248 -0
  59. package/cjs/components/series-break/util.js.map +1 -0
  60. package/cjs/components/series-label/constant.d.ts +1 -0
  61. package/cjs/components/series-label/constant.js +6 -0
  62. package/cjs/components/series-label/constant.js.map +1 -0
  63. package/cjs/components/series-label/index.d.ts +3 -0
  64. package/cjs/components/series-label/index.js +49 -0
  65. package/cjs/components/series-label/index.js.map +1 -0
  66. package/cjs/components/series-label/series-label.d.ts +7 -0
  67. package/cjs/components/series-label/series-label.js +114 -0
  68. package/cjs/components/series-label/series-label.js.map +1 -0
  69. package/cjs/components/series-label/type.d.ts +41 -0
  70. package/cjs/components/series-label/type.js +6 -0
  71. package/cjs/components/series-label/type.js.map +1 -0
  72. package/cjs/components/series-label/util.d.ts +33 -0
  73. package/cjs/components/series-label/util.js +152 -0
  74. package/cjs/components/series-label/util.js.map +1 -0
  75. package/cjs/index.d.ts +5 -0
  76. package/cjs/index.js +22 -0
  77. package/cjs/index.js.map +1 -0
  78. package/cjs/type/index.d.ts +1 -0
  79. package/cjs/type/index.js +21 -0
  80. package/cjs/type/index.js.map +1 -0
  81. package/cjs/type/type.d.ts +8 -0
  82. package/cjs/type/type.js +6 -0
  83. package/cjs/type/type.js.map +1 -0
  84. package/cjs/utils/element.d.ts +7 -0
  85. package/cjs/utils/element.js +21 -0
  86. package/cjs/utils/element.js.map +1 -0
  87. package/cjs/utils/math.d.ts +1 -0
  88. package/cjs/utils/math.js +10 -0
  89. package/cjs/utils/math.js.map +1 -0
  90. package/esm/charts/conversion-funnel/arrow-data-transform.d.ts +24 -0
  91. package/esm/charts/conversion-funnel/arrow-data-transform.js +94 -0
  92. package/esm/charts/conversion-funnel/arrow-data-transform.js.map +1 -0
  93. package/esm/charts/conversion-funnel/conversion-funnel-transformer.d.ts +7 -0
  94. package/esm/charts/conversion-funnel/conversion-funnel-transformer.js +192 -0
  95. package/esm/charts/conversion-funnel/conversion-funnel-transformer.js.map +1 -0
  96. package/esm/charts/conversion-funnel/conversion-funnel.d.ts +40 -0
  97. package/esm/charts/conversion-funnel/conversion-funnel.js +81 -0
  98. package/esm/charts/conversion-funnel/conversion-funnel.js.map +1 -0
  99. package/esm/charts/conversion-funnel/index.d.ts +2 -0
  100. package/esm/charts/conversion-funnel/index.js +4 -0
  101. package/esm/charts/conversion-funnel/index.js.map +1 -0
  102. package/esm/charts/conversion-funnel/interface.d.ts +35 -0
  103. package/esm/charts/conversion-funnel/interface.js +2 -0
  104. package/esm/charts/conversion-funnel/interface.js.map +1 -0
  105. package/esm/charts/conversion-funnel/util.d.ts +3 -0
  106. package/esm/charts/conversion-funnel/util.js +10 -0
  107. package/esm/charts/conversion-funnel/util.js.map +1 -0
  108. package/esm/charts/ranking-bar/interface.d.ts +45 -0
  109. package/esm/charts/ranking-bar/interface.js +2 -0
  110. package/esm/charts/ranking-bar/interface.js.map +1 -0
  111. package/esm/charts/ranking-bar/ranking-bar-transformer.d.ts +10 -0
  112. package/esm/charts/ranking-bar/ranking-bar-transformer.js +285 -0
  113. package/esm/charts/ranking-bar/ranking-bar-transformer.js.map +1 -0
  114. package/esm/charts/ranking-bar/ranking-bar.d.ts +16 -0
  115. package/esm/charts/ranking-bar/ranking-bar.js +27 -0
  116. package/esm/charts/ranking-bar/ranking-bar.js.map +1 -0
  117. package/esm/components/bar-link/bar-link.d.ts +7 -0
  118. package/esm/components/bar-link/bar-link.js +85 -0
  119. package/esm/components/bar-link/bar-link.js.map +1 -0
  120. package/esm/components/bar-link/constant.d.ts +1 -0
  121. package/esm/components/bar-link/constant.js +2 -0
  122. package/esm/components/bar-link/constant.js.map +1 -0
  123. package/esm/components/bar-link/index.d.ts +4 -0
  124. package/esm/components/bar-link/index.js +7 -0
  125. package/esm/components/bar-link/index.js.map +1 -0
  126. package/esm/components/bar-link/type.d.ts +27 -0
  127. package/esm/components/bar-link/type.js +2 -0
  128. package/esm/components/bar-link/type.js.map +1 -0
  129. package/esm/components/bar-link/util.d.ts +22 -0
  130. package/esm/components/bar-link/util.js +178 -0
  131. package/esm/components/bar-link/util.js.map +1 -0
  132. package/esm/components/series-break/constant.d.ts +1 -0
  133. package/esm/components/series-break/constant.js +2 -0
  134. package/esm/components/series-break/constant.js.map +1 -0
  135. package/esm/components/series-break/index.d.ts +4 -0
  136. package/esm/components/series-break/index.js +8 -0
  137. package/esm/components/series-break/index.js.map +1 -0
  138. package/esm/components/series-break/series-break.d.ts +7 -0
  139. package/esm/components/series-break/series-break.js +115 -0
  140. package/esm/components/series-break/series-break.js.map +1 -0
  141. package/esm/components/series-break/type.d.ts +14 -0
  142. package/esm/components/series-break/type.js +2 -0
  143. package/esm/components/series-break/type.js.map +1 -0
  144. package/esm/components/series-break/util.d.ts +13 -0
  145. package/esm/components/series-break/util.js +244 -0
  146. package/esm/components/series-break/util.js.map +1 -0
  147. package/esm/components/series-label/constant.d.ts +1 -0
  148. package/esm/components/series-label/constant.js +2 -0
  149. package/esm/components/series-label/constant.js.map +1 -0
  150. package/esm/components/series-label/index.d.ts +3 -0
  151. package/esm/components/series-label/index.js +6 -0
  152. package/esm/components/series-label/index.js.map +1 -0
  153. package/esm/components/series-label/series-label.d.ts +7 -0
  154. package/esm/components/series-label/series-label.js +110 -0
  155. package/esm/components/series-label/series-label.js.map +1 -0
  156. package/esm/components/series-label/type.d.ts +41 -0
  157. package/esm/components/series-label/type.js +2 -0
  158. package/esm/components/series-label/type.js.map +1 -0
  159. package/esm/components/series-label/util.d.ts +33 -0
  160. package/esm/components/series-label/util.js +144 -0
  161. package/esm/components/series-label/util.js.map +1 -0
  162. package/esm/index.d.ts +5 -0
  163. package/esm/index.js +9 -0
  164. package/esm/index.js.map +1 -0
  165. package/esm/type/index.d.ts +1 -0
  166. package/esm/type/index.js +2 -0
  167. package/esm/type/index.js.map +1 -0
  168. package/esm/type/type.d.ts +8 -0
  169. package/esm/type/type.js +2 -0
  170. package/esm/type/type.js.map +1 -0
  171. package/esm/utils/element.d.ts +7 -0
  172. package/esm/utils/element.js +15 -0
  173. package/esm/utils/element.js.map +1 -0
  174. package/esm/utils/math.d.ts +1 -0
  175. package/esm/utils/math.js +4 -0
  176. package/esm/utils/math.js.map +1 -0
  177. package/package.json +8 -8
@@ -0,0 +1,178 @@
1
+ var __rest = this && this.__rest || function(s, e) {
2
+ var t = {};
3
+ for (var p in s) Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0 && (t[p] = s[p]);
4
+ if (null != s && "function" == typeof Object.getOwnPropertySymbols) {
5
+ var i = 0;
6
+ for (p = Object.getOwnPropertySymbols(s); i < p.length; i++) e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]) && (t[p[i]] = s[p[i]]);
7
+ }
8
+ return t;
9
+ };
10
+
11
+ import { STACK_FIELD_END } from "@visactor/vchart";
12
+
13
+ import { array } from "@visactor/vutils";
14
+
15
+ import { BAR_LINK } from "./constant";
16
+
17
+ export function groupBarsByFields(elements, groupFields) {
18
+ var _a;
19
+ const result = {};
20
+ for (let i = 0; i < elements.length; i++) {
21
+ const item = elements[i], itemData = null === (_a = item.data) || void 0 === _a ? void 0 : _a[0], groupKey = groupFields.map((field => itemData[field])).join("-");
22
+ result[groupKey] || (result[groupKey] = []), result[groupKey].push(item);
23
+ }
24
+ return result;
25
+ }
26
+
27
+ export function getLinkData(currentElement, nextElement, config) {
28
+ const {isHorizontal: isHorizontal, isXAxisInverse: isXAxisInverse, isYAxisInverse: isYAxisInverse, linkType: linkType, doFill: doFill, regionStartX: regionStartX, regionStartY: regionStartY} = config, currentBarGraphic = currentElement.getGraphicItem(), nextBarGraphic = nextElement.getGraphicItem(), currentBarBounds = currentBarGraphic.AABBBounds, nextBarBounds = nextBarGraphic.AABBBounds;
29
+ let linePoints, areaPoints;
30
+ return isHorizontal ? (linePoints = [ {
31
+ x: (currentBarBounds.x1 + currentBarBounds.x2) / 2 + regionStartX,
32
+ y: currentBarBounds.y1 + regionStartY
33
+ }, {
34
+ x: (nextBarBounds.x1 + nextBarBounds.x2) / 2 + regionStartX,
35
+ y: nextBarBounds.y2 + regionStartY
36
+ } ], isXAxisInverse ? ("total" === linkType && (linePoints = [ {
37
+ x: currentBarBounds.x1 + regionStartX,
38
+ y: currentBarBounds.y1 + regionStartY
39
+ }, {
40
+ x: nextBarBounds.x1 + regionStartX,
41
+ y: nextBarBounds.y2 + regionStartY
42
+ } ]), doFill && (areaPoints = [ {
43
+ x: currentBarBounds.x1 + regionStartX,
44
+ x1: currentBarBounds.x2 + regionStartX,
45
+ y: currentBarBounds.y1 + regionStartY
46
+ }, {
47
+ x: nextBarBounds.x1 + regionStartX,
48
+ x1: nextBarBounds.x2 + regionStartX,
49
+ y: nextBarBounds.y2 + regionStartY
50
+ } ])) : ("total" === linkType && (linePoints = [ {
51
+ x: currentBarBounds.x2 + regionStartX,
52
+ y: currentBarBounds.y1 + regionStartY
53
+ }, {
54
+ x: nextBarBounds.x2 + regionStartX,
55
+ y: nextBarBounds.y2 + regionStartY
56
+ } ]), doFill && (areaPoints = [ {
57
+ x: currentBarBounds.x2 + regionStartX,
58
+ x1: currentBarBounds.x1 + regionStartX,
59
+ y: currentBarBounds.y1 + regionStartY
60
+ }, {
61
+ x: nextBarBounds.x2 + regionStartX,
62
+ x1: nextBarBounds.x1 + regionStartX,
63
+ y: nextBarBounds.y2 + regionStartY
64
+ } ]))) : (linePoints = [ {
65
+ x: currentBarBounds.x2 + regionStartX,
66
+ y: (currentBarBounds.y1 + currentBarBounds.y2) / 2 + regionStartY
67
+ }, {
68
+ x: nextBarBounds.x1 + regionStartX,
69
+ y: (nextBarBounds.y1 + nextBarBounds.y2) / 2 + regionStartY
70
+ } ], isYAxisInverse ? ("total" === linkType && (linePoints = [ {
71
+ x: currentBarBounds.x2 + regionStartX,
72
+ y: currentBarBounds.y2 + regionStartY
73
+ }, {
74
+ x: nextBarBounds.x1 + regionStartX,
75
+ y: nextBarBounds.y2 + regionStartY
76
+ } ]), doFill && (areaPoints = [ {
77
+ x: currentBarBounds.x2 + regionStartX,
78
+ y: currentBarBounds.y2 + regionStartY,
79
+ y1: currentBarBounds.y1 + regionStartY
80
+ }, {
81
+ x: nextBarBounds.x1 + regionStartX,
82
+ y: nextBarBounds.y2 + regionStartY,
83
+ y1: nextBarBounds.y1 + regionStartY
84
+ } ])) : ("total" === linkType && (linePoints = [ {
85
+ x: currentBarBounds.x2 + regionStartX,
86
+ y: currentBarBounds.y1 + regionStartY
87
+ }, {
88
+ x: nextBarBounds.x1 + regionStartX,
89
+ y: nextBarBounds.y1 + regionStartY
90
+ } ]), doFill && (areaPoints = [ {
91
+ x: currentBarBounds.x2 + regionStartX,
92
+ y: currentBarBounds.y1 + regionStartY,
93
+ y1: currentBarBounds.y2 + regionStartY
94
+ }, {
95
+ x: nextBarBounds.x1 + regionStartX,
96
+ y: nextBarBounds.y1 + regionStartY,
97
+ y1: nextBarBounds.y2 + regionStartY
98
+ } ]))), {
99
+ areaPoints: areaPoints,
100
+ linePoints: linePoints,
101
+ data: [ currentElement.data[0], nextElement.data[0] ],
102
+ color: currentBarGraphic.attribute.fill
103
+ };
104
+ }
105
+
106
+ export function getBarLinkConfig(style = {}, extraStyle) {
107
+ const {linkType: linkType = "total", doFill: doFill} = style, rest = __rest(style, [ "linkType", "doFill" ]);
108
+ return {
109
+ type: "component",
110
+ componentType: BAR_LINK,
111
+ zIndex: 500,
112
+ interactive: !1,
113
+ style: Object.assign(Object.assign({
114
+ data: (datum, context) => {
115
+ const {vchart: vchart} = context, regions = vchart.getChart().getAllRegions(), linkLineData = [];
116
+ return regions.forEach((region => {
117
+ const barSeriesArr = region.getSeries().filter((s => "bar" === s.type)), {x: regionStartX, y: regionStartY} = region.getLayoutStartPoint();
118
+ if (barSeriesArr.length) {
119
+ const groupFields = barSeriesArr[0].getGroupFields(), allBarElements = [];
120
+ barSeriesArr.forEach((barSeries => {
121
+ var _a, _b;
122
+ (null === (_b = null === (_a = barSeries.getMarkInName("bar")) || void 0 === _a ? void 0 : _a.getProduct()) || void 0 === _b ? void 0 : _b.elements).forEach((barElement => {
123
+ allBarElements.push(barElement);
124
+ }));
125
+ }));
126
+ const groupData = groupBarsByFields(allBarElements, groupFields);
127
+ Object.values(groupData).forEach((groupedValues => {
128
+ groupedValues.sort(((prev, curr) => prev.data[0][STACK_FIELD_END] - curr.data[0][STACK_FIELD_END]));
129
+ }));
130
+ const barSeries = barSeriesArr[0], isHorizontal = "horizontal" === barSeries.direction, isYAxisInverse = barSeries.getYAxisHelper().isInverse(), isXAxisInverse = barSeries.getXAxisHelper().isInverse(), groupValues = Object.values(groupData);
131
+ if (groupValues.length) if (isHorizontal) {
132
+ groupValues[0][0].getGraphicItem().AABBBounds.y1 < groupValues[groupValues.length - 1][0].getGraphicItem().AABBBounds.y1 && groupValues.reverse();
133
+ } else {
134
+ groupValues[0][0].getGraphicItem().AABBBounds.x1 > groupValues[groupValues.length - 1][0].getGraphicItem().AABBBounds.x1 && groupValues.reverse();
135
+ }
136
+ for (let index = 0; index < groupValues.length - 1; index++) {
137
+ const currentValues = groupValues[index], nextValues = groupValues[index + 1];
138
+ if (currentValues.forEach(((element, elementIndex) => {
139
+ var _a;
140
+ const linkData = getLinkData(element, null !== (_a = nextValues[elementIndex]) && void 0 !== _a ? _a : nextValues[nextValues.length - 1], {
141
+ isHorizontal: isHorizontal,
142
+ isXAxisInverse: isXAxisInverse,
143
+ isYAxisInverse: isYAxisInverse,
144
+ doFill: doFill,
145
+ linkType: linkType,
146
+ regionStartX: regionStartX,
147
+ regionStartY: regionStartY
148
+ });
149
+ linkLineData.push(linkData);
150
+ })), currentValues.length < nextValues.length) {
151
+ const lastElementOfCurrentElement = currentValues[currentValues.length - 1];
152
+ for (let i = currentValues.length; i < nextValues.length; i++) {
153
+ const linkData = getLinkData(lastElementOfCurrentElement, nextValues[i], {
154
+ isHorizontal: isHorizontal,
155
+ isXAxisInverse: isXAxisInverse,
156
+ isYAxisInverse: isYAxisInverse,
157
+ doFill: doFill,
158
+ linkType: linkType,
159
+ regionStartX: regionStartX,
160
+ regionStartY: regionStartY
161
+ });
162
+ linkLineData.push(linkData);
163
+ }
164
+ }
165
+ }
166
+ }
167
+ })), linkLineData;
168
+ },
169
+ linkType: linkType
170
+ }, rest), extraStyle)
171
+ };
172
+ }
173
+
174
+ export function appendBarLinkConfig(rawSpec, barLinkSpec) {
175
+ rawSpec.customMark = array(rawSpec.customMark).filter((obj => obj.componentType !== BAR_LINK)),
176
+ rawSpec.customMark.push(getBarLinkConfig(barLinkSpec));
177
+ }
178
+ //# sourceMappingURL=util.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["components/bar-link/util.ts"],"names":[],"mappings":"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","file":"util.js","sourcesContent":["import type { IElement } from '@visactor/vgrammar-core';\nimport type { Dict, IPointLike } from '@visactor/vutils';\nimport type { BarLinkAttrs, BarLinkDatum } from './type';\nimport type { ICartesianSeries, ISpec } from '@visactor/vchart';\nimport { STACK_FIELD_END } from '@visactor/vchart';\nimport { array } from '@visactor/vutils';\nimport { BAR_LINK } from './constant';\n\nexport function groupBarsByFields(elements: IElement[], groupFields: string[]) {\n const result: Dict<IElement[]> = {};\n for (let i = 0; i < elements.length; i++) {\n const item = elements[i];\n const itemData = item.data?.[0];\n const groupKey = groupFields.map(field => itemData[field]).join('-');\n if (!result[groupKey]) {\n result[groupKey] = [];\n }\n result[groupKey].push(item);\n }\n return result;\n}\n\nexport function getLinkData(\n currentElement: IElement,\n nextElement: IElement,\n config: {\n isHorizontal: boolean;\n isXAxisInverse: boolean;\n isYAxisInverse: boolean;\n linkType: string;\n doFill: boolean;\n regionStartX: number;\n regionStartY: number;\n }\n): BarLinkDatum {\n const { isHorizontal, isXAxisInverse, isYAxisInverse, linkType, doFill, regionStartX, regionStartY } = config;\n const currentBarGraphic = currentElement.getGraphicItem();\n const nextBarGraphic = nextElement.getGraphicItem();\n const currentBarBounds = currentBarGraphic.AABBBounds;\n const nextBarBounds = nextBarGraphic.AABBBounds;\n\n let linePoints: [IPointLike, IPointLike];\n let areaPoints: [IPointLike, IPointLike];\n\n if (isHorizontal) {\n linePoints = [\n {\n x: (currentBarBounds.x1 + currentBarBounds.x2) / 2 + regionStartX,\n y: currentBarBounds.y1 + regionStartY\n },\n {\n x: (nextBarBounds.x1 + nextBarBounds.x2) / 2 + regionStartX,\n y: nextBarBounds.y2 + regionStartY\n }\n ];\n if (isXAxisInverse) {\n if (linkType === 'total') {\n linePoints = [\n {\n x: currentBarBounds.x1 + regionStartX,\n y: currentBarBounds.y1 + regionStartY\n },\n {\n x: nextBarBounds.x1 + regionStartX,\n y: nextBarBounds.y2 + regionStartY\n }\n ];\n }\n\n if (doFill) {\n areaPoints = [\n {\n x: currentBarBounds.x1 + regionStartX,\n x1: currentBarBounds.x2 + regionStartX,\n y: currentBarBounds.y1 + regionStartY\n },\n {\n x: nextBarBounds.x1 + regionStartX,\n x1: nextBarBounds.x2 + regionStartX,\n y: nextBarBounds.y2 + regionStartY\n }\n ];\n }\n } else {\n if (linkType === 'total') {\n linePoints = [\n {\n x: currentBarBounds.x2 + regionStartX,\n y: currentBarBounds.y1 + regionStartY\n },\n {\n x: nextBarBounds.x2 + regionStartX,\n y: nextBarBounds.y2 + regionStartY\n }\n ];\n }\n\n if (doFill) {\n areaPoints = [\n {\n x: currentBarBounds.x2 + regionStartX,\n x1: currentBarBounds.x1 + regionStartX,\n y: currentBarBounds.y1 + regionStartY\n },\n {\n x: nextBarBounds.x2 + regionStartX,\n x1: nextBarBounds.x1 + regionStartX,\n y: nextBarBounds.y2 + regionStartY\n }\n ];\n }\n }\n } else {\n linePoints = [\n {\n x: currentBarBounds.x2 + regionStartX,\n y: (currentBarBounds.y1 + currentBarBounds.y2) / 2 + regionStartY\n },\n {\n x: nextBarBounds.x1 + regionStartX,\n y: (nextBarBounds.y1 + nextBarBounds.y2) / 2 + regionStartY\n }\n ];\n\n if (isYAxisInverse) {\n if (linkType === 'total') {\n linePoints = [\n {\n x: currentBarBounds.x2 + regionStartX,\n y: currentBarBounds.y2 + regionStartY\n },\n {\n x: nextBarBounds.x1 + regionStartX,\n y: nextBarBounds.y2 + regionStartY\n }\n ];\n }\n if (doFill) {\n areaPoints = [\n {\n x: currentBarBounds.x2 + regionStartX,\n y: currentBarBounds.y2 + regionStartY,\n y1: currentBarBounds.y1 + regionStartY\n },\n {\n x: nextBarBounds.x1 + regionStartX,\n y: nextBarBounds.y2 + regionStartY,\n y1: nextBarBounds.y1 + regionStartY\n }\n ];\n }\n } else {\n if (linkType === 'total') {\n linePoints = [\n {\n x: currentBarBounds.x2 + regionStartX,\n y: currentBarBounds.y1 + regionStartY\n },\n {\n x: nextBarBounds.x1 + regionStartX,\n y: nextBarBounds.y1 + regionStartY\n }\n ];\n }\n if (doFill) {\n areaPoints = [\n {\n x: currentBarBounds.x2 + regionStartX,\n y: currentBarBounds.y1 + regionStartY,\n y1: currentBarBounds.y2 + regionStartY\n },\n {\n x: nextBarBounds.x1 + regionStartX,\n y: nextBarBounds.y1 + regionStartY,\n y1: nextBarBounds.y2 + regionStartY\n }\n ];\n }\n }\n }\n\n return {\n // points,\n areaPoints,\n linePoints,\n data: [currentElement.data[0], nextElement.data[0]],\n color: currentBarGraphic.attribute.fill as string\n };\n}\n\nexport function getBarLinkConfig(\n style: Pick<BarLinkAttrs, 'areaStyle' | 'label' | 'linkStyle' | 'styleMap' | 'doFill' | 'linkType'> = {},\n extraStyle?: any\n) {\n const { linkType = 'total', doFill, ...rest } = style;\n return {\n type: 'component',\n componentType: BAR_LINK,\n zIndex: 500, // 需要处于 region 上层\n interactive: false,\n style: {\n data: (datum: any, context: any) => {\n const { vchart } = context;\n const regions = vchart.getChart().getAllRegions();\n const linkLineData: BarLinkDatum[] = [];\n regions.forEach((region: any) => {\n // 获取所有 bar 系列\n const barSeriesArr = region\n .getSeries()\n .filter((s: ICartesianSeries) => s.type === 'bar') as ICartesianSeries[];\n const { x: regionStartX, y: regionStartY } = region.getLayoutStartPoint();\n if (barSeriesArr.length) {\n const groupFields = barSeriesArr[0].getGroupFields();\n const allBarElements: IElement[] = [];\n barSeriesArr.forEach(barSeries => {\n const barGraphicElements = barSeries.getMarkInName('bar')?.getProduct()?.elements;\n barGraphicElements.forEach(barElement => {\n allBarElements.push(barElement);\n });\n });\n // 按照 xField/yField 进行分组\n const groupData = groupBarsByFields(allBarElements, groupFields);\n\n // 对同组内的图形进行排序\n Object.values(groupData).forEach((groupedValues: IElement[]) => {\n groupedValues.sort((prev: IElement, curr: IElement) => {\n return prev.data[0][STACK_FIELD_END] - curr.data[0][STACK_FIELD_END];\n });\n });\n\n const barSeries = barSeriesArr[0];\n const isHorizontal = barSeries.direction === 'horizontal';\n const isYAxisInverse = barSeries.getYAxisHelper().isInverse();\n const isXAxisInverse = barSeries.getXAxisHelper().isInverse();\n\n const groupValues: IElement[][] = Object.values(groupData);\n\n // 根据每组图形:\n // 1. 水平,每组图形的 y1 进行由小到大排序,保证图形顺序\n // 2. 垂直,每组图形的 x1 进行由小到大排序,保证图形顺序\n if (groupValues.length) {\n if (isHorizontal) {\n const firstElementPosY = groupValues[0][0].getGraphicItem().AABBBounds.y1;\n const lastElementPosY = groupValues[groupValues.length - 1][0].getGraphicItem().AABBBounds.y1;\n if (firstElementPosY < lastElementPosY) {\n groupValues.reverse();\n }\n } else {\n const firstElementPosX = groupValues[0][0].getGraphicItem().AABBBounds.x1;\n const lastElementPosX = groupValues[groupValues.length - 1][0].getGraphicItem().AABBBounds.x1;\n if (firstElementPosX > lastElementPosX) {\n groupValues.reverse();\n }\n }\n }\n\n for (let index = 0; index < groupValues.length - 1; index++) {\n const currentValues: IElement[] = groupValues[index];\n const nextValues: IElement[] = groupValues[index + 1];\n\n currentValues.forEach((element, elementIndex) => {\n const nextElement = nextValues[elementIndex] ?? nextValues[nextValues.length - 1];\n\n const linkData = getLinkData(element, nextElement, {\n isHorizontal,\n isXAxisInverse,\n isYAxisInverse,\n doFill,\n linkType,\n regionStartX,\n regionStartY\n });\n\n linkLineData.push(linkData);\n });\n\n if (currentValues.length < nextValues.length) {\n // 如果当前组的个数小于下一个组的个数,用当前组的最后一个元素去链接下一组剩余的图形\n // 使用当前组的最后一个元素去链接下一组剩余的图形\n const lastElementOfCurrentElement = currentValues[currentValues.length - 1];\n for (let i = currentValues.length; i < nextValues.length; i++) {\n const nextElement = nextValues[i];\n\n const linkData = getLinkData(lastElementOfCurrentElement, nextElement, {\n isHorizontal,\n isXAxisInverse,\n isYAxisInverse,\n doFill,\n linkType,\n regionStartX,\n regionStartY\n });\n\n linkLineData.push(linkData);\n }\n }\n }\n }\n });\n\n return linkLineData;\n },\n linkType,\n ...rest,\n ...extraStyle\n }\n };\n}\n\nexport function appendBarLinkConfig(\n rawSpec: ISpec,\n barLinkSpec?: Pick<BarLinkAttrs, 'areaStyle' | 'label' | 'linkStyle' | 'styleMap' | 'doFill' | 'linkType'>\n) {\n // 判断 editorSpec 中是否有 barLink,有则添加 customMark\n (rawSpec as any).customMark = array((rawSpec as any).customMark).filter((obj: any) => obj.componentType !== BAR_LINK);\n (rawSpec as any).customMark.push(getBarLinkConfig(barLinkSpec));\n}\n"]}
@@ -0,0 +1 @@
1
+ export declare const SERIES_BREAK = "seriesBreak";
@@ -0,0 +1,2 @@
1
+ export const SERIES_BREAK = "seriesBreak";
2
+ //# sourceMappingURL=constant.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["components/series-break/constant.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,YAAY,GAAG,aAAa,CAAC","file":"constant.js","sourcesContent":["export const SERIES_BREAK = 'seriesBreak';\n"]}
@@ -0,0 +1,4 @@
1
+ export { registerSeriesBreak, SeriesBreakComponent } from './series-break';
2
+ export { getSeriesBreakConfig, appendSeriesBreakConfig } from './util';
3
+ export * from './type';
4
+ export * from './constant';
@@ -0,0 +1,8 @@
1
+ export { registerSeriesBreak, SeriesBreakComponent } from "./series-break";
2
+
3
+ export { getSeriesBreakConfig, appendSeriesBreakConfig } from "./util";
4
+
5
+ export * from "./type";
6
+
7
+ export * from "./constant";
8
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["components/series-break/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,oBAAoB,EAAE,MAAM,gBAAgB,CAAC;AAC3E,OAAO,EAAE,oBAAoB,EAAE,uBAAuB,EAAE,MAAM,QAAQ,CAAC;AACvE,cAAc,QAAQ,CAAC;AACvB,cAAc,YAAY,CAAC","file":"index.js","sourcesContent":["export { registerSeriesBreak, SeriesBreakComponent } from './series-break';\nexport { getSeriesBreakConfig, appendSeriesBreakConfig } from './util';\nexport * from './type';\nexport * from './constant';\n"]}
@@ -0,0 +1,7 @@
1
+ import { AbstractComponent } from '@visactor/vrender-components';
2
+ import { SeriesBreakAttrs } from './type';
3
+ export declare class SeriesBreakComponent extends AbstractComponent<Required<SeriesBreakAttrs>> {
4
+ name: string;
5
+ protected render(): void;
6
+ }
7
+ export declare const registerSeriesBreak: () => void;
@@ -0,0 +1,115 @@
1
+ var __rest = this && this.__rest || function(s, e) {
2
+ var t = {};
3
+ for (var p in s) Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0 && (t[p] = s[p]);
4
+ if (null != s && "function" == typeof Object.getOwnPropertySymbols) {
5
+ var i = 0;
6
+ for (p = Object.getOwnPropertySymbols(s); i < p.length; i++) e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]) && (t[p[i]] = s[p[i]]);
7
+ }
8
+ return t;
9
+ };
10
+
11
+ import { AbstractComponent } from "@visactor/vrender-components";
12
+
13
+ import { Factory } from "@visactor/vgrammar-core";
14
+
15
+ import { createGroup, createPath } from "@visactor/vrender-core";
16
+
17
+ import { isEmpty, isNumberClose, isValid } from "@visactor/vutils";
18
+
19
+ import { SERIES_BREAK } from "./constant";
20
+
21
+ function generateZigzagPath(start, end, size, angle, isVertical = !1) {
22
+ 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);
23
+ path.push(`M ${startX} ${startY}`);
24
+ for (let i = 0; i <= numZigzags; i++) {
25
+ const x = isVertical ? startX + (i % 2 == 0 ? deltaX : -deltaX) : startX + i * size * 2, y = isVertical ? startY + i * size * 2 : i % 2 == 0 ? startY - deltaY : startY + deltaY;
26
+ path.push(`L ${x} ${y}`);
27
+ }
28
+ return path.push(`L ${isVertical ? startX : endX} ${isVertical ? endY : startY}`),
29
+ path.join(" ");
30
+ }
31
+
32
+ const checkOverlap = (prevData, newEntry) => {
33
+ const {start: start, end: end} = newEntry, isVertical = start.x === end.x, equalDim = isVertical ? "x" : "y", diffDim = isVertical ? "y" : "x";
34
+ let needAppend = !0;
35
+ prevData.length && prevData.forEach((prevEntry => {
36
+ if (isNumberClose(prevEntry.start[equalDim], start[equalDim])) {
37
+ 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]);
38
+ if (!(maxDim < prevMinDim - 1e-6 || minDim > prevMaxDim + 1e-6)) return prevEntry.start[diffDim] = Math.min(prevMinDim, minDim),
39
+ prevEntry.end[diffDim] = Math.max(prevMaxDim, maxDim), void (needAppend = !1);
40
+ }
41
+ })), needAppend && prevData.push(newEntry);
42
+ };
43
+
44
+ export class SeriesBreakComponent extends AbstractComponent {
45
+ constructor() {
46
+ super(...arguments), this.name = SERIES_BREAK;
47
+ }
48
+ render() {
49
+ this.removeAllChild();
50
+ const {data: data = []} = this.attribute;
51
+ if (isEmpty(data)) return;
52
+ const verticalData = [], horizontalData = [];
53
+ data.forEach((breakData => {
54
+ const {start: start, end: end} = breakData, isVertical = start.x === end.x;
55
+ checkOverlap(isVertical ? verticalData : horizontalData, breakData);
56
+ })), [ ...verticalData, ...horizontalData ].forEach(((breakData, id) => {
57
+ var _a;
58
+ const {start: start, end: end, size: size = 4, gap: gap = 5, style: style = {}} = breakData, rest = __rest(breakData, [ "start", "end", "size", "gap", "style" ]), breakGroup = createGroup({}), isVertical = start.x === end.x;
59
+ let startPathStart, startPathEnd, endPathStart, endPathEnd;
60
+ isVertical ? (startPathStart = {
61
+ x: start.x - gap / 2,
62
+ y: start.y
63
+ }, startPathEnd = {
64
+ x: end.x - gap / 2,
65
+ y: end.y
66
+ }, endPathStart = {
67
+ x: start.x + gap / 2,
68
+ y: start.y
69
+ }, endPathEnd = {
70
+ x: end.x + gap / 2,
71
+ y: end.y
72
+ }) : (startPathStart = {
73
+ x: start.x,
74
+ y: start.y - gap / 2
75
+ }, startPathEnd = {
76
+ x: end.x,
77
+ y: end.y - gap / 2
78
+ }, endPathStart = {
79
+ x: start.x,
80
+ y: start.y + gap / 2
81
+ }, endPathEnd = {
82
+ x: end.x,
83
+ y: end.y + gap / 2
84
+ });
85
+ 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);
86
+ breakGroup.add(createPath(Object.assign(Object.assign({
87
+ path: startPath,
88
+ stroke: "#000",
89
+ lineWidth: 1
90
+ }, style), {
91
+ pickable: !1,
92
+ zIndex: 1
93
+ }))), breakGroup.add(createPath(Object.assign(Object.assign({
94
+ path: endPath,
95
+ stroke: "#000",
96
+ lineWidth: 1
97
+ }, style), {
98
+ pickable: !1,
99
+ zIndex: 1
100
+ }))), breakGroup.add(createPath({
101
+ path: centerPath,
102
+ stroke: "#fff",
103
+ lineWidth: gap,
104
+ pickable: !1,
105
+ zIndex: 0
106
+ })), breakGroup.name = "series-break", breakGroup.data = rest, isValid(rest.axisId) && (breakGroup.id = `${null !== (_a = rest.axisId) && void 0 !== _a ? _a : ""}_${id}`),
107
+ this.add(breakGroup);
108
+ }));
109
+ }
110
+ }
111
+
112
+ export const registerSeriesBreak = () => {
113
+ Factory.registerGraphicComponent("seriesBreak", (attrs => new SeriesBreakComponent(attrs)));
114
+ };
115
+ //# sourceMappingURL=series-break.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["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 { AbstractComponent, Point } from '@visactor/vrender-components';\nimport { Factory } from '@visactor/vgrammar-core';\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';\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"]}
@@ -0,0 +1,14 @@
1
+ import { Point } from '@visactor/vrender-components';
2
+ import { IGroupGraphicAttribute, ILineGraphicAttribute } from '@visactor/vrender-core';
3
+ export type SeriesBreakData = {
4
+ start: Point;
5
+ end: Point;
6
+ size?: number;
7
+ gap?: number;
8
+ style?: ILineGraphicAttribute;
9
+ axisId: string;
10
+ data: [number, number];
11
+ };
12
+ export interface SeriesBreakAttrs extends IGroupGraphicAttribute {
13
+ data: SeriesBreakData[];
14
+ }
@@ -0,0 +1,2 @@
1
+ export { };
2
+ //# sourceMappingURL=type.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["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"]}
@@ -0,0 +1,13 @@
1
+ import type { ILinearAxisSpec } from '@visactor/vchart/esm/component/axis';
2
+ import { ISpec } from '@visactor/vchart';
3
+ import { SeriesBreakData } from './type';
4
+ export declare function getSeriesBreakConfig(axesSpec: ILinearAxisSpec[], axesIndex?: number[]): {
5
+ type: string;
6
+ componentType: string;
7
+ interactive: boolean;
8
+ zIndex: number;
9
+ style: {
10
+ data: (datum: any, ctx: any) => SeriesBreakData[];
11
+ };
12
+ };
13
+ export declare const appendSeriesBreakConfig: (rawSpec: ISpec) => boolean;