2024-08-23 13:19:20 +08:00
|
|
|
|
<!-- 模式切换页面 -->
|
|
|
|
|
|
<template>
|
2025-10-14 19:00:47 +08:00
|
|
|
|
<div class="main_container box">
|
|
|
|
|
|
<el-carousel :interval="5000" type="card" style="width: 60%; margin-left: 20%; height: 70%">
|
|
|
|
|
|
<el-carousel-item
|
|
|
|
|
|
class="mode"
|
|
|
|
|
|
:class="{ modeBG: index != 0 }"
|
|
|
|
|
|
v-for="(item, index) in modeList"
|
|
|
|
|
|
:key="index"
|
|
|
|
|
|
>
|
|
|
|
|
|
<div class="mode_top">
|
|
|
|
|
|
<div class="mode_name">
|
|
|
|
|
|
{{ item.name }}
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
<div class="mode_img">
|
|
|
|
|
|
<img :src="item.img" />
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="test_button">
|
|
|
|
|
|
<el-button size="large" type="primary" @click="handelOpen(item)" :disabled="!item.activated">
|
|
|
|
|
|
进入检测
|
|
|
|
|
|
</el-button>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</el-carousel-item>
|
|
|
|
|
|
</el-carousel>
|
|
|
|
|
|
</div>
|
2024-08-23 13:19:20 +08:00
|
|
|
|
</template>
|
|
|
|
|
|
<script lang="ts" setup>
|
2025-10-14 19:00:47 +08:00
|
|
|
|
import { useAuthStore } from '@/stores/modules/auth'
|
|
|
|
|
|
import { useAppSceneStore, useModeStore } from '@/stores/modules/mode' // 引入模式 store
|
|
|
|
|
|
import { getCurrentScene } from '@/api/user/login'
|
|
|
|
|
|
|
|
|
|
|
|
const authStore = useAuthStore()
|
|
|
|
|
|
const modeStore = useModeStore() // 使用模式 store
|
|
|
|
|
|
const AppSceneStore = useAppSceneStore()
|
|
|
|
|
|
const activateInfo = authStore.activateInfo
|
|
|
|
|
|
const isActivateOpen = import.meta.env.VITE_ACTIVATE_OPEN
|
2025-07-21 13:47:56 +08:00
|
|
|
|
|
2024-08-23 13:19:20 +08:00
|
|
|
|
const modeList = [
|
2025-10-14 19:00:47 +08:00
|
|
|
|
{
|
|
|
|
|
|
name: '模拟式模块',
|
|
|
|
|
|
code: '模拟式',
|
|
|
|
|
|
subName: '未启用模拟式检测计划',
|
|
|
|
|
|
img: new URL('/src/assets/images/dashboard/1.svg', import.meta.url).href,
|
|
|
|
|
|
activated:
|
|
|
|
|
|
isActivateOpen === 'true'
|
|
|
|
|
|
? activateInfo.simulate.apply === 1 && activateInfo.simulate.permanently === 1
|
|
|
|
|
|
: true
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
name: '数字式模块',
|
|
|
|
|
|
code: '数字式',
|
|
|
|
|
|
subName: '启用数字检测计划',
|
|
|
|
|
|
img: new URL('/src/assets/images/dashboard/2.svg', import.meta.url).href,
|
|
|
|
|
|
activated:
|
|
|
|
|
|
isActivateOpen === 'true'
|
|
|
|
|
|
? activateInfo.digital.apply === 1 && activateInfo.digital.permanently === 1
|
|
|
|
|
|
: true
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
name: '比对式模块',
|
|
|
|
|
|
code: '比对式',
|
|
|
|
|
|
subName: '启用比对式检测计划',
|
|
|
|
|
|
img: new URL('/src/assets/images/dashboard/3.svg', import.meta.url).href,
|
|
|
|
|
|
activated:
|
|
|
|
|
|
isActivateOpen === 'true'
|
|
|
|
|
|
? activateInfo.contrast.apply === 1 && activateInfo.contrast.permanently === 1
|
|
|
|
|
|
: true
|
|
|
|
|
|
}
|
|
|
|
|
|
]
|
2024-11-20 11:02:50 +08:00
|
|
|
|
const handelOpen = async (item: any) => {
|
2025-10-14 19:00:47 +08:00
|
|
|
|
if (!item.activated) {
|
|
|
|
|
|
ElMessage.warning(`${item.name}未激活`)
|
|
|
|
|
|
return
|
|
|
|
|
|
}
|
|
|
|
|
|
modeStore.setCurrentMode(item.code) // 将模式code存入 store
|
|
|
|
|
|
const { data: scene } = await getCurrentScene() // 获取当前场景
|
|
|
|
|
|
AppSceneStore.setCurrentMode(scene + '') //0:省级平台,1:设备出厂,2:研发自测
|
|
|
|
|
|
await authStore.setShowMenu()
|
|
|
|
|
|
await authStore.getAuthMenuList()
|
|
|
|
|
|
return
|
|
|
|
|
|
}
|
2024-08-23 13:19:20 +08:00
|
|
|
|
const handleSelect = (key: string, keyPath: string[]) => {
|
2025-10-14 19:00:47 +08:00
|
|
|
|
console.log(key, keyPath)
|
|
|
|
|
|
}
|
2024-08-23 13:19:20 +08:00
|
|
|
|
onMounted(() => {
|
2025-10-14 19:00:47 +08:00
|
|
|
|
console.log()
|
|
|
|
|
|
})
|
2024-08-23 13:19:20 +08:00
|
|
|
|
</script>
|
|
|
|
|
|
<style lang="scss" scoped>
|
2025-01-14 19:26:22 +08:00
|
|
|
|
.box {
|
2025-10-14 19:00:47 +08:00
|
|
|
|
background: #ededed;
|
|
|
|
|
|
// background-image: url("/src/assets/images/dashboard/DT.jpg");
|
|
|
|
|
|
// /* 背景图垂直、水平均居中 */
|
|
|
|
|
|
// // background-position: center center;
|
|
|
|
|
|
// /* 背景图不平铺 */
|
|
|
|
|
|
// background-repeat: no-repeat;
|
|
|
|
|
|
// /* 当内容高度大于图片高度时,背景图像的位置相对于viewport固定 */
|
|
|
|
|
|
// background-attachment: fixed;
|
|
|
|
|
|
// /* 让背景图基于容器大小伸缩 */
|
|
|
|
|
|
// background-size: cover;
|
2025-01-14 19:26:22 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2024-08-23 13:19:20 +08:00
|
|
|
|
.main_container {
|
2025-10-14 19:00:47 +08:00
|
|
|
|
width: 100%;
|
|
|
|
|
|
// height: calc(100vh - 165px);
|
|
|
|
|
|
height: 100%;
|
|
|
|
|
|
// overflow-y: auto;
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
|
flex-wrap: wrap;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
|
|
|
|
|
|
.mode {
|
|
|
|
|
|
height: 99.5% !important;
|
|
|
|
|
|
border: 1px solid #eee;
|
|
|
|
|
|
border-radius: 6px;
|
|
|
|
|
|
background: linear-gradient(
|
|
|
|
|
|
180deg,
|
|
|
|
|
|
rgba(0, 153, 255, 1) 0%,
|
|
|
|
|
|
rgba(0, 153, 255, 1) 0%,
|
|
|
|
|
|
rgba(0, 102, 255, 1) 65%,
|
|
|
|
|
|
rgba(0, 51, 255, 1) 100%,
|
|
|
|
|
|
rgba(0, 51, 255, 1) 100%
|
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
position: absolute;
|
|
|
|
|
|
|
|
|
|
|
|
// padding: 40px 0;
|
|
|
|
|
|
.mode_top {
|
|
|
|
|
|
width: 100%;
|
|
|
|
|
|
height: 40px;
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
justify-content: center;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
background: #008aff;
|
|
|
|
|
|
border-radius: 6px 6px 0 0;
|
|
|
|
|
|
|
|
|
|
|
|
.mode_name {
|
|
|
|
|
|
width: 100%;
|
|
|
|
|
|
height: 40px;
|
|
|
|
|
|
font-family: '微软雅黑 Bold', '微软雅黑', '微软雅黑', sans-serif;
|
|
|
|
|
|
font-weight: 700;
|
|
|
|
|
|
font-style: normal;
|
|
|
|
|
|
font-size: 20px;
|
|
|
|
|
|
color: #ffffff;
|
|
|
|
|
|
text-align: center;
|
|
|
|
|
|
line-height: 40px;
|
|
|
|
|
|
padding-left: 10px;
|
|
|
|
|
|
// margin-top: 20px;
|
|
|
|
|
|
|
|
|
|
|
|
.mode_subName {
|
|
|
|
|
|
font-family: '微软雅黑', sans-serif;
|
|
|
|
|
|
font-weight: 400;
|
|
|
|
|
|
font-style: normal;
|
|
|
|
|
|
font-size: 12px;
|
|
|
|
|
|
color: #ffffff;
|
|
|
|
|
|
line-height: 40px;
|
|
|
|
|
|
text-align: center;
|
|
|
|
|
|
padding: 5px 0 0 10px;
|
|
|
|
|
|
// margin-top: 10px;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.test_button {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
text-align: center;
|
|
|
|
|
|
width: 100%;
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
justify-content: flex-end;
|
|
|
|
|
|
padding-right: 5px;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2025-01-14 19:26:22 +08:00
|
|
|
|
|
2025-10-14 19:00:47 +08:00
|
|
|
|
.mode_img {
|
|
|
|
|
|
width: 100%;
|
|
|
|
|
|
height: auto;
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
justify-content: center;
|
|
|
|
|
|
// padding: 30px 0 50px;
|
|
|
|
|
|
margin-top: 100px;
|
|
|
|
|
|
// margin-bottom: 100px;
|
|
|
|
|
|
|
|
|
|
|
|
img:nth-child(1) {
|
|
|
|
|
|
width: 60%;
|
|
|
|
|
|
height: auto;
|
|
|
|
|
|
display: block;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
img:nth-child(2) {
|
|
|
|
|
|
width: 70%;
|
|
|
|
|
|
height: auto;
|
|
|
|
|
|
display: block;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
img:nth-child(3) {
|
|
|
|
|
|
width: 60%;
|
|
|
|
|
|
height: auto;
|
|
|
|
|
|
display: block;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2025-01-14 16:19:15 +08:00
|
|
|
|
|
2025-10-14 19:00:47 +08:00
|
|
|
|
.mode_test {
|
|
|
|
|
|
width: 100%;
|
|
|
|
|
|
height: 40px;
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
justify-content: center;
|
|
|
|
|
|
margin-bottom: 20px;
|
2025-01-14 16:19:15 +08:00
|
|
|
|
|
2025-10-14 19:00:47 +08:00
|
|
|
|
.test_button:hover {
|
|
|
|
|
|
background: rgba(0, 0, 0, 0.2);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2025-01-14 16:19:15 +08:00
|
|
|
|
|
2025-10-14 19:00:47 +08:00
|
|
|
|
.test_button {
|
|
|
|
|
|
position: absolute;
|
|
|
|
|
|
bottom: 30px;
|
|
|
|
|
|
left: 50%;
|
|
|
|
|
|
transform: translateX(-50%);
|
|
|
|
|
|
border-radius: 5px;
|
|
|
|
|
|
font-family: '微软雅黑', sans-serif;
|
|
|
|
|
|
font-weight: 400;
|
2025-01-14 19:26:22 +08:00
|
|
|
|
font-style: normal;
|
2025-10-14 19:00:47 +08:00
|
|
|
|
color: #fff;
|
2025-01-14 19:26:22 +08:00
|
|
|
|
text-align: center;
|
|
|
|
|
|
line-height: 40px;
|
2025-10-14 19:00:47 +08:00
|
|
|
|
cursor: pointer;
|
2024-08-23 13:19:20 +08:00
|
|
|
|
}
|
2025-01-14 16:19:15 +08:00
|
|
|
|
|
2025-10-14 19:00:47 +08:00
|
|
|
|
.mode:nth-child(3n + 3) {
|
|
|
|
|
|
background: linear-gradient(
|
|
|
|
|
|
180deg,
|
|
|
|
|
|
rgba(0, 153, 255, 1) 0%,
|
|
|
|
|
|
rgba(0, 153, 255, 1) 0%,
|
|
|
|
|
|
rgba(0, 102, 255, 1) 39%,
|
|
|
|
|
|
rgba(102, 51, 204, 1) 100%,
|
|
|
|
|
|
rgba(102, 51, 204, 1) 100%
|
|
|
|
|
|
);
|
2024-08-23 13:19:20 +08:00
|
|
|
|
}
|
2025-01-14 16:19:15 +08:00
|
|
|
|
|
2025-10-14 19:00:47 +08:00
|
|
|
|
.mode_off {
|
|
|
|
|
|
.mode_name,
|
|
|
|
|
|
.mode_subName,
|
|
|
|
|
|
.test_button {
|
|
|
|
|
|
color: #fff !important;
|
|
|
|
|
|
}
|
2025-01-14 16:19:15 +08:00
|
|
|
|
|
2025-10-14 19:00:47 +08:00
|
|
|
|
.test_button:hover {
|
|
|
|
|
|
// background: rgba(0, 0, 0, 0.2) !important;
|
|
|
|
|
|
cursor: pointer;
|
|
|
|
|
|
}
|
2024-08-23 13:19:20 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
2025-01-14 16:19:15 +08:00
|
|
|
|
|
2024-10-09 20:03:07 +08:00
|
|
|
|
:deep(.el-sub-menu__title) {
|
2025-10-14 19:00:47 +08:00
|
|
|
|
border-bottom: 0 !important;
|
|
|
|
|
|
outline: none !important;
|
2024-08-23 13:19:20 +08:00
|
|
|
|
}
|
2025-01-14 16:19:15 +08:00
|
|
|
|
|
2025-01-14 19:26:22 +08:00
|
|
|
|
// .modeBG {
|
|
|
|
|
|
// &::before {
|
|
|
|
|
|
// content: "";
|
|
|
|
|
|
// position: absolute;
|
|
|
|
|
|
// top: 0;
|
|
|
|
|
|
// left: 0;
|
|
|
|
|
|
// width: 100%;
|
|
|
|
|
|
// height: 100%;
|
|
|
|
|
|
// background-color: #70707080;
|
|
|
|
|
|
// ;
|
|
|
|
|
|
// }
|
2025-01-14 16:19:15 +08:00
|
|
|
|
|
2025-01-14 19:26:22 +08:00
|
|
|
|
// }
|
|
|
|
|
|
:deep(.el-carousel__container) {
|
2025-10-14 19:00:47 +08:00
|
|
|
|
height: 100%;
|
2025-01-14 19:26:22 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
:deep(.el-carousel__item) {
|
2025-10-14 19:00:47 +08:00
|
|
|
|
position: relative;
|
2025-01-14 16:19:15 +08:00
|
|
|
|
}
|
2024-08-23 13:19:20 +08:00
|
|
|
|
</style>
|