From fd7c52b1d38d7ca29686f6a59db5a6f14205731e Mon Sep 17 00:00:00 2001 From: Ross Bulat Date: Thu, 7 Nov 2024 13:08:19 +0700 Subject: [PATCH] feat(fix): Render timeleft on `end` time update (#2320) --- src/hooks/useEraTimeLeft/index.tsx | 2 +- src/pages/Overview/Stats/ActiveEraTimeLeft.tsx | 7 ++++--- 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/src/hooks/useEraTimeLeft/index.tsx b/src/hooks/useEraTimeLeft/index.tsx index d4993b483c..b29ddafd60 100644 --- a/src/hooks/useEraTimeLeft/index.tsx +++ b/src/hooks/useEraTimeLeft/index.tsx @@ -37,7 +37,7 @@ export const useEraTimeLeft = () => { ? new BigNumber(0) : new BigNumber(100).minus(percentRemaining); - return { timeleft, percentSurpassed, percentRemaining }; + return { timeleft, end, percentSurpassed, percentRemaining }; }; return { get }; diff --git a/src/pages/Overview/Stats/ActiveEraTimeLeft.tsx b/src/pages/Overview/Stats/ActiveEraTimeLeft.tsx index acf807d5f3..1e7b36f2e6 100644 --- a/src/pages/Overview/Stats/ActiveEraTimeLeft.tsx +++ b/src/pages/Overview/Stats/ActiveEraTimeLeft.tsx @@ -17,16 +17,17 @@ export const ActiveEraStat = () => { const { get: getEraTimeleft } = useEraTimeLeft(); const { timeleft, setFromNow } = useTimeLeft(); + const timeleftResult = getEraTimeleft(); const dateFrom = fromUnixTime(Date.now() / 1000); - const dateTo = fromNow(getEraTimeleft().timeleft.toNumber()); + const dateTo = fromNow(timeleftResult.timeleft.toNumber()); // re-set timer on era change (also covers network change). useEffect(() => { setFromNow(dateFrom, dateTo); - }, [activeEra]); + }, [activeEra, timeleftResult.end.toString()]); // NOTE: this maybe should be called in an interval. Needs more testing. - const { percentSurpassed, percentRemaining } = getEraTimeleft(); + const { percentSurpassed, percentRemaining } = timeleftResult; const params = { label: t('overview.timeRemainingThisEra'),