react-svg-donut-chart
Version:
A lightweight responsive donut chart React component using only SVG
69 lines (53 loc) • 2.56 kB
JavaScript
;
exports.__esModule = true;
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
var _react = require("react");
var _react2 = _interopRequireDefault(_react);
var _propTypes = require("prop-types");
var _propTypes2 = _interopRequireDefault(_propTypes);
var _Segment = require("./Segment");
var _Segment2 = _interopRequireDefault(_Segment);
var _constants = require("./constants");
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }
var ReactSvgDonutChart = function ReactSvgDonutChart(_ref) {
var data = _ref.data,
spacing = _ref.spacing,
rest = _objectWithoutProperties(_ref, ["data", "spacing"]);
var total = data.reduce(function (prev, current) {
return current.value + prev;
}, 0);
var percentAcc = 0;
return _react2.default.createElement(
"svg",
_extends({ viewBox: "0 0 " + _constants.width + " " + _constants.width }, rest),
data.map(function (d, i) {
var percent = Math.round(d.value / Math.ceil(total) * 100);
var DashArrayPercent = spacing < 0 || percent - spacing < 0 ? percent : percent - spacing;
var DashArraylength = spacing < 0 || percent + spacing > 100 ? 100 - percent : 100 - percent + spacing;
var strokeDasharray = DashArrayPercent + " " + DashArraylength;
var strokeDashoffset = i === 0 ? 0 : 100 - percentAcc;
percentAcc += percent;
return percent > 0 && _react2.default.createElement(_Segment2.default, _extends({
key: i,
strokeDasharray: strokeDasharray,
strokeDashoffset: strokeDashoffset
}, d));
})
);
};
ReactSvgDonutChart.propTypes = process.env.NODE_ENV !== "production" ? {
data: _propTypes2.default.arrayOf(_propTypes2.default.shape({
stroke: _propTypes2.default.string.isRequired,
strokeWidth: _propTypes2.default.number,
title: _propTypes2.default.string,
value: _propTypes2.default.number.isRequired
})),
spacing: _propTypes2.default.number
} : {};
ReactSvgDonutChart.defaultProps = {
data: [],
spacing: 0
};
exports.default = ReactSvgDonutChart;
module.exports = exports["default"];