@easyv/charts 1.4.24 → 1.4.26
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/lib/components/Marquee.js +1 -1
- package/lib/components/PieChart.js +152 -88
- package/lib/components/index.js +7 -0
- package/lib/components/pieTooltip.js +132 -0
- package/package.json +1 -1
- package/src/components/Marquee.tsx +2 -2
- package/src/components/PieChart.js +400 -261
- package/src/components/PieTooltip.jsx +134 -0
- package/src/components/index.js +2 -0
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.PieTooltip = void 0;
|
|
9
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
10
|
+
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
11
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
12
|
+
var _utils = require("../utils");
|
|
13
|
+
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); }
|
|
14
|
+
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; }
|
|
15
|
+
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; }
|
|
16
|
+
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; }
|
|
17
|
+
var PieTooltip = /*#__PURE__*/(0, _react.memo)(function (props) {
|
|
18
|
+
var mousePos = props.mousePos,
|
|
19
|
+
pieCenter = props.pieCenter,
|
|
20
|
+
_props$config$tip = props.config.tip,
|
|
21
|
+
_props$config$tip$dat = _props$config$tip.data,
|
|
22
|
+
lineHeight = _props$config$tip$dat.lineHeight,
|
|
23
|
+
iconSize = _props$config$tip$dat.iconSize,
|
|
24
|
+
name = _props$config$tip$dat.name,
|
|
25
|
+
_props$config$tip$dat2 = _props$config$tip$dat.value,
|
|
26
|
+
valueIsShow = _props$config$tip$dat2.show,
|
|
27
|
+
valueFont = _props$config$tip$dat2.fontStyle,
|
|
28
|
+
valueSuffix = _props$config$tip$dat2.suffix,
|
|
29
|
+
valueSuffixIsShow = _props$config$tip$dat2.suffix.show,
|
|
30
|
+
_props$config$tip$dat3 = _props$config$tip$dat.percentage,
|
|
31
|
+
percentageIsShow = _props$config$tip$dat3.show,
|
|
32
|
+
percentageFont = _props$config$tip$dat3.fontStyle,
|
|
33
|
+
percentageSuffix = _props$config$tip$dat3.suffix,
|
|
34
|
+
percentageSuffixIsShow = _props$config$tip$dat3.suffix.show,
|
|
35
|
+
image = _props$config$tip.image,
|
|
36
|
+
margin = _props$config$tip.margin,
|
|
37
|
+
_props$config$tip$siz = _props$config$tip.size,
|
|
38
|
+
tipWidth = _props$config$tip$siz.width,
|
|
39
|
+
tipHeight = _props$config$tip$siz.height,
|
|
40
|
+
translateTip = _props$config$tip.translate,
|
|
41
|
+
data = props.data,
|
|
42
|
+
series = props.series;
|
|
43
|
+
var Item = function Item() {
|
|
44
|
+
var _data$data = data.data,
|
|
45
|
+
s = _data$data.s,
|
|
46
|
+
y = _data$data.y,
|
|
47
|
+
percent = data.percent;
|
|
48
|
+
var _find = (0, _toConsumableArray2["default"])(series.values()).find(function (series) {
|
|
49
|
+
return series.name == s;
|
|
50
|
+
}),
|
|
51
|
+
type = _find.type,
|
|
52
|
+
icon = _find.icon,
|
|
53
|
+
displayName = _find.displayName;
|
|
54
|
+
var renderSuffix = function renderSuffix(suffix) {
|
|
55
|
+
var content = suffix.content,
|
|
56
|
+
suffiixFont = suffix.font,
|
|
57
|
+
suffixTranslate = suffix.translate;
|
|
58
|
+
return /*#__PURE__*/_react["default"].createElement("span", {
|
|
59
|
+
style: _objectSpread(_objectSpread({}, (0, _utils.getFontStyle)(suffiixFont)), {}, {
|
|
60
|
+
display: "inline-block",
|
|
61
|
+
transform: (0, _utils.getTranslate3d)(suffixTranslate)
|
|
62
|
+
})
|
|
63
|
+
}, content);
|
|
64
|
+
};
|
|
65
|
+
var _icon = (0, _utils.getIcon)(type, icon);
|
|
66
|
+
return /*#__PURE__*/_react["default"].createElement("dd", {
|
|
67
|
+
style: {
|
|
68
|
+
display: 'flex',
|
|
69
|
+
justifyContent: 'space-between',
|
|
70
|
+
lineHeight: lineHeight + 'px'
|
|
71
|
+
}
|
|
72
|
+
}, /*#__PURE__*/_react["default"].createElement("span", {
|
|
73
|
+
style: {
|
|
74
|
+
// border: '1px solid red',
|
|
75
|
+
display: 'flex',
|
|
76
|
+
alignItems: 'center',
|
|
77
|
+
gap: icon.iconGap
|
|
78
|
+
}
|
|
79
|
+
}, /*#__PURE__*/_react["default"].createElement("span", {
|
|
80
|
+
style: _objectSpread(_objectSpread({}, _icon), {}, {
|
|
81
|
+
width: iconSize + 'px',
|
|
82
|
+
height: iconSize + 'px'
|
|
83
|
+
})
|
|
84
|
+
}), /*#__PURE__*/_react["default"].createElement("span", {
|
|
85
|
+
style: (0, _utils.getFontStyle)(name)
|
|
86
|
+
}, displayName || s)), valueIsShow && /*#__PURE__*/_react["default"].createElement("span", {
|
|
87
|
+
style: (0, _utils.getFontStyle)(valueFont)
|
|
88
|
+
}, y, valueSuffixIsShow && renderSuffix(valueSuffix)), percentageIsShow && /*#__PURE__*/_react["default"].createElement("span", {
|
|
89
|
+
style: (0, _utils.getFontStyle)(percentageFont)
|
|
90
|
+
}, percent, percentageSuffixIsShow && renderSuffix(percentageSuffix)));
|
|
91
|
+
};
|
|
92
|
+
var mouseX = mousePos.x,
|
|
93
|
+
mouseY = mousePos.y;
|
|
94
|
+
var centerX = pieCenter.x,
|
|
95
|
+
centerY = pieCenter.y;
|
|
96
|
+
var getTipPos = function getTipPos() {
|
|
97
|
+
var tipPosMap = {
|
|
98
|
+
rightTop: "translate(".concat(mouseX + translateTip.x, "px,").concat(mouseY - tipHeight - translateTip.y, "px)"),
|
|
99
|
+
leftTop: "translate(".concat(mouseX - tipWidth - translateTip.x, "px,").concat(mouseY - tipHeight - translateTip.y, "px)"),
|
|
100
|
+
leftBottom: "translate(".concat(mouseX - tipWidth - translateTip.x, "px,").concat(mouseY + translateTip.y, "px)"),
|
|
101
|
+
rightBottom: "translate(".concat(mouseX + translateTip.x, "px,").concat(mouseY + translateTip.y, "px)")
|
|
102
|
+
};
|
|
103
|
+
if (mouseX < centerX && mouseY < centerY) {
|
|
104
|
+
return tipPosMap.leftTop;
|
|
105
|
+
} else if (mouseX > centerX && mouseY < centerY) {
|
|
106
|
+
return tipPosMap.rightTop;
|
|
107
|
+
} else if (mouseX >= centerX && mouseY >= centerY) {
|
|
108
|
+
return tipPosMap.rightBottom;
|
|
109
|
+
} else {
|
|
110
|
+
return tipPosMap.leftBottom;
|
|
111
|
+
}
|
|
112
|
+
};
|
|
113
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
114
|
+
className: "__easyv-tooltip",
|
|
115
|
+
style: {
|
|
116
|
+
pointerEvents: 'none',
|
|
117
|
+
transform: getTipPos(mousePos, pieCenter),
|
|
118
|
+
width: tipWidth,
|
|
119
|
+
height: tipHeight,
|
|
120
|
+
padding: (0, _utils.getMargin)(margin),
|
|
121
|
+
background: image ? '50% 50% / 100% 100% no-repeat url(' + window.appConfig.ASSETS_URL + image + ')' : 'rgba(48, 55, 66, 0.85)'
|
|
122
|
+
}
|
|
123
|
+
}, /*#__PURE__*/_react["default"].createElement("dl", {
|
|
124
|
+
style: {
|
|
125
|
+
display: 'flex',
|
|
126
|
+
flexDirection: 'column',
|
|
127
|
+
justifyContent: 'space-between',
|
|
128
|
+
height: '100%'
|
|
129
|
+
}
|
|
130
|
+
}, Item()));
|
|
131
|
+
});
|
|
132
|
+
exports.PieTooltip = PieTooltip;
|
package/package.json
CHANGED
|
@@ -16,7 +16,7 @@ export default memo(forwardRef((props:marquee, ref:any) => {
|
|
|
16
16
|
style, // 样式
|
|
17
17
|
speed = 5, // 动画速度
|
|
18
18
|
} = props;
|
|
19
|
-
|
|
19
|
+
|
|
20
20
|
const rootRef = ref || useRef();
|
|
21
21
|
const target = useRef<any>(null);
|
|
22
22
|
const observe = useRef<any>(null);
|
|
@@ -40,7 +40,7 @@ export default memo(forwardRef((props:marquee, ref:any) => {
|
|
|
40
40
|
observe.current = new IntersectionObserver(
|
|
41
41
|
function (entries:any) {
|
|
42
42
|
let entrie = entries[0];
|
|
43
|
-
if (entrie.boundingClientRect.width
|
|
43
|
+
if (entrie.boundingClientRect.width <= entrie.rootBounds.width) {
|
|
44
44
|
//表示文字全部可视
|
|
45
45
|
cancelAnimationFrame(timer.current||0);
|
|
46
46
|
target.current!.style.transform = "translate(0px,0px)"; //重置偏移
|