From 2a58de13e9690acdc908975937715c02379e8b7d Mon Sep 17 00:00:00 2001 From: Jin Date: Tue, 28 Apr 2020 11:52:46 -0400 Subject: [PATCH] Use mask for native input on send sheet (#628) --- src/components/fields/UnderlineField.js | 4 +++- src/components/send/SendAssetFormField.js | 3 +++ src/components/send/SendAssetFormToken.js | 25 ++++++++--------------- 3 files changed, 15 insertions(+), 17 deletions(-) diff --git a/src/components/fields/UnderlineField.js b/src/components/fields/UnderlineField.js index e16c82a6b77..f0ac62f6bca 100644 --- a/src/components/fields/UnderlineField.js +++ b/src/components/fields/UnderlineField.js @@ -36,6 +36,7 @@ export default class UnderlineField extends PureComponent { buttonText: PropTypes.string, format: PropTypes.func, keyboardType: Input.propTypes.keyboardType, + mask: PropTypes.string, maxLength: PropTypes.number, onBlur: PropTypes.func, onChange: PropTypes.func, @@ -130,6 +131,7 @@ export default class UnderlineField extends PureComponent { autoFocus, buttonText, keyboardType, + mask, maxLength, placeholder, ...props @@ -147,7 +149,7 @@ export default class UnderlineField extends PureComponent { keyboardAppearance="light" keyboardType={keyboardType} letterSpacing={fonts.letterSpacing.roundedTightest} - mask="[099999999999999999].[999999999999999999]" + mask={mask} maxLength={maxLength} onBlur={this.onBlur} onChange={this.onChange} diff --git a/src/components/send/SendAssetFormField.js b/src/components/send/SendAssetFormField.js index 969225ec5f5..f235b78f9c4 100644 --- a/src/components/send/SendAssetFormField.js +++ b/src/components/send/SendAssetFormField.js @@ -11,6 +11,7 @@ const SendAssetFormField = ({ format, label, labelMaxLength, + mask, onChange, onPressButton, placeholder, @@ -29,6 +30,7 @@ const SendAssetFormField = ({ buttonText="Max" format={format} keyboardType="decimal-pad" + mask={mask} onChange={onChange} onPressButton={onPressButton} placeholder={placeholder} @@ -48,6 +50,7 @@ SendAssetFormField.propTypes = { format: PropTypes.func, label: PropTypes.string, labelMaxLength: PropTypes.number, + mask: PropTypes.string, onChange: PropTypes.func, onPressButton: PropTypes.func, placeholder: PropTypes.string, diff --git a/src/components/send/SendAssetFormToken.js b/src/components/send/SendAssetFormToken.js index b454204e534..ae3c89777d6 100644 --- a/src/components/send/SendAssetFormToken.js +++ b/src/components/send/SendAssetFormToken.js @@ -1,5 +1,7 @@ +import { pick } from 'lodash'; import PropTypes from 'prop-types'; -import React, { Fragment, useCallback } from 'react'; +import React, { Fragment } from 'react'; +import supportedNativeCurrencies from '../../references/native-currencies.json'; import { deviceUtils } from '../../utils'; import { removeLeadingZeros } from '../../utils/formatters'; import { ColumnWithMargins } from '../layout'; @@ -17,19 +19,10 @@ const SendAssetFormToken = ({ txSpeedRenderer, ...props }) => { - const formatNativeInput = useCallback( - (value = '') => { - const nativeCurrencyDecimals = nativeCurrency !== 'ETH' ? 2 : 18; - const formattedValue = removeLeadingZeros(value); - const parts = formattedValue.split('.'); - const decimals = parts[1] || ''; - - return decimals.length > nativeCurrencyDecimals - ? `${parts[0]}.${decimals.substring(0, nativeCurrencyDecimals)}` - : formattedValue; - }, - [nativeCurrency] - ); + const { + mask: nativeMask, + placeholder: nativePlaceholder, + } = pick(supportedNativeCurrencies[nativeCurrency], ['mask', 'placeholder']); return ( @@ -44,11 +37,11 @@ const SendAssetFormToken = ({ />