bigbuffet-rw/app/soapbox/utils/numbers.tsx

22 lines
860 B
TypeScript
Raw Normal View History

2022-04-24 12:28:07 -07:00
import React from 'react';
import { FormattedNumber } from 'react-intl';
/** Check if a value is REALLY a number. */
2022-04-28 09:36:45 -07:00
export const isNumber = (value: unknown): value is number => typeof value === 'number' && !isNaN(value);
2022-04-24 12:28:07 -07:00
/** 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) {
2022-04-24 12:28:07 -07:00
return <span><FormattedNumber value={number / 1000} maximumFractionDigits={1} />K</span>;
} else {
return <span><FormattedNumber value={number / 1000000} maximumFractionDigits={1} />M</span>;
2022-04-24 12:28:07 -07:00
}
};
/** 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);