| | |
| | | <span class="title">{{ config.title }}</span |
| | | > : |
| | | <span class="val" v-for="option in config.data" :key="option.id"> |
| | | <!-- <template> |
| | | <div> |
| | | |
| | | </div> |
| | | </template>--> |
| | | <span v-if="option.isChecked" class="val-show"> |
| | | {{ option.name }} |
| | | <i>、</i> |
| | |
| | | @change="filterSearchData" |
| | | > |
| | | <el-option value label="全部"></el-option> |
| | | <el-option :value="false" label="未关注"></el-option> |
| | | <el-option :value="true" label="已关注"></el-option> |
| | | <el-option :value="'1'" label="未关注"></el-option> |
| | | <el-option :value="'0'" label="已关注"></el-option> |
| | | </el-select> |
| | | </div> |
| | | <div> |
| | |
| | | > |
| | | <div class="card"> |
| | | <div class="video-wrap" @click="checkVideoDetail(data)"> |
| | | <img :src="data.VideoCover" alt /> |
| | | <img :src="data.VideoCover | fixPath" alt /> |
| | | </div> |
| | | <div class="video-info"> |
| | | <div class="base-info"> |
| | |
| | | </div> |
| | | <div class="flex-box"> |
| | | <label>时间:</label> |
| | | <span>{{ data.VideoDate }}</span> |
| | | <span>{{ data.StartTime }}</span> |
| | | </div> |
| | | <div class="flex-box"> |
| | | <label>司机 | 副司机:</label> |
| | |
| | | class="abnormal-label" |
| | | v-for="(label, index) in data.LableLst" |
| | | :key="index" |
| | | >{{ |
| | | > |
| | | {{ |
| | | label.Desc + |
| | | (index == data.LableLst.length - 1 ? "" : ",") |
| | | }}</span |
| | | > |
| | | }} |
| | | </span> |
| | | </div> |
| | | <div v-else> |
| | | <span>无异常</span> |
| | |
| | | <div class="star" @click="toggleFollow(data)"> |
| | | <i |
| | | class="iconfont" |
| | | :class="[data.IsFollow ? 'follow' : '', 'iconguanzhu']" |
| | | :class="[data.IsFollow == '0' ? 'follow' : '', 'iconguanzhu']" |
| | | ></i> |
| | | </div> |
| | | </div> |
| | |
| | | </template> |
| | | </el-table-column> |
| | | |
| | | <el-table-column label="大小" prop="VideoSize" sortable> |
| | | <template slot-scope="scope" style="cursor: pointer"> |
| | | <div> |
| | | {{ Math.round(+scope.row.VideoSize / (1024 * 1024)) + " MB" }} |
| | | </div> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column |
| | | label="大小" |
| | | prop="VideoSize" |
| | | label="视频时间" |
| | | prop="StartTime" |
| | | sortable |
| | | ></el-table-column> |
| | | <el-table-column |
| | | label="修改日期" |
| | | prop="VideoUpdateDate" |
| | | sortable |
| | | ></el-table-column> |
| | | <el-table-column |
| | | label="创建日期" |
| | | prop="VideoCreateDate" |
| | | sortable |
| | | ></el-table-column> |
| | | <!-- <el-table-column label="创建日期" prop="VideoCreateDate" sortable></el-table-column> --> |
| | | |
| | | <el-table-column label="操作"> |
| | | <template slot-scope="scope"> |
| | |
| | | <div class="star"> |
| | | <i |
| | | class="iconfont" |
| | | :class="[scope.row.IsFollow ? 'follow' : '', 'iconguanzhu']" |
| | | :class="[ |
| | | scope.row.IsFollow == '0' ? 'follow' : '', |
| | | 'iconguanzhu', |
| | | ]" |
| | | @click.stop="toggleFollow(scope.row)" |
| | | ></i> |
| | | </div> |
| | | <!-- <i class="el-icon-star-off" @click="toggleFollow(scope.row)"></i> --> |
| | | </div> |
| | | </template> |
| | | </el-table-column> |
| | |
| | | |
| | | v-drag v-resize |
| | | |
| | | --> |
| | | --> |
| | | <!-- <div > --> |
| | | <!-- :modal="false" --> |
| | | <el-dialog v-drag v-resize |
| | | class="dialog-video" |
| | | :visible="videoDialogVisible" |
| | | @close="closeDial" |
| | | :close-on-click-modal="false" |
| | | :destroy-on-close="true" |
| | | :modal-append-to-body="false" |
| | | > |
| | | <div slot="title" class="title"> |
| | | <div class="center"> |
| | | <i class="el-icon-connection"></i> |
| | | <span>播放视频</span> |
| | | </div> |
| | | <!-- :modal="false" --> |
| | | <el-dialog |
| | | v-drag |
| | | v-resize |
| | | class="dialog-video" |
| | | :visible="videoDialogVisible" |
| | | @close="closeDial" |
| | | :close-on-click-modal="false" |
| | | :destroy-on-close="true" |
| | | :modal-append-to-body="false" |
| | | > |
| | | <div slot="title" class="title"> |
| | | <div class="center"> |
| | | <i class="el-icon-connection"></i> |
| | | <span>播放视频</span> |
| | | </div> |
| | | <video-analyze v-if="videoDialogVisible" :videoDetails="selectedVideo" /> |
| | | </el-dialog> |
| | | </div> |
| | | <video-analyze |
| | | v-if="videoDialogVisible" |
| | | :videoDetails="selectedVideo" |
| | | /> |
| | | </el-dialog> |
| | | <!-- </div> --> |
| | | |
| | | <el-dialog |
| | |
| | | <script> |
| | | import { |
| | | getlstInit, |
| | | updateVideoAnalyze, |
| | | updateFollow, |
| | | getlst, |
| | | getRelatedVideoInfo, |
| | | getLabelMap, |
| | | delLabel, |
| | | editLabel, |
| | | getEventVideo, |
| | | } from "@/api/shuohuang"; |
| | | import VideoAnalyze from "./videoAnalyze"; |
| | |
| | | VideoAnalyze, |
| | | EventVideos, |
| | | }, |
| | | filters: { |
| | | fixPath(str) { |
| | | if (!str || str == undefined) { |
| | | return ""; |
| | | } |
| | | |
| | | return str.replace("/opt/vasystem", ""); |
| | | }, |
| | | }, |
| | | data() { |
| | | return { |
| | | CLIP: "http://", |
| | |
| | | IsFollow: "", |
| | | searchTime: [ |
| | | new Date(2020, 0, 1, 0, 0, 0), |
| | | new Date(2020, 11, 31, 23, 59, 59), |
| | | new Date(2021, 11, 31, 23, 59, 59), |
| | | ], |
| | | curTabPage: 1, |
| | | curTablePage: 1, |
| | |
| | | const end = new Date(); |
| | | const start = new Date(); |
| | | start.setTime(start.getTime() - 3600 * 1000 * 24 * 7); |
| | | //start.setHours(0,0,0); |
| | | picker.$emit("pick", [start, end]); |
| | | }, |
| | | }, |
| | |
| | | }, |
| | | methods: { |
| | | checkEventVideo(label) { |
| | | if (label.LKGID != "") { |
| | | this.$message.warning("该事件没有相关联的视频"); |
| | | return; |
| | | } |
| | | |
| | | this.eventDialogVisible = true; |
| | | this.curEventDetail = label; |
| | | let _this = this; |
| | | getEventVideo({ Event: label.Event, LkgID: label.ParentID }).then( |
| | | getEventVideo({ event: label.Event, videoId: label.VideoIds }).then( |
| | | (res) => { |
| | | _this.eventVideoArr = res.data; |
| | | _this.curEvName = label.Event; |
| | | } |
| | | ); |
| | | }, |
| | | closeDial(){ |
| | | this.videoDialogVisible = false |
| | | this.selectedVideo={} |
| | | closeDial() { |
| | | this.videoDialogVisible = false; |
| | | this.selectedVideo = {}; |
| | | }, |
| | | handleTabSizeChange(size) { |
| | | this.tabPageSize = size; |
| | |
| | | //二级查询 |
| | | filterSearchData() { |
| | | let _this = this; |
| | | let isFollow = ""; |
| | | if (this.IsFollow === "") { |
| | | isFollow = ""; |
| | | } else if (!!this.IsFollow) { |
| | | isFollow = "1"; |
| | | } else { |
| | | isFollow = "0"; |
| | | } |
| | | let query = { |
| | | KeyWord: this.keyword, |
| | | StartDate: this.searchTime[0], |
| | |
| | | PageSize: |
| | | this.showType == "list" ? this.tablePageSize : this.tabPageSize, |
| | | IsDetail: this.showType == "list", |
| | | IsFollow: isFollow, |
| | | IsFollow: this.IsFollow , |
| | | IsOperate: this.IsOperate, |
| | | }; |
| | | let filterQuerys = []; |
| | |
| | | }, |
| | | //一级查询 |
| | | init() { |
| | | if (this.checkedConfigs.length) { |
| | | this.filterSearchData() |
| | | return |
| | | } |
| | | let _this = this; |
| | | let query = { |
| | | KeyWord: this.keyword, |
| | |
| | | IsFollow: this.IsFollow, |
| | | IsOperate: this.IsOperate, |
| | | }; |
| | | let filterQuerys = []; |
| | | this.checkedConfigs.forEach((config) => { |
| | | let checkedOpts = config.data.filter((option) => option.isChecked); |
| | | if (checkedOpts.length) { |
| | | var linkOpts = checkedOpts.map((opt) => opt.name); |
| | | linkOpts = linkOpts.join(","); |
| | | let obj = {}; |
| | | obj[config.NameEn] = linkOpts; |
| | | filterQuerys.push(obj); |
| | | } |
| | | }); |
| | | Object.assign(query, ...filterQuerys); |
| | | this.optionalConfigs = []; |
| | | this.highLevelConfigs = []; |
| | | getlstInit(query).then((res) => { |
| | |
| | | return item; |
| | | }); |
| | | } |
| | | |
| | | res.filterlst.forEach((config) => { |
| | | this.$set(config, "isShow", true); |
| | | // config.data = Object.keys(config.Node).map(key => { |
| | | // let obj = {}; |
| | | // obj.name = key; |
| | | // obj.id = config.Node[key] |
| | | // return obj |
| | | // }); |
| | | config.data = config.Node.map((item) => { |
| | | let obj = {}; |
| | | obj.name = item[0]; |
| | |
| | | config.showMore = false; |
| | | } |
| | | }); |
| | | console.log(this.optionalConfigs); |
| | | }); |
| | | }); |
| | | }, |
| | | toggleFollow(data) { |
| | | data.IsFollow = !data.IsFollow; |
| | | this.updataVideo(data); |
| | | if (data.IsFollow) { |
| | | data.IsFollow == "0" ? (data.IsFollow = "1") : (data.IsFollow = "0"); |
| | | updateFollow({ |
| | | id: data.id, |
| | | IsFollow: data.IsFollow, |
| | | }).then((res) => { |
| | | this.$notify({ |
| | | type: "success", |
| | | message: "已添加关注!", |
| | | message: data.IsFollow == "0" ? "已添加关注!" : "已取消关注!", |
| | | }); |
| | | } |
| | | }, |
| | | updataVideo(data) { |
| | | let _this = this; |
| | | updateVideoAnalyze(data).then((res) => { |
| | | //二级查询 |
| | | }); |
| | | }, |
| | | |
| | | checkVideoDetail(data) { |
| | | let _this = this; |
| | | _this.selectedVideo = data; |
| | | _this.videoDialogVisible = true; |
| | | }, |
| | | checkFollow() {}, |
| | | checkType(type) { |
| | | this.showType = type; |
| | | this.filterSearchData(); |
| | |
| | | option.isChecked = true; |
| | | } |
| | | this.checkedConfigs.push(config); |
| | | |
| | | config.isShow = false; |
| | | config.isMultCheck = false; |
| | | if (config.IsAdvanced) { |
| | | this.showAdvance = false; |
| | | } |
| | | // this.$nextTick(() => { |
| | | // this.$set(config, 'isShow', false) |
| | | // }) |
| | | }, |
| | | |
| | | cancleMultCheck(config) { |
| | |
| | | }; |
| | | }, |
| | | resize(el, binding, vnode) { |
| | | const dragDom = el.querySelector('.el-dialog') |
| | | dragDom.style.overflow = 'hidden' |
| | | let minWidth = 400 |
| | | let minHeight = 300 // |
| | | |
| | | // 拉伸 |
| | | let resizeEl = document.createElement('div') |
| | | dragDom.appendChild(resizeEl) // 在弹窗右下角加上一个10-10px的控制块 |
| | | resizeEl.style.cursor = 'nwse-resize' |
| | | // resizeEl.style.cursor = 'se-resize' |
| | | resizeEl.style.position = 'absolute' |
| | | resizeEl.style.height = '12px' |
| | | resizeEl.style.width = '12px' |
| | | resizeEl.style.right = '0px' |
| | | resizeEl.style.bottom = '0px' //鼠标拉伸弹窗 |
| | | resizeEl.style.background = 'url("/images/desktop/resize.png") no-repeat' //鼠标拉伸弹窗 |
| | | const dragDom = el.querySelector(".el-dialog"); |
| | | dragDom.style.overflow = "hidden"; |
| | | let minWidth = 400; |
| | | let minHeight = 300; // |
| | | |
| | | resizeEl.onmousedown = (e) => { |
| | | // 记录初始x位置 |
| | | const clientX = e.clientX // 鼠标按下,计算当前元素距离可视区的距离 |
| | | const disX = e.clientX - resizeEl.offsetLeft |
| | | const disY = e.clientY - resizeEl.offsetTop |
| | | // 拉伸 |
| | | let resizeEl = document.createElement("div"); |
| | | dragDom.appendChild(resizeEl); // 在弹窗右下角加上一个10-10px的控制块 |
| | | resizeEl.style.cursor = "nwse-resize"; |
| | | // resizeEl.style.cursor = 'se-resize' |
| | | resizeEl.style.position = "absolute"; |
| | | resizeEl.style.height = "12px"; |
| | | resizeEl.style.width = "12px"; |
| | | resizeEl.style.right = "0px"; |
| | | resizeEl.style.bottom = "0px"; //鼠标拉伸弹窗 |
| | | resizeEl.style.background = 'url("/images/desktop/resize.png") no-repeat'; //鼠标拉伸弹窗 |
| | | |
| | | document.onmousemove = function(e) { |
| | | e.preventDefault() // 移动时禁用默认事件 // 通过事件委托,计算移动的距离 |
| | | resizeEl.onmousedown = (e) => { |
| | | // 记录初始x位置 |
| | | const clientX = e.clientX; // 鼠标按下,计算当前元素距离可视区的距离 |
| | | const disX = e.clientX - resizeEl.offsetLeft; |
| | | const disY = e.clientY - resizeEl.offsetTop; |
| | | |
| | | const x = e.clientX - disX + (e.clientX - clientX) //这里 由于elementUI的dialog控制居中的,所以水平拉伸效果是双倍 |
| | | const y = e.clientY - disY //比较是否小于最小宽高 |
| | | dragDom.style.width = x > minWidth ? `${x}px` : minWidth + 'px' |
| | | dragDom.style.height = |
| | | y > minHeight ? `${y}px` : minHeight + 'px' |
| | | } //拉伸结束 |
| | | document.onmouseup = function(e) { |
| | | document.onmousemove = null |
| | | document.onmouseup = null |
| | | } |
| | | } |
| | | document.onmousemove = function (e) { |
| | | e.preventDefault(); // 移动时禁用默认事件 通过事件委托,计算移动的距离 |
| | | |
| | | const x = e.clientX - disX + (e.clientX - clientX); //这里 由于elementUI的dialog控制居中的,所以水平拉伸效果是双倍 |
| | | const y = e.clientY - disY; //比较是否小于最小宽高 |
| | | dragDom.style.width = x > minWidth ? `${x}px` : minWidth + "px"; |
| | | dragDom.style.height = y > minHeight ? `${y}px` : minHeight + "px"; |
| | | }; //拉伸结束 |
| | | document.onmouseup = function (e) { |
| | | document.onmousemove = null; |
| | | document.onmouseup = null; |
| | | }; |
| | | }; |
| | | }, |
| | | }, |
| | | }; |
| | |
| | | |
| | | <style lang="scss"> |
| | | .search-for-video-analyze { |
| | | //padding: 20px 30px; |
| | | //出横向滚动条 |
| | | padding: 20px 40px; |
| | | .flex-box { |
| | |
| | | } |
| | | .config-submenu { |
| | | .el-menu--horizontal { |
| | | //max-width: 700px; |
| | | //overflow-x: auto; |
| | | left: 20px !important; |
| | | & > ul { |
| | | flex-wrap: wrap; |
| | |
| | | margin: 0 -30px; |
| | | margin-bottom: -30px; |
| | | padding: 0; |
| | | // .el-row { |
| | | // display: flex; |
| | | // flex-wrap: wrap; |
| | | // } |
| | | .el-table__row { |
| | | cursor: pointer; |
| | | } |
| | |
| | | width: 100%; |
| | | height: 100%; |
| | | object-fit: contain; |
| | | // width: 100%; |
| | | // max-height: 200px; |
| | | // border-radius: 3px; |
| | | } |
| | | } |
| | | .video-info { |
| | |
| | | background: #f5f5f5; |
| | | } |
| | | } |
| | | .el-dialog__wrapper{ |
| | | top: -22px; |
| | | .el-dialog__wrapper { |
| | | top: -22px; |
| | | } |
| | | .dialog-video { |
| | | // z-index: 2020 !important; |
| | | .el-dialog { |
| | | width: 1180px; |
| | | // height: 893px; |
| | | } |
| | | .el-dialog__body { |
| | | background: #eaeaea; |
| | | padding: 0; |
| | | // height: 100%; |
| | | height: inherit; |
| | | |
| | | height: inherit; |
| | | } |
| | | .el-dialog__header { |
| | | padding: 3px; |
| | |
| | | .window-view { |
| | | width: 100%; |
| | | height: auto; |
| | | // height: 100%; |
| | | // min-height: 684px; |
| | | overflow: auto; |
| | | z-index: 2000; |
| | | } |