Browse Source

Ability to change settings by currency

master
meriadec 7 years ago
parent
commit
29a6880f73
No known key found for this signature in database GPG Key ID: 1D2FC2305E2CB399
  1. 88
      src/components/SettingsPage/sections/Currencies.js
  2. 1
      src/reducers/settings.js
  3. 15
      src/types/common.js

88
src/components/SettingsPage/sections/Currencies.js

@ -5,9 +5,10 @@ import React, { PureComponent } from 'react'
import { listCurrencies } from '@ledgerhq/currencies' import { listCurrencies } from '@ledgerhq/currencies'
import type { Currency } from '@ledgerhq/currencies' import type { Currency } from '@ledgerhq/currencies'
import type { T } from 'types/common' import type { Settings, CurrencySettings, T } from 'types/common'
import SelectCurrency from 'components/SelectCurrency' import SelectCurrency from 'components/SelectCurrency'
import StepperNumber from 'components/base/StepperNumber'
import IconCurrencies from 'icons/Currencies' import IconCurrencies from 'icons/Currencies'
@ -18,7 +19,29 @@ import {
SettingsSectionRow as Row, SettingsSectionRow as Row,
} from '../SettingsSection' } from '../SettingsSection'
// .
// /!\ Please note that this will likely not be like that in the future.
// I guess that all currencies should have those settings inside them
// instead of using same default for all.
//
const CURRENCY_DEFAULTS_SETTINGS: CurrencySettings = {
// will be overwritten
coinType: 0,
confirmationsToSpend: 10,
minConfirmationsToSpend: 10,
maxConfirmationsToSpend: 50,
confirmationsNb: 10,
minConfirmationsNb: 10,
maxConfirmationsNb: 50,
transactionFees: 10,
}
type Props = { type Props = {
settings: Settings,
saveSettings: Function,
t: T, t: T,
} }
@ -31,30 +54,89 @@ class TabCurrencies extends PureComponent<Props, State> {
currency: listCurrencies()[0], currency: listCurrencies()[0],
} }
getCurrencySettings() {
const { settings } = this.props
const { currency } = this.state
return settings.currencies.find(c => c.coinType === currency.coinType)
}
handleChangeCurrency = (currency: Currency) => this.setState({ currency }) handleChangeCurrency = (currency: Currency) => this.setState({ currency })
handleChangeConfirmationsToSpend = (nb: number) =>
this.updateCurrencySetting('confirmationsToSpend', nb)
handleChangeConfirmationsNb = (nb: number) => this.updateCurrencySetting('confirmationsNb', nb)
updateCurrencySetting = (key: string, val: number) => {
const { settings, saveSettings } = this.props
const { currency } = this.state
const currencySettings = this.getCurrencySettings()
let newCurrenciesSettings = []
if (!currencySettings) {
newCurrenciesSettings = [
...settings.currencies,
{
...CURRENCY_DEFAULTS_SETTINGS,
coinType: currency.coinType,
[key]: val,
},
]
} else {
newCurrenciesSettings = settings.currencies.map(c => {
if (c.coinType !== currency.coinType) {
return c
}
return { ...c, [key]: val }
})
}
saveSettings({ currencies: newCurrenciesSettings })
}
render() { render() {
const { t } = this.props const { t } = this.props
const { currency } = this.state const { currency } = this.state
const { confirmationsToSpend, confirmationsNb } =
this.getCurrencySettings() || CURRENCY_DEFAULTS_SETTINGS
return ( return (
<Section> <Section key={currency.coinType}>
<Header <Header
icon={<IconCurrencies size={16} />} icon={<IconCurrencies size={16} />}
title={t('settings:tabs.currencies')} title={t('settings:tabs.currencies')}
desc="Lorem ipsum dolor sit amet" desc="Lorem ipsum dolor sit amet"
renderRight={ renderRight={
<SelectCurrency small value={currency} onChange={this.handleChangeCurrency} /> <SelectCurrency
style={{ minWidth: 200 }}
small
value={currency}
onChange={this.handleChangeCurrency}
/>
} }
/> />
<Body> <Body>
<Row <Row
title={t('settings:currencies.confirmationsToSpend')} title={t('settings:currencies.confirmationsToSpend')}
desc={t('settings:currencies.confirmationsToSpendDesc')} desc={t('settings:currencies.confirmationsToSpendDesc')}
>
<StepperNumber
min={10}
max={40}
step={1}
onChange={this.handleChangeConfirmationsToSpend}
value={confirmationsToSpend}
/> />
</Row>
<Row <Row
title={t('settings:currencies.confirmationsNb')} title={t('settings:currencies.confirmationsNb')}
desc={t('settings:currencies.confirmationsNbDesc')} desc={t('settings:currencies.confirmationsNbDesc')}
>
<StepperNumber
min={10}
max={40}
step={1}
onChange={this.handleChangeConfirmationsNb}
value={confirmationsNb}
/> />
</Row>
<Row <Row
title={t('settings:currencies.transactionsFees')} title={t('settings:currencies.transactionsFees')}
desc={t('settings:currencies.transactionsFeesDesc')} desc={t('settings:currencies.transactionsFeesDesc')}

1
src/reducers/settings.js

@ -18,6 +18,7 @@ const defaultState: SettingsState = {
isEnabled: false, isEnabled: false,
value: '', value: '',
}, },
currencies: [],
} }
const state: SettingsState = { const state: SettingsState = {

15
src/types/common.js

@ -12,6 +12,20 @@ export type Devices = Array<Device>
// -------------------- Settings // -------------------- Settings
export type CurrencySettings = {
coinType: number,
confirmationsToSpend: number,
minConfirmationsToSpend: number,
maxConfirmationsToSpend: number,
confirmationsNb: number,
minConfirmationsNb: number,
maxConfirmationsNb: number,
transactionFees: number,
}
export type Settings = { export type Settings = {
language: string, language: string,
username: string, username: string,
@ -20,6 +34,7 @@ export type Settings = {
isEnabled: boolean, isEnabled: boolean,
value: string, value: string,
}, },
currencies: CurrencySettings[],
} }
export type T = (?string, ?Object) => string export type T = (?string, ?Object) => string

Loading…
Cancel
Save