import React from 'react' import PropTypes from 'prop-types' import LoadingBolt from 'components/LoadingBolt' import FormContainer from './FormContainer' import ConnectionType from './ConnectionType' import ConnectionDetails from './ConnectionDetails' import ConnectionConfirm from './ConnectionConfirm' import BtcPayServer from './BtcPayServer' import Alias from './Alias' import Autopilot from './Autopilot' import Login from './Login' import Signup from './Signup' import RecoverForm from './RecoverForm' import NewWalletSeed from './NewWalletSeed' import ReEnterSeed from './ReEnterSeed' import NewWalletPassword from './NewWalletPassword' import styles from './Onboarding.scss' const Onboarding = ({ onboarding: { step, previousStep, connectionType, connectionString, connectionHost, connectionCert, connectionMacaroon, alias, autopilot, startingLnd, createWalletPassword, seed, fetchingSeed }, connectionTypeProps, connectionDetailProps, connectionConfirmProps, changeStep, startLnd, submitNewWallet, recoverOldWallet, aliasProps, initWalletProps, autopilotProps, recoverFormProps, newWalletSeedProps, newWalletPasswordProps, reEnterSeedProps }) => { const renderStep = () => { switch (step) { case 0.1: return ( { switch (connectionType) { case 'custom': changeStep(0.2) break case 'btcpayserver': changeStep(0.3) break default: changeStep(1) } }} > ) case 0.2: return ( changeStep(0.1)} next={() => { // dont allow the user to move on if we don't at least have a hostname. if (!connectionDetailProps.connectionHostIsValid) { return } changeStep(0.4) }} > ) case 0.3: return ( changeStep(0.1)} next={() => { // dont allow the user to move on if the connection string is invalid. if (!connectionDetailProps.connectionStringIsValid) { return } changeStep(0.4) }} > ) case 0.4: return ( changeStep(previousStep)} next={() => { startLnd({ type: connectionType, string: connectionString, host: connectionHost, cert: connectionCert, macaroon: connectionMacaroon }) }} > ) case 1: return ( changeStep(0.1)} next={() => changeStep(2)} > ) case 2: return ( changeStep(1)} next={() => startLnd({ type: connectionType, alias, autopilot })} > ) case 3: // eslint-disable-next-line no-case-declarations let message = 'It looks like you already have a wallet' if (initWalletProps.loginProps.existingWalletDir && connectionType === 'local') { message += ` (we found one at ${initWalletProps.loginProps.existingWalletDir})` } else { message += ` at ${connectionHost.split(':')[0]}` } message += '. Please enter your wallet password to unlock it.' return ( ) case 4: return ( { // dont allow the user to move on if the confirmation password doesnt match the original password // if the password is less than 8 characters or empty dont allow users to proceed if ( newWalletPasswordProps.passwordMinCharsError || !newWalletPasswordProps.createWalletPassword || !newWalletPasswordProps.createWalletPasswordConfirmation || newWalletPasswordProps.showCreateWalletPasswordConfirmationError ) { return } changeStep(5) }} > ) case 5: return ( changeStep(4)} next={() => { // require the user to select create wallet or import wallet if ( !initWalletProps.signupProps.signupForm.create && !initWalletProps.signupProps.signupForm.import ) { return } changeStep(initWalletProps.signupProps.signupForm.create ? 6 : 5.1) }} > ) case 5.1: return ( changeStep(5)} next={() => { const recoverySeed = recoverFormProps.recoverSeedInput.map(input => input.word) recoverOldWallet(createWalletPassword, recoverySeed) }} > ) case 6: return ( changeStep(5)} next={() => changeStep(7)} > ) case 7: return ( changeStep(6)} next={() => { // don't allow them to move on if they havent re-entered the seed correctly if (!reEnterSeedProps.reEnterSeedChecker) { return } submitNewWallet(createWalletPassword, seed) }} > ) default: return } } if (startingLnd) { return } if (fetchingSeed) { return } return
{renderStep()}
} Onboarding.propTypes = { onboarding: PropTypes.object.isRequired, connectionTypeProps: PropTypes.object.isRequired, connectionDetailProps: PropTypes.object.isRequired, connectionConfirmProps: PropTypes.object.isRequired, aliasProps: PropTypes.object.isRequired, autopilotProps: PropTypes.object.isRequired, initWalletProps: PropTypes.object.isRequired, newWalletSeedProps: PropTypes.object.isRequired, newWalletPasswordProps: PropTypes.object.isRequired, recoverFormProps: PropTypes.object.isRequired, reEnterSeedProps: PropTypes.object.isRequired, changeStep: PropTypes.func.isRequired, startLnd: PropTypes.func.isRequired, submitNewWallet: PropTypes.func.isRequired, recoverOldWallet: PropTypes.func.isRequired } export default Onboarding