新版目录树样式调试及状态更新调试;朔黄批量导入列表调试;视频检索页面添加处理参数,添加标注接口添加参数;分页器展示优化,默认检索时间调整;转储设备接口调试
| | |
| | | url:'/data/api-c/device/getlst', |
| | | method: 'get' |
| | | }) |
| | | export const getDeviceInfoById = (query:any) => request({ |
| | | url:'/data/api-c/slot/getlst', |
| | | method: 'get', |
| | | params: query |
| | | }) |
| | |
| | | { required: true, message: "请输入节点名称", trigger: "change" }, |
| | | { min: 2, max: 10, message: "长度在2到10个字", trigger: "change" } |
| | | ] |
| | | } |
| | | }, |
| | | evt: {}, |
| | | treeId: '', |
| | | }; |
| | | }, |
| | | created() { |
| | |
| | | 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; |
| | | |
| | |
| | | |
| | | 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; |
| | |
| | | list: [], |
| | | ztreeSetting: { |
| | | view: { |
| | | showLine: true, |
| | | showIcon: true, // default to hide icon |
| | | addHoverDom: this.addHoverDom, |
| | | removeHoverDom: this.removeHoverDom |
| | |
| | | .ztree * { |
| | | padding: 0; |
| | | margin: 0; |
| | | font-size: 13px; |
| | | font-size: 14px; |
| | | font-family: Verdana, Arial, Helvetica, AppleGothic, sans-serif; |
| | | } |
| | | .ztree { |
| | |
| | | background-attachment: scroll; |
| | | /* background-image: url("./img/zTreeStandard.png"); */ |
| | | /* *background-image: url("./img/zTreeStandard.gif"); */ |
| | | |
| | | background-image: url(); |
| | | *background-image: url(); |
| | | } |
| | |
| | | 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; |
| | |
| | | } |
| | | }, |
| | | selectNode: function (setting, node, addFlag) { |
| | | debugger |
| | | if (!addFlag) { |
| | | view.cancelPreSelectedNode(setting, null, node); |
| | | } |
| | |
| | | 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({ |
| | |
| | | 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({ |
| | |
| | | <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"> |
| | |
| | | </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> |
| | |
| | | this.$refs['directoryInput'].click(); |
| | | }, |
| | | importDirectory () { |
| | | let _this = this; |
| | | //this.$refs['directoryInput'].files //文件夹map |
| | | let formData = new FormData; |
| | | for (var file in this.$refs['directoryInput'].files) { |
| | |
| | | |
| | | uploadDirectory(formData).then(res => { |
| | | debugger |
| | | |
| | | _this.batchImportTableData = res.data; |
| | | _this.renderMemberTable(); |
| | | }) |
| | | }, |
| | | |
| | |
| | | </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> |
| | |
| | | </el-col> |
| | | </el-row> |
| | | <el-pagination |
| | | class="pagination-center" |
| | | background |
| | | @size-change="handleTabSizeChange" |
| | | @current-change="handleCurrentChange" |
| | |
| | | </el-table-column> |
| | | </el-table> |
| | | <el-pagination |
| | | class="pagination-center" |
| | | @size-change="handleTableSizeChange" |
| | | @current-change="handleCurrentChange" |
| | | :current-page.sync="curTablePage" |
| | |
| | | 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, |
| | |
| | | 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' }, |
| | |
| | | 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 => { |
| | |
| | | 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 = []; |
| | |
| | | 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 => { |
| | |
| | | border-radius: 5px; |
| | | height: 350px; |
| | | .video-wrap { |
| | | background: aliceblue; |
| | | border-radius: 3px; |
| | | img { |
| | | width: 100%; |
| | | border-radius: 3px; |
| | | padding-top: 56.25%; |
| | | height: 0; |
| | | position: relative; |
| | | img { |
| | | position: absolute; |
| | | top: 0; |
| | | width: 100%; |
| | | height: 100%; |
| | | object-fit: contain; |
| | | // width: 100%; |
| | | // max-height: 200px; |
| | | // border-radius: 3px; |
| | | } |
| | | } |
| | | .video-info { |
| | |
| | | cursor: pointer; |
| | | } |
| | | } |
| | | .pagination-center{ |
| | | text-align: center; |
| | | margin: 10px auto; |
| | | } |
| | | } |
| | | .dialog-video { |
| | | z-index: 2096 !important; |
| | |
| | | <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-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> |
| | |
| | | :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"> |
| | |
| | | </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> |
| | |
| | | <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> |
| | |
| | | </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: '正常设备', 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: [], |
| | |
| | | }, |
| | | methods: { |
| | | findDeviceList (){ |
| | | let _this = this; |
| | | getDeviceList().then(res=>{ |
| | | _this.devices = res.data; |
| | | _this.actTab = _this.devices[0].ID; |
| | | _this.findDeviceIfo() |
| | | }) |
| | | }, |
| | | findDeviceIfo () { |
| | | let _this = this; |
| | | getDeviceInfoById({ DeviceID: this.actTab }).then(res => { |
| | | debugger |
| | | //_this.devices = |
| | | _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(){ |
| | |
| | | |
| | | }, |
| | | checkTab (tab, event) { |
| | | |
| | | this.findDeviceIfo(); |
| | | }, |
| | | checkSlot (row) { |
| | | |
| | |
| | | height: 10px; |
| | | margin-right: 5px; |
| | | border-radius: 50%; |
| | | background: rgb(94, 14, 243); |
| | | background: #01a854; |
| | | &.kx { |
| | | background: #0f77d1; |
| | | } |
| | | &.ccgz { |
| | | background: #f04235; |
| | | } |
| | | } |
| | | } |
| | | .indicator-val { |
| | |
| | | } |
| | | } |
| | | } |
| | | .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> |
| | |
| | | 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(',') |
| | |
| | | } |
| | | }, |
| | | "/api-c": { |
| | | target: 'http://192.168.20.113:8004', |
| | | target: 'http://192.168.20.10:8004', |
| | | changeOrigin: true |
| | | }, |
| | | "/api-v": { |