progress.js 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  1. import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
  2. import { createVNode as _createVNode } from "vue";
  3. var __rest = this && this.__rest || function (s, e) {
  4. var t = {};
  5. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
  6. if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
  7. if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
  8. }
  9. return t;
  10. };
  11. import { computed, defineComponent } from 'vue';
  12. import initDefaultProps from '../_util/props-util/initDefaultProps';
  13. import CloseOutlined from "@ant-design/icons-vue/es/icons/CloseOutlined";
  14. import CheckOutlined from "@ant-design/icons-vue/es/icons/CheckOutlined";
  15. import CheckCircleFilled from "@ant-design/icons-vue/es/icons/CheckCircleFilled";
  16. import CloseCircleFilled from "@ant-design/icons-vue/es/icons/CloseCircleFilled";
  17. import Line from './Line';
  18. import Circle from './Circle';
  19. import Steps from './Steps';
  20. import { getSize, getSuccessPercent, validProgress } from './utils';
  21. import useConfigInject from '../config-provider/hooks/useConfigInject';
  22. import devWarning from '../vc-util/devWarning';
  23. import { progressProps, progressStatuses } from './props';
  24. import useStyle from './style';
  25. export default defineComponent({
  26. compatConfig: {
  27. MODE: 3
  28. },
  29. name: 'AProgress',
  30. inheritAttrs: false,
  31. props: initDefaultProps(progressProps(), {
  32. type: 'line',
  33. percent: 0,
  34. showInfo: true,
  35. // null for different theme definition
  36. trailColor: null,
  37. size: 'default',
  38. strokeLinecap: 'round'
  39. }),
  40. slots: Object,
  41. setup(props, _ref) {
  42. let {
  43. slots,
  44. attrs
  45. } = _ref;
  46. const {
  47. prefixCls,
  48. direction
  49. } = useConfigInject('progress', props);
  50. const [wrapSSR, hashId] = useStyle(prefixCls);
  51. if (process.env.NODE_ENV !== 'production') {
  52. devWarning('successPercent' in props, 'Progress', '`successPercent` is deprecated. Please use `success.percent` instead.');
  53. devWarning('width' in props, 'Progress', '`width` is deprecated. Please use `size` instead.');
  54. }
  55. const strokeColorNotArray = computed(() => Array.isArray(props.strokeColor) ? props.strokeColor[0] : props.strokeColor);
  56. const percentNumber = computed(() => {
  57. const {
  58. percent = 0
  59. } = props;
  60. const successPercent = getSuccessPercent(props);
  61. return parseInt(successPercent !== undefined ? successPercent.toString() : percent.toString(), 10);
  62. });
  63. const progressStatus = computed(() => {
  64. const {
  65. status
  66. } = props;
  67. if (!progressStatuses.includes(status) && percentNumber.value >= 100) {
  68. return 'success';
  69. }
  70. return status || 'normal';
  71. });
  72. const classString = computed(() => {
  73. const {
  74. type,
  75. showInfo,
  76. size
  77. } = props;
  78. const pre = prefixCls.value;
  79. return {
  80. [pre]: true,
  81. [`${pre}-inline-circle`]: type === 'circle' && getSize(size, 'circle').width <= 20,
  82. [`${pre}-${type === 'dashboard' && 'circle' || type}`]: true,
  83. [`${pre}-status-${progressStatus.value}`]: true,
  84. [`${pre}-show-info`]: showInfo,
  85. [`${pre}-${size}`]: size,
  86. [`${pre}-rtl`]: direction.value === 'rtl',
  87. [hashId.value]: true
  88. };
  89. });
  90. const strokeColorNotGradient = computed(() => typeof props.strokeColor === 'string' || Array.isArray(props.strokeColor) ? props.strokeColor : undefined);
  91. const renderProcessInfo = () => {
  92. const {
  93. showInfo,
  94. format,
  95. type,
  96. percent,
  97. title
  98. } = props;
  99. const successPercent = getSuccessPercent(props);
  100. if (!showInfo) return null;
  101. let text;
  102. const textFormatter = format || (slots === null || slots === void 0 ? void 0 : slots.format) || (val => `${val}%`);
  103. const isLineType = type === 'line';
  104. if (format || (slots === null || slots === void 0 ? void 0 : slots.format) || progressStatus.value !== 'exception' && progressStatus.value !== 'success') {
  105. text = textFormatter(validProgress(percent), validProgress(successPercent));
  106. } else if (progressStatus.value === 'exception') {
  107. text = isLineType ? _createVNode(CloseCircleFilled, null, null) : _createVNode(CloseOutlined, null, null);
  108. } else if (progressStatus.value === 'success') {
  109. text = isLineType ? _createVNode(CheckCircleFilled, null, null) : _createVNode(CheckOutlined, null, null);
  110. }
  111. return _createVNode("span", {
  112. "class": `${prefixCls.value}-text`,
  113. "title": title === undefined && typeof text === 'string' ? text : undefined
  114. }, [text]);
  115. };
  116. return () => {
  117. const {
  118. type,
  119. steps,
  120. title
  121. } = props;
  122. const {
  123. class: cls
  124. } = attrs,
  125. restAttrs = __rest(attrs, ["class"]);
  126. const progressInfo = renderProcessInfo();
  127. let progress;
  128. // Render progress shape
  129. if (type === 'line') {
  130. progress = steps ? _createVNode(Steps, _objectSpread(_objectSpread({}, props), {}, {
  131. "strokeColor": strokeColorNotGradient.value,
  132. "prefixCls": prefixCls.value,
  133. "steps": steps
  134. }), {
  135. default: () => [progressInfo]
  136. }) : _createVNode(Line, _objectSpread(_objectSpread({}, props), {}, {
  137. "strokeColor": strokeColorNotArray.value,
  138. "prefixCls": prefixCls.value,
  139. "direction": direction.value
  140. }), {
  141. default: () => [progressInfo]
  142. });
  143. } else if (type === 'circle' || type === 'dashboard') {
  144. progress = _createVNode(Circle, _objectSpread(_objectSpread({}, props), {}, {
  145. "prefixCls": prefixCls.value,
  146. "strokeColor": strokeColorNotArray.value,
  147. "progressStatus": progressStatus.value
  148. }), {
  149. default: () => [progressInfo]
  150. });
  151. }
  152. return wrapSSR(_createVNode("div", _objectSpread(_objectSpread({
  153. "role": "progressbar"
  154. }, restAttrs), {}, {
  155. "class": [classString.value, cls],
  156. "title": title
  157. }), [progress]));
  158. };
  159. }
  160. });