diff --git a/src/modules/rewards/components/StakePushActivitiesListItem.tsx b/src/modules/rewards/components/StakePushActivitiesListItem.tsx index c0c49f90a8..6c05fe14b7 100644 --- a/src/modules/rewards/components/StakePushActivitiesListItem.tsx +++ b/src/modules/rewards/components/StakePushActivitiesListItem.tsx @@ -16,6 +16,7 @@ export type StakeActivitiesItemProps = { isLoadingItem: boolean; setErrorMessage: (errorMessage: string) => void; isLocked: boolean; + hasEpochEnded?: boolean; }; const StakePushActivitiesListItem: FC = ({ userId, @@ -23,6 +24,7 @@ const StakePushActivitiesListItem: FC = ({ isLoadingItem, setErrorMessage, isLocked, + hasEpochEnded, }) => { const { data: usersSingleActivity, @@ -32,6 +34,8 @@ const StakePushActivitiesListItem: FC = ({ const { isWalletConnected } = useAccount(); + const hasActivityEndedUnclaimed = usersSingleActivity?.status !== 'COMPLETED' && hasEpochEnded; + const isLockedOrNotConnected = isLocked || !isWalletConnected; return ( = ({ )} - {!isLocked && isWalletConnected && ( + {hasActivityEndedUnclaimed && !isLocked && isWalletConnected && ( + + )} + + {!hasActivityEndedUnclaimed && !isLocked && isWalletConnected && ( = ({ title, subtitle, timeline, mult const activityResetDate = daysToReset + 7; const isEpochStatusActive = useMemo(() => { - return daysToReset != null && !multiplier && daysToReset >= 0 && activityResetDate > 7; - }, [daysToReset, multiplier, activityResetDate]); + return daysToReset != null && !multiplier && daysToReset >= 0 && activityResetDate > 7 && isWalletConnected; + }, [daysToReset, multiplier, activityResetDate, isWalletConnected]); const hasEpochEnded = useMemo(() => { - return daysToReset != null && activityResetDate >= 0 && activityResetDate <= 7 && !multiplier; - }, [daysToReset, activityResetDate, multiplier]); + return daysToReset != null && activityResetDate >= 0 && activityResetDate <= 7 && !multiplier && isWalletConnected; + }, [daysToReset, activityResetDate, multiplier, isWalletConnected]); return ( = ({ title, subtitle, timeline, mult isLoadingItem={isLoading} setErrorMessage={setErrorMessage} isLocked={isLocked} + hasEpochEnded={hasEpochEnded} /> ))} @@ -182,6 +183,7 @@ const StakePushSection: FC = ({ title, subtitle, timeline, mult isLoadingItem={isLoading} setErrorMessage={setErrorMessage} isLocked={isLocked} + hasEpochEnded={hasEpochEnded} /> ))} diff --git a/src/modules/rewards/hooks/useStakeRewardsResetTime.tsx b/src/modules/rewards/hooks/useStakeRewardsResetTime.tsx index 489c41471c..bef46eda6c 100644 --- a/src/modules/rewards/hooks/useStakeRewardsResetTime.tsx +++ b/src/modules/rewards/hooks/useStakeRewardsResetTime.tsx @@ -76,7 +76,7 @@ const useStakeRewardsResetTime = ({ multiplier }: StakeRewardsResetTime) => { const daysToReset = useMemo(() => { const currentTime = Date.now() / 1000; // Current time in seconds const differenceInSeconds = (resetDate as number) - currentTime; - return Math.floor(differenceInSeconds / (60 * 60 * 24)); // Convert seconds to days and add the 7 days rest period + return Math.floor(differenceInSeconds / (60 * 60 * 24)); }, [resetDate]); // Helper function to check if 7 days have passed since the stored epoch time (in seconds)