import classNames from 'classnames'; import * as React from 'react'; import { ConfigContext } from '../config-provider'; import LocaleReceiver from '../locale/LocaleReceiver'; import DefaultEmptyImg from './empty'; import SimpleEmptyImg from './simple'; import useStyle from './style'; const defaultEmptyImg = ; const simpleEmptyImg = ; export interface TransferLocale { description: string; } export interface EmptyProps { prefixCls?: string; className?: string; rootClassName?: string; style?: React.CSSProperties; /** @since 3.16.0 */ imageStyle?: React.CSSProperties; image?: React.ReactNode; description?: React.ReactNode; children?: React.ReactNode; } type CompoundedComponent = React.FC & { PRESENTED_IMAGE_DEFAULT: React.ReactNode; PRESENTED_IMAGE_SIMPLE: React.ReactNode; }; const Empty: CompoundedComponent = ({ className, rootClassName, prefixCls: customizePrefixCls, image = defaultEmptyImg, description, children, imageStyle, ...restProps }) => { const { getPrefixCls, direction } = React.useContext(ConfigContext); const prefixCls = getPrefixCls('empty', customizePrefixCls); const [wrapSSR, hashId] = useStyle(prefixCls); return wrapSSR( {(locale: TransferLocale) => { const des = typeof description !== 'undefined' ? description : locale.description; const alt = typeof des === 'string' ? des : 'empty'; let imageNode: React.ReactNode = null; if (typeof image === 'string') { imageNode = {alt}; } else { imageNode = image; } return (
{imageNode}
{des &&
{des}
} {children &&
{children}
}
); }}
, ); }; Empty.PRESENTED_IMAGE_DEFAULT = defaultEmptyImg; Empty.PRESENTED_IMAGE_SIMPLE = simpleEmptyImg; if (process.env.NODE_ENV !== 'production') { Empty.displayName = 'Empty'; } export default Empty;