From 84001b5d34d3344f2fa40126877c4903dd10f1f3 Mon Sep 17 00:00:00 2001
From: guoshilong <123456>
Date: Mon, 20 Mar 2023 17:10:04 +0800
Subject: [PATCH] socketio连接调整,显示页添加表单校验;控制页添加表单校验,显示设备改为下拉框

---
 src/views/funcController.vue |  100 ++++++++++++++++++++++++++++++++-----------------
 1 files changed, 65 insertions(+), 35 deletions(-)

diff --git a/src/views/funcController.vue b/src/views/funcController.vue
index 540f690..e3b483b 100644
--- a/src/views/funcController.vue
+++ b/src/views/funcController.vue
@@ -1,6 +1,6 @@
 <template>
   <div>
-    <avue-form ref="form" v-model="form" :option="option" @submit="getMenuList"></avue-form>
+    <avue-form ref="form" v-model="form" :option="option" @submit="connect"></avue-form>
     <div class="menu-btn-group">
       <el-button size="small" v-for="data in menuList" :index="data.id" :key="data.id" @click="menuChange(data)">
         {{ data.name }}
@@ -18,26 +18,64 @@
 <script>
 import {getAll} from "@/api/modules/function";
 import io from "socket.io-client";
+import {getAllEq} from "@/api/equipment/equipment";
 
 export default {
   name: "funcController",
   data() {
+    //设备编码校验
+    var equipmentList = []
+    getAllEq().then(res=>{
+      equipmentList = res.data.data
+    })
+    let validateEquipment = (rule, value, callback) => {
+      if (value) {
+        let filterArray = equipmentList.filter(e=>{
+          return e.code == value && e.type == 1
+        })
+        if (filterArray.length>0){
+          callback()
+        }else {
+          callback(new Error("请输入正确的控制器设备码"))
+        }
+      } else {
+        callback(new Error('请输入设备码'));
+      }
+    };
     return {
       form:{},
       option:{
         emptyBtn:false,
         submitText: "连接",
-        menuSpan: 6,
+        menuSpan: 1,
         column:[
           {
-            label:"当前设备",
-            prop:"currentDevice",
+            label:"控制器设备编码",
+            labelWidth:150,
+            prop:"controllerEquipmentCode",
             span:6,
+            rules: [{
+              required: true,
+              trigger: "blur",
+              validator:validateEquipment,
+            }],
           },
           {
-            label:"控制模块",
-            prop:"modulesId",
+            label:"显示器设备编码",
+            labelWidth:150,
+            prop:"viewEquipmentCode",
             span:6,
+            type: "select",
+            dicUrl: `/api/equipment/equipment/all?type=2`,
+            props: {
+              label: "code",
+              value: "code"
+            },
+            rules: [{
+              required: true,
+              message: "请选择显示器",
+              trigger: "blur",
+            }],
           },
         ]
       },
@@ -48,65 +86,57 @@
   mounted() {
   },
   created() {
-    this.connect()
   },
   methods: {
-    getMenuList(form,done){
-      this.sendMsg("putInClientMap",null)
-      done()
-    },
     menuChange(data){
       this.currentClick = data
       this.sendMsg("menuChange",data.id)
     },
     sendMsg(msgName,data) {
       let msg = {
-        current:this.form.currentDevice,
-        target:this.form.modulesId,
+        current:this.form.controllerEquipmentCode,
+        target:this.form.viewEquipmentCode,
         msg :data
       }
       this.socketIoClient.emit(msgName,JSON.stringify(msg))
     },
-    connect(){
-
-      // if (this.socketIoClient != null){
+    //连接
+    connect(form,done){
+      // if (this.socketIoClient !=null ){
       //   this.socketIoClient.disconnect()
-      //   this.socketIoClient = null
       // }
-
       let serveUri = 'http://192.168.0.200:10246'
-      // let params={
-      //   modulesId:form.modulesId,
-      //   controllerId : form.currentDevice,
-      //   isView:false
-      // }
-
+      let params = {
+        current :form.controllerEquipmentCode
+      }
       this.socketIoClient = io.connect(serveUri, {
-        // 'force new connection': true,
-        // 'query': 'connectInfo=' + JSON.stringify(params)
+        'force new connection': true,
+        'query': 'connectInfo=' + JSON.stringify(params)
       });
-
       //监听与服务器的连接状态
       this.socketIoClient.on("connect",()=>{
-        // done()
+        done()
       })
-
       //监听服务器发回的消息
       //连接成功
       this.socketIoClient.on("connectOk", (res) => {
-        this.menuList = res.data
-        this.$notify.success({
-          title: '连接成功',
-        });
+        if (res.code == 200){
+          let params = {
+            equipmentCode :form.viewEquipmentCode
+          }
+          getAll(params).then(res=>{
+            if (res.data.code == 200){
+              this.menuList = res.data.data
+            }
+          })
+        }
       });
-
       //连接失败
       this.socketIoClient.on("connectError", (res) => {
         this.$notify.error({
           title: res.msg,
         });
       });
-
     },
   }
 }

--
Gitblit v1.9.3