lbry-desktop/ui/modal/modalWalletEncrypt/view.jsx

182 lines
5.7 KiB
React
Raw Normal View History

2018-07-18 15:48:30 -04:00
// @flow
import React from 'react';
2019-07-23 04:20:08 +07:00
import { Form, FormField, Submit } from 'component/common/form';
2018-07-18 15:48:30 -04:00
import { Modal } from 'modal/modal';
import Button from 'component/button';
2019-08-27 22:35:07 -04:00
import { setSavedPassword } from 'util/saved-passwords';
2018-07-18 15:48:30 -04:00
type Props = {
closeModal: () => void,
walletEncryptSucceded: boolean,
updateWalletStatus: boolean,
2019-01-19 13:54:06 -05:00
encryptWallet: (?string) => void,
updateWalletStatus: () => void,
2018-07-18 15:48:30 -04:00
};
type State = {
newPassword: ?string,
newPasswordConfirm: ?string,
passwordMismatch: boolean,
understandConfirmed: boolean,
understandError: boolean,
submitted: boolean,
2019-01-19 13:54:06 -05:00
failMessage: ?string,
2019-08-20 08:29:59 -04:00
rememberPassword: boolean,
};
const acknowledgementText = __('I Understand');
class ModalWalletEncrypt extends React.PureComponent<Props, State> {
2018-07-18 15:48:30 -04:00
state = {
newPassword: null,
newPasswordConfirm: null,
passwordMismatch: false,
understandConfirmed: false,
understandError: false,
submitted: false, // Prior actions could be marked complete
2019-01-19 13:54:06 -05:00
failMessage: undefined,
2019-08-20 08:29:59 -04:00
rememberPassword: false,
2018-07-18 15:48:30 -04:00
};
componentDidUpdate() {
const { props, state } = this;
if (state.submitted) {
if (props.walletEncryptSucceded === true) {
props.closeModal();
props.updateWalletStatus();
} else if (props.walletEncryptSucceded === false) {
// See https://github.com/lbryio/lbry/issues/1307
this.setState({ failMessage: 'Unable to encrypt wallet.' });
}
}
}
onChangeNewPassword(event: SyntheticInputEvent<>) {
2018-07-18 15:48:30 -04:00
this.setState({ newPassword: event.target.value });
}
2019-08-20 08:29:59 -04:00
onChangeRememberPassword(event: SyntheticInputEvent<>) {
this.setState({ rememberPassword: event.target.checked });
}
onChangeNewPasswordConfirm(event: SyntheticInputEvent<>) {
2018-07-18 15:48:30 -04:00
this.setState({ newPasswordConfirm: event.target.value });
}
onChangeUnderstandConfirm(event: SyntheticInputEvent<>) {
const regex = new RegExp('^.?' + acknowledgementText + '.?$', 'i');
2018-07-18 15:48:30 -04:00
this.setState({
understandConfirmed: regex.test(event.target.value),
2018-07-18 15:48:30 -04:00
});
}
submitEncryptForm() {
const { state } = this;
if (!state.newPassword) {
return;
}
2018-07-18 15:48:30 -04:00
let invalidEntries = false;
if (state.newPassword !== state.newPasswordConfirm) {
this.setState({ passwordMismatch: true });
invalidEntries = true;
}
if (state.understandConfirmed === false) {
this.setState({ understandError: true });
invalidEntries = true;
}
if (invalidEntries === true) {
return;
}
setSavedPassword(state.newPassword, state.rememberPassword);
2018-07-18 15:48:30 -04:00
this.setState({ submitted: true });
this.props.encryptWallet(state.newPassword);
}
render() {
const { closeModal } = this.props;
const { passwordMismatch, understandError, failMessage } = this.state;
return (
<Modal
isOpen
2018-09-26 13:48:07 -04:00
title={__('Encrypt Wallet')}
2018-07-18 15:48:30 -04:00
contentLabel={__('Encrypt Wallet')}
2019-07-23 04:20:08 +07:00
type="custom"
2018-07-18 15:48:30 -04:00
onConfirmed={() => this.submitEncryptForm()}
onAborted={closeModal}
>
2019-07-21 17:31:22 -04:00
<Form onSubmit={() => this.submitEncryptForm()}>
2019-02-13 12:27:20 -04:00
<p>
{__(
'Encrypting your wallet will require a password to access your local wallet data when LBRY starts. Please enter a new password for your wallet.'
)}{' '}
2019-05-07 17:38:29 -04:00
<Button button="link" label={__('Learn more')} href="https://lbry.com/faq/wallet-encryption" />.
2019-02-13 12:27:20 -04:00
</p>
<fieldset-section>
<FormField
autoFocus
error={passwordMismatch === true ? 'Passwords do not match' : false}
label={__('Password')}
placeholder={__('Shh...')}
2019-03-20 17:43:00 -04:00
type="password"
name="wallet-new-password"
2019-02-13 12:27:20 -04:00
onChange={event => this.onChangeNewPassword(event)}
/>
</fieldset-section>
<fieldset-section>
<FormField
error={passwordMismatch === true ? 'Passwords do not match' : false}
label={__('Confirm Password')}
placeholder={__('Your eyes only')}
2019-03-20 17:43:00 -04:00
type="password"
name="wallet-new-password-confirm"
2019-02-13 12:27:20 -04:00
onChange={event => this.onChangeNewPasswordConfirm(event)}
/>
2019-08-20 08:29:59 -04:00
</fieldset-section>
<fieldset-section>
<FormField
label={__('Remember Password')}
type="checkbox"
name="wallet-remember-password"
onChange={event => this.onChangeRememberPassword(event)}
checked={this.state.rememberPassword}
/>
2019-02-13 12:27:20 -04:00
</fieldset-section>
2019-11-22 16:13:00 -05:00
<div className="section__subtitle--status">
2019-02-13 12:27:20 -04:00
{__(
'If your password is lost, it cannot be recovered. You will not be able to access your wallet without a password.'
)}
</div>
<FormField
2019-07-23 04:20:08 +07:00
inputButton={<Submit label={failMessage ? __('Encrypting Wallet') : __('Encrypt Wallet')} />}
error={
understandError === true
? __('You must enter "%acknowledgement_text%"', { acknowledgement_text: acknowledgementText })
: false
}
label={__('Enter "%acknowledgement_text%"', { acknowledgement_text: acknowledgementText })}
placeholder={__('Type "%acknowledgement_text%"', { acknowledgement_text: acknowledgementText })}
2019-03-20 17:43:00 -04:00
type="text"
name="wallet-understand"
2019-02-13 12:27:20 -04:00
onChange={event => this.onChangeUnderstandConfirm(event)}
/>
2019-03-20 17:43:00 -04:00
{failMessage && <div className="error-text">{__(failMessage)}</div>}
</Form>
2019-07-23 04:20:08 +07:00
<div className="card__actions">
<Button button="link" label={__('Cancel')} onClick={closeModal} />
</div>
2018-07-18 15:48:30 -04:00
</Modal>
);
}
}
export default ModalWalletEncrypt;