mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-07 20:08:21 +08:00
76 lines
1.8 KiB
TypeScript
76 lines
1.8 KiB
TypeScript
import React from 'react';
|
|
import { DownOutlined, UserOutlined } from '@ant-design/icons';
|
|
import type { MenuProps } from 'antd';
|
|
import { Button, Dropdown, message, Space, Tooltip } from 'antd';
|
|
|
|
const handleButtonClick = (e: React.MouseEvent<HTMLButtonElement>) => {
|
|
message.info('Click on left button.');
|
|
console.log('click left button', e);
|
|
};
|
|
|
|
const handleMenuClick: MenuProps['onClick'] = (e) => {
|
|
message.info('Click on menu item.');
|
|
console.log('click', e);
|
|
};
|
|
|
|
const items: MenuProps['items'] = [
|
|
{
|
|
label: '1st menu item',
|
|
key: '1',
|
|
icon: <UserOutlined />,
|
|
},
|
|
{
|
|
label: '2nd menu item',
|
|
key: '2',
|
|
icon: <UserOutlined />,
|
|
},
|
|
{
|
|
label: '3rd menu item',
|
|
key: '3',
|
|
icon: <UserOutlined />,
|
|
},
|
|
];
|
|
|
|
const menuProps = {
|
|
items,
|
|
onClick: handleMenuClick,
|
|
};
|
|
|
|
const App: React.FC = () => (
|
|
<Space wrap>
|
|
<Dropdown.Button menu={menuProps} onClick={handleButtonClick}>
|
|
Dropdown
|
|
</Dropdown.Button>
|
|
<Dropdown.Button menu={menuProps} placement="bottom" icon={<UserOutlined />}>
|
|
Dropdown
|
|
</Dropdown.Button>
|
|
<Dropdown.Button menu={menuProps} onClick={handleButtonClick} disabled>
|
|
Dropdown
|
|
</Dropdown.Button>
|
|
<Dropdown.Button
|
|
menu={menuProps}
|
|
buttonsRender={([leftButton, rightButton]) => [
|
|
<Tooltip title="tooltip" key="leftButton">
|
|
{leftButton}
|
|
</Tooltip>,
|
|
React.cloneElement(rightButton as React.ReactElement<any, string>, { loading: true }),
|
|
]}
|
|
>
|
|
With Tooltip
|
|
</Dropdown.Button>
|
|
<Dropdown menu={menuProps}>
|
|
<Button>
|
|
<Space>
|
|
Button
|
|
<DownOutlined />
|
|
</Space>
|
|
</Button>
|
|
</Dropdown>
|
|
<Dropdown.Button menu={menuProps} onClick={handleButtonClick} danger>
|
|
Danger
|
|
</Dropdown.Button>
|
|
</Space>
|
|
);
|
|
|
|
export default App;
|