import React from 'react'; import { useAppState } from '../../contexts/app-state/app-state-context'; import { useContracts } from '../../contexts/contracts/contracts-context'; import { useGetUserTrancheBalances } from '../../hooks/use-get-user-tranche-balances'; import { useRefreshBalances } from '../../hooks/use-refresh-balances'; import { useSearchParams } from '../../hooks/use-search-params'; import { ClaimError } from './claim-error'; import { ClaimFlow } from './claim-flow'; import { ClaimActionType, claimReducer, ClaimStatus, initialClaimState, } from './claim-reducer'; import type { Tranche } from '@vegaprotocol/smart-contracts'; const Claim = ({ address, tranches, }: { address: string; tranches: Tranche[]; }) => { const params = useSearchParams(); const { vesting } = useContracts(); const { appState } = useAppState(); const [state, dispatch] = React.useReducer(claimReducer, initialClaimState); const getUserTrancheBalances = useGetUserTrancheBalances(address, vesting); const refreshBalances = useRefreshBalances(address); React.useEffect(() => { dispatch({ type: ClaimActionType.SET_DATA_FROM_URL, decimals: appState.decimals, data: { amount: params.amount, trancheId: params.tranche, expiry: params.expiry, s: params.s, r: params.r, v: params.v, target: params.target, }, }); }, [appState.decimals, dispatch, params]); // If the claim has been committed refetch the new VEGA balance React.useEffect(() => { if (state.claimStatus === ClaimStatus.Finished && address) { getUserTrancheBalances(); refreshBalances(); } }, [address, getUserTrancheBalances, refreshBalances, state.claimStatus]); if (state.error) { return ; } if (state.claimData?.signature.s) { return ( ); } return null; }; export default Claim;