2018-01-30 09:54:45 -05:00
|
|
|
var classNames = require('classnames');
|
|
|
|
var Formsy = require('formsy-react');
|
|
|
|
var omit = require('lodash.omit');
|
|
|
|
var React = require('react');
|
|
|
|
var validations = require('./validations.jsx').validations;
|
2016-05-12 17:42:04 -04:00
|
|
|
|
2018-01-30 09:54:45 -05:00
|
|
|
for (var validation in validations) {
|
2016-05-12 17:42:04 -04:00
|
|
|
Formsy.addValidationRule(validation, validations[validation]);
|
|
|
|
}
|
|
|
|
|
2018-01-30 09:54:45 -05:00
|
|
|
var Form = React.createClass({
|
|
|
|
getDefaultProps: function () {
|
|
|
|
return {
|
|
|
|
noValidate: true,
|
|
|
|
onChange: function () {}
|
|
|
|
};
|
|
|
|
},
|
|
|
|
getInitialState: function () {
|
|
|
|
return {
|
2016-07-01 11:43:18 -04:00
|
|
|
allValues: {}
|
|
|
|
};
|
2018-01-30 09:54:45 -05:00
|
|
|
},
|
|
|
|
onChange: function (currentValues, isChanged) {
|
2016-07-01 11:43:18 -04:00
|
|
|
this.setState({allValues: omit(currentValues, 'all')});
|
|
|
|
this.props.onChange(currentValues, isChanged);
|
2018-01-30 09:54:45 -05:00
|
|
|
},
|
|
|
|
render: function () {
|
|
|
|
var classes = classNames(
|
|
|
|
'form',
|
|
|
|
this.props.className
|
|
|
|
);
|
2016-05-12 17:42:04 -04:00
|
|
|
return (
|
2018-01-30 09:54:45 -05:00
|
|
|
<Formsy.Form {... this.props} className={classes} ref="formsy" onChange={this.onChange}>
|
|
|
|
{React.Children.map(this.props.children, function (child) {
|
2016-07-05 15:48:21 -04:00
|
|
|
if (!child) return child;
|
2016-07-05 12:05:54 -04:00
|
|
|
if (child.props.name === 'all') {
|
|
|
|
return React.cloneElement(child, {value: this.state.allValues});
|
2018-01-30 09:54:45 -05:00
|
|
|
} else {
|
|
|
|
return child;
|
2016-07-05 12:05:54 -04:00
|
|
|
}
|
2018-01-30 09:54:45 -05:00
|
|
|
}.bind(this))}
|
2016-06-23 15:10:51 -04:00
|
|
|
</Formsy.Form>
|
2016-05-12 17:42:04 -04:00
|
|
|
);
|
|
|
|
}
|
2018-01-30 09:54:45 -05:00
|
|
|
});
|
2016-05-12 17:42:04 -04:00
|
|
|
|
|
|
|
module.exports = Form;
|