From 52da412079ce56691c5dee0db1da335d3f0f1c60 Mon Sep 17 00:00:00 2001 From: tienifr Date: Wed, 27 Mar 2024 16:48:16 +0700 Subject: [PATCH 1/3] fix no invalid amount error if lasts digit are 0 --- .../components/BankAccountValidationForm.tsx | 19 ++++++++++--------- 1 file changed, 10 insertions(+), 9 deletions(-) diff --git a/src/pages/ReimbursementAccount/ConnectBankAccount/components/BankAccountValidationForm.tsx b/src/pages/ReimbursementAccount/ConnectBankAccount/components/BankAccountValidationForm.tsx index 6a18fba22bf9..82ee17377220 100644 --- a/src/pages/ReimbursementAccount/ConnectBankAccount/components/BankAccountValidationForm.tsx +++ b/src/pages/ReimbursementAccount/ConnectBankAccount/components/BankAccountValidationForm.tsx @@ -43,9 +43,10 @@ function getAmountValues(values: FormOnyxValues { +const filterInput = (amount: string, amountRegex?: RegExp, permittedDecimalSeparator?: string) => { let value = amount ? amount.toString().trim() : ''; - value = value.replace(/^0+|0+$/g, ''); + const regex = new RegExp(`^0+|(\\${permittedDecimalSeparator}\\d*?)0+$`, 'g'); + value = value.replace(regex, '$1'); if (value === '' || Number.isNaN(Number(value)) || !Math.abs(Str.fromUSDToNumber(value, false)) || (amountRegex && !amountRegex.test(value))) { return ''; } @@ -58,17 +59,17 @@ function BankAccountValidationForm({requiresTwoFactorAuth, reimbursementAccount, const styles = useThemeStyles(); const policyID = reimbursementAccount?.achData?.policyID ?? ''; - + const decimalSeparator = toLocaleDigit('.'); + const permittedDecimalSeparator = getPermittedDecimalSeparator(decimalSeparator); const validate = (values: FormOnyxValues): FormInputErrors => { const errors: FormInputErrors = {}; const amountValues = getAmountValues(values); - const decimalSeparator = toLocaleDigit('.'); const outputCurrency = policy?.outputCurrency ?? CONST.CURRENCY.USD; const amountRegex = RegExp(String.raw`^-?\d{0,8}([${getPermittedDecimalSeparator(decimalSeparator)}]\d{0,${CurrencyUtils.getCurrencyDecimals(outputCurrency)}})?$`, 'i'); Object.keys(amountValues).forEach((key) => { const value = amountValues[key as keyof AmountValues]; - const filteredValue = filterInput(value, amountRegex); + const filteredValue = filterInput(value, amountRegex, permittedDecimalSeparator); if (ValidationUtils.isRequiredFulfilled(filteredValue.toString())) { return; } @@ -80,9 +81,9 @@ function BankAccountValidationForm({requiresTwoFactorAuth, reimbursementAccount, const submit = useCallback( (values: FormOnyxValues) => { - const amount1 = filterInput(values.amount1 ?? ''); - const amount2 = filterInput(values.amount2 ?? ''); - const amount3 = filterInput(values.amount3 ?? ''); + const amount1 = filterInput(values.amount1 ?? '', undefined, permittedDecimalSeparator); + const amount2 = filterInput(values.amount2 ?? '', undefined, permittedDecimalSeparator); + const amount3 = filterInput(values.amount3 ?? '', undefined, permittedDecimalSeparator); const validateCode = [amount1, amount2, amount3].join(','); @@ -92,7 +93,7 @@ function BankAccountValidationForm({requiresTwoFactorAuth, reimbursementAccount, BankAccounts.validateBankAccount(bankAccountID, validateCode, policyID); } }, - [reimbursementAccount, policyID], + [reimbursementAccount, policyID, permittedDecimalSeparator], ); return ( Date: Wed, 27 Mar 2024 17:22:17 +0700 Subject: [PATCH 2/3] fix regex --- .../ConnectBankAccount/components/BankAccountValidationForm.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/pages/ReimbursementAccount/ConnectBankAccount/components/BankAccountValidationForm.tsx b/src/pages/ReimbursementAccount/ConnectBankAccount/components/BankAccountValidationForm.tsx index 82ee17377220..5f07ae474eac 100644 --- a/src/pages/ReimbursementAccount/ConnectBankAccount/components/BankAccountValidationForm.tsx +++ b/src/pages/ReimbursementAccount/ConnectBankAccount/components/BankAccountValidationForm.tsx @@ -45,7 +45,7 @@ function getAmountValues(values: FormOnyxValues { let value = amount ? amount.toString().trim() : ''; - const regex = new RegExp(`^0+|(\\${permittedDecimalSeparator}\\d*?)0+$`, 'g'); + const regex = new RegExp(`^0+|([${permittedDecimalSeparator}]\\d*?)0+$`, 'g'); value = value.replace(regex, '$1'); if (value === '' || Number.isNaN(Number(value)) || !Math.abs(Str.fromUSDToNumber(value, false)) || (amountRegex && !amountRegex.test(value))) { return ''; From 41f840874863253bebc21dcbedd9ad1e7d474e30 Mon Sep 17 00:00:00 2001 From: tienifr Date: Thu, 28 Mar 2024 11:35:14 +0700 Subject: [PATCH 3/3] fix use permittedDecimalSeparator in regex --- .../ConnectBankAccount/components/BankAccountValidationForm.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/pages/ReimbursementAccount/ConnectBankAccount/components/BankAccountValidationForm.tsx b/src/pages/ReimbursementAccount/ConnectBankAccount/components/BankAccountValidationForm.tsx index 5f07ae474eac..a83e18d119c9 100644 --- a/src/pages/ReimbursementAccount/ConnectBankAccount/components/BankAccountValidationForm.tsx +++ b/src/pages/ReimbursementAccount/ConnectBankAccount/components/BankAccountValidationForm.tsx @@ -65,7 +65,7 @@ function BankAccountValidationForm({requiresTwoFactorAuth, reimbursementAccount, const errors: FormInputErrors = {}; const amountValues = getAmountValues(values); const outputCurrency = policy?.outputCurrency ?? CONST.CURRENCY.USD; - const amountRegex = RegExp(String.raw`^-?\d{0,8}([${getPermittedDecimalSeparator(decimalSeparator)}]\d{0,${CurrencyUtils.getCurrencyDecimals(outputCurrency)}})?$`, 'i'); + const amountRegex = RegExp(String.raw`^-?\d{0,8}([${permittedDecimalSeparator}]\d{0,${CurrencyUtils.getCurrencyDecimals(outputCurrency)}})?$`, 'i'); Object.keys(amountValues).forEach((key) => { const value = amountValues[key as keyof AmountValues];