import { MsgWithdrawDelegatorRewardEncodeObject } 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 MsgClaimRewardsFormProps { readonly delegatorAddress: string; readonly setMsgGetter: (msgGetter: MsgGetter) => void; readonly deleteMsg: () => void; } const MsgClaimRewardsForm = ({ delegatorAddress, setMsgGetter, deleteMsg, }: MsgClaimRewardsFormProps) => { const { chain } = useChains(); const [validatorAddress, setValidatorAddress] = useState(""); const [validatorAddressError, setValidatorAddressError] = useState(""); useEffect(() => { try { setValidatorAddressError(""); const isMsgValid = (): boolean => { const addressErrorMsg = checkAddress(validatorAddress, chain.addressPrefix); if (addressErrorMsg) { setValidatorAddressError( `Invalid address for network ${chain.chainId}: ${addressErrorMsg}`, ); return false; } return true; }; const msgValue = MsgCodecs[MsgTypeUrls.WithdrawDelegatorReward].fromPartial({ delegatorAddress, validatorAddress, }); const msg: MsgWithdrawDelegatorRewardEncodeObject = { typeUrl: MsgTypeUrls.WithdrawDelegatorReward, value: msgValue, }; setMsgGetter({ isMsgValid, msg }); } catch {} }, [chain.addressPrefix, chain.chainId, delegatorAddress, setMsgGetter, validatorAddress]); return (

MsgWithdrawDelegatorReward

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