Compare commits

..

No commits in common. "c4a61f5b1ec0c0e6a8e19f053c3bf2cabf77360f" and "4452edc5178a6fe75ef4fed5a6b2281458a3f801" have entirely different histories.

3 changed files with 241 additions and 315 deletions

View File

@ -208,16 +208,6 @@ const downloadKateOrdersExcel = (data) => {
}) })
} }
const downloadPickTaskRecordsExcel = (data) => {
return request({
url: '/excel/downloadPickTaskRecordsExcel',
method: 'post',
responseType: 'blob',
data: data,
timeout: 600000
})
}
export { export {
uploadExcelStock, uploadExcelStock,
uploadExcelGoods, uploadExcelGoods,
@ -240,6 +230,5 @@ export {
uploadWorkFlow, uploadWorkFlow,
uploadExcelWorkDate, uploadExcelWorkDate,
downloadWorkFlowExcel, downloadWorkFlowExcel,
downloadKateOrdersExcel, downloadKateOrdersExcel
downloadPickTaskRecordsExcel
} }

View File

@ -402,7 +402,7 @@ export default {
// let blob = new Blob([res.data],{type: 'application/vnd.ms-excel'}); //blobblobtypexls // let blob = new Blob([res.data],{type: 'application/vnd.ms-excel'}); //blobblobtypexls
let blob = res.data //blob let blob = res.data //blob
// let _fileName = res.headers['content-disposition'].split(';')[1].split('=')[1]; // // let _fileName = res.headers['content-disposition'].split(';')[1].split('=')[1]; //
let _fileName = "未做工单报表" + dateFormatter(this.planStartDateQuery) + ".xlsx" let _fileName = "工单报表" + dateFormatter(new Date) + ".xlsx"
link.style.display = 'none'// link.style.display = 'none'//
// URL // URL

View File

@ -1,356 +1,293 @@
<template> <template>
<div style="margin-bottom: 10px; height: 100%; padding-left: 1%; padding-right: 1%;"> <div style="margin-bottom: 10px; height: 100%; padding-left: 1%; padding-right: 1%;">
<el-config-provider :locale="zhCn"> <el-config-provider :locale="zhCn">
<div style="display: flex;justify-content: space-between;"> <div style="display: flex;justify-content: space-between;">
<el-row> <el-row>
<el-input v-model="vehicleIdQuery" style="width: 158px; margin-right: 10px;" placeholder="箱号" <el-input v-model="vehicleIdQuery" style="width: 158px; margin-right: 10px;" placeholder="箱号"
:suffix-icon="Search"/> :suffix-icon="Search" />
<el-input v-model="standQuery" style="width: 158px; margin-right: 10px;" placeholder="工站" <el-input v-model="standQuery" style="width: 158px; margin-right: 10px;" placeholder="工站"
:suffix-icon="Search"/> :suffix-icon="Search" />
<el-select-v2 v-model="pickStatusQuery" style="width: 158px; margin-right: 10px;" <el-select-v2 v-model="pickStatusQuery" style="width: 158px; margin-right: 10px;"
placeholder="请选择状态" :options="pickStatusOptions" @change="search()"></el-select-v2> placeholder="请选择状态" :options="pickStatusOptions" @change="search()"></el-select-v2>
<el-button type="primary" @click="search()">搜索</el-button> <el-button type="primary" @click="search()">搜索</el-button>
<el-button type="warning" @click="reset()">重置</el-button> <el-button type="warning" @click="reset()">重置</el-button>
</el-row> </el-row>
<el-row> </div>
<el-date-picker v-model="dateQuery" type="date" placeholder="任务日期" :shortcuts="shortcuts" <br />
style="width: 158px; margin-right: 10px;" clearable/> <el-table :data="pickTaskList" stripe border v-loading="loading" class="table-class" highlight-current-row
<el-button style="background-color: #00CED1; color: #000; width: 120px"
@click="exportPickTaskRecords()">导出拣选任务记录
</el-button>
</el-row>
</div>
<br/>
<el-table :data="pickTaskList" stripe border v-loading="loading" class="table-class" highlight-current-row
max-height="650px" @row-click="getCurrentRow" :header-cell-style="{ 'text-align': 'center' }" max-height="650px" @row-click="getCurrentRow" :header-cell-style="{ 'text-align': 'center' }"
:cell-style="{ 'text-align': 'center' }"> :cell-style="{ 'text-align': 'center' }">
<el-table-column width="65px" fixed="left"> <el-table-column width="65px" fixed="left">
<template v-slot="scope"> <template v-slot="scope">
<el-radio :label="scope.row.pickTaskId" v-model="pickTaskId">&nbsp;</el-radio> <el-radio :label="scope.row.pickTaskId" v-model="pickTaskId">&nbsp;</el-radio>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column prop="pickTaskId" label="id" fixed="left" min-width="120px" show-overflow-tooltip/> <el-table-column prop="pickTaskId" label="id" fixed="left" min-width="120px" show-overflow-tooltip />
<el-table-column prop="vehicleId" label="箱号" fixed="left" min-width="120px"/> <el-table-column prop="vehicleId" label="箱号" fixed="left" min-width="120px" />
<el-table-column prop="standId" label="站台号" fixed="left" min-width="120px"/> <el-table-column prop="standId" label="站台号" fixed="left" min-width="120px" />
<el-table-column prop="pickStatus" label="拣选状态" :formatter="pickStatusFormat" min-width="120px"/> <el-table-column prop="pickStatus" label="拣选状态" :formatter="pickStatusFormat" min-width="120px" />
<el-table-column prop="lastUpdateTime" label="最近更新时间" :formatter="timeFormat" show-overflow-tooltip <el-table-column prop="lastUpdateTime" label="最近更新时间" :formatter="timeFormat" show-overflow-tooltip
min-width="120px"/> min-width="120px" />
<el-table-column fixed="right" label="操作" width="120px"> <el-table-column fixed="right" label="操作" width="120px">
<template v-slot="scope"> <template v-slot="scope">
<el-button plain type="primary" @click="editCurrentRow(scope.row)">编辑</el-button> <el-button plain type="primary" @click="editCurrentRow(scope.row)">编辑</el-button>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
<br/> <br />
<el-pagination v-model:current-page="currentPage" v-model:page-size="pageSize" :page-sizes="[10, 25, 50]" <el-pagination v-model:current-page="currentPage" v-model:page-size="pageSize" :page-sizes="[10, 25, 50]"
:small="false" :disabled="false" :background="false" :default-page-size="10" :small="false" :disabled="false" :background="false" :default-page-size="10"
layout="total, sizes, prev, pager, next, jumper" :total="total" @size-change="search" layout="total, sizes, prev, pager, next, jumper" :total="total" @size-change="search"
@current-change="search"/> @current-change="search" />
<el-dialog v-model="dialogVisible" title="拣选任务详细信息" width="40%" draggable :show-close="false"> <el-dialog v-model="dialogVisible" title="拣选任务详细信息" width="40%" draggable :show-close="false">
<div <div
style="max-width: 100%; max-height: 500px; overflow: auto; display: flex; justify-content: center;"> style="max-width: 100%; max-height: 500px; overflow: auto; display: flex; justify-content: center;">
<el-form ref="pickTaskFormRef" :model="pickTaskFormEntity" :label-position="labelPosition" <el-form ref="pickTaskFormRef" :model="pickTaskFormEntity" :label-position="labelPosition"
label-width="100px" style="width: 95%;" :rules="rules" status-icon> label-width="100px" style="width: 95%;" :rules="rules" status-icon>
<el-row :gutter="16"> <el-row :gutter="16">
<el-col :span="12" :offset="0"> <el-col :span="12" :offset="0">
<el-form-item label="id" prop="pickTaskId"> <el-form-item label="id" prop="pickTaskId">
<el-input v-model="pickTaskFormEntity.pickTaskId" disabled/> <el-input v-model="pickTaskFormEntity.pickTaskId" disabled />
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="12"> <el-col :span="12">
<el-form-item label="工站" prop="vehicleId"> <el-form-item label="工站" prop="vehicleId">
<el-input v-model="pickTaskFormEntity.vehicleId" disabled/> <el-input v-model="pickTaskFormEntity.vehicleId" disabled />
</el-form-item> </el-form-item>
</el-col> </el-col>
</el-row> </el-row>
<el-row :gutter="16"> <el-row :gutter="16">
<el-col :span="12" :offset="0"> <el-col :span="12" :offset="0">
<el-form-item label="小盒子" prop="standId"> <el-form-item label="小盒子" prop="standId">
<el-input v-model="pickTaskFormEntity.standId" disabled/> <el-input v-model="pickTaskFormEntity.standId" disabled />
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="12"> <el-col :span="12">
<el-form-item label="任务状态" prop="pickStatus"> <el-form-item label="任务状态" prop="pickStatus">
<el-select-v2 v-model="pickTaskFormEntity.pickStatus" placeholder="请选择任务状态" <el-select-v2 v-model="pickTaskFormEntity.pickStatus" placeholder="请选择任务状态"
:options="taskStatusOptions"></el-select-v2> :options="taskStatusOptions"></el-select-v2>
</el-form-item> </el-form-item>
</el-col> </el-col>
</el-row> </el-row>
</el-form> </el-form>
</div> </div>
<template #footer> <template #footer>
<span class="dialog-footer"> <span class="dialog-footer">
<el-button @click="dialogVisible = false">取消</el-button> <el-button @click="dialogVisible = false">取消</el-button>
<el-button type="primary" @click="submitInfo(pickTaskFormEntity)"> <el-button type="primary" @click="submitInfo(pickTaskFormEntity)">
确定 确定
</el-button> </el-button>
</span> </span>
</template> </template>
</el-dialog> </el-dialog>
</el-config-provider> </el-config-provider>
</div> </div>
</template> </template>
<script setup> <script setup>
import store from '@/store' import store from '@/store'
import {getPickTasksByPage, updatePickTaskInfo} from '@/api/taskMonitor.js' import { getPickTasksByPage, updatePickTaskInfo } from '@/api/taskMonitor.js'
import {errorBox} from '@/utils/myMessageBox.js' import { errorBox } from '@/utils/myMessageBox.js'
import {ElMessage} from 'element-plus' import { ElMessage } from 'element-plus'
import {ref, reactive} from 'vue' import { ref, reactive } from 'vue'
import {dateFormatter, timeFormatter} from '@/utils/formatter.js' import { dateFormatter, timeFormatter } from '@/utils/formatter.js'
import {downloadPickTaskRecordsExcel} from "@/api/excel"; import { Search } from '@element-plus/icons-vue'
import {Search} from '@element-plus/icons-vue'
import zhCn from 'element-plus/dist/locale/zh-cn.mjs' import zhCn from 'element-plus/dist/locale/zh-cn.mjs'
</script> </script>
<script> <script>
export default { export default {
name: 'pickTaskMonitor', name: 'pickTaskMonitor',
data() { data() {
return { return {
pickTaskList: [], pickTaskList: [],
currentPage: 1, currentPage: 1,
pageSize: 10, pageSize: 10,
total: 0, total: 0,
vehicleIdQuery: '', vehicleIdQuery: '',
standQuery: '', standQuery: '',
pickStatusQuery: -99, pickStatusQuery: -99,
dateQuery: null, loading: true,
loading: true, dialogVisible: false,
dialogVisible: false, pickTaskId: '',
pickTaskId: '', pickTaskFormEntity: reactive({}),
pickTaskFormEntity: reactive({}), pickTaskFormRef: ref(),
pickTaskFormRef: ref(), labelPosition: 'top',
labelPosition: 'top', rules: reactive({}),
rules: reactive({}), taskStatusOptions: [
taskStatusOptions: [ {
{ value: -1,
value: -1, label: '暂存'
label: '暂存' },
}, {
{ value: 0,
value: 0, label: '待下发'
label: '待下发' },
}, {
{ value: 1,
value: 1, label: '已下发'
label: '已下发' },
}, {
{ value: 2,
value: 2, label: '已到达'
label: '已到达' }
],
pickStatusOptions: [
{
value: -99,
label: '全部'
},
{
value: -1,
label: '暂存'
},
{
value: 0,
label: '待下发'
},
{
value: 1,
label: '已下发'
},
{
value: 2,
label: '已到达'
}
],
} }
], },
pickStatusOptions: [ mounted() {
{ this.search()
value: -99, },
label: '全部' methods: {
search() {
this.loading = true
const request = {
pageNo: this.currentPage,
pageSize: this.pageSize,
vehicleId: this.vehicleIdQuery.trim(),
standId: this.standQuery.trim(),
pickStatus: this.pickStatusQuery == -99 ? null : this.pickStatusQuery,
userName: store.getters.getUserName
}
getPickTasksByPage(request).then(res => {
const tableResponse = res.data
if (tableResponse.code == 0) {
this.pickTaskList = tableResponse.returnData.lists
this.total = tableResponse.returnData.total
} else {
errorBox(tableResponse.message)
}
}).catch(err => {
console.log(err)
errorBox('查询拣选任务错误')
})
this.loading = false
}, },
{ dateFormat: (row, column, cellValue, index) => {
value: -1, return dateFormatter(cellValue)
label: '暂存'
}, },
{ timeFormat: (row, column, cellValue, index) => {
value: 0, return timeFormatter(cellValue)
label: '待下发'
}, },
{ pickStatusFormat: (row, column, cellValue, index) => {
value: 1, switch (cellValue) {
label: '已下发' case -1:
return '暂存'
case 0:
return '待下发'
case 1:
return '已下发'
case 2:
return '已到达'
default:
return '未知'
}
}, },
{ reset() {
value: 2, this.vehicleIdQuery = ''
label: '已到达' this.standQuery = ''
} this.search()
],
shortcuts: [
{
text: '今天',
value: new Date(),
}, },
{ editCurrentRow(row) {
text: '昨天', this.pickTaskId = row.pickTaskId
value: () => { this.pickTaskFormEntity = {
const date = new Date() pickTaskId: row.pickTaskId,
date.setTime(date.getTime() - 3600 * 1000 * 24) vehicleId: row.vehicleId,
return date standId: row.standId,
}, pickStatus: row.pickStatus,
lastUpdateTime: row.lastUpdateTime
}
this.dialogVisible = true
},
submitInfo(formData) {
const params = {
pickTaskId: formData.pickTaskId,
pickStatus: formData.pickStatus,
userName: store.getters.getUserName
}
updatePickTaskInfo(params).then(res => {
if (res.data.code == 0) {
this.dialogVisible = false
ElMessage.success('更新拣选任务成功。')
this.search()
} else {
errorBox(res.data.message)
}
}).catch(err => {
console.log(err)
errorBox('更新拣选任务失败。')
})
},
getCurrentRow(row) {
this.pickTaskId = row.pickTaskId
}, },
],
}
},
mounted() {
this.search()
},
methods: {
search() {
this.loading = true
const request = {
pageNo: this.currentPage,
pageSize: this.pageSize,
vehicleId: this.vehicleIdQuery.trim(),
standId: this.standQuery.trim(),
pickStatus: this.pickStatusQuery == -99 ? null : this.pickStatusQuery,
userName: store.getters.getUserName
}
getPickTasksByPage(request).then(res => {
const tableResponse = res.data
if (tableResponse.code == 0) {
this.pickTaskList = tableResponse.returnData.lists
this.total = tableResponse.returnData.total
} else {
errorBox(tableResponse.message)
}
}).catch(err => {
console.log(err)
errorBox('查询拣选任务错误')
})
this.loading = false
}, },
dateFormat: (row, column, cellValue, index) => {
return dateFormatter(cellValue)
},
timeFormat: (row, column, cellValue, index) => {
return timeFormatter(cellValue)
},
pickStatusFormat: (row, column, cellValue, index) => {
switch (cellValue) {
case -1:
return '暂存'
case 0:
return '待下发'
case 1:
return '已下发'
case 2:
return '已到达'
default:
return '未知'
}
},
reset() {
this.vehicleIdQuery = ''
this.standQuery = ''
this.search()
},
editCurrentRow(row) {
this.pickTaskId = row.pickTaskId
this.pickTaskFormEntity = {
pickTaskId: row.pickTaskId,
vehicleId: row.vehicleId,
standId: row.standId,
pickStatus: row.pickStatus,
lastUpdateTime: row.lastUpdateTime
}
this.dialogVisible = true
},
submitInfo(formData) {
const params = {
pickTaskId: formData.pickTaskId,
pickStatus: formData.pickStatus,
userName: store.getters.getUserName
}
updatePickTaskInfo(params).then(res => {
if (res.data.code == 0) {
this.dialogVisible = false
ElMessage.success('更新拣选任务成功。')
this.search()
} else {
errorBox(res.data.message)
}
}).catch(err => {
console.log(err)
errorBox('更新拣选任务失败。')
})
},
getCurrentRow(row) {
this.pickTaskId = row.pickTaskId
},
//
exportPickTaskRecords() {
if (this.dateQuery == null) {
errorBox('请选择日期')
return
}
const request = {
vehicleId: this.vehicleIdQuery,
standId: this.standQuery,
workDate: dateFormatter(this.dateQuery),
userName: store.getters.getUserName
}
downloadPickTaskRecordsExcel(request).then(res => {
const link = document.createElement('a');//a
try {
// let blob = new Blob([res.data],{type: 'application/vnd.ms-excel'}); //blobblobtypexls
let blob = res.data //blob
// let _fileName = res.headers['content-disposition'].split(';')[1].split('=')[1]; //
let _fileName = "拣选任务记录" + dateFormatter(this.dateQuery) + ".xlsx"
link.style.display = 'none'//
// URL
const url = window.URL || window.webkitURL || window.moxURL
link.href = url.createObjectURL(blob)
link.setAttribute('download', _fileName.substring(_fileName.lastIndexOf('_') + 1))
document.body.appendChild(link)
link.click()
document.body.removeChild(link)
url.revokeObjectURL(link.href)//url
} catch (e) {
console.log(e)
errorBox('下载文件失败')
}
}).catch(err => {
console.log(err)
errorBox('导出失败')
})
},
},
} }
</script> </script>
<style scoped> <style scoped>
.el-pagination { .el-pagination {
padding-left: 5px; padding-left: 5px;
} }
.el-row .el-button { .el-row .el-button {
width: 72px; width: 72px;
margin-left: 0px; margin-left: 0px;
margin-right: 5px; margin-right: 5px;
} }
.table-class { .table-class {
width: 100%; width: 100%;
} }
.el-row .el-form-item { .el-row .el-form-item {
width: 10% inherit; width: 10% inherit;
justify-content: center; justify-content: center;
} }
.el-row .el-form-item .el-select-v2 { .el-row .el-form-item .el-select-v2 {
width: 100% !important; width: 100% !important;
} }
.el-row .el-form-item .el-input-number { .el-row .el-form-item .el-input-number {
width: 100% !important; width: 100% !important;
} }
.el-row .el-form-item .el-button { .el-row .el-form-item .el-button {
margin: auto; margin: auto;
} }
.title-area { .title-area {
display: flex; display: flex;
/* min-height: 10%; */ /* min-height: 10%; */
max-height: max-content; max-height: max-content;
margin-bottom: 10px; margin-bottom: 10px;
min-width: inherit; min-width: inherit;
border: solid 1px; border: solid 1px;
border-radius: 10px; border-radius: 10px;
box-shadow: 0px 15px 10px -15px #000; box-shadow: 0px 15px 10px -15px #000;
overflow: auto; overflow: auto;
flex-direction: column; flex-direction: column;
padding: 10px; padding: 10px;
} }
</style> </style>