UNPKG

victory-core

Version:
87 lines (85 loc) 3.72 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.Arc = void 0; var _react = _interopRequireDefault(require("react")); var _defaults = _interopRequireDefault(require("lodash/defaults")); var Helpers = _interopRequireWildcard(require("../victory-util/helpers")); var _path = require("./path"); function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } /* eslint no-magic-numbers: ["error", { "ignore": [0, 1, 2, 180] }]*/ const getArcPath = props => { const { cx, cy, r, startAngle, endAngle, closedPath } = props; // Always draw the path as two arcs so that complete circles may be rendered. const halfAngle = Math.abs(endAngle - startAngle) / 2 + startAngle; const x1 = cx + r * Math.cos(Helpers.degreesToRadians(startAngle)); const y1 = cy - r * Math.sin(Helpers.degreesToRadians(startAngle)); const x2 = cx + r * Math.cos(Helpers.degreesToRadians(halfAngle)); const y2 = cy - r * Math.sin(Helpers.degreesToRadians(halfAngle)); const x3 = cx + r * Math.cos(Helpers.degreesToRadians(endAngle)); const y3 = cy - r * Math.sin(Helpers.degreesToRadians(endAngle)); const largerArcFlag1 = halfAngle - startAngle <= 180 ? 0 : 1; const largerArcFlag2 = endAngle - halfAngle <= 180 ? 0 : 1; const arcStart = closedPath ? ` M ${cx}, ${cy} L ${x1}, ${y1}` : `M ${x1}, ${y1}`; const arc1 = `A ${r}, ${r}, 0, ${largerArcFlag1}, 0, ${x2}, ${y2}`; const arc2 = `A ${r}, ${r}, 0, ${largerArcFlag2}, 0, ${x3}, ${y3}`; const arcEnd = closedPath ? "Z" : ""; return `${arcStart} ${arc1} ${arc2} ${arcEnd}`; }; const evaluateProps = props => { /** * Potential evaluated props are: * `ariaLabel` * `desc` * `id` * `style` * `tabIndex` */ const ariaLabel = Helpers.evaluateProp(props.ariaLabel, props); const desc = Helpers.evaluateProp(props.desc, props); const id = Helpers.evaluateProp(props.id, props); const style = Helpers.evaluateStyle(Object.assign({ stroke: "black", fill: "none" }, props.style), props); const tabIndex = Helpers.evaluateProp(props.tabIndex, props); return Object.assign({}, props, { ariaLabel, desc, id, style, tabIndex }); }; const defaultProps = { pathComponent: /*#__PURE__*/_react.default.createElement(_path.Path, null), role: "presentation", shapeRendering: "auto" }; const Arc = initialProps => { const props = evaluateProps((0, _defaults.default)({}, initialProps, defaultProps)); return /*#__PURE__*/_react.default.cloneElement(props.pathComponent, { ...props.events, "aria-label": props.ariaLabel, d: getArcPath(props), style: props.style, desc: props.desc, tabIndex: props.tabIndex, className: props.className, role: props.role, shapeRendering: props.shapeRendering, transform: props.transform, clipPath: props.clipPath }); }; exports.Arc = Arc;