1 import React, {PropTypes} from 'react';
2 import ReactDOM from 'react-dom';
3 import Trigger from 'rc-trigger';
4 import {createChainedFunction} from 'rc-util';
5 import Panel from './module/Panel';
6 import placements from './util/placements';
7 import CommonMixin from './mixin/CommonMixin';
12 function refFn(field, component) {
13 this[field] = component;
16 const Picker = React.createClass({
18 prefixCls: PropTypes.string,
19 inputClassName: PropTypes.string,
20 locale: PropTypes.object,
21 value: PropTypes.object,
22 children: PropTypes.func,
23 disabled: PropTypes.bool,
24 defaultValue: PropTypes.object,
26 align: PropTypes.object,
27 placement: PropTypes.any,
28 transitionName: PropTypes.string,
29 placeholder: PropTypes.string,
30 formatter: PropTypes.object,
31 hourOptions: PropTypes.array,
32 minuteOptions: PropTypes.array,
33 secondOptions: PropTypes.array,
34 onChange: PropTypes.func,
35 onOpen: PropTypes.func,
36 onClose: PropTypes.func,
39 mixins: [CommonMixin],
45 placement: 'bottomLeft',
53 this.savePanelRef = refFn.bind(this, 'panelInstance');
54 const { open, defaultValue, value } = this.props;
57 value: value || defaultValue,
61 componentWillReceiveProps(nextProps) {
62 const { value, open } = nextProps;
63 if (value !== undefined) {
68 if (open !== undefined) {
69 this.setState({open});
73 onPanelChange(value) {
82 onVisibleChange(open) {
83 this.setOpen(open, () => {
85 ReactDOM.findDOMNode(this.refs.picker).blur();
86 ReactDOM.findDOMNode(this.panelInstance).focus();
92 if (!('value' in this.props)) {
97 this.props.onChange(value);
101 const { prefixCls, defaultValue, locale, formatter, placeholder, hourOptions, minuteOptions, secondOptions } = this.props;
104 prefixCls={prefixCls}
105 defaultValue={defaultValue}
107 formatter={formatter}
108 placeholder={placeholder}
109 hourOptions={hourOptions}
110 minuteOptions={minuteOptions}
111 secondOptions={secondOptions}
117 const panel = this.getPanel();
119 ref: this.savePanelRef,
120 value: this.state.value,
121 onChange: createChainedFunction(panel.props.onChange, this.onPanelChange),
122 onClear: createChainedFunction(panel.props.onClear, this.onPanelClear),
125 return React.cloneElement(panel, extraProps);
128 setOpen(open, callback) {
129 const {onOpen, onClose} = this.props;
130 if (this.state.open !== open) {
146 const { prefixCls, placeholder, placement, align, disabled, transitionName, formatter, inputClassName } = this.props;
147 const { open, value } = this.state;
151 prefixCls={`${prefixCls}-panel`}
152 popup={this.getPanelElement()}
154 builtinPlacements={placements}
155 popupPlacement={placement}
156 action={disabled ? [] : ['click']}
158 popupTransitionName={transitionName}
160 onPopupVisibleChange={this.onVisibleChange}
162 <span className={`${prefixCls}`}>
163 <input className={inputClassName} ref="picker" type="text" placeholder={placeholder} readOnly
164 disabled={disabled} value={value && formatter.format(value)}/>
165 <span className={`${prefixCls}-icon`}/>
172 export default Picker;