import SelectValidator from "@/components/SelectValidator"; import { MsgWithdrawDelegatorRewardEncodeObject } from "@cosmjs/stargate"; import { useEffect, useState } from "react"; import { MsgGetter } from ".."; import { useChains } from "../../../../context/ChainsContext"; import { checkAddress, exampleAddress, trimStringsObj } 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(""); const trimmedInputs = trimStringsObj({ validatorAddress }); useEffect(() => { // eslint-disable-next-line no-shadow const { validatorAddress } = trimmedInputs; const isMsgValid = (): boolean => { setValidatorAddressError(""); 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 }); }, [chain.addressPrefix, chain.chainId, delegatorAddress, setMsgGetter, trimmedInputs]); return (

MsgWithdrawDelegatorReward

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