From 7aca2b562095a836bd9e2e29b938c5b43aff6db1 Mon Sep 17 00:00:00 2001 From: admin <15939171744@163.com> Date: 星期一, 06 五月 2024 16:04:06 +0800 Subject: [PATCH] - --- jcdm-ui/src/views/main/kb/stationTerminal/index.vue | 252 ++++++++++++++++++++++++++++---------------------- 1 files changed, 141 insertions(+), 111 deletions(-) diff --git a/jcdm-ui/src/views/main/kb/stationTerminal/index.vue b/jcdm-ui/src/views/main/kb/stationTerminal/index.vue index 0f16945..1f17669 100644 --- a/jcdm-ui/src/views/main/kb/stationTerminal/index.vue +++ b/jcdm-ui/src/views/main/kb/stationTerminal/index.vue @@ -95,8 +95,14 @@ <!-- </el-col>--> <!-- </el-row>--> - <el-row style="margin-top: 20px"> - <el-button @click="Release" type="primary">鏀捐</el-button> + <el-row v-show="showInput" style="margin-top: 20px"> + <el-col></el-col> + <span style="width: 130px;" class="head-font">棰勮鎬绘垚鍙� : {{headContent.yzSfcCode}}</span> + </el-row> + <el-row v-show="showInput" style="margin-top: 20px"> +<!-- <el-button @click="Release" type="primary">缁戝畾</el-button>--> + <el-button @click="bindYzSfc" type="primary">缁戝畾</el-button> + </el-row> </el-card> @@ -106,16 +112,18 @@ <el-tab-pane name="first"> <span slot="label"> <a class="el-icon-date"></a>棣栭〉</span> <el-col :span="24"> - <el-table :cell-style="rowStyle" :data="formulaChildList"> - <el-table-column label="鎺掑簭" width="60" align="center" prop="stepSort"> + <el-table height="500" :cell-style="rowStyle" :data="formulaChildList"> + <el-table-column label="鎺掑簭" width="60" align="center" type="index"> </el-table-column> <el-table-column label="鎿嶄綔鍐呭" :show-overflow-tooltip='true' align="center" prop="operationSteps"> </el-table-column> - <el-table-column label="浜у搧缂栧彿" width="150" align="center" prop="productCode"> + <el-table-column label="浜у搧缂栧彿" align="center" prop="productCode"> </el-table-column> - <el-table-column label="閲囬泦鍊�" width="150" align="center" prop="productCode"> + <el-table-column label="鐗╂枡缂栫爜" align="center" prop="materialCode"> </el-table-column> - <el-table-column label="缁撴灉" width="150" align="center" prop="results"> + <el-table-column label="閲囬泦鍊�" align="center" prop="collectData"> + </el-table-column> + <el-table-column label="缁撴灉" align="center" prop="results"> </el-table-column> </el-table> </el-col> @@ -292,7 +300,14 @@ <script> import {listWorkReport} from "@/api/main/om/workReport/workReport"; import {listStationConf,getIpv4} from "@/api/main/sc/stationConf"; -import {listFormulaChild, releaseCheck, updateResults, workpieceRelease} from "@/api/main/bs/formulaChild/formulaChild"; +import { + listFormulaChild, + noPageListFormulaChild, + releaseCheck, + updateResults, + updateTighteningFormula, + workpieceRelease +} from "@/api/main/bs/formulaChild/formulaChild"; import MySerialPort from "@/utils/MySerialPort"; import USBDevice from "@/utils/usb.json"; import {listProductionOrde} from "@/api/main/om/productionOrde/productionOrde"; @@ -300,13 +315,16 @@ import { addBasicParameters, addParamCollection, - addTighteningParameters + addTighteningParameters, + saveCampaignTimeParameters, + replaceAssemblyCode, } from "@/api/main/da/paramCollection/paramCollection"; export default { name: "stationTerminal", data() { return { + showInput: true, serialPortContent: '', // 鏌ヨ鍙傛暟 formulaChildParams: { @@ -323,6 +341,7 @@ processesCode: 'OP1010', processesName: '璐存爣鏈�-璐寸爜', sfcCode: '', + yzSfcCode: '', }, workpieceInformation: { workOrderNo: null, @@ -353,7 +372,7 @@ }, content: '', activeName: 'first', - url: "ws://192.168.11.76:8080/websocket/message/", + url: "ws://192.168.2.76:8080/websocket/message/", message: "", text_content: "", ws: null, @@ -363,7 +382,7 @@ input: "", keepReading: true, form1: { - baudRate: "9600", + baudRate: "115200", dataBits: "8", stopBits: "1", parity: "none", @@ -421,6 +440,19 @@ serialLink() { this.open1 = true }, + bindYzSfc(){ + if(this.headContent.sfcCode!==""&&this.headContent.yzSfcCode!==""){ + let param = { + sfcCode: this.headContent.sfcCode, + locationCode: this.headContent.processesCode, + yzSfcCode: this.headContent.yzSfcCode + } + this.$message('鍙互缁戝畾锛�'); + replaceAssemblyCode(param).then(response => { + + }); + } + }, Release(){ // this.$message('portsList锛�'+this.portsList.length); if(this.btnType === "danger"){ @@ -451,30 +483,32 @@ // }); }, serialPortMethod(value){ - console.log(value.includes('C')); - let formulaChilds = ''; - console.log(this.formulaChildList) - this.formulaChildList.forEach((formulaChild) => { - formulaChilds = formulaChild; - let operationType = formulaChild.operationType; - let results = formulaChild.results; - let materialCode = formulaChild.materialCode; - if(operationType === '2' && value.includes(materialCode) && (results === '' || results === null || results === 'NG')){ - return; // 浣跨敤return浠f浛break - } - }); - console.log(formulaChilds) - // let formulaChildParams = { - // scanBarcode: value, - // sfcBarcode: this.headContent.sfcCode, - // workOrderNo: this.workpieceInformation.workOrderNo, - // productCode: this.workpieceInformation.productCode, - // locationCode: this.headContent.processesCode, - // collectionTime: new Date() - // } - // updateResults(formulaChildParams).then(response => { - // this.getListFormulaChild() + // let formulaChilds = ""; + // this.formulaChildList.forEach((formulaChild) => { + // let operationType = formulaChild.operationType; + // let results = formulaChild.results; + // let materialCode = formulaChild.materialCode; + // if(operationType === '2' && value.includes(materialCode) && (results === "" || results === null || results === 'NG')){ + // formulaChilds = formulaChild; + // return; // 浣跨敤return浠f浛break + // } // }); + // console.log(formulaChilds) + let formulaChildParams = { + scanBarcode: value, + sfcBarcode: this.headContent.sfcCode, + workOrderNo: this.workpieceInformation.workOrderNo, + productCode: this.workpieceInformation.productCode, + locationCode: this.headContent.processesCode, + collectionTime: new Date() + } + updateResults(formulaChildParams).then(response => { + console.log(response) + if(response.msg === "3"){ + this.cakeLamp.release= 1 //鍏佽鏀捐 + } + this.getListFormulaChild() + }); }, rowStyle({ row }) { if (row.results === 'OK') { @@ -486,14 +520,27 @@ }, /** 鏌ヨ閰嶆柟閰嶇疆瀛愪俊鎭垪琛� */ getListFormulaChild() { + // this.formulaChildList = [] this.formulaChildParams.productCode = this.workpieceInformation.productCode this.formulaChildParams.processesCode = this.headContent.processesCode - listFormulaChild(this.formulaChildParams).then(response => { + console.log(this.formulaChildParams) + noPageListFormulaChild(this.formulaChildParams).then(response => { this.formulaChildList = response.rows; - console.log(this.formulaChildList) }); }, + endClear(){ + this.cakeLamp.InPlace= 0 //宸ヤ欢鍒颁綅 + this.cakeLamp.scanFinish= 0 + this.cakeLamp.startWork= 0 + this.cakeLamp.release= 0 //鍏佽鏀捐 + this.formulaChildList = [] + this.workpieceInformation.productCode = null; + this.workpieceInformation.workOrderNo = null; + this.workpieceInformation.productModel = null; + this.workpieceInformation.productName = null; + this.headContent.sfcCode = ''; + }, changeMenu(tab, event) { console.log(tab, event); }, @@ -537,52 +584,12 @@ locationCode: this.headContent.processesCode, model: this.workpieceInformation.productModel, productBarcode: this.headContent.sfcCode, + sfcCode: this.headContent.sfcCode, inboundTime: new Date() } addPassingStationCollection(this.passingStationForm).then(response => {}); addBasicParameters(this.passingStationForm).then(response => {}); }, - allowRelease(){ - clearInterval(this.timer); - this.$message('淇濆瓨鑺傛媿涓�'+this.workpieceInformation.beat+'绉�'); - }, - /** 鏌ヨ宸ヤ綅缁堢閰嶇疆鍒楄〃 */ - // async getStationConfList() { - // await getIpv4().then(response => { - // this.StationConfQueryParams.ipAddress = response.msg - // console.log('鏌ヨ鍒版湰宸ヤ綅IP涓�'+this.StationConfQueryParams.ipAddress) - // }); - // listStationConf(this.StationConfQueryParams).then(response => { - // let rows = response.rows[0] - // if(response.rows.length===0){ - // this.$message('璇ュ伐浣嶆病鏈夐厤缃甀P锛岃鑱旂郴绠$悊鍛橀厤缃甀P'); - // return - // } - // this.headContent.processesName = rows.processesName - // this.headContent.processesCode = rows.processesCode - // console.log('璁剧疆宸ヤ綅缂栫爜'+this.headContent.processesCode) - // - // }); - // }, - // connectWebsocket() { - // console.log('websocket杩炴帴宸ヤ綅涓�'+this.headContent.processesCode) - // const wsuri = this.url + this.headContent.processesCode; - // this.ws = new WebSocket(wsuri); - // const self = this; - // this.ws.onopen = function (event) { - // // self.text_content = self.text_content + "宸茬粡鎵撳紑杩炴帴!" + "\n"; - // this.$message('websocket杩炴帴鎴愬姛锛�'); - // }; - // this.ws.onmessage = function (event) { - // self.text_content = event.data + "\n"; - // console.log(event.data) - // if(event.data === "IN"){ - // self.cakeLamp.InPlace = "1" - // }else if(event.data === "OUT"){ - // self.cakeLamp.outRsSign = "1" - // } - // }; - // }, exit() { if (this.ws) { this.ws.close(); @@ -596,6 +603,7 @@ alert("鏈繛鎺ュ埌鏈嶅姟鍣�"); } }, + initStation: async function () { await getIpv4().then(response => { this.StationConfQueryParams.ipAddress = response.msg @@ -612,6 +620,7 @@ console.log('璁剧疆宸ヤ綅缂栫爜' + this.headContent.processesCode) }); + this.conCom() console.log('websocket杩炴帴宸ヤ綅涓�' + this.headContent.processesCode) const wsuri = this.url + this.headContent.processesCode; this.ws = new WebSocket(wsuri); @@ -620,45 +629,36 @@ this.$message('websocket杩炴帴鎴愬姛锛�'); }; this.ws.onmessage = function (event) { - const DELAY_TIME = 2000; if (event.data === "IN") { self.cakeLamp.InPlace = 1; } else if (event.data === "IN0") { self.cakeLamp.InPlace = 0; } else if (event.data === "OUT") { self.cakeLamp.release = 1; - setTimeout(() => { - self.cakeLamp.InPlace = 0; - self.cakeLamp.release = 0; - self.cakeLamp.startWork = 0; - self.cakeLamp.scanFinish = 0; - self.Release(); - }, DELAY_TIME); - } else if (event.data === "TIGHTEN") { - this.formulaChildList = []; - self.getListFormulaChild(); + } else if (event.data === "END") { + const param = { + workOrderNo: self.workpieceInformation.workOrderNo, + productCode: self.workpieceInformation.productCode, + locationCode: self.headContent.processesCode, + productBarcode: self.headContent.sfcCode, + } + saveCampaignTimeParameters(param).then(response => {}); + self.cakeLamp.release = 1; + self.endClear() + workpieceRelease(param).then(response => {}); } else if (event.data.includes("[")) { let formulaChilds = ""; - // for(let i=0;i<self.formulaChildList.length;i++){ - // formulaChilds = self.formulaChildList[i]; - // let operationType = formulaChild.operationType; - // let results = formulaChild.results; - // if(operationType === '1' && - // (results === '' || results === null ||results === 'NG')){ - // break; - // } - // } - self.formulaChildList.forEach((formulaChild) => { - formulaChilds = formulaChild; - let operationType = formulaChild.operationType; + self.formulaChildList.sort((a, b) => a.stepSort - b.stepSort); + self.formulaChildList + .filter((formulaChild) => formulaChild.operationType === '1'); + for (let i = 0; i < self.formulaChildList.length; i++) { + let formulaChild = self.formulaChildList[i]; let results = formulaChild.results; - if(operationType === '1' && (results === '' || results === null || results === 'NG')){ - return; // 浣跨敤return浠f浛break + if (results === '' || results === null || results === 'NG') { + formulaChilds = formulaChild; + break; } - // 鎵ц鍏朵粬鎿嶄綔 - }); - console.log(formulaChilds) - console.log(formulaChilds.paramCode) + } const param = { tightenTheArray: event.data, paramCode: formulaChilds.paramCode, @@ -668,28 +668,41 @@ productBarcode: self.headContent.sfcCode, } addTighteningParameters(param).then(response => {}); + updateTighteningFormula(param).then(response => { + self.getListFormulaChild() + }).catch(error =>{ + self.getListFormulaChild() + }); } }; }, + + //鎺ュ彈鏁版嵁鐨勫洖璋� callBack(value) { if (this.form1.isShowHistory) this.form1.desc = this.readLi().join(""); else { const scanValue = this.myserialport.hex2atostr(value).replace(/[\r\n]/g, ''); - this.$message('鎵爜瀹屾垚'+this.content); + console.log("涓插彛鏀跺埌鏁版嵁-------------------"+scanValue) if(this.headContent.sfcCode !== ''){ - console.log(scanValue) - this.serialPortMethod(scanValue) - }else { + if(scanValue.includes("SS")){ + this.headContent.yzSfcCode = scanValue + }else { + this.$message('鎵弿鐗╂枡缂栫爜'+scanValue); + console.log(scanValue) + this.serialPortMethod(scanValue) + } + } else { + this.$message('鎵爜璇嗗埆浜у搧搴忓垪鍙�'+scanValue); this.headContent.sfcCode = scanValue; this.queryParams.productNum = scanValue; this.getList() - // this.getListFormulaChild() this.cakeLamp.scanFinish = 1 this.cakeLamp.startWork = 1 } + } }, clearHistory() { @@ -738,6 +751,22 @@ return body; }); }, + conCom(){ + try { + this.myserialport.state.baudRate = this.form1.baudRate; + this.myserialport.state.dataBits = this.form1.dataBits; + this.myserialport.state.stopBits = this.form1.stopBits; + this.myserialport.state.parity = this.form1.parity; + this.myserialport.state.flowControl = this.form1.flowControl; + this.myserialport.openPort(0, true, this.callBack); + console.log(this.form1.port) + } catch (error) { + this.$message.error("涓插彛杩炴帴澶辫触锛佽妫�鏌ヤ覆鍙f槸鍚﹀凡琚崰鐢�"); + } + if (this.myserialport.state.isOpen) { + this.$message.success("涓插彛杩炴帴鎴愬姛"); + } + }, //杩炴帴 async connectBtn() { if (this.btnType === "primary") { @@ -748,6 +777,7 @@ this.myserialport.state.parity = this.form1.parity; this.myserialport.state.flowControl = this.form1.flowControl; await this.myserialport.openPort(this.form1.port, true, this.callBack); + console.log(this.form1.port) } catch (error) { this.$message.error("涓插彛杩炴帴澶辫触锛佽妫�鏌ヤ覆鍙f槸鍚﹀凡琚崰鐢�"); } -- Gitblit v1.9.3