@easyv/charts 1.2.1 → 1.2.4

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 (90) 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 +40 -36
  6. package/lib/components/Axis.js +333 -329
  7. package/lib/components/Background.js +2 -2
  8. package/lib/components/Band.js +177 -173
  9. package/lib/components/Brush.js +201 -201
  10. package/lib/components/Carousel.js +171 -164
  11. package/lib/components/CartesianChart.js +11 -7
  12. package/lib/components/Chart.js +114 -111
  13. package/lib/components/ChartContainer.js +62 -58
  14. package/lib/components/ConicalGradient.js +268 -264
  15. package/lib/components/ExtentData.js +48 -45
  16. package/lib/components/FilterData.js +56 -53
  17. package/lib/components/Indicator.js +2 -2
  18. package/lib/components/Label.js +278 -278
  19. package/lib/components/Legend.js +160 -154
  20. package/lib/components/Lighter.js +179 -179
  21. package/lib/components/Line.js +187 -181
  22. package/lib/components/LinearGradient.js +2 -2
  23. package/lib/components/Mapping.js +130 -127
  24. package/lib/components/Marquee.js +98 -0
  25. package/lib/components/PieChart.js +1078 -1061
  26. package/lib/components/StackData.js +48 -45
  27. package/lib/components/StereoBar.js +340 -336
  28. package/lib/components/TextOverflow.js +65 -0
  29. package/lib/components/Tooltip.js +155 -155
  30. package/lib/components/index.js +202 -194
  31. package/lib/css/index.module.css +41 -41
  32. package/lib/css/piechart.module.css +26 -26
  33. package/lib/element/ConicGradient.js +72 -72
  34. package/lib/formatter/legend.js +91 -91
  35. package/lib/hooks/index.js +62 -62
  36. package/lib/hooks/useAnimateData.js +88 -88
  37. package/lib/hooks/useAxes.js +135 -135
  38. package/lib/hooks/useCarouselAxisX.js +184 -184
  39. package/lib/hooks/useExtentData.js +128 -128
  40. package/lib/hooks/useFilterData.js +112 -112
  41. package/lib/hooks/useStackData.js +136 -134
  42. package/lib/hooks/useTooltip.js +10 -10
  43. package/lib/index.js +89 -85
  44. package/lib/utils/index.js +835 -832
  45. package/package.json +53 -51
  46. package/src/components/AnimateData.tsx +24 -24
  47. package/src/components/Axis.tsx +354 -354
  48. package/src/components/Background.tsx +45 -45
  49. package/src/components/Band.tsx +173 -173
  50. package/src/components/Brush.js +159 -159
  51. package/src/components/Carousel.tsx +144 -144
  52. package/src/components/Chart.js +99 -99
  53. package/src/components/ChartContainer.tsx +63 -63
  54. package/src/components/ConicalGradient.js +258 -258
  55. package/src/components/ExtentData.js +17 -17
  56. package/src/components/FilterData.js +23 -23
  57. package/src/components/Indicator.js +13 -13
  58. package/src/components/Label.js +206 -206
  59. package/src/components/Legend.js +158 -158
  60. package/src/components/Lighter.jsx +173 -173
  61. package/src/components/Line.js +144 -144
  62. package/src/components/LinearGradient.js +29 -29
  63. package/src/components/Mapping.js +71 -71
  64. package/src/components/Marquee.js +93 -74
  65. package/src/components/PieChart.js +1288 -1097
  66. package/src/components/StackData.js +20 -20
  67. package/src/components/StereoBar.tsx +310 -310
  68. package/src/components/TextOverflow.js +51 -0
  69. package/src/components/Tooltip.js +169 -169
  70. package/src/components/index.js +53 -51
  71. package/src/context/index.js +2 -2
  72. package/src/css/index.module.css +41 -41
  73. package/src/css/piechart.module.css +26 -26
  74. package/src/element/ConicGradient.jsx +55 -55
  75. package/src/element/Line.tsx +33 -33
  76. package/src/element/index.ts +3 -3
  77. package/src/formatter/index.js +1 -1
  78. package/src/formatter/legend.js +90 -90
  79. package/src/hooks/index.js +17 -17
  80. package/src/hooks/useAnimateData.ts +67 -67
  81. package/src/hooks/useAxes.js +144 -144
  82. package/src/hooks/useCarouselAxisX.js +163 -163
  83. package/src/hooks/useExtentData.js +88 -88
  84. package/src/hooks/useFilterData.js +72 -72
  85. package/src/hooks/useStackData.js +100 -100
  86. package/src/hooks/useTooltip.ts +96 -96
  87. package/src/index.js +6 -6
  88. package/src/types/index.d.ts +67 -67
  89. package/src/utils/index.js +696 -696
  90. package/tsconfig.json +22 -22
@@ -1,330 +1,334 @@
1
- "use strict";
2
-
3
- var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
-
5
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
6
-
7
- Object.defineProperty(exports, "__esModule", {
8
- value: true
9
- });
10
- exports["default"] = void 0;
11
-
12
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
13
-
14
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
15
-
16
- var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
17
-
18
- var _react = _interopRequireWildcard(require("react"));
19
-
20
- var _utils = require("../utils");
21
-
22
- var _context = require("../context");
23
-
24
- var _element = require("../element");
25
-
26
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
27
-
28
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
29
-
30
- var defaultEvent = function defaultEvent() {};
31
-
32
- var defaultAlign = {
33
- textAnchor: 'middle',
34
- dominantBaseline: 'middle'
35
- };
36
- var defaultOrientation = 'bottom';
37
- var defaultTickSize = 6;
38
-
39
- var defaultFormatter = function defaultFormatter(d, _ref) {
40
- var suffix = _ref.suffix;
41
- return d + suffix;
42
- };
43
-
44
- var getAxesPath = function getAxesPath(orientation, _ref2) {
45
- var width = _ref2.width,
46
- height = _ref2.height;
47
-
48
- switch (orientation) {
49
- case 'top':
50
- case 'bottom':
51
- return 'M-0.5, 0H' + width;
52
-
53
- case 'left':
54
- case 'right':
55
- return 'M0, -0.5V' + (height + 0.5);
56
- }
57
- };
58
- /**
59
- * 根据坐标轴位置来确定轴标签的垂直对齐方式,水平对齐方式,以及轴标签位于坐标轴的哪个方向
60
- * @param orientation 坐标轴位置
61
- * @param rotate 旋转角度
62
- * @returns {
63
- * dominantBaseline,
64
- * textAnchor,
65
- * directionX,
66
- * directionY
67
- * }
68
- */
69
-
70
-
71
- var getLayout = function getLayout(orientation, rotate) {
72
- switch (orientation) {
73
- case 'top':
74
- return {
75
- dominantBaseline: 'text-after-edge',
76
- textAnchor: rotate ? 'end' : 'middle',
77
- directionX: 1,
78
- directionY: -1
79
- };
80
-
81
- case 'bottom':
82
- return {
83
- dominantBaseline: 'text-before-edge',
84
- textAnchor: rotate ? 'start' : 'middle',
85
- directionX: 1,
86
- directionY: 1
87
- };
88
-
89
- case 'left':
90
- return {
91
- dominantBaseline: 'middle',
92
- textAnchor: 'end',
93
- directionX: -1,
94
- directionY: 1
95
- };
96
-
97
- case 'right':
98
- return {
99
- dominantBaseline: 'middle',
100
- textAnchor: 'start',
101
- directionX: 1,
102
- directionY: 1
103
- };
104
- }
105
- };
106
-
107
- var AxisLine = function AxisLine(_ref3) {
108
- var _ref3$orientation = _ref3.orientation,
109
- orientation = _ref3$orientation === void 0 ? defaultOrientation : _ref3$orientation,
110
- _ref3$config = _ref3.config,
111
- show = _ref3$config.show,
112
- color = _ref3$config.color,
113
- lineWidth = _ref3$config.lineWidth;
114
- if (!show) return null;
115
- var context = (0, _react.useContext)(_context.chartContext);
116
- return /*#__PURE__*/_react["default"].createElement("path", {
117
- d: getAxesPath(orientation, context),
118
- stroke: color,
119
- strokeWidth: lineWidth
120
- });
121
- };
122
-
123
- var Unit = function Unit(_ref4) {
124
- var _ref4$config = _ref4.config,
125
- show = _ref4$config.show,
126
- text = _ref4$config.text,
127
- _ref4$config$font = _ref4$config.font,
128
- bold = _ref4$config$font.bold,
129
- color = _ref4$config$font.color,
130
- fontFamily = _ref4$config$font.fontFamily,
131
- fontSize = _ref4$config$font.fontSize,
132
- italic = _ref4$config$font.italic,
133
- letterSpacing = _ref4$config$font.letterSpacing,
134
- _ref4$config$translat = _ref4$config.translate,
135
- translateX = _ref4$config$translat.x,
136
- translateY = _ref4$config$translat.y,
137
- _ref4$config$align = _ref4$config.align;
138
- _ref4$config$align = _ref4$config$align === void 0 ? defaultAlign : _ref4$config$align;
139
- var textAnchor = _ref4$config$align.textAnchor;
140
- if (!show) return null;
141
- return /*#__PURE__*/_react["default"].createElement("text", {
142
- className: "__easyv-unit",
143
- transform: 'translate(' + translateX + ', ' + translateY + ')',
144
- fontFamily: fontFamily,
145
- fontSize: fontSize,
146
- fill: color,
147
- fontWeight: bold ? 'bold' : 'normal',
148
- fontStyle: italic ? 'italic' : 'normal',
149
- letterSpacing: letterSpacing,
150
- textAnchor: textAnchor
151
- }, text);
152
- };
153
-
154
- var Label = function Label(_ref5) {
155
- var className = _ref5.className,
156
- _ref5$orientation = _ref5.orientation,
157
- orientation = _ref5$orientation === void 0 ? defaultOrientation : _ref5$orientation,
158
- label = _ref5.label,
159
- coordinate = _ref5.coordinate,
160
- _ref5$formatter = _ref5.formatter,
161
- formatter = _ref5$formatter === void 0 ? defaultFormatter : _ref5$formatter,
162
- tickSize = _ref5.tickSize,
163
- _ref5$rotate = _ref5.rotate,
164
- rotate = _ref5$rotate === void 0 ? 0 : _ref5$rotate,
165
- config = _ref5.config,
166
- _ref5$onClick = _ref5.onClick,
167
- onClick = _ref5$onClick === void 0 ? defaultEvent : _ref5$onClick,
168
- _ref5$config = _ref5.config,
169
- show = _ref5$config.show,
170
- style = _ref5$config.style,
171
- _ref5$config$translat = _ref5$config.translate,
172
- translateX = _ref5$config$translat.x,
173
- translateY = _ref5$config$translat.y,
174
- _ref5$config$font = _ref5$config.font,
175
- fontFamily = _ref5$config$font.fontFamily,
176
- fontSize = _ref5$config$font.fontSize,
177
- color = _ref5$config$font.color,
178
- bold = _ref5$config$font.bold,
179
- italic = _ref5$config$font.italic,
180
- letterSpacing = _ref5$config$font.letterSpacing;
181
- if (!show) return null;
182
-
183
- var _label = formatter(label, config);
184
-
185
- var _getLayout = getLayout(orientation, rotate),
186
- dominantBaseline = _getLayout.dominantBaseline,
187
- textAnchor = _getLayout.textAnchor,
188
- directionX = _getLayout.directionX,
189
- directionY = _getLayout.directionY;
190
-
191
- var isVertical = orientation == 'left' || orientation == 'right';
192
- var x = (isVertical ? tickSize * directionX : coordinate) + translateX * directionX;
193
- var y = (isVertical ? coordinate : tickSize * directionY) + translateY * directionY;
194
- var translateText = 'translate(' + x + ', ' + y + ')';
195
-
196
- var _style = style && ((0, _typeof2["default"])(style) == 'object' ? style : style(_label));
197
-
198
- return /*#__PURE__*/_react["default"].createElement("text", {
199
- className: className,
200
- style: _objectSpread(_objectSpread({}, _style), {}, {
201
- whiteSpace: 'pre'
202
- }),
203
- onClick: onClick,
204
- "data-data": JSON.stringify({
205
- x: label
206
- }),
207
- dominantBaseline: dominantBaseline,
208
- textAnchor: textAnchor,
209
- fontFamily: fontFamily,
210
- fontSize: fontSize,
211
- fill: color,
212
- fontWeight: bold ? 'bold' : 'normal',
213
- fontStyle: italic ? 'italic' : 'normal',
214
- letterSpacing: letterSpacing,
215
- dx: "0",
216
- dy: "0",
217
- transform: Array.isArray(_label) ? rotate !== 0 ? isVertical ? translateText + 'rotate(' + rotate + ')' : 'rotate(' + rotate + ', ' + x + ', ' + y + ')' : isVertical ? translateText : 'translate(' + translateX + ', ' + translateY + ')' : translateText + 'rotate(' + rotate + ')'
218
- }, !!Array.isArray(_label) ? _label.map(function (item, index) {
219
- return /*#__PURE__*/_react["default"].createElement("tspan", {
220
- key: index,
221
- x: x,
222
- dy: "1em"
223
- }, item);
224
- }) : _label);
225
- };
226
-
227
- var _default = /*#__PURE__*/(0, _react.memo)(function (_ref6) {
228
- var orientation = _ref6.orientation,
229
- scaler = _ref6.scaler,
230
- _ref6$tickSize = _ref6.tickSize,
231
- tickSize = _ref6$tickSize === void 0 ? defaultTickSize : _ref6$tickSize,
232
- ticks = _ref6.ticks,
233
- formatter = _ref6.formatter,
234
- rotate = _ref6.rotate,
235
- triggerClick = _ref6.triggerClick,
236
- _ref6$config = _ref6.config,
237
- on = _ref6$config.on,
238
- label = _ref6$config.label,
239
- axisLine = _ref6$config.axisLine,
240
- tickLine = _ref6$config.tickLine,
241
- gridLine = _ref6$config.gridLine,
242
- unit = _ref6$config.unit,
243
- positions = _ref6.positions;
244
- if (!(on && ticks.length > 0)) return null;
245
-
246
- var _useContext = (0, _react.useContext)(_context.chartContext),
247
- width = _useContext.width,
248
- height = _useContext.height;
249
-
250
- var x = orientation == 'right' ? width : 0;
251
- var y = orientation == 'bottom' ? height : 0;
252
- return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, axisLine && tickLine && /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, axisLine && (positions && positions.length ? positions.map(function (_ref7, index) {
253
- var x = _ref7.x,
254
- y = _ref7.y;
255
- return /*#__PURE__*/_react["default"].createElement("g", {
256
- key: index,
257
- transform: 'translate(' + x + ', ' + y + ')'
258
- }, /*#__PURE__*/_react["default"].createElement(AxisLine, {
259
- orientation: orientation,
260
- config: axisLine
261
- }), tickLine && ticks.map(function (tick, index) {
262
- var coordinate = scaler(tick);
263
- if (isNaN(coordinate)) return null;
264
-
265
- var _tickSize = tickLine.tickSize || tickSize;
266
-
267
- return /*#__PURE__*/_react["default"].createElement(_element.Line, (0, _extends2["default"])({
268
- className: "__easyv-tickLine",
269
- key: index,
270
- config: tickLine
271
- }, (0, _utils.getTickCoord)({
272
- orientation: orientation,
273
- coordinate: coordinate,
274
- tickSize: _tickSize
275
- })));
276
- }));
277
- }) : /*#__PURE__*/_react["default"].createElement("g", {
278
- transform: 'translate(' + x + ', ' + y + ')'
279
- }, /*#__PURE__*/_react["default"].createElement(AxisLine, {
280
- orientation: orientation,
281
- config: axisLine
282
- }), tickLine && ticks.map(function (tick, index) {
283
- var coordinate = scaler(tick);
284
- if (isNaN(coordinate)) return null;
285
-
286
- var _tickSize = tickLine.tickSize || tickSize;
287
-
288
- return /*#__PURE__*/_react["default"].createElement(_element.Line, (0, _extends2["default"])({
289
- className: "__easyv-tickLine",
290
- key: index,
291
- config: tickLine
292
- }, (0, _utils.getTickCoord)({
293
- orientation: orientation,
294
- coordinate: coordinate,
295
- tickSize: _tickSize
296
- })));
297
- })))), /*#__PURE__*/_react["default"].createElement("g", {
298
- transform: 'translate(' + x + ', ' + y + ')'
299
- }, label && gridLine && ticks.map(function (tick, index) {
300
- var coordinate = scaler(tick);
301
- if (isNaN(coordinate)) return null;
302
-
303
- var _tickSize = tickLine.tickSize || tickSize;
304
-
305
- return /*#__PURE__*/_react["default"].createElement("g", {
306
- key: index
307
- }, label && /*#__PURE__*/_react["default"].createElement(Label, {
308
- className: "__easyv-label",
309
- orientation: orientation,
310
- coordinate: coordinate,
311
- config: label,
312
- label: tick,
313
- tickSize: _tickSize,
314
- formatter: formatter,
315
- rotate: rotate,
316
- onClick: triggerClick
317
- }), gridLine && /*#__PURE__*/_react["default"].createElement(_element.Line, (0, _extends2["default"])({
318
- className: "__easyv-gridLine",
319
- config: gridLine
320
- }, (0, _utils.getGridCoord)({
321
- orientation: orientation,
322
- coordinate: coordinate,
323
- end: orientation == 'left' || orientation == 'right' ? width : height
324
- }))));
325
- }), unit && /*#__PURE__*/_react["default"].createElement(Unit, {
326
- config: unit
327
- })));
328
- });
329
-
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _typeof3 = require("@babel/runtime/helpers/typeof");
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports["default"] = void 0;
11
+
12
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
13
+
14
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
15
+
16
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
17
+
18
+ var _react = _interopRequireWildcard(require("react"));
19
+
20
+ var _utils = require("../utils");
21
+
22
+ var _context = require("../context");
23
+
24
+ var _element = require("../element");
25
+
26
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
27
+
28
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
29
+
30
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
31
+
32
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
33
+
34
+ var defaultEvent = function defaultEvent() {};
35
+
36
+ var defaultAlign = {
37
+ textAnchor: 'middle',
38
+ dominantBaseline: 'middle'
39
+ };
40
+ var defaultOrientation = 'bottom';
41
+ var defaultTickSize = 6;
42
+
43
+ var defaultFormatter = function defaultFormatter(d, _ref) {
44
+ var suffix = _ref.suffix;
45
+ return d + suffix;
46
+ };
47
+
48
+ var getAxesPath = function getAxesPath(orientation, _ref2) {
49
+ var width = _ref2.width,
50
+ height = _ref2.height;
51
+
52
+ switch (orientation) {
53
+ case 'top':
54
+ case 'bottom':
55
+ return 'M-0.5, 0H' + width;
56
+
57
+ case 'left':
58
+ case 'right':
59
+ return 'M0, -0.5V' + (height + 0.5);
60
+ }
61
+ };
62
+ /**
63
+ * 根据坐标轴位置来确定轴标签的垂直对齐方式,水平对齐方式,以及轴标签位于坐标轴的哪个方向
64
+ * @param orientation 坐标轴位置
65
+ * @param rotate 旋转角度
66
+ * @returns {
67
+ * dominantBaseline,
68
+ * textAnchor,
69
+ * directionX,
70
+ * directionY
71
+ * }
72
+ */
73
+
74
+
75
+ var getLayout = function getLayout(orientation, rotate) {
76
+ switch (orientation) {
77
+ case 'top':
78
+ return {
79
+ dominantBaseline: 'text-after-edge',
80
+ textAnchor: rotate ? 'end' : 'middle',
81
+ directionX: 1,
82
+ directionY: -1
83
+ };
84
+
85
+ case 'bottom':
86
+ return {
87
+ dominantBaseline: 'text-before-edge',
88
+ textAnchor: rotate ? 'start' : 'middle',
89
+ directionX: 1,
90
+ directionY: 1
91
+ };
92
+
93
+ case 'left':
94
+ return {
95
+ dominantBaseline: 'middle',
96
+ textAnchor: 'end',
97
+ directionX: -1,
98
+ directionY: 1
99
+ };
100
+
101
+ case 'right':
102
+ return {
103
+ dominantBaseline: 'middle',
104
+ textAnchor: 'start',
105
+ directionX: 1,
106
+ directionY: 1
107
+ };
108
+ }
109
+ };
110
+
111
+ var AxisLine = function AxisLine(_ref3) {
112
+ var _ref3$orientation = _ref3.orientation,
113
+ orientation = _ref3$orientation === void 0 ? defaultOrientation : _ref3$orientation,
114
+ _ref3$config = _ref3.config,
115
+ show = _ref3$config.show,
116
+ color = _ref3$config.color,
117
+ lineWidth = _ref3$config.lineWidth;
118
+ if (!show) return null;
119
+ var context = (0, _react.useContext)(_context.chartContext);
120
+ return /*#__PURE__*/_react["default"].createElement("path", {
121
+ d: getAxesPath(orientation, context),
122
+ stroke: color,
123
+ strokeWidth: lineWidth
124
+ });
125
+ };
126
+
127
+ var Unit = function Unit(_ref4) {
128
+ var _ref4$config = _ref4.config,
129
+ show = _ref4$config.show,
130
+ text = _ref4$config.text,
131
+ _ref4$config$font = _ref4$config.font,
132
+ bold = _ref4$config$font.bold,
133
+ color = _ref4$config$font.color,
134
+ fontFamily = _ref4$config$font.fontFamily,
135
+ fontSize = _ref4$config$font.fontSize,
136
+ italic = _ref4$config$font.italic,
137
+ letterSpacing = _ref4$config$font.letterSpacing,
138
+ _ref4$config$translat = _ref4$config.translate,
139
+ translateX = _ref4$config$translat.x,
140
+ translateY = _ref4$config$translat.y,
141
+ _ref4$config$align = _ref4$config.align;
142
+ _ref4$config$align = _ref4$config$align === void 0 ? defaultAlign : _ref4$config$align;
143
+ var textAnchor = _ref4$config$align.textAnchor;
144
+ if (!show) return null;
145
+ return /*#__PURE__*/_react["default"].createElement("text", {
146
+ className: "__easyv-unit",
147
+ transform: 'translate(' + translateX + ', ' + translateY + ')',
148
+ fontFamily: fontFamily,
149
+ fontSize: fontSize,
150
+ fill: color,
151
+ fontWeight: bold ? 'bold' : 'normal',
152
+ fontStyle: italic ? 'italic' : 'normal',
153
+ letterSpacing: letterSpacing,
154
+ textAnchor: textAnchor
155
+ }, text);
156
+ };
157
+
158
+ var Label = function Label(_ref5) {
159
+ var className = _ref5.className,
160
+ _ref5$orientation = _ref5.orientation,
161
+ orientation = _ref5$orientation === void 0 ? defaultOrientation : _ref5$orientation,
162
+ label = _ref5.label,
163
+ coordinate = _ref5.coordinate,
164
+ _ref5$formatter = _ref5.formatter,
165
+ formatter = _ref5$formatter === void 0 ? defaultFormatter : _ref5$formatter,
166
+ tickSize = _ref5.tickSize,
167
+ _ref5$rotate = _ref5.rotate,
168
+ rotate = _ref5$rotate === void 0 ? 0 : _ref5$rotate,
169
+ config = _ref5.config,
170
+ _ref5$onClick = _ref5.onClick,
171
+ onClick = _ref5$onClick === void 0 ? defaultEvent : _ref5$onClick,
172
+ _ref5$config = _ref5.config,
173
+ show = _ref5$config.show,
174
+ style = _ref5$config.style,
175
+ _ref5$config$translat = _ref5$config.translate,
176
+ translateX = _ref5$config$translat.x,
177
+ translateY = _ref5$config$translat.y,
178
+ _ref5$config$font = _ref5$config.font,
179
+ fontFamily = _ref5$config$font.fontFamily,
180
+ fontSize = _ref5$config$font.fontSize,
181
+ color = _ref5$config$font.color,
182
+ bold = _ref5$config$font.bold,
183
+ italic = _ref5$config$font.italic,
184
+ letterSpacing = _ref5$config$font.letterSpacing;
185
+ if (!show) return null;
186
+
187
+ var _label = formatter(label, config);
188
+
189
+ var _getLayout = getLayout(orientation, rotate),
190
+ dominantBaseline = _getLayout.dominantBaseline,
191
+ textAnchor = _getLayout.textAnchor,
192
+ directionX = _getLayout.directionX,
193
+ directionY = _getLayout.directionY;
194
+
195
+ var isVertical = orientation == 'left' || orientation == 'right';
196
+ var x = (isVertical ? tickSize * directionX : coordinate) + translateX * directionX;
197
+ var y = (isVertical ? coordinate : tickSize * directionY) + translateY * directionY;
198
+ var translateText = 'translate(' + x + ', ' + y + ')';
199
+
200
+ var _style = style && ((0, _typeof2["default"])(style) == 'object' ? style : style(_label));
201
+
202
+ return /*#__PURE__*/_react["default"].createElement("text", {
203
+ className: className,
204
+ style: _objectSpread(_objectSpread({}, _style), {}, {
205
+ whiteSpace: 'pre'
206
+ }),
207
+ onClick: onClick,
208
+ "data-data": JSON.stringify({
209
+ x: label
210
+ }),
211
+ dominantBaseline: dominantBaseline,
212
+ textAnchor: textAnchor,
213
+ fontFamily: fontFamily,
214
+ fontSize: fontSize,
215
+ fill: color,
216
+ fontWeight: bold ? 'bold' : 'normal',
217
+ fontStyle: italic ? 'italic' : 'normal',
218
+ letterSpacing: letterSpacing,
219
+ dx: "0",
220
+ dy: "0",
221
+ transform: Array.isArray(_label) ? rotate !== 0 ? isVertical ? translateText + 'rotate(' + rotate + ')' : 'rotate(' + rotate + ', ' + x + ', ' + y + ')' : isVertical ? translateText : 'translate(' + translateX + ', ' + translateY + ')' : translateText + 'rotate(' + rotate + ')'
222
+ }, !!Array.isArray(_label) ? _label.map(function (item, index) {
223
+ return /*#__PURE__*/_react["default"].createElement("tspan", {
224
+ key: index,
225
+ x: x,
226
+ dy: "1em"
227
+ }, item);
228
+ }) : _label);
229
+ };
230
+
231
+ var _default = /*#__PURE__*/(0, _react.memo)(function (_ref6) {
232
+ var orientation = _ref6.orientation,
233
+ scaler = _ref6.scaler,
234
+ _ref6$tickSize = _ref6.tickSize,
235
+ tickSize = _ref6$tickSize === void 0 ? defaultTickSize : _ref6$tickSize,
236
+ ticks = _ref6.ticks,
237
+ formatter = _ref6.formatter,
238
+ rotate = _ref6.rotate,
239
+ triggerClick = _ref6.triggerClick,
240
+ _ref6$config = _ref6.config,
241
+ on = _ref6$config.on,
242
+ label = _ref6$config.label,
243
+ axisLine = _ref6$config.axisLine,
244
+ tickLine = _ref6$config.tickLine,
245
+ gridLine = _ref6$config.gridLine,
246
+ unit = _ref6$config.unit,
247
+ positions = _ref6.positions;
248
+ if (!(on && ticks.length > 0)) return null;
249
+
250
+ var _useContext = (0, _react.useContext)(_context.chartContext),
251
+ width = _useContext.width,
252
+ height = _useContext.height;
253
+
254
+ var x = orientation == 'right' ? width : 0;
255
+ var y = orientation == 'bottom' ? height : 0;
256
+ return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, axisLine && tickLine && /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, axisLine && (positions && positions.length ? positions.map(function (_ref7, index) {
257
+ var x = _ref7.x,
258
+ y = _ref7.y;
259
+ return /*#__PURE__*/_react["default"].createElement("g", {
260
+ key: index,
261
+ transform: 'translate(' + x + ', ' + y + ')'
262
+ }, /*#__PURE__*/_react["default"].createElement(AxisLine, {
263
+ orientation: orientation,
264
+ config: axisLine
265
+ }), tickLine && ticks.map(function (tick, index) {
266
+ var coordinate = scaler(tick);
267
+ if (isNaN(coordinate)) return null;
268
+
269
+ var _tickSize = tickLine.tickSize || tickSize;
270
+
271
+ return /*#__PURE__*/_react["default"].createElement(_element.Line, (0, _extends2["default"])({
272
+ className: "__easyv-tickLine",
273
+ key: index,
274
+ config: tickLine
275
+ }, (0, _utils.getTickCoord)({
276
+ orientation: orientation,
277
+ coordinate: coordinate,
278
+ tickSize: _tickSize
279
+ })));
280
+ }));
281
+ }) : /*#__PURE__*/_react["default"].createElement("g", {
282
+ transform: 'translate(' + x + ', ' + y + ')'
283
+ }, /*#__PURE__*/_react["default"].createElement(AxisLine, {
284
+ orientation: orientation,
285
+ config: axisLine
286
+ }), tickLine && ticks.map(function (tick, index) {
287
+ var coordinate = scaler(tick);
288
+ if (isNaN(coordinate)) return null;
289
+
290
+ var _tickSize = tickLine.tickSize || tickSize;
291
+
292
+ return /*#__PURE__*/_react["default"].createElement(_element.Line, (0, _extends2["default"])({
293
+ className: "__easyv-tickLine",
294
+ key: index,
295
+ config: tickLine
296
+ }, (0, _utils.getTickCoord)({
297
+ orientation: orientation,
298
+ coordinate: coordinate,
299
+ tickSize: _tickSize
300
+ })));
301
+ })))), /*#__PURE__*/_react["default"].createElement("g", {
302
+ transform: 'translate(' + x + ', ' + y + ')'
303
+ }, label && gridLine && ticks.map(function (tick, index) {
304
+ var coordinate = scaler(tick);
305
+ if (isNaN(coordinate)) return null;
306
+
307
+ var _tickSize = tickLine.tickSize || tickSize;
308
+
309
+ return /*#__PURE__*/_react["default"].createElement("g", {
310
+ key: index
311
+ }, label && /*#__PURE__*/_react["default"].createElement(Label, {
312
+ className: "__easyv-label",
313
+ orientation: orientation,
314
+ coordinate: coordinate,
315
+ config: label,
316
+ label: tick,
317
+ tickSize: _tickSize,
318
+ formatter: formatter,
319
+ rotate: rotate,
320
+ onClick: triggerClick
321
+ }), gridLine && /*#__PURE__*/_react["default"].createElement(_element.Line, (0, _extends2["default"])({
322
+ className: "__easyv-gridLine",
323
+ config: gridLine
324
+ }, (0, _utils.getGridCoord)({
325
+ orientation: orientation,
326
+ coordinate: coordinate,
327
+ end: orientation == 'left' || orientation == 'right' ? width : height
328
+ }))));
329
+ }), unit && /*#__PURE__*/_react["default"].createElement(Unit, {
330
+ config: unit
331
+ })));
332
+ });
333
+
330
334
  exports["default"] = _default;