Line.js 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. exports.sortGradient = exports.lineProps = exports.handleGradient = 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 _colors = require("@ant-design/colors");
  11. var _props = require("./props");
  12. var _utils = require("./utils");
  13. var _devWarning = _interopRequireDefault(require("../vc-util/devWarning"));
  14. var _type = require("../_util/type");
  15. var __rest = void 0 && (void 0).__rest || function (s, e) {
  16. var t = {};
  17. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
  18. if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
  19. if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
  20. }
  21. return t;
  22. };
  23. const lineProps = () => (0, _extends2.default)((0, _extends2.default)({}, (0, _props.progressProps)()), {
  24. strokeColor: (0, _type.anyType)(),
  25. direction: (0, _type.stringType)()
  26. });
  27. /**
  28. * {
  29. * '0%': '#afc163',
  30. * '75%': '#009900',
  31. * '50%': 'green', ====> '#afc163 0%, #66FF00 25%, #00CC00 50%, #009900 75%, #ffffff 100%'
  32. * '25%': '#66FF00',
  33. * '100%': '#ffffff'
  34. * }
  35. */
  36. exports.lineProps = lineProps;
  37. const sortGradient = gradients => {
  38. let tempArr = [];
  39. Object.keys(gradients).forEach(key => {
  40. const formattedKey = parseFloat(key.replace(/%/g, ''));
  41. if (!isNaN(formattedKey)) {
  42. tempArr.push({
  43. key: formattedKey,
  44. value: gradients[key]
  45. });
  46. }
  47. });
  48. tempArr = tempArr.sort((a, b) => a.key - b.key);
  49. return tempArr.map(_ref => {
  50. let {
  51. key,
  52. value
  53. } = _ref;
  54. return `${value} ${key}%`;
  55. }).join(', ');
  56. };
  57. /**
  58. * Then this man came to realize the truth: Besides six pence, there is the moon. Besides bread and
  59. * butter, there is the bug. And... Besides women, there is the code.
  60. *
  61. * @example
  62. * {
  63. * "0%": "#afc163",
  64. * "25%": "#66FF00",
  65. * "50%": "#00CC00", // ====> linear-gradient(to right, #afc163 0%, #66FF00 25%,
  66. * "75%": "#009900", // #00CC00 50%, #009900 75%, #ffffff 100%)
  67. * "100%": "#ffffff"
  68. * }
  69. */
  70. exports.sortGradient = sortGradient;
  71. const handleGradient = (strokeColor, directionConfig) => {
  72. const {
  73. from = _colors.presetPrimaryColors.blue,
  74. to = _colors.presetPrimaryColors.blue,
  75. direction = directionConfig === 'rtl' ? 'to left' : 'to right'
  76. } = strokeColor,
  77. rest = __rest(strokeColor, ["from", "to", "direction"]);
  78. if (Object.keys(rest).length !== 0) {
  79. const sortedGradients = sortGradient(rest);
  80. return {
  81. backgroundImage: `linear-gradient(${direction}, ${sortedGradients})`
  82. };
  83. }
  84. return {
  85. backgroundImage: `linear-gradient(${direction}, ${from}, ${to})`
  86. };
  87. };
  88. exports.handleGradient = handleGradient;
  89. var _default = exports.default = (0, _vue.defineComponent)({
  90. compatConfig: {
  91. MODE: 3
  92. },
  93. name: 'ProgressLine',
  94. inheritAttrs: false,
  95. props: lineProps(),
  96. setup(props, _ref2) {
  97. let {
  98. slots,
  99. attrs
  100. } = _ref2;
  101. const backgroundProps = (0, _vue.computed)(() => {
  102. const {
  103. strokeColor,
  104. direction
  105. } = props;
  106. return strokeColor && typeof strokeColor !== 'string' ? handleGradient(strokeColor, direction) : {
  107. backgroundColor: strokeColor
  108. };
  109. });
  110. const borderRadius = (0, _vue.computed)(() => props.strokeLinecap === 'square' || props.strokeLinecap === 'butt' ? 0 : undefined);
  111. const trailStyle = (0, _vue.computed)(() => props.trailColor ? {
  112. backgroundColor: props.trailColor
  113. } : undefined);
  114. const mergedSize = (0, _vue.computed)(() => {
  115. var _a;
  116. return (_a = props.size) !== null && _a !== void 0 ? _a : [-1, props.strokeWidth || (props.size === 'small' ? 6 : 8)];
  117. });
  118. const sizeRef = (0, _vue.computed)(() => (0, _utils.getSize)(mergedSize.value, 'line', {
  119. strokeWidth: props.strokeWidth
  120. }));
  121. if (process.env.NODE_ENV !== 'production') {
  122. (0, _devWarning.default)('strokeWidth' in props, 'Progress', '`strokeWidth` is deprecated. Please use `size` instead.');
  123. }
  124. const percentStyle = (0, _vue.computed)(() => {
  125. const {
  126. percent
  127. } = props;
  128. return (0, _extends2.default)({
  129. width: `${(0, _utils.validProgress)(percent)}%`,
  130. height: `${sizeRef.value.height}px`,
  131. borderRadius: borderRadius.value
  132. }, backgroundProps.value);
  133. });
  134. const successPercent = (0, _vue.computed)(() => {
  135. return (0, _utils.getSuccessPercent)(props);
  136. });
  137. const successPercentStyle = (0, _vue.computed)(() => {
  138. const {
  139. success
  140. } = props;
  141. return {
  142. width: `${(0, _utils.validProgress)(successPercent.value)}%`,
  143. height: `${sizeRef.value.height}px`,
  144. borderRadius: borderRadius.value,
  145. backgroundColor: success === null || success === void 0 ? void 0 : success.strokeColor
  146. };
  147. });
  148. const outerStyle = {
  149. width: sizeRef.value.width < 0 ? '100%' : sizeRef.value.width,
  150. height: `${sizeRef.value.height}px`
  151. };
  152. return () => {
  153. var _a;
  154. return (0, _vue.createVNode)(_vue.Fragment, null, [(0, _vue.createVNode)("div", (0, _objectSpread2.default)((0, _objectSpread2.default)({}, attrs), {}, {
  155. "class": [`${props.prefixCls}-outer`, attrs.class],
  156. "style": [attrs.style, outerStyle]
  157. }), [(0, _vue.createVNode)("div", {
  158. "class": `${props.prefixCls}-inner`,
  159. "style": trailStyle.value
  160. }, [(0, _vue.createVNode)("div", {
  161. "class": `${props.prefixCls}-bg`,
  162. "style": percentStyle.value
  163. }, null), successPercent.value !== undefined ? (0, _vue.createVNode)("div", {
  164. "class": `${props.prefixCls}-success-bg`,
  165. "style": successPercentStyle.value
  166. }, null) : null])]), (_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots)]);
  167. };
  168. }
  169. });