73 lines
2.0 KiB
TypeScript
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
|