"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://api.github.com/repos/hoarder-app/hoarder/releases/latest"; const REPO_RELEASE_PAGE = "https://github.com/hoarder-app/hoarder/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.numBookmarks}
Server Version
Background Jobs
Job Queued Pending Failed Crawling Jobs {serverStats.crawlStats.queued} {serverStats.crawlStats.pending} {serverStats.crawlStats.failed} Indexing Jobs {serverStats.indexingStats.queued} - - Inference Jobs {serverStats.inferenceStats.queued} {serverStats.inferenceStats.pending} {serverStats.inferenceStats.failed} Tidy Assets Jobs {serverStats.tidyAssetsStats.queued} - -
); }