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} />;
|
2022-04-25 08:08:32 -07:00
|
|
|
} else if (number < 1000000) {
|
2022-04-24 12:28:07 -07:00
|
|
|
return <span><FormattedNumber value={number / 1000} maximumFractionDigits={1} />K</span>;
|
2022-04-25 08:08:32 -07:00
|
|
|
} 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);
|