mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-10 14:10:15 +08:00
70 lines
1.4 KiB
TypeScript
70 lines
1.4 KiB
TypeScript
|
import React, { useState } from 'react';
|
||
|
import { ConfigProvider, TreeSelect } from 'antd';
|
||
|
|
||
|
const treeData = [
|
||
|
{
|
||
|
value: 'parent 1',
|
||
|
title: 'parent 1',
|
||
|
children: [
|
||
|
{
|
||
|
value: 'parent 1-0',
|
||
|
title: 'parent 1-0',
|
||
|
children: [
|
||
|
{
|
||
|
value: 'leaf1',
|
||
|
title: 'leaf1',
|
||
|
},
|
||
|
{
|
||
|
value: 'leaf2',
|
||
|
title: 'leaf2',
|
||
|
},
|
||
|
],
|
||
|
},
|
||
|
{
|
||
|
value: 'parent 1-1',
|
||
|
title: 'parent 1-1',
|
||
|
children: [
|
||
|
{
|
||
|
value: 'leaf3',
|
||
|
title: <b style={{ color: '#08c' }}>leaf3</b>,
|
||
|
},
|
||
|
],
|
||
|
},
|
||
|
],
|
||
|
},
|
||
|
];
|
||
|
const App: React.FC = () => {
|
||
|
const [value, setValue] = useState<string>();
|
||
|
|
||
|
const onChange = (newValue: string) => {
|
||
|
setValue(newValue);
|
||
|
};
|
||
|
|
||
|
return (
|
||
|
<ConfigProvider
|
||
|
theme={{
|
||
|
components: {
|
||
|
TreeSelect: {
|
||
|
nodeHoverBg: '#fff2f0',
|
||
|
nodeSelectedBg: '#ffa39e',
|
||
|
},
|
||
|
},
|
||
|
}}
|
||
|
>
|
||
|
<TreeSelect
|
||
|
showSearch
|
||
|
style={{ width: '100%' }}
|
||
|
value={value}
|
||
|
dropdownStyle={{ maxHeight: 400, overflow: 'auto' }}
|
||
|
placeholder="Please select"
|
||
|
allowClear
|
||
|
treeDefaultExpandAll
|
||
|
onChange={onChange}
|
||
|
treeData={treeData}
|
||
|
/>
|
||
|
</ConfigProvider>
|
||
|
);
|
||
|
};
|
||
|
|
||
|
export default App;
|