新版目录树样式调试及状态更新调试;朔黄批量导入列表调试;视频检索页面添加处理参数,添加标注接口添加参数;分页器展示优化,默认检索时间调整;转储设备接口调试
11个文件已修改
240 ■■■■ 已修改文件
src/api/shuohuang.ts 5 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/components/giantTree/index.vue 23 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/components/giantTree/zTree/ztree.vue 4 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/components/giantTree/zTree/ztree_v3/jquery.ztree.all.js 2 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/pages/cameraAccess/components/CameraInfo.vue 12 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/pages/cameraAccess/index/App.vue 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/pages/shuohuangMonitorAnalyze/components/memberManage.vue 10 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/pages/shuohuangMonitorAnalyze/components/searchForVideoAnalyze.vue 43 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/pages/shuohuangMonitorAnalyze/components/transferDeviceManage.vue 136 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/pages/shuohuangMonitorAnalyze/components/videoAnalyze.vue 1 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
vue.config.js 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
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
})
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;
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();
}
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);
        }
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({
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">
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 //文件夹map
      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();
      })
    },
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;
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: '正常设备', 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>
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(',')
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": {