import * as React from 'react'; import Select, { Option, OptGroup } from '../select'; import classNames from 'classnames'; export interface AutoCompleteProps { size?: string; className?: string; notFoundContent?: Element; dataSource: Array; prefixCls?: string; transitionName?: string; optionLabelProp?: string; choiceTransitionName?: string; showSearch?: boolean; } export default class AutoComplete extends React.Component { static Option = Option; static OptGroup = OptGroup; static defaultProps = { prefixCls: 'ant-select', transitionName: 'slide-up', optionLabelProp: 'children', choiceTransitionName: 'zoom', showSearch: false, }; static contextTypes = { antLocale: React.PropTypes.object, }; render() { let { size, className, notFoundContent, prefixCls, optionLabelProp, dataSource, } = this.props; const cls = classNames({ [`${prefixCls}-lg`]: size === 'large', [`${prefixCls}-sm`]: size === 'small', [className]: !!className, [`${prefixCls}-show-search`]: true, }); const options = dataSource ? dataSource.map((item, index) => { switch (typeof item) { case 'string': return ; case 'object': if (React.isValidElement(item)) { return React.cloneElement(item, { key: item.key || index, }); } return ; default: return []; } }) : []; return ( ); } }