From f2d29294137023de2f3af5c7fa4052abd492cc01 Mon Sep 17 00:00:00 2001 From: Memo Khoury Date: Tue, 10 Dec 2024 10:31:07 +0000 Subject: [PATCH 1/7] fix caching. --- .../components/bridge/history/Withdrawal.tsx | 35 +++++++---- .../src/hooks/useBridgeTransfer.ts | 60 +++++++------------ 2 files changed, 45 insertions(+), 50 deletions(-) diff --git a/webapps/world-builder-dashboard/src/components/bridge/history/Withdrawal.tsx b/webapps/world-builder-dashboard/src/components/bridge/history/Withdrawal.tsx index ce70c811..37db3168 100644 --- a/webapps/world-builder-dashboard/src/components/bridge/history/Withdrawal.tsx +++ b/webapps/world-builder-dashboard/src/components/bridge/history/Withdrawal.tsx @@ -216,9 +216,14 @@ const Withdrawal: React.FC = ({ withdrawal }) => {
Initiate
{timeAgo(withdrawal?.highNetworkTimestamp)}
-
{`${transactionInputs?.tokenSymbol === 'USDC' ? ethers.utils.formatUnits(transactionInputs?.amount, 6) : withdrawal.amount} ${transactionInputs?.tokenSymbol}`}
+ {!transactionInputs?.tokenSymbol ? ( +
+
Loading
+
+ ) : ( +
{`${transactionInputs.tokenSymbol === 'USDC' ? ethers.utils.formatUnits(transactionInputs.amount, 6) : withdrawal.amount} ${transactionInputs.tokenSymbol}`}
+ )}
{status?.data?.from ?? ''}
{status?.data?.to ?? ''}
@@ -240,10 +245,14 @@ const Withdrawal: React.FC = ({ withdrawal }) => {
Finalize
{timeAgo(withdrawal?.completionTimestamp)}
-
{`${transactionInputs?.tokenSymbol === 'USDC' ? ethers.utils.formatUnits(transactionInputs?.amount, 6) : withdrawal.amount} ${transactionInputs?.tokenSymbol}`}
-
{status?.data?.from ?? ''}
+ {!transactionInputs?.tokenSymbol ? ( +
+
Loading
+
+ ) : ( +
{`${transactionInputs.tokenSymbol === 'USDC' ? ethers.utils.formatUnits(transactionInputs.amount, 6) : withdrawal.amount} ${transactionInputs.tokenSymbol}`}
+ )}
{status?.data?.from ?? ''}
{status?.data?.to ?? ''}
= ({ withdrawal }) => {
{timeAgo(status?.data?.timestamp)}
-
{`${transactionInputs?.tokenSymbol === 'USDC' ? ethers.utils.formatUnits(transactionInputs?.amount, 6) : withdrawal.amount} ${transactionInputs?.tokenSymbol}`}
-
{status?.data?.from ?? ''}
+ {!transactionInputs?.tokenSymbol ? ( +
+
Loading
+
+ ) : ( +
{`${transactionInputs.tokenSymbol === 'USDC' ? ethers.utils.formatUnits(transactionInputs.amount, 6) : withdrawal.amount} ${transactionInputs.tokenSymbol}`}
+ )}
{status?.data?.from ?? ''}
{status?.data?.to ?? ''}
{transferStatus && transferStatus?.status === ChildToParentMessageStatus.CONFIRMED && ( <> diff --git a/webapps/world-builder-dashboard/src/hooks/useBridgeTransfer.ts b/webapps/world-builder-dashboard/src/hooks/useBridgeTransfer.ts index 5b7c9662..6a91903e 100644 --- a/webapps/world-builder-dashboard/src/hooks/useBridgeTransfer.ts +++ b/webapps/world-builder-dashboard/src/hooks/useBridgeTransfer.ts @@ -38,7 +38,7 @@ export const useBridgeTransfer = () => { await new Promise((resolve) => setTimeout(resolve, retryDelay)) attempt++ } else { - throw error + throw error // Rethrow error if not 429 or max retries reached } } } @@ -59,19 +59,11 @@ export const useBridgeTransfer = () => { return isPending && timeSinceLastUpdate > 1 * 60 * 1000 } - let transferStatus: any + let status: any return useQuery( ['transferData', txHash], async () => { - const transactions = getCachedTransactions(connectedAccount ?? '', selectedNetworkType) - const cachedTransaction = transactions.find((t: any) => - isDeposit ? t.lowNetworkHash === txRecord.lowNetworkHash : t.highNetworkHash === txRecord.highNetworkHash - ) - - if (cachedTransaction?.status && !shouldFetchStatus(cachedTransaction)) { - return { status: cachedTransaction.status } - } const _bridgeTransfer = new BridgeTransfer({ txHash: txHash ?? '', destinationNetworkChainId: destinationChainId ?? 0, @@ -82,9 +74,9 @@ export const useBridgeTransfer = () => { try { // Fetch status with retry logic - const statusResponse = await retryWithExponentialBackoff(async () => await _bridgeTransfer.getStatus()) - transferStatus = statusResponse + status = await retryWithExponentialBackoff(async () => await _bridgeTransfer.getStatus()) + const transactions = getCachedTransactions(connectedAccount ?? '', selectedNetworkType) // Update the cache with the latest status const newTransactions = transactions.map((t: any) => { @@ -92,7 +84,7 @@ export const useBridgeTransfer = () => { ? t.lowNetworkHash === txRecord.lowNetworkHash : t.highNetworkHash === txRecord.highNetworkHash - return isSameHash ? { ...t, status: statusResponse?.status, lastUpdated: Date.now() } : t + return isSameHash ? { ...t, status: status?.status, lastUpdated: Date.now() } : t }) localStorage.setItem( @@ -100,7 +92,7 @@ export const useBridgeTransfer = () => { JSON.stringify(newTransactions) ) - return statusResponse + return status } catch (error) { console.error('Error fetching status:', error) @@ -111,8 +103,8 @@ export const useBridgeTransfer = () => { ) if (cachedTransaction && cachedTransaction.status !== undefined) { - transferStatus = cachedTransaction.status - return { status: transferStatus, ...cachedTransaction } // Return cached status + status = cachedTransaction.status + return { status } // Return cached status } throw error // Re-throw error if no cache @@ -127,8 +119,8 @@ export const useBridgeTransfer = () => { ) if (cachedTransaction && cachedTransaction.status !== undefined) { - transferStatus = cachedTransaction.status - return { status: transferStatus } + status = cachedTransaction.status + return { status } } }, staleTime: 0.5 * 60 * 1000, @@ -237,21 +229,9 @@ export const useBridgeTransfer = () => { const destinationRpc = getNetworks(selectedNetworkType)?.find((n) => n.chainId === destinationChainId)?.rpcs[0] const originRpc = getNetworks(selectedNetworkType)?.find((n) => n.chainId === originChainId)?.rpcs[0] - return useQuery( ['transactionInputs', txHash], async () => { - // Get fresh cache data - const transactions = getCachedTransactions(connectedAccount ?? '', selectedNetworkType) - const cachedTransaction = transactions.find((t: any) => - isDeposit ? t.lowNetworkHash === txRecord.lowNetworkHash : t.highNetworkHash === txRecord.highNetworkHash - ) - - // Check if we have cached inputs - if (cachedTransaction?.transactionInputs !== undefined) { - return cachedTransaction.transactionInputs - } - const _bridgeTransfer = new BridgeTransfer({ txHash: txHash ?? '', destinationNetworkChainId: destinationChainId ?? 0, @@ -260,17 +240,17 @@ export const useBridgeTransfer = () => { originSignerOrProviderOrRpc: originRpc }) - const transactionInputs = await retryWithExponentialBackoff( - async () => _bridgeTransfer.getInfo() - ) + const transactionInputs = await _bridgeTransfer.getInfo() - // Update cache with new data + const transactions = getCachedTransactions(connectedAccount ?? '', selectedNetworkType) + + // Update the cache with the latest status const newTransactions = transactions.map((t: any) => { const isSameHash = isDeposit ? t.lowNetworkHash === txRecord.lowNetworkHash : t.highNetworkHash === txRecord.highNetworkHash - return isSameHash ? { ...t, transactionInputs: transactionInputs, lastUpdated: Date.now() } : t + return isSameHash ? { ...t, transactionInputs: transactionInputs } : t }) localStorage.setItem( @@ -281,19 +261,21 @@ export const useBridgeTransfer = () => { }, { placeholderData: () => { - // Get fresh cache data for placeholder const transactions = getCachedTransactions(connectedAccount ?? '', selectedNetworkType) const cachedTransaction = transactions.find((t: any) => isDeposit ? t.lowNetworkHash === txRecord.lowNetworkHash : t.highNetworkHash === txRecord.highNetworkHash ) - return cachedTransaction?.transactionInputs + if (cachedTransaction && cachedTransaction.transactionInputs !== undefined) { + return cachedTransaction?.transactionInputs + } }, - staleTime: 30 * 60 * 1000, + staleTime: 2 * 60 * 1000, refetchOnWindowFocus: false, enabled: !!txRecord } ) } + const getHighNetworkTimestamp = ({ txRecord, transferStatus, @@ -346,7 +328,7 @@ export const useBridgeTransfer = () => { return cachedTransaction?.highNetworkTimestamp }, - staleTime: Infinity, + staleTime: 1 * 60 * 1000, refetchInterval: false, refetchOnWindowFocus: false, enabled: !!txRecord && !!transferStatus?.completionTxHash // Run query only if data is valid From a5ed6142661f31ce275f4d3929aedd23da18a39c Mon Sep 17 00:00:00 2001 From: Memo Khoury Date: Tue, 10 Dec 2024 10:40:59 +0000 Subject: [PATCH 2/7] updates --- .../src/components/bridge/history/Deposit.tsx | 6 +-- .../components/bridge/history/Withdrawal.tsx | 41 +++++++++++-------- 2 files changed, 26 insertions(+), 21 deletions(-) diff --git a/webapps/world-builder-dashboard/src/components/bridge/history/Deposit.tsx b/webapps/world-builder-dashboard/src/components/bridge/history/Deposit.tsx index fdbb6d80..20f69890 100644 --- a/webapps/world-builder-dashboard/src/components/bridge/history/Deposit.tsx +++ b/webapps/world-builder-dashboard/src/components/bridge/history/Deposit.tsx @@ -55,13 +55,13 @@ const Deposit: React.FC = ({ deposit }) => {
{timeAgo(deposit.lowNetworkTimestamp)}
- {!transactionInputs?.tokenSymbol ? ( + {transactionInputs?.tokenSymbol ? (
-
Loading
+ {`${transactionInputs.tokenSymbol === 'USDC' ? ethers.utils.formatUnits(transactionInputs.amount, 6) : deposit.amount} ${transactionInputs.tokenSymbol}`}
) : (
- {`${transactionInputs.tokenSymbol === 'USDC' ? ethers.utils.formatUnits(transactionInputs.amount, 6) : deposit.amount} ${transactionInputs.tokenSymbol}`} +
Loading
)}
{depositInfo.from}
diff --git a/webapps/world-builder-dashboard/src/components/bridge/history/Withdrawal.tsx b/webapps/world-builder-dashboard/src/components/bridge/history/Withdrawal.tsx index 37db3168..205554ea 100644 --- a/webapps/world-builder-dashboard/src/components/bridge/history/Withdrawal.tsx +++ b/webapps/world-builder-dashboard/src/components/bridge/history/Withdrawal.tsx @@ -92,13 +92,13 @@ const Withdrawal: React.FC = ({ withdrawal }) => {
{timeAgo(withdrawal.highNetworkTimestamp)}
- {!transactionInputs?.tokenSymbol ? ( + {transactionInputs?.tokenSymbol ? (
-
Loading
+ {`${transactionInputs.tokenSymbol === 'USDC' ? ethers.utils.formatUnits(transactionInputs.amount, 6) : withdrawal.amount} ${transactionInputs.tokenSymbol}`}
) : (
- {`${transactionInputs.tokenSymbol === 'USDC' ? ethers.utils.formatUnits(transactionInputs.amount, 6) : withdrawal.amount} ${transactionInputs.tokenSymbol}`} +
Loading
)}
{status?.data?.from ?? ''}
@@ -216,13 +216,14 @@ const Withdrawal: React.FC = ({ withdrawal }) => {
Initiate
{timeAgo(withdrawal?.highNetworkTimestamp)}
- {!transactionInputs?.tokenSymbol ? ( -
-
Loading
+ {transactionInputs?.tokenSymbol ? ( +
+ {`${transactionInputs.tokenSymbol === 'USDC' ? ethers.utils.formatUnits(transactionInputs.amount, 6) : withdrawal.amount} ${transactionInputs.tokenSymbol}`}
) : ( -
{`${transactionInputs.tokenSymbol === 'USDC' ? ethers.utils.formatUnits(transactionInputs.amount, 6) : withdrawal.amount} ${transactionInputs.tokenSymbol}`}
+
+
Loading
+
)}
{status?.data?.from ?? ''}
{status?.data?.to ?? ''}
@@ -245,14 +246,16 @@ const Withdrawal: React.FC = ({ withdrawal }) => {
Finalize
{timeAgo(withdrawal?.completionTimestamp)}
- {!transactionInputs?.tokenSymbol ? ( + {transactionInputs?.tokenSymbol ? ( +
+ {`${transactionInputs.tokenSymbol === 'USDC' ? ethers.utils.formatUnits(transactionInputs.amount, 6) : withdrawal.amount} ${transactionInputs.tokenSymbol}`} +
+ ) : (
Loading
- ) : ( -
{`${transactionInputs.tokenSymbol === 'USDC' ? ethers.utils.formatUnits(transactionInputs.amount, 6) : withdrawal.amount} ${transactionInputs.tokenSymbol}`}
- )}
{status?.data?.from ?? ''}
+ )} +
{status?.data?.from ?? ''}
{status?.data?.to ?? ''}
= ({ withdrawal }) => {
{timeAgo(status?.data?.timestamp)}
- {!transactionInputs?.tokenSymbol ? ( + {transactionInputs?.tokenSymbol ? (
-
Loading
+ {`${transactionInputs.tokenSymbol === 'USDC' ? ethers.utils.formatUnits(transactionInputs.amount, 6) : withdrawal.amount} ${transactionInputs.tokenSymbol}`}
) : ( -
{`${transactionInputs.tokenSymbol === 'USDC' ? ethers.utils.formatUnits(transactionInputs.amount, 6) : withdrawal.amount} ${transactionInputs.tokenSymbol}`}
- )}
{status?.data?.from ?? ''}
+
+
Loading
+
+ )} +
{status?.data?.from ?? ''}
{status?.data?.to ?? ''}
{transferStatus && transferStatus?.status === ChildToParentMessageStatus.CONFIRMED && ( <> From ad01dc3b0516f4c1a1f01f4aff8f5b20fb3e5cc7 Mon Sep 17 00:00:00 2001 From: Memo Khoury Date: Tue, 10 Dec 2024 11:12:36 +0000 Subject: [PATCH 3/7] update links --- .../src/components/bridge/history/Deposit.tsx | 5 +++-- .../src/components/landing/MainSection.tsx | 2 +- .../src/components/landing/Navbar.tsx | 2 +- .../src/components/landing/NetworksEssentials.tsx | 4 ++-- .../world-builder-dashboard/src/hooks/useBridgeTransfer.ts | 4 +++- .../src/layouts/MainLayout/MainLayout.tsx | 2 +- 6 files changed, 11 insertions(+), 8 deletions(-) diff --git a/webapps/world-builder-dashboard/src/components/bridge/history/Deposit.tsx b/webapps/world-builder-dashboard/src/components/bridge/history/Deposit.tsx index 20f69890..582c1ba6 100644 --- a/webapps/world-builder-dashboard/src/components/bridge/history/Deposit.tsx +++ b/webapps/world-builder-dashboard/src/components/bridge/history/Deposit.tsx @@ -27,8 +27,9 @@ const Deposit: React.FC = ({ deposit }) => { const { returnTransferData, getTransactionInputs, getHighNetworkTimestamp } = useBridgeTransfer() const { data: transferStatus, isLoading } = returnTransferData({ txRecord: deposit }) - const { data: transactionInputs } = getTransactionInputs({ txRecord: deposit }) + const { data: transactionInputs, isLoading: isLoadingInputs } = getTransactionInputs({ txRecord: deposit }) const { data: highNetworkTimestamp } = getHighNetworkTimestamp({ txRecord: deposit, transferStatus: transferStatus }) + return ( <> {isLoading && smallView ? ( @@ -55,7 +56,7 @@ const Deposit: React.FC = ({ deposit }) => {
{timeAgo(deposit.lowNetworkTimestamp)}
- {transactionInputs?.tokenSymbol ? ( + {!isLoadingInputs && transactionInputs?.tokenSymbol ? (
{`${transactionInputs.tokenSymbol === 'USDC' ? ethers.utils.formatUnits(transactionInputs.amount, 6) : deposit.amount} ${transactionInputs.tokenSymbol}`}
diff --git a/webapps/world-builder-dashboard/src/components/landing/MainSection.tsx b/webapps/world-builder-dashboard/src/components/landing/MainSection.tsx index 30efec54..75068e5e 100644 --- a/webapps/world-builder-dashboard/src/components/landing/MainSection.tsx +++ b/webapps/world-builder-dashboard/src/components/landing/MainSection.tsx @@ -21,7 +21,7 @@ const MainSection: React.FC = ({ smallView, startBuilding }) = className={styles.learnMoreCTA} onClick={() => window.open( - 'https://wiki.game7.io/g7-developer-resource/bWmdEUXVjGpgIbH3H5XT/introducing-the-g7-network/world-builder', + 'https://docs.game7.io/', '_blank' ) } diff --git a/webapps/world-builder-dashboard/src/components/landing/Navbar.tsx b/webapps/world-builder-dashboard/src/components/landing/Navbar.tsx index fea37284..915b3c46 100644 --- a/webapps/world-builder-dashboard/src/components/landing/Navbar.tsx +++ b/webapps/world-builder-dashboard/src/components/landing/Navbar.tsx @@ -21,7 +21,7 @@ const NAVBAR_ITEMS = [ { name: 'Community', link: 'https://discord.com/invite/g7dao' }, { name: 'Docs', - link: 'https://wiki.game7.io/g7-developer-resource/bWmdEUXVjGpgIbH3H5XT/introducing-the-g7-network/world-builder' + link: 'https://docs.game7.io/g7-developer-resource/bWmdEUXVjGpgIbH3H5XT/introducing-the-g7-network/world-builder' } ] diff --git a/webapps/world-builder-dashboard/src/components/landing/NetworksEssentials.tsx b/webapps/world-builder-dashboard/src/components/landing/NetworksEssentials.tsx index f681b858..3d893317 100644 --- a/webapps/world-builder-dashboard/src/components/landing/NetworksEssentials.tsx +++ b/webapps/world-builder-dashboard/src/components/landing/NetworksEssentials.tsx @@ -31,13 +31,13 @@ const essentials = [ title: 'Block explorer', description: 'Track and interact directly with your smart contracts', imageClass: styles.networkEssentialExplorer, - onClick: () => window.open('https://testnet.game7.io/', '_blank') + onClick: () => window.open('https://mainnet.game7.io/', '_blank') }, { title: 'Docs', description: 'Get more information about building on the G7 Network', imageClass: styles.networkEssentialDocs, - onClick: () => window.open('https://wiki.game7.io/g7-developer-resource/', '_blank') + onClick: () => window.open('https://docs.game7.io/', '_blank') }, { title: 'Discord', diff --git a/webapps/world-builder-dashboard/src/hooks/useBridgeTransfer.ts b/webapps/world-builder-dashboard/src/hooks/useBridgeTransfer.ts index 6a91903e..2cd9ae5d 100644 --- a/webapps/world-builder-dashboard/src/hooks/useBridgeTransfer.ts +++ b/webapps/world-builder-dashboard/src/hooks/useBridgeTransfer.ts @@ -265,7 +265,9 @@ export const useBridgeTransfer = () => { const cachedTransaction = transactions.find((t: any) => isDeposit ? t.lowNetworkHash === txRecord.lowNetworkHash : t.highNetworkHash === txRecord.highNetworkHash ) + console.log(cachedTransaction) if (cachedTransaction && cachedTransaction.transactionInputs !== undefined) { + console.log('returning..') return cachedTransaction?.transactionInputs } }, @@ -327,7 +329,7 @@ export const useBridgeTransfer = () => { const cachedTransaction = transactions.find((t: any) => t.lowNetworkHash === txRecord?.lowNetworkHash) return cachedTransaction?.highNetworkTimestamp }, - + keepPreviousData: true, staleTime: 1 * 60 * 1000, refetchInterval: false, refetchOnWindowFocus: false, diff --git a/webapps/world-builder-dashboard/src/layouts/MainLayout/MainLayout.tsx b/webapps/world-builder-dashboard/src/layouts/MainLayout/MainLayout.tsx index f601fddc..bb3af3f2 100644 --- a/webapps/world-builder-dashboard/src/layouts/MainLayout/MainLayout.tsx +++ b/webapps/world-builder-dashboard/src/layouts/MainLayout/MainLayout.tsx @@ -42,7 +42,7 @@ const MainLayout: React.FC = ({}) => { }, { name: 'documentation', - navigateTo: 'https://wiki.game7.io/g7-developer-resource/bWmdEUXVjGpgIbH3H5XT/', + navigateTo: 'https://docs.game7.io/', icon: } ] From 54db5eaae11db0b774588c99323d91501fb30694 Mon Sep 17 00:00:00 2001 From: Memo Khoury Date: Tue, 10 Dec 2024 12:32:02 +0000 Subject: [PATCH 4/7] added ternary statement for cell in withdrawal --- .../components/bridge/history/Withdrawal.tsx | 38 +++++++++++++------ .../src/hooks/useBridgeTransfer.ts | 18 ++++++--- 2 files changed, 38 insertions(+), 18 deletions(-) diff --git a/webapps/world-builder-dashboard/src/components/bridge/history/Withdrawal.tsx b/webapps/world-builder-dashboard/src/components/bridge/history/Withdrawal.tsx index 205554ea..9544c9ff 100644 --- a/webapps/world-builder-dashboard/src/components/bridge/history/Withdrawal.tsx +++ b/webapps/world-builder-dashboard/src/components/bridge/history/Withdrawal.tsx @@ -143,16 +143,30 @@ const Withdrawal: React.FC = ({ withdrawal }) => { > {timeAgo(withdrawal?.highNetworkTimestamp)} -
setCollapseExecuted(!collapseExecuted)} - style={{ - cursor: 'pointer', - backgroundColor: hovered ? '#393939' : 'initial' - }} - onMouseEnter={() => setHovered(true)} - onMouseLeave={() => setHovered(false)} - >{`${transactionInputs?.tokenSymbol === 'USDC' ? ethers.utils.formatUnits(transactionInputs?.amount, 6) : withdrawal.amount} ${transactionInputs?.tokenSymbol}`}
+ {transactionInputs?.tokenSymbol ? ( +
setCollapseExecuted(!collapseExecuted)} + style={{ + cursor: 'pointer', + backgroundColor: hovered ? '#393939' : 'initial' + }} + onMouseEnter={() => setHovered(true)} + onMouseLeave={() => setHovered(false)} + >{`${transactionInputs?.tokenSymbol === 'USDC' ? ethers.utils.formatUnits(transactionInputs?.amount, 6) : withdrawal.amount} ${transactionInputs?.tokenSymbol}`}
) : ( +
setCollapseExecuted(!collapseExecuted)} + style={{ + cursor: 'pointer', + backgroundColor: hovered ? '#393939' : 'initial' + }} + onMouseEnter={() => setHovered(true)} + onMouseLeave={() => setHovered(false)} + > +
Loading
+
+ )}
setCollapseExecuted(!collapseExecuted)} @@ -216,8 +230,8 @@ const Withdrawal: React.FC = ({ withdrawal }) => {
Initiate
{timeAgo(withdrawal?.highNetworkTimestamp)}
- {transactionInputs?.tokenSymbol ? ( -
+ {transactionInputs?.tokenSymbol ? ( +
{`${transactionInputs.tokenSymbol === 'USDC' ? ethers.utils.formatUnits(transactionInputs.amount, 6) : withdrawal.amount} ${transactionInputs.tokenSymbol}`}
) : ( diff --git a/webapps/world-builder-dashboard/src/hooks/useBridgeTransfer.ts b/webapps/world-builder-dashboard/src/hooks/useBridgeTransfer.ts index 2cd9ae5d..13d873da 100644 --- a/webapps/world-builder-dashboard/src/hooks/useBridgeTransfer.ts +++ b/webapps/world-builder-dashboard/src/hooks/useBridgeTransfer.ts @@ -232,6 +232,16 @@ export const useBridgeTransfer = () => { return useQuery( ['transactionInputs', txHash], async () => { + const transactions = getCachedTransactions(connectedAccount ?? '', selectedNetworkType) + const cachedTransaction = transactions.find((t: any) => + isDeposit ? t.lowNetworkHash === txRecord.lowNetworkHash : t.highNetworkHash === txRecord.highNetworkHash + ) + + // Check if we have cached inputs + if (cachedTransaction?.transactionInputs !== undefined) { + return cachedTransaction.transactionInputs + } + const _bridgeTransfer = new BridgeTransfer({ txHash: txHash ?? '', destinationNetworkChainId: destinationChainId ?? 0, @@ -242,15 +252,13 @@ export const useBridgeTransfer = () => { const transactionInputs = await _bridgeTransfer.getInfo() - const transactions = getCachedTransactions(connectedAccount ?? '', selectedNetworkType) - // Update the cache with the latest status const newTransactions = transactions.map((t: any) => { const isSameHash = isDeposit ? t.lowNetworkHash === txRecord.lowNetworkHash : t.highNetworkHash === txRecord.highNetworkHash - return isSameHash ? { ...t, transactionInputs: transactionInputs } : t + return isSameHash ? { ...t, transactionInputs: transactionInputs, lastUpdated: Date.now() } : t }) localStorage.setItem( @@ -265,13 +273,11 @@ export const useBridgeTransfer = () => { const cachedTransaction = transactions.find((t: any) => isDeposit ? t.lowNetworkHash === txRecord.lowNetworkHash : t.highNetworkHash === txRecord.highNetworkHash ) - console.log(cachedTransaction) if (cachedTransaction && cachedTransaction.transactionInputs !== undefined) { - console.log('returning..') return cachedTransaction?.transactionInputs } }, - staleTime: 2 * 60 * 1000, + staleTime: 30 * 60 * 1000, refetchOnWindowFocus: false, enabled: !!txRecord } From 3febd3dab57b81e56a330f9b4d73a7b50828a3d3 Mon Sep 17 00:00:00 2001 From: Memo Khoury Date: Tue, 10 Dec 2024 15:05:35 +0000 Subject: [PATCH 5/7] token symbol caching --- .../src/components/bridge/history/Deposit.tsx | 13 ++++-- .../components/bridge/history/Withdrawal.tsx | 1 - .../src/hooks/useBridgeTransfer.ts | 40 +++++++++---------- 3 files changed, 29 insertions(+), 25 deletions(-) diff --git a/webapps/world-builder-dashboard/src/components/bridge/history/Deposit.tsx b/webapps/world-builder-dashboard/src/components/bridge/history/Deposit.tsx index 582c1ba6..33bbddf1 100644 --- a/webapps/world-builder-dashboard/src/components/bridge/history/Deposit.tsx +++ b/webapps/world-builder-dashboard/src/components/bridge/history/Deposit.tsx @@ -27,8 +27,9 @@ const Deposit: React.FC = ({ deposit }) => { const { returnTransferData, getTransactionInputs, getHighNetworkTimestamp } = useBridgeTransfer() const { data: transferStatus, isLoading } = returnTransferData({ txRecord: deposit }) - const { data: transactionInputs, isLoading: isLoadingInputs } = getTransactionInputs({ txRecord: deposit }) const { data: highNetworkTimestamp } = getHighNetworkTimestamp({ txRecord: deposit, transferStatus: transferStatus }) + const { data: transactionInputs, isLoading: isLoadingInputs } = getTransactionInputs({ txRecord: deposit }) + const finalTransactionInputs = transactionInputs || deposit.transactionInputs return ( <> @@ -56,13 +57,17 @@ const Deposit: React.FC = ({ deposit }) => {
{timeAgo(deposit.lowNetworkTimestamp)}
- {!isLoadingInputs && transactionInputs?.tokenSymbol ? ( + {!isLoadingInputs && finalTransactionInputs?.tokenSymbol ? (
- {`${transactionInputs.tokenSymbol === 'USDC' ? ethers.utils.formatUnits(transactionInputs.amount, 6) : deposit.amount} ${transactionInputs.tokenSymbol}`} + {`${finalTransactionInputs.tokenSymbol === 'USDC' + ? ethers.utils.formatUnits(finalTransactionInputs.amount, 6) + : deposit.amount} ${finalTransactionInputs.tokenSymbol}`}
) : (
-
Loading
+
+ Loading +
)}
{depositInfo.from}
diff --git a/webapps/world-builder-dashboard/src/components/bridge/history/Withdrawal.tsx b/webapps/world-builder-dashboard/src/components/bridge/history/Withdrawal.tsx index 9544c9ff..dd893bbf 100644 --- a/webapps/world-builder-dashboard/src/components/bridge/history/Withdrawal.tsx +++ b/webapps/world-builder-dashboard/src/components/bridge/history/Withdrawal.tsx @@ -63,7 +63,6 @@ const Withdrawal: React.FC = ({ withdrawal }) => { const status = getStatus(withdrawal, lowNetworks, highNetworks) const { data: transferStatus, isLoading } = returnTransferData({ txRecord: withdrawal }) const { data: transactionInputs } = getTransactionInputs({ txRecord: withdrawal }) - return ( <> {status?.isLoading && smallView ? ( diff --git a/webapps/world-builder-dashboard/src/hooks/useBridgeTransfer.ts b/webapps/world-builder-dashboard/src/hooks/useBridgeTransfer.ts index 13d873da..d82324cb 100644 --- a/webapps/world-builder-dashboard/src/hooks/useBridgeTransfer.ts +++ b/webapps/world-builder-dashboard/src/hooks/useBridgeTransfer.ts @@ -52,11 +52,12 @@ export const useBridgeTransfer = () => { const destinationRpc = getNetworks(selectedNetworkType)?.find((n) => n.chainId === destinationChainId)?.rpcs[0] const originRpc = getNetworks(selectedNetworkType)?.find((n) => n.chainId === originChainId)?.rpcs[0] - // If the status is pending and time since last fetched is > 2 minutes, fetch again + // Update shouldFetchStatus to prevent refetching for completed transactions const shouldFetchStatus = (cachedTransaction: any) => { - const isPending = ![1, 2, 6, 9].includes(cachedTransaction?.status) + const isCompleted = [1, 2, 6, 9].includes(cachedTransaction?.status) + if (isCompleted) return false const timeSinceLastUpdate = Date.now() - (cachedTransaction?.lastUpdated || 0) - return isPending && timeSinceLastUpdate > 1 * 60 * 1000 + return timeSinceLastUpdate > 1 * 60 * 1000 } let status: any @@ -124,13 +125,13 @@ export const useBridgeTransfer = () => { } }, staleTime: 0.5 * 60 * 1000, - refetchInterval: shouldFetchStatus( - getCachedTransactions(connectedAccount ?? '', selectedNetworkType).find((t: any) => + refetchInterval: () => { + const cachedTx = getCachedTransactions(connectedAccount ?? '', selectedNetworkType).find((t: any) => t.type === 'DEPOSIT' ? t.lowNetworkHash === txHash : t.highNetworkHash === txHash ) - ) - ? 1 * 60 * 1000 - : false, + + return shouldFetchStatus(cachedTx) ? 1 * 60 * 1000 : false + }, refetchOnWindowFocus: false, enabled: !!txRecord } @@ -232,14 +233,8 @@ export const useBridgeTransfer = () => { return useQuery( ['transactionInputs', txHash], async () => { - const transactions = getCachedTransactions(connectedAccount ?? '', selectedNetworkType) - const cachedTransaction = transactions.find((t: any) => - isDeposit ? t.lowNetworkHash === txRecord.lowNetworkHash : t.highNetworkHash === txRecord.highNetworkHash - ) - - // Check if we have cached inputs - if (cachedTransaction?.transactionInputs !== undefined) { - return cachedTransaction.transactionInputs + if (txRecord.transactionInputs) { + return txRecord.transactionInputs } const _bridgeTransfer = new BridgeTransfer({ @@ -252,13 +247,15 @@ export const useBridgeTransfer = () => { const transactionInputs = await _bridgeTransfer.getInfo() + const transactions = getCachedTransactions(connectedAccount ?? '', selectedNetworkType) + // Update the cache with the latest status const newTransactions = transactions.map((t: any) => { const isSameHash = isDeposit ? t.lowNetworkHash === txRecord.lowNetworkHash : t.highNetworkHash === txRecord.highNetworkHash - return isSameHash ? { ...t, transactionInputs: transactionInputs, lastUpdated: Date.now() } : t + return isSameHash ? { ...t, transactionInputs: transactionInputs } : t }) localStorage.setItem( @@ -273,11 +270,14 @@ export const useBridgeTransfer = () => { const cachedTransaction = transactions.find((t: any) => isDeposit ? t.lowNetworkHash === txRecord.lowNetworkHash : t.highNetworkHash === txRecord.highNetworkHash ) - if (cachedTransaction && cachedTransaction.transactionInputs !== undefined) { - return cachedTransaction?.transactionInputs + + if (cachedTransaction?.transactionInputs) { + return cachedTransaction.transactionInputs } + + return null }, - staleTime: 30 * 60 * 1000, + staleTime: 2 * 60 * 1000, refetchOnWindowFocus: false, enabled: !!txRecord } From a45c18dddcfcbea9f34aa050642d630178408906 Mon Sep 17 00:00:00 2001 From: Memo Khoury Date: Tue, 10 Dec 2024 15:08:00 +0000 Subject: [PATCH 6/7] hide usdc --- .../src/utils/tokens.ts | 138 +++++++++--------- 1 file changed, 69 insertions(+), 69 deletions(-) diff --git a/webapps/world-builder-dashboard/src/utils/tokens.ts b/webapps/world-builder-dashboard/src/utils/tokens.ts index 49ce312b..4da6a91d 100644 --- a/webapps/world-builder-dashboard/src/utils/tokens.ts +++ b/webapps/world-builder-dashboard/src/utils/tokens.ts @@ -9,15 +9,15 @@ import { L3_MAIN_NETWORK, L3_NETWORK, TG7T, - USDC, - USDC_MAINNET + // USDC, + // USDC_MAINNET } from '../../constants' import { ZERO_ADDRESS } from './web3utils' import { TokenAddressMap } from 'game7-bridge-sdk' import IconEthereum from '@/assets/IconEthereum' import IconG7T from '@/assets/IconG7T' import IconTokenNoSynbol from '@/assets/IconTokenNoSymbol' -import IconUSDC from '@/assets/IconUSDC' +// import IconUSDC from '@/assets/IconUSDC' export interface Token { @@ -62,17 +62,17 @@ export const getTokensForNetwork = (chainId: number | undefined, userAddress: st chainId: L1_NETWORK.chainId, geckoId: 'ethereum' }, - { - name: 'USDC', - symbol: 'USDC', - address: '0xf2B58E3519C5b977a254993A4A6EaD581A8989A0', - Icon: IconUSDC, - rpc: L1_NETWORK.rpcs[0], - tokenAddressMap: USDC, - chainId: L1_NETWORK.chainId, - decimals: 6, - geckoId: 'usd-coin' - }, + // { + // name: 'USDC', + // symbol: 'USDC', + // address: '0xf2B58E3519C5b977a254993A4A6EaD581A8989A0', + // Icon: IconUSDC, + // rpc: L1_NETWORK.rpcs[0], + // tokenAddressMap: USDC, + // chainId: L1_NETWORK.chainId, + // decimals: 6, + // geckoId: 'usd-coin' + // }, ...storedTokensWithItems ] case L2_NETWORK.chainId: @@ -97,17 +97,17 @@ export const getTokensForNetwork = (chainId: number | undefined, userAddress: st chainId: L2_NETWORK.chainId, geckoId: 'ethereum' }, - { - name: 'USDC', - symbol: 'USDC', - address: '0x119f0E6303BEc7021B295EcaB27A4a1A5b37ECf0', - Icon: IconUSDC, - rpc: L2_NETWORK.rpcs[0], - tokenAddressMap: USDC, - chainId: L2_NETWORK.chainId, - decimals: 6, - geckoId: 'usd-coin' - }, + // { + // name: 'USDC', + // symbol: 'USDC', + // address: '0x119f0E6303BEc7021B295EcaB27A4a1A5b37ECf0', + // Icon: IconUSDC, + // rpc: L2_NETWORK.rpcs[0], + // tokenAddressMap: USDC, + // chainId: L2_NETWORK.chainId, + // decimals: 6, + // geckoId: 'usd-coin' + // }, ...storedTokensWithItems ] case L3_NETWORK.chainId: @@ -122,17 +122,17 @@ export const getTokensForNetwork = (chainId: number | undefined, userAddress: st chainId: L3_NETWORK.chainId, geckoId: 'G7T' }, - { - name: 'USDC', - symbol: 'USDC', - address: '0x1c7D4B196Cb0C7B01d743Fbc6116a902379C7238', - Icon: IconUSDC, - rpc: L3_NETWORK.rpcs[0], - tokenAddressMap: USDC, - chainId: L3_NETWORK.chainId, - decimals: 6, - geckoId: 'usd-coin' - }, + // { + // name: 'USDC', + // symbol: 'USDC', + // address: '0x1c7D4B196Cb0C7B01d743Fbc6116a902379C7238', + // Icon: IconUSDC, + // rpc: L3_NETWORK.rpcs[0], + // tokenAddressMap: USDC, + // chainId: L3_NETWORK.chainId, + // decimals: 6, + // geckoId: 'usd-coin' + // }, ...storedTokensWithItems ] case L1_MAIN_NETWORK.chainId: @@ -157,17 +157,17 @@ export const getTokensForNetwork = (chainId: number | undefined, userAddress: st chainId: L1_MAIN_NETWORK.chainId, geckoId: 'ethereum' }, - { - name: 'USDC', - symbol: 'USDC', - address: '0xa0b86991c6218b36c1d19d4a2e9eb0ce3606eb48', - Icon: IconUSDC, - rpc: L1_MAIN_NETWORK.rpcs[0], - tokenAddressMap: USDC_MAINNET, - chainId: L1_MAIN_NETWORK.chainId, - decimals: 6, - geckoId: 'usd-coin' - }, + // { + // name: 'USDC', + // symbol: 'USDC', + // address: '0xa0b86991c6218b36c1d19d4a2e9eb0ce3606eb48', + // Icon: IconUSDC, + // rpc: L1_MAIN_NETWORK.rpcs[0], + // tokenAddressMap: USDC_MAINNET, + // chainId: L1_MAIN_NETWORK.chainId, + // decimals: 6, + // geckoId: 'usd-coin' + // }, ...storedTokensWithItems ] case L2_MAIN_NETWORK.chainId: @@ -192,17 +192,17 @@ export const getTokensForNetwork = (chainId: number | undefined, userAddress: st chainId: L2_MAIN_NETWORK.chainId, geckoId: 'ethereum' }, - { - name: 'USDC', - symbol: 'USDC', - address: '0xaf88d065e77c8cC2239327C5EDb3A432268e5831', - Icon: IconUSDC, - rpc: L2_MAIN_NETWORK.rpcs[0], - tokenAddressMap: USDC_MAINNET, - chainId: L2_MAIN_NETWORK.chainId, - decimals: 6, - geckoId: 'usd-coin' - }, + // { + // name: 'USDC', + // symbol: 'USDC', + // address: '0xaf88d065e77c8cC2239327C5EDb3A432268e5831', + // Icon: IconUSDC, + // rpc: L2_MAIN_NETWORK.rpcs[0], + // tokenAddressMap: USDC_MAINNET, + // chainId: L2_MAIN_NETWORK.chainId, + // decimals: 6, + // geckoId: 'usd-coin' + // }, ...storedTokensWithItems ] case L3_MAIN_NETWORK.chainId: @@ -217,17 +217,17 @@ export const getTokensForNetwork = (chainId: number | undefined, userAddress: st chainId: L3_MAIN_NETWORK.chainId, geckoId: 'G7T' }, - { - name: 'USDC', - symbol: 'USDC', - address: '0x401eCb1D350407f13ba348573E5630B83638E30D', - Icon: IconUSDC, - rpc: L3_MAIN_NETWORK.rpcs[0], - tokenAddressMap: USDC_MAINNET, - chainId: L3_MAIN_NETWORK.chainId, - decimals: 6, - geckoId: 'usd-coin' - }, + // { + // name: 'USDC', + // symbol: 'USDC', + // address: '0x401eCb1D350407f13ba348573E5630B83638E30D', + // Icon: IconUSDC, + // rpc: L3_MAIN_NETWORK.rpcs[0], + // tokenAddressMap: USDC_MAINNET, + // chainId: L3_MAIN_NETWORK.chainId, + // decimals: 6, + // geckoId: 'usd-coin' + // }, ...storedTokensWithItems ] default: From 6427b6f04d2721c6f0c15e7bd22f3b798b786a95 Mon Sep 17 00:00:00 2001 From: Memo Khoury Date: Tue, 10 Dec 2024 15:12:57 +0000 Subject: [PATCH 7/7] fix navbar link --- .../world-builder-dashboard/src/components/landing/Navbar.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/webapps/world-builder-dashboard/src/components/landing/Navbar.tsx b/webapps/world-builder-dashboard/src/components/landing/Navbar.tsx index 915b3c46..c0bb3ac9 100644 --- a/webapps/world-builder-dashboard/src/components/landing/Navbar.tsx +++ b/webapps/world-builder-dashboard/src/components/landing/Navbar.tsx @@ -21,7 +21,7 @@ const NAVBAR_ITEMS = [ { name: 'Community', link: 'https://discord.com/invite/g7dao' }, { name: 'Docs', - link: 'https://docs.game7.io/g7-developer-resource/bWmdEUXVjGpgIbH3H5XT/introducing-the-g7-network/world-builder' + link: 'https://docs.game7.io/' } ]