优化交叉评查详情页面

This commit is contained in:
2025-07-16 22:20:02 +08:00
parent 328f326db3
commit 4843b7bebf
19 changed files with 4955 additions and 4 deletions
+130
View File
@@ -0,0 +1,130 @@
import { postgrestPost } from "../postgrest-client";
import { API_BASE_URL } from "../../config/api-config";
/**
* 提出意见的请求参数接口
*/
export interface SubmitOpinionRequest {
reviewPointResultId: string | number;
documentId: string | number;
auditPoint: string;
foundIssue: string;
auditOpinion: string;
deductionScore: number;
}
/**
* 提出意见的响应接口
*/
export interface SubmitOpinionResponse {
success: boolean;
message: string;
data?: {
id: string | number;
created_at: string;
};
}
/**
* 交叉评查意见数据接口
*/
export interface CrossCheckingOpinion {
id: string | number;
evaluation_point_id: string | number;
document_id: string | number;
audit_point: string;
found_issue: string;
audit_opinion: string;
deduction_score: number;
status: string;
created_at: string;
updated_at?: string;
}
/**
* API响应格式
*/
export interface ApiResponse<T> {
data?: T;
error?: string;
status?: number;
}
/**
* 提交交叉评查意见
* @param opinionData 意见数据
* @returns 提交结果
*/
export async function submitCrossCheckingOpinion(
opinionData: SubmitOpinionRequest
): Promise<ApiResponse<SubmitOpinionResponse>> {
try {
const requestData = {
proposer_user_id: 1,
evaluation_result_id: opinionData.reviewPointResultId,
// document_id: opinionData.documentId,
// audit_point: opinionData.auditPoint,
// found_issue: opinionData.foundIssue,
proposed_score: opinionData.deductionScore,
reason: opinionData.auditOpinion
};
const response = await fetch(`${API_BASE_URL}/admin/cross_review/proposals`, {
method: 'POST',
headers: {
'Content-Type': 'application/json'
},
body: JSON.stringify(requestData)
});
const data = await response.json();
if (!response.ok) {
throw new Error(data.message || '提交失败');
}
return {
data: {
success: true,
message: '意见提交成功',
data: data
}
};
} catch (error) {
console.error('提交交叉评查意见失败:', error);
return {
error: error instanceof Error ? error.message : '提交意见失败',
status: 500
};
}
}
/**
* 获取交叉评查意见列表
* @param documentId 文档ID
* @returns 意见列表
*/
export async function getCrossCheckingOpinions(documentId: string | number): Promise<ApiResponse<CrossCheckingOpinion[]>> {
try {
const response = await postgrestPost('rpc/get_cross_checking_opinions', {
p_document_id: documentId
});
if (response.error) {
return {
error: response.error,
status: response.status || 500
};
}
return {
data: (response.data as CrossCheckingOpinion[]) || []
};
} catch (error) {
console.error('获取交叉评查意见失败:', error);
return {
error: error instanceof Error ? error.message : '获取意见列表失败',
status: 500
};
}
}
+39 -2
View File
@@ -109,6 +109,19 @@ interface ContractStructureComparison {
[key: string]: unknown;
}
// 定义评分提案数据接口
interface ScoringProposal {
id: string | number;
evaluation_result_id: string | number;
proposer_id: string | number;
proposed_score: number;
reason: string;
status: string;
created_at: string;
updated_at: string;
document_id: string | number;
}
/**
* 获取当前评查文件的所有评查点结果
* @param fileId 评查文件ID
@@ -294,6 +307,26 @@ export async function getReviewPoints(fileId: string) {
// console.log('groupsMap-------', groupsMap);
//从scoring_proposals表中获取评分提案数据,用于交叉评查
const scoringProposalsParams: PostgrestParams = {
select: '*',
filter: {
'document_id': `eq.${fileId}`
}
};
const scoringProposalsResponse = await postgrestGet('scoring_proposals', scoringProposalsParams);
if (scoringProposalsResponse.error) {
return { error: scoringProposalsResponse.error, status: scoringProposalsResponse.status };
}
const scoringProposalsData = extractApiData<ScoringProposal[]>(scoringProposalsResponse.data) || [];
// 构建前端所需的数据格式
const resultData: ReviewPointResult[] = evaluationResultsData.map(result => {
const point = pointsMap.get(result.evaluation_point_id) || {} as EvaluationPoint;
@@ -394,6 +427,10 @@ export async function getReviewPoints(fileId: string) {
// 评查配置: point.evaluation_config
evaluationConfig: point.evaluation_config || {},
// 评查点evaluation_point中的fail_message和pass_message 用于交叉评查的提出意见
failMessage: point.fail_message || '',
passMessage: point.pass_message || '',
evaluatedPointResultsLog: evaluatedPointResultsLog || {}
// evaluatedPointResultsLog: {
// rules:[
@@ -671,8 +708,8 @@ export async function getReviewPoints(fileId: string) {
issueCount: issueCount
};
// console.log("reviewInfo-------",JSON.stringify(reviewInfo,null,2));
// data->reviewPoints stats->statistics reviewInfo->reviewInfo document->document
return { data: resultData, stats, reviewInfo, document: documentData.data, comparison_document: comparisonDocument };
// data->reviewPoints stats->statistics reviewInfo->reviewInfo document->document scoring_proposals->scoringProposalsData
return { data: resultData, stats, reviewInfo, document: documentData.data, comparison_document: comparisonDocument, scoring_proposals: scoringProposalsData };
}
/**