Skip to content

Commit

Permalink
Merge branch 'master' into feat-dont-require-wallet
Browse files Browse the repository at this point in the history
  • Loading branch information
fionnachan authored Sep 3, 2024
2 parents 5c15c73 + 59756ff commit cd4de57
Show file tree
Hide file tree
Showing 42 changed files with 703 additions and 581 deletions.
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@
"lint": "yarn workspace arb-token-bridge-ui lint",
"lint:fix": "yarn workspace arb-token-bridge-ui lint:fix",
"test:e2e": "yarn workspace arb-token-bridge-ui env-cmd --silent --file .e2e.env yarn synpress run --configFile synpress.config.ts",
"test:e2e:cctp": "E2E_CCTP=true yarn test:e2e",
"test:e2e:cctp": "yarn test:e2e --configFile synpress.cctp.config.ts",
"test:e2e:orbit": "E2E_ORBIT=true yarn test:e2e"
},
"resolutions": {
Expand Down
2 changes: 2 additions & 0 deletions packages/arb-token-bridge-ui/.e2e.env.sample
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,8 @@ CYPRESS_RECORD_VIDEO=false
# Below key is only used to fund the newly created wallet
PRIVATE_KEY_CUSTOM=b6b15c8cb491557369f3c7d2c287b053eb229daa9c22138887752191c9520659

PRIVATE_KEY_CCTP=

# We set up MetaMask ourselves
SKIP_METAMASK_SETUP=true

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ import { ExternalLink } from '../common/ExternalLink'
import { TransferCountdown } from '../common/TransferCountdown'
import { isDepositReadyToRedeem } from '../../state/app/utils'
import { Address } from '../../util/AddressUtils'
import { isTeleport } from '@/token-bridge-sdk/teleport'
import { isTeleportTx } from '../../hooks/useTransactions'
import {
firstRetryableLegRequiresRedeem,
secondRetryableLegForTeleportRequiresRedeem
Expand All @@ -31,7 +31,6 @@ import {
minutesToHumanReadableTime,
useTransferDuration
} from '../../hooks/useTransferDuration'
import { isTeleporterTransaction } from '../../hooks/useTransactions'

function needsToClaimTransfer(tx: MergedTransaction) {
return tx.isCctp || tx.isWithdrawal
Expand Down Expand Up @@ -119,7 +118,7 @@ const LastStepEndItem = ({
const destinationChainId = tx.isWithdrawal
? tx.parentChainId
: tx.childChainId
const isTeleportTx = isTeleport(tx) && isTeleporterTransaction(tx)
const isTeleport = isTeleportTx(tx)

if (destinationNetworkTxId) {
return (
Expand All @@ -134,8 +133,8 @@ const LastStepEndItem = ({
}

if (
(!isTeleportTx && isDepositReadyToRedeem(tx)) ||
(isTeleportTx && secondRetryableLegForTeleportRequiresRedeem(tx))
(!isTeleport && isDepositReadyToRedeem(tx)) ||
(isTeleport && secondRetryableLegForTeleportRequiresRedeem(tx))
) {
return (
<TransactionsTableRowAction
Expand Down Expand Up @@ -181,9 +180,9 @@ export const TransactionsTableDetailsSteps = ({
tx.depositStatus
)

const isTeleportTx = isTeleport(tx) && isTeleporterTransaction(tx)
const isTeleport = isTeleportTx(tx)

const isDestinationChainFailure = isTeleportTx
const isDestinationChainFailure = isTeleport
? secondRetryableLegForTeleportRequiresRedeem(tx)
: !isSourceChainDepositFailure && isTxFailed(tx)

Expand All @@ -194,7 +193,7 @@ export const TransactionsTableDetailsSteps = ({
if (isTxExpired(tx)) {
return `Transaction expired on ${networkName}`
}
if (isTeleportTx && firstRetryableLegRequiresRedeem(tx)) {
if (isTeleport && firstRetryableLegRequiresRedeem(tx)) {
return fundsArrivedText
}

Expand All @@ -205,7 +204,7 @@ export const TransactionsTableDetailsSteps = ({
return `Transaction failed on ${networkName}.`
}
return fundsArrivedText
}, [tx, isDestinationChainFailure, isTeleportTx])
}, [tx, isDestinationChainFailure, isTeleport])

return (
<div className="flex flex-col text-xs">
Expand All @@ -226,7 +225,7 @@ export const TransactionsTableDetailsSteps = ({
/>

{/* Pending transfer showing the remaining time */}
{!isTeleport(tx) && (
{!isTeleportTx(tx) && (
<Step
pending={isTxPending(tx)}
done={!isTxPending(tx) && !isSourceChainDepositFailure}
Expand All @@ -241,7 +240,7 @@ export const TransactionsTableDetailsSteps = ({
/>
)}

{isTeleport(tx) && isTeleporterTransaction(tx) && (
{isTeleportTx(tx) && (
<TransactionsTableDetailsTeleporterSteps tx={tx} address={address} />
)}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ import { useRedeemRetryable } from '../../hooks/useRedeemRetryable'
import { TransferCountdown } from '../common/TransferCountdown'
import { Address } from '../../util/AddressUtils'
import { getChainIdForRedeemingRetryable } from '../../util/RetryableUtils'
import { isTeleport } from '@/token-bridge-sdk/teleport'
import { isTeleportTx } from '../../hooks/useTransactions'
import { useRedeemTeleporter } from '../../hooks/useRedeemTeleporter'
import { sanitizeTokenSymbol } from '../../util/TokenUtils'
import { formatAmount } from '../../util/NumberUtils'
Expand Down Expand Up @@ -67,7 +67,7 @@ export function TransactionsTableRowAction({
await switchNetworkAsync?.(chainIdForRedeemingRetryable)
}

if (isTeleport(tx)) {
if (isTeleportTx(tx)) {
await teleporterRedeem()
} else {
await redeem()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,11 +25,10 @@ import { AssetType } from '../../hooks/arbTokenBridge.types'
import { getDepositStatus } from '../../state/app/utils'
import { getBlockBeforeConfirmation } from '../../state/cctpState'
import { getAttestationHashAndMessageFromReceipt } from '../../util/cctp/getAttestationHashAndMessageFromReceipt'
import { isTeleport } from '@/token-bridge-sdk/teleport'
import { getOutgoingMessageState } from '../../util/withdrawals/helpers'
import { getUniqueIdOrHashFromEvent } from '../../hooks/useArbTokenBridge'
import { getProviderForChainId } from '../../token-bridge-sdk/utils'
import { isTeleporterTransaction } from '../../hooks/useTransactions'
import { isTeleportTx } from '../../hooks/useTransactions'

const PARENT_CHAIN_TX_DETAILS_OF_CLAIM_TX =
'arbitrum:bridge:claim:parent:tx:details'
Expand Down Expand Up @@ -639,7 +638,7 @@ export function getDestinationNetworkTxId(tx: MergedTransaction) {
return tx.cctpData?.receiveMessageTransactionHash
}

if (isTeleport(tx) && isTeleporterTransaction(tx)) {
if (isTeleportTx(tx)) {
return tx.l2ToL3MsgData?.l3TxID
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -263,6 +263,7 @@ export const AdvancedSettings = () => {
onChange={e =>
setDestinationAddress(e.target.value?.toLowerCase().trim())
}
aria-label="Custom Destination Address Input"
/>
{isEOA && (
<button
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ export function TokenButton({
{({ open }) => (
<>
<Popover.Button
className="arb-hover h-full w-max rounded-bl rounded-tl px-3 py-3 text-white"
className="arb-hover h-full w-max rounded-bl rounded-tl px-3 pb-1 pt-2 text-white"
aria-label="Select Token"
onClick={onPopoverButtonClick}
disabled={disabled}
Expand All @@ -75,9 +75,7 @@ export function TokenButton({
className="h-5 w-5 sm:h-7 sm:w-7"
/>
)} */}
<span className="text-xl font-light sm:text-3xl">
{tokenSymbol}
</span>
<span className="text-xl font-light">{tokenSymbol}</span>
{!disabled && (
<ChevronDownIcon
className={twMerge(
Expand All @@ -92,7 +90,7 @@ export function TokenButton({
<Transition
// we don't unmount on leave here because otherwise transition won't work with virtualized lists
options={{ unmountOnLeave: false }}
className="fixed left-0 top-0 z-20 sm:absolute sm:top-[76px] sm:max-w-[466px]"
className="fixed right-0 top-0 z-20 sm:absolute sm:top-[76px] sm:max-w-[466px]"
afterLeave={onPopoverClose}
>
<Popover.Panel
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,6 @@ import { useNetworksRelationship } from '../../hooks/useNetworksRelationship'
import { TransferDisabledDialog } from './TransferDisabledDialog'
import { getBridgeUiConfigForChain } from '../../util/bridgeUiConfig'
import { useUpdateUSDCTokenData } from './TransferPanelMain/hooks'
import { Balances } from '../../hooks/TransferPanel/useSelectedTokenBalances'
import { useBalances } from '../../hooks/useBalances'
import { DestinationNetworkBox } from './TransferPanelMain/DestinationNetworkBox'
import { SourceNetworkBox } from './TransferPanelMain/SourceNetworkBox'
Expand Down Expand Up @@ -276,13 +275,7 @@ export function TransferPanelMain() {

const destinationAddressOrWalletAddress = destinationAddress || walletAddress

const {
ethParentBalance,
erc20ParentBalances,
updateErc20ParentBalances,
ethChildBalance,
updateErc20ChildBalances
} = useBalances()
const { updateErc20ParentBalances, updateErc20ChildBalances } = useBalances()

const { updateUSDCBalances } = useUpdateUSDCBalances({
walletAddress: destinationAddressOrWalletAddress
Expand Down Expand Up @@ -327,19 +320,6 @@ export function TransferPanelMain() {
isTeleportMode
])

// TODO: move into a hook (FS-714)
// when customFeeTokenBalances is moved to an independent hook file, use `setAmount` directly in useMaxAmount and do not pass `customFeeTokenBalances` as a prop
const customFeeTokenBalances: Balances = useMemo(() => {
if (!nativeCurrency.isCustom) {
return { parentBalance: ethParentBalance, childBalance: ethChildBalance }
}

return {
parentBalance: erc20ParentBalances?.[nativeCurrency.address] ?? null,
childBalance: ethChildBalance
}
}, [nativeCurrency, ethParentBalance, ethChildBalance, erc20ParentBalances])

const showUSDCSpecificInfo =
!isTeleportMode &&
((isTokenMainnetUSDC(selectedToken?.address) && isArbitrumOne) ||
Expand All @@ -356,17 +336,11 @@ export function TransferPanelMain() {

return (
<div className="flex flex-col pb-6 lg:gap-y-1">
<SourceNetworkBox
customFeeTokenBalances={customFeeTokenBalances}
showUsdcSpecificInfo={showUSDCSpecificInfo}
/>
<SourceNetworkBox showUsdcSpecificInfo={showUSDCSpecificInfo} />

<SwitchNetworksButton />

<DestinationNetworkBox
customFeeTokenBalances={customFeeTokenBalances}
showUsdcSpecificInfo={showUSDCSpecificInfo}
/>
<DestinationNetworkBox showUsdcSpecificInfo={showUSDCSpecificInfo} />

<TransferDisabledDialog />
</div>
Expand Down
Loading

0 comments on commit cd4de57

Please sign in to comment.