diff --git a/tools/tenscan/frontend/api/general.ts b/tools/tenscan/frontend/api/general.ts index 88324a5255..07c2aec2e3 100644 --- a/tools/tenscan/frontend/api/general.ts +++ b/tools/tenscan/frontend/api/general.ts @@ -4,9 +4,9 @@ import { pathToUrl } from "@/src/routes/router"; import { apiRoutes } from "@/src/routes"; export const fetchTestnetStatus = async (): Promise< - ResponseDataInterface + ResponseDataInterface > => { - return await httpRequest>({ + return await httpRequest>({ method: "post", url: pathToUrl(apiRoutes.getHealthStatus), data: { jsonrpc: "2.0", method: "obscuro_health", params: [], id: 1 }, diff --git a/tools/tenscan/frontend/src/components/health-indicator.tsx b/tools/tenscan/frontend/src/components/health-indicator.tsx index 532049146c..4dd21804cd 100644 --- a/tools/tenscan/frontend/src/components/health-indicator.tsx +++ b/tools/tenscan/frontend/src/components/health-indicator.tsx @@ -3,19 +3,31 @@ import { Badge, badgeVariants } from "./ui/badge"; import { useGeneralService } from "../services/useGeneralService"; const HealthIndicator = () => { + const [status, setStatus] = React.useState(false); const { testnetStatus } = useGeneralService(); + // if testnetStatus.result is true, status is set to true + // if testnetStatus.result is false but testnetStatus.error includes [p2p], status is set to true + + React.useEffect(() => { + if (testnetStatus?.result) { + setStatus(true); + } else if (testnetStatus?.errors?.includes("[p2p]")) { + setStatus(true); + } else { + setStatus(false); + } + }, [testnetStatus]); + return (

Testnet Status:

- {testnetStatus?.result ? "Live" : "Down"} + {status ? "Live" : "Down"}
); diff --git a/tools/tenscan/frontend/src/services/useGeneralService.ts b/tools/tenscan/frontend/src/services/useGeneralService.ts index f82c686456..148989d10d 100644 --- a/tools/tenscan/frontend/src/services/useGeneralService.ts +++ b/tools/tenscan/frontend/src/services/useGeneralService.ts @@ -3,17 +3,11 @@ import { useQuery } from "@tanstack/react-query"; import { useState } from "react"; export const useGeneralService = () => { - const [noPolling, setNoPolling] = useState(false); - - const { - data: testnetStatus, - isLoading: isStatusLoading, - refetch: refetchTestnetStatus, - } = useQuery({ + const { data: testnetStatus, isLoading: isStatusLoading } = useQuery({ queryKey: ["testnetStatus"], queryFn: () => fetchTestnetStatus(), - // refetchInterval: noPolling ? false : pollingInterval, + refetchInterval: 10000, }); - return { testnetStatus, isStatusLoading, setNoPolling, refetchTestnetStatus }; + return { testnetStatus, isStatusLoading }; }; diff --git a/tools/tenscan/frontend/src/types/interfaces/index.ts b/tools/tenscan/frontend/src/types/interfaces/index.ts index 5f626114df..923786fedc 100644 --- a/tools/tenscan/frontend/src/types/interfaces/index.ts +++ b/tools/tenscan/frontend/src/types/interfaces/index.ts @@ -57,6 +57,7 @@ export interface PaginationInterface { export interface ResponseDataInterface { result: T; + errors?: string[] | string; item: T; message: string; pagination?: PaginationInterface; diff --git a/tools/walletextension/frontend/src/components/health-indicator.tsx b/tools/walletextension/frontend/src/components/health-indicator.tsx index 8242ca8fee..772be3e006 100644 --- a/tools/walletextension/frontend/src/components/health-indicator.tsx +++ b/tools/walletextension/frontend/src/components/health-indicator.tsx @@ -12,6 +12,7 @@ const HealthIndicator = () => { setLoading(true); try { const status = await getTestnetStatus(); + return status; } catch (error) { console.error(error); @@ -20,18 +21,26 @@ const HealthIndicator = () => { } }; - // using useRef to avoid memory leak - let isMounted = React.useRef(true); - useEffect(() => { + let isMounted = true; + + // if overall health is true, status is set to true + // if overall health is false but if the error includes [p2p], status is set to true + testnetStatus().then((res) => { - if (isMounted.current) { - setStatus(res?.result); + if (isMounted) { + if (res?.result?.OverallHealth) { + setStatus(true); + } else if (res?.result?.Errors?.includes("[p2p]")) { + setStatus(true); + } else { + setStatus(false); + } } }); return () => { - isMounted.current = false; + isMounted = false; }; // eslint-disable-next-line react-hooks/exhaustive-deps }, []);