Steps.js 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. "use strict";
  2. "use client";
  3. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
  4. var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
  5. Object.defineProperty(exports, "__esModule", {
  6. value: true
  7. });
  8. exports.default = void 0;
  9. var React = _interopRequireWildcard(require("react"));
  10. var _classnames = _interopRequireDefault(require("classnames"));
  11. var _utils = require("./utils");
  12. const Steps = props => {
  13. const {
  14. size,
  15. steps,
  16. rounding: customRounding = Math.round,
  17. percent = 0,
  18. strokeWidth = 8,
  19. strokeColor,
  20. trailColor = null,
  21. prefixCls,
  22. children
  23. } = props;
  24. const current = customRounding(steps * (percent / 100));
  25. const stepWidth = size === 'small' ? 2 : 14;
  26. const mergedSize = size !== null && size !== void 0 ? size : [stepWidth, strokeWidth];
  27. const [width, height] = (0, _utils.getSize)(mergedSize, 'step', {
  28. steps,
  29. strokeWidth
  30. });
  31. const unitWidth = width / steps;
  32. const styledSteps = Array.from({
  33. length: steps
  34. });
  35. for (let i = 0; i < steps; i++) {
  36. const color = Array.isArray(strokeColor) ? strokeColor[i] : strokeColor;
  37. styledSteps[i] = /*#__PURE__*/React.createElement("div", {
  38. key: i,
  39. className: (0, _classnames.default)(`${prefixCls}-steps-item`, {
  40. [`${prefixCls}-steps-item-active`]: i <= current - 1
  41. }),
  42. style: {
  43. backgroundColor: i <= current - 1 ? color : trailColor,
  44. width: unitWidth,
  45. height
  46. }
  47. });
  48. }
  49. return /*#__PURE__*/React.createElement("div", {
  50. className: `${prefixCls}-steps-outer`
  51. }, styledSteps, children);
  52. };
  53. var _default = exports.default = Steps;