formsy-react/examples/login/app.js

30 lines
941 B
JavaScript

import React from 'react';
import ReactDOM from 'react-dom';
import { Form } from 'formsy-react';
import MyInput from './../components/Input';
class App extends React.Component {
state = { canSubmit: false };
submit(data) {
alert(JSON.stringify(data, null, 4));
}
enableButton = () => {
this.setState({ canSubmit: true });
}
disableButton = () => {
this.setState({ canSubmit: false });
}
render() {
return (
<Form onSubmit={this.submit} onValid={this.enableButton} onInvalid={this.disableButton} className="login">
<MyInput value="" name="email" title="Email" validations="isEmail" validationError="This is not a valid email" required />
<MyInput value="" name="password" title="Password" type="password" required />
<button type="submit" disabled={!this.state.canSubmit}>Submit</button>
</Form>
);
}
}
ReactDOM.render(<App/>, document.getElementById('example'));