import { MangoAccount } from '@blockworks-foundation/mango-client' import { useEffect, useState } from 'react' import useMangoStore from '../stores/useMangoStore' import Select from './Select' import { abbreviateAddress } from '../utils' type MangoAccountSelectProps = { className?: string onChange?: (x) => void value?: MangoAccount | null disabled?: boolean } const MangoAccountSelect = ({ onChange, value, disabled = false, className = '', }: MangoAccountSelectProps) => { const mangoAccounts = useMangoStore((s) => s.mangoAccounts) const [selectedMangoAccount, setSelectedMangoAccount] = useState( value || mangoAccounts[0] ) useEffect(() => { if (value) { setSelectedMangoAccount(value) } }, [value]) const handleSelectMangoAccount = (value) => { const mangoAccount = mangoAccounts.find( (ma) => ma.publicKey.toString() === value ) setSelectedMangoAccount(mangoAccount) if (onChange) { onChange(mangoAccount) } } return ( ) } export default MangoAccountSelect