|
@@ -2,65 +2,46 @@
|
|
<template>
|
|
<template>
|
|
<s-layout title="物流追踪">
|
|
<s-layout title="物流追踪">
|
|
<view class="log-wrap">
|
|
<view class="log-wrap">
|
|
|
|
+ <!-- 商品信息 -->
|
|
<view class="log-card ss-flex ss-m-20 ss-r-10" v-if="goodsImages.length > 0">
|
|
<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">
|
|
<uni-swiper-dot :info="goodsImages" :current="state.current" mode="round">
|
|
- <swiper class="swiper-box" @change="change">
|
|
|
|
|
|
+ <swiper class="swiper-box">
|
|
<swiper-item v-for="(item, index) in goodsImages" :key="index">
|
|
<swiper-item v-for="(item, index) in goodsImages" :key="index">
|
|
- <image class="log-card-img" :src="sheep.$url.static(item.image)"></image>
|
|
|
|
|
|
+ <image class="log-card-img" :src="sheep.$url.static(item.image)" />
|
|
</swiper-item>
|
|
</swiper-item>
|
|
</swiper>
|
|
</swiper>
|
|
</uni-swiper-dot>
|
|
</uni-swiper-dot>
|
|
-
|
|
|
|
<view class="log-card-msg">
|
|
<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>
|
|
|
|
|
|
+ <!-- TODO 芋艿:优化点:展示状态 -->
|
|
|
|
+<!-- <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.logisticsNo }}</view>
|
|
|
|
+ <view>快递公司:{{ state.info.logisticsName }}</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
|
|
+
|
|
|
|
+ <!-- 物流轨迹 -->
|
|
<view class="log-content ss-m-20 ss-r-10">
|
|
<view class="log-content ss-m-20 ss-r-10">
|
|
<view
|
|
<view
|
|
class="log-content-box ss-flex"
|
|
class="log-content-box ss-flex"
|
|
- v-for="(item, index) in state.info.logs"
|
|
|
|
|
|
+ v-for="(item, index) in state.tracks"
|
|
:key="item.title"
|
|
:key="item.title"
|
|
>
|
|
>
|
|
<view class="log-icon ss-flex-col ss-col-center ss-m-r-20">
|
|
<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>
|
|
|
|
|
|
+ <text class="cicon-title" />
|
|
|
|
+ <view v-if="state.tracks.length - 1 !== index" class="line" />
|
|
</view>
|
|
</view>
|
|
<view class="log-content-msg">
|
|
<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
|
|
|
|
- >
|
|
|
|
|
|
+ <!-- TODO 芋艿:优化点:展示状态 -->
|
|
|
|
+<!-- <view 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-desc ss-m-b-16">{{ item.content }}</view>
|
|
- <view class="log-msg-date ss-m-b-40">{{ item.change_date }}</view>
|
|
|
|
|
|
+ <view class="log-msg-date ss-m-b-40">
|
|
|
|
+ {{ sheep.$helper.timeFormat(item.time, 'yyyy-mm-dd hh:MM:ss') }}
|
|
|
|
+ </view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
@@ -72,31 +53,38 @@
|
|
import sheep from '@/sheep';
|
|
import sheep from '@/sheep';
|
|
import { onLoad } from '@dcloudio/uni-app';
|
|
import { onLoad } from '@dcloudio/uni-app';
|
|
import { computed, reactive } from 'vue';
|
|
import { computed, reactive } from 'vue';
|
|
|
|
+ import OrderApi from '@/sheep/api/trade/order';
|
|
|
|
|
|
const state = reactive({
|
|
const state = reactive({
|
|
info: [],
|
|
info: [],
|
|
- current: 0,
|
|
|
|
|
|
+ tracks: [],
|
|
});
|
|
});
|
|
|
|
+
|
|
const goodsImages = computed(() => {
|
|
const goodsImages = computed(() => {
|
|
let array = [];
|
|
let array = [];
|
|
if (state.info.items) {
|
|
if (state.info.items) {
|
|
state.info.items.forEach((item) => {
|
|
state.info.items.forEach((item) => {
|
|
array.push({
|
|
array.push({
|
|
- image: item.goods_image,
|
|
|
|
|
|
+ image: item.picUrl,
|
|
});
|
|
});
|
|
});
|
|
});
|
|
}
|
|
}
|
|
return array;
|
|
return array;
|
|
});
|
|
});
|
|
- function change(e) {
|
|
|
|
- state.current = e.detail.current;
|
|
|
|
|
|
+
|
|
|
|
+ async function getExpressDetail(id) {
|
|
|
|
+ const { data } = await OrderApi.getOrderExpressTrackList(id);
|
|
|
|
+ state.tracks = data.reverse();
|
|
}
|
|
}
|
|
- async function getExpressdetail(id, orderId) {
|
|
|
|
- const { data } = await sheep.$api.order.express(id, orderId);
|
|
|
|
|
|
+
|
|
|
|
+ async function getOrderDetail(id) {
|
|
|
|
+ const { data } = await OrderApi.getOrder(id)
|
|
state.info = data;
|
|
state.info = data;
|
|
}
|
|
}
|
|
- onLoad((Option) => {
|
|
|
|
- getExpressdetail(Option.id, Option.orderId);
|
|
|
|
|
|
+
|
|
|
|
+ onLoad((options) => {
|
|
|
|
+ getExpressDetail(options.id);
|
|
|
|
+ getOrderDetail(options.id);
|
|
});
|
|
});
|
|
</script>
|
|
</script>
|
|
|
|
|