import { FunctionComponent, useState } from 'react' import useMangoStore from '../stores/useMangoStore' import { ExclamationCircleIcon } from '@heroicons/react/outline' import Input from './Input' import Button from './Button' import Modal from './Modal' import { ElementTitle } from './styles' import { notify } from '../utils/notifications' import { useTranslation } from 'next-i18next' import { PublicKey } from '@solana/web3.js' interface DelegateModalProps { delegate?: PublicKey isOpen: boolean onClose?: (x?) => void } const DelegateModal: FunctionComponent = ({ delegate, isOpen, onClose, }) => { const { t } = useTranslation(['common', 'delegate']) const [keyBase58, setKeyBase58] = useState( delegate.equals(PublicKey.default) ? '' : delegate.toBase58() ) const [invalidKeyMessage, setInvalidKeyMessage] = 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 setDelegate = async () => { const wallet = useMangoStore.getState().wallet.current try { const key = keyBase58.length ? new PublicKey(keyBase58) : PublicKey.default const txid = await mangoClient.setDelegate( mangoGroup, mangoAccount, wallet, key ) actions.reloadMangoAccount() onClose() notify({ title: t('delegate:delegate-updated'), txid, }) } catch (err) { console.warn('Error setting delegate key:', err) notify({ title: t('delegate:set-error'), description: `${err}`, txid: err.txid, type: 'error', }) } } const validateKeyInput = () => { if (keyBase58.length != 44 && keyBase58.length != 0) { setInvalidKeyMessage(t('delegate:invalid-key')) return false } else { setInvalidKeyMessage('') return true } } const onChangeKeyInput = (name) => { setKeyBase58(name) validateKeyInput() } return (
{t('delegate:delegate-your-account')}

{t('delegate:info')}

{t('delegate:public-key')}
onChangeKeyInput(e.target.value)} /> {invalidKeyMessage ? (
{invalidKeyMessage}
) : null}
) } export default DelegateModal