Browse Source

Finalize the import, add accounts to reducer, finish step

master
meriadec 7 years ago
parent
commit
b3141f928f
No known key found for this signature in database GPG Key ID: 1D2FC2305E2CB399
  1. 41
      src/components/modals/ImportAccounts/index.js
  2. 12
      src/components/modals/ImportAccounts/steps/03-step-import.js
  3. 16
      src/components/modals/ImportAccounts/steps/04-step-finish.js
  4. 60
      src/helpers/libcore.js
  5. 2
      static/i18n/en/importAccounts.yml

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

@ -11,6 +11,8 @@ import type { T, Device } from 'types/common'
import { getCurrentDevice } from 'reducers/devices' import { getCurrentDevice } from 'reducers/devices'
import { getAccounts } from 'reducers/accounts' import { getAccounts } from 'reducers/accounts'
import { addAccount } from 'actions/accounts'
import { closeModal } from 'reducers/modals'
import Modal, { ModalContent, ModalTitle, ModalFooter, ModalBody } from 'components/base/Modal' import Modal, { ModalContent, ModalTitle, ModalFooter, ModalBody } from 'components/base/Modal'
import Box from 'components/base/Box' import Box from 'components/base/Box'
@ -50,9 +52,9 @@ const createSteps = ({ t }: { t: T }) => [
id: 'finish', id: 'finish',
label: t('importAccounts:breadcrumb.finish'), label: t('importAccounts:breadcrumb.finish'),
component: StepFinish, component: StepFinish,
footer: StepChooseCurrencyFooter, footer: null,
onBack: null, onBack: null,
hideFooter: false, hideFooter: true,
}, },
] ]
@ -85,6 +87,8 @@ export type StepProps = {
isAppOpened: boolean, isAppOpened: boolean,
transitionTo: StepId => void, transitionTo: StepId => void,
setState: any => void, setState: any => void,
onClickImport: void => void,
onCloseModal: void => void,
// scan process // scan process
scannedAccounts: Account[], scannedAccounts: Account[],
@ -99,6 +103,11 @@ const mapStateToProps = state => ({
existingAccounts: getAccounts(state), existingAccounts: getAccounts(state),
}) })
const mapDispatchToProps = {
addAccount,
closeModal,
}
const INITIAL_STATE = { const INITIAL_STATE = {
stepId: 'chooseCurrency', stepId: 'chooseCurrency',
isAppOpened: false, isAppOpened: false,
@ -121,6 +130,26 @@ class ImportAccounts extends PureComponent<Props, State> {
this.setState(nextState) this.setState(nextState)
} }
handleClickImport = async () => {
const { addAccount } = this.props
const { scannedAccounts, checkedAccountsIds } = this.state
const accountsIdsMap = checkedAccountsIds.reduce((acc, cur) => {
acc[cur] = true
return acc
}, {})
const accountsToImport = scannedAccounts.filter(account => accountsIdsMap[account.id] === true)
for (let i = 0; i < accountsToImport.length; i++) {
await idleCallback()
addAccount(accountsToImport[i])
}
this.transitionTo('finish')
}
handleCloseModal = () => {
const { closeModal } = this.props
closeModal('importAccounts')
}
render() { render() {
const { t, currentDevice, existingAccounts } = this.props const { t, currentDevice, existingAccounts } = this.props
const { const {
@ -152,6 +181,8 @@ class ImportAccounts extends PureComponent<Props, State> {
scanStatus, scanStatus,
err, err,
isAppOpened, isAppOpened,
onClickImport: this.handleClickImport,
onCloseModal: this.handleCloseModal,
transitionTo: this.transitionTo, transitionTo: this.transitionTo,
setState: (...args) => this.setState(...args), setState: (...args) => this.setState(...args),
} }
@ -182,4 +213,8 @@ class ImportAccounts extends PureComponent<Props, State> {
} }
} }
export default compose(connect(mapStateToProps), translate())(ImportAccounts) export default compose(connect(mapStateToProps, mapDispatchToProps), translate())(ImportAccounts)
function idleCallback() {
return new Promise(resolve => window.requestIdleCallback(resolve))
}

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

@ -141,7 +141,7 @@ class StepImport extends PureComponent<StepProps> {
<Box horizontal mt={2}> <Box horizontal mt={2}>
{['error', 'finished'].includes(scanStatus) && ( {['error', 'finished'].includes(scanStatus) && (
<Button small outline onClick={this.handleRetry}> <Button ml="auto" small outline onClick={this.handleRetry}>
<Box horizontal flow={2} align="center"> <Box horizontal flow={2} align="center">
<IconExchange size={13} /> <IconExchange size={13} />
<span>{'retry'}</span> <span>{'retry'}</span>
@ -156,8 +156,12 @@ class StepImport extends PureComponent<StepProps> {
export default StepImport export default StepImport
export const StepImportFooter = ({ scanStatus, transitionTo, t }: StepProps) => ( export const StepImportFooter = ({ scanStatus, onClickImport, checkedAccountsIds }: StepProps) => (
<Button primary disabled={scanStatus !== 'finished'} onClick={() => transitionTo('finish')}> <Button
{t('common:next')} primary
disabled={scanStatus !== 'finished' || checkedAccountsIds.length === 0}
onClick={() => onClickImport()}
>
{'Import accounts'}
</Button> </Button>
) )

16
src/components/modals/ImportAccounts/steps/04-step-finish.js

@ -3,9 +3,21 @@
import React from 'react' import React from 'react'
import Box from 'components/base/Box' import Box from 'components/base/Box'
import Button from 'components/base/Button'
import IconCheckCircle from 'icons/CheckCircle'
function StepFinish() { function StepFinish({ onCloseModal }: StepProps) {
return <Box>{'StepFinish'}</Box> return (
<Box align="center" py={6}>
<Box color="positiveGreen" mb={4}>
<IconCheckCircle size={40} />
</Box>
<Box mb={4}>{'Great success!'}</Box>
<Button primary onClick={onCloseModal}>
{'Close'}
</Button>
</Box>
)
} }
export default StepFinish export default StepFinish

60
src/helpers/libcore.js

@ -136,7 +136,8 @@ async function scanNextAccount(props: {
? await wallet.getAccount(accountIndex) ? await wallet.getAccount(accountIndex)
: await core.createAccount(wallet, hwApp) : await core.createAccount(wallet, hwApp)
if (!hasBeenScanned) { const shouldSyncAccount = true // TODO: let's sync everytime. maybe in the future we can optimize.
if (shouldSyncAccount) {
await core.syncAccount(njsAccount) await core.syncAccount(njsAccount)
} }
@ -214,16 +215,6 @@ async function buildAccountRaw({
// $FlowFixMe // $FlowFixMe
ops: NJSOperation[], ops: NJSOperation[],
}): Promise<AccountRaw> { }): Promise<AccountRaw> {
/*
const balanceByDay = ops.length
? await getBalanceByDaySinceOperation({
njsAccount,
njsOperation: ops[0],
core,
})
: {}
*/
const njsBalance = await njsAccount.getBalance() const njsBalance = await njsAccount.getBalance()
const balance = njsBalance.toLong() const balance = njsBalance.toLong()
@ -269,7 +260,7 @@ async function buildAccountRaw({
freshAddressPath, freshAddressPath,
balance, balance,
blockHeight, blockHeight,
archived: true, archived: false,
index: accountIndex, index: accountIndex,
operations, operations,
pendingOperations: [], pendingOperations: [],
@ -318,48 +309,3 @@ function buildOperationRaw({
date: op.getDate().toISOString(), date: op.getDate().toISOString(),
} }
} }
/*
async function getBalanceByDaySinceOperation({
njsAccount,
njsOperation,
core,
}: {
njsAccount: NJSAccount,
njsOperation: NJSOperation,
core: Object,
}) {
const startDate = njsOperation.getDate()
// set end date to tomorrow
const endDate = new Date()
endDate.setDate(endDate.getDate() + 1)
const njsBalanceHistory = await njsAccount.getBalanceHistory(
startDate.toISOString(),
endDate.toISOString(),
core.TIME_PERIODS.DAY,
)
let i = 0
const res = {}
while (!areSameDay(startDate, endDate)) {
const dateSQLFormatted = startDate.toISOString().substr(0, 10)
const balanceDay = njsBalanceHistory[i]
if (balanceDay) {
res[dateSQLFormatted] = njsBalanceHistory[i].toLong()
} else {
console.warn(`No balance for day ${dateSQLFormatted}. This is a bug.`) // eslint-disable-line no-console
}
startDate.setDate(startDate.getDate() + 1)
i++
}
return res
}
function areSameDay(date1: Date, date2: Date): boolean {
return (
date1.getFullYear() === date2.getFullYear() &&
date1.getMonth() === date2.getMonth() &&
date1.getDate() === date2.getDate()
)
}
*/

2
static/i18n/en/importAccounts.yml

@ -3,4 +3,4 @@ breadcrumb:
informations: Informations informations: Informations
connectDevice: Connect device connectDevice: Connect device
import: Import import: Import
finish: Confirm finish: End

Loading…
Cancel
Save