import React from 'react'; import Button from '../button'; import Icon from '../icon'; import Dropdown from './dropdown'; const ButtonGroup = Button.Group; import classNames from 'classnames'; export interface DropdownButtonProps { prefixCls?: string; className?: string; type?: 'primary' | 'ghost' | 'dashed'; onClick?: React.MouseEventHandler; trigger?: ('click' | 'hover')[]; align?: any; overlay: React.ReactNode; visible?: boolean; disabled?: boolean; onVisibleChange?: (visible: boolean) => void; style?: React.CSSProperties; children?: any; placement?: 'topLeft' | 'topCenter' | 'topRight' | 'bottomLeft' | 'bottomCenter' | 'bottomRight'; } export default class DropdownButton extends React.Component { static defaultProps = { placement: 'bottomRight', type: 'default', prefixCls: 'ant-dropdown-button', }; render() { const { type, overlay, trigger, align, children, className, onClick, prefixCls, disabled, visible, onVisibleChange, placement, ...restProps, } = this.props; const cls = classNames(prefixCls, className); const dropdownProps = { align, overlay, trigger: disabled ? [] : trigger, onVisibleChange, placement, }; if ('visible' in this.props) { (dropdownProps as any).visible = visible; } return ( ); } }