import type { JSX } from "react" import { getTeacherClasses } from "@/modules/classes/data-access" import { getClassGradeStatsWithMeta, getClassRanking } from "@/modules/grades/data-access" import { getSubjectOptions } from "@/modules/school/data-access" import { ClassGradeReport } from "@/modules/grades/components/class-grade-report" import { ExportButton } from "@/modules/grades/components/export-button" import { StatsClassSelector } from "@/modules/grades/components/stats-class-selector" import { EmptyState } from "@/shared/components/ui/empty-state" import { getParam, type SearchParams } from "@/shared/lib/search-params" import { BarChart3 } from "lucide-react" export const dynamic = "force-dynamic" export default async function StatsPage({ searchParams, }: { searchParams: Promise }): Promise { const sp = await searchParams const classId = getParam(sp, "classId") const subjectId = getParam(sp, "subjectId") const [classes, allSubjects] = await Promise.all([ getTeacherClasses(), getSubjectOptions(), ]) if (classes.length === 0) { return (

Grade Statistics

View class grade statistics and rankings.

) } const targetClassId = classId ?? classes[0].id const targetSubjectId = subjectId && subjectId !== "all" ? subjectId : undefined const [stats, ranking] = await Promise.all([ getClassGradeStatsWithMeta(targetClassId, targetSubjectId), getClassRanking(targetClassId, targetSubjectId), ]) const classOptions = classes.map((c) => ({ id: c.id, name: c.name })) const subjectOptions = allSubjects.map((s) => ({ id: s.id, name: s.name })) return (

Grade Statistics

View class grade statistics and rankings.

) }