import { Decimal } from "@cosmjs/math"; import { MsgUndelegateEncodeObject } from "@cosmjs/stargate"; import { useEffect, useState } from "react"; import { MsgGetter } from ".."; import { useChains } from "../../../../context/ChainsContext"; import { checkAddress, exampleAddress } from "../../../../lib/displayHelpers"; import { MsgCodecs, MsgTypeUrls } from "../../../../types/txMsg"; import Input from "../../../inputs/Input"; import StackableContainer from "../../../layout/StackableContainer"; interface MsgUndelegateFormProps { readonly delegatorAddress: string; readonly setMsgGetter: (msgGetter: MsgGetter) => void; readonly deleteMsg: () => void; } const MsgUndelegateForm = ({ delegatorAddress, setMsgGetter, deleteMsg, }: MsgUndelegateFormProps) => { const { chain } = useChains(); const [validatorAddress, setValidatorAddress] = useState(""); const [amount, setAmount] = useState("0"); const [validatorAddressError, setValidatorAddressError] = useState(""); const [amountError, setAmountError] = useState(""); useEffect(() => { try { setValidatorAddressError(""); setAmountError(""); const isMsgValid = (): boolean => { const addressErrorMsg = checkAddress(validatorAddress, chain.addressPrefix); if (addressErrorMsg) { setValidatorAddressError( `Invalid address for network ${chain.chainId}: ${addressErrorMsg}`, ); return false; } if (!amount || Number(amount) <= 0) { setAmountError("Amount must be greater than 0"); return false; } return true; }; const amountInAtomics = Decimal.fromUserInput( amount || "0", Number(chain.displayDenomExponent), ).atomics; const msgValue = MsgCodecs[MsgTypeUrls.Undelegate].fromPartial({ delegatorAddress, validatorAddress, amount: { amount: amountInAtomics, denom: chain.denom }, }); const msg: MsgUndelegateEncodeObject = { typeUrl: MsgTypeUrls.Undelegate, value: msgValue }; setMsgGetter({ isMsgValid, msg }); } catch {} }, [ amount, chain.addressPrefix, chain.chainId, chain.denom, chain.displayDenomExponent, delegatorAddress, setMsgGetter, validatorAddress, ]); return (

MsgUndelegate

setValidatorAddress(target.value)} error={validatorAddressError} placeholder={`E.g. ${exampleAddress(0, chain.addressPrefix)}`} />
setAmount(target.value)} error={amountError} />
); }; export default MsgUndelegateForm;