@visactor/vgrammar-core 0.8.0 → 0.8.2

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 (272) hide show
  1. package/cjs/component/axis.js +9 -9
  2. package/cjs/component/axis.js.map +1 -1
  3. package/cjs/component/datazoom.js +9 -9
  4. package/cjs/component/datazoom.js.map +1 -1
  5. package/cjs/component/grid.js +18 -18
  6. package/cjs/component/grid.js.map +1 -1
  7. package/cjs/component/label.js +27 -22
  8. package/cjs/component/label.js.map +1 -1
  9. package/cjs/component/legend.js +13 -13
  10. package/cjs/component/legend.js.map +1 -1
  11. package/cjs/component/scrollbar.js +7 -7
  12. package/cjs/component/scrollbar.js.map +1 -1
  13. package/cjs/component/slider.js +5 -5
  14. package/cjs/component/slider.js.map +1 -1
  15. package/cjs/component/title.js +5 -5
  16. package/cjs/component/title.js.map +1 -1
  17. package/cjs/core/factory.d.ts +5 -1
  18. package/cjs/core/factory.js +13 -3
  19. package/cjs/core/factory.js.map +1 -1
  20. package/cjs/graph/animation/animate.d.ts +1 -0
  21. package/cjs/graph/animation/animate.js +4 -0
  22. package/cjs/graph/animation/animate.js.map +1 -1
  23. package/cjs/graph/animation/animation/move.js +10 -8
  24. package/cjs/graph/animation/animation/move.js.map +1 -1
  25. package/cjs/graph/attributes/common.js +2 -10
  26. package/cjs/graph/attributes/common.js.map +1 -1
  27. package/cjs/graph/attributes/helpers.d.ts +2 -2
  28. package/cjs/graph/attributes/helpers.js +50 -17
  29. package/cjs/graph/attributes/helpers.js.map +1 -1
  30. package/cjs/graph/attributes/index.d.ts +4 -10
  31. package/cjs/graph/attributes/index.js +16 -251
  32. package/cjs/graph/attributes/index.js.map +1 -1
  33. package/cjs/graph/attributes/line.d.ts +3 -0
  34. package/cjs/graph/attributes/line.js +46 -0
  35. package/cjs/graph/attributes/line.js.map +1 -0
  36. package/cjs/graph/attributes/transform.d.ts +5 -0
  37. package/cjs/graph/attributes/transform.js +167 -0
  38. package/cjs/graph/attributes/transform.js.map +1 -0
  39. package/cjs/graph/canvas-renderer.js +1 -1
  40. package/cjs/graph/canvas-renderer.js.map +1 -1
  41. package/cjs/graph/constants.d.ts +0 -1
  42. package/cjs/graph/constants.js +2 -3
  43. package/cjs/graph/constants.js.map +1 -1
  44. package/cjs/graph/element.js +12 -14
  45. package/cjs/graph/element.js.map +1 -1
  46. package/cjs/graph/glyph-element.js +6 -7
  47. package/cjs/graph/glyph-element.js.map +1 -1
  48. package/cjs/graph/layout/relative.js.map +1 -1
  49. package/cjs/graph/mark/encode.js +4 -4
  50. package/cjs/graph/mark/encode.js.map +1 -1
  51. package/cjs/index.d.ts +3 -1
  52. package/cjs/index.js +3 -2
  53. package/cjs/index.js.map +1 -1
  54. package/cjs/interactions/base.js.map +1 -1
  55. package/cjs/interactions/brush-base.js +2 -2
  56. package/cjs/interactions/brush-base.js.map +1 -1
  57. package/cjs/interactions/brush-filter.js +2 -2
  58. package/cjs/interactions/brush-filter.js.map +1 -1
  59. package/cjs/interactions/crosshair.d.ts +1 -1
  60. package/cjs/interactions/crosshair.js +15 -15
  61. package/cjs/interactions/crosshair.js.map +1 -1
  62. package/cjs/interactions/datazoom-filter.js +3 -3
  63. package/cjs/interactions/datazoom-filter.js.map +1 -1
  64. package/cjs/interactions/drill-down.js +2 -2
  65. package/cjs/interactions/drill-down.js.map +1 -1
  66. package/cjs/interactions/legend-filter.js +3 -3
  67. package/cjs/interactions/legend-filter.js.map +1 -1
  68. package/cjs/interactions/player-filter.js +3 -3
  69. package/cjs/interactions/player-filter.js.map +1 -1
  70. package/cjs/interactions/roll-up.js +2 -2
  71. package/cjs/interactions/roll-up.js.map +1 -1
  72. package/cjs/interactions/scrollbar-filter.js +3 -3
  73. package/cjs/interactions/scrollbar-filter.js.map +1 -1
  74. package/cjs/interactions/slider-filter.js +3 -3
  75. package/cjs/interactions/slider-filter.js.map +1 -1
  76. package/cjs/parse/view.js +1 -1
  77. package/cjs/parse/view.js.map +1 -1
  78. package/cjs/semantic-marks/cell.d.ts +3 -1
  79. package/cjs/semantic-marks/cell.js +10 -4
  80. package/cjs/semantic-marks/cell.js.map +1 -1
  81. package/cjs/semantic-marks/interval.d.ts +2 -0
  82. package/cjs/semantic-marks/interval.js +10 -4
  83. package/cjs/semantic-marks/interval.js.map +1 -1
  84. package/cjs/semantic-marks/text.d.ts +1 -0
  85. package/cjs/semantic-marks/text.js +3 -3
  86. package/cjs/semantic-marks/text.js.map +1 -1
  87. package/cjs/theme/common/component.d.ts +2 -1
  88. package/cjs/theme/common/component.js +13 -1
  89. package/cjs/theme/common/component.js.map +1 -1
  90. package/cjs/theme/dark.js.map +1 -1
  91. package/cjs/transforms/data/sampling.d.ts +2 -0
  92. package/cjs/transforms/data/sampling.js +111 -0
  93. package/cjs/transforms/data/sampling.js.map +1 -0
  94. package/cjs/transforms/index.d.ts +1 -1
  95. package/cjs/transforms/index.js +6 -6
  96. package/cjs/transforms/index.js.map +1 -1
  97. package/cjs/transforms/util/util.d.ts +4 -0
  98. package/cjs/transforms/util/util.js +20 -2
  99. package/cjs/transforms/util/util.js.map +1 -1
  100. package/cjs/types/animate.d.ts +6 -1
  101. package/cjs/types/animate.js.map +1 -1
  102. package/cjs/types/grammar.d.ts +1 -1
  103. package/cjs/types/grammar.js.map +1 -1
  104. package/cjs/types/mark.d.ts +5 -1
  105. package/cjs/types/mark.js.map +1 -1
  106. package/cjs/types/theme.d.ts +2 -1
  107. package/cjs/types/theme.js.map +1 -1
  108. package/cjs/types/transform.d.ts +5 -5
  109. package/cjs/types/transform.js.map +1 -1
  110. package/cjs/types/view.d.ts +2 -0
  111. package/cjs/types/view.js.map +1 -1
  112. package/cjs/view/View.d.ts +0 -1
  113. package/cjs/view/View.js +18 -27
  114. package/cjs/view/View.js.map +1 -1
  115. package/cjs/view/animate.d.ts +1 -0
  116. package/cjs/view/animate.js +12 -12
  117. package/cjs/view/animate.js.map +1 -1
  118. package/cjs/view/constants.d.ts +0 -3
  119. package/cjs/view/constants.js +2 -3
  120. package/cjs/view/constants.js.map +1 -1
  121. package/cjs/view/dataflow.d.ts +1 -0
  122. package/cjs/view/dataflow.js +9 -4
  123. package/cjs/view/dataflow.js.map +1 -1
  124. package/cjs/view/grammar-record.js +5 -5
  125. package/cjs/view/grammar-record.js.map +1 -1
  126. package/cjs/view/mark.js +1 -1
  127. package/cjs/view/mark.js.map +1 -1
  128. package/es/component/axis.js +1 -1
  129. package/es/component/axis.js.map +1 -1
  130. package/es/component/datazoom.js +5 -5
  131. package/es/component/datazoom.js.map +1 -1
  132. package/es/component/grid.js +1 -1
  133. package/es/component/grid.js.map +1 -1
  134. package/es/component/label.js +13 -8
  135. package/es/component/label.js.map +1 -1
  136. package/es/component/legend.js +1 -1
  137. package/es/component/legend.js.map +1 -1
  138. package/es/component/scrollbar.js +1 -1
  139. package/es/component/scrollbar.js.map +1 -1
  140. package/es/component/slider.js +1 -1
  141. package/es/component/slider.js.map +1 -1
  142. package/es/component/title.js +1 -1
  143. package/es/component/title.js.map +1 -1
  144. package/es/core/factory.d.ts +5 -1
  145. package/es/core/factory.js +11 -1
  146. package/es/core/factory.js.map +1 -1
  147. package/es/graph/animation/animate.d.ts +1 -0
  148. package/es/graph/animation/animate.js +4 -0
  149. package/es/graph/animation/animate.js.map +1 -1
  150. package/es/graph/animation/animation/move.js +5 -5
  151. package/es/graph/animation/animation/move.js.map +1 -1
  152. package/es/graph/attributes/common.js +2 -7
  153. package/es/graph/attributes/common.js.map +1 -1
  154. package/es/graph/attributes/helpers.d.ts +2 -2
  155. package/es/graph/attributes/helpers.js +46 -12
  156. package/es/graph/attributes/helpers.js.map +1 -1
  157. package/es/graph/attributes/index.d.ts +4 -10
  158. package/es/graph/attributes/index.js +4 -227
  159. package/es/graph/attributes/index.js.map +1 -1
  160. package/es/graph/attributes/line.d.ts +3 -0
  161. package/es/graph/attributes/line.js +42 -0
  162. package/es/graph/attributes/line.js.map +1 -0
  163. package/es/graph/attributes/transform.d.ts +5 -0
  164. package/es/graph/attributes/transform.js +153 -0
  165. package/es/graph/attributes/transform.js.map +1 -0
  166. package/es/graph/canvas-renderer.js +1 -1
  167. package/es/graph/canvas-renderer.js.map +1 -1
  168. package/es/graph/constants.d.ts +0 -1
  169. package/es/graph/constants.js +0 -2
  170. package/es/graph/constants.js.map +1 -1
  171. package/es/graph/element.js +11 -11
  172. package/es/graph/element.js.map +1 -1
  173. package/es/graph/glyph-element.js +3 -4
  174. package/es/graph/glyph-element.js.map +1 -1
  175. package/es/graph/layout/relative.js.map +1 -1
  176. package/es/graph/mark/encode.js +1 -1
  177. package/es/graph/mark/encode.js.map +1 -1
  178. package/es/index.d.ts +3 -1
  179. package/es/index.js +5 -1
  180. package/es/index.js.map +1 -1
  181. package/es/interactions/base.js.map +1 -1
  182. package/es/interactions/brush-base.js +1 -1
  183. package/es/interactions/brush-base.js.map +1 -1
  184. package/es/interactions/brush-filter.js +2 -3
  185. package/es/interactions/brush-filter.js.map +1 -1
  186. package/es/interactions/crosshair.d.ts +1 -1
  187. package/es/interactions/crosshair.js +1 -1
  188. package/es/interactions/crosshair.js.map +1 -1
  189. package/es/interactions/datazoom-filter.js +1 -1
  190. package/es/interactions/datazoom-filter.js.map +1 -1
  191. package/es/interactions/drill-down.js +1 -1
  192. package/es/interactions/drill-down.js.map +1 -1
  193. package/es/interactions/element-highlight-by-group.js +2 -1
  194. package/es/interactions/index.js +1 -2
  195. package/es/interactions/legend-filter.js +2 -2
  196. package/es/interactions/legend-filter.js.map +1 -1
  197. package/es/interactions/player-filter.js +2 -2
  198. package/es/interactions/player-filter.js.map +1 -1
  199. package/es/interactions/roll-up.js +2 -2
  200. package/es/interactions/roll-up.js.map +1 -1
  201. package/es/interactions/scrollbar-filter.js +2 -2
  202. package/es/interactions/scrollbar-filter.js.map +1 -1
  203. package/es/interactions/slider-filter.js +2 -2
  204. package/es/interactions/slider-filter.js.map +1 -1
  205. package/es/interactions/tooltip.js +1 -1
  206. package/es/interactions/view-drag-mixin.js +1 -1
  207. package/es/parse/coordinate.js +1 -1
  208. package/es/parse/event.js +1 -1
  209. package/es/parse/mark.js +1 -1
  210. package/es/parse/option.js +1 -1
  211. package/es/parse/scale.js +2 -1
  212. package/es/parse/transform.js +1 -1
  213. package/es/parse/util.js +1 -1
  214. package/es/parse/view.js +2 -2
  215. package/es/parse/view.js.map +1 -1
  216. package/es/semantic-marks/cell.d.ts +3 -1
  217. package/es/semantic-marks/cell.js +11 -1
  218. package/es/semantic-marks/cell.js.map +1 -1
  219. package/es/semantic-marks/interval.d.ts +2 -0
  220. package/es/semantic-marks/interval.js +9 -1
  221. package/es/semantic-marks/interval.js.map +1 -1
  222. package/es/semantic-marks/text.d.ts +1 -0
  223. package/es/semantic-marks/text.js +3 -1
  224. package/es/semantic-marks/text.js.map +1 -1
  225. package/es/theme/common/component.d.ts +2 -1
  226. package/es/theme/common/component.js +14 -0
  227. package/es/theme/common/component.js.map +1 -1
  228. package/es/theme/dark.js.map +1 -1
  229. package/es/transforms/data/sampling.d.ts +2 -0
  230. package/es/transforms/data/sampling.js +105 -0
  231. package/es/transforms/data/sampling.js.map +1 -0
  232. package/es/transforms/index.d.ts +1 -1
  233. package/es/transforms/index.js +4 -4
  234. package/es/transforms/index.js.map +1 -1
  235. package/es/transforms/util/util.d.ts +4 -0
  236. package/es/transforms/util/util.js +17 -0
  237. package/es/transforms/util/util.js.map +1 -1
  238. package/es/types/animate.d.ts +6 -1
  239. package/es/types/animate.js.map +1 -1
  240. package/es/types/grammar.d.ts +1 -1
  241. package/es/types/grammar.js.map +1 -1
  242. package/es/types/mark.d.ts +5 -1
  243. package/es/types/mark.js.map +1 -1
  244. package/es/types/theme.d.ts +2 -1
  245. package/es/types/theme.js.map +1 -1
  246. package/es/types/transform.d.ts +5 -5
  247. package/es/types/transform.js.map +1 -1
  248. package/es/types/view.d.ts +2 -0
  249. package/es/types/view.js.map +1 -1
  250. package/es/view/View.d.ts +0 -1
  251. package/es/view/View.js +15 -29
  252. package/es/view/View.js.map +1 -1
  253. package/es/view/animate.d.ts +1 -0
  254. package/es/view/animate.js +6 -6
  255. package/es/view/animate.js.map +1 -1
  256. package/es/view/constants.d.ts +0 -3
  257. package/es/view/constants.js +0 -6
  258. package/es/view/constants.js.map +1 -1
  259. package/es/view/dataflow.d.ts +1 -0
  260. package/es/view/dataflow.js +9 -4
  261. package/es/view/dataflow.js.map +1 -1
  262. package/es/view/grammar-record.js +1 -1
  263. package/es/view/grammar-record.js.map +1 -1
  264. package/es/view/mark.js +1 -1
  265. package/es/view/mark.js.map +1 -1
  266. package/package.json +9 -9
  267. package/cjs/transforms/mark/lttb-sample.d.ts +0 -2
  268. package/cjs/transforms/mark/lttb-sample.js +0 -68
  269. package/cjs/transforms/mark/lttb-sample.js.map +0 -1
  270. package/es/transforms/mark/lttb-sample.d.ts +0 -2
  271. package/es/transforms/mark/lttb-sample.js +0 -60
  272. package/es/transforms/mark/lttb-sample.js.map +0 -1
@@ -1,68 +0,0 @@
1
- "use strict";
2
-
3
- function lttb(size, array, isGroup, yfield) {
4
- const frameSize = Math.floor(array.length / size), newIndices = [], len = array.length;
5
- let maxArea, area, nextIndex, currentIndex = 0, sampledIndex = 0;
6
- newIndices[sampledIndex++] = currentIndex;
7
- for (let i = 1; i < len - 1; i += frameSize) {
8
- const nextFrameStart = Math.min(i + frameSize, len - 1), nextFrameEnd = Math.min(i + 2 * frameSize, len), avgX = (nextFrameEnd + nextFrameStart) / 2;
9
- let avgY = 0;
10
- for (let idx = nextFrameStart; idx < nextFrameEnd; idx++) {
11
- const y = isGroup ? array[idx].y : array[idx][yfield];
12
- Number.isNaN(y) || (avgY += y);
13
- }
14
- avgY /= nextFrameEnd - nextFrameStart;
15
- const frameStart = i, frameEnd = Math.min(i + frameSize, len), pointAX = i - 1, pointAY = isGroup ? array[currentIndex].y : array[currentIndex][yfield];
16
- maxArea = -1, nextIndex = frameStart;
17
- for (let idx = frameStart; idx < frameEnd; idx++) {
18
- const y = isGroup ? array[idx].y : array[idx][yfield];
19
- Number.isNaN(y) || (area = Math.abs((pointAX - avgX) * (y - pointAY) - (pointAX - idx) * (avgY - pointAY)),
20
- area > maxArea && (maxArea = area, nextIndex = idx));
21
- }
22
- newIndices[sampledIndex++] = nextIndex, currentIndex = nextIndex;
23
- }
24
- newIndices[sampledIndex - 1] !== len - 1 && (newIndices[sampledIndex++] = len - 1);
25
- return newIndices.map((i => isGroup ? array[i].i : i));
26
- }
27
-
28
- Object.defineProperty(exports, "__esModule", {
29
- value: !0
30
- }), exports.transform = void 0;
31
-
32
- const transform = (options, upstreamData) => {
33
- let size = options.size;
34
- const factor = options.factor || 1;
35
- if (Array.isArray(size) && (size = Math.floor(size[1] - size[0])), size *= factor,
36
- size <= 0) return [];
37
- if (upstreamData.length <= size) return upstreamData;
38
- if (options.skipfirst) return upstreamData.slice(0, 1);
39
- const {yfield: yfield, groupBy: groupBy} = options;
40
- if (upstreamData.length) {
41
- const groups = {};
42
- if (groupBy) {
43
- for (let i = 0, n = upstreamData.length; i < n; i++) {
44
- const datum = upstreamData[i], groupId = datum[groupBy];
45
- groups[groupId] || (groups[groupId] = []), groups[groupId].push({
46
- y: datum[yfield],
47
- i: i
48
- });
49
- }
50
- let rawIndice = [];
51
- return Object.keys(groups).forEach((groupName => {
52
- const group = groups[groupName];
53
- if (group.length <= size) {
54
- const indices = group.map((datum => datum.i));
55
- rawIndice = rawIndice.concat(indices);
56
- } else {
57
- const indices = lttb(size, group, !0);
58
- rawIndice = rawIndice.concat(indices);
59
- }
60
- })), rawIndice.sort(((a, b) => a - b)), rawIndice.map((index => upstreamData[index]));
61
- }
62
- return lttb(size, upstreamData, !1, yfield).map((index => upstreamData[index]));
63
- }
64
- return [];
65
- };
66
-
67
- exports.transform = transform;
68
- //# sourceMappingURL=lttb-sample.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/transforms/mark/lttb-sample.ts"],"names":[],"mappings":"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","file":"lttb-sample.js","sourcesContent":["import type { IElement, LttbSampleTransformOptions } from '../../types';\n\nfunction lttb(size: number, array: any[], isGroup: boolean, yfield?: string) {\n const frameSize = Math.floor(array.length / size);\n const newIndices = [];\n const len = array.length;\n\n let currentIndex = 0;\n let sampledIndex = 0;\n let maxArea;\n let area;\n let nextIndex;\n\n // First frame use the first data.\n newIndices[sampledIndex++] = currentIndex;\n\n for (let i = 1; i < len - 1; i += frameSize) {\n const nextFrameStart = Math.min(i + frameSize, len - 1);\n const nextFrameEnd = Math.min(i + frameSize * 2, len);\n\n const avgX = (nextFrameEnd + nextFrameStart) / 2;\n let avgY = 0;\n\n for (let idx = nextFrameStart; idx < nextFrameEnd; idx++) {\n const y = isGroup ? array[idx].y : array[idx][yfield];\n if (Number.isNaN(y)) {\n continue;\n }\n avgY += y;\n }\n avgY /= nextFrameEnd - nextFrameStart;\n\n const frameStart = i;\n const frameEnd = Math.min(i + frameSize, len);\n\n const pointAX = i - 1;\n const pointAY = isGroup ? array[currentIndex].y : array[currentIndex][yfield];\n\n maxArea = -1;\n\n nextIndex = frameStart;\n // Find a point from current frame that construct a triangel with largest area with previous selected point\n // And the average of next frame.\n for (let idx = frameStart; idx < frameEnd; idx++) {\n const y = isGroup ? array[idx].y : array[idx][yfield];\n if (Number.isNaN(y)) {\n continue;\n }\n // Calculate triangle area over three buckets\n area = Math.abs((pointAX - avgX) * (y - pointAY) - (pointAX - idx) * (avgY - pointAY));\n if (area > maxArea) {\n maxArea = area;\n nextIndex = idx; // Next a is this b\n }\n }\n\n newIndices[sampledIndex++] = nextIndex;\n\n currentIndex = nextIndex; // This a is the next a (chosen b)\n }\n\n // First frame use the last data.\n if (newIndices[sampledIndex - 1] !== len - 1) {\n newIndices[sampledIndex++] = len - 1;\n }\n\n // output newly added tuples\n const newRawIndices = newIndices.map(i => (isGroup ? array[i].i : i));\n return newRawIndices;\n}\n\n/**\n * Samples tuples passing through this operator.\n * Uses lttb sampling to maintain a trend-maintained sample.\n * @constructor\n * @param {object} options - The parameters for this operator.\n * @param {number} [options.size=1000] - The maximum number of samples.\n * @param {string} [options.xfield] - The xfield string of data.\n * @param {string} [options.yfield] - The yfield string of data.\n * @param {string} [options.groupBy] - The groupBy string of data.\n */\n\nexport const transform = (options: LttbSampleTransformOptions, upstreamData: IElement[]) => {\n let size = options.size;\n const factor = options.factor || 1;\n\n if (Array.isArray(size)) {\n size = Math.floor(size[1] - size[0]);\n }\n\n size *= factor;\n\n // size<=0的特殊情况不采样,返回空\n if (size <= 0) {\n return [];\n }\n\n // 数据<size的情况,不进行采样,保留所有数据\n if (upstreamData.length <= size) {\n return upstreamData;\n }\n\n const skipfirst = options.skipfirst;\n // 如果是ChartSpace的第一次数据流(evaluateAsync),不需要采样,返回一条数据供布局使用\n // 这里需要依据this.value.length判断是不是第一次数据流,\n // 以避免点击图例,updateChartData等操作清空所有label\n if (skipfirst) {\n return upstreamData.slice(0, 1);\n }\n\n const { yfield, groupBy } = options;\n\n // 处理数据source,source为采样前的原始数据\n if (upstreamData.length) {\n // 如果有groupBy,数据分组\n const groups = {};\n if (groupBy) {\n for (let i = 0, n = upstreamData.length; i < n; i++) {\n const datum = upstreamData[i];\n const groupId = datum[groupBy];\n if (groups[groupId]) {\n groups[groupId].push({ y: datum[yfield], i });\n } else {\n groups[groupId] = [];\n groups[groupId].push({ y: datum[yfield], i });\n }\n }\n\n // 分组采样\n let rawIndice: any[] = [];\n\n Object.keys(groups).forEach(groupName => {\n const group = groups[groupName];\n if (group.length <= size) {\n const indices = group.map((datum: any) => {\n return datum.i;\n });\n rawIndice = rawIndice.concat(indices);\n } else {\n const indices = lttb(size, group, true);\n rawIndice = rawIndice.concat(indices);\n }\n });\n\n // 采样后,整合分组数据,按照原始顺序排序\n rawIndice.sort((a, b) => a - b);\n\n return rawIndice.map((index: number) => upstreamData[index]);\n }\n // 非分组数据同理\n return lttb(size, upstreamData, false, yfield).map(index => upstreamData[index]);\n }\n\n return [];\n};\n"]}
@@ -1,2 +0,0 @@
1
- import type { IElement, LttbSampleTransformOptions } from '../../types';
2
- export declare const transform: (options: LttbSampleTransformOptions, upstreamData: IElement[]) => IElement[];
@@ -1,60 +0,0 @@
1
- function lttb(size, array, isGroup, yfield) {
2
- const frameSize = Math.floor(array.length / size), newIndices = [], len = array.length;
3
- let maxArea, area, nextIndex, currentIndex = 0, sampledIndex = 0;
4
- newIndices[sampledIndex++] = currentIndex;
5
- for (let i = 1; i < len - 1; i += frameSize) {
6
- const nextFrameStart = Math.min(i + frameSize, len - 1), nextFrameEnd = Math.min(i + 2 * frameSize, len), avgX = (nextFrameEnd + nextFrameStart) / 2;
7
- let avgY = 0;
8
- for (let idx = nextFrameStart; idx < nextFrameEnd; idx++) {
9
- const y = isGroup ? array[idx].y : array[idx][yfield];
10
- Number.isNaN(y) || (avgY += y);
11
- }
12
- avgY /= nextFrameEnd - nextFrameStart;
13
- const frameStart = i, frameEnd = Math.min(i + frameSize, len), pointAX = i - 1, pointAY = isGroup ? array[currentIndex].y : array[currentIndex][yfield];
14
- maxArea = -1, nextIndex = frameStart;
15
- for (let idx = frameStart; idx < frameEnd; idx++) {
16
- const y = isGroup ? array[idx].y : array[idx][yfield];
17
- Number.isNaN(y) || (area = Math.abs((pointAX - avgX) * (y - pointAY) - (pointAX - idx) * (avgY - pointAY)),
18
- area > maxArea && (maxArea = area, nextIndex = idx));
19
- }
20
- newIndices[sampledIndex++] = nextIndex, currentIndex = nextIndex;
21
- }
22
- newIndices[sampledIndex - 1] !== len - 1 && (newIndices[sampledIndex++] = len - 1);
23
- return newIndices.map((i => isGroup ? array[i].i : i));
24
- }
25
-
26
- export const transform = (options, upstreamData) => {
27
- let size = options.size;
28
- const factor = options.factor || 1;
29
- if (Array.isArray(size) && (size = Math.floor(size[1] - size[0])), size *= factor,
30
- size <= 0) return [];
31
- if (upstreamData.length <= size) return upstreamData;
32
- if (options.skipfirst) return upstreamData.slice(0, 1);
33
- const {yfield: yfield, groupBy: groupBy} = options;
34
- if (upstreamData.length) {
35
- const groups = {};
36
- if (groupBy) {
37
- for (let i = 0, n = upstreamData.length; i < n; i++) {
38
- const datum = upstreamData[i], groupId = datum[groupBy];
39
- groups[groupId] || (groups[groupId] = []), groups[groupId].push({
40
- y: datum[yfield],
41
- i: i
42
- });
43
- }
44
- let rawIndice = [];
45
- return Object.keys(groups).forEach((groupName => {
46
- const group = groups[groupName];
47
- if (group.length <= size) {
48
- const indices = group.map((datum => datum.i));
49
- rawIndice = rawIndice.concat(indices);
50
- } else {
51
- const indices = lttb(size, group, !0);
52
- rawIndice = rawIndice.concat(indices);
53
- }
54
- })), rawIndice.sort(((a, b) => a - b)), rawIndice.map((index => upstreamData[index]));
55
- }
56
- return lttb(size, upstreamData, !1, yfield).map((index => upstreamData[index]));
57
- }
58
- return [];
59
- };
60
- //# sourceMappingURL=lttb-sample.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/transforms/mark/lttb-sample.ts"],"names":[],"mappings":"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","file":"lttb-sample.js","sourcesContent":["import type { IElement, LttbSampleTransformOptions } from '../../types';\n\nfunction lttb(size: number, array: any[], isGroup: boolean, yfield?: string) {\n const frameSize = Math.floor(array.length / size);\n const newIndices = [];\n const len = array.length;\n\n let currentIndex = 0;\n let sampledIndex = 0;\n let maxArea;\n let area;\n let nextIndex;\n\n // First frame use the first data.\n newIndices[sampledIndex++] = currentIndex;\n\n for (let i = 1; i < len - 1; i += frameSize) {\n const nextFrameStart = Math.min(i + frameSize, len - 1);\n const nextFrameEnd = Math.min(i + frameSize * 2, len);\n\n const avgX = (nextFrameEnd + nextFrameStart) / 2;\n let avgY = 0;\n\n for (let idx = nextFrameStart; idx < nextFrameEnd; idx++) {\n const y = isGroup ? array[idx].y : array[idx][yfield];\n if (Number.isNaN(y)) {\n continue;\n }\n avgY += y;\n }\n avgY /= nextFrameEnd - nextFrameStart;\n\n const frameStart = i;\n const frameEnd = Math.min(i + frameSize, len);\n\n const pointAX = i - 1;\n const pointAY = isGroup ? array[currentIndex].y : array[currentIndex][yfield];\n\n maxArea = -1;\n\n nextIndex = frameStart;\n // Find a point from current frame that construct a triangel with largest area with previous selected point\n // And the average of next frame.\n for (let idx = frameStart; idx < frameEnd; idx++) {\n const y = isGroup ? array[idx].y : array[idx][yfield];\n if (Number.isNaN(y)) {\n continue;\n }\n // Calculate triangle area over three buckets\n area = Math.abs((pointAX - avgX) * (y - pointAY) - (pointAX - idx) * (avgY - pointAY));\n if (area > maxArea) {\n maxArea = area;\n nextIndex = idx; // Next a is this b\n }\n }\n\n newIndices[sampledIndex++] = nextIndex;\n\n currentIndex = nextIndex; // This a is the next a (chosen b)\n }\n\n // First frame use the last data.\n if (newIndices[sampledIndex - 1] !== len - 1) {\n newIndices[sampledIndex++] = len - 1;\n }\n\n // output newly added tuples\n const newRawIndices = newIndices.map(i => (isGroup ? array[i].i : i));\n return newRawIndices;\n}\n\n/**\n * Samples tuples passing through this operator.\n * Uses lttb sampling to maintain a trend-maintained sample.\n * @constructor\n * @param {object} options - The parameters for this operator.\n * @param {number} [options.size=1000] - The maximum number of samples.\n * @param {string} [options.xfield] - The xfield string of data.\n * @param {string} [options.yfield] - The yfield string of data.\n * @param {string} [options.groupBy] - The groupBy string of data.\n */\n\nexport const transform = (options: LttbSampleTransformOptions, upstreamData: IElement[]) => {\n let size = options.size;\n const factor = options.factor || 1;\n\n if (Array.isArray(size)) {\n size = Math.floor(size[1] - size[0]);\n }\n\n size *= factor;\n\n // size<=0的特殊情况不采样,返回空\n if (size <= 0) {\n return [];\n }\n\n // 数据<size的情况,不进行采样,保留所有数据\n if (upstreamData.length <= size) {\n return upstreamData;\n }\n\n const skipfirst = options.skipfirst;\n // 如果是ChartSpace的第一次数据流(evaluateAsync),不需要采样,返回一条数据供布局使用\n // 这里需要依据this.value.length判断是不是第一次数据流,\n // 以避免点击图例,updateChartData等操作清空所有label\n if (skipfirst) {\n return upstreamData.slice(0, 1);\n }\n\n const { yfield, groupBy } = options;\n\n // 处理数据source,source为采样前的原始数据\n if (upstreamData.length) {\n // 如果有groupBy,数据分组\n const groups = {};\n if (groupBy) {\n for (let i = 0, n = upstreamData.length; i < n; i++) {\n const datum = upstreamData[i];\n const groupId = datum[groupBy];\n if (groups[groupId]) {\n groups[groupId].push({ y: datum[yfield], i });\n } else {\n groups[groupId] = [];\n groups[groupId].push({ y: datum[yfield], i });\n }\n }\n\n // 分组采样\n let rawIndice: any[] = [];\n\n Object.keys(groups).forEach(groupName => {\n const group = groups[groupName];\n if (group.length <= size) {\n const indices = group.map((datum: any) => {\n return datum.i;\n });\n rawIndice = rawIndice.concat(indices);\n } else {\n const indices = lttb(size, group, true);\n rawIndice = rawIndice.concat(indices);\n }\n });\n\n // 采样后,整合分组数据,按照原始顺序排序\n rawIndice.sort((a, b) => a - b);\n\n return rawIndice.map((index: number) => upstreamData[index]);\n }\n // 非分组数据同理\n return lttb(size, upstreamData, false, yfield).map(index => upstreamData[index]);\n }\n\n return [];\n};\n"]}