import * as React from 'react'; import * as PropTypes from 'prop-types'; import { ButtonType, ButtonProps } from '../button/button'; import { ConfigConsumerProps } from '../config-provider'; export declare const destroyFns: Array<() => void>; export interface ModalProps { /** 对话框是否可见 */ visible?: boolean; /** 确定按钮 loading */ confirmLoading?: boolean; /** 标题 */ title?: React.ReactNode | string; /** 是否显示右上角的关闭按钮 */ closable?: boolean; /** 点击确定回调 */ onOk?: (e: React.MouseEvent) => void; /** 点击模态框右上角叉、取消按钮、Props.maskClosable 值为 true 时的遮罩层或键盘按下 Esc 时的回调 */ onCancel?: (e: React.MouseEvent) => void; afterClose?: () => void; /** 垂直居中 */ centered?: boolean; /** 宽度 */ width?: string | number; /** 底部内容 */ footer?: React.ReactNode; /** 确认按钮文字 */ okText?: React.ReactNode; /** 确认按钮类型 */ okType?: ButtonType; /** 取消按钮文字 */ cancelText?: React.ReactNode; /** 点击蒙层是否允许关闭 */ maskClosable?: boolean; /** 强制渲染 Modal */ forceRender?: boolean; okButtonProps?: ButtonProps; cancelButtonProps?: ButtonProps; destroyOnClose?: boolean; style?: React.CSSProperties; wrapClassName?: string; maskTransitionName?: string; transitionName?: string; className?: string; getContainer?: string | HTMLElement | getContainerFunc | false | null; zIndex?: number; bodyStyle?: React.CSSProperties; maskStyle?: React.CSSProperties; mask?: boolean; keyboard?: boolean; wrapProps?: any; prefixCls?: string; closeIcon?: React.ReactNode; } declare type getContainerFunc = () => HTMLElement; export interface ModalFuncProps { prefixCls?: string; className?: string; visible?: boolean; title?: React.ReactNode; content?: React.ReactNode; onOk?: (...args: any[]) => any; onCancel?: (...args: any[]) => any; okButtonProps?: ButtonProps; cancelButtonProps?: ButtonProps; centered?: boolean; width?: string | number; okText?: React.ReactNode; okType?: ButtonType; cancelText?: React.ReactNode; icon?: React.ReactNode; iconType?: string; mask?: boolean; maskClosable?: boolean; zIndex?: number; okCancel?: boolean; style?: React.CSSProperties; maskStyle?: React.CSSProperties; type?: string; keyboard?: boolean; getContainer?: string | HTMLElement | getContainerFunc | false | null; autoFocusButton?: null | 'ok' | 'cancel'; transitionName?: string; maskTransitionName?: string; } export declare type ModalFunc = (props: ModalFuncProps) => { destroy: () => void; update: (newConfig: ModalFuncProps) => void; }; export interface ModalLocale { okText: string; cancelText: string; justOkText: string; } export default class Modal extends React.Component { static info: ModalFunc; static success: ModalFunc; static error: ModalFunc; static warn: ModalFunc; static warning: ModalFunc; static confirm: ModalFunc; static destroyAll: () => void; static defaultProps: { width: number; transitionName: string; maskTransitionName: string; confirmLoading: boolean; visible: boolean; okType: "link" | "default" | "dashed" | "primary" | "ghost" | "danger"; }; static propTypes: { prefixCls: PropTypes.Requireable; onOk: PropTypes.Requireable<(...args: any[]) => any>; onCancel: PropTypes.Requireable<(...args: any[]) => any>; okText: PropTypes.Requireable; cancelText: PropTypes.Requireable; centered: PropTypes.Requireable; width: PropTypes.Requireable; confirmLoading: PropTypes.Requireable; visible: PropTypes.Requireable; footer: PropTypes.Requireable; title: PropTypes.Requireable; closable: PropTypes.Requireable; closeIcon: PropTypes.Requireable; }; handleCancel: (e: React.MouseEvent) => void; handleOk: (e: React.MouseEvent) => void; renderFooter: (locale: ModalLocale) => JSX.Element; renderModal: ({ getPopupContainer: getContextPopupContainer, getPrefixCls, }: ConfigConsumerProps) => JSX.Element; render(): JSX.Element; } export {};