mirror of
https://github.com/ant-design/ant-design.git
synced 2024-12-24 15:46:10 +08:00
66 lines
1.7 KiB
TypeScript
66 lines
1.7 KiB
TypeScript
|
import React from 'react';
|
||
|
import { Flex, Tree } from 'antd';
|
||
|
import type { GetProps, TreeDataNode } from 'antd';
|
||
|
|
||
|
const { DirectoryTree } = Tree;
|
||
|
|
||
|
const treeData: TreeDataNode[] = [
|
||
|
{
|
||
|
title: 'parent 0',
|
||
|
key: '0-0',
|
||
|
children: [
|
||
|
{ title: 'leaf 0-0', key: '0-0-0', isLeaf: true },
|
||
|
{ title: 'leaf 0-1', key: '0-0-1', isLeaf: true },
|
||
|
],
|
||
|
},
|
||
|
{
|
||
|
title: 'parent 1',
|
||
|
key: '0-1',
|
||
|
children: [
|
||
|
{ title: 'leaf 1-0', key: '0-1-0', isLeaf: true },
|
||
|
{ title: 'leaf 1-1', key: '0-1-1', isLeaf: true },
|
||
|
],
|
||
|
},
|
||
|
];
|
||
|
|
||
|
const sharedProps: GetProps<typeof DirectoryTree> = {
|
||
|
treeData,
|
||
|
defaultExpandAll: true,
|
||
|
onSelect: (keys, info) => {
|
||
|
console.log('Trigger Select', keys, info);
|
||
|
},
|
||
|
onExpand: (keys, info) => {
|
||
|
console.log('Trigger Expand', keys, info);
|
||
|
},
|
||
|
};
|
||
|
|
||
|
const DemoOne = () => <DirectoryTree draggable defaultSelectedKeys={['0-0-0']} />;
|
||
|
|
||
|
const DemoTwo = () => <DirectoryTree {...sharedProps} checkable defaultSelectedKeys={['0-1-0']} />;
|
||
|
|
||
|
const DemoThree = () => (
|
||
|
<DirectoryTree {...sharedProps} draggable checkable defaultSelectedKeys={['0-1']} />
|
||
|
);
|
||
|
|
||
|
const BasicDemo = () => <DirectoryTree {...sharedProps} multiple treeData={treeData} />;
|
||
|
|
||
|
const NormalDemo = () => <Tree {...sharedProps} defaultSelectedKeys={['0-1']} />;
|
||
|
|
||
|
const NormalCheckDemo = () => <Tree {...sharedProps} checkable defaultSelectedKeys={['0-1']} />;
|
||
|
|
||
|
const NormalDragDemo = () => <Tree {...sharedProps} draggable defaultSelectedKeys={['0-1-0']} />;
|
||
|
|
||
|
const App = () => (
|
||
|
<Flex wrap gap="large">
|
||
|
<DemoOne />
|
||
|
<DemoTwo />
|
||
|
<DemoThree />
|
||
|
<BasicDemo />
|
||
|
<NormalDemo />
|
||
|
<NormalCheckDemo />
|
||
|
<NormalDragDemo />
|
||
|
</Flex>
|
||
|
);
|
||
|
|
||
|
export default App;
|