import { useBalances } from '../hooks/useBalances' import useMangoStore from '../stores/useMangoStore' import { settleAll } from '../utils/mango' import useConnection from '../hooks/useConnection' import Button from '../components/Button' import { notify } from '../utils/notifications' import { Table, Thead, Tbody, Tr, Th, Td } from 'react-super-responsive-table' import { InformationCircleIcon } from '@heroicons/react/outline' import Tooltip from './Tooltip' import { sleep } from '../utils' import { PublicKey } from '@solana/web3.js' const BalancesTable = () => { const balances = useBalances() const { programId, connection } = useConnection() const actions = useMangoStore((s) => s.actions) async function handleSettleAll() { const markets = Object.values( useMangoStore.getState().selectedMangoGroup.markets ) const marginAccount = useMangoStore.getState().selectedMarginAccount.current const mangoGroup = useMangoStore.getState().selectedMangoGroup.current const wallet = useMangoStore.getState().wallet.current try { await settleAll( connection, new PublicKey(programId), mangoGroup, marginAccount, markets, wallet ) await sleep(250) actions.fetchMarginAccounts() } catch (e) { console.warn('Error settling all:', e) if (e.message === 'No unsettled funds') { notify({ message: 'There are no unsettled funds', type: 'error', }) } else { notify({ message: 'Error settling funds', description: e.message, txid: e.txid, type: 'error', }) } } } return (
Coin | Deposits | Borrows | In Orders | Unsettled | Net |
---|---|---|---|---|---|
{balance.coin} | {balance.marginDeposits} | {balance.borrows} | {balance.orders} | {balance.unsettled} | {balance.net} |