From b3141f928f3fb88e3bac10da1668f07ce2ba3cff Mon Sep 17 00:00:00 2001 From: meriadec Date: Tue, 29 May 2018 14:51:07 +0200 Subject: [PATCH] Finalize the import, add accounts to reducer, finish step --- src/components/modals/ImportAccounts/index.js | 41 ++++++++++++- .../ImportAccounts/steps/03-step-import.js | 12 ++-- .../ImportAccounts/steps/04-step-finish.js | 16 ++++- src/helpers/libcore.js | 60 +------------------ static/i18n/en/importAccounts.yml | 2 +- 5 files changed, 64 insertions(+), 67 deletions(-) diff --git a/src/components/modals/ImportAccounts/index.js b/src/components/modals/ImportAccounts/index.js index a721681b..64ee5e09 100644 --- a/src/components/modals/ImportAccounts/index.js +++ b/src/components/modals/ImportAccounts/index.js @@ -11,6 +11,8 @@ import type { T, Device } from 'types/common' import { getCurrentDevice } from 'reducers/devices' 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 Box from 'components/base/Box' @@ -50,9 +52,9 @@ const createSteps = ({ t }: { t: T }) => [ id: 'finish', label: t('importAccounts:breadcrumb.finish'), component: StepFinish, - footer: StepChooseCurrencyFooter, + footer: null, onBack: null, - hideFooter: false, + hideFooter: true, }, ] @@ -85,6 +87,8 @@ export type StepProps = { isAppOpened: boolean, transitionTo: StepId => void, setState: any => void, + onClickImport: void => void, + onCloseModal: void => void, // scan process scannedAccounts: Account[], @@ -99,6 +103,11 @@ const mapStateToProps = state => ({ existingAccounts: getAccounts(state), }) +const mapDispatchToProps = { + addAccount, + closeModal, +} + const INITIAL_STATE = { stepId: 'chooseCurrency', isAppOpened: false, @@ -121,6 +130,26 @@ class ImportAccounts extends PureComponent { 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() { const { t, currentDevice, existingAccounts } = this.props const { @@ -152,6 +181,8 @@ class ImportAccounts extends PureComponent { scanStatus, err, isAppOpened, + onClickImport: this.handleClickImport, + onCloseModal: this.handleCloseModal, transitionTo: this.transitionTo, setState: (...args) => this.setState(...args), } @@ -182,4 +213,8 @@ class ImportAccounts extends PureComponent { } } -export default compose(connect(mapStateToProps), translate())(ImportAccounts) +export default compose(connect(mapStateToProps, mapDispatchToProps), translate())(ImportAccounts) + +function idleCallback() { + return new Promise(resolve => window.requestIdleCallback(resolve)) +} diff --git a/src/components/modals/ImportAccounts/steps/03-step-import.js b/src/components/modals/ImportAccounts/steps/03-step-import.js index 05463305..97dbdd68 100644 --- a/src/components/modals/ImportAccounts/steps/03-step-import.js +++ b/src/components/modals/ImportAccounts/steps/03-step-import.js @@ -141,7 +141,7 @@ class StepImport extends PureComponent { {['error', 'finished'].includes(scanStatus) && ( - ) diff --git a/src/components/modals/ImportAccounts/steps/04-step-finish.js b/src/components/modals/ImportAccounts/steps/04-step-finish.js index 1fbd9719..4ee03102 100644 --- a/src/components/modals/ImportAccounts/steps/04-step-finish.js +++ b/src/components/modals/ImportAccounts/steps/04-step-finish.js @@ -3,9 +3,21 @@ import React from 'react' import Box from 'components/base/Box' +import Button from 'components/base/Button' +import IconCheckCircle from 'icons/CheckCircle' -function StepFinish() { - return {'StepFinish'} +function StepFinish({ onCloseModal }: StepProps) { + return ( + + + + + {'Great success!'} + + + ) } export default StepFinish diff --git a/src/helpers/libcore.js b/src/helpers/libcore.js index 1db3b08f..ac42c1e0 100644 --- a/src/helpers/libcore.js +++ b/src/helpers/libcore.js @@ -136,7 +136,8 @@ async function scanNextAccount(props: { ? await wallet.getAccount(accountIndex) : 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) } @@ -214,16 +215,6 @@ async function buildAccountRaw({ // $FlowFixMe ops: NJSOperation[], }): Promise { - /* - const balanceByDay = ops.length - ? await getBalanceByDaySinceOperation({ - njsAccount, - njsOperation: ops[0], - core, - }) - : {} - */ - const njsBalance = await njsAccount.getBalance() const balance = njsBalance.toLong() @@ -269,7 +260,7 @@ async function buildAccountRaw({ freshAddressPath, balance, blockHeight, - archived: true, + archived: false, index: accountIndex, operations, pendingOperations: [], @@ -318,48 +309,3 @@ function buildOperationRaw({ 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() - ) -} -*/ diff --git a/static/i18n/en/importAccounts.yml b/static/i18n/en/importAccounts.yml index 0fbb3e0c..9e44b2a8 100644 --- a/static/i18n/en/importAccounts.yml +++ b/static/i18n/en/importAccounts.yml @@ -3,4 +3,4 @@ breadcrumb: informations: Informations connectDevice: Connect device import: Import - finish: Confirm + finish: End