109 lines
2.9 KiB
TypeScript
109 lines
2.9 KiB
TypeScript
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: (
|
|
<>
|
|
<ToastHeading>{t('Referral code no longer valid')}</ToastHeading>
|
|
<p>
|
|
{t(
|
|
'Your referral code is no longer valid as the referrer no longer meets the minimum requirements.'
|
|
)}
|
|
</p>
|
|
<p className="mt-2">
|
|
<Button
|
|
data-testid="toast-apply-code"
|
|
size="xs"
|
|
onClick={() => {
|
|
const matched = matchPath(Routes.REFERRALS, pathname);
|
|
if (!matched) navigate(Routes.REFERRALS_APPLY_CODE);
|
|
updateToast(NON_ELIGIBLE_REFERRAL_SET_TOAST_ID + epoch, {
|
|
hidden: true,
|
|
});
|
|
}}
|
|
>
|
|
{t('Apply a new code')}
|
|
</Button>
|
|
</p>
|
|
</>
|
|
),
|
|
onClose: () =>
|
|
updateToast(NON_ELIGIBLE_REFERRAL_SET_TOAST_ID + epoch, {
|
|
hidden: true,
|
|
}),
|
|
};
|
|
setToast(nonEligibleReferralToast);
|
|
}
|
|
}, [
|
|
data,
|
|
epoch,
|
|
hasToast,
|
|
loading,
|
|
navigate,
|
|
pathname,
|
|
setToast,
|
|
t,
|
|
updateToast,
|
|
]);
|
|
};
|