import type { JSX } from "react" import { getTeacherClasses } from "@/modules/classes/data-access" import { getClassAttendanceStats } from "@/modules/attendance/data-access-stats" import { AttendanceStatsCard } from "@/modules/attendance/components/attendance-stats-card" import { AttendanceRecordList } from "@/modules/attendance/components/attendance-record-list" import { AttendanceStatsClassSelector } from "@/modules/attendance/components/attendance-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 AttendanceStatsPage({ searchParams, }: { searchParams: Promise }): Promise { const sp = await searchParams const classId = getParam(sp, "classId") const startDate = getParam(sp, "startDate") const endDate = getParam(sp, "endDate") const classes = await getTeacherClasses() if (classes.length === 0) { return (

Attendance Statistics

View class attendance statistics.

) } const targetClassId = classId ?? classes[0].id const summary = await getClassAttendanceStats( targetClassId, startDate, endDate ) const classOptions = classes.map((c) => ({ id: c.id, name: c.name })) return (

Attendance Statistics

View class attendance statistics and trends.

{summary ? ( <>

Student Records

) : ( )}
) }