YouKeChuanMei_VUE/src/views/index.vue

267 lines
8.2 KiB
Vue
Raw Normal View History

2025-07-22 21:42:20 +08:00
<template>
2025-07-25 21:14:24 +08:00
<div class="flex-container">
<!-- 左侧内容 - 自动宽度 -->
<div class="left-content">
<div class="dashboard-4grid">
<div class="grid-item4">
<img :src="mediaMap" class="custom-icon" />
<div class="grid-title grid-item4-margin">媒体地图</div>
<div class="grid-line"></div>
</div>
<div class="grid-item4">
<img :src="supplierManage" class="custom-icon" />
<div class="grid-title grid-item4-margin">供应商管理</div>
<div class="grid-line"></div>
</div>
<div class="grid-item4">
<img :src="mediaLibary" class="custom-icon" />
<div class="grid-title grid-item4-margin">媒体库管理</div>
<div class="grid-line"></div>
</div>
<div class="grid-item4">
<img :src="outdoorMediaMap" class="custom-icon" />
<div class="grid-title grid-item4-margin">户外媒介数据</div>
<div class="grid-line"></div>
</div>
</div>
<div class="dashboard-3grid">
<div class="grid-item3 calibrationPlatform">
<div class="grid-title">校准平台</div>
<div class="grid-sub-title"><span>去使用</span>></div>
</div>
<div class="grid-item3 PPTAnalysisTool">
<div class="grid-title">PPT分析工具</div>
<div class="grid-sub-title"><span>去使用</span>></div>
</div>
<div class="grid-item3 longitudeConversion">
<div class="grid-title">经纬度转换</div>
<div class="grid-sub-title"><span>去使用</span>></div>
</div>
</div>
</div>
2025-07-22 21:42:20 +08:00
2025-07-25 21:14:24 +08:00
<!-- 右侧内容 - 固定宽度360px -->
<div class="right-content">
<div class="title-container">
<div class="title-label">
<img :src="notic_icon" class="custom-icon" /><span>系统通知</span>
</div>
</div>
<ul class="resource-list">
<li v-for="(notice, index) in notices" :key="index" class="resource-link">
{{ notice.content }}
</li>
</ul>
</div>
</div>
</template>
2025-07-22 21:42:20 +08:00
2025-07-25 21:14:24 +08:00
<script setup name="Index">
import { ref } from 'vue';
import mediaMap from '@/assets/images/mediaMap.png'
import supplierManage from '@/assets/images/supplierManage.png'
import mediaLibary from '@/assets/images/mediaLibary.png'
import outdoorMediaMap from '@/assets/images/outdoorMediaMap.png'
import notic_icon from '@/assets/images/notic-icon.png'
2025-07-22 21:42:20 +08:00
2025-07-25 21:14:24 +08:00
const notices = ref([
{ date: 'XXXXX供应商信息记不全请完善', content: 'XXXXX供应商信息记不全请完善' },
{ date: 'XXXXX供应商信息记不全请完善', content: 'XXXXX供应商信息记不全请完善' },
{ date: 'XXXXX供应商信息记不全请完善', content: 'XXXXX供应商信息记不全请完善' },
{ date: 'XXXXX供应商信息记不全请完善', content: 'XXXXX供应商信息记不全请完善' },
{ date: 'XXXXX供应商信息记不全请完善', content: 'XXXXX供应商信息记不全请完善' },
{ date: 'XXXXX供应商信息记不全请完善', content: 'XXXXX供应商信息记不全请完善' },
{ date: 'XXXXX供应商信息记不全请完善', content: 'XXXXX供应商信息记不全请完善' },
{ date: 'XXXXX供应商信息记不全请完善', content: 'XXXXX供应商信息记不全请完善' },
{ date: 'XXXXX供应商信息记不全请完善', content: 'XXXXX供应商信息记不全请完善' },
{ date: 'XXXXX供应商信息记不全请完善', content: 'XXXXX供应商信息记不全请完善' },
{ date: 'XXXXX供应商信息记不全请完善', content: 'XXXXX供应商信息记不全请完善' },
{ date: 'XXXXX供应商信息记不全请完善', content: 'XXXXX供应商信息记不全请完善' },
{ date: 'XXXXX供应商信息记不全请完善', content: 'XXXXX供应商信息记不全请完善' },
{ date: 'XXXXX供应商信息记不全请完善', content: 'XXXXX供应商信息记不全请完善' },
{ date: 'XXXXX供应商信息记不全请完善', content: 'XXXXX供应商信息记不全请完善' },
{ date: 'XXXXX供应商信息记不全请完善', content: 'XXXXX供应商信息记不全请完善' },
{ date: 'XXXXX供应商信息记不全请完善', content: 'XXXXX供应商信息记不全请完善' },
{ date: 'XXXXX供应商信息记不全请完善', content: 'XXXXX供应商信息记不全请完善' },
{ date: 'XXXXX供应商信息记不全请完善', content: 'XXXXX供应商信息记不全请完善' },
{ date: 'XXXXX供应商信息记不全请完善', content: 'XXXXX供应商信息记不全请完善' },
{ date: 'XXXXX供应商信息记不全请完善', content: 'XXXXX供应商信息记不全请完善' },
{ date: 'XXXXX供应商信息记不全请完善', content: 'XXXXX供应商信息记不全请完善' },
{ date: 'XXXXX供应商信息记不全请完善', content: 'XXXXX供应商信息记不全请完善' },
{ date: 'XXXXX供应商信息记不全请完善', content: 'XXXXX供应商信息记不全请完善' },
]);
</script>
<style scoped lang="scss">
.flex-container {
display: flex;
gap: 30px;
/* 间距30px */
width: 1440px;
height: 520px;
align-items: center; // 垂直居中
box-sizing: border-box;
/* 包含padding在尺寸计算内 */
margin: 174px auto;
}
2025-07-22 21:42:20 +08:00
2025-07-25 21:14:24 +08:00
.left-content {
flex: 1;
/* 自动分配剩余空间 */
min-width: 0;
/* 防止内容溢出 */
}
2025-07-22 21:42:20 +08:00
2025-07-25 21:14:24 +08:00
.right-content {
width: 360px;
height: 520px;
padding: 30px;
/* 固定宽度360px */
flex-shrink: 0;
/* 防止被压缩 */
background-image: url("../assets/images/system-notic-bg.png");
background-repeat: no-repeat;
/* 禁止平铺 */
background-size: cover;
}
.dashboard-4grid {
display: grid;
grid-template-columns: repeat(4, 1fr);
gap: 30px;
}
2025-07-22 21:42:20 +08:00
2025-07-25 21:14:24 +08:00
.dashboard-3grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 30px;
margin-top: 30px;
}
2025-07-22 21:42:20 +08:00
2025-07-25 21:14:24 +08:00
.grid-item4 {
width: 240px;
height: 280px;
border-radius: 6px 6px 6px 6px;
background: #ffffffdb;
text-align: center;
padding: 38px 40px;
}
2025-07-22 21:42:20 +08:00
2025-07-25 21:14:24 +08:00
.grid-item4-margin {
margin: 14px auto 16px auto;
}
2025-07-22 21:42:20 +08:00
2025-07-25 21:14:24 +08:00
.grid-item3 {
width: 330px;
height: 210px;
border-radius: 6px 6px 6px 6px;
background: #ffffffdb;
padding: 40px 9px 7px 40px;
2025-07-22 21:42:20 +08:00
}
2025-07-25 21:14:24 +08:00
.grid-title {
font-family: Microsoft YaHei;
font-weight: 600;
font-size: 22px;
color: #000000;
letter-spacing: 1px;
}
2025-07-22 21:42:20 +08:00
2025-07-25 21:14:24 +08:00
.grid-sub-title {
font-family: Microsoft YaHei;
font-weight: 400;
font-size: 16px;
text-align: left;
color: #6C7B91;
margin-top: 16px;
span {
padding-right: 10px;
2025-07-22 21:42:20 +08:00
}
2025-07-25 21:14:24 +08:00
}
2025-07-22 21:42:20 +08:00
2025-07-25 21:14:24 +08:00
.grid-line {
width: 34px;
height: 3px;
border-radius: 1.5px 1.5px 1.5px 1.5px;
background: #467cf6;
margin: 0 auto;
}
2025-07-22 21:42:20 +08:00
2025-07-25 21:14:24 +08:00
.full-width {
grid-column: 1 / -1;
}
2025-07-22 21:42:20 +08:00
2025-07-25 21:14:24 +08:00
.notice-item {
padding: 10px 0;
border-bottom: 1px solid #eee;
}
2025-07-22 21:42:20 +08:00
2025-07-25 21:14:24 +08:00
.notice-item:last-child {
border-bottom: none;
}
2025-07-22 21:42:20 +08:00
2025-07-25 21:14:24 +08:00
.notice-date {
font-weight: bold;
margin-bottom: 5px;
}
2025-07-22 21:42:20 +08:00
2025-07-25 21:14:24 +08:00
.calibrationPlatform {
background-image: url("../assets/images/calibrationPlatform.png");
background-repeat: no-repeat;
background-position: right bottom;
}
2025-07-22 21:42:20 +08:00
2025-07-25 21:14:24 +08:00
.PPTAnalysisTool {
background-image: url("../assets/images/PPTAnalysisTool.png");
background-repeat: no-repeat;
background-position: right bottom;
}
.longitudeConversion {
background-image: url("../assets/images/longitudeConversion.png");
background-repeat: no-repeat;
background-position: right bottom;
}
.title-label {
font-family: Microsoft YaHei;
font-weight: 700;
font-size: 18px;
color: #FFFFFF;
span {
padding-left: 10px;
2025-07-22 21:42:20 +08:00
}
}
2025-07-25 21:14:24 +08:00
.title-container {
margin-bottom: 20px;
}
.resource-list {
font-family: Microsoft YaHei;
font-weight: 400;
font-size: 16px;
color: #FFFFFF;
padding: 0 0 0 18px !important;
margin: 6px 0px;
max-height: 416px;
overflow-y: auto;
}
.resource-link {
line-height: 28px;
}
</style>
<style>
.app-wrapper {
width: 100%;
height: 100vh;
background-image: url("../assets/images/bigBackgroud.png");
background-repeat: no-repeat;
/* 禁止平铺 */
background-size: cover;
/* 完全覆盖容器 */
}
</style>