From 0ca950aa78220bc7a9cde4742f24f07db8a653d3 Mon Sep 17 00:00:00 2001 From: thedoublejay Date: Thu, 5 Aug 2021 15:17:24 +0800 Subject: [PATCH] factor in slippage for poolswap calculation --- .../screens/Dex/PoolSwap/PoolSwapScreen.tsx | 34 +++++++++++++------ .../functional/dex/poolswap.spec.ts | 21 ++++++------ 2 files changed, 33 insertions(+), 22 deletions(-) diff --git a/app/screens/AppNavigator/screens/Dex/PoolSwap/PoolSwapScreen.tsx b/app/screens/AppNavigator/screens/Dex/PoolSwap/PoolSwapScreen.tsx index 195c87ed4e..194e9a814e 100644 --- a/app/screens/AppNavigator/screens/Dex/PoolSwap/PoolSwapScreen.tsx +++ b/app/screens/AppNavigator/screens/Dex/PoolSwap/PoolSwapScreen.tsx @@ -42,6 +42,7 @@ export function PoolSwapScreen ({ route }: Props): JSX.Element { // props derived state const [tokenA, setTokenA] = useState() const [tokenB, setTokenB] = useState() + const [isComputing, setIsComputing] = useState(false) // component UI state const { control, setValue, formState: { isValid }, getValues, trigger } = useForm({ mode: 'onChange' }) @@ -112,11 +113,14 @@ export function PoolSwapScreen ({ route }: Props): JSX.Element { token={tokenA} control={control} controlName={tokenAForm} title={`${translate('screens/PoolSwapScreen', 'SWAP')} ${tokenA.symbol}`} onChangeFromAmount={async (amount) => { + setIsComputing(true) amount = isNaN(+amount) ? '0' : amount setValue(tokenAForm, amount) await trigger(tokenAForm) - setValue(tokenBForm, aToBPrice.times(amount !== undefined && amount !== '' ? amount : 0).toFixed(8)) + const reserveA = getReserveAmount(tokenA.id, poolpair) + setValue(tokenBForm, calculateEstimatedAmount(amount, reserveA, aToBPrice.toFixed(8)).toFixed(8)) await trigger(tokenBForm) + setIsComputing(false) }} maxAmount={tokenA.amount} /> @@ -129,7 +133,7 @@ export function PoolSwapScreen ({ route }: Props): JSX.Element { maxAmount={aToBPrice.times(getValues()[tokenAForm]).toFixed(8)} /> { - (new BigNumber(getValues()[tokenAForm]).isGreaterThan(0) && new BigNumber(getValues()[tokenBForm]).isGreaterThan(0)) && + !isComputing && (new BigNumber(getValues()[tokenAForm]).isGreaterThan(0) && new BigNumber(getValues()[tokenBForm]).isGreaterThan(0)) && - { cy.getByTestID('swap_button').click().wait(4000) // Valid form cy.getByTestID('text_input_tokenA').type('1') - cy.getByTestID('text_price_row_price_1').then(($txt: any) => { - const tokenValue = $txt[0].textContent.replace(' LTC per DFI', '').replace(',', '') + cy.getByTestID('text_price_row_estimated_0').then(($txt: any) => { + const tokenValue = $txt[0].textContent.replace(' LTC', '').replace(',', '') cy.getByTestID('text_input_tokenB').should('have.value', new BigNumber(tokenValue).toFixed(8)) cy.getByTestID('button_submit').should('not.have.attr', 'disabled') @@ -56,7 +56,7 @@ context('poolswap with values', () => { it('should be able to click max', function () { cy.getByTestID('MAX_amount_button').click().wait(3000) cy.getByTestID('text_input_tokenA').should('have.value', '10.00000000') - cy.getByTestID('text_price_row_minimum_0').then(($txt: any) => { + cy.getByTestID('text_price_row_estimated_0').then(($txt: any) => { const tokenValue = $txt[0].textContent.replace(' LTC', '').replace(',', '') cy.getByTestID('text_input_tokenB').should('have.value', new BigNumber(tokenValue).toFixed(8)) }) @@ -64,27 +64,26 @@ context('poolswap with values', () => { it('should be able to click half', function () { cy.getByTestID('50%_amount_button').click().wait(3000) - cy.getByTestID('text_input_tokenA').should('have.value', '5.00000000') - cy.getByTestID('text_price_row_minimum_0').then(($txt: any) => { + cy.getByTestID('text_input_tokenA').should('have.value', '5.00000000').wait(3000) + cy.getByTestID('text_price_row_estimated_0').then(($txt: any) => { const tokenValue = $txt[0].textContent.replace(' LTC', '').replace(',', '') - cy.getByTestID('text_input_tokenB').should('have.value', new BigNumber(tokenValue).div(2).toFixed(8)) + cy.getByTestID('text_input_tokenB').should('have.value', new BigNumber(tokenValue).toFixed(8)) }) }) it('should be able to swap', function () { - cy.getByTestID('text_price_row_minimum_0').then(() => { - // const tokenValue = $txt[0].textContent.replace(' LTC', '').replace(',', '') + cy.getByTestID('text_price_row_estimated_0').then(($txt: any) => { + const tokenValue = $txt[0].textContent.replace(' LTC', '').replace(',', '') cy.getByTestID('button_submit').click() cy.closeOceanInterface() cy.getByTestID('playground_wallet_fetch_balances').click() cy.getByTestID('bottom_tab_balances').click() cy.getByTestID('balances_row_4').should('exist') - // Need to update once poolswap calculations are correct - /* cy.getByTestID('balances_row_4_amount').then(($txt: any) => { + cy.getByTestID('balances_row_4_amount').then(($txt: any) => { const balanceAmount = $txt[0].textContent.replace(' LTC', '').replace(',', '') expect(new BigNumber(balanceAmount).toNumber()).be.gte(new BigNumber(tokenValue).toNumber()) - }) */ + }) cy.getByTestID('bottom_tab_dex').click() cy.getByTestID('swap_button').click().wait(4000)