From ec9d8bd02af15f80d0a67968761f6d46373aed9d Mon Sep 17 00:00:00 2001 From: Anastasia Poupeney Date: Thu, 31 May 2018 17:45:01 +0200 Subject: [PATCH 1/2] empty state for the account page, no transactions on dashboard --- .../AccountPage/EmptyStateAccount.js | 58 +++++++ src/components/AccountPage/index.js | 146 ++++++++++-------- src/components/DashboardPage/EmptyState.js | 4 +- src/components/DashboardPage/index.js | 21 ++- src/icons/AccountSettings.js | 16 ++ static/i18n/en/account.yml | 5 + static/images/logos/emptyStateAccount.png | Bin 0 -> 9066 bytes 7 files changed, 174 insertions(+), 76 deletions(-) create mode 100644 src/components/AccountPage/EmptyStateAccount.js create mode 100644 src/icons/AccountSettings.js create mode 100644 static/images/logos/emptyStateAccount.png diff --git a/src/components/AccountPage/EmptyStateAccount.js b/src/components/AccountPage/EmptyStateAccount.js new file mode 100644 index 00000000..e7986f9d --- /dev/null +++ b/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 { + render() { + const { t, account, openModal } = this.props + + return ( + + emptyState Dashboard logo + + {t('account:emptyState.title')} + {t('account:emptyState.desc')} + + + + ) + } +} + +export default compose(connect(null, mapDispatchToProps), translate())(EmptyStateAccount) diff --git a/src/components/AccountPage/index.js b/src/components/AccountPage/index.js index f972c9f7..7bd5c134 100644 --- a/src/components/AccountPage/index.js +++ b/src/components/AccountPage/index.js @@ -1,6 +1,6 @@ // @flow -import React, { PureComponent } from 'react' +import React, { PureComponent, Fragment } from 'react' import { compose } from 'redux' import { connect } from 'react-redux' import { translate } from 'react-i18next' @@ -18,7 +18,7 @@ import { getAccountById } from 'reducers/accounts' import { counterValueCurrencySelector, localeSelector } from 'reducers/settings' import { openModal } from 'reducers/modals' -import IconControls from 'icons/Controls' +import IconAccountSettings from 'icons/AccountSettings' import IconReceive from 'icons/Receive' import IconSend from 'icons/Send' @@ -35,6 +35,7 @@ import PillsDaysCount from 'components/PillsDaysCount' import OperationsList from 'components/OperationsList' import AccountHeader from './AccountHeader' +import EmptyStateAccount from './EmptyStateAccount' const ButtonSettings = styled(Button).attrs({ small: true, @@ -99,78 +100,89 @@ class AccountPage extends PureComponent { - - + {account.operations.length > 0 && ( + + + + + + )} openModal(MODAL_SETTINGS_ACCOUNT, { account })}> - + - - ( - - - - - - - + {account.operations.length > 0 ? ( + + + ( + + + + + + + + + + + + + - - - - - - - )} - /> - - + )} + /> + + + + ) : ( + + )} ) } diff --git a/src/components/DashboardPage/EmptyState.js b/src/components/DashboardPage/EmptyState.js index cb1f2562..48bf8fc8 100644 --- a/src/components/DashboardPage/EmptyState.js +++ b/src/components/DashboardPage/EmptyState.js @@ -64,13 +64,13 @@ class EmptyState extends PureComponent { } } -const Title = styled(Box).attrs({ +export const Title = styled(Box).attrs({ ff: 'Museo Sans|Regular', fontSize: 6, color: p => p.theme.colors.dark, })`` -const Description = styled(Box).attrs({ +export const Description = styled(Box).attrs({ ff: 'Open Sans|Regular', fontSize: 4, color: p => p.theme.colors.graphite, diff --git a/src/components/DashboardPage/index.js b/src/components/DashboardPage/index.js index 3027da19..80343277 100644 --- a/src/components/DashboardPage/index.js +++ b/src/components/DashboardPage/index.js @@ -108,6 +108,11 @@ class DashboardPage extends PureComponent { const timeFrame = this.handleGreeting() const totalAccounts = accounts.length + const displayOperationsHelper = (account: Account) => { + return account.operations.length > 0 + } + const displayOperations = accounts.some(displayOperationsHelper) + return ( {totalAccounts > 0 ? ( @@ -186,13 +191,15 @@ class DashboardPage extends PureComponent { ))} - push(`/account/${account.id}`)} - accounts={accounts} - title={t('dashboard:recentActivity')} - withAccount - /> + {displayOperations && ( + push(`/account/${account.id}`)} + accounts={accounts} + title={t('dashboard:recentActivity')} + withAccount + /> + )} ) : ( diff --git a/src/icons/AccountSettings.js b/src/icons/AccountSettings.js new file mode 100644 index 00000000..3bb3053e --- /dev/null +++ b/src/icons/AccountSettings.js @@ -0,0 +1,16 @@ +// @flow + +import React from 'react' + +const path = ( + +) + +export default ({ size, ...p }: { size: number }) => ( + + {path} + +) diff --git a/static/i18n/en/account.yml b/static/i18n/en/account.yml index 66126329..be9e4d8a 100644 --- a/static/i18n/en/account.yml +++ b/static/i18n/en/account.yml @@ -1,6 +1,11 @@ balance: Balance receive: Receive 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: title: Edit Account accountName: diff --git a/static/images/logos/emptyStateAccount.png b/static/images/logos/emptyStateAccount.png new file mode 100644 index 0000000000000000000000000000000000000000..094ab0517a8a70a7752c4bce4e6ba08c0fa41bce GIT binary patch literal 9066 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 Date: Thu, 31 May 2018 17:59:05 +0200 Subject: [PATCH 2/2] resolve lint issues --- src/components/AccountPage/EmptyStateAccount.js | 1 - src/components/DashboardPage/index.js | 4 +--- 2 files changed, 1 insertion(+), 4 deletions(-) diff --git a/src/components/AccountPage/EmptyStateAccount.js b/src/components/AccountPage/EmptyStateAccount.js index e7986f9d..0cc89db6 100644 --- a/src/components/AccountPage/EmptyStateAccount.js +++ b/src/components/AccountPage/EmptyStateAccount.js @@ -2,7 +2,6 @@ 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' diff --git a/src/components/DashboardPage/index.js b/src/components/DashboardPage/index.js index 80343277..fc7b970c 100644 --- a/src/components/DashboardPage/index.js +++ b/src/components/DashboardPage/index.js @@ -108,9 +108,7 @@ class DashboardPage extends PureComponent { const timeFrame = this.handleGreeting() const totalAccounts = accounts.length - const displayOperationsHelper = (account: Account) => { - return account.operations.length > 0 - } + const displayOperationsHelper = (account: Account) => account.operations.length > 0 const displayOperations = accounts.some(displayOperationsHelper) return (