You've already forked DataMate
## 功能概述 实现完整的任务拆分、分配和进度跟踪功能,支持将任务拆分为子任务并分配给不同用户。 ## 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 生产构建:✅ 成功
77 lines
2.6 KiB
TypeScript
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");
|
|
}
|