diff --git a/lefthook.yml b/lefthook.yml index 990f1f61e4b..ad20da55ce9 100644 --- a/lefthook.yml +++ b/lefthook.yml @@ -5,9 +5,9 @@ pre-commit: # bridge-ui: # glob: "packages/bridge-ui/**.{js,svelte,ts}" # run: pnpm -F bridge-ui lint:fix && git add {staged_files} - # bridge-ui-v2: - # glob: "packages/bridge-ui-v2/**.{js,ts,css,svelte}" - # run: pnpm -F bridge-ui-v2 svelte:check && pnpm -F bridge-ui-v2 lint:fix && git add {staged_files} + bridge-ui-v2: + glob: "packages/bridge-ui-v2/**.{js,ts,css,svelte}" + run: pnpm -F bridge-ui-v2 svelte:check && pnpm -F bridge-ui-v2 lint:fix && git add {staged_files} protocol_sol: glob: "packages/protocol/**.{sol}" run: pnpm -F protocol lint:sol && git add {staged_files} diff --git a/packages/bridge-ui-v2/src/components/Bridge/Bridge.svelte b/packages/bridge-ui-v2/src/components/Bridge/Bridge.svelte index 0d6defc8ac2..a74cfea3f57 100644 --- a/packages/bridge-ui-v2/src/components/Bridge/Bridge.svelte +++ b/packages/bridge-ui-v2/src/components/Bridge/Bridge.svelte @@ -296,6 +296,9 @@ } } } + $: if ($selectedToken && amountComponent) { + amountComponent.validateAmount(); + } diff --git a/packages/bridge-ui-v2/src/components/Bridge/ProcessingFee/NoneOption.svelte b/packages/bridge-ui-v2/src/components/Bridge/ProcessingFee/NoneOption.svelte index 603c6aaf41c..6cf2d4da7ec 100644 --- a/packages/bridge-ui-v2/src/components/Bridge/ProcessingFee/NoneOption.svelte +++ b/packages/bridge-ui-v2/src/components/Bridge/ProcessingFee/NoneOption.svelte @@ -11,8 +11,8 @@ export let calculating = false; export let error = false; - async function compute(token: Maybe, userAddress?: Address, srcChainId?: number, destChainId?: number) { - if (!token || !userAddress || !srcChainId || !destChainId) { + async function compute(token: Maybe, userAddress?: Address, srcChain?: number, destChain?: number) { + if (!token || !userAddress || !srcChain || !destChain) { enoughEth = false; return; } @@ -25,14 +25,14 @@ // Get the balance of the user on the destination chain destBalance = await getBalance({ userAddress, - srcChainId: destChainId, + srcChainId: destChain, }); // Calculate the recommended amount of ETH needed for processMessage call const recommendedAmount = await recommendProcessingFee({ token, - destChainId, - srcChainId, + destChainId: destChain, + srcChainId: srcChain, }); // Does the user have enough ETH to claim manually on the destination chain? diff --git a/packages/bridge-ui-v2/src/components/Transactions/MobileDetailsDialog.svelte b/packages/bridge-ui-v2/src/components/Transactions/MobileDetailsDialog.svelte index b83f002d4ac..7d6642abe46 100644 --- a/packages/bridge-ui-v2/src/components/Transactions/MobileDetailsDialog.svelte +++ b/packages/bridge-ui-v2/src/components/Transactions/MobileDetailsDialog.svelte @@ -1,4 +1,5 @@ @@ -66,7 +73,7 @@
- +
  • diff --git a/packages/bridge-ui-v2/src/components/Transactions/Status.svelte b/packages/bridge-ui-v2/src/components/Transactions/Status.svelte index 8b5e370c9c7..5b1425ad826 100644 --- a/packages/bridge-ui-v2/src/components/Transactions/Status.svelte +++ b/packages/bridge-ui-v2/src/components/Transactions/Status.svelte @@ -1,6 +1,6 @@ @@ -65,7 +87,11 @@ {/if}
    - + +
    + + + + + diff --git a/packages/bridge-ui-v2/src/components/Transactions/Transactions.svelte b/packages/bridge-ui-v2/src/components/Transactions/Transactions.svelte index 6f91ca3a9fb..b3b121a508b 100644 --- a/packages/bridge-ui-v2/src/components/Transactions/Transactions.svelte +++ b/packages/bridge-ui-v2/src/components/Transactions/Transactions.svelte @@ -15,7 +15,6 @@ import { account, network } from '$stores'; import type { Account } from '$stores/account'; - import MobileDetailsDialog from './MobileDetailsDialog.svelte'; import StatusInfoDialog from './StatusInfoDialog.svelte'; import Transaction from './Transaction.svelte'; @@ -31,11 +30,8 @@ let loadingTxs = false; - let detailsOpen = false; let isDesktopOrLarger: boolean; - let selectedItem: BridgeTransaction | null = null; - const handlePageChange = (detail: number) => { isBlurred = true; setTimeout(() => { @@ -67,16 +63,6 @@ } }; - const closeDetails = () => { - detailsOpen = false; - selectedItem = null; - }; - - const openDetails = (tx: BridgeTransaction) => { - detailsOpen = true; - selectedItem = tx; - }; - const updateTransactions = async (address: Address) => { const { mergedTransactions, outdatedLocalTransactions, error } = await fetchTransactions(address); transactions = mergedTransactions; @@ -136,7 +122,7 @@ class="flex flex-col items-center" style={isBlurred ? `filter: blur(5px); transition: filter ${transitionTime / 1000}s ease-in-out` : ''}> {#each transactionsToShow as item (item.hash)} - openDetails(item)} /> +
    {/each}
    @@ -156,8 +142,6 @@ - - diff --git a/packages/bridge-ui-v2/src/i18n/en.json b/packages/bridge-ui-v2/src/i18n/en.json index a5943f0201f..0c569706904 100644 --- a/packages/bridge-ui-v2/src/i18n/en.json +++ b/packages/bridge-ui-v2/src/i18n/en.json @@ -102,9 +102,9 @@ "release": "Release" }, "status": { - "initiated": { - "name": "Initiated", - "description": "Transaction initiated" + "processing": { + "name": "Processing", + "description": "Transaction is processing. Depending on the pending blocks to be verified this can take up to several minutes." }, "pending": { "name": "Pending", diff --git a/packages/bridge-ui-v2/src/libs/token/getBalance.test.ts b/packages/bridge-ui-v2/src/libs/token/getBalance.test.ts index 6a17133be05..e0873f2336c 100644 --- a/packages/bridge-ui-v2/src/libs/token/getBalance.test.ts +++ b/packages/bridge-ui-v2/src/libs/token/getBalance.test.ts @@ -64,7 +64,10 @@ describe('getBalance', () => { expect(balance).toEqual(mockBalanceForETH); expect(getAddress).not.toHaveBeenCalled(); - expect(fetchBalance).toHaveBeenCalledWith({ address: mockWalletClient.account.address }); + expect(fetchBalance).toHaveBeenCalledWith({ + address: mockWalletClient.account.address, + chainId: Number(PUBLIC_L1_CHAIN_ID), + }); }); it('should return the balance of ERC20 token', async () => { diff --git a/packages/bridge-ui-v2/src/libs/token/getBalance.ts b/packages/bridge-ui-v2/src/libs/token/getBalance.ts index a4710f8c79f..feeb240b3b3 100644 --- a/packages/bridge-ui-v2/src/libs/token/getBalance.ts +++ b/packages/bridge-ui-v2/src/libs/token/getBalance.ts @@ -20,7 +20,7 @@ export async function getBalance({ userAddress, token, srcChainId, destChainId } if (!token || token.type === TokenType.ETH) { // If no token is passed in, we assume is ETH - tokenBalance = await fetchBalance({ address: userAddress }); + tokenBalance = await fetchBalance({ address: userAddress, chainId: srcChainId }); } else { // We need at least the source chain to find the address if (!srcChainId) return;