|
@ -8,11 +8,10 @@ import uniq from 'lodash/uniq' |
|
|
import { getBridgeForCurrency } from 'bridge' |
|
|
import { getBridgeForCurrency } from 'bridge' |
|
|
|
|
|
|
|
|
import Box from 'components/base/Box' |
|
|
import Box from 'components/base/Box' |
|
|
import FakeLink from 'components/base/FakeLink' |
|
|
|
|
|
import CurrencyBadge from 'components/base/CurrencyBadge' |
|
|
import CurrencyBadge from 'components/base/CurrencyBadge' |
|
|
import Button from 'components/base/Button' |
|
|
import Button from 'components/base/Button' |
|
|
import AccountsList from 'components/base/AccountsList' |
|
|
import AccountsList from 'components/base/AccountsList' |
|
|
import IconExchange from 'icons/Exchange' |
|
|
import IconExclamationCircleThin from 'icons/ExclamationCircleThin' |
|
|
|
|
|
|
|
|
import type { StepProps } from '../index' |
|
|
import type { StepProps } from '../index' |
|
|
|
|
|
|
|
@ -26,6 +25,11 @@ class StepImport extends PureComponent<StepProps> { |
|
|
if (prevProps.scanStatus !== 'finished' && this.props.scanStatus === 'finished') { |
|
|
if (prevProps.scanStatus !== 'finished' && this.props.scanStatus === 'finished') { |
|
|
this.unsub() |
|
|
this.unsub() |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// handle case when we click on retry sync
|
|
|
|
|
|
if (prevProps.scanStatus !== 'scanning' && this.props.scanStatus === 'scanning') { |
|
|
|
|
|
this.startScanAccountsDevice() |
|
|
|
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
componentWillUnmount() { |
|
|
componentWillUnmount() { |
|
@ -71,8 +75,12 @@ class StepImport extends PureComponent<StepProps> { |
|
|
|
|
|
|
|
|
setState({ scanStatus: 'scanning' }) |
|
|
setState({ scanStatus: 'scanning' }) |
|
|
|
|
|
|
|
|
|
|
|
this._unsubscribed = false |
|
|
this.scanSubscription = bridge.scanAccountsOnDevice(currency, devicePath, { |
|
|
this.scanSubscription = bridge.scanAccountsOnDevice(currency, devicePath, { |
|
|
next: account => { |
|
|
next: account => { |
|
|
|
|
|
// FIXME: this is called even if we unsubscribed
|
|
|
|
|
|
if (this._unsubscribed) return |
|
|
|
|
|
|
|
|
const { scannedAccounts, checkedAccountsIds, existingAccounts } = this.props |
|
|
const { scannedAccounts, checkedAccountsIds, existingAccounts } = this.props |
|
|
const hasAlreadyBeenScanned = !!scannedAccounts.find(a => account.id === a.id) |
|
|
const hasAlreadyBeenScanned = !!scannedAccounts.find(a => account.id === a.id) |
|
|
const hasAlreadyBeenImported = !!existingAccounts.find(a => account.id === a.id) |
|
|
const hasAlreadyBeenImported = !!existingAccounts.find(a => account.id === a.id) |
|
@ -87,8 +95,16 @@ class StepImport extends PureComponent<StepProps> { |
|
|
}) |
|
|
}) |
|
|
} |
|
|
} |
|
|
}, |
|
|
}, |
|
|
complete: () => setState({ scanStatus: 'finished' }), |
|
|
complete: () => { |
|
|
error: err => setState({ scanStatus: 'error', err }), |
|
|
// FIXME: this is called even if we unsubscribed
|
|
|
|
|
|
if (this._unsubscribed) return |
|
|
|
|
|
setState({ scanStatus: 'finished' }) |
|
|
|
|
|
}, |
|
|
|
|
|
error: err => { |
|
|
|
|
|
// FIXME: this is called even if we unsubscribed
|
|
|
|
|
|
if (this._unsubscribed) return |
|
|
|
|
|
setState({ scanStatus: 'error', err }) |
|
|
|
|
|
}, |
|
|
}) |
|
|
}) |
|
|
} catch (err) { |
|
|
} catch (err) { |
|
|
setState({ scanStatus: 'error', err }) |
|
|
setState({ scanStatus: 'error', err }) |
|
@ -145,6 +161,17 @@ class StepImport extends PureComponent<StepProps> { |
|
|
|
|
|
|
|
|
handleUnselectAll = () => this.props.setState({ checkedAccountsIds: [] }) |
|
|
handleUnselectAll = () => this.props.setState({ checkedAccountsIds: [] }) |
|
|
|
|
|
|
|
|
|
|
|
renderError() { |
|
|
|
|
|
const { err, t } = this.props |
|
|
|
|
|
invariant(err, 'Trying to render inexisting error') |
|
|
|
|
|
return ( |
|
|
|
|
|
<Box style={{ height: 200 }} align="center" justify="center" color="alertRed"> |
|
|
|
|
|
<IconExclamationCircleThin size={43} /> |
|
|
|
|
|
<Box mt={4}>{t('app:addAccounts.somethingWentWrong')}</Box> |
|
|
|
|
|
</Box> |
|
|
|
|
|
) |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
render() { |
|
|
render() { |
|
|
const { |
|
|
const { |
|
|
scanStatus, |
|
|
scanStatus, |
|
@ -156,6 +183,10 @@ class StepImport extends PureComponent<StepProps> { |
|
|
t, |
|
|
t, |
|
|
} = this.props |
|
|
} = this.props |
|
|
|
|
|
|
|
|
|
|
|
if (err) { |
|
|
|
|
|
return this.renderError() |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
const currencyName = currency ? currency.name : '' |
|
|
const currencyName = currency ? currency.name : '' |
|
|
|
|
|
|
|
|
const importableAccounts = scannedAccounts.filter(acc => { |
|
|
const importableAccounts = scannedAccounts.filter(acc => { |
|
@ -208,17 +239,7 @@ class StepImport extends PureComponent<StepProps> { |
|
|
/> |
|
|
/> |
|
|
</Box> |
|
|
</Box> |
|
|
|
|
|
|
|
|
{err && ( |
|
|
{err && <Box shrink>{err.message}</Box>} |
|
|
<Box shrink> |
|
|
|
|
|
{err.message} |
|
|
|
|
|
<Button small outline onClick={this.handleRetry}> |
|
|
|
|
|
<Box horizontal flow={2} align="center"> |
|
|
|
|
|
<IconExchange size={13} /> |
|
|
|
|
|
<span>{t('app:addAccounts.retrySync')}</span> |
|
|
|
|
|
</Box> |
|
|
|
|
|
</Button> |
|
|
|
|
|
</Box> |
|
|
|
|
|
)} |
|
|
|
|
|
</Fragment> |
|
|
</Fragment> |
|
|
) |
|
|
) |
|
|
} |
|
|
} |
|
@ -270,12 +291,21 @@ export const StepImportFooter = ({ |
|
|
return ( |
|
|
return ( |
|
|
<Fragment> |
|
|
<Fragment> |
|
|
{currency && <CurrencyBadge mr="auto" currency={currency} />} |
|
|
{currency && <CurrencyBadge mr="auto" currency={currency} />} |
|
|
|
|
|
{scanStatus === 'error' && ( |
|
|
|
|
|
<Button mr={2} onClick={() => setState({ scanStatus: 'scanning', err: null })}> |
|
|
|
|
|
{t('app:common.retry')} |
|
|
|
|
|
</Button> |
|
|
|
|
|
)} |
|
|
{scanStatus === 'scanning' && ( |
|
|
{scanStatus === 'scanning' && ( |
|
|
<FakeLink mr={2} fontSize={3} onClick={() => setState({ scanStatus: 'finished' })}> |
|
|
<Button mr={2} onClick={() => setState({ scanStatus: 'finished' })}> |
|
|
{t('app:addAccounts.cancelSync')} |
|
|
{t('app:addAccounts.cancelSync')} |
|
|
</FakeLink> |
|
|
</Button> |
|
|
)} |
|
|
)} |
|
|
<Button primary disabled={scanStatus !== 'finished'} onClick={onClick}> |
|
|
<Button |
|
|
|
|
|
primary |
|
|
|
|
|
disabled={scanStatus !== 'finished' && scanStatus !== 'error'} |
|
|
|
|
|
onClick={onClick} |
|
|
|
|
|
> |
|
|
{ctaWording} |
|
|
{ctaWording} |
|
|
</Button> |
|
|
</Button> |
|
|
</Fragment> |
|
|
</Fragment> |
|
|