Browse Source

Merge pull request #314 from NastiaS/greetingsBranch

Greetings branch
master
Gaëtan Renaudeau 7 years ago
committed by GitHub
parent
commit
17f7ac1b94
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 21
      src/components/DashboardPage/index.js
  2. 24
      src/components/SettingsPage/sections/Profile.js
  3. 87
      src/components/TopBar.js
  4. 12
      src/icons/Lock.js
  5. 2
      src/reducers/settings.js
  6. 1
      src/types/common.js
  7. 5
      static/i18n/en/dashboard.yml

21
src/components/DashboardPage/index.js

@ -36,7 +36,6 @@ import AccountCard from './AccountCard'
import AccountsOrder from './AccountsOrder' import AccountsOrder from './AccountsOrder'
const mapStateToProps = state => ({ const mapStateToProps = state => ({
username: state.settings.username,
accounts: getVisibleAccounts(state), accounts: getVisibleAccounts(state),
counterValue: getCounterValueCode(state), counterValue: getCounterValueCode(state),
settings: state.settings, settings: state.settings,
@ -53,7 +52,6 @@ type Props = {
accounts: Account[], accounts: Account[],
push: Function, push: Function,
counterValue: string, counterValue: string,
username: string,
settings: Settings, settings: Settings,
} }
@ -112,6 +110,19 @@ class DashboardPage extends PureComponent<Props, State> {
} }
} }
handleGreeting = () => {
const localTimeHour = new Date().getHours()
const afternoon_breakpoint = 12
const evening_breakpoint = 17
if (localTimeHour >= afternoon_breakpoint && localTimeHour < evening_breakpoint) {
return 'dashboard:greeting.afternoon'
} else if (localTimeHour >= evening_breakpoint) {
return 'dashboard:greeting.evening'
}
return 'dashboard:greeting.morning'
}
handleChangeSelectedTime = item => handleChangeSelectedTime = item =>
this.setState({ this.setState({
selectedTime: item.key, selectedTime: item.key,
@ -121,9 +132,9 @@ class DashboardPage extends PureComponent<Props, State> {
_cacheBalance = null _cacheBalance = null
render() { render() {
const { push, accounts, t, counterValue, username } = this.props const { push, accounts, t, counterValue } = this.props
const { accountsChunk, selectedTime, daysCount } = this.state const { accountsChunk, selectedTime, daysCount } = this.state
const timeFrame = this.handleGreeting()
const totalAccounts = accounts.length const totalAccounts = accounts.length
return ( return (
@ -131,7 +142,7 @@ class DashboardPage extends PureComponent<Props, State> {
<Box horizontal alignItems="flex-end"> <Box horizontal alignItems="flex-end">
<Box grow> <Box grow>
<Text color="dark" ff="Museo Sans" fontSize={7}> <Text color="dark" ff="Museo Sans" fontSize={7}>
{t('dashboard:greetings', { name: username })} {t(timeFrame)}
</Text> </Text>
<Text color="grey" fontSize={5} ff="Museo Sans|Light"> <Text color="grey" fontSize={5} ff="Museo Sans|Light">
{totalAccounts > 0 {totalAccounts > 0

24
src/components/SettingsPage/sections/Profile.js

@ -7,12 +7,9 @@ import bcrypt from 'bcryptjs'
import type { Settings, T } from 'types/common' import type { Settings, T } from 'types/common'
import debounce from 'lodash/debounce'
import { unlock } from 'reducers/application' import { unlock } from 'reducers/application'
import db, { setEncryptionKey } from 'helpers/db' import db, { setEncryptionKey } from 'helpers/db'
import Input from 'components/base/Input'
import CheckBox from 'components/base/CheckBox' import CheckBox from 'components/base/CheckBox'
import Box from 'components/base/Box' import Box from 'components/base/Box'
import Button from 'components/base/Button' import Button from 'components/base/Button'
@ -43,12 +40,10 @@ type State = {
isHardResetModalOpened: boolean, isHardResetModalOpened: boolean,
isPasswordModalOpened: boolean, isPasswordModalOpened: boolean,
isDisablePasswordModalOpened: boolean, isDisablePasswordModalOpened: boolean,
username: string,
} }
class TabProfile extends PureComponent<Props, State> { class TabProfile extends PureComponent<Props, State> {
state = { state = {
username: this.props.settings.username,
isHardResetModalOpened: false, isHardResetModalOpened: false,
isPasswordModalOpened: false, isPasswordModalOpened: false,
isDisablePasswordModalOpened: false, isDisablePasswordModalOpened: false,
@ -69,16 +64,6 @@ class TabProfile extends PureComponent<Props, State> {
}) })
} }
debounceSaveUsername = debounce(
v => this.props.saveSettings({ username: v.trim() || 'Anonymous' }),
250,
)
handleChangeUsername = username => {
this.setState({ username })
this.debounceSaveUsername(username)
}
handleOpenHardResetModal = () => this.setState({ isHardResetModalOpened: true }) handleOpenHardResetModal = () => this.setState({ isHardResetModalOpened: true })
handleCloseHardResetModal = () => this.setState({ isHardResetModalOpened: false }) handleCloseHardResetModal = () => this.setState({ isHardResetModalOpened: false })
handleOpenPasswordModal = () => this.setState({ isPasswordModalOpened: true }) handleOpenPasswordModal = () => this.setState({ isPasswordModalOpened: true })
@ -113,7 +98,6 @@ class TabProfile extends PureComponent<Props, State> {
render() { render() {
const { t, settings } = this.props const { t, settings } = this.props
const { const {
username,
isHardResetModalOpened, isHardResetModalOpened,
isPasswordModalOpened, isPasswordModalOpened,
isDisablePasswordModalOpened, isDisablePasswordModalOpened,
@ -127,14 +111,6 @@ class TabProfile extends PureComponent<Props, State> {
desc="Lorem ipsum dolor sit amet" desc="Lorem ipsum dolor sit amet"
/> />
<Body> <Body>
<Row title={t('settings:profile.username')} desc={t('settings:profile.usernameDesc')}>
<Input
small
placeholder={t('settings:profile.username')}
onChange={this.handleChangeUsername}
value={username}
/>
</Row>
<Row title={t('settings:profile.password')} desc={t('settings:profile.passwordDesc')}> <Row title={t('settings:profile.password')} desc={t('settings:profile.passwordDesc')}>
<Box horizontal flow={2} align="center"> <Box horizontal flow={2} align="center">
{isPasswordEnabled && ( {isPasswordEnabled && (

87
src/components/TopBar.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 { translate } from 'react-i18next' import { translate } from 'react-i18next'
import { connect } from 'react-redux' import { connect } from 'react-redux'
@ -17,11 +17,10 @@ import { lock } from 'reducers/application'
import { hasPassword } from 'reducers/settings' import { hasPassword } from 'reducers/settings'
import IconActivity from 'icons/Activity' import IconActivity from 'icons/Activity'
import IconAngleDown from 'icons/AngleDown'
import IconDevices from 'icons/Devices' import IconDevices from 'icons/Devices'
import IconUser from 'icons/User' import IconLock from 'icons/Lock'
import IconSettings from 'icons/Settings'
import DropDown, { DropDownItem as DDItem } from 'components/base/DropDown'
import Box from 'components/base/Box' import Box from 'components/base/Box'
import GlobalSearch from 'components/GlobalSearch' import GlobalSearch from 'components/GlobalSearch'
@ -65,19 +64,7 @@ const Activity = styled.div`
width: 4px; width: 4px;
` `
const DropDownItem = styled(DDItem).attrs({
horizontal: true,
justifyContent: 'flex-start',
alignItems: 'center',
flow: 3,
ff: 'Open Sans|SemiBold',
px: 2,
})`
height: 35px;
`
const mapStateToProps = state => ({ const mapStateToProps = state => ({
username: state.settings.username,
hasAccounts: getAccounts(state).length > 0, hasAccounts: getAccounts(state).length > 0,
hasPassword: hasPassword(state), hasPassword: hasPassword(state),
}) })
@ -93,7 +80,6 @@ type Props = {
location: Location, location: Location,
lock: Function, lock: Function,
t: T, t: T,
username: string,
} }
type State = { type State = {
@ -150,8 +136,16 @@ class TopBar extends PureComponent<Props, State> {
handleLock = () => this.props.lock() handleLock = () => this.props.lock()
navigateToSettings = () => {
const { location, history } = this.props
const url = '/settings'
if (location.pathname !== url) {
history.push(url)
}
}
render() { render() {
const { location, hasPassword, history, hasAccounts, username, t } = this.props const { hasPassword, hasAccounts, t } = this.props
const { sync } = this.state const { sync } = this.state
return ( return (
@ -169,50 +163,19 @@ class TopBar extends PureComponent<Props, State> {
<Box justifyContent="center"> <Box justifyContent="center">
<Bar /> <Bar />
</Box> </Box>
</Box> <Box justifyContent="center" onClick={this.navigateToSettings}>
<Box horizontal noShrink> <IconSettings size={16} />
<DropDown </Box>
items={[ {hasPassword && (
{ <Fragment>
key: 'profile', <Box justifyContent="center">
label: t('common:editProfile'), <Bar />
icon: <IconUser size={16} />, </Box>
onClick: () => { <Box justifyContent="center" onClick={this.handleLock}>
const url = '/settings/profile' <IconLock size={16} />
</Box>
if (location.pathname !== url) { </Fragment>
history.push(url) )}
}
},
},
...(hasPassword
? [
{
key: 'lock',
label: t('common:lockApplication'),
icon: <IconUser size={16} />,
onClick: this.handleLock,
},
]
: []),
]}
renderItem={({ item, isHighlighted }) => (
<DropDownItem isHighlighted={isHighlighted}>
<Box color={isHighlighted ? 'wallet' : ''}>{item.icon}</Box>
<Box>{item.label}</Box>
</DropDownItem>
)}
alignItems="center"
ff="Open Sans|SemiBold"
flow={1}
fontSize={4}
horizontal
justifyContent="center"
offsetTop={-2}
>
<Box>{username}</Box>
<IconAngleDown size={12} />
</DropDown>
</Box> </Box>
</Inner> </Inner>
</Container> </Container>

12
src/icons/Lock.js

@ -0,0 +1,12 @@
// @flow
import React from 'react'
export default ({ size, ...p }: { size: number }) => (
<svg width={size} height={size} {...p}>
<path
fill="currentColor"
d="M15 7.5v7a1.5 1.5 0 0 1-1.5 1.5h-11A1.5 1.5 0 0 1 1 14.5v-7A1.5 1.5 0 0 1 2.5 6h1V4.5A4.506 4.506 0 0 1 8.012 0C10.5.006 12.5 2.056 12.5 4.544V6h1A1.5 1.5 0 0 1 15 7.5zM5 6h6V4.5c0-1.653-1.347-3-3-3s-3 1.347-3 3V6zm8.5 1.5h-11v7h11v-7z"
/>
</svg>
)

2
src/reducers/settings.js

@ -9,7 +9,6 @@ import type { State } from 'reducers'
export type SettingsState = { export type SettingsState = {
hasCompletedOnboarding: boolean, hasCompletedOnboarding: boolean,
username: string,
counterValue: string, counterValue: string,
language: string, language: string,
orderAccounts: string, orderAccounts: string,
@ -29,7 +28,6 @@ const language = window.navigator.language.split('-')[0]
const defaultState: SettingsState = { const defaultState: SettingsState = {
hasCompletedOnboarding: false, hasCompletedOnboarding: false,
username: 'Anonymous',
counterValue: 'USD', counterValue: 'USD',
language, language,
orderAccounts: 'balance|asc', orderAccounts: 'balance|asc',

1
src/types/common.js

@ -32,7 +32,6 @@ export type Settings = {
hasCompletedOnboarding: boolean, hasCompletedOnboarding: boolean,
language: string, language: string,
orderAccounts: string, orderAccounts: string,
username: string,
counterValue: string, counterValue: string,
password: { password: {
isEnabled: boolean, isEnabled: boolean,

5
static/i18n/en/dashboard.yml

@ -1,5 +1,8 @@
title: Dashboard title: Dashboard
greetings: 'Good morning, {{name}}.' greeting:
morning: "Good Morning!"
evening: "Good Evening!"
afternoon: "Good Afternoon!"
summary: here is the summary of your account summary: here is the summary of your account
summary_plural: 'here is the summary of your {{count}} accounts' summary_plural: 'here is the summary of your {{count}} accounts'
noAccounts: no accounts noAccounts: no accounts

Loading…
Cancel
Save