import CloseOutlined from '@ant-design/icons/CloseOutlined'; import classNames from 'classnames'; import { Panel } from 'rc-dialog'; import type { PanelProps } from 'rc-dialog/lib/Dialog/Content/Panel'; import * as React from 'react'; import Button from '../button'; import { convertLegacyProps } from '../button/button'; import { ConfigContext } from '../config-provider'; import LocaleReceiver from '../locale-provider/LocaleReceiver'; import { ConfirmContent } from './ConfirmDialog'; import { getConfirmLocale } from './locale'; import type { ModalProps, ModalFuncProps } from './Modal'; import useStyle from './style'; export interface PurePanelProps extends Omit, Pick { prefixCls?: string; style?: React.CSSProperties; } export function renderCloseIcon(prefixCls: string, closeIcon?: React.ReactNode) { return ( {closeIcon || } ); } export function renderFooter( props: Pick< ModalProps, | 'footer' | 'okText' | 'okType' | 'cancelText' | 'confirmLoading' | 'okButtonProps' | 'cancelButtonProps' > & { onOk?: React.MouseEventHandler; onCancel?: React.MouseEventHandler; }, ) { const { okText, okType = 'primary', cancelText, confirmLoading, onOk, onCancel, okButtonProps, cancelButtonProps, footer, } = props; return ( footer ?? ( {locale => ( <> )} ) ); } export default function PurePanel(props: PurePanelProps) { const { prefixCls: customizePrefixCls, className, closeIcon, closable, type, title, children, ...restProps } = props; const { getPrefixCls } = React.useContext(ConfigContext); const rootPrefixCls = getPrefixCls(); const prefixCls = customizePrefixCls || getPrefixCls('modal'); const [, hashId] = useStyle(prefixCls); const confirmPrefixCls = `${prefixCls}-confirm`; // Choose target props by confirm mark let additionalProps: Partial = {}; if (type) { additionalProps = { closable: closable ?? false, title: '', footer: '', children: ( ), }; } else { additionalProps = { closable: closable ?? true, title, footer: renderFooter(props), children, }; } return ( ); }