Files
NextEdu/src/app/(dashboard)/teacher/diagnostic/page.tsx
SpecialX 1a9377222c feat(app): add error/loading boundaries and update dashboard routes
- Add error.tsx and loading.tsx boundaries for admin, parent, student, teacher routes

- Add dashboard-error-fallback and dashboard-loading-skeleton components

- Add student/learning page, parent/leave routes, teacher textbook components

- Update existing app routes across auth, dashboard, and API endpoints

- Update proxy middleware and next-auth type declarations
2026-06-23 17:38:28 +08:00

68 lines
2.2 KiB
TypeScript

import type { JSX } from "react"
import { requirePermission } from "@/shared/lib/auth-guard"
import { Permissions } from "@/shared/types/permissions"
import { getParam, type SearchParams } from "@/shared/lib/search-params"
import { getDiagnosticReports } from "@/modules/diagnostic/data-access-reports"
import { ReportList } from "@/modules/diagnostic/components/report-list"
import type { DiagnosticReportType, DiagnosticReportStatus } from "@/modules/diagnostic/types"
export const dynamic = "force-dynamic"
const VALID_REPORT_TYPES: ReadonlySet<string> = new Set([
"individual",
"class",
"grade",
])
const VALID_REPORT_STATUSES: ReadonlySet<string> = new Set([
"draft",
"published",
"archived",
])
function parseReportType(v?: string): DiagnosticReportType | undefined {
return v && VALID_REPORT_TYPES.has(v) ? (v as DiagnosticReportType) : undefined
}
function parseReportStatus(v?: string): DiagnosticReportStatus | undefined {
return v && VALID_REPORT_STATUSES.has(v) ? (v as DiagnosticReportStatus) : undefined
}
export default async function TeacherDiagnosticPage({
searchParams,
}: {
searchParams: Promise<SearchParams>
}): Promise<JSX.Element> {
const sp = await searchParams
const ctx = await requirePermission(Permissions.DIAGNOSTIC_READ)
const reportType = getParam(sp, "reportType")
const status = getParam(sp, "status")
const reports = await getDiagnosticReports(
{
reportType: reportType && reportType !== "all" ? parseReportType(reportType) : undefined,
status: status && status !== "all" ? parseReportStatus(status) : undefined,
},
ctx.dataScope,
)
// 学生角色仅查看自己的报告;其他角色查看全部
const visibleReports =
ctx.dataScope.type === "class_members"
? reports.reports.filter((r) => r.studentId === ctx.userId)
: reports.reports
return (
<div className="h-full flex-1 flex-col space-y-8 p-8 md:flex">
<div>
<h1 className="text-2xl font-bold tracking-tight">Learning Diagnostic</h1>
<p className="text-muted-foreground">
View and manage diagnostic reports based on knowledge point mastery.
</p>
</div>
<ReportList reports={visibleReports} />
</div>
)
}