|
@ -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')} |
|
|