mirror of
https://github.com/massbug/judge4c.git
synced 2025-05-18 15:26:33 +00:00
40 lines
1.0 KiB
TypeScript
40 lines
1.0 KiB
TypeScript
import prisma from "@/lib/prisma";
|
|
import { notFound } from "next/navigation";
|
|
import { MdxRenderer } from "@/components/content/mdx-renderer";
|
|
import { ScrollArea, ScrollBar } from "@/components/ui/scroll-area";
|
|
import ProblemDescriptionFooter from "@/features/playground/problem/description/footer";
|
|
|
|
interface ProblemDescriptionPageProps {
|
|
params: Promise<{ id: string }>
|
|
}
|
|
|
|
export default async function ProblemDescriptionPage({
|
|
params
|
|
}: ProblemDescriptionPageProps) {
|
|
const { id } = await params;
|
|
|
|
const problem = await prisma.problem.findUnique({
|
|
where: { id },
|
|
select: {
|
|
title: true,
|
|
description: true,
|
|
}
|
|
});
|
|
|
|
if (!problem) {
|
|
notFound();
|
|
}
|
|
|
|
return (
|
|
<>
|
|
<div className="flex-1">
|
|
<ScrollArea className="[&>[data-radix-scroll-area-viewport]]:max-h-[calc(100vh-130px)]">
|
|
<MdxRenderer source={problem.description} />
|
|
<ScrollBar orientation="horizontal" />
|
|
</ScrollArea>
|
|
</div>
|
|
<ProblemDescriptionFooter title={problem.title} />
|
|
</>
|
|
);
|
|
}
|