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