From d9e451e7e74580e64a7f42710f734ef15a5a14b2 Mon Sep 17 00:00:00 2001 From: kwoktung Date: Mon, 20 Feb 2023 21:28:31 +0800 Subject: [PATCH] OK-17503: fix swap slippage (#2595) --- .../kit/src/views/Swap/Slippage/index.tsx | 83 +++++++++++++++---- 1 file changed, 66 insertions(+), 17 deletions(-) diff --git a/packages/kit/src/views/Swap/Slippage/index.tsx b/packages/kit/src/views/Swap/Slippage/index.tsx index e3f6afedaeb..9444b050614 100644 --- a/packages/kit/src/views/Swap/Slippage/index.tsx +++ b/packages/kit/src/views/Swap/Slippage/index.tsx @@ -1,4 +1,5 @@ import { useCallback, useMemo, useState } from 'react'; +import type { FC } from 'react'; import BigNumber from 'bignumber.js'; import { useIntl } from 'react-intl'; @@ -6,11 +7,11 @@ import { useIntl } from 'react-intl'; import { Box, Button, + Icon, Modal, NumberInput, Typography, } from '@onekeyhq/components'; -import { FormErrorMessage } from '@onekeyhq/components/src/Form/FormErrorMessage'; import backgroundApiProxy from '../../../background/instance/backgroundApiProxy'; import { useNavigation } from '../../../hooks'; @@ -22,6 +23,28 @@ import { SwapRoutes } from '../typings'; import type { ISlippageSetting } from '../typings'; +type ErrorMessageProps = { + type: 'error' | 'warn'; + message: string; +}; + +const ErrorMessage: FC = ({ message, type }) => ( + + + + + + {message} + + +); + const TypographyStrong = (text: string) => ( {text} ); @@ -113,23 +136,43 @@ const Slippage = () => { [slippageCurrent], ); - const errorMsg = useMemo(() => { + const errorMsg = useMemo(() => { if (slippageCurrent && slippageCurrent.mode === 'custom') { - if (slippageCurrent.value) { - const value = new BigNumber(slippageCurrent.value); - if (!slippageCurrent.value || value.gte(50) || value.eq(0)) { - return intl.formatMessage({ + const slippageValue = slippageCurrent.value + ? slippageCurrent.value.trim() + : ''; + if (!slippageValue) { + return { + type: 'error', + message: intl.formatMessage({ id: 'msg__enter_a_valid_slippage_percentage', - }); - } - if (value.lt(0.1)) { - return intl.formatMessage({ id: 'msg__your_transaction_may_fail' }); - } - if (value.gte(5) && value.lt(50)) { - return intl.formatMessage({ + }), + }; + } + const value = new BigNumber(slippageValue); + if (value.gt(50) || value.eq(0)) { + return { + type: 'error', + message: intl.formatMessage({ + id: 'msg__enter_a_value_50_to_save_the_slippage', + }), + }; + } + if (value.lt(0.1)) { + return { + type: 'warn', + message: intl.formatMessage({ + id: 'msg__your_transaction_may_fail', + }), + }; + } + if (value.gte(5) && value.lte(50)) { + return { + type: 'warn', + message: intl.formatMessage({ id: 'msg__your_transaction_may_be_frontrun', - }); - } + }), + }; } } }, [slippageCurrent, intl]); @@ -197,7 +240,7 @@ const Slippage = () => { placeholder={intl.formatMessage({ id: 'content__custom' })} onChangeText={onCustomChange} /> - {errorMsg ? : null} + {errorMsg ? : null} {slippageCurrent.mode === 'auto' ? : null} {slippageCurrent.mode === 'preset' && @@ -251,7 +294,13 @@ const Slippage = () => { -