fumadocs-ui
Version:
The Radix UI version of Fumadocs UI
68 lines (66 loc) • 3.08 kB
JavaScript
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