button.js 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. Object.defineProperty(exports, "buttonProps", {
  7. enumerable: true,
  8. get: function get() {
  9. return _buttonTypes.default;
  10. }
  11. });
  12. exports.default = void 0;
  13. var _vue = require("vue");
  14. var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
  15. var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
  16. var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
  17. var _wave = _interopRequireDefault(require("../_util/wave"));
  18. var _buttonTypes = _interopRequireDefault(require("./buttonTypes"));
  19. var _propsUtil = require("../_util/props-util");
  20. var _useConfigInject2 = _interopRequireDefault(require("../_util/hooks/useConfigInject"));
  21. var _devWarning = _interopRequireDefault(require("../vc-util/devWarning"));
  22. var _LoadingIcon = _interopRequireDefault(require("./LoadingIcon"));
  23. var rxTwoCNChar = /^[\u4e00-\u9fa5]{2}$/;
  24. var isTwoCNChar = rxTwoCNChar.test.bind(rxTwoCNChar);
  25. function isUnborderedButtonType(type) {
  26. return type === 'text' || type === 'link';
  27. }
  28. var _default2 = (0, _vue.defineComponent)({
  29. compatConfig: {
  30. MODE: 3
  31. },
  32. name: 'AButton',
  33. inheritAttrs: false,
  34. __ANT_BUTTON: true,
  35. props: (0, _propsUtil.initDefaultProps)((0, _buttonTypes.default)(), {
  36. type: 'default'
  37. }),
  38. slots: ['icon'],
  39. // emits: ['click', 'mousedown'],
  40. setup: function setup(props, _ref) {
  41. var slots = _ref.slots,
  42. attrs = _ref.attrs,
  43. emit = _ref.emit,
  44. expose = _ref.expose;
  45. var _useConfigInject = (0, _useConfigInject2.default)('btn', props),
  46. prefixCls = _useConfigInject.prefixCls,
  47. autoInsertSpaceInButton = _useConfigInject.autoInsertSpaceInButton,
  48. direction = _useConfigInject.direction,
  49. size = _useConfigInject.size;
  50. var buttonNodeRef = (0, _vue.ref)(null);
  51. var delayTimeoutRef = (0, _vue.ref)(undefined);
  52. var isNeedInserted = false;
  53. var innerLoading = (0, _vue.ref)(false);
  54. var hasTwoCNChar = (0, _vue.ref)(false);
  55. var autoInsertSpace = (0, _vue.computed)(function () {
  56. return autoInsertSpaceInButton.value !== false;
  57. });
  58. // =============== Update Loading ===============
  59. var loadingOrDelay = (0, _vue.computed)(function () {
  60. return (0, _typeof2.default)(props.loading) === 'object' && props.loading.delay ? props.loading.delay || true : !!props.loading;
  61. });
  62. (0, _vue.watch)(loadingOrDelay, function (val) {
  63. clearTimeout(delayTimeoutRef.value);
  64. if (typeof loadingOrDelay.value === 'number') {
  65. delayTimeoutRef.value = setTimeout(function () {
  66. innerLoading.value = val;
  67. }, loadingOrDelay.value);
  68. } else {
  69. innerLoading.value = val;
  70. }
  71. }, {
  72. immediate: true
  73. });
  74. var classes = (0, _vue.computed)(function () {
  75. var _ref2;
  76. var type = props.type,
  77. _props$shape = props.shape,
  78. shape = _props$shape === void 0 ? 'default' : _props$shape,
  79. ghost = props.ghost,
  80. block = props.block,
  81. danger = props.danger;
  82. var pre = prefixCls.value;
  83. var sizeClassNameMap = {
  84. large: 'lg',
  85. small: 'sm',
  86. middle: undefined
  87. };
  88. var sizeFullname = size.value;
  89. var sizeCls = sizeFullname ? sizeClassNameMap[sizeFullname] || '' : '';
  90. return _ref2 = {}, (0, _defineProperty2.default)(_ref2, "".concat(pre), true), (0, _defineProperty2.default)(_ref2, "".concat(pre, "-").concat(type), type), (0, _defineProperty2.default)(_ref2, "".concat(pre, "-").concat(shape), shape !== 'default' && shape), (0, _defineProperty2.default)(_ref2, "".concat(pre, "-").concat(sizeCls), sizeCls), (0, _defineProperty2.default)(_ref2, "".concat(pre, "-loading"), innerLoading.value), (0, _defineProperty2.default)(_ref2, "".concat(pre, "-background-ghost"), ghost && !isUnborderedButtonType(type)), (0, _defineProperty2.default)(_ref2, "".concat(pre, "-two-chinese-chars"), hasTwoCNChar.value && autoInsertSpace.value), (0, _defineProperty2.default)(_ref2, "".concat(pre, "-block"), block), (0, _defineProperty2.default)(_ref2, "".concat(pre, "-dangerous"), !!danger), (0, _defineProperty2.default)(_ref2, "".concat(pre, "-rtl"), direction.value === 'rtl'), _ref2;
  91. });
  92. var fixTwoCNChar = function fixTwoCNChar() {
  93. // Fix for HOC usage like <FormatMessage />
  94. var node = buttonNodeRef.value;
  95. if (!node || autoInsertSpaceInButton.value === false) {
  96. return;
  97. }
  98. var buttonText = node.textContent;
  99. if (isNeedInserted && isTwoCNChar(buttonText)) {
  100. if (!hasTwoCNChar.value) {
  101. hasTwoCNChar.value = true;
  102. }
  103. } else if (hasTwoCNChar.value) {
  104. hasTwoCNChar.value = false;
  105. }
  106. };
  107. var handleClick = function handleClick(event) {
  108. // https://github.com/ant-design/ant-design/issues/30207
  109. if (innerLoading.value || props.disabled) {
  110. event.preventDefault();
  111. return;
  112. }
  113. emit('click', event);
  114. };
  115. var insertSpace = function insertSpace(child, needInserted) {
  116. var SPACE = needInserted ? ' ' : '';
  117. if (child.type === _vue.Text) {
  118. var text = child.children.trim();
  119. if (isTwoCNChar(text)) {
  120. text = text.split('').join(SPACE);
  121. }
  122. return (0, _vue.createVNode)("span", null, [text]);
  123. }
  124. return child;
  125. };
  126. (0, _vue.watchEffect)(function () {
  127. (0, _devWarning.default)(!(props.ghost && isUnborderedButtonType(props.type)), 'Button', "`link` or `text` button can't be a `ghost` button.");
  128. });
  129. (0, _vue.onMounted)(fixTwoCNChar);
  130. (0, _vue.onUpdated)(fixTwoCNChar);
  131. (0, _vue.onBeforeUnmount)(function () {
  132. delayTimeoutRef.value && clearTimeout(delayTimeoutRef.value);
  133. });
  134. var focus = function focus() {
  135. var _buttonNodeRef$value;
  136. (_buttonNodeRef$value = buttonNodeRef.value) === null || _buttonNodeRef$value === void 0 ? void 0 : _buttonNodeRef$value.focus();
  137. };
  138. var blur = function blur() {
  139. var _buttonNodeRef$value2;
  140. (_buttonNodeRef$value2 = buttonNodeRef.value) === null || _buttonNodeRef$value2 === void 0 ? void 0 : _buttonNodeRef$value2.blur();
  141. };
  142. expose({
  143. focus: focus,
  144. blur: blur
  145. });
  146. return function () {
  147. var _slots$icon, _slots$default;
  148. var _props$icon = props.icon,
  149. icon = _props$icon === void 0 ? (_slots$icon = slots.icon) === null || _slots$icon === void 0 ? void 0 : _slots$icon.call(slots) : _props$icon;
  150. var children = (0, _propsUtil.flattenChildren)((_slots$default = slots.default) === null || _slots$default === void 0 ? void 0 : _slots$default.call(slots));
  151. isNeedInserted = children.length === 1 && !icon && !isUnborderedButtonType(props.type);
  152. var type = props.type,
  153. htmlType = props.htmlType,
  154. disabled = props.disabled,
  155. href = props.href,
  156. title = props.title,
  157. target = props.target,
  158. onMousedown = props.onMousedown;
  159. var iconType = innerLoading.value ? 'loading' : icon;
  160. var buttonProps = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, attrs), {}, {
  161. title: title,
  162. disabled: disabled,
  163. class: [classes.value, attrs.class, (0, _defineProperty2.default)({}, "".concat(prefixCls.value, "-icon-only"), children.length === 0 && !!iconType)],
  164. onClick: handleClick,
  165. onMousedown: onMousedown
  166. });
  167. // https://github.com/vueComponent/ant-design-vue/issues/4930
  168. if (!disabled) {
  169. delete buttonProps.disabled;
  170. }
  171. var iconNode = icon && !innerLoading.value ? icon : (0, _vue.createVNode)(_LoadingIcon.default, {
  172. "existIcon": !!icon,
  173. "prefixCls": prefixCls.value,
  174. "loading": !!innerLoading.value
  175. }, null);
  176. var kids = children.map(function (child) {
  177. return insertSpace(child, isNeedInserted && autoInsertSpace.value);
  178. });
  179. if (href !== undefined) {
  180. return (0, _vue.createVNode)("a", (0, _objectSpread2.default)((0, _objectSpread2.default)({}, buttonProps), {}, {
  181. "href": href,
  182. "target": target,
  183. "ref": buttonNodeRef
  184. }), [iconNode, kids]);
  185. }
  186. var buttonNode = (0, _vue.createVNode)("button", (0, _objectSpread2.default)((0, _objectSpread2.default)({}, buttonProps), {}, {
  187. "ref": buttonNodeRef,
  188. "type": htmlType
  189. }), [iconNode, kids]);
  190. if (isUnborderedButtonType(type)) {
  191. return buttonNode;
  192. }
  193. return (0, _vue.createVNode)(_wave.default, {
  194. "ref": "wave",
  195. "disabled": !!innerLoading.value
  196. }, {
  197. default: function _default() {
  198. return [buttonNode];
  199. }
  200. });
  201. };
  202. }
  203. });
  204. exports.default = _default2;