Files
jurong_circle_front_app/pages/my/order.vue
Sun_sun 5769349d08 2025-10-24
我的订单修改
2025-10-24 15:56:41 +08:00

542 lines
14 KiB
Vue
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<template>
<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">
<!-- 'pending'待发货,'paid','shipped'已发货,'delivered','cancelled'已取消,'pre_order'预订单状态未选择地址和支付方式,'completed'已收货 -->
<view class="menu-item" :class="currentMenu==''?'active':''" @click="handleChangeMenu('')">全部订单</view>
<view class="menu-item" :class="currentMenu=='pending'?'active':''"
@click="handleChangeMenu('pending')">待发货</view>
<view class="menu-item" :class="currentMenu=='pre_order'?'active':''"
@click="handleChangeMenu('pre_order')">待支付</view>
<view class="menu-item" :class="currentMenu=='shipped'?'active':''"
@click="handleChangeMenu('shipped')">已发货</view>
<view class="menu-item" :class="currentMenu=='completed'?'active':''"
@click="handleChangeMenu('completed')">已完成</view>
<view class="menu-item" :class="currentMenu=='cancelled'?'active':''"
@click="handleChangeMenu('cancelled')">已取消</view>
</view>
</view>
<scroll-view scroll-y="true" class="scroll-view" :style="'height:'+scrollHeight+'px'" @scrolltolower="loadData">
<template v-if="currentTab==0">
111
</template>
<template v-if="currentTab==1">
<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>
</template>
<template v-if="currentTab==2">
222
</template>
</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> -->
<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>
{{detailInfo.total_rongdou}}
</view>
</view>
<view class="info-item">
<view class="info-name">实付</view>
<view class="info-value" v-if="detailInfo.real_rongdou">
<image class="icon" src="/static/icon/rongdou.png" mode=""></image>
{{detailInfo.real_rongdou}}
</view>
<view class="info-value" v-if="detailInfo.real_points">
<image class="icon" src="/static/icon/jifen.png" mode=""></image>
{{detailInfo.real_points}}
</view>
</view>
</view>
</u-modal>
<!-- 消息提示 -->
<u-toast ref="msgRef" />
</template>
<script setup>
import {
ref,
onMounted,
getCurrentInstance,
computed,
watch
} 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 = () => {
msgRef.value.show({
title: '暂无功能,请期待~'
})
}
const tabList = ref([{
name: '项目订单'
}, {
name: '商品订单'
}, {
name: '理财产品',
}])
const currentTab = ref(1)
const currentMenu = ref(0)
watch(currentTab, (val) => {
if (val == 0 || val === 2) {
msgRef.value.show({
title: '暂无功能,请期待~'
})
currentTab.value = 1
return
}
loadData()
})
const handleChangeMenu = (val) => {
currentMenu.value = val
clearData()
params.value.status = val
loadData()
}
// 取消订单
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: '',
status: ''
})
const loadStatus = ref('loadmore')
const maxPage = ref(1)
const orderList = ref([])
const loadData = () => {
if (currentTab.value == 0) {
// 项目订单
} else if (currentTab.value == 1) {
// 商品订单
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++
if (maxPage.value < params.value.page) {
loadStatus.value = 'nomore'
}
})
} else if (currentTab.value == 2) {
// 理财产品
}
}
const clearData = () => {
loadStatus.value = 'loadmore'
params.value.page = 1
params.value.search = ''
orderList.value = []
}
onShow(() => {
clearData()
loadData()
})
onMounted(() => {
loadHeight()
})
</script>
<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%;
padding: 20rpx 20rpx;
overflow-x: auto;
white-space: nowrap;
.menu-item {
background: #DFDFDF;
border-radius: 12rpx;
padding: 12rpx 20rpx;
color: #676767;
margin: 0 10rpx;
}
.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>