From 680e883eb1c03ea91c2f5870dae382360557ff45 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ga=C3=ABtan=20Renaudeau?= Date: Tue, 25 Sep 2018 17:39:41 +0200 Subject: [PATCH] Make the fees display Standard when it's pending (optimistically) --- src/components/FeesField/BitcoinKind.js | 19 ++++++++++++------- 1 file changed, 12 insertions(+), 7 deletions(-) diff --git a/src/components/FeesField/BitcoinKind.js b/src/components/FeesField/BitcoinKind.js index 88d992fd..7e5f542c 100644 --- a/src/components/FeesField/BitcoinKind.js +++ b/src/components/FeesField/BitcoinKind.js @@ -51,6 +51,12 @@ const customItem = { blockCount: 0, feePerByte: BigNumber(0), } +const notLoadedItem = { + label: 'Standard', + value: 'standard', + blockCount: 0, + feePerByte: BigNumber(0), +} type State = { isFocused: boolean, items: FeeItem[], selectedItem: FeeItem } @@ -58,13 +64,13 @@ type OwnProps = Props & { fees?: Fees, error?: Error } class FeesField extends Component { state = { - items: [customItem], - selectedItem: customItem, + items: [notLoadedItem], + selectedItem: notLoadedItem, isFocused: false, } static getDerivedStateFromProps(nextProps, prevState) { - const { fees, feePerByte } = nextProps + const { fees, feePerByte, error } = nextProps let items: FeeItem[] = [] if (fees) { for (const key of Object.keys(fees)) { @@ -81,10 +87,9 @@ class FeesField extends Component { } items = items.sort((a, b) => a.blockCount - b.blockCount) } - items.push(customItem) - const selectedItem = !feePerByte - ? customItem - : prevState.selectedItem.feePerByte.eq(feePerByte) + items.push(!feePerByte && !error ? notLoadedItem : customItem) + const selectedItem = + !feePerByte && prevState.selectedItem.feePerByte.eq(feePerByte) ? prevState.selectedItem : items.find(f => f.feePerByte.eq(feePerByte)) || items[items.length - 1] return { items, selectedItem }