|  |  |  | 
|---|
|  |  |  | <template> | 
|---|
|  |  |  | <div id="DeviceTree" style="width: 100%;height: 100%; background-color: #FFFFFF"> | 
|---|
|  |  |  | <div id="DeviceTree" style="width: 100%;height: 100%; background-color: #FFFFFF; overflow: auto"> | 
|---|
|  |  |  | <el-container> | 
|---|
|  |  |  | <el-header>设备列表</el-header> | 
|---|
|  |  |  | <el-main style="background-color: #ffffff;"> | 
|---|
|  |  |  | <div class="device-tree-main-box"> | 
|---|
|  |  |  | <el-tree :props="defaultProps" :load="loadNode" lazy @node-click="handleNodeClick"@node-contextmenu="handleContextMenu"> | 
|---|
|  |  |  | <el-tree :props="defaultProps" :load="loadNode" lazy @node-click="handleNodeClick"@node-contextmenu="handleContextMenu" style="min-width: 100%; display:inline-block !important;"> | 
|---|
|  |  |  | <span class="custom-tree-node" slot-scope="{ node, data }" style="width: 100%"> | 
|---|
|  |  |  | <span v-if="node.data.type === 0 && node.data.online" title="在线设备" class="device-online iconfont icon-jiedianleizhukongzhongxin2"></span> | 
|---|
|  |  |  | <span v-if="node.data.type === 0 && !node.data.online " title="离线设备" class="device-offline iconfont icon-jiedianleizhukongzhongxin2"></span> | 
|---|
|  |  |  | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | props: ['clickEvent', 'contextMenuEvent'], | 
|---|
|  |  |  | methods: { | 
|---|
|  |  |  | handleNodeClick(data) { | 
|---|
|  |  |  | handleNodeClick(data,node,element) { | 
|---|
|  |  |  | console.log("点击事件") | 
|---|
|  |  |  | console.log(data) | 
|---|
|  |  |  | if(typeof (this.clickEvent) == "function") { | 
|---|
|  |  |  | this.clickEvent(data.userData) | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | handleContextMenu(data) { | 
|---|
|  |  |  | handleContextMenu(event,data,node,element) { | 
|---|
|  |  |  | console.log("右键点击事件") | 
|---|
|  |  |  | if(typeof (this.contextMenuEvent) == "function") { | 
|---|
|  |  |  | this.contextMenuEvent(data.userData) | 
|---|
|  |  |  | this.contextMenuEvent(event, data.userData) | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | loadNode: function(node, resolve){ | 
|---|
|  |  |  | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | resolve([]) | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, (list)=>{ | 
|---|
|  |  |  | console.log("设备加载完成") | 
|---|
|  |  |  | }, (error)=>{ | 
|---|
|  |  |  |  | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (node.level === 1) { | 
|---|
|  |  |  | this.deviceService.getAllChannel(true, node.data.id, (catalogData) => { | 
|---|
|  |  |  | this.deviceService.getAllChannel(false, node.data.id, (channelData) => { | 
|---|
|  |  |  | let data = catalogData.concat(channelData) | 
|---|
|  |  |  | this.channelDataHandler(data, resolve) | 
|---|
|  |  |  | let channelArray = [] | 
|---|
|  |  |  | this.deviceService.getAllChannel(true, true, node.data.id, catalogData =>{ | 
|---|
|  |  |  | channelArray = channelArray.concat(catalogData) | 
|---|
|  |  |  | this.channelDataHandler(channelArray, resolve) | 
|---|
|  |  |  | },(endCatalogData) => { | 
|---|
|  |  |  | this.deviceService.getAllChannel(false, true, node.data.id, channelData => { | 
|---|
|  |  |  | channelArray = channelArray.concat(channelData) | 
|---|
|  |  |  | this.channelDataHandler(channelArray, resolve) | 
|---|
|  |  |  | }, endChannelList => { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | }else if (node.level > 1){ | 
|---|
|  |  |  | let channelArray = [] | 
|---|
|  |  |  | this.deviceService.getAllSubChannel(true, node.data.deviceId, node.data.id, (catalogData)=>{ | 
|---|
|  |  |  | channelArray = channelArray.concat(catalogData) | 
|---|
|  |  |  | this.channelDataHandler(channelArray, resolve) | 
|---|
|  |  |  | }, (endCatalogData)=>{ | 
|---|
|  |  |  | this.deviceService.getAllSubChannel(false, node.data.deviceId, node.data.id, (channelData)=>{ | 
|---|
|  |  |  | let data = catalogData.concat(channelData) | 
|---|
|  |  |  | this.channelDataHandler(data, resolve) | 
|---|
|  |  |  | channelArray = channelArray.concat(channelData) | 
|---|
|  |  |  | this.channelDataHandler(channelArray, resolve) | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | let nodeList = [] | 
|---|
|  |  |  | for (let i = 0; i < data.length; i++) { | 
|---|
|  |  |  | let type = 3; | 
|---|
|  |  |  | if (data[i].subCount > 0) { | 
|---|
|  |  |  | if (data[i].subCount > 0 || data[i].parental === 1) { | 
|---|
|  |  |  | type = 2; | 
|---|
|  |  |  | }else if (data[i].ptztype === 1 ) { // 1-球机;2-半球;3-固定枪机;4-遥控枪机 | 
|---|
|  |  |  | type = 4; | 
|---|