Vulcan/packages/vulcan-forms/lib/DateTime.jsx

58 lines
1.5 KiB
React
Raw Normal View History

2016-04-18 10:03:53 +09:00
import React, { PropTypes, Component } from 'react';
import DateTimePicker from 'react-datetime';
// import moment from 'moment';
2016-04-18 10:03:53 +09:00
class DateTime extends Component {
constructor(props) {
super(props);
this.updateDate = this.updateDate.bind(this);
}
// when the datetime picker has mounted, SmartForm will catch the date value (no formsy mixin in this component)
componentDidMount() {
this.updateDate(this.props.value || new Date());
}
updateDate(date) {
this.context.updateCurrentValues({[this.props.name]: date});
}
2016-04-18 10:03:53 +09:00
render() {
2017-02-21 19:08:14 +01:00
const date = typeof this.props.value === 'string' ? new Date(this.props.value) : this.props.value;
2016-04-18 10:03:53 +09:00
return (
<div className="form-group row">
<label className="control-label col-sm-3">{this.props.label}</label>
<div className="col-sm-9">
<DateTimePicker
2017-02-21 19:08:14 +01:00
value={date || new Date()}
// newDate argument is a Moment object given by react-datetime
onChange={newDate => this.updateDate(newDate._d)}
format={"x"}
inputProps={{name: this.props.name}}
/>
</div>
2016-04-18 10:03:53 +09:00
</div>
);
2016-04-18 10:03:53 +09:00
}
}
DateTime.propTypes = {
control: React.PropTypes.any,
datatype: React.PropTypes.any,
group: React.PropTypes.any,
2016-04-18 10:03:53 +09:00
label: React.PropTypes.string,
name: React.PropTypes.string,
value: React.PropTypes.any,
};
DateTime.contextTypes = {
addToAutofilledValues: React.PropTypes.func,
updateCurrentValues: React.PropTypes.func,
};
2016-04-18 10:03:53 +09:00
2016-09-27 07:30:58 +02:00
export default DateTime;