Backup local changes before resolving remote repository issue
This commit is contained in:
@@ -109,16 +109,25 @@ const getList = () => {
|
||||
});
|
||||
};
|
||||
|
||||
// 标记是否已经手动选择过患者,防止后续自动选择
|
||||
const hasManuallySelectedPatient = ref(false);
|
||||
|
||||
// 添加一个变量来跟踪当前期望的患者ID
|
||||
let expectedPatientId = null;
|
||||
|
||||
watch(
|
||||
() => filteredCardData.value,
|
||||
(newData) => {
|
||||
// 如果有数据且当前没有选中患者,且是首次加载,默认选择第一条
|
||||
// 只有在从未手动选择过患者的情况下才自动选择
|
||||
// 并且确保当前没有正在处理的患者切换操作
|
||||
if (
|
||||
newData &&
|
||||
newData.length > 0 &&
|
||||
!cardId.value &&
|
||||
isFirstLoad.value &&
|
||||
!patientInfo.value?.encounterId
|
||||
!patientInfo.value?.encounterId &&
|
||||
!hasManuallySelectedPatient.value
|
||||
) {
|
||||
const firstPatient = newData[0];
|
||||
if (firstPatient?.encounterId) {
|
||||
@@ -130,34 +139,81 @@ watch(
|
||||
debounceTimer = setTimeout(() => {
|
||||
handleItemClick(firstPatient);
|
||||
isFirstLoad.value = false;
|
||||
hasManuallySelectedPatient.value = true; // 标记已手动选择过
|
||||
}, 100);
|
||||
}
|
||||
} else if (expectedPatientId && cardId.value && cardId.value !== expectedPatientId) {
|
||||
// 如果当前cardId与期望的不一致,且不是初始状态,这可能意味着发生了意外的重置
|
||||
// 这种情况下,我们不希望自动选择第一个患者
|
||||
console.debug(`期望的患者ID: ${expectedPatientId}, 当前cardId: ${cardId.value}`);
|
||||
}
|
||||
},
|
||||
{ immediate: true }
|
||||
);
|
||||
|
||||
// 防抖函数,防止快速点击导致状态冲突
|
||||
let debounceTimer = null;
|
||||
// 更新handleItemClick函数,设置期望的患者ID
|
||||
const handleItemClick = (node) => {
|
||||
// 设置期望的患者ID
|
||||
expectedPatientId = node.encounterId;
|
||||
|
||||
// 清除之前的计时器
|
||||
if (debounceTimer) {
|
||||
clearTimeout(debounceTimer);
|
||||
}
|
||||
|
||||
// 取消之前未完成的患者加载操作
|
||||
if (currentPatientPromise) {
|
||||
// 注意:这里无法真正取消Promise,但我们可以标记当前操作已过期
|
||||
currentPatientPromise.cancelled = true;
|
||||
}
|
||||
|
||||
// 设置新的计时器
|
||||
debounceTimer = setTimeout(() => {
|
||||
debounceTimer = setTimeout(async () => {
|
||||
// 检查是否已被取消
|
||||
if (currentPatientPromise?.cancelled) {
|
||||
return;
|
||||
}
|
||||
|
||||
cardId.value = node.encounterId;
|
||||
// 同时更新本地和全局状态,确保模块内组件和跨模块组件都能正确响应
|
||||
updatePatientInfo(node);
|
||||
updateLocalPatientInfo(node);
|
||||
|
||||
diagnosisRef.value?.getList();
|
||||
adviceRef.value?.getListInfo();
|
||||
adviceRef.value?.getDiagnosisInfo();
|
||||
// 标记已手动选择患者,防止自动选择第一条
|
||||
hasManuallySelectedPatient.value = true;
|
||||
|
||||
// 创建一个新的Promise来追踪这次加载操作
|
||||
currentPatientPromise = Promise.all([
|
||||
// 并行调用医嘱相关的API,避免重复请求
|
||||
adviceRef.value?.getListInfo().catch(error => {
|
||||
console.error('获取医嘱信息失败:', error);
|
||||
return null;
|
||||
}),
|
||||
adviceRef.value?.getDiagnosisInfo().catch(error => {
|
||||
console.error('获取诊断信息失败:', error);
|
||||
return null;
|
||||
}),
|
||||
// 获取诊断信息
|
||||
diagnosisRef.value?.getList?.().catch(error => {
|
||||
console.error('获取诊断信息失败:', error);
|
||||
return null;
|
||||
})
|
||||
]);
|
||||
|
||||
try {
|
||||
await currentPatientPromise;
|
||||
// 检查在此期间是否选择了其他患者
|
||||
if (currentPatientPromise?.cancelled) {
|
||||
return;
|
||||
}
|
||||
} catch (error) {
|
||||
console.error('加载患者信息时出错:', error);
|
||||
}
|
||||
}, 100); // 100ms 防抖延迟
|
||||
};
|
||||
|
||||
// 防抖函数,防止快速点击导致状态冲突
|
||||
|
||||
const handleSearch = (keyword) => {
|
||||
searchData.keyword = keyword;
|
||||
getList();
|
||||
|
||||
Reference in New Issue
Block a user