|
@ -5,7 +5,6 @@ import { compose } from 'redux' |
|
|
import { translate } from 'react-i18next' |
|
|
import { translate } from 'react-i18next' |
|
|
import { connect } from 'react-redux' |
|
|
import { connect } from 'react-redux' |
|
|
import { push } from 'react-router-redux' |
|
|
import { push } from 'react-router-redux' |
|
|
import chunk from 'lodash/chunk' |
|
|
|
|
|
import { createStructuredSelector } from 'reselect' |
|
|
import { createStructuredSelector } from 'reselect' |
|
|
|
|
|
|
|
|
import type { Account, Currency } from '@ledgerhq/live-common/lib/types' |
|
|
import type { Account, Currency } from '@ledgerhq/live-common/lib/types' |
|
@ -51,36 +50,17 @@ type Props = { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
type State = { |
|
|
type State = { |
|
|
accountsChunk: Array<Array<?Account>>, |
|
|
|
|
|
selectedTime: string, |
|
|
selectedTime: string, |
|
|
daysCount: number, |
|
|
daysCount: number, |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
const ACCOUNTS_BY_LINE = 3 |
|
|
|
|
|
|
|
|
|
|
|
const getAccountsChunk = accounts => { |
|
|
|
|
|
// create shallow copy of accounts, to be mutated
|
|
|
|
|
|
const listAccounts = [...accounts] |
|
|
|
|
|
|
|
|
|
|
|
while (listAccounts.length % ACCOUNTS_BY_LINE !== 0) listAccounts.push(null) |
|
|
|
|
|
|
|
|
|
|
|
return chunk(listAccounts, ACCOUNTS_BY_LINE) |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
class DashboardPage extends PureComponent<Props, State> { |
|
|
class DashboardPage extends PureComponent<Props, State> { |
|
|
state = { |
|
|
state = { |
|
|
accountsChunk: getAccountsChunk(this.props.accounts), |
|
|
|
|
|
selectedTime: 'week', |
|
|
selectedTime: 'week', |
|
|
daysCount: 7, |
|
|
daysCount: 7, |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
componentWillReceiveProps(nextProps) { |
|
|
onAccountClick = account => this.props.push(`/account/${account.id}`) |
|
|
if (nextProps.accounts !== this.props.accounts) { |
|
|
|
|
|
this.setState({ |
|
|
|
|
|
accountsChunk: getAccountsChunk(nextProps.accounts), |
|
|
|
|
|
}) |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
handleGreeting = () => { |
|
|
handleGreeting = () => { |
|
|
const localTimeHour = new Date().getHours() |
|
|
const localTimeHour = new Date().getHours() |
|
@ -104,8 +84,8 @@ class DashboardPage extends PureComponent<Props, State> { |
|
|
_cacheBalance = null |
|
|
_cacheBalance = null |
|
|
|
|
|
|
|
|
render() { |
|
|
render() { |
|
|
const { push, accounts, t, counterValue } = this.props |
|
|
const { accounts, t, counterValue } = this.props |
|
|
const { accountsChunk, selectedTime, daysCount } = this.state |
|
|
const { selectedTime, daysCount } = this.state |
|
|
const timeFrame = this.handleGreeting() |
|
|
const timeFrame = this.handleGreeting() |
|
|
const totalAccounts = accounts.length |
|
|
const totalAccounts = accounts.length |
|
|
|
|
|
|
|
@ -161,31 +141,24 @@ class DashboardPage extends PureComponent<Props, State> { |
|
|
<AccountsOrder /> |
|
|
<AccountsOrder /> |
|
|
</Box> |
|
|
</Box> |
|
|
</Box> |
|
|
</Box> |
|
|
<Box flow={5}> |
|
|
<Box |
|
|
{accountsChunk.map((accountsByLine, i) => ( |
|
|
horizontal |
|
|
<Box |
|
|
flexWrap="wrap" |
|
|
key={i} // eslint-disable-line react/no-array-index-key
|
|
|
justifyContent="flex-start" |
|
|
horizontal |
|
|
alignItems="center" |
|
|
flow={5} |
|
|
style={{ margin: '0 -16px' }} |
|
|
> |
|
|
> |
|
|
{accountsByLine.map( |
|
|
{accounts.concat(Array(3 - accounts.length % 3).fill(null)).map((account, i) => ( |
|
|
(account: any, j) => |
|
|
<Box key={account ? account.id : `placeholder_${i}`} flex="33%" p={16}> |
|
|
account === null ? ( |
|
|
{account ? ( |
|
|
<Box |
|
|
<AccountCard |
|
|
key={j} // eslint-disable-line react/no-array-index-key
|
|
|
key={account.id} |
|
|
p={4} |
|
|
counterValue={counterValue} |
|
|
flex={1} |
|
|
account={account} |
|
|
/> |
|
|
daysCount={daysCount} |
|
|
) : ( |
|
|
onClick={this.onAccountClick} |
|
|
<AccountCard |
|
|
/> |
|
|
counterValue={counterValue} |
|
|
) : null} |
|
|
account={account} |
|
|
|
|
|
daysCount={daysCount} |
|
|
|
|
|
key={account.id} |
|
|
|
|
|
onClick={() => push(`/account/${account.id}`)} |
|
|
|
|
|
/> |
|
|
|
|
|
), |
|
|
|
|
|
)} |
|
|
|
|
|
</Box> |
|
|
</Box> |
|
|
))} |
|
|
))} |
|
|
</Box> |
|
|
</Box> |
|
@ -193,7 +166,7 @@ class DashboardPage extends PureComponent<Props, State> { |
|
|
{displayOperations && ( |
|
|
{displayOperations && ( |
|
|
<OperationsList |
|
|
<OperationsList |
|
|
canShowMore |
|
|
canShowMore |
|
|
onAccountClick={account => push(`/account/${account.id}`)} |
|
|
onAccountClick={this.onAccountClick} |
|
|
accounts={accounts} |
|
|
accounts={accounts} |
|
|
title={t('dashboard:recentActivity')} |
|
|
title={t('dashboard:recentActivity')} |
|
|
withAccount |
|
|
withAccount |
|
|