import React, { PureComponent } from 'react'; import PropTypes from 'prop-types'; import ToggleButton from '../../../components/ui/toggle-button'; export default class ExperimentalTab extends PureComponent { static contextTypes = { t: PropTypes.func, metricsEvent: PropTypes.func, }; static propTypes = { useTokenDetection: PropTypes.bool, setUseTokenDetection: PropTypes.func, useCollectibleDetection: PropTypes.bool, setUseCollectibleDetection: PropTypes.func, setOpenSeaEnabled: PropTypes.func, openSeaEnabled: PropTypes.bool, eip1559V2Enabled: PropTypes.bool, setEIP1559V2Enabled: PropTypes.func, }; renderTokenDetectionToggle() { const { t } = this.context; const { useTokenDetection, setUseTokenDetection } = this.props; return (
{t('useTokenDetection')}
{t('useTokenDetectionDescription')}
{ this.context.metricsEvent({ eventOpts: { category: 'Settings', action: 'Token Detection', name: 'Token Detection', }, }); setUseTokenDetection(!value); }} offLabel={t('off')} onLabel={t('on')} />
); } renderCollectibleDetectionToggle() { if (!process.env.COLLECTIBLES_V1) { return null; } const { t } = this.context; const { useCollectibleDetection, setUseCollectibleDetection, openSeaEnabled, } = this.props; return (
{t('useCollectibleDetection')}
{t('useCollectibleDetectionDescription')}
{ this.context.metricsEvent({ eventOpts: { category: 'Settings', action: 'Collectible Detection', name: 'Collectible Detection', }, }); setUseCollectibleDetection(!value); }} offLabel={t('off')} onLabel={t('on')} />
); } renderOpenSeaEnabledToggle() { if (!process.env.COLLECTIBLES_V1) { return null; } const { t } = this.context; const { openSeaEnabled, setOpenSeaEnabled } = this.props; return (
{t('enableOpenSeaAPI')}
{t('enableOpenSeaAPIDescription')}
{ this.context.metricsEvent({ eventOpts: { category: 'Settings', action: 'Enabled/Disable OpenSea', name: 'Enabled/Disable OpenSea', }, }); setOpenSeaEnabled(!value); }} offLabel={t('off')} onLabel={t('on')} />
); } renderEIP1559V2EnabledToggle() { const EIP_1559_V2_ENABLED = // This is a string in unit tests but is a boolean in the browser process.env.EIP_1559_V2 === true || process.env.EIP_1559_V2 === 'true'; if (!EIP_1559_V2_ENABLED) { return null; } const { t } = this.context; const { eip1559V2Enabled, setEIP1559V2Enabled } = this.props; return (
{t('enableEIP1559V2')}
{t('enableEIP1559V2Description', [ {t('learnMoreUpperCase')} , ])}
{ this.context.metricsEvent({ eventOpts: { category: 'Settings', action: 'Enabled/Disable OpenSea', name: 'Enabled/Disable OpenSea', }, }); setEIP1559V2Enabled(!value); }} offLabel={t('off')} onLabel={t('on')} />
); } render() { return (
{this.renderTokenDetectionToggle()} {this.renderOpenSeaEnabledToggle()} {this.renderCollectibleDetectionToggle()} {this.renderEIP1559V2EnabledToggle()}
); } }