From 29a6880f7341410a7423a573ce977ae7ea325aa4 Mon Sep 17 00:00:00 2001 From: meriadec Date: Wed, 18 Apr 2018 14:45:08 +0200 Subject: [PATCH] Ability to change settings by currency --- .../SettingsPage/sections/Currencies.js | 92 ++++++++++++++++++- src/reducers/settings.js | 1 + src/types/common.js | 15 +++ 3 files changed, 103 insertions(+), 5 deletions(-) diff --git a/src/components/SettingsPage/sections/Currencies.js b/src/components/SettingsPage/sections/Currencies.js index 92cf36a1..22e6f72d 100644 --- a/src/components/SettingsPage/sections/Currencies.js +++ b/src/components/SettingsPage/sections/Currencies.js @@ -5,9 +5,10 @@ import React, { PureComponent } from 'react' import { listCurrencies } 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 StepperNumber from 'components/base/StepperNumber' import IconCurrencies from 'icons/Currencies' @@ -18,7 +19,29 @@ import { SettingsSectionRow as Row, } 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 = { + settings: Settings, + saveSettings: Function, t: T, } @@ -31,30 +54,89 @@ class TabCurrencies extends PureComponent { 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 }) + 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() { const { t } = this.props const { currency } = this.state + const { confirmationsToSpend, confirmationsNb } = + this.getCurrencySettings() || CURRENCY_DEFAULTS_SETTINGS return ( -
+
} title={t('settings:tabs.currencies')} desc="Lorem ipsum dolor sit amet" renderRight={ - + } /> + > + + + > + + // -------------------- Settings +export type CurrencySettings = { + coinType: number, + + confirmationsToSpend: number, + minConfirmationsToSpend: number, + maxConfirmationsToSpend: number, + + confirmationsNb: number, + minConfirmationsNb: number, + maxConfirmationsNb: number, + + transactionFees: number, +} + export type Settings = { language: string, username: string, @@ -20,6 +34,7 @@ export type Settings = { isEnabled: boolean, value: string, }, + currencies: CurrencySettings[], } export type T = (?string, ?Object) => string