105 lines
2.3 KiB
Vue
105 lines
2.3 KiB
Vue
<template>
|
||
<view class="tab-page">
|
||
<view class="tab-page__header">
|
||
<text class="tab-page__title">发现</text>
|
||
<text class="tab-page__subtitle">活动 · 资讯 · 今日推荐</text>
|
||
</view>
|
||
|
||
<TodayRecommend />
|
||
|
||
<view class="discover-links">
|
||
<view class="discover-link" hover-class="discover-link--hover" @tap="goReferral">
|
||
<text class="discover-link__title">邀请好友</text>
|
||
<text class="discover-link__desc">邀请注册/购课,双方得积分</text>
|
||
</view>
|
||
<view class="discover-link" hover-class="discover-link--hover" @tap="goCouponCenter">
|
||
<text class="discover-link__title">领券中心</text>
|
||
<text class="discover-link__desc">限时优惠券,先到先得</text>
|
||
</view>
|
||
<view class="discover-link" hover-class="discover-link--hover" @tap="goPointsMall">
|
||
<text class="discover-link__title">积分商城</text>
|
||
<text class="discover-link__desc">积分兑换好礼</text>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="bottom-placeholder"></view>
|
||
<TabBar :active="3" />
|
||
</view>
|
||
</template>
|
||
|
||
<script setup>
|
||
import TodayRecommend from '@/components/index/TodayRecommend.vue'
|
||
import TabBar from '@/components/TabBar.vue'
|
||
import { PAGE, navigateToPage } from '@/common/constants/routes.js'
|
||
|
||
function goReferral() {
|
||
navigateToPage(PAGE.REFERRAL)
|
||
}
|
||
|
||
function goCouponCenter() {
|
||
navigateToPage(PAGE.COUPON_CENTER)
|
||
}
|
||
|
||
function goPointsMall() {
|
||
navigateToPage(PAGE.POINTS_MALL)
|
||
}
|
||
</script>
|
||
|
||
<style lang="scss" scoped>
|
||
.tab-page {
|
||
min-height: 100vh;
|
||
background-color: #f0f4f8;
|
||
padding-bottom: 160rpx;
|
||
}
|
||
|
||
.tab-page__header {
|
||
padding: 48rpx 32rpx 16rpx;
|
||
}
|
||
|
||
.tab-page__title {
|
||
display: block;
|
||
font-size: 40rpx;
|
||
font-weight: 700;
|
||
color: #1a202c;
|
||
}
|
||
|
||
.tab-page__subtitle {
|
||
display: block;
|
||
margin-top: 8rpx;
|
||
font-size: 24rpx;
|
||
color: #64748b;
|
||
}
|
||
|
||
.discover-links {
|
||
display: flex;
|
||
flex-direction: column;
|
||
gap: 16rpx;
|
||
padding: 24rpx 32rpx;
|
||
}
|
||
|
||
.discover-link {
|
||
padding: 24rpx 28rpx;
|
||
border-radius: 20rpx;
|
||
background: #fff;
|
||
box-shadow: 0 2rpx 12rpx rgba(0, 0, 0, 0.06);
|
||
}
|
||
|
||
.discover-link__title {
|
||
display: block;
|
||
font-size: 28rpx;
|
||
font-weight: 600;
|
||
color: #1e2a3a;
|
||
}
|
||
|
||
.discover-link__desc {
|
||
display: block;
|
||
margin-top: 6rpx;
|
||
font-size: 22rpx;
|
||
color: #64748b;
|
||
}
|
||
|
||
.bottom-placeholder {
|
||
height: 40rpx;
|
||
}
|
||
</style>
|