From 3c38ff3899f5d2c7bc5f8466af0872c6ac12d40e Mon Sep 17 00:00:00 2001 From: Vladimir Saric <92527393+VSaric@users.noreply.github.com> Date: Mon, 16 Jan 2023 18:41:46 +0100 Subject: [PATCH] Validating or restricting the number of digits on token allowance flow (#17234) * Validating or restricting the number of digits after the decimal point that the user can enter and styles for Max button and description with error message * Use better solution for validation the number of digits on token allowance flow --- shared/constants/tokens.js | 1 + .../custom-spending-cap.js | 33 +++++++++++++------ .../app/custom-spending-cap/index.scss | 8 +++++ .../numeric-input/numeric-input.component.js | 3 +- 4 files changed, 33 insertions(+), 12 deletions(-) diff --git a/shared/constants/tokens.js b/shared/constants/tokens.js index 658b19417..03fd7fe52 100644 --- a/shared/constants/tokens.js +++ b/shared/constants/tokens.js @@ -45,3 +45,4 @@ export const MAX_TOKEN_ALLOWANCE_AMOUNT = new BigNumber(2) .minus(1) .toString(10); export const TOKEN_ALLOWANCE_VALUE_REGEX = /^[0-9]{1,}([,.][0-9]{1,})?$/u; +export const DECIMAL_REGEX = /\.(\d*)/u; diff --git a/ui/components/app/custom-spending-cap/custom-spending-cap.js b/ui/components/app/custom-spending-cap/custom-spending-cap.js index 8e976482c..11743c116 100644 --- a/ui/components/app/custom-spending-cap/custom-spending-cap.js +++ b/ui/components/app/custom-spending-cap/custom-spending-cap.js @@ -1,6 +1,7 @@ import React, { useState, useContext, useEffect } from 'react'; import { useDispatch, useSelector } from 'react-redux'; import PropTypes from 'prop-types'; +import classnames from 'classnames'; import BigNumber from 'bignumber.js'; import { I18nContext } from '../../../contexts/i18n'; import Box from '../../ui/box'; @@ -29,6 +30,7 @@ import { import { MAX_TOKEN_ALLOWANCE_AMOUNT, TOKEN_ALLOWANCE_VALUE_REGEX, + DECIMAL_REGEX, } from '../../../../shared/constants/tokens'; import { CustomSpendingCapTooltip } from './custom-spending-cap-tooltip'; @@ -105,6 +107,10 @@ export default function CustomSpendingCap({ let spendingCapError = ''; const inputTextLogic = getInputTextLogic(valueInput); const inputTextLogicDescription = inputTextLogic.description; + const match = DECIMAL_REGEX.exec(replaceCommaToDot(valueInput)); + if (match?.[1]?.length > decimals) { + return; + } if (valueInput && !TOKEN_ALLOWANCE_VALUE_REGEX.test(valueInput)) { spendingCapError = t('spendingCapError'); @@ -230,7 +236,9 @@ export default function CustomSpendingCap({ paddingRight={4} paddingBottom={2} textAlign={TEXT_ALIGN.END} - className="custom-spending-cap__max" + className={classnames('custom-spending-cap__max', { + 'custom-spending-cap__max--with-error-message': error, + })} > - - {replaceCommaToDot(value) - ? customSpendingCapText - : inputLogicEmptyStateText} - + + {replaceCommaToDot(value) + ? customSpendingCapText + : inputLogicEmptyStateText} + + diff --git a/ui/components/app/custom-spending-cap/index.scss b/ui/components/app/custom-spending-cap/index.scss index 2377aec1f..927c281d2 100644 --- a/ui/components/app/custom-spending-cap/index.scss +++ b/ui/components/app/custom-spending-cap/index.scss @@ -6,6 +6,10 @@ &__max { position: relative; margin-top: -30px; + + &--with-error-message { + margin-top: -66px; + } } &__input { @@ -14,6 +18,10 @@ &__description { word-break: break-word; + + &--with-error-message { + margin-top: 30px; + } } #custom-spending-cap-input-value { diff --git a/ui/components/ui/numeric-input/numeric-input.component.js b/ui/components/ui/numeric-input/numeric-input.component.js index 76eb8df0c..9f0e3fd8f 100644 --- a/ui/components/ui/numeric-input/numeric-input.component.js +++ b/ui/components/ui/numeric-input/numeric-input.component.js @@ -3,8 +3,7 @@ import classNames from 'classnames'; import PropTypes from 'prop-types'; import Typography from '../typography/typography'; import { COLORS, TYPOGRAPHY } from '../../../helpers/constants/design-system'; - -const DECIMAL_REGEX = /\.(\d*)/u; +import { DECIMAL_REGEX } from '../../../../shared/constants/tokens'; export default function NumericInput({ detailText = '',