web_src/src/components/StreamProxyList.vue
@@ -5,14 +5,15 @@
      <div class="page-header-btn">
        <el-button icon="el-icon-plus" size="mini" style="margin-right: 1rem;" type="primary" @click="addStreamProxy">添加代理</el-button>
        <el-button v-if="false" icon="el-icon-search" size="mini" style="margin-right: 1rem;" type="primary" @click="addOnvif">搜索ONVIF</el-button>
        <el-button icon="el-icon-refresh-right" circle size="mini" @click="refresh()"></el-button>
      </div>
    </div>
    <devicePlayer ref="devicePlayer"></devicePlayer>
    <el-table :data="streamProxyList" border style="width: 100%" :height="winHeight">
      <el-table-column prop="name" label="名称" align="center" show-overflow-tooltip/>
      <el-table-column prop="app" label="流应用名" align="center" show-overflow-tooltip/>
      <el-table-column prop="stream" label="流ID" align="center" show-overflow-tooltip/>
      <el-table-column label="流地址" width="400" align="center" show-overflow-tooltip >
    <el-table :data="streamProxyList" style="width: 100%" :height="winHeight">
      <el-table-column prop="name" label="名称" min-width="120" show-overflow-tooltip/>
      <el-table-column prop="app" label="流应用名" min-width="120" show-overflow-tooltip/>
      <el-table-column prop="stream" label="流ID" min-width="120" show-overflow-tooltip/>
      <el-table-column label="流地址" min-width="400"  show-overflow-tooltip >
        <template slot-scope="scope">
          <div slot="reference" class="name-wrapper">
@@ -27,8 +28,8 @@
          </div>
        </template>
      </el-table-column>
      <el-table-column prop="mediaServerId" label="流媒体" width="150" align="center"></el-table-column>
      <el-table-column label="类型" width="100" align="center">
      <el-table-column prop="mediaServerId" label="流媒体" min-width="180" ></el-table-column>
      <el-table-column label="类型" width="100" >
        <template slot-scope="scope">
          <div slot="reference" class="name-wrapper">
            <el-tag size="medium">{{scope.row.type}}</el-tag>
@@ -36,8 +37,8 @@
        </template>
      </el-table-column>
      <el-table-column prop="gbId" label="国标编码" width="180" align="center" show-overflow-tooltip/>
      <el-table-column label="状态" width="120" align="center">
      <el-table-column prop="gbId" label="国标编码" min-width="180"  show-overflow-tooltip/>
      <el-table-column label="状态" min-width="120" >
        <template slot-scope="scope">
          <div slot="reference" class="name-wrapper">
            <el-tag size="medium" v-if="scope.row.status">在线</el-tag>
@@ -45,7 +46,7 @@
          </div>
        </template>
      </el-table-column>
      <el-table-column label="启用" width="120" align="center">
      <el-table-column label="启用" min-width="120" >
        <template slot-scope="scope">
          <div slot="reference" class="name-wrapper">
            <el-tag size="medium" v-if="scope.row.enable">已启用</el-tag>
@@ -53,8 +54,8 @@
          </div>
        </template>
      </el-table-column>
      <el-table-column prop="createTime" label="创建时间" align="center" width="150" show-overflow-tooltip/>
      <el-table-column label="转HLS" width="120" align="center">
      <el-table-column prop="createTime" label="创建时间"  min-width="150" show-overflow-tooltip/>
      <el-table-column label="转HLS" min-width="120" >
        <template slot-scope="scope">
          <div slot="reference" class="name-wrapper">
            <el-tag size="medium" v-if="scope.row.enable_hls">已启用</el-tag>
@@ -62,7 +63,7 @@
          </div>
        </template>
      </el-table-column>
      <el-table-column label="MP4录制" width="120" align="center">
      <el-table-column label="MP4录制" min-width="120" >
        <template slot-scope="scope">
          <div slot="reference" class="name-wrapper">
            <el-tag size="medium" v-if="scope.row.enable_mp4">已启用</el-tag>
@@ -70,7 +71,7 @@
          </div>
        </template>
      </el-table-column>
      <el-table-column label="无人观看自动删除" width="160" align="center">
      <el-table-column label="无人观看自动删除" min-width="160" >
        <template slot-scope="scope">
          <div slot="reference" class="name-wrapper">
            <el-tag size="medium" v-if="scope.row.enable_remove_none_reader">已启用</el-tag>
@@ -80,14 +81,15 @@
      </el-table-column>
      <el-table-column label="操作" width="360" align="center" fixed="right">
      <el-table-column label="操作" width="360"  fixed="right">
        <template slot-scope="scope">
          <el-button-group>
            <el-button size="mini" icon="el-icon-video-play" v-if="scope.row.enable" @click="play(scope.row)">播放</el-button>
            <el-button size="mini" icon="el-icon-close" type="success" v-if="scope.row.enable" @click="stop(scope.row)">停用</el-button>
            <el-button size="mini" icon="el-icon-check" type="primary" :loading="startBtnLaoding" v-if="!scope.row.enable" @click="start(scope.row)">启用</el-button>
            <el-button size="mini" icon="el-icon-delete" type="danger"  @click="deleteStreamProxy(scope.row)">删除</el-button>
          </el-button-group>
          <el-button size="medium" icon="el-icon-video-play" type="text" v-if="scope.row.enable" @click="play(scope.row)">播放</el-button>
          <el-divider direction="vertical"></el-divider>
          <el-button size="medium" icon="el-icon-switch-button" type="text" v-if="scope.row.enable" @click="stop(scope.row)">停用</el-button>
          <el-divider direction="vertical"></el-divider>
          <el-button size="medium" icon="el-icon-check" type="text" :loading="scope.row.startBtnLoading" v-if="!scope.row.enable" @click="start(scope.row)">启用</el-button>
          <el-divider v-if="!scope.row.enable" direction="vertical"></el-divider>
          <el-button size="medium" icon="el-icon-delete" type="text" style="color: #f56c6c" @click="deleteStreamProxy(scope.row)">删除</el-button>
        </template>
      </el-table-column>
    </el-table>
@@ -130,7 +132,7 @@
            count:15,
            total:0,
            getListLoading: false,
            startBtnLaoding: false
        startBtnLoading: false
         };
      },
      computed: {
@@ -167,7 +169,10 @@
               }
            }).then(function (res) {
               that.total = res.data.total;
               that.streamProxyList = res.data.list;
          for (let i = 0; i < res.data.list.length; i++) {
            res.data.list[i]["startBtnLoading"] = false;
          }
          that.streamProxyList = res.data.list;
               that.getListLoading = false;
            }).catch(function (error) {
               console.log(error);
@@ -261,7 +266,7 @@
         start: function(row){
            let that = this;
            this.getListLoading = true;
            this.startBtnLaoding = true;
        this.$set(row, 'startBtnLoading', true)
            this.$axios({
               method: 'get',
               url:`/api/proxy/start`,
@@ -271,7 +276,7 @@
               }
            }).then(function (res) {
          that.getListLoading = false;
          that.startBtnLaoding = false;
          that.$set(row, 'startBtnLoading', false)
              if (res.data == "success"){
            that.initData()
          }else {
@@ -285,7 +290,7 @@
            }).catch(function (error) {
               console.log(error);
               that.getListLoading = false;
               that.startBtnLaoding = false;
          that.$set(row, 'startBtnLoading', false)
            });
         },
         stop: function(row){
@@ -305,8 +310,10 @@
               console.log(error);
               that.getListLoading = false;
            });
         }
         },
      refresh: function (){
        this.initData();
      }
      }
   };
</script>