Skip to content

Commit

Permalink
bubble up fund wallet CTA
Browse files Browse the repository at this point in the history
  • Loading branch information
qrtp committed Nov 9, 2024
1 parent bb47079 commit 910c8b6
Showing 1 changed file with 160 additions and 166 deletions.
326 changes: 160 additions & 166 deletions packages/ui-components/src/components/Wallet/Swap.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -696,175 +696,169 @@ const Swap: React.FC<Props> = ({
label={t('swap.description')}
/>
<Box className={classes.container}>
<Box className={classes.content}>
{allTokens.length > 0 &&
sourceTokens.length === 0 &&
onClickBuy &&
onClickReceive ? (
<Box className={classes.noTokensContainer}>
<FundWalletModal
onBuyClicked={onClickBuy}
onReceiveClicked={onClickReceive}
/>
</Box>
) : (
<>
{showSwapIntro && (
<Alert
severity="info"
className={classes.description}
onClose={handleSwapInfoClicked}
>
<AlertTitle>{t('swap.introTitle')}</AlertTitle>
{t('swap.introContent')}
</Alert>
)}
<FormControl disabled={isLoading}>
<ManageInput
id="source-token-amount"
label={t('swap.payWithToken')}
placeholder="0.00"
value={
sourceTokenAmountUsd ? sourceTokenAmountUsd.toString() : ''
}
stacked={true}
disabled={isLoading}
onChange={handleAmountChanged}
startAdornment={<Typography ml={2}>$</Typography>}
endAdornment={
<Select
size="small"
id="source-token"
disabled={isLoading}
value={
sourceToken
? `${sourceToken.swing.chain}/${sourceToken.swing.symbol}`
: ''
}
onChange={handleSourceChange}
className={classes.dropDown}
variant="standard"
disableUnderline
>
{sourceTokens
.filter(v => getTokenEntry(v))
.map(v => (
<MenuItem
key={`source-${v.swing.chain}/${v.swing.symbol}`}
value={`${v.swing.chain}/${v.swing.symbol}`}
>
<Token
key={`source-token-${v.swing.chain}/${v.swing.symbol}`}
token={getTokenEntry(v)!}
isOwner
hideBalance
iconWidth={5}
descriptionWidth={7}
/>
</MenuItem>
))}
</Select>
}
/>
<FormHelperText className={classes.tokenBalanceContainer}>
<Box
display="flex"
justifyContent="space-between"
width="100%"
{allTokens.length > 0 &&
sourceTokens.length === 0 &&
onClickBuy &&
onClickReceive ? (
<Box className={classes.noTokensContainer}>
<FundWalletModal
onBuyClicked={onClickBuy}
onReceiveClicked={onClickReceive}
/>
</Box>
) : (
<Box className={classes.content}>
{showSwapIntro && (
<Alert
severity="info"
className={classes.description}
onClose={handleSwapInfoClicked}
>
<AlertTitle>{t('swap.introTitle')}</AlertTitle>
{t('swap.introContent')}
</Alert>
)}
<FormControl disabled={isLoading}>
<ManageInput
id="source-token-amount"
label={t('swap.payWithToken')}
placeholder="0.00"
value={
sourceTokenAmountUsd ? sourceTokenAmountUsd.toString() : ''
}
stacked={true}
disabled={isLoading}
onChange={handleAmountChanged}
startAdornment={<Typography ml={2}>$</Typography>}
endAdornment={
<Select
size="small"
id="source-token"
disabled={isLoading}
value={
sourceToken
? `${sourceToken.swing.chain}/${sourceToken.swing.symbol}`
: ''
}
onChange={handleSourceChange}
className={classes.dropDown}
variant="standard"
disableUnderline
>
<Box className={classes.tokenActionText}>
<Markdown>{sourceTokenDescription || ''}</Markdown>
</Box>
{sourceToken && (
<Box>
{t('swap.balance')}:{' '}
<b>
{getTokenEntry(sourceToken)?.value
? getTokenEntry(sourceToken)?.value.toLocaleString(
'en-US',
{
style: 'currency',
currency: 'USD',
},
)
: numeral(
getTokenEntry(sourceToken)?.balance,
).format('0.[0000]')}
</b>
</Box>
)}
</Box>
</FormHelperText>
</FormControl>
{txId ? (
<CheckIcon
className={cx(classes.swapIcon, {
[classes.successIcon]: isTxComplete,
})}
/>
) : isLoading ? (
<CircularProgress className={classes.swapIcon} />
) : (
<ImportExportIcon className={classes.swapIcon} />
)}
<FormControl disabled={isLoading}>
<ManageInput
id="destination-token-amount"
label={t('swap.receiveToken')}
placeholder="0.00"
value={
destinationTokenAmountUsd
? destinationTokenAmountUsd.toString()
: ''
}
stacked={true}
disabled={isLoading}
onChange={handleAmountChanged}
startAdornment={<Typography ml={2}>$</Typography>}
endAdornment={
<Select
size="small"
id="destination-token"
disabled={isLoading}
value={
destinationToken
? `${destinationToken.swing.chain}/${destinationToken.swing.symbol}`
: ''
}
onChange={handleDestinationChange}
className={classes.dropDown}
variant="standard"
disableUnderline
>
{destinationTokens
.filter(v => getTokenEntry(v, true))
.map(v => (
<MenuItem
key={`destination-${v.swing.chain}/${v.swing.symbol}`}
value={`${v.swing.chain}/${v.swing.symbol}`}
>
<Token
key={`destination-token-${v.swing.chain}/${v.swing.symbol}`}
token={getTokenEntry(v, true)!}
isOwner
hideBalance
iconWidth={5}
descriptionWidth={7}
/>
</MenuItem>
))}
</Select>
}
/>
<FormHelperText className={classes.tokenBalanceContainer}>
{sourceTokens
.filter(v => getTokenEntry(v))
.map(v => (
<MenuItem
key={`source-${v.swing.chain}/${v.swing.symbol}`}
value={`${v.swing.chain}/${v.swing.symbol}`}
>
<Token
key={`source-token-${v.swing.chain}/${v.swing.symbol}`}
token={getTokenEntry(v)!}
isOwner
hideBalance
iconWidth={5}
descriptionWidth={7}
/>
</MenuItem>
))}
</Select>
}
/>
<FormHelperText className={classes.tokenBalanceContainer}>
<Box display="flex" justifyContent="space-between" width="100%">
<Box className={classes.tokenActionText}>
<Markdown>{destinationTokenDescription || ''}</Markdown>
<Markdown>{sourceTokenDescription || ''}</Markdown>
</Box>
</FormHelperText>
</FormControl>
</>
)}
</Box>
{sourceToken && (
<Box>
{t('swap.balance')}:{' '}
<b>
{getTokenEntry(sourceToken)?.value
? getTokenEntry(sourceToken)?.value.toLocaleString(
'en-US',
{
style: 'currency',
currency: 'USD',
},
)
: numeral(getTokenEntry(sourceToken)?.balance).format(
'0.[0000]',
)}
</b>
</Box>
)}
</Box>
</FormHelperText>
</FormControl>
{txId ? (
<CheckIcon
className={cx(classes.swapIcon, {
[classes.successIcon]: isTxComplete,
})}
/>
) : isLoading ? (
<CircularProgress className={classes.swapIcon} />
) : (
<ImportExportIcon className={classes.swapIcon} />
)}
<FormControl disabled={isLoading}>
<ManageInput
id="destination-token-amount"
label={t('swap.receiveToken')}
placeholder="0.00"
value={
destinationTokenAmountUsd
? destinationTokenAmountUsd.toString()
: ''
}
stacked={true}
disabled={isLoading}
onChange={handleAmountChanged}
startAdornment={<Typography ml={2}>$</Typography>}
endAdornment={
<Select
size="small"
id="destination-token"
disabled={isLoading}
value={
destinationToken
? `${destinationToken.swing.chain}/${destinationToken.swing.symbol}`
: ''
}
onChange={handleDestinationChange}
className={classes.dropDown}
variant="standard"
disableUnderline
>
{destinationTokens
.filter(v => getTokenEntry(v, true))
.map(v => (
<MenuItem
key={`destination-${v.swing.chain}/${v.swing.symbol}`}
value={`${v.swing.chain}/${v.swing.symbol}`}
>
<Token
key={`destination-token-${v.swing.chain}/${v.swing.symbol}`}
token={getTokenEntry(v, true)!}
isOwner
hideBalance
iconWidth={5}
descriptionWidth={7}
/>
</MenuItem>
))}
</Select>
}
/>
<FormHelperText className={classes.tokenBalanceContainer}>
<Box className={classes.tokenActionText}>
<Markdown>{destinationTokenDescription || ''}</Markdown>
</Box>
</FormHelperText>
</FormControl>
</Box>
)}
{txId && (
<Box>
<Button
Expand Down

0 comments on commit 910c8b6

Please sign in to comment.