From 93a26507f76156fa65aead1515c430688c089e1d Mon Sep 17 00:00:00 2001 From: hanbaoshan <hanbaoshan@aiotlink.com> Date: 星期一, 22 二月 2021 15:49:01 +0800 Subject: [PATCH] 新版目录树样式调试及状态更新调试;朔黄批量导入列表调试;视频检索页面添加处理参数,添加标注接口添加参数;分页器展示优化,默认检索时间调整;转储设备接口调试 --- vue.config.js | 2 src/pages/cameraAccess/index/App.vue | 2 src/components/giantTree/zTree/ztree_v3/jquery.ztree.all.js | 2 src/components/giantTree/zTree/ztree.vue | 4 src/pages/shuohuangMonitorAnalyze/components/searchForVideoAnalyze.vue | 43 ++++++++-- src/pages/cameraAccess/components/CameraInfo.vue | 12 ++ src/pages/shuohuangMonitorAnalyze/components/transferDeviceManage.vue | 136 +++++++++++++++++++++++++-------- src/pages/shuohuangMonitorAnalyze/components/memberManage.vue | 10 +- src/pages/shuohuangMonitorAnalyze/components/videoAnalyze.vue | 1 src/api/shuohuang.ts | 5 + src/components/giantTree/index.vue | 23 +++++ 11 files changed, 189 insertions(+), 51 deletions(-) diff --git a/src/api/shuohuang.ts b/src/api/shuohuang.ts index ac54af1..7b111d0 100644 --- a/src/api/shuohuang.ts +++ b/src/api/shuohuang.ts @@ -144,4 +144,9 @@ export const getDeviceList = ()=>request({ url:'/data/api-c/device/getlst', method: 'get' +}) +export const getDeviceInfoById = (query:any) => request({ + url:'/data/api-c/slot/getlst', + method: 'get', + params: query }) \ No newline at end of file diff --git a/src/components/giantTree/index.vue b/src/components/giantTree/index.vue index 09e5bdc..52a101a 100644 --- a/src/components/giantTree/index.vue +++ b/src/components/giantTree/index.vue @@ -82,7 +82,9 @@ { required: true, message: "璇疯緭鍏ヨ妭鐐瑰悕绉�", trigger: "change" }, { min: 2, max: 10, message: "闀垮害鍦�2鍒�10涓瓧", trigger: "change" } ] - } + }, + evt: {}, + treeId: '', }; }, created() { @@ -241,6 +243,12 @@ this.showDialog = true; }, itemClick(evt, treeId, treeNode) { + debugger + //let itemClickArgs = {evt,treeId}; + this.evt = evt; + this.treeId = treeId; + console.log(evt,treeId) + // sessionStorage.setItem('itemClickArgs',JSON.stringify(itemClickArgs)) this.TreeDataPool.selectedNode = treeNode; this.TreeDataPool.treeType = this.treeName; @@ -253,6 +261,19 @@ this.TreeDataPool.updateZTreeCheckNodes([treeNode]); }, + // itemClick(treeNode) { + // this.TreeDataPool.selectedNode = treeNode; + // this.TreeDataPool.treeType = this.treeName; + + // // 澶氶�� + // if (this.TreeDataPool.multiple) { + // // 鍗曞嚮鏌愪竴涓妭鐐规枃瀛楁椂 鍙栨秷鎵�鏈夊嬀閫夌姸鎬� 鐒跺悗閫変腑鑷韩 + // this.ztreeObj.checkAllNodes(false); + // this.ztreeObj.checkNode(treeNode, true, false, false); + // } + + // this.TreeDataPool.updateZTreeCheckNodes([treeNode]); + // }, itemCheck(evt, treeId, treeNode) { this.TreeDataPool.selectedNode = treeNode; this.TreeDataPool.treeType = this.treeName; diff --git a/src/components/giantTree/zTree/ztree.vue b/src/components/giantTree/zTree/ztree.vue index fc3ba3a..f6f79e0 100644 --- a/src/components/giantTree/zTree/ztree.vue +++ b/src/components/giantTree/zTree/ztree.vue @@ -38,6 +38,7 @@ list: [], ztreeSetting: { view: { + showLine: true, showIcon: true, // default to hide icon addHoverDom: this.addHoverDom, removeHoverDom: this.removeHoverDom @@ -265,7 +266,7 @@ .ztree * { padding: 0; margin: 0; - font-size: 13px; + font-size: 14px; font-family: Verdana, Arial, Helvetica, AppleGothic, sans-serif; } .ztree { @@ -381,6 +382,7 @@ background-attachment: scroll; /* background-image: url("./img/zTreeStandard.png"); */ /* *background-image: url("./img/zTreeStandard.gif"); */ + background-image: url(); *background-image: url(); } diff --git a/src/components/giantTree/zTree/ztree_v3/jquery.ztree.all.js b/src/components/giantTree/zTree/ztree_v3/jquery.ztree.all.js index b191ff7..3b74a68 100644 --- a/src/components/giantTree/zTree/ztree_v3/jquery.ztree.all.js +++ b/src/components/giantTree/zTree/ztree_v3/jquery.ztree.all.js @@ -841,6 +841,7 @@ return true; }, onClickNode: function (event, node) { + debugger var setting = data.getSetting(event.data.treeId), clickFlag = ((setting.view.autoCancelSelected && (event.ctrlKey || event.metaKey)) && data.isSelectedNode(setting, node)) ? 0 : (setting.view.autoCancelSelected && (event.ctrlKey || event.metaKey) && setting.view.selectedMulti) ? 2 : 1; if (tools.apply(setting.callback.beforeClick, [setting.treeId, node, clickFlag], true) == false) return true; @@ -1674,6 +1675,7 @@ } }, selectNode: function (setting, node, addFlag) { + debugger if (!addFlag) { view.cancelPreSelectedNode(setting, null, node); } diff --git a/src/pages/cameraAccess/components/CameraInfo.vue b/src/pages/cameraAccess/components/CameraInfo.vue index 58eee53..72cec9a 100644 --- a/src/pages/cameraAccess/components/CameraInfo.vue +++ b/src/pages/cameraAccess/components/CameraInfo.vue @@ -382,10 +382,11 @@ this.form.sensors = list this.form.resolution_width = Number(this.form.resolution.split("*")[0]) this.form.resolution_height = Number(this.form.resolution.split("*")[1]) - + let _this = this; // 鏇存柊 if (this.form.id !== "") { this.form.areaid = this.TreeDataPool.getParent(this.form.id, this.isGb28182); + console.log(this.TreeDataPool.selectedNode) updateCameraInfo(this.form).then(rsp => { if (rsp.success) { this.$notify({ @@ -393,6 +394,15 @@ message: "鎽勫儚鏈轰俊鎭慨鏀规垚鍔燂紒" }); this.TreeDataPool.fetchTreeData(); + console.log(this.TreeDataPool.selectedNode) + //_this.$root.$children[0].$refs['leftTree'].$refs.tree.ztreeObj.checkNode(_this.TreeDataPool.selectedNode, true, false, false); + //閫変腑淇敼鍚庣殑鑺傜偣 + let {evt,treeId} = _this.$root.$children[0].$refs['leftTree'].$refs.tree; + console.log(evt,treeId) + // this.$nextTick(()=>{ + _this.$root.$children[0].$refs['leftTree'].$refs.tree.itemClick(evt,treeId,_this.TreeDataPool.selectedNode) + // }) + } else { this.selectCamera(this.TreeDataPool.selectedNode); this.$notify({ diff --git a/src/pages/cameraAccess/index/App.vue b/src/pages/cameraAccess/index/App.vue index e843f32..d18f4ca 100644 --- a/src/pages/cameraAccess/index/App.vue +++ b/src/pages/cameraAccess/index/App.vue @@ -4,7 +4,7 @@ <div class="resize-bar"></div> <div class="resize-line"></div> <div class="resize-save"> - <left-nav :appName="app" :height="screenHeight"></left-nav> + <left-nav :appName="app" :height="screenHeight" ref="leftTree"></left-nav> </div> </div> <div class="column-right"> diff --git a/src/pages/shuohuangMonitorAnalyze/components/memberManage.vue b/src/pages/shuohuangMonitorAnalyze/components/memberManage.vue index 2111a3e..bfe6e92 100644 --- a/src/pages/shuohuangMonitorAnalyze/components/memberManage.vue +++ b/src/pages/shuohuangMonitorAnalyze/components/memberManage.vue @@ -221,9 +221,9 @@ </div> <el-table class="thbg" :data="batchImportTableData" fit> <el-table-column type="index" label="搴忓彿"></el-table-column> - <el-table-column prop="filename" label="鏂囦欢鍚嶇О"></el-table-column> - <el-table-column prop="time" label="涓婁紶鏃堕棿"></el-table-column> - <el-table-column prop="state" label="鐘舵��"></el-table-column> + <el-table-column prop="Name" label="鏂囦欢鍚嶇О"></el-table-column> + <el-table-column prop="UploadTime" label="涓婁紶鏃堕棿"></el-table-column> + <el-table-column prop="Status" label="鐘舵��"></el-table-column> </el-table> </div> </el-dialog> @@ -411,6 +411,7 @@ this.$refs['directoryInput'].click(); }, importDirectory () { + let _this = this; //this.$refs['directoryInput'].files //鏂囦欢澶筸ap let formData = new FormData; for (var file in this.$refs['directoryInput'].files) { @@ -420,7 +421,8 @@ uploadDirectory(formData).then(res => { debugger - + _this.batchImportTableData = res.data; + _this.renderMemberTable(); }) }, diff --git a/src/pages/shuohuangMonitorAnalyze/components/searchForVideoAnalyze.vue b/src/pages/shuohuangMonitorAnalyze/components/searchForVideoAnalyze.vue index 10c1de4..2d8b3dd 100644 --- a/src/pages/shuohuangMonitorAnalyze/components/searchForVideoAnalyze.vue +++ b/src/pages/shuohuangMonitorAnalyze/components/searchForVideoAnalyze.vue @@ -124,10 +124,10 @@ </el-select> </div> <div> - <el-select v-model="settle" size="mini"> + <el-select v-model="IsOperate" size="mini" @change="filterSearchData"> <el-option value label="鍏ㄩ儴"></el-option> - <el-option value="1" label="鏈鐞�"></el-option> - <el-option value="2" label="宸插鐞�"></el-option> + <el-option value="0" label="鏈鐞�"></el-option> + <el-option value="1" label="宸插鐞�"></el-option> </el-select> </div> </div> @@ -187,6 +187,7 @@ </el-col> </el-row> <el-pagination + class="pagination-center" background @size-change="handleTabSizeChange" @current-change="handleCurrentChange" @@ -216,6 +217,7 @@ </el-table-column> </el-table> <el-pagination + class="pagination-center" @size-change="handleTableSizeChange" @current-change="handleCurrentChange" :current-page.sync="curTablePage" @@ -256,7 +258,8 @@ CLIP: 'http://', keyword: '', IsFollow: '', - searchTime: [this.$moment(new Date().getTime() - 3600 * 1000 * 24 * 5).format("YYYY-MM-DD HH:mm:ss"), this.$moment(new Date()).format("YYYY-MM-DD HH:mm:ss")], + //searchTime: [this.$moment(new Date().getTime() - 3600 * 1000 * 24 * 5).format("YYYY-MM-DD HH:mm:ss"), this.$moment(new Date()).format("YYYY-MM-DD HH:mm:ss")], + searchTime: [new Date(2020,0,1,0,0,0),new Date(2020,11,31,23,59,59)], curTabPage: 1, curTablePage: 1, tabPageSize: 8, @@ -310,6 +313,7 @@ showAdvance: true, fixedOneLineHeight: 40, settle: '', + IsOperate: '', showType: 'menu', tableData: [ { name: 'SS4B115_06_B鑺備簩绔徃鏈哄_20201115_091500.mp4', size: '17.66M', updateTime: '2020-11-04 15:41', createTime: '2020-11-04 15:41' }, @@ -363,10 +367,11 @@ KeyWord: this.keyword, StartDate: this.searchTime[0], EndDate: this.searchTime[1], - PageIndex: this.showType == 'list' ? this.curTablePage : this.showType == 'list', + PageIndex: this.showType == 'list' ? this.curTablePage : this.curTabPage, PageSize: this.showType == 'list' ? this.tablePageSize : this.tabPageSize, IsDetail: this.showType == 'list', - IsFollow: isFollow + IsFollow: isFollow, + IsOperate: this.IsOperate }; let filterQuerys = []; this.checkedConfigs.forEach(config => { @@ -401,7 +406,8 @@ PageIndex: this.showType == 'list' ? this.curTablePage : this.showType == 'list', PageSize: this.showType == 'list' ? this.tablePageSize : this.tabPageSize, IsDetail: this.showType == 'list', - IsFollow: this.IsFollow + IsFollow: this.IsFollow, + IsOperate: this.IsOperate, }; this.optionalConfigs = []; this.highLevelConfigs = []; @@ -422,6 +428,12 @@ obj.id = config.Node[key] return obj }); + // config.data = config.Node.map((item) => { + // let obj = {}; + // obj.name = item[0]; + // obj.id = item[1]; + // return obj; + // }); config.id = config.ID; config.title = config.NameZn; config.data.forEach(item => { @@ -744,11 +756,20 @@ border-radius: 5px; height: 350px; .video-wrap { - background: aliceblue; border-radius: 3px; + width: 100%; + padding-top: 56.25%; + height: 0; + position: relative; img { + position: absolute; + top: 0; width: 100%; - border-radius: 3px; + height: 100%; + object-fit: contain; + // width: 100%; + // max-height: 200px; + // border-radius: 3px; } } .video-info { @@ -801,6 +822,10 @@ cursor: pointer; } } + .pagination-center{ + text-align: center; + margin: 10px auto; + } } .dialog-video { z-index: 2096 !important; diff --git a/src/pages/shuohuangMonitorAnalyze/components/transferDeviceManage.vue b/src/pages/shuohuangMonitorAnalyze/components/transferDeviceManage.vue index 5429e2b..8921ac0 100644 --- a/src/pages/shuohuangMonitorAnalyze/components/transferDeviceManage.vue +++ b/src/pages/shuohuangMonitorAnalyze/components/transferDeviceManage.vue @@ -1,19 +1,22 @@ <template> <div class="transfer-device-manage"> <div class="header-with-tab"> - <el-tabs v-model="actTab" @tab-click="checkTab" > - <el-tab-pane name="dev1" v-for="tab in devices" :key="tab"> + <el-tabs v-model="actTab" @tab-click="checkTab"> + <el-tab-pane :name="tab.ID" v-for="tab in devices" :key="tab.ID"> <div slot="label" class="label-slot"> <span>{{tab.Name}}</span> - <span class="capsule" :class="{'online':tab.Status==0,'offline':tab.Status==1}">{{tab.Status==0?"鍦ㄧ嚎":"绂荤嚎"}}</span> + <span + class="capsule" + :class="{'online':tab.Status==0,'offline':tab.Status==1}" + >{{tab.Status==0?"鍦ㄧ嚎":"绂荤嚎"}}</span> </div> </el-tab-pane> - <el-tab-pane name="dev2"> + <!-- <el-tab-pane name="dev2"> <div slot="label" class="label-slot"> <span>杞偍璁惧2</span> <span class="capsule offline">绂荤嚎</span> </div> - </el-tab-pane> + </el-tab-pane>--> </el-tabs> <div class="btn-add-dev" @click="showAddDevice"> <i class="el-icon-circle-plus"></i> @@ -31,10 +34,10 @@ :key="indicator.id" > <div class="title"> - <span class="dot"></span> + <span class="dot" :class="{'kx':indicator.id=='kx','dx':indicator.id=='dx','ccgz':indicator.id=='ccgz'}"></span> <span class="word">{{indicator.title}}</span> </div> - <div class="indicator-val">{{indicator.val}}</div> + <div class="indicator-val">{{indicator.slots.length}}</div> </div> </div> <div class="table-area"> @@ -44,7 +47,7 @@ <div> <el-input v-model="deviceAddr" size="small"></el-input> </div> - </div> --> + </div>--> <div> <label>璁惧鐘舵��:</label> <div> @@ -58,8 +61,18 @@ </div> </div> <el-table class="thbg" :data="tableData" fit> - <el-table-column prop="name" label="杞偍璁惧鍚嶇О"></el-table-column> - <el-table-column prop="state" label="璁惧鐘舵��"></el-table-column> + <el-table-column type="index" width="100" label="搴忓彿"></el-table-column> + <el-table-column prop="Name" label="鎻掓Ы鍚嶇О"></el-table-column> + <el-table-column prop="Status" label="鐘舵��"> + <template slot-scope="scope"> + <div> + <span v-if="scope.row.Status==0">绌洪棽涓�</span> + <span v-if="scope.row.Status==1">璇诲啓涓�</span> + <span v-if="scope.row.Status==2">鎻掓Ы鏁呴殰</span> + </div> + </template> + </el-table-column> + <!-- <el-table-column prop="state" label="璁惧鐘舵��"></el-table-column> <el-table-column prop="pic" label="鐜板満鍥剧墖"></el-table-column> <el-table-column prop="addr" label="璁惧鍦板潃"></el-table-column> <el-table-column prop="tel" label="鎶ヤ慨鐢佃瘽"></el-table-column> @@ -69,12 +82,16 @@ <span @click="checkSlot(scope.row)">鏌ョ湅鎻掓Ы</span> </div> </template> - </el-table-column> + </el-table-column>--> </el-table> </div> - <el-dialog :visible="visibleOfialogAddDev"> + <el-dialog + :visible="visibleOfialogAddDev" + title="娣诲姞璁惧" + class="dialog-addDev" + @close="visibleOfialogAddDev = false" + > <div> - <p slot="title">娣诲姞璁惧</p> <div class="flex-box"> <label>璁惧鍚嶇О锛�</label> <el-input v-model="Name"></el-input> @@ -92,53 +109,81 @@ </div> </template> <script> -import {addDevice,getDeviceList} from '@/api/shuohuang'; +import { addDevice, getDeviceList, getDeviceInfoById } from '@/api/shuohuang'; export default { data () { return { actTab: 'dev1', devices: [], - generalIndicators: [{ id: 'gz', title: '鏈夋晠闅滆澶�', val: 156 }, { id: 'zc', title: '姝e父璁惧', val: 5000 }, { id: 'dx', title: '璇诲啓涓�', val: 56 }, { id: 'kx', title: '绌洪棽涓�', val: 2000 }, { id: 'ccgz', title: '鎻掓Ы鏁呴殰', val: 1000 }], + generalIndicators: [{ id: 'dx', title: '璇诲啓涓�', slots: [] }, { id: 'kx', title: '绌洪棽涓�', slots: [] }, { id: 'ccgz', title: '鎻掓Ы鏁呴殰', slots: [] }], deviceAddr: '', deviceState: '', tableData: [], visibleOfialogAddDev: false, - Name:'', - IP:'', + Name: '', + IP: '', } }, - mounted(){ + mounted () { this.findDeviceList(); }, methods: { - findDeviceList (){ - getDeviceList().then(res=>{ - debugger - //_this.devices = + findDeviceList () { + let _this = this; + getDeviceList().then(res => { + _this.devices = res.data; + _this.actTab = _this.devices[0].ID; + _this.findDeviceIfo() }) }, - toAddDevice(){ + findDeviceIfo () { + let _this = this; + getDeviceInfoById({ DeviceID: this.actTab }).then(res => { + debugger + _this.tableData = res.data; + //缁熻褰撳墠鎻掓Ы鐘舵�� + let dx = _this.generalIndicators.find(indicator => indicator.id == 'dx'); + let kx = _this.generalIndicators.find(indicator => indicator.id == 'kx'); + let ccgz = _this.generalIndicators.find(indicator => indicator.id == 'ccgz'); + dx.slots = []; + kx.slots = []; + ccgz.slots = []; + res.data.forEach(slot => { + if (slot.Status == 0) { + kx.slots.push(slot) + } + if (slot.Status == 1) { + dx.slots.push(slot) + } + if (slot.Status == 2) { + ccgz.slots.push(slot) + } + }) + //_this.generalIndicators + }) + }, + toAddDevice () { let _this = this; let params = { Name: this.Name, IP: this.IP } - addDevice(params).then(res=>{ - if(res.success){ + addDevice(params).then(res => { + if (res.success) { this.$notify({ - type:'success', + type: 'success', message: res.msg }) _this.visibleOfialogAddDev = true; } }) }, - showAddDevice(){ + showAddDevice () { this.visibleOfialogAddDev = true; }, checkTab (tab, event) { - + this.findDeviceIfo(); }, checkSlot (row) { @@ -150,7 +195,7 @@ <style lang="scss"> .transfer-device-manage { padding: 20px; - .el-tabs__item{ + .el-tabs__item { height: 45px; line-height: 45px; } @@ -167,17 +212,17 @@ .capsule { width: 42px; height: 20px; - margin-left: 10px; + margin-left: 10px; line-height: 20px; text-align: center; border-radius: 20px; font-size: 12px; font-weight: normal; color: #fff; - &.online{ + &.online { background: #00a854; } - &.offline{ + &.offline { background: #f04134; } } @@ -223,7 +268,13 @@ height: 10px; margin-right: 5px; border-radius: 50%; - background: rgb(94, 14, 243); + background: #01a854; + &.kx { + background: #0f77d1; + } + &.ccgz { + background: #f04235; + } } } .indicator-val { @@ -241,5 +292,24 @@ } } } + .dialog-addDev { + .el-dialog { + width: 600px; + } + .flex-box { + align-items: center; + margin-bottom: 10px; + label { + width: 90px; + text-align: left; + } + .el-input { + width: 500px; + } + } + .btns { + padding: 10px 0; + } + } } </style> \ No newline at end of file diff --git a/src/pages/shuohuangMonitorAnalyze/components/videoAnalyze.vue b/src/pages/shuohuangMonitorAnalyze/components/videoAnalyze.vue index 5cba441..87a6943 100644 --- a/src/pages/shuohuangMonitorAnalyze/components/videoAnalyze.vue +++ b/src/pages/shuohuangMonitorAnalyze/components/videoAnalyze.vue @@ -316,6 +316,7 @@ let query = { ID: this.selectedLabelId, ParentID: this.isCheckAllVideo ? tempArr.join(',') : this.curVideo.ID + '', + ParentUniqID:this.curVideo.UniqeID+ '', Time: Math.round(this.setLabelTime) + '', Codes: this.labelCheckedList.join(','), Desc: desc.join('锛�') diff --git a/vue.config.js b/vue.config.js index e619261..c5faf7a 100644 --- a/vue.config.js +++ b/vue.config.js @@ -87,7 +87,7 @@ } }, "/api-c": { - target: 'http://192.168.20.113:8004', + target: 'http://192.168.20.10:8004', changeOrigin: true }, "/api-v": { -- Gitblit v1.8.0