sourcebot/src/app/repos/page.tsx

50 lines
1.7 KiB
TypeScript
Raw Normal View History

2024-09-11 05:23:40 +00:00
"use server";
2024-09-11 04:55:00 +00:00
import { NavigationMenu } from "../navigationMenu";
import { DataTable } from "@/components/ui/data-table";
import { columns, RepositoryColumnInfo } from "./columns";
import { listRepositories } from "@/lib/server/searchService";
import { isServiceError } from "@/lib/utils";
2024-09-11 05:23:40 +00:00
import { Suspense } from "react";
2024-09-11 04:55:00 +00:00
export default async function ReposPage() {
const _repos = await listRepositories();
if (isServiceError(_repos)) {
return <div>Error fetching repositories</div>;
}
const repos = _repos.List.Repos.map((repo): RepositoryColumnInfo => {
return {
name: repo.Repository.Name,
branches: repo.Repository.Branches.map((branch) => {
return {
name: branch.Name,
version: branch.Version,
}
}),
repoSizeBytes: repo.Stats.ContentBytes,
indexSizeBytes: repo.Stats.IndexBytes,
shardCount: repo.Stats.Shards,
lastIndexed: repo.IndexMetadata.IndexTime,
latestCommit: repo.Repository.LatestCommitDate,
indexedFiles: repo.Stats.Documents,
commitUrlTemplate: repo.Repository.CommitURLTemplate,
}
2024-09-11 05:23:40 +00:00
}).sort((a, b) => {
return new Date(b.lastIndexed).getTime() - new Date(a.lastIndexed).getTime();
})
2024-09-11 04:55:00 +00:00
return (
<div className="h-screen flex flex-col items-center">
<NavigationMenu />
2024-09-11 05:23:40 +00:00
<Suspense fallback={<div>Loading...</div>}>
<DataTable
columns={columns}
data={repos}
searchKey="name"
searchPlaceholder="Search repositories..."
/>
</Suspense>
2024-09-11 04:55:00 +00:00
</div>
)
}