307 lines
9.1 KiB
Markdown
307 lines
9.1 KiB
Markdown
# 阅读任务模块设计文档
|
||
|
||
> 创建时间:2026-02-23
|
||
> 最后更新:2026-02-23
|
||
|
||
---
|
||
|
||
## 一、模块概述
|
||
|
||
### 1.1 设计目标
|
||
|
||
阅读任务是**连接课堂教学与家庭阅读**的桥梁,实现:
|
||
- 教师:布置、跟踪、评估学生的课后阅读任务
|
||
- 学校:监督全校阅读任务执行,查看统计数据
|
||
- 家长:接收任务、陪伴阅读、提交反馈
|
||
|
||
### 1.2 业务流程
|
||
|
||
```
|
||
┌─────────────────┐
|
||
│ 课堂授课 │ ← 教师端
|
||
│ (教师端) │
|
||
└────────┬────────┘
|
||
↓ 布置任务
|
||
┌─────────────────┐
|
||
│ 阅读任务系统 │
|
||
│ (学校端+教师端) │
|
||
└────────┬────────┘
|
||
↓ 推送给家长
|
||
┌─────────────────┐
|
||
│ 亲子共读 │ ← 家长端
|
||
│ (家长端) │
|
||
└────────┬────────┘
|
||
↓ 提交反馈
|
||
┌─────────────────┐
|
||
│ 完成情况 │ ← 教师端/学校端
|
||
│ (两端可见) │
|
||
└─────────────────┘
|
||
```
|
||
|
||
---
|
||
|
||
## 二、角色分工
|
||
|
||
### 2.1 教师端 - 执行层
|
||
|
||
**核心理念**:让老师"傻瓜式"完成高质量阅读教学
|
||
|
||
**功能定位**:
|
||
```
|
||
├── 阅读任务
|
||
│ ├── 布置任务 ← 日常操作,可选班级/学生
|
||
│ ├── 任务模板 ← 快速创建(待开发)
|
||
│ ├── 完成情况 ← 跟踪进度,查看详情
|
||
│ └── 家长反馈 ← 接收并查看家长提交的反馈
|
||
```
|
||
|
||
**使用场景**:
|
||
- 场景3:上完课,记录孩子表现,**布置任务**
|
||
- 跟踪班级学生的任务完成情况
|
||
- 与家长进行阅读互动
|
||
|
||
### 2.2 学校端 - 管理层
|
||
|
||
**核心理念**:回答"孩子们有什么收获?"
|
||
|
||
**功能定位**:
|
||
- 管理全校的阅读任务(创建、编辑、删除)
|
||
- 监督任务执行情况
|
||
- 查看统计数据和报告
|
||
- 制定任务模板供教师使用(待开发)
|
||
|
||
### 2.3 家长端 - 参与层
|
||
|
||
**功能定位**:
|
||
- 接收教师布置的阅读任务
|
||
- 陪伴孩子完成任务
|
||
- 提交完成反馈(文字、图片)
|
||
|
||
---
|
||
|
||
## 三、数据模型
|
||
|
||
### 3.1 核心表结构
|
||
|
||
#### tasks 表
|
||
```prisma
|
||
model Task {
|
||
id Int @id @default(autoincrement())
|
||
tenantId Int @map("tenant_id")
|
||
title String
|
||
description String?
|
||
taskType String @map("task_type") // READING, ACTIVITY, HOMEWORK
|
||
targetType String @map("target_type") // CLASS, STUDENT
|
||
status String @default("DRAFT") // DRAFT, PUBLISHED, ARCHIVED
|
||
relatedCourseId Int? @map("related_course_id")
|
||
startDate DateTime? @map("start_date")
|
||
endDate DateTime? @map("end_date")
|
||
createdBy Int @map("created_by")
|
||
createdAt DateTime @default(now())
|
||
updatedAt DateTime @updatedAt
|
||
|
||
tenant Tenant @relation(fields: [tenantId], references: [id])
|
||
course Course? @relation(fields: [relatedCourseId], references: [id])
|
||
targets TaskTarget[]
|
||
completions TaskCompletion[]
|
||
|
||
@@map("tasks")
|
||
}
|
||
```
|
||
|
||
#### task_targets 表(任务目标关联)
|
||
```prisma
|
||
model TaskTarget {
|
||
id Int @id @default(autoincrement())
|
||
taskId Int @map("task_id")
|
||
classId Int? @map("class_id")
|
||
studentId Int? @map("student_id")
|
||
|
||
task Task @relation(fields: [taskId], references: [id])
|
||
class Class? @relation(fields: [classId], references: [id])
|
||
student Student? @relation(fields: [studentId], references: [id])
|
||
|
||
@@map("task_targets")
|
||
}
|
||
```
|
||
|
||
#### task_completions 表(完成记录)
|
||
```prisma
|
||
model TaskCompletion {
|
||
id Int @id @default(autoincrement())
|
||
taskId Int @map("task_id")
|
||
studentId Int @map("student_id")
|
||
status String @default("PENDING") // PENDING, IN_PROGRESS, COMPLETED
|
||
completedAt DateTime? @map("completed_at")
|
||
studentFeedback String? @map("student_feedback")
|
||
parentFeedback String? @map("parent_feedback")
|
||
images String? // JSON array
|
||
createdAt DateTime @default(now())
|
||
updatedAt DateTime @updatedAt
|
||
|
||
task Task @relation(fields: [taskId], references: [id])
|
||
student Student @relation(fields: [studentId], references: [id])
|
||
|
||
@@map("task_completions")
|
||
}
|
||
```
|
||
|
||
### 3.2 实体关系图
|
||
|
||
```
|
||
Tenant (1) ←→ (N) Tasks
|
||
↓
|
||
Tasks (1) ←→ (N) TaskTargets
|
||
↓ ↓
|
||
TaskTargets (1) ←→ (1) Class OR Student
|
||
↓
|
||
TaskTargets (1) ←→ (N) TaskCompletions
|
||
↓
|
||
TaskCompletions (1) ←→ (1) Student
|
||
```
|
||
|
||
---
|
||
|
||
## 四、API 接口
|
||
|
||
### 4.1 学校端接口
|
||
|
||
| 方法 | 路径 | 说明 |
|
||
|-----|------|------|
|
||
| GET | /school/tasks | 任务列表(分页、筛选) |
|
||
| GET | /school/tasks/stats | 任务统计 |
|
||
| GET | /school/tasks/:id | 任务详情 |
|
||
| GET | /school/tasks/:id/completions | 完成情况列表 |
|
||
| POST | /school/tasks | 创建任务 |
|
||
| PUT | /school/tasks/:id | 更新任务 |
|
||
| DELETE | /school/tasks/:id | 删除任务 |
|
||
| PUT | /school/tasks/:taskId/completions/:studentId | 更新学生完成状态 |
|
||
|
||
### 4.2 教师端接口
|
||
|
||
| 方法 | 路径 | 说明 |
|
||
|-----|------|------|
|
||
| GET | /teacher/tasks | 我的任务列表 |
|
||
| GET | /teacher/tasks/upcoming | 即将截止的任务 |
|
||
| GET | /teacher/tasks/:id | 任务详情 |
|
||
| GET | /teacher/tasks/:id/completions | 完成情况列表 |
|
||
| POST | /teacher/tasks | 创建任务 |
|
||
| PUT | /teacher/tasks/:id | 更新任务 |
|
||
| DELETE | /teacher/tasks/:id | 删除任务 |
|
||
| POST | /teacher/tasks/:id/remind | 发送提醒 |
|
||
|
||
### 4.3 家长端接口
|
||
|
||
| 方法 | 路径 | 说明 |
|
||
|-----|------|------|
|
||
| GET | /parent/tasks | 孩子的任务列表 |
|
||
| GET | /parent/tasks/:id | 任务详情 |
|
||
| PUT | /parent/tasks/:id/complete | 提交完成情况 |
|
||
|
||
---
|
||
|
||
## 五、功能实现状态
|
||
|
||
### 5.1 已完成功能
|
||
|
||
| 功能 | 学校端 | 教师端 | 家长端 | 后端 |
|
||
|-----|-------|-------|-------|-----|
|
||
| 任务列表 | ✅ | ✅ | ✅ | ✅ |
|
||
| 创建任务 | ✅ | ✅ | - | ✅ |
|
||
| 编辑任务 | ✅ | ✅ | - | ✅ |
|
||
| 删除任务 | ✅ | ✅ | - | ✅ |
|
||
| 任务类型 | ✅ | ✅ | - | ✅ |
|
||
| 目标选择 | ✅ | ✅ | - | ✅ |
|
||
| API接口 | - | - | - | ✅ |
|
||
| 完成情况详情页 | ✅ | ✅ | - | ✅ |
|
||
| 家长提交反馈 | - | - | ✅ | ✅ |
|
||
| 家长反馈展示 | ✅ | ✅ | - | ✅ |
|
||
| 课后记录→布置任务 | - | ✅ | - | ✅ |
|
||
| 任务模板 | ✅ | ✅ | - | ✅ |
|
||
| 提醒通知 | ✅ | ✅ | - | ✅ |
|
||
| 统计报表 | ✅ | ✅ | - | ✅ |
|
||
|
||
### 5.2 所有功能已完成 ✅
|
||
|
||
阅读任务模块的核心功能已全部实现。
|
||
|
||
---
|
||
|
||
## 六、开发计划
|
||
|
||
### 6.1 阶段一:完善现有功能(P0)✅ 已完成
|
||
|
||
1. **测试家长端任务功能** ✅
|
||
- 验证任务列表展示 - 通过
|
||
- 验证任务详情 - 通过
|
||
- 验证完成提交 - 通过
|
||
- 验证家长反馈可见性 - 通过
|
||
|
||
2. **实现完成情况详情页** ✅
|
||
- 学生完成状态列表 - 完成
|
||
- 批量更新状态 - 完成
|
||
- 家长反馈展示 - 完成
|
||
- 文件:`src/views/teacher/tasks/TaskListView.vue`
|
||
|
||
3. **打通课后记录→布置任务** ✅
|
||
- 在课后记录页面添加"布置阅读任务"按钮
|
||
- 自动关联当前课程和班级
|
||
- 预设任务时间(默认7天)
|
||
- 文件:`src/views/teacher/lessons/LessonRecordsView.vue`
|
||
|
||
### 6.2 阶段二:功能增强(P1-P2)✅ 已完成
|
||
|
||
4. **任务模板功能** ✅
|
||
- 数据库:新增 TaskTemplate 模型
|
||
- 后端:模板 CRUD API
|
||
- 学校端:模板管理页面 (`/school/task-templates`)
|
||
- 教师端:任务创建时使用模板
|
||
|
||
5. **提醒通知系统** ✅
|
||
- 定时任务:每天早上9点检查即将截止任务
|
||
- 手动提醒:教师可发送提醒给家长
|
||
- 通知记录:通过 Notification 模型存储
|
||
|
||
### 6.3 阶段三:数据分析(P3)✅ 已完成
|
||
|
||
6. **统计报表增强** ✅
|
||
- 基本统计:任务数、完成数、完成率
|
||
- 按类型统计:阅读/活动/作业完成率
|
||
- 按班级统计:各班级完成情况
|
||
- 月度趋势:任务数量和完成率趋势
|
||
|
||
---
|
||
|
||
## 七、技术实现建议
|
||
|
||
### 7.1 前端组件复用
|
||
|
||
建议创建共享组件:
|
||
- `TaskCard.vue` - 任务卡片(学校端/教师端复用)
|
||
- `TaskForm.vue` - 任务表单(学校端/教师端复用)
|
||
- `CompletionList.vue` - 完成情况列表
|
||
- `FeedbackDisplay.vue` - 反馈展示组件
|
||
|
||
### 7.2 状态管理
|
||
|
||
任务数据涉及多端,建议:
|
||
- 使用 Pinia 统一管理任务状态
|
||
- 缓存任务列表减少请求
|
||
- 使用 WebSocket 实时推送完成状态
|
||
|
||
### 7.3 数据一致性
|
||
|
||
- 任务创建后自动创建 TaskCompletion 记录
|
||
- 学生调班时更新 TaskTarget
|
||
- 任务删除时级联删除关联数据
|
||
|
||
---
|
||
|
||
## 八、变更记录
|
||
|
||
| 日期 | 变更内容 |
|
||
|-----|---------|
|
||
| 2026-02-23 | 完成 P2/P3 功能:任务模板、提醒通知、统计报表 |
|
||
| 2026-02-23 | 完成 P0 功能:测试家长端任务功能、实现教师端完成情况详情页、打通课后记录→布置任务流程 |
|
||
| 2026-02-23 | 创建文档,分析现状,制定开发计划 |
|