115 lines
4.2 KiB
Vue
Raw Normal View History

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>