mango-ui-v3/components/MarginAccountSelect.tsx

73 lines
2.0 KiB
TypeScript

import { MarginAccount } from '@blockworks-foundation/mango-client'
import { useState } from 'react'
import useMangoStore from '../stores/useMangoStore'
import Select from './Select'
import { abbreviateAddress } from '../utils'
import useMarketList from '../hooks/useMarketList'
type MarginAccountSelectProps = {
className?: string
onChange?: (x) => void
value?: MarginAccount | null
disabled?: boolean
}
const MarginAccountSelect = ({
onChange,
value,
disabled = false,
className = '',
}: MarginAccountSelectProps) => {
const marginAccounts = useMangoStore((s) => s.marginAccounts)
const [selectedMarginAccount, setSelectedMarginAccount] = useState(
value || marginAccounts[0]
)
const { symbols } = useMarketList()
const handleSelectMarginAccount = (value) => {
const marginAccount = marginAccounts.find(
(ma) => ma.publicKey.toString() === value
)
setSelectedMarginAccount(marginAccount)
if (onChange) {
onChange(marginAccount)
}
}
return (
<Select
disabled={disabled}
value={
<div className="text-left">
{Object.keys(symbols).map((symbol, index) =>
index !== 0 ? `/${symbol}` : symbol
)}
<div className="text-xs text-th-fgd-4">
{abbreviateAddress(selectedMarginAccount?.publicKey)}
</div>
</div>
}
onChange={handleSelectMarginAccount}
placeholder="Select Margin Account"
className={className}
>
{marginAccounts.length ? (
marginAccounts.map((ma, index) => (
<Select.Option key={index} value={ma.publicKey.toString()}>
BTC/ETH/USDT
<div className="text-xs text-th-fgd-4">
{abbreviateAddress(ma.publicKey)}
</div>
</Select.Option>
))
) : (
<Select.Option value className="text-th-fgd-4">
No Margin Accounts Found
</Select.Option>
)}
</Select>
)
}
export default MarginAccountSelect