Merge branch 'format-counts' into 'next'

Add support for formatting numbers in millions

See merge request soapbox-pub/soapbox-fe!1257
This commit is contained in:
Justin 2022-04-25 15:34:25 +00:00
commit 033407f1c7
3 changed files with 40 additions and 1 deletions

View file

@ -0,0 +1,37 @@
import React from 'react';
import { render, screen } from '../../jest/test-helpers';
import { isIntegerId, shortNumberFormat } from '../numbers';
test('isIntegerId()', () => {
expect(isIntegerId('0')).toBe(true);
expect(isIntegerId('1')).toBe(true);
expect(isIntegerId('508107650')).toBe(true);
expect(isIntegerId('-1764036199')).toBe(true);
expect(isIntegerId('106801667066418367')).toBe(true);
expect(isIntegerId('9v5bmRalQvjOy0ECcC')).toBe(false);
expect(isIntegerId(null)).toBe(false);
expect(isIntegerId(undefined)).toBe(false);
});
describe('shortNumberFormat', () => {
test('handles non-numbers', () => {
render(<div data-testid='num'>{shortNumberFormat('not-number')}</div>, null, null);
expect(screen.getByTestId('num')).toHaveTextContent('•');
});
test('formats numbers under 1,000', () => {
render(<div data-testid='num'>{shortNumberFormat(555)}</div>, null, null);
expect(screen.getByTestId('num')).toHaveTextContent('555');
});
test('formats numbers under 1,000,000', () => {
render(<div data-testid='num'>{shortNumberFormat(5555)}</div>, null, null);
expect(screen.getByTestId('num')).toHaveTextContent('5.6K');
});
test('formats numbers over 1,000,000', () => {
render(<div data-testid='num'>{shortNumberFormat(5555555)}</div>, null, null);
expect(screen.getByTestId('num')).toHaveTextContent('5.6M');
});
});

View file

@ -10,8 +10,10 @@ export const shortNumberFormat = (number: any): React.ReactNode => {
if (number < 1000) {
return <FormattedNumber value={number} />;
} else {
} else if (number < 1000000) {
return <span><FormattedNumber value={number / 1000} maximumFractionDigits={1} />K</span>;
} else {
return <span><FormattedNumber value={number / 1000000} maximumFractionDigits={1} />M</span>;
}
};