Files
NextEdu/src/shared/components/ui/page-header.tsx
SpecialX 978d9a8309
Some checks failed
Security / deep-security-scan (push) Failing after 20m5s
DR Drill / dr-drill (push) Failing after 1m31s
CI / scheduled-backup (push) Failing after 1m31s
CI / backup-verify (push) Has been skipped
CI / weekly-dr-drill (push) Failing after 0s
CI / build-deploy (push) Has been cancelled
CI / security-scan (push) Has been cancelled
feat: 新增备课模块并修复全模块 P0/P1/P2 缺陷
主要变更:

- 新增 lesson-preparation 模块: 备课编辑器、节点编辑、AI 建议、知识点选择、版本历史、作业发布

- 新增 shared 通用组件: charts/question-bank-filters/schedule-list/ui (chip-nav/filter-bar/page-header/stat-card/stat-item)

- 新增 student/admin 端 loading.tsx 与 error.tsx, 优化加载与错误态体验

- 新增 teacher/lesson-plans 页面 (列表/新建/编辑)

- 新增 drizzle 迁移 0002_tiny_lionheart 及 snapshot

- 新增 textbooks/schema.ts 与 exams/utils/normalize-structure.ts

- 修复 Tiptap v3 SSR hydration 崩溃 (rich-text-block immediatelyRender: false)

- 重构多模块 data-access/actions/组件, 修复权限校验与类型规范

- 同步架构文档 004/005 反映新增模块、导出、依赖关系

- 归档 bugs/* 测试报告与 e2e 测试脚本 (admin/parent/student/teacher web_test)
2026-06-22 01:06:16 +08:00

45 lines
1.5 KiB
TypeScript
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
import type { ComponentType, ReactNode } from "react"
import { cn } from "@/shared/lib/utils"
/**
* 页面头部:统一的标题 + 描述 + 操作区域布局。
*
* 覆盖以下重复模式:
* - AdminDashboardView 内联头部
* - Profile 页面内联头部
* - SettingsView 内联头部
* - Security 页面内联头部(带图标)
*
* 结构:左侧标题 + 描述,右侧操作区域(响应式:移动端纵向,桌面端横向)。
*/
interface PageHeaderProps {
/** 页面标题 */
title: string
/** 标题下方描述文本 */
description?: string
/** 标题左侧图标组件lucide-react 图标等) */
icon?: ComponentType<{ className?: string }>
/** 右侧操作区域(按钮、徽章等) */
actions?: ReactNode
/** 额外类名 */
className?: string
}
export function PageHeader({ title, description, icon: Icon, actions, className }: PageHeaderProps) {
return (
<div className={cn("flex flex-col justify-between gap-4 md:flex-row md:items-center", className)}>
<div className="space-y-1">
<div className="flex items-center gap-2">
{Icon ? <Icon className="h-7 w-7 text-muted-foreground" /> : null}
<h1 className="text-3xl font-bold tracking-tight">{title}</h1>
</div>
{description ? (
<div className="text-sm text-muted-foreground">{description}</div>
) : null}
</div>
{actions ? <div className="flex items-center gap-2">{actions}</div> : null}
</div>
)
}