|
|
@ -11,37 +11,61 @@ import { MODAL_SEND, MODAL_RECEIVE, MODAL_SETTINGS_ACCOUNT } from 'constants' |
|
|
|
import type { MapStateToProps } from 'react-redux' |
|
|
|
import type { T, Account } from 'types/common' |
|
|
|
|
|
|
|
import { formatBTC } from 'helpers/format' |
|
|
|
|
|
|
|
import { getAccountById } from 'reducers/accounts' |
|
|
|
import { openModal } from 'reducers/modals' |
|
|
|
|
|
|
|
import Box, { Card } from 'components/base/Box' |
|
|
|
import Button from 'components/base/Button' |
|
|
|
import IconControls from 'icons/Controls' |
|
|
|
import Text from 'components/base/Text' |
|
|
|
import TransactionsList from 'components/TransactionsList' |
|
|
|
import IconArrowUp from 'icons/ArrowUp' |
|
|
|
import IconArrowDown from 'icons/ArrowDown' |
|
|
|
import IconArrowUp from 'icons/ArrowUp' |
|
|
|
|
|
|
|
import BalanceSummary from 'components/BalanceSummary' |
|
|
|
import { |
|
|
|
BalanceTotal, |
|
|
|
BalanceSinceDiff, |
|
|
|
BalanceSincePercent, |
|
|
|
} from 'components/BalanceSummary/BalanceInfos' |
|
|
|
import Box from 'components/base/Box' |
|
|
|
import Button from 'components/base/Button' |
|
|
|
import FormattedVal from 'components/base/FormattedVal' |
|
|
|
import PillsDaysCount from 'components/PillsDaysCount' |
|
|
|
import TransactionsList from 'components/TransactionsList' |
|
|
|
|
|
|
|
import AccountHeader from './AccountHeader' |
|
|
|
|
|
|
|
const mapStateToProps: MapStateToProps<*, *, *> = (state, props) => ({ |
|
|
|
account: getAccountById(state, props.match.params.id), |
|
|
|
}) |
|
|
|
|
|
|
|
const mapDispatchToProps = { |
|
|
|
openModal, |
|
|
|
} |
|
|
|
|
|
|
|
type Props = { |
|
|
|
t: T, |
|
|
|
account?: Account, |
|
|
|
openModal: Function, |
|
|
|
} |
|
|
|
|
|
|
|
const mapStateToProps: MapStateToProps<*, *, *> = (state, props) => ({ |
|
|
|
account: getAccountById(state, props.match.params.id), |
|
|
|
}) |
|
|
|
type State = { |
|
|
|
selectedTime: string, |
|
|
|
daysCount: number, |
|
|
|
} |
|
|
|
|
|
|
|
const mapDispatchToProps = { |
|
|
|
openModal, |
|
|
|
class AccountPage extends PureComponent<Props, State> { |
|
|
|
state = { |
|
|
|
selectedTime: 'week', |
|
|
|
daysCount: 7, |
|
|
|
} |
|
|
|
|
|
|
|
class AccountPage extends PureComponent<Props> { |
|
|
|
handleChangeSelectedTime = item => |
|
|
|
this.setState({ |
|
|
|
selectedTime: item.key, |
|
|
|
daysCount: item.value, |
|
|
|
}) |
|
|
|
|
|
|
|
render() { |
|
|
|
const { account, openModal, t } = this.props |
|
|
|
const { selectedTime, daysCount } = this.state |
|
|
|
|
|
|
|
// Don't even throw if we jumped in wrong account route
|
|
|
|
if (!account) { |
|
|
@ -49,19 +73,19 @@ class AccountPage extends PureComponent<Props> { |
|
|
|
} |
|
|
|
|
|
|
|
return ( |
|
|
|
<Box flow={7}> |
|
|
|
<Box horizontal> |
|
|
|
<Box> |
|
|
|
<Box horizontal mb={5}> |
|
|
|
<AccountHeader account={account} /> |
|
|
|
<Box horizontal alignItems="center" justifyContent="flex-end" grow flow={2}> |
|
|
|
<Button primary onClick={() => openModal(MODAL_SEND, { account })}> |
|
|
|
<Box horizontal flow={2} alignItems="center"> |
|
|
|
<IconArrowUp height={16} width={16} /> |
|
|
|
<Box horizontal flow={1} alignItems="center"> |
|
|
|
<IconArrowUp width={12} /> |
|
|
|
<Box>{t('send:title')}</Box> |
|
|
|
</Box> |
|
|
|
</Button> |
|
|
|
<Button primary onClick={() => openModal(MODAL_RECEIVE, { account })}> |
|
|
|
<Box horizontal flow={2} alignItems="center"> |
|
|
|
<IconArrowDown height={16} width={16} /> |
|
|
|
<Box horizontal flow={1} alignItems="center"> |
|
|
|
<IconArrowDown width={12} /> |
|
|
|
<Box>{t('receive:title')}</Box> |
|
|
|
</Box> |
|
|
|
</Button> |
|
|
@ -75,9 +99,55 @@ class AccountPage extends PureComponent<Props> { |
|
|
|
</Button> |
|
|
|
</Box> |
|
|
|
</Box> |
|
|
|
<Card style={{ height: 435 }} alignItems="center" justifyContent="center"> |
|
|
|
<Text fontSize={5}>{formatBTC(account.balance)}</Text> |
|
|
|
</Card> |
|
|
|
<Box mb={7}> |
|
|
|
<BalanceSummary |
|
|
|
chartColor={account.currency.color} |
|
|
|
chartId={`account-chart-${account.id}`} |
|
|
|
accounts={[account]} |
|
|
|
selectedTime={selectedTime} |
|
|
|
daysCount={daysCount} |
|
|
|
renderHeader={({ totalBalance, sinceBalance }) => ( |
|
|
|
<Box flow={4} mb={2}> |
|
|
|
<Box horizontal> |
|
|
|
<BalanceTotal totalBalance={account.balance} unit={account.unit}> |
|
|
|
<Box mt={1}> |
|
|
|
<FormattedVal |
|
|
|
alwaysShowSign={false} |
|
|
|
color="warmGrey" |
|
|
|
fiat="USD" |
|
|
|
fontSize={6} |
|
|
|
showCode |
|
|
|
style={{ lineHeight: 1 }} |
|
|
|
val={totalBalance} |
|
|
|
/> |
|
|
|
</Box> |
|
|
|
</BalanceTotal> |
|
|
|
<Box> |
|
|
|
<PillsDaysCount |
|
|
|
selectedTime={selectedTime} |
|
|
|
onChange={this.handleChangeSelectedTime} |
|
|
|
/> |
|
|
|
</Box> |
|
|
|
</Box> |
|
|
|
<Box horizontal justifyContent="center" flow={7}> |
|
|
|
<BalanceSincePercent |
|
|
|
alignItems="center" |
|
|
|
totalBalance={totalBalance} |
|
|
|
sinceBalance={sinceBalance} |
|
|
|
since={selectedTime} |
|
|
|
/> |
|
|
|
<BalanceSinceDiff |
|
|
|
fiat="USD" |
|
|
|
alignItems="center" |
|
|
|
totalBalance={totalBalance} |
|
|
|
sinceBalance={sinceBalance} |
|
|
|
since={selectedTime} |
|
|
|
/> |
|
|
|
</Box> |
|
|
|
</Box> |
|
|
|
)} |
|
|
|
/> |
|
|
|
</Box> |
|
|
|
<TransactionsList |
|
|
|
title={t('account:lastOperations')} |
|
|
|
transactions={account.transactions} |
|
|
|