// @flow import React, { PureComponent } from 'react' import { compose } from 'redux' import { connect } from 'react-redux' import { translate } from 'react-i18next' import type { Currency, Account } from '@ledgerhq/live-common/lib/types' import type { T, Device } from 'types/common' import { getCurrentDevice } from 'reducers/devices' import { getAccounts } from 'reducers/accounts' import Modal, { ModalContent, ModalTitle, ModalFooter, ModalBody } from 'components/base/Modal' import Box from 'components/base/Box' import Breadcrumb from 'components/Breadcrumb' import StepChooseCurrency, { StepChooseCurrencyFooter } from './steps/01-step-choose-currency' import StepConnectDevice, { StepConnectDeviceFooter } from './steps/02-step-connect-device' import StepImport, { StepImportFooter } from './steps/03-step-import' import StepFinish from './steps/04-step-finish' const createSteps = ({ t }: { t: T }) => [ { id: 'chooseCurrency', label: t('importAccounts:breadcrumb.informations'), component: StepChooseCurrency, footer: StepChooseCurrencyFooter, onBack: null, hideFooter: false, }, { id: 'connectDevice', label: t('importAccounts:breadcrumb.connectDevice'), component: StepConnectDevice, footer: StepConnectDeviceFooter, onBack: ({ transitionTo }: StepProps) => transitionTo('chooseCurrency'), hideFooter: false, }, { id: 'import', label: t('importAccounts:breadcrumb.import'), component: StepImport, footer: StepImportFooter, onBack: ({ transitionTo }: StepProps) => transitionTo('chooseCurrency'), hideFooter: false, }, { id: 'finish', label: t('importAccounts:breadcrumb.finish'), component: StepFinish, footer: StepChooseCurrencyFooter, onBack: null, hideFooter: false, }, ] type Props = { t: T, currentDevice: ?Device, existingAccounts: Account[], } type StepId = 'chooseCurrency' | 'connectDevice' | 'import' | 'finish' type ScanStatus = 'idle' | 'scanning' | 'error' | 'finished' type State = { stepId: StepId, isAppOpened: boolean, currency: ?Currency, // scan process scannedAccounts: Account[], checkedAccountsIds: string[], scanStatus: ScanStatus, err: ?Error, } export type StepProps = { t: T, currency: ?Currency, currentDevice: ?Device, isAppOpened: boolean, transitionTo: StepId => void, setState: any => void, // scan process scannedAccounts: Account[], existingAccounts: Account[], checkedAccountsIds: string[], scanStatus: ScanStatus, err: ?Error, } const mapStateToProps = state => ({ currentDevice: getCurrentDevice(state), existingAccounts: getAccounts(state), }) const INITIAL_STATE = { stepId: 'chooseCurrency', isAppOpened: false, currency: null, scannedAccounts: [], checkedAccountsIds: [], } class ImportAccounts extends PureComponent { state = INITIAL_STATE STEPS = createSteps({ t: this.props.t, }) transitionTo = stepId => { let nextState = { stepId } if (stepId === 'chooseCurrency') { nextState = { ...INITIAL_STATE } } this.setState(nextState) } render() { const { t, currentDevice, existingAccounts } = this.props const { stepId, currency, isAppOpened, scannedAccounts, checkedAccountsIds, scanStatus, err, } = this.state const stepIndex = this.STEPS.findIndex(s => s.id === stepId) const step = this.STEPS[stepIndex] if (!step) { throw new Error(`ImportAccountsModal: step ${stepId} doesn't exists`) } const { component: StepComponent, footer: StepFooter, hideFooter, onBack } = step const stepProps: StepProps = { t, currency, currentDevice, existingAccounts, scannedAccounts, checkedAccountsIds, scanStatus, err, isAppOpened, transitionTo: this.transitionTo, setState: (...args) => this.setState(...args), } return ( this.setState({ ...INITIAL_STATE })} render={({ onClose }) => ( onBack(stepProps) : void 0}> {t('importAccounts:title')} {!hideFooter && ( {StepFooter ? : footer} )} )} /> ) } } export default compose(connect(mapStateToProps), translate())(ImportAccounts)