mall-uniapp/pages/chat/components/order.vue

115 lines
2.4 KiB
Vue
Raw Normal View History

2022-11-22 07:45:36 +00:00
<template>
2024-07-09 09:34:18 +00:00
<view class="bg-white order-list-card-box ss-r-10 ss-m-t-14 ss-m-20"
:key="orderData.id">
<view class="order-card-header ss-flex ss-col-center ss-row-between ss-p-x-20">
<view class="order-no">订单号{{ orderData.no }}</view>
<view class="order-state ss-font-26" :class="formatOrderColor(orderData)">
{{ formatOrderStatus(orderData) }}
2022-11-22 07:45:36 +00:00
</view>
2024-07-09 09:34:18 +00:00
</view>
<view class="border-bottom" v-for="item in orderData.items" :key="item.id">
<s-goods-item
:img="item.picUrl"
:title="item.spuName"
:skuText="item.properties.map((property) => property.valueName).join(' ')"
:price="item.price"
:num="item.count"
/>
</view>
<view class="pay-box ss-m-t-30 ss-flex ss-row-right ss-p-r-20">
<view class="ss-flex ss-col-center">
<view class="discounts-title pay-color"> {{ orderData.productCount }} 件商品,总金额:</view>
<view class="discounts-money pay-color">
{{ fen2yuan(orderData.payPrice) }}
2022-11-22 07:45:36 +00:00
</view>
</view>
2024-07-09 09:34:18 +00:00
</view>
2022-11-22 07:45:36 +00:00
</view>
</template>
<script setup>
2024-07-09 09:34:18 +00:00
import { fen2yuan, formatOrderColor, formatOrderStatus } from '@/sheep/hooks/useGoods';
2022-11-22 07:45:36 +00:00
const props = defineProps({
orderData: {
type: Object,
default: {},
},
});
</script>
<style lang="scss" scoped>
2024-07-09 09:34:18 +00:00
.order-list-card-box {
.order-card-header {
height: 80rpx;
2022-11-22 07:45:36 +00:00
2024-07-09 09:34:18 +00:00
.order-no {
font-size: 26rpx;
font-weight: 500;
}
2022-11-22 07:45:36 +00:00
2024-07-09 09:34:18 +00:00
.order-state {}
}
.pay-box {
.discounts-title {
font-size: 24rpx;
line-height: normal;
color: #999999;
2022-11-22 07:45:36 +00:00
}
2024-07-09 09:34:18 +00:00
.discounts-money {
font-size: 24rpx;
line-height: normal;
color: #999;
font-family: OPPOSANS;
2022-11-22 07:45:36 +00:00
}
2024-07-09 09:34:18 +00:00
.pay-color {
2022-11-22 07:45:36 +00:00
color: #333;
2024-07-09 09:34:18 +00:00
}
}
.order-card-footer {
height: 100rpx;
.more-item-box {
padding: 20rpx;
.more-item {
height: 60rpx;
2022-11-22 07:45:36 +00:00
2024-07-09 09:34:18 +00:00
.title {
font-size: 26rpx;
}
2022-11-22 07:45:36 +00:00
}
}
2024-07-09 09:34:18 +00:00
.more-btn {
color: $dark-9;
2022-11-22 07:45:36 +00:00
font-size: 24rpx;
}
2024-07-09 09:34:18 +00:00
.content {
width: 154rpx;
color: #333333;
2022-11-22 07:45:36 +00:00
font-size: 26rpx;
font-weight: 500;
}
2024-07-09 09:34:18 +00:00
}
}
.warning-color {
color: #faad14;
}
2022-11-22 07:45:36 +00:00
2024-07-09 09:34:18 +00:00
.danger-color {
color: #ff3000;
}
2022-11-22 07:45:36 +00:00
2024-07-09 09:34:18 +00:00
.success-color {
color: #52c41a;
}
.info-color {
color: #999999;
2022-11-22 07:45:36 +00:00
}
</style>