mango-ui-v3/hooks/useMangoStats.tsx

132 lines
3.9 KiB
TypeScript
Raw Normal View History

import { useEffect, useState } from 'react'
import { I80F48 } from '@blockworks-foundation/mango-client'
import useMangoStore from '../stores/useMangoStore'
2021-08-24 10:04:43 -07:00
import { tokenPrecision } from '../utils'
const useMangoStats = () => {
2021-08-23 14:09:16 -07:00
const [stats, setStats] = useState([
{
2021-08-23 14:09:16 -07:00
name: '',
hourly: '',
depositInterest: 0,
borrowInterest: 0,
totalDeposits: 0,
totalBorrows: 0,
2021-08-23 14:09:16 -07:00
baseOraclePrice: 0,
utilization: '0',
},
])
const [perpStats, setPerpStats] = useState([
{
name: '',
hourly: '',
oldestLongFunding: 0,
oldestShortFunding: 0,
latestLongFunding: 0,
latestShortFunding: 0,
openInterest: 0,
baseOraclePrice: 0,
},
])
const [latestStats, setLatestStats] = useState<any[]>([])
2022-06-23 04:35:07 -07:00
const [loadLatestStats, setLoadLatestStats] = useState<boolean>(false)
2022-06-21 17:38:24 -07:00
const [loadHistoricalStats, setLoadHistoricalStats] = useState<boolean>(false)
const [loadPerpStats, setLoadPerpStats] = useState<boolean>(false)
const mangoGroup = useMangoStore((s) => s.selectedMangoGroup.current)
const mangoGroupName = useMangoStore((s) => s.selectedMangoGroup.name)
2021-07-21 14:26:18 -07:00
const connection = useMangoStore((s) => s.connection.current)
2022-03-31 07:58:01 -07:00
const config = useMangoStore((s) => s.selectedMangoGroup.config)
useEffect(() => {
2021-08-23 14:09:16 -07:00
const fetchHistoricalStats = async () => {
2022-06-23 04:35:07 -07:00
setLoadHistoricalStats(true)
2022-06-21 17:38:24 -07:00
try {
const response = await fetch(
`https://mango-transaction-log.herokuapp.com/v3/stats/spot_stats_hourly?mango-group=${mangoGroupName}`
)
const stats = await response.json()
setStats(stats)
setLoadHistoricalStats(false)
} catch {
setLoadHistoricalStats(false)
}
2021-08-23 14:09:16 -07:00
}
fetchHistoricalStats()
2021-07-21 14:31:28 -07:00
}, [mangoGroupName])
useEffect(() => {
const fetchHistoricalPerpStats = async () => {
2022-06-23 04:35:07 -07:00
setLoadPerpStats(true)
2022-06-21 17:38:24 -07:00
try {
const response = await fetch(
`https://mango-transaction-log.herokuapp.com/v3/stats/perp_stats_hourly?mango-group=${mangoGroupName}`
)
const stats = await response.json()
setPerpStats(stats)
setLoadPerpStats(false)
} catch {
setLoadPerpStats(false)
}
}
fetchHistoricalPerpStats()
}, [mangoGroupName])
useEffect(() => {
const getLatestStats = async () => {
if (mangoGroup) {
2022-06-23 04:35:07 -07:00
setLoadLatestStats(true)
2021-07-21 14:26:18 -07:00
const rootBanks = await mangoGroup.loadRootBanks(connection)
2022-03-29 06:02:29 -07:00
if (!config) return
const latestStats = config.tokens.map((token) => {
const rootBank = rootBanks.find((bank) => {
if (!bank) {
2021-07-21 14:26:18 -07:00
return false
}
2021-07-21 14:26:18 -07:00
return bank.publicKey.toBase58() == token.rootKey.toBase58()
})
2022-03-25 09:00:48 -07:00
if (!rootBank) {
return
}
2021-07-21 14:26:18 -07:00
const totalDeposits = rootBank.getUiTotalDeposit(mangoGroup)
const totalBorrows = rootBank.getUiTotalBorrow(mangoGroup)
return {
time: new Date(),
2021-08-23 14:09:16 -07:00
name: token.symbol,
2021-08-24 10:04:43 -07:00
totalDeposits: totalDeposits.toFixed(
tokenPrecision[token.symbol] || 2
),
totalBorrows: totalBorrows.toFixed(
tokenPrecision[token.symbol] || 2
),
2021-07-21 14:26:18 -07:00
depositInterest: rootBank
.getDepositRate(mangoGroup)
.mul(I80F48.fromNumber(100)),
borrowInterest: rootBank
.getBorrowRate(mangoGroup)
.mul(I80F48.fromNumber(100)),
2021-07-27 08:41:33 -07:00
utilization: totalDeposits.gt(I80F48.fromNumber(0))
? totalBorrows.div(totalDeposits)
: I80F48.fromNumber(0),
}
2021-07-21 14:26:18 -07:00
})
setLatestStats(latestStats)
2022-06-23 04:35:07 -07:00
setLoadLatestStats(false)
2021-07-21 14:26:18 -07:00
}
}
getLatestStats()
2021-07-21 14:31:28 -07:00
}, [mangoGroup])
2022-06-23 04:35:07 -07:00
return {
latestStats,
loadLatestStats,
stats,
perpStats,
loadHistoricalStats,
loadPerpStats,
}
}
export default useMangoStats