Modal.js 7.1 KB

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