"use client"; import LoadingSpinner from "@/components/ui/spinner"; import { useClientConfig } from "@/lib/clientConfig"; import { useTranslation } from "@/lib/i18n/client"; 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 { t } = useTranslation(); const { data: serverStats } = api.admin.stats.useQuery(undefined, { refetchInterval: 5000, placeholderData: keepPreviousData, }); if (!serverStats) { return ; } return (
{t("admin.server_stats.server_stats")}
{t("admin.server_stats.total_users")}
{serverStats.numUsers}
{t("admin.server_stats.total_bookmarks")}
{serverStats.numBookmarks}
{t("admin.server_stats.server_version")}
); }