Skip to content

Commit

Permalink
fix: [cherry-pick][V12.1.0] Permit ellipsis fixes (4/4) - Permit elli…
Browse files Browse the repository at this point in the history
…psis should use max 15 char (#26458) (#26516)

## **Description**

Cherry-pick fix: Permit ellipsis should use max 15 char (#26458) into
v12.1.0

> Display max 15 characters, not max 15 digits, before ellipsis for
amounts shown in Permit pages. Updated to use `shortenString` here.

[![Open in GitHub
Codespaces](https://github.com/codespaces/badge.svg)](https://codespaces.new/MetaMask/metamask-extension/pull/26516?quickstart=1)

## **Related issues**

Fixes: MetaMask/MetaMask-planning#2845

## **Manual testing steps**

1. Go to test-dapp
2. Trigger Malicious Permit request
3. Observe ellipsis values in a. spending cap in simulation b. value in
the message

## **Screenshots/Recordings**

<!-- If applicable, add screenshots and/or recordings to visualize the
before and after of your change. -->

### **Before**

<!-- [screenshots/recordings] -->

### **After**

There is a decimal issue that will be merged with another cherry-pick
<img width="320"
src="https://github.com/user-attachments/assets/e9c75347-b6e4-410b-b235-682c925313a3">

## **Pre-merge author checklist**

- [ ] I've followed [MetaMask Contributor
Docs](https://github.com/MetaMask/contributor-docs) and [MetaMask
Extension Coding

Standards](https://github.com/MetaMask/metamask-extension/blob/develop/.github/guidelines/CODING_GUIDELINES.md).
- [ ] I've completed the PR template to the best of my ability
- [ ] I’ve included tests if applicable
- [ ] I’ve documented my code using [JSDoc](https://jsdoc.app/) format
if applicable
- [ ] I’ve applied the right labels on the PR (see [labeling
guidelines](https://github.com/MetaMask/metamask-extension/blob/develop/.github/guidelines/LABELING_GUIDELINES.md)).
Not required for external contributors.

## **Pre-merge reviewer checklist**

- [ ] I've manually tested the PR (e.g. pull and build branch, run the
app, test code being changed).
- [ ] I confirm that this PR addresses all acceptance criteria described
in the ticket it closes and includes the necessary testing evidence such
as recordings and or screenshots.

---------

Co-authored-by: OGPoyraz <[email protected]>
  • Loading branch information
digiwand and OGPoyraz authored Aug 19, 2024
1 parent 32edb6d commit 071c491
Show file tree
Hide file tree
Showing 5 changed files with 17 additions and 64 deletions.
4 changes: 2 additions & 2 deletions ui/components/app/confirm/info/row/text-token-units.test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ describe('ConfirmInfoRowTextTokenUnits', () => {
<ConfirmInfoRowTextTokenUnits value={value} decimals={decimals} />,
);

expect(getByText('30,001,231,231,212')).toBeInTheDocument();
expect(getByText('30,001,231,231,...')).toBeInTheDocument();
});

it('renders the value with the correct formatted number and ellipsis', () => {
Expand All @@ -50,6 +50,6 @@ describe('ConfirmInfoRowTextTokenUnits', () => {
<ConfirmInfoRowTextTokenUnits value={value} decimals={decimals} />,
);

expect(getByText('3,000,123,123,121,23...')).toBeInTheDocument();
expect(getByText('3,000,123,123,1...')).toBeInTheDocument();
});
});
9 changes: 7 additions & 2 deletions ui/components/app/confirm/info/row/text-token-units.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,10 @@ import { BigNumber } from 'bignumber.js';

import { calcTokenAmount } from '../../../../../../shared/lib/transactions-controller-utils';
import {
ellipsisAmountText,
formatAmount,
formatAmountMaxPrecision,
} from '../../../../../pages/confirmations/components/simulation-details/formatAmount';
import { shortenString } from '../../../../../helpers/utils/util';
import { ConfirmInfoRowText } from './text';

type ConfirmInfoRowTextTokenUnitsProps = {
Expand All @@ -24,7 +24,12 @@ export const ConfirmInfoRowTextTokenUnits: React.FC<

return (
<ConfirmInfoRowText
text={ellipsisAmountText(tokenText)}
text={shortenString(tokenText, {
truncatedCharLimit: 15,
truncatedStartChars: 15,
truncatedEndChars: 0,
skipCharacterInEnd: true,
})}
tooltip={tokenTextMaxPrecision}
/>
);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ import {
ConfirmInfoRow,
ConfirmInfoRowText,
} from '../../../../../../../components/app/confirm/info/row';
import { shortenString } from '../../../../../../../helpers/utils/util';
import { useI18nContext } from '../../../../../../../hooks/useI18nContext';
import { currentConfirmationSelector } from '../../../../../../../selectors';
import { Box, Text } from '../../../../../../../components/component-library';
Expand All @@ -25,7 +26,6 @@ import { SignatureRequestType } from '../../../../../types/confirm';
import useTokenExchangeRate from '../../../../../../../components/app/currency-input/hooks/useTokenExchangeRate';
import { IndividualFiatDisplay } from '../../../../simulation-details/fiat-display';
import {
ellipsisAmountText,
formatAmount,
formatAmountMaxPrecision,
} from '../../../../simulation-details/formatAmount';
Expand Down Expand Up @@ -90,7 +90,12 @@ const PermitSimulation: React.FC<{
paddingInline={2}
textAlign={TextAlign.Center}
>
{ellipsisAmountText(tokenValue || '')}
{shortenString(tokenValue || '', {
truncatedCharLimit: 15,
truncatedStartChars: 15,
truncatedEndChars: 0,
skipCharacterInEnd: true,
})}
</Text>
</Tooltip>
</Box>
Expand Down
Original file line number Diff line number Diff line change
@@ -1,24 +1,7 @@
import { BigNumber } from 'bignumber.js';
import { ellipsisAmountText, formatAmount } from './formatAmount';
import { formatAmount } from './formatAmount';

describe('formatAmount', () => {
describe('#ellipsisAmountText', () => {
const MOCK_MAX_LEFT_DIGITS = 15;

// @ts-expect-error This is missing from the Mocha type definitions
it.each([
['1.003', '1.003'],
['1,034', '1,034'],
['1,213,098,292,340,945', '1,213,098,292,340,94...'],
['30,001,231,231,212,312,138,768', '30,001,231,231,212,3...'],
])(
'formats amount greater than or equal to 1 with appropriate decimal precision (%s => %s)',
(amount: string, expected: string) => {
expect(ellipsisAmountText(amount, MOCK_MAX_LEFT_DIGITS)).toBe(expected);
},
);
});

describe('#formatAmount', () => {
const locale = 'en-US';

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,51 +4,11 @@ import {
DEFAULT_PRECISION,
} from '../../../../hooks/useCurrencyDisplay';

const MAX_ELLIPSIS_LEFT_DIGITS = 15;

// The number of significant decimals places to show for amounts less than 1.
const MAX_SIGNIFICANT_DECIMAL_PLACES = 3;

const ZERO_DISPLAY = '0';

/**
* This function receives an formatted number and will append an ellipsis if the number of digits
* is greater than MAX_LEFT_DIGITS. Currently, we're only supporting en-US format. When we support
* i18n numbers, we'll need to update this method to support i18n.
*
* This method has been designed to receive results of formatAmount.
*
* There is no need to format the decimal portion because formatAmount shaves the portions off
* accordingly.
*
* @param amountText
* @param maxLeftDigits
*/
export function ellipsisAmountText(
amountText: string,
maxLeftDigits: number = MAX_ELLIPSIS_LEFT_DIGITS,
): string {
const [integerPart] = amountText.split('.');
const cleanIntegerPart = integerPart.replace(/,/gu, '');

if (cleanIntegerPart.length > maxLeftDigits) {
let result = '';
let digitCount = 0;

for (let i = 0; digitCount < maxLeftDigits; i++) {
const integerChar = integerPart[i];
result += integerChar;
if (integerChar !== ',') {
digitCount += 1;
}
}

return `${result}...`;
}

return amountText;
}

export function formatAmountMaxPrecision(
locale: string,
num: number | BigNumber,
Expand Down

0 comments on commit 071c491

Please sign in to comment.