Files
aio-hl-new/src/pages/modules/workorder/work-order-assignment.vue

265 lines
8.3 KiB
Vue
Raw Normal View History

<template>
<div class="order-wraper">
<div class="wrap-filter-buttons">
<div class="wrap-filters">
<div class="filter_item">
<div class="filter_label">设备</div>
<div class="filter-input-wrap">
2023-05-26 19:12:08 +08:00
<el-select v-model="value" filterable clearable placeholder="请选择">
<el-option
v-for="item in options"
:key="item.device_code"
:label="item.device_name"
:value="item.device_code">
</el-option>
</el-select>
</div>
</div>
</div>
<div class="wrap-buttons">
<button class="button button--primary" @click="getDatas">查询</button>
2023-05-28 14:42:55 +08:00
<button class="button button--primary" :class="{'button--defalut': pkId === '' || pkObj.workorder_status === '3'}" :disabled="disabled1" @click="_openStart">开工</button>
2023-05-26 19:12:08 +08:00
<button class="button button--primary" :class="{'button--defalut': pkId === ''}" :disabled="disabled2" @click="showDialog('1')">报工</button>
2023-05-28 14:42:55 +08:00
<button class="button button--primary" :class="{'button--defalut': pkId === '' || pkObj.workorder_status === '2'}" :disabled="disabled3" @click="showDialog('2')">强制完成</button>
</div>
</div>
<div class="grid_wraper">
<table class="filter-table">
<tr>
<th width="4%"></th>
<th width="8%">工单日期</th>
<th width="8%">工单号</th>
2023-05-26 19:12:08 +08:00
<th width="7%">状态</th>
<th width="8%">设备</th>
2023-05-26 19:12:08 +08:00
<th width="8%">物料名称</th>
<th width="10%">物料规格</th>
<th width="10%">工序</th>
2023-05-26 19:12:08 +08:00
<th width="9%">计划生产</th>
<th width="9%">待生产</th>
<th width="9%">已生产</th>
2023-05-26 19:12:08 +08:00
<th width="9%">开工时间</th>
</tr>
<tr v-for="e in dataList" :key="e.workorder_id">
<td>
<button class="iconfont select_icon" :class="{'selected_icon': pkId === e.workorder_id}" @click="toRadio(e)"></button>
</td>
<td>{{e.create_time}}</td>
<td>{{e.workorder_code}}</td>
2023-05-26 19:12:08 +08:00
<td>{{['创建','下发','生产中','暂停', '完成', '强制完成'][Number(e.workorder_status) - 1]}}</td>
<td>{{e.device_code}}</td>
2023-05-26 19:12:08 +08:00
<td>{{e.material_name}}</td>
<td>{{e.material_spec}}</td>
<td>{{e.workprocedure_name}}</td>
<td>{{e.plan_qty}}</td>
<td>{{ e.report_qty }}</td>
<td>{{ e.real_qty }}</td>
<td>{{ e.realproducestart_date }}</td>
</tr>
</table>
</div>
<jxDialog
ref="child"
2023-05-26 19:12:08 +08:00
:title="title"
:type="type"
@toSure="toSureDialog"
>
2023-05-26 19:12:08 +08:00
<div v-if="type === '1'" class="form_wraper">
<div class="form">
<div class="form_item">
<div class="form_item__label">合格数量</div>
<div class="form_item__content">
<input type="number" class="form_item__input" v-model="reportQty">
</div>
</div>
<div class="form_item">
<div class="form_item__label">报废数量</div>
<div class="form_item__content">
<input type="number" class="form_item__input" v-model="nokQty">
</div>
</div>
</div>
<div class="form">
<div class="form_item">
<div class="form_item__label">报修数量</div>
<div class="form_item__content">
<input type="number" class="form_item__input" v-model="repareQty">
</div>
</div>
</div>
</div>
<div v-if="type === '2'" class="form_wraper">当前操作为强制确认确定继续操作吗</div>
</jxDialog>
</div>
</template>
<script>
2023-05-28 14:42:55 +08:00
import { deviceList, getOrderList2, openStart, tofinish, saveReport } from '../../../config/getData2.js'
import jxDialog from '@components/dialog.vue'
import {accSubtract} from '@config/utils.js'
export default {
components: {
jxDialog
},
data () {
return {
options: [],
value: '',
disabled1: false,
disabled2: false,
disabled3: false,
dataList: [],
pkId: '',
2023-05-26 19:12:08 +08:00
pkObj: {},
title: '',
type: '',
reportQty: '',
nokQty: '',
repareQty: ''
}
},
watch: {
type (val) {
switch (val) {
case '1':
this.title = '请输入数量'
break
case '2':
this.title = '提示'
break
}
}
},
created () {
this._deviceList()
2023-05-28 14:42:55 +08:00
this.getDatas()
},
methods: {
async _deviceList () {
let res = await deviceList()
if (res.code === 200) {
this.options = [...res.content]
}
},
async getDatas () {
2023-05-28 14:42:55 +08:00
let res = await getOrderList2(this.value)
res.content.map(el => {
let qty = '0'
if (Number(accSubtract(el.plan_qty, el.real_qty)) > 0) {
qty = accSubtract(el.plan_qty, el.real_qty)
}
this.$set(el, 'report_qty', qty)
})
this.dataList = [...res.content]
},
// 开工
async _openStart () {
this.disabled1 = true
if (!this.pkId) {
this.toast('请选择一行')
this.disabled1 = false
return
}
2023-05-28 14:42:55 +08:00
if (this.pkObj.workorder_status === '3') {
this.disabled1 = false
return
}
try {
let res = await openStart(this.pkId, this.value)
this.toast(res.message)
this.disabled1 = false
this.pkId = ''
this.pkObj = {}
this.getDatas()
} catch (e) {
this.disabled1 = false
}
},
// 报工
async _saveReport () {
2023-05-26 19:12:08 +08:00
this.$refs.child.disabled = true
this.disabled2 = true
if (!this.pkId) {
this.toast('请选择一行')
this.disabled2 = false
return
}
try {
2023-05-26 19:12:08 +08:00
let res = await saveReport(this.pkId, this.reportQty, this.nokQty, this.repareQty)
this.toast(res.message)
this.disabled2 = false
this.pkId = ''
this.pkObj = {}
2023-05-26 19:12:08 +08:00
this.$refs.child.active = false
this.$refs.child.disabled = false
this.getDatas()
} catch (e) {
this.disabled2 = false
2023-05-26 19:12:08 +08:00
this.$refs.child.active = false
this.$refs.child.disabled = false
}
},
2023-05-26 19:12:08 +08:00
showDialog (type) {
this.type = type
if (!this.pkId) {
this.toast('请选择一行')
return
}
2023-05-26 19:12:08 +08:00
switch (type) {
case '1':
this.reportQty = ''
this.nokQty = ''
this.repareQty = ''
2023-05-28 14:42:55 +08:00
this.$refs.child.active = true
2023-05-26 19:12:08 +08:00
break
case '2':
2023-05-28 14:42:55 +08:00
if (this.pkObj.workorder_status === '2') {
return
}
this.$refs.child.active = true
2023-05-26 19:12:08 +08:00
break
}
},
// 完工
async _tofinish () {
this.$refs.child.disabled = true
this.disabled3 = true
try {
let res = await tofinish(this.pkObj)
this.toast(res.message)
this.disabled3 = false
2023-05-26 19:12:08 +08:00
this.pkId = ''
this.pkObj = {}
this.$refs.child.active = false
this.$refs.child.disabled = false
this.getDatas()
} catch (e) {
this.disabled3 = false
this.$refs.child.active = false
this.$refs.child.disabled = false
}
},
2023-05-26 19:12:08 +08:00
toSureDialog (type) {
switch (type) {
case '1':
this._saveReport()
break
case '2':
this._tofinish()
break
}
},
toRadio (e) {
this.pkId = this.pkId === e.workorder_id ? '' : e.workorder_id
this.pkObj = this.pkId === e.workorder_id ? e : {}
}
}
}
</script>
<style lang="stylus" scoped>
.filter_label
width 32px
.filter-input-wrap
width calc(100% - 32px)
</style>