|
|
|
<template>
|
|
|
|
<view class="flash-sale" ref="container">
|
|
|
|
<view class="header" v-if="headerImg">
|
|
|
|
<image :src="headerImg" />
|
|
|
|
</view>
|
|
|
|
<scroll-view scroll-y="false" scroll-x="true">
|
|
|
|
<view class="timeScroll">
|
|
|
|
<view v-for="(item, index) in timeList" :key="index">
|
|
|
|
<view v-if="active==index" class="timeItem active" @click="setTime(index)">
|
|
|
|
<view class="time">{{ item.time }}</view>
|
|
|
|
<view class="state">{{ item.state }}</view>
|
|
|
|
</view>
|
|
|
|
<view v-if="active!=index" class="timeItem" @click="setTime(index)">
|
|
|
|
<view class="time">{{ item.time }}</view>
|
|
|
|
<view class="state">{{ item.state }}</view>
|
|
|
|
</view>
|
|
|
|
</view>
|
|
|
|
</view>
|
|
|
|
</scroll-view>
|
|
|
|
<view v-for="(item, index) in timeList" :key="index">
|
|
|
|
<view v-if="active == index">
|
|
|
|
<view class="countDown font-color-red acea-row row-center-wrapper">
|
|
|
|
<view v-if="item.status === 0" class="activity">活动已结束</view>
|
|
|
|
<count-down
|
|
|
|
:isDay="false"
|
|
|
|
:tipText="'距结束仅剩 '"
|
|
|
|
:dayText="false"
|
|
|
|
:hourText="' : '"
|
|
|
|
:minuteText="' : '"
|
|
|
|
:secondText="false"
|
|
|
|
:datatime="datatime"
|
|
|
|
v-if="item.status === 1"
|
|
|
|
></count-down>
|
|
|
|
<view v-if="item.status === 2" class="activity">活动即将开始</view>
|
|
|
|
</view>
|
|
|
|
<view class="list">
|
|
|
|
<view
|
|
|
|
class="item acea-row row-between-wrapper"
|
|
|
|
v-for="(itemSeckill, indexSeckill) in seckillList"
|
|
|
|
:key="indexSeckill"
|
|
|
|
>
|
|
|
|
<view class="pictrue">
|
|
|
|
<image :src="itemSeckill.image" />
|
|
|
|
</view>
|
|
|
|
<view class="text acea-row row-column-around">
|
|
|
|
<view class="line1" v-text="itemSeckill.title"></view>
|
|
|
|
<view class="money">
|
|
|
|
限时价
|
|
|
|
<text class="num font-color-red" v-text="'¥' + itemSeckill.price"></text>
|
|
|
|
</view>
|
|
|
|
<view class="progress cart-color">
|
|
|
|
<view class="bg-red" :style="{ width: loading ? itemSeckill.percent + '%' : '' }"></view>
|
|
|
|
<view class="piece font-color-red" v-text="'仅剩' + itemSeckill.stock + '件'"></view>
|
|
|
|
</view>
|
|
|
|
</view>
|
|
|
|
<view
|
|
|
|
class="grab bg-color-red"
|
|
|
|
v-if="item.status === 1 && itemSeckill.stock > 0"
|
|
|
|
@click="goDetail(itemSeckill.id)"
|
|
|
|
>马上抢</view>
|
|
|
|
<view class="grab" v-if="item.status === 1 && itemSeckill.stock <= 0">已售磬</view>
|
|
|
|
<view class="grab bg-color-red" v-if="item.status === 2">即将开始</view>
|
|
|
|
<view class="grab bg-color-red" v-if="item.status === 0">已结束</view>
|
|
|
|
</view>
|
|
|
|
</view>
|
|
|
|
<view
|
|
|
|
class="noCommodity"
|
|
|
|
style="background-color: #fff;"
|
|
|
|
v-if="seckillList.length === 0 && page > 1"
|
|
|
|
>
|
|
|
|
<view class="noPictrue">
|
|
|
|
<image src="@/static/images/noGood.png" class="image" />
|
|
|
|
</view>
|
|
|
|
</view>
|
|
|
|
</view>
|
|
|
|
</view>
|
|
|
|
</view>
|
|
|
|
</template>
|
|
|
|
<script>
|
|
|
|
import { getSeckillConfig, getSeckillList } from "@/api/activity";
|
|
|
|
import CountDown from "@/components/CountDown";
|
|
|
|
// import { Tab, Tabs } from "vant-weapp";
|
|
|
|
import Loading from "@/components/Loading";
|
|
|
|
|
|
|
|
export default {
|
|
|
|
name: "GoodsSeckill",
|
|
|
|
components: {
|
|
|
|
CountDown
|
|
|
|
},
|
|
|
|
props: {},
|
|
|
|
data: function() {
|
|
|
|
return {
|
|
|
|
headerImg: "",
|
|
|
|
timeList: [],
|
|
|
|
sticky: false,
|
|
|
|
loading: false,
|
|
|
|
datatime: 0,
|
|
|
|
active: 0,
|
|
|
|
seckillList: [],
|
|
|
|
status: false, //砍价列表是否获取完成 false 未完成 true 完成
|
|
|
|
loadingList: false, //当前接口是否请求完成 false 完成 true 未完成
|
|
|
|
page: 1, //页码
|
|
|
|
limit: 5, //数量
|
|
|
|
title: []
|
|
|
|
};
|
|
|
|
},
|
|
|
|
mounted: function() {
|
|
|
|
this.mountedStart();
|
|
|
|
},
|
|
|
|
onReachBottom() {
|
|
|
|
!this.loadingList && this.getSeckillList();
|
|
|
|
},
|
|
|
|
methods: {
|
|
|
|
changeTime: function(index) {
|
|
|
|
this.active = index;
|
|
|
|
this.getSeckillList();
|
|
|
|
},
|
|
|
|
mountedStart: function() {
|
|
|
|
var that = this;
|
|
|
|
uni.showLoading();
|
|
|
|
getSeckillConfig().then(res => {
|
|
|
|
that.$set(that, "headerImg", res.data.lovely);
|
|
|
|
that.$set(that, "timeList", res.data.seckillTime);
|
|
|
|
that.$set(that, "active", res.data.seckillTimeIndex);
|
|
|
|
|
|
|
|
let title = [];
|
|
|
|
title = res.data.seckillTime.map((item, index) => {
|
|
|
|
return {
|
|
|
|
name: "div",
|
|
|
|
attrs: {
|
|
|
|
class: "timeItem"
|
|
|
|
},
|
|
|
|
children: [
|
|
|
|
{
|
|
|
|
name: "div",
|
|
|
|
attrs: {
|
|
|
|
class: "time"
|
|
|
|
},
|
|
|
|
children: [
|
|
|
|
{
|
|
|
|
type: "text",
|
|
|
|
text: item.time
|
|
|
|
}
|
|
|
|
]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "div",
|
|
|
|
attrs: {
|
|
|
|
class: "state"
|
|
|
|
},
|
|
|
|
children: [
|
|
|
|
{
|
|
|
|
type: "text",
|
|
|
|
text: item.state
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
]
|
|
|
|
};
|
|
|
|
});
|
|
|
|
that.$set(that, "title", title);
|
|
|
|
that.datatime = that.timeList[that.active].stop;
|
|
|
|
that.getSeckillList();
|
|
|
|
that.$nextTick(function() {
|
|
|
|
that.sticky = true;
|
|
|
|
uni.hideLoading();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
},
|
|
|
|
setTime: function(index) {
|
|
|
|
var that = this;
|
|
|
|
that.page = 1;
|
|
|
|
that.loadingList = false;
|
|
|
|
that.status = false;
|
|
|
|
that.active = index;
|
|
|
|
that.datatime = that.timeList[that.active].stop;
|
|
|
|
this.seckillList = [];
|
|
|
|
that.getSeckillList();
|
|
|
|
},
|
|
|
|
getSeckillList: function() {
|
|
|
|
var that = this;
|
|
|
|
if (that.loadingList) return;
|
|
|
|
if (that.status) return;
|
|
|
|
var time = that.timeList[that.active].id;
|
|
|
|
getSeckillList(time, {
|
|
|
|
page: that.page,
|
|
|
|
limit: that.limit
|
|
|
|
}).then(res => {
|
|
|
|
that.status = res.data.length < that.limit;
|
|
|
|
that.seckillList.push.apply(that.seckillList, res.data);
|
|
|
|
that.page++;
|
|
|
|
uni.hideLoading();
|
|
|
|
});
|
|
|
|
},
|
|
|
|
goDetail: function(id) {
|
|
|
|
var that = this;
|
|
|
|
var time = that.timeList[that.active].stop;
|
|
|
|
this.$yrouter.push({
|
|
|
|
path: "/pages/activity/SeckillDetails/index",
|
|
|
|
query: {
|
|
|
|
id,
|
|
|
|
time
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
</script>
|
|
|
|
<style scoped lang="less">
|
|
|
|
.timeScroll {
|
|
|
|
display: flex;
|
|
|
|
align-items: center;
|
|
|
|
flex-direction: row;
|
|
|
|
}
|
|
|
|
|
|
|
|
.timeItem {
|
|
|
|
font-size: 0.22 * 100rpx;
|
|
|
|
color: #282828;
|
|
|
|
width: 150rpx;
|
|
|
|
text-align: center;
|
|
|
|
padding: 0.11 * 100rpx 0;
|
|
|
|
background-color: none;
|
|
|
|
|
|
|
|
&.active {
|
|
|
|
.time {
|
|
|
|
color: #eb3729;
|
|
|
|
}
|
|
|
|
|
|
|
|
.state {
|
|
|
|
background-color: #eb3729;
|
|
|
|
color: #fff;
|
|
|
|
opacity: 1;
|
|
|
|
border-radius: 30rpx;
|
|
|
|
padding: 0 0.2 * 100rpx;
|
|
|
|
font-weight: 800;
|
|
|
|
height: 0.37 * 100rpx;
|
|
|
|
line-height: 0.37 * 100rpx;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
.timeItem .time {
|
|
|
|
font-size: 0.32 * 100rpx;
|
|
|
|
font-weight: bold;
|
|
|
|
height: 0.37 * 100rpx;
|
|
|
|
line-height: 0.37 * 100rpx;
|
|
|
|
}
|
|
|
|
|
|
|
|
.timeItem .state {
|
|
|
|
height: 0.37 * 100rpx;
|
|
|
|
line-height: 0.37 * 100rpx;
|
|
|
|
}
|
|
|
|
|
|
|
|
.activity {
|
|
|
|
color: #333;
|
|
|
|
}
|
|
|
|
|
|
|
|
.flash-sale .list .item .grab {
|
|
|
|
background-color: #999;
|
|
|
|
}
|
|
|
|
</style>
|