Files
DataMate/frontend/src/pages/TaskCoordination/taskCoordination.api.ts
Jerry Yan 71f8f7d1c3 feat: 实现任务拆分和分配功能
## 功能概述
实现完整的任务拆分、分配和进度跟踪功能,支持将任务拆分为子任务并分配给不同用户。

## Phase 1: 数据库层
- 新增 t_task_meta 表(任务元数据协调表)
- 新增 t_task_assignment_log 表(分配日志表)
- 新增 3 个权限条目(read/write/assign)
- 新增 SQLAlchemy ORM 模型

## Phase 2: 后端 API (Java)
- 新增 task-coordination-service 模块(32 个文件)
- 实现 11 个 API 端点:
  - 任务查询(列表、子任务、我的任务)
  - 任务拆分(支持 4 种策略)
  - 任务分配(单个、批量、重新分配、撤回)
  - 进度管理(查询、更新、聚合)
  - 分配日志
- 集成权限控制和路由规则

## Phase 3: 前端 UI (React + TypeScript)
- 新增 10 个文件(模型、API、组件、页面)
- 实现 5 个核心组件:
  - SplitTaskDialog - 任务拆分对话框
  - AssignTaskDialog - 任务分配对话框
  - BatchAssignDialog - 批量分配对话框
  - TaskProgressPanel - 进度面板
  - AssignmentLogDrawer - 分配记录
- 实现 2 个页面:
  - TaskCoordination - 任务管理主页
  - MyTasks - 我的任务页面
- 集成侧边栏菜单和路由

## 问题修复
- 修复 getMyTasks 分页参数缺失
- 修复子任务 assignee 信息缺失(批量查询优化)
- 修复 proportion 精度计算(余量分配)

## 技术亮点
- 零侵入设计:通过独立协调表实现,不修改现有模块
- 批量查询优化:避免 N+1 查询问题
- 4 种拆分策略:按比例/数量/文件/手动
- 进度自动聚合:子任务更新自动聚合到父任务
- 权限细粒度控制:read/write/assign 三级权限

## 验证
- Maven 编译: 零错误
- TypeScript 编译: 零错误
- Vite 生产构建: 成功
2026-02-09 00:42:34 +08:00

77 lines
2.6 KiB
TypeScript

import { get, post, put, del } from "@/utils/request";
type RequestParams = Record<string, unknown>;
type RequestPayload = Record<string, unknown>;
// ── CRUD ─────────────────────────────────────────────────
export function createTaskMetaUsingPost(data: RequestPayload) {
return post("/api/task-meta", data);
}
export function getTaskMetaByIdUsingGet(id: string) {
return get(`/api/task-meta/${id}`);
}
export function deleteTaskMetaByIdUsingDelete(id: string) {
return del(`/api/task-meta/${id}`);
}
export function queryTaskMetasUsingGet(params?: RequestParams) {
return get("/api/task-meta", params);
}
export function getChildrenUsingGet(id: string, params?: RequestParams) {
return get(`/api/task-meta/${id}/children`, params);
}
export function getMyTasksUsingGet(params?: RequestParams) {
return get("/api/task-meta/my-tasks", params);
}
// ── Split ────────────────────────────────────────────────
export function splitTaskUsingPost(id: string, data: RequestPayload) {
return post(`/api/task-meta/${id}/split`, data);
}
// ── Assignment ───────────────────────────────────────────
export function assignTaskUsingPost(id: string, data: RequestPayload) {
return post(`/api/task-meta/${id}/assign`, data);
}
export function reassignTaskUsingPost(id: string, data: RequestPayload) {
return post(`/api/task-meta/${id}/reassign`, data);
}
export function revokeTaskUsingPost(id: string, remark?: string) {
return post(`/api/task-meta/${id}/revoke`, null, {
params: remark ? { remark } : undefined,
});
}
export function batchAssignUsingPost(data: RequestPayload) {
return post("/api/task-meta/batch-assign", data);
}
export function getAssignmentLogsUsingGet(id: string) {
return get(`/api/task-meta/${id}/assignment-logs`);
}
// ── Progress ─────────────────────────────────────────────
export function getProgressUsingGet(id: string) {
return get(`/api/task-meta/${id}/progress`);
}
export function updateProgressUsingPut(id: string, data: RequestPayload) {
return put(`/api/task-meta/${id}/progress`, data);
}
// ── Users (for assignment selectors) ─────────────────────
export function listUsersUsingGet() {
return get("/api/auth/users");
}