@easyv/charts 1.1.7 → 1.2.1

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 (86) hide show
  1. package/.babelrc +8 -8
  2. package/.husky/commit-msg +3 -3
  3. package/CHANGELOG.md +18 -18
  4. package/commitlint.config.js +1 -1
  5. package/lib/components/AnimateData.js +36 -36
  6. package/lib/components/Axis.js +329 -329
  7. package/lib/components/Background.js +2 -2
  8. package/lib/components/Band.js +173 -173
  9. package/lib/components/Brush.js +201 -201
  10. package/lib/components/Carousel.js +164 -164
  11. package/lib/components/Chart.js +111 -111
  12. package/lib/components/ChartContainer.js +58 -58
  13. package/lib/components/ConicalGradient.js +264 -264
  14. package/lib/components/ExtentData.js +45 -45
  15. package/lib/components/FilterData.js +53 -53
  16. package/lib/components/Indicator.js +2 -2
  17. package/lib/components/Label.js +278 -278
  18. package/lib/components/Legend.js +154 -154
  19. package/lib/components/Lighter.js +179 -179
  20. package/lib/components/Line.js +181 -181
  21. package/lib/components/LinearGradient.js +2 -2
  22. package/lib/components/Mapping.js +127 -127
  23. package/lib/components/PieChart.js +1061 -1061
  24. package/lib/components/StackData.js +45 -45
  25. package/lib/components/StereoBar.js +336 -336
  26. package/lib/components/Tooltip.js +155 -155
  27. package/lib/components/index.js +194 -194
  28. package/lib/css/index.module.css +41 -41
  29. package/lib/css/piechart.module.css +26 -26
  30. package/lib/element/ConicGradient.js +72 -72
  31. package/lib/formatter/legend.js +91 -91
  32. package/lib/hooks/index.js +62 -62
  33. package/lib/hooks/useAnimateData.js +88 -88
  34. package/lib/hooks/useAxes.js +135 -135
  35. package/lib/hooks/useCarouselAxisX.js +184 -184
  36. package/lib/hooks/useExtentData.js +128 -128
  37. package/lib/hooks/useFilterData.js +112 -112
  38. package/lib/hooks/useStackData.js +134 -134
  39. package/lib/hooks/useTooltip.js +10 -10
  40. package/lib/index.js +84 -84
  41. package/lib/utils/index.js +832 -832
  42. package/package.json +51 -51
  43. package/src/components/AnimateData.tsx +24 -24
  44. package/src/components/Axis.tsx +354 -354
  45. package/src/components/Background.tsx +45 -45
  46. package/src/components/Band.tsx +173 -173
  47. package/src/components/Brush.js +159 -159
  48. package/src/components/Carousel.tsx +144 -144
  49. package/src/components/Chart.js +99 -99
  50. package/src/components/ChartContainer.tsx +63 -63
  51. package/src/components/ConicalGradient.js +258 -258
  52. package/src/components/ExtentData.js +17 -17
  53. package/src/components/FilterData.js +23 -23
  54. package/src/components/Indicator.js +13 -13
  55. package/src/components/Label.js +206 -206
  56. package/src/components/Legend.js +158 -158
  57. package/src/components/Lighter.jsx +173 -173
  58. package/src/components/Line.js +144 -144
  59. package/src/components/LinearGradient.js +29 -29
  60. package/src/components/Mapping.js +71 -71
  61. package/src/components/Marquee.js +74 -0
  62. package/src/components/PieChart.js +1097 -1097
  63. package/src/components/StackData.js +20 -20
  64. package/src/components/StereoBar.tsx +310 -310
  65. package/src/components/Tooltip.js +169 -168
  66. package/src/components/index.js +51 -51
  67. package/src/context/index.js +2 -2
  68. package/src/css/index.module.css +41 -41
  69. package/src/css/piechart.module.css +26 -26
  70. package/src/element/ConicGradient.jsx +55 -55
  71. package/src/element/Line.tsx +33 -33
  72. package/src/element/index.ts +3 -3
  73. package/src/formatter/index.js +1 -1
  74. package/src/formatter/legend.js +90 -90
  75. package/src/hooks/index.js +17 -17
  76. package/src/hooks/useAnimateData.ts +67 -62
  77. package/src/hooks/useAxes.js +144 -144
  78. package/src/hooks/useCarouselAxisX.js +163 -163
  79. package/src/hooks/useExtentData.js +88 -88
  80. package/src/hooks/useFilterData.js +72 -72
  81. package/src/hooks/useStackData.js +100 -100
  82. package/src/hooks/useTooltip.ts +96 -96
  83. package/src/index.js +6 -6
  84. package/src/types/index.d.ts +67 -62
  85. package/src/utils/index.js +696 -696
  86. package/tsconfig.json +22 -22
@@ -1,168 +1,169 @@
1
- /**
2
- * 提示框
3
- */
4
- import { memo, useMemo } from 'react';
5
- import { getFontStyle, getMargin, getTranslate3d } from '../utils';
6
- import { getIcon } from '../utils';
7
- export default memo(
8
- ({
9
- x: position,
10
- tickName: x,
11
- marginLeft,
12
- marginTop,
13
- data,
14
- series,
15
- config: {
16
- tip: {
17
- data: {
18
- xAxis,
19
- xAxis: { align, font, translate: translateXAxis },
20
- data: dataConfig,
21
- data: { lineHeight, iconSize, name, value, suffix },
22
- },
23
- image,
24
- margin,
25
- size: { width: tipWidth, height: tipHeight },
26
- translate: translateTip,
27
- },
28
- },
29
- formatter,
30
- isVertical,
31
- width,
32
- height,
33
- }) => {
34
- const tipPosition = useMemo(() => {
35
- const translate3d = isVertical
36
- ? {
37
- ...translateTip,
38
- y: translateTip.y + position + marginTop,
39
- }
40
- : {
41
- ...translateTip,
42
- x: translateTip.x + position + marginLeft,
43
- };
44
- if (translate3d.x + tipWidth > width) {
45
- const newPositon = position + marginLeft - tipWidth - translateTip.x;
46
- translate3d.x = newPositon >= 0 ? newPositon : 0;
47
- }
48
- if (translate3d.y + tipHeight > height) {
49
- const newPositon = position + marginTop - tipHeight - translateTip.y;
50
- translate3d.y = newPositon >= 0 ? newPositon : height - tipHeight;
51
- }
52
- return getTranslate3d(translate3d);
53
- }, [
54
- width,
55
- height,
56
- marginLeft,
57
- marginTop,
58
- position,
59
- tipWidth,
60
- tipHeight,
61
- translateTip,
62
- ]);
63
-
64
- return (
65
- <div
66
- className='__easyv-tooltip'
67
- style={{
68
- pointerEvents: 'none',
69
- transform: tipPosition,
70
- width: tipWidth,
71
- height: tipHeight,
72
- padding: getMargin(margin),
73
- background: image
74
- ? '50% 50% / 100% 100% no-repeat url(' +
75
- window.appConfig.ASSETS_URL +
76
- image +
77
- ')'
78
- : 'rgba(48, 55, 66, 0.85)',
79
- ...getFontStyle(font),
80
- }}
81
- >
82
- {formatter ? (
83
- formatter({
84
- series,
85
- x: { x, config: xAxis },
86
- data: { data, config: dataConfig },
87
- })
88
- ) : (
89
- <dl
90
- style={{
91
- display: 'flex',
92
- flexDirection: 'column',
93
- justifyContent: 'space-between',
94
- height: '100%',
95
- }}
96
- >
97
- <dt
98
- style={{
99
- textAlign: align,
100
- transform: getTranslate3d(translateXAxis),
101
- ...font,
102
- }}
103
- >
104
- {x}
105
- </dt>
106
- {data.map(({ showY, s }, index) => {
107
- const { type, icon, displayName } = series.find(
108
- (series) => series.name == s
109
- );
110
- const {
111
- show: showSuffix,
112
- content,
113
- font: suffiixFont,
114
- translate: suffixTranslate,
115
- } = suffix;
116
- const tmp = new Map();
117
- Object.values(content).forEach((item) => {
118
- tmp.set(item['suffix'].name, item['suffix'].suffix);
119
- });
120
- const _icon = getIcon(type, icon);
121
- return (
122
- <dd
123
- style={{
124
- display: 'flex',
125
- justifyContent: 'space-between',
126
- lineHeight: lineHeight + 'px',
127
- }}
128
- key={index}
129
- >
130
- <span
131
- style={{
132
- border: '1px solid red',
133
- display: 'flex',
134
- alignItems: 'center',
135
- gap: icon.iconGap,
136
- }}
137
- >
138
- <span
139
- style={{
140
- ..._icon,
141
- width: iconSize + 'px',
142
- height: iconSize + 'px',
143
- }}
144
- />
145
- <span style={getFontStyle(name)}>{displayName || s}</span>
146
- </span>
147
- <span style={getFontStyle(value)}>
148
- {showY}
149
- {showSuffix && (
150
- <span
151
- style={{
152
- ...getFontStyle(suffiixFont),
153
- transform: getTranslate3d(suffixTranslate),
154
- }}
155
- >
156
- {tmp.get(s)}
157
- </span>
158
- )}
159
- </span>
160
- </dd>
161
- );
162
- })}
163
- </dl>
164
- )}
165
- </div>
166
- );
167
- }
168
- );
1
+ /**
2
+ * 提示框
3
+ */
4
+ import { memo, useMemo } from 'react';
5
+ import { getFontStyle, getMargin, getTranslate3d } from '../utils';
6
+ import { getIcon } from '../utils';
7
+ export default memo(
8
+ ({
9
+ x: position,
10
+ tickName: x,
11
+ marginLeft,
12
+ marginTop,
13
+ data,
14
+ series,
15
+ config: {
16
+ tip: {
17
+ data: {
18
+ xAxis,
19
+ xAxis: { align, font, translate: translateXAxis },
20
+ data: dataConfig,
21
+ data: { lineHeight, iconSize, name, value, suffix },
22
+ },
23
+ image,
24
+ margin,
25
+ size: { width: tipWidth, height: tipHeight },
26
+ translate: translateTip,
27
+ },
28
+ },
29
+ formatter,
30
+ isVertical,
31
+ width,
32
+ height,
33
+ }) => {
34
+ const tipPosition = useMemo(() => {
35
+ const translate3d = isVertical
36
+ ? {
37
+ ...translateTip,
38
+ y: translateTip.y + position + marginTop,
39
+ }
40
+ : {
41
+ ...translateTip,
42
+ x: translateTip.x + position + marginLeft,
43
+ };
44
+
45
+ if (translate3d.x + tipWidth > width) {
46
+ const newPositon = position + marginLeft - tipWidth - translateTip.x;
47
+ translate3d.x = newPositon >= 0 ? newPositon : 0;
48
+ }
49
+ if (translate3d.y + tipHeight > height) {
50
+ const newPositon = position + marginTop - tipHeight - translateTip.y;
51
+ translate3d.y = newPositon <= 0 ? newPositon : height - tipHeight;
52
+ }
53
+ return getTranslate3d(translate3d);
54
+ }, [
55
+ width,
56
+ height,
57
+ marginLeft,
58
+ marginTop,
59
+ position,
60
+ tipWidth,
61
+ tipHeight,
62
+ translateTip,
63
+ ]);
64
+
65
+ return (
66
+ <div
67
+ className='__easyv-tooltip'
68
+ style={{
69
+ pointerEvents: 'none',
70
+ transform: tipPosition,
71
+ width: tipWidth,
72
+ height: tipHeight,
73
+ padding: getMargin(margin),
74
+ background: image
75
+ ? '50% 50% / 100% 100% no-repeat url(' +
76
+ window.appConfig.ASSETS_URL +
77
+ image +
78
+ ')'
79
+ : 'rgba(48, 55, 66, 0.85)',
80
+ ...getFontStyle(font),
81
+ }}
82
+ >
83
+ {formatter ? (
84
+ formatter({
85
+ series,
86
+ x: { x, config: xAxis },
87
+ data: { data, config: dataConfig },
88
+ })
89
+ ) : (
90
+ <dl
91
+ style={{
92
+ display: 'flex',
93
+ flexDirection: 'column',
94
+ justifyContent: 'space-between',
95
+ height: '100%',
96
+ }}
97
+ >
98
+ <dt
99
+ style={{
100
+ textAlign: align,
101
+ transform: getTranslate3d(translateXAxis),
102
+ ...font,
103
+ }}
104
+ >
105
+ {x}
106
+ </dt>
107
+ {data.map(({ showY, s }, index) => {
108
+ const { type, icon, displayName } = series.find(
109
+ (series) => series.name == s
110
+ );
111
+ const {
112
+ show: showSuffix,
113
+ content,
114
+ font: suffiixFont,
115
+ translate: suffixTranslate,
116
+ } = suffix;
117
+ const tmp = new Map();
118
+ Object.values(content).forEach((item) => {
119
+ tmp.set(item['suffix'].name, item['suffix'].suffix);
120
+ });
121
+ const _icon = getIcon(type, icon);
122
+ return (
123
+ <dd
124
+ style={{
125
+ display: 'flex',
126
+ justifyContent: 'space-between',
127
+ lineHeight: lineHeight + 'px',
128
+ }}
129
+ key={index}
130
+ >
131
+ <span
132
+ style={{
133
+ border: '1px solid red',
134
+ display: 'flex',
135
+ alignItems: 'center',
136
+ gap: icon.iconGap,
137
+ }}
138
+ >
139
+ <span
140
+ style={{
141
+ ..._icon,
142
+ width: iconSize + 'px',
143
+ height: iconSize + 'px',
144
+ }}
145
+ />
146
+ <span style={getFontStyle(name)}>{displayName || s}</span>
147
+ </span>
148
+ <span style={getFontStyle(value)}>
149
+ {showY}
150
+ {showSuffix && (
151
+ <span
152
+ style={{
153
+ ...getFontStyle(suffiixFont),
154
+ transform: getTranslate3d(suffixTranslate),
155
+ }}
156
+ >
157
+ {tmp.get(s)}
158
+ </span>
159
+ )}
160
+ </span>
161
+ </dd>
162
+ );
163
+ })}
164
+ </dl>
165
+ )}
166
+ </div>
167
+ );
168
+ }
169
+ );
@@ -1,51 +1,51 @@
1
- import Mapping from './Mapping';
2
- import AnimateData from './AnimateData';
3
- import FilterData from './FilterData';
4
- import ExtentData from './ExtentData';
5
- import StackData from './StackData';
6
- import ChartContainer from './ChartContainer';
7
- import Legend from './Legend';
8
- import Axis from './Axis';
9
- import Tooltip from './Tooltip';
10
- import Indicator from './Indicator';
11
- import Band from './Band';
12
- import Lighter from './Lighter';
13
- import Line from './Line';
14
- import Background from './Background';
15
- import LinearGradient from './LinearGradient';
16
- import Brush from './Brush';
17
- import Label from './Label';
18
- import StereoBar from './StereoBar';
19
- import Carousel from './Carousel';
20
- import Chart from './Chart';
21
- import ConicalGradient from './ConicalGradient';
22
- import CartesianChart from './CartesianChart';
23
- import PieChart from './PieChart';
24
-
25
- const Area = Line;
26
- export {
27
- Mapping,
28
- AnimateData,
29
- FilterData,
30
- StackData,
31
- ExtentData,
32
- ChartContainer,
33
- Legend,
34
- Tooltip,
35
- Axis,
36
- Indicator,
37
- Band,
38
- Lighter,
39
- Line,
40
- Area,
41
- Background,
42
- LinearGradient,
43
- Brush,
44
- Label,
45
- StereoBar,
46
- Carousel,
47
- CartesianChart,
48
- PieChart,
49
- Chart,
50
- ConicalGradient,
51
- };
1
+ import Mapping from './Mapping';
2
+ import AnimateData from './AnimateData';
3
+ import FilterData from './FilterData';
4
+ import ExtentData from './ExtentData';
5
+ import StackData from './StackData';
6
+ import ChartContainer from './ChartContainer';
7
+ import Legend from './Legend';
8
+ import Axis from './Axis';
9
+ import Tooltip from './Tooltip';
10
+ import Indicator from './Indicator';
11
+ import Band from './Band';
12
+ import Lighter from './Lighter';
13
+ import Line from './Line';
14
+ import Background from './Background';
15
+ import LinearGradient from './LinearGradient';
16
+ import Brush from './Brush';
17
+ import Label from './Label';
18
+ import StereoBar from './StereoBar';
19
+ import Carousel from './Carousel';
20
+ import Chart from './Chart';
21
+ import ConicalGradient from './ConicalGradient';
22
+ import CartesianChart from './CartesianChart';
23
+ import PieChart from './PieChart';
24
+
25
+ const Area = Line;
26
+ export {
27
+ Mapping,
28
+ AnimateData,
29
+ FilterData,
30
+ StackData,
31
+ ExtentData,
32
+ ChartContainer,
33
+ Legend,
34
+ Tooltip,
35
+ Axis,
36
+ Indicator,
37
+ Band,
38
+ Lighter,
39
+ Line,
40
+ Area,
41
+ Background,
42
+ LinearGradient,
43
+ Brush,
44
+ Label,
45
+ StereoBar,
46
+ Carousel,
47
+ CartesianChart,
48
+ PieChart,
49
+ Chart,
50
+ ConicalGradient,
51
+ };
@@ -1,2 +1,2 @@
1
- import { createContext } from 'react';
2
- export const chartContext = createContext();
1
+ import { createContext } from 'react';
2
+ export const chartContext = createContext();
@@ -1,42 +1,42 @@
1
- .rotateClockwise {
2
- animation-name: rotateClockwise;
3
- }
4
-
5
- @keyframes rotateClockwise {
6
- 0% {
7
- transform: rotate(0deg);
8
- }
9
- 100% {
10
- transform: rotate(360deg);
11
- }
12
- }
13
-
14
- .rotateCounterClockwise {
15
- animation-name: rotateCounterClockwise;
16
- }
17
-
18
- @keyframes rotateCounterClockwise {
19
- 0% {
20
- transform: rotate(360deg);
21
- }
22
- 100% {
23
- transform: rotate(0deg);
24
- }
25
- }
26
-
27
- .showAllStyle {
28
- display: grid;
29
- width: 100%;
30
- grid-template-columns: 40% 30% 30%;
31
- align-items: center;
32
- flex-direction: row;
33
- justify-content: space-between;
34
- }
35
-
36
- .notShowAllStyle {
37
- display: flex;
38
- width: 100%;
39
- align-items: center;
40
- flex-direction: row;
41
- justify-content: space-between;
1
+ .rotateClockwise {
2
+ animation-name: rotateClockwise;
3
+ }
4
+
5
+ @keyframes rotateClockwise {
6
+ 0% {
7
+ transform: rotate(0deg);
8
+ }
9
+ 100% {
10
+ transform: rotate(360deg);
11
+ }
12
+ }
13
+
14
+ .rotateCounterClockwise {
15
+ animation-name: rotateCounterClockwise;
16
+ }
17
+
18
+ @keyframes rotateCounterClockwise {
19
+ 0% {
20
+ transform: rotate(360deg);
21
+ }
22
+ 100% {
23
+ transform: rotate(0deg);
24
+ }
25
+ }
26
+
27
+ .showAllStyle {
28
+ display: grid;
29
+ width: 100%;
30
+ grid-template-columns: 40% 30% 30%;
31
+ align-items: center;
32
+ flex-direction: row;
33
+ justify-content: space-between;
34
+ }
35
+
36
+ .notShowAllStyle {
37
+ display: flex;
38
+ width: 100%;
39
+ align-items: center;
40
+ flex-direction: row;
41
+ justify-content: space-between;
42
42
  }
@@ -1,27 +1,27 @@
1
- /*甜甜圈图专用css*/
2
- .label-line {
3
- stroke-dasharray: 100;
4
- stroke-dashoffset: 100;
5
- animation: dash 800ms ease forwards;
6
- }
7
-
8
- .label-text {
9
- opacity: 0;
10
- animation: show 800ms ease forwards;
11
- }
12
-
13
- .inner-arc {
14
- animation: dash 2s ease forwards;
15
- }
16
-
17
- @keyframes dash {
18
- 100% {
19
- stroke-dashoffset: 0%;
20
- }
21
- }
22
-
23
- @keyframes show {
24
- 100% {
25
- opacity: 1;
26
- }
1
+ /*甜甜圈图专用css*/
2
+ .label-line {
3
+ stroke-dasharray: 100;
4
+ stroke-dashoffset: 100;
5
+ animation: dash 800ms ease forwards;
6
+ }
7
+
8
+ .label-text {
9
+ opacity: 0;
10
+ animation: show 800ms ease forwards;
11
+ }
12
+
13
+ .inner-arc {
14
+ animation: dash 2s ease forwards;
15
+ }
16
+
17
+ @keyframes dash {
18
+ 100% {
19
+ stroke-dashoffset: 0%;
20
+ }
21
+ }
22
+
23
+ @keyframes show {
24
+ 100% {
25
+ opacity: 1;
26
+ }
27
27
  }