From 93a26507f76156fa65aead1515c430688c089e1d Mon Sep 17 00:00:00 2001
From: hanbaoshan <hanbaoshan@aiotlink.com>
Date: 星期一, 22 二月 2021 15:49:01 +0800
Subject: [PATCH] 新版目录树样式调试及状态更新调试;朔黄批量导入列表调试;视频检索页面添加处理参数,添加标注接口添加参数;分页器展示优化,默认检索时间调整;转储设备接口调试

---
 vue.config.js                                                          |    2 
 src/pages/cameraAccess/index/App.vue                                   |    2 
 src/components/giantTree/zTree/ztree_v3/jquery.ztree.all.js            |    2 
 src/components/giantTree/zTree/ztree.vue                               |    4 
 src/pages/shuohuangMonitorAnalyze/components/searchForVideoAnalyze.vue |   43 ++++++++--
 src/pages/cameraAccess/components/CameraInfo.vue                       |   12 ++
 src/pages/shuohuangMonitorAnalyze/components/transferDeviceManage.vue  |  136 +++++++++++++++++++++++++--------
 src/pages/shuohuangMonitorAnalyze/components/memberManage.vue          |   10 +-
 src/pages/shuohuangMonitorAnalyze/components/videoAnalyze.vue          |    1 
 src/api/shuohuang.ts                                                   |    5 +
 src/components/giantTree/index.vue                                     |   23 +++++
 11 files changed, 189 insertions(+), 51 deletions(-)

diff --git a/src/api/shuohuang.ts b/src/api/shuohuang.ts
index ac54af1..7b111d0 100644
--- a/src/api/shuohuang.ts
+++ b/src/api/shuohuang.ts
@@ -144,4 +144,9 @@
 export const getDeviceList = ()=>request({
   url:'/data/api-c/device/getlst',
   method: 'get'
+})
+export const getDeviceInfoById = (query:any) => request({
+  url:'/data/api-c/slot/getlst',
+  method: 'get',
+  params: query
 })
\ No newline at end of file
diff --git a/src/components/giantTree/index.vue b/src/components/giantTree/index.vue
index 09e5bdc..52a101a 100644
--- a/src/components/giantTree/index.vue
+++ b/src/components/giantTree/index.vue
@@ -82,7 +82,9 @@
           { required: true, message: "璇疯緭鍏ヨ妭鐐瑰悕绉�", trigger: "change" },
           { min: 2, max: 10, message: "闀垮害鍦�2鍒�10涓瓧", trigger: "change" }
         ]
-      }
+      },
+      evt: {},
+      treeId: '',
     };
   },
   created() {
@@ -241,6 +243,12 @@
       this.showDialog = true;
     },
     itemClick(evt, treeId, treeNode) {
+      debugger
+      //let itemClickArgs = {evt,treeId};
+      this.evt = evt;
+      this.treeId = treeId;
+      console.log(evt,treeId)
+      // sessionStorage.setItem('itemClickArgs',JSON.stringify(itemClickArgs))
       this.TreeDataPool.selectedNode = treeNode;
       this.TreeDataPool.treeType = this.treeName;
 
@@ -253,6 +261,19 @@
 
       this.TreeDataPool.updateZTreeCheckNodes([treeNode]);
     },
+    // itemClick(treeNode) {
+    //   this.TreeDataPool.selectedNode = treeNode;
+    //   this.TreeDataPool.treeType = this.treeName;
+
+    //   // 澶氶��
+    //   if (this.TreeDataPool.multiple) {
+    //     // 鍗曞嚮鏌愪竴涓妭鐐规枃瀛楁椂 鍙栨秷鎵�鏈夊嬀閫夌姸鎬� 鐒跺悗閫変腑鑷韩
+    //     this.ztreeObj.checkAllNodes(false);
+    //     this.ztreeObj.checkNode(treeNode, true, false, false);
+    //   }
+
+    //   this.TreeDataPool.updateZTreeCheckNodes([treeNode]);
+    // },
     itemCheck(evt, treeId, treeNode) {
       this.TreeDataPool.selectedNode = treeNode;
       this.TreeDataPool.treeType = this.treeName;
diff --git a/src/components/giantTree/zTree/ztree.vue b/src/components/giantTree/zTree/ztree.vue
index fc3ba3a..f6f79e0 100644
--- a/src/components/giantTree/zTree/ztree.vue
+++ b/src/components/giantTree/zTree/ztree.vue
@@ -38,6 +38,7 @@
       list: [],
       ztreeSetting: {
         view: {
+          showLine: true,
           showIcon: true, // default to hide icon
           addHoverDom: this.addHoverDom,
           removeHoverDom: this.removeHoverDom
@@ -265,7 +266,7 @@
 .ztree * {
   padding: 0;
   margin: 0;
-  font-size: 13px;
+  font-size: 14px;
   font-family: Verdana, Arial, Helvetica, AppleGothic, sans-serif;
 }
 .ztree {
@@ -381,6 +382,7 @@
   background-attachment: scroll;
   /* background-image: url("./img/zTreeStandard.png"); */
   /* *background-image: url("./img/zTreeStandard.gif"); */
+  
   background-image: url();
   *background-image: url();
 }
diff --git a/src/components/giantTree/zTree/ztree_v3/jquery.ztree.all.js b/src/components/giantTree/zTree/ztree_v3/jquery.ztree.all.js
index b191ff7..3b74a68 100644
--- a/src/components/giantTree/zTree/ztree_v3/jquery.ztree.all.js
+++ b/src/components/giantTree/zTree/ztree_v3/jquery.ztree.all.js
@@ -841,6 +841,7 @@
         return true;
       },
       onClickNode: function (event, node) {
+        debugger
         var setting = data.getSetting(event.data.treeId),
           clickFlag = ((setting.view.autoCancelSelected && (event.ctrlKey || event.metaKey)) && data.isSelectedNode(setting, node)) ? 0 : (setting.view.autoCancelSelected && (event.ctrlKey || event.metaKey) && setting.view.selectedMulti) ? 2 : 1;
         if (tools.apply(setting.callback.beforeClick, [setting.treeId, node, clickFlag], true) == false) return true;
@@ -1674,6 +1675,7 @@
         }
       },
       selectNode: function (setting, node, addFlag) {
+        debugger
         if (!addFlag) {
           view.cancelPreSelectedNode(setting, null, node);
         }
diff --git a/src/pages/cameraAccess/components/CameraInfo.vue b/src/pages/cameraAccess/components/CameraInfo.vue
index 58eee53..72cec9a 100644
--- a/src/pages/cameraAccess/components/CameraInfo.vue
+++ b/src/pages/cameraAccess/components/CameraInfo.vue
@@ -382,10 +382,11 @@
           this.form.sensors = list
           this.form.resolution_width = Number(this.form.resolution.split("*")[0])
           this.form.resolution_height = Number(this.form.resolution.split("*")[1])
-
+          let _this = this;
           // 鏇存柊
           if (this.form.id !== "") {
             this.form.areaid = this.TreeDataPool.getParent(this.form.id, this.isGb28182);
+            console.log(this.TreeDataPool.selectedNode)
             updateCameraInfo(this.form).then(rsp => {
               if (rsp.success) {
                 this.$notify({
@@ -393,6 +394,15 @@
                   message: "鎽勫儚鏈轰俊鎭慨鏀规垚鍔燂紒"
                 });
                 this.TreeDataPool.fetchTreeData();
+                console.log(this.TreeDataPool.selectedNode)
+                //_this.$root.$children[0].$refs['leftTree'].$refs.tree.ztreeObj.checkNode(_this.TreeDataPool.selectedNode, true, false, false);
+                //閫変腑淇敼鍚庣殑鑺傜偣
+                let {evt,treeId} = _this.$root.$children[0].$refs['leftTree'].$refs.tree;
+                console.log(evt,treeId)
+                // this.$nextTick(()=>{
+                   _this.$root.$children[0].$refs['leftTree'].$refs.tree.itemClick(evt,treeId,_this.TreeDataPool.selectedNode)
+                // })
+
               } else {
                 this.selectCamera(this.TreeDataPool.selectedNode);
                 this.$notify({
diff --git a/src/pages/cameraAccess/index/App.vue b/src/pages/cameraAccess/index/App.vue
index e843f32..d18f4ca 100644
--- a/src/pages/cameraAccess/index/App.vue
+++ b/src/pages/cameraAccess/index/App.vue
@@ -4,7 +4,7 @@
       <div class="resize-bar"></div>
       <div class="resize-line"></div>
       <div class="resize-save">
-        <left-nav :appName="app" :height="screenHeight"></left-nav>
+        <left-nav :appName="app" :height="screenHeight" ref="leftTree"></left-nav>
       </div>
     </div>
     <div class="column-right">
diff --git a/src/pages/shuohuangMonitorAnalyze/components/memberManage.vue b/src/pages/shuohuangMonitorAnalyze/components/memberManage.vue
index 2111a3e..bfe6e92 100644
--- a/src/pages/shuohuangMonitorAnalyze/components/memberManage.vue
+++ b/src/pages/shuohuangMonitorAnalyze/components/memberManage.vue
@@ -221,9 +221,9 @@
         </div>
         <el-table class="thbg" :data="batchImportTableData" fit>
           <el-table-column type="index" label="搴忓彿"></el-table-column>
-          <el-table-column prop="filename" label="鏂囦欢鍚嶇О"></el-table-column>
-          <el-table-column prop="time" label="涓婁紶鏃堕棿"></el-table-column>
-          <el-table-column prop="state" label="鐘舵��"></el-table-column>
+          <el-table-column prop="Name" label="鏂囦欢鍚嶇О"></el-table-column>
+          <el-table-column prop="UploadTime" label="涓婁紶鏃堕棿"></el-table-column>
+          <el-table-column prop="Status" label="鐘舵��"></el-table-column>
         </el-table>
       </div>
     </el-dialog>
@@ -411,6 +411,7 @@
       this.$refs['directoryInput'].click();
     },
     importDirectory () {
+      let _this = this;
       //this.$refs['directoryInput'].files //鏂囦欢澶筸ap
       let formData = new FormData;
       for (var file in this.$refs['directoryInput'].files) {
@@ -420,7 +421,8 @@
 
       uploadDirectory(formData).then(res => {
         debugger
-
+        _this.batchImportTableData = res.data;
+        _this.renderMemberTable();
       })
     },
 
diff --git a/src/pages/shuohuangMonitorAnalyze/components/searchForVideoAnalyze.vue b/src/pages/shuohuangMonitorAnalyze/components/searchForVideoAnalyze.vue
index 10c1de4..2d8b3dd 100644
--- a/src/pages/shuohuangMonitorAnalyze/components/searchForVideoAnalyze.vue
+++ b/src/pages/shuohuangMonitorAnalyze/components/searchForVideoAnalyze.vue
@@ -124,10 +124,10 @@
             </el-select>
           </div>
           <div>
-            <el-select v-model="settle" size="mini">
+            <el-select v-model="IsOperate" size="mini" @change="filterSearchData">
               <el-option value label="鍏ㄩ儴"></el-option>
-              <el-option value="1" label="鏈鐞�"></el-option>
-              <el-option value="2" label="宸插鐞�"></el-option>
+              <el-option value="0" label="鏈鐞�"></el-option>
+              <el-option value="1" label="宸插鐞�"></el-option>
             </el-select>
           </div>
         </div>
@@ -187,6 +187,7 @@
           </el-col>
         </el-row>
         <el-pagination
+          class="pagination-center"
           background
           @size-change="handleTabSizeChange"
           @current-change="handleCurrentChange"
@@ -216,6 +217,7 @@
           </el-table-column>
         </el-table>
         <el-pagination
+          class="pagination-center"
           @size-change="handleTableSizeChange"
           @current-change="handleCurrentChange"
           :current-page.sync="curTablePage"
@@ -256,7 +258,8 @@
       CLIP: 'http://',
       keyword: '',
       IsFollow: '',
-      searchTime: [this.$moment(new Date().getTime() - 3600 * 1000 * 24 * 5).format("YYYY-MM-DD HH:mm:ss"), this.$moment(new Date()).format("YYYY-MM-DD HH:mm:ss")],
+      //searchTime: [this.$moment(new Date().getTime() - 3600 * 1000 * 24 * 5).format("YYYY-MM-DD HH:mm:ss"), this.$moment(new Date()).format("YYYY-MM-DD HH:mm:ss")],
+      searchTime: [new Date(2020,0,1,0,0,0),new Date(2020,11,31,23,59,59)],
       curTabPage: 1,
       curTablePage: 1,
       tabPageSize: 8,
@@ -310,6 +313,7 @@
       showAdvance: true,
       fixedOneLineHeight: 40,
       settle: '',
+      IsOperate: '',
       showType: 'menu',
       tableData: [
         { name: 'SS4B115_06_B鑺備簩绔徃鏈哄_20201115_091500.mp4', size: '17.66M', updateTime: '2020-11-04 15:41', createTime: '2020-11-04 15:41' },
@@ -363,10 +367,11 @@
         KeyWord: this.keyword,
         StartDate: this.searchTime[0],
         EndDate: this.searchTime[1],
-        PageIndex: this.showType == 'list' ? this.curTablePage : this.showType == 'list',
+        PageIndex: this.showType == 'list' ? this.curTablePage : this.curTabPage,
         PageSize: this.showType == 'list' ? this.tablePageSize : this.tabPageSize,
         IsDetail: this.showType == 'list',
-        IsFollow: isFollow
+        IsFollow: isFollow,
+        IsOperate: this.IsOperate
       };
       let filterQuerys = [];
       this.checkedConfigs.forEach(config => {
@@ -401,7 +406,8 @@
         PageIndex: this.showType == 'list' ? this.curTablePage : this.showType == 'list',
         PageSize: this.showType == 'list' ? this.tablePageSize : this.tabPageSize,
         IsDetail: this.showType == 'list',
-        IsFollow: this.IsFollow
+        IsFollow: this.IsFollow,
+        IsOperate: this.IsOperate,
       };
       this.optionalConfigs = [];
       this.highLevelConfigs = [];
@@ -422,6 +428,12 @@
             obj.id = config.Node[key]
             return obj
           });
+          // config.data = config.Node.map((item) => {
+          //   let obj = {};
+          //   obj.name = item[0];
+          //   obj.id = item[1];
+          //   return obj;
+          // });
           config.id = config.ID;
           config.title = config.NameZn;
           config.data.forEach(item => {
@@ -744,11 +756,20 @@
         border-radius: 5px;
         height: 350px;
         .video-wrap {
-          background: aliceblue;
           border-radius: 3px;
+          width: 100%;
+          padding-top: 56.25%;
+          height: 0;
+          position: relative;
           img {
+            position: absolute;
+            top: 0;
             width: 100%;
-            border-radius: 3px;
+            height: 100%;
+            object-fit: contain;
+            // width: 100%;
+            // max-height: 200px;
+            // border-radius: 3px;
           }
         }
         .video-info {
@@ -801,6 +822,10 @@
           cursor: pointer;
         }
       }
+      .pagination-center{
+        text-align: center;
+        margin: 10px auto;
+      }
     }
     .dialog-video {
       z-index: 2096 !important;
diff --git a/src/pages/shuohuangMonitorAnalyze/components/transferDeviceManage.vue b/src/pages/shuohuangMonitorAnalyze/components/transferDeviceManage.vue
index 5429e2b..8921ac0 100644
--- a/src/pages/shuohuangMonitorAnalyze/components/transferDeviceManage.vue
+++ b/src/pages/shuohuangMonitorAnalyze/components/transferDeviceManage.vue
@@ -1,19 +1,22 @@
 <template>
   <div class="transfer-device-manage">
     <div class="header-with-tab">
-      <el-tabs v-model="actTab" @tab-click="checkTab" >
-        <el-tab-pane name="dev1" v-for="tab in devices" :key="tab">
+      <el-tabs v-model="actTab" @tab-click="checkTab">
+        <el-tab-pane :name="tab.ID" v-for="tab in devices" :key="tab.ID">
           <div slot="label" class="label-slot">
             <span>{{tab.Name}}</span>
-            <span class="capsule" :class="{'online':tab.Status==0,'offline':tab.Status==1}">{{tab.Status==0?"鍦ㄧ嚎":"绂荤嚎"}}</span>
+            <span
+              class="capsule"
+              :class="{'online':tab.Status==0,'offline':tab.Status==1}"
+            >{{tab.Status==0?"鍦ㄧ嚎":"绂荤嚎"}}</span>
           </div>
         </el-tab-pane>
-        <el-tab-pane name="dev2">
+        <!-- <el-tab-pane name="dev2">
           <div slot="label" class="label-slot">
             <span>杞偍璁惧2</span>
             <span class="capsule offline">绂荤嚎</span>
           </div>
-        </el-tab-pane>
+        </el-tab-pane>-->
       </el-tabs>
       <div class="btn-add-dev" @click="showAddDevice">
         <i class="el-icon-circle-plus"></i>
@@ -31,10 +34,10 @@
         :key="indicator.id"
       >
         <div class="title">
-          <span class="dot"></span>
+          <span class="dot" :class="{'kx':indicator.id=='kx','dx':indicator.id=='dx','ccgz':indicator.id=='ccgz'}"></span>
           <span class="word">{{indicator.title}}</span>
         </div>
-        <div class="indicator-val">{{indicator.val}}</div>
+        <div class="indicator-val">{{indicator.slots.length}}</div>
       </div>
     </div>
     <div class="table-area">
@@ -44,7 +47,7 @@
           <div>
             <el-input v-model="deviceAddr" size="small"></el-input>
           </div>
-        </div> -->
+        </div>-->
         <div>
           <label>璁惧鐘舵��:</label>
           <div>
@@ -58,8 +61,18 @@
         </div>
       </div>
       <el-table class="thbg" :data="tableData" fit>
-        <el-table-column prop="name" label="杞偍璁惧鍚嶇О"></el-table-column>
-        <el-table-column prop="state" label="璁惧鐘舵��"></el-table-column>
+        <el-table-column type="index" width="100" label="搴忓彿"></el-table-column>
+        <el-table-column prop="Name" label="鎻掓Ы鍚嶇О"></el-table-column>
+        <el-table-column prop="Status" label="鐘舵��">
+          <template slot-scope="scope">
+            <div>
+              <span v-if="scope.row.Status==0">绌洪棽涓�</span>
+              <span v-if="scope.row.Status==1">璇诲啓涓�</span>
+              <span v-if="scope.row.Status==2">鎻掓Ы鏁呴殰</span>
+            </div>
+          </template>
+        </el-table-column>
+        <!-- <el-table-column prop="state" label="璁惧鐘舵��"></el-table-column>
         <el-table-column prop="pic" label="鐜板満鍥剧墖"></el-table-column>
         <el-table-column prop="addr" label="璁惧鍦板潃"></el-table-column>
         <el-table-column prop="tel" label="鎶ヤ慨鐢佃瘽"></el-table-column>
@@ -69,12 +82,16 @@
               <span @click="checkSlot(scope.row)">鏌ョ湅鎻掓Ы</span>
             </div>
           </template>
-        </el-table-column>
+        </el-table-column>-->
       </el-table>
     </div>
-    <el-dialog :visible="visibleOfialogAddDev">
+    <el-dialog
+      :visible="visibleOfialogAddDev"
+      title="娣诲姞璁惧"
+      class="dialog-addDev"
+      @close="visibleOfialogAddDev = false"
+    >
       <div>
-        <p slot="title">娣诲姞璁惧</p>
         <div class="flex-box">
           <label>璁惧鍚嶇О锛�</label>
           <el-input v-model="Name"></el-input>
@@ -92,53 +109,81 @@
   </div>
 </template>
 <script>
-import {addDevice,getDeviceList} from '@/api/shuohuang';
+import { addDevice, getDeviceList, getDeviceInfoById } from '@/api/shuohuang';
 export default {
   data () {
     return {
       actTab: 'dev1',
       devices: [],
-      generalIndicators: [{ id: 'gz', title: '鏈夋晠闅滆澶�', val: 156 }, { id: 'zc', title: '姝e父璁惧', val: 5000 }, { id: 'dx', title: '璇诲啓涓�', val: 56 }, { id: 'kx', title: '绌洪棽涓�', val: 2000 }, { id: 'ccgz', title: '鎻掓Ы鏁呴殰', val: 1000 }],
+      generalIndicators: [{ id: 'dx', title: '璇诲啓涓�', slots: [] }, { id: 'kx', title: '绌洪棽涓�', slots: [] }, { id: 'ccgz', title: '鎻掓Ы鏁呴殰', slots: [] }],
       deviceAddr: '',
       deviceState: '',
       tableData: [],
       visibleOfialogAddDev: false,
-      Name:'',
-      IP:'',
+      Name: '',
+      IP: '',
     }
   },
-  mounted(){
+  mounted () {
     this.findDeviceList();
   },
   methods: {
-    findDeviceList (){
-      getDeviceList().then(res=>{
-        debugger
-        //_this.devices = 
+    findDeviceList () {
+      let _this = this;
+      getDeviceList().then(res => {
+        _this.devices = res.data;
+        _this.actTab = _this.devices[0].ID;
+        _this.findDeviceIfo()
       })
     },
-    toAddDevice(){
+    findDeviceIfo () {
+      let _this = this;
+      getDeviceInfoById({ DeviceID: this.actTab }).then(res => {
+        debugger
+        _this.tableData = res.data;
+        //缁熻褰撳墠鎻掓Ы鐘舵��
+        let dx = _this.generalIndicators.find(indicator => indicator.id == 'dx');
+        let kx = _this.generalIndicators.find(indicator => indicator.id == 'kx');
+        let ccgz = _this.generalIndicators.find(indicator => indicator.id == 'ccgz');
+        dx.slots = [];
+        kx.slots = [];
+        ccgz.slots = [];
+        res.data.forEach(slot => {
+          if (slot.Status == 0) {
+            kx.slots.push(slot)
+          }
+          if (slot.Status == 1) {
+            dx.slots.push(slot)
+          }
+          if (slot.Status == 2) {
+            ccgz.slots.push(slot)
+          }
+        })
+        //_this.generalIndicators
+      })
+    },
+    toAddDevice () {
       let _this = this;
       let params = {
         Name: this.Name,
         IP: this.IP
       }
-      addDevice(params).then(res=>{
-        if(res.success){
+      addDevice(params).then(res => {
+        if (res.success) {
           this.$notify({
-            type:'success',
+            type: 'success',
             message: res.msg
           })
           _this.visibleOfialogAddDev = true;
         }
       })
     },
-    showAddDevice(){
+    showAddDevice () {
       this.visibleOfialogAddDev = true;
 
     },
     checkTab (tab, event) {
-
+      this.findDeviceIfo();
     },
     checkSlot (row) {
 
@@ -150,7 +195,7 @@
 <style lang="scss">
 .transfer-device-manage {
   padding: 20px;
-  .el-tabs__item{
+  .el-tabs__item {
     height: 45px;
     line-height: 45px;
   }
@@ -167,17 +212,17 @@
       .capsule {
         width: 42px;
         height: 20px;
-        margin-left: 10px; 
+        margin-left: 10px;
         line-height: 20px;
         text-align: center;
         border-radius: 20px;
         font-size: 12px;
         font-weight: normal;
         color: #fff;
-        &.online{
+        &.online {
           background: #00a854;
         }
-        &.offline{
+        &.offline {
           background: #f04134;
         }
       }
@@ -223,7 +268,13 @@
           height: 10px;
           margin-right: 5px;
           border-radius: 50%;
-          background: rgb(94, 14, 243);
+          background: #01a854;
+          &.kx {
+            background: #0f77d1;
+          }
+          &.ccgz {
+            background: #f04235;
+          }
         }
       }
       .indicator-val {
@@ -241,5 +292,24 @@
       }
     }
   }
+  .dialog-addDev {
+    .el-dialog {
+      width: 600px;
+    }
+    .flex-box {
+      align-items: center;
+      margin-bottom: 10px;
+      label {
+        width: 90px;
+        text-align: left;
+      }
+      .el-input {
+        width: 500px;
+      }
+    }
+    .btns {
+      padding: 10px 0;
+    }
+  }
 }
 </style>
\ No newline at end of file
diff --git a/src/pages/shuohuangMonitorAnalyze/components/videoAnalyze.vue b/src/pages/shuohuangMonitorAnalyze/components/videoAnalyze.vue
index 5cba441..87a6943 100644
--- a/src/pages/shuohuangMonitorAnalyze/components/videoAnalyze.vue
+++ b/src/pages/shuohuangMonitorAnalyze/components/videoAnalyze.vue
@@ -316,6 +316,7 @@
       let query = {
         ID: this.selectedLabelId,
         ParentID: this.isCheckAllVideo ? tempArr.join(',') : this.curVideo.ID + '',
+        ParentUniqID:this.curVideo.UniqeID+ '',
         Time: Math.round(this.setLabelTime) + '',
         Codes: this.labelCheckedList.join(','),
         Desc: desc.join('锛�')
diff --git a/vue.config.js b/vue.config.js
index e619261..c5faf7a 100644
--- a/vue.config.js
+++ b/vue.config.js
@@ -87,7 +87,7 @@
         }
       },
       "/api-c": {
-        target: 'http://192.168.20.113:8004',
+        target: 'http://192.168.20.10:8004',
         changeOrigin: true
       },
       "/api-v": {

--
Gitblit v1.8.0