176 lines
3.8 KiB
Vue
176 lines
3.8 KiB
Vue
|
<template>
|
|||
|
<view class="express-info" v-if="!loadding">
|
|||
|
<view class="top-tabbar" v-if="express.length>0">
|
|||
|
<view class="tab-item" :class="{ active: expressIndex == index }" @click="changeIndex(index)"
|
|||
|
v-for="(item, index) in express" :key="index">{{$t("MY_ORD_20")}}</view>
|
|||
|
</view>
|
|||
|
<view class="d-c-c p30" v-if="express.length == 0">
|
|||
|
<text class="iconfont icon-wushuju"></text>
|
|||
|
<text class="cont">{{$t('w_0405')}}</text>
|
|||
|
</view>
|
|||
|
<view class="base-info p30 d-b-c" v-if="express.length>0">
|
|||
|
<image class="express-img" src="/static/icon/order/express-detail.png" mode=""></image>
|
|||
|
<view class="ml20 flex-1">
|
|||
|
<view class="name">
|
|||
|
<text class="gray9">{{$t("MY_ORD_21")}}:</text>
|
|||
|
<text class="fb">{{ detailData.expressName }}</text>
|
|||
|
</view>
|
|||
|
<view class="order-code pt20">
|
|||
|
<text class="gray9">{{$t("MN_F_T_226")}}:</text>
|
|||
|
<text class="fb">{{ detailData.expressCode }}</text>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
<view class="list" v-if="detailData.detailList">
|
|||
|
<view :class="index == 0 ? 'active item' : 'item'" v-for="(item, index) in detailData.detailList"
|
|||
|
:key="index">
|
|||
|
<view class="datetime f28">{{ item.time }}</view>
|
|||
|
<view class="content">{{ item.context }}</view>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
</template>
|
|||
|
|
|||
|
<script>
|
|||
|
export default {
|
|||
|
data() {
|
|||
|
return {
|
|||
|
/*是否加载完成*/
|
|||
|
loadding: false,
|
|||
|
indicatorDots: true,
|
|||
|
autoplay: true,
|
|||
|
interval: 2000,
|
|||
|
duration: 500,
|
|||
|
/*订单id*/
|
|||
|
orderCode: '',
|
|||
|
expressIndex: 0,
|
|||
|
/*快递信息*/
|
|||
|
express: [],
|
|||
|
detail: {},
|
|||
|
detailData: {}
|
|||
|
};
|
|||
|
},
|
|||
|
computed: {
|
|||
|
// detailData() {
|
|||
|
// return this.express[this.expressIndex];
|
|||
|
// }
|
|||
|
},
|
|||
|
onLoad(e) {
|
|||
|
this.orderCode = e.orderCode;
|
|||
|
},
|
|||
|
mounted() {
|
|||
|
/*获取数据*/
|
|||
|
this.getData();
|
|||
|
},
|
|||
|
methods: {
|
|||
|
changeIndex(e) {
|
|||
|
this.expressIndex = e;
|
|||
|
this.detailData = this.express[this.expressIndex];
|
|||
|
},
|
|||
|
/*获取数据*/
|
|||
|
getData() {
|
|||
|
let self = this;
|
|||
|
let orderCode = self.orderCode;
|
|||
|
// console.log(orderCode)
|
|||
|
uni.showLoading({
|
|||
|
title: self.$t("MN_F_6")
|
|||
|
});
|
|||
|
self._get(
|
|||
|
'sale/api/my-order/express/' + orderCode, {},
|
|||
|
function(res) {
|
|||
|
self.express = res.data;
|
|||
|
if (self.express.length > 0) {
|
|||
|
self.detailData = self.express[self.expressIndex];
|
|||
|
}
|
|||
|
// self.detail = self.express[0];
|
|||
|
// console.log(res.data.express);
|
|||
|
self.loadding = false;
|
|||
|
uni.hideLoading();
|
|||
|
}
|
|||
|
);
|
|||
|
}
|
|||
|
}
|
|||
|
};
|
|||
|
</script>
|
|||
|
|
|||
|
<style>
|
|||
|
.express-info .base-info {
|
|||
|
background: #ffffff;
|
|||
|
border-bottom: 1px solid #eeeeee;
|
|||
|
}
|
|||
|
|
|||
|
.express-info .list {
|
|||
|
padding: 30rpx 30rpx 30rpx 50rpx;
|
|||
|
margin-top: 20rpx;
|
|||
|
border-top: 1px solid #eeeeee;
|
|||
|
background: #ffffff;
|
|||
|
}
|
|||
|
|
|||
|
.express-info .list .item {
|
|||
|
position: relative;
|
|||
|
padding: 30rpx;
|
|||
|
padding-left: 40rpx;
|
|||
|
padding-right: 0;
|
|||
|
padding-top: 0;
|
|||
|
border-left: 1px solid #cccccc;
|
|||
|
font-size: 28rpx;
|
|||
|
}
|
|||
|
|
|||
|
.express-info .list .item::before {
|
|||
|
display: block;
|
|||
|
content: '';
|
|||
|
position: absolute;
|
|||
|
top: 0;
|
|||
|
left: -18rpx;
|
|||
|
width: 20rpx;
|
|||
|
height: 20rpx;
|
|||
|
border: 8rpx solid #ffffff;
|
|||
|
border-radius: 50%;
|
|||
|
background: #cccccc;
|
|||
|
}
|
|||
|
|
|||
|
/*
|
|||
|
.express-info .list .item::after {
|
|||
|
display: block;
|
|||
|
content: '';
|
|||
|
position: absolute;
|
|||
|
top: 30rpx;
|
|||
|
left: -18rpx;
|
|||
|
width: 30rpx;
|
|||
|
height: 30rpx;
|
|||
|
border-radius: 50%;
|
|||
|
border: 4rpx solid #cccccc;
|
|||
|
} */
|
|||
|
|
|||
|
.express-info .list .item.active::before {
|
|||
|
background: #fb3024;
|
|||
|
}
|
|||
|
|
|||
|
/* .express-info .list .item.active::after {
|
|||
|
border: 4rpx solid #FB3024;
|
|||
|
}
|
|||
|
*/
|
|||
|
.express-info .list .item {
|
|||
|
color: #999999;
|
|||
|
}
|
|||
|
|
|||
|
.express-info .list .item.active {
|
|||
|
color: #333;
|
|||
|
font-weight: bold;
|
|||
|
}
|
|||
|
|
|||
|
.express-info .list .item .datetime {
|
|||
|
font-size: 28rpx;
|
|||
|
}
|
|||
|
|
|||
|
.express-info .list .item.active .datetime {
|
|||
|
color: #fb3024;
|
|||
|
}
|
|||
|
|
|||
|
.express-img {
|
|||
|
display: block;
|
|||
|
width: 80rpx;
|
|||
|
height: 80rpx;
|
|||
|
border-radius: 50%;
|
|||
|
}
|
|||
|
</style>
|