import React, { PureComponent } from 'react' import PropTypes from 'prop-types' import classnames from 'classnames' import { exportAsFile } from '../../../helpers/utils/util' import ToggleButton from '../../../components/ui/toggle-button' import TextField from '../../../components/ui/text-field' import Button from '../../../components/ui/button' import { MOBILE_SYNC_ROUTE } from '../../../helpers/constants/routes' export default class AdvancedTab extends PureComponent { static contextTypes = { t: PropTypes.func, metricsEvent: PropTypes.func, } static propTypes = { setUseNonceField: PropTypes.func, useNonceField: PropTypes.bool, setHexDataFeatureFlag: PropTypes.func, displayWarning: PropTypes.func, showResetAccountConfirmationModal: PropTypes.func, warning: PropTypes.string, history: PropTypes.object, sendHexData: PropTypes.bool, setAdvancedInlineGasFeatureFlag: PropTypes.func, advancedInlineGas: PropTypes.bool, showFiatInTestnets: PropTypes.bool, autoLogoutTimeLimit: PropTypes.number, setAutoLogoutTimeLimit: PropTypes.func.isRequired, setShowFiatConversionOnTestnetsPreference: PropTypes.func.isRequired, threeBoxSyncingAllowed: PropTypes.bool.isRequired, setThreeBoxSyncingPermission: PropTypes.func.isRequired, threeBoxDisabled: PropTypes.bool.isRequired, } state = { autoLogoutTimeLimit: this.props.autoLogoutTimeLimit, logoutTimeError: '', } renderMobileSync () { const { t } = this.context const { history } = this.props // return (
{ t('syncWithMobile') }
) } renderStateLogs () { const { t } = this.context const { displayWarning } = this.props return (
{ t('stateLogs') } { t('stateLogsDescription') }
) } renderResetAccount () { const { t } = this.context const { showResetAccountConfirmationModal } = this.props return (
{ t('resetAccount') } { t('resetAccountDescription') }
) } renderHexDataOptIn () { const { t } = this.context const { sendHexData, setHexDataFeatureFlag } = this.props return (
{ t('showHexData') }
{ t('showHexDataDescription') }
setHexDataFeatureFlag(!value)} offLabel={t('off')} onLabel={t('on')} />
) } renderAdvancedGasInputInline () { const { t } = this.context const { advancedInlineGas, setAdvancedInlineGasFeatureFlag } = this.props return (
{ t('showAdvancedGasInline') }
{ t('showAdvancedGasInlineDescription') }
setAdvancedInlineGasFeatureFlag(!value)} offLabel={t('off')} onLabel={t('on')} />
) } renderShowConversionInTestnets () { const { t } = this.context const { showFiatInTestnets, setShowFiatConversionOnTestnetsPreference, } = this.props return (
{ t('showFiatConversionInTestnets') }
{ t('showFiatConversionInTestnetsDescription') }
setShowFiatConversionOnTestnetsPreference(!value)} offLabel={t('off')} onLabel={t('on')} />
) } renderUseNonceOptIn () { const { t } = this.context const { useNonceField, setUseNonceField } = this.props return (
{ this.context.t('nonceField') }
{ t('nonceFieldDescription') }
setUseNonceField(!value)} offLabel={t('off')} onLabel={t('on')} />
) } handleLogoutChange (time) { const { t } = this.context const autoLogoutTimeLimit = Math.max(Number(time), 0) this.setState(() => { let logoutTimeError = '' if (autoLogoutTimeLimit > 10080) { logoutTimeError = t('logoutTimeTooGreat') } return { autoLogoutTimeLimit, logoutTimeError, } }) } renderAutoLogoutTimeLimit () { const { t } = this.context const { logoutTimeError } = this.state const { autoLogoutTimeLimit, setAutoLogoutTimeLimit, } = this.props return (
{ t('autoLogoutTimeLimit') }
{ t('autoLogoutTimeLimitDescription') }
this.handleLogoutChange(e.target.value)} error={logoutTimeError} fullWidth margin="dense" min={0} />
) } renderThreeBoxControl () { const { t } = this.context const { threeBoxSyncingAllowed, setThreeBoxSyncingPermission, threeBoxDisabled, } = this.props let allowed = threeBoxSyncingAllowed let description = t('syncWithThreeBoxDescription') if (threeBoxDisabled) { allowed = false description = t('syncWithThreeBoxDisabled') } return (
{ t('syncWithThreeBox') }
{ description }
{ if (!threeBoxDisabled) { setThreeBoxSyncingPermission(!value) } }} offLabel={t('off')} onLabel={t('on')} />
) } renderContent () { const { warning } = this.props return (
{ warning &&
{ warning }
} { this.renderStateLogs() } { this.renderMobileSync() } { this.renderResetAccount() } { this.renderAdvancedGasInputInline() } { this.renderHexDataOptIn() } { this.renderShowConversionInTestnets() } { this.renderUseNonceOptIn() } { this.renderAutoLogoutTimeLimit() } { this.renderThreeBoxControl() }
) } render () { return this.renderContent() } }