|
@@ -0,0 +1,369 @@
|
|
|
|
+<template>
|
|
|
|
+ <div class="tab5">
|
|
|
|
+ <div class="search">
|
|
|
|
+ <div :class="{ active: topInd === 1 }" @click="topInd = 1">环境情况</div>
|
|
|
|
+ <div :class="{ active: topInd === 2 }" @click="topInd = 2">监控画面</div>
|
|
|
|
+ <div :class="{ active: topInd === 3 }" @click="topInd = 3">进度管理</div>
|
|
|
|
+ </div>
|
|
|
|
+ <!-- 表格1 -->
|
|
|
|
+ <div class="table" v-show="topInd === 1">
|
|
|
|
+ <el-table :data="tableData" border style="width: 100%">
|
|
|
|
+ <el-table-column prop="id" label="序列" width="80"></el-table-column>
|
|
|
|
+ <el-table-column
|
|
|
|
+ prop="type"
|
|
|
|
+ label="栏目类型"
|
|
|
|
+ width="240"
|
|
|
|
+ ></el-table-column>
|
|
|
|
+ <el-table-column prop="conten" label="数据字段"></el-table-column>
|
|
|
|
+ <el-table-column prop="time" label="更新时间" width="200">
|
|
|
|
+ </el-table-column>
|
|
|
|
+ <el-table-column label="操作" width="120">
|
|
|
|
+ <template #default="{ row }">
|
|
|
|
+ <el-button type="text" @click="edit(row.data, row.id)"
|
|
|
|
+ >修 改</el-button
|
|
|
|
+ >
|
|
|
|
+ </template>
|
|
|
|
+ </el-table-column>
|
|
|
|
+ </el-table>
|
|
|
|
+ </div>
|
|
|
|
+ <!-- 表格2 -->
|
|
|
|
+ <div class="table" v-show="topInd === 2">
|
|
|
|
+ <div class="add">
|
|
|
|
+ <el-button type="primary" @click="addVideo">新 增</el-button>
|
|
|
|
+ </div>
|
|
|
|
+ <el-table :data="tableData2" border style="width: 100%">
|
|
|
|
+ <el-table-column label="序列" width="80">
|
|
|
|
+ <template slot-scope="scope">
|
|
|
|
+ {{ scope.$index + (from2.pageNum - 1) * from2.pageSize + 1 }}
|
|
|
|
+ </template>
|
|
|
|
+ </el-table-column>
|
|
|
|
+ <el-table-column prop="name" label="视频名称"></el-table-column>
|
|
|
|
+ <el-table-column prop="lon" label="经度"></el-table-column>
|
|
|
|
+ <el-table-column prop="lat" label="纬度"></el-table-column>
|
|
|
|
+ <el-table-column label="视频封面" width="150">
|
|
|
|
+ <template #default="{ row }">
|
|
|
|
+ <el-image
|
|
|
|
+ style="height: 50px"
|
|
|
|
+ :src="baseURL + row.thumb"
|
|
|
|
+ :preview-src-list="srcList"
|
|
|
|
+ >
|
|
|
|
+ </el-image>
|
|
|
|
+ </template>
|
|
|
|
+ </el-table-column>
|
|
|
|
+ <el-table-column label="视频文件" width="100">
|
|
|
|
+ <template #default="{ row }">
|
|
|
|
+ <a
|
|
|
|
+ :href="baseURL + row.video"
|
|
|
|
+ target="_blank"
|
|
|
|
+ :download="baseURL + row.video"
|
|
|
|
+ class="mydown"
|
|
|
|
+ >下 载</a
|
|
|
|
+ >
|
|
|
|
+ </template>
|
|
|
|
+ </el-table-column>
|
|
|
|
+ <el-table-column label="操作" width="200">
|
|
|
|
+ <template #default="{ row }">
|
|
|
|
+ <el-button type="text" @click="editVideo(row.id)">修 改</el-button>
|
|
|
|
+ <el-button type="text" @click="delTow(row.id)">删 除</el-button>
|
|
|
|
+ </template>
|
|
|
|
+ </el-table-column>
|
|
|
|
+ </el-table>
|
|
|
|
+ </div>
|
|
|
|
+ <!-- 表格3 -->
|
|
|
|
+ <div class="table" v-show="topInd === 3">
|
|
|
|
+ <div class="add">
|
|
|
|
+ <el-button type="primary" @click="addVideoThree">新 增</el-button>
|
|
|
|
+ </div>
|
|
|
|
+ <el-table :data="tableData3" border style="width: 100%">
|
|
|
|
+ <el-table-column label="序列" width="80">
|
|
|
|
+ <template slot-scope="scope">
|
|
|
|
+ {{ scope.$index + (from3.pageNum - 1) * from3.pageSize + 1 }}
|
|
|
|
+ </template>
|
|
|
|
+ </el-table-column>
|
|
|
|
+ <el-table-column prop="year" label="年份"></el-table-column>
|
|
|
|
+ <el-table-column label="进度图片">
|
|
|
|
+ <template #default="{ row }">
|
|
|
|
+ <el-image
|
|
|
|
+ style="height: 50px"
|
|
|
|
+ :src="baseURL + row.thumb"
|
|
|
|
+ :preview-src-list="srcList3"
|
|
|
|
+ >
|
|
|
|
+ </el-image>
|
|
|
|
+ </template>
|
|
|
|
+ </el-table-column>
|
|
|
|
+ <el-table-column label="操作" width="200">
|
|
|
|
+ <template #default="{ row }">
|
|
|
|
+ <el-button type="text" @click="editVideoThree(row.id)"
|
|
|
|
+ >修 改</el-button
|
|
|
|
+ >
|
|
|
|
+ <el-button type="text" @click="delThree(row.id)"
|
|
|
|
+ >删 除</el-button
|
|
|
|
+ >
|
|
|
|
+ </template>
|
|
|
|
+ </el-table-column>
|
|
|
|
+ </el-table>
|
|
|
|
+ </div>
|
|
|
|
+ <!-- 监控画面弹窗 -->
|
|
|
|
+ <Tab5Dialog
|
|
|
|
+ :isShow.sync="isShow"
|
|
|
|
+ @refresh="siteVideoList(from2)"
|
|
|
|
+ ref="Tab5DialogRef"
|
|
|
|
+ />
|
|
|
|
+ <!-- 进度管理弹窗 -->
|
|
|
|
+ <Tab5DialogThree
|
|
|
|
+ :isShow.sync="isShow3"
|
|
|
|
+ @refresh="siteImgList(from3)"
|
|
|
|
+ ref="Tab5DialogThreeRef"
|
|
|
|
+ />
|
|
|
|
+ <!-- 分页 -->
|
|
|
|
+ <div class="paging" v-show="topInd === 2">
|
|
|
|
+ <span class="zong">共 {{ total }} 条</span>
|
|
|
|
+ <el-pagination
|
|
|
|
+ layout="sizes,prev,pager,next,jumper"
|
|
|
|
+ :total="total"
|
|
|
|
+ :page-sizes="[15, 30, 45, 60]"
|
|
|
|
+ :current-page="from2.pageNum"
|
|
|
|
+ @current-change="currentChange"
|
|
|
|
+ @size-change="sizeChange"
|
|
|
|
+ >
|
|
|
|
+ </el-pagination>
|
|
|
|
+ </div>
|
|
|
|
+ <!-- 分页 -->
|
|
|
|
+ <div class="paging" v-show="topInd === 3">
|
|
|
|
+ <span class="zong">共 {{ total3 }} 条</span>
|
|
|
|
+ <el-pagination
|
|
|
|
+ layout="sizes,prev,pager,next,jumper"
|
|
|
|
+ :total="total3"
|
|
|
|
+ :page-sizes="[15, 30, 45, 60]"
|
|
|
|
+ :current-page="from3.pageNum"
|
|
|
|
+ @current-change="currentChange3"
|
|
|
|
+ @size-change="sizeChange3"
|
|
|
|
+ >
|
|
|
|
+ </el-pagination>
|
|
|
|
+ </div>
|
|
|
|
+ </div>
|
|
|
|
+</template>
|
|
|
|
+
|
|
|
|
+<script>
|
|
|
|
+import axios from '@/utils/request'
|
|
|
|
+import Tab5Dialog from '@/components/tab5Dialog.vue'
|
|
|
|
+import Tab5DialogThree from '@/components/Tab5DialogThree.vue'
|
|
|
|
+import { siteList, siteVideoList, siteImgList, videoRemove, imgRemove } from '@/apis/tab5'
|
|
|
|
+export default {
|
|
|
|
+ name: 'tab5',
|
|
|
|
+ components: { Tab5Dialog, Tab5DialogThree },
|
|
|
|
+ data () {
|
|
|
|
+ // 这里存放数据
|
|
|
|
+ return {
|
|
|
|
+ total: 0,
|
|
|
|
+ total3: 0,
|
|
|
|
+ srcList: [], // 查看大图的图片数组合集
|
|
|
|
+ srcList3: [], // 查看大图的图片数组合集
|
|
|
|
+ baseURL: '',
|
|
|
|
+ isShow: false,
|
|
|
|
+ isShow3: false,
|
|
|
|
+ topInd: 1,
|
|
|
|
+ from: {
|
|
|
|
+ pageNum: 1,
|
|
|
|
+ pageSize: 9999,
|
|
|
|
+ searchKey: '',
|
|
|
|
+ type: ''
|
|
|
|
+ },
|
|
|
|
+ from2: {
|
|
|
|
+ pageNum: 1,
|
|
|
|
+ pageSize: 15,
|
|
|
|
+ searchKey: ''
|
|
|
|
+ },
|
|
|
|
+ from3: {
|
|
|
|
+ pageNum: 1,
|
|
|
|
+ pageSize: 15,
|
|
|
|
+ searchKey: ''
|
|
|
|
+ },
|
|
|
|
+ tableData: [],
|
|
|
|
+ tableData2: [],
|
|
|
|
+ tableData3: []
|
|
|
|
+ }
|
|
|
|
+ },
|
|
|
|
+ // 监听属性 类似于data概念
|
|
|
|
+ computed: {},
|
|
|
|
+ // 监控data中的数据变化
|
|
|
|
+ watch: {},
|
|
|
|
+ // 方法集合
|
|
|
|
+ methods: {
|
|
|
|
+ // ----------------------进度管理-----------------------------
|
|
|
|
+ addVideoThree () {
|
|
|
|
+ this.isShow3 = true
|
|
|
|
+ },
|
|
|
|
+ editVideoThree (id) {
|
|
|
|
+ this.$refs.Tab5DialogThreeRef.videoDetailById3(id)
|
|
|
|
+ this.isShow3 = true
|
|
|
|
+ },
|
|
|
|
+ delThree (id) {
|
|
|
|
+ this.$confirm('确定删除吗?', '提示', {
|
|
|
|
+ confirmButtonText: '确定',
|
|
|
|
+ cancelButtonText: '取消',
|
|
|
|
+ type: 'warning'
|
|
|
|
+ })
|
|
|
|
+ .then(async () => {
|
|
|
|
+ await imgRemove(id)
|
|
|
|
+ this.$message.success('删除成功!')
|
|
|
|
+ this.siteImgList(this.from3)
|
|
|
|
+ })
|
|
|
|
+ .catch(() => {
|
|
|
|
+ this.$message.info('已取消删除')
|
|
|
|
+ })
|
|
|
|
+ },
|
|
|
|
+ // 分页器方法
|
|
|
|
+ currentChange3 (val) {
|
|
|
|
+ // console.log('当前页改变了', val)
|
|
|
|
+ this.from3.pageNum = val
|
|
|
|
+ this.siteImgList(this.from3)
|
|
|
|
+ },
|
|
|
|
+ sizeChange3 (val) {
|
|
|
|
+ // console.log('条数改变了', val)
|
|
|
|
+ this.from3.pageNum = 1
|
|
|
|
+ this.from3.pageSize = val
|
|
|
|
+ this.siteImgList(this.from3)
|
|
|
|
+ },
|
|
|
|
+ // ----------------------进度管理-----------------------------
|
|
|
|
+ // 分页器方法
|
|
|
|
+ currentChange (val) {
|
|
|
|
+ // console.log('当前页改变了', val)
|
|
|
|
+ this.from2.pageNum = val
|
|
|
|
+ this.siteVideoList(this.from2)
|
|
|
|
+ },
|
|
|
|
+ sizeChange (val) {
|
|
|
|
+ // console.log('条数改变了', val)
|
|
|
|
+ this.from2.pageNum = 1
|
|
|
|
+ this.from2.pageSize = val
|
|
|
|
+ this.siteVideoList(this.from2)
|
|
|
|
+ },
|
|
|
|
+ // 点击监控画面新增
|
|
|
|
+ addVideo () {
|
|
|
|
+ this.isShow = true
|
|
|
|
+ },
|
|
|
|
+ // 点击安防设备修改
|
|
|
|
+ edit (val, id) {
|
|
|
|
+ this.$router.push({
|
|
|
|
+ path: '/layout/tab5Edit1',
|
|
|
|
+ query: { ...val, id }
|
|
|
|
+ })
|
|
|
|
+ },
|
|
|
|
+ // 监控画面删除
|
|
|
|
+ delTow (id) {
|
|
|
|
+ this.$confirm('确定删除吗?', '提示', {
|
|
|
|
+ confirmButtonText: '确定',
|
|
|
|
+ cancelButtonText: '取消',
|
|
|
|
+ type: 'warning'
|
|
|
|
+ })
|
|
|
|
+ .then(async () => {
|
|
|
|
+ await videoRemove(id)
|
|
|
|
+ this.$message.success('删除成功!')
|
|
|
|
+ this.siteVideoList(this.from2)
|
|
|
|
+ })
|
|
|
|
+ .catch(() => {
|
|
|
|
+ this.$message.info('已取消删除')
|
|
|
|
+ })
|
|
|
|
+ },
|
|
|
|
+ // 点击监控画面修改
|
|
|
|
+ editVideo (id) {
|
|
|
|
+ this.$refs.Tab5DialogRef.videoDetailById(id)
|
|
|
|
+ this.isShow = true
|
|
|
|
+ },
|
|
|
|
+ // 封装获取列表方法
|
|
|
|
+ async siteList (data) {
|
|
|
|
+ const res = await siteList(data)
|
|
|
|
+ res.data.forEach((v) => {
|
|
|
|
+ const temp = {}
|
|
|
|
+ temp.id = v.id
|
|
|
|
+ temp.type = '环境情况'
|
|
|
|
+ temp.data = JSON.parse(v.data)
|
|
|
|
+ temp.time = v.userUpdateTime
|
|
|
|
+ temp.conten = `温度:${temp.data.temp}°--${temp.data.tempScope};湿度:${temp.data.humidity}RH--${temp.data.humidityScope};PM2.5:${temp.data.pm25}个--${temp.data.pm25Scope};PM10:${temp.data.pm10}个;噪音:${temp.data.noise};风速:${temp.data.windSpeed};AIQ:${temp.data.aiq};TSP:${temp.data.tsp}`
|
|
|
|
+ this.tableData.push(temp)
|
|
|
|
+ })
|
|
|
|
+ },
|
|
|
|
+ // 封装获取监控画面列表方法
|
|
|
|
+ async siteVideoList (data) {
|
|
|
|
+ this.srcList = []
|
|
|
|
+ const res = await siteVideoList(data)
|
|
|
|
+ this.total = res.data.total
|
|
|
|
+ this.tableData2 = res.data.records
|
|
|
|
+ this.tableData2.forEach((v) => {
|
|
|
|
+ this.srcList.push(this.baseURL + v.thumb)
|
|
|
|
+ })
|
|
|
|
+ // console.log(998, res)
|
|
|
|
+ },
|
|
|
|
+ // 封装获取进度管理列表方法
|
|
|
|
+ async siteImgList (data) {
|
|
|
|
+ this.srcList = []
|
|
|
|
+ const res = await siteImgList(data)
|
|
|
|
+ this.total3 = res.data.total
|
|
|
|
+ this.tableData3 = res.data.records
|
|
|
|
+ this.tableData3.forEach((v) => {
|
|
|
|
+ this.srcList3.push(this.baseURL + v.thumb)
|
|
|
|
+ })
|
|
|
|
+ // console.log(998, res)
|
|
|
|
+ }
|
|
|
|
+ },
|
|
|
|
+ // 生命周期 - 创建完成(可以访问当前this实例)
|
|
|
|
+ created () {
|
|
|
|
+ // 获取服务器前缀地址
|
|
|
|
+ this.baseURL = axios.defaults.baseURL
|
|
|
|
+ this.siteList(this.from)
|
|
|
|
+ this.siteVideoList(this.from2)
|
|
|
|
+ this.siteImgList(this.from3)
|
|
|
|
+ },
|
|
|
|
+ // 生命周期 - 挂载完成(可以访问DOM元素)
|
|
|
|
+ mounted () {},
|
|
|
|
+ beforeCreate () {}, // 生命周期 - 创建之前
|
|
|
|
+ beforeMount () {}, // 生命周期 - 挂载之前
|
|
|
|
+ beforeUpdate () {}, // 生命周期 - 更新之前
|
|
|
|
+ updated () {}, // 生命周期 - 更新之后
|
|
|
|
+ beforeDestroy () {}, // 生命周期 - 销毁之前
|
|
|
|
+ destroyed () {}, // 生命周期 - 销毁完成
|
|
|
|
+ activated () {} // 如果页面有keep-alive缓存功能,这个函数会触发
|
|
|
|
+}
|
|
|
|
+</script>
|
|
|
|
+<style lang='less' scoped>
|
|
|
|
+.tab5 {
|
|
|
|
+
|
|
|
|
+ /deep/.el-table__body-wrapper {
|
|
|
|
+ max-height: 600px;
|
|
|
|
+ overflow-y: auto;
|
|
|
|
+ }
|
|
|
|
+ .search {
|
|
|
|
+ display: flex;
|
|
|
|
+ font-size: 24px;
|
|
|
|
+ margin-bottom: 30px;
|
|
|
|
+ & > div {
|
|
|
|
+ cursor: pointer;
|
|
|
|
+ margin-right: 40px;
|
|
|
|
+ }
|
|
|
|
+ .active {
|
|
|
|
+ font-weight: 700;
|
|
|
|
+ border-bottom: 5px solid #1482b4;
|
|
|
|
+ padding-bottom: 10px;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ .table {
|
|
|
|
+ position: relative;
|
|
|
|
+ .add {
|
|
|
|
+ position: absolute;
|
|
|
|
+ right: 0;
|
|
|
|
+ top: -50px;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ .paging {
|
|
|
|
+ width: auto;
|
|
|
|
+ display: flex;
|
|
|
|
+ position: absolute;
|
|
|
|
+ bottom: 40px;
|
|
|
|
+ right: 50px;
|
|
|
|
+ .zong {
|
|
|
|
+ margin-right: 20px;
|
|
|
|
+ margin-top: 4px;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+}
|
|
|
|
+</style>
|