"use client"; import LoadingSpinner from "@/components/ui/spinner"; import { Table, TableBody, TableCell, TableHead, TableHeader, TableRow, } from "@/components/ui/table"; import { useClientConfig } from "@/lib/clientConfig"; import { api } from "@/lib/trpc"; import { keepPreviousData, useQuery } from "@tanstack/react-query"; const REPO_LATEST_RELEASE_API = "https://git.ryanpandya.com/repos/ryan/lifetracker/releases/latest"; const REPO_RELEASE_PAGE = "https://git.ryanpandya.com/ryan/lifetracker/releases"; function useLatestRelease() { const { data } = useQuery({ queryKey: ["latest-release"], queryFn: async () => { const res = await fetch(REPO_LATEST_RELEASE_API); if (!res.ok) { return undefined; } const data = (await res.json()) as { name: string }; return data.name; }, staleTime: 60 * 60 * 1000, enabled: !useClientConfig().disableNewReleaseCheck, }); return data; } function ReleaseInfo() { const currentRelease = useClientConfig().serverVersion ?? "NA"; const latestRelease = useLatestRelease(); let newRelease; if (latestRelease && currentRelease != latestRelease) { newRelease = ( ({latestRelease} ⬆️) ); } return (