Browse Source

Clean up state, and prepare sync step

master
meriadec 7 years ago
parent
commit
08ac8d01b7
No known key found for this signature in database GPG Key ID: 1D2FC2305E2CB399
  1. 2
      src/components/modals/ImportAccounts/index.js
  2. 96
      src/components/modals/ImportAccounts/steps/03-step-import.js

2
src/components/modals/ImportAccounts/index.js

@ -75,7 +75,6 @@ type State = {
stepId: StepId, stepId: StepId,
isAppOpened: boolean, isAppOpened: boolean,
currency: ?Currency, currency: ?Currency,
scannedAccounts: [],
} }
const mapStateToProps = state => ({ const mapStateToProps = state => ({
@ -86,7 +85,6 @@ const INITIAL_STATE = {
stepId: 'chooseCurrency', stepId: 'chooseCurrency',
isAppOpened: false, isAppOpened: false,
currency: null, currency: null,
scannedAccounts: [],
} }
class ImportAccounts extends PureComponent<Props, State> { class ImportAccounts extends PureComponent<Props, State> {

96
src/components/modals/ImportAccounts/steps/03-step-import.js

@ -1,15 +1,107 @@
// @flow // @flow
import React, { PureComponent } from 'react' import React, { PureComponent } from 'react'
import styled from 'styled-components'
import type { Account } from '@ledgerhq/live-common/lib/types'
import { getBridgeForCurrency } from 'bridge'
import Box from 'components/base/Box' import Box from 'components/base/Box'
import Button from 'components/base/Button'
import type { StepProps } from '../index' import type { StepProps } from '../index'
class StepImport extends PureComponent<StepProps> { type Status = 'scanning' | 'error' | 'finished'
type State = {
status: Status,
err: ?Error,
scannedAccounts: Account[],
}
const INITIAL_STATE = {
status: 'scanning',
err: null,
scannedAccounts: [],
}
class StepImport extends PureComponent<StepProps, State> {
state = INITIAL_STATE
componentDidMount() {
console.log(`starting import...`)
this.startScanAccountsDevice()
}
componentWillUnmount() {
console.log(`stopping import...`)
}
startScanAccountsDevice() {
const { currency } = this.props
if (!currency) {
throw new Error('No currency to scan')
}
const bridge = getBridgeForCurrency(currency)
// TODO: use the real device
const devicePath = ''
this.scanSubscription = bridge.scanAccountsOnDevice(currency, devicePath, {
next: account => {
const { scannedAccounts } = this.state
const hasAlreadyBeenScanned = !!scannedAccounts.find(a => account.id === a.id)
if (!hasAlreadyBeenScanned) {
this.setState({ scannedAccounts: [...scannedAccounts, account] })
}
},
complete: () => {
this.setState({ status: 'finished' })
},
error: err => this.setState({ status: 'error', err }),
})
}
handleRetry = () => {
this.setState(INITIAL_STATE)
this.startScanAccountsDevice()
}
render() { render() {
return <Box>step import</Box> const { status, err, scannedAccounts } = this.state
return (
<Box>
{status === 'scanning' && <Box>{'Scanning in progress...'}</Box>}
{status === 'finished' && <Box>{'Finished'}</Box>}
{['error', 'finished'].includes(status) && (
<Button outline onClick={this.handleRetry}>
{'retry'}
</Button>
)}
{err && <Box shrink>{err.toString()}</Box>}
<AccountsList>
{scannedAccounts.map(account => <AccountRow key={account.id} account={account} />)}
</AccountsList>
</Box>
)
} }
} }
const AccountsList = styled(Box).attrs({
flow: 2,
})``
const AccountRowContainer = styled(Box).attrs({
horizontal: true,
})``
const AccountRow = ({ account }: { account: Account }) => (
<AccountRowContainer>{account.name}</AccountRowContainer>
)
export default StepImport export default StepImport

Loading…
Cancel
Save