2024-08-23 13:19:20 +08:00
|
|
|
<!-- 模式切换页面 -->
|
|
|
|
|
<template>
|
2024-10-10 17:47:55 +08:00
|
|
|
<div class="main_container">
|
|
|
|
|
<!-- :style="{
|
|
|
|
|
height: authStore?.showMenuFlag
|
|
|
|
|
? 'calc(100vh - 165px)'
|
|
|
|
|
: 'calc(100vh - 125px)',
|
|
|
|
|
}" -->
|
|
|
|
|
<div class="mode" v-for="(item, index) in modeList" :key="index">
|
|
|
|
|
<div class="mode_top">
|
|
|
|
|
<div class="mode_name">
|
|
|
|
|
<p>
|
|
|
|
|
{{ item.name }}
|
|
|
|
|
</p>
|
2024-08-23 13:19:20 +08:00
|
|
|
</div>
|
2024-10-10 17:47:55 +08:00
|
|
|
<div class="test_button">
|
|
|
|
|
<el-button
|
|
|
|
|
size="small"
|
|
|
|
|
type="primary"
|
2024-11-20 11:22:05 +08:00
|
|
|
@click="handelOpen(item)"
|
2024-10-10 17:47:55 +08:00
|
|
|
:disabled="item.isActive == false"
|
|
|
|
|
>进入检测</el-button
|
|
|
|
|
>
|
2024-08-23 13:19:20 +08:00
|
|
|
</div>
|
|
|
|
|
</div>
|
2024-10-10 17:47:55 +08:00
|
|
|
<div class="mode_img">
|
|
|
|
|
<img :src="item.img" />
|
|
|
|
|
</div>
|
2024-08-23 13:19:20 +08:00
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</template>
|
|
|
|
|
<script lang="ts" setup>
|
|
|
|
|
import { useRouter } from "vue-router";
|
|
|
|
|
import { ElMessage } from "element-plus";
|
2024-10-09 20:03:07 +08:00
|
|
|
import { useAuthStore } from "@/stores/modules/auth";
|
2024-11-20 11:22:05 +08:00
|
|
|
import { useModeStore } from "@/stores/modules/mode"; // 引入模式 store
|
2024-08-23 13:19:20 +08:00
|
|
|
const authStore = useAuthStore();
|
2024-11-20 11:22:05 +08:00
|
|
|
const modeStore = useModeStore(); // 使用模式 store
|
2024-08-23 13:19:20 +08:00
|
|
|
const activeIndex = ref("1-1");
|
|
|
|
|
const router = useRouter();
|
|
|
|
|
const modeList = [
|
|
|
|
|
{
|
2024-08-27 18:37:46 +08:00
|
|
|
name: "模拟式模块",
|
2024-08-23 13:19:20 +08:00
|
|
|
subName: "未启用模拟式检测计划",
|
|
|
|
|
img: "/src/assets/images/dashboard/1.svg",
|
|
|
|
|
isActive: true,
|
|
|
|
|
},
|
|
|
|
|
{
|
2024-08-27 18:37:46 +08:00
|
|
|
name: "数字式模块",
|
2024-08-23 13:19:20 +08:00
|
|
|
subName: "启用数字检测计划",
|
|
|
|
|
img: "/src/assets/images/dashboard/2.svg",
|
|
|
|
|
isActive: false,
|
|
|
|
|
},
|
|
|
|
|
{
|
2024-08-27 18:37:46 +08:00
|
|
|
name: "对比式模块",
|
2024-08-23 13:19:20 +08:00
|
|
|
subName: "启用对比式检测计划",
|
|
|
|
|
img: "/src/assets/images/dashboard/3.svg",
|
|
|
|
|
isActive: false,
|
|
|
|
|
},
|
|
|
|
|
];
|
2024-11-20 11:22:05 +08:00
|
|
|
const handelOpen = async (item: any) => {
|
|
|
|
|
|
2024-08-23 13:19:20 +08:00
|
|
|
await authStore.setShowMenu();
|
2024-11-20 11:22:05 +08:00
|
|
|
modeStore.setCurrentMode(item.name); // 将模式名称存入 store
|
2024-08-23 13:19:20 +08:00
|
|
|
return;
|
|
|
|
|
if (isActive) {
|
|
|
|
|
router.push({ path: "/static" });
|
|
|
|
|
} else {
|
|
|
|
|
ElMessage({
|
|
|
|
|
message: "当前模式未配置",
|
|
|
|
|
type: "warning",
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
const handleSelect = (key: string, keyPath: string[]) => {
|
|
|
|
|
console.log(key, keyPath);
|
|
|
|
|
};
|
|
|
|
|
onMounted(() => {
|
|
|
|
|
console.log();
|
|
|
|
|
});
|
|
|
|
|
</script>
|
|
|
|
|
<style lang="scss" scoped>
|
|
|
|
|
.main_container {
|
|
|
|
|
width: 100%;
|
2024-10-10 17:47:55 +08:00
|
|
|
// height: calc(100vh - 165px);
|
|
|
|
|
height: 100%;
|
2024-08-23 13:19:20 +08:00
|
|
|
// overflow-y: auto;
|
|
|
|
|
display: flex;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
flex-wrap: wrap;
|
|
|
|
|
align-items: center;
|
|
|
|
|
// padding: 20px 2%;
|
|
|
|
|
.mode {
|
|
|
|
|
flex: none;
|
2024-10-10 17:47:55 +08:00
|
|
|
margin-top: 3px;
|
2024-08-23 13:19:20 +08:00
|
|
|
width: 32.5%;
|
2024-10-10 17:47:55 +08:00
|
|
|
height: 99.5% !important;
|
2024-08-23 13:19:20 +08:00
|
|
|
border: 1px solid #eee;
|
|
|
|
|
display: flex;
|
|
|
|
|
flex-direction: column;
|
|
|
|
|
align-items: center;
|
|
|
|
|
background: #fff;
|
|
|
|
|
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%
|
|
|
|
|
);
|
|
|
|
|
// padding: 40px 0;
|
|
|
|
|
.mode_top {
|
|
|
|
|
width: 100%;
|
|
|
|
|
height: 40px;
|
|
|
|
|
display: flex;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
align-items: center;
|
|
|
|
|
background: #008aff;
|
|
|
|
|
border-radius: 6px 6px 0 0;
|
|
|
|
|
.mode_name {
|
|
|
|
|
width: 100%;
|
|
|
|
|
height: 40px;
|
|
|
|
|
flex: 1;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: flex-start;
|
|
|
|
|
p {
|
|
|
|
|
font-family: "微软雅黑 Bold", "微软雅黑", "微软雅黑", sans-serif;
|
|
|
|
|
font-weight: 700;
|
|
|
|
|
font-style: normal;
|
|
|
|
|
font-size: 16px;
|
|
|
|
|
color: #ffffff;
|
|
|
|
|
text-align: center;
|
|
|
|
|
// background: #fff;
|
|
|
|
|
line-height: 40px;
|
|
|
|
|
text-align: left;
|
|
|
|
|
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 {
|
|
|
|
|
width: 150px;
|
|
|
|
|
height: 100%;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: flex-end;
|
|
|
|
|
padding-right: 5px;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
.mode_img {
|
|
|
|
|
width: 100%;
|
|
|
|
|
height: auto;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
// padding: 30px 0 50px;
|
|
|
|
|
margin-top: 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;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
.mode_test {
|
|
|
|
|
width: 100%;
|
|
|
|
|
height: 40px;
|
|
|
|
|
display: flex;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
margin-bottom: 20px;
|
|
|
|
|
.test_button {
|
|
|
|
|
width: 120px;
|
|
|
|
|
height: 100%;
|
|
|
|
|
border: 1px solid rgba(121, 121, 121, 1);
|
|
|
|
|
border-radius: 5px;
|
|
|
|
|
font-family: "微软雅黑", sans-serif;
|
|
|
|
|
font-weight: 400;
|
|
|
|
|
font-style: normal;
|
|
|
|
|
color: #fff;
|
|
|
|
|
text-align: center;
|
|
|
|
|
line-height: 40px;
|
|
|
|
|
cursor: pointer;
|
|
|
|
|
}
|
|
|
|
|
.test_button:hover {
|
|
|
|
|
background: rgba(0, 0, 0, 0.2);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.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%
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
.mode_off {
|
|
|
|
|
.mode_name,
|
|
|
|
|
.mode_subName,
|
|
|
|
|
.test_button {
|
|
|
|
|
color: #fff !important;
|
|
|
|
|
}
|
|
|
|
|
.test_button:hover {
|
|
|
|
|
// background: rgba(0, 0, 0, 0.2) !important;
|
|
|
|
|
cursor: pointer;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2024-10-09 20:03:07 +08:00
|
|
|
:deep(.el-sub-menu__title) {
|
2024-08-23 13:19:20 +08:00
|
|
|
border-bottom: 0 !important;
|
|
|
|
|
outline: none !important;
|
|
|
|
|
}
|
|
|
|
|
</style>
|