Browse Source

Merge pull request #85 from loeck/master

Add orderAccounts
master
Loëck Vézien 7 years ago
committed by GitHub
parent
commit
52610e8dc1
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 43
      src/actions/accounts.js
  2. 4
      src/actions/settings.js
  3. 48
      src/components/DevToolbar.js
  4. 69
      src/components/SettingsPage/Display.js
  5. 24
      src/components/SettingsPage/index.js
  6. 6
      src/reducers/settings.js
  7. 1
      src/types/common.js
  8. 7
      static/i18n/en/translation.yml
  9. 7
      static/i18n/fr/translation.yml

43
src/actions/accounts.js

@ -1,9 +1,27 @@
// @flow // @flow
import db from 'helpers/db' import db from 'helpers/db'
import sortBy from 'lodash/sortBy'
import type { Dispatch } from 'redux'
import type { Account } from 'types/common' import type { Account } from 'types/common'
function sortAccounts(accounts, orderAccounts) {
const accountsSorted = sortBy(accounts, a => {
if (orderAccounts === 'balance') {
return a.data.balance
}
return a[orderAccounts]
})
if (orderAccounts === 'balance') {
accountsSorted.reverse()
}
return accountsSorted
}
export type AddAccount = Account => { type: string, payload: Account } export type AddAccount = Account => { type: string, payload: Account }
export const addAccount: AddAccount = payload => ({ export const addAccount: AddAccount = payload => ({
type: 'DB:ADD_ACCOUNT', type: 'DB:ADD_ACCOUNT',
@ -16,11 +34,24 @@ export const updateAccount: AddAccount = payload => ({
payload, payload,
}) })
type FetchAccounts = () => { type: string } export type FetchAccounts = () => (Dispatch<*>, Function) => void
export const fetchAccounts: FetchAccounts = () => { export const fetchAccounts: FetchAccounts = () => (dispatch, getState) => {
const payload = db.get('accounts') const { settings: { orderAccounts } } = getState()
return { const accounts = db.get('accounts')
dispatch({
type: 'SET_ACCOUNTS', type: 'SET_ACCOUNTS',
payload, payload: sortAccounts(accounts, orderAccounts),
} })
}
export type UpdateOrderAccounts = string => (Dispatch<*>, Function) => void
export const updateOrderAccounts: UpdateOrderAccounts = (orderAccounts: string) => (
dispatch,
getState,
) => {
const { accounts } = getState()
dispatch({
type: 'DB:SET_ACCOUNTS',
payload: sortAccounts(accounts, orderAccounts),
})
} }

4
src/actions/settings.js

@ -2,6 +2,7 @@
import db from 'helpers/db' import db from 'helpers/db'
import type { Dispatch } from 'redux'
import type { Settings } from 'types/common' import type { Settings } from 'types/common'
export type SaveSettings = Settings => { type: string, payload: Settings } export type SaveSettings = Settings => { type: string, payload: Settings }
@ -10,7 +11,8 @@ export const saveSettings: SaveSettings = payload => ({
payload, payload,
}) })
export const fetchSettings: Function = () => dispatch => { type FetchSettings = () => (Dispatch<*>) => void
export const fetchSettings: FetchSettings = () => dispatch => {
const settings = db.get('settings') const settings = db.get('settings')
if (Object.keys(settings).length === 0) { if (Object.keys(settings).length === 0) {
return return

48
src/components/DevToolbar.js

@ -195,30 +195,32 @@ class DevToolbar extends PureComponent<any, State> {
</GrowScroll> </GrowScroll>
</Box> </Box>
<Box flow={10}> <Box flow={10}>
{Object.keys(cpuUsage).map(k => ( {Object.keys(cpuUsage)
<Box key={k} grow> .sort()
<Box horizontal align="center"> .map(k => (
<Box grow>{k}</Box> <Box key={k} grow>
<Box fontSize="8px">{last(cpuUsage[k]).value}%</Box> <Box horizontal align="center">
<Box grow>{k}</Box>
<Box fontSize="8px">{last(cpuUsage[k]).value}%</Box>
</Box>
<Box>
<AreaChart
width={100}
height={40}
data={cpuUsage[k]}
margin={{ top: 10, right: 0, left: 0, bottom: 0 }}
>
<Area
type="monotone"
stroke="#8884d8"
fill="#8884d8"
dataKey="value"
isAnimationActive={false}
/>
</AreaChart>
</Box>
</Box> </Box>
<Box> ))}
<AreaChart
width={100}
height={40}
data={cpuUsage[k]}
margin={{ top: 10, right: 0, left: 0, bottom: 0 }}
>
<Area
type="monotone"
stroke="#8884d8"
fill="#8884d8"
dataKey="value"
isAnimationActive={false}
/>
</AreaChart>
</Box>
</Box>
))}
</Box> </Box>
</Box> </Box>
</Container> </Container>

69
src/components/SettingsPage/Display.js

@ -14,7 +14,6 @@ type InputValue = SettingsDisplay
type Props = { type Props = {
t: T, t: T,
i18n: Object,
settings: SettingsDisplay, settings: SettingsDisplay,
onSaveSettings: Function, onSaveSettings: Function,
} }
@ -26,22 +25,43 @@ class TabProfile extends PureComponent<Props, State> {
state = { state = {
inputValue: { inputValue: {
language: this.props.settings.language, language: this.props.settings.language,
orderAccounts: this.props.settings.orderAccounts,
}, },
} }
getLanguages() { getDatas() {
const { t } = this.props const { t } = this.props
return [ return {
{ languages: [
key: 'en', {
name: t('language.en'), key: 'en',
}, name: t('language.en'),
{ },
key: 'fr', {
name: t('language.fr'), key: 'fr',
}, name: t('language.fr'),
] },
],
orderAccounts: [
{
key: 'custom',
name: t('orderAccounts.custom'),
},
{
key: 'name',
name: t('orderAccounts.name'),
},
{
key: 'balance',
name: t('orderAccounts.balance'),
},
{
key: 'type',
name: t('orderAccounts.type'),
},
],
}
} }
handleChangeInput = (key: $Keys<InputValue>) => (value: $Values<InputValue>) => handleChangeInput = (key: $Keys<InputValue>) => (value: $Values<InputValue>) =>
@ -55,24 +75,22 @@ class TabProfile extends PureComponent<Props, State> {
handleSubmit = (e: SyntheticEvent<HTMLFormElement>) => { handleSubmit = (e: SyntheticEvent<HTMLFormElement>) => {
e.preventDefault() e.preventDefault()
const { onSaveSettings, i18n } = this.props const { onSaveSettings } = this.props
const { inputValue } = this.state const { inputValue } = this.state
const settings = { onSaveSettings({
language: inputValue.language, ...inputValue,
} })
i18n.changeLanguage(settings.language)
onSaveSettings(settings)
} }
render() { render() {
const { t } = this.props const { t } = this.props
const { inputValue } = this.state const { inputValue } = this.state
const languages = this.getLanguages() const { languages, orderAccounts } = this.getDatas()
const currentLanguage = languages.find(l => l.key === inputValue.language) const currentLanguage = languages.find(l => l.key === inputValue.language)
const currentOrderAccounts = orderAccounts.find(l => l.key === inputValue.orderAccounts)
return ( return (
<form onSubmit={this.handleSubmit}> <form onSubmit={this.handleSubmit}>
@ -86,6 +104,15 @@ class TabProfile extends PureComponent<Props, State> {
items={languages} items={languages}
/> />
</Box> </Box>
<Box flow={1}>
<Label>{t('settings.display.orderAccounts')}</Label>
<Select
onChange={item => this.handleChangeInput('orderAccounts')(item.key)}
renderSelected={item => item && item.name}
value={currentOrderAccounts}
items={orderAccounts}
/>
</Box>
<Box horizontal justify="flex-end"> <Box horizontal justify="flex-end">
<Button primary type="submit"> <Button primary type="submit">
Save Save

24
src/components/SettingsPage/index.js

@ -7,7 +7,10 @@ import { translate } from 'react-i18next'
import type { MapStateToProps } from 'react-redux' import type { MapStateToProps } from 'react-redux'
import type { Settings, T } from 'types/common' import type { Settings, T } from 'types/common'
import type { SaveSettings } from 'actions/settings'
import type { UpdateOrderAccounts } from 'actions/accounts'
import { updateOrderAccounts } from 'actions/accounts'
import { saveSettings } from 'actions/settings' import { saveSettings } from 'actions/settings'
import Box from 'components/base/Box' import Box from 'components/base/Box'
@ -23,12 +26,15 @@ const mapStateToProps: MapStateToProps<*, *, *> = state => ({
const mapDispatchToProps = { const mapDispatchToProps = {
saveSettings, saveSettings,
updateOrderAccounts,
} }
type Props = { type Props = {
t: T, i18n: Object,
saveSettings: SaveSettings,
settings: Settings, settings: Settings,
saveSettings: Function, t: T,
updateOrderAccounts: UpdateOrderAccounts,
} }
type State = { type State = {
@ -42,7 +48,19 @@ class SettingsPage extends PureComponent<Props, State> {
handleChangeTab = (tab: number) => this.setState({ tab }) handleChangeTab = (tab: number) => this.setState({ tab })
handleSaveSettings = settings => this.props.saveSettings(settings) handleSaveSettings = newSettings => {
const { saveSettings, i18n, settings, updateOrderAccounts } = this.props
if (newSettings.language !== settings.language) {
i18n.changeLanguage(newSettings.language)
}
if (newSettings.orderAccounts !== settings.orderAccounts) {
updateOrderAccounts(newSettings.orderAccounts)
}
saveSettings(newSettings)
}
render() { render() {
const { settings, t } = this.props const { settings, t } = this.props

6
src/reducers/settings.js

@ -10,6 +10,7 @@ export type SettingsState = Object
const state: SettingsState = { const state: SettingsState = {
language: 'en', language: 'en',
orderAccounts: 'balance',
password: { password: {
state: false, state: false,
}, },
@ -20,7 +21,10 @@ const handlers: Object = {
...state, ...state,
...settings, ...settings,
}), }),
FETCH_SETTINGS: (state: SettingsState, { payload: settings }: { payload: Settings }) => settings, FETCH_SETTINGS: (state: SettingsState, { payload: settings }: { payload: Settings }) => ({
...state,
...settings,
}),
} }
export const hasPassword = (state: Object) => get(state.settings, 'password.state', false) export const hasPassword = (state: Object) => get(state.settings, 'password.state', false)

1
src/types/common.js

@ -45,6 +45,7 @@ export type SettingsProfile = {
} }
export type SettingsDisplay = { export type SettingsDisplay = {
language: string, language: string,
orderAccounts: string,
} }
export type Settings = SettingsProfile & SettingsDisplay export type Settings = SettingsProfile & SettingsDisplay

7
static/i18n/en/translation.yml

@ -8,6 +8,12 @@ language:
en: English en: English
fr: French fr: French
orderAccounts:
custom: Custom
name: By name
balance: By balance
type: By type
sidebar: sidebar:
menu: Menu menu: Menu
accounts: Accounts accounts: Accounts
@ -45,6 +51,7 @@ settings:
display: display:
language: Language language: Language
orderAccounts: Order accounts
SelectAccount: SelectAccount:
placeholder: Select a account placeholder: Select a account

7
static/i18n/fr/translation.yml

@ -8,6 +8,12 @@ language:
en: Anglais en: Anglais
fr: Français fr: Français
orderAccounts:
custom: Personnalisé
name: Par nom
balance: Par solde
type: Par type
sidebar: sidebar:
menu: Menu menu: Menu
accounts: Comptes accounts: Comptes
@ -45,6 +51,7 @@ settings:
display: display:
language: Langage language: Langage
orderAccounts: Ordre des comptes
SelectAccount: SelectAccount:
placeholder: Sélectionner un compte placeholder: Sélectionner un compte

Loading…
Cancel
Save