You've already forked DataMate
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 生产构建:✅ 成功
This commit is contained in:
76
frontend/src/pages/TaskCoordination/taskCoordination.api.ts
Normal file
76
frontend/src/pages/TaskCoordination/taskCoordination.api.ts
Normal file
@@ -0,0 +1,76 @@
|
||||
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");
|
||||
}
|
||||
Reference in New Issue
Block a user