@easyv/charts 1.0.60 → 1.0.61

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 (63) hide show
  1. package/.babelrc +8 -8
  2. package/lib/components/AnimateData.js +2 -2
  3. package/lib/components/Axis.js +12 -12
  4. package/lib/components/Background.js +2 -2
  5. package/lib/components/Carousel.js +2 -2
  6. package/lib/components/Chart.js +2 -2
  7. package/lib/components/ConicalGradient.js +21 -21
  8. package/lib/components/Indicator.js +2 -2
  9. package/lib/components/LinearGradient.js +2 -2
  10. package/lib/components/Tooltip.js +24 -4
  11. package/lib/css/index.module.css +41 -41
  12. package/lib/css/piechart.module.css +26 -26
  13. package/lib/hooks/useAnimateData.js +5 -5
  14. package/lib/hooks/useAxes.js +5 -5
  15. package/lib/hooks/useCarouselAxisX.js +5 -5
  16. package/lib/hooks/useExtentData.js +6 -6
  17. package/lib/hooks/useFilterData.js +5 -5
  18. package/lib/hooks/useStackData.js +5 -5
  19. package/lib/hooks/useTooltip.js +10 -10
  20. package/package.json +34 -34
  21. package/src/components/AnimateData.tsx +24 -24
  22. package/src/components/Axis.tsx +333 -333
  23. package/src/components/Background.tsx +45 -45
  24. package/src/components/Band.tsx +160 -160
  25. package/src/components/Brush.js +159 -159
  26. package/src/components/Carousel.tsx +144 -144
  27. package/src/components/Chart.js +99 -99
  28. package/src/components/ChartContainer.tsx +63 -63
  29. package/src/components/ConicalGradient.js +258 -258
  30. package/src/components/ExtentData.js +17 -17
  31. package/src/components/FilterData.js +23 -23
  32. package/src/components/Indicator.js +13 -13
  33. package/src/components/Label.js +193 -193
  34. package/src/components/Legend.js +158 -158
  35. package/src/components/Lighter.jsx +162 -162
  36. package/src/components/Line.js +126 -126
  37. package/src/components/LinearGradient.js +29 -29
  38. package/src/components/Mapping.js +71 -71
  39. package/src/components/PieChart.js +1092 -1092
  40. package/src/components/StackData.js +20 -20
  41. package/src/components/StereoBar.tsx +298 -298
  42. package/src/components/Tooltip.js +134 -117
  43. package/src/components/index.js +49 -49
  44. package/src/context/index.js +2 -2
  45. package/src/css/index.module.css +41 -41
  46. package/src/css/piechart.module.css +26 -26
  47. package/src/element/ConicGradient.jsx +55 -55
  48. package/src/element/Line.tsx +33 -33
  49. package/src/element/index.ts +3 -3
  50. package/src/formatter/index.js +1 -1
  51. package/src/formatter/legend.js +87 -87
  52. package/src/hooks/index.js +17 -17
  53. package/src/hooks/useAnimateData.ts +62 -62
  54. package/src/hooks/useAxes.js +143 -143
  55. package/src/hooks/useCarouselAxisX.js +163 -163
  56. package/src/hooks/useExtentData.js +88 -88
  57. package/src/hooks/useFilterData.js +72 -72
  58. package/src/hooks/useStackData.js +100 -100
  59. package/src/hooks/useTooltip.ts +96 -96
  60. package/src/index.js +6 -6
  61. package/src/types/index.d.ts +59 -59
  62. package/src/utils/index.js +640 -640
  63. package/tsconfig.json +22 -22
@@ -1,163 +1,163 @@
1
- import { useEffect, useState } from 'react';
2
- import { animate, linear } from 'popmotion';
3
-
4
- const initialState = {
5
- currentIndex: null,
6
- flag: false,
7
- };
8
-
9
- /**
10
- * x轴滚动逻辑
11
- * @param {Object} axis x轴配置项
12
- * @param {Object} config x轴轮播动画的配置项
13
- * @returns {Map} 返回经过改变后的x轴,主要是ticks和scaler的range发生了改变
14
- */
15
-
16
- export default (axis, config) => {
17
- const { show, interval, duration } = config;
18
- const time = duration + interval;
19
-
20
- const {
21
- tickCount,
22
- allTicks,
23
- scaler,
24
- start,
25
- end,
26
- step,
27
- ticks,
28
- lengthWithoutPaddingOuter,
29
- } = axis;
30
- const tickLength = ticks.length;
31
-
32
- const [state, setState] = useState({
33
- scaler,
34
- step,
35
- ticks,
36
- });
37
- const [status, setStatus] = useState(initialState);
38
-
39
- useEffect(() => {
40
- let handler;
41
- if (show && time && tickLength > tickCount) {
42
- setStatus({
43
- currentIndex: 0,
44
- flag: true,
45
- });
46
- handler = setInterval(() => {
47
- setStatus(({ currentIndex }) => {
48
- const tmp = +currentIndex + 1;
49
- return {
50
- currentIndex: tmp >= tickLength ? 0 : tmp,
51
- flag: false,
52
- };
53
- });
54
- }, time * 1000);
55
- } else {
56
- setStatus(initialState);
57
- }
58
- return () => {
59
- handler && clearInterval(handler);
60
- };
61
- }, [show, time, tickCount, tickLength]);
62
-
63
- useEffect(() => {
64
- let animation;
65
- const { currentIndex, flag } = status;
66
- if (currentIndex !== null) {
67
- const step = lengthWithoutPaddingOuter / tickCount;
68
- if (flag) {
69
- const _ticks = allTicks.slice(currentIndex, tickCount);
70
- setState({
71
- step,
72
- ticks: _ticks,
73
- scaler: scaler.copy().domain(_ticks).range([start, end]),
74
- });
75
- } else {
76
- animation = animate({
77
- from: 0,
78
- to: -1,
79
- duration: duration * 1000,
80
- ease: linear,
81
- onPlay: () => {
82
- setState((axis) => {
83
- const { ticks, scaler } = axis;
84
- const [tick] = ticks;
85
- const _ticks = [
86
- tick,
87
- ...getTicks(allTicks, currentIndex, tickCount),
88
- ];
89
- return {
90
- ...axis,
91
- ticks: _ticks,
92
- scaler: scaler
93
- .copy()
94
- .range([start, end + step])
95
- .domain(_ticks),
96
- };
97
- });
98
- },
99
- onUpdate: (v) => {
100
- setState((axis) => {
101
- const { scaler, step } = axis;
102
- return {
103
- ...axis,
104
- scaler: scaler
105
- .copy()
106
- .range([start + step * v, end + step + step * v]),
107
- };
108
- });
109
- },
110
- onComplete: () => {
111
- setState((axis) => {
112
- const { scaler, ticks } = axis;
113
- const _ticks = ticks.slice(1, ticks.length);
114
- return {
115
- ...axis,
116
- ticks: _ticks,
117
- scaler: scaler.copy().range([start, end]).domain(_ticks),
118
- };
119
- });
120
- },
121
- });
122
- }
123
- } else {
124
- const _ticks = scaler.type == 'linear' ? scaler.domain() : allTicks;
125
- setState({
126
- step,
127
- scaler: scaler.copy().domain(_ticks).range([start, end]),
128
- ticks,
129
- });
130
- }
131
- return () => {
132
- animation && animation.stop();
133
- };
134
- }, [
135
- tickCount,
136
- allTicks,
137
- scaler,
138
- start,
139
- end,
140
- step,
141
- ticks,
142
- lengthWithoutPaddingOuter,
143
- status,
144
- duration,
145
- ]);
146
- return {
147
- ...axis,
148
- ...state,
149
- };
150
- };
151
-
152
- const getTicks = (ticks, currentIndex, length) => {
153
- const _currentIndex = +currentIndex;
154
- const ticksLength = ticks.length;
155
- if (ticksLength <= length) return ticks;
156
- const end = _currentIndex + length;
157
- if (ticksLength < end) {
158
- const prev = ticks.slice(_currentIndex, ticksLength);
159
- const next = ticks.slice(0, end - ticksLength);
160
- return [...prev, ...next];
161
- }
162
- return ticks.slice(_currentIndex, end);
163
- };
1
+ import { useEffect, useState } from 'react';
2
+ import { animate, linear } from 'popmotion';
3
+
4
+ const initialState = {
5
+ currentIndex: null,
6
+ flag: false,
7
+ };
8
+
9
+ /**
10
+ * x轴滚动逻辑
11
+ * @param {Object} axis x轴配置项
12
+ * @param {Object} config x轴轮播动画的配置项
13
+ * @returns {Map} 返回经过改变后的x轴,主要是ticks和scaler的range发生了改变
14
+ */
15
+
16
+ export default (axis, config) => {
17
+ const { show, interval, duration } = config;
18
+ const time = duration + interval;
19
+
20
+ const {
21
+ tickCount,
22
+ allTicks,
23
+ scaler,
24
+ start,
25
+ end,
26
+ step,
27
+ ticks,
28
+ lengthWithoutPaddingOuter,
29
+ } = axis;
30
+ const tickLength = ticks.length;
31
+
32
+ const [state, setState] = useState({
33
+ scaler,
34
+ step,
35
+ ticks,
36
+ });
37
+ const [status, setStatus] = useState(initialState);
38
+
39
+ useEffect(() => {
40
+ let handler;
41
+ if (show && time && tickLength > tickCount) {
42
+ setStatus({
43
+ currentIndex: 0,
44
+ flag: true,
45
+ });
46
+ handler = setInterval(() => {
47
+ setStatus(({ currentIndex }) => {
48
+ const tmp = +currentIndex + 1;
49
+ return {
50
+ currentIndex: tmp >= tickLength ? 0 : tmp,
51
+ flag: false,
52
+ };
53
+ });
54
+ }, time * 1000);
55
+ } else {
56
+ setStatus(initialState);
57
+ }
58
+ return () => {
59
+ handler && clearInterval(handler);
60
+ };
61
+ }, [show, time, tickCount, tickLength]);
62
+
63
+ useEffect(() => {
64
+ let animation;
65
+ const { currentIndex, flag } = status;
66
+ if (currentIndex !== null) {
67
+ const step = lengthWithoutPaddingOuter / tickCount;
68
+ if (flag) {
69
+ const _ticks = allTicks.slice(currentIndex, tickCount);
70
+ setState({
71
+ step,
72
+ ticks: _ticks,
73
+ scaler: scaler.copy().domain(_ticks).range([start, end]),
74
+ });
75
+ } else {
76
+ animation = animate({
77
+ from: 0,
78
+ to: -1,
79
+ duration: duration * 1000,
80
+ ease: linear,
81
+ onPlay: () => {
82
+ setState((axis) => {
83
+ const { ticks, scaler } = axis;
84
+ const [tick] = ticks;
85
+ const _ticks = [
86
+ tick,
87
+ ...getTicks(allTicks, currentIndex, tickCount),
88
+ ];
89
+ return {
90
+ ...axis,
91
+ ticks: _ticks,
92
+ scaler: scaler
93
+ .copy()
94
+ .range([start, end + step])
95
+ .domain(_ticks),
96
+ };
97
+ });
98
+ },
99
+ onUpdate: (v) => {
100
+ setState((axis) => {
101
+ const { scaler, step } = axis;
102
+ return {
103
+ ...axis,
104
+ scaler: scaler
105
+ .copy()
106
+ .range([start + step * v, end + step + step * v]),
107
+ };
108
+ });
109
+ },
110
+ onComplete: () => {
111
+ setState((axis) => {
112
+ const { scaler, ticks } = axis;
113
+ const _ticks = ticks.slice(1, ticks.length);
114
+ return {
115
+ ...axis,
116
+ ticks: _ticks,
117
+ scaler: scaler.copy().range([start, end]).domain(_ticks),
118
+ };
119
+ });
120
+ },
121
+ });
122
+ }
123
+ } else {
124
+ const _ticks = scaler.type == 'linear' ? scaler.domain() : allTicks;
125
+ setState({
126
+ step,
127
+ scaler: scaler.copy().domain(_ticks).range([start, end]),
128
+ ticks,
129
+ });
130
+ }
131
+ return () => {
132
+ animation && animation.stop();
133
+ };
134
+ }, [
135
+ tickCount,
136
+ allTicks,
137
+ scaler,
138
+ start,
139
+ end,
140
+ step,
141
+ ticks,
142
+ lengthWithoutPaddingOuter,
143
+ status,
144
+ duration,
145
+ ]);
146
+ return {
147
+ ...axis,
148
+ ...state,
149
+ };
150
+ };
151
+
152
+ const getTicks = (ticks, currentIndex, length) => {
153
+ const _currentIndex = +currentIndex;
154
+ const ticksLength = ticks.length;
155
+ if (ticksLength <= length) return ticks;
156
+ const end = _currentIndex + length;
157
+ if (ticksLength < end) {
158
+ const prev = ticks.slice(_currentIndex, ticksLength);
159
+ const next = ticks.slice(0, end - ticksLength);
160
+ return [...prev, ...next];
161
+ }
162
+ return ticks.slice(_currentIndex, end);
163
+ };
@@ -1,88 +1,88 @@
1
- import { useMemo } from 'react';
2
- import { group, extent } from 'd3v7';
3
- import {
4
- getStacks,
5
- dataYOrZ,
6
- seriesYOrZ,
7
- resetStacks,
8
- getCurrentStack,
9
- } from '../utils';
10
-
11
- const stackData = (data, series) => {
12
- const dataMap = group(data, (d) => d.x);
13
- const stacks = getStacks(series);
14
- let min = 0,
15
- max = 0;
16
-
17
- dataMap.forEach((value) => {
18
- const arr = [];
19
- resetStacks(stacks);
20
- for (let i = 0, j = value.length; i < j; i++) {
21
- const d = value[i];
22
- const stack = series.get(d.s);
23
- if (d && d.y !== undefined && !isNaN(d.y)) {
24
- const currentStack = getCurrentStack(stack, stacks);
25
- if (stack && currentStack) {
26
- if (d.y >= 0) {
27
- currentStack.positive += d.y;
28
- arr.push(currentStack.positive);
29
- } else {
30
- currentStack.negative += d.y;
31
- arr.push(currentStack.negative);
32
- }
33
- } else {
34
- arr.push(d.y);
35
- }
36
- }
37
- }
38
- min = Math.min(...arr, min);
39
- max = Math.max(...arr, max);
40
- });
41
- dataMap.clear();
42
- return [min, max];
43
- };
44
-
45
- /**
46
- * 计算轴的domain
47
- * @param {Array} axes x轴列表
48
- * @param {Object} series 图表的系列,主要是为了读取type, stack, yOrZ三个字段
49
- * @param {Object} data 数据列表
50
- * @returns {Array} 返回带domain的轴
51
- */
52
-
53
- export default ({ axes, series, data }) => {
54
- const _series = useMemo(() => seriesYOrZ(series), [series]);
55
- const { y: dataY, z: dataZ } = useMemo(
56
- () => dataYOrZ(data, _series),
57
- [data, _series]
58
- );
59
-
60
- const x = useMemo(() => [...group(data, (d) => d.x).keys()], [data]);
61
- const y = stackData(dataY, _series.y);
62
- const z = stackData(dataZ, _series.z);
63
-
64
- return axes.map((item) => {
65
- const { axisType, domain, type } = item;
66
- switch (axisType) {
67
- case 'x':
68
- return {
69
- ...item,
70
- domain: type == 'linear' ? extent(x) : x,
71
- };
72
- case 'y':
73
- return {
74
- ...item,
75
- domain: domain ? getDomain(y, domain) : y,
76
- };
77
- case 'z':
78
- return {
79
- ...item,
80
- domain: domain ? getDomain(z, domain) : z,
81
- };
82
- }
83
- });
84
- };
85
-
86
- const getDomain = ([min1, max1], { min, max }) => {
87
- return [min !== '' ? +min : min1, max !== '' ? +max : max1];
88
- };
1
+ import { useMemo } from 'react';
2
+ import { group, extent } from 'd3v7';
3
+ import {
4
+ getStacks,
5
+ dataYOrZ,
6
+ seriesYOrZ,
7
+ resetStacks,
8
+ getCurrentStack,
9
+ } from '../utils';
10
+
11
+ const stackData = (data, series) => {
12
+ const dataMap = group(data, (d) => d.x);
13
+ const stacks = getStacks(series);
14
+ let min = 0,
15
+ max = 0;
16
+
17
+ dataMap.forEach((value) => {
18
+ const arr = [];
19
+ resetStacks(stacks);
20
+ for (let i = 0, j = value.length; i < j; i++) {
21
+ const d = value[i];
22
+ const stack = series.get(d.s);
23
+ if (d && d.y !== undefined && !isNaN(d.y)) {
24
+ const currentStack = getCurrentStack(stack, stacks);
25
+ if (stack && currentStack) {
26
+ if (d.y >= 0) {
27
+ currentStack.positive += d.y;
28
+ arr.push(currentStack.positive);
29
+ } else {
30
+ currentStack.negative += d.y;
31
+ arr.push(currentStack.negative);
32
+ }
33
+ } else {
34
+ arr.push(d.y);
35
+ }
36
+ }
37
+ }
38
+ min = Math.min(...arr, min);
39
+ max = Math.max(...arr, max);
40
+ });
41
+ dataMap.clear();
42
+ return [min, max];
43
+ };
44
+
45
+ /**
46
+ * 计算轴的domain
47
+ * @param {Array} axes x轴列表
48
+ * @param {Object} series 图表的系列,主要是为了读取type, stack, yOrZ三个字段
49
+ * @param {Object} data 数据列表
50
+ * @returns {Array} 返回带domain的轴
51
+ */
52
+
53
+ export default ({ axes, series, data }) => {
54
+ const _series = useMemo(() => seriesYOrZ(series), [series]);
55
+ const { y: dataY, z: dataZ } = useMemo(
56
+ () => dataYOrZ(data, _series),
57
+ [data, _series]
58
+ );
59
+
60
+ const x = useMemo(() => [...group(data, (d) => d.x).keys()], [data]);
61
+ const y = stackData(dataY, _series.y);
62
+ const z = stackData(dataZ, _series.z);
63
+
64
+ return axes.map((item) => {
65
+ const { axisType, domain, type } = item;
66
+ switch (axisType) {
67
+ case 'x':
68
+ return {
69
+ ...item,
70
+ domain: type == 'linear' ? extent(x) : x,
71
+ };
72
+ case 'y':
73
+ return {
74
+ ...item,
75
+ domain: domain ? getDomain(y, domain) : y,
76
+ };
77
+ case 'z':
78
+ return {
79
+ ...item,
80
+ domain: domain ? getDomain(z, domain) : z,
81
+ };
82
+ }
83
+ });
84
+ };
85
+
86
+ const getDomain = ([min1, max1], { min, max }) => {
87
+ return [min !== '' ? +min : min1, max !== '' ? +max : max1];
88
+ };
@@ -1,72 +1,72 @@
1
- import { useState, useCallback, useEffect, useMemo } from 'react';
2
-
3
- const getInitialSelected = (series) => {
4
- const status = new Map();
5
- for (let [name] of series.entries()) {
6
- status.set(name, true);
7
- }
8
- return status;
9
- };
10
-
11
- const getSelected = (selected, name) => {
12
- const tmp = new Map();
13
- selected.forEach((value, key) => {
14
- if (name == key) {
15
- tmp.set(key, !value);
16
- } else {
17
- tmp.set(key, value);
18
- }
19
- });
20
- return tmp;
21
- };
22
-
23
- /**
24
- * 图例点击状态管理
25
- * @param {Array} data 数据
26
- * @param {Map} series 系列
27
- * @returns {Array} 返回筛选后的数据和是否选中状态,及控制选中函数
28
- */
29
-
30
- export default ({ data, series }) => {
31
- const [selected, setSelected] = useState(getInitialSelected(series));
32
-
33
- const _series = useMemo(() => {
34
- const tmp = new Map();
35
- series.forEach((currentSeries, key) => {
36
- const value = selected.get(key);
37
- tmp.set(key, {
38
- ...currentSeries,
39
- selected: value,
40
- });
41
- });
42
- return tmp;
43
- }, [selected, series]);
44
-
45
- const _data = useMemo(() => {
46
- return data.filter(({ s }) => {
47
- return s && _series.get(s) && _series.get(s).selected;
48
- });
49
- }, [data, _series]);
50
-
51
- const onClick = useCallback((name) => {
52
- setSelected((selected) => getSelected(selected, name));
53
- }, []);
54
-
55
- useEffect(() => {
56
- setSelected(getInitialSelected(series));
57
- }, [series]);
58
-
59
- return [
60
- {
61
- series: _series,
62
- data: _data.map(d=>{
63
- return {
64
- ...d,
65
- y:parseFloat(d.y),
66
- showY:d.y
67
- }
68
- }),
69
- },
70
- onClick,
71
- ];
72
- };
1
+ import { useState, useCallback, useEffect, useMemo } from 'react';
2
+
3
+ const getInitialSelected = (series) => {
4
+ const status = new Map();
5
+ for (let [name] of series.entries()) {
6
+ status.set(name, true);
7
+ }
8
+ return status;
9
+ };
10
+
11
+ const getSelected = (selected, name) => {
12
+ const tmp = new Map();
13
+ selected.forEach((value, key) => {
14
+ if (name == key) {
15
+ tmp.set(key, !value);
16
+ } else {
17
+ tmp.set(key, value);
18
+ }
19
+ });
20
+ return tmp;
21
+ };
22
+
23
+ /**
24
+ * 图例点击状态管理
25
+ * @param {Array} data 数据
26
+ * @param {Map} series 系列
27
+ * @returns {Array} 返回筛选后的数据和是否选中状态,及控制选中函数
28
+ */
29
+
30
+ export default ({ data, series }) => {
31
+ const [selected, setSelected] = useState(getInitialSelected(series));
32
+
33
+ const _series = useMemo(() => {
34
+ const tmp = new Map();
35
+ series.forEach((currentSeries, key) => {
36
+ const value = selected.get(key);
37
+ tmp.set(key, {
38
+ ...currentSeries,
39
+ selected: value,
40
+ });
41
+ });
42
+ return tmp;
43
+ }, [selected, series]);
44
+
45
+ const _data = useMemo(() => {
46
+ return data.filter(({ s }) => {
47
+ return s && _series.get(s) && _series.get(s).selected;
48
+ });
49
+ }, [data, _series]);
50
+
51
+ const onClick = useCallback((name) => {
52
+ setSelected((selected) => getSelected(selected, name));
53
+ }, []);
54
+
55
+ useEffect(() => {
56
+ setSelected(getInitialSelected(series));
57
+ }, [series]);
58
+
59
+ return [
60
+ {
61
+ series: _series,
62
+ data: _data.map(d=>{
63
+ return {
64
+ ...d,
65
+ y:parseFloat(d.y),
66
+ showY:d.y
67
+ }
68
+ }),
69
+ },
70
+ onClick,
71
+ ];
72
+ };