fix: 1. 继续对齐交叉评查的接口,完善创建交叉评查的逻辑 和 相关组件的渲染布局。

2. 文档的基本信息修改改用接口。      3. 重新完善角色权限管理的页面逻辑。     4.将评查点列表中的返回逻辑改用浏览器的记忆返回。
This commit is contained in:
2025-12-12 12:00:36 +08:00
parent a5c49a5c95
commit d4000cd292
25 changed files with 4750 additions and 28293 deletions
+40 -23
View File
@@ -1,5 +1,6 @@
import { postgrestGet, postgrestPut } from "../postgrest-client";
import axios from 'axios';
import { API_BASE_URL } from '../../config/api-config';
/**
* 从不同格式的 API 响应中提取数据
@@ -83,32 +84,50 @@ async function safeGetJWT(jwtToken?: string): Promise<string> {
}
/**
* 获取当前登录用户是否是发起人
* 检查用户是否有权确认完成文档评查
*
* 🔥 接口文档: auth_doc/交叉评查接口文档.md 接口11
* 📍 API地址: GET /api/v2/cross_review/tasks/{task_id}/can-confirm
*
* @param taskId 任务ID
* @param userId 用户ID
* @returns 是否是发起人
* @param frontendJWT JWT token
* @returns 是否有权确认完成
*/
export async function findIsProposer(taskId: string | number, userId: number | undefined, frontendJWT?: string): Promise<boolean> {
// 通过postgrest的get请求去cross_examination_tasks表中进行查找assignee_id是否等于userId
const response = await postgrestGet(`/api/postgrest/proxy/cross_examination_tasks`, {
select: 'assigner_id',
filter: {
id: `eq.${taskId}`
},
token: frontendJWT
});
if (response.error) {
console.error('获取任务数据失败:', response.error);
try {
if (!taskId) {
console.error('任务ID不能为空');
return false;
}
// 调用新的接口检查用户是否有权确认完成
// GET /api/v2/cross_review/tasks/{task_id}/can-confirm
const response = await axios.get(
`${API_BASE_URL}/api/v2/cross_review/tasks/${taskId}/can-confirm`,
{
headers: {
'Content-Type': 'application/json',
'Authorization': `Bearer ${frontendJWT}`
}
}
);
const data = response.data;
console.log('[findIsProposer] 检查权限响应:', data);
// 返回 can_confirm 字段,表示是否有权确认完成
// 有权限的用户:任务创建者(assigner_id) 或 主要负责人(principal_user_ids)
return data?.can_confirm === true;
} catch (error) {
console.error('[findIsProposer] 检查权限失败:', error);
// 正确处理 axios 错误响应
if (axios.isAxiosError(error) && error.response?.data) {
console.error('[findIsProposer] 错误详情:', error.response.data);
}
return false;
}
const data = extractApiData<{assigner_id: number}[]>(response.data);
// console.log('data', data, userId);
if (data && data.length > 0) {
return data[0].assigner_id.toString() === userId?.toString();
}
return false;
}
/**
@@ -180,8 +199,6 @@ export async function submitCrossCheckingOpinion(
* @param jwtToken JWT token
* @returns 意见列表和总数
*/
import { API_BASE_URL } from '../../config/api-config';
export async function getCrossCheckingOpinions(
documentId: string | number,
page: number = 1,
+11 -4
View File
@@ -210,6 +210,7 @@ export async function uploadCrossCheckingDocument(
* @param docType 文档类型(如 XZCF、XZXK
* @param taskType 任务类型(如 市局间交叉评查、区局间交叉评查)
* @param token JWT Token
* @param principalUserIds 负责人ID数组(包含主要负责人和额外负责人)
*/
export async function batchUploadAndAssignCrossCheckingFiles(
files: CrossCheckingUploadedFile[],
@@ -222,17 +223,18 @@ export async function batchUploadAndAssignCrossCheckingFiles(
taskName: string,
docType: string,
taskType: string = '市局间交叉评查',
token: string | null = null
token: string | null = null,
principalUserIds: number[] = []
): Promise<{
successes: Array<{file: CrossCheckingUploadedFile; result: Record<string, unknown>}>;
failures: Array<{file: CrossCheckingUploadedFile; error: string}>;
}> {
const successes: Array<{file: CrossCheckingUploadedFile; result: Record<string, unknown>}> = [];
const failures: Array<{file: CrossCheckingUploadedFile; error: string}> = [];
const uploadEndpoint = '/cross_review/documents/upload_and_assign';
const uploadUrl = UPLOAD_URL + uploadEndpoint;
const uploadEndpoint = '/admin/v2/documents/cross_review/documents/upload_and_assign';
const uploadUrl = API_BASE_URL + uploadEndpoint;
// console.log('[批量上传] 任务类型:', taskType, '文档类型:', docType);
// console.log('[批量上传] 任务类型:', taskType, '文档类型:', docType, '负责人ID:', leaderId);
for (const fileInfo of files) {
@@ -254,6 +256,11 @@ export async function batchUploadAndAssignCrossCheckingFiles(
formData.append('upload_info', JSON.stringify(uploadInfo));
formData.append('assign_user_ids', JSON.stringify(assignUserIds));
// 添加负责人ID数组(包含主要负责人和额外负责人)
if (principalUserIds.length > 0) {
formData.append('principal_user_ids', JSON.stringify(principalUserIds));
}
const headers: Record<string, string> = {};
if (token) headers['Authorization'] = `Bearer ${token}`;