import { Decimal } from "@cosmjs/math"; import { assert } from "@cosmjs/utils"; import { useEffect, useState } from "react"; import { MsgGetter } from ".."; import { useAppContext } from "../../../../context/AppContext"; import { checkAddress, exampleAddress } from "../../../../lib/displayHelpers"; import { isTxMsgRedelegate } from "../../../../lib/txMsgHelpers"; import { TxMsg, TxMsgRedelegate } from "../../../../types/txMsg"; import Input from "../../../inputs/Input"; import StackableContainer from "../../../layout/StackableContainer"; interface MsgRedelegateFormProps { readonly delegatorAddress: string; readonly setMsgGetter: (msgGetter: MsgGetter) => void; readonly deleteMsg: () => void; } const MsgRedelegateForm = ({ delegatorAddress, setMsgGetter, deleteMsg, }: MsgRedelegateFormProps) => { const { state } = useAppContext(); assert(state.chain.addressPrefix, "addressPrefix missing"); const [validatorSrcAddress, setValidatorSrcAddress] = useState(""); const [validatorDstAddress, setValidatorDstAddress] = useState(""); const [amount, setAmount] = useState("0"); const [validatorSrcAddressError, setValidatorSrcAddressError] = useState(""); const [validatorDstAddressError, setValidatorDstAddressError] = useState(""); const [amountError, setAmountError] = useState(""); useEffect(() => { try { assert(state.chain.denom, "denom missing"); setValidatorSrcAddressError(""); setValidatorDstAddressError(""); setAmountError(""); const isMsgValid = (msg: TxMsg): msg is TxMsgRedelegate => { assert(state.chain.addressPrefix, "addressPrefix missing"); const srcAddressErrorMsg = checkAddress(validatorSrcAddress, state.chain.addressPrefix); if (srcAddressErrorMsg) { setValidatorSrcAddressError( `Invalid address for network ${state.chain.chainId}: ${srcAddressErrorMsg}`, ); return false; } const dstAddressErrorMsg = checkAddress(validatorDstAddress, state.chain.addressPrefix); if (dstAddressErrorMsg) { setValidatorDstAddressError( `Invalid address for network ${state.chain.chainId}: ${dstAddressErrorMsg}`, ); return false; } if (!amount || Number(amount) <= 0) { setAmountError("Amount must be greater than 0"); return false; } return isTxMsgRedelegate(msg); }; const amountInAtomics = Decimal.fromUserInput( amount || "0", Number(state.chain.displayDenomExponent), ).atomics; const msg: TxMsgRedelegate = { typeUrl: "/cosmos.staking.v1beta1.MsgBeginRedelegate", value: { delegatorAddress, validatorSrcAddress, validatorDstAddress, amount: { amount: amountInAtomics, denom: state.chain.denom }, }, }; setMsgGetter({ isMsgValid, msg }); } catch {} }, [ amount, delegatorAddress, setMsgGetter, state.chain.addressPrefix, state.chain.chainId, state.chain.denom, state.chain.displayDenomExponent, validatorDstAddress, validatorSrcAddress, ]); return (

MsgBeginRedelegate

setValidatorSrcAddress(target.value)} error={validatorSrcAddressError} placeholder={`E.g. ${exampleAddress(0, state.chain.addressPrefix)}`} />
setValidatorDstAddress(target.value)} error={validatorDstAddressError} placeholder={`E.g. ${exampleAddress(0, state.chain.addressPrefix)}`} />
setAmount(target.value)} error={amountError} />
); }; export default MsgRedelegateForm;