UNPKG

@aplus-frontend/antdv

Version:

Vue basic component library maintained based on ant-design-vue

224 lines (223 loc) 9.31 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.popconfirmProps = exports.default = void 0; var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2")); var _vue = require("vue"); var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _popover = _interopRequireDefault(require("../popover")); var _abstractTooltipProps = _interopRequireDefault(require("../tooltip/abstractTooltipProps")); 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 _en_US = _interopRequireDefault(require("../locale/en_US")); var _type = require("../_util/type"); var _useMergedState = _interopRequireDefault(require("../_util/hooks/useMergedState")); var _KeyCode = _interopRequireDefault(require("../_util/KeyCode")); var _useConfigInject = _interopRequireDefault(require("../config-provider/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 _style = _interopRequireDefault(require("./style")); var _warning = _interopRequireDefault(require("../_util/warning")); var __rest = void 0 && (void 0).__rest || function (s, e) { var t = {}; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p]; if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]]; } return t; }; const popconfirmProps = () => (0, _extends2.default)((0, _extends2.default)({}, (0, _abstractTooltipProps.default)()), { prefixCls: String, content: (0, _type.anyType)(), title: (0, _type.anyType)(), description: (0, _type.anyType)(), okType: (0, _type.stringType)('primary'), disabled: { type: Boolean, default: false }, okText: (0, _type.anyType)(), cancelText: (0, _type.anyType)(), icon: (0, _type.anyType)(), okButtonProps: (0, _type.objectType)(), cancelButtonProps: (0, _type.objectType)(), showCancel: { type: Boolean, default: true }, onConfirm: Function, onCancel: Function }); exports.popconfirmProps = popconfirmProps; const Popconfirm = (0, _vue.defineComponent)({ compatConfig: { MODE: 3 }, name: 'APopconfirm', inheritAttrs: false, props: (0, _propsUtil.initDefaultProps)(popconfirmProps(), (0, _extends2.default)((0, _extends2.default)({}, (0, _Tooltip.tooltipDefaultProps)()), { trigger: 'click', placement: 'top', mouseEnterDelay: 0.1, mouseLeaveDelay: 0.1, arrowPointAtCenter: false, autoAdjustOverflow: true, okType: 'primary', disabled: false })), slots: Object, // emits: ['update:open', 'visibleChange'], setup(props, _ref) { let { slots, emit, expose, attrs } = _ref; const rootRef = (0, _vue.ref)(); (0, _warning.default)(props.visible === undefined, 'Popconfirm', `\`visible\` will be removed in next major version, please use \`open\` instead.`); expose({ getPopupDomNode: () => { var _a, _b; return (_b = (_a = rootRef.value) === null || _a === void 0 ? void 0 : _a.getPopupDomNode) === null || _b === void 0 ? void 0 : _b.call(_a); } }); const [open, setOpen] = (0, _useMergedState.default)(false, { value: (0, _vue.toRef)(props, 'open') }); const settingOpen = (value, e) => { if (props.open === undefined) { setOpen(value); } emit('update:open', value); emit('openChange', value, e); }; const close = e => { settingOpen(false, e); }; const onConfirm = e => { var _a; return (_a = props.onConfirm) === null || _a === void 0 ? void 0 : _a.call(props, e); }; const onCancel = e => { var _a; settingOpen(false, e); (_a = props.onCancel) === null || _a === void 0 ? void 0 : _a.call(props, e); }; const onKeyDown = e => { if (e.keyCode === _KeyCode.default.ESC && open) { settingOpen(false, e); } }; const onOpenChange = value => { const { disabled } = props; if (disabled) { return; } settingOpen(value); }; const { prefixCls: prefixClsConfirm, getPrefixCls } = (0, _useConfigInject.default)('popconfirm', props); const rootPrefixCls = (0, _vue.computed)(() => getPrefixCls()); const btnPrefixCls = (0, _vue.computed)(() => getPrefixCls('btn')); const [wrapSSR] = (0, _style.default)(prefixClsConfirm); const [popconfirmLocale] = (0, _LocaleReceiver.useLocaleReceiver)('Popconfirm', _en_US.default.Popconfirm); const renderOverlay = () => { var _a, _b, _c, _d, _e; const { okButtonProps, cancelButtonProps, title = (_a = slots.title) === null || _a === void 0 ? void 0 : _a.call(slots), description = (_b = slots.description) === null || _b === void 0 ? void 0 : _b.call(slots), cancelText = (_c = slots.cancel) === null || _c === void 0 ? void 0 : _c.call(slots), okText = (_d = slots.okText) === null || _d === void 0 ? void 0 : _d.call(slots), okType, icon = ((_e = slots.icon) === null || _e === void 0 ? void 0 : _e.call(slots)) || (0, _vue.createVNode)(_ExclamationCircleFilled.default, null, null), showCancel = true } = props; const { cancelButton, okButton } = slots; const cancelProps = (0, _extends2.default)({ onClick: onCancel, size: 'small' }, cancelButtonProps); const okProps = (0, _extends2.default)((0, _extends2.default)((0, _extends2.default)({ onClick: onConfirm }, (0, _buttonTypes.convertLegacyProps)(okType)), { size: 'small' }), okButtonProps); return (0, _vue.createVNode)("div", { "class": `${prefixClsConfirm.value}-inner-content` }, [(0, _vue.createVNode)("div", { "class": `${prefixClsConfirm.value}-message` }, [icon && (0, _vue.createVNode)("span", { "class": `${prefixClsConfirm.value}-message-icon` }, [icon]), (0, _vue.createVNode)("div", { "class": [`${prefixClsConfirm.value}-message-title`, { [`${prefixClsConfirm.value}-message-title-only`]: !!description }] }, [title])]), description && (0, _vue.createVNode)("div", { "class": `${prefixClsConfirm.value}-description` }, [description]), (0, _vue.createVNode)("div", { "class": `${prefixClsConfirm.value}-buttons` }, [showCancel ? cancelButton ? cancelButton(cancelProps) : (0, _vue.createVNode)(_button.default, cancelProps, { default: () => [cancelText || popconfirmLocale.value.cancelText] }) : null, okButton ? okButton(okProps) : (0, _vue.createVNode)(_ActionButton.default, { "buttonProps": (0, _extends2.default)((0, _extends2.default)({ size: 'small' }, (0, _buttonTypes.convertLegacyProps)(okType)), okButtonProps), "actionFn": onConfirm, "close": close, "prefixCls": btnPrefixCls.value, "quitOnNullishReturnValue": true, "emitEvent": true }, { default: () => [okText || popconfirmLocale.value.okText] })])]); }; return () => { var _a; const { placement, overlayClassName, trigger = 'click' } = props, restProps = __rest(props, ["placement", "overlayClassName", "trigger"]); const otherProps = (0, _omit.default)(restProps, ['title', 'content', 'cancelText', 'okText', 'onUpdate:open', 'onConfirm', 'onCancel', 'prefixCls']); const overlayClassNames = (0, _classNames.default)(prefixClsConfirm.value, overlayClassName); return wrapSSR((0, _vue.createVNode)(_popover.default, (0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)({}, otherProps), attrs), {}, { "trigger": trigger, "placement": placement, "onOpenChange": onOpenChange, "open": open.value, "overlayClassName": overlayClassNames, "transitionName": (0, _transition.getTransitionName)(rootPrefixCls.value, 'zoom-big', props.transitionName), "ref": rootRef, "data-popover-inject": true }), { default: () => [(0, _vnode.cloneVNodes)(((_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots)) || [], { onKeydown: e => { onKeyDown(e); } }, false)], content: renderOverlay })); }; } }); var _default = exports.default = (0, _type.withInstall)(Popconfirm);