import React, { Component } from 'react' import PropTypes from 'prop-types' import {connect} from 'react-redux' import CreatePasswordScreen from './create-password-screen' import UniqueImageScreen from './unique-image-screen' import NoticeScreen from './notice-screen' import BackupPhraseScreen from './backup-phrase-screen' import ImportAccountScreen from './import-account-screen' import ImportSeedPhraseScreen from './import-seed-phrase-screen' const Loading = require('../../../../ui/app/components/loading') import { onboardingBuyEthView, unMarkPasswordForgotten, } from '../../../../ui/app/actions' class FirstTimeFlow extends Component { static propTypes = { isInitialized: PropTypes.bool, seedWords: PropTypes.string, address: PropTypes.string, noActiveNotices: PropTypes.bool, goToBuyEtherView: PropTypes.func.isRequired, }; static defaultProps = { isInitialized: false, seedWords: '', noActiveNotices: false, }; static SCREEN_TYPE = { CREATE_PASSWORD: 'create_password', IMPORT_ACCOUNT: 'import_account', IMPORT_SEED_PHRASE: 'import_seed_phrase', UNIQUE_IMAGE: 'unique_image', NOTICE: 'notice', BACK_UP_PHRASE: 'back_up_phrase', CONFIRM_BACK_UP_PHRASE: 'confirm_back_up_phrase', LOADING: 'loading', }; constructor (props) { super(props) this.state = { screenType: this.getScreenType(), } } setScreenType (screenType) { this.setState({ screenType }) } getScreenType () { const { isInitialized, seedWords, noActiveNotices, forgottenPassword, } = this.props const {SCREEN_TYPE} = FirstTimeFlow // return SCREEN_TYPE.NOTICE if (forgottenPassword) { return SCREEN_TYPE.IMPORT_SEED_PHRASE } if (!isInitialized) { return SCREEN_TYPE.CREATE_PASSWORD } if (!noActiveNotices) { return SCREEN_TYPE.NOTICE } if (seedWords) { return SCREEN_TYPE.BACK_UP_PHRASE } }; renderScreen () { const {SCREEN_TYPE} = FirstTimeFlow const { goToBuyEtherView, address, restoreCreatePasswordScreen, forgottenPassword, isLoading, leaveImportSeedScreenState, } = this.props if (isLoading) { return () } switch (this.state.screenType) { case SCREEN_TYPE.CREATE_PASSWORD: return ( this.setScreenType(SCREEN_TYPE.UNIQUE_IMAGE)} goToImportAccount={() => this.setScreenType(SCREEN_TYPE.IMPORT_ACCOUNT)} goToImportWithSeedPhrase={() => this.setScreenType(SCREEN_TYPE.IMPORT_SEED_PHRASE)} /> ) case SCREEN_TYPE.IMPORT_ACCOUNT: return ( this.setScreenType(SCREEN_TYPE.CREATE_PASSWORD)} next={() => this.setScreenType(SCREEN_TYPE.NOTICE)} /> ) case SCREEN_TYPE.IMPORT_SEED_PHRASE: return ( { leaveImportSeedScreenState() this.setScreenType(SCREEN_TYPE.CREATE_PASSWORD) }} next={() => { const newScreenType = forgottenPassword ? null : SCREEN_TYPE.NOTICE this.setScreenType(newScreenType) }} /> ) case SCREEN_TYPE.UNIQUE_IMAGE: return ( this.setScreenType(SCREEN_TYPE.NOTICE)} /> ) case SCREEN_TYPE.NOTICE: return ( this.setScreenType(SCREEN_TYPE.BACK_UP_PHRASE)} /> ) case SCREEN_TYPE.BACK_UP_PHRASE: return ( goToBuyEtherView(address)} /> ) default: return