import * as React from 'react'; import { PropTypes } from 'react'; import RcSelect, { Option, OptGroup } from 'rc-select'; import classNames from 'classnames'; type SelectValue = string | string[] | Array<{ key: string, label: React.ReactNode }>; export interface SelectProps { prefixCls?: string; className?: string; value?: SelectValue; defaultValue?: SelectValue; size?: 'default' | 'large' | 'small'; combobox?: boolean; notFoundContent?: React.ReactNode; showSearch?: boolean; transitionName?: string; choiceTransitionName?: string; multiple?: boolean; allowClear?: boolean; filterOption?: boolean | ((inputValue: string, option: Object) => any); tags?: boolean; onSelect?: (value: SelectValue, option: Object) => any; onDeselect?: (value: SelectValue) => any; onSearch?: (value: string) => any; placeholder?: string; dropdownMatchSelectWidth?: boolean; optionFilterProp?: string; optionLabelProp?: string; disabled?: boolean; defaultActiveFirstOption?: boolean; labelInValue?: boolean; getPopupContainer?: (triggerNode: React.ReactNode) => React.ReactNode; } export interface SelectContext { antLocale?: { Select?: any, }; } export default class Select extends React.Component { static Option = Option; static OptGroup = OptGroup; static defaultProps = { prefixCls: 'ant-select', showSearch: false, transitionName: 'slide-up', choiceTransitionName: 'zoom', }; static propTypes = { prefixCls: PropTypes.string, className: PropTypes.string, size: PropTypes.oneOf(['default', 'large', 'small']), combobox: PropTypes.bool, notFoundContent: PropTypes.any, showSearch: PropTypes.bool, optionLabelProp: PropTypes.string, transitionName: PropTypes.string, choiceTransitionName: PropTypes.string, }; context: SelectContext; render() { let { prefixCls, className, size, combobox, notFoundContent, showSearch, optionLabelProp, } = this.props; const cls = classNames({ [`${prefixCls}-lg`]: size === 'large', [`${prefixCls}-sm`]: size === 'small', [className]: !!className, [`${prefixCls}-show-search`]: showSearch, }); const { antLocale } = this.context; if (antLocale && antLocale.Select) { notFoundContent = notFoundContent || antLocale.Select.notFoundContent; } if (combobox) { notFoundContent = null; // children 带 dom 结构时,无法填入输入框 optionLabelProp = optionLabelProp || 'value'; } return ( ); } }