598 lines
13 KiB
Vue
598 lines
13 KiB
Vue
<template>
|
||
<view>
|
||
<view class="tabr" :style="{top:headerTop}">
|
||
<view :class="{on:typeClass=='valid'}" @tap="switchType('valid')">可用({{couponValidList.length}})</view>
|
||
<view :class="{on:typeClass=='invalid'}" @tap="switchType('invalid')">已失效({{couponinvalidList.length}})
|
||
</view>
|
||
<view class="border" :class="typeClass"></view>
|
||
</view>
|
||
<view class="place"></view>
|
||
<view class="list">
|
||
<!-- 优惠券列表 -->
|
||
<view class="sub-list valid" :class="subState">
|
||
<view class="tis" v-if="couponValidList.length==0">没有数据~</view>
|
||
<view class="row" v-for="(row,index) in couponValidList" :key="index">
|
||
<!-- 删除按钮 -->
|
||
<view class="menu" @tap.stop="deleteCoupon(row.id,couponValidList)">
|
||
<view class="icon shanchu"></view>
|
||
</view>
|
||
<!-- content -->
|
||
<view class="carrier"
|
||
:class="[typeClass=='valid'?theIndex==index?'open':oldIndex==index?'close':'':'']"
|
||
@touchstart="touchStart(index,$event)" @touchmove="touchMove(index,$event)"
|
||
@touchend="touchEnd(index,$event)">
|
||
<view class="left">
|
||
<view class="title">
|
||
{{row.note}}
|
||
</view>
|
||
<view class="term" v-if="row.terStartime==0 && row.terEndtime==0">
|
||
永久有效
|
||
<!-- {{row.termStart}} ~ {{row.termEnd}} -->
|
||
</view>
|
||
<view class="term" v-else>
|
||
{{row.startTime|formatCreateTime}} ~ {{row.endTime |formatCreateTime}}
|
||
</view>
|
||
<view class="gap-top"></view>
|
||
<view class="gap-bottom"></view>
|
||
</view>
|
||
<view class="right">
|
||
<view class="ticket">
|
||
<view class="num">
|
||
|
||
</view>
|
||
<view class="unit">
|
||
|
||
</view>
|
||
</view>
|
||
<view class="criteria">
|
||
{{row.amount}} 元
|
||
</view>
|
||
<view class="use" @click="goUse">
|
||
去使用
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<view class="sub-list invalid" :class="subState">
|
||
<view class="tis" v-if="couponinvalidList.length==0">没有数据~</view>
|
||
<view class="row" v-for="(row,index) in couponinvalidList" :key="index">
|
||
<!-- 删除按钮 -->
|
||
<view class="menu" @tap.stop="deleteCoupon(row.id,couponinvalidList)">
|
||
<view class="icon shanchu"></view>
|
||
</view>
|
||
<!-- content -->
|
||
<view class="carrier"
|
||
:class="[typeClass=='invalid'?theIndex==index?'open':oldIndex==index?'close':'':'']"
|
||
@touchstart="touchStart(index,$event)" @touchmove="touchMove(index,$event)"
|
||
@touchend="touchEnd(index,$event)">
|
||
<view class="left">
|
||
<view class="title">
|
||
{{row.note}}
|
||
</view>
|
||
<view class="term" v-if="row.terStartime==0 && row.terEndtime==0">
|
||
已失效
|
||
<!-- {{row.termStart}} ~ {{row.termEnd}} -->
|
||
</view>
|
||
<view class="term" v-else>
|
||
{{row.startTime |formatCreateTime}} ~ {{row.endTime |formatCreateTime}}
|
||
</view>
|
||
<view class="icon shixiao">
|
||
|
||
</view>
|
||
<view class="gap-top"></view>
|
||
<view class="gap-bottom"></view>
|
||
</view>
|
||
<view class="right invalid">
|
||
<view class="ticket">
|
||
<view class="num">
|
||
|
||
</view>
|
||
<view class="unit">
|
||
|
||
</view>
|
||
</view>
|
||
<view class="criteria">
|
||
{{row.amount}}元
|
||
</view>
|
||
<!-- <view class="use">
|
||
去查看
|
||
</view> -->
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
|
||
</view>
|
||
</template>
|
||
|
||
<script>
|
||
import mallplusCopyright from '@/components/mall-copyright/mallplusCopyright.vue';
|
||
import Api from '@/common/api';
|
||
import eonfox from '@/components/eonfox/eonfox.js';
|
||
import fns from '@/components/eonfox/fns.js';
|
||
import {
|
||
formatDate
|
||
} from '@/common/date';
|
||
|
||
var ef = new eonfox();
|
||
export default {
|
||
data() {
|
||
return {
|
||
couponValidList: [
|
||
// {id:1,title:"日常用品立减10元",termStart:"2019-04-01",termEnd:"2019-05-30",ticket:"10",criteria:"满50使用"},
|
||
// {id:2,title:"家用电器立减100元",termStart:"2019-04-01",termEnd:"2019-05-30",ticket:"100",criteria:"满500使用"},
|
||
// {id:3,title:"全场立减10元",termStart:"2019-04-01",termEnd:"2019-05-30",ticket:"10",criteria:"无门槛"},
|
||
// {id:4,title:"全场立减50元",termStart:"2019-04-01",termEnd:"2019-05-30",ticket:"50",criteria:"满1000使用"}
|
||
|
||
],
|
||
couponinvalidList: [
|
||
// {id:1,title:"日常用品立减10元",termStart:"2019-04-01",termEnd:"2019-05-30",ticket:"10",criteria:"满50使用"},
|
||
// {id:2,title:"家用电器立减100元",termStart:"2019-04-01",termEnd:"2019-05-30",ticket:"100",criteria:"满500使用"},
|
||
// {id:3,title:"全场立减10元",termStart:"2019-04-01",termEnd:"2019-05-30",ticket:"10",criteria:"无门槛"},
|
||
// {id:4,title:"全场立减50元",termStart:"2019-04-01",termEnd:"2019-05-30",ticket:"50",criteria:"满1000使用"}
|
||
],
|
||
headerTop: 0,
|
||
//控制滑动效果
|
||
typeClass: 'valid',
|
||
subState: '',
|
||
theIndex: null,
|
||
oldIndex: null,
|
||
isStop: false
|
||
}
|
||
},
|
||
onPageScroll(e) {
|
||
|
||
},
|
||
//下拉刷新,需要自己在page.json文件中配置开启页面下拉刷新 "enablePullDownRefresh": true
|
||
onPullDownRefresh() {
|
||
setTimeout(function() {
|
||
uni.stopPullDownRefresh();
|
||
}, 1000);
|
||
},
|
||
onLoad() {
|
||
this.getData()
|
||
//兼容H5下排序栏位置
|
||
// #ifdef H5
|
||
//定时器方式循环获取高度为止,这么写的原因是onLoad中head未必已经渲染出来。
|
||
let Timer = setInterval(() => {
|
||
let uniHead = document.getElementsByTagName('uni-page-head');
|
||
if (uniHead.length > 0) {
|
||
this.headerTop = uniHead[0].offsetHeight + 'px';
|
||
clearInterval(Timer); //清除定时器
|
||
}
|
||
}, 1);
|
||
// #endif
|
||
},
|
||
filters: {
|
||
formatCreateTime(time) {
|
||
let date = new Date(time);
|
||
return formatDate(date, 'yyyy-MM-dd')
|
||
},
|
||
},
|
||
methods: {
|
||
goUse() {
|
||
uni.switchTab({
|
||
url: '/pages/index/index'
|
||
})
|
||
},
|
||
async getData() {
|
||
let params = {};
|
||
let data = await Api.apiCall('get', Api.index.listMemberCoupon, params);
|
||
let viewList = data;
|
||
console.log("viewList》》》》",viewList);
|
||
viewList.forEach(item => {
|
||
if (item.useStatus == 0) {
|
||
this.couponValidList.push(item);
|
||
} else {
|
||
this.couponinvalidList.push(item);
|
||
}
|
||
});
|
||
|
||
|
||
},
|
||
switchType(type) {
|
||
// console.log(type)
|
||
if (this.typeClass == type) {
|
||
return;
|
||
}
|
||
uni.pageScrollTo({
|
||
scrollTop: 0,
|
||
duration: 0
|
||
})
|
||
this.typeClass = type;
|
||
this.subState = this.typeClass == '' ? '' : 'show' + type;
|
||
setTimeout(() => {
|
||
this.oldIndex = null;
|
||
this.theIndex = null;
|
||
this.subState = this.typeClass == 'valid' ? '' : this.subState;
|
||
}, 200)
|
||
},
|
||
//控制左滑删除效果-begin
|
||
touchStart(index, event) {
|
||
//多点触控不触发
|
||
if (event.touches.length > 1) {
|
||
this.isStop = true;
|
||
return;
|
||
}
|
||
this.oldIndex = this.theIndex;
|
||
this.theIndex = null;
|
||
//初始坐标
|
||
this.initXY = [event.touches[0].pageX, event.touches[0].pageY];
|
||
},
|
||
touchMove(index, event) {
|
||
//多点触控不触发
|
||
if (event.touches.length > 1) {
|
||
this.isStop = true;
|
||
return;
|
||
}
|
||
let moveX = event.touches[0].pageX - this.initXY[0];
|
||
let moveY = event.touches[0].pageY - this.initXY[1];
|
||
|
||
if (this.isStop || Math.abs(moveX) < 5) {
|
||
return;
|
||
}
|
||
if (Math.abs(moveY) > Math.abs(moveX)) {
|
||
// 竖向滑动-不触发左滑效果
|
||
this.isStop = true;
|
||
return;
|
||
}
|
||
|
||
if (moveX < 0) {
|
||
this.theIndex = index;
|
||
this.isStop = true;
|
||
} else if (moveX > 0) {
|
||
if (this.theIndex != null && this.oldIndex == this.theIndex) {
|
||
this.oldIndex = index;
|
||
this.theIndex = null;
|
||
this.isStop = true;
|
||
setTimeout(() => {
|
||
this.oldIndex = null;
|
||
}, 150)
|
||
}
|
||
}
|
||
},
|
||
|
||
touchEnd(index, $event) {
|
||
//解除禁止触发状态
|
||
this.isStop = false;
|
||
},
|
||
|
||
//删除商品
|
||
deleteCoupon(id, List) {
|
||
let len = List.length;
|
||
for (let i = 0; i < len; i++) {
|
||
if (id == List[i].id) {
|
||
List.splice(i, 1);
|
||
break;
|
||
}
|
||
}
|
||
this.oldIndex = null;
|
||
this.theIndex = null;
|
||
},
|
||
|
||
discard() {
|
||
//丢弃
|
||
}
|
||
|
||
|
||
}
|
||
}
|
||
</script>
|
||
<style lang="scss">
|
||
view {
|
||
display: flex;
|
||
flex-wrap: wrap;
|
||
|
||
}
|
||
|
||
page {
|
||
position: relative;
|
||
background-color: #f5f5f5;
|
||
}
|
||
|
||
.hidden {
|
||
display: none !important;
|
||
}
|
||
|
||
.place {
|
||
width: 100%;
|
||
height: 95upx;
|
||
}
|
||
|
||
.tabr {
|
||
background-color: #fff;
|
||
/* #ifdef H5 || MP-WEIXIN*/
|
||
width: 100% !important;
|
||
/* #endif */
|
||
width: 100%;
|
||
height: 95upx;
|
||
padding: 0 3%;
|
||
border-bottom: solid 1upx #dedede;
|
||
position: fixed;
|
||
top: 0;
|
||
z-index: 10;
|
||
|
||
view {
|
||
width: 50%;
|
||
height: 90upx;
|
||
justify-content: center;
|
||
align-items: center;
|
||
font-size: 32upx;
|
||
color: #999;
|
||
}
|
||
|
||
.on {
|
||
color: $uni-color-success;
|
||
}
|
||
|
||
.border {
|
||
height: 4upx;
|
||
background-color: $uni-color-success;
|
||
transition: all .3s ease-out;
|
||
|
||
&.invalid {
|
||
transform: translate3d(100%, 0, 0);
|
||
}
|
||
}
|
||
|
||
}
|
||
|
||
.list {
|
||
width: 100%;
|
||
display: block;
|
||
position: relative;
|
||
}
|
||
|
||
@keyframes showValid {
|
||
0% {
|
||
transform: translateX(-100%);
|
||
}
|
||
|
||
100% {
|
||
transform: translateX(0);
|
||
}
|
||
}
|
||
|
||
@keyframes showInvalid {
|
||
0% {
|
||
transform: translateX(0);
|
||
}
|
||
|
||
100% {
|
||
transform: translateX(-100%);
|
||
}
|
||
}
|
||
|
||
.sub-list {
|
||
&.invalid {
|
||
position: absolute;
|
||
top: 0;
|
||
left: 100%;
|
||
display: none;
|
||
}
|
||
|
||
&.showvalid {
|
||
display: flex;
|
||
animation: showValid 0.20s linear both;
|
||
}
|
||
|
||
&.showinvalid {
|
||
display: flex;
|
||
animation: showInvalid 0.20s linear both;
|
||
}
|
||
|
||
width: 100%;
|
||
padding: 20upx 0 120upx 0;
|
||
|
||
.tis {
|
||
width: 100%;
|
||
height: 60upx;
|
||
justify-content: center;
|
||
align-items: center;
|
||
font-size: 32upx;
|
||
}
|
||
|
||
.row {
|
||
width: 92%;
|
||
height: 24vw;
|
||
margin: 20upx auto 10upx auto;
|
||
border-radius: 8upx;
|
||
// box-shadow: 0upx 0 10upx rgba(0,0,0,0.1);
|
||
align-items: center;
|
||
position: relative;
|
||
overflow: hidden;
|
||
z-index: 4;
|
||
border: 0;
|
||
|
||
.menu {
|
||
.icon {
|
||
color: #fff;
|
||
font-size: 50upx;
|
||
}
|
||
|
||
position: absolute;
|
||
width: 28%;
|
||
height: 100%;
|
||
right: 0;
|
||
justify-content: center;
|
||
align-items: center;
|
||
background-color: red;
|
||
color: #fff;
|
||
z-index: 2;
|
||
}
|
||
|
||
.carrier {
|
||
@keyframes showMenu {
|
||
0% {
|
||
transform: translateX(0);
|
||
}
|
||
|
||
100% {
|
||
transform: translateX(-28%);
|
||
}
|
||
}
|
||
|
||
@keyframes closeMenu {
|
||
0% {
|
||
transform: translateX(-28%);
|
||
}
|
||
|
||
100% {
|
||
transform: translateX(0);
|
||
}
|
||
}
|
||
|
||
&.open {
|
||
animation: showMenu 0.25s linear both;
|
||
}
|
||
|
||
&.close {
|
||
animation: closeMenu 0.15s linear both;
|
||
}
|
||
|
||
background-color: #fff;
|
||
position: absolute;
|
||
width: 100%;
|
||
padding: 0 0;
|
||
height: 100%;
|
||
z-index: 3;
|
||
flex-wrap: nowrap;
|
||
|
||
.left {
|
||
width: 100%;
|
||
|
||
.title {
|
||
padding-top: 3vw;
|
||
width: 90%;
|
||
margin: 0 5%;
|
||
font-size: 36upx;
|
||
}
|
||
|
||
.term {
|
||
width: 90%;
|
||
margin: 0 5%;
|
||
font-size: 26upx;
|
||
color: #999;
|
||
}
|
||
|
||
position: relative;
|
||
|
||
.gap-top,
|
||
.gap-bottom {
|
||
position: absolute;
|
||
width: 20upx;
|
||
height: 20upx;
|
||
right: -10upx;
|
||
border-radius: 100%;
|
||
background-color: #f5f5f5;
|
||
}
|
||
|
||
.gap-top {
|
||
top: -10upx;
|
||
}
|
||
|
||
.gap-bottom {
|
||
bottom: -10upx;
|
||
}
|
||
|
||
.shixiao {
|
||
position: absolute;
|
||
right: 20upx;
|
||
font-size: 150upx;
|
||
z-index: 6;
|
||
color: rgba(153, 153, 153, 0.2)
|
||
}
|
||
}
|
||
|
||
.right {
|
||
flex-shrink: 0;
|
||
width: 28%;
|
||
color: #fff;
|
||
background: linear-gradient(to right, #ec625c, #ee827f);
|
||
|
||
&.invalid {
|
||
background: linear-gradient(to right, #aaa, #999);
|
||
|
||
.use {
|
||
color: #aaa;
|
||
}
|
||
}
|
||
|
||
justify-content: center;
|
||
|
||
.ticket,
|
||
.criteria {
|
||
width: 100%;
|
||
}
|
||
|
||
.ticket {
|
||
padding-top: 1vw;
|
||
justify-content: center;
|
||
align-items: baseline;
|
||
height: 6vw;
|
||
|
||
.num {
|
||
font-size: 42upx;
|
||
font-weight: 600;
|
||
}
|
||
|
||
.unit {
|
||
font-size: 24upx;
|
||
}
|
||
}
|
||
|
||
.criteria {
|
||
justify-content: center;
|
||
|
||
font-size: 28upx;
|
||
}
|
||
|
||
.use {
|
||
width: 50%;
|
||
height: 40upx;
|
||
justify-content: center;
|
||
align-items: center;
|
||
font-size: 24upx;
|
||
background-color: #fff;
|
||
color: #ee827f;
|
||
border-radius: 40upx;
|
||
padding: 0 10upx;
|
||
}
|
||
}
|
||
}
|
||
|
||
/*
|
||
<view class="carrier" :class="[theIndex==index?'open':oldIndex==index?'close':'']" @touchstart="touchStart(index,$event)" @touchmove="touchMove(index,$event)" @touchend="touchEnd(index,$event)">
|
||
<view class="left">
|
||
<view class="title">
|
||
10元日常用品类
|
||
</view>
|
||
<view class="term">
|
||
2019-04-01~2019-05-30
|
||
</view>
|
||
</view>
|
||
<view class="right">
|
||
<view class="ticket">
|
||
<view class="num">
|
||
10
|
||
</view>
|
||
<view class="unit">
|
||
元
|
||
</view>
|
||
</view>
|
||
<view class="criteria">
|
||
满50使用
|
||
</view>
|
||
<view class="use">
|
||
去使用
|
||
</view>
|
||
</view>
|
||
</view>
|
||
*
|
||
* */
|
||
}
|
||
}
|
||
</style>
|