<!--多排页签形式-->
|
|
<template>
|
<div>
|
<div class="body" :style="{height:mainHeight+'px'}">
|
|
<div class="bodyTopFormGroup" style="margin-top: 10px;padding-top: 10px">
|
<el-form
|
ref="form"
|
:model="formTop"
|
label-width="100px"
|
inline
|
style="display: flex;"
|
>
|
<div class="elForm">
|
<el-form-item label="车间编码" style=" display: flex;">
|
<el-input v-model="formTop.workshop" placeholder="请输入" style="width: 200px" />
|
</el-form-item>
|
<el-form-item label="生产工单号" style=" display: flex;">
|
<el-input v-model="formTop.wocode" placeholder="请输入" style="width: 200px" />
|
</el-form-item>
|
<el-form-item label="物料编码" style=" display: flex;">
|
<el-input v-model="formTop.partcode" placeholder="请输入" style="width: 200px" />
|
</el-form-item>
|
<el-form-item label="物料名称" style=" display: flex;">
|
<el-input v-model="formTop.partname" placeholder="请输入" style="width: 200px" />
|
</el-form-item>
|
</div>
|
<div
|
class="bodySearchReset"
|
:style="{marginLeft:$store.state.app.sidebar.opened? $store.state.settings.menuIsHorizontal?'15%':'3%':'10%'}"
|
>
|
<el-button v-waves type="primary" icon="el-icon-search" @click="search">查询</el-button>
|
<el-button v-waves type="info" icon="el-icon-refresh" @click="reset">重置</el-button>
|
</div>
|
</el-form>
|
<div
|
class="bodyTopFormExpand"
|
style="height: 5px"
|
/>
|
</div>
|
|
<div class="elTableDiv" style="margin-top: 0">
|
<el-table
|
ref="tableDataRef"
|
class="tableFixed"
|
:data="tableData"
|
:height="(tableHeight-400)+'px'"
|
border
|
:row-class-name="tableRowClassName"
|
:style="{width: 100+'%',height:(tableHeight-400)+'px',}"
|
highlight-current-row
|
:header-cell-style="this.$headerCellStyle"
|
:cell-style="this.$cellStyle"
|
@sort-change="sortChangeTop"
|
|
@selection-change="handleSelectionChange"
|
>
|
<!-- @row-click="getCurrentRow"-->
|
|
<!-- @selection-change="handleSelectionChange"-->
|
|
<el-table-column
|
type="selection"
|
width="55"
|
/>
|
<el-table-column
|
prop="RowNum"
|
width="50"
|
fixed
|
label="序号"
|
/>
|
<el-table-column
|
prop="AdvaSchePiroQue"
|
show-tooltip-when-overflow
|
label="优先级"
|
width="90"
|
sortable="custom"
|
/>
|
<el-table-column
|
prop="AdvaScheWorkShop"
|
label="生产车间"
|
width="110"
|
show-tooltip-when-overflow
|
sortable="custom"
|
/>
|
<el-table-column
|
prop="AdvaScheWorkCode"
|
label="工单编号"
|
min-width="160"
|
show-tooltip-when-overflow
|
sortable="custom"
|
/>
|
<el-table-column
|
prop="AdvaSchePartNumber"
|
label="产品编码"
|
min-width="110"
|
show-tooltip-when-overflow
|
sortable="custom"
|
>
|
<!-- <template slot-scope="{row}">-->
|
<!-- <div v-if="row.AdvaSchePartNumber">{{ row.AdvaSchePartNumber }}</div>-->
|
<!-- <div v-else>/</div>-->
|
<!-- </template>-->
|
</el-table-column>
|
<el-table-column
|
prop="AdvaSchePartName"
|
min-width="160"
|
show-tooltip-when-overflow
|
label="产品名称"
|
sortable="custom"
|
/>
|
<el-table-column
|
prop="AdvaSchePartSpec"
|
label="产品规格"
|
width="110"
|
show-tooltip-when-overflow
|
sortable="custom"
|
>
|
<template slot-scope="{row}">
|
<div v-if="row.AdvaSchePartSpec">{{ row.AdvaSchePartSpec }}</div>
|
<div v-else>/</div>
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="AdvaScheQty"
|
label="数量"
|
show-tooltip-when-overflow
|
width="110"
|
sortable="custom"
|
/>
|
<el-table-column
|
prop="AdvaScheEndDate"
|
label="要求交付时间"
|
sortable="custom"
|
show-tooltip-when-overflow
|
width="160"
|
/>
|
<el-table-column
|
prop="AdvaScheStus"
|
label="排程状态"
|
show-tooltip-when-overflow
|
width="110"
|
sortable="custom"
|
>
|
<template slot-scope="{row}">
|
<div v-if="row.AdvaScheStus==='NOSCHED'">待排程</div>
|
<div v-if="row.AdvaScheStus==='SCHED'">已排程</div>
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="AdvaScheBotProcName"
|
label="排程工序"
|
show-tooltip-when-overflow
|
width="110"
|
sortable="custom"
|
/>
|
<el-table-column
|
prop="AdvaSchePCStartDate"
|
label="计划排程时间"
|
width="200"
|
sortable="custom"
|
show-tooltip-when-overflow
|
>
|
<template slot-scope="{row}">
|
<div v-if="row.AdvaSchePCStartDate">{{ row.AdvaSchePCStartDate }} ~ {{ row.AdvaSchePCEndDate }}</div>
|
<div v-else>/</div>
|
</template>
|
</el-table-column>
|
|
</el-table>
|
</div>
|
<!--分页-->
|
<pagination
|
:total="totalTop"
|
:page.sync="formTop.page"
|
:limit.sync="formTop.rows"
|
align="right"
|
layout="total,prev, pager, next,sizes"
|
popper-class="select_bottom"
|
@pagination="getAdvancedSchedulingSearch"
|
/>
|
|
<!-- 自动排程部分的代码-->
|
<div class="autoScheduling">
|
|
<div class="bodyTopFormGroup">
|
<el-form
|
ref="form"
|
:model="formBottom"
|
inline
|
label-width="100px"
|
style="display: flex;"
|
>
|
<div class="elForm">
|
<el-form-item label="排程日期" style=" display: flex;">
|
<el-date-picker
|
v-model="formBottom.scheDate"
|
:disabled="multipleSelection.length===0"
|
type="daterange"
|
range-separator="~"
|
format="yyyy-MM-dd"
|
value-format="yyyy-MM-dd"
|
start-placeholder="开始日期"
|
end-placeholder="结束日期"
|
size="small"
|
:picker-options="pickerOptions1"
|
:clearable="false"
|
@change="dateChange"
|
/>
|
</el-form-item>
|
<el-form-item label="排程方式" style=" display: flex;">
|
<el-select
|
v-model="formBottom.types"
|
:disabled="multipleSelection.length===0"
|
style="width:120px"
|
@change="typesChange"
|
>
|
<el-option value="N" label="设备优先" />
|
<el-option value="Y" label="时间优先" />
|
</el-select>
|
</el-form-item>
|
<el-form-item label="时间刻度(分钟)" label-width="110" style=" display: flex;">
|
<el-select
|
v-model.number="formBottom.scale"
|
:disabled="multipleSelection.length===0"
|
style="width: 120px;"
|
>
|
<el-option v-for="item in scaleList" :key="item" :value="item" :label="item" />
|
</el-select>
|
|
</el-form-item>
|
<el-form-item label="换型时间(分钟)" label-width="110" style=" display: flex;">
|
<el-input
|
id="scale"
|
v-model="formBottom.times"
|
:disabled="multipleSelection.length===0"
|
type="number"
|
style="display:inline-block;width:80px;"
|
@change="no_zero"
|
/>
|
</el-form-item>
|
<el-form-item label="预排进度" style=" display: flex;">
|
<span>
|
<span style="text-decoration:underline;">{{ formBottom.canArrangeNumber }}</span> /
|
<span style="text-decoration:underline">{{ formBottom.needArrangeNumber }}</span>
|
</span>
|
</el-form-item>
|
</div>
|
<div
|
class="bodySearchReset"
|
:style="{marginLeft:$store.state.app.sidebar.opened? $store.state.settings.menuIsHorizontal?'15%':'3%':'10%'}"
|
>
|
<el-button
|
v-waves
|
:disabled="multipleSelection.length===0"
|
type="primary"
|
icon="el-icon-document-remove"
|
@click="prepareArrange"
|
>预排
|
</el-button>
|
<el-button
|
v-waves
|
type="primary"
|
:disabled="multipleSelection.length===0"
|
icon="el-icon-document-checked"
|
@click="prepareSubmit"
|
>提交
|
</el-button>
|
</div>
|
</el-form>
|
<div class="colorDescription">
|
<div class="colorDescriptionItem"><i
|
class="el-icon-s-opportunity"
|
style="margin-right: 5px;color: rgba(5, 185, 100, 0.5)"
|
/>产能
|
</div>
|
<div class="colorDescriptionItem"><i
|
class="el-icon-s-opportunity"
|
style="margin-right: 5px;color: rgba(5, 185, 100, 1)"
|
/>已排
|
</div>
|
<div class="colorDescriptionItem"><i
|
class="el-icon-s-opportunity"
|
style="margin-right: 5px;color:rgba(128,0,128,0.7)"
|
/>预排
|
</div>
|
<div>
|
<el-tag
|
v-for="item in multipleSelection"
|
:key="item.AdvaScheId"
|
:effect="item.isPlain"
|
style="margin-right: 10px"
|
@click="isPlainClick(item)"
|
>
|
{{ item.AdvaScheWorkCode }}
|
</el-tag>
|
</div>
|
<!-- <div class="colorDescriptionItem"><i class="el-icon-s-opportunity" style="margin-right: 5px;color: #a7a7a7" />失效产能</div>-->
|
</div>
|
<div
|
class="bodyTopFormExpand"
|
style="height: 5px"
|
/>
|
</div>
|
<!--
|
字段描述:
|
1.schedulingData:数组,是所有产能的每一行的汇总
|
2.data:对象,是一行内每一个产能的汇总
|
3.item:对象,是每一个产能条
|
-->
|
<!-- {{ schedulingData }}-->
|
<div class="container" style="margin: 10px;">
|
<v-gantt-chart
|
:start-time="time_data[0]"
|
:end-time="time_data[1]"
|
:cell-width="cellWidth"
|
:cell-height="cellHeight"
|
:title-height="titleHeight"
|
:scale="formBottom.scale"
|
:title-width="titleWidth"
|
show-current-time
|
:hide-header="hideHeader"
|
:data-key="dataKey"
|
:array-keys="arrayKeys"
|
|
:datas="schedulingData"
|
>
|
<!-- 暂时用不到-->
|
<!-- :time-lines="timeLines"-->
|
<!-- @scrollLeft="scrollLeftA"-->
|
<!-- :scroll-to-postion="positionA"-->
|
<template slot="block" slot-scope="{data,item}">
|
<Scheduling
|
:data="data"
|
:cell-height="cellHeight"
|
:item="item"
|
/>
|
<!-- 暂时用不到-->
|
<!-- :update-time-lines="updateTimeLines"-->
|
<!-- :current-time="currentTime"-->
|
</template>
|
<template slot="left" slot-scope="{data}">
|
<div class="name">
|
<div class="carId">
|
<el-checkbox
|
v-model="data.status"
|
style="margin-right:5px;"
|
@change="checkboxSingle(data)"
|
/>
|
{{ data.id }} {{ data.name }}
|
</div>
|
<div class="speed">
|
<!-- <el-tooltip class="item" effect="dark" content="查看" placement="top">-->
|
<!-- <el-button v-waves type="text" size="mini" @click="look(data)">-->
|
<!-- <i class="el-icon-document size i-color" />-->
|
<!-- </el-button>-->
|
<!-- </el-tooltip>-->
|
</div>
|
</div>
|
</template>
|
<template slot="title">
|
<span class="tc">工位列表</span>
|
<el-checkbox
|
v-model="ganttCheckboxAll"
|
class="box_style"
|
:disabled="multipleSelection.length===0"
|
@change="checkboxAll()"
|
/>
|
<input
|
v-model.number="cellWidth"
|
type="range"
|
min="20"
|
max="100"
|
class="box_styles"
|
:disabled="multipleSelection.length===0"
|
>
|
</template>
|
</v-gantt-chart>
|
</div>
|
</div>
|
|
</div>
|
|
</div>
|
</template>
|
|
<script>
|
import Pagination from '@/components/Pagination'
|
import Scheduling from '@/components/Scheduling'
|
import dayjs from 'dayjs'
|
import {
|
AdvancedSchedulingSearch, NewOnclickAdvancedSchedulingDevice,
|
OnclickAdvancedSchedulingDevice,
|
SubmitAlreadyScheduling
|
} from '@/api/produceManager'
|
import { handleDatetime, handleDatetime2 } from '@/utils/global'
|
import waves from '@/directive/waves'
|
import template from '@/views/template'
|
|
export default {
|
name: 'Zzjg',
|
components: {
|
Pagination, Scheduling
|
},
|
directives: { waves },
|
data() {
|
return {
|
mouseHoverType: 'mouseout',
|
isExpandForm: false,
|
mainHeight: 0,
|
tableHeight: 0,
|
|
formTop: {
|
workshop: '', // 车间编码
|
wocode: '', // 生产工单号
|
partcode: '', // 物料编码
|
partname: '', // 物料名称
|
prop: 'AdvaScheWorkCode', // 排序字段
|
order: 'desc', // 排序字段
|
page: 1, // 第几页
|
rows: 20 // 每页多少条
|
},
|
totalTop: 10, // 总共多少条
|
tableData: [],
|
multipleSelection: [],
|
/*
|
排程部分的属性
|
* */
|
show: false,
|
pickerOptions1: {
|
disabledDate(time) {
|
return time.getTime() <= Date.now() - 24 * 60 * 60 * 1000
|
}
|
},
|
|
ganttCheckboxAll: true, // 甘特图左侧复选框是否选中或者取消
|
ganttLeftArrId: [], // 甘特图左侧的数组id
|
cl_name: '', // 产品名称
|
cl_code: '', // 产品编码
|
work_order: '', // 工单编号
|
AdvaScheUom: '', // 产品单位
|
time_data: [[handleDatetime(new Date()) + ' 00:00:00'], [handleDatetime(new Date()) + ' 00:00:00']], // 甘特图初始渲染的时间范围
|
forms: { // 点击行获取信息 请求接口 的数据对象
|
wocode: '', // 工单编号
|
wkshpcode: '', // 车间编码
|
partcode: '', // 物料编码
|
botproccode: '', // 瓶颈工序编码(首道工序)
|
startdate: '', // 开始日期
|
enddate: ''// 结束日期
|
},
|
|
formsTempArr: [], // 表单数组形式存储
|
|
formBottom: { // 底部表单的 数据对象
|
scheDate: [handleDatetime(new Date()), handleDatetime(new Date())], // 排程日期
|
types: 'N', // 排程方式
|
scale: 60, // 时间刻度
|
times: 0, // 换型时间
|
canArrangeNumber: 0, // 可排数量
|
needArrangeNumber: 0// 需排数量
|
},
|
schedulingAllData: [], // 排程的所有数据
|
schedulingData: [], // 排程的最终数据
|
timeTopTempData: [], // 时间优先的临时数据
|
eqpTopTempData: [], // 设备优先的临时数据
|
|
formUpdate: {
|
WorkCode: '',
|
BotProceCode: '',
|
json: []
|
},
|
// currentTime: dayjs(),
|
cellWidth: 50,
|
cellHeight: 30,
|
titleHeight: 40,
|
titleWidth: 250,
|
dataKey: 'id', // 相当于是设备code做唯一字符
|
scaleList: `30,60,240,360`.split(',').map(n => parseInt(n)), // 时间刻度(分钟)
|
hideHeader: false,
|
arrayKeys: ['gtArray', 'error']
|
|
}
|
},
|
|
created() {
|
const loading = this.$loading({
|
lock: true,
|
text: '正在加载数据,请稍等...',
|
spinner: 'el-icon-loading',
|
customClass: 'osloading',
|
background: 'rgba(0, 0, 0, 0.7)'
|
})
|
setTimeout(() => {
|
if (this.getAdvancedSchedulingSearch()) {
|
loading.close()
|
}
|
}, 3000)
|
|
// this.getAdvancedSchedulingSearch()
|
},
|
mounted() {
|
window.addEventListener('resize', this.getHeight)
|
this.getHeight()
|
},
|
methods: {
|
async getAdvancedSchedulingSearch() {
|
const res = await AdvancedSchedulingSearch(this.formTop)
|
this.tableData = res.data
|
this.totalTop = res.count
|
|
this.tableData.forEach(row => {
|
row.AdvaSchePiroQueNumber = row.AdvaSchePiroQue === '正常' ? 3 : row.AdvaSchePiroQue === '紧急' ? 2 : 1
|
})
|
|
const newArr = []
|
this.tableData.filter((currentValue, currentIndex, selfArr) => {
|
return selfArr.findIndex(item => item.AdvaScheEndDate === currentValue.AdvaScheEndDate) === currentIndex
|
}).map(i => i.AdvaScheEndDate).forEach(i => {
|
newArr.push(this.tableData.filter(j => j.AdvaScheEndDate === i))
|
})
|
// 根据日期相同的,工单优先级进行排序
|
newArr.filter(i => {
|
i.sort((a, b) => b.AdvaSchePiroQueNumber - a.AdvaSchePiroQueNumber)
|
})
|
// 排好之后 工单顺序就是整个的优先级
|
this.tableData = newArr.flat()// 二维转一维
|
this.tableData.reverse()
|
return true
|
},
|
// 排序改变时
|
sortChangeTop({ column, prop, order }) {
|
if (order === 'descending') {
|
order = 'desc'
|
} else if (order === 'ascending') {
|
order = 'asc'
|
} else {
|
order = 'desc'
|
}
|
this.formTop.order = order
|
this.formTop.prop = prop
|
this.getAdvancedSchedulingSearch()
|
},
|
// 查询
|
search() {
|
this.getAdvancedSchedulingSearch()
|
},
|
// 重置
|
reset() {
|
this.formTop.workshop = ''
|
this.formTop.wocode = ''
|
this.formTop.partcode = ''
|
this.formTop.partname = ''
|
this.getAdvancedSchedulingSearch()
|
|
this.schedulingData = [] // 排程数据置空
|
},
|
// 获取页面高度
|
getHeight() {
|
this.$nextTick(() => {
|
this.mainHeight = window.innerHeight - 85
|
this.tableHeight = this.mainHeight - 255
|
this.$refs.tableDataRef.doLayout()
|
})
|
},
|
tableRowClassName({ row, rowIndex }) {
|
return 'custom-row'
|
},
|
/*
|
排程部分的方法
|
*/
|
// 确保换型时间为非负数
|
no_zero() {
|
if (this.formBottom.times < 0) {
|
this.formBottom.times = 0
|
}
|
},
|
// 排程方式改变
|
typesChange() {
|
this.getOnclickAdvancedSchedulingDevice()
|
},
|
// 排程日期值改变时
|
dateChange() {
|
this.time_data[0] = this.formBottom.scheDate[0] + ' 00:00'
|
this.time_data[1] = this.formBottom.scheDate[1] + ' 23:59'
|
this.forms.startdate = this.formBottom.scheDate[0]
|
this.forms.enddate = this.formBottom.scheDate[1]
|
this.getOnclickAdvancedSchedulingDevice()
|
},
|
// 工位列表复选框操作 (全选、全不选)
|
checkboxAll() {
|
if (this.ganttCheckboxAll) { // 复选框从取消到选中
|
console.log('003')
|
this.ganttLeftArrId = []
|
|
// 这里要进行forEach循环遍历
|
// 先用一个临时数组对象存储需请求接口的forms信息
|
let tempArr = []
|
this.schedulingData.forEach(val => {
|
val.status = true
|
tempArr.push({
|
wocode: val.wocode, // 工单编号
|
wkshpcode: val.wkshpcode, // 车间编码
|
partcode: val.partcode, // 产品编码
|
botproccode: val.botproccode, // 工艺路线编码
|
startdate: val.startdate, // 当前日期(今天)
|
enddate: val.enddate // 要求交付时间
|
})
|
})
|
|
// 数组对象去重
|
tempArr = tempArr.filter((currentValue, currentIndex, selfArr) => {
|
return selfArr.findIndex(item => item.wocode === currentValue.wocode) === currentIndex
|
})
|
|
tempArr.forEach(i => {
|
setTimeout(() => {
|
console.log('国宾府', i)
|
this.forms = i
|
this.getOnclickAdvancedSchedulingDevice()
|
// this.$forceUpdate()
|
})
|
})
|
} else { // 复选框从选中到取消
|
console.log('004')
|
for (const i in this.schedulingData) {
|
this.schedulingData[i].status = false
|
this.schedulingData[i].gtArray = []
|
}
|
for (const i in this.timeTopTempData) {
|
this.timeTopTempData[i].gtArray = []
|
}
|
}
|
// this.prepareArrange()
|
},
|
// 甘特图左侧checkbox值选中或者取消时
|
// checkboxSingle(val) {
|
// console.log(val, 'xaxaxa')
|
// console.log(val.status)
|
// },
|
checkboxSingle(val) {
|
console.log(val, 'xaxaxa')
|
if (!val.status) { // 复选框状态从选中到取消
|
console.log('001')
|
for (const i in this.timeTopTempData) {
|
const new_arr = []
|
for (const j in this.timeTopTempData[i].gtArray) {
|
if (this.timeTopTempData[i].gtArray[j].id === val.id) {
|
} else {
|
new_arr.push(this.timeTopTempData[i].gtArray[j])
|
}
|
}
|
this.timeTopTempData[i].gtArray = new_arr
|
}
|
} else { // 复选框状态从取消到选中
|
console.log('002')
|
this.ganttLeftArrId = []
|
for (const i in this.schedulingData) {
|
if (!this.schedulingData[i].status) {
|
this.ganttLeftArrId.push(this.schedulingData[i].id)
|
}
|
}
|
|
this.forms = {
|
wocode: val.wocode, // 工单编号
|
wkshpcode: val.wkshpcode, // 车间编码
|
partcode: val.partcode, // 产品编码
|
botproccode: val.botproccode, // 工艺路线编码
|
startdate: val.startdate, // 当前日期(今天)
|
enddate: val.enddate // 要求交付时间
|
}
|
this.getOnclickAdvancedSchedulingDevice()
|
}
|
|
if (!val.status) { // 复选框状态从选中到取消
|
console.log('005')
|
for (const i in this.schedulingData) {
|
if (!this.schedulingData[i].status) {
|
this.schedulingData[i].gtArray = []
|
}
|
}
|
} else { // 复选框状态从取消到选中
|
console.log('006')
|
this.ganttLeftArrId = []
|
for (const i in this.schedulingData) {
|
if (!this.schedulingData[i].status) {
|
this.ganttLeftArrId.push(this.schedulingData[i].id)
|
}
|
}
|
this.getOnclickAdvancedSchedulingDevice()
|
}
|
for (const i in this.schedulingData) {
|
const arr = []
|
for (const j in this.schedulingData[i].gtArray) {
|
if (this.schedulingData[i].gtArray[j].type !== 'schedule') {
|
arr.push(this.schedulingData[i].gtArray[j])
|
}
|
}
|
this.schedulingData[i].gtArray = arr
|
}
|
this.formBottom.canArrangeNumber = 0
|
|
// this.prepareArrange()
|
},
|
// 点击带出数据
|
async getOnclickAdvancedSchedulingDevice2() {
|
console.log(this.forms, 302)
|
|
this.formsTempArr.push(this.forms)
|
this.formsTempArr = this.formsTempArr.filter((currentValue, currentIndex, selfArr) => {
|
return selfArr.findIndex(item => item.wocode === currentValue.wocode) === currentIndex
|
})
|
console.log(JSON.stringify(this.formsTempArr))
|
|
const res = await OnclickAdvancedSchedulingDevice(this.forms)
|
if (res.rus.Message) {
|
return this.$message.error(res.rus.Message)
|
}
|
|
const data = res.rows // 拿到待排数据 对数据进行改造
|
const cont = res.Cont // 拿到已排数据 对数据进行改造
|
|
this.formBottom.canArrangeNumber = 0
|
|
// 找到index值
|
// const index = this.formsTempArr.findIndex(i => i.wocode === this.forms.wocode)
|
|
// 将五个时间段进行赋值 拿到后端的接口格式,改成前端所需的格式
|
data.forEach(item => {
|
item.children.forEach(it => {
|
if (it.OneStartDate !== '') {
|
it.OneStartDate = it.OneStartDate.split('~')
|
it.OneStartDate[0] = item.YearDate + ' ' + it.OneStartDate[0] + ':00'
|
it.OneStartDate[1] = item.YearDate + ' ' + it.OneStartDate[1] + ':00'
|
}
|
|
if (it.TwoStartDate !== '') {
|
it.TwoStartDate = it.TwoStartDate.split('~')
|
it.TwoStartDate[0] = item.YearDate + ' ' + it.TwoStartDate[0] + ':00'
|
it.TwoStartDate[1] = item.YearDate + ' ' + it.TwoStartDate[1] + ':00'
|
}
|
if (it.ThreeStartDate !== '') {
|
it.ThreeStartDate = it.ThreeStartDate.split('~')
|
it.ThreeStartDate[0] = item.YearDate + ' ' + it.ThreeStartDate[0] + ':00'
|
it.ThreeStartDate[1] = item.YearDate + ' ' + it.ThreeStartDate[1] + ':00'
|
}
|
if (it.FourStartDate !== '') {
|
it.FourStartDate = it.FourStartDate.split('~')
|
it.FourStartDate[0] = item.YearDate + ' ' + it.FourStartDate[0] + ':00'
|
it.FourStartDate[1] = item.YearDate + ' ' + it.FourStartDate[1] + ':00'
|
}
|
if (it.FiveStartDate !== '') {
|
it.FiveStartDate = it.FiveStartDate.split('~')
|
it.FiveStartDate[0] = item.YearDate + ' ' + it.FiveStartDate[0] + ':00'
|
it.FiveStartDate[1] = item.YearDate + ' ' + it.FiveStartDate[1] + ':00'
|
}
|
})
|
})
|
|
// 构建 按设备优先排程的 数据格式 schedulingData
|
const list = [] // 临时list 暂存 代表的是所有的产能
|
console.log(this.forms.wocode, ' this.forms.wocode')
|
console.log(data, 'xxx1')
|
|
data[0].children.forEach(item => {
|
const obj = {
|
// 新增五个参数
|
// wocode: this.formsTempArr[index].wocode, // 工单编号
|
// wkshpcode: this.formsTempArr[index].wkshpcode, // 车间编码
|
// partcode: this.formsTempArr[index].partcode, // 产品编码
|
// botproccode: this.formsTempArr[index].botproccode, // 工艺路线编码
|
// startdate: this.formsTempArr[index].startdate, // 当前日期(今天)
|
// enddate: this.formsTempArr[index].enddate, // 要求交付时间
|
|
wocode: this.forms.wocode, // 工单编号
|
wkshpcode: this.forms.wkshpcode, // 车间编码
|
partcode: this.forms.partcode, // 产品编码
|
botproccode: this.forms.botproccode, // 工艺路线编码
|
startdate: this.forms.startdate, // 当前日期(今天)
|
enddate: this.forms.enddate, // 要求交付时间
|
|
id: '', // 设备的code
|
name: '', // 设备名称
|
AdvaDevicRhythm: '', // 节拍多少秒生产一个(生产节拍)
|
status: true, // 甘特图左侧复选框是否是选中状态 当为true时渲染 为false时 不渲染产能
|
colorPair: { // 颜色集 不同状态下的甘特图的颜色 (目前的理解)
|
dark: 'rgb(83, 186, 241,0.8)',
|
light: 'rgb(83, 186, 241,0.1)',
|
light_capacity: 'rgb(209,239,237,0.8)',
|
h_schedule: 'rgb(100,255,192,0.8)',
|
scheduleing: 'rgb(20,182,231,0.8)'
|
},
|
gtArray: [] // 甘特图的每一个子项
|
}
|
// 将接口返回的设备编码,设备名称,生产节拍赋值给obj
|
obj.id = item.AdvaDevicNumber
|
obj.name = item.AdvaDevicName
|
obj.AdvaDevicRhythm = item.AdvaDevicRhythm
|
list.push(obj)
|
})
|
|
// 组合新的结构 浅绿色背景条
|
const newList = []
|
for (const i in data) {
|
for (const j in data[i].children) {
|
if (data[i].children[j].OneStartDate !== '') {
|
const data1 = {
|
id: '',
|
start: '',
|
end: '',
|
mod: ''
|
}
|
data1.id = data[i].children[j].AdvaDevicNumber
|
data1.start = data[i].children[j].OneStartDate[0]
|
data1.end = data[i].children[j].OneStartDate[1]
|
// AdvaDevicCropMob 稼动率 AdvaDevicRhythm 生产节拍
|
data1.mod = (data[i].children[j].AdvaDevicCropMob * 1) / 100 // 稼动率
|
newList.push(data1)
|
}
|
if (data[i].children[j].TwoStartDate !== '') {
|
const data2 = {
|
id: '',
|
start: '',
|
end: '',
|
mod: ''
|
}
|
data2.id = data[i].children[j].AdvaDevicNumber
|
data2.start = data[i].children[j].TwoStartDate[0]
|
data2.end = data[i].children[j].TwoStartDate[1]
|
data2.mod = (data[i].children[j].AdvaDevicCropMob * 1) / 100
|
newList.push(data2)
|
}
|
if (data[i].children[j].ThreeStartDate !== '') {
|
const data3 = {
|
id: '',
|
start: '',
|
end: '',
|
mod: ''
|
}
|
data3.id = data[i].children[j].AdvaDevicNumber
|
data3.start = data[i].children[j].ThreeStartDate[0]
|
data3.end = data[i].children[j].ThreeStartDate[1]
|
data3.mod = (data[i].children[j].AdvaDevicCropMob * 1) / 100
|
newList.push(data3)
|
}
|
if (data[i].children[j].FourStartDate !== '') {
|
const data4 = {
|
id: '',
|
start: '',
|
end: '',
|
mod: ''
|
}
|
data4.id = data[i].children[j].AdvaDevicNumber
|
data4.start = data[i].children[j].FourStartDate[0]
|
data4.end = data[i].children[j].FourStartDate[1]
|
data4.mod = (data[i].children[j].AdvaDevicCropMob * 1) / 100
|
newList.push(data4)
|
}
|
if (data[i].children[j].FiveStartDate !== '') {
|
const data5 = {
|
id: '',
|
start: '',
|
end: '',
|
mod: ''
|
}
|
data5.id = data[i].children[j].AdvaDevicNumber
|
data5.start = data[i].children[j].FiveStartDate[0]
|
data5.end = data[i].children[j].FiveStartDate[1]
|
data5.mod = (data[i].children[j].AdvaDevicCropMob * 1) / 100
|
newList.push(data5)
|
}
|
}
|
}
|
|
// 插入产能时间段 产能数据都在gtArray里面
|
for (const i in list) {
|
this.pushItem(newList, list[i].id, list[i].gtArray)
|
}
|
|
// this.schedulingData = list
|
|
// 上面注释代码只适合list数组长度为一的时候,是不对的,下面逻辑进行优化
|
// 判断当前点击行的数据请求接口数据 是否已经在排程数组内
|
list.forEach((item, index) => {
|
const flag = this.schedulingData.map(i => i.id).includes(list[index].id)
|
if (!flag) { // 当设备code不在排程数组内时 直接push排程数组即可
|
this.schedulingData.push(list[index])
|
} else { // 当已经在排程数组内时 应该判断时间取并集
|
const ind = this.schedulingData.findIndex(i => i.id === list[index].id)
|
const tempGtArray = [...new Set(this.schedulingData[ind].gtArray.concat(list[index].gtArray))]
|
// 数组中对象相同的去重
|
this.schedulingData[ind].gtArray = tempGtArray.filter((currentValue, currentIndex, selfArr) => {
|
return selfArr.findIndex(item => item.start === currentValue.start) === currentIndex
|
})
|
}
|
})
|
|
if (cont !== '') { // 对已排的产能进行数组重组
|
for (const i in cont) {
|
for (const j in this.schedulingData) {
|
if (this.schedulingData[j].id === cont[i].eqp_code) { // 当设备code相等时
|
const data = {
|
id: cont[i].eqp_code,
|
number: cont[i].alloc_qty,
|
cl_name: cont[i].part_name,
|
cl_code: cont[i].part_code,
|
AdvaScheUom: cont[i].uom_name, // 单位
|
work_order: cont[i].wo_code,
|
start: cont[i].time_start,
|
end: cont[i].time_end,
|
// type: cont[i].status === 'S' ? 'h_schedule' : 'bm_schedule'
|
type: 'h_schedule'
|
}
|
this.schedulingData[j].gtArray.unshift(data)
|
}
|
}
|
}
|
}
|
|
// console.log(this.ganttLeftArrId)
|
if (this.ganttLeftArrId !== '') {
|
// console.log('ykxkd')
|
for (const j in this.schedulingData) {
|
// console.log(this.ganttLeftArrId.indexOf(this.schedulingData[j].id) >= 0) //false
|
if (this.ganttLeftArrId.indexOf(this.schedulingData[j].id) >= 0) {
|
this.schedulingData[j].gtArray = []
|
this.schedulingData[j].status = false
|
}
|
}
|
}
|
|
// 设备优先的数据格式
|
// this.eqpTopTempData = []
|
// console.log(this.schedulingData, 30)
|
// console.log(data, 30)
|
// for (const i in data[0].children) {
|
// console.log(i, '特斯拉')
|
// const obj = {
|
// id: '',
|
// name: '',
|
// status: true,
|
// AdvaDevicRhythm: '',
|
// // mod:'',
|
// colorPair: {
|
// dark: 'rgb(83, 186, 241,0.8)',
|
// light: 'rgb(83, 186, 241,0.1)',
|
// light_capacity: 'rgb(209,239,237,0.8)',
|
// h_schedule: 'rgb(100,255,192,0.8)',
|
// scheduleing: 'rgb(20,182,231,0.8)'
|
// },
|
// gtArray: []
|
// }
|
// obj.id = data[0].children[i].AdvaDevicNumber
|
// obj.name = data[0].children[i].AdvaDevicName
|
// obj.AdvaDevicRhythm = data[0].children[i].AdvaDevicRhythm
|
// // obj.mod =data[0].children[i].AdvaDevicCropMob *1
|
//
|
// this.eqpTopTempData.push(obj)
|
// }
|
|
// 上面的注释代码可以换成下面这行代码
|
this.eqpTopTempData = JSON.parse(JSON.stringify(this.schedulingData))
|
|
// 更改格式
|
// this.timeTopTempData = []
|
|
console.log(data, 31)
|
|
// 构建按时间优先的排程数据格式 timeTopTempData
|
for (const i in data) {
|
const time = {
|
date: data[i].YearDate, // 日期
|
AdvaDevicRhythm: '', // 生产节拍
|
gtArray: []
|
}
|
if (data[i].children !== '') {
|
time.AdvaDevicRhythm = data[i].children[0].AdvaDevicRhythm
|
}
|
for (const j in data[i].children) {
|
if (data[i].children[j].OneStartDate !== '') {
|
const icu1 = {
|
name: data[i].children[j].AdvaDevicName,
|
id: data[i].children[j].AdvaDevicNumber,
|
type: 'capacity',
|
rhythm: data[i].children[j].AdvaDevicRhythm, // 生产节拍
|
start: data[i].children[j].OneStartDate[0],
|
end: data[i].children[j].OneStartDate[1],
|
mod: (data[i].children[j].AdvaDevicCropMob * 1) / 100
|
}
|
time.gtArray.push(icu1)
|
}
|
if (data[i].children[j].TwoStartDate !== '') {
|
const icu2 = {
|
name: data[i].children[j].AdvaDevicName,
|
id: data[i].children[j].AdvaDevicNumber,
|
type: 'capacity',
|
rhythm: data[i].children[j].AdvaDevicRhythm,
|
start: data[i].children[j].TwoStartDate[0],
|
end: data[i].children[j].TwoStartDate[1],
|
mod: (data[i].children[j].AdvaDevicCropMob * 1) / 100
|
}
|
time.gtArray.push(icu2)
|
}
|
if (data[i].children[j].ThreeStartDate !== '') {
|
const icu3 = {
|
name: data[i].children[j].AdvaDevicName,
|
id: data[i].children[j].AdvaDevicNumber,
|
type: 'capacity',
|
rhythm: data[i].children[j].AdvaDevicRhythm,
|
start: data[i].children[j].ThreeStartDate[0],
|
end: data[i].children[j].ThreeStartDate[1],
|
mod: (data[i].children[j].AdvaDevicCropMob * 1) / 100
|
}
|
time.gtArray.push(icu3)
|
}
|
if (data[i].children[j].FourStartDate !== '') {
|
const icu4 = {
|
name: data[i].children[j].AdvaDevicName,
|
id: data[i].children[j].AdvaDevicNumber,
|
type: 'capacity',
|
rhythm: data[i].children[j].AdvaDevicRhythm,
|
start: data[i].children[j].FourStartDate[0],
|
end: data[i].children[j].FourStartDate[1],
|
mod: (data[i].children[j].AdvaDevicCropMob * 1) / 100
|
}
|
time.gtArray.push(icu4)
|
}
|
if (data[i].children[j].FiveStartDate !== '') {
|
const icu5 = {
|
name: data[i].children[j].AdvaDevicName, // 设备名称
|
id: data[i].children[j].AdvaDevicNumber, // 设备code
|
type: 'capacity', // 产能
|
rhythm: data[i].children[j].AdvaDevicRhythm, // 生产节拍
|
start: data[i].children[j].FiveStartDate[0], // 开始时间
|
end: data[i].children[j].FiveStartDate[1], // 结束时间
|
mod: (data[i].children[j].AdvaDevicCropMob * 1) / 100 // 稼动率
|
}
|
time.gtArray.push(icu5)
|
}
|
}
|
this.timeTopTempData.push(time)
|
// console.log(this.timeTopTempData)
|
}
|
|
if (cont !== '') {
|
for (const i in cont) {
|
for (const j in this.timeTopTempData) {
|
const data = {
|
id: cont[i].eqp_code,
|
date: cont[i].time_start.split(' ')[0],
|
number: cont[i].alloc_qty,
|
cl_name: cont[i].part_name,
|
cl_code: cont[i].part_code,
|
AdvaScheUom: cont[i].uom_name, // 单位
|
work_order: cont[i].wo_code,
|
start: cont[i].time_start,
|
end: cont[i].time_end,
|
type: 'h_schedule'
|
}
|
if (this.timeTopTempData[j].date === data.date) {
|
this.timeTopTempData[j].gtArray.unshift(data)
|
}
|
}
|
}
|
}
|
|
console.log(JSON.parse(JSON.stringify(this.eqpTopTempData)), 7)
|
console.log(this.timeTopTempData, 8)
|
|
this.$forceUpdate()
|
},
|
// 换型时间
|
MinutesTest(time) {
|
const t = new Date(time)
|
t.setMinutes(t.getMinutes() + this.formBottom.times * 1)
|
const now =
|
t.getFullYear() +
|
'-' +
|
(t.getMonth() + 1).toString().padStart(2, '0') +
|
'-' +
|
t.getDate().toString().padStart(2, '0') +
|
' ' +
|
t.getHours().toString().padStart(2, '0') +
|
':' +
|
t.getMinutes().toString().padStart(2, '0') +
|
':' +
|
t.getSeconds().toString().padStart(2, '0')
|
return now
|
},
|
// 插入产能时间段
|
pushItem(newList, id, arr) {
|
for (const i in newList) {
|
if (newList[i].id === id) {
|
const data = {
|
start: newList[i].start,
|
end: newList[i].end,
|
id: newList[i].id,
|
mod: newList[i].mod,
|
type: 'capacity'
|
}
|
arr.push(data)
|
}
|
}
|
},
|
|
isPlainClick(val) {
|
console.log(val)
|
this.tableData.forEach(i => {
|
if (val.AdvaScheWorkCode === i.AdvaScheWorkCode) {
|
i.isPlain = 'dark'
|
} else {
|
i.isPlain = 'plain'
|
}
|
})
|
this.getOnclickAdvancedSchedulingDevice('getApi')
|
this.$forceUpdate()
|
},
|
|
// checkbox 点击改变事件
|
handleSelectionChange(val) {
|
console.log(val, '009')
|
this.multipleSelection = val
|
this.getOnclickAdvancedSchedulingDevice()
|
},
|
// 勾选表格复选框带出数据 获取NEW高级排程点击工单任务带出瓶颈工序设备、已排程任务数据
|
async getOnclickAdvancedSchedulingDevice(val) {
|
// 拿到复选框勾选的数据请求接口
|
let DATA = []
|
if (val === 'getApi') { // 代表是从切换页签过来的
|
console.log(this.tableData, 333)
|
const row = this.tableData.find(i => i.isPlain === 'dark')
|
console.log(row, 334)
|
DATA = [
|
{
|
isPlain: row.isPlain, // 代表是否是选中状态
|
wocode: row.AdvaScheWorkCode, // 工单编号
|
wkshpcode: row.AdvaScheWorkShopid, // 车间编码
|
partcode: row.AdvaSchePartNumber, // 产品编码
|
botproccode: row.AdvaScheBotProcid, // 工艺路线编码
|
startdate: handleDatetime(new Date()), // 当前日期(今天)
|
enddate: row.AdvaScheEndDate // 要求交付时间
|
}
|
]
|
console.log(DATA)
|
} else {
|
this.multipleSelection.forEach((row, index) => {
|
row.isPlain = index !== 0 ? 'plain' : 'dark'
|
row.AdvaSchePiroQueNumber = row.AdvaSchePiroQue === '正常' ? 3 : row.AdvaSchePiroQue === '紧急' ? 2 : 1
|
DATA.push({
|
isPlain: row.isPlain, // 代表是否是选中状态
|
wocode: row.AdvaScheWorkCode, // 工单编号
|
wkshpcode: row.AdvaScheWorkShopid, // 车间编码
|
partcode: row.AdvaSchePartNumber, // 产品编码
|
botproccode: row.AdvaScheBotProcid, // 工艺路线编码
|
startdate: handleDatetime(new Date()), // 当前日期(今天)
|
enddate: row.AdvaScheEndDate // 要求交付时间
|
})
|
})
|
}
|
|
const res = await NewOnclickAdvancedSchedulingDevice(DATA.filter(i => i.isPlain === 'dark'))
|
// 如果Message有报错信息则终止执行后面逻辑
|
if (res.rus.Message) {
|
return this.$message.error(res.rus.Message)
|
}
|
|
// 获取预排进度值和最大的要求交付日期
|
this.getMaxPayDate()
|
|
let waitingForScheduling = res.rows // 拿到待排数据,对数据进行改造
|
const alreadyForScheduling = res.Cont // 拿到已排数据 对数据进行改造
|
|
this.formBottom.canArrangeNumber = 0 // 预排进度的可排数量置零
|
|
// 将五个时间段进行赋值 拿到后端的接口格式,改成前端所需的格式
|
waitingForScheduling.forEach(item => {
|
item.children.forEach(it => {
|
if (it.OneStartDate !== '') {
|
it.OneStartDate = it.OneStartDate.split('~')
|
it.OneStartDate[0] = item.YearDate + ' ' + it.OneStartDate[0] + ':00'
|
it.OneStartDate[1] = item.YearDate + ' ' + it.OneStartDate[1] + ':00'
|
}
|
|
if (it.TwoStartDate !== '') {
|
it.TwoStartDate = it.TwoStartDate.split('~')
|
it.TwoStartDate[0] = item.YearDate + ' ' + it.TwoStartDate[0] + ':00'
|
it.TwoStartDate[1] = item.YearDate + ' ' + it.TwoStartDate[1] + ':00'
|
}
|
if (it.ThreeStartDate !== '') {
|
it.ThreeStartDate = it.ThreeStartDate.split('~')
|
it.ThreeStartDate[0] = item.YearDate + ' ' + it.ThreeStartDate[0] + ':00'
|
it.ThreeStartDate[1] = item.YearDate + ' ' + it.ThreeStartDate[1] + ':00'
|
}
|
if (it.FourStartDate !== '') {
|
it.FourStartDate = it.FourStartDate.split('~')
|
it.FourStartDate[0] = item.YearDate + ' ' + it.FourStartDate[0] + ':00'
|
it.FourStartDate[1] = item.YearDate + ' ' + it.FourStartDate[1] + ':00'
|
}
|
if (it.FiveStartDate !== '') {
|
it.FiveStartDate = it.FiveStartDate.split('~')
|
it.FiveStartDate[0] = item.YearDate + ' ' + it.FiveStartDate[0] + ':00'
|
it.FiveStartDate[1] = item.YearDate + ' ' + it.FiveStartDate[1] + ':00'
|
}
|
})
|
})
|
|
// 格式转换,根据wo_code再套一层children
|
waitingForScheduling = this.listToTree(waitingForScheduling)
|
|
// 构建 按设备优先排程的 数据格式 schedulingData
|
const allCapacity = [] // 代表的是所有的产能
|
waitingForScheduling.forEach(item => {
|
item.children[0].children.forEach(it => {
|
const obj = {
|
wo_code: item.wo_code, // 工单号
|
id: it.AdvaDevicNumber, // 设备的code
|
name: it.AdvaDevicName, // 设备名称
|
AdvaDevicRhythm: it.AdvaDevicRhythm, // 节拍多少秒生产一个(生产节拍)
|
status: true, // 甘特图左侧复选框是否是选中状态 当为true时渲染 为false时 不渲染产能
|
colorPair: { // 颜色集 不同状态下的甘特图的颜色 (目前的理解)
|
dark: 'rgb(83, 186, 241,0.8)',
|
light: 'rgb(83, 186, 241,0.1)',
|
light_capacity: 'rgb(209,239,237,0.8)',
|
h_schedule: 'rgb(100,255,192,0.8)',
|
scheduleing: 'rgb(20,182,231,0.8)'
|
},
|
gtArray: [] // 甘特图的每一个子项
|
}
|
allCapacity.push(obj)
|
})
|
})
|
|
// 每一个设备的产能
|
const everyEqpCapacity = []
|
waitingForScheduling.forEach(item => {
|
item.children.forEach(it => {
|
const maxDate = this.multipleSelection.find(i => i.AdvaScheWorkCode === it.wo_code).AdvaScheEndDate // 当前工单的最大排程日期
|
it.children.forEach(i => {
|
if (i.OneStartDate !== '') {
|
const obj = {
|
maxDate,
|
work_order: item.wo_code,
|
id: '',
|
start: '',
|
end: '',
|
mod: ''
|
}
|
obj.id = i.AdvaDevicNumber
|
obj.start = i.OneStartDate[0]
|
obj.end = i.OneStartDate[1]
|
// AdvaDevicCropMob 稼动率 AdvaDevicRhythm 生产节拍
|
obj.mod = (i.AdvaDevicCropMob * 1) / 100 // 稼动率
|
everyEqpCapacity.push(obj)
|
}
|
if (i.TwoStartDate !== '') {
|
const obj = {
|
maxDate,
|
work_order: item.wo_code,
|
id: '',
|
start: '',
|
end: '',
|
mod: ''
|
}
|
obj.id = i.AdvaDevicNumber
|
obj.start = i.TwoStartDate[0]
|
obj.end = i.TwoStartDate[1]
|
// AdvaDevicCropMob 稼动率 AdvaDevicRhythm 生产节拍
|
obj.mod = (i.AdvaDevicCropMob * 1) / 100 // 稼动率
|
everyEqpCapacity.push(obj)
|
}
|
if (i.ThreeStartDate !== '') {
|
const obj = {
|
maxDate,
|
work_order: item.wo_code,
|
id: '',
|
start: '',
|
end: '',
|
mod: ''
|
}
|
obj.id = i.AdvaDevicNumber
|
obj.start = i.ThreeStartDate[0]
|
obj.end = i.ThreeStartDate[1]
|
// AdvaDevicCropMob 稼动率 AdvaDevicRhythm 生产节拍
|
obj.mod = (i.AdvaDevicCropMob * 1) / 100 // 稼动率
|
everyEqpCapacity.push(obj)
|
}
|
if (i.FourStartDate !== '') {
|
const obj = {
|
maxDate,
|
work_order: item.wo_code,
|
id: '',
|
start: '',
|
end: '',
|
mod: ''
|
}
|
obj.id = i.AdvaDevicNumber
|
obj.start = i.FourStartDate[0]
|
obj.end = i.FourStartDate[1]
|
// AdvaDevicCropMob 稼动率 AdvaDevicRhythm 生产节拍
|
obj.mod = (i.AdvaDevicCropMob * 1) / 100 // 稼动率
|
everyEqpCapacity.push(obj)
|
}
|
if (i.FiveStartDate !== '') {
|
const obj = {
|
maxDate,
|
work_order: item.wo_code,
|
id: '',
|
start: '',
|
end: '',
|
mod: ''
|
}
|
obj.id = i.AdvaDevicNumber
|
obj.start = i.FiveStartDate[0]
|
obj.end = i.FiveStartDate[1]
|
// AdvaDevicCropMob 稼动率 AdvaDevicRhythm 生产节拍
|
obj.mod = (i.AdvaDevicCropMob * 1) / 100 // 稼动率
|
everyEqpCapacity.push(obj)
|
}
|
})
|
})
|
})
|
|
// 插入产能时间段 产能数据都在gtArray里面
|
waitingForScheduling.forEach(item => {
|
allCapacity.forEach(it => {
|
if (item.wo_code === it.wo_code) {
|
this.pushCapacity(everyEqpCapacity, it.id, it.gtArray)
|
it.gtArray = it.gtArray.filter((currentValue, currentIndex, selfArr) => {
|
return selfArr.findIndex(item => item.start === currentValue.start) === currentIndex
|
})
|
// it.gtArray.sort((a, b) => new Date(a.end).getTime() - new Date(b.end).getTime())
|
}
|
})
|
})
|
// console.log(allCapacity, 'allCapacity')
|
this.schedulingAllData = JSON.parse(JSON.stringify(allCapacity))
|
|
// 去重设备id(code)
|
this.schedulingData = allCapacity.filter((currentValue, currentIndex, selfArr) => {
|
return selfArr.findIndex(item => item.id === currentValue.id) === currentIndex
|
})
|
|
// 排程复选框的选中与取消
|
if (this.ganttLeftArrId !== '') {
|
for (const j in this.schedulingData) {
|
if (this.ganttLeftArrId.indexOf(this.schedulingData[j].id) >= 0) {
|
this.schedulingData[j].gtArray = []
|
this.schedulingData[j].status = false
|
}
|
}
|
}
|
|
// 将工单的优先级进行排序,先以时间排,再以优先级排
|
// this.getMultipleSelectionOrder()
|
|
// this.eqpTopTempData = JSON.parse(JSON.stringify(this.schedulingData))
|
|
// console.log(waitingForScheduling, 'waitingForScheduling')
|
// console.log(allCapacity, 'allCapacity')
|
// console.log(this.schedulingData, 'schedulingData')
|
// // console.log(JSON.stringify(this.schedulingData), 'schedulingData')
|
// console.log(this.schedulingAllData, 'schedulingAllData')
|
// console.log(everyEqpCapacity, 'everyEqpCapacity')
|
},
|
// 将工单的优先级进行排序,先以时间排,再以优先级排
|
getMultipleSelectionOrder() {
|
// 1.先通过时间去重知道有哪几天的时间 // 2.遍历这几天的时间,过滤出相对应的工单
|
const newArr = []
|
this.multipleSelection.filter((currentValue, currentIndex, selfArr) => {
|
return selfArr.findIndex(item => item.AdvaScheEndDate === currentValue.AdvaScheEndDate) === currentIndex
|
}).map(i => i.AdvaScheEndDate).forEach(i => {
|
newArr.push(this.multipleSelection.filter(j => j.AdvaScheEndDate === i))
|
})
|
// 根据日期相同的,工单优先级进行排序
|
newArr.filter(i => {
|
i.sort((a, b) => b.AdvaSchePiroQueNumber - a.AdvaSchePiroQueNumber)
|
})
|
// 排好之后 工单顺序就是整个的优先级
|
this.multipleSelection = newArr.flat()// 二维转一维
|
},
|
|
// 设备优先 数据格式转换
|
eqpDataTransition2() {
|
const needNumber = this.formBottom.needArrangeNumber // 需排数量
|
|
// 将产能的所有值与多选框的选中的行时间进行匹配校验 以便后续计算
|
this.multipleSelection.forEach(item => {
|
this.schedulingAllData.forEach(it => {
|
// 找到工单所对应的设备进行计算排程 写出计算逻辑 这部分比较上头
|
if (it.wo_code === item.AdvaScheWorkCode) {
|
it.gtArray.forEach(i => {
|
const t = i.start.split(' ')[0]
|
// 代表当前工单下的产能是否可排
|
i.status = new Date(t).getTime() <= new Date(item.AdvaScheEndDate).getTime()
|
})
|
// 目前计算逻辑还不太清楚怎么写 太上头了
|
|
console.log(it.id, 'it')
|
|
const end_time = ''
|
const mistiming = ''
|
const data = {
|
id: it.id,
|
start: '2023-04-17 14:00:00',
|
end: '2023-04-17 16:00:00',
|
type: 'schedule',
|
cl_name: item.AdvaSchePartName,
|
cl_code: item.AdvaSchePartNumber,
|
work_order: item.AdvaScheWorkCode,
|
AdvaScheUom: item.AdvaScheUom,
|
number: 0,
|
real_number: 0
|
}
|
// 工单相同之后 应该根据时间优先或者设备优先 对设备进行一一排程
|
|
// 这个地方不对 写不出来了
|
// data.start = it.gtArray[0].start // 先只考虑一种情况
|
// data.start = it.gtArray[0].start // 先只考虑一种情况
|
data.number = '230'
|
data.real_number = '230'
|
const index = this.schedulingData.findIndex(i => i.id === it.id)
|
this.schedulingData[index].gtArray.push(data)
|
console.log(JSON.stringify(it))
|
}
|
})
|
})
|
|
// 这个是计算出来的数值,需要push到schedulingData中
|
|
// 'id': 'JG002',
|
// 'start': '2023-04-17 10:10:21',
|
// 'end': '2023-04-17 11:30:00',
|
// 'type': 'schedule',
|
// 'cl_name': '主机',
|
// 'cl_code': '201',
|
// 'work_order': 'MO-2023-04-0001_1',
|
// 'AdvaScheUom': '个',
|
// 'number': '64',
|
// 'real_number': 63.72
|
|
// this.schedulingData = [
|
// {
|
// 'id': 'JG002',
|
// 'name': '精工设备2#',
|
// 'AdvaDevicRhythm': '15.0',
|
// 'status': true,
|
// 'colorPair': {
|
// 'dark': 'rgb(83, 186, 241,0.8)',
|
// 'light': 'rgb(83, 186, 241,0.1)',
|
// 'light_capacity': 'rgb(209,239,237,0.8)',
|
// 'h_schedule': 'rgb(100,255,192,0.8)',
|
// 'scheduleing': 'rgb(20,182,231,0.8)'
|
// },
|
// 'gtArray': [
|
// {
|
// 'start': '2023-04-17 08:00:00',
|
// 'end': '2023-04-17 11:30:00',
|
// 'id': 'JG002',
|
// 'mod': 0.2,
|
// 'type': 'capacity'
|
// },
|
// {
|
// 'start': '2023-04-17 13:00:00',
|
// 'end': '2023-04-17 18:00:00',
|
// 'id': 'JG002',
|
// 'mod': 0.2,
|
// 'type': 'capacity'
|
// },
|
// {
|
// 'id': 'JG002',
|
// 'start': '2023-04-17 10:10:21',
|
// 'end': '2023-04-17 11:30:00',
|
// 'type': 'schedule',
|
// 'cl_name': '主机',
|
// 'cl_code': '201',
|
// 'work_order': 'MO-2023-04-0001_1',
|
// 'AdvaScheUom': '个',
|
// 'number': '64',
|
// 'real_number': 63.72
|
// },
|
// {
|
// 'id': 'JG002',
|
// 'start': '2023-04-17 13:00:00',
|
// 'end': '2023-04-17 18:00:00',
|
// 'type': 'schedule',
|
// 'cl_name': '主机',
|
// 'cl_code': '201',
|
// 'work_order': 'MO-2023-04-0001_1',
|
// 'AdvaScheUom': '个',
|
// 'number': '240',
|
// 'real_number': 240
|
// }
|
// ]
|
// },
|
// {
|
// 'id': 'SB001',
|
// 'name': '设备001',
|
// 'AdvaDevicRhythm': '15.0',
|
// 'status': true,
|
// 'colorPair': {
|
// 'dark': 'rgb(83, 186, 241,0.8)',
|
// 'light': 'rgb(83, 186, 241,0.1)',
|
// 'light_capacity': 'rgb(209,239,237,0.8)',
|
// 'h_schedule': 'rgb(100,255,192,0.8)',
|
// 'scheduleing': 'rgb(20,182,231,0.8)'
|
// },
|
// 'gtArray': [
|
// {
|
// 'start': '2023-04-17 08:00:00',
|
// 'end': '2023-04-17 11:30:00',
|
// 'id': 'SB001',
|
// 'mod': 0.3,
|
// 'type': 'capacity'
|
// },
|
// {
|
// 'start': '2023-04-17 13:00:00',
|
// 'end': '2023-04-17 18:00:00',
|
// 'id': 'SB001',
|
// 'mod': 0.3,
|
// 'type': 'capacity'
|
// },
|
// {
|
// 'id': 'SB001',
|
// 'start': '2023-04-17 10:10:21',
|
// 'end': '2023-04-17 11:30:00',
|
// 'type': 'schedule',
|
// 'cl_name': '主机',
|
// 'cl_code': '201',
|
// 'work_order': 'MO-2023-04-0001_1',
|
// 'AdvaScheUom': '个',
|
// 'number': '96',
|
// 'real_number': 95.58
|
// },
|
// {
|
// 'id': 'SB001',
|
// 'start': '2023-04-17 13:00:00',
|
// 'end': '2023-04-17 18:00:00',
|
// 'type': 'schedule',
|
// 'cl_name': '主机',
|
// 'cl_code': '201',
|
// 'work_order': 'MO-2023-04-0001_1',
|
// 'AdvaScheUom': '个',
|
// 'number': '360',
|
// 'real_number': 360
|
// }
|
// ]
|
// }
|
// ]
|
|
console.log(this.schedulingData, 'schedulingData')
|
console.log(this.schedulingAllData, 'schedulingAllData')
|
},
|
// 获取排程日期最大值
|
getMaxPayDate() {
|
this.formBottom.needArrangeNumber = 0
|
let maxPayDate = handleDatetime(new Date())
|
if (this.multipleSelection.length > 0) {
|
this.multipleSelection.forEach(i => {
|
this.formBottom.needArrangeNumber += i.AdvaScheQty * 1 - i.AdvaScheYPQty * 1
|
if (new Date(i.AdvaScheEndDate).getTime() > new Date(maxPayDate).getTime()) {
|
maxPayDate = i.AdvaScheEndDate
|
}
|
})
|
}
|
|
this.formBottom.scheDate = [] // 排程日期置空
|
this.formBottom.scheDate.push(handleDatetime(new Date())) // 当前日期(今天)
|
this.formBottom.scheDate.push(maxPayDate) // 要求交付时间
|
|
if (this.formBottom.scheDate !== '') {
|
this.time_data[0] = this.formBottom.scheDate[0] + ' 00:00' // 排程开始时间
|
this.time_data[1] = this.formBottom.scheDate[1] + ' 23:59' // 排程结束时间
|
}
|
},
|
// 插入产能时间段
|
pushCapacity(newList, id, arr) {
|
for (const i in newList) {
|
if (newList[i].id === id) {
|
// console.log(JSON.stringify(newList[i]))
|
const t = this.multipleSelection.find(j => j.AdvaScheWorkCode === newList[i].work_order)
|
const data = {
|
work_order: t.AdvaScheWorkCode,
|
AdvaScheUom: t.AdvaScheUom,
|
partname: t.AdvaSchePartName,
|
partcode: t.AdvaSchePartNumber,
|
start: newList[i].start,
|
end: newList[i].end,
|
id: newList[i].id,
|
mod: newList[i].mod,
|
type: 'capacity'
|
}
|
arr.push(data)
|
}
|
}
|
},
|
// 递归构建树形并返回
|
listToTree(list) {
|
const pid = [...new Set(list.map(i => i.wo_code))]
|
const newArr = []
|
pid.forEach(i => {
|
const arr = []
|
list.forEach(j => {
|
if (i === j.wo_code) {
|
arr.push(j)
|
}
|
})
|
newArr.push({ children: arr, wo_code: i })
|
})
|
return newArr
|
},
|
|
// 提交排程
|
async prepareSubmit() {
|
if (this.formBottom.canArrangeNumber !== this.formBottom.needArrangeNumber) {
|
this.$message.error('数量未排完,请设置产能时间!')
|
} else {
|
const list = [] // 提交数组
|
for (const i in this.schedulingData) {
|
const arr = []
|
for (const j in this.schedulingData[i].gtArray) {
|
if (this.schedulingData[i].gtArray[j].type === 'schedule') {
|
arr.push(this.schedulingData[i].gtArray[j])
|
}
|
}
|
if (arr !== '') {
|
for (const i in arr) {
|
const data = {
|
AlreDevicNumber: '',
|
AlreStartDate: '',
|
AlreEndDate: '',
|
AlreQty: ''
|
}
|
data.AlreDevicNumber = arr[i].id
|
data.AlreStartDate = arr[i].start
|
data.AlreEndDate = arr[i].end
|
data.AlreQty = arr[i].number
|
list.push(data)
|
}
|
}
|
}
|
// 排程相同设备获取开始时间 结束时间 数量的总和
|
// 过滤
|
let update = []
|
for (const i in list) {
|
if (list[i].AlreStartDate !== '') {
|
update.push(list[i])
|
}
|
}
|
|
update = JSON.stringify(update)
|
this.formUpdate.json = update
|
if (list === '') {
|
this.$message.error('请先预排')
|
return false
|
}
|
|
const formData = new FormData()
|
formData.append('wocode', this.formUpdate.WorkCode)
|
formData.append('botprocecode', this.formUpdate.BotProceCode)
|
formData.append('json', this.formUpdate.json)
|
|
const res = await SubmitAlreadyScheduling(formData)
|
|
if (res.code === '200') {
|
this.$message.success(res.Message)
|
}
|
|
this.formBottom.needArrangeNumber = 0
|
this.formBottom.canArrangeNumber = 0
|
await this.getOnclickAdvancedSchedulingDevice()
|
await this.getAdvancedSchedulingSearch()
|
}
|
},
|
|
prepareArrange() {
|
const timestamp = new Date().toLocaleDateString()
|
|
if (new Date(this.formBottom.scheDate[1]) < new Date(timestamp)) {
|
this.$message.error('排程日期不可以小于当前时间!')
|
return false
|
}
|
this.filterAlreadyScheduleEqp()// 手动过滤所有设备已排程
|
|
// 设备优先或者时间优先 对数据进行的格式转换
|
if (this.schedulingData !== '' && this.formBottom.types === 'N') { // 设备优先
|
this.eqpDataTransition()
|
this.editLastValue(this.schedulingData)
|
} else if (this.timeTopTempData !== '' && this.formBottom.types === 'Y') { // 时间优先
|
this.filterAlreadyScheduleTime() // 手动过滤所有时间已排程
|
this.timeDataTransition()
|
this.dataTransition()
|
this.editLastValue(this.schedulingData)
|
}
|
},
|
// 手动过滤所有时间已排程
|
filterAlreadyScheduleTime() {
|
this.timeTopTempData.forEach(item => {
|
if (item.gtArray && item.gtArray.length > 0) {
|
item.gtArray = item.gtArray.filter(it => it.type !== 'schedule')
|
}
|
})
|
},
|
// 手动过滤所有设备已排程
|
filterAlreadyScheduleEqp() {
|
this.schedulingData.forEach(item => {
|
if (item.gtArray && item.gtArray.length > 0) {
|
item.gtArray = item.gtArray.filter(it => it.type !== 'schedule')
|
}
|
})
|
},
|
// 给排程最后一个修改数量
|
editLastValue(arr) {
|
this.formBottom.canArrangeNumber = 0 // 真实已排数量
|
let num = 0 // 取整已排数量
|
const arr_num = [] // 已排数据
|
let need_num = 0
|
for (const i in arr) {
|
for (const j in arr[i].gtArray) {
|
if (arr[i].gtArray[j].type === 'schedule') {
|
arr_num.unshift(arr[i].gtArray[j])
|
}
|
}
|
}
|
|
for (const n in arr_num) {
|
this.formBottom.canArrangeNumber += arr_num[n].real_number
|
num += arr_num[n].number * 1
|
}
|
|
this.formBottom.canArrangeNumber = Math.ceil(this.formBottom.canArrangeNumber)
|
const y10 = this.formBottom.needArrangeNumber - this.formBottom.canArrangeNumber
|
if (y10 <= 10) {
|
this.formBottom.canArrangeNumber = this.formBottom.needArrangeNumber
|
need_num = this.formBottom.needArrangeNumber - num
|
} else {
|
}
|
for (const i in this.schedulingData) {
|
for (const j in this.schedulingData[i].gtArray) {
|
if (
|
this.schedulingData[i].gtArray[j].type === 'schedule' &&
|
this.schedulingData[i].gtArray[j].end_num
|
) {
|
this.schedulingData[i].gtArray[j].number =
|
this.schedulingData[i].gtArray[j].number * 1 + need_num
|
}
|
}
|
}
|
},
|
// 设备优先 数据格式转换
|
eqpDataTransition() { // 这里是原先的写法
|
let needNumber = this.formBottom.needArrangeNumber // 需排数量
|
let flag1 = 0
|
console.log(this.schedulingData, 33)
|
console.log(this.schedulingData.length, 33)
|
for (const i in this.schedulingData) {
|
console.log(i, '中国移动')
|
let end_arr = [] // 已排程的数组
|
let need_arr = [] // 待排程的数组
|
|
let capacity_arr = [] // 要排程的数组
|
this.schedulingData[i].gtArray.sort((a, b) => new Date(a.end).getTime() - new Date(b.end).getTime())
|
|
end_arr = JSON.parse(JSON.stringify(this.schedulingData[i].gtArray.filter(item => item.type === 'h_schedule'))) // 已排程数组
|
need_arr = JSON.parse(JSON.stringify(this.schedulingData[i].gtArray.filter(item => item.type === 'capacity'))) // 容量
|
// console.log(need_arr, 5)
|
// console.log(JSON.stringify(need_arr))
|
|
// need_arr = [
|
// {
|
// 'start': '2023-03-25 08:00:00',
|
// 'end': '2023-03-25 11:30:00',
|
// 'id': 'SB001',
|
// 'mod': 0.3,
|
// 'type': 'capacity'
|
// },
|
// {
|
// 'start': '2023-03-25 13:00:00',
|
// 'end': '2023-03-25 18:00:00',
|
// 'id': 'SB001',
|
// 'mod': 0.3,
|
// 'type': 'capacity'
|
// },
|
// {
|
// 'start': '2023-03-26 06:00:00',
|
// 'end': '2023-03-26 11:00:00',
|
// 'id': 'SB001',
|
// 'mod': 0.3,
|
// 'type': 'capacity'
|
// },
|
// {
|
// 'start': '2023-03-26 14:00:00',
|
// 'end': '2023-03-26 20:00:00',
|
// 'id': 'SB001',
|
// 'mod': 0.3,
|
// 'type': 'capacity'
|
// },
|
// {
|
// 'start': '2023-03-26 21:30:00',
|
// 'end': '2023-03-26 23:00:00',
|
// 'id': 'SB001',
|
// 'mod': 0.3,
|
// 'type': 'capacity'
|
// },
|
// {
|
// 'start': '2023-03-27 05:30:00',
|
// 'end': '2023-03-27 17:30:00',
|
// 'id': 'SB001',
|
// 'mod': 0.3,
|
// 'type': 'capacity'
|
// },
|
// {
|
// 'start': '2023-03-28 08:00:00',
|
// 'end': '2023-03-28 11:30:00',
|
// 'id': 'SB001',
|
// 'mod': 0.3,
|
// 'type': 'capacity'
|
// },
|
// {
|
// 'start': '2023-03-28 13:00:00',
|
// 'end': '2023-03-28 18:00:00',
|
// 'id': 'SB001',
|
// 'mod': 0.3,
|
// 'type': 'capacity'
|
// },
|
// {
|
// 'start': '2023-03-29 08:00:00',
|
// 'end': '2023-03-29 11:30:00',
|
// 'id': 'SB001',
|
// 'mod': 0.3,
|
// 'type': 'capacity'
|
// },
|
// {
|
// 'start': '2023-03-29 13:00:00',
|
// 'end': '2023-03-29 18:00:00',
|
// 'id': 'SB001',
|
// 'mod': 0.3,
|
// 'type': 'capacity'
|
// },
|
// {
|
// 'start': '2023-03-30 08:00:00',
|
// 'end': '2023-03-30 11:30:00',
|
// 'id': 'SB001',
|
// 'mod': 0.3,
|
// 'type': 'capacity'
|
// },
|
// {
|
// 'start': '2023-03-30 13:00:00',
|
// 'end': '2023-03-30 18:00:00',
|
// 'id': 'SB001',
|
// 'mod': 0.3,
|
// 'type': 'capacity'
|
// },
|
// {
|
// 'start': '2023-03-31 08:00:00',
|
// 'end': '2023-03-31 11:30:00',
|
// 'id': 'SB001',
|
// 'mod': 0.3,
|
// 'type': 'capacity'
|
// },
|
// {
|
// 'start': '2023-03-31 13:00:00',
|
// 'end': '2023-03-31 18:00:00',
|
// 'id': 'SB001',
|
// 'mod': 0.3,
|
// 'type': 'capacity'
|
// }
|
// ]
|
if (end_arr && end_arr.length > 0) {
|
capacity_arr = need_arr.map(item => {
|
// 排除掉已经排程的存在hshedule,start,end都相等的情况
|
const schedule = end_arr.filter(it => {
|
return new Date(item.start).getTime() <= new Date(it.start).getTime() &&
|
new Date(item.end).getTime() >= new Date(it.end).getTime()
|
})
|
|
if (schedule && schedule.length > 0) {
|
item.start = this.MinutesTest(schedule[schedule.length - 1]['end'])
|
}
|
|
const schedule1 = end_arr.filter(schedule => {
|
return new Date(item.start).getTime() === new Date(schedule.start).getTime() &&
|
new Date(item.end).getTime() === new Date(schedule.end).getTime()
|
})
|
if (schedule1 && schedule1.length > 0) {
|
item.capacity = false
|
}
|
|
return item
|
}).filter(item => item.capacity !== false)
|
} else {
|
capacity_arr = need_arr
|
}
|
|
const id_obj = {
|
id: '',
|
start_time: ''
|
}
|
if (end_arr != '') {
|
(id_obj.id = end_arr[0].id), (id_obj.start_time = end_arr[0].end)
|
}
|
|
capacity_arr = this.filterOutTime(capacity_arr) // 过滤掉当前时间之前的不能排程
|
|
for (const w in capacity_arr) {
|
let end_time = ''
|
let mistiming = ''
|
const data = {
|
id: capacity_arr[w].id,
|
start: '',
|
end: '',
|
type: 'schedule',
|
cl_name: this.cl_name,
|
cl_code: this.cl_code,
|
work_order: this.work_order,
|
AdvaScheUom: this.AdvaScheUom,
|
number: 0,
|
real_number: 0
|
}
|
if (
|
id_obj.start_time !== '' &&
|
flag1 === 0 &&
|
new Date(id_obj.start_time).getTime() >= new Date(capacity_arr[w].start).getTime()
|
) {
|
data.start = this.MinutesTest(id_obj.start_time)
|
flag1 = 1
|
} else {
|
data.start = capacity_arr[w].start
|
}
|
let nowTime = (this.schedulingData[i].AdvaDevicRhythm * needNumber) / capacity_arr[w].mod
|
end_time = this.formSeconds(nowTime, data.start, capacity_arr[w].mod) // 总共的结束时间
|
data.end = end_time
|
mistiming = this.compareTime(
|
end_time,
|
capacity_arr[w].end,
|
capacity_arr[w].mod
|
) // 总共的结束时间-当前的结束时间 = 剩下多久时间
|
if (mistiming >= 0) {
|
data.number =
|
((new Date(data.end) - new Date(data.start)) *
|
capacity_arr[w].mod) /
|
this.schedulingData[i].AdvaDevicRhythm /
|
1000
|
data.real_number =
|
((new Date(data.end) - new Date(data.start)) *
|
capacity_arr[w].mod) /
|
this.schedulingData[i].AdvaDevicRhythm /
|
1000
|
data.number = data.number.toFixed(0)
|
data.end_num = true
|
if (new Date(data.start) >= new Date(data.end)) {
|
} else {
|
this.schedulingData[i].gtArray.push(data)
|
}
|
return false
|
} else {
|
data.end = capacity_arr[w].end
|
|
if (new Date(data.end).getTime() < new Date(data.start)) {
|
continue // 因为开始时间比结束时间大 需要跳过后面步骤
|
}
|
|
// 这里除以一千是因为 new Date() 得到的是毫秒 毫秒转化为秒是千进制
|
// 一段时间段内的生产量=两者时间差(毫秒)/1000 / 生产节拍 * 稼动率
|
data.number =
|
((new Date(data.end) - new Date(data.start)) *
|
capacity_arr[w].mod) /
|
this.schedulingData[i].AdvaDevicRhythm /
|
1000
|
|
data.real_number =
|
((new Date(data.end) - new Date(data.start)) *
|
capacity_arr[w].mod) /
|
this.schedulingData[i].AdvaDevicRhythm /
|
1000
|
|
data.number = data.number.toFixed(0)
|
|
nowTime = (needNumber - data.real_number) * this.schedulingData[i].AdvaDevicRhythm
|
needNumber = needNumber - data.real_number
|
if (new Date(data.start) >= new Date(data.end)) {
|
|
} else {
|
this.schedulingData[i].gtArray.push(data)
|
}
|
}
|
}
|
}
|
},
|
// 时间优先 数据格式转换
|
timeDataTransition() {
|
// 排除未勾选项
|
for (const i in this.timeTopTempData) {
|
const newArr = []
|
for (const j in this.timeTopTempData[i].gtArray) {
|
if (this.ganttLeftArrId.indexOf(this.timeTopTempData[i].gtArray[j].id) < 0) {
|
newArr.push(this.timeTopTempData[i].gtArray[j])
|
}
|
}
|
this.timeTopTempData[i].gtArray = newArr
|
}
|
let needNumber = this.formBottom.needArrangeNumber // 需排数量
|
|
// 里面逻辑要搞清楚 很重要
|
for (const i in this.timeTopTempData) {
|
let end_arr = []
|
let need_arr = [] // 排程的数组
|
|
let capacity_arr = [] // 要排程的数组
|
|
this.timeTopTempData[i].gtArray.sort((a, b) => new Date(a.end).getTime() - new Date(b.end).getTime())
|
|
end_arr = JSON.parse(JSON.stringify(this.timeTopTempData[i].gtArray.filter(item => item.type === 'h_schedule'))) // 已排程数据
|
need_arr = JSON.parse(JSON.stringify(this.timeTopTempData[i].gtArray.filter(item => item.type === 'capacity'))) // 容量
|
|
capacity_arr = JSON.parse(JSON.stringify(need_arr)) // 容量
|
|
// 获取可排程的时间 以便接着往后排程 遍历结束要得到的是 当前日期可排容量
|
end_arr.forEach((item, index) => { // 已排程的数组
|
capacity_arr.forEach((it, ind) => { // 容量(日产能)
|
if (item.id === it.id &&
|
new Date(item.start).getTime() >= new Date(it.start).getTime() &&
|
new Date(item.end).getTime() === new Date(it.end).getTime() // new Date(item.end).getTime() <= new Date(it.end).getTime()
|
) {
|
capacity_arr.splice(ind, 1)
|
}
|
})
|
})
|
|
// continue:表示跳出本次循环,也就是不执行本次循环continue之后的操作
|
// break:表示跳出当前的循环,针对整个循环体终止后续的遍历;
|
if (!capacity_arr || capacity_arr.length === 0) {
|
continue
|
}
|
|
const schedule_arr = end_arr.filter(item => {
|
const remain = need_arr.some(it => {
|
return (new Date(item.start).getTime() >= new Date(it.start).getTime() &&
|
new Date(item.end).getTime() < new Date(it.end).getTime())
|
})
|
|
return remain
|
})
|
|
// 下面逻辑很重要
|
if (schedule_arr && schedule_arr.length > 0) {
|
const scheduleCan = schedule_arr.map(item => {
|
const temp = need_arr.filter(it => {
|
if (it.id === item.id) {
|
return (new Date(item.start).getTime() >= new Date(it.start).getTime() &&
|
new Date(item.end).getTime() < new Date(it.end).getTime())
|
// ||
|
// (new Date(item.start).getTime() > new Date(it.start).getTime() &&
|
// new Date(item.end).getTime() < new Date(it.end).getTime())
|
}
|
})[0]
|
|
temp.start = this.MinutesTest(item.end)
|
|
return temp
|
})
|
|
const newSchedule = JSON.parse(JSON.stringify(scheduleCan))
|
|
capacity_arr.forEach(item => {
|
newSchedule.forEach(it => {
|
if (item.id === it.id && new Date(item.start).getTime() < new Date(it.start).getTime()) {
|
item.start = it.start
|
}
|
})
|
})
|
}
|
|
const id_obj = {}
|
if (end_arr != '') {
|
(id_obj.id = end_arr[0].id), (id_obj.start_time = end_arr[0].end)
|
}
|
|
capacity_arr = this.filterOutTime(capacity_arr) // 过滤掉当前时间之前的不能排程
|
|
for (const w in capacity_arr) {
|
const data = {
|
id: capacity_arr[w].id,
|
start: '',
|
end: '',
|
type: 'schedule',
|
cl_name: this.cl_name,
|
cl_code: this.cl_code,
|
work_order: this.work_order,
|
AdvaScheUom: this.AdvaScheUom, // 单位
|
number: 0,
|
real_number: 0
|
}
|
|
if (
|
id_obj &&
|
new Date(id_obj.start_time).getTime() >=
|
new Date(capacity_arr[w].start).getTime()
|
) {
|
if (data.id === id_obj.id) {
|
data.start = this.MinutesTest(id_obj.start_time)
|
} else {
|
data.start = capacity_arr[w].start
|
}
|
} else {
|
data.start = capacity_arr[w].start
|
}
|
|
let nowTime = (capacity_arr[w].rhythm * needNumber) / capacity_arr[w].mod
|
|
const end_time = this.formSeconds(nowTime, data.start)
|
|
data.end = end_time
|
const mistiming = this.compareTime(end_time, capacity_arr[w].end)
|
if (mistiming >= 0) {
|
data.number = ((new Date(data.end) - new Date(data.start)) * capacity_arr[w].mod) / capacity_arr[w].rhythm / 1000
|
data.real_number = ((new Date(data.end) - new Date(data.start)) * capacity_arr[w].mod) / capacity_arr[w].rhythm / 1000
|
data.number = data.number.toFixed(0)
|
data.end_num = true
|
|
if (new Date(data.start) >= new Date(data.end)) {
|
|
} else {
|
this.timeTopTempData[i].gtArray.push(data)
|
}
|
|
return false
|
} else {
|
data.end = capacity_arr[w].end
|
data.number = ((new Date(data.end) - new Date(data.start)) * capacity_arr[w].mod) / capacity_arr[w].rhythm / 1000
|
data.real_number = ((new Date(data.end) - new Date(data.start)) * capacity_arr[w].mod) / capacity_arr[w].rhythm / 1000
|
data.number = data.number.toFixed(0)
|
nowTime = (needNumber - data.real_number) * capacity_arr[w].rhythm
|
needNumber = needNumber - data.real_number
|
|
if (new Date(data.start) >= new Date(data.end)) {
|
} else {
|
this.timeTopTempData[i].gtArray.push(data)
|
}
|
}
|
}
|
}
|
},
|
// 过滤掉当前时间之前的不能排程
|
filterOutTime(capacity_arr) {
|
// 这里要将容量和当前时间做对比 做时间处理 如果在当前时间之前的不能排程
|
capacity_arr.forEach((item, index) => {
|
// 当前时间 大于等于开始时间 且小于等于结束时间
|
if (new Date(item.start).getTime() <= new Date(handleDatetime2(new Date())).getTime() && new Date(item.end).getTime() >= new Date(handleDatetime2(new Date())).getTime()) {
|
item.start = handleDatetime2(new Date())
|
}
|
// 当前时间比开始时间大 比结束时间也大
|
if (new Date(item.start).getTime() < new Date(handleDatetime2(new Date())).getTime() && new Date(item.end).getTime() < new Date(handleDatetime2(new Date())).getTime()) {
|
item.capacity = false
|
}
|
})
|
|
return capacity_arr.filter(item => item.capacity !== false)
|
},
|
|
// 时间优先 给设备转换格式
|
dataTransition() {
|
this.schedulingData = []
|
const data = this.timeTopTempData
|
|
const all = []
|
// const list = this.eqpTopTempData
|
const list = this.eqpTopTempData
|
|
console.log(this.eqpTopTempData, 212)
|
for (const i in data) {
|
for (const j in data[i].gtArray) {
|
all.push(data[i].gtArray[j])
|
}
|
}
|
|
for (const i in list) {
|
list[i].gtArray = []
|
this.pushTimes(all, list[i].id, list[i].gtArray)// 插入产能时间段
|
}
|
|
for (const n in list) {
|
if (list[n].gtArray.length === 0) {
|
list[n].status = false
|
}
|
}
|
|
this.schedulingData = list
|
},
|
// 插入产能时间段
|
pushTimes(newList, id, arr) {
|
for (const i in newList) {
|
if (newList[i].id === id) {
|
arr.push(newList[i])
|
}
|
}
|
},
|
// 排程方法
|
formSeconds(s1, start, mod) {
|
const nowData = new Date(start)
|
// 算出当前排程的结束时间
|
return this.transitionTime(
|
new Date(nowData.setSeconds(nowData.getSeconds() + s1))
|
)
|
},
|
// 转化标准时间
|
transitionTime(time) {
|
const d = new Date(time)
|
return (
|
d.getFullYear() +
|
'-' +
|
(d.getMonth() + 1).toString().padStart(2, '0') +
|
'-' +
|
d.getDate().toString().padStart(2, '0') +
|
' ' +
|
d.getHours().toString().padStart(2, '0') +
|
':' +
|
d.getMinutes().toString().padStart(2, '0') +
|
':' +
|
d.getSeconds().toString().padStart(2, '0')
|
)
|
},
|
// 时间比较
|
compareTime(d1, d2, mod) {
|
// d1 排除结束时间 d2 当前产能结束时间
|
const time1 = new Date(d1)
|
const time2 = new Date(d2)
|
return parseInt(time2 - time1) / 1000
|
}
|
}
|
}
|
</script>
|
<!--排程部分的样式-->
|
<style scoped>
|
body {
|
font-size: 12px;
|
margin: 0;
|
padding: 0;
|
width: 100%;
|
height: 100%;
|
}
|
|
.box_style {
|
position: relative;
|
top: 40px;
|
left: -91px;
|
}
|
|
.box_styles {
|
position: relative;
|
top: 40px;
|
left: 0;
|
}
|
|
/*自动排程部分*/
|
.autoScheduling {
|
display: flex;
|
flex-direction: column;
|
/*padding: 0 10px;*/
|
/* height: calc(100vh - 100px); */
|
/*background-color: #f8f8fa;*/
|
background-color: #fff;
|
margin-top: 20px;
|
height: 490px;
|
}
|
|
.colorDescription {
|
display: flex;
|
padding: 5px 30px 0;
|
align-items: center;
|
}
|
|
.colorDescriptionItem {
|
display: flex;
|
margin-right: 20px;
|
}
|
|
label {
|
margin-left: 10px;
|
}
|
|
input {
|
width: 40px;
|
height: 20px;
|
vertical-align: middle;
|
}
|
|
input[type="range"] {
|
width: 100px;
|
}
|
|
.container {
|
display: flex;
|
flex-direction: column;
|
flex: 1;
|
}
|
|
.tc {
|
text-align: center;
|
}
|
|
.name {
|
display: flex;
|
box-sizing: border-box;
|
overflow: hidden;
|
height: 100%;
|
width: 100%;
|
padding: 0 5px 0 0;
|
border-radius: 8px 0 0 8px;
|
align-items: center;
|
}
|
|
.carId {
|
flex: 1;
|
}
|
|
.tc {
|
color: #909399;
|
font-size: 14px;
|
}
|
</style>
|
|
<!--公共页面样式-->
|
<style lang="scss" scoped>
|
$main_color: #42b983;
|
.elTableDiv {
|
::v-deep .el-radio__label {
|
display: none;
|
}
|
}
|
|
::v-deep .el-button--text {
|
font-size: 14px;
|
cursor: pointer;
|
}
|
|
.el-icon-share, .el-icon-delete, .el-icon-edit-outline {
|
color: $main_color;
|
cursor: pointer;
|
}
|
|
.el-icon-edit-outline {
|
margin-right: 15px;
|
}
|
|
::v-deep .el-button--primary, .el-button--default, .el-button--info {
|
height: 34px;
|
display: flex;
|
align-items: center;
|
padding: 0 15px;
|
}
|
|
::v-deep .el-button--primary {
|
//background-color: $main_color !important;
|
}
|
|
::v-deep .el-button--default {
|
background-color: #f8f8fa;
|
border: none;
|
}
|
|
::v-deep .el-input__inner {
|
height: 34px;
|
line-height: 34px;
|
//color: #a7a7a7;
|
}
|
|
::v-deep .el-dialog__body {
|
padding: 20px 100px !important;
|
}
|
|
::v-deep .dialogVisibleRoles .el-dialog__body {
|
padding: 20px 20px !important;
|
}
|
|
::v-deep .importPickerClass .el-dialog__body {
|
padding: 20px 20px !important;
|
}
|
|
::v-deep .el-dialog__footer {
|
display: flex;
|
justify-content: flex-end;
|
}
|
|
::v-deep .el-table .caret-wrapper {
|
transform: scale(0.8);
|
}
|
|
::v-deep .cell {
|
display: flex;
|
align-items: center;
|
justify-content: space-between;
|
}
|
|
::v-deep .el-table::before {
|
height: 0;
|
}
|
|
::v-deep .el-table__body-wrapper {
|
background-color: #f8f8fa;
|
}
|
|
::v-deep .el-table__body .el-table__row.hover-row td {
|
background-color: #eaecef;
|
}
|
|
::v-deep .el-form--inline .el-form-item__label {
|
color: #a7a7a7;
|
}
|
|
.body ::v-deep .el-divider {
|
border: 1px solid #eee;
|
width: 99%;
|
margin: 10px auto;
|
}
|
|
.body ::v-deep .el-form-item {
|
margin-bottom: 0;
|
}
|
|
.userDialogVisible ::v-deep .el-form-item {
|
margin-bottom: 0;
|
}
|
|
::v-deep .el-select__caret {
|
display: flex;
|
align-items: center;
|
justify-content: center;
|
}
|
|
.tableFixed {
|
::v-deep .el-table__fixed-right {
|
height: 100% !important;
|
}
|
|
::v-deep .el-table__fixed {
|
height: 100% !important;
|
}
|
|
}
|
|
::v-deep .gantt-header-title {
|
background-color: #fff;
|
//border-left: 1px solid #eee !important;
|
//border-bottom: 1px solid #eee !important;
|
}
|
|
</style>
|
<style>
|
|
.el-table .custom-row {
|
background: #f8f8fa;
|
}
|
|
</style>
|
|
<!--<style>-->
|
<!--input[type=range]:focus {-->
|
<!-- display: none;-->
|
<!--}-->
|
|
<!--input[type=range] {-->
|
<!-- -webkit-appearance: none;-->
|
<!-- width: 500px;-->
|
<!-- border-radius: 10px;-->
|
<!-- /*这个属性设置使填充进度条时的图形为圆角*/-->
|
<!--}-->
|
|
<!--input[type=range]::-webkit-slider-runnable-track {-->
|
<!-- height: 20px;-->
|
<!-- border-radius: 10px;-->
|
<!-- /*将轨道设为圆角的*/-->
|
<!-- /* box-shadow: 0 1px 1px #def3f8, inset 0 .125em .125em #0d1112; */-->
|
<!-- border: solid 1px red;-->
|
<!--}-->
|
|
<!--input[type=range]::-webkit-slider-thumb {-->
|
<!-- -webkit-appearance: none;-->
|
<!-- height: 30px;-->
|
<!-- width: 120px;-->
|
<!-- margin-top: -5px;-->
|
<!-- /*使滑块超出轨道部分的偏移量相等*/-->
|
<!-- background: #ffffff;-->
|
<!-- /* border-radius: 50%; */-->
|
<!-- /*外观设置为圆形*/-->
|
<!-- border: solid 0.125em rgba(205, 224, 230, 0.5);-->
|
<!-- /*设置边框*/-->
|
<!-- /* box-shadow: 0 .125em .125em #3b4547; */-->
|
<!-- /*添加底部阴影*/-->
|
<!--}-->
|
<!--</style>-->
|