diff options
Diffstat (limited to 'mascara/src/app/first-time/create-password-screen.js')
-rw-r--r-- | mascara/src/app/first-time/create-password-screen.js | 221 |
1 files changed, 0 insertions, 221 deletions
diff --git a/mascara/src/app/first-time/create-password-screen.js b/mascara/src/app/first-time/create-password-screen.js deleted file mode 100644 index 0908787da..000000000 --- a/mascara/src/app/first-time/create-password-screen.js +++ /dev/null @@ -1,221 +0,0 @@ -import React, { Component } from 'react' -import PropTypes from 'prop-types' -import {connect} from 'react-redux' -import { withRouter } from 'react-router-dom' -import { compose } from 'recompose' -import { createNewVaultAndKeychain } from '../../../../ui/app/actions' -import Breadcrumbs from './breadcrumbs' -import EventEmitter from 'events' -import Mascot from '../../../../ui/app/components/mascot' -import classnames from 'classnames' -import { - INITIALIZE_UNIQUE_IMAGE_ROUTE, - INITIALIZE_IMPORT_WITH_SEED_PHRASE_ROUTE, - INITIALIZE_NOTICE_ROUTE, -} from '../../../../ui/app/routes' -import TextField from '../../../../ui/app/components/text-field' - -class CreatePasswordScreen extends Component { - static contextTypes = { - t: PropTypes.func, - } - - static propTypes = { - isLoading: PropTypes.bool.isRequired, - createAccount: PropTypes.func.isRequired, - history: PropTypes.object.isRequired, - isInitialized: PropTypes.bool, - isUnlocked: PropTypes.bool, - isMascara: PropTypes.bool.isRequired, - } - - state = { - password: '', - confirmPassword: '', - passwordError: null, - confirmPasswordError: null, - } - - constructor (props) { - super(props) - this.animationEventEmitter = new EventEmitter() - } - - componentWillMount () { - const { isInitialized, history } = this.props - - if (isInitialized) { - history.push(INITIALIZE_NOTICE_ROUTE) - } - } - - isValid () { - const { password, confirmPassword } = this.state - - if (!password || !confirmPassword) { - return false - } - - if (password.length < 8) { - return false - } - - return password === confirmPassword - } - - createAccount = (event) => { - event.preventDefault() - - if (!this.isValid()) { - return - } - - const { password } = this.state - const { createAccount, history } = this.props - - this.setState({ isLoading: true }) - createAccount(password) - .then(() => history.push(INITIALIZE_UNIQUE_IMAGE_ROUTE)) - } - - handlePasswordChange (password) { - const { confirmPassword } = this.state - let confirmPasswordError = null - let passwordError = null - - if (password && password.length < 8) { - passwordError = this.context.t('passwordNotLongEnough') - } - - if (confirmPassword && password !== confirmPassword) { - confirmPasswordError = this.context.t('passwordsDontMatch') - } - - this.setState({ password, passwordError, confirmPasswordError }) - } - - handleConfirmPasswordChange (confirmPassword) { - const { password } = this.state - let confirmPasswordError = null - - if (password !== confirmPassword) { - confirmPasswordError = this.context.t('passwordsDontMatch') - } - - this.setState({ confirmPassword, confirmPasswordError }) - } - - render () { - const { history, isMascara } = this.props - const { passwordError, confirmPasswordError } = this.state - const { t } = this.context - - return ( - <div className={classnames({ 'first-view-main-wrapper': !isMascara })}> - <div className={classnames({ - 'first-view-main': !isMascara, - 'first-view-main__mascara': isMascara, - })}> - {isMascara && <div className="mascara-info first-view-phone-invisible"> - <Mascot - animationEventEmitter={this.animationEventEmitter} - width="225" - height="225" - /> - <div className="info"> - MetaMask is a secure identity vault for Ethereum. - </div> - <div className="info"> - It allows you to hold ether & tokens, and interact with decentralized applications. - </div> - </div>} - <form className="create-password"> - <div className="create-password__title"> - Create Password - </div> - <TextField - id="create-password" - label={t('newPassword')} - type="password" - className="first-time-flow__input" - value={this.state.password} - onChange={event => this.handlePasswordChange(event.target.value)} - error={passwordError} - autoFocus - autoComplete="new-password" - margin="normal" - fullWidth - largeLabel - /> - <TextField - id="confirm-password" - label={t('confirmPassword')} - type="password" - className="first-time-flow__input" - value={this.state.confirmPassword} - onChange={event => this.handleConfirmPasswordChange(event.target.value)} - error={confirmPasswordError} - autoComplete="confirm-password" - margin="normal" - fullWidth - largeLabel - /> - <button - className="first-time-flow__button" - disabled={!this.isValid()} - onClick={this.createAccount} - > - Create - </button> - <a - href="" - className="first-time-flow__link create-password__import-link" - onClick={e => { - e.preventDefault() - history.push(INITIALIZE_IMPORT_WITH_SEED_PHRASE_ROUTE) - }} - > - Import with seed phrase - </a> - { /* } - <a - href="" - className="first-time-flow__link create-password__import-link" - onClick={e => { - e.preventDefault() - history.push(INITIALIZE_IMPORT_ACCOUNT_ROUTE) - }} - > - Import an account - </a> - { */ } - <Breadcrumbs total={3} currentIndex={0} /> - </form> - </div> - </div> - ) - } -} - -const mapStateToProps = ({ metamask, appState }) => { - const { isInitialized, isUnlocked, isMascara, noActiveNotices } = metamask - const { isLoading } = appState - - return { - isLoading, - isInitialized, - isUnlocked, - isMascara, - noActiveNotices, - } -} - -export default compose( - withRouter, - connect( - mapStateToProps, - dispatch => ({ - createAccount: password => dispatch(createNewVaultAndKeychain(password)), - }) - ) -)(CreatePasswordScreen) |