import { FunctionComponent, useState } from 'react' import useMangoStore from '../stores/useMangoStore' import { ExclamationCircleIcon, InformationCircleIcon, } from '@heroicons/react/outline' import Input from './Input' import Button from './Button' import Modal from './Modal' import { ElementTitle } from './styles' import Tooltip from './Tooltip' import { notify } from '../utils/notifications' interface AccountNameModalProps { accountName?: string isOpen: boolean onClose?: (x?) => void } const AccountNameModal: FunctionComponent = ({ accountName, isOpen, onClose, }) => { const [name, setName] = useState(accountName || '') const [invalidNameMessage, setInvalidNameMessage] = useState('') const mangoGroup = useMangoStore((s) => s.selectedMangoGroup.current) const mangoAccount = useMangoStore((s) => s.selectedMangoAccount.current) const mangoClient = useMangoStore((s) => s.connection.client) const actions = useMangoStore((s) => s.actions) const submitName = async () => { const wallet = useMangoStore.getState().wallet.current try { const txid = await mangoClient.addMangoAccountInfo( mangoGroup, mangoAccount, wallet, name ) actions.fetchMangoAccounts() onClose() notify({ title: 'Account name updated', txid, }) } catch (err) { console.warn('Error setting account name:', err) notify({ title: 'Could not set account name', description: `${err}`, txid: err.txid, type: 'error', }) } } const validateNameInput = () => { if (name.length >= 33) { setInvalidNameMessage('Account name must be 32 characters or less') } if (name.length === 0) { setInvalidNameMessage('Enter an account name') } } const onChangeNameInput = (name) => { setName(name) if (invalidNameMessage) { setInvalidNameMessage('') } } return (
Name your Account
Edit the public nickname for your account
Account Name
onChangeNameInput(e.target.value)} /> {invalidNameMessage ? (
{invalidNameMessage}
) : null}
) } export default AccountNameModal