UNPKG

linkmore-design

Version:

🌈 πŸš€lmη»„δ»ΆεΊ“γ€‚πŸš€

97 lines (94 loc) β€’ 3.32 kB
"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _ExclamationCircleFilled = _interopRequireDefault(require("@ant-design/icons/ExclamationCircleFilled")); var _classnames = _interopRequireDefault(require("classnames")); var _useMergedState = _interopRequireDefault(require("rc-util/lib/hooks/useMergedState")); var _KeyCode = _interopRequireDefault(require("rc-util/lib/KeyCode")); var React = _interopRequireWildcard(require("react")); var _configProvider = require("../config-provider"); var _popover = _interopRequireDefault(require("../popover")); var _reactNode = require("../_util/reactNode"); var _PurePanel = require("./PurePanel"); const Popconfirm = /*#__PURE__*/React.forwardRef((props, ref) => { const { getPrefixCls } = React.useContext(_configProvider.ConfigContext); const [open, setOpen] = (0, _useMergedState.default)(false, { value: props.open !== undefined ? props.open : props.visible, defaultValue: props.defaultOpen !== undefined ? props.defaultOpen : props.defaultVisible }); // const isDestroyed = useDestroyed(); const settingOpen = (value, e) => { setOpen(value, true); props.onVisibleChange?.(value, e); props.onOpenChange?.(value, e); }; const close = e => { settingOpen(false, e); }; const onConfirm = e => props.onConfirm?.call(void 0, e); const onCancel = e => { settingOpen(false, e); props.onCancel?.call(void 0, e); }; const onKeyDown = e => { if (e.keyCode === _KeyCode.default.ESC && open) { settingOpen(false, e); } }; const onOpenChange = value => { const { disabled = false } = props; if (disabled) { return; } settingOpen(value); }; const { prefixCls: customizePrefixCls, placement = 'top', trigger = 'click', okType = 'primary', icon = /*#__PURE__*/React.createElement(_ExclamationCircleFilled.default, null), children, overlayClassName, ...restProps } = props; const prefixCls = getPrefixCls('popover', customizePrefixCls); const prefixClsConfirm = getPrefixCls('popconfirm', customizePrefixCls); const overlayClassNames = (0, _classnames.default)(prefixClsConfirm, overlayClassName); return /*#__PURE__*/React.createElement(_popover.default, (0, _extends2.default)({}, restProps, { trigger: trigger, prefixCls: prefixCls, placement: placement, onOpenChange: onOpenChange, open: open, ref: ref, overlayClassName: overlayClassNames, _overlay: /*#__PURE__*/React.createElement(_PurePanel.Overlay, (0, _extends2.default)({ okType: okType, icon: icon }, props, { prefixCls: prefixCls, close: close, onConfirm: onConfirm, onCancel: onCancel })) }), (0, _reactNode.cloneElement)(children, { onKeyDown: e => { if ( /*#__PURE__*/React.isValidElement(children)) { children?.props.onKeyDown?.(e); } onKeyDown(e); } })); }); var _default = Popconfirm; exports.default = _default;