Browse Source

Polish code of reducers/accounts

master
Gaëtan Renaudeau 7 years ago
parent
commit
ba3cfd6739
  1. 21
      src/helpers/db.js
  2. 39
      src/reducers/accounts.js
  3. 1
      src/reducers/settings.js

21
src/helpers/db.js

@ -4,7 +4,7 @@ import Store from 'electron-store'
import set from 'lodash/set' import set from 'lodash/set'
import get from 'lodash/get' import get from 'lodash/get'
import { serializeAccounts, deserializeAccounts } from 'reducers/accounts' import { decodeAccountsModel, encodeAccountsModel } from 'reducers/accounts'
type DBKey = 'settings' | 'accounts' | 'countervalues' type DBKey = 'settings' | 'accounts' | 'countervalues'
@ -23,17 +23,20 @@ export function setEncryptionKey(key: DBKey, value?: string) {
encryptionKey[key] = value encryptionKey[key] = value
} }
function middleware(type, key, data: any) { const transforms = {
if (key === 'accounts') { get: {
if (type === 'get') { accounts: decodeAccountsModel,
data = serializeAccounts(data) },
set: {
accounts: encodeAccountsModel,
},
} }
if (type === 'set') { function middleware(type: 'get' | 'set', key: string, data: any) {
data = deserializeAccounts(data) const t = transforms[type][key]
if (t) {
data = t(data)
} }
}
return data return data
} }

39
src/reducers/accounts.js

@ -59,9 +59,7 @@ const handlers: Object = {
// Selectors // Selectors
export function accountsSelector(state: { accounts: AccountsState }): Account[] { export const accountsSelector = (state: { accounts: AccountsState }): Account[] => state.accounts
return state.accounts
}
export const currenciesSelector = createSelector(accountsSelector, accounts => export const currenciesSelector = createSelector(accountsSelector, accounts =>
[...new Set(accounts.map(a => a.currency))].sort((a, b) => a.name.localeCompare(b.name)), [...new Set(accounts.map(a => a.currency))].sort((a, b) => a.name.localeCompare(b.name)),
@ -73,41 +71,16 @@ export const accountSelector = createSelector(
(accounts, accountId) => accounts.find(a => a.id === accountId), (accounts, accountId) => accounts.find(a => a.id === accountId),
) )
export function decodeAccount(account: AccountRaw): Account { export const decodeAccount = (account: AccountRaw): Account =>
return accountModel.decode({ accountModel.decode({
data: account, data: account,
version: accountModel.version, version: accountModel.version,
}) })
}
export function encodeAccount(account: Account): AccountRaw { export const encodeAccount = (account: Account): AccountRaw => accountModel.encode(account).data
return accountModel.encode(account).data
}
// Yeah. `any` should be `AccountRaw[]` but it can also be a map export const decodeAccountsModel = (raws: *) => (raws || []).map(accountModel.decode)
// of wrapped accounts. And as flow is apparently incapable of doing
// such a simple thing, let's put any, right? I don't care.
// FIXME: no it shouldn't. the purpose of DataModel is to contain the version, it's the only way we can run the migration functions
export function serializeAccounts(accounts: any): Account[] {
// ensure that accounts are always wrapped in data key
if (accounts && accounts.length && !accounts[0].data) {
accounts = accounts.map(account => ({ data: account }))
}
return accounts ? accounts.map(accountModel.decode) : []
}
export function deserializeAccounts(accounts: Account[]) { export const encodeAccountsModel = (accounts: *) => (accounts || []).map(accountModel.encode)
return accounts.map(account => {
// as account can be passed by main process, the Date types
// can be converted to string. we ensure here that we have real
// date
// FIXME Account shouldn't be passed by main process. only AccountRaw should be!
if (typeof account.lastSyncDate === 'string') {
account.lastSyncDate = new Date(account.lastSyncDate)
}
return accountModel.encode(account)
})
}
export default handleActions(handlers, state) export default handleActions(handlers, state)

1
src/reducers/settings.js

@ -76,7 +76,6 @@ const INITIAL_STATE: SettingsState = {
} }
function asCryptoCurrency(c: Currency): ?CryptoCurrency { function asCryptoCurrency(c: Currency): ?CryptoCurrency {
// $FlowFixMe
return 'id' in c ? c : null return 'id' in c ? c : null
} }

Loading…
Cancel
Save