mirror of
https://github.com/massbug/judge4c.git
synced 2025-05-18 23:56:33 +00:00
feat(problemset): add page to display published problems in a table
This commit is contained in:
parent
0e8639212e
commit
134046ff5a
40
src/app/(app)/problemset/page.tsx
Normal file
40
src/app/(app)/problemset/page.tsx
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
import {
|
||||||
|
Table,
|
||||||
|
TableBody,
|
||||||
|
TableCell,
|
||||||
|
TableHead,
|
||||||
|
TableHeader,
|
||||||
|
TableRow,
|
||||||
|
} from "@/components/ui/table";
|
||||||
|
import prisma from "@/lib/prisma";
|
||||||
|
|
||||||
|
export default async function ProblemsetPage() {
|
||||||
|
const problems = await prisma.problem.findMany({
|
||||||
|
where: { published: true },
|
||||||
|
});
|
||||||
|
|
||||||
|
return (
|
||||||
|
<Table>
|
||||||
|
<TableHeader className="bg-transparent">
|
||||||
|
<TableRow className="hover:bg-transparent">
|
||||||
|
<TableHead className="w-1/3">Id</TableHead>
|
||||||
|
<TableHead className="w-1/3">Title</TableHead>
|
||||||
|
<TableHead className="w-1/3">Difficulty</TableHead>
|
||||||
|
</TableRow>
|
||||||
|
</TableHeader>
|
||||||
|
<tbody aria-hidden="true" className="table-row h-2"></tbody>
|
||||||
|
<TableBody className="[&_td:first-child]:rounded-l-lg [&_td:last-child]:rounded-r-lg">
|
||||||
|
{problems.map((problem) => (
|
||||||
|
<TableRow
|
||||||
|
key={problem.id}
|
||||||
|
className="odd:bg-muted/50 odd:hover:bg-muted/50 border-none hover:bg-transparent"
|
||||||
|
>
|
||||||
|
<TableCell className="py-2.5">{problem.id}</TableCell>
|
||||||
|
<TableCell className="py-2.5">{problem.title}</TableCell>
|
||||||
|
<TableCell className="py-2.5">{problem.difficulty}</TableCell>
|
||||||
|
</TableRow>
|
||||||
|
))}
|
||||||
|
</TableBody>
|
||||||
|
</Table>
|
||||||
|
);
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user