You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
228 lines
6.5 KiB
228 lines
6.5 KiB
<template> |
|
<view class="page_box"> |
|
<view class="content_box"> |
|
<scroll-view class="scroll-box" scroll-y enable-back-to-top scroll-with-animation @scrolltolower="loadMore"> |
|
<view class="group-wrap"> |
|
<view class="group-head x-bc"> |
|
<text class="group-head__title">爆款拼团</text> |
|
<text class="group-head__notice">省钱省心限时拼</text> |
|
</view> |
|
<view class="group-box"> |
|
<view class="goods-item" v-for="(groupon, index) in grouponList" :key="groupon.id"> |
|
<activity-card |
|
:cId="groupon.id" |
|
:title="groupon.title" |
|
:info="groupon.info" |
|
:img="groupon.image" |
|
:price="groupon.price" |
|
:productPrice="groupon.productPrice" |
|
> |
|
<block slot="tag"> |
|
<view class="tag" v-if="index < 3">TOP{{ index + 1 }}</view> |
|
</block> |
|
<block slot="sell"> |
|
<view class="x-f"> |
|
<view class="sell-box"> |
|
<text class="cuIcon-hotfill"></text> |
|
<text class="sell-num">已拼{{ groupon.sales }}件</text> |
|
</view> |
|
<text class="group-num">{{ groupon.people || 0 }}人团</text> |
|
</view> |
|
</block> |
|
<block slot="btn"><button class="cu-btn buy-btn" @tap.stop="jump('/pages/activity/GroupDetails/index', { id: groupon.id })">马上拼</button></block> |
|
</activity-card> |
|
</view> |
|
</view> |
|
</view> |
|
<!-- 空白 --> |
|
<!-- <Shop-empty v-if="!grouponList.length && !isLoading" :emptyData="emptyData"></Shop-empty>--> |
|
<!-- 加载更多 --> |
|
<view v-if="grouponList.length" class="cu-load text-gray" :class="loadStatus"></view> |
|
<!-- loading --> |
|
<Shop-load v-model="isLoading"></Shop-load> |
|
</scroll-view> |
|
</view> |
|
<!-- 自定义底部导航 --> |
|
<Shop-tabbar></Shop-tabbar> |
|
</view> |
|
</template> |
|
|
|
<script> |
|
import activityCard from './children/activity-card.vue'; |
|
import { getCombinationList } from "@/api/activity"; |
|
export default { |
|
components: { |
|
activityCard |
|
}, |
|
data() { |
|
return { |
|
emptyData: { |
|
img: '/static/imgs/empty/empty_goods.png', |
|
tip: '还没有拼团商品噢,去首页看看吧~', |
|
path: '/pages/index/index', |
|
pathText: '去首页逛逛' |
|
}, |
|
status:'', |
|
isLoading: true, |
|
loadStatus: '', //loading,over |
|
lastPage: 0, |
|
currentPage: 1, |
|
grouponList: [] |
|
}; |
|
}, |
|
onLoad() { |
|
this.getGrouponList(); |
|
}, |
|
onPullDownRefresh() {}, |
|
computed: {}, |
|
methods: { |
|
// 路由跳转 |
|
jump(path, parmas) { |
|
this.$yrouter.push({ |
|
path: path, |
|
query: parmas |
|
}); |
|
}, |
|
// 加载更多 |
|
loadMore() { |
|
if (this.currentPage < this.lastPage) { |
|
this.currentPage += 1; |
|
this.getGrouponList(); |
|
} |
|
}, |
|
// 拼团列表 |
|
getGrouponList() { |
|
let that = this; |
|
that.isLoading = true; |
|
that.loadStatus = 'loading'; |
|
getCombinationList({ page:that.currentPage, limit: 10 }).then(res => { |
|
that.status = res.data.length < 10; |
|
that.grouponList.push.apply(that.grouponList, res.data); |
|
that.lastPage = res.data.last_page; |
|
if (that.currentPage < res.data.last_page) { |
|
that.loadStatus = ''; |
|
} else { |
|
that.loadStatus = 'over'; |
|
} |
|
that.loading = false; |
|
}); |
|
|
|
// that.$api('goods.grouponList', { |
|
// page: that.currentPage |
|
// }).then(res => { |
|
// if (res.code === 1) { |
|
// that.isLoading = false; |
|
// that.grouponList = [...that.grouponList, ...res.data.data]; |
|
// // that.grouponList=[]; |
|
// that.lastPage = res.data.last_page; |
|
// if (that.currentPage < res.data.last_page) { |
|
// that.loadStatus = ''; |
|
// } else { |
|
// that.loadStatus = 'over'; |
|
// } |
|
// } |
|
// }); |
|
} |
|
} |
|
}; |
|
</script> |
|
|
|
<style lang="scss"> |
|
.group-wrap { |
|
background: url('~@/static/images/index-bg.png') no-repeat; |
|
background-size: 100% 374rpx; |
|
} |
|
.group-head { |
|
padding: 0 25rpx; |
|
height: 100rpx; |
|
.group-head__title { |
|
font-size: 32rpx; |
|
font-family: PingFang SC; |
|
font-weight: 500; |
|
color: rgba(255, 255, 255, 1); |
|
} |
|
.group-head__notice { |
|
font-size: 26rpx; |
|
font-family: PingFang SC; |
|
font-weight: 500; |
|
color: rgba(255, 255, 255, 1); |
|
} |
|
} |
|
|
|
.group-box { |
|
width: 710rpx; |
|
background: linear-gradient(#fff, #f5f5f5); |
|
border-radius: 20rpx; |
|
margin: 0 auto; |
|
min-height: 1000rpx; |
|
.goods-item { |
|
border-radius: 20rpx; |
|
overflow: hidden; |
|
position: relative; |
|
margin-bottom: 20rpx; |
|
.tag { |
|
position: absolute; |
|
left: 0; |
|
top: 10rpx; |
|
z-index: 2; |
|
line-height: 35rpx; |
|
background: linear-gradient(132deg, rgba(255, 153, 93, 1), rgba(255, 99, 97, 1)); |
|
border-radius: 0px 18rpx 18rpx 0px; |
|
padding: 0 10rpx; |
|
font-size: 24rpx; |
|
font-family: PingFang SC; |
|
font-weight: bold; |
|
color: rgba(255, 255, 255, 0.8); |
|
} |
|
/deep/.goods-right { |
|
width: 460rpx; |
|
.title { |
|
width: 460rpx; |
|
} |
|
.tip { |
|
width: 460rpx; |
|
} |
|
} |
|
.buy-btn { |
|
position: absolute; |
|
right: 0; |
|
bottom: -10rpx; |
|
width: 160rpx; |
|
height: 60rpx; |
|
background: linear-gradient(90deg, rgba(254, 131, 42, 1), rgba(255, 102, 0, 1)); |
|
box-shadow: 0px 7rpx 6rpx 0px rgba(255, 104, 4, 0.22); |
|
border-radius: 30rpx; |
|
font-size: 28rpx; |
|
font-family: PingFang SC; |
|
font-weight: 500; |
|
color: #fff; |
|
padding: 0; |
|
} |
|
.group-num { |
|
font-size: 20rpx; |
|
font-family: PingFang SC; |
|
font-weight: 500; |
|
color: rgba(153, 153, 153, 1); |
|
margin-left: 20rpx; |
|
} |
|
.sell-box { |
|
background: rgba(255, 224, 226, 0.3); |
|
border-radius: 16rpx; |
|
line-height: 32rpx; |
|
padding: 0 10rpx; |
|
.sell-num { |
|
font-size: 20rpx; |
|
font-family: PingFang SC; |
|
font-weight: 400; |
|
color: rgba(247, 151, 156, 1); |
|
} |
|
|
|
.cuIcon-hotfill { |
|
font-size: 26rpx; |
|
color: #e1212b; |
|
margin-right: 8rpx; |
|
} |
|
} |
|
} |
|
} |
|
</style>
|
|
|