This commit is contained in:
shuhongfan
2023-09-04 16:40:17 +08:00
commit cf5ac25c14
8267 changed files with 1305066 additions and 0 deletions

View File

@@ -0,0 +1,138 @@
<template>
<!-- 待取件 -->
<DealParcel ref="dealparcel" :tabIndex="tabIndex" :isAdmin="isAdmin" @checkbox="checkbox" @getSelected="getSelected"></DealParcel>
<!-- end -->
<!-- 已取件 -->
<AlreadyParcel ref="already" :tabIndex="tabIndex" :isAdmin="isAdmin" @checkbox="checkbox"></AlreadyParcel>
<!-- end -->
<!-- 已取件 -->
<CancelParcel :tabIndex="tabIndex" ref="cancel" :isAdmin="isAdmin" @checkbox="checkbox" @handleOpen="handleOpen"></CancelParcel>
<!-- end -->
<!-- 提示窗 -->
<UniPopup ref="popup" :tipInfo="tipInfo" @handleClick="handleClick"></UniPopup>
<!-- end -->
</template>
<script setup>
import { ref, onMounted } from 'vue';
import { useStore } from 'vuex';
//接口
import { taskDelete } from '@/pages/api/index.js';
// 导入组件
// 待取件
import DealParcel from './components/dealParcel.vue';
// 已取件
import AlreadyParcel from './components/alreadyParcel.vue';
// 已取件
import CancelParcel from './components/cancelParcel.vue';
// 弹层
import UniPopup from '@/components/uni-popup/index.vue';
// 获取父组件数据
const props = defineProps({
// tab切换数据
tabBars: {
type: Object,
default: () => ({})
},
tabIndex: {
type: Number,
default: 0
},
// 当前高度
scrollH: {
type: String,
default: ''
},
// 是否触发管理按钮
isAdmin: {
type: Boolean,
default: false
},
// 获取当前筛选的距离升序还是降序
orderDistance: {
type: Number,
default: 0
},
// 获取当前筛选的时间升序还是降序
orderTime: {
type: Number,
default: 0
},
// 获取当前筛选超时
filterOverTime: {
type: Number,
default: 0
}
});
// ------定义变量------
const emit = defineEmits(''); //子组件向父组件事件传递
const store = useStore(); //设置、获取储存的数据
const users = store.state.user;
let popup = ref();
let dealparcel = ref();
let already = ref();
let cancel = ref();
const tipInfo = ref('确定要删除吗?');
let taskId = ref('');
let scrollH = ref(0); //滚动高度
// ------生命周期------
onMounted(() => {
// 获取屏幕信息
uni.getSystemInfo({
success: res => {
scrollH.value = res.windowHeight;
}
});
});
// ------定义方法------
// 获取已经选的任务
const getSelected = array => {
emit('getSelected', array);
};
// 获取待取件列表方法
const dealPList = () => {
dealparcel.value.getList();
};
// 获取已取件列表方法
const alreadList = () => {
already.value.getList();
};
// 获取取消件列表方法
const cancelList = () => {
cancel.value.getList();
};
// 确认删除
const handleClick = async () => {
await taskDelete(taskId.value)
.then(res => {
if (res.code === 200) {
dealparcel.value.getList();
return uni.showToast({
title: '删除成功!',
duration: 1000,
icon: 'none'
});
}
})
.catch(err => {});
};
// 选项框点击事件,参数是数据的下标
const checkbox = index => {
emit('checkbox', index);
};
// 删除弹层id
const handleOpen = id => {
popup.value.dialogOpen();
taskId.value = id;
};
//把数据、方法暴漏给父组件
defineExpose({
dealPList,
alreadList,
cancelList
});
</script>
<style></style>

View File

@@ -0,0 +1,200 @@
.maxHeight{
height: 1170rpx;
}
.orderList{
margin: 40rpx 28rpx 0;
position: relative;
margin-top: 0rpx;
::v-deep .scrollView {
height:1300rpx ;
}
//隐藏滚动条
::v-deep ::-webkit-scrollbar {
display: none;
}
.title{
font-size: 30rpx;
color:#333334 ;
font-weight: bold;
margin-bottom: 10rpx;
}
.see-more{
font-size: 24rpx;
text-align: center;
margin-top: 22rpx;
display: flex;
align-items: center;
justify-content: center;
.arrow{
margin-left: 10rpx;
margin-top: 4rpx;
width: 12rpx;
height: 18rpx;
background-repeat: no-repeat;
background-size: contain;
background-image: url('../../../static/icon15.png');
}
}
.empty-data{
height:1200rpx ;
overflow: hidden;
image{
width: 400rpx;
height: 240rpx;
text-align: center;
margin: 0 auto;
display: block;
margin-top: 27vh;
}
.tips{
color: #818181;
font-size: 28rpx;
text-align: center;
margin-top: 40rpx;
margin-left: 25rpx;
}
}
.notLogin{
position: relative;
top: 36vh;
.toLogin-btn{
width: 240rpx;
height: 88rpx;
background: #E63E32;
border-radius: 44rpx;
color: white;
font-size: 30rpx;
margin: 0 auto;
text-align: center;
line-height: 88rpx;
}
.tips{
color:#6C6C6C ;
font-size: 24rpx;
text-align: center;
margin-top: 30rpx;
}
}
.order-item{
position: relative;
background: #FFFFFF;
border-radius: 24rpx;
padding:28rpx 32rpx 20rpx;
margin-top: 20rpx;
.orderNumber{
font-size: 20rpx;
color: #878787;
display: flex;
align-items: center;
.copy{
width: 40rpx;
height: 40rpx;
margin-left: 10rpx;
}
}
.area-to-area{
display: flex;
align-items: center;
justify-content: space-between;
margin-top:40rpx ;
margin-left: 42rpx;
margin-right: 42rpx;
margin-bottom: 20rpx;
.sendBox,.getBox{
text-align: center;
.sendArea,.getArea{
font-size: 30rpx;
font-weight: bold;
}
.sendName,.getName{
font-size: 24rpx;
color: #878787;
}
}
.order-status{
.status{
font-size: 24rpx;
color: #878787;
padding-left: 20rpx;
}
.arrow{
width: 160rpx;
height: 20rpx;
background-repeat: no-repeat;
background-size: contain;
}
.green-arrow{
background-image: url();
}
.red-arrow{
background-image: url();
}
.gray-arrow{
background-image: url('');
}
}
}
.order-detail{
margin-top: 12rpx;
overflow: hidden;
border-bottom: 2rpx solid #F4F4F4;
padding-bottom: 26rpx;
.detail-item{
overflow: hidden;
text-overflow:ellipsis;
white-space: nowrap;
font-size: 24rpx;
margin-top: 12rpx;
uni-text,text{
color: #878787;
display: inline-block;
}
}
}
.btn-box{
.btn{
width: 144rpx;
height: 56rpx;
background: #FFFFFF;
border: 2rpx solid #DDDDDD;
border-radius: 28rpx;
text-align: center;
line-height: 56rpx;
font-size: 24rpx;
color:#303030 ;
}
.wait-pay{
margin-top: 29rpx;
display: flex;
align-items: center;
justify-content: space-between;
.price{
font-size: 26rpx;
font-weight: bold;
uni-text,text{
color: #E84134;
}
}
}
.btn-list{
display: flex;
justify-content: flex-end;
margin-top: 19rpx;
.btn{
margin-left: 20rpx;
}
}
}
.paymentStatus{
position: absolute;
right: 29rpx;
top: 27rpx;
image{
width: 76rpx;
height: 30rpx;
}
}
}
}

View File

@@ -0,0 +1,299 @@
<template>
<view class="orderList" :style="{'paddingTop':capsuleBottom +'px'}">
<view v-if="!isLogin" class="notLogin">
<view class="toLogin-btn" @click="toLogin">登录/注册</view>
<view class="tips">登录后可查看快递信息</view>
</view>
<view v-else>
<view v-if="!allOrderList.data.length && isLogin" class="empty-data">
<image src="../../../static/emptyData.png"></image>
<view class="tips">{{serchValue?'没有搜索到相关条件的运单':'暂无数据'}}</view>
</view>
<scroll-view v-else class="scrollView" scroll-y lower-threshold="30" @scrolltolower="LoadMoreCustomers">
<view class="order-item" v-for="(item,index) in allOrderList.data" :key="index"
@click='handleToOrderInfo(event,item.id,item.transportOrderId)'>
<view class="orderNumber">
{{[23000,22000,230011].includes(item.status)?'订':'运'}}单号{{[23000,22000,230011].includes(item.status)?item.id:item.transportOrderId}}
<image src="../../../static/pickUp-copy.png" class="copy"
@click.stop="handleCopy([23000,22000,230011].includes(item.status)?item.id:item.transportOrderId)">
</image>
</view>
<view class="area-to-area">
<view class="sendBox">
<view class="sendArea">{{item.senderCity.name}}</view>
<view class="sendName">{{item.senderName}}</view>
</view>
<view class="order-status">
<view class="status">
{{showOrderStatus(item.status)}}
</view>
<view class="arrow" :class="
[[21000,23000,23001,23005,23008].includes(item.status)?'green-arrow':'',
[23009,23010].includes(item.status)?'red-arrow':'',
[230011,22000].includes(item.status)?'gray-arrow':'']
"></view>
</view>
<view class="getBox">
<view class="getArea">{{item.receiverCity.name}}</view>
<view class="getName">{{item.receiverName}}</view>
</view>
</view>
<view class="order-detail">
<!-- 已取件运输信息 -->
<view v-if="item.status ===23001 && item.transportOrderPointVOS" class="detail-item">
<text>已取件</text>{{ item.transportOrderPointVOS.length>0?item.transportOrderPointVOS[item.transportOrderPointVOS.length-1].info:''}}
</view>
<!-- 运输中信息 -->
<view v-if="[23005,23008].includes(item.status) && item.transportOrderPointVOS"
class="detail-item">
<text>运送中</text>{{item.transportOrderPointVOS.length>0?item.transportOrderPointVOS[item.transportOrderPointVOS.length-1].info:''}}
</view>
<!-- 已签收 -->
<view v-if="item.status ===23009 && item.transportOrderPointVOS" class="detail-item">
<text>已签收</text>{{item.transportOrderPointVOS.length>0?item.transportOrderPointVOS[item.transportOrderPointVOS.length-1].info:''}}
</view>
<!-- 已拒收 -->
<view v-if="item.status ===23010 && item.transportOrderPointVOS" class="detail-item">
<text>已拒收</text>{{item.transportOrderPointVOS.length>0?item.transportOrderPointVOS[item.transportOrderPointVOS.length-1].info:''}}
</view>
<!-- 预计上门时间 -->
<view v-if="item.status ===23000 " class="detail-item">
<text>预计上门时间</text>{{item.estimatedStartTime}}
</view>
<!-- 取消时间 -->
<view v-if="item.status ===230011 " class="detail-item"><text>取消时间</text>{{item.updated}}
</view>
<!-- 预计送达时间 -->
<view v-if="[23001,23005,23008,23010].includes(item.status) " class="detail-item">
<text>预计送达时间</text>{{item.estimatedArrivalTime}}
</view>
<!-- 已关闭时间 -->
<view v-if="item.status ===22000 " class="detail-item"><text>关闭时间</text>{{item.updated}}</view>
<!-- 签收时间 -->
<view v-if="item.status ===23009 " class="detail-item"><text>签收时间</text>{{item.updated}}</view>
</view>
<!-- 功能按钮区域 -->
<view class="btn-box">
<view class="btn-list" @click.stop="handleSecondQi">
<view class="btn" v-if="[23000,23001,23005,23008,23010].includes(item.status)">分享</view>
<view class="btn" v-if='item.status===23000' @click.stop="handleOrderCancel(item.id)">取消寄件
</view>
<view class="btn" v-if="[22000,230011,23009].includes(item.status)"
@click.stop="handleOrderDelete(item.id)">删除</view>
</view>
</view>
<view class="paymentStatus"
v-if="item.paymentStatus && [23001,23005,23008,23009,23010].includes(item.status)">
<image
:src="item.paymentStatus===1?'../../../static/daizhifu.png':'../../../static/yizhifu.png'">
</image>
</view>
</view>
<!-- 加载底部 -->
<uni-load-more :status="status" v-if="!isShowMore && isLogin && allOrderList.data.length" />
</scroll-view>
</view>
<!-- 删除确认对话框 -->
<uni-popup ref="popup" type="dialog" class='address-popup'>
<uni-popup-dialog mode="base" :content="'确定是否删除此条订单?'" :animation='false' :before-close="true"
@close="close" @confirm="confirm">
</uni-popup-dialog>
</uni-popup>
</view>
</template>
<script setup>
import {
ref,
reactive,
onMounted,
} from 'vue';
import {
getOrderList,
deleteOrder
} from '@/pages/api/order.js'
import {
onLoad,
onShow,
} from '@dcloudio/uni-app';
import {
handleSecondQi
} from '@/utils/index.js'
import {
useStore
} from 'vuex';
// 获取父组件数据
const props = defineProps({
serchValue: {
type: String
}
})
const store = useStore(); //vuex获取、储存数据
const users = store.state.user
const emits = defineEmits(["@stopRefresh"]);
let pageInfo = reactive({
page: 1,
pageSize: 10,
mailType: 1
})
let status = ref('more') //加载状态
let isShowMore = ref(false) //是否显示更多
let allOrderList = reactive({
data: []
})
let orderId = ref()
let isLogin = ref('')
let popup = ref(null)
//胶囊底部距离头部的距离
let capsuleBottom = ref()
// let height = ref('570rpx')
//关闭删除确认提示框
const close = () => {
popup.value.close()
orderId.value = ''
}
onLoad(() => {
uni.getSystemInfo({
success: (res) => {
capsuleBottom.value = uni.getMenuButtonBoundingClientRect().bottom + 52
}
})
})
onShow(() => {
isLogin.value = uni.getStorageSync('token')
allOrderList.data = users.indexList
})
onMounted(() => {
getOrderListFunc()
})
//复制
const handleCopy = (value) => {
uni.setClipboardData({
data: value,
showToast: false,
success: () => {
uni.hideToast(); // 隐藏弹出提示
uni.hideKeyboard(); // 隐藏软键盘
uni.showToast({
title: '复制成功',
icon: 'success',
duration: 1000
})
}
});
}
//确认删除订单
const confirm = () => {
popup.value.close()
deleteOrder(orderId.value).then((res) => {
pageInfo.page = 1
pageInfo.pageSize = 10
getOrderListFunc()
uni.showToast({
title: '删除成功',
icon: 'success',
duration: 1000
})
}).catch((err) => {
uni.showToast({
title: '网络异常',
duration: 2000,
icon: 'none'
});
})
}
//删除订单
const handleOrderDelete = (id) => {
orderId.value = id
popup.value.open()
}
//跳转到取消订单页面
const handleOrderCancel = (id) => {
uni.navigateTo({
url: '/subPages/order-cancel/index?orderId=' + id
})
}
const toLogin = () => {
uni.navigateTo({
url: '/pages/login/index'
})
}
const getOrderListFunc = (flag) => {
status.value = 'loading'
getOrderList(pageInfo).then((res) => {
console.log(res, '接受到了resovle')
if (res.data) {
console.log(res.data.items && res.data.items.length, 'res.data.items && res.data.items.length')
status.value = (res.data.items && res.data.items.length) < 10 ? 'no-more' : 'more'
if (flag === 'topPull') {
allOrderList.data = allOrderList.data.concat(res.data.items ? res.data.items : [])
} else {
allOrderList.data = res.data.items ? res.data.items : []
}
}
store.commit('user/setIndexList', allOrderList.data)
emits('stopRefresh')
})
}
//根据状态去显示对应的运单状态文案
const showOrderStatus = (status) => {
switch (status) {
case 21000:
return '待支付';
case 23000:
return '待取件';
case 230011:
return '已取消';
case 23001:
return '已取件';
case 23005:
return '运送中';
case 22000:
return '已关闭';
case 23008:
return '派送中';
case 23009:
return '已签收';
case 23010:
return '已拒收';
}
}
//跳转到订单详情页面
const handleToOrderInfo = (event, id, transportOrderId) => {
uni.navigateTo({
url: '/subPages/order-info/index?orderId=' + id + '&transportOrderId=' + transportOrderId
});
store.commit('user/setIsToOrderInfo', true)
}
//下拉加载更多
const LoadMoreCustomers = () => {
if (status.value === 'no-more') {
return
}
pageInfo.page = pageInfo.page + 1
getOrderListFunc('topPull')
}
//
const indexGetOrderListFunc = (params) => {
pageInfo.page = 1
pageInfo = Object.assign({}, pageInfo, params)
getOrderListFunc()
}
// 暴漏给父组件
defineExpose({
indexGetOrderListFunc,
LoadMoreCustomers
});
</script>
<style src="./orderList.scss" lang="scss" scoped></style>