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>
|