Steps.js 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. exports.default = void 0;
  7. var _vue = require("vue");
  8. var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
  9. var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
  10. var _vueTypes = _interopRequireDefault(require("../_util/vue-types"));
  11. var _classNames = _interopRequireDefault(require("../_util/classNames"));
  12. var _Step = _interopRequireDefault(require("./Step"));
  13. var _type = require("../_util/type");
  14. var _propsUtil = require("../_util/props-util");
  15. var _vnode = require("../_util/vnode");
  16. var __rest = void 0 && (void 0).__rest || function (s, e) {
  17. var t = {};
  18. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
  19. if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
  20. if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
  21. }
  22. return t;
  23. };
  24. var _default = exports.default = (0, _vue.defineComponent)({
  25. compatConfig: {
  26. MODE: 3
  27. },
  28. name: 'Steps',
  29. props: {
  30. type: _vueTypes.default.string.def('default'),
  31. prefixCls: _vueTypes.default.string.def('vc-steps'),
  32. iconPrefix: _vueTypes.default.string.def('vc'),
  33. direction: _vueTypes.default.string.def('horizontal'),
  34. labelPlacement: _vueTypes.default.string.def('horizontal'),
  35. status: (0, _type.stringType)('process'),
  36. size: _vueTypes.default.string.def(''),
  37. progressDot: _vueTypes.default.oneOfType([_vueTypes.default.looseBool, _vueTypes.default.func]).def(undefined),
  38. initial: _vueTypes.default.number.def(0),
  39. current: _vueTypes.default.number.def(0),
  40. items: _vueTypes.default.array.def(() => []),
  41. icons: _vueTypes.default.shape({
  42. finish: _vueTypes.default.any,
  43. error: _vueTypes.default.any
  44. }).loose,
  45. stepIcon: (0, _type.functionType)(),
  46. isInline: _vueTypes.default.looseBool,
  47. itemRender: (0, _type.functionType)()
  48. },
  49. emits: ['change'],
  50. setup(props, _ref) {
  51. let {
  52. slots,
  53. emit
  54. } = _ref;
  55. const onStepClick = next => {
  56. const {
  57. current
  58. } = props;
  59. if (current !== next) {
  60. emit('change', next);
  61. }
  62. };
  63. const renderStep = (item, index, legacyRender) => {
  64. const {
  65. prefixCls,
  66. iconPrefix,
  67. status,
  68. current,
  69. initial,
  70. icons,
  71. stepIcon = slots.stepIcon,
  72. isInline,
  73. itemRender,
  74. progressDot = slots.progressDot
  75. } = props;
  76. const mergedProgressDot = isInline || progressDot;
  77. const mergedItem = (0, _extends2.default)((0, _extends2.default)({}, item), {
  78. class: ''
  79. });
  80. const stepNumber = initial + index;
  81. const commonProps = {
  82. active: stepNumber === current,
  83. stepNumber: stepNumber + 1,
  84. stepIndex: stepNumber,
  85. key: stepNumber,
  86. prefixCls,
  87. iconPrefix,
  88. progressDot: mergedProgressDot,
  89. stepIcon,
  90. icons,
  91. onStepClick
  92. };
  93. // fix tail color
  94. if (status === 'error' && index === current - 1) {
  95. mergedItem.class = `${prefixCls}-next-error`;
  96. }
  97. if (!mergedItem.status) {
  98. if (stepNumber === current) {
  99. mergedItem.status = status;
  100. } else if (stepNumber < current) {
  101. mergedItem.status = 'finish';
  102. } else {
  103. mergedItem.status = 'wait';
  104. }
  105. }
  106. if (isInline) {
  107. mergedItem.icon = undefined;
  108. mergedItem.subTitle = undefined;
  109. }
  110. if (legacyRender) {
  111. return legacyRender((0, _extends2.default)((0, _extends2.default)({}, mergedItem), commonProps));
  112. }
  113. if (itemRender) {
  114. mergedItem.itemRender = stepItem => itemRender(mergedItem, stepItem);
  115. }
  116. return (0, _vue.createVNode)(_Step.default, (0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)({}, mergedItem), commonProps), {}, {
  117. "__legacy": false
  118. }), null);
  119. };
  120. const renderStepWithNode = (node, index) => {
  121. return renderStep((0, _extends2.default)({}, node.props), index, stepProps => {
  122. const stepNode = (0, _vnode.cloneElement)(node, stepProps);
  123. return stepNode;
  124. });
  125. };
  126. return () => {
  127. var _a;
  128. const {
  129. prefixCls,
  130. direction,
  131. type,
  132. labelPlacement,
  133. iconPrefix,
  134. status,
  135. size,
  136. current,
  137. progressDot = slots.progressDot,
  138. initial,
  139. icons,
  140. items,
  141. isInline,
  142. itemRender
  143. } = props,
  144. restProps = __rest(props, ["prefixCls", "direction", "type", "labelPlacement", "iconPrefix", "status", "size", "current", "progressDot", "initial", "icons", "items", "isInline", "itemRender"]);
  145. const isNav = type === 'navigation';
  146. const mergedProgressDot = isInline || progressDot;
  147. const mergedDirection = isInline ? 'horizontal' : direction;
  148. const mergedSize = isInline ? undefined : size;
  149. const adjustedLabelPlacement = mergedProgressDot ? 'vertical' : labelPlacement;
  150. const classString = (0, _classNames.default)(prefixCls, `${prefixCls}-${direction}`, {
  151. [`${prefixCls}-${mergedSize}`]: mergedSize,
  152. [`${prefixCls}-label-${adjustedLabelPlacement}`]: mergedDirection === 'horizontal',
  153. [`${prefixCls}-dot`]: !!mergedProgressDot,
  154. [`${prefixCls}-navigation`]: isNav,
  155. [`${prefixCls}-inline`]: isInline
  156. });
  157. return (0, _vue.createVNode)("div", (0, _objectSpread2.default)({
  158. "class": classString
  159. }, restProps), [items.filter(item => item).map((item, index) => renderStep(item, index)), (0, _propsUtil.filterEmpty)((_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots)).map(renderStepWithNode)]);
  160. };
  161. }
  162. });