MyCrypto/common/containers/Tabs/GenerateWallet/components/GenerateWalletPasswordCompo...

160 lines
5.8 KiB
React
Raw Normal View History

2017-06-20 06:13:21 +00:00
import React, { Component } from 'react';
2017-05-30 20:36:52 +00:00
import PropTypes from 'prop-types';
2017-06-20 06:13:21 +00:00
import { Field, reduxForm } from 'redux-form';
2017-05-30 20:36:52 +00:00
import GenerateWalletPasswordInputComponent from './GenerateWalletPasswordInputComponent';
import LedgerTrezorWarning from './LedgerTrezorWarning';
2017-05-31 03:34:57 +00:00
import translate from 'translations';
2017-04-25 00:00:58 +00:00
// VALIDATORS
const minLength = min => value => {
2017-06-20 06:13:21 +00:00
return value && value.length < min
? `Must be ${min} characters or more`
: undefined;
2017-05-31 03:34:57 +00:00
};
const minLength9 = minLength(9);
2017-06-20 06:13:21 +00:00
const required = value => (value ? undefined : 'Required');
class GenerateWalletPasswordComponent extends Component {
2017-06-20 06:13:21 +00:00
constructor(props) {
super(props);
}
2017-06-20 06:13:21 +00:00
static propTypes = {
// state
title: PropTypes.string,
body: PropTypes.string,
userId: PropTypes.number,
id: PropTypes.number,
generateWalletPassword: PropTypes.object,
showPassword: PropTypes.bool,
generateWalletFile: PropTypes.bool,
hasDownloadedWalletFile: PropTypes.bool,
canProceedToPaper: PropTypes.bool,
// actions
generateWalletShowPassword: PropTypes.func,
generateWalletGenerateFile: PropTypes.func,
generateWalletDownloadFile: PropTypes.func,
generateWalletConfirmContinueToPaper: PropTypes.func
};
2017-06-20 06:13:21 +00:00
continueToPaper() {}
2017-06-20 06:13:21 +00:00
downloaded() {
let nextState = this.state;
nextState.hasDownloadedWalletFile = true;
this.setState(nextState);
}
2017-06-20 06:13:21 +00:00
render() {
const {
generateWalletPassword,
showPassword,
generateWalletFile,
hasDownloadedWalletFile,
generateWalletShowPassword,
generateWalletGenerateFile,
generateWalletDownloadFile,
generateWalletConfirmContinueToPaper
} = this.props;
2017-06-20 06:13:21 +00:00
return (
<section className="container" style={{ minHeight: '50%' }}>
<div className="tab-content">
<main className="tab-pane active text-center" role="main">
<br />
{!generateWalletFile &&
<div>
<section className="row">
<h1 aria-live="polite">{translate('NAV_GenerateWallet')}</h1>
<div className="col-sm-8 col-sm-offset-2">
<h4>{translate('HELP_1_Desc_3')}</h4>
<Field
validate={[required, minLength9]}
component={GenerateWalletPasswordInputComponent}
showPassword={showPassword}
generateWalletShowPassword={generateWalletShowPassword}
name="password"
type="text"
/>
<br />
<button
onClick={() => generateWalletGenerateFile()}
disabled={
generateWalletPassword
? generateWalletPassword.syncErrors
: true
}
className="btn btn-primary btn-block"
>
{translate('NAV_GenerateWallet')}
</button>
</div>
</section>
<LedgerTrezorWarning />
</div>}
{generateWalletFile &&
<section role="main" className="row">
<h1>{translate('GEN_Label_2')}</h1>
<br />
<div className="col-sm-8 col-sm-offset-2">
<div aria-hidden="true" className="account-help-icon">
<img
src="https://myetherwallet.com/images/icon-help.svg"
className="help-icon"
/>
<p className="account-help-text">
{translate('x_KeystoreDesc')}
</p>
<h4>{translate('x_Keystore2')}</h4>
</div>
<a
role="button"
className="btn btn-primary btn-block"
href="blob:https://myetherwallet.com/2455ae32-916f-4224-a806-414bbe680168"
download="UTC--2017-04-26T23-07-03.538Z--c5b7fff4e1669e38e8d6bc8fffe7e562b2b70f43"
aria-label="Download Keystore File (UTC / JSON · Recommended · Encrypted)"
aria-describedby="x_KeystoreDesc"
onClick={() => generateWalletDownloadFile()}
>
{translate('x_Download')}
</a>
<p className="sr-only" id="x_KeystoreDesc">
{translate('x_KeystoreDesc')}
</p>
<br /><br /><br /><br />
</div>
<div className="col-xs-12 alert alert-danger">
<span>
MyEtherWallet.com is not a web wallet &amp; does not store
or transmit this secret information at any time. <br />
<strong>
If you do not save your wallet file and password, we
cannot recover them.
</strong>
<br />
Save your wallet file now &amp; back it up in a second
location (not on your computer).
<br /><br />
<a
role="button"
className={`btn btn-info ${hasDownloadedWalletFile
? ''
: 'disabled'}`}
onClick={() => generateWalletConfirmContinueToPaper()}
>
{' '}I understand. Continue.{' '}
</a>
</span>
</div>
2017-06-20 06:13:21 +00:00
</section>}
</main>
</div>
</section>
);
}
}
export default reduxForm({
2017-06-20 06:13:21 +00:00
form: 'generateWalletPassword' // a unique name for this form
})(GenerateWalletPasswordComponent);