Merge branch 'master' of https://gitee.com/beijing_hongye_huicheng/lilishop-uniapp
commit
e8d3b3decb
|
@ -1 +0,0 @@
|
||||||
qSyvBPhDsPdxvOhC
|
|
|
@ -2,8 +2,8 @@
|
||||||
"name" : "lili商城",
|
"name" : "lili商城",
|
||||||
"appid" : "__UNI__83F0C3D",
|
"appid" : "__UNI__83F0C3D",
|
||||||
"description" : "",
|
"description" : "",
|
||||||
"versionName" : "4.2.4.1",
|
"versionName" : "4.2.5",
|
||||||
"versionCode" : 4000241,
|
"versionCode" : 4000250,
|
||||||
"transformPx" : false,
|
"transformPx" : false,
|
||||||
"app-plus" : {
|
"app-plus" : {
|
||||||
"compatible" : {
|
"compatible" : {
|
||||||
|
|
|
@ -1,342 +1,269 @@
|
||||||
<template>
|
<template>
|
||||||
<view class="myTracks">
|
<view class="myTracks">
|
||||||
<u-navbar title="我的足迹">
|
<u-navbar title="我的足迹">
|
||||||
<div @click="changeRightBtn" slot="right" style="margin-right:32rpx">
|
|
||||||
{{edit}}
|
</u-navbar>
|
||||||
</div>
|
<u-empty text="暂无历史记录" style="margin-top:200rpx;" mode="history" v-if="whetherEmpty"></u-empty>
|
||||||
</u-navbar>
|
<div v-else>
|
||||||
<u-empty text="暂无历史记录" style="margin-top:200rpx;" mode="history" v-if="whetherEmpty"></u-empty>
|
|
||||||
<div v-else>
|
|
||||||
<view v-for="(item, index) in trackList" :key="index">
|
|
||||||
<view class="myTracks-title" @click="navgaiteToStore(item)">{{item.storeName}}</view>
|
|
||||||
<view class="myTracks-items">
|
|
||||||
<view class="myTracks-item">
|
|
||||||
<u-checkbox-group>
|
|
||||||
<u-checkbox v-model="item.___isDel" v-if="editFlag" active-color="#ff6b35" style="margin-right: 10rpx"
|
|
||||||
@change="changeChecked(item)"></u-checkbox>
|
|
||||||
</u-checkbox-group>
|
|
||||||
<view class="myTracks-item-img" @click.stop="navgaiteToDetail(item)">
|
|
||||||
<image :src="item.thumbnail"></image>
|
|
||||||
</view>
|
|
||||||
<view class="myTracks-item-content" @click.stop="navgaiteToDetail(item)">
|
|
||||||
<view class="myTracks-item-title">
|
|
||||||
{{ item.goodsName }}
|
|
||||||
<view class="myTracks-item-title-desc"> </view>
|
|
||||||
</view>
|
|
||||||
<view class="myTracks-item-price">
|
|
||||||
¥{{ item.price | unitPrice }}
|
|
||||||
</view>
|
|
||||||
</view>
|
|
||||||
</view>
|
|
||||||
</view>
|
|
||||||
<view class="myTracks-divider"></view>
|
|
||||||
|
|
||||||
</view>
|
|
||||||
<uni-load-more :status="loadStatus"></uni-load-more>
|
|
||||||
</div>
|
|
||||||
<view v-if="editFlag">
|
|
||||||
<view class="myTracks-action">
|
|
||||||
<view class="myTracks-action-check">
|
|
||||||
<u-checkbox-group>
|
|
||||||
<u-checkbox v-model="allChecked" v-if="editFlag" active-color="#ff6b35" style="margin-right: 10rpx"
|
|
||||||
@change="checkedAllitem"></u-checkbox>
|
|
||||||
全选
|
|
||||||
</u-checkbox-group>
|
|
||||||
</view>
|
|
||||||
|
|
||||||
<view>
|
|
||||||
<u-button type="warning" @click="delAllTracks" class="myTracks-action-btn">
|
<view v-for="(item, index) in trackList" :key="index">
|
||||||
删除
|
<view class="myTracks-title" @click="navgaiteToStore(item)">{{item.storeName}}</view>
|
||||||
</u-button>
|
<view class="myTracks-items">
|
||||||
</view>
|
|
||||||
</view>
|
<u-swipe-action style="width: 100%;" :show="item.show" :index="index" :key="item.id" @click="delTracks"
|
||||||
</view>
|
@open="open" :options="options">
|
||||||
</view>
|
<view class="myTracks-item">
|
||||||
|
<view class="myTracks-item-img" @click.stop="navgaiteToDetail(item)">
|
||||||
|
<image :src="item.thumbnail"></image>
|
||||||
|
</view>
|
||||||
|
<view class="myTracks-item-content" @click.stop="navgaiteToDetail(item)">
|
||||||
|
<view class="myTracks-item-title">
|
||||||
|
{{ item.goodsName }}
|
||||||
|
<view class="myTracks-item-title-desc"> </view>
|
||||||
|
</view>
|
||||||
|
<view class="myTracks-item-price">
|
||||||
|
¥{{ item.price | unitPrice }}
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
</u-swipe-action>
|
||||||
|
|
||||||
|
</view>
|
||||||
|
<view class="myTracks-divider"></view>
|
||||||
|
|
||||||
|
</view>
|
||||||
|
<uni-load-more :status="loadStatus"></uni-load-more>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</view>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import { myTrackList, deleteHistoryListId } from "@/api/members.js";
|
import {
|
||||||
|
myTrackList,
|
||||||
|
deleteHistoryListId
|
||||||
|
} from "@/api/members.js";
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
edit: "编辑",
|
loadStatus: "more", //底部下拉加载状态
|
||||||
editFlag: false, //是否编辑
|
whetherEmpty: false, //是否数据为空
|
||||||
allChecked: false, //是否全选
|
params: {
|
||||||
loadStatus: "more", //底部下拉加载状态
|
pageNumber: 1,
|
||||||
whetherEmpty: false, //是否数据为空
|
pageSize: 10,
|
||||||
params: {
|
order: "desc",
|
||||||
pageNumber: 1,
|
sort: "updateTime",
|
||||||
pageSize: 10,
|
},
|
||||||
order: "desc",
|
options: [
|
||||||
sort: "updateTime",
|
{
|
||||||
},
|
text: '删除',
|
||||||
|
style: {
|
||||||
|
backgroundColor: '#dd524d'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
trackList: [], //足迹列表
|
||||||
|
};
|
||||||
|
},
|
||||||
|
|
||||||
trackList: [], //足迹列表
|
/**
|
||||||
};
|
* 滑到底部加载下一页数据
|
||||||
},
|
*/
|
||||||
|
onReachBottom() {
|
||||||
|
if (this.loadStatus != "noMore") {
|
||||||
|
this.params.pageNumber++;
|
||||||
|
this.getList();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
onLoad() {
|
||||||
|
this.getList();
|
||||||
|
},
|
||||||
|
onPullDownRefresh() {
|
||||||
|
this.trackList = [];
|
||||||
|
this.getList();
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
/**
|
||||||
|
* 导航到店铺
|
||||||
|
*/
|
||||||
|
navgaiteToStore(val) {
|
||||||
|
uni.navigateTo({
|
||||||
|
url: "/pages/product/shopPage?id=" + val.storeId,
|
||||||
|
});
|
||||||
|
},
|
||||||
|
open(index) {
|
||||||
|
// 先将正在被操作的swipeAction标记为打开状态,否则由于props的特性限制,
|
||||||
|
// 原本为'false',再次设置为'false'会无效
|
||||||
|
this.trackList[index].show = true;
|
||||||
|
this.trackList.map((val, idx) => {
|
||||||
|
if (index != idx) this.trackList[idx].show = false;
|
||||||
|
})
|
||||||
|
},
|
||||||
|
/**
|
||||||
|
* 跳转详情
|
||||||
|
*/
|
||||||
|
navgaiteToDetail(item) {
|
||||||
|
uni.navigateTo({
|
||||||
|
url: "/pages/product/goods?id=" + item.id + "&goodsId=" + item.goodsId,
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 滑到底部加载下一页数据
|
* 获取我的足迹列表
|
||||||
*/
|
*/
|
||||||
onReachBottom() {
|
getList() {
|
||||||
if (this.loadStatus != "noMore") {
|
uni.showLoading({
|
||||||
this.params.pageNumber++;
|
title: "加载中",
|
||||||
this.getList();
|
});
|
||||||
}
|
myTrackList(this.params).then((res) => {
|
||||||
},
|
uni.stopPullDownRefresh();
|
||||||
onLoad() {
|
uni.hideLoading();
|
||||||
this.getList();
|
if (res.statusCode == 200) {
|
||||||
},
|
res.data.result &&
|
||||||
onPullDownRefresh() {
|
res.data.result.forEach((item) => {
|
||||||
this.trackList = [];
|
item.show = false;
|
||||||
this.getList();
|
});
|
||||||
},
|
|
||||||
methods: {
|
|
||||||
/**
|
|
||||||
* 导航到店铺
|
|
||||||
*/
|
|
||||||
navgaiteToStore(val) {
|
|
||||||
uni.navigateTo({
|
|
||||||
url: "/pages/product/shopPage?id=" + val.storeId,
|
|
||||||
});
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
let data = res.data.result;
|
||||||
* 设置右侧导航栏文本
|
if (data.total == 0) {
|
||||||
*/
|
this.whetherEmpty = true;
|
||||||
setStyle(text) {
|
} else if (data.total < 10) {
|
||||||
//导航按钮文本设置
|
this.loadStatus = "noMore";
|
||||||
let pages = getCurrentPages();
|
this.trackList.push(...data);
|
||||||
let page = pages[pages.length - 1];
|
} else {
|
||||||
// #ifdef APP-PLUS
|
this.trackList.push(...data);
|
||||||
let currentWebview = page.$getAppWebview();
|
if (data.length < 10) this.loadStatus = "noMore";
|
||||||
let titleNView = currentWebview.getStyle().titleNView;
|
}
|
||||||
titleNView.buttons[0].text = text;
|
}
|
||||||
if (text == "完成") {
|
});
|
||||||
this.trackList.forEach((key) => {
|
},
|
||||||
key.history.forEach((item) => {
|
|
||||||
this.$set(item, "___isDel", false);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
currentWebview.setStyle({
|
|
||||||
titleNView: titleNView,
|
|
||||||
});
|
|
||||||
// #endif
|
|
||||||
// #ifdef H5
|
|
||||||
// h5 临时方案
|
|
||||||
document.getElementsByClassName("uni-btn-icon")[1].innerText = text;
|
|
||||||
// #endif
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 跳转详情
|
|
||||||
*/
|
|
||||||
navgaiteToDetail(item) {
|
|
||||||
uni.navigateTo({
|
|
||||||
url: "/pages/product/goods?id=" + item.id + "&goodsId=" + item.goodsId,
|
|
||||||
});
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取我的足迹列表
|
* 删除足迹
|
||||||
*/
|
*/
|
||||||
getList() {
|
delTracks(index) {
|
||||||
uni.showLoading({
|
deleteHistoryListId(this.trackList[index].goodsId).then((res) => {
|
||||||
title: "加载中",
|
if (res.data.code == 200) {
|
||||||
});
|
this.trackList = [];
|
||||||
myTrackList(this.params).then((res) => {
|
this.getList();
|
||||||
uni.stopPullDownRefresh();
|
} else {
|
||||||
uni.hideLoading();
|
uni.showToast({
|
||||||
if (res.statusCode == 200) {
|
title: res.data.message,
|
||||||
res.data.result &&
|
duration: 2000,
|
||||||
res.data.result.forEach((item) => {
|
icon: "none",
|
||||||
item.___isDel = false;
|
});
|
||||||
});
|
}
|
||||||
|
});
|
||||||
let data = res.data.result;
|
},
|
||||||
if (data.total == 0) {
|
},
|
||||||
this.whetherEmpty = true;
|
};
|
||||||
} else if (data.total < 10) {
|
|
||||||
this.loadStatus = "noMore";
|
|
||||||
this.trackList.push(...data);
|
|
||||||
} else {
|
|
||||||
this.trackList.push(...data);
|
|
||||||
if (data.length < 10) this.loadStatus = "noMore";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 点击后判断是不是全选
|
|
||||||
*/
|
|
||||||
|
|
||||||
changeChecked(val) {
|
|
||||||
var opt = null;
|
|
||||||
const isCheckedAll = this.trackList.every((key) => {
|
|
||||||
key.___isDel == val.___isDel;
|
|
||||||
opt = key.___isDel;
|
|
||||||
return opt;
|
|
||||||
});
|
|
||||||
if(opt){
|
|
||||||
this.allChecked = isCheckedAll;
|
|
||||||
}else{
|
|
||||||
this.allChecked = false;
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 右侧标签栏切换
|
|
||||||
*/
|
|
||||||
changeRightBtn(e) {
|
|
||||||
if (!this.editFlag) {
|
|
||||||
this.edit = "完成";
|
|
||||||
} else {
|
|
||||||
this.edit = "编辑";
|
|
||||||
}
|
|
||||||
this.editFlag = !this.editFlag;
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 点击全选按钮
|
|
||||||
*/
|
|
||||||
checkedAllitem() {
|
|
||||||
//全选按钮
|
|
||||||
this.trackList.forEach((key) => {
|
|
||||||
this.$set(key, "___isDel", this.allChecked);
|
|
||||||
});
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 删除足迹
|
|
||||||
*/
|
|
||||||
delAllTracks() {
|
|
||||||
let way = [];
|
|
||||||
this.trackList.forEach((key) => {
|
|
||||||
if (key.___isDel) {
|
|
||||||
way.push(key.goodsId);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
if (way.length == 0) return false;
|
|
||||||
deleteHistoryListId(way).then((res) => {
|
|
||||||
if (res.data.code == 200) {
|
|
||||||
this.trackList = [];
|
|
||||||
this.allChecked = false;
|
|
||||||
this.getList();
|
|
||||||
} else {
|
|
||||||
uni.showToast({
|
|
||||||
title: res.data.message,
|
|
||||||
duration: 2000,
|
|
||||||
icon: "none",
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
},
|
|
||||||
},
|
|
||||||
};
|
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style lang="scss" scoped>
|
<style lang="scss" scoped>
|
||||||
.myTracks {
|
.myTracks {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
padding-top: 2rpx;
|
padding-top: 2rpx;
|
||||||
}
|
}
|
||||||
|
|
||||||
.myTracks-title {
|
.myTracks-title {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
height: 110rpx;
|
height: 110rpx;
|
||||||
padding-left: 20rpx;
|
padding-left: 20rpx;
|
||||||
font-size: 28rpx;
|
font-size: 28rpx;
|
||||||
color: #666;
|
color: #666;
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
background-color: #fff;
|
background-color: #fff;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
display: -webkit-box;
|
display: -webkit-box;
|
||||||
display: -webkit-flex;
|
display: -webkit-flex;
|
||||||
display: flex;
|
display: flex;
|
||||||
}
|
}
|
||||||
|
|
||||||
.myTracks-items {
|
.myTracks-items {
|
||||||
padding-top: 2rpx;
|
padding-top: 2rpx;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
display: -webkit-box;
|
display: -webkit-box;
|
||||||
display: -webkit-flex;
|
display: -webkit-flex;
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
}
|
}
|
||||||
|
|
||||||
.myTracks-item {
|
.myTracks-item {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
height: 226rpx;
|
height: 226rpx;
|
||||||
padding-left: 20rpx;
|
padding-left: 20rpx;
|
||||||
padding-right: 20rpx;
|
padding-right: 20rpx;
|
||||||
margin-bottom: 2rpx;
|
margin-bottom: 2rpx;
|
||||||
// border-radius: 6/@px;
|
// border-radius: 6/@px;
|
||||||
background-color: #fff;
|
background-color: #fff;
|
||||||
position: relative;
|
position: relative;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
display: -webkit-box;
|
display: -webkit-box;
|
||||||
display: -webkit-flex;
|
display: -webkit-flex;
|
||||||
display: flex;
|
display: flex;
|
||||||
}
|
}
|
||||||
|
|
||||||
.myTracks-item-img {
|
.myTracks-item-img {
|
||||||
margin-right: 20rpx;
|
margin-right: 20rpx;
|
||||||
border-radius: 8rpx;
|
border-radius: 8rpx;
|
||||||
image {
|
|
||||||
width: 130rpx;
|
|
||||||
height: 130rpx;
|
|
||||||
border-radius: 8rpx;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.myTracks-item-title {
|
image {
|
||||||
font-size: 28rpx;
|
width: 130rpx;
|
||||||
color: #333;
|
height: 130rpx;
|
||||||
}
|
border-radius: 8rpx;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
.myTracks-item-title-desc {
|
.myTracks-item-title {
|
||||||
font-size: 28rpx;
|
font-size: 28rpx;
|
||||||
color: #999;
|
color: #333;
|
||||||
}
|
}
|
||||||
|
|
||||||
.myTracks-item-price {
|
.myTracks-item-title-desc {
|
||||||
font-size: 28rpx;
|
font-size: 28rpx;
|
||||||
color: $light-color;
|
color: #999;
|
||||||
padding: 10rpx 0 0 0;
|
}
|
||||||
}
|
|
||||||
.myTracks-action{
|
|
||||||
display: flex;
|
|
||||||
justify-content: space-between;
|
|
||||||
position: fixed;
|
|
||||||
bottom: 0;
|
|
||||||
left: 0;
|
|
||||||
width: 100%;
|
|
||||||
background: #fff;
|
|
||||||
height: 75rpx;
|
|
||||||
align-items: center;
|
|
||||||
padding: 0 32rpx;
|
|
||||||
}
|
|
||||||
|
|
||||||
.myTracks-action-btn {
|
.myTracks-item-price {
|
||||||
width: 130rpx;
|
font-size: 28rpx;
|
||||||
height: 60rpx;
|
color: $light-color;
|
||||||
line-height: 60rpx;
|
padding: 10rpx 0 0 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.myTracks-divider {
|
.myTracks-action {
|
||||||
width: 100%;
|
display: flex;
|
||||||
height: 20rpx;
|
justify-content: space-between;
|
||||||
}
|
position: fixed;
|
||||||
|
bottom: 0;
|
||||||
|
left: 0;
|
||||||
|
width: 100%;
|
||||||
|
background: #fff;
|
||||||
|
height: 75rpx;
|
||||||
|
align-items: center;
|
||||||
|
padding: 0 32rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
.myTracks-action-btn {
|
||||||
|
width: 130rpx;
|
||||||
|
height: 60rpx;
|
||||||
|
line-height: 60rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
.myTracks-divider {
|
||||||
|
width: 100%;
|
||||||
|
height: 20rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
.myTracks-action-check {
|
.myTracks-action-check {
|
||||||
align-items: center;
|
align-items: center;
|
||||||
display: -webkit-box;
|
display: -webkit-box;
|
||||||
display: -webkit-flex;
|
display: -webkit-flex;
|
||||||
display: flex;
|
display: flex;
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|
|
@ -17,7 +17,8 @@
|
||||||
@clear="submitSearchOrderList(current)"
|
@clear="submitSearchOrderList(current)"
|
||||||
@custom="submitSearchOrderList(current)"
|
@custom="submitSearchOrderList(current)"
|
||||||
v-model="orderSn"
|
v-model="orderSn"
|
||||||
></u-search>
|
>
|
||||||
|
</u-search>
|
||||||
</div>
|
</div>
|
||||||
<scroll-view class="body-view" scroll-y @scrolltolower="renderDate">
|
<scroll-view class="body-view" scroll-y @scrolltolower="renderDate">
|
||||||
<view
|
<view
|
||||||
|
@ -60,78 +61,77 @@
|
||||||
<view>x{{ sku.num }}</view>
|
<view>x{{ sku.num }}</view>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
<view class="btn-view u-flex u-row-between">
|
<view class="description">
|
||||||
<view class="description">
|
<!-- 售后申请 -->
|
||||||
<!-- 售后申请 -->
|
<view v-if="current === 0 && order.groupAfterSaleStatus">
|
||||||
<view
|
<view
|
||||||
v-if="
|
v-if="order.groupAfterSaleStatus.includes('ALREADY_APPLIED')"
|
||||||
current === 0 &&
|
class="cannot_apply not_center"
|
||||||
order.groupAfterSaleStatus &&
|
|
||||||
order.groupAfterSaleStatus.includes('ALREADY_APPLIED')
|
|
||||||
"
|
|
||||||
class="cannot_apply"
|
|
||||||
>
|
>
|
||||||
<u-icon class="icon" name="info-circle-fill"></u-icon>
|
<u-icon class="icon" name="info-circle-fill"></u-icon>
|
||||||
该商品已申请售后服务
|
该商品已申请售后服务
|
||||||
</view>
|
</view>
|
||||||
|
</view>
|
||||||
|
<view v-if="current === 0 && order.groupAfterSaleStatus">
|
||||||
<view
|
<view
|
||||||
class="cannot_apply"
|
v-if="order.groupAfterSaleStatus.includes('EXPIRED')"
|
||||||
v-if="
|
class="cannot_apply not_center"
|
||||||
current === 0 &&
|
|
||||||
order.groupAfterSaleStatus &&
|
|
||||||
order.groupAfterSaleStatus.includes('EXPIRED')
|
|
||||||
"
|
|
||||||
@click="tipsShow = true"
|
@click="tipsShow = true"
|
||||||
>
|
>
|
||||||
<u-icon class="icon" name="info-circle-fill"></u-icon>
|
<u-icon class="icon" name="info-circle-fill"></u-icon>
|
||||||
该商品无法申请售后
|
该商品无法申请售后
|
||||||
</view>
|
</view>
|
||||||
|
|
||||||
<div v-if="current === 1 || current === 2">
|
|
||||||
<!-- 申请中 -->
|
|
||||||
<view
|
|
||||||
class="cannot_apply"
|
|
||||||
v-if="order.serviceType == 'RETURN_GOODS'"
|
|
||||||
>
|
|
||||||
退货处理-{{ order.serviceStatus | serviceStatusList }}</view
|
|
||||||
>
|
|
||||||
<view
|
|
||||||
class="cannot_apply"
|
|
||||||
v-if="order.serviceType == 'SUPPLY_AGAIN_GOODS'"
|
|
||||||
>
|
|
||||||
补发商品-{{ order.serviceStatus | serviceStatusList }}</view
|
|
||||||
>
|
|
||||||
<view
|
|
||||||
class="cannot_apply"
|
|
||||||
v-if="order.serviceType == 'RETURN_MONEY'"
|
|
||||||
>
|
|
||||||
退款-{{ order.serviceStatus | serviceStatusList }}</view
|
|
||||||
>
|
|
||||||
<view
|
|
||||||
class="cannot_apply"
|
|
||||||
v-if="order.serviceType == 'EXCHANGE_GOODS'"
|
|
||||||
>
|
|
||||||
换货-{{ order.serviceStatus | serviceStatusList }}</view
|
|
||||||
>
|
|
||||||
<view class="cannot_apply" v-if="order.serviceType == 'CANCEL'">
|
|
||||||
取消订单-{{ order.serviceStatus | serviceStatusList }}</view
|
|
||||||
>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- 申请记录 -->
|
|
||||||
</view>
|
</view>
|
||||||
<!-- 售后申请 -->
|
|
||||||
<div
|
<div v-if="current === 1 || current === 2">
|
||||||
v-if="
|
<!-- 申请中 -->
|
||||||
current === 0 &&
|
<view
|
||||||
sku.afterSaleStatus &&
|
class="cannot_apply not_center"
|
||||||
(sku.afterSaleStatus.includes('NOT_APPLIED') ||
|
v-if="order.serviceType == 'RETURN_GOODS'"
|
||||||
sku.afterSaleStatus.includes('PART_AFTER_SALE'))
|
>
|
||||||
"
|
退货处理-{{ order.serviceStatus | serviceStatusList }}</view
|
||||||
@click="applyService(sku.sn, order, sku)"
|
>
|
||||||
class="sale"
|
<view
|
||||||
>
|
class="cannot_apply not_center"
|
||||||
<view class="default-btn border"> 申请售后 </view>
|
v-if="order.serviceType == 'SUPPLY_AGAIN_GOODS'"
|
||||||
|
>
|
||||||
|
补发商品-{{ order.serviceStatus | serviceStatusList }}</view
|
||||||
|
>
|
||||||
|
<view
|
||||||
|
class="cannot_apply not_center"
|
||||||
|
v-if="order.serviceType == 'RETURN_MONEY'"
|
||||||
|
>
|
||||||
|
退款-{{ order.serviceStatus | serviceStatusList }}</view
|
||||||
|
>
|
||||||
|
<view
|
||||||
|
class="cannot_apply not_center"
|
||||||
|
v-if="order.serviceType == 'EXCHANGE_GOODS'"
|
||||||
|
>
|
||||||
|
换货-{{ order.serviceStatus | serviceStatusList }}</view
|
||||||
|
>
|
||||||
|
<view
|
||||||
|
class="cannot_apply not_center"
|
||||||
|
v-if="order.serviceType == 'CANCEL'"
|
||||||
|
>
|
||||||
|
取消订单-{{ order.serviceStatus | serviceStatusList }}</view
|
||||||
|
>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- 申请记录 -->
|
||||||
|
</view>
|
||||||
|
<view class="btn-view u-flex u-row-right">
|
||||||
|
<!-- 售后申请 -->
|
||||||
|
|
||||||
|
<div class="sale" v-if="current === 0 && sku.afterSaleStatus">
|
||||||
|
<div
|
||||||
|
v-if="
|
||||||
|
sku.afterSaleStatus.includes('NOT_APPLIED') ||
|
||||||
|
sku.afterSaleStatus.includes('PART_AFTER_SALE')
|
||||||
|
"
|
||||||
|
@click="applyService(sku.sn, order, sku)"
|
||||||
|
>
|
||||||
|
<view class="default-btn border"> 申请售后 </view>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<view class="after-line">
|
<view class="after-line">
|
||||||
<!-- 申请中 -->
|
<!-- 申请中 -->
|
||||||
|
@ -229,7 +229,7 @@ export default {
|
||||||
pageNumber: 1,
|
pageNumber: 1,
|
||||||
pageSize: 10,
|
pageSize: 10,
|
||||||
sort: "createTime",
|
sort: "createTime",
|
||||||
flowPrice: 1,
|
flowPrice: 0,
|
||||||
order: "desc",
|
order: "desc",
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -404,6 +404,10 @@ export default {
|
||||||
*/
|
*/
|
||||||
onExpress(order, sku) {
|
onExpress(order, sku) {
|
||||||
sku.storeName = order.storeName;
|
sku.storeName = order.storeName;
|
||||||
|
let data = {
|
||||||
|
...order,
|
||||||
|
...sku,
|
||||||
|
};
|
||||||
|
|
||||||
storage.setAfterSaleData(data);
|
storage.setAfterSaleData(data);
|
||||||
uni.navigateTo({
|
uni.navigateTo({
|
||||||
|
@ -458,31 +462,38 @@ page,
|
||||||
overflow-y: auto;
|
overflow-y: auto;
|
||||||
height: calc(100vh - 44px - 80rpx - 104rpx);
|
height: calc(100vh - 44px - 80rpx - 104rpx);
|
||||||
}
|
}
|
||||||
|
|
||||||
.u-tabs-search {
|
.u-tabs-search {
|
||||||
padding: 20rpx;
|
padding: 20rpx;
|
||||||
background: #fff;
|
background: #fff;
|
||||||
}
|
}
|
||||||
|
|
||||||
.countMoney {
|
.countMoney {
|
||||||
margin-left: 7rpx;
|
margin-left: 7rpx;
|
||||||
color: $main-color;
|
color: $main-color;
|
||||||
font-size: 28rpx;
|
font-size: 28rpx;
|
||||||
}
|
}
|
||||||
|
|
||||||
.seller-view {
|
.seller-view {
|
||||||
background-color: #fff;
|
background-color: #fff;
|
||||||
margin: 20rpx 0rpx;
|
margin: 20rpx 0rpx;
|
||||||
padding: 0rpx 20rpx;
|
padding: 0rpx 20rpx;
|
||||||
border-radius: 20rpx;
|
border-radius: 20rpx;
|
||||||
|
|
||||||
.seller-info {
|
.seller-info {
|
||||||
height: 70rpx;
|
height: 70rpx;
|
||||||
|
|
||||||
.seller-name {
|
.seller-name {
|
||||||
font-size: 28rpx;
|
font-size: 28rpx;
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: row;
|
flex-direction: row;
|
||||||
|
|
||||||
.name {
|
.name {
|
||||||
margin-left: 15rpx;
|
margin-left: 15rpx;
|
||||||
margin-top: -2rpx;
|
margin-top: -2rpx;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.order-sn {
|
.order-sn {
|
||||||
font-size: 22rpx;
|
font-size: 22rpx;
|
||||||
color: #909399;
|
color: #909399;
|
||||||
|
@ -526,6 +537,7 @@ page,
|
||||||
color: $main-color;
|
color: $main-color;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.btn-view {
|
.btn-view {
|
||||||
padding: 16rpx 0;
|
padding: 16rpx 0;
|
||||||
|
|
||||||
|
@ -535,10 +547,12 @@ page,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.description {
|
.description {
|
||||||
color: #909399;
|
color: #909399;
|
||||||
size: 25rpx;
|
size: 25rpx;
|
||||||
}
|
}
|
||||||
|
|
||||||
.cannot_apply {
|
.cannot_apply {
|
||||||
text-align: center;
|
text-align: center;
|
||||||
font-size: 22rpx;
|
font-size: 22rpx;
|
||||||
|
@ -547,6 +561,10 @@ page,
|
||||||
height: 70rpx;
|
height: 70rpx;
|
||||||
line-height: 70rpx;
|
line-height: 70rpx;
|
||||||
}
|
}
|
||||||
|
.not_center {
|
||||||
|
text-align: left;
|
||||||
|
}
|
||||||
|
|
||||||
.icon {
|
.icon {
|
||||||
margin-right: 10rpx;
|
margin-right: 10rpx;
|
||||||
}
|
}
|
||||||
|
@ -556,6 +574,7 @@ page,
|
||||||
display: flex;
|
display: flex;
|
||||||
justify-content: flex-end;
|
justify-content: flex-end;
|
||||||
}
|
}
|
||||||
|
|
||||||
.default-btn {
|
.default-btn {
|
||||||
background-color: #ffffff;
|
background-color: #ffffff;
|
||||||
margin-left: 15rpx;
|
margin-left: 15rpx;
|
||||||
|
@ -566,9 +585,11 @@ page,
|
||||||
padding: 0 24rpx;
|
padding: 0 24rpx;
|
||||||
border-radius: 200px;
|
border-radius: 200px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.close {
|
.close {
|
||||||
color: $light-color;
|
color: $light-color;
|
||||||
}
|
}
|
||||||
|
|
||||||
.border {
|
.border {
|
||||||
border: 2rpx solid $light-color;
|
border: 2rpx solid $light-color;
|
||||||
color: $light-color;
|
color: $light-color;
|
||||||
|
|
|
@ -139,7 +139,7 @@
|
||||||
shape="circle"
|
shape="circle"
|
||||||
class="cancel-btn"
|
class="cancel-btn"
|
||||||
size="mini"
|
size="mini"
|
||||||
v-if="order.groupAfterSaleStatus.includes('NOT_APPLIED')"
|
v-if="order.groupAfterSaleStatus && order.groupAfterSaleStatus.includes('NOT_APPLIED')"
|
||||||
@click="applyService(order)"
|
@click="applyService(order)"
|
||||||
>
|
>
|
||||||
退款/售后
|
退款/售后
|
||||||
|
|
|
@ -159,7 +159,7 @@ export default {
|
||||||
let recommendLives = await getLiveList(this.recommendParams);
|
let recommendLives = await getLiveList(this.recommendParams);
|
||||||
if (recommendLives.data.success) {
|
if (recommendLives.data.success) {
|
||||||
// 推荐直播间
|
// 推荐直播间
|
||||||
if (recommendLives.data.result.records.length != 0) {
|
if (recommendLives.data.result.records.length ) {
|
||||||
this.status = "loadmore";
|
this.status = "loadmore";
|
||||||
this.recommendLives = recommendLives.data.result.records;
|
this.recommendLives = recommendLives.data.result.records;
|
||||||
} else {
|
} else {
|
||||||
|
@ -172,7 +172,7 @@ export default {
|
||||||
* 2.如果没有直播间设置一个默认图片
|
* 2.如果没有直播间设置一个默认图片
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (this.recommendLives.length == 0) {
|
if (!this.recommendLives.length) {
|
||||||
if (this.liveList[0].shareImg) {
|
if (this.liveList[0].shareImg) {
|
||||||
this.$set(this, "swiperImg", [
|
this.$set(this, "swiperImg", [
|
||||||
{
|
{
|
||||||
|
@ -199,7 +199,7 @@ export default {
|
||||||
let res = await getLiveList(this.params[this.current]);
|
let res = await getLiveList(this.params[this.current]);
|
||||||
// 直播间
|
// 直播间
|
||||||
if (res.data.success) {
|
if (res.data.success) {
|
||||||
if (res.data.result.records.length != 0) {
|
if (res.data.result.records.length ) {
|
||||||
this.status = "loadmore";
|
this.status = "loadmore";
|
||||||
this.liveList.push(...res.data.result.records);
|
this.liveList.push(...res.data.result.records);
|
||||||
} else {
|
} else {
|
||||||
|
@ -211,7 +211,7 @@ export default {
|
||||||
? (this.status = "loadmore")
|
? (this.status = "loadmore")
|
||||||
: (this.status = "noMore");
|
: (this.status = "noMore");
|
||||||
|
|
||||||
console.log(this.status);
|
|
||||||
this.liveList.forEach((item) => {
|
this.liveList.forEach((item) => {
|
||||||
if (item.roomGoodsList) {
|
if (item.roomGoodsList) {
|
||||||
item.roomGoodsList = JSON.parse(item.roomGoodsList);
|
item.roomGoodsList = JSON.parse(item.roomGoodsList);
|
||||||
|
|
|
@ -51,7 +51,7 @@
|
||||||
<view class="goods-row" :class="{ invalid: isInvalid(skuItem) }">
|
<view class="goods-row" :class="{ invalid: isInvalid(skuItem) }">
|
||||||
<view class="goods-config">
|
<view class="goods-config">
|
||||||
<view>
|
<view>
|
||||||
<u-checkbox-group v-if="skuItem.invalid == 0">
|
<u-checkbox-group v-if="skuItem.invalid == 0 && !skuItem.errorMessage">
|
||||||
<!-- #ifndef MP-WEIXIN -->
|
<!-- #ifndef MP-WEIXIN -->
|
||||||
<u-checkbox shape="circle" :active-color="lightColor" class="c-left" v-model="skuItem.checked"
|
<u-checkbox shape="circle" :active-color="lightColor" class="c-left" v-model="skuItem.checked"
|
||||||
@change="checkboxChange(skuItem)"></u-checkbox>
|
@change="checkboxChange(skuItem)"></u-checkbox>
|
||||||
|
@ -99,7 +99,7 @@
|
||||||
>
|
>
|
||||||
<div class="promotions-item-seckill" v-if="getPromotion(skuItem).includes('SECKILL')">
|
<div class="promotions-item-seckill" v-if="getPromotion(skuItem).includes('SECKILL')">
|
||||||
距秒杀结束: <u-count-down show-border :hide-zero-day="true" :color="$mainColor" border-color="#ededed"
|
距秒杀结束: <u-count-down show-border :hide-zero-day="true" :color="$mainColor" border-color="#ededed"
|
||||||
font-size="24" :timestamp="getCountDownTime(seckill.endTime)">
|
font-size="24" :timestamp="getCountDownTime(skuItem)">
|
||||||
</u-count-down>
|
</u-count-down>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -110,7 +110,9 @@
|
||||||
预估到手价 ¥<span>{{ formatPrice(skuItem.priceDetailDTO.flowPrice)[0]}}</span>
|
预估到手价 ¥<span>{{ formatPrice(skuItem.priceDetailDTO.flowPrice)[0]}}</span>
|
||||||
<span>.{{ formatPrice(skuItem.priceDetailDTO.flowPrice)[1] }} </span>
|
<span>.{{ formatPrice(skuItem.priceDetailDTO.flowPrice)[1] }} </span>
|
||||||
</div>
|
</div>
|
||||||
|
<div style='margin-left: 20rpx;' v-if="!skuItem.checked && skuItem.errorMessage">
|
||||||
|
{{skuItem.errorMessage}}
|
||||||
|
</div>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
</u-swipe-action>
|
</u-swipe-action>
|
||||||
|
@ -192,8 +194,8 @@ export default {
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
isInvalid(val) {
|
isInvalid(val) {
|
||||||
//是否无效商品
|
//是否无效商品/没库存商品
|
||||||
if (val.invalid == 1) {
|
if (val.invalid == 1 || (!val.checked && val.errorMessage)) {
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
return false;
|
return false;
|
||||||
|
@ -236,12 +238,15 @@ export default {
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
/**
|
/**
|
||||||
* 倒数计时
|
* 倒数计时
|
||||||
*/
|
*/
|
||||||
getCountDownTime(val) {
|
getCountDownTime(val) {
|
||||||
let date = new Date(val.replace(/-/g, "/"));
|
if (val.promotionMap) {
|
||||||
let timeSimple = new Date(date).getTime() / 1000;
|
let key = Object.keys(val.promotionMap).find((child, index) => {
|
||||||
return timeSimple - new Date().getTime() / 1000;
|
return child.split("-")[0] == 'SECKILL'
|
||||||
|
});
|
||||||
|
return val.promotionMap[key].endTime / 1000 - (new Date().getTime() / 1000)
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -854,7 +854,7 @@ function downloadPopup(data, callback, cancelCallback, rebootCallback) {
|
||||||
export default function (isPrompt = false) {
|
export default function (isPrompt = false) {
|
||||||
getCurrentNo((version) => {
|
getCurrentNo((version) => {
|
||||||
getServerNo((res) => {
|
getServerNo((res) => {
|
||||||
if (res.versionCode.replace(/\./g, "") <= version.versionCode) {
|
if (res.versionCode.replace(/\./g, "") <= version.version) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue