67 lines
2.0 KiB
TypeScript
67 lines
2.0 KiB
TypeScript
import { ModalProps } from '../../types/modal'
|
|
import Modal from '../shared/Modal'
|
|
import { useEffect, useState } from 'react'
|
|
import TabUnderline from '@components/shared/TabUnderline'
|
|
import DepositForm from '@components/DepositForm'
|
|
import WithdrawForm from '@components/WithdrawForm'
|
|
import { ACCOUNT_ACTION_MODAL_HEIGHT } from 'utils/constants'
|
|
import mangoStore from '@store/mangoStore'
|
|
import { useWallet } from '@solana/wallet-adapter-react'
|
|
import useUnownedAccount from 'hooks/useUnownedAccount'
|
|
|
|
interface DepositWithdrawModalProps {
|
|
action: 'deposit' | 'withdraw'
|
|
token?: string
|
|
}
|
|
|
|
type ModalCombinedProps = DepositWithdrawModalProps & ModalProps
|
|
|
|
const DepositWithdrawModal = ({
|
|
action,
|
|
isOpen,
|
|
onClose,
|
|
token,
|
|
}: ModalCombinedProps) => {
|
|
const [activeTab, setActiveTab] = useState(action)
|
|
const { publicKey: walletPk } = useWallet()
|
|
const { isDelegatedAccount } = useUnownedAccount()
|
|
|
|
useEffect(() => {
|
|
if (walletPk) {
|
|
mangoStore.getState().actions.fetchWalletTokens(walletPk)
|
|
}
|
|
}, [walletPk])
|
|
|
|
return (
|
|
<Modal isOpen={isOpen} onClose={onClose}>
|
|
<div style={{ height: ACCOUNT_ACTION_MODAL_HEIGHT }}>
|
|
{!isDelegatedAccount ? (
|
|
<>
|
|
<div className="pb-2">
|
|
<TabUnderline
|
|
activeValue={activeTab}
|
|
values={['deposit', 'withdraw']}
|
|
onChange={(v) => setActiveTab(v)}
|
|
/>
|
|
</div>
|
|
{activeTab === 'deposit' ? (
|
|
<DepositForm onSuccess={onClose} token={token} />
|
|
) : null}
|
|
{activeTab === 'withdraw' ? (
|
|
<WithdrawForm onSuccess={onClose} token={token} />
|
|
) : null}
|
|
</>
|
|
) : (
|
|
<div className="flex h-full w-full items-center justify-center">
|
|
<div className="text-th-fgd-4">
|
|
Unavailable for delegate accounts
|
|
</div>
|
|
</div>
|
|
)}
|
|
</div>
|
|
</Modal>
|
|
)
|
|
}
|
|
|
|
export default DepositWithdrawModal
|