|  |  |  | 
|---|
|  |  |  | <template> | 
|---|
|  |  |  | <div id="chooseChannelForGb" > | 
|---|
|  |  |  | <div id="chooseChannelForGb" v-loading="loading"> | 
|---|
|  |  |  | <div style="font-size: 17px; color: #606060; white-space: nowrap; line-height: 30px; font-family: monospace;"> | 
|---|
|  |  |  | <span v-if="catalogId == null">{{catalogName}}的直播流</span> | 
|---|
|  |  |  | <span v-if="catalogId != null">{{catalogName}}({{catalogId}})的直播流</span> | 
|---|
|  |  |  | <span v-if="catalogId == null">{{catalogName}}的国标通道</span> | 
|---|
|  |  |  | <span v-if="catalogId != null">{{catalogName}}({{catalogId}})的国标通道</span> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div style="background-color: #FFFFFF; position: relative; padding: 0.5rem; text-align: left;font-size: 14px;"> | 
|---|
|  |  |  | 搜索: <el-input @input="search" style="margin-right: 1rem; width: auto;" size="mini" placeholder="关键字" prefix-icon="el-icon-search" v-model="searchSrt" clearable> </el-input> | 
|---|
|  |  |  | 
|---|
|  |  |  | <el-option label="在线" value="true"></el-option> | 
|---|
|  |  |  | <el-option label="离线" value="false"></el-option> | 
|---|
|  |  |  | </el-select> | 
|---|
|  |  |  | <el-button v-if="catalogId !== null" icon="el-icon-delete" size="mini" style="margin-right: 1rem;" :disabled="gbChannels.length === 0 || multipleSelection.length === 0" type="danger" @click="batchDel">批量移除</el-button> | 
|---|
|  |  |  | <el-button v-if="catalogId === null" icon="el-icon-plus" size="mini" style="margin-right: 1rem;" :disabled="gbChannels.length === 0 || multipleSelection.length === 0" @click="batchAdd">批量添加</el-button> | 
|---|
|  |  |  | <el-button v-if="catalogId !== null" icon="el-icon-delete" size="mini" :disabled="gbChannels.length === 0 || multipleSelection.length === 0" type="danger" @click="batchDel">批量移除</el-button> | 
|---|
|  |  |  | <el-button v-if="catalogId === null" icon="el-icon-plus" size="mini" :disabled="gbChannels.length === 0 || multipleSelection.length === 0" @click="batchAdd">批量添加</el-button> | 
|---|
|  |  |  | <el-button v-if="catalogId === null" icon="el-icon-plus" size="mini" @click="add()">全部添加</el-button> | 
|---|
|  |  |  | <el-button v-if="catalogId !== null" type="danger" icon="el-icon-delete" size="mini" @click="remove()">全部移除</el-button> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <el-table ref="gbChannelsTable" :data="gbChannels" border style="width: 100%" :height="winHeight" :row-key="(row)=> row.deviceId + row.channelId" @selection-change="handleSelectionChange"> | 
|---|
|  |  |  | 
|---|
|  |  |  | <el-table-column label="操作" width="100" align="center" fixed="right"> | 
|---|
|  |  |  | <template slot-scope="scope"> | 
|---|
|  |  |  | <el-button-group> | 
|---|
|  |  |  | <el-button size="mini" icon="el-icon-plus" v-if="!scope.row.platformId" @click="add(scope.row)">添加</el-button> | 
|---|
|  |  |  | <el-button size="mini" icon="el-icon-delete" v-if="scope.row.platformId" type="danger" @click="remove(scope.row)">移除</el-button> | 
|---|
|  |  |  | <el-button size="mini" icon="el-icon-plus" v-if="catalogId === null" @click="add(scope.row)">添加</el-button> | 
|---|
|  |  |  | <el-button size="mini" icon="el-icon-delete" v-if="catalogId !== null" type="danger" @click="remove(scope.row)">移除</el-button> | 
|---|
|  |  |  | </el-button-group> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </el-table-column> | 
|---|
|  |  |  | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | data() { | 
|---|
|  |  |  | return { | 
|---|
|  |  |  | loading: false, | 
|---|
|  |  |  | gbChannels: [], | 
|---|
|  |  |  | gbChoosechannel:{}, | 
|---|
|  |  |  | searchSrt: "", | 
|---|
|  |  |  | 
|---|
|  |  |  | this.initData(); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | add: function (row) { | 
|---|
|  |  |  | let all = typeof(row) === "undefined" | 
|---|
|  |  |  |  | 
|---|
|  |  |  | this.getCatalogFromUser((catalogId)=> { | 
|---|
|  |  |  | let task = null; | 
|---|
|  |  |  | this.$axios({ | 
|---|
|  |  |  | method:"post", | 
|---|
|  |  |  | url:"/api/platform/update_channel_for_gb", | 
|---|
|  |  |  | data:{ | 
|---|
|  |  |  | platformId:  this.platformId, | 
|---|
|  |  |  | channelReduces: [row], | 
|---|
|  |  |  | all: all, | 
|---|
|  |  |  | channelReduces: all?[]:[row], | 
|---|
|  |  |  | catalogId: catalogId | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }).then((res)=>{ | 
|---|
|  |  |  | console.log("保存成功") | 
|---|
|  |  |  | window.clearTimeout(task); | 
|---|
|  |  |  | this.loading = false; | 
|---|
|  |  |  | this.getChannelList(); | 
|---|
|  |  |  | }).catch((error)=> { | 
|---|
|  |  |  | window.clearTimeout(task); | 
|---|
|  |  |  | this.loading = false; | 
|---|
|  |  |  | console.log(error); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | task= setTimeout(()=>{ | 
|---|
|  |  |  | this.loading = true; | 
|---|
|  |  |  | }, 200) | 
|---|
|  |  |  | }) | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | remove: function (row) { | 
|---|
|  |  |  | let all = typeof(row) === "undefined" | 
|---|
|  |  |  | this.$confirm(`确定移除${all?"所有通道":""}吗?`, '提示', { | 
|---|
|  |  |  | dangerouslyUseHTMLString: true, | 
|---|
|  |  |  | confirmButtonText: '确定', | 
|---|
|  |  |  | cancelButtonText: '取消', | 
|---|
|  |  |  | type: 'warning' | 
|---|
|  |  |  | }).then(() => { | 
|---|
|  |  |  | console.log(row) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | this.$axios({ | 
|---|
|  |  |  | method:"delete", | 
|---|
|  |  |  | url:"/api/platform/del_channel_for_gb", | 
|---|
|  |  |  | data:{ | 
|---|
|  |  |  | platformId:  this.platformId, | 
|---|
|  |  |  | all: all, | 
|---|
|  |  |  | channelReduces: all?[]:[row], | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }).then((res)=>{ | 
|---|
|  |  |  | console.log("移除成功") | 
|---|
|  |  |  | this.getChannelList(); | 
|---|
|  |  |  | }).catch(function (error) { | 
|---|
|  |  |  | console.log(error); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | }).catch(() => { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | remove: function (row) { | 
|---|
|  |  |  | console.log(row) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | this.$axios({ | 
|---|
|  |  |  | method:"delete", | 
|---|
|  |  |  | url:"/api/platform/del_channel_for_gb", | 
|---|
|  |  |  | data:{ | 
|---|
|  |  |  | platformId:  this.platformId, | 
|---|
|  |  |  | channelReduces: [row] | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }).then((res)=>{ | 
|---|
|  |  |  | console.log("移除成功") | 
|---|
|  |  |  | this.getChannelList(); | 
|---|
|  |  |  | }).catch(function (error) { | 
|---|
|  |  |  | console.log(error); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // checkedChange: function (val) { | 
|---|
|  |  |  | //     let that = this; | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .then(function (res) { | 
|---|
|  |  |  | that.total = res.data.total; | 
|---|
|  |  |  | that.gbChannels = res.data.list; | 
|---|
|  |  |  | if (res.data.code === 0 ) { | 
|---|
|  |  |  | that.total = res.data.data.total; | 
|---|
|  |  |  | that.gbChannels = res.data.data.list; | 
|---|
|  |  |  | that.gbChoosechannel = {}; | 
|---|
|  |  |  | // 防止出现表格错位 | 
|---|
|  |  |  | that.$nextTick(() => { | 
|---|
|  |  |  | that.$refs.gbChannelsTable.doLayout(); | 
|---|
|  |  |  | that.eventEnable = true; | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | console.log(that.gbChoosechannel) | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 防止出现表格错位 | 
|---|
|  |  |  | that.$nextTick(() => { | 
|---|
|  |  |  | that.$refs.gbChannelsTable.doLayout(); | 
|---|
|  |  |  | that.eventEnable = true; | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .catch(function (error) { | 
|---|
|  |  |  | console.log(error); | 
|---|