diff --git a/src/components/Table.tsx b/src/components/Table.tsx
index 2be096b..4aec5f6 100644
--- a/src/components/Table.tsx
+++ b/src/components/Table.tsx
@@ -1,6 +1,7 @@
import { useTranslation } from 'next-i18next';
import { EcosystemChainData } from '~/types';
+import { formatDataNumber } from '~/utils';
interface TableProps {
chains: EcosystemChainData[];
@@ -25,7 +26,7 @@ export const Table = ({ chains }: TableProps) => {
{data.name} |
{data.id} |
{data.nativeToken} |
- {data.tvl} |
+ {formatDataNumber(data.tvl, 0, true)} |
{data.type} |
);
diff --git a/src/components/TotalValueLocked.tsx b/src/components/TotalValueLocked.tsx
index 38b4fe1..bc502c9 100644
--- a/src/components/TotalValueLocked.tsx
+++ b/src/components/TotalValueLocked.tsx
@@ -1,3 +1,5 @@
+import { formatDataNumber } from '~/utils';
+
export interface TokenValueLocked {
token: string;
value: number;
@@ -13,7 +15,7 @@ export const TotalValueLocked = ({ tvl }: TotalValueLockedProps) => {
{tvl.map((data, index) => (
{data.token}
- {data.value}
+ {formatDataNumber(data.value, 0, true)}
))}
diff --git a/src/containers/LockedAssets/index.tsx b/src/containers/LockedAssets/index.tsx
index beb9cc6..3d0212d 100644
--- a/src/containers/LockedAssets/index.tsx
+++ b/src/containers/LockedAssets/index.tsx
@@ -2,6 +2,7 @@ import { useTranslation } from 'next-i18next';
import { TotalValueLocked, Title } from '~/components';
import { useData } from '~/hooks';
+import { formatDataNumber } from '~/utils';
export const LockedAssets = () => {
const { t } = useTranslation();
@@ -11,7 +12,7 @@ export const LockedAssets = () => {
{ecosystemData && (
<>
-
+
>
)}
diff --git a/src/data/ecosystemMockData.json b/src/data/ecosystemMockData.json
index c701642..acb7d40 100644
--- a/src/data/ecosystemMockData.json
+++ b/src/data/ecosystemMockData.json
@@ -50,7 +50,7 @@
"type": "Validium"
}
],
- "total": 7000000,
+ "total": 700000000,
"tvl": [
{
"token": "ETH",
diff --git a/src/utils/format.ts b/src/utils/format.ts
index d650ed3..1b39c3d 100644
--- a/src/utils/format.ts
+++ b/src/utils/format.ts
@@ -1,3 +1,46 @@
export const truncateAddress = (address: string) => {
return `${address.slice(0, 6)}...${address.slice(-4)}`;
};
+
+export function formatDataNumber(input: string | number, formatDecimal = 3, currency?: boolean, compact?: boolean) {
+ const res: number = Number.parseFloat(input.toString());
+
+ if (res === 0 || isNaN(res)) return `${currency ? '$0' : '0'}`;
+
+ if (res < 0.01) return formatSmallNumber(res);
+
+ const userNotation = compact ? 'compact' : 'standard';
+ const notation = res > 1e12 ? 'scientific' : userNotation;
+
+ return new Intl.NumberFormat('en-US', {
+ maximumFractionDigits: formatDecimal,
+ notation: notation,
+ style: currency ? 'currency' : 'decimal',
+ currency: 'USD',
+ }).format(res);
+}
+
+export const formatSmallNumber = (value: number) => {
+ if (value === 0) {
+ return '0';
+ }
+
+ const formattedValue = value.toString();
+
+ let numLeadingZeros = 0;
+
+ // Count the leading zeros and decimal point
+ for (let i = 0; i < formattedValue.length; i++) {
+ if (formattedValue[i] === '0' || formattedValue[i] === '.') {
+ numLeadingZeros++;
+ } else {
+ break;
+ }
+ }
+
+ // Return the number with 3 digits after the last leading zero
+ const result = formattedValue.slice(0, numLeadingZeros + 3);
+
+ // Trim any trailing zeros from the result
+ return result.replace(/\.?0+$/, '');
+};