147 lines
4.6 KiB
Vue
147 lines
4.6 KiB
Vue
|
|
<template>
|
|||
|
|
<div class="app-container">
|
|||
|
|
<div style="margin-bottom: 20px;display: flex;align-items: center;justify-content: space-between;">
|
|||
|
|
<div>
|
|||
|
|
{{ '盘点结果' }}
|
|||
|
|
<el-text v-show="dialogParams.status == 0">(当前为正常数据)</el-text>
|
|||
|
|
<el-text v-show="dialogParams.status == 1">(当前为未扫描到,但数据库里有的数据)</el-text>
|
|||
|
|
<el-text v-show="dialogParams.status == 2">(当前为已扫描到,但数据库里没有的数据)</el-text>
|
|||
|
|
</div>
|
|||
|
|
<el-button
|
|||
|
|
type="warning"
|
|||
|
|
plain
|
|||
|
|
icon="Download"
|
|||
|
|
@click="handleExport"
|
|||
|
|
>导出</el-button>
|
|||
|
|
</div>
|
|||
|
|
|
|||
|
|
|
|||
|
|
<el-tabs v-model="activeTabs" type="border-card" @tab-change="handleQueryInfo">
|
|||
|
|
<el-tab-pane v-for="item in statusList" :label="item.label" :name="item.value">
|
|||
|
|
<el-table :data="dialogData" border empty-text="暂无数据" v-if="dialogParams.status == 0 || dialogParams.status == 1">
|
|||
|
|
<el-table-column prop="rkPcode" label="存放位置" />
|
|||
|
|
<el-table-column prop="realQty" label="数量" />
|
|||
|
|
<el-table-column prop="count" label="操作" class-name="small-padding fixed-width">
|
|||
|
|
<template #default="scope">
|
|||
|
|
<el-button link type="primary" icon="View" @click="handleView(scope.row)">查看</el-button>
|
|||
|
|
</template>
|
|||
|
|
</el-table-column>
|
|||
|
|
</el-table>
|
|||
|
|
|
|||
|
|
<el-table :data="dialogData" border empty-text="暂无数据" v-if="dialogParams.status == 2">
|
|||
|
|
<el-table-column prop="rkPcode" label="存放位置" />
|
|||
|
|
</el-table>
|
|||
|
|
<div style="margin-top: 20px;width: 100%;display: flex;align-items: center;justify-content: flex-end;">
|
|||
|
|
<div style="margin-right: 20px;color: #606266;">共{{ dialogTotal }}条</div>
|
|||
|
|
<el-pagination background layout="prev, pager, next" :total="dialogTotal" @change="chageDialogPage" />
|
|||
|
|
</div>
|
|||
|
|
</el-tab-pane>
|
|||
|
|
</el-tabs>
|
|||
|
|
|
|||
|
|
|
|||
|
|
<el-dialog v-model="taskView" title="详情" width="85%" draggable>
|
|||
|
|
<el-table :data="viewData" border empty-text="暂无数据">
|
|||
|
|
<el-table-column prop="sapNo" label="订单" />
|
|||
|
|
<el-table-column prop="wlNo" label="物料号" />
|
|||
|
|
<el-table-column prop="wlMs" label="物料描述" />
|
|||
|
|
<el-table-column prop="realQty" label="数量">
|
|||
|
|
<template #default="scope">{{ scope.row.realQty }}({{ scope.row.dw }})</template>
|
|||
|
|
</el-table-column>
|
|||
|
|
<el-table-column prop="xmMs" label="项目名称" />
|
|||
|
|
<el-table-column prop="gysMc" label="供应商" />
|
|||
|
|
<el-table-column prop="cangkuName" label="所属仓库" />
|
|||
|
|
<el-table-column prop="rkTime" label="入库时间">
|
|||
|
|
<template #default="scope">{{ parseTime(scope.row.rkTime, '{y}-{m}-{d}') }}</template>
|
|||
|
|
</el-table-column>
|
|||
|
|
</el-table>
|
|||
|
|
<template #footer>
|
|||
|
|
<span class="dialog-footer">
|
|||
|
|
<el-button @click="taskView=false">关闭</el-button>
|
|||
|
|
</span>
|
|||
|
|
</template>
|
|||
|
|
</el-dialog>
|
|||
|
|
</div>
|
|||
|
|
</template>
|
|||
|
|
|
|||
|
|
<script setup name="InventoryResult">
|
|||
|
|
import { getScanResult, getStockList } from "@/api/Inventory/autoInventory";
|
|||
|
|
import { onMounted, ref } from "vue";
|
|||
|
|
import { useRoute } from 'vue-router';
|
|||
|
|
|
|||
|
|
const { proxy } = getCurrentInstance();
|
|||
|
|
|
|||
|
|
const statusList = ref(
|
|||
|
|
[
|
|||
|
|
{
|
|||
|
|
label: '正常',
|
|||
|
|
value: 0
|
|||
|
|
},
|
|||
|
|
{
|
|||
|
|
label: '未扫到',
|
|||
|
|
value: 1
|
|||
|
|
},
|
|||
|
|
{
|
|||
|
|
label: '无数据',
|
|||
|
|
value: 2
|
|||
|
|
}
|
|||
|
|
]
|
|||
|
|
) // 盘点状态
|
|||
|
|
const activeTabs = ref(0)
|
|||
|
|
const dialogParams = ref({
|
|||
|
|
status: 0,
|
|||
|
|
pageNum: 1,
|
|||
|
|
pageSize: 10,
|
|||
|
|
taskId: ""
|
|||
|
|
})
|
|||
|
|
const dialogData = ref([])
|
|||
|
|
const dialogTotal = ref(0)
|
|||
|
|
|
|||
|
|
const getHistoryInfo = () => {
|
|||
|
|
getScanResult(dialogParams.value).then(res => {
|
|||
|
|
dialogData.value = res.rows
|
|||
|
|
dialogTotal.value = res.total
|
|||
|
|
})
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
/** 导出按钮操作 */
|
|||
|
|
function handleExport() {
|
|||
|
|
proxy.download('/MatchScan/export', {taskId: dialogParams.value.taskId}, `盘点结果_${new Date().getTime()}.xlsx`)
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
const handleQueryInfo = (tab) => {
|
|||
|
|
dialogParams.value.status = tab
|
|||
|
|
dialogParams.value.pageNum = 1
|
|||
|
|
getHistoryInfo()
|
|||
|
|
}
|
|||
|
|
const chageDialogPage = (e) => {
|
|||
|
|
dialogParams.value.pageNum = e
|
|||
|
|
getHistoryInfo()
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
|
|||
|
|
const taskView = ref(false)
|
|||
|
|
const viewData = ref([])
|
|||
|
|
const handleView = (row) => {
|
|||
|
|
// let obj = {
|
|||
|
|
// pageNum: 1,
|
|||
|
|
// pageSize: 100,
|
|||
|
|
// pcode: row.rkPcode
|
|||
|
|
// }
|
|||
|
|
getStockList(row.rkPcode).then(res => {
|
|||
|
|
console.log(res)
|
|||
|
|
viewData.value = res.data
|
|||
|
|
taskView.value = true
|
|||
|
|
})
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
|
|||
|
|
const route = useRoute()
|
|||
|
|
onMounted(() => {
|
|||
|
|
dialogParams.value.taskId = route.query.taskId
|
|||
|
|
getHistoryInfo()
|
|||
|
|
})
|
|||
|
|
</script>
|
|||
|
|
|
|||
|
|
<style scoped lang="scss">
|
|||
|
|
</style>
|