Skip to content

Commit

Permalink
Refacto handle percent fn
Browse files Browse the repository at this point in the history
  • Loading branch information
pivilartisant committed Oct 25, 2023
1 parent bf507c3 commit 2f3b069
Show file tree
Hide file tree
Showing 3 changed files with 30 additions and 39 deletions.
26 changes: 1 addition & 25 deletions web-frontend/cypress/e2e/acceptance/home/send.cy.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import {
formatStandard,
maskAddress,
} from '../../../../src/utils/massaFormat';
import { compareSnapshot } from '../../../compareSnapshot';
import { handlePercent } from '../../../../src/utils/math';

describe('E2E | Acceptance | Home', () => {
let server: Server;
Expand Down Expand Up @@ -78,18 +78,6 @@ describe('E2E | Acceptance | Home', () => {
}
}

// mimics handlepercent fn in sendForm.tsx
// TODO: refactor handlePercent to be a util function
function handlePercent(amount = 0, percent: number, fees, balance) {
let newAmount = amount * percent;
const feesAsNumber = Number(fees);

if (newAmount > balance - feesAsNumber)
newAmount = Math.max(balance - feesAsNumber, 0);

return toMASS(newAmount);
}

// standardize percent testing
function performPercentAction(percentValue, account, fees) {
const balance = Number(account?.candidateBalance);
Expand Down Expand Up @@ -126,8 +114,6 @@ describe('E2E | Acceptance | Home', () => {
cy.get('[data-testid="loading"]').should('not.exist');
});
});

compareSnapshot(cy, 'wallet-loading');
});

it('should land on send page when send CTA is clicked', () => {
Expand All @@ -139,8 +125,6 @@ describe('E2E | Acceptance | Home', () => {
cy.get('[data-testid="send-coins"]').should('be.visible');
cy.get('[data-testid="receive-coins"]').should('not.be.visible');
cy.get('[data-testid="send-coins"]').should('exist');

compareSnapshot(cy, 'send-page');
});

it('should navigate to /transfer-coins when accessing it by the side-menu', () => {
Expand All @@ -150,7 +134,6 @@ describe('E2E | Acceptance | Home', () => {
cy.get('[data-testid="side-menu"]').click();
cy.get('[data-testid="side-menu-sendreceive-icon"]').click();
cy.url().should('eq', `${baseUrl}/${account.nickname}/transfer-coins`);
compareSnapshot(cy, 'send-page');
});

it('should render balance and amount should equal account balance', () => {
Expand All @@ -162,7 +145,6 @@ describe('E2E | Acceptance | Home', () => {
'contain',
getBalance(account),
);
compareSnapshot(cy, 'send-page');
});

it('should send coins to address', () => {
Expand Down Expand Up @@ -196,14 +178,10 @@ describe('E2E | Acceptance | Home', () => {
maskAddress(recipientAccount.address),
);

compareSnapshot(cy, 'send-confirmation-page');

cy.get('[data-testid="button"]')
.contains('Confirm and sign with password')
.click();
cy.url().should('eq', `${baseUrl}/${account.nickname}/home`);

compareSnapshot(cy, 'home-page');
});

it('should process any % as input', () => {
Expand All @@ -226,8 +204,6 @@ describe('E2E | Acceptance | Home', () => {
const randomIndex = Math.floor(Math.random() * mockedAccounts.length);
const selectedAccount = mockedAccounts.at(randomIndex);

console.log(mockedAccounts);

navigateToTransfercoins(2);

cy.get('[data-testid="transfer-between-accounts"]')
Expand Down
27 changes: 13 additions & 14 deletions web-frontend/src/pages/TransferCoins/SendCoins/SendForm.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ import {
reverseFormatStandard,
fetchAccounts,
} from '@/utils';
import { handlePercent } from '@/utils/math';

interface InputsErrors {
amount?: string;
Expand Down Expand Up @@ -51,16 +52,6 @@ export function SendForm({ ...props }) {
setRecipient(to);
}, []);

function handlePercent(amount = 0, percent: number) {
let newAmount = amount * percent;
const feesAsNumber = Number(fees);

if (newAmount > balance - feesAsNumber)
newAmount = Math.max(balance - feesAsNumber, 0);

setAmount(toMASS(newAmount));
}

function validate(formObject: IForm) {
const { amount, recipient } = formObject;

Expand Down Expand Up @@ -137,28 +128,36 @@ export function SendForm({ ...props }) {
<ul className="flex flex-row mas-body2">
<li
data-testid="send-percent-25"
onClick={() => handlePercent(balance, 0.25)}
onClick={() =>
setAmount(handlePercent(balance, 0.25, fees, balance))
}
className="mr-3.5 hover:cursor-pointer"
>
25%
</li>
<li
data-testid="send-percent-50"
onClick={() => handlePercent(balance, 0.5)}
onClick={() =>
setAmount(handlePercent(balance, 0.5, fees, balance))
}
className="mr-3.5 hover:cursor-pointer"
>
50%
</li>
<li
data-testid="send-percent-75"
onClick={() => handlePercent(balance, 0.75)}
onClick={() =>
setAmount(handlePercent(balance, 0.75, fees, balance))
}
className="mr-3.5 hover:cursor-pointer"
>
75%
</li>
<li
data-testid="send-percent-100"
onClick={() => handlePercent(balance, 1)}
onClick={() =>
setAmount(handlePercent(balance, 1, fees, balance))
}
className="mr-3.5 hover:cursor-pointer"
>
Max
Expand Down
16 changes: 16 additions & 0 deletions web-frontend/src/utils/math.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
import { toMASS } from './massaFormat';

export function handlePercent(
amount = 0,
percent: number,
fees: string,
balance: number,
) {
let newAmount = amount * percent;
const feesAsNumber = Number(fees);

if (newAmount > balance - feesAsNumber)
newAmount = Math.max(balance - feesAsNumber, 0);

return toMASS(newAmount);
}

0 comments on commit 2f3b069

Please sign in to comment.