mango-ui-v3/pages/borrow.tsx

94 lines
2.9 KiB
TypeScript

import { useCallback, useState, useEffect } from 'react'
import { CurrencyDollarIcon, LinkIcon } from '@heroicons/react/outline'
import useMangoStore from '../stores/useMangoStore'
import PageBodyContainer from '../components/PageBodyContainer'
import TopBar from '../components/TopBar'
import EmptyState from '../components/EmptyState'
import AccountsModal from '../components/AccountsModal'
import AccountBorrows from '../components/account_page/AccountBorrows'
import Loading from '../components/Loading'
import { serverSideTranslations } from 'next-i18next/serverSideTranslations'
import { useTranslation } from 'next-i18next'
export async function getStaticProps({ locale }) {
return {
props: {
...(await serverSideTranslations(locale, ['common'])),
// Will be passed to the page component as props
},
}
}
export default function Borrow() {
const { t } = useTranslation('common')
const [showAccountsModal, setShowAccountsModal] = useState(false)
const connected = useMangoStore((s) => s.wallet.connected)
const selectedMangoAccount = useMangoStore(
(s) => s.selectedMangoAccount.current
)
const wallet = useMangoStore((s) => s.wallet.current)
const isLoading = useMangoStore((s) => s.selectedMangoAccount.initialLoad)
const handleCloseAccounts = useCallback(() => {
setShowAccountsModal(false)
}, [])
useEffect(() => {
// @ts-ignore
if (window.solana) {
// @ts-ignore
window.solana.connect({ onlyIfTrusted: true })
}
}, [])
return (
<div className={`bg-th-bkg-1 text-th-fgd-1 transition-all`}>
<TopBar />
<PageBodyContainer>
<div className="pt-8 pb-3 sm:pb-4 md:pt-10">
{connected ? (
<>
<h1 className={`mb-1 text-th-fgd-1 text-2xl font-semibold`}>
{t('borrow-funds')}
</h1>
<p>{t('borrow-notification')}</p>
</>
) : null}
</div>
<div className="bg-th-bkg-2 overflow-none p-4 sm:p-6 rounded-lg">
{selectedMangoAccount ? (
<AccountBorrows />
) : connected ? (
isLoading ? (
<div className="flex justify-center py-10">
<Loading />
</div>
) : (
<EmptyState
buttonText="Create Account"
icon={<CurrencyDollarIcon />}
onClickButton={() => setShowAccountsModal(true)}
title="No Account Found"
/>
)
) : (
<EmptyState
buttonText={t('connect')}
desc={t('connect-view')}
icon={<LinkIcon />}
onClickButton={() => wallet.connect()}
title={t('connect-wallet')}
/>
)}
</div>
</PageBodyContainer>
{showAccountsModal ? (
<AccountsModal
onClose={handleCloseAccounts}
isOpen={showAccountsModal}
/>
) : null}
</div>
)
}