mirror of
https://github.com/ant-design/ant-design.git
synced 2024-12-29 11:58:31 +08:00
dd9070998a
* chore: fix typo ref: https://github.com/ant-design/ant-design/issues/49690 * chore: add demo * chore: update snapshots * chore: update
52 lines
1.4 KiB
TypeScript
52 lines
1.4 KiB
TypeScript
import React, { useContext } from 'react';
|
|
|
|
import type { ConfigConsumerProps } from '.';
|
|
import { ConfigContext } from '.';
|
|
import Empty from '../empty';
|
|
|
|
type ComponentName =
|
|
| 'Table'
|
|
| 'Table.filter' /* 👈 5.20.0+ */
|
|
| 'List'
|
|
| 'Select'
|
|
| 'TreeSelect'
|
|
| 'Cascader'
|
|
| 'Transfer'
|
|
| 'Mentions';
|
|
|
|
interface EmptyProps {
|
|
componentName?: ComponentName;
|
|
}
|
|
|
|
const DefaultRenderEmpty: React.FC<EmptyProps> = (props) => {
|
|
const { componentName } = props;
|
|
const { getPrefixCls } = useContext<ConfigConsumerProps>(ConfigContext);
|
|
const prefix = getPrefixCls('empty');
|
|
switch (componentName) {
|
|
case 'Table':
|
|
case 'List':
|
|
return <Empty image={Empty.PRESENTED_IMAGE_SIMPLE} />;
|
|
case 'Select':
|
|
case 'TreeSelect':
|
|
case 'Cascader':
|
|
case 'Transfer':
|
|
case 'Mentions':
|
|
return <Empty image={Empty.PRESENTED_IMAGE_SIMPLE} className={`${prefix}-small`} />;
|
|
/**
|
|
* This type of component should satisfy the nullish coalescing operator(??) on the left-hand side.
|
|
* to let the component itself implement the logic.
|
|
* For example `Table.filter`.
|
|
*/
|
|
case 'Table.filter':
|
|
// why `null`? legacy react16 node type `undefined` is not allowed.
|
|
return null;
|
|
default:
|
|
// Should never hit if we take all the component into consider.
|
|
return <Empty />;
|
|
}
|
|
};
|
|
|
|
export type RenderEmptyHandler = (componentName?: ComponentName) => React.ReactNode;
|
|
|
|
export default DefaultRenderEmpty;
|