2025-07-15 17:02:25 +08:00
|
|
|
<!-- QuarantineList.vue -->
|
2025-07-14 19:12:50 +08:00
|
|
|
<template>
|
|
|
|
<div class="app-container">
|
|
|
|
<el-form :model="queryParams" ref="queryRef" :inline="true" v-show="showSearch" label-width="68px">
|
|
|
|
<el-form-item label="羊只" prop="sheepId">
|
2025-07-15 17:02:25 +08:00
|
|
|
<el-input v-model="queryParams.sheepId" placeholder="请输入耳号" clearable @keyup.enter="handleQuery" />
|
2025-07-14 19:12:50 +08:00
|
|
|
</el-form-item>
|
|
|
|
<el-form-item label="检疫日期" style="width: 308px">
|
2025-07-15 17:02:25 +08:00
|
|
|
<el-date-picker v-model="daterangeDatetime" value-format="YYYY-MM-DD" type="daterange" range-separator="-"
|
|
|
|
start-placeholder="开始日期" end-placeholder="结束日期" />
|
2025-07-14 19:12:50 +08:00
|
|
|
</el-form-item>
|
|
|
|
<el-form-item>
|
|
|
|
<el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button>
|
|
|
|
<el-button icon="Refresh" @click="resetQuery">重置</el-button>
|
|
|
|
</el-form-item>
|
|
|
|
</el-form>
|
|
|
|
|
|
|
|
<el-row :gutter="10" class="mb8">
|
|
|
|
<el-col :span="1.5">
|
2025-07-15 17:02:25 +08:00
|
|
|
<el-button type="primary" plain icon="Plus" @click="openDialog()">新增</el-button>
|
2025-07-14 19:12:50 +08:00
|
|
|
</el-col>
|
|
|
|
</el-row>
|
|
|
|
|
|
|
|
<el-table v-loading="loading" :data="quarantineList" @selection-change="handleSelectionChange">
|
|
|
|
<el-table-column type="selection" width="55" align="center" />
|
|
|
|
<el-table-column label="羊只" align="center" prop="sheepNo" />
|
|
|
|
<el-table-column label="检疫日期" align="center" prop="datetime" width="180">
|
|
|
|
<template #default="scope">
|
|
|
|
<span>{{ parseTime(scope.row.datetime, '{y}-{m}-{d}') }}</span>
|
|
|
|
</template>
|
|
|
|
</el-table-column>
|
2025-07-15 17:02:25 +08:00
|
|
|
<el-table-column label="羊只性别" align="center" prop="gender" />
|
2025-07-14 19:12:50 +08:00
|
|
|
<el-table-column label="羊只类别" align="center" prop="sheepType" />
|
|
|
|
<el-table-column label="月龄" align="center" prop="monthAge" />
|
|
|
|
<el-table-column label="繁育状态" align="center" prop="breed" />
|
|
|
|
<el-table-column label="检疫项目" align="center" prop="itemName" />
|
|
|
|
<el-table-column label="样品类型" align="center" prop="sample" />
|
|
|
|
<el-table-column label="采样员" align="center" prop="sampler" />
|
|
|
|
<el-table-column label="检疫员" align="center" prop="quarOfficer" />
|
|
|
|
<el-table-column label="检疫结果" align="center" prop="result">
|
|
|
|
<template #default="scope">
|
2025-07-15 17:02:25 +08:00
|
|
|
<dict-tag :options="quar_result" :value="scope.row.result" />
|
2025-07-14 19:12:50 +08:00
|
|
|
</template>
|
|
|
|
</el-table-column>
|
|
|
|
<el-table-column label="状态" align="center" prop="status">
|
|
|
|
<template #default="scope">
|
2025-07-15 17:02:25 +08:00
|
|
|
<dict-tag :options="quar_status" :value="scope.row.status" />
|
2025-07-14 19:12:50 +08:00
|
|
|
</template>
|
|
|
|
</el-table-column>
|
2025-07-15 17:02:25 +08:00
|
|
|
<el-table-column label="操作" align="center" width="200">
|
2025-07-14 19:12:50 +08:00
|
|
|
<template #default="scope">
|
2025-07-15 17:02:25 +08:00
|
|
|
<el-button link type="primary" @click="openDialog(scope.row)">检疫</el-button>
|
2025-07-14 19:12:50 +08:00
|
|
|
</template>
|
|
|
|
</el-table-column>
|
|
|
|
</el-table>
|
|
|
|
|
2025-07-15 17:02:25 +08:00
|
|
|
<pagination v-show="total > 0" :total="total" v-model:page="queryParams.pageNum"
|
|
|
|
v-model:limit="queryParams.pageSize" @pagination="getList" />
|
|
|
|
|
|
|
|
<!-- 弹窗组件 -->
|
|
|
|
<add ref="dialogRef" @success="getList" />
|
2025-07-14 19:12:50 +08:00
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
2025-07-15 17:02:25 +08:00
|
|
|
<script setup name="QuarantineList">
|
|
|
|
import { listQuarantine } from '@/api/biosafety/quarantine'
|
|
|
|
import add from './add.vue'
|
2025-07-14 19:12:50 +08:00
|
|
|
const { proxy } = getCurrentInstance()
|
|
|
|
const { quar_result, quar_status } = proxy.useDict('quar_result', 'quar_status')
|
|
|
|
|
2025-07-15 17:02:25 +08:00
|
|
|
const dialogRef = ref()
|
2025-07-14 19:12:50 +08:00
|
|
|
const quarantineList = ref([])
|
|
|
|
const loading = ref(true)
|
|
|
|
const showSearch = ref(true)
|
|
|
|
const total = ref(0)
|
|
|
|
const daterangeDatetime = ref([])
|
|
|
|
|
2025-07-15 17:02:25 +08:00
|
|
|
const queryParams = reactive({
|
|
|
|
pageNum: 1,
|
|
|
|
pageSize: 10,
|
|
|
|
sheepId: null,
|
|
|
|
params: {}
|
2025-07-14 19:12:50 +08:00
|
|
|
})
|
|
|
|
|
|
|
|
function getList() {
|
|
|
|
loading.value = true
|
2025-07-15 17:02:25 +08:00
|
|
|
queryParams.params = {}
|
|
|
|
if (daterangeDatetime.value && daterangeDatetime.value.length === 2) {
|
|
|
|
queryParams.params.beginDatetime = daterangeDatetime.value[0]
|
|
|
|
queryParams.params.endDatetime = daterangeDatetime.value[1]
|
2025-07-14 19:12:50 +08:00
|
|
|
}
|
2025-07-15 17:02:25 +08:00
|
|
|
listQuarantine(queryParams).then(res => {
|
|
|
|
quarantineList.value = res.rows
|
|
|
|
total.value = res.total
|
2025-07-14 19:12:50 +08:00
|
|
|
loading.value = false
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2025-07-15 17:02:25 +08:00
|
|
|
function openDialog(row = null) {
|
|
|
|
dialogRef.value.open(row)
|
2025-07-14 19:12:50 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
function handleQuery() {
|
2025-07-15 17:02:25 +08:00
|
|
|
queryParams.pageNum = 1
|
2025-07-14 19:12:50 +08:00
|
|
|
getList()
|
|
|
|
}
|
|
|
|
|
|
|
|
function resetQuery() {
|
2025-07-15 17:02:25 +08:00
|
|
|
proxy.resetForm('queryRef')
|
2025-07-14 19:12:50 +08:00
|
|
|
daterangeDatetime.value = []
|
|
|
|
handleQuery()
|
|
|
|
}
|
|
|
|
|
|
|
|
getList()
|
2025-07-15 17:02:25 +08:00
|
|
|
</script>
|