scratch-www/src/components/forms/form.jsx

62 lines
1.7 KiB
React
Raw Normal View History

2018-01-19 14:06:26 -05:00
const bindAll = require('lodash.bindall');
const classNames = require('classnames');
const Formsy = require('formsy-react');
const omit = require('lodash.omit');
const PropTypes = require('prop-types');
const React = require('react');
2018-01-19 14:06:26 -05:00
const validations = require('./validations.jsx').validations;
for (const validation in validations) {
Formsy.addValidationRule(validation, validations[validation]);
}
2018-01-19 14:06:26 -05:00
class Form extends React.Component {
constructor (props) {
super(props);
bindAll(this, [
'handleChange'
]);
this.state = {
allValues: {}
};
2018-01-19 14:06:26 -05:00
}
handleChange (currentValues, isChanged) {
this.setState({allValues: omit(currentValues, 'all')});
this.props.onChange(currentValues, isChanged);
2018-01-19 14:06:26 -05:00
}
render () {
return (
2018-01-19 14:06:26 -05:00
<Formsy.Form
className={classNames('form', this.props.className)}
ref={form => {
this.formsy = form;
}}
onChange={this.handleChange}
{...this.props}
>
{React.Children.map(this.props.children, child => {
if (!child) return child;
if (child.props.name === 'all') {
return React.cloneElement(child, {value: this.state.allValues});
}
2018-01-19 14:06:26 -05:00
return child;
})}
2016-06-23 15:10:51 -04:00
</Formsy.Form>
);
}
2018-01-19 14:06:26 -05:00
}
Form.propTypes = {
children: PropTypes.node,
className: PropTypes.string,
onChange: PropTypes.func
};
Form.defaultProps = {
noValidate: true,
onChange: function () {}
};
module.exports = Form;