"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 (
{currentRelease} {/* {newRelease} */}
); } export default function ServerStats() { const { data: serverStats } = api.admin.stats.useQuery(undefined, { refetchInterval: 1000, placeholderData: keepPreviousData, }); if (!serverStats) { return ; } return ( <>
Server Stats
Total Users
{serverStats.numUsers}
Total Bookmarks
{serverStats.numEntries}
Server Version
Background Jobs
Job Queued Pending Failed No workers yet...
); }