2022-11-09 12:28:04 +08:00
|
|
|
import React, { useState } from 'react';
|
2024-03-05 17:23:47 +08:00
|
|
|
import { Flex, Radio, Space, Table, Tag } from 'antd';
|
2024-01-11 15:55:58 +08:00
|
|
|
import type { TableProps } from 'antd';
|
|
|
|
|
|
|
|
type ColumnsType<T extends object> = TableProps<T>['columns'];
|
|
|
|
type TablePagination<T extends object> = NonNullable<Exclude<TableProps<T>['pagination'], boolean>>;
|
|
|
|
type TablePaginationPosition = NonNullable<TablePagination<any>['position']>[number];
|
2022-11-09 12:28:04 +08:00
|
|
|
|
|
|
|
interface DataType {
|
|
|
|
key: string;
|
|
|
|
name: string;
|
|
|
|
age: number;
|
|
|
|
address: string;
|
|
|
|
tags: string[];
|
|
|
|
}
|
|
|
|
|
|
|
|
const topOptions = [
|
|
|
|
{ label: 'topLeft', value: 'topLeft' },
|
|
|
|
{ label: 'topCenter', value: 'topCenter' },
|
|
|
|
{ label: 'topRight', value: 'topRight' },
|
|
|
|
{ label: 'none', value: 'none' },
|
|
|
|
];
|
|
|
|
|
|
|
|
const bottomOptions = [
|
|
|
|
{ label: 'bottomLeft', value: 'bottomLeft' },
|
|
|
|
{ label: 'bottomCenter', value: 'bottomCenter' },
|
|
|
|
{ label: 'bottomRight', value: 'bottomRight' },
|
|
|
|
{ label: 'none', value: 'none' },
|
|
|
|
];
|
|
|
|
|
|
|
|
const columns: ColumnsType<DataType> = [
|
|
|
|
{
|
|
|
|
title: 'Name',
|
|
|
|
dataIndex: 'name',
|
|
|
|
key: 'name',
|
2022-11-19 13:47:33 +08:00
|
|
|
render: (text) => <a>{text}</a>,
|
2022-11-09 12:28:04 +08:00
|
|
|
},
|
|
|
|
{
|
|
|
|
title: 'Age',
|
|
|
|
dataIndex: 'age',
|
|
|
|
key: 'age',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: 'Address',
|
|
|
|
dataIndex: 'address',
|
|
|
|
key: 'address',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: 'Tags',
|
|
|
|
key: 'tags',
|
|
|
|
dataIndex: 'tags',
|
|
|
|
render: (tags: string[]) => (
|
2024-03-05 17:23:47 +08:00
|
|
|
<Flex gap="small">
|
|
|
|
{tags.map<React.ReactNode>((tag) => {
|
2022-11-09 12:28:04 +08:00
|
|
|
let color = tag.length > 5 ? 'geekblue' : 'green';
|
|
|
|
if (tag === 'loser') {
|
|
|
|
color = 'volcano';
|
|
|
|
}
|
|
|
|
return (
|
|
|
|
<Tag color={color} key={tag}>
|
|
|
|
{tag.toUpperCase()}
|
|
|
|
</Tag>
|
|
|
|
);
|
|
|
|
})}
|
2024-03-05 17:23:47 +08:00
|
|
|
</Flex>
|
2022-11-09 12:28:04 +08:00
|
|
|
),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: 'Action',
|
|
|
|
key: 'action',
|
|
|
|
render: (_, record) => (
|
|
|
|
<Space size="middle">
|
|
|
|
<a>Invite {record.name}</a>
|
|
|
|
<a>Delete</a>
|
|
|
|
</Space>
|
|
|
|
),
|
|
|
|
},
|
|
|
|
];
|
|
|
|
|
|
|
|
const data: DataType[] = [
|
|
|
|
{
|
|
|
|
key: '1',
|
|
|
|
name: 'John Brown',
|
|
|
|
age: 32,
|
|
|
|
address: 'New York No. 1 Lake Park',
|
|
|
|
tags: ['nice', 'developer'],
|
|
|
|
},
|
|
|
|
{
|
|
|
|
key: '2',
|
|
|
|
name: 'Jim Green',
|
|
|
|
age: 42,
|
|
|
|
address: 'London No. 1 Lake Park',
|
|
|
|
tags: ['loser'],
|
|
|
|
},
|
|
|
|
{
|
|
|
|
key: '3',
|
|
|
|
name: 'Joe Black',
|
|
|
|
age: 32,
|
2023-01-29 12:46:00 +08:00
|
|
|
address: 'Sydney No. 1 Lake Park',
|
2022-11-09 12:28:04 +08:00
|
|
|
tags: ['cool', 'teacher'],
|
|
|
|
},
|
|
|
|
];
|
|
|
|
|
|
|
|
const App: React.FC = () => {
|
|
|
|
const [top, setTop] = useState<TablePaginationPosition>('topLeft');
|
|
|
|
const [bottom, setBottom] = useState<TablePaginationPosition>('bottomRight');
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div>
|
|
|
|
<div>
|
|
|
|
<Radio.Group
|
|
|
|
style={{ marginBottom: 10 }}
|
|
|
|
options={topOptions}
|
|
|
|
value={top}
|
2022-11-19 13:47:33 +08:00
|
|
|
onChange={(e) => {
|
2022-11-09 12:28:04 +08:00
|
|
|
setTop(e.target.value);
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
<Radio.Group
|
|
|
|
style={{ marginBottom: 10 }}
|
|
|
|
options={bottomOptions}
|
|
|
|
value={bottom}
|
2022-11-19 13:47:33 +08:00
|
|
|
onChange={(e) => {
|
2022-11-09 12:28:04 +08:00
|
|
|
setBottom(e.target.value);
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
<Table columns={columns} pagination={{ position: [top, bottom] }} dataSource={data} />
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default App;
|