| ¶Ô±ÈÐÂÎļþ |
| | |
| | | <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" |
| | | @select="handleSelect" |
| | | @selection-change="handleSelectionChange" |
| | | > |
| | | <!-- @row-click="getCurrentRow"--> |
| | | |
| | | <!-- @selection-change="handleSelectionChange"--> |
| | | |
| | | <!-- <el-table-column--> |
| | | <!-- width="50"--> |
| | | <!-- fixed--> |
| | | <!-- >--> |
| | | <!-- <template slot-scope="{row}">--> |
| | | <!-- <el-radio--> |
| | | <!-- v-model="radioSelectedId"--> |
| | | <!-- :label="row.AdvaScheId"--> |
| | | <!-- />--> |
| | | <!-- </template>--> |
| | | <!-- </el-table-column>--> |
| | | <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="radioSelectedId===''" |
| | | 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="radioSelectedId===''" |
| | | 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="radioSelectedId===''" 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="radioSelectedId===''" |
| | | 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="radioSelectedId===''" |
| | | type="primary" |
| | | icon="el-icon-document-remove" |
| | | @click="prepareArrange" |
| | | >颿 |
| | | </el-button> |
| | | <el-button |
| | | v-waves |
| | | type="primary" |
| | | :disabled="radioSelectedId===''" |
| | | 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 class="colorDescriptionItem"><i class="el-icon-s-opportunity" style="margin-right: 5px;color: #a7a7a7" />失æäº§è½</div>--> |
| | | </div> |
| | | <div |
| | | class="bodyTopFormExpand" |
| | | style="height: 5px" |
| | | /> |
| | | </div> |
| | | |
| | | <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="radioSelectedId===''" |
| | | @change="checkboxAll()" |
| | | /> |
| | | <input |
| | | v-model.number="cellWidth" |
| | | type="range" |
| | | min="20" |
| | | max="100" |
| | | class="box_styles" |
| | | :disabled="radioSelectedId===''" |
| | | > |
| | | </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, |
| | | OnclickAdvancedSchedulingDevice, |
| | | SubmitAlreadyScheduling |
| | | } from '@/api/produceManager' |
| | | import { handleDatetime, handleDatetime2 } from '@/utils/global' |
| | | import waves from '@/directive/waves' |
| | | |
| | | export default { |
| | | name: 'Zzjg', |
| | | components: { |
| | | Pagination, Scheduling |
| | | }, |
| | | directives: { waves }, |
| | | data() { |
| | | return { |
| | | mouseHoverType: 'mouseout', |
| | | isExpandForm: false, |
| | | mainHeight: 0, |
| | | tableHeight: 0, |
| | | radioSelectedId: '', // 表ååéæ¡ |
| | | 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: ''// ç»ææ¥æ |
| | | }, |
| | | formBottom: { // åºé¨è¡¨åç æ°æ®å¯¹è±¡ |
| | | scheDate: [handleDatetime(new Date()), handleDatetime(new Date())], // æç¨æ¥æ |
| | | types: 'N', // æç¨æ¹å¼ |
| | | scale: 60, // æ¶é´å»åº¦ |
| | | times: 0, // æ¢åæ¶é´ |
| | | canArrangeNumber: 0, // 坿æ°é |
| | | needArrangeNumber: 0// éææ°é |
| | | }, |
| | | schedulingData: [], // æç¨çæç»æ°æ® |
| | | timeTopTempData: [], // æ¶é´ä¼å
çä¸´æ¶æ°æ® |
| | | eqpTopTempData: [], // 设å¤ä¼å
çä¸´æ¶æ°æ® |
| | | |
| | | formUpdate: { |
| | | WorkCode: '', |
| | | BotProceCode: '', |
| | | json: [] |
| | | }, |
| | | // currentTime: dayjs(), |
| | | cellWidth: 50, |
| | | cellHeight: 30, |
| | | titleHeight: 40, |
| | | titleWidth: 250, |
| | | dataKey: 'id', |
| | | // timeList: `0,30,60,120,240,480`.split(',').map(n => parseInt(n)), |
| | | scaleList: `30,60,240,360`.split(',').map(n => parseInt(n)), |
| | | hideHeader: false, |
| | | arrayKeys: ['gtArray', 'error'], |
| | | |
| | | rowCheckBoxValue: {}// ç¹å»checkboxæ¡ éä¸çå
容 |
| | | |
| | | } |
| | | }, |
| | | |
| | | 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 |
| | | |
| | | 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) { |
| | | this.ganttLeftArrId = [] |
| | | this.getOnclickAdvancedSchedulingDevice() |
| | | } else { |
| | | 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) { |
| | | if (!val.status) { |
| | | 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 { |
| | | this.ganttLeftArrId = [] |
| | | for (const i in this.schedulingData) { |
| | | if (!this.schedulingData[i].status) { |
| | | this.ganttLeftArrId.push(this.schedulingData[i].id) |
| | | } |
| | | } |
| | | this.getOnclickAdvancedSchedulingDevice() |
| | | } |
| | | |
| | | if (!val.status) { |
| | | for (const i in this.schedulingData) { |
| | | if (!this.schedulingData[i].status) { |
| | | this.schedulingData[i].gtArray = [] |
| | | } |
| | | } |
| | | } else { |
| | | 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 getOnclickAdvancedSchedulingDevice() { |
| | | console.log(this.forms, 21) |
| | | // debugger |
| | | const res = await OnclickAdvancedSchedulingDevice(this.forms) |
| | | if (res.rus.Message) { |
| | | this.$message.error(res.rus.Message) |
| | | } |
| | | |
| | | const data = res.rows // æ¿å°å¾
ææ°æ® å¯¹æ°æ®è¿è¡æ¹é |
| | | const cont = res.Cont // æ¿å°å·²ææ°æ® å¯¹æ°æ®è¿è¡æ¹é |
| | | |
| | | this.formBottom.canArrangeNumber = 0 |
| | | |
| | | // å°äºä¸ªæ¶é´æ®µè¿è¡èµå¼ |
| | | 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 æå |
| | | data[0].children.forEach(item => { |
| | | const obj = { |
| | | id: '', |
| | | name: '', |
| | | AdvaDevicRhythm: '', // èæå¤å°ç§ç产ä¸ä¸ªï¼ç产èæï¼ |
| | | 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: [] |
| | | } |
| | | 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) |
| | | } |
| | | } |
| | | } |
| | | |
| | | for (const i in list) { |
| | | this.pushItem(newList, list[i].id, list[i].gtArray) |
| | | } |
| | | |
| | | // this.schedulingData = list |
| | | |
| | | // å½æç¨æ°ç»ä¸ºç©ºçæ¶å |
| | | // if (this.schedulingData.length === 0) { |
| | | // this.schedulingData.push(list[0]) |
| | | // } else { |
| | | // 夿å½åç¹å»è¡çæ°æ®è¯·æ±æ¥å£æ°æ® æ¯å¦å·²ç»å¨æç¨æ°ç»å
|
| | | const flag = this.schedulingData.map(i => i.id).includes(list[0].id) |
| | | |
| | | if (!flag || this.schedulingData.length === 0) { // å½ä¸å¨æç¨æ°ç»å
æ¶ ç´æ¥pushæç¨æ°ç»å³å¯ |
| | | this.schedulingData.push(list[0]) |
| | | } else { // å½å·²ç»å¨æç¨æ°ç»å
æ¶ åºè¯¥å¤ææ¶é´åå¹¶é |
| | | console.log(list, 9) |
| | | const index = this.schedulingData.findIndex(i => i.id === list[0].id) |
| | | const tempGtArray = [...new Set(this.schedulingData[index].gtArray.concat(list[0].gtArray))] |
| | | // æ°ç»ä¸å¯¹è±¡ç¸åçå»é |
| | | this.schedulingData[index].gtArray = tempGtArray.filter((currentValue, currentIndex, selfArr) => { |
| | | return selfArr.findIndex(item => item.start === currentValue.start) === currentIndex |
| | | }) |
| | | // this.schedulingData[index].gtArray = tempGtArray |
| | | // console.log(tempGtArray, 10) |
| | | // console.log(this.schedulingData[index].gtArray, 11) |
| | | } |
| | | // } |
| | | |
| | | console.log(this.schedulingData, 6) |
| | | // console.log(JSON.stringify(this.schedulingData)) |
| | | |
| | | // this.schedulingData = [ |
| | | // { |
| | | // 'id': 'SB001', |
| | | // 'name': '设å¤001', |
| | | // 'AdvaDevicRhythm': '10.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-03-25 0: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 (cont !== '') { |
| | | for (const i in cont) { |
| | | for (const j in this.schedulingData) { |
| | | if (this.schedulingData[j].id === cont[i].eqp_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) |
| | | } |
| | | } |
| | | } |
| | | } |
| | | |
| | | 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.eqpTopTempData = [] |
| | | for (const i in data[0].children) { |
| | | 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.timeTopTempData = [] |
| | | |
| | | // æå»ºææ¶é´ä¼å
çæç¨æ°æ®æ ¼å¼ 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, |
| | | 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(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) |
| | | } |
| | | } |
| | | }, |
| | | // è¡ç¹å»äºä»¶ |
| | | getCurrentRow(row) { |
| | | console.log(row, 3) |
| | | // 夿æ¯å¦å·²åå¨éä¸ç multipleSelection æ°ç»éé¢ |
| | | // const index = this.multipleSelection.findIndex(i => i.AdvaScheWorkCode === row.AdvaScheWorkCode) |
| | | // this.$refs.tableDataRef.toggleRowSelection(row, index === -1) |
| | | |
| | | this.radioSelectedId = row.AdvaScheId // æç¨idèµå¼ç»éä¸è¡id |
| | | |
| | | // this.formBottom.needArrangeNumber += row.AdvaScheQty * 1 - row.AdvaScheYPQty * 1 // éææ°é = æªæç¨æ°é - å·²æç¨æ°é |
| | | |
| | | // console.log(this.multipleSelection, 'multipleSelection') |
| | | // è·å颿è¿åº¦å¼åæå¤§çè¦æ±äº¤ä»æ¥æ |
| | | this.formBottom.needArrangeNumber = 0 |
| | | let maxPayDate = handleDatetime(new Date()) |
| | | console.log(maxPayDate, 'maxPayDate') |
| | | if (this.multipleSelection.length > 0) { |
| | | console.log('çèå') |
| | | 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 |
| | | } |
| | | }) |
| | | } else { |
| | | console.log('å å¤å®ï¼') |
| | | this.formBottom.needArrangeNumber = 0 |
| | | // maxPayDate = row.AdvaScheEndDate |
| | | this.radioSelectedId = '' |
| | | } |
| | | |
| | | this.formBottom.scheDate = [] // æç¨æ¥æç½®ç©º |
| | | this.cl_name = row.AdvaSchePartName // 产ååç§° |
| | | this.cl_code = row.AdvaSchePartNumber // 产åç¼ç |
| | | this.AdvaScheUom = row.AdvaScheUom // 产ååä½ |
| | | this.work_order = row.AdvaScheWorkCode // å·¥åç¼å· |
| | | |
| | | 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' // æç¨ç»ææ¶é´ |
| | | } |
| | | this.forms.wocode = row.AdvaScheWorkCode // å·¥åç¼å· |
| | | this.forms.wkshpcode = row.AdvaScheWorkShopid // 车é´ç¼ç |
| | | this.forms.partcode = row.AdvaSchePartNumber // 产åç¼ç |
| | | this.forms.botproccode = row.AdvaScheBotProcid // å·¥èºè·¯çº¿ç¼ç |
| | | this.forms.startdate = handleDatetime(new Date()) // å½åæ¥æï¼ä»å¤©ï¼ |
| | | this.forms.enddate = row.AdvaScheEndDate // è¦æ±äº¤ä»æ¶é´ |
| | | |
| | | this.getOnclickAdvancedSchedulingDevice() |
| | | this.formUpdate.WorkCode = row.AdvaScheWorkCode // å·¥åç¼å· |
| | | this.formUpdate.BotProceCode = row.AdvaScheBotProcid // å·¥èºè·¯çº¿ç¼ç |
| | | }, |
| | | |
| | | // æç¨éæäºä»¶ |
| | | resetScheduling() { |
| | | console.log(this.multipleSelection, 16) |
| | | console.log(this.schedulingData, 16) |
| | | |
| | | // this.multipleSelection.forEach(i => { |
| | | // this.getCurrentRow(i) // è¿ééåè¯·æ±æ¶ï¼åæ°æ²¡å |
| | | // }) |
| | | |
| | | // this.getCurrentRow(this.multipleSelection[0]) |
| | | // this.getCurrentRow(this.multipleSelection[1]) |
| | | }, |
| | | // checkbox ç¹å»æ¹åäºä»¶ |
| | | handleSelectionChange(val, isCarry) { |
| | | console.log(val, 2) |
| | | this.multipleSelection = val |
| | | |
| | | // if (isCarry) { |
| | | // // this.multipleSelection.push(val) |
| | | // this.getCurrentRow(val) |
| | | // } else { |
| | | // this.multipleSelection = val |
| | | // } |
| | | |
| | | const index = this.multipleSelection.findIndex(i => i.AdvaScheId === this.rowCheckBoxValue.AdvaScheId) |
| | | if (index !== -1) { // 说æcheckboxæ¯ä» æªéä¸å°éä¸ç¶æ |
| | | this.getCurrentRow(this.rowCheckBoxValue) |
| | | } else { // 说æcheckbox æ¯ä»éä¸å°æªéä¸,æç¨ç产è½åºè¯¥ä»å½åä¸å»é¤å»ï¼è¿è¡éæï¼ |
| | | console.log(this.schedulingData, 88) |
| | | this.resetScheduling() |
| | | // const ind = this.schedulingData.findIndex(i => i.id === this.rowCheckBoxValue.AdvaScheId) |
| | | } |
| | | |
| | | if (val.length === 0) { |
| | | this.schedulingData = [] // æç¨æ°æ®ç½®ç©º |
| | | this.radioSelectedId = '' |
| | | } |
| | | |
| | | console.log('æ§è¡äºï¼') |
| | | }, |
| | | // checkbox ç¹å»äºä»¶ |
| | | handleSelect(selection, row) { |
| | | console.log(selection, row, 1) |
| | | // console.log('æ§è¡äº handleSelect æ§è¡é¡ºåºä¸º1 ') |
| | | // this.multipleSelection = selection |
| | | |
| | | this.rowCheckBoxValue = row |
| | | |
| | | // this.getCurrentRow(row) |
| | | // this.handleSelectionChange(row, true) |
| | | }, |
| | | |
| | | // æäº¤æç¨ |
| | | 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 |
| | | |
| | | for (const i in this.schedulingData) { |
| | | 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 |
| | | 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; |
| | | } |
| | | |
| | | .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>--> |