Browse Source

Separate importable/creatable accounts

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

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

@ -1,7 +1,9 @@
// @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 type { Account } from '@ledgerhq/live-common/lib/types'
import uniq from 'lodash/uniq'
import { getBridgeForCurrency } from 'bridge' import { getBridgeForCurrency } from 'bridge'
@ -48,10 +50,16 @@ class StepImport extends PureComponent<StepProps> {
this.scanSubscription = bridge.scanAccountsOnDevice(currency, devicePath, { this.scanSubscription = bridge.scanAccountsOnDevice(currency, devicePath, {
next: account => { next: account => {
const { scannedAccounts } = this.props const { scannedAccounts, checkedAccountsIds } = this.props
const hasAlreadyBeenScanned = !!scannedAccounts.find(a => account.id === a.id) const hasAlreadyBeenScanned = !!scannedAccounts.find(a => account.id === a.id)
if (!hasAlreadyBeenScanned) { if (!hasAlreadyBeenScanned) {
setState({ scannedAccounts: [...scannedAccounts, account] }) setState({
scannedAccounts: [...scannedAccounts, account],
checkedAccountsIds:
account.operations.length > 0
? uniq([...checkedAccountsIds, account.id])
: checkedAccountsIds,
})
} }
}, },
complete: () => setState({ scanStatus: 'finished' }), complete: () => setState({ scanStatus: 'finished' }),
@ -105,26 +113,52 @@ class StepImport extends PureComponent<StepProps> {
handleToggleSelectAll = () => { handleToggleSelectAll = () => {
const { scannedAccounts, setState } = this.props const { scannedAccounts, setState } = this.props
setState({ checkedAccountsIds: scannedAccounts.map(a => a.id) }) setState({
checkedAccountsIds: scannedAccounts.filter(a => a.operations.length > 0).map(a => a.id),
})
} }
render() { render() {
const { scanStatus, err, scannedAccounts, checkedAccountsIds, existingAccounts } = this.props const { scanStatus, err, scannedAccounts, checkedAccountsIds, existingAccounts } = this.props
const importableAccounts = scannedAccounts.filter(acc => {
if (acc.operations.length <= 0) {
return false
}
return existingAccounts.find(a => a.id === acc.id) === undefined
})
const creatableAccounts = scannedAccounts.filter(acc => {
if (acc.operations.length > 0) {
return false
}
return existingAccounts.find(a => a.id === acc.id) === undefined
})
return ( return (
<Box> <Box>
{err && <Box shrink>{err.message}</Box>} {err && <Box shrink>{err.message}</Box>}
{!!scannedAccounts.length && ( <Box flow={5}>
<Box horizontal justify="flex-end" mb={2}> <Box>
<FakeLink onClick={this.handleToggleSelectAll} fontSize={3}> {!!importableAccounts.length && (
<Box horizontal mb={3} align="center">
<Box
ff="Open Sans|Bold"
color="dark"
fontSize={2}
style={{ textTransform: 'uppercase' }}
>
{`Account(s) to import (${importableAccounts.length})`}
</Box>
<FakeLink ml="auto" onClick={this.handleToggleSelectAll} fontSize={3}>
{'Select all'} {'Select all'}
</FakeLink> </FakeLink>
</Box> </Box>
)} )}
<Box flow={2}> <Box flow={2}>
{scannedAccounts.map(account => { {importableAccounts.map(account => {
const isChecked = checkedAccountsIds.find(id => id === account.id) !== undefined const isChecked = checkedAccountsIds.find(id => id === account.id) !== undefined
const existingAccount = existingAccounts.find(a => a.id === account.id) const existingAccount = existingAccounts.find(a => a.id === account.id)
const isDisabled = existingAccount !== undefined const isDisabled = existingAccount !== undefined
@ -139,23 +173,40 @@ class StepImport extends PureComponent<StepProps> {
/> />
) )
})} })}
{scanStatus === 'scanning' && ( {scanStatus === 'scanning' && (
<LoadingRow>
<Spinner color="grey" size={16} />
</LoadingRow>
)}
</Box>
</Box>
{creatableAccounts.length > 0 && (
<Box>
<Box horizontal mb={3} align="center">
<Box <Box
horizontal ff="Open Sans|Bold"
bg="lightGrey" color="dark"
borderRadius={3} fontSize={2}
px={3} style={{ textTransform: 'uppercase' }}
align="center"
justify="center"
style={{ height: 48 }}
> >
<Spinner color="grey" size={24} /> {'Create account'}
</Box>
</Box>
<AccountRow
account={creatableAccounts[0]}
isChecked={
checkedAccountsIds.find(id => id === creatableAccounts[0].id) !== undefined
}
onClick={this.handleToggleAccount}
onAccountUpdate={this.handleAccountUpdate}
/>
</Box> </Box>
)} )}
</Box> </Box>
<Box horizontal mt={2}> <Box horizontal mt={2}>
{['error', 'finished'].includes(scanStatus) && ( {['error'].includes(scanStatus) && (
<Button small outline onClick={this.handleRetry}> <Button small outline onClick={this.handleRetry}>
<Box horizontal flow={2} align="center"> <Box horizontal flow={2} align="center">
<IconExchange size={13} /> <IconExchange size={13} />
@ -171,6 +222,17 @@ class StepImport extends PureComponent<StepProps> {
export default StepImport export default StepImport
export const LoadingRow = styled(Box).attrs({
horizontal: true,
borderRadius: 1,
px: 3,
align: 'center',
justify: 'center',
})`
height: 48px;
border: 1px dashed ${p => p.theme.colors.fog};
`
export const StepImportFooter = ({ scanStatus, onClickImport, checkedAccountsIds }: StepProps) => ( export const StepImportFooter = ({ scanStatus, onClickImport, checkedAccountsIds }: StepProps) => (
<Button <Button
primary primary

2
static/i18n/en/importAccounts.yml

@ -1,4 +1,4 @@
title: Import accounts title: Add accounts
breadcrumb: breadcrumb:
informations: Informations informations: Informations
connectDevice: Connect device connectDevice: Connect device

Loading…
Cancel
Save