From b20332f8302295b93b55bf5f29cc5d639aa67600 Mon Sep 17 00:00:00 2001
From: batman <978517621@qq.com>
Date: 星期四, 09 三月 2023 10:16:16 +0800
Subject: [PATCH] 新修改添加页面
---
src/views/specialWorkSystem/specialIndex/index.vue | 275 +++++++++++++++++-
src/assets/spwbg.png | 0
src/api/specialWorkSystem/specialIndex/index.ts | 12
src/views/intellectInspect/inspectIndex2/index.vue | 570 ++++++++++++++++++++++---------------
4 files changed, 604 insertions(+), 253 deletions(-)
diff --git a/src/api/specialWorkSystem/specialIndex/index.ts b/src/api/specialWorkSystem/specialIndex/index.ts
new file mode 100644
index 0000000..5bb9c3f
--- /dev/null
+++ b/src/api/specialWorkSystem/specialIndex/index.ts
@@ -0,0 +1,12 @@
+import request from '/@/utils/request';
+
+export function specialIndexApi() {
+ return {
+ analyseType: (startTime: string | null,endTime: string | null,depId: number | null) => {
+ return request({
+ url: import.meta.env.VITE_API_URL + `specialWork/analyse/everyType/dep?startTime=${startTime == null ? null : startTime}&endTime=${endTime == null ? null : endTime}&depId=${depId == null ? null : depId}`,
+ method: 'get'
+ });
+ }
+ };
+}
diff --git a/src/assets/spwbg.png b/src/assets/spwbg.png
new file mode 100644
index 0000000..a8445d9
--- /dev/null
+++ b/src/assets/spwbg.png
Binary files differ
diff --git a/src/views/intellectInspect/inspectIndex2/index.vue b/src/views/intellectInspect/inspectIndex2/index.vue
index 83c0fd9..00200da 100644
--- a/src/views/intellectInspect/inspectIndex2/index.vue
+++ b/src/views/intellectInspect/inspectIndex2/index.vue
@@ -1,5 +1,19 @@
<template>
- <div class="home-container">
+ <div class="home-container" :class="isFull==true?'container':''" id="bigScreen">
+ <div class="full">
+ <el-button v-if="isFull==false" type="text" style="height: 34px" @click="toFullscreen">
+ <el-icon style="vertical-align: middle">
+ <FullScreen />
+ </el-icon>
+ <span style="vertical-align: middle">全屏</span>
+ </el-button>
+ <el-button v-else type="text" style="height: 34px" @click="toFullscreen">
+ <el-icon style="vertical-align: middle">
+ <Close />
+ </el-icon>
+ <span style="vertical-align: middle">退出全屏</span>
+ </el-button>
+ </div>
<div style="height: 100%">
<div class="topChart">
<div class="chart-item">
@@ -64,54 +78,54 @@
</div>
</div>
<div class="chart">
-<!-- <el-table :data="tableData" style="width: 100%" stripe border>-->
-<!-- <el-table-column label="任务信息" align="center">-->
-<!-- <template #default="scope">-->
-<!-- <div class="left-info">-->
-<!-- <span>{{ scope.row.taskName }},</span>-->
-<!-- <p v-if="scope.row.execUserName == null">该任务暂无人认领</p>-->
-<!-- <p v-else>-->
-<!-- <span class="time">{{ scope.row.taskStatus == 2 ? scope.row.startTime : scope.row.endTime }}</span>由<span class="name">{{ scope.row.execUserName }}</span>进行的巡检任务-->
-<!-- </p>-->
-<!-- </div>-->
-<!-- </template>-->
-<!-- </el-table-column>-->
-<!-- <el-table-column prop="taskStatus" label="任务状态" align="center" width="180">-->
-<!-- <template #default="scope">-->
-<!-- <span :class="scope.row.taskStatus == 1 ? 'grey' : scope.row.taskStatus == 2 ? 'green' : scope.row.taskStatus == 3 ? 'blue' : 'red'">{{ scope.row.taskStatus == 1 ? '待巡检' : scope.row.taskStatus == 2 ? '巡检中' : scope.row.taskStatus == 3 ? '已巡检' : '超期未巡检' }}</span>-->
-<!-- </template>-->
-<!-- </el-table-column>-->
-<!-- <el-table-column label="操作" align="center" width="180">-->
-<!-- <template #default="scope">-->
-<!-- <el-button type="text" v-if="scope.row.taskStatus == 2" @click="toLine(scope.row)" class="checkBtn">查看实时巡检</el-button>-->
-<!-- <el-button type="text" v-else class="reviewBtn" @click="toDetails('查看', scope.row)">查看巡检记录</el-button>-->
-<!-- </template>-->
-<!-- </el-table-column>-->
-<!-- </el-table>-->
- <div class="list">
- <div class="list-tit">
- <span class="w60">任务信息</span>
- <span class="w20">任务状态</span>
- <span class="w20">操作</span>
- </div>
- <div class="cardTop" v-for="(item, index) in tableData" :key="index">
- <div class="l-info">
- <span class="place">{{ item.taskName }},</span>
- <p v-if="item.execUserName == null">该任务暂无人认领</p>
- <p v-else>
- <span class="time">{{ item.taskStatus == 2 ? item.startTime : item.endTime }}</span>由<span class="name">{{ item.execUserName }}</span
- >进行的巡检任务
- </p>
- </div>
- <div class="m-info">
- 任务状态:<span :class="item.taskStatus == 1 ? 'grey' : item.taskStatus == 2 ? 'green' : item.taskStatus == 3 ? 'blue' : 'red'">{{ item.taskStatus == 1 ? '待巡检' : item.taskStatus == 2 ? '巡检中' : item.taskStatus == 3 ? '已巡检' : '超期未巡检' }}</span>
- </div>
- <div class="r-info">
- <el-button type="text" v-if="item.taskStatus == 2" @click="toLine(item)" size="small">查看实时巡检</el-button>
- <el-button type="text" v-else class="reviewBtn" @click="toDetails('查看', item)" size="small">查看巡检记录</el-button>
- </div>
- </div>
- </div>
+ <el-table :data="tableData" stripe border :header-cell-style="isFull==true?{background: none}:{ background: '#fafafa' }">
+ <el-table-column label="任务信息" align="center">
+ <template #default="scope">
+ <div class="left-info">
+ <span>{{ scope.row.taskName }},</span>
+ <p v-if="scope.row.execUserName == null">该任务暂无人认领</p>
+ <p v-else>
+ <span class="time">{{ scope.row.taskStatus == 2 ? scope.row.startTime : scope.row.endTime }}</span>由<span class="name">{{ scope.row.execUserName }}</span>进行的巡检任务
+ </p>
+ </div>
+ </template>
+ </el-table-column>
+ <el-table-column prop="taskStatus" label="任务状态" align="center" width="180">
+ <template #default="scope">
+ <span :class="scope.row.taskStatus == 1 ? 'grey' : scope.row.taskStatus == 2 ? 'green' : scope.row.taskStatus == 3 ? 'blue' : 'red'">{{ scope.row.taskStatus == 1 ? '待巡检' : scope.row.taskStatus == 2 ? '巡检中' : scope.row.taskStatus == 3 ? '已巡检' : '超期未巡检' }}</span>
+ </template>
+ </el-table-column>
+ <el-table-column label="操作" align="center" width="180">
+ <template #default="scope">
+ <el-button type="text" size="small" v-if="scope.row.taskStatus == 2" @click="toLine(scope.row)" class="checkBtn">查看实时巡检</el-button>
+ <el-button type="text" size="small" v-else class="reviewBtn" @click="toDetails('查看', scope.row)">查看巡检记录</el-button>
+ </template>
+ </el-table-column>
+ </el-table>
+<!-- <div class="list">-->
+<!-- <div class="list-tit">-->
+<!-- <span class="w60">任务信息</span>-->
+<!-- <span class="w20">任务状态</span>-->
+<!-- <span class="w20">操作</span>-->
+<!-- </div>-->
+<!-- <div class="cardTop" v-for="(item, index) in tableData" :key="index">-->
+<!-- <div class="l-info">-->
+<!-- <span class="place">{{ item.taskName }},</span>-->
+<!-- <p v-if="item.execUserName == null">该任务暂无人认领</p>-->
+<!-- <p v-else>-->
+<!-- <span class="time">{{ item.taskStatus == 2 ? item.startTime : item.endTime }}</span>由<span class="name">{{ item.execUserName }}</span-->
+<!-- >进行的巡检任务-->
+<!-- </p>-->
+<!-- </div>-->
+<!-- <div class="m-info">-->
+<!-- 任务状态:<span :class="item.taskStatus == 1 ? 'grey' : item.taskStatus == 2 ? 'green' : item.taskStatus == 3 ? 'blue' : 'red'">{{ item.taskStatus == 1 ? '待巡检' : item.taskStatus == 2 ? '巡检中' : item.taskStatus == 3 ? '已巡检' : '超期未巡检' }}</span>-->
+<!-- </div>-->
+<!-- <div class="r-info">-->
+<!-- <el-button type="text" v-if="item.taskStatus == 2" @click="toLine(item)" size="small">查看实时巡检</el-button>-->
+<!-- <el-button type="text" v-else class="reviewBtn" @click="toDetails('查看', item)" size="small">查看巡检记录</el-button>-->
+<!-- </div>-->
+<!-- </div>-->
+<!-- </div>-->
<!-- <div class="pageBtn">-->
<!-- <el-pagination v-model:currentPage="pageIndex" v-model:page-size="pageSize" :page-sizes="[10, 15]" small="false" background layout="total, sizes, prev, pager, next, jumper" :total="totalSize" @size-change="handleSizeChange" @current-change="handleCurrentChange" />-->
<!-- </div>-->
@@ -127,39 +141,25 @@
</div>
</div>
<div class="chart">
- <div class="list">
- <div class="list-tit">
- <span class="w10">工单编号</span>
- <span class="w10">异常巡检点</span>
- <span class="w10">巡检(发现)时间</span>
- <span class="w10">所属巡检任务</span>
- <span class="w10">设备/区域名称</span>
- <span class="w10">正常参考值</span>
- <span class="w10">实际巡检值</span>
- <span class="w10">隐患处置人</span>
- <span class="w10">电话</span>
- <span class="w10">处置状态</span>
- <span class="w10">处置描述反馈</span>
- <span class="w15">操作</span>
- </div>
- <div class="cardTop" v-for="(item, index) in unusualData" :key="index">
- <span class="w10">{{item.num}}</span>
- <span class="w10">{{item.spot}}</span>
- <span class="w10">{{item.time}}</span>
- <span class="w10">{{item.job}}</span>
- <span class="w10">{{item.area}}</span>
- <span class="w10">{{item.refer}}</span>
- <span class="w10">{{item.real}}</span>
- <span class="w10">{{item.name}}</span>
- <span class="w10">{{item.phone}}</span>
- <span class="w10">{{item.status}}</span>
- <span class="w10">{{item.describe}}</span>
- <span class="w15">
- <el-button type="text" @click="toLine(item)" size="small">验收</el-button>
- <el-button type="text" @click="toPhotos('查看', item)" size="small">查看现场照片</el-button>
- </span>
- </div>
- </div>
+ <el-table :data="unusualData" stripe border :header-cell-style="isFull==true?{background: none}:{ background: '#fafafa' }">
+ <el-table-column prop="num" label="工单编号" align="center"/>
+ <el-table-column prop="spot" label="异常巡检点" align="center"/>
+ <el-table-column prop="time" label="巡检(发现)时间" align="center"/>
+ <el-table-column prop="job" label="所属巡检任务" align="center"/>
+ <el-table-column prop="area" label="设备/区域名称" align="center"/>
+ <el-table-column prop="refer" label="正常参考值" align="center"/>
+ <el-table-column prop="real" label="实际巡检值" align="center"/>
+ <el-table-column prop="name" label="隐患处置人" align="center"/>
+ <el-table-column prop="phone" label="电话" align="center"/>
+ <el-table-column prop="status" label="处置状态" align="center"/>
+ <el-table-column prop="describe" label="处置描述反馈" align="center"/>
+ <el-table-column label="操作" align="center" width="180" fixed="right">
+ <template #default="scope">
+ <el-button type="text" size="small" class="checkBtn">验收</el-button>
+ <el-button type="text" size="small" class="reviewBtn">查看现场照片</el-button>
+ </template>
+ </el-table-column>
+ </el-table>
<!-- <div class="pageBtn">-->
<!-- <el-pagination v-model:currentPage="pageIndex" v-model:page-size="pageSize" :page-sizes="[10, 15]" small="false" background layout="total, sizes, prev, pager, next, jumper" :total="totalSize" @size-change="handleSizeChange" @current-change="handleCurrentChange" />-->
<!-- </div>-->
@@ -189,6 +189,7 @@
import inspectList from './components/inspectList.vue';
import unusualList from './components/unusualList.vue';
import { departmentApi } from '/@/api/systemManage/department';
+import screenfull from "screenfull";
// 定义接口来定义对象的类型
interface stateType {
tableData: Array<string>;
@@ -207,7 +208,9 @@
quotaList: [];
inspectPointAllList: [];
chartStatus:boolean;
- period: string
+ period: string;
+ isFull:boolean;
+ themeColor:string
}
interface type {
id: number;
@@ -225,8 +228,10 @@
const xjLine = ref("eChartXjLine" + Date.now() + Math.random())
const sbtj = ref("eChartSbtj" + Date.now() + Math.random())
const state = reactive<stateType>({
+ isFull: false,
+ themeColor: '#333',
pageIndex: 1,
- pageSize: 4,
+ pageSize: 5,
totalSize: 0,
tableData: [],
unusualData: [
@@ -323,6 +328,23 @@
initXjLine()
initSbtj()
});
+ const toFullscreen =()=>{
+ state.isFull = !state.isFull
+ if(state.isFull == true){
+ state.themeColor = '#11FEEE'
+ }else{
+ state.themeColor = '#333'
+ }
+ initXjLine()
+ initSbtj()
+ console.log(state.isFull,'quanp',state.themeColor)
+ const element = document.getElementById('bigScreen')
+ if (!screenfull.isEnabled) {
+ ElMessage.warning('暂不不支持全屏');
+ return false;
+ }
+ screenfull.toggle(element);
+ }
const checkAllRecord =()=>{
inspectListRef.value.departmentList = state.departmentList
inspectListRef.value.showInspectList()
@@ -346,7 +368,12 @@
height: '15%',
top: 0,
bottom: 0,
- padding:[1,1,1,0]
+ padding:[1,1,1,0],
+ textStyle: {
+ // 设置默认的文字颜色
+ color: state.themeColor,
+ fontSize: 12
+ },
},
grid: {
top: '15%',
@@ -363,7 +390,10 @@
xAxis: {
type: 'category',
boundaryGap: false,
- data: ['四月', '五月', '六月', '七月', '八月', '九月', '十月', '十一月', '十二月', '一月', '二月', '三月']
+ data: ['四月', '五月', '六月', '七月', '八月', '九月', '十月', '十一月', '十二月', '一月', '二月', '三月'],
+ axisLabel: {
+ color: state.themeColor
+ }
},
yAxis: {
type: 'value'
@@ -428,7 +458,15 @@
legend: {
orient: 'vertical',
left: 'left',
- top: 'center'
+ top: 'center',
+ textStyle: {
+ // 设置默认的文字颜色
+ color: state.themeColor,
+ fontSize: 12
+ },
+ itemStyle: {
+ borderWidth: 0 // 设置图例边框宽度为0
+ }
},
series: [
{
@@ -557,6 +595,7 @@
inspectRecordDialogRef,
inspectListRef,
unusualListRef,
+ toFullscreen,
checkAllRecord,
checkAllList,
toLine,
@@ -586,7 +625,14 @@
height: calc(100vh - 144px);
box-sizing: border-box;
overflow: hidden;
-
+ .full{
+ position:fixed;
+ height: 34px;
+ line-height: 34px;
+ top: 80px;
+ right: 20px;
+ z-index: 99999;
+ }
.topChart{
width: 100%;
height: calc((100% - 40px) / 3);
@@ -731,168 +777,56 @@
height: 100% !important;
:deep(.el-table__inner-wrapper){
height: 100% !important;
- .el-table__header-wrapper{
+ .el-table__header-wrapper {
height: 20% !important;
+ .el-table__header{
+ height: 100% !important;
+ th{
+ height: 100% !important;
+ padding: 0 0 !important;
+ .cell{
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
+ }
+ }
+ }
}
- .el-table__body-wrapper{
+ .el-table__body-wrapper {
height: 80% !important;
.el-scrollbar__view{
height: 100% !important;
.el-table__body{
height: 100% !important;
-
- .el-table__row{
- height: 20% !important;
+ tbody{
+ height: 100% !important;
+ .el-table__row{
+ height: 25% !important;
+ td{
+ height: 25% !important;
+ padding: 0 0 !important;
+ .left-info{
+ display: flex;
+ align-items: center;
+ }
+ .cell{
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
+ }
+ .el-button{
+ padding: 0 !important;
+ }
+ }
+ }
}
}
}
+
}
}
}
- .list {
- height: 100%;
- margin-top: 10px;
- border: 1px solid #ebeef5;
- .list-tit{
- width: 100%;
- height: 20%;
- display: flex;
- align-items: center;
- border-bottom: 1px solid #ebeef5;
-
- span{
- text-align: center;
- padding: 10px 0;
- }
-
- .w60{
- width: 60%;
- border-right: 1px solid #ebeef5;
- }
- .w20{
- width: 20%;
- border-right: 1px solid #ebeef5;
-
- &:last-of-type{
- border-right: none;
- }
- }
- .w15{
- width: 15%;
- border-right: 1px solid #ebeef5;
- text-align: center;
- white-space: nowrap;
- overflow: hidden;
- text-overflow: ellipsis;
- }
- .w10{
- width: 10%;
- border-right: 1px solid #ebeef5;
- text-align: center;
- white-space: nowrap;
- overflow: hidden;
- text-overflow: ellipsis;
- }
- }
-
- .cardTop {
- display: flex;
- width: 100%;
- height: 20%;
- align-items: center;
- border-bottom: 1px solid #ebeef5;
-
- &:last-of-type{
- border-bottom: none;
- }
- span{
- text-align: center;
- padding: 10px 0;
- }
- .l-info{
- width: 60%;
- height: 100%;
- border-right: 1px solid #ebeef5;
- display: flex;
- align-items: center;
- padding: 0 20px;
-
- .num {
- font-weight: bolder;
- margin-right: 10px;
- }
- .place {
- font-weight: bolder;
- }
- .time {
- font-weight: bolder;
- margin-right: 5px;
- }
- .name {
- font-weight: bolder;
- margin: 0 5px;
- font-weight: bolder;
- }
- }
- .m-info{
- height: 100%;
- width: 20%;
- display: flex;
- align-items: center;
- border-right: 1px solid #ebeef5;
- justify-content: center;
-
- span {
- font-weight: bolder;
- }
-
- .grey {
- color: #999;
- }
- .green {
- color: #44b100;
- }
- .blue {
- color: #409eff;
- }
- .red {
- color: red;
- }
- }
- .r-info{
- width: 20%;
- text-align: center;
-
- .reviewBtn {
- color: #44b100;
- }
- }
- .w10{
- width: 10%;
- border-right: 1px solid #ebeef5;
- text-align: center;
- white-space: nowrap;
- overflow: hidden;
- text-overflow: ellipsis;
- }
- .w15{
- width: 15%;
- border-right: 1px solid #ebeef5;
- text-align: center;
- white-space: nowrap;
- overflow: hidden;
- text-overflow: ellipsis;
- .el-button{
- margin-left: 0 !important;
- padding: 12px 0;
- &:last-of-type{
- margin-left: 12px !important;
- }
- }
- }
- }
- }
.pageBtn {
position: absolute;
bottom: 15px;
@@ -926,6 +860,170 @@
}
}
}
+.container{
+ padding: 20px;
+ background: url('../../../assets/spwbg.png') no-repeat center;
+
+ .full{
+ position:fixed;
+ background: #fff;
+ border-radius: 17px;
+ box-shadow: 3px 3px 12px rgba(0,0,0,.2);
+ height: 34px;
+ line-height: 34px;
+ top: 0;
+ right: 20px;
+ z-index: 99999;
+ }
+ .topChart{
+ .chart-item{
+ border-radius: 4px;
+ background: rgba(8, 109, 209, 0.2);
+ border: 1px solid rgba(54, 252, 252, .6);
+ backdrop-filter: blur(5px);
+ position: relative;
+ z-index: 2;
+ &:last-of-type{
+ position: relative;
+ z-index: 1;
+ }
+ .el-radio.is-bordered.is-checked{
+ border-color: #11FEEE !important;
+ :deep(.el-radio__inner){
+ border-color: #11FEEE !important;
+ background: #11FEEE !important;
+ }
+ :deep(.el-radio__label){
+ color: #11FEEE !important
+ }
+ }
+ .chart-tit{
+ .tit{
+ color: #11FEEE;
+ }
+ ::v-deep(.el-popper){
+ background-color: rgba(10,31,92,1);
+ border: 1px solid rgba(17,254,238,.4);
+ color: #11FEEE;
+ .el-cascader-node__label{
+ color: #11FEEE;
+ }
+ .el-icon{
+ color: #11FEEE;
+ }
+ .el-select-dropdown__item{
+ color: #11FEEE;
+ }
+ .el-select-dropdown__item.hover{
+ background: #0049af;
+ }
+ }
+ ::v-deep(.el-popper__arrow){
+ &::before{
+ background-color: rgba(10,31,92,.6) !important;
+ border: 1px solid rgba(17,254,238,.4);
+ }
+ }
+ ::v-deep(.el-input__wrapper){
+ box-shadow: none;
+ border: 1px solid rgba(17,254,238,.2);
+ background: rgba(10,31,92,.6) !important;
+ height: 1.5rem;
+ color: #11FEEE;
+
+ input{
+ font-size: 0.8rem;
+ color: #11FEEE;
+ }
+ .el-icon{
+ color: #11FEEE;
+ }
+ }
+ }
+ .chart{
+ .el-table {
+ color: #11FEEE !important;
+ background-color: rgba(0,0,0,0) !important;
+ :deep(thead){
+ color: #11FEEE !important;
+ }
+ :deep(tr){
+ background-color: rgba(0,0,0,0) !important;
+ .el-table__cell{
+ background-color: rgba(0,0,0,0) !important;
+ }
+ }
+ }
+ }
+ }
+ }
+ .midChart{
+ border-radius: 4px;
+ background: rgba(8, 109, 209, 0.2);
+ border: 1px solid rgba(54, 252, 252, .6);
+ backdrop-filter: blur(5px);
+ position: relative;
+ z-index: 3;
+ .tit{
+ color: #11FEEE;
+ }
+ .el-table {
+ color: #11FEEE !important;
+ background-color: rgba(0,0,0,0) !important;
+ :deep(thead){
+ color: #11FEEE !important;
+ }
+ :deep(tr){
+ background-color: rgba(0,0,0,0) !important;
+ .el-table__cell{
+ background-color: rgba(0,0,0,0) !important;
+ }
+ .el-table-fixed-column--right{
+ background-color: #092846 !important
+ }
+ }
+ }
+
+ ::v-deep(.el-popper){
+ background-color: rgba(10,31,92,1);
+ border: 1px solid rgba(17,254,238,.4);
+ color: #11FEEE;
+ .el-cascader-node__label{
+ color: #11FEEE;
+ }
+ .el-icon{
+ color: #11FEEE;
+ }
+ .el-select-dropdown__item{
+ color: #11FEEE;
+ }
+ .el-select-dropdown__item.hover{
+ background: #0049af;
+ }
+ }
+ ::v-deep(.el-popper__arrow){
+ &::before{
+ background-color: rgba(10,31,92,.6) !important;
+ border: 1px solid rgba(17,254,238,.4);
+ }
+ }
+ ::v-deep(.el-input__wrapper){
+ box-shadow: none;
+ border: 1px solid rgba(17,254,238,.2);
+ background: rgba(10,31,92,.6) !important;
+ height: 1.5rem;
+ color: #11FEEE;
+
+ input{
+ font-size: 0.8rem;
+ color: #11FEEE;
+ }
+ .el-icon{
+ color: #11FEEE;
+ }
+ }
+ }
+}
.el-input {
width: 100% !important;
}
diff --git a/src/views/specialWorkSystem/specialIndex/index.vue b/src/views/specialWorkSystem/specialIndex/index.vue
index 9f747d8..54102a3 100644
--- a/src/views/specialWorkSystem/specialIndex/index.vue
+++ b/src/views/specialWorkSystem/specialIndex/index.vue
@@ -1,14 +1,25 @@
<template>
- <div class="home-container">
+ <div class="home-container" :class="isFull==true?'container':''" id="bigScreen">
<div class="full">
- 全屏
+ <el-button v-if="isFull==false" type="text" style="height: 34px" @click="toFullscreen">
+ <el-icon style="vertical-align: middle">
+ <FullScreen />
+ </el-icon>
+ <span style="vertical-align: middle">全屏</span>
+ </el-button>
+ <el-button v-else type="text" style="height: 34px" @click="toFullscreen">
+ <el-icon style="vertical-align: middle">
+ <Close />
+ </el-icon>
+ <span style="vertical-align: middle">退出全屏</span>
+ </el-button>
</div>
<div class="topChart">
<div class="chart-item">
<div class="chart-tit">
<span class="tit">八大作业各分类分布图</span>
<div class="filter-part filter-part2">
- <el-cascader v-model="chartSearch1.searchDep" :options="departmentList" :props="casProps" :show-all-levels="false" size="small"/>
+ <el-cascader :teleported="false" v-model="chartSearch1.searchDep" :options="departmentList" :props="casProps" :show-all-levels="false" size="small"/>
</div>
</div>
<div class="chart" :id="zyfb"></div>
@@ -23,8 +34,8 @@
<div class="chart-tit">
<span class="tit">各事业部关联作业分析</span>
<div class="filter-part">
- <el-cascader v-model="chartSearch2.searchDep" :options="departmentList" :props="casProps" :show-all-levels="false" size="small"/>
- <el-select v-model="chartSearch2.type" size="small">
+ <el-cascader :teleported="false" v-model="chartSearch2.searchDep" :options="departmentList" :props="casProps" :show-all-levels="false" size="small"/>
+ <el-select v-model="chartSearch2.type" size="small" :teleported="false">
<el-option
v-for="item in workType1"
:key="item.id"
@@ -42,7 +53,7 @@
<div class="chart-tit">
<span class="tit">关联作业趋势图</span>
<div class="filter-part filter-part2">
- <el-cascader v-model="chartSearch3.searchDep" :options="departmentList" :props="casProps" :show-all-levels="false" size="small"/>
+ <el-cascader :teleported="false" v-model="chartSearch3.searchDep" :options="departmentList" :props="casProps" :show-all-levels="false" size="small"/>
</div>
</div>
<div class="chart" :id="zyqs"></div>
@@ -58,13 +69,13 @@
active-text="作业人"
inactive-text="监护人"
/>
- <el-select v-model="chartSearch4.period" size="small">
+ <el-select :teleported="false" v-model="chartSearch4.period" size="small">
<el-option label="近7天" value="week"/>
<el-option label="近30天" value="month"/>
<el-option label="近90天" value="season"/>
<el-option label="近1年" value="year"/>
</el-select>
- <el-select v-model="chartSearch4.workType" size="small">
+ <el-select :teleported="false" v-model="chartSearch4.workType" size="small">
<el-option
v-for="item in workType1"
:key="item.id"
@@ -76,7 +87,7 @@
</div>
</div>
<div class="chart">
- <el-table ref="multipleTableRef" :data="warningData" style="width: 100%" :header-cell-style="{ background: '#fafafa' }">
+ <el-table ref="multipleTableRef" :data="warningData" style="width: 100%" :header-cell-style="isFull==true?{background: none}:{ background: '#fafafa' }">
<el-table-column property="name" label="姓名" width="180" align="center"/>
<el-table-column property="dep" label="所属部门" align="center"/>
<el-table-column property="warning" label="异常报警次数" align="center"/>
@@ -97,7 +108,7 @@
<el-col :span="5" style="display:flex;align-items: center">
<span style="white-space: nowrap">作业类型:</span>
<div class="grid-content topInfo">
- <el-select v-model="searchWord" size="small">
+ <el-select :teleported="false" v-model="searchWord" size="small">
<el-option
v-for="item in workType"
:key="item.id"
@@ -110,7 +121,7 @@
<el-col :span="5" style="display:flex;align-items: center">
<span style="white-space: nowrap">作业状态:</span>
<div class="grid-content topInfo">
- <el-select v-model="searchStatus" size="small">
+ <el-select :teleported="false" v-model="searchStatus" size="small">
<el-option
v-for="item in workStatus"
:key="item.value"
@@ -123,7 +134,7 @@
<el-col :span="5" style="display:flex;align-items: center">
<span style="white-space: nowrap">作业部门:</span>
<div class="grid-content topInfo">
- <el-cascader size="small" v-model="searchDep" :options="departmentList" :props="casProps" :show-all-levels="false"/>
+ <el-cascader :teleported="false" size="small" v-model="searchDep" :options="departmentList" :props="casProps" :show-all-levels="false"/>
</div>
</el-col>
<el-col :span="6" style="display:flex;align-items: center;">
@@ -132,6 +143,7 @@
<el-date-picker
v-model="searchDate"
size="small"
+ :teleported="false"
type="daterange"
unlink-panels
range-separator="至"
@@ -168,7 +180,7 @@
</el-col>
</el-row>
<el-table ref="multipleTableRef" :data="workData" style="width: 100%" :header-cell-style="{ background: '#fafafa' }">
- <el-table-column property="num" label="作业证编号" width="180" align="center"/>
+ <el-table-column property="num" label="作业证编号" align="center"/>
<el-table-column property="dep" label="部门" align="center"/>
<el-table-column property="applyer" label="申请人" align="center"/>
<el-table-column property="worker" label="作业人" align="center"/>
@@ -190,7 +202,7 @@
</el-table-column>
<el-table-column property="message" label="报警信息" align="center">
<template #default="scope">
- <el-button type="text" size="small" v-if="scope.row.message == 1">查看报警信息</el-button>
+ <el-button type="text" size="small" v-if="scope.row.message == 1">查看</el-button>
<span v-else>无</span>
</template>
</el-table-column>
@@ -254,6 +266,7 @@
import { useRouter } from 'vue-router';
import { Edit, View, Plus, Delete, Refresh, Search, Finished, Download, FolderChecked } from '@element-plus/icons-vue';
import { ElTable, ElMessage } from 'element-plus';
+import { specialIndexApi } from '/@/api/specialWorkSystem/specialIndex';
import { workApplyApi } from '/@/api/specialWorkSystem/workApply';
import type { TabsPaneContext } from 'element-plus';
import type { FormInstance, FormRules } from 'element-plus'
@@ -261,6 +274,7 @@
import Cookies from 'js-cookie';
import axios from 'axios';
import * as echarts from "echarts";
+import screenfull from "screenfull";
// 定义接口来定义对象的类型
interface stateType {
@@ -294,6 +308,8 @@
reviewForm: object;
reviewRules: object;
warningData: Array<any>;
+ isFull:boolean;
+ themeColor:string
}
interface type {
id: number;
@@ -345,6 +361,8 @@
searchStatus: null,
chartSearch1: {
searchDep: null,
+ startTime: '2023-03-08',
+ endTime: '2023-02-08',
period: 'month'
},
chartSearch2: {
@@ -407,6 +425,8 @@
message: 0
}
],
+ isFull: false,
+ themeColor: '#333',
workTimeList: [],
multipleSelection: [],
approveInfo: {
@@ -492,7 +512,35 @@
initSlfx()
initZyqs()
});
-
+ const toFullscreen =()=>{
+ state.isFull = !state.isFull
+ if(state.isFull == true){
+ state.themeColor = '#11FEEE'
+ }else{
+ state.themeColor = '#333'
+ }
+ initZyfb()
+ initSlfx()
+ initZyqs()
+ console.log(state.isFull,'quanp',state.themeColor)
+ const element = document.getElementById('bigScreen')
+ if (!screenfull.isEnabled) {
+ ElMessage.warning('暂不不支持全屏');
+ return false;
+ }
+ screenfull.toggle(element);
+ }
+ const getTypePie = async ()=>{
+ let res = await specialIndexApi().analyseType(state.chartSearch1.startTime,state.chartSearch1.endTime,state.chartSearch1.searchDep);
+ if (res.data.code === '200') {
+ console.log(res.data,'666666666')
+ } else {
+ ElMessage({
+ type: 'warning',
+ message: res.data.msg
+ });
+ }
+ }
type EChartsOption = echarts.EChartsOption
const initZyfb =()=>{
let dom = document.getElementById(zyfb.value);
@@ -505,7 +553,15 @@
legend: {
orient: 'vertical',
left: 'left',
- top: 'center'
+ top: 'center',
+ textStyle: {
+ // 设置默认的文字颜色
+ color: state.themeColor,
+ fontSize: 12
+ },
+ itemStyle: {
+ borderWidth: 0 // 设置图例边框宽度为0
+ }
},
series: [
{
@@ -574,6 +630,9 @@
data: ['事业部1', '事业部2', '事业部3', '事业部4', '事业部5', '事业部6', '事业部7'],
axisTick: {
alignWithLabel: true
+ },
+ axisLabel: {
+ color: state.themeColor
}
}
],
@@ -604,7 +663,10 @@
option = {
xAxis: {
type: 'category',
- data: ['四月', '五月', '六月', '七月', '八月', '九月', '十月', '十一月', '十二月', '一月', '二月', '三月']
+ data: ['四月', '五月', '六月', '七月', '八月', '九月', '十月', '十一月', '十二月', '一月', '二月', '三月'],
+ axisLabel: {
+ color: state.themeColor
+ }
},
yAxis: {
type: 'value'
@@ -797,6 +859,7 @@
zyfb,
slfx,
zyqs,
+ toFullscreen,
handleReview,
submitReview,
reLoadData,
@@ -828,6 +891,15 @@
&::-webkit-scrollbar {
display: none; /* Chrome Safari */
}
+ .full{
+ position:fixed;
+ height: 34px;
+ line-height: 34px;
+ top: 80px;
+ right: 20px;
+ z-index: 99999;
+ }
+
.demo-tabs {
width: 100%;
height: 100%;
@@ -1211,6 +1283,175 @@
}
}
}
+
+.container{
+ padding: 20px;
+ background: url('../../../assets/spwbg.png') no-repeat center;
+
+ .full{
+ position:fixed;
+ background: #fff;
+ border-radius: 17px;
+ box-shadow: 3px 3px 12px rgba(0,0,0,.2);
+ height: 34px;
+ line-height: 34px;
+ top: 0;
+ right: 20px;
+ z-index: 99999;
+ }
+ .topChart{
+ .chart-item{
+ border-radius: 4px;
+ background: rgba(8, 109, 209, 0.2);
+ border: 1px solid rgba(54, 252, 252, .6);
+ backdrop-filter: blur(5px);
+ position: relative;
+ z-index: 2;
+ &:last-of-type{
+ position: relative;
+ z-index: 1;
+ }
+ .el-radio.is-bordered.is-checked{
+ border-color: #11FEEE !important;
+ :deep(.el-radio__inner){
+ border-color: #11FEEE !important;
+ background: #11FEEE !important;
+ }
+ :deep(.el-radio__label){
+ color: #11FEEE !important
+ }
+ }
+ .chart-tit{
+ .tit{
+ color: #11FEEE;
+ }
+ ::v-deep(.el-popper){
+ background-color: rgba(10,31,92,1);
+ border: 1px solid rgba(17,254,238,.4);
+ color: #11FEEE;
+ .el-cascader-node__label{
+ color: #11FEEE;
+ }
+ .el-icon{
+ color: #11FEEE;
+ }
+ .el-select-dropdown__item{
+ color: #11FEEE;
+ }
+ .el-select-dropdown__item.hover{
+ background: #0049af;
+ }
+ }
+ ::v-deep(.el-popper__arrow){
+ &::before{
+ background-color: rgba(10,31,92,.6) !important;
+ border: 1px solid rgba(17,254,238,.4);
+ }
+ }
+ ::v-deep(.el-input__wrapper){
+ box-shadow: none;
+ border: 1px solid rgba(17,254,238,.2);
+ background: rgba(10,31,92,.6) !important;
+ height: 1.5rem;
+ color: #11FEEE;
+
+ input{
+ font-size: 0.8rem;
+ color: #11FEEE;
+ }
+ .el-icon{
+ color: #11FEEE;
+ }
+ }
+ }
+ .chart{
+ .el-table {
+ color: #11FEEE !important;
+ background-color: rgba(0,0,0,0) !important;
+ :deep(thead){
+ color: #11FEEE !important;
+ }
+ :deep(tr){
+ background-color: rgba(0,0,0,0) !important;
+ .el-table__cell{
+ background-color: rgba(0,0,0,0) !important;
+ }
+ }
+ }
+ }
+ }
+ }
+ .homeCard{
+ border-radius: 4px;
+ background: rgba(8, 109, 209, 0.2);
+ border: 1px solid rgba(54, 252, 252, .6);
+ backdrop-filter: blur(5px);
+ position: relative;
+ z-index: 3;
+ .el-row{
+ &>div{
+ &>span{
+ color: #11FEEE;
+ }
+ }
+ }
+ .el-table {
+ color: #11FEEE !important;
+ background-color: rgba(0,0,0,0) !important;
+ :deep(thead){
+ color: #11FEEE !important;
+ }
+ :deep(tr){
+ background-color: rgba(0,0,0,0) !important;
+ .el-table__cell{
+ background-color: rgba(0,0,0,0) !important;
+ }
+ .el-table-fixed-column--right{
+ background-color: #092846 !important
+ }
+ }
+ }
+
+ ::v-deep(.el-popper){
+ background-color: rgba(10,31,92,1);
+ border: 1px solid rgba(17,254,238,.4);
+ color: #11FEEE;
+ .el-cascader-node__label{
+ color: #11FEEE;
+ }
+ .el-icon{
+ color: #11FEEE;
+ }
+ .el-select-dropdown__item{
+ color: #11FEEE;
+ }
+ .el-select-dropdown__item.hover{
+ background: #0049af;
+ }
+ }
+ ::v-deep(.el-popper__arrow){
+ &::before{
+ background-color: rgba(10,31,92,.6) !important;
+ border: 1px solid rgba(17,254,238,.4);
+ }
+ }
+ ::v-deep(.el-input__wrapper){
+ box-shadow: none;
+ border: 1px solid rgba(17,254,238,.2);
+ background: rgba(10,31,92,.6) !important;
+ height: 1.5rem;
+ color: #11FEEE;
+
+ input{
+ font-size: 0.8rem;
+ color: #11FEEE;
+ }
+ .el-icon{
+ color: #11FEEE;
+ }
+ }
+ }
+}
.el-card {
border: 0;
}
--
Gitblit v1.9.2