!275 Review代码修改

Merge pull request !275 from 疯狂的世界/dev
pull/279/head^2
芋道源码 2023-10-17 12:52:28 +00:00 committed by Gitee
commit 40ec1b08ae
No known key found for this signature in database
GPG Key ID: 173E9B9CA92EEF8F
11 changed files with 185 additions and 28 deletions

View File

@ -58,8 +58,8 @@ export interface MemberTerminalStatisticsRespVO {
export interface MemberCountRespVO { export interface MemberCountRespVO {
/** 用户访问量 */ /** 用户访问量 */
visitUserCount: string visitUserCount: string
/** 新增用户数量 */ /** 注册用户数量 */
createUserCount: number registerUserCount: number
} }
/** 会员注册数量 Response VO */ /** 会员注册数量 Response VO */
@ -86,21 +86,21 @@ export const getMemberAnalyse = (params: MemberAnalyseReqVO) => {
// 按照省份,查询会员统计列表 // 按照省份,查询会员统计列表
export const getMemberAreaStatisticsList = () => { export const getMemberAreaStatisticsList = () => {
return request.get<MemberAreaStatisticsRespVO[]>({ return request.get<MemberAreaStatisticsRespVO[]>({
url: '/statistics/member/get-area-statistics-list' url: '/statistics/member/area-statistics-list'
}) })
} }
// 按照性别,查询会员统计列表 // 按照性别,查询会员统计列表
export const getMemberSexStatisticsList = () => { export const getMemberSexStatisticsList = () => {
return request.get<MemberSexStatisticsRespVO[]>({ return request.get<MemberSexStatisticsRespVO[]>({
url: '/statistics/member/get-sex-statistics-list' url: '/statistics/member/sex-statistics-list'
}) })
} }
// 按照终端,查询会员统计列表 // 按照终端,查询会员统计列表
export const getMemberTerminalStatisticsList = () => { export const getMemberTerminalStatisticsList = () => {
return request.get<MemberTerminalStatisticsRespVO[]>({ return request.get<MemberTerminalStatisticsRespVO[]>({
url: '/statistics/member/get-terminal-statistics-list' url: '/statistics/member/terminal-statistics-list'
}) })
} }

View File

@ -1,6 +1,12 @@
import request from '@/config/axios' import request from '@/config/axios'
/** 支付统计 */
export interface PaySummaryRespVO {
/** 充值金额,单位分 */
rechargePrice: number
}
/** 获取钱包充值金额 */ /** 获取钱包充值金额 */
export const getWalletRechargePrice = async () => { export const getWalletRechargePrice = async () => {
return await request.get<number>({ url: `/statistics/pay/wallet-recharge-price` }) return await request.get<PaySummaryRespVO>({ url: `/statistics/pay/summary` })
} }

View File

@ -23,9 +23,9 @@ export interface TradeTrendSummaryRespVO {
orderPayPrice: number orderPayPrice: number
rechargePrice: number rechargePrice: number
expensePrice: number expensePrice: number
orderWalletPayPrice: number walletPayPrice: number
brokerageSettlementPrice: number brokerageSettlementPrice: number
orderRefundPrice: number afterSaleRefundPrice: number
} }
/** 交易订单数量 Response VO */ /** 交易订单数量 Response VO */

View File

@ -1,6 +1,7 @@
import request from '@/config/axios' import request from '@/config/axios'
export interface OrderVO { export interface OrderVO {
// ========== 订单基本信息 ==========
id?: number | null // 订单编号 id?: number | null // 订单编号
no?: string // 订单流水号 no?: string // 订单流水号
createTime?: Date | null // 下单时间 createTime?: Date | null // 下单时间
@ -15,35 +16,43 @@ export interface OrderVO {
cancelTime?: Date | null // 订单取消时间 cancelTime?: Date | null // 订单取消时间
cancelType?: number | null // 取消类型 cancelType?: number | null // 取消类型
remark?: string // 商家备注 remark?: string // 商家备注
// ========== 价格 + 支付基本信息 ==========
payOrderId?: number | null // 支付订单编号 payOrderId?: number | null // 支付订单编号
payed?: boolean // 是否已支付 payStatus?: boolean // 是否已支付
payTime?: Date | null // 付款时间 payTime?: Date | null // 付款时间
payChannelCode?: string // 支付渠道 payChannelCode?: string // 支付渠道
totalPrice?: number | null // 商品原价(总) totalPrice?: number | null // 商品原价(总)
orderPrice?: number | null // 订单原价(总)
discountPrice?: number | null // 订单优惠(总) discountPrice?: number | null // 订单优惠(总)
deliveryPrice?: number | null // 运费金额 deliveryPrice?: number | null // 运费金额
adjustPrice?: number | null // 订单调价(总) adjustPrice?: number | null // 订单调价(总)
payPrice?: number | null // 应付金额(总) payPrice?: number | null // 应付金额(总)
// ========== 收件 + 物流基本信息 ==========
deliveryType?: number | null // 发货方式 deliveryType?: number | null // 发货方式
pickUpStoreId?: number // 自提门店编号
pickUpVerifyCode?: string // 自提核销码
deliveryTemplateId?: number | null // 配送模板编号 deliveryTemplateId?: number | null // 配送模板编号
logisticsId?: number | null | null // 发货物流公司编号 logisticsId?: number | null // 发货物流公司编号
logisticsNo?: string // 发货物流单号 logisticsNo?: string // 发货物流单号
deliveryStatus?: number | null // 发货状态
deliveryTime?: Date | null // 发货时间 deliveryTime?: Date | null // 发货时间
receiveTime?: Date | null // 收货时间 receiveTime?: Date | null // 收货时间
receiverName?: string // 收件人名称 receiverName?: string // 收件人名称
receiverMobile?: string // 收件人手机 receiverMobile?: string // 收件人手机
receiverAreaId?: number | null // 收件人地区编号
receiverPostCode?: number | null // 收件人邮编 receiverPostCode?: number | null // 收件人邮编
receiverAreaId?: number | null // 收件人地区编号
receiverAreaName?: string //收件人地区名字
receiverDetailAddress?: string // 收件人详细地址 receiverDetailAddress?: string // 收件人详细地址
// ========== 售后基本信息 ==========
afterSaleStatus?: number | null // 售后状态 afterSaleStatus?: number | null // 售后状态
refundPrice?: number | null // 退款金额 refundPrice?: number | null // 退款金额
// ========== 营销基本信息 ==========
couponId?: number | null // 优惠劵编号 couponId?: number | null // 优惠劵编号
couponPrice?: number | null // 优惠劵减免金额 couponPrice?: number | null // 优惠劵减免金额
vipPrice?: number | null // VIP 减免金额
pointPrice?: number | null // 积分抵扣的金额 pointPrice?: number | null // 积分抵扣的金额
receiverAreaName?: string //收件人地区名字 vipPrice?: number | null // VIP 减免金额
items?: OrderItemRespVO[] // 订单项列表 items?: OrderItemRespVO[] // 订单项列表
// 下单用户信息 // 下单用户信息
user?: { user?: {
@ -142,5 +151,21 @@ export const updateOrderAddress = async (data: any) => {
// 订单核销 // 订单核销
export const pickUpOrder = async (id: number) => { export const pickUpOrder = async (id: number) => {
return await request.put({ url: `/trade/order/pick-up?id=${id}` }) return await request.put({ url: `/trade/order/pick-up-by-id?id=${id}` })
}
// 订单核销
export const pickUpOrderByVerifyCode = async (pickUpVerifyCode: string) => {
return await request.put({
url: `/trade/order/pick-up-by-verify-code`,
params: { pickUpVerifyCode }
})
}
// 查询核销码对应的订单
export const getOrderByPickUpVerifyCode = async (pickUpVerifyCode: string) => {
return await request.get<OrderVO>({
url: `/trade/order/get-by-pick-up-verify-code`,
params: { pickUpVerifyCode }
})
} }

View File

@ -70,7 +70,8 @@ const getProductData = async () => {
/** 查询钱包充值数据 */ /** 查询钱包充值数据 */
const getWalletRechargeData = async () => { const getWalletRechargeData = async () => {
data.rechargePrice.value = await PayStatisticsApi.getWalletRechargePrice() const paySummary = await PayStatisticsApi.getWalletRechargePrice()
data.rechargePrice.value = paySummary.rechargePrice
} }
/** /**

View File

@ -186,7 +186,7 @@ const getOrderCountTrendComparison = async (
dates.push(item.value.date) dates.push(item.value.date)
if (series.length === 2) { if (series.length === 2) {
series[0].data.push(fenToYuan(item?.value?.orderPayPrice || 0)) // series[0].data.push(fenToYuan(item?.value?.orderPayPrice || 0)) //
series[1].data.push(fenToYuan(item?.value?.orderPayCount || 0)) // series[1].data.push(fenToYuan(item?.value?.orderPayCount || 0)) //
} else { } else {
series[0].data.push(fenToYuan(item?.reference?.orderPayPrice || 0)) // series[0].data.push(fenToYuan(item?.reference?.orderPayPrice || 0)) //
series[1].data.push(fenToYuan(item?.value?.orderPayPrice || 0)) // series[1].data.push(fenToYuan(item?.value?.orderPayPrice || 0)) //

View File

@ -32,8 +32,8 @@
<ComparisonCard <ComparisonCard
tag="今日" tag="今日"
title="新增用户" title="新增用户"
:value="userComparison?.value?.createUserCount || 0" :value="userComparison?.value?.registerUserCount || 0"
:reference="userComparison?.reference?.createUserCount || 0" :reference="userComparison?.reference?.registerUserCount || 0"
/> />
</el-col> </el-col>
</el-row> </el-row>

View File

@ -156,11 +156,11 @@
icon-bg-color="text-cyan-500" icon-bg-color="text-cyan-500"
prefix="¥" prefix="¥"
:decimals="2" :decimals="2"
:value="fenToYuan(trendSummary?.value?.orderWalletPayPrice || 0)" :value="fenToYuan(trendSummary?.value?.walletPayPrice || 0)"
:percent=" :percent="
calculateRelativeRate( calculateRelativeRate(
trendSummary?.value?.orderWalletPayPrice, trendSummary?.value?.walletPayPrice,
trendSummary?.reference?.orderWalletPayPrice trendSummary?.reference?.walletPayPrice
) )
" "
/> />
@ -192,11 +192,11 @@
icon-bg-color="text-blue-500" icon-bg-color="text-blue-500"
prefix="¥" prefix="¥"
:decimals="2" :decimals="2"
:value="fenToYuan(trendSummary?.value?.orderRefundPrice || 0)" :value="fenToYuan(trendSummary?.value?.afterSaleRefundPrice || 0)"
:percent=" :percent="
calculateRelativeRate( calculateRelativeRate(
trendSummary?.value?.orderRefundPrice, trendSummary?.value?.afterSaleRefundPrice,
trendSummary?.reference?.orderRefundPrice trendSummary?.reference?.afterSaleRefundPrice
) )
" "
/> />

View File

@ -54,7 +54,7 @@
</el-button> </el-button>
<!-- 到店自提 --> <!-- 到店自提 -->
<el-button <el-button
v-if="formData.deliveryType === DeliveryTypeEnum.PICK_UP.type" v-if="formData.deliveryType === DeliveryTypeEnum.PICK_UP.type && showPickUp"
type="primary" type="primary"
@click="handlePickUp" @click="handlePickUp"
> >
@ -235,6 +235,7 @@ import * as DeliveryExpressApi from '@/api/mall/trade/delivery/express'
import { useTagsViewStore } from '@/store/modules/tagsView' import { useTagsViewStore } from '@/store/modules/tagsView'
import { DeliveryTypeEnum, TradeOrderStatusEnum } from '@/utils/constants' import { DeliveryTypeEnum, TradeOrderStatusEnum } from '@/utils/constants'
import * as DeliveryPickUpStoreApi from '@/api/mall/trade/delivery/pickUpStore' import * as DeliveryPickUpStoreApi from '@/api/mall/trade/delivery/pickUpStore'
import { propTypes } from '@/utils/propTypes'
defineOptions({ name: 'TradeOrderDetail' }) defineOptions({ name: 'TradeOrderDetail' })
@ -294,8 +295,12 @@ const handlePickUp = async () => {
/** 获得详情 */ /** 获得详情 */
const { params } = useRoute() // const { params } = useRoute() //
const props = defineProps({
id: propTypes.number.def(undefined), // ID
showPickUp: propTypes.bool.def(true) //
})
const id = (params.id || props.id) as unknown as number
const getDetail = async () => { const getDetail = async () => {
const id = params.id as unknown as number
if (id) { if (id) {
const res = (await TradeOrderApi.getOrder(id)) as TradeOrderApi.OrderVO const res = (await TradeOrderApi.getOrder(id)) as TradeOrderApi.OrderVO
// //

View File

@ -0,0 +1,108 @@
<template>
<!-- 核销对话框 -->
<Dialog v-model="dialogVisible" title="订单核销" width="35%">
<el-form
ref="formRef"
v-loading="formLoading"
:model="formData"
:rules="formRules"
label-width="100px"
>
<el-form-item prop="pickUpVerifyCode" label="核销码">
<el-input v-model="formData.pickUpVerifyCode" placeholder="请输入核销码" />
</el-form-item>
</el-form>
<template #footer>
<el-button type="primary" :disabled="formLoading" @click="getOrderByPickUpVerifyCode">
查询
</el-button>
<el-button @click="dialogVisible = false"> </el-button>
</template>
</Dialog>
<!-- 核销确认对话框 -->
<Dialog v-model="detailDialogVisible" title="订单详情" width="55%">
<TradeOrderDetail v-if="orderDetails.id" :id="orderDetails.id" :show-pick-up="false" />
<template #footer>
<el-button type="primary" :disabled="formLoading" @click="submitForm"> </el-button>
<el-button @click="detailDialogVisible = false"> </el-button>
</template>
</Dialog>
</template>
<script lang="ts" setup>
import * as TradeOrderApi from '@/api/mall/trade/order'
import { OrderVO } from '@/api/mall/trade/order'
import { DeliveryTypeEnum, TradeOrderStatusEnum } from '@/utils/constants'
import TradeOrderDetail from '@/views/mall/trade/order/detail/index.vue'
/** 订单核销表单 */
defineOptions({ name: 'OrderPickUpForm' })
const message = useMessage() //
const dialogVisible = ref(false) //
const detailDialogVisible = ref(false) //
const formLoading = ref(false) // 12
const formRules = reactive({
pickUpVerifyCode: [{ required: true, message: '核销码不能为空', trigger: 'blur' }]
})
const formData = ref({
pickUpVerifyCode: '' //
})
const formRef = ref() // Ref
const orderDetails = ref<OrderVO>({})
/** 打开弹窗 */
const open = async () => {
resetForm()
dialogVisible.value = true
}
defineExpose({ open }) // open
/** 提交表单 */
const emit = defineEmits(['success']) // success
const submitForm = async () => {
//
formLoading.value = true
try {
await TradeOrderApi.pickUpOrderByVerifyCode(formData.value.pickUpVerifyCode)
message.success('核销成功')
detailDialogVisible.value = false
dialogVisible.value = false
//
emit('success', true)
} finally {
formLoading.value = false
}
}
/** 重置表单 */
const resetForm = () => {
formData.value = {
pickUpVerifyCode: '' //
}
formRef.value?.resetFields()
}
/** 查询核销码对应的订单 */
const getOrderByPickUpVerifyCode = async () => {
//
if (!formRef) return
const valid = await formRef.value.validate()
if (!valid) return
formLoading.value = true
const data = await TradeOrderApi.getOrderByPickUpVerifyCode(formData.value.pickUpVerifyCode)
formLoading.value = false
if (data?.deliveryType !== DeliveryTypeEnum.PICK_UP.type) {
message.error('请输入正确的核销码')
return
}
if (data?.status !== TradeOrderStatusEnum.UNDELIVERED.status) {
message.error('订单不是待核销状态')
return
}
orderDetails.value = data
//
detailDialogVisible.value = true
}
</script>

View File

@ -156,6 +156,10 @@
<Icon class="mr-5px" icon="ep:refresh" /> <Icon class="mr-5px" icon="ep:refresh" />
重置 重置
</el-button> </el-button>
<el-button @click="handlePickup" type="success" plain>
<Icon class="mr-5px" icon="ep:check" />
核销
</el-button>
</el-form-item> </el-form-item>
</el-form> </el-form>
</ContentWrap> </ContentWrap>
@ -347,6 +351,7 @@
<!-- 各种操作的弹窗 --> <!-- 各种操作的弹窗 -->
<OrderDeliveryForm ref="deliveryFormRef" @success="getList" /> <OrderDeliveryForm ref="deliveryFormRef" @success="getList" />
<OrderUpdateRemarkForm ref="updateRemarkForm" @success="getList" /> <OrderUpdateRemarkForm ref="updateRemarkForm" @success="getList" />
<OrderPickUpForm ref="pickUpForm" @success="getList" />
</template> </template>
<script lang="ts" setup> <script lang="ts" setup>
@ -361,6 +366,7 @@ import { floatToFixed2 } from '@/utils'
import { createImageViewer } from '@/components/ImageViewer' import { createImageViewer } from '@/components/ImageViewer'
import * as DeliveryExpressApi from '@/api/mall/trade/delivery/express' import * as DeliveryExpressApi from '@/api/mall/trade/delivery/express'
import { DeliveryTypeEnum, TradeOrderStatusEnum } from '@/utils/constants' import { DeliveryTypeEnum, TradeOrderStatusEnum } from '@/utils/constants'
import OrderPickUpForm from './form/OrderPickUpForm.vue'
defineOptions({ name: 'TradeOrder' }) defineOptions({ name: 'TradeOrder' })
@ -521,6 +527,12 @@ watch(
} }
) )
/** 显示核销表单 */
const pickUpForm = ref()
const handlePickup = () => {
pickUpForm.value.open()
}
const pickUpStoreList = ref([]) // const pickUpStoreList = ref([]) //
const deliveryExpressList = ref([]) // const deliveryExpressList = ref([]) //
/** 初始化 **/ /** 初始化 **/