import { Intent, type Toast, useToasts, ToastHeading, Button, } from '@vegaprotocol/ui-toolkit'; import { useReferral } from './use-referral'; import { useVegaWallet } from '@vegaprotocol/wallet'; import { useEffect } from 'react'; import { useT } from '../../../lib/use-t'; import { matchPath, useLocation, useNavigate } from 'react-router-dom'; import { Routes } from '../../../lib/links'; import { useCurrentEpochInfoQuery } from '../../../lib/hooks/__generated__/Epoch'; const REFETCH_INTERVAL = 60 * 60 * 1000; // 1h const NON_ELIGIBLE_REFERRAL_SET_TOAST_ID = 'non-eligible-referral-set'; const useNonEligibleReferralSet = () => { const { pubKey } = useVegaWallet(); const { data, loading, refetch } = useReferral({ pubKey, role: 'referee' }); const { data: epochData, loading: epochLoading, refetch: epochRefetch, } = useCurrentEpochInfoQuery(); useEffect(() => { const interval = setInterval(() => { refetch(); epochRefetch(); }, REFETCH_INTERVAL); return () => { clearInterval(interval); }; }, [epochRefetch, refetch]); return { data, epoch: epochData?.epoch.id, loading: loading || epochLoading }; }; export const useReferralToasts = () => { const navigate = useNavigate(); const { pathname } = useLocation(); const t = useT(); const [setToast, hasToast, updateToast] = useToasts((store) => [ store.setToast, store.hasToast, store.update, ]); const { data, epoch, loading } = useNonEligibleReferralSet(); useEffect(() => { if ( data && epoch && !loading && !data.isEligible && !hasToast(NON_ELIGIBLE_REFERRAL_SET_TOAST_ID + epoch) ) { const nonEligibleReferralToast: Toast = { id: NON_ELIGIBLE_REFERRAL_SET_TOAST_ID + epoch, intent: Intent.Warning, content: ( <> {t('Referral code no longer valid')}

{t( 'Your referral code is no longer valid as the referrer no longer meets the minimum requirements.' )}

), onClose: () => updateToast(NON_ELIGIBLE_REFERRAL_SET_TOAST_ID + epoch, { hidden: true, }), }; setToast(nonEligibleReferralToast); } }, [ data, epoch, hasToast, loading, navigate, pathname, setToast, t, updateToast, ]); };