2020-06-04 08:21:34 +08:00
|
|
|
|
<template>
|
|
|
|
|
<view class="wash">
|
2020-07-27 09:36:59 +08:00
|
|
|
|
<view class="title">
|
2020-07-28 20:47:31 +08:00
|
|
|
|
<u-tabs-swiper ref="tabs" :list="list" :is-scroll="false" active-color="#FF780F" :current="current" font-size="32" :show-bar="false" @change="tabsChange" height="88"></u-tabs-swiper>
|
|
|
|
|
<u-icon name="arrow-down-fill" :color="current == 0 ? '#FF780F' : '#333333'" size="17" class="order-icon" :style="{ left: list[0].name == '平台历史订单' ? '236rpx' : '252rpx' }"></u-icon>
|
2020-08-04 19:08:04 +08:00
|
|
|
|
<view class="popup" v-if="showPopup" @click="onTap">
|
|
|
|
|
<view class="popup_cont" @click="replaces(1)">
|
|
|
|
|
实体店历史订单
|
|
|
|
|
</view>
|
|
|
|
|
<view class="popup_cont" @click="replaces(2)">
|
|
|
|
|
平台历史订单
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
2020-06-04 08:21:34 +08:00
|
|
|
|
</view>
|
2020-08-04 19:08:04 +08:00
|
|
|
|
<swiper :current="swiperCurrent" @animationfinish="animationfinish" :style="{ height: swiperHeight }">
|
2020-06-04 08:21:34 +08:00
|
|
|
|
<swiper-item class="swiper-item">
|
2020-07-28 20:47:31 +08:00
|
|
|
|
<scroll-view scroll-y class="order-list" @scrolltolower="loadmore">
|
|
|
|
|
<view v-for="(item, index) in orderList" :key="index" class="order-item">
|
2020-06-04 08:21:34 +08:00
|
|
|
|
<view class="order-title">
|
|
|
|
|
<view class="order-text">订单状态</view>
|
2020-07-28 20:47:31 +08:00
|
|
|
|
<view class="order-status">{{ item.order_status | viewStatus }}</view>
|
2020-06-04 08:21:34 +08:00
|
|
|
|
</view>
|
|
|
|
|
<view class="order-info">
|
2020-08-12 18:38:14 +08:00
|
|
|
|
<image :src="type == 1 ? item.goods_image : item.images[0]"></image>
|
2020-07-28 20:47:31 +08:00
|
|
|
|
<view v-if="item.deliver_goods_type == 2 && item.order_status == 20">
|
2020-07-30 20:33:16 +08:00
|
|
|
|
<view>骑手名字:{{ item.takeawayer_name || '' }}</view>
|
2020-08-04 19:08:04 +08:00
|
|
|
|
<view>联系方式:{{ item.takeawayer_mobile || '' }}</view>
|
2020-07-30 20:33:16 +08:00
|
|
|
|
<view>所属公司:{{ item.company || '' }}</view>
|
2020-07-28 20:47:31 +08:00
|
|
|
|
</view>
|
|
|
|
|
<view v-if="item.order_status == 0">
|
|
|
|
|
<view>正在等待接单</view>
|
|
|
|
|
</view>
|
|
|
|
|
<view v-if="item.order_status == 40">
|
|
|
|
|
<view>商家已拒绝</view>
|
|
|
|
|
</view>
|
|
|
|
|
<view v-if="item.order_status == 50">
|
|
|
|
|
<view>交易已完成</view>
|
|
|
|
|
</view>
|
|
|
|
|
<view v-if="item.deliver_goods_type == 1 && item.order_status == 20">
|
|
|
|
|
<view>商家在正路途中,请耐心等待</view>
|
2020-06-04 08:21:34 +08:00
|
|
|
|
</view>
|
|
|
|
|
</view>
|
2020-08-12 18:38:14 +08:00
|
|
|
|
<view class="send-btn" v-if="item.order_status == 20 || (item.order_status == 50&& !item.comment)">
|
|
|
|
|
<view class="btn" v-if="item.order_status == 20" @click="sendLaundryOrderConfirm(item.laundry_id)">确认完成</view>
|
|
|
|
|
<view class="btn" v-if="item.order_status == 50 && !item.comment" @click="toComment(item.laundry_id)">去评价</view>
|
2020-07-27 09:36:59 +08:00
|
|
|
|
</view>
|
2020-06-04 08:21:34 +08:00
|
|
|
|
</view>
|
|
|
|
|
</scroll-view>
|
|
|
|
|
</swiper-item>
|
|
|
|
|
<swiper-item class="swiper-item">
|
2020-06-08 15:23:23 +08:00
|
|
|
|
<scroll-view scroll-y style="height: 100%;" class="none-page">
|
2020-06-04 08:21:34 +08:00
|
|
|
|
<view></view>
|
|
|
|
|
</scroll-view>
|
|
|
|
|
</swiper-item>
|
|
|
|
|
<swiper-item class="swiper-item">
|
2020-06-08 15:23:23 +08:00
|
|
|
|
<scroll-view scroll-y class="comment">
|
2020-07-29 19:01:10 +08:00
|
|
|
|
<view v-for="(comment, index) in commentList" :key="index" class="comment-item">
|
|
|
|
|
<Comment :info="comment"></Comment>
|
2020-06-08 15:23:23 +08:00
|
|
|
|
</view>
|
2020-06-04 08:21:34 +08:00
|
|
|
|
</scroll-view>
|
|
|
|
|
</swiper-item>
|
|
|
|
|
</swiper>
|
|
|
|
|
</view>
|
|
|
|
|
</template>
|
|
|
|
|
<script>
|
2020-07-28 20:47:31 +08:00
|
|
|
|
import Comment from '@/components/mine/comment/index';
|
2020-06-04 08:21:34 +08:00
|
|
|
|
export default {
|
|
|
|
|
data() {
|
|
|
|
|
return {
|
2020-07-27 09:36:59 +08:00
|
|
|
|
showPopup: false,
|
2020-06-04 08:21:34 +08:00
|
|
|
|
list: [{
|
2020-07-27 09:36:59 +08:00
|
|
|
|
name: '平台历史订单'
|
2020-06-04 08:21:34 +08:00
|
|
|
|
}, {
|
|
|
|
|
name: '申请表'
|
|
|
|
|
}, {
|
|
|
|
|
name: '评价'
|
|
|
|
|
}],
|
|
|
|
|
current: 0,
|
2020-07-27 09:36:59 +08:00
|
|
|
|
swiperCurrent: 0,
|
2020-07-28 20:47:31 +08:00
|
|
|
|
btn_show:true,
|
|
|
|
|
page: 1,
|
|
|
|
|
orderList: [],
|
|
|
|
|
timer: true,
|
2020-07-29 19:01:10 +08:00
|
|
|
|
commentList: [],
|
2020-08-04 19:08:04 +08:00
|
|
|
|
swiperHeight: '',
|
2020-08-12 18:38:14 +08:00
|
|
|
|
type: 1, // 1 平台 2 实体店
|
2020-06-04 08:21:34 +08:00
|
|
|
|
}
|
|
|
|
|
},
|
2020-06-08 15:23:23 +08:00
|
|
|
|
components: {
|
|
|
|
|
Comment
|
|
|
|
|
},
|
2020-07-28 20:47:31 +08:00
|
|
|
|
filters: {
|
|
|
|
|
viewStatus(status) {
|
|
|
|
|
let state;
|
|
|
|
|
switch (status) {
|
|
|
|
|
case 0:
|
|
|
|
|
state = '等待接单';
|
|
|
|
|
break;
|
|
|
|
|
case 20:
|
|
|
|
|
state = '已接单';
|
|
|
|
|
break;
|
|
|
|
|
case 40:
|
|
|
|
|
state = '交易失败';
|
|
|
|
|
break;
|
|
|
|
|
case 50:
|
|
|
|
|
state = '交易成功';
|
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
return state;
|
|
|
|
|
},
|
|
|
|
|
},
|
2020-07-29 19:01:10 +08:00
|
|
|
|
watch: {
|
|
|
|
|
current(index) {
|
|
|
|
|
if(index == 1) {
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
url: '/pageE/tool/WashOrder'
|
|
|
|
|
});
|
|
|
|
|
this.showPopup = false;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
},
|
2020-08-03 18:38:04 +08:00
|
|
|
|
onPullDownRefresh() {
|
|
|
|
|
this.sendLaundryOrderList();
|
|
|
|
|
},
|
2020-06-04 08:21:34 +08:00
|
|
|
|
onShow() {
|
|
|
|
|
this.current = 0;
|
|
|
|
|
this.swiperCurrent = 0;
|
2020-07-28 20:47:31 +08:00
|
|
|
|
this.showPopup = false;
|
|
|
|
|
this.sendLaundryOrderList();
|
2020-07-29 19:01:10 +08:00
|
|
|
|
this.sendCommentList();
|
2020-06-04 08:21:34 +08:00
|
|
|
|
},
|
2020-08-04 19:08:04 +08:00
|
|
|
|
onLoad() {
|
|
|
|
|
this.setViewHeight();
|
|
|
|
|
},
|
2020-06-04 08:21:34 +08:00
|
|
|
|
methods: {
|
2020-07-28 20:47:31 +08:00
|
|
|
|
async sendLaundryOrderList({ load = 'reload' } = {}) {
|
2020-08-12 18:38:14 +08:00
|
|
|
|
// let type = this.list[0].name == '平台历史订单' ? 1 : 2;
|
2020-07-28 20:47:31 +08:00
|
|
|
|
const res = await this.$u.api.sendLaundryOrderList({
|
2020-08-12 18:38:14 +08:00
|
|
|
|
type: this.type,
|
2020-07-28 20:47:31 +08:00
|
|
|
|
page: this.page,
|
|
|
|
|
})
|
2020-08-03 18:38:04 +08:00
|
|
|
|
uni.stopPullDownRefresh();
|
2020-07-28 20:47:31 +08:00
|
|
|
|
this.timer = false;
|
|
|
|
|
if(res.errCode == 0) {
|
|
|
|
|
// this.orderList = res.data.list;
|
|
|
|
|
// console.log(...res.data.list);
|
|
|
|
|
if(load == 'loadmore') this.orderList = this.orderList.concat(res.data.list);
|
|
|
|
|
else if(load == 'reload') this.orderList = res.data.list;
|
|
|
|
|
} else {
|
|
|
|
|
this.orderList = [];
|
|
|
|
|
}
|
|
|
|
|
return res.data.list.length;
|
|
|
|
|
},
|
|
|
|
|
sendLaundryOrderConfirm(id) {
|
|
|
|
|
this.$u.api.sendLaundryOrderConfirm({ id: id }).then(res => {
|
|
|
|
|
if(res.errCode == 0) {
|
|
|
|
|
this.sendLaundryOrderList();
|
|
|
|
|
}
|
|
|
|
|
this.$u.toast(res.message);
|
|
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
loadmore() {
|
|
|
|
|
if(!this.timer) return false;
|
|
|
|
|
this.loadStatus = "loading";
|
|
|
|
|
this.page++;
|
|
|
|
|
this.sendLaundryOrderList({ load: 'loadmore' }).then(length => {
|
|
|
|
|
if(length == 0) {
|
|
|
|
|
this.page--;
|
|
|
|
|
this.status = 'nomore';
|
|
|
|
|
} else {
|
|
|
|
|
this.status = 'loading';
|
|
|
|
|
}
|
|
|
|
|
}).catch(() => {
|
|
|
|
|
this.loadStatus = "nomore";
|
|
|
|
|
this.page--;
|
|
|
|
|
})
|
|
|
|
|
},
|
2020-07-29 19:01:10 +08:00
|
|
|
|
// 送洗评论列表
|
|
|
|
|
sendCommentList() {
|
|
|
|
|
this.$u.api.sendCommentList().then(res => {
|
|
|
|
|
if(res.errCode == 0) {
|
|
|
|
|
this.commentList = res.data.list;
|
|
|
|
|
} else {
|
|
|
|
|
this.commentList = [];
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
},
|
2020-08-04 19:08:04 +08:00
|
|
|
|
setViewHeight() {
|
|
|
|
|
const res = uni.getSystemInfoSync();
|
2020-08-09 18:39:35 +08:00
|
|
|
|
this.swiperHeight = res.windowHeight - (88 * (res.windowWidth / 750)) + 'px';
|
2020-08-04 19:08:04 +08:00
|
|
|
|
},
|
2020-07-29 19:01:10 +08:00
|
|
|
|
toComment(id) {
|
|
|
|
|
this.$u.route('/pageE/tool/washComment', {
|
|
|
|
|
id: id
|
|
|
|
|
});
|
|
|
|
|
},
|
2020-06-04 08:21:34 +08:00
|
|
|
|
tabsChange(index) {
|
|
|
|
|
this.swiperCurrent = index;
|
2020-07-29 19:01:10 +08:00
|
|
|
|
if (index == 0){
|
|
|
|
|
this.showPopup = !this.showPopup;
|
|
|
|
|
} else {
|
|
|
|
|
this.showPopup = false;
|
|
|
|
|
}
|
2020-06-04 08:21:34 +08:00
|
|
|
|
},
|
|
|
|
|
animationfinish(e) {
|
|
|
|
|
let current = e.detail.current;
|
|
|
|
|
this.swiperCurrent = current;
|
|
|
|
|
this.current = current;
|
2020-07-27 09:36:59 +08:00
|
|
|
|
},
|
|
|
|
|
replaces(e){
|
|
|
|
|
if(e == 1){
|
2020-08-12 18:38:14 +08:00
|
|
|
|
this.type = 2;
|
2020-07-27 09:36:59 +08:00
|
|
|
|
this.$set(this.list,0,{name: '实体店历史订单'} )
|
2020-07-28 20:47:31 +08:00
|
|
|
|
} else {
|
2020-08-12 18:38:14 +08:00
|
|
|
|
this.type = 1;
|
2020-07-27 09:36:59 +08:00
|
|
|
|
this.$set(this.list,0,{name: '平台历史订单'} )
|
|
|
|
|
}
|
2020-07-28 20:47:31 +08:00
|
|
|
|
this.sendLaundryOrderList();
|
2020-07-27 09:36:59 +08:00
|
|
|
|
},
|
|
|
|
|
onTap(){
|
|
|
|
|
this.showPopup = false
|
2020-06-04 08:21:34 +08:00
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
};
|
|
|
|
|
</script>
|
|
|
|
|
<style lang="scss" scoped>
|
|
|
|
|
.wash {
|
|
|
|
|
min-height: calc(100vh - var(--window-top));
|
|
|
|
|
background-color: #ECECEC;
|
|
|
|
|
display: flex;
|
|
|
|
|
flex-direction: column;
|
|
|
|
|
> uni-swiper {
|
|
|
|
|
flex: 1;
|
2020-07-27 09:36:59 +08:00
|
|
|
|
}
|
2020-07-28 20:47:31 +08:00
|
|
|
|
.title {
|
|
|
|
|
position: relative;
|
|
|
|
|
.order-icon {
|
|
|
|
|
position: absolute;
|
|
|
|
|
top: 50%;
|
|
|
|
|
transform: translate(0, -50%);
|
|
|
|
|
z-index: 9;
|
|
|
|
|
}
|
2020-08-04 19:08:04 +08:00
|
|
|
|
.popup{
|
|
|
|
|
width: 100%;
|
|
|
|
|
height: calc(calc(100vh - 88rpx) - var(--window-top));
|
|
|
|
|
position: absolute;
|
|
|
|
|
top: 88rpx;
|
|
|
|
|
left: 0;
|
|
|
|
|
z-index: 9;
|
|
|
|
|
background-color: rgba(0, 0, 0, 0.4);
|
|
|
|
|
transform: scale(1);
|
|
|
|
|
display: flex;
|
|
|
|
|
flex-direction: column;
|
|
|
|
|
justify-content: top;
|
|
|
|
|
align-items: center;
|
|
|
|
|
transition-duration: 0.3s;
|
|
|
|
|
.popup_cont{
|
|
|
|
|
border-top: 1px solid RGBA(239, 236, 240, 1);
|
|
|
|
|
background-color: #fff;
|
|
|
|
|
width: 100%;
|
|
|
|
|
height: 80rpx;
|
|
|
|
|
line-height: 80rpx;
|
|
|
|
|
font-size:28rpx;
|
|
|
|
|
font-family:PingFang SC;
|
|
|
|
|
font-weight:400;
|
|
|
|
|
color:rgba(102,102,102,1);
|
|
|
|
|
padding-left: 41rpx;
|
|
|
|
|
position: relative;
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-06-04 08:21:34 +08:00
|
|
|
|
}
|
|
|
|
|
.swiper-item {
|
2020-06-08 15:23:23 +08:00
|
|
|
|
padding-top: 20rpx;
|
2020-06-04 08:21:34 +08:00
|
|
|
|
.order-list {
|
2020-06-08 15:23:23 +08:00
|
|
|
|
width: 100%;
|
|
|
|
|
height: 100%;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 0 30rpx;
|
2020-06-04 08:21:34 +08:00
|
|
|
|
.order-item {
|
|
|
|
|
padding: 30rpx;
|
2020-07-28 20:47:31 +08:00
|
|
|
|
width: 690rpx;
|
|
|
|
|
// height: 362rpx;
|
2020-06-04 08:21:34 +08:00
|
|
|
|
background: rgba(255,255,255,1);
|
|
|
|
|
border-radius: 10rpx;
|
|
|
|
|
margin-bottom: 20rpx;
|
|
|
|
|
.order-title {
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
margin-bottom: 30rpx;
|
|
|
|
|
.order-text {
|
|
|
|
|
font-size: 30rpx;
|
|
|
|
|
color: rgba(51,51,51,1);
|
|
|
|
|
}
|
|
|
|
|
.order-status {
|
|
|
|
|
font-size: 28rpx;
|
|
|
|
|
color: rgba(255,120,15,1);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
.order-info {
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
> image {
|
|
|
|
|
width: 180rpx;
|
|
|
|
|
height: 160rpx;
|
|
|
|
|
border-radius: 10rpx;
|
|
|
|
|
margin-right: 30rpx;
|
|
|
|
|
}
|
|
|
|
|
> view {
|
|
|
|
|
font-size: 26rpx;
|
|
|
|
|
color: rgba(51,51,51,1);
|
|
|
|
|
> view:not(:last-child) {
|
|
|
|
|
margin-bottom: 19rpx;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-07-27 17:59:47 +08:00
|
|
|
|
.send-btn {
|
2020-07-27 09:36:59 +08:00
|
|
|
|
width: 100%;
|
|
|
|
|
display: flex;
|
|
|
|
|
justify-content: flex-end;
|
|
|
|
|
margin-top: 30rpx;
|
2020-08-12 18:38:14 +08:00
|
|
|
|
.btn {
|
|
|
|
|
box-sizing: border-box;
|
2020-07-27 09:36:59 +08:00
|
|
|
|
width: 154rpx;
|
2020-08-13 16:07:19 +08:00
|
|
|
|
// height: 54rpx;
|
2020-07-27 09:36:59 +08:00
|
|
|
|
border-radius: 49rpx;
|
2020-08-12 18:38:14 +08:00
|
|
|
|
// transform: translate(-50%, 0);
|
2020-07-27 09:36:59 +08:00
|
|
|
|
font-size: 26rpx;
|
|
|
|
|
border: 1rpx solid rgba(255,120,15,1);
|
|
|
|
|
color:rgba(255,120,15,1);
|
2020-08-13 16:07:19 +08:00
|
|
|
|
text-align: center;
|
|
|
|
|
line-height: 54rpx;
|
2020-08-12 18:38:14 +08:00
|
|
|
|
// margin-right: -80rpx;
|
2020-08-13 16:07:19 +08:00
|
|
|
|
// display: flex;
|
|
|
|
|
// align-items: center;
|
|
|
|
|
// justify-content: center;
|
2020-07-27 09:36:59 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
2020-06-04 08:21:34 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
2020-06-08 15:23:23 +08:00
|
|
|
|
.comment {
|
|
|
|
|
width: 100%;
|
|
|
|
|
height: 100%;
|
|
|
|
|
.comment-item {
|
|
|
|
|
margin-bottom: 20rpx;
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-06-04 08:21:34 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
</style>
|