mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
feat(878): add new incomingTxn component and change styles of settings (#20374)
* feat(878): add new incomingTxn component and change styles of settings * feat(878): relocate openSea tab from rebase regression * feat(878): make UI and test modifications * feat(878): transfer to ts * feat(878): rename network-toggle.tsx
This commit is contained in:
parent
66b4d7c9fb
commit
a85a4cf97e
6
app/_locales/en/messages.json
generated
6
app/_locales/en/messages.json
generated
@ -1397,6 +1397,9 @@
|
||||
"enableAutoDetect": {
|
||||
"message": " Enable autodetect"
|
||||
},
|
||||
"enableForAllNetworks": {
|
||||
"message": "Enable for all networks"
|
||||
},
|
||||
"enableFromSettings": {
|
||||
"message": " Enable it from Settings."
|
||||
},
|
||||
@ -3850,6 +3853,9 @@
|
||||
"message": "This relies on $1 which will have access to your Ethereum address and your IP address. $2",
|
||||
"description": "$1 is the link to etherscan url and $2 is the link to the privacy policy of consensys APIs"
|
||||
},
|
||||
"showIncomingTransactionsInformation": {
|
||||
"message": "This relies on each network which will have access to your Ethereum address and your IP address."
|
||||
},
|
||||
"showMore": {
|
||||
"message": "Show more"
|
||||
},
|
||||
|
@ -0,0 +1,472 @@
|
||||
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
||||
|
||||
exports[`IncomingTransactionToggle should render existing incoming transaction preferences 1`] = `
|
||||
<div>
|
||||
<div
|
||||
class="mm-box mm-incoming-transaction-toggle"
|
||||
>
|
||||
<p
|
||||
class="mm-box mm-text mm-text--body-lg-medium mm-text--font-weight-bold mm-box--color-text-default"
|
||||
>
|
||||
Show incoming transactions
|
||||
</p>
|
||||
<p
|
||||
class="mm-box mm-text mm-text--body-md mm-box--color-text-alternative"
|
||||
>
|
||||
This relies on each network which will have access to your Ethereum address and your IP address.
|
||||
</p>
|
||||
<div
|
||||
class="mm-box mm-box--margin-top-3 mm-box--display-flex mm-box--flex-direction-row mm-box--justify-content-space-between"
|
||||
data-testid="incoming-transaction-toggle-enable-all"
|
||||
>
|
||||
<p
|
||||
class="mm-box mm-text mm-text--body-md mm-box--color-text-default"
|
||||
>
|
||||
|
||||
Enable for all networks
|
||||
</p>
|
||||
<label
|
||||
class="toggle-button toggle-button--off"
|
||||
tabindex="0"
|
||||
>
|
||||
<div
|
||||
style="display: flex; width: 52px; align-items: center; justify-content: flex-start; position: relative; cursor: pointer; background-color: transparent; border: 0px; padding: 0px; user-select: none;"
|
||||
>
|
||||
<div
|
||||
style="width: 40px; height: 24px; padding: 0px; border-radius: 26px; display: flex; align-items: center; justify-content: center; background-color: rgb(242, 244, 246);"
|
||||
>
|
||||
<div
|
||||
style="font-size: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Helvetica Neue', Helvetica, sans-serif; position: relative; color: rgb(250, 250, 250); margin-top: auto; margin-bottom: auto; line-height: 0; opacity: 0; width: 26px; height: 20px; left: 4px;"
|
||||
/>
|
||||
<div
|
||||
style="font-size: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Helvetica Neue', Helvetica, sans-serif; position: relative; color: rgba(255, 255, 255, 0.6); bottom: 0px; margin-top: auto; margin-bottom: auto; padding-right: 5px; line-height: 0; width: 26px; height: 20px; opacity: 1;"
|
||||
/>
|
||||
</div>
|
||||
<div
|
||||
style="position: absolute; height: 100%; top: 0px; left: 0px; display: flex; flex: 1; align-self: stretch; align-items: center; justify-content: flex-start;"
|
||||
>
|
||||
<div
|
||||
style="width: 18px; height: 18px; display: flex; align-self: center; box-shadow: none; border-radius: 50%; box-sizing: border-box; position: relative; background-color: rgb(106, 115, 125); left: 3px;"
|
||||
/>
|
||||
</div>
|
||||
<input
|
||||
style="border: 0px; height: 1px; margin: -1px; overflow: hidden; padding: 0px; position: absolute; width: 1px;"
|
||||
type="checkbox"
|
||||
value="false"
|
||||
/>
|
||||
</div>
|
||||
<div
|
||||
class="toggle-button__status"
|
||||
>
|
||||
<span
|
||||
class="toggle-button__label-off"
|
||||
>
|
||||
Off
|
||||
</span>
|
||||
<span
|
||||
class="toggle-button__label-on"
|
||||
>
|
||||
On
|
||||
</span>
|
||||
</div>
|
||||
</label>
|
||||
</div>
|
||||
<div
|
||||
class="mm-box network-toggle-wrapper mm-box--margin-top-6 mm-box--margin-bottom-6 mm-box--display-flex mm-box--flex-direction-row mm-box--justify-content-space-between"
|
||||
data-testid="network-toggle-0x1"
|
||||
>
|
||||
<div
|
||||
class="mm-box mm-box--display-flex mm-box--gap-2 mm-box--align-items-center mm-box--width-full mm-box--background-color-transparent"
|
||||
>
|
||||
<div
|
||||
class="mm-box mm-text mm-avatar-base mm-avatar-base--size-sm mm-avatar-network mm-text--body-sm mm-text--text-transform-uppercase mm-box--display-flex mm-box--justify-content-center mm-box--align-items-center mm-box--color-text-default mm-box--background-color-background-alternative mm-box--rounded-full mm-box--border-color-transparent box--border-style-solid box--border-width-1"
|
||||
>
|
||||
<img
|
||||
alt="Ethereum Mainnet logo"
|
||||
class="mm-avatar-network__network-image"
|
||||
src="./images/eth_logo.png"
|
||||
/>
|
||||
</div>
|
||||
<p
|
||||
class="mm-box mm-text mm-text--body-md mm-text--ellipsis mm-box--margin-left-2 mm-box--color-text-default mm-box--background-color-transparent"
|
||||
>
|
||||
Ethereum Mainnet
|
||||
</p>
|
||||
</div>
|
||||
<label
|
||||
class="toggle-button toggle-button--on"
|
||||
tabindex="0"
|
||||
>
|
||||
<div
|
||||
style="display: flex; width: 52px; align-items: center; justify-content: flex-start; position: relative; cursor: pointer; background-color: transparent; border: 0px; padding: 0px; user-select: none;"
|
||||
>
|
||||
<div
|
||||
style="width: 40px; height: 24px; padding: 0px; border-radius: 26px; display: flex; align-items: center; justify-content: center; background-color: rgb(242, 244, 246);"
|
||||
>
|
||||
<div
|
||||
style="font-size: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Helvetica Neue', Helvetica, sans-serif; position: relative; color: rgb(250, 250, 250); margin-top: auto; margin-bottom: auto; line-height: 0; opacity: 1; width: 26px; height: 20px; left: 4px;"
|
||||
/>
|
||||
<div
|
||||
style="font-size: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Helvetica Neue', Helvetica, sans-serif; position: relative; color: rgba(255, 255, 255, 0.6); bottom: 0px; margin-top: auto; margin-bottom: auto; padding-right: 5px; line-height: 0; width: 26px; height: 20px; opacity: 0;"
|
||||
/>
|
||||
</div>
|
||||
<div
|
||||
style="position: absolute; height: 100%; top: 0px; left: 0px; display: flex; flex: 1; align-self: stretch; align-items: center; justify-content: flex-start;"
|
||||
>
|
||||
<div
|
||||
style="width: 18px; height: 18px; display: flex; align-self: center; box-shadow: none; border-radius: 50%; box-sizing: border-box; position: relative; background-color: rgb(3, 125, 214); left: 18px;"
|
||||
/>
|
||||
</div>
|
||||
<input
|
||||
style="border: 0px; height: 1px; margin: -1px; overflow: hidden; padding: 0px; position: absolute; width: 1px;"
|
||||
type="checkbox"
|
||||
value="true"
|
||||
/>
|
||||
</div>
|
||||
<div
|
||||
class="toggle-button__status"
|
||||
>
|
||||
<span
|
||||
class="toggle-button__label-off"
|
||||
>
|
||||
Off
|
||||
</span>
|
||||
<span
|
||||
class="toggle-button__label-on"
|
||||
>
|
||||
On
|
||||
</span>
|
||||
</div>
|
||||
</label>
|
||||
</div>
|
||||
<div
|
||||
class="mm-box network-toggle-wrapper mm-box--margin-top-6 mm-box--margin-bottom-6 mm-box--display-flex mm-box--flex-direction-row mm-box--justify-content-space-between"
|
||||
data-testid="network-toggle-0xe708"
|
||||
>
|
||||
<div
|
||||
class="mm-box mm-box--display-flex mm-box--gap-2 mm-box--align-items-center mm-box--width-full mm-box--background-color-transparent"
|
||||
>
|
||||
<div
|
||||
class="mm-box mm-text mm-avatar-base mm-avatar-base--size-sm mm-avatar-network mm-text--body-sm mm-text--text-transform-uppercase mm-box--display-flex mm-box--justify-content-center mm-box--align-items-center mm-box--color-text-default mm-box--background-color-background-alternative mm-box--rounded-full mm-box--border-color-transparent box--border-style-solid box--border-width-1"
|
||||
>
|
||||
<img
|
||||
alt="Linea Mainnet logo"
|
||||
class="mm-avatar-network__network-image"
|
||||
src="./images/linea-logo-mainnet.png"
|
||||
/>
|
||||
</div>
|
||||
<p
|
||||
class="mm-box mm-text mm-text--body-md mm-text--ellipsis mm-box--margin-left-2 mm-box--color-text-default mm-box--background-color-transparent"
|
||||
>
|
||||
Linea Mainnet
|
||||
</p>
|
||||
</div>
|
||||
<label
|
||||
class="toggle-button toggle-button--off"
|
||||
tabindex="0"
|
||||
>
|
||||
<div
|
||||
style="display: flex; width: 52px; align-items: center; justify-content: flex-start; position: relative; cursor: pointer; background-color: transparent; border: 0px; padding: 0px; user-select: none;"
|
||||
>
|
||||
<div
|
||||
style="width: 40px; height: 24px; padding: 0px; border-radius: 26px; display: flex; align-items: center; justify-content: center; background-color: rgb(242, 244, 246);"
|
||||
>
|
||||
<div
|
||||
style="font-size: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Helvetica Neue', Helvetica, sans-serif; position: relative; color: rgb(250, 250, 250); margin-top: auto; margin-bottom: auto; line-height: 0; opacity: 0; width: 26px; height: 20px; left: 4px;"
|
||||
/>
|
||||
<div
|
||||
style="font-size: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Helvetica Neue', Helvetica, sans-serif; position: relative; color: rgba(255, 255, 255, 0.6); bottom: 0px; margin-top: auto; margin-bottom: auto; padding-right: 5px; line-height: 0; width: 26px; height: 20px; opacity: 1;"
|
||||
/>
|
||||
</div>
|
||||
<div
|
||||
style="position: absolute; height: 100%; top: 0px; left: 0px; display: flex; flex: 1; align-self: stretch; align-items: center; justify-content: flex-start;"
|
||||
>
|
||||
<div
|
||||
style="width: 18px; height: 18px; display: flex; align-self: center; box-shadow: none; border-radius: 50%; box-sizing: border-box; position: relative; background-color: rgb(106, 115, 125); left: 3px;"
|
||||
/>
|
||||
</div>
|
||||
<input
|
||||
style="border: 0px; height: 1px; margin: -1px; overflow: hidden; padding: 0px; position: absolute; width: 1px;"
|
||||
type="checkbox"
|
||||
value="false"
|
||||
/>
|
||||
</div>
|
||||
<div
|
||||
class="toggle-button__status"
|
||||
>
|
||||
<span
|
||||
class="toggle-button__label-off"
|
||||
>
|
||||
Off
|
||||
</span>
|
||||
<span
|
||||
class="toggle-button__label-on"
|
||||
>
|
||||
On
|
||||
</span>
|
||||
</div>
|
||||
</label>
|
||||
</div>
|
||||
<div
|
||||
class="mm-box network-toggle-wrapper mm-box--margin-top-6 mm-box--margin-bottom-6 mm-box--display-flex mm-box--flex-direction-row mm-box--justify-content-space-between"
|
||||
data-testid="network-toggle-0xfa"
|
||||
>
|
||||
<div
|
||||
class="mm-box mm-box--display-flex mm-box--gap-2 mm-box--align-items-center mm-box--width-full mm-box--background-color-transparent"
|
||||
>
|
||||
<div
|
||||
class="mm-box mm-text mm-avatar-base mm-avatar-base--size-sm mm-avatar-network mm-text--body-sm mm-text--text-transform-uppercase mm-box--display-flex mm-box--justify-content-center mm-box--align-items-center mm-box--color-text-default mm-box--background-color-background-alternative mm-box--rounded-full mm-box--border-color-transparent box--border-style-solid box--border-width-1"
|
||||
>
|
||||
F
|
||||
</div>
|
||||
<p
|
||||
class="mm-box mm-text mm-text--body-md mm-text--ellipsis mm-box--margin-left-2 mm-box--color-text-default mm-box--background-color-transparent"
|
||||
>
|
||||
FANTOM
|
||||
</p>
|
||||
</div>
|
||||
<label
|
||||
class="toggle-button toggle-button--on"
|
||||
tabindex="0"
|
||||
>
|
||||
<div
|
||||
style="display: flex; width: 52px; align-items: center; justify-content: flex-start; position: relative; cursor: pointer; background-color: transparent; border: 0px; padding: 0px; user-select: none;"
|
||||
>
|
||||
<div
|
||||
style="width: 40px; height: 24px; padding: 0px; border-radius: 26px; display: flex; align-items: center; justify-content: center; background-color: rgb(242, 244, 246);"
|
||||
>
|
||||
<div
|
||||
style="font-size: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Helvetica Neue', Helvetica, sans-serif; position: relative; color: rgb(250, 250, 250); margin-top: auto; margin-bottom: auto; line-height: 0; opacity: 1; width: 26px; height: 20px; left: 4px;"
|
||||
/>
|
||||
<div
|
||||
style="font-size: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Helvetica Neue', Helvetica, sans-serif; position: relative; color: rgba(255, 255, 255, 0.6); bottom: 0px; margin-top: auto; margin-bottom: auto; padding-right: 5px; line-height: 0; width: 26px; height: 20px; opacity: 0;"
|
||||
/>
|
||||
</div>
|
||||
<div
|
||||
style="position: absolute; height: 100%; top: 0px; left: 0px; display: flex; flex: 1; align-self: stretch; align-items: center; justify-content: flex-start;"
|
||||
>
|
||||
<div
|
||||
style="width: 18px; height: 18px; display: flex; align-self: center; box-shadow: none; border-radius: 50%; box-sizing: border-box; position: relative; background-color: rgb(3, 125, 214); left: 18px;"
|
||||
/>
|
||||
</div>
|
||||
<input
|
||||
style="border: 0px; height: 1px; margin: -1px; overflow: hidden; padding: 0px; position: absolute; width: 1px;"
|
||||
type="checkbox"
|
||||
value="true"
|
||||
/>
|
||||
</div>
|
||||
<div
|
||||
class="toggle-button__status"
|
||||
>
|
||||
<span
|
||||
class="toggle-button__label-off"
|
||||
>
|
||||
Off
|
||||
</span>
|
||||
<span
|
||||
class="toggle-button__label-on"
|
||||
>
|
||||
On
|
||||
</span>
|
||||
</div>
|
||||
</label>
|
||||
</div>
|
||||
<div
|
||||
class="mm-box network-toggle-wrapper mm-box--margin-top-6 mm-box--margin-bottom-6 mm-box--display-flex mm-box--flex-direction-row mm-box--justify-content-space-between"
|
||||
data-testid="network-toggle-0x5"
|
||||
>
|
||||
<div
|
||||
class="mm-box mm-box--display-flex mm-box--gap-2 mm-box--align-items-center mm-box--width-full mm-box--background-color-transparent"
|
||||
>
|
||||
<div
|
||||
class="mm-box mm-text mm-avatar-base mm-avatar-base--size-sm mm-avatar-network mm-text--body-sm mm-text--text-transform-uppercase mm-box--display-flex mm-box--justify-content-center mm-box--align-items-center mm-box--color-text-default mm-box--background-color-background-alternative mm-box--rounded-full mm-box--border-color-transparent box--border-style-solid box--border-width-1"
|
||||
>
|
||||
G
|
||||
</div>
|
||||
<p
|
||||
class="mm-box mm-text mm-text--body-md mm-text--ellipsis mm-box--margin-left-2 mm-box--color-text-default mm-box--background-color-transparent"
|
||||
>
|
||||
Goerli
|
||||
</p>
|
||||
</div>
|
||||
<label
|
||||
class="toggle-button toggle-button--off"
|
||||
tabindex="0"
|
||||
>
|
||||
<div
|
||||
style="display: flex; width: 52px; align-items: center; justify-content: flex-start; position: relative; cursor: pointer; background-color: transparent; border: 0px; padding: 0px; user-select: none;"
|
||||
>
|
||||
<div
|
||||
style="width: 40px; height: 24px; padding: 0px; border-radius: 26px; display: flex; align-items: center; justify-content: center; background-color: rgb(242, 244, 246);"
|
||||
>
|
||||
<div
|
||||
style="font-size: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Helvetica Neue', Helvetica, sans-serif; position: relative; color: rgb(250, 250, 250); margin-top: auto; margin-bottom: auto; line-height: 0; opacity: 0; width: 26px; height: 20px; left: 4px;"
|
||||
/>
|
||||
<div
|
||||
style="font-size: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Helvetica Neue', Helvetica, sans-serif; position: relative; color: rgba(255, 255, 255, 0.6); bottom: 0px; margin-top: auto; margin-bottom: auto; padding-right: 5px; line-height: 0; width: 26px; height: 20px; opacity: 1;"
|
||||
/>
|
||||
</div>
|
||||
<div
|
||||
style="position: absolute; height: 100%; top: 0px; left: 0px; display: flex; flex: 1; align-self: stretch; align-items: center; justify-content: flex-start;"
|
||||
>
|
||||
<div
|
||||
style="width: 18px; height: 18px; display: flex; align-self: center; box-shadow: none; border-radius: 50%; box-sizing: border-box; position: relative; background-color: rgb(106, 115, 125); left: 3px;"
|
||||
/>
|
||||
</div>
|
||||
<input
|
||||
style="border: 0px; height: 1px; margin: -1px; overflow: hidden; padding: 0px; position: absolute; width: 1px;"
|
||||
type="checkbox"
|
||||
value="false"
|
||||
/>
|
||||
</div>
|
||||
<div
|
||||
class="toggle-button__status"
|
||||
>
|
||||
<span
|
||||
class="toggle-button__label-off"
|
||||
>
|
||||
Off
|
||||
</span>
|
||||
<span
|
||||
class="toggle-button__label-on"
|
||||
>
|
||||
On
|
||||
</span>
|
||||
</div>
|
||||
</label>
|
||||
</div>
|
||||
<div
|
||||
class="mm-box network-toggle-wrapper mm-box--margin-top-6 mm-box--margin-bottom-6 mm-box--display-flex mm-box--flex-direction-row mm-box--justify-content-space-between"
|
||||
data-testid="network-toggle-0xaa36a7"
|
||||
>
|
||||
<div
|
||||
class="mm-box mm-box--display-flex mm-box--gap-2 mm-box--align-items-center mm-box--width-full mm-box--background-color-transparent"
|
||||
>
|
||||
<div
|
||||
class="mm-box mm-text mm-avatar-base mm-avatar-base--size-sm mm-avatar-network mm-text--body-sm mm-text--text-transform-uppercase mm-box--display-flex mm-box--justify-content-center mm-box--align-items-center mm-box--color-text-default mm-box--background-color-background-alternative mm-box--rounded-full mm-box--border-color-transparent box--border-style-solid box--border-width-1"
|
||||
>
|
||||
S
|
||||
</div>
|
||||
<p
|
||||
class="mm-box mm-text mm-text--body-md mm-text--ellipsis mm-box--margin-left-2 mm-box--color-text-default mm-box--background-color-transparent"
|
||||
>
|
||||
Sepolia
|
||||
</p>
|
||||
</div>
|
||||
<label
|
||||
class="toggle-button toggle-button--on"
|
||||
tabindex="0"
|
||||
>
|
||||
<div
|
||||
style="display: flex; width: 52px; align-items: center; justify-content: flex-start; position: relative; cursor: pointer; background-color: transparent; border: 0px; padding: 0px; user-select: none;"
|
||||
>
|
||||
<div
|
||||
style="width: 40px; height: 24px; padding: 0px; border-radius: 26px; display: flex; align-items: center; justify-content: center; background-color: rgb(242, 244, 246);"
|
||||
>
|
||||
<div
|
||||
style="font-size: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Helvetica Neue', Helvetica, sans-serif; position: relative; color: rgb(250, 250, 250); margin-top: auto; margin-bottom: auto; line-height: 0; opacity: 1; width: 26px; height: 20px; left: 4px;"
|
||||
/>
|
||||
<div
|
||||
style="font-size: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Helvetica Neue', Helvetica, sans-serif; position: relative; color: rgba(255, 255, 255, 0.6); bottom: 0px; margin-top: auto; margin-bottom: auto; padding-right: 5px; line-height: 0; width: 26px; height: 20px; opacity: 0;"
|
||||
/>
|
||||
</div>
|
||||
<div
|
||||
style="position: absolute; height: 100%; top: 0px; left: 0px; display: flex; flex: 1; align-self: stretch; align-items: center; justify-content: flex-start;"
|
||||
>
|
||||
<div
|
||||
style="width: 18px; height: 18px; display: flex; align-self: center; box-shadow: none; border-radius: 50%; box-sizing: border-box; position: relative; background-color: rgb(3, 125, 214); left: 18px;"
|
||||
/>
|
||||
</div>
|
||||
<input
|
||||
style="border: 0px; height: 1px; margin: -1px; overflow: hidden; padding: 0px; position: absolute; width: 1px;"
|
||||
type="checkbox"
|
||||
value="true"
|
||||
/>
|
||||
</div>
|
||||
<div
|
||||
class="toggle-button__status"
|
||||
>
|
||||
<span
|
||||
class="toggle-button__label-off"
|
||||
>
|
||||
Off
|
||||
</span>
|
||||
<span
|
||||
class="toggle-button__label-on"
|
||||
>
|
||||
On
|
||||
</span>
|
||||
</div>
|
||||
</label>
|
||||
</div>
|
||||
<div
|
||||
class="mm-box network-toggle-wrapper mm-box--margin-top-6 mm-box--margin-bottom-6 mm-box--display-flex mm-box--flex-direction-row mm-box--justify-content-space-between"
|
||||
data-testid="network-toggle-0xe704"
|
||||
>
|
||||
<div
|
||||
class="mm-box mm-box--display-flex mm-box--gap-2 mm-box--align-items-center mm-box--width-full mm-box--background-color-transparent"
|
||||
>
|
||||
<div
|
||||
class="mm-box mm-text mm-avatar-base mm-avatar-base--size-sm mm-avatar-network mm-text--body-sm mm-text--text-transform-uppercase mm-box--display-flex mm-box--justify-content-center mm-box--align-items-center mm-box--color-text-default mm-box--background-color-background-alternative mm-box--rounded-full mm-box--border-color-transparent box--border-style-solid box--border-width-1"
|
||||
>
|
||||
<img
|
||||
alt="Linea Goerli logo"
|
||||
class="mm-avatar-network__network-image"
|
||||
src="./images/linea-logo-testnet.png"
|
||||
/>
|
||||
</div>
|
||||
<p
|
||||
class="mm-box mm-text mm-text--body-md mm-text--ellipsis mm-box--margin-left-2 mm-box--color-text-default mm-box--background-color-transparent"
|
||||
>
|
||||
Linea Goerli
|
||||
</p>
|
||||
</div>
|
||||
<label
|
||||
class="toggle-button toggle-button--on"
|
||||
tabindex="0"
|
||||
>
|
||||
<div
|
||||
style="display: flex; width: 52px; align-items: center; justify-content: flex-start; position: relative; cursor: pointer; background-color: transparent; border: 0px; padding: 0px; user-select: none;"
|
||||
>
|
||||
<div
|
||||
style="width: 40px; height: 24px; padding: 0px; border-radius: 26px; display: flex; align-items: center; justify-content: center; background-color: rgb(242, 244, 246);"
|
||||
>
|
||||
<div
|
||||
style="font-size: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Helvetica Neue', Helvetica, sans-serif; position: relative; color: rgb(250, 250, 250); margin-top: auto; margin-bottom: auto; line-height: 0; opacity: 1; width: 26px; height: 20px; left: 4px;"
|
||||
/>
|
||||
<div
|
||||
style="font-size: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Helvetica Neue', Helvetica, sans-serif; position: relative; color: rgba(255, 255, 255, 0.6); bottom: 0px; margin-top: auto; margin-bottom: auto; padding-right: 5px; line-height: 0; width: 26px; height: 20px; opacity: 0;"
|
||||
/>
|
||||
</div>
|
||||
<div
|
||||
style="position: absolute; height: 100%; top: 0px; left: 0px; display: flex; flex: 1; align-self: stretch; align-items: center; justify-content: flex-start;"
|
||||
>
|
||||
<div
|
||||
style="width: 18px; height: 18px; display: flex; align-self: center; box-shadow: none; border-radius: 50%; box-sizing: border-box; position: relative; background-color: rgb(3, 125, 214); left: 18px;"
|
||||
/>
|
||||
</div>
|
||||
<input
|
||||
style="border: 0px; height: 1px; margin: -1px; overflow: hidden; padding: 0px; position: absolute; width: 1px;"
|
||||
type="checkbox"
|
||||
value="true"
|
||||
/>
|
||||
</div>
|
||||
<div
|
||||
class="toggle-button__status"
|
||||
>
|
||||
<span
|
||||
class="toggle-button__label-off"
|
||||
>
|
||||
Off
|
||||
</span>
|
||||
<span
|
||||
class="toggle-button__label-on"
|
||||
>
|
||||
On
|
||||
</span>
|
||||
</div>
|
||||
</label>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
`;
|
@ -0,0 +1,209 @@
|
||||
import React from 'react';
|
||||
import { fireEvent, within } from '@testing-library/react';
|
||||
import configureMockState from 'redux-mock-store';
|
||||
import thunk from 'redux-thunk';
|
||||
import { renderWithProvider } from '../../../../test/lib/render-helpers';
|
||||
import mockState from '../../../../test/data/mock-state.json';
|
||||
import { MetaMetricsContext } from '../../../contexts/metametrics';
|
||||
import IncomingTransactionToggle from './incoming-transaction-toggle';
|
||||
|
||||
const mockTrackEvent = jest.fn();
|
||||
const ALL_NETWORKS_DATA = [
|
||||
{
|
||||
chainId: '0x1',
|
||||
nickname: 'Ethereum Mainnet',
|
||||
rpcUrl: 'https://mainnet.infura.io/v3/6c21df2a8dcb4a77b9bbcc1b65ee9ded',
|
||||
rpcPrefs: {
|
||||
imageUrl: './images/eth_logo.png',
|
||||
},
|
||||
providerType: 'mainnet',
|
||||
ticker: 'ETH',
|
||||
id: 'mainnet',
|
||||
removable: false,
|
||||
},
|
||||
{
|
||||
chainId: '0xe708',
|
||||
nickname: 'Linea Mainnet',
|
||||
rpcUrl:
|
||||
'https://linea-mainnet.infura.io/v3/6c21df2a8dcb4a77b9bbcc1b65ee9ded',
|
||||
rpcPrefs: {
|
||||
imageUrl: './images/linea-logo-mainnet.png',
|
||||
},
|
||||
providerType: 'linea-mainnet',
|
||||
id: 'linea-mainnet',
|
||||
removable: false,
|
||||
},
|
||||
{
|
||||
chainId: '0xfa',
|
||||
nickname: 'FANTOM',
|
||||
rpcPrefs: {},
|
||||
rpcUrl: 'http://ftmscan.com5',
|
||||
ticker: 'FTM',
|
||||
},
|
||||
{
|
||||
chainId: '0x5',
|
||||
nickname: 'Goerli',
|
||||
rpcUrl: 'https://goerli.infura.io/v3/6c21df2a8dcb4a77b9bbcc1b65ee9ded',
|
||||
providerType: 'goerli',
|
||||
ticker: 'GoerliETH',
|
||||
id: 'goerli',
|
||||
removable: false,
|
||||
},
|
||||
{
|
||||
chainId: '0xaa36a7',
|
||||
nickname: 'Sepolia',
|
||||
rpcUrl: 'https://sepolia.infura.io/v3/6c21df2a8dcb4a77b9bbcc1b65ee9ded',
|
||||
providerType: 'sepolia',
|
||||
ticker: 'SepoliaETH',
|
||||
id: 'sepolia',
|
||||
removable: false,
|
||||
},
|
||||
{
|
||||
chainId: '0xe704',
|
||||
nickname: 'Linea Goerli',
|
||||
rpcUrl:
|
||||
'https://linea-goerli.infura.io/v3/6c21df2a8dcb4a77b9bbcc1b65ee9ded',
|
||||
rpcPrefs: {
|
||||
imageUrl: './images/linea-logo-testnet.png',
|
||||
},
|
||||
providerType: 'linea-goerli',
|
||||
ticker: 'LineaETH',
|
||||
id: 'linea-goerli',
|
||||
removable: false,
|
||||
},
|
||||
];
|
||||
|
||||
const INCOMING_DATA = {
|
||||
'0x1': true,
|
||||
'0xe708': false,
|
||||
'0xfa': true,
|
||||
'0x5': false,
|
||||
'0xaa36a7': true,
|
||||
'0xe704': true,
|
||||
};
|
||||
|
||||
describe('IncomingTransactionToggle', () => {
|
||||
const mockStore = configureMockState([thunk])(mockState);
|
||||
let setIncomingTransactionsPreferencesStub;
|
||||
|
||||
beforeEach(() => {
|
||||
setIncomingTransactionsPreferencesStub = jest.fn();
|
||||
});
|
||||
|
||||
it('should render existing incoming transaction preferences', () => {
|
||||
const { container, getByTestId } = renderWithProvider(
|
||||
<MetaMetricsContext.Provider value={mockTrackEvent}>
|
||||
<IncomingTransactionToggle
|
||||
setIncomingTransactionsPreferences={
|
||||
setIncomingTransactionsPreferencesStub
|
||||
}
|
||||
allNetworks={ALL_NETWORKS_DATA}
|
||||
incomingTransactionsPreferences={INCOMING_DATA}
|
||||
/>
|
||||
</MetaMetricsContext.Provider>,
|
||||
mockStore,
|
||||
);
|
||||
expect(container).toMatchSnapshot();
|
||||
const enableForAllCheckbox = within(
|
||||
getByTestId('incoming-transaction-toggle-enable-all'),
|
||||
).getByRole('checkbox');
|
||||
expect(enableForAllCheckbox.checked).toStrictEqual(false);
|
||||
|
||||
const ethMainnetCheckbox = within(
|
||||
getByTestId(`network-toggle-${ALL_NETWORKS_DATA[0].chainId}`),
|
||||
).getByRole('checkbox');
|
||||
expect(ethMainnetCheckbox.value).toStrictEqual('true');
|
||||
const lineaMainnetCheckbox = within(
|
||||
getByTestId(`network-toggle-${ALL_NETWORKS_DATA[1].chainId}`),
|
||||
).getByRole('checkbox');
|
||||
expect(lineaMainnetCheckbox.value).toStrictEqual('false');
|
||||
const fantomCheckbox = within(
|
||||
getByTestId(`network-toggle-${ALL_NETWORKS_DATA[2].chainId}`),
|
||||
).getByRole('checkbox');
|
||||
expect(fantomCheckbox.value).toStrictEqual('true');
|
||||
const goerliCheckbox = within(
|
||||
getByTestId(`network-toggle-${ALL_NETWORKS_DATA[3].chainId}`),
|
||||
).getByRole('checkbox');
|
||||
expect(goerliCheckbox.value).toStrictEqual('false');
|
||||
const sepoliaCheckbox = within(
|
||||
getByTestId(`network-toggle-${ALL_NETWORKS_DATA[4].chainId}`),
|
||||
).getByRole('checkbox');
|
||||
expect(sepoliaCheckbox.value).toStrictEqual('true');
|
||||
const lineaGoerliCheckbox = within(
|
||||
getByTestId(`network-toggle-${ALL_NETWORKS_DATA[5].chainId}`),
|
||||
).getByRole('checkbox');
|
||||
expect(lineaGoerliCheckbox.value).toStrictEqual('true');
|
||||
});
|
||||
|
||||
it('should trigger settle for all when click toggle all button', () => {
|
||||
const { getByTestId } = renderWithProvider(
|
||||
<MetaMetricsContext.Provider value={mockTrackEvent}>
|
||||
<IncomingTransactionToggle
|
||||
setIncomingTransactionsPreferences={
|
||||
setIncomingTransactionsPreferencesStub
|
||||
}
|
||||
allNetworks={ALL_NETWORKS_DATA}
|
||||
incomingTransactionsPreferences={INCOMING_DATA}
|
||||
/>
|
||||
</MetaMetricsContext.Provider>,
|
||||
mockStore,
|
||||
);
|
||||
const enableForAllCheckbox = within(
|
||||
getByTestId('incoming-transaction-toggle-enable-all'),
|
||||
).getByRole('checkbox');
|
||||
fireEvent.click(enableForAllCheckbox);
|
||||
// set 2 false to true
|
||||
expect(setIncomingTransactionsPreferencesStub).toHaveBeenCalledTimes(2);
|
||||
expect(
|
||||
setIncomingTransactionsPreferencesStub.mock.calls[0][0],
|
||||
).toStrictEqual('0xe708');
|
||||
expect(
|
||||
setIncomingTransactionsPreferencesStub.mock.calls[0][1],
|
||||
).toStrictEqual(true);
|
||||
expect(
|
||||
setIncomingTransactionsPreferencesStub.mock.calls[1][0],
|
||||
).toStrictEqual('0x5');
|
||||
expect(
|
||||
setIncomingTransactionsPreferencesStub.mock.calls[1][1],
|
||||
).toStrictEqual(true);
|
||||
});
|
||||
|
||||
it('should trigger settle for one when click toggle one button', () => {
|
||||
const { getByTestId } = renderWithProvider(
|
||||
<MetaMetricsContext.Provider value={mockTrackEvent}>
|
||||
<IncomingTransactionToggle
|
||||
setIncomingTransactionsPreferences={
|
||||
setIncomingTransactionsPreferencesStub
|
||||
}
|
||||
allNetworks={ALL_NETWORKS_DATA}
|
||||
incomingTransactionsPreferences={INCOMING_DATA}
|
||||
/>
|
||||
</MetaMetricsContext.Provider>,
|
||||
mockStore,
|
||||
);
|
||||
const lineaMainnetCheckbox = within(
|
||||
getByTestId(`network-toggle-${ALL_NETWORKS_DATA[1].chainId}`),
|
||||
).getByRole('checkbox');
|
||||
fireEvent.click(lineaMainnetCheckbox);
|
||||
// set 1 false to true
|
||||
expect(setIncomingTransactionsPreferencesStub).toHaveBeenCalledTimes(1);
|
||||
expect(
|
||||
setIncomingTransactionsPreferencesStub.mock.calls[0][0],
|
||||
).toStrictEqual('0xe708');
|
||||
expect(
|
||||
setIncomingTransactionsPreferencesStub.mock.calls[0][1],
|
||||
).toStrictEqual(true);
|
||||
|
||||
// set 1 false to true
|
||||
const goerliCheckbox = within(
|
||||
getByTestId(`network-toggle-${ALL_NETWORKS_DATA[3].chainId}`),
|
||||
).getByRole('checkbox');
|
||||
fireEvent.click(goerliCheckbox);
|
||||
expect(
|
||||
setIncomingTransactionsPreferencesStub.mock.calls[1][0],
|
||||
).toStrictEqual('0x5');
|
||||
expect(
|
||||
setIncomingTransactionsPreferencesStub.mock.calls[1][1],
|
||||
).toStrictEqual(true);
|
||||
});
|
||||
});
|
@ -0,0 +1,145 @@
|
||||
import React, { useContext, useEffect, useState } from 'react';
|
||||
|
||||
import PropTypes from 'prop-types';
|
||||
import { I18nContext } from '../../../contexts/i18n';
|
||||
|
||||
import ToggleButton from '../../ui/toggle-button';
|
||||
import { Box, Text } from '../../component-library';
|
||||
import {
|
||||
Display,
|
||||
FlexDirection,
|
||||
JustifyContent,
|
||||
TextVariant,
|
||||
FontWeight,
|
||||
TextColor,
|
||||
} from '../../../helpers/constants/design-system';
|
||||
|
||||
import { PolymorphicRef } from '../../component-library/box';
|
||||
import { TEST_CHAINS } from '../../../../shared/constants/network';
|
||||
import NetworkToggle from './network-toggle';
|
||||
|
||||
interface IncomingTransactionToggleProps {
|
||||
wrapperRef: PolymorphicRef<any>;
|
||||
incomingTransactionsPreferences: Record<string, boolean>;
|
||||
allNetworks: [Record<string, any>];
|
||||
setIncomingTransactionsPreferences: (
|
||||
chainId: string,
|
||||
isAllEnabledValue: boolean,
|
||||
) => void;
|
||||
}
|
||||
|
||||
const IncomingTransactionToggle = ({
|
||||
wrapperRef,
|
||||
incomingTransactionsPreferences,
|
||||
allNetworks,
|
||||
setIncomingTransactionsPreferences,
|
||||
}: IncomingTransactionToggleProps) => {
|
||||
const t = useContext(I18nContext);
|
||||
|
||||
const [networkPreferences, setNetworkPreferences] = useState(
|
||||
generateIncomingNetworkPreferences(
|
||||
incomingTransactionsPreferences,
|
||||
allNetworks,
|
||||
),
|
||||
);
|
||||
|
||||
const [isAllEnabled, setIsAllEnabled] = useState(
|
||||
checkAllNetworks(incomingTransactionsPreferences),
|
||||
);
|
||||
|
||||
useEffect(() => {
|
||||
setNetworkPreferences(
|
||||
generateIncomingNetworkPreferences(
|
||||
incomingTransactionsPreferences,
|
||||
allNetworks,
|
||||
),
|
||||
);
|
||||
}, [incomingTransactionsPreferences, allNetworks]);
|
||||
|
||||
useEffect(() => {
|
||||
setIsAllEnabled(checkAllNetworks(incomingTransactionsPreferences));
|
||||
}, [incomingTransactionsPreferences]);
|
||||
|
||||
const toggleAllEnabled = (isAllEnabledValue: boolean): void => {
|
||||
Object.keys(incomingTransactionsPreferences).forEach((chainId) => {
|
||||
if (incomingTransactionsPreferences[chainId] !== isAllEnabledValue) {
|
||||
setIncomingTransactionsPreferences(chainId, isAllEnabledValue);
|
||||
}
|
||||
});
|
||||
};
|
||||
|
||||
const toggleSingleNetwork = (chainId: string, value: boolean): void => {
|
||||
setIncomingTransactionsPreferences(chainId, value);
|
||||
};
|
||||
|
||||
return (
|
||||
<Box ref={wrapperRef} className="mm-incoming-transaction-toggle">
|
||||
<Text variant={TextVariant.bodyLgMedium} fontWeight={FontWeight.Bold}>
|
||||
{t('showIncomingTransactions')}
|
||||
</Text>
|
||||
|
||||
<Text variant={TextVariant.bodyMd} color={TextColor.textAlternative}>
|
||||
{t('showIncomingTransactionsInformation')}
|
||||
</Text>
|
||||
<Box
|
||||
marginTop={3}
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Row}
|
||||
justifyContent={JustifyContent.spaceBetween}
|
||||
data-testid="incoming-transaction-toggle-enable-all"
|
||||
>
|
||||
<Text variant={TextVariant.bodyMd}> {t('enableForAllNetworks')}</Text>
|
||||
<ToggleButton
|
||||
value={isAllEnabled}
|
||||
onToggle={(value) => toggleAllEnabled(!value)}
|
||||
offLabel={t('off')}
|
||||
onLabel={t('on')}
|
||||
/>
|
||||
</Box>
|
||||
{Object.keys(networkPreferences).map((chainId, index) => {
|
||||
return (
|
||||
<NetworkToggle
|
||||
key={index}
|
||||
chainId={chainId}
|
||||
networkPreferences={networkPreferences[chainId]}
|
||||
toggleSingleNetwork={toggleSingleNetwork}
|
||||
/>
|
||||
);
|
||||
})}
|
||||
</Box>
|
||||
);
|
||||
};
|
||||
|
||||
export default IncomingTransactionToggle;
|
||||
|
||||
IncomingTransactionToggle.propTypes = {
|
||||
wrapperRef: PropTypes.object,
|
||||
incomingTransactionsPreferences: PropTypes.object.isRequired,
|
||||
allNetworks: PropTypes.array.isRequired,
|
||||
setIncomingTransactionsPreferences: PropTypes.func.isRequired,
|
||||
};
|
||||
|
||||
function generateIncomingNetworkPreferences(
|
||||
incomingTransactionsPreferences: Record<string, boolean>,
|
||||
allNetworks: Record<string, any>,
|
||||
): Record<string, any> {
|
||||
const incomingTxnPreferences: Record<string, any> = {};
|
||||
|
||||
Object.keys(allNetworks).forEach((id) => {
|
||||
const { chainId } = allNetworks[id];
|
||||
incomingTxnPreferences[chainId] = {
|
||||
isShowIncomingTransactions: incomingTransactionsPreferences[chainId],
|
||||
isATestNetwork: TEST_CHAINS.includes(chainId),
|
||||
label: allNetworks[id].nickname,
|
||||
imageUrl: allNetworks[id].rpcPrefs?.imageUrl,
|
||||
};
|
||||
});
|
||||
|
||||
return incomingTxnPreferences;
|
||||
}
|
||||
|
||||
function checkAllNetworks(
|
||||
incomingTransactionsPreferences: Record<string, boolean>,
|
||||
): boolean {
|
||||
return Object.values(incomingTransactionsPreferences).every(Boolean);
|
||||
}
|
104
ui/components/app/incoming-trasaction-toggle/network-toggle.tsx
Normal file
104
ui/components/app/incoming-trasaction-toggle/network-toggle.tsx
Normal file
@ -0,0 +1,104 @@
|
||||
import React, { useContext } from 'react';
|
||||
import PropTypes from 'prop-types';
|
||||
import {
|
||||
AvatarNetwork,
|
||||
AvatarNetworkSize,
|
||||
Box,
|
||||
Text,
|
||||
} from '../../component-library';
|
||||
import {
|
||||
AlignItems,
|
||||
BackgroundColor,
|
||||
BlockSize,
|
||||
Display,
|
||||
FlexDirection,
|
||||
JustifyContent,
|
||||
TextColor,
|
||||
TextVariant,
|
||||
} from '../../../helpers/constants/design-system';
|
||||
|
||||
import Tooltip from '../../ui/tooltip';
|
||||
import ToggleButton from '../../ui/toggle-button';
|
||||
import { I18nContext } from '../../../contexts/i18n';
|
||||
|
||||
const MAXIMUM_CHARACTERS_WITHOUT_TOOLTIP = 20;
|
||||
|
||||
interface NetworkPreferences {
|
||||
isShowIncomingTransactions: boolean;
|
||||
label: string;
|
||||
imageUrl: string;
|
||||
}
|
||||
|
||||
interface NetworkToggleProps {
|
||||
networkPreferences: NetworkPreferences;
|
||||
toggleSingleNetwork: (chainId: string, value: boolean) => void;
|
||||
chainId: string;
|
||||
}
|
||||
|
||||
const NetworkToggle = ({
|
||||
networkPreferences,
|
||||
toggleSingleNetwork,
|
||||
chainId,
|
||||
}: NetworkToggleProps) => {
|
||||
const t = useContext(I18nContext);
|
||||
|
||||
const { isShowIncomingTransactions } = networkPreferences;
|
||||
|
||||
const networkName = networkPreferences.label;
|
||||
|
||||
return (
|
||||
<Box
|
||||
marginTop={6}
|
||||
marginBottom={6}
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Row}
|
||||
justifyContent={JustifyContent.spaceBetween}
|
||||
data-testid={`network-toggle-${chainId}`}
|
||||
className="network-toggle-wrapper"
|
||||
>
|
||||
<Box
|
||||
gap={2}
|
||||
backgroundColor={BackgroundColor.transparent}
|
||||
display={Display.Flex}
|
||||
alignItems={AlignItems.center}
|
||||
width={BlockSize.Full}
|
||||
>
|
||||
<AvatarNetwork
|
||||
size={AvatarNetworkSize.Sm}
|
||||
src={networkPreferences.imageUrl}
|
||||
name={networkName}
|
||||
/>
|
||||
<Text
|
||||
color={TextColor.textDefault}
|
||||
backgroundColor={BackgroundColor.transparent}
|
||||
variant={TextVariant.bodyMd}
|
||||
ellipsis
|
||||
marginLeft={2}
|
||||
>
|
||||
{networkName.length > MAXIMUM_CHARACTERS_WITHOUT_TOOLTIP ? (
|
||||
<Tooltip title={networkName} position="bottom">
|
||||
{networkName}
|
||||
</Tooltip>
|
||||
) : (
|
||||
networkName
|
||||
)}
|
||||
</Text>
|
||||
</Box>
|
||||
|
||||
<ToggleButton
|
||||
value={isShowIncomingTransactions}
|
||||
onToggle={(value) => toggleSingleNetwork(chainId, !value)}
|
||||
offLabel={t('off')}
|
||||
onLabel={t('on')}
|
||||
/>
|
||||
</Box>
|
||||
);
|
||||
};
|
||||
|
||||
export default NetworkToggle;
|
||||
|
||||
NetworkToggle.propTypes = {
|
||||
chainId: PropTypes.string.isRequired,
|
||||
networkPreferences: PropTypes.object.isRequired,
|
||||
toggleSingleNetwork: PropTypes.func.isRequired,
|
||||
};
|
@ -1,13 +1,15 @@
|
||||
import React from 'react';
|
||||
import PropTypes from 'prop-types';
|
||||
import Box from '../../../components/ui/box';
|
||||
import Typography from '../../../components/ui/typography';
|
||||
import { Box, Text } from '../../../components/component-library';
|
||||
import ToggleButton from '../../../components/ui/toggle-button';
|
||||
import {
|
||||
JustifyContent,
|
||||
TypographyVariant,
|
||||
FONT_WEIGHT,
|
||||
TextVariant,
|
||||
AlignItems,
|
||||
Display,
|
||||
FontWeight,
|
||||
} from '../../../helpers/constants/design-system';
|
||||
import { useI18nContext } from '../../../hooks/useI18nContext';
|
||||
|
||||
export const Setting = ({
|
||||
value,
|
||||
@ -16,20 +18,31 @@ export const Setting = ({
|
||||
description,
|
||||
showToggle = true,
|
||||
}) => {
|
||||
const t = useI18nContext();
|
||||
|
||||
return (
|
||||
<Box justifyContent={JustifyContent.center} margin={3}>
|
||||
<div className="privacy-settings__setting">
|
||||
<Typography
|
||||
variant={TypographyVariant.H5}
|
||||
fontWeight={FONT_WEIGHT.BOLD}
|
||||
<Box
|
||||
display={Display.Flex}
|
||||
justifyContent={JustifyContent.spaceBetween}
|
||||
alignItems={AlignItems.center}
|
||||
marginTop={3}
|
||||
marginBottom={3}
|
||||
className="privacy-settings__setting__wrapper"
|
||||
>
|
||||
<div className="privacy-settings__setting">
|
||||
<Text variant={TextVariant.bodyLgMedium} fontWeight={FontWeight.Bold}>
|
||||
{title}
|
||||
</Typography>
|
||||
<Typography variant={TypographyVariant.H6}>{description}</Typography>
|
||||
</Text>
|
||||
<Text variant={TextVariant.bodyMd}>{description}</Text>
|
||||
</div>
|
||||
{showToggle ? (
|
||||
<div className="privacy-settings__setting__toggle">
|
||||
<ToggleButton value={value} onToggle={(val) => setValue(!val)} />
|
||||
<ToggleButton
|
||||
value={value}
|
||||
onToggle={(val) => setValue(!val)}
|
||||
offLabel={t('off')}
|
||||
onLabel={t('on')}
|
||||
/>
|
||||
</div>
|
||||
) : null}
|
||||
</Box>
|
||||
|
@ -0,0 +1,656 @@
|
||||
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
||||
|
||||
exports[`AdvancedTab Component should match snapshot 1`] = `
|
||||
<div>
|
||||
<div
|
||||
class="settings-page__body"
|
||||
>
|
||||
<div
|
||||
class="mm-box settings-page__content-row mm-box--display-flex mm-box--flex-direction-column"
|
||||
data-testid="advanced-setting-state-logs"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<span>
|
||||
State logs
|
||||
</span>
|
||||
<span
|
||||
class="settings-page__content-description"
|
||||
>
|
||||
State logs contain your public account addresses and sent transactions.
|
||||
</span>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item-col"
|
||||
>
|
||||
<button
|
||||
class="button btn--rounded btn-secondary btn--large"
|
||||
role="button"
|
||||
tabindex="0"
|
||||
>
|
||||
Download state logs
|
||||
</button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="mm-box settings-page__content-row mm-box--display-flex mm-box--flex-direction-column"
|
||||
data-testid="advanced-setting-reset-account"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<span>
|
||||
Clear activity and nonce data
|
||||
</span>
|
||||
<span
|
||||
class="settings-page__content-description"
|
||||
>
|
||||
This resets the account's nonce and erases data from the activity tab in your wallet. Only the current account and network will be affected. Your balances and incoming transactions won't change.
|
||||
</span>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item-col"
|
||||
>
|
||||
<button
|
||||
class="button btn--rounded btn-danger btn--large settings-tab__button--red"
|
||||
role="button"
|
||||
tabindex="0"
|
||||
>
|
||||
Clear activity tab data
|
||||
</button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="mm-box settings-page__content-row mm-box--display-flex mm-box--flex-direction-row mm-box--justify-content-space-between"
|
||||
data-testid="advanced-setting-hex-data"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<span>
|
||||
Show hex data
|
||||
</span>
|
||||
<div
|
||||
class="settings-page__content-description"
|
||||
>
|
||||
Select this to show the hex data field on the send screen
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-item-col"
|
||||
>
|
||||
<label
|
||||
class="toggle-button toggle-button--off"
|
||||
tabindex="0"
|
||||
>
|
||||
<div
|
||||
style="display: flex; width: 52px; align-items: center; justify-content: flex-start; position: relative; cursor: pointer; background-color: transparent; border: 0px; padding: 0px; user-select: none;"
|
||||
>
|
||||
<div
|
||||
style="width: 40px; height: 24px; padding: 0px; border-radius: 26px; display: flex; align-items: center; justify-content: center; background-color: rgb(242, 244, 246);"
|
||||
>
|
||||
<div
|
||||
style="font-size: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Helvetica Neue', Helvetica, sans-serif; position: relative; color: rgb(250, 250, 250); margin-top: auto; margin-bottom: auto; line-height: 0; opacity: 0; width: 26px; height: 20px; left: 4px;"
|
||||
/>
|
||||
<div
|
||||
style="font-size: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Helvetica Neue', Helvetica, sans-serif; position: relative; color: rgba(255, 255, 255, 0.6); bottom: 0px; margin-top: auto; margin-bottom: auto; padding-right: 5px; line-height: 0; width: 26px; height: 20px; opacity: 1;"
|
||||
/>
|
||||
</div>
|
||||
<div
|
||||
style="position: absolute; height: 100%; top: 0px; left: 0px; display: flex; flex: 1; align-self: stretch; align-items: center; justify-content: flex-start;"
|
||||
>
|
||||
<div
|
||||
style="width: 18px; height: 18px; display: flex; align-self: center; box-shadow: none; border-radius: 50%; box-sizing: border-box; position: relative; background-color: rgb(106, 115, 125); left: 3px;"
|
||||
/>
|
||||
</div>
|
||||
<input
|
||||
style="border: 0px; height: 1px; margin: -1px; overflow: hidden; padding: 0px; position: absolute; width: 1px;"
|
||||
type="checkbox"
|
||||
value="false"
|
||||
/>
|
||||
</div>
|
||||
<div
|
||||
class="toggle-button__status"
|
||||
>
|
||||
<span
|
||||
class="toggle-button__label-off"
|
||||
>
|
||||
Off
|
||||
</span>
|
||||
<span
|
||||
class="toggle-button__label-on"
|
||||
>
|
||||
On
|
||||
</span>
|
||||
</div>
|
||||
</label>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="mm-box settings-page__content-row mm-box--display-flex mm-box--flex-direction-row mm-box--justify-content-space-between"
|
||||
data-testid="advanced-setting-show-testnet-conversion"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<span>
|
||||
Show conversion on test networks
|
||||
</span>
|
||||
<div
|
||||
class="settings-page__content-description"
|
||||
>
|
||||
Select this to show fiat conversion on test networks
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-item-col"
|
||||
>
|
||||
<label
|
||||
class="toggle-button toggle-button--off"
|
||||
tabindex="0"
|
||||
>
|
||||
<div
|
||||
style="display: flex; width: 52px; align-items: center; justify-content: flex-start; position: relative; cursor: pointer; background-color: transparent; border: 0px; padding: 0px; user-select: none;"
|
||||
>
|
||||
<div
|
||||
style="width: 40px; height: 24px; padding: 0px; border-radius: 26px; display: flex; align-items: center; justify-content: center; background-color: rgb(242, 244, 246);"
|
||||
>
|
||||
<div
|
||||
style="font-size: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Helvetica Neue', Helvetica, sans-serif; position: relative; color: rgb(250, 250, 250); margin-top: auto; margin-bottom: auto; line-height: 0; opacity: 0; width: 26px; height: 20px; left: 4px;"
|
||||
/>
|
||||
<div
|
||||
style="font-size: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Helvetica Neue', Helvetica, sans-serif; position: relative; color: rgba(255, 255, 255, 0.6); bottom: 0px; margin-top: auto; margin-bottom: auto; padding-right: 5px; line-height: 0; width: 26px; height: 20px; opacity: 1;"
|
||||
/>
|
||||
</div>
|
||||
<div
|
||||
style="position: absolute; height: 100%; top: 0px; left: 0px; display: flex; flex: 1; align-self: stretch; align-items: center; justify-content: flex-start;"
|
||||
>
|
||||
<div
|
||||
style="width: 18px; height: 18px; display: flex; align-self: center; box-shadow: none; border-radius: 50%; box-sizing: border-box; position: relative; background-color: rgb(106, 115, 125); left: 3px;"
|
||||
/>
|
||||
</div>
|
||||
<input
|
||||
style="border: 0px; height: 1px; margin: -1px; overflow: hidden; padding: 0px; position: absolute; width: 1px;"
|
||||
type="checkbox"
|
||||
value="false"
|
||||
/>
|
||||
</div>
|
||||
<div
|
||||
class="toggle-button__status"
|
||||
>
|
||||
<span
|
||||
class="toggle-button__label-off"
|
||||
>
|
||||
Off
|
||||
</span>
|
||||
<span
|
||||
class="toggle-button__label-on"
|
||||
>
|
||||
On
|
||||
</span>
|
||||
</div>
|
||||
</label>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="mm-box settings-page__content-row mm-box--display-flex mm-box--flex-direction-row mm-box--justify-content-space-between"
|
||||
data-testid="advanced-setting-show-testnet-conversion"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<span>
|
||||
Show test networks
|
||||
</span>
|
||||
<div
|
||||
class="settings-page__content-description"
|
||||
>
|
||||
Select this to show test networks in network list
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-item-col"
|
||||
>
|
||||
<label
|
||||
class="toggle-button toggle-button--on"
|
||||
tabindex="0"
|
||||
>
|
||||
<div
|
||||
style="display: flex; width: 52px; align-items: center; justify-content: flex-start; position: relative; cursor: pointer; background-color: transparent; border: 0px; padding: 0px; user-select: none;"
|
||||
>
|
||||
<div
|
||||
style="width: 40px; height: 24px; padding: 0px; border-radius: 26px; display: flex; align-items: center; justify-content: center; background-color: rgb(242, 244, 246);"
|
||||
>
|
||||
<div
|
||||
style="font-size: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Helvetica Neue', Helvetica, sans-serif; position: relative; color: rgb(250, 250, 250); margin-top: auto; margin-bottom: auto; line-height: 0; opacity: 1; width: 26px; height: 20px; left: 4px;"
|
||||
/>
|
||||
<div
|
||||
style="font-size: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Helvetica Neue', Helvetica, sans-serif; position: relative; color: rgba(255, 255, 255, 0.6); bottom: 0px; margin-top: auto; margin-bottom: auto; padding-right: 5px; line-height: 0; width: 26px; height: 20px; opacity: 0;"
|
||||
/>
|
||||
</div>
|
||||
<div
|
||||
style="position: absolute; height: 100%; top: 0px; left: 0px; display: flex; flex: 1; align-self: stretch; align-items: center; justify-content: flex-start;"
|
||||
>
|
||||
<div
|
||||
style="width: 18px; height: 18px; display: flex; align-self: center; box-shadow: none; border-radius: 50%; box-sizing: border-box; position: relative; background-color: rgb(3, 125, 214); left: 18px;"
|
||||
/>
|
||||
</div>
|
||||
<input
|
||||
style="border: 0px; height: 1px; margin: -1px; overflow: hidden; padding: 0px; position: absolute; width: 1px;"
|
||||
type="checkbox"
|
||||
value="true"
|
||||
/>
|
||||
</div>
|
||||
<div
|
||||
class="toggle-button__status"
|
||||
>
|
||||
<span
|
||||
class="toggle-button__label-off"
|
||||
>
|
||||
Off
|
||||
</span>
|
||||
<span
|
||||
class="toggle-button__label-on"
|
||||
>
|
||||
On
|
||||
</span>
|
||||
</div>
|
||||
</label>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="mm-box settings-page__content-row mm-box--display-flex mm-box--flex-direction-row mm-box--justify-content-space-between"
|
||||
data-testid="advanced-setting-custom-nonce"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<span>
|
||||
Customize transaction nonce
|
||||
</span>
|
||||
<div
|
||||
class="settings-page__content-description"
|
||||
>
|
||||
Turn this on to change the nonce (transaction number) on confirmation screens. This is an advanced feature, use cautiously.
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-item-col"
|
||||
>
|
||||
<label
|
||||
class="toggle-button toggle-button--off"
|
||||
tabindex="0"
|
||||
>
|
||||
<div
|
||||
style="display: flex; width: 52px; align-items: center; justify-content: flex-start; position: relative; cursor: pointer; background-color: transparent; border: 0px; padding: 0px; user-select: none;"
|
||||
>
|
||||
<div
|
||||
style="width: 40px; height: 24px; padding: 0px; border-radius: 26px; display: flex; align-items: center; justify-content: center; background-color: rgb(242, 244, 246);"
|
||||
>
|
||||
<div
|
||||
style="font-size: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Helvetica Neue', Helvetica, sans-serif; position: relative; color: rgb(250, 250, 250); margin-top: auto; margin-bottom: auto; line-height: 0; opacity: 0; width: 26px; height: 20px; left: 4px;"
|
||||
/>
|
||||
<div
|
||||
style="font-size: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Helvetica Neue', Helvetica, sans-serif; position: relative; color: rgba(255, 255, 255, 0.6); bottom: 0px; margin-top: auto; margin-bottom: auto; padding-right: 5px; line-height: 0; width: 26px; height: 20px; opacity: 1;"
|
||||
/>
|
||||
</div>
|
||||
<div
|
||||
style="position: absolute; height: 100%; top: 0px; left: 0px; display: flex; flex: 1; align-self: stretch; align-items: center; justify-content: flex-start;"
|
||||
>
|
||||
<div
|
||||
style="width: 18px; height: 18px; display: flex; align-self: center; box-shadow: none; border-radius: 50%; box-sizing: border-box; position: relative; background-color: rgb(106, 115, 125); left: 3px;"
|
||||
/>
|
||||
</div>
|
||||
<input
|
||||
style="border: 0px; height: 1px; margin: -1px; overflow: hidden; padding: 0px; position: absolute; width: 1px;"
|
||||
type="checkbox"
|
||||
value="false"
|
||||
/>
|
||||
</div>
|
||||
<div
|
||||
class="toggle-button__status"
|
||||
>
|
||||
<span
|
||||
class="toggle-button__label-off"
|
||||
>
|
||||
Off
|
||||
</span>
|
||||
<span
|
||||
class="toggle-button__label-on"
|
||||
>
|
||||
On
|
||||
</span>
|
||||
</div>
|
||||
</label>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="mm-box settings-page__content-row mm-box--display-flex mm-box--flex-direction-column"
|
||||
data-testid="advanced-setting-auto-lock"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<span>
|
||||
Auto-lock timer (minutes)
|
||||
</span>
|
||||
<div
|
||||
class="settings-page__content-description"
|
||||
>
|
||||
Set the idle time in minutes before MetaMask will become locked.
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item-col"
|
||||
>
|
||||
<div
|
||||
class="MuiFormControl-root MuiTextField-root MuiFormControl-marginDense MuiFormControl-fullWidth"
|
||||
>
|
||||
<div
|
||||
class="MuiInputBase-root MuiInput-root TextField-inputRoot-12 MuiInputBase-fullWidth MuiInput-fullWidth MuiInputBase-formControl MuiInput-formControl MuiInputBase-marginDense MuiInput-marginDense"
|
||||
>
|
||||
<input
|
||||
aria-invalid="false"
|
||||
class="MuiInputBase-input MuiInput-input MuiInputBase-inputMarginDense MuiInput-inputMarginDense"
|
||||
data-testid="auto-lockout-time"
|
||||
dir="auto"
|
||||
id="autoTimeout"
|
||||
min="0"
|
||||
placeholder="0"
|
||||
type="text"
|
||||
value="0"
|
||||
/>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
<button
|
||||
class="button btn--rounded btn-primary settings-tab__rpc-save-button"
|
||||
data-testid="auto-lockout-button"
|
||||
role="button"
|
||||
tabindex="0"
|
||||
>
|
||||
Save
|
||||
</button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="mm-box settings-page__content-row mm-box--display-flex mm-box--flex-direction-column"
|
||||
data-testid="advanced-setting-data-backup"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<span>
|
||||
Backup your data
|
||||
</span>
|
||||
<span
|
||||
class="settings-page__content-description"
|
||||
>
|
||||
You can backup user settings containing preferences and account addresses into a JSON file.
|
||||
</span>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item-col"
|
||||
>
|
||||
<button
|
||||
class="button btn--rounded btn-secondary btn--large"
|
||||
data-testid="backup-button"
|
||||
role="button"
|
||||
tabindex="0"
|
||||
>
|
||||
Backup
|
||||
</button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="mm-box settings-page__content-row mm-box--display-flex mm-box--flex-direction-column"
|
||||
data-testid="advanced-setting-data-restore"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<span>
|
||||
Restore user data
|
||||
</span>
|
||||
<span
|
||||
class="settings-page__content-description"
|
||||
>
|
||||
You can restore user settings containing preferences and account addresses from a previously backed up JSON file.
|
||||
</span>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item-col"
|
||||
>
|
||||
<label
|
||||
class="button btn btn--rounded btn-secondary btn--large settings-page__button"
|
||||
for="restore-file"
|
||||
>
|
||||
Restore
|
||||
</label>
|
||||
<input
|
||||
accept=".json"
|
||||
data-testid="restore-file"
|
||||
id="restore-file"
|
||||
style="visibility: hidden;"
|
||||
type="file"
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="mm-box settings-page__content-row mm-box--display-flex mm-box--flex-direction-column"
|
||||
data-testid="ledger-live-control"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<span>
|
||||
Preferred Ledger connection type
|
||||
</span>
|
||||
<div
|
||||
class="settings-page__content-description"
|
||||
>
|
||||
<span>
|
||||
|
||||
Customize how you connect your Ledger to MetaMask.
|
||||
U2F
|
||||
is recommended, but other options are available. Read more here:
|
||||
<a
|
||||
class="button btn-link settings-page__inline-link"
|
||||
href="https://metamask.zendesk.com/hc/en-us/articles/360020394612-How-to-connect-a-Trezor-or-Ledger-Hardware-Wallet"
|
||||
rel="noopener noreferrer"
|
||||
target="_blank"
|
||||
>
|
||||
learn more
|
||||
</a>
|
||||
|
||||
|
||||
</span>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item-col"
|
||||
>
|
||||
<div
|
||||
class="dropdown"
|
||||
>
|
||||
<select
|
||||
class="dropdown__select"
|
||||
>
|
||||
<option
|
||||
value="ledgerLive"
|
||||
>
|
||||
Ledger Live
|
||||
</option>
|
||||
<option
|
||||
value="u2f"
|
||||
>
|
||||
U2F
|
||||
</option>
|
||||
</select>
|
||||
<span
|
||||
class="mm-box dropdown__icon-caret-down mm-icon mm-icon--size-sm mm-box--display-inline-block mm-box--color-inherit"
|
||||
style="mask-image: url('./images/icons/arrow-down.svg');"
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="mm-box settings-page__content-row mm-box--display-flex mm-box--flex-direction-row mm-box--justify-content-space-between"
|
||||
data-testid="advanced-setting-dismiss-reminder"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<span>
|
||||
Dismiss Secret Recovery Phrase backup reminder
|
||||
</span>
|
||||
<div
|
||||
class="settings-page__content-description"
|
||||
>
|
||||
Turn this on to dismiss the Secret Recovery Phrase backup reminder message. We highly recommend that you back up your Secret Recovery Phrase to avoid loss of funds
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-item-col"
|
||||
>
|
||||
<label
|
||||
class="toggle-button toggle-button--off"
|
||||
tabindex="0"
|
||||
>
|
||||
<div
|
||||
style="display: flex; width: 52px; align-items: center; justify-content: flex-start; position: relative; cursor: pointer; background-color: transparent; border: 0px; padding: 0px; user-select: none;"
|
||||
>
|
||||
<div
|
||||
style="width: 40px; height: 24px; padding: 0px; border-radius: 26px; display: flex; align-items: center; justify-content: center; background-color: rgb(242, 244, 246);"
|
||||
>
|
||||
<div
|
||||
style="font-size: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Helvetica Neue', Helvetica, sans-serif; position: relative; color: rgb(250, 250, 250); margin-top: auto; margin-bottom: auto; line-height: 0; opacity: 0; width: 26px; height: 20px; left: 4px;"
|
||||
/>
|
||||
<div
|
||||
style="font-size: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Helvetica Neue', Helvetica, sans-serif; position: relative; color: rgba(255, 255, 255, 0.6); bottom: 0px; margin-top: auto; margin-bottom: auto; padding-right: 5px; line-height: 0; width: 26px; height: 20px; opacity: 1;"
|
||||
/>
|
||||
</div>
|
||||
<div
|
||||
style="position: absolute; height: 100%; top: 0px; left: 0px; display: flex; flex: 1; align-self: stretch; align-items: center; justify-content: flex-start;"
|
||||
>
|
||||
<div
|
||||
style="width: 18px; height: 18px; display: flex; align-self: center; box-shadow: none; border-radius: 50%; box-sizing: border-box; position: relative; background-color: rgb(106, 115, 125); left: 3px;"
|
||||
/>
|
||||
</div>
|
||||
<input
|
||||
style="border: 0px; height: 1px; margin: -1px; overflow: hidden; padding: 0px; position: absolute; width: 1px;"
|
||||
type="checkbox"
|
||||
value="false"
|
||||
/>
|
||||
</div>
|
||||
<div
|
||||
class="toggle-button__status"
|
||||
>
|
||||
<span
|
||||
class="toggle-button__label-off"
|
||||
>
|
||||
Off
|
||||
</span>
|
||||
<span
|
||||
class="toggle-button__label-on"
|
||||
>
|
||||
On
|
||||
</span>
|
||||
</div>
|
||||
</label>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="mm-box settings-page__content-row mm-box--display-flex mm-box--flex-direction-row mm-box--justify-content-space-between"
|
||||
data-testid="advanced-setting-toggle-ethsign"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<span>
|
||||
Eth_sign requests
|
||||
</span>
|
||||
<div
|
||||
class="settings-page__content-description"
|
||||
>
|
||||
If you enable this setting, you might get signature requests that aren’t readable. By signing a message you don't understand, you could be agreeing to give away your funds and NFTs.
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-item-col"
|
||||
>
|
||||
<label
|
||||
class="toggle-button toggle-button--off eth-sign-toggle"
|
||||
tabindex="0"
|
||||
>
|
||||
<div
|
||||
style="display: flex; width: 52px; align-items: center; justify-content: flex-start; position: relative; cursor: pointer; background-color: transparent; border: 0px; padding: 0px; user-select: none;"
|
||||
>
|
||||
<div
|
||||
style="width: 40px; height: 24px; padding: 0px; border-radius: 26px; display: flex; align-items: center; justify-content: center; background-color: rgb(242, 244, 246);"
|
||||
>
|
||||
<div
|
||||
style="font-size: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Helvetica Neue', Helvetica, sans-serif; position: relative; color: rgb(250, 250, 250); margin-top: auto; margin-bottom: auto; line-height: 0; opacity: 0; width: 26px; height: 20px; left: 4px;"
|
||||
/>
|
||||
<div
|
||||
style="font-size: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Helvetica Neue', Helvetica, sans-serif; position: relative; color: rgba(255, 255, 255, 0.6); bottom: 0px; margin-top: auto; margin-bottom: auto; padding-right: 5px; line-height: 0; width: 26px; height: 20px; opacity: 1;"
|
||||
/>
|
||||
</div>
|
||||
<div
|
||||
style="position: absolute; height: 100%; top: 0px; left: 0px; display: flex; flex: 1; align-self: stretch; align-items: center; justify-content: flex-start;"
|
||||
>
|
||||
<div
|
||||
style="width: 18px; height: 18px; display: flex; align-self: center; box-shadow: none; border-radius: 50%; box-sizing: border-box; position: relative; background-color: rgb(106, 115, 125); left: 3px;"
|
||||
/>
|
||||
</div>
|
||||
<input
|
||||
style="border: 0px; height: 1px; margin: -1px; overflow: hidden; padding: 0px; position: absolute; width: 1px;"
|
||||
type="checkbox"
|
||||
value="false"
|
||||
/>
|
||||
</div>
|
||||
<div
|
||||
class="toggle-button__status"
|
||||
>
|
||||
<span
|
||||
class="toggle-button__label-off"
|
||||
>
|
||||
OFF (Recommended)
|
||||
</span>
|
||||
<span
|
||||
class="toggle-button__label-on"
|
||||
>
|
||||
ON (Not recommended)
|
||||
</span>
|
||||
</div>
|
||||
</label>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
`;
|
@ -1,11 +1,18 @@
|
||||
import React, { PureComponent } from 'react';
|
||||
import PropTypes from 'prop-types';
|
||||
import { Box, BannerAlert } from '../../../components/component-library';
|
||||
import ToggleButton from '../../../components/ui/toggle-button';
|
||||
import TextField from '../../../components/ui/text-field';
|
||||
import Button from '../../../components/ui/button';
|
||||
import Dropdown from '../../../components/ui/dropdown';
|
||||
import Dialog from '../../../components/ui/dialog';
|
||||
|
||||
import {
|
||||
Display,
|
||||
FlexDirection,
|
||||
JustifyContent,
|
||||
SEVERITIES,
|
||||
TextVariant,
|
||||
} from '../../../helpers/constants/design-system';
|
||||
import { getPlatform } from '../../../../app/scripts/lib/util';
|
||||
|
||||
import { PLATFORM_FIREFOX } from '../../../../shared/constants/app';
|
||||
@ -29,11 +36,6 @@ import {
|
||||
} from '../../../helpers/utils/export-utils';
|
||||
import ActionableMessage from '../../../components/ui/actionable-message';
|
||||
import ZENDESK_URLS from '../../../helpers/constants/zendesk-url';
|
||||
import { BannerAlert } from '../../../components/component-library';
|
||||
import {
|
||||
SEVERITIES,
|
||||
TextVariant,
|
||||
} from '../../../helpers/constants/design-system';
|
||||
|
||||
const CORRUPT_JSON_FILE = 'CORRUPT_JSON_FILE';
|
||||
|
||||
@ -167,9 +169,11 @@ export default class AdvancedTab extends PureComponent {
|
||||
const { displayWarning } = this.props;
|
||||
|
||||
return (
|
||||
<div
|
||||
ref={this.settingsRefs[0]}
|
||||
<Box
|
||||
className="settings-page__content-row"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Column}
|
||||
ref={this.settingsRefs[0]}
|
||||
data-testid="advanced-setting-state-logs"
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
@ -201,7 +205,7 @@ export default class AdvancedTab extends PureComponent {
|
||||
</Button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
@ -210,9 +214,11 @@ export default class AdvancedTab extends PureComponent {
|
||||
const { showResetAccountConfirmationModal } = this.props;
|
||||
|
||||
return (
|
||||
<div
|
||||
<Box
|
||||
ref={this.settingsRefs[1]}
|
||||
className="settings-page__content-row"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Column}
|
||||
data-testid="advanced-setting-reset-account"
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
@ -241,7 +247,7 @@ export default class AdvancedTab extends PureComponent {
|
||||
</Button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
@ -250,9 +256,12 @@ export default class AdvancedTab extends PureComponent {
|
||||
const { sendHexData, setHexDataFeatureFlag } = this.props;
|
||||
|
||||
return (
|
||||
<div
|
||||
<Box
|
||||
ref={this.settingsRefs[2]}
|
||||
className="settings-page__content-row"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Row}
|
||||
justifyContent={JustifyContent.spaceBetween}
|
||||
data-testid="advanced-setting-hex-data"
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
@ -261,7 +270,6 @@ export default class AdvancedTab extends PureComponent {
|
||||
{t('showHexDataDescription')}
|
||||
</div>
|
||||
</div>
|
||||
<div className="settings-page__content-item">
|
||||
<div className="settings-page__content-item-col">
|
||||
<ToggleButton
|
||||
value={sendHexData}
|
||||
@ -270,8 +278,7 @@ export default class AdvancedTab extends PureComponent {
|
||||
onLabel={t('on')}
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
@ -281,9 +288,12 @@ export default class AdvancedTab extends PureComponent {
|
||||
this.props;
|
||||
|
||||
return (
|
||||
<div
|
||||
<Box
|
||||
ref={this.settingsRefs[3]}
|
||||
className="settings-page__content-row"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Row}
|
||||
justifyContent={JustifyContent.spaceBetween}
|
||||
data-testid="advanced-setting-show-testnet-conversion"
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
@ -292,7 +302,7 @@ export default class AdvancedTab extends PureComponent {
|
||||
{t('showFiatConversionInTestnetsDescription')}
|
||||
</div>
|
||||
</div>
|
||||
<div className="settings-page__content-item">
|
||||
|
||||
<div className="settings-page__content-item-col">
|
||||
<ToggleButton
|
||||
value={showFiatInTestnets}
|
||||
@ -303,8 +313,7 @@ export default class AdvancedTab extends PureComponent {
|
||||
onLabel={t('on')}
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
@ -313,10 +322,13 @@ export default class AdvancedTab extends PureComponent {
|
||||
const { showTestNetworks, setShowTestNetworks } = this.props;
|
||||
|
||||
return (
|
||||
<div
|
||||
<Box
|
||||
ref={this.settingsRefs[4]}
|
||||
className="settings-page__content-row"
|
||||
data-testid="advanced-setting-show-testnet-conversion"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Row}
|
||||
justifyContent={JustifyContent.spaceBetween}
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
<span>{t('showTestnetNetworks')}</span>
|
||||
@ -324,7 +336,7 @@ export default class AdvancedTab extends PureComponent {
|
||||
{t('showTestnetNetworksDescription')}
|
||||
</div>
|
||||
</div>
|
||||
<div className="settings-page__content-item">
|
||||
|
||||
<div className="settings-page__content-item-col">
|
||||
<ToggleButton
|
||||
value={showTestNetworks}
|
||||
@ -333,8 +345,7 @@ export default class AdvancedTab extends PureComponent {
|
||||
onLabel={t('on')}
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
@ -343,10 +354,13 @@ export default class AdvancedTab extends PureComponent {
|
||||
const { useNonceField, setUseNonceField } = this.props;
|
||||
|
||||
return (
|
||||
<div
|
||||
<Box
|
||||
ref={this.settingsRefs[5]}
|
||||
className="settings-page__content-row"
|
||||
data-testid="advanced-setting-custom-nonce"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Row}
|
||||
justifyContent={JustifyContent.spaceBetween}
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
<span>{t('nonceField')}</span>
|
||||
@ -354,7 +368,7 @@ export default class AdvancedTab extends PureComponent {
|
||||
{t('nonceFieldDescription')}
|
||||
</div>
|
||||
</div>
|
||||
<div className="settings-page__content-item">
|
||||
|
||||
<div className="settings-page__content-item-col">
|
||||
<ToggleButton
|
||||
value={useNonceField}
|
||||
@ -363,8 +377,7 @@ export default class AdvancedTab extends PureComponent {
|
||||
onLabel={t('on')}
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
@ -374,10 +387,12 @@ export default class AdvancedTab extends PureComponent {
|
||||
const { setAutoLockTimeLimit } = this.props;
|
||||
|
||||
return (
|
||||
<div
|
||||
<Box
|
||||
ref={this.settingsRefs[6]}
|
||||
className="settings-page__content-row"
|
||||
data-testid="advanced-setting-auto-lock"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Column}
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
<span>{t('autoLockTimeLimit')}</span>
|
||||
@ -411,7 +426,7 @@ export default class AdvancedTab extends PureComponent {
|
||||
</Button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
@ -461,10 +476,12 @@ export default class AdvancedTab extends PureComponent {
|
||||
: LEDGER_TRANSPORT_NAMES.U2F;
|
||||
|
||||
return (
|
||||
<div
|
||||
<Box
|
||||
ref={this.settingsRefs[7]}
|
||||
className="settings-page__content-row"
|
||||
data-testId="ledger-live-control"
|
||||
data-testid="ledger-live-control"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Column}
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
<span>{t('preferredLedgerConnectionType')}</span>
|
||||
@ -517,7 +534,7 @@ export default class AdvancedTab extends PureComponent {
|
||||
) : null}
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
@ -527,10 +544,13 @@ export default class AdvancedTab extends PureComponent {
|
||||
this.props;
|
||||
|
||||
return (
|
||||
<div
|
||||
<Box
|
||||
ref={this.settingsRefs[8]}
|
||||
className="settings-page__content-row"
|
||||
data-testid="advanced-setting-dismiss-reminder"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Row}
|
||||
justifyContent={JustifyContent.spaceBetween}
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
<span>{t('dismissReminderField')}</span>
|
||||
@ -538,7 +558,7 @@ export default class AdvancedTab extends PureComponent {
|
||||
{t('dismissReminderDescriptionField')}
|
||||
</div>
|
||||
</div>
|
||||
<div className="settings-page__content-item">
|
||||
|
||||
<div className="settings-page__content-item-col">
|
||||
<ToggleButton
|
||||
value={dismissSeedBackUpReminder}
|
||||
@ -547,8 +567,7 @@ export default class AdvancedTab extends PureComponent {
|
||||
onLabel={t('on')}
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
@ -571,10 +590,13 @@ export default class AdvancedTab extends PureComponent {
|
||||
});
|
||||
};
|
||||
return (
|
||||
<div
|
||||
<Box
|
||||
ref={this.settingsRefs[9]}
|
||||
className="settings-page__content-row"
|
||||
data-testid="advanced-setting-toggle-ethsign"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Row}
|
||||
justifyContent={JustifyContent.spaceBetween}
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
<span>{t('toggleEthSignField')}</span>
|
||||
@ -583,7 +605,7 @@ export default class AdvancedTab extends PureComponent {
|
||||
</div>
|
||||
</div>
|
||||
|
||||
{disabledRpcMethodPreferences?.eth_sign === true ? (
|
||||
{disabledRpcMethodPreferences?.eth_sign ? (
|
||||
<BannerAlert
|
||||
severity={SEVERITIES.DANGER}
|
||||
marginBottom={5}
|
||||
@ -592,7 +614,7 @@ export default class AdvancedTab extends PureComponent {
|
||||
{t('toggleEthSignBannerDescription')}
|
||||
</BannerAlert>
|
||||
) : null}
|
||||
<div className="settings-page__content-item">
|
||||
|
||||
<div className="settings-page__content-item-col">
|
||||
<ToggleButton
|
||||
className="eth-sign-toggle"
|
||||
@ -604,8 +626,7 @@ export default class AdvancedTab extends PureComponent {
|
||||
onLabel={t('toggleEthSignOn')}
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
@ -650,10 +671,12 @@ export default class AdvancedTab extends PureComponent {
|
||||
renderUserDataBackup() {
|
||||
const { t } = this.context;
|
||||
return (
|
||||
<div
|
||||
<Box
|
||||
ref={this.settingsRefs[10]}
|
||||
className="settings-page__content-row"
|
||||
data-testid="advanced-setting-data-backup"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Column}
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
<span>{t('backupUserData')}</span>
|
||||
@ -673,7 +696,7 @@ export default class AdvancedTab extends PureComponent {
|
||||
</Button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
@ -690,10 +713,12 @@ export default class AdvancedTab extends PureComponent {
|
||||
: defaultRestoreMessage;
|
||||
|
||||
return (
|
||||
<div
|
||||
<Box
|
||||
ref={this.settingsRefs[11]}
|
||||
className="settings-page__content-row"
|
||||
data-testid="advanced-setting-data-restore"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Column}
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
<span>{t('restoreUserData')}</span>
|
||||
@ -735,7 +760,7 @@ export default class AdvancedTab extends PureComponent {
|
||||
/>
|
||||
)}
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
|
@ -19,6 +19,12 @@ jest.mock('../../../store/actions.ts', () => {
|
||||
describe('AdvancedTab Component', () => {
|
||||
const mockStore = configureMockStore([thunk])(mockState);
|
||||
|
||||
it('should match snapshot', () => {
|
||||
const { container } = renderWithProvider(<AdvancedTab />, mockStore);
|
||||
|
||||
expect(container).toMatchSnapshot();
|
||||
});
|
||||
|
||||
it('should render backup button', () => {
|
||||
const { queryByTestId } = renderWithProvider(<AdvancedTab />, mockStore);
|
||||
const backupButton = queryByTestId('backup-button');
|
||||
|
@ -31,5 +31,6 @@
|
||||
padding: 16px 32px;
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
align-items: center;
|
||||
}
|
||||
}
|
||||
|
@ -101,7 +101,7 @@ exports[`ExperimentalTab with desktop enabled renders ExperimentalTab component
|
||||
Privacy
|
||||
</h4>
|
||||
<div
|
||||
class="settings-page__content-row settings-page__content-row-experimental"
|
||||
class="mm-box settings-page__content-row settings-page__content-row-experimental mm-box--margin-bottom-3"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
@ -112,24 +112,24 @@ exports[`ExperimentalTab with desktop enabled renders ExperimentalTab component
|
||||
<div
|
||||
class="settings-page__content-description"
|
||||
>
|
||||
<p
|
||||
<h6
|
||||
class="mm-box mm-text mm-text--body-sm mm-box--color-text-alternative"
|
||||
>
|
||||
We use third-party APIs to detect and display risks involved in unsigned transaction and signature requests before you sign them. These services will have access to your unsigned transaction and signature requests, your account address, and your preferred language.
|
||||
</p>
|
||||
<p
|
||||
</h6>
|
||||
<h6
|
||||
class="mm-box mm-text mm-text--body-sm mm-box--margin-top-3 mm-box--margin-bottom-1 mm-box--color-text-alternative"
|
||||
>
|
||||
Select providers:
|
||||
</p>
|
||||
</h6>
|
||||
<div
|
||||
class="settings-page__content-item-col settings-page__content-item-col-open-sea"
|
||||
>
|
||||
<p
|
||||
<h5
|
||||
class="mm-box mm-text mm-text--body-md mm-text--font-weight-medium mm-box--margin-bottom-0 mm-box--color-text-default"
|
||||
>
|
||||
OpenSea + Blockaid (Beta)
|
||||
</p>
|
||||
</h5>
|
||||
<label
|
||||
class="toggle-button toggle-button--off"
|
||||
tabindex="0"
|
||||
@ -172,7 +172,7 @@ exports[`ExperimentalTab with desktop enabled renders ExperimentalTab component
|
||||
</div>
|
||||
</label>
|
||||
</div>
|
||||
<p
|
||||
<h6
|
||||
class="mm-box mm-text mm-text--body-sm mm-box--margin-top-0 mm-box--color-text-alternative"
|
||||
>
|
||||
<span>
|
||||
@ -188,17 +188,17 @@ exports[`ExperimentalTab with desktop enabled renders ExperimentalTab component
|
||||
.
|
||||
|
||||
</span>
|
||||
</p>
|
||||
<p
|
||||
</h6>
|
||||
<h5
|
||||
class="mm-box mm-text mm-text--body-md mm-text--font-weight-medium mm-box--margin-top-2 mm-box--color-text-muted"
|
||||
>
|
||||
More providers coming soon
|
||||
</p>
|
||||
</h5>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-row"
|
||||
class="mm-box settings-page__content-row mm-box--display-flex mm-box--flex-direction-row mm-box--justify-content-space-between"
|
||||
data-testid="advanced-setting-desktop-pairing"
|
||||
>
|
||||
<div
|
||||
@ -208,9 +208,6 @@ exports[`ExperimentalTab with desktop enabled renders ExperimentalTab component
|
||||
Click to run all background processes in the desktop app.
|
||||
</span>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item-col"
|
||||
>
|
||||
@ -225,5 +222,4 @@ exports[`ExperimentalTab with desktop enabled renders ExperimentalTab component
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
`;
|
||||
|
@ -6,11 +6,17 @@ import {
|
||||
handleSettingsRefs,
|
||||
} from '../../../helpers/utils/settings-search';
|
||||
import { MetaMetricsEventCategory } from '../../../../shared/constants/metametrics';
|
||||
import { Text } from '../../../components/component-library';
|
||||
|
||||
import { Text, Box } from '../../../components/component-library';
|
||||
import {
|
||||
FontWeight,
|
||||
TextColor,
|
||||
TextVariant,
|
||||
FontWeight,
|
||||
///: BEGIN:ONLY_INCLUDE_IN(desktop)
|
||||
Display,
|
||||
FlexDirection,
|
||||
JustifyContent,
|
||||
///: END:ONLY_INCLUDE_IN
|
||||
} from '../../../helpers/constants/design-system';
|
||||
///: BEGIN:ONLY_INCLUDE_IN(desktop)
|
||||
import DesktopEnableButton from '../../../components/app/desktop-enable-button';
|
||||
@ -57,6 +63,7 @@ export default class ExperimentalTab extends PureComponent {
|
||||
const { t } = this.context;
|
||||
|
||||
const { securityAlertsEnabled, setSecurityAlertsEnabled } = this.props;
|
||||
|
||||
return (
|
||||
<>
|
||||
<Text
|
||||
@ -144,21 +151,24 @@ export default class ExperimentalTab extends PureComponent {
|
||||
<>
|
||||
<Text
|
||||
variant={TextVariant.headingSm}
|
||||
as="h4"
|
||||
color={TextColor.textAlternative}
|
||||
marginBottom={2}
|
||||
fontWeight={FontWeight.Bold}
|
||||
>
|
||||
{t('privacy')}
|
||||
</Text>
|
||||
<div
|
||||
<Box
|
||||
ref={this.settingsRefs[1]}
|
||||
className="settings-page__content-row settings-page__content-row-experimental"
|
||||
marginBottom={3}
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
<span>{t('transactionSecurityCheck')}</span>
|
||||
<div className="settings-page__content-description">
|
||||
<Text
|
||||
variant={TextVariant.bodySm}
|
||||
as="h6"
|
||||
color={TextColor.textAlternative}
|
||||
>
|
||||
{t('transactionSecurityCheckDescription')}
|
||||
@ -167,6 +177,7 @@ export default class ExperimentalTab extends PureComponent {
|
||||
marginTop={3}
|
||||
marginBottom={1}
|
||||
variant={TextVariant.bodySm}
|
||||
as="h6"
|
||||
color={TextColor.textAlternative}
|
||||
>
|
||||
{t('selectProvider')}
|
||||
@ -174,6 +185,7 @@ export default class ExperimentalTab extends PureComponent {
|
||||
<div className="settings-page__content-item-col settings-page__content-item-col-open-sea">
|
||||
<Text
|
||||
variant={TextVariant.bodyMd}
|
||||
as="h5"
|
||||
color={TextColor.textDefault}
|
||||
fontWeight={FontWeight.Medium}
|
||||
marginBottom={0}
|
||||
@ -197,6 +209,7 @@ export default class ExperimentalTab extends PureComponent {
|
||||
</div>
|
||||
<Text
|
||||
variant={TextVariant.bodySm}
|
||||
as="h6"
|
||||
color={TextColor.textAlternative}
|
||||
marginTop={0}
|
||||
>
|
||||
@ -213,15 +226,16 @@ export default class ExperimentalTab extends PureComponent {
|
||||
</Text>
|
||||
<Text
|
||||
variant={TextVariant.bodyMd}
|
||||
color={TextColor.textMuted}
|
||||
as="h5"
|
||||
fontWeight={FontWeight.Medium}
|
||||
color={TextColor.textMuted}
|
||||
marginTop={2}
|
||||
>
|
||||
{t('moreComingSoon')}
|
||||
</Text>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
</>
|
||||
);
|
||||
}
|
||||
@ -231,20 +245,22 @@ export default class ExperimentalTab extends PureComponent {
|
||||
const { t } = this.context;
|
||||
|
||||
return (
|
||||
<div
|
||||
<Box
|
||||
ref={this.settingsRefs[6]}
|
||||
className="settings-page__content-row"
|
||||
data-testid="advanced-setting-desktop-pairing"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Row}
|
||||
justifyContent={JustifyContent.spaceBetween}
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
<span>{t('desktopEnableButtonDescription')}</span>
|
||||
</div>
|
||||
<div className="settings-page__content-item">
|
||||
|
||||
<div className="settings-page__content-item-col">
|
||||
<DesktopEnableButton />
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
///: END:ONLY_INCLUDE_IN
|
||||
|
@ -258,7 +258,7 @@
|
||||
}
|
||||
|
||||
&__body {
|
||||
padding: 12px 24px;
|
||||
padding: 24px;
|
||||
|
||||
@include screen-sm-min {
|
||||
padding: 12px;
|
||||
@ -266,23 +266,18 @@
|
||||
}
|
||||
|
||||
&__content-row {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
padding: 10px 0 20px;
|
||||
}
|
||||
|
||||
&__content-item {
|
||||
flex: 1;
|
||||
min-width: 0;
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
margin-bottom: 20px;
|
||||
font-size: 16px;
|
||||
font-weight: 500;
|
||||
|
||||
@include screen-sm-max {
|
||||
height: initial;
|
||||
padding: 5px 0;
|
||||
}
|
||||
|
||||
&--without-height {
|
||||
@ -364,10 +359,10 @@
|
||||
max-width: 300px;
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
margin-top: 8px;
|
||||
|
||||
@include screen-sm-max {
|
||||
max-width: 100%;
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
.eth-sign-toggle .toggle-button__status {
|
||||
|
@ -47,7 +47,7 @@ exports[`Security Tab should match snapshot 1`] = `
|
||||
class="settings-page__content-padded"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-row"
|
||||
class="mm-box settings-page__content-row mm-box--display-flex mm-box--flex-direction-row mm-box--justify-content-space-between"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
@ -61,9 +61,6 @@ exports[`Security Tab should match snapshot 1`] = `
|
||||
Display a warning for phishing domains targeting Ethereum users
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item-col"
|
||||
data-testid="usePhishingDetection"
|
||||
@ -116,7 +113,6 @@ exports[`Security Tab should match snapshot 1`] = `
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<span
|
||||
class="settings-page__security-tab-sub-header"
|
||||
>
|
||||
@ -126,7 +122,7 @@ exports[`Security Tab should match snapshot 1`] = `
|
||||
class="settings-page__content-padded"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-row"
|
||||
class="mm-box settings-page__content-row mm-box--display-flex mm-box--flex-direction-row mm-box--justify-content-space-between"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
@ -168,9 +164,6 @@ exports[`Security Tab should match snapshot 1`] = `
|
||||
</span>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item-col"
|
||||
data-testid="currencyRateCheckToggle"
|
||||
@ -222,9 +215,8 @@ exports[`Security Tab should match snapshot 1`] = `
|
||||
</label>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-row"
|
||||
class="mm-box settings-page__content-row mm-box--display-flex mm-box--flex-direction-row mm-box--justify-content-space-between"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
@ -258,9 +250,6 @@ exports[`Security Tab should match snapshot 1`] = `
|
||||
</span>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item-col"
|
||||
data-testid="showIncomingTransactions"
|
||||
@ -313,7 +302,6 @@ exports[`Security Tab should match snapshot 1`] = `
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<span
|
||||
class="settings-page__security-tab-sub-header"
|
||||
>
|
||||
@ -323,7 +311,7 @@ exports[`Security Tab should match snapshot 1`] = `
|
||||
class="settings-page__content-padded"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-row"
|
||||
class="mm-box settings-page__content-row mm-box--display-flex mm-box--flex-direction-column"
|
||||
data-testid="advanced-setting-choose-your-network"
|
||||
>
|
||||
<div
|
||||
@ -350,9 +338,6 @@ exports[`Security Tab should match snapshot 1`] = `
|
||||
</span>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item-col"
|
||||
>
|
||||
@ -364,9 +349,8 @@ exports[`Security Tab should match snapshot 1`] = `
|
||||
</button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-row"
|
||||
class="mm-box settings-page__content-row mm-box--display-flex mm-box--flex-direction-column"
|
||||
data-testid="setting-ipfs-gateway"
|
||||
>
|
||||
<div
|
||||
@ -382,7 +366,7 @@ exports[`Security Tab should match snapshot 1`] = `
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
class="settings-page__content-item-col"
|
||||
>
|
||||
<label
|
||||
class="toggle-button toggle-button--on"
|
||||
@ -458,9 +442,10 @@ exports[`Security Tab should match snapshot 1`] = `
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
class="mm-box settings-page__content-row mm-box--margin-top-3 mm-box--display-flex mm-box--flex-direction-row mm-box--justify-content-space-between"
|
||||
id="ens-domains"
|
||||
>
|
||||
<div>
|
||||
Show ENS domains in address bar
|
||||
<div
|
||||
class="settings-page__content-description"
|
||||
@ -497,9 +482,6 @@ exports[`Security Tab should match snapshot 1`] = `
|
||||
</span>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item-col"
|
||||
data-testid="ipfs-gateway-resolution-container"
|
||||
@ -562,7 +544,7 @@ exports[`Security Tab should match snapshot 1`] = `
|
||||
class="settings-page__content-padded"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-row"
|
||||
class="mm-box settings-page__content-row mm-box--display-flex mm-box--flex-direction-row mm-box--justify-content-space-between"
|
||||
data-testid="advanced-setting-gas-fee-estimation"
|
||||
>
|
||||
<div
|
||||
@ -589,9 +571,6 @@ exports[`Security Tab should match snapshot 1`] = `
|
||||
</span>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item-col"
|
||||
data-testid="autoDetectTokens"
|
||||
@ -643,9 +622,8 @@ exports[`Security Tab should match snapshot 1`] = `
|
||||
</label>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-row"
|
||||
class="mm-box settings-page__content-row mm-box--display-flex mm-box--flex-direction-row mm-box--justify-content-space-between"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
@ -659,9 +637,6 @@ exports[`Security Tab should match snapshot 1`] = `
|
||||
Get faster balance updates by batching account balance requests. This lets us fetch your account balances together, so you get quicker updates for an improved experience. When this feature is off, third parties may be less likely to associate your accounts with each other.
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item-col"
|
||||
data-testid="useMultiAccountBalanceChecker"
|
||||
@ -713,9 +688,8 @@ exports[`Security Tab should match snapshot 1`] = `
|
||||
</label>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-row"
|
||||
class="mm-box settings-page__content-row mm-box--display-flex mm-box--flex-direction-row mm-box--justify-content-space-between"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
@ -729,9 +703,6 @@ exports[`Security Tab should match snapshot 1`] = `
|
||||
Displaying NFT media and data exposes your IP address to OpenSea or other third parties. This can allow attackers to associate your IP address with your Ethereum address. NFT autodetection relies on this setting, and won't be available when this is turned off.
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item-col"
|
||||
data-testid="displayNftMedia"
|
||||
@ -783,9 +754,8 @@ exports[`Security Tab should match snapshot 1`] = `
|
||||
</label>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-row"
|
||||
class="mm-box settings-page__content-row mm-box--display-flex mm-box--flex-direction-row mm-box--justify-content-space-between"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
@ -821,9 +791,6 @@ exports[`Security Tab should match snapshot 1`] = `
|
||||
</p>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item-col"
|
||||
data-testid="useNftDetection"
|
||||
@ -876,7 +843,6 @@ exports[`Security Tab should match snapshot 1`] = `
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<span
|
||||
class="settings-page__security-tab-sub-header"
|
||||
>
|
||||
@ -886,7 +852,7 @@ exports[`Security Tab should match snapshot 1`] = `
|
||||
class="settings-page__content-padded"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-row"
|
||||
class="mm-box settings-page__content-row mm-box--display-flex mm-box--flex-direction-row mm-box--justify-content-space-between"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
@ -902,9 +868,6 @@ exports[`Security Tab should match snapshot 1`] = `
|
||||
</span>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
class="settings-page__content-item"
|
||||
>
|
||||
<div
|
||||
class="settings-page__content-item-col"
|
||||
data-testid="participateInMetaMetrics"
|
||||
@ -959,5 +922,4 @@ exports[`Security Tab should match snapshot 1`] = `
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
`;
|
||||
|
@ -24,19 +24,23 @@ import SRPQuiz from '../../../components/app/srp-quiz-modal/SRPQuiz';
|
||||
import {
|
||||
BUTTON_SIZES,
|
||||
Button,
|
||||
} from '../../../components/component-library/button';
|
||||
Box,
|
||||
Text,
|
||||
} from '../../../components/component-library';
|
||||
import TextField from '../../../components/ui/text-field';
|
||||
import ToggleButton from '../../../components/ui/toggle-button';
|
||||
import {
|
||||
Display,
|
||||
FlexDirection,
|
||||
JustifyContent,
|
||||
TextColor,
|
||||
TextVariant,
|
||||
} from '../../../helpers/constants/design-system';
|
||||
import { ADD_POPULAR_CUSTOM_NETWORK } from '../../../helpers/constants/routes';
|
||||
import {
|
||||
getNumberOfSettingsInSection,
|
||||
handleSettingsRefs,
|
||||
} from '../../../helpers/utils/settings-search';
|
||||
import { Box, Text } from '../../../components/component-library';
|
||||
import {
|
||||
TextColor,
|
||||
TextVariant,
|
||||
} from '../../../helpers/constants/design-system';
|
||||
|
||||
export default class SecurityTab extends PureComponent {
|
||||
static contextTypes = {
|
||||
@ -169,7 +173,13 @@ export default class SecurityTab extends PureComponent {
|
||||
this.props;
|
||||
|
||||
return (
|
||||
<div ref={this.settingsRefs[1]} className="settings-page__content-row">
|
||||
<Box
|
||||
ref={this.settingsRefs[1]}
|
||||
className="settings-page__content-row"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Row}
|
||||
justifyContent={JustifyContent.spaceBetween}
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
<span>{t('showIncomingTransactions')}</span>
|
||||
<div className="settings-page__content-description">
|
||||
@ -195,22 +205,18 @@ export default class SecurityTab extends PureComponent {
|
||||
])}
|
||||
</div>
|
||||
</div>
|
||||
<div className="settings-page__content-item">
|
||||
<div
|
||||
className="settings-page__content-item-col"
|
||||
data-testid="showIncomingTransactions"
|
||||
>
|
||||
<ToggleButton
|
||||
value={showIncomingTransactions}
|
||||
onToggle={(value) =>
|
||||
setShowIncomingTransactionsFeatureFlag(!value)
|
||||
}
|
||||
onToggle={(value) => setShowIncomingTransactionsFeatureFlag(!value)}
|
||||
offLabel={t('off')}
|
||||
onLabel={t('on')}
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
@ -219,14 +225,20 @@ export default class SecurityTab extends PureComponent {
|
||||
const { usePhishDetect, setUsePhishDetect } = this.props;
|
||||
|
||||
return (
|
||||
<div ref={this.settingsRefs[2]} className="settings-page__content-row">
|
||||
<Box
|
||||
ref={this.settingsRefs[2]}
|
||||
className="settings-page__content-row"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Row}
|
||||
justifyContent={JustifyContent.spaceBetween}
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
<span>{t('usePhishingDetection')}</span>
|
||||
<div className="settings-page__content-description">
|
||||
{t('usePhishingDetectionDescription')}
|
||||
</div>
|
||||
</div>
|
||||
<div className="settings-page__content-item">
|
||||
|
||||
<div
|
||||
className="settings-page__content-item-col"
|
||||
data-testid="usePhishingDetection"
|
||||
@ -238,8 +250,7 @@ export default class SecurityTab extends PureComponent {
|
||||
onLabel={t('on')}
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
@ -249,14 +260,20 @@ export default class SecurityTab extends PureComponent {
|
||||
this.props;
|
||||
|
||||
return (
|
||||
<div ref={this.settingsRefs[3]} className="settings-page__content-row">
|
||||
<Box
|
||||
ref={this.settingsRefs[3]}
|
||||
className="settings-page__content-row"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Row}
|
||||
justifyContent={JustifyContent.spaceBetween}
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
<span>{t('participateInMetaMetrics')}</span>
|
||||
<div className="settings-page__content-description">
|
||||
<span>{t('participateInMetaMetricsDescription')}</span>
|
||||
</div>
|
||||
</div>
|
||||
<div className="settings-page__content-item">
|
||||
|
||||
<div
|
||||
className="settings-page__content-item-col"
|
||||
data-testid="participateInMetaMetrics"
|
||||
@ -268,8 +285,7 @@ export default class SecurityTab extends PureComponent {
|
||||
onLabel={t('on')}
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
@ -277,10 +293,12 @@ export default class SecurityTab extends PureComponent {
|
||||
const { t } = this.context;
|
||||
|
||||
return (
|
||||
<div
|
||||
<Box
|
||||
ref={this.settingsRefs[4]}
|
||||
className="settings-page__content-row"
|
||||
data-testid="advanced-setting-choose-your-network"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Column}
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
<span>{t('chooseYourNetwork')}</span>
|
||||
@ -298,7 +316,6 @@ export default class SecurityTab extends PureComponent {
|
||||
])}
|
||||
</div>
|
||||
</div>
|
||||
<div className="settings-page__content-item">
|
||||
<div className="settings-page__content-item-col">
|
||||
<Button
|
||||
type="secondary"
|
||||
@ -314,8 +331,7 @@ export default class SecurityTab extends PureComponent {
|
||||
{t('addCustomNetwork')}
|
||||
</Button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
@ -367,10 +383,12 @@ export default class SecurityTab extends PureComponent {
|
||||
: handleIpfsGatewayChange('');
|
||||
};
|
||||
return (
|
||||
<div
|
||||
<Box
|
||||
ref={this.settingsRefs[5]}
|
||||
className="settings-page__content-row"
|
||||
data-testid="setting-ipfs-gateway"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Column}
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
<span>{t('ipfsGateway')}</span>
|
||||
@ -378,7 +396,7 @@ export default class SecurityTab extends PureComponent {
|
||||
{t('ipfsGatewayDescription')}
|
||||
</div>
|
||||
</div>
|
||||
<div className="settings-page__content-item">
|
||||
<div className="settings-page__content-item-col">
|
||||
<ToggleButton
|
||||
value={this.state.ipfsGateway}
|
||||
onToggle={(value) => {
|
||||
@ -405,11 +423,16 @@ export default class SecurityTab extends PureComponent {
|
||||
</div>
|
||||
</div>
|
||||
)}
|
||||
<div
|
||||
className="settings-page__content-item"
|
||||
<Box
|
||||
className="settings-page__content-row"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Row}
|
||||
justifyContent={JustifyContent.spaceBetween}
|
||||
ref={this.settingsRefs[9]}
|
||||
marginTop={3}
|
||||
id="ens-domains"
|
||||
>
|
||||
<div>
|
||||
{t('ensDomainsSettingTitle')}
|
||||
<div className="settings-page__content-description">
|
||||
<Text color={TextColor.inherit} variant={TextVariant.inherit}>
|
||||
@ -449,7 +472,7 @@ export default class SecurityTab extends PureComponent {
|
||||
</Text>
|
||||
</div>
|
||||
</div>
|
||||
<div className="settings-page__content-item">
|
||||
|
||||
<div
|
||||
className="settings-page__content-item-col"
|
||||
data-testid="ipfs-gateway-resolution-container"
|
||||
@ -461,8 +484,8 @@ export default class SecurityTab extends PureComponent {
|
||||
onLabel={t('on')}
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
@ -471,10 +494,13 @@ export default class SecurityTab extends PureComponent {
|
||||
const { useTokenDetection, setUseTokenDetection } = this.props;
|
||||
|
||||
return (
|
||||
<div
|
||||
<Box
|
||||
ref={this.settingsRefs[6]}
|
||||
className="settings-page__content-row"
|
||||
data-testid="advanced-setting-gas-fee-estimation"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Row}
|
||||
justifyContent={JustifyContent.spaceBetween}
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
<span>{t('autoDetectTokens')}</span>
|
||||
@ -492,7 +518,7 @@ export default class SecurityTab extends PureComponent {
|
||||
])}
|
||||
</div>
|
||||
</div>
|
||||
<div className="settings-page__content-item">
|
||||
|
||||
<div
|
||||
className="settings-page__content-item-col"
|
||||
data-testid="autoDetectTokens"
|
||||
@ -511,8 +537,7 @@ export default class SecurityTab extends PureComponent {
|
||||
onLabel={t('on')}
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
@ -522,14 +547,20 @@ export default class SecurityTab extends PureComponent {
|
||||
this.props;
|
||||
|
||||
return (
|
||||
<div ref={this.settingsRefs[7]} className="settings-page__content-row">
|
||||
<Box
|
||||
ref={this.settingsRefs[7]}
|
||||
className="settings-page__content-row"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Row}
|
||||
justifyContent={JustifyContent.spaceBetween}
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
<span>{t('useMultiAccountBalanceChecker')}</span>
|
||||
<div className="settings-page__content-description">
|
||||
{t('useMultiAccountBalanceCheckerSettingDescription')}
|
||||
</div>
|
||||
</div>
|
||||
<div className="settings-page__content-item">
|
||||
|
||||
<div
|
||||
className="settings-page__content-item-col"
|
||||
data-testid="useMultiAccountBalanceChecker"
|
||||
@ -548,8 +579,7 @@ export default class SecurityTab extends PureComponent {
|
||||
onLabel={t('on')}
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
@ -558,7 +588,13 @@ export default class SecurityTab extends PureComponent {
|
||||
const { useCurrencyRateCheck, setUseCurrencyRateCheck } = this.props;
|
||||
|
||||
return (
|
||||
<div ref={this.settingsRefs[8]} className="settings-page__content-row">
|
||||
<Box
|
||||
ref={this.settingsRefs[8]}
|
||||
className="settings-page__content-row"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Row}
|
||||
justifyContent={JustifyContent.spaceBetween}
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
<span>{t('currencyRateCheckToggle')}</span>
|
||||
<div className="settings-page__content-description">
|
||||
@ -590,7 +626,7 @@ export default class SecurityTab extends PureComponent {
|
||||
])}
|
||||
</div>
|
||||
</div>
|
||||
<div className="settings-page__content-item">
|
||||
|
||||
<div
|
||||
className="settings-page__content-item-col"
|
||||
data-testid="currencyRateCheckToggle"
|
||||
@ -602,8 +638,7 @@ export default class SecurityTab extends PureComponent {
|
||||
onLabel={t('on')}
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
@ -617,14 +652,20 @@ export default class SecurityTab extends PureComponent {
|
||||
} = this.props;
|
||||
|
||||
return (
|
||||
<div ref={this.settingsRefs[10]} className="settings-page__content-row">
|
||||
<Box
|
||||
ref={this.settingsRefs[10]}
|
||||
className="settings-page__content-row"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Row}
|
||||
justifyContent={JustifyContent.spaceBetween}
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
<span>{t('displayNftMedia')}</span>
|
||||
<div className="settings-page__content-description">
|
||||
{t('displayNftMediaDescription')}
|
||||
</div>
|
||||
</div>
|
||||
<div className="settings-page__content-item">
|
||||
|
||||
<div
|
||||
className="settings-page__content-item-col"
|
||||
data-testid="displayNftMedia"
|
||||
@ -650,8 +691,7 @@ export default class SecurityTab extends PureComponent {
|
||||
onLabel={t('on')}
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
@ -664,7 +704,13 @@ export default class SecurityTab extends PureComponent {
|
||||
setUseNftDetection,
|
||||
} = this.props;
|
||||
return (
|
||||
<div ref={this.settingsRefs[11]} className="settings-page__content-row">
|
||||
<Box
|
||||
ref={this.settingsRefs[11]}
|
||||
className="settings-page__content-row"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Row}
|
||||
justifyContent={JustifyContent.spaceBetween}
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
<span>{t('useNftDetection')}</span>
|
||||
<div className="settings-page__content-description">
|
||||
@ -681,7 +727,7 @@ export default class SecurityTab extends PureComponent {
|
||||
</Text>
|
||||
</div>
|
||||
</div>
|
||||
<div className="settings-page__content-item">
|
||||
|
||||
<div
|
||||
className="settings-page__content-item-col"
|
||||
data-testid="useNftDetection"
|
||||
@ -706,8 +752,7 @@ export default class SecurityTab extends PureComponent {
|
||||
onLabel={t('on')}
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
|
@ -5,6 +5,10 @@ import availableCurrencies from '../../../helpers/constants/available-conversion
|
||||
import {
|
||||
TextVariant,
|
||||
TextColor,
|
||||
Display,
|
||||
FlexDirection,
|
||||
JustifyContent,
|
||||
AlignItems,
|
||||
} from '../../../helpers/constants/design-system';
|
||||
import Dropdown from '../../../components/ui/dropdown';
|
||||
import ToggleButton from '../../../components/ui/toggle-button';
|
||||
@ -18,7 +22,7 @@ import {
|
||||
handleSettingsRefs,
|
||||
} from '../../../helpers/utils/settings-search';
|
||||
import { ThemeType } from '../../../../shared/constants/preferences';
|
||||
import { Text } from '../../../components/component-library';
|
||||
import { Text, Box } from '../../../components/component-library';
|
||||
|
||||
const sortedCurrencies = availableCurrencies.sort((a, b) => {
|
||||
return a.name.toLocaleLowerCase().localeCompare(b.name.toLocaleLowerCase());
|
||||
@ -89,7 +93,12 @@ export default class SettingsTab extends PureComponent {
|
||||
this.props;
|
||||
|
||||
return (
|
||||
<div ref={this.settingsRefs[0]} className="settings-page__content-row">
|
||||
<Box
|
||||
ref={this.settingsRefs[0]}
|
||||
className="settings-page__content-row"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Column}
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
<span>{t('currencyConversion')}</span>
|
||||
<span className="settings-page__content-description">
|
||||
@ -111,7 +120,7 @@ export default class SettingsTab extends PureComponent {
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
@ -124,7 +133,12 @@ export default class SettingsTab extends PureComponent {
|
||||
const currentLocaleName = currentLocaleMeta ? currentLocaleMeta.name : '';
|
||||
|
||||
return (
|
||||
<div ref={this.settingsRefs[2]} className="settings-page__content-row">
|
||||
<Box
|
||||
ref={this.settingsRefs[2]}
|
||||
className="settings-page__content-row"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Column}
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
<span className="settings-page__content-label">
|
||||
{t('currentLanguage')}
|
||||
@ -144,7 +158,7 @@ export default class SettingsTab extends PureComponent {
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
@ -153,16 +167,19 @@ export default class SettingsTab extends PureComponent {
|
||||
const { hideZeroBalanceTokens, setHideZeroBalanceTokens } = this.props;
|
||||
|
||||
return (
|
||||
<div
|
||||
<Box
|
||||
ref={this.settingsRefs[5]}
|
||||
data-testid="hide-zero-balance-tokens"
|
||||
className="settings-page__content-row"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Row}
|
||||
justifyContent={JustifyContent.spaceBetween}
|
||||
alignItems={AlignItems.center}
|
||||
id="toggle-zero-balance"
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
<span>{t('hideZeroBalanceTokens')}</span>
|
||||
</div>
|
||||
<div className="settings-page__content-item">
|
||||
|
||||
<div className="settings-page__content-item-col">
|
||||
<ToggleButton
|
||||
value={hideZeroBalanceTokens}
|
||||
@ -171,8 +188,7 @@ export default class SettingsTab extends PureComponent {
|
||||
onLabel={t('on')}
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
@ -189,9 +205,11 @@ export default class SettingsTab extends PureComponent {
|
||||
});
|
||||
|
||||
return (
|
||||
<div
|
||||
<Box
|
||||
ref={this.settingsRefs[4]}
|
||||
className="settings-page__content-row"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Column}
|
||||
id="blockie-optin"
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
@ -275,7 +293,7 @@ export default class SettingsTab extends PureComponent {
|
||||
</button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
@ -287,7 +305,12 @@ export default class SettingsTab extends PureComponent {
|
||||
useNativeCurrencyAsPrimaryCurrency,
|
||||
} = this.props;
|
||||
return (
|
||||
<div ref={this.settingsRefs[1]} className="settings-page__content-row">
|
||||
<Box
|
||||
ref={this.settingsRefs[1]}
|
||||
className="settings-page__content-row"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Column}
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
<span>{t('primaryCurrencySetting')}</span>
|
||||
<div className="settings-page__content-description">
|
||||
@ -334,7 +357,7 @@ export default class SettingsTab extends PureComponent {
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
@ -369,7 +392,12 @@ export default class SettingsTab extends PureComponent {
|
||||
};
|
||||
|
||||
return (
|
||||
<div ref={this.settingsRefs[3]} className="settings-page__content-row">
|
||||
<Box
|
||||
ref={this.settingsRefs[3]}
|
||||
className="settings-page__content-row"
|
||||
display={Display.Flex}
|
||||
flexDirection={FlexDirection.Column}
|
||||
>
|
||||
<div className="settings-page__content-item">
|
||||
<span>{this.context.t('theme')}</span>
|
||||
<div className="settings-page__content-description">
|
||||
@ -386,7 +414,7 @@ export default class SettingsTab extends PureComponent {
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Box>
|
||||
);
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user