index.js 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. var _typeof = require("@babel/runtime/helpers/typeof");
  4. Object.defineProperty(exports, "__esModule", {
  5. value: true
  6. });
  7. exports.stepsProps = exports.stepProps = exports.default = exports.Step = void 0;
  8. var _vue = require("vue");
  9. var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
  10. var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
  11. var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
  12. var _CloseOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/CloseOutlined"));
  13. var _CheckOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/CheckOutlined"));
  14. var _vueTypes = _interopRequireDefault(require("../_util/vue-types"));
  15. var _initDefaultProps = _interopRequireDefault(require("../_util/props-util/initDefaultProps"));
  16. var _vcSteps = _interopRequireWildcard(require("../vc-steps"));
  17. var _useConfigInject2 = _interopRequireDefault(require("../_util/hooks/useConfigInject"));
  18. var _useBreakpoint = _interopRequireDefault(require("../_util/hooks/useBreakpoint"));
  19. var _classNames2 = _interopRequireDefault(require("../_util/classNames"));
  20. var _progress = _interopRequireDefault(require("../progress"));
  21. var _omit = _interopRequireDefault(require("../_util/omit"));
  22. var _Step = require("../vc-steps/Step");
  23. function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
  24. function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
  25. var stepsProps = function stepsProps() {
  26. return {
  27. prefixCls: String,
  28. iconPrefix: String,
  29. current: Number,
  30. initial: Number,
  31. percent: Number,
  32. responsive: {
  33. type: Boolean,
  34. default: undefined
  35. },
  36. labelPlacement: String,
  37. status: String,
  38. size: String,
  39. direction: String,
  40. progressDot: {
  41. type: [Boolean, Function],
  42. default: undefined
  43. },
  44. type: String,
  45. onChange: Function,
  46. 'onUpdate:current': Function
  47. };
  48. };
  49. exports.stepsProps = stepsProps;
  50. var stepProps = function stepProps() {
  51. return {
  52. description: _vueTypes.default.any,
  53. icon: _vueTypes.default.any,
  54. status: String,
  55. disabled: {
  56. type: Boolean,
  57. default: undefined
  58. },
  59. title: _vueTypes.default.any,
  60. subTitle: _vueTypes.default.any,
  61. onClick: Function
  62. };
  63. };
  64. exports.stepProps = stepProps;
  65. var Steps = (0, _vue.defineComponent)({
  66. compatConfig: {
  67. MODE: 3
  68. },
  69. name: 'ASteps',
  70. inheritAttrs: false,
  71. props: (0, _initDefaultProps.default)(stepsProps(), {
  72. current: 0,
  73. responsive: true,
  74. labelPlacement: 'horizontal'
  75. }),
  76. slots: ['progressDot'],
  77. // emits: ['update:current', 'change'],
  78. setup: function setup(props, _ref) {
  79. var attrs = _ref.attrs,
  80. slots = _ref.slots,
  81. emit = _ref.emit;
  82. var _useConfigInject = (0, _useConfigInject2.default)('steps', props),
  83. prefixCls = _useConfigInject.prefixCls,
  84. rtlDirection = _useConfigInject.direction,
  85. configProvider = _useConfigInject.configProvider;
  86. var screens = (0, _useBreakpoint.default)();
  87. var direction = (0, _vue.computed)(function () {
  88. return props.responsive && screens.value.xs ? 'vertical' : props.direction;
  89. });
  90. var iconPrefix = (0, _vue.computed)(function () {
  91. return configProvider.getPrefixCls('', props.iconPrefix);
  92. });
  93. var handleChange = function handleChange(current) {
  94. emit('update:current', current);
  95. emit('change', current);
  96. };
  97. var stepIconRender = function stepIconRender(_ref2) {
  98. var node = _ref2.node,
  99. status = _ref2.status;
  100. if (status === 'process' && props.percent !== undefined) {
  101. // currently it's hard-coded, since we can't easily read the actually width of icon
  102. var progressWidth = props.size === 'small' ? 32 : 40;
  103. var iconWithProgress = (0, _vue.createVNode)("div", {
  104. "class": "".concat(prefixCls, "-progress-icon")
  105. }, [(0, _vue.createVNode)(_progress.default, {
  106. "type": "circle",
  107. "percent": props.percent,
  108. "width": progressWidth,
  109. "strokeWidth": 4,
  110. "format": function format() {
  111. return null;
  112. }
  113. }, null), node]);
  114. return iconWithProgress;
  115. }
  116. return node;
  117. };
  118. return function () {
  119. var _classNames;
  120. var stepsClassName = (0, _classNames2.default)((_classNames = {}, (0, _defineProperty2.default)(_classNames, "".concat(prefixCls.value, "-rtl"), rtlDirection.value === 'rtl'), (0, _defineProperty2.default)(_classNames, "".concat(prefixCls.value, "-with-progress"), props.percent !== undefined), _classNames), attrs.class);
  121. var icons = {
  122. finish: (0, _vue.createVNode)(_CheckOutlined.default, {
  123. "class": "".concat(prefixCls, "-finish-icon")
  124. }, null),
  125. error: (0, _vue.createVNode)(_CloseOutlined.default, {
  126. "class": "".concat(prefixCls, "-error-icon")
  127. }, null)
  128. };
  129. return (0, _vue.createVNode)(_vcSteps.default, (0, _objectSpread2.default)((0, _objectSpread2.default)({
  130. "icons": icons
  131. }, (0, _omit.default)(props, ['percent', 'responsive'])), {}, {
  132. "direction": direction.value,
  133. "prefixCls": prefixCls.value,
  134. "iconPrefix": iconPrefix.value,
  135. "class": stepsClassName,
  136. "onChange": handleChange
  137. }), (0, _objectSpread2.default)((0, _objectSpread2.default)({}, slots), {}, {
  138. stepIcon: stepIconRender
  139. }));
  140. };
  141. }
  142. });
  143. /* istanbul ignore next */
  144. var Step = (0, _vue.defineComponent)((0, _objectSpread2.default)((0, _objectSpread2.default)({
  145. compatConfig: {
  146. MODE: 3
  147. }
  148. }, _vcSteps.Step), {}, {
  149. name: 'AStep',
  150. props: (0, _Step.VcStepProps)()
  151. }));
  152. exports.Step = Step;
  153. var _default = (0, _extends2.default)(Steps, {
  154. Step: Step,
  155. install: function install(app) {
  156. app.component(Steps.name, Steps);
  157. app.component(Step.name, Step);
  158. return app;
  159. }
  160. });
  161. exports.default = _default;