Files
edubox/server/app/dashboard/page.tsx
2026-06-06 19:55:41 +00:00

73 lines
2.8 KiB
TypeScript

import { prisma } from "@/lib/prisma";
import { getServerSession } from "next-auth/next";
import { authOptions } from "@/lib/auth-config";
import { redirect } from "next/navigation";
import { Card, CardHeader, CardTitle, CardContent } from "@/components/ui/card";
import { Badge } from "@/components/ui/badge";
export const dynamic = "force-dynamic";
export default async function DashboardPage() {
const session = await getServerSession(authOptions);
if (!session?.user) redirect("/login");
const isSuperadmin = session.user.role === "superadmin";
const establishmentId = session.user.establishmentId;
const where = isSuperadmin ? {} : { establishmentId };
const nodesCount = await prisma.node.count({
where: isSuperadmin ? {} : { student: { class: { establishmentId } } },
});
const onlineNodes = await prisma.node.count({
where: isSuperadmin ? { status: "online" } : { status: "online", student: { class: { establishmentId } } },
});
const instancesRunning = await prisma.instance.count({
where: isSuperadmin ? { status: "running" } : { status: "running", node: { student: { class: { establishmentId } } } },
});
const studentsCount = await prisma.student.count({
where: isSuperadmin ? {} : { class: { establishmentId } },
});
return (
<div className="space-y-6">
<h1 className="text-3xl font-bold">Tableau de bord</h1>
<div className="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-4 gap-4">
<Card>
<CardHeader className="pb-2">
<CardTitle className="text-sm font-medium text-muted-foreground">Nœuds</CardTitle>
</CardHeader>
<CardContent>
<div className="text-3xl font-bold">{nodesCount}</div>
<Badge variant="success" className="mt-2">{onlineNodes} en ligne</Badge>
</CardContent>
</Card>
<Card>
<CardHeader className="pb-2">
<CardTitle className="text-sm font-medium text-muted-foreground">Instances actives</CardTitle>
</CardHeader>
<CardContent>
<div className="text-3xl font-bold">{instancesRunning}</div>
</CardContent>
</Card>
<Card>
<CardHeader className="pb-2">
<CardTitle className="text-sm font-medium text-muted-foreground">Étudiants</CardTitle>
</CardHeader>
<CardContent>
<div className="text-3xl font-bold">{studentsCount}</div>
</CardContent>
</Card>
<Card>
<CardHeader className="pb-2">
<CardTitle className="text-sm font-medium text-muted-foreground">Statut</CardTitle>
</CardHeader>
<CardContent>
<Badge variant="success">Opérationnel</Badge>
</CardContent>
</Card>
</div>
</div>
);
}