diff --git a/static/app-strings.json b/static/app-strings.json index c6992f8fe..b071a3446 100644 --- a/static/app-strings.json +++ b/static/app-strings.json @@ -1743,6 +1743,8 @@ "Remove address": "Remove address", "Waiting %sendAmount% BTC": "Waiting %sendAmount% BTC", "Waiting to receive your bitcoin.": "Waiting to receive your bitcoin.", + "Confirming %sendAmount% BTC": "Confirming %sendAmount% BTC", + "Confirming BTC transaction.": "Confirming BTC transaction.", "Sending LBC": "Sending LBC", "Bitcoin received. Sending your LBC.": "Bitcoin received. Sending your LBC.", "Completed": "Completed", diff --git a/ui/component/walletSwap/view.jsx b/ui/component/walletSwap/view.jsx index f6343d169..00039b2c5 100644 --- a/ui/component/walletSwap/view.jsx +++ b/ui/component/walletSwap/view.jsx @@ -29,16 +29,19 @@ const DEBOUNCE_BTC_CHANGE_MS = 400; const INTERNAL_APIS_DOWN = 'internal_apis_down'; const BTC_API_STATUS_PENDING = 'Pending'; const BTC_API_STATUS_PROCESSING = 'Processing'; +const BTC_API_STATUS_CONFIRMING = 'Confirming'; const BTC_API_STATUS_SUCCESS = 'Success'; const BTC_API_STATUS_ERROR = 'Error'; const ACTION_MAIN = 'action_main'; const ACTION_STATUS_PENDING = 'action_pending'; +const ACTION_STATUS_CONFIRMING = 'action_confirming'; const ACTION_STATUS_PROCESSING = 'action_processing'; const ACTION_STATUS_SUCCESS = 'action_success'; const ACTION_PAST_SWAPS = 'action_past_swaps'; const NAG_API_STATUS_PENDING = 'Waiting to receive your bitcoin.'; +const NAG_API_STATUS_CONFIRMING = 'Confirming BTC transaction.'; const NAG_API_STATUS_PROCESSING = 'Bitcoin received. Sending your LBC.'; const NAG_API_STATUS_SUCCESS = 'LBC sent. You should see it in your wallet.'; const NAG_API_STATUS_ERROR = 'An error occurred on the previous swap.'; @@ -165,6 +168,10 @@ function WalletSwap(props: Props) { setAction(ACTION_STATUS_PENDING); setNag({ msg: NAG_API_STATUS_PENDING, type: 'helpful' }); break; + case BTC_API_STATUS_CONFIRMING: + setAction(ACTION_STATUS_CONFIRMING); + setNag({ msg: NAG_API_STATUS_CONFIRMING, type: 'helpful' }); + break; case BTC_API_STATUS_PROCESSING: setAction(ACTION_STATUS_PROCESSING); setNag({ msg: NAG_API_STATUS_PROCESSING, type: 'helpful' }); @@ -274,7 +281,7 @@ function WalletSwap(props: Props) { }); } - function getStatusStr(coinSwap: CoinSwapInfo) { + function getShortStatusStr(coinSwap: CoinSwapInfo) { const status = statusMap[coinSwap.sendAddress]; if (!status) { return '---'; @@ -285,6 +292,9 @@ function WalletSwap(props: Props) { case BTC_API_STATUS_PENDING: msg = __('Waiting %sendAmount% BTC', { sendAmount: coinSwap.sendAmount }); break; + case BTC_API_STATUS_CONFIRMING: + msg = __('Confirming %sendAmount% BTC', { sendAmount: coinSwap.sendAmount }); + break; case BTC_API_STATUS_PROCESSING: msg = __('Sending LBC'); break; @@ -318,13 +328,20 @@ function WalletSwap(props: Props) { switch (action) { case ACTION_MAIN: return actionMain; + case ACTION_STATUS_PENDING: return actionPending; - case ACTION_STATUS_SUCCESS: // fall-through - case ACTION_STATUS_PROCESSING: + + case ACTION_STATUS_CONFIRMING: + return actionConfirmingSend; + + case ACTION_STATUS_PROCESSING: // fall-through + case ACTION_STATUS_SUCCESS: return actionProcessingAndSuccess; + case ACTION_PAST_SWAPS: return actionPastSwaps; + default: if (IS_DEV) throw new Error('Unhandled action: ' + action); return actionMain; @@ -399,6 +416,21 @@ function WalletSwap(props: Props) { > ); + const actionConfirmingSend = ( + <> +