mirror of
https://gitee.com/ccnetcore/Yi
synced 2026-04-29 04:33:24 +08:00
176 lines
4.3 KiB
Vue
176 lines
4.3 KiB
Vue
<template >
|
||
<div style="width: 1200px;">
|
||
<el-row :gutter="20" class="top-div">
|
||
|
||
<el-col :span="17">
|
||
<div class="scrollbar">
|
||
<ScrollbarInfo />
|
||
</div>
|
||
|
||
|
||
<el-row class="left-div">
|
||
<el-col :span="8" v-for="i in plateList" class="plate"
|
||
:style="{ 'padding-left': i % 3 == 1 ? 0 : 0.2 + 'rem', 'padding-right': i % 3 == 0 ? 0 : 0.2 + 'rem' }">
|
||
<PlateCard :name="i.name" :introduction="i.introduction" :id="i.id" />
|
||
</el-col>
|
||
|
||
<el-col :span="24" v-for="i in discussList">
|
||
<DisscussCard :discuss="i" />
|
||
|
||
</el-col>
|
||
<el-col :span="24">
|
||
<el-empty v-show="discussList.length <= 0" description="推荐位置,空空如也" />
|
||
</el-col>
|
||
</el-row>
|
||
|
||
</el-col>
|
||
|
||
<el-col :span="7">
|
||
<el-row class="right-div">
|
||
<el-col :span="24">
|
||
|
||
|
||
<el-carousel trigger="click" height="150px">
|
||
<el-carousel-item v-for="item in bannerList">
|
||
<div class="carousel-font" :style="{ color: item.color }">{{ item.name }}</div>
|
||
<el-image style="width: 100%; height: 100%" :src="item.logo" fit="cover" />
|
||
</el-carousel-item>
|
||
</el-carousel>
|
||
|
||
</el-col>
|
||
|
||
<el-col :span="24" >
|
||
<InfoCard header="访问统计" class="VisitsLineChart" text="详情">
|
||
<template #content>
|
||
<VisitsLineChart />
|
||
|
||
</template>
|
||
</InfoCard>
|
||
</el-col>
|
||
|
||
|
||
|
||
<el-col :span="24">
|
||
<InfoCard header="简介" text="详情">
|
||
<template #content>
|
||
<div class="introduce">
|
||
|
||
没有什么能够阻挡,人类对代码<span style="color: #1890ff;">优雅</span>的追求
|
||
</div>
|
||
|
||
</template>
|
||
</InfoCard>
|
||
</el-col>
|
||
|
||
<el-col :span="24">
|
||
<InfoCard :items=items header="本月排行" text="更多">
|
||
<template #item="temp">
|
||
<AvatarInfo>
|
||
<template #bottom>
|
||
本月积分:680
|
||
</template>
|
||
|
||
</AvatarInfo>
|
||
</template>
|
||
</InfoCard>
|
||
</el-col>
|
||
|
||
|
||
<el-col :span="24">
|
||
<InfoCard :items=items header="推荐好友" text="更多">
|
||
<template #item="temp">
|
||
<AvatarInfo />
|
||
</template>
|
||
</InfoCard>
|
||
</el-col>
|
||
|
||
|
||
<el-col :span="24" style=" background: transparent;">
|
||
<BottomInfo />
|
||
</el-col>
|
||
</el-row>
|
||
</el-col>
|
||
</el-row>
|
||
</div>
|
||
</template>
|
||
|
||
<script setup>
|
||
import DisscussCard from '@/components/DisscussCard.vue'
|
||
import InfoCard from '@/components/InfoCard.vue'
|
||
import PlateCard from '@/components/PlateCard.vue'
|
||
import ScrollbarInfo from '@/components/ScrollbarInfo.vue'
|
||
import AvatarInfo from '@/components/AvatarInfo.vue'
|
||
import BottomInfo from '@/components/BottomInfo.vue'
|
||
import VisitsLineChart from '@/components/echars/VisitsLineChart.vue'
|
||
|
||
import { getList } from '@/apis/plateApi.js'
|
||
import { getList as bannerGetList } from '@/apis/bannerApi.js'
|
||
import { getList as discussGetList } from '@/apis/discussApi.js'
|
||
import { onMounted, ref, reactive } from 'vue'
|
||
var plateList = ref([]);
|
||
var discussList = ref([]);
|
||
var bannerList = ref([]);
|
||
|
||
const items = [{ user: "用户1" }, { user: "用户2" }, { user: "用户3" }]
|
||
//主题查询参数
|
||
const query = reactive({
|
||
pageNum: 1,
|
||
pageSize: 10,
|
||
isTop: true
|
||
});
|
||
|
||
//初始化
|
||
onMounted(async () => {
|
||
plateList.value = (await getList()).data.items;
|
||
discussList.value = (await discussGetList(query)).data.items;
|
||
bannerList.value = (await bannerGetList()).data.items
|
||
});
|
||
|
||
|
||
</script>
|
||
<style scoped >
|
||
.introduce {
|
||
color: rgba(0, 0, 0, .45);
|
||
font-size: small;
|
||
}
|
||
|
||
.plate {
|
||
background: transparent !important;
|
||
|
||
}
|
||
|
||
.left-div .el-col {
|
||
background-color: #FFFFFF;
|
||
|
||
margin-bottom: 1rem;
|
||
}
|
||
|
||
.right-div .el-col {
|
||
background-color: #FFFFFF;
|
||
margin-bottom: 1rem;
|
||
}
|
||
|
||
.carousel-font {
|
||
position: absolute;
|
||
z-index: 1;
|
||
top: 10%;
|
||
left: 10%;
|
||
}
|
||
|
||
|
||
.top-div {
|
||
|
||
padding-top: 0.5rem;
|
||
}
|
||
|
||
.scrollbar {
|
||
display: block;
|
||
margin-bottom: 0.5rem;
|
||
}
|
||
.VisitsLineChart >>> .el-card__body
|
||
{
|
||
|
||
padding: 0.5rem;
|
||
}
|
||
</style>
|