@easyv/charts 1.3.27 → 1.3.29
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.
- package/.babelrc +8 -8
- package/.husky/commit-msg +3 -3
- package/CHANGELOG.md +18 -18
- package/lib/components/Background.js +2 -2
- package/lib/components/CartesianChart.js +15 -2
- package/lib/components/ConicalGradient.js +21 -21
- package/lib/components/Indicator.js +2 -2
- package/lib/components/Lighter.js +179 -179
- package/lib/components/LinearGradient.js +2 -2
- package/lib/components/PieChart.js +3 -40
- package/lib/css/index.module.css +41 -41
- package/lib/css/piechart.module.css +26 -26
- package/lib/element/ConicGradient.js +72 -72
- package/lib/hooks/useAnimateData.js +5 -5
- package/lib/hooks/useCarouselAxisX.js +14 -8
- package/lib/hooks/useFilterData.js +5 -5
- package/lib/hooks/useStackData.js +5 -5
- package/lib/hooks/useTooltip.js +10 -10
- package/package.json +1 -1
- package/src/components/Background.tsx +62 -62
- package/src/components/Band.tsx +192 -192
- package/src/components/Brush.js +159 -159
- package/src/components/CartesianChart.js +5 -2
- package/src/components/Chart.js +99 -99
- package/src/components/ChartContainer.tsx +63 -63
- package/src/components/ConicalGradient.js +258 -258
- package/src/components/ExtentData.js +17 -17
- package/src/components/Indicator.js +13 -13
- package/src/components/Label.js +225 -225
- package/src/components/Lighter.jsx +173 -173
- package/src/components/Line.js +150 -150
- package/src/components/LinearGradient.js +29 -29
- package/src/components/PieChart.js +6 -51
- package/src/components/StereoBar.tsx +307 -307
- package/src/components/index.js +55 -55
- package/src/context/index.js +2 -2
- package/src/css/index.module.css +41 -41
- package/src/css/piechart.module.css +26 -26
- package/src/element/ConicGradient.jsx +55 -55
- package/src/element/Line.tsx +33 -33
- package/src/element/index.ts +3 -3
- package/src/formatter/index.js +1 -1
- package/src/formatter/legend.js +90 -90
- package/src/hooks/index.js +17 -17
- package/src/hooks/useAnimateData.ts +67 -67
- package/src/hooks/useCarouselAxisX.js +11 -7
- package/src/hooks/useFilterData.js +72 -72
- package/src/hooks/useStackData.js +101 -101
- package/src/hooks/useTooltip.ts +96 -96
- package/src/index.js +6 -6
- package/src/types/index.d.ts +67 -67
- package/src/utils/index.js +757 -757
- package/tsconfig.json +23 -23
package/.babelrc
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
{
|
|
2
|
-
"presets": ["@babel/preset-env", "@babel/preset-react", "@babel/preset-typescript"],
|
|
3
|
-
"plugins": [
|
|
4
|
-
"@babel/plugin-proposal-export-default-from",
|
|
5
|
-
"@babel/plugin-transform-runtime",
|
|
6
|
-
"@babel/plugin-proposal-class-properties"
|
|
7
|
-
]
|
|
8
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"presets": ["@babel/preset-env", "@babel/preset-react", "@babel/preset-typescript"],
|
|
3
|
+
"plugins": [
|
|
4
|
+
"@babel/plugin-proposal-export-default-from",
|
|
5
|
+
"@babel/plugin-transform-runtime",
|
|
6
|
+
"@babel/plugin-proposal-class-properties"
|
|
7
|
+
]
|
|
8
|
+
}
|
package/.husky/commit-msg
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
#!/bin/sh
|
|
2
|
-
. "$(dirname "$0")/_/husky.sh"
|
|
3
|
-
|
|
1
|
+
#!/bin/sh
|
|
2
|
+
. "$(dirname "$0")/_/husky.sh"
|
|
3
|
+
|
|
4
4
|
yarn commitlint --edit $1
|
package/CHANGELOG.md
CHANGED
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
# Changelog
|
|
2
|
-
|
|
3
|
-
All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
|
|
4
|
-
|
|
5
|
-
### [1.1.1](https://gitlab.prod.dtstack.cn:10022/visdev/visApplication/easyv-charts/compare/v1.1.0...v1.1.1) (2022-04-13)
|
|
6
|
-
|
|
7
|
-
## 1.1.0 (2022-04-02)
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
### Features
|
|
11
|
-
|
|
12
|
-
* 轴标签,label支持样式传入 ([749a595](https://gitlab.prod.dtstack.cn:10022/visdev/visApplication/easyv-charts/commit/749a595a96b95917dafdc1766f63efec73398d64))
|
|
13
|
-
* axis轴标签支持点击触发回调 ([1f636e1](https://gitlab.prod.dtstack.cn:10022/visdev/visApplication/easyv-charts/commit/1f636e1840f4f3b48c2b9765ce6087759d82fb17))
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
### Bug Fixes
|
|
17
|
-
|
|
18
|
-
* **band组件:** 修复foreignObject在Safari浏览器下的位置诡异偏离问题 ([1a65d54](https://gitlab.prod.dtstack.cn:10022/visdev/visApplication/easyv-charts/commit/1a65d54abbcf6c9e84cc85cc8b6a9d28b24fa4c4))
|
|
1
|
+
# Changelog
|
|
2
|
+
|
|
3
|
+
All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
|
|
4
|
+
|
|
5
|
+
### [1.1.1](https://gitlab.prod.dtstack.cn:10022/visdev/visApplication/easyv-charts/compare/v1.1.0...v1.1.1) (2022-04-13)
|
|
6
|
+
|
|
7
|
+
## 1.1.0 (2022-04-02)
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
### Features
|
|
11
|
+
|
|
12
|
+
* 轴标签,label支持样式传入 ([749a595](https://gitlab.prod.dtstack.cn:10022/visdev/visApplication/easyv-charts/commit/749a595a96b95917dafdc1766f63efec73398d64))
|
|
13
|
+
* axis轴标签支持点击触发回调 ([1f636e1](https://gitlab.prod.dtstack.cn:10022/visdev/visApplication/easyv-charts/commit/1f636e1840f4f3b48c2b9765ce6087759d82fb17))
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
### Bug Fixes
|
|
17
|
+
|
|
18
|
+
* **band组件:** 修复foreignObject在Safari浏览器下的位置诡异偏离问题 ([1a65d54](https://gitlab.prod.dtstack.cn:10022/visdev/visApplication/easyv-charts/commit/1a65d54abbcf6c9e84cc85cc8b6a9d28b24fa4c4))
|
|
@@ -15,6 +15,8 @@ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")
|
|
|
15
15
|
|
|
16
16
|
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
17
17
|
|
|
18
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
19
|
+
|
|
18
20
|
var _react = _interopRequireWildcard(require("react"));
|
|
19
21
|
|
|
20
22
|
var _hooks = require("../hooks");
|
|
@@ -69,6 +71,11 @@ var Chart = /*#__PURE__*/(0, _react.memo)(function (_ref) {
|
|
|
69
71
|
filterData = _ref.filterData;
|
|
70
72
|
var context = (0, _react.useContext)(_context.chartContext);
|
|
71
73
|
|
|
74
|
+
var _useState = (0, _react.useState)(false),
|
|
75
|
+
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
76
|
+
isHover = _useState2[0],
|
|
77
|
+
setIsHover = _useState2[1];
|
|
78
|
+
|
|
72
79
|
var _useContext = (0, _react.useContext)(_context.chartContext),
|
|
73
80
|
chartWidth = _useContext.width,
|
|
74
81
|
chartHeight = _useContext.height,
|
|
@@ -80,7 +87,7 @@ var Chart = /*#__PURE__*/(0, _react.memo)(function (_ref) {
|
|
|
80
87
|
axes: axesConfig,
|
|
81
88
|
context: context
|
|
82
89
|
});
|
|
83
|
-
var axisX = (0, _hooks.useCarouselAxisX)(axes.get('x'), animation);
|
|
90
|
+
var axisX = (0, _hooks.useCarouselAxisX)(axes.get('x'), animation, isHover);
|
|
84
91
|
|
|
85
92
|
var _useTooltip = (0, _hooks.useTooltip)({
|
|
86
93
|
svg: svg,
|
|
@@ -128,8 +135,14 @@ var Chart = /*#__PURE__*/(0, _react.memo)(function (_ref) {
|
|
|
128
135
|
height: height,
|
|
129
136
|
marginLeft: marginLeft,
|
|
130
137
|
marginTop: marginTop,
|
|
138
|
+
onMouseEnter: function onMouseEnter() {
|
|
139
|
+
setIsHover(true);
|
|
140
|
+
},
|
|
131
141
|
onMouseMove: setIndex,
|
|
132
|
-
onMouseLeave:
|
|
142
|
+
onMouseLeave: function onMouseLeave(e) {
|
|
143
|
+
setIsHover(false);
|
|
144
|
+
setIndex(e);
|
|
145
|
+
},
|
|
133
146
|
ref: svg
|
|
134
147
|
}, background && /*#__PURE__*/_react["default"].createElement(_.Background, {
|
|
135
148
|
length: isVertical ? chartWidth : chartHeight,
|
|
@@ -23,8 +23,8 @@ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "functio
|
|
|
23
23
|
|
|
24
24
|
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(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; }
|
|
25
25
|
|
|
26
|
-
/**
|
|
27
|
-
* 饼图装饰内圈
|
|
26
|
+
/**
|
|
27
|
+
* 饼图装饰内圈
|
|
28
28
|
*/
|
|
29
29
|
var _default = function _default(_ref) {
|
|
30
30
|
var width = _ref.width,
|
|
@@ -127,8 +127,8 @@ var _default = function _default(_ref) {
|
|
|
127
127
|
}
|
|
128
128
|
});
|
|
129
129
|
};
|
|
130
|
-
/**
|
|
131
|
-
* ConicalGradient
|
|
130
|
+
/**
|
|
131
|
+
* ConicalGradient
|
|
132
132
|
*/
|
|
133
133
|
|
|
134
134
|
|
|
@@ -140,11 +140,11 @@ function ConicalGradient() {
|
|
|
140
140
|
}
|
|
141
141
|
|
|
142
142
|
ConicalGradient.prototype = {
|
|
143
|
-
/**
|
|
144
|
-
* addColorStop
|
|
145
|
-
*
|
|
146
|
-
* @param {Number} offset
|
|
147
|
-
* @param {Array} color RGBA值
|
|
143
|
+
/**
|
|
144
|
+
* addColorStop
|
|
145
|
+
*
|
|
146
|
+
* @param {Number} offset
|
|
147
|
+
* @param {Array} color RGBA值
|
|
148
148
|
*/
|
|
149
149
|
addColorStop: function addColorStop(offset, color) {
|
|
150
150
|
this._offsets.push(offset);
|
|
@@ -154,23 +154,23 @@ ConicalGradient.prototype = {
|
|
|
154
154
|
return this;
|
|
155
155
|
},
|
|
156
156
|
|
|
157
|
-
/**
|
|
158
|
-
* _offsetsReverse (array.forEach callback)
|
|
157
|
+
/**
|
|
158
|
+
* _offsetsReverse (array.forEach callback)
|
|
159
159
|
*/
|
|
160
160
|
_offsetsReverse: function _offsetsReverse(offset, index, array) {
|
|
161
161
|
array[index] = 1 - offset;
|
|
162
162
|
},
|
|
163
163
|
|
|
164
|
-
/**
|
|
165
|
-
* fill
|
|
166
|
-
*
|
|
167
|
-
* @param {Number} context
|
|
168
|
-
* @param {Number} x
|
|
169
|
-
* @param {Number} y
|
|
170
|
-
* @param {Number} radius
|
|
171
|
-
* @param {Number} startAngle
|
|
172
|
-
* @param {Number} endAngle
|
|
173
|
-
* @param {Boolean} anticlockwise
|
|
164
|
+
/**
|
|
165
|
+
* fill
|
|
166
|
+
*
|
|
167
|
+
* @param {Number} context
|
|
168
|
+
* @param {Number} x
|
|
169
|
+
* @param {Number} y
|
|
170
|
+
* @param {Number} radius
|
|
171
|
+
* @param {Number} startAngle
|
|
172
|
+
* @param {Number} endAngle
|
|
173
|
+
* @param {Boolean} anticlockwise
|
|
174
174
|
*/
|
|
175
175
|
fill: function fill(context, x, y, radius, startAngle, endAngle, anticlockwise) {
|
|
176
176
|
var offsets = this._offsets;
|
|
@@ -1,180 +1,180 @@
|
|
|
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 _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
13
|
-
|
|
14
|
-
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
15
|
-
|
|
16
|
-
var _react = _interopRequireWildcard(require("react"));
|
|
17
|
-
|
|
18
|
-
var _d3v = require("d3v7");
|
|
19
|
-
|
|
20
|
-
var _utils = require("../utils");
|
|
21
|
-
|
|
22
|
-
var _svgPathProperties = require("svg-path-properties");
|
|
23
|
-
|
|
24
|
-
/**
|
|
25
|
-
* 区域图发光跟踪路径
|
|
26
|
-
*/
|
|
27
|
-
var _default = function _default(_ref) {
|
|
28
|
-
var d = _ref.path,
|
|
29
|
-
config = _ref.config,
|
|
30
|
-
_ref$config = _ref.config,
|
|
31
|
-
curveLength = _ref$config.length,
|
|
32
|
-
width = _ref$config.width,
|
|
33
|
-
fill = _ref$config.fill,
|
|
34
|
-
unitStep = _ref$config.unitStep;
|
|
35
|
-
var pointIndexRef = (0, _react.useRef)(0);
|
|
36
|
-
var raf = (0, _react.useRef)(null);
|
|
37
|
-
|
|
38
|
-
var _useState = (0, _react.useState)([]),
|
|
39
|
-
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
40
|
-
points = _useState2[0],
|
|
41
|
-
setPoints = _useState2[1];
|
|
42
|
-
|
|
43
|
-
var _useState3 = (0, _react.useState)(null),
|
|
44
|
-
_useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
|
|
45
|
-
lighter = _useState4[0],
|
|
46
|
-
setLighter = _useState4[1];
|
|
47
|
-
|
|
48
|
-
var pointLength = points.length;
|
|
49
|
-
var totalLength = getLength(pointLength, curveLength);
|
|
50
|
-
var easingFunc = easing.linear;
|
|
51
|
-
var interpolateList = (0, _react.useMemo)(function () {
|
|
52
|
-
return getColorsInterpolate((0, _utils.getColorList)(fill));
|
|
53
|
-
}, [fill]);
|
|
54
|
-
var drawLigher = (0, _react.useCallback)(function () {
|
|
55
|
-
var STEP = 2;
|
|
56
|
-
var LOOP = false;
|
|
57
|
-
|
|
58
|
-
if (lighter && lighter.children) {
|
|
59
|
-
var currentPointLength = pointIndexRef.current;
|
|
60
|
-
var pointIndex = currentPointLength >= totalLength ? LOOP ? curveLength : 0 : currentPointLength + unitStep + Math.floor(easingFunc(pointIndexRef.current / totalLength) * STEP);
|
|
61
|
-
var overstep = pointIndex - pointLength;
|
|
62
|
-
var startIndex = getPointIndex(pointIndex, pointLength, curveLength);
|
|
63
|
-
var endIndex = getPointIndex(pointIndex + curveLength, pointLength, curveLength);
|
|
64
|
-
var overstepPoints = LOOP && overstep > 0 ? points.slice(0, overstep) : [];
|
|
65
|
-
drawCircle(Array.from(lighter.children), [].concat((0, _toConsumableArray2["default"])(points.slice(startIndex, endIndex)), (0, _toConsumableArray2["default"])(overstepPoints)), interpolateList);
|
|
66
|
-
pointIndexRef.current = pointIndex;
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
raf.current = requestAnimationFrame(drawLigher);
|
|
70
|
-
}, [lighter, totalLength, curveLength, unitStep, points, interpolateList]);
|
|
71
|
-
(0, _react.useEffect)(function () {
|
|
72
|
-
var path = new _svgPathProperties.svgPathProperties(d);
|
|
73
|
-
var totalLength = path.getTotalLength();
|
|
74
|
-
var points = [];
|
|
75
|
-
|
|
76
|
-
for (var i = 0; i < totalLength; i++) {
|
|
77
|
-
var _path$getPointAtLengt = path.getPointAtLength(i),
|
|
78
|
-
x = _path$getPointAtLengt.x,
|
|
79
|
-
y = _path$getPointAtLengt.y;
|
|
80
|
-
|
|
81
|
-
points.push({
|
|
82
|
-
index: i,
|
|
83
|
-
x: x,
|
|
84
|
-
y: y
|
|
85
|
-
});
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
setPoints(points);
|
|
89
|
-
}, [d, config]);
|
|
90
|
-
(0, _react.useEffect)(function () {
|
|
91
|
-
raf.current = requestAnimationFrame(drawLigher);
|
|
92
|
-
return function () {
|
|
93
|
-
cancelAnimationFrame(raf.current);
|
|
94
|
-
};
|
|
95
|
-
}, [drawLigher]);
|
|
96
|
-
return /*#__PURE__*/_react["default"].createElement("g", {
|
|
97
|
-
ref: setLighter
|
|
98
|
-
}, points.map(function (_ref2, index) {
|
|
99
|
-
var x = _ref2.x,
|
|
100
|
-
y = _ref2.y;
|
|
101
|
-
return /*#__PURE__*/_react["default"].createElement("circle", {
|
|
102
|
-
cx: x,
|
|
103
|
-
cy: y,
|
|
104
|
-
key: index,
|
|
105
|
-
r: width,
|
|
106
|
-
fill: "none"
|
|
107
|
-
});
|
|
108
|
-
}));
|
|
109
|
-
};
|
|
110
|
-
|
|
111
|
-
exports["default"] = _default;
|
|
112
|
-
|
|
113
|
-
var drawCircle = function drawCircle(children, points, interpolateList) {
|
|
114
|
-
var pointLength = points.length; // const [startPoint] = points;
|
|
115
|
-
// const startIndex = startPoint ? startPoint.index : 0;
|
|
116
|
-
|
|
117
|
-
children.forEach(function (child, index) {
|
|
118
|
-
var pointIndex = points.findIndex(function (_ref3) {
|
|
119
|
-
var i = _ref3.index;
|
|
120
|
-
return i == index;
|
|
121
|
-
});
|
|
122
|
-
child.setAttribute('fill', pointIndex > -1 ? getColor(pointIndex / pointLength, //TODO: 颜色插值尚需完善
|
|
123
|
-
interpolateList) : 'none');
|
|
124
|
-
});
|
|
125
|
-
};
|
|
126
|
-
|
|
127
|
-
var getColor = function getColor(x, interpolateList) {
|
|
128
|
-
return interpolateList(x);
|
|
129
|
-
};
|
|
130
|
-
|
|
131
|
-
var getLength = function getLength(pointLength, length) {
|
|
132
|
-
if (length > pointLength) {
|
|
133
|
-
return pointLength * 2;
|
|
134
|
-
}
|
|
135
|
-
|
|
136
|
-
return pointLength + length;
|
|
137
|
-
};
|
|
138
|
-
|
|
139
|
-
var getColorsInterpolate = function getColorsInterpolate(colors) {
|
|
140
|
-
var length = colors.length;
|
|
141
|
-
if (!!(length < 2)) return (0, _d3v.scaleLinear)().domain([0, 1]).range([colors[0].color || '#000', colors[0].color || '#000']);
|
|
142
|
-
var linear = (0, _d3v.scaleLinear)().domain(colors.map(function (d) {
|
|
143
|
-
return d.offset;
|
|
144
|
-
})).range(colors.map(function (d) {
|
|
145
|
-
return d.color;
|
|
146
|
-
}));
|
|
147
|
-
return linear;
|
|
148
|
-
};
|
|
149
|
-
|
|
150
|
-
var easing = {
|
|
151
|
-
linear: function linear() {
|
|
152
|
-
return 0;
|
|
153
|
-
},
|
|
154
|
-
easeIn: function easeIn(k) {
|
|
155
|
-
return Math.pow(k, 3);
|
|
156
|
-
},
|
|
157
|
-
easeOut: function easeOut(k) {
|
|
158
|
-
return 1 - easing.easeIn(1 - k);
|
|
159
|
-
},
|
|
160
|
-
easeInOut: function easeInOut(k) {
|
|
161
|
-
return k < 0.5 ? easing.easeIn(k * 2) / 2 : 1 - easing.easeIn(2 - 2 * k) / 2;
|
|
162
|
-
},
|
|
163
|
-
easeOutIn: function easeOutIn(k) {
|
|
164
|
-
return k < 0.5 ? 0.5 * (1 - easing.easeIn(1 - 2 * k)) : 0.5 * easing.easeIn(k * 2 - 1) + 0.5;
|
|
165
|
-
}
|
|
166
|
-
};
|
|
167
|
-
|
|
168
|
-
var getPointIndex = function getPointIndex(pointIndex, pointLength, curveLength) {
|
|
169
|
-
var index = pointIndex - curveLength;
|
|
170
|
-
|
|
171
|
-
if (index < 0) {
|
|
172
|
-
return 0;
|
|
173
|
-
}
|
|
174
|
-
|
|
175
|
-
if (index >= pointLength) {
|
|
176
|
-
return pointLength - 1;
|
|
177
|
-
}
|
|
178
|
-
|
|
179
|
-
return index;
|
|
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 _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
13
|
+
|
|
14
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
15
|
+
|
|
16
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
17
|
+
|
|
18
|
+
var _d3v = require("d3v7");
|
|
19
|
+
|
|
20
|
+
var _utils = require("../utils");
|
|
21
|
+
|
|
22
|
+
var _svgPathProperties = require("svg-path-properties");
|
|
23
|
+
|
|
24
|
+
/**
|
|
25
|
+
* 区域图发光跟踪路径
|
|
26
|
+
*/
|
|
27
|
+
var _default = function _default(_ref) {
|
|
28
|
+
var d = _ref.path,
|
|
29
|
+
config = _ref.config,
|
|
30
|
+
_ref$config = _ref.config,
|
|
31
|
+
curveLength = _ref$config.length,
|
|
32
|
+
width = _ref$config.width,
|
|
33
|
+
fill = _ref$config.fill,
|
|
34
|
+
unitStep = _ref$config.unitStep;
|
|
35
|
+
var pointIndexRef = (0, _react.useRef)(0);
|
|
36
|
+
var raf = (0, _react.useRef)(null);
|
|
37
|
+
|
|
38
|
+
var _useState = (0, _react.useState)([]),
|
|
39
|
+
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
40
|
+
points = _useState2[0],
|
|
41
|
+
setPoints = _useState2[1];
|
|
42
|
+
|
|
43
|
+
var _useState3 = (0, _react.useState)(null),
|
|
44
|
+
_useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
|
|
45
|
+
lighter = _useState4[0],
|
|
46
|
+
setLighter = _useState4[1];
|
|
47
|
+
|
|
48
|
+
var pointLength = points.length;
|
|
49
|
+
var totalLength = getLength(pointLength, curveLength);
|
|
50
|
+
var easingFunc = easing.linear;
|
|
51
|
+
var interpolateList = (0, _react.useMemo)(function () {
|
|
52
|
+
return getColorsInterpolate((0, _utils.getColorList)(fill));
|
|
53
|
+
}, [fill]);
|
|
54
|
+
var drawLigher = (0, _react.useCallback)(function () {
|
|
55
|
+
var STEP = 2;
|
|
56
|
+
var LOOP = false;
|
|
57
|
+
|
|
58
|
+
if (lighter && lighter.children) {
|
|
59
|
+
var currentPointLength = pointIndexRef.current;
|
|
60
|
+
var pointIndex = currentPointLength >= totalLength ? LOOP ? curveLength : 0 : currentPointLength + unitStep + Math.floor(easingFunc(pointIndexRef.current / totalLength) * STEP);
|
|
61
|
+
var overstep = pointIndex - pointLength;
|
|
62
|
+
var startIndex = getPointIndex(pointIndex, pointLength, curveLength);
|
|
63
|
+
var endIndex = getPointIndex(pointIndex + curveLength, pointLength, curveLength);
|
|
64
|
+
var overstepPoints = LOOP && overstep > 0 ? points.slice(0, overstep) : [];
|
|
65
|
+
drawCircle(Array.from(lighter.children), [].concat((0, _toConsumableArray2["default"])(points.slice(startIndex, endIndex)), (0, _toConsumableArray2["default"])(overstepPoints)), interpolateList);
|
|
66
|
+
pointIndexRef.current = pointIndex;
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
raf.current = requestAnimationFrame(drawLigher);
|
|
70
|
+
}, [lighter, totalLength, curveLength, unitStep, points, interpolateList]);
|
|
71
|
+
(0, _react.useEffect)(function () {
|
|
72
|
+
var path = new _svgPathProperties.svgPathProperties(d);
|
|
73
|
+
var totalLength = path.getTotalLength();
|
|
74
|
+
var points = [];
|
|
75
|
+
|
|
76
|
+
for (var i = 0; i < totalLength; i++) {
|
|
77
|
+
var _path$getPointAtLengt = path.getPointAtLength(i),
|
|
78
|
+
x = _path$getPointAtLengt.x,
|
|
79
|
+
y = _path$getPointAtLengt.y;
|
|
80
|
+
|
|
81
|
+
points.push({
|
|
82
|
+
index: i,
|
|
83
|
+
x: x,
|
|
84
|
+
y: y
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
setPoints(points);
|
|
89
|
+
}, [d, config]);
|
|
90
|
+
(0, _react.useEffect)(function () {
|
|
91
|
+
raf.current = requestAnimationFrame(drawLigher);
|
|
92
|
+
return function () {
|
|
93
|
+
cancelAnimationFrame(raf.current);
|
|
94
|
+
};
|
|
95
|
+
}, [drawLigher]);
|
|
96
|
+
return /*#__PURE__*/_react["default"].createElement("g", {
|
|
97
|
+
ref: setLighter
|
|
98
|
+
}, points.map(function (_ref2, index) {
|
|
99
|
+
var x = _ref2.x,
|
|
100
|
+
y = _ref2.y;
|
|
101
|
+
return /*#__PURE__*/_react["default"].createElement("circle", {
|
|
102
|
+
cx: x,
|
|
103
|
+
cy: y,
|
|
104
|
+
key: index,
|
|
105
|
+
r: width,
|
|
106
|
+
fill: "none"
|
|
107
|
+
});
|
|
108
|
+
}));
|
|
109
|
+
};
|
|
110
|
+
|
|
111
|
+
exports["default"] = _default;
|
|
112
|
+
|
|
113
|
+
var drawCircle = function drawCircle(children, points, interpolateList) {
|
|
114
|
+
var pointLength = points.length; // const [startPoint] = points;
|
|
115
|
+
// const startIndex = startPoint ? startPoint.index : 0;
|
|
116
|
+
|
|
117
|
+
children.forEach(function (child, index) {
|
|
118
|
+
var pointIndex = points.findIndex(function (_ref3) {
|
|
119
|
+
var i = _ref3.index;
|
|
120
|
+
return i == index;
|
|
121
|
+
});
|
|
122
|
+
child.setAttribute('fill', pointIndex > -1 ? getColor(pointIndex / pointLength, //TODO: 颜色插值尚需完善
|
|
123
|
+
interpolateList) : 'none');
|
|
124
|
+
});
|
|
125
|
+
};
|
|
126
|
+
|
|
127
|
+
var getColor = function getColor(x, interpolateList) {
|
|
128
|
+
return interpolateList(x);
|
|
129
|
+
};
|
|
130
|
+
|
|
131
|
+
var getLength = function getLength(pointLength, length) {
|
|
132
|
+
if (length > pointLength) {
|
|
133
|
+
return pointLength * 2;
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
return pointLength + length;
|
|
137
|
+
};
|
|
138
|
+
|
|
139
|
+
var getColorsInterpolate = function getColorsInterpolate(colors) {
|
|
140
|
+
var length = colors.length;
|
|
141
|
+
if (!!(length < 2)) return (0, _d3v.scaleLinear)().domain([0, 1]).range([colors[0].color || '#000', colors[0].color || '#000']);
|
|
142
|
+
var linear = (0, _d3v.scaleLinear)().domain(colors.map(function (d) {
|
|
143
|
+
return d.offset;
|
|
144
|
+
})).range(colors.map(function (d) {
|
|
145
|
+
return d.color;
|
|
146
|
+
}));
|
|
147
|
+
return linear;
|
|
148
|
+
};
|
|
149
|
+
|
|
150
|
+
var easing = {
|
|
151
|
+
linear: function linear() {
|
|
152
|
+
return 0;
|
|
153
|
+
},
|
|
154
|
+
easeIn: function easeIn(k) {
|
|
155
|
+
return Math.pow(k, 3);
|
|
156
|
+
},
|
|
157
|
+
easeOut: function easeOut(k) {
|
|
158
|
+
return 1 - easing.easeIn(1 - k);
|
|
159
|
+
},
|
|
160
|
+
easeInOut: function easeInOut(k) {
|
|
161
|
+
return k < 0.5 ? easing.easeIn(k * 2) / 2 : 1 - easing.easeIn(2 - 2 * k) / 2;
|
|
162
|
+
},
|
|
163
|
+
easeOutIn: function easeOutIn(k) {
|
|
164
|
+
return k < 0.5 ? 0.5 * (1 - easing.easeIn(1 - 2 * k)) : 0.5 * easing.easeIn(k * 2 - 1) + 0.5;
|
|
165
|
+
}
|
|
166
|
+
};
|
|
167
|
+
|
|
168
|
+
var getPointIndex = function getPointIndex(pointIndex, pointLength, curveLength) {
|
|
169
|
+
var index = pointIndex - curveLength;
|
|
170
|
+
|
|
171
|
+
if (index < 0) {
|
|
172
|
+
return 0;
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
if (index >= pointLength) {
|
|
176
|
+
return pointLength - 1;
|
|
177
|
+
}
|
|
178
|
+
|
|
179
|
+
return index;
|
|
180
180
|
};
|
|
@@ -875,9 +875,6 @@ var Label = function Label(_ref10) {
|
|
|
875
875
|
judge = _ref10.judge,
|
|
876
876
|
animation = _ref10.animation;
|
|
877
877
|
|
|
878
|
-
// const [labels, setLabels] = useState(null);
|
|
879
|
-
// const [opacity, setOpacity] = useState(0);
|
|
880
|
-
// console.log('judeg1111',judge)
|
|
881
878
|
var _arcs = (0, _react.useMemo)(function () {
|
|
882
879
|
return (0, _utils.getDataWithPercent)(arcs, precision);
|
|
883
880
|
}, [arcs, precision]); //数据做出容错
|
|
@@ -887,48 +884,14 @@ var Label = function Label(_ref10) {
|
|
|
887
884
|
_arcs.forEach(function (d) {
|
|
888
885
|
d.percent = 0;
|
|
889
886
|
});
|
|
890
|
-
}
|
|
891
|
-
// if (labels) {
|
|
892
|
-
// const children = [...labels.children];
|
|
893
|
-
// const bbox = children.reduce(
|
|
894
|
-
// (prev, current) => {
|
|
895
|
-
// const { topRight, bottomRight, bottomLeft, topLeft } = prev;
|
|
896
|
-
// const { x, y, height } = current.getBBox();
|
|
897
|
-
// current._y1 = y;
|
|
898
|
-
// current._y2 = y + height;
|
|
899
|
-
// current._delta = 0;
|
|
900
|
-
// if (x > 0) {
|
|
901
|
-
// if (y > 0) {
|
|
902
|
-
// bottomRight.push(current);
|
|
903
|
-
// } else {
|
|
904
|
-
// topRight.push(current);
|
|
905
|
-
// }
|
|
906
|
-
// } else {
|
|
907
|
-
// if (y > 0) {
|
|
908
|
-
// bottomLeft.push(current);
|
|
909
|
-
// } else {
|
|
910
|
-
// topLeft.push(current);
|
|
911
|
-
// }
|
|
912
|
-
// }
|
|
913
|
-
// return prev;
|
|
914
|
-
// },
|
|
915
|
-
// {
|
|
916
|
-
// topRight: [],
|
|
917
|
-
// bottomRight: [],
|
|
918
|
-
// bottomLeft: [],
|
|
919
|
-
// topLeft: [],
|
|
920
|
-
// }
|
|
921
|
-
// );
|
|
922
|
-
// console.log('bbox: ', bbox);
|
|
923
|
-
// }
|
|
924
|
-
// }, [labels]);
|
|
925
|
-
|
|
887
|
+
}
|
|
926
888
|
|
|
927
889
|
return /*#__PURE__*/_react["default"].createElement("g", null, _arcs.map(function (_ref11, index) {
|
|
928
890
|
var _ref11$series$color = _ref11.series.color,
|
|
929
891
|
type = _ref11$series$color.type,
|
|
930
892
|
pure = _ref11$series$color.pure,
|
|
931
893
|
stops = _ref11$series$color.linear.stops,
|
|
894
|
+
data = _ref11.data,
|
|
932
895
|
displayName = _ref11.displayName,
|
|
933
896
|
value = _ref11.value,
|
|
934
897
|
percent = _ref11.percent,
|
|
@@ -990,7 +953,7 @@ var Label = function Label(_ref10) {
|
|
|
990
953
|
dx: valueDx(_showName, mode),
|
|
991
954
|
dy: !!(_showName && mode == 'vertical') ? '1.5em' : '',
|
|
992
955
|
style: (0, _utils.getFontStyle)(valueFont, 'svg')
|
|
993
|
-
},
|
|
956
|
+
}, data.y), showSuffix && /*#__PURE__*/_react["default"].createElement("tspan", {
|
|
994
957
|
style: _objectSpread(_objectSpread({}, (0, _utils.getFontStyle)(valueFont, 'svg')), {}, {
|
|
995
958
|
fontSize: suffixFontSize
|
|
996
959
|
}),
|