Disable auth form during requests
This commit is contained in:
parent
1d213b5d0b
commit
42e584ca72
1 changed files with 17 additions and 5 deletions
|
@ -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>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue