UNPKG

antd

Version:

An enterprise-class UI design language and React components implementation

105 lines (104 loc) 3.87 kB
"use strict"; "use client"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = exports.Overlay = void 0; var React = _interopRequireWildcard(require("react")); var _ExclamationCircleFilled = _interopRequireDefault(require("@ant-design/icons/ExclamationCircleFilled")); var _clsx = require("clsx"); var _ActionButton = _interopRequireDefault(require("../_util/ActionButton")); var _getRenderPropValue = require("../_util/getRenderPropValue"); var _Button = _interopRequireDefault(require("../button/Button")); var _buttonHelpers = require("../button/buttonHelpers"); var _configProvider = require("../config-provider"); var _locale = require("../locale"); var _en_US = _interopRequireDefault(require("../locale/en_US")); var _PurePanel = _interopRequireDefault(require("../popover/PurePanel")); var _style = _interopRequireDefault(require("./style")); const Overlay = props => { const { prefixCls, okButtonProps, cancelButtonProps, title, description, cancelText, okText, okType = 'primary', icon = /*#__PURE__*/React.createElement(_ExclamationCircleFilled.default, null), showCancel = true, close, onConfirm, onCancel, onPopupClick, classNames, styles } = props; const { getPrefixCls } = React.useContext(_configProvider.ConfigContext); const [contextLocale] = (0, _locale.useLocale)('Popconfirm', _en_US.default.Popconfirm); const titleNode = (0, _getRenderPropValue.getRenderPropValue)(title); const descriptionNode = (0, _getRenderPropValue.getRenderPropValue)(description); return /*#__PURE__*/React.createElement("div", { className: `${prefixCls}-inner-content`, onClick: onPopupClick }, /*#__PURE__*/React.createElement("div", { className: `${prefixCls}-message` }, icon && /*#__PURE__*/React.createElement("span", { className: `${prefixCls}-message-icon` }, icon), /*#__PURE__*/React.createElement("div", { className: `${prefixCls}-message-text` }, titleNode && (/*#__PURE__*/React.createElement("div", { className: (0, _clsx.clsx)(`${prefixCls}-title`, classNames?.title), style: styles?.title }, titleNode)), descriptionNode && (/*#__PURE__*/React.createElement("div", { className: (0, _clsx.clsx)(`${prefixCls}-description`, classNames?.content), style: styles?.content }, descriptionNode)))), /*#__PURE__*/React.createElement("div", { className: `${prefixCls}-buttons` }, showCancel && (/*#__PURE__*/React.createElement(_Button.default, { onClick: onCancel, size: "small", ...cancelButtonProps }, cancelText || contextLocale?.cancelText)), /*#__PURE__*/React.createElement(_ActionButton.default, { buttonProps: { size: 'small', ...(0, _buttonHelpers.convertLegacyProps)(okType), ...okButtonProps }, actionFn: onConfirm, close: close, prefixCls: getPrefixCls('btn'), quitOnNullishReturnValue: true, emitEvent: true }, okText || contextLocale?.okText))); }; exports.Overlay = Overlay; const PurePanel = props => { const { prefixCls: customizePrefixCls, placement, className, style, ...restProps } = props; const { getPrefixCls } = React.useContext(_configProvider.ConfigContext); const prefixCls = getPrefixCls('popconfirm', customizePrefixCls); (0, _style.default)(prefixCls); return /*#__PURE__*/React.createElement(_PurePanel.default, { placement: placement, className: (0, _clsx.clsx)(prefixCls, className), style: style, content: /*#__PURE__*/React.createElement(Overlay, { prefixCls: prefixCls, ...restProps }) }); }; var _default = exports.default = PurePanel;