332 lines
9.4 KiB
Vue
332 lines
9.4 KiB
Vue
|
|
<template>
|
||
|
|
<el-config-provider :locale="zhCn">
|
||
|
|
<el-container class="content">
|
||
|
|
<div class="work-area">
|
||
|
|
<fieldset class="title-area">
|
||
|
|
<legend>
|
||
|
|
工单
|
||
|
|
</legend>
|
||
|
|
<div class="title-div">
|
||
|
|
<span class="title-text">生产工单管理
|
||
|
|
</span>
|
||
|
|
</div>
|
||
|
|
</fieldset>
|
||
|
|
<fieldset class="main-area">
|
||
|
|
<legend>
|
||
|
|
上传
|
||
|
|
</legend>
|
||
|
|
<el-form ref="workFormRef" :model="workFormEntity" :label-position="labelPosition"
|
||
|
|
label-width="150px" style="max-width: 100%" :rules="rules" status-icon>
|
||
|
|
<div style="display: flex; justify-content: center;">
|
||
|
|
<div style="display: block; margin: 5px;">
|
||
|
|
<!-- <div
|
||
|
|
style="display: inline-flex; justify-content: center; height: 60px; width: 655px; margin: 5px; padding: 5px;">
|
||
|
|
<UploadExcelPart></UploadExcelPart>
|
||
|
|
</div> -->
|
||
|
|
<div style="height: 50px; margin-top: 20px; margin-bottom: 20px;"><UploadExcelOrders></UploadExcelOrders></div>
|
||
|
|
<div style="display: flex; margin-top: 15px">
|
||
|
|
<div
|
||
|
|
style="display: inline-flex; justify-content: center; width: 160px; margin: 5px; padding: 5px; background-color: #CCCCCC;">
|
||
|
|
<span style="align-self: center; font-weight: bold;font-size: 25px;">备注</span>
|
||
|
|
</div>
|
||
|
|
<div
|
||
|
|
style="display: inline-flex; justify-content: center; width: 700px; margin: 5px; padding: 5px; background-color: #00AAE8;">
|
||
|
|
<span style="align-self: center; font-weight: bold;font-size: 25px;">
|
||
|
|
{{ workFormEntity.remark }}
|
||
|
|
</span>
|
||
|
|
</div>
|
||
|
|
</div>
|
||
|
|
</div>
|
||
|
|
</div>
|
||
|
|
</el-form>
|
||
|
|
</fieldset>
|
||
|
|
</div>
|
||
|
|
</el-container>
|
||
|
|
</el-config-provider>
|
||
|
|
</template>
|
||
|
|
|
||
|
|
<script setup>
|
||
|
|
import store from '@/store'
|
||
|
|
import { getWorkByStandAndGoods, queryFinishByStandAndGoods } from '@/api/task'
|
||
|
|
import { reactive, ref } from 'vue'
|
||
|
|
import { ElMessage } from 'element-plus'
|
||
|
|
import UploadExcelOrders from '@/excel/UploadExcelOrders.vue'
|
||
|
|
import zhCn from 'element-plus/dist/locale/zh-cn.mjs'
|
||
|
|
</script>
|
||
|
|
|
||
|
|
<script>
|
||
|
|
export default {
|
||
|
|
name: 'uploadOrders',
|
||
|
|
data() {
|
||
|
|
return {
|
||
|
|
standId: store.getters.getStandId,
|
||
|
|
timer: '',
|
||
|
|
labelPosition: 'top',
|
||
|
|
workFormRef: ref(),
|
||
|
|
workFormEntity: reactive({
|
||
|
|
goodsId: '',
|
||
|
|
planPickNum: 0,
|
||
|
|
remainNumOrigin: null,
|
||
|
|
remainNumReal: null,
|
||
|
|
remark: '',
|
||
|
|
finishedRows: 0,
|
||
|
|
totalRows: 0,
|
||
|
|
finishedCounts: 0,
|
||
|
|
totalCounts: 0,
|
||
|
|
tip: ''
|
||
|
|
}),
|
||
|
|
rules: reactive({
|
||
|
|
goodsId: [
|
||
|
|
{ required: true, message: '请输入料号' }
|
||
|
|
]
|
||
|
|
}),
|
||
|
|
}
|
||
|
|
},
|
||
|
|
mounted() {
|
||
|
|
this.timer = setInterval(() => {
|
||
|
|
this.queryFinish()
|
||
|
|
}, 2000)
|
||
|
|
},
|
||
|
|
beforeUnmount() {
|
||
|
|
clearInterval(this.timer)
|
||
|
|
},
|
||
|
|
methods: {
|
||
|
|
// 获取当前工作信息
|
||
|
|
getCurrentWorkInfo() {
|
||
|
|
const request = {
|
||
|
|
standId: this.standId,
|
||
|
|
goodsId: this.workFormEntity.goodsId
|
||
|
|
}
|
||
|
|
getWorkByStandAndGoods(request).then(res => {
|
||
|
|
const response = res.data
|
||
|
|
if (response.code == 0) {
|
||
|
|
this.workFormEntity.goodsId = response.returnData.goodsId
|
||
|
|
this.workFormEntity.planPickNum = response.returnData.planPickNum
|
||
|
|
this.workFormEntity.remainNumOrigin = response.returnData.remainNumOrigin
|
||
|
|
this.workFormEntity.remainNumReal = response.returnData.remainNumReal
|
||
|
|
this.workFormEntity.remark = response.returnData.remark
|
||
|
|
this.workFormEntity.finishedRows = response.returnData.finishedRows
|
||
|
|
this.workFormEntity.totalRows = response.returnData.totalRows
|
||
|
|
this.workFormEntity.finishedCounts = response.returnData.finishedCounts
|
||
|
|
this.workFormEntity.totalCounts = response.returnData.totalCounts
|
||
|
|
this.workFormEntity.tip = response.returnData.tip
|
||
|
|
} else {
|
||
|
|
this.resetForms()
|
||
|
|
ElMessage.error(response.message)
|
||
|
|
}
|
||
|
|
}).catch(err => {
|
||
|
|
console.log(err)
|
||
|
|
this.resetForms()
|
||
|
|
ElMessage.error('查询工作信息错误')
|
||
|
|
})
|
||
|
|
},
|
||
|
|
// 查询是否完成
|
||
|
|
queryFinish() {
|
||
|
|
if (this.workFormEntity.goodsId == '') {
|
||
|
|
return
|
||
|
|
}
|
||
|
|
const request = {
|
||
|
|
standId: this.standId,
|
||
|
|
goodsId: this.workFormEntity.goodsId
|
||
|
|
}
|
||
|
|
queryFinishByStandAndGoods(request).then(res => {
|
||
|
|
const response = res.data
|
||
|
|
if (response.code == 0) {
|
||
|
|
if (response.returnData != null) {
|
||
|
|
this.workFormEntity.tip = response.returnData.tip
|
||
|
|
}
|
||
|
|
this.resetForms()
|
||
|
|
ElMessage.success(response.message)
|
||
|
|
}
|
||
|
|
}).catch(err => {
|
||
|
|
console.log(err)
|
||
|
|
})
|
||
|
|
},
|
||
|
|
// 重置参数
|
||
|
|
resetForms() {
|
||
|
|
this.workFormEntity = reactive({
|
||
|
|
goodsId: '',
|
||
|
|
planPickNum: 0,
|
||
|
|
remainNumOrigin: null,
|
||
|
|
remainNumReal: null,
|
||
|
|
remark: '',
|
||
|
|
finishedRows: 0,
|
||
|
|
totalRows: 0,
|
||
|
|
finishedCounts: 0,
|
||
|
|
totalCounts: 0,
|
||
|
|
tip: ''
|
||
|
|
})
|
||
|
|
this.$refs.goodsId.focus()
|
||
|
|
},
|
||
|
|
}
|
||
|
|
}
|
||
|
|
</script>
|
||
|
|
|
||
|
|
<style scoped>
|
||
|
|
.content {
|
||
|
|
display: flex;
|
||
|
|
width: 100%;
|
||
|
|
}
|
||
|
|
|
||
|
|
.work-area {
|
||
|
|
width: 100%;
|
||
|
|
/* padding: 5px; */
|
||
|
|
}
|
||
|
|
|
||
|
|
.main-area {
|
||
|
|
margin: auto;
|
||
|
|
min-height: fit-content;
|
||
|
|
max-height: 90%;
|
||
|
|
margin-bottom: 10px;
|
||
|
|
min-width: inherit;
|
||
|
|
border: solid 1px;
|
||
|
|
border-radius: 10px;
|
||
|
|
box-shadow: 0px 15px 10px -15px #000;
|
||
|
|
overflow: auto;
|
||
|
|
}
|
||
|
|
|
||
|
|
.title-area {
|
||
|
|
display: flex;
|
||
|
|
min-height: 10%;
|
||
|
|
max-height: max-content;
|
||
|
|
margin-bottom: 10px;
|
||
|
|
min-width: inherit;
|
||
|
|
border: solid 1px;
|
||
|
|
border-radius: 10px;
|
||
|
|
box-shadow: 0px 15px 10px -15px #000;
|
||
|
|
overflow: auto;
|
||
|
|
}
|
||
|
|
|
||
|
|
.arrow {
|
||
|
|
background: linear-gradient(-105deg,
|
||
|
|
transparent 50%,
|
||
|
|
#309330 50%,
|
||
|
|
#309330 100%) top right,
|
||
|
|
linear-gradient(-75deg,
|
||
|
|
transparent 50%,
|
||
|
|
#309330 50%,
|
||
|
|
#309330 100%) bottom right;
|
||
|
|
background-size: 100% 50%;
|
||
|
|
height: 400px;
|
||
|
|
width: 250px;
|
||
|
|
background-repeat: no-repeat;
|
||
|
|
display: inline-flex;
|
||
|
|
cursor: pointer;
|
||
|
|
}
|
||
|
|
|
||
|
|
:deep(.el-input) {
|
||
|
|
width: 195px;
|
||
|
|
height: 130px;
|
||
|
|
font-size: 25px;
|
||
|
|
}
|
||
|
|
|
||
|
|
:deep(.el-input-number) {
|
||
|
|
width: 125px;
|
||
|
|
height: 130px;
|
||
|
|
font-size: 25px;
|
||
|
|
}
|
||
|
|
|
||
|
|
/* :deep(.el-input .el-input__inner) {
|
||
|
|
font-size: 60px;
|
||
|
|
height: 130px;
|
||
|
|
}
|
||
|
|
|
||
|
|
:deep(.el-input-number .el-input__inner) {
|
||
|
|
font-size: 60px;
|
||
|
|
height: 130px;
|
||
|
|
} */
|
||
|
|
|
||
|
|
.title-div {
|
||
|
|
display: inline-flex;
|
||
|
|
width: -webkit-fill-available;
|
||
|
|
margin-right: 5px;
|
||
|
|
padding: 5px;
|
||
|
|
background-color: #CCCCCC;
|
||
|
|
}
|
||
|
|
|
||
|
|
.title-text {
|
||
|
|
align-self: center;
|
||
|
|
font-weight: bold;
|
||
|
|
font-size: 25px;
|
||
|
|
}
|
||
|
|
|
||
|
|
.station-div {
|
||
|
|
display: inline-flex;
|
||
|
|
justify-content: center;
|
||
|
|
width: 150px;
|
||
|
|
margin-left: 5px;
|
||
|
|
margin-right: 5px;
|
||
|
|
padding: 5px;
|
||
|
|
background-color: #FFFAAA;
|
||
|
|
}
|
||
|
|
|
||
|
|
.station-text {
|
||
|
|
align-self: center;
|
||
|
|
font-weight: bold;
|
||
|
|
font-size: 25px;
|
||
|
|
}
|
||
|
|
|
||
|
|
.station-no-div {
|
||
|
|
display: inline-flex;
|
||
|
|
justify-content: center;
|
||
|
|
width: 200px;
|
||
|
|
padding: 5px;
|
||
|
|
border: 5px double #000000;
|
||
|
|
}
|
||
|
|
|
||
|
|
.station-no-text {
|
||
|
|
align-self: center;
|
||
|
|
font-weight: bold;
|
||
|
|
font-size: 25px;
|
||
|
|
}
|
||
|
|
|
||
|
|
.display-title-div {
|
||
|
|
display: inline-flex;
|
||
|
|
justify-content: center;
|
||
|
|
width: 205px;
|
||
|
|
height: 80px;
|
||
|
|
margin: 5px;
|
||
|
|
padding: 5px;
|
||
|
|
background-color: #FFFAAA;
|
||
|
|
}
|
||
|
|
|
||
|
|
.display-title-text {
|
||
|
|
align-self: center;
|
||
|
|
font-weight: bold;
|
||
|
|
font-size: 25px;
|
||
|
|
}
|
||
|
|
|
||
|
|
.display-form-div {
|
||
|
|
display: inline-flex;
|
||
|
|
justify-content: center;
|
||
|
|
width: 195px;
|
||
|
|
margin: 5px;
|
||
|
|
padding: 5px;
|
||
|
|
border: 5px double #000000;
|
||
|
|
margin-top: 25px;
|
||
|
|
}
|
||
|
|
|
||
|
|
.display-form-div-left {
|
||
|
|
display: inline-flex;
|
||
|
|
justify-content: center;
|
||
|
|
width: 125px;
|
||
|
|
margin: 5px;
|
||
|
|
padding: 5px;
|
||
|
|
border: 5px double #000000;
|
||
|
|
}
|
||
|
|
|
||
|
|
.display-form-div-right {
|
||
|
|
display: inline-flex;
|
||
|
|
justify-content: center;
|
||
|
|
width: 50px;
|
||
|
|
margin: 5px;
|
||
|
|
padding: 5px;
|
||
|
|
background-color: #CCCCCC;
|
||
|
|
}
|
||
|
|
|
||
|
|
.display-form-text-right {
|
||
|
|
align-self: center;
|
||
|
|
font-weight: bold;
|
||
|
|
font-size: 25px;
|
||
|
|
}
|
||
|
|
</style>
|