var classNames = require('classnames'); var Formsy = require('formsy-react'); var omit = require('lodash.omit'); var React = require('react'); var validations = require('./validations.jsx').validations; for (var validation in validations) { Formsy.addValidationRule(validation, validations[validation]); } var Form = React.createClass({ getDefaultProps: function () { return { noValidate: true, onChange: function () {} }; }, getInitialState: function () { return { allValues: {} }; }, onChange: function (currentValues, isChanged) { this.setState({allValues: omit(currentValues, 'all')}); this.props.onChange(currentValues, isChanged); }, render: function () { var classes = classNames( 'form', this.props.className ); return ( {React.Children.map(this.props.children, function (child) { if (!child) return child; if (child.props.name === 'all') { return React.cloneElement(child, {value: this.state.allValues}); } else { return child; } }.bind(this))} ); } }); module.exports = Form;