UNPKG

antd

Version:

An enterprise-class UI design language and React components implementation

52 lines (51 loc) 2.34 kB
"use strict"; "use client"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _classnames = _interopRequireDefault(require("classnames")); var React = _interopRequireWildcard(require("react")); var _utils = require("./utils"); 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; } const Steps = props => { const { size, steps, percent = 0, strokeWidth = 8, strokeColor, trailColor = null, prefixCls, children } = props; const current = Math.round(steps * (percent / 100)); const stepWidth = size === 'small' ? 2 : 14; const mergedSize = size !== null && size !== void 0 ? size : [stepWidth, strokeWidth]; const [width, height] = (0, _utils.getSize)(mergedSize, 'step', { steps, strokeWidth }); const unitWidth = width / steps; const styledSteps = new Array(steps); for (let i = 0; i < steps; i++) { const color = Array.isArray(strokeColor) ? strokeColor[i] : strokeColor; styledSteps[i] = /*#__PURE__*/React.createElement("div", { key: i, className: (0, _classnames.default)(`${prefixCls}-steps-item`, { [`${prefixCls}-steps-item-active`]: i <= current - 1 }), style: { backgroundColor: i <= current - 1 ? color : trailColor, width: unitWidth, height } }); } return /*#__PURE__*/React.createElement("div", { className: `${prefixCls}-steps-outer` }, styledSteps, children); }; var _default = exports.default = Steps;