IPC-610
2024-10-31 9b85a8b67aa6354ee9ea1a13c5799bf1c934922f
Web/src/views/device/deviceInfo/index.vue
@@ -89,34 +89,35 @@
                     <div >
                        <el-form label-position="right" label-width="40px" style="">
                           <el-form-item label="工位">
                              <el-input v-model="stationValue.LocatNo" style="width: 200px; margin-right: 10px;"></el-input>
                              <el-input id="locaText" :disabled="lockInputStatus" v-model="stationValue.locatNo" style="width: 200px; margin-right: 10px;"></el-input>
                              <el-button @click="textLock(stationValue)">{{lockText}}</el-button>
                              <el-button @click="write('zidong',stationValue)">自动</el-button>
                              <el-button @click="write('shoudong',stationValue)">手动</el-button>
                              <el-button @click="write('huifu',stationValue)">报警恢复</el-button>
                              <el-button @mousedown="writeDown('huifu',stationValue)"  @mouseup="writeUp('huifu',stationValue)">报警恢复</el-button>
                           </el-form-item>
                                                      
                           <el-form-item>
                              <el-button size="large" @mousedown="writeDown('1diandong',stationValue)"  @mouseup="writeUp('1diandong',stationValue)">1点动</el-button>
                              <el-button size="large" @mousedown="writeDown('2diandong',stationValue)"  @mouseup="writeUp('2diandong',stationValue)">2点动</el-button>
                              <el-button size="large" @mousedown="writeDown('3diandong',stationValue)"  @mouseup="writeUp('3diandong',stationValue)">3点动</el-button>
                              <el-button size="large" @mousedown="writeDown('4diandong',stationValue)"  @mouseup="writeUp('4diandong',stationValue)">4点动</el-button>
                              <el-button size="large" :disabled="lockStatus" @mousedown="writeDown('1diandong',stationValue)"  @mouseup="writeUp('1diandong',stationValue)">1点动</el-button>
                              <el-button size="large" :disabled="lockStatus" @mousedown="writeDown('2diandong',stationValue)"  @mouseup="writeUp('2diandong',stationValue)">2点动</el-button>
                              <el-button size="large" :disabled="lockStatus" @mousedown="writeDown('3diandong',stationValue)"  @mouseup="writeUp('3diandong',stationValue)">3点动</el-button>
                              <el-button size="large" :disabled="lockStatus" @mousedown="writeDown('4diandong',stationValue)"  @mouseup="writeUp('4diandong',stationValue)">4点动</el-button>
                           </el-form-item>
                           <el-form-item>
                              <el-button size="large" @mousedown="writeDown('1liandong',stationValue)"  @mouseup="writeUp('1liandong',stationValue)">1联动</el-button>
                              <el-button size="large" @mousedown="writeDown('2liandong',stationValue)"  @mouseup="writeUp('2liandong',stationValue)">2联动</el-button>
                              <el-button size="large" @mousedown="writeDown('3liandong',stationValue)"  @mouseup="writeUp('3liandong',stationValue)">3联动</el-button>
                              <el-button size="large" @mousedown="writeDown('4liandong',stationValue)"  @mouseup="writeUp('4liandong',stationValue)">4联动</el-button>
                              <el-button size="large" :disabled="lockStatus" @mousedown="writeDown('1liandong',stationValue)"  @mouseup="writeUp('1liandong',stationValue)">1联动</el-button>
                              <el-button size="large" :disabled="lockStatus" @mousedown="writeDown('2liandong',stationValue)"  @mouseup="writeUp('2liandong',stationValue)">2联动</el-button>
                              <el-button size="large" :disabled="lockStatus" @mousedown="writeDown('3liandong',stationValue)"  @mouseup="writeUp('3liandong',stationValue)">3联动</el-button>
                              <el-button size="large" :disabled="lockStatus" @mousedown="writeDown('4liandong',stationValue)"  @mouseup="writeUp('4liandong',stationValue)">4联动</el-button>
                           </el-form-item>
                           
                           <el-form-item>
                              <el-button size="large" @mousedown="writeDown('yizaisheng',stationValue)"  @mouseup="writeUp('yizaisheng',stationValue)">移栽上升</el-button>
                              <el-button size="large" @mousedown="writeDown('fanzhuansheng',stationValue)"  @mouseup="writeUp('fanzhuansheng',stationValue)">翻转机上升</el-button>
                              <el-button size="large" :disabled="lockStatus" @mousedown="writeDown('yizaisheng',stationValue)"  @mouseup="writeUp('yizaisheng',stationValue)">移栽上升</el-button>
                              <el-button size="large" :disabled="lockStatus" @mousedown="writeDown('fanzhuansheng',stationValue)"  @mouseup="writeUp('fanzhuansheng',stationValue)">翻转机上升</el-button>
                           </el-form-item>
                           <el-form-item>
                              <el-button size="large" @mousedown="writeDown('yizaijiang',stationValue)"  @mouseup="writeUp('yizaijiang',stationValue)">移栽下降</el-button>
                              <el-button size="large" @mousedown="writeDown('fanzhuanjiang',stationValue)"  @mouseup="writeUp('fanzhuanjiang',stationValue)">翻转机下降</el-button>
                              <el-button size="large" :disabled="lockStatus" @mousedown="writeDown('yizaijiang',stationValue)"  @mouseup="writeUp('yizaijiang',stationValue)">移栽下降</el-button>
                              <el-button size="large" :disabled="lockStatus" @mousedown="writeDown('fanzhuanjiang',stationValue)"  @mouseup="writeUp('fanzhuanjiang',stationValue)">翻转机下降</el-button>
                           </el-form-item>
                        </el-form>
@@ -135,52 +136,52 @@
                              </el-col>   
                              <el-col :span="6">
                                 <el-form-item label="任务号" >
                                    <el-input v-model="stationValue.TaskNo" style="width: 200px; "></el-input>
                                    <el-input v-model="stationValue.taskNo" style="width: 200px; "></el-input>
                                 </el-form-item>
                              </el-col>
                              <el-col :span="6">
                                 <el-form-item label="托盘号">
                                    <el-input v-model="stationValue.PalletNo" style="width: 200px; margin-right: 10px;"></el-input>
                                    <el-input v-model="stationValue.palletNo" style="width: 200px; margin-right: 10px;"></el-input>
                                 </el-form-item>
                              </el-col>
                              <el-col :span="6">
                                 <el-form-item label="起始工位">
                                    <el-input v-model="stationValue.StartLoction" style="width: 200px; margin-right: 10px;"></el-input>
                                    <el-input v-model="stationValue.startLoction" style="width: 200px; margin-right: 10px;"></el-input>
                                 </el-form-item>
                              </el-col>
                              <el-col :span="6">
                                 <el-form-item label="目标工位">
                                    <el-input v-model="stationValue.EndLoction" style="width: 200px; margin-right: 10px;"></el-input>
                                    <el-input v-model="stationValue.endLoction" style="width: 200px; margin-right: 10px;"></el-input>
                                 </el-form-item>
                              </el-col>
                              <el-col :span="6">
                                 <el-form-item label="起始排">
                                    <el-input v-model="stationValue.StartPai" style="width: 200px; margin-right: 10px;"></el-input>
                                    <el-input v-model="stationValue.startPai" style="width: 200px; margin-right: 10px;"></el-input>
                                 </el-form-item>
                              </el-col>
                              <el-col :span="6">
                                 <el-form-item label="起始列">
                                    <el-input v-model="stationValue.StartLie" style="width: 200px; margin-right: 10px;"></el-input>
                                    <el-input v-model="stationValue.startLie" style="width: 200px; margin-right: 10px;"></el-input>
                                 </el-form-item>
                              </el-col>
                              <el-col :span="6">
                                 <el-form-item label="起始层">
                                    <el-input v-model="stationValue.StartCeng" style="width: 200px; margin-right: 10px;"></el-input>
                                    <el-input v-model="stationValue.startCeng" style="width: 200px; margin-right: 10px;"></el-input>
                                 </el-form-item>
                              </el-col>
                              <el-col :span="6">
                                 <el-form-item label="目标排">
                                    <el-input v-model="stationValue.EndPai" style="width: 200px; margin-right: 10px;"></el-input>
                                    <el-input v-model="stationValue.endPai" style="width: 200px; margin-right: 10px;"></el-input>
                                 </el-form-item>
                              </el-col>
                              <el-col :span="6">
                                 <el-form-item label="目标列">
                                    <el-input v-model="stationValue.EndLie" style="width: 200px; margin-right: 10px;"></el-input>
                                    <el-input v-model="stationValue.endLie" style="width: 200px; margin-right: 10px;"></el-input>
                                 </el-form-item>
                              </el-col>
                              <el-col :span="6">
                                 <el-form-item label="目标层">
                                    <el-input v-model="stationValue.EndCeng" style="width: 200px; margin-right: 10px;"></el-input>
                                    <el-input v-model="stationValue.endCeng" style="width: 200px; margin-right: 10px;"></el-input>
                                 </el-form-item>
                              </el-col>
                              
@@ -198,30 +199,39 @@
<script lang="ts" setup>
import { ref, reactive, onMounted } from 'vue';
import { listStatus, listPosition } from '/@/api/wcs/wcsPlc';
import { WriteInfo,WriteTaskInfo } from '/@/api/wcs/wcsDevice';
import { GetLocationInfo,WriteLocationInfo,WriteInfo,WriteTaskInfo } from '/@/api/wcs/wcsDevice';
import { signalR } from './signalR';
import { cellsDataLine, cellsDataOne, cellsDataTwo, cellsDataThree } from './data';
import { ElMessage } from "element-plus";
// export default{
// }
const state = ref<any>({});
const stackers = ref<any>({});
const conveyors = ref<any>({});
const stationValue = ref<any>({
   LocatNo: '',//工位
   Layer:'',//楼层
   TypeName:'',//操作类型名称
   FuncName:'',//事件结果  true/false
   TaskNo:'',
   PalletNo:'',
   StartLoction:'',
   EndLoction:'',
   StartPai:'',
   StartLie:'',
   StartCeng:'',
   EndPai:'',
   EndLie:'',
   EndCeng:'',
const lockText = ref("锁定");
const lockStatus = ref(true);
const lockInputStatus = ref(false);
const stationValue = ref<any>({
   locatNo: '',//工位
   layer:'',//楼层
   typeName:'',//操作类型名称
   funcName:'',//事件结果  true/false
   taskNo:'',
   palletNo:'',
   startLoction:'',
   endLoction:'',
   startPai:'',
   startLie:'',
   startCeng:'',
   endPai:'',
   endLie:'',
   endCeng:'',
});
@@ -376,16 +386,71 @@
   }
}
const write = async (type: string,row: any) => {
const textLock = async (row: any) => {
   if(lockText.value == "锁定"){
      lockStatus.value=false;
      lockInputStatus.value=true;
      lockText.value ="解锁";
   if (floorStates.value.isPlain1 == false) {
      row.Layer = 1;
         row.layer = 1;
   }else if(floorStates.value.isPlain2 == false){
      row.Layer = 2;
         row.layer = 2;
   }
   else if(floorStates.value.isPlain3 == false){
      row.Layer = 3;
         row.layer = 3;
   }
   row.TypeName = type;
      row.typeName = "suoding";
      console.log(row);
      var res = await WriteLocationInfo(row);
      var res2 = await GetLocationInfo(row);
      let rowData = JSON.parse(JSON.stringify(res2.data.result));
      stationValue.value = res2.data.result;
//       stationValue.value = {
//    locatNo: '',//工位
//    layer:'',//楼层
//    typeName:'',//操作类型名称
//    funcName:null,//事件结果  true/false
//    taskNo:'',
//    palletNo:'',
//    startLoction:'',
//    endLoction:'',
//    startPai:'',
//    startLie:'',
//    startCeng:'',
//    endPai:'',
//    endLie:'',
//    endCeng:'',
// }
      console.log(res2.data.result);
      console.log(rowData);
   }else{
      lockStatus.value=true;
      lockInputStatus.value=false;
      lockText.value ="锁定";
   }
}
const write = async (type: string,row: any) => {
   if (lockStatus.value == false) {
      ElMessage.success("请先锁定");
      return;
   }
   if (floorStates.value.isPlain1 == false) {
      row.layer = 1;
   }else if(floorStates.value.isPlain2 == false){
      row.layer = 2;
   }
   else if(floorStates.value.isPlain3 == false){
      row.layer = 3;
   }
   row.typeName = type;
   
   console.log(row);
   var res = await WriteInfo(row);
@@ -394,32 +459,40 @@
}
const writeDown = async (type: string,row: any) => {
   if (lockStatus.value == false) {
      ElMessage.success("请先锁定");
      return;
   }
   if (floorStates.value.isPlain1 == false) {
      row.Layer = 1;
      row.layer = 1;
   }else if(floorStates.value.isPlain2 == false){
      row.Layer = 2;
      row.layer = 2;
   }
   else if(floorStates.value.isPlain3 == false){
      row.Layer = 3;
      row.layer = 3;
   }
   row.TypeName = type;
   row.FuncName = "true";
   row.typeName = type;
   row.funcName = "true";
   var res = await WriteInfo(row);
   console.log(type+"按下事件");
   
   // ElMessage.success(res.data.result);
}
const writeUp = async (type: string,row: any) => {
   if (lockStatus.value == false) {
      ElMessage.success("请先锁定");
      return;
   }
   if (floorStates.value.isPlain1 == false) {
      row.Layer = 1;
      row.layer = 1;
   }else if(floorStates.value.isPlain2 == false){
      row.Layer = 2;
      row.layer = 2;
   }
   else if(floorStates.value.isPlain3 == false){
      row.Layer = 3;
      row.layer = 3;
   }
   row.TypeName = type;
   row.FuncName = "false";
   row.typeName = type;
   row.funcName = "false";
   var res = await WriteInfo(row);
   console.log(type+"抬起事件");
   
@@ -428,14 +501,14 @@
const writeTaskInfo = async (type: string,row: any) => {
   if (floorStates.value.isPlain1 == false) {
      row.Layer = 1;
      row.layer = 1;
   }else if(floorStates.value.isPlain2 == false){
      row.Layer = 2;
      row.layer = 2;
   }
   else if(floorStates.value.isPlain3 == false){
      row.Layer = 3;
      row.layer = 3;
   }
   row.TypeName = type;
   row.typeName = type;
   var res = await WriteTaskInfo(row);
   console.log(type+"抬起事件");