mirror of
https://github.com/ant-design/ant-design.git
synced 2024-12-21 13:18:04 +08:00
78 lines
1.8 KiB
TypeScript
78 lines
1.8 KiB
TypeScript
import React, { useState } from 'react';
|
|
import type { GetProp } from 'antd';
|
|
import { Button, ConfigProvider, Empty, Table } from 'antd';
|
|
|
|
interface DataType {
|
|
key: number;
|
|
name: string;
|
|
age: number;
|
|
address: string;
|
|
}
|
|
|
|
const genFakeData = (count = 5) =>
|
|
Array.from({ length: count }).map<DataType>((_, index) => ({
|
|
key: index,
|
|
name: `Edward King ${index}`,
|
|
age: 32 + index,
|
|
address: `London, Park Lane no. ${index}`,
|
|
}));
|
|
|
|
const renderEmpty: GetProp<typeof ConfigProvider, 'renderEmpty'> = (componentName) => {
|
|
if (componentName === 'Table.filter' /** 👈 5.20.0+ */) {
|
|
return <Empty image={Empty.PRESENTED_IMAGE_SIMPLE} description="No Filter(Custom)" />;
|
|
}
|
|
};
|
|
|
|
function App() {
|
|
const [dataSource, setDataSource] = useState<DataType[]>(genFakeData);
|
|
|
|
const handleToggle = () => {
|
|
setDataSource(dataSource.length ? [] : genFakeData(Math.floor(Math.random() * 10)));
|
|
};
|
|
|
|
const columns: GetProp<typeof Table<DataType>, 'columns'> = [
|
|
{
|
|
title: 'Name',
|
|
dataIndex: 'name',
|
|
key: 'name',
|
|
},
|
|
{
|
|
title: 'Age',
|
|
dataIndex: 'age',
|
|
key: 'age',
|
|
filters: dataSource.length
|
|
? [
|
|
{ text: '>=35', value: 'gte35' },
|
|
{ text: '<18', value: 'lt18' },
|
|
]
|
|
: [],
|
|
},
|
|
{
|
|
title: 'Address',
|
|
dataIndex: 'address',
|
|
key: 'address',
|
|
},
|
|
];
|
|
|
|
const toggleButton = (
|
|
<Button type="primary" onClick={handleToggle}>
|
|
Toggle Data
|
|
</Button>
|
|
);
|
|
|
|
return (
|
|
<ConfigProvider renderEmpty={renderEmpty}>
|
|
{dataSource.length ? toggleButton : null}
|
|
<div style={{ marginBlock: 8 }} />
|
|
<Table<DataType>
|
|
bordered
|
|
dataSource={dataSource}
|
|
columns={columns}
|
|
locale={{ emptyText: <Empty description="No Data">{toggleButton}</Empty> }}
|
|
/>
|
|
</ConfigProvider>
|
|
);
|
|
}
|
|
|
|
export default App;
|