From 1295474dc3101d9c98f0d59f8e131536b639316f Mon Sep 17 00:00:00 2001
From: Daniel <80175477+dan437@users.noreply.github.com>
Date: Fri, 14 Jul 2023 20:48:46 +0200
Subject: [PATCH] Show a balance for the Token To, update position of the MM
fee, removes a link (#20030)
---
app/_locales/en/messages.json | 10 +++-
test/e2e/swaps/shared.js | 4 +-
.../exchange-rate-display.test.js.snap | 2 +-
.../exchange-rate-display.js | 11 +++-
.../swaps/exchange-rate-display/index.scss | 4 ++
...swaps-quotes-stories-metadata.test.js.snap | 2 +-
.../main-quote-summary.test.js.snap | 2 +-
.../prepare-swap-page/prepare-swap-page.js | 16 +++++-
.../swaps/prepare-swap-page/review-quote.js | 55 +++++++++----------
.../prepare-swap-page/review-quote.test.js | 9 ++-
.../__snapshots__/view-quote.test.js.snap | 4 +-
11 files changed, 72 insertions(+), 47 deletions(-)
diff --git a/app/_locales/en/messages.json b/app/_locales/en/messages.json
index d801f338317d..862ca35ce427 100644
--- a/app/_locales/en/messages.json
+++ b/app/_locales/en/messages.json
@@ -3086,9 +3086,6 @@
"message": "You have (1) pending transaction.",
"description": "$1 is count of pending transactions"
},
- "percentage": {
- "message": "$1%"
- },
"permissionRequest": {
"message": "Permission request"
},
@@ -4469,6 +4466,10 @@
"message": "Includes a $1% MetaMask fee.",
"description": "Provides information about the fee that metamask takes for swaps. $1 is a decimal number."
},
+ "swapIncludesMetaMaskFeeViewAllQuotes": {
+ "message": "Includes a $1% MetaMask fee – $2",
+ "description": "Provides information about the fee that metamask takes for swaps. $1 is a decimal number and $2 is a link to view all quotes."
+ },
"swapLearnMore": {
"message": "Learn more about Swaps"
},
@@ -5233,6 +5234,9 @@
"viewAllDetails": {
"message": "View all details"
},
+ "viewAllQuotes": {
+ "message": "view all quotes"
+ },
"viewContact": {
"message": "View contact"
},
diff --git a/test/e2e/swaps/shared.js b/test/e2e/swaps/shared.js
index 12fbe4ccb039..efef3b4b00d4 100644
--- a/test/e2e/swaps/shared.js
+++ b/test/e2e/swaps/shared.js
@@ -173,9 +173,7 @@ const checkNotification = async (driver, options) => {
};
const changeExchangeRate = async (driver) => {
- await driver.clickElement(
- '[data-testid="exchange-rate-display-base-symbol"]',
- );
+ await driver.clickElement('[data-testid="review-quote-view-all-quotes"]');
await driver.waitForSelector({ text: 'Quote details', tag: 'h2' });
const networkFees = await driver.findElements(
diff --git a/ui/pages/swaps/exchange-rate-display/__snapshots__/exchange-rate-display.test.js.snap b/ui/pages/swaps/exchange-rate-display/__snapshots__/exchange-rate-display.test.js.snap
index 7dc3b1256c6a..bdd3b3dfab0d 100644
--- a/ui/pages/swaps/exchange-rate-display/__snapshots__/exchange-rate-display.test.js.snap
+++ b/ui/pages/swaps/exchange-rate-display/__snapshots__/exchange-rate-display.test.js.snap
@@ -6,7 +6,7 @@ exports[`ExchangeRateDisplay renders the component with initial props 1`] = `
class="exchange-rate-display"
>
diff --git a/ui/pages/swaps/exchange-rate-display/exchange-rate-display.js b/ui/pages/swaps/exchange-rate-display/exchange-rate-display.js
index 413730c2894a..12a38e12c8eb 100644
--- a/ui/pages/swaps/exchange-rate-display/exchange-rate-display.js
+++ b/ui/pages/swaps/exchange-rate-display/exchange-rate-display.js
@@ -72,6 +72,13 @@ export default function ExchangeRateDisplay({
rateToDisplay = formatSwapsValueForDisplay(rate);
}
+ const quoteRateClassName = onQuotesClick
+ ? 'exchange-rate-display__quote-rate'
+ : 'exchange-rate-display__quote-rate--no-link';
+ const quoteRateColor = onQuotesClick
+ ? TextColor.primaryDefault
+ : TextColor.textDefault;
+
return (
1
diff --git a/ui/pages/swaps/exchange-rate-display/index.scss b/ui/pages/swaps/exchange-rate-display/index.scss
index 9a397f9822a0..f59713639344 100644
--- a/ui/pages/swaps/exchange-rate-display/index.scss
+++ b/ui/pages/swaps/exchange-rate-display/index.scss
@@ -19,4 +19,8 @@
&__quote-rate {
cursor: pointer;
}
+
+ &__quote-rate--no-link {
+ cursor: text;
+ }
}
diff --git a/ui/pages/swaps/loading-swaps-quotes/__snapshots__/loading-swaps-quotes-stories-metadata.test.js.snap b/ui/pages/swaps/loading-swaps-quotes/__snapshots__/loading-swaps-quotes-stories-metadata.test.js.snap
index 6581c8123ee8..66be56d52a69 100644
--- a/ui/pages/swaps/loading-swaps-quotes/__snapshots__/loading-swaps-quotes-stories-metadata.test.js.snap
+++ b/ui/pages/swaps/loading-swaps-quotes/__snapshots__/loading-swaps-quotes-stories-metadata.test.js.snap
@@ -27,4 +27,4 @@ exports[`storiesMetadata matches expected values for storiesMetadata 1`] = `
"icon": "",
},
}
-`;
\ No newline at end of file
+`;
diff --git a/ui/pages/swaps/main-quote-summary/__snapshots__/main-quote-summary.test.js.snap b/ui/pages/swaps/main-quote-summary/__snapshots__/main-quote-summary.test.js.snap
index 7b58f794feb2..b36e37007e03 100644
--- a/ui/pages/swaps/main-quote-summary/__snapshots__/main-quote-summary.test.js.snap
+++ b/ui/pages/swaps/main-quote-summary/__snapshots__/main-quote-summary.test.js.snap
@@ -81,7 +81,7 @@ exports[`MainQuoteSummary renders the component with initial props 4`] = `
class="exchange-rate-display main-quote-summary__exchange-rate-display"
>
diff --git a/ui/pages/swaps/prepare-swap-page/prepare-swap-page.js b/ui/pages/swaps/prepare-swap-page/prepare-swap-page.js
index f83ad48001d3..654d2b766612 100644
--- a/ui/pages/swaps/prepare-swap-page/prepare-swap-page.js
+++ b/ui/pages/swaps/prepare-swap-page/prepare-swap-page.js
@@ -586,7 +586,10 @@ export default function PrepareSwapPage({
);
};
- const swapYourTokenBalance = `${t('balance')}: ${fromTokenString || '0'}`;
+ const yourTokenFromBalance = `${t('balance')}: ${fromTokenString || '0'}`;
+ const yourTokenToBalance = `${t('balance')}: ${
+ selectedToToken?.string || '0'
+ }`;
const isDirectWrappingEnabled = shouldEnableDirectWrapping(
chainId,
@@ -883,7 +886,7 @@ export default function PrepareSwapPage({
alignItems={AlignItems.stretch}
>
- {fromTokenSymbol && swapYourTokenBalance}
+ {fromTokenSymbol && yourTokenFromBalance}
{showMaxBalanceLink && (
+
+
+ {selectedToToken?.string && yourTokenToBalance}
+
+
{!showReviewQuote && toTokenIsNotDefault && occurrences < 2 && (
diff --git a/ui/pages/swaps/prepare-swap-page/review-quote.js b/ui/pages/swaps/prepare-swap-page/review-quote.js
index a363747b981b..3e73d97ce15d 100644
--- a/ui/pages/swaps/prepare-swap-page/review-quote.js
+++ b/ui/pages/swaps/prepare-swap-page/review-quote.js
@@ -1047,7 +1047,6 @@ export default function ReviewQuote({ setReceiveToAmount }) {
>
@@ -1063,39 +1062,11 @@ export default function ReviewQuote({ setReceiveToAmount }) {
secondaryTokenValue={destinationValue}
secondaryTokenDecimals={destinationTokenDecimals}
secondaryTokenSymbol={destinationTokenSymbol}
- arrowColor="var(--color-primary-default)"
boldSymbols={false}
className="main-quote-summary__exchange-rate-display"
- onQuotesClick={
- /* istanbul ignore next */
- () => {
- trackAllAvailableQuotesOpened();
- setSelectQuotePopoverShown(true);
- }
- }
showIconForSwappingTokens={false}
/>
-
-
- {t('swapMetaMaskFee')}
-
-
- {t('percentage', [metaMaskFee])}
-
-
)}
+
+
+ {t('swapIncludesMetaMaskFeeViewAllQuotes', [
+ metaMaskFee,
+ {
+ trackAllAvailableQuotesOpened();
+ setSelectQuotePopoverShown(true);
+ }
+ }
+ size={Size.inherit}
+ >
+ {t('viewAllQuotes')}
+ ,
+ ])}
+
+
{
const { getByText } = renderWithProvider(, store);
expect(getByText('New quotes in')).toBeInTheDocument();
expect(getByText('Quote rate')).toBeInTheDocument();
- expect(getByText('MetaMask fee')).toBeInTheDocument();
+ expect(getByText('Includes a 1% MetaMask fee –')).toBeInTheDocument();
+ expect(getByText('view all quotes')).toBeInTheDocument();
expect(getByText('Estimated gas fee')).toBeInTheDocument();
expect(getByText('0.00008 ETH')).toBeInTheDocument();
expect(getByText('Max fee:')).toBeInTheDocument();
@@ -71,7 +72,8 @@ describe('ReviewQuote', () => {
const { getByText } = renderWithProvider(, store);
expect(getByText('New quotes in')).toBeInTheDocument();
expect(getByText('Quote rate')).toBeInTheDocument();
- expect(getByText('MetaMask fee')).toBeInTheDocument();
+ expect(getByText('Includes a 1% MetaMask fee –')).toBeInTheDocument();
+ expect(getByText('view all quotes')).toBeInTheDocument();
expect(getByText('Estimated gas fee')).toBeInTheDocument();
expect(getByText('0.00008 ETH')).toBeInTheDocument();
expect(getByText('Max fee:')).toBeInTheDocument();
@@ -93,7 +95,8 @@ describe('ReviewQuote', () => {
const { getByText } = renderWithProvider(, store);
expect(getByText('New quotes in')).toBeInTheDocument();
expect(getByText('Quote rate')).toBeInTheDocument();
- expect(getByText('MetaMask fee')).toBeInTheDocument();
+ expect(getByText('Includes a 1% MetaMask fee –')).toBeInTheDocument();
+ expect(getByText('view all quotes')).toBeInTheDocument();
expect(getByText('Estimated gas fee')).toBeInTheDocument();
expect(getByText('0.00008 ETH')).toBeInTheDocument();
expect(getByText('Max fee:')).toBeInTheDocument();
diff --git a/ui/pages/swaps/view-quote/__snapshots__/view-quote.test.js.snap b/ui/pages/swaps/view-quote/__snapshots__/view-quote.test.js.snap
index 9d8204c51d4f..d9ed7df327f1 100644
--- a/ui/pages/swaps/view-quote/__snapshots__/view-quote.test.js.snap
+++ b/ui/pages/swaps/view-quote/__snapshots__/view-quote.test.js.snap
@@ -38,7 +38,7 @@ exports[`ViewQuote renders the component with EIP-1559 enabled 2`] = `
class="exchange-rate-display main-quote-summary__exchange-rate-display"
>
@@ -110,7 +110,7 @@ exports[`ViewQuote renders the component with initial props 2`] = `
class="exchange-rate-display main-quote-summary__exchange-rate-display"
>