Modal.js 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209
  1. import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
  2. import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
  3. import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
  4. import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
  5. var _excluded = ["prefixCls", "visible", "wrapClassName", "centered", "getContainer", "closeIcon", "focusTriggerAfterClose"];
  6. import { resolveDirective as _resolveDirective, createVNode as _createVNode, Fragment as _Fragment } from "vue";
  7. import { defineComponent } from 'vue';
  8. import classNames from '../_util/classNames';
  9. import Dialog from '../vc-dialog';
  10. import PropTypes from '../_util/vue-types';
  11. import addEventListener from '../vc-util/Dom/addEventListener';
  12. import CloseOutlined from "@ant-design/icons-vue/es/icons/CloseOutlined";
  13. import Button from '../button';
  14. import { convertLegacyProps } from '../button/buttonTypes';
  15. import { useLocaleReceiver } from '../locale-provider/LocaleReceiver';
  16. import initDefaultProps from '../_util/props-util/initDefaultProps';
  17. import { canUseDocElement } from '../_util/styleChecker';
  18. import useConfigInject from '../_util/hooks/useConfigInject';
  19. import { getTransitionName } from '../_util/transition';
  20. var mousePosition = null;
  21. // ref: https://github.com/ant-design/ant-design/issues/15795
  22. var getClickPosition = function getClickPosition(e) {
  23. mousePosition = {
  24. x: e.pageX,
  25. y: e.pageY
  26. };
  27. // 100ms 内发生过点击事件,则从点击位置动画展示
  28. // 否则直接 zoom 展示
  29. // 这样可以兼容非点击方式展开
  30. setTimeout(function () {
  31. return mousePosition = null;
  32. }, 100);
  33. };
  34. // 只有点击事件支持从鼠标位置动画展开
  35. if (canUseDocElement()) {
  36. addEventListener(document.documentElement, 'click', getClickPosition, true);
  37. }
  38. export var modalProps = function modalProps() {
  39. return {
  40. prefixCls: String,
  41. visible: {
  42. type: Boolean,
  43. default: undefined
  44. },
  45. confirmLoading: {
  46. type: Boolean,
  47. default: undefined
  48. },
  49. title: PropTypes.any,
  50. closable: {
  51. type: Boolean,
  52. default: undefined
  53. },
  54. closeIcon: PropTypes.any,
  55. onOk: Function,
  56. onCancel: Function,
  57. 'onUpdate:visible': Function,
  58. onChange: Function,
  59. afterClose: Function,
  60. centered: {
  61. type: Boolean,
  62. default: undefined
  63. },
  64. width: [String, Number],
  65. footer: PropTypes.any,
  66. okText: PropTypes.any,
  67. okType: String,
  68. cancelText: PropTypes.any,
  69. icon: PropTypes.any,
  70. maskClosable: {
  71. type: Boolean,
  72. default: undefined
  73. },
  74. forceRender: {
  75. type: Boolean,
  76. default: undefined
  77. },
  78. okButtonProps: Object,
  79. cancelButtonProps: Object,
  80. destroyOnClose: {
  81. type: Boolean,
  82. default: undefined
  83. },
  84. wrapClassName: String,
  85. maskTransitionName: String,
  86. transitionName: String,
  87. getContainer: {
  88. type: [String, Function, Boolean, Object],
  89. default: undefined
  90. },
  91. zIndex: Number,
  92. bodyStyle: {
  93. type: Object,
  94. default: undefined
  95. },
  96. maskStyle: {
  97. type: Object,
  98. default: undefined
  99. },
  100. mask: {
  101. type: Boolean,
  102. default: undefined
  103. },
  104. keyboard: {
  105. type: Boolean,
  106. default: undefined
  107. },
  108. wrapProps: Object,
  109. focusTriggerAfterClose: {
  110. type: Boolean,
  111. default: undefined
  112. },
  113. modalRender: Function
  114. };
  115. };
  116. export var destroyFns = [];
  117. export default defineComponent({
  118. compatConfig: {
  119. MODE: 3
  120. },
  121. name: 'AModal',
  122. inheritAttrs: false,
  123. props: initDefaultProps(modalProps(), {
  124. width: 520,
  125. transitionName: 'zoom',
  126. maskTransitionName: 'fade',
  127. confirmLoading: false,
  128. visible: false,
  129. okType: 'primary'
  130. }),
  131. setup: function setup(props, _ref) {
  132. var emit = _ref.emit,
  133. slots = _ref.slots,
  134. attrs = _ref.attrs;
  135. var _useLocaleReceiver = useLocaleReceiver('Modal'),
  136. _useLocaleReceiver2 = _slicedToArray(_useLocaleReceiver, 1),
  137. locale = _useLocaleReceiver2[0];
  138. var _useConfigInject = useConfigInject('modal', props),
  139. prefixCls = _useConfigInject.prefixCls,
  140. rootPrefixCls = _useConfigInject.rootPrefixCls,
  141. direction = _useConfigInject.direction,
  142. getPopupContainer = _useConfigInject.getPopupContainer;
  143. var handleCancel = function handleCancel(e) {
  144. emit('update:visible', false);
  145. emit('cancel', e);
  146. emit('change', false);
  147. };
  148. var handleOk = function handleOk(e) {
  149. emit('ok', e);
  150. };
  151. var renderFooter = function renderFooter() {
  152. var _slots$okText, _slots$cancelText;
  153. var _props$okText = props.okText,
  154. okText = _props$okText === void 0 ? (_slots$okText = slots.okText) === null || _slots$okText === void 0 ? void 0 : _slots$okText.call(slots) : _props$okText,
  155. okType = props.okType,
  156. _props$cancelText = props.cancelText,
  157. cancelText = _props$cancelText === void 0 ? (_slots$cancelText = slots.cancelText) === null || _slots$cancelText === void 0 ? void 0 : _slots$cancelText.call(slots) : _props$cancelText,
  158. confirmLoading = props.confirmLoading;
  159. return _createVNode(_Fragment, null, [_createVNode(Button, _objectSpread({
  160. "onClick": handleCancel
  161. }, props.cancelButtonProps), {
  162. default: function _default() {
  163. return [cancelText || locale.value.cancelText];
  164. }
  165. }), _createVNode(Button, _objectSpread(_objectSpread({}, convertLegacyProps(okType)), {}, {
  166. "loading": confirmLoading,
  167. "onClick": handleOk
  168. }, props.okButtonProps), {
  169. default: function _default() {
  170. return [okText || locale.value.okText];
  171. }
  172. })]);
  173. };
  174. return function () {
  175. var _slots$closeIcon, _classNames;
  176. var customizePrefixCls = props.prefixCls,
  177. visible = props.visible,
  178. wrapClassName = props.wrapClassName,
  179. centered = props.centered,
  180. getContainer = props.getContainer,
  181. _props$closeIcon = props.closeIcon,
  182. _closeIcon = _props$closeIcon === void 0 ? (_slots$closeIcon = slots.closeIcon) === null || _slots$closeIcon === void 0 ? void 0 : _slots$closeIcon.call(slots) : _props$closeIcon,
  183. _props$focusTriggerAf = props.focusTriggerAfterClose,
  184. focusTriggerAfterClose = _props$focusTriggerAf === void 0 ? true : _props$focusTriggerAf,
  185. restProps = _objectWithoutProperties(props, _excluded);
  186. var wrapClassNameExtended = classNames(wrapClassName, (_classNames = {}, _defineProperty(_classNames, "".concat(prefixCls.value, "-centered"), !!centered), _defineProperty(_classNames, "".concat(prefixCls.value, "-wrap-rtl"), direction.value === 'rtl'), _classNames));
  187. return _createVNode(Dialog, _objectSpread(_objectSpread(_objectSpread({}, restProps), attrs), {}, {
  188. "getContainer": getContainer || getPopupContainer.value,
  189. "prefixCls": prefixCls.value,
  190. "wrapClassName": wrapClassNameExtended,
  191. "visible": visible,
  192. "mousePosition": mousePosition,
  193. "onClose": handleCancel,
  194. "focusTriggerAfterClose": focusTriggerAfterClose,
  195. "transitionName": getTransitionName(rootPrefixCls.value, 'zoom', props.transitionName),
  196. "maskTransitionName": getTransitionName(rootPrefixCls.value, 'fade', props.maskTransitionName)
  197. }), _objectSpread(_objectSpread({}, slots), {}, {
  198. footer: slots.footer || renderFooter,
  199. closeIcon: function closeIcon() {
  200. return _createVNode("span", {
  201. "class": "".concat(prefixCls.value, "-close-x")
  202. }, [_closeIcon || _createVNode(CloseOutlined, {
  203. "class": "".concat(prefixCls.value, "-close-icon")
  204. }, null)]);
  205. }
  206. }));
  207. };
  208. }
  209. });