175 lines
4.8 KiB
Vue
175 lines
4.8 KiB
Vue
|
<!-- 物流追踪 -->
|
|||
|
<template>
|
|||
|
<s-layout title="物流追踪">
|
|||
|
<view class="log-wrap">
|
|||
|
<view class="log-card ss-flex ss-m-20 ss-r-10" v-if="goodsImages.length > 0">
|
|||
|
<uni-swiper-dot :info="goodsImages" :current="state.current" mode="round">
|
|||
|
<swiper class="swiper-box" @change="change">
|
|||
|
<swiper-item v-for="(item, index) in goodsImages" :key="index">
|
|||
|
<image class="log-card-img" :src="sheep.$url.static(item.image)"></image>
|
|||
|
</swiper-item>
|
|||
|
</swiper>
|
|||
|
</uni-swiper-dot>
|
|||
|
|
|||
|
<view class="log-card-msg">
|
|||
|
<view class="ss-flex ss-m-b-8">
|
|||
|
<view>物流状态:</view>
|
|||
|
<view class="warning-color">{{ state.info.status_text }}</view>
|
|||
|
</view>
|
|||
|
<view class="ss-m-b-8">快递单号:{{ state.info.express_no }}</view>
|
|||
|
<view>快递公司:{{ state.info.express_name }}</view>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
<view class="log-content ss-m-20 ss-r-10">
|
|||
|
<view
|
|||
|
class="log-content-box ss-flex"
|
|||
|
v-for="(item, index) in state.info.logs"
|
|||
|
:key="item.title"
|
|||
|
>
|
|||
|
<view class="log-icon ss-flex-col ss-col-center ss-m-r-20">
|
|||
|
<text
|
|||
|
v-if="state.info.logs[index].status === state.info.logs[index - 1]?.status"
|
|||
|
class="cicon-title"
|
|||
|
></text>
|
|||
|
<text
|
|||
|
v-if="state.info.logs[index].status != state.info.logs[index - 1]?.status"
|
|||
|
:class="[
|
|||
|
index === 0 ? 'activity-color' : 'info-color',
|
|||
|
item.status === 'transport'
|
|||
|
? 'sicon-transport'
|
|||
|
: item.status === 'delivery'
|
|||
|
? 'sicon-delivery'
|
|||
|
: item.status === 'collect'
|
|||
|
? 'sicon-a-collectmaterials'
|
|||
|
: item.status === 'fail' || item.status === 'back' || item.status === 'refuse'
|
|||
|
? 'sicon-circleclose'
|
|||
|
: item.status === 'signfor'
|
|||
|
? 'sicon-circlecheck'
|
|||
|
: 'sicon-warning-outline',
|
|||
|
]"
|
|||
|
></text>
|
|||
|
<view v-if="state.info.logs.length - 1 != index" class="line"></view>
|
|||
|
</view>
|
|||
|
<view class="log-content-msg">
|
|||
|
<view
|
|||
|
v-if="
|
|||
|
item.status_text &&
|
|||
|
state.info.logs[index].status != state.info.logs[index - 1]?.status
|
|||
|
"
|
|||
|
class="log-msg-title ss-m-b-20"
|
|||
|
>{{ item.status_text }}</view
|
|||
|
>
|
|||
|
<view class="log-msg-desc ss-m-b-16">{{ item.content }}</view>
|
|||
|
<view class="log-msg-date ss-m-b-40">{{ item.change_date }}</view>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
</s-layout>
|
|||
|
</template>
|
|||
|
|
|||
|
<script setup>
|
|||
|
import sheep from '@/sheep';
|
|||
|
import { onLoad } from '@dcloudio/uni-app';
|
|||
|
import { computed, reactive } from 'vue';
|
|||
|
|
|||
|
const state = reactive({
|
|||
|
info: [],
|
|||
|
current: 0,
|
|||
|
});
|
|||
|
const goodsImages = computed(() => {
|
|||
|
let array = [];
|
|||
|
if (state.info.items) {
|
|||
|
state.info.items.forEach((item) => {
|
|||
|
array.push({
|
|||
|
image: item.goods_image,
|
|||
|
});
|
|||
|
});
|
|||
|
}
|
|||
|
return array;
|
|||
|
});
|
|||
|
function change(e) {
|
|||
|
state.current = e.detail.current;
|
|||
|
}
|
|||
|
async function getExpressdetail(id, orderId) {
|
|||
|
const { data } = await sheep.$api.order.express(id, orderId);
|
|||
|
state.info = data;
|
|||
|
}
|
|||
|
onLoad((Option) => {
|
|||
|
getExpressdetail(Option.id, Option.orderId);
|
|||
|
});
|
|||
|
</script>
|
|||
|
|
|||
|
<style lang="scss" scoped>
|
|||
|
.swiper-box {
|
|||
|
width: 200rpx;
|
|||
|
height: 200rpx;
|
|||
|
}
|
|||
|
.log-card {
|
|||
|
border-top: 2rpx solid rgba(#dfdfdf, 0.5);
|
|||
|
padding: 20rpx;
|
|||
|
background: #fff;
|
|||
|
margin-bottom: 20rpx;
|
|||
|
.log-card-img {
|
|||
|
width: 200rpx;
|
|||
|
height: 200rpx;
|
|||
|
margin-right: 20rpx;
|
|||
|
}
|
|||
|
.log-card-msg {
|
|||
|
font-size: 28rpx;
|
|||
|
font-weight: 500;
|
|||
|
width: 490rpx;
|
|||
|
color: #333333;
|
|||
|
.warning-color {
|
|||
|
color: #999;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
.log-content {
|
|||
|
padding: 34rpx 20rpx 0rpx 20rpx;
|
|||
|
background: #fff;
|
|||
|
.log-content-box {
|
|||
|
align-items: stretch;
|
|||
|
}
|
|||
|
.log-icon {
|
|||
|
height: inherit;
|
|||
|
.cicon-title {
|
|||
|
color: #ccc;
|
|||
|
font-size: 40rpx;
|
|||
|
}
|
|||
|
.activity-color {
|
|||
|
color: #f0c785;
|
|||
|
font-size: 40rpx;
|
|||
|
}
|
|||
|
.info-color {
|
|||
|
color: #ccc;
|
|||
|
font-size: 40rpx;
|
|||
|
}
|
|||
|
.line {
|
|||
|
width: 1px;
|
|||
|
height: 100%;
|
|||
|
background: #d8d8d8;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
.log-content-msg {
|
|||
|
.log-msg-title {
|
|||
|
font-size: 28rpx;
|
|||
|
font-weight: bold;
|
|||
|
color: #333333;
|
|||
|
}
|
|||
|
.log-msg-desc {
|
|||
|
font-size: 24rpx;
|
|||
|
font-weight: 400;
|
|||
|
color: #333333;
|
|||
|
line-height: 36rpx;
|
|||
|
}
|
|||
|
.log-msg-date {
|
|||
|
font-size: 24rpx;
|
|||
|
font-weight: 500;
|
|||
|
color: #999999;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
</style>
|