2025-10-24

我的订单
This commit is contained in:
2025-10-24 15:10:06 +08:00
parent d283a1cc58
commit 81dba82be3
7 changed files with 538 additions and 373 deletions

View File

@@ -80,7 +80,8 @@
} from '../../api/mall.js';
import {
getImageUrl
} from '../../util/common.js'
} from '../../util/common.js';
import {onShow} from '@dcloudio/uni-app'
const msgRef = ref()
@@ -199,10 +200,13 @@
cartList.value.forEach(item => item.isCheck = false)
})
}
onShow(()=>{
loadData()
})
onMounted(() => {
loadHeight()
loadData()
})
</script>

View File

@@ -123,7 +123,7 @@
收货地址
</view>
</view>
<view class="menu-item">
<view class="menu-item" @click="handleOrder">
<u-image src="/static/my/07.png" width="40%" mode="widthFix"></u-image>
<view class="menu-text">
我的订单
@@ -163,6 +163,12 @@
})
}
const handleOrder = () => {
uni.navigateTo({
url: '/pages/my/order'
})
}
const loadData = () => {
authAPI.me().then(res => {
user.value = res.user
@@ -182,17 +188,17 @@
url: '/pages/login/login'
})
}
const navigatorSrc = ()=>{
uni.navigateTo({
url:'/pages/my/getCoupons'
})
}
//购物车跳转
const shop_car = ()=>{
uni.navigateTo({
url:'/pages/my/car'
})
}
const navigatorSrc = () => {
uni.navigateTo({
url: '/pages/my/getCoupons'
})
}
//购物车跳转
const shop_car = () => {
uni.navigateTo({
url: '/pages/my/car'
})
}
</script>
<style scoped lang="scss">

View File

@@ -1,13 +1,497 @@
<template>
<view>
<view class="order-container">
<u-navbar id="navBar" title="" :border-bottom="false" :background="{ background: '#F5F8FF' }">
<view class="slot-wrap">
<u-search :show-action="false" placeholder="搜索订单" v-model="params.search" bgColor="#CADBFF"
@search="handleSearch"></u-search>
</view>
<template v-slot:right>
<u-icon class="more-dot-fill" name="more-dot-fill"></u-icon>
</template>
</u-navbar>
<view class="box-tabs" id="tabsId">
<u-tabs bg-color="#F5F8FF" :show-bar="false" :list="tabList" :is-scroll="false"
v-model="currentTab"></u-tabs>
<view class="menu-list">
<view class="menu-item" :class="currentMenu==0?'active':''" @click="handleChangeMenu(0)">全部订单</view>
<view class="menu-item" :class="currentMenu==1?'active':''" @click="handleChangeMenu(1)">待付款</view>
<view class="menu-item" :class="currentMenu==2?'active':''" @click="handleChangeMenu(2)">待发货</view>
<view class="menu-item" :class="currentMenu==3?'active':''" @click="handleChangeMenu(3)">待收货</view>
<view class="menu-item" :class="currentMenu==4?'active':''" @click="handleChangeMenu(4)">退款/售后</view>
</view>
</view>
<scroll-view scroll-y="true" class="scroll-view" :style="'height:'+scrollHeight+'px'" @scrolltolower="loadData">
<view class="order-list" v-for="orderItem in orderList">
<view class="u-m-l-20">订单号{{orderItem.order_no}}</view>
<view class="order-item" v-for="item in orderItem.items">
<view class="item-left">
<image style="width: 100%;height: 100%;" :src="getImageUrl(item.image_url)" mode="">
</image>
</view>
<view class="item-right">
<u-row>
<u-col :span="10">
<view>{{item.product_name}}</view>
<view style="display: flex;align-items: center;">
<image class="icon" src="/static/icon/rongdou.png" mode=""></image>
{{item.rongdou_price}}
</view>
<view style="display: flex;align-items: center;">
<image class="icon" src="/static/icon/jifen.png" mode=""></image>
{{item.points_price}}
</view>
</u-col>
<u-col :span="2" text-align="right">
<view>X{{item.quantity}}</view>
</u-col>
</u-row>
</view>
</view>
<view class="operate-btns">
<!-- 待发货 -->
<template v-if="orderItem.status=='pending'">
<u-button hover-class="none" class="operate-btn"
@click="handelCancel(orderItem)">取消订单</u-button>
</template>
<!-- 已支付 -->
<!-- <template v-if="orderItem.status=='paid'">
<u-button hover-class="none" class="operate-btn">取消订单</u-button>
</template> -->
<!-- 已发货 -->
<template v-if="orderItem.status=='shipped'">
<u-button hover-class="none" class="operate-btn"
@click="handleReceive(orderItem)">确认收货</u-button>
</template>
<!-- 已取消 -->
<!-- <template v-if="orderItem.status=='cancelled'">
<u-button hover-class="none" class="operate-btn">查看详情</u-button>
</template> -->
<!-- 待支付 -->
<template v-if="orderItem.status=='pre_order'">
<u-button hover-class="none" class="operate-btn"
@click="handelCancel(orderItem)">取消订单</u-button>
<u-button hover-class="none" class="operate-btn" @click="handlePay(orderItem)">立即支付</u-button>
</template>
<!-- 完成 -->
<!-- <template v-if="orderItem.status=='completed'">
<u-button hover-class="none" class="operate-btn">评价</u-button>
</template> -->
<u-button hover-class="none" class="operate-btn"
@click="handleOrderDetail(orderItem)">查看详情</u-button>
</view>
</view>
<u-loadmore margin-top="20" :status="loadStatus"></u-loadmore>
<view class="box-view"></view>
</scroll-view>
</view>
<!-- 取消订单提示 -->
<u-modal @confirm="confirmCancel" v-model="showCancel" content="是否取消订单" :show-cancel-button="true"></u-modal>
<!-- 收货提示 -->
<u-modal @confirm="confirmReceive" v-model="showReceive" content="是否确认收到商品" :show-cancel-button="true"></u-modal>
<!-- 详情 -->
<u-modal v-model="showDetail" title="订单详情">
<view class="slot-content">
<view class="info-title">
订单信息
</view>
<view class="info-item">
<view class="info-name">订单号</view>
<view class="info-value">{{detailInfo.order_no}}</view>
</view>
<view class="info-item">
<view class="info-name">用户名</view>
<view class="info-value">{{detailInfo.username}}</view>
</view>
<view class="info-item">
<view class="info-name">下单时间</view>
<view class="info-value">{{detailInfo.created_at}}</view>
</view>
<view class="info-item">
<view class="info-name">更新时间</view>
<view class="info-value">{{detailInfo.updated_at}}</view>
</view>
<view class="info-item">
<view class="info-name">订单状态</view>
<!-- <view class="info-value">{{detailInfo.status}}</view> -->
<!-- 'pending'待发货,'paid','shipped'已发货,'delivered','cancelled'已取消,'pre_order'预订单状态未选择地址和支付方式,'completed'已收货 -->
<u-tag v-if="detailInfo.status=='pending'" text="待发货"></u-tag>
<u-tag v-if="detailInfo.status=='shipped'" text="已发货"></u-tag>
<u-tag v-if="detailInfo.status=='cancelled'" text="已取消"></u-tag>
<u-tag v-if="detailInfo.status=='pre_order'" text="预订单"></u-tag>
<u-tag v-if="detailInfo.status=='completed'" text="已收货"></u-tag>
</view>
<view class="info-item" v-if="detailInfo.address">
<view class="info-name">收货信息</view>
<view class="info-value">
{{detailInfo.address.recipient_name + " " + detailInfo.address.detail_address}}
</view>
</view>
<view class="info-title">
商品信息
</view>
<view class="order-item" v-for="item in detailInfo.items">
<view class="item-left">
<image style="width: 100%;height: 100%;" :src="getImageUrl(item.image_url)" mode="">
</image>
</view>
<view class="item-right">
<u-row>
<u-col :span="10">
<view>{{item.product_name}}</view>
<view style="display: flex;align-items: center;">
<image class="icon" src="/static/icon/rongdou.png" mode=""></image>
{{item.rongdou_price}}
</view>
<view style="display: flex;align-items: center;">
<image class="icon" src="/static/icon/jifen.png" mode=""></image>
{{item.points_price}}
</view>
</u-col>
<u-col :span="2" text-align="right">
<view>X{{item.quantity}}</view>
</u-col>
</u-row>
</view>
</view>
<view class="info-title">
费用明细
</view>
<view class="info-item">
<view class="info-name">商品总计</view>
<view class="info-value">
<image class="icon" src="/static/icon/rongdou.png" mode=""></image>
{{allPay}}
</view>
</view>
<view class="info-item">
<view class="info-name">实付</view>
<view class="info-value">
<image class="icon" src="/static/icon/rongdou.png" mode=""></image>
{{detailInfo.total_rongdou}}
</view>
</view>
</view>
</u-modal>
<!-- 消息提示 -->
<u-toast ref="msgRef" />
</template>
<script setup>
import {
ref,
onMounted,
getCurrentInstance,
computed
} from 'vue';
import {
onLoad,
onShow
} from '@dcloudio/uni-app'
import {
mallAPI
} from '../../api/mall';
import {
getImageUrl
} from '../../util/common.js'
const msgRef = ref()
const instance = getCurrentInstance();
const scrollHeight = ref(0)
const loadHeight = () => {
uni.getSystemInfo({
success(res) {
let screenHeight = res.screenHeight
uni.createSelectorQuery().in(instance.proxy).select("#navBar").boundingClientRect((data) => {
scrollHeight.value = screenHeight - data.height
}).exec()
uni.createSelectorQuery().in(instance.proxy).select("#tabsId").boundingClientRect((
data) => {
scrollHeight.value = scrollHeight.value - data.height
}).exec()
}
})
}
const navBarTitle = {
fontWeight: '510',
fontStyle: 'Medium',
fontSize: '40rpx',
lineHeight: '52px'
}
const handleSearch = () => {
}
const tabList = ref([{
name: '项目订单'
}, {
name: '商品订单'
}, {
name: '理财产品',
}])
const currentTab = ref(0)
const currentMenu = ref(0)
const handleChangeMenu = (val) => {
currentMenu.value = val
}
// 取消订单
const showCancel = ref(false)
const cancelId = ref()
const handelCancel = (item) => {
showCancel.value = true
cancelId.value = item.id
}
const confirmCancel = () => {
mallAPI.cancelOrder(cancelId.value).then(res => {
msgRef.value.show({
title: '取消成功',
type: 'success'
})
clearData()
loadData()
})
}
// 收货
const showReceive = ref(false)
const receiveId = ref()
const handleReceive = (item) => {
showReceive.value = true
receiveId.value = item.id
}
const confirmReceive = () => {
mallAPI.confirmOrder(receiveId.value).then(res => {
msgRef.value.show({
title: '收货成功',
type: 'success'
})
clearData()
loadData()
})
}
// 进入支付页面
const handlePay = (item) => {
uni.navigateTo({
url: '/pages/home/pay?preOrderId=' + item.id
})
}
// 详情
const showDetail = ref(false)
const detailInfo = ref({})
const allPay = computed(()=>{
let data = 0
detailInfo.value.items.forEach(item=>{
data += item.rongdou_price * item.quantity
})
return data
})
// 查看详情
const handleOrderDetail = (item) => {
showDetail.value = true
detailInfo.value = item
}
const params = ref({
page: 1,
limit: 10,
search: '',
})
const loadStatus = ref('loadmore')
const maxPage = ref(1)
const orderList = ref([])
const loadData = () => {
if (loadStatus.value == 'nomore') return
mallAPI.getOrderList(params.value).then(res => {
orderList.value = orderList.value.concat(res.data.orders)
maxPage.value = res.data.pagination.pages
params.value.page++
console.log(orderList.value);
if (maxPage.value < params.value.page) {
loadStatus.value = 'nomore'
}
})
}
const clearData = () => {
loadStatus.value = 'loadmore'
params.value.page = 1
params.value.search = ''
orderList.value = []
}
onShow(() => {
clearData()
loadData()
})
onMounted(() => {
loadHeight()
})
</script>
<style lang="scss">
</style>
<style lang="scss" scoped>
.order-container {
width: 100%;
height: 100vh;
background: var(--Color, #E4ECFF);
background-blend-mode: lighten;
.more-dot-fill {
width: 48rpx;
height: 48rpx;
margin-right: 24rpx;
}
.box-tabs {
background: #F5F8FF;
.menu-list {
display: flex;
font-weight: 400;
font-size: 26rpx;
line-height: 100%;
justify-content: space-between;
padding: 20rpx 20rpx;
.menu-item {
background: #DFDFDF;
border-radius: 12rpx;
padding: 12rpx 20rpx;
color: #676767;
}
.active {
background: #93B2FF80;
color: #305DEF;
}
}
}
.scroll-view {
.order-list {
background: #F5F8FF;
margin: 10rpx 0;
padding: 20rpx 0;
.order-item {
display: flex;
padding: 20rpx;
.item-left {
width: 160rpx;
height: 160rpx;
}
.item-right {
flex: 1;
.icon {
width: 30rpx;
height: 30rpx;
}
}
}
.operate-btns {
display: flex;
justify-content: flex-end;
.operate-btn {
margin: 10rpx;
width: 136rpx;
height: 52rpx;
background: #D4D9EA;
font-weight: 400;
font-size: 24rpx;
line-height: 100%;
border: none;
}
}
.box-view {
height: 20rpx;
}
}
}
}
.slot-content {
padding: 10rpx 20rpx 20rpx;
.icon {
width: 30rpx;
height: 30rpx;
}
.info-title {
font-weight: 400;
font-size: 30rpx;
line-height: 100%;
margin: 30prx 0;
}
.info-item {
display: flex;
justify-content: space-between;
align-items: center;
margin: 20rpx 0;
.info-name {
font-weight: 400;
font-size: 24rpx;
line-height: 100%;
}
.info-value {
max-width: 50%;
font-weight: 400;
font-size: 24rpx;
line-height: 100%;
display: flex;
align-items: center;
}
}
.order-item {
display: flex;
padding: 20rpx;
.item-left {
width: 160rpx;
height: 160rpx;
}
.item-right {
flex: 1;
font-weight: 400;
font-size: 24rpx;
line-height: 100%;
}
}
}
</style>