Browse Source

empty state for the account page, no transactions on dashboard

master
Anastasia Poupeney 7 years ago
parent
commit
ec9d8bd02a
  1. 58
      src/components/AccountPage/EmptyStateAccount.js
  2. 18
      src/components/AccountPage/index.js
  3. 4
      src/components/DashboardPage/EmptyState.js
  4. 7
      src/components/DashboardPage/index.js
  5. 16
      src/icons/AccountSettings.js
  6. 5
      static/i18n/en/account.yml
  7. BIN
      static/images/logos/emptyStateAccount.png

58
src/components/AccountPage/EmptyStateAccount.js

@ -0,0 +1,58 @@
// @flow
import React, { PureComponent } from 'react'
import { i } from 'helpers/staticPath'
import styled from 'styled-components'
import { connect } from 'react-redux'
import { compose } from 'redux'
import { translate } from 'react-i18next'
import { openModal } from 'reducers/modals'
import type { T } from 'types/common'
import type { Account } from '@ledgerhq/live-common/lib/types'
import { MODAL_RECEIVE } from 'config/constants'
import Box from 'components/base/Box'
import Button from 'components/base/Button'
import { Title, Description } from 'components/DashboardPage/EmptyState'
import IconReceive from 'icons/Receive'
const mapDispatchToProps = {
openModal,
}
type Props = {
t: T,
account: Account,
openModal: Function,
}
class EmptyStateAccount extends PureComponent<Props, *> {
render() {
const { t, account, openModal } = this.props
return (
<Box mt={7} alignItems="center">
<img
alt="emptyState Dashboard logo"
src={i('logos/emptyStateAccount.png')}
width="400"
height="89"
/>
<Box mt={5} alignItems="center">
<Title>{t('account:emptyState.title')}</Title>
<Description>{t('account:emptyState.desc')}</Description>
<Button mt={3} padded primary onClick={() => openModal(MODAL_RECEIVE, { account })}>
<Box horizontal flow={1} alignItems="center">
<IconReceive size={12} />
<Box>{t('account:emptyState.buttons.receiveFunds')}</Box>
</Box>
</Button>
</Box>
</Box>
)
}
}
export default compose(connect(null, mapDispatchToProps), translate())(EmptyStateAccount)

18
src/components/AccountPage/index.js

@ -1,6 +1,6 @@
// @flow // @flow
import React, { PureComponent } from 'react' import React, { PureComponent, Fragment } from 'react'
import { compose } from 'redux' import { compose } from 'redux'
import { connect } from 'react-redux' import { connect } from 'react-redux'
import { translate } from 'react-i18next' import { translate } from 'react-i18next'
@ -18,7 +18,7 @@ import { getAccountById } from 'reducers/accounts'
import { counterValueCurrencySelector, localeSelector } from 'reducers/settings' import { counterValueCurrencySelector, localeSelector } from 'reducers/settings'
import { openModal } from 'reducers/modals' import { openModal } from 'reducers/modals'
import IconControls from 'icons/Controls' import IconAccountSettings from 'icons/AccountSettings'
import IconReceive from 'icons/Receive' import IconReceive from 'icons/Receive'
import IconSend from 'icons/Send' import IconSend from 'icons/Send'
@ -35,6 +35,7 @@ import PillsDaysCount from 'components/PillsDaysCount'
import OperationsList from 'components/OperationsList' import OperationsList from 'components/OperationsList'
import AccountHeader from './AccountHeader' import AccountHeader from './AccountHeader'
import EmptyStateAccount from './EmptyStateAccount'
const ButtonSettings = styled(Button).attrs({ const ButtonSettings = styled(Button).attrs({
small: true, small: true,
@ -99,25 +100,32 @@ class AccountPage extends PureComponent<Props, State> {
<Box horizontal mb={5}> <Box horizontal mb={5}>
<AccountHeader account={account} /> <AccountHeader account={account} />
<Box horizontal alignItems="center" justifyContent="flex-end" grow flow={2}> <Box horizontal alignItems="center" justifyContent="flex-end" grow flow={2}>
{account.operations.length > 0 && (
<Fragment>
<Button small primary onClick={() => openModal(MODAL_SEND, { account })}> <Button small primary onClick={() => openModal(MODAL_SEND, { account })}>
<Box horizontal flow={1} alignItems="center"> <Box horizontal flow={1} alignItems="center">
<IconSend size={12} /> <IconSend size={12} />
<Box>{t('send:title')}</Box> <Box>{t('send:title')}</Box>
</Box> </Box>
</Button> </Button>
<Button small primary onClick={() => openModal(MODAL_RECEIVE, { account })}> <Button small primary onClick={() => openModal(MODAL_RECEIVE, { account })}>
<Box horizontal flow={1} alignItems="center"> <Box horizontal flow={1} alignItems="center">
<IconReceive size={12} /> <IconReceive size={12} />
<Box>{t('receive:title')}</Box> <Box>{t('receive:title')}</Box>
</Box> </Box>
</Button> </Button>
</Fragment>
)}
<ButtonSettings onClick={() => openModal(MODAL_SETTINGS_ACCOUNT, { account })}> <ButtonSettings onClick={() => openModal(MODAL_SETTINGS_ACCOUNT, { account })}>
<Box align="center"> <Box align="center">
<IconControls size={16} /> <IconAccountSettings size={16} />
</Box> </Box>
</ButtonSettings> </ButtonSettings>
</Box> </Box>
</Box> </Box>
{account.operations.length > 0 ? (
<Fragment>
<Box mb={7}> <Box mb={7}>
<BalanceSummary <BalanceSummary
accounts={[account]} accounts={[account]}
@ -171,6 +179,10 @@ class AccountPage extends PureComponent<Props, State> {
/> />
</Box> </Box>
<OperationsList account={account} title={t('account:lastOperations')} /> <OperationsList account={account} title={t('account:lastOperations')} />
</Fragment>
) : (
<EmptyStateAccount account={account} />
)}
</Box> </Box>
) )
} }

4
src/components/DashboardPage/EmptyState.js

@ -64,13 +64,13 @@ class EmptyState extends PureComponent<Props, *> {
} }
} }
const Title = styled(Box).attrs({ export const Title = styled(Box).attrs({
ff: 'Museo Sans|Regular', ff: 'Museo Sans|Regular',
fontSize: 6, fontSize: 6,
color: p => p.theme.colors.dark, color: p => p.theme.colors.dark,
})`` })``
const Description = styled(Box).attrs({ export const Description = styled(Box).attrs({
ff: 'Open Sans|Regular', ff: 'Open Sans|Regular',
fontSize: 4, fontSize: 4,
color: p => p.theme.colors.graphite, color: p => p.theme.colors.graphite,

7
src/components/DashboardPage/index.js

@ -108,6 +108,11 @@ class DashboardPage extends PureComponent<Props, State> {
const timeFrame = this.handleGreeting() const timeFrame = this.handleGreeting()
const totalAccounts = accounts.length const totalAccounts = accounts.length
const displayOperationsHelper = (account: Account) => {
return account.operations.length > 0
}
const displayOperations = accounts.some(displayOperationsHelper)
return ( return (
<Box flow={7}> <Box flow={7}>
{totalAccounts > 0 ? ( {totalAccounts > 0 ? (
@ -186,6 +191,7 @@ class DashboardPage extends PureComponent<Props, State> {
))} ))}
</Box> </Box>
</Box> </Box>
{displayOperations && (
<OperationsList <OperationsList
canShowMore canShowMore
onAccountClick={account => push(`/account/${account.id}`)} onAccountClick={account => push(`/account/${account.id}`)}
@ -193,6 +199,7 @@ class DashboardPage extends PureComponent<Props, State> {
title={t('dashboard:recentActivity')} title={t('dashboard:recentActivity')}
withAccount withAccount
/> />
)}
</Fragment> </Fragment>
</Fragment> </Fragment>
) : ( ) : (

16
src/icons/AccountSettings.js

@ -0,0 +1,16 @@
// @flow
import React from 'react'
const path = (
<path
fill="currentColor"
d="M12.541 4.432l1.51-1.51a.697.697 0 0 1 1.1.152c.94 1.67.744 3.259-.575 4.577-1.153 1.154-2.565 1.502-4.127 1.02a.232.232 0 0 0-.233.057L3.71 15.234a2.09 2.09 0 1 1-2.955-2.956L7.26 5.772c.06-.06.083-.15.057-.232-.483-1.562-.134-2.974 1.02-4.128C9.655.094 11.244-.1 12.914.838a.697.697 0 0 1 .15 1.1l-1.509 1.51.165.82.82.164zM1.74 14.25a.697.697 0 0 0 .985 0l6.506-6.506a1.625 1.625 0 0 1 1.63-.404c1.068.33 1.942.115 2.73-.673.63-.63.862-1.277.702-2.015l-.854.854a1.161 1.161 0 0 1-1.049.318l-1.095-.22a1.161 1.161 0 0 1-.91-.91l-.22-1.094a1.168 1.168 0 0 1 .318-1.05l.855-.854c-.738-.16-1.386.073-2.016.702-.787.788-1.003 1.662-.673 2.73a1.625 1.625 0 0 1-.403 1.63L1.74 13.264a.697.697 0 0 0 0 .986z"
/>
)
export default ({ size, ...p }: { size: number }) => (
<svg viewBox="0 0 16 16" height={size} width={size} {...p}>
{path}
</svg>
)

5
static/i18n/en/account.yml

@ -1,6 +1,11 @@
balance: Balance balance: Balance
receive: Receive receive: Receive
lastOperations: Last operations lastOperations: Last operations
emptyState:
title: This is a title, use it with caution
desc: Please create a new account or recover an old account from your Ledger device.
buttons:
receiveFunds: Receive Funds
settings: settings:
title: Edit Account title: Edit Account
accountName: accountName:

BIN
static/images/logos/emptyStateAccount.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.9 KiB

Loading…
Cancel
Save