编辑情况优化-需要继续完善-暂存

This commit is contained in:
2025-04-07 20:24:52 +08:00
parent 046dd109e0
commit a5cad46a84
2 changed files with 188 additions and 75 deletions
+71 -60
View File
@@ -73,59 +73,60 @@ export function ReviewSettings({ onChange, initialData }: ReviewSettingsProps) {
// 使用useRef跟踪是否已经初始化过
const initializedRef = useRef(false);
// 保存初始数据的引用,用于检测是否有实际变更
const initialDataRef = useRef<any>(null);
// 加载初始数据
useEffect(() => {
// 如果已经初始化过,则跳过此次处理
if (initialData && !initializedRef.current) {
initializedRef.current = true;
console.log('加载初始数据(首次):', initialData);
// 设置规则
if (initialData.rules && initialData.rules.length > 0) {
// 确保每个规则都有完整的配置
const enhancedRules = initialData.rules.map(rule => {
// 根据规则类型,确保config包含必要的字段
let config = { ...rule.config };
// 确保有用于展示的字段
if (rule.type === 'format' && config.field && !config.checkField) {
config.checkField = config.field;
if (initializedRef.current) {
console.log("ReviewSettings已初始化,跳过后续初始化处理");
return;
}
// 记录初始化处理
console.log("ReviewSettings开始初始化,数据:", initialData);
// 保存初始数据引用,用于后续比较
initialDataRef.current = JSON.parse(JSON.stringify(initialData));
// 设置已初始化标记
initializedRef.current = true;
// 只有在有initialData时才进行初始化设置
if (initialData) {
// 处理初始规则数据
if (initialData.rules && Array.isArray(initialData.rules) && initialData.rules.length > 0) {
console.log("设置初始规则数据:", initialData.rules);
const validRules = initialData.rules.map(rule => {
// 确保每个规则都有id
if (!rule.id) {
rule.id = `rule_${Date.now()}_${Math.random().toString(36).substr(2, 9)}`;
}
if (rule.type === 'regex') {
if (config.field && !config.checkField) {
config.checkField = config.field;
}
if (config.pattern && !config.regexPattern) {
config.regexPattern = config.pattern;
}
// 确保配置对象存在
if (!rule.config) {
rule.config = {};
}
// 确保存在字段有正确的内部表示
if (rule.type === 'exists' && config.fields && !config.selectedFields) {
config.selectedFields = config.fields;
config.existsLogic = config.logic || 'all';
// 添加可用字段
if (availableFields.length > 0) {
rule.config.availableFields = availableFields;
}
// 对于条件逻辑规则
if ((rule.type === 'consistency' || rule.type === 'logic') && config.logic && !config.logicRelation) {
config.logicRelation = config.logic;
}
// 确保所有规则都有可用字段列表
if (!config.availableFields) {
config.availableFields = availableFields;
}
return {
...rule,
config
};
return rule;
});
console.log('增强后的规则(首次):', enhancedRules);
setRules(enhancedRules);
// 如果没有规则或规则为空,添加一个默认规则
if (validRules.length === 0) {
validRules.push({ id: '1', type: '', config: { availableFields } });
}
setRules(validRules);
} else {
// 如果rules为空或不是数组,添加一个默认规则
setRules([{ id: '1', type: '', config: { availableFields } }]);
}
// 设置组合逻辑
@@ -1520,7 +1521,7 @@ export function ReviewSettings({ onChange, initialData }: ReviewSettingsProps) {
break;
}
// 移除只在UI使用的字段
// 移除辅助用的UI字段
delete processedConfig.availableFields;
return {
@@ -1528,30 +1529,40 @@ export function ReviewSettings({ onChange, initialData }: ReviewSettingsProps) {
type: rule.type,
config: processedConfig
};
})
}).filter(rule => rule.type && rule.type.trim() !== '')
};
if (onChange) {
const updateData = {
rules: config.rules,
combinationLogic: config.logicType,
customLogic: config.customLogic,
pass_message: pass_message,
fail_message: fail_message,
suggestion_message: suggestion_message,
suggestion_message_type: suggestion_message_type,
post_action: post_action,
action_config: action_config,
score: score,
scoreDisplay: scoreDisplay
};
onChange(updateData);
}
// 使用setTimeout避免连锁更新
setTimeout(() => {
if (onChange) {
onChange({
rules: config.rules,
combinationLogic: config.logicType,
customLogic: config.customLogic,
pass_message: pass_message,
fail_message: fail_message,
suggestion_message: suggestion_message,
suggestion_message_type: suggestion_message_type,
post_action: post_action,
action_config: action_config,
score: score,
scoreDisplay: scoreDisplay
});
}
}, 0);
return config;
}, [rules, combinationLogic, customLogic, pass_message, fail_message, suggestion_message, suggestion_message_type, post_action, action_config, score, scoreDisplay, onChange]);
// 组件初次渲染后,主动发送一次完整配置数据
useEffect(() => {
// 如果有初始数据,在组件挂载后主动发送一次完整规则配置
if (initialDataRef.current && onChange) {
console.log("组件挂载后发送初始完整配置");
setTimeout(() => generateEvaluationConfig(), 100);
}
}, [generateEvaluationConfig, onChange]);
// 处理评查结果消息变更
const handleMessageChange = (type: string, value: string) => {
switch(type) {
+117 -15
View File
@@ -174,6 +174,20 @@ interface ApiResponse {
[key: string]: unknown;
}
// 深拷贝工具函数
function deepClone<T>(obj: T): T {
if (obj === null || obj === undefined || typeof obj !== 'object') {
return obj;
}
try {
return JSON.parse(JSON.stringify(obj));
} catch (err) {
console.error('深拷贝对象失败:', err);
return obj;
}
}
export default function RuleNew() {
const navigate = useNavigate();
const location = useLocation();
@@ -442,7 +456,7 @@ export default function RuleNew() {
console.log("提取配置:", extractionConfig);
console.log("评查配置:", evaluationConfig);
console.log("分数:", pointData.score);
console.log("评查规则详细信息:", JSON.stringify(evaluationConfig.rules || [], null, 2));
// 提取字段列表,用于规则设置
const extractedFields: string[] = [];
@@ -548,7 +562,7 @@ export default function RuleNew() {
evaluation_config: {
logicType: evaluationConfig.logicType || 'and',
customLogic: evaluationConfig.customLogic || '',
rules: (evaluationConfig.rules || []).map((rule) => {
rules: validateAndFixRules((evaluationConfig.rules || []).map((rule) => {
// 将API规则格式转换为UI使用的格式
let config: RuleConfigType = {};
@@ -607,12 +621,17 @@ export default function RuleNew() {
config = rule.config || {};
}
// 保存原始规则数据以便后续处理
if (typeof config === 'object' && config !== null) {
config._originalData = JSON.parse(JSON.stringify(rule.config || {}));
}
return {
id: rule.id,
type: rule.type,
config
};
})
}))
},
pass_message: pointData.pass_message || '文档检查通过,符合规范要求。',
@@ -810,9 +829,12 @@ export default function RuleNew() {
// 记录所有收到的数据
console.log("评查设置更新数据:", data);
// 更新规则
// 更新规则 - 只有当明确提供了rules数据时才更新
if (data.rules) {
updatedData.evaluation_config.rules = data.rules as Rule[];
// 验证并修复规则数据
const validatedRules = validateAndFixRules(data.rules as Rule[]);
console.log("规则数据验证后:", validatedRules);
updatedData.evaluation_config.rules = validatedRules;
}
// 更新组合逻辑
@@ -866,8 +888,49 @@ export default function RuleNew() {
});
};
// 检查并修复评查规则数据,确保数据的完整性
const validateAndFixRules = (rules: Rule[] | undefined): Rule[] => {
if (!rules || !Array.isArray(rules)) {
console.log("规则数据无效或为空,返回空数组");
return [];
}
// 过滤无效规则,确保每个规则都有type字段
const validRules = rules.filter(rule => {
if (!rule || typeof rule !== 'object') {
console.log("发现无效规则对象:", rule);
return false;
}
if (!rule.type || typeof rule.type !== 'string' || rule.type.trim() === '') {
console.log("发现无效规则类型:", rule);
return false;
}
if (!rule.id || typeof rule.id !== 'string') {
console.log("发现缺少ID的规则:", rule);
// 为缺少ID的规则自动生成ID
rule.id = `rule_${Date.now()}_${Math.random().toString(36).substr(2, 9)}`;
}
// 确保config存在
if (!rule.config || typeof rule.config !== 'object') {
console.log("规则缺少配置对象,自动创建:", rule);
rule.config = {};
}
return true;
});
console.log(`规则验证结果: 输入${rules.length}条,有效${validRules.length}`);
return validRules;
};
// 格式化数据,准备提交到接口
const formatDataForApi = (formData: FormDataType, isDraft: boolean = false) => {
// 记录规则处理前的数据
console.log("格式化前的评查规则数据:", formData.evaluation_config?.rules || []);
// 转换提取配置为符合数据库格式的JSON
const extractionConfig = {
llm: {
@@ -906,11 +969,15 @@ export default function RuleNew() {
}
};
// 确保规则数据有效
const validatedRules = validateAndFixRules(formData.evaluation_config.rules || []);
console.log("验证后的评查规则数量:", validatedRules.length);
// 转换评查配置为符合数据库格式的JSON
const evaluationConfig = {
logicType: formData.evaluation_config.logicType || 'and',
customLogic: formData.evaluation_config.customLogic || '',
rules: (formData.evaluation_config.rules || [])
rules: validatedRules
.filter((rule: Rule) => rule.type && rule.type.trim() !== '')
.map((rule: Rule) => {
let config = {};
@@ -919,14 +986,14 @@ export default function RuleNew() {
switch (rule.type) {
case 'exists':
config = {
fields: rule.config?.fields || [],
logic: rule.config?.logicRelation || 'and'
fields: rule.config?.fields || rule.config?.selectedFields || [],
logic: rule.config?.logic || rule.config?.logicRelation || 'and'
};
break;
case 'consistency':
config = {
pairs: rule.config?.pairs || [],
logic: rule.config?.logicRelation || 'and'
logic: rule.config?.logic || rule.config?.logicRelation || 'and'
};
break;
case 'format':
@@ -939,7 +1006,7 @@ export default function RuleNew() {
case 'logic':
config = {
conditions: rule.config?.conditions || [],
logic: rule.config?.logicRelation || 'and'
logic: rule.config?.logic || rule.config?.logicRelation || 'and'
};
break;
case 'regex':
@@ -963,10 +1030,16 @@ export default function RuleNew() {
};
break;
default:
config = { ...rule.config };
// 如果有保存的原始数据,优先使用
if (rule.config?._originalData) {
config = { ...rule.config._originalData };
} else {
config = { ...rule.config };
}
// 清除辅助字段,避免发送无效数据
if (typeof config === 'object' && config !== null) {
delete (config as Record<string, unknown>).availableFields;
delete (config as Record<string, unknown>)._originalData;
}
}
@@ -977,6 +1050,9 @@ export default function RuleNew() {
};
})
};
// 记录规则处理后的数据
console.log("处理后的评查规则数据:", evaluationConfig.rules);
// 构建完整的评查点数据
const evaluationPointData: Record<string, unknown> = {
@@ -1029,6 +1105,9 @@ export default function RuleNew() {
try {
setIsLoading(true);
// 记录当前评查规则状态
console.log("保存前评查规则状态:", formData.evaluation_config.rules);
// 基本验证
if (!formData.name || !formData.code) {
alert("请填写评查点名称和编码,这些是必填项");
@@ -1050,14 +1129,33 @@ export default function RuleNew() {
return;
}
// 检查评查规则
if (!formData.evaluation_config.rules || formData.evaluation_config.rules.length === 0 ||
!formData.evaluation_config.rules.some(rule => rule.type && rule.type.trim() !== '')) {
// 检查评查规则 - 只在新增模式下检查规则是否为空
if (!isEditMode &&
(!formData.evaluation_config.rules ||
formData.evaluation_config.rules.length === 0 ||
!formData.evaluation_config.rules.some(rule => rule.type && rule.type.trim() !== ''))) {
console.log("规则验证失败,当前规则:", formData.evaluation_config.rules);
console.log("规则数量:", formData.evaluation_config.rules?.length || 0);
console.log("规则有效性:", formData.evaluation_config.rules?.some(rule => rule.type && rule.type.trim() !== ''));
alert("请至少添加一条有效的评查规则");
setIsLoading(false);
return;
}
// 编辑模式下,只有当规则数组不为空时才验证规则有效性
if (isEditMode &&
formData.evaluation_config.rules &&
formData.evaluation_config.rules.length > 0 &&
!formData.evaluation_config.rules.some(rule => rule.type && rule.type.trim() !== '')) {
console.log("编辑模式下规则无效,当前规则:", formData.evaluation_config.rules);
console.log("编辑模式-规则数量:", formData.evaluation_config.rules.length);
console.log("编辑模式-规则详情:", JSON.stringify(formData.evaluation_config.rules, null, 2));
console.log("编辑模式-规则有效性:", formData.evaluation_config.rules.some(rule => rule.type && rule.type.trim() !== ''));
alert("请至少添加一条有效的评查规则或清空规则列表");
setIsLoading(false);
return;
}
const evaluationPointData = formatDataForApi(formData);
console.log("保存数据:", evaluationPointData);
@@ -1142,6 +1240,9 @@ export default function RuleNew() {
return;
}
// 编辑模式下不检查评查规则是否为空
// 草稿模式下规则可以为空
const draftData = formatDataForApi(formData, true);
console.log("保存草稿数据:", draftData);
@@ -1390,9 +1491,10 @@ export default function RuleNew() {
<div className="mb-8">
<RuleContext.Provider value={{ extractionFields, updateFields: updateExtractionFields }}>
<ReviewSettings
key={`review-settings-${isEditMode ? formData.id : 'new'}`}
onChange={handleReviewSettingsChange}
initialData={{
rules: formData.evaluation_config.rules,
rules: deepClone(formData.evaluation_config.rules),
combinationLogic: formData.evaluation_config.logicType,
customLogic: formData.evaluation_config.customLogic,
pass_message: formData.pass_message,