109 lines
3.1 KiB
React
109 lines
3.1 KiB
React
|
// @flow
|
||
|
import * as PAGES from 'constants/pages';
|
||
|
import React from 'react';
|
||
|
import { Lbryio } from 'lbryinc';
|
||
|
import { useHistory } from 'react-router';
|
||
|
import Card from 'component/common/card';
|
||
|
import { Form, FormField } from 'component/common/form';
|
||
|
import ErrorText from 'component/common/error-text';
|
||
|
import Button from 'component/button';
|
||
|
import Nag from 'component/common/nag';
|
||
|
import Spinner from 'component/spinner';
|
||
|
|
||
|
type Props = {
|
||
|
user: ?User,
|
||
|
doClearEmailEntry: () => void,
|
||
|
doUserFetch: () => void,
|
||
|
doToast: ({ message: string }) => void,
|
||
|
history: { push: string => void },
|
||
|
location: { search: string },
|
||
|
passwordSetPending: boolean,
|
||
|
passwordSetError: ?string,
|
||
|
};
|
||
|
|
||
|
function UserPasswordReset(props: Props) {
|
||
|
const { doClearEmailEntry, doToast, doUserFetch } = props;
|
||
|
const { location, push } = useHistory();
|
||
|
const urlParams = new URLSearchParams(location.search);
|
||
|
const email = urlParams.get('email');
|
||
|
const authToken = urlParams.get('auth_token');
|
||
|
const verificationToken = urlParams.get('verification_token');
|
||
|
const [password, setPassword] = React.useState('');
|
||
|
const [error, setError] = React.useState();
|
||
|
const [loading, setLoading] = React.useState(false);
|
||
|
|
||
|
function handleSubmit() {
|
||
|
setLoading(true);
|
||
|
|
||
|
Lbryio.call('user_email', 'confirm', {
|
||
|
email: email,
|
||
|
verification_token: verificationToken,
|
||
|
})
|
||
|
.then(() =>
|
||
|
Lbryio.call(
|
||
|
'user_password',
|
||
|
'set',
|
||
|
{
|
||
|
auth_token: authToken,
|
||
|
new_password: password,
|
||
|
},
|
||
|
'post'
|
||
|
)
|
||
|
)
|
||
|
.then(doUserFetch)
|
||
|
.then(() => {
|
||
|
setLoading(false);
|
||
|
doToast({
|
||
|
message: __('Password successfully changed!'),
|
||
|
});
|
||
|
push(`/`);
|
||
|
})
|
||
|
.catch(error => {
|
||
|
setLoading(false);
|
||
|
setError(error.message);
|
||
|
});
|
||
|
}
|
||
|
|
||
|
function handleRestart() {
|
||
|
doClearEmailEntry();
|
||
|
push(`/$/${PAGES.AUTH_SIGNIN}`);
|
||
|
}
|
||
|
|
||
|
return (
|
||
|
<section className="main__sign-in">
|
||
|
<Card
|
||
|
title={__('Choose a new password')}
|
||
|
subtitle={__('Setting a new password for %email%', { email })}
|
||
|
actions={
|
||
|
<div>
|
||
|
<Form onSubmit={handleSubmit} className="section">
|
||
|
<FormField
|
||
|
autoFocus
|
||
|
type="password"
|
||
|
name="password_set"
|
||
|
label={__('New Password')}
|
||
|
value={password}
|
||
|
onChange={e => setPassword(e.target.value)}
|
||
|
/>
|
||
|
|
||
|
<div className="section__actions">
|
||
|
<Button
|
||
|
button="primary"
|
||
|
type="submit"
|
||
|
label={loading ? __('Updating Password') : __('Update Password')}
|
||
|
disabled={!password || loading}
|
||
|
/>
|
||
|
<Button button="link" label={__('Cancel')} onClick={handleRestart} />
|
||
|
{loading && <Spinner type="small" />}
|
||
|
</div>
|
||
|
</Form>
|
||
|
</div>
|
||
|
}
|
||
|
nag={error && <Nag type="error" relative message={<ErrorText>{error}</ErrorText>} />}
|
||
|
/>
|
||
|
</section>
|
||
|
);
|
||
|
}
|
||
|
|
||
|
export default UserPasswordReset;
|