import Link from "next/link"
import { Suspense } from "react"
import { BarChart3 } from "lucide-react"
import { getClassHomeworkInsights, getTeacherClasses } from "@/modules/classes/data-access"
import { InsightsFilters } from "@/modules/classes/components/insights-filters"
import { EmptyState } from "@/shared/components/ui/empty-state"
import { Skeleton } from "@/shared/components/ui/skeleton"
import { Badge } from "@/shared/components/ui/badge"
import { Card, CardContent, CardHeader, CardTitle } from "@/shared/components/ui/card"
import { Button } from "@/shared/components/ui/button"
import { Table, TableBody, TableCell, TableHead, TableHeader, TableRow } from "@/shared/components/ui/table"
import { formatDate } from "@/shared/lib/utils"
export const dynamic = "force-dynamic"
type SearchParams = { [key: string]: string | string[] | undefined }
const getParam = (params: SearchParams, key: string) => {
const v = params[key]
return Array.isArray(v) ? v[0] : v
}
const formatNumber = (v: number | null, digits = 1) => {
if (typeof v !== "number" || Number.isNaN(v)) return "-"
return v.toFixed(digits)
}
function InsightsResultsFallback() {
return (
{Array.from({ length: 3 }).map((_, idx) => (
))}
{Array.from({ length: 8 }).map((_, idx) => (
))}
)
}
async function InsightsResults({ searchParams }: { searchParams: Promise }) {
const params = await searchParams
const classId = getParam(params, "classId")
if (!classId || classId === "all") {
return (
)
}
const insights = await getClassHomeworkInsights({ classId, limit: 50 })
if (!insights) {
return (
)
}
const hasAssignments = insights.assignments.length > 0
if (!hasAssignments) {
return (
)
}
const latest = insights.latest
return (
Students
{insights.studentCounts.total}
Active {insights.studentCounts.active} · Inactive {insights.studentCounts.inactive}
Assignments
{insights.assignments.length}
Latest: {latest ? formatDate(latest.createdAt) : "-"}
Overall scores
{formatNumber(insights.overallScores.avg, 1)}
Median {formatNumber(insights.overallScores.median, 1)} · Count {insights.overallScores.count}
{latest && (
Latest assignment
{latest.title}
{latest.status}
·
{formatDate(latest.createdAt)}
{latest.dueAt ? (
<>
·
Due {formatDate(latest.dueAt)}
>
) : null}
Targeted
{latest.targetCount}
Submitted
{latest.submittedCount}
Graded
{latest.gradedCount}
Average
{formatNumber(latest.scoreStats.avg, 1)}
Median
{formatNumber(latest.scoreStats.median, 1)}
)}
Assignment
Status
Due
Targeted
Submitted
Graded
Avg
Median
Min
Max
{insights.assignments.map((a) => (
{a.title}
Created {formatDate(a.createdAt)}
{a.status}
{a.dueAt ? formatDate(a.dueAt) : "-"}
{a.targetCount}
{a.submittedCount}
{a.gradedCount}
{formatNumber(a.scoreStats.avg, 1)}
{formatNumber(a.scoreStats.median, 1)}
{formatNumber(a.scoreStats.min, 0)}
{formatNumber(a.scoreStats.max, 0)}
))}
)
}
export default async function ClassInsightsPage({ searchParams }: { searchParams: Promise }) {
const classes = await getTeacherClasses()
return (
Class Insights
Latest homework and historical score statistics for a class.
}>
}>
)
}