mango-v4-ui/pages/index.tsx

60 lines
1.8 KiB
TypeScript
Raw Normal View History

2022-07-14 22:20:20 -07:00
import { toUiDecimals } from '@blockworks-foundation/mango-v4'
2022-04-12 13:48:22 -07:00
import type { NextPage } from 'next'
2022-07-14 22:20:20 -07:00
import { useTranslation } from 'next-i18next'
2022-07-14 16:36:31 -07:00
import { serverSideTranslations } from 'next-i18next/serverSideTranslations'
2022-07-15 04:09:23 -07:00
import { useState } from 'react'
import AccountActions from '../components/account/AccountActions'
2022-07-14 22:20:20 -07:00
import DepositModal from '../components/modals/DepositModal'
import WithdrawModal from '../components/modals/WithdrawModal'
import mangoStore from '../store/state'
import { formatDecimal } from '../utils/numbers'
2022-04-12 13:48:22 -07:00
2022-07-14 16:36:31 -07:00
export async function getStaticProps({ locale }: { locale: string }) {
return {
props: {
2022-07-15 04:09:23 -07:00
...(await serverSideTranslations(locale, ['common', 'close-account'])),
2022-07-14 16:36:31 -07:00
},
}
}
2022-04-12 13:48:22 -07:00
2022-07-14 16:36:31 -07:00
const Index: NextPage = () => {
2022-07-14 22:20:20 -07:00
const { t } = useTranslation('common')
const mangoAccount = mangoStore((s) => s.mangoAccount)
const [showDepositModal, setShowDepositModal] = useState(false)
const [showWithdrawModal, setShowWithdrawModal] = useState(false)
2022-07-15 04:09:23 -07:00
2022-07-14 22:20:20 -07:00
return (
<>
<div className="flex items-end justify-between">
<div>
<p className="mb-1">{t('account-value')}</p>
<div className="text-5xl font-bold text-th-fgd-1">
$
{mangoAccount
? formatDecimal(
toUiDecimals(mangoAccount.getEquity().toNumber()),
2
)
: (0).toFixed(2)}
</div>
</div>
2022-07-15 04:09:23 -07:00
<AccountActions />
2022-07-14 22:20:20 -07:00
</div>
{showDepositModal ? (
<DepositModal
isOpen={showDepositModal}
onClose={() => setShowDepositModal(false)}
/>
) : null}
{showWithdrawModal ? (
<WithdrawModal
isOpen={showWithdrawModal}
onClose={() => setShowWithdrawModal(false)}
/>
) : null}
</>
)
2022-04-12 13:48:22 -07:00
}
export default Index