import React, { PropTypes } from 'react'; import ReactDom from 'react-dom'; import classnames from 'classnames'; const scrollTo = (element, to, duration) => { const requestAnimationFrame = window.requestAnimationFrame || function requestAnimationFrameTimeout() { return setTimeout(arguments[0], 10); }; // jump to target if duration zero if (duration <= 0) { element.scrollTop = to; return; } const difference = to - element.scrollTop; const perTick = difference / duration * 10; requestAnimationFrame(() => { element.scrollTop = element.scrollTop + perTick; if (element.scrollTop === to) return; scrollTo(element, to, duration - 10); }); }; const Select = React.createClass({ propTypes: { prefixCls: PropTypes.string, options: PropTypes.array, selectedIndex: PropTypes.number, type: PropTypes.string, onSelect: PropTypes.func, onMouseEnter: PropTypes.func, }, getInitialState() { return { active: false, }; }, componentDidMount() { // jump to selected option this.scrollToSelected(0); }, componentDidUpdate(prevProps) { // smooth scroll to selected option if (prevProps.selectedIndex !== this.props.selectedIndex) { this.scrollToSelected(120); } }, onSelect(value) { const { onSelect, type } = this.props; onSelect(type, value); }, getOptions() { const { options, selectedIndex, prefixCls } = this.props; return options.map((item, index) => { const cls = classnames({ [`${prefixCls}-select-option-selected`]: selectedIndex === index, [`${prefixCls}-select-option-disabled`]: item.disabled, }); let onclick = null; if (!item.disabled) { onclick = this.onSelect.bind(this, item.value); } return (