From 49ac12f2c3ceb20f457d2b976474e3e2571f4c3d Mon Sep 17 00:00:00 2001 From: Shadab Khan Date: Wed, 4 Jan 2023 20:27:41 +0530 Subject: [PATCH] fix(bridge): multiple message processed toasts --- packages/bridge-ui/src/App.svelte | 21 ++++++++++++++++++--- 1 file changed, 18 insertions(+), 3 deletions(-) diff --git a/packages/bridge-ui/src/App.svelte b/packages/bridge-ui/src/App.svelte index 88f0dacfb5d..4eedd15104b 100644 --- a/packages/bridge-ui/src/App.svelte +++ b/packages/bridge-ui/src/App.svelte @@ -157,16 +157,29 @@ }); }); + const transactionToIntervalMap = new Map(); + transactions.subscribe((store) => { if (store) { store.forEach(async (tx) => { - if (tx.interval) clearInterval(tx.interval); + const txInterval = transactionToIntervalMap.get(tx.ethersTx.hash); + if (txInterval) { + clearInterval(txInterval); + transactionToIntervalMap.delete(tx.ethersTx.hash); + } if (tx.status === MessageStatus.New) { const provider = providerMap.get(tx.toChainId); + const interval = setInterval(async () => { - tx.interval = interval; + const txInterval = transactionToIntervalMap.get(tx.ethersTx.hash); + if (txInterval !== interval) { + clearInterval(txInterval); + transactionToIntervalMap.delete(tx.ethersTx.hash); + } + + transactionToIntervalMap.set(tx.ethersTx.hash, interval); if (!tx.signal) return; const contract = new ethers.Contract( @@ -180,7 +193,9 @@ if (messageStatus === MessageStatus.Done) { successToast("Bridge message processed successfully"); - clearInterval(tx.interval); + const txOngoingInterval = transactionToIntervalMap.get(tx.ethersTx.hash); + clearInterval(txOngoingInterval); + transactionToIntervalMap.delete(tx.ethersTx.hash); } }, 20 * 1000); }