# 驾驶员任务管理 - 终止功能及分页更新
## 📅 更新时间
2025-10-16
## 🎯 更新概述
对驾驶员任务管理系统进行以下重要更新:
1. ✅ 为接收任务添加二次确认功能(已完成)
2. ✅ 移除"已暂停"状态
3. ✅ 为进行中任务添加"终止"操作
4. ✅ 为终止操作添加 AlertDialog 二次确认
5. ✅ 为任务列表添加分页功能
## ✨ 主要变更
### 1. 任务状态更新
#### 新增状态
- **已终止** 🟠: 用于标记被强制停止的任务
#### 完整状态列表
```typescript
export type TaskStatus = '待接收' | '已接收' | '进行中' | '已完成' | '已取消' | '已终止';
```
#### 状态颜色配置
| 状态 | 颜色 | Tailwind 类 | 说明 |
|------|------|-------------|------|
| 待接收 | 灰色 | bg-gray-100 text-gray-700 | 新创建的任务 |
| 已接收 | 蓝色 | bg-blue-100 text-blue-700 | 驾驶员已确认接收 |
| 进行中 | 绿色 | bg-green-100 text-green-700 | 任务正在执行 |
| 已完成 | 紫色 | bg-purple-100 text-purple-700 | 任务正常完成 |
| 已取消 | 红色 | bg-red-100 text-red-700 | 任务被取消 |
| 已终止 | 橙色 🆕 | bg-orange-100 text-orange-700 | 任务被强制终止 |
### 2. 终止任务功能
#### 功能说明
- **触发条件**: 任务状态为"进行中"时可用
- **操作位置**: 任务列表的操作列
- **按钮样式**: 橙色文字按钮,显示"终止"
#### 操作流程
```
任务进行中
↓
点击"终止"按钮
↓
显示 AlertDialog 确认对话框
↓
用户确认
↓
任务状态: 进行中 → 已终止
↓
记录终止时间
↓
Toast 提示: "任务状态更新成功"
```
#### 终止确认对话框
```tsx
┌────────────────────────────────────────┐
│ 确认终止任务 │
├────────────────────────────────────────┤
│ 确定要终止任务 T202510160001 吗? │
│ ⚠️ 终止后任务将停止执行,并记录为 │
│ 已终止状态。此操作不可恢复。 │
├────────────────────────────────────────┤
│ [我再想想] [确认终止] │
│ └─ 橙色 │
└────────────────────────────────────────┘
```
**对话框特点**:
- 标题: "确认终止任务"
- 显示任务编号(橙色高亮)
- 橙色警告文字说明后果
- 按钮: "我再想想" / "确认终止"(橙色)
### 3. 进行中任务操作按钮
#### 按钮布局
```
进行中任务操作区域:
┌─────────────────────────────────┐
│ [完成] [终止] [上报问题图标] │
│ ↑ ↑ ↑ │
│ 紫色 橙色 橙色图标 │
└─────────────────────────────────┘
```
#### 完整按钮列表
| 按钮 | 颜色 | 图标 | 功能 | 状态变化 |
|------|------|------|------|----------|
| 完成 | 默认 | 无 | 标记任务完成 | 进行中 → 已完成 |
| 终止 🆕 | 橙色 | 无 | 强制终止任务 | 进行中 → 已终止 |
| 上报问题 | 默认 | MessageSquare | 上报任务问题 | 状态不变 |
### 4. 分页功能
#### 分页配置
- **默认每页**: 10 条
- **可选项**: 10, 20, 50, 100 条/页
- **位置**: 任务列表底部
- **组件**: DataPagination
#### 分页界面
```
┌────────────────────────────────────────────────────────────┐
│ 每页显示 [10▼] 条 < [1] 2 3 ... 10 > 显示 1-10 条,共 95 条 │
└────────────────────────────────────────────────────────────┘
```
**功能特性**:
- ✅ 页码选择
- ✅ 上一页/下一页
- ✅ 每页数量调整
- ✅ 总数统计显示
- ✅ 智能省略号(页数较多时)
## 📁 修改文件
### 1. `/types/driver.ts`
#### 更新内容
```typescript
// 更新前
export type TaskStatus = '待接收' | '已接收' | '进行中' | '已完成' | '已取消';
// 更新后
export type TaskStatus = '待接收' | '已接收' | '进行中' | '已完成' | '已取消' | '已终止';
```
### 2. `/components/machinery/driver/DriverTask.tsx`
#### 新增导入
```tsx
import { usePagination } from '../../../lib/usePagination';
import { DataPagination } from '../../ui/data-pagination';
```
#### 新增状态
```tsx
const [showTerminateConfirm, setShowTerminateConfirm] = useState(false);
```
#### 新增函数
```tsx
// 终止任务确认
const handleTerminateTask = (taskId: string) => {
setPendingTaskId(taskId);
setShowTerminateConfirm(true);
};
const confirmTerminateTask = () => {
if (pendingTaskId) {
handleUpdateStatus(pendingTaskId, '已终止');
}
setShowTerminateConfirm(false);
setPendingTaskId(null);
};
```
#### 更新状态颜色
```tsx
const getStatusColor = (status: TaskStatus) => {
switch (status) {
case '待接收': return 'bg-gray-100 text-gray-700';
case '已接收': return 'bg-blue-100 text-blue-700';
case '进行中': return 'bg-green-100 text-green-700';
case '已完成': return 'bg-purple-100 text-purple-700';
case '已取消': return 'bg-red-100 text-red-700';
case '已终止': return 'bg-orange-100 text-orange-700'; // 新增
default: return 'bg-gray-100 text-gray-700';
}
};
```
#### 添加终止按钮
```tsx
{task.status === '进行中' && (
<>
{/* 新增终止按钮 */}
>
)}
```
#### 添加分页
```tsx
// 初始化分页
const pagination = usePagination(tasks, 10);
// 使用分页数据
{pagination.paginatedData.map((task) => (
// 渲染任务行
))}
// 添加分页组件
```
#### 添加 AlertDialog
```tsx
{/* 终止任务确认对话框 */}
确认终止任务
{pendingTaskId && tasks.find(t => t.id === pendingTaskId) && (
<>
确定要终止任务
{tasks.find(t => t.id === pendingTaskId)?.taskNumber}
吗?
终止后任务将停止执行,并记录为已终止状态。此操作不可恢复。
>
)}
我再想想
确认终止
```
## 🎨 视觉设计
### 操作按钮颜色规范
| 操作 | 按钮类型 | 颜色 | 含义 |
|------|---------|------|------|
| 接收 | 图标 | 默认 | 正向操作 |
| 取消 | 图标 | 红色 | 危险操作 |
| 开始 | 文字 | 默认 | 正向操作 |
| 完成 | 文字 | 默认 | 完成状态 |
| 终止 🆕 | 文字 | 橙色 | 警告操作 |
| 上报问题 | 图标 | 橙色 | 警告提示 |
### AlertDialog 颜色语义
| 对话框 | 主题色 | 确认按钮类 | 场景 |
|--------|--------|-----------|------|
| 接收任务 | 绿色 | bg-green-600 | 正向操作 |
| 取消任务 | 红色 | bg-red-600 | 危险操作 |
| 完成任务 | 紫色 | bg-purple-600 | 完成操作 |
| 终止任务 🆕 | 橙色 | bg-orange-600 | 警告操作 |
## 🔄 任务状态流转
### 完整流程图
```
创建任务
↓
【待接收】
↙ ↘
接收 取消 → 【已取消】
↓
【已接收】
↙ ↘
开始 取消 → 【已取消】
↓
【进行中】
↙ ↓ ↘
完成 终止 上报问题
↓ ↓ ↓
已完成 已终止 (状态不变)
```
### 状态说明
#### 待接收
- **可执行操作**: 接收、取消
- **说明**: 任务刚创建,等待驾驶员确认
#### 已接收
- **可执行操作**: 开始、取消
- **说明**: 驾驶员已确认,准备开始
#### 进行中
- **可执行操作**: 完成、终止、上报问题
- **说明**: 任务正在执行中
- **⚠️ 特别注意**: 不能直接取消,只能完成或终止
#### 已完成
- **可执行操作**: 查看详情
- **说明**: 任务正常完成
- **自动操作**: 记录结束时间、计算工时
#### 已取消
- **可执行操作**: 查看详情
- **说明**: 任务在开始前被取消
- **不可恢复**: 取消后无法恢复
#### 已终止 🆕
- **可执行操作**: 查看详情
- **说明**: 任务在执行中被强制终止
- **使用场景**: 设备故障、天气原因、安全问题等
- **不可恢复**: 终止后无法恢复
## 💡 使用场景
### 何时使用"取消"
**适用场景**:
- ✅ 任务分配错误
- ✅ 驾驶员临时请假
- ✅ 设备故障无法开始
- ✅ 计划变更
- ✅ 天气原因延期
**状态要求**:
- ✅ 待接收状态
- ✅ 已接收状态
- ❌ 不能取消进行中的任务
### 何时使用"终止"
**适用场景**:
- ✅ 执行中设备突发故障
- ✅ 天气突变(暴雨、大风等)
- ✅ 安全隐患需立即停止
- ✅ 地块条件不符合作业要求
- ✅ 驾驶员身体不适
**状态要求**:
- ✅ 仅限进行中状态
- ⚠️ 终止后不可恢复
### 取消 vs 终止
| 对比项 | 取消 | 终止 |
|--------|------|------|
| **适用状态** | 待接收、已接收 | 进行中 |
| **使用时机** | 任务开始前 | 任务执行中 |
| **典型场景** | 计划变更 | 突发情况 |
| **是否记录工时** | ❌ 否 | ✅ 是(到终止时) |
| **颜色标识** | 红色 | 橙色 |
| **严重程度** | 较低 | 较高 |
## 📊 分页使用说明
### 基本操作
#### 翻页
- **上一页**: 点击 "< Previous" 或 "<"
- **下一页**: 点击 "Next >" 或 ">"
- **跳转**: 直接点击页码
#### 调整每页数量
```
点击"每页显示"下拉框 → 选择 10/20/50/100 → 自动刷新
```
#### 查看统计
```
右下角显示: "显示 1-10 条,共 95 条"
```
### 分页特性
**智能省略**:
```
页数少: [1] [2] [3] [4] [5]
页数多: [1] ... [5] [6] [7] ... [20]
```
**状态保持**:
- ✅ 切换页码时保持每页数量
- ✅ 更改每页数量时自动跳转到第1页
- ✅ 筛选后重新计算分页
## ✅ 测试要点
### 终止功能测试
**基础功能**:
- [ ] 进行中任务显示"终止"按钮
- [ ] 其他状态不显示"终止"按钮
- [ ] 点击终止按钮弹出确认对话框
- [ ] 对话框显示正确的任务编号
- [ ] 橙色警告文字显示正确
**确认操作**:
- [ ] 点击"我再想想"关闭对话框,任务状态不变
- [ ] 点击"确认终止"任务状态变为"已终止"
- [ ] 显示 Toast 提示"任务状态更新成功"
- [ ] 任务列表状态徽章显示为橙色"已终止"
**边界情况**:
- [ ] 连续点击终止按钮不会出错
- [ ] 按 Esc 键可以关闭对话框
- [ ] 点击遮罩可以关闭对话框
### 分页功能测试
**基础功能**:
- [ ] 任务列表显示分页组件
- [ ] 默认每页显示 10 条
- [ ] 总数统计正确
- [ ] 页码显示正确
**翻页测试**:
- [ ] 上一页按钮功能正常
- [ ] 下一页按钮功能正常
- [ ] 直接点击页码跳转正常
- [ ] 第一页时上一页按钮禁用
- [ ] 最后一页时下一页按钮禁用
**每页数量**:
- [ ] 可以切换 10/20/50/100
- [ ] 切换后自动跳转到第1页
- [ ] 数据显示正确
**UI 测试**:
- [ ] 分页组件居中显示
- [ ] 统计信息显示完整
- [ ] 响应式布局正常
### 状态流转测试
**完整流程**:
- [ ] 待接收 → 接收 → 已接收
- [ ] 已接收 → 开始 → 进行中
- [ ] 进行中 → 完成 → 已完成
- [ ] 进行中 → 终止 → 已终止
- [ ] 待接收 → 取消 → 已取消
- [ ] 已接收 → 取消 → 已取消
**操作限制**:
- [ ] 进行中任务不显示取消按钮
- [ ] 已完成/已取消/已终止任务不显示操作按钮
- [ ] 只有进行中任务显示终止按钮
## 🎓 用户指南
### 快速操作指南
#### 终止进行中的任务
```
1. 找到状态为"进行中"的任务
2. 点击该任务行的"终止"按钮(橙色)
3. 在弹出的对话框中仔细阅读警告信息
4. 确认无误后点击"确认终止"
5. 系统提示"任务状态更新成功"
6. 任务状态变为橙色的"已终止"
```
#### 使用分页
```
查看更多任务:
- 点击页码或"下一页"
快速查看大量数据:
- 选择"每页显示 50 条"或"100 条"
返回第一页:
- 点击页码 "1"
```
### 常见问题
**Q1: 为什么进行中的任务不能取消?**
A: 进行中的任务已经在执行,应该通过"完成"或"终止"来结束。
- 正常完成 → 点击"完成"
- 异常情况 → 点击"终止"
**Q2: 取消和终止有什么区别?**
A:
- **取消**: 用于任务开始前,表示不再执行此任务
- **终止**: 用于任务执行中,表示强制停止正在进行的任务
**Q3: 终止后可以恢复吗?**
A: 不可以。终止操作不可逆,请谨慎使用。
**Q4: 终止会记录工时吗?**
A: 会。系统会记录从开始到终止的时间作为实际工时。
**Q5: 分页后筛选条件会保留吗?**
A: 会。筛选条件保持不变,分页会根据筛选结果重新计算。
## 📚 相关文档
- **任务操作确认**: `/TASK_ALERT_DIALOG_UPDATE.md`
- **任务状态优化**: `/TASK_STATUS_UPDATE.md`
- **任务管理指南**: `/components/machinery/driver/TASK_MANAGEMENT_GUIDE.md`
- **快速开始**: `/components/machinery/driver/TASK_QUICK_START.md`
- **分页组件**: `/components/ui/data-pagination.tsx`
- **分页 Hook**: `/lib/usePagination.ts`
## 🎉 总结
本次更新为驾驶员任务管理系统带来了以下增强:
### 核心功能
✅ **终止任务功能** - 支持强制停止进行中的任务
✅ **二次确认机制** - 所有关键操作都有确认对话框
✅ **分页功能** - 大量数据时保持界面流畅
✅ **状态完善** - 新增"已终止"状态,更符合实际场景
### 用户体验
✅ **视觉统一** - 橙色主题贯穿终止相关功能
✅ **操作明确** - 清晰区分取消和终止的使用场景
✅ **信息丰富** - 详细的警告提示和��作说明
✅ **响应流畅** - 分页优化大量数据的展示性能
### 安全机制
✅ **操作确认** - 所有状态变更都需要确认
✅ **不可恢复** - 明确提示不可逆操作
✅ **权限控制** - 根据任务状态显示对应操作
现在,驾驶员任务管理系统功能更加完善,能够更好地应对各种实际工作场景!🎊
---
**更新人**: AI助手
**更新日期**: 2025-10-16
**版本**: v1.5
**影响范围**: 驾驶员任务管理 - 状态管理、操作按钮、分页功能