4 changed files with 1760 additions and 521 deletions
-
25src/api/production/dailyPlan.js
-
28src/assets/scss/global.scss
-
1478src/views/modules/production/dailyPlan.vue
-
750src/views/modules/production/dailyPlan_old.vue
@ -0,0 +1,25 @@ |
|||
import { createAPI } from "@/utils/httpRequest.js"; |
|||
|
|||
//获得接下来一周内的日历班次信息
|
|||
export const getWeekCalendarExceptionShiftData= data => createAPI(`/dailyPlan/getWeekCalendarExceptionShiftData`,'post',data) |
|||
|
|||
export const getWeekShiftData= data => createAPI(`/dailyPlan/getWeekShiftData`,'post',data) |
|||
|
|||
//获得可排产的清单
|
|||
export const getShopOrderOutData= data => createAPI(`/dailyPlan/getShopOrderOutData`,'post',data) |
|||
//获得已排产的派工单
|
|||
export const getOrderScheduleList= data => createAPI(`/dailyPlan/getOrderScheduleList`,'post',data) |
|||
//获得已排产的派工单
|
|||
export const getWorkCenterNoWithSiteResourceId= data => createAPI(`/dailyPlan/getWorkCenterNoWithSiteResourceId`,'post',data) |
|||
//获得当日班次清单
|
|||
export const getTodayShiftNoList= data => createAPI(`/dailyPlan/getTodayShiftNoList`,'post',data) |
|||
//获得可用机台清单
|
|||
export const getSORoutingAvailableResourceList= data => createAPI(`/dailyPlan/getSORoutingAvailableResourceList`,'post',data) |
|||
//获得当日负荷
|
|||
export const getHasScheduledData= data => createAPI(`/dailyPlan/getHasScheduledData`,'post',data) |
|||
//获得当日负荷
|
|||
export const scheduleOne=data => createAPI(`/dailyPlan/scheduleOne`,'post',data) |
|||
//获得当日负荷
|
|||
export const scheduleDatas=data => createAPI(`/dailyPlan/scheduleDatas`,'post',data) |
|||
//获得当日负荷
|
|||
export const cancelScheduleData=data => createAPI(`/dailyPlan/cancelScheduleData`,'post',data) |
|||
1478
src/views/modules/production/dailyPlan.vue
File diff suppressed because it is too large
View File
File diff suppressed because it is too large
View File
@ -0,0 +1,750 @@ |
|||
<template> |
|||
<div class="mod-config"> |
|||
<el-form inline="true" style="margin-top: -25px;" v-model="searchData"> |
|||
<el-form :inline="true" label-position="top" label-width="100px" style="margin-top: 5px;"> |
|||
<el-form-item :label="'订单号:'"> |
|||
<el-input v-model="searchData.orderNo" style="width: 120px"></el-input> |
|||
</el-form-item> |
|||
<el-form-item :label="'计划开工日期:'"> |
|||
<el-date-picker |
|||
style="width: 130px" |
|||
v-model="searchData.startDate2" |
|||
type="date" |
|||
value-format="yyyy-MM-dd" |
|||
placeholder="选择日期"> |
|||
</el-date-picker> |
|||
</el-form-item> |
|||
<el-form-item style="margin-top: 30px;"> |
|||
<laber style="margin-left: -9px;font-size: 19px">➞</laber> |
|||
</el-form-item> |
|||
<el-form-item style="margin-top: 30px;"> |
|||
<el-date-picker |
|||
style="width: 130px" |
|||
v-model="searchData.endDate2" |
|||
type="date" |
|||
value-format="yyyy-MM-dd" |
|||
placeholder="选择日期"> |
|||
</el-date-picker> |
|||
</el-form-item> |
|||
<el-form-item :label="'计划完工日期:'"> |
|||
<el-date-picker |
|||
style="width: 130px" |
|||
v-model="searchData.startDate3" |
|||
type="date" |
|||
value-format="yyyy-MM-dd" |
|||
placeholder="选择日期"> |
|||
</el-date-picker> |
|||
</el-form-item> |
|||
<el-form-item style="margin-top: 30px;"> |
|||
<laber style="margin-left: -9px;font-size: 19px">➞</laber> |
|||
</el-form-item> |
|||
<el-form-item style="margin-top: 30px;"> |
|||
<el-date-picker |
|||
style="width: 130px" |
|||
v-model="searchData.endDate3" |
|||
type="date" |
|||
value-format="yyyy-MM-dd" |
|||
placeholder="选择日期"> |
|||
</el-date-picker> |
|||
</el-form-item> |
|||
</el-form> |
|||
|
|||
<el-form :inline="true" label-position="top" label-width="100px" style="margin-top: 5px;"> |
|||
<el-form-item :label="'状态:'"> |
|||
<el-select filterable v-model="searchData.status" style="width: 120px"> |
|||
<el-option label="全部" value=""></el-option> |
|||
<el-option label="可排产" value="('已下达','已发料','已入库','已开工')"></el-option> |
|||
<el-option label="不可排产" value="('已计划','已取消','已关闭')"></el-option> |
|||
</el-select> |
|||
</el-form-item> |
|||
<el-form-item :label="'录入日期:'"> |
|||
<el-date-picker |
|||
style="width: 130px" |
|||
v-model="searchData.startDate1" |
|||
value-format="yyyy-MM-dd" |
|||
placeholder="选择日期"> |
|||
</el-date-picker> |
|||
</el-form-item> |
|||
<el-form-item style="margin-top: 30px;"> |
|||
<laber style="margin-left: -9px;font-size: 19px">➞</laber> |
|||
</el-form-item> |
|||
<el-form-item style="margin-top: 30px;"> |
|||
<el-date-picker |
|||
style="width: 130px" |
|||
v-model="searchData.endDate1" |
|||
type="date" |
|||
value-format="yyyy-MM-dd" |
|||
placeholder="选择日期"> |
|||
</el-date-picker> |
|||
</el-form-item> |
|||
<el-form-item :label="'物料编码:'"> |
|||
<el-input v-model="searchData.partNo" style="width: 130px"></el-input> |
|||
</el-form-item> |
|||
<el-form-item style="margin-top: 30px"> |
|||
<el-button @click="search()" style="margin-left: 24px" type="primary">查询</el-button> |
|||
<el-button @click="savePlansModal()" style="margin-left: 24px" type="primary">批量排产</el-button> |
|||
</el-form-item> |
|||
</el-form> |
|||
</el-form> |
|||
|
|||
<el-table |
|||
:height="height" |
|||
:data="tableData" |
|||
border |
|||
style="width: 100%" |
|||
@selection-change="selectionChangeHandle"> |
|||
<el-table-column |
|||
type="selection" |
|||
:selectable="checkSelections" |
|||
width="44"> |
|||
</el-table-column> |
|||
<!-- <el-table-column--> |
|||
<!-- align="center"--> |
|||
<!-- width="40"--> |
|||
<!-- type="selection">--> |
|||
<!-- <template slot-scope="scope">--> |
|||
<!-- <el-checkbox v-if="scope.row.status==1" ></el-checkbox>--> |
|||
<!-- </template>--> |
|||
<!-- </el-table-column>--> |
|||
<el-table-column |
|||
prop="orderNo" |
|||
header-align="center" |
|||
align="left" |
|||
min-width="60" |
|||
label="订单号"> |
|||
</el-table-column> |
|||
<el-table-column |
|||
prop="partNo" |
|||
header-align="center" |
|||
align="left" |
|||
min-width="60" |
|||
label="物料编码"> |
|||
</el-table-column> |
|||
<el-table-column |
|||
prop="partDescription" |
|||
header-align="center" |
|||
align="left" |
|||
min-width="200" |
|||
label="物料名称"> |
|||
</el-table-column> |
|||
<el-table-column |
|||
prop="status" |
|||
header-align="center" |
|||
align="left" |
|||
min-width="40" |
|||
label="状态"> |
|||
</el-table-column> |
|||
<el-table-column |
|||
prop="planStartDate" |
|||
header-align="center" |
|||
align="left" |
|||
min-width="50" |
|||
label="计划开工日期"> |
|||
</el-table-column> |
|||
<el-table-column |
|||
prop="needDate" |
|||
header-align="center" |
|||
align="left" |
|||
min-width="50" |
|||
label="计划完工日期"> |
|||
</el-table-column> |
|||
<el-table-column |
|||
prop="lotSize" |
|||
header-align="center" |
|||
align="right" |
|||
min-width="40" |
|||
label="订单数量"> |
|||
</el-table-column> |
|||
<el-table-column |
|||
prop="schedulingSize" |
|||
header-align="center" |
|||
align="right" |
|||
min-width="40" |
|||
label="已排产数量"> |
|||
</el-table-column> |
|||
<el-table-column |
|||
prop="enterDate" |
|||
header-align="center" |
|||
align="left" |
|||
min-width="80" |
|||
label="录入时间"> |
|||
</el-table-column> |
|||
<el-table-column |
|||
prop="userName" |
|||
header-align="center" |
|||
align="left" |
|||
min-width="40" |
|||
label="录入人"> |
|||
</el-table-column> |
|||
<el-table-column |
|||
prop="" |
|||
fixed="right" |
|||
header-align="center" |
|||
align="center" |
|||
min-width="30" |
|||
label="操作"> |
|||
<template slot-scope="scope"> |
|||
<a type="text" size="small" @click="openScheduleModel(scope.row)">排产</a> |
|||
</template> |
|||
</el-table-column> |
|||
</el-table> |
|||
|
|||
<el-dialog title="排产信息" :visible.sync="schedulingFlag" :close-on-click-modal="false" v-drag width="800px"> |
|||
<el-form :inline="true" label-position="top"> |
|||
<el-form-item :label="'订单号:'"> |
|||
<el-input v-model="scheduledModelData.orderNo" readonly style="width: 130px"></el-input> |
|||
</el-form-item> |
|||
<el-form-item :label="'计划开工日期:'"> |
|||
<el-input v-model="scheduledModelData.planStartDate" readonly style="width: 130px"></el-input> |
|||
</el-form-item> |
|||
<el-form-item :label="'计划完工日期:'"> |
|||
<el-input v-model="scheduledModelData.needDate" readonly style="width: 130px"></el-input> |
|||
</el-form-item> |
|||
<el-form-item :label="'已排产数量:'"> |
|||
<el-input v-model="scheduledModelData.schedulingSize" readonly style="width: 100px"></el-input> |
|||
</el-form-item> |
|||
<el-form-item :label="'未排产数量:'"> |
|||
<el-input v-model="scheduledModelData.unSchedulingSize" readonly style="width: 100px"></el-input> |
|||
</el-form-item> |
|||
<el-button @click="schedulingModal()" type="primary" style="margin-top: 33px;margin-left: 40px;">新增</el-button> |
|||
</el-form> |
|||
<el-table |
|||
:height="300" |
|||
:data="scheduleTableData" |
|||
border |
|||
style="width: 100%"> |
|||
<el-table-column |
|||
prop="orderDate" |
|||
header-align="center" |
|||
align="left" |
|||
min-width="50" |
|||
label="计划日期"> |
|||
</el-table-column> |
|||
<el-table-column |
|||
prop="shiftdesc" |
|||
header-align="center" |
|||
align="left" |
|||
min-width="40" |
|||
label="班次名称"> |
|||
</el-table-column> |
|||
<el-table-column |
|||
prop="orderQty" |
|||
header-align="center" |
|||
align="right" |
|||
min-width="40" |
|||
label="排产数量"> |
|||
</el-table-column> |
|||
<el-table-column |
|||
prop="qtyCirculation" |
|||
header-align="center" |
|||
align="right" |
|||
min-width="40" |
|||
label="已流转数"> |
|||
</el-table-column> |
|||
<el-table-column |
|||
prop="userName" |
|||
header-align="center" |
|||
align="left" |
|||
min-width="50" |
|||
label="录入人"> |
|||
</el-table-column> |
|||
<el-table-column |
|||
prop="enterDate" |
|||
header-align="center" |
|||
align="left" |
|||
min-width="90" |
|||
label="录入日期"> |
|||
</el-table-column> |
|||
<el-table-column |
|||
prop="" |
|||
header-align="center" |
|||
align="center" |
|||
min-width="50" |
|||
label="操作"> |
|||
<template slot-scope="scope" class="foo_container"> |
|||
<a type="text" size="small" @click="editSchedule(scope.row)">编辑</a> |
|||
<a type="text" size="small" @click="deleteSchedule(scope.row)">删除</a> |
|||
</template> |
|||
</el-table-column> |
|||
</el-table> |
|||
<el-footer style="height:40px;margin-top: 20px;text-align:center"> |
|||
<el-button type="primary" @click="schedulingFlag = false">关闭</el-button> |
|||
<!-- <el-button type="primary" :disabled="bannersBut" @click="saveBanners()">确定</el-button>--> |
|||
</el-footer> |
|||
</el-dialog> |
|||
<el-dialog title="维护日计划" :close-on-click-modal="false" v-drag :visible.sync="schedulingModalFlag" width="341px"> |
|||
<el-form :inline="true" label-position="top" style="margin-left: 7px;margin-top: -5px;"> |
|||
<el-form-item :label="'订单号:'"> |
|||
<el-input v-model="scheduledingData.orderNo" disabled style="width: 130px"></el-input> |
|||
</el-form-item> |
|||
<el-form-item :label="'计划日期:'"> |
|||
<el-date-picker |
|||
style="width: 130px" |
|||
v-model="scheduledingData.orderDate" |
|||
type="date" |
|||
value-format="yyyy-MM-dd" |
|||
:disabled="scheduledingDataFlag1" |
|||
placeholder="选择日期"> |
|||
</el-date-picker> |
|||
</el-form-item> |
|||
<el-form-item :label="'计划班次:'"> |
|||
<!-- <el-input v-model="scheduledingData.shiftId" :disabled="scheduledingDataFlag1" style="width: 130px"></el-input>--> |
|||
<el-select v-model="scheduledingData.shiftId" :disabled="scheduledingDataFlag1" style="width: 130px" |
|||
placeholder="请选择"> |
|||
<el-option |
|||
v-for="(item,index) in selectList" |
|||
:key="index" |
|||
:label="item.label" |
|||
:value="item.value" |
|||
> |
|||
</el-option> |
|||
</el-select> |
|||
</el-form-item> |
|||
<el-form-item :label="'计划数量:'"> |
|||
<el-input v-model="scheduledingData.orderQty" style="width: 130px"></el-input> |
|||
</el-form-item> |
|||
</el-form> |
|||
<el-footer style="height:40px;margin-top: 20px;text-align:center"> |
|||
<el-button type="primary" v-if="scheduledingDataFlag3" @click="planSaveOn()">保存并继续</el-button> |
|||
<el-button type="primary" @click="planSave()">保存</el-button> |
|||
<el-button type="primary" @click="schedulingModalFlag = false">关闭</el-button> |
|||
</el-footer> |
|||
</el-dialog> |
|||
|
|||
<el-dialog title="批量排产" :close-on-click-modal="false" v-drag :visible.sync="savePlansModalFlag" width="341px"> |
|||
<el-form :inline="true" label-position="top" style="margin-left: 7px;margin-top: -5px;"> |
|||
<el-form-item :label="'计划日期:'"> |
|||
<el-date-picker |
|||
style="width: 130px" |
|||
v-model="schedulingModalData.orderDate" |
|||
type="date" |
|||
value-format="yyyy-MM-dd" |
|||
placeholder="选择日期"> |
|||
</el-date-picker> |
|||
</el-form-item> |
|||
<el-form-item :label="'计划班次:'"> |
|||
<!-- <el-input v-model="scheduledingData.shiftId" :disabled="scheduledingDataFlag1" style="width: 130px"></el-input>--> |
|||
<el-select v-model="schedulingModalData.shiftId" style="width: 130px" |
|||
placeholder="请选择"> |
|||
<el-option |
|||
v-for="(item,index) in selectList" |
|||
:key="index" |
|||
:label="item.label" |
|||
:value="item.value" |
|||
> |
|||
</el-option> |
|||
</el-select> |
|||
</el-form-item> |
|||
</el-form> |
|||
<el-footer style="height:40px;margin-top: 20px;text-align:center"> |
|||
<el-button type="primary" @click="savePlans()">保存</el-button> |
|||
<el-button type="primary" @click="savePlansModalFlag = false">关闭</el-button> |
|||
</el-footer> |
|||
</el-dialog> |
|||
|
|||
</div> |
|||
|
|||
|
|||
</template> |
|||
|
|||
<script> |
|||
import { |
|||
getShopOrderData, |
|||
getSchedulingSize, |
|||
savePlan, |
|||
getWorkPlanData, |
|||
delPlan, |
|||
getShiftData, |
|||
savePlans |
|||
} from '@/api/prd.js' |
|||
|
|||
export default { |
|||
name: 'productionDispatch', |
|||
data () { |
|||
return { |
|||
savePlansModalFlag: false, |
|||
selectList: [], |
|||
// 维护日计划界面 |
|||
schedulingModalFlag: false, |
|||
scheduleTableData: [], |
|||
scheduledModelData: { |
|||
orderNo: '', |
|||
planStartDate: '', |
|||
needDate: '', |
|||
schedulingSize: '', |
|||
unSchedulingSize: '' |
|||
}, |
|||
dataListSelections: [], |
|||
scheduledingData: { |
|||
orderNo: '', |
|||
orderDate: '', |
|||
orderQty: '', |
|||
shiftId: '', |
|||
userName: this.$store.state.user.name, |
|||
lotSize: '', |
|||
planStartDate: '', |
|||
needDate: '', |
|||
site: this.$store.state.user.site, |
|||
productionType: '生产订单', |
|||
planAdd: 0, |
|||
partNo: '' |
|||
}, |
|||
schedulingModalData: { |
|||
orderDate: '', |
|||
shiftId: '', |
|||
}, |
|||
scheduledingDataFlag1: false, |
|||
scheduledingDataFlag3: true, |
|||
schedulingFlag: false, |
|||
tableData: [], |
|||
searchData: { |
|||
orderNo: '', |
|||
startDate1: new Date(), |
|||
endDate1: '', |
|||
startDate2: '', |
|||
endDate2: '', |
|||
status: '(\'已下达\',\'已发料\',\'已入库\',\'已开工\')', |
|||
partNo: '', |
|||
startDate3: '', |
|||
endDate3: '', |
|||
site: this.$store.state.user.site |
|||
}, |
|||
// table高度 |
|||
height: 200 |
|||
} |
|||
}, |
|||
mounted () { |
|||
this.$nextTick(() => { |
|||
this.height = window.innerHeight - 270 |
|||
}) |
|||
}, |
|||
methods: { |
|||
search () { |
|||
this.getData() |
|||
}, |
|||
// 维护日计划界面 |
|||
schedulingModal () { |
|||
if (this.scheduledModelData.unSchedulingSize == 0) { |
|||
this.$alert('该日计划已排产完毕无需新增!', '错误', { |
|||
confirmButtonText: '确定' |
|||
}) |
|||
return false |
|||
} |
|||
this.scheduledingDataFlag1 = false |
|||
this.scheduledingDataFlag3 = true |
|||
this.scheduledingData.userName = this.$store.state.user.name |
|||
this.scheduledingData.planStartDate = this.scheduledModelData.planStartDate |
|||
this.scheduledingData.needDate = this.scheduledModelData.needDate |
|||
this.scheduledingData.orderNo = this.scheduledModelData.orderNo |
|||
this.scheduledingData.orderDate = this.scheduledModelData.planStartDate |
|||
this.scheduledingData.planAdd = 0 |
|||
this.scheduledingData.orderQty = '' |
|||
this.scheduledingData.shiftId = '' |
|||
this.schedulingModalFlag = true |
|||
}, |
|||
// 多选数据 |
|||
selectionChangeHandle (val) { |
|||
this.dataListSelections = val |
|||
}, |
|||
// 多选框选中触发判断 |
|||
checkSelections (row) { |
|||
if (row.status == '已计划' || row.status == '已取消' || row.status == '已关闭') { |
|||
return false |
|||
} |
|||
if (row.schedulingSize >= row.lotSize) { |
|||
return false |
|||
} |
|||
return true |
|||
}, |
|||
// 排产信息界面 |
|||
openScheduleModel (row) { |
|||
if (row.status == '已计划' || row.status == '已取消' || row.status == '已关闭') { |
|||
this.$alert('该订单状态为' + row.status + '无法排产', '错误', { |
|||
confirmButtonText: '确定' |
|||
}) |
|||
return false |
|||
} |
|||
let list = {orderNo: row.orderNo} |
|||
getSchedulingSize(list).then(({data}) => { |
|||
this.scheduledModelData.schedulingSize = data.schedulingSize |
|||
this.scheduledModelData.unSchedulingSize = row.lotSize - data.schedulingSize |
|||
}) |
|||
this.scheduledingData.lotSize = row.lotSize |
|||
this.scheduledingData.partNo = row.partNo |
|||
this.scheduledModelData.needDate = row.needDate |
|||
this.scheduledModelData.planStartDate = row.planStartDate |
|||
this.scheduledModelData.orderNo = row.orderNo |
|||
this.schedulingFlag = true |
|||
let data1 = {orderNo: row.orderNo} |
|||
getWorkPlanData(data1).then(({data}) => { |
|||
this.scheduleTableData = data.rows |
|||
}) |
|||
}, |
|||
|
|||
// 查询 |
|||
getData () { |
|||
getShopOrderData(JSON.parse(JSON.stringify(this.searchData))).then(({data}) => { |
|||
this.tableData = data.rows |
|||
}) |
|||
}, |
|||
planSave () { |
|||
if (this.scheduledingData.orderDate == '' || this.scheduledingData.orderDate == null) { |
|||
this.$alert('请选择计划日期!', '错误', { |
|||
confirmButtonText: '确定' |
|||
}) |
|||
return false |
|||
} |
|||
if (this.scheduledingData.orderQty == '' || this.scheduledingData.orderQty == null) { |
|||
this.$alert('请输入排产数量!', '错误', { |
|||
confirmButtonText: '确定' |
|||
}) |
|||
return false |
|||
} |
|||
if (this.scheduledingData.orderQty <= 0) { |
|||
this.$alert('排产数量必须大于0!', '错误', { |
|||
confirmButtonText: '确定' |
|||
}) |
|||
return false |
|||
} |
|||
if (this.scheduledingData.shiftId == '') { |
|||
this.$alert('请输入排产班次!', '错误', { |
|||
confirmButtonText: '确定' |
|||
}) |
|||
return false |
|||
} |
|||
|
|||
// this.scheduledingData.orderDate = this.format(this.scheduledingData.orderDate,'yyyy-MM-dd') |
|||
|
|||
savePlan(this.scheduledingData).then(({data}) => { |
|||
if (data && data.code === 0) { |
|||
this.scheduledModelData.schedulingSize = data.schedulingSize |
|||
this.scheduledModelData.unSchedulingSize = this.scheduledingData.lotSize - data.schedulingSize |
|||
this.schedulingModalFlag = false |
|||
let data1 = {orderNo: this.scheduledModelData.orderNo} |
|||
getWorkPlanData(data1).then(({data}) => { |
|||
this.scheduleTableData = data.rows |
|||
}) |
|||
this.getData() |
|||
this.$message({ |
|||
message: '操作成功', |
|||
type: 'success', |
|||
duration: 1500, |
|||
|
|||
onClose: () => { |
|||
} |
|||
}) |
|||
} else { |
|||
this.$alert(data.msg, '错误', { |
|||
confirmButtonText: '确定' |
|||
}) |
|||
} |
|||
}) |
|||
}, |
|||
planSaveOn () { |
|||
if (this.scheduledingData.orderDate == '' || this.scheduledingData.orderDate == null) { |
|||
this.$alert('请选择计划日期!', '错误', { |
|||
confirmButtonText: '确定' |
|||
}) |
|||
return false |
|||
} |
|||
if (this.scheduledingData.orderQty == '' || this.scheduledingData.orderQty == null) { |
|||
this.$alert('请输入排产数量!', '错误', { |
|||
confirmButtonText: '确定' |
|||
}) |
|||
return false |
|||
} |
|||
if (this.scheduledingData.shiftId == '') { |
|||
this.$alert('请输入排产班次!', '错误', { |
|||
confirmButtonText: '确定' |
|||
}) |
|||
return false |
|||
} |
|||
if (this.scheduledingData.orderQty <= 0) { |
|||
this.$alert('排产数量必须大于0!', '错误', { |
|||
confirmButtonText: '确定' |
|||
}) |
|||
return false |
|||
} |
|||
|
|||
savePlan(this.scheduledingData).then(({data}) => { |
|||
if (data && data.code === 0) { |
|||
this.scheduledModelData.schedulingSize = data.schedulingSize |
|||
this.scheduledModelData.unSchedulingSize = this.scheduledingData.lotSize - data.schedulingSize |
|||
let data1 = {orderNo: this.scheduledModelData.orderNo} |
|||
getWorkPlanData(data1).then(({data}) => { |
|||
this.scheduleTableData = data.rows |
|||
}) |
|||
this.scheduledingData.orderDate = this.getNextDay(this.scheduledingData.orderDate) |
|||
this.getData() |
|||
getShiftData().then(({data}) => { |
|||
this.shiftData = data.rows |
|||
}) |
|||
this.$message({ |
|||
message: '操作成功', |
|||
type: 'success', |
|||
duration: 1500, |
|||
|
|||
onClose: () => { |
|||
} |
|||
}) |
|||
} else { |
|||
this.$alert(data.msg, '错误', { |
|||
confirmButtonText: '确定' |
|||
}) |
|||
} |
|||
}) |
|||
}, |
|||
// 修改日计划 |
|||
editSchedule (row) { |
|||
this.scheduledingDataFlag1 = true |
|||
this.scheduledingDataFlag3 = false |
|||
this.scheduledingData.userName = this.$store.state.user.name |
|||
this.scheduledingData.planStartDate = this.scheduledModelData.planStartDate |
|||
this.scheduledingData.needDate = this.scheduledModelData.needDate |
|||
this.scheduledingData.orderNo = this.scheduledModelData.orderNo |
|||
this.scheduledingData.orderDate = row.orderDate |
|||
this.scheduledingData.planAdd = 1 |
|||
this.scheduledingData.orderQty = row.orderQty |
|||
this.scheduledingData.shiftId = row.shiftId |
|||
this.schedulingModalFlag = true |
|||
}, |
|||
// 刪除 |
|||
deleteSchedule (row) { |
|||
let delData = { |
|||
orderNo: row.orderNo, |
|||
orderQty: row.orderQty, |
|||
orderRef1: row.orderRef1 |
|||
} |
|||
this.$confirm(`是否删除此条记录?`, '提示', { |
|||
confirmButtonText: '确定', |
|||
cancelButtonText: '取消', |
|||
type: 'warning' |
|||
}).then(() => { |
|||
delPlan(delData).then(({data}) => { |
|||
if (data && data.code === 0) { |
|||
this.scheduledModelData.schedulingSize = data.schedulingSize |
|||
this.scheduledModelData.unSchedulingSize = this.scheduledingData.lotSize - data.schedulingSize |
|||
this.getData() |
|||
let data1 = {orderNo: this.scheduledModelData.orderNo} |
|||
getWorkPlanData(data1).then(({data}) => { |
|||
this.scheduleTableData = data.rows |
|||
}) |
|||
this.$message({ |
|||
message: '操作成功', |
|||
type: 'success', |
|||
duration: 1500, |
|||
onClose: () => { |
|||
} |
|||
}) |
|||
} else { |
|||
this.$alert(data.msg, '错误', { |
|||
confirmButtonText: '确定' |
|||
}) |
|||
} |
|||
}) |
|||
}).catch(() => { |
|||
}) |
|||
}, |
|||
|
|||
getTime (date) { |
|||
if (date == '') { |
|||
return '' |
|||
} else { |
|||
let json_date = new Date(date).toJSON() |
|||
return new Date(new Date(json_date) + 8 * 3600 * 1000).toISOString().replace(/T/g, ' ').replace(/\.[\d]{3}Z/, '') |
|||
} |
|||
}, |
|||
|
|||
getSelectData () { |
|||
this.selectList = [] |
|||
getShiftData().then(({data}) => { |
|||
let list = data.rows |
|||
for (let i = 0; i < list.length; i++) { |
|||
let resultData = { |
|||
value: list[i].id, |
|||
label: list[i].shiftdesc |
|||
} |
|||
this.selectList.push(resultData) |
|||
} |
|||
}) |
|||
}, |
|||
savePlansModal () { |
|||
if (this.dataListSelections.length == 0) { |
|||
this.$alert('请选择订单!', '错误', { |
|||
confirmButtonText: '确定' |
|||
}) |
|||
return false |
|||
} |
|||
this.schedulingModalData.orderDate = '' |
|||
this.schedulingModalData.shiftId = '' |
|||
this.savePlansModalFlag = true |
|||
}, |
|||
getNextDay (dateTime) { |
|||
var dd = new Date(dateTime) |
|||
dd.setDate(dd.getDate() + 1)//获取1天后的日期 |
|||
var y = dd.getFullYear() |
|||
var m = (dd.getMonth() + 1) < 10 ? '0' + (dd.getMonth() + 1) : (dd.getMonth() + 1)//获取当前月份的日期,不足10补0 |
|||
var d = dd.getDate() < 10 ? '0' + dd.getDate() : dd.getDate()//获取当前几号,不足10补0 |
|||
// let haha= new Date(y+"-"+m+"-"+d); |
|||
return y + '-' + m + '-' + d |
|||
}, |
|||
savePlans () { |
|||
if (this.schedulingModalData.orderDate == '') { |
|||
this.$alert('请选择排产日期!', '错误', { |
|||
confirmButtonText: '确定' |
|||
}) |
|||
return false |
|||
} |
|||
if (this.schedulingModalData.shiftId == '') { |
|||
this.$alert('请选择班次!', '错误', { |
|||
confirmButtonText: '确定' |
|||
}) |
|||
return false |
|||
} |
|||
let inList = [] |
|||
for (let i = this.dataListSelections.length - 1; i >= 0; i--) { |
|||
let newlist = { |
|||
orderNo: this.dataListSelections[i].orderNo, |
|||
orderDate: this.schedulingModalData.orderDate, |
|||
orderQty: this.dataListSelections[i].lotSize - this.dataListSelections[i].schedulingSize, |
|||
shiftId: this.schedulingModalData.shiftId, |
|||
userName: this.$store.state.user.name, |
|||
lotSize: this.dataListSelections[i].lotSize, |
|||
planStartDate: this.dataListSelections[i].planStartDate, |
|||
needDate: this.dataListSelections[i].needDate, |
|||
site: this.$store.state.user.site, |
|||
productionType: '生产订单', |
|||
planAdd: 0, |
|||
partNo: this.dataListSelections[i].partNo |
|||
} |
|||
inList.push(newlist) |
|||
} |
|||
console.log(JSON.parse(JSON.stringify(inList))) |
|||
savePlans(JSON.parse(JSON.stringify(inList))).then(({data}) => { |
|||
if (data && data.code === 0) { |
|||
this.savePlansModalFlag = false |
|||
this.getData() |
|||
this.$message({ |
|||
message: '操作成功', |
|||
type: 'success', |
|||
duration: 1500, |
|||
|
|||
onClose: () => { |
|||
} |
|||
}) |
|||
} else { |
|||
this.$alert(data.msg, '错误', { |
|||
confirmButtonText: '确定' |
|||
}) |
|||
} |
|||
}) |
|||
}, |
|||
}, |
|||
created () { |
|||
this.getSelectData() |
|||
} |
|||
} |
|||
</script> |
|||
<style scoped> |
|||
|
|||
</style> |
|||
Write
Preview
Loading…
Cancel
Save
Reference in new issue