Browse Source

Refactor retry on add account fail

master
meriadec 7 years ago
parent
commit
4a9912281c
No known key found for this signature in database GPG Key ID: 1D2FC2305E2CB399
  1. 66
      src/components/modals/AddAccounts/steps/03-step-import.js
  2. 2
      static/i18n/en/app.yml

66
src/components/modals/AddAccounts/steps/03-step-import.js

@ -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>

2
static/i18n/en/app.yml

@ -149,7 +149,7 @@ addAccounts:
title: Create new account title: Create new account
noOperationOnLastAccount: You cannot create a new account because your last account has no operations noOperationOnLastAccount: You cannot create a new account because your last account has no operations
noAccountToCreate: We didnt find any {{currencyName}} account to create. noAccountToCreate: We didnt find any {{currencyName}} account to create.
retrySync: Retry sync somethingWentWrong: Something went wrong during synchronization.
cta: cta:
create: 'Create account' create: 'Create account'
import: 'Import account' import: 'Import account'

Loading…
Cancel
Save