You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
71 lines
2.5 KiB
71 lines
2.5 KiB
1 year ago
|
<!--商品信息,订单列表、评论列表中展示-->
|
||
|
<script setup lang="ts">
|
||
|
import { toRefs } from 'vue'
|
||
|
import {orderProductTypeFilter, productTypeFilter} from '~/utils/filter'
|
||
|
import useOrder from '~/composables/useOrder'
|
||
|
const { handlerNuxtLink } = useOrder()
|
||
|
const props = defineProps({
|
||
|
//列表数据
|
||
|
list: {
|
||
|
type: Object,
|
||
|
default: null,
|
||
|
},
|
||
|
refundStatus: {
|
||
|
type: Number,
|
||
|
default: null,
|
||
|
},
|
||
|
})
|
||
|
const { list,refundStatus } = toRefs(props)
|
||
|
|
||
|
//商品详情跳转
|
||
|
const handlerNuxtLinks = async (list: any) => {
|
||
|
if(refundStatus.value && refundStatus.value===-1) {
|
||
|
await handlerNuxtLink(list.productId, orderProductTypeFilter(list.productType))
|
||
|
}
|
||
|
}
|
||
|
|
||
|
//跳转至申请记录
|
||
|
const emit = defineEmits(['onHandlerToRecord'])
|
||
|
const handlerToRecord = async (orderNo:string)=>{
|
||
|
emit('onHandlerToRecord',orderNo)
|
||
|
}
|
||
|
</script>
|
||
|
|
||
|
<template>
|
||
|
<div class="flex-between-center orderProduct cursors">
|
||
|
<div
|
||
|
class="acea-row justify-between"
|
||
|
@click="handlerNuxtLinks(list)"
|
||
|
>
|
||
|
<el-image :src="list.image" class="backImg w100px h100px b-rd-12px" lazy></el-image>
|
||
|
<div class="ml-20px acea-row flex-col justify-center">
|
||
|
<div class="text-14px fontColor333 line1 mb14px w-635px font-500 oppoSans-M">{{ list.productName }}</div>
|
||
|
<div class="borRadius text-14px fontColor333 line1 mb-15px font-400 oppoSans-R">规格:{{ list.sku }}</div>
|
||
|
<div class="acea-row">
|
||
|
<div v-if="list.price && list.payNum" class="text-14px fontColor333 oppoSans-R mr-20px">
|
||
|
¥{{ list.price }} ×{{ list.payNum }}
|
||
|
</div>
|
||
|
<div @click.stop="handlerToRecord(list.orderNo)" v-if="(list.applyRefundNum+list.refundNum) && refundStatus === -1" class="text-14px font-color oppoSans-R mr-20px flex-y-center">
|
||
|
{{ list.applyRefundNum+list.refundNum }}件商品已申请售后 <span class="iconfont icon-gengduo"></span>
|
||
|
</div>
|
||
|
<div v-if="list.applyRefundNum && refundStatus > -1" class="text-14px fontColor333 oppoSans-R mr-20px">
|
||
|
申请数量:{{ list.applyRefundNum }}
|
||
|
</div>
|
||
|
<div v-if="list.afterSalesType" class="text-14px font-color oppoSans-R mr-20px">
|
||
|
{{ list.afterSalesType === 1 ? '仅退款' : '退货退款' }}
|
||
|
</div>
|
||
|
<div v-if="list.refundStatus === 3" class="text-14px font-color">
|
||
|
已退款:{{ list.refundPrice }}
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</template>
|
||
|
|
||
|
<style scoped lang="scss">
|
||
|
.orderProduct {
|
||
|
margin-bottom: 20px;
|
||
|
}
|
||
|
</style>
|