From e87c714283f674bbb45974c18fb66e9cc07bc1f7 Mon Sep 17 00:00:00 2001
From: Jyoti Puri
Date: Wed, 18 Dec 2024 19:09:02 +0530
Subject: [PATCH 1/8] fix: Remove use of boolean value for metrics properties
(#29315)
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
## **Description**
Remove use of boolean value for metrics property.
## **Related issues**
Fixes: https://github.com/MetaMask/MetaMask-planning/issues/3811
## **Manual testing steps**
NA
## **Screenshots/Recordings**
NA
## **Pre-merge author checklist**
- [X] I've followed [MetaMask Contributor
Docs](https://github.com/MetaMask/contributor-docs) and [MetaMask
Extension Coding
Standards](https://github.com/MetaMask/metamask-extension/blob/main/.github/guidelines/CODING_GUIDELINES.md).
- [X] I've completed the PR template to the best of my ability
- [X] I’ve included tests if applicable
- [X] I’ve documented my code using [JSDoc](https://jsdoc.app/) format
if applicable
- [X] I’ve applied the right labels on the PR (see [labeling
guidelines](https://github.com/MetaMask/metamask-extension/blob/main/.github/guidelines/LABELING_GUIDELINES.md)).
Not required for external contributors.
## **Pre-merge reviewer checklist**
- [ ] I've manually tested the PR (e.g. pull and build branch, run the
app, test code being changed).
- [ ] I confirm that this PR addresses all acceptance criteria described
in the ticket it closes and includes the necessary testing evidence such
as recordings and or screenshots.
---
.../hooks/useTrackERC20WithoutDecimalInformation.ts | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/ui/pages/confirmations/hooks/useTrackERC20WithoutDecimalInformation.ts b/ui/pages/confirmations/hooks/useTrackERC20WithoutDecimalInformation.ts
index 266048e11134..27417613d3cc 100644
--- a/ui/pages/confirmations/hooks/useTrackERC20WithoutDecimalInformation.ts
+++ b/ui/pages/confirmations/hooks/useTrackERC20WithoutDecimalInformation.ts
@@ -39,7 +39,7 @@ const useTrackERC20WithoutDecimalInformation = (
event: MetaMetricsEventName.SimulationIncompleteAssetDisplayed,
category: MetaMetricsEventCategory.Confirmations,
properties: {
- token_decimals_available: false,
+ token_decimals_available: 'not_available',
asset_address: tokenAddress,
asset_type: TokenStandard.ERC20,
chain_id: chainId,
From d5335c6329e8cb1e1feac85b08cd248a1573faa3 Mon Sep 17 00:00:00 2001
From: Frederik Bolding
Date: Wed, 18 Dec 2024 15:10:00 +0100
Subject: [PATCH 2/8] fix: Remove details option if permission has no
description (#29313)
## **Description**
Remove details option if permission has no description, for instance
`eth_accounts` has no description currently.
[![Open in GitHub
Codespaces](https://github.com/codespaces/badge.svg)](https://codespaces.new/MetaMask/metamask-extension/pull/29313?quickstart=1)
## **Manual testing steps**
1. Install Ethereum Provider Snap
2. Connect the Snap to an account
3. Go to Snaps settings
4. See that there is no "details" button for the eth_accounts permission
---
.../permission-cell-options.js | 26 ++++++++++++-------
1 file changed, 16 insertions(+), 10 deletions(-)
diff --git a/ui/components/app/permission-cell/permission-cell-options.js b/ui/components/app/permission-cell/permission-cell-options.js
index 5cefdf7f7d8f..f94a2b7599d3 100644
--- a/ui/components/app/permission-cell/permission-cell-options.js
+++ b/ui/components/app/permission-cell/permission-cell-options.js
@@ -49,6 +49,10 @@ export const PermissionCellOptions = ({
dispatch(revokeDynamicSnapPermissions(snapId, [permissionName]));
};
+ if (!description && !isRevokable) {
+ return null;
+ }
+
return (
{showOptions && (
-
-
- {t('details')}
-
-
+ {description && (
+
+
+ {t('details')}
+
+
+ )}
{isRevokable && (
Date: Wed, 18 Dec 2024 15:12:29 +0000
Subject: [PATCH 3/8] fix: close network/accounts toasts when opening the Edit
page (#29239)
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
## **Description**
This PR fixes the issue where toasts persist after navigating between
`Permissions view` > `Edit networks` or `Edit accounts`. The fix ensures
the toast dismisses upon navigating to edit in the Permissions modal.
[![Open in GitHub
Codespaces](https://github.com/codespaces/badge.svg)](https://codespaces.new/MetaMask/metamask-extension/pull/29239?quickstart=1)
## **Related issues**
Fixes: https://github.com/MetaMask/metamask-extension/issues/27808
## **Manual testing steps**
1. Connect a dapp and grant permissions.
2. Go to the Connection icon > Permissions view > Accounts > Edit.
3. Change the account selection.
4. Update and verify the toast confirms account permissions were
updated.
5. Navigate to Networks > Edit.
6. Change the network selection.
7. Update and verify the toast confirms network permissions were
updated.
8. Confirm no stale toast persists after each navigation.
## **Screenshots/Recordings**
### **Before**
![Brave Browser 2024-10-11 at 4 24 18
PM](https://github.com/user-attachments/assets/a011d199-e0cc-40a7-b059-16d808c18964)
### **After**
https://github.com/user-attachments/assets/6cdd3b9d-90ce-4435-aea8-cf990b8b985a
## **Pre-merge author checklist**
- [ ] I've followed [MetaMask Contributor
Docs](https://github.com/MetaMask/contributor-docs) and [MetaMask
Extension Coding
Standards](https://github.com/MetaMask/metamask-extension/blob/main/.github/guidelines/CODING_GUIDELINES.md).
- [ ] I've completed the PR template to the best of my ability.
- [ ] I’ve included tests if applicable.
- [ ] I’ve documented my code using [JSDoc](https://jsdoc.app/) format
if applicable.
- [ ] I’ve applied the right labels on the PR (see [labeling
guidelines](https://github.com/MetaMask/metamask-extension/blob/main/.github/guidelines/LABELING_GUIDELINES.md)).
Not required for external contributors.
## **Pre-merge reviewer checklist**
- [ ] I've manually tested the PR (e.g., pulled and built the branch,
ran the app, tested the code being changed).
- [ ] I confirm that this PR addresses all acceptance criteria described
in the ticket it closes and includes the necessary testing evidence such
as recordings and/or screenshots.
---
.../review-permissions-page.tsx | 6 ++
.../site-cell/site-cell.test.tsx | 81 +++++++++++++++++++
.../site-cell/site-cell.tsx | 48 ++++++-----
3 files changed, 115 insertions(+), 20 deletions(-)
create mode 100644 ui/components/multichain/pages/review-permissions-page/site-cell/site-cell.test.tsx
diff --git a/ui/components/multichain/pages/review-permissions-page/review-permissions-page.tsx b/ui/components/multichain/pages/review-permissions-page/review-permissions-page.tsx
index d71bc499717e..cb3c929b5d27 100644
--- a/ui/components/multichain/pages/review-permissions-page/review-permissions-page.tsx
+++ b/ui/components/multichain/pages/review-permissions-page/review-permissions-page.tsx
@@ -176,6 +176,11 @@ export const ReviewPermissions = () => {
setShowAccountToast(true);
};
+ const hideAllToasts = () => {
+ setShowAccountToast(false);
+ setShowNetworkToast(false);
+ };
+
return (
{
onSelectChainIds={handleSelectChainIds}
selectedAccountAddresses={connectedAccountAddresses}
selectedChainIds={connectedChainIds}
+ hideAllToasts={hideAllToasts}
/>
) : (
diff --git a/ui/components/multichain/pages/review-permissions-page/site-cell/site-cell.test.tsx b/ui/components/multichain/pages/review-permissions-page/site-cell/site-cell.test.tsx
new file mode 100644
index 000000000000..affd55cfaa66
--- /dev/null
+++ b/ui/components/multichain/pages/review-permissions-page/site-cell/site-cell.test.tsx
@@ -0,0 +1,81 @@
+import React from 'react';
+import { Provider } from 'react-redux';
+import { render, fireEvent } from '@testing-library/react';
+import configureStore from '../../../../../store/store';
+import { SiteCell } from './site-cell';
+
+describe('SiteCell', () => {
+ const store = configureStore({
+ metamask: {
+ useBlockie: false,
+ },
+ });
+
+ describe('toast handling', () => {
+ it('should call hideAllToasts when edit accounts is clicked', () => {
+ const hideAllToasts = jest.fn();
+ const { getAllByTestId } = render(
+
+ undefined}
+ onSelectChainIds={() => undefined}
+ selectedAccountAddresses={[]}
+ selectedChainIds={[]}
+ hideAllToasts={hideAllToasts}
+ />
+ ,
+ );
+
+ const editButtons = getAllByTestId('edit');
+ fireEvent.click(editButtons[0]);
+ expect(hideAllToasts).toHaveBeenCalled();
+ });
+
+ it('should call hideAllToasts when edit networks is clicked', () => {
+ const hideAllToasts = jest.fn();
+ const { getAllByTestId } = render(
+
+ undefined}
+ onSelectChainIds={() => undefined}
+ selectedAccountAddresses={[]}
+ selectedChainIds={[]}
+ hideAllToasts={hideAllToasts}
+ />
+ ,
+ );
+
+ const editButtons = getAllByTestId('edit');
+ fireEvent.click(editButtons[1]);
+ expect(hideAllToasts).toHaveBeenCalled();
+ });
+
+ it('should not throw if hideAllToasts is not provided', () => {
+ const { getAllByTestId } = render(
+
+ undefined}
+ onSelectChainIds={() => undefined}
+ selectedAccountAddresses={[]}
+ selectedChainIds={[]}
+ />
+ ,
+ );
+
+ expect(() => {
+ const editButtons = getAllByTestId('edit');
+ fireEvent.click(editButtons[0]);
+ fireEvent.click(editButtons[1]);
+ }).not.toThrow();
+ });
+ });
+});
diff --git a/ui/components/multichain/pages/review-permissions-page/site-cell/site-cell.tsx b/ui/components/multichain/pages/review-permissions-page/site-cell/site-cell.tsx
index fcb104937e28..1c91489d0d1f 100644
--- a/ui/components/multichain/pages/review-permissions-page/site-cell/site-cell.tsx
+++ b/ui/components/multichain/pages/review-permissions-page/site-cell/site-cell.tsx
@@ -38,6 +38,7 @@ type SiteCellProps = {
selectedAccountAddresses: string[];
selectedChainIds: string[];
isConnectFlow?: boolean;
+ hideAllToasts?: () => void;
};
export const SiteCell: React.FC = ({
@@ -49,6 +50,7 @@ export const SiteCell: React.FC = ({
selectedAccountAddresses,
selectedChainIds,
isConnectFlow,
+ hideAllToasts = () => undefined,
}) => {
const t = useI18nContext();
const trackEvent = useContext(MetaMetricsContext);
@@ -91,6 +93,30 @@ export const SiteCell: React.FC = ({
? t('requestingForNetwork', [selectedNetworks[0].name])
: t('requestingFor');
+ const handleOpenAccountsModal = () => {
+ hideAllToasts?.();
+ setShowEditAccountsModal(true);
+ trackEvent({
+ category: MetaMetricsEventCategory.Navigation,
+ event: MetaMetricsEventName.ViewPermissionedAccounts,
+ properties: {
+ location: 'Connect view, Permissions toast, Permissions (dapp)',
+ },
+ });
+ };
+
+ const handleOpenNetworksModal = () => {
+ hideAllToasts?.();
+ setShowEditNetworksModal(true);
+ trackEvent({
+ category: MetaMetricsEventCategory.Navigation,
+ event: MetaMetricsEventName.ViewPermissionedNetworks,
+ properties: {
+ location: 'Connect view, Permissions toast, Permissions (dapp)',
+ },
+ });
+ };
+
return (
<>
= ({
connectedMessage={accountMessageConnectedState}
unconnectedMessage={accountMessageNotConnectedState}
isConnectFlow={isConnectFlow}
- onClick={() => {
- setShowEditAccountsModal(true);
- trackEvent({
- category: MetaMetricsEventCategory.Navigation,
- event: MetaMetricsEventName.ViewPermissionedAccounts,
- properties: {
- location: 'Connect view, Permissions toast, Permissions (dapp)',
- },
- });
- }}
+ onClick={handleOpenAccountsModal}
paddingBottomValue={2}
paddingTopValue={0}
content={
@@ -136,16 +153,7 @@ export const SiteCell: React.FC = ({
connectedMessage={networkMessageConnectedState}
unconnectedMessage={networkMessageNotConnectedState}
isConnectFlow={isConnectFlow}
- onClick={() => {
- setShowEditNetworksModal(true);
- trackEvent({
- category: MetaMetricsEventCategory.Navigation,
- event: MetaMetricsEventName.ViewPermissionedNetworks,
- properties: {
- location: 'Connect view, Permissions toast, Permissions (dapp)',
- },
- });
- }}
+ onClick={handleOpenNetworksModal}
paddingTopValue={2}
paddingBottomValue={0}
content={ }
From fd9eb4837070abd041c405a94ab78d9c7e755ad8 Mon Sep 17 00:00:00 2001
From: Jony Bursztyn
Date: Wed, 18 Dec 2024 15:16:19 +0000
Subject: [PATCH 4/8] feat: center backup toast (#29200)
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
## **Description**
Centers the backup warning toast
[![Open in GitHub
Codespaces](https://github.com/codespaces/badge.svg)](https://codespaces.new/MetaMask/metamask-extension/pull/29200?quickstart=1)
## **Related issues**
Fixes:
## **Manual testing steps**
1. Go to this page...
2.
3.
## **Screenshots/Recordings**
### **Before**
### **After**
## **Pre-merge author checklist**
- [ ] I've followed [MetaMask Contributor
Docs](https://github.com/MetaMask/contributor-docs) and [MetaMask
Extension Coding
Standards](https://github.com/MetaMask/metamask-extension/blob/main/.github/guidelines/CODING_GUIDELINES.md).
- [ ] I've completed the PR template to the best of my ability
- [ ] I’ve included tests if applicable
- [ ] I’ve documented my code using [JSDoc](https://jsdoc.app/) format
if applicable
- [ ] I’ve applied the right labels on the PR (see [labeling
guidelines](https://github.com/MetaMask/metamask-extension/blob/main/.github/guidelines/LABELING_GUIDELINES.md)).
Not required for external contributors.
## **Pre-merge reviewer checklist**
- [ ] I've manually tested the PR (e.g. pull and build branch, run the
app, test code being changed).
- [ ] I confirm that this PR addresses all acceptance criteria described
in the ticket it closes and includes the necessary testing evidence such
as recordings and or screenshots.
---
ui/components/app/home-notification/index.scss | 5 ++---
1 file changed, 2 insertions(+), 3 deletions(-)
diff --git a/ui/components/app/home-notification/index.scss b/ui/components/app/home-notification/index.scss
index ec997e00e3aa..647dc7314d0d 100644
--- a/ui/components/app/home-notification/index.scss
+++ b/ui/components/app/home-notification/index.scss
@@ -10,10 +10,9 @@
border-radius: 8px;
min-height: 116px;
padding: 16px;
+ width: calc(100% - 16px);
+ max-width: 472px;
- @include design-system.screen-sm-min {
- min-width: 472px;
- }
&__content-container {
display: flex;
From 804a56f252b5d65777b183648139ec04cd450270 Mon Sep 17 00:00:00 2001
From: Brian Bergeron
Date: Wed, 18 Dec 2024 07:50:17 -0800
Subject: [PATCH 5/8] feat: event when token list is refreshed (#29300)
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
## **Description**
Adds an event when the user refreshes the token list
[![Open in GitHub
Codespaces](https://github.com/codespaces/badge.svg)](https://codespaces.new/MetaMask/metamask-extension/pull/29300?quickstart=1)
## **Related issues**
Fixes: https://consensyssoftware.atlassian.net/browse/MMASSETS-440
## **Manual testing steps**
- Enable metametrics
- Click this refresh button on the tokens tab:
- Verify an event is emitted.
I test this by adding a console.log in
`MetaMetricsController.trackEvent`, but in a production build you may be
able to check network requests.
## **Screenshots/Recordings**
### **Before**
### **After**
## **Pre-merge author checklist**
- [ ] I've followed [MetaMask Contributor
Docs](https://github.com/MetaMask/contributor-docs) and [MetaMask
Extension Coding
Standards](https://github.com/MetaMask/metamask-extension/blob/main/.github/guidelines/CODING_GUIDELINES.md).
- [ ] I've completed the PR template to the best of my ability
- [ ] I’ve included tests if applicable
- [ ] I’ve documented my code using [JSDoc](https://jsdoc.app/) format
if applicable
- [ ] I’ve applied the right labels on the PR (see [labeling
guidelines](https://github.com/MetaMask/metamask-extension/blob/main/.github/guidelines/LABELING_GUIDELINES.md)).
Not required for external contributors.
## **Pre-merge reviewer checklist**
- [ ] I've manually tested the PR (e.g. pull and build branch, run the
app, test code being changed).
- [ ] I confirm that this PR addresses all acceptance criteria described
in the ticket it closes and includes the necessary testing evidence such
as recordings and or screenshots.
---
shared/constants/metametrics.ts | 1 +
.../asset-list-control-bar.test.tsx | 62 +++++++++++++++++++
.../asset-list-control-bar.tsx | 4 ++
3 files changed, 67 insertions(+)
create mode 100644 ui/components/app/assets/asset-list/asset-list-control-bar/asset-list-control-bar.test.tsx
diff --git a/shared/constants/metametrics.ts b/shared/constants/metametrics.ts
index a65c349963ec..9b99140b7d24 100644
--- a/shared/constants/metametrics.ts
+++ b/shared/constants/metametrics.ts
@@ -766,6 +766,7 @@ export enum MetaMetricsEventName {
TokenAdded = 'Token Added',
TokenRemoved = 'Token Removed',
TokenSortPreference = 'Token Sort Preference',
+ TokenListRefreshed = 'Token List Refreshed',
NFTRemoved = 'NFT Removed',
TokenDetected = 'Token Detected',
TokenHidden = 'Token Hidden',
diff --git a/ui/components/app/assets/asset-list/asset-list-control-bar/asset-list-control-bar.test.tsx b/ui/components/app/assets/asset-list/asset-list-control-bar/asset-list-control-bar.test.tsx
new file mode 100644
index 000000000000..7c6ba579943c
--- /dev/null
+++ b/ui/components/app/assets/asset-list/asset-list-control-bar/asset-list-control-bar.test.tsx
@@ -0,0 +1,62 @@
+import React from 'react';
+import thunk from 'redux-thunk';
+import configureMockStore from 'redux-mock-store';
+import { renderWithProvider } from '../../../../../../test/jest';
+import { MetaMetricsContext } from '../../../../../contexts/metametrics';
+import {
+ MetaMetricsEventCategory,
+ MetaMetricsEventName,
+} from '../../../../../../shared/constants/metametrics';
+import AssetListControlBar from './asset-list-control-bar';
+
+describe('AssetListControlBar', () => {
+ afterEach(() => {
+ jest.clearAllMocks();
+ });
+
+ it('should fire metrics event when refresh button is clicked', async () => {
+ const store = configureMockStore([thunk])({
+ metamask: {
+ selectedNetworkClientId: 'selectedNetworkClientId',
+ networkConfigurationsByChainId: {
+ '0x1': {
+ chainId: '0x1',
+ defaultRpcEndpointIndex: 0,
+ rpcEndpoints: [
+ {
+ networkClientId: 'selectedNetworkClientId',
+ },
+ ],
+ },
+ },
+ internalAccounts: {
+ selectedAccount: 'selectedAccount',
+ accounts: {
+ selectedAccount: {},
+ },
+ },
+ },
+ });
+
+ const mockTrackEvent = jest.fn();
+
+ const { findByTestId } = renderWithProvider(
+
+
+ ,
+ store,
+ );
+
+ const importButton = await findByTestId('import-token-button');
+ importButton.click();
+
+ const refreshListItem = await findByTestId('refreshList__button');
+ refreshListItem.click();
+
+ expect(mockTrackEvent).toHaveBeenCalledTimes(1);
+ expect(mockTrackEvent).toHaveBeenCalledWith({
+ category: MetaMetricsEventCategory.Tokens,
+ event: MetaMetricsEventName.TokenListRefreshed,
+ });
+ });
+});
diff --git a/ui/components/app/assets/asset-list/asset-list-control-bar/asset-list-control-bar.tsx b/ui/components/app/assets/asset-list/asset-list-control-bar/asset-list-control-bar.tsx
index c61815a9ab0a..d335f6f41820 100644
--- a/ui/components/app/assets/asset-list/asset-list-control-bar/asset-list-control-bar.tsx
+++ b/ui/components/app/assets/asset-list/asset-list-control-bar/asset-list-control-bar.tsx
@@ -160,6 +160,10 @@ const AssetListControlBar = ({ showTokensLinks }: AssetListControlBarProps) => {
const handleRefresh = () => {
dispatch(detectTokens());
closePopover();
+ trackEvent({
+ category: MetaMetricsEventCategory.Tokens,
+ event: MetaMetricsEventName.TokenListRefreshed,
+ });
};
return (
From acdaefe8d03d79364171188f09dbc299c48d8e7d Mon Sep 17 00:00:00 2001
From: Brian Bergeron
Date: Wed, 18 Dec 2024 07:50:24 -0800
Subject: [PATCH 6/8] chore: remove `NewNetworkInfo` (#29293)
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
## **Description**
In https://github.com/MetaMask/metamask-extension/pull/28765 the
`NewNetworkInfo` modal stopped being rendered. This PR removes the
component entirely, since it's no longer referenced anywhere.
[![Open in GitHub
Codespaces](https://github.com/codespaces/badge.svg)](https://codespaces.new/MetaMask/metamask-extension/pull/29293?quickstart=1)
## **Related issues**
Fixes: https://consensyssoftware.atlassian.net/browse/MMASSETS-477
## **Manual testing steps**
No changes expected. Switching networks should continue to work.
## **Screenshots/Recordings**
### **Before**
### **After**
## **Pre-merge author checklist**
- [ ] I've followed [MetaMask Contributor
Docs](https://github.com/MetaMask/contributor-docs) and [MetaMask
Extension Coding
Standards](https://github.com/MetaMask/metamask-extension/blob/main/.github/guidelines/CODING_GUIDELINES.md).
- [ ] I've completed the PR template to the best of my ability
- [ ] I’ve included tests if applicable
- [ ] I’ve documented my code using [JSDoc](https://jsdoc.app/) format
if applicable
- [ ] I’ve applied the right labels on the PR (see [labeling
guidelines](https://github.com/MetaMask/metamask-extension/blob/main/.github/guidelines/LABELING_GUIDELINES.md)).
Not required for external contributors.
## **Pre-merge reviewer checklist**
- [ ] I've manually tested the PR (e.g. pull and build branch, run the
app, test code being changed).
- [ ] I confirm that this PR addresses all acceptance criteria described
in the ticket it closes and includes the necessary testing evidence such
as recordings and or screenshots.
---
app/_locales/de/messages.json | 37 ---
app/_locales/el/messages.json | 37 ---
app/_locales/en/messages.json | 49 +---
app/_locales/es/messages.json | 37 ---
app/_locales/fr/messages.json | 37 ---
app/_locales/hi/messages.json | 37 ---
app/_locales/id/messages.json | 37 ---
app/_locales/it/messages.json | 6 -
app/_locales/ja/messages.json | 38 ---
app/_locales/ko/messages.json | 38 ---
app/_locales/pt/messages.json | 38 ---
app/_locales/ru/messages.json | 37 ---
app/_locales/tl/messages.json | 38 ---
app/_locales/tr/messages.json | 38 ---
app/_locales/vi/messages.json | 38 ---
app/_locales/zh_CN/messages.json | 38 ---
ui/components/ui/new-network-info/index.js | 1 -
ui/components/ui/new-network-info/index.scss | 59 ----
.../ui/new-network-info/new-network-info.js | 267 ------------------
.../new-network-info.stories.js | 10 -
.../new-network-info/new-network-info.test.js | 223 ---------------
ui/components/ui/ui-components.scss | 1 -
ui/pages/routes/routes.component.test.js | 96 +------
23 files changed, 10 insertions(+), 1227 deletions(-)
delete mode 100644 ui/components/ui/new-network-info/index.js
delete mode 100644 ui/components/ui/new-network-info/index.scss
delete mode 100644 ui/components/ui/new-network-info/new-network-info.js
delete mode 100644 ui/components/ui/new-network-info/new-network-info.stories.js
delete mode 100644 ui/components/ui/new-network-info/new-network-info.test.js
diff --git a/app/_locales/de/messages.json b/app/_locales/de/messages.json
index a738b56b0fe0..946f556f1abd 100644
--- a/app/_locales/de/messages.json
+++ b/app/_locales/de/messages.json
@@ -330,9 +330,6 @@
"addingCustomNetwork": {
"message": "Netzwerk wird hinzugefügt"
},
- "addingTokens": {
- "message": "Hinzufügen von Token"
- },
"additionalNetworks": {
"message": "Zusätzliche Netzwerke"
},
@@ -627,12 +624,6 @@
"assetsDescription": {
"message": "Automatische Erkennung von Tokens in Ihrer Wallet, Anzeige von NFTs und stapelweise Aktualisierung des Kontostands"
},
- "attemptSendingAssets": {
- "message": "Wenn Sie versuchen, Assets direkt von einem Netzwerk in ein anderes zu senden, kann dies zu einem dauerhaften Asset-Verlust führen. Verwenden Sie unbedingt eine Bridge."
- },
- "attemptSendingAssetsWithPortfolio": {
- "message": "Sie können Ihre Assets verlieren, wenn Sie versuchen, sie von einem anderen Netzwerk zu versenden. Übertragen Sie Gelder sicher zwischen den Netzwerken, indem Sie eine Bridge wie $1 verwenden."
- },
"attemptToCancelSwapForFree": {
"message": "Versuch, den Swap kostenlos zu stornieren"
},
@@ -840,9 +831,6 @@
"bridgeCalculatingAmount": {
"message": "Berechnen ..."
},
- "bridgeDontSend": {
- "message": "Bridge, nicht senden"
- },
"bridgeEnterAmount": {
"message": "Betrag eingeben"
},
@@ -954,9 +942,6 @@
"message": "Klicken Sie hier, um Ihren Ledger über WebHID zu verbinden.",
"description": "Text that can be clicked to open a browser popup for connecting the ledger device via webhid"
},
- "clickToManuallyAdd": {
- "message": "Sie können Tokens jederzeit manuell hinzufügen."
- },
"close": {
"message": "Schließen"
},
@@ -2138,9 +2123,6 @@
"gasFee": {
"message": "Gas-Gebühr"
},
- "gasIsETH": {
- "message": "Gas ist $1"
- },
"gasLimit": {
"message": "Gas-Limit"
},
@@ -2702,9 +2684,6 @@
"learnScamRisk": {
"message": "Betrügereien und Sicherheitsrisiken."
},
- "learnToBridge": {
- "message": "Lernen Sie zu bridgen"
- },
"leaveMetaMask": {
"message": "MetaMask verlassen?"
},
@@ -2900,9 +2879,6 @@
"metamaskNotificationsAreOff": {
"message": "Wallet-Benachrichtigungen sind momentan nicht aktiv."
},
- "metamaskPortfolio": {
- "message": "MetaMask Portfolio."
- },
"metamaskSwapsOfflineDescription": {
"message": "MetaMask Swaps wird gewartet. Bitte versuchen Sie es später erneut."
},
@@ -3047,10 +3023,6 @@
"message": "$1 bittet um Ihre Zustimmung zu:",
"description": "$1 represents dapp name"
},
- "nativeToken": {
- "message": "Das native Token dieses Netzwerks ist $1. Dieses Token wird für die Gas-Gebühr verwendet. ",
- "description": "$1 represents the name of the native token on the current network"
- },
"nativeTokenScamWarningConversion": {
"message": "Netzwerkdetails bearbeiten"
},
@@ -5940,9 +5912,6 @@
"message": "$1 ist jetzt aktiv bei $2",
"description": "$1 represents the account name, $2 represents the network name"
},
- "switchedTo": {
- "message": "Sie verwenden jetzt"
- },
"switchingNetworksCancelsPendingConfirmations": {
"message": "Das Wechseln der Netzwerke wird alle ausstehenden Bestätigungen stornieren."
},
@@ -5979,9 +5948,6 @@
"themeDescription": {
"message": "Wählen Sie Ihr bevorzugtes MetaMask-Motiv aus."
},
- "thingsToKeep": {
- "message": "Was Sie beachten sollten:"
- },
"thirdPartySoftware": {
"message": "Mitteilung bzgl. Drittanbieter-Software",
"description": "Title of a popup modal displayed when installing a snap for the first time."
@@ -6063,9 +6029,6 @@
"tokenScamSecurityRisk": {
"message": "Token-Betrügereien und Sicherheitsrisiken"
},
- "tokenShowUp": {
- "message": "Ihre Tokens werden möglicherweise nicht automatisch in Ihrer Wallet angezeigt. "
- },
"tokenStandard": {
"message": "Token-Standard"
},
diff --git a/app/_locales/el/messages.json b/app/_locales/el/messages.json
index 7992443a500a..a02ec275c224 100644
--- a/app/_locales/el/messages.json
+++ b/app/_locales/el/messages.json
@@ -330,9 +330,6 @@
"addingCustomNetwork": {
"message": "Προσθήκη δικτύου"
},
- "addingTokens": {
- "message": "Προσθήκη tokens"
- },
"additionalNetworks": {
"message": "Επιπλέον δίκτυα"
},
@@ -627,12 +624,6 @@
"assetsDescription": {
"message": "Αυτόματος εντοπισμός tokens στο πορτοφόλι σας, εμφάνιση NFT και ομαδοποιημένες ενημερώσεις υπολοίπων λογαριασμών"
},
- "attemptSendingAssets": {
- "message": "Ενδέχεται να χάσετε τα περιουσιακά σας στοιχεία εάν προσπαθήσετε να τα στείλετε από άλλο δίκτυο. Μεταφέρετε κεφάλαια με ασφάλεια μεταξύ δικτύων χρησιμοποιώντας μια διασύνδεση."
- },
- "attemptSendingAssetsWithPortfolio": {
- "message": "Μπορεί να χάσετε τα περιουσιακά σας στοιχεία αν προσπαθήσετε να τα στείλετε από άλλο δίκτυο. Μεταφέρετε χρήματα με ασφάλεια μεταξύ δικτύων χρησιμοποιώντας μια διασύνδεση, όπως το $1"
- },
"attemptToCancelSwapForFree": {
"message": "Προσπάθεια ακύρωσης των ανταλλαγών δωρεάν"
},
@@ -840,9 +831,6 @@
"bridgeCalculatingAmount": {
"message": "Υπολογισμός..."
},
- "bridgeDontSend": {
- "message": "Μην στείλετε χωρίς διασύνδεση"
- },
"bridgeEnterAmount": {
"message": "Πληκτρολογήστε το ποσό"
},
@@ -954,9 +942,6 @@
"message": "Κάντε κλικ εδώ για να συνδέσετε το Ledger σας μέσω WebHID",
"description": "Text that can be clicked to open a browser popup for connecting the ledger device via webhid"
},
- "clickToManuallyAdd": {
- "message": "Μπορείτε πάντα να προσθέσετε τα tokens χειροκίνητα."
- },
"close": {
"message": "Κλείσιμο"
},
@@ -2138,9 +2123,6 @@
"gasFee": {
"message": "Τέλη συναλλαγών"
},
- "gasIsETH": {
- "message": "Τέλη συναλλαγής $1 "
- },
"gasLimit": {
"message": "Όριο τέλους συναλλαγής"
},
@@ -2702,9 +2684,6 @@
"learnScamRisk": {
"message": "απάτες και κίνδυνοι ασφάλειας."
},
- "learnToBridge": {
- "message": "Μάθετε για την διασύνδεση"
- },
"leaveMetaMask": {
"message": "Αποχώρηση από το MetaMask;"
},
@@ -2900,9 +2879,6 @@
"metamaskNotificationsAreOff": {
"message": "Οι ειδοποιήσεις του πορτοφολιού δεν είναι προς το παρόν ενεργές."
},
- "metamaskPortfolio": {
- "message": "MetaMask Portfolio."
- },
"metamaskSwapsOfflineDescription": {
"message": "Το MetaMask Swaps είναι υπό συντήρηση. Παρακαλείστε να επιστρέψετε αργότερα."
},
@@ -3047,10 +3023,6 @@
"message": "Το $1 ζητάει την έγκρισή σας για:",
"description": "$1 represents dapp name"
},
- "nativeToken": {
- "message": "Το αρχικό token σε αυτό το δίκτυο είναι το $1. Είναι το token που χρησιμοποιείται για τα τέλη συναλλαγών.",
- "description": "$1 represents the name of the native token on the current network"
- },
"nativeTokenScamWarningConversion": {
"message": "Επεξεργασία λεπτομερειών δικτύου"
},
@@ -5940,9 +5912,6 @@
"message": "Το $1 είναι τώρα ενεργό στο $2",
"description": "$1 represents the account name, $2 represents the network name"
},
- "switchedTo": {
- "message": "Τώρα χρησιμοποιείτε το"
- },
"switchingNetworksCancelsPendingConfirmations": {
"message": "Η αλλαγή δικτύων θα ακυρώσει όλες τις εκκρεμείς επιβεβαιώσεις"
},
@@ -5979,9 +5948,6 @@
"themeDescription": {
"message": "Επιλέξτε το προτιμώμενο θέμα σας για το MetaMask."
},
- "thingsToKeep": {
- "message": "Πράγματα που πρέπει να έχετε υπόψη σας:"
- },
"thirdPartySoftware": {
"message": "Ειδοποίηση για λογισμικό τρίτων",
"description": "Title of a popup modal displayed when installing a snap for the first time."
@@ -6063,9 +6029,6 @@
"tokenScamSecurityRisk": {
"message": "απάτες με token και κίνδυνοι ασφάλειας"
},
- "tokenShowUp": {
- "message": "Τα tokens σας ενδέχεται να μην εμφανιστούν αυτόματα στο πορτοφόλι σας."
- },
"tokenStandard": {
"message": "Πρότυπο Token"
},
diff --git a/app/_locales/en/messages.json b/app/_locales/en/messages.json
index 3bfd303e5dd0..7ddf609b48f0 100644
--- a/app/_locales/en/messages.json
+++ b/app/_locales/en/messages.json
@@ -330,9 +330,6 @@
"addingCustomNetwork": {
"message": "Adding Network"
},
- "addingTokens": {
- "message": "Adding tokens"
- },
"additionalNetworks": {
"message": "Additional networks"
},
@@ -648,12 +645,6 @@
"assetsDescription": {
"message": "Autodetect tokens in your wallet, display NFTs, and get batched account balance updates"
},
- "attemptSendingAssets": {
- "message": "You may lose your assets if you try to send them from another network. Transfer funds safely between networks by using a bridge."
- },
- "attemptSendingAssetsWithPortfolio": {
- "message": "You may lose your assets if you try to send them from another network. Transfer funds safely between networks by using a bridge, like $1"
- },
"attemptToCancelSwapForFree": {
"message": "Attempt to cancel swap for free"
},
@@ -880,9 +871,6 @@
"bridgeConfirmTwoTransactions": {
"message": "You'll need to confirm 2 transactions on your hardware wallet:"
},
- "bridgeDontSend": {
- "message": "Bridge, don't send"
- },
"bridgeEnterAmount": {
"message": "Select amount"
},
@@ -1089,9 +1077,6 @@
"message": "Click here to connect your Ledger via WebHID",
"description": "Text that can be clicked to open a browser popup for connecting the ledger device via webhid"
},
- "clickToManuallyAdd": {
- "message": "You can always add tokens manually."
- },
"close": {
"message": "Close"
},
@@ -2299,9 +2284,6 @@
"gasFee": {
"message": "Gas fee"
},
- "gasIsETH": {
- "message": "Gas is $1 "
- },
"gasLimit": {
"message": "Gas limit"
},
@@ -2387,7 +2369,9 @@
"gotIt": {
"message": "Got it"
},
- "grantExactAccess": { "message": "Grant exact access" },
+ "grantExactAccess": {
+ "message": "Grant exact access"
+ },
"grantedToWithColon": {
"message": "Granted to:"
},
@@ -2870,9 +2854,6 @@
"learnScamRisk": {
"message": "scams and security risks."
},
- "learnToBridge": {
- "message": "Learn to bridge"
- },
"leaveMetaMask": {
"message": "Leave MetaMask?"
},
@@ -3077,9 +3058,6 @@
"metamaskNotificationsAreOff": {
"message": "Wallet notifications are currently not active."
},
- "metamaskPortfolio": {
- "message": "MetaMask Portfolio."
- },
"metamaskSwapsOfflineDescription": {
"message": "MetaMask Swaps is undergoing maintenance. Please check back later."
},
@@ -3230,10 +3208,6 @@
"message": "$1 is asking for your approval to:",
"description": "$1 represents dapp name"
},
- "nativeToken": {
- "message": "The native token on this network is $1. It is the token used for gas fees. ",
- "description": "$1 represents the name of the native token on the current network"
- },
"nativeTokenScamWarningConversion": {
"message": "Edit network details"
},
@@ -4527,7 +4501,9 @@
"quotedReceiveAmount": {
"message": "$1 receive amount"
},
- "quotedTotalCost": { "message": "$1 total cost" },
+ "quotedTotalCost": {
+ "message": "$1 total cost"
+ },
"rank": {
"message": "Rank"
},
@@ -6230,9 +6206,6 @@
"message": "You're now using $1",
"description": "$1 represents the network name"
},
- "switchedTo": {
- "message": "You're now using"
- },
"switchingNetworksCancelsPendingConfirmations": {
"message": "Switching networks will cancel all pending confirmations"
},
@@ -6269,9 +6242,6 @@
"themeDescription": {
"message": "Choose your preferred MetaMask theme."
},
- "thingsToKeep": {
- "message": "Keep in mind:"
- },
"thirdPartySoftware": {
"message": "Third-party software notice",
"description": "Title of a popup modal displayed when installing a snap for the first time."
@@ -6353,9 +6323,6 @@
"tokenScamSecurityRisk": {
"message": "token scams and security risks"
},
- "tokenShowUp": {
- "message": "Your tokens may not automatically show up in your wallet. "
- },
"tokenStandard": {
"message": "Token standard"
},
@@ -6876,7 +6843,9 @@
"you": {
"message": "You"
},
- "youDeclinedTheTransaction": { "message": "You declined the transaction." },
+ "youDeclinedTheTransaction": {
+ "message": "You declined the transaction."
+ },
"youNeedToAllowCameraAccess": {
"message": "You need to allow camera access to use this feature."
},
diff --git a/app/_locales/es/messages.json b/app/_locales/es/messages.json
index 2475977d0794..8acce0ad02d9 100644
--- a/app/_locales/es/messages.json
+++ b/app/_locales/es/messages.json
@@ -330,9 +330,6 @@
"addingCustomNetwork": {
"message": "Agregando red"
},
- "addingTokens": {
- "message": "Agregando tokens"
- },
"additionalNetworks": {
"message": "Redes adicionales"
},
@@ -627,12 +624,6 @@
"assetsDescription": {
"message": "Detectar automáticamente tokens en su monedero, mostrar NFT y recibir actualizaciones de saldo de cuenta por lotes"
},
- "attemptSendingAssets": {
- "message": "Puede perder sus activos si intenta enviarlos desde otra red. Transfiera fondos de forma segura entre redes mediante el uso de un puente."
- },
- "attemptSendingAssetsWithPortfolio": {
- "message": "Puede perder sus activos si intenta enviarlos desde otra red. Transfiera fondos de forma segura entre redes usando un puente, como $1"
- },
"attemptToCancelSwapForFree": {
"message": "Intente cancelar el intercambio de forma gratuita"
},
@@ -840,9 +831,6 @@
"bridgeCalculatingAmount": {
"message": "Calculando..."
},
- "bridgeDontSend": {
- "message": "Puente, no enviar"
- },
"bridgeEnterAmount": {
"message": "Ingrese el monto"
},
@@ -954,9 +942,6 @@
"message": "Haga clic aquí para conectar su Ledger a través de WebHID",
"description": "Text that can be clicked to open a browser popup for connecting the ledger device via webhid"
},
- "clickToManuallyAdd": {
- "message": "Siempre puede agregar tókenes manualmente."
- },
"close": {
"message": "Cerrar"
},
@@ -2138,9 +2123,6 @@
"gasFee": {
"message": "Tarifa de gas"
},
- "gasIsETH": {
- "message": "El gas es $1 "
- },
"gasLimit": {
"message": "Límite de gas"
},
@@ -2702,9 +2684,6 @@
"learnScamRisk": {
"message": "estafas y riesgos en seguridad."
},
- "learnToBridge": {
- "message": "Aprenda a puentear"
- },
"leaveMetaMask": {
"message": "¿Dejar MetaMask?"
},
@@ -2900,9 +2879,6 @@
"metamaskNotificationsAreOff": {
"message": "Las notificaciones del monedero no están activas actualmente."
},
- "metamaskPortfolio": {
- "message": "MetaMask Portfolio."
- },
"metamaskSwapsOfflineDescription": {
"message": "MetaMask Swaps está en mantenimiento. Vuelva a comprobarlo más tarde."
},
@@ -3047,10 +3023,6 @@
"message": "$1 solicita su aprobación para:",
"description": "$1 represents dapp name"
},
- "nativeToken": {
- "message": "El token nativo en esta red es de $1. Es el token utilizado para las tarifas de gas. ",
- "description": "$1 represents the name of the native token on the current network"
- },
"nativeTokenScamWarningConversion": {
"message": "Editar detalles de la red"
},
@@ -5940,9 +5912,6 @@
"message": "$1 ahora está activo en $2",
"description": "$1 represents the account name, $2 represents the network name"
},
- "switchedTo": {
- "message": "Ahora está usando"
- },
"switchingNetworksCancelsPendingConfirmations": {
"message": "Cambiar de red cancelará todas las confirmaciones pendientes"
},
@@ -5979,9 +5948,6 @@
"themeDescription": {
"message": "Elija su tema MetaMask preferido."
},
- "thingsToKeep": {
- "message": "Tenga en cuenta:"
- },
"thirdPartySoftware": {
"message": "Aviso de software de terceros",
"description": "Title of a popup modal displayed when installing a snap for the first time."
@@ -6063,9 +6029,6 @@
"tokenScamSecurityRisk": {
"message": "estafas de tokens y riesgos de seguridad"
},
- "tokenShowUp": {
- "message": "Es posible que sus tókenes no aparezcan automáticamente en su monedero. "
- },
"tokenStandard": {
"message": "Estándar de tokenes"
},
diff --git a/app/_locales/fr/messages.json b/app/_locales/fr/messages.json
index abe83f8ea900..68e6626c4688 100644
--- a/app/_locales/fr/messages.json
+++ b/app/_locales/fr/messages.json
@@ -330,9 +330,6 @@
"addingCustomNetwork": {
"message": "Ajout de réseau"
},
- "addingTokens": {
- "message": "Ajouter des jetons"
- },
"additionalNetworks": {
"message": "Réseaux supplémentaires"
},
@@ -627,12 +624,6 @@
"assetsDescription": {
"message": "Détection automatique des jetons dans votre portefeuille, affichage des NFT et mise à jour du solde de plusieurs comptes"
},
- "attemptSendingAssets": {
- "message": "Si vous essayez d’envoyer des actifs directement d’un réseau à un autre, une perte permanente des actifs pourrait en résulter. Assurez-vous d’utiliser une passerelle."
- },
- "attemptSendingAssetsWithPortfolio": {
- "message": "Si vous essayez d’envoyer des actifs directement d’un réseau à un autre, vous pourriez les perdre définitivement. Utilisez une passerelle comme $1 pour transférer en toute sécurité des fonds d’un réseau à un autre"
- },
"attemptToCancelSwapForFree": {
"message": "Tentative d’annuler gratuitement le swap"
},
@@ -840,9 +831,6 @@
"bridgeCalculatingAmount": {
"message": "Calcul en cours…"
},
- "bridgeDontSend": {
- "message": "Passerelle, ne pas envoyer"
- },
"bridgeEnterAmount": {
"message": "Saisissez le montant"
},
@@ -954,9 +942,6 @@
"message": "Cliquez ici pour connecter votre Ledger via WebHID",
"description": "Text that can be clicked to open a browser popup for connecting the ledger device via webhid"
},
- "clickToManuallyAdd": {
- "message": "Vous pouvez ajouter des jetons manuellement."
- },
"close": {
"message": "Fermer"
},
@@ -2138,9 +2123,6 @@
"gasFee": {
"message": "Frais de gaz"
},
- "gasIsETH": {
- "message": "Le gaz est $1 "
- },
"gasLimit": {
"message": "Montant maximal des frais de transaction"
},
@@ -2702,9 +2684,6 @@
"learnScamRisk": {
"message": "hameçonnages et risques de sécurité."
},
- "learnToBridge": {
- "message": "Apprenez à établir une passerelle"
- },
"leaveMetaMask": {
"message": "Voulez-vous quitter MetaMask ?"
},
@@ -2900,9 +2879,6 @@
"metamaskNotificationsAreOff": {
"message": "Les notifications du portefeuille ne sont actuellement pas activées."
},
- "metamaskPortfolio": {
- "message": "Portfolio MetaMask."
- },
"metamaskSwapsOfflineDescription": {
"message": "MetaMask Swaps est en cours de maintenance. Nous vous invitons à revenir plus tard."
},
@@ -3047,10 +3023,6 @@
"message": "$1 vous demande votre approbation pour :",
"description": "$1 represents dapp name"
},
- "nativeToken": {
- "message": "Le jeton natif de ce réseau est $1. C’est le jeton utilisé pour les frais de gaz. ",
- "description": "$1 represents the name of the native token on the current network"
- },
"nativeTokenScamWarningConversion": {
"message": "Modifier les détails du réseau"
},
@@ -5940,9 +5912,6 @@
"message": "$1 est maintenant actif sur $2",
"description": "$1 represents the account name, $2 represents the network name"
},
- "switchedTo": {
- "message": "Vous êtes en train d’utiliser"
- },
"switchingNetworksCancelsPendingConfirmations": {
"message": "Le changement de réseau annulera toutes les confirmations en attente"
},
@@ -5979,9 +5948,6 @@
"themeDescription": {
"message": "Choisissez votre thème MetaMask préféré."
},
- "thingsToKeep": {
- "message": "Les choses que vous devez garder à l’esprit :"
- },
"thirdPartySoftware": {
"message": "Avis sur les logiciels développés par des tiers",
"description": "Title of a popup modal displayed when installing a snap for the first time."
@@ -6063,9 +6029,6 @@
"tokenScamSecurityRisk": {
"message": "les arnaques et les risques de piratage informatique"
},
- "tokenShowUp": {
- "message": "Il se peut que vos jetons n’apparaissent pas automatiquement dans votre portefeuille. "
- },
"tokenStandard": {
"message": "Jeton standard"
},
diff --git a/app/_locales/hi/messages.json b/app/_locales/hi/messages.json
index 4eaf54f8b012..1f96413e81ff 100644
--- a/app/_locales/hi/messages.json
+++ b/app/_locales/hi/messages.json
@@ -330,9 +330,6 @@
"addingCustomNetwork": {
"message": "नेटवर्क जोड़ रहे हैं"
},
- "addingTokens": {
- "message": "टोकन जोड़ना"
- },
"additionalNetworks": {
"message": "अतिरिक्त नेटवर्क"
},
@@ -627,12 +624,6 @@
"assetsDescription": {
"message": "अपने वॉलेट में टोकन ऑटोडिटेक्ट करें, NFT प्रदर्शित करें, और बैच अकाउंट बैलेंस संबंधी अपडेट प्राप्त करें"
},
- "attemptSendingAssets": {
- "message": "अगर आप एसेट्स को सीधे एक नेटवर्क से दूसरे नेटवर्क पर भेजने की कोशिश करते हैं, तो ऐसा करने से आपको एसेट्स का नुकसान हो सकता है। ब्रिज का इस्तेमाल करके नेटवर्कों के बीच फंड्स को सुरक्षित तरीके से ट्रांसफ़र करें।"
- },
- "attemptSendingAssetsWithPortfolio": {
- "message": "अगर आप एसेट्स को सीधे एक नेटवर्क से दूसरे नेटवर्क पर भेजने की कोशिश करते हैं, तो ऐसा करने से आपको एसेट्स का नुकसान हो सकता है। ब्रिज, जैसे like $1, का इस्तेमाल करके नेटवर्कों के बीच फंड्स को सुरक्षित तरीके से ट्रांसफ़र करें।"
- },
"attemptToCancelSwapForFree": {
"message": "स्वैप को मुफ्त में कैंसिल करने की कोशिश करें"
},
@@ -840,9 +831,6 @@
"bridgeCalculatingAmount": {
"message": "कैलकुलेट किया जा रहा है..."
},
- "bridgeDontSend": {
- "message": "ब्रिज, न भेजें"
- },
"bridgeEnterAmount": {
"message": "रकम डालें"
},
@@ -954,9 +942,6 @@
"message": "अपने Ledger को WebHID के ज़रिए कनेक्ट करने के लिए यहां क्लिक करें",
"description": "Text that can be clicked to open a browser popup for connecting the ledger device via webhid"
},
- "clickToManuallyAdd": {
- "message": "आप कभी भी मैन्युअल रूप से टोकन जोड़ सकते हैं।"
- },
"close": {
"message": "बंद करें"
},
@@ -2138,9 +2123,6 @@
"gasFee": {
"message": "गैस फीस"
},
- "gasIsETH": {
- "message": "गैस $1 है "
- },
"gasLimit": {
"message": "गैस लिमिट"
},
@@ -2702,9 +2684,6 @@
"learnScamRisk": {
"message": "घोटाले और सुरक्षा जोखिम।"
},
- "learnToBridge": {
- "message": "ब्रिज करना सीखें"
- },
"leaveMetaMask": {
"message": "MetaMask से बाहर निकलें?"
},
@@ -2900,9 +2879,6 @@
"metamaskNotificationsAreOff": {
"message": "वॉलेट नोटिफिकेशंस वर्तमान में सक्रिय नहीं हैं।"
},
- "metamaskPortfolio": {
- "message": "MetaMask Portfolio."
- },
"metamaskSwapsOfflineDescription": {
"message": "MetaMask स्वैप का रखरखाव किया जा रहा है। कृपया बाद में वापस देखें।"
},
@@ -3047,10 +3023,6 @@
"message": "$1 निम्नलिखित के लिए आपका एप्रूवल मांग रहा है:",
"description": "$1 represents dapp name"
},
- "nativeToken": {
- "message": "इस नेटवर्क पर ओरिजिनल टोकन $1 है। यह गैस फ़ीस के लिए इस्तेमाल किया जाने वाला टोकन है।",
- "description": "$1 represents the name of the native token on the current network"
- },
"nativeTokenScamWarningConversion": {
"message": "नेटवर्क का ब्यौरा बदलें"
},
@@ -5940,9 +5912,6 @@
"message": "$1 अब $2 पर एक्टिव है",
"description": "$1 represents the account name, $2 represents the network name"
},
- "switchedTo": {
- "message": "आप अब इस्तेमाल कर रहे हैं"
- },
"switchingNetworksCancelsPendingConfirmations": {
"message": "नेटवर्क स्विच करने से सभी लंबित कन्फर्मेशन कैंसिल हो जाएंगे"
},
@@ -5979,9 +5948,6 @@
"themeDescription": {
"message": "अपनी पसंदीदा MetaMask थीम चुन लें"
},
- "thingsToKeep": {
- "message": "ध्यान रखने योग्य बातें:"
- },
"thirdPartySoftware": {
"message": "थर्ड-पार्टी सॉफ्टवेयर नोटिस",
"description": "Title of a popup modal displayed when installing a snap for the first time."
@@ -6063,9 +6029,6 @@
"tokenScamSecurityRisk": {
"message": "टोकन घोटाले और सुरक्षा जोखिम"
},
- "tokenShowUp": {
- "message": "हो सकता है आपके वॉलेट में आपके टोकन ऑटोमेटिकली दिखाई नहीं दें। "
- },
"tokenStandard": {
"message": "टोकन स्टैंडर्ड"
},
diff --git a/app/_locales/id/messages.json b/app/_locales/id/messages.json
index c93bd496ac12..68bbf6477be5 100644
--- a/app/_locales/id/messages.json
+++ b/app/_locales/id/messages.json
@@ -330,9 +330,6 @@
"addingCustomNetwork": {
"message": "Menambahkan Jaringan"
},
- "addingTokens": {
- "message": "Menambahkan token"
- },
"additionalNetworks": {
"message": "Jaringan tambahan"
},
@@ -627,12 +624,6 @@
"assetsDescription": {
"message": "Autodeteksi token di dompet Anda, tampilkan NFT, dan dapatkan pembaruan saldo akun secara batch"
},
- "attemptSendingAssets": {
- "message": "Aset Anda berpotensi hilang jika mencoba mengirimnya dari jaringan lain. Transfer dana secara aman antar jaringan menggunakan bridge."
- },
- "attemptSendingAssetsWithPortfolio": {
- "message": "Aset Anda berpotensi hilang jika mencoba mengirimnya melalui jaringan lain. Transfer dana antar jaringan dengan aman menggunakan bridge, seperti $1"
- },
"attemptToCancelSwapForFree": {
"message": "Mencoba membatalkan pertukaran secara gratis"
},
@@ -840,9 +831,6 @@
"bridgeCalculatingAmount": {
"message": "Menghitung..."
},
- "bridgeDontSend": {
- "message": "Bridge, jangan kirim"
- },
"bridgeEnterAmount": {
"message": "Masukkan jumlah"
},
@@ -954,9 +942,6 @@
"message": "Klik di sini untuk menghubungkan Ledger Anda melalui WebHID",
"description": "Text that can be clicked to open a browser popup for connecting the ledger device via webhid"
},
- "clickToManuallyAdd": {
- "message": "Anda dapat menambahkan token secara manual setiap saat."
- },
"close": {
"message": "Tutup"
},
@@ -2138,9 +2123,6 @@
"gasFee": {
"message": "Biaya gas"
},
- "gasIsETH": {
- "message": "Gas bernilai $1 "
- },
"gasLimit": {
"message": "Batas gas"
},
@@ -2702,9 +2684,6 @@
"learnScamRisk": {
"message": "penipuan dan risiko keamanan."
},
- "learnToBridge": {
- "message": "Pelajari bridge"
- },
"leaveMetaMask": {
"message": "Keluar dari MetaMask?"
},
@@ -2900,9 +2879,6 @@
"metamaskNotificationsAreOff": {
"message": "Saat ini notifikasi dompet tidak aktif."
},
- "metamaskPortfolio": {
- "message": "Portfolio MetaMask."
- },
"metamaskSwapsOfflineDescription": {
"message": "MetaMask Swap sedang dalam pemeliharaan. Harap periksa kembali nanti."
},
@@ -3047,10 +3023,6 @@
"message": "$1 meminta persetujuan Anda untuk:",
"description": "$1 represents dapp name"
},
- "nativeToken": {
- "message": "Token asli di jaringan ini adalah $1. Ini merupakan token yang digunakan untuk biaya gas. ",
- "description": "$1 represents the name of the native token on the current network"
- },
"nativeTokenScamWarningConversion": {
"message": "Edit detail jaringan"
},
@@ -5940,9 +5912,6 @@
"message": "$1 kini telah aktif di $2",
"description": "$1 represents the account name, $2 represents the network name"
},
- "switchedTo": {
- "message": "Saat ini Anda menggunakan"
- },
"switchingNetworksCancelsPendingConfirmations": {
"message": "Mengalihkan jaringan akan membatalkan semua konfirmasi yang berstatus menunggu"
},
@@ -5979,9 +5948,6 @@
"themeDescription": {
"message": "Pilih tema MetaMask yang Anda sukai."
},
- "thingsToKeep": {
- "message": "Ingatlah:"
- },
"thirdPartySoftware": {
"message": "Pemberitahuan perangkat lunak pihak ketiga",
"description": "Title of a popup modal displayed when installing a snap for the first time."
@@ -6063,9 +6029,6 @@
"tokenScamSecurityRisk": {
"message": "penipuan dan risiko keamanan token"
},
- "tokenShowUp": {
- "message": "Token Anda mungkin tidak muncul secara otomatis di dompet Anda. "
- },
"tokenStandard": {
"message": "Standar token"
},
diff --git a/app/_locales/it/messages.json b/app/_locales/it/messages.json
index 05cccdac0359..c00040b84086 100644
--- a/app/_locales/it/messages.json
+++ b/app/_locales/it/messages.json
@@ -252,9 +252,6 @@
"assetOptions": {
"message": "Opzioni asset"
},
- "attemptSendingAssets": {
- "message": "Se si tenta di inviare risorse direttamente da una rete all'altra, ciò potrebbe comportare una perdita permanente della risorca coinvolta. Assicurati di usare un bridge."
- },
"attributions": {
"message": "Attribuzioni"
},
@@ -369,9 +366,6 @@
"message": "Clicca qui per connettere il tuo Ledger tramite WebHID",
"description": "Text that can be clicked to open a browser popup for connecting the ledger device via webhid"
},
- "clickToManuallyAdd": {
- "message": "Clicca qui per aggiungere manualmente i token."
- },
"close": {
"message": "Chiudi"
},
diff --git a/app/_locales/ja/messages.json b/app/_locales/ja/messages.json
index 24a2f60314cd..05f359973442 100644
--- a/app/_locales/ja/messages.json
+++ b/app/_locales/ja/messages.json
@@ -330,9 +330,6 @@
"addingCustomNetwork": {
"message": "ネットワークを追加中"
},
- "addingTokens": {
- "message": "トークンを追加しています"
- },
"additionalNetworks": {
"message": "他のネットワーク"
},
@@ -627,12 +624,6 @@
"assetsDescription": {
"message": "ウォレットのトークンを自動検出し、NFTを表示して、アカウント残高の最新情報を一括で取得します"
},
- "attemptSendingAssets": {
- "message": "別のネットワークからアセットを送ろうとすると、アセットが失われる可能性があります。ネットワーク間で安全に資金を移動するには、必ずブリッジを使用してください。"
- },
- "attemptSendingAssetsWithPortfolio": {
- "message": "別のネットワークからアセットを送ろうとすると、アセットが失われる可能性があります。ネットワーク間で安全に資金を移動するには、必ず$1などのブリッジを使用してください。"
- },
"attemptToCancelSwapForFree": {
"message": "無料でスワップのキャンセルを試行"
},
@@ -840,9 +831,6 @@
"bridgeCalculatingAmount": {
"message": "計算中..."
},
- "bridgeDontSend": {
- "message": "ブリッジを使用してください"
- },
"bridgeEnterAmount": {
"message": "金額を入力"
},
@@ -858,7 +846,6 @@
"bridgeTo": {
"message": "ブリッジ先:"
},
-
"browserNotSupported": {
"message": "ご使用のブラウザはサポートされていません..."
},
@@ -955,9 +942,6 @@
"message": "ここをクリックして、WebHIDでLedgerを接続します",
"description": "Text that can be clicked to open a browser popup for connecting the ledger device via webhid"
},
- "clickToManuallyAdd": {
- "message": "トークンはいつでも手動で追加できます。"
- },
"close": {
"message": "閉じる"
},
@@ -2139,9 +2123,6 @@
"gasFee": {
"message": "ガス代"
},
- "gasIsETH": {
- "message": "ガス代は$1です"
- },
"gasLimit": {
"message": "ガスリミット"
},
@@ -2703,9 +2684,6 @@
"learnScamRisk": {
"message": "詐欺やセキュリティのリスク。"
},
- "learnToBridge": {
- "message": "ブリッジの使い方"
- },
"leaveMetaMask": {
"message": "MetaMaskから離れますか?"
},
@@ -2901,9 +2879,6 @@
"metamaskNotificationsAreOff": {
"message": "ウォレットの通知は現在無効になっています"
},
- "metamaskPortfolio": {
- "message": "MetaMask Portfolio。"
- },
"metamaskSwapsOfflineDescription": {
"message": "MetaMask Swapsはメンテナンス中です。後でもう一度確認してください。"
},
@@ -3048,10 +3023,6 @@
"message": "$1が次の承認を求めています:",
"description": "$1 represents dapp name"
},
- "nativeToken": {
- "message": "このネットワークのネイティブトークンは$1です。ガス代にもこのトークンが使用されます。",
- "description": "$1 represents the name of the native token on the current network"
- },
"nativeTokenScamWarningConversion": {
"message": "ネットワークの詳細を編集"
},
@@ -5941,9 +5912,6 @@
"message": "$1が$2で有効になりました",
"description": "$1 represents the account name, $2 represents the network name"
},
- "switchedTo": {
- "message": "次に切り替えました:"
- },
"switchingNetworksCancelsPendingConfirmations": {
"message": "ネットワークを切り替えると、保留中の承認がすべてキャンセルされます"
},
@@ -5980,9 +5948,6 @@
"themeDescription": {
"message": "ご希望のMetaMaskテーマを選択してください。"
},
- "thingsToKeep": {
- "message": "留意点:"
- },
"thirdPartySoftware": {
"message": "サードパーティソフトウェアに関する通知",
"description": "Title of a popup modal displayed when installing a snap for the first time."
@@ -6064,9 +6029,6 @@
"tokenScamSecurityRisk": {
"message": "トークン関連の詐欺やセキュリティのリスク"
},
- "tokenShowUp": {
- "message": "トークンはウォレットに自動的に表示されない可能性があります。"
- },
"tokenStandard": {
"message": "トークン規格"
},
diff --git a/app/_locales/ko/messages.json b/app/_locales/ko/messages.json
index c261f74b4b5c..f261c0b24c06 100644
--- a/app/_locales/ko/messages.json
+++ b/app/_locales/ko/messages.json
@@ -330,9 +330,6 @@
"addingCustomNetwork": {
"message": "네트워크 추가"
},
- "addingTokens": {
- "message": "토큰 추가"
- },
"additionalNetworks": {
"message": "추가 네트워크"
},
@@ -627,12 +624,6 @@
"assetsDescription": {
"message": "지갑에서 토큰을 자동으로 감지하고, NFT를 표시하며, 계정 잔액을 일괄 업데이트하세요."
},
- "attemptSendingAssets": {
- "message": "다른 네트워크로 자산을 직접 전송하면 자산이 영구적으로 손실될 수 있습니다. 브릿지를 이용하여 네트워크 간에 자금을 안전하게 전송하세요."
- },
- "attemptSendingAssetsWithPortfolio": {
- "message": "다른 네트워크에서 자산을 전송하려고 하면 자산이 손실될 수 있습니다. $1 같은 브릿지를 사용하여 네트워크 간에 자산을 안전하게 전송하세요."
- },
"attemptToCancelSwapForFree": {
"message": "무료 스왑 취소 시도"
},
@@ -840,9 +831,6 @@
"bridgeCalculatingAmount": {
"message": "계산 중..."
},
- "bridgeDontSend": {
- "message": "전송하지 마세요, 브릿지 하세요"
- },
"bridgeEnterAmount": {
"message": "금액 입력"
},
@@ -858,7 +846,6 @@
"bridgeTo": {
"message": "브릿지 대상"
},
-
"browserNotSupported": {
"message": "지원되지 않는 브라우저입니다..."
},
@@ -955,9 +942,6 @@
"message": "WebHID를 통해 Ledger를 연결하려면 여기를 클릭하세요.",
"description": "Text that can be clicked to open a browser popup for connecting the ledger device via webhid"
},
- "clickToManuallyAdd": {
- "message": "토큰은 언제든지 직접 추가할 수 있습니다."
- },
"close": {
"message": "닫기"
},
@@ -2139,9 +2123,6 @@
"gasFee": {
"message": "가스비"
},
- "gasIsETH": {
- "message": "가스는 $1입니다 "
- },
"gasLimit": {
"message": "가스 한도"
},
@@ -2703,9 +2684,6 @@
"learnScamRisk": {
"message": "사기 및 보안 위험"
},
- "learnToBridge": {
- "message": "브릿지 알아보기"
- },
"leaveMetaMask": {
"message": "MetaMask를 나가시겠습니까?"
},
@@ -2901,9 +2879,6 @@
"metamaskNotificationsAreOff": {
"message": "현재 지갑 알림이 꺼져 있습니다."
},
- "metamaskPortfolio": {
- "message": "MetaMask Portfolio."
- },
"metamaskSwapsOfflineDescription": {
"message": "MetaMask Swaps 점검 중입니다. 나중에 다시 확인하세요."
},
@@ -3048,10 +3023,6 @@
"message": "$1에서 다음 승인을 요청합니다:",
"description": "$1 represents dapp name"
},
- "nativeToken": {
- "message": "이 네트워크의 네이티브 토큰은 $1입니다. 이는 가스비 지불에 사용하는 토큰입니다. ",
- "description": "$1 represents the name of the native token on the current network"
- },
"nativeTokenScamWarningConversion": {
"message": "네트워크 세부 정보 편집"
},
@@ -5941,9 +5912,6 @@
"message": "$1 계정이 현재 $2 네트워크에서 활성화되어 있습니다",
"description": "$1 represents the account name, $2 represents the network name"
},
- "switchedTo": {
- "message": "다음을 사용 중입니다:"
- },
"switchingNetworksCancelsPendingConfirmations": {
"message": "네트워크를 전환하면 대기 중인 모든 컨펌 작업이 취소됩니다."
},
@@ -5980,9 +5948,6 @@
"themeDescription": {
"message": "원하는 MetaMask 테마를 선택하세요."
},
- "thingsToKeep": {
- "message": "유의 사항:"
- },
"thirdPartySoftware": {
"message": "타사 소프트웨어 알림",
"description": "Title of a popup modal displayed when installing a snap for the first time."
@@ -6064,9 +6029,6 @@
"tokenScamSecurityRisk": {
"message": "토큰 사기 및 보안 위험"
},
- "tokenShowUp": {
- "message": "토큰이 지갑에 자동으로 표시되지 않을 수 있습니다. "
- },
"tokenStandard": {
"message": "토큰 표준"
},
diff --git a/app/_locales/pt/messages.json b/app/_locales/pt/messages.json
index 5a1389a0d4d6..1c3bba86966d 100644
--- a/app/_locales/pt/messages.json
+++ b/app/_locales/pt/messages.json
@@ -330,9 +330,6 @@
"addingCustomNetwork": {
"message": "Adicionar rede"
},
- "addingTokens": {
- "message": "Adicionando tokens"
- },
"additionalNetworks": {
"message": "Redes adicionais"
},
@@ -627,12 +624,6 @@
"assetsDescription": {
"message": "Detecte automaticamente os tokens em sua carteira, exiba NFTs e receba atualizações de saldo de contas em lote"
},
- "attemptSendingAssets": {
- "message": "Você poderá perder seus ativos se tentar enviá-los a partir de outra rede. Transfira fundos entre redes com segurança usando uma ponte."
- },
- "attemptSendingAssetsWithPortfolio": {
- "message": "Você poderá perder seus ativos se tentar enviá-los a partir de outra rede. Transfira os fundos com segurança entre redes usando uma ponte, como $1"
- },
"attemptToCancelSwapForFree": {
"message": "Tentar cancelar a troca sem custo"
},
@@ -840,9 +831,6 @@
"bridgeCalculatingAmount": {
"message": "Calculando..."
},
- "bridgeDontSend": {
- "message": "Usar uma ponte, não enviar"
- },
"bridgeEnterAmount": {
"message": "Insira o valor"
},
@@ -858,7 +846,6 @@
"bridgeTo": {
"message": "Ponte para"
},
-
"browserNotSupported": {
"message": "Seu navegador não é compatível..."
},
@@ -955,9 +942,6 @@
"message": "Clique aqui para conectar seu Ledger por meio do WebHID",
"description": "Text that can be clicked to open a browser popup for connecting the ledger device via webhid"
},
- "clickToManuallyAdd": {
- "message": "Sempre é possível adicionar tokens manualmente."
- },
"close": {
"message": "Fechar"
},
@@ -2139,9 +2123,6 @@
"gasFee": {
"message": "Taxa de gás"
},
- "gasIsETH": {
- "message": "O gás é $1 "
- },
"gasLimit": {
"message": "Limite de gás"
},
@@ -2703,9 +2684,6 @@
"learnScamRisk": {
"message": "golpes e riscos de segurança."
},
- "learnToBridge": {
- "message": "Aprenda a usar uma ponte"
- },
"leaveMetaMask": {
"message": "Sair da MetaMask?"
},
@@ -2901,9 +2879,6 @@
"metamaskNotificationsAreOff": {
"message": "As notificações de carteiras estão inativas no momento."
},
- "metamaskPortfolio": {
- "message": "MetaMask Portfolio."
- },
"metamaskSwapsOfflineDescription": {
"message": "O recurso de Trocas da MetaMask está em manutenção. Verifique novamente mais tarde."
},
@@ -3048,10 +3023,6 @@
"message": "$1 solicita sua aprovação para:",
"description": "$1 represents dapp name"
},
- "nativeToken": {
- "message": "O token nativo dessa rede é $1. Esse é o token usado para taxas de gás.",
- "description": "$1 represents the name of the native token on the current network"
- },
"nativeTokenScamWarningConversion": {
"message": "Editar detalhes da rede"
},
@@ -5941,9 +5912,6 @@
"message": "$1 agora está ativa na $2",
"description": "$1 represents the account name, $2 represents the network name"
},
- "switchedTo": {
- "message": "Você alternou para"
- },
"switchingNetworksCancelsPendingConfirmations": {
"message": "A alternância de redes cancelará todas as confirmações pendentes"
},
@@ -5980,9 +5948,6 @@
"themeDescription": {
"message": "Escolha o seu tema preferido para a MetaMask."
},
- "thingsToKeep": {
- "message": "Informações importantes:"
- },
"thirdPartySoftware": {
"message": "Aviso de software de terceiros",
"description": "Title of a popup modal displayed when installing a snap for the first time."
@@ -6064,9 +6029,6 @@
"tokenScamSecurityRisk": {
"message": "golpes e riscos de segurança envolvendo tokens"
},
- "tokenShowUp": {
- "message": "Seus tokens podem não aparecer automaticamente em sua carteira."
- },
"tokenStandard": {
"message": "Padrão de token"
},
diff --git a/app/_locales/ru/messages.json b/app/_locales/ru/messages.json
index 37a672ec798a..fd0b0b84fcb4 100644
--- a/app/_locales/ru/messages.json
+++ b/app/_locales/ru/messages.json
@@ -330,9 +330,6 @@
"addingCustomNetwork": {
"message": "Добавление сети"
},
- "addingTokens": {
- "message": "Добавление токенов"
- },
"additionalNetworks": {
"message": "Дополнительные сети"
},
@@ -627,12 +624,6 @@
"assetsDescription": {
"message": "Автоматически обнаруживайте токены в своем кошельке, отображайте NFT и получайте пакетные обновления баланса счета"
},
- "attemptSendingAssets": {
- "message": "Вы можете потерять свои активы, если попытаетесь отправить их из другой сети. Безопасно переводите средства между сетями с помощью моста."
- },
- "attemptSendingAssetsWithPortfolio": {
- "message": "Попытка отправки активов напрямую из одной сети в другую может привести к необратимой потере активов. Следует использовать мост, такой как $1"
- },
"attemptToCancelSwapForFree": {
"message": "Бесплатная попытка отменить своп"
},
@@ -840,9 +831,6 @@
"bridgeCalculatingAmount": {
"message": "Расчет..."
},
- "bridgeDontSend": {
- "message": "Мост, не отправлять"
- },
"bridgeEnterAmount": {
"message": "Введите сумму"
},
@@ -954,9 +942,6 @@
"message": "Нажмите здесь, чтобы подключить свой Ledger через WebHID",
"description": "Text that can be clicked to open a browser popup for connecting the ledger device via webhid"
},
- "clickToManuallyAdd": {
- "message": "Вы также можете добавлять токены вручную."
- },
"close": {
"message": "Закрыть"
},
@@ -2138,9 +2123,6 @@
"gasFee": {
"message": "Плата за газ"
},
- "gasIsETH": {
- "message": "Газ стоит $1 "
- },
"gasLimit": {
"message": "Лимит газа"
},
@@ -2702,9 +2684,6 @@
"learnScamRisk": {
"message": "мошенничество и угрозы безопасности."
},
- "learnToBridge": {
- "message": "Научитесь создавать мост для"
- },
"leaveMetaMask": {
"message": "Выйти из MetaMask?"
},
@@ -2900,9 +2879,6 @@
"metamaskNotificationsAreOff": {
"message": "Уведомления кошелька в настоящее время неактивны."
},
- "metamaskPortfolio": {
- "message": "MetaMask Portfolio."
- },
"metamaskSwapsOfflineDescription": {
"message": "Сервис свопов MetaMask на техобслуживании. Зайдите позже."
},
@@ -3047,10 +3023,6 @@
"message": "$1 запрашивает ваше одобрение на:",
"description": "$1 represents dapp name"
},
- "nativeToken": {
- "message": "Нативный токен этой сети — $1. Этот токен используется для внесения платы за газ. ",
- "description": "$1 represents the name of the native token on the current network"
- },
"nativeTokenScamWarningConversion": {
"message": "Изменить сведения о сети"
},
@@ -5940,9 +5912,6 @@
"message": "$1 теперь активен в $2",
"description": "$1 represents the account name, $2 represents the network name"
},
- "switchedTo": {
- "message": "Сейчас вы используете"
- },
"switchingNetworksCancelsPendingConfirmations": {
"message": "В случае смены сетей все ожидающие подтверждения будут отменены"
},
@@ -5979,9 +5948,6 @@
"themeDescription": {
"message": "Выберите предпочитаемую тему MetaMask."
},
- "thingsToKeep": {
- "message": "Что нужно помнить:"
- },
"thirdPartySoftware": {
"message": "Уведомление о стороннем ПО",
"description": "Title of a popup modal displayed when installing a snap for the first time."
@@ -6063,9 +6029,6 @@
"tokenScamSecurityRisk": {
"message": "мошенничество с токенами и угрозы безопасности"
},
- "tokenShowUp": {
- "message": "Ваши токены могут не отображаться автоматически в вашем кошельке. "
- },
"tokenStandard": {
"message": "Стандарт токена"
},
diff --git a/app/_locales/tl/messages.json b/app/_locales/tl/messages.json
index 20b318456d77..4c201294dcdb 100644
--- a/app/_locales/tl/messages.json
+++ b/app/_locales/tl/messages.json
@@ -330,9 +330,6 @@
"addingCustomNetwork": {
"message": "Nagdaragdag ng Network"
},
- "addingTokens": {
- "message": "Nagdaragdag ng mga token"
- },
"additionalNetworks": {
"message": "Mga karagdagang network"
},
@@ -627,12 +624,6 @@
"assetsDescription": {
"message": "I-autodetect ang mga token sa wallet mo, ipakita ang mga NFT, at kumuha ng naka-batch na mga update sa balanse ng account"
},
- "attemptSendingAssets": {
- "message": "Maaari mong mawala ang mga asset kung susubukan mo itong ipadala mula sa isang network papunta sa isa pa. Ligtas ng maglipat ng pondo sa pagitan ng mga network sa pamamagitan ng paggamit ng bridge."
- },
- "attemptSendingAssetsWithPortfolio": {
- "message": "Maaaring mawala ang iyong mga asset kung susubukan mong ipadala ito mula sa ibang network. Ilipat ang mga pondo nang ligtas sa pagitan ng mga network gamit ang isang bridge, tulad ng $1"
- },
"attemptToCancelSwapForFree": {
"message": "Subukang kanselahin ang swap nang libre"
},
@@ -840,9 +831,6 @@
"bridgeCalculatingAmount": {
"message": "Nagkakalkula..."
},
- "bridgeDontSend": {
- "message": "Bridge, huwag ipadala"
- },
"bridgeEnterAmount": {
"message": "Ilagay ang halaga"
},
@@ -858,7 +846,6 @@
"bridgeTo": {
"message": "I-bridge papunta sa"
},
-
"browserNotSupported": {
"message": "Hindi sinusuportahan ang iyong browser..."
},
@@ -955,9 +942,6 @@
"message": "Mag-click dito upang ikonekta ang iyong Ledger sa pamamagitan ng WebHID",
"description": "Text that can be clicked to open a browser popup for connecting the ledger device via webhid"
},
- "clickToManuallyAdd": {
- "message": "Maaari ka ring magdagdag ng mga token nang manu-mano."
- },
"close": {
"message": "Isara"
},
@@ -2139,9 +2123,6 @@
"gasFee": {
"message": "Bayad sa gas"
},
- "gasIsETH": {
- "message": "Ang gas ay $1 "
- },
"gasLimit": {
"message": "Limitasyon ng gas"
},
@@ -2703,9 +2684,6 @@
"learnScamRisk": {
"message": "mga panloloko at panganib sa seguridad."
},
- "learnToBridge": {
- "message": "Matutong mag-bridge"
- },
"leaveMetaMask": {
"message": "Umalis sa MetaMask?"
},
@@ -2901,9 +2879,6 @@
"metamaskNotificationsAreOff": {
"message": "Hindi active sa kasalukuyan ang mga notipikasyon sa wallet."
},
- "metamaskPortfolio": {
- "message": "MetaMask Portfolio."
- },
"metamaskSwapsOfflineDescription": {
"message": "Kasalukuyang minementina ang MetaMask Swaps. Bumalik sa ibang pagkakataon."
},
@@ -3048,10 +3023,6 @@
"message": "Ang $1 ay humihiling ng iyong pag-apruba para:",
"description": "$1 represents dapp name"
},
- "nativeToken": {
- "message": "Ang native token sa network na ito ay $1. Ito ang token na ginagamit para sa mga gas fee. ",
- "description": "$1 represents the name of the native token on the current network"
- },
"nativeTokenScamWarningConversion": {
"message": "I-edit ang mga detalye ng network"
},
@@ -5941,9 +5912,6 @@
"message": "Ang $1 ay aktibo ngayon sa $2",
"description": "$1 represents the account name, $2 represents the network name"
},
- "switchedTo": {
- "message": "Lumipat ka sa"
- },
"switchingNetworksCancelsPendingConfirmations": {
"message": "Ang paglipat ng network ay magkakansela ng lahat ng nakabinbing kumpirmasyon"
},
@@ -5980,9 +5948,6 @@
"themeDescription": {
"message": "Piliin ang mas gusto mong tema ng MetaMask."
},
- "thingsToKeep": {
- "message": "Mga bagay na dapat tandaan:"
- },
"thirdPartySoftware": {
"message": "Paunawa ng third-party na software",
"description": "Title of a popup modal displayed when installing a snap for the first time."
@@ -6064,9 +6029,6 @@
"tokenScamSecurityRisk": {
"message": "mga panloloko sa token at panganib sa seguridad"
},
- "tokenShowUp": {
- "message": "Maaaring hindi awtomatikong lumabas ang iyong mga token sa iyong wallet. "
- },
"tokenStandard": {
"message": "Pamantayan ng token"
},
diff --git a/app/_locales/tr/messages.json b/app/_locales/tr/messages.json
index 470bb934f74b..f55ea0c69c14 100644
--- a/app/_locales/tr/messages.json
+++ b/app/_locales/tr/messages.json
@@ -330,9 +330,6 @@
"addingCustomNetwork": {
"message": "Ağ Ekleniyor"
},
- "addingTokens": {
- "message": "Token'leri ekleme"
- },
"additionalNetworks": {
"message": "İlave ağlar"
},
@@ -627,12 +624,6 @@
"assetsDescription": {
"message": "Cüzdanınızdaki token'ler otomatik algılansın, NFT'ler gösterilsin ve toplu hesap bakiye güncellemeleri alınsın"
},
- "attemptSendingAssets": {
- "message": "Varlıklarınızı doğrudan bir ağdan diğerine göndermeye çalışırsanız onları kaybedebilirsiniz. Fonları köprü kullanarak ağlar arasında güvenli bir şekilde transfer edin."
- },
- "attemptSendingAssetsWithPortfolio": {
- "message": "Varlıkları doğrudan bir ağdan diğerine göndermeye çalışırsanız bu durum kalıcı varlık kaybına neden olabilir. $1 gibi bir köprü kullandığınızdan emin olun"
- },
"attemptToCancelSwapForFree": {
"message": "Swap işlemini ücretsiz iptal etme girişimi"
},
@@ -840,9 +831,6 @@
"bridgeCalculatingAmount": {
"message": "Hesaplanıyor..."
},
- "bridgeDontSend": {
- "message": "Köprü yap, gönderme"
- },
"bridgeEnterAmount": {
"message": "Miktar girin"
},
@@ -858,7 +846,6 @@
"bridgeTo": {
"message": "Şuraya köprü:"
},
-
"browserNotSupported": {
"message": "Tarayıcınız desteklenmiyor..."
},
@@ -955,9 +942,6 @@
"message": "WebHID üzerinden Ledger'ınızı bağlamak için tıklayın",
"description": "Text that can be clicked to open a browser popup for connecting the ledger device via webhid"
},
- "clickToManuallyAdd": {
- "message": "Dilediğiniz zaman tokenleri manuel olarak ekleyebilirsiniz."
- },
"close": {
"message": "Kapat"
},
@@ -2139,9 +2123,6 @@
"gasFee": {
"message": "Gaz ücreti"
},
- "gasIsETH": {
- "message": "Gaz $1 "
- },
"gasLimit": {
"message": "Gaz limiti"
},
@@ -2703,9 +2684,6 @@
"learnScamRisk": {
"message": "dolandırıcılıklar ve güvenlik riskleri."
},
- "learnToBridge": {
- "message": "Köprü yapmayı öğren"
- },
"leaveMetaMask": {
"message": "MetaMask'ten ayrıl?"
},
@@ -2901,9 +2879,6 @@
"metamaskNotificationsAreOff": {
"message": "Cüzdan bildirimleri şu anda aktif değil."
},
- "metamaskPortfolio": {
- "message": "MetaMask Portfolio."
- },
"metamaskSwapsOfflineDescription": {
"message": "MetaMask Swap İşlemleri bakımda. Lütfen daha sonra tekrar kontrol edin."
},
@@ -3048,10 +3023,6 @@
"message": "$1 sizden şunun için onay istiyor:",
"description": "$1 represents dapp name"
},
- "nativeToken": {
- "message": "Bu ağdaki yerli token $1. Bu, gaz ücretleri için kullanılan tokendir. ",
- "description": "$1 represents the name of the native token on the current network"
- },
"nativeTokenScamWarningConversion": {
"message": "Ağ bilgilerini düzenle"
},
@@ -5941,9 +5912,6 @@
"message": "$1, $2 üzerinde aktif",
"description": "$1 represents the account name, $2 represents the network name"
},
- "switchedTo": {
- "message": "Şu anda kullandığınız ağ"
- },
"switchingNetworksCancelsPendingConfirmations": {
"message": "Ağ değiştirmek bekleyen tüm onayları iptal eder"
},
@@ -5980,9 +5948,6 @@
"themeDescription": {
"message": "Tercih ettiğin MetaMask temasını seç."
},
- "thingsToKeep": {
- "message": "Unutulmaması gerekenler:"
- },
"thirdPartySoftware": {
"message": "Üçüncü taraf yazılım uyarısı",
"description": "Title of a popup modal displayed when installing a snap for the first time."
@@ -6064,9 +6029,6 @@
"tokenScamSecurityRisk": {
"message": "token dolandırıcılıkları ve güvenlik riskleri"
},
- "tokenShowUp": {
- "message": "Tokenleriniz cüzdanınızda otomatik olarak görünmeyebilir. "
- },
"tokenStandard": {
"message": "Token standardı"
},
diff --git a/app/_locales/vi/messages.json b/app/_locales/vi/messages.json
index d331ab42b9b5..07262f16cbd2 100644
--- a/app/_locales/vi/messages.json
+++ b/app/_locales/vi/messages.json
@@ -330,9 +330,6 @@
"addingCustomNetwork": {
"message": "Thêm mạng"
},
- "addingTokens": {
- "message": "Đang thêm token"
- },
"additionalNetworks": {
"message": "Mạng bổ sung"
},
@@ -627,12 +624,6 @@
"assetsDescription": {
"message": "Tự động phát hiện token trong ví của bạn, hiển thị NFT và nhận hàng loạt thông tin cập nhật về số dư tài khoản"
},
- "attemptSendingAssets": {
- "message": "Bạn có thể bị mất tài sản nếu cố gắng gửi tài sản từ một mạng khác. Chuyển tiền an toàn giữa các mạng bằng cách sử dụng cầu nối."
- },
- "attemptSendingAssetsWithPortfolio": {
- "message": "Bạn có thể bị mất tài sản nếu cố gắng gửi tài sản từ một mạng khác. Chuyển tiền an toàn giữa các mạng bằng cách sử dụng cầu nối, chẳng hạn như $1"
- },
"attemptToCancelSwapForFree": {
"message": "Cố gắng hủy hoán đổi miễn phí"
},
@@ -840,9 +831,6 @@
"bridgeCalculatingAmount": {
"message": "Đang tính toán..."
},
- "bridgeDontSend": {
- "message": "Cầu nối, không gửi"
- },
"bridgeEnterAmount": {
"message": "Nhập số tiền"
},
@@ -858,7 +846,6 @@
"bridgeTo": {
"message": "Cầu nối đến"
},
-
"browserNotSupported": {
"message": "Trình duyệt của bạn không được hỗ trợ..."
},
@@ -955,9 +942,6 @@
"message": "Nhấp vào đây để kết nối với ví Ledger của bạn qua WebHID",
"description": "Text that can be clicked to open a browser popup for connecting the ledger device via webhid"
},
- "clickToManuallyAdd": {
- "message": "Bạn luôn có thể thêm token theo cách thủ công."
- },
"close": {
"message": "Đóng"
},
@@ -2139,9 +2123,6 @@
"gasFee": {
"message": "Phí gas"
},
- "gasIsETH": {
- "message": "Gas là $1 "
- },
"gasLimit": {
"message": "Hạn mức phí gas"
},
@@ -2703,9 +2684,6 @@
"learnScamRisk": {
"message": "lừa đảo và nguy cơ bảo mật."
},
- "learnToBridge": {
- "message": "Tìm hiểu cách sử dụng cầu nối"
- },
"leaveMetaMask": {
"message": "Rời khỏi MetaMask?"
},
@@ -2901,9 +2879,6 @@
"metamaskNotificationsAreOff": {
"message": "Thông báo ví hiện không hoạt động."
},
- "metamaskPortfolio": {
- "message": "MetaMask Portfolio."
- },
"metamaskSwapsOfflineDescription": {
"message": "Tính năng Hoán đổi trên MetaMask đang được bảo trì. Vui lòng kiểm tra lại sau."
},
@@ -3048,10 +3023,6 @@
"message": "$1 đang yêu cầu sự chấp thuận của bạn cho:",
"description": "$1 represents dapp name"
},
- "nativeToken": {
- "message": "Token gốc của mạng này là $1. Token này được dùng làm phí gas.",
- "description": "$1 represents the name of the native token on the current network"
- },
"nativeTokenScamWarningConversion": {
"message": "Chỉnh sửa thông tin mạng"
},
@@ -5941,9 +5912,6 @@
"message": "$1 hiện đang hoạt động trên $2",
"description": "$1 represents the account name, $2 represents the network name"
},
- "switchedTo": {
- "message": "Bạn hiện đang sử dụng"
- },
"switchingNetworksCancelsPendingConfirmations": {
"message": "Khi bạn chuyển mạng, mọi xác nhận đang chờ xử lý sẽ bị hủy"
},
@@ -5980,9 +5948,6 @@
"themeDescription": {
"message": "Chọn chủ đề MetaMask yêu thích của bạn."
},
- "thingsToKeep": {
- "message": "Những điều cần lưu ý:"
- },
"thirdPartySoftware": {
"message": "Thông báo phần mềm của bên thứ ba",
"description": "Title of a popup modal displayed when installing a snap for the first time."
@@ -6064,9 +6029,6 @@
"tokenScamSecurityRisk": {
"message": "rủi ro về bảo mật và lừa đảo token"
},
- "tokenShowUp": {
- "message": "Các token có thể không tự động hiển thị trong ví của bạn. "
- },
"tokenStandard": {
"message": "Tiêu chuẩn token"
},
diff --git a/app/_locales/zh_CN/messages.json b/app/_locales/zh_CN/messages.json
index 52941dcc24f9..944ad47289f0 100644
--- a/app/_locales/zh_CN/messages.json
+++ b/app/_locales/zh_CN/messages.json
@@ -330,9 +330,6 @@
"addingCustomNetwork": {
"message": "正在添加网络"
},
- "addingTokens": {
- "message": "正在添加代币"
- },
"additionalNetworks": {
"message": "其他网络"
},
@@ -627,12 +624,6 @@
"assetsDescription": {
"message": "自动检测钱包中的代币,显示 NFT,并获取批量账户余额更新"
},
- "attemptSendingAssets": {
- "message": "如果您试图将资产从一个网络直接发送到另一个网络,这可能会导致永久的资产损失。请务必使用跨链桥进行操作。"
- },
- "attemptSendingAssetsWithPortfolio": {
- "message": "如果您尝试将资产从一个网络发送到另一个网络,这可能会导致资产损失。请务必使用跨链桥在不同网络间安全转移资金,例如 $1"
- },
"attemptToCancelSwapForFree": {
"message": "尝试免费取消兑换"
},
@@ -840,9 +831,6 @@
"bridgeCalculatingAmount": {
"message": "正在计算......"
},
- "bridgeDontSend": {
- "message": "跨链桥,不要发送"
- },
"bridgeEnterAmount": {
"message": "输入金额"
},
@@ -858,7 +846,6 @@
"bridgeTo": {
"message": "桥接至"
},
-
"browserNotSupported": {
"message": "您的浏览器不受支持……"
},
@@ -955,9 +942,6 @@
"message": "点击这里以通过 WebHID 连接您的 Ledger",
"description": "Text that can be clicked to open a browser popup for connecting the ledger device via webhid"
},
- "clickToManuallyAdd": {
- "message": "请点击这里,以手动添加代币。"
- },
"close": {
"message": "关闭"
},
@@ -2139,9 +2123,6 @@
"gasFee": {
"message": "燃料费"
},
- "gasIsETH": {
- "message": "燃料是 $1 "
- },
"gasLimit": {
"message": "燃料限制"
},
@@ -2703,9 +2684,6 @@
"learnScamRisk": {
"message": "欺诈和安全风险信息。"
},
- "learnToBridge": {
- "message": "了解跨链桥"
- },
"leaveMetaMask": {
"message": "要离开 MetaMask?"
},
@@ -2901,9 +2879,6 @@
"metamaskNotificationsAreOff": {
"message": "钱包通知目前未开启。"
},
- "metamaskPortfolio": {
- "message": "MetaMask Portfolio。"
- },
"metamaskSwapsOfflineDescription": {
"message": "MetaMask Swaps 正在进行维护。请稍后再查看。"
},
@@ -3048,10 +3023,6 @@
"message": "$1 请求您的批准,以便:",
"description": "$1 represents dapp name"
},
- "nativeToken": {
- "message": "此网络上的原生代币为 $1。它是用于燃料费的代币。 ",
- "description": "$1 represents the name of the native token on the current network"
- },
"nativeTokenScamWarningConversion": {
"message": "编辑网络详情"
},
@@ -5941,9 +5912,6 @@
"message": "$1 现已在 $2 上激活",
"description": "$1 represents the account name, $2 represents the network name"
},
- "switchedTo": {
- "message": "您现在使用的是"
- },
"switchingNetworksCancelsPendingConfirmations": {
"message": "切换网络将取消所有待处理的确认"
},
@@ -5980,9 +5948,6 @@
"themeDescription": {
"message": "选择您喜欢的MetaMask主题。"
},
- "thingsToKeep": {
- "message": "注意事项:"
- },
"thirdPartySoftware": {
"message": "第三方软件通告",
"description": "Title of a popup modal displayed when installing a snap for the first time."
@@ -6064,9 +6029,6 @@
"tokenScamSecurityRisk": {
"message": "代币欺诈和安全风险。"
},
- "tokenShowUp": {
- "message": "您的代币可能不会自动显示在您的钱包中。"
- },
"tokenStandard": {
"message": "代币标准"
},
diff --git a/ui/components/ui/new-network-info/index.js b/ui/components/ui/new-network-info/index.js
deleted file mode 100644
index e4bd2dcdbd3e..000000000000
--- a/ui/components/ui/new-network-info/index.js
+++ /dev/null
@@ -1 +0,0 @@
-export { default } from './new-network-info';
diff --git a/ui/components/ui/new-network-info/index.scss b/ui/components/ui/new-network-info/index.scss
deleted file mode 100644
index 989a927bb251..000000000000
--- a/ui/components/ui/new-network-info/index.scss
+++ /dev/null
@@ -1,59 +0,0 @@
-.new-network-info {
- &__wrapper {
- box-shadow: 0 4px 20px rgba(0, 0, 0, 0.214);
- border-radius: 8px;
-
- .popover-footer {
- border-top: none;
- width: 100%;
- gap: 16px;
-
- .footer__button {
- flex: 1;
- flex-grow: 1;
- white-space: nowrap;
- overflow: hidden;
- }
-
- a:hover > span {
- color: var(--inherit);
- }
- }
-
- .popover-header {
- padding-bottom: 1px;
- }
-
- .popover-header__button {
- color: var(--color-icon-default);
- }
- }
-
- &__token-box {
- align-self: center;
- margin-top: 8px;
- max-width: 245px;
- }
-
- &__button {
- display: contents;
- padding: 0;
- }
-
- &__bullet-icon-container {
- background-color: var(--color-info-muted);
- border-radius: 50%;
- padding: 6px;
-
- .mm-icon {
- display: flex;
- color: var(--color-info-default);
- }
- }
-}
-
-.chip--with-left-icon {
- padding-left: 8px;
- padding-top: 8px;
- padding-bottom: 8px;
-}
diff --git a/ui/components/ui/new-network-info/new-network-info.js b/ui/components/ui/new-network-info/new-network-info.js
deleted file mode 100644
index 9d4df0ec63ec..000000000000
--- a/ui/components/ui/new-network-info/new-network-info.js
+++ /dev/null
@@ -1,267 +0,0 @@
-import React, { useCallback, useContext, useEffect, useState } from 'react';
-import { useSelector } from 'react-redux';
-import { TOKEN_API_METASWAP_CODEFI_URL } from '../../../../shared/constants/tokens';
-import fetchWithCache from '../../../../shared/lib/fetch-with-cache';
-import { I18nContext } from '../../../contexts/i18n';
-import { getProviderConfig } from '../../../../shared/modules/selectors/networks';
-import {
- AlignItems,
- BackgroundColor,
- BorderColor,
- Color,
- Display,
- FlexDirection,
- TextAlign,
- TextColor,
- TextVariant,
-} from '../../../helpers/constants/design-system';
-import {
- getCurrentNetwork,
- getIsBridgeChain,
- getMetaMetricsId,
- getUseTokenDetection,
- getUseExternalServices,
- getParticipateInMetaMetrics,
- getDataCollectionForMarketing,
-} from '../../../selectors';
-import {
- PickerNetwork,
- Text,
- Box,
- Button,
- Icon,
- IconName,
- ButtonPrimarySize,
- IconSize,
- AvatarNetworkSize,
-} from '../../component-library';
-import Popover from '../popover';
-import { getPortfolioUrl } from '../../../helpers/utils/portfolio';
-import ZENDESK_URLS from '../../../helpers/constants/zendesk-url';
-
-export default function NewNetworkInfo() {
- const t = useContext(I18nContext);
- const [tokenDetectionSupported, setTokenDetectionSupported] = useState(false);
- const [showPopup, setShowPopup] = useState(true);
- const [isLoading, setIsLoading] = useState(true);
- const autoDetectToken = useSelector(getUseTokenDetection);
- const areExternalServicesEnabled = useSelector(getUseExternalServices);
- const providerConfig = useSelector(getProviderConfig);
- const currentNetwork = useSelector(getCurrentNetwork);
- const metaMetricsId = useSelector(getMetaMetricsId);
- const isBridgeChain = useSelector(getIsBridgeChain);
- const isMetaMetricsEnabled = useSelector(getParticipateInMetaMetrics);
- const isMarketingEnabled = useSelector(getDataCollectionForMarketing);
-
- const onCloseClick = () => {
- setShowPopup(false);
- };
-
- const checkTokenDetection = useCallback(async () => {
- setIsLoading(true);
- const fetchedTokenData = await fetchWithCache({
- url: `${TOKEN_API_METASWAP_CODEFI_URL}${providerConfig.chainId}?occurrenceFloor=100&includeNativeAssets=false`,
- functionName: 'getIsTokenDetectionSupported',
- });
- const isTokenDetectionSupported = !fetchedTokenData?.error;
- setTokenDetectionSupported(isTokenDetectionSupported);
- setIsLoading(false);
- }, [providerConfig.chainId]);
-
- useEffect(() => {
- if (!areExternalServicesEnabled) {
- return;
- }
- checkTokenDetection();
- // we want to only fetch once
- // eslint-disable-next-line react-hooks/exhaustive-deps
- }, []);
-
- return (
- !isLoading &&
- showPopup && (
-
-
-
- {t('learnToBridge')}
-
-
-
-
- {t('recoveryPhraseReminderConfirm')}
-
-
- >
- }
- >
-
-
-
- {t('thingsToKeep')}
-
-
- {providerConfig.ticker && (
-
-
-
-
-
-
- {t('gasIsETH', [providerConfig.ticker])}
-
-
- {t('nativeToken', [providerConfig.ticker])}
-
-
-
- )}
-
-
-
-
-
-
- {t('bridgeDontSend')}
-
-
- {isBridgeChain
- ? t('attemptSendingAssetsWithPortfolio', [
-
-
- {t('metamaskPortfolio')}
-
- ,
- ])
- : t('attemptSendingAssets')}
-
-
-
-
- {!autoDetectToken || !tokenDetectionSupported ? (
-
-
-
-
-
-
- {t('addingTokens')}
-
-
- {t('tokenShowUp')}
- {t('clickToManuallyAdd')}
-
-
-
- ) : null}
-
-
-
- )
- );
-}
diff --git a/ui/components/ui/new-network-info/new-network-info.stories.js b/ui/components/ui/new-network-info/new-network-info.stories.js
deleted file mode 100644
index 9d70ef07b5f0..000000000000
--- a/ui/components/ui/new-network-info/new-network-info.stories.js
+++ /dev/null
@@ -1,10 +0,0 @@
-import React from 'react';
-import NewNetworkInfo from '.';
-
-export default {
- title: 'Components/UI/NewNetworkInfo',
-};
-
-export const DefaultStory = () => ;
-
-DefaultStory.storyName = 'Default';
diff --git a/ui/components/ui/new-network-info/new-network-info.test.js b/ui/components/ui/new-network-info/new-network-info.test.js
deleted file mode 100644
index 59d98ab358fd..000000000000
--- a/ui/components/ui/new-network-info/new-network-info.test.js
+++ /dev/null
@@ -1,223 +0,0 @@
-import React from 'react';
-import { waitFor } from '@testing-library/react';
-import configureMockStore from 'redux-mock-store';
-import nock from 'nock';
-import { renderWithProvider } from '../../../../test/lib/render-helpers';
-import { mockNetworkState } from '../../../../test/stub/networks';
-import { CHAIN_IDS } from '../../../../shared/constants/network';
-import NewNetworkInfo from './new-network-info';
-
-const fetchWithCache =
- require('../../../../shared/lib/fetch-with-cache').default;
-
-const localStorageMock = (function () {
- let store = {};
- return {
- getItem(key) {
- return store[key];
- },
-
- setItem(key, value) {
- store[key] = value.toString();
- },
-
- clear() {
- store = {};
- },
-
- removeItem(key) {
- delete store[key];
- },
- };
-})();
-Object.defineProperty(window, 'localStorage', { value: localStorageMock });
-
-const responseOfTokenList = [];
-describe('NewNetworkInfo', () => {
- afterEach(() => {
- nock.cleanAll();
- });
-
- describe('fetch token successfully', () => {
- const state = {
- metamask: {
- ...mockNetworkState({ chainId: CHAIN_IDS.MAINNET }),
- useExternalServices: true,
- useTokenDetection: false,
- currencyRates: {},
- },
- };
-
- it('should match snapshot and render component', async () => {
- nock('https://token.api.cx.metamask.io')
- .get('/tokens/0x1?occurrenceFloor=100&includeNativeAssets=false')
- .reply(200, responseOfTokenList);
-
- const store = configureMockStore()(state);
- const { getByText, getByTestId } = renderWithProvider(
- ,
- store,
- );
- // wait for the fetch to finish
- await waitFor(() => {
- expect(getByTestId('new-network-info__wrapper')).toBeInTheDocument();
- });
- // render title
- expect(getByText("You're now using")).toBeInTheDocument();
- // render the network name
- expect(getByText('Ethereum Mainnet')).toBeInTheDocument();
- expect(
- getByTestId('new-network-info__bullet-paragraph').textContent,
- ).toMatchInlineSnapshot(
- `"Gas is ETH The native token on this network is ETH. It is the token used for gas fees. "`,
- );
- });
-
- it('should render a question mark icon image for non-main network', async () => {
- nock('https://token.api.cx.metamask.io')
- .get('/tokens/0x1?occurrenceFloor=100&includeNativeAssets=false')
- .reply(200, responseOfTokenList);
-
- const updateTokenDetectionSupportStatus = await fetchWithCache({
- url: 'https://token.api.cx.metamask.io/tokens/0x1?occurrenceFloor=100&includeNativeAssets=false',
- functionName: 'getTokenDetectionSupportStatus',
- });
-
- state.metamask.nativeCurrency = '';
-
- const store = configureMockStore()(
- state,
- updateTokenDetectionSupportStatus,
- );
- const { container, getByTestId } = renderWithProvider(
- ,
- store,
- );
- // wait for the fetch to finish
- await waitFor(() => {
- expect(getByTestId('new-network-info__wrapper')).toBeInTheDocument();
- });
-
- const questionMark = container.querySelector('.question');
-
- expect(questionMark).toBeDefined();
- });
-
- it('should not render first bullet when provider ticker is null', async () => {
- nock('https://token.api.cx.metamask.io')
- .get('/tokens/0x3?occurrenceFloor=100&includeNativeAssets=false')
- .reply(200, '{"error":"ChainId 0x3 is not supported"}');
-
- const store = configureMockStore()({
- metamask: {
- ...state.metamask,
- ...mockNetworkState({ chainId: '0x3', ticker: undefined }),
- },
- });
- const { container, getByTestId } = renderWithProvider(
- ,
- store,
- );
- // wait for the fetch to finish
- await new Promise((r) => setTimeout(r, 2000));
- await waitFor(() => {
- expect(getByTestId('new-network-info__wrapper')).toBeInTheDocument();
- });
- const firstBox = container.querySelector(
- 'new-network-info__content-box-1',
- );
-
- expect(firstBox).toBeNull();
- });
-
- describe('add token link', () => {
- const newState = {
- metamask: {
- ...mockNetworkState({ chainId: CHAIN_IDS.MAINNET }),
-
- useExternalServices: true,
- useTokenDetection: true,
- currencyRates: {},
- },
- };
-
- it('should not render link when auto token detection is set true and token detection is supported', async () => {
- nock('https://token.api.cx.metamask.io')
- .get('/tokens/0x1?occurrenceFloor=100&includeNativeAssets=false')
- .reply(200, responseOfTokenList);
-
- const store = configureMockStore()(newState);
- const { getByTestId, queryByTestId } = renderWithProvider(
- ,
- store,
- );
- // should not render add token link
- await waitFor(() => {
- expect(getByTestId('new-network-info__wrapper')).toBeInTheDocument();
- });
- expect(
- queryByTestId('new-network-info__add-token-manually'),
- ).toBeNull();
- });
-
- it('should render link when auto token detection is set true and token detection is not supported', async () => {
- nock('https://token.api.cx.metamask.io')
- .get('/tokens/0x1?occurrenceFloor=100&includeNativeAssets=false')
- .replyWithError('something awful happened');
-
- const store = configureMockStore()(newState);
- const { getByTestId } = renderWithProvider( , store);
- // render add token link when token is supported
- await waitFor(() => {
- expect(getByTestId('new-network-info__wrapper')).toBeInTheDocument();
- });
- });
-
- it('should render link when auto token detection is set false but token detection is not supported', async () => {
- nock('https://token.api.cx.metamask.io')
- .get('/tokens/0x1?occurrenceFloor=100&includeNativeAssets=false')
- .reply(403);
-
- const store = configureMockStore()(state);
- const { getByTestId } = renderWithProvider( , store);
- // render add token link when token is supported
- await waitFor(() => {
- expect(getByTestId('new-network-info__wrapper')).toBeInTheDocument();
- });
- expect(
- getByTestId('new-network-info__add-token-manually'),
- ).toBeInTheDocument();
- });
-
- it('should render link when auto token detection is set false and token detection is supported', async () => {
- nock('https://token.api.cx.metamask.io')
- .get('/tokens/0x1?occurrenceFloor=100&includeNativeAssets=false')
- .reply(200, responseOfTokenList);
-
- const updateTokenDetectionSupportStatus = await fetchWithCache({
- url: 'https://token.api.cx.metamask.io/tokens/0x1?occurrenceFloor=100&includeNativeAssets=false',
- functionName: 'getTokenDetectionSupportStatus',
- });
-
- const store = configureMockStore()(
- state,
- updateTokenDetectionSupportStatus,
- );
- const { getByText, getByTestId } = renderWithProvider(
- ,
- store,
- );
- // wait for the fetch to finish
- await waitFor(() => {
- expect(getByTestId('new-network-info__wrapper')).toBeInTheDocument();
- });
- // render add token link when token is supported
- expect(
- getByText(
- 'Your tokens may not automatically show up in your wallet. You can always add tokens manually.',
- ),
- ).toBeInTheDocument();
- });
- });
- });
-});
diff --git a/ui/components/ui/ui-components.scss b/ui/components/ui/ui-components.scss
index a851a6fd72d5..a1a901ac2a4d 100644
--- a/ui/components/ui/ui-components.scss
+++ b/ui/components/ui/ui-components.scss
@@ -29,7 +29,6 @@
@import 'logo/logo-coinbasepay.scss';
@import 'loading-screen/index';
@import 'menu/menu';
-@import 'new-network-info/index';
@import 'numeric-input/numeric-input';
@import 'nickname-popover/index';
@import 'form-field/index';
diff --git a/ui/pages/routes/routes.component.test.js b/ui/pages/routes/routes.component.test.js
index e661099e1aa2..b9bd116195ea 100644
--- a/ui/pages/routes/routes.component.test.js
+++ b/ui/pages/routes/routes.component.test.js
@@ -1,6 +1,6 @@
import React from 'react';
import configureMockStore from 'redux-mock-store';
-import { act, waitFor } from '@testing-library/react';
+import { act } from '@testing-library/react';
import thunk from 'redux-thunk';
import { BtcAccountType } from '@metamask/keyring-api';
import { SEND_STAGES } from '../../ducks/send';
@@ -15,10 +15,6 @@ import { useIsOriginalNativeTokenSymbol } from '../../hooks/useIsOriginalNativeT
import { createMockInternalAccount } from '../../../test/jest/mocks';
import { CHAIN_IDS } from '../../../shared/constants/network';
import { mockNetworkState } from '../../../test/stub/networks';
-import {
- MOCK_ACCOUNT_BIP122_P2WPKH,
- MOCK_ACCOUNT_EOA,
-} from '../../../test/data/mock-accounts';
import useMultiPolling from '../../hooks/useMultiPolling';
import Routes from '.';
@@ -191,96 +187,6 @@ describe('Routes Component', () => {
expect(getByTestId('account-menu-icon')).not.toBeDisabled();
});
});
-
- describe('new network popup', () => {
- const mockBtcAccount = MOCK_ACCOUNT_BIP122_P2WPKH;
- const mockEvmAccount = MOCK_ACCOUNT_EOA;
-
- const mockNewlyAddedNetwork = {
- chainId: CHAIN_IDS.BASE,
- name: 'Base',
- nativeCurrency: 'ETH',
- defaultRpcEndpointIndex: 0,
- rpcEndpoints: [
- {
- type: 'custom',
- url: 'https://base.com',
- networkClientId: CHAIN_IDS.BASE,
- },
- ],
- };
-
- const renderPopup = async (account) => {
- // This popup does not show up for tests, so we have to disable this:
- process.env.IN_TEST = '';
- const state = {
- ...mockSendState,
- metamask: {
- ...mockState.metamask,
- completedOnboarding: true,
- selectedNetworkClientId: mockNewlyAddedNetwork.chainId,
- internalAccounts: {
- accounts: {
- [account.id]: account,
- },
- selectedAccount: account.id,
- },
- networkConfigurationsByChainId: {
- ...mockState.metamask.networkConfigurationsByChainId,
- [mockNewlyAddedNetwork.chainId]: mockNewlyAddedNetwork,
- },
- networksMetadata: {
- ...mockState.metamask.networksMetadata,
- [mockNewlyAddedNetwork.chainId]: {
- EIPS: {
- 1559: true,
- },
- status: 'available',
- },
- },
- tokens: [],
- swapsState: { swapsFeatureIsLive: false },
- announcements: {},
- pendingApprovals: {},
- termsOfUseLastAgreed: new Date('2999-03-25'),
- shouldShowSeedPhraseReminder: false,
- useExternalServices: true,
- },
- send: {
- ...mockSendState.send,
- stage: SEND_STAGES.INACTIVE,
- currentTransactionUUID: null,
- draftTransactions: {},
- },
- appState: {
- ...mockSendState.appState,
- showWhatsNewPopup: false,
- onboardedInThisUISession: false,
- },
- };
- return await render(['/'], state);
- };
-
- it('displays new EVM network popup for EVM accounts', async () => {
- const { getAllByText, queryByTestId } = await renderPopup(mockEvmAccount);
-
- await waitFor(() => {
- expect(getAllByText(mockNewlyAddedNetwork.name).length).toBeGreaterThan(
- 0,
- );
- expect(
- queryByTestId('new-network-info__bullet-paragraph'),
- ).not.toBeInTheDocument();
- });
- });
-
- it('does not display new EVM network popup for non-EVM accounts', async () => {
- const { queryByTestId } = await renderPopup(mockBtcAccount);
-
- const networkInfo = queryByTestId('new-network-info__bullet-paragraph');
- expect(networkInfo).not.toBeInTheDocument();
- });
- });
});
describe('toast display', () => {
From 41b46a04daa8f1fa610c65e1a0666a8b7130d4dd Mon Sep 17 00:00:00 2001
From: chloeYue <105063779+chloeYue@users.noreply.github.com>
Date: Wed, 18 Dec 2024 16:51:16 +0100
Subject: [PATCH 7/8] test: [POM] Migrate portfolio e2e tests and permission
requests tests to TS and Page Object Model (#29274)
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
## **Description**
- Migrate portfolio e2e tests and permission requests e2e tests to TS
and Page Object Model
```
test/e2e/tests/portfolio/portfolio-site.spec.ts
test/e2e/json-rpc/wallet_revokePermissions.spec.ts
test/e2e/json-rpc/wallet_requestPermissions.spec.ts
```
- Remove unused ganach setup
[![Open in GitHub
Codespaces](https://github.com/codespaces/badge.svg)](https://codespaces.new/MetaMask/metamask-extension/pull/27155?quickstart=1)
## **Related issues**
## **Manual testing steps**
Check code readability, make sure tests pass.
## **Screenshots/Recordings**
### **Before**
### **After**
## **Pre-merge author checklist**
- [x] I've followed [MetaMask Contributor
Docs](https://github.com/MetaMask/contributor-docs) and [MetaMask
Extension Coding
Standards](https://github.com/MetaMask/metamask-extension/blob/develop/.github/guidelines/CODING_GUIDELINES.md).
- [x] I've completed the PR template to the best of my ability
- [x] I’ve included tests if applicable
- [x] I’ve documented my code using [JSDoc](https://jsdoc.app/) format
if applicable
- [x] I’ve applied the right labels on the PR (see [labeling
guidelines](https://github.com/MetaMask/metamask-extension/blob/develop/.github/guidelines/LABELING_GUIDELINES.md)).
Not required for external contributors.
## **Pre-merge reviewer checklist**
- [x] I've manually tested the PR (e.g. pull and build branch, run the
app, test code being changed).
- [x] I confirm that this PR addresses all acceptance criteria described
in the ticket it closes and includes the necessary testing evidence such
as recordings and or screenshots.
---
test/e2e/constants.ts | 3 ++
...c.js => wallet_requestPermissions.spec.ts} | 42 +++++----------
...ec.js => wallet_revokePermissions.spec.ts} | 34 ++++---------
test/e2e/page-objects/pages/home/homepage.ts | 7 +++
test/e2e/page-objects/pages/test-dapp.ts | 51 ++++++++++---------
...io-site.spec.js => portfolio-site.spec.ts} | 27 +++++-----
.../sendTx-revokePermissions.spec.ts | 6 +--
7 files changed, 75 insertions(+), 95 deletions(-)
rename test/e2e/json-rpc/{wallet_requestPermissions.spec.js => wallet_requestPermissions.spec.ts} (51%)
rename test/e2e/json-rpc/{wallet_revokePermissions.spec.js => wallet_revokePermissions.spec.ts} (52%)
rename test/e2e/tests/portfolio/{portfolio-site.spec.js => portfolio-site.spec.ts} (56%)
diff --git a/test/e2e/constants.ts b/test/e2e/constants.ts
index 7123d3e4114a..8296cdc3e3d1 100644
--- a/test/e2e/constants.ts
+++ b/test/e2e/constants.ts
@@ -70,3 +70,6 @@ export const DEFAULT_SOLANA_ACCOUNT =
/* Default (mocked) SOLANA balance used by the Solana RPC provider */
export const DEFAULT_SOLANA_BALANCE = 1; // SOL
+
+/* Title of the mocked E2E test empty HTML page */
+export const EMPTY_E2E_TEST_PAGE_TITLE = 'E2E Test Page';
diff --git a/test/e2e/json-rpc/wallet_requestPermissions.spec.js b/test/e2e/json-rpc/wallet_requestPermissions.spec.ts
similarity index 51%
rename from test/e2e/json-rpc/wallet_requestPermissions.spec.js
rename to test/e2e/json-rpc/wallet_requestPermissions.spec.ts
index 5484fdf73d80..d2a033dcf3c5 100644
--- a/test/e2e/json-rpc/wallet_requestPermissions.spec.js
+++ b/test/e2e/json-rpc/wallet_requestPermissions.spec.ts
@@ -1,58 +1,42 @@
-const { strict: assert } = require('assert');
-const {
- defaultGanacheOptions,
- withFixtures,
- switchToNotificationWindow,
- switchToOrOpenDapp,
- unlockWallet,
-} = require('../helpers');
-const FixtureBuilder = require('../fixture-builder');
+import { strict as assert } from 'assert';
+import { withFixtures } from '../helpers';
+import FixtureBuilder from '../fixture-builder';
+import { loginWithBalanceValidation } from '../page-objects/flows/login.flow';
+import TestDapp from '../page-objects/pages/test-dapp';
describe('wallet_requestPermissions', function () {
it('executes a request permissions on eth_accounts event', async function () {
await withFixtures(
{
dapp: true,
- fixtures: new FixtureBuilder()
- .withPermissionControllerConnectedToTestDapp()
- .build(),
- ganacheOptions: defaultGanacheOptions,
- title: this.test.title,
+ fixtures: new FixtureBuilder().build(),
+ title: this.test?.title,
},
async ({ driver }) => {
- await unlockWallet(driver);
+ await loginWithBalanceValidation(driver);
+ const testDapp = new TestDapp(driver);
+ await testDapp.openTestDappPage();
// wallet_requestPermissions
- await driver.openNewPage(`http://127.0.0.1:8080`);
-
const requestPermissionsRequest = JSON.stringify({
jsonrpc: '2.0',
method: 'wallet_requestPermissions',
params: [{ eth_accounts: {} }],
});
-
await driver.executeScript(
`window.ethereum.request(${requestPermissionsRequest})`,
);
- await switchToNotificationWindow(driver);
-
- await driver.clickElement({
- text: 'Connect',
- tag: 'button',
- });
-
- await switchToOrOpenDapp(driver);
+ // confirm connect account
+ await testDapp.confirmConnectAccountModal();
const getPermissionsRequest = JSON.stringify({
method: 'wallet_getPermissions',
});
-
const getPermissions = await driver.executeScript(
`return window.ethereum.request(${getPermissionsRequest})`,
);
-
- assert.strictEqual(getPermissions[0].parentCapability, 'eth_accounts');
+ assert.strictEqual(getPermissions[1].parentCapability, 'eth_accounts');
},
);
});
diff --git a/test/e2e/json-rpc/wallet_revokePermissions.spec.js b/test/e2e/json-rpc/wallet_revokePermissions.spec.ts
similarity index 52%
rename from test/e2e/json-rpc/wallet_revokePermissions.spec.js
rename to test/e2e/json-rpc/wallet_revokePermissions.spec.ts
index 70d2fd3ba572..5c444b5ecf01 100644
--- a/test/e2e/json-rpc/wallet_revokePermissions.spec.js
+++ b/test/e2e/json-rpc/wallet_revokePermissions.spec.ts
@@ -1,12 +1,8 @@
-const { strict: assert } = require('assert');
-
-const {
- withFixtures,
- defaultGanacheOptions,
- unlockWallet,
- openDapp,
-} = require('../helpers');
-const FixtureBuilder = require('../fixture-builder');
+import { strict as assert } from 'assert';
+import { ACCOUNT_1, withFixtures } from '../helpers';
+import FixtureBuilder from '../fixture-builder';
+import TestDapp from '../page-objects/pages/test-dapp';
+import { loginWithBalanceValidation } from '../page-objects/flows/login.flow';
describe('Revoke Dapp Permissions', function () {
it('should revoke dapp permissions ', async function () {
@@ -16,18 +12,13 @@ describe('Revoke Dapp Permissions', function () {
fixtures: new FixtureBuilder()
.withPermissionControllerConnectedToTestDapp()
.build(),
- ganacheOptions: defaultGanacheOptions,
title: this.test?.fullTitle(),
},
async ({ driver }) => {
- await unlockWallet(driver);
-
- await openDapp(driver);
-
- await driver.findElement({
- text: '0x5cfe73b6021e818b776b421b1c4db2474086a7e1',
- css: '#accounts',
- });
+ await loginWithBalanceValidation(driver);
+ const testDapp = new TestDapp(driver);
+ await testDapp.openTestDappPage();
+ await testDapp.check_connectedAccounts(ACCOUNT_1);
// wallet_revokePermissions request
const revokePermissionsRequest = JSON.stringify({
@@ -43,15 +34,10 @@ describe('Revoke Dapp Permissions', function () {
const result = await driver.executeScript(
`return window.ethereum.request(${revokePermissionsRequest})`,
);
-
// Response of method call
assert.deepEqual(result, null);
- // TODO: Fix having to reload dapp as it is not the proper behavior in production, issue with test setup.
- await driver.executeScript(`window.location.reload()`);
-
- // You cannot use driver.findElement() with an empty string, so use xpath
- await driver.findElement({ xpath: '//span[@id="accounts"][.=""]' });
+ await testDapp.check_connectedAccounts(ACCOUNT_1, false);
},
);
});
diff --git a/test/e2e/page-objects/pages/home/homepage.ts b/test/e2e/page-objects/pages/home/homepage.ts
index 1da2349752cb..b4b79846fb06 100644
--- a/test/e2e/page-objects/pages/home/homepage.ts
+++ b/test/e2e/page-objects/pages/home/homepage.ts
@@ -39,6 +39,8 @@ class HomePage {
testId: 'popover-close',
};
+ private readonly portfolioLink = '[data-testid="portfolio-link"]';
+
private readonly privacyBalanceToggle = {
testId: 'sensitive-toggle',
};
@@ -99,6 +101,11 @@ class HomePage {
await this.driver.clickElement(this.nftTab);
}
+ async openPortfolioPage(): Promise {
+ console.log(`Open portfolio page on homepage`);
+ await this.driver.clickElement(this.portfolioLink);
+ }
+
async refreshErc20TokenList(): Promise {
console.log(`Refresh the ERC20 token list`);
await this.driver.clickElement(this.erc20TokenDropdown);
diff --git a/test/e2e/page-objects/pages/test-dapp.ts b/test/e2e/page-objects/pages/test-dapp.ts
index 4eff00462351..6b82926fd9ca 100644
--- a/test/e2e/page-objects/pages/test-dapp.ts
+++ b/test/e2e/page-objects/pages/test-dapp.ts
@@ -273,6 +273,16 @@ class TestDapp {
await this.driver.clickElement(this.erc20TokenTransferButton);
}
+ async confirmConnectAccountModal() {
+ console.log('Confirm connect account modal in notification window');
+ await this.driver.switchToWindowWithTitle(WINDOW_TITLES.Dialog);
+ await this.driver.waitForSelector(this.connectMetaMaskMessage);
+ await this.driver.clickElementAndWaitForWindowToClose(
+ this.confirmDialogButton,
+ );
+ await this.driver.switchToWindowWithTitle(WINDOW_TITLES.TestDApp);
+ }
+
/**
* Connect account to test dapp.
*
@@ -289,25 +299,18 @@ class TestDapp {
}) {
console.log('Connect account to test dapp');
await this.driver.clickElement(this.connectAccountButton);
- await this.driver.switchToWindowWithTitle(WINDOW_TITLES.Dialog);
- await this.driver.waitForSelector(this.connectMetaMaskMessage);
if (connectAccountButtonEnabled) {
- await this.driver.clickElementAndWaitForWindowToClose(
- this.confirmDialogButton,
- );
+ await this.confirmConnectAccountModal();
} else {
+ await this.driver.switchToWindowWithTitle(WINDOW_TITLES.Dialog);
+ await this.driver.waitForSelector(this.connectMetaMaskMessage);
const confirmConnectDialogButton = await this.driver.findElement(
this.confirmDialogButton,
);
assert.equal(await confirmConnectDialogButton.isEnabled(), false);
}
-
if (publicAddress) {
- await this.driver.switchToWindowWithTitle(WINDOW_TITLES.TestDApp);
- await this.driver.waitForSelector({
- css: this.connectedAccount,
- text: publicAddress.toLowerCase(),
- });
+ await this.check_connectedAccounts(publicAddress);
await this.driver.waitForSelector(this.localhostNetworkMessage);
}
}
@@ -332,28 +335,30 @@ class TestDapp {
await this.driver.clickElement(this.revokePermissionButton);
await this.driver.refresh();
await this.check_pageIsLoaded();
- await this.driver.assertElementNotPresent({
- css: this.connectedAccount,
- text: publicAddress.toLowerCase(),
- });
+ await this.check_connectedAccounts(publicAddress, false);
}
/**
- * Verifies the accounts connected to the test dapp.
+ * Check if the accounts connected to the test dapp.
*
- * @param connectedAccounts - The expected connected accounts separated by a comma. If no accounts are connected we can omit the param.
+ * @param connectedAccounts - Account addresses to check if connected to test dapp, separated by a comma.
+ * @param shouldBeConnected - Whether the accounts should be connected to test dapp. Defaults to true.
*/
- async check_connectedAccounts(connectedAccounts: string = '') {
- console.log('Verify connected accounts');
- if (connectedAccounts) {
+ async check_connectedAccounts(
+ connectedAccounts: string,
+ shouldBeConnected: boolean = true,
+ ) {
+ if (shouldBeConnected) {
+ console.log('Verify connected accounts:', connectedAccounts);
await this.driver.waitForSelector({
css: this.connectedAccount,
- text: connectedAccounts,
+ text: connectedAccounts.toLowerCase(),
});
} else {
- await this.driver.waitForSelector({
+ console.log('Verify accounts not connected:', connectedAccounts);
+ await this.driver.assertElementNotPresent({
css: this.connectedAccount,
- text: ' ',
+ text: connectedAccounts.toLowerCase(),
});
}
}
diff --git a/test/e2e/tests/portfolio/portfolio-site.spec.js b/test/e2e/tests/portfolio/portfolio-site.spec.ts
similarity index 56%
rename from test/e2e/tests/portfolio/portfolio-site.spec.js
rename to test/e2e/tests/portfolio/portfolio-site.spec.ts
index cba9c0452522..f630de50f1da 100644
--- a/test/e2e/tests/portfolio/portfolio-site.spec.js
+++ b/test/e2e/tests/portfolio/portfolio-site.spec.ts
@@ -1,13 +1,13 @@
-const {
- withFixtures,
- unlockWallet,
- defaultGanacheOptions,
-} = require('../../helpers');
-const FixtureBuilder = require('../../fixture-builder');
-const { emptyHtmlPage } = require('../../mock-e2e');
+import { MockttpServer } from 'mockttp';
+import { withFixtures } from '../../helpers';
+import { EMPTY_E2E_TEST_PAGE_TITLE } from '../../constants';
+import FixtureBuilder from '../../fixture-builder';
+import { emptyHtmlPage } from '../../mock-e2e';
+import HomePage from '../../page-objects/pages/home/homepage';
+import { loginWithBalanceValidation } from '../../page-objects/flows/login.flow';
describe('Portfolio site', function () {
- async function mockPortfolioSite(mockServer) {
+ async function mockPortfolioSite(mockServer: MockttpServer) {
return await mockServer
.forGet('https://portfolio.metamask.io/')
.withQuery({
@@ -27,18 +27,15 @@ describe('Portfolio site', function () {
{
dapp: true,
fixtures: new FixtureBuilder().build(),
- ganacheOptions: defaultGanacheOptions,
- title: this.test.fullTitle(),
+ title: this.test?.fullTitle(),
testSpecificMock: mockPortfolioSite,
},
async ({ driver }) => {
- await unlockWallet(driver);
+ await loginWithBalanceValidation(driver);
+ await new HomePage(driver).openPortfolioPage();
// Click Portfolio site
- await driver.clickElement('[data-testid="portfolio-link"]');
- await driver.waitUntilXWindowHandles(2);
- const windowHandles = await driver.getAllWindowHandles();
- await driver.switchToWindowWithTitle('E2E Test Page', windowHandles);
+ await driver.switchToWindowWithTitle(EMPTY_E2E_TEST_PAGE_TITLE);
// Verify site
await driver.waitForUrl({
diff --git a/test/e2e/tests/request-queuing/sendTx-revokePermissions.spec.ts b/test/e2e/tests/request-queuing/sendTx-revokePermissions.spec.ts
index c5ff864df99c..9f5454404806 100644
--- a/test/e2e/tests/request-queuing/sendTx-revokePermissions.spec.ts
+++ b/test/e2e/tests/request-queuing/sendTx-revokePermissions.spec.ts
@@ -41,9 +41,7 @@ describe('Request Queuing', function () {
// Open test dapp
const testDapp = new TestDapp(driver);
await testDapp.openTestDappPage();
- await testDapp.check_connectedAccounts(
- DEFAULT_FIXTURE_ACCOUNT.toLowerCase(),
- );
+ await testDapp.check_connectedAccounts(DEFAULT_FIXTURE_ACCOUNT);
// Trigger a tx
await testDapp.clickSimpleSendButton();
@@ -71,7 +69,7 @@ describe('Request Queuing', function () {
await driver.waitUntilXWindowHandles(2);
// Cleared eth_accounts account label
- await testDapp.check_connectedAccounts();
+ await testDapp.check_connectedAccounts(DEFAULT_FIXTURE_ACCOUNT, false);
},
);
});
From 22bcc760ab137d4faf44fdcd27e3d6f1c5bb9a52 Mon Sep 17 00:00:00 2001
From: George Marshall
Date: Wed, 18 Dec 2024 08:04:16 -0800
Subject: [PATCH 8/8] chore: fix security settings layout (#29258)
## **Description**
This PR improves the layout of the basic security section by aligning
the toggle button with the heading text. The changes include:
1. Restructuring the layout using Box components with proper alignment
2. Moving the toggle button to be inline with the heading
3. Improving the visual hierarchy by using proper Typography components
4. Maintaining the description text below with appropriate spacing
[![Open in GitHub
Codespaces](https://github.com/codespaces/badge.svg)](https://codespaces.new/MetaMask/metamask-extension/pull/29258?quickstart=1)
## **Related issues**
Fixes: https://github.com/MetaMask/metamask-extension/issues/26667
## **Manual testing steps**
1. Go to Settings > Security & Privacy
2. Observe the Basic Configuration section at the top
3. Verify the toggle button is properly aligned with the heading
4. Verify the description text appears below with proper spacing
## **Screenshots/Recordings**
### **Before**
https://github.com/user-attachments/assets/bab9a14c-8f10-4865-b159-5343537a2785
### **After**
https://github.com/user-attachments/assets/b9d02fd8-8e35-4dfa-a00d-b4e6952625df
## **Pre-merge author checklist**
- [x] I've followed [MetaMask Contributor
Docs](https://github.com/MetaMask/contributor-docs) and [MetaMask
Extension Coding
Standards](https://github.com/MetaMask/metamask-extension/blob/main/.github/guidelines/CODING_GUIDELINES.md).
- [x] I've completed the PR template to the best of my ability
- [x] I've included tests if applicable
- [x] I've documented my code using [JSDoc](https://jsdoc.app/) format
if applicable
- [x] I've applied the right labels on the PR (see [labeling
guidelines](https://github.com/MetaMask/metamask-extension/blob/main/.github/guidelines/LABELING_GUIDELINES.md)).
Not required for external contributors.
## **Pre-merge reviewer checklist**
- [ ] I've manually tested the PR (e.g. pull and build branch, run the
app, test code being changed).
- [ ] I confirm that this PR addresses all acceptance criteria described
in the ticket it closes and includes the necessary testing evidence such
as recordings and or screenshots.
---
.../__snapshots__/security-tab.test.js.snap | 109 +++++++++---------
.../security-tab/security-tab.component.js | 77 +++++++------
2 files changed, 100 insertions(+), 86 deletions(-)
diff --git a/ui/pages/settings/security-tab/__snapshots__/security-tab.test.js.snap b/ui/pages/settings/security-tab/__snapshots__/security-tab.test.js.snap
index 1d5b622b6b46..3b1837d55ef2 100644
--- a/ui/pages/settings/security-tab/__snapshots__/security-tab.test.js.snap
+++ b/ui/pages/settings/security-tab/__snapshots__/security-tab.test.js.snap
@@ -12,11 +12,62 @@ exports[`Security Tab should match snapshot 1`] = `
-
- Basic functionality
-
+
+ Basic functionality
+
+
+
+
+
+ Off
+
+
+ On
+
+
+
+
+
@@ -31,57 +82,11 @@ exports[`Security Tab should match snapshot 1`] = `
.
-
+
-
-
-
-
- Off
-
-
- On
-
-
-
-
+ />