Spin.js 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  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. exports.setDefaultIndicator = setDefaultIndicator;
  8. exports.spinProps = void 0;
  9. var _vue = require("vue");
  10. var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
  11. var _throttleDebounce = require("throttle-debounce");
  12. var _vueTypes = _interopRequireDefault(require("../_util/vue-types"));
  13. var _propsUtil = require("../_util/props-util");
  14. var _initDefaultProps = _interopRequireDefault(require("../_util/props-util/initDefaultProps"));
  15. var _style = _interopRequireDefault(require("./style"));
  16. var _useConfigInject = _interopRequireDefault(require("../config-provider/hooks/useConfigInject"));
  17. var __rest = void 0 && (void 0).__rest || function (s, e) {
  18. var t = {};
  19. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
  20. if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
  21. if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
  22. }
  23. return t;
  24. };
  25. const spinProps = () => ({
  26. prefixCls: String,
  27. spinning: {
  28. type: Boolean,
  29. default: undefined
  30. },
  31. size: String,
  32. wrapperClassName: String,
  33. tip: _vueTypes.default.any,
  34. delay: Number,
  35. indicator: _vueTypes.default.any
  36. });
  37. // Render indicator
  38. exports.spinProps = spinProps;
  39. let defaultIndicator = null;
  40. function shouldDelay(spinning, delay) {
  41. return !!spinning && !!delay && !isNaN(Number(delay));
  42. }
  43. function setDefaultIndicator(Content) {
  44. const Indicator = Content.indicator;
  45. defaultIndicator = typeof Indicator === 'function' ? Indicator : () => (0, _vue.createVNode)(Indicator, null, null);
  46. }
  47. var _default = exports.default = (0, _vue.defineComponent)({
  48. compatConfig: {
  49. MODE: 3
  50. },
  51. name: 'ASpin',
  52. inheritAttrs: false,
  53. props: (0, _initDefaultProps.default)(spinProps(), {
  54. size: 'default',
  55. spinning: true,
  56. wrapperClassName: ''
  57. }),
  58. setup(props, _ref) {
  59. let {
  60. attrs,
  61. slots
  62. } = _ref;
  63. const {
  64. prefixCls,
  65. size,
  66. direction
  67. } = (0, _useConfigInject.default)('spin', props);
  68. const [wrapSSR, hashId] = (0, _style.default)(prefixCls);
  69. const sSpinning = (0, _vue.shallowRef)(props.spinning && !shouldDelay(props.spinning, props.delay));
  70. let updateSpinning;
  71. (0, _vue.watch)([() => props.spinning, () => props.delay], () => {
  72. updateSpinning === null || updateSpinning === void 0 ? void 0 : updateSpinning.cancel();
  73. updateSpinning = (0, _throttleDebounce.debounce)(props.delay, () => {
  74. sSpinning.value = props.spinning;
  75. });
  76. updateSpinning === null || updateSpinning === void 0 ? void 0 : updateSpinning();
  77. }, {
  78. immediate: true,
  79. flush: 'post'
  80. });
  81. (0, _vue.onBeforeUnmount)(() => {
  82. updateSpinning === null || updateSpinning === void 0 ? void 0 : updateSpinning.cancel();
  83. });
  84. return () => {
  85. var _a, _b;
  86. const {
  87. class: cls
  88. } = attrs,
  89. divProps = __rest(attrs, ["class"]);
  90. const {
  91. tip = (_a = slots.tip) === null || _a === void 0 ? void 0 : _a.call(slots)
  92. } = props;
  93. const children = (_b = slots.default) === null || _b === void 0 ? void 0 : _b.call(slots);
  94. const spinClassName = {
  95. [hashId.value]: true,
  96. [prefixCls.value]: true,
  97. [`${prefixCls.value}-sm`]: size.value === 'small',
  98. [`${prefixCls.value}-lg`]: size.value === 'large',
  99. [`${prefixCls.value}-spinning`]: sSpinning.value,
  100. [`${prefixCls.value}-show-text`]: !!tip,
  101. [`${prefixCls.value}-rtl`]: direction.value === 'rtl',
  102. [cls]: !!cls
  103. };
  104. function renderIndicator(prefixCls) {
  105. const dotClassName = `${prefixCls}-dot`;
  106. let indicator = (0, _propsUtil.getPropsSlot)(slots, props, 'indicator');
  107. // should not be render default indicator when indicator value is null
  108. if (indicator === null) {
  109. return null;
  110. }
  111. if (Array.isArray(indicator)) {
  112. indicator = indicator.length === 1 ? indicator[0] : indicator;
  113. }
  114. if ((0, _vue.isVNode)(indicator)) {
  115. return (0, _vue.cloneVNode)(indicator, {
  116. class: dotClassName
  117. });
  118. }
  119. if (defaultIndicator && (0, _vue.isVNode)(defaultIndicator())) {
  120. return (0, _vue.cloneVNode)(defaultIndicator(), {
  121. class: dotClassName
  122. });
  123. }
  124. return (0, _vue.createVNode)("span", {
  125. "class": `${dotClassName} ${prefixCls}-dot-spin`
  126. }, [(0, _vue.createVNode)("i", {
  127. "class": `${prefixCls}-dot-item`
  128. }, null), (0, _vue.createVNode)("i", {
  129. "class": `${prefixCls}-dot-item`
  130. }, null), (0, _vue.createVNode)("i", {
  131. "class": `${prefixCls}-dot-item`
  132. }, null), (0, _vue.createVNode)("i", {
  133. "class": `${prefixCls}-dot-item`
  134. }, null)]);
  135. }
  136. const spinElement = (0, _vue.createVNode)("div", (0, _objectSpread2.default)((0, _objectSpread2.default)({}, divProps), {}, {
  137. "class": spinClassName,
  138. "aria-live": "polite",
  139. "aria-busy": sSpinning.value
  140. }), [renderIndicator(prefixCls.value), tip ? (0, _vue.createVNode)("div", {
  141. "class": `${prefixCls.value}-text`
  142. }, [tip]) : null]);
  143. if (children && (0, _propsUtil.filterEmpty)(children).length) {
  144. const containerClassName = {
  145. [`${prefixCls.value}-container`]: true,
  146. [`${prefixCls.value}-blur`]: sSpinning.value
  147. };
  148. return wrapSSR((0, _vue.createVNode)("div", {
  149. "class": [`${prefixCls.value}-nested-loading`, props.wrapperClassName, hashId.value]
  150. }, [sSpinning.value && (0, _vue.createVNode)("div", {
  151. "key": "loading"
  152. }, [spinElement]), (0, _vue.createVNode)("div", {
  153. "class": containerClassName,
  154. "key": "container"
  155. }, [children])]));
  156. }
  157. return wrapSSR(spinElement);
  158. };
  159. }
  160. });