bigbuffet-rw/app/soapbox/utils/numbers.tsx
2022-04-28 11:36:45 -05:00

21 lines
860 B
TypeScript

import React from 'react';
import { FormattedNumber } from 'react-intl';
/** Check if a value is REALLY a number. */
export const isNumber = (value: unknown): value is number => typeof value === 'number' && !isNaN(value);
/** Display a number nicely for the UI, eg 1000 becomes 1K. */
export const shortNumberFormat = (number: any): React.ReactNode => {
if (!isNumber(number)) return '•';
if (number < 1000) {
return <FormattedNumber value={number} />;
} 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>;
}
};
/** Check if an entity ID is an integer (eg not a FlakeId). */
export const isIntegerId = (id: string): boolean => new RegExp(/^-?[0-9]+$/g).test(id);