mango-v4-ui/components/SolanaTps.tsx

80 lines
2.2 KiB
TypeScript
Raw Normal View History

2022-11-04 10:29:21 -07:00
import { useEffect, useState } from 'react'
import sumBy from 'lodash/sumBy'
import { useTranslation } from 'next-i18next'
import { Connection } from '@solana/web3.js'
import mangoStore, { CLUSTER } from '@store/mangoStore'
import useInterval from './shared/useInterval'
const tpsAlertThreshold = 1000
const tpsWarningThreshold = 1300
const getRecentPerformance = async (
connection: Connection,
setTps: (x: number) => void
) => {
try {
const samples = 2
const response = await connection.getRecentPerformanceSamples(samples)
const totalSecs = sumBy(response, 'samplePeriodSecs')
const totalTransactions = sumBy(response, 'numTransactions')
const tps = totalTransactions / totalSecs
setTps(tps)
} catch {
2023-01-20 05:45:43 -08:00
console.warn('Unable to fetch TPS')
2022-11-04 10:29:21 -07:00
}
}
const SolanaTps = () => {
const connection = mangoStore((s) => s.connection)
const [tps, setTps] = useState(0)
const { t } = useTranslation('common')
useEffect(() => {
getRecentPerformance(connection, setTps)
}, [])
useInterval(() => {
getRecentPerformance(connection, setTps)
}, 45 * 1000)
if (CLUSTER == 'mainnet-beta') {
return (
<div>
2022-11-19 02:03:39 -08:00
<p className="text-xs text-th-fgd-4">{t('solana-tps')}</p>
2022-11-04 10:29:21 -07:00
<div className="flex items-center">
<div className="relative mr-1 h-3 w-3">
<div
className={`absolute top-0.5 left-0.5 h-2 w-2 rounded-full ${
tps < tpsWarningThreshold
2022-11-30 19:32:32 -08:00
? 'bg-th-warning'
2022-11-04 10:29:21 -07:00
: tps < tpsAlertThreshold
2022-11-30 19:46:37 -08:00
? 'bg-th-error'
: 'bg-th-success'
2022-11-04 10:29:21 -07:00
}`}
/>
<div
className={`absolute h-3 w-3 rounded-full opacity-40 ${
tps < tpsWarningThreshold
2022-11-30 19:32:32 -08:00
? 'bg-th-warning'
2022-11-04 10:29:21 -07:00
: tps < tpsAlertThreshold
2022-11-30 19:46:37 -08:00
? 'bg-th-error'
: 'bg-th-success'
2022-11-04 10:29:21 -07:00
}`}
/>
</div>
<span className="font-mono text-th-fgd-2">
{tps?.toLocaleString(undefined, {
maximumFractionDigits: 0,
})}
</span>
</div>
</div>
)
} else {
return null
}
}
export default SolanaTps