import useMangoGroup from 'hooks/useMangoGroup' import type { NextPage } from 'next' import { serverSideTranslations } from 'next-i18next/serverSideTranslations' import { DashboardNavbar } from '.' import { Table, Td, Th, TrBody, TrHead } from '@components/shared/TableElements' import { useQuery } from '@tanstack/react-query' import { emptyWallet } from '@store/mangoStore' import { MANGO_V4_ID, MangoClient, getRiskStats, } from '@blockworks-foundation/mango-v4' import { PublicKey } from '@solana/web3.js' import { formatNumericValue } from 'utils/numbers' import { AnchorProvider, web3 } from '@coral-xyz/anchor' export async function getStaticProps({ locale }: { locale: string }) { return { props: { ...(await serverSideTranslations(locale, ['common', 'settings'])), }, } } type TableRow = { val: string | number | PublicKey highlight: boolean } type TableData = { title: string data: Array> } const formatValue = (val: string | number | PublicKey) => { if (val instanceof PublicKey || typeof val === 'object') { return val.toString() } if (typeof val === 'string') { return val } else { return formatNumericValue(val) } } const RiskDashboard: NextPage = () => { const { group } = useMangoGroup() const { data } = useQuery( ['risks'], () => { const provider = new AnchorProvider( new web3.Connection( process.env.NEXT_PUBLIC_ENDPOINT || 'https://mango.rpcpool.com/946ef7337da3f5b8d3e4a34e7f88', 'processed', ), emptyWallet, AnchorProvider.defaultOptions(), ) const client = MangoClient.connect( provider, 'mainnet-beta', MANGO_V4_ID['mainnet-beta'], ) if (group) { return getRiskStats(client, group) } }, { cacheTime: 1000 * 60 * 5, staleTime: 1000 * 60 * 5, retry: 0, refetchOnWindowFocus: false, enabled: !!group, }, ) return (

Dashboard

{group && data ? (
{Object.entries(data).map( ([tableType, table]: [string, TableData]) => { if (!table?.data?.length) return null return (

{table.title}

{Object.keys(table.data[0]).map( (colName: string) => { return ( ) }, )} {table.data.map((rowData, index: number) => { return ( {Object.values(rowData).map( (val, idx: number) => { return ( ) }, )} ) })}
{colName}{' '} {colName.toLowerCase().includes('fee') || colName.toLowerCase().includes('slippage') ? '(bps)' : ''} {colName.toLowerCase().includes('assets') || colName.toLowerCase().includes('liabs') || colName.toLowerCase().includes('equity') || colName.toLowerCase().includes('price') || colName.toLowerCase().includes('position') ? '($)' : ''}
{formatValue(val?.val)}
) }, )}
) : (
Loading... make take up to 60 seconds
)}
) } export default RiskDashboard