| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237 |
- <template>
- <div id="chooseChannelForGb" >
- <div style="background-color: #FFFFFF; margin-bottom: 1rem; 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-select size="mini" @change="search" style="margin-right: 1rem; width:6rem" v-model="channelType" placeholder="请选择" default-first-option>
- <el-option label="全部" value=""></el-option>
- <el-option label="设备" value="false"></el-option>
- <el-option label="子目录" value="true"></el-option>
- </el-select>
- 选择状态: <el-select size="mini" style="margin-right: 1rem; width:6rem" v-model="choosed" @change="search" placeholder="请选择" default-first-option>
- <el-option label="全部" value=""></el-option>
- <el-option label="已选择" value="true"></el-option>
- <el-option label="未选择" value="false"></el-option>
- </el-select>
- 在线状态: <el-select size="mini" style="margin-right: 1rem; width:6rem" @change="search" v-model="online" placeholder="请选择" default-first-option>
- <el-option label="全部" value=""></el-option>
- <el-option label="在线" value="true"></el-option>
- <el-option label="离线" value="false"></el-option>
- </el-select>
- <el-checkbox @change="shareAllCheckedChanage">全部共享</el-checkbox>
- </div>
- <el-table ref="gbChannelsTable" :data="gbChannels" border style="width: 100%" @selection-change="checkedChanage" >
- <el-table-column type="selection" width="55" align="center" fixed > </el-table-column>
- <el-table-column prop="channelId" label="通道编号" width="210">
- </el-table-column>
- <el-table-column prop="name" label="通道名称">
- </el-table-column>
- <el-table-column prop="deviceId" label="设备编号" width="210" >
- </el-table-column>
- <el-table-column label="设备地址" width="180" align="center">
- <template slot-scope="scope">
- <div slot="reference" class="name-wrapper">
- <el-tag size="medium">{{ scope.row.hostAddress }}</el-tag>
- </div>
- </template>
- </el-table-column>
- <el-table-column prop="manufacturer" label="厂家" align="center">
- </el-table-column>
- </el-table>
- <el-pagination style="float: right;margin-top: 1rem;" @size-change="handleSizeChange" @current-change="currentChange" :current-page="currentPage" :page-size="count" :page-sizes="[10, 20, 30, 50]" layout="total, sizes, prev, pager, next" :total="total">
- </el-pagination>
- </div>
- </template>
- <script>
- export default {
- name: 'chooseChannelForGb',
- props: {},
- computed: {
- // getPlayerShared: function () {
- // return {
- // sharedUrl: window.location.host + '/' + this.videoUrl,
- // sharedIframe: '<iframe src="' + window.location.host + '/' + this.videoUrl + '"></iframe>',
- // sharedRtmp: this.videoUrl
- // };
- // }
- },
- props: ['platformId'],
- created() {
- this.initData();
- },
- data() {
- return {
- gbChannels: [],
- gbChoosechannel:{},
- searchSrt: "",
- channelType: "",
- online: "",
- choosed: "",
- currentPage: 0,
- count: 15,
- total: 0,
- eventEnanle: false
- };
- },
- watch:{
- platformId(newData, oldData){
- console.log(newData)
- this.initData()
-
- },
- },
- methods: {
- initData: function() {
- this.getChannelList();
- },
- currentChange: function (val) {
- this.currentPage = val;
- this.initData();
- },
- handleSizeChange: function (val) {
- this.count = val;
- console.log(val)
- this.initData();
- },
- rowcheckedChanage: function (val, row) {
- console.log(val)
- console.log(row)
- },
- checkedChanage: function (val) {
- var that = this;
- if (!that.eventEnanle) {
- return;
- }
- var tabelData = JSON.parse(JSON.stringify(this.$refs.gbChannelsTable.data));
- console.log("checkedChanage")
- console.log(val)
- var newData = {};
- var addData = [];
- var delData = [];
- if (val.length > 0) {
- for (let i = 0; i < val.length; i++) {
- const element = val[i];
- var key = element.deviceId + "_" + element.channelId;
- newData[key] = element;
- if (!!!that.gbChoosechannel[key]){
- addData.push(element)
- }else{
- delete that.gbChoosechannel[key]
- }
- }
-
- var oldKeys = Object.keys(that.gbChoosechannel);
- if (oldKeys.length > 0) {
- for (let i = 0; i < oldKeys.length; i++) {
- const key = oldKeys[i];
- delData.push(that.gbChoosechannel[key])
- }
- }
-
- }else{
- var oldKeys = Object.keys(that.gbChoosechannel);
- if (oldKeys.length > 0) {
- for (let i = 0; i < oldKeys.length; i++) {
- const key = oldKeys[i];
- delData.push(that.gbChoosechannel[key])
- }
- }
- }
- that.gbChoosechannel = newData;
- if (Object.keys(addData).length >0) {
- that.$axios({
- method:"post",
- url:"/api/platforms/updateChannelForGB",
- data:{
- platformId: that.platformId,
- channelReduces: addData
- }
- }).then((res)=>{
- console.log("保存成功")
- }).catch(function (error) {
- console.log(error);
- });
- }
- if (Object.keys(delData).length >0) {
- that.$axios({
- method:"post",
- url:"/api/platforms/delChannelForGB",
- data:{
- platformId: that.platformId,
- channelReduces: delData
- }
- }).then((res)=>{
- console.log("移除成功")
- }).catch(function (error) {
- console.log(error);
- });
- }
- },
- shareAllCheckedChanage: function (val) {
- this.chooseChanage(null, val)
- },
- getChannelList: function () {
- let that = this;
- this.$axios.get(`/api/platforms/channelList`, {
- params: {
- page: that.currentPage,
- count: that.count,
- query: that.searchSrt,
- online: that.online,
- choosed: that.choosed,
- platformId: that.platformId,
- channelType: that.channelType
- }
- })
- .then(function (res) {
- that.total = res.data.total;
- that.gbChannels = res.data.list;
- that.gbChoosechannel = {};
- // 防止出现表格错位
- that.$nextTick(() => {
- that.$refs.gbChannelsTable.doLayout();
- // 默认选中
- var chooseGBS = [];
- for (let i = 0; i < res.data.list.length; i++) {
- const row = res.data.list[i];
- console.log(row.platformId)
- if (row.platformId == that.platformId) {
- that.$refs.gbChannelsTable.toggleRowSelection(row, true);
- chooseGBS.push(row)
- that.gbChoosechannel[row.deviceId+ "_" + row.channelId] = row;
-
- }
- }
- that.eventEnanle = true;
- // that.checkedChanage(chooseGBS)
- })
- console.log(that.gbChoosechannel)
- })
- .catch(function (error) {
- console.log(error);
- });
- },
- search: function() {
- this.initData();
- },
- handleGBSelectionChange: function() {
- this.initData();
- },
- }
- };
- </script>
- <style>
- </style>
|