UNPKG

fumadocs-ui

Version:

The Radix UI version of Fumadocs UI

68 lines (66 loc) 3.08 kB
import { cn } from "@fumadocs/ui/cn"; import { jsx, jsxs } from "react/jsx-runtime"; import { Star } from "lucide-react"; //#region src/components/github-info.tsx async function getRepoStarsAndForks(owner, repo, token, baseUrl = "https://api.github.com") { const endpoint = `${baseUrl}/repos/${owner}/${repo}`; const headers = new Headers({ "Content-Type": "application/json" }); if (token) headers.set("Authorization", `Bearer ${token}`); const response = await fetch(endpoint, { headers, next: { revalidate: 60 } }); if (!response.ok) { const message = await response.text(); throw new Error(`Failed to fetch repository data: ${message}`); } const data = await response.json(); return { stars: data.stargazers_count, forks: data.forks_count }; } async function GithubInfo({ repo, owner, token, baseUrl, ...props }) { const { stars } = await getRepoStarsAndForks(owner, repo, token, baseUrl); const humanizedStars = humanizeNumber(stars); return /* @__PURE__ */ jsxs("a", { href: `https://github.com/${owner}/${repo}`, rel: "noreferrer noopener", target: "_blank", ...props, className: cn("flex flex-col gap-1.5 p-2 rounded-lg text-sm text-fd-foreground/80 transition-colors lg:flex-row lg:items-center hover:text-fd-accent-foreground hover:bg-fd-accent", props.className), children: [/* @__PURE__ */ jsxs("p", { className: "flex items-center gap-2 truncate", children: [ /* @__PURE__ */ jsxs("svg", { fill: "currentColor", viewBox: "0 0 24 24", className: "size-3.5", children: [/* @__PURE__ */ jsx("title", { children: "GitHub" }), /* @__PURE__ */ jsx("path", { d: "M12 .297c-6.63 0-12 5.373-12 12 0 5.303 3.438 9.8 8.205 11.385.6.113.82-.258.82-.577 0-.285-.01-1.04-.015-2.04-3.338.724-4.042-1.61-4.042-1.61C4.422 18.07 3.633 17.7 3.633 17.7c-1.087-.744.084-.729.084-.729 1.205.084 1.838 1.236 1.838 1.236 1.07 1.835 2.809 1.305 3.495.998.108-.776.417-1.305.76-1.605-2.665-.3-5.466-1.332-5.466-5.93 0-1.31.465-2.38 1.235-3.22-.135-.303-.54-1.523.105-3.176 0 0 1.005-.322 3.3 1.23.96-.267 1.98-.399 3-.405 1.02.006 2.04.138 3 .405 2.28-1.552 3.285-1.23 3.285-1.23.645 1.653.24 2.873.12 3.176.765.84 1.23 1.91 1.23 3.22 0 4.61-2.805 5.625-5.475 5.92.42.36.81 1.096.81 2.22 0 1.606-.015 2.896-.015 3.286 0 .315.21.69.825.57C20.565 22.092 24 17.592 24 12.297c0-6.627-5.373-12-12-12" })] }), owner, "/", repo ] }), /* @__PURE__ */ jsxs("p", { className: "flex text-xs items-center gap-1 text-fd-muted-foreground", children: [/* @__PURE__ */ jsx(Star, { className: "size-3" }), humanizedStars] })] }); } /** * Converts a number to a human-readable string with K suffix for thousands * @example 1500 -> "1.5K", 1000000 -> "1000000" */ function humanizeNumber(num) { if (num < 1e3) return num.toString(); if (num < 1e5) { const value = (num / 1e3).toFixed(1); return `${value.endsWith(".0") ? value.slice(0, -2) : value}K`; } if (num < 1e6) return `${Math.floor(num / 1e3)}K`; return num.toString(); } //#endregion export { GithubInfo }; //# sourceMappingURL=github-info.js.map