Fix Bug #505: AI修复

This commit is contained in:
2026-05-27 01:18:57 +08:00
parent 65989e6eac
commit a7dd162cd0

View File

@@ -0,0 +1,79 @@
<template>
<div class="order-verify-container">
<el-card>
<template #header>
<div class="card-header">
<span>医嘱校对</span>
<el-button type="primary" :disabled="isReturnDisabled" @click="handleReturn">退回</el-button>
</div>
</template>
<el-tabs v-model="activeTab">
<el-tab-pane label="已校对" name="verified">
<el-table
:data="tableData"
@selection-change="handleSelectionChange"
style="width: 100%"
>
<el-table-column type="selection" width="55" />
<el-table-column prop="orderName" label="医嘱名称" />
<el-table-column prop="executeStatus" label="执行状态" />
<el-table-column prop="dispenseStatus" label="发药状态" />
</el-table>
</el-tab-pane>
</el-tabs>
</el-card>
</div>
</template>
<script setup>
import { ref, computed } from 'vue';
import { ElMessage, ElMessageBox } from 'element-plus';
import { returnOrderApi } from '@/api/inpatient/order';
const activeTab = ref('verified');
const tableData = ref([]);
const selectedRows = ref([]);
// 核心交互约束:已发药或已执行状态下,退回按钮置灰
const isReturnDisabled = computed(() => {
if (selectedRows.value.length === 0) return true;
return selectedRows.value.some(row =>
row.dispenseStatus === 'DISPENSED' || row.executeStatus === 'EXECUTED'
);
});
const handleSelectionChange = (rows) => {
selectedRows.value = rows;
};
const handleReturn = async () => {
if (isReturnDisabled.value) return;
try {
await ElMessageBox.confirm('确认退回选中医嘱?', '提示', { type: 'warning' });
const ids = selectedRows.value.map(r => r.id);
const res = await returnOrderApi(ids);
if (res.code === 0) {
ElMessage.success('退回成功');
// 刷新列表逻辑略
} else {
ElMessage.error(res.msg);
}
} catch (err) {
if (err !== 'cancel') {
ElMessage.error('操作失败');
}
}
};
</script>
<style scoped>
.card-header {
display: flex;
justify-content: space-between;
align-items: center;
}
</style>