完善订单详情和售后退款日志展示样式重构

(cherry picked from commit 46fd154e3a)
pull/253/head
puhui999 2023-09-03 01:44:22 +08:00 committed by shizhong
parent 563c3eeddf
commit c960ba1e20
4 changed files with 161 additions and 14 deletions

View File

@ -51,12 +51,13 @@ export interface OrderVO {
avatar?: string avatar?: string
} }
// 订单操作日志 // 订单操作日志
orderLog: orderLog[] orderLog?: orderLog[]
} }
export interface orderLog { export interface orderLog {
content?: string content?: string
createTime?: Date createTime?: Date
userType?: number
} }
export interface OrderItemRespVO { export interface OrderItemRespVO {

View File

@ -60,13 +60,20 @@ export const getBoolDictOptions = (dictType: string) => {
return dictOption return dictOption
} }
export const getDictObj = (dictType: string, value: any) => { /**
*
* @param dictType
* @param value
* @return DictDataType
*/
export const getDictObj = (dictType: string, value: any): DictDataType | undefined => {
const dictOptions: DictDataType[] = getDictOptions(dictType) const dictOptions: DictDataType[] = getDictOptions(dictType)
dictOptions.forEach((dict: DictDataType) => { console.log(dictOptions)
if (dict.value === value.toString()) { for (const dict of dictOptions) {
if (dict.value === value + '') {
return dict return dict
} }
}) }
} }
/** /**
@ -74,12 +81,13 @@ export const getDictObj = (dictType: string, value: any) => {
* *
* @param dictType * @param dictType
* @param value * @param value
* @return
*/ */
export const getDictLabel = (dictType: string, value: any) => { export const getDictLabel = (dictType: string, value: any): string => {
const dictOptions: DictDataType[] = getDictOptions(dictType) const dictOptions: DictDataType[] = getDictOptions(dictType)
const dictLabel = ref('') const dictLabel = ref('')
dictOptions.forEach((dict: DictDataType) => { dictOptions.forEach((dict: DictDataType) => {
if (dict.value === value) { if (dict.value === value + '') {
dictLabel.value = dict.label dictLabel.value = dict.label
} }
}) })

View File

@ -131,9 +131,7 @@
:timestamp="formatDate(saleLog.createTime)" :timestamp="formatDate(saleLog.createTime)"
placement="top" placement="top"
> >
<el-card> <div class="el-timeline-right-content">
<span>用户类型</span>
<dict-tag :type="DICT_TYPE.USER_TYPE" :value="saleLog.userType" class="mr-10px" />
<span>售后状态(之前)</span> <span>售后状态(之前)</span>
<dict-tag <dict-tag
:type="DICT_TYPE.TRADE_AFTER_SALE_STATUS" :type="DICT_TYPE.TRADE_AFTER_SALE_STATUS"
@ -147,7 +145,15 @@
class="mr-10px" class="mr-10px"
/> />
<span>操作明细{{ saleLog.content }}</span> <span>操作明细{{ saleLog.content }}</span>
</el-card> </div>
<template #dot>
<span
:style="{ backgroundColor: updateStyles(saleLog.userType) }"
class="dot-node-style"
>
{{ getDictLabel(DICT_TYPE.USER_TYPE, saleLog.userType)[0] }}
</span>
</template>
</el-timeline-item> </el-timeline-item>
</el-timeline> </el-timeline>
</el-descriptions-item> </el-descriptions-item>
@ -160,7 +166,7 @@
<script lang="ts" setup> <script lang="ts" setup>
import * as AfterSaleApi from '@/api/mall/trade/afterSale/index' import * as AfterSaleApi from '@/api/mall/trade/afterSale/index'
import { floatToFixed2 } from '@/utils' import { floatToFixed2 } from '@/utils'
import { DICT_TYPE } from '@/utils/dict' import { DICT_TYPE, getDictLabel, getDictObj } from '@/utils/dict'
import { formatDate } from '@/utils/formatTime' import { formatDate } from '@/utils/formatTime'
import UpdateAuditReasonForm from '@/views/mall/trade/afterSale/form/AfterSaleDisagreeForm.vue' import UpdateAuditReasonForm from '@/views/mall/trade/afterSale/form/AfterSaleDisagreeForm.vue'
import { createImageViewer } from '@/components/ImageViewer' import { createImageViewer } from '@/components/ImageViewer'
@ -177,6 +183,21 @@ const formData = ref({
}) })
const updateAuditReasonFormRef = ref() // Ref const updateAuditReasonFormRef = ref() // Ref
const updateStyles = (type: number) => {
const dict = getDictObj(DICT_TYPE.USER_TYPE, type)
switch (dict?.colorType) {
case 'success':
return '#67C23A'
case 'info':
return '#909399'
case 'warning':
return '#E6A23C'
case 'danger':
return '#F56C6C'
}
return '#409EFF'
}
/** 获得详情 */ /** 获得详情 */
const getDetail = async () => { const getDetail = async () => {
const id = params.orderId as unknown as number const id = params.orderId as unknown as number
@ -277,4 +298,51 @@ onMounted(async () => {
} }
} }
} }
// 线
:deep(.el-timeline) {
margin: 10px 0px 0px 160px;
.el-timeline-item__wrapper {
position: relative;
top: -20px;
.el-timeline-item__timestamp {
position: absolute !important;
top: 10px;
left: -150px;
}
}
.el-timeline-right-content {
display: flex;
align-items: center;
min-height: 30px;
padding: 10px;
background-color: #f7f8fa;
&::before {
content: ''; /* 必须设置 content 属性 */
position: absolute;
top: 10px;
left: 13px; /* 将伪元素水平居中 */
border-width: 8px; /* 调整尖角大小 */
border-style: solid;
border-color: transparent #f7f8fa transparent transparent; /* 尖角颜色,左侧朝向 */
}
}
.dot-node-style {
width: 20px;
height: 20px;
position: absolute;
left: -5px;
display: flex;
justify-content: center;
align-items: center;
border-radius: 50%;
color: #fff;
font-size: 10px;
}
}
</style> </style>

View File

@ -155,8 +155,16 @@
v-for="(log, index) in formData.orderLog" v-for="(log, index) in formData.orderLog"
:key="index" :key="index"
:timestamp="formatDate(log.createTime!)" :timestamp="formatDate(log.createTime!)"
placement="top"
> >
<div class="el-timeline-right-content">
{{ log.content }} {{ log.content }}
</div>
<template #dot>
<span :style="{ backgroundColor: updateStyles(log.userType) }" class="dot-node-style">
{{ getDictLabel(DICT_TYPE.USER_TYPE, log.userType)[0] }}
</span>
</template>
</el-timeline-item> </el-timeline-item>
</el-timeline> </el-timeline>
</el-descriptions-item> </el-descriptions-item>
@ -173,7 +181,7 @@
import * as TradeOrderApi from '@/api/mall/trade/order' import * as TradeOrderApi from '@/api/mall/trade/order'
import { floatToFixed2 } from '@/utils' import { floatToFixed2 } from '@/utils'
import { formatDate } from '@/utils/formatTime' import { formatDate } from '@/utils/formatTime'
import { DICT_TYPE } from '@/utils/dict' import { DICT_TYPE, getDictLabel, getDictObj } from '@/utils/dict'
import OrderUpdateRemarkForm from '@/views/mall/trade/order/form/OrderUpdateRemarkForm.vue' import OrderUpdateRemarkForm from '@/views/mall/trade/order/form/OrderUpdateRemarkForm.vue'
import OrderDeliveryForm from '@/views/mall/trade/order/form/OrderDeliveryForm.vue' import OrderDeliveryForm from '@/views/mall/trade/order/form/OrderDeliveryForm.vue'
import OrderUpdateAddressForm from '@/views/mall/trade/order/form/OrderUpdateAddressForm.vue' import OrderUpdateAddressForm from '@/views/mall/trade/order/form/OrderUpdateAddressForm.vue'
@ -184,6 +192,21 @@ defineOptions({ name: 'TradeOrderDetail' })
const message = useMessage() // const message = useMessage() //
const updateStyles = (type: number) => {
const dict = getDictObj(DICT_TYPE.USER_TYPE, type)
switch (dict?.colorType) {
case 'success':
return '#67C23A'
case 'info':
return '#909399'
case 'warning':
return '#E6A23C'
case 'danger':
return '#F56C6C'
}
return '#409EFF'
}
// //
const formData = ref<TradeOrderApi.OrderVO>({ const formData = ref<TradeOrderApi.OrderVO>({
orderLog: [] // TODO @puhui999orderLogs orderLog: [] // TODO @puhui999orderLogs
@ -267,4 +290,51 @@ onMounted(async () => {
} }
} }
} }
// 线
:deep(.el-timeline) {
margin: 10px 0px 0px 160px;
.el-timeline-item__wrapper {
position: relative;
top: -20px;
.el-timeline-item__timestamp {
position: absolute !important;
top: 10px;
left: -150px;
}
}
.el-timeline-right-content {
display: flex;
align-items: center;
min-height: 30px;
padding: 10px;
background-color: #f7f8fa;
&::before {
content: ''; /* 必须设置 content 属性 */
position: absolute;
top: 10px;
left: 13px; /* 将伪元素水平居中 */
border-width: 8px; /* 调整尖角大小 */
border-style: solid;
border-color: transparent #f7f8fa transparent transparent; /* 尖角颜色,左侧朝向 */
}
}
.dot-node-style {
width: 20px;
height: 20px;
position: absolute;
left: -5px;
display: flex;
justify-content: center;
align-items: center;
border-radius: 50%;
color: #fff;
font-size: 10px;
}
}
</style> </style>