mall-laonong/pagesA/order/order.vue

372 lines
11 KiB
Vue
Raw Blame History

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

<template>
<view v-if="isLoading">
<status-nav :ifReturn="true" navBarTitle="订单管理" :backTag="backTag" :marginBottom="0"></status-nav>
<!-- 订单搜索 -->
<view class="order-search">
<input class="input font30 pad-zy40 color-66 radius20 border-box" v-model="order_coding" type="text" placeholder="请输入订单编号" confirm-type="search" @confirm="doSearch" placeholder-style="color:#666666">
</view>
<!-- 订单导航 -->
<view class="order-nav-bg mar-s30" :style="{top:newTop+'px'}">
<scroll-view scroll-x="true" :scroll-left="tabsScrollLeft" @scroll="scroll">
<view class="order-nav flex" id="tab_list" :style="{width:navWidth}">
<view id="tab_item" class="item font30 color-8c radius20" :class="activeIndex == index?'cur':''" v-for="(item,index) in orderNav" :key="index" @tap="changeNav(index,item.tag)">{{item.title}}</view>
</view>
</scroll-view>
</view>
<!-- 订单列表 -->
<view class="order-list">
<view class="order-item" @tap.stop="toDetail(item.id)" v-for="(item,index) in orderList" :key="index">
<view class="order-code flex">
<text>订单号:{{item.coding}}</text>
<text class="status color-red" v-if="item.status=='waiting'">{{item.status_text}}</text>
<text class="status" style="color: #02d20b;" v-if="item.status=='paid' || item.status=='shipped'">{{item.status_text}}</text>
<text class="status color-99" v-if="item.status=='completed' || item.status=='closed'">{{item.status_text}}</text>
</view>
<view class="item-bg">
<view class="item flex" v-for="(item1,index1) in item.skus" :key="index1">
<view class="img"><image :src="item1.spu_cover" mode="widthFix"></image></view>
<view class="txt">
<view class="title clips1">{{item1.spu_name}}</view>
<view class="specs clips2">规格{{item1.sku_name}}</view>
<view class="price flex">
<text>{{item1.price}}</text>
<view><text>x</text>{{item1.num}}</view>
</view>
</view>
</view>
</view>
<view class="total-price flex">
<text>合计{{item.price}}</text>
<view class="btns flex" v-if="item.status == 'waiting'">
<view class="btn border-box" @tap.stop="cancleEv(item.coding)">取消订单</view>
<view class="btn btn-01 border-box" @tap.stop="payEv(item.coding)">立即支付</view>
</view>
<view class="btns flex" v-if="item.status == 'paid'">
<view class="btn border-box" @tap.stop="cancleEv(item.coding)">取消订单</view>
</view>
<view class="btns flex" v-if="item.status == 'shipped'">
<view class="btn border-box" @tap.stop="refundEv">客服退款</view>
<view class="btn btn-02 border-box background-orange" @tap.stop="affirmEv(item.id)">确认收货</view>
</view>
<view class="btns flex" v-if="item.status == 'completed' || item.status == 'closed'">
<view class="btn border-box" @tap.stop="refundEv" v-if="item.status == 'completed'">客服退款</view>
<view class="btn border-box" @tap.stop="buyAgain(index)">再次购买</view>
</view>
</view>
</view>
</view>
<!-- 取消原因 -->
<view class="pull-bg" style="background-color: rgba(0,0,0,.3);" v-show="isOpen" @tap="closeEdit"></view>
<view class="vip-box-bg border-box" v-if="isOpen">
<view class="vip-box radius20 background-white font30">
<view class="title">取消理由</view>
<view class="cancle-reason">
<view class="item flex" v-for="(item,index) in cancleReason" :key="index" @tap="chooseEv(index)">
<label class="radio"><radio :checked="index==reasonIndex" color="#febf00"/></label>
<view class="txt font28">{{item.value}}</view>
</view>
</view>
<view class="submit-btn font36 background-orange radius30 mar-s60 flex" @tap="submitEdit">取消订单</view>
<view class="close-btn" @tap="closeEdit">
<image src="/static/icon/close-btn.png" mode="widthFix"></image>
</view>
</view>
</view>
<!-- 到底啦 -->
<view class="no-more font24" style="margin: 0;padding: 25rpx 0;" v-if="total!==0&&totalAll==total"><text>—— 到底啦 ——</text></view>
<!-- 没有内容 -->
<nothing-page v-if="total==0&&totalAll == total" content="还没有相关订单哟(*^▽^*)"></nothing-page>
</view>
</template>
<script>
import {getCartInfo} from '@/jsFile/public-api.js';
import {mapState} from 'vuex'//引入mapState
export default {
data() {
return {
newTop:uni.getSystemInfoSync().statusBarHeight + 50,
orderNav:[
{title:'全部',tag:'all'},
{title:'待付款',tag:'waiting'},
{title:'已下单',tag:'paid'},
{title:'已发货',tag:'shipped'},
{title:'已完成',tag:'completed'},
{title:'已取消',tag:'closed'},
],
activeIndex:0,
scrollLeft:0,
tabsScrollLeft:0,
navWidth:'', //导航宽度
orderList:[],
flag:true,
isLoading:false,
isOpen:false,
cancleReason:[], //取消理由
reasonIndex:0, //理由位置
cancleCode:'', // 取消订到号
total:0,
totalAll:-1,
page: 1,
size: 10,
tag: 'all',
order_coding:'', //订单号
backTag:'',
}
},
onLoad(op) {
if(op.tag && op.index){
this.tag = op.tag;
this.activeIndex = op.index;
setTimeout(()=>{
//计算左滑距离
this.setLeft()
},200)
}
if(op.backTag){this.backTag = op.backTag;}
this.navWidth = this.orderNav.length*150 - 20 + 'rpx';
},
onShow() {
this.orderList=[];
this.getOrderList();
},
onReachBottom(e) {
if(this.orderList.length<this.total){
this.page++;
this.getOrderList();
}
},
methods: {
//
changeNav(index,tag) {
this.total=0;
this.totalAll=-1;
this.activeIndex = index;
this.tag = tag;
this.orderList=[];
this.page = 1;
this.order_coding = '';
this.getOrderList();
//
this.setTabList();
},
//
doSearch(){
this.orderList = [];
this.activeIndex = 0;
this.tag = 'all'
//
this.getOrderList();
},
//
getOrderList(){
uni.showLoading({
title:''
});
let params = {
page: this.page,
size: this.size,
tag: this.tag,
order_coding:this.order_coding,
}
this.$requst.get('/api/user/order',params).then(res=>{
console.log(res,'订单列表')
if(res.data.length!=0){
this.total = res.data.total;
let newArr = [];
res.data.list.forEach(item=>{
let obj = {
id: item.id, //id
coding: item.coding, //订单号
price: item.price, //总价
status: item.status, //订单状态英文
status_text: item.status_text, //订单状态中文
skus: item.skus ,//订单详情
}
newArr.push(obj);
})
this.orderList = this.orderList.concat(newArr);
if(this.orderList.length == this.total){
this.totalAll = this.total;
}
}
uni.hideLoading();
this.isLoading = true;
})
},
// 去详情
toDetail(id){
uni.navigateTo({
url:`/pagesA/order/detail?id=${id}`
})
},
// 获取取消订单原因
getCancleReason(){
this.$requst.post('/api/order/cancellation-reason-all').then(res=>{
if(res.code==0) {
console.log(res,'取消订单原因');
this.cancleReason = res.data.list;
} else {
this.$toolAll.tools.showToast(res.msg)
}
})
},
// 取消订单
cancleEv(coding){
// 获取取消订单原因
this.getCancleReason();
this.isOpen =true;
this.cancleCode = coding;
},
// 选择取消原因
chooseEv(index){
if(index!==this.reasonIndex){
this.reasonIndex = index;
}
},
// 关闭弹窗
closeEdit(){
this.isOpen = false;
},
//确认取消订单
submitEdit(){
let params = {
order_coding: this.cancleCode, //订单号
remarks:this.cancleReason[this.reasonIndex].value, //取消原因
}
this.$requst.post('/api/order/cancel',params).then(res=>{
if(res.code==0) {
this.$toolAll.tools.showToast('取消订单成功(*^▽^*)');
this.orderList = [];
this.page = 1;
this.getOrderList();
this.isOpen = false;
} else {
this.$toolAll.tools.showToast(res.msg)
}
})
},
// 联系客服退款
refundEv(){
this.$toolAll.tools.countCustomer('18683958573')
},
// 确认收货
affirmEv(id){
let params = {
order_id: id //订单号
}
this.$requst.post('/api/order/accepted',params).then(res=>{
if(res.code==0) {
this.$toolAll.tools.showToast('确认收货成功(*^▽^*)');
this.orderList = [];
this.page = 1;
this.getOrderList();
} else {
this.$toolAll.tools.showToast(res.msg)
}
})
},
// 再次购买
buyAgain(index){
let buyList = [];
let newArr = this.orderList[index];
newArr.skus.forEach(item=>{
let obj = {
sku_coding: item.coding,
num: item.num
}
buyList.push(obj);
})
uni.setStorageSync('buyList',buyList);
uni.navigateTo({
url:'/pages/cart/settlement'
})
},
// 立即支付
payEv(coding){
this.$requst.post('/api/order/pay',{order_coding:coding}).then(res=>{
if(res.code==0) {
console.log(res,'立即支付');
// 调用微信支付
this.callPayMent(res.data.payment_params)
} else {
this.$toolAll.tools.showToast(res.msg)
}
})
},
// 调用微信支付
callPayMent(data){
//调起支付
wx.requestPayment({
'timeStamp': data.timeStamp,
'nonceStr': data.nonceStr,
'package': data.package,
"signType": data.signType,
'paySign': data.sign,
'success': function (res) { // 接口调用成功的回调函数
console.log('支付成功:',res);
this.$toolAll.tools.showToast('支付成功(*^▽^*)');
uni.navigateTo({
url:`/pages/cart/finish`
})
},
'fail': function (res) { // 接口调用失败的回调函数
console.log('支付失败:' + JSON.stringify(res));
}
})
},
// 分类切换效果
setTabList() {
this.$nextTick(() => {
if (this.orderNav.length > 0) {
//计算左滑距离
this.setLeft()
}
})
},
//计算左滑距离
setLeft() {
let lineLeft = 0;
this.getElementData('#tab_list', (data) => {
let list = data[0];
this.getElementData('#tab_item', (res) => {
let el = res[this.activeIndex]
lineLeft = el.width / 2 + (-list.left) + el.left - list.width / 2 - this.scrollLeft
this.tabsScrollLeft = this.scrollLeft + lineLeft
})
})
},
// 获取DOM距离
getElementData(el, callback) {
uni.createSelectorQuery().in(this).selectAll(el).boundingClientRect().exec((data) => {
callback(data[0]);
});
},
// 滚动
scroll(e) {
this.scrollLeft = e.detail.scrollLeft;
},
}
}
</script>
<style scoped>
</style>