ant-design-vue
Version:
An enterprise-class UI design language and Vue-based implementation
233 lines (232 loc) • 10.6 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.popconfirmProps = exports.default = void 0;
var _vue = require("vue");
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
var _tooltip = _interopRequireDefault(require("../tooltip"));
var _abstractTooltipProps = _interopRequireDefault(require("../tooltip/abstractTooltipProps"));
var _vueTypes = _interopRequireDefault(require("../_util/vue-types"));
var _propsUtil = require("../_util/props-util");
var _buttonTypes = require("../button/buttonTypes");
var _ExclamationCircleFilled = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/ExclamationCircleFilled"));
var _button = _interopRequireDefault(require("../button"));
var _LocaleReceiver = require("../locale-provider/LocaleReceiver");
var _default3 = _interopRequireDefault(require("../locale-provider/default"));
var _type = require("../_util/type");
var _useMergedState3 = _interopRequireDefault(require("../_util/hooks/useMergedState"));
var _devWarning = _interopRequireDefault(require("../vc-util/devWarning"));
var _KeyCode = _interopRequireDefault(require("../_util/KeyCode"));
var _useConfigInject2 = _interopRequireDefault(require("../_util/hooks/useConfigInject"));
var _classNames = _interopRequireDefault(require("../_util/classNames"));
var _transition = require("../_util/transition");
var _vnode = require("../_util/vnode");
var _omit = _interopRequireDefault(require("../_util/omit"));
var _Tooltip = require("../tooltip/Tooltip");
var _ActionButton = _interopRequireDefault(require("../_util/ActionButton"));
var _excluded = ["placement", "overlayClassName"];
var popconfirmProps = function popconfirmProps() {
return (0, _objectSpread2.default)((0, _objectSpread2.default)({}, (0, _abstractTooltipProps.default)()), {}, {
prefixCls: String,
content: _vueTypes.default.any,
title: _vueTypes.default.any,
okType: {
type: String,
default: 'primary'
},
disabled: {
type: Boolean,
default: false
},
okText: _vueTypes.default.any,
cancelText: _vueTypes.default.any,
icon: _vueTypes.default.any,
okButtonProps: {
type: Object,
default: undefined
},
cancelButtonProps: {
type: Object,
default: undefined
},
showCancel: {
type: Boolean,
default: true
},
onConfirm: Function,
onCancel: Function
});
};
exports.popconfirmProps = popconfirmProps;
var Popconfirm = (0, _vue.defineComponent)({
compatConfig: {
MODE: 3
},
name: 'APopconfirm',
props: (0, _propsUtil.initDefaultProps)(popconfirmProps(), (0, _objectSpread2.default)((0, _objectSpread2.default)({}, (0, _Tooltip.tooltipDefaultProps)()), {}, {
trigger: 'click',
transitionName: 'zoom-big',
placement: 'top',
mouseEnterDelay: 0.1,
mouseLeaveDelay: 0.1,
arrowPointAtCenter: false,
autoAdjustOverflow: true,
okType: 'primary',
disabled: false
})),
slots: ['title', 'content', 'okText', 'icon', 'cancelText', 'cancelButton', 'okButton'],
emits: ['update:visible', 'visibleChange'],
setup: function setup(props, _ref) {
var slots = _ref.slots,
emit = _ref.emit,
expose = _ref.expose;
(0, _vue.onMounted)(function () {
(0, _devWarning.default)(props.defaultVisible === undefined, 'Popconfirm', "'defaultVisible' is deprecated, please use 'v-model:visible'");
});
var tooltipRef = (0, _vue.ref)();
expose({
getPopupDomNode: function getPopupDomNode() {
var _tooltipRef$value, _tooltipRef$value$get;
return (_tooltipRef$value = tooltipRef.value) === null || _tooltipRef$value === void 0 ? void 0 : (_tooltipRef$value$get = _tooltipRef$value.getPopupDomNode) === null || _tooltipRef$value$get === void 0 ? void 0 : _tooltipRef$value$get.call(_tooltipRef$value);
}
});
var _useMergedState = (0, _useMergedState3.default)(false, {
value: (0, _vue.toRef)(props, 'visible'),
defaultValue: props.defaultVisible
}),
_useMergedState2 = (0, _slicedToArray2.default)(_useMergedState, 2),
visible = _useMergedState2[0],
setVisible = _useMergedState2[1];
var settingVisible = function settingVisible(value, e) {
if (props.visible === undefined) {
setVisible(value);
}
emit('update:visible', value);
emit('visibleChange', value, e);
};
var close = function close(e) {
settingVisible(false, e);
};
var onConfirm = function onConfirm(e) {
var _props$onConfirm;
return (_props$onConfirm = props.onConfirm) === null || _props$onConfirm === void 0 ? void 0 : _props$onConfirm.call(props, e);
};
var onCancel = function onCancel(e) {
var _props$onCancel;
settingVisible(false, e);
(_props$onCancel = props.onCancel) === null || _props$onCancel === void 0 ? void 0 : _props$onCancel.call(props, e);
};
var onKeyDown = function onKeyDown(e) {
if (e.keyCode === _KeyCode.default.ESC && visible) {
settingVisible(false, e);
}
};
var onVisibleChange = function onVisibleChange(value) {
var disabled = props.disabled;
if (disabled) {
return;
}
settingVisible(value);
};
var _useConfigInject = (0, _useConfigInject2.default)('popconfirm', props),
prefixClsConfirm = _useConfigInject.prefixCls,
getPrefixCls = _useConfigInject.getPrefixCls;
var rootPrefixCls = (0, _vue.computed)(function () {
return getPrefixCls();
});
var popoverPrefixCls = (0, _vue.computed)(function () {
return getPrefixCls('popover');
});
var btnPrefixCls = (0, _vue.computed)(function () {
return getPrefixCls('btn');
});
var _useLocaleReceiver = (0, _LocaleReceiver.useLocaleReceiver)('Popconfirm', _default3.default.Popconfirm),
_useLocaleReceiver2 = (0, _slicedToArray2.default)(_useLocaleReceiver, 1),
popconfirmLocale = _useLocaleReceiver2[0];
var renderOverlay = function renderOverlay() {
var _slots$title, _slots$cancel, _slots$okText, _slots$icon;
var okButtonProps = props.okButtonProps,
cancelButtonProps = props.cancelButtonProps,
_props$title = props.title,
title = _props$title === void 0 ? (_slots$title = slots.title) === null || _slots$title === void 0 ? void 0 : _slots$title.call(slots) : _props$title,
_props$cancelText = props.cancelText,
cancelText = _props$cancelText === void 0 ? (_slots$cancel = slots.cancel) === null || _slots$cancel === void 0 ? void 0 : _slots$cancel.call(slots) : _props$cancelText,
_props$okText = props.okText,
okText = _props$okText === void 0 ? (_slots$okText = slots.okText) === null || _slots$okText === void 0 ? void 0 : _slots$okText.call(slots) : _props$okText,
okType = props.okType,
_props$icon = props.icon,
icon = _props$icon === void 0 ? (_slots$icon = slots.icon) === null || _slots$icon === void 0 ? void 0 : _slots$icon.call(slots) : _props$icon,
_props$showCancel = props.showCancel,
showCancel = _props$showCancel === void 0 ? true : _props$showCancel;
var cancelButton = slots.cancelButton,
okButton = slots.okButton;
var cancelProps = (0, _objectSpread2.default)({
onClick: onCancel,
size: 'small'
}, cancelButtonProps);
var okProps = (0, _objectSpread2.default)((0, _objectSpread2.default)({
onClick: onConfirm
}, (0, _buttonTypes.convertLegacyProps)(okType)), {}, {
size: 'small'
}, okButtonProps);
return (0, _vue.createVNode)("div", {
"class": "".concat(popoverPrefixCls.value, "-inner-content")
}, [(0, _vue.createVNode)("div", {
"class": "".concat(popoverPrefixCls.value, "-message")
}, [icon || (0, _vue.createVNode)(_ExclamationCircleFilled.default, null, null), (0, _vue.createVNode)("div", {
"class": "".concat(popoverPrefixCls.value, "-message-title")
}, [title])]), (0, _vue.createVNode)("div", {
"class": "".concat(popoverPrefixCls.value, "-buttons")
}, [showCancel ? cancelButton ? cancelButton(cancelProps) : (0, _vue.createVNode)(_button.default, cancelProps, {
default: function _default() {
return [cancelText || popconfirmLocale.value.cancelText];
}
}) : null, okButton ? okButton(okProps) : (0, _vue.createVNode)(_ActionButton.default, {
"buttonProps": (0, _objectSpread2.default)((0, _objectSpread2.default)({
size: 'small'
}, (0, _buttonTypes.convertLegacyProps)(okType)), okButtonProps),
"actionFn": onConfirm,
"close": close,
"prefixCls": btnPrefixCls.value,
"quitOnNullishReturnValue": true,
"emitEvent": true
}, {
default: function _default() {
return [okText || popconfirmLocale.value.okText];
}
})])]);
};
return function () {
var _slots$default;
var placement = props.placement,
overlayClassName = props.overlayClassName,
restProps = (0, _objectWithoutProperties2.default)(props, _excluded);
var otherProps = (0, _omit.default)(restProps, ['title', 'content', 'cancelText', 'okText', 'onUpdate:visible', 'onConfirm', 'onCancel']);
var overlayClassNames = (0, _classNames.default)(prefixClsConfirm.value, overlayClassName);
return (0, _vue.createVNode)(_tooltip.default, (0, _objectSpread2.default)((0, _objectSpread2.default)({}, otherProps), {}, {
"prefixCls": popoverPrefixCls.value,
"placement": placement,
"onVisibleChange": onVisibleChange,
"visible": visible.value,
"overlayClassName": overlayClassNames,
"transitionName": (0, _transition.getTransitionName)(rootPrefixCls.value, 'zoom-big', props.transitionName),
"ref": tooltipRef
}), {
default: function _default() {
return [(0, _vnode.cloneVNodes)(((_slots$default = slots.default) === null || _slots$default === void 0 ? void 0 : _slots$default.call(slots)) || [], {
onKeydown: function onKeydown(e) {
onKeyDown(e);
}
}, false)];
},
title: renderOverlay
});
};
}
});
var _default2 = (0, _type.withInstall)(Popconfirm);
exports.default = _default2;