"use client"; import { AdminCard } from "@/components/admin/AdminCard"; import { useClientConfig } from "@/lib/clientConfig"; import { useTranslation } from "@/lib/i18n/client"; import { api } from "@/lib/trpc"; import { useQuery } from "@tanstack/react-query"; const REPO_LATEST_RELEASE_API = "https://api.github.com/repos/karakeep-app/karakeep/releases/latest"; const REPO_RELEASE_PAGE = "https://github.com/karakeep-app/karakeep/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 = ( // oxlint-disable-next-line no-html-link-for-pages ({latestRelease} ⬆️) ); } return (
{currentRelease} {newRelease}
); } function StatsSkeleton() { return (
{[1, 2, 3].map((i) => (
))}
); } export default function BasicStats() { const { t } = useTranslation(); const { data: serverStats } = api.admin.stats.useQuery(undefined, { refetchInterval: 5000, }); 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")}
); }