648540858
2022-01-14 ac1a4a027a7bd88efb32e9da666bdba4b5fa166f
web_src/src/components/PushVideoList.vue
@@ -17,6 +17,8 @@
               </el-table-column>
               <el-table-column prop="gbId" label="国标编码" width="150" align="center">
               </el-table-column>
               <el-table-column prop="mediaServerId" label="流媒体" width="150" align="center">
               </el-table-column>
               <el-table-column label="开始时间" align="center" >
                  <template slot-scope="scope">
                     <el-button-group>
@@ -29,12 +31,12 @@
                     {{(scope.row.status == false && scope.row.gbId == null) || scope.row.status ?'是':'否'}}
                  </template>
               </el-table-column>
               <el-table-column label="操作" width="360" align="center" fixed="right">
                  <template slot-scope="scope">
                     <el-button-group>
                        <el-button size="mini" icon="el-icon-video-play" @click="playPuhsh(scope.row)">播放</el-button>
                        <el-button size="mini" icon="el-icon-switch-button" type="danger" v-if="!!scope.row.streamId" @click="stopPuhsh(scope.row)">停止</el-button>
                        <el-button size="mini" icon="el-icon-video-play" v-if="(scope.row.status == false && scope.row.gbId == null) || scope.row.status" @click="playPuhsh(scope.row)">播放</el-button>
                        <el-button size="mini" icon="el-icon-switch-button" type="danger" @click="stopPuhsh(scope.row)">移除</el-button>
                        <el-button size="mini" icon="el-icon-position" type="primary" v-if="!!!scope.row.gbId" @click="addToGB(scope.row)">加入国标</el-button>
                        <el-button size="mini" icon="el-icon-position" type="primary" v-if="!!scope.row.gbId" @click="removeFromGB(scope.row)">移出国标</el-button>
                     </el-button-group>
@@ -107,65 +109,80 @@
         getPushList: function() {
            let that = this;
            this.getDeviceListLoading = true;
            this.$axios.get(`/api/push/list`,{
            this.$axios({
               method: 'get',
               url:`/api/push/list`,
               params: {
                  page: that.currentPage,
                  count: that.count
               }
            } )
            .then(function (res) {
            }).then(function (res) {
               console.log(res);
               console.log(res.data.list);
               that.total = res.data.total;
               that.pushList = res.data.list;
               that.getDeviceListLoading = false;
            })
            .catch(function (error) {
            }).catch(function (error) {
               console.log(error);
               that.getDeviceListLoading = false;
            });
         },
         playPuhsh: function(row){
            let that = this;
            this.getListLoading = true;
            this.$axios.get(`/api/media/getStreamInfoByAppAndStream`,{
            this.$axios({
               method: 'get',
               url: '/api/media/stream_info_by_app_and_stream',
               params: {
                  app: row.app,
                  stream: row.stream
                  stream: row.stream,
            mediaServerId: row.mediaServerId
               }
            })
            .then(function (res) {
            }).then(function (res) {
               that.getListLoading = false;
               that.$refs.devicePlayer.openDialog("streamPlay", null, null, {
                        streamInfo: res.data,
                        streamInfo: res.data.data,
                        hasAudio: true
                    });
            })
            .catch(function (error) {
            }).catch(function (error) {
               console.log(error);
               that.getListLoading = false;
            });
         },
         stopPuhsh: function(row){
            console.log(row)
        var that = this;
        that.$axios({
          method:"post",
          url:"/api/push/stop",
          params: {
            app: row.app,
            streamId: row.stream
          }
        }).then((res)=>{
          if (res.data == "success") {
            that.initData()
          }
        }).catch(function (error) {
          console.log(error);
        });
         },
         addToGB: function(row){
            this.$refs.addStreamTOGB.openDialog({app: row.app, stream: row.stream}, this.initData);
            this.$refs.addStreamTOGB.openDialog({app: row.app, stream: row.stream, mediaServerId: row.mediaServerId}, this.initData);
         },
         removeFromGB: function(row){
            var that = this;
            that.$axios.post(`/api/push/remove_form_gb`, row)
               .then(function (res) {
                  console.log(res);
                  console.log(res.data == "success");
                  if (res.data == "success") {
            that.$axios({
            method:"delete",
            url:"/api/push/remove_form_gb",
            data:row
        }).then((res)=>{
            if (res.data == "success") {
                     that.initData()
                  }
               })
               .catch(function (error) {
                  console.log(error);
               });
        }).catch(function (error) {
            console.log(error);
        });
         },
         dateFormat: function(/** timestamp=0 **/) {
            var ts = arguments[0] || 0;