jiangchengfeiyi-xiaochengxu/pages/syy.vue
2024-12-19 15:52:16 +08:00

570 lines
13 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="flex-row relative page">
<view class="flex-row justify-center items-center section_2 pos">
<!-- <image class="image"
src="https://ide.code.fun/api/image?token=67610a10797f850011f30392&name=49977e5fbfb65cc3b62ce79b9d6705a2.png" />
<text class="font text ml-4">搜索订单</text> -->
<input class="search-input" placeholder="请输入商品名称" v-model="searchKeyword" @input="handleSearch" />
</view>
<view class="flex-col section_44">
<view class="flex-row justify-between self-stretch groupp">
<view class="font_22" :class="{ active: orderStatus === '全部', selected: isSelected('全部') }"
@click="changeTab('全部')">
全部
</view>
<view class="font_22" :class="{ active: orderStatus === '待支付', selected: isSelected('待支付') }"
@click="changeTab('待支付')">
待支付
</view>
<view class="font_22" :class="{ active: orderStatus === '待发货', selected: isSelected('待发货') }"
@click="changeTab('待发货')">
待发货
</view>
<view class="font_22" :class="{ active: orderStatus === '已发货', selected: isSelected('已发货') }"
@click="changeTab('已发货')">
已发货
</view>
<view class="font_22" :class="{ active: orderStatus === '已退款', selected: isSelected('已退款') }"
@click="changeTab('已退款')">
售后/退款
</view>
</view>
<view class="flex-col pos_8">
<view class="flex-col section_4 list-item_1 mt-14" v-for="(order, index) in Status.displayedOrders"
:key="order.id" @click="goToText(index)">
<view class="flex-col">
<!-- <text class="self-end font_3 text_5">交易关闭</text> -->
<view class="flex-row items-center self-stretch mt-2">
<text class="font_4">订单编号:</text>
<text class="font_5 ml-5">{{order.orderNumber}}</text>
</view>
</view>
<view class="flex-col group">
<view class="flex-row justify-between list-item group_3" v-for="item in order.orderItemList"
:key="item.id">
<view class="flex-row">
<image class="image_2" :src="item.goodSnapshot.goodImg" />
<view class="flex-col self-start group_1 ml-18">
<view class="flex-row self-stretch">
<text class="font">{{ item.goodSnapshot.name }}</text>
<text class="font text_10">【{{ item.goodSnapshot.type }}】</text>
</view>
<text class="self-start font_7 text_12 mt-36">×1</text>
</view>
</view>
<view class="flex-row items-center self-start group_2">
{{ item.goodSnapshot.price }}
</view>
</view>
</view>
<view class="divider view_1"></view>
<view class="flex-row justify-end group_5">
<view v-if="order.orderStatus==='待支付'" class="font text_18">去支付</view>
<view v-if="order.orderStatus==='待发货'" class="font text_18">取消订单</view>
<view v-if="order.orderStatus==='已发货'" class="font text_18">确认收货</view>
<view v-if="order.orderStatus==='已退款'" class="font text_18">售后详情</view>
</view>
<view class="flex-row justify-end items-center view">
<text class="font_9 text_16">总 金额:</text>
<image class="image_4 image_5"
src="https://ide.code.fun/api/image?token=67610a10797f850011f30392&name=f10bd62afae3562e9d76103ff6fb0f84.png" />
<text class="font_8 text_17">{{order.totalAmount}}</text>
</view>
<view class="flex-row justify-end group_7">
<view class="flex-col justify-start items-center text-wrapper"><text
class="font text_18">删除记录</text></view>
<view class="flex-col justify-start items-center text-wrapper_2 ml-14">
<text class="font_3">联系客服</text>
</view>
</view>
</view>
</view>
</view>
</view>
</template>
<script setup>
import {
ref,
onMounted,
toRaw
} from 'vue';
import {
baseUrl,
testUrl,
suiUrl
} from '@/api/request';
import { onLoad } from "@dcloudio/uni-app";
const Status = ref({
orderStatus: '全部',
orders: [],
displayedOrders: [],
});
const orderStatus = '';
const currentColor = ref(0);
const isSelected = (tab) => Status.value.orderStatus === tab;
const searchKeyword = ref(''); // 新增,用于存储搜索关键词
onMounted(async () => {
await Getorder();
// 根据当前的tab值来设置displayedOrders
if (Status.value.orderStatus === '全部') {
Status.value.displayedOrders = Status.value.orders;
} else {
Status.value.displayedOrders = Status.value.orders.filter((order) => {
switch (Status.value.orderStatus) {
case '待支付':
return order.orderStatus === '待支付'
case '待发货':
return order.orderStatus === '待发货'
case '已发货':
return order.orderStatus === '已发货'
case '已退款':
return order.orderStatus === '已退款'
default:
return false;
}
});
}
});
const userInfo = wx.getStorageSync('userInfo');
const Getorder = async () => {
const res = await uni.request({
url: baseUrl + '/order/list',
method: 'POST',
header: {
cookie: wx.getStorageSync('cookie')
},
data: {
id: userInfo.id,
},
});
if (res.data.code === 1) {
Status.value.orders = res.data.data;
} else {
console.log('没拿到用户数据');
}
};
const zt = ref({
tab: ''
});
onLoad((options) => {
if (options.tab) {
zt.value.tab = JSON.parse(options.tab);
changeTab(zt.value.tab);
}
});
const changeTab = (tab) => {
if (tab === '全部') {
Status.value.displayedOrders = Status.value.orders;
Status.value.orderStatus = '全部';
} else {
Status.value.displayedOrders = Status.value.orders.filter((order) => {
switch (tab) {
case '待支付':
return order.orderStatus === '待支付';
case '待发货':
return order.orderStatus === '待发货';
case '已发货':
return order.orderStatus === '已发货';
case '已退款':
return order.orderStatus === '已退款';
default:
return false;
}
});
Status.value.orderStatus = tab;
}
};
// 新增,处理搜索逻辑的函数
const handleSearch = () => {
if (searchKeyword.value.trim() === '') {
// 如果关键词为空恢复根据当前tab展示的数据全部或筛选后的数据
if (Status.value.orderStatus === '全部') {
Status.value.displayedOrders = Status.value.orders;
} else {
Status.value.displayedOrders = Status.value.orders.filter((order) => {
switch (Status.value.orderStatus) {
case '待支付':
return order.orderStatus === '待支付'
case '待发货':
return order.orderStatus === '待发货'
case '已发货':
return order.orderStatus === '已发货'
case '已退款':
return order.orderStatus === '已退款'
default:
return false;
}
});
}
return;
}
const keyword = searchKeyword.value.toLowerCase(); // 转换为小写,方便不区分大小写搜索
Status.value.displayedOrders = Status.value.orders.filter((order) => {
return order.orderItemList.some((item) => {
return item.goodSnapshot.name.toLowerCase().includes(keyword);
});
});
};
const goToText = (index) => {
uni.navigateTo({
url: '../../../pages/mine/OrderDetails/OrderDetails?info=' + JSON.stringify(Status.value
.displayedOrders[index]),
})
};
</script>
<style lang="scss" scoped>
.groupp {
padding: 22.5rpx 0 18.75rpx;
}
.section_44 {
padding-left: 33.75rpx;
padding-right: 30rpx;
width: 100%;
height: 120rpx;
margin-top: 80rpx;
}
.ml-5 {
margin-left: 9.38rpx;
}
.font_22.selected {
position: relative;
}
.font_22.selected::after {
content: '';
position: absolute;
bottom: -5px; // 调整线条距离底部的距离
left: 0;
right: 0;
height: 2px; // 调整线条的粗细
background-color: #f6aaa4; // 调整线条颜色
transition: all 0.3s ease; // 添加过渡效果
}
.page {
padding: 46.88rpx 22.5rpx 401.25rpx;
background-color: #ffffff;
background-image: url('https://ide.code.fun/api/image?token=67610a10797f850011f30392&name=4ba8389730acda4f67d46a7370efec60.png');
background-size: 100% 100%;
background-repeat: no-repeat;
height: 2073.75rpx;
width: 100%;
overflow-y: auto;
overflow-x: hidden;
}
.section_2 {
padding: 9.38rpx 0;
background-color: #ffffff;
border-radius: 75rpx;
}
.pos {
position: absolute;
left: 35.63rpx;
right: 35.63rpx;
top: 46.88rpx;
}
.image {
width: 37.5rpx;
height: 37.5rpx;
}
.font {
font-size: 26.25rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 25.54rpx;
color: #323232;
}
.text {
color: #c0c0c0;
line-height: 25.84rpx;
}
.font_2 {
font-size: 30rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 28.84rpx;
color: #323232;
}
.font_22 {
font-size: 30rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 27.81rpx;
color: #323232;
}
.text_2 {
line-height: 28.48rpx;
}
.pos_2 {
position: absolute;
left: 33.99rpx;
top: 146.36rpx;
}
.text_3 {
line-height: 28.24rpx;
}
.pos_3 {
position: absolute;
left: 147.66rpx;
top: 146.14rpx;
}
.pos_4 {
position: absolute;
left: 295.78rpx;
top: 145.78rpx;
}
.pos_5 {
position: absolute;
right: 214.22rpx;
top: 145.78rpx;
}
.text_4 {
line-height: 29.53rpx;
}
.pos_6 {
position: absolute;
right: 34.22rpx;
top: 147.07rpx;
}
.section_3 {
background-color: #ffaaa5;
width: 73.13rpx;
height: 5.63rpx;
}
.pos_7 {
position: absolute;
left: 30rpx;
top: 182.81rpx;
}
.pos_8 {
position: absolute;
left: 22.5rpx;
right: 30rpx;
top: 217.5rpx;
}
.section_4 {
padding: 34.61rpx 15rpx 31.88rpx;
background-color: #ffffff;
border-radius: 31.88rpx;
}
.list-item_1:first-child {
margin-top: 0;
}
.font_3 {
font-size: 26.25rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 25.54rpx;
color: #ffaaa5;
}
.text_5 {
margin-right: 8.08rpx;
line-height: 24.62rpx;
}
.font_4 {
font-size: 22.5rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 22.14rpx;
color: #818181;
}
.font_5 {
font-size: 22.5rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 15.04rpx;
color: #818181;
}
.group {
margin-top: 29.21rpx;
}
.list-item:first-child {
margin-top: 0;
}
.image_2 {
border-radius: 9.38rpx;
width: 146.25rpx;
height: 144.38rpx;
}
.group_1 {
margin-top: 2.33rpx;
}
.text_10 {
line-height: 25.01rpx;
}
.font_7 {
font-size: 26.25rpx;
font-family: Open Sans;
line-height: 19.29rpx;
color: #323232;
}
.text_12 {
margin-left: 5.34rpx;
line-height: 18.73rpx;
}
.group_2 {
margin-right: 8.23rpx;
margin-top: 89.19rpx;
}
.font_6 {
font-size: 33.75rpx;
font-family: Open Sans;
line-height: 25.54rpx;
font-weight: 600;
color: #323232;
}
.text_11 {
margin-left: 25.03rpx;
line-height: 24.88rpx;
}
.image_3 {
margin-left: -90.66rpx;
width: 30rpx;
height: 26.25rpx;
}
.font_8 {
font-size: 26.25rpx;
font-family: Open Sans;
line-height: 19.29rpx;
font-weight: 600;
color: #323232;
}
.text_13 {
margin-left: 61.14rpx;
}
.divider {
background-color: #dad2d2;
height: 0.81rpx;
}
.view_1 {
margin: 30.43rpx 28.13rpx 0 39.38rpx;
}
.group_5 {
margin-top: 49.41rpx;
padding: 0 21.21rpx;
color: #ffaaa5;
}
.font_9 {
font-size: 26.25rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 25.54rpx;
color: #000000;
}
.text_14 {
line-height: 24.62rpx;
}
.text_15 {
margin-top: 2.17rpx;
line-height: 24rpx;
}
.view {
margin-top: 19.93rpx;
padding: 0 19.54rpx;
}
.text_16 {
margin-right: 6.99rpx;
line-height: 24.3rpx;
}
.image_4 {
width: 31.88rpx;
height: 30rpx;
}
.image_5 {
margin-right: -8.29rpx;
}
.text_17 {
color: #ffaaa5;
line-height: 19.39rpx;
}
.group_7 {
margin-top: 52.5rpx;
padding: 0 9.38rpx;
}
.text-wrapper {
padding: 13.86rpx 0 13.52rpx;
background-color: #fffef8;
border-radius: 75rpx;
width: 155.63rpx;
height: 56.25rpx;
border: solid 1.88rpx #cbcbcb;
}
.text_18 {
line-height: 25.13rpx;
}
.text-wrapper_2 {
padding: 13.46rpx 0 13.5rpx;
background-color: #fffef8;
border-radius: 75rpx;
width: 155.63rpx;
height: 56.25rpx;
border: solid 1.88rpx #ffaaa5;
}
.group_3 {
margin-top: 15rpx;
}
@import url("../common/css/global.css");
</style>