soapbox/app/gabsocial/features/auth_login/index.js

58 wiersze
1.9 KiB
JavaScript

import React from 'react';
import { connect } from 'react-redux'
import ImmutablePureComponent from 'react-immutable-pure-component';
import { createAuthApp, logIn } from 'gabsocial/actions/auth';
import { fetchMe } from 'gabsocial/actions/me';
import { Link } from 'react-router-dom';
export default @connect()
class LoginForm extends ImmutablePureComponent {
constructor(props) {
super(props);
this.state = {isLoading: false};
}
componentWillMount() {
this.props.dispatch(createAuthApp());
}
getFormData = (form) => {
return Object.fromEntries(
Array.from(form).map(i => [i.name, i.value])
);
}
handleSubmit = (event) => {
const { dispatch } = this.props;
const { username, password } = this.getFormData(event.target);
dispatch(logIn(username, password)).then(() => {
return dispatch(fetchMe());
}).catch((error) => {
this.setState({isLoading: false});
});
this.setState({isLoading: true});
event.preventDefault();
}
render() {
return (
<form className='simple_form new_user' onSubmit={this.handleSubmit}>
<fieldset className='fields-group' disabled={this.state.isLoading}>
<div className='input email optional user_email'>
<input aria-label='Username' className='string email optional' placeholder='Username' type='text' name='username' />
</div>
<div className='input password optional user_password'>
<input aria-label='Password' className='password optional' placeholder='Password' type='password' name='password' />
</div>
<p className='hint subtle-hint'>
<Link to='/auth/password/new'>Trouble logging in?</Link>
</p>
</fieldset>
<div className='actions'>
<button name='button' type='submit' className='btn button button-primary'>Log in</button>
</div>
</form>
)
}
}