Files
NextEdu/src/app/(dashboard)/teacher/lesson-plans/new/page.tsx
SpecialX 20691f53ce feat(lesson-preparation): 备课模块审计重构 — 跨模块解耦 + i18n + 纯函数抽取 + 错误边界
P0-1 跨模块直查修复:publish-service 不再直查 examQuestions 表,新增 exams/data-access.addExamQuestions 接口,复用 classes/data-access.getStudentIdsByClassIds

P0-2 i18n 接入:新增 zh-CN/en 翻译文件,注册 lessonPreparation 命名空间,17 个组件改造为 useTranslations/getTranslations

P1 纯函数抽取:lib/document-migration.ts(类型守卫替代 as 断言)、lib/node-summary.ts(翻译函数注入)、lib/rf-mappers.ts

P1 错误边界+骨架屏:新增 LessonPlanErrorBoundary 和 4 个 Skeleton 组件

P1 Block 注册表:新增 config/block-registry.tsx(BlockRenderer 组件),node-edit-panel 重构为配置驱动渲染

P1 其他修复:exercise-block 改用 router.refresh(),node-editor/lesson-node 复用 lib/ 纯函数

架构图同步:更新 004 和 005 文档

Refs: docs/architecture/audit/lesson-preparation-audit-report.md
2026-06-22 16:17:58 +08:00

27 lines
927 B
TypeScript

import type { JSX } from "react"
import Link from "next/link"
import { ArrowLeft } from "lucide-react"
import { getTranslations } from "next-intl/server"
import { Button } from "@/shared/components/ui/button"
import { TemplatePicker } from "@/modules/lesson-preparation/components/template-picker"
export const dynamic = "force-dynamic"
export default async function NewLessonPlanPage(): Promise<JSX.Element> {
const t = await getTranslations("lessonPreparation")
return (
<div className="p-6">
<div className="mb-6 flex items-center gap-4">
<Button asChild variant="ghost" size="sm">
<Link href="/teacher/lesson-plans">
<ArrowLeft className="mr-2 h-4 w-4" aria-hidden="true" />
{t("action.back")}
</Link>
</Button>
<h1 className="text-2xl font-bold tracking-tight">{t("title.new")}</h1>
</div>
<TemplatePicker />
</div>
)
}