<template> <mescroll-uni ref="mescrollRef" top="80rpx" @down="downCallback" @up="upCallback" :down="downOption" :up="upOption"> <view class="group-list"> <navigator v-for="(item, index) in groupList" :key="index" class="item bg-white mt20" hover-class="none" :url="'/bundle/pages/order_details/order_details?id=' + item.order_id"> <view class="group-header row-between"> <view> <view v-if="item.team_end_time">{{item.team_end_time}}</view> <view v-else> <view class="row" v-if="getTeamCountTime(item) >= 0"> <view class="sm mr10">{{item.shop_name}}</view> <!-- <u-count-down :timestamp="getTeamCountTime(item)" color="#fff" bg-color="#FF2C3C" separator-color="#FF2C3C" font-size="24" height="36" separator-size="26" @end="reflesh"></u-count-down> --> </view> </view> </view> <view :class="item.status == 2 ? 'muted' : 'primary'">{{getGroupStatus(item.status)}} </view> </view> <view class="group-con"> <view v-if="item.identity_text" class="team-chief xs white">{{item.identity_text}}</view> <order-goods :team="{need: item.need}" :list="[{people_num: item.people_num,name: item.name, spec_value_str: item.spec_value_str,image: item.image,goods_num: item.count, goods_id: item.goods_id, goods_price: item.order_amount}]"> </order-goods> <view class="all-price row-end"> <text class="muted xs">共{{item.count}}件商品,总金额:</text> <price-format show-subscript :subscript-size="30" :first-size="30" :second-size="30" :price="item.order_amount"></price-format> </view> </view> <view class="group-footer row" v-if="item.pay_status == 0"> <view style="flex: 1"></view> <view> <navigator v-if="item.pay_status == 0" hover-class="none" :url="'/pages/order_details/order_details?id=' + item.order_id"> <button size="sm" class="br60 lighter btn" type="primary" hover-class="none"> 去付款 </button> </navigator> </view> </view> </navigator> </view> </mescroll-uni> </template> <script> import {getUserGroup} from '@/api/activity'; import MescrollMixin from "@/components/mescroll-uni/mescroll-mixins.js"; import MescrollMoreItemMixin from "@/components/mescroll-uni/mixins/mescroll-more-item.js"; export default { mixins: [MescrollMixin, MescrollMoreItemMixin], data() { return { groupList: [], downOption: { auto: false // 不自动加载 (mixin已处理第一个tab触发downCallback) }, upOption: { auto: true, // 不自动加载 noMoreSize: 1, //如果列表已无数据,可设置列表的总数量要大于半页才显示无更多数据;避免列表数据过少(比如只有一条数据),显示无更多数据会不好看; 默认5 empty: { icon: '/static/images/goods_null.png', tip: '暂无拼团~', // 提示 fixed: true } }, }; }, props: { groupType: { type: Number } }, mounted() { // this.$getUserGroup(); }, methods: { // 触底加载 upCallback(page) { this.$getUserGroup(page.num, page.size); }, $getUserGroup(pageNum = 1, pageSize = 10) { let {groupType} = this; getUserGroup({ 'type': groupType, 'page_no': pageNum, 'page_size': pageSize }).then(res => { if (res) { let curPageData = res.data.list; let curPageLen = curPageData.length; let hasNext = !!res.data.more; if (pageNum == 1) this.lists = []; console.log(hasNext) this.groupList = this.lists.concat(curPageData); this.mescroll.endSuccess(curPageLen, hasNext); } }).catch(() => { this.mescroll.endErr() }) } }, computed: { // 计算属性,如果拼团状态等于某个值就返回某个值的文字状态 getGroupStatus() { return (status) => { var text = '' switch (status) { case 0: text = '拼团中'; break; case 1: text = '拼团成功'; break; case 2: text = '拼团失败'; break; } return text } }, getTeamCountTime() { return (item) => item.count_time = Math.min(item.found_end_time, item.end_time) - Date.now() / 1000 } } }; </script> <style lang="scss"> @import '@/styles/base.scss'; .group-list { min-height: calc(100vh - 80rpx); padding: 0 20rpx; overflow: hidden; .item { border-radius: 10rpx; position: relative; .group-header { height: 80rpx; padding: 0 24rpx; border-bottom: 1px dotted #E5E5E5; } .team-chief { position: absolute; z-index: 100; top: 105rpx; padding: 4rpx 20rpx; border-radius: 0 60rpx 60rpx 0; background: linear-gradient(87deg, #F95F2F 0%, #FF2C3C 100%); } .all-price { text-align: right; padding: 0 24rpx 20rpx; } .group-footer { height: 100rpx; border-top: $-solid-border; padding: 0 24rpx; .btn { width: 244rpx; } } } } </style>