@visactor/vchart-extension 1.12.15 → 1.12.16

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