Disable auth form during requests

This commit is contained in:
Alex Gleason 2020-04-06 16:20:03 -05:00
parent 1d213b5d0b
commit 42e584ca72
No known key found for this signature in database
GPG key ID: 7211D1F99744FBB7

View file

@ -4,6 +4,7 @@ import ImmutablePureComponent from 'react-immutable-pure-component';
import { createAuthApp, logIn } from 'gabsocial/actions/auth'; import { createAuthApp, logIn } from 'gabsocial/actions/auth';
import { Redirect } from 'react-router-dom'; import { Redirect } from 'react-router-dom';
import { fetchMe } from 'gabsocial/actions/me'; import { fetchMe } from 'gabsocial/actions/me';
import { LoadingBar } from 'react-redux-loading-bar';
const mapStateToProps = (state, props) => ({ const mapStateToProps = (state, props) => ({
me: state.get('me'), me: state.get('me'),
@ -11,6 +12,11 @@ const mapStateToProps = (state, props) => ({
class LoginForm extends ImmutablePureComponent { class LoginForm extends ImmutablePureComponent {
constructor(props) {
super(props);
this.state = {isLoading: false};
}
componentWillMount() { componentWillMount() {
this.props.dispatch(createAuthApp()); this.props.dispatch(createAuthApp());
} }
@ -25,21 +31,27 @@ class LoginForm extends ImmutablePureComponent {
const { dispatch } = this.props; const { dispatch } = this.props;
const { username, password } = this.getFormData(event.target); const { username, password } = this.getFormData(event.target);
dispatch(logIn(username, password)).then(() => { dispatch(logIn(username, password)).then(() => {
dispatch(fetchMe()); return dispatch(fetchMe());
}).catch(() => {
// TODO: Handle bad request
this.setState({isLoading: false});
}); });
this.setState({isLoading: true});
event.preventDefault(); event.preventDefault();
} }
render() { render() {
const { me } = this.props; const { me } = this.props;
if (me) return <Redirect to="/home" />; if (me) return <Redirect to="/home" />;
return ( return (
<form onSubmit={this.handleSubmit}> <form onSubmit={this.handleSubmit}>
<LoadingBar loading={this.state.isLoading ? 1 : 0} className='loading-bar' />
<fieldset disabled={this.state.isLoading}>
<input name='username' placeholder='me@example.com' /> <input name='username' placeholder='me@example.com' />
<input name='password' type='password' placeholder='Password' /> <input name='password' type='password' placeholder='Password' />
<input type='submit' value='Login' /> <input type='submit' value='Login' />
</fieldset>
</form> </form>
) )
} }